From 1344f6314e854c9e61ecf6d20c9f169030d85f15 Mon Sep 17 00:00:00 2001 From: pprokop Date: Fri, 4 Nov 2016 12:41:18 +0100 Subject: [PATCH] Changing k8s-client to kubernetes/go-client --- Godeps/Godeps.json | 1134 +- client/client.go | 54 +- dependencies/daemonset/daemonset.go | 19 +- entrypoint/entrypoint.go | 4 +- mocks/client.go | 24 +- mocks/daemonset.go | 32 +- mocks/endpoints.go | 49 +- mocks/job.go | 24 +- mocks/pod.go | 79 +- mocks/service.go | 40 +- vendor/github.com/blang/semver/README.md | 77 +- vendor/github.com/blang/semver/range.go | 233 - vendor/github.com/blang/semver/semver.go | 23 - .../candiedyaml/.gitignore | 1 - .../candiedyaml/.travis.yml | 12 - .../candiedyaml/LICENSE | 176 - .../candiedyaml/README.md | 59 - .../cloudfoundry-incubator/candiedyaml/api.go | 834 - .../candiedyaml/decode.go | 622 - .../candiedyaml/emitter.go | 2072 - .../candiedyaml/encode.go | 395 - .../candiedyaml/libyaml-LICENSE | 19 - .../candiedyaml/parser.go | 1230 - .../candiedyaml/reader.go | 465 - .../candiedyaml/resolver.go | 449 - .../candiedyaml/run_parser.go | 62 - .../candiedyaml/scanner.go | 3318 -- .../candiedyaml/tags.go | 360 - .../candiedyaml/writer.go | 128 - .../candiedyaml/yaml_definesh.go | 22 - .../candiedyaml/yaml_privateh.go | 891 - .../candiedyaml/yamlh.go | 953 - .../coreos/go-oidc/jose/sig_hmac.go | 0 vendor/github.com/davecgh/go-spew/LICENSE | 2 - .../github.com/davecgh/go-spew/spew/bypass.go | 7 +- .../davecgh/go-spew/spew/bypasssafe.go | 7 +- .../github.com/davecgh/go-spew/spew/config.go | 2 +- .../distribution/reference/reference.go | 10 +- .../go-restful/swagger/model_builder.go | 11 - .../go-restful/swagger/model_property_ext.go | 15 - .../go-restful/swagger/swagger_webservice.go | 2 +- vendor/github.com/ghodss/yaml/README.md | 18 +- vendor/github.com/ghodss/yaml/yaml.go | 8 +- .../github.com/go-openapi/spec/.drone.sec | 0 .../github.com/go-openapi/spec/.drone.yml | 0 .../go-openapi/spec}/.pullapprove.yml | 0 vendor/github.com/go-openapi/spec/.travis.yml | 16 - vendor/github.com/go-openapi/spec/README.md | 4 +- vendor/github.com/go-openapi/spec/bindata.go | 26 +- vendor/github.com/go-openapi/spec/debug.test | Bin 9263612 -> 0 bytes vendor/github.com/go-openapi/spec/expander.go | 180 +- vendor/github.com/go-openapi/spec/header.go | 4 - vendor/github.com/go-openapi/spec/spec.go | 9 +- .../github.com/go-openapi/swag/.drone.sec | 0 .../github.com/go-openapi/swag/.drone.yml | 0 .../go-openapi/swag}/.pullapprove.yml | 0 vendor/github.com/go-openapi/swag/.travis.yml | 13 - vendor/github.com/go-openapi/swag/README.md | 2 +- vendor/github.com/go-openapi/swag/loading.go | 45 +- vendor/github.com/go-openapi/swag/util.go | 3 - vendor/github.com/gogo/protobuf/LICENSE | 6 +- .../github.com/gogo/protobuf/proto/Makefile | 2 +- .../github.com/gogo/protobuf/proto/clone.go | 14 +- .../github.com/gogo/protobuf/proto/decode.go | 25 +- .../gogo/protobuf/proto/decode_gogo.go | 6 +- .../gogo/protobuf/proto/duration.go | 100 - .../gogo/protobuf/proto/duration_gogo.go | 202 - .../github.com/gogo/protobuf/proto/encode.go | 66 +- .../gogo/protobuf/proto/encode_gogo.go | 6 +- .../github.com/gogo/protobuf/proto/equal.go | 34 +- .../gogo/protobuf/proto/extensions.go | 412 +- .../gogo/protobuf/proto/extensions_gogo.go | 88 +- vendor/github.com/gogo/protobuf/proto/lib.go | 6 +- .../gogo/protobuf/proto/lib_gogo.go | 6 +- .../gogo/protobuf/proto/message_set.go | 43 +- .../gogo/protobuf/proto/pointer_reflect.go | 7 +- .../gogo/protobuf/proto/pointer_unsafe.go | 6 +- .../protobuf/proto/pointer_unsafe_gogo.go | 19 +- .../gogo/protobuf/proto/properties.go | 93 +- .../gogo/protobuf/proto/properties_gogo.go | 51 +- .../gogo/protobuf/proto/skip_gogo.go | 6 +- vendor/github.com/gogo/protobuf/proto/text.go | 213 +- .../gogo/protobuf/proto/text_gogo.go | 12 +- .../gogo/protobuf/proto/text_parser.go | 264 +- .../gogo/protobuf/proto/timestamp.go | 113 - .../gogo/protobuf/proto/timestamp_gogo.go | 227 - .../gogo/protobuf/sortkeys/sortkeys.go | 4 +- vendor/github.com/golang/glog/README | 2 +- vendor/github.com/golang/glog/glog.go | 5 +- .../golang/protobuf/proto/decode.go | 117 +- .../golang/protobuf/proto/encode.go | 14 +- .../github.com/golang/protobuf/proto/equal.go | 8 +- .../golang/protobuf/proto/extensions.go | 31 - .../github.com/golang/protobuf/proto/lib.go | 2 +- .../golang/protobuf/proto/properties.go | 10 +- .../github.com/golang/protobuf/proto/text.go | 2 +- .../golang/protobuf/proto/text_parser.go | 17 +- vendor/github.com/google/cadvisor/LICENSE | 190 - .../google/cadvisor/info/v1/container.go | 607 - .../google/cadvisor/info/v1/docker.go | 37 - .../google/cadvisor/info/v1/machine.go | 208 - .../google/cadvisor/info/v1/metric.go | 79 - vendor/github.com/google/gofuzz/README.md | 8 +- vendor/github.com/google/gofuzz/fuzz.go | 11 +- .../jonboulle/clockwork/.travis.yml | 5 - .../github.com/jonboulle/clockwork/README.md | 17 +- .../jonboulle/clockwork/clockwork.go | 28 +- .../mailru/easyjson/jlexer/lexer.go | 32 +- .../mailru/easyjson/jwriter/writer.go | 57 +- vendor/github.com/pborman/uuid/.travis.yml | 9 - .../github.com/pborman/uuid/CONTRIBUTING.md | 10 - vendor/github.com/pborman/uuid/README.md | 13 - vendor/github.com/pborman/uuid/dce.go | 0 vendor/github.com/pborman/uuid/doc.go | 0 vendor/github.com/pborman/uuid/hash.go | 2 +- vendor/github.com/pborman/uuid/json.go | 12 +- vendor/github.com/pborman/uuid/node.go | 20 +- vendor/github.com/pborman/uuid/sql.go | 66 - vendor/github.com/pborman/uuid/time.go | 14 +- vendor/github.com/pborman/uuid/util.go | 2 +- vendor/github.com/pborman/uuid/uuid.go | 66 +- vendor/github.com/spf13/pflag/flag.go | 2 +- vendor/github.com/spf13/pflag/string_array.go | 3 +- vendor/github.com/spf13/pflag/string_slice.go | 2 +- vendor/github.com/ugorji/go/codec/0doc.go | 14 +- vendor/github.com/ugorji/go/codec/README.md | 2 +- vendor/github.com/ugorji/go/codec/binc.go | 13 +- vendor/github.com/ugorji/go/codec/cbor.go | 10 +- vendor/github.com/ugorji/go/codec/decode.go | 66 +- .../github.com/ugorji/go/codec/decode_go.go | 16 - .../github.com/ugorji/go/codec/decode_go14.go | 14 - vendor/github.com/ugorji/go/codec/encode.go | 179 +- .../ugorji/go/codec/fast-path.generated.go | 574 +- .../ugorji/go/codec/fast-path.go.tmpl | 54 +- .../ugorji/go/codec/fast-path.not.go | 2 - .../ugorji/go/codec/gen-dec-array.go.tmpl | 5 +- .../ugorji/go/codec/gen-helper.generated.go | 14 +- .../ugorji/go/codec/gen-helper.go.tmpl | 12 +- .../ugorji/go/codec/gen.generated.go | 5 +- vendor/github.com/ugorji/go/codec/gen.go | 226 +- vendor/github.com/ugorji/go/codec/gen_15.go | 12 - vendor/github.com/ugorji/go/codec/gen_16.go | 12 - vendor/github.com/ugorji/go/codec/gen_17.go | 10 - vendor/github.com/ugorji/go/codec/helper.go | 289 +- .../ugorji/go/codec/helper_internal.go | 4 +- .../ugorji/go/codec/helper_not_unsafe.go | 2 +- .../ugorji/go/codec/helper_unsafe.go | 16 +- vendor/github.com/ugorji/go/codec/json.go | 183 +- vendor/github.com/ugorji/go/codec/msgpack.go | 10 +- vendor/github.com/ugorji/go/codec/prebuild.sh | 2 +- vendor/github.com/ugorji/go/codec/rpc.go | 2 +- vendor/github.com/ugorji/go/codec/simple.go | 10 +- vendor/github.com/ugorji/go/codec/test.py | 18 +- vendor/github.com/ugorji/go/codec/tests.sh | 32 +- vendor/github.com/ugorji/go/codec/time.go | 13 +- .../x/net/context/ctxhttp/ctxhttp.go | 12 +- .../x/net/http2/client_conn_pool.go | 9 +- vendor/golang.org/x/net/http2/errors.go | 8 - vendor/golang.org/x/net/http2/frame.go | 46 +- vendor/golang.org/x/net/http2/go17.go | 12 - vendor/golang.org/x/net/http2/go17_not18.go | 36 - vendor/golang.org/x/net/http2/go18.go | 11 - vendor/golang.org/x/net/http2/hpack/hpack.go | 2 +- vendor/golang.org/x/net/http2/http2.go | 16 +- vendor/golang.org/x/net/http2/not_go17.go | 38 +- vendor/golang.org/x/net/http2/server.go | 92 +- vendor/golang.org/x/net/http2/transport.go | 506 +- .../golang.org/x/net/lex/httplex/httplex.go | 39 - vendor/golang.org/x/text/cases/cases.go | 49 +- vendor/golang.org/x/text/cases/context.go | 101 +- vendor/golang.org/x/text/cases/fold.go | 10 +- vendor/golang.org/x/text/cases/gen.go | 20 +- vendor/golang.org/x/text/cases/gen_trieval.go | 12 +- vendor/golang.org/x/text/cases/icu.go | 61 - vendor/golang.org/x/text/cases/info.go | 15 +- vendor/golang.org/x/text/cases/map.go | 383 +- vendor/golang.org/x/text/cases/tables.go | 388 +- vendor/golang.org/x/text/cases/trieval.go | 12 +- vendor/golang.org/x/text/internal/gen.go | 52 - vendor/golang.org/x/text/internal/internal.go | 51 - vendor/golang.org/x/text/internal/match.go | 67 - vendor/golang.org/x/text/internal/tables.go | 116 - .../golang.org/x/text/internal/tag/tag.go | 0 vendor/golang.org/x/text/language/index.go | 1501 +- vendor/golang.org/x/text/language/language.go | 2 +- .../golang.org/x/text/language/maketables.go | 13 - vendor/golang.org/x/text/language/match.go | 21 +- vendor/golang.org/x/text/language/tables.go | 5038 +- vendor/golang.org/x/text/runes/cond.go | 77 +- vendor/golang.org/x/text/runes/runes.go | 139 +- .../x/text/secure/bidirule/bidirule.go | 110 +- .../x/text/secure/precis/options.go | 15 - .../x/text/secure/precis/profile.go | 36 +- .../x/text/secure/precis/profiles.go | 2 +- .../golang.org/x/text/transform/transform.go | 52 +- .../golang.org/x/text/unicode/bidi/bracket.go | 42 +- vendor/golang.org/x/text/unicode/bidi/core.go | 3 - .../x/text/unicode/norm/normalize.go | 36 +- vendor/golang.org/x/text/width/transform.go | 77 - vendor/golang.org/x/text/width/width.go | 9 +- .../google.golang.org/appengine/.travis.yml | 4 +- vendor/google.golang.org/appengine/README.md | 4 +- .../appengine/internal/api.go | 42 +- .../appengine/internal/api_common.go | 30 - vendor/gopkg.in/yaml.v2/.travis.yml | 9 - vendor/gopkg.in/yaml.v2/LICENSE | 195 +- vendor/gopkg.in/yaml.v2/README.md | 2 +- vendor/gopkg.in/yaml.v2/decode.go | 2 +- vendor/gopkg.in/yaml.v2/readerc.go | 7 +- vendor/gopkg.in/yaml.v2/scannerc.go | 2 +- vendor/gopkg.in/yaml.v2/yaml.go | 2 +- .../k8s.io/{kubernetes => client-go}/LICENSE | 0 .../discovery/discovery_client.go | 59 +- vendor/k8s.io/client-go/discovery/helper.go | 135 + .../discovery/restmapper.go | 6 +- .../discovery/unstructured.go | 4 +- .../k8s.io/client-go/kubernetes/clientset.go | 261 + vendor/k8s.io/client-go/kubernetes/doc.go | 20 + .../kubernetes}/import_known_versions.go | 29 +- .../typed/apps/v1alpha1}/apps_client.go | 55 +- .../kubernetes/typed/apps/v1alpha1/doc.go | 20 + .../apps/v1alpha1/generated_expansion.go} | 5 +- .../typed/apps/v1alpha1/statefulset.go | 167 + .../v1beta1/authentication_client.go | 96 + .../typed/authentication/v1beta1}/doc.go | 4 +- .../v1beta1}/generated_expansion.go | 6 +- .../authentication/v1beta1/tokenreview.go} | 25 +- .../v1beta1/authorization_client.go | 106 + .../typed/authorization/v1beta1/doc.go | 20 + .../v1beta1/generated_expansion.go | 21 + .../v1beta1/localsubjectaccessreview.go | 46 + .../v1beta1/selfsubjectaccessreview.go | 44 + .../v1beta1}/subjectaccessreview.go | 25 +- .../v1beta1/subjectaccessreview_expansion.go | 36 + .../autoscaling/v1/autoscaling_client.go | 96 + .../kubernetes/typed/autoscaling/v1}/doc.go | 4 +- .../autoscaling/v1/generated_expansion.go | 19 + .../autoscaling/v1/horizontalpodautoscaler.go | 167 + .../typed/batch/v1}/batch_client.go | 54 +- .../kubernetes/typed/batch/v1}/doc.go | 4 +- .../typed/batch/v1}/generated_expansion.go | 4 +- .../kubernetes/typed/batch/v1}/job.go | 62 +- .../v1alpha1/certificates_client.go | 96 + .../v1alpha1/certificatesigningrequest.go | 156 + .../typed/certificates/v1alpha1/doc.go | 20 + .../v1alpha1/generated_expansion.go | 19 + .../typed/core/v1}/componentstatus.go | 54 +- .../kubernetes/typed/core/v1}/configmap.go | 54 +- .../kubernetes/typed/core/v1}/core_client.go | 49 +- .../kubernetes/typed/core/v1}/doc.go | 4 +- .../kubernetes/typed/core/v1}/endpoints.go | 54 +- .../kubernetes/typed/core/v1}/event.go | 54 +- .../typed/core/v1}/event_expansion.go | 39 +- .../typed/core/v1}/generated_expansion.go | 4 +- .../kubernetes/typed/core/v1}/limitrange.go | 54 +- .../kubernetes/typed/core/v1}/namespace.go | 60 +- .../typed/core/v1}/namespace_expansion.go | 10 +- .../kubernetes/typed/core/v1}/node.go | 60 +- .../typed/core/v1}/persistentvolume.go | 60 +- .../typed/core/v1}/persistentvolumeclaim.go | 60 +- .../kubernetes/typed/core/v1}/pod.go | 60 +- .../typed/core/v1}/pod_expansion.go | 21 +- .../kubernetes/typed/core/v1}/podtemplate.go | 54 +- .../typed/core/v1}/replicationcontroller.go | 60 +- .../typed/core/v1}/resourcequota.go | 60 +- .../kubernetes/typed/core/v1}/secret.go | 54 +- .../kubernetes/typed/core/v1}/service.go | 60 +- .../typed/core/v1}/service_expansion.go | 10 +- .../typed/core/v1}/serviceaccount.go | 54 +- .../typed/extensions/v1beta1}/daemonset.go | 62 +- .../typed/extensions/v1beta1}/deployment.go | 62 +- .../v1beta1}/deployment_expansion.go | 8 +- .../typed/extensions/v1beta1/doc.go | 20 + .../extensions/v1beta1}/extensions_client.go | 55 +- .../v1beta1}/generated_expansion.go | 4 +- .../typed/extensions/v1beta1}/ingress.go | 62 +- .../typed/extensions/v1beta1/job.go | 167 + .../extensions/v1beta1}/podsecuritypolicy.go | 56 +- .../typed/extensions/v1beta1}/replicaset.go | 62 +- .../typed/extensions/v1beta1}/scale.go | 10 +- .../extensions/v1beta1}/scale_expansion.go | 20 +- .../extensions/v1beta1}/thirdpartyresource.go | 56 +- .../kubernetes/typed/policy/v1alpha1/doc.go | 20 + .../policy/v1alpha1/generated_expansion.go | 19 + .../policy/v1alpha1/poddisruptionbudget.go | 167 + .../typed/policy/v1alpha1/policy_client.go | 96 + .../typed/rbac/v1alpha1/clusterrole.go | 143 + .../typed/rbac/v1alpha1/clusterrolebinding.go | 143 + .../kubernetes/typed/rbac/v1alpha1/doc.go | 20 + .../rbac/v1alpha1/generated_expansion.go} | 12 +- .../typed/rbac/v1alpha1/rbac_client.go | 111 + .../kubernetes/typed/rbac/v1alpha1/role.go | 153 + .../typed/rbac/v1alpha1/rolebinding.go | 153 + .../kubernetes/typed/storage/v1beta1/doc.go | 20 + .../storage/v1beta1/generated_expansion.go | 19 + .../typed/storage/v1beta1/storage_client.go | 96 + .../typed/storage/v1beta1/storageclass.go | 143 + .../{kubernetes => client-go}/pkg/api/OWNERS | 0 .../pkg/api/context.go | 4 +- .../pkg/api/conversion.go | 23 +- .../pkg/api/defaults.go | 6 +- .../{kubernetes => client-go}/pkg/api/doc.go | 0 .../pkg/api/errors/doc.go | 0 .../pkg/api/errors/errors.go | 6 +- .../pkg/api/field_constants.go | 0 .../pkg/api/generate.go | 2 +- .../pkg/api/helpers.go | 54 +- .../pkg/api/install/install.go | 18 +- .../pkg/api/mapper.go | 8 +- .../{kubernetes => client-go}/pkg/api/meta.go | 14 +- .../pkg/api/meta/doc.go | 0 .../pkg/api/meta/errors.go | 2 +- .../pkg/api/meta/firsthit_restmapper.go | 4 +- .../pkg/api/meta/help.go | 4 +- .../pkg/api/meta/interfaces.go | 8 +- .../pkg/api/meta/meta.go | 10 +- .../pkg/api/meta/metatypes/types.go | 2 +- .../pkg/api/meta/multirestmapper.go | 6 +- .../pkg/api/meta/priority.go | 2 +- .../pkg/api/meta/restmapper.go | 4 +- .../pkg/api/meta/unstructured.go | 4 +- .../{kubernetes => client-go}/pkg/api/ref.go | 6 +- .../pkg/api/register.go | 6 +- .../pkg/api/requestcontext.go | 0 .../pkg/api/resource/amount.go | 0 .../pkg/api/resource/generated.pb.go | 33 +- .../pkg/api/resource/generated.proto | 0 .../pkg/api/resource/math.go | 0 .../pkg/api/resource/quantity.go | 2 +- .../pkg/api/resource/quantity_proto.go | 0 .../pkg/api/resource/scale_int.go | 0 .../pkg/api/resource/suffix.go | 0 .../pkg/api/resource_helpers.go | 4 +- .../pkg/api/types.generated.go | 23418 +++++----- .../pkg/api/types.go | 558 +- .../pkg/api/unversioned/doc.go | 1 + .../pkg/api/unversioned/duration.go | 0 .../pkg/api/unversioned/generated.pb.go | 223 +- .../pkg/api/unversioned/generated.proto | 22 + .../pkg/api/unversioned/group_version.go | 0 .../pkg/api/unversioned/helpers.go | 9 +- .../pkg/api/unversioned/meta.go | 0 .../pkg/api/unversioned/register.go | 0 .../pkg/api/unversioned/time.go | 2 +- .../pkg/api/unversioned/time_proto.go | 0 .../pkg/api/unversioned/types.go | 22 + .../types_swagger_doc_generated.go | 0 .../pkg/api/unversioned/well_known_labels.go | 0 .../api/unversioned/zz_generated.deepcopy.go | 2 +- .../pkg/api/v1/conversion.go | 52 +- .../pkg/api/v1/defaults.go | 21 +- .../pkg/api/v1/doc.go | 1 + .../pkg/api/v1/generated.pb.go | 1840 +- .../pkg/api/v1/generated.proto | 449 +- .../pkg/api/v1/helpers.go | 2 +- .../pkg/api/v1/meta.go | 8 +- vendor/k8s.io/client-go/pkg/api/v1/ref.go | 133 + .../pkg/api/v1/register.go | 6 +- .../pkg/api/v1/types.generated.go | 24300 +++++----- .../pkg/api/v1/types.go | 460 +- .../pkg/api/v1/types_swagger_doc_generated.go | 3 +- .../pkg/api/v1/zz_generated.conversion.go | 587 +- .../pkg/api/v1/zz_generated.deepcopy.go | 9 +- .../pkg/api/v1/zz_generated.defaults.go | 577 + .../pkg/api/validation/path/name.go | 0 .../pkg/api/zz_generated.deepcopy.go | 13 +- .../pkg/apimachinery/announced/announced.go | 4 +- .../apimachinery/announced/group_factory.go | 14 +- .../pkg/apimachinery/doc.go | 0 .../pkg/apimachinery/registered/registered.go | 8 +- .../pkg/apimachinery/types.go | 6 +- .../pkg/apis/apps/doc.go | 0 .../pkg/apis/apps/install/install.go | 8 +- .../pkg/apis/apps/register.go | 10 +- .../pkg/apis/apps/types.generated.go | 80 +- .../pkg/apis/apps/types.go | 64 +- .../pkg/apis/apps/v1alpha1/conversion.go | 22 +- .../pkg/apis/apps/v1alpha1/defaults.go | 9 +- .../pkg/apis/apps/v1alpha1/doc.go | 1 + .../pkg/apis/apps/v1alpha1/generated.pb.go | 197 +- .../pkg/apis/apps/v1alpha1/generated.proto | 58 +- .../pkg/apis/apps/v1alpha1/register.go | 16 +- .../pkg/apis/apps/v1alpha1/types.generated.go | 80 +- .../pkg/apis/apps/v1alpha1/types.go | 64 +- .../v1alpha1/types_swagger_doc_generated.go | 42 +- .../apps/v1alpha1/zz_generated.conversion.go | 192 + .../apps/v1alpha1/zz_generated.deepcopy.go | 48 +- .../apps/v1alpha1/zz_generated.defaults.go | 166 + .../pkg/apis/apps/zz_generated.deepcopy.go | 48 +- .../pkg/apis/authentication/doc.go | 0 .../apis/authentication/install/install.go | 10 +- .../pkg/apis/authentication/register.go | 6 +- .../apis/authentication/types.generated.go | 6 +- .../pkg/apis/authentication/types.go | 4 +- .../apis/authentication/v1beta1/conversion.go | 2 +- .../apis/authentication/v1beta1/defaults.go | 2 +- .../pkg/apis/authentication/v1beta1/doc.go | 1 + .../authentication/v1beta1/generated.pb.go | 93 +- .../authentication/v1beta1/generated.proto | 10 + .../apis/authentication/v1beta1/register.go | 6 +- .../authentication/v1beta1/types.generated.go | 6 +- .../pkg/apis/authentication/v1beta1/types.go | 16 +- .../v1beta1/types_swagger_doc_generated.go | 0 .../v1beta1/zz_generated.conversion.go | 13 +- .../v1beta1/zz_generated.deepcopy.go | 6 +- .../authentication/zz_generated.deepcopy.go | 6 +- .../pkg/apis/authorization/doc.go | 0 .../pkg/apis/authorization/install/install.go | 10 +- .../pkg/apis/authorization/register.go | 4 +- .../pkg/apis/authorization/types.generated.go | 6 +- .../pkg/apis/authorization/types.go | 4 +- .../apis/authorization/v1beta1/conversion.go | 2 +- .../apis/authorization/v1beta1/defaults.go | 2 +- .../pkg/apis/authorization/v1beta1/doc.go | 1 + .../authorization/v1beta1/generated.pb.go | 129 +- .../authorization/v1beta1/generated.proto | 24 + .../apis/authorization/v1beta1/register.go | 8 +- .../authorization/v1beta1/types.generated.go | 6 +- .../pkg/apis/authorization/v1beta1/types.go | 34 +- .../v1beta1/types_swagger_doc_generated.go | 0 .../v1beta1/zz_generated.conversion.go | 25 +- .../v1beta1/zz_generated.deepcopy.go | 6 +- .../authorization/zz_generated.deepcopy.go | 6 +- .../pkg/apis/autoscaling/doc.go | 0 .../pkg/apis/autoscaling/install/install.go | 8 +- .../pkg/apis/autoscaling/register.go | 6 +- .../pkg/apis/autoscaling/types.generated.go | 6 +- .../pkg/apis/autoscaling/types.go | 21 +- .../pkg/apis/autoscaling/v1/defaults.go | 3 +- .../pkg/apis/autoscaling/v1/doc.go | 1 + .../pkg/apis/autoscaling/v1/generated.pb.go | 125 +- .../pkg/apis/autoscaling/v1/generated.proto | 15 + .../pkg/apis/autoscaling/v1/register.go | 8 +- .../apis/autoscaling/v1/types.generated.go | 6 +- .../pkg/apis/autoscaling/v1/types.go | 19 +- .../v1/types_swagger_doc_generated.go | 0 .../autoscaling/v1/zz_generated.conversion.go | 34 +- .../autoscaling/v1/zz_generated.deepcopy.go | 8 +- .../autoscaling/v1/zz_generated.defaults.go | 47 + .../apis/autoscaling/zz_generated.deepcopy.go | 8 +- .../pkg/apis/batch/doc.go | 0 .../pkg/apis/batch/install/install.go | 10 +- .../pkg/apis/batch/register.go | 6 +- .../pkg/apis/batch/types.generated.go | 10 +- .../pkg/apis/batch/types.go | 36 +- .../pkg/apis/batch/v1/conversion.go | 31 +- .../pkg/apis/batch/v1/defaults.go | 3 +- .../pkg/apis/batch/v1/doc.go | 1 + .../pkg/apis/batch/v1/generated.pb.go | 640 +- .../pkg/apis/batch/v1/generated.proto | 51 +- .../pkg/apis/batch/v1/register.go | 8 +- .../pkg/apis/batch/v1/types.generated.go | 1938 +- .../pkg/apis/batch/v1/types.go | 62 +- .../batch/v1/types_swagger_doc_generated.go | 21 - .../apis/batch/v1/zz_generated.conversion.go | 134 +- .../apis/batch/v1/zz_generated.deepcopy.go | 59 +- .../apis/batch/v1/zz_generated.defaults.go | 159 + .../pkg/apis/batch/v2alpha1/conversion.go | 38 +- .../pkg/apis/batch/v2alpha1/defaults.go | 3 +- .../pkg/apis/batch/v2alpha1/doc.go | 1 + .../pkg/apis/batch/v2alpha1/generated.pb.go | 695 +- .../pkg/apis/batch/v2alpha1/generated.proto | 64 +- .../pkg/apis/batch/v2alpha1/register.go | 8 +- .../apis/batch/v2alpha1/types.generated.go | 3228 +- .../pkg/apis/batch/v2alpha1/types.go | 75 +- .../v2alpha1/types_swagger_doc_generated.go | 21 - .../batch/v2alpha1/zz_generated.conversion.go | 161 +- .../batch/v2alpha1/zz_generated.deepcopy.go | 59 +- .../batch/v2alpha1/zz_generated.defaults.go | 402 + .../pkg/apis/batch/zz_generated.deepcopy.go | 8 +- .../pkg/apis/certificates/doc.go | 0 .../pkg/apis/certificates/install/install.go | 10 +- .../pkg/apis/certificates/register.go | 6 +- .../pkg/apis/certificates/types.generated.go | 6 +- .../pkg/apis/certificates/types.go | 25 +- .../apis/certificates/v1alpha1/conversion.go | 4 +- .../pkg/apis/certificates/v1alpha1/doc.go | 1 + .../certificates/v1alpha1/generated.pb.go | 99 +- .../certificates/v1alpha1/generated.proto | 12 + .../apis/certificates/v1alpha1/register.go | 8 +- .../certificates/v1alpha1/types.generated.go | 6 +- .../pkg/apis/certificates/v1alpha1/types.go | 24 +- .../v1alpha1/types_swagger_doc_generated.go | 0 .../v1alpha1/zz_generated.conversion.go | 35 +- .../v1alpha1/zz_generated.deepcopy.go | 6 +- .../certificates/zz_generated.deepcopy.go | 6 +- .../pkg/apis/extensions/doc.go | 0 .../pkg/apis/extensions/helpers.go | 0 .../pkg/apis/extensions/install/install.go | 10 +- .../pkg/apis/extensions/register.go | 10 +- .../pkg/apis/extensions/types.generated.go | 15529 +++--- .../pkg/apis/extensions/types.go | 188 +- .../pkg/apis/extensions/v1beta1/conversion.go | 86 +- .../pkg/apis/extensions/v1beta1/defaults.go | 18 +- .../pkg/apis/extensions/v1beta1/doc.go | 1 + .../apis/extensions/v1beta1/generated.pb.go | 2097 +- .../apis/extensions/v1beta1/generated.proto | 218 +- .../pkg/apis/extensions/v1beta1/register.go | 8 +- .../extensions/v1beta1/types.generated.go | 16497 +++---- .../pkg/apis/extensions/v1beta1/types.go | 265 +- .../v1beta1/types_swagger_doc_generated.go | 56 +- .../v1beta1/zz_generated.conversion.go | 547 +- .../v1beta1/zz_generated.deepcopy.go | 119 +- .../v1beta1/zz_generated.defaults.go | 565 + .../apis/extensions/zz_generated.deepcopy.go | 46 +- .../pkg/apis/policy/doc.go | 0 .../pkg/apis/policy/install/install.go | 8 +- .../pkg/apis/policy/register.go | 6 +- .../pkg/apis/policy/types.generated.go | 8 +- .../pkg/apis/policy/types.go | 16 +- .../pkg/apis/policy/v1alpha1/doc.go | 1 + .../pkg/apis/policy/v1alpha1/generated.pb.go | 98 +- .../pkg/apis/policy/v1alpha1/generated.proto | 8 + .../pkg/apis/policy/v1alpha1/register.go | 8 +- .../apis/policy/v1alpha1/types.generated.go | 8 +- .../pkg/apis/policy/v1alpha1/types.go | 16 +- .../v1alpha1/types_swagger_doc_generated.go | 0 .../v1alpha1/zz_generated.conversion.go | 44 +- .../policy/v1alpha1/zz_generated.deepcopy.go | 8 +- .../pkg/apis/policy/zz_generated.deepcopy.go | 8 +- .../pkg/apis/rbac/doc.go | 0 .../pkg/apis/rbac/helpers.go | 4 +- .../pkg/apis/rbac/install/install.go | 10 +- .../pkg/apis/rbac/register.go | 8 +- .../pkg/apis/rbac/types.go | 6 +- .../pkg/apis/rbac/v1alpha1/defaults.go | 26 +- .../pkg/apis/rbac/v1alpha1/doc.go | 1 + .../pkg/apis/rbac/v1alpha1/generated.pb.go | 125 +- .../pkg/apis/rbac/v1alpha1/generated.proto | 15 + .../pkg/apis/rbac/v1alpha1/register.go | 8 +- .../pkg/apis/rbac/v1alpha1/types.generated.go | 8 +- .../pkg/apis/rbac/v1alpha1/types.go | 21 +- .../v1alpha1/types_swagger_doc_generated.go | 0 .../rbac/v1alpha1/zz_generated.conversion.go | 87 +- .../rbac/v1alpha1/zz_generated.deepcopy.go | 6 +- .../rbac/v1alpha1/zz_generated.defaults.go | 58 + .../pkg/apis/rbac/zz_generated.deepcopy.go | 6 +- .../pkg/apis/storage/doc.go | 0 .../pkg/apis/storage/install/install.go | 10 +- .../pkg/apis/storage/register.go | 6 +- .../pkg/apis/storage/types.generated.go | 6 +- .../pkg/apis/storage/types.go | 9 +- .../pkg/apis/storage/v1beta1/doc.go | 1 + .../pkg/apis/storage/v1beta1/generated.pb.go | 64 +- .../pkg/apis/storage/v1beta1/generated.proto | 3 + .../pkg/apis/storage/v1beta1/register.go | 8 +- .../apis/storage/v1beta1/types.generated.go | 6 +- .../pkg/apis/storage/v1beta1/types.go | 7 +- .../v1beta1/types_swagger_doc_generated.go | 0 .../v1beta1/zz_generated.conversion.go | 27 +- .../storage/v1beta1/zz_generated.deepcopy.go | 6 +- .../pkg/apis/storage/zz_generated.deepcopy.go | 6 +- .../pkg/auth/user/doc.go | 0 .../pkg/auth/user/user.go | 0 .../pkg/conversion/OWNERS | 0 .../pkg/conversion/cloner.go | 0 .../pkg/conversion/converter.go | 4 +- .../pkg/conversion/deep_equal.go | 2 +- .../pkg/conversion/doc.go | 0 .../pkg/conversion/helper.go | 0 .../pkg/conversion/queryparams/convert.go | 0 .../pkg/conversion/queryparams/doc.go | 0 .../pkg/fields/doc.go | 0 .../pkg/fields/fields.go | 0 .../pkg/fields/requirements.go | 2 +- .../pkg/fields/selector.go | 2 +- .../genericapiserver/openapi/common/common.go | 18 +- .../genericapiserver/openapi/common/doc.go | 0 .../pkg/labels/doc.go | 0 .../pkg/labels/labels.go | 0 .../pkg/labels/selector.go | 61 +- .../pkg/runtime/OWNERS | 0 .../pkg/runtime/codec.go | 38 +- .../pkg/runtime/codec_check.go | 2 +- .../pkg/runtime/conversion.go | 2 +- .../pkg/runtime/doc.go | 0 .../pkg/runtime/embedded.go | 4 +- .../pkg/runtime/error.go | 2 +- .../pkg/runtime/extension.go | 0 .../pkg/runtime/generated.pb.go | 57 +- .../pkg/runtime/generated.proto | 2 + .../pkg/runtime/helper.go | 6 +- .../pkg/runtime/interfaces.go | 49 +- .../pkg/runtime/register.go | 2 +- .../pkg/runtime/scheme.go | 25 +- .../pkg/runtime/scheme_builder.go | 0 .../pkg/runtime/serializer/codec_factory.go | 174 +- .../pkg/runtime/serializer/json/json.go | 10 +- .../pkg/runtime/serializer/json/meta.go | 6 +- .../runtime/serializer/negotiated_codec.go | 43 + .../pkg/runtime/serializer/protobuf/doc.go | 0 .../runtime/serializer/protobuf/protobuf.go | 8 +- .../runtime/serializer/protobuf_extension.go | 14 +- .../serializer/recognizer/recognizer.go | 4 +- .../runtime/serializer/streaming/streaming.go | 4 +- .../serializer/versioning/versioning.go | 51 +- .../pkg/runtime/swagger_doc_generator.go | 0 .../pkg/runtime/types.go | 4 +- .../pkg/runtime/types_proto.go | 0 .../pkg/runtime/unstructured.go | 8 +- .../pkg/runtime/zz_generated.deepcopy.go | 2 +- .../pkg/selection/operator.go | 0 .../forked/golang/reflect/deep_equal.go | 0 .../third_party/forked/golang/reflect/type.go | 0 .../pkg/types/doc.go | 0 .../pkg/types/namespacedname.go | 0 .../pkg/types/nodename.go | 0 .../pkg/types/uid.go | 0 .../pkg/types/unix_user_id.go | 0 .../pkg/util/cert/cert.go | 0 .../pkg/util/cert/csr.go | 2 +- .../pkg/util/cert/io.go | 0 .../pkg/util/cert/pem.go | 0 .../pkg/util/clock/clock.go | 0 .../{kubernetes => client-go}/pkg/util/doc.go | 0 .../pkg/util/errors/doc.go | 0 .../pkg/util/errors/errors.go | 0 .../pkg/util/flowcontrol/backoff.go | 4 +- .../pkg/util/flowcontrol/throttle.go | 0 .../pkg/util/framer/framer.go | 0 .../pkg/util/integer/integer.go | 0 .../pkg/util/intstr/generated.pb.go | 37 +- .../pkg/util/intstr/generated.proto | 0 .../pkg/util/intstr/intstr.go | 2 +- .../pkg/util/json/json.go | 0 .../pkg/util/labels/doc.go | 0 .../pkg/util/labels/labels.go | 2 +- .../pkg/util/net/http.go | 0 .../pkg/util/net/interface.go | 0 .../pkg/util/net/port_range.go | 0 .../pkg/util/net/port_split.go | 2 +- .../pkg/util/net/util.go | 0 .../pkg/util/parsers/parsers.go | 0 .../pkg/util/rand/rand.go | 0 .../pkg/util/runtime/runtime.go | 0 .../pkg/util/sets/byte.go | 0 .../pkg/util/sets/doc.go | 0 .../pkg/util/sets/empty.go | 0 .../pkg/util/sets/int.go | 0 .../pkg/util/sets/int64.go | 0 .../pkg/util/sets/string.go | 0 .../pkg/util/template.go | 0 .../pkg/util/trace.go | 0 .../pkg/util/trie.go | 0 .../pkg/util/umask.go | 0 .../pkg/util/umask_windows.go | 0 .../pkg/util/util.go | 26 +- .../pkg/util/uuid/uuid.go | 2 +- .../pkg/util/validation/field/errors.go | 2 +- .../pkg/util/validation/field/path.go | 0 .../pkg/util/validation/validation.go | 0 .../pkg/util/wait/doc.go | 0 .../pkg/util/wait/wait.go | 2 +- .../pkg/util/yaml/decoder.go | 0 .../pkg/version/.gitattributes | 0 .../pkg/version/base.go | 2 +- .../pkg/version/doc.go | 0 .../pkg/version/semver.go | 0 .../pkg/version/version.go | 0 .../pkg/watch/doc.go | 0 .../pkg/watch/filter.go | 0 .../pkg/watch/mux.go | 4 +- .../pkg/watch/streamwatcher.go | 6 +- .../pkg/watch/until.go | 8 +- .../pkg/watch/versioned/decoder.go | 6 +- .../pkg/watch/versioned/encoder.go | 6 +- .../pkg/watch/versioned/generated.pb.go | 40 +- .../pkg/watch/versioned/generated.proto | 0 .../pkg/watch/versioned/register.go | 8 +- .../pkg/watch/versioned/types.go | 2 +- .../pkg/watch/watch.go | 2 +- .../plugin/pkg/client/auth/gcp/gcp.go | 12 +- .../plugin/pkg/client/auth/oidc/OWNERS | 0 .../plugin/pkg/client/auth/oidc/oidc.go | 16 +- .../plugin/pkg/client/auth/plugins.go | 4 +- .../restclient => client-go/rest}/client.go | 65 +- .../restclient => client-go/rest}/config.go | 16 +- .../restclient => client-go/rest}/plugin.go | 4 +- .../restclient => client-go/rest}/request.go | 36 +- .../rest}/transport.go | 4 +- .../rest}/url_utils.go | 4 +- .../rest}/urlbackoff.go | 6 +- .../restclient => client-go/rest}/versions.go | 4 +- .../tools}/clientcmd/api/helpers.go | 0 .../tools}/clientcmd/api/register.go | 4 +- .../tools}/clientcmd/api/types.go | 28 +- .../tools}/metrics/metrics.go | 0 .../client => client-go}/transport/cache.go | 2 +- .../client => client-go}/transport/config.go | 0 .../transport/round_trippers.go | 0 .../transport/transport.go | 0 .../kubernetes/pkg/api/node_example.json | 49 - .../api/replication_controller_example.json | 83 - .../apps/v1alpha1/zz_generated.conversion.go | 209 - .../pkg/apis/componentconfig/helpers.go | 97 - .../apis/componentconfig/install/install.go | 41 - .../pkg/apis/componentconfig/register.go | 57 - .../apis/componentconfig/types.generated.go | 11189 ----- .../pkg/apis/componentconfig/types.go | 712 - .../apis/componentconfig/v1alpha1/defaults.go | 369 - .../apis/componentconfig/v1alpha1/register.go | 46 - .../apis/componentconfig/v1alpha1/types.go | 489 - .../v1alpha1/zz_generated.conversion.go | 556 - .../v1alpha1/zz_generated.deepcopy.go | 436 - .../componentconfig/zz_generated.deepcopy.go | 408 - .../typed/apps/unversioned/petset.go | 165 - .../typed/batch/unversioned/scheduledjob.go | 165 - .../typed/core/unversioned/node_expansion.go | 40 - .../extensions/unversioned/networkpolicy.go | 151 - .../kubernetes/pkg/client/unversioned/apps.go | 55 - .../pkg/client/unversioned/authentication.go | 77 - .../pkg/client/unversioned/authorization.go | 77 - .../pkg/client/unversioned/autoscaling.go | 55 - .../pkg/client/unversioned/batch.go | 60 - .../pkg/client/unversioned/certificates.go | 69 - .../unversioned/certificatesigningrequests.go | 104 - .../pkg/client/unversioned/client.go | 202 - .../client/unversioned/clusterrolebindings.go | 92 - .../pkg/client/unversioned/clusterroles.go | 92 - .../client/unversioned/componentstatuses.go | 60 - .../pkg/client/unversioned/conditions.go | 271 - .../pkg/client/unversioned/configmap.go | 122 - .../pkg/client/unversioned/containerinfo.go | 123 - .../pkg/client/unversioned/daemon_sets.go | 100 - .../pkg/client/unversioned/deployment.go | 111 - .../kubernetes/pkg/client/unversioned/doc.go | 58 - .../pkg/client/unversioned/endpoints.go | 101 - .../pkg/client/unversioned/events.go | 219 - .../pkg/client/unversioned/extensions.go | 109 - .../pkg/client/unversioned/flags.go | 31 - .../pkg/client/unversioned/helper.go | 335 - .../unversioned/horizontalpodautoscaler.go | 103 - .../pkg/client/unversioned/ingress.go | 100 - .../kubernetes/pkg/client/unversioned/jobs.go | 167 - .../pkg/client/unversioned/limit_ranges.go | 94 - .../pkg/client/unversioned/namespaces.go | 116 - .../pkg/client/unversioned/network_policys.go | 92 - .../pkg/client/unversioned/nodes.go | 111 - .../unversioned/persistentvolumeclaim.go | 99 - .../client/unversioned/persistentvolumes.go | 93 - .../pkg/client/unversioned/pet_sets.go | 100 - .../unversioned/pod_disruption_budgets.go | 100 - .../pkg/client/unversioned/pod_templates.go | 94 - .../kubernetes/pkg/client/unversioned/pods.go | 115 - .../client/unversioned/podsecuritypolicy.go | 111 - .../pkg/client/unversioned/policy.go | 55 - .../kubernetes/pkg/client/unversioned/rbac.go | 73 - .../pkg/client/unversioned/replica_sets.go | 100 - .../unversioned/replication_controllers.go | 99 - .../pkg/client/unversioned/resource_quotas.go | 102 - .../pkg/client/unversioned/rolebindings.go | 95 - .../pkg/client/unversioned/roles.go | 95 - .../pkg/client/unversioned/scale.go | 77 - .../pkg/client/unversioned/scheduledjobs.go | 103 - .../pkg/client/unversioned/secrets.go | 120 - .../client/unversioned/service_accounts.go | 120 - .../pkg/client/unversioned/services.go | 121 - .../pkg/client/unversioned/storage.go | 77 - .../pkg/client/unversioned/storageclasses.go | 87 - .../client/unversioned/thirdpartyresources.go | 98 - .../k8s.io/kubernetes/pkg/kubelet/qos/doc.go | 25 - .../kubernetes/pkg/kubelet/qos/policy.go | 71 - .../k8s.io/kubernetes/pkg/kubelet/qos/qos.go | 146 - .../kubernetes/pkg/kubelet/qos/types.go | 29 - .../kubernetes/pkg/kubelet/types/constants.go | 22 - .../kubernetes/pkg/kubelet/types/doc.go | 18 - .../kubernetes/pkg/kubelet/types/labels.go | 40 - .../pkg/kubelet/types/pod_update.go | 133 - .../kubernetes/pkg/kubelet/types/types.go | 93 - .../k8s.io/kubernetes/pkg/master/ports/doc.go | 19 - .../kubernetes/pkg/master/ports/ports.go | 38 - .../runtime/serializer/negotiated_codec.go | 56 - .../kubernetes/pkg/util/config/config.go | 140 - .../pkg/util/config/configuration_map.go | 53 - .../k8s.io/kubernetes/pkg/util/config/doc.go | 20 - .../pkg/util/config/feature_gate.go | 223 - .../go/compute/metadata/metadata.go | 438 - .../cloud.google.com/go/internal/cloud.go | 64 - .../github.com/PuerkitoBio/purell/.gitignore | 5 - .../github.com/PuerkitoBio/purell/.travis.yml | 7 - .../github.com/PuerkitoBio/purell/LICENSE | 12 - .../github.com/PuerkitoBio/purell/README.md | 185 - .../github.com/PuerkitoBio/purell/purell.go | 375 - .../github.com/PuerkitoBio/urlesc/.travis.yml | 11 - .../github.com/PuerkitoBio/urlesc/LICENSE | 27 - .../github.com/PuerkitoBio/urlesc/README.md | 16 - .../github.com/PuerkitoBio/urlesc/urlesc.go | 180 - .../vendor/github.com/blang/semver/LICENSE | 22 - .../vendor/github.com/blang/semver/README.md | 142 - .../vendor/github.com/blang/semver/json.go | 23 - .../vendor/github.com/blang/semver/semver.go | 395 - .../vendor/github.com/blang/semver/sort.go | 28 - .../vendor/github.com/blang/semver/sql.go | 30 - .../github.com/coreos/go-oidc/http/client.go | 7 - .../github.com/coreos/go-oidc/http/http.go | 156 - .../github.com/coreos/go-oidc/http/url.go | 29 - .../github.com/coreos/go-oidc/jose/claims.go | 126 - .../github.com/coreos/go-oidc/jose/jose.go | 112 - .../github.com/coreos/go-oidc/jose/jwk.go | 135 - .../github.com/coreos/go-oidc/jose/jws.go | 51 - .../github.com/coreos/go-oidc/jose/jwt.go | 82 - .../github.com/coreos/go-oidc/jose/sig.go | 24 - .../github.com/coreos/go-oidc/jose/sig_rsa.go | 67 - .../github.com/coreos/go-oidc/key/key.go | 153 - .../github.com/coreos/go-oidc/key/manager.go | 99 - .../github.com/coreos/go-oidc/key/repo.go | 55 - .../github.com/coreos/go-oidc/key/rotate.go | 159 - .../github.com/coreos/go-oidc/key/sync.go | 91 - .../github.com/coreos/go-oidc/oauth2/error.go | 29 - .../coreos/go-oidc/oauth2/oauth2.go | 416 - .../github.com/coreos/go-oidc/oidc/client.go | 846 - .../coreos/go-oidc/oidc/identity.go | 44 - .../coreos/go-oidc/oidc/interface.go | 3 - .../github.com/coreos/go-oidc/oidc/key.go | 67 - .../coreos/go-oidc/oidc/provider.go | 690 - .../coreos/go-oidc/oidc/transport.go | 88 - .../github.com/coreos/go-oidc/oidc/util.go | 109 - .../coreos/go-oidc/oidc/verification.go | 190 - .../github.com/coreos/pkg/health/README.md | 11 - .../github.com/coreos/pkg/health/health.go | 127 - .../github.com/coreos/pkg/httputil/README.md | 13 - .../github.com/coreos/pkg/httputil/cookie.go | 21 - .../github.com/coreos/pkg/httputil/json.go | 27 - .../github.com/coreos/pkg/timeutil/backoff.go | 15 - .../github.com/davecgh/go-spew/spew/bypass.go | 151 - .../davecgh/go-spew/spew/bypasssafe.go | 37 - .../github.com/davecgh/go-spew/spew/common.go | 341 - .../github.com/davecgh/go-spew/spew/config.go | 297 - .../github.com/davecgh/go-spew/spew/doc.go | 202 - .../github.com/davecgh/go-spew/spew/dump.go | 509 - .../github.com/davecgh/go-spew/spew/format.go | 419 - .../github.com/davecgh/go-spew/spew/spew.go | 148 - .../docker/distribution/digest/digest.go | 139 - .../docker/distribution/digest/digester.go | 155 - .../docker/distribution/digest/doc.go | 42 - .../docker/distribution/digest/set.go | 245 - .../docker/distribution/digest/verifiers.go | 44 - .../distribution/reference/reference.go | 334 - .../docker/distribution/reference/regexp.go | 124 - .../github.com/emicklei/go-restful/.gitignore | 70 - .../github.com/emicklei/go-restful/CHANGES.md | 163 - .../github.com/emicklei/go-restful/LICENSE | 22 - .../github.com/emicklei/go-restful/README.md | 74 - .../github.com/emicklei/go-restful/Srcfile | 1 - .../emicklei/go-restful/bench_test.sh | 10 - .../emicklei/go-restful/compress.go | 123 - .../emicklei/go-restful/compressor_cache.go | 103 - .../emicklei/go-restful/compressor_pools.go | 91 - .../emicklei/go-restful/compressors.go | 53 - .../emicklei/go-restful/constants.go | 30 - .../emicklei/go-restful/container.go | 361 - .../emicklei/go-restful/cors_filter.go | 202 - .../emicklei/go-restful/coverage.sh | 2 - .../github.com/emicklei/go-restful/curly.go | 162 - .../emicklei/go-restful/curly_route.go | 52 - .../github.com/emicklei/go-restful/doc.go | 196 - .../emicklei/go-restful/entity_accessors.go | 163 - .../github.com/emicklei/go-restful/filter.go | 26 - .../github.com/emicklei/go-restful/install.sh | 10 - .../github.com/emicklei/go-restful/jsr311.go | 248 - .../github.com/emicklei/go-restful/log/log.go | 31 - .../github.com/emicklei/go-restful/logger.go | 32 - .../github.com/emicklei/go-restful/mime.go | 45 - .../emicklei/go-restful/options_filter.go | 26 - .../emicklei/go-restful/parameter.go | 114 - .../emicklei/go-restful/path_expression.go | 69 - .../github.com/emicklei/go-restful/request.go | 131 - .../emicklei/go-restful/response.go | 235 - .../github.com/emicklei/go-restful/route.go | 183 - .../emicklei/go-restful/route_builder.go | 240 - .../github.com/emicklei/go-restful/router.go | 18 - .../emicklei/go-restful/service_error.go | 23 - .../emicklei/go-restful/swagger/CHANGES.md | 43 - .../emicklei/go-restful/swagger/README.md | 76 - .../swagger/api_declaration_list.go | 64 - .../emicklei/go-restful/swagger/config.go | 38 - .../go-restful/swagger/model_builder.go | 449 - .../emicklei/go-restful/swagger/model_list.go | 86 - .../go-restful/swagger/model_property_ext.go | 66 - .../go-restful/swagger/model_property_list.go | 87 - .../go-restful/swagger/ordered_route_map.go | 36 - .../emicklei/go-restful/swagger/swagger.go | 185 - .../go-restful/swagger/swagger_builder.go | 21 - .../go-restful/swagger/swagger_webservice.go | 440 - .../emicklei/go-restful/web_service.go | 268 - .../go-restful/web_service_container.go | 39 - .../vendor/github.com/ghodss/yaml/.gitignore | 20 - .../vendor/github.com/ghodss/yaml/.travis.yml | 7 - .../vendor/github.com/ghodss/yaml/LICENSE | 50 - .../vendor/github.com/ghodss/yaml/README.md | 116 - .../vendor/github.com/ghodss/yaml/fields.go | 497 - .../vendor/github.com/ghodss/yaml/yaml.go | 277 - .../go-openapi/jsonpointer/.drone.sec | 1 - .../go-openapi/jsonpointer/.drone.yml | 32 - .../go-openapi/jsonpointer/.gitignore | 1 - .../go-openapi/jsonpointer/CODE_OF_CONDUCT.md | 74 - .../github.com/go-openapi/jsonpointer/LICENSE | 202 - .../go-openapi/jsonpointer/README.md | 15 - .../go-openapi/jsonpointer/pointer.go | 238 - .../go-openapi/jsonreference/.drone.sec | 1 - .../go-openapi/jsonreference/.drone.yml | 33 - .../go-openapi/jsonreference/.gitignore | 1 - .../jsonreference/CODE_OF_CONDUCT.md | 74 - .../go-openapi/jsonreference/LICENSE | 202 - .../go-openapi/jsonreference/README.md | 15 - .../go-openapi/jsonreference/reference.go | 156 - .../github.com/go-openapi/spec/.gitignore | 2 - .../go-openapi/spec/.pullapprove.yml | 13 - .../go-openapi/spec/CODE_OF_CONDUCT.md | 74 - .../vendor/github.com/go-openapi/spec/LICENSE | 202 - .../github.com/go-openapi/spec/README.md | 5 - .../github.com/go-openapi/spec/bindata.go | 274 - .../go-openapi/spec/contact_info.go | 24 - .../github.com/go-openapi/spec/expander.go | 626 - .../go-openapi/spec/external_docs.go | 24 - .../github.com/go-openapi/spec/header.go | 165 - .../vendor/github.com/go-openapi/spec/info.go | 168 - .../github.com/go-openapi/spec/items.go | 199 - .../github.com/go-openapi/spec/license.go | 23 - .../github.com/go-openapi/spec/operation.go | 233 - .../github.com/go-openapi/spec/parameter.go | 299 - .../github.com/go-openapi/spec/path_item.go | 90 - .../github.com/go-openapi/spec/paths.go | 97 - .../vendor/github.com/go-openapi/spec/ref.go | 167 - .../github.com/go-openapi/spec/response.go | 113 - .../github.com/go-openapi/spec/responses.go | 122 - .../github.com/go-openapi/spec/schema.go | 628 - .../go-openapi/spec/security_scheme.go | 142 - .../vendor/github.com/go-openapi/spec/spec.go | 79 - .../github.com/go-openapi/spec/swagger.go | 317 - .../vendor/github.com/go-openapi/spec/tag.go | 73 - .../github.com/go-openapi/spec/xml_object.go | 68 - .../github.com/go-openapi/swag/.gitignore | 1 - .../go-openapi/swag/.pullapprove.yml | 13 - .../go-openapi/swag/CODE_OF_CONDUCT.md | 74 - .../vendor/github.com/go-openapi/swag/LICENSE | 202 - .../github.com/go-openapi/swag/README.md | 12 - .../github.com/go-openapi/swag/convert.go | 188 - .../go-openapi/swag/convert_types.go | 595 - .../vendor/github.com/go-openapi/swag/json.go | 270 - .../github.com/go-openapi/swag/loading.go | 49 - .../vendor/github.com/go-openapi/swag/net.go | 24 - .../vendor/github.com/go-openapi/swag/path.go | 56 - .../vendor/github.com/go-openapi/swag/util.go | 318 - .../github.com/gogo/protobuf/proto/Makefile | 43 - .../github.com/gogo/protobuf/proto/clone.go | 228 - .../github.com/gogo/protobuf/proto/decode.go | 873 - .../gogo/protobuf/proto/decode_gogo.go | 169 - .../github.com/gogo/protobuf/proto/encode.go | 1331 - .../gogo/protobuf/proto/encode_gogo.go | 354 - .../github.com/gogo/protobuf/proto/equal.go | 276 - .../gogo/protobuf/proto/extensions.go | 518 - .../gogo/protobuf/proto/extensions_gogo.go | 236 - .../github.com/gogo/protobuf/proto/lib.go | 894 - .../gogo/protobuf/proto/lib_gogo.go | 40 - .../gogo/protobuf/proto/message_set.go | 280 - .../gogo/protobuf/proto/pointer_reflect.go | 479 - .../gogo/protobuf/proto/pointer_unsafe.go | 266 - .../protobuf/proto/pointer_unsafe_gogo.go | 108 - .../gogo/protobuf/proto/properties.go | 923 - .../gogo/protobuf/proto/properties_gogo.go | 64 - .../gogo/protobuf/proto/skip_gogo.go | 117 - .../github.com/gogo/protobuf/proto/text.go | 805 - .../gogo/protobuf/proto/text_gogo.go | 55 - .../gogo/protobuf/proto/text_parser.go | 849 - .../gogo/protobuf/sortkeys/sortkeys.go | 99 - .../vendor/github.com/golang/glog/LICENSE | 191 - .../vendor/github.com/golang/glog/README | 44 - .../vendor/github.com/golang/glog/glog.go | 1177 - .../github.com/golang/glog/glog_file.go | 124 - .../github.com/golang/protobuf/proto/Makefile | 43 - .../github.com/golang/protobuf/proto/clone.go | 229 - .../golang/protobuf/proto/decode.go | 869 - .../golang/protobuf/proto/encode.go | 1363 - .../github.com/golang/protobuf/proto/equal.go | 296 - .../golang/protobuf/proto/extensions.go | 555 - .../github.com/golang/protobuf/proto/lib.go | 898 - .../golang/protobuf/proto/message_set.go | 311 - .../golang/protobuf/proto/pointer_reflect.go | 484 - .../golang/protobuf/proto/pointer_unsafe.go | 270 - .../golang/protobuf/proto/properties.go | 864 - .../github.com/golang/protobuf/proto/text.go | 854 - .../golang/protobuf/proto/text_parser.go | 880 - .../google/cadvisor/info/v1/container.go | 607 - .../google/cadvisor/info/v1/docker.go | 37 - .../google/cadvisor/info/v1/machine.go | 208 - .../google/cadvisor/info/v1/metric.go | 79 - .../github.com/google/gofuzz/.travis.yml | 13 - .../github.com/google/gofuzz/CONTRIBUTING.md | 67 - .../vendor/github.com/google/gofuzz/LICENSE | 202 - .../vendor/github.com/google/gofuzz/README.md | 71 - .../vendor/github.com/google/gofuzz/doc.go | 18 - .../vendor/github.com/google/gofuzz/fuzz.go | 446 - .../github.com/jonboulle/clockwork/.gitignore | 25 - .../github.com/jonboulle/clockwork/LICENSE | 201 - .../github.com/jonboulle/clockwork/README.md | 58 - .../jonboulle/clockwork/clockwork.go | 161 - .../vendor/github.com/juju/ratelimit/LICENSE | 191 - .../github.com/juju/ratelimit/README.md | 117 - .../github.com/juju/ratelimit/ratelimit.go | 245 - .../github.com/juju/ratelimit/reader.go | 51 - .../github.com/mailru/easyjson/buffer/pool.go | 207 - .../mailru/easyjson/jlexer/error.go | 15 - .../mailru/easyjson/jlexer/lexer.go | 956 - .../mailru/easyjson/jwriter/writer.go | 273 - .../github.com/pborman/uuid/CONTRIBUTORS | 1 - .../vendor/github.com/pborman/uuid/LICENSE | 27 - .../vendor/github.com/pborman/uuid/dce.go | 84 - .../vendor/github.com/pborman/uuid/doc.go | 8 - .../vendor/github.com/pborman/uuid/hash.go | 53 - .../vendor/github.com/pborman/uuid/json.go | 30 - .../vendor/github.com/pborman/uuid/node.go | 101 - .../vendor/github.com/pborman/uuid/time.go | 132 - .../vendor/github.com/pborman/uuid/util.go | 43 - .../vendor/github.com/pborman/uuid/uuid.go | 163 - .../github.com/pborman/uuid/version1.go | 41 - .../github.com/pborman/uuid/version4.go | 25 - .../vendor/github.com/spf13/pflag/.travis.yml | 21 - .../vendor/github.com/spf13/pflag/LICENSE | 28 - .../vendor/github.com/spf13/pflag/README.md | 275 - .../vendor/github.com/spf13/pflag/bool.go | 94 - .../vendor/github.com/spf13/pflag/count.go | 94 - .../vendor/github.com/spf13/pflag/duration.go | 86 - .../vendor/github.com/spf13/pflag/flag.go | 947 - .../vendor/github.com/spf13/pflag/float32.go | 88 - .../vendor/github.com/spf13/pflag/float64.go | 84 - .../github.com/spf13/pflag/golangflag.go | 104 - .../vendor/github.com/spf13/pflag/int.go | 84 - .../vendor/github.com/spf13/pflag/int32.go | 88 - .../vendor/github.com/spf13/pflag/int64.go | 84 - .../vendor/github.com/spf13/pflag/int8.go | 88 - .../github.com/spf13/pflag/int_slice.go | 128 - .../vendor/github.com/spf13/pflag/ip.go | 96 - .../vendor/github.com/spf13/pflag/ipmask.go | 122 - .../vendor/github.com/spf13/pflag/ipnet.go | 100 - .../vendor/github.com/spf13/pflag/string.go | 80 - .../github.com/spf13/pflag/string_array.go | 110 - .../github.com/spf13/pflag/string_slice.go | 132 - .../vendor/github.com/spf13/pflag/uint.go | 88 - .../vendor/github.com/spf13/pflag/uint16.go | 88 - .../vendor/github.com/spf13/pflag/uint32.go | 88 - .../vendor/github.com/spf13/pflag/uint64.go | 88 - .../vendor/github.com/spf13/pflag/uint8.go | 88 - .../vendor/github.com/ugorji/go/codec/0doc.go | 193 - .../github.com/ugorji/go/codec/README.md | 148 - .../vendor/github.com/ugorji/go/codec/binc.go | 918 - .../vendor/github.com/ugorji/go/codec/cbor.go | 584 - .../github.com/ugorji/go/codec/decode.go | 2015 - .../github.com/ugorji/go/codec/encode.go | 1405 - .../ugorji/go/codec/fast-path.generated.go | 38900 ---------------- .../ugorji/go/codec/fast-path.go.tmpl | 511 - .../ugorji/go/codec/fast-path.not.go | 32 - .../ugorji/go/codec/gen-dec-array.go.tmpl | 101 - .../ugorji/go/codec/gen-dec-map.go.tmpl | 58 - .../ugorji/go/codec/gen-helper.generated.go | 233 - .../ugorji/go/codec/gen-helper.go.tmpl | 364 - .../ugorji/go/codec/gen.generated.go | 172 - .../vendor/github.com/ugorji/go/codec/gen.go | 1920 - .../github.com/ugorji/go/codec/helper.go | 1129 - .../ugorji/go/codec/helper_internal.go | 242 - .../ugorji/go/codec/helper_not_unsafe.go | 20 - .../ugorji/go/codec/helper_unsafe.go | 45 - .../vendor/github.com/ugorji/go/codec/json.go | 1072 - .../github.com/ugorji/go/codec/msgpack.go | 844 - .../vendor/github.com/ugorji/go/codec/noop.go | 213 - .../github.com/ugorji/go/codec/prebuild.go | 3 - .../github.com/ugorji/go/codec/prebuild.sh | 199 - .../vendor/github.com/ugorji/go/codec/rpc.go | 180 - .../github.com/ugorji/go/codec/simple.go | 518 - .../ugorji/go/codec/test-cbor-goldens.json | 639 - .../vendor/github.com/ugorji/go/codec/test.py | 120 - .../github.com/ugorji/go/codec/tests.sh | 74 - .../vendor/github.com/ugorji/go/codec/time.go | 222 - .../golang.org/x/net/context/context.go | 156 - .../x/net/context/ctxhttp/ctxhttp.go | 64 - .../x/net/context/ctxhttp/ctxhttp_pre17.go | 147 - .../vendor/golang.org/x/net/context/go17.go | 72 - .../golang.org/x/net/context/pre_go17.go | 300 - .../vendor/golang.org/x/net/http2/.gitignore | 2 - .../vendor/golang.org/x/net/http2/Dockerfile | 51 - .../vendor/golang.org/x/net/http2/Makefile | 3 - .../vendor/golang.org/x/net/http2/README | 20 - .../x/net/http2/client_conn_pool.go | 255 - .../x/net/http2/configure_transport.go | 80 - .../vendor/golang.org/x/net/http2/errors.go | 122 - .../golang.org/x/net/http2/fixed_buffer.go | 60 - .../vendor/golang.org/x/net/http2/flow.go | 50 - .../vendor/golang.org/x/net/http2/frame.go | 1507 - .../vendor/golang.org/x/net/http2/go16.go | 43 - .../vendor/golang.org/x/net/http2/go17.go | 94 - .../vendor/golang.org/x/net/http2/gotrack.go | 170 - .../golang.org/x/net/http2/headermap.go | 78 - .../golang.org/x/net/http2/hpack/encode.go | 251 - .../golang.org/x/net/http2/hpack/hpack.go | 542 - .../golang.org/x/net/http2/hpack/huffman.go | 212 - .../golang.org/x/net/http2/hpack/tables.go | 352 - .../vendor/golang.org/x/net/http2/http2.go | 351 - .../vendor/golang.org/x/net/http2/not_go16.go | 46 - .../vendor/golang.org/x/net/http2/not_go17.go | 51 - .../vendor/golang.org/x/net/http2/pipe.go | 153 - .../vendor/golang.org/x/net/http2/server.go | 2263 - .../golang.org/x/net/http2/transport.go | 1868 - .../vendor/golang.org/x/net/http2/write.go | 264 - .../golang.org/x/net/http2/writesched.go | 283 - .../vendor/golang.org/x/net/idna/idna.go | 68 - .../vendor/golang.org/x/net/idna/punycode.go | 200 - .../golang.org/x/net/lex/httplex/httplex.go | 312 - .../vendor/golang.org/x/oauth2/.travis.yml | 13 - .../vendor/golang.org/x/oauth2/AUTHORS | 3 - .../golang.org/x/oauth2/CONTRIBUTING.md | 31 - .../vendor/golang.org/x/oauth2/CONTRIBUTORS | 3 - .../vendor/golang.org/x/oauth2/LICENSE | 27 - .../vendor/golang.org/x/oauth2/README.md | 65 - .../golang.org/x/oauth2/client_appengine.go | 25 - .../golang.org/x/oauth2/google/appengine.go | 86 - .../x/oauth2/google/appengine_hook.go | 13 - .../x/oauth2/google/appenginevm_hook.go | 14 - .../golang.org/x/oauth2/google/default.go | 155 - .../golang.org/x/oauth2/google/google.go | 153 - .../vendor/golang.org/x/oauth2/google/jwt.go | 74 - .../vendor/golang.org/x/oauth2/google/sdk.go | 168 - .../golang.org/x/oauth2/internal/oauth2.go | 76 - .../golang.org/x/oauth2/internal/token.go | 225 - .../golang.org/x/oauth2/internal/transport.go | 69 - .../vendor/golang.org/x/oauth2/jws/jws.go | 182 - .../vendor/golang.org/x/oauth2/jwt/jwt.go | 157 - .../vendor/golang.org/x/oauth2/oauth2.go | 341 - .../vendor/golang.org/x/oauth2/token.go | 158 - .../vendor/golang.org/x/oauth2/transport.go | 132 - .../vendor/golang.org/x/text/cases/cases.go | 129 - .../vendor/golang.org/x/text/cases/context.go | 281 - .../vendor/golang.org/x/text/cases/fold.go | 26 - .../vendor/golang.org/x/text/cases/gen.go | 831 - .../golang.org/x/text/cases/gen_trieval.go | 217 - .../vendor/golang.org/x/text/cases/info.go | 83 - .../vendor/golang.org/x/text/cases/map.go | 599 - .../vendor/golang.org/x/text/cases/tables.go | 2213 - .../vendor/golang.org/x/text/cases/trieval.go | 213 - .../golang.org/x/text/language/Makefile | 16 - .../golang.org/x/text/language/common.go | 16 - .../golang.org/x/text/language/coverage.go | 197 - .../golang.org/x/text/language/gen_common.go | 20 - .../golang.org/x/text/language/gen_index.go | 162 - .../golang.org/x/text/language/go1_1.go | 38 - .../golang.org/x/text/language/go1_2.go | 11 - .../golang.org/x/text/language/index.go | 762 - .../golang.org/x/text/language/language.go | 975 - .../golang.org/x/text/language/lookup.go | 396 - .../golang.org/x/text/language/maketables.go | 1635 - .../golang.org/x/text/language/match.go | 840 - .../golang.org/x/text/language/parse.go | 859 - .../golang.org/x/text/language/tables.go | 2791 -- .../vendor/golang.org/x/text/language/tags.go | 143 - .../vendor/golang.org/x/text/runes/cond.go | 126 - .../vendor/golang.org/x/text/runes/runes.go | 278 - .../x/text/secure/bidirule/bidirule.go | 290 - .../golang.org/x/text/secure/precis/class.go | 36 - .../x/text/secure/precis/context.go | 139 - .../golang.org/x/text/secure/precis/doc.go | 14 - .../golang.org/x/text/secure/precis/gen.go | 310 - .../x/text/secure/precis/gen_trieval.go | 68 - .../x/text/secure/precis/nickname.go | 70 - .../x/text/secure/precis/options.go | 106 - .../x/text/secure/precis/profile.go | 330 - .../x/text/secure/precis/profiles.go | 56 - .../golang.org/x/text/secure/precis/tables.go | 3788 -- .../x/text/secure/precis/transformer.go | 32 - .../x/text/secure/precis/trieval.go | 64 - .../golang.org/x/text/transform/transform.go | 661 - .../golang.org/x/text/unicode/bidi/bidi.go | 198 - .../golang.org/x/text/unicode/bidi/bracket.go | 307 - .../golang.org/x/text/unicode/bidi/core.go | 1055 - .../golang.org/x/text/unicode/bidi/gen.go | 133 - .../x/text/unicode/bidi/gen_ranges.go | 57 - .../x/text/unicode/bidi/gen_trieval.go | 64 - .../golang.org/x/text/unicode/bidi/prop.go | 206 - .../golang.org/x/text/unicode/bidi/tables.go | 1779 - .../golang.org/x/text/unicode/bidi/trieval.go | 60 - .../x/text/unicode/norm/composition.go | 514 - .../x/text/unicode/norm/forminfo.go | 256 - .../golang.org/x/text/unicode/norm/input.go | 105 - .../golang.org/x/text/unicode/norm/iter.go | 450 - .../x/text/unicode/norm/maketables.go | 978 - .../x/text/unicode/norm/normalize.go | 576 - .../x/text/unicode/norm/readwriter.go | 126 - .../golang.org/x/text/unicode/norm/tables.go | 7627 --- .../x/text/unicode/norm/transform.go | 88 - .../golang.org/x/text/unicode/norm/trie.go | 54 - .../golang.org/x/text/unicode/norm/triegen.go | 117 - .../vendor/golang.org/x/text/width/gen.go | 115 - .../golang.org/x/text/width/gen_common.go | 96 - .../golang.org/x/text/width/gen_trieval.go | 34 - .../golang.org/x/text/width/kind_string.go | 16 - .../vendor/golang.org/x/text/width/tables.go | 1284 - .../golang.org/x/text/width/transform.go | 162 - .../vendor/golang.org/x/text/width/trieval.go | 30 - .../vendor/golang.org/x/text/width/width.go | 201 - .../google.golang.org/appengine/.travis.yml | 18 - .../google.golang.org/appengine/LICENSE | 202 - .../google.golang.org/appengine/README.md | 71 - .../google.golang.org/appengine/appengine.go | 112 - .../appengine/appengine_vm.go | 20 - .../google.golang.org/appengine/errors.go | 46 - .../google.golang.org/appengine/identity.go | 142 - .../appengine/internal/api.go | 646 - .../appengine/internal/api_classic.go | 159 - .../appengine/internal/api_common.go | 86 - .../appengine/internal/app_id.go | 28 - .../app_identity/app_identity_service.pb.go | 296 - .../app_identity/app_identity_service.proto | 64 - .../appengine/internal/base/api_base.pb.go | 133 - .../appengine/internal/base/api_base.proto | 33 - .../internal/datastore/datastore_v3.pb.go | 2778 -- .../internal/datastore/datastore_v3.proto | 541 - .../appengine/internal/identity.go | 14 - .../appengine/internal/identity_classic.go | 27 - .../appengine/internal/identity_vm.go | 97 - .../appengine/internal/internal.go | 110 - .../appengine/internal/log/log_service.pb.go | 899 - .../appengine/internal/log/log_service.proto | 150 - .../appengine/internal/main.go | 15 - .../appengine/internal/main_vm.go | 44 - .../appengine/internal/metadata.go | 61 - .../internal/modules/modules_service.pb.go | 375 - .../internal/modules/modules_service.proto | 80 - .../appengine/internal/net.go | 56 - .../appengine/internal/regen.sh | 40 - .../internal/remote_api/remote_api.pb.go | 231 - .../internal/remote_api/remote_api.proto | 44 - .../appengine/internal/transaction.go | 107 - .../google.golang.org/appengine/namespace.go | 25 - .../google.golang.org/appengine/timeout.go | 20 - .../kubernetes/vendor/gopkg.in/inf.v0/LICENSE | 28 - .../kubernetes/vendor/gopkg.in/inf.v0/dec.go | 615 - .../vendor/gopkg.in/inf.v0/rounder.go | 145 - .../vendor/gopkg.in/yaml.v2/LICENSE | 188 - .../vendor/gopkg.in/yaml.v2/LICENSE.libyaml | 31 - .../vendor/gopkg.in/yaml.v2/README.md | 131 - .../vendor/gopkg.in/yaml.v2/apic.go | 742 - .../vendor/gopkg.in/yaml.v2/decode.go | 683 - .../vendor/gopkg.in/yaml.v2/emitterc.go | 1685 - .../vendor/gopkg.in/yaml.v2/encode.go | 306 - .../vendor/gopkg.in/yaml.v2/parserc.go | 1096 - .../vendor/gopkg.in/yaml.v2/readerc.go | 391 - .../vendor/gopkg.in/yaml.v2/resolve.go | 203 - .../vendor/gopkg.in/yaml.v2/scannerc.go | 2710 -- .../vendor/gopkg.in/yaml.v2/sorter.go | 104 - .../vendor/gopkg.in/yaml.v2/writerc.go | 89 - .../vendor/gopkg.in/yaml.v2/yaml.go | 346 - .../vendor/gopkg.in/yaml.v2/yamlh.go | 716 - .../vendor/gopkg.in/yaml.v2/yamlprivateh.go | 173 - 1251 files changed, 60311 insertions(+), 266533 deletions(-) delete mode 100644 vendor/github.com/blang/semver/range.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/.gitignore delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/.travis.yml delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/README.md delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/libyaml-LICENSE delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go delete mode 100644 vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go rename vendor/{k8s.io/kubernetes/vendor => }/github.com/coreos/go-oidc/jose/sig_hmac.go (100%) rename vendor/{k8s.io/kubernetes/vendor => }/github.com/go-openapi/spec/.drone.sec (100%) rename vendor/{k8s.io/kubernetes/vendor => }/github.com/go-openapi/spec/.drone.yml (100%) rename vendor/{k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer => github.com/go-openapi/spec}/.pullapprove.yml (100%) delete mode 100644 vendor/github.com/go-openapi/spec/.travis.yml delete mode 100755 vendor/github.com/go-openapi/spec/debug.test rename vendor/{k8s.io/kubernetes/vendor => }/github.com/go-openapi/swag/.drone.sec (100%) rename vendor/{k8s.io/kubernetes/vendor => }/github.com/go-openapi/swag/.drone.yml (100%) rename vendor/{k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference => github.com/go-openapi/swag}/.pullapprove.yml (100%) delete mode 100644 vendor/github.com/go-openapi/swag/.travis.yml delete mode 100644 vendor/github.com/gogo/protobuf/proto/duration.go delete mode 100644 vendor/github.com/gogo/protobuf/proto/duration_gogo.go delete mode 100644 vendor/github.com/gogo/protobuf/proto/timestamp.go delete mode 100644 vendor/github.com/gogo/protobuf/proto/timestamp_gogo.go delete mode 100644 vendor/github.com/google/cadvisor/LICENSE delete mode 100644 vendor/github.com/google/cadvisor/info/v1/container.go delete mode 100644 vendor/github.com/google/cadvisor/info/v1/docker.go delete mode 100644 vendor/github.com/google/cadvisor/info/v1/machine.go delete mode 100644 vendor/github.com/google/cadvisor/info/v1/metric.go delete mode 100644 vendor/github.com/jonboulle/clockwork/.travis.yml delete mode 100644 vendor/github.com/pborman/uuid/.travis.yml delete mode 100644 vendor/github.com/pborman/uuid/CONTRIBUTING.md delete mode 100644 vendor/github.com/pborman/uuid/README.md mode change 100644 => 100755 vendor/github.com/pborman/uuid/dce.go mode change 100644 => 100755 vendor/github.com/pborman/uuid/doc.go mode change 100644 => 100755 vendor/github.com/pborman/uuid/node.go delete mode 100644 vendor/github.com/pborman/uuid/sql.go mode change 100644 => 100755 vendor/github.com/pborman/uuid/time.go mode change 100644 => 100755 vendor/github.com/pborman/uuid/uuid.go delete mode 100644 vendor/github.com/ugorji/go/codec/decode_go.go delete mode 100644 vendor/github.com/ugorji/go/codec/decode_go14.go delete mode 100644 vendor/github.com/ugorji/go/codec/gen_15.go delete mode 100644 vendor/github.com/ugorji/go/codec/gen_16.go delete mode 100644 vendor/github.com/ugorji/go/codec/gen_17.go delete mode 100644 vendor/golang.org/x/net/http2/go17_not18.go delete mode 100644 vendor/golang.org/x/net/http2/go18.go delete mode 100644 vendor/golang.org/x/text/cases/icu.go delete mode 100644 vendor/golang.org/x/text/internal/gen.go delete mode 100644 vendor/golang.org/x/text/internal/internal.go delete mode 100644 vendor/golang.org/x/text/internal/match.go delete mode 100644 vendor/golang.org/x/text/internal/tables.go rename vendor/{k8s.io/kubernetes/vendor => }/golang.org/x/text/internal/tag/tag.go (100%) delete mode 100644 vendor/gopkg.in/yaml.v2/.travis.yml rename vendor/k8s.io/{kubernetes => client-go}/LICENSE (100%) rename vendor/k8s.io/{kubernetes/pkg/client/typed => client-go}/discovery/discovery_client.go (88%) create mode 100644 vendor/k8s.io/client-go/discovery/helper.go rename vendor/k8s.io/{kubernetes/pkg/client/typed => client-go}/discovery/restmapper.go (98%) rename vendor/k8s.io/{kubernetes/pkg/client/typed => client-go}/discovery/unstructured.go (97%) create mode 100644 vendor/k8s.io/client-go/kubernetes/clientset.go create mode 100644 vendor/k8s.io/client-go/kubernetes/doc.go rename vendor/k8s.io/{kubernetes/pkg/client/unversioned => client-go/kubernetes}/import_known_versions.go (54%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned => client-go/kubernetes/typed/apps/v1alpha1}/apps_client.go (57%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/doc.go rename vendor/k8s.io/{kubernetes/pkg/apis/componentconfig/doc.go => client-go/kubernetes/typed/apps/v1alpha1/generated_expansion.go} (86%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/statefulset.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/authentication_client.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned => client-go/kubernetes/typed/authentication/v1beta1}/doc.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned => client-go/kubernetes/typed/authentication/v1beta1}/generated_expansion.go (86%) rename vendor/k8s.io/{kubernetes/pkg/client/unversioned/tokenreviews.go => client-go/kubernetes/typed/authentication/v1beta1/tokenreview.go} (56%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/authorization_client.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/doc.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/generated_expansion.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/localsubjectaccessreview.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/selfsubjectaccessreview.go rename vendor/k8s.io/{kubernetes/pkg/client/unversioned => client-go/kubernetes/typed/authorization/v1beta1}/subjectaccessreview.go (56%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview_expansion.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/autoscaling_client.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/autoscaling/v1}/doc.go (68%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/generated_expansion.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/horizontalpodautoscaler.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned => client-go/kubernetes/typed/batch/v1}/batch_client.go (58%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/batch/v1}/doc.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned => client-go/kubernetes/typed/batch/v1}/generated_expansion.go (91%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned => client-go/kubernetes/typed/batch/v1}/job.go (68%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificates_client.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificatesigningrequest.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/doc.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/generated_expansion.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/componentstatus.go (67%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/configmap.go (69%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/core_client.go (77%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned => client-go/kubernetes/typed/core/v1}/doc.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/endpoints.go (69%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/event.go (70%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/event_expansion.go (83%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/generated_expansion.go (95%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/limitrange.go (69%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/namespace.go (66%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/namespace_expansion.go (81%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/node.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/persistentvolume.go (65%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/persistentvolumeclaim.go (66%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/pod.go (69%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/pod_expansion.go (65%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/podtemplate.go (69%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/replicationcontroller.go (66%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/resourcequota.go (67%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/secret.go (70%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/service.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/service_expansion.go (86%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned => client-go/kubernetes/typed/core/v1}/serviceaccount.go (68%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/daemonset.go (65%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/deployment.go (65%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/deployment_expansion.go (82%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/doc.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/extensions_client.go (67%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/generated_expansion.go (92%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/ingress.go (67%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/job.go rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/podsecuritypolicy.go (64%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/replicaset.go (65%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/scale.go (90%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/scale_expansion.go (74%) rename vendor/k8s.io/{kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned => client-go/kubernetes/typed/extensions/v1beta1}/thirdpartyresource.go (64%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/doc.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/generated_expansion.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/poddisruptionbudget.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/policy_client.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrole.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrolebinding.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/doc.go rename vendor/k8s.io/{kubernetes/pkg/apis/componentconfig/v1alpha1/doc.go => client-go/kubernetes/typed/rbac/v1alpha1/generated_expansion.go} (79%) create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rbac_client.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/role.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rolebinding.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/doc.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/generated_expansion.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storage_client.go create mode 100644 vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storageclass.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/OWNERS (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/context.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/conversion.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/defaults.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/errors/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/errors/errors.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/field_constants.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/generate.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/helpers.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/install/install.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/mapper.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/errors.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/firsthit_restmapper.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/help.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/interfaces.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/meta.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/metatypes/types.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/multirestmapper.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/priority.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/restmapper.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/meta/unstructured.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/ref.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/register.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/requestcontext.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/amount.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/generated.pb.go (50%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/generated.proto (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/math.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/quantity.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/quantity_proto.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/scale_int.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource/suffix.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/resource_helpers.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/types.generated.go (81%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/types.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/duration.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/generated.pb.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/generated.proto (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/group_version.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/helpers.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/meta.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/register.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/time.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/time_proto.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/types.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/well_known_labels.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/unversioned/zz_generated.deepcopy.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/conversion.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/defaults.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/generated.pb.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/generated.proto (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/helpers.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/meta.go (96%) create mode 100644 vendor/k8s.io/client-go/pkg/api/v1/ref.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/register.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/types.generated.go (80%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/types.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/types_swagger_doc_generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/zz_generated.conversion.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/v1/zz_generated.deepcopy.go (99%) create mode 100644 vendor/k8s.io/client-go/pkg/api/v1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/validation/path/name.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/api/zz_generated.deepcopy.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apimachinery/announced/announced.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apimachinery/announced/group_factory.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apimachinery/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apimachinery/registered/registered.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apimachinery/types.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/install/install.go (85%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/register.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/types.generated.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/types.go (60%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/conversion.go (81%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/defaults.go (85%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/generated.pb.go (73%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/generated.proto (67%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/register.go (76%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/types.generated.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/types.go (61%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go (50%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.conversion.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go (61%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/apps/zz_generated.deepcopy.go (61%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/install/install.go (82%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/register.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/types.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/conversion.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/defaults.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/generated.pb.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/generated.proto (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/register.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/types.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/zz_generated.conversion.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authentication/zz_generated.deepcopy.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/install/install.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/register.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/types.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/conversion.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/defaults.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/generated.pb.go (89%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/generated.proto (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/register.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/types.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/zz_generated.conversion.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/authorization/zz_generated.deepcopy.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/install/install.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/register.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/types.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/defaults.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/generated.pb.go (87%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/generated.proto (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/register.go (88%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/types.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/zz_generated.conversion.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go (96%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/autoscaling/zz_generated.deepcopy.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/install/install.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/register.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/types.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/conversion.go (71%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/defaults.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/generated.pb.go (64%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/generated.proto (81%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/register.go (88%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/types.generated.go (60%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/types.go (75%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/types_swagger_doc_generated.go (80%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/zz_generated.conversion.go (57%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v1/zz_generated.deepcopy.go (74%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/conversion.go (68%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/defaults.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/generated.pb.go (74%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/generated.proto (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/register.go (89%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/types.generated.go (65%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/types.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/zz_generated.conversion.go (72%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go (83%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/batch/zz_generated.deepcopy.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/install/install.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/register.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/types.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/conversion.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/generated.pb.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/generated.proto (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/register.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/types.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go (89%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/certificates/zz_generated.deepcopy.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/helpers.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/install/install.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/register.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/types.generated.go (66%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/types.go (89%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/conversion.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/defaults.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/generated.pb.go (87%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/generated.proto (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/register.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/types.generated.go (72%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/types.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/zz_generated.conversion.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go (94%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/extensions/zz_generated.deepcopy.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/install/install.go (85%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/register.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/types.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/generated.pb.go (85%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/generated.proto (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/register.go (89%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/types.go (91%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/zz_generated.conversion.go (85%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/policy/zz_generated.deepcopy.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/helpers.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/install/install.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/register.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/types.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/defaults.go (64%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/doc.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/generated.pb.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/generated.proto (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/register.go (90%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/types.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go (98%) create mode 100644 vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.defaults.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/rbac/zz_generated.deepcopy.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/install/install.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/register.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/types.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/doc.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/generated.pb.go (84%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/generated.proto (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/register.go (88%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/types.generated.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/types.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/types_swagger_doc_generated.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/zz_generated.conversion.go (79%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/apis/storage/zz_generated.deepcopy.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/auth/user/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/auth/user/user.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/OWNERS (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/cloner.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/converter.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/deep_equal.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/helper.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/queryparams/convert.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/conversion/queryparams/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/fields/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/fields/fields.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/fields/requirements.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/fields/selector.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/genericapiserver/openapi/common/common.go (83%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/genericapiserver/openapi/common/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/labels/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/labels/labels.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/labels/selector.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/OWNERS (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/codec.go (87%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/codec_check.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/conversion.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/embedded.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/error.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/extension.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/generated.pb.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/generated.proto (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/helper.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/interfaces.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/register.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/scheme.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/scheme_builder.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/codec_factory.go (56%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/json/json.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/json/meta.go (95%) create mode 100644 vendor/k8s.io/client-go/pkg/runtime/serializer/negotiated_codec.go rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/protobuf/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/protobuf/protobuf.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/protobuf_extension.go (74%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/recognizer/recognizer.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/streaming/streaming.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/serializer/versioning/versioning.go (82%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/swagger_doc_generator.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/types.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/types_proto.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/unstructured.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/runtime/zz_generated.deepcopy.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/selection/operator.go (100%) rename vendor/k8s.io/{kubernetes => client-go/pkg}/third_party/forked/golang/reflect/deep_equal.go (100%) rename vendor/k8s.io/{kubernetes => client-go/pkg}/third_party/forked/golang/reflect/type.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/types/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/types/namespacedname.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/types/nodename.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/types/uid.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/types/unix_user_id.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/cert/cert.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/cert/csr.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/cert/io.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/cert/pem.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/clock/clock.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/errors/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/errors/errors.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/flowcontrol/backoff.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/flowcontrol/throttle.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/framer/framer.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/integer/integer.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/intstr/generated.pb.go (81%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/intstr/generated.proto (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/intstr/intstr.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/json/json.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/labels/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/labels/labels.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/net/http.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/net/interface.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/net/port_range.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/net/port_split.go (98%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/net/util.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/parsers/parsers.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/rand/rand.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/runtime/runtime.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/byte.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/empty.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/int.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/int64.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/sets/string.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/template.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/trace.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/trie.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/umask.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/umask_windows.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/util.go (82%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/uuid/uuid.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/validation/field/errors.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/validation/field/path.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/validation/validation.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/wait/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/wait/wait.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/util/yaml/decoder.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/version/.gitattributes (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/version/base.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/version/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/version/semver.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/version/version.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/doc.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/filter.go (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/mux.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/streamwatcher.go (96%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/until.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/decoder.go (94%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/encoder.go (92%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/generated.pb.go (81%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/generated.proto (100%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/register.go (95%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/versioned/types.go (97%) rename vendor/k8s.io/{kubernetes => client-go}/pkg/watch/watch.go (99%) rename vendor/k8s.io/{kubernetes => client-go}/plugin/pkg/client/auth/gcp/gcp.go (86%) rename vendor/k8s.io/{kubernetes => client-go}/plugin/pkg/client/auth/oidc/OWNERS (100%) rename vendor/k8s.io/{kubernetes => client-go}/plugin/pkg/client/auth/oidc/oidc.go (93%) rename vendor/k8s.io/{kubernetes => client-go}/plugin/pkg/client/auth/plugins.go (86%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/client.go (78%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/config.go (97%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/plugin.go (96%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/request.go (97%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/transport.go (97%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/url_utils.go (98%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/urlbackoff.go (97%) rename vendor/k8s.io/{kubernetes/pkg/client/restclient => client-go/rest}/versions.go (97%) rename vendor/k8s.io/{kubernetes/pkg/client/unversioned => client-go/tools}/clientcmd/api/helpers.go (100%) rename vendor/k8s.io/{kubernetes/pkg/client/unversioned => client-go/tools}/clientcmd/api/register.go (94%) rename vendor/k8s.io/{kubernetes/pkg/client/unversioned => client-go/tools}/clientcmd/api/types.go (95%) rename vendor/k8s.io/{kubernetes/pkg/client => client-go/tools}/metrics/metrics.go (100%) rename vendor/k8s.io/{kubernetes/pkg/client => client-go}/transport/cache.go (98%) rename vendor/k8s.io/{kubernetes/pkg/client => client-go}/transport/config.go (100%) rename vendor/k8s.io/{kubernetes/pkg/client => client-go}/transport/round_trippers.go (100%) rename vendor/k8s.io/{kubernetes/pkg/client => client-go}/transport/transport.go (100%) delete mode 100644 vendor/k8s.io/kubernetes/pkg/api/node_example.json delete mode 100644 vendor/k8s.io/kubernetes/pkg/api/replication_controller_example.json delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.conversion.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/helpers.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/install/install.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/register.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.generated.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/defaults.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/register.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/types.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.conversion.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.deepcopy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/apis/componentconfig/zz_generated.deepcopy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/petset.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/scheduledjob.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node_expansion.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/networkpolicy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/apps.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/authentication.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/authorization.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/autoscaling.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/batch.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/certificates.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/certificatesigningrequests.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/client.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterrolebindings.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterroles.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/componentstatuses.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/conditions.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/configmap.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/containerinfo.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/daemon_sets.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/deployment.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/doc.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/endpoints.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/events.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/extensions.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/flags.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/helper.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/horizontalpodautoscaler.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/ingress.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/jobs.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/limit_ranges.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/namespaces.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/network_policys.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/nodes.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumeclaim.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumes.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/pet_sets.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_disruption_budgets.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_templates.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/pods.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/podsecuritypolicy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/policy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/rbac.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/replica_sets.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/replication_controllers.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/resource_quotas.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/rolebindings.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/roles.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/scale.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/scheduledjobs.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/secrets.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/service_accounts.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/services.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/storage.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/storageclasses.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/client/unversioned/thirdpartyresources.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/qos/doc.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/qos/policy.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/qos/qos.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/qos/types.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/types/constants.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/types/doc.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/types/labels.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/types/pod_update.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/kubelet/types/types.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/master/ports/doc.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/master/ports/ports.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/runtime/serializer/negotiated_codec.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/util/config/config.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/util/config/configuration_map.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/util/config/doc.go delete mode 100644 vendor/k8s.io/kubernetes/pkg/util/config/feature_gate.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/compute/metadata/metadata.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/internal/cloud.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/purell.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/urlesc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/json.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/semver.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sort.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sql.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/client.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/http.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/url.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/claims.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jose.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwk.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jws.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwt.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_rsa.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/key.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/manager.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/repo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/rotate.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/sync.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/error.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/oauth2.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/client.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/identity.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/interface.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/key.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/provider.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/transport.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/util.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/verification.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/health.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/cookie.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/json.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/timeutil/backoff.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypass.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/common.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/config.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/dump.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/format.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/spew.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digest.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digester.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/set.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/verifiers.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/reference.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/regexp.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/CHANGES.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/Srcfile delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/bench_test.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compress.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_cache.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_pools.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressors.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/constants.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/container.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/cors_filter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/coverage.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly_route.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/entity_accessors.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/filter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/install.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/jsr311.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/log/log.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/logger.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/mime.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/options_filter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/parameter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/path_expression.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/request.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/response.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route_builder.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/router.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/service_error.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/CHANGES.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/api_declaration_list.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/config.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_builder.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_list.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_list.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/ordered_route_map.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_builder.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service_container.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/fields.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/yaml.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.sec delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/CODE_OF_CONDUCT.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/pointer.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.sec delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/CODE_OF_CONDUCT.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/reference.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.pullapprove.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/CODE_OF_CONDUCT.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/bindata.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/contact_info.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/expander.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/external_docs.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/header.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/info.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/items.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/license.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/operation.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/parameter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/path_item.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/paths.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/ref.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/response.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/responses.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/schema.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/security_scheme.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/spec.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/swagger.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/tag.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/xml_object.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.pullapprove.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/CODE_OF_CONDUCT.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert_types.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/json.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/loading.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/net.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/path.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/util.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/Makefile delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/clone.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/equal.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/message_set.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/skip_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_gogo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_parser.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/README delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog_file.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/Makefile delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/clone.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/decode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/encode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/equal.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/extensions.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/lib.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/message_set.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_reflect.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/properties.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text_parser.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/container.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/docker.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/machine.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/metric.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/CONTRIBUTING.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/fuzz.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/clockwork.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/ratelimit.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/reader.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/buffer/pool.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/error.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/lexer.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jwriter/writer.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/CONTRIBUTORS delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/LICENSE delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/dce.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/hash.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/json.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/node.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/time.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/util.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/uuid.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version1.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version4.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/bool.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/count.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/duration.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/flag.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float32.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float64.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/golangflag.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int32.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int64.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int8.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int_slice.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ip.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipmask.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipnet.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_array.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_slice.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint16.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint32.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint64.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint8.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/0doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/binc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/cbor.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/decode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/encode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.generated.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.not.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-map.go.tmpl delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.generated.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.generated.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_internal.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_unsafe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/json.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/msgpack.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/noop.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/rpc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/simple.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test-cbor-goldens.json delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test.py delete mode 100755 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/tests.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/time.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/context.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp_pre17.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/go17.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/pre_go17.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/.gitignore delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Dockerfile delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Makefile delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/README delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/client_conn_pool.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/configure_transport.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/errors.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/fixed_buffer.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/flow.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/frame.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go16.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go17.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/gotrack.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/headermap.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/encode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/hpack.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/huffman.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/http2.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go16.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go17.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/pipe.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/server.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/transport.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/write.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/writesched.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/idna.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/punycode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/net/lex/httplex/httplex.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/AUTHORS delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTING.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTORS delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/client_appengine.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine_hook.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appenginevm_hook.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/default.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/google.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/jwt.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/sdk.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/oauth2.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/token.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/transport.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jws/jws.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jwt/jwt.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/oauth2.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/token.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/transport.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/cases.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/context.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/fold.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen_trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/info.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/map.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/Makefile delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/common.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/coverage.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_common.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_index.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_1.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_2.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/index.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/language.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/lookup.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/maketables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/match.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/parse.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tags.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/cond.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/runes.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/bidirule/bidirule.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/class.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/context.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/doc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen_trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/nickname.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/options.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profile.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profiles.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/transformer.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/transform/transform.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bidi.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bracket.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/core.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_ranges.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/prop.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/composition.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/forminfo.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/input.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/iter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/maketables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/normalize.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/readwriter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/transform.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/trie.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/triegen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_common.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/kind_string.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/tables.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/transform.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/trieval.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/width.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/.travis.yml delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine_vm.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/errors.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/identity.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_classic.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_common.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_id.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.pb.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.pb.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_classic.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_vm.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/internal.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.pb.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main_vm.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/metadata.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.pb.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/net.go delete mode 100755 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/regen.sh delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/transaction.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/namespace.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/timeout.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/dec.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/rounder.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE.libyaml delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/README.md delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/apic.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/decode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/emitterc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/encode.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/parserc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/readerc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/resolve.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/scannerc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/sorter.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/writerc.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yaml.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlh.go delete mode 100644 vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlprivateh.go diff --git a/Godeps/Godeps.json b/Godeps/Godeps.json index 3d94b7f..808dead 100644 --- a/Godeps/Godeps.json +++ b/Godeps/Godeps.json @@ -2,19 +2,16 @@ "ImportPath": "github.com/stackanetes/kubernetes-entrypoint", "GoVersion": "go1.7", "GodepVersion": "v74", - "Packages": [ - "./..." - ], "Deps": [ { "ImportPath": "cloud.google.com/go/compute/metadata", - "Comment": "v0.3.0-3-g324a60e", - "Rev": "324a60ed5211861ba3ef5a71f502fa8dd2e0d02e" + "Comment": "v0.1.0-115-g3b1ae45", + "Rev": "3b1ae45394a234c385be014e9a488f2bb6eef821" }, { "ImportPath": "cloud.google.com/go/internal", - "Comment": "v0.3.0-3-g324a60e", - "Rev": "324a60ed5211861ba3ef5a71f502fa8dd2e0d02e" + "Comment": "v0.1.0-115-g3b1ae45", + "Rev": "3b1ae45394a234c385be014e9a488f2bb6eef821" }, { "ImportPath": "github.com/PuerkitoBio/purell", @@ -27,77 +24,76 @@ }, { "ImportPath": "github.com/blang/semver", - "Comment": "v3.3.0", - "Rev": "60ec3488bfea7cca02b021d106d9911120d25fe9" + "Comment": "v3.0.1", + "Rev": "31b736133b98f26d5e078ec9eb591666edfd091f" }, { "ImportPath": "github.com/coreos/go-oidc/http", - "Rev": "16c5ecc505f1efa0fe4685826fd9962c4d137e87" + "Rev": "5644a2f50e2d2d5ba0b474bc5bc55fea1925936d" }, { "ImportPath": "github.com/coreos/go-oidc/jose", - "Rev": "16c5ecc505f1efa0fe4685826fd9962c4d137e87" + "Rev": "5644a2f50e2d2d5ba0b474bc5bc55fea1925936d" }, { "ImportPath": "github.com/coreos/go-oidc/key", - "Rev": "16c5ecc505f1efa0fe4685826fd9962c4d137e87" + "Rev": "5644a2f50e2d2d5ba0b474bc5bc55fea1925936d" }, { "ImportPath": "github.com/coreos/go-oidc/oauth2", - "Rev": "16c5ecc505f1efa0fe4685826fd9962c4d137e87" + "Rev": "5644a2f50e2d2d5ba0b474bc5bc55fea1925936d" }, { "ImportPath": "github.com/coreos/go-oidc/oidc", - "Rev": "16c5ecc505f1efa0fe4685826fd9962c4d137e87" + "Rev": "5644a2f50e2d2d5ba0b474bc5bc55fea1925936d" }, { "ImportPath": "github.com/coreos/pkg/health", - "Comment": "v3", - "Rev": "3ac0863d7acf3bc44daf49afef8919af12f704ef" + "Comment": "v2-8-gfa29b1d", + "Rev": "fa29b1d70f0beaddd4c7021607cc3c3be8ce94b8" }, { "ImportPath": "github.com/coreos/pkg/httputil", - "Comment": "v3", - "Rev": "3ac0863d7acf3bc44daf49afef8919af12f704ef" + "Comment": "v2-8-gfa29b1d", + "Rev": "fa29b1d70f0beaddd4c7021607cc3c3be8ce94b8" }, { "ImportPath": "github.com/coreos/pkg/timeutil", - "Comment": "v3", - "Rev": "3ac0863d7acf3bc44daf49afef8919af12f704ef" + "Comment": "v2-8-gfa29b1d", + "Rev": "fa29b1d70f0beaddd4c7021607cc3c3be8ce94b8" }, { "ImportPath": "github.com/davecgh/go-spew/spew", - "Comment": "v1.0.0-3-g6d21280", - "Rev": "6d212800a42e8ab5c146b8ace3490ee17e5225f9" + "Rev": "5215b55f46b2b919f50a1df0eaa5886afe4e3b3d" }, { "ImportPath": "github.com/docker/distribution/digest", - "Comment": "docs-v2.4.1-2016-06-28-145-gc372264", - "Rev": "c372264f17c47d91c7c614162bab6121edbb9c30" + "Comment": "v2.4.0-rc.1-38-gcd27f17", + "Rev": "cd27f179f2c10c5d300e6d09025b538c475b0d51" }, { "ImportPath": "github.com/docker/distribution/reference", - "Comment": "docs-v2.4.1-2016-06-28-145-gc372264", - "Rev": "c372264f17c47d91c7c614162bab6121edbb9c30" + "Comment": "v2.4.0-rc.1-38-gcd27f17", + "Rev": "cd27f179f2c10c5d300e6d09025b538c475b0d51" }, { "ImportPath": "github.com/emicklei/go-restful", - "Comment": "v1.2-91-g3d66f88", - "Rev": "3d66f886316ac990eb502aaa89ea38546420b8b7" + "Comment": "v1.2-79-g89ef8af", + "Rev": "89ef8af493ab468a45a42bb0d89a06fccdd2fb22" }, { "ImportPath": "github.com/emicklei/go-restful/log", - "Comment": "v1.2-91-g3d66f88", - "Rev": "3d66f886316ac990eb502aaa89ea38546420b8b7" + "Comment": "v1.2-79-g89ef8af", + "Rev": "89ef8af493ab468a45a42bb0d89a06fccdd2fb22" }, { "ImportPath": "github.com/emicklei/go-restful/swagger", - "Comment": "v1.2-91-g3d66f88", - "Rev": "3d66f886316ac990eb502aaa89ea38546420b8b7" + "Comment": "v1.2-79-g89ef8af", + "Rev": "89ef8af493ab468a45a42bb0d89a06fccdd2fb22" }, { "ImportPath": "github.com/ghodss/yaml", - "Rev": "aa0c862057666179de291b67d9f093d12b5a8473" + "Rev": "73d445a93680fa1a78ae23a5839bad48f32ba1ee" }, { "ImportPath": "github.com/go-openapi/jsonpointer", @@ -109,43 +105,37 @@ }, { "ImportPath": "github.com/go-openapi/spec", - "Rev": "8f2b3d0e3aa15100eea0ab61dc6fa02f00f5e713" + "Rev": "6aced65f8501fe1217321abf0749d354824ba2ff" }, { "ImportPath": "github.com/go-openapi/swag", - "Rev": "c98c5a1cc708d9860aeeceea6391da6f223d479c" + "Rev": "1d0bd113de87027671077d3c71eb3ac5d7dbba72" }, { "ImportPath": "github.com/gogo/protobuf/proto", - "Comment": "v0.3-121-g50d1bd3", - "Rev": "50d1bd39ce4e7a96b75e3e040be9caf79dbb4c61" + "Comment": "v0.2-33-ge18d7aa", + "Rev": "e18d7aa8f8c624c915db340349aad4c49b10d173" }, { "ImportPath": "github.com/gogo/protobuf/sortkeys", - "Comment": "v0.3-121-g50d1bd3", - "Rev": "50d1bd39ce4e7a96b75e3e040be9caf79dbb4c61" + "Comment": "v0.2-33-ge18d7aa", + "Rev": "e18d7aa8f8c624c915db340349aad4c49b10d173" }, { "ImportPath": "github.com/golang/glog", - "Rev": "23def4e6c14b4da8ac2ed8007337bc5eb5007998" + "Rev": "44145f04b68cf362d9c4df2182967c2275eaefed" }, { "ImportPath": "github.com/golang/protobuf/proto", - "Rev": "98fa357170587e470c5f27d3c3ea0947b71eb455" - }, - { - "ImportPath": "github.com/google/cadvisor/info/v1", - "Comment": "v0.24.0-alpha1-43-gcae5bfa", - "Rev": "cae5bfaee63f62fdf374519f04bf24e02a742f87" + "Rev": "8616e8ee5e20a1704615e6c8d7afcdac06087a67" }, { "ImportPath": "github.com/google/gofuzz", - "Rev": "fd52762d25a41827db7ef64c43756fd4b9f7e382" + "Rev": "bbcb9da2d746f8bdbd6a936686a0a6067ada0ec5" }, { "ImportPath": "github.com/jonboulle/clockwork", - "Comment": "v0.1.0-4-gbcac988", - "Rev": "bcac9884e7502bb2b474c0339d889cb981a2f27f" + "Rev": "72f9bd7c4e0c2a40055ab3d0f09654f730cce982" }, { "ImportPath": "github.com/juju/ratelimit", @@ -153,152 +143,143 @@ }, { "ImportPath": "github.com/mailru/easyjson/buffer", - "Rev": "9dc3521db3580379d6cc493938ef9d2e9782ee7b" + "Rev": "d5b7844b561a7bc640052f1b935f7b800330d7e0" }, { "ImportPath": "github.com/mailru/easyjson/jlexer", - "Rev": "9dc3521db3580379d6cc493938ef9d2e9782ee7b" + "Rev": "d5b7844b561a7bc640052f1b935f7b800330d7e0" }, { "ImportPath": "github.com/mailru/easyjson/jwriter", - "Rev": "9dc3521db3580379d6cc493938ef9d2e9782ee7b" + "Rev": "d5b7844b561a7bc640052f1b935f7b800330d7e0" }, { "ImportPath": "github.com/pborman/uuid", - "Comment": "v1.0-17-g3d4f2ba", - "Rev": "3d4f2ba23642d3cfd06bd4b54cf03d99d95c0f1b" + "Rev": "ca53cad383cad2479bbba7f7a1a05797ec1386e4" }, { "ImportPath": "github.com/spf13/pflag", - "Rev": "bf8481a6aebc13a8aab52e699ffe2e79771f5a3f" + "Rev": "c7e63cf4530bcd3ba943729cee0efeff2ebea63f" }, { "ImportPath": "github.com/ugorji/go/codec", - "Rev": "faddd6128c66c4708f45fdc007f575f75e592a3c" + "Rev": "f1f1a805ed361a0e078bb537e4ea78cd37dcf065" }, { "ImportPath": "golang.org/x/net/context", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/net/context/ctxhttp", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/net/http2", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/net/http2/hpack", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/net/idna", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/net/lex/httplex", - "Rev": "8b4af36cd21a1f85a7484b49feb7c79363106d8e" + "Rev": "e90d6d0afc4c315a0d87a568ae68577cc15149a0" }, { "ImportPath": "golang.org/x/oauth2", - "Rev": "1e695b1c8febf17aad3bfa7bf0a819ef94b98ad5" + "Rev": "3c3a985cb79f52a3190fbc056984415ca6763d01" }, { "ImportPath": "golang.org/x/oauth2/google", - "Rev": "1e695b1c8febf17aad3bfa7bf0a819ef94b98ad5" + "Rev": "3c3a985cb79f52a3190fbc056984415ca6763d01" }, { "ImportPath": "golang.org/x/oauth2/internal", - "Rev": "1e695b1c8febf17aad3bfa7bf0a819ef94b98ad5" + "Rev": "3c3a985cb79f52a3190fbc056984415ca6763d01" }, { "ImportPath": "golang.org/x/oauth2/jws", - "Rev": "1e695b1c8febf17aad3bfa7bf0a819ef94b98ad5" + "Rev": "3c3a985cb79f52a3190fbc056984415ca6763d01" }, { "ImportPath": "golang.org/x/oauth2/jwt", - "Rev": "1e695b1c8febf17aad3bfa7bf0a819ef94b98ad5" + "Rev": "3c3a985cb79f52a3190fbc056984415ca6763d01" }, { "ImportPath": "golang.org/x/text/cases", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/internal/tag", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/language", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/runes", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/secure/bidirule", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/secure/precis", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/transform", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/unicode/bidi", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/unicode/norm", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "golang.org/x/text/width", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" + "Rev": "2910a502d2bf9e43193af9d68ca516529614eed3" }, { "ImportPath": "google.golang.org/appengine", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/app_identity", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/base", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/datastore", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/log", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/modules", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "google.golang.org/appengine/internal/remote_api", - "Comment": "v1.0.0-8-g5b8c3b8", - "Rev": "5b8c3b819891014a2d12354528f7d046dd53c89e" + "Rev": "4f7eeb5305a4ba1966344836ba4af9996b7b4e05" }, { "ImportPath": "gopkg.in/inf.v0", @@ -307,870 +288,517 @@ }, { "ImportPath": "gopkg.in/yaml.v2", - "Rev": "a5b47d31c556af34a302ce5d659e6fea44d90de0" + "Rev": "53feefa2559fb8dfa8d81baad31be332c97d6c77" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/discovery", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/errors", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/apps/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/meta", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/authentication/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/meta/metatypes", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/authorization/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/resource", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/autoscaling/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/batch/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/v1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/certificates/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/api/validation/path", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/core/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apimachinery", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/extensions/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apimachinery/announced", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/policy/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apimachinery/registered", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/rbac/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/apps", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/kubernetes/typed/storage/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/apps/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/apps/v1alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/errors", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authentication", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authentication/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/meta", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authentication/v1beta1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/meta/metatypes", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authorization", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/resource", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authorization/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/unversioned", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/authorization/v1beta1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/autoscaling", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/api/validation/path", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/autoscaling/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apimachinery", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/autoscaling/v1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apimachinery/announced", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/batch", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apimachinery/registered", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/batch/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/apps", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/batch/v1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/apps/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/batch/v2alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/apps/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/certificates", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authentication", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/certificates/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authentication/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/certificates/v1alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authentication/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/componentconfig", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authorization", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/componentconfig/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authorization/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/authorization/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/extensions", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/autoscaling", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/extensions/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/autoscaling/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/extensions/v1beta1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/autoscaling/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/policy", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/batch", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/policy/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/batch/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/policy/v1alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/batch/v1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/rbac", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/batch/v2alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/rbac/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/certificates", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/rbac/v1alpha1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/certificates/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/storage", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/certificates/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/storage/install", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/extensions", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/apis/storage/v1beta1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/extensions/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/auth/user", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/extensions/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/policy", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/policy/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/policy/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/rbac", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/metrics", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/rbac/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/restclient", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/rbac/v1alpha1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/transport", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/storage", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/typed/discovery", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/storage/install", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/unversioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/apis/storage/v1beta1", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/auth/user", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/conversion", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/conversion", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/conversion/queryparams", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/conversion/queryparams", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/fields", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/fields", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/genericapiserver/openapi/common", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/genericapiserver/openapi/common", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/kubelet/qos", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/labels", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/kubelet/types", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/labels", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/master/ports", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer/json", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer/protobuf", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer/recognizer", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer/json", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer/streaming", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer/protobuf", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/runtime/serializer/versioning", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer/recognizer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/selection", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer/streaming", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/third_party/forked/golang/reflect", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/runtime/serializer/versioning", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/types", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/selection", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/types", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/cert", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/clock", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/cert", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/errors", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/clock", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/flowcontrol", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/config", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/framer", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/errors", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/integer", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/flowcontrol", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/intstr", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/framer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/json", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/integer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/labels", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/intstr", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/net", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/json", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/parsers", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/labels", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/rand", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/net", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/runtime", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/parsers", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/sets", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/rand", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/uuid", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/runtime", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/validation", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/sets", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/validation/field", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/uuid", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/wait", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/validation", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/util/yaml", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/validation/field", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/version", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/wait", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/watch", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/util/yaml", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/pkg/watch/versioned", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/version", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/plugin/pkg/client/auth", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/watch", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/plugin/pkg/client/auth/gcp", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/pkg/watch/versioned", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/plugin/pkg/client/auth/oidc", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/plugin/pkg/client/auth", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/rest", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/plugin/pkg/client/auth/gcp", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/tools/clientcmd/api", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/plugin/pkg/client/auth/oidc", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/tools/metrics", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" }, { - "ImportPath": "k8s.io/kubernetes/third_party/forked/golang/reflect", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "golang.org/x/text/internal", - "Rev": "fa5033c827cad7080e8e7047a0091945b0e1f031" - }, - { - "ImportPath": "github.com/cloudfoundry-incubator/candiedyaml", - "Rev": "99c3df83b51532e3615f851d8c2dbb638f5313bf" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/golang/glog", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/ugorji/go/codec", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/context", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/go-openapi/spec", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/spf13/pflag", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/gopkg.in/inf.v0", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/gogo/protobuf/sortkeys", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/google/gofuzz", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/pborman/uuid", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/go-openapi/swag", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/emicklei/go-restful", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/ghodss/yaml", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jwriter", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/log", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/gopkg.in/yaml.v2", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/idna", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/mailru/easyjson/buffer", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/cases", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/runes", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/secure/bidirule", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/transform", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/width", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/language", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/text/internal/tag", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/docker/distribution/reference", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/docker/distribution/digest", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/http2", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/lex/httplex", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/juju/ratelimit", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/blang/semver", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/oauth2", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/oauth2/google", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/cloud.google.com/go/compute/metadata", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/oauth2/jws", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/oauth2/jwt", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/pkg/timeutil", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/cloud.google.com/go/internal", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/pkg/health", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" - }, - { - "ImportPath": "k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil", - "Comment": "v1.5.0-alpha.1-393-g57a47b6", - "Rev": "57a47b6af50b94857e978eb6989b3e3403fe94c5" + "ImportPath": "k8s.io/client-go/transport", + "Comment": "v2.0.0-alpha.0", + "Rev": "b22087a53becae45931ed72d5e0f12e0031d771a" } ] } diff --git a/client/client.go b/client/client.go index 98ad2e2..f331156 100644 --- a/client/client.go +++ b/client/client.go @@ -1,55 +1,61 @@ package client import ( - restclient "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/unversioned" + "k8s.io/client-go/kubernetes" + v1batch "k8s.io/client-go/kubernetes/typed/batch/v1" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + v1beta1extensions "k8s.io/client-go/kubernetes/typed/extensions/v1beta1" + "k8s.io/client-go/rest" ) type ClientInterface interface { - Pods(string) unversioned.PodInterface - Jobs(string) unversioned.JobInterface - Endpoints(string) unversioned.EndpointsInterface - DaemonSets(string) unversioned.DaemonSetInterface - Services(string) unversioned.ServiceInterface + Pods(string) v1core.PodInterface + Jobs(string) v1batch.JobInterface + Endpoints(string) v1core.EndpointsInterface + DaemonSets(string) v1beta1extensions.DaemonSetInterface + Services(string) v1core.ServiceInterface } - type Client struct { - *unversioned.Client + *kubernetes.Clientset } -func (c Client) Pods(namespace string) unversioned.PodInterface { - return c.Client.Pods(namespace) +func (c Client) Pods(namespace string) v1core.PodInterface { + return c.Clientset.Core().Pods(namespace) } -func (c Client) Jobs(namespace string) unversioned.JobInterface { - return c.Client.Extensions().Jobs(namespace) +func (c Client) Jobs(namespace string) v1batch.JobInterface { + return c.Clientset.Batch().Jobs(namespace) } -func (c Client) Endpoints(namespace string) unversioned.EndpointsInterface { - return c.Client.Endpoints(namespace) +func (c Client) Endpoints(namespace string) v1core.EndpointsInterface { + return c.Clientset.Core().Endpoints(namespace) } -func (c Client) DaemonSets(namespace string) unversioned.DaemonSetInterface { - return c.Client.Extensions().DaemonSets(namespace) +func (c Client) DaemonSets(namespace string) v1beta1extensions.DaemonSetInterface { + return c.Clientset.Extensions().DaemonSets(namespace) } -func (c Client) Services(namespace string) unversioned.ServiceInterface { - return c.Client.Services(namespace) +func (c Client) Services(namespace string) v1core.ServiceInterface { + return c.Clientset.Core().Services(namespace) } -func New(config *restclient.Config) (ClientInterface, error) { +func New(config *rest.Config) (ClientInterface, error) { if config == nil { - client, err := unversioned.NewInCluster() + config, err := rest.InClusterConfig() if err != nil { return nil, err } - return Client{Client: client}, nil + clientset, err := kubernetes.NewForConfig(config) + if err != nil { + return nil, err + } + return Client{Clientset: clientset}, nil } - client, err := unversioned.New(config) + clientset, err := kubernetes.NewForConfig(config) if err != nil { return nil, err } - return Client{Client: client}, nil + return Client{Clientset: clientset}, nil } diff --git a/dependencies/daemonset/daemonset.go b/dependencies/daemonset/daemonset.go index a558ae3..dbc42bc 100644 --- a/dependencies/daemonset/daemonset.go +++ b/dependencies/daemonset/daemonset.go @@ -7,8 +7,8 @@ import ( entry "github.com/stackanetes/kubernetes-entrypoint/entrypoint" "github.com/stackanetes/kubernetes-entrypoint/logger" "github.com/stackanetes/kubernetes-entrypoint/util/env" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/labels" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/labels" ) type Daemonset struct { @@ -48,7 +48,7 @@ func (d Daemonset) IsResolved(entrypoint entry.EntrypointInterface) (bool, error } label := labels.SelectorFromSet(daemonset.Spec.Selector.MatchLabels) - opts := api.ListOptions{LabelSelector: label} + opts := v1.ListOptions{LabelSelector: label.String()} pods, err := entrypoint.Client().Pods(entrypoint.GetNamespace()).List(opts) if err != nil { return false, err @@ -65,7 +65,7 @@ func (d Daemonset) IsResolved(entrypoint entry.EntrypointInterface) (bool, error if !isPodOnHost(&pod, myHost) { continue } - if api.IsPodReady(&pod) { + if isPodReady(pod) { return true, nil } return false, fmt.Errorf("Pod %v of daemonset %v is not ready", pod.Name, d.GetName()) @@ -78,9 +78,18 @@ func (d Daemonset) GetName() string { return d.name } -func isPodOnHost(pod *api.Pod, hostIP string) bool { +func isPodOnHost(pod *v1.Pod, hostIP string) bool { if pod.Status.HostIP == hostIP { return true } return false } + +func isPodReady(pod v1.Pod) bool { + for _, condition := range pod.Status.Conditions { + if condition.Type == v1.PodReady && condition.Status == "True" { + return true + } + } + return false +} diff --git a/entrypoint/entrypoint.go b/entrypoint/entrypoint.go index 84558d7..0027888 100644 --- a/entrypoint/entrypoint.go +++ b/entrypoint/entrypoint.go @@ -3,7 +3,7 @@ package entrypoint import ( cli "github.com/stackanetes/kubernetes-entrypoint/client" "github.com/stackanetes/kubernetes-entrypoint/logger" - restclient "k8s.io/kubernetes/pkg/client/restclient" + "k8s.io/client-go/rest" "os" "sync" "time" @@ -29,7 +29,7 @@ type Entrypoint struct { } //New is a constructor for entrypoint -func New(config *restclient.Config) (entry *Entrypoint, err error) { +func New(config *rest.Config) (entry *Entrypoint, err error) { entry = new(Entrypoint) client, err := cli.New(config) if err != nil { diff --git a/mocks/client.go b/mocks/client.go index 5135361..183bd4f 100644 --- a/mocks/client.go +++ b/mocks/client.go @@ -2,33 +2,35 @@ package mocks import ( cli "github.com/stackanetes/kubernetes-entrypoint/client" - "k8s.io/kubernetes/pkg/client/unversioned" + v1batch "k8s.io/client-go/kubernetes/typed/batch/v1" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + v1beta1extensions "k8s.io/client-go/kubernetes/typed/extensions/v1beta1" ) type Client struct { - unversioned.PodInterface - unversioned.ServiceInterface - unversioned.DaemonSetInterface - unversioned.EndpointsInterface - unversioned.JobInterface + v1core.PodInterface + v1core.ServiceInterface + v1beta1extensions.DaemonSetInterface + v1core.EndpointsInterface + v1batch.JobInterface } -func (c Client) Pods(namespace string) unversioned.PodInterface { +func (c Client) Pods(namespace string) v1core.PodInterface { return c.PodInterface } -func (c Client) Services(namespace string) unversioned.ServiceInterface { +func (c Client) Services(namespace string) v1core.ServiceInterface { return c.ServiceInterface } -func (c Client) DaemonSets(namespace string) unversioned.DaemonSetInterface { +func (c Client) DaemonSets(namespace string) v1beta1extensions.DaemonSetInterface { return c.DaemonSetInterface } -func (c Client) Endpoints(namespace string) unversioned.EndpointsInterface { +func (c Client) Endpoints(namespace string) v1core.EndpointsInterface { return c.EndpointsInterface } -func (c Client) Jobs(namespace string) unversioned.JobInterface { +func (c Client) Jobs(namespace string) v1batch.JobInterface { return c.JobInterface } diff --git a/mocks/daemonset.go b/mocks/daemonset.go index 6962521..10bdc2b 100644 --- a/mocks/daemonset.go +++ b/mocks/daemonset.go @@ -2,12 +2,12 @@ package mocks import ( "fmt" - - "k8s.io/kubernetes/pkg/api" - unv "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/watch" + v1beta1extensions "k8s.io/client-go/kubernetes/typed/extensions/v1beta1" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + extensions "k8s.io/client-go/pkg/apis/extensions/v1beta1" + "k8s.io/client-go/pkg/watch" ) type dClient struct { @@ -18,9 +18,9 @@ func (d dClient) Get(name string) (*extensions.DaemonSet, error) { return nil, fmt.Errorf("Mock daemonset didnt work") } ds := &extensions.DaemonSet{ - ObjectMeta: api.ObjectMeta{Name: name}, + ObjectMeta: v1.ObjectMeta{Name: name}, Spec: extensions.DaemonSetSpec{ - Selector: &unv.LabelSelector{ + Selector: &unversioned.LabelSelector{ MatchLabels: map[string]string{"name": "test"}, }, }, @@ -31,10 +31,10 @@ func (d dClient) Create(ds *extensions.DaemonSet) (*extensions.DaemonSet, error) return nil, fmt.Errorf("Not implemented") } -func (d dClient) Delete(name string) error { +func (d dClient) Delete(name string, options *v1.DeleteOptions) error { return fmt.Errorf("Not implemented") } -func (d dClient) List(options api.ListOptions) (*extensions.DaemonSetList, error) { +func (d dClient) List(options v1.ListOptions) (*extensions.DaemonSetList, error) { return nil, fmt.Errorf("Not implemented") } @@ -46,10 +46,18 @@ func (d dClient) UpdateStatus(ds *extensions.DaemonSet) (*extensions.DaemonSet, return nil, fmt.Errorf("Not implemented") } -func (d dClient) Watch(options api.ListOptions) (watch.Interface, error) { +func (d dClient) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return fmt.Errorf("Not implemented") +} + +func (d dClient) Watch(options v1.ListOptions) (watch.Interface, error) { return nil, fmt.Errorf("Not implemented") } -func NewDSClient() unversioned.DaemonSetInterface { +func (d dClient) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.DaemonSet, err error) { + return nil, fmt.Errorf("Not implemented") +} + +func NewDSClient() v1beta1extensions.DaemonSetInterface { return dClient{} } diff --git a/mocks/endpoints.go b/mocks/endpoints.go index 2403464..67ef315 100644 --- a/mocks/endpoints.go +++ b/mocks/endpoints.go @@ -2,59 +2,68 @@ package mocks import ( "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/watch" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/watch" + "k8s.io/client-go/rest" ) type eClient struct { } -func (e eClient) Get(name string) (*api.Endpoints, error) { +func (e eClient) Get(name string) (*v1.Endpoints, error) { if name != "lgtm" { return nil, fmt.Errorf("Mock endpoint didnt work") } - endpoint := &api.Endpoints{ - ObjectMeta: api.ObjectMeta{Name: name}, - Subsets: []api.EndpointSubset{ - api.EndpointSubset{ - Addresses: []api.EndpointAddress{ - api.EndpointAddress{IP: "127.0.0.1"}, + endpoint := &v1.Endpoints{ + ObjectMeta: v1.ObjectMeta{Name: name}, + Subsets: []v1.EndpointSubset{ + v1.EndpointSubset{ + Addresses: []v1.EndpointAddress{ + v1.EndpointAddress{IP: "127.0.0.1"}, }, }, }, } return endpoint, nil } -func (e eClient) Create(ds *api.Endpoints) (*api.Endpoints, error) { +func (e eClient) Create(ds *v1.Endpoints) (*v1.Endpoints, error) { return nil, fmt.Errorf("Not implemented") } -func (e eClient) Delete(name string) error { +func (e eClient) Delete(name string, options *v1.DeleteOptions) error { return fmt.Errorf("Not implemented") } -func (e eClient) List(options api.ListOptions) (*api.EndpointsList, error) { + +func (e eClient) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return fmt.Errorf("Not implemented") +} + +func (e eClient) List(options v1.ListOptions) (*v1.EndpointsList, error) { return nil, fmt.Errorf("Not implemented") } -func (e eClient) Update(ds *api.Endpoints) (*api.Endpoints, error) { +func (e eClient) Update(ds *v1.Endpoints) (*v1.Endpoints, error) { return nil, fmt.Errorf("Not implemented") } -func (s eClient) UpdateStatus(ds *api.Endpoints) (*api.Endpoints, error) { +func (s eClient) UpdateStatus(ds *v1.Endpoints) (*v1.Endpoints, error) { return nil, fmt.Errorf("Not implemented") } -func (e eClient) Watch(options api.ListOptions) (watch.Interface, error) { +func (e eClient) Watch(options v1.ListOptions) (watch.Interface, error) { return nil, fmt.Errorf("Not implemented") } -func (e eClient) ProxyGet(scheme string, name string, port string, path string, params map[string]string) restclient.ResponseWrapper { +func (e eClient) ProxyGet(scheme string, name string, port string, path string, params map[string]string) rest.ResponseWrapper { return nil } -func NewEClient() unversioned.EndpointsInterface { +func (e eClient) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Endpoints, err error) { + return nil, fmt.Errorf("Not implemented") +} + +func NewEClient() v1core.EndpointsInterface { return eClient{} } diff --git a/mocks/job.go b/mocks/job.go index b5dac44..ffc7d2f 100644 --- a/mocks/job.go +++ b/mocks/job.go @@ -2,11 +2,11 @@ package mocks import ( "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/watch" + v1batch "k8s.io/client-go/kubernetes/typed/batch/v1" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + batch "k8s.io/client-go/pkg/apis/batch/v1" + "k8s.io/client-go/pkg/watch" ) type jClient struct { @@ -29,10 +29,13 @@ func (j jClient) Create(job *batch.Job) (*batch.Job, error) { return nil, fmt.Errorf("Not implemented") } -func (j jClient) Delete(name string, opts *api.DeleteOptions) error { +func (j jClient) Delete(name string, opts *v1.DeleteOptions) error { return fmt.Errorf("Not implemented") } -func (j jClient) List(options api.ListOptions) (*batch.JobList, error) { +func (j jClient) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return fmt.Errorf("Not implemented") +} +func (j jClient) List(options v1.ListOptions) (*batch.JobList, error) { return nil, fmt.Errorf("Not implemented") } @@ -44,10 +47,13 @@ func (j jClient) UpdateStatus(job *batch.Job) (*batch.Job, error) { return nil, fmt.Errorf("Not implemented") } -func (j jClient) Watch(options api.ListOptions) (watch.Interface, error) { +func (j jClient) Watch(options v1.ListOptions) (watch.Interface, error) { return nil, fmt.Errorf("Not implemented") } -func NewJClient() unversioned.JobInterface { +func (j jClient) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *batch.Job, err error) { + return nil, fmt.Errorf("Not implemented") +} +func NewJClient() v1batch.JobInterface { return jClient{} } diff --git a/mocks/pod.go b/mocks/pod.go index 19ce750..5695784 100644 --- a/mocks/pod.go +++ b/mocks/pod.go @@ -2,22 +2,23 @@ package mocks import ( "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/watch" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + policy "k8s.io/client-go/pkg/apis/policy/v1alpha1" + "k8s.io/client-go/pkg/watch" + "k8s.io/client-go/rest" ) type pClient struct { } -func (p pClient) Get(name string) (*api.Pod, error) { - return &api.Pod{ - ObjectMeta: api.ObjectMeta{Name: name}, - Status: api.PodStatus{ - ContainerStatuses: []api.ContainerStatus{ - api.ContainerStatus{ +func (p pClient) Get(name string) (*v1.Pod, error) { + return &v1.Pod{ + ObjectMeta: v1.ObjectMeta{Name: name}, + Status: v1.PodStatus{ + ContainerStatuses: []v1.ContainerStatus{ + v1.ContainerStatus{ Name: "container_test", Ready: true, }, @@ -27,28 +28,33 @@ func (p pClient) Get(name string) (*api.Pod, error) { }, nil } -func (p pClient) Create(pod *api.Pod) (*api.Pod, error) { +func (p pClient) Create(pod *v1.Pod) (*v1.Pod, error) { return nil, fmt.Errorf("Not implemented") } -func (p pClient) Delete(name string, options *api.DeleteOptions) error { +func (p pClient) Delete(name string, options *v1.DeleteOptions) error { return fmt.Errorf("Not implemented") } -func (p pClient) List(options api.ListOptions) (*api.PodList, error) { - return &api.PodList{ - Items: []api.Pod{ - api.Pod{ - ObjectMeta: api.ObjectMeta{Name: "podList"}, - Status: api.PodStatus{ + +func (p pClient) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return fmt.Errorf("Not implemented") +} + +func (p pClient) List(options v1.ListOptions) (*v1.PodList, error) { + return &v1.PodList{ + Items: []v1.Pod{ + v1.Pod{ + ObjectMeta: v1.ObjectMeta{Name: "podList"}, + Status: v1.PodStatus{ HostIP: "127.0.01", - Conditions: []api.PodCondition{ - api.PodCondition{ - Type: api.PodReady, + Conditions: []v1.PodCondition{ + v1.PodCondition{ + Type: v1.PodReady, Status: "True", }, }, - ContainerStatuses: []api.ContainerStatus{ - api.ContainerStatus{ + ContainerStatuses: []v1.ContainerStatus{ + v1.ContainerStatus{ Name: "container_test", Ready: true, }, @@ -60,24 +66,33 @@ func (p pClient) List(options api.ListOptions) (*api.PodList, error) { } -func (p pClient) Update(pod *api.Pod) (*api.Pod, error) { +func (p pClient) Update(pod *v1.Pod) (*v1.Pod, error) { return nil, fmt.Errorf("Not implemented") } -func (p pClient) UpdateStatus(pod *api.Pod) (*api.Pod, error) { +func (p pClient) UpdateStatus(pod *v1.Pod) (*v1.Pod, error) { return nil, fmt.Errorf("Not implemented") } -func (p pClient) Watch(options api.ListOptions) (watch.Interface, error) { +func (p pClient) Watch(options v1.ListOptions) (watch.Interface, error) { return nil, fmt.Errorf("Not implemented") } -func (p pClient) GetLogs(name string, opts *api.PodLogOptions) *restclient.Request { - return nil -} -func (p pClient) Bind(binding *api.Binding) error { +func (p pClient) Bind(binding *v1.Binding) error { return fmt.Errorf("Not implemented") } -func NewPClient() unversioned.PodInterface { + +func (p pClient) Evict(eviction *policy.Eviction) error { + return fmt.Errorf("Not implemented") +} + +func (p pClient) GetLogs(name string, opts *v1.PodLogOptions) *rest.Request { + return nil +} + +func (p pClient) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Pod, err error) { + return nil, fmt.Errorf("Not implemented") +} +func NewPClient() v1core.PodInterface { return pClient{} } diff --git a/mocks/service.go b/mocks/service.go index ff5812a..08d8a62 100644 --- a/mocks/service.go +++ b/mocks/service.go @@ -3,50 +3,60 @@ package mocks import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/watch" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + api "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/watch" + "k8s.io/client-go/rest" ) type sClient struct { } -func (s sClient) Get(name string) (*api.Service, error) { +func (s sClient) Get(name string) (*v1.Service, error) { if name != "lgtm" { return nil, fmt.Errorf("Mock service didnt work") } - return &api.Service{ - ObjectMeta: api.ObjectMeta{Name: name}, + return &v1.Service{ + ObjectMeta: v1.ObjectMeta{Name: name}, }, nil } -func (s sClient) Create(ds *api.Service) (*api.Service, error) { +func (s sClient) Create(ds *v1.Service) (*v1.Service, error) { return nil, fmt.Errorf("Not implemented") } -func (s sClient) Delete(name string) error { +func (s sClient) Delete(name string, options *v1.DeleteOptions) error { return fmt.Errorf("Not implemented") } -func (s sClient) List(options api.ListOptions) (*api.ServiceList, error) { + +func (s sClient) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return fmt.Errorf("Not implemented") +} + +func (s sClient) List(options v1.ListOptions) (*v1.ServiceList, error) { return nil, fmt.Errorf("Not implemented") } -func (s sClient) Update(ds *api.Service) (*api.Service, error) { +func (s sClient) Update(ds *v1.Service) (*v1.Service, error) { return nil, fmt.Errorf("Not implemented") } -func (s sClient) UpdateStatus(ds *api.Service) (*api.Service, error) { +func (s sClient) UpdateStatus(ds *v1.Service) (*v1.Service, error) { return nil, fmt.Errorf("Not implemented") } -func (s sClient) Watch(options api.ListOptions) (watch.Interface, error) { +func (s sClient) Watch(options v1.ListOptions) (watch.Interface, error) { return nil, fmt.Errorf("Not implemented") } -func (s sClient) ProxyGet(scheme string, name string, port string, path string, params map[string]string) restclient.ResponseWrapper { +func (s sClient) ProxyGet(scheme string, name string, port string, path string, params map[string]string) rest.ResponseWrapper { return nil } -func NewSClient() unversioned.ServiceInterface { +func (s sClient) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Service, err error) { + return nil, fmt.Errorf("Not implemented") +} + +func NewSClient() v1core.ServiceInterface { return sClient{} } diff --git a/vendor/github.com/blang/semver/README.md b/vendor/github.com/blang/semver/README.md index 4399639..5171c5c 100644 --- a/vendor/github.com/blang/semver/README.md +++ b/vendor/github.com/blang/semver/README.md @@ -40,52 +40,10 @@ Features - Comparator-like comparisons - Compare Helper Methods - InPlace manipulation -- Ranges `>=1.0.0 <2.0.0 || >=3.0.0 !3.0.1-beta.1` - Sortable (implements sort.Interface) - database/sql compatible (sql.Scanner/Valuer) - encoding/json compatible (json.Marshaler/Unmarshaler) -Ranges ------- - -A `Range` is a set of conditions which specify which versions satisfy the range. - -A condition is composed of an operator and a version. The supported operators are: - -- `<1.0.0` Less than `1.0.0` -- `<=1.0.0` Less than or equal to `1.0.0` -- `>1.0.0` Greater than `1.0.0` -- `>=1.0.0` Greater than or equal to `1.0.0` -- `1.0.0`, `=1.0.0`, `==1.0.0` Equal to `1.0.0` -- `!1.0.0`, `!=1.0.0` Not equal to `1.0.0`. Excludes version `1.0.0`. - -A `Range` can link multiple `Ranges` separated by space: - -Ranges can be linked by logical AND: - - - `>1.0.0 <2.0.0` would match between both ranges, so `1.1.1` and `1.8.7` but not `1.0.0` or `2.0.0` - - `>1.0.0 <3.0.0 !2.0.3-beta.2` would match every version between `1.0.0` and `3.0.0` except `2.0.3-beta.2` - -Ranges can also be linked by logical OR: - - - `<2.0.0 || >=3.0.0` would match `1.x.x` and `3.x.x` but not `2.x.x` - -AND has a higher precedence than OR. It's not possible to use brackets. - -Ranges can be combined by both AND and OR - - - `>1.0.0 <2.0.0 || >3.0.0 !4.2.1` would match `1.2.3`, `1.9.9`, `3.1.1`, but not `4.2.1`, `2.1.1` - -Range usage: - -``` -v, err := semver.Parse("1.2.3") -range, err := semver.ParseRange(">1.0.0 <2.0.0 || >=3.0.0") -if range(v) { - //valid -} - -``` Example ----- @@ -145,30 +103,23 @@ if err != nil { } ``` - Benchmarks ----- - BenchmarkParseSimple-4 5000000 390 ns/op 48 B/op 1 allocs/op - BenchmarkParseComplex-4 1000000 1813 ns/op 256 B/op 7 allocs/op - BenchmarkParseAverage-4 1000000 1171 ns/op 163 B/op 4 allocs/op - BenchmarkStringSimple-4 20000000 119 ns/op 16 B/op 1 allocs/op - BenchmarkStringLarger-4 10000000 206 ns/op 32 B/op 2 allocs/op - BenchmarkStringComplex-4 5000000 324 ns/op 80 B/op 3 allocs/op - BenchmarkStringAverage-4 5000000 273 ns/op 53 B/op 2 allocs/op - BenchmarkValidateSimple-4 200000000 9.33 ns/op 0 B/op 0 allocs/op - BenchmarkValidateComplex-4 3000000 469 ns/op 0 B/op 0 allocs/op - BenchmarkValidateAverage-4 5000000 256 ns/op 0 B/op 0 allocs/op - BenchmarkCompareSimple-4 100000000 11.8 ns/op 0 B/op 0 allocs/op - BenchmarkCompareComplex-4 50000000 30.8 ns/op 0 B/op 0 allocs/op - BenchmarkCompareAverage-4 30000000 41.5 ns/op 0 B/op 0 allocs/op - BenchmarkSort-4 3000000 419 ns/op 256 B/op 2 allocs/op - BenchmarkRangeParseSimple-4 2000000 850 ns/op 192 B/op 5 allocs/op - BenchmarkRangeParseAverage-4 1000000 1677 ns/op 400 B/op 10 allocs/op - BenchmarkRangeParseComplex-4 300000 5214 ns/op 1440 B/op 30 allocs/op - BenchmarkRangeMatchSimple-4 50000000 25.6 ns/op 0 B/op 0 allocs/op - BenchmarkRangeMatchAverage-4 30000000 56.4 ns/op 0 B/op 0 allocs/op - BenchmarkRangeMatchComplex-4 10000000 153 ns/op 0 B/op 0 allocs/op + BenchmarkParseSimple 5000000 328 ns/op 49 B/op 1 allocs/op + BenchmarkParseComplex 1000000 2105 ns/op 263 B/op 7 allocs/op + BenchmarkParseAverage 1000000 1301 ns/op 168 B/op 4 allocs/op + BenchmarkStringSimple 10000000 130 ns/op 5 B/op 1 allocs/op + BenchmarkStringLarger 5000000 280 ns/op 32 B/op 2 allocs/op + BenchmarkStringComplex 3000000 512 ns/op 80 B/op 3 allocs/op + BenchmarkStringAverage 5000000 387 ns/op 47 B/op 2 allocs/op + BenchmarkValidateSimple 500000000 7.92 ns/op 0 B/op 0 allocs/op + BenchmarkValidateComplex 2000000 923 ns/op 0 B/op 0 allocs/op + BenchmarkValidateAverage 5000000 452 ns/op 0 B/op 0 allocs/op + BenchmarkCompareSimple 100000000 11.2 ns/op 0 B/op 0 allocs/op + BenchmarkCompareComplex 50000000 40.9 ns/op 0 B/op 0 allocs/op + BenchmarkCompareAverage 50000000 43.8 ns/op 0 B/op 0 allocs/op + BenchmarkSort 5000000 436 ns/op 259 B/op 2 allocs/op See benchmark cases at [semver_test.go](semver_test.go) diff --git a/vendor/github.com/blang/semver/range.go b/vendor/github.com/blang/semver/range.go deleted file mode 100644 index 238e131..0000000 --- a/vendor/github.com/blang/semver/range.go +++ /dev/null @@ -1,233 +0,0 @@ -package semver - -import ( - "fmt" - "strings" - "unicode" -) - -type comparator func(Version, Version) bool - -var ( - compEQ comparator = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) == 0 - } - compNE = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) != 0 - } - compGT = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) == 1 - } - compGE = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) >= 0 - } - compLT = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) == -1 - } - compLE = func(v1 Version, v2 Version) bool { - return v1.Compare(v2) <= 0 - } -) - -type versionRange struct { - v Version - c comparator -} - -// rangeFunc creates a Range from the given versionRange. -func (vr *versionRange) rangeFunc() Range { - return Range(func(v Version) bool { - return vr.c(v, vr.v) - }) -} - -// Range represents a range of versions. -// A Range can be used to check if a Version satisfies it: -// -// range, err := semver.ParseRange(">1.0.0 <2.0.0") -// range(semver.MustParse("1.1.1") // returns true -type Range func(Version) bool - -// OR combines the existing Range with another Range using logical OR. -func (rf Range) OR(f Range) Range { - return Range(func(v Version) bool { - return rf(v) || f(v) - }) -} - -// AND combines the existing Range with another Range using logical AND. -func (rf Range) AND(f Range) Range { - return Range(func(v Version) bool { - return rf(v) && f(v) - }) -} - -// ParseRange parses a range and returns a Range. -// If the range could not be parsed an error is returned. -// -// Valid ranges are: -// - "<1.0.0" -// - "<=1.0.0" -// - ">1.0.0" -// - ">=1.0.0" -// - "1.0.0", "=1.0.0", "==1.0.0" -// - "!1.0.0", "!=1.0.0" -// -// A Range can consist of multiple ranges separated by space: -// Ranges can be linked by logical AND: -// - ">1.0.0 <2.0.0" would match between both ranges, so "1.1.1" and "1.8.7" but not "1.0.0" or "2.0.0" -// - ">1.0.0 <3.0.0 !2.0.3-beta.2" would match every version between 1.0.0 and 3.0.0 except 2.0.3-beta.2 -// -// Ranges can also be linked by logical OR: -// - "<2.0.0 || >=3.0.0" would match "1.x.x" and "3.x.x" but not "2.x.x" -// -// AND has a higher precedence than OR. It's not possible to use brackets. -// -// Ranges can be combined by both AND and OR -// -// - `>1.0.0 <2.0.0 || >3.0.0 !4.2.1` would match `1.2.3`, `1.9.9`, `3.1.1`, but not `4.2.1`, `2.1.1` -func ParseRange(s string) (Range, error) { - parts := splitAndTrim(s) - orParts, err := splitORParts(parts) - if err != nil { - return nil, err - } - var orFn Range - for _, p := range orParts { - var andFn Range - for _, ap := range p { - opStr, vStr, err := splitComparatorVersion(ap) - if err != nil { - return nil, err - } - vr, err := buildVersionRange(opStr, vStr) - if err != nil { - return nil, fmt.Errorf("Could not parse Range %q: %s", ap, err) - } - rf := vr.rangeFunc() - - // Set function - if andFn == nil { - andFn = rf - } else { // Combine with existing function - andFn = andFn.AND(rf) - } - } - if orFn == nil { - orFn = andFn - } else { - orFn = orFn.OR(andFn) - } - - } - return orFn, nil -} - -// splitORParts splits the already cleaned parts by '||'. -// Checks for invalid positions of the operator and returns an -// error if found. -func splitORParts(parts []string) ([][]string, error) { - var ORparts [][]string - last := 0 - for i, p := range parts { - if p == "||" { - if i == 0 { - return nil, fmt.Errorf("First element in range is '||'") - } - ORparts = append(ORparts, parts[last:i]) - last = i + 1 - } - } - if last == len(parts) { - return nil, fmt.Errorf("Last element in range is '||'") - } - ORparts = append(ORparts, parts[last:]) - return ORparts, nil -} - -// buildVersionRange takes a slice of 2: operator and version -// and builds a versionRange, otherwise an error. -func buildVersionRange(opStr, vStr string) (*versionRange, error) { - c := parseComparator(opStr) - if c == nil { - return nil, fmt.Errorf("Could not parse comparator %q in %q", opStr, strings.Join([]string{opStr, vStr}, "")) - } - v, err := Parse(vStr) - if err != nil { - return nil, fmt.Errorf("Could not parse version %q in %q: %s", vStr, strings.Join([]string{opStr, vStr}, ""), err) - } - - return &versionRange{ - v: v, - c: c, - }, nil - -} - -// splitAndTrim splits a range string by spaces and cleans leading and trailing spaces -func splitAndTrim(s string) (result []string) { - last := 0 - for i := 0; i < len(s); i++ { - if s[i] == ' ' { - if last < i-1 { - result = append(result, s[last:i]) - } - last = i + 1 - } - } - if last < len(s)-1 { - result = append(result, s[last:]) - } - // parts := strings.Split(s, " ") - // for _, x := range parts { - // if s := strings.TrimSpace(x); len(s) != 0 { - // result = append(result, s) - // } - // } - return -} - -// splitComparatorVersion splits the comparator from the version. -// Spaces between the comparator and the version are not allowed. -// Input must be free of leading or trailing spaces. -func splitComparatorVersion(s string) (string, string, error) { - i := strings.IndexFunc(s, unicode.IsDigit) - if i == -1 { - return "", "", fmt.Errorf("Could not get version from string: %q", s) - } - return strings.TrimSpace(s[0:i]), s[i:], nil -} - -func parseComparator(s string) comparator { - switch s { - case "==": - fallthrough - case "": - fallthrough - case "=": - return compEQ - case ">": - return compGT - case ">=": - return compGE - case "<": - return compLT - case "<=": - return compLE - case "!": - fallthrough - case "!=": - return compNE - } - - return nil -} - -// MustParseRange is like ParseRange but panics if the range cannot be parsed. -func MustParseRange(s string) Range { - r, err := ParseRange(s) - if err != nil { - panic(`semver: ParseRange(` + s + `): ` + err.Error()) - } - return r -} diff --git a/vendor/github.com/blang/semver/semver.go b/vendor/github.com/blang/semver/semver.go index 8ee0842..bbf85ce 100644 --- a/vendor/github.com/blang/semver/semver.go +++ b/vendor/github.com/blang/semver/semver.go @@ -200,29 +200,6 @@ func Make(s string) (Version, error) { return Parse(s) } -// ParseTolerant allows for certain version specifications that do not strictly adhere to semver -// specs to be parsed by this library. It does so by normalizing versions before passing them to -// Parse(). It currently trims spaces, removes a "v" prefix, and adds a 0 patch number to versions -// with only major and minor components specified -func ParseTolerant(s string) (Version, error) { - s = strings.TrimSpace(s) - s = strings.TrimPrefix(s, "v") - - // Split into major.minor.(patch+pr+meta) - parts := strings.SplitN(s, ".", 3) - if len(parts) < 3 { - if strings.ContainsAny(parts[len(parts)-1], "+-") { - return Version{}, errors.New("Short version cannot contain PreRelease/Build meta data") - } - for len(parts) < 3 { - parts = append(parts, "0") - } - s = strings.Join(parts, ".") - } - - return Parse(s) -} - // Parse parses version string and returns a validated Version or error func Parse(s string) (Version, error) { if len(s) == 0 { diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/.gitignore b/vendor/github.com/cloudfoundry-incubator/candiedyaml/.gitignore deleted file mode 100644 index 7823778..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/.gitignore +++ /dev/null @@ -1 +0,0 @@ -*.coverprofile diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/.travis.yml b/vendor/github.com/cloudfoundry-incubator/candiedyaml/.travis.yml deleted file mode 100644 index b39955e..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/.travis.yml +++ /dev/null @@ -1,12 +0,0 @@ -language: go - -go: - - 1.4.1 - -install: - - go get -t -v ./... - - go install github.com/onsi/ginkgo/ginkgo - -script: - - export PATH=$HOME/gopath/bin:$PATH - - ginkgo -r -failOnPending -randomizeAllSpecs -race diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE b/vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE deleted file mode 100644 index d9a10c0..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/LICENSE +++ /dev/null @@ -1,176 +0,0 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/README.md b/vendor/github.com/cloudfoundry-incubator/candiedyaml/README.md deleted file mode 100644 index 9407799..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/README.md +++ /dev/null @@ -1,59 +0,0 @@ -[![Build Status](https://travis-ci.org/cloudfoundry-incubator/candiedyaml.svg)](https://travis-ci.org/cloudfoundry-incubator/candiedyaml) -[![GoDoc](https://godoc.org/github.com/cloudfoundry-incubator/candiedyaml?status.svg)](https://godoc.org/github.com/cloudfoundry-incubator/candiedyaml) - - -candiedyaml -=========== - -YAML for Go - -A YAML 1.1 parser with support for YAML 1.2 features - -Usage ------ - -```go -package myApp - -import ( - "github.com/cloudfoundry-incubator/candiedyaml" - "fmt" - "os" -) - -func main() { - file, err := os.Open("path/to/some/file.yml") - if err != nil { - println("File does not exist:", err.Error()) - os.Exit(1) - } - defer file.Close() - - document := new(interface{}) - decoder := candiedyaml.NewDecoder(file) - err = decoder.Decode(document) - - if err != nil { - println("Failed to decode document:", err.Error()) - } - - println("parsed yml into interface:", fmt.Sprintf("%#v", document)) - - fileToWrite, err := os.Create("path/to/some/new/file.yml") - if err != nil { - println("Failed to open file for writing:", err.Error()) - os.Exit(1) - } - defer fileToWrite.Close() - - encoder := candiedyaml.NewEncoder(fileToWrite) - err = encoder.Encode(document) - - if err != nil { - println("Failed to encode document:", err.Error()) - os.Exit(1) - } - - return -} -``` diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go deleted file mode 100644 index 87c1043..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/api.go +++ /dev/null @@ -1,834 +0,0 @@ -/* -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 candiedyaml - -import ( - "io" -) - -/* - * Create a new parser object. - */ - -func yaml_parser_initialize(parser *yaml_parser_t) bool { - *parser = yaml_parser_t{ - raw_buffer: make([]byte, 0, INPUT_RAW_BUFFER_SIZE), - buffer: make([]byte, 0, INPUT_BUFFER_SIZE), - } - - return true -} - -/* - * Destroy a parser object. - */ -func yaml_parser_delete(parser *yaml_parser_t) { - *parser = yaml_parser_t{} -} - -/* - * String read handler. - */ - -func yaml_string_read_handler(parser *yaml_parser_t, buffer []byte) (int, error) { - if parser.input_pos == len(parser.input) { - return 0, io.EOF - } - - n := copy(buffer, parser.input[parser.input_pos:]) - parser.input_pos += n - return n, nil -} - -/* - * File read handler. - */ - -func yaml_file_read_handler(parser *yaml_parser_t, buffer []byte) (int, error) { - return parser.input_reader.Read(buffer) -} - -/* - * Set a string input. - */ - -func yaml_parser_set_input_string(parser *yaml_parser_t, input []byte) { - if parser.read_handler != nil { - panic("input already set") - } - - parser.read_handler = yaml_string_read_handler - - parser.input = input - parser.input_pos = 0 -} - -/* - * Set a reader input - */ -func yaml_parser_set_input_reader(parser *yaml_parser_t, reader io.Reader) { - if parser.read_handler != nil { - panic("input already set") - } - - parser.read_handler = yaml_file_read_handler - parser.input_reader = reader -} - -/* - * Set a generic input. - */ - -func yaml_parser_set_input(parser *yaml_parser_t, handler yaml_read_handler_t) { - if parser.read_handler != nil { - panic("input already set") - } - - parser.read_handler = handler -} - -/* - * Set the source encoding. - */ - -func yaml_parser_set_encoding(parser *yaml_parser_t, encoding yaml_encoding_t) { - if parser.encoding != yaml_ANY_ENCODING { - panic("encoding already set") - } - - parser.encoding = encoding -} - -/* - * Create a new emitter object. - */ - -func yaml_emitter_initialize(emitter *yaml_emitter_t) { - *emitter = yaml_emitter_t{ - buffer: make([]byte, OUTPUT_BUFFER_SIZE), - raw_buffer: make([]byte, 0, OUTPUT_RAW_BUFFER_SIZE), - states: make([]yaml_emitter_state_t, 0, INITIAL_STACK_SIZE), - events: make([]yaml_event_t, 0, INITIAL_QUEUE_SIZE), - } -} - -func yaml_emitter_delete(emitter *yaml_emitter_t) { - *emitter = yaml_emitter_t{} -} - -/* - * String write handler. - */ - -func yaml_string_write_handler(emitter *yaml_emitter_t, buffer []byte) error { - *emitter.output_buffer = append(*emitter.output_buffer, buffer...) - return nil -} - -/* - * File write handler. - */ - -func yaml_writer_write_handler(emitter *yaml_emitter_t, buffer []byte) error { - _, err := emitter.output_writer.Write(buffer) - return err -} - -/* - * Set a string output. - */ - -func yaml_emitter_set_output_string(emitter *yaml_emitter_t, buffer *[]byte) { - if emitter.write_handler != nil { - panic("output already set") - } - - emitter.write_handler = yaml_string_write_handler - emitter.output_buffer = buffer -} - -/* - * Set a file output. - */ - -func yaml_emitter_set_output_writer(emitter *yaml_emitter_t, w io.Writer) { - if emitter.write_handler != nil { - panic("output already set") - } - - emitter.write_handler = yaml_writer_write_handler - emitter.output_writer = w -} - -/* - * Set a generic output handler. - */ - -func yaml_emitter_set_output(emitter *yaml_emitter_t, handler yaml_write_handler_t) { - if emitter.write_handler != nil { - panic("output already set") - } - - emitter.write_handler = handler -} - -/* - * Set the output encoding. - */ - -func yaml_emitter_set_encoding(emitter *yaml_emitter_t, encoding yaml_encoding_t) { - if emitter.encoding != yaml_ANY_ENCODING { - panic("encoding already set") - } - - emitter.encoding = encoding -} - -/* - * Set the canonical output style. - */ - -func yaml_emitter_set_canonical(emitter *yaml_emitter_t, canonical bool) { - emitter.canonical = canonical -} - -/* - * Set the indentation increment. - */ - -func yaml_emitter_set_indent(emitter *yaml_emitter_t, indent int) { - if indent < 2 || indent > 9 { - indent = 2 - } - emitter.best_indent = indent -} - -/* - * Set the preferred line width. - */ - -func yaml_emitter_set_width(emitter *yaml_emitter_t, width int) { - if width < 0 { - width = -1 - } - emitter.best_width = width -} - -/* - * Set if unescaped non-ASCII characters are allowed. - */ - -func yaml_emitter_set_unicode(emitter *yaml_emitter_t, unicode bool) { - emitter.unicode = unicode -} - -/* - * Set the preferred line break character. - */ - -func yaml_emitter_set_break(emitter *yaml_emitter_t, line_break yaml_break_t) { - emitter.line_break = line_break -} - -/* - * Destroy a token object. - */ - -// yaml_DECLARE(void) -// yaml_token_delete(yaml_token_t *token) -// { -// assert(token); /* Non-NULL token object expected. */ -// -// switch (token.type) -// { -// case yaml_TAG_DIRECTIVE_TOKEN: -// yaml_free(token.data.tag_directive.handle); -// yaml_free(token.data.tag_directive.prefix); -// break; -// -// case yaml_ALIAS_TOKEN: -// yaml_free(token.data.alias.value); -// break; -// -// case yaml_ANCHOR_TOKEN: -// yaml_free(token.data.anchor.value); -// break; -// -// case yaml_TAG_TOKEN: -// yaml_free(token.data.tag.handle); -// yaml_free(token.data.tag.suffix); -// break; -// -// case yaml_SCALAR_TOKEN: -// yaml_free(token.data.scalar.value); -// break; -// -// default: -// break; -// } -// -// memset(token, 0, sizeof(yaml_token_t)); -// } - -/* - * Check if a string is a valid UTF-8 sequence. - * - * Check 'reader.c' for more details on UTF-8 encoding. - */ - -// static int -// yaml_check_utf8(yaml_char_t *start, size_t length) -// { -// yaml_char_t *end = start+length; -// yaml_char_t *pointer = start; -// -// while (pointer < end) { -// unsigned char octet; -// unsigned int width; -// unsigned int value; -// size_t k; -// -// octet = pointer[0]; -// width = (octet & 0x80) == 0x00 ? 1 : -// (octet & 0xE0) == 0xC0 ? 2 : -// (octet & 0xF0) == 0xE0 ? 3 : -// (octet & 0xF8) == 0xF0 ? 4 : 0; -// value = (octet & 0x80) == 0x00 ? octet & 0x7F : -// (octet & 0xE0) == 0xC0 ? octet & 0x1F : -// (octet & 0xF0) == 0xE0 ? octet & 0x0F : -// (octet & 0xF8) == 0xF0 ? octet & 0x07 : 0; -// if (!width) return 0; -// if (pointer+width > end) return 0; -// for (k = 1; k < width; k ++) { -// octet = pointer[k]; -// if ((octet & 0xC0) != 0x80) return 0; -// value = (value << 6) + (octet & 0x3F); -// } -// if (!((width == 1) || -// (width == 2 && value >= 0x80) || -// (width == 3 && value >= 0x800) || -// (width == 4 && value >= 0x10000))) return 0; -// -// pointer += width; -// } -// -// return 1; -// } - -/* - * Create STREAM-START. - */ - -func yaml_stream_start_event_initialize(event *yaml_event_t, encoding yaml_encoding_t) { - *event = yaml_event_t{ - event_type: yaml_STREAM_START_EVENT, - encoding: encoding, - } -} - -/* - * Create STREAM-END. - */ - -func yaml_stream_end_event_initialize(event *yaml_event_t) { - *event = yaml_event_t{ - event_type: yaml_STREAM_END_EVENT, - } -} - -/* - * Create DOCUMENT-START. - */ - -func yaml_document_start_event_initialize(event *yaml_event_t, - version_directive *yaml_version_directive_t, - tag_directives []yaml_tag_directive_t, - implicit bool) { - *event = yaml_event_t{ - event_type: yaml_DOCUMENT_START_EVENT, - version_directive: version_directive, - tag_directives: tag_directives, - implicit: implicit, - } -} - -/* - * Create DOCUMENT-END. - */ - -func yaml_document_end_event_initialize(event *yaml_event_t, implicit bool) { - *event = yaml_event_t{ - event_type: yaml_DOCUMENT_END_EVENT, - implicit: implicit, - } -} - -/* - * Create ALIAS. - */ - -func yaml_alias_event_initialize(event *yaml_event_t, anchor []byte) { - *event = yaml_event_t{ - event_type: yaml_ALIAS_EVENT, - anchor: anchor, - } -} - -/* - * Create SCALAR. - */ - -func yaml_scalar_event_initialize(event *yaml_event_t, - anchor []byte, tag []byte, - value []byte, - plain_implicit bool, quoted_implicit bool, - style yaml_scalar_style_t) { - - *event = yaml_event_t{ - event_type: yaml_SCALAR_EVENT, - anchor: anchor, - tag: tag, - value: value, - implicit: plain_implicit, - quoted_implicit: quoted_implicit, - style: yaml_style_t(style), - } -} - -/* - * Create SEQUENCE-START. - */ - -func yaml_sequence_start_event_initialize(event *yaml_event_t, - anchor []byte, tag []byte, implicit bool, style yaml_sequence_style_t) { - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_START_EVENT, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(style), - } -} - -/* - * Create SEQUENCE-END. - */ - -func yaml_sequence_end_event_initialize(event *yaml_event_t) { - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_END_EVENT, - } -} - -/* - * Create MAPPING-START. - */ - -func yaml_mapping_start_event_initialize(event *yaml_event_t, - anchor []byte, tag []byte, implicit bool, style yaml_mapping_style_t) { - *event = yaml_event_t{ - event_type: yaml_MAPPING_START_EVENT, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(style), - } -} - -/* - * Create MAPPING-END. - */ - -func yaml_mapping_end_event_initialize(event *yaml_event_t) { - *event = yaml_event_t{ - event_type: yaml_MAPPING_END_EVENT, - } -} - -/* - * Destroy an event object. - */ - -func yaml_event_delete(event *yaml_event_t) { - *event = yaml_event_t{} -} - -// /* -// * Create a document object. -// */ -// -// func yaml_document_initialize(document *yaml_document_t, -// version_directive *yaml_version_directive_t, -// tag_directives []yaml_tag_directive_t, -// start_implicit, end_implicit bool) bool { -// -// -// { -// struct { -// YAML_error_type_t error; -// } context; -// struct { -// yaml_node_t *start; -// yaml_node_t *end; -// yaml_node_t *top; -// } nodes = { NULL, NULL, NULL }; -// yaml_version_directive_t *version_directive_copy = NULL; -// struct { -// yaml_tag_directive_t *start; -// yaml_tag_directive_t *end; -// yaml_tag_directive_t *top; -// } tag_directives_copy = { NULL, NULL, NULL }; -// yaml_tag_directive_t value = { NULL, NULL }; -// YAML_mark_t mark = { 0, 0, 0 }; -// -// assert(document); /* Non-NULL document object is expected. */ -// assert((tag_directives_start && tag_directives_end) || -// (tag_directives_start == tag_directives_end)); -// /* Valid tag directives are expected. */ -// -// if (!STACK_INIT(&context, nodes, INITIAL_STACK_SIZE)) goto error; -// -// if (version_directive) { -// version_directive_copy = yaml_malloc(sizeof(yaml_version_directive_t)); -// if (!version_directive_copy) goto error; -// version_directive_copy.major = version_directive.major; -// version_directive_copy.minor = version_directive.minor; -// } -// -// if (tag_directives_start != tag_directives_end) { -// yaml_tag_directive_t *tag_directive; -// if (!STACK_INIT(&context, tag_directives_copy, INITIAL_STACK_SIZE)) -// goto error; -// for (tag_directive = tag_directives_start; -// tag_directive != tag_directives_end; tag_directive ++) { -// assert(tag_directive.handle); -// assert(tag_directive.prefix); -// if (!yaml_check_utf8(tag_directive.handle, -// strlen((char *)tag_directive.handle))) -// goto error; -// if (!yaml_check_utf8(tag_directive.prefix, -// strlen((char *)tag_directive.prefix))) -// goto error; -// value.handle = yaml_strdup(tag_directive.handle); -// value.prefix = yaml_strdup(tag_directive.prefix); -// if (!value.handle || !value.prefix) goto error; -// if (!PUSH(&context, tag_directives_copy, value)) -// goto error; -// value.handle = NULL; -// value.prefix = NULL; -// } -// } -// -// DOCUMENT_INIT(*document, nodes.start, nodes.end, version_directive_copy, -// tag_directives_copy.start, tag_directives_copy.top, -// start_implicit, end_implicit, mark, mark); -// -// return 1; -// -// error: -// STACK_DEL(&context, nodes); -// yaml_free(version_directive_copy); -// while (!STACK_EMPTY(&context, tag_directives_copy)) { -// yaml_tag_directive_t value = POP(&context, tag_directives_copy); -// yaml_free(value.handle); -// yaml_free(value.prefix); -// } -// STACK_DEL(&context, tag_directives_copy); -// yaml_free(value.handle); -// yaml_free(value.prefix); -// -// return 0; -// } -// -// /* -// * Destroy a document object. -// */ -// -// yaml_DECLARE(void) -// yaml_document_delete(document *yaml_document_t) -// { -// struct { -// YAML_error_type_t error; -// } context; -// yaml_tag_directive_t *tag_directive; -// -// context.error = yaml_NO_ERROR; /* Eliminate a compliler warning. */ -// -// assert(document); /* Non-NULL document object is expected. */ -// -// while (!STACK_EMPTY(&context, document.nodes)) { -// yaml_node_t node = POP(&context, document.nodes); -// yaml_free(node.tag); -// switch (node.type) { -// case yaml_SCALAR_NODE: -// yaml_free(node.data.scalar.value); -// break; -// case yaml_SEQUENCE_NODE: -// STACK_DEL(&context, node.data.sequence.items); -// break; -// case yaml_MAPPING_NODE: -// STACK_DEL(&context, node.data.mapping.pairs); -// break; -// default: -// assert(0); /* Should not happen. */ -// } -// } -// STACK_DEL(&context, document.nodes); -// -// yaml_free(document.version_directive); -// for (tag_directive = document.tag_directives.start; -// tag_directive != document.tag_directives.end; -// tag_directive++) { -// yaml_free(tag_directive.handle); -// yaml_free(tag_directive.prefix); -// } -// yaml_free(document.tag_directives.start); -// -// memset(document, 0, sizeof(yaml_document_t)); -// } -// -// /** -// * Get a document node. -// */ -// -// yaml_DECLARE(yaml_node_t *) -// yaml_document_get_node(document *yaml_document_t, int index) -// { -// assert(document); /* Non-NULL document object is expected. */ -// -// if (index > 0 && document.nodes.start + index <= document.nodes.top) { -// return document.nodes.start + index - 1; -// } -// return NULL; -// } -// -// /** -// * Get the root object. -// */ -// -// yaml_DECLARE(yaml_node_t *) -// yaml_document_get_root_node(document *yaml_document_t) -// { -// assert(document); /* Non-NULL document object is expected. */ -// -// if (document.nodes.top != document.nodes.start) { -// return document.nodes.start; -// } -// return NULL; -// } -// -// /* -// * Add a scalar node to a document. -// */ -// -// yaml_DECLARE(int) -// yaml_document_add_scalar(document *yaml_document_t, -// yaml_char_t *tag, yaml_char_t *value, int length, -// yaml_scalar_style_t style) -// { -// struct { -// YAML_error_type_t error; -// } context; -// YAML_mark_t mark = { 0, 0, 0 }; -// yaml_char_t *tag_copy = NULL; -// yaml_char_t *value_copy = NULL; -// yaml_node_t node; -// -// assert(document); /* Non-NULL document object is expected. */ -// assert(value); /* Non-NULL value is expected. */ -// -// if (!tag) { -// tag = (yaml_char_t *)yaml_DEFAULT_SCALAR_TAG; -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error; -// tag_copy = yaml_strdup(tag); -// if (!tag_copy) goto error; -// -// if (length < 0) { -// length = strlen((char *)value); -// } -// -// if (!yaml_check_utf8(value, length)) goto error; -// value_copy = yaml_malloc(length+1); -// if (!value_copy) goto error; -// memcpy(value_copy, value, length); -// value_copy[length] = '\0'; -// -// SCALAR_NODE_INIT(node, tag_copy, value_copy, length, style, mark, mark); -// if (!PUSH(&context, document.nodes, node)) goto error; -// -// return document.nodes.top - document.nodes.start; -// -// error: -// yaml_free(tag_copy); -// yaml_free(value_copy); -// -// return 0; -// } -// -// /* -// * Add a sequence node to a document. -// */ -// -// yaml_DECLARE(int) -// yaml_document_add_sequence(document *yaml_document_t, -// yaml_char_t *tag, yaml_sequence_style_t style) -// { -// struct { -// YAML_error_type_t error; -// } context; -// YAML_mark_t mark = { 0, 0, 0 }; -// yaml_char_t *tag_copy = NULL; -// struct { -// yaml_node_item_t *start; -// yaml_node_item_t *end; -// yaml_node_item_t *top; -// } items = { NULL, NULL, NULL }; -// yaml_node_t node; -// -// assert(document); /* Non-NULL document object is expected. */ -// -// if (!tag) { -// tag = (yaml_char_t *)yaml_DEFAULT_SEQUENCE_TAG; -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error; -// tag_copy = yaml_strdup(tag); -// if (!tag_copy) goto error; -// -// if (!STACK_INIT(&context, items, INITIAL_STACK_SIZE)) goto error; -// -// SEQUENCE_NODE_INIT(node, tag_copy, items.start, items.end, -// style, mark, mark); -// if (!PUSH(&context, document.nodes, node)) goto error; -// -// return document.nodes.top - document.nodes.start; -// -// error: -// STACK_DEL(&context, items); -// yaml_free(tag_copy); -// -// return 0; -// } -// -// /* -// * Add a mapping node to a document. -// */ -// -// yaml_DECLARE(int) -// yaml_document_add_mapping(document *yaml_document_t, -// yaml_char_t *tag, yaml_mapping_style_t style) -// { -// struct { -// YAML_error_type_t error; -// } context; -// YAML_mark_t mark = { 0, 0, 0 }; -// yaml_char_t *tag_copy = NULL; -// struct { -// yaml_node_pair_t *start; -// yaml_node_pair_t *end; -// yaml_node_pair_t *top; -// } pairs = { NULL, NULL, NULL }; -// yaml_node_t node; -// -// assert(document); /* Non-NULL document object is expected. */ -// -// if (!tag) { -// tag = (yaml_char_t *)yaml_DEFAULT_MAPPING_TAG; -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error; -// tag_copy = yaml_strdup(tag); -// if (!tag_copy) goto error; -// -// if (!STACK_INIT(&context, pairs, INITIAL_STACK_SIZE)) goto error; -// -// MAPPING_NODE_INIT(node, tag_copy, pairs.start, pairs.end, -// style, mark, mark); -// if (!PUSH(&context, document.nodes, node)) goto error; -// -// return document.nodes.top - document.nodes.start; -// -// error: -// STACK_DEL(&context, pairs); -// yaml_free(tag_copy); -// -// return 0; -// } -// -// /* -// * Append an item to a sequence node. -// */ -// -// yaml_DECLARE(int) -// yaml_document_append_sequence_item(document *yaml_document_t, -// int sequence, int item) -// { -// struct { -// YAML_error_type_t error; -// } context; -// -// assert(document); /* Non-NULL document is required. */ -// assert(sequence > 0 -// && document.nodes.start + sequence <= document.nodes.top); -// /* Valid sequence id is required. */ -// assert(document.nodes.start[sequence-1].type == yaml_SEQUENCE_NODE); -// /* A sequence node is required. */ -// assert(item > 0 && document.nodes.start + item <= document.nodes.top); -// /* Valid item id is required. */ -// -// if (!PUSH(&context, -// document.nodes.start[sequence-1].data.sequence.items, item)) -// return 0; -// -// return 1; -// } -// -// /* -// * Append a pair of a key and a value to a mapping node. -// */ -// -// yaml_DECLARE(int) -// yaml_document_append_mapping_pair(document *yaml_document_t, -// int mapping, int key, int value) -// { -// struct { -// YAML_error_type_t error; -// } context; -// -// yaml_node_pair_t pair; -// -// assert(document); /* Non-NULL document is required. */ -// assert(mapping > 0 -// && document.nodes.start + mapping <= document.nodes.top); -// /* Valid mapping id is required. */ -// assert(document.nodes.start[mapping-1].type == yaml_MAPPING_NODE); -// /* A mapping node is required. */ -// assert(key > 0 && document.nodes.start + key <= document.nodes.top); -// /* Valid key id is required. */ -// assert(value > 0 && document.nodes.start + value <= document.nodes.top); -// /* Valid value id is required. */ -// -// pair.key = key; -// pair.value = value; -// -// if (!PUSH(&context, -// document.nodes.start[mapping-1].data.mapping.pairs, pair)) -// return 0; -// -// return 1; -// } -// diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go deleted file mode 100644 index dcc1b89..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/decode.go +++ /dev/null @@ -1,622 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" - "errors" - "fmt" - "io" - "reflect" - "runtime" - "strconv" - "strings" -) - -type Unmarshaler interface { - UnmarshalYAML(tag string, value interface{}) error -} - -// A Number represents a JSON number literal. -type Number string - -// String returns the literal text of the number. -func (n Number) String() string { return string(n) } - -// Float64 returns the number as a float64. -func (n Number) Float64() (float64, error) { - return strconv.ParseFloat(string(n), 64) -} - -// Int64 returns the number as an int64. -func (n Number) Int64() (int64, error) { - return strconv.ParseInt(string(n), 10, 64) -} - -type Decoder struct { - parser yaml_parser_t - event yaml_event_t - replay_events []yaml_event_t - useNumber bool - - anchors map[string][]yaml_event_t - tracking_anchors [][]yaml_event_t -} - -type ParserError struct { - ErrorType YAML_error_type_t - Context string - ContextMark YAML_mark_t - Problem string - ProblemMark YAML_mark_t -} - -func (e *ParserError) Error() string { - return fmt.Sprintf("yaml: [%s] %s at line %d, column %d", e.Context, e.Problem, e.ProblemMark.line+1, e.ProblemMark.column+1) -} - -type UnexpectedEventError struct { - Value string - EventType yaml_event_type_t - At YAML_mark_t -} - -func (e *UnexpectedEventError) Error() string { - return fmt.Sprintf("yaml: Unexpect event [%d]: '%s' at line %d, column %d", e.EventType, e.Value, e.At.line+1, e.At.column+1) -} - -func recovery(err *error) { - if r := recover(); r != nil { - if _, ok := r.(runtime.Error); ok { - panic(r) - } - - var tmpError error - switch r := r.(type) { - case error: - tmpError = r - case string: - tmpError = errors.New(r) - default: - tmpError = errors.New("Unknown panic: " + reflect.ValueOf(r).String()) - } - - *err = tmpError - } -} - -func Unmarshal(data []byte, v interface{}) error { - d := NewDecoder(bytes.NewBuffer(data)) - return d.Decode(v) -} - -func NewDecoder(r io.Reader) *Decoder { - d := &Decoder{ - anchors: make(map[string][]yaml_event_t), - tracking_anchors: make([][]yaml_event_t, 1), - } - yaml_parser_initialize(&d.parser) - yaml_parser_set_input_reader(&d.parser, r) - return d -} - -func (d *Decoder) Decode(v interface{}) (err error) { - defer recovery(&err) - - rv := reflect.ValueOf(v) - if rv.Kind() != reflect.Ptr || rv.IsNil() { - return fmt.Errorf("Expected a pointer or nil but was a %s at %s", rv.String(), d.event.start_mark) - } - - if d.event.event_type == yaml_NO_EVENT { - d.nextEvent() - - if d.event.event_type != yaml_STREAM_START_EVENT { - return errors.New("Invalid stream") - } - - d.nextEvent() - } - - d.document(rv) - return nil -} - -func (d *Decoder) UseNumber() { d.useNumber = true } - -func (d *Decoder) error(err error) { - panic(err) -} - -func (d *Decoder) nextEvent() { - if d.event.event_type == yaml_STREAM_END_EVENT { - d.error(errors.New("The stream is closed")) - } - - if d.replay_events != nil { - d.event = d.replay_events[0] - if len(d.replay_events) == 1 { - d.replay_events = nil - } else { - d.replay_events = d.replay_events[1:] - } - } else { - if !yaml_parser_parse(&d.parser, &d.event) { - yaml_event_delete(&d.event) - - d.error(&ParserError{ - ErrorType: d.parser.error, - Context: d.parser.context, - ContextMark: d.parser.context_mark, - Problem: d.parser.problem, - ProblemMark: d.parser.problem_mark, - }) - } - } - - last := len(d.tracking_anchors) - // skip aliases when tracking an anchor - if last > 0 && d.event.event_type != yaml_ALIAS_EVENT { - d.tracking_anchors[last-1] = append(d.tracking_anchors[last-1], d.event) - } -} - -func (d *Decoder) document(rv reflect.Value) { - if d.event.event_type != yaml_DOCUMENT_START_EVENT { - d.error(fmt.Errorf("Expected document start at %s", d.event.start_mark)) - } - - d.nextEvent() - d.parse(rv) - - if d.event.event_type != yaml_DOCUMENT_END_EVENT { - d.error(fmt.Errorf("Expected document end at %s", d.event.start_mark)) - } - - d.nextEvent() -} - -func (d *Decoder) parse(rv reflect.Value) { - if !rv.IsValid() { - // skip ahead since we cannot store - d.valueInterface() - return - } - - anchor := string(d.event.anchor) - switch d.event.event_type { - case yaml_SEQUENCE_START_EVENT: - d.begin_anchor(anchor) - d.sequence(rv) - d.end_anchor(anchor) - case yaml_MAPPING_START_EVENT: - d.begin_anchor(anchor) - d.mapping(rv) - d.end_anchor(anchor) - case yaml_SCALAR_EVENT: - d.begin_anchor(anchor) - d.scalar(rv) - d.end_anchor(anchor) - case yaml_ALIAS_EVENT: - d.alias(rv) - case yaml_DOCUMENT_END_EVENT: - default: - d.error(&UnexpectedEventError{ - Value: string(d.event.value), - EventType: d.event.event_type, - At: d.event.start_mark, - }) - } -} - -func (d *Decoder) begin_anchor(anchor string) { - if anchor != "" { - events := []yaml_event_t{d.event} - d.tracking_anchors = append(d.tracking_anchors, events) - } -} - -func (d *Decoder) end_anchor(anchor string) { - if anchor != "" { - events := d.tracking_anchors[len(d.tracking_anchors)-1] - d.tracking_anchors = d.tracking_anchors[0 : len(d.tracking_anchors)-1] - // remove the anchor, replaying events shouldn't have anchors - events[0].anchor = nil - // we went one too many, remove the extra event - events = events[:len(events)-1] - // if nested, append to all the other anchors - for i, e := range d.tracking_anchors { - d.tracking_anchors[i] = append(e, events...) - } - d.anchors[anchor] = events - } -} - -func (d *Decoder) indirect(v reflect.Value, decodingNull bool) (Unmarshaler, reflect.Value) { - // If v is a named type and is addressable, - // start with its address, so that if the type has pointer methods, - // we find them. - if v.Kind() != reflect.Ptr && v.Type().Name() != "" && v.CanAddr() { - v = v.Addr() - } - for { - // Load value from interface, but only if the result will be - // usefully addressable. - if v.Kind() == reflect.Interface && !v.IsNil() { - e := v.Elem() - if e.Kind() == reflect.Ptr && !e.IsNil() && (!decodingNull || e.Elem().Kind() == reflect.Ptr) { - v = e - continue - } - } - - if v.Kind() != reflect.Ptr { - break - } - - if v.Elem().Kind() != reflect.Ptr && decodingNull && v.CanSet() { - break - } - - if v.IsNil() { - v.Set(reflect.New(v.Type().Elem())) - } - - if v.Type().NumMethod() > 0 { - if u, ok := v.Interface().(Unmarshaler); ok { - var temp interface{} - return u, reflect.ValueOf(&temp) - } - } - - v = v.Elem() - } - - return nil, v -} - -func (d *Decoder) sequence(v reflect.Value) { - if d.event.event_type != yaml_SEQUENCE_START_EVENT { - d.error(fmt.Errorf("Expected sequence start at %s", d.event.start_mark)) - } - - u, pv := d.indirect(v, false) - if u != nil { - defer func() { - if err := u.UnmarshalYAML(yaml_SEQ_TAG, pv.Interface()); err != nil { - d.error(err) - } - }() - _, pv = d.indirect(pv, false) - } - - v = pv - - // Check type of target. - switch v.Kind() { - case reflect.Interface: - if v.NumMethod() == 0 { - // Decoding into nil interface? Switch to non-reflect code. - v.Set(reflect.ValueOf(d.sequenceInterface())) - return - } - // Otherwise it's invalid. - fallthrough - default: - d.error(fmt.Errorf("Expected an array, slice or interface{} but was a %s at %s", v, d.event.start_mark)) - case reflect.Array: - case reflect.Slice: - break - } - - d.nextEvent() - - i := 0 -done: - for { - switch d.event.event_type { - case yaml_SEQUENCE_END_EVENT, yaml_DOCUMENT_END_EVENT: - break done - } - - // Get element of array, growing if necessary. - if v.Kind() == reflect.Slice { - // Grow slice if necessary - if i >= v.Cap() { - newcap := v.Cap() + v.Cap()/2 - if newcap < 4 { - newcap = 4 - } - newv := reflect.MakeSlice(v.Type(), v.Len(), newcap) - reflect.Copy(newv, v) - v.Set(newv) - } - if i >= v.Len() { - v.SetLen(i + 1) - } - } - - if i < v.Len() { - // Decode into element. - d.parse(v.Index(i)) - } else { - // Ran out of fixed array: skip. - d.parse(reflect.Value{}) - } - i++ - } - - if i < v.Len() { - if v.Kind() == reflect.Array { - // Array. Zero the rest. - z := reflect.Zero(v.Type().Elem()) - for ; i < v.Len(); i++ { - v.Index(i).Set(z) - } - } else { - v.SetLen(i) - } - } - if i == 0 && v.Kind() == reflect.Slice { - v.Set(reflect.MakeSlice(v.Type(), 0, 0)) - } - - if d.event.event_type != yaml_DOCUMENT_END_EVENT { - d.nextEvent() - } -} - -func (d *Decoder) mapping(v reflect.Value) { - u, pv := d.indirect(v, false) - if u != nil { - defer func() { - if err := u.UnmarshalYAML(yaml_MAP_TAG, pv.Interface()); err != nil { - d.error(err) - } - }() - _, pv = d.indirect(pv, false) - } - v = pv - - // Decoding into nil interface? Switch to non-reflect code. - if v.Kind() == reflect.Interface && v.NumMethod() == 0 { - v.Set(reflect.ValueOf(d.mappingInterface())) - return - } - - // Check type of target: struct or map[X]Y - switch v.Kind() { - case reflect.Struct: - d.mappingStruct(v) - return - case reflect.Map: - default: - d.error(fmt.Errorf("Expected a struct or map but was a %s at %s ", v, d.event.start_mark)) - } - - mapt := v.Type() - if v.IsNil() { - v.Set(reflect.MakeMap(mapt)) - } - - d.nextEvent() - - keyt := mapt.Key() - mapElemt := mapt.Elem() - - var mapElem reflect.Value -done: - for { - switch d.event.event_type { - case yaml_MAPPING_END_EVENT: - break done - case yaml_DOCUMENT_END_EVENT: - return - } - - key := reflect.New(keyt) - d.parse(key.Elem()) - - if !mapElem.IsValid() { - mapElem = reflect.New(mapElemt).Elem() - } else { - mapElem.Set(reflect.Zero(mapElemt)) - } - - d.parse(mapElem) - - v.SetMapIndex(key.Elem(), mapElem) - } - - d.nextEvent() -} - -func (d *Decoder) mappingStruct(v reflect.Value) { - - structt := v.Type() - fields := cachedTypeFields(structt) - - d.nextEvent() - -done: - for { - switch d.event.event_type { - case yaml_MAPPING_END_EVENT: - break done - case yaml_DOCUMENT_END_EVENT: - return - } - - key := "" - d.parse(reflect.ValueOf(&key)) - - // Figure out field corresponding to key. - var subv reflect.Value - - var f *field - for i := range fields { - ff := &fields[i] - if ff.name == key { - f = ff - break - } - - if f == nil && strings.EqualFold(ff.name, key) { - f = ff - } - } - - if f != nil { - subv = v - for _, i := range f.index { - if subv.Kind() == reflect.Ptr { - if subv.IsNil() { - subv.Set(reflect.New(subv.Type().Elem())) - } - subv = subv.Elem() - } - subv = subv.Field(i) - } - } - d.parse(subv) - } - - d.nextEvent() -} - -func (d *Decoder) scalar(v reflect.Value) { - val := string(d.event.value) - wantptr := null_values[val] - - u, pv := d.indirect(v, wantptr) - - var tag string - if u != nil { - defer func() { - if err := u.UnmarshalYAML(tag, pv.Interface()); err != nil { - d.error(err) - } - }() - - _, pv = d.indirect(pv, wantptr) - } - v = pv - - var err error - tag, err = resolve(d.event, v, d.useNumber) - if err != nil { - d.error(err) - } - - d.nextEvent() -} - -func (d *Decoder) alias(rv reflect.Value) { - val, ok := d.anchors[string(d.event.anchor)] - if !ok { - d.error(fmt.Errorf("missing anchor: '%s' at %s", d.event.anchor, d.event.start_mark)) - } - - d.replay_events = val - d.nextEvent() - d.parse(rv) -} - -func (d *Decoder) valueInterface() interface{} { - var v interface{} - - anchor := string(d.event.anchor) - switch d.event.event_type { - case yaml_SEQUENCE_START_EVENT: - d.begin_anchor(anchor) - v = d.sequenceInterface() - case yaml_MAPPING_START_EVENT: - d.begin_anchor(anchor) - v = d.mappingInterface() - case yaml_SCALAR_EVENT: - d.begin_anchor(anchor) - v = d.scalarInterface() - case yaml_ALIAS_EVENT: - rv := reflect.ValueOf(&v) - d.alias(rv) - return v - case yaml_DOCUMENT_END_EVENT: - d.error(&UnexpectedEventError{ - Value: string(d.event.value), - EventType: d.event.event_type, - At: d.event.start_mark, - }) - - } - d.end_anchor(anchor) - - return v -} - -func (d *Decoder) scalarInterface() interface{} { - _, v := resolveInterface(d.event, d.useNumber) - - d.nextEvent() - return v -} - -// sequenceInterface is like sequence but returns []interface{}. -func (d *Decoder) sequenceInterface() []interface{} { - var v = make([]interface{}, 0) - - d.nextEvent() - -done: - for { - switch d.event.event_type { - case yaml_SEQUENCE_END_EVENT, yaml_DOCUMENT_END_EVENT: - break done - } - - v = append(v, d.valueInterface()) - } - - if d.event.event_type != yaml_DOCUMENT_END_EVENT { - d.nextEvent() - } - - return v -} - -// mappingInterface is like mapping but returns map[interface{}]interface{}. -func (d *Decoder) mappingInterface() map[interface{}]interface{} { - m := make(map[interface{}]interface{}) - - d.nextEvent() - -done: - for { - switch d.event.event_type { - case yaml_MAPPING_END_EVENT, yaml_DOCUMENT_END_EVENT: - break done - } - - key := d.valueInterface() - - // Read value. - m[key] = d.valueInterface() - } - - if d.event.event_type != yaml_DOCUMENT_END_EVENT { - d.nextEvent() - } - - return m -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go deleted file mode 100644 index bd2014f..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/emitter.go +++ /dev/null @@ -1,2072 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" -) - -var default_tag_directives = []yaml_tag_directive_t{ - {[]byte("!"), []byte("!")}, - {[]byte("!!"), []byte("tag:yaml.org,2002:")}, -} - -/* - * Flush the buffer if needed. - */ - -func flush(emitter *yaml_emitter_t) bool { - if emitter.buffer_pos+5 >= len(emitter.buffer) { - return yaml_emitter_flush(emitter) - } - return true -} - -/* - * Put a character to the output buffer. - */ -func put(emitter *yaml_emitter_t, value byte) bool { - if !flush(emitter) { - return false - } - - emitter.buffer[emitter.buffer_pos] = value - emitter.buffer_pos++ - emitter.column++ - return true -} - -/* - * Put a line break to the output buffer. - */ - -func put_break(emitter *yaml_emitter_t) bool { - if !flush(emitter) { - return false - } - switch emitter.line_break { - case yaml_CR_BREAK: - emitter.buffer[emitter.buffer_pos] = '\r' - emitter.buffer_pos++ - case yaml_LN_BREAK: - emitter.buffer[emitter.buffer_pos] = '\n' - emitter.buffer_pos++ - case yaml_CRLN_BREAK: - emitter.buffer[emitter.buffer_pos] = '\r' - emitter.buffer[emitter.buffer_pos] = '\n' - emitter.buffer_pos += 2 - default: - return false - } - emitter.column = 0 - emitter.line++ - return true -} - -/* - * Copy a character from a string into buffer. - */ -func write(emitter *yaml_emitter_t, src []byte, src_pos *int) bool { - if !flush(emitter) { - return false - } - copy_bytes(emitter.buffer, &emitter.buffer_pos, src, src_pos) - emitter.column++ - return true -} - -/* - * Copy a line break character from a string into buffer. - */ - -func write_break(emitter *yaml_emitter_t, src []byte, src_pos *int) bool { - if src[*src_pos] == '\n' { - if !put_break(emitter) { - return false - } - *src_pos++ - } else { - if !write(emitter, src, src_pos) { - return false - } - emitter.column = 0 - emitter.line++ - } - - return true -} - -/* - * Set an emitter error and return 0. - */ - -func yaml_emitter_set_emitter_error(emitter *yaml_emitter_t, problem string) bool { - emitter.error = yaml_EMITTER_ERROR - emitter.problem = problem - return false -} - -/* - * Emit an event. - */ - -func yaml_emitter_emit(emitter *yaml_emitter_t, event *yaml_event_t) bool { - emitter.events = append(emitter.events, *event) - for !yaml_emitter_need_more_events(emitter) { - event := &emitter.events[emitter.events_head] - if !yaml_emitter_analyze_event(emitter, event) { - return false - } - if !yaml_emitter_state_machine(emitter, event) { - return false - } - yaml_event_delete(event) - emitter.events_head++ - } - return true -} - -/* - * Check if we need to accumulate more events before emitting. - * - * We accumulate extra - * - 1 event for DOCUMENT-START - * - 2 events for SEQUENCE-START - * - 3 events for MAPPING-START - */ - -func yaml_emitter_need_more_events(emitter *yaml_emitter_t) bool { - if emitter.events_head == len(emitter.events) { - return true - } - - accumulate := 0 - switch emitter.events[emitter.events_head].event_type { - case yaml_DOCUMENT_START_EVENT: - accumulate = 1 - case yaml_SEQUENCE_START_EVENT: - accumulate = 2 - case yaml_MAPPING_START_EVENT: - accumulate = 3 - default: - return false - } - - if len(emitter.events)-emitter.events_head > accumulate { - return false - } - - level := 0 - for i := emitter.events_head; i < len(emitter.events); i++ { - switch emitter.events[i].event_type { - case yaml_STREAM_START_EVENT, yaml_DOCUMENT_START_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT: - level++ - case yaml_STREAM_END_EVENT, yaml_DOCUMENT_END_EVENT, yaml_SEQUENCE_END_EVENT, yaml_MAPPING_END_EVENT: - level-- - } - - if level == 0 { - return false - } - } - return true -} - -/* - * Append a directive to the directives stack. - */ - -func yaml_emitter_append_tag_directive(emitter *yaml_emitter_t, - value *yaml_tag_directive_t, allow_duplicates bool) bool { - - for i := range emitter.tag_directives { - - if bytes.Equal(value.handle, emitter.tag_directives[i].handle) { - if allow_duplicates { - return true - } - return yaml_emitter_set_emitter_error(emitter, "duplicat %TAG directive") - } - } - - tag_copy := yaml_tag_directive_t{ - handle: value.handle, - prefix: value.prefix, - } - - emitter.tag_directives = append(emitter.tag_directives, tag_copy) - - return true -} - -/* - * Increase the indentation level. - */ - -func yaml_emitter_increase_indent(emitter *yaml_emitter_t, flow bool, indentless bool) bool { - - emitter.indents = append(emitter.indents, emitter.indent) - - if emitter.indent < 0 { - if flow { - emitter.indent = emitter.best_indent - } else { - emitter.indent = 0 - } - } else if !indentless { - emitter.indent += emitter.best_indent - } - - return true -} - -/* - * State dispatcher. - */ - -func yaml_emitter_state_machine(emitter *yaml_emitter_t, event *yaml_event_t) bool { - switch emitter.state { - case yaml_EMIT_STREAM_START_STATE: - return yaml_emitter_emit_stream_start(emitter, event) - - case yaml_EMIT_FIRST_DOCUMENT_START_STATE: - return yaml_emitter_emit_document_start(emitter, event, true) - - case yaml_EMIT_DOCUMENT_START_STATE: - return yaml_emitter_emit_document_start(emitter, event, false) - - case yaml_EMIT_DOCUMENT_CONTENT_STATE: - return yaml_emitter_emit_document_content(emitter, event) - - case yaml_EMIT_DOCUMENT_END_STATE: - return yaml_emitter_emit_document_end(emitter, event) - - case yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE: - return yaml_emitter_emit_flow_sequence_item(emitter, event, true) - - case yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE: - return yaml_emitter_emit_flow_sequence_item(emitter, event, false) - - case yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE: - return yaml_emitter_emit_flow_mapping_key(emitter, event, true) - - case yaml_EMIT_FLOW_MAPPING_KEY_STATE: - return yaml_emitter_emit_flow_mapping_key(emitter, event, false) - - case yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE: - return yaml_emitter_emit_flow_mapping_value(emitter, event, true) - - case yaml_EMIT_FLOW_MAPPING_VALUE_STATE: - return yaml_emitter_emit_flow_mapping_value(emitter, event, false) - - case yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE: - return yaml_emitter_emit_block_sequence_item(emitter, event, true) - - case yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE: - return yaml_emitter_emit_block_sequence_item(emitter, event, false) - - case yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE: - return yaml_emitter_emit_block_mapping_key(emitter, event, true) - - case yaml_EMIT_BLOCK_MAPPING_KEY_STATE: - return yaml_emitter_emit_block_mapping_key(emitter, event, false) - - case yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE: - return yaml_emitter_emit_block_mapping_value(emitter, event, true) - - case yaml_EMIT_BLOCK_MAPPING_VALUE_STATE: - return yaml_emitter_emit_block_mapping_value(emitter, event, false) - - case yaml_EMIT_END_STATE: - return yaml_emitter_set_emitter_error(emitter, - "expected nothing after STREAM-END") - - } - - panic("invalid state") -} - -/* - * Expect STREAM-START. - */ - -func yaml_emitter_emit_stream_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - - if event.event_type != yaml_STREAM_START_EVENT { - return yaml_emitter_set_emitter_error(emitter, - "expected STREAM-START") - } - - if emitter.encoding == yaml_ANY_ENCODING { - emitter.encoding = event.encoding - - if emitter.encoding == yaml_ANY_ENCODING { - emitter.encoding = yaml_UTF8_ENCODING - } - } - - if emitter.best_indent < 2 || emitter.best_indent > 9 { - emitter.best_indent = 2 - } - - if emitter.best_width >= 0 && emitter.best_width <= emitter.best_indent*2 { - emitter.best_width = 80 - } - - if emitter.best_width < 0 { - emitter.best_width = 1<<31 - 1 - } - - if emitter.line_break == yaml_ANY_BREAK { - emitter.line_break = yaml_LN_BREAK - } - - emitter.indent = -1 - - emitter.line = 0 - emitter.column = 0 - emitter.whitespace = true - emitter.indention = true - - if emitter.encoding != yaml_UTF8_ENCODING { - if !yaml_emitter_write_bom(emitter) { - return false - } - } - - emitter.state = yaml_EMIT_FIRST_DOCUMENT_START_STATE - - return true -} - -/* - * Expect DOCUMENT-START or STREAM-END. - */ - -func yaml_emitter_emit_document_start(emitter *yaml_emitter_t, - event *yaml_event_t, first bool) bool { - - if event.event_type == yaml_DOCUMENT_START_EVENT { - if event.version_directive != nil { - if !yaml_emitter_analyze_version_directive(emitter, - *event.version_directive) { - return false - } - } - - for i := range event.tag_directives { - tag_directive := &event.tag_directives[i] - - if !yaml_emitter_analyze_tag_directive(emitter, tag_directive) { - return false - } - if !yaml_emitter_append_tag_directive(emitter, tag_directive, false) { - return false - } - } - - for i := range default_tag_directives { - if !yaml_emitter_append_tag_directive(emitter, &default_tag_directives[i], true) { - return false - } - } - - implicit := event.implicit - if !first || emitter.canonical { - implicit = false - } - - if (event.version_directive != nil || len(event.tag_directives) > 0) && - emitter.open_ended { - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if event.version_directive != nil { - implicit = false - if !yaml_emitter_write_indicator(emitter, []byte("%YAML"), true, false, false) { - return false - } - - if !yaml_emitter_write_indicator(emitter, []byte("1.1"), true, false, false) { - return false - } - - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if len(event.tag_directives) > 0 { - implicit = false - for i := range event.tag_directives { - tag_directive := &event.tag_directives[i] - - if !yaml_emitter_write_indicator(emitter, []byte("%TAG"), true, false, false) { - return false - } - if !yaml_emitter_write_tag_handle(emitter, tag_directive.handle) { - return false - } - if !yaml_emitter_write_tag_content(emitter, tag_directive.prefix, true) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - } - - if yaml_emitter_check_empty_document(emitter) { - implicit = false - } - - if !implicit { - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte("---"), true, false, false) { - return false - } - - if emitter.canonical { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - } - - emitter.state = yaml_EMIT_DOCUMENT_CONTENT_STATE - - return true - } else if event.event_type == yaml_STREAM_END_EVENT { - if emitter.open_ended { - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if !yaml_emitter_flush(emitter) { - return false - } - - emitter.state = yaml_EMIT_END_STATE - - return true - } - - return yaml_emitter_set_emitter_error(emitter, - "expected DOCUMENT-START or STREAM-END") -} - -/* - * Expect the root node. - */ - -func yaml_emitter_emit_document_content(emitter *yaml_emitter_t, event *yaml_event_t) bool { - emitter.states = append(emitter.states, yaml_EMIT_DOCUMENT_END_STATE) - - return yaml_emitter_emit_node(emitter, event, true, false, false, false) -} - -/* - * Expect DOCUMENT-END. - */ - -func yaml_emitter_emit_document_end(emitter *yaml_emitter_t, event *yaml_event_t) bool { - - if event.event_type != yaml_DOCUMENT_END_EVENT { - return yaml_emitter_set_emitter_error(emitter, - "expected DOCUMENT-END") - } - - if !yaml_emitter_write_indent(emitter) { - return false - } - if !event.implicit { - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_flush(emitter) { - return false - } - - emitter.state = yaml_EMIT_DOCUMENT_START_STATE - emitter.tag_directives = emitter.tag_directives[:0] - return true -} - -/* - * - * Expect a flow item node. - */ - -func yaml_emitter_emit_flow_sequence_item(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - if first { - if !yaml_emitter_write_indicator(emitter, []byte("["), true, true, false) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - emitter.flow_level++ - } - - if event.event_type == yaml_SEQUENCE_END_EVENT { - emitter.flow_level-- - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - if emitter.canonical && !first { - if !yaml_emitter_write_indicator(emitter, []byte(","), false, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte("]"), false, false, false) { - return false - } - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true - } - - if !first { - if !yaml_emitter_write_indicator(emitter, []byte(","), false, false, false) { - return false - } - } - - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - emitter.states = append(emitter.states, yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE) - return yaml_emitter_emit_node(emitter, event, false, true, false, false) -} - -/* - * Expect a flow key node. - */ - -func yaml_emitter_emit_flow_mapping_key(emitter *yaml_emitter_t, - event *yaml_event_t, first bool) bool { - - if first { - - if !yaml_emitter_write_indicator(emitter, []byte("{"), true, true, false) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - emitter.flow_level++ - } - - if event.event_type == yaml_MAPPING_END_EVENT { - emitter.flow_level-- - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - - if emitter.canonical && !first { - if !yaml_emitter_write_indicator(emitter, []byte(","), false, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte("}"), false, false, false) { - return false - } - - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true - } - - if !first { - if !yaml_emitter_write_indicator(emitter, []byte(","), false, false, false) { - return false - } - } - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if !emitter.canonical && yaml_emitter_check_simple_key(emitter) { - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, true) - } else { - if !yaml_emitter_write_indicator(emitter, []byte("?"), true, false, false) { - return false - } - - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) - } -} - -/* - * Expect a flow value node. - */ - -func yaml_emitter_emit_flow_mapping_value(emitter *yaml_emitter_t, - event *yaml_event_t, simple bool) bool { - - if simple { - if !yaml_emitter_write_indicator(emitter, []byte(":"), false, false, false) { - return false - } - } else { - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte(":"), true, false, false) { - return false - } - } - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_KEY_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -/* - * Expect a block item node. - */ - -func yaml_emitter_emit_block_sequence_item(emitter *yaml_emitter_t, - event *yaml_event_t, first bool) bool { - - if first { - if !yaml_emitter_increase_indent(emitter, false, - (emitter.mapping_context && !emitter.indention)) { - return false - } - } - - if event.event_type == yaml_SEQUENCE_END_EVENT { - - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true - } - - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte("-"), true, false, true) { - return false - } - - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE) - return yaml_emitter_emit_node(emitter, event, false, true, false, false) -} - -/* - * Expect a block key node. - */ - -func yaml_emitter_emit_block_mapping_key(emitter *yaml_emitter_t, - event *yaml_event_t, first bool) bool { - - if first { - if !yaml_emitter_increase_indent(emitter, false, false) { - return false - } - } - - if event.event_type == yaml_MAPPING_END_EVENT { - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true - } - - if !yaml_emitter_write_indent(emitter) { - return false - } - - if yaml_emitter_check_simple_key(emitter) { - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE) - - return yaml_emitter_emit_node(emitter, event, false, false, true, true) - } else { - if !yaml_emitter_write_indicator(emitter, []byte("?"), true, false, true) { - return false - } - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_VALUE_STATE) - - return yaml_emitter_emit_node(emitter, event, false, false, true, false) - } -} - -/* - * Expect a block value node. - */ - -func yaml_emitter_emit_block_mapping_value(emitter *yaml_emitter_t, - event *yaml_event_t, simple bool) bool { - - if simple { - if !yaml_emitter_write_indicator(emitter, []byte(":"), false, false, false) { - return false - } - } else { - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte(":"), true, false, true) { - return false - } - } - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_KEY_STATE) - - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -/* - * Expect a node. - */ - -func yaml_emitter_emit_node(emitter *yaml_emitter_t, event *yaml_event_t, - root bool, sequence bool, mapping bool, simple_key bool) bool { - emitter.root_context = root - emitter.sequence_context = sequence - emitter.mapping_context = mapping - emitter.simple_key_context = simple_key - - switch event.event_type { - case yaml_ALIAS_EVENT: - return yaml_emitter_emit_alias(emitter, event) - - case yaml_SCALAR_EVENT: - return yaml_emitter_emit_scalar(emitter, event) - - case yaml_SEQUENCE_START_EVENT: - return yaml_emitter_emit_sequence_start(emitter, event) - - case yaml_MAPPING_START_EVENT: - return yaml_emitter_emit_mapping_start(emitter, event) - - default: - return yaml_emitter_set_emitter_error(emitter, - "expected SCALAR, SEQUENCE-START, MAPPING-START, or ALIAS") - } - - return false -} - -/* - * Expect ALIAS. - */ - -func yaml_emitter_emit_alias(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true -} - -/* - * Expect SCALAR. - */ - -func yaml_emitter_emit_scalar(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_select_scalar_style(emitter, event) { - return false - } - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - if !yaml_emitter_process_scalar(emitter) { - return false - } - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true -} - -/* - * Expect SEQUENCE-START. - */ - -func yaml_emitter_emit_sequence_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - - if emitter.flow_level > 0 || emitter.canonical || - event.style == yaml_style_t(yaml_FLOW_SEQUENCE_STYLE) || - yaml_emitter_check_empty_sequence(emitter) { - emitter.state = yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE - } else { - emitter.state = yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE - } - - return true -} - -/* - * Expect MAPPING-START. - */ - -func yaml_emitter_emit_mapping_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - - if emitter.flow_level > 0 || emitter.canonical || - event.style == yaml_style_t(yaml_FLOW_MAPPING_STYLE) || - yaml_emitter_check_empty_mapping(emitter) { - emitter.state = yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE - } else { - emitter.state = yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE - } - - return true -} - -/* - * Check if the document content is an empty scalar. - */ - -func yaml_emitter_check_empty_document(emitter *yaml_emitter_t) bool { - return false -} - -/* - * Check if the next events represent an empty sequence. - */ - -func yaml_emitter_check_empty_sequence(emitter *yaml_emitter_t) bool { - if len(emitter.events)-emitter.events_head < 2 { - return false - } - - return (emitter.events[emitter.events_head].event_type == yaml_SEQUENCE_START_EVENT && - emitter.events[emitter.events_head+1].event_type == yaml_SEQUENCE_END_EVENT) -} - -/* - * Check if the next events represent an empty mapping. - */ - -func yaml_emitter_check_empty_mapping(emitter *yaml_emitter_t) bool { - if len(emitter.events)-emitter.events_head < 2 { - return false - } - - return (emitter.events[emitter.events_head].event_type == yaml_MAPPING_START_EVENT && - emitter.events[emitter.events_head+1].event_type == yaml_MAPPING_END_EVENT) -} - -/* - * Check if the next node can be expressed as a simple key. - */ - -func yaml_emitter_check_simple_key(emitter *yaml_emitter_t) bool { - length := 0 - - switch emitter.events[emitter.events_head].event_type { - case yaml_ALIAS_EVENT: - length += len(emitter.anchor_data.anchor) - - case yaml_SCALAR_EVENT: - if emitter.scalar_data.multiline { - return false - } - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) + - len(emitter.scalar_data.value) - - case yaml_SEQUENCE_START_EVENT: - if !yaml_emitter_check_empty_sequence(emitter) { - return false - } - - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) - - case yaml_MAPPING_START_EVENT: - if !yaml_emitter_check_empty_mapping(emitter) { - return false - } - - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) - - default: - return false - } - - if length > 128 { - return false - } - - return true -} - -/* - * Determine an acceptable scalar style. - */ - -func yaml_emitter_select_scalar_style(emitter *yaml_emitter_t, event *yaml_event_t) bool { - no_tag := len(emitter.tag_data.handle) == 0 && len(emitter.tag_data.suffix) == 0 - - if no_tag && !event.implicit && !event.quoted_implicit { - return yaml_emitter_set_emitter_error(emitter, - "neither tag nor implicit flags are specified") - } - - style := yaml_scalar_style_t(event.style) - - if style == yaml_ANY_SCALAR_STYLE { - style = yaml_PLAIN_SCALAR_STYLE - } - - if emitter.canonical { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - - if emitter.simple_key_context && emitter.scalar_data.multiline { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - - if style == yaml_PLAIN_SCALAR_STYLE { - if (emitter.flow_level > 0 && !emitter.scalar_data.flow_plain_allowed) || - (emitter.flow_level == 0 && !emitter.scalar_data.block_plain_allowed) { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - if len(emitter.scalar_data.value) == 0 && - (emitter.flow_level > 0 || emitter.simple_key_context) { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - if no_tag && !event.implicit { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - } - - if style == yaml_SINGLE_QUOTED_SCALAR_STYLE { - if !emitter.scalar_data.single_quoted_allowed { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - } - - if style == yaml_LITERAL_SCALAR_STYLE || style == yaml_FOLDED_SCALAR_STYLE { - if !emitter.scalar_data.block_allowed || - emitter.flow_level > 0 || emitter.simple_key_context { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - } - - if no_tag && !event.quoted_implicit && - style != yaml_PLAIN_SCALAR_STYLE { - emitter.tag_data.handle = []byte("!") - } - - emitter.scalar_data.style = style - - return true -} - -/* - * Write an achor. - */ - -func yaml_emitter_process_anchor(emitter *yaml_emitter_t) bool { - if emitter.anchor_data.anchor == nil { - return true - } - - indicator := "*" - if !emitter.anchor_data.alias { - indicator = "&" - } - if !yaml_emitter_write_indicator(emitter, []byte(indicator), true, false, false) { - return false - } - - return yaml_emitter_write_anchor(emitter, emitter.anchor_data.anchor) -} - -/* - * Write a tag. - */ - -func yaml_emitter_process_tag(emitter *yaml_emitter_t) bool { - if len(emitter.tag_data.handle) == 0 && len(emitter.tag_data.suffix) == 0 { - return true - } - - if len(emitter.tag_data.handle) > 0 { - if !yaml_emitter_write_tag_handle(emitter, emitter.tag_data.handle) { - return false - } - - if len(emitter.tag_data.suffix) > 0 { - if !yaml_emitter_write_tag_content(emitter, emitter.tag_data.suffix, false) { - return false - } - - } - } else { - if !yaml_emitter_write_indicator(emitter, []byte("!<"), true, false, false) { - return false - } - - if !yaml_emitter_write_tag_content(emitter, emitter.tag_data.suffix, false) { - return false - } - - if !yaml_emitter_write_indicator(emitter, []byte(">"), false, false, false) { - return false - } - - } - - return true -} - -/* - * Write a scalar. - */ - -func yaml_emitter_process_scalar(emitter *yaml_emitter_t) bool { - switch emitter.scalar_data.style { - case yaml_PLAIN_SCALAR_STYLE: - return yaml_emitter_write_plain_scalar(emitter, - emitter.scalar_data.value, - !emitter.simple_key_context) - - case yaml_SINGLE_QUOTED_SCALAR_STYLE: - return yaml_emitter_write_single_quoted_scalar(emitter, - emitter.scalar_data.value, - !emitter.simple_key_context) - - case yaml_DOUBLE_QUOTED_SCALAR_STYLE: - return yaml_emitter_write_double_quoted_scalar(emitter, - emitter.scalar_data.value, - !emitter.simple_key_context) - - case yaml_LITERAL_SCALAR_STYLE: - return yaml_emitter_write_literal_scalar(emitter, - emitter.scalar_data.value) - - case yaml_FOLDED_SCALAR_STYLE: - return yaml_emitter_write_folded_scalar(emitter, - emitter.scalar_data.value) - - default: - panic("unknown scalar") - } - - return false -} - -/* - * Check if a %YAML directive is valid. - */ - -func yaml_emitter_analyze_version_directive(emitter *yaml_emitter_t, - version_directive yaml_version_directive_t) bool { - if version_directive.major != 1 || version_directive.minor != 1 { - return yaml_emitter_set_emitter_error(emitter, - "incompatible %YAML directive") - } - - return true -} - -/* - * Check if a %TAG directive is valid. - */ - -func yaml_emitter_analyze_tag_directive(emitter *yaml_emitter_t, - tag_directive *yaml_tag_directive_t) bool { - handle := tag_directive.handle - prefix := tag_directive.prefix - - if len(handle) == 0 { - return yaml_emitter_set_emitter_error(emitter, - "tag handle must not be empty") - } - - if handle[0] != '!' { - return yaml_emitter_set_emitter_error(emitter, - "tag handle must start with '!'") - } - - if handle[len(handle)-1] != '!' { - return yaml_emitter_set_emitter_error(emitter, - "tag handle must end with '!'") - } - - for i := 1; i < len(handle)-1; width(handle[i]) { - if !is_alpha(handle[i]) { - return yaml_emitter_set_emitter_error(emitter, - "tag handle must contain alphanumerical characters only") - } - } - - if len(prefix) == 0 { - return yaml_emitter_set_emitter_error(emitter, - "tag prefix must not be empty") - } - - return true -} - -/* - * Check if an anchor is valid. - */ - -func yaml_emitter_analyze_anchor(emitter *yaml_emitter_t, - anchor []byte, alias bool) bool { - if len(anchor) == 0 { - errmsg := "alias value must not be empty" - if !alias { - errmsg = "anchor value must not be empty" - } - return yaml_emitter_set_emitter_error(emitter, errmsg) - } - - for i := 0; i < len(anchor); i += width(anchor[i]) { - if !is_alpha(anchor[i]) { - errmsg := "alias value must contain alphanumerical characters only" - if !alias { - errmsg = "anchor value must contain alphanumerical characters only" - } - return yaml_emitter_set_emitter_error(emitter, errmsg) - } - } - - emitter.anchor_data.anchor = anchor - emitter.anchor_data.alias = alias - - return true -} - -/* - * Check if a tag is valid. - */ - -func yaml_emitter_analyze_tag(emitter *yaml_emitter_t, tag []byte) bool { - if len(tag) == 0 { - return yaml_emitter_set_emitter_error(emitter, - "tag value must not be empty") - } - - for i := range emitter.tag_directives { - tag_directive := &emitter.tag_directives[i] - if bytes.HasPrefix(tag, tag_directive.prefix) { - emitter.tag_data.handle = tag_directive.handle - emitter.tag_data.suffix = tag[len(tag_directive.prefix):] - return true - } - } - - emitter.tag_data.suffix = tag - - return true -} - -/* - * Check if a scalar is valid. - */ - -func yaml_emitter_analyze_scalar(emitter *yaml_emitter_t, value []byte) bool { - block_indicators := false - flow_indicators := false - line_breaks := false - special_characters := false - - leading_space := false - leading_break := false - trailing_space := false - trailing_break := false - break_space := false - space_break := false - - preceeded_by_whitespace := false - followed_by_whitespace := false - previous_space := false - previous_break := false - - emitter.scalar_data.value = value - - if len(value) == 0 { - emitter.scalar_data.multiline = false - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = true - emitter.scalar_data.single_quoted_allowed = true - emitter.scalar_data.block_allowed = false - - return true - } - - if len(value) >= 3 && ((value[0] == '-' && value[1] == '-' && value[2] == '-') || - (value[0] == '.' && value[1] == '.' && value[2] == '.')) { - block_indicators = true - flow_indicators = true - } - - preceeded_by_whitespace = true - - for i, w := 0, 0; i < len(value); i += w { - w = width(value[i]) - followed_by_whitespace = i+w >= len(value) || is_blankz_at(value, i+w) - - if i == 0 { - switch value[i] { - case '#', ',', '[', ']', '{', '}', '&', '*', '!', '|', '>', '\'', '"', '%', '@', '`': - flow_indicators = true - block_indicators = true - case '?', ':': - flow_indicators = true - if followed_by_whitespace { - block_indicators = true - } - case '-': - if followed_by_whitespace { - flow_indicators = true - block_indicators = true - } - } - } else { - switch value[i] { - case ',', '?', '[', ']', '{', '}': - flow_indicators = true - case ':': - flow_indicators = true - if followed_by_whitespace { - block_indicators = true - } - case '#': - if preceeded_by_whitespace { - flow_indicators = true - block_indicators = true - } - } - } - - if !is_printable_at(value, i) || (!is_ascii(value[i]) && !emitter.unicode) { - special_characters = true - } - - if is_break_at(value, i) { - line_breaks = true - } - - if is_space(value[i]) { - if i == 0 { - leading_space = true - } - if i+w == len(value) { - trailing_space = true - } - if previous_break { - break_space = true - } - previous_space = true - previous_break = false - } else if is_break_at(value, i) { - if i == 0 { - leading_break = true - } - if i+width(value[i]) == len(value) { - trailing_break = true - } - if previous_space { - space_break = true - } - previous_space = false - previous_break = true - } else { - previous_space = false - previous_break = false - } - - preceeded_by_whitespace = is_blankz_at(value, i) - } - - emitter.scalar_data.multiline = line_breaks - - emitter.scalar_data.flow_plain_allowed = true - emitter.scalar_data.block_plain_allowed = true - emitter.scalar_data.single_quoted_allowed = true - emitter.scalar_data.block_allowed = true - - if leading_space || leading_break || trailing_space || trailing_break { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - } - - if trailing_space { - emitter.scalar_data.block_allowed = false - } - - if break_space { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - emitter.scalar_data.single_quoted_allowed = false - } - - if space_break || special_characters { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - emitter.scalar_data.single_quoted_allowed = false - emitter.scalar_data.block_allowed = false - } - - if line_breaks { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - } - - if flow_indicators { - emitter.scalar_data.flow_plain_allowed = false - } - - if block_indicators { - emitter.scalar_data.block_plain_allowed = false - } - - return true -} - -/* - * Check if the event data is valid. - */ - -func yaml_emitter_analyze_event(emitter *yaml_emitter_t, event *yaml_event_t) bool { - emitter.anchor_data.anchor = nil - emitter.tag_data.handle = nil - emitter.tag_data.suffix = nil - emitter.scalar_data.value = nil - - switch event.event_type { - case yaml_ALIAS_EVENT: - if !yaml_emitter_analyze_anchor(emitter, - event.anchor, true) { - return false - } - - case yaml_SCALAR_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, - event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || - (!event.implicit && - !event.quoted_implicit)) { - if !yaml_emitter_analyze_tag(emitter, event.tag) { - return false - } - } - if !yaml_emitter_analyze_scalar(emitter, event.value) { - return false - } - case yaml_SEQUENCE_START_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, - event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || - !event.implicit) { - if !yaml_emitter_analyze_tag(emitter, - event.tag) { - return false - } - } - case yaml_MAPPING_START_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, - event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || - !event.implicit) { - if !yaml_emitter_analyze_tag(emitter, - event.tag) { - return false - } - } - - } - return true -} - -/* - * Write the BOM character. - */ - -func yaml_emitter_write_bom(emitter *yaml_emitter_t) bool { - if !flush(emitter) { - return false - } - - pos := emitter.buffer_pos - emitter.buffer[pos] = '\xEF' - emitter.buffer[pos+1] = '\xBB' - emitter.buffer[pos+2] = '\xBF' - emitter.buffer_pos += 3 - return true -} - -func yaml_emitter_write_indent(emitter *yaml_emitter_t) bool { - indent := emitter.indent - if indent < 0 { - indent = 0 - } - - if !emitter.indention || emitter.column > indent || - (emitter.column == indent && !emitter.whitespace) { - if !put_break(emitter) { - return false - } - } - - for emitter.column < indent { - if !put(emitter, ' ') { - return false - } - } - - emitter.whitespace = true - emitter.indention = true - - return true -} - -func yaml_emitter_write_indicator(emitter *yaml_emitter_t, - indicator []byte, need_whitespace bool, - is_whitespace bool, is_indention bool) bool { - if need_whitespace && !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - - ind_pos := 0 - for ind_pos < len(indicator) { - if !write(emitter, indicator, &ind_pos) { - return false - } - } - - emitter.whitespace = is_whitespace - emitter.indention = (emitter.indention && is_indention) - emitter.open_ended = false - - return true -} - -func yaml_emitter_write_anchor(emitter *yaml_emitter_t, value []byte) bool { - pos := 0 - for pos < len(value) { - if !write(emitter, value, &pos) { - return false - } - } - - emitter.whitespace = false - emitter.indention = false - - return true -} - -func yaml_emitter_write_tag_handle(emitter *yaml_emitter_t, value []byte) bool { - if !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - - pos := 0 - for pos < len(value) { - if !write(emitter, value, &pos) { - return false - } - } - - emitter.whitespace = false - emitter.indention = false - - return true -} - -func yaml_emitter_write_tag_content(emitter *yaml_emitter_t, value []byte, - need_whitespace bool) bool { - if need_whitespace && !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - - for i := 0; i < len(value); { - write_it := false - switch value[i] { - case ';', '/', '?', ':', '@', '&', '=', '+', '$', ',', '_', - '.', '!', '~', '*', '\'', '(', ')', '[', ']': - write_it = true - default: - write_it = is_alpha(value[i]) - } - if write_it { - if !write(emitter, value, &i) { - return false - } - } else { - w := width(value[i]) - for j := 0; j < w; j++ { - val := value[i] - i++ - - if !put(emitter, '%') { - return false - } - c := val >> 4 - if c < 10 { - c += '0' - } else { - c += 'A' - 10 - } - if !put(emitter, c) { - return false - } - - c = val & 0x0f - if c < 10 { - c += '0' - } else { - c += 'A' - 10 - } - if !put(emitter, c) { - return false - } - - } - } - } - - emitter.whitespace = false - emitter.indention = false - - return true -} - -func yaml_emitter_write_plain_scalar(emitter *yaml_emitter_t, value []byte, - allow_breaks bool) bool { - spaces := false - breaks := false - - if !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - - for i := 0; i < len(value); { - if is_space(value[i]) { - if allow_breaks && !spaces && - emitter.column > emitter.best_width && - !is_space(value[i+1]) { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - spaces = true - } else if is_break_at(value, i) { - if !breaks && value[i] == '\n' { - if !put_break(emitter) { - return false - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - spaces = false - breaks = false - } - } - - emitter.whitespace = false - emitter.indention = false - if emitter.root_context { - emitter.open_ended = true - } - - return true -} - -func yaml_emitter_write_single_quoted_scalar(emitter *yaml_emitter_t, value []byte, - allow_breaks bool) bool { - spaces := false - breaks := false - - if !yaml_emitter_write_indicator(emitter, []byte("'"), true, false, false) { - return false - } - - for i := 0; i < len(value); { - if is_space(value[i]) { - if allow_breaks && !spaces && - emitter.column > emitter.best_width && - i > 0 && i < len(value)-1 && - !is_space(value[i+1]) { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - spaces = true - } else if is_break_at(value, i) { - if !breaks && value[i] == '\n' { - if !put_break(emitter) { - return false - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if value[i] == '\'' { - if !put(emitter, '\'') { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - spaces = false - breaks = false - } - } - - if !yaml_emitter_write_indicator(emitter, []byte("'"), false, false, false) { - return false - } - - emitter.whitespace = false - emitter.indention = false - - return true -} - -func yaml_emitter_write_double_quoted_scalar(emitter *yaml_emitter_t, value []byte, - allow_breaks bool) bool { - - spaces := false - - if !yaml_emitter_write_indicator(emitter, []byte("\""), true, false, false) { - return false - } - - for i := 0; i < len(value); { - if !is_printable_at(value, i) || (!emitter.unicode && !is_ascii(value[i])) || - is_bom_at(value, i) || is_break_at(value, i) || - value[i] == '"' || value[i] == '\\' { - octet := value[i] - - var w int - var v rune - switch { - case octet&0x80 == 0x00: - w, v = 1, rune(octet&0x7F) - case octet&0xE0 == 0xC0: - w, v = 2, rune(octet&0x1F) - case octet&0xF0 == 0xE0: - w, v = 3, rune(octet&0x0F) - case octet&0xF8 == 0xF0: - w, v = 4, rune(octet&0x07) - } - - for k := 1; k < w; k++ { - octet = value[i+k] - v = (v << 6) + (rune(octet) & 0x3F) - } - i += w - - if !put(emitter, '\\') { - return false - } - - switch v { - case 0x00: - if !put(emitter, '0') { - return false - } - case 0x07: - if !put(emitter, 'a') { - return false - } - case 0x08: - if !put(emitter, 'b') { - return false - } - case 0x09: - if !put(emitter, 't') { - return false - } - - case 0x0A: - if !put(emitter, 'n') { - return false - } - - case 0x0B: - if !put(emitter, 'v') { - return false - } - - case 0x0C: - if !put(emitter, 'f') { - return false - } - - case 0x0D: - if !put(emitter, 'r') { - return false - } - - case 0x1B: - if !put(emitter, 'e') { - return false - } - case 0x22: - if !put(emitter, '"') { - return false - } - case 0x5C: - if !put(emitter, '\\') { - return false - } - case 0x85: - if !put(emitter, 'N') { - return false - } - - case 0xA0: - if !put(emitter, '_') { - return false - } - - case 0x2028: - if !put(emitter, 'L') { - return false - } - - case 0x2029: - if !put(emitter, 'P') { - return false - } - default: - if v <= 0xFF { - if !put(emitter, 'x') { - return false - } - w = 2 - } else if v <= 0xFFFF { - if !put(emitter, 'u') { - return false - } - w = 4 - } else { - if !put(emitter, 'U') { - return false - } - w = 8 - } - for k := (w - 1) * 4; k >= 0; k -= 4 { - digit := byte((v >> uint(k)) & 0x0F) - c := digit + '0' - if c > 9 { - c = digit + 'A' - 10 - } - if !put(emitter, c) { - return false - } - } - } - spaces = false - } else if is_space(value[i]) { - if allow_breaks && !spaces && - emitter.column > emitter.best_width && - i > 0 && i < len(value)-1 { - if !yaml_emitter_write_indent(emitter) { - return false - } - if is_space(value[i+1]) { - if !put(emitter, '\\') { - return false - } - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - spaces = true - } else { - if !write(emitter, value, &i) { - return false - } - spaces = false - } - } - - if !yaml_emitter_write_indicator(emitter, []byte("\""), false, false, false) { - return false - } - - emitter.whitespace = false - emitter.indention = false - - return true -} - -func yaml_emitter_write_block_scalar_hints(emitter *yaml_emitter_t, value []byte) bool { - - if is_space(value[0]) || is_break_at(value, 0) { - indent_hint := []byte{'0' + byte(emitter.best_indent)} - if !yaml_emitter_write_indicator(emitter, indent_hint, false, false, false) { - return false - } - } - - emitter.open_ended = false - - var chomp_hint [1]byte - if len(value) == 0 { - chomp_hint[0] = '-' - } else { - i := len(value) - 1 - for value[i]&0xC0 == 0x80 { - i-- - } - - if !is_break_at(value, i) { - chomp_hint[0] = '-' - } else if i == 0 { - chomp_hint[0] = '+' - emitter.open_ended = true - } else { - for value[i]&0xC0 == 0x80 { - i-- - } - - if is_break_at(value, i) { - chomp_hint[0] = '+' - emitter.open_ended = true - } - } - } - - if chomp_hint[0] != 0 { - if !yaml_emitter_write_indicator(emitter, chomp_hint[:], false, false, false) { - return false - } - } - - return true -} - -func yaml_emitter_write_literal_scalar(emitter *yaml_emitter_t, value []byte) bool { - - breaks := true - - if !yaml_emitter_write_indicator(emitter, []byte("|"), true, false, false) { - return false - } - - if !yaml_emitter_write_block_scalar_hints(emitter, value) { - return false - } - - if !put_break(emitter) { - return false - } - - emitter.indention = true - emitter.whitespace = true - - for i := 0; i < len(value); { - if is_break_at(value, i) { - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - breaks = false - } - } - - return true -} - -func yaml_emitter_write_folded_scalar(emitter *yaml_emitter_t, value []byte) bool { - breaks := true - leading_spaces := true - - if !yaml_emitter_write_indicator(emitter, []byte(">"), true, false, false) { - return false - } - if !yaml_emitter_write_block_scalar_hints(emitter, value) { - return false - } - if !put_break(emitter) { - return false - } - emitter.indention = true - emitter.whitespace = true - - for i := 0; i < len(value); { - if is_break_at(value, i) { - if !breaks && !leading_spaces && value[i] == '\n' { - k := i - for is_break_at(value, k) { - k += width(value[k]) - } - if !is_blankz_at(value, k) { - if !put_break(emitter) { - return false - } - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - leading_spaces = is_blank(value[i]) - } - if !breaks && is_space(value[i]) && !is_space(value[i+1]) && - emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - emitter.indention = false - breaks = false - } - } - - return true -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go deleted file mode 100644 index fd99180..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/encode.go +++ /dev/null @@ -1,395 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" - "encoding/base64" - "io" - "math" - "reflect" - "regexp" - "sort" - "strconv" - "time" -) - -var ( - timeTimeType = reflect.TypeOf(time.Time{}) - marshalerType = reflect.TypeOf(new(Marshaler)).Elem() - numberType = reflect.TypeOf(Number("")) - nonPrintable = regexp.MustCompile("[^\t\n\r\u0020-\u007E\u0085\u00A0-\uD7FF\uE000-\uFFFD]") - multiline = regexp.MustCompile("\n|\u0085|\u2028|\u2029") - - shortTags = map[string]string{ - yaml_NULL_TAG: "!!null", - yaml_BOOL_TAG: "!!bool", - yaml_STR_TAG: "!!str", - yaml_INT_TAG: "!!int", - yaml_FLOAT_TAG: "!!float", - yaml_TIMESTAMP_TAG: "!!timestamp", - yaml_SEQ_TAG: "!!seq", - yaml_MAP_TAG: "!!map", - yaml_BINARY_TAG: "!!binary", - } -) - -type Marshaler interface { - MarshalYAML() (tag string, value interface{}, err error) -} - -// An Encoder writes JSON objects to an output stream. -type Encoder struct { - w io.Writer - emitter yaml_emitter_t - event yaml_event_t - flow bool - err error -} - -func Marshal(v interface{}) ([]byte, error) { - b := bytes.Buffer{} - e := NewEncoder(&b) - err := e.Encode(v) - return b.Bytes(), err -} - -// NewEncoder returns a new encoder that writes to w. -func NewEncoder(w io.Writer) *Encoder { - e := &Encoder{w: w} - yaml_emitter_initialize(&e.emitter) - yaml_emitter_set_output_writer(&e.emitter, e.w) - yaml_stream_start_event_initialize(&e.event, yaml_UTF8_ENCODING) - e.emit() - yaml_document_start_event_initialize(&e.event, nil, nil, true) - e.emit() - - return e -} - -func (e *Encoder) Encode(v interface{}) (err error) { - defer recovery(&err) - - if e.err != nil { - return e.err - } - - e.marshal("", reflect.ValueOf(v), true) - - yaml_document_end_event_initialize(&e.event, true) - e.emit() - e.emitter.open_ended = false - yaml_stream_end_event_initialize(&e.event) - e.emit() - - return nil -} - -func (e *Encoder) emit() { - if !yaml_emitter_emit(&e.emitter, &e.event) { - panic("bad emit") - } -} - -func (e *Encoder) marshal(tag string, v reflect.Value, allowAddr bool) { - vt := v.Type() - - if vt.Implements(marshalerType) { - e.emitMarshaler(tag, v) - return - } - - if vt.Kind() != reflect.Ptr && allowAddr { - if reflect.PtrTo(vt).Implements(marshalerType) { - e.emitAddrMarshaler(tag, v) - return - } - } - - switch v.Kind() { - case reflect.Interface: - if v.IsNil() { - e.emitNil() - } else { - e.marshal(tag, v.Elem(), allowAddr) - } - case reflect.Map: - e.emitMap(tag, v) - case reflect.Ptr: - if v.IsNil() { - e.emitNil() - } else { - e.marshal(tag, v.Elem(), true) - } - case reflect.Struct: - e.emitStruct(tag, v) - case reflect.Slice: - e.emitSlice(tag, v) - case reflect.String: - e.emitString(tag, v) - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - e.emitInt(tag, v) - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - e.emitUint(tag, v) - case reflect.Float32, reflect.Float64: - e.emitFloat(tag, v) - case reflect.Bool: - e.emitBool(tag, v) - default: - panic("Can't marshal type yet: " + v.Type().String()) - } -} - -func (e *Encoder) emitMap(tag string, v reflect.Value) { - e.mapping(tag, func() { - var keys stringValues = v.MapKeys() - sort.Sort(keys) - for _, k := range keys { - e.marshal("", k, true) - e.marshal("", v.MapIndex(k), true) - } - }) -} - -func (e *Encoder) emitStruct(tag string, v reflect.Value) { - if v.Type() == timeTimeType { - e.emitTime(tag, v) - return - } - - fields := cachedTypeFields(v.Type()) - - e.mapping(tag, func() { - for _, f := range fields { - fv := fieldByIndex(v, f.index) - if !fv.IsValid() || f.omitEmpty && isEmptyValue(fv) { - continue - } - - e.marshal("", reflect.ValueOf(f.name), true) - e.flow = f.flow - e.marshal("", fv, true) - } - }) -} - -func (e *Encoder) emitTime(tag string, v reflect.Value) { - t := v.Interface().(time.Time) - bytes, _ := t.MarshalText() - e.emitScalar(string(bytes), "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func isEmptyValue(v reflect.Value) bool { - switch v.Kind() { - case reflect.Array, reflect.Map, reflect.Slice, reflect.String: - return v.Len() == 0 - case reflect.Bool: - return !v.Bool() - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return v.Uint() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.Interface, reflect.Ptr: - return v.IsNil() - } - return false -} - -func (e *Encoder) mapping(tag string, f func()) { - implicit := tag == "" - style := yaml_BLOCK_MAPPING_STYLE - if e.flow { - e.flow = false - style = yaml_FLOW_MAPPING_STYLE - } - yaml_mapping_start_event_initialize(&e.event, nil, []byte(tag), implicit, style) - e.emit() - - f() - - yaml_mapping_end_event_initialize(&e.event) - e.emit() -} - -func (e *Encoder) emitSlice(tag string, v reflect.Value) { - if v.Type() == byteSliceType { - e.emitBase64(tag, v) - return - } - - implicit := tag == "" - style := yaml_BLOCK_SEQUENCE_STYLE - if e.flow { - e.flow = false - style = yaml_FLOW_SEQUENCE_STYLE - } - yaml_sequence_start_event_initialize(&e.event, nil, []byte(tag), implicit, style) - e.emit() - - n := v.Len() - for i := 0; i < n; i++ { - e.marshal("", v.Index(i), true) - } - - yaml_sequence_end_event_initialize(&e.event) - e.emit() -} - -func (e *Encoder) emitBase64(tag string, v reflect.Value) { - if v.IsNil() { - e.emitNil() - return - } - - s := v.Bytes() - - dst := make([]byte, base64.StdEncoding.EncodedLen(len(s))) - - base64.StdEncoding.Encode(dst, s) - e.emitScalar(string(dst), "", yaml_BINARY_TAG, yaml_DOUBLE_QUOTED_SCALAR_STYLE) -} - -func (e *Encoder) emitString(tag string, v reflect.Value) { - var style yaml_scalar_style_t - s := v.String() - - if nonPrintable.MatchString(s) { - e.emitBase64(tag, v) - return - } - - if v.Type() == numberType { - style = yaml_PLAIN_SCALAR_STYLE - } else { - event := yaml_event_t{ - implicit: true, - value: []byte(s), - } - - rtag, _ := resolveInterface(event, false) - if tag == "" && rtag != yaml_STR_TAG { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } else if multiline.MatchString(s) { - style = yaml_LITERAL_SCALAR_STYLE - } else { - style = yaml_PLAIN_SCALAR_STYLE - } - } - - e.emitScalar(s, "", tag, style) -} - -func (e *Encoder) emitBool(tag string, v reflect.Value) { - s := strconv.FormatBool(v.Bool()) - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *Encoder) emitInt(tag string, v reflect.Value) { - s := strconv.FormatInt(v.Int(), 10) - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *Encoder) emitUint(tag string, v reflect.Value) { - s := strconv.FormatUint(v.Uint(), 10) - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *Encoder) emitFloat(tag string, v reflect.Value) { - f := v.Float() - - var s string - switch { - case math.IsNaN(f): - s = ".nan" - case math.IsInf(f, 1): - s = "+.inf" - case math.IsInf(f, -1): - s = "-.inf" - default: - s = strconv.FormatFloat(f, 'g', -1, v.Type().Bits()) - } - - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *Encoder) emitNil() { - e.emitScalar("null", "", "", yaml_PLAIN_SCALAR_STYLE) -} - -func (e *Encoder) emitScalar(value, anchor, tag string, style yaml_scalar_style_t) { - implicit := tag == "" - if !implicit { - style = yaml_PLAIN_SCALAR_STYLE - } - - stag := shortTags[tag] - if stag == "" { - stag = tag - } - - yaml_scalar_event_initialize(&e.event, []byte(anchor), []byte(stag), []byte(value), implicit, implicit, style) - e.emit() -} - -func (e *Encoder) emitMarshaler(tag string, v reflect.Value) { - if v.Kind() == reflect.Ptr && v.IsNil() { - e.emitNil() - return - } - - m := v.Interface().(Marshaler) - if m == nil { - e.emitNil() - return - } - t, val, err := m.MarshalYAML() - if err != nil { - panic(err) - } - if val == nil { - e.emitNil() - return - } - - e.marshal(t, reflect.ValueOf(val), false) -} - -func (e *Encoder) emitAddrMarshaler(tag string, v reflect.Value) { - if !v.CanAddr() { - e.marshal(tag, v, false) - return - } - - va := v.Addr() - if va.IsNil() { - e.emitNil() - return - } - - m := v.Interface().(Marshaler) - t, val, err := m.MarshalYAML() - if err != nil { - panic(err) - } - - if val == nil { - e.emitNil() - return - } - - e.marshal(t, reflect.ValueOf(val), false) -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/libyaml-LICENSE b/vendor/github.com/cloudfoundry-incubator/candiedyaml/libyaml-LICENSE deleted file mode 100644 index 050ced2..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/libyaml-LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2006 Kirill Simonov - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go deleted file mode 100644 index 8d38e30..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/parser.go +++ /dev/null @@ -1,1230 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" -) - -/* - * The parser implements the following grammar: - * - * stream ::= STREAM-START implicit_document? explicit_document* STREAM-END - * implicit_document ::= block_node DOCUMENT-END* - * explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* - * block_node_or_indentless_sequence ::= - * ALIAS - * | properties (block_content | indentless_block_sequence)? - * | block_content - * | indentless_block_sequence - * block_node ::= ALIAS - * | properties block_content? - * | block_content - * flow_node ::= ALIAS - * | properties flow_content? - * | flow_content - * properties ::= TAG ANCHOR? | ANCHOR TAG? - * block_content ::= block_collection | flow_collection | SCALAR - * flow_content ::= flow_collection | SCALAR - * block_collection ::= block_sequence | block_mapping - * flow_collection ::= flow_sequence | flow_mapping - * block_sequence ::= BLOCK-SEQUENCE-START (BLOCK-ENTRY block_node?)* BLOCK-END - * indentless_sequence ::= (BLOCK-ENTRY block_node?)+ - * block_mapping ::= BLOCK-MAPPING_START - * ((KEY block_node_or_indentless_sequence?)? - * (VALUE block_node_or_indentless_sequence?)?)* - * BLOCK-END - * flow_sequence ::= FLOW-SEQUENCE-START - * (flow_sequence_entry FLOW-ENTRY)* - * flow_sequence_entry? - * FLOW-SEQUENCE-END - * flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * flow_mapping ::= FLOW-MAPPING-START - * (flow_mapping_entry FLOW-ENTRY)* - * flow_mapping_entry? - * FLOW-MAPPING-END - * flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - */ - -/* - * Peek the next token in the token queue. - */ -func peek_token(parser *yaml_parser_t) *yaml_token_t { - if parser.token_available || yaml_parser_fetch_more_tokens(parser) { - return &parser.tokens[parser.tokens_head] - } - return nil -} - -/* - * Remove the next token from the queue (must be called after peek_token). - */ -func skip_token(parser *yaml_parser_t) { - parser.token_available = false - parser.tokens_parsed++ - parser.stream_end_produced = parser.tokens[parser.tokens_head].token_type == yaml_STREAM_END_TOKEN - parser.tokens_head++ -} - -/* - * Get the next event. - */ - -func yaml_parser_parse(parser *yaml_parser_t, event *yaml_event_t) bool { - /* Erase the event object. */ - *event = yaml_event_t{} - - /* No events after the end of the stream or error. */ - - if parser.stream_end_produced || parser.error != yaml_NO_ERROR || - parser.state == yaml_PARSE_END_STATE { - return true - } - - /* Generate the next event. */ - - return yaml_parser_state_machine(parser, event) -} - -/* - * Set parser error. - */ - -func yaml_parser_set_parser_error(parser *yaml_parser_t, - problem string, problem_mark YAML_mark_t) bool { - parser.error = yaml_PARSER_ERROR - parser.problem = problem - parser.problem_mark = problem_mark - - return false -} - -func yaml_parser_set_parser_error_context(parser *yaml_parser_t, - context string, context_mark YAML_mark_t, - problem string, problem_mark YAML_mark_t) bool { - parser.error = yaml_PARSER_ERROR - parser.context = context - parser.context_mark = context_mark - parser.problem = problem - parser.problem_mark = problem_mark - - return false -} - -/* - * State dispatcher. - */ - -func yaml_parser_state_machine(parser *yaml_parser_t, event *yaml_event_t) bool { - switch parser.state { - case yaml_PARSE_STREAM_START_STATE: - return yaml_parser_parse_stream_start(parser, event) - - case yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE: - return yaml_parser_parse_document_start(parser, event, true) - - case yaml_PARSE_DOCUMENT_START_STATE: - return yaml_parser_parse_document_start(parser, event, false) - - case yaml_PARSE_DOCUMENT_CONTENT_STATE: - return yaml_parser_parse_document_content(parser, event) - - case yaml_PARSE_DOCUMENT_END_STATE: - return yaml_parser_parse_document_end(parser, event) - - case yaml_PARSE_BLOCK_NODE_STATE: - return yaml_parser_parse_node(parser, event, true, false) - - case yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE: - return yaml_parser_parse_node(parser, event, true, true) - - case yaml_PARSE_FLOW_NODE_STATE: - return yaml_parser_parse_node(parser, event, false, false) - - case yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE: - return yaml_parser_parse_block_sequence_entry(parser, event, true) - - case yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_block_sequence_entry(parser, event, false) - - case yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_indentless_sequence_entry(parser, event) - - case yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE: - return yaml_parser_parse_block_mapping_key(parser, event, true) - - case yaml_PARSE_BLOCK_MAPPING_KEY_STATE: - return yaml_parser_parse_block_mapping_key(parser, event, false) - - case yaml_PARSE_BLOCK_MAPPING_VALUE_STATE: - return yaml_parser_parse_block_mapping_value(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE: - return yaml_parser_parse_flow_sequence_entry(parser, event, true) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_flow_sequence_entry(parser, event, false) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_key(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_value(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_end(parser, event) - - case yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE: - return yaml_parser_parse_flow_mapping_key(parser, event, true) - - case yaml_PARSE_FLOW_MAPPING_KEY_STATE: - return yaml_parser_parse_flow_mapping_key(parser, event, false) - - case yaml_PARSE_FLOW_MAPPING_VALUE_STATE: - return yaml_parser_parse_flow_mapping_value(parser, event, false) - - case yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE: - return yaml_parser_parse_flow_mapping_value(parser, event, true) - } - - panic("invalid parser state") -} - -/* - * Parse the production: - * stream ::= STREAM-START implicit_document? explicit_document* STREAM-END - * ************ - */ - -func yaml_parser_parse_stream_start(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type != yaml_STREAM_START_TOKEN { - return yaml_parser_set_parser_error(parser, - "did not find expected ", token.start_mark) - } - - parser.state = yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE - *event = yaml_event_t{ - event_type: yaml_STREAM_START_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - encoding: token.encoding, - } - skip_token(parser) - - return true -} - -/* - * Parse the productions: - * implicit_document ::= block_node DOCUMENT-END* - * * - * explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* - * ************************* - */ - -func yaml_parser_parse_document_start(parser *yaml_parser_t, event *yaml_event_t, - implicit bool) bool { - - token := peek_token(parser) - if token == nil { - return false - } - - /* Parse extra document end indicators. */ - - if !implicit { - for token.token_type == yaml_DOCUMENT_END_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - } - - /* Parse an implicit document. */ - - if implicit && token.token_type != yaml_VERSION_DIRECTIVE_TOKEN && - token.token_type != yaml_TAG_DIRECTIVE_TOKEN && - token.token_type != yaml_DOCUMENT_START_TOKEN && - token.token_type != yaml_STREAM_END_TOKEN { - if !yaml_parser_process_directives(parser, nil, nil) { - return false - } - - parser.states = append(parser.states, yaml_PARSE_DOCUMENT_END_STATE) - parser.state = yaml_PARSE_BLOCK_NODE_STATE - - *event = yaml_event_t{ - event_type: yaml_DOCUMENT_START_EVENT, - implicit: true, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - } else if token.token_type != yaml_STREAM_END_TOKEN { - /* Parse an explicit document. */ - var version_directive *yaml_version_directive_t - var tag_directives []yaml_tag_directive_t - - start_mark := token.start_mark - if !yaml_parser_process_directives(parser, &version_directive, - &tag_directives) { - return false - } - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_DOCUMENT_START_TOKEN { - yaml_parser_set_parser_error(parser, - "did not find expected ", token.start_mark) - return false - } - - parser.states = append(parser.states, yaml_PARSE_DOCUMENT_END_STATE) - parser.state = yaml_PARSE_DOCUMENT_CONTENT_STATE - - end_mark := token.end_mark - - *event = yaml_event_t{ - event_type: yaml_DOCUMENT_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - version_directive: version_directive, - tag_directives: tag_directives, - implicit: false, - } - skip_token(parser) - } else { - /* Parse the stream end. */ - parser.state = yaml_PARSE_END_STATE - - *event = yaml_event_t{ - event_type: yaml_STREAM_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - skip_token(parser) - } - return true -} - -/* - * Parse the productions: - * explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* - * *********** - */ - -func yaml_parser_parse_document_content(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_VERSION_DIRECTIVE_TOKEN || - token.token_type == yaml_TAG_DIRECTIVE_TOKEN || - token.token_type == yaml_DOCUMENT_START_TOKEN || - token.token_type == yaml_DOCUMENT_END_TOKEN || - token.token_type == yaml_STREAM_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - return yaml_parser_process_empty_scalar(parser, event, - token.start_mark) - } else { - return yaml_parser_parse_node(parser, event, true, false) - } -} - -/* - * Parse the productions: - * implicit_document ::= block_node DOCUMENT-END* - * ************* - * explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* - * ************* - */ - -func yaml_parser_parse_document_end(parser *yaml_parser_t, event *yaml_event_t) bool { - implicit := true - - token := peek_token(parser) - if token == nil { - return false - } - - start_mark, end_mark := token.start_mark, token.start_mark - - if token.token_type == yaml_DOCUMENT_END_TOKEN { - end_mark = token.end_mark - skip_token(parser) - implicit = false - } - - parser.tag_directives = parser.tag_directives[:0] - - parser.state = yaml_PARSE_DOCUMENT_START_STATE - *event = yaml_event_t{ - event_type: yaml_DOCUMENT_END_EVENT, - start_mark: start_mark, - end_mark: end_mark, - implicit: implicit, - } - - return true -} - -/* - * Parse the productions: - * block_node_or_indentless_sequence ::= - * ALIAS - * ***** - * | properties (block_content | indentless_block_sequence)? - * ********** * - * | block_content | indentless_block_sequence - * * - * block_node ::= ALIAS - * ***** - * | properties block_content? - * ********** * - * | block_content - * * - * flow_node ::= ALIAS - * ***** - * | properties flow_content? - * ********** * - * | flow_content - * * - * properties ::= TAG ANCHOR? | ANCHOR TAG? - * ************************* - * block_content ::= block_collection | flow_collection | SCALAR - * ****** - * flow_content ::= flow_collection | SCALAR - * ****** - */ - -func yaml_parser_parse_node(parser *yaml_parser_t, event *yaml_event_t, - block bool, indentless_sequence bool) bool { - - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_ALIAS_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - event_type: yaml_ALIAS_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - anchor: token.value, - } - skip_token(parser) - return true - } else { - start_mark, end_mark := token.start_mark, token.start_mark - - var tag_handle []byte - var tag_suffix, anchor []byte - var tag_mark YAML_mark_t - if token.token_type == yaml_ANCHOR_TOKEN { - anchor = token.value - start_mark = token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type == yaml_TAG_TOKEN { - tag_handle = token.value - tag_suffix = token.suffix - tag_mark = token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - } else if token.token_type == yaml_TAG_TOKEN { - tag_handle = token.value - tag_suffix = token.suffix - start_mark, tag_mark = token.start_mark, token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type == yaml_ANCHOR_TOKEN { - anchor = token.value - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - - } - } - - var tag []byte - if tag_handle != nil { - if len(tag_handle) == 0 { - tag = tag_suffix - tag_handle = nil - tag_suffix = nil - } else { - for i := range parser.tag_directives { - tag_directive := &parser.tag_directives[i] - if bytes.Equal(tag_directive.handle, tag_handle) { - tag = append([]byte(nil), tag_directive.prefix...) - tag = append(tag, tag_suffix...) - tag_handle = nil - tag_suffix = nil - break - } - } - if len(tag) == 0 { - yaml_parser_set_parser_error_context(parser, - "while parsing a node", start_mark, - "found undefined tag handle", tag_mark) - return false - } - } - } - - implicit := len(tag) == 0 - if indentless_sequence && token.token_type == yaml_BLOCK_ENTRY_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_SEQUENCE_STYLE), - } - - return true - } else { - if token.token_type == yaml_SCALAR_TOKEN { - plain_implicit := false - quoted_implicit := false - end_mark = token.end_mark - if (token.style == yaml_PLAIN_SCALAR_STYLE && len(tag) == 0) || - (len(tag) == 1 && tag[0] == '!') { - plain_implicit = true - } else if len(tag) == 0 { - quoted_implicit = true - } - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - event_type: yaml_SCALAR_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - value: token.value, - implicit: plain_implicit, - quoted_implicit: quoted_implicit, - style: yaml_style_t(token.style), - } - - skip_token(parser) - return true - } else if token.token_type == yaml_FLOW_SEQUENCE_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_FLOW_SEQUENCE_STYLE), - } - - return true - } else if token.token_type == yaml_FLOW_MAPPING_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE - - *event = yaml_event_t{ - event_type: yaml_MAPPING_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_FLOW_MAPPING_STYLE), - } - - return true - } else if block && token.token_type == yaml_BLOCK_SEQUENCE_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_SEQUENCE_STYLE), - } - - return true - } else if block && token.token_type == yaml_BLOCK_MAPPING_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE - - *event = yaml_event_t{ - event_type: yaml_MAPPING_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_MAPPING_STYLE), - } - return true - } else if len(anchor) > 0 || len(tag) > 0 { - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - event_type: yaml_SCALAR_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - quoted_implicit: false, - style: yaml_style_t(yaml_PLAIN_SCALAR_STYLE), - } - return true - } else { - msg := "while parsing a block node" - if !block { - msg = "while parsing a flow node" - } - yaml_parser_set_parser_error_context(parser, msg, start_mark, - "did not find expected node content", token.start_mark) - return false - } - } - } - - return false -} - -/* - * Parse the productions: - * block_sequence ::= BLOCK-SEQUENCE-START (BLOCK-ENTRY block_node?)* BLOCK-END - * ******************** *********** * ********* - */ - -func yaml_parser_parse_block_sequence_entry(parser *yaml_parser_t, - event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_BLOCK_ENTRY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_BLOCK_ENTRY_TOKEN && - token.token_type != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, true, false) - } else { - parser.state = yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } else if token.token_type == yaml_BLOCK_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - skip_token(parser) - return true - } else { - mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - return yaml_parser_set_parser_error_context(parser, - "while parsing a block collection", mark, - "did not find expected '-' indicator", token.start_mark) - } -} - -/* - * Parse the productions: - * indentless_sequence ::= (BLOCK-ENTRY block_node?)+ - * *********** * - */ - -func yaml_parser_parse_indentless_sequence_entry(parser *yaml_parser_t, - event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_BLOCK_ENTRY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_BLOCK_ENTRY_TOKEN && - token.token_type != yaml_KEY_TOKEN && - token.token_type != yaml_VALUE_TOKEN && - token.token_type != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, true, false) - } else { - parser.state = yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } else { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.start_mark, - } - return true - } -} - -/* - * Parse the productions: - * block_mapping ::= BLOCK-MAPPING_START - * ******************* - * ((KEY block_node_or_indentless_sequence?)? - * *** * - * (VALUE block_node_or_indentless_sequence?)?)* - * - * BLOCK-END - * ********* - */ - -func yaml_parser_parse_block_mapping_key(parser *yaml_parser_t, - event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_KEY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_KEY_TOKEN && - token.token_type != yaml_VALUE_TOKEN && - token.token_type != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, true, true) - } else { - parser.state = yaml_PARSE_BLOCK_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } else if token.token_type == yaml_BLOCK_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - *event = yaml_event_t{ - event_type: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - skip_token(parser) - return true - } else { - mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - return yaml_parser_set_parser_error_context(parser, - "while parsing a block mapping", mark, - "did not find expected key", token.start_mark) - } -} - -/* - * Parse the productions: - * block_mapping ::= BLOCK-MAPPING_START - * - * ((KEY block_node_or_indentless_sequence?)? - * - * (VALUE block_node_or_indentless_sequence?)?)* - * ***** * - * BLOCK-END - * - */ - -func yaml_parser_parse_block_mapping_value(parser *yaml_parser_t, - event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_VALUE_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_KEY_TOKEN && - token.token_type != yaml_VALUE_TOKEN && - token.token_type != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_MAPPING_KEY_STATE) - return yaml_parser_parse_node(parser, event, true, true) - } else { - parser.state = yaml_PARSE_BLOCK_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } else { - parser.state = yaml_PARSE_BLOCK_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) - } -} - -/* - * Parse the productions: - * flow_sequence ::= FLOW-SEQUENCE-START - * ******************* - * (flow_sequence_entry FLOW-ENTRY)* - * * ********** - * flow_sequence_entry? - * * - * FLOW-SEQUENCE-END - * ***************** - * flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * * - */ - -func yaml_parser_parse_flow_sequence_entry(parser *yaml_parser_t, - event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type != yaml_FLOW_SEQUENCE_END_TOKEN { - if !first { - if token.token_type == yaml_FLOW_ENTRY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } else { - mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - return yaml_parser_set_parser_error_context(parser, - "while parsing a flow sequence", mark, - "did not find expected ',' or ']'", token.start_mark) - } - } - - if token.token_type == yaml_KEY_TOKEN { - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE - *event = yaml_event_t{ - event_type: yaml_MAPPING_START_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - implicit: true, - style: yaml_style_t(yaml_FLOW_MAPPING_STYLE), - } - - skip_token(parser) - return true - } else if token.token_type != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - *event = yaml_event_t{ - event_type: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - skip_token(parser) - return true -} - -/* - * Parse the productions: - * flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * *** * - */ - -func yaml_parser_parse_flow_sequence_entry_mapping_key(parser *yaml_parser_t, - event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type != yaml_VALUE_TOKEN && - token.token_type != yaml_FLOW_ENTRY_TOKEN && - token.token_type != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } else { - mark := token.end_mark - skip_token(parser) - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } -} - -/* - * Parse the productions: - * flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * ***** * - */ - -func yaml_parser_parse_flow_sequence_entry_mapping_value(parser *yaml_parser_t, - event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type == yaml_VALUE_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_FLOW_ENTRY_TOKEN && - token.token_type != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) -} - -/* - * Parse the productions: - * flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * * - */ - -func yaml_parser_parse_flow_sequence_entry_mapping_end(parser *yaml_parser_t, - event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE - *event = yaml_event_t{ - event_type: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.start_mark, - } - - return true -} - -/* - * Parse the productions: - * flow_mapping ::= FLOW-MAPPING-START - * ****************** - * (flow_mapping_entry FLOW-ENTRY)* - * * ********** - * flow_mapping_entry? - * ****************** - * FLOW-MAPPING-END - * **************** - * flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * * *** * - */ - -func yaml_parser_parse_flow_mapping_key(parser *yaml_parser_t, - event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.token_type != yaml_FLOW_MAPPING_END_TOKEN { - if !first { - if token.token_type == yaml_FLOW_ENTRY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } else { - mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - return yaml_parser_set_parser_error_context(parser, - "while parsing a flow mapping", mark, - "did not find expected ',' or '}'", token.start_mark) - } - } - - if token.token_type == yaml_KEY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_VALUE_TOKEN && - token.token_type != yaml_FLOW_ENTRY_TOKEN && - token.token_type != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } else { - parser.state = yaml_PARSE_FLOW_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, - token.start_mark) - } - } else if token.token_type != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - *event = yaml_event_t{ - event_type: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - skip_token(parser) - return true -} - -/* - * Parse the productions: - * flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - * * ***** * - */ - -func yaml_parser_parse_flow_mapping_value(parser *yaml_parser_t, - event *yaml_event_t, empty bool) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if empty { - parser.state = yaml_PARSE_FLOW_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, - token.start_mark) - } - - if token.token_type == yaml_VALUE_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.token_type != yaml_FLOW_ENTRY_TOKEN && - token.token_type != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_KEY_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - - parser.state = yaml_PARSE_FLOW_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) -} - -/* - * Generate an empty scalar event. - */ - -func yaml_parser_process_empty_scalar(parser *yaml_parser_t, event *yaml_event_t, - mark YAML_mark_t) bool { - *event = yaml_event_t{ - event_type: yaml_SCALAR_EVENT, - start_mark: mark, - end_mark: mark, - value: nil, - implicit: true, - style: yaml_style_t(yaml_PLAIN_SCALAR_STYLE), - } - - return true -} - -/* - * Parse directives. - */ - -func yaml_parser_process_directives(parser *yaml_parser_t, - version_directive_ref **yaml_version_directive_t, - tag_directives_ref *[]yaml_tag_directive_t) bool { - - token := peek_token(parser) - if token == nil { - return false - } - - var version_directive *yaml_version_directive_t - var tag_directives []yaml_tag_directive_t - - for token.token_type == yaml_VERSION_DIRECTIVE_TOKEN || - token.token_type == yaml_TAG_DIRECTIVE_TOKEN { - if token.token_type == yaml_VERSION_DIRECTIVE_TOKEN { - if version_directive != nil { - yaml_parser_set_parser_error(parser, - "found duplicate %YAML directive", token.start_mark) - return false - } - if token.major != 1 || - token.minor != 1 { - yaml_parser_set_parser_error(parser, - "found incompatible YAML document", token.start_mark) - return false - } - version_directive = &yaml_version_directive_t{ - major: token.major, - minor: token.minor, - } - } else if token.token_type == yaml_TAG_DIRECTIVE_TOKEN { - value := yaml_tag_directive_t{ - handle: token.value, - prefix: token.prefix, - } - - if !yaml_parser_append_tag_directive(parser, value, false, - token.start_mark) { - return false - } - tag_directives = append(tag_directives, value) - } - - skip_token(parser) - token := peek_token(parser) - if token == nil { - return false - } - } - - for i := range default_tag_directives { - if !yaml_parser_append_tag_directive(parser, default_tag_directives[i], true, token.start_mark) { - return false - } - } - - if version_directive_ref != nil { - *version_directive_ref = version_directive - } - if tag_directives_ref != nil { - *tag_directives_ref = tag_directives - } - - return true -} - -/* - * Append a tag directive to the directives stack. - */ - -func yaml_parser_append_tag_directive(parser *yaml_parser_t, - value yaml_tag_directive_t, allow_duplicates bool, mark YAML_mark_t) bool { - for i := range parser.tag_directives { - tag := &parser.tag_directives[i] - if bytes.Equal(value.handle, tag.handle) { - if allow_duplicates { - return true - } - return yaml_parser_set_parser_error(parser, "found duplicate %TAG directive", mark) - } - } - - parser.tag_directives = append(parser.tag_directives, value) - return true -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go deleted file mode 100644 index 5631da2..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/reader.go +++ /dev/null @@ -1,465 +0,0 @@ -/* -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 candiedyaml - -import ( - "io" -) - -/* - * Set the reader error and return 0. - */ - -func yaml_parser_set_reader_error(parser *yaml_parser_t, problem string, - offset int, value int) bool { - parser.error = yaml_READER_ERROR - parser.problem = problem - parser.problem_offset = offset - parser.problem_value = value - - return false -} - -/* - * Byte order marks. - */ -const ( - BOM_UTF8 = "\xef\xbb\xbf" - BOM_UTF16LE = "\xff\xfe" - BOM_UTF16BE = "\xfe\xff" -) - -/* - * Determine the input stream encoding by checking the BOM symbol. If no BOM is - * found, the UTF-8 encoding is assumed. Return 1 on success, 0 on failure. - */ - -func yaml_parser_determine_encoding(parser *yaml_parser_t) bool { - /* Ensure that we had enough bytes in the raw buffer. */ - for !parser.eof && - len(parser.raw_buffer)-parser.raw_buffer_pos < 3 { - if !yaml_parser_update_raw_buffer(parser) { - return false - } - } - - /* Determine the encoding. */ - raw := parser.raw_buffer - pos := parser.raw_buffer_pos - remaining := len(raw) - pos - if remaining >= 2 && - raw[pos] == BOM_UTF16LE[0] && raw[pos+1] == BOM_UTF16LE[1] { - parser.encoding = yaml_UTF16LE_ENCODING - parser.raw_buffer_pos += 2 - parser.offset += 2 - } else if remaining >= 2 && - raw[pos] == BOM_UTF16BE[0] && raw[pos+1] == BOM_UTF16BE[1] { - parser.encoding = yaml_UTF16BE_ENCODING - parser.raw_buffer_pos += 2 - parser.offset += 2 - } else if remaining >= 3 && - raw[pos] == BOM_UTF8[0] && raw[pos+1] == BOM_UTF8[1] && raw[pos+2] == BOM_UTF8[2] { - parser.encoding = yaml_UTF8_ENCODING - parser.raw_buffer_pos += 3 - parser.offset += 3 - } else { - parser.encoding = yaml_UTF8_ENCODING - } - - return true -} - -/* - * Update the raw buffer. - */ - -func yaml_parser_update_raw_buffer(parser *yaml_parser_t) bool { - size_read := 0 - - /* Return if the raw buffer is full. */ - if parser.raw_buffer_pos == 0 && len(parser.raw_buffer) == cap(parser.raw_buffer) { - return true - } - - /* Return on EOF. */ - - if parser.eof { - return true - } - - /* Move the remaining bytes in the raw buffer to the beginning. */ - if parser.raw_buffer_pos > 0 && parser.raw_buffer_pos < len(parser.raw_buffer) { - copy(parser.raw_buffer, parser.raw_buffer[parser.raw_buffer_pos:]) - } - parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)-parser.raw_buffer_pos] - parser.raw_buffer_pos = 0 - - /* Call the read handler to fill the buffer. */ - size_read, err := parser.read_handler(parser, - parser.raw_buffer[len(parser.raw_buffer):cap(parser.raw_buffer)]) - parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)+size_read] - - if err == io.EOF { - parser.eof = true - } else if err != nil { - return yaml_parser_set_reader_error(parser, "input error: "+err.Error(), - parser.offset, -1) - } - - return true -} - -/* - * Ensure that the buffer contains at least `length` characters. - * Return 1 on success, 0 on failure. - * - * The length is supposed to be significantly less that the buffer size. - */ - -func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { - /* Read handler must be set. */ - if parser.read_handler == nil { - panic("read handler must be set") - } - - /* If the EOF flag is set and the raw buffer is empty, do nothing. */ - - if parser.eof && parser.raw_buffer_pos == len(parser.raw_buffer) { - return true - } - - /* Return if the buffer contains enough characters. */ - - if parser.unread >= length { - return true - } - - /* Determine the input encoding if it is not known yet. */ - - if parser.encoding == yaml_ANY_ENCODING { - if !yaml_parser_determine_encoding(parser) { - return false - } - } - - /* Move the unread characters to the beginning of the buffer. */ - buffer_end := len(parser.buffer) - if 0 < parser.buffer_pos && - parser.buffer_pos < buffer_end { - copy(parser.buffer, parser.buffer[parser.buffer_pos:]) - buffer_end -= parser.buffer_pos - parser.buffer_pos = 0 - } else if parser.buffer_pos == buffer_end { - buffer_end = 0 - parser.buffer_pos = 0 - } - - parser.buffer = parser.buffer[:cap(parser.buffer)] - - /* Fill the buffer until it has enough characters. */ - first := true - for parser.unread < length { - /* Fill the raw buffer if necessary. */ - - if !first || parser.raw_buffer_pos == len(parser.raw_buffer) { - if !yaml_parser_update_raw_buffer(parser) { - parser.buffer = parser.buffer[:buffer_end] - return false - } - } - first = false - - /* Decode the raw buffer. */ - for parser.raw_buffer_pos != len(parser.raw_buffer) { - var value rune - var w int - - raw_unread := len(parser.raw_buffer) - parser.raw_buffer_pos - incomplete := false - - /* Decode the next character. */ - - switch parser.encoding { - case yaml_UTF8_ENCODING: - - /* - * Decode a UTF-8 character. Check RFC 3629 - * (http://www.ietf.org/rfc/rfc3629.txt) for more details. - * - * The following table (taken from the RFC) is used for - * decoding. - * - * Char. number range | UTF-8 octet sequence - * (hexadecimal) | (binary) - * --------------------+------------------------------------ - * 0000 0000-0000 007F | 0xxxxxxx - * 0000 0080-0000 07FF | 110xxxxx 10xxxxxx - * 0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx - * 0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx - * - * Additionally, the characters in the range 0xD800-0xDFFF - * are prohibited as they are reserved for use with UTF-16 - * surrogate pairs. - */ - - /* Determine the length of the UTF-8 sequence. */ - - octet := parser.raw_buffer[parser.raw_buffer_pos] - w = width(octet) - - /* Check if the leading octet is valid. */ - - if w == 0 { - return yaml_parser_set_reader_error(parser, - "invalid leading UTF-8 octet", - parser.offset, int(octet)) - } - - /* Check if the raw buffer contains an incomplete character. */ - - if w > raw_unread { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-8 octet sequence", - parser.offset, -1) - } - incomplete = true - break - } - - /* Decode the leading octet. */ - switch { - case octet&0x80 == 0x00: - value = rune(octet & 0x7F) - case octet&0xE0 == 0xC0: - value = rune(octet & 0x1F) - case octet&0xF0 == 0xE0: - value = rune(octet & 0x0F) - case octet&0xF8 == 0xF0: - value = rune(octet & 0x07) - default: - value = 0 - } - - /* Check and decode the trailing octets. */ - - for k := 1; k < w; k++ { - octet = parser.raw_buffer[parser.raw_buffer_pos+k] - - /* Check if the octet is valid. */ - - if (octet & 0xC0) != 0x80 { - return yaml_parser_set_reader_error(parser, - "invalid trailing UTF-8 octet", - parser.offset+k, int(octet)) - } - - /* Decode the octet. */ - - value = (value << 6) + rune(octet&0x3F) - } - - /* Check the length of the sequence against the value. */ - switch { - case w == 1: - case w == 2 && value >= 0x80: - case w == 3 && value >= 0x800: - case w == 4 && value >= 0x10000: - default: - return yaml_parser_set_reader_error(parser, - "invalid length of a UTF-8 sequence", - parser.offset, -1) - } - - /* Check the range of the value. */ - - if (value >= 0xD800 && value <= 0xDFFF) || value > 0x10FFFF { - return yaml_parser_set_reader_error(parser, - "invalid Unicode character", - parser.offset, int(value)) - } - case yaml_UTF16LE_ENCODING, - yaml_UTF16BE_ENCODING: - - var low, high int - if parser.encoding == yaml_UTF16LE_ENCODING { - low, high = 0, 1 - } else { - high, low = 1, 0 - } - - /* - * The UTF-16 encoding is not as simple as one might - * naively think. Check RFC 2781 - * (http://www.ietf.org/rfc/rfc2781.txt). - * - * Normally, two subsequent bytes describe a Unicode - * character. However a special technique (called a - * surrogate pair) is used for specifying character - * values larger than 0xFFFF. - * - * A surrogate pair consists of two pseudo-characters: - * high surrogate area (0xD800-0xDBFF) - * low surrogate area (0xDC00-0xDFFF) - * - * The following formulas are used for decoding - * and encoding characters using surrogate pairs: - * - * U = U' + 0x10000 (0x01 00 00 <= U <= 0x10 FF FF) - * U' = yyyyyyyyyyxxxxxxxxxx (0 <= U' <= 0x0F FF FF) - * W1 = 110110yyyyyyyyyy - * W2 = 110111xxxxxxxxxx - * - * where U is the character value, W1 is the high surrogate - * area, W2 is the low surrogate area. - */ - - /* Check for incomplete UTF-16 character. */ - - if raw_unread < 2 { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-16 character", - parser.offset, -1) - } - incomplete = true - break - } - - /* Get the character. */ - value = rune(parser.raw_buffer[parser.raw_buffer_pos+low]) + - (rune(parser.raw_buffer[parser.raw_buffer_pos+high]) << 8) - - /* Check for unexpected low surrogate area. */ - - if (value & 0xFC00) == 0xDC00 { - return yaml_parser_set_reader_error(parser, - "unexpected low surrogate area", - parser.offset, int(value)) - } - - /* Check for a high surrogate area. */ - - if (value & 0xFC00) == 0xD800 { - - w = 4 - - /* Check for incomplete surrogate pair. */ - - if raw_unread < 4 { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-16 surrogate pair", - parser.offset, -1) - } - incomplete = true - break - } - - /* Get the next character. */ - - value2 := rune(parser.raw_buffer[parser.raw_buffer_pos+low+2]) + - (rune(parser.raw_buffer[parser.raw_buffer_pos+high+2]) << 8) - - /* Check for a low surrogate area. */ - - if (value2 & 0xFC00) != 0xDC00 { - return yaml_parser_set_reader_error(parser, - "expected low surrogate area", - parser.offset+2, int(value2)) - } - - /* Generate the value of the surrogate pair. */ - - value = 0x10000 + ((value & 0x3FF) << 10) + (value2 & 0x3FF) - } else { - w = 2 - } - - break - - default: - panic("Impossible") /* Impossible. */ - } - - /* Check if the raw buffer contains enough bytes to form a character. */ - - if incomplete { - break - } - - /* - * Check if the character is in the allowed range: - * #x9 | #xA | #xD | [#x20-#x7E] (8 bit) - * | #x85 | [#xA0-#xD7FF] | [#xE000-#xFFFD] (16 bit) - * | [#x10000-#x10FFFF] (32 bit) - */ - - if !(value == 0x09 || value == 0x0A || value == 0x0D || - (value >= 0x20 && value <= 0x7E) || - (value == 0x85) || (value >= 0xA0 && value <= 0xD7FF) || - (value >= 0xE000 && value <= 0xFFFD) || - (value >= 0x10000 && value <= 0x10FFFF)) { - return yaml_parser_set_reader_error(parser, - "control characters are not allowed", - parser.offset, int(value)) - } - - /* Move the raw pointers. */ - - parser.raw_buffer_pos += w - parser.offset += w - - /* Finally put the character into the buffer. */ - - /* 0000 0000-0000 007F . 0xxxxxxx */ - if value <= 0x7F { - parser.buffer[buffer_end] = byte(value) - } else if value <= 0x7FF { - /* 0000 0080-0000 07FF . 110xxxxx 10xxxxxx */ - parser.buffer[buffer_end] = byte(0xC0 + (value >> 6)) - parser.buffer[buffer_end+1] = byte(0x80 + (value & 0x3F)) - } else if value <= 0xFFFF { - /* 0000 0800-0000 FFFF . 1110xxxx 10xxxxxx 10xxxxxx */ - parser.buffer[buffer_end] = byte(0xE0 + (value >> 12)) - parser.buffer[buffer_end+1] = byte(0x80 + ((value >> 6) & 0x3F)) - parser.buffer[buffer_end+2] = byte(0x80 + (value & 0x3F)) - } else { - /* 0001 0000-0010 FFFF . 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx */ - parser.buffer[buffer_end] = byte(0xF0 + (value >> 18)) - parser.buffer[buffer_end+1] = byte(0x80 + ((value >> 12) & 0x3F)) - parser.buffer[buffer_end+2] = byte(0x80 + ((value >> 6) & 0x3F)) - parser.buffer[buffer_end+3] = byte(0x80 + (value & 0x3F)) - } - - buffer_end += w - parser.unread++ - } - - /* On EOF, put NUL into the buffer and return. */ - - if parser.eof { - parser.buffer[buffer_end] = 0 - buffer_end++ - parser.buffer = parser.buffer[:buffer_end] - parser.unread++ - return true - } - - } - - parser.buffer = parser.buffer[:buffer_end] - return true -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go deleted file mode 100644 index fb9e8be..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/resolver.go +++ /dev/null @@ -1,449 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" - "encoding/base64" - "fmt" - "math" - "reflect" - "regexp" - "strconv" - "strings" - "time" -) - -var byteSliceType = reflect.TypeOf([]byte(nil)) - -var binary_tags = [][]byte{[]byte("!binary"), []byte(yaml_BINARY_TAG)} -var bool_values map[string]bool -var null_values map[string]bool - -var signs = []byte{'-', '+'} -var nulls = []byte{'~', 'n', 'N'} -var bools = []byte{'t', 'T', 'f', 'F', 'y', 'Y', 'n', 'N', 'o', 'O'} - -var timestamp_regexp *regexp.Regexp -var ymd_regexp *regexp.Regexp - -func init() { - bool_values = make(map[string]bool) - bool_values["y"] = true - bool_values["yes"] = true - bool_values["n"] = false - bool_values["no"] = false - bool_values["true"] = true - bool_values["false"] = false - bool_values["on"] = true - bool_values["off"] = false - - null_values = make(map[string]bool) - null_values["~"] = true - null_values["null"] = true - null_values["Null"] = true - null_values["NULL"] = true - - timestamp_regexp = regexp.MustCompile("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:(?:[Tt]|[ \t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \t]*(?:Z|([-+][0-9][0-9]?)(?::([0-9][0-9])?)?))?)?$") - ymd_regexp = regexp.MustCompile("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)$") -} - -func resolve(event yaml_event_t, v reflect.Value, useNumber bool) (string, error) { - val := string(event.value) - - if null_values[val] { - v.Set(reflect.Zero(v.Type())) - return yaml_NULL_TAG, nil - } - - switch v.Kind() { - case reflect.String: - if useNumber && v.Type() == numberType { - tag, i := resolveInterface(event, useNumber) - if n, ok := i.(Number); ok { - v.Set(reflect.ValueOf(n)) - return tag, nil - } - return "", fmt.Errorf("Not a number: '%s' at %s", event.value, event.start_mark) - } - - return resolve_string(val, v, event) - case reflect.Bool: - return resolve_bool(val, v, event) - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return resolve_int(val, v, useNumber, event) - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64: - return resolve_uint(val, v, useNumber, event) - case reflect.Float32, reflect.Float64: - return resolve_float(val, v, useNumber, event) - case reflect.Interface: - _, i := resolveInterface(event, useNumber) - if i != nil { - v.Set(reflect.ValueOf(i)) - } else { - v.Set(reflect.Zero(v.Type())) - } - - case reflect.Struct: - return resolve_time(val, v, event) - case reflect.Slice: - if v.Type() != byteSliceType { - return "", fmt.Errorf("Cannot resolve %s into %s at %s", val, v.String(), event.start_mark) - } - b, err := decode_binary(event.value, event) - if err != nil { - return "", err - } - - v.Set(reflect.ValueOf(b)) - default: - return "", fmt.Errorf("Unknown resolution for '%s' using %s at %s", val, v.String(), event.start_mark) - } - - return yaml_STR_TAG, nil -} - -func hasBinaryTag(event yaml_event_t) bool { - for _, tag := range binary_tags { - if bytes.Equal(event.tag, tag) { - return true - } - } - return false -} - -func decode_binary(value []byte, event yaml_event_t) ([]byte, error) { - b := make([]byte, base64.StdEncoding.DecodedLen(len(value))) - n, err := base64.StdEncoding.Decode(b, value) - if err != nil { - return nil, fmt.Errorf("Invalid base64 text: '%s' at %s", string(b), event.start_mark) - } - return b[:n], nil -} - -func resolve_string(val string, v reflect.Value, event yaml_event_t) (string, error) { - if len(event.tag) > 0 { - if hasBinaryTag(event) { - b, err := decode_binary(event.value, event) - if err != nil { - return "", err - } - val = string(b) - } - } - v.SetString(val) - return yaml_STR_TAG, nil -} - -func resolve_bool(val string, v reflect.Value, event yaml_event_t) (string, error) { - b, found := bool_values[strings.ToLower(val)] - if !found { - return "", fmt.Errorf("Invalid boolean: '%s' at %s", val, event.start_mark) - } - - v.SetBool(b) - return yaml_BOOL_TAG, nil -} - -func resolve_int(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) { - original := val - val = strings.Replace(val, "_", "", -1) - var value uint64 - - isNumberValue := v.Type() == numberType - - sign := int64(1) - if val[0] == '-' { - sign = -1 - val = val[1:] - } else if val[0] == '+' { - val = val[1:] - } - - base := 0 - if val == "0" { - if isNumberValue { - v.SetString("0") - } else { - v.Set(reflect.Zero(v.Type())) - } - - return yaml_INT_TAG, nil - } - - if strings.HasPrefix(val, "0o") { - base = 8 - val = val[2:] - } - - value, err := strconv.ParseUint(val, base, 64) - if err != nil { - return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark) - } - - var val64 int64 - if value <= math.MaxInt64 { - val64 = int64(value) - if sign == -1 { - val64 = -val64 - } - } else if sign == -1 && value == uint64(math.MaxInt64)+1 { - val64 = math.MinInt64 - } else { - return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark) - } - - if isNumberValue { - v.SetString(strconv.FormatInt(val64, 10)) - } else { - if v.OverflowInt(val64) { - return "", fmt.Errorf("Invalid integer: '%s' at %s", original, event.start_mark) - } - v.SetInt(val64) - } - - return yaml_INT_TAG, nil -} - -func resolve_uint(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) { - original := val - val = strings.Replace(val, "_", "", -1) - var value uint64 - - isNumberValue := v.Type() == numberType - - if val[0] == '-' { - return "", fmt.Errorf("Unsigned int with negative value: '%s' at %s", original, event.start_mark) - } - - if val[0] == '+' { - val = val[1:] - } - - base := 0 - if val == "0" { - if isNumberValue { - v.SetString("0") - } else { - v.Set(reflect.Zero(v.Type())) - } - - return yaml_INT_TAG, nil - } - - if strings.HasPrefix(val, "0o") { - base = 8 - val = val[2:] - } - - value, err := strconv.ParseUint(val, base, 64) - if err != nil { - return "", fmt.Errorf("Invalid unsigned integer: '%s' at %s", val, event.start_mark) - } - - if isNumberValue { - v.SetString(strconv.FormatUint(value, 10)) - } else { - if v.OverflowUint(value) { - return "", fmt.Errorf("Invalid unsigned integer: '%s' at %s", val, event.start_mark) - } - - v.SetUint(value) - } - - return yaml_INT_TAG, nil -} - -func resolve_float(val string, v reflect.Value, useNumber bool, event yaml_event_t) (string, error) { - val = strings.Replace(val, "_", "", -1) - var value float64 - - isNumberValue := v.Type() == numberType - typeBits := 64 - if !isNumberValue { - typeBits = v.Type().Bits() - } - - sign := 1 - if val[0] == '-' { - sign = -1 - val = val[1:] - } else if val[0] == '+' { - val = val[1:] - } - - valLower := strings.ToLower(val) - if valLower == ".inf" { - value = math.Inf(sign) - } else if valLower == ".nan" { - value = math.NaN() - } else { - var err error - value, err = strconv.ParseFloat(val, typeBits) - value *= float64(sign) - - if err != nil { - return "", fmt.Errorf("Invalid float: '%s' at %s", val, event.start_mark) - } - } - - if isNumberValue { - v.SetString(strconv.FormatFloat(value, 'g', -1, typeBits)) - } else { - if v.OverflowFloat(value) { - return "", fmt.Errorf("Invalid float: '%s' at %s", val, event.start_mark) - } - - v.SetFloat(value) - } - - return yaml_FLOAT_TAG, nil -} - -func resolve_time(val string, v reflect.Value, event yaml_event_t) (string, error) { - var parsedTime time.Time - matches := ymd_regexp.FindStringSubmatch(val) - if len(matches) > 0 { - year, _ := strconv.Atoi(matches[1]) - month, _ := strconv.Atoi(matches[2]) - day, _ := strconv.Atoi(matches[3]) - parsedTime = time.Date(year, time.Month(month), day, 0, 0, 0, 0, time.UTC) - } else { - matches = timestamp_regexp.FindStringSubmatch(val) - if len(matches) == 0 { - return "", fmt.Errorf("Invalid timestamp: '%s' at %s", val, event.start_mark) - } - - year, _ := strconv.Atoi(matches[1]) - month, _ := strconv.Atoi(matches[2]) - day, _ := strconv.Atoi(matches[3]) - hour, _ := strconv.Atoi(matches[4]) - min, _ := strconv.Atoi(matches[5]) - sec, _ := strconv.Atoi(matches[6]) - - nsec := 0 - if matches[7] != "" { - millis, _ := strconv.Atoi(matches[7]) - nsec = int(time.Duration(millis) * time.Millisecond) - } - - loc := time.UTC - if matches[8] != "" { - sign := matches[8][0] - hr, _ := strconv.Atoi(matches[8][1:]) - min := 0 - if matches[9] != "" { - min, _ = strconv.Atoi(matches[9]) - } - - zoneOffset := (hr*60 + min) * 60 - if sign == '-' { - zoneOffset = -zoneOffset - } - - loc = time.FixedZone("", zoneOffset) - } - parsedTime = time.Date(year, time.Month(month), day, hour, min, sec, nsec, loc) - } - - v.Set(reflect.ValueOf(parsedTime)) - return "", nil -} - -func resolveInterface(event yaml_event_t, useNumber bool) (string, interface{}) { - val := string(event.value) - if len(event.tag) == 0 && !event.implicit { - return "", val - } - - if len(val) == 0 { - return yaml_NULL_TAG, nil - } - - var result interface{} - - sign := false - c := val[0] - switch { - case bytes.IndexByte(signs, c) != -1: - sign = true - fallthrough - case c >= '0' && c <= '9': - i := int64(0) - result = &i - if useNumber { - var n Number - result = &n - } - - v := reflect.ValueOf(result).Elem() - if _, err := resolve_int(val, v, useNumber, event); err == nil { - return yaml_INT_TAG, v.Interface() - } - - f := float64(0) - result = &f - if useNumber { - var n Number - result = &n - } - - v = reflect.ValueOf(result).Elem() - if _, err := resolve_float(val, v, useNumber, event); err == nil { - return yaml_FLOAT_TAG, v.Interface() - } - - if !sign { - t := time.Time{} - if _, err := resolve_time(val, reflect.ValueOf(&t).Elem(), event); err == nil { - return "", t - } - } - case bytes.IndexByte(nulls, c) != -1: - if null_values[val] { - return yaml_NULL_TAG, nil - } - b := false - if _, err := resolve_bool(val, reflect.ValueOf(&b).Elem(), event); err == nil { - return yaml_BOOL_TAG, b - } - case c == '.': - f := float64(0) - result = &f - if useNumber { - var n Number - result = &n - } - - v := reflect.ValueOf(result).Elem() - if _, err := resolve_float(val, v, useNumber, event); err == nil { - return yaml_FLOAT_TAG, v.Interface() - } - case bytes.IndexByte(bools, c) != -1: - b := false - if _, err := resolve_bool(val, reflect.ValueOf(&b).Elem(), event); err == nil { - return yaml_BOOL_TAG, b - } - } - - if hasBinaryTag(event) { - bytes, err := decode_binary(event.value, event) - if err == nil { - return yaml_BINARY_TAG, bytes - } - } - - return yaml_STR_TAG, val -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go deleted file mode 100644 index 25c2981..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/run_parser.go +++ /dev/null @@ -1,62 +0,0 @@ -/* -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 candiedyaml - -import ( - "fmt" - "os" -) - -func Run_parser(cmd string, args []string) { - for i := 0; i < len(args); i++ { - fmt.Printf("[%d] Scanning '%s'", i, args[i]) - file, err := os.Open(args[i]) - if err != nil { - panic(fmt.Sprintf("Invalid file '%s': %s", args[i], err.Error())) - } - - parser := yaml_parser_t{} - yaml_parser_initialize(&parser) - yaml_parser_set_input_reader(&parser, file) - - failed := false - token := yaml_token_t{} - count := 0 - for { - if !yaml_parser_scan(&parser, &token) { - failed = true - break - } - - if token.token_type == yaml_STREAM_END_TOKEN { - break - } - count++ - } - - file.Close() - - msg := "SUCCESS" - if failed { - msg = "FAILED" - if parser.error != yaml_NO_ERROR { - m := parser.problem_mark - fmt.Printf("ERROR: (%s) %s @ line: %d col: %d\n", - parser.context, parser.problem, m.line, m.column) - } - } - fmt.Printf("%s (%d tokens)\n", msg, count) - } -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go deleted file mode 100644 index 5c080a0..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/scanner.go +++ /dev/null @@ -1,3318 +0,0 @@ -/* -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 candiedyaml - -import ( - "bytes" -) - -/* - * Introduction - * ************ - * - * The following notes assume that you are familiar with the YAML specification - * (http://yaml.org/spec/cvs/current.html). We mostly follow it, although in - * some cases we are less restrictive that it requires. - * - * The process of transforming a YAML stream into a sequence of events is - * divided on two steps: Scanning and Parsing. - * - * The Scanner transforms the input stream into a sequence of tokens, while the - * parser transform the sequence of tokens produced by the Scanner into a - * sequence of parsing events. - * - * The Scanner is rather clever and complicated. The Parser, on the contrary, - * is a straightforward implementation of a recursive-descendant parser (or, - * LL(1) parser, as it is usually called). - * - * Actually there are two issues of Scanning that might be called "clever", the - * rest is quite straightforward. The issues are "block collection start" and - * "simple keys". Both issues are explained below in details. - * - * Here the Scanning step is explained and implemented. We start with the list - * of all the tokens produced by the Scanner together with short descriptions. - * - * Now, tokens: - * - * STREAM-START(encoding) # The stream start. - * STREAM-END # The stream end. - * VERSION-DIRECTIVE(major,minor) # The '%YAML' directive. - * TAG-DIRECTIVE(handle,prefix) # The '%TAG' directive. - * DOCUMENT-START # '---' - * DOCUMENT-END # '...' - * BLOCK-SEQUENCE-START # Indentation increase denoting a block - * BLOCK-MAPPING-START # sequence or a block mapping. - * BLOCK-END # Indentation decrease. - * FLOW-SEQUENCE-START # '[' - * FLOW-SEQUENCE-END # ']' - * BLOCK-SEQUENCE-START # '{' - * BLOCK-SEQUENCE-END # '}' - * BLOCK-ENTRY # '-' - * FLOW-ENTRY # ',' - * KEY # '?' or nothing (simple keys). - * VALUE # ':' - * ALIAS(anchor) # '*anchor' - * ANCHOR(anchor) # '&anchor' - * TAG(handle,suffix) # '!handle!suffix' - * SCALAR(value,style) # A scalar. - * - * The following two tokens are "virtual" tokens denoting the beginning and the - * end of the stream: - * - * STREAM-START(encoding) - * STREAM-END - * - * We pass the information about the input stream encoding with the - * STREAM-START token. - * - * The next two tokens are responsible for tags: - * - * VERSION-DIRECTIVE(major,minor) - * TAG-DIRECTIVE(handle,prefix) - * - * Example: - * - * %YAML 1.1 - * %TAG ! !foo - * %TAG !yaml! tag:yaml.org,2002: - * --- - * - * The correspoding sequence of tokens: - * - * STREAM-START(utf-8) - * VERSION-DIRECTIVE(1,1) - * TAG-DIRECTIVE("!","!foo") - * TAG-DIRECTIVE("!yaml","tag:yaml.org,2002:") - * DOCUMENT-START - * STREAM-END - * - * Note that the VERSION-DIRECTIVE and TAG-DIRECTIVE tokens occupy a whole - * line. - * - * The document start and end indicators are represented by: - * - * DOCUMENT-START - * DOCUMENT-END - * - * Note that if a YAML stream contains an implicit document (without '---' - * and '...' indicators), no DOCUMENT-START and DOCUMENT-END tokens will be - * produced. - * - * In the following examples, we present whole documents together with the - * produced tokens. - * - * 1. An implicit document: - * - * 'a scalar' - * - * Tokens: - * - * STREAM-START(utf-8) - * SCALAR("a scalar",single-quoted) - * STREAM-END - * - * 2. An explicit document: - * - * --- - * 'a scalar' - * ... - * - * Tokens: - * - * STREAM-START(utf-8) - * DOCUMENT-START - * SCALAR("a scalar",single-quoted) - * DOCUMENT-END - * STREAM-END - * - * 3. Several documents in a stream: - * - * 'a scalar' - * --- - * 'another scalar' - * --- - * 'yet another scalar' - * - * Tokens: - * - * STREAM-START(utf-8) - * SCALAR("a scalar",single-quoted) - * DOCUMENT-START - * SCALAR("another scalar",single-quoted) - * DOCUMENT-START - * SCALAR("yet another scalar",single-quoted) - * STREAM-END - * - * We have already introduced the SCALAR token above. The following tokens are - * used to describe aliases, anchors, tag, and scalars: - * - * ALIAS(anchor) - * ANCHOR(anchor) - * TAG(handle,suffix) - * SCALAR(value,style) - * - * The following series of examples illustrate the usage of these tokens: - * - * 1. A recursive sequence: - * - * &A [ *A ] - * - * Tokens: - * - * STREAM-START(utf-8) - * ANCHOR("A") - * FLOW-SEQUENCE-START - * ALIAS("A") - * FLOW-SEQUENCE-END - * STREAM-END - * - * 2. A tagged scalar: - * - * !!float "3.14" # A good approximation. - * - * Tokens: - * - * STREAM-START(utf-8) - * TAG("!!","float") - * SCALAR("3.14",double-quoted) - * STREAM-END - * - * 3. Various scalar styles: - * - * --- # Implicit empty plain scalars do not produce tokens. - * --- a plain scalar - * --- 'a single-quoted scalar' - * --- "a double-quoted scalar" - * --- |- - * a literal scalar - * --- >- - * a folded - * scalar - * - * Tokens: - * - * STREAM-START(utf-8) - * DOCUMENT-START - * DOCUMENT-START - * SCALAR("a plain scalar",plain) - * DOCUMENT-START - * SCALAR("a single-quoted scalar",single-quoted) - * DOCUMENT-START - * SCALAR("a double-quoted scalar",double-quoted) - * DOCUMENT-START - * SCALAR("a literal scalar",literal) - * DOCUMENT-START - * SCALAR("a folded scalar",folded) - * STREAM-END - * - * Now it's time to review collection-related tokens. We will start with - * flow collections: - * - * FLOW-SEQUENCE-START - * FLOW-SEQUENCE-END - * FLOW-MAPPING-START - * FLOW-MAPPING-END - * FLOW-ENTRY - * KEY - * VALUE - * - * The tokens FLOW-SEQUENCE-START, FLOW-SEQUENCE-END, FLOW-MAPPING-START, and - * FLOW-MAPPING-END represent the indicators '[', ']', '{', and '}' - * correspondingly. FLOW-ENTRY represent the ',' indicator. Finally the - * indicators '?' and ':', which are used for denoting mapping keys and values, - * are represented by the KEY and VALUE tokens. - * - * The following examples show flow collections: - * - * 1. A flow sequence: - * - * [item 1, item 2, item 3] - * - * Tokens: - * - * STREAM-START(utf-8) - * FLOW-SEQUENCE-START - * SCALAR("item 1",plain) - * FLOW-ENTRY - * SCALAR("item 2",plain) - * FLOW-ENTRY - * SCALAR("item 3",plain) - * FLOW-SEQUENCE-END - * STREAM-END - * - * 2. A flow mapping: - * - * { - * a simple key: a value, # Note that the KEY token is produced. - * ? a complex key: another value, - * } - * - * Tokens: - * - * STREAM-START(utf-8) - * FLOW-MAPPING-START - * KEY - * SCALAR("a simple key",plain) - * VALUE - * SCALAR("a value",plain) - * FLOW-ENTRY - * KEY - * SCALAR("a complex key",plain) - * VALUE - * SCALAR("another value",plain) - * FLOW-ENTRY - * FLOW-MAPPING-END - * STREAM-END - * - * A simple key is a key which is not denoted by the '?' indicator. Note that - * the Scanner still produce the KEY token whenever it encounters a simple key. - * - * For scanning block collections, the following tokens are used (note that we - * repeat KEY and VALUE here): - * - * BLOCK-SEQUENCE-START - * BLOCK-MAPPING-START - * BLOCK-END - * BLOCK-ENTRY - * KEY - * VALUE - * - * The tokens BLOCK-SEQUENCE-START and BLOCK-MAPPING-START denote indentation - * increase that precedes a block collection (cf. the INDENT token in Python). - * The token BLOCK-END denote indentation decrease that ends a block collection - * (cf. the DEDENT token in Python). However YAML has some syntax pecularities - * that makes detections of these tokens more complex. - * - * The tokens BLOCK-ENTRY, KEY, and VALUE are used to represent the indicators - * '-', '?', and ':' correspondingly. - * - * The following examples show how the tokens BLOCK-SEQUENCE-START, - * BLOCK-MAPPING-START, and BLOCK-END are emitted by the Scanner: - * - * 1. Block sequences: - * - * - item 1 - * - item 2 - * - - * - item 3.1 - * - item 3.2 - * - - * key 1: value 1 - * key 2: value 2 - * - * Tokens: - * - * STREAM-START(utf-8) - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * SCALAR("item 1",plain) - * BLOCK-ENTRY - * SCALAR("item 2",plain) - * BLOCK-ENTRY - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * SCALAR("item 3.1",plain) - * BLOCK-ENTRY - * SCALAR("item 3.2",plain) - * BLOCK-END - * BLOCK-ENTRY - * BLOCK-MAPPING-START - * KEY - * SCALAR("key 1",plain) - * VALUE - * SCALAR("value 1",plain) - * KEY - * SCALAR("key 2",plain) - * VALUE - * SCALAR("value 2",plain) - * BLOCK-END - * BLOCK-END - * STREAM-END - * - * 2. Block mappings: - * - * a simple key: a value # The KEY token is produced here. - * ? a complex key - * : another value - * a mapping: - * key 1: value 1 - * key 2: value 2 - * a sequence: - * - item 1 - * - item 2 - * - * Tokens: - * - * STREAM-START(utf-8) - * BLOCK-MAPPING-START - * KEY - * SCALAR("a simple key",plain) - * VALUE - * SCALAR("a value",plain) - * KEY - * SCALAR("a complex key",plain) - * VALUE - * SCALAR("another value",plain) - * KEY - * SCALAR("a mapping",plain) - * BLOCK-MAPPING-START - * KEY - * SCALAR("key 1",plain) - * VALUE - * SCALAR("value 1",plain) - * KEY - * SCALAR("key 2",plain) - * VALUE - * SCALAR("value 2",plain) - * BLOCK-END - * KEY - * SCALAR("a sequence",plain) - * VALUE - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * SCALAR("item 1",plain) - * BLOCK-ENTRY - * SCALAR("item 2",plain) - * BLOCK-END - * BLOCK-END - * STREAM-END - * - * YAML does not always require to start a new block collection from a new - * line. If the current line contains only '-', '?', and ':' indicators, a new - * block collection may start at the current line. The following examples - * illustrate this case: - * - * 1. Collections in a sequence: - * - * - - item 1 - * - item 2 - * - key 1: value 1 - * key 2: value 2 - * - ? complex key - * : complex value - * - * Tokens: - * - * STREAM-START(utf-8) - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * SCALAR("item 1",plain) - * BLOCK-ENTRY - * SCALAR("item 2",plain) - * BLOCK-END - * BLOCK-ENTRY - * BLOCK-MAPPING-START - * KEY - * SCALAR("key 1",plain) - * VALUE - * SCALAR("value 1",plain) - * KEY - * SCALAR("key 2",plain) - * VALUE - * SCALAR("value 2",plain) - * BLOCK-END - * BLOCK-ENTRY - * BLOCK-MAPPING-START - * KEY - * SCALAR("complex key") - * VALUE - * SCALAR("complex value") - * BLOCK-END - * BLOCK-END - * STREAM-END - * - * 2. Collections in a mapping: - * - * ? a sequence - * : - item 1 - * - item 2 - * ? a mapping - * : key 1: value 1 - * key 2: value 2 - * - * Tokens: - * - * STREAM-START(utf-8) - * BLOCK-MAPPING-START - * KEY - * SCALAR("a sequence",plain) - * VALUE - * BLOCK-SEQUENCE-START - * BLOCK-ENTRY - * SCALAR("item 1",plain) - * BLOCK-ENTRY - * SCALAR("item 2",plain) - * BLOCK-END - * KEY - * SCALAR("a mapping",plain) - * VALUE - * BLOCK-MAPPING-START - * KEY - * SCALAR("key 1",plain) - * VALUE - * SCALAR("value 1",plain) - * KEY - * SCALAR("key 2",plain) - * VALUE - * SCALAR("value 2",plain) - * BLOCK-END - * BLOCK-END - * STREAM-END - * - * YAML also permits non-indented sequences if they are included into a block - * mapping. In this case, the token BLOCK-SEQUENCE-START is not produced: - * - * key: - * - item 1 # BLOCK-SEQUENCE-START is NOT produced here. - * - item 2 - * - * Tokens: - * - * STREAM-START(utf-8) - * BLOCK-MAPPING-START - * KEY - * SCALAR("key",plain) - * VALUE - * BLOCK-ENTRY - * SCALAR("item 1",plain) - * BLOCK-ENTRY - * SCALAR("item 2",plain) - * BLOCK-END - */ - -/* - * Ensure that the buffer contains the required number of characters. - * Return 1 on success, 0 on failure (reader error or memory error). - */ -func cache(parser *yaml_parser_t, length int) bool { - if parser.unread >= length { - return true - } - - return yaml_parser_update_buffer(parser, length) -} - -/* - * Advance the buffer pointer. - */ -func skip(parser *yaml_parser_t) { - parser.mark.index++ - parser.mark.column++ - parser.unread-- - parser.buffer_pos += width(parser.buffer[parser.buffer_pos]) -} - -func skip_line(parser *yaml_parser_t) { - if is_crlf_at(parser.buffer, parser.buffer_pos) { - parser.mark.index += 2 - parser.mark.column = 0 - parser.mark.line++ - parser.unread -= 2 - parser.buffer_pos += 2 - } else if is_break_at(parser.buffer, parser.buffer_pos) { - parser.mark.index++ - parser.mark.column = 0 - parser.mark.line++ - parser.unread-- - parser.buffer_pos += width(parser.buffer[parser.buffer_pos]) - } -} - -/* - * Copy a character to a string buffer and advance pointers. - */ - -func read(parser *yaml_parser_t, s []byte) []byte { - w := width(parser.buffer[parser.buffer_pos]) - if w == 0 { - panic("invalid character sequence") - } - if len(s) == 0 { - s = make([]byte, 0, 32) - } - if w == 1 && len(s)+w <= cap(s) { - s = s[:len(s)+1] - s[len(s)-1] = parser.buffer[parser.buffer_pos] - parser.buffer_pos++ - } else { - s = append(s, parser.buffer[parser.buffer_pos:parser.buffer_pos+w]...) - parser.buffer_pos += w - } - parser.mark.index++ - parser.mark.column++ - parser.unread-- - return s -} - -/* - * Copy a line break character to a string buffer and advance pointers. - */ -func read_line(parser *yaml_parser_t, s []byte) []byte { - buf := parser.buffer - pos := parser.buffer_pos - if buf[pos] == '\r' && buf[pos+1] == '\n' { - /* CR LF . LF */ - s = append(s, '\n') - parser.buffer_pos += 2 - parser.mark.index++ - parser.unread-- - } else if buf[pos] == '\r' || buf[pos] == '\n' { - /* CR|LF . LF */ - s = append(s, '\n') - parser.buffer_pos += 1 - } else if buf[pos] == '\xC2' && buf[pos+1] == '\x85' { - /* NEL . LF */ - s = append(s, '\n') - parser.buffer_pos += 2 - } else if buf[pos] == '\xE2' && buf[pos+1] == '\x80' && - (buf[pos+2] == '\xA8' || buf[pos+2] == '\xA9') { - // LS|PS . LS|PS - s = append(s, buf[parser.buffer_pos:pos+3]...) - parser.buffer_pos += 3 - } else { - return s - } - - parser.mark.index++ - parser.mark.column = 0 - parser.mark.line++ - parser.unread-- - return s -} - -/* - * Get the next token. - */ - -func yaml_parser_scan(parser *yaml_parser_t, token *yaml_token_t) bool { - /* Erase the token object. */ - *token = yaml_token_t{} - - /* No tokens after STREAM-END or error. */ - - if parser.stream_end_produced || parser.error != yaml_NO_ERROR { - return true - } - - /* Ensure that the tokens queue contains enough tokens. */ - - if !parser.token_available { - if !yaml_parser_fetch_more_tokens(parser) { - return false - } - } - - /* Fetch the next token from the queue. */ - - *token = parser.tokens[parser.tokens_head] - parser.tokens_head++ - parser.token_available = false - parser.tokens_parsed++ - - if token.token_type == yaml_STREAM_END_TOKEN { - parser.stream_end_produced = true - } - - return true -} - -/* - * Set the scanner error and return 0. - */ - -func yaml_parser_set_scanner_error(parser *yaml_parser_t, context string, - context_mark YAML_mark_t, problem string) bool { - parser.error = yaml_SCANNER_ERROR - parser.context = context - parser.context_mark = context_mark - parser.problem = problem - parser.problem_mark = parser.mark - - return false -} - -func yaml_parser_set_scanner_tag_error(parser *yaml_parser_t, directive bool, context_mark YAML_mark_t, problem string) bool { - context := "while parsing a %TAG directive" - if directive { - context = "while parsing a tag" - } - return yaml_parser_set_scanner_error(parser, context, context_mark, "did not find URI escaped octet") -} - -/* - * Ensure that the tokens queue contains at least one token which can be - * returned to the Parser. - */ - -func yaml_parser_fetch_more_tokens(parser *yaml_parser_t) bool { - /* While we need more tokens to fetch, do it. */ - - for { - /* - * Check if we really need to fetch more tokens. - */ - - need_more_tokens := false - - if parser.tokens_head == len(parser.tokens) { - /* Queue is empty. */ - - need_more_tokens = true - } else { - - /* Check if any potential simple key may occupy the head position. */ - - if !yaml_parser_stale_simple_keys(parser) { - return false - } - - for i := range parser.simple_keys { - simple_key := &parser.simple_keys[i] - - if simple_key.possible && - simple_key.token_number == parser.tokens_parsed { - need_more_tokens = true - break - } - } - } - if len(parser.simple_keys) > 0 { - - } - /* We are finished. */ - - if !need_more_tokens { - break - } - - /* Fetch the next token. */ - - if !yaml_parser_fetch_next_token(parser) { - return false - } - - } - - parser.token_available = true - - return true -} - -/* - * The dispatcher for token fetchers. - */ - -func yaml_parser_fetch_next_token(parser *yaml_parser_t) bool { - /* Ensure that the buffer is initialized. */ - - if !cache(parser, 1) { - return false - } - - /* Check if we just started scanning. Fetch STREAM-START then. */ - - if !parser.stream_start_produced { - return yaml_parser_fetch_stream_start(parser) - } - - /* Eat whitespaces and comments until we reach the next token. */ - - if !yaml_parser_scan_to_next_token(parser) { - return false - } - - /* Remove obsolete potential simple keys. */ - - if !yaml_parser_stale_simple_keys(parser) { - return false - } - - /* Check the indentation level against the current column. */ - - if !yaml_parser_unroll_indent(parser, parser.mark.column) { - return false - } - - /* - * Ensure that the buffer contains at least 4 characters. 4 is the length - * of the longest indicators ('--- ' and '... '). - */ - - if !cache(parser, 4) { - return false - } - - /* Is it the end of the stream? */ - buf := parser.buffer - pos := parser.buffer_pos - - if is_z(buf[pos]) { - return yaml_parser_fetch_stream_end(parser) - } - - /* Is it a directive? */ - - if parser.mark.column == 0 && buf[pos] == '%' { - return yaml_parser_fetch_directive(parser) - } - - /* Is it the document start indicator? */ - - if parser.mark.column == 0 && - buf[pos] == '-' && buf[pos+1] == '-' && buf[pos+2] == '-' && - is_blankz_at(buf, pos+3) { - return yaml_parser_fetch_document_indicator(parser, - yaml_DOCUMENT_START_TOKEN) - } - - /* Is it the document end indicator? */ - - if parser.mark.column == 0 && - buf[pos] == '.' && buf[pos+1] == '.' && buf[pos+2] == '.' && - is_blankz_at(buf, pos+3) { - return yaml_parser_fetch_document_indicator(parser, - yaml_DOCUMENT_END_TOKEN) - } - - /* Is it the flow sequence start indicator? */ - - if buf[pos] == '[' { - return yaml_parser_fetch_flow_collection_start(parser, - yaml_FLOW_SEQUENCE_START_TOKEN) - } - - /* Is it the flow mapping start indicator? */ - - if buf[pos] == '{' { - return yaml_parser_fetch_flow_collection_start(parser, - yaml_FLOW_MAPPING_START_TOKEN) - } - - /* Is it the flow sequence end indicator? */ - - if buf[pos] == ']' { - return yaml_parser_fetch_flow_collection_end(parser, - yaml_FLOW_SEQUENCE_END_TOKEN) - } - - /* Is it the flow mapping end indicator? */ - - if buf[pos] == '}' { - return yaml_parser_fetch_flow_collection_end(parser, - yaml_FLOW_MAPPING_END_TOKEN) - } - - /* Is it the flow entry indicator? */ - - if buf[pos] == ',' { - return yaml_parser_fetch_flow_entry(parser) - } - - /* Is it the block entry indicator? */ - if buf[pos] == '-' && is_blankz_at(buf, pos+1) { - return yaml_parser_fetch_block_entry(parser) - } - - /* Is it the key indicator? */ - if buf[pos] == '?' && - (parser.flow_level > 0 || is_blankz_at(buf, pos+1)) { - return yaml_parser_fetch_key(parser) - } - - /* Is it the value indicator? */ - if buf[pos] == ':' && - (parser.flow_level > 0 || is_blankz_at(buf, pos+1)) { - return yaml_parser_fetch_value(parser) - } - - /* Is it an alias? */ - if buf[pos] == '*' { - return yaml_parser_fetch_anchor(parser, yaml_ALIAS_TOKEN) - } - - /* Is it an anchor? */ - - if buf[pos] == '&' { - return yaml_parser_fetch_anchor(parser, yaml_ANCHOR_TOKEN) - } - - /* Is it a tag? */ - - if buf[pos] == '!' { - return yaml_parser_fetch_tag(parser) - } - - /* Is it a literal scalar? */ - if buf[pos] == '|' && parser.flow_level == 0 { - return yaml_parser_fetch_block_scalar(parser, true) - } - - /* Is it a folded scalar? */ - if buf[pos] == '>' && parser.flow_level == 0 { - return yaml_parser_fetch_block_scalar(parser, false) - } - - /* Is it a single-quoted scalar? */ - - if buf[pos] == '\'' { - return yaml_parser_fetch_flow_scalar(parser, true) - } - - /* Is it a double-quoted scalar? */ - if buf[pos] == '"' { - return yaml_parser_fetch_flow_scalar(parser, false) - } - - /* - * Is it a plain scalar? - * - * A plain scalar may start with any non-blank characters except - * - * '-', '?', ':', ',', '[', ']', '{', '}', - * '#', '&', '*', '!', '|', '>', '\'', '\"', - * '%', '@', '`'. - * - * In the block context (and, for the '-' indicator, in the flow context - * too), it may also start with the characters - * - * '-', '?', ':' - * - * if it is followed by a non-space character. - * - * The last rule is more restrictive than the specification requires. - */ - - b := buf[pos] - if !(is_blankz_at(buf, pos) || b == '-' || - b == '?' || b == ':' || - b == ',' || b == '[' || - b == ']' || b == '{' || - b == '}' || b == '#' || - b == '&' || b == '*' || - b == '!' || b == '|' || - b == '>' || b == '\'' || - b == '"' || b == '%' || - b == '@' || b == '`') || - (b == '-' && !is_blank(buf[pos+1])) || - (parser.flow_level == 0 && - (buf[pos] == '?' || buf[pos] == ':') && - !is_blank(buf[pos+1])) { - return yaml_parser_fetch_plain_scalar(parser) - } - - /* - * If we don't determine the token type so far, it is an error. - */ - - return yaml_parser_set_scanner_error(parser, - "while scanning for the next token", parser.mark, - "found character that cannot start any token") -} - -/* - * Check the list of potential simple keys and remove the positions that - * cannot contain simple keys anymore. - */ - -func yaml_parser_stale_simple_keys(parser *yaml_parser_t) bool { - /* Check for a potential simple key for each flow level. */ - - for i := range parser.simple_keys { - /* - * The specification requires that a simple key - * - * - is limited to a single line, - * - is shorter than 1024 characters. - */ - - simple_key := &parser.simple_keys[i] - if simple_key.possible && - (simple_key.mark.line < parser.mark.line || - simple_key.mark.index+1024 < parser.mark.index) { - - /* Check if the potential simple key to be removed is required. */ - - if simple_key.required { - return yaml_parser_set_scanner_error(parser, - "while scanning a simple key", simple_key.mark, - "could not find expected ':'") - } - - simple_key.possible = false - } - } - - return true -} - -/* - * Check if a simple key may start at the current position and add it if - * needed. - */ - -func yaml_parser_save_simple_key(parser *yaml_parser_t) bool { - /* - * A simple key is required at the current position if the scanner is in - * the block context and the current column coincides with the indentation - * level. - */ - - required := (parser.flow_level == 0 && - parser.indent == parser.mark.column) - - /* - * A simple key is required only when it is the first token in the current - * line. Therefore it is always allowed. But we add a check anyway. - */ - if required && !parser.simple_key_allowed { - panic("impossible") /* Impossible. */ - } - - /* - * If the current position may start a simple key, save it. - */ - - if parser.simple_key_allowed { - simple_key := yaml_simple_key_t{ - possible: true, - required: required, - token_number: parser.tokens_parsed + (len(parser.tokens) - parser.tokens_head), - } - simple_key.mark = parser.mark - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_keys[len(parser.simple_keys)-1] = simple_key - } - - return true -} - -/* - * Remove a potential simple key at the current flow level. - */ - -func yaml_parser_remove_simple_key(parser *yaml_parser_t) bool { - simple_key := &parser.simple_keys[len(parser.simple_keys)-1] - - if simple_key.possible { - /* If the key is required, it is an error. */ - - if simple_key.required { - return yaml_parser_set_scanner_error(parser, - "while scanning a simple key", simple_key.mark, - "could not find expected ':'") - } - } - - /* Remove the key from the stack. */ - - simple_key.possible = false - - return true -} - -/* - * Increase the flow level and resize the simple key list if needed. - */ - -func yaml_parser_increase_flow_level(parser *yaml_parser_t) bool { - /* Reset the simple key on the next level. */ - - parser.simple_keys = append(parser.simple_keys, yaml_simple_key_t{}) - - /* Increase the flow level. */ - - parser.flow_level++ - - return true -} - -/* - * Decrease the flow level. - */ - -func yaml_parser_decrease_flow_level(parser *yaml_parser_t) bool { - if parser.flow_level > 0 { - parser.flow_level-- - parser.simple_keys = parser.simple_keys[:len(parser.simple_keys)-1] - } - - return true -} - -/* - * Push the current indentation level to the stack and set the new level - * the current column is greater than the indentation level. In this case, - * append or insert the specified token into the token queue. - * - */ - -func yaml_parser_roll_indent(parser *yaml_parser_t, column int, - number int, token_type yaml_token_type_t, mark YAML_mark_t) bool { - /* In the flow context, do nothing. */ - - if parser.flow_level > 0 { - return true - } - - if parser.indent == -1 || parser.indent < column { - /* - * Push the current indentation level to the stack and set the new - * indentation level. - */ - - parser.indents = append(parser.indents, parser.indent) - parser.indent = column - - /* Create a token and insert it into the queue. */ - token := yaml_token_t{ - token_type: token_type, - start_mark: mark, - end_mark: mark, - } - - // number == -1 -> enqueue otherwise insert - if number > -1 { - number -= parser.tokens_parsed - } - insert_token(parser, number, &token) - } - - return true -} - -/* - * Pop indentation levels from the indents stack until the current level - * becomes less or equal to the column. For each indentation level, append - * the BLOCK-END token. - */ - -func yaml_parser_unroll_indent(parser *yaml_parser_t, column int) bool { - /* In the flow context, do nothing. */ - - if parser.flow_level > 0 { - return true - } - - /* - * column is unsigned and parser->indent is signed, so if - * parser->indent is less than zero the conditional in the while - * loop below is incorrect. Guard against that. - */ - - if parser.indent < 0 { - return true - } - - /* Loop through the indentation levels in the stack. */ - - for parser.indent > column { - /* Create a token and append it to the queue. */ - token := yaml_token_t{ - token_type: yaml_BLOCK_END_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - } - insert_token(parser, -1, &token) - - /* Pop the indentation level. */ - parser.indent = parser.indents[len(parser.indents)-1] - parser.indents = parser.indents[:len(parser.indents)-1] - - } - - return true -} - -/* - * Pop indentation levels from the indents stack until the current - * level resets to -1. For each indentation level, append the - * BLOCK-END token. - */ - -func yaml_parser_reset_indent(parser *yaml_parser_t) bool { - /* In the flow context, do nothing. */ - - if parser.flow_level > 0 { - return true - } - - /* Loop through the indentation levels in the stack. */ - - for parser.indent > -1 { - /* Create a token and append it to the queue. */ - - token := yaml_token_t{ - token_type: yaml_BLOCK_END_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - } - insert_token(parser, -1, &token) - - /* Pop the indentation level. */ - parser.indent = parser.indents[len(parser.indents)-1] - parser.indents = parser.indents[:len(parser.indents)-1] - } - - return true -} - -/* - * Initialize the scanner and produce the STREAM-START token. - */ - -func yaml_parser_fetch_stream_start(parser *yaml_parser_t) bool { - /* Set the initial indentation. */ - - parser.indent = -1 - - /* Initialize the simple key stack. */ - parser.simple_keys = append(parser.simple_keys, yaml_simple_key_t{}) - - /* A simple key is allowed at the beginning of the stream. */ - - parser.simple_key_allowed = true - - /* We have started. */ - - parser.stream_start_produced = true - - /* Create the STREAM-START token and append it to the queue. */ - token := yaml_token_t{ - token_type: yaml_STREAM_START_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - encoding: parser.encoding, - } - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the STREAM-END token and shut down the scanner. - */ - -func yaml_parser_fetch_stream_end(parser *yaml_parser_t) bool { - /* Force new line. */ - - if parser.mark.column != 0 { - parser.mark.column = 0 - parser.mark.line++ - } - - /* Reset the indentation level. */ - - if !yaml_parser_reset_indent(parser) { - return false - } - - /* Reset simple keys. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - /* Create the STREAM-END token and append it to the queue. */ - token := yaml_token_t{ - token_type: yaml_STREAM_END_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce a VERSION-DIRECTIVE or TAG-DIRECTIVE token. - */ - -func yaml_parser_fetch_directive(parser *yaml_parser_t) bool { - /* Reset the indentation level. */ - - if !yaml_parser_reset_indent(parser) { - return false - } - - /* Reset simple keys. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - /* Create the YAML-DIRECTIVE or TAG-DIRECTIVE token. */ - var token yaml_token_t - if !yaml_parser_scan_directive(parser, &token) { - return false - } - - /* Append the token to the queue. */ - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the DOCUMENT-START or DOCUMENT-END token. - */ - -func yaml_parser_fetch_document_indicator(parser *yaml_parser_t, - token_type yaml_token_type_t) bool { - - /* Reset the indentation level. */ - - if !yaml_parser_reset_indent(parser) { - return false - } - - /* Reset simple keys. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - /* Consume the token. */ - - start_mark := parser.mark - - skip(parser) - skip(parser) - skip(parser) - - end_mark := parser.mark - - /* Create the DOCUMENT-START or DOCUMENT-END token. */ - - token := yaml_token_t{ - token_type: token_type, - start_mark: start_mark, - end_mark: end_mark, - } - - /* Append the token to the queue. */ - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the FLOW-SEQUENCE-START or FLOW-MAPPING-START token. - */ - -func yaml_parser_fetch_flow_collection_start(parser *yaml_parser_t, - token_type yaml_token_type_t) bool { - - /* The indicators '[' and '{' may start a simple key. */ - - if !yaml_parser_save_simple_key(parser) { - return false - } - - /* Increase the flow level. */ - - if !yaml_parser_increase_flow_level(parser) { - return false - } - - /* A simple key may follow the indicators '[' and '{'. */ - - parser.simple_key_allowed = true - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the FLOW-SEQUENCE-START of FLOW-MAPPING-START token. */ - - token := yaml_token_t{ - token_type: token_type, - start_mark: start_mark, - end_mark: end_mark, - } - - /* Append the token to the queue. */ - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the FLOW-SEQUENCE-END or FLOW-MAPPING-END token. - */ - -func yaml_parser_fetch_flow_collection_end(parser *yaml_parser_t, - token_type yaml_token_type_t) bool { - - /* Reset any potential simple key on the current flow level. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - /* Decrease the flow level. */ - - if !yaml_parser_decrease_flow_level(parser) { - return false - } - - /* No simple keys after the indicators ']' and '}'. */ - - parser.simple_key_allowed = false - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the FLOW-SEQUENCE-END of FLOW-MAPPING-END token. */ - - token := yaml_token_t{ - token_type: token_type, - start_mark: start_mark, - end_mark: end_mark, - } - - /* Append the token to the queue. */ - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the FLOW-ENTRY token. - */ - -func yaml_parser_fetch_flow_entry(parser *yaml_parser_t) bool { - - /* Reset any potential simple keys on the current flow level. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - /* Simple keys are allowed after ','. */ - - parser.simple_key_allowed = true - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the FLOW-ENTRY token and append it to the queue. */ - - token := yaml_token_t{ - token_type: yaml_FLOW_ENTRY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the BLOCK-ENTRY token. - */ - -func yaml_parser_fetch_block_entry(parser *yaml_parser_t) bool { - - /* Check if the scanner is in the block context. */ - - if parser.flow_level == 0 { - /* Check if we are allowed to start a new entry. */ - - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "block sequence entries are not allowed in this context") - } - - /* Add the BLOCK-SEQUENCE-START token if needed. */ - - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, - yaml_BLOCK_SEQUENCE_START_TOKEN, parser.mark) { - return false - } - } else { - /* - * It is an error for the '-' indicator to occur in the flow context, - * but we let the Parser detect and report about it because the Parser - * is able to point to the context. - */ - } - - /* Reset any potential simple keys on the current flow level. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - /* Simple keys are allowed after '-'. */ - - parser.simple_key_allowed = true - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the BLOCK-ENTRY token and append it to the queue. */ - - token := yaml_token_t{ - token_type: yaml_BLOCK_ENTRY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the KEY token. - */ - -func yaml_parser_fetch_key(parser *yaml_parser_t) bool { - /* In the block context, additional checks are required. */ - - if parser.flow_level == 0 { - /* Check if we are allowed to start a new key (not nessesary simple). */ - - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "mapping keys are not allowed in this context") - } - - /* Add the BLOCK-MAPPING-START token if needed. */ - - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, - yaml_BLOCK_MAPPING_START_TOKEN, parser.mark) { - return false - } - } - - /* Reset any potential simple keys on the current flow level. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - /* Simple keys are allowed after '?' in the block context. */ - - parser.simple_key_allowed = (parser.flow_level == 0) - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the KEY token and append it to the queue. */ - - token := yaml_token_t{ - token_type: yaml_KEY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the VALUE token. - */ - -func yaml_parser_fetch_value(parser *yaml_parser_t) bool { - - simple_key := &parser.simple_keys[len(parser.simple_keys)-1] - - /* Have we found a simple key? */ - - if simple_key.possible { - - /* Create the KEY token and insert it into the queue. */ - - token := yaml_token_t{ - token_type: yaml_KEY_TOKEN, - start_mark: simple_key.mark, - end_mark: simple_key.mark, - } - - insert_token(parser, simple_key.token_number-parser.tokens_parsed, &token) - - /* In the block context, we may need to add the BLOCK-MAPPING-START token. */ - - if !yaml_parser_roll_indent(parser, simple_key.mark.column, - simple_key.token_number, - yaml_BLOCK_MAPPING_START_TOKEN, simple_key.mark) { - return false - } - - /* Remove the simple key. */ - - simple_key.possible = false - - /* A simple key cannot follow another simple key. */ - - parser.simple_key_allowed = false - } else { - /* The ':' indicator follows a complex key. */ - - /* In the block context, extra checks are required. */ - - if parser.flow_level == 0 { - /* Check if we are allowed to start a complex value. */ - - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "mapping values are not allowed in this context") - } - - /* Add the BLOCK-MAPPING-START token if needed. */ - - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, - yaml_BLOCK_MAPPING_START_TOKEN, parser.mark) { - return false - } - } - - /* Simple keys after ':' are allowed in the block context. */ - - parser.simple_key_allowed = (parser.flow_level == 0) - } - - /* Consume the token. */ - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - /* Create the VALUE token and append it to the queue. */ - - token := yaml_token_t{ - token_type: yaml_VALUE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the ALIAS or ANCHOR token. - */ - -func yaml_parser_fetch_anchor(parser *yaml_parser_t, token_type yaml_token_type_t) bool { - - /* An anchor or an alias could be a simple key. */ - - if !yaml_parser_save_simple_key(parser) { - return false - } - - /* A simple key cannot follow an anchor or an alias. */ - - parser.simple_key_allowed = false - - /* Create the ALIAS or ANCHOR token and append it to the queue. */ - var token yaml_token_t - if !yaml_parser_scan_anchor(parser, &token, token_type) { - return false - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the TAG token. - */ - -func yaml_parser_fetch_tag(parser *yaml_parser_t) bool { - /* A tag could be a simple key. */ - - if !yaml_parser_save_simple_key(parser) { - return false - } - - /* A simple key cannot follow a tag. */ - - parser.simple_key_allowed = false - - /* Create the TAG token and append it to the queue. */ - var token yaml_token_t - if !yaml_parser_scan_tag(parser, &token) { - return false - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the SCALAR(...,literal) or SCALAR(...,folded) tokens. - */ - -func yaml_parser_fetch_block_scalar(parser *yaml_parser_t, literal bool) bool { - /* Remove any potential simple keys. */ - - if !yaml_parser_remove_simple_key(parser) { - return false - } - - /* A simple key may follow a block scalar. */ - - parser.simple_key_allowed = true - - /* Create the SCALAR token and append it to the queue. */ - var token yaml_token_t - if !yaml_parser_scan_block_scalar(parser, &token, literal) { - return false - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the SCALAR(...,single-quoted) or SCALAR(...,double-quoted) tokens. - */ - -func yaml_parser_fetch_flow_scalar(parser *yaml_parser_t, single bool) bool { - - /* A plain scalar could be a simple key. */ - - if !yaml_parser_save_simple_key(parser) { - return false - } - - /* A simple key cannot follow a flow scalar. */ - - parser.simple_key_allowed = false - - /* Create the SCALAR token and append it to the queue. */ - var token yaml_token_t - if !yaml_parser_scan_flow_scalar(parser, &token, single) { - return false - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Produce the SCALAR(...,plain) token. - */ - -func yaml_parser_fetch_plain_scalar(parser *yaml_parser_t) bool { - /* A plain scalar could be a simple key. */ - - if !yaml_parser_save_simple_key(parser) { - return false - } - - /* A simple key cannot follow a flow scalar. */ - - parser.simple_key_allowed = false - - /* Create the SCALAR token and append it to the queue. */ - var token yaml_token_t - if !yaml_parser_scan_plain_scalar(parser, &token) { - return false - } - - insert_token(parser, -1, &token) - - return true -} - -/* - * Eat whitespaces and comments until the next token is found. - */ - -func yaml_parser_scan_to_next_token(parser *yaml_parser_t) bool { - /* Until the next token is not found. */ - - for { - /* Allow the BOM mark to start a line. */ - - if !cache(parser, 1) { - return false - } - - if parser.mark.column == 0 && is_bom_at(parser.buffer, parser.buffer_pos) { - skip(parser) - } - - /* - * Eat whitespaces. - * - * Tabs are allowed: - * - * - in the flow context; - * - in the block context, but not at the beginning of the line or - * after '-', '?', or ':' (complex value). - */ - - if !cache(parser, 1) { - return false - } - - for parser.buffer[parser.buffer_pos] == ' ' || - ((parser.flow_level > 0 || !parser.simple_key_allowed) && - parser.buffer[parser.buffer_pos] == '\t') { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - /* Eat a comment until a line break. */ - - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz_at(parser.buffer, parser.buffer_pos) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - } - - /* If it is a line break, eat it. */ - - if is_break_at(parser.buffer, parser.buffer_pos) { - if !cache(parser, 2) { - return false - } - skip_line(parser) - - /* In the block context, a new line may start a simple key. */ - - if parser.flow_level == 0 { - parser.simple_key_allowed = true - } - } else { - /* We have found a token. */ - - break - } - } - - return true -} - -/* - * Scan a YAML-DIRECTIVE or TAG-DIRECTIVE token. - * - * Scope: - * %YAML 1.1 # a comment \n - * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - * %TAG !yaml! tag:yaml.org,2002: \n - * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - */ - -func yaml_parser_scan_directive(parser *yaml_parser_t, token *yaml_token_t) bool { - /* Eat '%'. */ - - start_mark := parser.mark - - skip(parser) - - /* Scan the directive name. */ - var name []byte - if !yaml_parser_scan_directive_name(parser, start_mark, &name) { - return false - } - - /* Is it a YAML directive? */ - var major, minor int - if bytes.Equal(name, []byte("YAML")) { - /* Scan the VERSION directive value. */ - - if !yaml_parser_scan_version_directive_value(parser, start_mark, - &major, &minor) { - return false - } - - end_mark := parser.mark - - /* Create a VERSION-DIRECTIVE token. */ - - *token = yaml_token_t{ - token_type: yaml_VERSION_DIRECTIVE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - major: major, - minor: minor, - } - } else if bytes.Equal(name, []byte("TAG")) { - /* Is it a TAG directive? */ - /* Scan the TAG directive value. */ - var handle, prefix []byte - if !yaml_parser_scan_tag_directive_value(parser, start_mark, - &handle, &prefix) { - return false - } - - end_mark := parser.mark - - /* Create a TAG-DIRECTIVE token. */ - - *token = yaml_token_t{ - token_type: yaml_TAG_DIRECTIVE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: handle, - prefix: prefix, - } - } else { - /* Unknown directive. */ - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "found uknown directive name") - return false - } - - /* Eat the rest of the line including any comments. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz_at(parser.buffer, parser.buffer_pos) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - } - - /* Check if we are at the end of the line. */ - - if !is_breakz_at(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "did not find expected comment or line break") - return false - } - - /* Eat a line break. */ - - if is_break_at(parser.buffer, parser.buffer_pos) { - if !cache(parser, 2) { - return false - } - skip_line(parser) - } - - return true -} - -/* - * Scan the directive name. - * - * Scope: - * %YAML 1.1 # a comment \n - * ^^^^ - * %TAG !yaml! tag:yaml.org,2002: \n - * ^^^ - */ - -func yaml_parser_scan_directive_name(parser *yaml_parser_t, - start_mark YAML_mark_t, name *[]byte) bool { - - /* Consume the directive name. */ - - if !cache(parser, 1) { - return false - } - - var s []byte - for is_alpha(parser.buffer[parser.buffer_pos]) { - s = read(parser, s) - if !cache(parser, 1) { - return false - } - } - - /* Check if the name is empty. */ - - if len(s) == 0 { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "could not find expected directive name") - return false - } - - /* Check for an blank character after the name. */ - - if !is_blankz_at(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "found unexpected non-alphabetical character") - return false - } - - *name = s - - return true -} - -/* - * Scan the value of VERSION-DIRECTIVE. - * - * Scope: - * %YAML 1.1 # a comment \n - * ^^^^^^ - */ - -func yaml_parser_scan_version_directive_value(parser *yaml_parser_t, - start_mark YAML_mark_t, major *int, minor *int) bool { - /* Eat whitespaces. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - /* Consume the major version number. */ - - if !yaml_parser_scan_version_directive_number(parser, start_mark, major) { - return false - } - - /* Eat '.'. */ - - if parser.buffer[parser.buffer_pos] != '.' { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "did not find expected digit or '.' character") - } - - skip(parser) - - /* Consume the minor version number. */ - - if !yaml_parser_scan_version_directive_number(parser, start_mark, minor) { - return false - } - - return true -} - -const MAX_NUMBER_LENGTH = 9 - -/* - * Scan the version number of VERSION-DIRECTIVE. - * - * Scope: - * %YAML 1.1 # a comment \n - * ^ - * %YAML 1.1 # a comment \n - * ^ - */ - -func yaml_parser_scan_version_directive_number(parser *yaml_parser_t, - start_mark YAML_mark_t, number *int) bool { - - /* Repeat while the next character is digit. */ - - if !cache(parser, 1) { - return false - } - - value := 0 - length := 0 - for is_digit(parser.buffer[parser.buffer_pos]) { - /* Check if the number is too long. */ - - length++ - if length > MAX_NUMBER_LENGTH { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "found extremely long version number") - } - - value = value*10 + as_digit(parser.buffer[parser.buffer_pos]) - - skip(parser) - - if !cache(parser, 1) { - return false - } - } - - /* Check if the number was present. */ - - if length == 0 { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "did not find expected version number") - } - - *number = value - - return true -} - -/* - * Scan the value of a TAG-DIRECTIVE token. - * - * Scope: - * %TAG !yaml! tag:yaml.org,2002: \n - * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - */ - -func yaml_parser_scan_tag_directive_value(parser *yaml_parser_t, - start_mark YAML_mark_t, handle, prefix *[]byte) bool { - - /* Eat whitespaces. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - /* Scan a handle. */ - var handle_value []byte - if !yaml_parser_scan_tag_handle(parser, true, start_mark, &handle_value) { - return false - } - - /* Expect a whitespace. */ - - if !cache(parser, 1) { - return false - } - - if !is_blank(parser.buffer[parser.buffer_pos]) { - yaml_parser_set_scanner_error(parser, "while scanning a %TAG directive", - start_mark, "did not find expected whitespace") - return false - } - - /* Eat whitespaces. */ - - for is_blank(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - /* Scan a prefix. */ - var prefix_value []byte - if !yaml_parser_scan_tag_uri(parser, true, nil, start_mark, &prefix_value) { - return false - } - - /* Expect a whitespace or line break. */ - - if !cache(parser, 1) { - return false - } - - if !is_blankz_at(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a %TAG directive", - start_mark, "did not find expected whitespace or line break") - return false - } - - *handle = handle_value - *prefix = prefix_value - - return true -} - -func yaml_parser_scan_anchor(parser *yaml_parser_t, token *yaml_token_t, - token_type yaml_token_type_t) bool { - - /* Eat the indicator character. */ - - start_mark := parser.mark - - skip(parser) - - /* Consume the value. */ - - if !cache(parser, 1) { - return false - } - - var s []byte - for is_alpha(parser.buffer[parser.buffer_pos]) { - s = read(parser, s) - if !cache(parser, 1) { - return false - } - } - - end_mark := parser.mark - - /* - * Check if length of the anchor is greater than 0 and it is followed by - * a whitespace character or one of the indicators: - * - * '?', ':', ',', ']', '}', '%', '@', '`'. - */ - - b := parser.buffer[parser.buffer_pos] - if len(s) == 0 || !(is_blankz_at(parser.buffer, parser.buffer_pos) || b == '?' || - b == ':' || b == ',' || - b == ']' || b == '}' || - b == '%' || b == '@' || - b == '`') { - context := "while scanning an anchor" - if token_type != yaml_ANCHOR_TOKEN { - context = "while scanning an alias" - } - yaml_parser_set_scanner_error(parser, context, start_mark, - "did not find expected alphabetic or numeric character") - return false - } - - /* Create a token. */ - *token = yaml_token_t{ - token_type: token_type, - start_mark: start_mark, - end_mark: end_mark, - value: s, - } - - return true -} - -/* - * Scan a TAG token. - */ - -func yaml_parser_scan_tag(parser *yaml_parser_t, token *yaml_token_t) bool { - start_mark := parser.mark - - /* Check if the tag is in the canonical form. */ - - if !cache(parser, 2) { - return false - } - - var handle []byte - var suffix []byte - if parser.buffer[parser.buffer_pos+1] == '<' { - /* Set the handle to '' */ - - /* Eat '!<' */ - - skip(parser) - skip(parser) - - /* Consume the tag value. */ - - if !yaml_parser_scan_tag_uri(parser, false, nil, start_mark, &suffix) { - return false - } - - /* Check for '>' and eat it. */ - - if parser.buffer[parser.buffer_pos] != '>' { - yaml_parser_set_scanner_error(parser, "while scanning a tag", - start_mark, "did not find the expected '>'") - return false - } - - skip(parser) - } else if is_blank(parser.buffer[parser.buffer_pos+1]) { - // NON-SPECIFIED - skip(parser) - } else { - /* The tag has either the '!suffix' or the '!handle!suffix' form. */ - - /* First, try to scan a handle. */ - - if !yaml_parser_scan_tag_handle(parser, false, start_mark, &handle) { - return false - } - - /* Check if it is, indeed, handle. */ - - if handle[0] == '!' && len(handle) > 1 && handle[len(handle)-1] == '!' { - /* Scan the suffix now. */ - - if !yaml_parser_scan_tag_uri(parser, false, nil, start_mark, &suffix) { - return false - } - } else { - /* It wasn't a handle after all. Scan the rest of the tag. */ - - if !yaml_parser_scan_tag_uri(parser, false, handle, start_mark, &suffix) { - return false - } - - /* Set the handle to '!'. */ - - handle = []byte{'!'} - - /* - * A special case: the '!' tag. Set the handle to '' and the - * suffix to '!'. - */ - - if len(suffix) == 0 { - handle, suffix = suffix, handle - } - - } - } - - /* Check the character which ends the tag. */ - - if !cache(parser, 1) { - return false - } - - if !is_blankz_at(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a tag", - start_mark, "did not find expected whitespace or line break") - return false - } - - end_mark := parser.mark - - /* Create a token. */ - - *token = yaml_token_t{ - token_type: yaml_TAG_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: handle, - suffix: suffix, - } - - return true -} - -/* - * Scan a tag handle. - */ - -func yaml_parser_scan_tag_handle(parser *yaml_parser_t, directive bool, - start_mark YAML_mark_t, handle *[]byte) bool { - - /* Check the initial '!' character. */ - - if !cache(parser, 1) { - return false - } - - if parser.buffer[parser.buffer_pos] != '!' { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected '!'") - return false - } - - /* Copy the '!' character. */ - var s []byte - s = read(parser, s) - - /* Copy all subsequent alphabetical and numerical characters. */ - - if !cache(parser, 1) { - return false - } - - for is_alpha(parser.buffer[parser.buffer_pos]) { - s = read(parser, s) - if !cache(parser, 1) { - return false - } - } - - /* Check if the trailing character is '!' and copy it. */ - - if parser.buffer[parser.buffer_pos] == '!' { - s = read(parser, s) - } else { - /* - * It's either the '!' tag or not really a tag handle. If it's a %TAG - * directive, it's an error. If it's a tag token, it must be a part of - * URI. - */ - - if directive && !(s[0] == '!' && len(s) == 1) { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected '!'") - return false - } - } - - *handle = s - - return true -} - -/* - * Scan a tag. - */ - -func yaml_parser_scan_tag_uri(parser *yaml_parser_t, directive bool, - head []byte, start_mark YAML_mark_t, uri *[]byte) bool { - - var s []byte - /* - * Copy the head if needed. - * - * Note that we don't copy the leading '!' character. - */ - if len(head) > 1 { - s = append(s, head[1:]...) - } - - /* Scan the tag. */ - if !cache(parser, 1) { - return false - } - - /* - * The set of characters that may appear in URI is as follows: - * - * '0'-'9', 'A'-'Z', 'a'-'z', '_', '-', ';', '/', '?', ':', '@', '&', - * '=', '+', '$', ',', '.', '!', '~', '*', '\'', '(', ')', '[', ']', - * '%'. - */ - - b := parser.buffer[parser.buffer_pos] - for is_alpha(b) || b == ';' || - b == '/' || b == '?' || - b == ':' || b == '@' || - b == '&' || b == '=' || - b == '+' || b == '$' || - b == ',' || b == '.' || - b == '!' || b == '~' || - b == '*' || b == '\'' || - b == '(' || b == ')' || - b == '[' || b == ']' || - b == '%' { - /* Check if it is a URI-escape sequence. */ - - if b == '%' { - if !yaml_parser_scan_uri_escapes(parser, - directive, start_mark, &s) { - return false - } - } else { - s = read(parser, s) - } - - if !cache(parser, 1) { - return false - } - b = parser.buffer[parser.buffer_pos] - } - - /* Check if the tag is non-empty. */ - - if len(s) == 0 { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected tag URI") - return false - } - - *uri = s - - return true -} - -/* - * Decode an URI-escape sequence corresponding to a single UTF-8 character. - */ - -func yaml_parser_scan_uri_escapes(parser *yaml_parser_t, directive bool, - start_mark YAML_mark_t, s *[]byte) bool { - - /* Decode the required number of characters. */ - w := 10 - for w > 0 { - - /* Check for a URI-escaped octet. */ - - if !cache(parser, 3) { - return false - } - - if !(parser.buffer[parser.buffer_pos] == '%' && - is_hex(parser.buffer[parser.buffer_pos+1]) && - is_hex(parser.buffer[parser.buffer_pos+2])) { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find URI escaped octet") - } - - /* Get the octet. */ - octet := byte((as_hex(parser.buffer[parser.buffer_pos+1]) << 4) + - as_hex(parser.buffer[parser.buffer_pos+2])) - - /* If it is the leading octet, determine the length of the UTF-8 sequence. */ - - if w == 10 { - w = width(octet) - if w == 0 { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "found an incorrect leading UTF-8 octet") - } - } else { - /* Check if the trailing octet is correct. */ - - if (octet & 0xC0) != 0x80 { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "found an incorrect trailing UTF-8 octet") - } - } - - /* Copy the octet and move the pointers. */ - - *s = append(*s, octet) - skip(parser) - skip(parser) - skip(parser) - w-- - } - - return true -} - -/* - * Scan a block scalar. - */ - -func yaml_parser_scan_block_scalar(parser *yaml_parser_t, token *yaml_token_t, - literal bool) bool { - - /* Eat the indicator '|' or '>'. */ - - start_mark := parser.mark - - skip(parser) - - /* Scan the additional block scalar indicators. */ - - if !cache(parser, 1) { - return false - } - - /* Check for a chomping indicator. */ - chomping := 0 - increment := 0 - if parser.buffer[parser.buffer_pos] == '+' || parser.buffer[parser.buffer_pos] == '-' { - /* Set the chomping method and eat the indicator. */ - - if parser.buffer[parser.buffer_pos] == '+' { - chomping = +1 - } else { - chomping = -1 - } - - skip(parser) - - /* Check for an indentation indicator. */ - - if !cache(parser, 1) { - return false - } - - if is_digit(parser.buffer[parser.buffer_pos]) { - /* Check that the indentation is greater than 0. */ - - if parser.buffer[parser.buffer_pos] == '0' { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found an indentation indicator equal to 0") - return false - } - - /* Get the indentation level and eat the indicator. */ - - increment = as_digit(parser.buffer[parser.buffer_pos]) - - skip(parser) - } - } else if is_digit(parser.buffer[parser.buffer_pos]) { - - /* Do the same as above, but in the opposite order. */ - if parser.buffer[parser.buffer_pos] == '0' { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found an indentation indicator equal to 0") - return false - } - - increment = as_digit(parser.buffer[parser.buffer_pos]) - - skip(parser) - - if !cache(parser, 1) { - return false - } - - if parser.buffer[parser.buffer_pos] == '+' || parser.buffer[parser.buffer_pos] == '-' { - if parser.buffer[parser.buffer_pos] == '+' { - chomping = +1 - } else { - chomping = -1 - } - - skip(parser) - } - } - - /* Eat whitespaces and comments to the end of the line. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz_at(parser.buffer, parser.buffer_pos) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - } - - /* Check if we are at the end of the line. */ - - if !is_breakz_at(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "did not find expected comment or line break") - return false - } - - /* Eat a line break. */ - - if is_break_at(parser.buffer, parser.buffer_pos) { - if !cache(parser, 2) { - return false - } - - skip_line(parser) - } - - end_mark := parser.mark - - /* Set the indentation level if it was specified. */ - indent := 0 - if increment > 0 { - if parser.indent >= 0 { - indent = parser.indent + increment - } else { - indent = increment - } - } - - /* Scan the leading line breaks and determine the indentation level if needed. */ - var trailing_breaks []byte - if !yaml_parser_scan_block_scalar_breaks(parser, &indent, &trailing_breaks, - start_mark, &end_mark) { - return false - } - - /* Scan the block scalar content. */ - - if !cache(parser, 1) { - return false - } - - var s []byte - var leading_break []byte - leading_blank := false - trailing_blank := false - for parser.mark.column == indent && !is_z(parser.buffer[parser.buffer_pos]) { - - /* - * We are at the beginning of a non-empty line. - */ - - /* Is it a trailing whitespace? */ - - trailing_blank = is_blank(parser.buffer[parser.buffer_pos]) - - /* Check if we need to fold the leading line break. */ - - if !literal && len(leading_break) > 0 && leading_break[0] == '\n' && - !leading_blank && !trailing_blank { - /* Do we need to join the lines by space? */ - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } - leading_break = leading_break[:0] - } else { - s = append(s, leading_break...) - leading_break = leading_break[:0] - } - - /* Append the remaining line breaks. */ - s = append(s, trailing_breaks...) - trailing_breaks = trailing_breaks[:0] - - /* Is it a leading whitespace? */ - - leading_blank = is_blank(parser.buffer[parser.buffer_pos]) - - /* Consume the current line. */ - - for !is_breakz_at(parser.buffer, parser.buffer_pos) { - s = read(parser, s) - if !cache(parser, 1) { - return false - } - } - - /* Consume the line break. */ - - if !cache(parser, 2) { - return false - } - - leading_break = read_line(parser, leading_break) - - /* Eat the following indentation spaces and line breaks. */ - - if !yaml_parser_scan_block_scalar_breaks(parser, - &indent, &trailing_breaks, start_mark, &end_mark) { - return false - } - } - - /* Chomp the tail. */ - - if chomping != -1 { - s = append(s, leading_break...) - } - if chomping == 1 { - s = append(s, trailing_breaks...) - } - - /* Create a token. */ - - *token = yaml_token_t{ - token_type: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_LITERAL_SCALAR_STYLE, - } - if !literal { - token.style = yaml_FOLDED_SCALAR_STYLE - } - - return true -} - -/* - * Scan indentation spaces and line breaks for a block scalar. Determine the - * indentation level if needed. - */ - -func yaml_parser_scan_block_scalar_breaks(parser *yaml_parser_t, - indent *int, breaks *[]byte, - start_mark YAML_mark_t, end_mark *YAML_mark_t) bool { - - *end_mark = parser.mark - - /* Eat the indentation spaces and line breaks. */ - max_indent := 0 - for { - /* Eat the indentation spaces. */ - - if !cache(parser, 1) { - return false - } - - for (*indent == 0 || parser.mark.column < *indent) && - is_space(parser.buffer[parser.buffer_pos]) { - skip(parser) - if !cache(parser, 1) { - return false - } - } - if parser.mark.column > max_indent { - max_indent = parser.mark.column - } - - /* Check for a tab character messing the indentation. */ - - if (*indent == 0 || parser.mark.column < *indent) && - is_tab(parser.buffer[parser.buffer_pos]) { - return yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found a tab character where an indentation space is expected") - } - - /* Have we found a non-empty line? */ - - if !is_break_at(parser.buffer, parser.buffer_pos) { - break - } - - /* Consume the line break. */ - - if !cache(parser, 2) { - return false - } - - *breaks = read_line(parser, *breaks) - *end_mark = parser.mark - } - - /* Determine the indentation level if needed. */ - - if *indent == 0 { - *indent = max_indent - if *indent < parser.indent+1 { - *indent = parser.indent + 1 - } - if *indent < 1 { - *indent = 1 - } - } - - return true -} - -/* - * Scan a quoted scalar. - */ - -func yaml_parser_scan_flow_scalar(parser *yaml_parser_t, token *yaml_token_t, - single bool) bool { - - /* Eat the left quote. */ - - start_mark := parser.mark - - skip(parser) - - /* Consume the content of the quoted scalar. */ - var s []byte - var leading_break []byte - var trailing_breaks []byte - var whitespaces []byte - for { - /* Check that there are no document indicators at the beginning of the line. */ - - if !cache(parser, 4) { - return false - } - - if parser.mark.column == 0 && - ((parser.buffer[parser.buffer_pos] == '-' && - parser.buffer[parser.buffer_pos+1] == '-' && - parser.buffer[parser.buffer_pos+2] == '-') || - (parser.buffer[parser.buffer_pos] == '.' && - parser.buffer[parser.buffer_pos+1] == '.' && - parser.buffer[parser.buffer_pos+2] == '.')) && - is_blankz_at(parser.buffer, parser.buffer_pos+3) { - yaml_parser_set_scanner_error(parser, "while scanning a quoted scalar", - start_mark, "found unexpected document indicator") - return false - } - - /* Check for EOF. */ - - if is_z(parser.buffer[parser.buffer_pos]) { - yaml_parser_set_scanner_error(parser, "while scanning a quoted scalar", - start_mark, "found unexpected end of stream") - return false - } - - /* Consume non-blank characters. */ - - if !cache(parser, 2) { - return false - } - - leading_blanks := false - - for !is_blankz_at(parser.buffer, parser.buffer_pos) { - /* Check for an escaped single quote. */ - - if single && parser.buffer[parser.buffer_pos] == '\'' && - parser.buffer[parser.buffer_pos+1] == '\'' { - // Is is an escaped single quote. - s = append(s, '\'') - skip(parser) - skip(parser) - } else if single && parser.buffer[parser.buffer_pos] == '\'' { - /* Check for the right quote. */ - break - } else if !single && parser.buffer[parser.buffer_pos] == '"' { - /* Check for the right quote. */ - break - } else if !single && parser.buffer[parser.buffer_pos] == '\\' && - is_break_at(parser.buffer, parser.buffer_pos+1) { - - /* Check for an escaped line break. */ - if !cache(parser, 3) { - return false - } - - skip(parser) - skip_line(parser) - leading_blanks = true - break - } else if !single && parser.buffer[parser.buffer_pos] == '\\' { - - /* Check for an escape sequence. */ - - code_length := 0 - - /* Check the escape character. */ - - switch parser.buffer[parser.buffer_pos+1] { - case '0': - s = append(s, 0) - case 'a': - s = append(s, '\x07') - case 'b': - s = append(s, '\x08') - case 't', '\t': - s = append(s, '\x09') - case 'n': - s = append(s, '\x0A') - case 'v': - s = append(s, '\x0B') - case 'f': - s = append(s, '\x0C') - case 'r': - s = append(s, '\x0D') - case 'e': - s = append(s, '\x1B') - case ' ': - s = append(s, '\x20') - case '"': - s = append(s, '"') - case '/': - s = append(s, '/') - case '\\': - s = append(s, '\\') - case 'N': /* NEL (#x85) */ - s = append(s, '\xC2') - s = append(s, '\x85') - case '_': /* #xA0 */ - s = append(s, '\xC2') - s = append(s, '\xA0') - case 'L': /* LS (#x2028) */ - s = append(s, '\xE2') - s = append(s, '\x80') - s = append(s, '\xA8') - case 'P': /* PS (#x2029) */ - s = append(s, '\xE2') - s = append(s, '\x80') - s = append(s, '\xA9') - case 'x': - code_length = 2 - case 'u': - code_length = 4 - case 'U': - code_length = 8 - default: - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "found unknown escape character") - return false - } - - skip(parser) - skip(parser) - - /* Consume an arbitrary escape code. */ - - if code_length > 0 { - value := 0 - - /* Scan the character value. */ - - if !cache(parser, code_length) { - return false - } - - for k := 0; k < code_length; k++ { - if !is_hex(parser.buffer[parser.buffer_pos+k]) { - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "did not find expected hexdecimal number") - return false - } - value = (value << 4) + as_hex(parser.buffer[parser.buffer_pos+k]) - } - - /* Check the value and write the character. */ - - if (value >= 0xD800 && value <= 0xDFFF) || value > 0x10FFFF { - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "found invalid Unicode character escape code") - return false - } - - if value <= 0x7F { - s = append(s, byte(value)) - } else if value <= 0x7FF { - s = append(s, byte(0xC0+(value>>6))) - s = append(s, byte(0x80+(value&0x3F))) - } else if value <= 0xFFFF { - s = append(s, byte(0xE0+(value>>12))) - s = append(s, byte(0x80+((value>>6)&0x3F))) - s = append(s, byte(0x80+(value&0x3F))) - } else { - s = append(s, byte(0xF0+(value>>18))) - s = append(s, byte(0x80+((value>>12)&0x3F))) - s = append(s, byte(0x80+((value>>6)&0x3F))) - s = append(s, byte(0x80+(value&0x3F))) - } - - /* Advance the pointer. */ - - for k := 0; k < code_length; k++ { - skip(parser) - } - } - } else { - /* It is a non-escaped non-blank character. */ - - s = read(parser, s) - } - - if !cache(parser, 2) { - return false - } - } - - /* Check if we are at the end of the scalar. */ - b := parser.buffer[parser.buffer_pos] - if single { - if b == '\'' { - break - } - } else if b == '"' { - break - } - - /* Consume blank characters. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) || is_break_at(parser.buffer, parser.buffer_pos) { - if is_blank(parser.buffer[parser.buffer_pos]) { - /* Consume a space or a tab character. */ - if !leading_blanks { - whitespaces = read(parser, whitespaces) - } else { - skip(parser) - } - } else { - if !cache(parser, 2) { - return false - } - - /* Check if it is a first line break. */ - if !leading_blanks { - whitespaces = whitespaces[:0] - leading_break = read_line(parser, leading_break) - leading_blanks = true - } else { - trailing_breaks = read_line(parser, trailing_breaks) - } - } - - if !cache(parser, 1) { - return false - } - } - - /* Join the whitespaces or fold line breaks. */ - - if leading_blanks { - /* Do we need to fold line breaks? */ - - if len(leading_break) > 0 && leading_break[0] == '\n' { - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } else { - s = append(s, trailing_breaks...) - trailing_breaks = trailing_breaks[:0] - } - - leading_break = leading_break[:0] - } else { - s = append(s, leading_break...) - s = append(s, trailing_breaks...) - leading_break = leading_break[:0] - trailing_breaks = trailing_breaks[:0] - } - } else { - s = append(s, whitespaces...) - whitespaces = whitespaces[:0] - } - } - - /* Eat the right quote. */ - - skip(parser) - - end_mark := parser.mark - - /* Create a token. */ - - *token = yaml_token_t{ - token_type: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_SINGLE_QUOTED_SCALAR_STYLE, - } - if !single { - token.style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - - return true -} - -/* - * Scan a plain scalar. - */ - -func yaml_parser_scan_plain_scalar(parser *yaml_parser_t, token *yaml_token_t) bool { - var s []byte - var leading_break []byte - var trailing_breaks []byte - var whitespaces []byte - leading_blanks := false - indent := parser.indent + 1 - - start_mark := parser.mark - end_mark := parser.mark - - /* Consume the content of the plain scalar. */ - - for { - /* Check for a document indicator. */ - - if !cache(parser, 4) { - return false - } - - if parser.mark.column == 0 && - ((parser.buffer[parser.buffer_pos] == '-' && - parser.buffer[parser.buffer_pos+1] == '-' && - parser.buffer[parser.buffer_pos+2] == '-') || - (parser.buffer[parser.buffer_pos] == '.' && - parser.buffer[parser.buffer_pos+1] == '.' && - parser.buffer[parser.buffer_pos+2] == '.')) && - is_blankz_at(parser.buffer, parser.buffer_pos+3) { - break - } - - /* Check for a comment. */ - - if parser.buffer[parser.buffer_pos] == '#' { - break - } - - /* Consume non-blank characters. */ - - for !is_blankz_at(parser.buffer, parser.buffer_pos) { - /* Check for 'x:x' in the flow context. TODO: Fix the test "spec-08-13". */ - - if parser.flow_level > 0 && - parser.buffer[parser.buffer_pos] == ':' && - !is_blankz_at(parser.buffer, parser.buffer_pos+1) { - yaml_parser_set_scanner_error(parser, "while scanning a plain scalar", - start_mark, "found unexpected ':'") - return false - } - - /* Check for indicators that may end a plain scalar. */ - b := parser.buffer[parser.buffer_pos] - if (b == ':' && is_blankz_at(parser.buffer, parser.buffer_pos+1)) || - (parser.flow_level > 0 && - (b == ',' || b == ':' || - b == '?' || b == '[' || - b == ']' || b == '{' || - b == '}')) { - break - } - - /* Check if we need to join whitespaces and breaks. */ - - if leading_blanks || len(whitespaces) > 0 { - if leading_blanks { - /* Do we need to fold line breaks? */ - - if leading_break[0] == '\n' { - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } else { - s = append(s, trailing_breaks...) - trailing_breaks = trailing_breaks[:0] - } - leading_break = leading_break[:0] - } else { - s = append(s, leading_break...) - s = append(s, trailing_breaks...) - leading_break = leading_break[:0] - trailing_breaks = trailing_breaks[:0] - } - - leading_blanks = false - } else { - s = append(s, whitespaces...) - whitespaces = whitespaces[:0] - } - } - - /* Copy the character. */ - - s = read(parser, s) - end_mark = parser.mark - - if !cache(parser, 2) { - return false - } - } - - /* Is it the end? */ - - if !(is_blank(parser.buffer[parser.buffer_pos]) || - is_break_at(parser.buffer, parser.buffer_pos)) { - break - } - - /* Consume blank characters. */ - - if !cache(parser, 1) { - return false - } - - for is_blank(parser.buffer[parser.buffer_pos]) || - is_break_at(parser.buffer, parser.buffer_pos) { - - if is_blank(parser.buffer[parser.buffer_pos]) { - /* Check for tab character that abuse indentation. */ - - if leading_blanks && parser.mark.column < indent && - is_tab(parser.buffer[parser.buffer_pos]) { - yaml_parser_set_scanner_error(parser, "while scanning a plain scalar", - start_mark, "found a tab character that violate indentation") - return false - } - - /* Consume a space or a tab character. */ - - if !leading_blanks { - whitespaces = read(parser, whitespaces) - } else { - skip(parser) - } - } else { - if !cache(parser, 2) { - return false - } - - /* Check if it is a first line break. */ - - if !leading_blanks { - whitespaces = whitespaces[:0] - leading_break = read_line(parser, leading_break) - leading_blanks = true - } else { - trailing_breaks = read_line(parser, trailing_breaks) - } - } - if !cache(parser, 1) { - return false - } - } - - /* Check indentation level. */ - - if parser.flow_level == 0 && parser.mark.column < indent { - break - } - } - - /* Create a token. */ - - *token = yaml_token_t{ - token_type: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_PLAIN_SCALAR_STYLE, - } - - /* Note that we change the 'simple_key_allowed' flag. */ - - if leading_blanks { - parser.simple_key_allowed = true - } - - return true -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go deleted file mode 100644 index f153aee..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/tags.go +++ /dev/null @@ -1,360 +0,0 @@ -/* -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 candiedyaml - -import ( - "reflect" - "sort" - "strings" - "sync" - "unicode" -) - -// A field represents a single field found in a struct. -type field struct { - name string - tag bool - index []int - typ reflect.Type - omitEmpty bool - flow bool -} - -// byName sorts field by name, breaking ties with depth, -// then breaking ties with "name came from json tag", then -// breaking ties with index sequence. -type byName []field - -func (x byName) Len() int { return len(x) } - -func (x byName) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -func (x byName) Less(i, j int) bool { - if x[i].name != x[j].name { - return x[i].name < x[j].name - } - if len(x[i].index) != len(x[j].index) { - return len(x[i].index) < len(x[j].index) - } - if x[i].tag != x[j].tag { - return x[i].tag - } - return byIndex(x).Less(i, j) -} - -// byIndex sorts field by index sequence. -type byIndex []field - -func (x byIndex) Len() int { return len(x) } - -func (x byIndex) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -func (x byIndex) Less(i, j int) bool { - for k, xik := range x[i].index { - if k >= len(x[j].index) { - return false - } - if xik != x[j].index[k] { - return xik < x[j].index[k] - } - } - return len(x[i].index) < len(x[j].index) -} - -// typeFields returns a list of fields that JSON should recognize for the given type. -// The algorithm is breadth-first search over the set of structs to include - the top struct -// and then any reachable anonymous structs. -func typeFields(t reflect.Type) []field { - // Anonymous fields to explore at the current level and the next. - current := []field{} - next := []field{{typ: t}} - - // Count of queued names for current level and the next. - count := map[reflect.Type]int{} - nextCount := map[reflect.Type]int{} - - // Types already visited at an earlier level. - visited := map[reflect.Type]bool{} - - // Fields found. - var fields []field - - for len(next) > 0 { - current, next = next, current[:0] - count, nextCount = nextCount, map[reflect.Type]int{} - - for _, f := range current { - if visited[f.typ] { - continue - } - visited[f.typ] = true - - // Scan f.typ for fields to include. - for i := 0; i < f.typ.NumField(); i++ { - sf := f.typ.Field(i) - if sf.PkgPath != "" { // unexported - continue - } - tag := sf.Tag.Get("yaml") - if tag == "-" { - continue - } - name, opts := parseTag(tag) - if !isValidTag(name) { - name = "" - } - index := make([]int, len(f.index)+1) - copy(index, f.index) - index[len(f.index)] = i - - ft := sf.Type - if ft.Name() == "" && ft.Kind() == reflect.Ptr { - // Follow pointer. - ft = ft.Elem() - } - - // Record found field and index sequence. - if name != "" || !sf.Anonymous || ft.Kind() != reflect.Struct { - tagged := name != "" - if name == "" { - name = sf.Name - } - fields = append(fields, field{name, tagged, index, ft, - opts.Contains("omitempty"), opts.Contains("flow")}) - if count[f.typ] > 1 { - // If there were multiple instances, add a second, - // so that the annihilation code will see a duplicate. - // It only cares about the distinction between 1 or 2, - // so don't bother generating any more copies. - fields = append(fields, fields[len(fields)-1]) - } - continue - } - - // Record new anonymous struct to explore in next round. - nextCount[ft]++ - if nextCount[ft] == 1 { - next = append(next, field{name: ft.Name(), index: index, typ: ft}) - } - } - } - } - - sort.Sort(byName(fields)) - - // Delete all fields that are hidden by the Go rules for embedded fields, - // except that fields with JSON tags are promoted. - - // The fields are sorted in primary order of name, secondary order - // of field index length. Loop over names; for each name, delete - // hidden fields by choosing the one dominant field that survives. - out := fields[:0] - for advance, i := 0, 0; i < len(fields); i += advance { - // One iteration per name. - // Find the sequence of fields with the name of this first field. - fi := fields[i] - name := fi.name - for advance = 1; i+advance < len(fields); advance++ { - fj := fields[i+advance] - if fj.name != name { - break - } - } - if advance == 1 { // Only one field with this name - out = append(out, fi) - continue - } - dominant, ok := dominantField(fields[i : i+advance]) - if ok { - out = append(out, dominant) - } - } - - fields = out - sort.Sort(byIndex(fields)) - - return fields -} - -// dominantField looks through the fields, all of which are known to -// have the same name, to find the single field that dominates the -// others using Go's embedding rules, modified by the presence of -// JSON tags. If there are multiple top-level fields, the boolean -// will be false: This condition is an error in Go and we skip all -// the fields. -func dominantField(fields []field) (field, bool) { - // The fields are sorted in increasing index-length order. The winner - // must therefore be one with the shortest index length. Drop all - // longer entries, which is easy: just truncate the slice. - length := len(fields[0].index) - tagged := -1 // Index of first tagged field. - for i, f := range fields { - if len(f.index) > length { - fields = fields[:i] - break - } - if f.tag { - if tagged >= 0 { - // Multiple tagged fields at the same level: conflict. - // Return no field. - return field{}, false - } - tagged = i - } - } - if tagged >= 0 { - return fields[tagged], true - } - // All remaining fields have the same length. If there's more than one, - // we have a conflict (two fields named "X" at the same level) and we - // return no field. - if len(fields) > 1 { - return field{}, false - } - return fields[0], true -} - -var fieldCache struct { - sync.RWMutex - m map[reflect.Type][]field -} - -// cachedTypeFields is like typeFields but uses a cache to avoid repeated work. -func cachedTypeFields(t reflect.Type) []field { - fieldCache.RLock() - f := fieldCache.m[t] - fieldCache.RUnlock() - if f != nil { - return f - } - - // Compute fields without lock. - // Might duplicate effort but won't hold other computations back. - f = typeFields(t) - if f == nil { - f = []field{} - } - - fieldCache.Lock() - if fieldCache.m == nil { - fieldCache.m = map[reflect.Type][]field{} - } - fieldCache.m[t] = f - fieldCache.Unlock() - return f -} - -// tagOptions is the string following a comma in a struct field's "json" -// tag, or the empty string. It does not include the leading comma. -type tagOptions string - -func isValidTag(s string) bool { - if s == "" { - return false - } - for _, c := range s { - switch { - case strings.ContainsRune("!#$%&()*+-./:<=>?@[]^_{|}~ ", c): - // Backslash and quote chars are reserved, but - // otherwise any punctuation chars are allowed - // in a tag name. - default: - if !unicode.IsLetter(c) && !unicode.IsDigit(c) { - return false - } - } - } - return true -} - -func fieldByIndex(v reflect.Value, index []int) reflect.Value { - for _, i := range index { - if v.Kind() == reflect.Ptr { - if v.IsNil() { - return reflect.Value{} - } - v = v.Elem() - } - v = v.Field(i) - } - return v -} - -func typeByIndex(t reflect.Type, index []int) reflect.Type { - for _, i := range index { - if t.Kind() == reflect.Ptr { - t = t.Elem() - } - t = t.Field(i).Type - } - return t -} - -// stringValues is a slice of reflect.Value holding *reflect.StringValue. -// It implements the methods to sort by string. -type stringValues []reflect.Value - -func (sv stringValues) Len() int { return len(sv) } -func (sv stringValues) Swap(i, j int) { sv[i], sv[j] = sv[j], sv[i] } -func (sv stringValues) Less(i, j int) bool { - av, ak := getElem(sv[i]) - bv, bk := getElem(sv[j]) - if ak == reflect.String && bk == reflect.String { - return av.String() < bv.String() - } - - return ak < bk -} - -func getElem(v reflect.Value) (reflect.Value, reflect.Kind) { - k := v.Kind() - for k == reflect.Interface || k == reflect.Ptr && !v.IsNil() { - v = v.Elem() - k = v.Kind() - } - - return v, k -} - -// parseTag splits a struct field's json tag into its name and -// comma-separated options. -func parseTag(tag string) (string, tagOptions) { - if idx := strings.Index(tag, ","); idx != -1 { - return tag[:idx], tagOptions(tag[idx+1:]) - } - return tag, tagOptions("") -} - -// Contains reports whether a comma-separated list of options -// contains a particular substr flag. substr must be surrounded by a -// string boundary or commas. -func (o tagOptions) Contains(optionName string) bool { - if len(o) == 0 { - return false - } - s := string(o) - for s != "" { - var next string - i := strings.Index(s, ",") - if i >= 0 { - s, next = s[:i], s[i+1:] - } - if s == optionName { - return true - } - s = next - } - return false -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go deleted file mode 100644 index a76b633..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/writer.go +++ /dev/null @@ -1,128 +0,0 @@ -/* -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 candiedyaml - -/* - * Set the writer error and return 0. - */ - -func yaml_emitter_set_writer_error(emitter *yaml_emitter_t, problem string) bool { - emitter.error = yaml_WRITER_ERROR - emitter.problem = problem - - return false -} - -/* - * Flush the output buffer. - */ - -func yaml_emitter_flush(emitter *yaml_emitter_t) bool { - if emitter.write_handler == nil { - panic("Write handler must be set") /* Write handler must be set. */ - } - if emitter.encoding == yaml_ANY_ENCODING { - panic("Encoding must be set") /* Output encoding must be set. */ - } - - /* Check if the buffer is empty. */ - - if emitter.buffer_pos == 0 { - return true - } - - /* If the output encoding is UTF-8, we don't need to recode the buffer. */ - - if emitter.encoding == yaml_UTF8_ENCODING { - if err := emitter.write_handler(emitter, - emitter.buffer[:emitter.buffer_pos]); err != nil { - return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error()) - } - emitter.buffer_pos = 0 - return true - } - - /* Recode the buffer into the raw buffer. */ - - var low, high int - if emitter.encoding == yaml_UTF16LE_ENCODING { - low, high = 0, 1 - } else { - high, low = 1, 0 - } - - pos := 0 - for pos < emitter.buffer_pos { - - /* - * See the "reader.c" code for more details on UTF-8 encoding. Note - * that we assume that the buffer contains a valid UTF-8 sequence. - */ - - /* Read the next UTF-8 character. */ - - octet := emitter.buffer[pos] - - var w int - var value rune - switch { - case octet&0x80 == 0x00: - w, value = 1, rune(octet&0x7F) - case octet&0xE0 == 0xC0: - w, value = 2, rune(octet&0x1F) - case octet&0xF0 == 0xE0: - w, value = 3, rune(octet&0x0F) - case octet&0xF8 == 0xF0: - w, value = 4, rune(octet&0x07) - } - - for k := 1; k < w; k++ { - octet = emitter.buffer[pos+k] - value = (value << 6) + (rune(octet) & 0x3F) - } - - pos += w - - /* Write the character. */ - - if value < 0x10000 { - var b [2]byte - b[high] = byte(value >> 8) - b[low] = byte(value & 0xFF) - emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1]) - } else { - /* Write the character using a surrogate pair (check "reader.c"). */ - - var b [4]byte - value -= 0x10000 - b[high] = byte(0xD8 + (value >> 18)) - b[low] = byte((value >> 10) & 0xFF) - b[high+2] = byte(0xDC + ((value >> 8) & 0xFF)) - b[low+2] = byte(value & 0xFF) - emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1], b[2], b[3]) - } - } - - /* Write the raw buffer. */ - - // Write the raw buffer. - if err := emitter.write_handler(emitter, emitter.raw_buffer); err != nil { - return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error()) - } - - emitter.buffer_pos = 0 - emitter.raw_buffer = emitter.raw_buffer[:0] - return true -} diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go deleted file mode 100644 index de4c05a..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_definesh.go +++ /dev/null @@ -1,22 +0,0 @@ -/* -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 candiedyaml - -const ( - yaml_VERSION_MAJOR = 0 - yaml_VERSION_MINOR = 1 - yaml_VERSION_PATCH = 6 - yaml_VERSION_STRING = "0.1.6" -) diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go deleted file mode 100644 index 2b3b7d7..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yaml_privateh.go +++ /dev/null @@ -1,891 +0,0 @@ -/* -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 candiedyaml - -const ( - INPUT_RAW_BUFFER_SIZE = 1024 - - /* - * The size of the input buffer. - * - * It should be possible to decode the whole raw buffer. - */ - INPUT_BUFFER_SIZE = (INPUT_RAW_BUFFER_SIZE * 3) - - /* - * The size of the output buffer. - */ - - OUTPUT_BUFFER_SIZE = 512 - - /* - * The size of the output raw buffer. - * - * It should be possible to encode the whole output buffer. - */ - - OUTPUT_RAW_BUFFER_SIZE = (OUTPUT_BUFFER_SIZE*2 + 2) - - INITIAL_STACK_SIZE = 16 - INITIAL_QUEUE_SIZE = 16 -) - -func width(b byte) int { - if b&0x80 == 0 { - return 1 - } - - if b&0xE0 == 0xC0 { - return 2 - } - - if b&0xF0 == 0xE0 { - return 3 - } - - if b&0xF8 == 0xF0 { - return 4 - } - - return 0 -} - -func copy_bytes(dest []byte, dest_pos *int, src []byte, src_pos *int) { - w := width(src[*src_pos]) - switch w { - case 4: - dest[*dest_pos+3] = src[*src_pos+3] - fallthrough - case 3: - dest[*dest_pos+2] = src[*src_pos+2] - fallthrough - case 2: - dest[*dest_pos+1] = src[*src_pos+1] - fallthrough - case 1: - dest[*dest_pos] = src[*src_pos] - default: - panic("invalid width") - } - *dest_pos += w - *src_pos += w -} - -// /* -// * Check if the character at the specified position is an alphabetical -// * character, a digit, '_', or '-'. -// */ - -func is_alpha(b byte) bool { - return (b >= '0' && b <= '9') || - (b >= 'A' && b <= 'Z') || - (b >= 'a' && b <= 'z') || - b == '_' || b == '-' -} - -// /* -// * Check if the character at the specified position is a digit. -// */ -// -func is_digit(b byte) bool { - return b >= '0' && b <= '9' -} - -// /* -// * Get the value of a digit. -// */ -// -func as_digit(b byte) int { - return int(b) - '0' -} - -// /* -// * Check if the character at the specified position is a hex-digit. -// */ -// -func is_hex(b byte) bool { - return (b >= '0' && b <= '9') || - (b >= 'A' && b <= 'F') || - (b >= 'a' && b <= 'f') -} - -// -// /* -// * Get the value of a hex-digit. -// */ -// -func as_hex(b byte) int { - if b >= 'A' && b <= 'F' { - return int(b) - 'A' + 10 - } else if b >= 'a' && b <= 'f' { - return int(b) - 'a' + 10 - } - return int(b) - '0' -} - -// #define AS_HEX_AT(string,offset) \ -// (((string).pointer[offset] >= (yaml_char_t) 'A' && \ -// (string).pointer[offset] <= (yaml_char_t) 'F') ? \ -// ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \ -// ((string).pointer[offset] >= (yaml_char_t) 'a' && \ -// (string).pointer[offset] <= (yaml_char_t) 'f') ? \ -// ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \ -// ((string).pointer[offset] - (yaml_char_t) '0')) - -// /* -// * Check if the character is a line break, space, tab, or NUL. -// */ -func is_blankz_at(b []byte, i int) bool { - return is_blank(b[i]) || is_breakz_at(b, i) -} - -// /* -// * Check if the character at the specified position is a line break. -// */ -func is_break_at(b []byte, i int) bool { - return b[i] == '\r' || /* CR (#xD)*/ - b[i] == '\n' || /* LF (#xA) */ - (b[i] == 0xC2 && b[i+1] == 0x85) || /* NEL (#x85) */ - (b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8) || /* LS (#x2028) */ - (b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9) /* PS (#x2029) */ -} - -func is_breakz_at(b []byte, i int) bool { - return is_break_at(b, i) || is_z(b[i]) -} - -func is_crlf_at(b []byte, i int) bool { - return b[i] == '\r' && b[i+1] == '\n' -} - -// /* -// * Check if the character at the specified position is NUL. -// */ -func is_z(b byte) bool { - return b == 0x0 -} - -// /* -// * Check if the character at the specified position is space. -// */ -func is_space(b byte) bool { - return b == ' ' -} - -// -// /* -// * Check if the character at the specified position is tab. -// */ -func is_tab(b byte) bool { - return b == '\t' -} - -// /* -// * Check if the character at the specified position is blank (space or tab). -// */ -func is_blank(b byte) bool { - return is_space(b) || is_tab(b) -} - -// /* -// * Check if the character is ASCII. -// */ -func is_ascii(b byte) bool { - return b <= '\x7f' -} - -// /* -// * Check if the character can be printed unescaped. -// */ -func is_printable_at(b []byte, i int) bool { - return ((b[i] == 0x0A) || /* . == #x0A */ - (b[i] >= 0x20 && b[i] <= 0x7E) || /* #x20 <= . <= #x7E */ - (b[i] == 0xC2 && b[i+1] >= 0xA0) || /* #0xA0 <= . <= #xD7FF */ - (b[i] > 0xC2 && b[i] < 0xED) || - (b[i] == 0xED && b[i+1] < 0xA0) || - (b[i] == 0xEE) || - (b[i] == 0xEF && /* && . != #xFEFF */ - !(b[i+1] == 0xBB && b[i+2] == 0xBF) && - !(b[i+1] == 0xBF && (b[i+2] == 0xBE || b[i+2] == 0xBF)))) -} - -func insert_token(parser *yaml_parser_t, pos int, token *yaml_token_t) { - // collapse the slice - if parser.tokens_head > 0 && len(parser.tokens) == cap(parser.tokens) { - if parser.tokens_head != len(parser.tokens) { - // move the tokens down - copy(parser.tokens, parser.tokens[parser.tokens_head:]) - } - // readjust the length - parser.tokens = parser.tokens[:len(parser.tokens)-parser.tokens_head] - parser.tokens_head = 0 - } - - parser.tokens = append(parser.tokens, *token) - if pos < 0 { - return - } - copy(parser.tokens[parser.tokens_head+pos+1:], parser.tokens[parser.tokens_head+pos:]) - parser.tokens[parser.tokens_head+pos] = *token -} - -// /* -// * Check if the character at the specified position is BOM. -// */ -// -func is_bom_at(b []byte, i int) bool { - return b[i] == 0xEF && b[i+1] == 0xBB && b[i+2] == 0xBF -} - -// -// #ifdef HAVE_CONFIG_H -// #include -// #endif -// -// #include "./yaml.h" -// -// #include -// #include -// -// /* -// * Memory management. -// */ -// -// yaml_DECLARE(void *) -// yaml_malloc(size_t size); -// -// yaml_DECLARE(void *) -// yaml_realloc(void *ptr, size_t size); -// -// yaml_DECLARE(void) -// yaml_free(void *ptr); -// -// yaml_DECLARE(yaml_char_t *) -// yaml_strdup(const yaml_char_t *); -// -// /* -// * Reader: Ensure that the buffer contains at least `length` characters. -// */ -// -// yaml_DECLARE(int) -// yaml_parser_update_buffer(yaml_parser_t *parser, size_t length); -// -// /* -// * Scanner: Ensure that the token stack contains at least one token ready. -// */ -// -// yaml_DECLARE(int) -// yaml_parser_fetch_more_tokens(yaml_parser_t *parser); -// -// /* -// * The size of the input raw buffer. -// */ -// -// #define INPUT_RAW_BUFFER_SIZE 16384 -// -// /* -// * The size of the input buffer. -// * -// * It should be possible to decode the whole raw buffer. -// */ -// -// #define INPUT_BUFFER_SIZE (INPUT_RAW_BUFFER_SIZE*3) -// -// /* -// * The size of the output buffer. -// */ -// -// #define OUTPUT_BUFFER_SIZE 16384 -// -// /* -// * The size of the output raw buffer. -// * -// * It should be possible to encode the whole output buffer. -// */ -// -// #define OUTPUT_RAW_BUFFER_SIZE (OUTPUT_BUFFER_SIZE*2+2) -// -// /* -// * The size of other stacks and queues. -// */ -// -// #define INITIAL_STACK_SIZE 16 -// #define INITIAL_QUEUE_SIZE 16 -// #define INITIAL_STRING_SIZE 16 -// -// /* -// * Buffer management. -// */ -// -// #define BUFFER_INIT(context,buffer,size) \ -// (((buffer).start = yaml_malloc(size)) ? \ -// ((buffer).last = (buffer).pointer = (buffer).start, \ -// (buffer).end = (buffer).start+(size), \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define BUFFER_DEL(context,buffer) \ -// (yaml_free((buffer).start), \ -// (buffer).start = (buffer).pointer = (buffer).end = 0) -// -// /* -// * String management. -// */ -// -// typedef struct { -// yaml_char_t *start; -// yaml_char_t *end; -// yaml_char_t *pointer; -// } yaml_string_t; -// -// yaml_DECLARE(int) -// yaml_string_extend(yaml_char_t **start, -// yaml_char_t **pointer, yaml_char_t **end); -// -// yaml_DECLARE(int) -// yaml_string_join( -// yaml_char_t **a_start, yaml_char_t **a_pointer, yaml_char_t **a_end, -// yaml_char_t **b_start, yaml_char_t **b_pointer, yaml_char_t **b_end); -// -// #define NULL_STRING { NULL, NULL, NULL } -// -// #define STRING(string,length) { (string), (string)+(length), (string) } -// -// #define STRING_ASSIGN(value,string,length) \ -// ((value).start = (string), \ -// (value).end = (string)+(length), \ -// (value).pointer = (string)) -// -// #define STRING_INIT(context,string,size) \ -// (((string).start = yaml_malloc(size)) ? \ -// ((string).pointer = (string).start, \ -// (string).end = (string).start+(size), \ -// memset((string).start, 0, (size)), \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define STRING_DEL(context,string) \ -// (yaml_free((string).start), \ -// (string).start = (string).pointer = (string).end = 0) -// -// #define STRING_EXTEND(context,string) \ -// (((string).pointer+5 < (string).end) \ -// || yaml_string_extend(&(string).start, \ -// &(string).pointer, &(string).end)) -// -// #define CLEAR(context,string) \ -// ((string).pointer = (string).start, \ -// memset((string).start, 0, (string).end-(string).start)) -// -// #define JOIN(context,string_a,string_b) \ -// ((yaml_string_join(&(string_a).start, &(string_a).pointer, \ -// &(string_a).end, &(string_b).start, \ -// &(string_b).pointer, &(string_b).end)) ? \ -// ((string_b).pointer = (string_b).start, \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// /* -// * String check operations. -// */ -// -// /* -// * Check the octet at the specified position. -// */ -// -// #define CHECK_AT(string,octet,offset) \ -// ((string).pointer[offset] == (yaml_char_t)(octet)) -// -// /* -// * Check the current octet in the buffer. -// */ -// -// #define CHECK(string,octet) CHECK_AT((string),(octet),0) -// -// /* -// * Check if the character at the specified position is an alphabetical -// * character, a digit, '_', or '-'. -// */ -// -// #define IS_ALPHA_AT(string,offset) \ -// (((string).pointer[offset] >= (yaml_char_t) '0' && \ -// (string).pointer[offset] <= (yaml_char_t) '9') || \ -// ((string).pointer[offset] >= (yaml_char_t) 'A' && \ -// (string).pointer[offset] <= (yaml_char_t) 'Z') || \ -// ((string).pointer[offset] >= (yaml_char_t) 'a' && \ -// (string).pointer[offset] <= (yaml_char_t) 'z') || \ -// (string).pointer[offset] == '_' || \ -// (string).pointer[offset] == '-') -// -// #define IS_ALPHA(string) IS_ALPHA_AT((string),0) -// -// /* -// * Check if the character at the specified position is a digit. -// */ -// -// #define IS_DIGIT_AT(string,offset) \ -// (((string).pointer[offset] >= (yaml_char_t) '0' && \ -// (string).pointer[offset] <= (yaml_char_t) '9')) -// -// #define IS_DIGIT(string) IS_DIGIT_AT((string),0) -// -// /* -// * Get the value of a digit. -// */ -// -// #define AS_DIGIT_AT(string,offset) \ -// ((string).pointer[offset] - (yaml_char_t) '0') -// -// #define AS_DIGIT(string) AS_DIGIT_AT((string),0) -// -// /* -// * Check if the character at the specified position is a hex-digit. -// */ -// -// #define IS_HEX_AT(string,offset) \ -// (((string).pointer[offset] >= (yaml_char_t) '0' && \ -// (string).pointer[offset] <= (yaml_char_t) '9') || \ -// ((string).pointer[offset] >= (yaml_char_t) 'A' && \ -// (string).pointer[offset] <= (yaml_char_t) 'F') || \ -// ((string).pointer[offset] >= (yaml_char_t) 'a' && \ -// (string).pointer[offset] <= (yaml_char_t) 'f')) -// -// #define IS_HEX(string) IS_HEX_AT((string),0) -// -// /* -// * Get the value of a hex-digit. -// */ -// -// #define AS_HEX_AT(string,offset) \ -// (((string).pointer[offset] >= (yaml_char_t) 'A' && \ -// (string).pointer[offset] <= (yaml_char_t) 'F') ? \ -// ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \ -// ((string).pointer[offset] >= (yaml_char_t) 'a' && \ -// (string).pointer[offset] <= (yaml_char_t) 'f') ? \ -// ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \ -// ((string).pointer[offset] - (yaml_char_t) '0')) -// -// #define AS_HEX(string) AS_HEX_AT((string),0) -// -// /* -// * Check if the character is ASCII. -// */ -// -// #define IS_ASCII_AT(string,offset) \ -// ((string).pointer[offset] <= (yaml_char_t) '\x7F') -// -// #define IS_ASCII(string) IS_ASCII_AT((string),0) -// -// /* -// * Check if the character can be printed unescaped. -// */ -// -// #define IS_PRINTABLE_AT(string,offset) \ -// (((string).pointer[offset] == 0x0A) /* . == #x0A */ \ -// || ((string).pointer[offset] >= 0x20 /* #x20 <= . <= #x7E */ \ -// && (string).pointer[offset] <= 0x7E) \ -// || ((string).pointer[offset] == 0xC2 /* #0xA0 <= . <= #xD7FF */ \ -// && (string).pointer[offset+1] >= 0xA0) \ -// || ((string).pointer[offset] > 0xC2 \ -// && (string).pointer[offset] < 0xED) \ -// || ((string).pointer[offset] == 0xED \ -// && (string).pointer[offset+1] < 0xA0) \ -// || ((string).pointer[offset] == 0xEE) \ -// || ((string).pointer[offset] == 0xEF /* #xE000 <= . <= #xFFFD */ \ -// && !((string).pointer[offset+1] == 0xBB /* && . != #xFEFF */ \ -// && (string).pointer[offset+2] == 0xBF) \ -// && !((string).pointer[offset+1] == 0xBF \ -// && ((string).pointer[offset+2] == 0xBE \ -// || (string).pointer[offset+2] == 0xBF)))) -// -// #define IS_PRINTABLE(string) IS_PRINTABLE_AT((string),0) -// -// /* -// * Check if the character at the specified position is NUL. -// */ -// -// #define IS_Z_AT(string,offset) CHECK_AT((string),'\0',(offset)) -// -// #define IS_Z(string) IS_Z_AT((string),0) -// -// /* -// * Check if the character at the specified position is BOM. -// */ -// -// #define IS_BOM_AT(string,offset) \ -// (CHECK_AT((string),'\xEF',(offset)) \ -// && CHECK_AT((string),'\xBB',(offset)+1) \ -// && CHECK_AT((string),'\xBF',(offset)+2)) /* BOM (#xFEFF) */ -// -// #define IS_BOM(string) IS_BOM_AT(string,0) -// -// /* -// * Check if the character at the specified position is space. -// */ -// -// #define IS_SPACE_AT(string,offset) CHECK_AT((string),' ',(offset)) -// -// #define IS_SPACE(string) IS_SPACE_AT((string),0) -// -// /* -// * Check if the character at the specified position is tab. -// */ -// -// #define IS_TAB_AT(string,offset) CHECK_AT((string),'\t',(offset)) -// -// #define IS_TAB(string) IS_TAB_AT((string),0) -// -// /* -// * Check if the character at the specified position is blank (space or tab). -// */ -// -// #define IS_BLANK_AT(string,offset) \ -// (IS_SPACE_AT((string),(offset)) || IS_TAB_AT((string),(offset))) -// -// #define IS_BLANK(string) IS_BLANK_AT((string),0) -// -// /* -// * Check if the character at the specified position is a line break. -// */ -// -// #define IS_BREAK_AT(string,offset) \ -// (CHECK_AT((string),'\r',(offset)) /* CR (#xD)*/ \ -// || CHECK_AT((string),'\n',(offset)) /* LF (#xA) */ \ -// || (CHECK_AT((string),'\xC2',(offset)) \ -// && CHECK_AT((string),'\x85',(offset)+1)) /* NEL (#x85) */ \ -// || (CHECK_AT((string),'\xE2',(offset)) \ -// && CHECK_AT((string),'\x80',(offset)+1) \ -// && CHECK_AT((string),'\xA8',(offset)+2)) /* LS (#x2028) */ \ -// || (CHECK_AT((string),'\xE2',(offset)) \ -// && CHECK_AT((string),'\x80',(offset)+1) \ -// && CHECK_AT((string),'\xA9',(offset)+2))) /* PS (#x2029) */ -// -// #define IS_BREAK(string) IS_BREAK_AT((string),0) -// -// #define IS_CRLF_AT(string,offset) \ -// (CHECK_AT((string),'\r',(offset)) && CHECK_AT((string),'\n',(offset)+1)) -// -// #define IS_CRLF(string) IS_CRLF_AT((string),0) -// -// /* -// * Check if the character is a line break or NUL. -// */ -// -// #define IS_BREAKZ_AT(string,offset) \ -// (IS_BREAK_AT((string),(offset)) || IS_Z_AT((string),(offset))) -// -// #define IS_BREAKZ(string) IS_BREAKZ_AT((string),0) -// -// /* -// * Check if the character is a line break, space, or NUL. -// */ -// -// #define IS_SPACEZ_AT(string,offset) \ -// (IS_SPACE_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset))) -// -// #define IS_SPACEZ(string) IS_SPACEZ_AT((string),0) -// -// /* -// * Check if the character is a line break, space, tab, or NUL. -// */ -// -// #define IS_BLANKZ_AT(string,offset) \ -// (IS_BLANK_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset))) -// -// #define IS_BLANKZ(string) IS_BLANKZ_AT((string),0) -// -// /* -// * Determine the width of the character. -// */ -// -// #define WIDTH_AT(string,offset) \ -// (((string).pointer[offset] & 0x80) == 0x00 ? 1 : \ -// ((string).pointer[offset] & 0xE0) == 0xC0 ? 2 : \ -// ((string).pointer[offset] & 0xF0) == 0xE0 ? 3 : \ -// ((string).pointer[offset] & 0xF8) == 0xF0 ? 4 : 0) -// -// #define WIDTH(string) WIDTH_AT((string),0) -// -// /* -// * Move the string pointer to the next character. -// */ -// -// #define MOVE(string) ((string).pointer += WIDTH((string))) -// -// /* -// * Copy a character and move the pointers of both strings. -// */ -// -// #define COPY(string_a,string_b) \ -// ((*(string_b).pointer & 0x80) == 0x00 ? \ -// (*((string_a).pointer++) = *((string_b).pointer++)) : \ -// (*(string_b).pointer & 0xE0) == 0xC0 ? \ -// (*((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++)) : \ -// (*(string_b).pointer & 0xF0) == 0xE0 ? \ -// (*((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++)) : \ -// (*(string_b).pointer & 0xF8) == 0xF0 ? \ -// (*((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++), \ -// *((string_a).pointer++) = *((string_b).pointer++)) : 0) -// -// /* -// * Stack and queue management. -// */ -// -// yaml_DECLARE(int) -// yaml_stack_extend(void **start, void **top, void **end); -// -// yaml_DECLARE(int) -// yaml_queue_extend(void **start, void **head, void **tail, void **end); -// -// #define STACK_INIT(context,stack,size) \ -// (((stack).start = yaml_malloc((size)*sizeof(*(stack).start))) ? \ -// ((stack).top = (stack).start, \ -// (stack).end = (stack).start+(size), \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define STACK_DEL(context,stack) \ -// (yaml_free((stack).start), \ -// (stack).start = (stack).top = (stack).end = 0) -// -// #define STACK_EMPTY(context,stack) \ -// ((stack).start == (stack).top) -// -// #define PUSH(context,stack,value) \ -// (((stack).top != (stack).end \ -// || yaml_stack_extend((void **)&(stack).start, \ -// (void **)&(stack).top, (void **)&(stack).end)) ? \ -// (*((stack).top++) = value, \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define POP(context,stack) \ -// (*(--(stack).top)) -// -// #define QUEUE_INIT(context,queue,size) \ -// (((queue).start = yaml_malloc((size)*sizeof(*(queue).start))) ? \ -// ((queue).head = (queue).tail = (queue).start, \ -// (queue).end = (queue).start+(size), \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define QUEUE_DEL(context,queue) \ -// (yaml_free((queue).start), \ -// (queue).start = (queue).head = (queue).tail = (queue).end = 0) -// -// #define QUEUE_EMPTY(context,queue) \ -// ((queue).head == (queue).tail) -// -// #define ENQUEUE(context,queue,value) \ -// (((queue).tail != (queue).end \ -// || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \ -// (void **)&(queue).tail, (void **)&(queue).end)) ? \ -// (*((queue).tail++) = value, \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// #define DEQUEUE(context,queue) \ -// (*((queue).head++)) -// -// #define QUEUE_INSERT(context,queue,index,value) \ -// (((queue).tail != (queue).end \ -// || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \ -// (void **)&(queue).tail, (void **)&(queue).end)) ? \ -// (memmove((queue).head+(index)+1,(queue).head+(index), \ -// ((queue).tail-(queue).head-(index))*sizeof(*(queue).start)), \ -// *((queue).head+(index)) = value, \ -// (queue).tail++, \ -// 1) : \ -// ((context)->error = yaml_MEMORY_ERROR, \ -// 0)) -// -// /* -// * Token initializers. -// */ -// -// #define TOKEN_INIT(token,token_type,token_start_mark,token_end_mark) \ -// (memset(&(token), 0, sizeof(yaml_token_t)), \ -// (token).type = (token_type), \ -// (token).start_mark = (token_start_mark), \ -// (token).end_mark = (token_end_mark)) -// -// #define STREAM_START_TOKEN_INIT(token,token_encoding,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_STREAM_START_TOKEN,(start_mark),(end_mark)), \ -// (token).data.stream_start.encoding = (token_encoding)) -// -// #define STREAM_END_TOKEN_INIT(token,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_STREAM_END_TOKEN,(start_mark),(end_mark))) -// -// #define ALIAS_TOKEN_INIT(token,token_value,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_ALIAS_TOKEN,(start_mark),(end_mark)), \ -// (token).data.alias.value = (token_value)) -// -// #define ANCHOR_TOKEN_INIT(token,token_value,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_ANCHOR_TOKEN,(start_mark),(end_mark)), \ -// (token).data.anchor.value = (token_value)) -// -// #define TAG_TOKEN_INIT(token,token_handle,token_suffix,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_TAG_TOKEN,(start_mark),(end_mark)), \ -// (token).data.tag.handle = (token_handle), \ -// (token).data.tag.suffix = (token_suffix)) -// -// #define SCALAR_TOKEN_INIT(token,token_value,token_length,token_style,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_SCALAR_TOKEN,(start_mark),(end_mark)), \ -// (token).data.scalar.value = (token_value), \ -// (token).data.scalar.length = (token_length), \ -// (token).data.scalar.style = (token_style)) -// -// #define VERSION_DIRECTIVE_TOKEN_INIT(token,token_major,token_minor,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_VERSION_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \ -// (token).data.version_directive.major = (token_major), \ -// (token).data.version_directive.minor = (token_minor)) -// -// #define TAG_DIRECTIVE_TOKEN_INIT(token,token_handle,token_prefix,start_mark,end_mark) \ -// (TOKEN_INIT((token),yaml_TAG_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \ -// (token).data.tag_directive.handle = (token_handle), \ -// (token).data.tag_directive.prefix = (token_prefix)) -// -// /* -// * Event initializers. -// */ -// -// #define EVENT_INIT(event,event_type,event_start_mark,event_end_mark) \ -// (memset(&(event), 0, sizeof(yaml_event_t)), \ -// (event).type = (event_type), \ -// (event).start_mark = (event_start_mark), \ -// (event).end_mark = (event_end_mark)) -// -// #define STREAM_START_EVENT_INIT(event,event_encoding,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_STREAM_START_EVENT,(start_mark),(end_mark)), \ -// (event).data.stream_start.encoding = (event_encoding)) -// -// #define STREAM_END_EVENT_INIT(event,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_STREAM_END_EVENT,(start_mark),(end_mark))) -// -// #define DOCUMENT_START_EVENT_INIT(event,event_version_directive, \ -// event_tag_directives_start,event_tag_directives_end,event_implicit,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_DOCUMENT_START_EVENT,(start_mark),(end_mark)), \ -// (event).data.document_start.version_directive = (event_version_directive), \ -// (event).data.document_start.tag_directives.start = (event_tag_directives_start), \ -// (event).data.document_start.tag_directives.end = (event_tag_directives_end), \ -// (event).data.document_start.implicit = (event_implicit)) -// -// #define DOCUMENT_END_EVENT_INIT(event,event_implicit,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_DOCUMENT_END_EVENT,(start_mark),(end_mark)), \ -// (event).data.document_end.implicit = (event_implicit)) -// -// #define ALIAS_EVENT_INIT(event,event_anchor,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_ALIAS_EVENT,(start_mark),(end_mark)), \ -// (event).data.alias.anchor = (event_anchor)) -// -// #define SCALAR_EVENT_INIT(event,event_anchor,event_tag,event_value,event_length, \ -// event_plain_implicit, event_quoted_implicit,event_style,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_SCALAR_EVENT,(start_mark),(end_mark)), \ -// (event).data.scalar.anchor = (event_anchor), \ -// (event).data.scalar.tag = (event_tag), \ -// (event).data.scalar.value = (event_value), \ -// (event).data.scalar.length = (event_length), \ -// (event).data.scalar.plain_implicit = (event_plain_implicit), \ -// (event).data.scalar.quoted_implicit = (event_quoted_implicit), \ -// (event).data.scalar.style = (event_style)) -// -// #define SEQUENCE_START_EVENT_INIT(event,event_anchor,event_tag, \ -// event_implicit,event_style,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_SEQUENCE_START_EVENT,(start_mark),(end_mark)), \ -// (event).data.sequence_start.anchor = (event_anchor), \ -// (event).data.sequence_start.tag = (event_tag), \ -// (event).data.sequence_start.implicit = (event_implicit), \ -// (event).data.sequence_start.style = (event_style)) -// -// #define SEQUENCE_END_EVENT_INIT(event,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_SEQUENCE_END_EVENT,(start_mark),(end_mark))) -// -// #define MAPPING_START_EVENT_INIT(event,event_anchor,event_tag, \ -// event_implicit,event_style,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_MAPPING_START_EVENT,(start_mark),(end_mark)), \ -// (event).data.mapping_start.anchor = (event_anchor), \ -// (event).data.mapping_start.tag = (event_tag), \ -// (event).data.mapping_start.implicit = (event_implicit), \ -// (event).data.mapping_start.style = (event_style)) -// -// #define MAPPING_END_EVENT_INIT(event,start_mark,end_mark) \ -// (EVENT_INIT((event),yaml_MAPPING_END_EVENT,(start_mark),(end_mark))) -// -// /* -// * Document initializer. -// */ -// -// #define DOCUMENT_INIT(document,document_nodes_start,document_nodes_end, \ -// document_version_directive,document_tag_directives_start, \ -// document_tag_directives_end,document_start_implicit, \ -// document_end_implicit,document_start_mark,document_end_mark) \ -// (memset(&(document), 0, sizeof(yaml_document_t)), \ -// (document).nodes.start = (document_nodes_start), \ -// (document).nodes.end = (document_nodes_end), \ -// (document).nodes.top = (document_nodes_start), \ -// (document).version_directive = (document_version_directive), \ -// (document).tag_directives.start = (document_tag_directives_start), \ -// (document).tag_directives.end = (document_tag_directives_end), \ -// (document).start_implicit = (document_start_implicit), \ -// (document).end_implicit = (document_end_implicit), \ -// (document).start_mark = (document_start_mark), \ -// (document).end_mark = (document_end_mark)) -// -// /* -// * Node initializers. -// */ -// -// #define NODE_INIT(node,node_type,node_tag,node_start_mark,node_end_mark) \ -// (memset(&(node), 0, sizeof(yaml_node_t)), \ -// (node).type = (node_type), \ -// (node).tag = (node_tag), \ -// (node).start_mark = (node_start_mark), \ -// (node).end_mark = (node_end_mark)) -// -// #define SCALAR_NODE_INIT(node,node_tag,node_value,node_length, \ -// node_style,start_mark,end_mark) \ -// (NODE_INIT((node),yaml_SCALAR_NODE,(node_tag),(start_mark),(end_mark)), \ -// (node).data.scalar.value = (node_value), \ -// (node).data.scalar.length = (node_length), \ -// (node).data.scalar.style = (node_style)) -// -// #define SEQUENCE_NODE_INIT(node,node_tag,node_items_start,node_items_end, \ -// node_style,start_mark,end_mark) \ -// (NODE_INIT((node),yaml_SEQUENCE_NODE,(node_tag),(start_mark),(end_mark)), \ -// (node).data.sequence.items.start = (node_items_start), \ -// (node).data.sequence.items.end = (node_items_end), \ -// (node).data.sequence.items.top = (node_items_start), \ -// (node).data.sequence.style = (node_style)) -// -// #define MAPPING_NODE_INIT(node,node_tag,node_pairs_start,node_pairs_end, \ -// node_style,start_mark,end_mark) \ -// (NODE_INIT((node),yaml_MAPPING_NODE,(node_tag),(start_mark),(end_mark)), \ -// (node).data.mapping.pairs.start = (node_pairs_start), \ -// (node).data.mapping.pairs.end = (node_pairs_end), \ -// (node).data.mapping.pairs.top = (node_pairs_start), \ -// (node).data.mapping.style = (node_style)) -// diff --git a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go b/vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go deleted file mode 100644 index d608dbb..0000000 --- a/vendor/github.com/cloudfoundry-incubator/candiedyaml/yamlh.go +++ /dev/null @@ -1,953 +0,0 @@ -/* -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 candiedyaml - -import ( - "fmt" - "io" -) - -/** The version directive data. */ -type yaml_version_directive_t struct { - major int // The major version number - minor int // The minor version number -} - -/** The tag directive data. */ -type yaml_tag_directive_t struct { - handle []byte // The tag handle - prefix []byte // The tag prefix -} - -/** The stream encoding. */ -type yaml_encoding_t int - -const ( - /** Let the parser choose the encoding. */ - yaml_ANY_ENCODING yaml_encoding_t = iota - /** The defau lt UTF-8 encoding. */ - yaml_UTF8_ENCODING - /** The UTF-16-LE encoding with BOM. */ - yaml_UTF16LE_ENCODING - /** The UTF-16-BE encoding with BOM. */ - yaml_UTF16BE_ENCODING -) - -/** Line break types. */ -type yaml_break_t int - -const ( - yaml_ANY_BREAK yaml_break_t = iota /** Let the parser choose the break type. */ - yaml_CR_BREAK /** Use CR for line breaks (Mac style). */ - yaml_LN_BREAK /** Use LN for line breaks (Unix style). */ - yaml_CRLN_BREAK /** Use CR LN for line breaks (DOS style). */ -) - -/** Many bad things could happen with the parser and emitter. */ -type YAML_error_type_t int - -const ( - /** No error is produced. */ - yaml_NO_ERROR YAML_error_type_t = iota - - /** Cannot allocate or reallocate a block of memory. */ - yaml_MEMORY_ERROR - - /** Cannot read or decode the input stream. */ - yaml_READER_ERROR - /** Cannot scan the input stream. */ - yaml_SCANNER_ERROR - /** Cannot parse the input stream. */ - yaml_PARSER_ERROR - /** Cannot compose a YAML document. */ - yaml_COMPOSER_ERROR - - /** Cannot write to the output stream. */ - yaml_WRITER_ERROR - /** Cannot emit a YAML stream. */ - yaml_EMITTER_ERROR -) - -/** The pointer position. */ -type YAML_mark_t struct { - /** The position index. */ - index int - - /** The position line. */ - line int - - /** The position column. */ - column int -} - -func (m YAML_mark_t) String() string { - return fmt.Sprintf("line %d, column %d", m.line, m.column) -} - -/** @} */ - -/** - * @defgroup styles Node Styles - * @{ - */ - -type yaml_style_t int - -/** Scalar styles. */ -type yaml_scalar_style_t yaml_style_t - -const ( - /** Let the emitter choose the style. */ - yaml_ANY_SCALAR_STYLE yaml_scalar_style_t = iota - - /** The plain scalar style. */ - yaml_PLAIN_SCALAR_STYLE - - /** The single-quoted scalar style. */ - yaml_SINGLE_QUOTED_SCALAR_STYLE - /** The double-quoted scalar style. */ - yaml_DOUBLE_QUOTED_SCALAR_STYLE - - /** The literal scalar style. */ - yaml_LITERAL_SCALAR_STYLE - /** The folded scalar style. */ - yaml_FOLDED_SCALAR_STYLE -) - -/** Sequence styles. */ -type yaml_sequence_style_t yaml_style_t - -const ( - /** Let the emitter choose the style. */ - yaml_ANY_SEQUENCE_STYLE yaml_sequence_style_t = iota - - /** The block sequence style. */ - yaml_BLOCK_SEQUENCE_STYLE - /** The flow sequence style. */ - yaml_FLOW_SEQUENCE_STYLE -) - -/** Mapping styles. */ -type yaml_mapping_style_t yaml_style_t - -const ( - /** Let the emitter choose the style. */ - yaml_ANY_MAPPING_STYLE yaml_mapping_style_t = iota - - /** The block mapping style. */ - yaml_BLOCK_MAPPING_STYLE - /** The flow mapping style. */ - yaml_FLOW_MAPPING_STYLE - -/* yaml_FLOW_SET_MAPPING_STYLE */ -) - -/** @} */ - -/** - * @defgroup tokens Tokens - * @{ - */ - -/** Token types. */ -type yaml_token_type_t int - -const ( - /** An empty token. */ - yaml_NO_TOKEN yaml_token_type_t = iota - - /** A STREAM-START token. */ - yaml_STREAM_START_TOKEN - /** A STREAM-END token. */ - yaml_STREAM_END_TOKEN - - /** A VERSION-DIRECTIVE token. */ - yaml_VERSION_DIRECTIVE_TOKEN - /** A TAG-DIRECTIVE token. */ - yaml_TAG_DIRECTIVE_TOKEN - /** A DOCUMENT-START token. */ - yaml_DOCUMENT_START_TOKEN - /** A DOCUMENT-END token. */ - yaml_DOCUMENT_END_TOKEN - - /** A BLOCK-SEQUENCE-START token. */ - yaml_BLOCK_SEQUENCE_START_TOKEN - /** A BLOCK-SEQUENCE-END token. */ - yaml_BLOCK_MAPPING_START_TOKEN - /** A BLOCK-END token. */ - yaml_BLOCK_END_TOKEN - - /** A FLOW-SEQUENCE-START token. */ - yaml_FLOW_SEQUENCE_START_TOKEN - /** A FLOW-SEQUENCE-END token. */ - yaml_FLOW_SEQUENCE_END_TOKEN - /** A FLOW-MAPPING-START token. */ - yaml_FLOW_MAPPING_START_TOKEN - /** A FLOW-MAPPING-END token. */ - yaml_FLOW_MAPPING_END_TOKEN - - /** A BLOCK-ENTRY token. */ - yaml_BLOCK_ENTRY_TOKEN - /** A FLOW-ENTRY token. */ - yaml_FLOW_ENTRY_TOKEN - /** A KEY token. */ - yaml_KEY_TOKEN - /** A VALUE token. */ - yaml_VALUE_TOKEN - - /** An ALIAS token. */ - yaml_ALIAS_TOKEN - /** An ANCHOR token. */ - yaml_ANCHOR_TOKEN - /** A TAG token. */ - yaml_TAG_TOKEN - /** A SCALAR token. */ - yaml_SCALAR_TOKEN -) - -/** The token structure. */ -type yaml_token_t struct { - - /** The token type. */ - token_type yaml_token_type_t - - /** The token data. */ - /** The stream start (for @c yaml_STREAM_START_TOKEN). */ - encoding yaml_encoding_t - - /** The alias (for @c yaml_ALIAS_TOKEN, yaml_ANCHOR_TOKEN, yaml_SCALAR_TOKEN,yaml_TAG_TOKEN ). */ - /** The anchor (for @c ). */ - /** The scalar value (for @c ). */ - value []byte - - /** The tag suffix. */ - suffix []byte - - /** The scalar value (for @c yaml_SCALAR_TOKEN). */ - /** The scalar style. */ - style yaml_scalar_style_t - - /** The version directive (for @c yaml_VERSION_DIRECTIVE_TOKEN). */ - version_directive yaml_version_directive_t - - /** The tag directive (for @c yaml_TAG_DIRECTIVE_TOKEN). */ - prefix []byte - - /** The beginning of the token. */ - start_mark YAML_mark_t - /** The end of the token. */ - end_mark YAML_mark_t - - major, minor int -} - -/** - * @defgroup events Events - * @{ - */ - -/** Event types. */ -type yaml_event_type_t int - -const ( - /** An empty event. */ - yaml_NO_EVENT yaml_event_type_t = iota - - /** A STREAM-START event. */ - yaml_STREAM_START_EVENT - /** A STREAM-END event. */ - yaml_STREAM_END_EVENT - - /** A DOCUMENT-START event. */ - yaml_DOCUMENT_START_EVENT - /** A DOCUMENT-END event. */ - yaml_DOCUMENT_END_EVENT - - /** An ALIAS event. */ - yaml_ALIAS_EVENT - /** A SCALAR event. */ - yaml_SCALAR_EVENT - - /** A SEQUENCE-START event. */ - yaml_SEQUENCE_START_EVENT - /** A SEQUENCE-END event. */ - yaml_SEQUENCE_END_EVENT - - /** A MAPPING-START event. */ - yaml_MAPPING_START_EVENT - /** A MAPPING-END event. */ - yaml_MAPPING_END_EVENT -) - -/** The event structure. */ -type yaml_event_t struct { - - /** The event type. */ - event_type yaml_event_type_t - - /** The stream parameters (for @c yaml_STREAM_START_EVENT). */ - encoding yaml_encoding_t - - /** The document parameters (for @c yaml_DOCUMENT_START_EVENT). */ - version_directive *yaml_version_directive_t - - /** The beginning and end of the tag directives list. */ - tag_directives []yaml_tag_directive_t - - /** The document parameters (for @c yaml_DOCUMENT_START_EVENT, yaml_DOCUMENT_END_EVENT, yaml_SEQUENCE_START_EVENT,yaml_MAPPING_START_EVENT). */ - /** Is the document indicator implicit? */ - implicit bool - - /** The alias parameters (for @c yaml_ALIAS_EVENT,yaml_SCALAR_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */ - /** The anchor. */ - anchor []byte - - /** The scalar parameters (for @c yaml_SCALAR_EVENT,yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */ - /** The tag. */ - tag []byte - /** The scalar value. */ - value []byte - - /** Is the tag optional for the plain style? */ - plain_implicit bool - /** Is the tag optional for any non-plain style? */ - quoted_implicit bool - - /** The sequence parameters (for @c yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). */ - /** The sequence style. */ - /** The scalar style. */ - style yaml_style_t - - /** The beginning of the event. */ - start_mark, end_mark YAML_mark_t -} - -/** - * @defgroup nodes Nodes - * @{ - */ - -const ( - /** The tag @c !!null with the only possible value: @c null. */ - yaml_NULL_TAG = "tag:yaml.org,2002:null" - /** The tag @c !!bool with the values: @c true and @c falce. */ - yaml_BOOL_TAG = "tag:yaml.org,2002:bool" - /** The tag @c !!str for string values. */ - yaml_STR_TAG = "tag:yaml.org,2002:str" - /** The tag @c !!int for integer values. */ - yaml_INT_TAG = "tag:yaml.org,2002:int" - /** The tag @c !!float for float values. */ - yaml_FLOAT_TAG = "tag:yaml.org,2002:float" - /** The tag @c !!timestamp for date and time values. */ - yaml_TIMESTAMP_TAG = "tag:yaml.org,2002:timestamp" - - /** The tag @c !!seq is used to denote sequences. */ - yaml_SEQ_TAG = "tag:yaml.org,2002:seq" - /** The tag @c !!map is used to denote mapping. */ - yaml_MAP_TAG = "tag:yaml.org,2002:map" - - /** The default scalar tag is @c !!str. */ - yaml_DEFAULT_SCALAR_TAG = yaml_STR_TAG - /** The default sequence tag is @c !!seq. */ - yaml_DEFAULT_SEQUENCE_TAG = yaml_SEQ_TAG - /** The default mapping tag is @c !!map. */ - yaml_DEFAULT_MAPPING_TAG = yaml_MAP_TAG - - yaml_BINARY_TAG = "tag:yaml.org,2002:binary" -) - -/** Node types. */ -type yaml_node_type_t int - -const ( - /** An empty node. */ - yaml_NO_NODE yaml_node_type_t = iota - - /** A scalar node. */ - yaml_SCALAR_NODE - /** A sequence node. */ - yaml_SEQUENCE_NODE - /** A mapping node. */ - yaml_MAPPING_NODE -) - -/** An element of a sequence node. */ -type yaml_node_item_t int - -/** An element of a mapping node. */ -type yaml_node_pair_t struct { - /** The key of the element. */ - key int - /** The value of the element. */ - value int -} - -/** The node structure. */ -type yaml_node_t struct { - - /** The node type. */ - node_type yaml_node_type_t - - /** The node tag. */ - tag []byte - - /** The scalar parameters (for @c yaml_SCALAR_NODE). */ - scalar struct { - /** The scalar value. */ - value []byte - /** The scalar style. */ - style yaml_scalar_style_t - } - - /** The sequence parameters (for @c yaml_SEQUENCE_NODE). */ - sequence struct { - /** The stack of sequence items. */ - items []yaml_node_item_t - /** The sequence style. */ - style yaml_sequence_style_t - } - - /** The mapping parameters (for @c yaml_MAPPING_NODE). */ - mapping struct { - /** The stack of mapping pairs (key, value). */ - pairs []yaml_node_pair_t - /** The mapping style. */ - style yaml_mapping_style_t - } - - /** The beginning of the node. */ - start_mark YAML_mark_t - /** The end of the node. */ - end_mark YAML_mark_t -} - -/** The document structure. */ -type yaml_document_t struct { - - /** The document nodes. */ - nodes []yaml_node_t - - /** The version directive. */ - version_directive *yaml_version_directive_t - - /** The list of tag directives. */ - tags []yaml_tag_directive_t - - /** Is the document start indicator implicit? */ - start_implicit bool - /** Is the document end indicator implicit? */ - end_implicit bool - - /** The beginning of the document. */ - start_mark YAML_mark_t - /** The end of the document. */ - end_mark YAML_mark_t -} - -/** - * The prototype of a read handler. - * - * The read handler is called when the parser needs to read more bytes from the - * source. The handler should write not more than @a size bytes to the @a - * buffer. The number of written bytes should be set to the @a length variable. - * - * @param[in,out] data A pointer to an application data specified by - * yaml_parser_set_input(). - * @param[out] buffer The buffer to write the data from the source. - * @param[in] size The size of the buffer. - * @param[out] size_read The actual number of bytes read from the source. - * - * @returns On success, the handler should return @c 1. If the handler failed, - * the returned value should be @c 0. On EOF, the handler should set the - * @a size_read to @c 0 and return @c 1. - */ - -type yaml_read_handler_t func(parser *yaml_parser_t, buffer []byte) (n int, err error) - -/** - * This structure holds information about a potential simple key. - */ - -type yaml_simple_key_t struct { - /** Is a simple key possible? */ - possible bool - - /** Is a simple key required? */ - required bool - - /** The number of the token. */ - token_number int - - /** The position mark. */ - mark YAML_mark_t -} - -/** - * The states of the parser. - */ -type yaml_parser_state_t int - -const ( - /** Expect STREAM-START. */ - yaml_PARSE_STREAM_START_STATE yaml_parser_state_t = iota - /** Expect the beginning of an implicit document. */ - yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE - /** Expect DOCUMENT-START. */ - yaml_PARSE_DOCUMENT_START_STATE - /** Expect the content of a document. */ - yaml_PARSE_DOCUMENT_CONTENT_STATE - /** Expect DOCUMENT-END. */ - yaml_PARSE_DOCUMENT_END_STATE - /** Expect a block node. */ - yaml_PARSE_BLOCK_NODE_STATE - /** Expect a block node or indentless sequence. */ - yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE - /** Expect a flow node. */ - yaml_PARSE_FLOW_NODE_STATE - /** Expect the first entry of a block sequence. */ - yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE - /** Expect an entry of a block sequence. */ - yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE - /** Expect an entry of an indentless sequence. */ - yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE - /** Expect the first key of a block mapping. */ - yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE - /** Expect a block mapping key. */ - yaml_PARSE_BLOCK_MAPPING_KEY_STATE - /** Expect a block mapping value. */ - yaml_PARSE_BLOCK_MAPPING_VALUE_STATE - /** Expect the first entry of a flow sequence. */ - yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE - /** Expect an entry of a flow sequence. */ - yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE - /** Expect a key of an ordered mapping. */ - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE - /** Expect a value of an ordered mapping. */ - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE - /** Expect the and of an ordered mapping entry. */ - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE - /** Expect the first key of a flow mapping. */ - yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE - /** Expect a key of a flow mapping. */ - yaml_PARSE_FLOW_MAPPING_KEY_STATE - /** Expect a value of a flow mapping. */ - yaml_PARSE_FLOW_MAPPING_VALUE_STATE - /** Expect an empty value of a flow mapping. */ - yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE - /** Expect nothing. */ - yaml_PARSE_END_STATE -) - -/** - * This structure holds aliases data. - */ - -type yaml_alias_data_t struct { - /** The anchor. */ - anchor []byte - /** The node id. */ - index int - /** The anchor mark. */ - mark YAML_mark_t -} - -/** - * The parser structure. - * - * All members are internal. Manage the structure using the @c yaml_parser_ - * family of functions. - */ - -type yaml_parser_t struct { - - /** - * @name Error handling - * @{ - */ - - /** Error type. */ - error YAML_error_type_t - /** Error description. */ - problem string - /** The byte about which the problem occured. */ - problem_offset int - /** The problematic value (@c -1 is none). */ - problem_value int - /** The problem position. */ - problem_mark YAML_mark_t - /** The error context. */ - context string - /** The context position. */ - context_mark YAML_mark_t - - /** - * @} - */ - - /** - * @name Reader stuff - * @{ - */ - - /** Read handler. */ - read_handler yaml_read_handler_t - - /** Reader input data. */ - input_reader io.Reader - input []byte - input_pos int - - /** EOF flag */ - eof bool - - /** The working buffer. */ - buffer []byte - buffer_pos int - - /* The number of unread characters in the buffer. */ - unread int - - /** The raw buffer. */ - raw_buffer []byte - raw_buffer_pos int - - /** The input encoding. */ - encoding yaml_encoding_t - - /** The offset of the current position (in bytes). */ - offset int - - /** The mark of the current position. */ - mark YAML_mark_t - - /** - * @} - */ - - /** - * @name Scanner stuff - * @{ - */ - - /** Have we started to scan the input stream? */ - stream_start_produced bool - - /** Have we reached the end of the input stream? */ - stream_end_produced bool - - /** The number of unclosed '[' and '{' indicators. */ - flow_level int - - /** The tokens queue. */ - tokens []yaml_token_t - tokens_head int - - /** The number of tokens fetched from the queue. */ - tokens_parsed int - - /* Does the tokens queue contain a token ready for dequeueing. */ - token_available bool - - /** The indentation levels stack. */ - indents []int - - /** The current indentation level. */ - indent int - - /** May a simple key occur at the current position? */ - simple_key_allowed bool - - /** The stack of simple keys. */ - simple_keys []yaml_simple_key_t - - /** - * @} - */ - - /** - * @name Parser stuff - * @{ - */ - - /** The parser states stack. */ - states []yaml_parser_state_t - - /** The current parser state. */ - state yaml_parser_state_t - - /** The stack of marks. */ - marks []YAML_mark_t - - /** The list of TAG directives. */ - tag_directives []yaml_tag_directive_t - - /** - * @} - */ - - /** - * @name Dumper stuff - * @{ - */ - - /** The alias data. */ - aliases []yaml_alias_data_t - - /** The currently parsed document. */ - document *yaml_document_t - - /** - * @} - */ - -} - -/** - * The prototype of a write handler. - * - * The write handler is called when the emitter needs to flush the accumulated - * characters to the output. The handler should write @a size bytes of the - * @a buffer to the output. - * - * @param[in,out] data A pointer to an application data specified by - * yaml_emitter_set_output(). - * @param[in] buffer The buffer with bytes to be written. - * @param[in] size The size of the buffer. - * - * @returns On success, the handler should return @c 1. If the handler failed, - * the returned value should be @c 0. - */ - -type yaml_write_handler_t func(emitter *yaml_emitter_t, buffer []byte) error - -/** The emitter states. */ -type yaml_emitter_state_t int - -const ( - /** Expect STREAM-START. */ - yaml_EMIT_STREAM_START_STATE yaml_emitter_state_t = iota - /** Expect the first DOCUMENT-START or STREAM-END. */ - yaml_EMIT_FIRST_DOCUMENT_START_STATE - /** Expect DOCUMENT-START or STREAM-END. */ - yaml_EMIT_DOCUMENT_START_STATE - /** Expect the content of a document. */ - yaml_EMIT_DOCUMENT_CONTENT_STATE - /** Expect DOCUMENT-END. */ - yaml_EMIT_DOCUMENT_END_STATE - /** Expect the first item of a flow sequence. */ - yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE - /** Expect an item of a flow sequence. */ - yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE - /** Expect the first key of a flow mapping. */ - yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE - /** Expect a key of a flow mapping. */ - yaml_EMIT_FLOW_MAPPING_KEY_STATE - /** Expect a value for a simple key of a flow mapping. */ - yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE - /** Expect a value of a flow mapping. */ - yaml_EMIT_FLOW_MAPPING_VALUE_STATE - /** Expect the first item of a block sequence. */ - yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE - /** Expect an item of a block sequence. */ - yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE - /** Expect the first key of a block mapping. */ - yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE - /** Expect the key of a block mapping. */ - yaml_EMIT_BLOCK_MAPPING_KEY_STATE - /** Expect a value for a simple key of a block mapping. */ - yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE - /** Expect a value of a block mapping. */ - yaml_EMIT_BLOCK_MAPPING_VALUE_STATE - /** Expect nothing. */ - yaml_EMIT_END_STATE -) - -/** - * The emitter structure. - * - * All members are internal. Manage the structure using the @c yaml_emitter_ - * family of functions. - */ - -type yaml_emitter_t struct { - - /** - * @name Error handling - * @{ - */ - - /** Error type. */ - error YAML_error_type_t - /** Error description. */ - problem string - - /** - * @} - */ - - /** - * @name Writer stuff - * @{ - */ - - /** Write handler. */ - write_handler yaml_write_handler_t - - /** Standard (string or file) output data. */ - output_buffer *[]byte - output_writer io.Writer - - /** The working buffer. */ - buffer []byte - buffer_pos int - - /** The raw buffer. */ - raw_buffer []byte - raw_buffer_pos int - - /** The stream encoding. */ - encoding yaml_encoding_t - - /** - * @} - */ - - /** - * @name Emitter stuff - * @{ - */ - - /** If the output is in the canonical style? */ - canonical bool - /** The number of indentation spaces. */ - best_indent int - /** The preferred width of the output lines. */ - best_width int - /** Allow unescaped non-ASCII characters? */ - unicode bool - /** The preferred line break. */ - line_break yaml_break_t - - /** The stack of states. */ - states []yaml_emitter_state_t - - /** The current emitter state. */ - state yaml_emitter_state_t - - /** The event queue. */ - events []yaml_event_t - events_head int - - /** The stack of indentation levels. */ - indents []int - - /** The list of tag directives. */ - tag_directives []yaml_tag_directive_t - - /** The current indentation level. */ - indent int - - /** The current flow level. */ - flow_level int - - /** Is it the document root context? */ - root_context bool - /** Is it a sequence context? */ - sequence_context bool - /** Is it a mapping context? */ - mapping_context bool - /** Is it a simple mapping key context? */ - simple_key_context bool - - /** The current line. */ - line int - /** The current column. */ - column int - /** If the last character was a whitespace? */ - whitespace bool - /** If the last character was an indentation character (' ', '-', '?', ':')? */ - indention bool - /** If an explicit document end is required? */ - open_ended bool - - /** Anchor analysis. */ - anchor_data struct { - /** The anchor value. */ - anchor []byte - /** Is it an alias? */ - alias bool - } - - /** Tag analysis. */ - tag_data struct { - /** The tag handle. */ - handle []byte - /** The tag suffix. */ - suffix []byte - } - - /** Scalar analysis. */ - scalar_data struct { - /** The scalar value. */ - value []byte - /** Does the scalar contain line breaks? */ - multiline bool - /** Can the scalar be expessed in the flow plain style? */ - flow_plain_allowed bool - /** Can the scalar be expressed in the block plain style? */ - block_plain_allowed bool - /** Can the scalar be expressed in the single quoted style? */ - single_quoted_allowed bool - /** Can the scalar be expressed in the literal or folded styles? */ - block_allowed bool - /** The output style. */ - style yaml_scalar_style_t - } - - /** - * @} - */ - - /** - * @name Dumper stuff - * @{ - */ - - /** If the stream was already opened? */ - opened bool - /** If the stream was already closed? */ - closed bool - - /** The information associated with the document nodes. */ - anchors *struct { - /** The number of references. */ - references int - /** The anchor id. */ - anchor int - /** If the node has been emitted? */ - serialized bool - } - - /** The last assigned anchor id. */ - last_anchor_id int - - /** The currently emitted document. */ - document *yaml_document_t - - /** - * @} - */ - -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_hmac.go b/vendor/github.com/coreos/go-oidc/jose/sig_hmac.go similarity index 100% rename from vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_hmac.go rename to vendor/github.com/coreos/go-oidc/jose/sig_hmac.go diff --git a/vendor/github.com/davecgh/go-spew/LICENSE b/vendor/github.com/davecgh/go-spew/LICENSE index bb67332..2a7cfd2 100644 --- a/vendor/github.com/davecgh/go-spew/LICENSE +++ b/vendor/github.com/davecgh/go-spew/LICENSE @@ -1,5 +1,3 @@ -ISC License - Copyright (c) 2012-2013 Dave Collins Permission to use, copy, modify, and distribute this software for any diff --git a/vendor/github.com/davecgh/go-spew/spew/bypass.go b/vendor/github.com/davecgh/go-spew/spew/bypass.go index d42a0bc..565bf58 100644 --- a/vendor/github.com/davecgh/go-spew/spew/bypass.go +++ b/vendor/github.com/davecgh/go-spew/spew/bypass.go @@ -13,10 +13,9 @@ // OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. // NOTE: Due to the following build constraints, this file will only be compiled -// when the code is not running on Google App Engine, compiled by GopherJS, and -// "-tags safe" is not added to the go build command line. The "disableunsafe" -// tag is deprecated and thus should not be used. -// +build !js,!appengine,!safe,!disableunsafe +// when the code is not running on Google App Engine and "-tags disableunsafe" +// is not added to the go build command line. +// +build !appengine,!disableunsafe package spew diff --git a/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go b/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go index e47a4e7..457e412 100644 --- a/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go +++ b/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go @@ -13,10 +13,9 @@ // OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. // NOTE: Due to the following build constraints, this file will only be compiled -// when the code is running on Google App Engine, compiled by GopherJS, or -// "-tags safe" is added to the go build command line. The "disableunsafe" -// tag is deprecated and thus should not be used. -// +build js appengine safe disableunsafe +// when either the code is running on Google App Engine or "-tags disableunsafe" +// is added to the go build command line. +// +build appengine disableunsafe package spew diff --git a/vendor/github.com/davecgh/go-spew/spew/config.go b/vendor/github.com/davecgh/go-spew/spew/config.go index 5552827..ee1ab07 100644 --- a/vendor/github.com/davecgh/go-spew/spew/config.go +++ b/vendor/github.com/davecgh/go-spew/spew/config.go @@ -64,7 +64,7 @@ type ConfigState struct { // inside these interface methods. As a result, this option relies on // access to the unsafe package, so it will not have any effect when // running in environments without access to the unsafe package such as - // Google App Engine or with the "safe" build tag specified. + // Google App Engine or with the "disableunsafe" build tag specified. DisablePointerMethods bool // ContinueOnMethod specifies whether or not recursion should continue once diff --git a/vendor/github.com/docker/distribution/reference/reference.go b/vendor/github.com/docker/distribution/reference/reference.go index dc3af16..bb09fa2 100644 --- a/vendor/github.com/docker/distribution/reference/reference.go +++ b/vendor/github.com/docker/distribution/reference/reference.go @@ -24,7 +24,6 @@ package reference import ( "errors" "fmt" - "strings" "github.com/docker/distribution/digest" ) @@ -44,9 +43,6 @@ var ( // ErrDigestInvalidFormat represents an error while trying to parse a string as a tag. ErrDigestInvalidFormat = errors.New("invalid digest format") - // ErrNameContainsUppercase is returned for invalid repository names that contain uppercase characters. - ErrNameContainsUppercase = errors.New("repository name must be lowercase") - // ErrNameEmpty is returned for empty, invalid repository names. ErrNameEmpty = errors.New("repository name must have at least one component") @@ -138,7 +134,7 @@ type Canonical interface { func SplitHostname(named Named) (string, string) { name := named.Name() match := anchoredNameRegexp.FindStringSubmatch(name) - if len(match) != 3 { + if match == nil || len(match) != 3 { return "", name } return match[1], match[2] @@ -153,9 +149,7 @@ func Parse(s string) (Reference, error) { if s == "" { return nil, ErrNameEmpty } - if ReferenceRegexp.FindStringSubmatch(strings.ToLower(s)) != nil { - return nil, ErrNameContainsUppercase - } + // TODO(dmcgowan): Provide more specific and helpful error return nil, ErrReferenceInvalidFormat } diff --git a/vendor/github.com/emicklei/go-restful/swagger/model_builder.go b/vendor/github.com/emicklei/go-restful/swagger/model_builder.go index 3c988c3..398e830 100644 --- a/vendor/github.com/emicklei/go-restful/swagger/model_builder.go +++ b/vendor/github.com/emicklei/go-restful/swagger/model_builder.go @@ -43,12 +43,6 @@ func (b modelBuilder) addModelFrom(sample interface{}) { } func (b modelBuilder) addModel(st reflect.Type, nameOverride string) *Model { - // Turn pointers into simpler types so further checks are - // correct. - if st.Kind() == reflect.Ptr { - st = st.Elem() - } - modelName := b.keyFrom(st) if nameOverride != "" { modelName = nameOverride @@ -143,11 +137,6 @@ func (b modelBuilder) buildProperty(field reflect.StructField, model *Model, mod return "", "", prop } - if field.Name == "XMLName" && field.Type.String() == "xml.Name" { - // property is metadata for the xml.Name attribute, can be skipped - return "", "", prop - } - if tag := field.Tag.Get("modelDescription"); tag != "" { modelDescription = tag } diff --git a/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go b/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go index a433b6b..04fff2c 100644 --- a/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go +++ b/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go @@ -33,21 +33,6 @@ func (prop *ModelProperty) setMaximum(field reflect.StructField) { func (prop *ModelProperty) setType(field reflect.StructField) { if tag := field.Tag.Get("type"); tag != "" { - // Check if the first two characters of the type tag are - // intended to emulate slice/array behaviour. - // - // If type is intended to be a slice/array then add the - // overriden type to the array item instead of the main property - if len(tag) > 2 && tag[0:2] == "[]" { - pType := "array" - prop.Type = &pType - prop.Items = new(Item) - - iType := tag[2:] - prop.Items.Type = &iType - return - } - prop.Type = &tag } } diff --git a/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go b/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go index f12b6b1..58dd625 100644 --- a/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go +++ b/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go @@ -277,7 +277,7 @@ func composeResponseMessages(route restful.Route, decl *ApiDeclaration, config * } // sort by code codes := sort.IntSlice{} - for code := range route.ResponseErrors { + for code, _ := range route.ResponseErrors { codes = append(codes, code) } codes.Sort() diff --git a/vendor/github.com/ghodss/yaml/README.md b/vendor/github.com/ghodss/yaml/README.md index 6284973..f8f7e36 100644 --- a/vendor/github.com/ghodss/yaml/README.md +++ b/vendor/github.com/ghodss/yaml/README.md @@ -4,17 +4,17 @@ ## Introduction -A wrapper around [candiedyaml](https://github.com/cloudfoundry-incubator/candiedyaml) designed to enable a better way of handling YAML when marshaling to and from structs. +A wrapper around [go-yaml](https://github.com/go-yaml/yaml) designed to enable a better way of handling YAML when marshaling to and from structs. -In short, this library first converts YAML to JSON using candiedyaml and then uses `json.Marshal` and `json.Unmarshal` to convert to or from the struct. This means that it effectively reuses the JSON struct tags as well as the custom JSON methods `MarshalJSON` and `UnmarshalJSON` unlike candiedyaml. For a detailed overview of the rationale behind this method, [see this blog post](http://ghodss.com/2014/the-right-way-to-handle-yaml-in-golang/). +In short, this library first converts YAML to JSON using go-yaml and then uses `json.Marshal` and `json.Unmarshal` to convert to or from the struct. This means that it effectively reuses the JSON struct tags as well as the custom JSON methods `MarshalJSON` and `UnmarshalJSON` unlike go-yaml. For a detailed overview of the rationale behind this method, [see this blog post](http://ghodss.com/2014/the-right-way-to-handle-yaml-in-golang/). ## Compatibility -This package uses [candiedyaml](https://github.com/cloudfoundry-incubator/candiedyaml) and therefore supports [everything candiedyaml supports](https://github.com/cloudfoundry-incubator/candiedyaml#candiedyaml). +This package uses [go-yaml v2](https://github.com/go-yaml/yaml) and therefore supports [everything go-yaml supports](https://github.com/go-yaml/yaml#compatibility). ## Caveats -**Caveat #1:** When using `yaml.Marshal` and `yaml.Unmarshal`, binary data should NOT be preceded with the `!!binary` YAML tag. If you do, candiedyaml will convert the binary data from base64 to native binary data, which is not compatible with JSON. You can still use binary in your YAML files though - just store them without the `!!binary` tag and decode the base64 in your code (e.g. in the custom JSON methods `MarshalJSON` and `UnmarshalJSON`). This also has the benefit that your YAML and your JSON binary data will be decoded exactly the same way. As an example: +**Caveat #1:** When using `yaml.Marshal` and `yaml.Unmarshal`, binary data should NOT be preceded with the `!!binary` YAML tag. If you do, go-yaml will convert the binary data from base64 to native binary data, which is not compatible with JSON. You can still use binary in your YAML files though - just store them without the `!!binary` tag and decode the base64 in your code (e.g. in the custom JSON methods `MarshalJSON` and `UnmarshalJSON`). This also has the benefit that your YAML and your JSON binary data will be decoded exactly the same way. As an example: ``` BAD: @@ -44,8 +44,6 @@ import "github.com/ghodss/yaml" Usage is very similar to the JSON library: ```go -package main - import ( "fmt" @@ -54,7 +52,7 @@ import ( type Person struct { Name string `json:"name"` // Affects YAML field names too. - Age int `json:"age"` + Age int `json:"name"` } func main() { @@ -67,13 +65,13 @@ func main() { } fmt.Println(string(y)) /* Output: - age: 30 name: John + age: 30 */ // Unmarshal the YAML back into a Person struct. var p2 Person - err = yaml.Unmarshal(y, &p2) + err := yaml.Unmarshal(y, &p2) if err != nil { fmt.Printf("err: %v\n", err) return @@ -88,8 +86,6 @@ func main() { `yaml.YAMLToJSON` and `yaml.JSONToYAML` methods are also available: ```go -package main - import ( "fmt" diff --git a/vendor/github.com/ghodss/yaml/yaml.go b/vendor/github.com/ghodss/yaml/yaml.go index 0bb015b..c02beac 100644 --- a/vendor/github.com/ghodss/yaml/yaml.go +++ b/vendor/github.com/ghodss/yaml/yaml.go @@ -7,7 +7,7 @@ import ( "reflect" "strconv" - yaml "github.com/cloudfoundry-incubator/candiedyaml" + "gopkg.in/yaml.v2" ) // Marshals the object into JSON then converts JSON to YAML and returns the @@ -15,12 +15,12 @@ import ( func Marshal(o interface{}) ([]byte, error) { j, err := json.Marshal(o) if err != nil { - return nil, fmt.Errorf("error marshaling into JSON: %v", err) + return nil, fmt.Errorf("error marshaling into JSON: ", err) } y, err := JSONToYAML(j) if err != nil { - return nil, fmt.Errorf("error converting JSON to YAML: %v", err) + return nil, fmt.Errorf("error converting JSON to YAML: ", err) } return y, nil @@ -48,7 +48,7 @@ func JSONToYAML(j []byte) ([]byte, error) { var jsonObj interface{} // We are using yaml.Unmarshal here (instead of json.Unmarshal) because the // Go JSON library doesn't try to pick the right number type (int, float, - // etc.) when unmarshalling to interface{}, it just picks float64 + // etc.) when unmarshling to interface{}, it just picks float64 // universally. go-yaml does go through the effort of picking the right // number type, so we can preserve number type throughout this process. err := yaml.Unmarshal(j, &jsonObj) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.drone.sec b/vendor/github.com/go-openapi/spec/.drone.sec similarity index 100% rename from vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.drone.sec rename to vendor/github.com/go-openapi/spec/.drone.sec diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.drone.yml b/vendor/github.com/go-openapi/spec/.drone.yml similarity index 100% rename from vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.drone.yml rename to vendor/github.com/go-openapi/spec/.drone.yml diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.pullapprove.yml b/vendor/github.com/go-openapi/spec/.pullapprove.yml similarity index 100% rename from vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.pullapprove.yml rename to vendor/github.com/go-openapi/spec/.pullapprove.yml diff --git a/vendor/github.com/go-openapi/spec/.travis.yml b/vendor/github.com/go-openapi/spec/.travis.yml deleted file mode 100644 index ea80ef2..0000000 --- a/vendor/github.com/go-openapi/spec/.travis.yml +++ /dev/null @@ -1,16 +0,0 @@ -language: go -go: -- 1.7 -install: -- go get -u github.com/stretchr/testify -- go get -u github.com/go-openapi/swag -- go get -u gopkg.in/yaml.v2 -- go get -u github.com/go-openapi/jsonpointer -- go get -u github.com/go-openapi/jsonreference -script: -- go test -v -race -cover -coverprofile=coverage.txt -covermode=atomic ./... -after_success: -- bash <(curl -s https://codecov.io/bash) -notifications: - slack: - secure: QUWvCkBBK09GF7YtEvHHVt70JOkdlNBG0nIKu/5qc4/nW5HP8I2w0SEf/XR2je0eED1Qe3L/AfMCWwrEj+IUZc3l4v+ju8X8R3Lomhme0Eb0jd1MTMCuPcBT47YCj0M7RON7vXtbFfm1hFJ/jLe5+9FXz0hpXsR24PJc5ZIi/ogNwkaPqG4BmndzecpSh0vc2FJPZUD9LT0I09REY/vXR0oQAalLkW0asGD5taHZTUZq/kBpsNxaAFrLM23i4mUcf33M5fjLpvx5LRICrX/57XpBrDh2TooBU6Qj3CgoY0uPRYUmSNxbVx1czNzl2JtEpb5yjoxfVPQeg0BvQM00G8LJINISR+ohrjhkZmAqchDupAX+yFrxTtORa78CtnIL6z/aTNlgwwVD8kvL/1pFA/JWYmKDmz93mV/+6wubGzNSQCstzjkFA4/iZEKewKUoRIAi/fxyscP6L/rCpmY/4llZZvrnyTqVbt6URWpopUpH4rwYqreXAtJxJsfBJIeSmUIiDIOMGkCTvyTEW3fWGmGoqWtSHLoaWDyAIGb7azb+KvfpWtEcoPFWfSWU+LGee0A/YsUhBl7ADB9A0CJEuR8q4BPpKpfLwPKSiKSAXL7zDkyjExyhtgqbSl2jS+rKIHOZNL8JkCcTP2MKMVd563C5rC5FMKqu3S9m2b6380E= diff --git a/vendor/github.com/go-openapi/spec/README.md b/vendor/github.com/go-openapi/spec/README.md index 1d16220..4b2af12 100644 --- a/vendor/github.com/go-openapi/spec/README.md +++ b/vendor/github.com/go-openapi/spec/README.md @@ -1,5 +1,5 @@ -# OAI object model [![Build Status](https://travis-ci.org/go-openapi/spec.svg?branch=master)](https://travis-ci.org/go-openapi/spec) [![codecov](https://codecov.io/gh/go-openapi/spec/branch/master/graph/badge.svg)](https://codecov.io/gh/go-openapi/spec) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) +# OAI object model [![Build Status](https://ci.vmware.run/api/badges/go-openapi/spec/status.svg)](https://ci.vmware.run/go-openapi/spec) [![Coverage](https://coverage.vmware.run/badges/go-openapi/spec/coverage.svg)](https://coverage.vmware.run/go-openapi/spec) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) [![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/spec/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/spec?status.svg)](http://godoc.org/github.com/go-openapi/spec) -The object model for OpenAPI specification documents +The object model for OpenAPI specification documents \ No newline at end of file diff --git a/vendor/github.com/go-openapi/spec/bindata.go b/vendor/github.com/go-openapi/spec/bindata.go index 54b98e6..294cbcc 100644 --- a/vendor/github.com/go-openapi/spec/bindata.go +++ b/vendor/github.com/go-openapi/spec/bindata.go @@ -1,3 +1,17 @@ +// Copyright 2015 go-swagger maintainers +// +// 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 go-bindata. // sources: // schemas/jsonschema-draft-04.json @@ -69,7 +83,7 @@ func (fi bindataFileInfo) Sys() interface{} { return nil } -var _jsonschemaDraft04JSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xc4\x57\x3b\x6f\xdb\x3e\x10\xdf\xf3\x29\x08\x26\x63\xf2\x97\xff\x40\x27\x6f\x45\xbb\x18\x68\xd1\x0c\xdd\x0c\x0f\xb4\x75\xb2\x19\x50\xa4\x42\x51\x81\x0d\x43\xdf\xbd\xa0\xa8\x07\x29\x91\x92\x2d\xbb\x8d\x97\x28\xbc\xd7\xef\x8e\xf7\xe2\xf9\x01\x21\x84\x30\x8d\xf1\x12\xe1\x83\x52\xd9\x32\x8a\xde\x72\xc1\x5f\xf2\xdd\x01\x52\xf2\x9f\x90\xfb\x28\x96\x24\x51\x2f\x8b\x2f\x91\x39\x7b\xc4\xcf\x46\xe8\xc9\xfc\x3f\x43\x32\x86\x7c\x27\x69\xa6\xa8\xe0\x5a\xfa\x9b\x90\x80\x0c\x0b\x4a\x41\x91\x5a\x45\xc7\x9d\x50\x4e\x35\x73\x8e\x97\xc8\x20\xae\x08\x86\xed\xab\x94\xe4\xe4\x10\x2a\xa2\x3a\x65\xa0\x95\x93\x8a\xfc\xec\x12\x53\xca\x57\x0a\x52\xad\xef\xff\x1e\x89\xd6\xe7\x67\x84\x9f\x24\x24\x5a\xc5\x23\x46\x65\xcb\x54\x76\xfc\x38\x13\x39\x55\xf4\x03\x56\x5c\xc1\x1e\x64\x18\x04\xad\x19\x86\x30\x68\x5a\xa4\x78\x89\x16\x97\xe8\xff\x0e\x09\x29\x98\x5a\x0c\xed\x10\xc6\x7e\x69\xa8\x6b\x07\x76\x64\x45\x2e\xea\x63\x45\xe5\xb3\x66\x8e\x8d\x4e\x0d\x01\x95\x68\xe3\x85\x91\xd3\x34\x63\xf0\xfb\x94\x41\x3e\x34\x0d\xbc\x72\x60\xdd\x46\x1a\xe1\xad\x10\x0c\x08\xd7\x9f\xad\xe3\x08\xf3\x82\x31\xf3\x37\xdd\x9a\x13\xb1\x7d\x83\x9d\xd2\x5f\xb9\x92\x94\xef\x71\xc8\x7e\x45\x9d\x73\xcf\xd6\x65\x36\x7c\x8d\xa9\xf2\xf2\x94\x28\x38\x7d\x2f\xa0\xa1\x2a\x59\x40\x07\xf3\xc1\x02\xdb\xda\x68\x1c\x33\xa7\x99\x14\x19\x48\x45\x7b\xd1\x33\x45\x17\xf0\xa6\x46\xd9\x03\x92\x08\x99\x12\x7d\x57\xb8\x90\x14\x7b\x63\xd5\x15\xe5\xbd\x35\x2b\xaa\x18\x4c\xea\xf5\x8a\xba\xf5\x3e\x4b\x41\x93\xa5\x67\xfb\x38\x2d\x98\xa2\x19\x83\x2a\xf7\x03\x6a\x9b\x74\x0b\x56\x5e\x8f\x02\xc7\x1d\x2b\x72\xfa\x01\x3f\x5b\x16\xf7\xc6\x6d\xfb\xe4\x58\xb3\x8c\x1b\xf7\x0a\x77\x86\xa6\xb4\xb4\xf5\xe4\x92\xbb\xa0\x24\x84\xe5\x01\x84\xad\x13\x37\x21\x9c\xd2\x72\x0b\x42\x72\xfc\x01\x7c\xaf\x0e\xbd\x9e\x3b\xd5\xbc\x1c\x1f\xaf\xd6\xd0\xb6\x52\xb7\xdf\x12\xa5\x40\x4e\xe7\x68\xb0\x78\x24\xec\xe1\xe8\x0f\x26\x89\xe3\x0a\x0a\x61\x4d\x23\xe9\xf7\x70\x7e\x32\x3d\xdc\x39\xd6\xbf\xf3\x30\xd0\xfd\xf6\x55\xb3\x79\x27\x96\xfe\x6d\x82\x37\x73\xf6\x8f\x36\x3a\x03\xa4\x6d\x7d\x1c\x9e\x73\x35\xf6\x18\xbf\x15\x76\x4a\x8e\x2b\xcf\x00\xbf\x2a\x99\xae\x55\xe0\xcf\x25\x77\x68\xfc\x95\xba\x79\x75\x06\xcb\x5c\x77\x67\x69\xf1\xfb\x2c\xe1\xbd\xa0\x12\xe2\x31\x45\xf6\x30\x0f\x14\xc8\xab\x7f\x60\x4e\x27\xe0\x3f\xaf\x92\xd0\x6a\x8a\x82\xdb\xc0\xa4\xbb\x63\x65\x34\x0d\x28\xb0\x6b\x7c\x1e\x1e\xd3\x51\xc7\x6e\xf4\x33\x60\xc5\x90\x01\x8f\x81\xef\xee\x88\x68\x90\x69\x23\xb9\x8a\x2e\x69\x98\x7d\xa6\x91\x32\x1a\xc8\x6e\x9c\x13\x7f\x10\xea\xcd\xfd\x4e\xef\xa6\xb1\x25\xd9\xde\x22\x8d\xfa\x59\x63\xc5\x0d\x80\xf5\x28\xf1\xd6\xb9\x37\x9e\xa3\xee\xb5\x4c\xbe\x37\xe0\x55\xc6\x27\x82\x75\x49\xd0\xda\xe0\xb9\x1d\xca\xbf\x5b\xd4\xcf\xbf\x0b\x47\xac\x2d\x59\x07\xfe\x7a\x49\xc1\x61\xa6\x24\x17\x2a\xf0\xbe\x2e\xdb\x17\x7f\xa0\x3c\x7d\x4b\xf3\xba\xdb\xc3\xed\x06\xee\xdb\x5e\xd7\xdd\x42\x5c\x47\xb2\xb3\x68\x75\x8c\xf2\xe1\x4f\x00\x00\x00\xff\xff\x4e\x9b\x8d\xdf\x17\x11\x00\x00") +var _jsonschemaDraft04JSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xcc\x57\x3b\x6f\xdb\x30\x10\xde\xfd\x2b\x04\xa5\x63\x52\xb9\x40\xa7\x6c\x45\xbb\x18\x68\xd1\x0c\xdd\x0c\x0f\xb4\x75\xb2\x19\x50\xa4\x42\x51\x85\x0d\x43\xff\xbd\xa4\xa8\x07\x29\x91\x92\x2d\xbb\x48\xb4\xc4\xe1\xbd\xbe\x3b\xde\x8b\xe7\x45\x20\xbf\x10\xc7\xe1\x73\x10\x1e\x84\xc8\x9e\xa3\xe8\x35\x67\xf4\x29\xdf\x1d\x20\x45\x9f\x19\xdf\x47\x31\x47\x89\x78\x5a\x7e\x8d\xf4\xd9\x43\xf8\xa8\x85\x3e\xe9\xff\x67\x48\xc6\x90\xef\x38\xce\x04\x66\x54\x49\x7f\x67\x1c\x02\xcd\x12\xa4\x20\x50\xad\xa2\xe3\x4e\x30\xc5\x8a\x39\x97\xdc\x1a\x71\x45\xd0\x6c\xdf\x38\x47\x27\x8b\x50\x11\xc5\x29\x03\xa5\x1c\x55\xe4\x47\x9b\x98\x62\xba\x12\x90\x2a\x7d\x5f\x7a\x24\x5c\x9f\x9f\xa5\x83\x1c\x12\xa5\xe2\x21\x0c\xca\x96\xa9\xec\xf8\xc3\x8c\xe5\x12\xd7\x5f\x58\x51\x01\x7b\xe0\x7e\x10\xb8\x66\x18\xc2\xc0\x69\x91\x4a\x8e\xe5\x25\xfa\x7f\x40\x82\x0a\x22\x96\x43\x3b\x88\x90\xdf\x0a\xea\xda\x82\x1d\x19\x91\x8b\xfa\x58\xa5\x21\xc5\x1c\x6b\x9d\x0a\x42\x50\x06\x1b\x27\x8c\x1c\xa7\x19\x81\x3f\xd2\x97\x7c\x68\x1a\x68\xe5\xc0\xba\x8d\x74\x10\x6e\x19\x23\x80\xa8\xfa\xd9\x3a\x1e\x84\xb4\x20\x44\xff\x4d\xb7\xfa\x84\x6d\x5f\x61\x27\xd4\xaf\x5c\x70\x4c\xf7\xa1\xcf\x7e\x45\x9d\x73\xcf\xc6\x65\x36\x7c\x8d\xa9\xf2\xf2\x94\x28\x28\x7e\x2b\xa0\xa1\x0a\x5e\x40\x07\x73\x61\x80\x6d\x6d\x34\x8e\xe9\xd3\x8c\xb3\x0c\xb8\xc0\xbd\xe8\xe9\xa2\xf3\x78\x53\xa3\xec\x01\x49\x18\x4f\x91\xba\xab\xb0\xe0\x38\x74\xc6\xaa\x2b\xca\x7b\x6b\x16\x58\x10\x98\xd4\xeb\x14\xb5\xeb\x7d\x96\x82\x26\x4b\xcf\xe6\x71\x2a\xcf\xb0\x4c\xcd\x2a\xf7\x3d\x6a\x9b\x74\xf3\x56\x5e\x8f\x02\xc7\x1d\x29\x72\x59\x28\xbf\x5a\x16\xfb\xc6\x4d\xfb\xe8\x58\xb3\x8c\x1b\x77\x0a\x77\x86\xa6\xb4\xb4\xf5\x64\x93\xbb\xa0\x24\x88\xe4\x1e\x84\xad\x13\x37\x21\x9c\xd2\x72\x0b\x42\x74\xfc\x09\x74\x2f\x0e\xbd\x9e\x3b\xd5\xbc\x2c\x1f\xaf\xd6\xd0\xb6\x52\xbb\xdf\x22\x21\x80\x4f\xe7\xa8\xb7\x78\xb8\xd4\x7d\x74\x07\x13\xc5\x71\x05\x05\x91\xa6\x91\xf4\x7b\x38\x3d\xe9\x1e\x6e\x1d\xab\xef\x3c\x0c\x74\xbf\x7d\xd5\x6c\xce\x89\xa5\xbe\x8d\xf7\x66\xce\xee\xd1\x86\x67\x80\x34\xad\x8f\xc3\xb3\xae\xc6\x1c\xe3\xb7\xc2\x96\xd9\xb4\x72\x0c\xf0\xab\x92\xe9\x5a\x05\xee\x5c\xb2\x87\xc6\x7f\xa9\x9b\x17\x6b\xb0\xcc\x75\x77\x96\x16\xb7\xcf\x1c\xde\x0a\xcc\x21\x1e\x53\x64\x0e\x73\x4f\x81\xbc\xb8\x07\xa6\xe6\xfa\x50\x55\xe2\x5b\x4d\xad\x4b\xb6\xb6\x81\x49\x77\xc7\xca\x68\x1a\x90\x67\xd7\x78\x3f\x3c\xba\xa3\x8e\xdd\xe8\x7b\xc0\x8a\x21\x03\x1a\x03\xdd\xdd\x11\xd1\x20\xd3\x46\x72\x55\x7d\x93\x0d\xb3\xcf\x34\x52\x46\x03\xd9\x8d\x75\xe2\x0e\x42\xbd\xb9\xdf\xe9\xdd\x34\xb6\x24\x9b\x5b\xa4\x56\x3f\x6b\xac\xd8\x01\x30\x1e\x25\xce\x3a\x77\xc6\x73\xd4\xbd\x96\xc9\xf5\x06\xbc\xca\xf8\x44\xb0\x2e\x09\x5a\xf3\xf5\x3a\x94\x7b\xb7\xa8\x9f\x7f\x17\x8e\x58\x53\xb2\x0e\xfc\xf5\x92\x8c\xc2\x4c\x49\xca\x84\xe7\x7d\x5d\xb6\x2f\x7e\x4f\x79\xba\x96\xe6\x75\xb7\x87\x9b\x0d\xdc\xb5\xbd\xae\xbb\x85\xb8\x8e\x64\x67\xd1\xe8\x18\xe5\xe2\x5f\x00\x00\x00\xff\xff\x4e\x9b\x8d\xdf\x17\x11\x00\x00") func jsonschemaDraft04JSONBytes() ([]byte, error) { return bindataRead( @@ -84,12 +98,12 @@ func jsonschemaDraft04JSON() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "jsonschema-draft-04.json", size: 4375, mode: os.FileMode(420), modTime: time.Unix(1460872076, 0)} + info := bindataFileInfo{name: "jsonschema-draft-04.json", size: 4375, mode: os.FileMode(420), modTime: time.Unix(1441640690, 0)} a := &asset{bytes: bytes, info: info} return a, nil } -var _v2SchemaJSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xec\x5d\x4f\x93\xdb\x36\xb2\xbf\xfb\x53\xa0\x14\x57\xd9\xae\xd8\x92\xe3\xf7\x2e\xcf\x97\xd4\xbc\xd8\x49\x66\x37\x5e\x4f\x79\x26\xbb\x87\x78\x5c\x05\x91\x2d\x09\x09\x09\x30\x00\x38\x33\x5a\xef\x7c\xf7\x2d\xf0\x9f\x08\x02\x20\x41\x8a\xd2\xc8\x0e\x0f\xa9\x78\x28\xa0\xd1\xdd\x68\x34\x7e\xdd\xf8\xf7\xf9\x11\x42\x33\x49\x64\x04\xb3\xd7\x68\x76\x86\xfe\x76\xf9\xfe\x1f\xe8\x32\xd8\x40\x8c\xd1\x8a\x71\x74\x79\x8b\xd7\x6b\xe0\xe8\xd5\xfc\x25\x3a\xbb\x38\x9f\xcf\x9e\xab\x0a\x24\x54\xa5\x37\x52\x26\xaf\x17\x0b\x91\x17\x99\x13\xb6\xb8\x79\xb5\x10\x59\xdd\xf9\xef\x82\xd1\x6f\xf2\xc2\x8f\xf3\x4f\xb5\x1a\xea\xc7\x17\x45\x41\xc6\xd7\x8b\x90\xe3\x95\x7c\xf1\xf2\x7f\x8b\xca\x45\x3d\xb9\x4d\x32\xa6\xd8\xf2\x77\x08\x64\xfe\x8d\xc3\x9f\x29\xe1\xa0\x9a\xff\xed\x11\x42\x08\xcd\x8a\xd6\xb3\x9f\x15\x67\x74\xc5\xca\x7f\x27\x58\x6e\xc4\xec\x11\x42\xd7\x59\x5d\x1c\x86\x44\x12\x46\x71\x74\xc1\x59\x02\x5c\x12\x10\xb3\xd7\x68\x85\x23\x01\x59\x81\x04\x4b\x09\x9c\x6a\xbf\x7e\xce\x49\x7d\xba\x7b\x51\xfd\xa1\x44\xe2\xb0\x52\xac\x7d\xb3\x08\x61\x45\x68\x46\x56\x2c\x6e\x80\x86\x8c\xbf\xbd\x93\x40\x05\x61\x74\x96\x95\xbe\x7f\x84\xd0\x7d\x4e\xde\x42\xb7\xe4\xbe\x46\xbb\x14\x5b\x48\x4e\xe8\xba\x90\x05\xa1\x19\xd0\x34\xae\xc4\xce\xbe\xbc\x9a\xbf\x9c\x15\x7f\x5d\x57\xc5\x42\x10\x01\x27\x89\xe2\x48\x51\xb9\xda\x40\xd5\x87\x37\xc0\x15\x5f\x88\xad\x90\xdc\x10\x81\x42\x16\xa4\x31\x50\x39\x2f\x38\xad\xab\xb0\x53\xd8\xac\x94\x56\x6f\xc3\x84\xf4\x11\xa4\x50\xb3\xfa\xe9\xd3\x6f\x9f\x3e\xdf\x2f\xd0\xeb\x8f\x1f\x3f\x7e\xbc\xfe\xf6\xe9\xf7\xaf\x5f\x7f\xfc\x18\x7e\xfb\xec\xfb\xc7\xb3\x36\x79\x54\x43\xe8\x29\xc5\x31\x20\xc6\x11\x49\x9e\xe5\x12\x41\x66\xa0\xe8\xed\x1d\x8e\x93\x08\x5e\xa3\x27\x3b\xc3\x7c\xa2\x73\xba\xc4\x02\x2e\xb0\xdc\xf4\xe5\x76\xd1\xca\x96\xa2\x8a\x94\xcd\x21\xc9\x6c\xec\x2c\x70\x42\x9e\x34\x74\x9d\x19\x7c\xcd\x20\x9c\xea\x2e\x0a\xfe\x42\x84\xd4\x29\x04\x8c\x8a\xb4\x41\xa2\xc1\xdc\x19\x8a\x88\x90\x4a\x49\xef\xce\xdf\xbd\x45\x4a\x52\x81\x70\x10\x40\x22\x21\x44\xcb\x6d\xc5\xec\x4e\x3c\x1c\x45\xef\x57\x9a\xb5\x7d\xae\xfe\xe5\xe4\x31\x86\x90\xe0\xab\x6d\x02\x3b\x2e\xcb\x11\x90\xd9\xa8\xc6\x77\xc2\x59\x98\x06\xfd\xf9\x2e\x78\x45\x01\xa6\xa8\xa0\x71\x5c\xbe\x33\xa7\xd2\xd9\x5f\x95\xef\xd9\xd5\xac\xfd\xdc\x5d\xbf\x5e\xb8\xd1\x3e\xc7\x31\x48\xe0\x5e\x4c\x14\x65\xdf\xb8\xa8\x71\x10\x09\xa3\xc2\xc7\x02\xcb\xa2\x4e\x5a\x02\x82\x94\x13\xb9\xf5\x30\xe6\xb2\xa4\xb5\xfe\x9b\x3e\x7a\xb2\x55\xd2\xa8\x4a\xbc\x16\xb6\x71\x8e\x39\xc7\xdb\x9d\xe1\x10\x09\x71\xbd\x9c\xb3\x41\x89\xd7\xa5\x89\xdc\x57\xb5\x53\x4a\xfe\x4c\xe1\xbc\xa0\x21\x79\x0a\x1a\x0f\x70\xa7\x5c\x08\x8e\xde\xb0\xc0\x43\x24\xad\x74\x63\x0e\xb1\xd9\x90\xe1\xb0\x2d\x13\xa7\x6d\x78\xfd\x04\x14\x38\x8e\x90\xaa\xce\x63\xac\x3e\x23\xbc\x64\xa9\xb4\xf8\x03\x63\xde\xcd\xbe\x16\x13\x4a\x55\xac\x82\x12\xc6\xac\xd4\x35\xf7\x22\xd4\x3a\xff\x22\x73\x0e\x6e\x51\xa0\x75\x1e\xae\x8f\xe8\x5d\xc7\x59\xe6\xe4\x9a\x18\x8d\xd6\x1c\x53\x84\x4d\xb7\x67\x28\x37\x09\x84\x69\x88\x12\x0e\x01\x11\x80\x32\xa2\xf5\xb9\xaa\xc6\xd9\x73\x53\xab\xfb\xb4\x2e\x20\xc6\x54\x92\xa0\x9a\xf3\x69\x1a\x2f\x81\x77\x37\xae\x53\x1a\xce\x40\xc4\xa8\x82\x1c\xb5\xef\xda\x24\x7d\xb9\x61\x69\x14\xa2\x25\xa0\x90\xac\x56\xc0\x81\x4a\xb4\xe2\x2c\xce\x4a\x64\x7a\x9a\x23\xf4\x13\x91\x3f\xa7\x4b\xf4\x63\x84\x6f\x18\x87\x10\xbd\xc3\xfc\x8f\x90\xdd\x52\x44\x04\xc2\x51\xc4\x6e\x21\x74\x48\x21\x81\xc7\xe2\xfd\xea\x12\xf8\x0d\x09\xf6\xe9\x47\x35\xaf\x67\xc4\x14\xf7\x22\x27\x97\xe1\xe2\x76\x2d\x06\x8c\x4a\x1c\x48\x3f\x73\x2d\x0b\x5b\x29\x45\x24\x00\x2a\x0c\x11\xec\x94\xca\xc2\xa6\xc1\x37\x21\x43\x83\x3b\x5f\x97\xf1\x43\x5e\x53\x73\x19\xa5\x36\xd8\x2d\x05\x2e\x34\x0b\xeb\x39\xfc\x1d\x63\x51\x01\xbd\x3d\xbb\x90\x84\x40\x25\x59\x6d\x09\x5d\xa3\x1c\x37\xe6\x5c\x16\x9a\x40\x09\x70\xc1\xe8\x82\xf1\x35\xa6\xe4\xdf\x99\x5c\x8e\x9e\x4d\x79\xb4\x27\x2f\xbf\x7e\xf8\x05\x25\x8c\x50\xa9\x98\x29\x90\x62\x60\xea\x75\xae\x13\xca\xbf\x2b\x1a\x29\x27\x76\xd6\x20\xc6\x64\x5f\xe6\x32\x1a\x08\x87\x21\x07\x21\xbc\xb4\xe4\xe0\x32\x67\xa6\xcd\xf3\x1e\xcd\xd9\x6b\xb6\x6f\x8e\x27\xa7\xed\xdb\xe7\xbc\xcc\x1a\x07\xce\x6f\x87\x33\xf0\xba\x51\x17\x22\x66\x78\x79\x8e\xce\xe5\x13\x81\x80\x06\x2c\xe5\x78\x0d\xa1\xb2\xb8\x54\xa8\x79\x09\xbd\xbf\x3c\x47\x01\x8b\x13\x2c\xc9\x32\xaa\xaa\x1d\xd5\xee\xab\x36\xbd\x6c\xfd\x54\x6c\xc8\x08\x01\x3c\xbd\xe7\x07\x88\xb0\x24\x37\x79\x90\x28\x4a\x1d\x10\x1a\x92\x1b\x12\xa6\x38\x42\x40\xc3\x4c\x43\x62\x8e\xae\x36\xb0\x45\x71\x2a\xa4\x9a\x23\x79\x59\xb1\xa8\xf2\xa4\x0c\x60\x9f\xcc\x8d\x40\xf5\x80\xca\xa8\x99\xc3\xa7\x85\x1f\x31\x25\xa9\x82\xc5\x6d\xbd\xd8\x36\x76\x7c\x02\x28\x97\xf6\x1d\x74\x3b\x11\x7e\x91\xae\x32\xf8\x6c\xf4\xe6\x7b\x9a\xa5\x1f\x62\xc6\x21\xcf\x9a\xe5\xed\x8b\x02\xf3\x2c\x33\x33\xdf\x00\xca\xc9\x09\xb4\x04\xf5\xa5\x08\xd7\xc3\x02\x18\x66\xf1\xab\x1e\x83\x37\x4c\xcd\x12\xc1\x1d\x50\xf6\xaa\xbd\xfe\xe2\x73\x48\x38\x08\xa0\x32\x9b\x18\x44\x86\x0b\x6a\xc1\xaa\x26\x96\x2d\x96\x3c\xa0\x54\x65\x73\x87\x15\xca\x15\xe5\xf5\x94\x46\x9f\x33\x1a\x0c\x9a\xb1\x5a\xd9\x6a\x95\xcd\xcb\x7e\xec\x9a\xc5\x94\x3b\x37\x26\x31\xd7\xfc\xe4\x1f\x13\x8c\x31\x75\x9c\xba\xf7\x87\x3c\xa1\xb7\x4f\x17\x1b\x09\x82\x98\xc4\x70\x95\xd3\xe8\x4c\x48\x5a\xa6\xd6\x2a\x3d\x56\x42\x80\x9f\xaf\xae\x2e\x50\x0c\x42\xe0\x35\x34\x3c\x8a\x62\x03\x37\xba\xb2\x27\x04\xda\x25\x8d\x06\xe2\xa0\x13\x8a\xf3\xf5\xec\x10\x72\x67\x88\x90\x3d\x4b\x64\xeb\xaa\xda\x8f\xf7\x5a\x75\x47\x9a\xa8\x51\x70\x26\xd2\x38\xc6\x7c\xbb\x57\xfc\xbd\xe4\x04\x56\xa8\xa0\x54\x9a\x45\xd5\xf7\x0f\x16\xfc\x57\x1c\x3c\xdf\x23\xba\x77\x38\xda\x16\x4b\x31\x53\x6a\x4d\x9a\x15\x63\xe7\xe1\x18\x69\x9f\x22\xe0\x24\xbb\x94\x4b\x97\xee\x2d\xf9\x70\x87\x72\x7b\xe6\xc4\x33\x2a\x66\x5e\x1c\x35\x72\xe3\x2d\xda\x73\xe4\xc7\x51\x6d\xa4\xa1\x2a\x4f\xde\x94\xcb\xb2\x3e\x31\x48\xae\x82\xce\xc9\xc8\x65\xcd\xc3\xb7\x34\xb6\x2b\xdf\x58\x65\x78\x6e\x73\xac\x5e\x24\x0d\x3f\xdc\x70\x23\xc6\xda\x52\x0b\x2d\x63\x7d\xa9\x49\x2d\x54\x48\x28\xc0\x12\x9c\xe3\x63\xc9\x58\x04\x98\x36\x07\xc8\x0a\xa7\x91\xd4\xf0\xbc\xc1\xa8\xb9\x70\xd0\xc6\xa9\xb6\x78\x80\x5a\xa3\xb4\x2c\xf4\x18\x0b\x8a\x9d\xd0\xb4\x55\x10\xee\x0d\xc5\xd6\xe0\x99\x93\xdc\xa1\x04\xbb\xf1\xa7\x23\xd1\xd1\x97\x8c\x87\x13\x0a\x21\x02\xe9\x99\x25\xed\x20\xc5\x92\x66\x3c\x32\x9c\xd6\x06\xb0\x31\x5c\x86\x29\x0a\xcb\x60\x33\x12\xa5\x91\xfc\x96\x75\xd0\x59\xd7\x13\xbd\xd3\x23\x79\xdd\x2a\x90\xa6\x38\x06\x91\x39\x7f\x20\x72\x03\x1c\x2d\x01\x61\xba\x45\x37\x38\x22\x61\x8e\x71\x85\xc4\x32\x15\x28\x60\x61\x16\xb8\x3d\x29\xdc\x4d\x3d\x2f\x12\x13\x7d\xc8\x7e\x37\xee\xa8\x7f\xfa\xdb\xcb\x17\xff\x77\xfd\xf9\x7f\xee\x9f\x3d\xfe\xcf\xa7\xa7\x45\xfb\xcf\x1e\xf7\xf3\xe0\xff\xc4\x51\x0a\x8e\x4c\xcb\x01\xdc\x0a\x65\xb2\x01\x83\xed\x3d\xe4\xa9\xa3\x4e\x2d\x59\xc5\xe8\x2f\x48\x7d\x5a\x6e\x37\xbf\x5c\x9f\x35\x13\x64\x14\xfa\xef\x0b\x68\xa6\x0d\xb4\x8e\xf1\xa8\xff\xbb\x60\xf4\x03\x64\xab\x5b\x81\x65\x51\xe6\xda\xca\xfa\xf0\xb0\xac\x3e\x9c\xca\x26\x0e\x1d\xdb\x57\x5b\xbb\xb4\x9a\xa6\xb6\x9b\x1a\x6b\xd1\x9a\x9e\x7e\x33\x9a\xec\x41\x69\x45\x22\xb8\xb4\x51\xeb\x04\x77\xca\x6f\x7b\x7b\xc8\xb2\xb0\x95\x92\x25\x5b\xd0\x42\xaa\x2a\xdd\x32\x78\x4f\x0c\xab\x68\x46\x6c\xea\x6d\xf4\x5c\x5e\xde\xc4\xac\xa5\xf9\xd1\x00\x9f\x7d\x98\x65\x24\xbd\xc7\x97\xd4\xb3\x3a\xa8\x2b\xa0\x34\x76\xf9\x65\x5f\x2d\x25\x95\x1b\xcf\xd6\xf4\x9b\x5f\x09\x95\xb0\x36\x3f\xdb\xd0\x39\x2a\x93\x1c\x9d\x03\xa2\x4a\xca\xf5\xf6\x10\xb6\x94\x89\x0b\x6a\x70\x12\x13\x49\x6e\x40\xe4\x29\x12\x2b\xbd\x80\x45\x11\x04\xaa\xc2\x8f\x56\x9e\x5c\x6b\xec\x8d\x5a\x0e\x14\x59\x06\x2b\x1e\x24\xcb\xc2\x56\x4a\x31\xbe\x23\x71\x1a\xfb\x51\x2a\x0b\x3b\x1c\x48\x10\xa5\x82\xdc\xc0\xbb\x3e\x24\x8d\x5a\x76\x2e\x09\xed\xc1\x65\x51\xb8\x83\xcb\x3e\x24\x8d\x5a\x2e\x5d\xfe\x02\x74\x2d\x3d\xf1\xef\xae\xb8\x4b\xe6\x5e\xd4\xaa\xe2\x2e\x5c\x5e\xec\x0e\xf5\x5b\x0c\xcb\x0a\xbb\xa4\x3c\xf7\x1f\x2a\x55\x69\x97\x8c\x7d\x68\x95\xa5\xad\xb4\xf4\x9c\xa5\x07\xb9\x7a\x05\xbb\xad\x50\x6f\xfb\xa0\x4e\x9b\x48\x23\x49\x92\x28\x87\x19\x3e\x32\xee\xca\x3b\x46\x7e\x7f\x18\x64\xcc\xcc\x0f\x34\xe9\x36\x8b\xb7\x6c\xa8\xa5\x5b\x54\x4c\x54\x5b\x15\x3a\xf1\x6c\x2d\xfe\x96\xc8\x0d\xba\x7b\x81\x88\xc8\x23\xab\xee\x7d\x3b\x92\xa7\x60\x29\xe3\xdc\xff\xb8\x64\xe1\xf6\xa2\x5a\x59\xdc\x6f\xeb\x45\x7d\x6a\xd1\x76\x1e\xea\xb8\xf1\xfa\x14\xd3\x36\x63\xe5\xd7\xf3\xe4\xbe\x25\xbd\x5e\x05\xeb\x73\x74\xb5\x21\x2a\x2e\x4e\xa3\x30\xdf\xbf\x43\x28\x2a\xd1\xa5\x2a\x9d\x8a\xfd\x76\xd8\x8d\xbc\x67\x65\xc7\xb8\x03\x45\xec\xa3\xb0\x37\x8a\x70\x4c\x68\x91\x51\x8e\x58\x80\xed\x4a\xf3\x81\x62\xca\x96\xbb\xf1\x52\xcd\x80\xfb\xe4\x4a\x5d\x6c\xdf\x6e\x20\x4b\x80\x30\x8e\x28\x93\xf9\xe9\x8d\x8a\x6d\xd5\x59\x65\x7b\xaa\x44\x9e\xc0\xc2\xd1\x7c\x40\x26\xd6\x1a\xce\xf9\xc5\x69\x7b\x6c\xec\xc8\x71\x7b\xe5\x21\x2e\xd3\xe5\x65\x93\x91\x53\x0b\x7b\x3a\xc7\xfa\x17\x6a\x01\xa7\x33\xd0\xf4\x40\x0f\x39\x87\xda\xe4\x54\x87\x3a\xd5\xe3\xc7\xa6\x8e\x20\xd4\x11\xb2\x4e\xb1\xe9\x14\x9b\x4e\xb1\xe9\x14\x9b\xfe\x15\x63\xd3\x47\xf5\xff\x97\x38\xe9\xcf\x14\xf8\x76\x82\x49\x13\x4c\xaa\x7d\xcd\x6c\x62\x42\x49\x87\x43\x49\x19\x33\x6f\xe3\x44\x6e\x9b\xab\x8a\x3e\x86\xaa\x99\x52\x1b\x5b\x59\x33\x02\x09\xa0\x21\xa1\x6b\x84\x6b\x66\xbb\xdc\x16\x0c\xd3\x68\xab\xec\x36\x4b\xd8\x60\x8a\x40\x31\x85\x6e\x14\x57\x13\xc2\xfb\x92\x10\xde\xbf\x88\xdc\xbc\x53\x5e\x7f\x82\x7a\x13\xd4\x9b\xa0\xde\x04\xf5\x90\x01\xf5\x94\xcb\x7b\x83\x25\x9e\xd0\xde\x84\xf6\x6a\x5f\x4b\xb3\x98\x00\xdf\x04\xf8\x6c\xbc\x7f\x19\x80\xaf\xf1\x71\x45\x22\x98\x40\xe0\x04\x02\x27\x10\xd8\x29\xf5\x04\x02\xff\x4a\x20\x30\xc1\x72\xf3\x65\x02\x40\xd7\xc1\xd1\xe2\x6b\xf1\xa9\x7b\xfb\xe4\x20\xc0\x68\x9d\xd4\xb4\xd3\x96\xb5\xa6\xd1\x41\x20\xe6\x89\xc3\x48\x65\x58\x13\x84\x9c\x56\x56\x3b\x0c\xe0\x6b\x83\x5c\x13\xd2\x9a\x90\xd6\x84\xb4\x26\xa4\x85\x0c\xa4\x45\x19\xfd\xff\x63\x6c\x52\xb5\x1f\x1e\x19\x74\x3a\xcd\xb9\x69\xce\xa6\x3a\x0f\x7a\x2d\x19\xc7\x81\x14\x5d\xcb\xd5\x03\xc9\x39\xd0\xb0\xd1\xb3\xcd\xfb\x7a\x2d\x5d\x3a\x48\xe1\xfa\x2e\xe6\x81\x42\x18\x86\xd6\xc1\xbe\xb1\x23\xd3\xf7\x34\xed\x19\x0a\x0b\xc4\x48\x44\xfd\x22\x50\xb6\x42\x58\xbb\xe5\x3d\xa7\x73\xd4\x8b\xc4\x8c\x70\x61\xec\x73\xee\xc3\x81\x8b\xf5\xe2\xd7\x52\x3e\xcf\xeb\xeb\x17\x3b\x71\x16\xda\x7d\xb8\xde\xf0\x7a\x8f\x06\x2d\xa7\x40\x7b\xc1\x9d\x41\x4d\xb6\x61\xa2\x4e\x9f\x3d\xa0\xc5\xae\xe3\x1c\x1d\x40\x6c\x48\x8b\x63\xa0\xb5\x01\xed\x8e\x02\xe9\x86\xc8\x3b\x06\xee\xdb\x4b\xde\xbd\xc0\xa1\x6f\xcb\xda\xfc\xc2\x44\x16\x87\x9c\x17\x31\xd3\x30\x20\x39\x42\xcb\x6f\xf2\xf1\xf4\x72\x10\xf8\x1c\xa0\xf3\xbd\x10\xea\x21\x35\x7d\xe8\x86\xdb\x15\xed\x81\x81\x07\x28\xbb\x13\x28\xc7\xf8\xce\x7d\x8d\xc2\x31\xb4\x7e\x94\xd6\xdb\x55\xef\x4a\xfb\xed\xc3\x40\x3e\xeb\x9f\xe9\x99\x0f\xdf\x08\x65\x88\x27\x73\x86\x31\x9d\x47\xdf\x55\x19\xba\x3d\xee\x15\x0a\xcd\x8c\xaa\x5e\xb9\xf6\x57\x33\x73\x5a\xa1\x89\x7b\x3b\xa0\xb2\xa4\xc2\xf6\xc1\x53\xb5\x00\xca\x23\xe5\xf4\x60\x6a\xb4\x2d\x74\xea\x4e\xed\x3b\xe3\x47\xfb\xed\x82\x3d\x19\xd4\x3b\x6b\xaf\xae\x2b\x2f\x57\xb3\x82\x68\xcb\xed\x88\x2e\xe1\x5c\xd7\x26\xfa\x0a\x65\xe7\xce\x11\x33\xb4\xdd\x66\xe3\x37\xf6\xfa\x70\xd6\x4f\xa1\x21\x51\xd8\x3c\x26\x14\x4b\xc6\x87\x44\x27\x1c\x70\xf8\x9e\x46\xce\xab\x21\x07\x5f\xc1\x76\x17\x1b\x77\xb4\xda\x75\xa0\x0a\x3a\x30\xe1\xf8\x97\x32\x16\x2b\x00\x75\x85\xee\x62\x46\xef\xd3\x85\xb5\x6b\x60\xbe\xf2\x30\x7a\x8c\x0b\x4b\xa6\xd0\xf9\x64\x42\xe7\x07\x41\x41\xe3\x2c\x5d\xf9\x6d\xe9\x39\x98\x3b\x3b\x5d\x67\xd4\x5c\xed\xf2\xf0\x48\x7b\xbd\x2d\x31\xdd\x3f\x34\xad\x44\x76\x51\x9a\x56\x22\xa7\x95\xc8\x69\x25\xf2\xe1\x56\x22\x1f\x00\x32\x6a\x73\x92\xed\xe1\xc6\x7d\x9f\x49\x2c\x69\x7e\xc8\x31\x4c\x0c\xb4\xf2\x54\x3b\x79\x3b\x9e\x4d\xb4\xd1\x18\x3e\x5f\x9a\x93\xa2\x11\xc3\xda\x27\x0b\xaf\x37\x2e\x5c\x37\xfb\xeb\x9a\xd6\xc3\xac\xc3\xcc\xf8\x1e\x5b\x9d\xac\x22\x64\xb7\xed\x26\xb8\xf3\xb9\x3c\xbb\x1f\xe2\xb0\x22\x77\x43\x6a\x62\x29\x39\x59\xa6\xe6\xe5\xcd\x7b\x83\xc0\x5b\x8e\x93\x64\xac\xeb\xca\x4f\x65\xac\x4a\xbc\x1e\xcd\x82\xfa\x3c\x70\x36\xb6\xb5\xed\x79\xef\xec\x68\x00\xff\x54\xfa\xb5\xe3\xf1\xdb\xe1\xbe\xce\x76\x17\xaf\x57\xb6\x6b\x89\x05\x09\xce\x52\xb9\x01\x2a\x49\xbe\xd9\xf4\xd2\xb8\x7a\xbf\x91\x02\xf3\x22\x8c\x13\xf2\x77\xd8\x8e\x43\x8b\xe1\x54\x6e\x5e\x9d\xc7\x49\x44\x02\x22\xc7\xa4\x79\x81\x85\xb8\x65\x3c\x1c\x93\xe6\x59\xa2\xf8\x1c\x51\x95\x05\xd9\x20\x00\x21\x7e\x60\x21\x58\xa9\x56\xff\xbe\xb6\x5a\x5e\x5b\x3f\x1f\xd6\xd3\x3c\xc4\x4d\xba\x99\xb4\x63\x6e\x7d\x3e\x3d\x57\xd2\x18\x5f\x47\xe8\xc3\x06\x8a\x68\x6c\x7f\x3b\x72\x0f\xe7\xe2\x77\x77\xf1\xd0\x99\xab\xdf\x2e\xfe\xd6\xbb\xcd\x1a\xb9\x90\xd1\xaf\xf2\x38\x3d\xdb\x74\xf8\xeb\xe3\xda\xe8\x2a\x62\xb7\xda\x1b\x07\xa9\xdc\x30\x5e\xbc\x68\xfb\x6b\x9f\x97\xf1\xc6\xb1\xd8\x5c\x29\x1e\x49\x30\xc5\xf7\xde\xad\x91\x42\xf9\xdd\xed\x89\x80\x25\xbe\x37\xd7\xe7\x32\x5c\xe6\x35\xac\xd4\x0c\x2d\xf7\x90\xc4\xe3\xf5\xe3\x2f\x7f\x54\x18\x88\xe3\x61\x47\x85\x64\x7f\xc0\xd7\x3f\x1a\x92\x42\xe9\xc7\x1e\x0d\x95\x76\xa7\x51\xa0\x8f\x02\x1b\x46\x9e\x06\x42\xd1\xf2\x01\x07\x02\xde\xe9\x7d\x1a\x0b\xa7\x32\x16\xcc\xc0\xee\xc4\x90\xd2\x5f\x6f\x98\x54\x5d\xf2\x95\xe1\xa7\x69\x10\x3a\x06\xe1\x65\xb3\x17\x47\x58\x78\xd0\x45\xd6\x5b\xd5\x5f\x25\x1d\x71\x49\xa6\x7a\x64\xda\xd0\x6f\xc7\x3a\x4c\xe3\x09\xc0\x6e\x96\x2c\xa7\xa7\x77\x34\x10\x05\x08\x21\x44\x92\x65\x77\xdf\x20\x5c\xbc\xe7\x97\x3f\xf4\x1a\x45\xd6\xe7\x27\x4a\xde\x74\x27\x66\x11\x7d\x70\xba\xd3\x78\xf9\x1e\x0d\xca\xc8\x39\xde\x7c\xb3\xa6\xe1\xbc\xd7\xc1\x6a\x6f\xb3\x0e\x52\xbe\xe4\x98\x8a\x15\x70\x94\x70\x26\x59\xc0\xa2\xf2\x1c\xfb\xd9\xc5\xf9\xbc\xd5\x92\x9c\xa3\xdf\xe6\x1e\xb3\x0d\x49\xba\x87\x50\x5f\x84\xfe\xe9\xd6\xf8\xbb\xe6\xf0\x7a\xeb\xa6\x65\x3b\x86\x8b\x79\x93\xf5\x59\x20\x6e\xb4\xa7\x44\xf4\x3f\xa5\xfe\x67\x42\x12\xdb\xd3\xe7\xbb\xa5\xa3\x8c\x5c\x2b\x97\xbb\xbb\x7f\x8e\xc5\x6e\xed\x43\x5c\xbf\x74\xc8\x8f\xff\xe6\xd6\xbe\x91\xb6\xf5\x95\xe4\xed\x93\xc4\xa8\x5b\xf9\x76\x4d\x35\xb7\xd8\x8c\xb6\x7d\xaf\x72\xe0\xb6\xbd\x01\x63\x9e\x76\xab\x1a\x32\x76\xe4\x8c\x76\xc2\xad\x6c\xa2\x65\xf7\xcf\xf8\xa7\xda\x2a\xb9\x8c\x3d\x3c\xa3\x9d\x64\x33\xe5\x1a\xb5\x2d\xfb\x86\xa2\x5a\x7f\x19\x5b\x7f\xc6\x3f\xd1\x53\xd3\xe2\x41\x5b\xd3\x4f\xf0\xec\xb0\x42\x73\x43\xd2\x68\x27\xd3\x6a\x6a\x34\xf6\x4e\x1e\x52\x8b\x87\x6c\xcc\xae\x44\xfb\x9e\xa7\x51\x4f\x9d\x55\x03\x81\x8e\x67\xfc\xb4\x69\xf0\x3a\x18\xf2\x40\xd0\xf6\xa8\x34\xe3\xc9\x98\xaf\xf6\xda\x24\xd3\xeb\x60\xb9\x0e\xd3\x1f\xa9\xff\xee\xff\x1b\x00\x00\xff\xff\x3d\xeb\x17\xb5\x38\x9d\x00\x00") +var _v2SchemaJSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xec\x5d\xdf\x73\xdc\xb6\xf1\x7f\xcf\x5f\x81\xb9\x78\x46\xf6\x24\xd6\x39\xfe\x7e\x5f\xea\x97\x8c\x1a\x39\x89\x5a\xbb\xd2\xf8\x9c\xf6\xc1\x95\x67\x70\x24\x4e\x87\x84\x3f\x2e\x04\x29\xe9\xea\xea\x7f\xef\x02\xfc\x71\x04\x01\x90\x20\x89\x3b\x9d\x6d\x7a\xa6\x8d\x8e\x04\x16\x8b\xc5\x62\xf7\xb3\x0b\x10\xf8\xf4\x0d\x42\xb3\x94\xa6\x01\x99\xbd\x42\xb3\x33\xf4\xb7\xc5\xe5\x3f\xd0\xc2\x5b\x93\x10\xa3\x55\x9c\xa0\xc5\x1d\xbe\xb9\x21\x09\x7a\x79\xfa\x02\x9d\x5d\x5d\x9c\xce\xbe\xe7\x15\xa8\xcf\x4b\xaf\xd3\x74\xf3\x6a\x3e\x67\x79\x91\x53\x1a\xcf\x6f\x5f\xce\x99\xa8\x7b\xfa\x3b\x8b\xa3\x6f\xf3\xc2\x4f\xf2\x47\xb5\x1a\xfc\xe5\xf3\xa2\x60\x9c\xdc\xcc\xfd\x04\xaf\xd2\xe7\x2f\xfe\xbf\xa8\x5c\xd4\x4b\xb7\x1b\xc1\x54\xbc\xfc\x9d\x78\x69\xfe\x2c\x21\x7f\x66\x34\x21\xbc\xf9\x0f\xf0\x1b\x9e\x14\xad\x8b\xd7\x9c\xb3\x68\x15\x97\x7f\x6f\x70\xba\x66\x33\xf8\xfb\x5a\xd4\xc5\xbe\x4f\x53\x1a\x47\x38\xb8\x4a\xe2\x0d\x49\x52\x4a\x18\xd0\x59\xe1\x80\x11\x51\x00\xca\xa7\x24\x89\xa4\xb7\x9f\x72\x52\x1f\xef\x9f\x57\x3f\x78\x97\x12\xb2\xe2\xac\x7d\x3b\xf7\xc9\x8a\x46\x82\x2c\x9b\xdf\x92\xc8\x8f\x93\xd7\xf7\x29\x89\x18\x3c\x98\x89\xd2\x0f\xf0\xff\x0f\x39\x79\x0d\xdd\x92\xfb\x1a\xed\xb2\xdb\x2c\x4d\x68\x74\x53\xf4\x05\x9e\x93\x28\x0b\xab\x6e\x8b\x27\x30\x26\xb3\xe2\xd7\x75\x55\xcc\x27\xcc\x4b\xe8\x86\x73\xc4\xa9\xbc\x5f\x93\x6a\x0c\x6f\x49\xc2\xf9\x42\xf1\x0a\xa5\x6b\xca\x90\x1f\x7b\x59\x48\xa2\xf4\xb4\xe0\xb4\x2e\xc2\xce\xce\x8a\x52\x52\xbd\x75\xcc\x52\x9b\x8e\x14\x62\xe6\xaf\x3e\x7e\xf8\xf8\xe9\x61\x8e\x5e\xfd\x1b\xfe\x5d\x7f\xf7\xf4\xc7\x57\xf0\x97\xff\xdd\xb3\x1f\x9f\xcc\xda\xfa\xc3\x1b\x42\x4f\x23\x1c\x12\x04\x1a\x4a\x37\xcf\xf2\x1e\x11\xa1\xa0\xe8\xf5\x3d\x0e\x37\x01\x79\x85\x4e\x76\x8a\x79\x22\x73\xba\xc4\x8c\x5c\x81\x72\xf4\xe5\x76\xde\xca\x16\xa7\x8a\xb8\xce\xa1\x34\xd6\xb1\x33\xc7\x1b\x7a\xd2\x90\xb5\x50\xf8\x9a\x42\x18\xc5\x5d\x14\x7c\x43\x41\xc6\x12\x05\x0f\xde\x66\x0d\x12\x0d\xe6\xce\x50\x00\xd5\xb8\x90\xde\x5e\xbc\x7d\x8d\x78\x4f\x19\xc2\x9e\x47\x36\x29\xf1\xd1\x72\x5b\x31\xbb\xeb\x9e\x9e\x89\x90\xf8\x14\xbf\x87\xea\x2a\x1b\xa0\xdc\x7e\xe6\xf5\x67\xa3\x68\x1a\x79\x38\x42\x05\x8d\x51\x6c\x88\x29\xdf\x29\xcd\xca\x32\xec\x6a\xd6\x5e\x77\xd7\xaf\x17\x6e\xb4\x9f\x80\x5a\x82\xc2\x58\x31\x51\x94\x3d\x37\x51\x4b\x08\xdb\xc0\x43\x1b\xfd\x28\x8b\x1a\x69\x31\xe2\x65\x09\x4d\xb7\x16\xaa\x56\x96\xd4\xd6\x3f\xef\x23\x27\x5d\x25\x89\x6a\x8a\x6f\x98\x6e\x16\xe2\x24\xc1\xdb\x9d\x1e\xd0\x94\x84\xf5\x72\xc6\x06\x81\x5e\x69\x12\x1f\xaa\xda\x59\x44\xff\xcc\xc8\x45\x41\x23\x4d\x32\x22\xf1\x40\xee\xf9\x04\xc7\xc1\x79\xec\x59\x74\x49\x2a\xdd\xb0\xf0\x3a\x1d\x52\xcc\xa9\xc6\xad\xe9\x66\xcb\x2f\x24\x22\x09\x0e\x10\xaf\x9e\x84\x98\x3f\x46\x78\x19\x67\xa9\x66\xb6\x2a\x5e\x51\x3c\x2d\xcc\x7d\x55\xac\x72\xf4\x8a\xcf\xe8\xf2\x8c\xe5\xd4\x32\x78\x47\xf1\x5a\xf6\x90\x2d\x02\xd4\x7a\xc9\x52\x8e\xf2\xc0\x69\x3c\x66\xad\x1b\x8d\xd6\x0c\x06\x5c\x27\xdb\x33\x94\xab\x04\xc2\x91\x0f\x56\x87\x78\x14\x2c\xb7\x20\x5a\xf7\x24\x35\xce\xbe\x57\xa5\x3a\xa6\x75\x06\x20\x27\x4a\xa9\x57\x79\x64\x70\xed\x4b\x70\xd0\x9d\x8d\xcb\x94\x86\x33\x10\xc4\x11\x07\x04\xb5\xe7\x92\x0b\x5d\xac\xe3\x2c\x00\xcf\x40\x90\x4f\x57\x2b\x92\x00\x46\x40\xab\x24\x0e\x45\x09\x21\xa7\x53\x84\x7e\xa1\xe9\xaf\xd9\x12\xfd\x1c\xe0\xdb\x18\x74\x0f\xbd\xc5\xc9\x1f\x7e\x7c\x17\x21\x40\x16\x38\x08\xe2\x3b\xe2\x1b\x7a\x01\x6a\x14\xb2\xcb\xd5\x82\x24\xb7\xd4\x1b\x33\x8e\xdc\xeb\x0a\x62\x9c\x7b\x96\x93\x13\xa8\xb5\x5d\x8a\xe0\x32\x53\xec\xa5\x76\xea\x5a\x16\xd6\x52\x0a\xa0\x41\x30\xba\x76\x94\xca\xc2\xaa\xc2\x37\x1d\x7a\x83\x3b\x5b\x93\xf1\x53\x5e\x53\x32\x19\xa5\x34\x60\x60\x40\xd7\x24\x0d\xeb\x39\xfd\x0d\x73\x91\xc3\xb0\x91\x43\x48\x7d\x50\x30\xba\xda\x42\x59\x94\xa3\xba\x9c\xcb\x42\x12\x08\xda\x85\x80\x61\x0e\x91\x02\x8e\xe8\x7f\x44\xbf\x0c\x23\x9b\x25\xc1\x48\x5e\x7e\x7b\xf7\x06\x6d\x62\x0a\xfc\x00\x33\x05\x8e\xf3\x54\xb9\x9e\xca\x84\xf2\xe7\x9c\x06\xb8\x3b\x3d\x6b\x30\xe5\xe9\x58\xe6\x04\x0d\x04\xc3\x05\xde\x9e\x59\x49\xc9\xc0\x65\xce\x4c\x9b\xe5\x3d\x98\xb1\x97\x74\x5f\x9d\x4f\x46\xdd\xd7\xfb\x3c\xa1\x8d\x03\xfd\xdb\xfe\x14\xbc\xae\xd4\x45\x17\x05\xfc\x3d\x45\x17\xe9\x09\x43\x24\xf2\xe2\x2c\xc1\x37\x60\x44\x41\xe3\x32\xc6\xfd\x12\xba\x5c\x00\x28\x8e\x43\x18\x08\xba\x0c\xaa\x6a\x07\xd5\xfb\xaa\x4d\x2b\x5d\x3f\x16\x1d\x52\x42\x00\x4b\xeb\xf9\x8e\x04\x20\xeb\xdb\x3c\x84\x63\xa5\x0c\x68\xe4\xd3\x5b\xea\x67\x80\xc4\x80\x0d\x21\x21\x76\x8a\x40\x62\x5b\x14\x66\x10\xcd\x80\x8f\x4c\xca\x8a\x45\x95\x93\x32\xbc\x3c\x39\x55\xc2\xc8\x3d\x0a\xa3\xa6\x0e\x10\xa8\x5a\x11\xe3\x3d\xe5\xb0\xb8\x6d\x14\xdb\xe6\x8e\x4d\x00\x65\x92\xbe\x81\x6e\x27\xc2\x2f\x92\x49\x0a\x9f\x8d\xd1\xbc\x8c\x44\x72\x20\x04\x68\x92\xe7\xb4\xf2\xf6\x59\x81\x79\x96\x42\xcd\x61\xb0\x72\x72\x0c\xc6\x91\x3f\x29\x82\x69\xbf\x00\x86\x22\x1c\x95\x23\xe4\x86\xaa\x69\x22\xb8\x3d\xf6\xbd\x6a\xaf\x7f\xf7\x13\x02\x38\x97\x81\x9f\x15\x8e\x81\x09\x5c\x50\x0b\x56\xa5\x6e\xe9\x62\xc9\x3d\xf6\xaa\x6c\x6e\xbf\x9d\x32\x45\x79\x3d\x7b\x23\xfb\x8c\x06\x83\x6a\xac\x56\xb6\x5a\xe5\xda\xc4\xcb\x2e\x2f\xc6\xcd\xb9\xe2\xc4\x4c\xfe\xc9\x3e\x26\x70\xe1\x3a\x8e\xdd\xfa\x93\x3c\xdd\x36\x66\x88\x95\x04\x41\x48\x43\xf2\x3e\xa7\xd1\x99\x2e\xd4\xb8\xd6\x2a\xdb\x55\x42\x80\x5f\xdf\xbf\xbf\x42\x21\x40\x38\x70\xf9\x0d\x8b\xc2\xd9\xc0\x8d\xa1\xec\x09\x81\x76\x49\xa3\x81\x38\xe8\x88\xe2\x7c\x39\x3b\x24\x09\x43\xce\x10\x89\x57\x6a\x96\x48\x37\x54\xb5\x97\x0f\x52\x75\x43\x9a\xa8\x51\x70\x06\x0e\x22\xc4\xc9\x76\x54\xfc\xbd\x4c\x28\x81\x88\x35\xa7\x54\xaa\x45\x35\xf6\x8f\x16\xfc\x57\x1c\x7c\x3f\x22\xba\x37\x18\x5a\xf1\xce\x36\xa5\xd6\xa4\x59\x31\x76\xe1\xbb\x48\xfb\x14\x01\x27\xdd\xa5\x5c\xba\x64\xaf\x49\x6f\x1b\x84\xdb\x33\xc5\xdd\x22\x16\x4d\x9a\xbb\xc9\x96\x26\xf9\x3f\x88\xad\x82\x8e\x2b\xb6\xb4\x59\xf0\x16\x92\xbb\xf2\x66\x9a\xba\x5c\x78\x0b\x49\xc5\x0a\x36\x26\xb1\xb2\xee\xd2\x42\x4b\x59\x7b\x69\x52\xf3\x39\x0e\xf1\x70\x4a\x8c\xda\xb9\x8c\xe3\x80\xe0\xa8\xa9\x9e\x2b\x9c\x05\xa9\x84\xa6\x15\x46\xd5\xb4\x7d\x1b\xa7\x52\xea\x5e\xd0\x32\xc6\x48\x02\xf8\xbb\x02\x42\x47\xe4\x34\x0a\xc2\xbd\x81\xd0\x0d\xb1\xcc\x08\xee\x7c\xb4\x5e\xf9\x33\x47\x74\xe4\xe5\xd4\xe1\x84\x7c\x12\xc0\xdc\x72\x42\x2a\xde\x34\xa3\x81\xe1\xb4\xd6\x04\x2b\xd3\x65\x98\xa0\x70\xea\xad\x1d\x51\x72\x64\xb7\xb4\x93\x4e\xbb\x9a\x67\x9d\x9c\xc8\xeb\x56\x61\x2c\x4f\x29\x31\x61\xbb\x09\x05\x4b\x9e\xf0\x44\x04\x8e\xb6\xe8\x16\x07\xd4\xcf\x11\x26\x83\x60\x23\x83\x32\xb1\x2f\xc2\xa6\x93\xc2\xdc\xd4\xb3\x12\x21\x95\xa7\xec\x0f\x6e\x67\xfd\xd3\x0f\x2f\x9e\xff\xe5\xfa\xd3\xff\x3d\x3c\x7b\xf2\xdf\x8f\x4f\x8b\xf6\x9f\x3d\xe9\x67\xc1\xff\x89\x83\x8c\x18\xf2\x1c\x7b\x30\x2b\x51\x9c\x36\x40\xa8\x7e\x84\x2c\x65\xd4\x29\x25\x6d\x37\xfa\x77\x64\xd7\x95\x2e\xf5\xcb\xe5\x59\x53\xc1\x38\x22\x97\x2b\x29\x86\xe8\x31\x3a\xda\x81\xb1\xa8\xcf\xb7\x00\xbd\x23\x62\x6d\xc9\xd3\x2c\x89\x5c\x6b\x59\x1f\x1e\x14\xd5\xa7\x53\xd9\xc4\xbe\x23\xeb\x6a\xdb\x93\x54\x53\x95\x76\x53\x62\x2d\x52\x93\x93\x5f\x4a\x93\x3d\x28\xad\x68\x40\x16\x3a\x6a\xb5\x5f\xd7\x46\xbb\x6d\x6d\x21\xcb\xc2\x86\x48\x41\x89\xd5\x5b\x48\x55\xa5\x5b\x26\xef\x91\x61\x15\x49\x89\x55\xb9\x39\xcf\xa4\xe5\x4d\xcc\x5a\x9a\x77\x06\xf8\xf4\xd3\x4c\x90\xb4\x9e\x5f\xa9\x9c\x53\x91\x98\xd2\x85\x73\xca\x0e\x38\xf1\x54\x53\x92\x9b\x71\xb1\xa2\xde\x7c\x4a\xa3\x94\xdc\xa8\x8f\x75\xe8\x1c\x95\x29\x86\xce\x09\x51\xa5\xc4\x7a\x5b\x08\x5d\xc2\xc2\x04\x35\x12\x1a\x52\xbe\xca\xc0\xf2\x04\x85\x96\x9e\x17\x07\x01\x0c\x25\x54\xf8\x59\xcb\x93\x69\x85\xbb\x51\xcb\x80\x22\xcb\x60\xc5\x82\x64\x59\x58\x4b\x29\xc4\xf7\x34\xcc\x42\x3b\x4a\x65\x61\x83\x01\xf1\x82\x8c\x81\x50\xde\xf6\x21\xa9\xd4\xd2\x73\x09\xe5\xed\xb9\x2c\x0a\x77\x70\xd9\x87\xa4\x52\xcb\x24\xcb\x37\x24\xba\x49\x2d\xf1\xef\xae\xb8\xa9\xcf\xbd\xa8\x55\xc5\x4d\xb8\xbc\xd8\x39\x69\xb7\x14\x25\x0a\x9b\x7a\x79\x61\x3f\x55\xaa\xd2\xa6\x3e\xf6\xa1\x55\x96\xd6\xd2\x92\x33\x86\x16\xe4\xea\x15\xf4\xba\x12\x59\xeb\x47\x64\xd4\x09\x98\x79\x14\x3c\xe5\xa5\x12\x06\x1b\xfa\xb8\x2b\x6f\x98\xf9\xfd\x61\x90\xe2\x99\x1f\xc9\xe9\x36\x8b\xb7\xec\x4e\x85\xe0\xa9\x70\x54\x5b\x1e\x3a\x25\x62\x25\xfc\x0e\x82\x2b\x74\xff\x9c\x67\x3d\x45\x64\xd5\xbd\x6b\x86\xe7\x8d\x35\x65\x8c\xbb\x0f\x97\xb1\xbf\xbd\xaa\xd6\xf5\xc6\x6d\x7c\xa8\xbb\x16\x69\xdf\x9f\x8c\x1b\xaf\x8f\x31\x6d\xe3\x2a\xbb\x9d\xa7\xd6\x35\xc9\xed\x2a\x58\xe7\xcb\xf7\x94\xc7\xc5\x7c\x8f\x9b\xd8\x3d\x43\x21\x8a\x2e\xd0\x25\x2f\x9d\xb1\x71\xfb\xdb\x1c\xef\x18\xd9\x31\x6e\x40\x11\x63\x04\x76\xce\x09\x83\x95\x2b\x12\xc2\x41\xec\x61\xbd\xd0\x6c\xa0\x18\xd7\xe5\x6e\xbc\x54\x53\xe0\x3e\xb9\x52\x13\xdb\x77\x6b\x22\x12\x20\x71\x82\x20\x76\xcf\xbf\x6c\xa8\xd8\xe6\x83\x55\xb6\xc7\x4b\xe4\x09\x2c\x1c\x9c\x0e\xc8\xc4\x6a\xc3\x39\xbb\x38\x6d\xc4\xb6\x8a\x1c\xb7\x57\x16\x62\x91\x2d\x17\x4d\x46\x8e\x2d\xec\xe9\x9c\xeb\x9f\xa9\x06\x1c\xcf\x44\x93\x03\x3d\xfe\x4f\x3f\xd5\x26\xa3\x3a\xd4\xa8\x1e\x3e\x36\x35\x04\xa1\x86\x90\x75\x8a\x4d\xa7\xd8\x74\x8a\x4d\x5b\x7b\x3d\xc5\xa6\x5f\x68\x6c\xfa\x4d\xfd\xbf\x25\x4e\x02\xde\x93\xed\x04\x93\x26\x98\x54\x7b\x2a\x74\x62\x42\x49\xfb\x43\x49\x82\x99\xd7\xe1\x26\xdd\x36\x57\x15\xa5\x96\x6d\x76\xbf\xb4\xb1\x25\x9a\x61\x88\xc1\x94\xe2\x49\x19\x5c\x53\xdb\xe5\xb6\x60\x38\x0a\xb6\x5c\x6f\x45\xc2\x86\xaf\x8a\x73\xa6\x78\xce\x26\x33\x7d\x33\x31\x21\xbc\xa3\x44\x78\xff\x82\x01\x7c\xcb\xad\xfe\x04\xf5\xd0\x04\xf5\x26\xa8\x37\x41\x3d\xd4\x84\x7a\xdc\xe4\x9d\xe3\x14\x4f\x68\x6f\x42\x7b\xb5\xa7\xa5\x5a\x4c\x80\x6f\x02\x7c\x3a\xde\x3f\x0f\xc0\xd7\x78\xc8\xf7\x69\x4d\x20\x10\x4d\x20\x70\x02\x81\x5d\xbd\x9e\x40\xe0\xd7\x04\x02\xf9\x27\x2c\x9f\x27\x00\x34\x7d\xb6\x59\x3c\x2d\x1e\x75\x6f\x9f\x1c\x04\x18\xb5\x4e\x4d\xfa\xd6\xb1\xd6\xb4\xa8\xe1\x1c\x62\x1e\x39\x8c\xe4\x8a\x35\x41\xc8\x69\x65\xb5\xfa\xf7\x75\x40\xae\x09\x69\xa1\x09\x69\x4d\x48\x6b\x42\x5a\xa8\x89\xb4\xa2\x38\xfa\xeb\x21\x36\xa9\xea\x3f\x1e\x19\xf4\x75\x9a\x71\xd3\x9c\x4e\x74\x16\xf4\x5a\x32\x8e\x03\x29\x9a\x96\xab\x07\x92\x33\xa0\x61\x65\x64\xaf\x1b\x18\x5a\x33\xa4\x83\x04\x2e\xef\x62\x1e\xd8\x09\x45\xd1\x3a\xd8\x57\x76\x64\xda\x7e\x4d\x7b\x06\x80\x2b\x47\x8c\x94\xd5\x8f\xe1\x04\x04\x83\xa5\x13\xd0\x73\x3a\x07\x3d\xc6\x4b\x09\x17\x5c\x7f\xe7\x3e\x1c\xb8\x68\x8f\x5d\x2d\xfb\x67\x79\xb4\xfb\x7c\xd7\x9d\xb9\x74\x1a\xad\x35\xbc\x1e\xd1\xa0\xe6\x2b\xd0\x5e\x70\x67\x50\x93\x6d\x98\xa8\xd3\x66\x0f\x68\xb1\xeb\x73\x8e\x0e\x20\x36\xa4\x45\x17\x68\x6d\x40\xbb\x4e\x20\xdd\x90\xfe\xba\xc0\x7d\xa3\xfa\x3b\x0a\x1c\xda\xb6\x2c\xf9\x97\x98\x89\x38\xe4\xa2\x88\x99\x86\x01\x49\x07\x2d\x9f\xe7\xf3\xe9\xc5\x20\xf0\x39\x40\xe6\xa3\x10\xea\x3e\x25\xbd\xef\x86\xdb\x05\x6d\x81\x81\x07\x08\xbb\x13\x28\x83\xc0\xcd\xc7\x28\x1c\x42\xea\x07\x69\xbd\x5d\xf4\xa6\xb4\xdf\x18\x06\x72\xaf\x7f\x26\x67\x3e\x6c\x23\x94\x21\x96\xcc\x18\xc6\x74\x7e\xfa\xce\xcb\x44\xdb\xc3\x1e\xa1\xd0\xcc\xa8\xca\x95\x6b\xbf\x9a\x99\xd3\x0a\x4d\x3c\xe8\x01\x95\x26\x15\x36\x06\x4f\xd5\x02\x28\x8b\x94\xd3\xa3\x89\x51\xb7\xd0\x29\x1b\xb5\x1f\x94\x97\xfa\xb3\xfd\x7a\x32\x28\x0f\xd6\xa8\xa1\xc3\x41\xa0\xa2\xb6\x96\xb3\x09\x4d\x9d\x33\x1d\x5a\x68\xdb\x29\x3d\x77\x86\x98\xc1\x1c\x21\xe5\x7d\xea\x9e\x7b\x7d\x38\xeb\x27\x50\x9f\x72\x6c\x0e\x62\xc2\x69\x9c\x0c\x89\x4e\x12\x88\xf9\x2f\xa3\xc0\x78\x30\xe3\xe0\x23\xd8\xee\x43\xe5\x84\x54\xbd\x0c\x78\x41\x03\x26\x74\x7f\x24\x62\xb1\x02\x50\x17\xe8\x2e\x66\xb4\xfe\xba\xb0\x76\x0c\xcc\x17\x1e\x46\xbb\x38\xb0\x64\x0a\x9d\x8f\x26\x74\x7e\x14\x14\xe4\x66\xe9\xca\x6e\x4b\xcf\xde\xcc\xd9\xf1\x1a\xa3\xe6\x6a\x97\x85\x45\x1a\x75\xb3\xc3\x74\xfe\xd0\xb4\x12\xd9\x45\x69\x5a\x89\x9c\x56\x22\xa7\x95\xc8\xc7\x5b\x89\x7c\x04\xc8\x28\xf9\x24\xdd\xb5\x89\x63\x2f\x29\x2c\x69\xbe\xcb\x31\x0c\xbf\x16\x62\xa6\xf4\xb7\xe3\xd2\x42\x1d\x8d\xe1\xfe\x52\x75\x8a\x4a\x0c\xab\x77\x16\x56\x37\x4c\x98\xce\xd5\x97\x25\x2d\x87\x59\xfb\xf1\xf8\x16\x5b\x9d\xb4\x5d\x10\xa7\xed\x6e\x70\xe7\x65\x75\x7a\x3b\x04\x4a\x40\xef\x87\xd4\x04\x95\x4f\xe8\x32\x53\x0f\x6f\x1e\x0d\x02\xef\x12\xbc\xd9\xb8\x3a\xae\xfc\x58\xe6\x2a\xbf\xfc\xd3\x95\x06\xf5\xb9\x5e\xcc\xb5\xb6\x8d\x3c\x77\xd6\x19\xc0\x3f\x96\x71\xed\xb8\x7a\x76\xb8\xad\xd3\x9d\xc5\x6b\x95\xed\x5a\x62\x46\xbd\xb3\x2c\x5d\xf3\x7b\x24\xf2\xcd\xa6\x0b\xe5\xe8\xfd\x46\x0a\xcc\x8a\x30\xde\xd0\xbf\x93\xad\x1b\x5a\x31\x06\x06\x5f\x5e\x40\x60\x46\x3d\x9a\xba\xa4\x79\x85\x19\xbb\x8b\x13\xdf\x25\xcd\xb3\x0d\xe7\xd3\xa1\x28\x0b\xb2\x9e\x47\x18\xfb\x29\xf6\x89\x96\x6a\xf5\xf7\xb5\x56\xf3\xda\xc6\x79\xbf\x96\xe6\x31\x4e\xd2\x15\xbd\x75\xb9\xf5\xf9\xf8\x4c\x49\x63\x7e\x1d\x60\x0c\x1b\x28\xa2\xb1\xfd\xed\xc0\x23\x9c\x77\xbf\x7b\x88\x87\x7a\xae\x7e\xbb\xf8\x5b\xcf\x36\x6b\xe4\x42\x9c\x1f\xe5\x71\x7c\xba\x69\xb0\xd7\x87\xd5\xd1\x55\x10\xdf\x49\x77\x1c\x00\x4f\x71\x52\xdc\x27\xfb\x5b\x9f\x7b\xe9\xdc\x68\x6c\x2e\x14\x8b\x24\x18\xe7\x7b\x74\x6b\xb4\x10\x7e\x77\x7b\xcc\x83\x5e\xdb\x5e\x84\x22\xfa\xb0\xc8\x6b\x68\xa9\x29\x52\xee\xd1\x13\x8b\xbb\x87\x3f\xff\x59\xa1\x20\x8e\xc7\x9d\x15\x69\xfc\x07\xf9\xf2\x67\xc3\xa6\x10\xfa\xa1\x67\x43\x25\xdd\x69\x16\xc8\xb3\x40\x87\x91\xa7\x89\x50\xb4\xbc\xc7\x89\x80\x77\x72\x9f\xe6\xc2\xb1\xcc\x05\x35\xb0\x3b\x32\xa4\xf4\xf5\x4d\x93\x6a\x48\xbe\x30\xfc\x34\x4d\x42\xa4\x9f\x84\x8b\xe6\x28\x3a\x58\x78\x90\xbb\x2c\xb7\x2a\xdf\x3d\xea\x70\x49\xa6\xba\xe2\x59\x91\x6f\xc7\x3a\x4c\xe3\x0a\xc0\x6e\x96\x34\x5f\x4f\xef\x68\xa0\x88\x10\x9f\xf8\x28\x8d\xc5\xd9\x37\x08\x17\xf7\xf9\xe5\xf7\xb4\x06\x81\xf6\xfa\x89\x92\x37\xd9\x88\x69\xba\x3e\x38\xdd\xa9\xdc\x3b\x2f\x89\xc8\x9a\x8c\xe1\xce\x37\x6d\x1a\xce\x7a\x1d\xac\x76\x37\xeb\x20\xe1\xa7\x09\x8e\x18\xf0\xc4\x2f\xff\x48\x63\x2f\x0e\xca\xef\xd8\xc5\x75\xff\x6d\xe2\x34\xce\x7e\x9d\x79\x14\x1b\x92\x64\x0b\xc1\x9f\x30\xf9\xd1\x9d\xf2\xbb\x66\xf0\x7a\xcb\xa6\x65\x3b\x86\x89\x79\x95\xf5\x99\xc7\x6e\xa5\xab\x44\xe4\x9f\xa9\xfc\x73\x43\x37\xba\x8b\xc7\x77\x4b\x47\x82\x5c\x2b\x97\xbb\xb3\x7f\x0e\xc5\x6e\xed\x41\x58\x3f\x74\xc8\x8e\xff\xe6\xd6\x3e\x47\xdb\xfa\x4a\xf2\x7a\x27\xe1\x74\x2b\xdf\xae\xa9\xe6\x16\x1b\x67\xdb\xf7\x2a\x03\xae\xdb\x1b\xe0\xf2\x6b\xb7\xaa\x21\x65\x47\x8e\xb3\x2f\xdc\xca\x26\x5a\x76\xff\xb8\xff\xaa\xad\xea\x97\xb2\x87\xc7\xd9\x97\x6c\x6a\xbf\x9c\xb6\xa5\xdf\x50\x54\x1b\x2f\x65\xeb\x8f\xfb\x2f\x7a\x6a\x52\xdc\x6b\x6b\xf2\x17\x3c\x3b\xac\xd0\xdc\x90\xe4\xec\xcb\xb4\x9a\x18\x95\xbd\x93\xfb\x94\xe2\x3e\x1b\xd3\x0b\x51\xbf\xe7\xc9\xe9\x57\x67\xd5\x44\x88\xdc\x29\x7f\xd4\x54\x78\x19\x0c\x59\x20\x68\x7d\x54\x2a\x78\x52\xfc\xd5\xa8\x4d\x32\xbd\x3e\x2c\x97\x61\xfa\x37\xfc\x7f\x0f\xff\x0b\x00\x00\xff\xff\x31\x8b\xeb\xb6\x54\x9c\x00\x00") func v2SchemaJSONBytes() ([]byte, error) { return bindataRead( @@ -104,7 +118,7 @@ func v2SchemaJSON() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "v2/schema.json", size: 40248, mode: os.FileMode(420), modTime: time.Unix(1473777784, 0)} + info := bindataFileInfo{name: "v2/schema.json", size: 40020, mode: os.FileMode(420), modTime: time.Unix(1446147817, 0)} a := &asset{bytes: bytes, info: info} return a, nil } @@ -162,7 +176,7 @@ func AssetNames() []string { // _bindata is a table, holding each asset generator, mapped to its name. var _bindata = map[string]func() (*asset, error){ "jsonschema-draft-04.json": jsonschemaDraft04JSON, - "v2/schema.json": v2SchemaJSON, + "v2/schema.json": v2SchemaJSON, } // AssetDir returns the file names below a certain @@ -204,6 +218,7 @@ type bintree struct { Func func() (*asset, error) Children map[string]*bintree } + var _bintree = &bintree{nil, map[string]*bintree{ "jsonschema-draft-04.json": &bintree{jsonschemaDraft04JSON, map[string]*bintree{}}, "v2": &bintree{nil, map[string]*bintree{ @@ -257,4 +272,3 @@ func _filePath(dir, name string) string { cannonicalName := strings.Replace(name, "\\", "/", -1) return filepath.Join(append([]string{dir}, strings.Split(cannonicalName, "/")...)...) } - diff --git a/vendor/github.com/go-openapi/spec/debug.test b/vendor/github.com/go-openapi/spec/debug.test deleted file mode 100755 index 353a62618f023052c25db90d5c3f6725cadfbd95..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9263612 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νoOuC6} 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

`f)iZbdyB~2+K3&M}$BdN{3J$@s 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Ɂ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

i z6Mcdl#^%+G&GXbVpX#lZ(&M^JV}C`l*K8*mC0FHXF59bGz`? zJ=hY64$0(jys_OdGaXy{;Suys*kBh$bN@4wYe3z3=-#$(z{Q<7#{-DWBw2!p`}w4! zW;O@wYfzvbx*@SLySR9TM`#8&MQXptH7bw~GxH9#s^yOrtjFa;%lcZoWd-JKnUn!M zwD8G2klNwI7TrEsBkik27inVDVy0%$eXT7#WKrGYy#_;Zbyt1LaW@SIRb{#-s5+p5M4<5YJ)b9B&;r$AR%O zL*2f=1`;$8%L61(X^xuE{Us_@pTr={$0Z6g#z!boIo86Q?>n+W6*3Xksm=;#VjMTK z=uq48kOh z7j_Vj#Ql3+<)l;=6BAEe2^%C6lV`Z#Q6QBzDE8+QOUwvC!X5j<6Qa{H4M1mS^<4{i z*4j>0zd$tqx>ksu9NQ~%SY#r`B#2K7CZ7N&2AVL3lr!~)S$3V*`A#}$+^^K#3bfo8 zFeS~Ov1Xh@l}KEF2qZWoJfx|d-7uI{*Sd(-$qfeW^@_J1I6xxweHln$iV&sVISo5# zqX(=;iX*3^gSWgDV;hikDNvCaKr@4N?G!?1U}hLwZ;vk=EciOv7^&cQD5ZD1nJflf zdTH5(0D7=U&j;V}Fhp?=eoM;F%B6B(c0e>YKP+aU4>oYrXUA_G%Gq=+QK{p61s8SZh9VSO=!H75R*Q3S=K_9L6gvd;Rzp4q<=cR?JHi*2FQ|k$ zpY=87G}E7tLpvaPJ+d1q5Nq~8Nq-v4H60Ug`S3a#X`KB+K+3I!I*){Dq_X?a|A51Y zO;%dBR!Ff>PN3zLEJlngQM-C^*2j+1v)O{AflX?N zC9ARFwjt~?m9E{ILI1!BWyiM-V#J|s(T6y7I|uoROl!tp@V*VlB6GU@jEC`~yzLsW zx8}dxDb5Pd!V`P>a$tw`x^G}RbnDh@_$X2a)9SANVH6=SHSS3VZ9EkP=}49pMgb~} zj$_-8J^2XxLm>dc&J?e3&1qN%yCF(f88)nIw>vgN5Z3^DwA+@A6Qi)71 zXJ{(-hwQ@q{$~l7yFcWXs!}w0Hy@GvfJ2*BNT-gu*X^Of(*$nkj{PF0ZieIuozC_S zT@5_Gw>F=(6w^9c1Ly=!*e!?#wC${o%RZXTP-h0y+s?hV(slx~*aeV23`vip5SDx* z7InB>@Nf&{QT<+i5qblr9QkEOK8*47h2hAeev5xPIh6`7knX_=oSGj;SsupcIjf8IPLJ|ITL@ts zh}@l@A`pzZXe#y*AmYv$Kp8hZ7&c`ey+E!i zFUO8%=Mn5`wgJVP1iRD1GgQz2NN|TgQ2$!eWjqcL!ep@QLc)pe^uC)AXVF4=mXlQ( zUhEaoyl}~orj2tx1}aC1@1PA!z-Q{A@ExdX5?Vy$i~ve{B5;8J`Rc1~{K!F5sGF}^ zmKH2gJEOABzqz(BwLajrA;|g)SRaUM94eV4^nLP6pLs7~&1P2Sf{#%1v&r!N{Q55b zh3gw=>LW_*OPbFqqcw2Jc9F1b57-f6ou}mvl?GWU#j!|kv`224=6U2B zDX+ma9vPw}@+5(@___%Lzh9CSDy5H^d@$SzHXg;+58h1W%oS`Dw31CICn0uf!PHRf z*YGLMKh?TZ#n;kzc3&e7L&!qYPPI{2)EHHdT|r}d%0HnG-vcL258A&u z96&FWWvWHDb|64uTLkbLqxUg2J~ft(8oH(o6P9N+<*r+Een1 zztiTqO1?kIi_f8%v~{Je$p#l9KqfhX53L|dY9AvHeFpcNLFrB0U%wT?Ik~%Cr46l3 zR#p#UqfYKDsS&gT5kXkj43p7neh)R)Nsa33e}J-o^C;`1FQ}An2rTr*@7^YPqw);w@F}_9Sdspgk}Z?&XH$IMI#E;KhOq~v?p^l z(F+pnnW%vfylA%DkmxylC0=vhqBAhZT2zxwA#Xy+JROJrWoB42PvX~3HY8Jrkb0P> zoC`{BQMvdqv$~Vpl_+UI7wv3Q)mXJtk zyvk`$E{4QQrcstTIf3^-GV8J-BsqA6%1mD{PyO>mH@1X4!`dUF9R5BbdX(jW51?J( zZ4*^X39s{fG!jur8{vGR9nfM0cKxmZm&aE`$7NRlsOpO7ZWSnBRS`X}e+8KgZ*m zgDWD_KK&V1&tWZ2BM3DO@ONVu>=jtfZ%4Xf!(czKreo!LQbf<)l4t|aflE|tfCZ(6 z(5Mj=Bn=h;%Mu_0Q{paPtc^`(MFJn_20=1wBd4>H8jnCue)q!^T|@^{&zEzacYFlD zX?i4JMQEluZ?e6RVGWK+ai9TI7EemI3t~gYOsD)4{2_~^enRiWV|0W9ZsM8?5Keg& z%HRY-QWP?LpMc^f(affuU;>&7o4JARbT6ZV)0a{+IidfJ=HzS~geng&#hVoHM&0+K z$-+f*i>ES))6gGhQ|F@jSU;hEZl-`j^A3qr(bKVTX`}H`O;ltGU+ft?!M?&rAiz~k z>%`(AwXvQ};E!nzrEleaqkE6^%nH7DVFrzx`5U;c=QROQ{HWy{e$Am5|Cj2Mb+Crx z+-3QmNlWm*QzyZ<6eZ0KkGqtCp;G){q=6kLBA|V@tJ_3fqNgC7OOfP2N&p0)m;~1+ zkGLTiB+*w&RTHG^K|~K4zrS;ky(NJqU%oL1mEl|#y1&R1dMXi2Y7>7W>3R>YIz_w6 zmv{XY=EUpGj36E?5s!?l@R6*MNF3uKAx;pcX%1^eH*VI#9dW~*0G{LxwmQca6Vbr~ zqM-r((QmAcRt?AoN*B|dv3{xsbx$>7Z(}h8T*+hfUZrJFG?3#oX7A>*Fa)u-cPf2HGmA-~w%py!&L z2{;f9yLEgQAaJv^Kw|i*nN0!MHeR`HhjZk=zUIDnBL+lAzC79N+0n?aU;s5~r(sVI z(3z0q1ltn^j{3eG-sEJIsa)Pp*vC2jvns4br{f%7?OjHNGb>#*3Q%sGlbwYF8LI%u z9F(sD0HP@_ARb_PmhxEi`kli-&aqK!q%cngp{ksVu*<_zYqsnsVlb+TJXF|>3gZ}k z0_QnmP(}2RAFtt74_`D4tcpw=lvCN#o`Zu4t0JGs7H77DXS95H2?m`$j`5Kp3OKuh zRT_*zpd~zm)lh@;j0if9-4s+%>>l~8A?duc$~olpTZRJ1gJG5!P@oC819a4?A{Vp2 zDqKSbu?iYmOj*UA5SPG7nZZf8fM!&Pc2DV5yP7;P9y#sf&Rqx@40phpF^5-X;`Cu~ zXw>wNx^KeaeVMDrT8q};|COV{8DlYfZRWZ70(qmmB7_}rq$_S?4_wVn9rDx<$NF46 zoSB)qsReqH6iRx2`>qs4Y46T8DZRF-bG zX1;}xr0PI8)@g-xV;usFZND9V0>*WfRC@oq#&?*|c z7L9d2f}7$tQW>6?(F=tG5`wr%?;6sljD$u6Wp)jL>2`MwsozdB8uQrBwBD#*)%B&d zfpet6QUr^Z1ozEyPw~VL&>b(pWByoYe!!rZA+MlD6a|Vf)3jK9awgG~zM(tbA^B5x z6b4tCLNKkJS113aKoCC>yhKLnjtEe82SL!f6z*RLjB6#BJHuNv3~*KfoN#6||In+M zOSf8^1w5#WmoxOnq0TuS`H|994HbOZF6EFCliE=audx5?aK*9;AYf)x1CsT82d~}4 z>-42`b<#`I+;IXo&!7nglT^XZGE71u;&+ZJ7(;|Kl(9Nc9nu;b%}8VCRXWmGR)WT2 z8@aJh*Bg8Ut&~TX@R3S*w1EE584q&{Vo|U(X&B%>RhiC2d8Q(`A#S2#r%E+PzS>Ht zN4Qo#O;b6D5Z>X90LKbwnBQlBHgu#tw2Dn#t3w9Py+A-#@LSQ_ecQ(wwnR$ zX`;DoGm8Wof6wk@SY{ZI=0Om2U((zO9Gw}&D|S=OYm$++CJ*m3lr3915lX-ol!6eu z9F_N}P?H~m+7czm^GEYpE63#!iWHH3$T)3e#%ZHE3QKbI*sqRKY-d4okzL&)Nz7Np zZy-ME#H7xi;-g|OKDvw+Z~BI6Y5a*on^#9)5f@nljOhY=^>~#UDh>PbYYip@vW6x6 zp;8-+AgQ2ce*wxyNh{Emjz@z3!|%yl zy9$AUL%p&~*IF(A5Wtb&{{#URGX8%vv%kx9Ks6MTD%da#ly;CZVh2lq55EI*?;+#x z$NTwm2bgkix*{G|ogyu0Kba=3;z#5vE27ZXv3TjK(3PC0Twm#Mf6n-H^JXcl>N!mR^n_A;LtH2y>^9u?Ky|ywp4{GOiWpddy^$&xR_LJ6 zN?@iA-hNWtIK=Li4v;2e>@WDC`n*ErQPbo?MWG;qMmsG}pwSMA?WUoT);>)h<2r;{ zbRFu3fvhwH)kO=NN#i)ye>5^qS5y~=U_o-Z7E`XxxQ-;u)o)&bT4F~WQOkt>lQlyY zSElAKb*!C@t=|PCs8YqhT~%WLd9Fx<3=F~rWr$Tj9CI~{%+nOXIt5V*5}ugnyzjFA zhqX6>kE%M~#}mkCSi%fKAR_3XQG+4|g_dj|FO2KcyGW2AX&_HZBg}*jSuKwx4IU-0@F2;P#!# z$LNDed+XCf3+YM}xe0xoLi(k>f3?V9jrSmk zp=DW$4M9>N&#?{m-I8dwdl14a0HLRIz-0=&;&rBs4<*6dqq>iOarl($u?Dgh%ROhN zg5B$BFW4Le0@%Cvv=4R{4R&hhx#1r|`?0G5_QfvPDe!V7Gvwm{^!3k>!BdQARG$D! z7h)(ndIa3NCq8EY$>C#=vBD)icQ3?Ys+w7v2M!`}Xe66p|Js#pj7#$LM; z+_)8L>Ijj`533}9rb@mPlPS}7D04br1ACixK`f9Hjm|9{iEw$ zWUz#zE?8eMou5MO+52X*B_Z11;T}`9oF3n?>a(T1(^0Kzb?a6kgo4OGLx(HnlR3^O z8i{Euh#R%E{`ZRM&cvhsf>@4kx65~Q`bmmHz8#(y?6_RtsW^T;j9 zZ^^p-X*(4D^VNh`keI|Gi3{<|e?+PX*KJ9B-48Aq$dDuwH}O+VVsc0!0D1@Yjl^69 z`Xt@rR_5WD)XBDJyrKbm${><+1wg7j#{OEAL z%PD(!IOkhKfwrE}ynX4>uli70*z-2f&(bbN3jUI}JrMq?k9NF@vaJW~ zqph4Lu1N#@#+~g0-?BG7@Gt*efFDNS&uiB|I;j8IUHs1wS&;019-HLO9I2>0=m3C@ zYzNTJ3efxB0-#s8fNBpSh295+_we@MUHYh(u-fsw^WW_g_TD{;u&Ivcr5l8>pTGJ4 z1l}IiJ>V}(bdgNo_ipvVdz7N@+Hcy2cYAAkc%NA>@Sgg!;9YreeI8@74f!SX8u3C z`;&0PuIO1|3-&FowL5iVJJwFTal7YhL~8KXmN)H~Tx!xKCILfGFZ%{B^>lRc*pBw8 z_wugvcH?$Q@!DChgL>~Po9{UDZR5eO)60v@sjXL=>2d$*yQEla$LQtkIqi*)v@;p7 z!)7GAnSo_c8#t6-A$Ni99|4fv{VFw7gX}J*+wny?UwC3Oq++jG%NqC!HB?~Y40=j8 zYWBVUq4zb$B9mV~xS{>m_P4KsB>zbvNs2t>BP$7cs${T&i8J^E@50}mquCbbgD6*H zohOvZ#4-Zq=W!d(hUPmu6J9;13V4pgez8R)Ng+0k4TXz0P3h3`4;8#G$6ybpVSzsJ zAssM&oNbTZ=t=PeNr9AP3xfcr=tY00e48YnnbJX|;h;8a zMku@oHzQ!hDIbuOf4#3T(y1F1RWX@%n|KNfmfV1egoM#M8kdYn5uQqJDW`1- zzCDJBU(ylF7eG_&4u(|@Sm{ujsb{$=pwqtsV*GKKn2?#}^1MKj*bXUS4hD2XGKK1~Xuc$Ev+{2s`fnUtRV z3*zS{<=-AnA)B^i8$jaZg-!g0f6HGjZ8h|5=@+&YxY=JBfvZ(w1uy%$C8mnKa)1JGQ1z>Yile} z0-`A0j6mMV<5rMtE=LpiUQ=n>ify<}PK@tl0YDuf)_Hb(tD6{yE~++hpoVFPxTCR3 zN?Nx46KA}cp&BJCj;9~TsunX;LtfCSPbo4^7tw%9R$SO=0EG-e?Tidf9i)V-U9aJSK?G+0#-}&A)`NPwceS}_&hkn66LbBKt>cOHO43M7$LO}qF-?<}KrDlWv zhP@;n=7$u&Go{5p<4fM@vv1b(I&+qBHlpY>uyDj{zXFqq1ykR?r(TZ9>43ayILMc1DSY!G`4T!^8t)h z{PiJ$0W!tC8CR{u9co&8$FcspqvWGur-o|xAMLO2ggab~t?n4!zmoqIubr~>ju5Y4 zys`1(TK^2}NrHOiWG_Vy@y9YhVF?fkgYV(ujZs*+oou>c1I-L{tqPxsu@j|(K-9_u zbR;39i^I$H-Z<3SDPXB9?2lr`6a!I?0%5OrG9hkSYI%sPfvKawBgHJ@U^l*@x^7{8 z9?fKcitS58X&a$IRg{Dp4Fd$)z%Y1M;#3r|-+fUWzv8tC&c?Eb$t{*@$e_+3b+v^Ytcfrp-y}V`no7s1x}7bE5b>|Qn-u*eF5?;J zUvwvI<|Nq6uV6EGleJak9{x~H*y?DCCYmFroMu8S!)VUG=oe~Y%YFJmIEJ~skFNp; z!RY`6fm3*+0rr4mkI?aMld^i;2f|o_gJ$s9=3~o;Jps@JdhFZv(jQn3v#JFWr>91N z>a8d*I)ZCn$TjTqOx9yojmB?*xJA)@f+Q7qAtb4k3y`EBKK#dsLz3zuk^_5--U9RWHT`xO&xHj4GI@0=H@b`qB6w&(Gb)zygK=N>?L>ft(89Wrls}Khp;mN3RgY z*SNGiZa@A!^m&*b_cVQ!+drXdeZEr{D$leXN{Z*_Hwg^-7jTgS{1>*~Fg_3#%y0AP z@q?JTZ}gZtP_HH$JOd)bGktZ9@=SNK4oE5`6dSkzP$e-6bH{guOVG@cSR0N}d|bp2 zr|qwS!c6@Q#e?5dGNiuvR7e;cMQYgojmlnPju&BeMj$rv1|6cF;&IM41Ff1}fXVD& zsh*v0jm(q{nw^Hs1a#9NWQnR2iO*<~YKJ6C<48)l=o;{wEhWsfMYWd&-`DcFBXk;H zcw9A!zEm5h2CT^eT&k9yBGTe9)HccY9Bb7=sdRxWd1~FSDYym(BfA00Zg%1ZX-2bH z9|eSgx8}qcb_C<*LvS{zj=&=?2qUN!GXC*(S70!0M>F{Y7g_vUbOHR8E&w#(D@e~K z{PG{AXPbJRB0ZPFBNXXD=?6_|TsL{H=XtIdm}}5!HLfXB{0^el?IKPPhdT#t$(B}) z+VDvppV+ryM|@Ht=vvLCtTAjs99Ye&v*X4Ca@TEfF+b$a{DT z_q^T(QzQqkKWFgPa|VCGNv$G;_^m(*&PY|+Y`1r!@65@l&8VpaBe{2S;-U3RR1=Bc z7>IzbwRjVWPr$m;g<{Mj@zWy^Kx#n58XCN?KfWIVuLIad&_Ch)$ai(lMz(v2Mkx)_ zEF^)=QJ$LdHD?5_#;<=-H2=;Bx(C8oTKCsr1PVsD%Wys#Cn6T|IkxGEeOem(`-s@L ztZ=8UKvCeIJi-apQ|J>uEx)3pAWkhl$96GOv6eRHmJ2j<0E1M)$R=!IIvN3k5@YJX z*!-!y%CmdUB_hgLsK`l~3wWRaU7@6V3TP%#Beczc0rOcwN>22gM>rk2n|?)?25?fE zbeB+U8D>33aLx`n7nb@eLXl#GWPjodtM7$m;Q~}SI-b9UYzq=>$SEbA|9CxHUzas} z5iP=m;^)o@gOt(yj+j;KZ}=KANmlZUbNq|O=Xb#0Yx6Tpmwu65*6B-foE31T3X700 zyf16`7q-nswg%Eg=t6vlRV)$MwCo7Tv5tk}$3$XVM(qDP{mlTE5A8#ChBtR&d%=sB zporL<04^v68L79`K==5PKI3e~s0S#MUPsl0LFgZAOg* zz~lZ!m-OZiAa(m_iO@ghelnUY?+FLjNWYkB&iuJ=wU*RyTzZRH?~C83#g##Gj1Ryj z1+i`i4pS8|0IjzHa>2^Von+dfCQziLj1nn#gXBE>t%uO4dRP@L{VZ3 zpWFUnl?S{!tYDw@rw$~THr{}5#wa|Hvlamp<$@wtMA&$oDBVbdIib{@)Jl_63fM1w zOtYu!lLbe5*-Y_f|Ex#&2>_D%P;Y@$VX`}Vu?Ek^~Eojm!4;pB4w-b}!ke(j@=L?lXMk<$aEv9YJ;#dCI!l=U+MNhZo%X{_t% zrLi%mi|a|QL}KqmV#{$BqKH}IO>`NhR@c+T0_$&77=N5B-qvd?@P<%?t&&W1+vGyM z#t+Q1_sPm?O%{zIRa*eYrv#V?u?pEl9_I#5?t2Vi>6z~$O3Oln$a&Y8APsA8Z|}Bq zKaUAi6Qp@uA|^<4k89JG@klkbA+k+qi;jR$SyMQ%h+=Q$UbB`i8b#Z1N!o<&i2)m9WfRbVII@E*i?}wJ9Ap?J3L|BW!teuShOIyB*q=B=Ijh~}Tkz`uoohdR zYECdQ5{{=Am>La??EvFzKA*rSHB`V*4Xrt9N;M!uhcHJ^KxgVG1He!gr7Xx!kw`UR zN)k_%w2|*hPXmR5Z5uuBx*}E2dxKQkZ2B8Ic=lTy_7bi$o5OQ#)z;j(_t~EOu49_?ll^PpUBpB$O=inXBVE#ktnp)1$*2er2 z`3HipKCRDZ+oWJE+lThEeNs@FuetezA#B}(QKe6&jtpD3X3{LELMDV7w)$W!SOTyz z5({MFckZxvwVH@!2GxvuL?OqcyCjb|n1zQ_6LhwOCf@JHGhv0cVk1D%Si!G;6JsUB zL|{yysfldDe!UOFFjZ5_2K$XBtz0j^LqL9pa=nHP2C1_WQo71@oAh?R#>YAR)o@$6 zw3rophdg#djO`l~zY%GM03B$oedK8?nn9iAqvKd z#}c%V|Ht+cr+_gLCWHi=f$&qJV9e37`uqQiNSJkMiKU+uBw`CN=ia{XQQ>rKQ#iIK zf>R-4-ynx1-RbW%LT39~95x|zPpv>i>XH#T2~BkEVjLroL|s66@4f3y;-aosj6HfpUl z7T`K{iH4wlzd(k?seHh!7^G!3s^RI#)RmdI4$WMcFPT%!(6{EZjrgrdn~Z=PyWC&5 z2sK2ktjk8lhhgayRyVK!0BXW7|M8ka#ed<3{m~&Mao;zmGYvEv-Yfjc6IcO^MiUCa z$vzM1ps5{7F``h~sg;3{l1Me@j6F8*%K&==7Nlpq1-Ox9Mj+7^*2Xaqm{2_uYTOb5 zee2}a_yK}qmLR1pajg9GC z7~M666nqrgtvq`oW?T^a;0$Bed#p%Q|VwFH^p^)mISU|a5 zXX#1nLJ{czP5)FR4_ye7zg8=W}+z(y7@QJbYUEzB9z_jtPZ)r0t^Fbve}^GR*o z!EwoXf01ery%!g{!G7mqd>{y+2WRLpAoloe`Eh^=ZlayJ2^)KMvG+a}w7!~2kN)N;O%qT)uW1#HACVE^?sj~fN` z6B%TSy>(QlR1i(P{;JVZbUGl&7!HJ?^R{yT`40bCsH8-w$D3-GH! zRgRwhfTbu(&kX2*HLOIVO{R)|c2F9^MFB66Nh!>*Uwu(g5K;zu{&vxR*=dQ;km|7! z1vq4L?G-0wVA&-$9?|kq9uOjr!J}jnqwYM?+GczU%!6)4fw=EqLpYjzK_Tt`T_|Ph z3&%!)6ME(=XfvDdtlYI{ns`6=^=l|obS5mFW;G7Il*LV+eKMm3%U2^sfy>l>6hAFJ zsC|>Ps3m>c3Mv3}i7}U62r7(U6HsXz=RIEj^*Nc#!* zq>A0kJT`~)OcQ@CU#1{Ko9g@KY9b>_uKPLMfWdk&12=j0)iFWlSt$x+Ug}F^^aPBw zm{>V?N?|B!gA_gp=9cfK;aU;FwQN9%P8)ETi#%S~4^L657>wtfe5wTS+yG-BT1pIN zOlIW-b*oBm?)GB?jNa-^H>qE1l$Xi@`}0M~8eWUGU?Xrq`Lhyi<-BwiX#`vj@1wXV zCEDd8H;5WYn`oCVG!~(q!uH1dVIsFU0nOUaEUIk#A6*vZIIhv+cuR3E9C1pqEwb8^Y)t%9Hwr(W8zNF$>sVe!#u~ zLiok&YJ^B8-4qTbESB&1m9$8x9eqTBl1n28_8IFm`;{34Llm1kKBEF5-<*e4jTlTv zCv~E#@x#BmHA?TLW{BZshMjod;e66MnHQgCjrQqtz??MeC4|2JX7z36K$Hu8r{SGL zy1(~Sq`OE{jHENB(S883E~G;yvj^P=+O|s4P|b$$d{aVm3J%#%pqPB4W;!Vwi!BPn zhQxP)P(tFbo4h1Gi4bG|zZEV)Qc1jNZF&+n%@cwQxDN#R0fvQgmm+U#+NDSIN{1G! zdnj5APKVd)f1)_j`k;Hgzd3~v6bdR8FzDc5`XCr6m|pRO7t=us(=E%}$Ml=`(qp>l zFM{b=_X5*C#&r=jBWTb~>`IJ`us<9x#X$EOwNNbp2drhcR~eJ&16kJVm*!yJApD(H z!WWyb#tPu??8LnerWWuLi=>_sJtqaJ{0(QCdJ_=0-8z#G={Y9FK+2 zpeJsT4w@afj2uwzA>Vm+2_|2eaH&JfVwP8*Dpbo&io}^P`T27Wp|#tB)+i^!8`yVH zM`e8DV|rwPN!j)S=Mxltkht&!vM}V`fF~k_Z^LTl(;eB^bSNZuP<1Nv=>*Pnb0vc;AF|FWh z`(6z_VA2cW>Cx|mG-C0;S@B;Xy8vLiooD6$N)%CP1vCipww3&THp(Y>KCNcygd69Oy6=f;uV%R8i9J0tM$n<9s)lo zttTr1NTM_>>B;F!+mOd#GVyu+p zD_NwhhdGX<9$b63=)vXk)1DsKZyoS;drI1Fb))0x??xf9?RH`*{rf_ql_rM(4j}kk z?XRyFyb&JU*KAk;CmMSU!jps8_NJ#<$iy(VgymRj@#d%>VP6sCCpnuy+i)c+6CVd& zK#`{aDns{$Mh1Bri9RBYNCPeNStkU{)M-cW25KjRX)bDV<>F_Rxf% zP?@i+Jo@Jaghp*%LP2GJ+{7Xf#Af-`i8hkqsm_GFoL#ROHO5eT!(=?>CfpM`<1da~ z8LjT~{PpLkt3LkvGt`xH-0$AQ{L`vL!{2ZiuDEc-zxa|~hQc3fZYP^K}e;!cAUWA&|iJMfp_M>)<-{Z$>&jxB~I?xI);7 zYlicY!BtQLuGnK=;aV$@B;&fKn~SR)Oa*5E2UDG?EJ#}1G|tk!QtZ&Z3eN4(0tcao zFe$mZlcdfY*2`Hl|5MG7uI~Q&ry)DII;{Qgh0K%RG$K{kip}jm)Ff8o0g=1dc@GZ3 z@9=PFnDYuWgaf%$pB_YDQ#tI21I757w@jNJj-{1OyT~buHXxW<1aSmU780cQ9*9@{ zax||J+_x$Tfb9FP)eau19<+Y<)S?uc#*lyH?6n$}j3 z?fz|`swL4umdgh>BP*{Ci#{kL_Wspjgv`7*!wXQqPvwQ6Hn zuR^IBL^ZO1?sxvWzO2O>a-qx!mf@m!DLgx@H;7;_&AMIqC=$=w%~=!@pv(qU_>Vpj zeF*-;I8StFNj&$>Am=+(V895wu1(~Z81LZ+80;+1#GepGjJ9L4(=rZs^6RpA*0-#> zlGQcg0srxOp1O3ZzS>*$`%pwy-GoAEtLE2c5Q+n!EXZ*~Hc7veFqL6gtl@W36DL!_ zgvmL&geK4ae4gV@`Rl_d#NHFJ3KO^SF-y@~U}r3ZF3YpS#ozfGx=D$i*isAQtBW5} zA|S<42#--3A~=@bU6hvIELB12m@W-X)S`hfbD6*434mzav2e`U_D}j8LO8;OFnXI8 zx(H^D$GK7>1=S9l zJ7q<4D!?)_PpE+t2n;D!%P&B@s>Dtpz>3IT4t1-F{_;OmG>$WasuB@YWbdCUPG+n8 zw1=mdnJ)5>!tyxcg9TB3hQgD&%6Q z@kW{o_6aXI?%zR;U%gXQ388KaCaS&(js7nNaPwkC3&7{nBE89d-YJ^WYI0BHv5XGd z_Z?y^qx3|YK?Xfe} zffk^Tgnp7?l~fHl4iia1rjq6j-sMh4=Bf)Azh=I}NIqR38m)2~?JyTQSzJUDiC-iJ z4HA6>Z6!@&xOk<%u9v*b|BjPbX%EjC{4Y)=t&wd`%ZfkrTRZWzEcQ{^fPa?7HkK~k zdsf+ijin!8^2i(Ft&Xh;Ggxp&|t30 zrs=+qb|6fPP>vpad3^Zr!^0U^##DV7XSootaBK*cr(tn%nRO#%-r!GTqD0F>##Ev) z)6;}HG(|z%#76jAs1nA=JM-eaADJd5BxnhSS@p{;GqBnHfBthEVBl`?25`w*NT376 z34hQ&?@KB{+Rg66iSFbLz-M0A_mm=bjw%T`w~091M5+SQT&?(}1HPKSdV6>K%-dlDI-v>226*%zX=oZ^ zSugRdpI@cl4;{WvGsJ`c==ZGF*W56OV;vatz@P|*SaB`s>z}&e!n$C;tfxGm74rzg z&$7fS+$I%2_DTG9d_XWL>>N@60rJ?^*H#!SK5m^Fk^r^ zibW}rc*jT#^-RPNNYc>ztyt8;p?75Wp&B!RhS*d3WaH?LkgIl@X-|%~sE0evX*ZXJnzzwUE zv?=PZl16@M4P06hA9{B#!QbU?peg=ktnX3`%Z|H=bun+CnyavQ8+gHr?x zdW6@)eX@L?52Rs2gZ8Zp;YoDixp|^)Tm22IWdrP?@!=<7PF*yAq)-;WjF8m8C>W|J z%M1I4&twip5DSH1sG7)au`%#at7t@(NNX^}fFctGUK8(aiL9o;z z6p{F09@*;m;%>?ovt%p>XTB6Sv&bj*S{~Vgd5c*2yRrOaP!HM9-rryW%t);3ZU{p; zE;B~NZwV~@CXd*atLp%-FHqOnyuOgvytpWa448!vRoC5Cu*Pju=o1;5%~Gozf`w?Y zRQfMkTSEy#nfO*%!H^5_j@|j+J2-)*gq()_XaXtvnUMxfB#5Qz)G1I_zouQ_>j@%A z$Iihu#}Sn9gHI47cuh)>zW#)QG=+k6Ed>eV8fDg){LD1Xf-eqFOmkMhU$CV=I1;8L+f7W2E)1m%QnO2VIiTOAI>1=`c^|1>IuP=#>IK{sRa~biV zetop-h-s@cYWMG#=a@m$HFPf6*%SGk)>h7q={wAsdeuo@fn*?52}l>PAJa?O@-Pks z2U6O7@{&TW8!8Tm`YarCq*u}=*ZMQ1P0nAbl1pX!idSu}K#jE(9wGuGMJBvz%$ zJ&OFI@AcF?^-Jl`?Poqo0iWib70)rf&CP2~cLaAI>WE;iG``jrf)ut4naDqw$dkIO-* z3H}R#WCWWVc%#47U8f#8R(&-G#jGLA;={|kiL>i(kZHp%l`!{vt}J*WMJu3ZkSi2L z3J)Fc9KG4PZ&{HME#C{n2o$(OGZ*HS%DK^G%lGd_&hJ$2n#+0Rvdy+f z)P4giGe7x20IOcL2l*f?vh5>e`L@zQnf7ViX;M#suv^6;lCeKCX0CfWmPs5*uhJU& zr*Dr#c`C8w14QgN!~h}%?H@PO;<*ctxK_xzLLA<4iTN;OnmZ9p2YdB25(4rW&wc6) z5(4#+1a`=BxdXO{c_E8H95@U-C`LIpX5d3SDQ5DlA@9V8ztlB_JGFw~5bOdpS1nBf zC98xxGf>oUrxH&<>U;qTM2q{n3s9On5r;ccP`G1XCEU3np3EK9p5e|Dcc$l#s>X2V z4x1=1%;&cr?lj5+aZ>C{rHITwGE0y&cjP0@ovfWn+%ahj#hr^cC3Ai?f#|!(mF^a30ABaB79FR4?_}q*{ zT+V>VX~MN@ux|VsOTccyo7wi2>07Ok@-To$eJ2Kgbu1b5nFPcEy-)f|-g>Y=3gwai z2u6bV{RKa?d_|9$8A|nPlILN{iRN=@My72c~)7MOCOPr$$KW4yK*-l}~Xd+J)KE;6X zP&NDp%|IwwLyiTUw5r0u|!)ZvG&GZfd2#Dvi*?eriINxE*{Hi1w7xuU_zo%iAzs&qbhoJNUCdcya zy6bpUV8j_d59aSSv1GkO#^edHq#|2mVUtge}GC|0dx zWn90()^L1Gh_^89=z3HBtC_D{kVmlbfzBM#fLv&1#1ji)9eiy5!h|VU~43dXMnP?8=33?S&I0lfw z>tX^z#P+Ku<=|u^tgru292`v$?&Y~3VHOcVa=Kv?KS8x2?mI`tlUM^u(C_^-Zj^Tl zSQ*?hkjvY1@HS#)70Ut@%XieR#|wJOumGzJJD@=qqQpa>IBeX$nGisj0K^xt1G?!k znKG{r?wn+|=1L44jz@tT28U+U3GN0E^Q+!Yz8a}0KR&0~lCRnI-v4Ma)ll;oW;GS- zO6!(pGYwY3h5DddE$hcF46#+EIP^}-4wmRgVrvrF=m}{9lhyIj{;zbA${< zRhaFhgYPIUC{EwCU;co76o-vq5eta1Mi%V?8iitF5H!NBFtyK0S37%65KAhiYjSBy z#fq_tkiu5buqF`!*bJkD_MnYjH^W1BFj-jM6SfwyU|OW)g3645J@WkDuUd{EIdM`YjhI(H7NVwb9>0nb+Pu7?bT2zQyHQ~(gxrjW` zmgBeV9BB%%Z3&uEXMIg!hk|&P4ASvzZ_@-h2L>4uy1i9}BNkv`h;liHaA?oHe7b5`7&XA~U{BU%{>4>= z(>|BIXurokw7a+;E$mS7C;k~%u<(HIDa+*%>mKjnY{U4<>WM{|Ix}9kFVo*pL<@p7 z#}N!o%%ZNZ%E{MX_)F&IchV$EU9EsgC>+)V30>A6QX2v_1e zbrhx6ITahpTqq7~k0_4aqpN4Fd61o;c$(;k=xH);%iyoGw|?%jKafylL6Qct%AkG! z-y9{!d_9GhoQZ6(0uG7a(OrmrEBi@Bu>TDzL=MhWXdolmgLa9jkZe^IB0uZltymB< zWfWvedJn5nf9`wk(l59nF z^0+)4dmkIWl!Eq-oGCC87Xt$Ova2XqK=0oB4}jiv@3zN$2$BaYC-y1^?S$WZMA{O! z;2sM<-^5xY+pZK@UbU=@CAQ> zpU**_B!94gVkqM~Phsc*{$K@N75IbY{DnU#zaU#B?m4>?lR9xu45ld_!SYb%aV&_H z65YM)5bCex1WPM7IPhFS$-ejt#8tW)dQKH0vHELBawYGr+?}~jn&qbx`6=BAYpyDe zn}B`A`Hu4o-Dp(Hn5`<5!Z{fN`*^cU+QnGKVwMCK$SXLm(hio*%kRR}Px3vVNKq#C z3OHTU@{JLI=s$ffF=C0i-&7q|Xi+@!eRcGsw6+%gEX#w|M;x7)F9 z#o#8zK+^>pwLuuxmq;MNvx%8$2p0$kWSNsCw_GJJ%9Gvri# z%<62`1p_3O6tL9D$*PU~P@Sw=2tY7R>jG@z(KEj^_HKCh<`Mhf!ISlo{vSj#H`5^1 zh*jd4K)}8pfeiaPRtPhQzD_MMEyKi6UbDWkcqj2^&bPXP7@Fv?C91zwh_Qbq{E1(~ ze8f+Ir5#UmwtI89?z2P1CaOiV*v{Z=eM0dNB)}0ah4B^6Jv<+0;BLb2MF%(ocON3H zGIicSnpKuz?gys3)#4I_!aC^mghHP? zo{m1|QgPlNJe*WmWs?RR_1ooG4zy%}i>oyqBknAgww0Z^H70vsEigvXb(#8UKBr>GRMOo|yDzLmS+UUrhy zUUrhO#;9nH4o^920XL+NL`o=r&u>)m0v4wo#Tz>2kmV3;UqD{7OUCPRK$T(pIx26Z zk^mwkr&nOI0C*1_gtKohg65)t7b*+CaH7H#jll3+kIaOi4N7lA8D!y+IBh)^od5?@ zWHU0$H~Xf10EXhHy`ytCrv`?O-}f(lbmQiVIP5##Z$bXKxI||fL1#+fcmq2-}`j=dCX zhN)`OB;NAt#FKPUSj4=5OlI4EkfLT%i~1ySC5u|VXL1gnL;l5?N&t{Ue)k73bWL?n ztTCT?43O9DBpNZR24WHAGb7&ik!ZK&W7F+O;PmWdCCE^Hsw(ubNk}GoSX%GZLv#wL z3yML-3If!{*YP#iKvVC4ZifBFf9dJT)@YdPl=zdxxTtc~{c&w7XyFsoie zS(e0;^aMNnnqDS5?7DYrXI5Zkj$?NcbtnLvo(Li>ZeJn=(PtC^fW#^+53r){?#yZ}<`)B(BGw z!D|xR__5`i+g}Ux=UbIPFJNV;bcy`JYRWGnVfn?LIs7#O4>c262Oc8h9D}AT!&gWv z)0S_bX>Y@3)!t00S5JSU-PP?i>GtORU)lp3>=Ur}3P}zVBvDaTJ}3?Yll$zI%rToz zfMc4JI|v^pC)!`^Q;aI)R|V{0#u-5Pi}9Q3WOEh_Cm18Iy!PFmqsOj;{2q1c4!|BO z`DZB3{X^M0=*Mp{9#V^6LWWlbQZ;R|eodXG3W(9Ri``*ystI9W0XtKrw(lN;aAqim zAY{&(C!TTkcmIiV0MhU8PBEJYD7bcO*D{FAQj}Her*r)?GWj8v$M|QwMJ~&dnX}c^ zVg81JydnqjeY_9FxrzA1c88aK(-HaFI_?vtJz{LIb1Ax6?0g#^2}`Ty#MI)wnp3r9 z>S=PsbL`T<$dy>m&FWOyr7az?6nkQKcyw7umdwmLQaQXW)9q6()C!m|l z30G4^-gqNf0hwnu+9#?g+V|1FMf<>aSNlj7ZaV?(Yr-Y_or-Ymlf*^L0zhGE@zCXS z&%aR%rS^qFk(R|8^%IO|k6<8A1q1BCkmD#V-ZS;`uyrS*fZGrSoT{P#$nAt|69trD z!Qe#9FX`JYH3C=;@2+HK-!pXpfPBYH0;G3@w|icosq=0_l6jJeG*d_&nx{u!|2foI z@{LfZUs~!!k?Q0;Y|4F&OOGsZ9KH1TtC5w&XvY4M5GgPC21AKuLu)PSR7XT!Ib%?&cr8@Ucz$1dM*Qi z9Aj^Qk@Eckr1v|JQ?n5Je_TqoV6G}+Igws^)o{y8i@%$C8fGU-AU9%VR^HDL-IzUj zv}Vqrdc_<{Eqq+yB}qFax|y&29OfMHFJaEHWKJYb@l_h_5nT#=g@jCGQkBc3E5+~g zGU-i^zM`rLz}gksaaw5ov*fr=kKmF%3}KT6*IzdfMlMBo&xtKX1UsVBCID69Ds+mn zz*d;Z86)!%>tdmF*?~i5D9g7Kk9Nc54WEtZ^erMGG}HA|r6-9E%yI25)AWD-t|aAf z`)(%wr!Dz8^nav9=zmNaVLK>)nvSFUv41lnG9L7+J3$G z=RlUJAZuT3Pp4WyBF4Eem9>HCuTYoX{^>n9m7s1fR_=CESBGOakh;Bn{0+x~qKO~i zCCTOqFe?>m{u74E-nru{C@ef3EKw`|ZX#}!Z4AfY!CAvDgiYNSVEo?%I+bOvR%#F* zyHDwYeX`WbZ9AZ9j$i{~7~(N_iUV#QbCi4!eYbuQ;cTikyuJ*5=+1Yd~uJN

Oy!J22a@{x?pG5x`{4-tdx%p?e=qoKfW!eG&}Td? zBmdBqMxzpf(tU+M0&He4cP&NYN;aJpv#@(F`9J994+v8ff+*vl!yAt(B@6*Z{Xp_05*=vdJor z2od?Pgc+7^*%X)Lp%jvTG(A1ZA64074|$@+LXmL1Q#`lnYavQ!Axh#a3Ad7v+P_>w zmso?B@tm9a!J2Apqa#WOQYIG2SB!6noq3*ZuW&xS2PN!3j{?&JxN`kF;rEG(->~W9 zK@#wL9Jx^gRYcllP4#$Z^u)^f=m`?Vc$VFTLoo5>ps;wXFnRDr-?CIG6@pqGs6BHHa0YU}gIt+LxDtj!QsCQ6BtBqUWSr zp*v`2JVY6^EF|^deyJa!za)i0Q4oq5B2cFg)G2}z z_(H!|fGe>iZQa-Q@-QH~$*8pfFBv}n^u_!r8AcF06t3HL6x+*V^RSDntI-*omhC+0 zdl)uoRT2OZo9C{5li467+J0Q@AjqX!s3j1NA-|LJ#up;81$p*Xn*Ca0&BWJB zym-12e-(mNAZ^WZ`!p(1Ts4fq$%*)0ijv?)=Gvqit{CmL%nS(avTu~Ehlm3tL8PgK zs^z<@#gb7>v7u=Z5dvfDiGE2DOZ&<>IPqWX!DOhn`c-jiq zvD|)uSsTbHqzBUC^5-xauTSQWiO50mTR&3zQXqB!+ks}-&+SOIMeKlqDEYH}Qv3Yb zRhynaZ(S<<*^Ts1I{BF};ehgUWLX>e$eO2pM(e{v?)|MN`sY~^O}~QAz1XHNSq=+`?j?!KeOKtLOqQBzH~_%`5FGED?j~9 zAU}VDC?7z7pQRYI@uw=ZWZ)P|k!$o5U(7Qi0eCA3c{vF+j#m{hXO-c))xG!x24Fli zv2I0(CUo7IUXp8P%8t66hmA_o%>Ue}5J;u$iVER;+1bE};j6*P)d%#ilg_&Z2-{bEw{fNi6b3fFcs_Hr275S*R?}0 z(?)N$(JF2*IgiKosM`$X;lJ0p*+|_Q5!KCd%gr#3k&fd=kL)^&* zNL|d4#2Yq0#OX%t-k>yd)z|@6SkxWCw-A(YY_r+8uslAb50hi|6;~))1|Y5TFcYkV z7936N6gg5>y+N+k`lCulS2XJ3X?vTdXJ$;imQ4{L=K7gefQ&`+$Hm7UnFWU}J8YG# z3sTf7?6XZ%q#5dAmH{p!wTAv#Kz`?_NjvB-R#9?8o_2Z!kZdEB`%9M1wSuG|qO`@YMP zMfvv%fw8g%8gLx*oB~xGD%d*=5V8d9Bt(%3wrqQ+se&R}Ri7EpUAq~b<@)MV!!b!W zs4uXyF<_7{ZgRiS_2E@j;u!jOs98kR?j)`pYHWGk^>uv5-S|I=@bBigk&72UPxVb} z$i-TP_~*YfLP2*UnQgl#r)S&Sk|eh6)3spKmMX!R$tocj^z^h~)H~IiVa_C(yT6?l zE>|slbq0EbOn5QL_Rm)SW)6q@r|o!sYk4%E8selt8Nu!}xjV2X`sQy|7lE@mcJj!D7GBQ)Ri{=;D*Xn+} zkg|YYoHHUh%Ecxf&c44{%N*$onUZSgh@m*3ki8Pd(nH|1br?wdrdK%VB_k4=Z1@IN zGWV66z%6V7(eNWh9uJX_DeWD5S4}8`jgRQ(u=EyG>PCnrrcHF`3l)b|31n6U zM4Yx48ltQL)5vg8^0Em$%rpF{m91)8;&ZPkNx-M*A)HYR0)-plJBSm&(mh}Ur2|U1 z=xaBeuBH?^-$_e+9k#}HM&%j+slgi3hph!j5!6u_9`KQB{bXs~2oM2)mLQcvhGg4= ze^l}f(&3fm`@M)9#SFYwpn;NhXAHkG!VvM8wt`ZF)C2oFR?>*2yH0t;SEwVgPQpWa zo+`x^_3c_7tPX*yIsf=jyyF}~G7e;i zB0F&v-#Gy7doc;1H~95gQiAq^v5)0jH8lvH61g|4x$@XvR0Mtb08x`iUnJl2BUxIv zqmVvn0e#YfaJ+<$;ZlWc(vX-CWth!?OMu^5?c z=kcX|=6_n`4s=R}!hCKw)~NESCG00o14+IC;gTKd6#w#VMIR{Rcr*$62;vAIRDJ}W zd8@w~2jIbv|K1-6W#Lcu_x?-QeCO|ulnt($aYcfHKzSfga5=sRR6|nn#drQd2L2Cc zOPP>-<1LB(|L1E`{`o1TXC!6dSsEcBCHr@Z8n_^&?6%BH%0fwA+pqotnC9!4Bo#ku zf13Czng2cg^;;DGd-)q;ywZYyEAasL>FGrgjiFx)$1g;J>a)u5v^BLXIc*L7J?>bl ztSJ~ZjvJSDl1Y8gRwo*Z`wl${Q+47wtw-`FH8W4I&)EgdmqxyD@Ubb3yEEy|CY^V*# zzO0F25cz`Mu?-mCrU5uKJnbDp8T)-4OJ5dt^7G1YC!8+sA|ac?IVi_Av}^~ayZaGg zpDjN*oAJ}~nr@l_7r=!9K_%JtNnT$pAe$`On}?9UT9Q-vyOI3GzA~f%L>PGk{(=2d zoui}Wkmy!y6L=Mi8|%nn&v*!0C@h|v-^5C|Uvq*NR?o}G5)fnTIw;pz>;k=LV(+@I zjtWovtclfh!g?e0gyDGCb%Z_aUsN30wJI|@6qv1p!0O%w-Go@)%++*076_nv2Lgyj z4Se`oJX_8Vr~(%<>`=*z`0%QA=V2z+2%gJceFDdNa0vOWICZL2A3}~bJS05w)`x`a z)`nW9<8KfrAX^wf3&+f{o=r#21 z_GhPn?_EMp)!3XC-&o`6LC)5cqX}2#AM$+zr};n*au-XIiwe?2mLDc z`!dCs1@r7dlIWZQCR(GR2vfix9AHY_f?P%EZ-HA0BrwoH4#D{_zcI$X-BiZmQ4GF| zK_6lo=-x z2z-sA?1vlR4zgMS8)6~8q6>y1lr%0ULqNWs9j9VWC3I(y0haHVSGO;8SC3bs1fqx^ zX)N3c=ThiE>cqq1CYbF#%>Hm@k-Asej0uRr?%-P3tuQi{gFYzUD8Ufz$g^wVkdtBp zK_LlM;Dm+neVd5`qR!R)_3F0WyAYDh2^1;$V}0Jkl@JvOajSekUnLhT{Rh%o0MtvCZ z9CcnNeAb<;%53T%_kG=){YcIx`N{o^KcIJkP@(>SAKP;Vfdx}jj0s$$6npY#HrQtW z@+5yKr@9}7fc{X1;{b({9H4I1hf5LV0Kq@jW{ zVT+#vH^aZ^Ho&hp{`0@^eK>Qc1Nzrkn53LK0Ut}gbo}fEze0nr1|&834`1$rA4&oL z`5V&PtVts@_<8<@r`iJ_{wDa5d)W4KKr;<><|YHNfLpgF+xVd-Gv|f(T-~u_U>0Wo zXhrUSj&HUcM*@;Em``m1^wl z6Ct`6sezFcdCemA53GM3{WI<&CUvbHs%2^kxGO^CRWj^5u41^tu>Y+#Z>=1k!DFBY zj~DAGok=lVK;v=$D_%SnpQYKCd5p9ziV}Z7Hd5j!HBybAPf`h&sNLZi=K@nWVj{@!Ok4{&$LR2DT8$6rD4ti5K2rR1nG-dOCMGP(9 zQx&ca38mPO*RJ*;1_;4@x+V5q!;}s2#pY@WTp;I}D+vrf?MNWU@H`UO=cS-RgW_Wk zlUnS*9tR2JX4gsb=bwIPJNCov?4StX?F^OpXgv(aP+;m7#G(3R6Z9WNhJgq&ymNnZ z-OfxXk=MBJb<1|hZwRvB$$RvOzRb$24_bkh)9{G4qx0`~wXm$wp@FfZ#{T5K=q18w zXK4GA>#rY9BU0De%U^%0y6Rp1SmJhE+K(R#8hxB%LWmoM*9^9)d!6pV*joxc$0&ND zpBNAAgnkw91E{hSSqITLCcNwXS$Aa+Ax9yR3#cQ%sbl60<*Lu(=dcjUBxup0MB4Xl zG=hzn_OXd}5?@x%sE0M_Zkgkf?$A3O(xs-~w!Gja-G7P=>7v5`ktfp!4VFZJ2j0Bu zS%eq7SKG3Av1t#FcR%vt@sE&!F}ZR(D<906mBO61{%8o2nKr(qza?a3P{1^q-9apa z9{hqE-oz3Zj$9xmbr&pw9TfQcM@cV=0=^ISlA^|LVTT!Tq=0V<@gl>{JBc-s?XV6Y zhRoTUqZ)wSl299lNE&*&7GL=5Z>QYA(^T(d#)3(g0}?e;C7tY`VUy0`2@!|5Q7Q_d-#MxuTEPKj#u))o!BRmquW9d z%0s(W2CHwRskHC7*Tb(W;)|}ufxwwYd9HTc@zU%B%U%aJ%>oDoDW{f~c(hs`C54}O zu1|$CpTNOOQ_k0~i$px#$CT1c4vV1LNk6RG}|Rg%9= zjVFy(<4H{d?|elnOaFq0OXN8;))BP_Hjzt4)Req{tQWw$redp|Zk;g>^*wq|Nrill zjG>S{WH)Uv%r<;%m=AeZOC4Z<&55+^foc2K4O7g4QIsh{Id30BDW*WN*J3ZjKLLA& z-c-JT1tA8~Q%2|;NHnUXkH;KxSs8aVR-q3z3z0NSo|Z4M2+EhRgoo%piRG?kL4SR3 zk#MSl)fY#HaQuvJs8J&9f5H5a67%S%fs(lI@i)#>`!r7%f_D8B(0wX$jb>rP ztgKHXFbQW&gV*+AZ6Ka|$?G!cj8O^k+Ip@fp=*H^ zb}Cs5a6brRr~B9^hWsimWT99Lf~3CTX!gAi90*%gAEoX_T@Hw{J*2jPtpbQ=1%Yv` zr?V!>oxvU@&V;7f`A5>eb3`inUrPTf+qbmw;W30O!wr;b?VVs%0$TcSiQ>FSCIE8$ zdZ=a*D3IZKWch;kX-Dfky^$qd{k4x#XC%l;akO5X7sMOQAA7?o6cBrCKj3j5n3~T2 zo-{mN{6Tr4sgNA&_`fTNgT^E9KyB~u3(x+!Bm$+-=RM+d;CL{ndNj70L#hRR)AjyA zODCOyYhT|l24-CE|MyZ{=VZt=-t^<$-p~1F&}#pE42~dc#)HGzPv7_hOI!X1zo1(+ zPn`=3J@vR2=8yhfdmg*vMz*b-Ws4np9w7{%d#!@s%D;FCde>kfXcyp|=;aVJ1>eNM z@kRXmq?AJZJDO&ofQD!3wvJe$-Yi=Z>htsRw7i>ANea9sjs44< z_Savj(C^}}|CPGx3POy+rM>HL5F!&-ss494dzm&db$N>ajiskQDiR#Vy;KBWC?PJw z%GgS;I9MM~m#2G06JP_^9@W=tLlfmpf*W=Wge8DvVV+UkcZt5MpsEzYm&fG%_S$$) zAF#&|Bid0XX1pKPwdUg3G7$+YXX-tgv`^_JJS6RLvZ6u^6#ZJtSWqjJ|4A=t2M^Mu zMeK8^B4}@wae+h&{K*aXscw{viaj$A)V@!NU5dQzR`LeFE;*kNgYnH=Pg7<(LOiHi zr)*o5n=)7+5KC47i3hQ!=u2z)lwGXjqLLxNH7fIM7>2`O2Gu?r(o53+1_KK1x&283 zu~YQD#l5b^>R>d1c@(*23#Bj2p+yIGbnFjkRgeBWmO{6D#nP2wKICT}iI@s+w`JAf z<^&bfzNI(F!l>VCkdx>$sk9w?Z-1#tQ7FyO`a^It?3>mq3SqV{()}|9Mg-uT?b{Kp zwLG3G?>~`J>Bj3p?rFLWFbAlx4R&C5XWa%w9figM6{3lzYMWS@(#+)9zG0StVGO{led4kaA-JS=ckDgB- zr2ghHUy(1 zgipuGHL&MyW}HStiLrxE$Lel^59Kd3GaEBBtehWbYGnF)kcm!nkm*S{P~P`!0ML&6n`Cd0GTYX6N47V&`Ok7MOwBs-kWVa*!srEqz zOWLsyS7|{{mH#!0Owe}>Nr(?${LbWV*hlIYVOIyA-&u(8(KPXdthloiR zWsL4a#|vwZCML|z8P>{g3V$zUey1+|_?$L!lH55~kTA(!F#iYrK=K-thR^i_36z{n zh{>&(sEYv??9<35a@M4Olq)9#e{FIt=FY^lOBJ!meSlfV8} z`Yh-t)jKh?Iva(}O6xnzTRk^BhCuNI4S17?m`*1l=3T&hV5T}w4R}nVmvn#wtfZvX zHSo&_c##7*44@v+cam1RmEFr~(O7hxlhXic;5$gK0LlUB8Yfr9k}7WfY?%@);XnEh zLt`{rPU1q?WHbZN+Si>(Ss9PsqfSObRqmwa4+m{z%E213Z){UF37@zNI%GfUhYZG4 z=0}NPiu}p)f_CgncVP@E=$Q=&Z`&dT>RJyqqgx^vDK;j%jg6s0onjo`gW;J{uMN)= zdf^dWz#?}b&bWZa@N|7R2=bdgb5OoEJe||qm@d`m$&EcSHU_YFt*%dgeim&{RX0#; zt805mu_Ss;n$WKQvr5TAVK}DMHV;&?Z_;Ps7Ld;&xENR=`tUPu7Yd;jBcyyH`4-^f zDP4?jvBDzog%R~Q~ES;OMF9iM=?e9g)gX99# z(O?%4iz0FH2aic(=dta8^{j(Lakb zL$F(3zYg3K73OJ$UJ{heO2XlG_FIG9lB$gQ4?r$Q`DX=Tx#lWu|2?&A4ip72m!PlV z&L>+`q?@@V-mmy+5O^yNeT_i_bq*0}Uz1F#d#5*!Sc3^@W-TT^3!Ao1YSnbp`@#rI zK!9xfng(U<#Sj*?{5hWU!8~CkgxYknfT*QWaZw&Isdl3Ij!uK`dELoW&>yTE#1<`I z#c;QisSw_~-s1T4(swdL`itaSz8t+6twuIULWP4>r5!z$!g|poc3jZj?Ns_{P^(k# zYS}5ViB;j~Bv}%tjC|r>uqKcoOk6lx3ym0Rj3_nAm>MXqq+yxAQKeP27{zfU9X5lX z^^m|f^a=4eFsbbsJ>^p*qnr_vY8GdeYxA5bOJSte0hnxBfo=4D^%u~7ef1flKW1)U z3QHZ)R|mw0o6z_8|sSLfK}p55_|#O%&W8gkYL#MoBgHhE6a8|HTY6 zWyj55*B;1x_fF(V-466WYsPaNFXoy0h1bcLU+q|Vy==uHQ;^{YsUU3#jgB?Qsl4n z?DX>2y`RV*SYl7tt;-G!H@FMTIL{OlyndCkvTWjTSyfh&mlXyVD~XIC@z}905}zO4 zE)w=CpEgcc_Efm22}l~3-xRsHK;)Aw(;Xwzo4a%R>KeyOvmE|W@|cEz1Ex^j(C3s- zQk7BN>Se1$Q8$?|zbX^}WkK4U*M1*F@vdrE!v6ROHe_FS2qb46OkIk+9I5mxm>ORu zdq|J6X0L~Y2AGudMwQvxeZtDpwl6!Gmy6rHv~o&s*XE=Oi(g0v;Vbdm*r#Oy<-^29bMbZkvzZi{1Meru zZclZatE)$ZV>GuW0;0*J#pSqaGl79CmS@koyJbJ;W(RRRE?%W{ZKmrprr8a*ly!z^ zuvY*{r0y!VCe6q1RkqwT)i;0tda?pus@I&O_=5rpfx}IczJYbieY`tq$AMN@Cf=9r8r8;~l`OUmNlC`1jzKUSD~f@~0Jsdf}X_+A0 z8@|P`C(Tv5D8zw$wQ?UilLW?~C+M5qRTwcRzm~t?fXI`YVF7tk-7pAQV4qG04=fkF z{Po9EcpZ5nFY5LnpF^)4RjBoG6~Z&tT7xCb(vTJ)I(_jo!tu)>aU3GYx`_}El)wRE z3Z1feEn`q_YDQoppx6lGL5La%<3#}5hSdZUf(0?-6)Kj_S!4)?%`Tj(G`fhiTPI*? zE}CVKP$?1nSYIfdk$G8~xlm2V;Id5H-a?8*>FVgbK)KEde9uAVX4IVMCl=A<7pTAP z0nwI;A!Fdwk<$krG1UAXYK{)#KGSU%;G!T15Mh7H9R(0p z1i{e)1nap2F}npzr25H^uN!_^*1_0UOa15`RC~;N+&e+BsZgG^Op~9)Wa-CzZ*G@r zo|m88#r#2gXjEvG)Tmv&2W0v}dsHd(;fA(t^AQz7pSMKPXBy$HOcCBf?%@-AhdVr= z=>kl;tDZof;^Xx+))zuW`u*|N<6x|}R1f1Dslk3tFByV8j(`*Rb{xU3B4Y~7tV{_Y z$D14nw1(~pt>@pKI~J(YdR{$LDS}ZRK#MoY$q~y}ezDRH<-|&8Y58UhaJ2*6O)^`L zoSI%cuE`PY*s&YLT|c$hb9piJ?|3ngTxc?XvE{xOHhtrQR5wI7m)qG@=A@@ zsFT=mUe-yS@K&Mt+4j^MopaEmFa!FtV`T*%DrI3cE7u%~VP@v4y@8m%>a>o{?PRra z4WgbR%KB7uw6tcLH!Vl_8mC!*{U}N#if&>R6hr9(QKvj`zN6_e=+NQ9jlvOzn=64b z?4$MYZ2?8Ih9VoJx?LQO45QsF>uxF`T0@8&(YSs=(sBnut4 zeTR^AwEw^a=)mnwJc%&HZu}1R;ygECarIZ?m2(+&q}xy6LDsL8_CpbQjUk{Crv-8) zWx$}>0*ihQ*qV4Be_3^Odd~oC&#?a^ZEC1r9^%+4(qV{>o(@}(n0Kn2s+~l{3)Lh= z1UJ$SSOZ!bDH40vK}8uLgCxDxJ`6rP6dtnNxU6)sN39|Fl36hwxQ zvTt_yf&gos5?+y8cOYP*xaE{dh8xEUZKUs}G@_ykRs>%vcgh1w?h072upbMeF~AOk zY?nN!T3zW!;ej-SdSazrDT=U*=lgK*g?}F4T`nxd96B`CIXdO?x-1&mL7Hyn z=eecEgLE6Wa^6q#6m$=P?7++MYSEZ|EjIX3;)Fh?VXYKMYNuBeTQ~#GL?t~~elpne ziFwIs$5Kp6oa_vXxIO{o*y9t3G6|kA)fopX4vOTtbX@9oliYoou&tnpw|rBZNe%iH zE|Pd(lsKK>S-vaNysz7Ph=0aVe4i*}C3SndOy+?Co%{_!K0HD_%$Xd-!><1NF1)vL zhf7VVOz$R4&x`sJhp1vlrYp9mBYaB8FBx5!_?TC9dkz)ZJH%gKZ{B!hZ!(tD?ai7z z2!EB#9g?nIBXj>6G|U4c|F1u;*^cQovK%~EW>ZkAVJ`-kMJ@7L7#foTM`eQ4rC}Ks#4VUT}gB7&`f|~#Hyyx6y zW^QJnw*P#Tx%Zy!-QV}T=iGCB!0ZhwJ9cZ}%LSE)uk}8l@+dp8LvKG5gvv|VPu0#8 zT*W(IFtd~qk1&UTIZTXm82^4&&tAnd>=hUV+xPfICaNTd5FGS`taZ8W9Q<3@gafJ& z*v-Ik9(-X>yeCproD6^)&J6hgyh0`Zoa460Mp)?dbJFyRL{#*%YZLZppex+s#pm5c zO$+1}`)=CrR{e<6@sL)3wk!)j*$na@;P-NEHhx{3hR7COY}D1ec=s8>qNeAZ98}nOI1%iK?cBP7OR0GXW810!bnzR4JD(89hh?zE)Q!E1SGR)P@73RI|Kh zDt5(LGoa5z>?#2n;3>C`?w|()7`1%c2}Kf~feIF+wr07S_dXCk)MH@=zOM%23p91C z-OOS^x$$2bA?OmFJkS6_sN`axZh7RJqfF#MY;4O=@4CCyefSFU8pA;3Wjf#?|NDOe z`R*R_+4<_d$N!_e_&@w##ecsSba!wn9>4b$|M&9YpVa(EzvCgMkax&x73ULL-k}HL z2AL+tRaA{Ot7#(nwQ>dz)Z499C$-oGL>RH78fg4UjADZcm9V#C$u-u{as>y07pKeZygjs0fcZ$_ejOI3a?+x9|?l1Me^Pk-ifab##cO0)a_% ze%JuK_|%FVx1@6_uiCY5P~Z9vsLZ#hv;5H$`v~u|j|Ibv_e^hiK)+`?>3eygKVaXW z|1>ggsqXQw0G5BvFn#U6SC768td8@^4rM4qe)g3gmn;sF9}GVLZ`|TwGlYmt3{y9F zWu*SleZxrY+}asGWCv-$ej&&N$II5wEkW=iFFED=`GEe>&V3Rh{R(EG^kWqf zVikQdpzivU1243g2|X~W&edX(7&!*mCoQZ3pT}Iv?+xrQl#)x4mrW$Ts`w9z~_|C7|aa#AJO#QYxpNXp9v5)FPWXI0IW!zV(V;^@&0^9&o5ZG=&_wv z03S;8_8q0v8$fBWLFpUfGxU`}e6E=JpW^e}=eomk*P+2di!U=FS~iOg%Yo1GedNza zzj5$^gh0BOck^>fa|Q8bi8`uH<7iyjKJZNaTMx1iVtDfF;8_ej%iz~ajUVh3BT^@x zhT3TRC6-h4M+7IT2Fg3eChHW-MosmYuCbB;#1KFtW*)_y;KGnAo1}s#iM*Q3(lWKn z;3qt+AQ54Y9QHZcPP4DY3ntHd4Jh{UG)*g92EO~s&+y*!bJ?x`DL+d-+h>0MWXpet zpO=_-mJPeIL{%MUr1YEcv+O_O=Pj@91wZ8ja#`o+*ZAhQkma=btsufL2XG^4(*Pq~ z5+ra<2~voe8KOGQ)@b-4U}Z4nI3El;p}w-5c|8h6b4z>ys|YHmmn+X_wQ2_H>u?^o zo&$>3U|!ZfTiv%AxDBGLX2|CsB_p2segvR!w;@1Be0yjB(v^OY;v7{_<^?p)touQI z;STgd=0#>ASVjb)Ub3!b{24~Nb2DuMwi9Bc!KEE?iYoWz<2yxCAZcM%=X&OZMp@6i zjJ;Io^-Nh3b+`PagWJh8xn3x)52R{Y-79;VZ249^F${D16U}SbalFw4rZoV<#vhrD zNypUomyHFd5G+7|8IYdY$V#JlZ7v9D!$MnpNOe$ zV6#=A{Vw(XCh%_#6w%z6Zo3!Wm(RSx<_pH^2*XgmvS2!~=}drdL9aB2{fB zNPyOx*ZV^bw9y`3uaxV|gA;zRN7#1VV=eIzV-C3>Mh(Buc2=w_LIeCUWZ9; zcSbph2#)w6%J#5NybN+}B)O2FBMdlY<2s~)cJ*xP2APZ&^6{oApUQPZ7c23L<@E_UVkHdJNn0mj;F$;G1!6Gj2iBbuX#)FP6JW=9EcAMw> zabIYE3=qdd!+;ZV|Dl}|zFRP)a1z#N_^<`%n>2;gew#k(SQ&Z^MTP3ZTef$o^FG|& zp(b3qt3y5ci|z#=I1L_=+CyTf`_Tj7%nWYfL9r_W!Y z6{|9d_rpZE^rHcn57S(nohJz9&{h*dr<8{%^e%&faIJz}AO5IYk zUV@x_C~^|W@5uB&X3@v_qEOhfryx#nKPN;p1(R?B1rAmbfPhbDlxWN#C5(0dAW34lORRS2|32X}5RMN^WZl&cJ@t`(h&TwG?naUh{Y!gC`%JZRBkeZ z1F@w3`g(FQ-evzf(%KE-=%6*+-TgU+Msy5gJQi5tD|yKqO03EkBCQKipsV~|s*EZ_ zl^CkvcXG_C+|zg|iyJRMU{#K9@s(S!yJzDDgVo|?;#Zqa#0~JMh4ZByMqL=qQP9O& ze7W3MX52aRD46Ge;s4F}{~!4O9UYC)b>O`#5V{f3*qHP9_8K7J5y#8?1y2KBits9Y$Be23YyFhXu@yHsr}c16Fi_K!yZq%Z14OZ z!z;BBDyR7j$spcPFrmLwfZW#gemj}Ri$=6Ot zntac>p!f*0)knxTKF=mh>Q6{0`P!EW4M5m(O;~^XyMo%UDsZ)y0wlP;gSe0Q$$ zDEdd9GPu1f->H@FI0ES(-z|5AB6Z2TPQ?Ix-1?~zcwI|Z2<$I)N}lp7{+YY|m^|ep zzFE14??4-|(H>Eqd*hHYj|AD}W0AGURX*yN9ObZ&y~{c)_wYI7Rfi4!@!fJ>2x6%PZbbu9 zVExow9AcM?KhyJ+FMcg|`}^{g&;5qwBRu;WY#+yBr+sGFk(!TIJ~QCAj{^egYx|gV zr}jdyKze%g{|M*Zd%}RLJoVrBXm9GLCb>r1-=DUR-QBr82lkf-$cLR)ne`pf@e#&v zAH&$#pGC-5w!2WXeJ=aB9{c69+VA`%t$mEfsT2EX2efzX;|Z?YAnNj$51*mI{WTMW z)Mc68Bb%O?_QUfOW_;g#FM$3NcDR`5sGsWQI*>qqrsn1;@9#Q};P%1u5s!9YYD_3H zHPd7G`_uMuH`28l7yg@Fe%g__%Lm}4s7~9%KJMd{o+o`Gw_?5%f1=?|8@@jMZW8_KDo;W^vzLD{ZA`TUr*S} z^_?QvGWF@Nob?K`zJsMDXCbiLKwTE)Is#T@+-(gD7Uo*tk?$p!`}Z@+2EDYk9cMWQ z4;%3R4N}JI-43 zT=`3fRvGlT>ycdah)g%{SCo+^F)l60iXcdowdbUqJh=*6teow1^%T`|>=wbQCDsqI zWu%;2Mn>bwiMTltH->IL24SNi;Kz;$8|#}`Db#B~^j+#((zk5F!u}@X z$UW{BsFLcx062Iq)zefkPzYgDna`1IR zy-woqa6o%E{(dCWo9D;pS!{&Q#0UK~Lt_h4Z)JM>^mx)GBQIjoqE9}5E&Ap*OntOh z^;6T^9RdaNGj)hN%?mESFHiX??zAtneTM)2%B|?|%QwH!{`ZDnIs7O5?^DIO%O5-> zM>+iO4S3tx433|D^}p)3Z{_wkaqv-%nc0cI8Ti0|)!%%LEl2+Yez^t8@03nwzJ5<(k~>7w0Lz?;DnnaouVs{^m+- z@Xs_WsfB3OiN855puYAuzkS6)RVbQ={$II?vRw4{*&laemaBeh`s)r5{_(ZH>HUUN z#xDHjF2B9;?nW#twhJrw@Y8EJA+Z`CzusYtx=LdwzUI2lv-Z5K>pWZryMro1Pi=ctM)8&rkoUS^nNQ%4sjiN zAU{+09~H@6ep)m~Is8rcp8oQE_BY>o zHMhSZ=hgddo%ow)|M*|^H@B_&pZFWW;Y8^>zrXqL5BdGg;w6qv@$=J_PuFOqMlW?L z8jT68pE_lkQ!Ti>f1dI&%X7CMk*EBWZ&?1m>sCAQH@mTMKFiF-;YB;~H){jxYk%{d z7adfEqJi}C=)ZUQORxS^H&L0BUxx(d8@0cA&@E#ZdEgtE?mhF{=LOi|o<+#(HoG(- zD!Kg4grN4fd#hk3d!AY|Jdj_h``l{5<)`G?AF(n|`54#XXZD|gU!P2m?ys-?&7JPvyG;4hrC;n#iy#K1d>AUoQ;%@|p zWlPw1et&brZ}a<`5l=Y^?&k-^IAebEhFj6FD6oEN<($ljiecXvxF8X`*!*1d-SN+s| zZZ-e-+TWb!<|f&NzdS%bo=vOF`j8=QV}j>5Lsth7a(}$*?7*AH-+YCrD~l1wxXX`u z=Qqy=w0Hf@Wo}y4K$9Pz3Bmm_LM%wl%Jlx(^vtlw>(iWle)`{)eH-7zJ^*0Yc^}q2q#Nj;YJHNl_4wUk(-)wr!QE)#$0_@3z zMNUOB7k`2EQ)3=?ss)#i$WuOPaqjk4WE{xEp`ruXsyGgpUJo%ov%mu1)2 z{^pz&4yv8g(>2gVw{ z>k*M<`HS1vxin$>T=N?{sQnYqrL~XI*po2<`%6a$w0Hf@$L_MGpAj2MClI6cM>Sx4*1Jh^Ao$xEQ(ybQA&(s*#;Rlz$pQn71>+mz%XW%z9 z)1&+AYk%|9ZkL%E@~6vp@5x>M;g>ne;cuS$%3r?E{^qs6=kYf<8bQsywiACdVb*`u z-<+}Nf8%e6!#j`d-Tdax+w%LHD;793_w$>&o*~a)xfPAZ1lCWz|8UO!Qk(LWcUzdd z{fcrpN5Kv$Ho7bLoP!Wm-($h8CsiE$~D;NE} z`UBm>Wv=?Em2Nfv_}br$b#s&K!e1UBA8({pX8k<==8~ra2zkukU7E0cE`QS}sQq_W zrnS%IZ{9%E7T_Od&_$(g&h+m2@v(#ZYnJ{V$@Ko&^vtlwAEi0_{Pce|%ijn2r_>nN zp$GCa^?si6Nv=Z=Zr{yy)S2ZO_^o#Kvudn^dsDHc63@rco=ef&o*pZ_g{$`ZB zH<{z_v%k49q+N-dPs5%(|NgWha9;Hv--*BZYDO-9GwFuFvl#GoF6<7&t}-0Jki_X2 zJSC&Cznr3hlQGO;44s^eVd29|dgGZs+F~5eVc4}mdlK3EW;X6UrhWv_QWG-IU-0uM zbwqfVlZPPf_?K4xNS^YydgN|@b)NRW&(r>dJnb*b)BfY^@_m&Lv5`or;`?q_Ix>*G zpL5gxju2(+UwmVFPWfmIkdMe>Egq4@y({E&4xU$6i)Yv3|H;_S`B~6*PM%noe&ET* z13NjLLsvz5R; zOKyWygS(IdJURuUjW2ziRp_>wvX)hRn<&+)Hc+KaT}Jeg8|5fg2r)r4Pdd{D=7 z{Nj8+f{HT%hY6I@`INh1u4)Rs6QX!q;N7Zk0qE4|Onvg;&-hZK?-VYal5={~epaHN zSQeYd)(FkES`2l^gJvx_|4+z~ZoeYaf3E3aksfifO*>wL0VjH11ea<_uag2+%oSxijCR z1oyq~)j2||p4g+!Nds9`OC)O?z}o*~XU#`|0^slPjznue1~X z65u*fYyq8DFoxmF2M-4%NGqy89Ei3cv@j+{o|IDo!59)6RT@YesGaj6ONU>JGCvA) zYcnAIk*HyY{+aJ10HE=Z8Q2R5j+|YrjY7TFEIg920G~Nj8%81Y*OLe-mao-?#1cgS z%_x~b8YiSMMHz?LL#DOj&NH8LTvR$=I^gInD{7akS8fKpncu6hTTAgKYKL|DuxMm@ zLwAfgZCfokWhEYh9mcP1e(@Q{I(beUW|r2=HRYhZjrJ1&6HMSj$CIG-a8EP5v{l!D zRis5kwHUz{aCP+yNN^k}yY&cGse|Pxjz&Bh)VA&SeQ9R=x zG~g%mV`xi+9pq^daig)PNd*1am|&Nvf3BiRm?z0NhMy_j@uQ;+Qj0Xf&17=}c${Oe zMIOOmk`MA2e@JKUX3mQ29IBG=0RjSctgE%&*kBmuPk!nJH&_>fi z9N+r9>uQ=rwMy2{M3BFLU_&4j*JT%jCTbMxm*Boi>dc;FdwUn$_OzbbFQ?2 zU+S0V>l)yVw8BC40;Z-=L0>Ik zwrMJ)g0YOUj(YqFZDJu2qBGtXo!JN4cil+?3#QQM%9o|l5yv9UJ*&&&7$7N7C)s<1 zK%fn63ZNnS{Nr^e;x*HV7d{6|bh0F4reW$#{c&Ijy_RqDePVQchaN*qn{#c4?|q2q z!&ca)sc5x}{^G?NeUDe{$MxQJXp4Mi)u7*-Wk6ro2}XbL%>M!UiwydMVJ8+D)Nw?g z`XH)qRucZ>i}hw6t78g30R+|mO$+yYS`BM??zsOdld?{lki>6B0kD_TO=yjDehHcHnN z>kLN9m$&HL#H4|vYS{Px`v&E|qn3_bF4CVWM@+5N@)`MLd9@wt{{REnuBFvbKLvtI zAnP&o)W_1L!Jw_qoSKHQ$Td6`h>7Vh!dvYf=yCB>OETpiCR&UbLN7JWSm8JcY0(x{ zFd|^S(9qaKU;Lm!hdlLc>}GSXv1u*c%6pLPe*E%}*9-L}#V&roBk<-k@9AQDF3tj{ zju|Zl6zqp$%RbQl$8yB25!+t!%=<2Okd1xe*8jfP!iATJHq8`6PVmY^tNIjPPZt2n z+w)8nQr^|dYjIS#A3cYOHJe*( z(Q&#Cj#Ed_?%)l$Fdx7C6YeHn-G@%3?BsY1^gNDbPpQKmTjr0OY$bV&xqNu^Fns+y(s~VQ4BFw$-m1~KnP6eADe?)R&4d%ZNJ-_U zi2WL>R430Vs!kqUjUYm_L;Z-MDDV`M9Azvg^-<1iO*096CD@dD1~3pXrds~3btg`l zHvtN?q(aB^ZA+R?s768ENc$p8e5*@qM%vdP8RGQt!pOu1HUxq|PJaahWDfMM3Fp)H z&Ntc@>A(PUU7QcUqG35TU$Rx|s_R{ab|w`wwHt*i*C-(b05x=gZlvF@Ww?G4<@{qR zMGxQ+2XU&DI0TxbdqXSg8voLCwv*mMzw1A|AayV&i9IGlW?u0oiJrXJRXE&KCNt|P z71OqfP$VAGcwjOk_<*7sA|!$B;=cFLLV$zNnj(P)mMW@l-Qt_V$4GK8-OR3%6Cq%Y zkoM&1!v`(lyuX$*)J#;+I8Nz44+AVFkx`xK0a1d8s6$N%5M{jv@>NV^ z4M&Pw$aiR=sQfH4E5Uw|U_+NvKwSg}7@-kbi3AA7I}}*-I1~wx)`N5cWGIyQ&}wjx z0F7)}3Sol4Fm2*t0O+d|FL2m6M}$fNTKU|K1rP~Sky`X2tp`VwIVT{fZ@=HNhi;QN zUh?$zqMRgI+_1kU-%e85Q$KzX1li|vJ_ z5N=IdK_)I&hg<`$_XPhl^K(zLRlxV~c-}J4*RRFrF*Y_%(Rhh=@^yPVy!@vA7>#si z%mE%1s1x7OL0cIKQ|^8`%PziM>asCyE9;U(!m*e-{80T>DborCuq%?s84ulV!8bYC zss@c9>5vtiH#`k$$J9MsrRO1Jo^5Hi)11Jx_)l>YW5~|ptq8weNw&%rf(p8<{w^8%2 zjQ%S|{}sdcVrK5|eJ>^k0+sQ5F)v-s@5MBrs8HQ{$d?`JmfwI)eOmF+nA$z~=iMWK zo*jB_Rt$_rLhrFRw0j53!mr%W2M-<9t;A*)YFiYamw>W~adC1Dct$QK!Yj&#Bm4Kg z?(Roop2mZfq3zwwM`AQw==*Lw_xir;eSD{2vzk7E`WV1ZncTE&gS8qD0RX-Yl)XAo zL3mRy7j|g+FEkc(aLp{E&0)?&v>t*89hE!>EU!A?NiL+AIIWIiYRndFsl`;mO!i=h z9$jK`op-$MkOtiv0Z)#MnL*HqCcooF(x^gcdF$B+!pM5Aow^R&7o+h4>&&O@V5G!# zz(~y(m>oa6$QUhR+p=PEkjC4ggWL87Wf%{ldYjam=4K!azD1F4#y zL2A}{zMD2L!`}UXo-x1ttTb9ccr{Oq{Ak9c%g-82PhDcxQ+_Ps0!f0mrTnbX^7G=b z(gG2O+AV4FvkJu&u*pT)$8W#+8)y52BfDH&cINa}G#PG(Mj^p|4xcu&A7t3UH;8a& z5}CB>pt-dq@cq(YW~O{4$SJ2g=(Fnfu71BlPH|Co^wS==K zvKVY{-ALgBz;4tlD&j>0@|TM z$WYC!0s?sBv}39ZVBxKS97$h%SkLb}z3@SsO&HP!fLB1jYRV9BL7=%{=sr^){uGGf z3`-qSc=}~mmG08<@n=k>Pur#y{h`uk_Gz165LXn6v#Z-#PnPn|f%Y@Zf7mLrBQhFvQa)h(Ga%sfwini6s?wqDIR431q6}g&f zd{Ki7aGQys~>YAkV6ghM(NYZD0LX6{SG#KQ>~DOtcZ2^ zqT|$$Pu~~3!3Hc3RD&?JBUi0pjFrMc+SuH8^7!Lp5TU`aUnjpUrQ2^BH z+|wMA;1S=HJ97qY@oCQE)D)tOGMZ!&dv&P^+Uiq>iuM~DCwq~q5t;RD?%i`7 zo7<`vX5d_Ux+7uNP3mG`8d=;b(^*88r*YKH0-;&D0q0D-Y?c5(LrCb%Qk~j|+f&#| z+tL02TPo9XD}UXVcIcfZ|5OY4vjTPaLwa&jM*eWAvneDi>HcQ@uJ$*h^-xXgeUo$3 z4CmB?%ajE!rX&w=^T^_|mJt?o51`G$7=U+FYK8zRYcM9isLdfD`kZ6BVTgd6*)jm* ze|}#pbq-CMN6q5!RU`}RQtN~)H(^hdgtn5)?JYJ?h@qp=6ka6&Y({>kt)MtBS8FbV z@OL$lkQX0FzTqQ+kgorbQVZWV*77ThzRu){Q_sT%Ge=mm?Lzf%t>ZCm7r=CMW|TqJ z2s}+de9@0&>b$d#Dqm+JL6%fUuQf(jBnV{u51}YgeZM6B#xB(Is*DA7zHsU3OF<26 zaWzKKqlaBpI$IlqiP{)!7xp})r5(mVOTAg?73Q|OI|7Q-!9UhR$1Fex!$rPPszjx! zOlsKWx`t5&)F{cQG3y6T9~x+Og!W<=Cc8GqF23$tj>yh2>(JQQs>N1TXSkwx@Hv`x z00qnK&^>;2?n(#*?FaQCdva4~8#7{uPd>`e8QYO|qVd$l?byXLXbm@aA>yIhhIB>!z(BN3lr)ODGIO)RLFo zZY3)Uz}j!cYS}JZua;5yfQBPoggmC!{hhgDZ00lRPUI9u+LIBa31k#;%$6HcI0Q$m z#4f>`mca0_h*x#et3rwg_8)?q`Y8lb#l}H2f0jOF@#ItVwHFa=*#?OikC6~?*U&gj zMn4i3H1h&~?6i&_p-X^z$8OjuN}(SB8+=v1h?VT{`zIa;dNGP=z2u_~F2UVxT7$qE z=muTB!c2i6kY)-4@uo!wDNvVrY+Rx81z;=+%2}@hDfe}e7>1yEJG`Fek98RKWYF&|qSvww zAdUybpdY|CbG34pF$BAp4{Wg12etqkRgZl)OTQXxLDD^aiLYbR&^f3hu9WF;T$QNb zv^Z$uYq_GG+!~4^sJIReW|)aKrw>5aT23Hq9FBnb5+=A}wAsuoOC$nSuU#?mKsbyfJ8?@Qs>Bk&bfGHB%qifIzvRlM30R*2up+D&6csq$5X5ZxQ zAO!lU%Yc&lvKGkUiwh2)Gx+;5O?O5-&AzboTtCn{VcC zg1X=sB&thW8B57mPzN+LCLfUs=C-nknY3W7YT~V3ND8W42|Kb!#e{pR*I2D@8>rCe z2z}s1glS)_My*Ke3G&oLifAAAk8Y7{HK+$1Ky>G#&bg?U3p+e0;q1Agc7n9N#p2=S zu;iEq9Ya98$U%ICdWKm=7pR2!7$(Y2)j?U!>e#Fv&Du{tM$?HrJsOoQI8^CW$1h-v zz^gZW{JLJRoI{Lc@ntV~6u|dCpdoe&PpZwz?wio}xAzAoGvcfg%XBD1!828oi^^ z`cV6gf#4sM?i|wWn-{-~%@x0d&O2Z@c+*)7@D+BP%lln+_*{uH97|^VV}Qlylbq%W zCL1?`ABxgGZrRuToXMLe~+Qs%IUT;-X}D*LJ|Wrs;S- zsk0KGgdOhHk7F6)srxQr>L4Qyu}LyYt1;w7>V)-rfco}ly|%saFon-FbRaUhw9Sc3 z5Wi^m2}I$O8JP@v*0+jXPHw;gaU*)7c;#VO{VA>?oEw{tvJ#5?hTV(so5zC#GMh$gsz+lZ9#Tm#{&tbY)ep zjHQoT!xR1O7`gTy<~M4=99YMwSgYU z|3SH{lEpv$n31IHw(rqpR08j>fm#k9a7`Z12J%dRiHnbbQZCV5nH@Rw0h!k4yHwT z&X;MpxKg=pVlPpEWOZ+RAb53T-V%Hfw|u#Jv_?kgjuE`?;bzd+*7S{g{#?I9WRWFh zl!0<0QDaqZn2P+^MHmyWAPfeMoaADB$SZ>|xbS+?p+vQB-t9~=n|iTrIh+v(nELX@0ab@90%$QYL(8Ss9t{j(2V`YdToeh3l|o>~Y4cmZ^{w=j39y(L_wkm^I9DzLH6d^gfTm0KZF($H7Xn^B7fy*6 zfJp02>MgsvM{fPQP#k>d{JLS*&gBf<8;`XTR1onpoO2x!W|jppUd#5v^ie@2 zZi#S#XxY`J2^gleJ`zcMLQ#S=Mr00!zz=rIuKlmWD!{H#<7)idt#MgK>z0wZTNgDw z-~Jq0_Ke)BC;hv6OnL_Q;U>IfmIlXRSh)W*5(OZU3)fr`IesZVA|Cnek|USSNZ;qs zvg@G671CpytjMPKvV4RC4;98DGf60QprJL$OlBtOaT8QRG8tTrs#je)NK4d!2mnG{ z)aWpV+Rxrf)YQwq*3z0zEt1?4YCafIFr;u&cgl~R4`BbmufEUy1A|dis4hIPJI*(_9J>bkyoP_&{X09<cW$>--;!}+fwv}k+zA5;NfRJDi{t& zAFBLOf7~%IgT@s);tvgSdQOH{vYP0TEmOyIHLo}m-P@tUi~XG-f?&_vdODUOJS}G@ zpPeC{lwa!a1j}6P?ps)18bP>xaak)5q)N zFF89Y)twv_1j**8OOpvXJ9%rU(B$fgen`k<(BxNMCuKQ1xl?!2{xg3k`|D1==XLV# z*STo&1Kr7YFYC>Z5A!H6{x3bCynntQOJa1Nz7tK3zJSKim14A7md{;I0Ld(F1X z)KQ2RtE5NR!DR6RDAsn)F1{v;nYexUS=vk67w|P-dcLCpB@HNiviDAHmnn+@+nwF= z!*<^ZE^Ma@Y)zAaTtymO{ic2oa8*lh0@q<4T)pC!-RBq62;1P77&p)>zXY31*b=7) zz}9cdUsTO!9WYtb-WgFK5tvDB*x@B#5@F*5)PQA(cbjNl?eOo?N}?>mff+2Bl2)=~ zDN6WKAxdsYD|wwIHz0YXmRT^s_U;S=oMC^Hl-rDW)%Rv`+7@K4WE)IC)O$1MVSI*$FvYxzkNs<+dGN^m^kXyEuW zNRxVeIB<;NDhUcm#PZ z*!QT0V%+wm7yhKvcM{_3ZLrAWY1jAyICVH&|w5T+LlqlpjIT$(1(OXA%U|7i{VraZ^M2aQ}B9R^6+ zZ#6VZ8$UArMJ<1E!cajNDm+KhFJd>d*zSSe7%L~otp&jvNs}qh2~&sQgVti`g+ zejKvgs(hN9tulU}JSZpZ7Iuae0s+V?0_Odq70a4%tb>^r zk_4dou6|RRGp0J3p*VYzPTK!zB|fndFSWm+jyW5&|CZ1`1K)cB?3>swX3nEHi69hd zl^g@mP#ccaYt67*CZz${l;LD~XDqU_uQeUYLU=oqTm{*+`LPm*m#V7@+^w{n)FEpN zg2IN&439R%4z<>3UGwcEFG{5)UWE2!JuVQ)%Ni2fq8Hsr`lO|IF1SaaKwYyUZQn6k z*QfBxnQxkbw328)1&QthlZ66xCH8-D1{1^7_Zo7mL2C@D)3p(k2GA?@It7q02`YBD zWDK!z`Vr%Bl-Ey_X>}i4VW7zx(ALssUf_??YRJX`+wW9A9tIYkX^duP`W>0RRr9lf z@>@^&ttWhw0dWbk)g&MR$}fhK}*lI(I;p~a>^xB~kPBT-IRf5#!d7J8ttSOC4B5w)i$tUxJGTPTe8bLWG;5 z$lh{536=(C7Zel#j2IL3%H*Ua76|E;?v^|b#DMH6Lok|=*(un}(MwH!*#Fb{j5R>OhkI|IAfY3GFv7m#Fl5M$zG@lp7Z6*yIUCS+khEejd? zycHd$+fa@Q`(l-mCb!K&xw`)XE?Ck+CC@D*s3q2ukImWCUmbXSPiyCg*3#X*i6UTs z(^|UcOzYS!Rua6ihxF!KQ~$TIVC|i!TgPq!wTlWrr2&ji+s$WF`i-=!N(!efD>&sR zD`*BP(082TWqIbeZR6B1t976n+HgnFu6FF*32(%r7|!vKrLjIQ^9S@ZJy51R173Ru z@z<`z!{2T#Z6H}?ztJ{Ce%NoM*Q+1W+X!s)3ufu{Yf+4udJ!AMY3;{G@`}rAk=9!< z#j=ujEFnR$<*@C|Znyx;Hsb;R5TKWrh5+O|z0n8DCtKyQ>=2k|b~A{eTwK8(S`TLr zMs%W9auUR%k)paI(sm^*1oeQ1N=7>e51?ojxNqALkIY#WZ|#V*b|7@6ki)z>rUpAZ zWp|SnI4});#`t=k-WG$`hSV2=38ermsVCzrNLr})9J7Fb9$J`<4N%Q_rblNd2?SY; z9<>j0N=-E4;qFX`v|Ucfp_>{5Xx}+_fP2AU4PuAZHH`qERlmXvI@X|^f23)xbDcCS znzn+RTaMYrb3fza09M%#en^Kr&@H|Hs1>_i-`uPxezMINh}BzqH+Tai8xnI-+)C6I zCHp+VYOgh2XC-QIRLldov+UXu*%1e7*5EN>hT>`ej$^2ER@<-B^Qdf6GchH*_~p2(?a1oGntUaSsLq4UKhE4`x z6TcUGw2TvP>e4U~8dID~$J^{bU@XebjUQJja3*RyN7*uEPTb_-J zq_e7=9VHmr;Ym`1%v&ulLTgLjzCIHx*-MUozSqDW!3z@SbcZSY8t9 zAXSbuh}L-2RZlL&w6KCoykyXh6pq@58fP@<_<|3OD{)x+5=QLtNk5Eeqy#`~6>=^_ zN>oK3Ex|E|h<#SRL?T{O0i$=ACSb;RjT}!RI0ASm0BnDa!>DI21v+-<@r^MVR?WN5 zryY!$s2!E~O@@DnL7*K&p&bYOOlyZKPI2uiSf>KE0nE5T>0EYnV8e zfoaYqLMQu0L#M`jeRR6Rz%)=`s`Oy`dRP#hX8d)p>GZ60K$tE!FmbH*hgH?dh>1Sl zk&%7N%CBr-1d+af2ecM=sqJ^87-nQX`b0o9XBn07rxJ9SxAT*C(z=WOqW9gqwso<2bVgTWaGcw+LS1aE15dxWnaKGmalB4`k)~~|g zKxb8)b3~vRzHvVj@Eql@SA&vihZ|z37d&DV3NRA+SfJB-T@)ppE7&3E1mk64Kb@s_ zDMs-G))v+u=0+Hg$OM=3Q5$9*Mb3+jT(^d6D1i#ZX!Od|&1dO8%0(@w4b*pHyW`Xp z7~*O~w74o^1K1k%{W#7^T8-?Z@cPr53N z2L=DiKWi@6$g@;G37&L~dabUOQzO+*TPw{?IzrUB%#_zM@@WQGsY=$fF-J}yionC! zgjMQ(`Jf)HHno$x01YS*J%aLAMTE7B2D6(jd;MXED=B+(hBSxZE$)yh~e!& zXUigM=<^wa z7Pb=tJsxu@+Zgi42UZH4snA`@6XVjESAB3S?osY5`sj0H7Bv6d*-k*DR5@`~l^ zmJ^VcoSimaWcoVxkbYi)9cnw1?7*0e9ATYhj5-;Tqt){&AQPr)hA>ny=|-@JlXIj+ zMiDxI;|0)f6=)res;`1EXdniYnNDez3gdxs3l1hAL=AWX@B+)#UB`nvB~V!>g$3dl z73i%^0rb8$lirf*!A4Hxv5@&^T0mxBTs@I27LpObgzIIv0!bQ4d+f+rt0zolnh^j_ zh}7VbANKWtj_(v;wPW`{fXMZ+40!C;QpRvPzi@OEI8NKf*$LlglF2sm3;H+o#Dt^q z7}3=`+9%I|#e+@HE>2ZG>u@}ZM z+2IdAH4f<){yJNA2hScF!k}oGm_*aBG+S+0v=WQ3BNEr z*)w_aZ78$sr#U#Mc5UC6I=|w5viKS)oG47}#sWy+Wb}!Y${1ZFleQ)%Jf^REqnIE8iq^@jXIc`_Kh7_qKUNpRp;g2+~tacBN+&X)H>O! z00E;cVC&eLM&y5;*McZP5JyOm-KTUUtuiAhiX#BPohU3!zq&U>!E{m>bQd$tn?+dr zr4l;|K?@)!qo2lABS4>zQ!2-L_=JR5J4M4MOq6Hk{8gLp;b;DJT7z)DF3XMoIbo=}C*x?!cfl%_X zU>hp{gVdm-cL2avGb~U#H*O`FS{!MyHeb-x`?Mvouui5G=CDq_N#mS(X)J?Bh-!O8 z;mFF(ky+i@#J&_;G_X)``ohJf(`ZR1nB8~#_ESy4> z_6bwy9k{FaX~SQz(F8p}8#H##?ZOt)1b~Ba!tNhPT{&cD z2Rsp|N(ysSeA>bO3~ir8b!1ycmswL zuBnBR=5q{TviMY)(ex?f4;TTAF@09oKlq`WdxmN_##;v!sq@9G|Hpc-+K-ftD=v5*-me793FtY-WMF58IraHSB>NlS%dpsePEWYM7Zym~a3HuiHi0b;1Mf^HPiX zFfrH}txw-mwA<68F^i!pywRF|$Qo<(ouarmuTOjyT zV*^|0h$ppvC!rmJs^s_yxvEZ;dOy-_B9Rd5KbNciOUTc8 z(EK4+Ra>e$MrTr5RWtfosG_zVA?yc)%>r|)>=2@9hYGdog-%%a7)>)P;JVCrUGBTC zaIW!wzV*f4$G%Cf*&Hj=B&fH3qT7`iBR|ue-hi1E z+u?-R18B1$%8=Zm{_Fz)5OzG()SI+@}Z`_PS%9qf>y1v>+}V?L+u7YRWkspX%rcewxlBM?5@p(CD(3B6Re+cae*YFNl|SH+8p z@tX{!Y^GCwovMt7(64s#kPm(!PycRQM0x%x|3t>aE!*k|e;whkBm51Pym>tmp$AV3@^39@ z<_O{&Awo0E4FUpZ_Yo*jRT}q)EPRIx4KRU6V&o1|91#gdIK)bx#?{Zz^{;YP!YMw^ zd}-ZZY6uKi)lc^Bcqy{DYbhc-Ir*qoS44ynXW*dCl(VDAiN}aV%Zhr$)IvRms}fgw zhdu(v3OhNXhA?gKW z;#r7KKYPN7PrI)?3-Kv-;@IKm?~fOxj%RQ!u?r>foH+yl&Du9x2}bB#yA`{XEWU6v zDb>f~j~Ac3`UfvQ=}!1+++*EABxB2k6u7yAEYp2vk;|zIePcELQTOJ{6`MJPRdaho zo*qRIn=Vh2ehgVEr!19GmLNVtXYNJhS$U8pS5Cy%;+f$AI4xV355@*oo$7;3i6DWn zys|jD-nXhsFnarRoq_b^*={Yx_p3~P?`@{ArfsXBFeM(+ZpwCkLr>Id2cT|BxZG|P z6AeFLhihMAvWK*vsi#h0F+#24uOvgj#5Myn0HvGWf4L8Grv zY;(?noN2Z$&C_l^vB>C?s_6po1sS@HJdx1^3qZRW$k8WI!?`=I z1elD3hvZ4h^YLtC$5OrlnAl|T;AD++bz*HbzFia{6ELrye!QdtVL!Ox0RDpEtr}ur z$7AXZhFF5`ti&kfAU7>rFQkfi~>7Mae{nP=Y!*u=n{#FyCY6XN;NfGmNV2Z57)hvY0ALENllmnunsWf z?7WtpV}t+erJ!8bQg!ci%B9RIpAk>*97VX5+PR(Dxn1?eMt5>^a@wHp2y ztyQG0uY4n_Rg)+on?eEeu##k`A8K%SJ8Qix`BG;QX&87*`<~C3tzIqpU_UCQ%jIogNUgS6iwxVQbmLa-Ztlix>}!O{c}8L~^~UXK zssZuRjprFLt2!9S)dL^`vq7?>Jz#V2*t3*)0OCs|%r*5r1O}i@mTl=SmHYtDlx@h6 zx@Ok3Yd|OC94oind?k0>M#T^<(#acV*#)8}9@HMPvML$c_^719nlK~ovC>Lxw-PT} zi7ly{WaiEp5WT}d37ni|8`B>BZ^gjvYq6yNW!n*ufWeS1XHd+sv`K*e!Kgx<)G;^F zNj1_yPvI&UO|N|+pf(s7Bvbh02RxH&UQWLED5@XR6f}T9sX$f#&QU+mYUWRhNGp?W zM@r?^(R@IHRIZKO8t09iMHp!vC^gMi#lkJbu7)1{Nm7sjDHTKAberxyO73i6kys5> zuBYkHm0?=I9<;{%P1XX{cMtQaQcU-aD!^X10rOjHBx_uSj_|f{#OCA~SI9kI*hQ|o zMOq&NhLP5BWF07@1<5fU7Zif3j&yZ}J2#U96Iffx$8`OtX9Mc$WXlZx*h%?;bnTMc z3y~N7^ycqd_I2psG1jz}e$aJf;)05zk#?_&(m~ zBW6;|9guWL-@dup?lY!}=O7#oe*r3biD;g-A5+IpNlz?!t0NW8yZ~u^f}boN3ILG2 zImt?B3^XDnhfH(au^me2a{y(>BN;?Awe2T28zi=JhBM$kLc-1dZPVG!mA2jGPOAZ1>TA$Rz*r z(z-$G!2VcqgY-9! zgJu-r<0zjCb+g$u;#A_`gdIh|T>TsSnM}qi()z5l)06F$ael|cknkQ!o&~ULke?`A zi&1xb9XhXHTp{k+=cGbwBUS_BiL)*Ee~bk2!s6CBkPXAF9g@B~8jZAtcqLw z0Uv7ko0jap)iwZP;syR~qme4bsJ#z;5*&}A*&tMM$N#MgPCwAmHGi&>$1SFwAl8sK$<8Gl8QtAV z>>USXMEL+o&uZJfSw^SrenF~g?N0p=A7XOM`$D(ML;fngqzWgBPK3-}68P(p8FaQJD?#K2^Pac*oGQvreL=Hx?q zQftmrm6A)!W&1){i&>*M(Z+OT$MxiqOjo9q);M#O?LLsE zRc3(1`L=(Q7TM829|Ubhq^G?NBYBZ7Gb|EYB~BtjN7PSewbSx2Q^)E+dKcKkKN5gZ zk8@2ibFLZR%QfCFIL*nuJ8pv61K2~50e-B#im1}QXgEz`)`=f+K7p^j1|_ZipG|w9 zfsF~oQ;YjdJ;%WLbcwhSmE|zDY-|_*x-ShKy#XWl5CE}kCp@F=#nUqQeBg-fWxPzoCeQ20>al1qd75T@kF5*|=q>m5)&(#^&dexmX6 za$s!>eZ~q@$yk}l5K+AO{FwT*o9LPyUNa*O+E9yq1e^FBKf$0qLYf$U<)X~FDCdPb zlRpN~IrX4bz^?``CStqV z4xkZPd|30I<0EbF5H)*jht;whpPXMWh%OWI79yQs4$nv8VTqLJbx~Y`96C`f*LJx0 z6o>gvgb7Pd8fyXQAI~&mGuQ`cJe$9EsHrWUO_#q__;pI86h=t53?|K+-|~^>4$Nxc z?MTfgD&g^8$Z>;`=8Xz9P=2j3HlDPA>Q`8OO7eeCAlTz3NWT zLFpMx@SAXUsC3G_k2}?I*bzx*Cr6qWxR=KppO?m?TvJbTXcS}5*0b`EyGXRbcHBDgDiELid z)5m~r2)@;CyCCM6i%2Uo|1Re*FJ_+sYXGDn)G@Bb`cJ6kBuruXxk!*+Vbk~?hHQvD zB1r03xE&8|Zo#<~z6M+&5M8xH-J-;el!h?q+*CPE{4#UU#xCuDWjC05I^AU4s%3>h zj9&`zf+<{au&8Wxk)x%Db`bPgUBGYRQxsX;vw1hv?meMp4b*NI)b0h|ty+Rg1^B4O zpfyh)k1JUSsC;GWfGR9#RSaw1^}}mV#lJUPH^{QTSNOD4?pS3do=?15h17cGD^oT# z?-?kY-Ak}PtmW%7Z|c(i=?vJq?B^7UmL~0mDhE*I#wpu;naxs#ke2X zR1AxN0}h;re*nhl2}Q>@4Pem`=)bWyd%pP~?9pvJAh8awsa^*X=$ih2u`6njNcL(g z3Cku&4ExI+qIv5v+;5M4i|Ok@p?eNw7qy^WEZ76qopW12d= z0Bb*YI-~jHU6H>C8I!r+{@zN82F8SB6lw1hdhW&V;F&0;2dqj{`INAvDjV*=0d^6M?EjV7{0>NHXJe6>xsIRzA@zW%r) z^$)mtQjPjhG$eNIQA2K?*n7xPjo%t_dSmw?<08N2d5Y2HgO;@K#Q&e+|Bvy1d&c_S zPe9u^qjKbn<)6^0vi-==R-5!t{RSUx!9g)oX67GLqo@@ibs6!8Id+2w;E#oKd?8Yu z3W(d=gvk!P-vYedhn$`Xrw=~6s&up7+vO6T*}*1tH^KY~}DoAHRh z^j7+S7|TsVR<52poH-2|>d4~3`^9GrhP0Y>Dy~inNK7IBMWmz}Tr-D^`8%2N^plhZ zt}~2fJv+3t+?aHVA&Ni+lhg(cqUxxhXt^*Z9ZC5zeSQamc##n~jFiiENbQUFsQffy zKPmk@Bhb>Y99jiFj;NY}wL+7e9i8lnmAPRZ8x7oz*OB_j7tt89&&pSCMotXxrSr>4 zBY-ZJ-5Q~E9ax3fU?n~ki-0JuP~hjBneVWR%oA|NotST7GNN7(6u8SC9UwlDb%pO? z7>w8c2l5-hvoXhQ|Bb6g=%$E0=)TmG_hbh1n~5c&i>-pKVd=CLHSdXC`-A2^ zH&3ia+s3n-_nh8%TJs**tmUn*;ea_TMOVH!1uM}sxuA9#{8Bky4&vYK!$NY@4)t1RY@`}B$#HscGjg_ZoUR}SQ&_efAjd&t=T`N>@SUFz z7MVUBT!oEBh&mn~1vVOP#RTOE7->koND6d~S%GccwDa=COkZB)#!O(K7&s%ETnoKb zTe3N9w`wVFAbjGzxhclk(QOwunSQnCN;MczEvsCH!;J<5QNQ}|cUs$FFJ!)EXrz{X z9u?_Ab^k60HTGnEB)xeKF4vH`WOuD|QRiIL%LQysoRU#P>w{QR=AN9d0{D8%7T084 zn4=z1QICWCV?nr3iKJ6Is+oW?YyyY$3 zkS@1ft;e+5|E#Xv0Zq9ChQ)7AeEMRymdZz9?ShyFkoZWKZ4SNmk zH0zzZQxl@r-9+v%c%mgM0sgA*i(P2uFO0=BJiv3ZbVz-6dk2!L@iYySXh}?l(Mlh> z%0=R&DJ>D@pZ4lNzn4K%mC5pOI}UlnO6l zUDwY@16(2J;)GI9_~)2SE!c$m;zs@XUQkM)F#F$7Rb(p}DtW-0o78hi)HGphR9zl( z%rshqppI2F78Po<8c6ex>a;;$%JpX7^;YNF4*jLnarBPrlZhaFly%hdOL}x5q#Fhp z8TsUc3zWz^@8maDjU44quR1p4!4r?9k9Y z4pK(#bXPEyA{8L68hdJINPQmhBgIwcT$*uK0TD8`YT62#E{R38LXxiDsPycty&Ybn>J^_1sr?oFGvjd>5+&nSOkKjjy2 zXr0i!7QGNQf*a-1fL0MR9!qXu7%{=9!8LaJ#CQ~0tvtsPk-81TP(`sRqVbT~>h~Sn zgak6ov=tm(NU*QN&C|o-ElGl*hr{$oU5(eMIb56?3uD6M9PADPsX3x;8j8bmL6NLQ zpNq6HpfQpi8DK|v;sa)rr$~q$YCP7@9-3ekJxohVjNgYV(=VuUgJSFPTrI`r!RKH&Tw`A#Xk5j4DBcxc>2gWS+fj2>)IB=}EKCIKKE zqqq66jwxmwE{~#B%W2}=nocG7Q{c5o1D(7H++l(qjMS0_vyNTftySf&rRc8_TlFpv(*=022dwq zQtSX?z8DwM7FMeSkpR|n4)*qF{LKMAb&iA+Wh{b>HcqUMhQ3@)e#SDV9R}zfcapG`pz#Y0mXqhI<(@JJ#`|IkQ@U9 zV(5$AdAE&#_s5x58wcU+D6^vrh`{xYV|2;|gy%ty$gJ_g{UySENTkpm{1tgY!#jiz znb8vm@uVWgUBna!?%UL7X+of(6?W($S!#18x?y&PGvM~q>ZpSsM27|H$khmb9AhRc zl8$m@hEv;5(~Y$|jk56t(wMx#bnGZfr$CMF1Pf@0#tO2W>P=sgZy@JIOPNN1(2$)X zuIH)V&*`m4LT514S!RX6*~O2ZK**eQAvUSwP81H1srafc1*soW$VeEe1x}!gMJ9;h zyX3IPv!xkcerDS;b=Y?_W1)B^q_M-l9>a~mJxbNQv0A}FY?Exl{`LpsD74Cx#h2bX z0>tL&hWb5FZY)~BDP*D+=GLlDhKHaA*J>y0rajF7hyoP`{h^Gm?2jt;;>KNa}Sx)h`NlPju3!lw~z-k1r(667;X^A4W zpN-RS|M?r1^j8u;8@fEQ;mX^njpnk2NiqH;sbrfp!E1ZX~4I$_OYVa+%;n2 zQ0=yxWx#owILV94NG&fCr}}A1IpG6H&nW;V{4n2mu?3iPyhwh5X~x59XO`Q6i}@Zu zljeKOjsO~hT3W94%u#z&pQ-cYS`Z+CK(!e}hN4B6Q%5TjRXg#n8R3f&KA4a+lXRoJ zQ{k8-F~6QkTCfZKd{H^L5xG=*?{6|>Qfx|6M-l-$^oP6jgiTpLpe#?JZFxp^-{=iX-gNY`US>LKhmMQH zzz!|yTKSBGcrni^@fo4$zM_$w3jCRJzO5MbvBn zuH|3zTC;^JWrzBklgM>93?FHABCUj&RMuS7$8p@j zXOJBoNJ2EZ#*+;9_~dLd6_9jmL4-tmZvI=Bg3bu&JEDBmQaOQqXG%^gw|n&Fdt~NVa&!3j&MnZd>cZXn zVDiY!!>9;$Ro_DU=W;l?gAret+X8%^L^(Gshf?nu3DmUFrc=|#XFBNsaUkQjHR26K zd@_AD9$x(0w0R+OgY zGOJv8T~2%;dmh&e-LP1eE_iq$s_9@fC)apL$x>{8J{U2gdBl%+;7E4xv8rzeh=U{9 zQ*VlUU7dJQR(-K$W-R=k5p>)Y<4*l!>;FgF+rU>{*8l(9?C4O|87j3*blS9elMaI% zih9tY2O2tWvUxw#Y#P?Yp_C{a+jOVHCo$2?tVlEQ?i-dOn$;!HGct_jthhoX@##-q-v7dSCDBx)7y57A^J^tY=Q70^xga8E38Zo(?QveHx=MB_UU)`rWJ8H2z0Zp?vktmbW>?~{0EcN zsk;DL3aiZ;w!q;$=Tl13g0Xl1Sj~@dz5!CV!v|_U%7mkhLE*jwHUEktzESf=D@7P! zt5xdAwcSwE_VFd+m#FPhwf)4<0YIOb-?k;a$d!}e9%sL3AwuUoy)8Y3Q?*82>gb>6 zd4Z-~$9FsZXPKSP+``+@Jz8+%%vvf4TImJJT%&L!1*LWz=$C+&!>_+lXc-S$QEGW;f%ofi90mGstP_DwJfQP>E0^sOXX7yPNI0lV$)mdE zK7DysYbA0SKTQtPLq9zHH18K{;KpArA~Xs=&q@mlBg8w#W(+Ab{T?V&ZMcrM#hmAx9F@{RQ8)z1Q}?9|T; z=e!2Kpad138H`yFsg>kp2|I7J>BViDa6ofJm4H(1cl_7dRk_<4Ztf zPQndjR4IH{sU(Osrk5d8=Ii$4cqj8$x#W3_dcpd9YQyh?!aMSt*~vH4B5Ff&Th#My z>CWB%6}u4wc`P%W+V=2E?c_*-P6kmL{^WPgW}9zMD$rxC!?hklznKeE@WEWt^9t#Y zHGrHX*K*v7>D!xC>RZhU^ONiWI4Hl}B6Km`40}m!^5|-{n`IlEm`mU@aaHE2S??0A z{~m4gau_h>rE=PoW?uJfJ!o8`qKEsHzW0~4=>5;+g31N{(?X~3n}}ne?^kIgsk>cr z1^V7N1vU!xUbnH^0dbSa+4*qC_?#+L3Ql`3IqsSG)#duawIfm$|51!|@C#O|Q`z=* zG1YOheuk?Qo+{7ltT#EwW*maD>q2otJY z6`L+Ep%23iItiZ-l!jOvnmu2nX50TzOG-D;#&+gHy}HO zKbrDzeK_?+H-Dc>8S$P~visGeHSWk5R;nwe8_2Y}THw24yzcO3>*`Tf9pZ~REpShC z`!qEfT1nyi;#w)f8B978!b}rd7BJ}GdGQVB)WtjhKuFJ-h#*P+SZ}=JHhV+p+$WM9 z6z|$(w$%rVyyZ4{)YjA4wjTAxascQ=KnSk7~@*a zU)k%t(~5OEswiD@&Q*Hj!M%DPeMvo%+;@e1^v-jw^vy0VA}&&X2ICs|!0}%TJ)n?tiDnjr0hsyL zX#yysCL({o0=Qrh`Q?#Ap;?G`CY%=l^BX1Ixs-s;Kf2$Df$IbQ!6IFviuilT7oHG(l#mX;X1u=I0TCr}a&T9bmILC9Dmk}=ADD08GR zlto$jrXI}o5MiKbv)ZcW;S4@&gbV?vm$<5a+c#el;TwMwqRU?!fNX&~btN|kgh#?R zrU>H5X^BMEDW%LknApxC>LnMkJgQP7Dh;oAPU>#@w^g}Kuy|Ex;$YfC7)8qo`@$kZ z+`6|)&$rS8i$o?g)3`!M9zd!#E9wq6uniG&xj&`<(88K$T+-I6%yw2ELn0uVrTy!b zy+Md}0H_)*1Qf1A1qIi`Z?8%!U(D^sIlc8(x>01| zvrCN;3X^DW|KTx5SEpCj8Ej^-%sVhGA}Ei$R3Wk20lJwR?lr*M99GD6is+ph4Y-X!}MY)AYVY{U7{EMDp#Pj8X4Tl zXL{5M_JpRxdPrV}G$zwiVTBHzwnoU;-?#0`ajJ+br*LIKxrc2Zxt3nk-cC`uc?IRd zrl%P4=ZM|p4Y_E%wy~se{{q9oIGMZMg!g5Egs!X91uCXRN_K{Hb&LE{TtlU_+0}-2 zLNb1?-85Ee7z<*5^3fM36Q$OQUtNMVHBB|?SaheG^w5-_E`HI5;ukv=W1NbS>#!>W z{5l#v1A~~DC)&|8Fc{VP7by^V)L=$YVZIU16vQ>*+0!M2X3dnLsgY)Cz)$$)C&AP! z*r7sxxO8R_F9fmr?^eJXm>_{Kw=) zG3$^*jZo`179=x^;hAvb^}rpB{8hePP8oT8UzVplF){6 zchx$>r2m8?HtM@(+j9t(5D?(>t_eITtQ7B@r)Y=X&F;`sko?fTb$(mlmiO@gAZg7F z`W(E&@JK;#SKV;tvK3jy6$6~R@$RCKCin_eOjYwS~}oT7B$h=*M; zUdvPW5hSTkPvFqHVLI#Gj^ql*PKvUL=@Ba{#M6vXj``I@Q3fmFRpTmJSN@cGnbhG< zVQka0PGMxjCmXda#ZDmlQy9-SZHq2-)E&9*&l;VW4$g8jqH7x*43#QFHk!_FvuKO7 zDPi=h8|+&yj%96y-%I9!ZtB}WH=#w*w|O$e7P)%ycM>*!2@>Zt&*@#2^%7G&!$G@DP6f6qj~Ysrri3#=9Q1 z2Ijcf5d-?c-S#3%vauKwGtPb4^kZ3Xns)#>3gr@l-5f-c9QX08&kOM)K(hC59L-iz z!SQSrNZ^KKYEwOjte*!%*K_Yz+g_I17M1oVuURZSvc=)A4}5ELJ(T6bX`9c_tg4+9 z=r}Cv*#im=n+=S^&(^td#$OG;iCi|_Zgdj(CI?5%M+ziUg@&A=a>%oD!T1$ z+kt~M=yaA;@bg?Qw)W4)1bPn2mM0T5KF6=xce+FhmSooH=k}!%#OUnd8?0f;^eyIa zIT*N+l_`y}K#D1i`6m5I)ONBXk?C%@PKpMu>pDWD1AME(pMQ3x!~PVXjcVBM5qh%N->E5!{flE#Ub@yraO^(Z zC1-gM?>snbxO{SB7R2wIodxm9lK%$8Umdf}AWpZ21!DVQ4#dTvsqY3Bo;MRu2`}%p zNj`J12;fbA`;6gqVF6D6a8?%JQU4Xd?@iohfR|dPsQ_MOduE)e1E)T@NBdbMH;U6s zW+X>8kugY}u)%{F2$ z{8A4-!b{n6CZZ{q#J1Fqm{ROrXPUq^not684S<+MsMUkJl&;AC+)D)PD43rGvFi2C ziw?hYP*!wgm6xj->BrkAC!n0SJ>g?lMKM0?W^y#SKUh7bP@9Km&YhiQt(BT_@5F-+ zHIn`waB|pceR@dtQPBDlkULI#hf9gahu*u<^WmOEkIha zQ^6@r|61|oI7vbe_^UeDHQ4PC)k|iY%p1UZ{B*8^9hZZunt2aiAwx3XV2q}P;i5l) z{9cr+JO9Fsv6L~6TXMzDcE44}Bjw4>OOl+#G;Ybve`xHLhH&+VKY*J(ApTdVpTaW) zsL&)(Z0Wwk0O?&D`9V;1CF|Yr0s4$wl}L8Q|0msW+K4vG$U4lD)4|U3NU( z%DKMjU4ZyRs*lOW`{@mQ*+vq45FV+zh`ZoD;`FIH=^3D~wWAYQ>G>9|t`{CJ_-8H^R5s4|&m7e20Jg$Ri&^;Ep0 z%}V~g#2x3F9)2jE#G#ZPJ|tas!>Oh=4#DeC17i+N$2#hyTt-e#66zd<0BY6rZ^e+9owtI8p!E zSfQKf+bGNeNtBhUr)J^3g2+VW;P7CLj|%kaXhszVxjjwxP(DN;@g5wN?q5G8EQHH_$iNm~&7NXf#Nb zuU^ANxj}5tOLere2BSEcB64m(xw$?}6|LnltZ<>fOc@j^t|XGD2e~sHU`J_~aVxK= z^S7KOllU*;6Mq_<1+Z%;14yoPa5RXs(-clZzSR)GW!sqfaNaOFZ(=wOM1wU49Zlp? zUCYB;taXcfdyZ^MrkMEdFxp0Y(xX1Kz-Swy0bq>~5jtQ!rPWOi^&11!T@CK~`1$HT zTHwa1G>Z<|nju>Y3-uCrAPa91R@1SaFRugKvJ!n@8&q3=a!1WHLijDU&}1#tA?T3? zqXAXYpBhs|{fYf^-9tO5fi?#nQomU;&h=l)VaSTX;X4Zl8zO6jafT>0!KST!3c-w0 zEBk@T0OqT~PlPEVUS<|E;_$Es5v_e}ZY-Nu#NU$~e}loPVhj5(Ryr+W%zE+r2^HcF zsBOX{yAA6gL5edR{;H!|rQgzKdplkgCj_x`mUxQG_5(Tht)1&i!|9UCpzNgw6=#7- zCRXQJ%9_Yh;%KTKK5@DKtnix`6DC&-0ljZQd{oG~dz#@eZQ54r`WaitRM22^}PZK85LIv@+ zq@K#duil$&l>-5gvu7EXp?b-IolGsWbu^ z^)9fT*^Jx{(Q+Yi(fb5@?-As1lX)A$h1K^%rhf74psp%(@v_khvb3+49aFxRsjaDxJ3OH=X?p-z(vt*_fvFdw?V}jVX{;+jBce&@c28N5IV&lkY zs3s?J1x5moZqSdi?2GRrFU}O-{>vd+!ci z?fiulW-#&(zZbB1+9urXEH`4rMuwI1LEq3#Mv(ZHz4BBv0cG_g)jXhzPM4i@JTl4! z&_Z#ebo5|#iHV%AYN+W^qbZ>)o|otavecAJNkvD*$mMM;v>N_$3c#9yhA#P*s5u6G zaWPah4egJK;EO3~EEJAr_^n^M0X1kquwFrOOw^as_41gqT3>psSDbp3c(tB`QD2)a zC9V+T*i$$sl9g%r0Vc@2gU&NNx?xDCKI3=cKxa2*zhEV`8X-aE;I86wLPcZduhOu= z$Wa%1U9%N)FzH90Nz-L7O_5^s$w|R!)!rh2p;ZQLrqmR7WDyRszFqOY7c~^58J+mG zFMO~$%aPm2V&UqAXq9^i$wX6Y`z-P|E))}N(VvFh*3VCXVsq@Hg$Fc7*hN;h;6u@R zb1scr%V;Dm-9~+jrTfJ^Cl9f7bEHPhUXnb=52$_>6^DhV-IZlHP&s@b*Ygag-H@X< z&)4r+2Qr{PaPB*o-u|)qLKuL|C9>Z@RpUw&xR<$!0Zi@fPDN;Yel)bqA=C|z_%$^7 zE;P^5Bu5V*Ugh-tJg4uSnBDE%Wc2+4WBSDNPyvH7d=KiD#Goa z@hoYEoolS%N$Dv!;|IZ`btO{gj_Ozzmzh7){!oZtY{bEAXp_JUQ}E0O^ktKLRb;0} zB_MutexEJqgjGfw>4X_TI1>oX+89KwtFsU}yOm^)0n~^!ky(;YuQ^rCLqW)B=#>2k z#;iymo|>%F@VPEKW&rrZ@={|~D1s-gtl7zYKGS7qQB=BavDh3{K3Bg6u|u*vlQ%wN z^1ysn*~B0>m#PRC{anySrobuU6HgKyPs+CCgzEYwkloj?<>kjbom>trG|7emQahKlndyoA-W(SS9&7Pfvq+?Sl zN?2gBI0C&KyZgk5Te3q1O35=rZE^(RX@;IE!Y6+wpgpU#FBJ#k1Y6n&A|WOV(|Z$9 z_?1)jIog+om+;;R4f?XdL?CmfON+l=<)CR)(+MY#;7vTAc~-_D7(4Cu zDi4+Pg@X$JMii+kj+I=$sTy++CTt4)%juxodxmidOx#=@7X zauA!?E(Qj*t^Rw-88scA~6il~@=^Al_d2xnRSFt0ku4i^h ztMnM67>s*r1{CV4z5q}IVlit7=_V(K^ktHz=yJA-w*%D644X9p?y_BAi#t5I{cG3AZ`km6OyuRj5Ldm5RLt zM1>19!W^RJxJRxyIH^P0n37%apnNmU!Go_*Tp?a#K2y2op1B$`pOk8+Gu)!R7v%by zK5uS#+x-r?hLiTCLe-MF;WY!i4KMr^D8D}PX>$0s{7xTVn4yukXyh&0Ts5bvjRt)( zw%O#=lNu9DVfNQl_QQ?`$8C%U|D?2CnTa=`breB0h3IX-FHp)Vw`aC?#@^=$mlc+V@VmKCT%B@ z97J8#BQuG<-*Nximw!>k+Ku#dt89l@T?)Z1=iKor*^X9a0oZv!NYoThfT)MO0V-c0 zJE%-87IRW+b><{l&T-FkdUtRv4;wG}l7zVpUByU)CwTrAell<{TV5t89| zZnbFsieEyZe(?pJ-@WB{zIUJDpRAi;$bmo>&mR;>t0FbhC)L74i)aYFbHOMd z&p!$%^5gmNp5Kqwy1mJxjB~&JXhH1F@!C2GkKVhpBa^Xz6S}f|v@AH*<45+3Ihd@b zMAyr#$`iN!o{7XQcIY<}h=;9LXtr@!LJm{B>oFhBX|n4tM^^C~Ppw)p%Xa%Ix^@19 zYL3AfRibK4mJ|9-Ym~@uFzTf`+J+POE(!j%ZxbI-5oYB=ycVN8q+FxHrn}qpA!qtB zd+)xdx$P@`D!ei&sp0tsO`n$S@teKr0U{{;Scys>6lMq-D-Kc3FgkBB552Jct+jXV zWBKiss=XiQw|AH`w_VMOIzWU2cFGbVa;M7{{IEngNSD2Rgpk&N`QxGrDOrZyluRjq z?a%Hfiv+rr38Mh|5qHBOkGH7OyddAw~4%3e9!n_e^#cFfliA@xN%#}FUhaowAn)3Ko% z5RDk@!L>d7jNe@++FIACcD<6;ZWK7{^o9OIKJ};P4epUbe)DCt*-^}tZAZ?}r*{?B zU1xoF;k;JZu-N}X{w_W@gc=uoCOJA&z%t*NQhr*g`+p>|^ z$~xPeYC&OCl1F`=9hT>5uGg8P@(Mv^75a8wq0ILBy@=JJM4Q0NvgF0dWbj?sd}h^* z`rv33`KnpuH{mO#PH0d@7WCe|RBV|HhVPyp8H`8lR!?ULWp^wSWry!>XVCJ1{FPmA z?*z$f6~dU4gUn$#1oc5#<aT%JALNtj8~P#&8foi(^Dntdknk zBgqezCvMqI)_FKVe5WH%Zz2`O&sp#f#lMZ8lD6l>2l)%Pgmd3U5gZD#GKyhO#z zW5;#u&$;zEzDi%~uytC4s0cvQV5U}?rxU@Mlx=W1sG5n%>)1RvezlIunB*>|(5R?| zS6M%9dHm`J`2`e=TIEro;8QWc%WZbd8x`Xa^4H{seIL!l9;0lhEx`dfm+HWaev3BTS&-CEkc;HJ{0& z*&+Nsk))!FL1?(oPi4qR!#ndS!7rwkjG_xH<4q5i?j}@JhSl4zz=h9J z;k+nTlLPOWk#1zJ>CCQ5UHbLSI0hGz*%Nuo{njHF3*5pxKEQP&Z{>&-pUfS2mdl&K zm3%vLkoWqTZ7n=iM5#@RhC$iH`-FE!ZluHnf*VB;si(^D5Dw1h-`(7B^PTci zqtu7F;oAk@!&N_Fc>BXYx#1PBxBl6UkA9}oE&gdj;K8_n#{<$P(ta)NqMeoc3RlS_ z09duSxk6G=!@)s&ol(cZL2Fxa!p-U#quU%ut#**okW~qk{@3Z0PLF+09}+N0R7LpK zo^QHMjF^%U0>C=6eroz|XEpsBr>R=mDf$5aO@MC*M1l&s3jcf)W7k#fd1KdOk$*l^ zmbPO(}kF!mq@@CgZJ9qq=?#?|;^}D&!iP6G9`#Ay#8Yn?MhmDz#&Esn4%6WV~{6 z&x7Uch4pv3>}4n-0?|eeH4RXq5h|b)o$`cr+`I6$AA_!SD1##W{086(@w3$-e*CIa z>d66yxcbjq9OAc1_5sU&i0-iEtqk#kJ3eWM;d3`K9Np)WM{hvd;O4)_$fs*x@7$le zy{F_q)7~{uT>cAU4yLb-{WrzDzC7zsPkuZiYi=)1ULMJdKJ;wzY?OuBBp^X-)hiLU zI;(CLqQz)Ap7=$-nvhK^vJs3pEeos~nB#}ia1XycST5otm=?J79!C(HF*Og%d#NHQ z0hox9@SIJk+^(3R3mldaKJy2B{s$`DbRsTWx5~FK6&md_idr75fkgD+I3M0@us1<$ z_mx}4)vu#?l80aUdw_>xiv4okR&h1m*UVu#DU?W>U;0Ykuy+@T4BOgu@?&nJPwfU*skocD5s z50mDoH<}w1Ha}e~X$-gC&^T&&L;$JFERa@hbiZm@9BzMn9uDmQ(XHWd#chQG8ihOj z%mA(9(hS0bt_OQ>qIGggx(GkL{qchWLJm-?vJW-}7JvKUEQlSvEH_jJQh=djR&5bO zZ`z@0UKdrU`@*5hJyd^A-Tsvuz6D24-Ok9L`ulMnJCAYhWya|L-S|$764-#RczowS zwZ-vO*>RYDe7k%J>>y)EZ}U#U!L<{l&kKXc_&c^}lbP`joN za)5bN9zMCur6nUy>OiHG0qPmHBd^j2!tCr5a5M^zCi&E^b~tA)sL8tzNyEqE^C_YG z0vyipmi7C2av`>WKf+!=&~?Fv$aEtpcu8By(zW%hl4=K4V$!%5t~^6HzIsQ>)wA2~ z>LIGI@5)L0u9zYhWxY@_c#~GIf3QZ+tk~q?^U6na_^hO#iliV0_y~(`AovS(pRNJJ z@vFbDW}q6hBOCN`Bb+9+5bgp;xD+7-z%!Qggd17dQI>FYD#Js@)EB_|?I#H9qi)oP z(GAZZjLRF!Vw}B)kCCwr)qcoBd$|7(jAUHXRtW_mWSIy#(%u@9TxP**KY&iN3QWmB z_V(u*T)+H$TUNl4XS`RWcLLbUG)*4&%&bxSzCdhK3)rO0ZI>Rg@7fg8k|QNTTvX%4v25`lrMVQ4@h*6tQ}?IGoaQpbR9GpQrf{Bxs#7cby28(DD0OBn`psAT z{f{6mny)DG*~ArZM*__r2_L~rmz{C6a4f+Bh$D?l!$FsOtyw&ExecsD?Hr+zBzR$h z5zSp*@5w3SBZ`darWM7?IHCSDcWM84Z=mqTW~ACgS@CP+a>C5kjWecme_E`pnpLz# z7~jg=B{K(nMfX1ndaoers-*s5xVoz0VnbNfd&Rru1h&W?+rc@7{1L=f{7G5C1b+|u zw?^vY>@`uGeS?UxLCSGM_|WhCyns$?Y~(>%#S=n;`Ukf1GC&F!ovxdc>U8F<5G7t= zpe1@mElP#+Jml6038$rJhEJd4DoHsav6^_I7ZVkn4R%?*c6qX`4>mnKd+5R7HEPRA zsEs{5VoY9;uTt;eB={%C)12k^$MAvg+q%izG>Cn%P^NPDf|7nc@vn-x54@hp%qc#C zX-J&QC^cVDF1XU2xW6&nQ)vW@n6U^s#C8^I&?&_YjatIPoYOWE5$LSaJ`xU$yCj*8 z0=aM%N8B#R$1Uq9gTm9Op@RXDiLcrS$Cq9*KE7z4HIeGIi)f$u+xW`QzQ5;7iSE{_ zQxcue#k;1PA|}&qa}TF9<<*_GlpYt-uvRZ@Hw#p3=DRU&i#@PTZ;6Wnsk7>C{bq<4 zy;UH5?$KfqfwMK03u624n4mN@vjY>!xOD7xH!?R#(a0ppRt@z{TrZNH8a;&bZj|i! zMO?pNsbVwKzk+dXdf<;PZ+tis=G=i>c`9n(e!$L9y z(j{+&?D4=7H;%|CM2U6L3R7&mVFM%mt2gB%o$NJw${m?95ZQdf9dP{vj88f z;X~2=I<0FYH{_)yN96h0df(RBb zF%+k}C2Gm^TuEOtePf$GIv)8zS|yR>l=VS_IEQFw)lNOfvFzpE|NJ1?`!NEq^^lHD zL*sL9r(pNaiSA1VC%P|(4rQB1vEcUD^jX;48Q9zw+IBrHv@X(%U57eW(-zfc!Ww9T z3b9WABUmxdHcK!!s2i<3Jwpsz z4PXdi&k62+$^5oJYq&=K27{>(z(G#_qF8e*=mDjA;1!>!#CXI8__OYz(Zr`3>E^AYafmPpCnY-jc zrlJMNcQy%H2V&pS-1`^u-e*pM-@^ym;O2uZYFot5em_8UUc4iSl|CyLlK;O!J$V1W zy!cj>1thn-D_bo>V#A%#l8(Kwo6E5I2VjeB;jszGh)skBr(+NKpYQQML+S~o@kO!D z&mJ?VyImv4dwBHBN(aK-Z+ns$D&dmHrHh76*<`JDLnon$*92zMVc~Ln(9}N- z+bW;|5-P)+Ik7?GL7UcB9iUOS>IY9x-eLTai%J@&6tCwPB>A}@3VKd9!Ce18btYcoiJ z!Bdl=NWqlUBksbe8hI6SZ5$Q~@s2GcOhlU$WSYRf-?_jo5uMMWd2u*aP)&bwK32I$ zdtMVgWB;05R+a#xQ_B!@6*Z=caF0LuH4ay*M30JX` zDk}LIp+9teR^t2`7(;C)iiXU6Tp{m({T0?`v>d1D+sT6x){8q?WiqO6wUy=k&eT!W zutozAo(x&`-<5(Q3#2&N5k=fbgM-537rU-2g(ldk7Y*4t?WKh$< zLHcZ8DtTc8!{lm5K1tx?|5BUtjH@!O5-{V52zCkj0xRMMYv)yNv1d%`jRrxdKU2y1 ziCcuk_iKtpI>oVGqqpaNn3A8}+32V>1M%dED1;S_%_$^sXw(Jx<`B7koUYXdJbauEtk#nd3&A^`mU<5_p^6K zzDd-RsF`KlH|{H7T)qIyJ$!s3Ca{4Kf{&SH2 z>CA2GtG?dxN=e(MlIaI6Pt?$vk)nZSqUXlw89}nKwJ+6>m(Y1L7ligb)wXHa^p$L2 zhZHMZHEUy4-t(Hg=XKF@PnElnb*k299{-3tWvc(?PK@wA0 zAVRnHYeRsjjdiY#Yv=95S1&?#xC|6_{R}KZqpym>>!2OquU`28-c8MWz?6_TLryiG^)W}f4ml1ajkZ5a2wQ9D}l2X_4B8P4_7kC>QR3@mBBh2eBo8h!Qej&>~tspFNrtq?=Hg z8f9D?98$KsUCac?fe-QKA?2oil{XsJ{ds~xY*M!8x~hwcJcu*OA$BD@-Cw5!akuQ9z5@f)M zJ^nBkwsQEzqdT$k**jRpyna{+5ah) z;BDu`3;G7)Ld&Tu? zG@7qQDc0y{w64t2=qCSqhEo;e-YX{116D9gpz)qSZ zmK1P!m;LDc*vxSrc;HvMI@+1<@XZ+KG%H^R(~`-<;Hv6q0F~$aRY>sjrb) zf$;UxTTok7o7Jq&}MHVur%m0mFwgk`4_d4(dTKJh5il!KpGV zylng&Kf-c9_*5cGK?Juz#HRUk2~fU%awFX6PgtIBPdsCxO!TwHNPu0c`iTI)?Nuro_nGz_*eRLUk6cJ`%4xib@Xp|Xmm35vUY$zPDaQTgpx+D?)&TL z_qAhDwY6zkg|)~f0^07suxBcgwWEdovI&O;@)f^ITwb(Zga9-NMQ}^AG=#WhYPY;s z;~!pG7{t^EsB%zBmw+;ukp>}T9$jknCLE*JG@Vc@h=z}tgG3uW)b^R#I|^t;Egi^3 z@P0F9@Y4BIco}(ZVdNUIA~;9$;~hM=#pm@hd+vPKB03)F?VC39Q~a7m=4#KgH6J$n zb^e_14;jmVJ8`1Yw}y7CEbTtI>S*bwUWB-uf@8L-L9_t`0eYu&n~S` z{Yuc+r>x<0?5EpHYHn!boyBSh&~!B@T#zyV1l#DOg94bWYWgabt`Cl9GgWW=n(s-Y z1;-LEzDhq&=pJ5MSV605Y(RCjyoNq5*d?ybKMj+VbM-9fkZd$c?3(PAvIy!2FSm3n z&vR-A_+f`|`}r>I3MV^ahjw)?f;T2p?Lt~Q*1H|%k?~Ac^N!2f+pLroNT#o~I)Krb zO#j&Za-Wm2VEn=Aj`Kj-+Vp$X5qJuNHQB3M^=j~1i?d*C7FY>QQHULuhs{6V7V!2m z@TQL|04>Gx%LT7t6oJ>+o+hJHF#PNT)@2=a=?psx5e0~Haf6e}nqn@ULrUMh;c?B< zTC8Ms-JHLY#gMUbie@m#%CK>@JE0E3*)o>LDViI^c#II0Z^*olB2Z_(S3AOqQHRf) zlj5pneyYIpv)^p=s}HFOAVlaef*ccZmw!Gs$FNyGICxC%(8m=*kr0h z@9Wd{@yQ@%1}RnoJm7?AK1k*K({)np)|Km}Z=w4U1`hACAH7cR>M86Y1yP*_$aIno zP#^65r<*joDq7aE2zss@=y)UI@vTzA9{y;RMmbYE!l&wpV30W__{K0kS%7v()odU2 z;#H3Cq)xiA4&dwR_(jr?S%QPiuDG-1C#PdSsFpDd@{~0m{nw`-b^cRQ`Zytdj7Lyk zbz;XWgB7zF&UjA7m$>>+iirU7D^^PU7vFWK{p}~ZG$*+_JoR|8chix|!VHF=n0#6p zkv^C9Jn(t|5fvHre+*49a%aD7H6llYaKtUnepjkZqs9y>nOD)K2mU0yPRT@JdV$@c zy;?!++Vi}3RqHn=m5O~}O$H&3YDlIKmSl+o*^+eYK{@HA>9W@cOK&&WcIQ8-BPuoV z6BSCT&SwCnC4<6+j2s>)7m9WvXJq@sF>|vnJB+?Z?x}Iv0*bnXwry$!k3!(;PtOt! z{fX8NY+A0yJP0+bha|G7sW!&XvS;}I{QnDTBuH*NxC7z${HB{)OHc)X$l*F64}h8? z0H%8YD%4P=02_cd{e6P$Ajd@XADkQHn4&&L{9gtcUUx3szI&mw)Sut&P|GdONuGL9 zQYKZ9Hz$cd(8`FrUc7Q5DHlWHv*n@07ky8;EJKvXGGW-p^Cyhk(8^rrqwS_~?e>xn z*&@v~C!4lw-Ioj+8~NasTu(tGvwkOv)50Kfm<}*Ta1$JIhu4O0pCc`=n$wPqa&Mk~ zCBA649mufRf%J}}a*x;}oXsgy~jmE4&Qnsolb&983@UW!Q2yUd|D88<2>;g&9ejRjeAR^B z*GeZ2dzJd-6Njyuz!)bETT_R4A-gBzeWnlH%>60|rMOWCKu-UPBO4dZOdCh4(ua;s zgHs(D_KL_Lot_;0l-Aj-|Cr!jtW%aEdDd z5gSBA2|}Yi$WXYFJDdZmw{*VB*$6x9!fmPx%KPP?*bnKsQWVT4@Ihadf?mEvW+}NG z{WGX!*@RN+`UDg!nI5^%eK3aV-y=D%9zxhQ+;vXRW z{=E`xVzMs&z>xEW>$>`Mx0F}C1E=04DNRf*J%2)PSZYO%nG#$uWXiZ_WvA#>+#3WtE!(e?$KHMO$m-FsZX`3*0J5YjX1h{=7_;GJYvYP-K`^rk}<{EcfFZ? zAYgrP_=X?KwsQm&e2Hg^Q)YI(9z<7$OIB>zb5Zljl=ocLel$^@%fzhbl5Vq~*Ek&t z1L92SZas{?>@z%davd)k>e4`6r@iX(ry8?I3t(a*Pv+z2^E?^#+Bd&G7+Y&_j{$C$ zh0P-u@SJlXxOd!Exc72!AC-msC!Ywnh)uQ~|DPvvW8gD~m`iFIRT0pW`T>1wGQ~pk zh!>o8@KT7)TVRNayiT!q`%(cx@{!UtWPSeqoG{=mh0vHeTMl0^>Py!uROpLkEuSV) zd5+n~%S1%Q^*}SK${q7IENU?G0#06-IuikuyC=V=NZ-9F2nRS5-=FM~lf0SVi=^%k zR4I|?ir4Sh?&#@=(c0UH}0 z-2yhyPPQQ4E-8M{v5}C{Fn;7)1G#GF$ZQ!B zg4n(v5)Xv|6oV;tRHoeM9F?4(&;sU6PdbMo@{A%!4ouXdHxqK;<~DiSE9St} z|llVym@wK3eB+sUVLg9?MT z>prSv`B5>R7}dQ7RLY8{V^6*>-ga|&lv9(Y|6^4><(qA9Q?1<0zag2v*Ln)v{VK`i zxDVo2|IV6jl~t7p=+!UuYA{*!XqjMMRlAkYj2}Fg8?mNc<7WNP*n-{Jhy<~6jnE}W{iOl`_F&I0V zJ}e+l^SNn}+^swf`0rlzWyf#oMj7fOwwDc4;*_I!rkd8c>qt2V;gyZB)Pwm>aREPV zEk3_wl|vztoJ8HS6;E3l0geC60jyW|S$A_6dKw@;-{SbSN&2Nx`lS&>w@)2RyE5X7PQ&q?Hbj2!yFB0km+Rr+-Z#Aai<4OzpS`y# zEMLa|T;lSE9Oi?E;)&KBJcR%24<<)_%)#C(oq+pH{y7cQ4SN!A_5j?*jpBd=-a8L7 zrI%>4bEO(v-YcFY@H6}^cdwl7^Q^CG2p?aTr>l%tr;0w!ezFNORJXsPd15N5>GT1b zQ}UV6yi*UgJXEL4&U;sq)}T8Gj?!zGoOFhu>|tBAxQKjmOd_T58p;LAW0c79cy9bRD{$Xtz|pw<5?r`u{wAhNbNY_XH42$Bdu zcrtH7%d;d)f10Duw@>d7z$6YTx*21n31Y9mo9m`{9yrW*1IKB8vBhru0tDR&0pdm1 zP1yZaxc(By^#%MMzv@_plsneX5I?&3bCw4SGrT)C`2cX_1}vAV+WdF|`F{G}$4xhMi9BC^@cXKFC zcfN=E;5eM^NATq7rLHPj5d0qZShT0Ih-#KI33@BoO>W$>$>k zV@7Cdi0WJ1#*dNvKWh^T4jFP~c+SI8&CD<@V3^~pdiXNR*Fax4%Xj6-d(<@X$nn-<6)j5X(@wdX#rKEx z!??95FAGUP8m*;*GtT^+WuLcg&VnTQFza=~KDQ;xKr{mr^Af0>4NZy}lBp*%yUOx7 zZ54U@rD(eg3b*uqc<-?LZ+1&0iN~aosnl(<^sSsJe0Mv zHqVfn4$iW9h9J(oML0Ly^90n)%{+P6dLaK=!6NicrSuKz-2RI#Xz+gSH9dK@!_2|~ z8e?@{pfX{00P-hgFw$k?|6z7Q%d%e+9wc2+&yI~HSvuv+7 zv**|wEI#|bFyIYCdS5LawvsP{6};kMQ17~mVUMI%Wp{WTaEH`kylXu`({eMhoo~uK zdAo7XKXP`X*gQR*b|cA|C+R2s71)r-3B&=PuirpS1Bhu{g5=lImCNSfA;GVPz@$9{ zv4we^gLip?6f4)S;mQBU&Y6~+aJ*-W8Ki*=t)(JxlQ`l$KgHoY4#aTiUA1EZ2`-9; z=UZW(=L<6aazhM*Dbi#>9R+01Sf4{^u_12zzJnuYhzCY!lvLestK8-(@Y6&2?q~6Q z#_l92n9tx6b^>z;CmePx6SpyD{6D`G67M|H-sR6~{NhXMgWk8wQK0o^(8p_UsB4~u3WcooF_z9^VdWJ_Z<^m!zvs!N^-c?V$B{;og(zuUiP3C&z z5mI%kHsJ?LIg!=T*~lx4*p#`?EaJ%hYy@hgP(c?=gWkK(E9inVn}_8$ zN}KhXdkJEI^{c7d$>IgEz5l)kW8ad)O{-mfkXbPpIx~)^@a4(K$D2M<<#cX= zzTMjV?DI<;PavGzGCymjE6vYrtlEX^GLgx&=*ElL;`tKw&R=epzHgGg=f7C@ZC+75 zWoHYTD}>uK(D@PwCJ7VqJk|l|4rT_qzrb6*PdZ z7@@64b~O_Vr^}N2E>CuCzOpqr?q#J?eXlZ^I;}b#>waDOV{!$d3R0=KUk?5ont+oc z#W}BPz61%Cy?{^s=~-^7{v_W`SSV7+PzG{1OT+tn#advJRH_G$l};Bf`Kd;_9hl8< z)mrteDGOq6y^+)Q#pd&eosL^8C6YF~%g*TXZ3*lzAO*Yt%ma>61J~#u81};nj@~>e zn8b0mn+CV;&O}Ra*9RqgFjTt2V-RBA+w`j?0a2E8Mucn!89pI{5u&O|8Gv) zEonW09$;tkU>?`^X@`=MKVc~UoxnQYt1LLJ((_=Rwd%z42p(B^T1D#Cq|{^ZS!xM^ zl}9DH6OR$j0qQp_Al0XqPf4xFd??}GB8Waypg-C+uTUC+De~YFa>za!tYt%o3sh_y z5FZx|-x+vzN~S&-{ohT?(}A>lX{?)ZIRV$bF&`R`6O%<2Fjky(U|%N5RkI`L1B7Lj3w(%lF0n#P^}|*; zd*DgM;a6P`Z0|bNEK3Kus9Y`YZ}jig6hQ))H(D^%R+E{Cu+cH(EYxaIOXJglu!i$M`oZ3FAcm4Jvfd;O?VISvwl{=JM^jzk+x3 z6}+1tcB|EtwVIB-xlY>Y`)&5l36jFRXVOwKWdKB21*$+Ur@S$h-urPf6t z!1yYDtVg5G=W~)aybf1G_)2JRx4LIVRdYZ*vT{ePRCd?Ws6F*nK#3o-8FfBDkHh3WO$JnB z0}}SHUT)3L6aa3Es=d8aZwGU2=@{=;*#OG7X#gu<(f|~dECAjd(@*`r*fHH`{m*e5 zI@4Zw+m}j~$;FD)0*+F)HJP(F9+FydSmajgzbAaWW%ub(yoHrfA007omLO#K&YkiB z6^q8rtCfcV5h&{%~%@3ETU(VSkVaCB-VPd?lu3Rp=5A26O5b0o5b;s=&n0ra9wx( z5enlSK^SkgV_Glj_nD~bpsAw~8zHeiNJz40?UD>;L{gpT9y2uaeXI*-)PMJq0wN(A z!jeZ&{T;p$6QD_1KA>)r81H%UE+0WxpNn@GpjZ$27al>I{=_zqhWFMN{? zWc%@v;RC{~ySRWb7F)~`=C`+R(Xq5U9}N8{b^G?(e_yn!wKnS%u>UA6pbV3JgOa zXHcOA#KBlvqGo0-n^rnjRA#Q=6F2kQ?&F*K=*cXzgA?3lBzANgT^@rjKeqQ}CmUTx ze%0tQ$J1rrfNGD%&Y)8G&Ujp(;XLJ{Ys|+w)>mk9MGTMsfUOd#CuhH|stUU}Tn~Hm zQ05OSk$uF6rCe!xc-6QS)Av&eiq%(@)UKG$E>_B#S)>yBNDX%^t-x>Xdy9W>=EYxv z?D^u4$mq2Xc)mDVYCiauzhxJ>@qMB2uOp(m{-P(|NV!`CaP|`aMwHYflaL?&7ErYe zO$LY0ou+x?_^RGlN{79JmpyEyve(w4fNN7vXCr{)!x?uuC$m)iCB%z}R#uHh)e4b8Pgb=rI#y))Q@*xB#wO%nM>QMf(~0Eu6{;mmc0N~4ha9pU(*IBn_r(xR^hvk zd}|A z3%T3WeiYWq_Cp6zkob_i4vK@sr~3{(yXV*=+kuO`iLW%6yn(Dc1cIH8am*uF5xssQ z)zmS-{=QD_lkw9(+br}&l?1CTg()woWzI{gS9rJrvysd$g4Vf^@J&#C((>M6z-DW_ zLtRLCTCDr1?T8FBXF7^GQ_5hE@?sV}qd8MHFQ!or{+9D%vMDhoGCni&qSAf?k_CkQ z8mz7Q){!GK>nq9NH2k(7t7ihk<-~)_aop<4<+zo*$Z&A4tgT!whK_gIAJEC zeL>^}Nh_dqanrIXEVuo<*c%{fYi^n{9U~v@kE_iUI4J7^Iakd^g`H9LON>nGRKLM4 z$kP+bNJgBl!%enV*~f)j`X0n zeO!Rae#-`2fqSB90)b%oGPARJWW3HUEMVFH;5@F`AIRexd5J!vQ;qU?*WnX);cAM9 zqsGF*$vmA?#J@hjx ze$Ru8wx~v4uE)k?%FX>94;qKDMiq8_b6avfjs(gm->)e@*W;?Yi`C!)gCG~9-g2(T zg?Ea#9D|bU@vRykd$oWgR?$F|(FT*_42p80OeJ*BLoGz{UtMm8sD$>$lp@Jl{K&R$`;=LJsO zos`}&uN zQqBgjc#1_0rD2*zznFO$fur*Synk@(${eoxqyHMC@OuHhqW!Eh^W{dNMa~W`JW#(BN<2{If>t z(v6|!r?e2aMg_*LY(0v-N!7{CEZOFde9m?XTjKGoqnQ5m9J)tv=5g4*w1-zq>M@nt z2*l*^J_}pO+G2zdpm1+8wG`{A#2n%%MMyVgU3~-jaDUpGc-?Fr!Npd zy%+b)%HaXj3D4eFY`?AWvZ|h0B55hz4<1?qyE3oK@sG{FEu(wO``>hWX+t^uGVYmp z@Jk@`w}=xwxfm8<%X%IyuV-_MatlPG29dm4C2BsuYbWu`kCM$!sZ* z4vtEVFMb6GMSRgZflJAavcNd!3{Ow-r~V4OS!g@o-U`E0L3{hsHoh-GI5bW?(U$V$ zxOXobpWK(5bk?HRTfdkLcKb;(7>*K({Pc*`eUd%0x;<+9#4|rz^pV;hD6NooL}zkc(q#bM$I?2To(c*-fmI9;h{$gSeU~9(*6W zR-Z;8x-->Spn;zst}3OM`qZ*KuAX*kgnM6-8VfZzN;|cEpVi8%a%5f=6_sGw%9YAX z`6Ni!*ghW2!3gjai+5^IlD+F%WB^EODHsuq-J@=AhOc!83|GbWG!RbxN>*{jJFlX= zwAg_U@}O1l1H0?14#FTZeNSre38~Kp33#n;lL|(wgY=GCvX!DGbIu07PR}`6p2=Pm z$8oNhig#OaciN83M^TkYc~#8TF#A%KdL}zI@boVYaZ|=U-a4Eu-Y9@aGN-``I!nUu z+a#jmlyf(^R*`c4oQ+SO`9bmp5*nHtP~T$dWTOI#+Nc8BnDAn8n2R61G-u!KWnLur z?@a~X6vIn^7-{pQKCvUlX#Vg>sk5d@D6L6B13SdA5%sART1-DsOKJyYZZOBcKPZ?9 zZ!?0}dynRz;k{gDNLmht28E~ochJE05r1qPm(L%F%%HG-QWkfFWaRS*eB(LENt3}Z zOxD^6#2Ss6*%XU+YN?a+fcU@lNceGwc$e)9&g<{I6Z8AqLH+$Dne8v$sq zm6|8yS28BPJy)qUZX525z?nl0lUsn&#*sPKcqWH}q5WH*l-GJJ^A|0$eliM%6}9`z zL_es{0ky&*TlRZqeSVABba3vuZQafRV;ra2TGILA^lBMDF{1wTEM~OlB8FsH^NPP| z8dUaeeS8A@h7azEvYp4WqAXgTzOAd8>-^Dupd?0ZgSti8nn#1O)u%sf{YE`<*!lt$ z0WxVy{pqsPdI^RlCA2B&{)oxV6d zrd^za)9;RZH{SIjVvtNtV^hSapWL9y^lnw*BiH01WCo~udgl^;DNUDkKRglCHE_+2 z%Yo8(3<5jw|3dqo1kd-X?HpjOap=fb4H$&R?s|JazGJRf zag~1K)q)S)tJ3gOd+JW~cvnW|9Ud|21!X_7#Vx#0*>0@(36)6{h`UY&Pfs&mG*-EE zKdO8;7YBD8QlTQ;{yXI~CkIxI?`@6Osi8!*YSS#IC$EwvDOF(Z7Xr(3s5%NS`?>QX zDhvD4Er6V3z?ox*CDTX4V`bldmjmcoH72`q6<=R|{>VX@qtP5{MX*yQcIUVDFa(r` ziPP;c@YI^Vr3FHRz)EOj9wabx!!HmDkkttVSo=~5B2KQvg0uCPPpIHK>^7m&e^%RP zy0mjJJ2eF|NP$D2p6alm%TYL@UXdFHX^i5pH6ZZOd5e06(h`Vd>ZHo_$bBEuszkiY zuHj03rJ7rCK3L?WOmZU7SE)z-^t{GB+Vi^T86W_57-z3DIF+WLW_NT(Z*q%mxT-6C zwN9TD$?B0HcHQqH3mL7S78uDfrxu&+LKMEX{{SeY2MM44)Z0S$=mEk}RH#tl@#oKR zjl*W^k+T=u`wm$HXpGU$9$&7e#p%vFvyt+1r5?hO%l-{TBkVhDXMQ7RH8=@T zi8?;;dUae>%%!`C`r^$O|K)fSaJ^wH70``#0{)Fg%z2)eoWeZnjKxq6k^QQEK`i5o zM(uaMd-Yq7hQ$#YKuJ&D^NQ#hF@u<&OP^j!4xCC;@L@h|h)}PGXECoT6jAYs2XjU{faTc_gg`wdLR8)-^^>TSL~sp;WP5rh@qfkHt@RREdFi_cURk(}~c9{KjP zcTt&v$#=?9kAtIXB#& z7(ub@!$!4QPc1_3h6f_#YFVogv%8$Kb<8fU9!$b^-g~~f^={4_pqshj zu>-tKrp9~n?Q8p$qrEsXPh!B#T_i9mFTlQ8NI%?st?PY8)&gP{eDQB&i$_+BMS$>$ z0c&JNSz(B1^|4%~;jIIge3on`BX`!Ss_>=7g)=|2a>#YoHcPP_*RNc?vZLP5Y*rSO z6bi*9S56P@;fo`E?scY0<$|(Bzm-iv$N%(dhXHhera8+Kc9T`Q>>Kw)Q zuKAi@clgm&!h)huBucgnv~OlFUsKApNiEx=<-Dq9J)?fzq3^>bwKSp&3BV_uWKT}7 zlt_SE^u9cN|N9IqYD!Cy-*9bG*DVC4PbhEyaMX(b{49R;g#;JcKOAvdFl71xvc#Py z@B&BgpMCNjULesy-yyJrg>WJ#w-N$q|M18OnNN|g&9l|BFfrxYjDn+nqdXba|G@fo z^;z`foA0{oDV5~38O&{`uU2;XvP!uu@vi->TBmgz@A{>R!Xn*#>QB#d74!$Y?0vRQ zw;xXGeX^rxc#*Ez*iftl)Qa@3T7Xc;-ryBgghBaE-AO57*;mwC#g10e#}#;6skhaD z2qbXK z^CI@JH8e)ZL~MsIi#-Ia*rU`+`ja_%I}m$ZyQgCh;wkt^OKx$)E_Y)Duf0B+;C{a~ z`+IDVdF)zpW?YLkDE{=^V^0R-FAs~xsB(n^+&HCpfNDgDR0HDw>!JaA4I=(Of0_mu z@&C?NGIyEIKm%M@$=$6V5l9F>J;L#1FSQ0`mb3jw)W4n2_7Bhb%xORO&bzeD1M>TW zQB|d0+x*1l0r}d-Wm*xztc1+E-=bsrhCHSFVZte0#&LF?LxN6)noz6-{#jqF1=OC% zEitC{E2sGzGT?3Ivu;5v&l$Y8UjwoQYM|CNkSOsqum(DMDvIdP(yxJpZy@O!_~W$$ z(4p!d`E;oAba1dodI+4s5a=O2gw=aMhf56E-+JIn3*uedsd*v$%hJ_375$yY@iwCSW z)QRdd;D@gnV8Dw;4>Vv`bKn8*J&FOh$ZJfS&XP(WxnzGeqXkA-rJUf(pzw*meqfG5 z8(%W}O3y6s;c-x=#GZTY`At*Ry_uEzT<+eTgP2RECrI44{}f)#DfI-={w(rn6FQwtT6)qZ3DWNgX27N5`8jK2`+5@;Xg%RvhN#V$oB0N&M zNrOb#{EVgzpp&|TDjOf#&Btaiva))Vwq}yxWX?*pEkBqHMDyD9)TF2K@Yg49sh5+r zUZGm#JQ`Tx(Y~x%5wqqt5}+`JEZ13(8vmzb6L&Qf9M~?EBOS~8itwQQ9S&**Vhzx} z^`wW6GJq`C?sHp&$*+VdXtKsou&Z`7cm7Gw3@5?2>0gl6FOV^yY8L+)H>IcIL3ZeD z^kD3?$JF;2u%7Mv=O;w?a0vIbQ+)TcHlDNE^2Y-^Pq|9rQ^la^C!we6aMFHmlripEp&uq3wvTRGnZjxju2OJ|6O?%trCMg;&K7R#K|F-_8K+$wX&s@4KLae z&TNKn-RfvR{+uu56rP70#Ad9}$Q{KDW@{dT3;#bUawa4G{nDrN_!p{+sBlLG;8s7O z_Qb!2NtinPs&B=(rBW@!Mg~0?(pPwTDlE{UvuGFWz#tU1D~N|9Uzd`tzP?7busRvo zf3b({YQHVO{_^pK^os~9?A2<-VX#>dI(X561Ps-{P_rbg0*1cX{qVO|Dze}_57nN* zSyAhR+4S5{A4<9SsY<4VElo(f4t3Zv#!s4Unx+B@y{WXDulTtHlNHs1w5P%ztf!G3 z09~{t68;P`SG=FqVQJgA!~XL4k95$%kw743PzqJ2(*2X^o%B5Kkv&&-pImhWVZ=`D z%1htaqf+UGi>)x%#c67S^vqkr=BzVZLQ5i6-CbMduncXXR8TBgnTuvd>23$%T!S!u z;|c)^QYt7}DWp_~dse8SGvFFOo6;iHkvh2kh|GAnhn%8=+{c0XSnWJ?NbCS12l_`3 znG|n)nJ{q!E_--jDV#Tqr$~GX_4}oj8kXX>t(=wA03BCPA50{82Y*Ld-@D=Z?ctl1 z+3H)ZUpYYiyZ?*&%uo9DKXt41C&Rn2`c#=2{l{nk!i|QANDRv%R0YGTmuSMl zJRo#NEkDxAzURXs>S=y~{VT#x#Q^aAX}hiAhXd{k&XNK?R7CAdzmQ` zK;ah;$&)J>VJiIAp+lh3We+VDaYugcr6ULRJsF;?et%db&zF)=oPU24w>;nca{@Iz ztrg*QCOt5@-#D0s- zF+iL-K^k^j;O+jI;p98vEE{(Y-qu2R8y*}0-ov&6@9|rJ_cO)t-cZsX-hdbZBXIF7 zF5Olhr`e6m`Bj0ij`_(o{NNqMY48MB_XX*ck(=Gxs$2X_Nm5q{ViZD;>oxrVUzWphU8P zMEHSqtxRvd*=SMQK%t>vChT@n^d*K2gny>ntl>>{ta4vR26$lf9RzMtx^Z5>Na%(E z)CE~hd-^FY6QQ5dYhBXP>!LK@&v<7?<9sUcm4j=6@;q>$Qyv_axfoZ!;zwtGESi<< zTL4MXu;EZw0?zn(4YjNiY8By0m1(G#GEm3whm2~KMDeubtGYXFJ|_bZo>AuPfTyteRM2S>g;xq>ZklzoN;goli>rQ0 z_q(L>Y)5l--&;$}jVl9Py9LV8^TEi(Tpa~PswQ!1rzu-BN_(_)McrTJ3bZ_5OY9b>mfMFF zQcu3dUeAWq_JgS}tV`)s9>(U~Nl{bAK7PRw6B7$ZCA!wvC1x{gUDmaJEJvD>=vlmy znb_sL;_?1^gu!Bk1&Ib}kD(pJuDfJBZF$?p z=&dj>#yZfl48+UTAd~V(+bT@+L%+@Spu(GS54-RIvlkno&ep{d$_;{N;%)XOb|x31 z-9Hk>cCG*RS@Ev*KRma*XYtM1(e`A5o*btq4`p}Z3001FRo1zJy?VHO&{)7)#rNLg zOPZ{!i)0fi%igGw5gi}qaB?$xiG}+$bbVOozXLDXz2wKBoLG4Nh=#5WogGs-*!RO! z#;=3#*)Wo28_O3Xr8*O9d-gDlm|4k#3Xw^NW4+nPc*_^n65pNE5K1O~2^UcN8xQ%Q z$qK4%ZogTLc5Iic*d1j(g|lJPPY*3Dcq~8VA7867Ll4{Er6y4){dJvrK(pn@k(VDj z>jz1)qCup%0cX}8+Z0}Ny_>$MlN{E2<0NkzRNnAYb%I&$bn$5gvKo2hRCy*obshrr zP{-#~3=^y|=-XzE7k(p!vv-e_%!qYy$ zB%PBpN%{CLU@%h|ZT{~J6qtCaUy(-omYObIgXkKqA{{fnZZBTvHWys7mm7KJ1Dipl zN(83Trxd2;D~Z73ugp}`QUOV3dv(wJCKn;vy)|9N6dhc{{A8OQ&Jtd+CTskpbsJoOTS~Qh zCADEOA3!%_+5ZxKvpEyL+^Uwn2<+ei84FTyNS0!p)hkOI$Qmf93MO)DOc5RCt~0&z z^z2?LGA{`qUk_(y@Fw3o+{j=2OsJHO&(!CDi~aXD;Vqw!&1g`{1UBV>`|~b2HZLf+lmFzg}YUA$?6P**4ja<)eM$_=AcDw=Q_MaAKtr>&0`9=C6{EVlNt$z>QO zBfUcnb1K>dvB#`%6iis*%L@uuE{pw6g_p%{bC(-kRk;q*ZtK7@36^>N(fAYJwp9H+ z>oz-k=hWiWo1(HGoGMj3dITKV)Z_r17^YYf&VE-xMfm)C|J*QiSB~XH^(E%`?{&3^ zUdW;T5cJf8EXEz4MTu0DXtG2Qn>10n0M^WFwmPiIFWXrbuG`m%L6r!b)JwEL3&5D4 z*fWZgCe_R+DYkf{VkTA?v)F;V6mZZSEX|r~4Hv~WZ&nsm#Qxw6GcKB7}H7gUcx(l8Ou6f z+oD$zU8B=8zi@7=%H)IbpJP+seVp%c&AQ;QvnLQ|y~d%*iG|yKmQOS8+OvMb%vjI* z<1XAnp`Tk_+z}+lq0uH=5W>=rZ(70>RwD_t zYeZ~uznV|B25|P|#dKtwc8Ibbz;=ilMtimpp@l_(`7=Ay`iF!Hm*j92iqM z`E)JDVHjt&6*Q1!4cMA1jYK6Ul>2L~UDMO*GS&BALPYj_$9}2w)cQ>2Z@EhaTDaY@ zxej}<(d2wozKxITnzGwLp;RypQb&Q#yM8+`gg{V+ekUe4kqlxF*NdBy%)u{PC-Sa; zL*<|QxS&KHHgoi)YB^=(9}0<4e*0;yO&%;0LZZd^ha4GANKMSkjlLpiZOTr60rQC- z^N9}g9L@m+)gNvvDuY!}{nlw(+@+}}grp*DKh=>PeQYqVBTTE* z8UkcqM05Do>h%qims3Fqo^RfLzVg-$PgT>Ny- z1;t~nkP3yLS$QA~nl)=Hh;AU|23V6{+Ra!2ZIC@h3F!32U&uRxTBmEgb)NN_y^4T_ z=9VEmnc+Wt{lESNgx@dH7qJVu;~(M&bzqI6gPi``dyW#T=;s}ev6vMj@~_=_*09?Z zUQ()mZwTh1@nuyA3oJjvBB9p|5}P@D%vmh{`=-q6Y|s04_>~z)jLr!Ujr72@F{YWm zd!lE6TBj_2c~k9UsyHlj^ycME$w`^&fz0Hx$>_^hIX-gx!_w`W zmuISH@{C7Y9hM%)6iF0MrPA_0gzMo8r#K3xhF*4?kTg5CJbEb60ch(y7LUg~iUvq=_VkpI0en)KQBXj9l*6!< z@D-vM!|{)tJ;r4lwF4mSP{6+M-EE`sQXK94K_yr z+~hiAIvkVEm<_to8Cz*`=&u<+VCWS-<;RqX73u1@#X+lu>{=naHhgSH*F{5NNB&X@ zi|#UZ6sk&7UbkPo9Sxp6l;s>iQM_3cPk9gEhg)c9Ix&bQ)Spn{3_B5#7|{H@Dr&K_ zGRHnM>vRcqvv}Je5~eIFPPY>d2ct(!%EV@*B_o3!Uj!6ZDcMj74r%f~U8L5KZ$Ep! z%&1MkV`akMeNTdt1CGI}hN1iUK-EySjxCWnl{1kYHH{Jk$?(2o6xcLMXv~=q`b^QG zp4`!rz-CIbDVtJDkY%-zg`Femqbf3E7WYpsW6Mm(5vlZ+^fq_7Tf;Y_X-MF-zvIT$ zTjh<`8b!=ux)nlB>3Cx!*%{Bf?xkWWA)VX;(1tIaa_Zgo`mUx==$f3 z1Bnv(Hi$Qh_mFRIAiQ`a`Is4W;TTsToZ_SmWLw-zw}I%YiyWfg*E86LV;M8rHU{U4DZHFzYpg<=*f#NpLFrgw7yOQE?bQ?WNrqTuRT`G+txu>dS?ROmu>xW)QrQw)s zt(`Yd+Z$6%nM9}XK$|@a&V)C;4k0#iic^BWVp{AS&CUQfMBdKYsN-pw8m?sl7cGU$ zPITU>)&zvX9Qhog#5s#KVIx-5prgcs)}gC~e6VB+RAWvTQ{|^~Rk&^-++)3FXw*~> zGm8V^_C@#M`&pnp#zDIgzt%ec-5_|0OY{e4(rNILXp0iLC$07bR8k(54^D8X02s2K zN9CTu2$g9=LM74HuC`Rtq(Q3+YVAp?6}(zB7yFHmLX_f{&J&4zab}iv%vB(%BCgo( z_y~qfuCn&u2@?k{ir*%(b`FI9dCw8c``AoVryAaihOshDO~aO1QBuZFGN%YFj4ngg z?+{x2Z-P@=>m;XU7L644M=Od=!A=pNmE^A{2K*3B;9-YD66TihCPZ`!wf2x0>e1L2gS zn!-I_g?p2u0HcV1=N!IqUmNSVsg~gfDdf@jZ%}tLYmG9!3X36EQi>gF54ULKBZd23 zVQ^^vN80<3Z?EN3v=j@|J!>a$v@&%C;4^?h!7`f6ONC~B>1BDibh;DDCReeV8oJ-*@xA2oaKSKnx(32@QQZUKc}4eV#;WTh z&3JKEfo81P$gYj|4WzOw&8~f=q^8(ThZc62+#31Vv~54S!*u#i4lUvk>lFI9EgZAX zLgf4YhOT7`L!Kh}IOjCvu~xn_Dc_ltd%~Ech)W-8XVj;1r#Cbay{(&Ihf&<1c;TTp zW^J69FVeUrDoI>-t&Qur;u5FXS285?Hz}ig8}1`uW=4+O%WM%mi8*(wjgN>wQ1W_% z0VtzDi$Cv>m>${=TUJuqSOH+A!~vcyHdVNd_b6MEKvC2>)gPjXzj zPRqUzYoks~qIdV0zvDEQkyADdrr+b6I#fIJW_$fBTU9W%ZrSVwlpux&tjux5S4U#V zS>&yi1J-kxU(-c~)Yzvl*fW(mzq~QC38(mtO!SUY1wBhDQX4psr#R=#r}r7u0b|dr zUkgD(Rgg)UEMqUH5(!SDr861eKQE<@Tbuj1%F4v0JE=(UO$`3jCcbdIDT1(HIhgQp z)J~boozBO8v1sBiavMQ>_PbgaJ!(HHXUH2ff0TRv%Y{3e7=>H;txi~54XX$7H&$)J z8zQ`?euyynGaKG9_~tss5&vOWQg5hczf6Nw3%8R6(0Jz8-2|0?yISLT*q*3=ojJQf zl%V*XZg~ec6}mCza#Iz4_-CYckVM5=^`c)*1+iJygnCXnBGQC{ zj3B>yfhO{c9IC>r)dY2}qYC|$R?sxixy6{g-)( z_}f?c@%2bErJ@y9DTyj2!qpErUFB59j`O6eS2)%O$2Fj?>`$5q^egQ|?7T`oVmp>y z&Y{(&{6YNYw?!ZUbc?-q=x4VD77k1fFg4l)W;MC@q6rmI#w_&lGtYNAcaPryyq7Y3FK7*c%t%cB!GI7&Bu1nnE>b=-tq;}W@i;oUYW zEC^Isty6eLy~smhk!M>ogVD+(4UzG*WU1i|uR9W9_8Bh|IO}|k!;whdW(zhou*1qZ zp5DtzvQd7(KN*wg?XqO|`uSyv-gckuY%_T7_R7398NQf%)-gA`y}$V^FXBGEEyEvYAfws;Xq$gf`NeNbi-^ACDHnfY z@&DFdWRmJIN!wzQz~2jF`tj`Rc1l1LE!5ej9B-Odp@>I3t@UTbjtl+D&+_b!lnCE@ zhS1>&`|?RaywF>tJq0dg_{~;use4Twx?tz!=}O2@t1Im{*mD{Bxiu+E%gAFto9spt zEfmQx0JgJQrU|P_QOTOP9=LANYNcWQYO$W? z42}#_HJLj-9HVPCJgH`ZroprcTdTu*^o*nzUPK5NJGZ9U1g~=Uk@CN&K~yE?nF{9n zIEm?QYUg{8ro6XQG#gU$M%xdN||XD7L%Q(2N2VAinCSBNCac%&6n>RosUX$dTDwk zAi{s#<9(l?Y%(&$2VX3WW?$@bxr}ltmurW@T*4?^RG6#5i$`VQ<%PNGU9L<1 zTH4}_!d!JOSNKwCu0slQxlzNpHTB3IYq6A0rqh=MNRqn$J^^_IxooO$x z@FVt`)bhfrL$sy)VFbA2`wtaMvlW=x}NYIW4q4nBv8Q2KT~&y3mKHPviQ{n0uO=%<6eIWwl*y>7AB z-}SFeZqjWnnK9WjgiU9wz24lvHi1dEwPwaV>|VFoYxOJyyGcsAtt~U=*Y0(by*|dj zHW5j;HIY*?k-q&Y{x0tlLCYGb;l2$UNTHUHG$f@eO;*yj<7`>iAP<=iy1k2Q?`JZ0 z4b*w*dhexf3^~hnf@cVc$ui)x=vtcP2Fo($+@mzWfr66TsG>QB*)hL0C=-9}2T%Zs zF^LSWDnr6#91c_I^laVYLErp9S}q$L*<-VMd4pULUb>wVZ`f-#Sc7~RTjZ?Q)vZ%Z zg38(x1rFxVBG^6IXCrHwl)_X1p3JmJBTo%ZWntC!(IzIuUpab5WGeR)%)yll$RGvi zQFkldt=oKS(t{)GFgpfd3%W`Jm3C>DU5gyIQ9 zVzzEo*E+j47`O&z&imo;dTY7_d0_p#du#d)%NfyJ?Dt0cx!4G#OuuS{xz*pKZ4ua= zPe9yjCAX(PY`w>ligwIZWECX-u>Hy1A8fKoV)i|rZens`;n@|Yqss|85`UPo>B(-a zU<`RqwxI&;2PMTw!7G4aN790D?@tw^z|!);Ul&14BLQyIGkO+E?hu+k2ITzYq zv_-LA%ynn_Kp#~E{V)H;ZbpBT`CZjW;2MUC0yu=1s%=rm#zN+qqal^TeX z)4s43Jst>W|8-+&09~Titr2b`LGNayIP*T{9uTu?ApwL^$U5YbM67?!zU0ybth?}5 z@#>@QiNe(fqL&?aW*53N!RmHoRII9nJS4Xn?D$D`o=YoI4O~)z>iM*uy?}d3WDcDm zHn~njis+%i)$kHjbRfLxg^e-8%q)IbLha2=Dwyk~NCTiQK6RR4A9T+5w~x1Q%Gtu~ z4(jE~aGIrRuvcDxyzR)A(aYpy%!;z?N_E6?LusG2%+6lf7MT32b(19yzKQGURCOvBaqKTXkH z3W_>ss8$dBG(}ffFJT-iai>3+SVc#Enxgs!V+3$22k>$Wn?3>8Z3~Jv<%-VzG)3>W zQ_9-vjMV_`!VdxcjZahjn<}1m_^yCsjzQaenxb!WNJdoDMNew=nS&)DpMdXGDjE=- zNj?EuhQYNw@6#0D-HPkP^c^W4#e`bQG40b7U(6Y5u4oi=9!=4mhAEnDv#hT3=7LuZ z)x0%vV;r-)ll5+W9U^<19UHkduC0A*23`pvj zzwi*f+P!%njfEG_7X*`PLf5%{NSx_jGta=frAC38I=8yg%uQUdYU2d??UqH`D$wLb zcB4soj9?o#X8$`~0@tbpKl!76m!#V2y|z)922X?O)M+aKC|;oq;f76wo&{vqnY7hL zT0t7b?p&`v4@?5=mXg7h6(z-7+v?A%U6E>mu2wo8|D~+7NT_CO^dhh|1&RoHl!Wev zi2C+r;eYt6HXE!sRXGw&ax8Eppq}vUGYbalh&C9{l+-RzWtp>6QUWS3=e7)8Fq*d4 zFr>=RfCW}UDH;CrObL&NSHY;5e)C_79#;63E@*~Z>Eb!oy;KZb67IPiwpZewjO`*P z(n1UO z;p=yJJ^qyNGVpvTK-J8aX-dymeWI$q#aCU3Prn8ILMavW513_vf2_MKYCkb&iReGv zdaHiNI>@^PJLM3tv*$+L2gA;t2SNko;N75x!tQ^#&VRH!fpD|^^MqAhYJ(h*c#?)e zqtyYztv=KL0FS*8w8Ul=|$ zrKo$0JS`ntWlxC(P3=I;2o7ugik(_M*D0+XnSojnwYiHIJ0q!Mw^vFJN)h}l*P}G*M^LBl?~k)o+23f42Gii6LWqh zk`=)qDmQ=}I8R|FQS-`aMZ5oV+uu1&XVMC_9uBeb6}XxVb{g=on=Z8EuxM2(8O}ca zKO2Vb3xB-?PJQJ5s*4@`&|PeYhNzq5jfu|hGD2sxfOydeowZq!N@MqEgT6&9+g})D zCaEqwuO`2%D)I3>JVXX5qgYr2}6hVFE5dMTxFs z0;VSMl}}t~H9VvloE0nWm z`!g1Rpe*T&>{-0)9D(5V&YqsKR4k_k*9>fl|xL1SnvgX*)zEh@G3OOP(@w z**fDa0hRn570QX>?7Hl+==7P7s?hoe9%8FSv%WX0oa3$ZEe~0FSbggVUMV6#e(ID7 zZ7?6<8*VDhZ>(=n)|C2Jy`lj9D}V&*s~pstawPPCONPCTZxE?P zZU*dT24P3f(pF9yi?>?EfEsyp3nj>9X1z*@@QPn}lCth@`ebkr41vMG#0BTu&vxLf z%#JkSAs{jhnQ0LonTP(K1B8*=5*Q*7H+mE9eLs@39GUhSotK}0!4OHA?H{hu$PoL7 z&2!%3he4uiY74!Cin@H95Th(qOi)5M$i@7jdIjN$Kd zJb3#l`pYG^aIe-4;)9SG4;CyC3WmpycY1&nnUva`h@bO?^L9iO)9@5&%pB6JDL#g@ zSY{THyd_GsMv1m4(P;@p2HCL4(LQlt0^zMvXDV|z(x5F>>_sl4k>Zi=(QE^-uk{3O zpsO+MIp0OqKv7|F;!}@t^aLbUc_ST|fSeia$Zdp)m25M?{IRYn(d!NmLcEL;ZuOyo zpn8iz`0W}8LMn)K1F05oia?m^LD0hp1n4ag1SU_*!Y@6ZgP{G}Sc#v#q8Twb4F?f+ zAB>>`QZ!0AVcz}2oY`wnC@WeAFSGl3`^Acw!H$tE)L}5MOX#p=nhUxTh2m<#Hmwyw zb8Vg;ECBkL!r|m+v_VJp6%x3i1iK?XslKRi_|DT-pIHZ!O5h61#yC;-*d2owg)iKL zJ`MZ5K|3$<5z)G5O^f__v;29p$kRqVlEeaC`(q6xdpp_c?W8SZ;DpD=l`|=_RB1Cv zt=kN;wqTBBCF|%VdCquH52o3hy}ClPSFam0S>!RAAbF;Yu|F>H-6q;<1uB5>B59IQ z5#HM>#TMK>+SmKW-Jn~AMT!D~0{bzkW}P!0{}9p`4_(r5T-U%~>AW~wm3K%t-zn|R zJzs6v+3n#FUR{VVOYsfipz_BDmV__e1vTWPBWjfNFKm4;25N>p ziT*f_=25@xch0cE=KeM*2Fvm-Ca-|p9MP7h|MA1$y#vxfH1ult0~-98^~8xeYXn|N zJQiE`15hL)>$Babnb>M~-%&9TerbgU2BNqk*O3i>@fSTes`x4Ca?v*_07nijhi+G^ zl8m`W`6fw?Q8BachNry^Bj?W?%Ft2?WJ*z9)ni&5n&M&j-@UcaF!oJVrsBCp>#=(- z)e1^wpLVy+boWj~>;}T~mlr}DPG1BI-pjL~KpuN*Lanhef7Z_gr-m?W!h;U6u85?r zh*^Sj@T(xdt}X(hi>)jLVbdmeI4QN~MWDvp`lH33x83C?Ze;J?(lT2awZT0 zLm5p**%2{Wl^^;tZhq94DQ;l1Tm#?mna{DA&|x!gk;|O)nfEKqtfi&2o2PVq^GpQ( zzZN<0*DxPS-|fsM_1zME|0yrTraUucRQLL_2C~dv#hY#hS~cCo7T+=|p5(&Al4+}; z`m-l!o&iyDGgzWUQ+W6nqu?MDzy2D5QJ$!XEg+THx}hA?$G3qumGX*^naeZ_nQr2% z0hCQQvAV-=o?`?ld(^3NyKKJ|Bup& zaH90Qg7gBPZp<9kmiq=G^{jN+4dPW%TJ$HRYRvEvLl*@#X0B?b27TSIvoZ6X&c^gf zcwWli6qO-eF6#1AY^O-Az}qDL?$N+dC|hHCZ^tUZu84`LcFx0F>H<6EFiDfNszRWl zC&9!9xlQB3mCN(N)zOk4kyX+yQj0wzzdA}*gkeA@jH5BHwh*#-Ebzz*W!7d2q$`!J zR;-1T7s4^G5DxLm!I3I}W10}ZNv{It4J=D;g7Z~&leqYzKvoGwK#L*D;=FhJyy5dq zY-LZvB$NU(Pza1f!2xs6vK&zoy$>l5gmJHX{d%K&-EX>WIE)nwI+f9#Xlta^I;xIX_D7bB!Fbt5#a6za|CE7Z1acnfrVv>lva_bNt8@d`0CjZd4t9{ zN;uw?YeNFcO<8zczWzkt*M(kD89!uFU=;Vr7wGs_Y34Qu1#&Gdau}>b1-#4GfTv$o zotdN#4mM1qhuI@bfDM222!*!HThUY%j)MpZ$B~Y9_i-yFLQQWMD*TjQ~Y8`*$GB zmM+q@?zZG3w*l(UZ#hEbOQ;1+)Ts6%LQts1iDFb7J&)h{f+LRO;@1Rb5G{OFHx8E8 zVW*9^n#wB+_cq>s@sAr5htm|86yH;Gqo0z?RS^jwlZlWglSz?J*F|~6P2>J^J_gAn zt$KvC>L_R%YgYN_?z{5p3O|oN*RSI;xnB8`Lc#c=+5>l2S0oq_?zM({L&!pfU71H6 z2zR@8V*(6>iD93vzh}6-e;@Ygqr*H6Z@Pt;{U|0#={6O`>z#5N7O(HBz? z>_FvVDIUajzr*)x;kU_XIQiH}vap}XxtAyyKwLJd;A5GUzniION|V7;oAB(5%KowC z(MC2H7G85>K}=N_^;l$Q5xx<l<>6^rIQ{;-ZJxz| z&YDBq&|UcC4pHb0U`<+Vy9@a<@v9Fd=zpl=YasOOEJ+k%7k~H53Zo-wa?(8zuBCsW zKCw(f?s#8krLM7}GH#FT>IY4R{*Vgr>@*U=TJK;D{PZg4d)=1jj?LhB zN2R%ic21jc%#YM$ApGtyz$6w{-g+?TupR3vtL+MJNRC6y%_RTn6>2-)Gh%iaHwh4Cn+vb*@usY~UkF#Nu}D~H$4 zrgK(G?eK(~QKdz6bE6T6B7LgJ=~FukjnJnyvn;pxWn0lTcI=}pMo?RqU=0L|DMgDc zvy9HF+fXOYjp^G)wFL1MmYt!AZxv>5j~T|mrd66mj}76r%shQoY6jKtO7t2Vu#=kFJApIAsghx`8d7OwPi3er83 z5D1p${mXRISDR*ttrJwEy<9m({CA{?RNQG5Yh}Wi8%IkY+My1D0kOo{OuKm8&P-pG z@P>*E$2Fq+>hgVCt)Y}o=fSrN==76)w~Bqgyh-tskhVo5#QiBz=XRGF;=AwOZ`|j) z=IO{{-07Df&~1>#SVU1-17Io(4`1XghUyc;1t35ho1>YUaF2Tmv@lRkVC=H1>7YcF zBK1hdPLD`%2u*{^-`ygc>&G&wlg>)`m7Ni%AU4l($w|fHztEfuV2M81DgX;NS1xWb z2lUMhb!!5&?Z%5~_fko(Mb(AiH#zWg2Jf`H^U(L*E2x8LQHH~ppj7zg3hbXR&^}X- zoz|0Rqcp{1tA6d>32IFDSEVDmRfP92^AQEVHul}7m#x{S)MLoR{&9+i$>M*}1p{j6 zf#xS+7Pb#c>#5-EldXc2borzTBKnbU_y(%uFC?i(19sv;5Q)EbYDXQC?$O-4CH5}7_vaX>Q&?H(4OD@B%AJp7 zlgOWRK2mCt2o z-NdG14}9X2kv`d6AQVF&irw#s-%FX~JiR8>I@v%<>XfPo$1lvuVn=IH)}+gt6T;vB zA(ylL%W(aIlZ@*>&;@QPh>>C z9qn@9oyvoNT~K4bf_^4S)4Z%ZL%tFFJi)<~7*w+Yc%^0rS_%fK8U1Tus?^aW5@j;O z2ZU0DwX(x#Pn4c2do17u?<|XVAT7 zfmL>k`+OB+OwNJ1;i-Q!f{!bs_l87E!@}X zLC^c2;ghGN5(_Vr3x%{Chz3kbxqefOpJ73y>v?b9uE7#P{14rlMZ`*=8l5GQzt;-|K~+-hu&@vg$L@MgffQC- zs&}C3MAUgJF7wEOeh2d^z-ZlrmIzbu~m4sxqfi` zvVt1D8_QAQ7rsWYvXzw)6;8Jr!*{PiuJ^$Y6wC7pC(qX^-sxWB#N!qxGsv^a4t9D_ z2o=nv+%?b1v!3VWx%Wfld6`k0+6PGF_;pCN5ffVWEZ5g8FG-C48RZrT+~NSVdC z&5syCy|9a8`^H1w^B$3^LrG9;aFoP^ARI;d{@s^y`kv_9-*ih6ih{QU5}*plV+y_? zjb|Mh6ZAK#X}`RWFLZIpZqNEnl)-d8@R zi^0Y7s_@e7S?>0m)bg$_%288Uh7)cJN~}B zNg~vn;&rE!%-F2Q@_NzcK*>qOk5&yYW5?fNG6oc(T7@}lb;U^y*!2o;&*Il#?*-UU z4E!_zHx=P#E%}%!mc34q679B7-q2{Z1ayX52qFoXCHejhF@`W42ylSIO(g`}_B=kov-$yzch>%`~L{+g#+D zPII>p0Jv`7=1S%k_qKPoyB%S-?Wcp#jPSs`t@zLI9pRL^yw-X3}H&1 z%Cd)=!#5)$&9ylhGDu-D!U{IFvWBB3mUW2&;@!e=AC2I1e<@P5Ple!(HY%BKM}${9 zU*0@vgbd#)cfovvTVE`)m8ZAJ^q)k=^kJKt#0K%5zbLRIn?<%TPsoFc+R2kKd}SWu zG>FXR<9U;xp9qd&zCl-D{_norF$ZFMk?5EPYin7Wd!WGu8_T=ycy+6=MU_GMBwkp; zGh&4Dr40$?4981p;BB;80%M`VWe;CO5kiP*7bFrBcCGg+;$?(5_ znS;O9K$v^E9}&#Nzdd>~;97U$sy4tyaIjmml}u&)g#otxl`XKTNpfsWj#kSN0h;Tc zg##60A{7q3oPT(J?%}V(Z~YXM_Af%I1fMfibywaYMT6eMSb;!hS?A%Jg7rKPPhpVT~@wx(?pOKh7HG&JDs zeH(stwY86M0#v7phRNUi%Kbs;WM_~?dmOvSyR1vLTOy*|bsm+`@|Sw8*6Vd+7M`01 z^yL~G#~I%6Onjn9F9m_x!vxuwqySaS$Mf>=)vd+j891CCmVk!Ke+*yFvTi`0ANZp# z7cc!v{h97H3M{ogYMr19+|>rRoy$qE7)35s*9HD6ccA#fELVX}oqVZeve!=w$RmPi z((2a$k9r61#8kBMg=6qN49@kQ zLJ%80)czHA5|p#G2|20ne*fXF*V+@kR}&6)zkgSJ*Gm(jH57BzOHT zDg7O~Ki~5j(CcCq{?9`N7CkAw@3KtMXjHF9!|d~eyBC_n&nsh)j|PUDjQf&5g$Y7I zpzJHywQzlaHy@2g4HGYR%Zq+|eD&}}juLIeyNdxq@ybd$Qd;OV*KDJT{;O(C`&4v) zP`%>6*CZ}_1mDs9!T1T;tr8bK1}C~d*!s9&WTNj6;);CwjYvyzf-|7a8d7ANpDi1fKou9Ld$OGkcmPA6#+$sfoV73Iws|Pf7%1w)l>5v*QTpIvS4gEPl=&`TirW zIC4t7EDNt%UQE|0!Yu{IOI4pO6hxDcSJy(K@azFei9*MONOVy0b?RB=F#f5V+4}_A`CazHbYxLfETcLEuVYA6EqXUZ{Nv5z7a3AItL`>=CzrZA$a0%V&?!AOV=` zEM5n8c9JC@9dqx>j$I3p?fNKWA3ybir#SCl-n|gnmHUf0#f&;anR1NU3X36RqcHKK zWWfvgM#yeOnDalBFG4o5XYHq{Pk>x?-)ttPW7M*)#c*>(b_*OXLS65L`Z^nZaGft= z{vx4%aOtNLY6;pE;j#T#=Q4dUy*-)|3$4e&9zM^mr2+vk^TON}7Atq_ozkArqMuf?m7oIsQo=UHfacs)&f#zl=l*6N1K-^og zwP3B|YKeMF1hH?{2qjELKu)o=pwsdG;$l%&hnyURC_S0x!|-no&G|UOg=h7_)GrxR z3r4W=;|n(amU8^1Gdlxvz+Y&haqxn%g8gSX{sIL6Lx@(?)g0UE``nwzR5FTU6#JF1 zWf`;`PtX?O?s};3r3uD1FIm>DnM1laI%s;NJ3z8ElN#mtP!AL7^)ZSX6;D|rh<|?9 zyflVfGXAAmT#Fp=FR5w8g{ccH` z!ze84h2mEiQ@n)UKb67#g!u0QM^$R>?*d5k0GAk_)_*3^+pCnD;ZZ0rhO}iaQ>QjK zZbSM?CG@G~-UE~`s9ZBe@=lOmAnMvgE19ndU%b!}jJDWx1kLN!THg&;G2QYsgWccX z-{omby;J z4`Go2L>&MzmmBBYm2a2%p6=NZNJXw9jmLyf-<#tJ=H;># zN^f{Lm3FDVCoY(h*TKqrc9IUl`QYdpbWkpjx6azXRDytMb&<7K-WKW~)|K$iS>ho6 z`wKUr6&Wl8$|PUpr_nlVG+a{c&@f_E$ei)b8))h#X_((9>3(F3)Y~G?6d3RD zxml3;7m<}Hu@9e9N3Um1r|dBb#~&NvHIwWmx4<-Cd!CN=b3%M_&pNt#A0V!D+2=w5 zO)-~Co3G*7K2PlPJO{WW`p)Hse*Cg3_2UzLgYc7*nc74fL z$Kgy8=bEf063v#Ne^^gQXngV7P#_Gu++C_oUI~25u3Y^6&cZIDQ!U9MZ4TE(oPHNW zoF~Wtu8g`vEZrTwl=;1t5S%Zm%!YNxgQeA6I?cg5{<(Me^7ba*F-|;({wD2%xQr> z`N8&i1n7Df)xPt`);^uu z{pQ#?jiiTej!-*@yYTw+u^W%lB`P$}1@<|Z6rI0zDzs$2$Y{)bk;V~P^dB5`D}?BmXu-9 zJsyS#wc)PkIdxTt*v`-a{LrB=)SKdiP8=u}Tn5-(?>(29UQ^50NiR{{J*y!FTGWHF z-DPIJf{y!Tdu}I(eo8NLNuc$J`s2&sj0?kq*te@bI=bsySZqw(__Kx!RdH#hBcA0D z+_6uZod~!1A$;jTfsHSDdmi-GG|P_I{*?EL)nG}jI0H+}F2EAI!jd{YFJQ^CvmHy+ z^)=*wyty987D(CUv?`>o4blXQ<=QmsYS}aU@m-cpH8?(9-%@EQGOR}%y$GMCr!sm+ zE==LfnxlEt%nggQ54>x<_&APO>0Se@F>}#sis_h?at*nMD}L&Tl{>i1TpXvDadM%H zd+w*hGv>wA( z&KsCKii;^RX^lhbC+1g0=^*}}&xy&3z+5R&slej>?9Ng?H&9l5ww@5eV=U=jDo)vX z3Yo(;RTbe;*$>Td8>^5A7Q&>xC+Recb<7@29 zwq@uOIXxWo)%!jaWo0wksKXgXJeL~#aN^SY%=hFF)0yw91a#2W%<POD-&3 zDjU?=YPz|H5zx_UXi(05BN;Kdczmo{FL(=gvbN?pFQR^*SBH6#4w0@$i z?5cjWmila-`zlq^TDGLMxnA~%*Vzf_b?#$5=uW3KKx17>@FSQx;F@Sz912iu99I6O zSj^O=#rSkt!Pp~rid@KpDT|qNx5px>R`C}fPcGB??A8Pr)O_y6 zP9o;{Mi+3cQ#y$C{yZ-c_PV&yAKx~-M4ZrXUCUR`!biTWDY3kNwDBkV)OF7=>y64& zne-wxon{E)4>O#27) zKm>61!iF-{d6CEHx2qdAYw){so9sI=pac8PMBLgnn!qQ5jn)VL$XXd!)94}mMy6lp zuhAMcvYF-Ho3Bo4xkfEh_xq*--!xVt-1p34So+${A9%dGmx>&$4fn%5%}NN8+e zGc1cbA$ffcdTTlbp~bsj)6D7c`>{n|1#gA%?$fQ(8W+f=_!d!yNOH=iYP?1CJW0yn zLf4!QpfO;2H1Ei8w6ZqyXgW8r;|gmbvGA%E8q)5~S(~$t^$})k6q)wz$elIAkdB&Z zubH7*+KP0p5t5Kgj|q;+&@QUd&E`=P^RAbV_T8P#-K&jyGYO9+M9*HF(;`Mc*$;4f zxhis4=g#k~=ltGdz{X+?%+!)CW!2G-Kw&)<75LlNZgw>$1&*0?IT`tGg{kVDl@?=?4SS&B;vl z;VK5Z{;uv4Zx$#=y16z}J(@Q}pLKeBrGINUq?^&Y`EJEZX1~P3b4K>OI-;TL!x0_q zZ0qWx0yDwEn33noWR5Nf+=Dh~>9+8OM{nmyTp?%&D5Y<%++XfS$ttWtEx$-lsLI4{ z;&CKneugU*oY|zKua@DvQ|W0+PL6lXWy;{}rn(0)( znhiDX^-B`v$bu7`QBkyl1|$|vVG1+ZwLaM~KF6kLrT_~GzdAF=m7B@V(A_(`B6I$z z#KPmZrpq|0p}(CyGt+Cf4lf#|+9Cm81rWj15$ORX)ZaLsLCs9R?lJ>U@fWu}$397y zaR*>&ka9N9CEcBwDdmJLq8?Gt8ZIU!q-Ck}Q#7>BB_UmW%grObiB{(osm?8Y`d7xU zN|h%i`A&7_4y!r^5UivLS`xg-u(c`-^b-WDEk!zrr_1vYs8osa?&%>&s`5`%UdKoi zHQ|9JGge{VD#ETfm4i!duBI+E2a`a|pV)|-wMn?XWq4#HVgWfa)$hiTHmn%d|GwLK zA}zW=8Paofo65M0jMeKV852`1ETYr&eEX)He1JF|*mE*cHueKnT3Ch#K5)H2wFVbf zsJ1ioG<^u_!}oX7hcraufC;MAfZw1sqfbt_FF*BeLYT zGvbh6q@I+@)Up9DskcFFZ9OHWMd5{`*nkJOB{TXdEt6~M60@te`jscmwDxXz53vfs z#71Th=!SXJJgDYSQ)yXeHTC4-zQoXrL}nHCf}D%2M(POfSnX6-49kv^r_~sZmHnx` z@_|eQhS;4wU0pq_xW;(kV(h@%WGjFxJnH8J9-M$0dp+r+0i02}Ax5GiN>nKke(oEN zKYYpc*PBR`w8JyF>L%V1O@Dzs2}+6yU3QIxQ6T)rhJFQt&|Jf|IV(Q&cpm;|?BQ^Q zzhi|XrJX;#(x$O}0$z*>_qxu75(+W0bFiFz+y~!3p*g$Q)>7gCWX?kE-xG5>BN@r| z@_xjs^n_IQgrb~dH_Ew_y^lDzee^#2GD{uJ#UNZp5Nm1ui;j4-?uc!Cqj6>v2B@{m^&6~Y4m(Pb&M)uzuTf97Cgd&O#Zw4XeBoPzi zw)ZBHanl@4aahuHotFyH@slmvr_`hHu9Ju{f6kXt6k`^}m-=9Vi!W!&S9Y&y0ZMfV znssG7)voAStL}*-fwzqrN2f%n3#c?Ln;~0KR`8zkQz|BhS(yiFY1EG*@d-y>Bx#BSQ?uEC=A2*D|FTupI*aEl3Tos!vkm@d zL~86yiAx)dM$szNnd-!7%dfr}o}RQXWZd*~lQOY4KAcoGS;3Yf3mCd@Dt)ibBZ%Y@ zlT7SkvM9%IEQddwj`Qz7pYJp|EZjHs@XS>1!)Cc@-8lTzb=vW0VdYPs3BHc&o=(3d zI0`|t@k8t3WhoWa7XSE|B(#Ocv$<<8OCY^ z_&T9dKPBiiRE%5wf)BsbWSf~HG*}mgFbwhz(3f%%^g?3=SN)V;>5?)zV>cXRx|Rwe z&kxu#@aB}l=jNAM9g#*RO=MALsE8zQiN6u0wbrAB+Y9{55Z{8Q(kSJFH~@z!?Zo zpg)KW8sN9;VNHO)&MzY(a>L?ItH_)=3aJ}KzoMf5X!;hmDG40vMJmyt!4eFq`EUAM zd?IID_eWsl+YfT*XB?nN_an~FAWqbgB9eH_jZ+@PjUeiF+Oe?vSwHbuG~H#}2%mu5 ziG_1(?jmb{iijv~=aZy`S>6bgqyBfQGEfTd{b7!Gv}#(UB|Kvn^NnmVkIB((>~42s zWkV}ZI{qo8tINc`^8O^mV_K`s)4!;Z(froLLN}H!Q+%VIWhSUhqW3=CFlk%A@ucmd zxzS))>`%K!*!wX7V8Wgep;*iu&N$w|%fhh1_9U$*|b)zGu|ds z8LStC&8_SaVet;f!@~t?!j66S#C$~^e~_Ba6M)gF7Pus5o*uF7%~U_M1l1MYAi&D( zzGlOeNoMWFC{y;o3UGz8DAYSLQ@y1@a8_&Y^Bs)EO>E6Rs2pj9eTqM4L?x|2_9iP{ z0!s;OVeNEe{RWLrmc%0|mA3J&*VvPfh`G#+q65( zxqj7$1{izZ-z?GF`Z*RRJ&&dzL=Uoe)wXH|=aK4rH_^AJ-OWVW`Zh3Nr#l5!pCzHt zMYw+>Q$AS(7!w%Qo7CS}GkyX~v8j2}MDN2oaJy$iEYZ6iseRzTI|r>XsQlowyWrrU z8m6QiaLuNeXVH@?JqdSjaIy-<{t!}ZgCjSw-1c>jIC#cr&jf5!I2UyQ-2|RRbh7Fx z7txiAUp}I%Fy7@Ny1OHV#8g-|qLI}qNkkXg_0H1MrY|ZeV&a7ci89KrpiaeYuvw8^ zMY!p_h@-|ym?+<4;$s?*To6}*ty-h_T3vaF1R#Ln?^)iWFs5FQEsXKqXNzP!8HT}s zZkhC!dQI77mZm~$HDH2)G`njQITnBwRNrw{p=_C8#yOeDsf1}m&$>|wma)O&K@M*@ zPz9-#eg?+3DF&dG$^ku#uMh|(#*7?xS z)g?6zDxWvSQOGCB(I`=PU_o8Ps6MdExb=5A`b2ZU^Iho4gnRIF2}Gu?Je8?WrN?2c z+SSCEo4zL!C<;>(5Wg&Zf5|$t3bhiyE}ocfB7U$(K1&v|Q%%WY1MU{VM$pqGlvIdxe?fX6N(ZsSDm?XN`BOnuhv4Bx6_}ic zckm@FNt!jqNk4{ua5z%UC`2mwCQCM%E^#EwJ|oK=RQ@xex@ZIC`VE~B!qFi6 zMRQ1=T2yr(gYf1ujZ{8u51WU|S2gOY!m5zLvT(P8 zsz&N~vcmFRCFKw9C@gPs`3j4aB2Z#(qOqt7_vM{CeXsKnh<2wN%o5!|c>o}?2dHln z#QxE)>U-VF6ZqBy3v7rqh+VVQu$pp(%WKipX-$wbh`s$=ElVUWIN$GsK_q)!?{ztC zNg^7&d2Xoi_f`Iy)HM_T!oMe>otn>0^o`n*60$00R~ad++=RDU;krmOQJA}wy{Skn zbnb@Bf&I&~fyEbg^iF)6W(Td{6 z33ZvuxoZW~v|2U2yG=9sWBSumQP@f97+>Lz)kB#q+zhH$4Em{-GYZ>Ym210rlI8K) zQTx7+tc*-dlxJcI8kY_1hjNm)(B6#5#NPdvpqi@wdf#OK(i%@sFstw4lL4nX^V}Po z6U z>a#DZ_gRiRy;1wEo}1l7{!Gd;XVS?zFX_fyWxT^fI0{JWH-4OTma(bsJOj=;l2``u z@0~Nz>IldEN$11Nl(D_H#%e}SF?;bFHc2x6z9P|gqe^5BrFz$AESAovyPR}n;v)q$ z46#arR-MS^I>!Gg zt8#WwN4lv#6T3uDkg+3G69VXzj;OrDHB+wa@2eizv`W|XapjpY$J*N;y6@F5u-C*p z1`Q{C1Y=J5P@R;~HR0iY6AsGRYr_Z3lf}1JqYrg_UHWf@If9zk&4#Q0JOcMEy2o6# za@9}iwkS==U#IuoOBKSi@Q;{0R~_Cy9Buo^U86$_%td1&9gMi@a9jW034o_?M17BJ zb|3Q@qp3Q=o~S!~);2nOVnsHrw5T~Od8!;$<)p9qn4;M^atl3!#1kN6-KH}vdogg? zL(F>sl)3%J;j#?bC_J672s-ss!Y}y7%Z%A2wO(&U)Ud@$v48wnJ7W}yK9_M55Al6w z`!y_z#5G7S&&d(gxVxWl5UPA!Qbp+7`JPX?wPeevv=T0;{&G)}TCv(=?vvG)roic> zvVA%)qN-czs1kQ+s5qUf$iyFdUGkLZJKy7Ft=h5XJAX+|f-b-^+sWgdgu=2?Cvn6D zxgPfSKaYihaLR_6Zpg%1)c{(uR#FH*4PNFQGO@#XBb_z5lFpLr7UfDG#t2Gm{AQ7R zjlPXwwjuWXWi@1hcoutD!0^;Ljvz^bTBdnLGgeza(cVZm>YN5Wv{ft-gG6~8rLmx@ zfkb%JU*GdA0CuOU6Pi-#71_g?Qwe|nb*<|X@b+qXLldG+H)}DQv*3quJuF)$7#ucO zDLZ+J$?cTWt_W|*@zW0~r=yW_YA>qGHP?-7o50;}xm-Cvvqhwg8k*ly#2f}bi*slm za6nim+|W7^Rt?z67|hNau>QH5efj#Qtl^b{xgO_Fq|5P-DXn%dE-1A~FsaiXK4URZ zG)zzowMy+?P-Q^=sB(05lRRqxCX`fJPl9iG<5M&1qlUop#SuSUeZZe3( z#)Rc|@GIAKIt~tfk(`9NTv>~9^0`j1Tn|AY?s;I^d zOahKi=(Eex1vFYmkR*B+C>J0!$--wiYPg)(tCf2205iDo&v^qSe7ZAA2l1OjIXtik zTq$SLq%q1I9yTYZX=;!<<$3f|T3*M}YEtcEpX7Bk09NF2Ky5V{Q6WL!l>IXkU`_?D z@NQI8xt0CS3M3Bd9TY}pCnBRv4e~zOq?HtJB1bQ4eYWkCE-sS&3m?_6MyzjzlHqM* zcOL7kiQ66}_`@6TcAdmJ5fw`k2^5V4)$6~b{78%0Z*{4yLneci4A<0*D9bKdD|XHG zLk^;3<vnVJupXElr~INgRS^5cR(BWLw^4#<+aLH2O?DHjJTizFv>^VS zbFT z8QGR8nY$P8Qamt`1-W^4&)}AIF-#((k*Y~LfNp&DoHs;<|DnV_8?qBAqei7Z4p3;; z7*wBjTn+b(C>x-L;)pz;iQd)Z_Yo)G=J@zV6>m0_z{=6!25XVd%tI-V>G@ow9+K|` zk)DvgDN3_G^_9HNs8pUClw&VS_kg8M(q%&s!|A3UOmwYS0j8xyd?PnRm-T34tYO-eoyVk^j zLEv+Ece`&mo`a+n^xfQ%H7pzGa;6T@c>FjUY*NivtkXxV zfiX%2jWu5p2~G4HluAaQ_zWt4u&q`e$elL_V%RWWR*40xxI2-C zfvM(HW`_+=s-3cdaPE=%>dOpfXL~rlb|9QtbRV8@FtDf4n2qPl4E{L|e&CwHyba?W z^{&-Ss!k$U{u>DZZPL0O^c2Lt{)3%1f)4*>$c8`YFY=8ACVl;dyHQL8kz|h-?Jqmv zZ3Dd?&>NP7cT5D-6AC~zkPGJbPP$Xw@ne7fiip%3*!lUF&mHJQ zCuPrBZKWlMKftc@*-OX@(pUHu6z1Vh`Lk3&9?l>p@My4xY+@V+hTr^|>dVdMskSm| z(<4osF(IM+VA=wrmT0vEZo`2#6@nQjebt$>86!|kLzyW5SJ8La&_Nux%f!>QhJ>-84`A&h+DO#2S?K*Ydt3aF^Q7|bF1)7$y2r{Zv+1N zr0;2fLe!{Se~9{Ra@`05m8pu3yWFw14T^7?jH)KA1VeV?S<$^z9Ace90XWSL9KkC@ z!{?69LE}DxkpmnWMLykf-k#5CAHle3>0?u!hYIo86 z>ZF=QPPwa%q-$0P_Vg|0BsIA@sC$&#dPD`AXUE!FtLS+O@o6Mx1F6xuqqUvSgE=M>$j41X&ZhGhU_C zX7VjoBRI{|GW140L_NI>n+*Zs6Lcd=T?GX%;M3$A6_f~vyIP?ch;Yx+)$9>xb)njFbpEJSXPSSwJcKbcD+C+$NNcPw_wD4 ze~@a{Zv5tg-S}Bm}X5x(VK*32NdoFvESRu1StxjrI-~4wAdd{6KKe}(;yK?V#3R^ z@bQi!vz7zx$|KxZSA=$0wLh}3iL|ZIUZHR2oHVSiagY)Vz>~`wDn_U^XNE*CH7jy@ z4N{Al_}%a05tw(;#SDl!*td`JS~|2SoHv#gPjiNqznvvY8_OR@@gy~*`B!Vu;7Rn( z*NwF)(X*zYyO~RKLY;b674DDJONdb_=qT2hVQY}0C8cOYI8V&lMe|x+R^!Hp2zqg0 zMyMr~IU9MzesWBK#%o;o@EI+rrVXp!YOWu;4O+bVj?v;7UGTZ8U%$eY7Lt*?NG@wg za>wAN;l)KmAL}$&B{j@yH9|P89`-GD>?^jHwqC8FH1?IaP`XL@6Z3f228pEDJgW+q z`&cjOsN*bZCrMCeWN>zZUhj!`0wCEz+IEMyP2_!?P)E@ynaa_quAQZ$T)t z77G*$1R4ga)Y#ah*8>*>hnkD_8$^O3}(yVSzJ;9$LBj z`)l2VLajK2BrB+eO@JBg2{{U#`|}eF%s-)s>tNm-1@Nn~Q>a~8Q#o@Q)>`XUg)2S8 z;){q&X6^HAYL&(}L2Qfq<%wj5z6z`@(&DNIEW zulsZ1I2Q+(Qg@@v?yNk_wssYimW5?!3Y8hCcn{|^g;U3%2QvvMeW+-cygvgp|GlRD zG=={0-)q9aG-F_Tvo_^z+p1BO&E0COYk9cOL;a04ha?s@P19uY9G)y|Ko&AhFk@SA zsod^7;UWQ)LAE)Jhw1s? zq{Q4Qy6gTxlR}A0$8odI^UAcVW%BdT97b}tvG(^^kuE(9S4Z`j>*{pp2ci8g9^5Zmt*0iryK-py!hpF#CFZSlMq z7gSES3ZV#sIjF`mXH%gJWiaO0LsVfjUSXp_Z%i+!a0X+qQH5=S62+_BGFPFa5Bs{P zP<>gZa*tAl(I6t=l!Y^o%{f6?QF#WfUJ_?oM1XmMY3#!noQ{G+n>z5EHf9rQiDs+s zbzu9&6K3jNYxylM72%vpVdiJ*gM+a*xmEGzi;5eY`6J1`sDYRrCowxert+Kx0QY~q zxaZ#^^l-X8^j`v#SWMu7eV77f9SXV&ZrBAtVeV$vJ0wBSYpMi;Ds#J9R~N+o7k}Hw z{usqU<;rZGIkG$r(CW2ox!6=D!+-SHB+9qhX1HI#8{U}M9NLeFgC1F%n=;iiT(*=Z z!lx=5uR3{^QlgneOQt&I@-!>Ye>Jd?Gg8f1f$1_u%`8~>g3DH~Y&Tmr+uMOH&#;Cf zEumy5Ni=E^KA?>R_^hNPS`kU2?@&rf91qnz<7fQMA-Y*SQqB546p?D*4fenhfTh~U zp~bz&^USCF_Q|Jvt1RzSxbsBf#}5!TY6#?#cg*vYKn7+jL{bw%`BLG!%0EfMx7zTy ziyYigQ6ap5xzIZ?al?s3`{rI8I>0{q7#xcrRTF_j$W=e3*SaL=m3(F`h|juC0z#kY z)oTj`q~8i!so@3WRMx^<=Wt^IVdwG>|CASu>s1wkfylt{X$>44P!BVcJgd!AHd)T* zDqIjpH?>tQYpBCQPKB4U2YmU*+_O3-@7m~mj+dCel~!{!hcwrZbw-CHlwc~^kWC3s zyh(UQ(SzgeP`^`J8Ve5^=6!a&JR*c#Z6pyw(d?dE&sIuUiOS)GTUp!N(l>aw%4OY} z0%-j@a+eb|Pr>YOHO^7k#;0XsRKZEAAQE5z6tJIK68>)*E-XU`CW#YaByFVxaq+Jy zE7}=8Ya4{UA@cCc;T)RXPsg%YupC7x%761m=6{K)`KaReI8%sun+0pcDZ~p_CoVBCA3X)H4LNfJgzMzvt_H&YdL*F5mw@k4JmYy>piL zdGF_aHpEmW-}Ai$qe5}ixtrdU>mYA|HX8h<$gZ~@q{ca;$K5x$jOrDMw3n-Hk#{t> zIJ2Uo@l#sh)$=wp(!bHi!fVA3Sfk!WupEOg<49Odn~i(6xI&ZHUGG?Bde=>Bx2kCI z3jGqClEK@PlsCV~Up#iVszv+e@myIeuoE{!4!?XI!>7EW>J=KlytTAKLt`?|9{;en z{v55kDqmPzT&G#`-hp|=QsafGZ9)iE#Ba78e3S(pV? z@jVlnI6OgyCa7SHrhI&x4H$eBd|icwc1I=Ax%wSml0zmw6cfhDScu-ZtDC&C>sLF9 zzI?_iPG)W~gN7YG$;8K6MOH=7^m+rS~Gx7cyxp5nFJ)EHSf-1C+Pf}y} zxLTF#<2gF}As?T$!QOhV)Z0CG)~d{?wZXk-myT#;JvHDp($qAx`~9opA{zsU9Tf3G znvmD6#VKYmZKPvvlcMT;%PY%VrJAIII@J^}&3Z9o7N_3$qtK)p7Y6)ld8))H4yV2# zyta`^6U8_Z01&ppZjG;Wt=05l1 zB;F0MZDMrVu0Q74oh<16m1^LErHsy`YaK$3d{*$&;9i+T!*S|RtCs%6sqIvSaHKxB zDOKm5Sfa)}D;2*c`&H)m)bvx682Z6qRScaF((!c19kGYSeF{$&zo^~`TVi&jTs-;y z!z3k;$fQIcUFTtv5{8><85xrU9vMp+8+D-UbjH!pnmUKqwEusu=^Scui}pamep-(9 z4~a)*&Xo=&p3ov;$>)hj0+GR1D}6Bw?*d?Fp*)^lu!qFPjoG-FF$=#B`0#F?(P9fL z=T+8HLY)vn)o?QCO%e@CxL?DugKHr5PNR1NL-N_klxtM(I6bMg92Ogw3?zP0n2NeEseNSd3iHLq zk?wC-stg&qp)pRsw~0rP51s}DZU3b*f{@rM1nt8)Od}!a%>xZVox6dcL3p(SL1leg zIUkT48sh>#@WWUW3-}g(5#moZOeK*kApXdX9^xhut$9yR(v!YehS+dfLDKncBSUl z2(rPQ;+*m1uY6vdFv$-tEK=bf{9Y1xLjX`dA%K&U6g0@<%*GSi!^&w;A`3)ibyC|6 zdByrwO;#y*5)G;p9#KbQv+D|jw7Dg_hQzh$#VkB8v-Pq#5Iv`tCE+Enm!*1%Q^jY? zwy;y5i~@18nUCr1JTF!a@HM#UTY)gBE#&75Si`=5a5!o3Q%4_TR1)_EAD9mN>kI# zN;qwOmkODnTt)>$MW;S9Y%zHwlJ7BCn(^3OKprQ~uY&K41tZKg41o<0>Zsg6FisXw zS^JWJ-6XJ^-4x{-3Yvw+!pSheW$!eDFtb#9dZm;C9`;|87yH?ph z_*Q)3?E%pQ>_LV+gfUt*PSwTK*aoV9o2cQ>^w#yZjA-WkAM)ZaJpGE#L@mid<~KHW z3ix=^j`>knbF)TDA`5BoSE(Na|g_Zs_widIn3hJ6l|Qk4c6W;WwoHfqad8oT}DCI+hJJtXz>e@z^=E$uE zwZ+f+C5c+5cc1FLYT*9vZ{_})R*)_rRp*}kzT96`*uA>xF4qbu?=ycmORW8V`o-Ga_Xc)rKW|{|%$9$w!1#F|=WZ3@nQ6W;w2}DZu)wpdIY_KqRR$=fJLM@fG zsdGxq4kc4Rx02|Oa>;l5N}FHBiehLVoSvYbawz+q^Jie9YV*-J3xps5wXUfIF8OtE z&m53?G`Zu?AbMK)5zb@D3C>bY^HvCFUelC2ggCa_g++t6js$h-=ZdnWTHJHn!vqC5 zu*3vq`p46f^ZRe`&V#o&%e*+p;TffVeX!&reXAbov+qBk3v)!~Pt8ZrMZsikC&p6J zy~(NH$;SE9NSA={!#Eu>97SqFsSfnc)zivz3B4zqjyswvLwG*tkt8I8q*8P9F2I6b z_jqDK6AR1Plg5K_dSFj4N1llEtj0AQ>?I`|Si6NYlJP%@5nn1^=-x1D!I{*0+6w6( z7``!(|CJ-@oPfP>DS&ZWoc@Isl8k=wA`elU z0yR_Mo-Ki*wqv}#09fxg<=LTyqNmQGOV!BQ))Nq(w}jCF0bZGo*&3Jwpj=jSO|l;A+26 zt%+>0oqU2g_3@1G6trKHs)g?ngwmHvUEx|oO zf)*A~l+MiybG)2?bb&`j-QZ*HxCX#GrP5g#s(&-*KBoS6zmgj|J`&0z8_${k8$AlD z2mRM12u=Sr!!(=DZZHltYY-=k8o5<{zT@3Bfr0b3+X!5;u?E}lw{-B-7v?^+F2 zO^;)T*qbutY&Xfm{t z{m@8J1X)P|o_@XUc6<1Bfcz|`k(X_%P#ILSduz|~Vm`J4^n}qNLsp?UN?-k?6ny=K zdX#v?b?+lDC1jRMFs3oeH>hSR9wW^nP^<+d%++?!aWawAlLZ#T@xYS!5^O>MhBxRv>N6S`vqt?1zh%|2 zW_~w*3nw+Lm-1OJ1-ah6$s%~a?o=Vf5&7+Bjh^55+4CFJs6tr*h78M2GriYYTPE5* zcXmkbFPC%AIb6JA^}5FcW7MLWnq>Xd9sMaSv9&b#v|e|u7BXy2t1te$k9pFh{`I(+ zJN>R6*gKDug?^Lg(9&hx*}ysK_v#^ulaE}=o%LY|CjZ~mPMKado*pGq4U30*$MqsW z7H7AHxz?thO$ZL<{3HOVcb(^Yo!91b6}r^PD0S&CFiQh-_7}U&&KJ5oy-ok-@*;|R zvnNrOdfT(ld*dOT8v6o9yu|r+cbm%tEQ2>;Bp29>jBFk3l4I=*?2>wIYT^W#yC7CC zNy!Jod97wDp)jNtPq>G7x3S2Vwgg3gG!zZN&pWDnnE&67lE)C^I36fgvaU z?p&{>h%j~PCsY;+q8vQ|1`AIl7lQ+iS#47(awqv2CJAx!_I%-k(fChYKg||`?Vc}u z4xN(BJcOy5WH5}K3Ep}4UE~V!BUdPRn~#DI)#vclVbgxV)1OAui|rW>3@BCPCf9)( z-RG9rtSbDRaTK^gWu5}Sh-b4Xo-^!POF}W1-0l3to;7_S!L^9l$O4vv+G$WfTZDjC z5d;*fmTq?HxVti#$_uK;gPC)67awiHMv6|;W=<8hC2h|3Wc|)XTUbNQHUL|$u91tt z0C&=THh<56d;>hHNju>%fNhG)3kg9ZFlSaBo8kU;xvwbeAqGz9ASW}#5j&uUi&vxXK;y0mJY7fZi zmQ7$Kjk=$F2(r8&vXtq8Y6|-UYE#tT^}hQ9o-%ykE#lR)_m`4DT!iz}bxx^O ztHn6Fa71gcq9dEUtl*zCxY2Y@UFTbnj%>huGRMv2%)w#gPbE1c5jB-}Gw{{c5@|q3 zloUQ?R3}n-t4)2vtg#|}%8LP-1p(TRwLn^mUV=NJuS;+0!Ga<(7s+WFklx)nP6fo> z)Z40hX-v#Py>&sJ$37%ScjD8Tp3SLVYwkKSDr2HK*Kgfa2<}#q2np@vsXwLrd=df# zW^?O~s2JDKL=qMZBPF0)tFnTW;lq4SJFgX4Zw3n{1q3P-%>olmfpjI@5ok6wEDNST z0Sc=pYdB116KfuJpLB)28z>aBdz6+<(4T6OCD5Pzi~&7M`4jnx#{T?48N~6+^nerS zmd4_}7dmXV?L!R6HN57EzYcsdx1<#foj_?CjYgNykp2X~QlGT6)Pnx>eWg!=lGM*9 zC1xbivQ?JkwoiGSX9IzgBUVE6oW}EpaLC_gV&e|f0Z)8yPzj@wDI_3NtKy*wDvcVq z8{L+)$##ub2B@?|PriC8nfefwlyE<%wxLu4gff)?<9(+7uFky@6%AhIPey$KxX&Nu!*>R@Rv#d zi{CP>=aFHd^-9I_(9V^L2lZCtcHO6>c>G~v!ea44E#e7cS=^f!_ub7=l~1sw!&|Vj zzBK=*S747kzI88zr3Pq^K#(SKgY1%vTL0Wl!e62wK^+72ptBm>xFDWQVWkM_h3K&D z7ny+V$YDDeN>F;^+QFCIW3|9}EJ#Q!?TGMpBbmU9`Z)#u!v3|1wP1c}qp~M-_4DFy8FSmHZEPK< z&)8PvAtR{qqjA~;DDis*R0a!zV;eie73WO?ty$j;svIuW9A*RpM1ligs7J@T_JMtl zHEeJP;PR>8)D;{F@R*3}aHpsZY|p++jN2~)@>lkF!YW+s`AE5vv$MkNKq;5oZ8NCV zhVB`{Pj(np^?rpowetL3X%SENs<7E7!EYcKyPGr-GLFNW#vc7+1P;Pz{V4mG^96!J zobJs++=@}qRqWXC3oKh&S$B*oY=`M$$#EdSsLXly1H|-u24tJW7i~Jovt{PQdot(!luw)vuzr8-cz_L+{TywbJ1ov` zoKE~S)6->z?^NOGtNu88`lvf+(kRI4XslD<7v8jaB~7UUM6=sB=%}2BvcO?KAPm5! zv_`2FR|`K!l(#?FkzYjXWfawMtu z84N~j&v3=n8pt0%8Wx^h8psE=GlZXQ3|Jkb1Pp{0j=gWrNtlIa9}Xtu&To6VgHzLk z=_#lJ3`UghTVmX#i{={C0Whq!^cqUTMCDai3ewCVT+e_;e~cFbKwP`F{j}r z>!!DV2-Y<~o3#7& z#`yyF_;6fT|-s+)Av%mBTk*NZ{j{Btt8HjGQ0Vc zJzb3tvT9TH%XL-VfUx4}y z;iNTp21~WV97m?-Z`3DqCNEoi3v{tFJ-_e@2@-5`W_wAHdi-tx+_AmM6r~UPp}Awz zk-KtRg(Gr?d;7h=5`V)LH4R(VSDODh=6!rmaW|$$qC*O^hzG>% zM?;O%*#uHPD8u0TWW{S>uDs$knILgz)AV3m*<`rZmStw^p+e<;d{WdwWI5`InbTNHV>-G}*;u z)+sP~apS#~Y^jaL{^L^bXFWYenOM$lzqHmxy)m4^v0UFXD{gFjigt5- z?b$WC(?(@hj6diS3-o1rAJQJfc>KE=%_QU5#qBv=6_%%I*Lq3?QcQ&>3m-gEx~ncB ze0i@VWS;)}tK2X}v31!JIw^#;DRoO1l#$1h|(XfhHYtp z?MupC2=|i(5Ytbb6;NkhW8{Bj|CfD+CNgaeuJcTPd3ZKT-vpnQ+2pe2q4MV~V0eyR zImAhrlAMD(R}O3QY#TUD|6>M%R2ZW~G9cDMO`B z4_FJxmwV?DF-?$Jf9J0ir$hFaGc)I2`e{YBINzp2H`G>u$bWhk^x|&<5+kn@H}2KV>GpK1t)t zEZ6T{t7RQ6jG+9MPjOED2FjIReotlIu2q7YadYugif(bf{_-rD#if;DYS~29Sn?N@ z$ikU5F5RZlpIQ12*?bmfeeIqp+`k&#=I_usb1OT_KQK&jBNn~;Ep7;Tgak`!@0W#- zQ!8FaV-)Z$$9}ECbhH`17W#35O)w4JZKLlu{)om&dKUAI0pT6`$ zb5c(fA6QwuRK+ji8@+>6w%I3y(oy=Wlqu^I9nNhl&>M<>l&hDFXWeh?K5B2BiudTJ zIQ`6P>Kkg`bQdDw+mt2w?WyW*kKL{ij!jS|_npdWMpI4q+o0^H_-O2P`H@117EDpr znU>Wntm3KmQy5&kah0{CtA5(L@~7`>KUthQeT_^xG`RG{3K}$v2CS}Zk~@_+Nk?(-hR7#)Kt*= z1_zwUgU$*MYlT7ZN=PE?qcr@2u?fOJJa*m_S-@nn`$gM~GY@Blt^DgLHuQ+=vv(!0^~JyHT-{ia9H>aMc>_}VbsNixKBddbd989rrvvg1r4>gYodL2RSCGxP zZ80?@=_M8ErAa!jKjp8Ib{6ETvBXd1T}2Herr_7???ueQ40tb0q1f-t(pWifUM+u| zo;qqbiUPOPZr#TPOH44-3dlp0GEUTUlM?O#hU~&?lT{W*7yxsxlw%l7sNWpm2vTKd z6TiO$?7Vf7*Gm7X^dDX?mu@v^RQlHcvhd$Lr!o|ovufEKApqbuUBY^_55f{!;0e6lxER=k;&eh2(t3*y@x|JgZ=CT5=Pw!mg zyem$1$A_Znbv!mB^f0&ZnYw;=?0YZ6sL3?D#K%2g{tHk@O~6n1m3jHLsz*+yL8yis zT>lS-YU&nzOSKrKdLqGeStl5c-LKQ)@!>qhA-BF!M6_w5OqU zf)?FM`^EZPD!Vh9x!+y+ZYBKg?7u;dvj~co$WgIg!07S3fT&tyPncl>7$d?^CQ5@5 z<$~iqQFyB&$`N-bMEU#QMU*-7tvCw+vOV{8>>TwirV;kPp0TwZdNZNlz4W|k?0 zCZ@rl9AwZ&^yewnPAR2Xuh!Qu`1pG_STI0bV4mQlZ|m1nr|?97F$2Ct>W z)%<(9-z~1H-kteZurQi@!om=KyxsF7oTCYinE&AA%$6);(SI%auT7HPNn2%nOfY`fFa`MwAYjW+QJYvMMA~U(*wz1^OtVkVjuIYY6 zFR5NDGZ^AUM`qRbMh;j?W?)3B?t%B9$$q7S8ml7!j#c)4(Ol|dPU=&ubds8R$zzW9 zdv$w$K#|9JT1b>3y{>Wh?ctSaHg6KZkFd3-6XMi+J0{Uywa&+iQ0;}GnBjmrZB9f% zs#41qdfa`VO6_|n4d&ySz$b|+`N2vwnL|A30{nnK!O}Rlm+^3y4?^ADOFTY=zIO3S z_t5#$_A)73jg%|C;#s>r>XYg2daI_Uw&si!W0cw&0NIa4wq65kA~agu28GA{Ge7aU z`8(yK17}84YiC9?>ZV1H95!+7{Mq^LI~(#F*YNYa7fi5?vWJLU;?&H5F{rj*G~iJN zYU~=c&Xu8Muz7tDAI(6<^lYzu8D*3>wM3r1K==Hm1?1YwfB+Qe*Cb9cP0yd?M&McIQ824;`;$!o1 zmBw*dV#f~o?p09WF22osrQa1ccx~gc2AaMs$DxyA`N+;8`uqb3R%wCW0}ST3dLSDA zXs?Ch(A6LYGHmrgzdNY9s)F3BFw@QbFJZfOJG*P6#j^!qygV`7kmoEr^X(g~p=4Im zc!-9Mlx;Rx3P(Qz7|A(rM?V4>J3JDN|4bPSTg|k?BmM5?H>-MN7QO_=Wnoh^U@*sc z+q2s1x91BNsSi>8eLX0nN9XL2FLYaP zq8ogtp2Atk5sUv_uU3ku?OLeYQC(*(~ zSpi26&E21=iPIott-`yn_J$>@y?nUzx{3kS1+3ne9tEv;FWEVuwF9&=IEFzOA-lu= zyAMi z+S(n1cNqWcj=|p_jBy_ zZ)X1sW46gd0D8dy_1?b>>qK#X5jo)_xBpjU5^NuV+M}t~!8_Pi^{s7006Dy&@r30% z)FGB{xk*Ngd8I3}J9K5Xc6Ef_wuvaY;vv=?=1A-WW!on;Qn9!f(l*#_g1daMG^aMl z7SW-ZK~!-)Y6(TV=@HuZM{hnFcK-m%G^`Jo2+UAjSgKs@M+|pn(DDsY`uVPD(7vUP z=mVV+*0rfd!65SK&xXW4NyhX}rzvbYWDb%Tka23)>UHD{3nZ*Ad3FEd#5;9%_TY6O zz0|)wZC6;*KPF>1KW2+k{|Et^j3qcKZlXR`6h97!w2U4i#Y{p}7Jo(gODHbhqNos} zvuGhXg`~1}aD(grX<6YNzEdXWX+X+Y8MTz!Yi49DA{mnC>Baj!ZYr?1MW zyv0_)yOqCX^!wlq%FL!Gauma!N_@+NC(F7iwL#LJkRn9^_mfl^B)=CF{1{%Fi?^a{ zTxuNx*hyry%D%7l_I;tZ@5|LR_I;_I*mwU-eQ$G*cZD5R>ZjyvK-ouw!|kzK(j!yp z2|3%O(|X>Ph~v)rvK)BIXul0s`$VZ;W-_B0IWOd5QTJq{>Pr^n>bw-&K4*T?6^#Q1 zC(#{yhQkz5Tn2B~YITF1J!2oWlYEF2-tyTBeraDLXgqUgy(R_Qb<%$(8J573&ej-T z!#YND%4QA(1>~IrO_MrKSJ>pI;{x;1*vBrPs!70(@2Z-)d^086sRVz@K3CeeQ!jC9 z&H}Ne^o$vKF|)wn#~OF(b_q5;B9qyhp0N1DM@f-aa5SXXg{^`Gi^hIN@I>P$=^eSBmBh2B^DmH{S)B7QNO>JQXWrHWK%Jl3Z5sXvUJ{PR_DPiZ137;t~ zkGhpp$p&q9tqY3aok=_N@zPWK)wd?gDX ziBj^D*E8T$W%L5g{POaA+~WsI!Z3K1n?~&*SP57A((9%`vO)3uF9@bW-z({iJAx~d zD{iZ96_8QDX!UFrrS82{BuL+)hp7PgsKL!Rp+tf?sp1mv9Uc0IfZs7QE11yL1aGYqp-KEPK*o zAMXYn>HdoJ;v|i7=~NjQ#GPaZA;KKOsb3a&?T7iTGS8nBd!=WAW#}FPrDZ;-3Pd5C z6t0Qj2}6oXM|^)(-^|8iU8g3Vs03Rlsi!q63EnC-Qct+It{1&?MdMrm?AbIQe>3Ja<;QuK7!!x`%c4Dy^FN%Pf6^FEI zo_ihIhBTU>BNKH?hNK0~yN}QL=n#fPIxB->;|8QFer2CG^+Ci;&w0GA6f^0!MH%H{ zCHOH?nz9ofw_uZxptXEHdxMl`n@|TPO(mjB-2qv(DQ_BfeTrIzo4jyiyi3LjDl%Kx zZWgxHMGdXMjE-Ou-dAYF6eJVY@&(9x`X}_k+yp;h(EM0DXBv#+@8mwpN+iJgc@ww8 zqkc^VOK*--USMCZ#^PCwLNdKus7zrh%irm3Us$yf8ugo=1!%2sutCL4>>-T=&uiez z&rxk1^gq7MuaqgzzaGjEDg*{E{;9XR?wwDU6hfGpiqm`iVH0Y@y|~S zHdIrTzPv*{o@=*|k4>xX8^c1{(p2EXrOe+_=2DkS%Si6ms;h!6BPpRc?rXO`E%bM? z7nmienW-pJ7-5KgdMU^G;Z*3U;@MRA|YUP-6rRX>jlzMgCdNubYdZLyxhJKN)kIpH>|VQTb&-goZz~~ zmT*BneL%YPJ7J9HHfAl1;Zk8+6FQ;CPiwJ$^w|>CC3+*kmI|;%>1$6fQ++SBMMtbq znc1FVgNtX8xt6(Qf*AaH6dpUhkQ@6U)$}x@ICF< z&}Ta`{6@pgI838Y<@)9|enlohyrVy*=T@XULt6Lkt>bsjfoZC|UUJIDM@llC6%rC< z6J4-Y)q(j2`+SA(L3D$cyc^BMQ>{z+c_v8JkXNnedFoH;mL!c}X<0IJ58P+Awj$*8 z1nb;|w3+cj%VFCa)D{s&`L;^02pb(q0b)NHR#pK@A?z%+A7ks zlQfIJf3JBI6c1Qe_Mo1FfTF9}k8z22$czMj1D1DtWCDBdRQzc+^uD@IrnuA-B7B=xlIL*AB~tji9|J1@4PDFjieNktvnoYVy6TT~rBUK%6l@B7RdN{sb2HSOfOm&tlK*#11 z%CF!Xot0p?s?_xVbh63lIn-ALcj}}IZ8$JXk720jczy)bk7$6hK?S*AF7O~5I;=~n zkNYO}u_hAQxW%_~xV?_q8L=w?0pH%c8Ug8mfJ{%np*u)GCF=eo5;lI@*SXGW&^av& zgT+fWeFvYr5>dlYbJTPHEoxGm1lxSc{9&ls{sP1P7(Gn=NXXp$+d$1x{{c0vdsU<6 z|5x5{r&C{Lm!s76{RZ8YdJIEA>mUAG1dJXP5b*tZ!w|5YZ{ma2gzS(ZVBW12ywMrt zd~T5Qb`vehd6IvaoSUE4BstGY2)&%+?+1DJ!uW&VkJN$vY|!F$qo!I;GoL5Xo{2jZ zoQC#O{C{p~8vc~B*C+z|m7|k1pn2jJe|;$l@wH?_hGx*-$MWf7~^k$+L%jN`U7m1=$`s2#5egPfU3I-QFdwwkjPA z3QHDc3*EePZ}D=i)smTbZB2!lSfbjh&BT${BxYj6LuE5z87s`hvVOPuv%{&uLXAlH zu|W&#J0|PJ`>x!RqE!yjQTY%O8&NBLkF71{7H@x+=RE6KrM3uq=7UWYoEhanko=<% z7&Ci9%YD{8;ro@lKvb2iBw5Qw%;!#w*hilk-aYO3K9*~EitV&KkEINgS^_mtT+NL}0CKxMSUwd;o{~~5Xav`38*2jAze=tu!Vfb8M~nnd zC94c8vC{}8+}rmMT)UPFdTbF|)qH^S!8NU}B)DcCW?`9+wGv!Q{D38N(yz-AJG4rG zmJ18;&q{mV*f_w`yj>0W4%h7ZB6){1qfVKY!{k>th%6Hy$Skr$j3>UDIqxzflm(uj z&Yah)w>=+7qCL|K>+^d)tZ}63wlVb4$}x&XwPA48`|Om=#jEVb3p+-OMFVYq1h>9o z1ow@9dPOx2u$NNRG~B4SP}YdB~D z^U$I4rz9t$b-fi7;jcR1gZlaC-=L_#?XEszUBc7(PubLP-xAs|wZHw9n}OO8*N*zU ziS~Oc@T)yTmFGZ=M&X>#nNh!obgRb7&el$|sEdX^GTYYU2K6}W?zr$hlfA=>hr+`Q z9e${}qvC2?WAsOR+zlK3hJb8&Eo1e1zIa;WV$V;ujjQVwXI)y>xK2;_ z$)50U7CP!r+%K+3(xvb8e!YHIfGrtFV-T-?S~?+wQ(;35Ltx0+>J>SYL&7W0k{59q zj%Ym>{cU21l~uj*`2D{x+etvm-L}TBa~fBx21CPSW}2N5zc`NKI6Vu)Qhi$+w$N`0 z=a+Jw=?`0-ay4d$I`3iHwN$5F0-CJnx?qXm0Ay3`iWuM3cXZ>ywSw5)+~ft+u*E80GQB6V^dvdM7G=Y+^mp0oXzLr~|>DxIS~<$@-nm zFM?s3^!8-ou}%1evu^W4V&r|%u`)-h=nG1KKO<=&(S_PN=WP*s*h3^d1D=Pd{*YcE zI>8Pg(t@3dk7RllN>4@g6ZMPU?-F?w3%*zhkhC12dZ2G9RJoQ9CRJZJKygB(Tv%vB zduPsTwL%hziEA_G9iq2A?-a+-j|cL5t`gxb)Z8P+)Dm*3kNl|hvK*2_U9EDEsh?N% zgZlam3B$_4hZa^%>0Uo-8UgXiqM1NDEV2meOoHY!QJzA`q0tEq(;yo{%Bh)t;tpKT zRSIlq#m@IQJ5ZoAno<-LXYF%>Uqs~MUn+tt{p6peP-jqhhpM(LtT{LwvqA}C_XJUv24JU$F=qld|rmU z)c3pjYrTzKC+NFYOGQ-d-H+|BemNMHW-t9e96;M-;Kk>$MYI4$K zGWpJ|`bYNjk@f*Y3rtbk*q2&+NwRA6TdTY_{jEt%;3%U;*~hPSOSclnr=gYMD|D+Y z6Z(VkhAli!)`ogTt{Jf#{J@luwl&VASns|b8vmgRnyDpd*1?2wJ@ztaw314S>1Ne| zK9WS{Ve@1_5Y1{p-fCHYKZfOS1o7;5Q$Vsgzzcu??QXFlUr8W`@OX&{qs}E(gXSMD zsT3rMFrIFRTyyZy*8T3Q4B-^YTc;u=xu}+&!Kcb~S8W3|KKH{d4}CK1ljW!U? zD&Zy_;k5}vcryoq-|2+-ym%0z-0z-za5yymZq*21b-^2Z_9jb%ypK8WcYPxil;rR#Z=x(`iT)w{NS zH~D^1;S`KvH;0twPhgKq2XZ;_wFRG*9?3=*uBEw&Pb~N(2x7(bm`0wpZuh<4+XxbO zppq5|MKzxL-JkEPthVsl;HtuNgTE*|X6s0AB|1mtMN-NN#v7+XP7v3;-Kb1WC!t( z;Te+)iqW+oT)v2tI<7e zl38b<;)z+sw5m^?Hl^jz6!T)WI47R8Wby|FxNUun@C!*v1yWhehl+~I!Tqvf_ee$%oxLPhMPH z@V+kg6~r^ZOEA^()KP;!R7V!8YJ4VBBM2PA5T;o8ae4T0owaX}_xR}nEJqz+=sAzg)MsG9;{dETwck8C69q| z0KjnjXAsWPCarK#eMgrQ9p%oS^8-J9^vkiw5YR#{lH1H9OCk-Rz-03UDxsG;_u#J_V<84}2Ma&;U9-nClz}czu&3?=+MEs9xV;@3 zogJu=bHCyANJC^^y2<+QqK|vVvA)k1t|%3zp1U_}k%`ZsW41dbo~L!aoUxth+1;l= z`QtYF{(NKJ1_L5e-bWgeLA*k2ooX5o2K1cx#QgS|(Wlu`m(jpgM44IYEBN=vHTnS3 z!*G$J6Dl}8o=X_QtC{I>yKN}}-ei`%48pMX=Jg9C@w3Mx{CxL~-cvhxC?wgM2u;-Q zwb){3zc1flkCp56nE2dxj?C}*dVbH>Fcck!rc?PC7CR~L=2#^p1rKc8jVBf2J7+U;q|nX>S2dVBHwoKbEfC}Mz{@IbWHC^ z6?=zNf7uI_U>YAi_jpC`zhFFD3E&|^YPi#;q!IwFhAS#-_(-V+G-C<0)AZH!sYlo9 zM=IekbgiMA!c7*Na5i&Tl|cL~tm0)~aYd!uiBvtWOPy;!VEjhX^TYH`@6S`QidN73 zM`f#$3b*dDir!x(qE%%Qdjag3@_fA2ojqf8+a40_1Ed*)Zz#iPCJ| z$Y7FL!W42PtCUN8!Esh}tH#%HKf_}8N!fd@TYuh0M;p;lo{VnN!pN7*F z-T(1sUSWCOVwrJ`d*RWF?zfu1Qi=CZ4XNRiHI+5gsfMd6YuI{N4MPe4Pun(^u#b`8 zArM$1{MH`-m1O?dFsf`ll$)Nbq^t4d+{#LaaMO|H%N@OCEZ$~tvn*WJLKutdKVSo? zMCE&Di*Si$FfU79(2?km;*?~qgZD(zXWcJoQCvB9cXWQ)vCfa3^sqr{Cs(^SrxyDrzQ7$*q->V_r2dkJ?){7ed`1q#9$P}Nb~eF{7BOf z5VlX3r!3c13?6^_bjj2F!wFTMrsgh0UH8?cet^?v!^QzM1X>Vb4k*Me07-TUa*k1I ztzDH2rsYn%NsSfmWU~t4PR_Jj8<|YXsqh5l#4GKfnu)LJ{>ty-3~o9Tr%PS4C9o8s zA#(1^m4^$rOy&3ff>!W0mUL z)uP4gt#z}2j=&DRUR0d%l68TdQI-uI^}@Y=C9#~`4Y<-2lTybwVaB(aI+q9 zwM%V|;)SIUdeKs5 zd-k!tnCH7n{%n@Hr;+@l)lh})q zLa&8t5KAwx46^ewu;7$;u7l2&^@5ZN>S4Zn20`8+pQFXEz0YPs2J z;g*7U<$y9$(|tVih2?t9$NgeV&Na1X{3|Q|T-SRwH8~E;UBquueTT22jVi>roUbv9 z;!651ci*{5!TK%=<*~_+ot)g3c|kw9{D=%xAVmyqZ7k;QU}d@VSXPBl#^v3-lTg1} zZZLnWCyeoOoAx&~4KC`sQ;-!5+HmzslK-&b`EAejsMiYp!cp<>a!@2VpcyPG*uCut zWqw?d4QeRcYdZ`BrTFEFY>-sh9vC6pM=Tp+=eY!1;I664=5ILY{4wJ4EW?GexKzit z&)64P0a>RY*2K1P7FeYr`#`xAx{?oBpIxt9ShU{2<#P`i-#Lk50Bw85%LQa|u+xhKQS!wjWvYiRY`e~OFaz6Qr&uB%!VgOALjHbt?((XR zef??}V=7Ekx!=?D=jEP$vqe8-)Ba1fem&qkQI4W%ozawpxTD66J}(hHKIQcZ-qD4( zVOJTQkcX$Ft8u1sK;*c|-qzb? zVTBp6Tk7FrIFBou+RPqzBu(YuWVFPz#z}f@aJRe=W+AC>62DF0KswI8JO2MXj@s;S zDYe*+CTlm!n1W^2Y*8RaJ2YEPA4Q=ADbzNB+Qtk=j=p4t68Ehce)cyf7Iw{Bzrnrh zoGK2Squ~n4@$Va?73gE}V@A0Le^CjQyZ$ODmp96J0URQKANTZY7yU5M_TRk55iSya z{NcpMO-+0>8A`}H8^!?G=<6POrX);5C#vpr<+IP`4JmfXuwqbMD-Gk+XVxaI1<$Iw z!J~(jZ1o-oLzcfbf^ZNejL#DGp{bGBk5?4WF;pwzUjIc^z#qTVtBS-w6Kc9wx8LPv zT?tBWN>EzHXUv3$gw5u+#-*sc>y=jHhGpTH{_u=?!iF8=G#oR=0MSu(tl^M(LZ_Mj z?7lPWx%~dCJeS|A7;$8t90if|)6Vr?I6Mv~FlQ*0rZNq}t|}5uIQq27up+Lm#z%#g3MVW}xE6etH`=({jsS?;%!#Hn`Bql0NcIXfe}M#LXFZ zpY-xcq(r#6bdQARizMBr1b>1enmz`A=lWzF$$7}3G9|iP8~QH8RDxo+^jWM|3}sNYMBLj+cVO2>^MN z2tyxH-%YwqZG;&)Rx!`i%Lc(1X^`4I0L5Tw_`upWC1+%*b63NZdALx`E0b$Bi&3g; z&W$PtdHgAnnhPBf&}Z&X0IgqiTyUc3D}W|40n50HF7<$_4l|OM8jy*&0D)9DD;YVZ%M3h;an1x~@N#28&mHMyzo?86S(x{WcPK_=>obg^2$!Aw&AJ%*Z~1#x3D3n9 zN(1Yq_8bE1{a-X#Z`Gp=>&yyRIUg{o{T5JBQ#@Psl)e?m+pF5vj6=U`VVph`ef{ph z5x+K$@YQWxjA~WDStle%)U4f?co7mDClM`Te>K@nwB&h~Hy7HZt4~py9Nh z5>P#j=XoxnLwaA%Q!>`c?_mXVr+s3Ulp9v1sjg%9d1l3hD#_5L=X_pmW}>g9j-^P? z_IWSDiw? zCcc)aepcmVdfr6UhqArTOYN(zhn1i|US*Fh+^lk3J@PaAZsoqMBq$Wk^r!StOENE0X!)n8uK+PswvT=g!|+t zc{7AkefzjaHMw(uxMH^IX*b5<4B+Du9%Qi>Cs}lC%T>4a3^m|Fi~e^^Qizb1h+CN` za*`y(?WBR?{1A`Ui@N5fFO`&fj<(hYA7uO3UEC~Pw-0oDbWYZyQb1>&)f1g(j%(Ly zNfbKI&Q6xXD4}W71)ihJXd18vL!1k1Qb$p5_SVatTrYQWy}NvMVog%(`gftp9={l0 z0EP-om&fVj)`XY}7#*;m568_nkfw!(Y1Jo0dlVOB8o{cO$gM{Zswvy7 zoRpYgB@zfk+0<{I5M|~5i?Y+yejGsMtEVh{>M5&)dtqYItePxdhYn28o);j98s`@_ zE0X|*2T&JAkmA2YvwQBOmYU+>W=QTYenQW9?5#IunIlFs@csqXm+T#fiOffFE4}_yq+I_`zkscNE~)XqGdv7$rh~ZhR%+ z31U7{0rl;I`nusIFa20$$%-yNp@ssN*kmgmo?snTM~gEodF&V0-*2#IdT#f9Jo6Ri zAk@dJOMU!C*E^4#H2-l%^irRMho$Ice;lMGt`_+dVpjU3Wc(ik$*?+XPAeHT<#DM8hC--%1flAv##Qh_O0a>&>uo}mNfPULn9Cdy3nhawx>1g?4>evt2>GeV{4AY`HD{ZI|IAVG z`tf0##Kkum(-`)bfJ%jOINV6bR+$e)3cJDR*||@6=<+tM>9r2agCZ~3bU2*-wdC;ibkMb$QV+NkxKz z5KFREu18S;TP&ZltFSfrloB6qh3jumtnm0*1zF)6En~9&YbJ!v8w_?L3Dz*w?wnyI+N{Q&a4ZR(qxV)QPJi&1l`I1{7|RHDj|v1STWxK> z9f;DVCe4pF7rM2`wtL1xM`VlNB*Ds~qjZko-w*s<~2(Q(*(w=qgxx5qRpRrn-6 zVy*^4dG-v+HzTroI`MLI(_n#C+A@c$ElJF_1TD9s!`5FEbXarX64mcvRx2ihYn${dEVRjkV4!s}Y)ouOTEPA)lBs+5fU-bY!hcgSjyv z6Hsj`Pk_>$oM_SDKKOBu(ssin@O3J|pO|BUkOxIH$qCnW>T{gxyD-7CwVEp<8_^fP zZg#-`fNbAPVst}GBk?sOANH@@H)qV6PKnW|;;nL~=&^gU%Uiwt;7k84jopv?&r5a%w63Kclajh5(V&F8`kP*b(^@dwar)i;B&=eZ^f{Bo#TsJK%xvR0_o1*% zh0zM5PJV2$NwE-Ji|e2J`7V@UVk7mY>YgV~^?Qi@?Oxqghq0ZrA~8Ct+kOsaVAQ1o zRTq5SGbJmyc{VXr=fa=g#s;8ujTejzgq+qwq?+7RRaR}lA8z^~ z4pP7DVv#^GaG4M<1?A%{o0PXjzc;%deazo-kW>F@!XG!l;gPjb>H`2HK<)s>e1WBj zp5!8wn{~9OsNoGl`Oxt=u3S%o$vu8a3(@ZQSz{Q~;1yvGpdBT3TR5PrG)8`BWk3{> znHH5GyA5i|YPyj4j+x!^u=?JLBFZ95t|I>K3j8B?`su=xj0n8crcN5LCTXk$<%~mx zY!a^p7TF-g#`W7B9F{Nv%u0PST@Ei8Q#QEE!o9^=(bERf)UnQp(t@I4{SpPxAvErt z3`G~)^YM4N&g03<`I}g)$?BJR@^a*Ot$J}Z`5M5^eht&2RPWAq(?X{A7b!t7hE8zg zpP}YrBWsjCo-CNw-qS2ckB=(EsV^TS@a375_exM}I3|>~;F61dX0eI8^$cW#DS_zQ@XGf2 z?)R9*IE%3mze|bN;5&SFPAwO>_8e^^q_AWCo=>%4L>L53K7X?MGKsz{nBW)L#FO{2 zh1B!t1`OU{iy~`-)It$$-au2lH7e8d3v)T9H6A``)SM1>>TUNa8L#vQ?U6A1j2!nr zXNAZ)+(*Pg-!O4jaAO!uFx7j~rL}vQPE&$itEC&+)G~uI=o5IX)*b#Y;nLSVc%v-V zXNlQwGT4O?IpMCX(Z${WnpaCE2y-E+ywx&ef8ke&(nz<@lpmd(?!*EsGDoSCcarn4 z(4#j#vq^G#kw8XBR9!_~hu@UQRbp;h5dN@crT&O%s-8nK>$jmwElSx<)f6<5E^ZHN z^BPJMY4uMYnM^%jySu*;RW!!UlUf6XXpuz45uH+H|1BDma(1FWaksesm9<`xd0QgY z?plteMkE?K%P_EWq{CE`fEes4kpX0nxze>1#F6+dI{N`jrz zSwg2;xgf ztei}Oo@!A~Gh{ro_FhI(o(a=jzR(bjJ$fvpdv?wY2nj>g-#%G1Jp!5@q8}ce!%~eY z`888cLn2WT>auNHh>w8C;Mv%A@mm7OQ%=VKNreTc&&{*nk~NMY&m|mD9LmdTw}w38 zf`l`RD=nOt+WRX(9Tj9Owr|#;I?5t`UVNp!N+`wNg9$`EN5Z|E@eYEq z0J9VK=~yL`@!~cXPfPf3N=x#6BR&rrr}(BKHP){VK{EEF3q?7(=c?U!WaBlSM^G6W zIMYZ^aCOjXiApOTs)}L+(1b0K{m*T18;kQ4ut}yST#iqw;wi(6&3T~ji{r?|S-PjQ zKF(V!dF}>?6tZ8NdML-Ciq$z>)juC*xz!Rmvznzp?(8}?wxhRvZ(8n0Zwc;pcDt<|_ zY6O(7ees_jx%w$7IY?%+^?smO+);54V{@_TFRg@cqqt|X5FJ#kR23!(i$bOLB}fG7 zx%l0%@?5NHZaF=4r_GTg|AM>m1uS?b{-%$@;7Wl-f#A2CRFzT7|u$^g|6LP!8K^Bv5wv??D-36$q3! z|KVw^wiIAZuaWN_)!(B>WmhqlzK<7=*hhEecNqk2PFSQg2&x+Yw2Q-R{L?Ror0W$g z;>)}+F#f4EVF0&0F?+l4kPDV3_nJ<Q1;Cq6^SMs^bieDMKg#myK}WKu;DWsxtgB4uCv z&tFs1sM&lZ&jK>_tEwRWXrF8M6$UinrnL}5Jnp6|ldjY2wN_BWN7Ti=_7a@ah|6mu z`h>gPA}=srpbPXe=YL22M!Zob^AsLYFlN=CN2AD^QDkG9aksbLI=I{Z7>TW#lVP2Z zCBcr;uh)ySGrbo70q`YiI!?Xvi9k9!2Hk>^R*BEhB^|i>@#0myYI}= zwjt;ciY@#sE_ReUla@tqFd1^}Xl$fErKQ3x zjT2j|++C~1;Ni+Kt4*4<@T#En?G0WlRlkH%rqoSIp2Y9PQKpP#{1i9(q7|{wiLe`i z=i)5@kC}^pT4m-sM1JBh-pn2QLbaJ=M&6sbK;KR^96?XpPlP;F9cE19vp8`9^`VYd3 zgY~EMQlGSR<@Y7YcZ9c-v_;ouD$3Sx;vOwtr?2c^*;~~t;YEKE5LGGHLDluU8NGf5 zW;@FT=Q2QQX%Z@Dd+9D+R|#$rgnlb2AB>m9;ibWCw$Ljy!}Ah-hS!^=JE$x1@G6$B zSdPA@^yq$zZI0g%X;2SV6xFxLGe8n23^m|9eocHXuoDl0b^Ysjjp|2#*xYAsI_&e^ z@3iWJ;P<-|d#ZcskyP?E4*i>W&|`A&PVDMSb+Y3q>jz%)+*vD?)Fz*Qh8j#?w53^2 zu8T`wa;vwTar$o?CR1u?kKtJ3{ZN0!kzvMj!@49rgl1}RnQhfm4^@z0iBNhsYY^S# z;=g+6+8DF$$-Ih3D*o9x8Qk(gnnrSk!!I^hB4Ab%&9?FcO6AK3|DbaTnVsYO>Tuo= zs?w6n)YQ*tP$|W;ZjN8+X(LA{p3lemHV*5_w-JG7K@Mw=-lK=nhh@$FL8|L*P?ycb zFDQK{>47(&i7(})^UY^j5VJ@}e8PLvL}i0m0B**|arc3bNvhD)dAzutkKQuiV7e#& z;z4a00_qQDB%qEDp#D&_Lj^JMb^^~yJa-ebA~u~%_)T;hv%GlJftMMv7%@8D*P`$yw@8wamdsafw+D)AjG``u(Oeghrd?|$7?*{(1k zH>bFn6gYV46qNC$_wwl3G_ofPxz_3{SL4o$_UG2(Gcc(+nP#LI^sGED_#42T%b##x zKHjP}4=vUoTr>aReB4tDAvWgUd@89vx{q{gwCddt6r{qV^tz9mxA=%2 zutN}r<2U>znN;W?K9p!Z&+(vX(QY;*O~2+#zi6eCxKT2_8??m}Y10( zxJX?8BGD=J^vBeFc_yH}&TdT;yW6QB`{)O9qnQ5Kn|P6MP_yR17TF#WGE6ATGMa~) zSG?o}ga*UemEr`|as|I=<(HWPANV<(w< zHk%oLI;ZLQCA?_>;b#2NQ+F=BW?G8V+w{ywi@lbjo#j;FPjCB)Rpxsboj!Wv>zRcg z(nbhcdUQjPeO2(`Ds?9JtAQ?B4SmQQG&8}0%D-W+HiRH-jn@lsn-9U!t2^+Y(jqo1FgEtuTNPd%)hjO)h zK`_>b%giNcaM_+ji1=Z)3Q<7I;F$zX6~AZ(D>>234;5*RsUDMPabttK-rAL81q*pD zQB}McuM7cx)Ncz5+KPuEY@;477`bhKweYb-eH5y0g>a~cX;chhQ%7(9{sWKB>xK?I z41)J*oYVR~XBH+9o5rZW#TJH0P0?tbTtg)qcv>QxB$||P&v7gcKZgNK>WRZfbXvFH=WYmj!IB%WLGQf{a$w2T) zoPXS{NqGdW_rCA^PwZ7{ITu>?)griI;2+Ow!*!X}7T+LAeDgUDYhQE;P0N=k6@LBs zGT0@n<>xM~TQB~h;`g$)2Y?dC#BvCOyNH)U|44h)}pQXJdCRCY&p~Q?@sZFVC2Y?}1F7LM@Cfv)y`cc2GCG6}`Z@X9LS$+miKsh*HQ)-ig%LQk{~KIBgR z8tlNC-rfx<(<`2qoS(l&M0=m}^HHVijsATWry_{h$*W(Wx2_`W_|@+x)1LL0?i6By zCJS*QBl6mIw3&mTFvSx(tW{!U;uh&T8*Qx$XR9@pPZjZD!3nmS!&t!YQkxl_r_g{7 zhsz%p)gDGj;5))32B|}YG%mA2~z~_!5M)(-2XYsA_n6`ynMa@ zUs}%$0Xp)4xEUSx9i7gmEwbf`J6h9L0Hq^oahLu;wbtmOztmYSikMyUJ2Wrkwp2r;ol~%gCr=_(`zit_r9VAjrI_EUmu+ za+*au#Ob@+Ds}LlR4T$wQ09siHIjP}f&Hx&`yoz69SP$OJ^}3AUxB?L`ZIIxuJT2z z$8S_N*MP^%>QsV1)j2yv;F`;Wubd%u;*+vewr~tPQ4XZMH8F`!{NO|%NV!(jA}1%k zB%U1?C0PBe@ng~GY3#7sli6Y8v|&*6y9KBDF}5EQ0qNfAHhB7iP2&j7GaL8zqQI}l ztM1GYu5S>Yv*NM2$=IXc?Oj!)NSL<{$LU|4EX_4jp%X1YB-N5Hh$x>Icgv}4-+axS1gtrVqEDbj}sttNXoQ6=eOcamf2tRqyVNHaKYj_pq#QExxN5 z3j70RBn6VcktC!niF6VoA#-i)&6TgLW#gRZa=VwyIzb8GSQS=#a5N-atk9|-Hojrb zIXPF~R!bb(WiSHEWAkO{n?5dweDtt^;4tLO3Alvjx1u%qu+k5$M7yV|7 zen`0uuuUE2BX8`Wg&5v1@xTApDq4v?@^j%fn}Lt(PdZ871xB3Cp^wCRvXvL^Qg$vr zi|x9zvFroQ^)8Mq7}(=*@>PbxI+vb>jzkejN$5}MexIa8f!oa)0Esb+^4ed{MN{Z> ze;q*+Jl4Xu&kLAVUjypV67l$}{v~?irHycE(jm6-yF^cKCcaloPowmA-af?U-mah? z?s=}W?w@1bhdW$tJ&USQ$&h~n&%Jq0Qu{e;mPAl7shzBS&re836+hi|=}_wcNl*|$ ziRh#NgnjaNN*VyvP0!oM*0ulGSiB6X!`%iOIjwegkhy1Ir-&i^FA(eAJsJkOw<6{< zgntfJ*Wc&77&_W!Jq8D?ekp1E9>-VF8O@4W#`~05U*te5QXS#6*j4qUD@y@gY2%`ZmOj~JsiHg~6w@~8>|iniWPjM*y8wDr4Pzu~3S zpBclG_pGwSo*f`9({3EwU1 zp_5;EMD?hl?$ynAxf%hcpnWnp8tQ+Y@nztHaZiz1(|^F1D=mW;fdzpuhJi3=E4Zg- zire(fs4-iqCTA1MG>`mqIf3h%#lYzp~95YZ4h@0xjvDxOP58x6MbV z0m3}=^u+ft=H096xcqOB#UL7db_l#MK&{gRe1l6bD6fjN<3yW;wNR((8N3zQ*0B+4 zznfE@^lDV|ukJIgFzu&GOe^`z0yJ5K4LVJY!Un14yN2*n=3GtI(LXSD3J9csdF5`! zJi(|f{~vFE0v=~o{&C}JVIVCG6P7@L76yorvZhEO1uBy+Frg`=P$4Wr1koZDs!iI6 z1sal+jFSf{7DYuV3JAzjWw9V=S}HBzQb4ePVAQ>Gi6rO1~4Yk;#s8OBo{o`0t6rb@RdK~j;e zd>ED#p6Ss}7|^H4f{QCi#ymHjIS#+IuNA&Hx+)vLR?Pcw+dk>c85T@%9=P{rwX!}C z#N%jFeJj8HMcavN-A3JLWAFz1u9am?gNgF+cY}-NzHP=Rns?;$_M>TZgp%-rlb|g} zFcm4J68^M!5FpLM0fTnN=pY;9HHdtWe}`)2vzc6oKw<(Bs7`pVf}fHPh9l{u5Dyan z)RyoMWj+6-2J_E2W6U!(!%n9&TZrznnT{m7PSvZRa;MXZJTkbqEF4$nybFhd zZ2Sh=5?8|WrzVwFw3%vVCMKC%-Med&ON_;mm9CPBQHnRaxA@@BS5@7DJBjXFH#0mpSV+ziw();z2JUCSp zXn~+4+_Gfu&QQG4{P@gCdd8Y};ILkV?yAe8M6y}vr_PnlQTk?&ep1T>~Qz_j~dK^ zo!|oG(hwq6ZiYBNi0!yu@iQ#&ga# z{yE}Yq{gE%-`umdQ<<^#KV*Hlt|j@){T^ln2yk+i+-P<{P+V^>XYhP9C}C}Vto+yf z>u!6UN83kur0`qP^^jlXIn(!$G7RVLQz-#v_%`h`p|nJMQ3?1}Q0^L)$ffM143z-f z%s)3zkKg(o$DRoqwch^y>FBoGOOvSv`8x-o zThQ&Z#B2JGw&8d0ZdAb3RV2^BMn_M5XH$QFcoc2+KTvGW2l!84r#*mEpqKVQn`|BS zzyJ=*Xhl;aI#UW`L391N(}@ypxpX58`MEtKw|v)kojaTY8ikJ4tggb}Gy%+l5`CRm z*sbb=&akW%3~b6ZW9>e99X`RSd3pkw7~na_x@CPL;m+4`$~#{`7eFk+jcf!L|ImXJ z@Y0_NDEqPAae#WYzdhjDrtK1RmEtS0aEXH#Jt6lFoWTw>%Nd9%QU>0 z@vGZv^uVg6lBLyf;acc9;*|8NJ|HRU|C>KHtABAivpn}5rzwXYpn#~@0KCDdIBl2UOSF3bhhGn#p6e5w$Eb7+ZXwpju+9aMW?&O2=h+vX|g%F04EFd{rMh zrlTle45hp`Vf00g^4`S#)8P7B3OrTX{w&%bz)Q{86`0CSTPw7$!GXS%8yr_qP!@+P zWAm!;#Pu#1nN-~xy`3rknqA<;uohShj|FfB^0%F=I>`Tp#A#siS(A|m5}6~bH$A1D zrwcZGI6RzspxZVIj42yC1tPpzADA1O@4qn|+sN>@c4CpoKnXn(3%}sxqh0bnTk;M5 zx~dnzNT8rXz+q(PBk=5z>s+;=NGDDrmEV1_EPm6)Vn@$t1x~E@N32$9pdgb+LFxDv&q%8O zD)o<`I1iv!7zM79@rN(G<~l3a+Y0qlryc<~uYJFu&ORfa0kiw>6MQ0}A39&nuO_xc z-zPZZ1vlq<#AL&11}-fwEqTyiNsO9!_0{gNJzo-CBe8v4M@vQ0GOPW)$rbl&{JoQ} zXot2>qvE}r@F2fFO0U6}dw*@vhY4yfbm}SG?>qmWewbiXyHwO6Lx$LEFa1p2^vb+~ zLPYRN6ynB?fz@WKL^~?&)BTE6+UJD7z=yh=N|T&Qw<)8$EZp$MhnsSTqN&0ik47`R zfWKcPkJP-$ZN7S5llqSJYmFYaI=Te@7dnJ`F4vCypAA-~5M_vBCyqml(tEDo)_u)n zovU1~>3a9))KQ+A7?3PG_|5y%TsPaCWIqv7)hcecJu8HfLia^^f3i`Q#VxgD`@58= zt{dfw0bt5*-eTzL!*LlI3QA7MvS{B>r6YeYdsOeo@B#NnY;t|KZil@|_M~)o)wsxa}4XX_J-mruqH9G~g}h!J{8_M_0>m_4aB z`XszQ4`09Oap?}E;r{9+ydP|?7te{J0ln4hD3RTku#<|)TWHtrk(>NYOSF~5J3ubu zkHzZRo+xp3M)mPrFIR;O@`!^#&v&`zP-YvX%r=BSWV?(!gm5)y)q2&6Kf%^Gk_~o~ z23TiZ+Kwf>pv+U|x#WImGvQu;qG*@f=$iHX*RfJ;`JlcuC`3%lo(dwaH$H64RD%e< z@GC?JF5g3BQ$Zxi#HjkCt;}vQS{W~%&D2#gd^QoyyLiS~{4=VLvt83z)dMPd^j)} zKBgVS9%nf_?y#hh%2zK_BMSbYQ7ROwr-5d~v_($=NN!1QaU=8mmhc5CYXht7xTv@h z1&n9}m!TPRn-}q8iW~Wy8liG{9f_hEztIgD_SuIDcm$)rb*9=SE^EMP+qEAV_zK^* z^Vb}|<+8*a!peFSU>R2hdmQA?=W2y|=s&YVnOmLaK>s-n;!{(-{xhKgg8UpoP7vfl zVVN%g*tcvg&8O$$$so4+3_%)cc!M;E9o^&}x;UCV(Qu*%dWqpkK1s9>so)mS6S&(J zomSPDtp_m;DjZ47S8`$5`D^-uAeKe#59&eqD} z&E)u%iVu=t?no4w)9SJd3@tK;;i9wh3PA~zav2ptG5^!gU8PY$3_=^8HQ9*|f@)r_ zXVRHMoAF~fn~;;zEi1HlWG4ekCHX*KqH8+0V;@F;9>fS(T!HumFC}s9ilEl&z|Y_% zBk^~DWqx&?J^@BgEp8VwkcSm-Dsbc5zm2kfqe|Eygy(Owb5o))ynXes|H~Q;mPw4A%3UaH6T~XNTyJ9u|8$R!W{ZTg)gV}@eCl=L z<>MdYFuNfBT8oMrwM|Q-5Q!yJ2^m3r+V+ZLQYn0Cf+bz;t8QjHG(}nX2voQOd!f}j z_+2QN8VhRqwE` zdzUPTef1j!_kXhL6h$;XY|BfzsjZ@fJ5ap;QH7dxSyHoaK+RsKd!rCW5WC>KLS+NB zsM}6o8G?)XsO03wZ#4~KFAP5sg?(73Uj)O{ zX0)q?Hq$&eGB()-1Yf2H8H^~`eReI*{O-jLKSqx#^^aPTS`T9F$4EI)K_J2;aJ;>Z zK!m1ldZdf+n+?SgpWL2E+StC_jdH5~RR`Zr=c?2mB^I70w&+}s5YG~w^&j$qN<<-R zDw0zVAP~vq#2+0Rl+|a*zMYbaOg9D-hc%4faLG~W;9J<%Z=&uFc_KTZ{K-jWsjf|J z+W___bfVA=3{{_y2?3<*yvPyUSfRAINwbLs2CSoDAn(=ePN* zJm$rM2Ba5C*CFdCHf1Xp|4mDhq^f5o0plG088M&sD)Q~zDW>>L=S%wvjCD%|hBZbz z{j1R@zx$~$F6@Ky=IssT@p4O$lV7VBye(q0QGO91Vl#-P0^!Sz<`I13Fc9BU+`yQ%5|bp#189QqIbSfVFV4w}$G4I6V%`N=2JNDKfK-lHPfIY~>*;C)4S#}^%5 ztGvQh(p%TbA~EA_GNO`}pmQz)4s;s-eBz2#*0GFja0(RU#54laP>byC<|DJQ zaZf0Y!Wn0P=HzJdNX$=O!;Yj`eBI5^*<{x92JP;A}-OA4DW4D zpc#DY`5=2!di-DJoWVdJ{ebVy&zqLc%r+r!&Z}R5osHoe{c%KJEtZ-Ul5#eA2>iac zs_>Y79O{~L;fW8nbB0UxB+n|l;;Y7e&ldF(W<Cr5VnYp zF6MS;B++84M<%u8saj!!19Lmif7@ zMHlo-&{b{UnYHtXei;MZ9qUu33vP7>nJ^`^15KF3H}hP74|UmhEZ~SPJ4jQ{bRE6d zb&D^n>zUCtFsHfZC<%$ds}>jYCgc)#;{@b9yV=&FMGd+p;Io!aoOiLVXhyaeztOGF zRF-e_LV=K!rvv{@Wr=qr^sqhU^$H znZ+r)o7J2Ol9PE;U zZ?N$VfEreE2?yDc1xn7n04i2+QnM(M*Yn|GV=OHvBjgtLGVdU%=@`OzSN>dBv9jDY zv9Y{Du`t0vWizw?gL%AsxnkJEh67E#PPCsz;VnayF&#+9X=nT|vjaulXmSrAzUYb0 zF>-J=hhhV4lk~(7t{$i-Qr=J+}9oD2f8_*Ofs8; zzBMrb1~H_W-f)=768@XK5vZYUizqZGR6-J`T@oj2T4jw@`qI$WbC1A)W$K`@?BW_ADF%%U#+vgo6gN$6AS=o35SOQH{z1HCY& z%`J=GMo)3r^bHT8XUg0CSHYrboMHh^%*8MGQJD70h7$NP`ME3_W0@QCxbgvc# zv$L^i?E(*%4DXf+Dz6*Lrvg7dneiF76bv zsi!E|cO(y|o&887Fx57W|4ZWXQ`G@Z_hc!y@YbKWAY~J534bbwR}s9d`;InRz+!FB zCoUVMYSh2XQk?j>edeF;`}T>hw+$Cc-=J2o^}*TE_dJ9T%6WsF_1t}@dn+b+qs1SI zdyn6I(|H#qqUX;Y)w$=bZ&Y!cAhmgU5RKXhhfCEjKF>0K^@m>QBJ8)YK|XGpb)&%yJrJA>(LJ5PAV@sI6>o5upvxZNet*z4`wh7;$dKm|b9}%&r185t zE5eWW5(XUDmaaF21DNiYv!0E8px|9Lp0l6Ix9n&1+ZNID0|4y?JI2A#@6VF-5L3Bm znmL7}vngtLRUdGd?) zs#LjvceV1UKjwAeE7E&r>HRdlJlv06FXFh`{uPBH;k$b?Ud_%1jMs7oOUFxH00abN zl`WPB_}Lm-U5m_!l6*!+1;1GAT9L*AEJ1w5_nj}{)awp{K8Qbga>4x7I0camM+fb#lG@Dz{EYA0 zbi@LZR+$u2YHG}mkP1tsH$B=IoUkd~$tkN{{c2~`3Tl=$2BUwyg=Ti6sv8NIG-g}M z8?!Zy=w%vY*uM6Sc~7h~yR9CK$8M)u4%f}+}RrU`fimZNTP3Ne636P+FELd07& zdE`2->2LDLFuK?fU3_2{#u}yR=$w@rT@qM z9q?&Me?Qyn|Goag$E-e57P*y?Z zozEsIinTSUBIP3ftumlq+A`8I7?A}$Qm8>jWN@fq3~Bd174%Eis?_#k*C_%`Z|)FZ zi|&Na?5>8rKOmSU8ccp^#(O-B9q25QeoBS&)x0ih@`sAdCSG~R36iiQ83Ptx|5b#e zGSN(s+UPBh(3IvY$eBfIN6)i*qo^n7L|pX+`CDc033loVDz$3HWeeSSUEyQ)Icp1x zM`26v+Bo%rwTDWqA_nr_p5Z{~PAU6IPVO~t(cAGm21U^CtNK8%&@wck*N85og zs4e8HUbuFTQVe$gUJGKOn0~9~~b1-q=kInYB~KJ}e|MJPF?TM=rWVCtTYp&_b`sg0~G) z?TlHi?DDKC+~RL<12CcseLyivU&ZQ#Y+}C8wtl^lXUz?rD=-|)a~d{1nE5NcHR#Mr z0B9s{D)V+a^HgKT5*6~@&+lkNfiD12e6GbbJdq1gr!gW79?%l*C0Z?hRmHJ)WD;;p52@UQgx*Ef@lPZ=-)F>)!R9|XF1z(|o75Z|v@S>F@ygZ61~sxF z{1LlNq#_#WxiM>0ZJ#E4zKrU}2h~53Q&4q$u>XsVdiryoP7Ow_n4FD&bnm3HDcVe@ zB$lb!Q7=x-j9M`@XnnDKYA}BVVCDN5=lf_F|HPcH92@NLLU#1;sm#|o;4WC~*vt+u z92?Ak0pN5pPod(+>>n}x1?HMziWY5R+5U2EIg@W?8qC{+ig3RlI=wive@%G7uCmrd zLH`w~@F5gFUH;81NV{27E>EbWc)7hX%RqC@5G7nR3i5o%Gm;a>f%LeHK|_yPL0cnK zLITS`hKAZOqk};h?&%x>`xEXSsw#^Un*$Yu#y-j~A@BXo7;*TY|x3%fKroxNeG2+UTeAlMzyC{D% zctO{C_?SH$Nlr*}uc(3k!I-(}fOtI|)>$NMHD1u7Gq4G4XQr|xu=lrc4BR$Tt!WvH z6c6O9C7mT6;=M);VIOoEYzUJi-23qKjK3wRk9m#Yc5HN))szyf2p_8oSzwkGaK5O` z4oo#fc0qZeEL5s9^U2+Q(YyS?iZ0IvLb33HG&W|BhV^hb8nfF-5ND>dbAi28%gmLp zJT(d(xC6fUVhhg7(T*5kzV>T>!ErUQM%F1?8^vYx?Eyi0S{xRmwO%@UR3&CI-2WLZ^&_bP$Q{*MlEv*t{U&=ed;_iLDpH}^TAo!ZWlO@h*d{KqZ5%a$kF z&Pr#bw5GqJXpL7|;n{n*1Z{_vF8|#bW5+JPMq>u7%LRKuifbIHm(9p};qF)|nPIK+dwZ|e5h+?IBm*UPb~ zXDHYpbk@(X9HYZ`LQS1xi+Kb6<-&U2gA(td*YgnT#J28hbowo4IQo?nrC(ENpT*HZ z?Bl5@F32r+tVxJ5vNLqU5*Qia+}(dhKHVq^Iyv7@Nk=+X*NK{OC{3oVNi`n@*-`W1 zJc8XKe2scT?)`MgxT0e0vtn}OW^uLA7W*2!PBV?!;f)B%8mK_}39RW>5{vBO%j_m` zM%xuraS3cR6ObUR)qTN~{<^42AFssqL`j``iPINiiP-0;AOMW363@kMs=$&Lwa>M)nxFnYiLc;L97j?~In-X++=gCi|$ zkb}0R2JvE_UVcsfgG(Z?w1#XIYB`7!(ETuv1%*NUr0XD_l>THlKFmOp{4E)n)AaMjqMqRKx&^3b#mjw)D>^oVmj{{v{3q^c0q0?qyR43#0kZse!kt0R!rYVVg$|u+T zrM05-FG>BDr#G#@()2IG^|^R&Fm=?w07hf)|q$_iR13e!<3M+pK!q$BmcWHoX5vGI{5nNV$2(xv4csk`!ZmkhgIE zAH8om!b#%)tSyEhw=m<~UMq>2;O8n)Z`a$uRYv%nA z@t5~gswWTO{}O+h-s?Pxc40&+Mr3T!jp+|=X6i=1n%<;zv&7$|bz>GFh~2wdIFb^G z{A`fL1e4x6J216RGe6-7Qf%B$zO7pXn6}{qE2Bo z4ubN31$}7r*y!ldBAe^uM^L(sr#KaiBDzRN7fp5%#9ls9D#3BtOi~_=){|9jDr zp|~k2%z_y)SP=VFzM|xR@TtSU8&uVpxQVL2Oo}q}Nk8Q=07(ZP<&IW(-v+hYJ$u5g z#p&VdezpK<7foE$DEz}nX!2SKO$Oj+4|xHdL!CjxsiFo!{K9#A0u|X}dt4|rGha^H zd8>sK=0z;Lkr+i^+t-U6-OeMu34mPYebl5g9qVW?8@tby-c^)r;c2LDfPSU` zM+kIkP2isj|5gfw5HC^x2xb2okoD4Bfkgp;0U`x3l3nBt2fQ0q?^wK6n5<(p15C!Y zJHk^Gq?#Toa^?1(qNa)es(lofmzMDL-ORqv8v!0y7#<7wqnUNi*nUgXqK@@TY#_Hf zg&+9e$gueZS!)?16JB3FaP!wpN5XssOSkZ_sK$%FMwMWM?WIGZcZl z@|b0k^rvg-QT>63k%vcku+#$Cnmk|cHn|iJmM9pR``DWCQB4um)JeYP%aclL`XEwd z458QPA(*>etqjH7ZB-F-Qvih{Rm_M{IMKxE)H<`+!RSZ!P{W$_2pBsm?68;J{L_H-I9%8bF7>B!E0ibgWzgFm`CJc>sl)n@j-|*Hmx7BBtaDSY%Se7dNre7rw9s zTsbSha^e(Vfj^~hbv`DQBv;HgQW_7fNve!{)Du@NYPJG5vkDX;1VCpOHM$7*)g2XW zLyYZayNF71m7_7{U`!1+`=)ve*Vrtu(g37mS?{?%1%V9|ei+%4}%mYMy z6q&K1*mMydv#ry%DNjcqNuf_kok%fTzsL{y;1_P|vSw@bsAFXvKc>rMVl>Qk`i0Bk zmM(WT2RQ8Gq5g!=)$UR_xcKvtMe$kw@OKdoub42$7lh$ zaNuf3H~?^m16_oZDjW{d!a+*-wlUM!5IC4iY(VBspoJ^=r zIvye5fb#H>xq$;97Z>6^K%`<2;F|U4aY?(y3{?@{_k!!Bz{n0Uo;e&-oHJCr5v-Ac zgHIj3gb|cN6Nq<2%8q{dZUqC$!3v)Vo$;>Gppt_KA*5_?OKV*&tsCp!{ZrUjP`l>0 zHkA{#j!2CD^EOVo6SnC9T4Fq!(y}z&F?-|k$$8LvQoeIp z1-E~mV_kxAqc2PnWn(+aA2e34`x0Fz>du)XmsQo~PXK zj6#tv#EA);Usc>ge&kylbt*p^tA@N%MLO3~F z`qT9?cPTCN#sQH!j;e^)@+PgUZlF3=J8EBT2tdc6gH6&Ejm7G?LZvZDuJ+LC_^y%v zqdMkGfd62*iSNG>HyDT!!Q^~{ym!9${sKi5(6~$wm#-D}&6!6v=eo3dMKae`6kPQX zs-`Tr^nI1^%2m!`nv3vXXF10zDQ9bDo+*|Xnibi`w6&nuc6(k4^SF!Mwx7q( z&D-6%)rDoJ>U|5daciwzx${yPEnFn|uGkMJL6PYkw9$5&#%Uc{o_$2q`r2%)j8c@K zVx)cQSvjg4-5Gr3+i?F&Xvt`bcnhjL4>6i(hfA74k|(Whqv z)LlbLN&uP=+lpefOo#ff^-pdxEaPYsOF+B0iqR~O$2q=31vj`iejj>#|9i1t*~-!S z!2~<;btZCAcue^atO;fDyCbuM*yEr>d*~3~>ERk$fk(sVKFsOULni&wShZP8DL)CmgHI-FUO!o`R%xM; zg87S}*kCT1&n6cBLNYdJPD{9p&}lH0mt!B+9{Cy*MVmS!UvwZr{cEgv43sDfZ$Bj( z17+$k2Z>%g<(mDExhZr0E_`G>=6_unQ2lwQsBWFU zoR0gIE=h?EaRY4h)#L=mm1C8GI+LBteS1L*gx z9H-KJMBr|Me&va-GkBTk`dGB<{2-PHe#@1kXRn?CCmdCv=kuEl0_E~cis)Hm^sJ4V zyEIzKmGmLc3C=&2N)}5GzbFI)Ja4@ZYxOETd z>t<@0;%?CeF_f7!5Up$g!2D;@6H*fsWtXsLQ-0>A<&K?5{JCraHQYIW`rx=C_=NXu zfQlkq>U%Z6Tk(hgsl$iquw$coym)y3U&R!)f*Q_%zyi-!KwUm25&oX=cW;YDNMzX@ zkqd9LyZ=70|2lF8>xd=eW@rs6pB!0CFg*-^x^oflH03Hx=SNk6TXNfD+C9=e<*N2o ztA@vmIU1=!Hsv11Ei$;Ft0Ram28>uVDB+>%!EKK$YI_@NTilsDdr&+M_gR>~xxEyCAqfl55sxp7ls zabN!*!@s|^epCNd1N3DuIXYi;J7SOo-kZIL& zIX-#c4&Tv=Wj05h$}m;KE%_y^KUz|xpOvc!t*)`^vhnBMXVWseq}B7D^*#R zt=!papHinUemuz|5vzqNAWLY=OiyJi-|eMq-e2M0gVO0>v@v7Hf4rjOql>C)>f6o}Gj>&~d@$~s8Enp-q2QW zU79n*7+EMBSADJZtC_Q7HhndBB22+S1>@JuFL!-%{>m8gUe@%#)$!5X-<|zxqI<4< zLxvWU=Afa-rb6aFeR{0IkP*A02M71daVO8RW z(h`=TWo>v@tvu{3E%6(vLlex1?*z#ic}V8jdkK}a#nJX0S19+0(j^Nl!0heodV#(Pnidm zf9u{uQH-{UU3_12r_0dp54Y_k64#|O<$^m^n8!ub=aq!}+_Q_qLUsDMT%LHb31g#d z=+Ez?Y-pJNyPs3c0%#sP#nrRsu}7i; zs~l*2D38VxexEx9+$H6oRi#-kMPjuG>;dCE zE9Nou(SO5Wf2_yl3mllHsrX|ix%gxDi&UGmGgL{qsQ`an{JcVPpyx<-nP@JA zZjjCeWCIF@i~r$^-p%-Ga~{=QZY79fv#nD0kJ?3Qm7MAo(JM5zX0J%?bc)4p*$Unj z7>arCDfl8d7KLXsx0l|rQFN@-;8+$?lCh};yflr)Lj3ta$LQDZl~>E!efUmJfsRD? z2rX4Is0A7vgAz0*O6B2~$)T6anIccW@f~Z#MJmK1yZBZB2o6aPKm1>?Eb_DA$PIv-1WsZ#~NY2QhE5*AKpPN|a9xtp#TkOQ_ytqQqK>FgqF1kl^@LX$WHRW@Kl z#~(L1QdSf?sjm^4;K>NWdcN3gQ=mlG_QbpjohStlEwFLRMAx5j{go@0==!ZD0W_ew zHnEa#=*7dGZw~9>7;JrfXQX@`X#y z+vCHAiSB!18m12Fa6Byks{0Zi3gqL-T_gP`!U-Rk8X)_C>6r6pk4MaDObM;QQLl$! zv1dhq-%Q;VfpU@q#a!6GX@-#@GMVpCnKjXx{h|dBBwP78tI%wo>LRO4*m(xWV+)&(7E7e2i+RYVu7utwi;( zp>&lpPd}&Wgx2m0Op-kyjJ`+s^Qokr8#haI?Mwj|3M#jvg!4s?cdQ&ADW{DWTpiIi zMUa;ehmL^w0Z&~;-zM-QXgb=t$&x5XW2LIX|TU`F)gBX`22`vvae< zA5HhhEKw1A?vFL>f}$Hgsiev}io+vjKEvobh@F^+%nO&3sKV@}A{|6W1EOZbJD+%U zQ|_-eTR|e(e{1#gk{CPg9U(d*umnC_6mx*VVrXFIcHMm!!;1CXjL|nEK#?5P?J)5lb~eexo&ra2-g+rWVI zanzCXMW|+duXjRP-%Tw-A$)P#xtfheHp%IQc{i!Xx2Ulwj1K{17(Ry!{|gSoA3R^ZR~GIw&J#-4Sb$2lVwM>~pL!=la)3SH zj9#`eF*m(jr*jJtMgsOjUA6({#7)DxoJKQzhlg(2v$6{f|56c`e!qb@=m%HQ8}L__o^_yEmJ_sqPsT-%F?w zw+X45aIja8V}R1Z97-MHj6nFbKQ-DqZx$W$UH0FZUNtF6-Jzz*LF}&;inhupV2iFc zn9HV^jtgw5SbFg%)s91JU*6a~3Jjbx6k$;Pj8#Xir$#I?lT_(!l62ft2V!Cqp;9G?g|1Ceno z$nc6f{1cmSqoz4MP=gENyIId-*W2th5a!xsNcEj+ifnq!tZaDgGj93J^8pabrsdv| ztwIY34*ls`gwda_1&{uU2vl4e@;Ng442V1#!^E>N_P(@UnBtetPbUpEKedDT09+Bp zO!VoO3Xuom8T%=SSD2mN{0y_xU-~Xe+D|OJN?@1953*JphbyQ|EKWk7g0t~uvw@M@ zV%}))r%|ZeJDxb96C!&UQ3Xc%()Lnnk@+NHwk#aG%FXZeby9dYS~VW~Fy7M2@a?C; z&2bQ^fE!&6fdAglgr7|@8;7+fSP)7XVcaGeoXlFh$JXKf|Kd_(-0%CPW4ydvfJS4q ze36?z`QOHPt};mSW3;N%9vXU#GV&|KgvPjU$ruNW??2P$f-6g5f83nV64=*&{J+88 zw4vCxGQBDbzxT(XVR!U7aqWMn&)g%1=3l6-#JYz|KP4<#jM%xR|CR8~zr(k8l#;)c z{&Ul`kCL6mY?b&8B4O*b&=t-LuY2HQB;2OZ5)JfXg$T>b8Cp@1nu6()w*D4&sk5IK z^HEL?{Xj>7E*L{q@ zP2W58I2|nZt7z=GtIAnt+)>^KOMhm)R2HH456yv?-YFSIbs*eV^Fa_{UoJ z*N_z=(w{7q7MIjwt$v9Q*}Sl0r7*|V@W`LeR!&s|+0jSp$5MIZQigv%{Z(@_l1vg% zX|Xmd75^$f{a58Z6|mMrcm18tC$>3N>^CnJbFd)NMa?T}DW9MAvvBx=nXE@L8KO-@k8myb6wmtm6x5`hf zRQywZoV-cS^8Qq3HopFRFk%=CPOTGKK9rniCW2P}(Xissf6pd)7Rh=r`qA~GQe?`u!rMGBihr{mX*qFTV@#TWltNSEuG!R#QCk2=uQa4ex zS+Xo~6hBJ_^`~o9uRsISX?mjaLOqj-a%HBkJ%D3sgpGcV)uPF2{Nb$ zv&{CDD{rpYi-*y~*y1H8eCSBy;w2v`gcHO%tekg&0c;uF_;|^s$M|^3xhe086EAt- zu6(?tkD?mOYJN2wU9X9*gV-~# zc+~awYb=wMED8$?rDwD7P`4=D|2ah=BDZT%II846{N&F-reiH4x3Az2GbR1NIb)Nh zi96PtYRcSNy}-J5zqYwh3=A5C6ux9mw1nLiHor$>H1JO+=!_s-ym_K)D$gmitu&cs zpeT|@@U8*6p}(StfQdLaOVkxNX!>YU2S&oL{c;OKQ;kSdD=A1yn42{7cTmjPR!5-3 zq?OJPehif@y2YOG$(Tbq%ZEni()(QM9$CGKkI`!J29a5+PPw6uk6v=qqMJT@<1x^& zQV3xUZZoY0>Gb}LluYcIH&WcjAGM!x_v=TAPi`21QWf5G<3RB9klRuD8tf8v#mJlG zRL$lF{SmFM2bEuacNgBmnt|EYC|;;y;eA^=@lOgl@QZ0Zv*0x9MO!%EwgyFnG^t~q;+8$Iz0aw=jWvzj_EL^+93L2?b-21Yi4)RX2|Ru5Y9Jb zvZp0|6bFSUTr~%E`v&?h zyy6k0?Z;e2(l$^ZoL#C9gcU-(5~)@Mo6hp05^n!}vLXo_8Rhxye`PW^NU(OfSPv+L@3jH$w(yz{=VN0e^Su{6VK~{N` zMyK-=B1LexyOzLr>7el9QHZ-mz@T#M)6TI(m80Hl3h|N&3GRWq*3dJie+VXCZeM8g zAh^?UHWWef;|LN;^a;q$Rcne~SLa{Hmt2};2mp{rTo4@wD`IkE_2I9oaOLfh|AYvq zC7}*5765;2fI;$9I(y{;dUWTW)rm1%bWBrlnZU?ihz^*~M<8?#8>)tn`0Wk=jR4S? z-F8~`1dh3dll|FC^XYTR`l!$7+Yl%keAFwPkE$<>2PeaH^Kr6+c_g}&Kqh!lJOwa% zzb%JI3>?I|(~^7mMU|ieSP%EOL2_ZYR_24JL==?~Q6NKEc-#$QI?oRrG|WR3pwG6S zsjFJ?{%loi&%4!;uN}k=>=4FjJ=>_sf;n;uV>58@9W8W(KfD)rXV(bYJaq&HP#AwZ zw*K@GA=WWT?keOu+_*?e&^T=0~n1SB(AEQkQp74f~-`T`XIm_r*={TAi zi54?aJ_r*&{Sfl<+acRK@H5&I$S^zk*R)&I)a7dG{(|%mkpINOUBD=9LXlY*BVcS2 zj37ujiyXyp%R3#VDuidyp4ao1lkgLXS?9)W_)x05;&Z-Rn&^oiJ-cRqvp|^4-X}S3 z3@+83SdYU)r}B-;jh7sq)~Dw(_Zf39e`#~5#fRjAt#`{#Xg;g(y-Lmm6Of%Nn+wr~ z@VB<3J6=~%Dw-jZXD z?EAatkp|}H5UtEm^Mf-ofa%%xshZ+O;1 zVd&!;tcZ=shi1V;c-y|hrevHu^g@{}Z|h#drjRNRuYcAl0ypiqSmhtDbsSjNe|vcE zg8-#-Jq1(=Jc)&0F%BGjM!qtTe`J(o_75>?_~c>7hm-Gq`}1wpcxj0)OI{2{f3k58 zrr}Q~x*Y?fH4UDhh=#IUIx1A!7E~Wu6;P~tVNQN7~y6r1^kZ!~A_n`%k@bFCI z4#~VkMpNL59=VMGU^=ix^sa@O>mI}vZ!$&GOmBA4Vi)-WQ8Mw>vLN9rdnhyr%G7eX zIFLS=@RP3ChOgNGQMBwqiSnCi=L+@}pk=luCo6n^Vi-v=Nv?#uKW_+R{>4czNb6V}jO+I8{sbw$r_ zD!N`8T?erj`<0pq>e0`ud2B{pAGTylVB+VLez9MF?FhfS0Nk8h?D99u%~IPQ71#Lf z56mmG(V3(um+)dlL&9TZfC9E^zSyO$V}&#V8PM)=FtL`-PnKJ9BmRamxPHcO1gsO6 zMAvzG7R2Xjn>lobql{bRZ_crl+(!C>h*h@2l6cLB5Cpr%oVaItn$^3mEojEl#JaCH zMO<(E5FUTE%&A9D;KS&zY4fFj2pA0l@gV_DH|_iyEf(m4Kj66UIGJ)={O_t>;GW%h zj-CN;V9&*pl4o9)g~$383MN7*V55+cgD%&oHcAupMUgYjSK1$NTlvu^ssUC3-|>cQ zykV6J>r{K#YQ54W-+%jyTLCu)>sZ;xL({(Dyau5LSs*#X{Bq&S8GIxJVyEb(*Mnp7 zRM?$jq;1jQ+-JG{FaQehuJJ(7jlblPW4<{p>0ulA5+GH3JwrIq7lq|R!3p#C0G0kE z2#egM)M3LkA=k(7X-u#1VZSv>kqQF+ryQ7%zu3$;8c2Dza<|iD#}eHuR0Wn^tKSSe zG*+c5%4GV3(fwzubr?Ii%P)Y-YUZieOO#5A1_YVahsLsUfc33Os%XUXjzU%V``(RjkB>!WGr#1vS5K}!j zJjySB0_e#v2O;ZdSAUDbzdka!&G44rVTrnl-kAX^*dP3p#KJ#O4& zb}2?)G~Io_BFRCoS~uySy?pR2?>amzTZ@Z7a&@r%2axM=)wolf23sTen7s2IQ7Na~@`uh9f{r552oxJli*#G&r z*l?)tYp@ihsqByR9_ZR_?cqzhBOB&&_lX?8Dxtj``|6D;d3_mB-|PB~Fu5uvR_0fM zLw}KqF4DSiUPMsY`k;>(;ZQ(WKi-P)PjehorezMB9HQh&E4#Ce-D9l+?Y+4qZgZMb z5BoK3r!~r>IY_dk6PPZo=mq`{CRh9Y386IoXY5Z1Vy7;k zFG<4-2N!8L!-sa0kYy}h2r7qPfYeCUeQH3<)vd4bsHpg8^Uv6 z_3;`;Vgy4`sH6yalYX(kwv^2CrT$)1S}Bxex~G?Q{KEN`s}uTbzJET$hDFM2-U9zY@{OVylxi zv$aTfv@gZ{r7nYB!)}S#G$PC*PZ$}KI&D7s@d-ws{RKlx`qGHgs)qBFSsF&YF3-KM zX+{t~@v;(1SY44}EBm52ZL=|H)pCs_XNS}Cb;%!S%KDSLB@g+SXF(p!9vJU_Rz4x@ zERHtsr%EjgN6EoB`svFNv}WUNKaG?JsI9eX#pFDEF6F__(>Rh+WbT3tM}g;UU(M> zdL^2<4Zu&cRK+0s(N6TP9I5W!O|OIaF#-zJ(A{jjEEO$9;j9S!9E^VVKw#mx`R+Zf z1lxw%h{&H>l^*|~PS1(-WTeHIR$sEEX1HSCpz^R+BjX`g(?)y!t`RG9YYvEwu1OXI zD=ZTnjQ-~j{P8(Q+gDBJtMdG6zYV*g(@0m&vi#5+zr{p}6+Z*y0PRz;2&UW2j@(TO* z`sjn%e;4o5)_wNNJb#)ISy-S6ERp;!DHg>fK-A?22+eES&Q7la&pcXH51s6{#(wF| z!@RwN87kyq?yX*+vIYB-Kkp|G{g=!`qE}352G7L1X@_o%l-~YtIHkv2(Jc&55DnY5 zhD+)%tS`$wiDe?y`!D>2Wxs**vUyWAl)tt@0G0Y{z>8?{T*FHF;icU0R;5hfvhi`p znN*!ii8?EpP1jgT$(To^U8zMPOAx>O+s3#hd1+3#Chwmt7Op>zakj9g|4FZ%$?6Z{ z=TpD`_vH57$8srDkF+jbh6meLWq{>d13Uhjk?sLQ42)0RCUF=PZ*5`TZ8<3Rt>$bw z)A%u(#y_PoTTrP%qd_^zGck{ftJyB)f~$6001|uY@G`WJWF{?^sS(ShBqZn;3v-UX z^mkM(J8qVK2&}@3$}jokP#1wvJ{PNQ z1Uw&_v~#pF;Crr9riq8gK&fN13@b}C9)9Ts7eHZVu2>=VB)661NLS269;zQhV|1Ti zhk^*tk5_Ji=3nU9ik*e~y@M?P&ebU@9G-ERf1bNr5|xdgbG}AVd6ItcC>Bsze+9QP zI=(eRK{)jeNO@?aE=%b-_n0Ag^`TT1Fv~r%99|F=kp=n*YCtyvp?ac;LHNq;1nPfL z;?Lv1E%3>SF(B+%@7$wX-H!0U|7K&4+@CVig&GGwP*N-gZkYvZ_0%NRROs}3+(!{n zoSqs6> z_g~DOF!JxeXm~%@IP4L6-NM%~A9i4!rB>&!@1OY64L@0#qz)Cfq=G&Prg!u^TwhdE zv-81j5~YOUS)jw=EyB3_sp+GmNyPdEF4b}p3T}~*yNsB)kpJicw%8S59^5_ZZVul z@f5M!!jWn!i2uB2FMa9ekg=0{TC4dS&_^`!24Y9Bf9x=V{bcxmL<9e@M~!2L_cT^B zQ@O^u`N5pgqM5RH8pr=DafNn8(m}gGbdw(!4pZ#1U8pd)sj&h0r}P{-YD&+nQN!wc zCXX8a)%sPFM{Tx$QdQUTRu5zKJ@ZFxQUB27QClXb^t6sDukV>LYD9fcsNsQ}{1Fg%aCLp+rI@Dy)RasS?{x={bGWc6z@3;p#>-((@g3Bg3JaO137 z;W^}m5%?bh^S?L+5JdvfWlHXBj6=Bcmx?-s57^Jx_j2DNuPi+1COiA#@!Vm$+r#d{ z4{yStRI&|kfd3OfbD2KNhnSTB5gqH>g$EdTwti9h_KV%RiF^IYhAk<&E`EM>^jz3i z{S0&be?OhKw~6jmtQ{I{^j20@8TyLK$hD8zOFgWy`&;8Glup?k>4ZAPk1p@kvyK(= z_&6_!HSRRtNi=81x?eC#UX<@%2eoILT3lY%ZLD9=T3UvRkWqPA_>12=vtK2Pg3+|N zkGU;wh|;kdp4t=V*>FA`?K%(+6HU0f$rXpNA~?GEo}6##ONZNW{w-cN zuDhGu3ywfIx{k0`ikfVT-dLWm`6`#%iq@E&MAY%q@8X4BN2+S4`%L2DE^eorE0SZ;H!JiPsg)SQkF&r&O#D zotbn9GRG0Fwor?CAV*yjyPCkA*-U?)Oj|`^a z<`lf&y16A#1{0R8V46SvQ*;#N+BUaILJ*($r6hn9&B$zeKoe+52BVAc{7gg~kk_ME zh9zo+oez7>hygyT@VN1j!s9Ps@Bgv0Fi-iH^wo5nO!)Ku>IF14)DE6$k2|r*#ugu? zkU^q*cexFDJoQ@5G-te3&Y=KjtJ&tu$3+Y9-j2@UD3WIPs$9D1yZ+ToUcuR?f}9gl zQcc;)vFd^%DWl{m>_*w$RczAJO@JtVw^3)NlL}C85hs{Ahm(2twPr9OjGWX_|wFm;XDj zac+cj9r%E`fsuY8tKWBq685b}aQU~|;)*Sqk!ARKhv(`$Gg_Ytb?E9Leoj{;P8 zcyUn?jbQ=f$-QVY#;zWX!IZ|yLlyg}im5XQ1vS*%K|_?Y*SQml3PV*D9zI0jTtel< z9suGb6QGQq8qr^OE{rG-uH~irNT{+t)0rbZ0+y5%k0dyEbG}e3ZGLCyLTB6ZXEroA zd=wx&-pb}1+S{D5k(Q1CT*L4uP{K$f?wAZD&@}Pf2;)ocM?em{>M1Urxwdh*rMBh<%mUc4Y1-m)u`tn^b+?0llpS%1Q_6%SRL-U86^( zkaj=oAT^zsEQK`kPsl8RQj5YdLqQtE{=9=j(>k?I=R&RT{A)#>+w0QK%l{9Z-+J2+ zXbNI8>s{v?eCHqVs}0=H=(WQOBe&P3ooAo<-)VHv5S_Q}fX`7YpQAqU)4s`>Rk$xm^szrU@xRjf`~cqa)^pAB6d4LGMma=X)x zl3VjiIVu34a@Q&8CWw79(UGN0A`VZK^XtiS;`jnt>~$$w-dX#B8|5c5%L(cz*YmA+S-TdKQH1H@yuqvbPtH!rc8E`trzd z8Ae9sT{zr5vOv*nM+hvpI>XLz!Aaa+X+Kyyna+4krmiZuyId1BrSWc^v7Vuo<` znQFkHBX>Ke!rL-JMOkj9t|?;EsG@V|fBW?)0p*L=6waYHQ1_t9qVW8i2jeDu`VInq z%kEtK)ZXD%2eRg&86u&o%%kb$8x2n`1d*sJQq{lqLh{}gq zqAaY?@^qiG)M$~mW%g4d9Z1v7w2)vBT*bKXi0e1Uj{0Pr~bJM2o z$1jSjjZL&cgT&!88#0e^3`Umogv0>xJM~jUPIHq>7$CzuJk8Q?vDY1bfpD0?cnJ;IkfhJ`K(N>GD@RemDsMN$e!)UWz z1hIWqYdsXz5U8wV#5&R2@QBAt3;{2V=bDEk<$1RAJ0j(t>L!plgO8#;)__pMh|9t= z0ie*1nAzyo`;60n4hlnCjBjY<-jMSO%6s>U^t3w2q-R>nu+IH(NiilCu-+mnd5&*8 z*f^e0Vl*W(rq4|>f4EV}0ukRoV&~(zV*SsCzq$(6-y*-LSddq6wZR3`Y&zMoevv_Q ztD6B4Of%MjKUeFyf=6HXbF+2PgWrhm7uh&7P)i zUamJw?TyIGYa&3=K0kMSuZlA%a6=-d0ZFWhlu9=dh}rC-1Jc=TrCicchy?a~wrwA# zSY$@^sewY_`Fu>tkFH~-2F;ck|5ZGNL9!Fp{x(I>GxoH8#`h&US5l@i*gSPycI#Eg zWoN7^KQ=pm6(LplL|cR^Z2Lrb*7?rbd|+dN8ME;OEwGwaVLzj{)sHGUEhr5h9x$kq z(NcvF1y~;83uk_FP|NS$V=cdDKcnB*&w!Sn_=YN3dL2m0DLFkn>PnaTLt&UY}$fEj>jGS8|3J7Z_2!ra|@M(;VDiaBv?qL}$BF zDfdhGRa{Vn%kR6IU9M)^5H(+zH4sfc(-%W(JWRZLtr5q-G-Dwe+&rjW{KmTty+5>{ z(LMUnMAs8eV{4^S&NdMqdnE#P15>@h@#;QFr^T!H+ObUW>OKh!@#YppcgBn06eNFw#8>pBYSj~#LomJDNs zq1PTw?&)$16I4r6q%m;S8i^e>sePiM&HN6IhPLAkN;xzJv0IN#(%|MSSxiNkBvF{1 zrF-%$GCM?A%fipyU2Jv$z?4;%5siITk#Eyg^t*w=J*QWnOV;K^=SRtn!G!k!TXCpz zfyJ_hhToXoQjk{YQ56162iLeVV&ZVY4l3=xo*5jCA9|NpjwhLI6%46RfSy?*wM-t|0RPUd6LPqZA~-oDjtxxqt_7@z(6DW6!+0f@X#(-(3EHJWBXB5 z1v_%pgADZ>;mxZHYZhHIXhO>_=PCw#FJ0;88*s)qBF-RrVqXGYU02%68P(@0`gL)I z=MEU?l$or_ZAvAsdMI(vxA!Ido#-0IYpv|evb%>^d`b1RR-aEw(fYK8tSHa@j(1oC zhla6ZelHrz#nzCuaVhLr=5ir8&>_)v7HtT$^8t-^;@4X{*f54_JP5i#-RMmZ2z62^ z`F3``a|qOp(1MUhUFXJFqH8&JR~?+E-hN?=HId{f0-ExWNT!3uCWrN#*65K~pOtzRKHO?!L(s%7vl5ly;mp$45IxQR0jxUe zm?Xg90>bN#4y~fYxLucs4y~RJHb49IJw^2VKno$Fr_lYf-85EzLrY4>Nx-rSigkX- zV#{}UC;hfW7=y{3ieKzoI}>j+3r#I!~y`4#%lXZ2B6Z84W^-ayZYLm;Q~2y=jeoItSfW z!p-!(D~nm2=zIhPyb$gVTpW9im@Ry8pr86Zg#4=@5zTUh^-%$yhF?^G$Sq7EkW8&QVxXtgIKla=U4*KF@0Q7>33@ zey^~H4=3zN=ZK3-u=iAfTvD^s>4#I3FF%O-ehrk9x>+mvxf<%VFKvnuXY(Em(H^zr zX@mU*x)-N}YfbkQv4PTFv(j17IU0HAA-v{m&PkC4DsIiO5H|e;CSs%Kj#O|ZysRxbpQWP$d#e4JH#-SVQAFYMx#rt+>V^3nq@9}({^S;Z>1mAvs^T)j3_x(QS zbzbMSpVwL5c?EI0ko^ZSrJb$#yKY_Cg8T}3zR#11Tc1dOoV`XRKkxjEUMzg3K%$&J z_9Rh`n~_HP2KTifHkwz&q+&jyO!=HSg_Mvsgj4Uyr^h&0!bN}Gdhnu~Pnc;3Yj_)h z6Nfd$4nZ67)&pXOKp;-DRZV8z;WT)prR*ko^Ij^PKAxMysd1MGAZkr>uA^?^%Xjtw z0DH?2z0X-8{LRGdJ1p@?+1;z$S=}J^q#bYazjfuWfRPX;5ke;HZ|%sQ%oE1Y$E&3v zcESGv_PGwk?*9i6KN1MfhU_-_(ekBiZBw6pU&v0BpYptv?H#u{*}C9fmjZp{De5BWAW zF~6RjN^LFHAdtkFX9un}VvjYLk+j+HBm{gL#{b$|bhAPD&`oYZWEmq`Y%W3v4l0yt zS*#+4iYzww<`FrSS5Gl^7=S97pz5&q%fek*AfVL9x+Z0y&G6%qXULoqht1-eZDh_v z!PuldyxY5CXSuw_jraY0-*wq*HT94gaL^x;Nb=x4xnw8nk!MeDzBc)y@uKq?ly%cX zssJpUi{hcdG2&Z|`(0ehYMqksH<&Y#iuks1Tip~4#=Mr?OhaBv$ZftZ&MY^~ol99^ z_eQ1Z{Z{%PWnuNPbdJ7PsqYrV)Y-c>`yhDd%m{T!)(lOY6i8Mxznx@F&>O|Q4A+*4 zz%Kqxv>k@yW)6zsms?)k{mgV_O!2i=iV$^I5XP)!HEGYGhlH9+Ud zH03G}S@Vez>q1H0d3w#Bg7Y~0dy69CW+xVUHrz%y@iBTD#FpGA7J1|1qJeI9GKigY zlS;L9bM>7!0b=jD`91T_qjo)oF?`xbhY@okr%A>=Jk&Douj-A;M z?G~l=4r7QdeD?dfl$!n8o>neP0)Rso+J5PNmkJ;&)Jf(#$M*y$N*Ix{Z^{AZ+RDV< zJ;YFWS(m&&Kc_UeD!plg&W9o}xL!GRdQy0@GC6{do|+nOzTP3w`9VRWTauprc)gF|if+Ik-uTPSS?rzGfS3!&FvO980aW{EqCKY;vyd3Q6 zf3y37Z#(V7*%cYSwlY|Yez$-TO-kYEcw)>>W8PO$bkUQ;g09mP-Ci zpVSFrFPRn;%eRyvJ6Z1;=r?Zin23?xUB5F7XJt8SBg=W@zOQQ(9Ct4v^<@^CPu|`V zA8oHUvKeFa9$al5OnOyzPfBWv?-blJi+yih-1*wRuXny2*{I(9xHmFT`tchBByFpl zJ+O)%Dwj}fYY$#rXloUPh2^(*3mp?zKg1g+3mr{co0*LWs>M3zXDk0}6d7dAKv<|f zM^zkw%V*joc2R_S?{B*`Gr890Xpp$p)tg|%f0>v3Aa)L!t2~b^$i4ga0v?@HAk#>2 zN%ki^u%Prl0+(U@aF~w&k9eW1H@dfp32SzsJ&U~kDEPFNbi;x21TAZq(vQS7d+|e_ zuE|{X1=*OY1m&p%L|5l`U57QY2nPIXp|FkozR~s3-*oG6;_AQU>6&O?pq6lMV`RU7 zZErXXLRet2u5Psl(H7Pb4RZA^INne0;W4qOtxu}u3FDQ92StwGtTgO!BV?oBWv6Ry zNIP{1JMjK?q*b&~kiD^L8J9DUtFb&=#u_Sj$MMjnQo=5Kwh@=1Yxch%Smd&|c+s*p z7nA)})}>`_4TUWx(~cPDIq&AqL1b&7eV`+or-R}FN%uXOL4d!FQi<_bq zir5QyU_MC;K{c}$7l@pT2+G^jg&6a)Bz*86pIe6+T_xJ)8%u3sO*#`bf@wL*YDN~x zYTo*OG?PcmNwr+1td=+jTT`6id-({PqA6T+x~wrm*Dz(?&;qW4c0C1w1b}Ni%FAzT~Id%C7gUIRTls(Rxsq`&VQ2>fLPX zr|YR~i~cYJ&@+3@SxCe@(Bk;19#Gblo^!kt7>w3Qgn z2=AHd)^=3sY0DDHFDt6c&)!l(M!dxdxR@6Y<>A;SQN-(T~yN!#$zd-;66r2ZsIj?9n2OtvmbF6M=~wBGE(eU~5R z&-7!3nVQb$r8d=6HCd{$n;`z~ozhpvD1qsYhM*KH)7x;(yj)CR`sznA;litIOV5ZV zx-tMBb(#OP{!CFj>+@Hd>c@_tjJY!>`Dv`0s25e;Q4RkgfG~qdKr%*6M3B6)9wTtm z?CK{`@^<~sMsPe+I2O@+!sPG9Eh2+(sQ|i>t;%j9w9!4JDIB7gT~RAoxu7t`@XO=1 zneaL{qMZm>gkNH+65u_^gG~gpLgWyR2$c~iCFL;D>0{wE#DfzHry=(6$am>QBo5)V z1B8FG6ll=1 zig4w~jVQ0}-8`!n;40C)`8%*jL(|AKbs}-}hqRT2|2ft{1enATh@@Y>8)AI#eMQ6a z9d#+9VKh@6OTYx|EXBQKOMj{@YplNly8s&`!|o`r&sNCB z!Gi3uSiW%TMaW?bJnAZcZwf~D^9FPr`ZVX#kiv<7aKNyoI@B`JHr-lwbPd<0ay0Z$ zsvq~|qeBA1jeZ|Jk@#xL0hM;=sgaw|KCMkZvYG0NQ&kRoAeKw<05I}pNerJYp)yc{A0^*i-r`=Cc`Hk zB&ZI2jjN9U(22v_+&yVfbOuW@;AAC%C<@N)AB^0gKZzmZr)E$!NdPuMNt}#7FTB0L3>A$JTOjj>Glp}lkmlEOY zOFj(puGV~YT3_%XPmz!C7akNv_$OW9j$b_1Pi*I#r|ANfJ@%fRq_TV^*HrwEKm37_nZ7_AgQAX5wn9Ht_7Ea_ z0`>9+T9!~x^4o7pGx1S<=psS5VH=z*Pt^XY_B*GCLLt8V}InJ=MKheIO)g4NTBUZYRRyz=$n90E~ zm6gz&u;l>9%J*Y%p!H%ZmR&67I`v#5KuRo=RKFjA-o zXXO!U|GiPc7uVanY~r!t!7M)us!_|n#e~)bRFUsdctT%F!WW5qvS-VMc~pqOE}?h3 z76J%AT&-Ne(k7QHs1?&%mdL8QgN{#UW;lwyR&@S#MtEyaC4>0q^*SgGQdhoQpm>%D z=vnbN)E&i>emFkhuQH>PsdQawrt+Z;(52TC?Ng0^wd_Rxy`H?#L>Yfta~kVYxo`*Z zVRSN6d8O6Rce011vPY@UtqW7eEtAvmO(Er~X7|)<6VeD4emnfD6=`$XpBz@MMCbMT zu2e2*9sa6^ve}aeNQ%=Je`0t*`r>Y%9dZ4%Plbm&R2j8g`Xz`Rc!f*FxZn~|E(w30 z+gL7duIajt$pdVm8QI=g_8bq?G)OX2jsax<|M>2FWMkyhj8gmW!Z2yjBF;Gwk2A4P zck;hC*KbBZ4d|c#bU!w_4`Qd5R)T9}Yg~Ba3R{{eoIBUgQi_*?AwsLZ?A?|64ZOMt z9{2UpeGsd}N7VrZuyUMPu`a8r&2SUvWtdFS@?MifLYFvh8p8A0W zC{g=CdBrtRI?bEZ%*m(?yTokGh-O^F0e3~Fo$9r!hFz)>49hJ?W-loJ^u8YgTA`lo zZk-yU!`2W_EA+#)jwK7%ZS0PYsS&hl7aY8z-Guw%emwSCiiq7QujPR+8dT5N2-o(Y8+7U^~ z40u`>;|Wx&2v5kq7ma?JSb-JU?_$%Py&XAa|KoSGFnecf;aXj6dQCJ6KMuc73$|!1 zhz$s$kUX;1T`gmH-0vNWtHcZlg)JA!@u!zOES^f-WIdaqW!QAG78?|p>?LfyoDu$d zY)`b(3@lp%GM8Z_8Wn#<%UmSt;RwIn!gO_ggt86gn)YV5<#t%^8R35GYf4CmLF6g0`UAIONm?fXj_h`6l-(4129or%?QU`*aNNTzw_yg|8H@MMv{M`6i#^}U0LwA zp$t0`h{(HFk(@)%l5n`6vWXaJv5MC!2b?~+K+ZH-eUo063A#o)*)uTKWE)BwFKpbz zZAf@fJ~t=yLFK7arCwMD6A8tP;TG-r@xHA&bZz-~6!@hg+ZgY>dwPi@DQM!O_HIr5 zvF-abv9UGb+ocydIgN1GRox59cRF<^M@Az+;Pxw<5em05PCN0=&Xj z92s80P}eGS^Zy%9Nt`GI@w*O_jvJ~d`Yyr~iU?;t?P-PipLUc> zojazx6o*@nXV#}+2eTiW{g0cN3F(VAF+0(*P0Y35wu#x5bA!n22drl4x|x}+^4iRN zcX-aYuJ|q!0sjBTH}$>o?e{JCMyJ=l#?qJ>;qK>m=YSJe*{n_fULdZgP$B&HDI`w* z%F-1}Ar$2=5>s2%@9z0Y$ya#hA_+UfWzxnnYMWNoZ@GF~Y7xZh#=BU}NsO(nzT^N` zZ=ltqZ0TstkF-WjwygodcCHSH7!WpvN-esY(HFq6}1&C{eq7 zuwtg`u%m*_69%y>|6NFhZ6Inmo@vMLf_2FYg|OJ-hZ4sAdRZYXhLY@WE`U`d`!hpD zE!rtWGMdIxb_qi<%?fFH6&@t{fhii+FJ(7DY`=`(xDu$iky32c+wjO6a$d|r1Ivq1 z73}`e76ld}Q^W!2MBQ-RuU$P{qeY7l%-Px;k7z>n%P^_ZO?dtVntK=FTbDE}4i6rU zAe=-X=6P1cuL;MjM^;5>lLCb=`}mn$=c~4eTAL{${MrTzIk9`L4)M69Ks*ZM1G>z1 zi#0gpR>`%Mf|Q=?_JERHTcO|3xkNG~;lP>8=UJb_+qYe7{4WzNDwKO_n{Pu6Um;gG z0^lpd-OvD^j08U5asoN;5~*VB@8SP6ZA1AM`t{-~Bn z6+LgAHb#jODdaD1E{2hd@%;vQX{~Wis;C>MldqgBophYbI+cN}N}rx%`6RYXXg~kq z_9K!Q4KS3-qGEnQ@=iEd3dSPI_$q4XdUqVTm-U6#!&O2j$qj7e5b za7?oEl2aA_@k>W~MA~P~W~m>L$mwCOyX7DL)Uh?++wi(K-BPnEm7k`1t*hCpdVr9N zlylIs#FciU9LM@fgEzI8etBZA<%-#@CXq45&@VuO^UVg1<*U<|%OC{f*Xg^VS3Y9a z;jPqepV*T4JN2{I%eKz7?O1;7`#KwPFLXiiBsAmkQI0fdhSmW@YB3w=8s}fA{Hzf_|^Eln*-T=~9!q!*`lTW*W?p4U$fOjg0RtN5X>mo*O0>4}+Xi|?WK9INZ8 z-RyrN{(#=A#R`$#C~z6Qx+E+&_C?&8o|&SOmQqbNs&1& z);W?OcCfEez^1z=dUGPC%oZ|KpO`&_nrv67<`PyPXU7tx7qbS|z7mjLoZZGM=2I_A7Sr(ZU#gox!K!* zt^S&8i5^}h47NW`{*e)JkN%OxjK$xJj1B7}gDL0KJz@&4VdILkyl?|Okc&qWY6}9h zxufuqH|0HKu|FP7djl0a)hKp?sRqHd=7S0z)md~Pj$C4&jbn(S+mwIH_8st8Bi zz*wu2!!x||SfuVE3KsAqATKH(c#5 zhdUW*bv~cpNqI`pRP%oLovg1G01ii7Pon8@> z>KD`S(RPOZ{lZ(0bspV>$|M${P`@*coYL}dSTsDn5W9k57HCSa)2;J%J=C2VhDPpP z=k(#hMe9ZmdM?qr3@i`hxV_SK$>wkNX*^w_XElTyKIkL1y{$`slRXe#+d&(~6;5kV zsNhn2mH^#wyo7a4i+K-Rw9An_&L`A-?(Q#$k zTk%Lg1CtlyQISf5M}sy;DvlLWXqsQ79JqansWj`$$L$^scwigyD6>X8C`kFPk809{ zH8`93)4zCQqwJ9q#uRh!e}8`{M;AAZaypU5ZY9h1Qb&XMd9NN!<>_ADqIrE=7wKn4 z5V$%;Ujsc?jSDSH#2ja0!KL2pZ1~|~r#@plZxzzU0={_E#W;6s>bOEzqo2JK4hE1H^&VvfQstWHh7?I@`Z)-%sYEjTB(9Gh~AlBE7 zoDubc(U4uOz#$SN=yYL&Y<@Hpv%JBDtgwo@)4s2S*MrH9rE<7@I0C<2vA`Gk_r%mP z2~Y9&su;v5$kCq$G_te$)BS9_>;7DWI{m3kt}a|_U>#tZOw-b5$j9lo#3H|%X2ZbS@B<0^F?Dgphuie2C!T`xd&$!NTAwfivi2@Lf1)zSh2C=|foF zh;G)C>$K2`9deV{Gr1eiD~yj~mEX_F30 zhHVMk2{I2h*f;lXYUWq{qhDGWmJb*URbkZ$g{lBbCE?FlMHQ(++aEpc!HXp|wwI=r zM}ENr$G(9A7HoKpVxiI*CUb^Cw4TnzsJ_^!DsL3YpuC_ilnOUOs@5hK6S^qOCro!O z3KT72nqsh`dUc&si>J&LUonKx0&jbtT?RYCZH|EaZQRLE714jf3D6!+jzI{CjrkXw z{#i7q99#Hh65$nkv{hrO7M^ytvxiWf$IPoE&)6?BSOUNtzF3Bzw&vzLH&zrd`qW^?(-E}Pq?Mcr(*?1%_2}X=Y$h9C^ zgKV=7B2*Cn;yBmG{7g?cgynTok!p6+Q!yHev1~VGYl{8A?54v&rHL+^K;-eE*UQ~t zV2<0|HczZ2I5JB|aHOk0tWKsg!C`gA8m#Vee(O&TVuiack+16D9v^|RU8c9<34@#p z-3MCDuK?=b!<=i_Uae-zKUtl0OP~JXvr`MKCYJC%pJzk}#9O(O>#R&{$Iqw}#GAL( zJS#TXDM_rl)*f&Cpj1dzc+L>Aqk1>21TPad( zihNyHx=a{G&4!mX)|&?kxIs|X5H{doOkHEg(Ek>AZa#< zf(D1zv4qDgaL%2fMiW^U)AkcHuq?8K2)XqbiMB)Su}qOzwVSoukvwW-2^;b`n|QK) z&{8KM(@;|XQW77Dmi}}vFRZ_!xP#}j?J3XcB&y-OF4jho#+U7m{@5?0Ks1lyeR>eP z^bNlP2!T&IKIGJVvq`QpWVOmZt{|vWlalC28WFe8b}O8M{gDa;`KThVn4)$yaac*X z5C6q}dW$^w+S#q9Nvbg<0(*vtWVgXeq@G`yeOXtY&_RD9KR@WC)36!g+awJ%2AZRW zTb4*$ImomC!(40|_GxpVD%9PvYTOz4ZY%A8Q4*f}f-6lyABiBh-m!xw0-e+0@*5Hg zzof?3zmruutwy#qLYP2m1rTS1`+pa%Scncv8Ve=fPRC^GGCyATa`saOSu?^_M|baW z`1B!|v;BGBgMZ^Q+1>XaXzvQ2T1vCJ@6f+}vJRq_BA+umu$n087@BNl%Rx9ExSjWP z@z19e!!v739+p!f(7QZf7+y+mO2WNqAP=*LQYb}9SW2nR6=5&6c#Z2u?tk7sTmDSh zh@O2$t$fDe>XyU_!L}&Z^h0)tXQm(o3VtwUGH(2=4nP0b8pE?NF7l8NKM%?38zkhx zT%n0A@(^zI{+e~2kA;U0h8GHlbLe-W-|669T@>GJTH6b*dpWByIWsz*YCR#UF0=N- zVGp<=Mh%kNKoo#*ntir?&ACYDv4bJu^nB}G<15WaqXc3yu?~GPbBQkgoG4q|WJ#*q zW#FVBUx1@POFG{RPg4WmG9N8RNE>uy4AMj!{ENMGvV1j4C%Le2DtvvFR%!P@?@V)j?J0fo3F4 z)>15G|KMdKAe*0UQk|6O(qvUhnHq?f{7mi>S_bhyf1y~?;x%MDyz`1;zhYu-?2j$} zB1uE>2Xs+ga4rpRJiwg|G&b8u_B5awy>o5K%f0(22QcNPU;?cWcLhLL1(xIr914W+ zjzO?6DUSkyD~uqbbaYd#o5j)_Vv_qlH;jI(ORf+=tA$&QmC9>aULJzBepN!&^2y`m z=~_Ohmv|6D*6B(JX;*yIH2uy@Gb^v4q_6!pp-!|d0vBG&p-IS-iZ?88U_G4fm(ZC} zVnlB(MDz?RZGo3>sAY-TM_Q)4mAupspWzF4(jl{BFm^b-azhj7E&}s{0lGoGN+@LF zYhD@(@;A-l2PrNF9#eFS_GEvm{@O@JOdEBdc;YH|u7s!a4o_0C{9KcT+GM8uk3eGG zH`hA7v;0Nt z-acy9K%{e9V!8mi$pgvuv0j!R(O*o&%-^Q@%Q)X+U$-!| zZV`_reW-w~YH{2ma8Rk{l?z+(HR!6U-M9k#}+&2Z0T7^sWyCwx5wR}+Ua;k2_ znK%$}5@vJIH|*kWwd40YIRQp}Xq1MDDlRQBi9toc`Ysz(;CDIB%tEjnOu^}VnDOga z8^5~Dfqo*`LZ_AE4#KDV)BPi&?sxT1wjI4V|4Acb8G&G+5?7xi@#n!r|6qz{@l$*( zOy-NujaBCwbi}w$p&9h_<@@j{+ijU**(7mgjH29aoM`_yM6xrq;2gVc){(S!#V3*9 z8gSj{B(NIsM47>px#!bPIv5+0PU1togH~OBp$>P>oK$+W?Uy5#R?B4~Fjk)=^hgwA zh+D)4u_bOSNIpYTF}1^kOE~Wt;X67Q0*%xWemSf~Y9a+1E^2PlwfNhk?V#MYe$8U9 zA9Tqph^{`Irre@^bAUUb2K zLoZ;Ql9sB${(%HO`^?0uk;=&p zdaLP*)S%ZUopboUPYxgS>g9Xz(cP_v4|;z5u}384Z@=;3JH0l1(3!Ab8K|4Z;Z`+bS(va(4+VO7M4s~~s1csx z>d-|vKo_%v^>mkgq1H;c-Gx4%TR$zNm0)YVj-BwqdL1g)r1+pX+u+(3S~1zzUd#1@ z@crao+Ic#CroF*fGo3u><;(X<%s(hK=(+KiK$G4zEY=t@ZWI2Wd~xp~tt;OeHgIXv zNa^RgCn(H!Kn6WEegFl_4z6nKeefYzpdj`KQw`}SIP_d8+lD z4f*Q(4yo4nH%#sJR;qnnqWu~H8nh}geX4F)k)N2-q`RdZ{3r0}O|}*NgFgOrrXgR+ zTEXww&re8#Qsvop8GNiRm^tj24YZ_!nNyv`M+FmY_R-Cy9i;+G5zLhw>7ZqoZ^KHb zP5InqYe(;*7n9ysvrZSWTg_C|pL8~bKVV5lP`jbNZhNJ9E>sFn^jhM|Yg8!xT57k& zI@0lSnZ>$PuT{BzkVoXbdHPuT_@w%9sa*!2uZ!!0^b;(r!=52iux6NexXR*V(802=XpOA^OhI3e_f;)OIIxMa-bItQmRa z)4TB*US+m}@?JwoJnHD&+jy-Qd8NwZa>gdw-?l_HlKn)o0Y`pSvw?cDaeH@I9wP?r zB)xDM0X7RTf2q<;vIp_tL_g%rjKGyKeT@ve_#yo9MMYyyxHgd-07KZ_1cjl%0E04A z8Sy7h5E$oE$KoS^RaXe>y|F#Ps>;OQSn6OsYXOt?*(yEImn`X8(``4zgb#oflh?>Ow5$0<*GNU!LjKav)&tYnlmRK^$o$4e%$mU+r$;vlqCQ zC6YgceQ3R2b+Td!dgFm%W9)_zPAdv#tj4os%OYdx+r-Z6QHg6(X~y^nx~lxNdzEBS z6+4p)Tcd%IY;7y8(i=^jG+tWREpkdZ5;X2*-HJ!u&who2^0gA}_5m{pqYk*w02d(i zywBkj^x==k6!qaw`tVyIr&OP7t-sdk>SjsP8YdV{;!hqVn#c-aDclh?XBa%9IS~ft zLzwKQAgEba)--EzEXTmVgMp*pI`2P~?(g7*5BP&k5l+>bn|q1Agug6)*`$}ji0T}< z!wFVE6}8-gcX%|h(8L9!BKshncF8htAGWx_>2!rmeU*`gtYBFtwy~fvWAlQ{mW~MtVt3XS+lM6j zoN|nk(+r;&vmX2K=wfFd&NEo+wGZ{)J~YrC_F)|Mp_Q7l4;nf($XuBfH6t-?Hgw8V zo@pg6H9PTy*|I`AaWhXMJHb@y2;?3D{?k@#(FQ--U*d-};~DqR#_bnVR5z1i*+1)X z5a0b)cQjtO`HilVrHQgw(XE7R zQ`xhv6+7upi4L?l-0?O+1VrbnG_>$G-_RVteFsLl_~8k0-IjdW86F6qAeg0>>yv&s z1aREC38(V8QkmjvwFBdc^TjR5Y^zwb21DZWzOc?zE_geM9KM!l`VU(z6VBfmvU>>6sK{RP5H3l^^zv0i$>`6lKMmH~%gf#U<_9`5$ zh|Lr(+md15g7mK79F8tRM&Dffhp596JOln zB>!J}N(Qo7SA2Fsd*)xDs-h45iNf>Tt=%suxbKMWgZMUgh|+$QPn4~rdl(uU%R+*g zexB0Ls=*SqVeEk;rMOTUfHk@af3>?4mMX~!)<_K%vCC(6p&oqjYE3jVGsDd?cQ{ zW$rB3Pk0j!@%x%gX7+`|)kmvL?tna^tW9{Z?~}6W zADL#RWN;JL{GA_(=^A53F3vt&c!?{6t}`dMX2V3=4+|=_TS8ZUGD9X^0b={t)=j3y zjw4Xh7svj>18c7BH}=Y9hXAEz(tyR6(omzF#YcQM1`4)v_?~GC(YeCx!TWWKMP6i4 zmBnYIlDZz_Cu1|P^N)Em6~sr?6he>$h1cdGG(BcjvSTm_U5?o+MB~mQ3W1ag$VdZX z4xBc#Oq$slvs?;W->G}+eeW4#=KkS(7J1lO4A`(6-fd z>4JV15Vp(PLOg>*3!CVp4xVpKW&{T#Zq_7Ls3%3NUdd7rsqWu61v;4-qNZ1hBtGBinBM_o3 zG$=^4Jx`qDM7xeV)S%wNj%paLK}JwM=~&qX+_!X_h8;!2ciW@ACgx30<0_FFC9(vj zEi&^PJu~C$qs88CIJ&Z6{%41y-EfpIFdp~Hj(mYphOSXE{6N2EYYi6}zOtROK!Eo~ z*=!WCmVyk}jXK@p%IniFKQ{%|i6GlK3kkrmFR5P%Eyh%NSODR7EElDL)F;x>*43LO z+Wz3~HczyzQ2X>JWyw3tIkN_zT+yWI0vgp;42-(Pd$p;BZ}$f7*5KXyz+su#golQf z98R)jH{@~aRN$f_N_9d({vvnEl%KUqV@^5lv#va z^od+g*kMeW)USFZ{j5>-fx`oRw%m8P!FuCP$uvEYnP>CPI0>;p!DIKe&pU_Y^~4fJ zMz97;|6%aYX>&`G!h16XLB&`M&kfCjrKq8l4|_tskA9XaY*K9m{T`8f1NU|c``dPZSCHlt$r zW-`~0MEhYfGC5jgx6YXhSN-b)3#*$h-&RgrgQZ9Zrh01D&O`#;`HwdkwKRx5-4fg>P*Uh3V9& zq4ykO^tF+(&24SLd-upc;w%Rd5|BtLF;sSCm^F^=Wg{wz zyz8=i^j>mN#Hs>p!~R_nE1+Sy`U$JPUFE*x{kO36j7!vkh^4Xv;T>gNB`43)gB8D_ z`3{|)B`BP^HNNw2ta>W&ox07(cfqiJ3!MKv+xgFBVg&xPLs$H#T_M8eCMuR=jC|8&s}(LRky8Hk~vzXI7(WcPmE9Wc&LyRObU`=Al(DO*|M>J}|`9 z<#xB1G~S9v+u>`cIAB#y;v|hGZFx!{MmnO^oC!i1F6-NcS?p4$ITGm1Pt?k<(5luA zu&KzLB%f7VDWYoK?1u=f#L`o_ntfuld_|SiVBIS+ZzlS-xVL?_6&5J`xAV6iR9Dcb z;8@{3Q45F#n+dZcYw)p&w*AawoK(wqhe?wXz;DNc;e^TTpCnSoyFW~M`=Z|dsmzf? zI2}z#=K=$4XHpuMR8rDkLF??zh`q+f} zdYW5}wPqW;ro187z~OcT!Q=cIK4>|{T;C89^pqUgY*5gj?&r8$yPsEZzaY8~VlNC< ze1b0vjzuzLedUPsK0L>7B8@~a+Lh$s!hsueb#s0&S9$ktm4$!|h8m}GY2Sk3=kE5* zAuoB!^Hk_m8FT0KD;j=&Cv(4x`QOexW*Hw`jz(fIXBgt{*kidQ_*I&{Ln(p)CAJ{P zG#XZi_giRHsQ!eab=l3WbiDn-DoDWkusx>~n2Kq@ZzGrU#l4oJVqZ~|+aj*;DjCE# z{*AC<84{(lmzh6R1QHd6bK(BJaTV!Y63zW&k5S>Ji+EU)t+I+wWlMC;FeHZMNd^_` znobieXBV8iUrBjM6-d;f6JxP8sEJHeMR;nWNYUscLefQe(@Rr2`C(0Vsm{^2Cm68*g$hX7u3XttK#pd$i#pU3k!Ip=-{TTo&-$kg1fXCftQCo_7w4d|?nY-& zK^dhE@7m0vT&14_1))ZPbv3r9>3EjW{pPtO&6Z!Mi+F0f0QlwB@F*xS+B(la220_| z9vnb4VGFow3*A$}mOErunL_$0oAsE7RQJ`C6YTg>H|)q(bQxT)C>mUw37OBDtXxPW zJhPkPlnIGqx?uNEbyD_)+^$Y zr|Ea_h^2$O&sBa+pk{NGL2S{EGJ9=q?<)4FhKjf(=uE;_Ks1f{Oj*%1W{uhm$`9=4 zr!lwGZ+bG@kl<5n)K9cuZfAxcH83+^;oY{DjfqA(9elcBmC76ipQgLbvzeo+bw5x5 zGDp?uK56&DJFod{;2jXupL)O+b&C3P=c?LP2*1K)5Dh$cgX z2FPY>o?&g=;dsV0XBVodl#}9W{lI#N1J*B-VznFfv`Rl3e6f1F-r^U;+P+We3%Wlr z>?n6lr@R*C#`cOMPK=NsU$w2+Yz@+|A<(*-4_DN28k&eyXKl231cY;&Ymd?nk6Y~6 zTOSlzoFheMlE}KwyzpP|8p^HTmg@LnAMQh1Af9O7p-Fipuvv`}Wwc+T2VVRNCeJU_ z;~>6dCrKT1WhYuOB}Dj8OjCaepu_0_hZ6~lt9Q3Dr^EF9Ih==pWd$?t?n9PW*xY*$ zbsds5j$&(}*!_xS`QT!r%|%}2k8YC$+sX+~%fj7a=M*r%G6!*E zGW$5ZrE>GNbeRaTWvyEtVBZ)~*M6k;@OrjL0w0`0t(LSwmz18u0o7(=DVd4Y3ofjE zP$kmZEZF9FmmX59dq*56mes~W% zVbyhxk5valQWoUcJ7%OXQ0|@0Teqy$glSV60eEMGpDg{5(pi>GnC_?p zm5f?xExJCCE-1pc1wm=$rM-lwl{KEe9?7nSN~wlS{Hr@ffZ96JEX?B7L8a+tXQri~ z60_|?I<6St$F1+L%RXX{DqUF*e}^->b0L~c)L7yOIGdhJ<1(G|CJOQ-jocrx*v>7u$#2&fIWXtI zUiu}7!+;q;PNjQgV#fAbzr!Uj)>^bk&7-%F(shNtxwF>yjPsv=X_mp7^4 zqN=vnn5q2QR}`f!a@SBe9MxLb++p`D(^enrC#LBG|V2X_Y$Z!qkCoBmC#3$)L_3I9hnK& zfzmDClpq<2;4YKJ%4=8n4Lb`a;Um9@66GLNB^P6E zxdUAEr{HH9R~P&&FUX9SvNgbh9}IAZO2RRflnGg`D~Y11;;q|XX=-UA;Fo1!>`M6! zvC+gfOUv0kXf$Z^!;8O_WHlWo7C891%@3}b+zyI&A}Nj}Gl;*pE#8fAwILgr;FLF! zywBN!R1ks0)rPx!@|%FF_0IXJrHko7Np_}~5mc^jXWRM3y7$k2Y(Ohl>iK56kE}6z z{nLt_X(<{2lS(NGSMQ!10DIXB;={l&+gF(-qH?~)R{r7^NoZC%eTisxi_?e7=Y9hb zUMDr?y76likr9$VX3#nf7&PvM)@9(h(I$Pfy(bu`4^hD&)JK-47^=I_Y35bXK&LCZ!dWzj3FhT5p47wmP>mGH(83E4%)n(#Y`E!mR?58!D`dIb#rZr zPIvRp@aeoVKhTRhEAw`h74YbJGGvwKG5c&;si5*-J4U7VRpnu_0$pYc>N% zBVYCbCek@{@E$I*@l}!)eQ3QZ`q28;E$YoN^;ZeGFjq(B) z0m*x7@Ln1oeW|D$osQ$8{cNRRrX|dhydd`9z9L?fOEQzw{v#2Ogc8cc)IB4YEN6TJ z%8x==U-TDQMBffTc0Ifhh|Nxw?Bb-mDjM*$KRNl7=w5ElgyX3yb;J+QNFFFd!su=b z37s4HsP(Tt7S3!$v+lE=ribq9e8|o_RqxwM<)OH6xhEo4TPqO}ONp?uV>nPe6+GYv zVf{VwA6keM$yfQkTZ)l>=zUU0_SdWOiwrjt%piXEp+0UNZ9V8ZTo0v$nehWNgSWUv zu?)-qZI3x2PK8zAV?~!)Kvu)g%-|1hwo*-pCI`KXjcqqlQsb6c+4x1+i3CCH?R}zrtAB0MnoFC0GRO%R5@VC|kvKiv z*R8yF9{BbGuN(eHO_py0CfRd%9#(zRxh}g0PYdQ;3i3O{qV?);#XzX%_3Gex>4Q=P zn#VS+Fz&I=P|3ic{L&NDyU3T5o+$}8-PP-a(oxk~L&JN9E;=e`SU;`4ZcC{-*0@+@ ze@ZdT>!7+o@T!kBiFhJvuF3s!s|psVi1Lr&^Q+%8g>@x3fZf(>Yej@Vm?_bA3qM3Z z<`teyOuf?o0v!Ux;b7z)9!>st6Llq;XGD%l!Xf7td|RHOo3TNTB`E*V-r^m#EnqZ^ zQ1I}YpGCnUeNDO==)22zva64omx;3C^%C0IR&As*kZjCL4f-+>Y{d9yWafy{k(td# zVtTZXt~5Nb@X%Gr8ENfx6QaXdDORV(c!_-!*w)poL%LL2p=IXnuUJ#QBIw_^eIeh> zn>4cK${WN)+wWB#lQj^J)k{iUHiD&?A2 zJDu~x?3z%U#eTY07X+=7PdemRr^ zwx9u<;|b^1G`z2{3tFyJ4PZH=)n#G5*q^H=N50TP6xVX+Lper4@6&fGq<1M$!`@Xn zdgBTp2xN3PWK*JrQNNW1=GXjJNND$fZKV$4zdl63T+%`&WghS4j_B;)?)N^co2q&b zDP0YJ^_ld>Qr}UYU-=tJYnWWO7Nw zXjJ2udRQfK@SbsEiEF0w;qMIuF41ZvunskO&>(hXAN8K>pG^muo<4M5w4{RP_2O`~ z=rcoD@u4S+Mad&9YABG7Y4$SyuNwr-q+>fhp>92S7?!&<-XJ36rNf{(>3DL=_m>V= zP113@ZI5y5Dmxzv`+Z^3`#q^@$Govj(0$l_XQole?b}J9-xEN%3+nxh6B!+#O>ePsfC*^HMRKdb~y`^Xt%Tq4M6V`@P?S}f!Q^(GYfw3%I#wZZ}Q6R z(o(aTeAR}7-_y^f7OpuowQ%i5+A7?-7P38scOs`^ql5pAA1&V~sB2toC)i)}8TYdH z9ioQ}+#CME0zL3^D7MP+I$oGqw4b0Na5T}jlRe{mbsT;$*|-D`O2bqAoP_5Kz12FA z#yum#S`Gz*I>P!~OE<#$PsM#-IinNvgtN&?{Of^E5!?j2DZ+&3zrnk9muAD}`?gXj z8sE1LrW0=a=_n-GXcRWdU`lLxU6%ce}e?myz6+mQu*p`LzXA#BD+j#kN(sl@~ z5R4z7#)8=4_DMl}_MT_utg_$Ma4?k2#6P`8$pJo^9mIdLr}PPG7Fd8Fe%Qs%3V%Bz zrM&Ta10d}1SY46pd9lX*5W^i_^)Z%M ztNG0m=i_l(-+s2q_Xk*uF~o#{{=uVqvs=^c!1^Gby*u*qQHm5dcVtnB!BkR7c;;3) z6NLc4D55yGP6#UiMTa38ITl(JA5=cHv3kSAz8NU|KuLJs>^RyOA;Fkg=RF?K1mbei zjAT#2K5wP*Y6)|q&0MsmJvulkY6JiSow4FB>5O3z`~43c@mzC;^_REBG5oaBx~f;_ zy@1|WBZ-N~!sb1IHwq9Z1m#Cm36#bqve5>r=RB|$Vq9q|b0BNGx8ht0jYb+q%9ZI3w>eCM89ypcae5E# zRKv2rj7P(Pf%qO@X1bpWjyUh#q9 z$yAeltI@M+$tJ3zoCR-z>v}sQeCNwTxHG~Ri++a>d;k@-5Ukfo%IA214pp7iyTuu#0>gfw zTMUX%F*t(A_`JT8sJmnGt#+Tv9HMLnXM8l0DY&9^WDtM$#O+E(4*FZu?uqsZ=*95N zM8Y$2fbPiZ_^;=HYo_uxE>9fMzgPA+m08*W;w7EWrqa?rBS!hEVLEyv`V$-lDmX|UtA&a{cvUZ-s z{Lk4-59^OJ zT6$QS3UjTnYcSxR6Lc`|(EN-)Iv93hd zz+VaNXX&>Nn3Visb! zYtva_8ffJ@LMQ6!l-baR=*Ah-9xXcks!s)GJ2BzszO*UefUQo0Gh!(=n+}2!bMtnJ zRwlOmcl2w}qDCmk$_KTFJ(;5`e$}YV>K%T%q!Dm{7`t7SGLe*7t2FkIi-P(F$=T2FkrJ(z#l zbXn8EZ5yOo7fqC{6(*(O%_1fmre^e~d-X|wUHjGYjV&iyPIx-=N17ISv8hU=s%v@_ zuq}&bt4=lnVvf%!Ph>{?)66_E|!f7`{}DHODkQ(Q(Ws%C{aqb|vt zomt2cJKEVrO|u)A5w`nD;t8{28(9Oe1$kW{l$fw^ZTRSfRH#2$p&~q25kA%o{vaNA zzngEnsZG4Le)&Q#CxYoA|g_`ik-{C$KQbm`pjIO z2YLFN|EQC3YAyO+ZjTlQ@fw>C73)&SMY!-J7b@}#56VufQe#f6cmLLOL$ z>n2`c&M2td_-MrouO{061wKt%+gTqiYf4IbmrUN|iRAvh)L>_THq^~df>!x(T};bm z;ez<^E2NWhf--ILC{?N){`1X`AhJJ1BPppt9!zvRtFd{NlWqgppx3aegH=i1kbbM# z?A9_A`jw6AF4tnF@>o^M3`pwYq9xo@_cwuZaPxq@X{e0u%%kW{U!HmFI&%zh%gaqn))~EhQAr% zg{umAG$TBt=y#a>C*qeWj$n%9Z^9MG9_lp)MPuwzMQ||C1f?b~YZWGIC!XkJjbBBw zR=yyTwfo4ll)7 ze(-CFLi|HrAbNucEkI+%#)6{ZJ8yyccb+#{D-~(|0Mnxp7c@?KbRFKNx~1X8XZA2v zDaqE*KQs&ot*ndS zuE~L&oEX`0dCZPdP?h>TS%K<;syq-igfy7IJKA?I6gIpG>92QYwTrym-<{q;>|b9I zTS!uX<<5J*v!8sGtP2=pXCmqbvAb;}hDIb5u87m;aL}Q-^WGEfDYJQ!xXiQ;Q3QIs zZ)s$vHM`&L7;vs4?M+rVWM@}4B9iTEP>>zOX1=B5j;H7zs*ZoHQCIR4 zECQ_sCne#usqSkA5lM0)lfyE+;UBQH2A1ae3B;9d{P8pcD#jnP)lPb@pSku|obDVw z*Z4Jerb&!Vlhl#gbEt8(r}Yst9PnQ_mg^2rDp2Hz6!O98q?qh5}ar|bWr(($z);DQlmiZ zga$?=3IN{NuPUsZQoJ!b!t91yU89~ivJ+G62X(s$hW0X_aomMV-!Qn)1{LZ3VFU6KIPHiL^WPoA_;(t}RPub0L@! zqbQ^bs;I*H(|w2C^-u|5|4-#Jb)~5chv0qL`|@(Pme9WZ-Ol0L%d@A*scU``cKAbE zD?j~EW=cak9=ZeezF~!uU&H8S%fza-b6!z@zi$@`Y4m;TWa2IFkqkyB!di|8%}M$| z$rQR`3e}-C8j&WVXW6UWvgwyA#Ze53y15yY4fotJvb+Qfj8vm!4M$zDQMqw@ienx3 zPdQNmzIlvf>8VuC#J_3G&3awFYi`yn$M+z9^r`YrQ5HC#r7mK>#FCT441j!9^(fa` zJ+oes^`k(=D)B@9LHvjb`(J!5eqh(gxG-n#dTdeJOs1{~A5ME$w4w)^U62LvCdC)c zUZ5GSIj>;s`f^9mQ(*7f`pEz~lQ$k>Ve)E`beX)Au0eE-ZT+Dhqo=0wZT)N%!S7l8 zR^&EqImn7-serVW3eko7TdtMVXQ5 zz9xs>seHA{XGW6}Wz+wa+N;LNpDaC}ZE!j53ES7eL71Bn``qX?uA1>1c2dVjuoW`9GNz-|LJ%9V9_yJZ23W z!ytTvny&~at&OI47{MYKw$Rrml-m4q$(h!OIv%c5BS5x7${jt-elqda?M330o&Kw?1ld(rj~=VoXkmrGKuo`iLF)DTobAQJWWGkc^`0RQLuD# znI00Gu2O8eD%_ydkKw756yr^hQ1pSK-7=FDPDo zZA%H71EFF9YbPhPz2H`OG{87(hwh9O6Y1VWW2Uz)ElXr_@Q@Mf9oGrs;ecujL)A1W z+^e?T<73TAMGz2tL7BlzCye8+;|{qhpl5rz7B{@%mJ$#t>v&wps_c6@h=*2dD6K!; z4~*`ESjh%{g?Em%67L+>H{aBC&I=48D>xEa!GH|)=NH6_wmva%ZRJBoH71Bvx(ToO zXS5O$1+Olm$M;YO$1J38&KJgoAp`yJdfK4{Tv)9ZgZN*^2se6@ER9x9;*m7MK5&e) z@eJt>mF&+}1sh}+v8Q$P_hFBWPXt2zIn4qmcf?cYJ*=F7c#-Syw%IN7XKEBPy*kOoGN?2Cx^kPQxusu+3JiLh?cKRqs!V*i6(4Y*E-q_^)eLVwF`qSyWgpiz zFxYD?z&SG^{5F96HsRy<3N^4EWgVFr!kF_BKG29YJE?;e(klyG)+2;uN;@-oy6Q@u zu;k3<$!LyIxW!lq{w2Dm5YIQGPDi8QMyVhKzXcdRY@iL$tEB_{DUnds^Lnhim; z!4&)_&2ABn4Gc>GrLXWrg>1|MWYvJ0bvk1{xXIdaFzZv9edUCw8B7KN1pTGq1}!<5 zjU-KHIsm~4Je87E!O&ivEJBP1O_0tYDm)h5>_;^0LH+#8v3l8{AE@4JuKLscoPzs# z1@{Z0`yh7aH_`G=oCS|voRw40aiv|=Q}ETEV56Qph4N3{&b5uIUGKPjc0t?o-iy5c}+_h}MjsRkWB^8})ItCMdD= zf`cQu6bxv!;rs$x{YdcXk=k0HDQx@4|4ggawXw!Nd~4_++eW5XQ(;dqAbeZ#Ze!ti z>5x?#FOkUjR`O*(QjRufS%LxoezOn~(R4}p>3_c$q+b~%V(#8Lqbi7f{d4ar|K+y} z5uafNi~-5g3a**>U1#S!9T`+!s%z0Z@d+Gc`Ust9SvzII8-H$O z5MA!td*05@bsr@2=|(6oICx)kfbsK$Sf>1ZU0kfL(D`4-wL_Z&7d z$~W{itc)bso;|bL`rZYke$uymewD$3=H?iz&oWzJ13ArrXjC5D1jgKL*vN`c4qT39 zr&v}BdO3}bzx=B7Fv@_K9*$uhm&b^2zKc$_nJhcpB6)sh2NwgWeE($uiPBndyd>N; z4@AcldxUcR8<-tS-x6)tIQ(LKMpw%jW7)T5h{aEj-;8$)@#`bd&vfSSOSGQ~7=xOf zQ(Uw1CvOxYWx1W}3Ty5h)fBx48j7}>rl9r81uF_+7DZ9BGehdtruw*O&v!Vff+4N?Z?G(8OBk6)>5 zk@UZoERnnvVU>Ateh^prT$Ocq{D-c))oAV&Id?@<_4+YeqR0}v_gE4#8W*__ zSNTYUMu`XVxK)9{Out~9!3`5Kb~NdT^V}3d(n%dn6ObrI4PsY(8buuzr9`cONlAG9 zH@U=_CHJLuqWdW;+_u8_Pp5j~(o(6a*v?E+%0KX&-#`i z_7uB6)ity{irq+lbxEVTsH9@u2++9w-Y4fuVlVG8bGGW0X9REM+xg zvP$<{tL>`VA09yMp4Zd7L+s?wY`FNMDC_B0KM-z3x)I*=xTCQa(IU zIA6gu7y@4<)L6N`=<*TzGN}AcrgCm`61EJuM;G*<)B?D0BTR29qjm1VQGn4Q3c>Mc zy(F#>(xmww5xR2Rq5?eHCz=8E1kFrasg5%biqdsmOM|xW`k+3K?Fx6k5l-uXxBFoQ zi}-2lWo)T?_w@i~K5884Wj^lgFS5oS|9M0=*_F(wf!+vcPEHmeymzI;89g!?sFIHG zPIL;&o2|Nr*e9s^$y67G0y{ZP>zFQl*j2AKN!ZCGL3Cyg7xOy?k!t0WsFw2U{BL;Q z<8*6J=ps3d{_^rl|0Z<*9{ZTTLpY=p!lBT*tFX?(2Q(66QYLIm!w0N!70INkv3C^p z&ORwjs%-g1xHl+#%lFt5Q~xSHb*HZh6OjZ&t9D;sjfCmN%Q0yk_88ROp$oMO?SskFbFRNMBN~wduafaf^3=>(D!QqS zZt9|&db@!s*bTbRx@f=i0$k~?M9e>zK;94lkiwKws7IMP@v`1=HN)v<$V`PzSo5wy z^~dJ<<}7!lv)itFQ7Q=(TfmOv*Lxtt{mzbX#G`b)JnDFnd?lv-2dvk_U-`}Z^;(PT z_2Vl0!8F%sj)b|WN*~j0gx9pDy{V{$vlk|Ujrg-`Ghae|znTF$=8kTkY!RT`FSIRV zN(G5FpF*G%9&}dm47cf@#Z3`^p~~l-SF3IpF61@rTi%5SJ_0>HbJnCA|8H~js1^TH z;(to*4CJZtKWR7g32w=)i({~@G~A_^8;~16(M5>?eM(| zo_is|2AgSe20_XK;^L)=B{+tgq!}FkBixWyJFhMDrvyGw(aldDy$MiTK3E~onx5Nl zxvqh`lA=pQpKc_{u}a+(4&1Mf?y>bNxlhcWX2Bm*O3Mgsn3J5Xk_g}Q1@?QorSMYH zpuVH>1IPBW?Ja|AwTqfjqkRWGqwnFXSL&gE8H}w^?r^2x=I6OKWlxX!RS)C*RkS~H(4s`}4g)d18%z$VPH7qyu#X6j z%uwD@<7f`%Y^$amA95N(U&cx27sHp#vvKqi!rnf=tFXu%3 zKMb>JjB9fU@}n#jwB@GuD#FL^5&<2nI9sGj89r%<Sg&^opfaRG-pdKJX~d}<_kL^o!ug6V!z0sj-ecb}u%G?m5% zklK29LJ~yF=jvkGMy;}NuQm!q1h#_HeHvcMy-&R0ZDyLa&2A?aLV8uqT)RvyD4}A> z6X{}RhLuwr;ji!ecwIR9X?K2h8Ah1MKt*oxoV$J=)zg^;{LjSqJs#GG|td=-W z>}f7KWNz*#g=DoDg{EKRx@iZ8^N9x&l$%`lqBR8%|0(KSe5~q5QW@MN(zsFG6y0V& zk+-neO!zI{OISD&&aSXmqD*AtME==U#N+7SWZ5mdPLn!P^wRKhU&Nti@_T}!C?~8w z&2z9XT>I^XPqv&;e+o~MHH~flrKTh00{eV~F=fg3sM2gFDGwH5FXob0RRqki`R|^N z<_;TY8?qa#Xc`NT75wKxkL9mUfkQ>~f^JNc{sxv_O7;cfPR)46^VXT?6CnO#yGzfLYob z#og%2v074vQQjneq>0G~5Ohsy2SW74w9jE$Oj$C$9w`3lN@AKnhZi5ynFiA@I=W&? z|5L;McwM4`+di?LG_sR)fR@Twdwwg@8aAme_A2_<&pJ~laT0aA*5T4_aA;R&bn_Iw z$-hE+(~}ph=+Jb>$BTsS@owux?yX^+=qL2~%ixWUQ~5c-K3*Xs!-ECqNPqe69zR8GNqe6~U)mL8bz9hJPfj!qty5YY!w9 z?dx_`V(^fPjVsopEbOY8xrND5MJCg^k2fFd0~vQ4ognfURG zX*PardrZfVQz;<^L1c$;5B}4EW1|e(Tw)wwZK&BZZL>Ik{XFXs_2(ia5}PM2GZJf= zVC~?KBu`B?s?=7Pndk5)hZR8q~S>90t>@W!+{_{T6AESiG+tR zoe8Msp+07??L;UO@5%-v+A&YobTMW9%3R$*Y3f`UdQ?xJ`^%a=ai*`?8%G--BxIXZ zU^E-Lw8nhx#X7EGa`GM=5K1zwc=WSfX`rHigA}#~(ux83Yc7&wzvX)m6BrFPZY(7i zA%Z2mLImXs8LP){{^7R4+*0&f1NYQ%{?V&AxEB$6?gTzC0#_3dxZhx(j2^HwOPG!v z5Jm2}1GLB`1OO~xM&zz-wj#IBqgv$J7z0AGa#$FR1mXXH-7GrBkL+>|89>X_rbh%W z)_c;2alj#U>59}rv%?aG>=2jJyIix_{10lV9Ew!UJ8yI+&&F$#WnS(XYqrq#kN`wy zt`H%NPPIh`+sLNxM-UJ$iOVaQb*O^3zCa?v?Vu?z#bZL!P>+&!{@p~l*(_zyvU=`# zt3@--=x0*Ac}K**#U{DIXyB~Z!aWsaO4-f(iF$@iaW(|!2QmzPm!FBjn7byo8Atw& zbmYjtSj(ZpsJ<-_ZIQ$y#Fhi z?8`;ME|Tg96>aT6QMY|DE4U2{c!7DL;Dfgmdin|qe7joxl-4xSj>Z*Kn&tYNPsn1a zhY!->X=#R%prSr~D>)F677Mj>U+4+Mk?QJ)Fhij65)SV&V~<_7|HU~+@C1G_&$J5VR0 z12LiMFwf1PLtzOn7`4CPL%>Zd;@GSg3;kA`<^i+IY-X{Ge{L=+rU@7O_yKKAcDjY48V z$sWw9;lS^JRI*B^t3v+$WTTMV#JB_%ayDN13b{yL|8ELux&@uAK@WDcJ>YoO>Lg4q z<>@%dlbG@*L)9)C>%}X z6?PhM;0Siq(_S>NIt`Y9iS(Rc?LxCzN~h@sdYUaojLscTPQbyKOhqu(NMXrQr%K;X zGc*FH6CDF>z%r?xR0{5FZ_{Ewcqz>8Dh_~w_9khs3)Ro!s#Je}_)7y@)P12(WH5_R_?x>q?AIbI--TBn z-4AQ6X zBGQDjQhZn?05iEeFtDD~tBddXtTVk7!RuHlgk*&cpt~8C&Q5CUg<P`pV9 zC}d0ueAdV;VP;I)+J_zz#nK5 z11m9?&p;VOh=Cj@e=IO>V83_ie1mEbC-tBU=5(D(5)auRiZ!TwC{3G0XfSOZQrYaI zL1uLge?!)5AnWxwm1-^aCch4{y);CxaZ``w>A)z+BCM7K236@sv0Gkro|Iyk@tir}uZmyIh~`LkKzCXUukCcZph^piPR}ww z(CG|q;z8OVqRG&vMBVvfPar^{0$CEIh(mnflm2I70G>ujBWLjuj#zvIxw%2)=9wRY zoaGgeGrR&81|MK1YY6Za2dQFDNikcjfM=LFYRWy3z8M^rX7t;`NRTF6;w@Lt$H`jD zcr73fPAR~fMrnGGPj@%u+V-Dr0)rn;+YD8K)OM|Q(-#Mno zm4Cc%xAzE%gawT&$Psj_AqYlJtj>m5HABue9lT;l$f~doWe=JuOzR=l!>0t$6czHK zD<{(iA?!H9>;ZxlG@A*vXn$!r*Ntu}h5MAbi&)DGoWlecwGMJ~rj{n{0LJg9u z=7}(zq$Wc<+Z7skHo*#!R?q$oU+aMMbK1K3I+h1t*emj-k_=^cSrJZdjt-YW>T;e* zR6w&-V2ydw3bnzhLCj` zcfc~x2vZs=#nj158f|Iv*=vr!3V@z|qG4$qNC z?pYAtD;&CvD#x7&MINa0W^fsKh;Mh#lH+s(=^Iqf4%4{+Qx1d{8`b2nN;?b3c4`eo zD0d>r=SH_qz~%oaLczAh#9BK*lXG6u~_3EGVNGcGRGM`kUN&ONMOj);C9MFHH0Eo9&X zt4^odEIU)%Ehzk5`XcWsGPN@Xjq_JBX*4dub5& zH1m)LSuV*Rm>H>bT^=Q7u@F0tdkH26*=8u=cXW>)D zv6grDC8(K2Lb>F)dN+TdyuGsl1Yv=jOaUQUat0r}`FXkwtuV`+WXcH1k~8?&&EI$= zQMz-kDYHqAsF`VO+YCN-^H=LK)OEtS*OU=*C1>z4;)i+}k54i0C~HWfLVd8*sp%&i zD781<=wp0(N|}9m?8$A*o4)RWFR5`^I*#OMK8^=&K!Me52eH1P9f7;h6Rnxvpk99_ zgJ7a5IB-_@!DJLnV1YkaETwa(q0>iAgfngCv=T0fhJwc(gpk6lKzM}l+-dybj)ZF%>qw?-VLm=CvXefgG5?@9<5zsF+%FhT^; zT6$8TyvV(MktpE$zt2Gf*z!C1+shw)N?aqh3XfwgvYgBvi?7vg%|SpGYr71Xxsh)U z4+(4~1@>6toV=nEuv-Qi*n3Go@~`7>uW+|r_Xq5EV=Z5UviRn?upY}X8@FlLkK%zF znI*8{y;;|rRE60ud_iS&l?(*^8P>?sO2++Qq3SnK$Nici@VS1W=>1ZNW_*WGA<&yN zg4@i+m4CdK_?h>Jy2KVXuAqs;0FvgMP^QYRX^orA#lR3PUKTJO?1+x6aH9&pCuWi@ zHz5kdDNb=(C(U4Dlyk9LC}>{cX;=0|kNOm;ML*Gy8OxziGTU;D$Le}JAFUy^>B;`& zP{^>2hK9xwXC6icrA5JK&GAN>!ndEnr1eLGDaoPO7;p#*p#Xdr=pkGjTAG?H5gGRW z!*XX{klt6xc4$)+R*M*>PG)g&p0*JdEt8_UNZK{0kEePF==}45K)e;%ZU2KAmFwS9*{#l|n8S@ig&+a>w z*92z!H)6@UP#3IWY4VFD*=z@|UgX04NIL`t{OMB-i6j0-BU^Aq94+gHa-c|Z4^k0p zejfRW{-F5UI;`KcP57Tj)-CydaRv5_Xk=bXHOn%%{EN>eK}a%)q~lo#Op|E(Wmv=Z z(kq-*E7{}J5mG<;;J%>y?s8xF-e{Yi$3TjP!F{HK#F0gL?$t0nqd;z2PdveT5p0^H zK*#MTLOAU=kgNa^93ci)wz>(3HKa!Hv(#}Nn8E~1VF!&MzA54r_T@Ue!RulzZ%dP6 zqa|LF%&NADG{As{QL8XK|HeaUy^nHkf6^K?c@q%uX7K=^(1V~R!O zhY)X?UMK?k+4g@k3xO}{Y8Vvxvm|KJO{M2+Ixr-}{=~}}!ofbNgIDVnj@pT&elLNi zu`!VNLh(=}2V9gs`fM`RXE7v?V-VJx-)a({*MYe}OL(kLe+A?;jw$tDlQ7dvZEX+= zLx~Q(0G$N~MTzDL=bS3>PZ9ANCJ1rImD4gcNP)8)4(RK7?+w~{l6Ide&z$WgkTwy% zSvG;pW!KU4vc;AgZ5k4mzvln-5UN3}rCcP>G?y&LDO}Y?BqG zD-(H`q#o39GgaUCaj-B)eK1flu6GBpkl>!AgzIFVvs>) zc#r}X^zv^xi*Du&Ft+0e*c0e>Iosk(+*jCpFET*T(Y7)!Vn!l+y1ZulPs50xu0<3p zg}N9Nhyb?fgLN1??8yfx$R1<;TmxF8qMauki1eEl2TF*iZ<0@p8eW!49q0*Bqq$r& ze3uNTD@j9y-Z1=2imLb{qbU1fuZi_0gu*C)&x64kVDc=Xfr?T;laO>lB^wm-j zVQCdCRi&=S?;@c8S~`u2XYIM)FgU0;3fKEjyY@KTe$YlwUiph9{iI& z%bRA2L-<>O0ytxlE^)~J47D^1sz}=Qpn8R8p5I5%Q$xPf8YDWsoA;XbGn+@cJwGtFh&tmZ8D<`-{se5SaooxRt#y;yh+a! z<@WU+HdOs6fsqj!l+z@(W=dNKn4Z+T9O(j6@sc1~gOGzt{LIflV9gs?6OhH1QHx&U zm;&|^U7@!Hu(<+kSd|<3;s6q4QYB;=>zPMaa_;!)pe_|n9nt$3;3YtyPt0n0ISp|Kp;?0X;j1H!Q= zJgl>7sGRi-yp_;mo}8XsiF5LH=l))w%yCN5UkLI_yiNshq@UiEQOeKJ;& z$6AI_OOmJOxzY3a6x@;ay({JIPjo9uti=&H6$m44Y(U4|=pX@cWj#SG)P?HZ=>GDQ zO95gne-Mv^I9-|@Em5#KawUbsmj%wn@5XZ2`2ROM7mvKHQ~}vZ4q*-1tR92UXJzzA zOa`Ti!2nf66AdI9GF8r~d13x9f;-=UL#JR+*d)NlDGj;&!GYbS;y0lMUSaLvxE^_p z#vLHDw z^fq=@lUwX8dLqS}@J-cek4Z%&T{Wf>P%f5di97<{!h0|O)I!=p1eXJ`1%*8angAn} z?5Va6EaA6>^p5!IJ2)&=;TeN=9p8V9aDV`2h=4YCZ_bl+X%+(HK^00!rCUt@Ro#8P zUQ=mgN{*A8V?+vlToY;&{S}4)VQCbFr)z-r{CKyT-JfRR+38*IxZ>7qnOEIacctR;?_rvxqzKwX%dJfiDLn;z*$5YzvJe&NHcyH^Eaa} zTe9!p@hUv?*f@|_n%b%dNIl1C z!uSD$21G4>W-Cdhn@hi72ec21S6i04g;#5YWDN~0uva+Z-;{3-0%(Mh;=wPm0k8&Y z9~?%VdWvp`<{DV96RuGlb~B%l*8?kU+vueJAf*xc%Cx8YUZa#<>ab9$W!ovWUi=kd z(LK%ymC{z1EzSvgHAu&*TY}yTHZVuMfu&Gpgc33UgF8T5YXFA*hXjIzLbq2ow4)yO zOa;8{D;<1KO8}O4kWkQeC?Vv8RKfb$pkw^t`2gsx8&TEEzp>J&@D(^w##iAE*7l-z z-Hr=%6-^3oocriTi}&@z8cej9maqrUjqb)bV5j(6Z#FeuFB7|gx2Y=`FN#a2vHY!s zPP%YvqP)^!j$qEAusTtSpku%$J=cNytCt4_g7gHjM2FFPy_ArHE=chZK8Cm44e#f>?z5ZCfI*&Cyz>=pOP&{%{I2-{o z6*+cq$`r^_m=2I-F=>fqS(pq&w?5iiy2UR7AA0kFD4y*R26P^er)cw+JOVzUdlLar zVtPv#uy6`(;mEk4kNG7~-nr#kIH}hwB=oW=ZJW)0LL@tNYKl~Y*E_d2dL-H>S_jG3 zlMj^RIYq05x3ppm$IK6mCkq$3+PvwH1;Hi@^6=3oV}h^S!m`TR?_n9~vcrEqy21?&hun~=kssB;J5?wX@ z)`0g?7&jRcR13a%g&#{K#pw)2QlJ>VpK>?tvdmf72@%sa_)Eg4utfz3=^uc3hlPnp zd4eM)=mu#z3?Vf_g&_O;!#KtDN=rM>9E^Rgyu z^&}|`%{8VGq5NkbVY0U1Dooa%jyo)B&CJ(wzsa@To)zObNXk}VTm)^Bb(Nx$XLBhA z8INa`yn}(XA7Cx^r7zCcs6V;J>47s8aDm&eqTu3=%NwvFRUezA8m9oQYRIZxYs+f} zKkwusr6-fG;o7gpjk758$@zK<049^^+$B=tmBW!=vmE4pt`s!UzuIM6FFb{?5()Im z=v)H}!B~_?u5JT$ziG?P_|Sn^16%pJ^}2GL^`NlKI54+YEVd#tq3I-`1iPKT2y8(k zd29q^gK5>><=~+CLE18irACabo@o}cQSi_DUJpP(S&7-Gi>R+2`%*s#;s^%?U4y%Z zV{z<%v41vqtR>AT7Lp|81NG{iB+8=!C_9n!qCegcjIdz-bJS`7)-8%QJUPG95GL5`|^u`#OGDna> zT4d{n-{RDp@cHruXdR)PVSD2WN(1K2Y*R%S1&DArH4fZx$c+R=Lde0>N)O{J2+K6t zbqIdqn|b>-{BUHfWgAGq15MjLnuR^5Q$ASVEUWWZEyptyebX8ITCDjU+{YH}(y;YNy&J|EyfW4% zYmAbco&GCXX8IhKCjxqF%`~b06L6~?EnoZ|!te0*$5!Uy*mk*k@*xO{_wO8XB(|OK z03Smu5Fkt|_1G0M*h{{XYGeXY))0xDQm8?w0`-SkwB#J+gLt5uIiADxHr6{!6LCOj4V&;ACktWJ5t$h0P9YQxW<4xh0^ zz?0iFMog7zl$YEQM!7rC7oaXM9f^xN+@Ss%zeF+@l*NnT0^5I*I-3QXYV^=JptYhn zFmE-cdnDNqXycj-i5~pLs zN4Uitwe41)jkWNwVt6E!)eVvm>3h3A&orHGQpf%tEcz|fHV{8BzTtU`pldZ;Hy9(( zL19_-(vQAF{p$oU4sF7pNl!7LAob8E7H`5XS)JO|hcINnQ_o%g3+FAG^XC%8p_DiP zvbaLzozV`E@gW-}QIpQ|Jy{+0t#WM#aFeFX$&`vr2*tN}p{)p5p!NRnYrClJA+HCl zNHML*4(W$fyqYFXZLJ3Jx;=j`Hf;dqyJ=$$@vkEO_-|@aX;;ZEnqzZak)34~8<6rC z?+H>cXL;Z?)~n15jD0`?4%<*7fl<#|yC~1In{(J5zvjmeX4iy3Go0}vv;3NwlXC+# zAL>%Gf;B5q^SYZ!DxivHa&v*8gQyc2F_5DPmZ2tYm@CXtiK(G8^$`-yV--YM3{J?F zDu_(Ya`oV4py=Zi$FMxcrX9%eBTP^5upTGlNpy>;*_-ti7OuZat|nM+uvsYWkWN6R z0zYK%S1C96klAe}lL~?-vIst3jt4+jC`3YVzw>t=5g2C12@{>iTibd1AGQ}4M|4cM z^B4;gWBxJcFjuZNOtplN?B(2?)KFRhYe0BJSx<@;9*AwiBDLvqZlzlRV^-r}*8;4^ zlA;EIIhF2SbW}Cdty$Q5M?omk&z~ym=ZsEj!350U*)Z+eZ5_h2xw?D=s`VNDB zd9r=Plh*UNg}V@#J7`y4bXZdhzdv)+r#2Z`8<%EQHq8LSa32OQL8&x#we&sw?00yk z?yIr^hEM^ni}p439fOaHE`b0og_{q{&y@4Kv1i+)4dFOpbHUzEln^011HwRw8Uh1FbN??dr;_^v=&Xbc$aVK0owZ z4F{TXri{f@Uqkp#`OW`EuZafDVj%F9MgYN$#F!vg{}1#j8L=!vExj0ox;fl@m|wAJ zJ5$h`HbPpfVaH)Vi>XnSXhT#htjgSzQl($iND0uSG{jygFxWfqJxx{o3Q@J{L`&74 zmk3q=NUD}*I#mT{1{LExt{j^JBMA0g0-2@Zz}kWl=rqT-GnZpQXI{JdqE7Rm7(6JE z(H1H~lFTqNPn~)dQ7MCYfsWQlbLrItGT^=Rl6LjCPIngAP`nIP_l6BFr8(z?;#23bbgE%=@BiAnmdq( zWNfPq%iZUp-|FSxp${XWz}?7OY}zJ`e<}H0LViQDB%*;mM;paB{DK_(>>Z6fY*&zj z(Z38K@=#WF^2K^9_RR!{LuYrj^R*HWIAZjK5ec!5YUXr*D|YQzwuut#DjOF?J7$T_ zP~fMK;F%&J!F*maB>2zKB*FKSH3{$?i4~<#y$xBv{~7wN7GDUG@H9Y>B#WPti0g9R zG}a9xU8BSa$nXawxfLS_4hwR*(pOG&cO&-*j@%o@p}QViM{c}b=gNgn>|mu3QT#QC zm7}i4X)b1-DAuxp^g|(tJkm6O!??gU(!5NQcJ}Y-JvFTy7)Rz15g~NgSHhe{m zJl0Tm;p73L5Bq48tctw_5`Hu6Tba8s{VY)&vJUZF7hK= z2D^!ul3?awL|M95t(H@Y#(fDIB=A{ZNreS(%S zQo*;m8UnE)Y=Xpw@-~y3U?Vy<-22Mxz_^uF5Ey5n1t~(0u^ff3@dKUiQYHx;#UQzb z55^NHHfR__*#c*Es7U^i*~p_O%yoBB(aLQvrFaO|@eyGQ+@j<`U4x(`nyg)QA=^`l@Gbh}(Zqso>aI$S#izTosmRy^ z61XJd=;0XNf|poCg6GxDlZ)Mo9x7!3uLlb}0M(FNhA`uqb0LGHP15P!Vq$`E_MAaF08GG#jKb1%~W zVrxchdrrMJLEsJH@<*OJdT%m8x5WO`^9}Mj4RS^HR7(0Ooqp{$rDKZP4?s7pCkk}9 z|BMkfJe{!aaj&-!3rrT5VTi=x=0p}m$Aqe;16*XlKbc`>(`LZJ-?9J!-)HP$9a)=R zBgS^f9SSejZnu9^cU0^sYWRy3t>4VI8MkHD(| zYg^BNjDkd`@iclbdd_bHy0Zg&`Akn=cj$z@=rx-;9|+MI`ZC|hcy@`5KeP7}{Od-` zLXCifP(8scymULcrjv5SVjI+MD#)G8-noHP!h0z)WRPT zfdA)SA^3;NtBO3rt&mstl!fvpz5-ZoZFAdx$>^+VrVHqv~nZ+x9cS!G-$htkrdiq+}E2&w?uamAuX*s2f_Nf6? zs0kt?4_=CeG^T_oBm`CP5ry&E%sM+-f%h--cS_^4S3BxHXc;zRZL@69ggS0U-TO%C zL@{k7tuU~lXe=P|Xi!X{>u+0_$H$<7gIfHfso_#Mo$6c90nH{3Xf~;xT5YOtjyYlj zAr$+lP>p>ArE}EsOLQLzPxsM;$Pn7Hq6yl@-CZ5%T?OdHkZS_`z?m5gc{(YKJdC$= zTS5c2LL}AY3v~=Aeq%=i;7n@r2E4XFVvFvafuG#L$=(lGi=9#RMwdJ4N~zN%4+6FV zC%LTiO=2<8c%zmp5oWflPcGt+$ar>~afv=+0xojS`PP=t(XkF96m+l_9bmws&WTXx zHL>}n?uqGJm@KN2uoFsGK#B5Z%9ZWHv$Ju(`>6_8KvD0ne?{tad4DwDn+9->`9b&@ z0)S^R7J;;7IAK?shRpLG8A+=hknx2axH4*NGvue&KjrpNqcS&_)qqG@*#18TsV8oj z`1z#4C^=xPkIO1IXWKs)GQ1vZ|}^YxL&){0X@UkU#R|5!kQx27@{D zf@-S;)~?|Tktq$iw!PS^UA=N)cXE+|qFmF~NJOM?y|FN2QL zEMwXMQ!D#x3k|7n7eO{wk+v>12t#FIia-IxOEg3snv3>5aE(8yQulM9KIgJaFEU{| zmy^(+uF&2~EX7>5ybAyElE^hzV$9zKyduuq44VtD@)Vzf=Gs@$Gu<1daXy2_d33^! z9w-It@M{a`G)o%WsW5Mf{srNC-W-nmS4}Xe6rdq-V0! zTk@I~tve1`mzBB}wnKm1faY=T_A2@1`=h)}%p1fx;K@~02A4HL;%*vEt>p>w9LZX2 zWQb6*y?Uu;DNn0vjk4M?yKri#6dH(dk;s26(Tg;$1CrE-+&Cqs*$48R6f)rlVW;NE z?yA!vPiT$&Q?sRvL^v7{JWT2s7Bd>FPa0!q%$7j0slLg-=C1*he=n64Y$BJD=M*cC z=VH_?=mo8wD!iRt*bN3Kv8eg7vKaPrnZvW`iDH#8(bxV zB$6h4>Mj~snvbzi%2^F2 zXPLT5UO`q+wU+m2#E>Ym&jnqq-lKKK>NRcZkvc-^njxP%TT~khcy6vHsW5|$Q>}&K z92u1f`IzE@AZ#JY@W=ZcD+pfX@vDui_e?4*Fti!zYO@(9$qG0mA`nJf1ONlOPco2C z8Nzp9nl1w;K=~kj(WFhOtf&m9RLpo5kQ-PIB$W6~)Gw$e;JXay3ee=K-n>n$NLWgMxoA722Skt@&r@qFLo$5&Io->!Zc9VzAgRKda5xk%;J%~307bo0r8U7H zs&@^C*eh|0>ce@RovGU>;;Ya!CO-9Ni7|1q8Y?4G$BOWq$XnD(D}qjUVO||spC=59 z{Al~M217?!;SzP7#Pl-DS%#dpdoog9E96|n=#8Dov3QX*j^|A6#YfZ?pOvDnmX9Ro zWYPu_v0i8d-5s|4E5y0~{Y^JyUA0Vl)BFV^;di?!(XLi>^HkkahTPdp*fyc(O89?f zegJB;MJLbhAoIKbelTPzwmZhr{14%|O&01DFNWtWV_4U9DsdWk2^>eU)Bj!OiEb_x z!Hu4}a{{l;bT4L}oBzV@f?=h&%1uIUM33w=Hoa8Q46V_UtN_m?RSRl^!f&sq;Q?_e z%{a3LRF|}7_lo?(*&#&+E)vjLcSz@&rw);$Z{`;@5Ssl+a5hfJVE>Wvsypamh z7w4jL*Jcu;`57YVUZ-|r@M0+^G7&v(SAxk;@FL?WQ81pHlbXWPlud~szKBLpkR21d z=E@xV$(&4)89+`Vf(VtsT4-5iZ))sKz1(<_w@%0yPt*qCGFr3qw6O7%XhKp_b~%R@ zt4Q+FD>kr* zVS;*p6h!zGKm8k!UzrcTisIL_5e-y>78o8^kkqpX0Xu8(ku>@0OYM=QUln8&1&tYm zeCDW|dTaU?Yx>d^?IZ#%-G@|*mEg1zt(bcK3cFnry)9>*IA6dH$ZBjJd(HEA?h)C4 zLT5m64(e%+TaQzYIxmd1Ofj!ChTrkfo(XYT(JUUq%kOw-4oSP8ef6U67U-=6>fS|~GPzn?ylDCF$bV!HFaCHaO3J?c)7j-> zojEL*$IR^2!Ax=~eG*Zeu+LvkqDLk2j%ban%XKDHC*<#QIK>=Fr*%$Fr-@=+wua{b9;ZA1gajJhqt z1|@?PnPbSoy&AQUX<{H0SRk@ztUqewbYg87H2Ef>OM`~Iz)fdREb&LNMYG${Kr77= zHwnN;#VHWQ>f{r(=@PYr{9%wbjZ8p86)aK7M=dW)|HNR+a~rT2zwhNAF*;+OG#0bx zN*zhNnGFT>jOydf+E5AfdJ?RXad`tvV;=1^3&(s&2MG%#188>g)I7f`mXAbIokE5- zb8rS-Bi$Da9stsLKZPl&cC~!G4xAF~RpSauo_t^cblZb;Q{yiq1*{zDbp#1~u(K8} zo5(>Ifa_`}`G)>B4#bGYgMSpMxpIel6h=9dXtCYmTj=tU8^{fy=-EUJ<35TJYpc_) zr}oj%qF&r0lTO+@81O1qSBv)5eo53cH#LD43;NZ;R*d+eU56jT=tgL)r;gj~Si!jI3>%6*@Zc;h<31|KEn6_c%U1%cP|x7#|G7j!*= ztK2wp`b4|b>l-t<5?UT znkiXZfYt3vutk6)gu-`5@f$g8)0q0`H)IGqAnxI|4h*7ObuC6kp-L!(P=kvHw_ixz zn*bAsKy)(E|0}O(0`Y_f9-e{@kpTtE{UY){w#dmt$|etwu|6%YN9Oe_f!i#9=izWP zYO2`(hofL$9Uci`aK9#SAAHU+rIc~=t53x!OU_*N zA~{h`y(-7r(E%@laX7XD4VeD8 zld*d6ryjAJCgSyTP%DIP5_nFA2z?i8c|RAm-eXd29#L{@0CG{gDR#1aW|*gK4@NQh zfjA0&XX51?gwgNNy5Y+PAj+U0&eRX}KH&%+sy_R|>UxpCJJfkNPHG&U=cqlg(22qZ z`rF(Je)vmNqi^os4>cGFJav)|1n%uc4E&zg@NELVrhoVcD=|HHVk?qRS-4BU z1?IO3rZctA^zx4#Y2EEi)0au`wZ>4SFohukj^+L=S{lk545lKBI8 zjJ>Kbl2{l1hS-h)FJ{6U@su{!F#)$*_{J!z@G(yEU7Xqu-fRLi{_&n#!oLikTXk1V z0xZsb20xqsxtdzetDf;g{tj0_qLXD}DO<4#q!APw&>HFH% zpGN7xKumJu3R-ByNk%MS3e}BoXsgGCpv}uj1UGWgHnJ>wF)whgqI#J2(N-Kt3IpiR z_$NdY%{@=z9gO=^`*e(tS?%#wyx}83CHlyK-Q=iu@2f~0>p6h-fVJ4t zdY_qa&U7e{fXp;?&Ht&X`AFb(ZR)tJrqs9Nbg-w*77?Z?qdZ%>RQY~~<3U#jhBC|( zO@d;m-Pf`y#>C(|_)6*mr%Z+~Z9d$SVV_qQsMn{@4VTYG*$;-$}Trg4p zCegHXlG^mJqROAVsT+eTLv&I0K`C1}Qvs|O{T6f0sjph`r=G%$3*)RyniLoc#xA`q#7Cpqep_4JC&_8QWJ>n%e) zo~%3>tMz~Ck%-;3GW91s!d~r}gcy)TcYLV?n_hm7*&3`RnubqZu)7|h$7!BgE)r?5 zaUgm<3RNN5Ui6(YG?`WzB*rQZRqdNy6}XMc)obmRpe2bUac=l1Kcw`cHL}y#0@a2% zI^WSP>1Yn}lB34v=`l3pp{Gb3`JyMVcN1v9H!4N@tYh}5)9{Y1-W-@I<#usf+` z{NY7+{U3UA+&+F!UU{88LGB13aAqOp^jA)DIC`>X<1acaiLY#6GFlda=r@i^sRqk~MFKo17VA2&ok&Sext(P=zJqM)OR zb%|rl8Ptek4zroyU7k7&Ew-zc1PNFTGukAZ-ReTW)r0|{&o~HXHom)4*}Ckn!OB&{ zPJd=!(2%pTkx?V4GGjd-VT_mWtZK}Jy4A?HH*v>GvXKSc$W^a$9VL(Gkg4uQh7*q4 z15oh|!4-}>)X|H)d4#iFTZl&{R0cyn!xDXII(@t2>FUydJ9DmXdx)X{+|m!i=8Zjv zs)RHl)wcx0M2K=^nJle^3-S1Z6!k4O)+ZPRAPjH-mPtr{H*7z4H1{h3xz-OM$cS;LqG><3A80SK}auIrCvI~-;W(@k)t`h$VK1m3xw(3B2AytuMs;Ct4eH| zizonjL{=|Q@15?W%JDuFX{RC}0ebqGN8CBOhL`_`6G#fC=s*gIIW=Jbt3;jmHiiah zrj*@I@I?(9si)-Vc@DlU*Dr7fsItz+zE!&&1;V6+Fh&Wo=rfke8m12ve-;tOAB{k} zzLopna}JaECuE?G(w>++m-_BLt)PerodP5XPO@|c!7Jh%2__g~0CP-|JY~L0eiE1M zHiA5gj{O6LIcQ zIWCyo8^>38IlAgL7~j902kf^PE=Zh(wJz6o*7oEN!V zudXMiYKqgd!6kHx+5^Zc$Lt5fmp$9n*T;uD6?u1~ID?mY39%vEcDs5iR8!4995TnV zP_puMVsBfu{eo4j2906kODOja&_yE$d`Ky*6HUNT|yiO?|@+i;tf<`Gx*8~O0Hl)=*Las2jC z^WUXZ{(2FL!hiDuUZP7p?Zj5x!$@EPZn5s%Of!Z6m4*Pagig3>rtAt-!SL_JjK|qY zSQZ}p0*=BOnJg^K46Ph{?m)uurD`y7Swzn4A|mD3+emVt7wu9Sx)I~pj} zum7gXiXj5MGBO(C|CAFTpK30GD|k$s2BBRKZJ*W z^<|4Un19F(&Oc=T=7{ZM9lhxIWPflcFi8=(6}Z{IL-@z09n4{IH+^6{w}KPVUUZiQ zaj*p)+I+i?EYLleK)X=ed>aEaFxxebpJ21OGE~QCj1#l?+SiQb;0xAYjv?G6KL3Qt z2)FQBJjHi0^0*=ASMmnJPTLE)NWw{V;;DO-15l^~x7sgEmh3y;%p zN(ke2{RUz_uGB3o)Nkag8|UdaV8FP9TezcslVF`<{RW&LSAlk60`T#}Bu)oOmRGp> z?<^yR6%KL#H}yTqGegEzp=2dWRJr+2N{O0EmXOK9WJM)P)ZlFmuJvx=ZMsA~Tf0DD zl-I`=&7f+vw)1}k%i=WMJ9Uilm?&g&mi$V#^PQW2nn0PwS8VD>*3&Ce0BbIOwYKwr zo5yzVT+Ls}S-iM~yQ4PSzfT^vufZkuzl+>NPn_@nN!^ z@7(-nmy$NK*5e0OWefl|yahH}aA|Gl|A3PtJ#N<*32v+kI7uckYN38#o2|xRKIA67 z1W<{gF2HDEZK!}gEZLA1*LU5^>Ry z^W&f-bohu{tqybPGsxRTeW#8$>MI5-W2=TA1Vi{7c7lY=RrdI>KQ$>F&%-7{RkSiNab_P>`Q^kwc%}aPmxL^AmdPCv7xpa1v*i5&q8k zI%uwpQ6%7@uM>ld??11$K=iUW009RbPn;}=PPi-OvjXM*iWIUV7?|6m-`3{VkpQu; z5G``s={CzPkrAytTxK3gsvbH=(-_7{VkdeX4(zTtPEy?XzS`NG#|1a;F^fKd4jc#1 zlD_;ohRd;*7uie_56;E|yOB}`gGqd8U{#`+ExFMXrFdO6TdLwmD!j;htISXl_~f#b zj~H(X_(WaYOJj)m{J+lvzK~WY9sRV_nZ6gEb5%AVd%mZWbAixMA}Wi5rl1-4%3P*t-B65bnyM zcbTLGjRW~P^iH-85a~7QVD=<|K4sy5mW~fA7$cN3MkpW9A<2?bzF4)C9CGkAZ!drO zY-AL1a08~p@v*TJav)1n_d;O^WhL=|>=Q)OiVE%n%(wCVW!$K1rrVC97Mz{P zpo#mSRcA0xE&Tfq%wHl=+((wSPG#Ib6{DW4FOEGk*7|ZYBu(J6Vj!LbgG1wPkTTT8R$SjSXAQ>MP>9jpseKVTfCvP24f3 z+UeQIXG;+JGUjR|JU99Qe|!0l&Jvl3wVW%DG5)GM1M!6YzU0(X+{lopwf;i5CdEPO z{jvEi4gs0@I=e)%0ml)9_y!G3*W!DFgmXv=rPn}nR+LkxjOI}IG6L1V<$n;U3v-M> zz1$Y)a~FZS6f5-gRR4Aas`@EkpvGqe%8RUc1{9HRJB~&PbaXeqEytr$Il{~rCH<5V zbMI}M!*B`^sMH!UXd#)pUP@5f?y?`g_!CQc(KFFp>Ke+}m_Cp(I({t$A^o0mN>=Rb zMgDt$aSRk`a4kpeyNbCZ%olqF0KHU$3_GdH^hTm0w=ZrTyCoeEtfZ)ZV zz4oP0cO$z==4zZ)eM()Rmz`*v@?@21hpif1@&1Dgew zLbtfP~cvGTI7~T{5ZtQe|Udf?Lfn1w46&RY& zB@X^d^Ep}Tw$;A-0QC`YJtCkX`H4+?TH_BdSB;S=Y#`bv{(|D@JS{X>ZZmjIElywJ z>n0w&=H;I;EsjR9JmQB|!y`Ak=IgJRZ~Mj$hWa;U zB6w5G24V8}AN%G-OAiW4kx&oJQNMj(C&joQJce;~2|B<^O_%}UPcXv%R4?oe#kn=R zJ^y^Y%7DFRn=WiF^bg(^-{wM83M!8mUkk!Rmri+In}A}@X!Mul5K1R7{%zd$&pijn zV6|!d?T5HHkApJL`dLE$Gad8?;8-|E&?^K*0DNC+41tk9B5!R-;SqADF#2Qx+Us+FUAQ8PVm`4L(Vj(c;CqpR6 zVvKOz$$`3i(P-(>JEVDV?5oaHE$MH2q4p}_@(#5>$efz(`^ql#-lXY$JqL-68{4Jd z^L6SG^lp_tQbKIbQ5&dwt4uX=UIv2JtFX$K!iqO~jti+)ebg=HyE2cO|I4rm@=!s# zBq-1Tu?LgKc{t;#f$j0*3Y^&|b>sowyW=56FntNxtwouF!4v+M6B@Lf&FAyiDy|^|Jmw~Qd__PqVpZdB>h|LVRS@Q0<#g(3@usGLL#)h9-IeJs zXbI8aO`f-axH%%5D)Dr{MV1iDN<@RXZglSjG~BV4hlyBn2a*n&J*>cu{P-xttm_4`TeocH-a5;z z)Tt-}G@m-~0I*~!HBa_7sr{su`eb*A>Up7|XIJ|Zo7P9?GwP}0HMC(h7?MF}8vu{8 z0D4JA!K^?Xye8&7OCd0uQD9Ax6RU-^NMcA57y2^*^n!UjhhZKdacx^c8Ne=(A5dg< z;VC~zZ;Jg%Icv#P^1WTr06jRWRg(V@S4s#Nj^f+`!(Dk?A4;k2Agb;pyb(NV19pZR z##Zw+uouKS3sq+o!s-(#1f(R71pk(&PU%u;mMNrqe?($uYNIW?#_2`YbhRQd0>_2~q+Turnn%((dD|r+JaH1kic=8YeEey7E zu@u=JlYWpjXCgx-6a$B~OBq9ylfUB-cpUZ<95GOHsZ>SLLj(-Nz6$&UX4v#K{T2+qRDDd2Qq>GjFPCv zLpjN74HyX~5nyIUu2gUbN(s3E9Y9<1!i#*f9~lhP@irGW3&au|PiS~l05Os7$9bdv z**CmLTv)t|8~ySj3GgvlKP)%h1Vw~s_J*PWraE1AO`~M$VupSL+0FfNr@QI@ACmvr zG}&Mm&fiH4$Y4}<(U+IQU^(vB&fv{4uUQa}mdcXE-bL=q!fP=o>d&<0})e4_)V`8sw(e6t0;lg&U9xG>I< z<;z-2fzqS`nxt}k?IKQxP=z?8n3y;x#}-8gJuoz9MDvTayYokX{Ug@$4*VL8IN8dz z(&V$A(S(^-InVdTR18FbE8F`?(Pr5;K=UmjUlYC-<-HGi8PLHp`M9G5R>l^=;g&Xa^ zEQtw7yo9ttUO2Ugua|g3l z5T8`Z-Uw%=F3;@--9A3L;l`nt|GAE7G3X_Ymg89pfG28LGX}q}U>DJgQf6SlA+dBp z8UBl_K9d7tU&0p&ZB(f?kn#dIf3QY%FD}C@bB9B&);YLBsJ5Q>#t(w8MbzIm9r=YPfcL)Mr{V8zclbJeAS zS!w_w5X0?7K7Yts-AtAwFcjJq(>vs#@Et6)@;4khpcfXwR^1ft#)FNlLmaLo1&Ac= zBBT(~7MZ#iZ6#RXTSoQS5oRH6>RYoUTr>${Cz=Ih#aG#6j2Ed3Agx~kKH+I^G2!Iy zk-q7EL3(Ez*wpW3ZZ2qJzihC0kH-|BP7a8|dz_;l6FIun=1=)3yDo3Rk=rFv7 zQdUVWK=;I~!K9^5!vvzL>Ioyd97m+VYy86cgtGw?rnCW&=`!nSAL?}&rR^rHJG6EZ zv{z1Zi0cFI!R4ENt+}kbxhql2dHZV-rE;VTfNuq!$xWrb(ZK;;)yNYsy4yH2ZwR{S z2q{Fj=Z9v~4VuQ-0S>v;g*1+gm&d-{*gWNxi=lcro1%SF+<3vpyM?rkZgE|1*X z0ydqe4#iqIHe=T0yu2eq?T5OFXHa9c_V2B9lZ_h}v%kst#);W$*Ar8Dq798E9bx^^=K{Nn4q8U%aerY>-`ktYkeV}qZxzQl?B7g6-ovxw~Sy1;V zy2`We)FVBh3KRSRXeJ)zeugp7hhpkOoVpv=y1P?R>`9RMA~F`V8Hj6dHM3EV`b2a@ zK1+>gvR)HXYjxgM1%2?GK~uSLSt+?6PN%$1c(E3oASZFul?NL<^is2TK(7~O?*Se1c`87D!$ZAn*##}eeg90nl1JWZ_26W z?EuGO75p)aKadjKY&9GUE68{+-qJ$0jtiiBdBpP0H!U8J1jRcqks2JA@u0Vs%Hw9nipRf!8e1S_wh7oP`RA zq*zk4LrPVj`4hs80L=EdROvGdEGBn>Iqct7&ccUx4S8KF_N(FMxFo@1Qj%gpX5g8wdrD zi`BE=Qz#@mBLN$gRF5?6;LK+H>?RMhYai6si<8ui+ko?#=%H{m#Lp>|PZ))2$RKdV ze^=&W{y4dTk2dkqCbbkpF|H6%_dWEZNJM4ooq$2lY&v5082BT=c@*hr(9L z(qN2oFCs_?d8=?r+5vnw|3oQe76jKFh5};!&_E5_td}+eLqRHqX^5^s5WMC}ZSpG8 ztDGd&S6ZStR{C$+%81vg(6~{JTMq-_VmB{kTA&4I4Xlw>{_55(VEeh5frQcN5dUM- z?jRAuF*+a@i!LWMf+6MGNjZ_P79g!HwHvkgsrH!FJ?aULI!Qs zBvZA|ZDJL4R`cU46SP>K3nx2bS*nRL&F_<{38qL8#i_UU5i<-9X z7;EOo&vCa?tc3%5(2=E5I zy@ccPfskNMsUe~PLm(*0*ZRLf@~XGL(F-mrsF*{w*10*{)746Bn|ru&^=1H@hVS2n zg)15S<{vL4aRCW)+;4rK0Z{im0l02NJ0~r+{B>C)Cx(`?yATUsK9B=dRGDq!lbaqI>W@tL3 z*(~s&a-?n#L*b-+vLp3d(D@?JrPMwyLj(x;THbI|&W7L;&wErK&FFYE{*+)A(`dX| zqS26mD^46ijWYTh8D0_h$i){iAfmjoTD}04a`ZTOBqJZ*6oc+Ls$uqzov9Tt85XbB zf8ep4{-RF)2GV?eRaRuhI8CwI+x9JLPEDP9Rc^*aOZIRt0_a4*|il zVZv2gFV$;b%-rF&ub|9}jX4X`58u7bf+x`-cQ2%4oIHT#UO4mZL)5NE!ZVgZ?!HesOSj?ZwwIlyTTgQOzvQ@}sW)&JC;3n3lC?Q6%|71g z|0dj8ZjW~vzG0aepH2NW>`SbNcVo`6zgwZhbe9p)6e#gE=sbi+Q$aS^4JpELRfrdK z{MEAdx+rURqBcOKJFv4Z`9}IFbr}0}tly`s{)~pAqd#Ce{S;)jJhq53%kjKc#!{qv zE4n+*N7K_$v-cCKBZk5n1?t_QSym6ZNp&|%p(ze{TQQy6#-3c~axNQ=R2*#z{vVpbmoKYn@_)XoQ5`R)f0m7s72bun>BfkW( z?+gZ6A$m)E9Ve|#{xdKZDArv9Ef7c2=zLYIM`CvT_XV^sIQ~PI*K2=&0=zf!opaeY z`1@JB!r$|1<}<5!UV42DpB{f)^IrU?wtZ|4gorU1XSo$x2iXxZgASXS?4jmZ;If4bs;04$^8y6!^aV`b?Tb z@CiWcX`tB-+w87Qm>AMRXDE=q}CC@6n$+Q{ZN&I$|Sp8>;7j zAh-9@n}_9fd-3QY3$$#Sc=Wi9kj?CPRMx+Yr)X~1|HGznvH@JFcaq>d5?c+#9URJ4 zN55lZb4@+ryh-0QZS56nenM>5*4<*wRr+rC+H)wxATk96Vx;3H+*AOn=zXQ!;QYr2 zG9i4i);#DFYC`j9OoSl?s_zFu$L}PK`+&6GJd6})j+2tiY_b}PC2KTnaT>PeY!Do` zh7GG0MFw;SWO*+5_QmODr`e$2Xz>9=J~)c{8;QYpHw)Pj!K? z3&nP23i66E(f=y1D|aO#)lk?bu4kT(>fOofcGp9%L{Jc@f6D*0{%1|0`n@vse_?*L zg**?%8zOIbD&icsH^p+}MG9^16jT>!#^}qK%sjQ}KI7%I8O6{`z8_SMr6C-v+fafW zb9^?dYmVsbO#f4TtU&T}{W!vgfnj@52V7CL8f_z%Na*-iPXt2|^a7d^oZ1>^C=bPl zpf1zL?_b*JwAexurXJOk8-N>^5@g4_+p}L2 z?$LT}<^} zGifc@(;}I))#J6Al#?&w*%IWkZ?vj}xd2nahAK&dDhyc$d})U)X6}rnA-knmp4vQ9 zcd`aVs$Z@SB#{cU85ri@spu={AIK-ea_G4oFbEdfEBsteVdJnKDCXfa$HI~VVis4= zEz{v(F`6t{uJ->7biK=pO4sqil&Rgw3wluuTQ=F{kel9(EF0Y!{V<*5&E)f6#e)9@)Ma#@%nA$r87$Ic!RO8({i-`wMMPN7w?S7052XC%D0BZ;V3(_KVr9DF+SOI|6Mg(5wum3X#pM&1u z1$GD(IjmfJsXwf&Tc!;WFocmp!|8h*kK2%KPd+=_cu01lICUQQ!5ToYqZYH0=rq{R zJxmo?lI5cSOGfdf;^fMWT{2Og{)hVdBQTZ@Hl!|D@z{9q7ZSsn6WCWs+OS+SvOj`> z=*NoUWhnre$4*n|i%Pdc=Fwt_ZMsx9&FW2@HogW8r)Sw#L-G`xHcIoioNYR66XuEI zXyKnW>G0vx|ol6N&Er30kPG1@SLF;#uFe>!koFR7V+5jlZV?;{@36M2D% zRb|)5{_%jJNbq$a{9g4Z+6iEhx`v#UG}PHdf@aS>ArGA_b0a-?K}E>VRLIXQRqO*- z_oJprHz>ncjO0jt&#)!-Z}51#`)`_yX*nFFIeZzx2%2FaUrJ18|nV z&fLlR$y*kK>S96Gzo#vT;TKVb2-1W?UWPwKXUcFd_0a~L&Kzs`4cpYX;|--*sO%=K zi<6jIdnLHD%C3W^oe})W?qScaX{4wVADV8NVO_Ero*RsZ1=MCKAxMZbK{;SnMxj8= zq7L{L`$u#Ow5z_q z1josO^W)cD;pE`_uP=TEA2n+mH^Q{51>KZVKYRe0_|8wHhV*Z{@#x$2+CrQ7jr#kC_+#GfPH{W!s59b2FE(`JBhW-+#5UPsHr~z z^7lLT&QZ(8prL>L3C~u?@N@aj+d9>`ZJ&3lr_RLBqFeA^>|Pv3;zcgFnu7?46QylG z2$7m{8dI!PO^7huP2{$_PQq~qk6y#1V65d$2(golw&EeG_n)E1_iDkZwCXa^yrifS zBiH6$$VA`xCKbhx+7?19ze*r->=EgQHV3|`eXe)Lo3KlCyidtyQ%(eULy>MX(55~P z{9b=QK%_&7&74!SIQyP(_ALk~IeXOv;p}UgvsXSCsD1#epOamEiB!McRPU>+KdP&r zeN~{k$W`C$>UT-?iKhAsXG-hsy1G*xsE%*xVSQm)7KguJ^=JXBLqMvfdgR}_`dYIK zU!+YxrbEl(?!ZP^-As`>@gv^Md<(iK5Om0*WTxx znJN6<-|zqbdp~by&t7Xi>$yMAy6)TYgZb|(6hr7J2^}t6LvWbn*LSoWk#m{$d(c zH}*(FI&?HC9Z(NQX*MLz%8iD-yULs~=~O6lNPtk8XGyt9-4Smjr>^F;B-CY0#0+O3 zY~vIQ<^WX{S`hCrbKMsP8+SX&weABL(!wi)rd?k*S313na+gA>V z(J$AUPcS&wVK=FTjPB2Ak;H;)FH_F&#Z$x?F27!!;ZbykH_ijT@NpwJ8;|?BDzx6l zf_I{pFSQnUgRw^(V0JFar%tbDkP+eed&|n$> z%-8pOh&sRpv#PQVqWWksbVv_-!F)K?;mwq~z@%v~)VTp(Ftc4SUFrh!%*%>5bSZz_ z=OOA87t9aS>L6;227{b6FwYC7kqhRLy1=y6V4$6WyS-ql${pUEUl*87D-==mEm>YL zS2|z<`wAFs3Q#|0>@WqTel&$U0R|8n_BB$ey_f>cI@Xs;{eWyU7JOrr&R9+oBluF~ z+Ob28=8|iluA4gpgif=VHQm7GNF$Gz=D~yU61}%I6FJEP_wqOYiMzvx0&O~0 zO$$77QBO8{XSNnqExsdtvEw^#xkRyT-3h|B3o4}N8TA12{2~WPKMiE80@6|eIjO8} zOs;T&G|@nE6p$c*xLH|4NjZPLmJk_ba=x8Pqi}~9SAUS)F%Oh6jL$JQl$6t&VMr%T z>2&VtlTP#|N@vVSr5oo&MYvt@5{&M7o6%f`7{5h)&G(k(N9g8Rs(BOD{F{k&b7#=g z4vW9NSjp+ZJ|d^D$^{3jJ6930LjT<{YFZMu8=SM8h{*zCKB!t5$>tV{JI~~-dT=07 z3eMHgdMaoqD3lr}*jm1($QhV^h3qvJJV!UTju&L!XG$9nj6B?62$u(}YW*Edr};E# z-bOdSQ8m9xHIMW$nv1qSq?*nRE`M0Y1_a__8Td?P`=brR*AG8CJpvhHV}sbI!{qw%&f zknovGj+n|xS;n{2k0E(`_{j?jclr=B$R<}X3#KXVGByWs9{BeqM)Ou|KEvNUB+XZkP`wXV%`;T+#zB0^Ecm!ggF+tUN;Y_ z=IfY6BWWoynzv;0rvB#tmfla&%@_6(~w$gJfZyt-Tc9xf_w`_d&iTE=Azbn z`I{dn%}>?Mi&XPM)%@H)jOK+z{@t!V+Q&)rY~B2qi1dD;YX0zxMsvC{>sEjBM$-K4 z;fnUVRP*1MX8R|~oOxzzU6nd)jHTINpOf@jBNC7-tMWT_^3QQN#R7he27jOef0Dv( z^F%#)c)9FI)su(C8G7)($*+wP<7E!3Iy7k|*U|d@LP?)C%{%vNja1pE%J0q2)74*++ zweMQo$yoT{;aOSu*mJGNcMZq+729{o0b85+#voq&Dj%$_n;qX3(Y^Lpz5aTo^x9=? z-KYznYd4j)OM)B* zk&Q6w!TPd>zw&5O9{f#7etSK9!od$Z?0bHwV&4S2RERi~y)c)Q z9ZaOaxg~IkplktN8c037A&j>+QUOX}-pHg#ZPZ9v@{5ll^B415LtUg)6%SH_{74lF zQZvt1NbRPOYU@R6&qSp5Opeqljno>A)CPsrFas%7#e>v}KYW~e3cCw%|KnK-sli7I zr{-~cg)6?9pO~DI-IEiYD=a+XTcD9zqLHdnNWFQs%PCdGgH#7UQilmrBQ#PEcM_!b z_agQ4#|cP%bx~6B-KvqAtC5h95 z8WSn>lV+Wk9I43~sc9Oi849WU&T=`Ws(6qJ_>syJq>j-@ove^*;YDh{wI)(b0j(D< zRGh-LBW-uywsSkehA=OflYOay`4v`p01-(dR zc&tyN?ad>Sa;i`x712mV6;fZwyod5rs)`4xvx4UytNS zZO}+<)JR$UjR$TThEC*@R? zMrxHtYK=nb_hJ_*RmFqUS$?E`zl})Ua)#p6JM9Ij@9@$P--jMfK_Y2ZPI9E?Yor!v zq?Rb8E-;W%RXj+o`q?MGD+H-@jnqL3sf)ZwtzTtw3jN@`>Ul{yHA5qHt43P1ZLKnE%0Sw$+=U=IQ|cXF>f0#1~D zJ3*m!=38X8z3E#(G&4a&91w*Lh=@?s`r&7JW*L`)pO$Y=PGcpqkcIFd*k8vR!kLKU z2umy&)RcU1D9fiSJTQxm8ilAKwiLlbek}OefS$0zBKd@8rLHc0;)o3Hx8!X1!mdnj z@m0@PB9Rv0A6|WU9HkyS?q3jQ&fNgP549b_=9Pg$ymW~UT=_;AZ*Bey(fgij3o`}Z z3KY>l@6Q=|5PjCc2GRK`h|VP%aGuv-Qj|ms5D*;?PR$SkaE2=q)?Y!tqn8jc>lPC5 zaeqZX9$QuhuER@%fN+gT!0uF_v(Bl5fUqLqNSlB;2N?w9rXb)9q5%RXV0w-O2oNEl zft(P+X*m$U*?iFSeorCbbIfSPa$0Kw_G8P+zQ`di< znyDXQs+pR1!hwJerV66TnffHE+D!d1PgNJB6jLh(B`|e?($qm*oXxqMJ;7JZX4A?* zUoOr%90^Q+C5*SWuMnngJ*y6;ZuBy>qk!-*^>GtKGNx`&OzrcuX6m>4U<_tCaN9*~ zOr3&V|EV-}+Np}ER{?B#gWoh+5vyKzoBMTEKCx0{&k8X_#mPIEfOH& zzb==-tny#GDFRw{7XpTH2{q>|wgdsM?JopyUDY69^=n~6D};a#&#Z%hC5nKB`)C68 zF$q|Zf`IiWD+2Z>8X!P`2mw!iL=-#(4C*EXJc;d^v79+<2?ADzg@F6Hhtrk7PoBg* zixSwUE&}E&0)A+z2^btUBrrDx0Xdq0Rzw2?2oNFQw+|BtxV5VgkS+v#&{q+#bUz{B zN3J!x1RSuGt!=xM)OGOSIwWwbBH(bFfZO&n2$+$AfB{4Uj;ICE009C-2zdBYmw?9L zAiVXvU4(!lE|%uB)C4?_g$_8DW4#3Y^a5Mk1R(aLS+@LBQk` z1l)X*BA_YJ009C-2pIkWQShkHUW$ObxtN_Zh%KQ)2$v*aCKt0^2^{gGNq|f-ZYZvU zfbqo90nz$~9|*$si~?e|2_ljthL2V}Xum*v#{aZ7crZfXgO}(gA%O{q) zc?i2?k{}8uB}q?@MOE7~_S4k`DdidOmZ>|Hnrf}+snmKf7jknl*%O$$70b0?>d9Ql zbvP2(Z7DfoYlVcHvNP&nYKh{=nJu(dENf+Oq?mJC}Y-unxzc!}+{$6UPHXx~Vs8B94RS-?i z)D6eGOkIX?9;*vdimBt2|1z1n{%B$9epscA<=lqm)YM^YS{Z1{rCV217kM18m|E_D zI+z;vGIhsuCQ}8(JN*q1$(Wj}n0m>>nyJlkYYrE{C9}(}jj0c8NX^v8j#ErM4P!BK zNf1rW)G}1HHT4fHgR#0GrI`AYN{oc599hErryM0reV-c-a(c5TF!e4rtqi=ujR!7M zFL^19x3;Fr(0ci421k-jNo0AMdZ>V~&0j!F)*!+JElkB+29~VYP_1L}IA*+c?n9cX zFSRh3x{Xx4LhDar{-?d0nyG_&E2hS=VT@c7L={sbh?`+MI$+M?FjTdfTBxfFdWxyn zZ4HAhDk$jTe!C-usk6CDAm_Vd6;t19hMp<|)3{5(WopqIY;7}DlC@F&6jQ;6a`hcM z`1mka9l>E)*&Bc<7zae_pCnJ|b@&eZpMxlFxWR~JMTQ>VNeMoUkmefJ1qY7v)N zb8bg-YHD*fMgGNYs}4s3Uo2v4o2imO?p@&rZ(6Uq=Kn}d~&9iqpGc`k7cXsf~aEZQ8F;_F!kEQ zg{ix9*Fw&5>(2D21X z^C5K!LO>1)$mzhA(2D77SsBRk67bGal5cB8 zBlK=P*4H55R*g^C@4w=$E1GBmzS+|tU`7f8<{zW@_!-oOA`rkrz->ME2MUS+zjVPoko2V^n;OPJe_(xc)%Yn-tfa@{F7~!KOx@1pSmfE zZ)P+2lgYpv4DZb;J%uyQ351z>FMU?rmnJM@3p?p=B6SPo12@~ zyq|n?(} zvVlIE-n#)dKl1!hYu=vXXJy93$ARM3-eF;ob!E^{`Vqctr|gxD#`?f}uj@Dx55`8J z$I564P+N8WK6u2<#T`sYEZKwihKYgXP0+XD?=E#Fav*?PnC;u}*BG7LWp}b9?U4h1 z=d2?sD3-e{dq!e`2RkDQA^SrIgR^K0qftjbL>st4ig;g2e9#CMb(f-kplS-euckJZhGsOFd8C6NDUq|qFc=V{jOyZdOrLz*9{n>SF+Z&1yPFE^SWz~(Rbn?EAW ze?Cgl{t&bb$ltA+x9Dv&$K+$0b+y0wM}vs`V%@x-YQ6?9f&6DnjOHS^9{%QUO7ro$ z`8EzDD}zf_^V1qLWaHG;m3sRozPpEvK_j@xExI`&M<@ZUuPfsH_A2}u~gW?APVQ>wwOKY{P54UAOs`Xs!r z9>r^$;(;?f4LY(Uq)OU*N?NdF5pHOL1p7-#6MbdbA4q7b&yteB>NCuKK4-~KxVH!W zT;nNO&5}8)Ep9mfWODzVeiu!;(T(@`9(N4@*A5 zr~H81I!{S^mQ<*cX9k+|G-FA7Rq~Rjo!cRpL2oN{Oxw<3t7Ha>5w;g9}5AatI?|!{GR+x*@B?b0&IVG*mD;5XRuG zE({6xLdYgbL(22!5=J_!#Dn<)!)C!U)WGhD>OtSLJ+N~IyTsu>-F^Yuv(_J5++M2i zPO92#Qzv?E^-^~40e{X%`_GdZ$tzacw5w%hGce&J3{cUk--Q}y*nzcaRQ7Bbvesd~TDX9V{dMs4x0~wkNeG{kIqqw>KQ#eN zNSk(7^l>VhwW_P#{=yDcFZycT%vzvtj7i^ZtP~IS()~@g-2T)oKKmQ1A#pu{{pCq5 zMPH%Q-zmOYZ+<2Hb@23ei0W_ceu}>5zI6MGI*>9oq=@cssMJ#Z6*;v&ZmhUq*Fq*B z^j&7s_Y5n=gP*m6G5xxUohdLS4w!#wFvWONJ(pGDIcIuclqwkeYMj6S+{Jmc1ExrW z8G$$C(QK)uIvelQI@DLI2W#P6%4iekfa>os;@sgg7w2gXn9n8afg{43>h+%rjO#ow zma;}X`1L-3aVRTjx^H!0+^u2EAdI&+3XCH>FeWJ&^9bWWR?sl!J21}FFy<1*>z@dW zPcAiS>8xO!OBi8R&@h%bFj{CB3kc(tj|E1|1LLPGp=Dpf*oPG~j8zVdb*uq{uOf_P z9|?@3Juse7Fb20)de@9~v|rrdfSInrtic<~aPfz3XB(Yb!+o{RVXb)1;!!5uJym~S zLxzNO$_H+LTO3HOG$c#+xAlFuzim#fpBpLS>{@eJE1q+-r@yyZDIT1l`>TA%>2L8RCVl6q{;uB}GI`})7j3oskYIXfFx8yvG{x;I-6^7v3QZ73?Bt zp~Bc=4THO0t4pMcqB!bQnPpZ9vPwL7>qwGo$I~&WQGMWlq-2z*q?je+)=5ckPsuSX zd1bAXwDgqZu_RZOY`NI%r!h+|d|TSA^ptD~pyb&#QZmO=vYsWoOG#jilz=|T6P{J($=ui3CNS4i(uF18 zza}N)JSAb4^im~#JtYlUa`UUwrj4g$b0$hQt(KB)7ZNucgS9LG1-EG)3^G`9nkxDD1hb9R042Y!kT#n1nfxB~MgIn_N$uS6NalC4qwk16xBDuw>OsY!evbk-{x3IaQU6 z@svzt$n^8#&-r(`8du2UsrJSC5?}Wh{AQi9kEXL(hDc^p=u9rU!!?Sn|bUq33<+$JU*(ESWAP!EN14+y=8`!y@Tt zo~I-LrgVZNG z@RjR9s$_c~B4wldGE34_$)}z+53}Tfg@SG$X=5|&CYGF{N&+5quV6`sC#1~>T}|T8 zVoBB`QnK1pa;!jmSg^jr<8%*U$#)M)n^KQ3LoAshC4tvG^!$V~!`1n!bM!Jw_+X7eDtm zFnGGRDTN*^X^9f+z^S-pdgJ{&c6jcW4po$MDC)aYp0}4vdMjsckORr#@NDYCw-=}- z7nutzh{pS2nZ%xVXqu_YWPOKaVW&(0WD&rl4ge@xgcrK&Tj`{_F3(_uq#q z<|urD;7Htgi~H#FqcQ!FotS(Jw`H{Rd!?n(7&ns)&f*{E;Sb=1Zw$sp1Mdm=;M{v- z59+wOeD&B?C<>z}j8~yqOQ-ea2`IuW!`CZ1uCDo3WnW{t*n+RLse9fZYRr4yxels& zMz=Ljq4MMS|HIbvWuT*vONWQw^1bGK;vOdM0>Q^?>$x49WQNFLqswApquAx};kF!n zZ0wHiQ-7~{+?9}ZBJap6VICM3JDgu-0f!D04($_K6wMAT8k}92ib1^0pE{yGq<}Be zS)J$8X?Pj5(7N|pFoyH8_Lm0KuZKUOiuaU!qvTP9Jc5o43iG=U_`2OhtY~)bT8c%w z1IT;%+Jby7peV|37)F4Ewj&l}!Alk!_16P(tvxG$6V8I|eW^G6b{IbHP{?{CNW^GP zRAQoTPTpjq0ZmXJ3W0Bo-a_99@5Y;0umHpLgYRzQJKJAkVS_Js%u+AIteMZ6*52p9 z3Qq^+*4RSNyE#$=b&En9#NZ&Qb zL|PUHgVUz#L8|EOaIukeEe@RCG; z5}~VzPho4@(%&Qs zV9)mvJ^EN;%A*AG2$jD^j)001>Lf@i6vc$Hjfi$$7Am`+#Y;cSgy!vu@*xyiCwwDl zEH!;1RIu|ap|Z(R>8ngS9O!6fXMEndGiqn<84J|x!}Xuiqw(bl0_fB^7TBO(g#Zq< zz#m-4E?;9*jbNbICuJRuL((;$Vygt3W#;kA6$`dazeNo!zHi+|+zs}lVqcq;BuV#_J&gGl^fD!@Awc^5;%Wqqm#yn2fj47B0X_ORZbbd~A#Ub0SZoS@ zxJ+yBRPr$<6DZVN`}*sIkVS8bPYA?XB78P8VyTLexeSfJXgBV`H&pR&YVOYXufy13 zB(x}P8dg#-{Z@HsbWdLZ6r(huB9G0#Fe6bNUtMOZBTtCH{q6oQ^-`%Lb=11yOxQr& zYB3S~?zQXu77zIuRNKREn5))5m)|cqm3;i3b(P|`hkxU)sGq#0|1on_Zq84dbR;4L zu_)XMwm8QIXF_m$BL_kXWM?*p6+nF7N&~5lzcyL{pi?~>9P!{2s`yOF6OMQ!WPx}b z_4q%0=10e4M7t8yO(W^&$pbKw&wCGMS8&@zPJBi;$~3}?1$K*0b_-z1k6)t#%#h#O zCS80dU)?TY0rEMbQO3^z#RHGuKp}gbQ~K*l@M<8##1$3K@dRekhRK8AoX!T(R>KJ( zKb;EUqyJ$x-Wh#{yBCiG6^=k5R6dev{j^zWHUgY%eoCs@pT`qvIr6n6v~*0QWnnQi zyUgl-B?u`L%}$zM&D~jg+6z6gG_cqTe_Rjq+&2jkn-`iyVDBUaGSU;0MIhgu0U~a& z#*YUP$0{ORdHB9;W@Lr=rWPjZRKCg%A&tIyO?1$5zr;n~nMNW-G$_|1<11(^|8kXa zB%)2(im>s~#+}BmSo(wV53xH2etq-W5i#^mzh`fhMy1r)LFLg5MA5j=YzWQ5kDdQ} zh(rAT#o!`7lk4WzusNRwAMv$cgONDXj@{r|H4Z-QhFbFbaf5fFf3bN`iB2-Dr>p(F zi!T^q^xliT&!E_{@P%HmC9Ar}cfa|D8(#aa$9T+j?)Rr~<2O*MFCENFfp zS$;6C*G|Bnd7F-J$oft2g9(1V%~B6PLly7Sn0?(d8Yh zYQDw)zlOJKG>tA0oCGX;0NL$rzO$3)rbHcgvx@)3u!lACh0_~OL!27GICb{r5ZrEt zd-v*dsNx<)KV&tMIWhmKef-#g^hZLA(}n{%>zIk#MW(R*)CpL(>k>&h;~A3_oq%1R zNJYMLk)hx|A_jFtTC=}%X@P%gnB}s92r;<-en*#$U-wiDW z!AN*Ri(3vy=9GV4`^jti?6H)+h3lV$o9J*HQBBM zYqROsgqbcBa~==)b6U^MPTIKm+xX$bHrZ*_w<%0iL~-#k{U#=o-P|Y(aU!E^V`jHZ zx(m%e)9S7eKAfIOg!{Q4o6P2^0A zGLXY~vUlEqWErcAAM>Mx`5+^f`}0+oXZE0L@+WngRB$AeI(2^b7xLu>37tbN`SosB zBWGNkXwSC&*eUG9O zm7U5$d{|;Jmw5K`mjRYN<<`I{gJ>}dwg)5DLl+_Fl-fbZ#UJ>DDl*jkD*EQK3vhyR zNpojSqGdFO9A*M6@YhiJ1JFUPON7dA!4qcUK!Uxn!=71t;kMsTlts9Y$*` z@Vu66lCBdBhi6DJ&zep0bFGOtCN5scBwe(UD;@4q5G$XWr1F%GtKF{#lcVeb!1;;b z{Sxa}cK~OsiVMM`Pccnu_z&UFB9gf?`D}!r8!jqu7_Iz@Jl#T`Zn2uoQRj}V_P_rr z9uq8;)jd6U6s=S_D^k!iCozHW=BmMG`OeN&^_Z`GVn9Q$#Lx9^3Lkwl=)cp>G{BJ zqz5}6|3Vcjl)WbUvn(6XG*x*oS(Zk@X#9Tyyw|UW_X-OS#e0nhFW*e&y%HVL zi`S?0UUYR{Z*)_V%C`5iemoDv?&l*mAzw>~&&lnVsh{;^AD=u7p0EGhmWPk$mjI2_ z_8Y3WD+RxGOp7R*F_O*}9FD1Ub+*`!G+=cR^mYivb2p8NV6ogoP3<#=@cB z^|jZ;0fV2Pmk5SusQ7c%L&Lzy<7`fP^|_w>6H^{@ypMkfDt7R_C6&&$N9VQiuObEi z)Cv$7B5PhljWwWB#MZ?96iF7qn1#9FlHqT3wU=8kh#HBl;L}p;+H=9Dvur-u@q)~R zc}VQZs{VGdHyhIHRZjV+XZ__KeupaFQ1n7CM#4=YHo{jKIc3z$^P^l}KZ6KFr30o( z+;spI1x7N=kQHktb&@-zy`b_<=#aC)0F_6ubhO%AfXGycsi6p$E`BUc46|2!Yld0e z^28~j$iK}n8^lZN_s06w^4z=svN@PP!zYi})4Q1xf) zXAtURwxrds2Y#sH86~em_5nX#_k7l|lo9k63Zn>$DuT{ip=1L?7oiQn1RKO6(kxcv zMUd-kEGQnED4QQQCy~w7*PF7zG5$2`kRFf?6JG1_p^(j?j%*V67pj=Mv-FwkF$-Q+ zG>JAs3{+I1$)x0l%M&R%$+M``oH*bRqo|`j@faW_LywX580&11k+2?=v;Lk86W}p5(ukfqC{vNOO7i+iKv0{woBiZos7(!%Hv|t%RnRT71%+TYc zf}ed^qTm}nuC&#&GFl-T;t~AtZct$+sMh8opzUB+g?;p`QS?Q~|9bgTSq;VnLaYe1 zaT5jT!z}0k(kCM^4l!WDVwf;i8K3|+YkAW@WaN@h1BSe1TNiICFkR}uM<>$U?6D*? z54=&mR3jJM1(Ifs=?a=Zpt)HRdDeHlB2&-HU_8WMJPvbAQ{UfBq3@H>b!vT= z@q2B$ZpUV7IR3Aa$|SKlF&Qk!9;oD-Q@$PyZloH&KfSa1-NVptt=xuUA5$O2etuM< zkiVE~3R$l|JSy7YQS5kU2>D7Xb~BQ7n5)=24Egl?FRlMW;A$!=%bKbQgKlHuAce(# zen}!>ZPuBD?L~IS1OK^Hy;RyOu6ki1Ts7AJ2Z5?u*8l%5dS=&$o@Pnt>DH8&1laQk zxGb0SWG2$H>1d(nlH&gvdhV|eJ;#nD+mTinYj}@tQld~ERVQqnL_{>k)9*JHtFF-6p+t(B1jKCy^j+4yfH8(J-(SnBQyLzwO^wMERgjJbN>6U z?bkqT>zjP`+n-Po$@N_pC~U6|4x1Vuk-J}s_#3o{)aeP^(O9 zwjK((+Mb|qZBC=UdE$FL@;U2+cW|%r0o`IiD&0bAL%THhpJz>QMJqlmLLZwg4|BeNiRX}1Z<2Vgxs2C zR%_rR)ARPI+vUgqcKfO)ei7SW_m&4RNJb3pm~?{yL0q`sVefRR6*Kb?cVZ zZU3hx+P^D5`k!64pVJe1kCNyjLzO=}h4$m|H=n%n*Zoa_Ew4_7yfAjDbMadYQYk(} zi_xU9zAWQIY#vUOn9Hwv>eGMKAO3}SQdU)`K4qW$kLgn&q4xxTJhN|tKHUf}Zab!A z$bdwpca2EWAlSLr0~~&oCKs&`|A?;>oDg!Qm>!0f996@9(nzp8dSv+9ha34gcNd1lpUc zPn6fdy7l=3-l<{R6ZeC_<=V?mFY(S1DHCxyI&CeAqOVz`)6-w5VltRocb{LOPuqrM zLf>mcrET3)sii!jx+hMk?rEP;HEfGZ%=rJ;9vl16$^~|b^R@NVkN>Oobvc&C962Vp zue3gO*w=S2)oNdW$`zwJR+^N&in3#oCeWI!X#?__OzWE$)JYllTEj&{sj^~C^6ahF zO*l1~X>YX-+FPyRH|-@Vd#kmpZ}pUCM9dt${x|Z)UAFi8WhG6IN<^9o`P$*QxXrZp zdaMM}<~owq1&BxOIEsK|nqbJWOVSZTR11iwlCU+c>c(-K;Zw2@w|boAe$O0VbF}{GkVqGZ?1W+R)6Ek#QxtE&tG2X z_tpvV{Is5a`>q#1{;$Tbr=Ie2Btf4dkvjCL!!v(fpZ=@k!Cj6QrBC{~SIq3X#K;db zdi>wgr+UWs|Ej$H!uWmp0>8u(^u4HiqQ1NN&tIAkIxeC21btcCjrzjS?9AW4^>i)v z1$=hqz9E^qym~)7u48VK!QWUzzvnr74PBSzIs+4#`^3(2?0?$mhr<%#ll& z3Jq~%VL_(T;UtZz^lw|)d`Z;DrqB2o>*}NR<DK~su?@61g(qF0e;69b7S@KqJ-UI(Gju1BcOqY#iAo)gGb6# z9qtI@{K9A$@aPl<41IhL|Nk=C`H&9S80Ozpb2BR6h$R~c5K0_BQSv&aVj{#lu;Ger zzy#Sw3@=mN9Tu-{l#wl9&i3Q|UQE#W>PD!GBPeO==U2!q8D_I}FJQOR%WbHOmNTUZ z4a~j1hSz#M`9fl6$EqgX@MA4I3Oe%9AHEB|JpL(E@sjcng|s*LbN*xQ8BM(3>I5Pf z;eJkhU-rwr(}ZiW;E|h;!K1SwZv8;VF0-(7fGE+Idm*`v3^N4IuFh*u45O8I1IOb- z`Htfh%mL)m46xy0O_6$O9Bk>IgPlW{f~(ehM}p8iJSEI;)nhy>#wM}to?Hj#gxI!n zp>6IyLp%$8r}n@9?0o`HAmIA7S>0dsN+)n6*?E@p;Tz!UY~R|kN;_5ViYwdJVG=&t z#V;^n@n#65l)gcPL$O*57mx#bt1f2Sd!KnTF-{;X)_Qq{f0@*x>eo=*7k$i%!TZro~wzcL&3?Yz9SH}2W8qck*yS7+r~ zr(vrVCkDc}e+Lr--0`hHwoz)YT5`h1lY(UCnwlQ zho-QRt7s!n9}eOQ@Z^z4J?z7J?Fn1;b%^!lCt^FpVT>dcA=aDLbw|Io*vEv#SOq;& zXAKcO-1`szbZ>|}5fQ7HTZNORBZg);X9%YuSUZLS_&5<&^OSW@N3i6QTIF3I{@n3s z?fgMVOtX$}o`OHEfkZ9*`5(C-a&PPzbJzo}^BBlNtE>R*spEdgarL~PM9!!6YL!yNHI1G|Ide6s`~cgy~G#*58GNVdc8vN02c1@0#n^E72L=8Z(_? zQ{@crjwU$6HbFQ;xnFXAdk~rIe#!c*zdeVHilPQF5@L*Nb*;M}v2_LL!;_|urXky=bl^d7(W57Kg!IiGb|qinSJRnF?THd^*ugGq-*E7##d)CQr&o%ReZ?v_2g z^Pi=yVq^Erj19=n?7Y4-I~wnw&YBa~BZJCKU(SE++YNl{Nui3@lzvB;bJpuT%IQQX zD)TwKjy3}Cz@ZN}&_Tkmh$Kf*@;_9r1FFx=9ra2`_XrBZIo-F{F^R6@Qn@+F9&2dV z@!Am6b;wbaud?7ec%aC-OtS&Zi)2u(048>`t+H(P$GS88`<+j{ncdRS0y65K!(1(V)5L%lQ( z;#D_*ROI~ZrFo#Qmh-dq$fw=;mcwC~Bttx#Z!KZqy+$Hs1Xb&s1AOtz!{2{)zNP0w z-W-YJBsJf12Czyt-x8{LWM}oYv*>HWd1+VPd@80d$+hOb!Xuc53Lkzng$Ex51-CCX zd`b&c`N`dtl&5;;3S_RiK?YR#T5Eb6kaD!E!XEzqo#*v66%x@Au1QZ-wYokmOn-@B z&Qu2lBN)s_GY1&&iRitLN~Ct>))|I2u^WcKUDGJ z&dM(;^22%BNM@zFO^`1zl<|i3r$4QS(GEK@k-#OMi{AHA;>;aj5-2H4r!){anqmFf zFbF)*mZ(RbJ7ure!VQp?WcE7m?iBXg9i68h|NgV~degjA_WHnn$?dfs{IH(8%O({{ zO1Fg!)f|?{eAqx3lj0TRZu+nG=(!et{LjpXjlbVu46sx4VKesyQ)-_N3srof?4gMH ze3a`2(05~}4;FCTJ0|3|@k_~uVl`rgt#j;ea|>2&SU>B*(iv9q1arrvu=Q9IWhMpm z2!+Hn!h-S9%ISHNiAv?HylMP}7mVU+47q~5-QkI5bKv#LLOj{x7oF5gyq1wTUi+h!PhZF!a18@-8Lws3d%TuW zkMUZ4=06_3)zE+LKX&!sy3r|vkRUF1{)1#B+kdR%V*&LE!1xacMAKyV%^BA*#H$HzHTM$h_&$37C* z(+(lMu)!>`4aDsdK!9Fz_zEVD_QdzoI#6M~@qLpVg0{!7I^rF8n5o&aCG&vaHtndH zX+6>s_^13HQtj(Q8MUkr-FF++BH1iNM&kO=!9Zf?*M~AZ>qBrn#`;jiSs#ja-oo`E z{XrF8c?1RJ1mm^%kZHSKVTZR*M}hwId?TUmX$M3&!fv4a^?sN>&#KfKNBx-V3OWv=coY zwtV_gMdwoc{t#n7(1kMJJXA$*_*?A8;Eg7T(45B~gWn05cix^#XS}n;8Fw04N1?=W z_qMTUWfLfw_jSbl@sjyLnoQ(?0|<&q z=SABj!F+emykQF^fv8Ll+fzEb;idJ%R*9Drn*sBb@zOV6Pm_h~1*^bL&_n~EP3IC| zFZhsDHa&c%?G$`A{YTT<{ryhfxA^AK?wUq1k%1l3oOkuU#lsNw%{U;-Mj9@j5e=TR zx`2cf_brAhUMK&{Hb?5cJ}{8b5&I#2a~%;ci>L$$W6t!*_udsn3?3jGXKet}38NVw zoCSiP4y5*a)%^2Qlt!!g&_pYX?8vZ{g)=JF$}KS0b2)72yC-SSq?Y{pUrJx{ zsV`yrJ1B30%~>sOGy?=^kL;8~y>e$9|mrwx0e%Mv-7!1iTqQ2f<}TJQec^Y?QAO41kn@=Z-ZLI4af| z+N}{mV4D1X!6`~V>x&-|lW?nX66{JG>_+e@HFl#JVa9U~WU^?7?aZuKngBt%qlER? za)n>*_T$>Y4d40fAj`FbCu2TC0-|Oji=D`6*2xY4pRwc-#i4?tXM)8i@7oo=aNNH6 z0pV0c--mlSECVmR7fBu|$t#a0>;3+6Gu{%(IT^L&abuyKWB0Brc z;yzTKYn{D2sNi&wLxT_hzZl=_n^EF9mz~H+MEzw#5hPn6e6SokYhCe#CGIMp+5}!n zFyw`}W_-)pj}W}^Ei{nt7&ZYlH$OWYK!;@il^pg2{0`-j&%idOj6 zJ9_P#NYa45CP~7mcwn|?rcd&_W*`ac9dmXAJ*nq&mMHxztapChi(UkJ33c@4CsD;{ z6vGioXwjKU*m~tHA7K}^P9*HHQ%%D5P_lad2=!9QN(k#>L003SlU7w0XlrX~XM#U? zL(vzhcm9>~{$))JysD&FAkdoewz?v;K28;SH?~zG(R+K=bMyjid(mV&0h4jYaroeX z8ZW)p2t=nGFWtSf@@yya#QHG|q!^9mp~QX|ArG)JXBGMJeG-Y7F-8f=Gx?l*uzIN^ z*9d^D$zMVxZ?twJ1--S{eE#Hq)Z3}~MSMOS`pEVCz^BW(={Wcqe?U!%;0{ehl;QfC zNkw(bL@HjrED06Q?`={cL)T}&02P(iu?<1RF<#|^m-Nsx?o7~9k61)Ztqd3}iP1S3 zLN?7P%Q|$b9f$BIEYF!MTN*%8e52!;)q}VH^OELbN%!6*nP6tL^UiVXJKY;8WISXQ z5|Ijj|K>Oy2h`kk6CU4#e8M6hJmlLC1$;0+Zsg%-t?*)j&zFkyH}S^-3XUOMV65su z_420}{0Y-H*!SxgYdzRp=;DmX1CMtCES+92GjGS+6ct|SX$92_g@Ypl_+Y1%mkFNC zH1#1l{tl{m5c-LHq00yt-{kFMfv>BC@EZO&KtMQrI!-M(glj!<;U&F~r55^CE(b#G zT+*dpb!AY0P=lo7wR+4STWzng)m>t}IX)zLYW{FNY*5*X&n6ztK*uTfBach6{#dAT zE3Uj5`|;m%_v1Tf1yk(D=Q4~~i8B*F9~-g!`P5TZQ=nGI`eQxjSA_?%=YB2j2siwN z=d9|_lYLA?B4v;7UY%r@`FM9(IuNX5eswuCGl@?LErK$Dg`q_)k$dXTjmSX;ytj|v z{a~zb!H_)1?vjn)64$p*#jYtoWA*x$GlwryK;~$Txz6jWI9PW+H!?L1w1(lmJ@yc) zn5XEge?D{sMIiBq(>Cx7{96(rP;Tc8)*^pqH==oB0DAP|Bmw9-&zz$qK%GB90Gehk z+fltkPU>mP_WNI1kN85-1B6Bby`5Ok2KK4;rA}wt4g4qKSr~_K4mth(~egH46_8%iJlJ)GT z{scSfSkL|o^ReIuJU{v^LARhI>H6i&rbN&?1gX@ixk`>Wn+8hG-_xW-(u!gDBmveh zH~#@LQq9Ny!}I?eTd9wAL85g|5`c*Nga|LS_vp1HMJ;#gpyCzT3DlN;Xy>!re+R)S z^Vx?9VQ1Exp>IjXC)W89MH>R|K_E1g#J`dlK~fK7jbj z@Vzrolkz_FasOPtv2c5}FW>mf@m+X@Y)7X0b?T|Jo8#GA;(mvE#CJD_H-+g^SUTVJ z#IK_!q=->({DzKG$M=8q`)d17Nen0weXOH_RkHn&JH?L-IDl0A*lS!0e!TGO-@p&a zaNywNE(y%K{+cWrce2wQXM%evHdG~z#@4~WDj7fiVgEIE%1-&OO-*RpUUR>ypK0!T z&+wfg_0ottPve6cYCPU`TWbGRU-@UltymfGARhT=yE)rISEQ2vFSW@(R8gV)X945C zXa5nzEh+Ec`Ms^Qt5X;Vr`N5fKsE7uTfY3Oa%cVhUSt{aFPzee8i$_|bppF5iuavs zO!4L_Z+_HXrg&whV*NYt=J#7ee+J5fJ!AZT4&T!oC*pfxGJK!axsg&wNeK^9_&)wq zUHJZ$^9A=VP<&G73-%-P%sG|WyCvd({?)39ik_O^6(Sf<^c?;l@O!rP-H*V(mh%PU zYTv)rxR(7}{~1jSO16KiapL~13xLPY@84?d*}oO>?BA-#`F`%dO1*!pah?0Op8NsK zt9}1gsN$8KwXc5KzW9@Je8a*L85LOVmV4$zF&4le!9V?WQKLjvIZ``Wr78`TX?9Fh zm9A^yc`txXT1&Tr;8q^%H0N7n{PT~~`-qI}WE8}lIXS%(8Ya@aP)30E(geK@d{$5K z0Upyh>1~_dx4*BOUcLTR|MBadj(m+t-d6*O`2N<0?`(W^W`BC7dZ}EIjAQOt15u_&(&(Cn}j$^OoQ{c1u0*t;7Gct;PSGcWEmB(>Brn zeD&R~_@A~O{}c82pL*;c?S&jOwf|{br~f$|NY~+i>YERVB5j4@Q#q534;o&aA|HD6 z+uHJ>fAD)|3$c$Xc{1D*D5dzG*|=dC+rnwsdp&&n>-U({DH?CiK*Bv5&DW`X5Oa;z zJZvLK9?kZc_&WV98ae9(w|xViT$gPAH`#obdtc2SlP-zIn?$0OuSS=C+JIO@Vx4xE z+iGG>LY?0%Jqswji&5g(ceAiPc^#extjjt9cPRHJro6Q#OYcwSeB4azlS-{$drZ8U z7uFal9RD;j3~TLX@R2uDrJnDquYSq==}Z`YD*c)_B87gP3?yn9e~ztdZd5j}fKjrP zj~twvTHlPF+~KQg@qg!}@_(CZ^?%9ccSDQSTvljt z%i;O}$F2p~@3B=XxdS`{SS6d!tRucQOsQX~^S6eH`t{!DyQW_aljzrCJH9S%5*ohK zDcoDwaFtrW8rG>_AyD!c{9jH=em1=G*A)41P9i@mKTFNew^hD^q?embv0hr}<|{d& z_+%C{C&uJy5i;Uep?YI6FA|&hCQ{(cH~Yq#sAL%_IJPB!QaZ73B_^1;4Y@B~VMdoH z^`>D1l+DIdnSvHDmyd=P4M>OP4#_J*VT0_#Wu>_0aR8@n)n$~}$hj?N;$-A7#gZl$ zVy8)j*Ao>>nymg5NCKqhi)iKdxa_FrBkNzEg73-htExTT1XA+*mOE1MJCMllz0rFr z|5zKp1AiC4bFo!x7x^97C4L{gahLerASJ&Kx;+)Y8zl1k!B2LL-wpmQe$U6=r(NWC zgI(hH;*V4CyPokX3ubLyiwnI|jR$WToFZOzN6)p42b0As*-7TEz3loY)O%u+Rq}ZC zz(?Rmvios&)!tLbt0eY*2zpOt?}_L6T>l!FbfN8A;b2?6s$FZhH*pSxa}7h@gm)B2 z+xt~K^?em{4I4Pu(8Qi=kaHXKum@qUm92q^cjX2q{;Q6G;P4N@z{K->^_^c3eLDQ5 z)cSOMaSDC<=7ay9K7EfpQOWh`3}Cej`qVY0KTEAoT@(G;d++a>K6U;3^l3fzTBX*f zu663uULYZvKGoxUc>4^rRRuW$asl%`iXErhWteNj&KGC*>Ad&Avc&xv&iRGJ_27Tx zK8m}sCo8E&B|9%SCQ0Qf)`uIwxm4#D>X?sr?sEt*A@bh$JvQYGYLfdL&Hxh0*8_jA zC11=4#h+ra-1!}lZE<$q=)d?Id1E6uv(VI=(4epD(3~x$r(;`~t$^1!DPs}frDJ}4 z2=hjjhc?8Yy&Gay@!isB)XqJbb|Ux0Su3lF0q9^Ri%_Yaa@RT2%Z$);t{~Q(VxnjC zSM!C{?On*{EB92JXTB^{@v-7hG4tsn=F>&o05lqJ)A%r6J*drr_A@sK+RrnbXa7EN zHkW7K|1Mr`by*J%1nfyeAN_x@ZrNsRiX6!v z_|Gflc`j87Dk^~;p;4qw4Ff~i%dN0SxM6ophY{=6a+0L->0I&Dco*^2SYqm@7bLz*mWLQ8cQ z6hkt4b>7eX`pX@m-K~Az0eil56olPD8dw;>a0r{zv&#D~8drq-g->w6* zcC&SfjBxlhb@kX2LW_zHC|^7F$k3wVyz&pmwtbd3mu*eQJ6zRUv_F0ubzD7-oQ=l% zjgL-Ui#_W#-(mYr4T>^5uB};%YT=sK@${Nvv%m+-4gkxVqc9H@8$Uz10tRn0(fkKq z1YGkCn)vj)6{dP14=B(`=o9oiLVz%LXa^oj#Q3Z}vlZnc0WrB;;x_eF^dnVa!dckr zl4hMXcXw#HmX)DQ0TV(|d3r3T|D}<%a=;iRFfbq%CkDmFwq?LB-=FVeMFsK)Kismi zXBf4(sTrFXf6EM&uL6-B*G}t)1hEKc7elJQrB9l`S3tgKJa+t!7VM}Z*1abyEdu(~ z5e&>h4aVxx%9FCAmB;4B0!v2$qpH$yw6eeK6dnQi;^maPgWg17I??6P__5G+nh)Xb zeiF?GfNEZgR$>=BSpjURpC5ms^iyq#;7jXdY@)(Ef!cHpVxg6?<|<7^mE$=Zzc8E0 zTIya&nl*r$3FTAQj@@l#&;8S@KNcraG(u$aw)#VqsC)(fSlP2pdi8UB3uRVvJ@rK5 zP8=r5`vJyg4@Ilh>TPH=?s2qN?OgqVlU@_;+7ln?`hrR{Wi!28wDOTWdcJ7f{tdi8 zueB(NH6@}P4VVX$FHegFPrU>jhuM!OfY|iBDuIv{jgQCw7v@pGh69|6@se_Y;%Y`j zW3%#>uu7~Y17s0BNcnuK&D0M<<(Kjy9vEWx-oWe~x*`4mjKISPx{WOBi5G1xhj6WC zkK2Et20FBP_Q5u?T|BjR=E_+=uf4ewde&nMWBcm}NiJbuh3u=C>NmbTBi8!lk>J1w zp{X&UV@}>={#Le(#wQ2|rpccU$TAxwoJl(d77OM4k6~?#{Fdi!<8Mr}f659<1>Sy^ z)MXpi<9~c+UH+F)Ki>L)`zbaa%b+~_jJhyQgYJ0ns?)mEgM3(PJb0l1pr{A- zQN4|>c>?bX?<1*Nz|pv^hj7EzB~eu|T3rDfu=aQp*6=G97nJk$`_pkpg%$-mTo6g? zmOd_hd1=79`mHZ_tPHfmn{?~RrN8X3f@l7?!y56@?rB#4p}(Ri9Yq<-twnDjL0w3o z9{bv$?5lto&y>yc$y(UgT>iqor1a%PEw} zc;J70o~9nDpt`%HjVdyaP2>vJS_^-^47JW&;FN2SkLx zSrQQv@eoz+Y{8zYg@h>tADt7S1-pea`1Ikh>XK|>77>lxP{|Oy&4nid(nuiqVBPTH zkAg!!aVTIfh$y_%ARZX@hejWM5HA6c%@pcam{$h_bqGQ{Opi~QQlasIANl1I4}7-nCOdelr&UMNoFLKMm%upMxzJD5cJx=#_WMx)~t_OCiZ|}R!E^| z)clJi6``K6q*xv*n}e7ku%TYrUT!<-P&_dHrLfEAd^QJ@id^ELq>9OWunzga&*T!a zYXmUGx_~bBySz|Doph;(^SP~UHjtsij$H1@Br;ce^yuGia)dYCzJ}lN@5IN;V&v75`!=jgZ$;zcdKE>cS=9@Kc4$0bfj^bs zn06Yxu!AF#r4*QaZ}J4l2KP`w9?s$6i1-C)hJB<~JdZg<*>)}c_5{2|al%%~ zD9;cD=?q;Zc$F0kbUF`0s|rm$i2YYK7B$$CMOP zgH{{0n>o0840n)j8K#uM3hpjO^YMsLD<^`Ic<_ROjOk85*5i<54*Jgb5l^>mly8wi zGJ>Nuz6TXbakF|EGuwDD`~1$NPPBLEo6e8Rl)fz>zoBpQ`D^FLU=cmIjG!Y#uz(0zfiB;pcU6Y5Ta;Py z0I0&s2v14yz|RQi4I3(DI}Uj&Cj+@ zfZ8(v02p-kq?InL(uL5L-)8C*@SIMD8_I{ws;J(TS+U^3=R^RZD2rT3^K=9&eKu`t z;848OnA4*iy=;rf4webWfeC|bVR_)1IR~N^YaF=p%N@vFdtfJ-6*)zR5Yxu|VJUUS2A{!%RfQu|9v!Sv@{DsQ$7aA1WQ{^B0tpX1G zU88?D;+MphpsKCaI%NY*R=cB>V$(O-(t(%(Jy3m{EuHIDDCvx1;u{Za$j~Fm9*2`k zxf5(+-stj1N}0D9%KR#}t=ogH(IT;UFx+^5#U*iGC!sTI07~yIk89oK?ISm=-JK9*z~Tbm7Bt-6hkMi)bwn!f54O)htsig4<))gs$62WDZ#tJ!Gj& zF}%t@?ODk54GJxKIwF;8T{ObD>?%x-%w+=*HD4O4_>D&ZF{Y2>fjz&sqpg}rR)8I5 zwb`y5r^~Dv8t$$91$pXka0_kJ926Tv6Vt5wNBjbBGxSa6ZN!|Xte|x-?^spcfq7H^ z7a7-PSY4CUvG#fip5yK9NUB_a!Tk9Q+VPByJVU+RumHS^rCVex4s;9qD#n&V?NzNYQSDsIZDz%8`95izu zz(wX9Jj{qGOnUp$r7)(f8yo@C7*k5eQT>2%G%J?#yu2>XhR=@B{2)|*7qDMGXKU`3 z!ZFeE4@&nynieI(VM+bff*9CtZ9j@V0$$ChGJT?8aHjB6DbX24LCr%FX;shUz%oy9 z^<@;wT`z#|{3f%VUU>OYpYL0ugNSP_U|*V*OC~y~TbAs z9)LsgL@i}X1Qn*opS4)g0ne-h`aQkB-%&Hqs(B6~I|{;6bb06*cOdu)jT%W%{3q5c zD_RMEG)^WJ`KD||_HwHQVAQ;v$d7SXqkRF}=d-<_Txi=HuyPISg_*Wtb$x-cw6qh+ z1Itu`sJ)!X1Q;+&yZ4Ge;32xdN)JKMWw>;3hSlElx3vd}<5Zs`G?za3_ZcdAhy|cu zQ#Nm*>?$A8zFhwb#WHHf^)lcj=7C{_&`^nVu-M%@C|3cFo30}8+D)X07IxwDDm&PN z-5?mz)nV;3J#^#wG;U6VP1LW(9!DFNDXhI_SS72K`;*`@Wd-rWI*Sg{P-Z?$dMUDI z_t97evapxkO4F4S$KXO$oTX;P;;sKPg8GN)Qmm`Oaa;}bnWrFZi`VCsq*nF=N@sB2 zBjZ#I6Psf%VM^VQOSh%?6p5a_MXZ=6HfrNDUHNu&E5w3XP}0^VPMyXN`vMQMcg3#iFBtFQf%_w2V6B%%5sl`eSMd(~Lfa?V*ytZ30iH2oBSA^pEFEyTG+& z(B;_jLX}g9Ij@j!#9*F|gXE?ZH;_SPSSptRR9sRMxnC6#5|ff9_?lG*JmTQWKz85wiy@3lhs#PS9FG_$u!7&%2_ z+Sh6qXRTTYuiYOafY)~YwVdDGK^A+~)i($ zq**f`-MYhSeNf{xEBeZJJFFu<`Duss*gJpjuny^kIhnkF;h!F7;oWaTvFOU)j+klcl-&zQ-vw>V_6h+Z9=@J6vK|7MGPtkFS%C# z6~Cw*LHHba2mBw($S%rO6fUn3_(cjx=cS=pRbw-1da6DFB`Vq_F)A70_X~BRQ7TPmvay2+iX?dqW$N@hb+XKD7*EXoQjy%H55rjV)ejno4D4`$)a@L=VRa*ph zdNugTFx!sjC~dNkVSlen<|FNwI=HDsX~OhvLI%I%emuwsR9~dS51f~70lzX$zobA{^>y^cDgep(SZW)I3|nhn zRQ)4w#Q2207BcwH5KQ$V85WA?N*DS)C=wr9>7iuhb$&{ql(NL5rIaW>M-2vJ9n@BX z-qY+Pz%T!rG*{JpWt&o!SeGtsZd`5&J-yJJ5uah_rK&P!D;m8+a*Fo@6aAiWhxr$kN8@K1QT z3x81l-zwVA8N900tURp-|D(*J8Y_u{zI7)eZ@SoAnuZ;;*M{oxPzDAx2SlJeM zn!S;Du0lVAsT^Us19LLp+b}?F8~P_Vw?cxLHF!phhNSQ%S{W(})K+G?j*wyh!j z&R8@sJS9>pylmlr*$6L7Fb$?^Dlj&qrt1W_T&9Vr6GfE#cq;jLatr_Qd9v|5&3K++ zKf}0Kp9qV)hzE}S*v?|?PM8(iQQaDVTfo^L1R(xtx*8^;{TB8K<`52*9cy10CC39# zzGDNFj|zC8HB5lEflvT#qYoNKoxR}s6`rm^l@NPSIs(54fAT!qevSvKmKym9I4ok6 zHo%l^IGA94x?6O?wNH$?!dBnsy^GuS2v29Bz#}THUF9$4-|<1|(a!5aHy#XJ#Ej$p zus>p!Vzy7bdbbe07swaSVe`CFezTBQ8v(9{h8Ln0 zI0EhDC6T#Lut)iB6YO$`2DIpjOWGlO1qd1HK_tH~NwBWIEfl>XR|Fc_Pg0(jE5N7c zh2?ivUcUTttI?zRv~Gz0a;t1Dp}jefcb)gp3FvD`5PwXNA0T@ zOw?o+_*3xG4m>LVXjGF{J(1~pEr1?fX9AMjx^6W9F$2h`$*5Ue8;sIbCJgw|G;4qX zgONR>CLo`~wM7M=&Fp_i6@QDXk3jZr70hRnU;QcvQ=DpmmStJ7Hu#WkYX-LXk#D_E z6Tt`;Z6IB*Cf?K3n3pbKX$i$sNUl=nVmVdEA%R|7x;K?Z=_Q`DhE`AD&^B)S=H{vo zD~R4{!6h~8SyMSYJM(kh@NTaqFyL5hr4nff@k3QlRg`YowkF7T5usAM^|rD_lDRZT z2TjP(AFzeWg%_v}L9W$}fOK^R|4Gwg7S{}Y5ljtLe$5joL|^{xgLoze+ST{!k!&hT z2QD`$l^co%`QS7ooZ~6bq4OwEt5|-jJN*g{!v)QUF!&#z7Z}e=>}OvDw8lSxw5QoG z$;NjFpbf@%B^oEnju_h!H(7< zF@*G01P`|*vx9UzRC%lOk2}zHHj3Kew_PQiR_|3?1;;GpD~FbCNk?KyGTnYVR@E%9 zM%_<_yDYGgvW}bw7FNNEJo#b?r&c6i+>JAfQ#LF2^@#FV$QQ+PK}>XK{Es3laGo>s z_-IvDs8ENfBNi!1xiDWRT9`*tiB=C`ZYf*?Sqrwv)(F?%#-B2kOMrj4r;*KwzYWu% zMa}ID1jekwVPD9=u~J=0{Oxl1+g|`r`P<%&x1sCCTc`pfC;;e*t1NczU|T1}k2=^` zVeBWxbDF~kHRovaC)<7>w__m(zwtoR^>%#Mn;8JqNEi;-=ua3#zIF(M29?ln+1Wz* z8#XkZ(-@#O-~w(^6efdnNhP%1R(%b}&J%!}nnFx4bvy)pmXI{si>3Z!h?wFPFX>XUT&@bH|>HFOsdKL>W%J&wXBuBb%wq4&fBPr zWgZn6gDdG7**bqYxZ*FmsKPJ*<1_V?|B+J*_zP-emq|v=p%7=v+8P?h0BD3se4PkL zBGU%lt8ijNjBqj#$JAmXdps}2&PtDkx_GEG}beV8(tu> zEG4@*?E$!AzlXlYf4sICI>^On_pE;PB&m@)9^v)+Hb zpVDVhh)TWh8Tvez$eB8f=QVi8|6s0dHnswL5Sl7O&M;n_y1iG+wr(ALt(#W7 z(_wfhwy{Oa_0|^aqo`a&Yc&W8XjR0jC{?J>eHy9=ih$PqzTdU?o-^m%G=qd(R#Y!TkJ%rJ-eT>YiJAgO|cPDj(D%COzSjs3P4T&LMR4c}b$T9b_S*IALpu<&e!3%8PwUlwLB?Z}5TA#~ zcooZrS*kpd=PZv-hZXDVps3m;v*k9$Ehn8-!PWV={$cx9Y_Dl3YtjV6^vpO!tIsTL zQD`T~Q?=y=uoP1RRBZ!l<4=Sf!3I}d(^o9@Dk8m}II&RF)LKnLy0xH~;*1xOI?t&sc9a1DSLmJYjaQ*29)(yI@KOsBWM4KaB>v2Nvua@Kd;`sW8Zc z$i4z~qa>v8MC4LbvlQl6t$O_v$qUE>L3jZ15qgF4q(CrbEhGwa1Bk*kw(=u4F41`g zmKq~UMu3c(zh}0ULP(OjNqtGn9zN`FBueVB?cuJ`Ys~cO@+d3^vH)PqE(u*C0mW_7 z0y#zoUO=M&Mu_*z%wp*%sYU3vBT5tB0J@rYs(6Qq2AzmRIzO^?ViA7AHg*mO*&_pM zYmh4>45s7-`$U&H>OSlhPNdU)(#i>WJ&)k53qwiv_wuKga|Xg`9spcq;Eli7WG7)p*clzD*Ru&&Y&wt-UUcc2FW6To>vdA$6(48czYYR&geHq4TFTcghAHq|px!Y(a2$!DZ6*^_6=H?0F>4<7quG#g3wh{`r%$A@*N8G?n zPT)`yT(wTYq@e(<$QwU0{$yheo6TD`;!R?><2|3&r5u5tA?gL#={pnhTtWn7@x2gr zjAHHOMXo&_s)WgTijJ2~)y8mS2>up%Gz0#~PVnOfehZHl{+I$UGRSm5ETsc&4A0BT zBe2A`RA+Rs;nhq6Bzl^)mV)}2s25p!oW^}N`V`PK1Mm|Y)mtsCB5$CX)i}cE$$5=E zhn8yXim6<&UZEu zLF7B)<&f|2h~QKT{J;#Ot)Om)v@`0>8wI2QH$;sQBqX81{NKCT^MCt`;Sr$B07^$Q zR&D}3N$ExXy6QmNhxPEVc+yv-Hto-TF_fl3fpZcEBs|%PJW~`ft8zLoAHMrpyB6N0 z%aSz!1&zvlp_Mw2E=8Iw4&Az>S<^mWXlFAl9>gm#u&ZNNrR^#%9LrG4ab~w<=!*n4 z36GL4n(%Te2!iO@Pg)7Z_Mn8V0BDtPp*{B_|6Cdc3eXBThP-3hDWoIM08>6gFUj_j zN(d9hHL73Sn;q@zc(;+yiwD8;+IWr15ihAGHHJW;agkAls2pwGm$4M!pvWi>t2dD? zumVz!Ty+BKHq-~s@`Tkv&7TjAJ)_6`YMdQ^zD)pKk3XTm#9J7#OpbQE77&tM#SHZK zl}%miF9C}F3P7K{v)fo>LV3bA2ZKR@d5i#f;CiuHj{2df2$! zfC5m_R-0C9aipT*oscA6PYUY?0|?NlW#+__Iyu2>kPk-FYEfo@npz+nYz@VtO^P^0 zRm*>8YeN;qhfFJLP)Sw8jXYveMMbX8)CQ3#aNi_-npcw9MMxW7_$*T!$X%K9S-tm5J*8cs4G??) zR!nO_P>dV_*ZC7v;in~(oKlTf=|_wB0G4p<*lTL9c5Gd?V=xMuXNMjGP&ez@udYb1 zCitF|!X08P1yj922?LHHf;2T@&k|f}Z~rQ*ow{Zon6jBn3H^n}ALH=afD|)lY5Sn| z(Z5Szg@5M}_CbXb`&cALJ4&^D^3VaTwE)(dUd6$O#0CV|jFp7VQZKZw3a4^XEhkWQ zXwNvU#EW?gs?M&gs$1Pc6YJ>cTWC+f8<4a;$+;g{b#N3!06E;xgZ~#%!%xZ7l379q z2|}Hj4MAK{_4q=q&ZTSxACz{rrfLQaT}ViQlp**UHm)TUfTD+n?k|(>i~|7`tL33g zb^hwpOm!xssLo+NsmJC(a%YL;Lh?e^8`Pik^>|T7)CY7pg2)(_AToMaKsAw9)O;mI zZDbWW%Rioz+x$Z`y01ORwwEDC3JSM}OEy@0(3E^Df( zuuW~E^)(t}J(K9BMnb3XqODby?5@>@+q&?BwjytXrO|Z&$*_R{e{qW!T^4eS@W}L@ z*a7vrNGd^|!A+u8bPm~;1tu^h%MJl|NEjSf+d&18El|~HP#KzrZUDOvcySN;kv5S| z?e;}kcnU!5HX5g0l6Kff_pI<5rp^ehgeB0MP%ei0Hh9sVG-Ek66&}(u5#-Mc^Gr|F?zStU?MeLqS1O6%WJxd*vaz zJ+|Z@PMLu4kC!*e86S=e=fhN9z{}udhBuTRL4T1t{4X3sYRE7kLS+;qM1s*zF*CS( zPMXEv>xRXejj3wnw(Xy{f1a9%lhh%cy?zj-J)^pvoT+L`B4)hAAza2^D1HR-zJVq( zW3w>yTgUq=(M4vwKd@b#@F}223n4R_{olv@l4w+mi!uKIVZP1@=rZ9qC0!Q3DWhlv zWc6%ob_!cVPg_eVwhDy*V9dv6YaOXKq3i0MnGn+D64;HDx{}X~|BZZJz`TDTA5MH@ z5XIkmVTzFzhgJXo$m)K10|BN*Ssj!mE97aM_@{f4L;0YDeZG0fJHyWgw5BXUigf zFtWxS?K-EbQBqt&rj)9uK1yegv^Q~f9=mQ@S+&A+En@|JMg621M7Z#~)+u~D z{3WDxgMZu0dQw2Ix#40?(%CcqUw`;5@qaMUE&hJs&+hBdUN%u0wChE3%o@M&Mw_`I zxeL4il#gCLcdbS?3KQbUCX$lPH=wvxcmOd2r6f54CQyKJdI;0TTX6ma_U{d04*$?Z zADYPC0xs>&x;ByRxBrJsWVLi>SE|m}p$w!!34{6!HlGm>W9u`UJ??mOeHUR>pof7}dJM>rAHOGPnc|Me&53l*kEW0bJoiZl1HtK@vK0- zj71pqg$F^RF0V&vm9Q-lpj0rf;(#6RT&QD-<^>_k(H4}(7agqD<7cJyPpi)ZdIW^Q z*kT|AliVVBdB))aHI)abM1zyD6Np9;(SX*O0!fYa*O8Qj>fl+TiA-fKA>xnct@>2X z7lzKM?EG_mQ{e-RAQ>f4QA$5D^*&~A_NFcWnMT!g#5G72yDlTidf+&q>q?ULL#CLN z+Z@GX5CFCJNMZo=*_NF{d+nPL*39%6{P=msQY$CEL^=^k)`-Y*LA|&#GNs0o`dqFX&lxXRbZ>BkPAo(-IuQ``|0@bGXW9D8x9AS%JE4PPP|kW zkv!MQ`I>QUW2O*So5pM9*tHjW)Kp)s5I0F%!);R+G~5;;iWF?U@Z6gr#L@IY8S*px z^W3fFCt`>E1a;Umk70XO(qneI&j23`sXl%ybKWiOXUvFMwpHV6Pg?*?@RZ(yZ5oZR zF#Ks@Z%~ao9Oa}@PM{-V0i3tq^iYpe3ZE|1x)P>^9d$N>czCvi!US)H0)SQ zpPk2hQH);q#ZdNgUO^iM6R!d$$XR6F3fBt05ex_A;RF|nBBg_CQ9cVtXJ1-ue_h>q zBWUkqB2$`vKT%u*hUkzqA_82oJ{3-xE{NM0(gn#8mhaM8lN_8^*>lLJgzaREy&a`B zN~}D%@`Slk$}5n#v<>*C_g_zkGOG~@Gch5Q*c{A&1&|nlfm@_EPkoR0gJ>HMXJxM0 z06J|%8egOgmIHQ8iJ=tB83AAB4&^~~xS9ZLha@n2d@sT(QhjpM)wM|K@!q7_ppSwD za>4(~yi|xw$;?ZGap{`OOM`%T37Nh-Xd{P;9RB-Ja0_@q434?HBV1afo^WUFv~FSGUn~t3;P=)9980141pgDB?V3&$~u9 zuM@ga0)bO4;SpV|HR!At^sG8oT{BR~ETCaSCuIrq^)$r@!Vedh;Eo;1g-E_nj==)W`3uAr!BjEul{k^yG zJ$vKAp)be)n0*y^g*WaM<4ZJU{OR%{Tk#-{wpaVUyif{T&&lOgLT$p1N9~`XUXK`K z)o97b_^kB`byov0s|}4x(*7UuPrip-Lj0n{FDjt5Suql$BkT@?UJz1>Ac+Dp*^lfT zO`U_0tAnnWyi(Cvbf`-&!-fL~V>PGx>XYpq>Z2jpS72)yuD$)69UW@f@3E!8)I+ePz(cv% zbs+gGv^x%O1*wjy_^1EV2r_VGHK3m4UvZbsnoPPKTI%=IA2U;?{6CLB37b&=z5p`C zy1t`;DA^f#2$z8@-rOg|qPx=&zbBj(*UA3WRoM`46o``y#N`OG0`V$=cq#BaMzHJ? z!t$6bm_^wzhYQSH1M_SPvqWG5+3i_Yv3x(f4o} zCxBXQpuQP`ibRH~67Evja@0?zE$p-ps0U9wt{{$~Ch|UtA6ohM_UK@gn z1UQ4C&pnVu{v?6=N7y3CKg~j&AW*SxYMV1?Trs|G9{F2SngPdUL9NS%>Il@y2I>YN zCb;HUs9Om&2B^=4pvJPG?w<{H%^0$^w?J*URv*dhp<+;H1~%^6BU=eR&7o zMsB|amk-al{C8YV?F+|=JO3ITeqa^v$Tzk8{8uyXJjgpIFirOJ@5{JzJMZwr47f8r z<9>hC$^Sw$x|G|tq zUwni+rTR`&#+|o$XC)$SYA^hwp1K;bS@H?Hs2S-Tm#f=75sc5wi2RsEB#Y*D@Lqw=4=8SEK0{70WHE8 zf8aV%1b^fJFJJZ5ZhVe3s;6Xwbp9p0x1zU@H4Ayc;aTUhp*NRIalKZ}=*7ZeZyB+# z^!qr#*})zK8=aZ^<4Q&HO?TLr70Gq(uwDH8OkyCP^+$HN%Rj<KxA3#lAG&}41Hp5?&dvb`7z>@lyzOcJK5hD?v#tCcr7%h;n^M&XClcbj z#!qAiYz03EWe1_>uE5qBQ-1;(ZZPb?TN-cfA+8=axY4%2a>J_Y95pJi~oQtjvjc>fH*zBN3x z)x5Sx?UH#(DDKC3MsdL=v3~FhI!fL|)$(=RLe)6HQr?I$t%pNdpj9+^J0l%i*$tF=KPY!N!y_XX?vG?T?)j&pTmGSTnWZ3FqT%{@#exhT1D*fQd+nfeQ;3#9!=_>&?ro@ z*lZRjHRuYM5I>H8_yy*B@CmJXs_Zg(N!H7c9fmOI6_)XU2dd-&z(Mj`$ts?GRBgNr z%-9unf1&!b@Pn&=z>gUDQBHn9T8uWHTg&~dehS5V;&=|%@Ehz$4=tKC>?qkn{&@L$ zePXaRVI5MKgN^fUi4*p!I2p@7;)MlR_~f*R)q40mRbk$&cH3V;chAM5qSh!|foX^G zK|lYxR%UrneyAs8N9N*g0l})D-;`N!caPxVyk5h%Ih1Bov=Gw&vLutzwwN-&L=61bPUMbDz{Sk{2}FM$ zCpul~55Ca0rr|Wm?v`UkfACq3O}Q}$vnmQD+1p@EHg}^I#~5P3fB2;KHvp<^d^DsR z#q8V9KmQlq>&Dd!yVi{pZV=sg`p2N^h(I^!GSd3tCyMjvF=ff}3yh#MHaAKjeLz;S zyS_a}et8SGdq!F2KzVye;s~@tZxEl3bsbnWuD^5;x%Zc5*a9`q6Pb!W1H9`07wtxi z==p^BXy8ks`*f)O&`acb1g*^HQT5 z;J+O&RM^1ZLbh_-RQ)PB-U{UfgpIiHo4PCUM)E<>qfTIM4`qenf$Oc(6@EEOTk`Nk zd}nUMcjV5^_6}>n97MaG5!#HEl;sN7c?xM2V7x!pzWfYrgLmme?Sgt0&N?y**)lPu zgbwCK7`q53st)XzStn%bDn8hctguUseYprRr(Mu=6DcLY1en%xM79U4s8$n=1aB zwuGt_7tpI`FM{S5NSp;`hHuyo_)ynhMizGUZG#PSjl@=wHQX%Q6|uV zLF1&3c=Af4J~3k}Ui9-v&a>W8@&l{KY^kb#o#`D#SvZcv{^Rl(IZPkK6fEG8+Rr?O zbO&i4Z#J?r9tTJ~dDb8V*Lm*y@{)Qhi@yP0cw;NDtBN73jx+F%c%M}4af98tuXvjZJMshz~%EN2y2;CJYYr3Hpbbx8sH0fw?DWLlhKqUy!4Y8=EKH09R zoHt@%NXZ-%d>~w0%n|6hx z_|AS#^Dx+r(0l^6ZRiq&z(*A8_GV=_+)~@7Ktz1oIdDC4lD1Eg*Lx5@h_gyah3yC-3+qFJ$Qz&YE?AfSAyI93B7;rVp@69VB_$0sHF^@CB^7^G;SiaAG zIK@x~3iZ&dLZ!*?(L@f{}vCX+D#{A!jz_Z3iMs=dhFa?9G--QWoyfaOJ9Lb|1nqVbSWt)p*q))pjznkIkVC_Ef+%$tM(UN>vUHouV#ZcsVEe+($7D+abKj)G=X}Wr=-pp=CSk*MNb;*ckSa$N!QGyh-WCQVXE0JVO#=hq)&i4A2rl%olyh4OJ|6tfE0V^veuM zi+dlr&+D&4*6M@Fu!bC*W$8biQC7b0N6J@P{a+K(|I#k?za_2z$V75D1T*T?rSe;6 z<;|<5a(Z{x$>CupUs}u@8j-(6>R}_@5(12pGvMl&QZKUTa~K4_TlxD zOIUEPvsxmxDu?Dya%$iax^fO_{rm-^C*B=ItiLeeronOtln~evdRjQrnkk0s^=CeMiW&qB?9rz-}OF41x0B-IHDw z#%b8QOgMKIL`U!8%kY{Oi!%f{jv8_*v>$*lpb)8xBpO*oS@AM&@;Z%Q?{7&3x<9yn zA2dhJIu|`)<;4dkE5Yi&k_zIryKLS2R!4@>B+3Nge;4uufY zBC6D-7J2hD_wUq3_OJ*6AE9m@DcXSC3A@w-sCLIea*|hniJOEKl^81me_i~~kD1GG zOTJ`-Z&CP-F%um|BRXuEeue8_gUC>a$Z*{A-l%?CB{DR8A525pIlGgFUrQ(3WU~Fl!ebw@j97?>(Os*FoM|HjVNvnFh z@CLHYumjcW?<5`|aH`*ZqMIfGt_}KwX{*`h7Bv&@T@-)=A+H)bO8wKCSzYN*=v9Fd z|D5Fl6lE*=G-&SWy->PDyMf!hQ5Sup^|YQ62IB{AbN$L~dEO}3+!zZHY|HBc*XDD? zB>>l>gczg63xz#~(dM0VfQ2G6Vqg1$RphT3=y_fDORqA?-Xu|=hsa8`jUP8c=JD)L ztkCjPFGKeJfQc3f&NRb19wzFP4ut{idPktxuIIN*ND^l zy=w4~?!v1pVLU{tx~tGhybH(cB;p)zG=16Mnf)D}*{JFdedYp=Dk&Z0@C9Ni%wqT} z+L!eDLz{l2n;;k?8=xOoKm0;-59-U&rvx=%0>?4m;CX(Y+W~jT?g|Wo=rqRv)l3f&$+^DMF zu8}GwQec7EdlFJzOla_F5Ra`}Waxe(z4#D}mWeQsBqk(fMEodFYbNOTu%Rq=UB8UZ zwSVKP!)53uvnqKT7R>8XY2k^D%nr`jXKv=a1KkVN4~kYGDyQcP?^qi0 zA}~LexZsb;^GnboQBbk3kLPKE^jY?~xn z0#}1<|8v=f)ZaN(s7}-4zV&2NV`=~#3n9T99j6&CM&yqg_WmkZ{ZW#s-SJGN&5L6AE3I(k8NK1(a8XzKj3^Bp(Cl$*68A! zo37mDH#bp+mAm@u4^qBis^})Gi>R3kiHY}vDB+8fTf_@60sRGCI3QztsNSNs`>Yrp zruh7!4UgjOH!csk7uTHTpU549gLfvhX);Xn8u(r)wCiEEgtLm3Fh9M_0$<#w-Na;f z54dC2XlDLZI%np9C|WC*p1>uT-YGX~)2kfuoHO%xxK@#T%N@2&mY@jPH1OQl*_-sF zEtA-TG|U6CuTty>8w$pnTchDTWY%RghUJ4kBva4injFmevJ8_P9mOJ?#pn=hG6J)o zfu~{WMs$Fao*`__fc6*4w#!Ey)fp}g69n9PgY_Mfe58E`3onx&p@ncx3i>Pv)mc#D z5Lm&hszhIICG0bnTF>+glaYMwiMU~bP&RJN%_us`Ro(YwublQ*-BoR*BXx!(Z_lTO z%W()ATIB$0%9juMQroOXncJxq^eRHMRW*9aA7-~t-NXdv1Q+)3DOW9I)gw}j>Yc`u zX(NDIBB^QGwXc(CWK%B>J1XZjK$$SJ3Yrhc30PEBiZ*?m#GcYdrXCsw;_HFsEH6F) zm46%xiKor?Edo`?>U&;?e#Pj#!JvA~@EkWLm&le{ZPA+i?o2N ztfgq^GwbBUFZ`dYnQihZS|;JT@F&nn1WL7fo_V*1J=7A5I<2$mbflagN=I~)Auq7j zyKI8b+6f`ZfhXDqEaEz29SKLs*Jq=I?J@(Qitz`?H|Yp|fFb$~CFtO4G~o9E)=0yv zpgY-vV9l6|4l+Bv0NJs|?udw0RGvXBrBu}KC+fBZx*dR^V{t^Zk9w^q06vYt z8LKD;b_1BePp$gy4n6PgCYNY_VRo5GAa_P;!_jbwM{)`L4716ONCRfuy)!JoZLXKW z@@{~ENMZ&joqyhB25V9Z&64~|4ZR|Wt@<;Y)PdCF4DyD*sh`N$Fb!pUTNui|Xs_P5 zyelYYgrRUsQGIV5+`ukqRC*30%O6}xyUX~V2BixBN4v+a>0d+II4fwFNYOz5iI)T` z*^~r=PG?FYHT!xrWTUnKICZ%M$|<@IuA6lx-yYbp#xP?1*z9O3S~+#3l=^{6uG2h* zsHTy}1X&-AJp9y4lsO$4p2;8s9>oSLV!S7&in_rVlq;vWn^}g}4v0e1lsY6`a437z zDhjn%6{*bJbR6xP%i{dV$5ZWaKrWK81c2vrRIi&uIej#3EYF`O*=CP)?2DaAgpSm) zlFar*^IJeyx9y9zEjEexUx=y%=y%OUb=PQUWTT9{wN7T~qd2>a{Szos7f}b3m{7>( zIABwTu|%#{xbbbt=O?*Ij5DB_QfjQm_ZBu>hdtZ((h`BDz)Ojynkj2I7b#s(;+tVK zc%h;eK|ELs-FmXl=Z&tb9ghcz3p#F}&-UU%5Cyr_!s-}^BBMc47Cpbx_EpE?Z7qwp zwHTN3tpJz*Alr;wxkK+M4D(~lS|B67#5t^xo8i2${#2gKADjvGAl<^eWKMfGa|2TjsGl2AxAai&wFuYHI z^$|A@V0slB@H8VNOr#JxA`)vlSe1i_jmV+iEz=+yMRh5%fGiyZ=@@O61A-wHQyIjM zs5;x&J3rWW0!TVEAV~%V0T!kjU!c~VsH5@;@HPv9J_T9}0o7q$3;2yI65*@l1p7zS z8PkK`jq{$5#76iYSYZ4HO#v{I@I^&L3mWcIdqlxt@C1$X4wlE|E{vC#iXa9(nC6KZ z{%Eh9)PoF}xL1uUa<4{C{QT5Ui3x?3$ZgK1S*iNXsR77!^+eV zLxR9BTm!?f3I)mw<`FY2AoqQO^}yFU=uu+rizOsX-#-> zK#3b7|y$>uj~-Unf#A=FfBY9Yyb%| zp~R%M>B}M~@gm0aOcbS|eLC1IlFgdiV$L1U#ail%$2!gL32@Y^2sgRhZQ6und`BS? z6`gb2&yeFac4% z41|pPC;+GVEtGuHe9d!a-Z%gk_~r1K8@WaWA0c;UKC90V>JBDIfDoDELnH&ds)8B2 zp53Ek@A_$F+!k;wR;CSxw<9Y!2F>KeeDj%6XcpKh>IcmLZO(X+SLy*NV7vQKq zpB|nJNsSVd3+oYfHXs!=eX>*72Ei9NOQ#f%X<^Xo1-V-Qq$Ve|ljcaKH78kt53%ZS zunJF)o3ZO?zwB0L<^c%9Gj@GB{hp(p1ZAPG*Z0Lc4NHt$t_4I=b%3ZqcU0ACswUhN zP~{}<;e#;HTK92~#lPuzG3h#|tj(gU2mQcLbC|l>9li8a=!67c14n9Dhb=lDCVk)P z`O(EYIy9r|fm48s?A~-lJr%{ZsKrKe|4NhPn!Msif^GVY}1V03Vw>kyz z+4wjAkdESzCL3?7?GD+Upo}}z63@5I;cbjA z1X^NM@e5!&V^_zoPyU6II8)SQ$&`*wPU1rlIb+wZYtH@xZ*>2aZgYmJ08mtgOZPWCF;-vDv<1G;7}Hi{O8lXfL+24`r<~zR?O3`< z6~mgSTw~jp&%phz3e%k8;8^z_TR*Nr7+eulZ;3CNVJmG76$VlqGVFwJbYM5$63 z&Aa&C#@10VE6EEP;;_YVSi%0qT5yuVg^|aLjFZ;+<9UE0BWmDD_4S{^@A<(VHKpVh zsgyK^E=N5Z)o;Iy5e`tJsPpYE_RfMqUx`09_5rLk=J8B^G*Ej6c{`%U#6FVW59i(81NZj1%CfFcTXazg0?Lo}Uf3)I~~gKP!g_Z;fOmeAF94W_Kw;qjpeZ z>boGbF`LXuvQ%$($pmPIyP5m^n`D~je-CFACex0aw5>}#+E3?>1F!!M{8Il+zcf_> zYT8d-%->Br_H<@CGT#y0>Ey9mU~D$ed{GpM`KRQWm0WrRkF|(A#veS^;)}Z1CbL(U zc&zo;2Ar<{$?h2~{Sb0gF``~?M8V2?f zbP_J}s-_)9PV;BMGEn@iKZC7#SMMvxgP_E>t2&}F`xBTOIwLQm+ zM^mU5x{k1ex1j~dG&6>|`eB{&y?YgFbi3#27D%TYX0tG6RZs9IYuaX>aL@8_dr$3 z)qDsIN~D2qEC3L;pc|-KiK0l=N~&KJ4n`;?sm7_A%1=SUTZwqKi7kxm>lV(UWjYAsYa!`S* zmf2w)Of?2Sm2b0l2MdN%pl*N9ibKSp*-woM1UCBXP>U$7u?DE|kLR`a+%GITx%1?_ zZmcb_#6}#NI$==g>j?+uKsc29Cj8blDP5#X{b)1Yfq73ClG?%tw9U&rH;Fj#6;9>Z zU7GnZ#9(}iBuz?Xd87y|LmtEK*^QgD6W=9#Ko(MP@yL3h(z%3*#?r0229rnFjS1aJ z&Fq7(sbwq9 zTkW|YnRK3Yer6jLF?LHs==>tTThHOQRy?_hCkR#ZQJmJ5kLa%; zmulWYGDU1)&9Tj33|?Y{%^%p#75jA?xoH1m8LVDHWa%)53Rx;YpMy>hwD~y<$ny zYY%8+BqTMQ9^KF1HHoZ+ko_uPOzpP-l_Tg-L*Uhmkelqf6Ea@40%iQ1)Um)v{jeC5 z6Seq?f}PRNnr|FLvb&qF;RGWUTCEypy&8T(Hz-bUHfE%NmsSKpQGRN(Iu|v$P^2OD z0_bCzWMR1lFre?^Q)$%XvOM|KW^2@Vpo-0+yj#t-LVkHDu28Pf)|jy#>MfKV+>ogq zI=#31YecF<)?f>=)J!A7SLP(lz z)G?W}SRf{}7IFd_c-PRXHc7)*&0-~FKN}_c*)`Z{p2{;c(Q$x@&Jyztf_icUfkE|0 zEw2k+@=^`C3Q=&XVJr%mK{FT&*%bsBMxHQWcx#Q6cx&nom@kYjQGe)1K|B8L`#z&l7_+I-~9iG*gsPE0obTtx)&>Ln{=hvvQ{D!H;MSFlq$_LpTD7Zc;N# ze2I5+49TUe&jWFC?9mH+AHn_gsC^@hAk%*6t{W8J2&^PJ`f<%U^<)YO5MdgtJZc^_#EPMxJw z%VY7cF$ca0@sxYO;)M|>VKpEs=u!jfVpu+cT?4txzz(NL^SSrip;b}_DzO7heKFaHORVGY`v z266byM5d?G*|`8O&Q45g#!6Zmw%x;<&QyBnp>9k2zEfV_vE6Fe?N6$`_R~JRi!es& z)U`4np6M3S-idk}H$$!xW)z5BVh}nSQy+ketPWeCbA7DJaD7p}n#Nc>eNZm}7oAdGQI4xZp2 z$18dE9QMNN4E($X_d4p<&`KyQzrZ!yhFKM(03ViYohNFc&uqP$7^(IOd=l^w-wwOW z@C(s*HKxMfnt;EGooN1=ToKMGt+PvveuY`=pP4&x#4}FQf8o(ny=gCl6_Sr+@;Ua` zFrT?>i`aj&Ayc`*Z5ffKr>~;C3?XscYQqVBl=6p=fFB6`W)3>0)L{r@bT85`%tuK|WJwX&>87>-d-XjH$eRlG;w_k_F9)Mkz9Ch>=?J(+ z;)ap#&_%zZVCmQ?LoAodQLkZ<7MF&A2x~aBS8%;L^$H>%pghm2y+9!={o{Xg7@^P= z5DN4;N6ir^^<6x=t#}Zn&Q6ZRXX$hYk7b{LmQ!&>VUh_CAdiH5HqDJ_{lrY_;P~a zx{rL(CGuSX5{d{|-SAJ&)+S9XM${9Yo94J)c>W^4Q!z6CMW!6x@Kxs|B-l)ieW;X^}d|^diQCca}1fhHK1g9MFMo z40QTCAp@-n40J9TVhyxKesp1=5<(aUh0o-8RJ{Yg!2%0L1of9?8lPS_!Da|NHm#tP z@I(5*9jJL$3SY$sO4J@-eZe(tT?P$v9T=ND%?1-L%>zeQGnzk6>yw>Q$|zhZihHI;Nd#UEEZS0~FI zc>fy7vd$PE(9RL{0VT}PAxZm!S*BKNGAV`|8G)#MP1zz!aW`sx1=V#}O$`mOi6ht| zPZs|2Wtcd&dv4yFJ&R?ET19T<4KM$C9`HO=la^U@XUH-)as428wL`GOTj~gqTH%qP zBaPPjK80hg>H=@*f`?$P*x92&9+Nns-%ZRB8B9fhz(~EU1KamzM2=YL{Q%?Zi({1|HabmvpUm*#60ZHI!$pXhS4g4*;1Ji<@ z{GTFvzU?$6q=zYAnah4F7iHkHXAGyQu&Qh`b=YL2QS3dk_fL+-ou zPHliwiNIG?;opda(98#5=wDNjY^zAF;kM8Lhb?zCXH#z@6sq$a#tG~N{m>QrqyHhr zYEoQ}?GV@#dN{BOouK1YG3dPtn<@`$Er@ZH7{jNC zkIKkQZhg}_KD0nHMienkFMIp5~2Q-DUpK_Ch-U zu=Nl#?nVzW?jV_5i#?a!>SjIpCfRsTGs!0M!DfL=CyZ+k~ zFcDc)#fV)_lMkt%=1p4-SPcDHK77~n0ToVyUxJ`4SCjYL(*f49Sk5)S7s)wxP=o?6 zlyk_$jNYLTG1tF2SHBuMVwE#zK3Y_Q(l#DJM=cS6os5HCE&nh=Q>v~=_9?4Ko>Nxf zMWXk^_D~zCNKPrst4LOsVLy(x$|QE_+m-qw_*dbND?`t4;M8Yz%}lLB)#O^O>yOI? zy7ca5Uj=ecRZ1iF3jRu=tG4|Q6}H*yE!( zRwln|dpzux1K8t_;ZcL+@LJvDk7+;Foqqcs>4oA@ht#3c^ZTg-m`I*5KpX^o=UPz} zJ@&7J@@>LzB&(lqpxqz^_OY~(mn0hjZsH}>ho@*&0BZCAkgM2^`gl-h&tTl3D|Wvi zm`y~MvOrJ02%}*nfJ1A9I+Un}ZL~jIRkw3M$nPRoE)t~`wVNxLjplflF<-{Jiq~eW z+=2tfyQ2dY)orPw_a%tDhS|Q-^>wu<7^LK>7HQBm&r>xfC)B=->ThPYfIQq};azbi zH*|@Vq%Hd~5b!D(Hs7#-wL1K;LAq3Z`grhpdiVkp-wh?|{r*T2HX^aI6EEf%$`|mW zKu}*hho!L@n`Q8ye87xQ%@J%Z5p*>2di*AVf4)hIfW3MzH^WEL&`F^>V1|B!2Ocv~ z94E7(0w9a><334`Af9lb+=g5H<2k(>|1kSB?fZ82$#`yITcB9}c&%8*GY7rifo~@3 zkOTFoGFoS?fy@pv3zJEEI&-LH-6f8$E4@>q6-`*k(YyeeMvzUw77_I6f~u+gbhpeX z7RqsfxZ=v>Z>3l=zU-e2*fkX+K6iZXvtEflD!m(H6LF#GWI#Q`JMNQ8l*U@|^hEEZ zilz=^8VBOWL@X+q=v`W>GmW1kDY2Qxbv$>LUTQLpmyvjk=1x;Nl811IRb~#dlN;TM{tuCHeCaeTL4z~ADIcdZ4ocQ!9J=~c3Cl&sp{q}o;%1j2tE*%>G10#o z`Gqjl^3o<~mW}ls)mj#kOHg;=5>$7gpl7%QG?($WWzj5VA~4Jt5E8=_6PU4*D!D@a z&mQ7{!nBEp$%>UPtq5WzJ_hNEhquESt-ac;MSJagmTCt^uO!PTkzY7-wW*u~={S&d zJ#1l#kVanv)qx9B@0S{nW?pF&jatjLKHd?-o<8e&4&t`BKK@ZBo~SqU;f4bpAc@W@ z&L-TbplN3Z(7lr>2-vldm+2zWJ6T6R0PklORTkiT0iiOdSSDaCmWG-}@>Lt(*L!yM zuadZs0VGBZTx$~-{B*T#g1|;?py(MnzxBI15u@kCswXIxo|uAGm}<}+=(qc7&@mX3 zk?MsZOf`8%8r9kjqPrGpBK4p2n(e5>NCtj{dsN+Ngc9@d0v-at&L40VQ|nDIhyzS& zEDJZ+^`ZLgM(=7!rY-~yii5(aEqlu#8GiYoMA zI&2JkhDsy#QMacEPiDi)0!>}u zFkY2fv6_;LJZvV`&UebcuwUwRm00^y$|zC7D1m<>SC>X%An@Zzaq@S!65$uH>&mi8K`Q!0DVC? z>fp>m0BJgeau z7;iSlgZ4?C2sJ^q@=tVC^n3oPIFZE%h6?{g$qPt((@J-Rx*Yzv{VrhM3*T0|L!B?~ zS(w5H0HZuLjf29nuRmZA!R{hXGe^$IPA_=O?pq+Q)uM=OcX#x#SV}fl6nmiEJyOyG zg(8M35j^MumrP6qg#-|ykP#WzqUzlzNFne{l@h!EMx1MZTrH4U7GB+7sFc^otsw(U z4*=%{05^gK>YlGvN9xZ2m!VJ@`gGkH&?Ok@RX`EC1Uw}`a;s8oqT94Qf}-FweC7%p zhaPunFR5zg;f+9WhK-w67OlX$xh2T<>`!$RI&J@TsK<={oLhfMzJFt%H=PE})kt{N zl#N(4^y8!j>EqmbTL$ZTK0=CFnU z_iO$IhH=y05c;9|tk~a7v9GSaHx=fY;~yv1*RoK^#phhkG6a>&)~_SpoO;`H_W16?vk6S{Z?M5}}@{rM?X`=wFjUJb*t;SK^^yk!=^ZU3DbVVn1EI6b@h z2?h=5Zxtv2v;AxFRl1j^?)%)hy>m67rsdp(wo0$`*}RK=s}JM=3z~5ohri4K;ND6x zvrV&_d6XUW@rKxf^@8fx!;Kjke`|DGT|7uK5ejSd#c5#y1?07<#n5Q7LF8rFu>4EN zYYJ}kAg|HdU&g58ppE|!o?(O4amW8yXPTe$fCk==`E$MIT3@W+x_z-?28s!htwK&7`ur58}a#>EDe zUO)wTd^JYMZwe~?d!;If%40hW4Twv83j##+#*@AIlW{7=!a`ot@zi$~G-?>R{plY9!x(YYYddI*w|XfEBNH!9|@kZ96~p+~E4 zs?d4|^`?p;QgBQNt`;!n!KpL<_v`ThhQ(2J0{XJ^eg|d%n)Vow)4K<0GvLoKuJ`W% zuIC0`EDPWFG`FTjNya3M{Yjlb=5}(uj`RyohqN;F&w4vKc_jr!& z5qhIuK?Cv!ymy-4mmUK=Hpx$mhxEbp?lE4*v##lopKYv!`xA5i`y>sIADsFbQ*&LK zq=p7h8L_ zn69kmv5&EI!li`1}oqCOdpAV zdrd!@tKjg_3y2Q85a1iNQ;`gOJ?%wUSwSw7y@H$-Y}l{~!;1C|IPKl=dHY%%^QP~K zfBV+2+54#8-)Y$nk^Q+c~Yhv zvDWbi2SdV6f#k#!!6h{UQK6mD^d6>!|> z<=4zP8D50D0AqQ$pP%L)xqamv!SmeJw>#g8rngW?OYm= zhA}mYH~s1a#z??mk&WzBZ%?)`@OYF@A`D{fe`hZ<_F(H}OuVdRlDOU7`>Cq%9Pj(%2z=(Vr{4m%cw@mi@qh!JuC-|*=N`2_X!8!*sCd}xto{=l=$ z_m=nb@-O!pAh0Jc@`Kut-~Bz_GGRFCPLPoO&6WFuu#k(y^T;{W>sN#{;c58CNz#!1 zQOe|u&S+@-hl0VPv7tlSBH$$ooOl`6NP|^^yZ+ zYe5-(YhdjtSG=D31N|wc_4yGywf+-W{@%zAVEI}8lDnK{n5JyQp1rFC!vK=;KoxQq3G)H{^ zK6Hg>CfJkr><(;X`g!0&AN|?U5F(?TuAj(&t9kWqLDwiW;Tw8W0K9KknCGeku*2*( zVlMGOZ2_Biv+1O6ks0XB;T9f1sQ+}L)vs%`mJHeLzLMQEZQ41YYuJmhZQ^dyaZ@)< zn|AIg*ynfM!*>qZ?H;~7xa+1(I~^x6TXU+Q{)gbyAg8%EQkPIz!lMXFYg&S^v_Fhs zm%J2@umqEV-wSMpChzC}P3}_h_qs$IgxmgFXVc43W53fiUR`KjQP)k?!glzL7clz} z${4cz#~tDkvTI-^&eA-5gcnqct**+|ad>nA?Hu2KpGkrz=gFt>{K6-H$N+mL2@cnj zBwG4~cgtM_O?9x@^Rz^u;^RyL+&dF{n5=8SM+mCQ0Y!e`70uC&zzpo0CqbuaS1-qZ zix*bS;00z*xF?aVdEGQ5D|bq}SKh-W{nH1a6>n8#w7SV&h7+EShZpiLdgf)G3(QqB zI0!%shb!(8|lKu55$1~Giu^bMVWRMY*TmrdufPvy>7e*7>^*(5+?b`;M5JX7>xRtVZ?-abnm1!m zgq0ryJuUaLb@=c?;%QveucyRNM?(a{hsXH7;lp^`Y5FbxB|GrNF+_HLy9*Rz4>v0+ir7J=AA-SHN=P? zrHIq6A6jte4?W|H1HnILGb}xFWTDp1>-_c{(mBoPAcI3|DN0<5=c2jP=|gfc)H$nX&HG9~ujCf}sIy|-% zj@he*-n{Aff53gG=`I2RVUnOHfule4z8zu0&>0#GsStU9+$!~txt&w$3@U@l6VlJ3 z3@YasI)uvpf`3>MB}=ntPU)ZLddHzWJFP$XB?&zj&|#!hq~0*x!X}*HmI$f`IB*E{ z{iE=P{bl^1lW2;r2)vKxs>#NK0IPbaWEztCq$1#Z{k}RSWfE-+A@v)0kM6YXKXqMg zcux#w4d%O!w5DfVB9+ec1EewyFlb62d3c%*C-JIC)V|!}M{fFz@@7dOP~^UI{%sLI zV7ekR&#}yOmbS#vD+U>ulF(j6CZ*_q)X&{ClOb-+{`NQiQw(%{`{FXaWB$)}l3KVr zp%!MHqxPHqZ&Uk}!Ce%3g)ml+v&FOek&)Xv@%DaS_a=EdRFh-b4D+ERFt~-PV}O)l zK2_=7>PK5n2@fZnlI9^kaim#{k8^*F3isLC9 zl3=`JCUf2o^zc!;I1_F@$Nq!P(u!OpPEPX@vl$_MtNwz=`p}istN6ihiZ>rEPDVp; zmd+FBzODfq?87RSSM-uJIS;A|(=v9yD$Xb|2>%;&JDFCuWcYUE=@*uLO2N|;21fOW z_iwA&c@wmFX;h~Kn9_JAj!z3-zB84d_`e$iIq24mNvryZYs~>Da9(HT603s`Y?o0VKZN`B9Dh!-`{(}^+2IKF=v^H<< zGC8!i@!&6(iwG7-4Y166#K!5P@m*wA#iiM*KCehP1LF`4SnGfvpnT9tjyfwe%&OzK zq6#z6)hjCfNcA54+L9Si8{0(mU@VHNb~hx}Qi6=>Na0Bx>2_k~6-K57l?#pdqZ-xq z@_NCisY%Q<;R_I_ZRO&uYVu3K0aE*4RM|#w>Tg*YYZkxm?UG-$lAHF?0&1X}4NdW#8S770;+ zriDNTA0;xx%1)tmCp4m2wgY5i)4ZYHfeUUEmgO1eiU(Sf^`k!^Bro#bNvN;}CK z?Id5Geu^m#8z=cHMw*Z`out9t`pF!0sE)u4zpgIX(zoR^T;)-@)>UTId9|x-8yhl1 zag}fcQsnaaFTf0ht1Elu9bY>_bg$%>+g?AE%FAdJ- z$1hTU#y=3h`i+QxTp&ajv3y)QfKzR|*54;jO6!1p4YsX&!e+d03)uD3XlM=@Qr#=fkRQ}*QDI8X;@FTfldba zzQu}0Ih8KSug(?0OGb)=X& zLw|cQys`GTq+9%Lf2a9P5yt%DIIg)~XP2u<5XXtv>)_44aGLIxXQpg}N3$+hq~Sdx zB811r+Mt=&uvJogc9zS1TKbP1d)L3=a{G-;t1M!7!XR#4>SB`NPX?YZh}V4{IPR9$ zZN-D)b?e}D8&|0RdQH6U{&IjIcwfA(z7MmTidRt)F}|JGJ@xx(^kozjCs;b(*opcM z9WRn$yMvaNj7;rz#-j5TmHMmT{UbTh_vRqXT0Vu`?~6!Lq~Fyef_|OEy}W9e8jO3L z#KjOL>_72qvH!7r&h;y?8$W%k3=+^F%g5N_P_>~8G15seA+qpctZjTMNQ1TPf;1Qz z1JmHn9v)jB3F-lp0uK)tuUw3NtcR!27)iCv;NegEl3!kDGTeoSe`i#-d0P)}W;K(> z$$wtgvyqne z&(c}*y9koUpkZn-{(-fwY87imkTfnsba*%8DlWO)Q zanhzB%F z-~D8_0_HKD1Lo$6AYdA+dZx2L)Y7$xnXjOzl083u6un)>_crM`8W}7f7DuJWeQ{vP z&-u;ZHM;6Mj??NOCOR2cpr!&WXR66iE}Ri78~2!YCtYy%@N^v@yzr=ZkP19eYDEmoth!o+>k${N-Q zO1E267uP65N?Co#I>Cza?qn$+NHTu$?JGr)7|S#Xw%+Y>NUmqTV~Ye;X(K<%4a5g9 z?Jq-iabPblTjSOF3ZjP2h3C#?ODxHpeKT`meghX`cz3>t0V!%o3`kMC7lR$kEj~67 z19stQ)H!e#I_k=oph`>OQS`i9R{r%r47J^jcN4w@Vi^Rra5*DY>RMbwoE?pyO`qn% zXH0;hX)EV~Q!gVK_Lk9Jusnu288gzFO8<1^#55STR>0gT!>UF0{nCzYND$*zoE@(zv+>Yll8oB;5+>~y; zxr+t7u2}g~0plH}VduQX=NHL6J?iyz6Q+uAXn*82XwBIs~#}W;OD=^P_(+cL zOjOq&xH|WKScDyW1>>pI9k`0my`T3PNns)+jzxx4mq;sVKQPXGOqeE^*N$4uhgW;dUkBc&os8TVQyibw1P3FKEau~{dw5+ z(KzdFK3&$IKF!I??#5S%`DSV}PSnhx6n+PynJd_Ot=dKwi{+$8wzZZ1SXl8EXU@~~ z5L{K7)T7_zz_%dGfb@83JjAh42Q{F#mzOX zVUm)J5k$XFdN9ldW!c(n4Kql2+5pfieDudX+ol~sgp@dEbYPoy1c7+>xo>@)3F(ad zyX)@${9R3`xVvw|*ls;ufiRQFhh1T6Js$Iq2PN8}kc#}H6Jr=zmKndwG(GVuZQk$1~|9V?Oy5W1-gjjzUXvhxH zka<56LZX4o%c>$x!Fyk8rHqv^&V1{nz||QodDf12WU-gJ?^$@dVmwGsmzBTh@5^t7 z(lIYY{ixdJ!wHk+&h)IhecSZvOziwdXrgQX`z#l0HDR?~X1S+G7NE5(ZiE>g zXjx{K`}R@Y2`8N8eo-Tm+3hU%lu?05y2)}~o2;tumjsTm{vw!n(a(k72yr2P@5ZPi zSN+{U0>6>Y&gn9pg;JA2qUM@I>gV{-Lh1vX;AZK^cyJc+4?1}jSEBPD;Dz;oSfEFRI)GR&Nw*dm!O8+^Z|UC!*i@qO~!ETt>O%w7^|!U2H# zp`eA)5XyEjdUXrIHkgKfsiavA;=B6R9~s}(4~#sIgU|rrW`z7M+NT?M#^YrHREItT zHs1}Q^q6n_g0ku2ePHyj2B8YZt`QWuBo5_iqzcRUfJwql5%gqmJX{2A(@mr$v-jt( z#|t|$cm!X=>l4*)+9X;R$$>Y8=>=eV(F*mWlTe~rd@7xH!LQm84Lz#sEml0F^DexA#+|Cy zJ9CEcaa}W$6fHUMbqk1j*GKYr#>@gGuo1hq2gogvHW~w+=INwQO98v!$$c#e8Q*y= z8Y_*Xmc);Pan%1>l8usn8KZvfDUsyq`mjnLVse078%3_VY3HCe2r@=cyG_w=GN{#u z3xRrGcu^Dz99- zPk^NRQ~m`Adk#m^&1q`8#a(^_|AD;0vO-btNwW~f0IDduR-D~fWuyOy=AL;4f{9T zlyAU7?{eCIkM*-tk3(U_y?otbT;L1XgGa}A^u=2W9V_^j^spdvh2Gj{#|2|=q~toZkV+_@eh3dzu;ef zPyFlG761BY@NbVl?I!<5J=rt=^nRC|st?|0TnpS#_7R!$bz}MLeCRdCkpp7!jy0%mu{&N!ZP?p}@xQUTsU?AW7W1T<|i?qS(t2^343d98J9or_UrYfEsp zkZ1nD{o9v8{&Vfv#%p|O+DIKI%|Mv*Ur3#_q*)@ za8o~|(!KIHnFgr+8t&dLsQteIYF|RVQJ|`NeR%N+@Vm8peSKNSBa{)YLbyc!5@kFp z1s8=c{@hx!g7dvx{@#qwM?n@X!YTZoznm4j8|31Y;&Nx{ql>`wSOOpG`xlLd0lU!AV>S}4MaM41zHc-EQCBsj6=DIl9u&qtbwD>`!$+^i3M z^%6+&NAXK8_tKZK2f+tuN%WT3TQA~58ZT!yK_%8aPLiN+gX;%^^!xAwq}La=wEPdA zgRaCR0!5K7l&rw2N9;cHK3=8!$1!{f>^QuyZ8nU_!+goH(~;%E2)GPt)eOo4|Dn_| zqtTptg||$S;DKCah8EIlCY6I36Uy5?hK!hkN_6oL$_*h3#;5B5aIA6 z81Gn47~WF_-Olu0J%q53ctfYh)3RK7+-s?3Z{A$#)N8Hcuh7^S3x(COL-nIkWacQD zTxDJ*1P)cgo^r4!M$c3wTBU!gx0izUJc!LEp;__C><3ko9?uf1T5IpkYZ~?jTH3y` zB1svh%w9^qk#etv8i+R3NjS|~K|N#YSmjyNLG?8jzJ|GGx&xH;%0H7|X{a=2+q2gi z?+g`>MRU|m1~eJkS3tM_kpP7y8erB>%BtLDp62KGS{YtSNKc?PUl>Z%qS|V7j@I*1 z!ui;`#z@vl=sKfG(ZM1^j8I|XN~Ux*F^famaWRIru^VM*i+4UOsBh9UJ5#eq8XLQU z@ebHv7AwB_XE;T^Z3$GV=l!6ZTl>)WciLa93PwYp$0gfyz5<)M#yfGZob{DM6-x+b5xyel?6Lep#(pTm}40Ym&v?Bw=UAcU$8+}lX4S+xrPV&e0Qn@;_I+`S2WRMizfP6E-egcmAkRM1hQ zja4*JB1BOV4f>)J4VBuUSmTb?S~Q77MVL4f$v6y4r3#7~t5s@ki&c?UTN9uJv{i6L zu^N}wH;oHw#Q-h&f4}G4_vXzc0c!jI{TDu(ci)@4oO|xs?}q7LE4&)7P}c)WVEh+a zw^F(yRbtIKohe=;tOmqeNaz7gA*9R!O~H(I)HHJiwmQ`J*v|=uh1-^WHZ_;GpL6kf zq`toPbKWGsG72-v?C3^sv7@_l1K80YUFh}PqH94Zy`Eddx#OPa7ENGwoLe*&Pie)s zHv9yEJy@9n`-hu%1^Zh0m9YQR9M|W<4t$nfKLvl!FSG7!gE>|=SP`4}8RQPWUwr)u z_#WYsOFSmB@H3l1V1 z7TN)}8IPCH4sgx!NQn6^hCRb%TUUqbuf@Hu_(6Q9l2tQTQFR9FsBjzGfX=5l`-iD<`KmtK;&!ls0%cW^Y2*~I2%qG1jLLQeoV3gbU%@ zsB^(PQs+3-)A?vLfwRDQas-sFtS z>*!Kz(b_~K(nVW4U&jAWIE#NtzDRbay%kmwRo>|Dq5YK3oQf0ir&JLC=u9g+b7t?I zA-b0zp6pC}D|rBQ=3qZMcro%A$n5^z%J<1iZ`Gu?zu@fH zX&O>xy+cE|xdp=<_%8qB!YAM+OFig$>drZy9 z#zs}p<4jJN-!FD<^sWYg6B{wqCMxfrh8HZ@Z@Ntg=4rm7nv4LenU2%jW?W?-*~YdS z>?2n}q19o7+Wcnbir%HRVG#YwSQpFr1D5*R@w-B-aD6={Q06dcW+8+psz7no>IR94 zGB}@u1lT&?ENbn1#2Ngknk?j*It*gxVf;PWC*(|A1lo5l`Gsb@RRBQ_;PO^N6U!Pa zP~0w1wARZ3azOj7eSrd-3dNCw9B{L=hvDpem0xRoe%^sVPb}xH)7eGw^G1Q5I!`|s zXpmEgLiinsBc*tKjORQr8Ay)-)0LXemz@ERg8t_3mi~@GcpOJLv1XEB14Ui~r~8_v zskvrjw1fwEL{E!kT(FF27*!~cE~gR3D~BG*CUi^nJfNuBW{4<6uHtu|4>PwKDQm^? zkU^uZrqS|pa|R3(ydA7>nff*iZ^HgX-DN9LJPomi&|l) zA&Q9&RYmLJfa07PY(tdo>_?Y2*X0*0?m=laq%d$At~4n}#$(ExC+CkYZ=RZeY>y)JufXv~bLEOo{BBEE0PbkEKXbSWdWeYQ2{O#H$FV2?uoj)FqV2<-@1O*&y)N0)wPe&N8K&|+2-y%SH9;jU!8 zu$0@V&=ZQ-Bg+SBVhmn^<%t8=VerailPbOt+tv!A+gd?D*Lt^k1j}craE&Z@B)Bi|eDME2DvHwJH_e6Qi$`Mc*!qens#xWePk_jIISA zAve$|hkSbd@$7^}$+R4 zb_{a$v?Z^rtfn=n8rMNUY`avn(+dAYv5*0|u(OG}+-D2CCWw3AC=!+|*;#uTnv&eK zvEtJ+`3(+rT?S;y&Shye+@UqppDgVn=Ml-$hq|S|<(B>hOD8Tu8E5i?)CRaXauVL~ zI8z>-55d4_apA{j-JGRInPJPyVswV0@qXBwx=s6Tq*9pBJ@~BiUGVpzRwRH7g16!X zllXX;6&b9l!|VT+=%>kVTeoe+5)AzO9V_y&rjE8E?`vvw{j*ZXapeQoA~89?c;dhf zve*L!E|_sH{+=@982ml4et(nE&81e?&$XUYtR|jvl8EW+gu0herqqhutnU|CO_TWZ zHTqgJV}Ja7p%s~G-mNCCxK32+>&;f=G)>L4A|;x-#cCosB)+4s6J}h58jhY(jK7D~ z5BEX8YGQOl!qQwv*XIb7+Oy8Tnde_o=*0Sc6?(l&a(1@iw+Z#Hcedks;f$g9 zdqLeZOxLgKd;-s#>wbm5x70t``SaTEoDLCqU>Rg!{Rq9Ljw1Rv%Ju1qGq7_6}cW@|ZvK@BEo@ z)b92zzRb`GDVgVbnZeoqT59owv$TZ(mNze64mH{y;$%Pu{!QeZLku-tq2K7?Bh0;4 zLiW%F!Td4sQFGTy0cPTS0hL5B|7iSB;g({#&213%LAE^rQcxZW9kt^s-(GjP{RBQY8cIFGi#vUBg4=~pCm~T6DfpA7+p#Ir?AUcR zX$_+(M9x3>Oj~E<97l?{4npE@5c~wj*Se_>bxlE?UVZLXC)StY+~KP)D=`{iq}75Y zLRQnC1syU9vul$hV9om%n)OBjhhPXMaYUFom@M{qh$Vq{jDW0j@PJQ{w9(T%lWGO^ICKPdxcrE8|d&X-6M62`Oz1ji-3w1Zxpr`tNr!Q+x8-@v^-a1g72g_Nrz zes(t{zjKd17RiHogm81gHdur8&OPWz35Ly!K&Q#Gwc4Ko%CkVqe0LrM2j>57$%U?`VGu z+1~>8w}2*WHQgt7naMazV@S>GajG|xt|;$_MkO zG)o<*ib$jFb^ak6o8@I~h^O>0$X6r%)5~l4DrnHxB)WFoqxBPAau~^R?a`BMT{~LY`+V%Baz}aG`PU@ z9FIqOjE6y?I|Nhr0K8@Qe?#zCHxLh^{OR3EEXzFVxX#<~OG;lBE=FI*`})!geZ8vo z0iqCYypQ|qL+B+*>@og|k*e`X%!*vjZq5cUa>G)qYoUnj>-~=LlcULkSeb;|$Oh18Ber1g6}? z2P7mWU<6?FHKRdc7!8(%TgP@j*6ZiQv|bB1m*9>}YjE_%@OvGhZMYi4Jy4zJW<)>t zh0@!A|9*)!d=9_Y71}1D^fp@Qvd{yoEV$5vh%(!kXcqux*h`#C#i7%{VqJc~dBD&Z zEe_lTAYF5Nl{)Zq_ePCL7SqlOmuY8v_A|8Y2<+oWsnE8<>#fkXk{Kpw{y8*cXd5H% z+tMTNugg!2yl+d7ygws9d6Di9Rc&x_lr$Y*HXA1&&?NlGvdO+ehtoVdgx5kk+<&olpL95iTsi%BlnsPrZ1j~VX08CSoT?8As0(RJ zp_{R?K$SXHlhK?HmaLx@x3Rqx*Yj9m8b)Q%e1$l_E`ZBC8CD=HP7FR38=+N%TQZ=g zNbBg@y4p)6U<+qFlM`tB`$A!GGN48|C2=w8={eW6IXTzm#jx5<42vJgot-O+Hh2Ek zxp^T6KdmRuCi_lv6k1`CgQcPg$-E+naoC@cE{ZUBqWVkheBO zt)D?d-~^P5eA8sK=e}OYj0xo?MuL@JAD(EvqKNv@}BNCM|!@4JRWVN%j^vUfg$h-_Qv5qNfSX; ziH{KcO2eab&;m%ECHTRUIBD`m4(?5nH&{0{=)B~*DOjmcOuJh*<*v_r@t>Y(up)n= zEaL(qi~)`XA}vnGybB`BkXF+nY%ujg(t@}GJAY}#4?+PeJdDL4y{c(V99$Oaf~1-% zXt5%dd}22WD-cQ&=pd;euISaGJ`gR~D;P(+x^>{{J3N@`4oDSO#nIK#b-3j~G<+&! zN$psYIu0!wfmKHF6$|6IEDNaz~^7GnB@)6Q<8>OYclJ$^q0ObAp@utz* z!+jM5+zN6r`Ezh)XvZ%Q9+%zw&Vjd!sN9^GLs7Xo5fV|kzVkt@S-KB@5}ZPC{uyO9 z2&Zc&iEui>!#ai23Di`59TO!^CQgVeGI*u-5-+sMlf0xyv5!^GrjcjbtF!KQNYy9w zgtRnyTE_YE@W&X)Yhbp+enUhx>)9#+`FMg{EffflkKYx@t~{NU3<~04>TH##r5Gj1 zQwY)`nnI=I8r-7;f3KK1#5#%&0hu${$4Lo|xkAh$3{i)WL*AjjS>I3gR)(pD_L1o* z%*a11-)I0}e*U&A!#j?b*75I^9~7VEaNkg`^s4~h4T)pUt|&a`eDqn|O( z&taT-TKxA#sPm+JOn8S+rJ!Fi=77?zYvEtM3DY$E_t|FIp;KkXS|3!Gv7v!#@HD<*hh3v_2X10E9Nnw6}bqdf%-Aw zE?hn`3@&fD3)j*#LDF&ARt=uvuDz|uiIT{+BD}iyWF8Y~&HEevp4^SJHD8u&1GyN% zA)Mv-qOnp@f48E} zr@Y@NpuXoMqDiPhF#Qq}!C)zQ8k|4*@&IA|5{F10L%*!&66XOoPvVmFA1`(y-j7_!d-*Yir?U5csb+} zI)B|)I3G3}BqV+=#iv^H??OMrT?fvt2zTYweH$rk#{CM?C@5e0scybG1n_YQw6CQO(${XsePOtMK zC&w%HV)~C~J6q?&0)5bV(EIT+{MeHqol_%} z*wL@UfA4^C+*&^@{L#VDo#1kzrx9?4qdVPI5mxx`7JdPr_Dk%5xyn*qD7A&9_LfrQ zuf)6ft%wHo>qs~qVO5;2Sos5L7O@iA32Ww`;Ns`-e?RQ5v6^P104l@;dcCHm!bH1T zlQ1x6AtUVg{03P~z%?C3C{`D=qqG-f)MiL+unU(4j*-+;fOGarsNBEL-boNp|$&3;#LY7k&o5@YBwZZ&if* zn0cymcaxzi^dA#p^vwxof)~y9M1pga)Y0>YzAgAOch*3A}w+iiMAH1$0`ynj#VUDoPJ|_;ye^`hBgwxMcoM- zZ+Mi+qw~R{?#}!1%0=ohk$#DO6vGw9JebY#kH&6{JRnWhb2HVtWMfhs;9)XQa#mk zyn23du55&X^)s15PqVK|X-D+fZ&uCqu($Q&Z|E1I9=K2_U`0NKJP2)vDEJ-(i+CXP z5H{f}dv342)tyK=0i;n49$d{G&13eb^l1eRgz7Dx4PLVP`h-(Ao4CVZqq?WTg>Ix< zol8-}L>?0hFT@LE z;{K^Ct+WW0I*NcxBFQ4Pm$=zO_1EB(DR9Z!+Ozo$T;f}5rB!5_D(X+vYfjhJ9+oVA zuv^>$LiW!b4}YOGu>sudblxH?(keI0LI^yAkBBEfjQ@WI#ZZk}{rF7$62J4q=)?me z4A^ZMJULumyRE{(bX$c(dbhR6V6DOv4pM}|L9>f+&~8IGq<34ZSSP}v`+W)rEzTuo zf@Bd6TAWMF1Zx^px`V>u^O@4~t%)W|g{_HM@_=yI3gNI-gabM{R*4&n!J9EM;niFo ziM^Gi9!X#^%WkM=;0H>!yDpkgZS9oxg7sL2ANq4@^G?mfp~ckx*t)o zH2GpdQl!S;AsTm{`c30ue|*nFr4@Nd1ds9ZiBgDJdadBk8rm4X@RgGV=qL)XHU`V( z`~{tV%+jB-`O|UkPbOr%R%gGxu$x5Y*#g3BPz}67Y=#wnjgkufAbh^@`+@}^)AqtA zPeeY1A;j|eAF59FR_%z+(2y`I1jqqrNXYA99S%oF@4S$3O0zSgARR8{44qaf@Zk~l zXUgxO>NcRnJN8I1Khd6<1_?)H{vT9 zYrhokbj#c=WuU?7?kjhq%)S0Hq52z@L-7MQSW0CnT22c@<4|^RscVs#noT z?hmZ!7i9N@g->Kj&erqU4TVlVy_bI$^UG=Ie{@}9Ix?uy#QT`>flJOwUYv8plnO`{ zq5ALJkfFN?ZeM87OItn9H$E7AR04sK1sHk^4y8Tr(hP3|%9LmW^*_NDIM|6_T45TE z5JdYyEyL($gxg)<<=rMSJ4>8T0_gny&EyEz5d?6Tnb5^5P|%q>p_}Hvj*~;&|11CX zH?`!UwC*`eo73m2V!tL z-*?J-YmGv{4c5N`C69N|?<%3iJqgy|uVp~L|3$F=d{fDP60AQ0Wt?lT7xl6^k%u>! zQ^W9JoIW*JPXza^>C@1k_Uinw7TV^{ZSIt1Qs2aJb0CzE-Zy(C1#siX>u9dwzS&kj zG;o%H)QJ-_Z^JXZ(*cmY~PQg!AZIf0tNTfSy=2X}5rOTovgfk210WmxN|XdF&x%d6d%fnP6Av zYEvGi$`QOpdDLXQcqu=f<(IJi^zylE|2zKjLZ4Dz=u^t$R*O-W*N^I}{6FBYlkEa* zI*(8n*zJ*g2e9#<9e*}|3(|_74LJcueKHwCyC!~YyzXgW8xj`}*25wwKzQ#c$S@&H} zGR8=NUTZY+5jT4SIoHw8dD9odkJkrWLgOtKQC*m;x% zKtK!tLMuo6KA4rnG~WU}VLIA{38Er1mUF2zT_5D&!{Wn2Fkiz*_h^`F%TgNV?nOIh zP|~=DnBq}0&ratE)54@M!U$kEj6}?Je)EwI9nshMAac)hbGyT=2;jJdeR&f*Ffh&` zKf<^Lk>a?y|42#M7>aZ~u))`x%~!dGFmMfpCy$~6{30uq zt0^n?u2&Psthr{+Fwc=?c1*J}BM-0n8_x5=p=Ix|Jcp~F!!w6FUv#d##_8^C5|C5c zw{Gho7SraJ!5Z{F=~}yUfufjfc*HmZhKIJv=AC%XV>o-jZeR6nRsvK*xK4&Q4i!~^ zFZcxu?^$ydMz)gDAAh!mBR%X0ZC z4;`0g0!%o$9T{fwG5UguQ(q42(V6x`3|xPtQt*$O7Av#8#!2?Zj~!M9<=??4m`$Fb zb+#f0B+O;L*j$KqW+aU*lBlUVG9p0!Q1&&3n#vGDNW_`a;oSTXYwb%s#zzeJNgnD% zR84Rr9gHtB{78pt(NiC20EYkwm7;NqS4M4a*_(isq0!;_-5c0GNQpQ`Wz(pUa|z;f zs>T3&(sV2faIbt86YL6oG3T=%EA$v>@(cFx5`Xg``y|h*GJeSo(^0yFI z9Cq}zOVaENUiwK*GIM6aUD8p&Ch!{CDsYb24;4T-bg*#a8jfu8hz2{Bb)Gbt^L;)9 z*C?OoOQq>5mT>m2 z{Y?5R;B8R~dPUBEL%B_%C02Aw>0K^8ZA7D5jMyg_Afs{?bLeYb% za)MNg49+%*W0O3z<7CV|>G)K1eDrX1{AFlmP;Y;$iIZlDN&33?j0$|*%ZhN)?3>ko z5ipRb)9SM8pXvM^DjaUj`8WF(-ZtchU*K;}{e*8;`6^bZb8M$MDe! zUkg>|L8v2QndB~~23(SOjXqFJSep#z*+oc!?`ag>c&rjZfln&zA(a^c0xE;pc0!oO zPF&9R!rS(>=6s}R81YRJPz3Wju`jDjCEDMe(pQInye~?82+M2N9d16x6HX*vh$eJ> z&)CW(b}~VMGaqiJSbFI2etO6pQh9YGto^N~`GWdyLbm6z>jz3lzDe;%a2|8wZHz`5 z=6-X5$L^(7I@;;H9vgAuArP7+8|%*Y(-KMe8%gSsP(X=E0*c{hi05|$)Cf5n_<(#; zaphe1kED3c>}>p>G=B?}RN`d}lfO3S3`m8Z>VuLIvt7>qZ)D(CqgkgXp2U1N6?-el zng5txr%4L6qi&*NCu^msjpSt`xpo|`CkujR@|<7(%BSdA53LOT3{UAuRwCvI(49+N zh~Ly2fx**eM>lY8zJdV7P6gAsavDmv94ySBb&3mY=A#JtcPiy}c{3o32dfw%o+g)V&N> zFt+S0!~7CCR(eoMezX(kF^6B6-SI7=BUR-)*Io?EZ=g*48-qQ?{=MObRNEJwn7I>e zq37r&qD~^Wv}t^U;!2L;IDUpb#8omfyo@~tL2J0GQP&=>J0Iut3 zk?szjkGubGfrndkk_NtWdhhUH4FvP0+&7rS0cko(#_0DVa}*QoP3N-jd!j^;K<1&z zvh;NwOW@bY)?65(^|e5KTSlg!9<(*N2dxi{IcE)gvpN_wGYSn#y%+^l ziPoG6q)NCo?#Z@B;y82s_7zyf{eFKP!;?R~+FDYFqKwB_`GQ@iL+- z`dEGopKu}M32IEG9s** zm8?J}TF}*8=k@HKr{W?QAofqZc-%Gl$czXioyslFyV$fLaW)91D%8V&6jIf`bd8&i zF2XVqwl!A*Ol0#0ymJa?Y%?r1lRg3IyO|H2V^@5Eg>eilG;KdcLT8_`Ed&+>vLr}B z7bI|w1{N;E(E(m%`0BiZ)zw7QI%y>n1}B%u^$aV#HrIqYz=(rlSwq-xD|R0ttT2vY zg;F0TUYl<);X>^-|2JvP^o7k&mJenG8`p4P89=(QW)yHk$~Wc_!V4k+I4V_dAbP~G z!dS^gDl*X{?LNe>b2Rd}{Y?BD^rP$Shaly&P6eIa1B=ecDn3%^t<|HqEV^Ee9}8W9 z-h@0rZ}LRvHW6tqy-je@=%Y6hSsJ~a;-|L_tRP8mSM1d*y=603ytw)56ngvdyd=Gm zmiUkKHrd?m&t&SwG#2bD3A`q2`?n20!qUGH5+uyQtcttACzadq7U>X3Cc0m zPhw$?#)5uPi0+|@rId66%v^C`!8Fx9nWiP`F->)LEbEP}Nv5eH(?G9z;-kedn1^}~ zhs$w<(9G+)1>OvAxS zjPsc046uq5n*yeJ9hS5*O_E>a{=>&OAmNW8|E~dlAr66LaxQoy(kO$4!>46^-%<6K zdV(J!DfdKYQWKFxN4cr>7OtNw#n`fjFweb@Wi82}d8)FYP`f2{i-dmY^n`j{nD;JC z7Q=yib&EsW3$I@u+Fml_mz{Ids&$^NMt8>2GDziu$8A_t3sZ+g%|*}5+IliVlTqxtfG)ErHYYXAOhqUh#gP~e_^QV zJr)XYA5mBJd&oSLUuuj?V;wT51_SXchXUFI=GNj#vpVuosB9V_Kn=1r5{*{W>@KdRu($yR4W}2%bt?&!YHVfNcE7^kPkd?6Q71$5{P9fv_~>oCzYpvq@TNc}~V+ zwT}lK{CIbPvs2G4ORqDf4GoXn)j$y!g zafi-rLMoe(Rfu^(vCUE;I1Nvsx&}$avo5&J^@5VVg3k-OW`TM^0gu_HlS(nin|0J_ zJb4u~M5g;TtBo5MM8^sJQu=1XIcz-*=|zT_mKy35=MJ=}M?t)t$Odsa&F9jLbxAi- zEClB=8w4)f69mOay!V8k zNkwk!Ps@vuQy{)RIr|a>Se&EIg+RUm0g7~aEc)dk!kDsNjnqF)h7k!FTVaR>A}QCo z*Gk5wF2GT)!ol&J-(3m#!3vNeFd8U6B)hODd(T8b5~x(Ttbpy*FjpZ|$hZt=A5=v> zQwsHjqY>I$p(H>-IcHsc5azm^%f5?lOaS_fUU463`VzAJKk84;w>?wH5bhw<;M{rK z7r-}FC-^4!zwB8FZC$Tt&fSyH6RsDRF8r79e{yE8@Sj)oKZO5Ak*4m*IB!+$0{&GZ z#y-XnUjt%*y#gIc=@6xA@e35ZhzJs@+WXM2yT7n$=8J|Ft*9icMY&2_acS8hM-3f*zV~O)GijRA$LQMVfF;0rYFSM zJ~8pni~Y<>4scGd_n5VApCs+xdHF$zpR*4@f&gr*y7kp|chB0o>QZYnO!g3RCXVoG z3wI453hcx%e)840^ddieG&-Dzd#~|)*7&MOLk~Wldgp9C8)JM3Qa=BU^Szh#loe_= z#B;6|l|;_xzzN7bgdl$^06ZcO3Yk#eM;zbJAq{A~^R{$(6_4cCu%{BQ7)6?F{5Zft zf(e<&Crn6rx@r<6Rw}5#AeW7Tp zq$Y8RmP!~xCk6ZYD@oEPB5kG;T)1jfI4UXhS2E7LUfCc6GR-;= z0ahCw+Ce^vNKYv*oQ3c5gBjGuH5_YtV|SlpyfF<VS_6&wCCb~g{OGq9zM z=2h$(=!!7U2|Vviu~^uP7k;e~0Bldt8>IrBk0tpaStNWG;Qavze3$U@2wK1kxpxid z67m%q3WtqH_U`E;&%DXR3_u55Wx-?1&>=d4dJv$y2!l%^>J#YaV)hd=Jy?SQBa#x^ z_(s{z;b>Q!0l0&pXSN&03J&KlX98;OF>;|!(`Ro{tM}NSW+xjPWX->pyd2&(z?wfn z0m!iC|Casa1b5nTd4FXMxF_@w5twd_BV}|WPE_S`2)4z|dhqvu*&FATH03)le27mXeADs#e z_r~RBWH_y`k9)&j3QUrj_}SykxOV=EJ~D^5Wn)=(c-z3vz#3yr1DKHAao zkd(#4r3mLSxBS89`$OH)sxb|B{+bT8g3w4kA{D|~DeS43KER50&gWnh3b8D{3YApn z2GJFsPc@FFR4IE0B~ev~p9=6(fImT!%GzogW3f_Xr0S17D>e#Ejg1{NHLNBPelR!C zInUg<=LXYeBlSAE+9=jwcPnl;l~k-z^m=TeYWXFi^GjCMo@&PjK+AW))*jFwjz%W- zGBh_*m!b~ID|Iks@Q5y@;?c2B6%`WCdiV4+(*+ST#~y4rEtk`eg}T$ z!f~6m#9-5G$ARaI1aDe)t)9saqe#)X3fHJB8eJ<%@E2RI#uB#5Y~?~d*IX&J$2BXh$6rAh7*J@5ped}Im+sA0Bv z@t0?(xR~b~2JpPfX{;EML)^vb=0#l0237!i56KgEyU0`LML7r2O|lv$j831vXzoQ$t)kfrOYA*3MfIKPRjdVPT#G(FO?b>7RY0X@C>#fLrD&3 zHS#`l*UXZ55jKeP!|{eQGRx99LqVc^|N3bkXIw>@6)%1ztk-f=)q%{hUz<8kZ1Wav+TLo5-S1iNDj?2a`!hm`clSWNRBL99O zokZ66MGAd=cPdKAA$q>RIau4*XU5QpFm8^*&UH7KfTz#CDbHV~#?8M;NR1zF;xI-Z zQ@sk~W`hi?(W^8da%D+`Yux-s$d3j97D|tk7g#z{CPkjcPwU261Xg&cWSRU{mmOV5 zI+pVGf~D}@zeR7v)4Edp)-4|$U4SqB7Y>kaPvguNljs;`JQ2uZNn zxQ0k3Aq_Y&jgU~Dg!HfFA9TA210kJUObT*8R75vaMAu`^T#o|cL_a)7!vivt)aX=>hwx$P?IiChel9h(kjeo_~5#TrWO=(92b z0U|1-kw&@>!tx5D_70>;ShS1S`5?4BAuL-PuHw*F#vZistms}-8I=@1D1rS_3G4|a zu#c_qb_CweiRXV<(e@z-EdPj#@V`i3YbG{7sPrWTwI)^(MEKotaKK)Y5AH`5iiF`f zXj)#_EndJ7s}cb<9qfS)X{a3?t!769(&>g8sxuq-nIvfgo6wy$2>htIGMo*pmhmw;4?QQ8Ce88I@FJ?2qh5MeH`BpdvPp z2&v$icK0BZdRBZ0&L4e`zB>k09G|l0+lUAhU^%bBz*XgMezV5>u@7jpt+^=Z=J2DQe}J{G3u~+KPHSA<*7WP03Q5a|E%Rxi8Y4 zt14yqXBeiM!FjhMhTARbSL*K&}e|2Oy2ag1*MP?f{JEP&{BxrKW=|S;g8|Q)fw8gQPs}C;z7uDB51IEC^WMyN zQ2qjW0?+bI8_at)X#?+@%zLhR@4&l=QF%hl$`kXLcs4K1&qJ@N@Ekm; z@b3GwD7@oou}f!?#?w`ocsh@Rp~e%7yMqzW$~`_s=S55vRC`%Ky(`8$pH;k$u$q1X z-3`0~r&WcO2yF^IUV@LfNui|~xF`$#D??97D%vbckvICDLCkTCD?tz~GBi($gIpP( z)m=$;rS}4+{Hm)GLX;!KoXdSVE4p8-Ecw)$~*vl-tnw^3)4tW0Vc`)1l!PE zLP?wjZg;Arl(YUQW3^}055>_<0npeXR%9uxXPlDA2Y4O_aT%TmT~>kbY38QzJh$SD zn~m`V#k`6$&3rt661JEq#Uyz?Pewk;^8xeTf|@7;3iwW~C(lLsau#4rGMn33pzeK#Jr` zB9$iuQS7@&+!Hgefoil4#B~Xm!z?XWm^j2L!EH^de74 zKY4-|@C2Hx`Rb$HPyduevvekj=HFegTiUHTIt|TQ1=0LH>`ix(*7>Yp_j`)nY!ADA zNru4&yL3!}-R&o*VD}IM7qRDB1KEP5q-4l7?=E(!&Pc=od1^3@*e;ZON$l2`cNe?U z%)5)->3FAPXpkrDYUIg5BHJ zPD8pfDxWB(tMH1!7@ay8i?G>5NnL$fnq1@}n%An>7fB?Y?>ZQ|osRGH&6uCy@V&#l zH<A5dda%h)($(;SbOxg$HXU&TUx0;%WBc9^n&|R5*cyH~dJ~MFA#TP)^7V{T z`XuBKJ9-BEi-_?r&VYYmrb(h_z`r;n_fX`CWqr_g3V=BW%gQ*hpLNJqTK#9B)fokL z^dflB-`|BFfv9sl>(j4Tgi+r8?xP=}-QX0%GC~1Yw^g2q4*~qnp9c|B)%+jHR_I;l zmn)mm%8^eAwh)i$m-q`XNmS z;CrdA>x=~l1*n?(F$V@}4woJlz0B)4Awc;NBhW1Md~VJ8l!+*(KHLzx(<bd zHjO%u9;&uo@q6cSb=nv#yK`H@lpw1DS>XyVh7JPGV{;kouj6V%Ifpe3deqDoWct;q zGBuBwBQ>M%J!WY5B@YGAFsBmEmfGRJvx#w@lMJ{8$-qY`@G5f!&h>`~qx?`FL5A_R z2cxZt#pn|TVLeXkj3a4y5`9kfWu4=t9G&u_%|%;_c+e+KPQ+Dk6N@%aEc&o7$3F3U z1oiu@^qqjn zGt~ih5T8QSP6IE9Pl3ZgxAGl97%)fK+TF#cG%yvrlkG};>O6p#j86^GRSJvR%9`h? zb1;vXw!7OZqLPyM)P&dk@u`0?gG4J4fBdt&_~Va^)h#mdM-A86l4m+(gW1p=Yd}xH z-snkc{872G%q;V$j5V`pMR!|eR8sgr=qh6i*c~XMLOx2~w8Ez#aZY^5`U*td&WQ~f z1oMpX$F_;hvi{T*)S6fYWr{QHRe!fW5NOmvB&Xye8-TPG$5pd8;6AbXP{-khjEEOg!{S!v`Eh8dk=jDA3W- zARmP%^{i|p>a&JTqgaEVnB7lUBNw5~8Bc^K)+_^G2AuE7p8DJ#X`R+~Jw$y23yN>PsuLa*XzhD@Gj zc|zMto@8h!{CnCP=JQ}8~7q`0AD0bUPr?PW$prl-7hHX zHT2|seV~ZBc-Fi?npvYz(yR&JMV+prrs|+XQG7IKjWJLgyUPj- z0e{ndxOoU)l?ogN-`Em?*VVyz)|`v?6G=*pWz$%I#So;$fJtcQrbz1Y028dnd<7J| z;?$0shdH{YRj*1|rR`a0LrbdW)B4=n~d zq=R7jX+%xD`1?gEF5*sX)gUi%ElLd~?sUN*M<0yZATQjE4XzLI1v#4K34tw79G1%` zrpmkU!i$*Rz7%h4}|b}l0iRVL{YpJO~5LY6tIW>L)ZTf&WmfF!NRl#Tl%;7Tlm}R+# zvBap^D1qD9vT+?Ye9Tb=pEC0lNSLw$J9-@?^(6Y3eAKPQ2S7=T^xtOBIa@kC0q1+O(v?IrK~GZ> z?09U%Rga63z=f^acSV60vB2=QNLd$$dJuQwpEMqzK8PT7#Hl`(#+8e-IaNoUk2&?j zVTFXS6fDL5;ML4(f85UaGnV)eN3cI+L|}i&6GOa7zGH}U*11E>EfwQgN<1dm8#_U^ zuDt>FQG27*wKqVf2tuG5Z-n}^H#kC|10A8AR`@bHbpXYQI>h@%*J+ ztLfi9`8CazU;hh#>0Y1w+GBs|p;dlBPxa&%q}F#xE#WRmEn%+zsppg<)Yq%$l;L!| zkrZ4sQqnDO2(HS>uHfp$b1I#YD!5$5)|=-v`B9Nw|B2`Hz->xtEke{r^`(1G(!r$X zbnoFQ;%kjzt^dQG)0MwSimz!L-K6+B&Smz#J*PLVH1VZXP<*{8C{fpO7oOACgG7A& zztMBr>m*O|&{e=K1gYVxRu1-m={Y%%Q0gT^Q)!;lZ%#HK>^3x2z_E*Ydtd$+p3~HU zGBok5FLP4ltGh*xo|6+%!cTfm4@)WMetqO=9iE@CaHYc8Dv!t4@e#inp3}Ro=QQ#H zcusHmJ*T%^&uQ{o4)qK?r?1mICr;OKuW4+09z7@6fV$Vqwv(RIC=6HZnJf{)0QUp@Tx$#z_E5&mX zumQ5?Ih`-i&~rMgXKu546+K0fUOcCQY>t`pz}`m3_3qI5J*O4Vy3+ptpPo|#J*S0x z5g+iJ?1Ei*P6u9>t|ZizNmUZ0+1Q9<9}*?;zww+d2`Lw)c}^$o4O8R>Zxc<5J(BdF zPTfQQ=`X)`2b%uVKl@W&FkU;%YT|9u@Sh6kD}c1B0%S9|O2b1YyLm?doe&>8ek!>8%HZ zsP^@|Cfx!U-IS=5fNhGuG_D(Z6vo47wDO%0-mvqOtV9Ka>(H(Su;9}mG zin4$KkX$icgLs^N654SOL0f7Tdzg?31KIeU|0IwN@^RDIZaV2rW^KBk_CQZB=;7ks zp(d+xuM{oqc|j9zQQ@))&2>J9Xc|cvypc-7&Wo84HcR?A{{ri-ym-x>>i=YuFA=Zl zCoHZ{&KCvnPK)LxI5s{We1%^S&G#Ik!B*rhEX*Orh}W#<&!oYPeN1Hw?ELdFrw#@w$9F{HL4W8sv!x zC7&25P91Q$`LXwLppu50K#(Nmt;d`3>f3Omtc1H>Di340y(K&R^(d-6+2K#KOTr2= z3XN+xD65?ZyFY}s!-Aa?2c(dME__zs_}H73DmW^-!ykv{B&We-u)Gjdi@=yZ4JICZ zAJbqsBFU4dGTY)sp|F*BpXZbElszCV`a1x58ah2io~BNN)n1h<(6 zEESQuYiCY+;!T6S+K{S^Ss$mt3<>uhVKGxWyV+uzI;GR9L%)s>6N1qxorUrX=(+`H z>=}jm(J`JdUmkV`K^)%OZH6O4Sf3O`<#1H z>AOYpdCRN!E&6|uzE}Ut(D(TnY4oj7(lI&545CNhPR_qs%GpaFv$YPK&19~SgH6o5 z-f<|hItGh&Ft=;VILSI0ENd&2x5dJ~B^ztcx3NY>ccu*)408%cp|t4=8LWg8=9W4n z#hHrJA5Tg@TmyX&Braq!*`Nm>IB)HcjwUH@rL?_7C?=LV?<5WAywex(o*@1)q4I^e zPKYE;{=%V6S3^f@j%*Xj93=?(RCodW1iY{Vdx@VQRT zGk({JlTK6UI`!Ijopc)UloX-sbV@zB(zs5-;u6i}43g(MjTdO>I_37v&E9)O;A0Ac z@~abN++VR}yAa1!^5_#LcOatBVzYkZj-&CL)Ogn!r;v=M`k)OopB3OIbo`#-_`ysj zm;0uh7NAgNyb9Az+pYO=yi{<1T~sEg&WevOg?+jcgSayr#_7&Im~IjZjol&iiq$G( z?f7u4R>2{Mu_41;LXGKkQ_Le&Nx6DFaWb8!$=iq3#GLb~`rWt2;#^;~+bkbHbVp#R_A`K(L}wttyVv^u$+Ywu$&jP8S?g zOL~x26uq5KIfJ%;g!6b^hbhHhYM=ov`-xu$t08`yO;)1)!YAgNmL- z`b!a(GX9b|;TxhOGMu?Za}Hw4Ex$|6iS=uJtscQPRRE=KNS*-Vt{#Efd>e6D*9{3s zYX)lQeY|q=reeY_)aLk0(nqKifPs|Bd+^{z)R$_wSNVddpB(AwYL1y2YXsE{8mzQM z+ehl4gPCvvfSis-6*gDUYB2ho^Ovv4hLBCH2c(ud_|DL;LHh%Fj)MCyh5n~|^nU<7 z|HhAX#2?cok)VI!2hgvQ9qIp3m;Qk(TTWSO_c1}!gX{$umIcO>6W;EcbAN0+JihRR{e_kkTn4Cj(qXE46G`i87Lj}3HoVfqBK2Bt1 zI)^IN>Kv+cO+0>cY7S1s0nuUUD46AW95v{p-J);1%p!}qWZf2~`G}1MZ<-Ibq=@Xk zc*O4jgI|bFPMdzV0G(T}`~pVw49hq>a^<2e40@`~y`D5Op1_fBp&q;?|*zMU^Gn+?B3XqZtsC+43 z#q5`W1wM@9@1^`5p*vj)PRZ0XKPj0|g@@^L5BD%l;ij|Ggg|`x}9_WA3g6TDh1O zx?L?P(Yq8_LeM>XOuImQQltn}>LuN0h6K zV_yu;VH1SDNZ~wl$h|OMy}<{2FB7Y*L&co04(Gm4DCR&@pd@#3vmk7jw&|0)E~AgA z4(_b&o03jmxm!wlbc{<$y-d;H`~5wqq{nX;O8QTtIyM#58sjQy;zesLnE=v1e50F09r!(QjtxG2OgekZ-OAaw9lt3w76- zJgT3}`J_IgyfI3mOhzr)kdH7+4>lmU=A0g=E63v6((gtUgYHgw-CoTw%dvoF%w9pB0Ms;*T98n!ih^Iz%U~%e%IP6b4oMJxE zwMb5gkHp}|PQGGJBP3w9ON8G{nOsLpW`bm4^fbp?p%6k=kWQJr4P)+oTq$#mMxG-?Q_9(G+l%U4B+xLbb7IfjCaR-F(xW;DB!oEbaQNsGCU+ocODwzB z9mhS1>Zs)S|58+khEU>ZoW|_T`iMwDRHu00E}}Zw-%S`9f|xL`}Z!$kkX zJ?>D`M1KQbG0&vlfS-AZTQ;+SG9ck`RgT)QDWoFU z6uHvwBI94H7f)M51S-UNA%BNmu>ep0V|uYK-QuPp&etJL8{^S%(#8--k~T)Y0RdFM z3Ax3_SdIj23}S}o{Ehranw-@tC})SsFlg^PpLOG2#^qNW{-+|<3jYYh`5#)$``_&! zqv5PTVsM_zPwU2Y`CHjN&rV(@Z|MsF5P9RWX;}bpzHb4*Mj2cac_VsLjO0rY>vfG} zVw1raKQdt?zjTyq+K9_9%ciHg3jkJ~oz6w25Z)Sj6R6!yTW>ZB7bRW(lx5SOdoI77 zG>?z?fpQFLTq@K`mwz{OtD&)x{ZokcwEbM7mCzWD^`nTMWlr+Kk?4&drI4r>8oN$9ZRnG8+N_|*usCJrLB0EUnH`sbhXes6PR(6@!o87m;bwb0Wx`4Vixui>(g~86nwhvd zZe`|arTwj@7`@k~1*CeMiO}>{^wC<;97W*}E|O@Xr-*lM|B?57NSX1RrV0C_a_F+h zzDvr`)=W84U3T*z9HPZi&8I>vm?=QW+!{`gV7%RJf$rp>7yQ9);ykorHptsCIkwU6 zZnyOSM|_|#3+j1{K|R0`aopM)+!*eevGIG`;qFXq*=#Ru{-Zj$a_XbjQpz4gaeCt+ zcP7!ts{jnD0R1$QxtO`I5o!{@hS;ZKM?o3>Y}Q~xMb14P9DanN5w zw*xgxIXIOpmpl(XfX}hwvu4rIN#3~O$mxMSZrtd#akX@cpOPY&E^%g^ucM(Yy5I;X z+I;6SK$=ZRLug%sI~WR?nwBN>TylcGr$KtKK>ENfsgPcJHw`R8dR77M2Z2p?uGnO~ zp~*m6C`AbAt5XQ6H0Q$N!r?*+`W%3p8F<|E=QwfN-AbBx4)JHY-VAj0^l&y~X+1q0 z#Imq<(Z(+Rs!|>+!`wW)p+lZ_7lIS7M9aKTc$+k=T6fij%3{u_F?H=D{GvHkHv- z1QF3S1QDT!Dx`ntXyRyyy}tN~gI+(7qA76&gk~_7^|S7ifO)<6K@THs0Vr}9>7SSY z-|FBD$q&Xx)G>E#)a86&?_+o>$1Oe_2a~=(pb~f8LS;~P;@AbBOFC*;a^x~NYI5jo ztOm1=a1_kQU51h4aTVUkB~0rrcvi%*o0J1@{=B0We>=(s})-B#tnHFuf}syVtfKH>z6NA(N`r-}aNM8boox#k+$s-ioBwzx`%OS>rivl51`TRIG1|mrKpsO_qv~I{UD`o@?#DA1NAl)4Iu?#&t(}% zHF$;>WTdDMu-pQ{rXDVD9412?f@d7yGLQF#XwNW7%ZhTHCAn-*?~x?6sWLKVohvj- z+N^nJdu3e-;#_FT3YWy1WvF5cbl?_uAb&6(;ztfpbr72pD@xv+eUlv*Gh4F7hhsdk z{vbYnP%P)u8^9%I0%)3#;g8NS46g!SSVu^yaZL;Q496v>{|Rd07~v@Mw;Z<%CMz!y z!p`R~HgDnVaM}}QY+a+AqCVh^_Ky-YB#DH=kit{?7`=nNij62Iq%YUgD3|`lPKHlTmd1^xs470%5Yo^Pmfx?V~leT z!sl4dpX#aGtK8FvSKLn34nqOM=dfH9>$Z`mc0?Ki-JDFNrw>y}3hSrfkn|qU`Jq%r zDf8YWALf1zsl{SFQ16`i1_g@q;3f!;7d^Y#b;y(QL+<0;iYj`)kFy0JVdzhWvnD+N z6%oiIpT|v7{cn-$7M+(+n&KRXqTzs3Rt0SpfElZW>o5V(ETwSH7z@W1D>7cRk9?Dh zTV`Homwai3zbn;@KcF-OjLX@QI!l6$`eWs%nFnOxx1IH;*zF;r5CR01DO};UOsxJ= z5SzRBgMMKWH=Y#$LDyhvH;ijSrOBz%B%!iaNRvD3E4=2~PfP7h7Ypob^Kxo@%^;mj_vqwrkue}(Tq92eE+V%|3r#>r_pU&o|%+R*y>c^O- z&|P0s{d@F`U)Zz6A*5%;2Fu8$#LhXd$}o!E;S2*^O)E;5{3Uk8DF;$MqE z8cCy%)s)rY^!uf2T;$^-)BP~29Rl@oBGoQ=$BN8CDQm^z7Q9C`TTL~rq-p)EvyfHk zK(oeHc1VfOZz-~)U)V>2EMBskx~+)J9%j7BH3;)0o)Cq(q@uqLBBWt3rH`CZV+MY) zG=1a?fJ>`mMrejqQd9dy> zzNB1+aEAEeAI#?t>fR`%PN6PRNz_h(>Mv0fu_rpD{%53_j4r!mi#6wH0V%94XBGWq zJkYhuinK9j)64a|Dt4OCYZd6V8r*YgfJR971~!(<#&Fy7fP7?!uoldcJxg2^!z-# z{nP-6hEy|6sK$Wg3To%vN=hTC7WH*vv4g9gV_6q1M9*TyReZpJ0M=j*IPabRz659j zxS4mDDATp!766oy7(ikMoPxzt`6KjJ-kky_B5f4Pl4y8 zfCKTTNJp4dktdM@pS6@Zss$cNJfhzzzoe#OeP1rEx~}G8ZFKoEX>(<(WbU3d5Qhj@ zbMM0r2)krkeGV9(zwjRp7>jA4=wep&3`h(}cddry0!GQ}R-ETFB>v4ieq(V#wxA(68Oyx&5s9$KgeamC2sgW5El-j8`Bn9AYoFxC;;cz!Wmgo;?Z0f^vl^+FkY4s{%AsDdk8NTC0l9-mp0EFjDyYFGCOZ~E|&V8^Sx%e z(a-rmWpyc_YEwhdR0n@UQ$I3I`TE1A%A(uay7%%mxT$tL8XO9dl+yM1jhPs}38*k6 z6~0?Lw7j`|C=UN=>!0|HU0?g6D5B@|u~HtXT~naGg*r%1P=;3cXGj1r#DdasAb<_= z0k);~I>kgvR?K&0PK>T2UI|}WW1GVFb?tc28}{M`J8A#rU3 z5(Vr=_g|zNUHbT3AODaCXkw5RX@^8X3i0hfXeuys5Z-55^M1wm#%)dLlND*vmlnJz zMZQ6byj{Qc>o8yc&GDO8XTHL?n>m!k1A?8MmADX}Ayr6@l=8UQUag?^Qazt`#A!dI z5U$R^ta93ZQ(tgzi|7rUNNeQ;!b$V+1wrL;iomo$g4gqW{ zo`>~c_|#uM^~>g`Ed4Z~o|uDX={GYg@i}Z@5AwPBEb9aQP`t)Q?3Dzb+lK=!N#JqA zh$_NeWA76WdncwquMKuSSW)6DQ&6v-9X7d9U@sqRqYNp}7s9Xl&3}$=;W2oB@NQ znPSKgCqzvuaXLGmC&(zF!b&+9TRIL{J76$Kd4Wn^USzAOw$2BfGfWweU21$IelS`? z{AXGUzF%re;(HHAeChv1-Mhd?Rb27o2@nX6c!Lm(3K}(96v3dNqyi=ixagv>qDG|} z>nm1UQ%Dpm>c&kZ>*hjKYO%i1QU$e&ts=ha29TFk5v&Ct6;bhCgB3+FfRf+$duHbD z-A5p3f1ls~pAYPP&Ew3O^O`efW+V&o9T<~{?~0a1VZ$S}4$7Hx)BUT@e zrQwZRN<%v~)bzp!=%NgFy?kIMg=(D%$}Yow8Q%>3fLcm?jX6*nbLy1|jp=%MyfGji z?B%mZ=3jdmv#>EYo|4#@5)jWsA)c>RuqU{~EY9--(3sr7FX%vPc}^NwjbXI&47-0% z(c{FyoJ2T!#(REM4 zGT;Lw7LIYj14{2=H6lsIY4)_9o#^@te}*TF;zplg2m5rI0GCMk4ZJzoS~zT<=1tj| zyI^}3MZT-u#FA@wvEZ7)rL~{50c=#?qZIyL3W?g!_$G4~>=EL-H1ZYpk9FV25(R_x zIM*tKzjHYdF5^u4HR4kDyG!Dj4_x|Y2N3_N2DRPOk zSC)GRgq;BpWKrcKivlzwnpZ?96>yX(XNV_3se}&F_<@pz&|OxV2whdnqA`(8z?hKr zN@zICWtys zE`CH+`ZYk1gC7q%)t%kq&=FCE{$A{u`2VVc4I+3aCV@AiWzqQM&9rl|*S5P(6x8<4 zbkSp6{ye+T&gr#%0CG1fk1aw9<{&i!Zqa!;BU|(E331f6{*0bh13rAua3*vjGU#lD ziY}1hDib()?~ByL@YOkLi<%e5@UD75d^}@D2x^4lX6W7FmCkPv@r=#m8VE)4DvD_l z!0p)(&cs(mI7C(ij@%wNawkqjt3DgP;S z-&hl0VJr>^R^!&q--@Y>NOQ}=p=~Ym*-B^F7x7l*#S7Ev=YB0SBx%i^_B2g<@6icY zOknS-y#_g%PF0jo5bd1%w#EBr9$zK)&tEfC{}ix);Fe}UJbjNf?+UH%T8d%mRoJ%O zxaWNS7rU;I7LFRC_T%uZc5@}<6J7ijykdwdSFCf6a-b~}ML7q`y+)ypy$0!+mT8S} z>mcj4WuU8NrGw7Kl8nLDZBNV7;IpBs?cu|=k_zF7<*xNYe&UY)yjnThL1K-npi6sW zp-J_z9H$pyB4ElPW((_OUHXmTWFxvwYK*{z0jOFYcAj0#_707KyNbSNHE zO_$&x{v4GNSVX4G$Y{NVs0(~;<;rhwy+;5!0DoKL>j?RZUwjSWEpwE~JN)+MqBxVh zjh{;76Mpfjii?NdVw3e073hcaQIwmUg^l4J$glqPFeLHjLg!x^9+h5ZeA>5vjswL*%`xp?Fi)LQ(lt`$gx zUKE%&@Cuk6T(bx>?zfnG#3%Wn8FbJV4UhS+U zH*4Jey2yt+$3Qptg#_p>HuQv^Wg0@)z=8k~V^>Vi&NlaU*2zBT1|>oF&dy}$=CCk| zNM7x%Pp{C>{qq_6zJBmFhI9~S3B!e1Kkimbn6Us4T;d5i=Q&jTV;Y`8 zCHHpLJ~wH!JUhgPmeu$w1b^o9321rjt2kPih84?!RVb7OxaqVKb8lz8{+2s7~0Pv>m$pD5}9sq3M)y`_XOanM&un&VVlq49OkO*MimN*8Ph5*iCK>%=`0SfmE z%)OlzU2QNZ3+NJ{`>-_`xB!I54uGLx-XwfK;Nb>uXa|Mf$ju9bPEi0cO*g=@Il8kgiaz2 z08u{d50oj87MOcGYvvaQI<4yx0i5%lLSI~44HSC@R4w*Q)>Fr7^xZv(=mS$*xml+@ za9D=bTdEH*8LBVC6`Dlu%guc>tE7r%kUG=}esLQcXo$X%xo5o*GEWJ#)vDM77}?vv z6qx&=De5t>tmdj|BB<4Q%({49@o8M;%U zzgOz-EQjA&2KEDg>c;($ZKSeMi4nrX3H)3>urNO4JJ&z45s^iWg>wMf1iKXBK5!C_ zw|@ukjXqKfFDkvwr)5G6WATKhH)e6tC%kxsY~PXGMU6ZJjJ_bTaBG*+@Ll3uyGX3& zN_DwJU0!$|HuS3)zK9L&o8N&fVimHVKmnF=!hROKMxIdZg8eM*18zMW;-0wUpAeew z-v2&5{*_?|TQtwI&*AJ2V%F>DVAAG!7Q=w`A85t{aRqomm8xdONU1E514!_O4l~CC z=I!p&`ya#9#?0S9!etNt@HWbkYK$Z9f8moh)-pp1RzxDJz^|4UIeE8mCN8h5T<()D zv=$y0D1O5VpNtfkvN;wrHdhn2%c#;&`9MMv-jQe3ajby5e5>wPyt9YTyn*zA5khqM z+t;YMJ&-M8Rw#+`ou-d8e`8vkuw%v&8<+5CHpE8qfagzPpfg_J>XBot=}Yi1a)?!z z#p@WWJ~x~7E1DO37kCo76|>FG`|4F1(F_ma8Ct|BZwhdg8=^*TiqPq8&Nszhiv$@# zfgr*aBw0e7Lu|sBPOt@~#1iCp>{GvzZ0H6yfpfuan8zYqN3Q7Sa%@d+sFa#CA+z3%+>?5}0YIF|t?cS!w)Kumm;rg`-8I)1ma zdVCgFLdt3~;Ng3QbKqAAO32RZI*5aN&4F4L#Qilv{3OcJS4yOcDD z0j>dvlwp8Djm~2743H=mJU9eKf|LrAmRCFLl1*_y)u#kNCvQmt)ESiuXucGg4Cr%9 z(gAA3j`l$Sg1eeSeCPS{by#9z9!54l}KUJLT#LTt<*yaJL`|1##^#MAWCS- zyf2ela!`j`@&(5DR09bp2Pzv_i=Fi!9}4AFqQP-Ya>efrOhsY(zOGJFF^<^#o*o&{ zT9c~(qW9wsmsg4PKlR_FhF{p>`oC#TZ8-dg15v-@JWVwSe(!AAUjq;&7UmK(zPlB( zi$G4`2YISn%%|lvP(hA*pRvrv8{4UPo~rno z_3?`3Rbs_2w#Ryh$tWs-wp;1}K z%e;l@i^CM?-Ct+-j)7VS#S|eX!>4%0Fr+jty-Psf7rd;JW2$?MbWVnIre6JCL5)^U zk-mkcpj%p16*D%(v7ZV3zc?TBPM z0j&8rrU!*67a$1$U)dZ7LS7|y(E%C=k0>7=no1k#iSpu?Q;Blq1gq{yKrr%bt9}BQ z%N>D*t3-*iXzx>F3+Pux-_MAB-Q@I5QxyHX$})zD$;lK9NwywO;5Y&S5|oM>k612R zk%%L+>YtQZI@NPz)T=!c7S>M@G_*Sgi&E2-yw73&lF1Ctmuq|_Puye48!+f_-g{j2 zovQ8mGf<8@A0L{Wp)aLki~UNdNIMz4di~s}T;_JpY5!sOfi!HL#FNq}I>WipNuVJ} zbcHf)z!(D_2$w+}>QRU{M$El0rhy7Wmgvq zmWQqC91<@_4sNa#pdMPDOjp#osYP9vwy0Mzi(|@#F3WQ-fMt&X1MwDa?Pt}^2STdP z$Nhd_gOl(vU3E)__#r1@JKfS&cdoBG_baU@lJT%kw3xvI_u6otU!4vQ+5XbbZwI#O z)Y7g_TiOelBl4l5pDUy1H2pN9z~5TwrwCe0YlbMNAiZ zvr+zdV0%pAYBiWHhhoKGTFI6tR2)7A)1nTdIs5){WJWYnf=&u=M>uyUCI+A}po-@T zHGjkatE|AH#~+iwqXOT#f#&TeF|r)=g&nSP0v~7&SoF|7pU>gHz;~Z(k^7pYZQjv| z>FprbEpQ};ANVME#!|2_;7sprrmT#{guE^YL^+~H9Tl8XDwoswehDqlW3Q)A;0+rE{bV3b`meBPvWbI*kiV;9=pQx`40%Ug#=k+hLusPqR8qwv6on z^s6oVE0$rGk7M#Gwr9rmEF#UFExiJO~RCQKd6J*R7}&i6x4LLc;mi z2a4tZtVBrQkZ&|T5D4$gv}Vj@k_>$7ZqDh=X{88!h1@ zG$l~neEk`o!UsCVAVbxf6aY!SQ&6Tlp@2XDlXZIeu3G-fVTF)v?NUy5l>VpV9K4$XkfMV(=AT zag5ON8ltWk-^Leku4J^lFmz?hLMLM`2?A~DQPV@(;U0$)@x0ioe~I;T(IWABCmyVY z3a|ABuR2SH%Cga_ua9S$a;Zrks`(AWR#D89Gx@F)x@KNd5if(PQ0vB;69e?I7XN1o z?BQzm;;v9l0p20|f2QQZ{ON(kB=fPiv3onov*gc&ALKcWWVzC<;iawRFZln^&^Grx zK<4yUY1-VcNVC743*w95&eH%%^f!>wJiHnHuWK0i#2--O)b^=yi;!He9ug9MA0A9M zfw3W7;m#V)m*C(AqK9(k6Ve;3w-8_GDStX>B!R@8FXR_{WN&V%Gm}Puh<-}EKS-WM zq!lbqj>)Bg95TMRbxQRq2o?kWR!#YJNyErK2p(ht*$7kJMVo{$xud1Ji#CxDR0_E> z@rKYx#L96G^AdVYX%MdBxNjENgLcld|H{Ke0nI^);-UQm|1;M2 z!mMx_dQ#3(=|IL0)HShtO|L?)VJ$hJcDXSvBS#0}idc|~P^>6K828x#1=N9|P62M5 zCEZ!5IK-(nQM|8YcQeDG?VO8;)7s%!4EZV!U;%bc_qE1=mO+}|QR@u&Ai;W;7I6gj z=|c97CoFntVd0*GdOUf-x0Dy|NqDP82H#O+xP$Nx4J*XOS^l7OdBH=pr#w-fG(REo zyr=kb)2**kRAi!FNi>1zf*3E*yWxKV4iNKDNDB!00uX7?9*4!8IJfv|d_v6Tn4y`a zq1GN&J)+8yl|F0xEYZSKxp;Tx{qnlHuyR?KeXxyLvItKV*IMrTMY7_SX2{#U7w90} z5J51E4H6boj$Q+WALi;Od-zGxlbmk=oHF6T&Iaj;9R=EOa)e5RHl}f%JeM}%Fj&%H zg*4h7Ao8~@r{?!5NVw%-DcFwy(M~bICHVltOKV6>y943&Y(@Pb&-5U)JV13@9l|dZ z$1D`?_0=wPoYz(OCYe@!tbeJ$_CikO1MjC?A>gAC|g2N!_uV?($o zOx+5tfDoXRV89CpI}7g<;cJijLT2|d!)dC5ST(|o&=fc?cJ+kWG$nF`kRTWdG|DY; zIhq@~%^i$OXvci3t`mhBI1FIx^##IicxYg&@qm$oS>a{K+j;n25fb;R%Pe*I;y#Fs zb-q=*N&5FA78u@)0m3yL@bCwu4kAf7_@H=I&B?~_IxGVt`!2a#?2Fj9CnmvE0XUSVDW1=Ve5=x_j07sys0y6&tpsKwsDDH z^^R;PJdQO2#k;Dl02W9Uzcy_x#N?$wnKG$}%p`D}&+Y{lh*kgiQ{?5ToKy*K2Bxn8 zgQNZE98QrLqZF&s8o$JZB9`cJdWO?wOYtZ;XddM?#j1OdZzU^R*)`rutFFfX2_=i- zC;d4e=Bg58I_e}ZnO8Xi)W3xqL!KD>33(tC)KUjfSy@0YqXM0QoYXQhPK#qnmKA;$ z86na4!M+t%T_YY~Bd}%+*J^UWfQMUk7vL=)e~!n&STbzP&l4pp)@jN6{@R|j!iVYi zv?&K$b&ta3iSCf*)VI})mfAvXLwqIOge2g2DQO56(<{r=3SX|@vm{K}ZpD-)?CyO+ z+b_iGRhi$^yl2dF8enLms4cec4=P8G(Doaxx=Zm8+Wt$JesXh@Ro6{!j#hjBhPDIP zFs3^V9uwDom{Q-e!sj6o;OH6JeiGJMM;oXIVN>3WT>#LjrGxkt+Py(6RMJX#X(h(! z{k3-yxCi?v$SL^YNOq1sE>kjbk!m*~ke0tGI?)Ne5lC_qmq3*R7&P(cX@IFarX64? z+r*|y1I&ZR{#am+@qjrBQ3sHjq3uUlb#KbeAy(aEax<+4&0nOD2BNE$m!lJ3j+U1{ z!yyWCb7;*W#4Q*$JHsg%q1u$2jNo)_670S))N7Ej^A-0hWE$#8uyzot@OShpsP$N( z@1vCV#K{BPaR39MV>u8iu<9v}{(=A4`emC{cQWokfvR=eYKoEfBzUO#He&P%5T8N- zgZv==AY`mSl)*1rQ3RIGkYZ#XirGp$P?0UyF;OLfLy#{ze8F*}p%tf=5T5!v7G)2= z@^V_NRV7%PSBB*waQu{4U@=B6XcgN?+$=d{8wrf{axRnYp16&KGO(geY6Pz9#GVq7 zvLci)0{t-+t&Nj7T4?7SF4-x#9=WOa&JUJiT zC9Tu!km(E^t}v9s4u)T1$L=;krt@I?37jcI)8e1p$iYu`AE410Qq*n@l4xHh>YhH4 z(_7l(^iY@1x^?Mz*$B%vxC|*_AuMY!hCnyF0nCubiDp+pyFfdO2ekW5U_}5`hBFFd zI@XW|r;?~A6XowA5hAcMoX+t4rzy!f@J`chf4Gki5+ zrzPPlsY$F0F)LVSzmz(mC^MYgcIwR6b%M)(vyTERMQ7sM9Y8jlne@$B-;{tsXr2t` z5C2fhb6_b|Ys%P!dBG$(wO5bCpYwy5G$}B6xP@E>J)~B?8IyoXwK=tSz{j&0!vn(VktsEV3{ux@JSvd-dmDqc11A;4XN5iRQuFD*jE zQE+F07%Py~J9E|eC9Zm8McaVkgQ$#bs3Mw2^qZ%7l;$hfnkPWbQzDv214rFz=R7ajsdt~AdGY90`^J)l(JfXUHI6- z(79Nesi@p*I5Ev3`phy(H7s2S;%u@_^7)D;k3S{GG(lDY~LX1KRS@)f31Nkd3jd`oBnq zocoR-Aqs7g0gO2n)m9D8qv8%(uxc3BRE>Qzgx8Qv8f%}AR=zf+Bw+W7$Z#B}ShWt* zbE`H4>}ntm-Mod}yv3OnqnF?}TwC6Rs)dK9V&l;e9+o(VHj;ewHz8r~n^=f;&Q^(C zAr)WIl~k;##^nhZ;tRD0)Evd8ke0{zQjnY>ClpQ#N4Oh7oXgM$YBI$A8S*=Gqarlz zoK2e;Wvyxwx?*kt*oC{W@cVQkX4rYw4$J02O+X$}sGST-) z28qiz%;z?#`CQoqtakGj)*X35tq-#G6^)jDjPrD7S#o>*fIT+XhL zGz&;!7{^xeVmI)m?BE%+&&`~GosVWNLu#7y!AMAmG13crEj0-fV!pLp?M}Md*QE!) zsJfIh%F6Jjj~5Rd?GsU83KJ2bx7r&hUpPUE&r|7d3=u~78yk27mZEt#{!BKq!-}i0;43PZ0CsUjMu-KCYuFYg!N?N#AD}H3 zR3z>T8I=OHbJOi069)t%!ZVpZ^nCyCh?4f^`%QGU8GKta zk7Dwu7Nz>3N%HKK96lO6U_q~L~%VdT??S}sWvvCYkp(& zTH5}Zt@!sN!c@E2VIAP#4ZMPX<%%{6UoQ`_9fAc|FL- zyx+@^F5d5Eq^tU!;TmA03U+KIXhRW&o}<%xBjwODwNn*6uMI3YnG(P;q=d&05T>S( zlb#Z+)h;D6IR$awv;&aUv&NBwfPkqHP~yzo(mqowX?hoN9L;;=FkxyQg+nw4qIb!K zTQje9@6jv_VukS}EWE9aGG4PVOKSP2v*tF?!w)`I6_QAh=Zh3Q{7D%-BrDQGj91Wu zTtN@3`K~6N-k2U8*IHqL`MPovp?dKJz+LdUDe9gATEfH9_z1N9zW)(j0 zX}vtXBq*7<9^A$VooF?!56mtC1GG&Tx|3{&oO3Ac5O`K#-v*_Y0q&v3z73#jt3WVi zK0Blk8H^o*oq=$l)Au0H4#^b=5@{}Or7){9O=vRWWYB%qee*GA6PQ{)=9$j`L^~cG)L3OQ=rxNW}n49#A z{TM+w*+-bMsP3WY@>zV~lcLKAL4RRf&-#^B^O5xh|}M_@YsX?-V#nH{iTzOy^z7sUqCYC ze4p>pUq|HP4)B|yzqGQOgpTMU!YL&)W7|HuG#Zi=YT2yFvO`NAz7sc;^v@PdU{p`2^{D!7eXNp&sR zwhR?sMdn++48Iw{Ou`?-9b7(A&5x>3nx3g@zXQz7xAE2K;SxJ(Tf zl3+2tI@N7l zAFDwy%rf*#hI=}AcuZs&wpYY9XRX-g3?D#T8Sb(85Z=^^)LY~w=v{?cU_QMczB!H4 z$hg>oE2Yfaz}I6UZ(xTsl)2qkCT--DGRyH2Wu8T0Fha^48)*hS*!8Ye096}T#UKN? zWu&jrp5j5}7OAZ1*pFGaGNJqa0nYPJrK&Lz7AzC_$>dsK*bllb7}|et=qV z=4@7CPPY3FF%#OeMH+7$QB9yq4F9Qg6NeP1t04uqrwgM@5 z7iWJZ3?%Go0;8!qqZ)(_4$D+b`6yd!n9?T&$c89H@uu?Jr62KJgcy5{bjg&htQkxR z1{9Z`Fd&W>AS>c970l@|z%RrqleIFkaPacq9N|kgGG*|Rj)wxmmuYzDm~?!30A7NJ z`j9WbnM!I$-$bu910s5*AWd?`5>f-An?LU0fankXWI)92`a=NTKOn+R(r>xzz+tp9 z10V}MCffLQ@|b8P3=B41m~R8Gdfetbasz0;H_Aw>--l7p?Loh%cdc$E(Wg_~ui-;n zalb6Qu~&+_E-$XQCrB*=@@0ST_7wNo$Y2!r4x-S`Ii>erDefl(@y2g+^B}r4BI+^P zpcq*V=XgNsDrv#8=PJutgT_{%>q+oBx?`moi4lz~~{zH$D_QT(-NU!sHj#ZU}74EzJLt-VKk z{PhAswR1ksVTKM&iYbS|HOLj$P-3VhIs*PThVd?-*=HEfA=c9v#@cLDiptYaX&B|D zKWl9ZUu+S!O+k~BOh%c65|fcpw#llgNU5f?yR|=HOlyjr0X37>6dR5YsixS$cnec3 z9~bAm$=Vc4>u?Yif@qjt>^*usX3Oem%^%0WLe%{6C=PQ`{BfNx1^ENc4mk0Z$K!S3 z4{x}+FD=Y>ekc5K%oOm)=k4)FUEx#!t6X&V!0?3%VyBQrDD3E>lPioWMJz@%TlJOr zj*v!rRJo5zCX;I~C|XnkHj-ff>-(IBb>M^NAF`&xK3}-0;5=x)GlR95qbw@Zs(jY z<*+CAk>%p5y*OHrlP93MY(nIGE$fsGE~J$@%AvxYKtz)8^ZE6LEQX=XG zp z)aT25DJZYXDX&O%SaQQ5u1}w5QC=OfTL7FZe+xNwvJ4%4`rR+T{__7ueqGdq6yE{) zbu{oA%{fMrd-Ch3>pRFCdyronuQNS!#-@1BB+IX3ec#w8kkWf0zbFGcB)R@Lx8f3GHs3|PA|*;g^5B< z#o`$7YvKQ`EPJoA1F~#>C&MxQKaO*Z+b=H528pzzEZea$p2Cx5q`<;T_nAalww+^> z3w8^DbMIAj};XUCQeYsr$<3&^MC|2K_jkqDe-8m zy^EzB>ahaZA5ftzSz31SePgeqmC`)4s{__vho$8Y@A{cy4MJuy( zxRi>NqWEBQX(A0|vmsWBgK0gY=tPV{WjR5KX;k5i)rC{p>=01RW;YP!RBKGL z1<|HRjn7T`bBe);q#Mu`0b=b)IH0g}g7Jp19TDi|T;BSFc=tsb$iRfoTxEn!Vi*x5 z8=@5vqli1Tmyx1bevDSH+5(zi<_Ja9Dk{dPiI~RS-1lc`X-tvDIRcz5{9irP3`7Iyg(R|b}0c*-le;WctS7(TFl`a9O5gaWP|}b&mKc#1mid}H_c*G zTn&;l*KxK9X|6^RAx#0ab}8X!7zEz~G~Iwbymzj?6gXm#vBHs0UyL#P-?Xs2J;cMI zZBEr%AATMXAXLPe4?k&w;ZD3W5kL8A6!5oU3MJljz3QI?hV|mx{`IY(B!)@_B@{#8 zR$_)I;d?=|y@G^deVK#5$=fO%SgYb}2*{ z$eZl%i4MdV2nJ(t2B$TX2h+oLjq(D7PLWy$tk}g!TN_EmtU#D^ux$y2GgMY5vi1aNmF9a zj*y$0dTjY_qCU-_6Me*rB>!kLFrULfrk}jkYDZ}kwN5?TIKsb z9-Rdji4^Ky0dk@xM-EG%CoO-zBiJ2~Ke?-Y{Pmc$wIlN9y%~wUP~i0f@g%+QNL5lV z#8`TAFG$8*=c=#&hvH}RML^DHiq}%`qvLTqDu1@T;loeI<fP^CyZ`?69VV=DAx;LJ17(jTtdA)|i`bpvr3FhOYr`8igm%a#PO`Oi%l(me z!yj)6?UYTN^g{{FDjVaeDiqQ zF2u*g#vgcFO5@uw`cG=Smj~UL;e1w~lINOKgs}(+GeeYUmA5b0kw}eaZ(pz*)dnhh zU$FhTF+=jcVB0`-$l~n_CRt=(Fi9@^g5AiyR%BnW{X3zEZu8ZKlV2H6Ren<8N zV|KMK*c4=cNA?BV-|Pz(LKbJ>dF(f=6q<}DT(0INabGZh;|_qTR*hRl`jlNKumj8^ zc)(r}J<~PrGjxk;++Fc3Q?573L)hs?wwCy}G`MHF#&J7q7Eu$_HBK23&(6Is1UH4) z^sJ|D92Se|J=ZFk7mMz(5!x?t>zr_|YH-W@*w<|xn)*llzYDX6(rm;y<8lWs&hm4i5P6hng8c;lJUUXDe}keWuGP_k_~ zRNiPjrA}gFbAG1h9}nlC{lP!p$K($8)GjjE#;72dh6}8MXVlOYkv2_Dcvk7P~)Gb?3 zayL+v1ItM!8(|PT;ak-%u|=%-gKP{H#uT2!ANc4Dx(Ph&=zthpG^R^fUM`n8V#LBt zui$Ywi4KAS-i;PlfpbqTQ3v6~lCMU|UU{AyT$vxrRcOB?r_mskD`QeZm|f@T%IISA2`%JJ~snF?4IHbfNl6mM*luAYIPF#X0;eN*A$u$`pQLQkB_( z#l!1GVmzANM8n_-qr>ZeGGdeaP$O1M$vq)9)#^F)<_;j1v5Xj({NF?DKhGp$+ow|= znGBmq@6I{~9r_9hRd#)vh&!mfoSJHl@>cE%van@sSJ_}6z zylJ_f6GO))%L;OW^j#03B=>30Tzf;Brn`^+5g1V1HP&Z~sw_9FEa<*J#u#aRRu`0R zZEJZKo%xP3*IH)6WE<->S4h>J40BCUYuq{owQB1$skti4Nh%AP8@EnB6zf!yd)DcP zYMb7~=BgsThlwWCs;$!x#X8m5wRQR-&2eu_-nexdV_s#QK1)mQp3@Ztr?pNoM73ru zc8{akS0xEOCa2tRj=mwzFTgm=+y zOO+s6v8w(t$!}HB_;to@qgAEMHqUbi6YD;0Vm+fxEbhQ4+qH4F1qKzYDz3Uy(!J#`ZQjJyY!0ILd^d^wHb@;LzadN8C%+H5rB6Gm-0Qvg zw1ATQ0{|Ah{37`uWHs>ee@OBSlxWKvi{xmB$piszV0Wvi;QmM*&H3O{$!`=v&gYUB zlUL~iP9!2yZDrCfpvvq1s>^aH>A!D|x0rL};*>8F5c&B7-)Hgsv{!Ixq&55*R%NyM z7CSwSBPqs2mY4cgWvRtZv+*JP8CGSr`PMpx@e=ZO8ZOSZaTHO`nE{MDZ^yY2^h~S2 zxc^@KvD|79{@8N*W1$K7gV97q+>C)g_F<$Mx^n0mY#oXw1Jm3F1EZS&R@24UC((q_ zVN?#ImqFqs$O+@=1W4W@oPGy($6c{C-N9Xa=fC?|M(Q}w8Tx0C8=!$mQJdVTWz^_+ z#`XdV03f^S{9TwLyeo6szOwIz-Vrb02BCXI9&s)P1fSvjbxK_P!dTPgN|CCxmY2~( z4M>V+5gW3zG5nA9@9-ArKTO#DDd3`NQYvx+>c40%p9AM{`E2 z{3OrO$lK=_&rVVNZziymbVvx{NQO~S-dl2b3Muc>S4f!X%a*4#Rle}PA=*>TH}_n@ z(8xkAqR8f&APinrr$RdBJ8yib1R^$!tG!>3HW~OP7=uY&3##8Ua$*_FP(fYelIAs?p{2$ZcTL$A$>PPSzwn;9)^#dd zkP(|;VWpK185lr9KA^j=0rx>Z6tSy7+-8^q`7n<%#2e_#NYpp_4vP%Xvl&<8K@2kb zl>eVjZKMwL@5ID|nJ*KRmAFTMJK*uDLi5=2@X`@!M)P|+wQ)hI*IgbvP^3X~Y2Q(~ z@*QDbwnBVI&UDC2f+kKd`eaNe#DpEqbcE=9&LI64vQF)@i_L%6GEH1?72q+N^Xh-% ztfh?VoP)E4J^BFB6REg&^LL6mn_|R?A<|V=cp;vFus)o>xyqZr!KPAb z?k+)e5gR~@h)TWH6f9v8_Lx$4-jkxFuc|E)kH|npJjt|#b4(J?I*CTs>uEChoz>X| zHK4)dNu5jZ4nyY)aB+H`B&xoPT#_n~!AP?^6P)jSJlZ2WPf9!pw^I_yA4e&X*hx-y z2}H!lN<<{t4>QU8;muId*U-nwAIJv?37>p80cmJI0O1Pn3xrUki=;D(cjBBIkrDk5 z3hjiMumkiR+F4v;-Mvh9o7oOxZfkA`79Jeh-pQJ&yjXj^jNe-LULd?=_0?;7WWL)l zu@IYaDqm!R3Bx14!;BEN7WO}3+mcYtC4uEjXg35hvCo-?e)bB!z`;nE%i}y!qTmf) z9Y?9`Em}mM>cQ4R)amYkuLH;}2kjA4;iUtYL_Q3Eydktxrb?Hf^-0L z4Arf;{4mrI&3RDeH(dUmEROfDCsNGr3-;#r#tIZ=MzmVvu68L=n#M%9Bh}%5BRM)L00K49;a@?H9#(AnAKjY` z0x@f%MDJkch82r*1%v!~^1!Jp%raFfU&e9$*lIn?q|PQ!(@7^LM50JJzDb&XDiTFa z((HoN@j9t1?LyDyOV0O^$a6ipvl0(pzW?+!V-- zuippKuQLa4+3!%X@qUNDwwg9cbzzBf;r^=M1Dst{XLY6N_xGXI(0{7q)QK17unYPX z8U3uRQEdQWUe;-TOO=elpjD@GLPjXl2lne!&m9;!1-Z}8jb>f^Hb#Z98k~ED85VIX z&~!ptn3URO7&#Yd$06-;D(!)R$Ud5}K=g@>6^IN2Y?QLMEufT5^ggz%P_9RQzry#u zrH%tva;?t_J{XVDoLAPy^`kV%&bjHE0l+Vnh+#OYNV9l{ws50nH>D_tNI}=Bf~Y7t z-*DMD&m7+4I6j5~QbdT>nEj<3Hs}vevB9bto}1~dt%Q}Iuk(F&OCdiJjgsenm5$86 zhn{IqhPC%zTa-hgU7S0HB^ezGslQ&6g4BTmXvdLS0F*>?4p9Xeq@MJx^bEWXX;%p+ zI7ebApgp91Cp}E8l{}dSsnfnTNIk^&S&*t5&$$F=)^Ub~kv$!eT$etq^qT_H_MWg>h^y->S3 zpJD1F`1Vzno;wteW(i{X>fj~XwqLNjt-VqyBfxTRhOwi#@q{c?DiLhkxE-PFH zXi5=nQlz3yzM=9-vt_~x=7t;4YUI54&}~EEC5cfg!WzVBu=H`2U~wNS!A9ka$xF}8q z`?F4|PHHNlbYw5JJOUaUfg525>A%{g?A9fEnIoNk<-zDY_GJ*GxIj?tkrqUg$^!K` z38f3ZP+k}D8s62%s)tt)9k7h53i~JrUIfSJp+^K@53hVf#qx9bRv!^OO)Y`(3=I|E zu>gl}fX7E6DO`Mp$1BhC1gEkTb~90%wozJe7Dzed@kx&<9v5893r651V~06oeDB#w z73`l%I+Uv<;sVXX0TgUr&9ehC-2UKr6z+31S3C4#2AB0oz z056S-xl+`ChnUU-7N}E`M@WXwP%~`|g&GKO5#y8fw||PVK8`a$A?5-xY~hf8i*pYa zln`c3N}`zkq=ZncF>i8GNMko(>o$P}a-IEw>XxO{URrF#SbE~QOvUS`RDkJVY2qxI zS1?S*sZ3VgLb*8_=fubjj*#J*HKFY|Ip$uu!HF+-%1sH*iIJNMtBx^~$z3{%}!D`M2?%{g3LS~GHxA{r$Fb?=h;~A|q@5$$hz}`qM6cr| z=7^Tz;;cEE*l-37fnL~#>1w4B67)ftrw{(c!_#UviwKB3p=KSS4@f(lkqx0o`N#VP zbu0HIU;a@?R+^hCb2C+LKo?|Xqt>-L5%vdf!T9o4%$8$rVg*YJ@9JbVZp~(<1u?!z zoPn~>z;5-;R(KUsU{TTu2%*?D(yF%+WrhqHtZeT#fJ{>dV<3m4z<3PgyHHZ;w9=2S zk2=Y(27iYdd}=T+ZH3@Lju-{yxhOzxD5>S9KyF~)Ln(&YyKd~Bq-rx6G zMeqM8*KD3afDnQ+NY6QV1Ai5ib!A+$5UScS;%>kndzK zRlO?Oi725g);uSCmb8bAK13b+Iv$%4)^O*fcvu4hu9OarA^E-|JhMpDZekdU>@ckzuXTlN6goI9$^Y{N z<7FNDkgpx{wAEDoM?>;Q_&%puuyWwx=@(HCU|3W?a*x_O|q>0bSYp=}jp-xkD z?`L=k-Max7=Uge1=7Eyc5XiY?-h4`&g1807K=faO<2^^-hon?+ukZ`_D8$aLk6E`d zEYDilJGA2v#PEb$GjBcs^oNso7F*%D@@Y(F+enN+Ij$pkb=timHQ+CP`{?;nE2*V8e|9!5h^e_E5&)OO2ME=6`>@a`xN@D zJ-YGO*~8239CLc^Z%?>*4O*Jr2V7KVxz(_!+N<6vIgFIn?&m|~vu9I+EHa!AV4@jE zfY_AMufSJ@>LQG1%H4Mmx7BW`g9>5)bw!F~`%mJ7w$ldKLwwK!VkgM3I*omBgJ&Nc zV%1*{W#=^j@S~fPU7ya+Z}APF1Ee|FDoF$A#IPT$alL58zsFc&^hGM4U^G0BPjnwV zgRiigh84jM#E^a*9&v{u{YczNJgbCrD=FU}S`@^|Di!HF^KVuF74bt!B0vRX0sxr^ z(6pRDWHmdW#Jz$hGzN}wFVRtF#=A^HkfcZ%wX1?!7NfIB%V>)UK?1yB-U~s>FlY-a zF|w{coO_?#Rw}R9vO{VvM%X!)zz&gDRdP06kOOz6T+cw8&PAxss(*-X%nL-i>Uy99 zO+CuRiuOB)-Agu=cBv8&rL(*<`VW0}3gTd3*=5~=q5}5mC1CUVd-%o9+VF4ckWkk zXM+?@M?ajxEen%S6o|k8va{}x64-)E{-j&L2q^h>iU7xNW6d}BY;=&b>|k=9^ixvj zKQWD+FM>|w9vwTxikxBqtd~wc2fr6!wt6{;s9MK#KLIs{*E+T*>ElfG5wSfgmiiX; z%-Ejg?qob5dU`efKjj<~2g@5pwjij@aJ)EughhkHXS*ZZR(<6ao|cOoz*c z!8^_u160R$@iE|h#Qqoz>e#4JYSf(sgkv2H+4wm$hVhpA=Tk*Kj^!9E<-9_4Rs|pt z=~iiOs^kVtFo$2DqOBRX^R8_LOyH}h?G84lp@u8CMP=d_l7`wt3ys?@R z+neZHK!AO-xR2wjn#F}&Jq-`yDJ{i~x14Jq@Na1Q;a0uunH1@Q7<*;@BcdalGg?w6 zx-*w9%SEgJ&B>?Siphg4o|{G^g8}55rAC?7tUfPp33(7BD8t)q)Z>}wux`}!xY(xHoAUE)O{abF}^?E~Y;L&lTkrse(Ds|Hx|`$%XDV0A4GvD`3gXcAfmYqGgQ?n}k;DL0Dy=9tSyf6GfwXlal2V;>^zZfNZ~fu?QF= zS)c~;&RV1;3!-TsU{XEJrU*byv#I`9@+GFyRL~Qk>7X0}|7604 zJLLmZib@xj$H82QG8MN76MY;1pL70`pDGUjG%g);WFuQzK5!1$U&^ra&YD1r9!Mmg zp?xCma?MS?+<@{6ocu6XkI?4?`hlhrX$SM!9SyOIIJN_DasIqNWbFe9vX)Xe?vE6C z`y48QJqnh(2BT;=r?D+>OoCKVQwc@mjK^TqX-2(6x+J`#v(y+aH%d7(@-g>4)@5K(sq+X~Im=LPA+_70I7!}e20bjX>!YA?M& z=GVv^6OevFeX4h#SG~K#3Ky&T`lzgtSLk+2`W>{)HO4|#i&O8^k9(at( zU1UQ!A_6OxM7}de>0nonW$1>CmRBOXOh_Q#q5m>k9ydD{^9_19qvf8V+gkqM?CeYS zj2FVAd{~HUK}^NV;cJ%TwnDg@qWF?UxgX;tBGF_QsK?qX@C+nMQ{V~d3gj-xDDXgB zob#o?pq-aHJ`eL}5FnUpgw(_$e3?R3N0WSfvs%b6$`mGlkS3Cd4>Qn5gh}2HPm7d2 zI1uR^h=Pjs0IiZqp>w8TH_GFIWhKmM_y=cD*h*oloR;OZ465juY1%;=lp?z$XRH1DMvb_5Qr^GJ5q=UT|4VhDS?f;-d2sO1E3v zonA;~zDhqd<~}HQ*!m|H+7YTjhra9n0k7IY?{h1Y(0lBHpM>76PcgfP-rJY{RP+X< z1fn;;F%5b3%?H7=gxP}g?3Z-tKHLZ@0{72yb95O z$>e_cz2f>@i2T-oeeryVd^a0O^z&*yx59Inh)g@{cPofRZEI;-Jqxzhr%!5R!q!r> zTDmv1`iNxrkU46JhfFnsQ?fsLkC1Gn6tsFiX!Wf2X?5pfmOx~_c6$;s`EsFosgP-B zU3i1EOYAGsDm35ZL7^Svth<-gy;t2sbg26r;$4X4p1?9bxR2r)5z%wx((-R-i>1+9 zI{7%DcN}JPn-RO=&G(K)LP35Gk zMCG&D?8VHc=v{_q6^2AwXe(IHt^99xed!Od;xnGjSfiP4#&ZShmpGhLnIi2RE$2@U z#aF#NaFA7h3jzp+tux1zzxdn&L9> z6+Aj}1T04wdM;)>aaRmlijAd8c}u-0vg+OgEu#RoL>+9#JG>zLyE*Bs#9G)E2rpla zlnMli*+lROTO=o*-H3u2u#{Pf)hkwge>{#?o`VUQD{x*Kvq}7u!6%Ah^TyK!(b%xB zK*2;n(>%Gv%f1v}QFa&Fz6DnOsd)5RyeFv^>}`|cO_5$vQ_8Ye`)8=0P3feX(tyX5 zrud-8SU)w^@wMVOQyweBIY3G0N)t+>zab=7bDF#%F@#yU-@rNn-_Ah>q}1G2yEKI7 zC1WG2aOfaTBixP!x&TUaC7rutBX5<4H{yuH9Z;9}AnKAX2qed8gxj%V18+rDp1|Y~ zF2~^NoZV9kCv0SQqe5g1^`_~BCvycW{m}_Kv6J1)7CK=OVI+ms|Kv_c?sL-#nx1}C zCyX2M|Bp_1qdPkxPLRpC7_v_S>PI0wqLim!1NEO+bthvxD%B^!p1wY*J|Iq`h*Np3 z2l)>ZUmslx>7FFKlV);FNVoBdH7bV~G)@&N1yKg!rK(?fGu&fM<$!}bBQ{pB0_7a6 z;SLh(kfV19Zu8-IllY8AN-%mgQJ;{r(mk6#5x0hJs8lm%hD zR|VCHHWP~9wdw;LTI+Z_6{e1eO#;BL;Y^easnNGD7T4mKbEE|`LRw|7OBolxG&0h~hyU74W&9N*Sm!Y2XlN3dr?KaV4Wp3}Vcx zekRr`RHSr&lr|3d?glhN9vuTw=uM*4zeI3IU>>^If_&#PA%4!DV6sb~vi3#BVraLHa~D3i>Fp-aE<9IiXyCez5Kj zrZFIXMW@_w1(oIE1E8D+Z!l;k-+2e?NN51U5Ekb;-M^qC$zxiFF{y4HhiG;+{l^^l zB2rZKHpjp0R}`(r!JvbXJfJw9KT7^%yeark35p60Gj^}~00m62%i(`|%?dw<2N2n$Zq$192(erO-Zj%}cd9(t5NNJHPuQO)WYyoQ zK6XNZQ+_RlbwXkDk_sEE3#<8su6)X9ui{WmF*sS65#=#lBW zRv^=v+L>AfGkCHW(%7NzwKVZ3iXZoQkgSgGzm{o(lGb@uF4#%t`xEF?9R~gZ)+qsU z$w}}cBmTm9^EdQ~Xdmi8Y6Bo!ak2XlhT6`}QVd)x&!QN*R_IGXyfP?O2$cmEI1N$^ zc0A{nG$_W5CyXT1LK%Ijh(_qelcDavFfQe~%tg3TI;Z5J9{>tolFk zC1^~fTK&qJn(=l39@Xu)>Yf8(pJoq(F3@L< zAzonmSiJPq0CfVR2&NCj+f-d}-w34(=CDZ3QtTo~RL-@bcT{CNGqHt;h&H1g;KuQ3 zhu`y?Q9Yh^_$A+Fu83;~2v#&($qOM6YKMG*fzjUpKmnqqIb@4N!0h33dnSbPEyrpQ z6@{)1VZgFQns8rXh*vzf>Su}_KGV);gBIYKf@+>zm5CCBR9DV``(%*_(U&hxnx(fW zYV@MrM@Ts^CvaupdGQ1A;l;QS*)s~-c;I<~2Gd#yCm55*s`ItvM*k;T=tK;QTo$4P z&1(5Kf&reKlN6OM*dRMN;TsW^{-_hoAg=;J;bDgHXcQ@q@fh#iUwe$FqX6QJHx7c1 z;U1Ay!jSHC`Z&LB`H|>wMAf|gD&VCVF;m$`wynu#SiN^_c1vJFlR`^~#!0fv$6B^=sYKWyU z%Hi8lnW|MLsEC>IOjCaCWeC;Opd?84x2K#VFQFQ~r)o$jWr!}NrbOw6wNnNn@g!Ec zGgNb!(hX~;^ufz9nJA%kK1ztW-)#j6O#Xo+fE7rtgGXLB$n}$!`^OIbq-8dKRA^;9 zcvRw@haY+GC~&Mk21=OE9{$x6^q*Cg;5>{nL}Wm^sJIKY(am>%Vh(Q=&EGOR9xj@e z3Ifm^nB@Gmlmm8f`dv?_oszeVkRFN8!+$9-!Gv+XyDt8jGDv_<8fwc>UH7XDq1;8- zsY>%1M%# zBo(UpxuKAwyb{>InnF|wTd}(qEEB$VKf}Fq<4)D>pR}xFH?QSSBY&o|!-qosYa}Q- z9kFGvkf1VkR+)Y>5>#o=eyLE}0VMc{9L@)i*`}Zbg@l-UCGMT;c4*os5@P9*&`O=$ z?EdWwq#q~gJ<%ew8M}k_TIYT9f$HkARmB`t~&zs~bNLcT>J1)M+Tkl#n zCC;WE7yoe{VImg~^?lwg7bA-K@fKnr=I)29)6gmy;Hb|Vh>bz`6$d4`Ad|sHbhKA0 z?Hig&?p>enuH%}q6CONpt>S@GvsI@eL&71{aOPron&A$?2PB6Fu2np6F^sb_+jsoAb?8KwJN)enIycJHb_6e-#-?gt>ixT@i9e-DpJqiPpE zoK|ee-Z-b*bDT~2Ed-`=NY@;k;=vssX$?fa3r3c?mjlUue(bItt1WB%%*eOw)0US! zPUI_gXv=)CVar^n>o(Pu%cUzZOhxo%n{;K{Ah#bLF&JxbHhh~(r}trY$C-N%%)^J2g&i4q30Sw|U~=cCt%TKi=bKG! z?jd-Q9KZAhe2<7^KSRe6A;C~sorQ6d0QjtTMK;$5VlwnMAMlM~Z5(?iW0|P|T zSdD5wIEhI-K*I7~VV-uS%4LAShyl0;|162sTwxoAr0PzeCN3}31e@CRstqnpb!YbS zGEPDn6c#VB!asm7F(G!aTB`prp1di-ovC|hS&b(!1qRF&fvA9ACsR6lhOhX;o3h*@ z@GsgUa9}iE62Ls(jBg6z&(1HMMxA zsw7baBV7ZLo00q6ToyVag)VFdER<+bEjTF7H2Z0~6KYaLx(ks5W)rPfft5JP`RgIKW0eC~j8*4@d?Xytnswqbx z?L=0HK$t`D5(TW9(i=1w%r+>TlPq^HT3tfc|^9RGk_gt*+f#*L1 z6bwGnwq;H?o3dQR=s&_QcFyVtM4p$B7^)!H;h*4KQJPTwk;o9uS=uN?aD^d5^}ijM zG-RBu)Pb^XB2x!q;8}#y64qV#=)=zWyOcmh;8v1Mk}05Nt`L%)bA&+3gt4>yJ0ZiPe;kJ_8@Y9LI@qZKV5gRJPT%YoDIi5UWzAF%swfFJa zJnTjbip3}wTOf=bx^3)GbdZ|s;Vvw)97s6}l@^;ywH=d|=xI*)U_*S4yre~(IuetD z6cdAxCPB1r9a01%bHxYB{YtR*7)DtTc{VVww?jY|tMQN`c_BiS8<{+y62#<^ptyW{ zR)2bo#QXL=0n9tts{cJ6gZ4$>YUsAb>f59fC`$10m+B+98y_DqA1Na6u>{Zbl+gRG zm4S|g2`__ihmSnJ?T@xZcC3Ei)A zK$47TsnV4;kwl|+NKw&yVp4FeRKug>Mj{ntV6S{cK>WqHJ8c0TAPOhu zXNGp*+g+lM39EepBs-3M4is;-W*#Q5Rj)4Vvfs~sd<1eZT1zN{(Fnl{a!D+wo&a8# z-YN>H0*~I%iV@Ci&QGdPYKlgr-ePPp`yC2og}JIivS@0BhK4~K=tV9tiJA!ZPSbh^ zIAgLMQI&znR(C&2jz}*x;1&hE7Q-AfkSR1BCWf|jl$6GDF_pOiwYMyQ7@UVsXs4Dl z*uD_Yh;&Ia&OR41IqeW;6h5R5VSdKs7{VNkt84?8E8h@Vr!_EQ-<#sGdYSq z4_9YjDHa>_tn5$EJzSEyX(VVEMhs^lm#L|~xULirWQ|O|tb02jzx6lZ7u^>V1gESwn9nq7y}=}_ zege~)^#;ZAX<{ER$0Td|Xhd^y3BmN8h(uvj!}P0jc+=gg--ehInvzL;bDO;O_@+Dd z-Gzz}#!R6vv?zn5--ek4xx))eOZ9?xc(DRa7~i%6DR_q$nzq@rpb`KR$kts^F^2tJ zvUOw~qEa-8%dA+z{Xw<+8H4}f>-B;mifXfQy=+Kw(#WVz~e~l80UjalD}y_%=ZNu6 zf>9;1WLY=)fJGX2t2?aHXv7^jf6aI-(-_~@Jid8DmkF5wPgOi^`uN(`jCC0q({gar zhK;qX8P_6ig%54H8P?2S@gdxLi#7A-><*EkUs*HX1ZZO#x*Uu%8H(55^gFcfM|30` zjCQO3yhpWm-IOY}6cKnhE$xu;>KI!ASm6^x!s4~lW(Fg#xj`5^Vb=;G`!O%4!(>51^m+8fUoM3Sg4k}gZ6-p`w=-DizOjvB1(UDf`=TL zBbU<8-c9L(9Nlgh+2w9eh-#raBI$7tNxgui4QMkbcoUFBXQPKCki+=q?Olnh33hGB zm!4h3^-D7wh9#BK1lY0uB z=AhT+I6<7en>HJa0*ID-fYBx?U1QYWUnI9n{1Cs%v#ujgPDgH1F)1 zw#Uv={Gz%RO=j1P4{rd!%ueiD#V_pI{oL0uas#vU$z#{H!z`Ol^U$*Q%)+jHwy%#_ z{DecKH^fWt7}5>lK$tKP#p~KL6KjbxJPGK~bhYdi0kLb*7PpVDEy)D*(s&P39cxPp z<8OqqW7at>FIBTwS$~-}3MR=}B^;Q{BbVA)XU!M@X5}&xy%S+Xt$Jz_CN3@K`#I{q zf~%fnYC3C@Du}C|#-Nbjd@O}zcVyL5TI*CzO=lf0<!JIm~#e^o6Wnj{$jHl zexBs}tf!!{VuXtPitBTrm*1UWpFQ8bl*>KT!)o_jJft9G){Q9$DUnJ#j*y=LInk`s zRY3+Jqh9~tAmm$F#>^J~`n)s#yr;m@U zcW-Bn>4qj2GNv6vY(un4>KI}J-f|4F4p--m_tem2G14W^EHYhWwLi9B&n%`bHeVN; z%VMvWVlgxslG}ly$@Z}x3-5VoawH;BFb=4hmSXzf(#H&dFkCLchFM*Z6fitybpVE% zy?~+R!4&SeZfXj59D2JDc8A5qLBbt_RY8V3E>JA?lf}ipo;(OnOv4@5MGSWg_I(!a z2<;g7Ee~RZxhDXA1_1U`0KA;j0RS3K**gG=toj~M zMZ2dsY)9hWi2xX2VMIrO=)9LeoMBD>IYt+u9YL#p9Ate8G}g>_sC_&q02Cb>n%O;c^;sCAJH^HJL}e7RI`j+Pvbr~=j6RW*`p|JSYm0$ z>LU;ZPPcTWm8G#Q(FS)6%t#>hytkMkta7I#1dAT5`qdJ14c7C!cN28gBw(@}$vO56k%F$_X z&Q}+T6_Q0?9q`|TQ zz&Q$lon1Qsz_O7YM+5=5d`|!z2mszjP#7@q`;GuGb}s?A!m3{mJ9YQn&ewow#>csJ5olryJVw+dZM92OxPB!C64Z)g6K4_`QT=@}2<50RUqZ0H1g104kpS z`QD?7)xNYba%=Wf%&?X?}fhnx9qwA?8lJ6a6rcrlw~wbaloKY-^Kf=!P+c z@PA{99T0GiwTfA|_Kpxm|3oKwFnViDF1OP&GQN176+Q*2PC+%9p`DlyI#H%z{zOk8 z&k3{|Ki~>otekQ91_3-Fx$0SNxTq_*7!Q*GD0(8-Fx{tSx1*QwG!9I06DaygC4b5+ zIrC%ASMsA{D>+NPnuX!4ih!CTkNzztrN2Ok1JT>rjPb>9VA2MV5%3d2I}5OP0G=Au z=G_JvSPG|JaNp5!av&p5bd}`S;>HV(>JHz$x_UjjO&qCWoj%8NoIv2g)aThLz@XI zFqjgw3A!YRz=t!`F2M0b={!RWrr+FaITVUufrJ<9T)usmH}!ft=U}l`)j(t@$8>(j zJH4g8y&2lbfApD=*sn>>jC8jErpVUtCL9~NOLpy1$41glOFlM|n+n2#^AB8{H&-cX z!F7U@IAw7ew_v&kvf)|G;Qk-h&IP{i`TqY&+oM6_1TA6h1VQSWT1!GZsTSYp2|;IJ z9T`SVS!kj~FR3JLj?<%cU58njS+_AZmtQwVdeNJq)TrCk{d<<8V`z2s|9rha-|smm zCkcN0{qtzg_x8EGZ=d)3{ds?G620;mLdclugwm1#u@Ir&5J_D^$%vSvASZUteG%3$ znmS!XQz({tm=~^qbg}=71C`jq9;Son9Whl)1Ps=K(VY`((+gu!RbF*`sWpqRq143x zMvyxGadn)7q#b&pSv=cS?|8n)qLOIa5mtXr?Mh?FF4apVaAUeCo9?p{MF%s6ib$czE zNYG=m%^>D7n=@#FjRiEy)cJf-Gd#|wRR$<(Tf778h1*d-`tTksuyRYcYxvla1j42 z0Jhyr!_xwCCG;y*YpO(SQ~}k=!3e``Hh>e7AUdbrV16(#rQj4p|8C$VlT@Z$5X;}> z#rtJRwLkaEcPZ|_0>vr~@fYdTgi>v4sCTbaLyaXzytY+jV&+Z|=7_mqMOQK{8YX9m zAwZFdnWjBbCq%TjcHDzt{>NIjm>aB^6@aQ^YOM0p=$uN}nSskl<)$In*Ma()&lF&d zx1j`#xBd^m5V_o_nQLarf%$SznERrcOYHA3Cn;*94>sr;QXd)9*C~@c#{v~%&C|&Z zQ*ZrzEBn7VyO9|$bNbLX5GAGCWd7?k)W<>JExt?V>D zWTTk?#nhq5p1c0@}>?E&#&yNr^|h6YCZm!flS=)xGi4Y^bK(v-^r#$+su->~(6-8L}I zA&$bjp4o*N-h?6yk5cDq=H<-g0ec?a?AQ|v#6|=RwTZDu19Y>P=AX@;pqV(5g44_A#u2F;sJ-t9ZJ;3o&h@Kx-rOdq-9|;ve*@5 znS6dad2`cGdD(|@CZA$2`(W-D<&^O;@fOxcHjN7N@1K=_?=b()yo?V@4Ut~M@dGfj7wxLPhP-eU(B9P~wc(yYuo zfoL?7go+p8|HpV>pF;uZ<>N7!A5V3z%v%chKwhgn`KVhDpB%BnQ~S`=)91$|Kamh$ zOhUIxTdwzJtJJM~)w4>__l0`TvlYw)3abYbqd6#=8(X3)ifaSu^jvPwl0zOUf(Kev zs~v2kcD#U>S~DLx+t$ppgyg~CFq|}i8(DiI0NLnHYvtueU?J~ubBTjFeyUVOxwZ0r zZLR#(KgwAvzsaCNrTO0<`6dhv=YWPjR_8BA$2%A|8_9aSaQDbx(+0-II~Y!5_RnT> zMct^`Ts|vc>>iC!jFD1inxP2bIF>2vhdQTA+)RR=g!J=4VOkNboWeI2zMF(tt%)z zd}(om6+#T9r!`t#4`1rhXE)`TENrlH@O=DLM`{ex`M=?mg~BHqRgFIXHtVyELHY;$ z)nqZq(hc*?XLiGUik0@wG2a&|Bnt0y1%;R&cyk(aX)tD^n`#UehsAY%gICVN5G@M% zD$L)!DMan*BYMF6$;sj8`?5ZVa}y4Yw!OPnU4+w_gTHk0aHM;@=HGwLho{^J=HD-! zJWxhe29fs<@jlhekN^H7rdQr|m)G58y}LYX7y0kj!lje^B>VD*rt3!`k8(Rb>26Kh zu?qV(TBv|$S08qW!ro5MUDZN`z;REV`%LfJqNnvJ*F4?JdX!7~&}}`+1YWWp<$GNG z)L)DS$3DtJl<7}pA7;^IfAu5|G^*IGM_I-;nXE?mIKgi;A^-N@>m7maLCf(~^NCd%!UWA7G?U>V(Zb#7X- z$z#xG8}>@O1r7ppiutwv0NwVrWDomO@}g_i-6t~U&XJ2zqQqN{D!seAN}EZpC`i4! zdS=>5&c1Nrw5RY8_Fy0CM7SW36({u0sLAOGPUmU+rPbWtp%N1d7u#i#loN;SI=#qV z@sE><$w#q5CKYdC;mBz`vt|r&XRq{I-N*5T5_vuz;XWere4G+~#AN8>9{LzRnEoj4 zu0?agg(NLYSaK30#_^xi6io}3oZQ3gatV3BPJ!9Ol9QRF(vp+rE&E1WM_CqvFdlMF z2cKDw>fO-UU^6ti<_itGz!!q}3+(we^NDD?=P8n@?DUZEY?K{fVXLx3V#^L^q@u+c z%MORd>9OtP=BVOq0w&y=mJHI#!vi27MoTu%Dsn?RqM)(u{FduMQCD@@W@rW5C7BkEjlM^jU9JbC_BC(3M)h%24Orz@c2H$@#s;OEF z9TKugZ-RFbd*g=|;>aMjVxZ?j9fBLe>C{K+0$e5RWd}e*;6SC$S}skyjIpEtu!V3q zSZ`Etq_d^O={VTRy?Pw&%1CwqkO-Cfo|HQ66iyD`Q9X3uYMv&JemUhrwb_t@VTJa^ zi{-nuzwlwRvd~yzq9QB5>2y&W#~vp}Qn0RM(*{mNQm;Zk-+xdBh#~X6Ku$yE>KnN_ z@pl5bAOPzk9RK`w5ag3eA#@U|CrKvy#F%gB1R>(ou~0NbaF1LBqjPqWcmzmF5E~>b zhN*USOMzL4C@LvHaK%4`Ak%%*p}Zh0g@`J$Lg49qb$}hg^ai@RGGCr@oR|MEFHXM! zEFIwtOLe3!v2sIdIaDCxcs+3KqJk!*|W)%9N{m zAu!^i8iyqXgK6QurN{!tvnS_S}sAt*cY*+S)KJu&zA>rc#YjinAM(k6512 zGMGuoTKl<`Wk{gYZwLBzjMnYSXx(E{BQ`4cj{@nF&=+CQF=;Pi3ZMxpn&&2K_?h8H zHKjBN_1a-n;;O+OQ7y34I7`Zo3AXIWd9#W^{aW@=+1JZhTXxy>&{B7hG<0>`ezG-{ zpRgeVD{&ZQ?RS_%WHpZpawzp;A;bV4@g?^HNMfbOvu%I0^)alL%kdlCS(wc}RM0!O z9hvvyhTR-wFJkD{cFL-$OidTTwvV>%hJ`c8EbVVCk@=+m-JUo1Q##0rOSUiWDHI4+ z1GaO!mw&|jZhPNk$elx0@hO|8YB9}}(1onBs`UYF?IiSS4N*o?rDj zZV9c__-q~ee~^ZdqN#UK>b;q;X zl#&yH)KH~=&>u{l2s>whtdYu<-I*mzYDVP}@G|Kd+>ubX=1O@t*-m3~p@^5e!@{q} zb?Z_merUbnDyem`p3X1C3=ZuJ_E}i$-dix?Q0^0j6I?-ImwM`BR!9LY)ts8I+SIE< zob2WzNHr!4%dH$m3$8lAb*W{G)4_z-Cxl(<30a@5OC92^-RM5V&fv1HqMquO%?#DP z%$+q37N&!sMz+wt>KWlw+kp942=5ON;kDZ_)Q9G_`bwG}UFghnIA}YzbgH#qymr?b ztK(~`<18`$TZU6ez6Net*Bq#*>NtA~us_tNsrA5Ta&1l!_0VGoXIJ{?7!=bqL~Woj zI>Ktm(B_i3UNF`Ny@X5gV<&lhN_8i5%MnoUc)s-9#z18WHNPK}hx3Mt7%T zfp}mR%=@q^t-Ttz=VeK%jIXewgikgitK9{8cACs}uTe77PSuv5c;hIG7g-e{o$a)^ z`mTw)N}J)Ef(`W=`Ec5Nnp>B)KpZ9cLc6-YYwCkd;$+}?H;4f)S$E&nIUd3L!1p#y z)IK(xF))0K4ViVZE-Xw(50zWT0)qvtZ7WoycH1)TYUmgkD# z*`VjSO8GDuwU&NvX`NkfEUmY6kCw`e=pgvlPSCzOO~-h|$qmX(Ab7Co-w7$1pVT;H0}g9DQ#USD;9d~^ zUCsBJWDOmCq5#2mrm@55=xrlCrLi~4LCX;Pv>N41NrZq$b{$<;l#ttJQ zuto9TE~O-cQna0^RcqUsh9$6_sVhO-nYt2wYm%#T%KTp~k{*^?K7mJFk8xM+Q?pvz znXb0&Oo6h8L82ox2Q_Sd5H`=>_k~RJv%P8W=XGivt9-tqB^5S}F(NXy5lQVt+HWqr zjxnhUM}i%i`ddMr4*@T%&=_4TS}3}=1fzV%po&yT)5us-YhKq+-jB3nRoiCb@Vume^@_vCb_hr4Fm>DflHZ60 z(D@5Qh|8y3MEhUq=XNn*yerxmka|Z;kv86~JTZ|zV?Kk}gJxsNkouz)F0hzTQ-&2M zF||Kbi>V7#*21i^LZ>{8V}xbhmMN<-Q`R#dWXkGhYb(cgv$cDj{=c)e#J#Y!o5ol{ zp{?DrixnbU>#WjOgs(d!lfBs5KUz7mwb7DHLr>e<$=_2o`n+kc%x4$4zvS2EyaZlJ zYHv;8{Ko1Qp}+@E&8AP_@7JZE|8*J1QU(fv(0HLuUaywUnLOO0juLV{{F~|5l3jfm zNZcw`i0twHRoVF{7tX zXUIiJq&YXKb$v72mYT~H)!tNwU-N5%-o;EL4o`5FPf(<=Q^_)Wl{tUQ&KK2j>fQI} z!!l|HSmml{%N|OQ>{lfpf#|@5r53;7v2iKIDngSON&l6|MJzdXDXtSyF7-pFR%>@T zZMr!wIiT9YD7;>STQzLpiNR}d@RxE1XH2hft;Qzy8$5cHJhGEccPuL&u>k# zeKfD!_(CV!S}?w_S=3~FVUtlcxFQE`Ps6!(?u3#3L8Ujc6K1nOq-%`5N{10W6_iB)Q9KW?P+>_x4g+9L&(^2sce3 zU}i}fSJ1U(>%eGRRCPc#aU6!=lluEk`^4PIVwh4dX}8o$!@Vm(Gun7ihf!oL^0!^| z39OkQM;hHzY!R)RrpgE0czGqBC+R=gGj0DFno zvSF{z=B}7CkI3?)9R;YvT-5pm4e?R52!ub1?(CxeW`XGWbJi>;r&u<{&=|h4dx1+$ zprugIL+SjM4RuxeU7P~ejdI>0K>&eazGKVg;%M76d!qni%N8DMg9P7zLp47Whtzl= zcCnYdF*wD5PMB1_V`H&x6=5x`wX|8>wZsV7dVvlK4jnReMMps-6P|Z(cGb|J)T5#r zIm}*M)z~~pxtV{oy&|ldvFdCIAnK6mQn{{TCSvl;L`@_UjrGFxQm=Bw^t}=zABeV` zqWDLm-yg?Tu53Ec+qNQ1GwoH6{d8{YVCuIHxsVy$q(WycSNmKRAIbdqM?W;_E`UMD zsOoxEsj3r$uR)yr(lCKoaSW{3!L|+{0g;=wxUR5f7FUt8UZZ*8c$#yR(UH zfZaOhrR%l%HR-q*)twY=QO8%s7)GwT>;Igo?qKOXraij4ERpI`Kdf6tx2vLB39$iE zxvJ@0Nu%pnv3UggtZ~oYscm2?w_!A3R+`TJu4XUOUYX>5)kpu`+e|ONZkJxz{9jh= zUt@(zOJCoc1W91(I$x#1&n;aDrO%HZx+>cC3+|%V{LCmHv{t2~q^66ys*&Cls8YG6 zCC$l0sI5wb3~dV?<^KecmXav%1@GR$2FxYVpY@7V%jVspZ3F1Hr+%-nZOc|3&*d)l zrl!+PzST%R$z7hf4U4#mPEd}&p&3E=8)cecM!VM!kXHrj)N9$?KRTzv(roSz}gVr=V} zw&z!1gZ+8d_gdb__qJaZB&*}#0kGU*N&&wGO}BRboa=zgZ{WAEsiM~^Z<+MTwzO&L zk#0Lh+jP2B=cE1yx4_n+=IEF=neFeGKY6qCY0E||@+9dB{Xp4y&V`}-Tl%D{{% zm8_(HPQgSS2K#Vchj&u6#1oL8J!*Q7XcH8xI@7H zqC1M{k&1u2K8uRw--L>{q;o*Ua#7LrUJl3^xohpbT5=biJyn7(*=y<*ns5K4i|pYS zem&;@yfBleh>`S+*6Iclg1aBYNKKQke)s}pw}x;?Ai3_6(NFMqvvbxzkk82Gv=RWE z^=4g@!4)RBYHEwM*IsLb(k6(EGl`&eoITV{wN-Gf-@#|Y?k70GMmzdGuVNB)RbHY2 zStRT-fbVRIxRcvC{8pT_miK0|-jPNT?j(qZ?p0&4%T7uTaIu<;NyhLE%hU$!#7M$1 zOWxaVZ2mJrx@qf!b1`dYZ6msu7ft?$!p=utkI&1CZ(XvjpsIaZ=?U!d1Vw3OP<^(#sNH|+Xq*SZf~qWxjCHX z9&EY{Qb_a@UL7Cm!4FGh&LWD4%=9&6u6aT9!qdq-Bh8f5-&cWblX~e#NSnq zYh}Mu2mr+g{plsOM>)c3afNz`>{D5+w8ZagYqDhz$c5mz^*L;uO;?3<$I@k7d${5w zXKHhm!Cw5t0(#BzO5j4kOlAl3=tljm;eI=+zN0Iu6QBZSudJ%Id@HN!bq&ga3_0Z_ z2OY9n+CuBT%#EFTQ6vy~y$V786EsMiD4Fwg#)FTM%Y-Yz$)9pT$;^F{q{Bo-aYFE&PJdY^(91W^k6{h9_v3-F)X@v9nCZw<-6 z`#RCQx6h0R{-MAHAvpjTi!n%4N*3O~Ok#vfkW{xr4LW10mp|o9b%`1XDuh&OqW)Zq zG5dqAm%oZ1o3RJx&zuVv@nbRO{>;-rA;hi2s(ml#G18Z4cwJ|J{6%ixf&$N90(4UUF&y&LyX!Z^~Miv97}n z=Xi<2+LMk(rwtmdOT4xyG3doZXbc=wd4-CPd-UTA|6Q{iw_pvu1P-tVUW{&v^~TSe z63{47coQY4ZPc0mq(`f{1Y)_Mn`#n?a%?7-AtX)N9z1Y9ku2_b%B##BGQ=sf>IXSvccZ*_^NUI zQj`o`u15Oe7UGhHwSmw^hhdTOkWrT9h;d(Rv;B=6#G&!^XH3j^nmbGKtAqsVg}oCy zf1`q_N(HBVTkgt@WB#f1e3S($j;9{7l%+03WzP3E|Dp??aYff8)f@UdBGsi{z|HcK z@(V;jF?+dv1Ci8E`8MBwuuB>KP1n-?no)u|?XN+y(Xz2hg3l?a`axXl5eO6DiQ&!E z@TMWWNx!KJ-_(aUE?3g}CE2nW*=s`BK;N0?WOD;~`~`b{2_+ztv5TK9aenm&p*a63 z$f9n(2x{W2n_5Smb8c{+H}n+WAZn5E!4v(uw@PFf@`?OZSmqDhM=%84U;k##Oma_& z_I9<*#QgboXI$>>GH^iasAnnScUa_Nm$_hFNSa>y2iSwlFYPXiWg#l%b_4z}-mGZA`Er!a<%bA8 zYK2%-F9i=3ij>1YaAnV($d48pSXU(gOKb0Q`zvOj{z(Zr_K7MgTwRfy7P$_stIZr^ z;F~G{5WtN7W(p>?Ne9_7gAr;Z-=(ihk+{ebaAOaqOLe|3Rm zq`j$RVgFl2BsEFEE|J&f&)K@k&@tT%zhaK3wMvmIx{;$E$pi?D^;x_<>50Iix;9Ti zutvHz8Tsd7@?fAdWflw;*p6`$eO?u#_)Nu>=*EBN=UoU)84Ut!s+tv1{^j+{{8Qu5 zh6Q^W+K5OQ`XuT7pkQ4W_bs>H#g}_S7k7iMNq3d2k$kkY))dL4(oLe`CjXSh&fSPI zdZBo*t`^8iMy}WoUja<~+5sOxw${>3R%)voqQdfRwr3{0sL14?-ySVjg!Y*ja>OXP zEMi9THkX`-B7bF5AO+Uo+he6Oy#(o6-C#s=P=Bj&V5xr+HL5!@Q^EEZaRbxU2Qx$I z%emSImbxA&{AbFXk-IRj`s;n7jTeU;Bwv-RQL?c8Ww~oub+L}3s5P7-r$E(jKXe@y zG*zJJ%b2LO(vDr!a9f9RP}*9%h9h&qZW~O4Tx=yi>Y%KAJ=)sL8WfF*iLN#3Ws71q zeU%q6C^_2UhT?54oho7{)#-+b%|`h&6FdJL`i!(>eQN7yq<6$ZC?4n~6JTZJ&8iQ; zf_?_3MjQgLI&{_PkBq0R)$m<>Yid8KR-EB_IIKU_J(2tFZtLKOGaz&*B_KCQE<{3s zM2(9K>d+V@3vUQosB0KRP4fH^&;C15IOJcXa-emIhKCfeumHnbJ986$4L=Y}j<%j_ zU*MnVp5&liZ**~nOvCek{E^cD6xr$~T~R*TO;i6`w&X{zEl?TS%_o@iuA}K%Hx}{I z1#rA2Z}#)@mkxVHLsQ{gVo(D*^{Hog1Xq$XKs1&(*2ZdAfkZ5^gC>P30AAg)xnH#P z9Vo*cLA{II-S$lrV@RG0FC<5u@h3q}l)+R6)1~wLCx7>@HHi{NjYiUgno7oewUHST zA=O`sa}Ps#TT6;mwVBFRHw_I66d8wF-S!GRyYcGQVEP)%3xe;) z3BDKT85t<&+Fb^U9}Hw58TsO&POcWWtY}tq19jM1TIcG0?D8z_T?X+y)T@In zRNxfs6u55u(i@!uFBk9&^~nT^l8YcXTJf~KoCo9|^|7nlG}S_Vgg=&p<0}(|Tld1( z(IIBMwXAXI1@dYZ{Gpzz`yUC3=9U)lO0^Z~nh2EqtmV@A^lXH3SOPTn_x+Em1vYBz zyf<6Ow%wjBWbz{X^A}}=Y=_0<$V=TWmp_o7P@=3c8wRcgD12pN=!D%#dTKv%X4kj; z=Ir{cxqtebOnti`)auwep-%1pU)TF9S;K^m1ho|fZRbc76viE_8we+DCPGS+VX>b* zR_4Od%`Ab*D*DR4qaj^-3wp|J-TU`%SW7IEak|yW5GehmN23cAK1<-{9Ujo=eqGTP zo?Yh#79vP^Q3q3O`t==~DBL_mb7bh0KLX*^l2tKN-uimUX?-!J4?2i&fdb<_By4a& zS|L{;Bx#~WcI}qspAV$l=u4v=-l|D>oAQYz=LXf%K=h#UEY|67xy(sYXh;m397B@& z6R{R(I%=JZd;|(Dq&aQKf9`V?6A&S!7F1Sosl%n9l0&|HPTA={@!k>796L3^bpOeZ zr(}=mzG~t$E*<@fYU6<8M(P@iqz0}6%2~rN*ZFVeGjh*+ZnVV-p-R5q@16%5Udy6xh z^ezw!wH?@u<0}65zSN-XJbJqRZto!xheR9xw_qmX?98+aYd#OsVha&&dKRaHO2w4~% zOiclRRZ0V>9l8R0YrSrgg(v?U;v*&V^;o&4=_Ka{-&kruA}Q#60~`O}KeeAzA2Q_o zsk8YPuV`Zasjn-HVwRD5QHrSIJ`W2zUaEILBu!GMAb&Xj-0zD_F5WI1xn z2LjI$Lub&!;y^0rY|N6%W_?65EQd*@w?{@QEo(QaygBciOQkD8QrYl{lSSQRp0iOeX_{VtZxv}$dKpA@bldRGBkH)kzr~;2Fqb&7+stp zgJtbThI!kLfC1>zZ(zAy2_nOV|8`_hjWo`d&3n)niU>}uxwRsg5i~J#d428s;-L&p zsg+10+F)i|ljV{{tfKMKPQaE`&S~fW!Jsoh-$dB40!}`pAa1bdpp!r!X05#s(lOa8 z*`K0yS}>)qm9#I@=3kWt`AzStSsLRvm_&j z(6`j&Z%wML0w!4`>nbU$cBxQNHo~M~&SHQ1ud;0P5uwUaHEOocTYZtm?>i^e|79v< zFvWKmiqMLAVM+%ze7&NQ#rAw#=|oW_c^MnL1-rSid@VX>UwvJRE=0Q2CD4sV2Wf>qmTUnI7D)?>$1LP*c9 ztZp$t)3pEO_i3a5c4be_PLfGzmPNr!9;`egWWS4?5E|oi{hNOTba7Jiwf;@`2O_Q;efmlv6g{9#Rw zJL0gFJ2K`YA=tA!!iD#u=H9?yv-|bnZ7a5;xtrxOb z_t;H|7ys;DqNV%PZGi*+m6oTQ`}EWkJ-JWD+n|+7^waLsN%wt)`?TKHf?K$irXl#y z(4Hw$$b|d!+0KE6{>M8ZvNVQzeS}<=!!-0Scgbkz0)6eKq2J%~%{8Ma0>ICu1s)C`EnkZbiv*9ud zx1--BGHe$OUkUOW?G z`Qz1&e_0`xeV9w8xJ25&5jDgQ(-LS^Qzb!zOJFGolN@wx_gXi85e9bJI;Ia&i7qos^vIlgvZrbu*30COXRj}|()|T*Wl2#vlxT(C z=N5_H(Y8ay1+b9y5z)CdMB<7-2Yd7|B%3HaoD7VSv3e)kX2U8W>WHFJ8ad)#2@Kp_ zNuj2H(&qP#3f9&T;SE+<7`Z_22hRdZwq>!d$-*P|mokSNoP&OVBCfE~OU@0Z?8_zO z!P4@j*su68_$4EEL{%$N)*jRvma15TBvw+YKiwdmYZT@ z6t_-}B#vT|vY%xqanspcdg1iHsofuS8A0*Q>=Yjk7-Yr6$Cfs`VEApqXV%6%BicP? zE))!x*^qz~+k2buk8`y{boR9pvldnt%zg$9$lY$y*+;v(-3bCJxu)T_{=(hij$NfY zigGGJA%q));7#cB`+b?#CZDWCIJR5WL9e3O9#9Gfhsb$bkXfBw^tuDE5hL~GY2oZX zZ564Z9;T5_68&8vr_{NaCnZ=Fw3Ti6ck%?O)f8bEI$oe!Gj7@aEOF5;i|IB<==dNn zp&^LmXjtg#ntmg}nG)b6z7Y^`)^gExSy$}QY=(^F5K=e<!~ClALzdtS-l%z+ zLM^xOuPJ2Qi6KkAvJm>bjmLaVQTKbnX#Rf($&%`C2+4pc$9)YXvzb>Qv7y`WRg}@> z&y&BVsBcw;(>bHxUu|~{&9AK#2}rF}mrqk*=iD!m zWuka=j!m*}VdD77_T08L@KG}DuN$*>9rKM)>e7h26>{x?0f$;P<@d%U&3tbADbkwy ziIg8x-ls(Q-7eZTN9btZSsn|bZ8{FqhT;7w7o)|FW#;|g*hfI(DK#{&M#89Jf_Zm1 z#Pes?zz^1n2=m?0-~;|gR+qM7!vj%LvE@?arGI6=-930a>Hh4unrx}5(S5A6zD+8v zVOMzpVQCt&RB5Mvnw_sWcw6yS_FK)*Qfd8Xp2Tm&%G}P%JfcTf_CGMYroDnP_x>Wg z%sqlK3#_#5t+Xd!$xfj~vV!oTeX>i_=9zjstB1EOo1@Wrvq=Dy17?bjJ6gGC+KSj* z%;)TxUG9(oo>dt)R4BjABJr=FV2;^2f7t z7X@YB-s9VkAIMI-Q&8rvjibP9VB_BW4nlKktvv*3Gmkt(lHn}__OTv{NJhNwX#)cr z%IA*Jc^5kQj6~=CmBOg3&&&%YpOS%m!>Er*>9cQSLm5(ObXhh%LK(REob0z{0gy-T zk^MI0L|?0;pHXddarYF-$Zz^*zjZW+5Ea>P_YSC5V4T>_%It4tHs)og+cSXW50_@Y z)uFJGwtKG0etURO=JrZ;9^7^dox2}H4vgCRpPrWuX!N1HVUKX0~M9yf(a)B3rsU$zI{tv1fB1+aFz? zwf1-_Tc%@Vt{%%{^VS(v(VJ~A^#1m_^L5)heQ#w>Hn_dh3wdD3tPh6?eYvnIdP8>d z`;~n5+Z5cq_5G^o_1WKUKWw_()7UV( zPoKjHC4D&Q=aHtfDbKcJKUrn<0j$Tv-PrrHEAk$e^YNxb$VoExxy3!}(`V#kO@)Rd zMltmXMs4KdcvGGK@~eKVI0t(wzw3{1x1V-CKsnEn#@{!1V|y*LANybm_jd|kenb*p zKB|;k&a=5er=E|I{2?#8a4d&k$B4dN`L& zMSGmn@uMM zl}keGxfW4*UY<-1SsXax}N6!s-@EUx0$-mbqL4P3d|%DN|(xJb-$etMt(=~ByiP%8z^2CBxdXvab;!H?!8Qf8TM?FWlR^&fP|3NJp z78&boskU_%$GaGyBuv41*P#t2UnC>v4%d(qbV&vsUx|thgONVZAA7r_5#kb4&y$3z z(~n*BA)EN?WxbPX20xm~AgN->#@cA|U3)qMQ8I>KYH&7qiAqh>nW!=7sTSEMid#TZ zq#d8jZuky%#B`Ol%-{P{31AoukQ~%PggTNau7<)=GTy|P-)LgXU4!mQ^bYZ$-|WXm zIr5b2U4@{m3Odey@~1M`5H=@3kyMl=}o zoTN5cn79hLfs9jI`{)9&XF`_C;KQi^r~rlO5^;vAC{nuQh>IN;V1TWy(f)mw*2Eb8 z`{R!YyPu>e>7oHaNV2OxyDcPku0(lu}F80s9L)Zmx2m-k#fHu+A z#nwE=B0H69qRDqucmhNk5VNU(KCQHtMS(2AvWdHDaiHbjex8FeAQ$+9_XIVCo~20x zi-1)k0L%Q^kDW$EG^LNMWa(!wD3!7T{Y?2^QEFEi{rn@9s+}^DV=SL%=QdMRRaYeE zehVWene7m=vzAN#mf5KB!HBGX^$!u=uUa2UxK%=b^ys4K?Ed{##Kwh^2}F2-$%eZ! z-!01I*fL(}S`l2m;99GssH3$;aoNVOg`bE_1YzIgnXteORlx<;5HjDF^_c~3p9`h{ zvSSGOW0fnS$sK7;HHn?Iab`Vb*J$=TLwpmtkHufe3gPWOKO9+gDV0M|Dz$}nHF3zG zOAiRXJuj0*2-IlF>*@#*@4m=9)V{JfmN*soB!kl=gQ#SMB$ZgZ)CgP6RIRge8zm0Y zIB(9B%d)NEHEG1=c{-_7pWvo_w_(tM;-KH;yH@24Ao=LPO8?zr>Qy(*D$pZ5 zKs3Wq4dNI|6m`VQn&gR$TaGWCSgir$wAv2@f<#VWLZLt)MC>l2Fc)o&fH#zQZJ)BY zB~faz=}cDB za>v24;7DHb#vpR5qSJD4_02uY!8PYP3m#NLwNNq~G}VeX8S!5Lzn5TlZFiP~myj8M z&`rrsTmdDg1xn9kkEbGkm)ejV5U>R8e8-*|bpbw5Z#R7Q6wVZ+Ad8HH|K-(L(+|F| zG>(F%A$yRhj1hyQ;jTGi5frU=Zo@y{cW%S~juC3Kiv$1&QFMSR4;0;~q8pLdZNo!B z30rKHO?R+-JzIdTy80x8jR_OV5%?1g=1(-5KM|O7GY`QueTap;$R8Hj{CiI7LS>Yv zh8M)Z0$s6>8z@_Uy7%2JbwzH7XB+{SrHdnQ*9}fuz}@UsIHw{wPA?hx@H&MCuv_BF zD3zZK(}B^z$SwIJPWxg+^$h{8`omHb6~&+~W5frzS+nF9ai zN%Gib$IR-?TE39#f~AV-wmImX?6HvrgpNf+FEbK^YE9kG<}F{R$Ys7vCj5Q&$zpz) zmq6-LF-q{OPseaR&t5O``g-#BkMBnrJ^TA+ENS@KP-UXjM~7(B*3pC&>FQhxbm>Vi zfqkQiw*E#6M^gn`Yuz0qZdy|yF`;W@M+kmwsrV)rP9l*ch_C= zvJdR3^(;NDT)K;DNzaiRb@X|PAIZ3hH6+RN@>%p?t_{t@zw$qBxkq`RIL#fGQUM#& z*~o339@Z->5A|t0TQ&pOZ=mq7)r;|clK&VqJBGqAHcgjX<;mk{^wRRimO;^;2aw|$+RJy1wQ&p5{ z;-Gz`n?kUbw<=X?mOo&>Yz`d84IDE5RgpuT5fxV~$bM(Vp`|n}{pMgsZUDVRm8FJr#CtkA-1c&7@j435(+o%q}Rer-F)j>0f**x<=|O>|ti~ zjm2X>HC3>&UT!ZPRequmN3QD}nKv^3a$AGy7Rxn7{AI9rMWl&O`ThmxZN&e7@?Fl) z+5l1$KmQl|SutGZpEdmx;)@q-+UEDW_kGUWJn_SA{()`pu|MhSyvv))`ly3KKgW&1{oT z-d7+f+O|64M)+T5o=9~>^Q&K&-p8AHNp_XSzL>#{89 zXIU<63G|QQX1Z5g;>Lgaf1EDG{8`gBBT!ho8~NgqQ@A7|KTw&pthLnT#Rna%Z^_6f zMe+p$Fhm`ZDTiLOMg;Uq6z*n#v2jv7vZDj4vCr2RP?ag*@5nWQ!XXs!T;HSf{Nq^U zup%`G~*#YdeUan7ye$W-q^+-V#&grySy&ob;@>gN=7COQU(x_ zdI_!4Ww4S^tM0V?lnCvN4S>Ll0`Z^LI99z?#oC}L3j>!|Xb|b`bFxeju8;U%8LY&1 zdRT+2yu5Ov5~@pxFqGNCsxJy%WYB#>1{Wlvr1kjjwK8(oWxJ8GCqt z#{ZA`{~`Z7`Tt(F|7iOB|H!XP-uMRm8vdj1{5tSK#~Q~k*58U>YtHY+ubP95UoVX7 znO|eR8NVbC{+)-0{K{d)6%^k2o50|8k>|^g{a=)SYJ;0^Sby~P zcEKk)`yNrcWg}%zQepa`PQaCvnYXj2m!QpFiNJl_SSP=k`2-0?rV+bD16QJ#m0KH& zhOI`*Jk?o7o#k|paI~z2sJHIAH1nR>5ISjA2^Dm%Mh>5FiPHfsvK9O1^pJR#|7tay z*Orbw^5+}S@2WMu)9>*o!f!eBJD*zrf6`AawGR3zPIM*od%7q3jf8%UGPvfni6m!V zl6G>xo__m0-JRI8{M)>*pkH)$!pXxo*ViCmpi}{;v~#v%9{0oU4SnK;*$thjt{VEO zb=eKwdJ5+qKtunP|NaSpTbE&XuKX^OyU?<6s^pizhJFJ3Qlv0zv&v7Kn4r6)!G$r( zM^C{LxHYMQAHfe|M+E6xc2}b0z*7nKtVM!t=eWkTAW9t2ON?A=QK?vR>{^zN(C5@D zi1}35Z725fSR%HHCE(*%k#M{M{exGrP-d-mV%IC$4Lh-4|JKO#PV8$*r-~-5Vt1)4 z_`q%}+KGJ?b+4jj3eT41Q?Y*icqQ+Ew&Sl2R$qHgWvGV_Tm}AO-fJiJfk3RS@`#D~ zcLizd!nCz6?cCr!l(3N#hqUk|0tX(Yp4*B2-(#(}mW-VLgYHajxu6Fo-*iSclVzv< znfu{PG~s~wk>lZW33oaAse@$j_nXV(iGe)IFtV7!`4O($4xM>vE`*|F+!@X#{^C1a z@TLq+UDri|<7ak9?(V=UIa3u#@c1qgY{=bN3UZeqx_;SlAh)j*Vvs48up*xP*gmi& z;Y7?<4Q29b&;$onSdtp<&3a>-#$}SN1%1?mMA*tjJ_i)@8}5!4t?F!6{SUeN*RtJl zY8W+K6|t%4yW9 z378!}d8EfVR;*2hyin^eXDNvxr!v zNzqNaV3w1oLA=k8pY|GCTNmdq({H!=Y2L7oZ5`1&y(Ot#wL5e>1$UXkmfDe)kyU@{ zAo@;O&)61-y%>JzZ>G2R`e^F}8a$+^TpyihV_%9f^0#TGUR|ppxbwZ}CCkEGQF~l_ zesug=iP|;&CG4lK^_FxFXM0f^=&a5!v8f+L4}4PJujczl(WOfxJPc{G#N*e06rErn zo9ts9&u6UTofUYgd$;ubXxYmjMbBE#^)0@?&2=N!_bF$@Yui~H`h=D<;*G5P_p|P| zxchgN{-Lb*f6lsp!rgyBIqwMAzq;q8)WiR}4P3R&`+nbZ@894Z&l8sMUug<|Veco< zf_Fwja6<8&Ae1y{Uf$-Jk`z7LV;(D$>^X}ax$So{O%fT!N={M)S3hWpdi-PC81W)E zPYGiZjN`Mr#GDG{sr)=T=P=#Se1|^cwQY;G?xDy0mpC*bdTm7ap-9U-75RT^R3O+D zj@;Llc|$q1jx82fR+R}}>eOo-@n@sS$zX)SI8W~p`3mi$aqR+2WfP|maY4k!#~(%K z*d)B6FL*=O(eaM94prX#&+*(#H07Wsp-q7m*T%1*@!KlEk?e7_R?twTx*0SzdhO3e z=RRz8Xz(jBx!lWVyqgOf&Q0R$%pWRU1p`eGc6}PIc@vRrmO@>z^(c@S^b=j;wH1j$ z3tu+JW+$+$Qk$(szpz1gvbM^Lt4l*$^8fR&>!sCqzLu3FKCU8B_#H~2JXQLV2=ZDvD6J!%zf(BX z0^ZUxbn3klkt11n_azEpQEAdY9Z+SOJ*D-%;p)6j8S8x&O; zZ1wn`j6_Q}@S=-;j?Qiu?^-ry>1crtYdWHH57RfRBXJ6BI|CyL&tK;3jp_S%i7ODC z&!-axz5-#{#&{2a_&ZU970}6EL|5RVj%M-p_OZ&28K=Qdr~%(#yeunNIT$d!=)g?;UNl)3Wqt6Q9vlfXB{~qk|ys z=qg_4DJpatVQOTz5=hEwk^_o3lW+XNd?z+^1;gx(`^WOx3Ts-r-bU4{L8q?u za%6bt-~DHfvWgRt86OMoAwT8P`3v@l>M()sydIQ(Z=VY9(M4e)gM^#%@W#PN@zfE^ z#?7xi8YcY!>Bv$bIs7`#@e8)gEt1P8a@&sFbHAj9XzMy*E?E`pN*HZ(tb=cw`(geL zgu8Z@k|jQ4O{auj5Y2i! z0;mNK(m};L)D5mph95R&7pUHHy+`M-c_P^l`yN<2)uKgtRg3Ud1z1)& zps2jTutlDyrl-V!dKConAdrO}Mfo$Bkot18?MA8a#3_`9D5F=~PIE74XKSN#t?!sP z1&w%E=|S2HK_ICr=ck?|GPA0v~3{} zdT|sS%M5=s19juU0(Qy8CQPR16VvcZEFb=i^SqT~YT*OlNuD?jgvSI3kEx;*leq>p z-X4(kcRMm@I1ghS zZPpveOnsVL5)bT%UKRN#v#u+vQnOWqcVM%0YQoEm?ZDTm@NdiH5zz75(9wgARgR93 zszD+;l^T#$7dx=~w2=7!7-1BMzhL3}VXvgl24CMh!co%$C~RBrl4pau!R*g;q21bY zMpA9@X1Db5RjI`?S${l&7V~OX_cOP>JSJSa*%P+r43G||Vpl%f1dRd&F!%LdobdcJ zwh4}$?@YSJ_2#57w-K2= zE`hP~Ma$qsjZX57-q#c~p(M3kU{gMJ5#76zgW0zxq1?LYnlK z*ZGiNEQq!2qr3ik*V&75>90&Y7P%1wG?L^Q{k+O`Gp=%A5IMx(wEev0=iRBy@;9H> zgtXSVdc@zf_8Izj{tuqmL<|<-G-!6Vl0Y6+ARn>`N5Q;Ib3UE3IUNTJUcbfJk|`~t zOrsjYq=swjF)XARxSgChE7^)ZJUlw<%Vyop{T06ku+Be~3Y~L}ZUpd?vi(twgF$9+0cR$ZLycaq%uzyR5WA{awC;6nudL*2SRZ$nR@nP)_{I40j+8CXN4v z7-*`5*RGgy;w+~V&4*0NClSO|fj~st=GvP;DB@45Q_@8)o@D2V)CH0YQ=?(r4VH~4 z_@~<0s4XeH#pJQuYA{;6bGpjp5jxUhSN0&R%F?c8>r7?aRDUy%jSA<6BYpm?@<5Hc zreM-0vmrP2W!%&_Ye7O;I@F6#Eu(h>9#gy7`dD(nFy@2A;wxhDCsRKHcG&;4e@9Th zTzGj}FjFE{#OzS>Nma|ya*K~pPYP!Wck}?QFThhBo5xm5qswB+en)xnRbHIsDK8KE zbQm};OK}hg6H#zStE_@h3=X#^f5%~n!FFlCCWrrjkx!8m-wvYIG)k0W!4CfF(1{Ox zI{6Py28Do$B(@hVH$mPjlRpCcII7-Y5IOtSk?Kcmpo~k7VorZSOJmy&bH<)J77rI zmTAUCeEgD+lP}VTFPpa%Hr0h8FcetjiYdoxHfXz55rW`m=BGix2nz)L$sh|1{bfM$ zpE}g(UTe~wcl)F4*+0U)PJ0K5QRCl3NE4CoagkeQQ^1S;?>?+C6ig4wvb89!Ea`1s ztGJi>UmVcX@}AW?UPqry=)>YZ4q^YRy$VMd@G#JDXL{S{G|AggkEQY@p%{!egwwIQ zQaN8}eGQ8LJj75;7CtddGbYt~&_@#wGWZGy)Mt98_4=CCGcEZ^&plJ0@LrS|k0I~^ z76n|9ItfYkKR?)g1>4S70$pJmPr47pOvWlw_aK%2p@$;eL$h^Uj(m@D{yLCpk_7%b zn$yND`q>zJgM%1X4lh+fk|9b@3S_ujY@+RHHI}q4=Ef=gWZ?y8Xfg+u1uQ1gwoCBH zDM67pmFgwIMR&#iz3hZ-3|CUn;e+htkf7uWh-y_-*-bK%{C+S^1egFe=*9u8+zN`V zaK)aUT`a`pgNk)aSB0+)L1Et$2#31tYoc>Unz#jxnJ@A^>d<#DPruTm?W+)Kl&OU1 z)F^xTWgwy?4GboFn6oE>8I%^O!C4L{>_=_)9jl*uI&YRVHiMbEKd#}0YgxpY7Ir_v{tmhMEQWjr|g7EKY979Wna7aJ0Tj<#Zl9IT6QafJKp zpVAGmaW4mWZY^M1?qI}_wA~YCEWFduu9Mgs>8`VuFaKWyFTxcWp$~{r#G)PrfAX!yNR;2b#Nmk)0 zy2O!iRpcM^)1EtzpTq=$H}#)REkWhOo(2c3Qw z`_kdpw(S)(!igNfq~83j&-04%@}@=8z=tu*!e31Y6fJtEK#8P@ige=_To=w_19_T? znkKjzm5N0RkC~%m2Dq(t{ogGR!qY_KX{A-I{WWD6?YK$Wag$$NCwJ{)=oIL`Dh}a* z2`V@~x+D=9_k>22PAOu0`Eh#f@w!Mi_1u&vA_wuEZ#(G~JQ!V(DpzAkjwZjfioFE| z|7u&zhBK6kT5B3;A1O{Be;j`7ybGg^gyf}ORs)MKN&Qtm?uarN(ac>JdA$56Xb1`6fTcKBN9WzewNQJfk%p1BQmKa0eeO!@Nlg+uE1hLAM(K$D9Q$4f;Cpp@B zwO*n*V)?6#+%9@?-Gs~l0j*cY#YPCYm&+P2NDMk@nMKrx=qsG6Ef6FV1(UV3P+0X| z?6gE!5dY?1x<&><=Kb=ab2$^U73}ll`Y@!?N&dh0Lx7?b(4}|OE#4P%{&AgTs#Y>pD_%_%8eoi;;Uoz7 zHr2IPS5e@ifa?sp2*(%K#FtbL-5g7t4p+{CD@&r+YJzGkv42h5+tD`LEL`I^QjjrD zfSc7bC-7EP~{(KQo7MRd#G7Dp;a_VBo%2324vD zUn0002qI27L;+s(=TvX#GP#e$E*jyc6zO`8t{9`ij2;YzM?|~d^5583d}7y4V;hIu zohR-+X>Y-`+)K;^!{ZTg>tCCQ<4I|8^tKn%B5q)qc#**tIqjGz{ItV{TDB(|S&$kp zb&wo~4B=6!EdTqzaNeB*YC)}Q?3`R+DPHpNL1wCKET*tX7j{uBF{4C7rllPVU! ztDAol$lbJkk-MK|Jk}h2vx?k3>98z)bDfen`&ukB+V&i+KYVs-XYyguhZ!|#CpM-J zEg*2NTB@M_IB_iFP~f7U7jXE?f&9hS?4e9LSY3ubq88PRBOm#0X@C*=kEiq zTBMuR#&Ym|Sn9D`{K1o`)@o6+*%$6rKI+_h3K;psRmIiu&EC+@OwT1wD_)o zpZHddg5~NSnF73*o9dw-Sz}T-H|(}7dAhl}3)DlZk6oGqYVIJpUf;iw_MQN-D3|f{Aq4pY!LH zII3?+T?Uod|Kw~g{uTB%miPezzAq}G=_(MJ@>7RImbWE*+1vs~- zy^3M1T-vyg*0nAWN$}|x+BH~Y3hNr+u>vRq5gPeHiAbrkB}NU>MR5rUQ?Y;duQT1E zF=0)vL2wA5DV@fh#55gjC{R1&5`F(M3)oBZLkfy_Aa>&1hZqVSHEt!SOKIc-ARd23 zKos6@m+_)uxVSi6)Eg`$&7c4sVE@+h+?s^+(;X0lb~K2KKWs=^r|lmMBmkGtCJ?=M z2%O$jInJeN8|;Dn%^>OCn39DroDc>CEU;?*pqTy7Pek_ovvmj#l3psOLqPv0vfJBxQzHF_m7|N< zT$Fp+X}Igm5xoVdB~@x!)FBvulUxAG?CkI>1inW4x{q(jUBaGFkK*I#8vrr4y6`(M zNycjH@ysU@|7fJYsv=9p%6n?&583%3Eg`^N&ft=Pm(=Egq z$%@WDNUv4_faz7wZqg2&WR%nt{ zB3EdM+NmU6QH9QP=YwMfUy5F92j41SlbGu1D6BdAsX&bKoWZ(bIMpV3L|eDhBfBSQ z@02*k!NKJ>jOjmbAD(y1Wv~52AADtszh7AtH=D! zN__2sy0>0|`2y$$e<|yyq)QyCoHCcFt#utb9Du4?Fa-#EU8Q(n+s*3gXpN8dkFhbo zN03(i9fPA2ooB1lpMBF?xlHf8wspw;%B2>GAjh?r3aR9v|BO?ZLait0XBYVwHfMz= zCW@8C=>VWpSQ=apH$hHJMu@KR=)^LQeOw(AbfR;1qU>r3Q-qtEp-W;zSK5rX55z7k zy6S&f_{7y?z@%%=dy(J4nkO}X3J*9Q*F+WQ+mO?qk)FCO zSX)10q&)`X8;rg%0cup)^CYSKys@}xx*59F8~V9geCv)p;s_Ra`Cn?9B3;vLUk?qQ>6X%V z1B;1hmdL|GjocO-{_$YYerD8p`OkQ9E^5JFh>Iwzd2V1v0f22C%n&|rCIiR#X`50f z0ylkBxN?%X^4fDE-)+IBFQZo2EoZpk&`(*sd*$&B z6p)uPUp8?PsLeq3w>4G){NJT9D_62h=XZs;X(Dql3zzW)`FT*6jQkvz1^MY>wt1|X zW{Uj0dA~tEP+$EFJQn~HJg`HPt(n% zF+IY??{9CbiFz#AdW?l@)>l8fS<@8JBu}O;SC5!kFHc#|_!N+St}%if%qXFS8%=_S zgiXw8*@@8&l8iVPNk^Z~zvKPX+IGmnCLshCHiKQcFib}NI#%kFwvp^{50R%&a)A(} z)U>G7oiM-I!qd*6;-2~Yo1vW3#w))-eQ5Df z;PqVl^Nhg#M2xv#V0U5LLH8Nk%Jj8EUnOt}10~aS34r;tCTV4{(xn$dKTZhIKn^>C z{2?mc%DL1gdxf7*VWrgQ+8Bls>v^q+OK3f`^vhQZA$M*Ami}IQbR8uuedDoM`R&0O zE8p0kxw(5#ayD7sf7;0M0T+{I(Wcm+vLHj23xxPWt26*8J{oBr_y;4)e)_szUwbD@ z=bUVsxWuB#Dc5Atgl<@!5I1n zIK>GwWo99^6MmInewBq7j;NS}Jmih1NSqk)oGut&M1?8d{<%NP(8MgnqHZ+FyEmho zHt4JArW_05J{bP-Ed0A#h>XXPi1YzLG}6Z_(~>I|J%4is9NbBpshQ>v!m5>7Hhyu@ zJvP3gVlc`L#kCO>6O&S%z5&! z*-0v?w>IgIi_&j6o`kO7kkemF!P>6<9rY+{HJxC&KA|S6Ecjs)`ti2til%M50@d)U zNDEJP@ZUVjc}pc|wrSIq6Hk8ClryC0E@09;GcA@*{=Up(1-qB@-NtUgg-yreEizw4 zD$Xcq0p0ZA8~vfFpli|7X5H|Y>16ry3!O4v+WDB@&)uu^&i4Zx8fSqG_z)0nV4Ed?$cFz9ilP9>xUv4POJnPU%{q#FEZO{pkY?B-PRBD|em2 z%uRiGGcmj|&Hptu{QoFIJWN#~G5#@y$inBD;BjvMF*&Uo$-?`xTbGZ;<^t`EBvSNiO>ZwtP3JU0dk* ziQMcvSoY^r&Ix7#agPq4$3y)ZZX zf2b%CIX=j)L*J7Le?p~faf)%v#3u0KF@#QsvNw3Y+0i&E8V}s3A|VlN&YHW$LGY7vc{@NiJ$t9 z{#h-oEMCv+!Y;2*(CgW}KEBKAa$ei&Prk&ueA!K3)|=xPIkn4||FAkIHPd}5>+ybrRl zTslaUqwjAK%UiPdLsH9}$kw?@CfLSVHu0^$e_*Y3qPMbHwnl&4%2CrFw~O6f-iqc9 z-K}U|r3)YAYUq#KP413j3x8MRCLZ{g1`CY}q-krZ5_N#raNP!FN&I}RUH+&-yyTzl ziMWmzOCF!kq|BM8dCAj>lV9h)54;@xvaW!%)HZfqk=-PRuS<;TylW)KH*eFjtA6Wb zEb7o$ObiMKI{Xu7$+S{+=NqwP;XPY+#h;TOEN8^IAJ)5LMBP98(lGKsdOCGMq?hiX zhBD$eY@k}!zf&XY-}m+6Ee?kp+(kY@oY1wcI$D<+X+65}vYE1=vht5NJ5Z{uz|JT9 z+xx@8YGkH2{@EOmZu4d6QLw)1SrNl%O3!lcGJDcUE#29<580DUoyGp+-${&EO50)k zyQYiv3g=}q=#Rnq8b|Xw4YiN$rQ_VPrC@qt``8_A6p)8$ACKI=i8x~5*tBfeN-jt< zxYWN+(up*IU=Ry|`UKf+@{CL0`J9(jJ;QN#tWshv{-0-x3KnKDfw0K{fSQ^liX|gg z1SiUr$)uDYAWV{x=Z_3KI*czGHTBix!1qVH0*ghB667Gz2KRqU#@Vmj4kGumU%g3J z%SISC2|TcW5KN9qqQFa3mk>eVYCej&t|kQvqJm6=ga^_M40fX;u|lbM0#Hi{=@HQB zTirO3pC;RT%!4+y%LI1?NJ)@OtLz3rqcJK1hgGym}59t*P`qXI<}tQP7EcF9-?dX?5zf^St-~&>pn>P*HZoLv|T;w=QTaMB6$rXb`I*$ux5H_74aO zW{QLr3OP&sSpjN66Zvd?=X?Gr!wZ+>yx4ABD=<2&6)h^=zLc@ia< zX0FEkq6MxLrA)L7d)H(u*Gywj&cDO=wXsqnQN9VX@Lkv zFL3f+USa@KAy6Z>k%7Mtj*K)2m7;ArZ}Ruv_9p6^8I{@{!oR_ujvMy2+ix!MhyWwV zKb?+Tzzxs6449$;fR;N*G%hicm0r`rdj7%|ajqU*ARR5?q3N8MMnTL_zRymAdZDn~!<%_Jouw}7q5+_`>w8;iBLY3gp3np_ol#F(%#~}@?ke~9G ze(BKbyv0A#ZVivbem^--@rXk%vdf4`y1+=-GbvqX{)&AK+#yD<$hiApJ7dO zL9BB1l#8_{dZJtD)i|N6Seb5@ST$SN&54!ri_wJ1S-=yR91zOrfw`N-C_--wEU8pS z%klLYnbKcg4_K$*q^Ug-)W$K4+7|6%}qhkEx zFW+H&nA*DQuTphZXKid22ryu(R2bY0RhVlXa2>T4PC>v4eb6;>v;ef^*mC7&vHPf4 zqIoU%u|&H#pkb(%M^QAa|2g&K#Mo5@)!SAP(VupLw{5B1f$YrF@Mz`N;6O=bgORk$ zwLwEIkqfp+)u8XEa<)M;_uX<}rTht*9Oi)qGrbe1;MCZB9SM2>^Jv?rLUl5B^5yg^ zV~Mx}-<2VQ=1V(_ykCt}YQ)Fe;Y7OPx0y(Y$}Zp&KxJm3d4@io;; z-spP*OKWy4Iyo_Z9h&oulA8Q=)f$Y{Izi31x>mahFh^wDiqUa)oMP&Wt9jb&3O@@>!s?OB9G}CpEnm6-=*1d9`Y$a@~}Jy|{a%6;2Fk=42YT zBF+v5PE2gllfUkB$yzLV$ePlDNan#95L3ETDszD$Iu9fJ+IhJ>5R{XmaOo3UZxA4i zul>wAAxF{)ahNA`5hC^036V1yG87fzgixBgHub5LGlgQ52Ri)y{Tt;>m}+-RoI3w- zoW|~dO470MrKt#++PUq^!w^*yW+Fh=4m*+pH4L#nqFDlQVi$8GrkMRYt2N_=t zx@Y>L4g%Amrr5YcDlI@K(cOEs>!~82?e`n9f%=I5Kjz*9yow@gA5S1x0wi=mqR|1p zXw=}K1_w1kzyt#J#TyNRPC#^`Xg)?!ktBc`G~p&BZPSP&j_A1Hj>|Z>47iOZgh@b9 zSyZ+eh~P+HgNV2QLCODpPj%ld0d>Cb`9D7%P514tt~zz+IxI{L%5WB*!kU;j>`;p!SZKbi7h!I@LD{SdXY1rgK z^B5SNYw<*C1tY825-5vT><12rz+2x^W8ZiXm_E|};svUIpyMeZYxFNs+SHcTuEd*) zgBO-zdyMKUqde7Jq#n$n>NDmO1b3njND?7>QyMA`4l7+>aj>nlQwxH95#RH;P?Gcs zu_pT^UsTx=w}C+YVW)+bN9@-R0P4%4=OP`9&u~Zpj1Op-6M4W-J00A`)_SJ$@F`(e z5(cKgRb5#eHmeSB<)%PxtkmiyoJBe0Ek*|G5gt#o7Y>OCq!RwZrmE6x){T~s;qJi& z!d!4EFo2an1n5%0Vcn`uKW4GtPF42zWMp!2!)`3knhIsct4UiLp+c?TG(i$oAMU*N zsK*qWXOajq2%k*#a$xhfWQ1*gc^EnWJGWz-zsd1JyO7$W_5<6DZHuP=pWp9*?h>~E zGE+f?-lw7W*zd6K2QXFaeupQZzA#?sRw!OGGV=L|5z+2C38Y`>P`BhIA2P~|$SnrB zbKU%0R&P1lR^+qgiAz=}PUFCPJwP#P5KLR1=~4qo#7=i=XeNa~5Ld`hC_w>t$vkqM z!xa>CPobFO-vaq=lEU-X@&eh6iOYDbWr;o7OV{Qs) z`6wPZ7eXVUqf=+lYMOl>7w?XM{rUC<3F;U(72fH$PCNgKG=P{6c@_4G!M@;>z-#-i ziPcGvRicv|%NR^EZrcGfwdg)!8(716+klvI{&5Eyw(&mBaDWhCg7$QdZX62fqM{J9 z+7I8XbP*bH>u-70?)@zVppGuvUB!S`6$dW{kPqqb)t5c49iB`d=3# zP+R&gYk*f&tIkGLS;e95TFppIB`XefE$xM~D@&8{2!SI|0c~|HPtiQ!2Rirt9EWl~ zqfX}z6cyk`p%(57YJDDUdD7ARKpi?`2j( z&Sl1c`pb;#>l1zT&7DWoj*CaQsmyaw4F){G>iDlQP{#{+;P74%57Z zb@PWM8iZI89DQ;|JL`ZJbSw`0lgUbmp>9=e%X@xn=tq}P%noU9`j`IzusISkn=f z!5=Uq9x|j%;tol~>XTtDtB173K5T1Q>Q>zH5<A>HCilVGz#<}Q!|jg=Jg!Yxr+#6`qc;CKX?l(18$NvCqM4xulf zP!h|b{jk|q|P$*qPJwMWro+>@To}_D9l+|!R4ooKg6ohMM+{E3A2>Algbp%@NXoMtF zDwF_HEmCbTW}0f6A`7N5rPb*IV3pFs5aXOtMk}?^!k+LS=@Re1$nxyT@_L#6tfahBl9Ei0?-0cNOUG2Q`rqKpFvV# zsey+XR-gf-na(6`YS|cGWZBbqssYHMj#9)j1?&~T@|FGNmw@*QcP1A-zaN0;k;zpO zJrd8Lk!wIkjh-v;B;Fprb5EQ7(~m89kcS7I8tg@=spVbicIZ!ZeZS`XgzG*~$@0_K zg&bOgUI2_Wq--|xzdt{r7Xqs&Y+}z(*b+qb9iN||&H0*oI(qzMm>4$?<(EOVQN+Eo zOk+fCOt%6OAeiv-=fLNS@$xg>;^U}?za%)z3b0lbhZ|v?pX_!$9{95NYBg8k#tBHp z<}W0s8D&L#nS+r9Q^8j0qlX{>M3w3iCw)LiHHLu`_fVUVoJ}iy*Z^$>6yPL{IX2iqF z1i`V7A~W)_&3IP6(ctU9*4KYMKrFopsbNvcUDvStn3RIhX*%#%irqs%V*oZ9&eE-f zlN5}=O$>N*nO2E7E7XnQ*pjxAR5F!RqR1M-yvW44zU4mq%w1$wg!=vgU-;qtvLV&6 z3h@apcCvc8Rf2?N+cUf+^}*eE=R-2e@hr1y7Z~I_nQcVPH>%RT+*T(0XD;MAR^{%Z zZnzjPr5EywDTlhglYW51(o}yh@HVjSTm3~&b#w3oh03Akk%1x51lu!|h2gd1I7Bzg zwB&7;!#_?@>g0}}Ichlivk~rRR_X%p@qh&83tCD%Nty?Od1G(BG{P`}_#kdM6~e@W z|5*1XPC^8#<_M^IxYa`eu{6~)OH!yb^J;neO0yVKHY>-h;3kDP_H|CPXc6-YHjA~< zs`Lze$bW1$6Zh?#eK6HQ2AX4OHpi0GgIT;Hzxm1Rt<&sDtc}g`#%{@v=&dyCWwRBS zNAVw3OIq$6VdcE5{pup|Tu-J_5`;A!FF z1?e*ddwuUa?F0ahz>~CbA+=YPK9w(<6xytriS5Uw_E-nOs2K8t9zAil={NxFM(|=#%_?-Vxa#r()#Zo@4U`1v$%_-@;_SBt zEe>l}t|-D!coLJpdw|s?L70K??Pn(t4YHHLV#p&qX$Pf~eZx-3 zm_;zKqx7XVhoRfC{!`BzeIju$LrrSOjs4T;2;Ao=P6O@>h*CBe$rQx^@ccZ>w>NkH<~(Cn?uO=ygWi!RtQy&`ex$LoIJZ8S zn2VUNwz#-a+R~&Rxs}bh<$c02x%JJ7BfGBjYs)_JAsy&hSd{8iJjzJuo~JF#OFtjC zdEGm;HA&;s0vwykR1wPmYtL^c?(s4%zNBZKRl_6U-UR!_$$l3+PjjAQpx%U_iIXE3 z0QX{nTehI8F(!toVC}z7P#D#Nhp0N{eTHG}kGqcTA#IK%;fl^LV|g~67&*RZH!RKi z`qcP}Hq=AB1ummF#rS4oe6vn*#`nE~i1E!i>iC|U;*PIkCJdfpFK|`iEOJ%ZbUxB` z1Fuvb2&?bB-5A>+kU4kOXyl%$|Dt=YvA4K>Ph#a494@3`O!{5KaCKJ0RnOE7^}9M1 z=NU5ahM8V?-i<5Pt`Ipe93s#r<`CJ`DZ{gF#KE? z!(sk`h~t5{NvX~qle)TYdzG(}{;w`GV_hpA7#^EZYQRvd&Uq;I)`mZMrqaauC`@5}^R2I-S<+{nR{lJRf`BAq}v%t#9i zJJKBYMpAAihO+JMvP<&JiSJC!t%Rh+uc1wO@62SMc?`*<%?SNUDLF;A`uwFS?-2pP zSRGOEwCC){{w31(LAkK1DS0R`AkV!1ov9G%02t)b~1;2Hx8cFr~ZT@%oWsU|v-hxPJ2W86D40|(=^>WfhXPbcSr zJu~yN*Om4+%h6{1c6e$hF*q}&1YYGN!ziCyiasa@#KElul6fKo!wUq%X3{;_30wUa zbT*eql7PlGfyNN;Vj*Anq&l4Y95~Q(#tiw{)QEQDMj|uJAm1dM?b4P~@_Td0TO*ky zb<#>7o4t4xYRtpQ5!sC;7aHZSWMY+mq_G^|+`Wby72~LeVO1oGI);kGwI?d&d|0@r zas`>G!M;SGwO1&haWdj_^pInEPkw>fvIN(D{Lu0=C%a2w&THyQk!^S%XMc0N;%pdc zVlqHCi%fm<8{)&dq)nf6Q2KHr2;@B=a%OegU8%}}u*JFBeYfrKw zj2hElHMwn-JA^|xgiU#KXOagfiRpI3aR#y`(j-Le$^_6{IwB@v`T;G$)da7bfM<7B zmmfC^g?_Itd(>r@T#)MZUC_O~Sv|a5J^)%5U8^wuhJ*1sT+%Wbvufou}-J&xvL(iPvGLkI-DKRspT7e66Rltw}RO>tQn0q{x(To%!Xuq|d4Tl(Jpn{$oU4ZFlV*_zjHd#-V)auUSmPb%opZHzT!WUIh3hBDk+)9H|MKVaTcYlXq$-U!V?QLiM@U9au_S zSN<>=y8<CpHGrrXV zec7zBjpt4kHzk~iA6B1zO(UQ`amy5G-}5HW*6D7vh%^(k&O&Sl?2=5_eVu&Sn@Y}r zBJNZSRdfuZg^Pz9Nyq4c<+4DQeXu-YTY)|IQ({iH7K&HQprb?t8Lzkl@7N zWWlxcgw0tNmM*hWf!fmGYvhnY!+Gse*=^~}e?VC@&roo(9&W-}n1{G?!sWcYgMlUV zD6>D%xqXksQHG4xs{~;C<4`NVW&q;Z6nvS>6^6U6GV3x*Am9c0<*xk{R65b|v$!HB zie9Hhj zOO7R7Ys->OEQU(|Qyty44R+^`Wk4sQy_Of;-p9z>>EJx4$5Q{`Q2pk_P6^twL1=@i zPqIHkG%i@p^bbw|MT&o?nh{qz;J0M@|$zsDOcs4@>&PkOD5wP2kDJ!27uz zjR@Q$666tQ6lSd#tbDowSZRNr?f)hIk5w&AVM|BE|Lvf6$d)Obw(}2q3;6&!L~exV zAo!KV7|SC4e12 z_J;Ks2p%sPrVZXj)BANX@P(T9R9?>J0i`s5Jeya*69(L2zKoHxliLAONC=A}02vKH zT54S=!tGmC>1hB@&F@a5?NhmXvgnPM(rI7lnBU12hQd_-Hjn34jwJYDnMOwWVKLom z25ixjv2)|yxo}l_g?tI0mDKo%lpgp4(y)lCtDn`^Z}ws^P!8Si)#D&>sc1x_)tB$& zY^Ok$1W(}`%=?NWW_It#sdfggM}oh*`|C)qBU7-iX_Xk`zAMrZU<5noJA%j))r@T@ zc-KaxokSKM0EAN8^bI>PkI2zaXw&;`M-Y2yZ<+j6|B02zB&3#i5JC_hk0?wSI7<+* z8uzMBamB(K+VHRQWrdH=oWAwWH&f89vUJBt@gbIZH#VxzM-fSNA?U4KL990@W15QL zQghi?6N-}T=f67;-*vNZ!%t|S>)pA&%Aew(xn}h*IcJpNe-Y~j z>wLzy`i3u5@gIEse#npi-fwJk3YKroH$Dqq2tu)+_>jDvZ?yO-|I-E#MwwGyOw6tS zD#35Q#@#Z0^X)`j^0U7$$-m5+a&z2eX6e_7mze{;2Haiqv%j77ddXQA8~#V(su;cB zhZ(TjYMZa${`~kuz9v~J_Zx>T-fyVDRo|LO)f93?F`D(yLoD z+Kkt{fP{;eT(I<89?x=yK!EYrAqEp`GJb1L9JID?zZk>L>Pg%MA+Dyk59$W2_PR6V ze`XhTV-B|inV#yKsG0xF{&ElZXrMzk9^+3kCwP#8W+*YO1%g6o^?JRXh(|JZ$FjVY zdhZq(%1aYEX-hX_{7!^gOVqm}iOK=&YoRG^e8kLO;O9&q7VJR=dSF#Ix7wAc*6`1P zZuVRp?@UwBc9xPF03gLa=X`bu?ou{q&X*pD5`|<(|6su*0-r$3UK@G%KJB1$K1aUk`zXAcgx;75!XQ*T_vLt$G`t3xKCn+5$-(0eH`3 z1)v;#7YksiZ0yX03e0LSJ%2z^oHm)ETMyIufs`PZpi8{P`hmQ=r+_SDJ)EdsACK3( zB?Z{mCJ_kWrsYLNK6GEs%_I5nArePB%d+;2(8K3+Yqp>aXeQ$%+E=;nWZM+b0qc`S zt(E*rkz-+5V&tN*=vv?)&c33HV^S%zK#kBnGD6A5|A?^$i(HzLd}6w#M#^wkFg_pQ zz!_`-*`l?;GA?k`vhxULWhePhussud{-sZ{8A=}g2O3{JV)i9!bA{7(-762Z^C_Jn zSHBPHoE$L+h@sEBNj~lNw`MZruGSV(Tez2(>aBMV$0J333)ycxD(eLyQpbB@*X-7| zt_6w|wutJ9NG!+p0JS63Kzcx@?>tWOWsb*35K)}J5aF2irPzgS|3MeUCsBKV)tmDL z2y>wVsT6V;5sEdhv6B8+##i}hAC)>)QA2%bC7ooZ25%tM$+y^+eglxMs;N~yTU7=J zlGC&K(ldy}G(rNKO4h?;`aru7z!tEp(XL{Si__B(Ew(tDuQOXLBvPG7#c4NDkT5ci zM<3X4uEZE!kGppEpf=|z_No1T431CoE7e?hb3k4wLxVh=r=T;c7xNY2)761~=mahU z!;p#T8PU!7DKmMBRFZl#FX$AQ0gHC4JXU!si3Kar=gSio<&Sir00Tp{^4@wbv*JxXv86a?aQr0Za_VudrmtX6#% zD~TyRZM{ggz-K2Dc6d-8;&LjxmZ?`B;sTy_??YH$ z?Ii8q6Hx>UE%keP7*io2r(y^jk#2gbH@DvImK$i+u#}P@W&-R~db0eeu4YlJ_>F}PEtTWN{4R3K$so{LsQRy%bf5byZFXsk6>vEZqw1XdEZLf14q`a!C{wF`Ayss?` z^IS&c!Tf1l4pA34eC({>Ar@aXgQK$#qed>YxkwISQv8vyoN)9bhAVXFa504VY z3ln<-*8Etq30_K1_)3xeIT-J}hBx`SuX2iL%XOfPq@S3f561+F}O!b<7XmwN7- zNr1&;Pz1{0DxnsToSa6&7Tp>F>zlwB%Ly4~gf!s+#oRl@f?43y^03qb2Sh39>#)>P zLuEiAf#*DEEk(_pj@=-!-8?HX@bAhsflpzs)2Tg$eP;bj!;0Hrsl+k z1MYEUO^uzURgsMJX+U61#<_%EI(l*`9qsSa2#yFKPWee&Y8YfGRlLV;lkzQVQ58&k z&%6UWg1F*dmuno{@O56lCIe6S7Ry7%9p3iGN$H6)XA zK*yHiyU(W^_M2H=-F!<3q>Db3lvDzPs85sHmw@->&4|(r=1|f1t{0tR4##LXk&4KV z@OzF17}E*|FGh?;#bFf@h*m_W9ep$yuhT4e>v**6`|1=3(S$LdpIFJ`1Qb|9mJ?6T~1P6@z&t(ftkpp)x77_s#ifyjTls`2|+w$Rt>CHkT}t2Q&+iSpk@ZI`~wxmcum(fxxP( zBwT8~R3kf4RfVf4KaVW>`oy;3oMnE_S=rRrANZP+a znzxYT^HT3%`26O<*u-NB7vQ)-`0I>gUasf){G{AqDR%3f}e1+PhMss8Q`=c7+kJ4a6pbAZp$cv|_iwT9t-It9nA7 zyeUO-R*3nEg5^yG#D1Lj&?If57?{73<@m3$atZEW3|8)CBgR7qa4|hg$8*Z?kc}Uh zq-G+`7H=U7KB(fJw8}dEYN}j`3;$6*30H=;-*6@h#bJMS9u=O#RLgr%XoXa0yWST5 zE0T*=bskN`q15@B)j|u#(+Q<8;203JO&<=1e$GE+67DQxniHU{R+n5L+UjCt_6v=f z(pI_7j6I989hPR)XVX@h6Vi-r8(OHRPH5|Q$d~{Hg&ILQ#su%%fCL8drVTs$9co+M zZ=1PIkKd%=FlA;g1mTCEm5&04JSEuz$9qEDQCf2&-4+nkfJ1@cBu!vz_;6a2KoZz_ zGL~>)nJIVJU-*$Vw4#abus$c(@9`MZ0N^wl=2*ez^-zLleMHnVRK8Qym~Q zQ?I%bxLRKZTvav;$T6&A-6xOHB^d+zMcLEsa1d~%1`KmOPyA)!0fX%xrIerf{-^`? z=@q|jz)lw++yS$nTc#`>M*_NCt6;6aqHAjhMhFL(@947WxVtEc??ZfSXhglPBrf}n zOF3@(5!m7w>7IFqcM}e8s~OYc>~%}rgD53bW>4Y4Hb}7C8W%l9zMqEenk)W zWJdKcN(2O7fKyc;%AInvQuTGsy5}HGF?E`EFiu|fzU^${ z%AsXAy3yhQmNFjd2I)mod;x`nExBpTUFHtBySP+R~7!V4@R&q*t7*!DI94Wv z5S8ilWid*Hjh8cD6GX9;S*w&ODc-DA`W2oB`}p_CE}T<3=5f&XJ)bxoI(U~ScorXE z$qyKSF2fX@dBe>4Bt@)2)pC3pm-Gn%HQD-jP>rJ6z}5UXsb6ol#+Gq zuvYU7p7^sjYBi5Yc^qG{-#x4@z*jhnG5g?M)7e~+2wZVl;a7^i!&YABB0^r^B%p!) zy>b?g=X6g(7Eqf)-5LqXp*SXnp!^kQ(0cE`H}nn9uUH$r2wQQne%DeBC-8LA+s;>r zMr@M3kiY)^D&`^;@RNn-AF_UQ5zV-m{D9n^*p%Z%lW|QsX}o~p-vGuKyqf&mf29Hx z$n)^wg0Q9O4^oAAUu6H&F=#MCGT(-eK;)K8si8`h^NRA4qRh)1`?J5cptBN8C3Y!i zC#HDsLm_M?!f)gEO5RjXRyZ2i8j^S`cp4{h4ATvB6W}yGS6&LPs>AkSY$oSW!;uUl z2iePXDLOqO6eHnz;s2cS)(_ zO>#jU!8>KV=t@Jk1^R;E|KORn)FcA6rT4!{aO!tp-SvGud`lj__O?9y0uM1M`&8e* zzL;kXpG_;3XVr8Ub2UJs&IZdd zqar<9JaSbkGG3D!%-0CEKfWGcv1Y8aQji_B0|C{6x1|G~OmqNLaxKV)0Atu2r*PPl zm+|7zQgSzzT2%(mz9JpVlR1NOE>I`mgel8x<^v%j*oyY$87^fZK%3SkZLXoAhxcJi z<3O_J;Fp!Wa}ClHr3mmTWEuQB{7l#kIT9CJbBeyEL?O0fS%SO}44~2+Sgsf6g)P^d z7|XTg%P1!Y7!0>q|dz z64ze7fQ;MQ5Q>nMi@~uSa8y~%YpenjM|va1fvHHy3;9fWFp6L*2s#jlI&UVQbLnm} zZ)6f<^}T%~B^K2QLr&qmMpyt{vMKh-(Z-WIbQD5GL|Y2)1cBgocux7uYiBVpTY6?T=sT&fz+WF~t$=kR!>4-3Y?Np^%Vd_iq9%@k;BPK z6nTpEkSGE}gH;tnTb{C#j#$-2kNtAGi?a=2N9Mn_UwlE?X{HPtdUfxaN`Q+ngVJFR zS71R&G3gS{ySPiv&THW-S_eCLF!?eRjuu^I(>lV36(hPHJk>=@gy@qPh8nE<$~C@pn*9e zUS5lfeVuxF;R}!sUpUesCLU3nbBKuQAZAkXe`m<1L=09N3|(>~*bmQSS1R}ohl+ra zaR|^&=ywA9oxKv#bSP9nRs_+y!I8S*sCyLLT1-6k{TDA_T~x|ttQ#`J`~aR!O=fkb z=P*jO{FRMMyO}LdC^^8>5Sb$s7c9_j*l8lrp02JR`fcmF4-3Hn96lrjup79-z$rjC z#nLI1n-E}j-{*lHZg6+p!_o1Y+MF+_Put-KQU-93BTy4*W|Vj#^hyR%$k~5EWdt&j zh>|RQ)m5wnkMLQ{H`CUbW7CX{l{*+;XO5enh{T_P9U3AMyJ~ZW%V+adyjCrPxv*ZH zzytmQUc9=@O31m?^e;~wZT4QCXI3x*4%;p2zwXMFClkkUeWV3A<1>4|Wo%@v+54t@ zf_WeuN`Pv~KY(NJISQFDEdMmro#;B&U&Ji;{LiCjxzq!$bL_@EA@XxW&M{}EE50)# zU*R0B6p=P2N03FV-|TU((rS9kn^^eD-SDLv)ZBji@{F+fdHcA?Khr9MD9{mZMZ)3wiGO3ZiDARtI|E7 z5DRYF=Ze1QZqF5YTb{ptPE8A7FfB`ykAx2A zrhDZFxy_QHV+_dUdmNS%M8&J4b<5Lpm^Hjs88`Dqcbd++j07+- z6ach2*-U;SmxQcUuOZ)ArJ$}bgj+Yd6{?yl55`qsgy!}W9*uf7`ydh1RKccL2#t$T zjcH^ihoQ1nKApFj#Skc00m9^gjLZ2O`Lq!Tk;QUO@{*_d7|$~J3k6-xxCWD)W4VirEPhdB@k)9#T}ET1!kt13*v4=5 zoiqMKXu~a9HS^JMAjp7aI6`?$A_oxgmuo0?@?{jc?+547wG01EDfgix_uK`&2o{@% zI6;7O@~59fq7R=Fk14FjzOY*eeW4&`3|TG54*$r?^Kn%?vNnRGYt}g=4W4Fcave)@ z?QkKlZr|{Gk@H*05hoWFT3L(d7<5Qh6%-)%06eP-%sXZnnYZj**PqQS2gp!CCRXi) z(zjgevMW-_{6~#KLW#nK2vm-O0+FNe=5G{svRXcZWC8?nL8f{|bWe~+OxV6BAjlU$ zu2SNL<*k*MzDUKZZBIb&Dt9;ION!M^yh5z!FKzXY97?j@64r#govq~U zJxbon@*QPV0oe|`2lZ=u2BK;7Rt3`oCwLj6h?}s9MG0_K(@=^EZLZ8?oXXXs+2ZPM znjMz5vz1JM78F?ntYeEUT1>HZEf8C|h#hiPsDF`Agnqq*{HhKhW%vR8t8}jl z1y!zSMq9`a_NWLz%hPW?nbw5^@GGXpjXmcW#k5}C6fde{76Pn*V9b!Io$2Xuq0BbI z0#9V0ZfsGBV@YN}DDnl%R&Z?KZP|$t(`QrKpaIJd}?nRWfne5M|Q9&W-2Fw93 zN(d672$G-ZauI|eXC&xx+s!dTutGke5PaRie`Z(+$`M5PxQaqB?-2;WHb)35(^LLN z$iu4i0xqgaKCZ7=apmqzi5+<M0MpB$)eRFH-6$fwGc*mAIz=RGi$(ZMitt7s%66S1swEWR zGZaDotXj+yN$Qa98A8p%WPHz?G~U<;R-&6=Q|V3R3U;!=KJ_m^&>o;F0y$CoLj3bh zggeUSM~1&{gTm)SDigoVW0yR_RDXMZ$5el3jQFO_?ge+ceHP+D>{<(dUR#1QBR@?4 z3i@do!AVHR`qu?Q9G4=?(#QV6akloR`zBSr>5DhZ`R4DhVlRwmK59oC&J<^20Sb8r zFR2I=Bmd!8q*2;{$8(|{>wNsAJ@8@lxDO~bvd3Y1K!2yhNxvItoB}%x^BYJfavsqO zF$LiSQ6uPuR*AFsl}9)-!JlIiMD0!vr8i-#(N?%M3 za`fyA%R1}Esca^Pz6#7D1rVHc4v2I@5Go(@@e!?U7D6p%{TwvPW9{FRE|$r+;>IQlAdGnATAjk9{$+i!zqi&S-86 z-i*H4yB}_iOuiRfqi>#{QWTdvcF9`Y5Y^O(hw!M>{WD_Go8wk9JQZ zuP66tXB!i<6T)L@fAN6R-vNJXKcpEA9SmvB3+?)Q+jR8zYW8>kpV8l59rgGBl>Y91 zxjnE4UWo)2fn+4gSD%dpR_Jd(>urINE`&v@Rz zgzSd0KG-il5c|e^7Q+c0ON-b#-tv__a)C2I=3m?QIiaII&t4qaXCcV7r5K=z9H1*7 zK(~8xfMWRV{}Fn;@_whgkG#~ryQ#vHu847lc>i8`_WUsIkpev9;Yr4amZ$3?Lo<*xn1G<5Ykj%@k;=<4ypdLmL|#`j6p-(N2O zkr`X$sR(-e-S?<)sj;BoQj|tOH{qy_Pz$!e7u}Jo?Z}S6S4FnWk5UWLk+aZ|mbv!Q zKcN>Lo!|JBfqI?&fikL1Ny%!=U3IdJjPFElEFfj3OvAqBeXIZzW zrO_Tk7%2{1-OFnXy}Z#8yjd>1?>XC7#5PC)No2sZvb&;6%DF_I4p*L@0w(}^yO+J) zYfq_jC#ql*1eC!s$lm3dy=&c^1MFpn@hP1AXx!{QANl?UV*44h^>o9gkTj$By*d*Y zu+y6ucB$$pe4rudM zqm$aQVaR1TsuS`TrsQ=+?wqBgn9DE?_XC@%;_*7xWj^o# zOB)}#IWPeW8ZemNOC_G-*VtQzQour>;Q)3D;@X;sGy9sB%k&~10ZT{$hpyav9#D<0 z!kEkiZvmBJ0INk@hRuT_z4o1$LI5WjK<4DI*ogjxyvonnug=5hJsLaVh{3n5=raP} zSOxQrfRPVsg!Hc0&>IYi>FLae+4W^ZI3NIzVhkP>k!4Osf)qY0;$r;Wa7%v$<1+9O<7S@+qtL-YMDzC9bAfSgN)BN>1|LrJnW$MtQ5lwn-?g-%K7Y^*F?Xfpf7D!E0x9ScR}w&@S>BE!)to%|j!* zbzvuT>v=mJ-3p!)txMTS0zqvCW&$;VFnI<%cHw-BJsMp~d+*b-_8y}nl_fSyt7m1q zrAY66x|a0~vgS1=>VY8s$2szR6Ia^P`KFPd;X&EgqIolv=G6z*wbf})>h(e7A^I%7 z7IYD%lHK>%DbmsFHSYWRAaWFS@O`m%OH_}()o$&9|F2BJpKHAMQ=D0>eZ3NJ=KyZ} ze=tXz&EVQ%?N-l4Q~L25#Q*#7|DobM?ba2=+TgsEcsw|7t^D02f1BgJ#mkfUr#OXw zZ}IZ)bksgL&+f^;d*$zeo~UJTULAgX{Q>^}6#s88&egtd=AYI4^D+PYn}3j{s0lDd zz-BQ>h_JnOlM9;*4qK5b-&ZiVd%pSz&)1;WDbofJ-s3tf0!ZEmc0kLG`2S$atdEPe z(yi=MeSEQ2vN;hAuf&(@zSZvXoC*1Xha0^3vn8Qe+lpotC|?sW&pit8b)h#Yp*wuX zGJ}s>84nf|3W?%xZ4P%UfZrhbr@)^D9?ub}AOg8sHX~ZezH8HjjqSb8CK)kjGny)L z@bOR#EevZBX`JX#(8&}p2QTb*-=;N-ro)zO&&IsOoVEzF^lNekEIve}!GzCVJu5|9 zI_SjOiJ3VxHM3Wj@1^_@t%IRkp(EzkGyN9MPiV4ZHkoxgn!>~QWzPBte7Bh*a|95) zjI&egqXJGsLh0WRi}Wt82KRo}Uj7wF%OW%~q=?ACLf+2rRE?suy*hIo&P?D^9K>D7 znm=ZlvgYBe=aC{tEm1~aza&Zv$x8c+DhS0Y%8QusDdB<}@RKQR}Je$nJw6;EFA!B-jRjT=Cll!Am; z;I2c+OT-8Y_SJ{8T>}5X59tlNju7pY*oq3Pqu%c2HY^=lhGN5O6L4lJGG_(Rq0i8v zq;C0EE~>$)d0dhhUhD6{c~(5E=Gh$Dz=5{XQ+$>Wcsp3qk1%&qFYv50pB*FpXs{o^ z>3avKBx9aj($kR&ho|6|B3_t*49B)3Vg|tBOXd%P@7hKwUEBf)1#(2>s+| zgMET}+e=-#t4o5q{8T}>8tf}(gCVBEM314z3(-mNL=kDckn#eI%V3xLr1z~j%j#R; zg@ia0`D*CZL)aXSuA`s%jTc{#e`o6Zzobgk_4>mg-F@JyQGa(>S3E?VncJ@g)##88GdBi55f`- zrD_D1Kx~OpbEW}e_~!6gn!Tofglh^AxPb#z>9QsT7KZi8!)yV}Ox-H!6v>}^+#c5N z=oCz)q4iS*@VYp{V2;7>KQVO$egXaz^bPo(%%0Db1y1t>*+*N>BIX!K1f1}lFF#ax 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

pPZWxkt4zXd#8zzoBGQt<(yFOuj075| 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�p&%@H;NwW}+HdkC zc>b(^BMA<=G$KI{wSWY)9H&D*9PAi@!km>o%!UE`@p9}z{VQ_huX7biwpUrc97y&r zx27eKPh%#MZEsU|CSCHkX;QNNTLTx9_{vZFiOkyj^To7HB42j(z?sMHYndZrn_Br^ zEOYzyy>X0J`|Bp|{j2@xZE^k?$l5r_8tS$kN|tU1j;NTi9q8x(B#x$0d)=>MXoi;0*LDBx0NJZQkRT4^wipnZ z$=s1BUC3rCYSRpPJ!T>w5zVlvivv2dFCceBMP!ij)Nk$&=pu-gAHhdlK3U2f|cx|}U~M$4_`s-N!H$L=>q z_nFfDe^8AgwQW_TJ-uImS-=hSb7g|kTmIq$*k9eY!D?YX?s`EE+#cY)BO@Vm)HT?) zs;y#IilUpE*sD;TSz;>t#X*?8&LmElUCzhiWJys2cgf)lKqAvx(#6mkBXv(6=)&Ir zWo`nlfqf~~=w=tU7idpbP}hi)s;bc@{@Hz1bWd+l2y4rqs|AjwVqX)uAR5V<8EyG9 z>$koeMBO%89mkHJQw}P*6hHAPMt7wGKQ$Y>F(c=1tM3{tmHD(OIu@APL#w}902dZ4 zVGUjWEHAZkA^t%&<|zYYNDhefKM9F?*gtn z=PS8zHiDZ9>XOk}U+T&WzU(yp=bP-lN&Lk;VlK<%DwKy`|8WuM`bbu#sv^}b52;FF zq9r`UBdX!IGj6^4TPT;P7sbeYx%>jl>D-)XQ${&Bl->dunMXPlP3plmRgi%ZZ;upy z8}sGufw63DchpG+P3Ln90tgT^DDtQNElAxXXy*1q+ogI?7ye){YTLoI9~hVEbug*i zEPMFuw;k4-jX6H9WrNQ?wuOlHthFfvDyochc!ZkSs`yWH>iNMY1YY}Lrr zLv(o}5Ys9N^Be`h##m+%Yk9qpS<}Ii?KWiaKx#NcZf(Cc!g%L6m`o;h--C&Tg4$b7 z7fzE!3yOZYe<_@yi!}d(SQ~#xfau5W!Il00E3B6^iT3c{wc;ByQMQ4h&=8 z#zK5KuASla-*AeZjz#i&^#{M_!=6k-*D8sb20{bDarpNoOQQ%@XSXQ0M$aVws3(Cj=t z35}B!rec6lvDtcS&FB*+GK#Th&w;zlJ3WyL=U)$0%ebA$(IsNtvvkAz(xo$ebbz-y zp;2nbp9+|5vt2nk7%+Qeb zk0gyQ0+ZdDB;n|GjN>NkX3jWr)2lz->5QWtt}%bpW(fkuG1L{~XjdQ>s|-ygQitzf zm;yGcUdJpehzQ$e)#_A);18B)R&lguD3xIyi)NWp?d?It~9c zWM)haaCM(Zk!+!b(VwZ~4whe9k*%Y3e_RPi)DNU+v`;MW!&`;e! zL_x1i?;_o86)|~72hK2D#j*0_gNq$je5(vMtarHhFe+tFm(HYn-9#Lf@spHIAF@gL z&x;aJL?};TbFC?&{&F7bt*7~*|GZXjg3C*kw1xXA!2|})BBmLK+)9^$Sh28K4pI-Z z#$v2oI94yccL2nkcM#oIQ}O7&Hg=zi?y)hA+>5N!bVXg5EX`jj5ksRbbdz&nNEP3O znP6%uzu-xP1WSIv$H9R)yJ_0Qe+XaAACz)G%{?eO!HI7vJq1Nyd%=fwpL~0R2?GM> zUCED|S1|qF$iGSKxKjQ%TD-P6K^@fe9RHd6R61>+qiHbHv|9Qbk_<^G%T-WxCJWOl zGo!{@l3AQv+q{=TE>2#il@suuTr5-YnCoAr#~@qLXS7u~Z>uo&$VR35GP+@$V*OEx zXyCBnW72zneqy<_to8@A@P~~+dN;O9bqh+5eBQgUw``8lO9tm-=V4SaT|b&SMu0#L z>G)C3A-zo`0evgL+3!64%1Gqsmux@I5=J%ZMZ>rERx;6$?T~~^j!@81jyv!4)BQ%f z<31SmhS_V;Deq$8FXTrT(8l=~SXp@R8gHwFui%Klg3Vy!2;lv2NBG4nkt2J#bw4NK zghcKTW4lc+B6G8qjA?@7u~FaDeNeh_i)IQw&721yEBmSmRfXMm*!S5#=pZ~Zl-?c2xtaJ$`N})LXr#U%pP%e9n zHK#<`vl5SC72(xy#l+(t<@vbgH2m&db9&|Xx#qM>9DSPvKV&cQ*-n$N`GKxE(R2B~ z=%gU=+F-S_gdJ?*Ht-&1rZbGZ>!&H zw<*n^F&pzfcr*l`edZgQx%?WNu=1R2`wz?_={8(+{l(3PTe^DQsN=Cjkb}hj-&A_$ z2!GbUw-Qma`rb4w)w-%A)w9Az?MeOKFLyONZxkpYg;78^;hC>T<0CXPk)bY1(NFhl+^yZO zjoqug>(@({P}!UGj!JduivFCQGbB7<_nrTxFKlbzPLpg=QjU4M{x_B<(mQ^=H8smK zF&Ny^5DZ?y0b)gE?f|iqMBy$n(zRnH&Ab&vkMH-P{9G@4T-30zH+W=TJm?@+n#@>l zN?Ia&nKOr5UUuTAN$=DRNwC`qf@0z_0bX6%!n~Z zLrg=Bf4DpHWvawA&W#c&phYv96#G z(_~6tuy>%S3YhnWoX7=Z_4;+M8PTF{h*9OnUrKXnth;r~u;c=5Pzl78Xw*p!Iwm9D zTN23yOWcRLj>!pL?2=q?y?asHF?knWB$ErSaxWS>CMP9Yp$NcF_nY0V-EWEA7m!6i zrI9Oc_cR0LmB1;Vkej9lWi(3vpQP{F(wOwAoLiWmDx zpR0(Z@2PjBY_}(U6D;E=NZ-O&-2mryr7wJBjtxn$-_XdI5bg5VV=7v4B6}6Ei6xBRi|p znV8hoR+uR*9U+@{M#_2)S}6T5`-#AiI+M7Kv}&Bplsi)gH|>&2PsC#tnyo7< zand0)!q0w*e^(w7cE6emj;AJS8v5|6eW3jA?@?HTnRIW{N>teVGAD}^c7#I=$48Uc z(i2iyo0Q5E8a;yd9fL=L>>F?`JarC~@8qrzy&uN-^f@0PC`z#f zjZlV|rle`e>>rs1*Fde<{G9XObd;T;_o0s2QM|$?>YXZ>QO*(~WyRu6koZMiIZ)&z z{QNQ(EZd8e;pB`UQ7LFvq7GseXcx!gn2#3hvQ?+!_M|>|E2R)-FmGrf>-$p|uCqYc z{KxEa(DT6vwxn&Um{FHGp}Zk;T3Hmh`~keI59*2sk@ASIuB>PF%ypOW?jiA5@mfw+ z1G5v#(&v3*1|hPK^k3>_a~t0G!(s= zk;_;g}q&c{>mE>lNs0D(MWLXjLR+CinY$vvnK9B~0(E>C zm5|#>;APQDR;--q<3tYA%VCV3+HzB+MM)x-;w<+LUB|aW$4WYUFx^#L;8eb175y zf_&lJ^=e;pzC`)Jorz?i%lK0?(~5O8L#i~spz`I$ch0gw;3M`ZqoJE+ez73pL9+*)~aU(_VRkb;)7j@6L^up;G%<%5sm&&bYQUBRA9A z`*hBIO#xb#2(byPJmyVF2{@;W1j&a@Lth5|^iy9EVQK<60~x(9o&6ur3dGH@42px%|Xk-4e(=Ash{|!&PX_ znt6y0TS;5pU1V4tyY)sB-*D!yRC}V&a~xu@_UdU~1WfUp2yi@Vy6$KZ=`#@N*`ba| zLtr=OR?bWYZi(DViOVx`?9u1f?UVy9~2WzsA~c=KOXrYo-d zo^bDr+=L<5cC&lQ9S5Gu&` z!D&tr^U18?;0nq?rInucTWMDfmB~Vu=p_n*W+b;ODB9r)XSpi%xe6s#5Pr+AeXka% zS|yyWEHh-HQW&vDRI9b^y7;?r%th2ci5PCT{@AZI&VJo04Lg666V$t$CdYo=BkUrh zWaMysFnWal_`beU3E@QrG(^j&kgdD|A!y}A2)Ugr`G>~yz?f4Jg8xP|8Z!J#p+z}_ zoXqTZ_dG_-QnjEee>I+a&5P}=w5TdZ(PD_8Y$081=7KwUrGce-1R`K)bK#w{7rPF&(zcMcKBz_YBaZbwUBpr}?Ew}{Z(t1J8hM*R(e6+5>0-M& zNqA@eMZ)WClIg-(-7MG|_4?z=LYK?5qti8FE*voCmWN+hH-N5jah*n|*JIk10PD?3`O@PtvHJb9Ih4MoN|*his28RcZp5cZ&9^!M!}KG)lNDM zSJG8azTUcbL6$Yk+Mnuu2Xdt!A-Lb5812F<_L2NJxN6)5Y5>5ND5glMGGu-?%lvK*&$}@SC%XA*7J?Y9 zG{7)Iw0AY1rH3kexzI(q;jLMU>1uCIy3oK=f>R13GU4#lr=Ql;Fzq(}q(l>`>`ip* zFViEO85OXS@TkAKc3P=N>MNgyq8f!?nVRKVVUf{d;b07t^P14nbPs5MA0@BV ze1ElLQCzh}!2CnaN0(hf5P#u{QUnA=QS*<>&Z|#vO&zo$)!xHuw~>vhWXr9 zH4%%NTJeTWRe1IW36JM3t8Nk+jDETMj_~aBEO0HF~rxOs>f@s4w1!&rZ5MYNdIyMvL4GGZ-L_84JqH$oTXNw%sG2M z*|yH;e=NO~#7i$}6qtdsU-2&4exrS1WJ%ZbBz966^3hQ=j8kkkHz)X!c{(2C$Kfua z#|641Jgmm?zD4B60c!udZm9ASLDN#lwma>OkEt7*Xg|!WjphNq+*~UrFSX*4BD>;! z>xwq$;;NtS*F^U;_F4Kqf8|^*EA&nIqjZ81-3yN0qh$pv$2#Oh@MPwD!9tii^*)Wk z;@**k3WpQzYi604khBLRm94vzfABVLpkd1%p>eu~vIjTSIB`#s;P ztbCs%dzD`L(+?-=ocH!GUiL`GWe*K^x8NtunZpPna{8)g4Q zW(J8xe;osCdWQyZJG|`2hr3@;RY(mwY^a)(I|5Z6j^yQ2%bhLl`r`YLE4>2W;&DQ- zb9oAnJO@|tHRL7U-wWz0mN@6|#S+SxziFdrf^%qE7U$5eh_ajr{ouha1$&qzhBy34 zh|iN2US@{QEeUO1y*6gLb`A2T>mdPHU0X$U3Q`Xjyi=rOiGanPb*pP@)w2`PLwhGT z%4sRryGea1>OIm(IxMMmv1r!zU@Fo_+%)Iu1LjbeF3*om{Qh(0yprhee6AatSf)gf z-oc|DIEY_bCWL8RYE3jLukdfOQV8tG30tZMt@(GyZZc*?PB(d|EXqaxXgK?nx#>&` zSu%-ByuxoYY`toVq;aA4FkSy&PJgrd^qOMk1*X;REG-k&`*?^osWMa409b~}h_*Km(YRbH zy8j{K1NUrfo_`y1@NpJu}VVb8ezlWj%PZn>BdV>ctuM^pU@C14 zsLCb>qxQT^`a>oY7skcW&u+U|Tfll6+6$hM1SrB+WUH_EJ@P^oLC zbRSYO>|4gnK}awGX<3s^(#3U7pGYuooyu|fyEmG^IH+pd=h{cFPJa+Zr;T<(7&o-& zps$HYvYI(J^x+Nw>&fnol!ZS#y;s;xyY0y3V|RgVJF1$<` zwtI>tQ2$9ci{v{c+rFrt1lubz0duicCdad)x4!MraXcFe5yGKY#dtPT>GM4Mn<7*3 zhRxj9c}3Yx^1X5hu{l=e4BCSClf%nV1A+l}2?>oEi0x^d3u#9PbkzlMjHH;urLQ{x zl_K1%i2AlfMFnLz?3UoGEP)zT1FHqPV%~ z&Pp<+YyLrr>zcuk#fFT1s1oTH)$KMVK!zC>q0UR$NW;RQdELaODe;s_UGmj_)IRDjaURoH{KgCr-kTtY^(-hqm%in3 zPmUKfZHR0Y`&N`R-kl->FO*Evzy}$}8D=FooPR zuZ_qpaWHKH;XS#(^t(?(?*B*Ln}A1EoqxayWHbun3`#Vh=%CRC7Yr0MLD4}2OmL!6 zu?9sOm(pml29sda0EsifOouCJU8-Bd!1UL+HD_sN_)JJ;KDQ;-P zZ4Loy0?FESHWH*aNKw)|?$!$6ex@fvJ2Zx6^do(jq2?mA&_WH5G2>utdP_5H*AE{R zOjFk>!daL&RFlnW(D|P=i(+o`OzJ*CK&IUgeRP9EK?lt>!4q;QZwhQMuNmqKxU)2{ znZ;8{Ukh7cj8>b#PG#rOV?t4a$l3tnz&qR^N)rurr0M~Hm~Gc5fda_~+n=Gz(u0_U ztso6-TWt?P*jNo<`|FS0uu0wj#8j&Tg6(qDhZ8`&;z&|_mYJSLYm&ICi;|^j@fK+j zRu`ch0=@1&&|P0|-Df*CVp6T5kDRX{UWUF{-T5b%F@Y2?*mg)`hmYP*M}YtgAAL>d zP^l0?4r`+yDhtI?2zdkRZXpt69o0hCC5yDq7tyiGa@lbg<>46gh%Is(2V>z(_+UTs z7rwh=_`1|8>%<<$)whk8=>%gipP;rT9KSRWj$fG@F4|CCQ5q}mon2y$=#8P(+ddg3 z&rOkpvv*u>c;OouP}v zN=?u7s|VsiO2~514yH~qB*w&NKA8dZy4NnNXf)P|(*!O%?j9-dXy2CjO^WzhqlZuJ zCT<^Mei@rVzo2av8r**<^o*pt_h0S}c2})Y!WPXj1`mAxtowPC=`8*HUU{CJ+$}XhT-c>c2!h6sZ~ml zPS;C~nojfeQx~0@L_++}K^P z+8MNRg_MyHx?jh()4rnnbYkj`U6g zs+VgHzhD5p5~BfHV^E%?KjdXycX`Lsv|XwVlV~nd?9-I(F56y^2ti)eB@<}jkdiu_ zcgy6CfK;J<1Z99oUucNrItkGMmQ$q{fZ4gQXZA3E7k-bBXl-kd{KmW${s*dsF#Xl? ze*Ov0inC1+y890ZUUr;?4+YAAh7x@a4I;S~AK3W@=dKk{r)Ged!`gU70nk@VP?lG< zKa~Id!`d+K4s2rkk!3;5>hV-d>mfE$D>0tl!}7egl_avI!yS{~Ju_FP(zE#rH;#s$pBlvXLCa-q|%C-FJY6-&+L7X#Ac=_ z>Yut)*x#=3%*)*fp0e|Jv{SlgKW)s(@v$ik4Y~!Mt z7_e!6dx}zuTw`T}AjpB>9+a}>mX0iHe|l;TO3B+`E9 zbD;cw8A(K&KI!=V_x2vJc>Urul=+hww|(<_%X#01-v^2hx1Zb>KAxWNS)IaZu^E;( zan*h~t&aFs_^j+Po=Vln6O;J(n$E^YIxc$0iIBc!)HLItseIMykEm&NiXQLNCfU*{ z#`sjHLT%*2w&C0(-ofD0awclpxWxui*NM1V8{@^ILUx@8=0uG#j&`ZD*sgPd zXtiDEfkk&FYAWbbXV9+muipZ9MolmuliO_EwV^GrP14d7K{ehwXt>s+NlL6`9?SB0 zoN6^mVU;vVJ4-3*Hu~Dq4N4gJyH)FO>Sk1{{O3ZYk4}y8_G6!ZspAuf-BbqI{0{+5 zxmiw!K39eIM<-&}6{F9-=p>Q)DR6P;uv=E{d*R~TDd-{qi#06y3?Q2JueB6 zg7!3r6+y-p?6GvdMB?^Er<6gI#4c`*^&qVSQ7K)`1y9 zu2DsubGy{(Xzhn75#&BYXGdk{piXtwS>SG=!`=T{JW>0F!{4;=qsPIdOZ>PYS72Fr`>?i-PgQ*p$Z~KptnShu zz)I#c{Q*hPMZcsj>otWk$N9=;l{U#-w@>p#H8Rhitd3ia2wvcPf6v#|T6*?zAM zyJ9w=W-)d;Z>0Wn29s*)YyIwe)00}cnYPWF~G?vk6Pr}(C5_l#-Pm0>H?YYfx?{B3%tb|N;1;hd3K14e@?UpLaZ|R*ld@ zP2cqEZ{8kHYmD}RtYCG1Z;a1TLO`&&%K;Tv>EE>w7o3sY!e3^^e~pXM*ej(&*2$ha z9NH_*TpEt`*YipBEZ^o$I=dVo|0U+Ye;k{#MF+A6hA}1*D`$jg==s|G=*46r!9(BG zLWC?ZSEL%I+FT4H27*X~=Nx7$m*wnOMUdbY(5m;hrDD^1EYY?+t>*z6GZg{+KAH2T zT7fQSAW$l}A<=yN8ZL^W*j(J+fdfKUhGOeFmZ?3%za2N#@gtxfpCGT`A@Q2!QW+nfQwPi(|TF znfoOc&wEeDfzcSFhWtp0zUpI<+H;QU-&l{On;DKZ8)PN#_itf^h~s?H`_;J;`vk-CZ_h_cbl=mAknR z659Hxy8y<{yu;oz+^u{i$=#1c0pWo4@MEcdC2KdHF|UGn<);o*gyNSZm9SEja6Od{ z+Nn=!whcO*Z#Ko=k7j>9nmEw#BM_1KqiVV-`XRPFc3yVe^V%92y~jl6LlI?$ z;uBB{;}U#cmkcyRF*Ay*j(v&*gDdD*D-WS=fR^f(C2z1l2%88dM!OUesItTdPikTp zCOA)7wGRdFE==O6F~VYnZ*%tynvEa;5u{{87MaFKx>li?vSkr8TH)@CNq zG?2{bjH3d*(Z&zn zFuEyWz6$`E*h`*ZrH}@IlkzdmMS>(ildm4-lpq@bgy9AN`a0ce{9=3|JA@vS*C}!U zb5BXq{9F?nvJM-zqX{8U5QW9x*t75HcMe`ebUOFsmsxM z+>rlVmD7q}hy!I+#GwKK0OmqfCbrV z53M2GXG8pBD9(2H=SW>EZVZrkXt$_FoeZhF&z8C_@+RBaryYN?yzjq~nqAB-(uP;} z03oOVV?PrSI17TO0sWV<{jXnW=cIJjC0AQ2%lp|FH)x&%0Zp>~GmlKI@CduYBj>s+ zl+|MU!_^*oJ=v*Kgn5!P^t!f@b=s-ve)|H_NphKN|ArhJPF-g|I~lk8GIyOa+qNe- zojOgn|IRLT`t3Rgq|6V&YNej}?9^$p{XVs9Bw@9yttAGGuJ={vx7<)FajlY)t>skGx zvBp2WUz;Q#se9TeSZki8bePrUH+LjBaTyX~MCaWlUm!Fr#w>$Q$4 zVR$5l+d2j*9@dY>XyJJScG(C2Vs$j9+SbX66MCe4_2#y&4gL{qVN2yWSXCw>JMGpt zYd|U(8a1=}qIEN{%5IHb|K;qObQs$2i_s7|wt50%$RbGZ3z%mx6p@PkR&msfuMIHn zw(FxBo-*yQ0L*PJV8nUF>%TQHgSr88f&r$?2F7W){w@tkB_XLIS!!L7w31Z+2T1Ob z`Ny`akFKh@hRsykP&kd&$0>%`xpC#Kg=CSI0JHfP1a&jvfEpEPE9%ug4WsgOWod8+eW6L}AY1$Phb~MWnwTjtCx|y(; zjHM-T*_rvD8cmbP)`^R&vr!W2$|hm!X-4Mba!Tw74D9xrvSVpRgYUkj&6oC)+a(|O zY5brQXYPa|ANVl48i!HoLRnJCZ{PNk+kWRvOUNqK+p>?EbD8E&~$U|H_l)AQGZ+_ zPNzu+VlHGa#spCI5EtI1t4F00o-wxe*f>&C^_e7XZs7-Ff2}NaLt?@%(qdIPDs_C!6I7 zB%N5TX!_v}lb3LF24=2df!3l z5^FLFF`S@Ms3H@$1*x=bv*V?(l~Y~WAGmOwLHeBapgvfDg^v(uHO?&&1w^ot$iQLP zLJk4XsUT46u{a6>9gah&b%zcsO%2LbTqs+qm*RjyEyNd1l0w<)(feq=q-I@d$BR9& zO7jT)@R`}d8|?lD!W}qo?!sya2^ms(1CGc-O|!pT9eJ}`0vm@n72r)dcvEJ0gRQ?< zK-Qj4E7$z#Ul`B1Y!OL;v&F#Lk{HPk%&{VKg(H~Ykr6R$2kfYegVUT-!8na)1@Jsn z@Lcl^@qE}AYzQ5b17e%NJFtQKd;?kJ!Ep971`eXKxXk8eyc+DiqYgZ*D#ccIB}Kb@ zbGc5e#6tc*c1KmolFeBYVto&advAIHc&@4~oe(QNNN}u>4LTj|(@Nx^=b$oYWKt6) zoMkA+PN}(DEu)gF*{=rIiqQy+7izVCm(xE}k=g zp~&lC$Sd$A&W1`tAgCaQ(GuAJG|4nuSikyNS7CjrCt)qIsG=g~9Nu_QzLXrVma4@2 z=#v4V?bq)^0bjmzzX(;tb2k0aQNS`VugtB0z)AKwr2>Z8vjmUm9+C<;xEoGADxm&| zS>LS^bfg;F#J`z4a};}(DI%>I5lh^XQsfC!L@a_`M9I2eN&&4_M2ctuNKC=2p6IPg zauHcAz_PkD`Q}q}*S0|rp9-BoiV=#T^PsW{=7LsNh@`BKNGZuN(-qqJcq`}fq3qBD zFzMf+R@_O?jQ-#9Y&wyzIednoK{kC+OJC9~gju9-w8R|z9Le%EJxP?Zq@GfKd5J7`LnDlhK z8oiJ0K5H?tutt`QWgr5-9KQp5%AH>o#z=L9#|>~#`XwJ=r{%sld3WMbvgZ`qX8?5B zWa@(?m`Q*bq9wGGtxErumVVIYDos6H0UA`1LcZ3#ZsdyyG91~&9&T(((=qWK=%@O+ zzw|%QUC};82ct{^*1@PW0Cp_udZXjLw3NG6mYfiF@G9U(VfDn~?vz7#m4RC=bwnf+pS`c!D45+WrfE9j=rXXiQeVSo@k5c=$yl%76cZ24A_HSYLs^cf<^ z$bNR+C2QW{HhrcdVV0IYf0LQKHhq{cR8#)koj#Rm=@WpK<%f!P`z)Hr>RDLre#ksp zptBJdpN(ztM(h<2r+R-oe7`ri8@@#X90!_G<>7K_(zE?+d~e2*0`;H6VM`aeda22L zq3oAjPji&IUoup)97pl>V)S$&Ui)4^V1Q(d?}dR=cs#@@{DiYFhON9SFN#myl6_Hp#FmmJ|Li^9_d@*%hvTFAypwS~`2<#g5KjlYFj9I;PYgKa zs$-|=X@cki)?DMmtlU$5FQB6_rD$dCCA=NV+mm^FJ_EWS0>4~d6ojnri%}}4wgM|N zSqh;a7uDW0Ds4u=0Ft@0NkgGZP3+D{HVhP?$~& z+3y(YL8Q=t*a*ecw6V64aDPzyI={yspy2mlnEoCc2H|^(INx=e0mgiFvb!4RyV{lD zOS$kR2w@9xiS71znlA;Ue4*jX9l<1DAg(EVnL8mpUoOuxd?^>c=mylf!@!rRNl}!< zRu_3(1ps^I&-Wj;`6E2232WSAeRUTR+}Wu)C$xVA2Sz7p|AMCdiMzlenag^wv&PsV zz~{e6Lx9`Q?U?{~m!v1a_f8-I)Fv-59%v*{=kdDW+mC@j5GmM!rx zXC_Z#FfP5$`=GO<4N*EnG7&^QeGh_o!$X=66%@ouBZ%8aC;3p(MGy}PrRT$II`0gy zV1bW8p|UK8QUv2?cM2WudGXZ_m5BC-qq5c!AWG_;DjCo zDJe|s3nnt*8sY(e85!BQ0w3`Qjn?yYpX>vJefySP{!1{^1a`Ve2IhtTKJ-GVMyF zDiI#$;!=dC7TG(_&q+~Xtt|9^l`vyfm~+6KBIRp%5c2h^7Q`ye=Y9`pK9`fv6^73b zot2cU@-BRSZftr!Pd|?O&9*eDyRej|S+f+(O;|8_>TidDrKfi>elQ6s_F(!CU<-1| zTR(X#$`UYYd_HVCsmAkSk0Jc|U;_*RC?Xf2fFBgd1qD1mT!E=3ac?DmgpZmPb_q2e zz;rZqx4+ZJ^xXcX2=Yw(wU{hs*F_oxgx+@^g-qeUR7W=Iep(y5Zus4Z`cWF86!FXD z$N3sRc%$r0^`2=2ha71nHEuw%&_*&BNCt@Hoy!Hu2!DVie3L|0td=FzwFIOgmA>Ql z)BfGAWyFG{-5QmFLiI}=MFu1fV%?7u$<+GyjbDb^i>wBTcp&&a`m*5n7=O~?cjv+1 z6u%7hoNF0yTKxW!Blw-fy1V1&oBc=1T-W)|1&@sai0IN=o|iWqC(vfA^Ji*H0;j-3 zzA!;@%)6USbOp2G$38CHCX0R{mPs)#6At5|+-7wF7+HvpIY(qH&(CCRnym;kQUZ~M z=cVeY*Z>*awkI5`OAmqq4o&gJ-T7Ax+yLxU#Bz|&Y|1BulqcC^wli_~i@^aMZbB(0 zJ{w^AA(8xmS4w$6y(d_ESNTAM+Ee|QT7&vaw~$75P01^DFYEk$*ZM9?BhQ2vRgtu! z6WQv4e`vx3Gl=j&$sLh=D1k@Jlz_zW+m7mdhmGBr2LAKW9u#3Jb6ETj^g$co3D}l> z3+SOH8>I;-ZTFS;nIa(BPu3+0b%b1|7GcQb9NE}u`=qg#F z%0fS@CuY`%*>`qu4>F3&fTzmN9+lkvZ4Uv!<$e}DMzvwh#}?`ru4t*1hyV6#H% z?HuixK=QtM=o!Ec%2JtQ@(^}bA|S?tdZwRch!YG!v>YJu^VRb{{i*OGsJ4B^4!Y)M z5L;Ap?>`@W1xDi*!3^?m7CBwPJP0=6|!dWR`B7y z?HrrFma|vlo>k8g<2kbU762drH>AmNzFPDUzD9QIAmb$%tB_!-?8*1U*Z7I^Wotb-u4eVG4ICAF~x?(m5#!CWH@t`|aQa>p><=g|@==PClK?C`^f#aP97ClTKYA9}L+o9Tx zT4od3HhuyI1M@lh%mM;5vNxaRlw_xo9Fjw3W#Phqu%897MF!cN&kD7x2vdCQ>8g+m zVUo=WyuaoQ5jm)j}FmWYl;drE~7>v*O`-dGnZ{)XUL8lbj3oK zovdp`Fq<3A$G!9K7gI7Bmf)YKFz$fPn4L7SLM!fV(eJ@3d!igx-&o!uKN*pcs3u+( z?kP*od)k7xZ()P_;0P|GBEH_J)Xx?j%)JDxcx4LeZdeic~=gr3V7pgZ!y?%GRp zOzBn4qg>kCZnQH9?JdNP{C|*Pzw~CNMR~K+P&cwC&lkOe-$nME2p(7I%R*lhk84Qe z3u$s5y~%LkhDsL)wxw`j=zYS08KBU$Cp#Q?ie-cYhw1l4q_Bt}*FRa_Cz~lqT_xd~ zgVVt3Vv(+ZJUDZjW)Xquc;2w+{UHQ^uXA0m_156fRc*RBTD8C^@rb<6H>e==DkJ~R zN%}6cLdyHquU>pl>?ZebHq*R}J%|Sjh?F)5dI^^&FrSiOw6=vrfIWoVa`qI);G+%l z$a4sbVb#t_oO-8~VUAITs}D*;0%(EY1rxgAdA2ZU1%IHFFb|XuHA6$mQ7;(coCp5M zQr-vg)A0*JX~R<2F(>IF;+{HP+YPC;J>;tG2vqa?1*|RSG5jPZP&C{XCOFNB+R{ec zpwxm7?l+oyt>m*k-SKKsRcW4TeVk_q%USIppTRRD37N0yMWmt#3i+D&i!AnLBmM_LpWqJ&YGO$wG+?(2h=S$4bD0h@vQ^6t zaSYJ{wAP}2pVb|wVecgR$ix^!2*|i5KvSB+u&C!upxVR201@%ygqxmat&oqH!--c2 zXsQt=mdPoyS+=XFfC)I!7d@AwN${T~2T~W}A_fE_U3EcZ7{o?)(%x?uHx$*-(CNHO zUjT+0*AM-1yM9}LzS@~qf39BS(w}2fYD%L&o1Y~!jQ%u}0$P8}>?EpCM4ozvqg1grYUWC z7mcUn!1zHmx=UY~mYCinx=3Fc9gr`&na;!V)JPqaWFtGeF1>Ig}m$T*++_`-LS zbxD>U-JYFC)-nn_^@sF2K>v$tHbK7$5Rg`6JN!PvQ26~tcROC^4~IKmXC=#s*Lgs{ z7q6ogNxaUmJJWfcj*N6PNd^YG0=ktYHxeQZjN^5N3jlomsOzjpWD{z_$v54p~kxQj_;GM`H$WA_G1_;|F)OQK*)%$~YCT&b=P6w@(+s#(! zW{W9^0P8sS>^8|F4`j2jkr;kzQET_=WUt9I0Y7|(umHXxo8VjC@4aOEhMLcHr{NR6 zkdh9s>{OC!IpbpyX#|}_P+L02vu>$=6hM&ngPSiS#G4T@uceNCgK z2WEOdZaG+N%fZyov>f!7k~+~N+1QsPt&i*=H!QmtN+KJ>`kJPgA%Lo+ z!kc`OnCAw7s>34mG@IpyK0Wg!EnWdyOrk?NLWP8*W=196wDJvFiO%K)DB@sld7c}S zj3J~PoIMG~*0PNimrM?Lqdq?^X~jpgEeOEQ6KXN%NTe7PoSTXoq9I+G0|WvNP6VP= z)y>%xKh5F->@{?Vz?ui)V2>f?d&{#oXv5p30_YInr5HK(?>rZ{-*s9cAT?J& zRrcVp*j3b~2+uSBtLT;I#HSdBc#p(S;#od&^S=vyTh!~jQV@2R?Lm`T)Gt!LX;JZ% z`_%UA4GMIpy+wULrK}2m3`=tKzf)XPiaqhoUZeFL3Tw}|U<*%y`26E_t6b@8_j9tA zf0Wibl2omGAN0VTm>#W&L8I>|kYe|zFS7N$zC-K#L3T;oeKV~bgCl&gyA^p()Y~9$ z$AR2EY@kT_Y96Zr%@!5L_H9GjB`GsazQS~kaD2Q!41k?&zB1bgp3zSU@24NHO@YyV z2t|M@Tu2paCDO11BnA%WoQdevfReeE&qe0#M-FtDWAX?;uslB*ZR?y_Zj27KuCs

v7^7bddG~L2keS$7y?|Z}z_+tE%jy%`&UQ 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%0Axns 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

  • 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

    WZ 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

    X+bzT@xM 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

    kr+7*&ZjCh(qcm<8%Xyp5^ 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

    n{G0gbcT>Ijk^Nv_`t&y*e~D@T+a0C& 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 z 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%0Doc56p;=-Sys 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⋙nc51v@LXE(I2n$kG*$wpi6L=NB%mQS&B$R;!`f<@o^q&4@G02S zM`5=_Mvq9(1E+&G%?ICr4?gYDA|O?cQt*^kohk7@cFu{Fqmk~GYjNhF(FTR0waptz z=_9L?|BN5ttdl1m5Uuzzhk=hMlF@|T=V9^KK8IL}H!08qe;$s_l`N!J0Y{sAK57Fl zwI1FD{vptQkivZgJf#;lO1z(3+y}Q{G!N@`omY?<9>rUXCQ^=4)BydkIHk%=FC3l5xJ^2Z#-@7>MgBJ3$Tsd)Y9Ba zB3DRbE|y}L!?qBqY$K7%PUHHJ_5?&(X;`kNS`i2(Qmh$PowYn^2!t#{akeVp1x1D0s9>@)!yLw=W@37#S!pIl^+qg&iCH*-=%-{k(Ngn5jvqu)ok6BP6<6n} zW;LypG!dJ{n8V3b!SS1Rk}f!}X(kf~JsvdFXz2ApW(e8aYQ70Vt9)}W^ORdld6o?m zi8?(kz9cjTx8$N4v>Lx`$MCbU`FaHSiJ)m9Rc{NxQ_7ev`=PS$=$WrYy|p&2hHSk_ zSn|z>RrBWN#%8g&*55_j#1L+2cN(uT?HY3;G)qQ8zadPk$`WI{M5AfZfW*^*{M0`6 zkKo@1y$4cwz64LH*ww@TWJ-VIL-wl~74vZPS+$^bZA(j2Ye~-sv?;75SM4HW$Euj3OL5Z*Cx!68r1^A7iO(2D@4Lqe6T>GnI z^jSoGL98?x?p9(U*x-xkBes_eQX_i>pboC>fN*J?bvM%!Xg;iga?nnO__`9u^TkRN0f-VCo9Jhj}RJ}sBli$_rKDz(R-wgGd4M$^u^5}E?cFsEZmqLehr}3eoJz?R* z&ws*=A&^)M2VKKR=GDe?Em7k65cx%sAK{7rJ>tE9vOx+@5qL`9jc1JzqfJ}ew0;$x z?!T*Q+K)z3pCoa#AfG7mAsn}WzXxNclYI|t=-nNYSNa|U@Q_-B&_>2Sv8DH|K88+2qls2Kz$C znvH6J351cFYNT@AO}AIxEeC7a>@fL1*+u7~C5DG(a%G%#I0K|*s2YSbK>N4|N?z_wA_ zg*#jApo^pIkFj;84tzbR38Zkef~WM|>)o_gj2?1SaMX(T{f>^0k|N`IJ+c zn@_=uv3zENUkq9fQsv$No|1ot952V{{~nVc);I`ZWh)#JvOAw>hI_bnn~%00gK=LT z;p=H*R196nZH)SBeWqJ(CL7Su~T-K+YW=X;lbEBTO`(zJ4m zxY6z8SL)(?^IJ%1sds#9YY+G)K)t~axf5NW8c-`YcrGrPxPyh4K1D-TJgvh4J2)MR zZ&5gLDT1xdbi>RHK-DBU*-4p(^IdwxCac;M6X&}}ShDF)^5F+0WJpC>XBrtzk*bG4}+)lmb;z~)c<>xxUfXr$@eJ7w6QE24D&=Q>|)yc zzD#WYytr}%s?&@@@%`N{p0bx>c$R=)2C4^9qJG!c4|v~kcodGc8_y&S9jtTspJ69q zKzGk4ze~$;%a8A#f$yb${v7zXLGOW7`Hh#|^1JK$K>Kp?vw^YK)7i1ne1(gR=2Y>t z_llF^Q@VD&e-y4zt)xR=3|+n?m?uXxdr`lG2`6CA=*f|U^Mnpg(| z#x%%!&f|g9QG7m%5X1$g=?RMa${>R&7ac*?k;zs%+iaYszsIz)0*U{5;8Xj~cftP? z^chIuk9*baPwqT$a7zz0C zm23^;6RdqOWq>1=Lk!n|1;z}c1V0}nO#06MP4dqt#atHVqKrew*z07!B z*2~2{DVKOY)JHzir(VQVCMsr5tGwyW=`#M!4jHV=ct#hm%T4j>ke?dGhv|nzT|64n z_Jk|oUnHN0p?DwRLBA7^K?AjO+g|`t1rNdH7<4RcFFK($3~!jo*xqVT4rp<p+W*Y@epVjmzbyL%weU^~cg#Z9(1|BMQ=wt}=8b{b!p+Rbs<+z&tK);xIb z$lC4UcX;@n9)62Qhv!|7lLOCO!E`w2VzyqAX%AZLsn8R5d+b|quWH^*e}^^=XJ%oz zo@LBpUoyjwi3UCgwX(6YeBn1@`{Lo?$AKn+RQYCtr&KnOo=l&9DJE~XhOyS{aHR-v zyV8xKoKLIBRZsI0EH?AeKS{3l%fepney#U{fI=Nf7-eLMlR-QiJ$kU&PmNZoWQp+USPWw?0YCrHM_-{b^o3VNt z2Ay)0uekos#yGSzD*7Jdmb?=$l?@&*v(6lHq91QM- z#$rCi8KXO?cG^NSg+qXhd1Ilyiq@=~8NY+^v)L@D@!cm%Qa@FeqYXIKe&NU9e+haN zq}uyk@RW*=a}GVK5QQb;R7~S4+72bp=p0ZGy?!S&jJ2*XfrYq%nc4B-v8Is6u<64y2>bic7u_u_iQ!M%fN^w8V@^k>t(Kw;NzKVcu{|nEKeu!s{Zp4_^&|Uf>e1zZ_DzW=zjC4 z@=O$AcQ76Z#>>Q4QTLpo zU7L_?(2Tko?k#8zWhPFMBhcnT#|--clbwu{q}WaUmsw-=8JPUmvuc3?^;#!!?*pzV zen$QG4e*CRe+4Pr{{&CzcOE!~@KnOF+W_sLi=+BbtbG@QZw74! zDIE8Kr}W8rvi`0;zt1`qn}2&jp~~xIpGy6M>*QhQG^s&xm8rdufW_a6_l^=XKsk?R z2DdQghwA|t#@M_9o?&g=-@z!7VM;((SZuDQPSDMayWzTmSHkPQK!tP9d|97bS8Tn{ z1z!ak15)KU6FjA_-TTKAT5n~Es4#GZ2z4MVulw<$p71_`tDqPSycstsay2y_2R#9^ zK!E&iv6Yw;s%XW;oM2)vASIxJZ`cdEivz?H}O30DT2g z<yH51Xud#lyXf48~Y+cy03UYxSFgUJDDcSbDbUV}}o*U%V z%(I5}Ai#yJiQI=(!NE29V&hy)x)q7GE;_=!jGqgy6hAPA=_d&oTK7_k+j%cGu7-o3 z37P{^xVM8BX{qeT{pjZkR5xxwB=5Ba}EXP6Mi~=al5Bgu> z9}N@)sdA)%r*ypeK?+FZo~Y234Nig%_Bs@B^#*Bs6FV{NNa{OPw77T{BR?g#y%_vu zpetMqCnC@8567md@UBcMKgsBk$=bC^$?)^9%8&0>{qJAkGv3EN2S}Cw0C-C6*U5J5 zyludFsdv_t*+D3Ey+}ut-M!By4dO@c;pLzB4XsH3aI|}qvW;1W-y6@fbbgIt-eKqo z*f$#~7aIHy10utl4gFgkKA3RePX1Ci@cXcy0nsxIWwYoQGtwMQ$CwM4U7-iR)a@_y z;83I3{8Hy%=$w9brD0zI^(7wFvv>~XJbdv51`L?8Dp=yxhJBS0ff)y;#02MRgI{Iv zoRnNxp@*(wWK~eizv70UO*ii6`VnTiqX8AuDEm>$-(vMR9{e&;14z~5x8Ny_ReCW` z^r^@G&LM7%qB3DI^MWm`W8SgE>jquC@H3ibK9AELPA=tH;tb-)8HDI!X5j=9=4Hld zNe_x6^KdpO3uiuY6e-SfqRDJfCKR{W=*;jS=+?n>-;WiyiI0ZXz^OQBlz}*F#0h;Q zi2HmvaFh(=1+exmz+b>4h+_;DhZVBPYSf{Zm&IWh1Bzg24n%OOFOdh7M@;7;ZZ7iX z!NGI9lV{$++23G>M%5$JdRdQ){~qiA+reJ~x*SA_`u}&|yVkX?ZH8F-thxp))FnM$ zF^#g7rL2q&>&@B&DM7vj;%H&hgMEUV?;FTNjf1bi$A93_l0mBdCV;1;#=%?decCTJ z4=WIA4#q|FCGsNr7Wul-y^nq$&az=A2qCyt81})ty+4?3CZX+YUL9xa`$&;%g?SUB zCHXD}0~UBTxQWq!bG7-~+ z&m&^nxSDp5a_@MLu3ei-Ylh#tmBHR0+ecGu9M8qUVHoTxL~f8+I5}e)Ha$)=%?lWoJoT+9$F0EdxIs zG!jJVMA~;CJbjw?fi&5?TAiD38}d-&u><@8&@&)aAMyW`7}S3G7jS7nh z$QRq#c6tn@$JJu;dypbE>@%nD1SYK#(iWwq&l;ooxB zrk^FABgE7BR%|OCH?+4hN^$ry(RJroqwTbCfn8`PI}Q}@hj~aRqdu~Hc zQR_NS;xG6#)^C@9Zw74!Dg5o=DJef6pSW=jdd@Wi;-A;FddvETR-sfwsi%I zQh3LJr}X{t%KGjHZn=OPl5h`k?dr^<;f_*JpOsKW{+$;{ygPtL$+7l>e;xD}kivUG zx7$Bl{p-gD*l!-&Kg7+D1Wnb8YoRuI5p$z&*J&=UQL_#-S=zc z?u+VHE%XSCaJhYmLZv*##p^e^czuR23Hae@y`G7JhxHHrB7@?p>@=QF&_2pMjVC)x zjZ)}ha~?H{aer+!^rko5@D&%cDh>)vi`G2<^F?s_=S7%G0b91@~A`Zm)GXMgw7?-_A-cu{jkt8N@9xC#Dl;Wr}AMXL2H(vqFOrI^+tmi`~KCE42#uh7J6E z=9IwcWGgR7oSyPFgSxF+DQh$tP&B)8jB^nVfV$0YmG;34cp9U*@)&ktKOpiAc2h%n5$aH)w zz8UxP+Gb-i|3GKMt(E!;4hOYo>QRIR#LX4Ekg;pH^DhSbcrV?nb=@rM`3UM!-2-HP zjySQP;UHDdE5K7y@rPc$rr&xNhTzyvZJgAwNqQyOMk?~yQSEhiRPgme)eV!6hojki z1%CnlJ#fvOZ{^!I#89?TiZe$hTBJKcOC5LKW0xusUcrlxTy)-P4PJ($VrM6oo z{{6tG#`mAWzYF?1NZ~&Wo|4iFKjs`F`bi_1W^dcP2*EI7UUyq=VdB>1al}&uWL)Z_ zhHKz)U?je;<~Ess^%t>zx)gi^s0pO<-vFLc^+Z{3$M~rg`L{}szaoDL1(g@6Z-mpW zoyK|EAETLkDcLQK<&(s>VPEX#zaQVPZjp)i_+;QrTAGS}O6_De943-2RX6SNW&^2m1q14oKx+ z0iMzca{)DnP>;Ej{6?j z4t25}x?CJ>$Vb(~kHP;GbU#SpcpN;X6KIENYg;$Lhc?V~Hg0Ni{h7(8c(}is5MQfB z@09()`EP7I4FO*Y8V*u8CV;0jp#E|1@eFIBM(PNWn#s612v4A@*r;`)Du%))EKDPM zJg3kp4Zj?qB$8Q)G_m0s=>!Zw*hxvlj?WNc9!NC#s zQnNgG2F#Gm>0YkGfe@a4s1UEFA1%Q`1d+En%mXiEMtsD7FUQv`q1#N`@6Xk!L>a2K0Ef83ZhG#HWpmyXQ{>i2KlsUr^_ ziR^uDFU9Ua_TRSqWxXzT>y6g8wcs~_wt-Z=w!6RYbmMV#j_Py%=n27=(;obQ?+Vi4 z>{?yBa7aacF`Sv?K>Yy1CXPT0-tao$xsn;{5Pw}=^hftf99_sKivCDA{vUYz8`wR8 z6pj?|lm?VHiE$010T}ZM;};swEf+KBrbNUp=@F)VHYA%*wW_3D+AIXGL+Wz#uXn$n z@;?Lo*`V`5D*x-;-zz!xG5a)85AcFbv&a)tbkl_ZX}Q@VG@}iNxHkPWykyxu0=9(X z812(K_qpZA_p5b|f9ugqkO!plj{{GsbDZqg{qNH@341g+I@sLHVqrR3WV&`?UWk{| zj6RA7@jc<6yX}wfRr#I?z72EK>AK)*wHHrycxVpgkak=Xc;K4XEcO`k_#hUxdgGvM=@+Vo~>~ z-ww;tAShM5X}rA7v^(>mH)Z9)D%Wf4xF_IV_yUIWXtKcxMTA%2De$i=2QTt3dsyO4 zp*a+Z`fVZjYS1{4!aLvnz3R8etcRlC;%mvYbp0+;pj#rfhdyB1GXRyqOIZ>;-sICD z)`bVCx%`rz2wKr!NE{u=N7dUC;C~DHBS_(R6FjBw?!Q!dWMCSzIjL_!Ek%SKE_UXx z0?-(%SdQRHr1f^t%|8mkVYOQi)4?wSEd#0iF9c8NKG%-(82PL#_gg7U#G0fsztRto zwX;Fg&L5y+MF+*VU@umX&4b=k>?~*ydT-b9tr0|LmmB2g1)n{3MQJ?i}0KC)IL*Pz$TMp3NH%ZKWcS8}3 zuwp&Vgd`yw>e7Qugi5dx$J)*y#mBM6I%6Uu`?mcOAB8(n=eC{TZvgG?g>MgdN?*J7 z)yMQJF%C9t*|eFK+u<-1<8Tt3N8)X1xN<$yJ}=0GP$(!3S2h@h;tPK*^ZyXvuj4n&FM{KwOiqwIyXVPVWT7_FA9?I{$J{ivHy9lleQb2Ip@pmTcVGvGejt^Z#6 zP^1EEX@M_@oPyeYg_vl|+i%~ z7CfcC@$!1k^=|#Ce3XBtHg=o1{g^4Nn-G2HU?Cpb0rJq4i!oIHi0mI>%d184{WR~D zfFA`K4^sJ022V-J&DH!jQ2r{4UHv(jZ|qZPgx`(%rVtNp3*?h>^kUt7ROa7~?=Nuk ze*pXwpr=79|9^w0^zfx}+`jMXCk~YVNlj;MLVITI(_hi|>TI8$zZW9_APlXmuoN1= z)0p20LCs+VVl^P7b?J9P1J}=CMI5iir3L%t_!21I?BM4k7 z96fF^rs2w)Di5jV35l-@`K$i=|G-<0SMz}szEtp(j@NHn*0w-VQuf;9nzL}M4NagW z_Ge7Hx2OnODS6lhi6Ge{_?h^=Za4pWe7{;hwu8SGbQ4JB|9kM1mbrcu2kK8Uf3p6e zYH5S%0!?|t>2W4KYQ@>|DnomuXet?RaQH5$U%r?XYi7YOk*fk%5%)?XC*W(xl}@C!jpK??tN@F$MH$CRy&y(jaDiCX7V66f>4q2`TG!G8hz zFG%71A9zXw%5&U)DC=27R3WLPnCemEk@{L8lU$`;KNKx+GMBkx9)4PKGrY0eF0Q8?YCj!l2S-qn0M3;ZI` zGLXX22AVd@!~2cnrkW5i`D+ z14bC9v!!aXLOne%@f}3|QRGkUb{Kpx=+z=1h3^^glwNS{EN6Y(Xa6fk0fgDo?@^DZ z->gpkar1!AI`vB}@wyX!Wbx@%yl6drAgujz7<{oTbLJ-+5w8KQH*dV|%YibtM@KX- zKQumZSM2fntT+TMBqNs8d|v4|O-8_)6h9d5&MJ8UoPgn(I2dm2Qn5jvDP`+ z)aTbaGfU0on7I=tJ2Opl{$yuLsjoQ0neS93XPL!j>I#nyBi|d~DIU=lh9KhtPzDG_ zs*%!p&Ro6390oJm1$;^3Qgb=#;c=a}vtT1`D#!UQVcw6xBcOwA&Spbzw^Pjg0_NG{azZD_4{Fyl;`ZfvX5NH9T&1es6k`^6-u~?KFCOv&1tUPuvOS4Weg?H&D#dY@dURZTx*AS>3_u z6>54h3?F7fQ?Us5OGd07iuoQh1nbe;R8FmD$OR+L+S8L$ciq;QK6!&(!X9;Fp3<1*vv#0Z-|T1#&zU|Deyf zQv1A~8`DCB*gYK{<=n=H`^G2XzLDDbWB4&FD}|CNA~GaG<{PFpW4G`*e=X%lsqSqsue+u**NR{)?;3*9#ukELwZ6diP@=LDYgu_G$C|wAC zx?qG`o(=2v(L5av>oSZC`tov)8yczQnT+`IR9*s-IWDzXN&?r0{fu zr<5{~AN_vn=S(Yhaeur)h9Uz70$KWYFGeORe$H?3JX`jYsIQ^GRl-zPFiQit7 z8XCKBA2OWwyJHbQNVJr%8ZzE-qz|r(P2_U^AdOP!jeH>Ms~h>N{dp#AWGg|VKnmY# zvYSOxdLzYd9Lk>h>JMMT#^#M{8ynWgZb%NY|4Qxki(nB0lbKX$7xQaFyBUBJab09F z+nECU<3xC{%f`N^1e+o|zLs`9q*G_6*=Zy?DCh8pFb8Tp0u|={f5>v|2Trv=?*jid zl_4coj>+IDUHm6m&*5SH??ZZzOVV)@YXFHJa@wsoja?RNx5kR+9Pu2n3-TACJp1PG z3T!SW7{iTa+@sInMgBP5@#x-hJlCm8CAAAP$(zbE!afJugkdv+cwORck}7}@SWLs( zHibWpsBO>-TFMu*IyOP4$q*_0Pg%|mltZ=GAHe?!^cG09*N5OK-RH^=cK40L&`*19 zB~M49pc6NpwXusX3J(+BW@I7 zV`;7|8wD+ou+Z{YrR}TCM5m6!Y>CajgIj1#8zx)fA(|m=Qk&`*)avS&2jELLDpDhv5esVaJ-oyjj$|p7*rB`!-CLD zn2KuTME2bctLj=2kGYX{ zMNqxCU#ebQDcuKk;YIcSJj_x@%;STTicqt;M!<+SXJD#2AMThC)z%B80e&;IXrcBN zVM*vJ@DWxCm5bF-m`>%BJbC_NeT+RWcq?>n$y2pV?cd6BZ3FHa{D{`cd%^z!^fE}5 zYxp2pu9m;a@>GvJet#458kwO@}ba!Am2& zP*x#i@mPC|hi8qpM|t>j3`Mi80>p+&G~$dn&tg6@$2-QZG;l4KP;OTt0E(Vq6b*K) zLa1-%TJZ^Xq%6Ssa8w#^##!xTvjqVyTiI~$ zFw{dCu8=6TqukYaQ@uP5{uR(0AXP7)fv5Df8yDkiH}1%H&9AZf{^*LqrNDz+Tndcb zix4tGzvAmEOt8jO!(&bm0fTal5>MDDpm}2whv``k-$PKegQmn=lNDQ^)_~svIvb?$ z-V2`6hpwK-iR^b`c+q;vEjww)1D#ZAr{}N)jKl`QsYV0F4GIyz9VInsT%3caQBn{&>Rq zqII)aPZ!b33ea$mel7&&8E51$b8Afu$z?UCi_1YXr&J_P??&^I7eo~hZg zJfA-!%kln8$1l%TQYaPWp`vv2yWm6{vF$!Lq;c+(wsuXmD1&7il~%Gb+6np)#Sr^Y z8$oO=lq~Eify*o(*EzKNQxg$nK#*X!iZ&V!XnpW7|h0{ zI5cyptmW{>hK38va%}@{CAZiO{wJXOK&o8NgQxU;&Xuc$PY)V1Wt*@$$tEA$S_ z&IY!kQW_2LCh@+&R)%@S%is+Mfyoee3zA+@VF;<#9w+N-5Auy7W11IV0{<6K7f9jy zH+V|M4%xr2yx{o#ytN4@ak=TFN;}9t!I_2X>}p->7Pu~8d@_dVS%#Oy+U3}5E@vBI zsgkNiBNA85kl6U!4E{dQ&p`@TL9Sb0wp_n1){ei9wX`-jHf@r=7ih+&TR$N%$!asM zFuv7UoACvF2jJBro(GtCC5z_`T)fta=d1V)RrCuXZO7<&n0DZD7as1yAv_=$CPK{M zLE}^6_`jKxqMvD)*%MMs`(koicMg{Elt>K@F)6;)#zdZym10JGUVj|^?=rlJOuLkV zCBQ^JC7cFvK`vU(v{UTgz&yq=sZE*?jU2({D>(cEUdHSZ_H6IJ7#m?XI?L_x{47S2P|T-L8S;ji@&@Pd^3Tp9eh+kgC^p;3>W3o_ika>&LsF{c`Vml?{H2bm$1kD*C0(XowMICRbkWXL1>+f3`ombmJWuflZ!_*+4Df)uW2!BbND z0NURjNJz6|{-d>FDzjNn&v?J2@)gcEWRM=isi$oz3-aITRPf>B;z zCG+SRa!4QKd>-($4VL)B1u^_J;OjsOK?;8}cuM{=WW9c}<@ocATdz>f?>*h@V`uCo zHNuzJUIF=UaBD9h7Xqf~&9H5Z)y;+(s3q}tIj6wC#k|a<-6F=x5Q(=Fc%t}B{oo(q zzXE*=Qh2KiCEg*MB~HJq_w`--MR8l%dtST?^CE;ehw-A>@$DCsaX^&5!*-; zJv_sh2nQn6dlDc~1oG$LN=%@@GA`AH7r|89SA zannrIjV;n)GSKhl;`OBbbT>XxgFNJD?~N_Q^qvQ!RgV>d&meCA2V@=@l#`E}NFJBQ zZQn4biks=Mq>$dAiE$5(dul}OJ4kA97c>Pbln#6}2VUwjP2=Vz3i2@_7l`vDOG1!K6f7 zDHrI$Q=L^jFo+Lcguud?BVZfhwcruNlb&xEj514x+m*E;#{+>y3CooQ}2v_7x1X_LsE%X%L5GsDZG=wQ&MrUu3SIByyD_* zY;HLV=1mC2+q!8%vnynX8Gj*g>n<6wwfRM{^V*|pe;i**m0ZSh{9!sPSmmY&rhTr_ z%F`Ia-XzA=Bwq`5k%#GgDHD1tLF*b%J#;2cutDcEELBO|LF~L~hGmTN zBitI?Dj6q1(wzmNQKk_dX;&9xI8H$9K*vfzhrJNCIH-eKYYG;Q0_dj4;Uqs8_A1S2 zWZOH17kFT2eHn9ZL>Q+CypHT(IUM)wq3{^}TN%bOi3`b?8d#!2o#t9>Jmz*Drm9!;NZF&!Tr_bOdI=^cv4XyTF55oyvFX z{O`>9fbmoGTbKp^L^JI-ng2!>8I@Fl86{n>bcWeKW1goND`o}yFVQGvQ)Ii%D2uh* zR`9ogIzX!3-ULsnCPB8_k>CLHiQCWIHgmgLucqrXcUlKb)@feD#p_}wUfacU!2y%b zFL(H~3u`K%Llfr7IFqM4$uN|U!b!^}%qr>5ZQNHD522|I#{natcv2e}0e6YD_PO># z8z^TR_i&uY7V_7bH8C(g7=d!YCCq|uK71lYMu}o*UA3~@HRZ8#Zvej;v<;-neIa;C z|CfEJ>--7}V5DZbxS`&rJyMeijgJg6->V~C&-$4X$MeWX$w@x}uUBB)gA|Taz*ACs z@5Oz`xwr>xSamuy%jJZm++HDjh;wd`(IBpnQk{?tdiS=WJyTPPI<*|1$M%;%h08?f zJLoH=B&B*YB0LMTZw0!4yq@9@+rgn`0Vm;r9vqBgQhX+?h2gE*4=??3VPBZ)ejbjP z`I?re{Mk&%;X{M5-P! z2Qo%yQDCvND9pzhgAk#5EaFO+#U(D*7X|X|szP4?0<+?I&LSwZ!YZP89$y$R%IBGQ zns#nR`b2xuVDC9w?QITR>#j}<#9z+hE@QajclZ)(rZxB$X77drBWqAjlAQ=yf398- zfeuj;dR8iQva=w^u3->pnMsFPxC`1uPNiuk{nO>kOg-si!DAVU{|9sM7k;$q2ZHnB zx4QGL;L*MrsgvQ>F{FoU_@Ey#`$ks7YvAz0HX`sd6P)f;!NH$-4a*5Zzm*M+OZqi) z9%Bw%Sj@t&Fqfqr^#e?aNe`*NxR4=Q^Um(*YAD!eech45%I|fXUW;1yrD@$ zu%8&>c+9w5Y;>z}K;OX{u4B$MO#dM>VfZ&ViK_7u7QU1XhKr3$nOV9r-Au^S&5#)$ zrk8CrFJP5CR2UZ8xlqp=Vzo2#r>xg!FS>wv6#{VDoTs}#$Bd4@gyX1c%s&l~ADG?_ zX6W!@=kSw4J%5y8n&e`?L9dSe4CeJ^FnGiO3ZctS<&C1_J;l6(5a<(;O?NQ;BJRxL zzh%~9_^G;%V+RFIukF^K^F+{uhnaV=EjtR%h(U;pgD6xEn=i-2UofCe^qQAYyrO=bOA_> z&l|u~I-dS*?|Vmtd5zs-B)42j$MKLjitmSDY;ra?bG+GR&QK_~!K=MVqC40pHHduL znKyk@=@}fYrsDW>I5kqPPN3b!}Z5`q_021e&jjgo}ky# z*k#-)V>?_RJ^PFkj(zgQGfO<@$#4%pwY1kK)1;Ni;1ScJYo1CgXv8C?K%8$DADw8Y z7-2hCnKb79St%S!@bZ;7`cH5y1Ou=5=_95>AjxofE72x#Ag@a+F#dX3{6bhNCM z<*rA$l$`fE@V9~P0;zKE1yAYg?;)oV;f~Pc~p3iac(kZ*90eV}kcb1(Vxd`+NfvDZ;J+`fO%(K}m-AzR4TjjXwfi~KUMFC|cz7N1>$suj-c$jsjk44Z zy13pzzN)^QFz$KweO85aF5s**YFBLwvW9J2^Iud6uyig{!iDw6m{pf zEGNiyYn(9@!I>>93%2ZDJu%zPse-Y7F;+)!1Xp)-$t5L2-v}Rr!wJ{Hjk10_fK!#@ z8SpQHUID3c{0%&%MIK*gkAN__d&oAcf~@@RYW@`tJkjaU6w*28^uAAIYk06csvnuaNFM#VDfrHMG|0R6myqXD8 zI6dG6&VlsM#Ju0QX3NHPa*tRdUO)+R%jM^js_HiFnQ7Z_Q_3sxMd34KzIFIs)n1o? zzaDf8NagzkcuK0@T|2M;^EU2ggdY=`xlolvi29~Rc*>(-#B~0q8tX>C6B4nX>xV_> zyV%rTo|cV`T)KBAI@?kh%R*)XS3PIKVHGEh4KW>#=7^6vo2@W#92Ti#lf)k$AFH>C z;J1RdgB1Q>V|t+U@c$(4O1Vwf`pWbA#V;oA$yBGnj*HbdJ>p{ZACRm>IBpF!PWBGAy<>-q zcS6lLK0X!dC&kX_k%*rhp5zN-AB^1{4&&IDrgBfjPP5RtauLfU75h-jILVtDUtMcY z8iU|gX;=geFN_#)4^(Cbxr5yyYy()(kenGR#=g!n%tXD`TxQxHkF(C%ZU!nhIGash zwOwfz!!szX6sF)fZY4?1NpaueH?zz%Gute1OkB1>d46h=nVpWqDul@=n^_~GX0`{P zd?22Q&_3Btnw4lS<*8=WX*5^x$x(QPGqaubd`S`9ADGF;kf0BtH0(e;cJnLD;Oh9$n7_;_#F&cepqguan&;B;gq zBs&>6mc$|6Cj5Gq+o`CVVwNhMUY>3If+sRzqp(Ejq9=E-8sR_KBc9u&`{4JPc5yAq0Zo)H z5{BPJX9#9Lp&c=SZ^uPK-Gvh0LFBLYTSvgdy^0n9DSU3DHW`_`YBC*?+vK)R-((ku>}nJ%~XXuTDv;89Izl0+|-xSYu`T%*BH z1fP0{VPn8$+LIK8uHIADF77oUUq{bP< zfiP&}wUqBc7w10UQ1$nF@P7eyffUYfz*GA0DmnhP{j|?GlvpKd&&=kV(FwIvc@2FjQm2dK z4dhdX&$RxVQ=tP3ihvZ3bnuiOK8~Hh(d}6%cL5NP$w)Vmee5iW25z4B&CKL2gk~up zr`7L}^-+&}>RcR`fxj2D7o>2!2A+b*Z5w# zAY3k<|6$Uk>@`#SRRrBcoExb4*N5I>8hSp``75N8GIDkies$&9s7M{(A(l|2Rr z-MifOpAo}76?`3NAxPnF1W)M&_g=dHdWOWcvaBp7)QQwA#sOrIIC8?Y?chn7BtfMx zAcUs?irT8d+uJ3MeaJ`E-^<|N2mJ%2aG13c$9=BdM*lcO)g5)WAQz1~vZ|g$k1^-d z$mwR*0xW^$>8iLa3$f%NnHw>n7xBXD!t3&<@-xl!OL2V#~Zzp(4 zJ@^K=#|OBLI03Y7MwDV$1JpG)uLs0P-4ZcAHfvq8GoekJP4@uP5uRJqu95j4#P_T9 zfzQOb7c>Z@@?QX+((apNzbgA-pZ?{J)5i5{5#&bR1QeDuY=w_Wx0m%eN`>O|A$di1 zvwTH%8B}SHAgt}23JB$(e{UsN2?6MwLo8aVN=gz0f4f(|ziRluP)= zo=18qbJP?B$Ie$tkIv%`k;CQ@hlFbI&vfmVb4rZ_!*9;wg*YGQLINAl3w&XxM6aUW zia@5>m_0@9A`Z#*5_dgtDcskAzXx9U18gr;(naM_B!zWWa5iJ_PrZ?lpJ&4H9?CEa*J~ z7p;3YiKSNHbH$wRb zI1{Z?a9fna;#ml?FyX6dJ&q~UpeJ*q#I+CkDmm)w;NJ$l3sSiL0iM!~;+2EIhR)SRi+rd+68EAha z>ZM`J<~1U)&BRr!#5uklkx|92dh;%EjK7_09d+3}&+)OKQ)9yFf^4l3C3KLSc0Q*3 zDAn97aXpWG)qdw+;1f>9*asA8UOsu22W zF)qeUJ3t$!^Krx43d`(P>tlwF3@<01js7V;pXaP+Y(=h=gWCz)U z{6*48%T-U3J9g+=``m0k3fq#a7*2`{^*lR|W~PzkNSja6p>C{o-XU=w0gfne5YFs6 zuT}vX2~s%MfT#3~yASEO@whm#xG$JB9~j{}f>3s|52bAC*N{!o!tk`I?E%0v7%Y_= z<6yRsXTbiDPZ{z6_Py>hV?#fOw$vr5`7ZO7O=GTyJa~# zfm5w_?}I-K`W&RnVa%1~Q0K{G_5;WE2dZxrgo;p8kL}4YA$Ue;t7iZ{V67xCf_jL? z;V9fz7fC!d_qgqk{Oa%{(f;7?0o@Byc-{a{>00+(Ryn{uPp|&z;+X=2r7i1eB<8f) z?;GD*tj+!v6R#%myh45$DL&vyed1^Enmf0G!$i}{u#&yw;V9uX&dP8lcmp%0LlS2C zDnd>Qt{LrWvzj_fD;Dk_aSL}j!}N2l%bETPLD#x}D$7?kFE-CC1-}w>8c3CIBX~;n zCqDn4+_d$m?hOI!Vj*DNq}@C(6UMKYgeQne7~k7+uf(w*`KWRB9{B%)^!YIyUxTOg z*et0BaPc|)>jU(vXY}8raO8A*ZwnswvTpBC@$3#9_EIT;M-WFX0K=l~{*aY#I{Crs6gCz| z>wIjE!caHXk3+6XsknDdoaRt@z}OHOB?XYX(~rr^nyK@Q8xq#+ws`s*ukY zG+7Qno901gIuH^^V9=HXc_=va^g;CYnf@HSt3VFvnk_M^q1|*HcMdV*-^_ebPx=G1 zCZu1jrxfw)SZZlnO6qyxQvMm^rIAu+B)^LpgV|VLk&#JSB$F6Sgu3?2c5GV^8^1pR zzaR8CNcE?Gf~TbX*bfwUGS+g1CD_izB9OMTyXDGy052L6m+IQp^AWik+H^slZup_% zY8zoslWmeyFjANb!l{}KBgvSDun|TMTWj3Mbk{i;`r#uIf6c-e{$}uJgU$yj{I`Oq zbiDbeH-7A}7c{JE!nlYX?2_xwfxn~`bEpJgGwr_lc_=|1Pcb=yC&20mR0gu754O?3 z+abnn%cBzKhrprM&A3y%T0W>4q;Sp#Pf6)57N64peBT?V(37q`jh0S1-!~s79o?DY z`3>fN8ZB??+VAEM=NY)J!`>5zD6bJTe2639H9y0opKQ}aI@2iO?+HWwy2mBn8-XVZ zJT#9!5B?p{UqK2lLJtyL?c#GK&h6(PAMa@t?RS1-Ys2QoHIsxtQi6RD5mm)9+A5xI zxVgg!HzazAj|Y;BP%g}4{lOqVIRMo~#AONc(GdU`VKgGD6h?z`W2kjLA@MH;z9{e! z{wu)$6!ZW{;eQuArCF}On6CQc<8Rp_t?c?K!cDRWGer?Dl^-6&i@FPpw{Bh_JA4jq zDj;G+QNo@vJj^0-SbTlUi9-Y^j#EDg9&sEKWy@iI!Bc8`LzZXXYkkTk<&VvX&oaLWZo}c3r~agLGj*TzFE!x+d6}}Mlc__F z_RNA(n3>IHq4-cJk>@}=DuSIuG0aAU^G0}n8cX6V9YTE_5*hs-#>%i`8v!z5Sr{?S zGHTL=2(yu|;}a3Vmo2kqvI5vE@*;h!HPUw@6-BH6jVy0;N$mVq1HK7#I!KjwH+V`) zUUTKG{g#*HHMDz^5+<>|+y~Xyy>xGUpM3p_i%$>8PZQ+bXPd2kgSIQ@8;ly=wkTFg ziOG#t-SjSi#$Bnn=HT8k{CteZ3}=`V0>Cqww?H-ce0Vdznp;KYkK7o!gtO~;S*|0% z9mQwrpNUIhiws%>Qsuf0Jf+2-$?{zLd4J_viL)n^=inA{_2xAgOj%v95jezI7ym-O zy14lCs{Axte3*1dcr*CiFv9xFwC~#j<|JGhAXejz3rqQUY*ylI+q=Y@2}{sKeh%W= zgp5SY(xdK}8@_XH8G^>#!tR)B?w(u8C*C?YeB0cUZk@~b%!MxxT*Fn;E@lB~9FO5! zjAd*hdxrUI*$B@d(rCR(v@Ya_e~|T{{UFw#^TF=`T?JD0FlxEmzH8lm#2x+bBYMw^ zy$_T*U4dKU4+U6Pphi5K#dE26?q%Y2GZ(Km`RbHEyh;~8d`EsdEMITPKiMTel^+Vw z@cv7l_Q!>%@F7kGEVcdU=YsXohN(d@ea?&@WCjx{C?Ni-Mz03PSt7Yki>vTd(7d|RSPSN8 z=7<7bSy6~EJnE;bcz*N~W-jN0(kE0!`5az8syJB6)6Lq7@-btK!%$r0D~%F;o*33z zcbD7$SH$+wMc_w+CV*7`zX&{~S#I2qu><&5>D~Xu-9&7rgG~BScs7$VY1$GzWoSnh zl^PKa$9%AhN`(Qq#~1@UQx9L^_2BrI!g15>Pl3SIL1YI{L6}#0s^Xw=$)QrK+Yr49 z-N!$3C^_<|z*qBES)PNytIh@5sa~xXbTUYlr>I_*=lOAR98a0h|9EaZO8zNI)Jxt* zQ{6%RF6Tv^9n|+T@j6dD59#7{mHb(v_)smLx#C$Yo@a+6PxA13*a)CfDvYdPxwGCHIm9S4?09dS$H33693Fv0wGi6Fra!F5 z`Ailc9}Zzpn3vkdKlL-4KU10@+8$7Q+R@zTH?zq7vBx7 z3bW1_Y?dZEW@1uY5(!F9Hx`ls|IN&3HXi-|q`e7zT}9dWe`d~lm)zXsW?!0{bW78; zP203h_jE6%OK1x%rO>2py3r+cfdWOsrj@loL6oHtSt_CwSp|e5h$tu(710-=D)RCw zLVaIUM3momX70%?DXIGZPd?8%&$+qx%rpDUvtkD#=ZHpJE02ks9`7&4L}o`X5!g!% zD4kZ(UoNQ}QE-Jw_2VLn<(QoDiP5@wt=4x;`yQbELjK=j@DG500Ac$MYcuUz@&&VA z#lPHR-RhmcJ(DOGtkK)IYF2x3$9E6abr-BYI{oI*X)$>UgE;f*NC zACxB>3UY#6+$+}M1%N3vE@Qr3=jipFVDmo(I~sr@QP#P;EXte>h@i&;ED1G56FEAUa;zQ?Z?Ryo zU0;leak-F_obfoIqG_VS3A~s)!Nr*tD$b2TZ3RIqOZw*wa0}d2VSzI~Z$e~zUc(R- z)Dlavz`IE7kY`8i@#mnu6B+NgJA$*_$lNIR4%cM|HliFD9_M*Oz>hFnP#B-pYiy3b zmi4V~h>j&1rdK~YIwm5NqsnODaDZ-z@M*lkH=jlDp;9SO*C)EA`c8qe+(Y5s^%`ux zmtXJ2go~YY3{4d7V{-=ilb96wo+j&IV1);> zq#kAPv7jrQKT6x9Rvj=529@Aiz`Z-E;F+O!6a}+P?%chDr95ozv#6bS~=u*Nz zaZPzUDNk75d%+(79s$DgJ`JwYztX!oy1Yp9*M^qnI=WV>d8js@I>CB!c_rFmQ6)CT zA1?1bn4u$Bo1KRnz$XLKfsl@~!Bx8DJX7zBJO6cm-llEYrk<;5K%DT5_T2rdF&B8! zww_yFr`S+z1N+7cBcoLCM3gfMWxlF(27948lSjZXRdI9mp?nhkez-jjJJ9b7p_oyf zzNyFOp)cg`ybJy@;H=BiKLA{%kiWBQ!@s6q`2(E0WlM+ZHitx~)Xaq&GF*j6@e#7T z+FPgup+tV2h@xGYY(`EcWBJhS+S+UFEFAp7znm{jZpf=5hTfgf6OO|#f`0|r4}|so z5V%UWw3uHWk17Mwo~WV2 zTA!`AA>ea>1wcs03*ag(ebdm<*^3{pRowy_rOd2q4Z;1!_O{JCRP_;l_DNrdpM6s5 zTVZ%r8^Bj!d!DY$73(?g4#iS5UpChHgK(wiRAb;0;9|PU z1ZSaF7^z7_*o!1&QB@q*4zb)uiAh}@alxX|v@Ea9p(&j5I(JZ`#-jR4_rf7#x1+W; zXTOlY5vWk39=t*J!4**==XB@4g+13gl56Uzc0+c2oCMwh>;S@gdg)A4Pj8Pj`+{|= zKYf4jY4wDikE)|1?#teLt~lae71OuNq`rOKd5_5iHdcxC!RhU6cdHl>{!pjI+0g{2 zU^iUr5)YgIocuYk+#~4t_RZYAp_hyHs4qX`;;BWg!Gq3pE95Zr*cRrYUeGDrGf@oP zDkCv3Z7*K$Zzws@pL;-iZYfWnu72iD@sq(MDz-X3*4-FByA#vo;MQOaJ9I#s{@(CH z^$B^)Nq(+dn4S@S+nppQ+LPRggEBM~AN@T$y*|u^?+s2*4u2K!i;B!I%DaEz7N^^f z`u^DT@Mvo{g%k7V`}1hloXa^`+V*^R(MzJ5twW@L-k=mkZgCg5rNcOvy7BWX-Lgu@ z%{@%Ot{^k9JdA~y!y)a*LY$Jo?GJ{>{oN~kdxhNLFQtDZPR8pblHKC(n*r2NVfsb$ z#w;IcJNQ1}4j}9o?}Mwf?in+F;?J9V&-Lol`o%GJ+f`li8L>}_E_qPu+ePN-_vSW8 ze>QiYW-nbASf5=njG==(G{{ZFym_`CogyRok)VWa;sBY(@~%SSIiT9@>&|xlk@!7y z-P%+`Fd4i5+DKg`n>3c{h!RldXbb7pFhMZp;{ZR}{(|tjgzSizZf>=tO?|X%%F4$s z1-}n?5D4qz&}LH~ho+eyUV8SwKTeFU9O^3CGC&QP&fu2l$G+$co|F3aIrDU$ez;ud z+tQDHHOc(7)Ovfx2=wNOC_uC-T&U+a#drGUa+r6H)0b`R*+_|_1xYM+9~E30ipQo) z(QC8ExZ~KFqG|2P!M)#r#>Rs<`hC|eP<%AEX@aQ1#FAJ$x;MrHNrh!4Lcj#D+a z((dDy_htTePY;&6i-J?I@EqvYZc8Z}^%#45E6$+Z8L?7DUt`0c>mK-m88fUC6s zyJj4``oe!a9*)`|*K|3*cK11=3z?9qdc-n-`O{PAp(sR%d${YzH1rm2iS7BSV-Rl4>WM zb0P=U7$F96HPh~{ar3acJ`Ekq3S2?>95>4`sVesUq@T>4#Y$d+xCP%dgP4?uQz_Wy zsy&hz=j^g;ywi}}eO`DqVo0nc-X2>Nzf8oY1j~I>Tby6UnEHN{`c#-Yum2YOec*3E zSl?r|n)>d1$^3G5&wh5C`VP&*ly0%q`otG!G>I>DtRJnc#uaM4)`wI9?-5ZWi11vj zizr(Ke0rj$5^%914||u$AY~|;@;#43XM+z(ezJ1;<#T>o0rF1@|-kz@UDSDy<&N~ zIaB1xg_L@YQ;uBcIs9Pq{XE&0Gb%YvF3h`D7Ca*I(gm|*UhxyEnsn-DHuZU!`U=li zx!a>w5l{w%_1OOFWj3ghXgC9!3KEOS=TW16l$345UcTRC}Q;w>qbq`fS*dJufT=-vn$0Li%q8 zS1I(Tv;8wY=DAPhKOXH>hjks^^0$l^oy*`OE4tsdt;bg5Jy*cm3cOOL=Kk#blR1d} z+zQWD-T;W{?P8Zk_7@;RaPsWAay{ql>4xsNp(_nts@}`bM)nU32SU1MgR2zEqr280 zk8UN(%${>H<0`9j(M2E~t%Z6mH%0!#()!WrL7Y?SWIQ0!g!?(gAs}co-nj9c(IQZ8 zHtE0&L+?${ljb8u?+?NM0{k5a=^cEIp?A;ghR%{-{KxcW{EKN}>_PD$Qyf+lC+X|y z`uaulQLcXAswM)2>2Izco#Fl#a(85Z&S6yz&M>zDxBapb)rJAgf`zidPcG2B--R67 zXUowv)I@|}#BR1ry>WJ0E0Y|VWy-so@`UAm8vIwlZ-B78-cD2A2{)K>R%G<@{)2sV zPm}5{&dK`(dLl#hwM<{D_vvCjV#9eFN%8vO?NF)8sDQb?Qy~{PIkLu&;jN`cP3I>& zO%!guUrLarVrL0@x+j?OEQQ{%JbS>u4BQ2T<@ph~N}(UYf}Z|pJ~2){wZCb-?d}Pv z_^|l4ctc-}Y+e(nxe@e!Z;8DVOWmg4Q5Do{DEg_$w(4Cv$ZZKCH6v+{9CW0Wsb`rpmQ6*C+M%tb6&hH7)7Uf4Rdlq>Gjtz@ zt~AeT93{@f_XSV}gml+|tMpn%uGgD> zvVOUyQcg46zSA;GQOA5!FCXy!F#q!NqgD+t00{GM0RK<(&&H7n3HZ%11RTlazmxZe z`F{!gPT;FRnExZ-|4#l#=`UupKRS%f?;+vXFg8}l0#gsxt}GqZ;I%+K5YjOk{6C~4 zY=-WTk$-`N(WV)?14kat1f}o36tWch2P3$-A3)uNnupgMSNn5(vxx z7Pv~g{)InO#90K#&<46f3~JI#Dw-}UMHkE6yXGKp?movmT; zE95bE*!L+lupb!xuP>V0KqH)aIk1kbJ(qoI!t2ZRJdOaBcoacjcwDMHYEPBJ%L{56 zlH;AmQG6osAwJ32fT@R}tJ*fNYS#vCcx@LAF&$QBn)Qu!SW{wgLFh}L&M=A)Tn93AJW4*{yzwjW zcYr?uAsy~T|6l0XvKhBRYB}2@PP;}Kxks)M${eUuSdS@MaHR|rIF3&tY&@Z8usm6p z7C(qfP5rcxZ%Efg;8z0I0wG;@ga7CCvn}JXzq|iHV{!9Lj1$IAR?9BdDKD?X(>@ky z#ncy?GdV?yM$2lF8+3k$GxQxH|0JKNeqC~L)anb=0wI0F!By&2-lp4+cwybPGJ5nL zrKsF72vv!#u(>XGkQu)VS=R}{OE*ZxD(gDc)YDG#QJA9RI`FRp-vmNB4uPxmT1M|^ zZqGPMW;}0Ry)C-~+#^objW$|e6Z*Q*ocq2it$Ws2%Yi78#e;l5U)`PjL~dRoqhet$ zd38!{0(WScp|9kU?7nFl_#9w95Yl%FxJteHb=35&*|=ldIvq*E^mem#(jTZ^);wO% zcc)m-udkFN)Oz zLOrN1bQwW-q2dhHRKw&c`lVbBX6UHBG|SgK3A_zh1B7(!0#_;YN8g*>m8Qg;6f+yi zur}~~aiv+OW|~9e`@(vQHd`g*(E=Y9yez;qv-UzY5^wMszcUAyn|gYl{1v9^=?~z4 z20jEr`s~XLeW4!BG4jOBc|+5uI7EbI4XymKWcrqTPoF99k^R{X)$)KoXK!%+q+YL6 z`V2!y3;Bd{&2zvn1TFJ620vuQ8F7n*c1 zL&vM+6Vf3+8?_=p4iM5&2(HrJ3CEkKGuHV!$kxI|i+l8(Ze!%zA*980-x-Dst9gZ~ zk5=+&;xpAQp9Q}PxE2WM_#(JU&BwKuG-KSzc|Tbl-89_uNg57j@;}V`!+P*PhaU(a z9|-d=16Qfn_R!;4=c&$TQ&yeXqY_$|uTU$*Io87vu*g)xY|7J`DL?N|^L|zSE5NS< zZUn;oZv$89`16R)Kjc>&OGEPsdLCJAeFqwv4Gp98YpnwrI^HIqupa&ap4g2)3?QVV zKe$T0>b+#<+f^qrH7GsrjDmNlBspm&cCQap~;VaXGZo)JF&Tgml~r{t)mO z5YjQ?^M;OlpEdn*d4_-8lh2`Rgwtn6yR64tLS&~excAxO06vQKZ8wTUYDHp)@cstW zXi+#V3`RMHUXGUo!!{o~nkcGM5x5&U!uLkVxD$a((Bu?55kzG*`1yC&26LnMW?}DC zn|9ab!8>S^Gc)R_{c2~N))(1<+eDl+6s}59_>DBBu*}MxrdZ%=g_(tB%^Nbf6$Y-D zBGdMHxMCP*&k$M}@6cLPKYJ*DSU=wb|2gm)5Z2E>!Bu+y+)VvkZtmUnlkKm^dPvlh z$S3=YWv@Yrs`H{=B1G_h^3ACyCCwLAY^akD2F4hK^UsC#=Um zgU7ERehLuM(GIRs$A6jnTld>ftH+)ijMUb*9W7=4i4i$hm`cMX)omMx$SAD@{2k zWb~EZ?CD>|>{FCw)DpEJpSNvocHv`~|Hal)5ljwr@3_ykKG-rK{g!|4ffZq+=3xsq&53W*Z=hvHGDl-#iw!@rt zv5A_osbl-OC+%q8p{>vkiB&Ht)9C+$i>CVX2hw_O6A^TY*~jS!`6ksb7I7bDYn33P z5H=8pZhFQ6Lg!hA-jb`b{bwThd|(j}(tAF*N)sM6{pPiA_2@rG?z>1|uBJRO#G z;;sK~^eS_Sp6&G{V{)6=r=gQtmYIinLf_x%|2a z=J*4=7lgAxCWr8`nae)dl6)8%MA z>w7zfi4>rw)BQi^V@Gtlj|+Y4tFP}$eXG^iHho?Av7?&d#h7)==CfrAKYOLY88VF% z*$UAoUg$;g?EGRJ=#QqK&$lZGo>qh-)C&CM+rC{COAW^A#5sF#Ku8rZ<2^IdfxTMM z3_0DkPxEyvVn6<}Agbg#(a$?4X9ga55~80w+?gj92aP#1M2+JI)j3lVCwLh@7YEKa z^<-U>mFElrZvrL&VLi3krFR*+ZX#cWseQu_!G8_B1%z}J?J;!CJ=OHPmR{ma^rQ<;S$o^2 zB@Fepl^ffqp1ZwW%Rf5B^_p3BjlTLYH)t|xeYCk6enSl+rzC+=l+rSe1-*pQH}fkB z?LIQLFc+1gNWQJKaiOSAMR%Nx%d(COOgUPivpG|a%fa^pUkAc+M6NaEcgXF}d(u9b* z!vf!%l!F#4-s=;kZVAzP2FWtaCHmx`&z~2Z;14PhtMsqzgL}5)(K@cw0otWs z(@j^S4+r=ydVfnb!AQ|pK+C0?c_l!29gVOGMF-zbwKtmlDEY6U{Gj$t>6U zy&#O3Nry7|?Bt!Q#HyTM0KXf!7YNIFKe$S@t4%py`;_(l6ZtJVr>#RZ!9np)qqflg z6s6naTxMJE2rkwE4j)d1FyZs8)+;mZe^Zt}Q3YNH3gB}qBh%%`pdYqF#qM6=1@1C-0$Y{;53dhm>^XK?IakTU1{hz#Y;o{yey z7VTKMP0y=r!@uF_ZFZHuZc>}=Je&z5C$H}?g1xG+uLE+irSdbyyeFN>=R%@HhdaLUeLr(|!h5g_%@ZG?bKuFK^;3^&LO+K)G+x#uWpD{go8Wc>k7U#+# zYR55L=37TH`5fXsVg3FI{C(hq%)8Y(cAWNXA^iE4Ra-V{cKcD5#MWM?*gD0Se_F{~ zO?jGc%jUBZd?Roc5SC{LxJsei8J3OGO|m2JFnlqPHB+PnN_#iBb3%CLf~uoW4Go!2`kA_&NR{R z!*5rv(2g|G7L(?fFisf|oTlB1AM?TrO+Si`*-zN-)if+ z>Eo<0ZOfK3*Q>1-A=&P6o|59AY<>#P++Js|Yu$p22g3PIl%ENb_9SG$ym}TZ-f9)N zbrHtB*sSB*}2 zk{S7XGWmA!-e%sb+UpAN_kq6wVZH^on|wcLH2kQJ@yGC`y6Z!qG1X*v#QBN;o+FMp zmq>kkROs6hef_bmZ$tF8P+uqM>v{S*USC)1tNHKW&9A@Y>d#vAHT50~>t5#z<<>vF zHg>Z4C4*6%DfH6u{)9sxEmzj$L|O=@l)Oa*H;Z2rmOvH-qwvmiCnhkmC_W80o{{8q zep7_LD_8Gi_z-!Cc{1{lh&?HCqdBs$!527Nc`Dqr0q&{6IJdMh<>C*nI))Fr9Qbr6%N6^&j$ zcdkcxn?^Y*@}vmL#dLRwm+LkX3v`EbtFXtTB#<*)a>_p2zEZg3Wsw-Ex}Vi>!1UMs z^oumls^2^T{ypGDAnZ40YW;L zf~z!PhM8ZE*&pe1obo1q3XxrLfvRS}PAqK{$EHJFhN#O}bxEtsjru<;I8N<#K5(t) zBh}Gd+lxkXar>-kUr0Bv7CG?U)g9{)r_T^MAkrT{BsM)z3`dd1CAbDxA66AUiK}DK zxJf=Bp zS>Qwcnbt><%8FU#da_bB)hZ<)HuB%d`%%o6BSN1v&#;u2=!(ccjoWZ&d*})e?W789(obw|pdgC;&KT@S4 zVe`44ic|+RGM+O_&US(Z-;D))9^-R@!N9W3nI@-WkQ592IG_8O&pn4of~kCA7r7}u zFLF!qpB5>ubo=4Ho~t_ar22A4B$du1l5E;7%qej5mgKvo_5ROAPBO05_SY&~gsIME z`CTWd7B&1$wAaH#P7nr9rIsg5{k7het-tfZuLiCM!uop%T&0Z}{l;VZB|hS|wP&XM zx$8CWgMRr3-TQW`j#zo2s=BY(*6Xoql%h{TQT;^xZ@99Q_%4gkTaPH+^+>`dqZ8yK z()eq)o;37XcW2k&GVvLXvHQol!eTZIXgqD-Vl)fY$U!SWwBDk& ziB&5Ud5=l!FOb(SsyOHcY#mZIvShm=IFEXks^8Z``2Yf?wtM9&zvib5eO=@q@T~g% zx51wUo(DquehRKqukr~5WXIB%YHo%G!pnd-u5&al=u;RjZEJzY_1MXg=>o^zBFH=_e+{PqqH+7XHOic1XrNtylbFWz}q9=j`~kVCpmL5 z&x-`r7qYnl8D5igpC{rKBG}>RG?x}K_tB{2G3@1S5Z53Eu`|&*e zX7Hy~4h7$iPX1=pkN5d@GQ9ANd#uLx41>+w8xoF88t9VHp^=y?1%_&c}w8@cWvy5%-@vP z7(bVz$;jN7gg868)W1>`l*tW+14~K@OPu~V?ewcTbidHwAnJuo?*4|8{Vd zIx_Ys!QNx`ubbL-YB`e`9a;6{BjS(7O!G>13^3!bH&6YQrqy2O6`}|v)H;|KPht}{ z3(1O)2m{~ner~av--43G-V$8d<UBM-t?OB?tQzwqJ-AM_-b_?tRl>S5 zB2??Mntx>S-^u&KbHT0PUj@Dig!w-WuF`S%jotg;_MIKLEmta;==T{Zc=j{k=2zosCKsK2>FmOPtqys#4ayE@=;|Wh zu$~TrzX<#c2LJnI(DxO1Hqb`T$f)>0gwl-THEpq-3L+zLjq z#t!nMIr%X^u_VV&G;xF{-|61>j%Bg2o zZUXT4i(kl-+*91~e$5h2QcZ4RlsnFK6C+W(Ct8H`+|qrbv@hnE)CFgvR-9tvX={a?7HN&Khd(#IFo!+U*>aUk<=rX@N>U~9zL%c7V)xdfn%>Q<9mBP3N6P6vb4jdIsGZROP_OIF_uVs}Id*plO zc7cAFcnurk-OgK{^^P+JzYQfpJb~?ymrKapF_9^@TORatQ{N%X0ZMhF3o+g=#1kow zshWJ{l~g;}xLBkavP*4ajWTIhXw=Gyn14 zu-;w;e*^d}5a#>e;3^%b{f^ETamwPYdg)9x4AMDIw_f(9Th`Fbmbf*OZ^HxGeZ$G% zn}DrAnD6c2D)kx%tF~@y_q=;-Jl6x_0o<}-4fLA1UB*o{-Xo6nnnxfir%%8EM-bo> zx3bHTMD*trE&X~2V-L>J_`G(8tDTSw6^)X8?@GZcOX_;l)Y}p03+t`uLH0es03f7) z9JoryskbcsTiee<)~2JOx8ZV4b^q1@tnstickFhqLz<(>~&SEJde%x6rq*NPRnK>sz6|PW%|B z6T6+i$E_#*6~PWTx)GcgsW_)zvLKjMEo*`#{6eoFQ8>nL$^ka9H7?4_9~;beV-vws zazJHC$}d;~Ea%A`7>sa<22)j?tZ@Y^U`>geUrrc_!m4I}auOryKL}AID%_eJ%5|@B zrpP;_w_cX{v+P+Mv`)vL_zB)%dyZWh%p=(QNwS^*5-C5eD}hV%A5FcrJe=K^Yy{s4 zTmXdib``iv%NLmW>==8_+PX#UThCS!bWYZ6X*DCN`7*)oXzFCui2oz3+kjm4GkD%3=y(7j9dp4|IuUElVUz+1pfeI2P>1MGG#cdWMqrD>Y*h~(MFO|b=mXR}CqgH1YcTnX|koknGY zUhVtvQTq;c8`V;KpYT?S;bNM^2q%-8kC<|FL8ro0Ilcw{W8g3lmcxJ4l;gEb+%PAj z7v4QSs6}EOtk3c$ID+3|4%j!D1NPT=QWg8Ez=;1MTU`*?M~2DTgddB@vtIE^euipg ziKtO=!|aOq5%Ho|@`86xE?JL5c^vk^8oM6$E_Am1pP_pxbcOTGS>P7|mjfZ)UEnH( z^UUg=;~KujC+S9O>ySAi4pLfMyPXS&9>g4TX|!4{f7Z)?232YJ81_IZRh=Tjp33_> z-Z%8TO@3*fRXw`jidyAB8VKoG0It$489UDAt9tZ@upW(O$)fe=>6zxB*sQz2WwySp zP&ya8oj*I))lgLe*Xab5x_8T1b=*g;JW}S1VpEC4ymNE46*Bq+WPP`gL-7ZS`#5As z)pE2ZhRcz^82a}^Us#_{gTDy;7zpYAA8?hz`aDK2Cah0GznUeR*E6OT>oN6)u{E zJI&H}F@~^eSpC4Z-h#F~FE=`$&3z4<`-lnv?*n;-svi9~?srOJ%K4ohPFv&_l+5l` zBw1a5%d|gqDNMD0^6{uu43q;Q-TlE;I?j3j)9DV+lPRVrwPQKm`fLpMYLX}g?4i5Q z{nm$ujt=sfouT70@Ed`ffshXIgrOt8$n?KQ+k5oGwvG;TiZcpVRh`a8RGi9{{d@oX;<@G-uJZI~$V2{9>Fi^MYLYT|@PoJL)5M?N;?Yk~fT zO!+p0KMouO!t#xL(v{)%JPO><7!`U$>a%@OxqU%P|6&-jS^yRDzTD)epF zQP&&If37m#Bdhg){${@RCO6fkuC20Oj;)k^f=VxmAE!cD79Fj8DkajvAeoQ%U{qpi znt*b^m2kna5|s`@GWdv5&+`UwcAP8Al?FPjsA5sJN!YXN*64c)VDSo@_U7&Yj?tB!ZLurEom(^fZr!71@ZLfJueGt-Oc;2e*kJ=GyrN z%XO2fTlHr2kTFAs^TJXK5nY#aTv7|=W1**I`V=~7P`gd_?J2@(r1`kgA+2l zywdM;np zMDq%~LISqd6xLUwo9_;hBl>bj&Nv{2RM0Jobc%>Nl$H3+YL45CxS&lbh!Z(#GJ3Xc zL_MhSmn8ZW{+B2zm%o$INrS5DM&c#7R759R_YAao?PQ%c{R>~drZX^6CIG1ee_PQbXato2TV4pQ8lH1xERUr5iz;QN3(fRLWw zf~yqj{T%KYKj!H3f}XpxM1`*JmTLCt9cB3$PYT>;*pn0xUVL>sk`m?dCdIBpeRf_-e ztnU!TA}^X3MU?D{;$$**0$vLGBS+4~6pet!auk7NGxr#o{zBqn?gTl;-LE=ESCOIj zZRkn!tmw^o8eT6@2ZZ#F|E{6;P_3DdZfQMsURt+f^OLfU@p_flUDLEM7dr(&6O|O#aWW6&u?o71P zQ{1WX=;E4GRWw~y%Xv1hZK&Ya|+$%HFSepB(14A3iiNy@`af|bMLBT_$?@>Ln&2rzK+FSFgx z!h7ozM|z_C_OlhU-Dgpj#P8wP?BHH(L&{#V-9xs6VcbkPRoY*+gWK(TLewPl^1p5q z?Zma6&)fdx_F8Cq#dhDYgQ%hn-@aGqNGO-1b&1o&FWd5Vn;qz_c5s_5znl5iXWZ(> zyEFJsx47aGJGj)A*lQD{B>csg z{NGCYzAGwzErZ`k`T6euOsx2o3|^P=vhGiwv4dxAcUnZ(NJ3xTze)E)IsDI3mEi>` ze7i@X|hYCdr11zVBnlTV;3hM8lN^!=&SoZ={_&r^^-4_{zXhu#b~+4e<+;a z3#Z;0l^1pEBZI;A3iB@Ikg!5U<&jdB69Vho;sPh)C7pOdJcyPLLsD7A0X|+3eLw~e zN?A4RdUcNuN+#Sd$iQ|VmF~3okA?e+NWLxn{}!pAv3qr|lx*b zdZp>T+c_LqcctdQFY}m}T#=NsVRE9G>3BJQ83Gk_vF;aze#uz2b6*hbf{O_(G+>C2 zc8Xt%mk`_^*ZXW^*uhNaFoe5tv>!&s5(IfFRpo=Hzf_)u%94DLwb84#5wI4^6aA^K z_PwUcacG1ockB0#TK~bX0rmo6x$gy6Dcp~Iiak|!Kcd{`OxZ}78qK~(4MMBqbX=&) z{DQFFNmVOuGi;(_AO=M21#07UyRofO`E-pmbbUa+O+2giD0n_!6YBc$F@ZRuza2@!~Ko=0^yB}PoUj1wxlW(_q zN9uq$*W~^MVLew+DLYi|%cSm5hco#f;r%VVUzI!lee9Zmu|SxA8@NiHlT1H6<{W)= z{^w+je`txDwL;3b_4OpBmNK&Yq7|nqbR&K2Scj;VGB&@B*yJU=B0OiOyeP&93nPt@ zMt7)7@CV~AV2FI#L0&P&)Z2dO3eW#9g1-v<3JB>IKQMIndj3C}?ltQ-uiv&VBR|%x zfUhh5TK#0zk^T-#rI7utlZWnMK7WNlF^&@O!c^t|oB19v%*fky62(c#ZR^H!Aw1PE1^eGV*#GWEA^xqxN?FG43R@CRl@+)FkUUAn zFgR6K>+G!bI743-`G@WPZSd!T9|9qL{|&CvaoXLSr)l%HjWd-$B1KPg9qn!Ssh1;# zFRGM@L?jW7MLf(y9a%_B2~R5i-c&hTzyCmno`x5*^vnid04xGRdRBn{Tl9p2s#J56 z=9?_C?od=Pk7`w<0n!*MCC8h3*w1^zdUz51m%tl9nD3v!RXR@GcT*2KU%iVbaOIM= z^?I@EREA*;S{3VkxARS5y$S~)Ay4sgpoVzws@v4bX)-PP>s*-MGjuioFuSgu2EGQ^ z0EBd%2d+|6Z~oAb-)Xrl5~$E8T&lSrtuqK+fZfhItFyQg=2z6N2_=Y2l`cT@1XC{u zd4HPstNH9O_}jocK$!m#aFu%113>#eGZ7f~I{K=*NT)dcLdDS9Y28@7)3WBvI`y7| znS7gml-+l4TSj~e#zu}WQsXQE#7hLc`8$Gxc%f;b0G3c^uCBV5E-Pex7zyl zJ#*WrAKLWw`$FF~=<7lA@Lg9wU1Yvpejg3C+j%@~-BLV4E-UHpls+u{hlnUw;+1&y z!AQcs%Ko_M2#UU@wp>%t$u9L4%7!4)s4NwWE)wp=BCkR*h5BFtUKX$4;cirFNJW@W z%ScfrF(}>Q{29R+ZgC$!m>A5gAZRx{n~MZ0TW-*T#w3mmE|BM8V_uN-mIoV8N6%$@ zk_|6877N}d+*8@s4*SPXQR>n|bOqQZV|$!WnFn45UzPb>%)qhK&E zXo1gjVldwoRjKjVq{ZawiS< zM7oZ8+xrvnPw{5lOGFhY)R$n?UQ}FE;;O^{9CWzl7o|8Qc}DIpWx*Ebv!eLyf*VvM zZ?@JA#phOR#Ma>yIih-HS+aCY*VRb!F%Yew-agwcx{mkw8e#L~xbTz1g+RZri+iWBb;b zJ2tNxswG%Tms(G?*fE$>(3_$Kh%fxCe)|3|@9 z>h`aek)L(%kHc|`4esacmo(@6tG2ZV4(43`s+GogR83k+3{Qs zUIPpO!u;#NRqE=^Ul>+NGq>z8-Y&Ft`EIP)yUJ+>?ejI=V)E(WJq^4^mGctty}%cN zFrR@xG5IvTW%ggQe{b&HX6gR7klz>UgU#-VWhmde(l7CI^WblfM{}@N#ovo2BO{d>wd~I!VXQj& zdEFa(2qE2=8j)Psig_Uw4cgiNiZxsay`7V(MoPrj(ws`bPbY7Spxy;)Hyrz&->31%K|USjgIewxj1 zAox&V1Q6yo0bHeC`@Py%nik270E_^Y05|OZ9gDXp3bt4uK*1E#{ZGy686U{dv73C- zHxDvdZo7y2>V_UcNQKnmY zUcEO^j)vb*??%y%j|Q&rBQ$gb4N}WmB=@TrFhgyV3+wEurk-klmOU>`2cHit0z&$} z1g=uSO__dsU5|d7k!#P}v2)PSO)3IC%|rN>M+o1d2z=AEzSC!f(;^(<#oc&8>T~!} z^P*0a4TyTo3%JIDcoKb&{FrnXdu}{8FJSLDu^WrzHxxs~16?guk|%)7_k(e!6pT9sgrlhMk{=G%s_px1 zc#1mTLn{rPN1!9*7sX!17a~vugmm@+SLxtH(+`e0|4w7qrZ=itH({xk1t^W~b~aeo z)l|xvYL=NK>-B4_=2a%&b-XvtN2(n!2fqop6$tbFF1SipX8e2~<3Dtp)(Xk=yiZIq zoW8fH&HH;o@7_BxpsIlpA|vsrTZ-G{s6T@tHQdX!hp>fK1}?cAb+k*q^YNp9tq^l4 z?`lJ5@)z0j;1uw=z)3(z=jq@o9p@aYTMzvebBd+D)~sKGJN6g%^RsUPf%^hdZ zsLJ?!w{r!qPN}*?dRAVpYPMx^xXuNAigrWSe)0|X2j2nz1@Jl$(lz*(hOTu#Gws&& z+^5e!&=nGZG152uH&g(euNf<(87kHd0{4h@d*5Z~u_mMa;tBLuS~;EeC5XIBc)N() zz#hsc(DAzh@qi0I%vRp(Jlk;-4PJl7^61GpgUcBZ863E=BE^Ea2=J;|d!mf9Qdc?%ACu4k=w$d9+IrmTwjyJlW+zbp=NI5A9Vbpg*dH@~ z`HMT2)9;$}Wb!b^kNwn1cRU0z-Nkqr%3Zwgz?r5#(ywLbiy7c^ffgXle;K$+p?&w< znZ5QqPPjWd)V5&6im(eBM~=Il?bf{mDp5kKRy>ed4oClnjVAvt-XHLOHE;X`{B__r zK$!m#aFvd8P6*4t1s~(I$$TV_+QfZ&`( zhdNMg`_yUofY_u(1NX!2S8M)3+xigh`COUEkK#u~#+WuHtL4+3s^+wjXysfl#7SPY z5+yfpF?8;Pj&NSv2Yx$nSB5sVa!u&X4?_EvHAZzvS?z0n&f+abki2*cHCF*a71m9I zl&-Q$t(pAZ=H20VioX%Ha)A_}lFF~Ow{`DR^HUV?yBad9vA#5@hW?SsXDROt%XL2Z zmB6(?SpUz1tMqoppU#2Ixw3n|1&en3{FeC{-pnT!yqbePa%)k?R)_P z+(9E`3EmasUIX#{PE{skxkN#9(_qBBWcP9gqCy^Ov>O{FyGBbGq2K2n#@klY9?8Sm zeeNjm8NeJMq`MVdrC#;BaCN!rOtneS2T~(0?-uYQRl3$_cQu(l^9MNfb=9mfDX+#x zVbac5s$J@wx>%m0T+^ku8M?a2mq$GhJP!UO@SO}Ts@-}$4{hGDX)djVPpD}Nw``p| zlja&ujSaV6t&6f#LNF+7$F|)B(c*=)S~K~T{5soDMuJZPW&&Y7oB^&sWete48QlSODM<>$ftXWDVS zf_Q(wEYcA11$yT>3=rnu z0It%Nz1bftJHKt%%Y1@>E=j&zp1`4Lo*d>BAQ`liDiCw79gC;jl=2^lX%T_tkd5m4 z`L4j)mVM?qhOV9DJDX>>3RlSrR67@c09%|TAlNusrxK>y&{RrJ7{|k zLkZbM{HKmu$jCX|#tQPhA{(->8iz1qr1JXj2?F0_(&3$kuH>89em@X=4zK_S>ADD9 zrFVMsv$UzB@o2I*itm^EjtW9kuOIq{SJi-TIaZflO$g_)vev^wnvi_C_=rp8SNU5b zuF^e>*ObbVcutk@?J65k&3qUa2vY9K(BE>tq5lx{h4cH{;O_u`0z&%pe)liv-_G{n z=mOv$;zs2p;uWT+;SQl!Y}=720xF0{V)@w7$6_`w{Sq#`vain5w|@I5*-g#^D1S!lfy)J#+oM?4y~&9< z`mAlOn<_^K=^KTAgQ%E~E}5*D;m>KF<*Ar4(6i({bcJJ#i{xex|m#DT!0$)uA{ySC?U!%y(1;dk(+DNV2f9eo-s6D{# zpPJ{UmD)%P%#IwnC70Oh4Q_eUS5`RZd`#>iD%2|seX#PZZQsoC| z$tYW$oP0R;kXHy<6)OH@BBe12iG^+nB&s-db|S*31umWgz9Vu_#NX_mS)vxodCn68 zE-30*;u$AE?bDlzW`eUttQ6=IUO?l4<+^nPrO|1@wa-95q$)_eyx)z@^llKP{3|c*rc+ZzkniTCUCKU7 z{z|~R`0*5lGYn0l-@V%D(( zJ@tBesYfL}S2NNc`*$#J#UA?%ef@{jx2mJAht2=bzeZ10e^gV|6DoG~N!A_quxKH= zN`;I4MUj?ZL0L<1!c2WEAz*U~_C|wSmK+rEhD6=6v=gl?iq=fQr->7Z4{_2tHPPfE zq;7uNk8Jigl@vs6o~OHf!;Pd^)W0D(-<%es+RCd6-Q*w~U^g<8sdnk(%EdU1c5@fI z)6m49L?%hM3dLs^Sy*JKJ1TAWD~=ox{(YhZ4a>MMmn9cCSXoh5KNT2QT`ByZ$s|Fc zua$mZJQ$oJH`oiJt0P|#@rKwmRsTnBGWCCu`VIT>&%xz8ob!ON{x5#l)c@R4GymVT zq{lj-^z6fhKpkbeyuFcqp6K#^m(sU?3VrLZuT}c`KlVOPjo95OVpPBHQ`ZE_@}pnz zts`i@PYlwp3OvPB5vvTnOa3OHgV;aMo#~{?WXbqodJ2CUyOgKApdt|jo3N58UhS`n z5OG6_y7T2OCfWQty#z4u;Tv5?9o5&Cd`kq6i9~V$Zyce+ZP&7C=f^nblx{xes|4Qe z<5xz^_nh#1X+Br(GZKCP<2m2PI`}E!KZX^Mz78xRAUydwOPlltE*h9`@jA1&+SRuV%n-;wVM~Y zTlo7$3HAjLa;$@%s$K}C(%fKIDSUbvw|`#D4Zf&{ru-5@NG14;u^0)?H?CL znDrov8HgxtUQm-L<$DSJy?zpTboWz@n>=k$iT<4%p;zyd4!L)EnB>6(Un0-&mdRfW zzae@fTn0>H-<0-4HU_eD61R$+ie$BD%DGI+CibJ^Ls>9SjUwbp_n2`MyqD#dG=Z-K z)&k);dL3M)&ZrqbR$h;Bl%2;6TVl}AHS2eV18c_SRa?{%)agmnZjZ)vH>+91( z-{$LU^FF;GTokw7@`hpi;CbcjiU)W_?1h8iBsqqISq=&ag>s@3^~QM>a%8FyAN+PI zC@8{+BpM}F7JKC{3M_*0_8!mmA~of0{>lMzI0DbqssP7QwZl%p%gu?vq!_-E5On6F z&xvqT&HgLonXr9FILe9a4OoUcrEIQ-xaS8ObFUEj7s}j-_NKxv{D7&y*+=k;Mg6G# z?sD+EfCE5Se>HzH_4oe8W*yku(c^qdZFTP#a0>7Q>Zdpbc-`ETGAd7Zo7*t`(5|l| z^>w+ve%btcfqs~-JP6$6Jgb(11JXL|50fW(`4}Syb~GWqMz=yf!(y46o9_nbeGqPv zI6v{aQEX>pPKh@S#kVG+IU_BucN&}li=xY9Nu%F5upbV3`0gXN|EOJpU4+XoT>mnW z*I1bME8)M6Vo0v>Kd@Y)xXc{>7a=aUi8;F2TVt!KTBp{BO}%weFX8-sBlx|*{Xkf6 zzW`Th!W>gy$LQ~7qzuZH2)zpi%X5aoa)##3p}ecM7MIx8Z!k^G4d%<*NQ5(eoam>L zgZx697`;KB+gHT}D8(hPl0D4A(jShwPDdUwbk_cF_8dJCdQ_I`?wSLzvIe zwmzuH*XhV(rku(D%a(H>_(WhT5SDW>xJr+nWXgAp9J;nnY3XLY9PJU0h-;J=(Ixtt zdyQ_8r-`i*Igukn9fyWSXQ{6h!&f*pvcn$W)WIKp!qC%2ej)$j+u%O}egcH_jC|kF z(uvU(vn2XNjCb0-V{zKNZO)(WM%FI zce1w2Tp`bw-&dP((vc@K{U7?nb4VBX0pKAZEZ+;@Duw#d$M*mB_LDnS;Xz{a+UZ+% zAY+-fP&4@yx$HEDVY0)Lu>FZ{Fz0(*yHS32V`Z{Bu z9tAJ^)-ADN&P+KSiCdziCRm5GDDI`*VQlxMJv8Va_hWug;MAfU;K$-laUf%bsdJ0_ zyF>jx40foTEmz3NV!5+jxs1F>*eipb{uoU>mjln3@&Y~+gl-cUluTIJ*LCg(5GIuhf66Ree`Y@mmT5-%B3hvXs= z1epLwmkKNe6XIl1Z8dz?(6^ubOUPfXF9*SY4!j10^fml7L*HjjJ3Mi0Jb5!NLwjBH zr1puIRIGxppf1G?cWA1cV7q-&9D5Z;W?nQ%I(3e$9HZFks;ifHj_cIP(#5m^Z0e*t zi%n4RFr25LO{5Hxi{k@|u?;Pq#^2K??J%_RVBVl)VXSmZC;0L~!>HpB( z-T%SA1{?sway<#IQm_3#>}RXjuh!beVfj)mp>v;`lyjfo$3Mln5ASVxKGXgmWapV0 z@L@nB5Yo{Mu2QdjT2;Gdei@pPiom69S6tdUxU@GZF70jDBj$Ju?7?c8X^|_{`;y-` z`S0fa;W~IH_~XDqAk6<4;40mci92)5JfQtV9>aLpBYtgW-|2ex#owx;<&V-j04>Uj z1xrXZEL`b2)v^9+b!bFATz1FP?EHbDul8?QdEZj-UBE>^NZ&)?Dm{9N>3`GPj+qbi zX0QXF<%5RyCW=%m_#W{&Lvp9NU2AScB4!cc8ndo+4%t?xjo8F1jK<^9SUyZ%b}B(- zGKInr*4?vuOUMKWzq`tmv z9uQ?QFB*aLquTfApzk$Zk^c+!MMPI*ioV_|^lh%b z{?a_`mip-i^YlA&`;DVN{95LJ=61dL--vw_?MmmSO6x6-+>>OLEGM94PEbHw%QCE# z%80U3E@!&Am2$BXmUX5S9+)hZBkczfT*-!d6#sUzrn&oZ!!$bfQ0Za-?`391^<(+jowXdGbyXyGWqb z++6*6fi0*+(l|_8$8X^HG8VX7#A-?dJ19Y?vfl0cTS9F@?vO(BQFwRpm7yG3`oZK# zL|!2xc)(O6^Gs(5VG6$xUAo{GKVE zq(==sDR_gKzKjguAlvVM_ynSi-}U(dtUkfH(LG^kT-#CK$m|T zvV;M%RQ>PJ{}dM0isR&Z*D%Z2)iNkma{0CQV>wfL|`>7SpMey#rq#>D%VvukIPy;9iq7 z$(rkDUtU7vhf43G=oR3*^mDzx=AI)k0%*NYMwX!ctR3!mpWXoV@zs+iH3#w0)7RXj}fJs-77tR{2kOzy;H9TJqNa>BKVRC=A z5C)^dnRYL8hCQ1)JHedl^ffAvD*X?kpB^Xt9Qn7P4QTzpLYDBmT`IqO$Dg-vm+xG{ zvbK6lOvTjK$H~oq`|USO<1;@thA5uG7)=a>QZPDUnw1I5M0*223~(}puk0hGU%8PQ z8J|@lZvvI%Y!u9jjIA!skuEs08r7Cvr&>b4O&1#tW5f* z1m*|I!+4Zg#oTEW{rpsGH0zQqS&y*t*gVL!LMf9mKM8FQ?6CY7$qs79=0Kg}7X=nOz6tD# zE#YO6F&CE<&IEs;ATT7mufN~$B>YEb_eo`JseH5THSIO5gO_qpSMSXY)se!Qy-{8~ExwAUd}fOe?{xBzV=+=3U)aV!Q>J1OB1T`s zXmz7mY^MlVN0uTeW}7w7DZszD(>qsQs$w6V?q-W?JJv_Kj#KRl_M_}Pr^v2iV{wiz zEPA$mrP5V~n-dvHOFdkRd=5At=ybh`EMY*7s(+*UbyW{z(j}GfnEg=Fr*f~$h3Z}x z?q`uy{X4*-$R<41W=rM5^Uf;P2UF7eS%HC0-bkv@So>et=l6F;4IAl9UNA75`w#{K zj$U!rBh?C!+-&OC@C+xkgwu5-a;sg!;?#Ynb$sAS>^Q9L*@J>Jad)-anwjeQTd4e6 zrMJW%?FUXmt^(_UPVX*c2|eov)a4*C?Jm1)14lnIOC_1#F^!|R5(|>hTq~$n5eluX zZuESp^9L>P>3->B6{j4cE)sY~k<3^{3AtpM3xI>;X$i}QYee_uaGOdYa= zc^p*a@))-eLU^VexzNWwG-}zr-g?@!_sAstGLEca1=v4zuBpv9ji9a4eS~!B_t(3~ zpMuYUE{D8im2Pd{`hmAD)OorwP3D!VMn&!dHLHgYs@20=y!XSGmT_;IjERcGGdHWy z{-j}Cvm|@=SZ=2;l)i)oPcBAxC)x}~$r0b=q|weQ$^S-2>0OInVZKXyxe>V;JOs4f zzebjD+hwY}y4Jg{x^_#|TDcyhz3v|>-OF7ot4#HR`@LnfrVVowFh<%7dpQ1-k%5pe z1*h19NdlYLqWTn6r_)REP3P1^k*kb+_?7-8DXEctp2f)Pz$T#ezZ%&MXDa=V#Glh@ z_a0ogsY=HDxOQyj_y%_Xcvk^j%{OTRpW4P}WO|4(!$~-6EpjvXIE))`zJ;GcEA61! ztI-s#&*mV}iB>hYODOu)?_PC3Os!5%UytxxZy;suMD{W_-yDzlSHe8c=$fT#54 zxLWU!ug^@Yu=kWuz%CS*4M~Mu=NJfNB^{TZZTsu}I~V)jBmUTALPUW+_hx-%DZ2KL1qZu)V! zZKg8VBv(B*b>rYg5Nm#Ola@KjgjCiP4g+_9`% zQ$Ecyk7eBua39CiW2O7$3-zb-+%MOtzg*~Zzb$k>aUm%G?Q_njSyGDkOf_E1xZF${ zK_~70kMpDZWhaq7Yiu<9ADO;Ca{(Pc{Mj7+OOpXb8vSF&pX9r<-Cx_M#$P+*PjZsx zRg)i&nkm09{jFvi-f9+E=KiE&{F#_o(!z@ zZDcs9q&1k~)wsVYsWt#FuH{ehXjVC?nO4c^QPP=9?C@G=UB-!6Jyhn|*2F@VSEq6M z((3o3DH%M^8JICVa7+#$7qNGl=DWhgR4YFjzeLzUCUeGfl_9M(8R+d~2MVohhPI5#Fxz*Z1;`o$scT=wX@iI!&J1q*ZuoWPINTYXf%#Jfm)^FSGjq#E;RA9e zJ}?%f@3snk^}fwxYJ&smWU1Q6O#j7Za1x{9-MBRvWG%=XW8qm~xiizZ*qRz@G)L8r zEGW(%!AWW}&t`3K6r<1WR(bL;^AaoLpqYNVX^wRNH;Kv?`v8vrS2BYKT`;i|5 zPXXQTUq+UYa33OO6)x`Z0Uj-Ou@$i&=V!*pq+||#uj|gK!kS~$j#K=>UeR$y0df^s z4>W&amf}CC*TWx<8>i#5#$6JZQF*g`l zng`R3{{``V=-vdDk~A!B2zOajSpCgFzd+`+@z#XC?v>hDMh)!mcQX1Uv4EE}nJn*v z|Ejb=TDmV|)QQ%L0T@l@`cfDg4@^(*OGP@tTAt?jEwZp}^M#x~gRxJ?tc1U?lDouO z$hNQg9(ER33)385-@r%?zRRbHVvQ>wN{Xgr2XfRIOVlCKK6Z)0r9c$CrdGiQUZwG3iXN2guq$ zu{F;qnX33(iC^>oUATJl?gW~@FR}!EuXrc+3vuf@JGRv8YZDvHm9m~Q*Ig20!Q@F? z!R4^P?*#h#rZFP(OTRPIKFjK59P{+4gs%)fd5>R+ydPWxv_3Z?OZeFHXK~P5&xwrF z+iAlc!_i~MIlR}b_uO&ftCsP*tid+b3kA-gdos$VtNdsqeqE3Lha3vAP69OlY-9;5 zwyXN{AMY9Ak6YK*dz)?MA9<&mZRQd6IR8DjGCgG*ui}L*#Po$(B-d84QQQY7w_~ta z$z-$yQvGI-SvHEEZ@+GuEGx`1hZzl}O5aBG(et_cksk$50Il!OktH14r1ZVbvqMRw z@22`$b>3yc*=47@wP%m<3F8u6fwIM(YU2c&Jx_a(<#{$LQ+nj~iRv*8c|KSSv>vA- zOXy->I;JO+-kAal&zwBYCGYs!a?gV5y6A;(NRpM{<^f?5d z&X<>ve+k|MTAx24OX#^iu6r@jCL71T(yF#oIVE4PXR)$XuH>16+*nzEo2l}pBqv&* zPeoo2HUq84mB!UwWow&+V3RWADXo_5`th zau_ZKeS`6J&W1JC-a#3KOJ}mUrlwXD zZZJP{HyzeX4?A2wR?A1s0{Ro&FCj@t>W``0M0R(JIDMAqY{X9Wpc#-N~&hzXw6ZJ10(lv8E z`+4rtw%gL%%zNph=_hYc{bYgrWxe}3Ty@?za&tA_`}*UdtJ0>@{a{S%KS8F9t(cgb{`KWyN_ob_c7P~Y_#0RVD~fhDWlZ=_QS)B z*3fj^%%|fVY^XgF6Rkl0Fl#7ImeaV$3ctEmfmLFMt=yDeT!L&(VwPBGag1=WGc|cs zUtS=6d4=@d;B3sX(*klcDEk6AzTD|n$*`QH;-s9x zy+`h%*V@VMnqb@2MjZzh%`NKabM6BbVDiHh4{`9X=Pfj)(H{>$#y?ao(bU;tl# z8U31H_9`F4t z%gM~Daq1kiz?U^V@?WmU0;F$7rux2@qeFOQ^S=GlEO4b(GmPP=lgt`jKK8E3{aH%l zVAyp@}|4#CW(?lFT7|5nW5;yMo%B@ksln~bO9B20w_Vs$!3_NH0e`*F^ z#HVk@^Jd@$)8UiM7~m8P-Q-+oIp1YOWceLm$;4bt4|>lHl&i=BeUf!FI9k8b=l={Z zILWzAK^_yhQRU9E?DPU&%YE=T{0zRL`wZ_R!%PiQYb~~~Jz5aTAH~oliZxz+mo5g=yWbGMS@O>8gH(D2CF)YpMQHRTW zr->`SKrZJo>|p97){?0Lz7Z^b477gfUOJ$h^{@`bwHHsBn2xIy1kY6Ze}R4#{3QKg z-k?-t3Md6y|7(yXOjx7(!B^tXQ^)o1qW^O5VlU~=Td?PUN={bKbw4+|pM&LmHS6yt~cZZj5CnrBO32U2PNsjE(EV1r4t%c@pd$qaIl#{4#Xs%M}JxY4?yr5S&)ffN< z1D)PU$P&7^x2#?NxEs%zY((?sjodj}wucGI%2FvJ2H=PK%ByO5ZYFn2J9$>lARkvA z%Y8xXtmW`Dtx0ow*B^de&g-FBD7uJHj{K%<$#geziv?dN-_B z>D)LtI)1$h`8IGT(CPdcvIKn(#KDgCC++i}`=<4^*wnW{&At}vu+MDvO>jSl9Cr8r zIG}rdzcKcb@Gv{aDaG*3!9!23Usi9!gPo+XbT4Pw`1_}yeNa>}DmE&8gZa_=G8(xA zOaKxr(8c_9BR9XgL!1%OeRgs^2XBBmMy(frEpY{jN7~=j$k&1!V&d=O+-Xewat%(+ zPBGfZfFZ-UrN3*GLc9$g&)YFPUn2iUI0~Za=pj$_R!j-1>duBK38p0Dw*KxhNTbo? zDf8l#^eja_0j!MS(SEe_Gg5!Ixx+t`NKK=;zgq^VZ!~%FHW5dmmru_k9|eB}y53A1 zs?xG*nHtZuT-VLGMtn4`sM{oC&iuBNTTM`=Y6zQ#g(cgHb z|5nB-J1|k|%W_{YuAt8khLX6CZiPL(FXzBMuc;xtqB4O9+#_#Qt8brP zd0gb0g7v1Ea?!3?A?wKJY3Id}>j|_|}w1)CxK4Loa z?K7O?15^0^i|F_4QP>fg93CD#!pe9;;&X-%eaL+-%O25Zk$=wYQ&=1J2SVAWq*P?d zjS;)?wQA>`;7Ya5pzM*{dpCTdon%h5@&}a7XL)y=Q{^9b3ibGj-Q>G^urwmV?lQ!KtrGVpy{#Wg!s=P4;!>u7wU5wgYs@=9yA9R2E zIr6{3*Fe{o^kJ&L^mKl;wW@A&bf#Rg02f;OaqQVLP-e<$3?%W_AnOPH+*@z33-I(< z1&@B;>_)y2Tn4lr-$j=2u{VF}#4f8{f45d2aH{xLWZKD1JZ}wD(@w_0YU5QVow)xn z8h5MwXoE-V;S5hTvOzA;ddxtU@QSzo)QSK7j(S7}C(PRB$SmzeaXq)+zSlC|N1+T( zGp6OGS}9}_wVq4nLw#`v(4ULdSU6lRHGpwkoizg9mOV<(y`mT2rT=I`ZUzqlt><&d z5+e3k9TW(VCS@N z(x=YV>J9bfc%|H5Y~$^`6KDs6Sd`+P2DYciCY@n9!C-m@W8aLV>0G*;&k|#nxB&16 zdrcAjtL@QT-Z9r#%<;s0^LS@vQl+aL9~I|$<&VBPU(FGzMjy~0==4lQmM~|%N=GN_ zHFB~cCOz)lmfka`_HkKa*e4$&BkK%5@)?&78c#wvK9a=I5o?q=hTSzxZ8J!Ks-yE+ zt(oTwaZ~H5_DL=~AKzB`HlmO2@9#%`0z3n>zONxm*pk@JEKXk*P}i-OE$i%xQ)xN_ z-Bq_6OyjmexV1>iXLi-w&lPdh2G?(nr$=s4v>r@EUJgzMT93<-C3JD_Y{NO5YGs8Z z_WsN!b}N4<-e88ipYz;LF~O7O^Ci9yaBZ2Dm4$t51|I3sIo*1OuW+y(cKS0;79)S> zboRgG#2<}GnO>H$%QeNk-Lk@>Pg8@+$G6c>m-|1F|0}wWjOw3^ETM~WOsxL8(3Q9P z{q~8*XJp?PlfDn%z!K2~inpA2b^lwBybGM;amlzz-(TBd93ac=xR9>jShcy@8`daW z#poDEjXd^-W#kd`_>RQz{So;n`1t=HUx%^IJ{ZFuU*V|exa|bw6<`&RAn9vKR4)^z zPupVlp$33(A2+TtkMDpNxAcqmBR>Qljp5VzsGpI3Xg&Gp_S1F6@<2N^#=0>qRoJNT z;{PHh{@$ZgjU3P)NRagCc=fZh_*ZV*63cK<7%IK^D~U^wbI(WK53T{a9Stv5TnX2$ zdGT$lUa|PZ*;_W@xQqD~-b7I?r|e%g)2%~3cfR#Z!1y98tDF9!2?c}M2N%CP^1mVm z_Bc_Xk(UBGQvNp;DFXwh4BHur@rFN?!gC0F;2Au_JhOP>RVAYjPu$OBFoS>xY|7$bifOW6Zw{T2U-xdV6m|p~ ziLb@uKScaGzn(;X6}%2K|50QK(>%MY4*Nn;{_(=!Y%V@5_l)ng#1Y>7! z(BGSU6mT=iKwl>P8W+=wKc>lU^hVh}l^>H!qWUaFUI|VCTA$OAB_!+*qWVlgpX`$3 z8CmYLR~RiLR@9^WD2i=-d<7vK$``MyAwu+H-3Qr2Ac03 zI7C0vVn~rOj|CJtJ;kYQ@4CJ|B0nmI)kbB5SP4f5}DeuqCc6==!-vQ#&>AM&C zaqu+Ie7``J(1Z4Nyp(rrd&5A>Ric z2Aa3k`@23b(qZ4J9{*czH#1h~Do3-ExYs;0#kkP^m1(@>8;@7O6lb_KLJTMwKxNCE zL^i=H?9jN}truJ7Arc5-lhMhX^+R{ER_%a_LjV0t$BG>6mF^v!vmel6Fid@7%) z@f3zgF?Kc<~DF?~#v! zkAdbr=KWpQmk$1!JIxn)MPygZbj#*6SWlB9G48;u(&L?cTy!7t6y&o&4bZ&TAWP8x z+^2c-{I1h0uL2yWH7i$XTzg!-bDTz_$Scm={MQS|8*)IJ5Gs9Prdllcl)MoJ0jX+h<&rqHN+kg^EpzCu`jhB zwT;(&a!LF)OfSmZ+yAq*0}tURpxOFF_rWF$l1>bJ6ZJ$WwU<7HCEqe|JY}IV2@`(Vp)Z))J64j}}Jm3y|N1va{_~s}l7Bh-4YFUUKU6EDBTKhL@U(c7FKw8wf?F3@E39@Z7^nN#emHis%8zE!tMlU>|->li6o;%;xSvV>$Q34i%RcTSH}QbG3bfg-JDU2czLurOy%g z!hDzh?;Yg7g3o}~CuO?Q=g@Mc&x-hSD6T&Af2w_}!=aISfD?`j)It5UtKHcFOU>68 z7g=d3CA?hNp2bH6eYV^mWElI*q%1QVT_lv;ru19o@r!=DkiP{k09wCGyua&lfPO~u ztI$<&L)8urM9*OfK#d=>%ci;Wf|HGR$Db@qc51bR^=^;1m3Z~I`D>A9VDktx?{UZy z4&J5mW!mGNw-dL!mF-=88Aw~HsHiYTks#%F8uD7O0cd?Tdw%nHAdG{krn0AkT0b~VB}WLd#fwgIf*AZpbdCgfwSD=Z#6tn6g5*(|wB>D`82 zx;+%kOf`x?G0=LCLzd9ZKJYkw*`PX8;9h_fTd3=**KVn*tMrW=2KsI`y=u7J2Ehe%?)v+AYDgAP0bcB zFLElTGTVF1#81IK*@}992_Hr!Caqh|fp&i*e2>zr5nfSL^!gd{>)>sm^?C={)hp3G z9bUWZR4+LO#!{+x@r%~1nWebHrc}1Oc;}tKhjE4;4jHYUUWKz2ujq9;@;a~)XuY<0 zf7kthen#`lEil=eNl=Aqwv8<*(KV-bLXDK*GUJw$bj@*-ZG`Vt`E&%n5-*?ri2QHi zpA*%m2wB1b&wgo-XD=SrM~wp_%gXfg5d+mobL1H8PZ>M1U$fEutdNbGefBLr&U8YXADWTDv}!p8j&@nW8fA5uJ)TiKik5i|Go_CoU~rmbAgwH{Xb??JyX`bmD? zi~J~f66pMV3t2)J_ocZRy4GD5=MHeUmvyawyuNf6SshJC*?LyX<$~*dHij;*tQu?; z+Ibv&OY!xRk+2-36kX?7wJxpE*sSyn&yDsUry{Qdn}F7{9$A96$3N}#&ig&3r!3Z*)Zl7+cQ|K($+^6(w@%SYlzY@LX zaoz)H{gRO-==!Li@%5m6K6d`L(v>svcDiX@WI3YI)29MH-LGANd<(b(XnlTzETQ%X zDxVsfdY)hH-{LWI?grm|*4LKV;5);O7_=X-zG>rl_tcb>kO{t2fCQdeWTg=kf1Gha5}bNeQ)fBN5sxiXD(>%w~b zIBwPLYXl!sdcElJieCRkw#%7c0 zh8ZXCw@Oc+Rq*Nl=_2HP;3}Z?xfWT%#zgmGch+6vH;+Ctk~`TYBV8@#882*{$17j> zn?3%wiC@3>zZ9+o{g?xK3h zG(JcjY<&wG)?8Va8*JSPNy{TDUuxmedVC-GKJYNmdi(}ig6>Zbtm@Ey)^6OnZL?}E zBUITapQF)iYBuM(n_J#pQ(NWjzSsVfW!#=Q0V{a!%CwKe6HQ;{B}3T|oGWW^c%NY% zT;_92vBNsknrJQ;JxU%`dKWH=>b)9y4OkDf-e)08=pz605Hfb8)Wx`QFK_>sGWFZP z!PBD|o&Y@3&R<1-7yJQeJ&eUlkHBjx-!6W&WB$42=uVU(S%$mDJx__Z#wUDF(Rc2( z-^1xz&K#~i?#H@oFMMEInNzV0-*0him|xb6D(u_XB*ltpskMp4*0!Ihe5&yHMZas1 z4}gO}>(}J{UH3ow8PgA`xp-_YC32UkZtiRMTH4E`>E2&o41tWSXZ|*W{i)0!H5TB!W=5R~QLwwxgw&Gy&couy7rJZP{q?cIf zPI}PsZ=p%xz}oER=UZwC<}DL}dsuscjhBGY<}`Z`UK^%4wMOHUO7A95FUik$k^cxj z0$T6CdVkmXsGkwN+xgpwzSk3FX}iqaPi7tk-j;*pPphZbR>Y_&-PfH~1Q8e%~^spXSxi82)y4eNi1; zOG6o`#hfVXpws&)o=z2>K4l)C=u?fn5p3~(>(Y*-UHLE+5avh?Qzk3-r<+El$J0!l zdVKXO+v7&@46o7XZQKy?uEHSUTF>=rpHu9 z_}e`G@)M%#v0IUMgY$sq--|5a?uDv9?s-1Qo*0`APkSzL{(vuM3S~VDX?P$sjCvM5 z$cWabRe7|+qu&qzMEAKGt9q(Wv_mb0|5-(G9npE(q7V(!3i z2?MXPXB2;h7r&IlF68sU#X#r7Ro>tAxu)D!9df!1RPvV>{geTl8!I&tUqp`9L5A+RUdDu%!P&X7pliVSxMh-zi%1uhKljV+#g%tEISiV_L+Fi$};7~s%$Rl z?!%R_`1>=AsrD9bAlc<}*CA`4S9&+2m)84jt71+te$TER+1( zXuOcaf`&D~NA8tbg>J0WFHeujE2HZdmB_omxj^f2GqQxmD^z=L>bU-rxE$Rk-(+5; zmR?HTrI%f@^s-;}!dr8uk$DA}Nn6;*_H}Y_{$X*gYXK&EPI?Khu~TH+y)$Ww4=W|F z*eiaj^6waW>HcBRNv!*UGNAQdhb-Z|>y+MaT+w0t*iP@bb6}BbnBQ#QVI8*3W_y0j z=g`BpbmsePqq*;5oG1=WNw<3?FXpcCf!Lu8wer{jq|^~E|=MS;^X7D>_{cOl<4E>WQLq?%3tqH;^VJu`KHy_r8s|^fz3fG&tF){ zxZ_M_Pm2lBrKa-}i!0f`#OTd_!pivdJl5G~U>TH}=?~85PK|WGHG{iF<#y+q6kqZh z@cVRbCJf;oG@?R$k;E9V~W67X-#W;aD%=%gG-s z&+`ur%GN9=bu#__-eZ5}Sg$y#IFT&R_4f_pun^}<%Sw66F1?-I z0si+@=I9b@Oj0u!Ue5T+ntNBi_2Yau|0GK%%>CS4`mkC0oaC|m@2%9*>wC|AeZKYD zeD@zUo2B<#r491u7GLS-zS5-9#+1@0&C-|TUl*PEz#9K|d^MX(-&*9qZqbYupY^ma z^@c_M?<|`CPhV-pTx;&_X6d21{y#06alLJQ$4>q8BL7E==09eZ{=h6vDNQ4~wv^J( z`}=S0J>!|=gCk`6z5*bj z!3w~CVa*=wA2OJe{TG-8{=5MxvkUw~Rsi=;qx~g=3w%Q^Fvs|d2Bh(CC;6ug9_=f> zz&zeR!Tn*Tf6m}ZzR4Guv;8yN9~SwS4xZ_ob%D9WU+(^}(!Xl(BH!W*%#;1g-5<{M zuNl13chUuBmH#yNhfV%1gK>d&fw|eg9tAf0x2ynYxz)dI1wg_N-3l!rS_A3FX&Itw2d zIJC@HnxEW{H`joLz6Ci54m$2eN%7u4f~NV zbi2=bC@IwFbMEkka-F_j|8YrH=;ADgPt~1Bmy!rqSfPEEb2t#XJ;^zol)?FG7Kbe7 z$$_Dl`#P^Ch2GC~F6bA+Y2EKrLeC^S@AyN_mh*@ex_78^-%vU&zjRy!%}|YBycC$B zt^Qi~x!J#sXL9Hi-#WZ>kf#N}$qcRbr}^+soJY170Dd`vUzYO=B~t+SWj?=@^9zMn z0QhA(zs%ql%C`XU%Xog7z%NvR0>CdL_yv!ddDM~ufMx}Lmb%elAb%Nv7F4YQz+ZCw zd`H`mKiAbZ8@ITkeJ?*Z&hpIkXYus$O!INjK971`030)v&M!RksQCqeUuX{UTa75^$5zga

    pRhR_Hd%`GG(5>_F#++|a#_ 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 z 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%0Dy!D@uZH?%=IQT5egNzQrv5#OEGgN#x|}oJ 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 z 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 z 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‰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 $|-nIs~;xBcAzr%}%AXTR^Y*IIk+wbx$zB)XtG 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

    CXeVyEhMa-Bk4d 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

    (8Y8#z#_p|`&PaH^v?JCl?nJ6_$G1c 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 z zsP_k()vt;w+91p8?3LAOx&2I|!JX*TGP#s*DP@z@oXO)3cDz1i^S?4}6FrdFpTx%o z@T!*{B}+P}D~&{;{-b0jz0GtGYUH^(U3lWE&t-YQXjJY{is4tcj5piD(dW6crah79 zgYD0E$ry+(pLS4Rs#JW{={M?ceb8Xi1stfM7q>*f-RehkVu0+!Mi;U!K}UjBTfeuG z5Dz0Zy~t%!-Iy9T!fyV={Pkgp5vr86XuyixBAtIGs#@k*0`Ltv~dZyc2=ujIFi%FV<6tB zy!t|=X{AHs--|G{u+A0Cz$YGdR)1sqQ#2GU$0-T0$lG`w9`E_-}&Wa9d^9hX8`3L=uzNk zzY4Poo={@C_oZ6z3tRdcJAtqf{w+4SpdXOc5B9ayI9&EBpR<)bghe$a8>+4~lqw7h z4?v;qWGE?guQykOhy5CrH*5aQ@ECgAXF$ryDSt>I9! zdD{b3)7NYT264po*Bd5d#e8x2tF3a9&-LjmRA7UYSeQj$i@TLb$o>``JG9;qsN|Oi z?~yucZ16y4Wi>wEP>-!BO`Fs8gd(^Np~E&xZ{1|;u{(f|^e_p0=7@1euwhnv1#h-P z2o=BP4vn`2>D0;ma|3mJuJe*xgMwjegBSb-X|R3D;zkZQfpU2qYWh`h1`xo{6Zi>0$pv|u{R~;PVRkhK@qST|z!F^sGW@R%h z^MYfDFQRG0s|RXEL6cWLBMZj~8Al2kYT(-dDU5&7p=D@1Q=drVTEjtJMJk4cxEDSY zaz@ftdyGB4c4_*SXT0QadLh&43=lh*m0osGon(@Tcv#piG#GQ6!fK*ZEi^zs@)aj6 z_Ub6KK97tS0^r08KKag}V4qhd5I;{_A&s})d4$v%vR?BDF_!%;g*>&tcL`lTHo*0X z=41*!7gE0X96bb0Qaty%!-VE0E#ya#Er`G2$Snk7KN!dQ?+7U-R-+;JrUS9;f*agaRC>-$+jRkAgTS;}tC_=nU6&!vlfJ_P%5mR{1!HlT_W%AF88Vxjay75$WrJ zDk8;`uu%1hV=|AWK8=O7Psl2&I#lIb=~D-Y_g|pvv}-QS&S4><^^p{`gyYObekTgZ zbiDishjv)~HvNw@FkM+a%_YRBVEaII^*=(6vF^a=;MBxt4uiVj9^Mk7SU24ZmH*rU zCOX*X zLSw#!QelECzHx%Nl`vPRocz|L#|b6(wyqWeE|SK{yyI1{e_8)q$1cN3ilsdkB&Ygw zwpT%Jydfk%8iFc+V?WE~5H74-1RC;RLUo9m8`$(ry_2y@!Orl$^dG z1y%Q3Tnf7wseXXn5ncHQ$&0P8$?Zn3f^&N?NQ%bp50X>#e)K9RwS_{=Nk+#dV0hlHfvaC(rKlJi)Qf^vJ^|00od@Dn$$;%+~D z>;?x|!}mJ?4ztzRqxC93vz0t&h8tO3VQ2qhs41*Rx!6{6SkupKpjTehwKZG*DuM^- z54ZKo`Z%}sFKsnh_bB&*rCq76bBBGzR#RAyvTi91Yj?{{H>6VcLl&X72QQB;bXH>@ zW+XPX*h@*yADPMGDpA22iFaegGr5rh(vulM>yfc+awMHgt?oohY@%sk1ZOT?Cbr4w zTjE=9w|rWw}zL97qnEEMF?`g4%YDvJ=-uW#xp-3Z+JoPUz-g?uw=I z=%umS%0h$j5& zaVjt0R8PkdcW*33Z5CX;NvWh2Rf@KdclIW+F0by)$}Q^dcxD2 zmdd?5cXhP|yinDZDR*vGDt$$j*MK*B?%2Fk8{B24k2o!p=__R6$}P&mC`(7-&!tjU zR8cg&iLc$V47}v2yu@u=l}gMG&{Z00DoW+F-AuLkTw7L_N?TE76MOUF!;;BuYFA!7 zRaI)FcPk`vgY49xW$RMOl;=@wPn66?&5PpNb(>OSR*&1u71wJeb1@G!0kZhKJEGJm z(ymC|wp3Pk;517dPOL5~X#+l%j&~@b2XE3k_k)wxu%SzG52q{Zuj$?*_x| zzj+==9=Khp5yM!yzRQ>ir84Twb9<@1w=V~+8en+8_a-}(%58=&uAKP1Y_zVrzv51% z#+EWz<%F;PKUOliP3_8yn|3ZW(l&1^zIotwFh@-+m0aWq(|b$E-SwqfsK=YcaHlG< zDc;=*1 zQ{0Gt)lTk%Wuc=TUN+^J$)(0{dMs}z|HZhlr4cdHnl+35*&}Otv zbNQmqsinrVqRM9WdWutT~rTd_hU3ePxtuhhPQHX&|E)G2{<%uCalVnc4!x!b^ z?4muA9hp8nHu0C%Qsaq*C(%{F&ha3ZclL1D8<`l7x8wQY1T^kess%T{tWP_(m6==C ztF_xpCHH2Hw|>1+vISm`tcB4XrACzo6SO==$byku@a=eaY=6<^#X-qVxF z)s9k;hPvHLW%e>IHM2~NvfzGGHd0w)AK0VRsA7p#8R{*nf7!ECYW0Cya@2p8S@KAQ`8WEdrdNLZrrQX1Oyq7S=2G7R0~cPi9~pFYS!MR znlTCS9)_wQ4x0T;ci2fJddWNu#i)=}rvHpi8jQx=!4I!leO zQ(OWwd#kQe4dDD*2fh&Ye91(}BJ1LV@ls<(gfcTvOq9xq+md5F-ts!WyHr}*3Ez(M zop`V2zI;eyF7=jO68J;U?_;GA&q4{y@OoM7(BYvTwabA{9NS#N}#N zSZDBeGuDhBEfM#doVxG-wMk04oxMlx_q&+qbDw%=-b?%cZYK1G$EpK=Ckyzw)PBYN z4l1Jse0w*RqB=|UmFg{Y9{hXIyQ=Kohx}e9yfrp<=nt+nrL)Qrb%$AI%h`V^l{?@RqP{$0@3Twg z=AI1CW@*YLWuY|lIj*TEZQ-tS$`)yyfYPKh{#p)F6K&Ttl(z75$rf_KlQ5cp(s`w( zfUghvE7FLI7{mnu|N9*R=F~roJ>QVyg$CuNeiErmW2C!N`N{(mU46&ytP6ezX1=K4 zz2AeG?<&Y%_&dbeTvzbR??J9^EI9U}-yz;~X~EhTmrm?zT5x}VrE8t*jxtz4cW2)$ zv)!W7W6XSVG4AOykgD!1?oxE8KYK~(@pUaByXn`wv<&oe6}eI_dp=ZtcDk;&<+8Fz zT7Jzhk-luc+H5_bohxw6<%YRrNA2R>j z9c*ByYmI?2q(N_7QUGV3#SWo4Fy_<}M}o0~c$?{>G89%Zxk<1WT8AamJ@vD~|qzSR(yTq-2( zGPfDpG8AI7nsBB~T5?di&)x4g ztR=fooAX2DENytBw@HgKaoPiA;*?ps^@F98+Q)B1WM3{PuZ-}5f10nwZM|h)*HHcB z;Z>#Ox?-6yoKoVvz)`W-*u)a@e`4`P+ajlOc1_)!{}a3CKO|E6e`dAo;ib((t0Qq= z4(}Nn8Ovw-lU>zxzz=RN0?5L0k3>`8JHUHJKpJ8e938DkhC8AW^cZ~>cNBdd0i)y? z+?M}}jx*t4Rs^U$j}M6&wo@a3WEIIU2@ge}_MjI%8TE4n3bQI(10x;{k2~?eoFV{> z%SlBbCS{AGa9zDU_$X6EWDtP1Djti57+Z5AaGc$E&HT)IIHMR078gTcq<)CNwB*J^ z#pB_To|ul0hdmIG%&1Gk)hs03p+t1i_r(0P1U~8v)lV>rM3eE|6*y7-rnl+vnVu(E z$q&`_IDgmU`^vZ@{9Pr%L(zj;a`wL&Ur{wJ*`MTX!|G)*zFBgN5{X9Y1o4}(cl&&1pvq*BbwJ{J&*RSt7fVR*szaQs_zaq#21@)_Q?_1F~o zv^ze(G+63gT)ZegJD5l>fU|^5zpnd*5OG{u@EISx+V;;cIKlDCtydk2iFlVmHV@|u5q=noIKOE7r`H@Py|RigH-G69%|J(uFW%36 z-N8~|YBM|G6(QvfRyyM@c*8;SL%6RC0haP~MnAH=#hVUL$vYDL`2I``A7o4Wb$CZi z249`JRcPAzVd`r2Kln62qY6OXTaG366Q>J-s$Jg-Njx7{Xh?j@|TZm%n^UZ$GLD5zNct8lc zbhN79cR*wTsqPk{9@{Rod?1jH_-!FZw4JWqK6K!kh0}Ylkhk|1@^L(s2kU&~fXO{z ziF#Owy1UXSY5mv%k@JQ7gh0JAz3nFsM7g(pg@hkazDfutd(ytz^e^ZFqfx}l0rlN`~k9oR$T9C@ASmy?+b=~^d zrBu}lHy5bq-?#i)+O(CbhUHNyS`^bfP{Fp{CcI#SXoRC%5I1D}H<3K#GT|H>6F|d= z9}!{r@m;t67(T{@?I@l*>4P!f2I}zpkT!=}k&f9lqsG#hh+bcQ#a5wNsimi&mn;Nf-LzUh})Fkhikk?0y-T@PaNg$=w!sq?caSQ%sGuqpFwHXw~qU7yC|MUW*5M(TDuo{K8olG>ioh`}SE_X9W$S^Y|o(f|1xjoG3;o z{)Lg_EA;AJ^-(M8uoL;UwSL!6es=Z=BkIZU?^XYxLy#AvU23qzNbnA#G)!4Z>$_5z z;_f&Uj37%P((t1BJsr;o_L@)rrt)*eANO*5DIK!xAzz(eZ@VU|W0@gHn8=W>9I-;s-@Etqd>Wgw+{)YkEw9#c{wfz38IlqL|1 z2S`lOG37<))V*H0uFETK;layNn+#EM(R;*EnhI%eTwM3hHY>XsTd|L$&{f@5T|+8Q zp0YdU<^)#U(x^>(g)(j{^~~oS&IA4=PuMyPIJ-t@#%^UOeW6t5Uupw9L6v&x3Qu^u zqcG3ba6nuBZ(FV{jy7G3@s);)L)h~3Z8?X)zDuDiKYYL8G5gu)&f!U#e#1APSEv#k zk;tr#RPh+^OcVzZ|Hpf$O|N zbjR%}Y&mus=|N|cX*e}N$mrptG&+ms8t9TNoX3$bM6NesP)? zhXr9;p6`YGd}>#z`yADtG#E2%1e(VffKH2BeKo2nO-9;~>BkOn0;hLzSuKlQ9-QTQ zJrbj*g4P@xMMNN4o0w7*h4a$;c|h2UQW06?S7_^x1#6J(TaSkFT(NCD&K+aYXu7E( zD&)(Bs3>*k1?XBcm~`yQKkU)**HsbuDoCYcve9^VBsm!AFe+2SbQG67DszdR#KP=I z{J#0v!s;x&eohk|>MwXU0-;8Jcy+&*gvtkv6&Cw6{A4)k$Wv<6YukClyHGe2(lQ|m z5liLazDNW<$BrI*`|YDx=$T`9BodOvC)uH4hbR_&xH$p02S8kd)a7^dadHE;N#%%g%8%BOi#|F z;`lN&p5xy+oFt_g&X2(0xOJ6@;S~68I6k)kb@g6|QZ!lUrIK+t&8K&gf`e^J?XnGC z3I~GageF{ZSarP*)kUq^L@Y=j`cw`<7rr(GJ( zu6xmZfbKA_F?EReHmb%U7HF7V~y3f@@9WQj=4$ z9t#ee=7lEJ2WyCB^Mzc32U#!qKpwm3{F`v7>Bj=?%u#k-xf>vBp@52C69*JNHJ#E%wPs(KO3S|3<~ph2&OsF zgKkD=arYjhAF9E z2UWAZ#5}l}(J^^Ea}U2|Z$Akog?8RzFNxjK z4aG6784I?W8%Cv*bc_$sIRKCQgz-W@Jxxozy9eReZZ8uL_OADd>4`}yymr|e*5eJyD`=S<_1SI*VP=FT46 zZ9{O(6$IF@*KbMHY#bC))jlB-kcQVI^jyJrOuAw@yQap>4_#(!XbQ%WuRL!Vpb1e6 z=TFpTo62hSjCx0aMwg580#tNX^_>8D2lk+`BbR_}`uvvEx<+S!rYDE98lML!)bjky zl%I?>I)?uY(9=pk?el zI3H~Xp;@XS1o#dESeabDx*eDPx_Y6ozy6)XtJrX~fS2{47G5!8E7_fIq|GSF12nKV z5z8{>6C=T{b25fI%Q|{%df@Vj+ zJ=9ywZ)>oBI*p>>-NST{Tn6{4B%teX{o7pl&rzaADh=0%>M*_=9}ygoqkO!h)cK+q zp9_$4fDuR9Y$5=fIm;-V{7u7aULkYT9<>Y<)KI3H?gzo0`jB_YT5&fAZX=VjG^}v6 z3^py1r^&osT|(tOP7t!BRWlaeatW{tH|7{g1;>b=NxT!gD^;LbgK4CG%(eI}6ktun*_Q>? z3F<{Q^`vpXH}1bqzz)YdIt#D$!fWs0Wg)AmileZfrpIZ!LhT6-Jcn+JpT>g+g;WIK zYc}iY;n0&#bb{e_{O+-JiG?@?1FN0nmXEGg@{@dWc=%*D6lYDBI@J;3$lgk**rbKH zqN=&j@0!-TQ)oF5O~JyYr+KJorsLq#9pOaUE%THRh;*vD5AA0-@HiDp-WYMVkfJN- zhs8o5NG4hq?!ki1&U8p})X28?qQ8TL5aXr|Y`C!~(K}YXu{7K(lqqblRgiVha+ri2 zrJNhAY|9jI(d5bqC41iQA^Z^(w2KQnSX{lE*=) ztfKjAT%D_@C|mGo2)3DaD&b2G3E1eIU^d=Jo=pwHybypg*Qlxi%=&9EO?M7QX*HwZ z38B}r>9~Uz#-1A-ZgO&AB5uf6IL`sa;`8WPD(o1shhrREC;+&0YG+z|FE$f6e{P5l zK0lNQ8ZU5kYPXiEH~$p!iE1wwZgQ*WNJ$p zN8W-97CB&C`@=;k9b*`GiKD^II+I|zOI?D=aGhIF58GbmAXEyt5})D|Q!V~bNSi3$ zTV3viR_P?z$v!D_{wTyMLF~}(xx(R?U%>0>X%jw7xzZ!0UL9+m6B;!Iwi|_tv-0?> zoM2LEhaP>k7ocVlRj;w;8b`~lFkeVi3YGj3A!kWPW@39oQxmLytwSLK7wLGHl=SG3+$L zO+wgdajy~^@#SxDpjwJ8`D`I=!f{d(i^7Z>9c0pKN>9nfvc1VJT5y94qz)I=;U6dv zlL)4rHO&rebd%Am{xG+~wsz3gnynnH*KIC5Z>vRMqpZ2vFuTGUrvN9}dJ)*xeqw7~ zp{f1AZ4y}Rce%yTi{Os>a$C*e)eaEV#n4^}*1uIS1OWzYfaVxSQyXrQk8BJ^WA^v} zMAL1?jAE%BJ%`&6>>=D}t0=Hgta!US3{IYK7%UMvTSZ}n;t^Y+?2P4!7>=!zE!*E= zh$(a+e56EteXrh3ia25NXPy5pTefhaIs9;)I2>2h}kg%m^58G!(z=Bm6n zP|d^AUGEN}HUrZ~gw`3Fu5ynPhNamQZurf?aY9bHqQrFOi~oX;LiBQmsPFF%cSRLu zaiW>$`*3?Y?EDX@)9sjJMsH`_P&k|sPOzBOOc6zse&;eCcSpg8| z3vKYv;#e7huU+^~oOd&39nQpJ$?3*Ot}zdJaVm5DjNcYTO5VpFc6d3HxZX~tDXbjy zJmM%*8CuQ3C5irioUl++YYzxLW}XOI$-DSr%)cB0>^-Kiu)~GEK4V1pZ0tqv z(qn}*X-|``|AK>cPn4c6G*mpD`8;@As3@W^_C<%q#2ila2-TG82Og=K7TNkGhd|dW zSn*{?=1jF7B&3`;*x(fh=Z>hJcz+`Kt|_gVPYK3Q#bb_PZv=7}z0Grw7dI(w$Kxfhj+m8i+3ZaZy{)pD=X)V)OVF)> zVx6j`-dYB_af=Feg*tI7rruB4j&n_Y!5Vg>aBHBl$)ejoX~zpJ`?k%CeR@H=SD-?% zUgpw`trNk14N<9pyS`&vE4a-q3f8D#pShJTgHzviQ93#m^bAL>%D;%~mti^;bjSB> zX5CR1Vb2a#s=yyO`nWz5B|of7D$`l5o2t=9 zD5CBvP#X8E!Et-`rzNgdsheCLnE}gIU=!qsA4V}whoM`k;A0gW!v%w!zr0MByCaPhkfU0Eg#pS$Gz<#&c*`V$i) zcP8KxEt{OBsiqQyu{HBN9ms`G<>6fDl{aPQDCJ_rQumE zU~>Gu*)RoAcodwW1$ZQdd)TnyvI@b~i;nJIt_8T;64QW3lIiu{4m`32Yb>XrO4AvO z<95wXxXC5O^1zOAh2TQkTLL@xoQsA0QJe8Q9$oFP&m~!??G7x{aiMbw_ zyoyh(8n+u(Qwse2w6ledHM0gf*nC#Ykx5sf*Tw0sM&<|BYAig{IAg%-h8&o z23{U6f83$hnF2Tb(Tl05>Prk-^@9vkGn2zMECS*vbr(Z%q(=YA%f*r6l(*rKC>Muc zeUQ$@D<%4w5Yzsl)TAz+v zYS!JjiIzQ4T$=$($!K~48`%ir6`Q!JEF?Z<}TLC>XAdh zsr>vh0BMSj;%eO5Z_`0=>@SOiaLoU>jVq@uv*nJ@xAK|Z3By&D!Pb5__5CLdkK^gu z;a%8I;oo>n{5+dP&4Z}}<-dty;}OH4Cxhda|0xETBUE7yEs;c@)BO->ObN>4?H_bv z58Vn>SNr975TPSLjBs81PV{NH_T7wPIvttAZ8#%)_DyE#XuF=C96r*ka~As4{^-*q z5Y#;A9%|jFa3X?XJ3}iG*_v<|MG4lc4F{+TxO#jDPUQ(GPG&|XsijHb4tVTL;;hW~ zE-6_cY4d1_B`IIBakopHM(0e|(B!I>-Je`qJQkv~FtJXO#S;sfaUN93myu zOi*Z!673dGxYV-8`Zt$Gr&kw*F=HhuXU|NRsG`bFoxZH{;c&f5{vXFlPCK}|>hfrp zk~VR1E|{_6kCAGf6S?uyfZ(t*<2^*+iQ?Xo)Y+jw@XOHjz^U7M<$R+eu0Zs{8$KN` zwQRMWH^?MBDwOs~=g|)JTYX~A(pOQOpc!d&S0m?HnRNAxbU*Iy>&2akyH4=xDynQP zjXGUh{Voqc>xbO!K&}AGZSSYY-4-}WkM1LnBLTXqO~vFbA5;y>%;~3*J9w$|c}qQZ zJHV&sJ$jC*1YMT_PZxvHfi5_3N3Sst8J_S-&+MhX?1#mm3+O@vn7&gHMuzcTpg3Gn z42(-zcv&Cr_q>1SBDAqwE;a~j))#?g_@z~Neo_&fIrhBM6HhCpCLRQWdufS-dqAH_Z7e`G2DEJg4HS@R;|`27*tpeC=>n?CZ24fgS)5K)awOqipBi^~^3t64KDh5Ug|$eb zN9^Xc$;E6E2gt#`J~d6f80{xMElzZD*6QGGZC>_d8u^oPHg0Gx@u75%U`A@95$#?g zoWssJ`K@7Z`CxR&)Caq~BZ#dd2zvDlFO<5zCR!`(?$svKd80hXr=&GKqa88R8^DC`zvi)L7^-NVa*CX|CPkk$6|LJFRGpffM-1DZ~_rm8ftYMJGw#P5zB z1?=t{tEU0$-zL51Pzl>5WgJfPhq9uXX;Q%>~hJx)+nBN#|{c>-~&HA-}Q z!PwPJsTGaueY(y;I-{&6hr*PcmKi->T01DFk=RLx`l=X`4V zqG}TqT-@iSj^kzC=@_mjP^o~blvm#s!#e}GY1I_B_#oYQgp#)?{o+&cks>;Iq&5$w z`@Qrrt1Fpwb_YG~16cf!pgNJ|;6|stL^Rx{V?)3AG+1Ns?&Sm=p7Dm!-HL;G4i?V$2E+q&d<~PUukd&PjC$R8Tmqd&rW^j0^YU0Url?Q!B-3oE zCC7aMIII{D-ibh{s%W@&wZe@mBwP~=nUq#dJ^UdbNP+qeoH^+Z*4jIQ9*oxGF$VZ^ zA<%%KK*$U@syL|+7hU{*{8!>8Nd>0T{_K3qnW)Jg5&D+Hd5Bo_#Sa+W`JZ$&j ze!H?08y@nFfRMg^Yk2TEM|chMl-^+|rjJrx&5J?qqGFfS4jQ0x75mc0<7z}v^qeET zM)}k)?vSu=dbuG0;wns-v1aZYaFC2jg1=Mie%CCP~d? zaCz%K-UJCKZ$SZ`vjYSaXlK@f$#*&-l-z^7+(rhl`i5k%_KBgye(*sEcGo0YQ&oAZ zRwJK|MDVC&%1O~AIO@485JCegWo6})gD8}qZ5$K<;IYq_fdC#mDH9E+1ewqPwsBh& zf{j$2YVtPVQ;6>A@=ma2F=OL!uW!4?0s}9d%0~k5>f1K4*CqdV|}Y zKE-5uiVJ=TmUqJ*e^E>v9uAeiy5WBPlR3I!>9cjz>6Gxs_yeC68(GMuaE078a_k9G zb>My*TyljQ1C{m@TE7alIug#*`thw@&vA_Eb+4%zD=#7E3W(L4DWu|x29^lLZiPf{ za7H?z?ul#ttHX*-k`gX`t|Qc<)z5Q8IE9ZZzDa(?Tl@1vgc=tcEF6yG3kF{asl|uJ z2F`bA)JE;93p|oGoPofzcQe|W;5ebQ~?{1e(rkOW@;-=vxx7;^n@;%37;mAu{}4 zq2<2bnFikzfts9Cy`|_gw&Qc{Wc6>~N*Az>eE6n&Jn4 zwe=zfw)Q()>ki#E4O*`<#4;c%E=PrN-0?&r%TAGJv0(T$j;aw=O8TLY(pfmQQJ90l zCD%G3(liT+gE8uxejFf&?f>QhXZw1%AUrM=i2-U|;hO6l@UF>p+$>aoCFHs=VWFUP zCJwgK^-eIH7p54N?+>ls^P2abAs-yWbE%i)|YppM{Hqw7ROSeq%sL zJ|e$IkcMyTxG+dFkshCfkAhS@3##rT2gR9DZl*D&q207R=UA9n>Q`ExIGdq6O}eItzzKSFbmlJ5P^CGnQ* zE;u(xKPi>yhj)WCYBqX@I|3}S$}CV^6oKGKuX|@W1p#>8`s5%`QySh6lJA-rgb{ZI zuu@&j2PyEosr1|%qD50H-W|Y*0kN9`?Lj(HTqP9xLzt@jwNO=5+3SZLTt{_DIrkoE z(}Qse+m}%=MWqYYqQ5(YSS4}g5NDC9r{JLT*FcTlV1LFxoM2||MMYF)Ti3mjdQ%ow zzpn_){@#z?KLjM4@qmM(=-^|t&kGT*=;4TR-3J|z?E`T>1yzp;Rd;$p4Q%|+0BjQ- zL+Que4HoPlq*pgg(M5hp`DzdXC*o*-N>V{~SR7!affh${d>i0#LeEPp%J!QNIlsS~ zs2fFyggYK{%cjK!sjs`?6OI@+36L%J-e(Cpx02Oa{SwC;LW2uKeUoT=F*H2s@aP9x zTpfv1gub5->97}BEW~^auOF}9s>gFo|90qve3JI&Fg;i=GWIxuPzj)AVEDIB%x9t2 zdCIY;&}tELwoi^bT=CG$MLs#+ro;w55*n3IJYJDVVnKp`Jnb04FPzfe;>Kqjv9e9q zJ}>c0^}(tgpY`I|-Jj+Yt4coVIWOGh=sylq^Y@wcye}}H`nu33=b=6<36SSuyBEAH zm|IO|>jfO;Q#-mRg>C_jg&oz_FM3&8d+#VN?&DBBW(Q1u)k|zb^J(No zKD9Yo_mfXUR{-qrnwJixTuTlM)bR1WfB956B}%iW7Oe4l0G~?N9ziNf(s@A&`YLY+ zDeMok&l>@zI1?@l(r6F*nO{d6UEsVoeQfGH{kuK|`{-@o^5WU_fqrq?ighR0T|6R` z?ANEG1LRBe;m>b7bo5Xftp1K8n2uu@wWa5Hj}$Wl-V`z{vT7gb=I=Ve+0S50Q4lh| zIdicP&|J{^?>T|+_ryHR6B6aFVtk7xwb}1GV5QPcD5Ql3mo}(bZOOu7A*DeXefb?e za5zY&3d&6$DYd(F$aL!u-Dv$qAM%KmGw=M!4OYeTze3uzAWv~<{@4Mch`-{6ZW%|5 zuuB5u9ANqSWh2kvJq4sjClvL&EEp8Q#V`wAt)}On$I%=EX4!5WYMJs>dpxi@yy{`ggw+JltgjBCbE58s*o<>>yOUE?6f~ZDd_IlP_mzG)%TXi+6sP^i$HZwC} z#@6f|R{6?ca4sVd(T@nDuphbO7V7pO4Y|XmzYYlEG&yY{YSrpo6r|N3_cPQ5q)2yJ zcKOC=MOw7(5?ja9IVM31=yDPG)mDmtO0~zghSL>}z8dG>t+rkSwY6(5kr`pcba+6| z4#YzMI=wfCsp%HmrN0X%=bmzFh*C{uTo9t=FQ6b_hd}ttPy9aEv`*D2A!?@xyc>eh zU#tFyV1A|6!_T`yKxS%VBYGZe#)!6vY*@N7=)bdRu)3`N<4?3Y~-Y~0lDZE_HzuGcIj&3RC| z!XFulp<4e^6oRY%HcLm?QI-4PD2Q+ZFGb+<|ZI+ENr%L$AMIojx|2hODC-R`>idj`PpKJB7n^@=M-7$ZPm6hPGeXQOZ~7qHVGB22pdz}3-E+Zha7 zNmA0>pxX`12-a%{a7l=ks{WV3IV|wGg!qF8o?^N#*bbrkQMc4@{mv^RpNgKYe}`u z+JUU1W}g&{aMkH=f-&yeJZqgmQw`3{`L!+tA4l@kWLQ^n2!yW7yM^khHeVQ~<@)@2 zm{!&3oz@F6E$Z~?VHmE}?}TY}y{=n7#DY_^j}C+Ay8S`4UUy+*8-y4#_4}qU09TNu z{}>Y7)bWlmfT-nHhGDp#e;=k*HGPi_Lt?;cQ`a9Tf>Q44PtjBa;+Fs3Fd$aHjW!A) zp*r6erleYbN0`#C_bYE4!mVolUJ+`l;Ma!fNx9M{A>5+=XTvZq5AZ@5%IyPo8XjU$ zc!AU17`4jjZqPprg=jyp-KH)(f`d0J92=@;Pw;Z6TDgL)Hw$AIzTl8h5IcjXLe<(E zY`%Gz5yu@Y48>@F@L~~wb_nfTgxNA4;j&N!*Pe}0(0MbsZ2%{HO@$yiRt1hlq8OG(V zj0+=hcHjC51m&F>P0Q>@6^{_6(M38>5bjWA0^syqarjj>JaD#;A6}}1Rks$TW+u^0 zA81S#F-C>=w(99Zr4(}l4@bhZ|JZn&C@%IPxkw26k;Rb^gbKEsin$k~fC}<)p@Hiy9Uqk`E%$=pvg&N71pHj6{&D{5%q2yUQtcQKpp3JhvEz z9OGA!AVSO-6J<)c&woS$T`qL%u~D3EH~N<%Slg9;g+Sp-jjwWfs`0So` z*AoeHT;08qIPL1Tm=I-AfwZez6bUu1?#Df$ZwqcZjm6 zT;1)(F~-$Z>{yge=h>A*Me<;5DiQZX1t=iOo$ za%9_0jIu|F^CA(#)h%BiMdfmJRwUHz>fS7ZwO!qI4aSLu_v-Lfzzb|xn6E?7(v6{M zsTnK0-Rx+bc6T=xL6N^(eo~}Gc6fV5W0c3cF&ZRX-YSzLO|sAHjK*lEcSkhJ@p@}b zi8QI*-ol}vbRGUa8fzS1>(ofY?D;N@#u(T4-)NZdeS0)T8fE8qZ8S!CzqNLWBw~

    ;O-QhNH{*A{s$1uyI`oZR`* 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

    s)%?T3MVuHZ)qU4(*TT0BCq~rT};=v%Cd)Ua)8R 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�~QInr}swj=s55bz*!V;3oR@)60BEH1!3(W) z+@0p0)Jo3F+t&`snaQ$M6L@WKb+(*cx3tVbkFKB+TSQRJcG0ZibQ%JegAGTjF9DrPe9v#T8`=I zWKh~jAhgCQb`9rR5dtU-Mr|Zv%-F?kOP8&(7_$)^Ic!+pv!#HeIf^p=rV%@9l}|$h zb0LrIg)t#~G)JdU@X$4gR~Qf~V&-y62XC6R9>hGTNIlkbEA*n1y`S?U^~JRb%d@2?{U z9W7Hh7!(4Xl+vNLd{2b+4@&3hETXHwSLPF|%emo=${!Z>dA&qn{*++3c2-)TO)p5L z#TR9+Ed{R#fG? z6fXQoGUJj;Okr7z(&M%(J%WaakchcY2)}g$sSk+lJZ`SrxIM1%q z4RjDXapPLmda)Ljes;EC`RR*P*94oPh0zlC5uX1Z-BXJ2aG_he{4`54^wzWr0_$l! z*CZ3r#gdA=-*TBT0aU&oxShwOu zb+S+U?5S*}da?bHcr$yJFSTD@dmN$XG1-b-jr;~v`D_mlDHKU)TRPK$>!MrH=z3vK z+(x6&wL&(AhpbH>DDzSM?g(K~+sehZ#6Qy(Vi*(AF#3gn75TDNlg06#okf1_<_FSZ z$MOKUz0LwgI%bzwz;>f4S;qa`bRjQkHQeOU?p_^%s3T}WoArDiNs|e7S9&@YjN|x9 zaZY|c;J|$2jmHq`Y1Q*_V+IDS&P%-GGEp3zi-NytgQyNx@Rvat{lo`Fv#UXNP(H^- zHQqKhtRIjvzhQmkx!1WjUoPkDFl)?pgvAKcmKbHG&Xk*a3)RX=<;OUf`NlhR^78Mc z`rDf#f>i1ARtL87Vs#h+yO@)7L7js3i2x1WP7NL&M@B6+{|rVeE-Ix>AJ9SzK(8)p zDR)@`FX-xK+|wm(t(FcL4MWv3LhZJa)kqrc$_SyjUeJ;66Yij+E|jR>j9DYiwA;o) zv2bjvSR-@Nw3#P3B<#aN^$jWqu8^9YL$a->CFdrkWbK0CbCL6_?!1JYClN+xelsEG z+vIa^AWPfPh?IB(Sxfr(g$usu;_Pk+&wuMi29GL`fz_)M$um_ySHzcQjq`qB>RTVU zt+}w|*)IrLG7F;Ux85(T&@Ikh`3zG&-X^BJ_Qp^7kIZ?>!^Cj`rHwS53e{xh7!>hK za>q>FILKVZp#83}&vU^VegD^m0YmcbugJePKaD8TQxu)&_p9aX5#F#WWBf4tj}&hL zAFGm;NrZTryDpxzoFld6W^=pE<_aE{Jq%*HHry>!9E* zhY$Q-T-ibjq#;4)1>TooKfz&_Dk~}7F#BavdG0?_gz)mR50`dws!+pI;2UGUDHWGj zN8fp$43K{GFCTHn882yUIXU|&nmR2t)ehEwxh61@=ZqHW=)3Pt;8eQ}M3Qq?L!TKt zMLzQ%n02rIF~{t{!fuTPKG%JLZ6U`!D=jIq2fRZNPR`rI79Ew;q&RghN{i=%Q>N}% zlXaiKvC<&aTDursN6#KkRI8<)y~SE#bQmuk(?x{f8O+8NZhfKayL-uo5e!V`>8Zun zOGyVmn;4e#B8_$#f#{`TnP<)}sfqhZx$NP+xlv>d<~Net+g>DM{9^3LA=Z6E@_QK1 zqC4wsWm+9o{GMajj#40d8{YvK{<#XSEI^wjf!R@Kks#oCa)jVeS1lS+LeG& zlt>hGL?4uv0#0cWy)-B$0#u9&drIE2u*Z|&>aCKCxyx!WWLM^uoWE?P+8y*FVYP_d zrVO@#V#x^u1by$=C>-8Y9HmJ2{&NZ#z|++j*PWWceo({o-C$z>yhVL7;j<|Nlf?>| zMkV-l<^ES%(j#Pr5_E~0yx%>9+0Q{_n5APfT;CxHRX2Cj;!Ih#(z#ebuxJO`?e_}!R6D@Zt zG+UiUwF@mD5?OJNdb;_P80B^oIZ0VE>k}T=!68iBeP&^7F2)OVh!``y$IAP;N;E6t zWviwze^yT^KYN(heZtI+<&8?Q%rROFWuzC~QuI(30BtAa)2O4-r;0e#xR`p$s=y^2 zdGmV`n)q{qpX`s>KkMqeZ9qoJ;@tP=+vm3ZsOO2NXRn~G=Zvq@k6>Q>B2NRc$b?(E z1b^|DlsFui(M&?ME?py2)u|F4)&SP4pVl+ex26>FkmIs-70&!>v1iwgU0W_ERm)ao z%g0L9;_B*Tr3aI`;2tJ$ZmhdS^gEVcqS9$7CI3LZ1s~&GwZdp+B6B#0lt*}Dg3o4J zZQ5_nk7DlNB_Q;1fk6lIrHNd5sOC;`7V60$?#ql9t9f|xMpNPyhc^v{v&wD6XwvTV^W5HR}xm!?d!Bb>~ z3co>wH0g_a19&+TE1XGL;l9EI=IkV78a%>Wn2c3CnOeBVV-K1=lgetrzQW-`@n`|x z1?A`chj^nnpM{ozJ&Ng6tzZqwkD@;pQlYVB^EjwX8)D+EBrzG&r>BXOwi>@geIcy99DJGK(1L>=5 z-aSN$h2AfI!b7)A!4M&n1DO@L?4mE*F&GvcZ~KBWaWGeg3mLi&I5!u8p-|BQ0rpe= zaJE53qT90hrUv%zMDki}YLFfkvcPX?5{2h{mBAvW9hig_i1Zvk{rp6mj-00j;N^ccNB!se6!tvSR;?*>H0gZLMp>U zln0_JB8QS`DN2Q;az^173?37# zfIq4jvAzX@w5#)mU80t3G;23Ii!pUsFY_E5ffI(kB3RjeR$Ej1 zx654hx^Vk3Z%nch>@%=rDup#YF1@m!iV#%Ob=EbFIJs=s{PA&P@=;7IoW6k zY(W5RZ_+izX#4K@IZmSb$>9;hX9|@KMt@5gZORYx!j=i;e!3t6-aw)}Ql%ArvXjcj zZ0YK>cCBA~e`k*UinFW-?Hfb8I)6*`yWx!8fFkuVXvttlL@*Fiet%;v` z{v4aQ-jJ9V%8*#B$>pXK`CNz+r33u9q@8M3wl$Ug=v?U~)a*$^zf}gj)A`@4q7yDh z@-=tg#_>^DCE25g@VNhW%Hvt;M2z`p+>5Kxy|UGhIccQq1U5vpf8sL}zx8t!)`ISt7ImMc zoLA+zc~xSrkpy$ENK;-H?agY#e-z4q*o91{D>3yLC#p2<7 zj+~E;9HG8c{gTKb!4BmL{5GXYq_QtZZxNRzQb{C>;8G#}MSm<+IKCKGXM?Y=(~rxF zHz264OcAof1y(otlF7q9^e*wMs4VJ^m@ArJiriLfx0K5yx%%n9pOQ~=!)~7Gr%M`s zW{Do+rCaGVg4R_<`}|)Lw2xgHt$i3FVyywSR(^lHL3jL-DOWHO)n7=owQ`^9%C)n9 zbN%9nrIPI#7Qg0R_gUZ%o*jX<;ho^jU8Yw&HAqo#gm*;{1wXyqp>m7zCAAgNj%4|^ zu9D_c*dDp3L}SSea+xW9ge*vB5T`C|T055*MAsHL?Pr3gy5Up^iZ=;;ff8*{>dti< zP{z`M^hE~}Wz>C@nmvysM)KdK%|?;bPUH0C=pn)ZxO2DN=Z3js zNnH`|UyME}#=;-HO26^L9h73e7ZUElKp6%V6%B&8>Q2Wl1~;2lH{#+@u8OQ7<2yDh zx92!MkC8w@^7%gtS3K8-+nd5UYmC4uoaQD|D3#Rp-_s_d()6p@(A1skp27B6t zpvPkk|5`ptO<+qx;+@vk0?rr`ZGeZ_=`=szr)tw%c$anf?b2Tz-1e8ce)~bOx*!Xe zKCmI?U6!AI6yeb}E#IY(zXo0yI_0!AJ0Q=HX*+(_kVljj$v{~f+q6tuNuE;iq=DXo z19JdgS_-XO@G{pC$@1fepswx*g!EvT5_O^<5oEz=C951qhKfp=Be!1l3fFXMg16uI z9F(7sTH;Ila6tegan7x)o}ak6hx8eH1xD` zA>8iu(^8d!7Fmf6&?xOct?;9`%Ef{AzVOgXkI6?z;UCZWf{CfuO2G)ux%iNUkd>~P z5iq>M)$LgQxsB;}Di{~3j$+R|)AH17q+-4xuoE5z&pO$Dw7WiKc2BBo$5BIwXpfyp z@i1=#>}<0s?1k%?|jOa7IL}K;o=Zp_0#f= z2nkrw{ky(Ot$-+joRy>Sy!U2i`Scc^HV}!mgs?x}VrToA(Ic^O*A$Hz*)=u5}>3-Qc+xmAs=RAr)81v3hC;82E4 zf+4M6kgF*1LKIzW{Ru4^g9}KGJLy0dan2}zs@1knj+Z=ZT-k{Q|GY+qVFGV49p*D# zXfUv2;XOa;N&?-N)EKH%l6r?#csY7Rv`A9tNHJm*XzZNIAU$KZ*9Z+trr3B**(YeozQiN56Ik}soj(z5$&TH(i+W>;xX|B7Un?vDR5#e&!K%EIV6K+GOuCIeQM*= z2fMMC(rst|*YolXEh|n>LG6CHBv2Us#WG@PLHXcUC6+cdny-*1dPy!<+Bk^>l*G0D zHX{p)o>OqPcE7yi8bM|yz=}^MUT^smjnN5CCXXknqo0#r+Ch{YT~gV3#M0ne9y^fU zkd7`9ylxe`^6bDu;_fF-m*4<^<2STs2?G6`UdH!t=|s)FE?sLHD~_zW!l}ig$Di zo`DSXAck(PJ<(z(y^vfF{~HeL#ST(s-tIq0A=pMh3E}a;t$HaZ6BwH~>_+btd2~=_)54x+Jz0R=%*J6#F=f1|t?hX2J zSg3@Cn+-jIPxk)(|0l8KP=3a>SwPh{We7UN><`C^EwJsm$;l!ejU$onEY0E)4(V#z z8SEW%Bf9v_GC>08gu8UpR0FE@;@yeU8BGffaV?#wv>$R3Uwk9eR53kiJFV1EtwfQ6 zShYzbkZN6NYQW0mq!Zd$B}vEB#knNNP+AkSgc^W}+SPeP^^DDs$L5@DA>_0m#D;p= zs#!)cQdz;CT0XV2R}S2LTxc=A#*49q9XS>|{f5c0O?BMJF45 zBi44q32=aO3ViLY331oU1A1)1^MhGV%Nrl0!Dk{fFc^^7Y7uObLl!ccSVdh@!q#GH zUZjHVwZ#V*F%DSXNE3B+zEsU18{$Xy%<(89RDvEQ!degKl-VLvTXNhKWubH%V-(ZOetjJllX|-xo@YT@F>NVqLB6B21)(wDb4Kvzz z=6j!+?}jl5o$I#`td#KBB_bH*KB8{WDrdcVMeV&tN-1RZrrkE31Q&Ev>YN z4i?h>P&Qf|ErtqRNO%E0h>|VPS`Eqw)fJ(t~Ii@#)2dw#6Rdd&lJ9qF63#vI6go+m1iE z$cBk;?82`@tkL|hMI@Agf@G~kI50D z3IC;o>Fgm-v7F25L2{6xb7>SR%Zbe77&k#zuldf8PA;FC1U3!iwk0LuHnqrXSU6#~e18==hTDEvLeLS}NaOYt!He{}F@+v>~| zd~wLyAn-13r}PEIn=fq6kHcB$#%socI#ZC7u;iqb#8ka;MCB`7B+)0jOGre9LlCTv zVGZp%XKm-tqjtMBm7X*TIqL8UAiJz7jmD+M|dW$up|8lT{=oDXJZ|V zw*X;5Zm$?|LGICOBDc<{+yzS%Ne%ld$l6tB^Wsi%Gs`k^>F?CT;SakEDOn1EbBBFD zZf@pA*%4EY?v0qMIS=%u%LeAY} ziEOf<93$bcxYM-pw?B^3%<5IrqK+6gZN#5mFojunE(TU559H%LNz_xvev+%~pDRc2 z7AJp_n^JrZ>VaKnzo>p1N`1hE)V+)zfuj4Hb5#T)0P0s^s_Xo_&QVC6Hdo-3^An1T zaJ|8uCv+3@ukTG7OfsIUl7r5HxBr@g;j|Xmpy_8IW>FE$6NZ@tprlMs9i<^6*NuI+ z5gWauJ0>S{8AWq0jr_Hy@Z z=3Fr4=x$+L$MUE1)p>~P=&=HhBrw!b*AZcU4ne&Dto-KD0H8-YkV#wbAv%y$oadvq z_uG=71p8T>`y9zRLENtfMAY$g$kfiwsc+~HIoMpnCpsoY@HX}C3GH3Q+eP3_{02$^)UoAd!lfu!0&cj zDXD>7bmIam$9rGq{D4U%mLx*kZba}Hg*LJJ-c=cozPv)neOL~l6XeEgBh39MDSje& z@q?l)+|ek}yhlNjo2_e54zH8+#<6PCi3OcoV%9c}OJH_}m6W37QZ57*g}UTYF2!fb z(kIhA(&&X0E`Wq5cXR?z-8}H)((^2>m|gGC6Lz{=i9vdW#s%Q~7Pm58070(~U5c>S z*_Z8(kmGBT4?ZQsQooh(sXev>zpKs2K|Wl{cD7&2&}kzYpRge))TSizktZ~%#FF7W zn#+$*Q2lA$2_adVivyTxS*sBT*xkXXsNhW>+E?2mfI|v}z99yc_MC#jH*fT%9M#|# z{x|uOa_#}QMEh%IDa7S-$R>pzSj;9WYA7eI^$JglR${P|vQWw+2g)%Sz@#K_A-zGK zNJ2?c(e~U|%c#@Z**~bG;SAeBo3106i-))H*6@%4X+98=Qam<pv*$^yBkzD zaCC-XZARY#qqg|bEK&~{7oeo8Co(JvDL(j*w{kSG?vfL^38*;G-)@-`#ZvB4fKcji zaZ}naymW{Zad<)e7~jbU(YWD~P$a}j$QUI~3wjh+<3SxA+H2x9vUETEK6DRg>H@Ko zT9cx0D2k3o#T**gc@UuOhS{_teWlYpDY&c#bi#M|ts!ecC-m-!96Lm(_92zWNoRHQ7O1MC1ebl#lWQLI0$IOm1S>W+y4$ehCl^+EOF>NN4V) zbr37o;^jix3nc(4L0VWBLx8je7z3{sX#h0hAW2jBsbY8Ju&WwY|1HtSpC!%zwlwd| z87{ltGNy`&!ceW47&Bb=gy$t+$kAkj)Gp!U3%6ki0>y*zjsE7%;`P?qrQJ%ffEPs$ z^r=x42ad8Hq-%)a!`C(D2R1M-tzzwZ#AtBW z93|I2oEVY65bBfDH~6MQs&s(-L}X-8tE*E{`Ku%6J~T(-=eC#Bkg4N8=>~gldrAEY z2kCw*`HQ;Qn#vbMq*khs>V9iy-fc5)wSp?eZcz1oCHU^hs`Oh;GOhZ|8R52=cEx&b zdora|`*gz!oj zWYqmru14_G$bu*_Z?tY3uB2_IS)(D-l=}j|ZLv+xBK=SsN#M1dI!Fo|!4TS0m^?N> zAu^-XA!m#>m8P(q^k4Au5uE;WL~!B)6Hu#mazMfO#$I7XU3SH2II4ZTo2z-z)i=R%y*B)Tk}$^Y2ItDQlLXZLfFj24m9@0lkoV=_V9E zh2J#Hp&~$Sk#&=yq>H z@h>N&I@w=_Fky3fxFQd=c%_gZ8$)CbbobzK$6l}g{^$H0)t|Tj3|}L|&kD7vKxykS z94vVlQNJd%1RI8U1xOLs9CG)UARWr{VC>_cD9)hKT;T`@c&&JYO0*5K7LoOj{X2WO zKC2g~5pPP$v&(|Qa7_olS2mzQ@n{n?|9dtgh#7XmAg&T4pv$GJiY&l$Go~L-PN;=8 zjoQLnrMTTKaii%CZoj!;#&<%kpiC?`v;x?v@+f z_F$eLEmyrqhw`x6YB>(L?|RFdr0ZY@c(|>|d`ia%cj?L!&A(h)NtnCkoV#fVDxK&( z(k}MqZPHTMp+sGr>EL_nlI44HR=6Ef2GUs9k~Y8;-F+LqoITsUQ=E>iCvBsd=1fd^ zNd@5)7*1*6PzQ&`P}1KO>K_kY$+$L_2=4MY&^^u!XTj#Q6Sq`5^j1di>_oA(O94JH zvQ9kghA(`r@ajvD)fkHsW_RF{gvHYG#XHJZ*kUwwzuD0gy!92&(swxoN{-$g3n?3BA1<*Ic5IHZ=0$IDtT_=pl9IZ_a5cuF z{4txUZn$Edb23bHB$66F6}$pS&&$m%6=Lv+89m|2@5U=1XKgBY6o;RmVL_*G3{~;r zi$nA}Sd11E7&8@OTz%WmIIhMh^O;>UKK`ol_sUN-H|pgrFm-Lwosu>6OmI(-9w@y1 z&QL0_gO1U<@r0xGc<_?WT`>trexcOqroWE5*yQvhV5;lG(qzA%0P*?Q;2U_t8YHpQ z!P4;w2XN41H?auI18qPOu+DM}=mBC(M3#@kTCR=2F*dat8C2lN%|EcZSVH)9t+HAV zPJ9*gAcvRl%d6=&8N7K7s*K`LFFQVg)5+T^rQFfg^goKPL4cU^JE6;zqnX{%CYE#^ zW;5O+qJ`Bb7LWjVmoJjmE1x_=ia1IZ7o<4BHPu*Q>o3~m^>dCwEod|Jyuf z7Zb^bkljJ74g_QgxY;}ii_wxd2_$6621pH<%+Aj44%wXEQ4(<0epqTlG^Pc< zsy8qv%$tIyP)$MDxh=En5}!y*%ym)<4^H!R*XW)d$^lJxIk=FHkCDYj#cq968L&)Q zeM~uSF5yXjX!S-En@D`{L!QTuy2DHQ3UB7dI5u#w;T3#c1RJB7?G`DiKe8m4f=S(B znpw7UVPpe#N2{P62qnl^lL3?Q31>}a6y89pGJJ=*3i~3U}$<`hcU1 zh-w#Ul!#}%^Vx5yPaV4pm=0?JMOk9u`0*QAM1_T;^bBXEhJ~XMU=WBZ;;OjPERYm% z9`Y*t%dQoRtRpSo5nSwwn!V&zx`0x4Nzs-4)N9JpwHCae=}~tbaYGhth_;x(l9tRc zo@6U~y>(|SoDz+nPVHAF2^+hfOjy>zKVx2A)M_by#ZC6#L@DKc_zG^9D3`o;U_IlZ zRkeB8f`xD8nYE?nQW{M5Gb!F$B#~?zXGAI|a+=qPAY+D)avT7XbPgzVql0GHSG+v3 zg!{Swq$TV=gIIw=OiM_0GlYf3Z`~|XJG@*`PCegDSJb{XZik7Yj6AJM9HZ-65KPvl zT)TAVLqbZuynFT^G^j$+y+b`_3+WM%Df@VT_Us#!nH3qUapj(+tiFfo!{ybVt4Z$js>+J&N=*BdNVp zBg^r#>uRCf$O=&Gk#_wJ$wQR=Rpxin11(1`oj7IHJGtM%0urKN22Qy^O6cky4)~{N z%1GQZ(!;KMPkBU|P>D4nArQkUI>SQ+Jb6OPM@~^ikFGNi#`+X-W=hpcbUTc)$4^m} zXM{eQICbZ{7^e{v@5cQmZ!z*=hmbr~JEKAvp9uLIv^2&jA*!GD4%@*3nF-zq?0vO= z@0r{{CJT=NRwB(eL_x5KNzwre9~TLRk1le;;iGg{zK8i`E~63KXlO2krO8%6qr(bP zIvuPazB2KIbdjnI+7eY*QbXf-mIua=8HiKF>qO?9@0lZ`_Gw4%+-LFpu&-2fI}JA% zUWx6xezV{$%$yyuW|0*xe2s=)!sja41B%1F_ASB9j9(~ubhyc%b2ius&ovoZu?4i?tV9Ot4fah&uDPNGMA%1w0~pF&E>9FvB`v;gDj2>;MwW%vy4sl$aaD?if%(-`r*+(C)?X8h(^vn_F`(10Ny^FSsz* z$Ky598BBP}Ew;dR5Qe}ZfKAi1mxH=eF&E0gv4#OQfTTl1r9znkVh6Jk9~Y9qoG!o4 z2obd$X*Bs&N=P#+Od5vt68@UJ{<^CMrpaMVKXWjf2mi?pEOkr~h=be;x%`IV(l&&2 z8!vAu*(EEhk6cwQAV)rT%0&s9qsYbP0!MF0fPV8F3l%Ph$#BW6cfATs4Hl~#>8aE< z7^`TOog^q$Nit;ae-F=+J+`B$>&{#Kc?u21PCh<`p?4_w27hY@D5bDo**j_X7O+|x z$Dpad_OAE(z~vi(t8oo^qa4PYyLEH61tK>VS^@`yO!zBTe->^XCH5Ltr=!< zuy880*aLZYmdcTv5^`l>5?f}sNkBoSK3 z8uXpb1QrP!2ima%y~MT;nB`b#7bDGsA}6TX$p#0}WW!_UAx7Cww<{-Wi1mr18Fp6> z)qJ*M94=f&0X%;*Z?}4ML!x*=)*r<=jZlnB#6BfxYqcSwCfWgR(X|5gkTQOdC)=zg zTeW!9tSl7uJtWGSWk`+rl^UaN(c+M}yI3-~G09l%Mt3G%kap8rvVJs+TD#sSY;63d zq7DA;Hd}2xSlo9JHx^g%D{ikO=Z>Tt$JOPA$?*yNQgMZcS-gsI2;I3G=I~o#ImTXq zT>|434ZmH^VyR1Vc&bVSKS7F=BC-BV7i{ILFmLpc$(o~Afd|x2$;^MdK8m3Cu-1*A zEO}|6zI~3-qw%ePKf}c(Kv*0_`u!Z!Kpf_}DSE3Ftvf34DP)UnaQ_4gkGH(v&W!NC zk=~JyTo!UfJhDa_FTl~sW7bL?jcXKddk6Prkc0AfWtdlX?hKB9DWfH9zWi@3dJ(=u z(?zYs)k&?Sg?oQqP@LY$JRK?{Y6hvFw zZ?~96$uQ~n@8tgR2qoNsk8Z3^y0Szu9msz`bn_<`xD7w0_{IN_^c9I1*8#YhN2y&W zP~v)xB&d%FY&fjoKK|O>3%E!VaC$HidNLGYnk|8H!9aE7|3vRh87#-p~oP(HBwh481_V9a1^8MB?2Ya|X82$dL4wM)y=pT<$)I>*IYk*{M?n zd6b#(CHqj@+X;E7@P1$g9Arl(MmCv{|OZhOv$WCkYt_)|O- zU;A5{`~gX&V9&J?O>mgISvc8OujNJ^bp~QUV;?(6_sYSkcUsJey!hR&_j6X2&{t2X z!EuvvPpJ>H6%xwglirszh@fMVu?SZ7sU5vOQ-T&t8(^{^Wb_drsdRa=;{;y7p)pcJ zHNq^vq;rsDBxFzpYVi9^MrWse-kk1yT!yX()%>jus;1&uI%yB@{=S{Q6Q1>9UW1c1 z$Ev){%z?Wj-DF;0x);>_BX}N58in_GeNvdxv(Is!9LBf7OJ5veG7&Jk6`0o_3HyQW zJn@Yo^vP#=_zF-qv*-rsDIW@3H?y1XvP4YS)ux2^2mCFbWkmPmvw7=ctsrL|d&nP* z9DJZ5n7b>4T_eqyMMd}*dY4LkRrCh&xt)x%2%Ofp-pwWY$Gh%H9##_(`G}6*8$Qj&0EXsE&OwR?yTVm{5t0EUcNOJ0D=(%$Zkmjbt$s`-L4Ga+G3ZzQ~%=V0AKw|agUQa@B>y7PP7gX5l$G#ZdK6amzSI{yriAn zzrhxmP|T(v78r`*O1D^H&!(I$QbMN+2W*Lx@cW4oGLLbGDL5~fd`&L;n(Y>idhWQ_ zVg;8e3SZH?`ab@hrAs&1-@eKPxE6A`x_z`|TvjsB>-OcV&&+s@F^YA=hy6^-`P#$GN0A*5qk}3)z+WJ8kJ<=*Zcj@ezJ;Bm=YEZ%jAv*be zNzBPQWKtY0qjay^v~FV}nO^tFNvV?vM>tX#!S5r^1Agr;?oEf4R2d0ZUzMcZc(1o5 zi-arb&bGgoH6piDpB!lLeB?(UjX{PhEL~M%)oHlQlr}=CUQC77qP7qO1wArL(1g3- zo1SPV2dL!|mfr;1-sB|=m2{zAw9b}L^i*8joA9`XBG5!_^jgCF)t_SG*c$;9wcjj7 zw$=8H=b$vBrM96h?a@*=6;L=A-yM=&eNnbsga~}$DYn+WJGhGwWkN`PiYILWk+|F7 z?J?f$xlF z?u}er!LS-5bQ*crb+5z50nqwlfI#<;NV?Ph!^{@w_-*5Hu99&$w^^ z9hf!X>Vp%JwQuPCX=A}K!cczwY0D6e1qvyWPu=_ful=O4C?Vz(IEm**3Zuv|Z_dA) z@8`u&u0yPq$lW;(r(_a5Nq#prs1RbLv&qx8$wFwFkJ6pj@OYdSci=#SavE#zoYh8p z`hH=aIGi8>N^L@U2`4;8LyO}Zd4XmI(rsgb(n)fejZnS}p5D1awHue4bl112_2vgG zZQ*_Ep7qsz`PUfKU+{dvg?i>N>G5F+md~FvqVTtF9?;$7I59eSd127pHMmRe95VQk zwYBZi2buQ9fWLJI8ljm(xztc>(@@LsqWD-`LhugTKJWMWp}^!DjTqU&npV1rsgLqg+NF=}mVHD<3TVYJrY zglyW&#w(-Um+stlW^nsKwxS6g-tiBX9#&|C8!u{o`zUiT0VuX&FD&j_?l;& zqHZFI^gbzbDI@Uht|tTyX&r8oa9EfsFv29S&3BYHkmlTlxJu?ZvOBnMrCVB!Lz&vT z0zaM2?n0_{2D=NXRFWQQZ#gPge z(W(^__4*-hlB&SAYp>MX#UaO(@nZq^Kr{kM`dHw~+1J%mA7gdWEl$-v<~bA|+)1~; zI^E6pH|7Kj>YeT=kZQhr0MA7#CbYKk?eo>bWBc%oFGWZ``R53}UCnPU2B~UfHon1d zj&JPyMXh_jY&&))qkokW=Pb||FzI{Vs!LS{?~~)bSNd^t!efzq|E?;bZK}eenwJ zh|(VIS#9@3*bf$c)%NedD{CVoleUm}slNSSEm{D~sw?;4nUJ;PULk-yYZU?V+ej|0 zwQgb27R=TRXAACi^}S^Bc2{+y!zH=CF^1uOwSc1rPU0hDYci$6U$-}nF?;cyLuBl9cwX-u=Q-K9HAU$bO$=9?uS zZBS8j{+8Kj_rIUf^x$$9m|&L=F1wJ21sdXa+mE;NZ$~du1`bOzq74eVw*8ZB7w~nb zwP8bh^d}GYBT)8ITF0R|^o;wBOrD|tkGVrf|BoL#{hNmn_Aw6_QBrOxQV~iLJM)R$ z+4a+%pZI!|pEexpf!cvv)cOksr{`f;DLvVzXLh3GVgqZ@Y=WwLcnh%=m3WT&R9lL& z5byQG&U}(7=0T%qCZ6U-;mr`K5xR_yvd@VdvcUVJ^k#L2JS!YK;f3uZL|2?=C9RWw z@A3?_?}DM$unS+sXk2K$&54AA4!67cpDkNCndAJcDS!+jnPf=R8@*_tFx)*@I8dmT zDp+GjPOR&UZN4M%u;ClL?9F}=1rn6Fdg4S!;I)C(0lm)XgfcKd?}3BO7x6MEnzz0F zF$8-oG;Xq{dS{WkUD8QGD=$ax^WX{w?b*p&Y{VLS`D9jthP6BXYSyMivI)HbIO@7_ zf*ail#6IUlZZ;RV`UO;fUZmc;lUYRdQGPhyeUF%>;hk+~_8^pH#Fm1C#s+>RqkPTh zK6hl;3Rk+Za%tQ|)NdF2Z%XpPXvnVAX1u$V(jFOl&{3!F_dRN7O|PzD-zdP~p6j;B z>9a`JPz}oeVq2+?Nn$HF+M5TOH^~-rF)^C{qBwBv`s)IUKa+Mp$poI!pX&>9mU7M| z?0v6ZgL)^Mh>V~tH{;rr`~J&iQp zQ)-w9({}1(yqboIFkOEnKWV9LkzYwzNtdr-tmgCmtd6j}V#TV>6b5F~sCAtYCDAjk z;3e{up9zMNi_^Q%3PF;3oX*4#)6*fXnn`M?SMPmq!X$8Yx>Eo+)#1PhyLOI79GY@j z6MR{A5qkB$^4u#mECYJm^etv;T-=6h#<*tUsF%X;bgXX)>fqrz;USBl4v+!XJHl(S z&k2F~(={50FYoXG4dDU@5f;1*N47$~x~o#i2Oa+^tF#gO#uPVs$z9Mn=}7}F`1^|I z{(QbXz59T%6;?5>=eYN0xP=YQvZ%0RqREMlFbHJSgaxyRKL%^S9<;QQZY zCcuir?^*hr)(Z;eXo2N+6s5F?@I^t}^S@_-1Pxu1G)j-4b=GlKIe!vY0-P&kIGXt- z`kLm+>|RJW&3np-05uxw;qNzbi?L6`@yH)f;R;BFSt6zgx_`hE-i(dLb|F|dgN4d= z&pm8?!B?#8u`2)a)f&@l;xxD4Ptd7iMbEh_#ndKVN)vDQyxQ=CkBZZ~Q4Y@(yK|5O zq4VuAQopItKg09X6z+m1GlayA!B>CSME(+>`%X$VVVQ}S3|O>KAqP^ zQ?w(&TZjP;@}5}y@2>dYa90$4$WLOj*t`{)7H5Y1g~;d1g!D{zUifcz`MC4Zl1A08 zX)fbrOpY=h({yM_1`0zh4VCr?^|qrxVI_JtPO5?$MW__M83P3bPo(4Xaaw~6xMVDE zfA3G3P(@e?w`Wa&!1RxPKBJu{8EYZM^n5l$Fm3#q&Ev%!MEm|HEV7z7vi15VqVIJj zq-yBWJf?qz22d!L$4w|^SfXhf<)Kx|WYwm5arUa2uM69o(5VUNLoV}in@mUGI~s#* z=y*|KLQ&{ric~H~x8oY)D^;@vv-OMOHv1N8j+V%as<~TvE)o33hM`Ew%YLmW`&T8ik-?PnhO~2<5k`!KxSJ2yk!7J#ewdSpRg)hRS8FFovk#X*rwObzDzbE z@})s`^4VWyxt=Q8lCQWgYGY+<*q^=RQP+-woB{A0AuFC`j#o!$K90_L-fx=6*`;ab=gE*K=<4g6w5)^3JjNVXx)LU=O}9{|)*}d>n+3!hcwLH$yrK%xN3DLu@C|1jFWxdcPg^aldWmuo-Bx#vQ?tu19;K z7qAmvHnxd*WGp#vRotS|?O9at`f%oJsA^pA){i0#U6mqP!2*Toha~4e{hyYiDGh_2 z{_q*Ls2QqPsN68Yf&SD2|j<-e4f0 z$Er|1Q7aDVU9FLbxFLBsu(91AeV*(8w${+Q+W1E}beKpSB1g?*T9-M19=TfV1$Qqn z1-)xsjqx{ia=*Y_cJE?0irdLarx*LglhV^|C%c}$Pw#q{ud>&z-kjd#`QW^cl7%im z$L?BQn-6?4(X}4~jsWwiJ%Q5v->7WM>otWgK3A-P^Mi zC2{5t`eFdjnr*2zL;N zHBatt6~p1bY@3SpEMo`XtX$nQJ*gQ3`eG*Ny-OW$K0^MH=Q=0Q@iL5A({nJe{lS@n zEGclPz+=9d0HW^+686P^ZMB@>g)#Ma#iu0BxbZf4k&5%)Hs)j+6AIdv&9ep5v|WWL z4Xf|P$60XRv2q5YglAB(p61cSBFVAaf}0q{neBp{@Ac40sliC@5&P)K`8#H7n|5pl zse9DOU*2dw=~Yupx!*igTB`*`+hU6=ur2zu0E!e~?iNidRlNp3N3@#n5z60x8qas3 zy1g)HoK%V7bD;v3wGt9jwE|x0%tX4Vm_q1= zCJ8))Q-71B9$a(s2PsE_^~{>y9es#p&V(Rc_H@gbk9y`AUy}YWSrgKl$8N7;WW^n% zp&W!kfaMg>|8SfIW1*x?OO!!S+J1z$06c{>^Nh0eeaG8xXXN$~#?D)pGqN>CpbDn2 z%$yrLY8~}nZd^x^YgVshPZwW7&N(II-sRIhYuQ)?=D+5!HM`wXaGKjp6x_5=TTwuQ z7aco$=$Rdz<9h?iVfGb|V%M9)>53U1$|+h*w`V_Jy3i8Fx1Ucm_~tpb0K}3R?F1p^ z@F1^3m+S5Zl!ED_KyN^&x&77aQwB!vFz1~cd5H0*g^tPIv~ZdSEIs>z{{8Yz}(=(X(>8b zsWuS-GQD=&1Q6|MgpoGR3iUFDLF%n!1Cx6P_Lyg1dW;0)H0@zJC$Lvz!RYHk zNj~cB>~m+z@D4n7IO-Iv>g=`3$4$%TaGuw}eurTOt3VQSMG0 zTV(Yc%hB}C_Bvo9*geJdcjP*jenTn~%D4IbS8pOKM zLbht+5uBNhFAvaXhLSAY$K00LP<5h)z(~YNgvDkq6xwyTEsAcsOwLv?=~o$J?=9kS z!92^rb7#!~tKup(0_p~D_CISv22Rs-6y<;lvzPa-_C%I&79+v-(;fzpaAxuC;W78p z%`Zmw=vBNP?mEd%ihPV|x72YG)4K;G;!M}8K*uv$*qO6c zdX#2v-w_Wv-E*2lMGp}fFWutJP-NQ~@?g(?rlsYtyp7~VwADbLX~wkKDdWv{GC#P>q^0aiNYdb;|IQDh*H4b3ydqxV>HF!k z?DQRNb=$_{Gv4SOOL8|!>rQ8LmWZ$Bt+L4IX2^{r*#mi!@wf+r&Q8MPK|TYi=d6o{ z1`9O>_0Bw&v6Mw_f=RN&R1=h>Y*+>TC;ox2xn=jbswh}+h;e6R5GOdo^7$5 zq2^*Dl-cae2-QR}eP$+Tsz&SIijxuo1q_Ri{aa75$a+~f=FC*mB=?lG-5#`uZMRDh z4KXLWNu+q{o3{5R<0e!f^=6t@9ohrUef!vWZ9F>~rE_YDrSqpe?d!ly30bF7yH*C^7F7 zzDjmJQlUo{4iA7GEOpxq>I3QjWTX$d$ql32^d4dVGu~EmmbYn$gwUk4txg^>5w900 z-|-wv=c8T_m~A04JDla4`|(!g_GF+rB1^`16s{jK89UA@EcgmIEtwIc2dT5_09l%{)85HcT=-P&9itmv|n zG0p3OWT4Z&G)M*~I7-0I>FSgr=r*#@x*--A;(NXBOiPdHX%`7SAYdGsG&~uAWw3I^ zv_(L?3oNO*OD)!ZWZvUKOX^AJ6#gAX5D4jP4ih0D*tAA@(~HC1+k+bzzmCPOtPdG% z$#<^b$bV=h!G)aHIYo`gORH_6Bq$s}n5L1jYz1D)P*guJ4fBVxW93ofpxpb3Ka$AF zt`F(=L_9O0w1nNp50rasz=XYU>3FeqF`CeD)8 zlvE2LR?Lo>S2H*LAwMKSYDgMr%Ub@e-qr0ccVZGO>B;R*o6SyEt|1a6TtVCq_=#ke zlHfuWSOrLQlUs=9X5?tKZPFh*mb9Ps0;cC;?H_R@;Y5vTmk9YnjwxM#JHjxwoo(rq zh&@P>QR?o+uRM<^G!+P|I5gx&X>xA6QFg^f86~uJmuc4#02-*0Rx0qb#f%gL%0uN* zyo=prQ^!nw3*s1sk^$3bf_FVP$|YL07Uwm?5y67zGe_hRjtZFdD2ogh=-#DQ5mVYK z6zRbA4OKROD0pku!t6+-d(KgPgg}8=u*4(GLQgl_R{uG(hU?%U5-DFDy!tw3o4de>Vnl2ctvE%21&`BT z6fU&~C7RI}uUd2a^Jb&<#Ngi7m|e7EyQctn>_`!%kOP$&xI=K=(0+A#QZ=Z2LQE4O8RbrqLP6>rN; zg+X->LvjphigEm_mC8h0nv7qTF4qR>}^R#p%qeodr+Yiu6hY?lK^p{MJ za6cvFuGH3>)riJxRj#QrxJ8M7u#$y;I!WcNLM*e+FVq(FXzU{Wr7Y2>Q1M(Pw_khP zE#;2pVLEw)Eg(v6@C;T}Jrx+5wb?3q&)3aRCJDl^G&TmWWm0@@UL7TUs2WN^dH*mX zl$f>j80(*@F_Cr7b%JEM^B5Xq*)I+YM%1gAbK?qiCb&5ED9|RV(fGaLjSiUvcUPVp z#hxpGw|V^!0ic06%Xn*^GZI=AYllb#phID7BoC=L*r=K|mdj!?p&etznUG7QUy+F= zuH+lN?e@Lxsa0B26wiVH1nToPmaXn51XSKiTpC9cRRtB&I__Q-ds_9T4@i=Mf*FD9 zqB>F-qKRx1@#f@+e)mp+m^8)19*+$pO@u6u#2Fqo^!&;p<|#u=;e6OY@qU-qn!8l+ zqR@9GPrrApwDJo5Vw@2X5t2{davIB#x}O~lK0P$qI?B6~VV=bJn#@qFq==J{j2-nD zhHJuRhLTr=otri-VA~VJmXwvY+g@O~C`E>YcKt=&puous>InrI;jL7Oes(?Yt#&}( zU=8ZQsV_N}ktR|zgrC>JP~i}z>dXayJFmC%N$ZB!h(r^y9rL{_F zbTnTfd72L%xRJm2R?u)DYy)-P@xZ*Duoy6@Uvb2YD2OUcf=Li7E6juf! ziyWT;!}hy*Xvy@CbXCn|iw3@(jWrpHEjJ2N!(e79MLkBp@eM1|ufU+rWwLOvWjH8J zt0`ul%*6=ISgmdI5~*RdAxD66&gkzOtd5jG8&X{k)z-tBiTpXfLStBLO(rtr0o!oL z&=5t+7LzJAO<$s}jmZjw6>-44^(-$U^ft;PV?l$~-IeyPO!Yp?04YPfE?Hu!5H@Jo zqn{bWhBFU3mhuS_oW8!7mvQLmj|_gWTHVUXQv8jNDe$>gB`R1OfA2hT%WJ zXb*G~j5fzw!m(&LUn|qzpym>K#Esw1(1S_FZ?*FzW9awq2!g%#0FJ$gYca&OLQm_j z*7gq}$wNN4bVGE>YgHfof@zk553so^Wsp^spZoxD1!4+SBS?+Xk7UQnh7w3NC7Sz86-*u z&)&oft2A&Gey3~v+l^UZ2y|sS4-mwpIpzW2oA{)M0t3-YMwozsbdPQ39Q*vjH}5^} zrAqlN+|-gZw1hL(h?8UHPzYI7rX*8((g~gU=st0j7K@z0;>Vou8H~21_V?*92{cho znM|RhG$U5cl<5K`r%irJi{p*~3gP$+iOA+Py$y)(6lTj*{0R5tMNHQEw$Lu z6UpTd>{Y;Sv72&%?iRgkuCSZ{&~LQP$pTpMpf9_goJimr>1&H(?0=#V`=ZtKo!0J_ zTDQU+1%`~1zl{=iXSG;YaOuBCUj|Ft%62l%Hxjr0l zJZX(&iK-F_QD^?6sF3YHzr`}5r&mKM))BsZYjlKuE$yr3cMm`X-*_d1(nF%(Rv=M| z7I$wT-*{Wq_WT%MhB1}fE{x(3YjPBbtRqghp%a0OP&c(1b1kJxbKBTv9W?7P)ZCS) zwOogp5tQA$#n2IqVZ#?m5o?p~{3{-pGv|McsXgTlvL*~j_xK2fUg6YH^^O$l4e7UrFCob834?7JCDziE};{_-5aA1CfzAe+~D$!(k*c{ zg*4+tEg-DwCvSUY&r886(J{Rns<~qdZ(Qg%zRgASFQZ#I&C6hwRvntOhs>(&cH*&| z6T1n1!JLtNYYwG_@H1AC80z&#h@HUf)Y#R{Sp!4qjU60F9fI(YD7^Ln(5}dvk-8lw zqD7(yeB31)b&9mq9yv?QU^;+le78Opq9^w~=7cepJtnzUO=K%NUAKMvVx2KhR+x{1 zpMEr^S`O!`1TT2UkysUUVVt9a(_S5`DZ|)dPL9D(-xI4GW-ToEdp^{g`%A%Pe;yfg zYqj9bJ1m-Oo%bG|2Sru8J>$lc5rWQxU`pc`V%G2fg3;fvHB8AVK@3Q7%X7fMY!eQ5w3KH zbgvTFja7$7_Tm(4wN>#LGNp{;9I+bPww3%CyjJ#>OBG@`H7VOlC*he3}{FvTjJ2+TDN#uhOUo7M2457@PcAkc(} zFj}%qsp$Cv+?fPT4-m@F)xvN#M=m&K?)PG%`S;#&^rzSRscLpFjMDc0Mell1$kzdm zLMRi)NFb4duLa%xmJJk@ajz2iPl}7&Lg>VJ-6j}De9(W#{W|tDd>OP}%Th0K&cIwc zYeU$=^mNDPFPHA*Y|A;gqr3GPbX(e>gzAy;4xb%4 zYN=zLs4lItWV~o?#5i3_vwAQ_FXL5`WJQV40}C{lukJ6DNeqAtagh=sgML7wMJ_>% zR;YMY#|KNp!S`h9Iaa!koKj24ASKq2S2=X~B-ocm2VuA{i^9ml{6Y6Kk$LO~v`Tc@ z+ z6O}CCR6ecA#9+o*$*dV?9kN}huAaO1k9HAmokbF+?JFT0YIZmmK5E4jbNQusbUw*kBNVLWZrsvB!1~PladCnQq-OL{G z^xZ$9_|C9dyBixl*L+kY9G!{ju!BwWj7{3D;A0o%4$2G?Ec)A6_29rTB0dE-vC;;E z6*8Fb;p_*uUSS0XJV=-u0|O5>K;2*1O=l{@0N@p{qAk1B5%4K00765oFSx zQtB)u3$L^YHey+dV1P%F{7%GyQ;!sTSK|_x#}hIOc}J@7@Pw`VON@y-1xU>n9J?qk z9oR=-t)+@w;$EZDVbIsx0jxaC+m~vx!xRLAGsB{Nzg_iN>08q6Lo`3PXpt!E-Ixw2xP&PLo#&Nl#Bb z0L5+Vwi-olUnfMVe|d3|q5~}o+C@a+Znr=dso7ioCNh`hX#Bob*gR3{%7Gpt;9Q ztMe?%WCAndQcn#Bpj+Z&UAj0GV**gpb3)EiC`6FZu<EVEdS5jwy6|I@TAL)6a(()ru3(JZL}UlA8m9-5$h3G1SGu|ID(Pkh`Vxkvr|{HZ ze$>1>aXOv2m8AcO-6~SB1r>tXOKzAY*gC{K=+d>ri_&L7t$6+*FZ=mI39b;Isf;66 z#(|D}jXfTBRaRqookDbFvU0*fbrmg5{3hDS8i?-C4zm*3Li-8{EiG+aUg`edcry;icwv<0(SzGB+|fheo6y zQmKT(rYiWbVBl>zwkF;Ak~^(NS=U-a)CKvI6AvpHJ=x^uw<%;g^ww8vd&-aFM5~l#38AG zqz}&*(ri<~rFSu6q~p?l?FpZVb}AfUj1aUOAB-WcRTC2wS&CmYOX(JCF$Smhj4*>h zOCfpC_7yI0sLMy%i}JqIFt{7q5Pqysq`f@IvnP9s;@R#hP=+XM0xGoaQC!nMIRh+KKnWG;6r5APzKfEK8jHeGmLk2(x5g&}u z$GcHCpY_whG1ygza*$UE86o8Pz?*rc@?$V}9FOdSw4=D-OO{NTFL5uCISQjNe~)#) z_6Za?sT@SdZNA=>9Y6x{$8U(O5jPAXj-cPM7|W*HdPM9Yo<(OWugoV_n$X2IUcSlY zgKpD!LuL5lv8$L1%}!25TjuQNB7HZA{EXgi)mX=C7_db2@QLAFwNXfq-Xz4AGZuc> z!#215dqae6fkYdk+<^O)&q*ShBFFk96Vaw!+C(PN5={Cv^o8fzWW>dZNc~{M5~(+U z?yr?Zi$^VNtU&VTS4@g z9==Gh{tIe!Oi@qxy36~TtXoj#Mb+}eSxh1LFe?NhWo8$d{0AVkNtc1{PTseamKV!c zSOLd~VS3D9i=B+NUAs4F2zH0h)MV;bG%yKu^Sz=azIxFTX!wW+bLY(U6auTR7>(!S z;%iLeTrGGB4ML(lDwd&T`8%LBEOPaHedP*J?UI$sYx4RT8pPEeUq?%=GAsO{IK6Ka(^i+B9fg3WS*RY?T5-) zaF&JXX-N8-?a%q`nO6s6kA2Vf|KfFC^pt*ygW|=`@SY}m;X)?5wSUByw&%Lwh&+vf zI%fhb;glHM;tJ8s#%+@~WEqkEQUDp39n3%%wEGPtTuNSYE6dRXyq4J>xz#lo%gI>?gD}x3yk>=M$%B7$IFj*PDI9b0++O$t1-8X z4#noN(YRwH1y6SmPEJ$cD=X)PC{TVJ3EpzMl0eWODphiM>ol4VKKy>I*A6ORMD0L0 zllKzr$kY!7VK~*XD#q`v_y)iK;vL#G*-r&MD6odze{-u=D`vPl$tz~`V@-y9!!m4s zA}K|&Yr&Xa3EBNC;UZk19q^mbggQZ2DB>POUK;IqpQ7PE{^PsfqFBHdE-h8N`>i0b z@vUyVh6T*xXbm)XZb_QEMy$eT_}wn42ZN62cLEXGC8{>lIh~B{>CS<>EsoBJdQeKH zHlhMlA3~B?q_Z#fkaoq;7X4;6!Zw0^CWO5MAaLig{Om?|u(Gzc%{PSG1{0h` z;F~@Iu6S(>fgR=s!S#P}o*wzSAYYc6Jt2G?Jn3d06LLFU`Lxb?n!$!FATTY}g3=#* z)X>uVaSD+*hdO)`DMSysb%iz9Tq32nFbpc#Wv^y4U+&}i0yXea?+>_*nR4w%dS5Iw zBb@fug6q)##{2<%=&rI1{xI$874gNe*^qtGMUmNRtlG|~b7{nEcY*nRqIg!Nb`F|8 z^ch;J&$|nJrd(sB){!aL_(+5LFMWw6SZcdh+HBU&<|5!h|#1_q7GSTudBOG)@ zNG}tmQ?g42k9(W`h`SKk?q zi#jY@lv&V#M#(c%f^O_y_q5&ST|RA%h_*sVu0kqq4X?Z zGU|5$`a*_B=u2Bl+u480GQ%NBB)&+B4QeP!e_u*`3{a6dO+1+t1(fy*09a3C%pOgG z@3AWuDdBO71Xpoqu)ihL;vSKtg>_64$1z-D<249jswKQD^r+k+ez6JWW-VDIrMjlf z;^8?_3>G#pE5S)GvqbE$F1wRXA)I)n=hi>t@1mZ{lLL_6d=m_@NYJw{Vs?=WWFhjh z>fvH7d#HP-A!_i5pv_c{RF`Gff8WcQM?|vE`lOWfkJF>owy$}=dx$A|UcsLbqoSZo zJ>aN-nyk&-!`txo0__eiEA)0_9Cb;dHyC@|Zn4Lu_%e8(?EW%=5%gtr^DGNVEi@@4 zGmI44fg$yxF&!G}NPDIgUO6(goSOHdM|qG_$q~AsWj>F96`BKV z=BV5@TR^`(hraZp#9I5z_65n6JMES3H>EaFq*a{AvV@?#$>mYF%F_842Xe%Mwtqv! zKu?W`7_-T@T`A$G=~GO#QycL)eyiG;>^5sUG_uk5bY^nz@ePE#YrFr?c%E!`+CAT? zgrQ=63S+gN%(is)wvRLvuy)b&Bh9lRl(EH~$u}Fl04JV2t*_$Uy;UAvGTeHf9{);< zH#7$k^nplQCpbxOxXkVNmfO4Cmi0JqS@;42ur^E2Vt7n5{6${YxXm&#mJpy7cOsb= zUmJXxACvUByR_N#xPyohZ{?{_#O_IW4bb)`vDUW|5U5w{B~UxK?R7^ib&`D?r~Ew5 zE(4_6wn_ANpjEf`pm3S4H)*7(?aWulM{B{`IAA=;E=@Mj&9qUXgV%n70g&TZB8ke5 zkZ>QP8wiRcy2tV$*um}*!9I;ED$I(QF0{znL@7$q4OP2(*wDE#{THw172&Q6GOzh_ zDWf}Yh-@v83w09PJ#ta2u}0}}K(ChKET0%`v|1ZCk#)A{RhjJ?ANOgIQ8v~~q|)6| zZtsZ_hkx~}WQh=k=-MSppgVb}?qVj|0%EJl*Wr$Gp$i!;p3a3#6l)n*=yodF=nkIK zklRJH(IZp%THLq5S}BRK#^KTiw~CfcuVH2p-azU7vt)pwi@j)ff|I?_V>T9@EqsyZ zmW~L3O*SP%@ZuNp`mqt_Y#+hC`5a_UBseABN?cu@E5{tHbaKV2LM<}SV!y*<>sTBr zhBFQch(N@-d41&KQBd3zR(3L?sstS&2m)BsR8Tlal57F|pv>Fmm#}Ff=n$EqP0oL< zrFh~tO|6sU(w@AU$3B+!Z{rJtp5|1_)&EHdk-Y&Q8RynCIEF!^EE@ z65AYwL-TSGuVYBd=#;%jro(ZA5@mpig3lU=9H_WA_ z?|Bi9VIxn4HZ zK(t*s8HNfnilD4Zjbp53uhq|X^rK#*dIue0gt$wg8adjqty(kHPt0*!+C+nS>I$`y z@quo1wQRWb+)^30Amzd`vUhb4fC+GmL3S2nhsB|=IcCAek}fum*e0HAaCSr+>T>JB zsJCZkx|TMQxT}8Oly;$Zb_Q%!s+<}0KA@|3W?-uYiki5ALLCNk|3a2j^I*b!$4@$f z3;3J^2hWl{J@o(Fj$)?sk~D~gGo&|NP>yA{mCU~J?7wUhWqhD8+u&Ak5QnXud2(M0 z&VM7z4x?#ld7GB!#w#{yJvDFFV!9SWL0S}bxVg}DV##lQ&=S~mv=QN3q0haBdzmrO z{jmsvW=eIU#BaXHylqckRsp~Q!U3T~)LM2`wN&ihnLW52djjIm>7wwCcMIQSN!fZm zXMBpB^QHzSWLmhiUcbR`o82I=!A^U@&{)bgN0jD@dfI2105D|?(L=uOiy#qkr_*W# z4QoWJ=kjhGJ3&kv86$n^ZfR=`se|gDKl=WP88zYj@ph^6&L5Y(ncGWN11%68^Qm+G zXcF;0$P73G)(FqW;1`%F?5V&z4>bwn**Dlpik+sK1i$%bF~>!rvzQjo;4IdpF$+zT zPI67^;vQaGN$0>Ob#dKslY56IogyE23om(D;m~=H94Awgbc$>evO*6!gEk4IEIt28 z2^{~UhMSr72HR4(MAsbk#qOM6@ot_VcK`29B4RZ+Q|85QlQK5@Xn{=1{}i#S#9Ml! z9deU}q{8odtA*cWA*t}2FC^WZhlHdS|K5b8j#+5hd?Be_e1lg)^M#~#aUJrgPxh=S zNl5S@T^p?zO^`+#G{+fxJ zASKtmo$Ea1^jGhYGM18BAhYs6MM^sA?Ko=3Jag?-=Hu0mK3VFi^zaUzyC#cXN0jEv zUdKrx*{j9BH`(h3EmUp3@O6D$`8Sr^nlF7_ACFA&f+{o$rw{mcCjblkz`B z`ZDPrVWw-chRV?IXA(DANHX;1OGr1{AqlC)zc&dPp=a~OBX@9^`M>$Hkvo`s6<)E|F{Rh}kW0xa%3kT8uLvDQ^8*~60v z-0$4RbCsa(ZhW5zS0`{!`dcYufvW}oGX-v#j;n69qn|Mkn0+t|`}ChaIVx}xKitkU z`=rSE@UWUM^c}~AguWL4o`rsR_(JI?YX=DTc7#{wleHa$d%JG-vD+-(cRR}u5f@~$ zm@RYnWbF-MyoE|LH(w;JEm_BYy16!TqM4b2H?k$cuVsb+^`cI$<1Et{XF7P`%+UI+ zh8<^V(SRH5hB%o$de;YKn{ivu?>;1Dy!B{-@X}L2*KZ=_KK23GY{Y}HiNNn*0=pfc ziNKpL^W9X3WWE+pN9H$iz(UQCly4&ZeRo<`2+8#(!hZzrZj)J`M?TC;j~zYnC?m=E zeE(dTkdPp6BBDYF65Rl+FYh86I(*RCbv{_`-rUbj09!vcyxS^QgMr_wt~N8Em*o+) zz5>5HJW(o8ytE5G)g;LM#xsj|jgLImB&g&ySSntIZ~}0#L%xz~u;!ah0?mGc@Ba^m z7dsYVzMV6v+g769?F&y}zsrOZP3`Yw3vt`ZHTOsvZ!22x6xvp-(@xlF_M*Ej;xSWD zh)_53ke#4Ug4KM9?Wh=%*jhXtiJgSGj4vd5lN$aF&vQtICN-QY!eEju`23GB6A90d zT02Vy8wa;zi;NEgq(}vLY#-wcrK5JGeg0}Uv84D6!U-;Q0M=q$zZD%?)!hK zaJ>z4W;>i<9{l-#D)5;>v^x5wJGTX&{sDtTxaruoab1hsH&V23xF#3;{mduZ+y?XA zgvH3x@SRUIb(j`tRR%iKy&SP!#w&%|VS{nr0$(_bJ=99vaw>=~w zPG;PbxvSZMSom~X^U)uAT{VNZf>l3Oh%nkWoD?PGMBH(AkK`wY{X;8Pk&nW?B6FAnOLj@dJBjLner9|Ax=z0qxQ$- zo|R6zX?d9m(J&?Y=K5*IWHeAH>_fFQiuda?g;zE3?31b3+zi~`@Z9|O8yp@GN5W&o zrrZn))7&n1(kUT3&HV%X^v)>dnJGBICe&RA=C?WsIRD-UCZle`2kkM8r4ezem}G+E zi}~8Jky@?Xy#*MJ=xZMJ+mF@R(NPS$QXSZ3w zhWJ5uamL9)Bepopx=b z$FP|@_wjGU{2nS$UcjzP_HvO)6WB9)C;uFy6u)crbz^R{R5j_2w@8d03MX#z4)?w4 zK}$9_*t$b8IwnTb4Frl;%CO8Y3Rjm8es%@xm%EA9T&UkGRJulRF|8$s&)%`GW&cLKih*lkb#1d%XQq*iKjA17k+ zp+H6M$^StUw@CL$`qi$#Ovq{|L1JG`RX9^*&!KC1st$6=h?Z1H!kTBYUcOU!%(EB#Bd=WIK5Eb9b>T(6(~zTk z`w@$p_GuG3SHhc8A>};WiXDDc@FDFixgO_`z7jHaV;mB-CbiCHOl;FAvz07G_nrUj zFIdFAz^sXVX?#{ZzYk*rg>svT1*<_pQk%15h0((R-y)d+1tFJVmJynx2)!_0p=6S6 zABtfV>r#;BOBba5d4&~H-fl^EElK2A9X!DuAjp`FF5T@9Xf>s@i;?ez2z0rX5-hsJ z<2-=*4;GkJEk&Ps^%p0jsOw&Pj|^{h@XYB^bn|HGpve{Kr&X1CS1kK;2)VM?L?%v4 z5F0o7F$opRXT=+;fhYJNz+I1tFy+{4#O=K!32e0yF>6e4=JMR~+k7$-i3hVF)%gsBk3F}>GnUGZ?R`m0g4k2DxPNhEIY7u=Sj zeS`Y#&-mIToah5jA|_=sZGeAxrf2;-_nkOg#SD`gVff?Sq#lomkLN|^{0ding|{B| zZlLVS!6i?3sx2Mrm?gOOY92oBx#N}csh4N>cysCr!$@~ZLw7zokKs0;)hI?JaA=Xd zL^f16;T#!$nB$g1?UAoGnK=7*OH_SV!O_C!aR6`clQG<3;OaVSYqX{h+>||B zLO62h3M!!CBxF-zYl&^NX%xX>ywI*G(~wJhv@u8LK}!uZhS+z6V**a*L}e#piKZ?#R^p<2&G#!bpZhG*sSe188RE(S~pc>{5fgz$m? zCj)V1(AtdZsmicHA5_$w!A!*v1jdtyha___Ha)RZkz5gt*4E)L?7+G;eOtb{M_7bQ z1@AsVG(1nXtGVqSJ1gJb?51$fa!sIfpKA;LwpO032K^n#Kya*H1$*YpT{~RQPTF+4 zYl;}yxo$5D{HZTd%uE$bX@h~BAk4xj~65hQqJl>s`Tfl2M_M{B?@@%1YL8UZa4#bGbHOsQK(pVwaZI}Ly zs~B7)h&Y7@L~K42+tTpr>h*$UI3Tw+T>Pjd6tE4qu#u+&iIojB!u1N_4;ezN#U>-$ z?v?5YsHv zdPY`a>Nz}Cx=RF#fJ%a4QrQ^i{BDKNcAX^;HuUrxIE>^Y-RV`l~y!yms z7K02!%uNcOY8Xt?LPWdfW{18h>=m9SN@Ibb@GpyIBoI29IX2TMY!RCY?%`(c0rh*9 zn~Y2_N(Qf&f!RoP5MC=+*lZ5CB9Y`2(F_27tJRMQ;ws|2_}#hj8e%>=Gx3nNyZ zbl6Bch{{de6atT+OWP~Cc#$c!dVpjBk-<16P_D10R03@$KDe8?BglH{->>=+SAhpY zxV_4ihgshy&>mf++>c4dRnUQMM4Bxi!CG+OUoBnCgobMFMl>1PCxTyalN5F?Si4d( zJ*mMme&6DL7xTj?xILwpPS{>?RX2Od2eb$@t%Cq8C_Pc-@@UGb2}j9aMLr&)Ty`cf z>x)j04ejFbF)KNDemgogt?D@`Wv&r@WfPScuEy_A0SJD3S+Asbg(4j|#E=36#t)>I zy5x))UQBY!Ge3&q7ODn*hW4t0f%ee9e9{9o{YjL^)-8mOQ90ZvJcG`OsEq3zq1SnI z9?cKcpqOAhZ-0)C$7(}{S9G}h-EjBxnnXn5`fqrjuW-2tpV8%@LZ+E%g|vQwS8UTw z8fXriy{-W!1#(csYj1wsn{&Sc8*oS|HvzWQ^bS=?18ggm4H)Hfofm|p`>n_2WrMjN| zeV%lKDw_1H;Sxto?NP?%=%iJ1`Kt~}FcU*H-KqWP&C8Xi+sm~nw@xQP#X&@C{@ItlrW$- z5XPWw){MB?O=gqgppm0|VRE}*v8aBVbf+NWG=q9R5V6eQN}>9FD_>d^7&EMCx={)C z^O?)hI@Ii}A6hal5d8hxt(1Btq)#y+;*H7-M-@5JK#hv&tDuq=jiVs53Tm6(%@7>9 z{a%8dT#f0V!$voyqq4`tRX<`*m=~#-)zZR^(SvQfFWgqkjX}hGj-u78Y~$C)8cWUG zwiH7qUa_q|5^n7(OuS?Ro5}>l_u|c^sNvPXn}a?_mFtiL^4wP`$#Y25#S*nX6#Lf*Cx$Fi#@*c z+CW`wa*`QGztFo6EuO)<4-an{ThdDpui42zW&StJWT#!8u6fO-6KCiS2CWH)a9p{+ zMTVL5n#1c*@S@vauUL3L^q`owX0r~>@0e7{;>e+$LjAYBhjU5=3ru^G!Db|$_hh)@X6_cU zWUSVW{|DdXl8(hvQa;IKEx}%O#m{&Fa}~j+mEHERR2;N7#Yz?ERVKZg7C^#M3KX1! z-u`n748(|ZZIMAUyhsTu47y_xHRHmWZP^|mfi8o!BSIW&45SZ^x12ad&TMo7$+_|t zEgz$l)fm+*Eh&$hg4tR?HeE7O&2c4V+P-Hk(G)MKYphd)p2SlGC zDjxRR*MqO+zvI?|9?}cXZd*XM>mie_!EV_?L9!W|38UTd#@F!Hyom3VmX*tu(hywV zV7A4}3`$ZBcP(k=1k|oy@*15=Ky^$4xWGW1UVwG0kCpkw5~1mo1AUDT&LHkoJcuhI zx#t%DnsM}$gVTN^Wvm=%fv5pb0p*|$6~4{navDONhUfFZotjXmVe@qbN6wJ0pvBYC z73v@_qYNnwb=qFS(;j*eTBq$)4?*>9z7b9~OWjX}t%Qq6b(kfi4yg`xdKC;we~7Qo z@Pkh*ZF>XEt95_=aCQCR4J8x?YyRCbI4)`Gwt@YNKEa9!9^xlwsxzkVWglQ%Zqx-J zotQ&f?0pr4dWI9-tv9OkES~#&Z^hI3vu$x6&>5$zDu(jZtvbGEclY{2<279>% zfA}9lg5>%MScu?VK>5zSlW_{0E4E{}EBF>00?vhM3xt(ykTUm2!QF43B-rusMf~|qlp#tv^&knB3<4T2UUm)Q_Ll9?<`$G)MtzGR#|rCJOVBMqw@pbG%`YyppR`Kcx9F8% z15h62ZX@F!IK1I-ZqyL`^W2NmbUqs_Xp9>p@=}3b&Hz+ucbm+-Ol3RRK>CGt7G{W$ zCiY3z07!?6FxN+UN@D;*6TgND5Nj2gpL^=H(^1{VqXHzA=+1d$O{Q#=M@UICfon2@ z@CC}`MzTfo8#}^7XIT-5zDs=lQ*=k-xeDM{kIE_N@%Y`V zPWW&ZsL@(Np)>na;Z7un=lcN7|BfW8J|^F4u@jG^t$uNFmM!jBK&Js5-m1%R*sW1O z16+?s9ud}SauWlAWB#%N_M*Zl9EIT9fVX;hBX?5D(E~e_jGWy5QW1trU0#d#@ODY%RHfUrS9RcW%?$PWuhiPhX-9f)WQg_>7r_AN~ zB%8CFqXVVUb;ZFx`;qhJK=C%?qrX<>FX%|_@>)hIn*EM)qz>XHf*hMx&EYXE4hOOD z+dPgVr*TvR?s6BADw%ZAZg;QdvUCBK`2hn=(G?9B9=dt1?Il&s9>@>cyXDzS9??f0 zsqtzaht2^^(ArUXt5mJ-;N zMFB|J1<|Do0taP!&(JH|HXiW|mW~cP>3$A(qJH5j=EaJY*i{IMkSEF|f|kr3L{=EsrNuE&ZzMZP{_J*6 z|CI6Rh|EetQ#jAt6Slt~*fYL;Q7bEYJBEfJ9*D2%Q7-|sU=c-lYY}IU!k~U(abDe; zyaJM2L&`9cAiqTt&Z(iKmdPJVHz$T0GuJn82@xUbc=77-5}wRiA_gZ#u?W|Hkq5az zddHj0Lp7yD*bGy*%`@68sT7LM;yDGFc%yv`Cptkxh5YDX@P?JV#YL+xEmp_NWq9=D z2OZ1(oMFXTE}?M)vo~oclVD`#!E)4*Gi%lI=RV^q~9o( z+wC&VS1fvGJS`c$NHZLFqnyqTJ?$bFqi97SNJpNo<2lA197gB^@`qJN)-@TNfQ9)i z*O*^6U;&h$e^Ja;d72qO9NHq5dJ`6)?VrEF#|4w4clSI?FdUuhVi$a@hq*SgIFu&7 z-7*ZuHMy31QW$2Lx_a*@B_JX#?qdk^q~6leTu*KyF@>dW6r6CqrKdF5IzO31!mWD9 z`vwcvSVZpPPizqYQE7VK)0uJ+5g7&~-Qi#w#>&crbf-uJcf7cTSA8Rg-7rk^i$h?f zJ7v}!WSQ(KAt!V7&L{_mh6)~jCzB-E|8vUEA;C6-vcYrKSQE5)4c&GsQ$NO`Y|OqK zDared!96(r_~f~bw}fCiKwYU&vQw&V;$gbRzn7jCg&PhWW=ztZdB(+2|2IsXDXAY} zCoY~F_G}|8@ zMak=~juvuxOq!8$$1jYHFy07bG)5YHG}%li0&Z}w{cmagD_RZBcI4~i`F@-!9wUg1 z%@E|-CnOUj)TlAe4}BtV8>EN-E$DHlV$~2mB3~!dr76ul=VlOoy<-QaZ1U;4`h!V>Qj z%@S&>CoH4Dq|*jz75N+l`;lVZ5W(UAlBu?U!3MEy%RGLckunn7v<%2ii!J$M9om=U z&F#^`{4jTE;#0|mH);FEy?FUdy@8K2WN%;~GWyVkdjsD+#Jm=|d~e{psV?GQ`3$!P#?5W$k(T#MnXoZko6Zu-gf8M6 zz(6pkOL@P!TFk<6^zGe!K4e3)CqH4g@I8K9XeBf2MVCf|hk%Qo4f+okYuQ8AII{6% zOP#1W$!`Oz!B~~^0G1=5NeGj8rMKF>CQmHf9g;bxd=o^o-?eBPG5;dBG`BUi51* z=ppmIPwj5T!+@A__4C;nV%rm6ioTqxu3i>_&vw!X`JAQRmuEjSeYXjT`Cx!+gISyg_U_WAYASPD`F`jC(Ptl>QpC zSHCWL8dcAC@yBEo;m#Nrhboh6_PHwR)%CW5^_>q|pUXA#1R@-|iWCkP25fstip>Gm zBYpNR&jX`AE}>?R#V~=eCO!z(E{W1hYA_du;1EelCo6;Iyp!qXrba#zaBj%z*JP&W zZ{yvGAFrwJqgauaAuK`A`)`>h-puuUjkzFYhe1}_-leCBd=U`IeZ%Cg4VVh)&T&S} znPpFxlBxWc+*s|tz1iI8y_vD05Eynqel64~A+8R^61PoQfV>UtJ#f1$Ku2#Mmh=?G z!w@ucdUSs6r_-ah-hK4Gk>N&B3U%sH+DACu`L9eIN9}8*q;YB+WctYkWA1aJgLHM+ zS1nB<-Gs&L*>o<*`{dMiTDKVR6gpT;7AhV}?Q0~}k2vW|>^R;Kh=q^>glP%;z z(Rv`mA4?@HR7WXXA%)(&2wdsXV=aS9x>FAFj;GY}F*Q%w83^A(9LgxEjVywiUF?zp zH~2w&?6TD`o~&`0DT$a}#I~?Db2xCx(HxE{%1nb(1nPU7CTmJvyhVn45cy5b#LH zJl;?p-j3h2O~{#$3N5 z;x-o!A91l+#4Kf5amB*Ky^@dJ<&N#u?eHR*4$bzMgSFQgHu%-`@b-;%?e!2x=$Sv`-kh=*nhmtLn_`Xd8k4$2#D6+D;$COC zC|*$)@mY@InRexO+~6h~LVf>QLP43=cu;GWWzBhxpohh|{aeUr&xX zHKE)5hG;(AGdZ((-GN(H)MfJt&+;(Q0_;^wNU{v-GB9feuU-UKdnkdrao0I|PCOP! z3K$nQB+miq=HA92k>dfl3a`!u8Bu-iIj=DY^4+M3%X(4%unx=-UR7a_!p*>b`7iIuHZ(oLCNjD})zzIs;7 zW6Rpn5cGdvZW(U+m{*Y@t~-BKqMO{b5sm@9bA`q8Sd(XrWecN~@n!jJ^)UILEW0ZF z?C#E$B6W@p)hWPY6Sh`e?7Zr}v);bihw}R;t7MfowO1L;;+a8(-w>h;bThhJPDJJ2pXJGMvG;7~6Qm~0&O zJc7I&I$AOpOKF=DbTB_!7?a|RkfBM#wkXO(%sVzVj)^c!N(0jzc3NB7oTG<5y-GxN z=hLBaLJwG<4*i|r)A9IuLO>Vz=5R5#&bLyFGg4-wI0jvIQ=z}t&R{S)Y1=sPl+DY?r0Xe!qMXCT;YUqmNA9g zD8fyGHFhRL9uwgv*G+MQcOM5lx1kAblmaaiet>htky$dd&<$R=Gr?!ku`P?JbRRej zi_S2f4yHThg2UOKl-sAW>mB2ESQm-cGm&Ep)7V|>FUwE9fG?90mgTiCkR_-bmD&G? zQpU?t3uGFeI?K`ween4f;n<=ywKwq)V@uN1Hh)1nYK0c07SCWohQ^b$98H7Q^86(& zM$_O1m@g)~OxI-xxh{T6iI?duGN`1b7{XhMsi;pYbtzU1? z9$Gg{eU8XYQp%)Fq@uE_Qd^KMcSq6WJ-b>90TGQ3DX2?}=J_zi&^prc5Ql_uSz%?I zLIIC9xTr(WkX^VbuBN-1zuPZ-)%aPz+EYjXM_SDu>Ip(z4np#iynK7uJAp&$j4od&CjXZ$#a^9s z;ty+o36+?CdtP;}rs7+OxfaRfE$=woWR^}|!DhOv8Mvi7On16PUoD4MeYIRFR>`D# z&F0By*4(}z2qPR}B}$t}6p}Es6||pnfyD|1RT7-(wOoLSNEl)8?VY+A`op)Q49>em zYw@zdHQ;^jT852;QVF%PL53V3aJd`#QDohO0fR@*L4rj4{P0xC za14DHyY@1ZtQWg~O`@m$@m5&@$@P$9p@`zC0g|%h?F&X#je=tA5L6Uqe#j7^)lS-D z3?lo1j!o304q6+&^XyryqwNXg=DFjJ~_6R%Q=69}l2 zFA{PjZHm#>@m-fZM%sk8gYY`(Ka5B-p^VbHEC>Ux-p3et%shnJE!pBAW#Rg$BB&qx z)nI7J&hS!h=`pY0QUF1?C?vNq(w%3@jOzk@m{-!2;>APVn2&Jr#PRa4*~a8G4&p|F zL|T~W<{^YuY#1%TUb~@GEC%<;_fG#MAbyi0vvFL+EClE8uzjU!c+yA5fVN#l-uR&< zO8lL4$3`x+nL`jA4ox$%V`597EZiGQ$Ww@CTuzfP#n_lp+9M|7)Yv$FuGO?|^pp?< zTfX$q5+wrJdQs5#E6zLzuQ~)=prUrB2cch(p#tviTZgE(&V zAK=i58U_VCj5zjEq&+wfs(6Q~0HRQ?Yd;YHnx|2i?@bLHs`2a?jOF zpaBZHbW6+2XK_D6^!xUfmshx+gwncPt#BZZ^1EB~fHjsqw7G)wn+XU;(VVmg)L>e3 zwo3;Yz*k)L2yS!m!J{o2@o@w%4p8#QtV>?TXbmAF z8r=)cUhuJP=v|e4W+){7d+QjfE!e>|v%TNhL~ZC-dmBlB3owJQ$CQTqOltD_~35 zPBJHOe2kl{ttdvJ+o7o)(GZ30SMOrZk-`n6>ZI@6>lJU?c`3>=>-KRO6lK#*k9LES z4c2}@60r9tS#Fsft(lfIqAvP)VC70+8)DIbG?!6&YeO{j7oV61pg#FRvSg^s)j{ z7fZqlo4w=>?lujJi3m>gr7v%A!DjuMzI=sVP@%z5*Fe4_6M;qR7KauB9-3p5U8%0g z?XC&zR{0$5jMy5+y}{k>nqc%7gQj*0W-qz7<+MR2B(Mv2L6ID31oyXy-fLp>nNQ8) zC)us5e`G}s=@Nk=#2ras*>1hX@0e9M**IhC?w$k5fWP%iB(E3$oCBjm71D{w8tlH9 zy|nLR=Iy=I4#KGcQCL9_Uac^fxifJ!H-gJw@RL)e5p0-PSj~nW{xO)+eds{uBbx4f z9b@KBWoP^Y6MU+3jVA+qnD1wZo)qw_DcmyF7={q2VS|3PI{}`>s6k#7rWXr(G&U4$ z5qXyKbfVp=6Jg88BGnxq8Ufa(Dg;I2p@O2aG7RKGj^xRqA6(9(Hf>NwYx3mXTxgUW zQ+T9Bb*e(uiUm?nboKpz_Pzy9?xM*5x0__LYJ`PAviKYcV1lsOEFlDgnq-rZXcCre zfM~>Jc6WAn$nMNIGn-^l6h%CI;|ozy(K`Vjc=$l^&BF)c$)TQt=L_W&PR_q?<-Ak= z-|DXF*RN-0v%3U7pZ}lFha}U#>gww1>gww1>gp=IvuA8VZD+=jO}4c#jthV^-Avo6 zC75JTXf(@uU(V~MD&JZvm6a7oCX8(o6L%ev&Cq@ zBHlh!(=R_H(}*U|-F9}fB}bD(jEc-aMFl0m^srsj4j}c!!tZQpC68Q}MKQVgK;8nri{L;^7Wm zC;9C>2Hwo$X{VtFhwTxXfixtaF$1sm)j3&gAcabGVaOn{i`aAG^u)s_%{ddr=pdo( zN8FM#TT(Ef%lcEKBB&HcUj2`o^z^*eg`o4n7w|MXy(DFAPv6aDy%TEv@6q$S{V6ZBu$w6SMTC{K zJ-XOo4hev4MOPQuRX1e9fqiL+q%nq#`FlmgY#E}l!6X4=uri=`)K_*5W;sub56-t*xQy|HGf!8hVUFZ18zj z*Gzon`-=>Ax|S%5*pP(KBvX16Ol)kF->G^+m|8_oJ5jqWlTXj#byHa4ceYb6>@+B{ z?gV0HAY{#NVo$4t@OG(l&4QD*vPmr#;Ss#q(+hvR(nnjk17hVGCUy=&^V7Bw97Ae! zi18a_^GFxH+Wv_*h?ae(hU_vAJ03V{II+)HmXE>m?E6W+*I%o}lcw#pV% zo7pBkda@{1QP751B{&prcz!xId8HsmHhRi)*=7oeN))u4u1ZjXd0{KnxZoFRQ=Jxo z0d94XzP~D>-RX?sxgo=(?svBE*vc>o#Q`p!P3LOIdGb%Eb2YJpWWiO{^t`pcV)yhn z`PxRVDw!>oyOM)CKMhh&QFKy5N1$zKOPtKHaiEDx52Dqu@19$Ox zfhLWF1Lht%cj#}?ck*}K0rf3D05m$&{-d4)Y8vf`4@48{>&-Y_!u{stG{+_m7kBWL zph(rgTUT5bj|@nD*b~Uc%h&_q_iL)?thF}({`2)pIsZ_0W(P~mR8a~+)?V-Qq+5hJ zJeTi2T{+*Cb2~YUX|T4uI%o7?psvhBR^C8WRjYl{ne)%)rGG12>3!mqcSC8h8u4=i z?fIPyJVc&;zV2%7IXH?|wG<;&4K3eZveQa|52`a4O+xa{77Gt)sRo66(USM{Od~p>Vh@Ndt~-umTj3bAv-2wL-j9 zXDeT3662C%z@TiES5zF+`gFFZm8+}Ie^Ub=L=(S$J62+{6x>bkpCM|0teT%v_x#SkNQOYMeS~lP3A<8t$C5B(b^;IOB*z^4U`Z=8Q7yL*}@Z-oP*+ ze_R-NfSRyKv&0F)@l}G0Od53KX+t>@24E_xJtP>U!&Va+6dkT#z?EZp9=wq>Ly==5 zVGt8@4~1`GU0mXcrgl=2zbvE9BtI;a$6Y@TG&>%wF+lq_fr~CAe8F_xpfs?BGTli$qiQeVrc^@d$SU$ zCAZBzF;U{CjSREAVP=c|4%KlK;k=57zo?e18*q1?(&(COtviH()uYd(5zBWU zw-J9qg_eKnTZqB$ShF_L5rBdh%C1dVlBspm0w$J75@q@3Zg0~GmV4$)oUK8n{Z-9Y z8(yb%1NsUx6v08-+M7T3u>lEvYO|@oqEGs#+GizZpT!%`xn|?plfw}u^|PMc=VJXI zCM{@~*kzjK7829K4rD`65luFwnvMR|B4O&+YP#<#aV>q*`|ol!KQUC&CZ=v^3i)dT z977XjNrIS*n9XCB#@O$Q=!T*37JrRmE7 zR%}mQ96+Qaq+9|WQ*I#gy=W)U3--nNXCc5npS5mhT^G<0kfK%d=x4}Ci&7d5+1Q8o zQYmCqllG@Nr1?-&CXejVy0rN?rDg5!^Lx*b%lL$3;rtg~!altquDfBi;(pEcIvhv@ z>7p>$xtrU^m1%*ofjf6H)}|Y$u-RU4T{Hds$+$dNh$E&d4>aE3`2u$PMHTZJJR5xly*bnw1Q??eSaO|JfJB%Q+q3g5?-*U?Z<*sU!uF6 zVf9(bjZkbb)R!o;kgr~wLRhefNejI>#5q$!X1(xj(C^Bc1$5*7!Lf-d#YeX;nJWjl znRD`mkx^Re=Sd2MkOUvSbRnR@rBl-Z25CBibzHrV4JjDmG$=L&$j0K3t^sOn2s}y| zIf|cV=F+b)lmeqjTfqUO?LIdIN2${DO1hp)!5op8&mE}s$rq@MuU6I>m)jp97ape zVEIapjIpJdJswxX)?{J5V$3MmnKOrhq3L~`x-nFh=ud6&wwL76^dZ={=yPKg1+RiJ z7wXe~b((BTpZN+sRH2IK%UAZQpmDt1Qcd2D!*K%R+(oQAvX#S+sG|TZ!XdDKaLLUvH=^1jq^Bx2bU?JH}8JijWRlUs?!hsM6ET zmE@W_1n_6HuAUtgCvDhHfF+fO#<+d!J16h`3SZocI42+fD$O1zyHR%jB~r$@XiS0l zdAcB`UFLZbDWwZHt4(Q@LM_*;3^yoWD~arJQx%&ulx#L7+AoTtUQ>in@4-E$@-8XY zE+yYxi#bB49sk8_j<^^ZqKms4@h1wztUC`a=RD`3DV~w@P^jj9#XW@#bRv&w+%3pJ z)A0e`B*G$6pnQPR!MG1Fph-LYxKQSS@7;^9X3$>Hf&RQ!`hhmiPkpsad|*~?|G+m_ zziN8xOf5k`+g|b_)=G!^t>Qborf_;nv%c=lsT5?5>5O-AhYd#|jnh2>?C9M8HtbxT zO6b-mbRu|6`SgF#d`cegcZpg`+W)4{f)2m$2E9btC8;(D9iFB2e#NRaSy(F0uW|_& z_A0n>sttnGYqDdd!99Kn9#2Az-Q6||PaY`^O$8nFr>>)~$(9FILr_O+vXmXrG+Qm1 ze^&B?d2C9CkhFnoRe%s}kTO?Lt5#+&bSS~mA~i2PFf@DR;Ppk6xrvA+-pTs}8P#Ew zw3-rwfCR-H0hx}YwB3}d&ZDH`FPE~eHE?JiANH4C%O4C{{o$qZ0goRYWZoq&dyS^) zJe#Pw)iF{I#`sZ;F|`90nP-ABBr7PeOfQqQW!_GagpwU*sH$|2?+NCo5gn9f%@{f2 zgYu=BZ5(k&eAhx_q`}Et4TjJems+C;iV}7E6AS7H_m>m9UK{g|4-;>H9S?nEy?#Kx zIfsc0-oWs3m}m+_CqD|->xR5|6AOFlFqe6C#symKItPdi@jdbNnj?0pZwL;Vn&m@7 zI|AOiZ;Ge0?lXbTbm6T(x zQfVU|uC?leZ(=>;tyOcD+~0cQW&FiktmZ8Fv-yJ6>L7E^tX6kA4?WVnfcd)BR?PWHs;{0%j`*ytbKJ-9hsGK$SghV@vzxf&woo? zX0L7enS2Rk_G9J?WaS`p&&cd$EmkJyC^`a}&A8tKAG(q(bjip z;b#{oFx}LIf=CrO3nM%*uF`P$)zy8vf{fXCIVWpM9d972StaP;S$p<7gfFIjwGaki zZMd?wPuYRjafNW?g9?H-q|pac-jn3tr$mE>rQJDLPCF`0BpHX)^@{<@JBvNxYu~B6 zr_%nQphEX3mGohp)6K7_(l1 za66XdGDAU|87fXm;dtjWWqnhoWA{sW6H?6QhpNON$|-}|bx+XT_Jzip0rY7KqEmKwlN-6IOk=piLzy$^n(hU+>+=C~Ycag9 zI|VEY-mQ5Oa!#$&sIMivn%ux}p%jF0qcW=l%Y}3i(DAZkUVT)N*6p#m*kR_PYvy#B zc|^-O#ACHwIwZwFlS)0_h*OHN+yo1l9NXap3A-X)4(ufb=H!N84(Z{<%WGPx`Q48; zRS(BCSLz{&wdmuno3>qssj7=Euz_81i|Bo^o3gcx5*Z<)B#saZX4@NeAcsTYA; ztrZ6MOu{N-c7q~X)RH~De7>v+YM0~ca7@Gcf91Z1haFy2waWfQ%SWR_kGeJ9Cu$?c z-INvPvgSiFFm(4|x7uc|P9!s8%E}qY(H;i}h2Rb@ik)_qjH*$HN{9k5+*sK+no|MH zMh}2c@YH193V9e{kcP-<%(-E~sP_))RVr(Daqt`aq+qN{xKK%XJIVIdLl;TlppUa% z=&y6;ShF`BF+Ei=J!ll`D3)SB!d(q;Q}>PT}i7bY0KBY4FBZe#H4 zXIKB``(-#Djnws~Cbne@&F{~AKvSO?B!g?UTr1W$g4fC=BsNJmOKN~{ye&>`Q+2^9 ztqg2~j}EewLNVFAhKrmZzun}=A11AB(;-#(RAmK!BKTg|8O~ZU;9B8=D^8& zW9wuGhmiyhv#*#ha8w;+?iq*KRgRN46HYCA8HV&J<s}^t8@NhnXmTj& zYVig~lY6dZ>4+RnzD2${N0VRu5W~ySq$!XSp-1h}q{oqCuF?HS9Z-5uqN$r6Q+l;- zW4<*ztn@0;>VTB`$}};qg&DnRXGg|6vNXlBcVy{xM0!7kgG;a8-&wMzaD3_2D&-au8Jc5KFY)zi} z5#6D15AJ}#5ko6EdYYK`mM&0s?_1u;s{kJJqJp~j*BxxqV08cEJjJ88zqKM57?IjVr0vF^ zGJ^QM*C`+X*?|zLrTvtTX~I(X-vSa6F){1xnaHxvswg!uhhpiQZH)+j*6aZ>G&eIP z@gB|`KPGX&0K!QV$?OKy1ZfumlR4iZ`_m-Y`756lIaLuIUO&XqgWCPiA_xAqPyuO6 zCApnpLWShQU^b8E_Umn??-avAIHc|()jNZ7(MVIFDpfGbusWL$5<_Cx5#O6D76x&u zmB2+8qb5``VYPFv*Zc^KLe)N9exu_~^tDXkrpf7i@h(K_LEpd_BRLop+?f-3c)p1+qpzYRyWA9~XXHrbe))I56L}!zQUS;-OMboufXf@isFk zohn_kZcf?}@ytn6JbUJ((+%nQ6pTry))tngDVUN@t?~gIlK&%8D?*AXJ}L~Ef+6WN zE+j|HNC!%U$1@_W;=#fUg>#N}&11Fne8rB+@!&dd5TUjDTsbNG^mUiZ`Maw=-S61( z?%AvST0dn-r=?LBQZTu)p5UV98_c5+s6Uf*uhe!^swx$r`tSR>67}K=KE~RROuy%m?P`I(10zSmmjKaYm zc$pvf8JY2BPy&bp^JE8=1-(OnvYnA@fu-m5X#xTWOc&e$94*mpMw8h(qYQP7j2IlM zphur3;LP^P|DabHBnsDt{m#53*U#OpHV57c4`A1t!@ixgQ2^B& zi?A8Metg_4Lz}@zl{XMa>E}@IiBm%p|GFIkmHKn*mm7*P(2XLKWVbrbm_U$2qHtXd=d% zJCBup$|N^0m>~WO?*gpT@40jsUF1A$veZ0mqMrN0WDr_azt+C-^HyAF5H}lng8UF4 zdQFrIJ$7cMr8&{oIR-~fbjWDoeB74K579-%a%2*Cy$-m+V{{$U zvS9H3*PP^L28b5P7U0n0;E)DfemFxL1a zwQl6iCI;pF>N zK82PE^JIJM{bZaOt>_BAKh}PKZ1VWiPE=kN^}z4fALQvPTyVtJX;wPz2(B`zD(aDY ztZi_^u;l{rmGB6scMkLuZ_*5OTFQG5maz_d6T>-eM&U@;VS-^O?bIfoWTt0U7A9y?WfIJQ>(zWipriK)|7+G2bIR0 zSzO5v6>#&jCfItvqPy!%;1C3>G9F-{t{9wwOtbfXRZ|&rl_g)}Z;q?%$gfKoCvz|b;)Qq=xXSAC;d&kuXV?sn&gBdt z&S`61JSQ+`tV^seXxFT}!Ys!>Tl?dIeN}~g9oCj-fOm5F$c-&H2YA8DpN@iI+Tp(s@N}5 zYgeaRvmZCpp-y!VDO6e7Gi4QTX%g9Gs(T9MbNT>cT|SDW)uMtOk}PIv*1gU-K1Kv} zEEY4==14Sm{+l@tt#Ti&X>?DzoyEimCj19e3*2-8FJUy6hs$wEHD4*_#yU6A%{sM7 z=y7(44{;4UjLm95!j6Xrz_Wd2Gh~_A42!fIqf~7y^Fu7r@Bd~fXco5*2?OCAti>b; zX=A)zB|&cq=^UVQ|BinNo7LrOA=?!-#f+O_R6Uy8e%FN@A5Bh(tnrqREu=Tmc0W2) z+L)`1P41`SY+ZnGmZdfkMgK=#xkih==;Z+Id(upi0kfd`36odDXRG0|rK;w+{#!?q%q53&+Mosb(Wd5EXE(=`Wb;9oV- zPPce($OHFv2C#Zey{QMooB^;V!HK?q5-+S#bMo?82KmKC@-;fSRxg8^a7g|TdQctm z;siLcea;i6J?iQLMiP(x$g8;yscI1E^>C8lO~{q0t$~etW8EllreV#>otkS+jSmoJ zGQ~rSMmB-+fHt<8_L$jue=m{e^|TGB64#iu%;VJa8oX_8H!RnEN0Xl6Y&PGK-(*Jw zXZwGWZ_bA0tbgPBa<*>@#DaVjY*-GQL7Vyg^m_9E%uVDGOYCUehZ5Yuk|*PxP0xYT z^33mQ7Tev>f#aC{ZIT^lZ<}O_r?X8u@O}wzy#3RGqj?WYvA3~0a5Q%!%BazftM)xR z*(m1@9$A}nt(3`pp&i#;VWYR>I&gxdU*1+M)DlLJFPdXLxoz z%NO^aQ5>X?P_=k%g38KPp{m_uS3JvCcBk6Vfd zoa*Bejx-cnE<{TYHKed^HSj4g02q{v0C^V4i8P(1TQw^m*;_R$>)fi5a`5y1hcgY$ zJ$Lgw4Q|!k-7@+E{u11(xyO9LygA6+Gq-Bo**I6x5u~AMv-5lI>!?@5~+WH>(5(v#(%ohySLFS$jn%_FPi{>dh0-6;+n40lKl6d- zuNk}DJ3CO=)v1)1#+DBQ7M#tGQ%!KjSDtb%t39&d%-D~0-{PU_E@XOxS*8a+%WUf7-CgG<n__wo~hMC{K4skPlnK`v!Vcdsbb&gkygT|**!36TVt@5#a+UwQsjeB6rWN1kcw$j zsj?otBzJ+nJ)%#f^QGa?##3pJ>)EG&p$c?jfShKSm?V9auMxq;A#;#1m3 z`mX)Is6zZP;u9B?2JLbvRL^LZ<6?xNv?o}2ZzE<+7i;sL8KS6fi_T=|4ME8F5`uI*tgMj|4s35oZ=>d1ZX|P2qu?Fov_dwr=k#|`forjoA zI!~;Q=Jw=?s?r3#bPj#*oi5geD*cBZEv05VH^6{FIQY@8HAi>SH+QP&ohJih#OM8@ z(TIo8;84UvcoWk>Y(Xp*nx#{Z>4+Wek$j0&_k!ZpXsrcC_kpXfC^zft_V(L!pw~`b~W!)xFs?FiDRRCZFES+;OU?JTEHCk_uY-!cN0)V@oO! zjHJ4LFSp8E^a=psH|yl#@#mjkry3Q&jdVqZ@U5o}gvsMQic}O(K zr|N;EpT+!MJ)gPM`3P^s1!~r`ZN^I0g zU>3jF4D{}mDuFUh&703LrT*Ar>LLq|uG;L>!3{KpnX?8$dS^z zeYr`SI(GTn>Y!A8le?SuMo8qK6ZO2(shn&t)de>w`-|^s)RdQXZMYt2n9S>$?=v`& ziz+_KKj3F8Q^e(+n1(-H+Ni@XgE)MZ=0bya&-T^nS3bj$yv7M#lXRl7r&S+56DG`hk$+AZRN*v1FasOE4 zJ8if4IQUXI$91YZgPJ}a{V1Pty1k2Si9aTrUI($`#5hL$1kUI5hW(rflDdZ3+u0y; zDPtStF0r?q*2Kd3P~@9q8tt>6cdvBxtclwCiCA3DrXXj}@Lj6}&%asc%zs;JVD}2g zRXmltAGdWeS9DN8SkD+sUaObA-pCwVjR#VDldWC9-Lc$A)oXLf8*H1-<2NaSQx$(| zn{%D%%_|n27FSqzbn}Xzuodfe&{%z5C!h01+es&#R@h{`@}F(9ySqJtwJM~RIF|j5 zPCJgTSiF7?E)*y8}-Ofp(4myF4y3<6I-uruAlA@d8 z#&zR+y?3+uk(kZ7ZC3d-D9@Skna4Kk4dGAzgC^L9xMQX5q~Ws`hZ#&K%6;jXx}F4$ zeC>Yz9SIuwmp}41CurnXf08neayJEX2>$2@8mY^Qw=&~&*a6}acQ<0(|1b-@0FJu2 zyJkJ2-E!9p)iA}=4ArRH1LB$TY;`KHVU-(IwK?j1yYZ>=L~^4~`Mx=o=?*lAXv}->k`& z#)jzBO`o%g{GDJe5Yyr^D8ZNiMOYluYqQr*+WV-|IEf<5Fwx|Be4wmVJsep&&bbec z#Ud>KXFMph`sMU^0QqB0Lf%ZZJf^N$wm;>+S)<_6_s-Iuyn5dlpdBWhv__>U$(qo0 zAjj|3<~J^UR!D)_E5oc=G z2iZz~_;;QJ2*4fCuP&N{Tnfsivi{QWa5b;ayp34PC#5Wb$i`sHm+@SMu6-;Wc?Yv- zkb_S{$~V@!W6gKl^^kgi?o+Ev^hMmcvY;5+n{zXQzt$xiq@ayip%((H8VZ_-Z zt0z4*(XWlZwdS+d&7{2wgUZ<4Y(9}rc0O3cQP*Mi?h^K92%ZbeQdpno4qt?c4P=bi zrljlL!Zstqb7m}Ej9hKICRH+w7tiIv0eiu2`#d4+-?1Dm^VxR_NR`r8AnqH5o1Z?9 z>miXsnNG)G4@_pb%wZd?>cS$+H>h`0TAy)DtuUglCem<5DO<0NGK8}HN(tU|%@>gz zCaWA!)!O7(K3i`V>ds?12T*?v+b+Z?idALr%xZk-xt)os1~KhEHbR{U7o3KSSCw3Y zqyQ$uJ3F9b0*jl4dffiNNA$ zlI}wiu_oAV(-7Y`pJ$!ZH`l$2c6sk(w z!{qEVOj>xb-DkyHEe!}g=IW3b;pV!spjh#{7|!P3~ocoAhc+OmD4Q0mn(UE8H? zsUb{v55^ygZ??sya=u80n%YF(V#~GFt8G9qy!BhcaK%E{-#~MJ>yr-Uq2cA440C+A zVoq5;5PpUG#yN%*j)0!CO+w?~6})0}(T87pOJ>}N^}YA-#;AyCekn-N)1Lhr4ArXZIZ%h9wb<9gm>L@`DeD<*lcm~n&5-SKE|Vr6pH0@iOr#6={sdt> z(&$7w0*EIX2#rBpSFKB)WWI>)^JHVYJBK-yJp7Tg`Kjvt1B;2?OXMqvA}(COiS96{ z#~!BT+PNoiUOHFqWuYq#(|NDTo!tmmqokn zbqQ)LHYf_FW3jN$`jdVqtu?ct+p)Gw(!{zg+;xiHwjC+ml?GMfgNPs~x}?WA@u-Vg z5XDbLhVo>LRgyJF$gGI8B|zBUkT^l&1gY`yVss@TduqX4vyrxi-a!` zYyyN{QH~CXgGm>4HpK#<#3Yc4&O1RMt;8(|f$CWNI;O@>zGI}M+2o_?6X}9F!c^K4 z)`@Hx;xohp6}1Y``gpy)1n|p7q5=M}%6V_s^QK`tp%o|Fp$6@QRmALzS5f;w2-mKT z2GSrv*J4Rx^du4sWxpnC(%o}}d9RXM~0O zC3nu6nU10<6th_C$B=rdQ;9Yb;zo4~lLn2FzA;@;Im3Q?0&7B=9@%bg)Uh0$R$(a( zm!j=xEwu%o*Fb|EC~dH312v>t0zqvrypqXN)V6!nE;ZCPlKS8nNe&GgN-#Ou!p8>PlbnNe#4u1%tV);MI9k!?oYm5!CgZkD35@9kG~`vXN+^sM?@` z(G_lEilZGHF676CXl5mMyvImJg#BuqIr>GPYkY~%6B@`xFgfIeHC_Xk+e%}5^RoWk z{mw?@$e(NUZu^_LEx5ZY z3bE@cJkks50DOc|BsTd;k{lT{R;tz?wmP7faKnck9{?!ArB!e--m|Ct-SiA0S!M9G zx*RXU*7BW0g~8eeHhn+(LBpZ|YE(HYkGzV%9~pjzzhFF9Twkc2qp#E415dE#ED5D` z)fV8JgiU19MivKjNynzwbL7UrBwTZV$$l-XS&c}aq5Md`xCw6_U}e0b^*`l9QNxmx z&1{|!$d<3<#u)gwtylIiUL7IB<(JMe<&2%y+&N|yW-J?Rtj&#cZeaPzXiUzxo9s8n z=6t-(exxZ%o;W*4o3Ziir)nPHorIOEgNG0vbfP~WY(XxS6{k}0+DY9>_gdZOtyTsX z;`>P}P6<$a(aDPZ#a0683Q+8~D4v4v-K$px01rA@e%{-fgo2?0g_J5e;wXe0P}C6Q zK?ux{^HL2->yo*qu!xz7YpNCg(B^&U#Ss~QSm1oflXDh=B}K`ifVGy8($j>eD^{Jm z8~OpSG%|6`@k4IQR%j|Y?D||<$SPE(YYn_tq zWc>a0rs=?>;?2DR@VKC*o>HYUQLb&FNI0#6=Cx&x2!OVb)qqSMtfM;cypvj5>Lo%p zOfv2tH!zua)V+E&aoK)9+=|szt!ak%6f9YyM+V9*pfuf`zw;qDVp4t!)=zs16RsO%6&mgx++;$Q*zkRah$G58Jh{J>#j2x3Iz^ygg4&7-&nw{DVSpYD!; zl(r!#3MAopO$pD_KC1~e?RZrwg*v#q4T;*fs<;){;@4dhvhp@=sA<3%rBL_L^>bC- zA*3`b3{LK(z|f8AEevUkdseJg`$`iPoa_DK!@^&)A9A*pL-~P;k*%~GWobi#tYO9K zHmKh$?Vj|e2*!G_L$sAJAZ-#Dnc=D^YnS&p5_(Uk^Q_{YB3^*mp0DjIRrX9-o9dpD zFzG7aTH!RIGGLwZyPD7ly+7S(Ho9!%P>y|0fi!X$_7=0JTEZqQn; zZID@%A*}=7lK{6bdJzNj2d>ajthptw2imhIZGZ9iI(H?Hg(3sQtK~~(pI9^g$xSl2jR*Gy3(zq67OdG9N z{>C(Ey<&=SW~H@)T`*WB8x@@ClQ&3>eUaHx<@8k`&pxw)Qrt%?RW#Wvd@4T~W091jd*tQvZ9+Pi&kkWX+FCiRr9MhZa>u8?_5= zBW?%+DjcHOq2KsyU1EcsN@e8&!c;S+Xl?>;HpAbOtKr5AFqlJqyc01|9E5j?@R~

    6%W9#!(Jn2GT4;RUCzS_$_txFc#@7%sIh273kM}&KJ7|+CQTzc6FgZZiJ!ol2i zGBdl`U>?e8Y}mEsoGtGXSI3>!{~mhkk9XOk=AOe2pX27L6bXfma4ZmzU$$a*S%#a^vCDCZKNs>Ycy|d}Ojr8H6wd<$!m-EbsOow>(SJz)RWboKZi^0Hx4G?o$R#8C@*uN1lC z;S%n4Xy>k-$)6(~qVfpKcB<>dQI@%w+!p$FoSp1i9bp;DqcT>Y#Zg&xM$XR37e+>D zavp7p*u!&-DcGsrE&@zc9$hM2>eeNHjL^1@PT@o8UkBXT7;h~O5A(Wp>yk51O?MpS z>teiB7IpviJ@N=PT@$8Ly5=3@Q>(?8zR_*@=E)h>2}en%9Rs1bYe8 z0aL6~2QA}wyIDj^>O#6v@Uq1BskB&b$Pq8{{Ne0pYOcjQTHtOXABJ9Ruo{1sYdA5P z&gL*yqa)Rsg4Y$&J=Qa229~YPAF*`_t*t$xN^d8!n6ok;9@;j6bH}9bbDsS{FAQwR zR|k{Jq?{i5?%YHvwvzd6^L1le#IKTEzQz?ITfP>{8p7*IrI<5<%(k6pQ9q2encAyt z&Q*r?AUo3T2I<9q@mFJx`bc1za^xr>T{vHk2j+{)ES#YlP(wy41tp-iwT(62D2xE?~|CNPMe zt1C{7b5Q8%&yi7!Dcbt=FsOlo1uV^GGsN5u%Itm)2ZiS1@o(|UbX9smM5%SAWD1~yDsa+K1n9=Et0uZ|gSgLiT=B;>#*JMZWdbzWEju;*zL#Y$!DG~BD5AeRQ@@Y-Kp74riMXR`n$B0MP}J%9^=!@Pj#7OupdZ zG{p@yxq*_(7N?>0hz%~SRKt9NzVeBsm!@g!Vindz5qCGp3bgm9)M=%MN19;AO@9wL zE&JhSuOx4g)-`4Br|aaCvYy;8xTEWqVU8s8=Fao6Yt7tGT9JZflm8KHUPB?&(>A)y z;5I`bsF7TuA8}$Z=OCFkGiFto8!te3;bm}3Ne#1~w#_X^uAy29S6u+Vz%3`DwW-m5 z>?Tc6rXN5@{O<}eO$z<$x-B~eI)sfxgIWlns-7)XQAWW-K(JJ}pl4B?{s|LY9#a=U z5@KrS&wXr+g=VQ4;%2o1@S89|nBCPJ@+B#k*?$P3C>j<9w*1X0W$#sM$LX3IG4c&= zA;2ZSzkdQ!vYN&iACiN$r^{!Nhy{@>4ARb~(xkHi#G_x6MZwanqc_Q5laa41` zg<8)&@K{I!EaSgOQ72*xomwo>y-uYb$vV*M1}^~Eh!zKKjKW){5aEL zy^Sf5<-g_C7@XV{J_LBo$VVie$&_1vd$>r*G>Z3-NDx<^Rf(rO>$(e^BxdWPd>$ z2t!$u9j6cO*D5Y>l5xIjB`nQ{cqs=_yH8cKITaxD6}IbKx>fSz&S1>FyvV0~QLA4< z?4^GuUC^lFAEM1kZw7cO3RVJy%Ybh z=-Rffhioib&6D?iMfVHgp%JLxJx|N9i=tW`J4vB{AI(F-X+DgL$U|vrt=y_nB6LwV zh)ZfKaF#rRgQ?_${Be;q=zbjK_7-l_7&2tPA92qxA9EDx=Pu(M(F@FZ5?5`AaWP7B z^!g($5{MKQC*ToQ;m@OROv@Zx1J4g_FX2k@x{d2LB)gazLo%^BfPpusn$L}?O2l;Q zL_?kfDK$67Gdao*2w!sLmdMxysHJ&f7`0xh=CJu#H&V&tt#_<1WPCdv2tR+Hd*Jml zKR7f>Q7;zDy6vpb+@{iC=qq2xp`IESZnZGNPK{PsE$NVdFOEcMqXfIsFa<}V>hLuC zCvH&AaUDB-yR1l2+}Q4ux;gm#flq1?hHhzy0N-7J!9sa7U+J4b40Q6VFB$dZ zpuqLdVYPv{qQswt4n z!lgDJDN0c$bj`SJl+uUV3VlP z5bj}7^M){hxd~4pKP*E?Tkl+hz{9*Lc zG^uf%v*ewY!BrVTrEDon&s8l;Mr6Xu$KDcFUix^W9mKQ<-07gzb8n|o!Kin)t%p^n zm_yK7eqB+`W|d&}w=Ey#g%qoBN;rVv(pJNe2!Ja+SJ~(vS9*y0Yg! z)_is)E<`*mm}1k zP4rFDl*H~coNc4IDxOaC#07K1__C0aCiU^CGj0{>m5-=m^sCqDC>j5Dwq7cDG3_J* zu(?c`A@bo>=V*A31zMzFdu-fK;i@Bf>flcq(r1MdtN;=&tdJF2F39&!9FWQ2cPEBQ z8kO~0jiF}x8L+ZSkcnOu(aa~6_B?9~`L@UN*zszaYQJ9e!VV-!Qwy0Xf%ZTWmm2K_ ziQ9MevcZpjokiz%1igBYZ@d_yBeeAGigDA53-R&k&(|gIW&)v#P^9MOq+Di-j;V{`3*2uRN}|`S4%7s8d!g7UA0|nRtPWmp zz1mNCfv|qJYb2-Um}qL>6xNGTAjjWkl-@{1AtT(`qxKweQIFz~*8IV;14?RpLIt-L zb~lzF3mH*LRfUFkN*%`7!r7F>pElJt7Qay9(X4x?3}w0@Ktub)7e*+Kzy}h5z1J4Q)2M~4Y!_n>sTIyBl5>v{S8%n^{aedGZK8 zlc^2#ui6*uF0m^JU9)~5-vqTmx`7Gmc!R8tRTI#3YNDDSI%8}Is{$G@N#DFBC`zx` zUOZA!^UHoqa(YYxK9E@)EYkCYA0DU@6B>K9ElFO@=sczcFcAM8#4~YmW%}@|O@4VD z3~CB?>0Yeu6yl*Sg|(aFFa>)g4V>$_u9CWP4NFd^U)*RO0k0fSKbqc*N(S(bhy zM6Egs#dFM{^!7k&V$6c@9%+Zh?ngi3X-96v73}r<%uyx*Nvt&-gkf8SD}H18QW}1j zDxmSUhBVfzm8Q=^5{13|sI{kD>7)gbBO6slpJ4I#zCC3qGD#@)TrD{_>XieC(q=bxWbdmItz~Km3K0< z@2h%nQDt|x_ugm2YAdChef$w(0O#1b&WV{WabA9u`_z;Ilg91VVa@pr?cCZ;J_9|L}IWIr{X@ubi_~l1aAg}Uup=#HnHN3}?(iJFOZAxLKR%+`f$OVq_wZ{o`wT7%W zDA{aEbkiv6HAU*}W>a~Wl#sptj(e{`n&Roa23ePU>8bY=WL@ZEMm2xEcOdIRH+ux~=0o*}=ya{*BfGTa z8{9%h1WTDE(s%C>$hz$cmGlB+eK~NF(zGRRn$>ibxvO-rfXS~avP9~-D}KhRse?Z5 z`1-{d~+uL zv17r+Hw7{hkDiI&kR>lGhz@87_MP=+SORs>u-b8Z+!^2~k%qNqUrE@}@sxxqo`I5R z*c0i0OkXst*w6A6QymQ}-id>dMo-Dcw8#_2S(rt3NsF`!b7ESgAqhe|DU^nQB2+gy ziN@O0QEnF-b;C^AB9%Ez1)iDcu&3Db->0a2D0tg*e@!{jI^`Tn8!GM1Gfb(7ow^8K zEo4B0;aY-LR>|u{RUJtYHJxL*3nuX_2ssax9WP!ydOidzwu$4&&_Ux;39LvKd6nlB zWjdmfl(9XC4L%2#BW4ka`Fap;eqr)@t`xu0Q>Rkegrz-x+ue+db_HQm$)8L^>2L79 zNnww!2y}@F2j^@9?UMK)Gd_Xu9j9+%%g9MCp8bas%Oi|x;*|}+lNL;IbC!vbPAt8x{IU?S~L% z(A~s+r0Sb!IoeECw32%<)7(_aId$sjxGyj&N5@H}t_vn64)I+k+V&?7_b1aigngD7I-Rx3OBPcISPqRJimXU+_@=yCO~Hd5v8 z<)e7gX;0^tB3M>H0%P1L)ht0+`C-RTrRvZmLbMBmD#2Xx-o0#8PpMUUJ8Hi=%2KUO zsX6s>#RXqCw)^f?E9zd}bbF|`S(_+LbMi4UbEeiqmFgFM7tNUG*tVy_o-}9g;333n zabS5PdnfXhJ%w6neWA3xj1U&wR@z>wjMD=(D$Gd-dVlRs*+|ATQ5DV=L`Q3T4~AAp z$}OoOFz?Jg9%Lh3Ntxb|5c*eqw4Sw=DtTL{($d%W@w7kCZUedh(7mwTCfyv$?adF4 zj4mH3omegB_bsPCNQ2ipF~c8iy6Di6K?` z+-1BZY5^dtzC)stGCDJ8|9(yEfo3(GRZbl&85x=wr`Jb9nUt~5 z+Z2f9_$b(wxLtoU%YfZ)xL?1)U9`Il_v`HMEiAXZy@e^B&fdbMSo-7bC|rQg@%VZB z2p8b8CcB4w&*z6PjHcW?`e`l_5m4S~kxXy%;I<^B94rMkOa=g@_=F0(`Q-;!g}H67 zbsho~dpt8t>r4AFui)7wdMzvS8ut^8URzpUuh|TWN_DM1*s9Czr||gD;qe--I1t;N z*i2g}oj$-Ub~~s$1Y(z0r?6`T)0-8Oql^L+5FYhxF%!}?ylm$aau4pCQ2qV)zDn1B7|f6Z;NVu4 zU1W%vbuP%HDlb#l*sGavoG$JVV<~~;u(m$CRutE z6Ll5`9>kcKYl!KbbpKjJLnJ|+bW6WtBJNY8kF;TiC$HJ8Rh55st#;}7taj*s?BX4| zSn%@q!Cjp6T0Y7aB8Am;Jp$%g*BkVt#7X`m(Y$ou(L_ldSL`@m1GUc5DZEgGx!TO- zI(6Ft898WoptlCu<5eC&2-FFb*uwqe5iqfrAyw+ZEZtmS9)u! zIQK{mSNf2IZq2t{ehIJ2j(pPwXUm&)IcDSk^TM8-{T3E=lP}(#^GXFg0(0;YktAdv zmG!dGKg4q~|H`+q9O>Mtfx7&Ei*+JKSnChI#!h5NFryFhTF;(?E8otu=wRC#+`jlN z0%PM~uAKoT+Uh&F!oVafdxtX^j|c_EIcksL$@W8jp+{guKFmI?MR2M;BHZX$Ec~!p zxzBy49;2p-!8!Y@^5vY6?dHQL?qt^S|x+s2q zg(m1=D=?N>;Si<`2u+3IBA^#91xyT^thz8#+uy}v9yL;b)O=7q36)X@QQZlba4vMh4+X|GzQ*+=){!@|DUS^ju6tKsrQ4t4y2qOcieOm1 zEW1?wY)-Xg@pm^glJ8-@1mDaTQo@CDhHd_WIowQ!JoY9{IodZ_#rfQ-_cQy<`P?rk?IKJl{{>mV`a6-OLOHBp-{RvW!`MViwHPl@#WqM)g>gT)6_%|EtXuHY_(3oCYU4AWOQc~jP;DfxLI9XOGLviDZW@SQh zSjC%xYp2GWR7Fe=UVRL6!ne+vF)M{rh^e>pXwo@5(XhE$^C9V2Y;%n*U}HvkxX{8%Ak2btekMEb;H^1QqC#uD4)#&qbq>kA`X@iVp}rLIP@8N8)X zAbX>j8;d?VwBf_d2$k!43Kj0ZLDSY|Jy|OC^^{tB6<1!QAF60bS?W0?*=3W_YaBj~ zWqa7+nzGP*)n;_4bv*gOM?^Z)->$;tdKIvlJYDiIt~ z0m6R5b(*?3b|OLAk7B0_^ZBAmFlV?rq&!I-@;i>%G%VTBiD=vrB&M5dc|o3ab*}Di zEtqRMk6Nex{66kbd_a;sfA+=4u#-CcxG0E6+r=pmrU9AalNWs~7;xv?=A$wcn4Elx z5o89)*%Zc$W(s=&WV|hz+BikLc3C69@3`A&z%qQ=SR7n8Fy;ksr>YCgcbN15i{fmZ z{P-^O6-dWF>+YKYu-!*9BwE%WYC%lpl9FMDf&5#6<^i$<_QVLPl~07Bh_!tyyhi*Dc2dh_^-jW$p=| z)Qv`nGmXNkStZ$t>(D;H^j+jU#Mut3&DSnrkENDXz_U*kQ-Ph(W(MQ<#<+1#RjeSh- z)=veKCI)oT92qW39+%wCRPzvaBarc;mZ0z?Dr}WPGgL9`LV{s^suPbDA`Qsscy6$h z{zx8wL(l>H3HJ`G`YMCnjHm^ROU+(AQ!1-xdaODq=mJk4K<`5v$SX^k0unk>Nw1Wc zPFf0tI2oSG;L7^LLmzomejawp`Sz+dPV#g8ZQ4T36o}VtCd2gk`1uO+(@^E05cGzf zDY`x+1kfp{Oo>!pe|bFslObOmEDa&bet9`R&Zf*YpO%q{e1zd88$~&>&FGu|G%?yG zZChsjq|PdDtche%1e-J^MqWrM-|g3y8T4Kc<+Fq&%fkej9r;`p&yPU$z4kMKc4>&~ zFou=^R>0gE($gNZcg z<4#q052H0QtGJ-kX3Gl&Ki$O=N1NKZQY)SDcCzYbfWFwW8y!b{L<70MtVyCXb0yW@ zQhn&Nnlv|C;-#&tJ}1IP>4>J<{PP%>jtFl+r##`|2a0=v?@jx9J2z%805q+Fxjo3& z2(99khgOYZ%Fv~=#~7_eNp|UO!~%J?4Y|uGE2&Zk!lz8hyA)uGr*kQwX*b4sa6Cai zs|a7o&=?*{!TZEGs2JP0ACCpABN!*Gu9D3Lpu?Zn<8EU18;aY$Jpk2p>YpdqT{p)+Zy9dtCR3?!MEOaE>hD~2?9j)im&rPHOUkOl|eZ+^(w1C6X- z12U9pB^0V=Bq9MxcmSt%b^(D0^z4ZS42QNZV9yuz!1^N-K%D|7}csN}yuE)1ppEI!KHml-3QY$Sdw}eZ|eep!lC5>D$2& zBcPd$#H`e|->)P%O_Pc~z!)`{TpKo<2AN{h>578eZyuUizY?G_i!Hq+=(a-R!%(`u z9s2#js~J3FI1Dy)JoQ$VO4~17`u|5RHL?>yEzK|V*Auh`^@&BZhAG(EG+8D0J~#UuqX!*S5(%+8KwKhqQ6>v4Uo!nPy* z&aW@j`mhDZyNS>QvbRZ$*9o7u=8GdLsgMcHaCSVZrxu5dLeL0Wz_GwY1;&ZW_YWbX z=VH(|yOr?C3Tw1|MGtzY4#DKJDLY^y+_1V_2>_B%jFKfWN%FUDa1g--$;TL%uNh*H z7zy(_r5%Q?CA?NgZ$m;DrCDzfI%Bw`)nI;j-=p7WvN0}M0_&z z^VHPy5IJq4eTIidRWjEaZ01=l#Zt!vO5|m86AvR~_I{lz?)@4M^Z7WI++mNDFWekTtkB&mT5l$3*%95XUJU zTIg_B>x~^7woCQ~$~bWwcigDL|8qZ=G*yKSQ46sV0=Qc=5YR~z>ginSW8cP|plEAhNI#P(Fz0jPnmW-%) ze`QOn$u?G!K3pd`G{uGblyAj4=R({$&)B?w6PtJE`aW`Y3K9(Ft&AsQcFopIoU`Q4 zxf8M~neW;(!gFo&q&vPKxHJfr-eju{R9zx&L;yeA=7vriq-pHKOdsCH&5doJ7#~mv z5?Qn9Gn84%amHx~H*4voEoP-d9|}V-;IP8p*)sQEH7hePEyxK(%WkUywHpF@vf*Ok z6R;C#GjuK8$mH@z%#)m%~YKKBCV$nba!guhi&kLkL-R9l~i zEv9T7Nq|kI>xStFA0sSh+fl9f*1z=p*ioNqrsQ(4AEWOmO=8lY!5IOJ{ZRI%(E(w|OA*TiRkD zdp7BdJM-EyQT#od=zM5LemMD!v~jq*aB&+JY(eDfUbr*OqaEIrSl2-5WLygR@!!^r zj1Q6?8=~qGhKmo6g}ctcMd-6&YowDg!Yr6zi*Xcg%Vgf%c|JEID&Xwr#;hp!!EW!k z>|8!t3OeeaKm8^S6h9%V@KH{HF?Hl~M;xw!U;WMOR}V06DMsDDPZB?@&oaAG243K? zIJ{99o5LBaT;9o6aY>7+Qnw#R3q$#JBk(n2pECq~1XV&xDS7W;;AeixDxne?O75X{ z`?RRZaF{OnjR`GuN`@Pa0T;0R(;6o(Evuc;^BrMnc6gOjweA;-fAgQZj^8C8!#CW0E5P0Dat6(|s( z#T4esR487tR#QHdAI^c-u;JjMLs#TJGOkZk*V^UAUxs`i#Ssp`u!bZ(3c`h1!qf*u9T37s4Gt2=}_XS#Leg_m|NPwxqSCB`DrloWLV3 z$n86ns6Z#bQeWT)eWrLKLn`_lBkgTgiTl{RQN5J=vq-ECa~@Uh?q0byR~gA~q7jx@ zJ5fdZ?YutJD4-^FFaCk%iP5nhyw}Y0SwUJw>%pe!`ZD82YP9av96u;N`6pRgp9CGm zFZm(_?N-~$?p6A^G?ZTc?>ux1oI>gMJ&r;<%?8;y)SbLaI}m>?Xk@jFz`#wnfARvz zU-IVv(3&U4%Mc^F(5+u12DKZ0XsES?LaiGw(Lr5b(XDucdeR^`ynDr|rueNEol`3K zE?Qt&c@y25;6>Z%TKCGH3A{v|JoIz3%%p)%UZsHwDIlz2-6yY-_4H{!;?4;V{m=V( zIlb6jPP6`N&*z!>ul-4*(w9u33JC}A%XaQFrG6_y#N!Suk%aqp%0y)>Umfg}d8p_3 zRM4rc0iC7F$nyQ_VZG(r{##zIgY@k-s8c$TIp@d1wTG<<#0?co zI03?wq9nb-L4>&G_x9m^AJW=J%}*_%_KdnZwJaY^n$Xc#$<}XJlVlbc$XGiT3tnr> ztow-`r~|QOoM*#p$R()Ky)Da5i%vv{6svT|)45arm8a*t-|kuOt|QcbXb9-lyqxsWMT- zWN;J#ZRC}5|Ng&M!LKmVJT@+sMFscG(`t?I{Dus@pxYz27oDk@Z6?e}Kh>q4=Nn_oZp z19x~<7>O6-t9fMZbZBGBK8ykLLGx(pz4b z?<+WvV3Bn~IA7O>&ze6`>NUV1|Q3a`Q`;o0(&iPVakwm&Iw)r;QFa z4}Qjm`gFTlif(-98r(TLc=`a-X)ZRu&t@dL%M2;c% zROe2(Xy5&Rn154Ef7}?|HxJkAns;uFRtZn!r>v@92372-p0H; zv(yOoj)60W4rSX~A0yLXdOBVArRv(H$Imks;|#=4i`^F4q)pHHp?A9AG?}Uk=XbBw z2ITxteOxTbX;J8*z3lgT^roph(wp(CdA~c|mB*v*KBjJ(Zk2t7q1tFCvPo4+`*w;; z@=<61#HsxDAN0UXZ@twx@n`A) z?lg=EP>IQ$8P0Gz?&Be!xy7*~KLTeg+|HD|;#$$;4 z3hF8Awr~EOOSB{^_vdX7ahcXtRMzp$M341M^+BqelIn6cHl+*azm&UUo}-uzw8Ay= z;LdEilfR(nH=4W2Z1r4;;lla*dDLdD>k6;P$ISb#&~>vCnYGTdvRgQR(g-LAI?Qye z7_&@&u_3HLfsco> zrM4L{c({5>{6s&WHTU7|CpS~4mqz71T)otK1^qmB-ox8Z(@>qB8qM}_^%Tn|y15|p z@OD$TQm2n*_2&0er}|iDeW$;g^h5hRyTfG@Y7G{FcN^Hg=|Znz56q@6C9?! znVA+}!^g9`yJvdFIb11??<}p!R%SQ=6?S}qW9OwfrrxZcf0TBIsat`&jB{+J+`?tC z!BL#EY*--c#>^y1@F6<{-#+T68S&)DYxKyHJCxr~5>=FvGVWdVA<6|I_iBSJLGUx3 zJVJ@|Y^IzV&F#(87WHjeJ}Fbl8fV5WJ@3w)-YK40B~(v!vfO0eiL57N#y;r~T`<$` zyN$e;2DFA6%c_>TEc#dSHLw?VSNHC+M4>R@vid=Lo7Rj(XEhF~& z(u}=JIGCd+5X?nFiZz{~_e97LUQPG3!bp`?ZAoSE%npVPzVV6LL~aaO0_c|0NMWEb zMrkGfX$hl`E-d5O*_ayYHb#17Q)=}OkJF--%+O>R$X9FINSD$RA~Y5x$7cBVku?LQ zXTm}TOGP@#&)&<*B!etzBU`ZwqtLlpi9&2hQD!byX0TFhKzb&W9WNL2RAsh2TbDdT z6lezL`^c)t&?gA=Oec};>1l_}j%u+Ok2_proU!mC zjJZ8l*pnZdBwx%IpD;_CQx@A`b9(C020bjvnYnu6Ep$E2v@kRDy!vZv^lG+>XUu7} zxlso0XT+wSshV{yu^);V3gh&o?in)JO2u95Ds|^!PPwE{>Ryu_u+Hh{9c#G1`;?U@ zpKE4q6uR9)JAiskBD6CbK&^;jQ2gCCv)dzS)?0dwZ7JFza^kNBMV~m%Vbdy?OO_;o zy}-gcIDtsBep)<|`@;js<=NRodAdN^0nV(Tls1J{-=@#;;k^Gv}+` z&rvYYH>L8PkvdJqFXgaIY`o-~?g>|CY&R;XD4ztxYljwNd3;< ztaRms*`)To1g`Zm$t4yz6JwD9+tqsbl4a}(QEHEhI({rg6h00CqQ{MQbv{GGL1#Z& zd%E#>Ch?W1obx{}#`&`|~@<3H$Vikm;^_~vf2ay~kl_HB_nRu!=Ho^6uNdNYt` zdZRZWpPk5?kH{bCC<&RoKz>5w`j@pfo=#VDAORwavyt9n*=N2G5is8rPmlSE*v-;Eo@TT$E!Qf~PGlwZrke1Xp-xaJn(_Ma zD>Mt8sS)S(I~mX}HC{X2@>%oS`!@SL7h(dQo8klKxkvDg(i!GEA{>w?yw-_>_`&>G z9s}_ClHN&OSDDTHtb_otCAZ~Mf z=|U(du2}1q42h5}A2RVFEIBcRM7!F3wY$-3ce95rg#c=RB5pwgH4tDaG#Cn0w3HZ1 zh)AJTDGe%DOo6go#ZV5l1!_u5f6p=V-t+FP{BHV-|48h2Kl9u(^UU4j^cJ*PZ6B52 zY%SSx+gPu=YA9HKRTLK$MS%+6g;GG53(e2XyHFweP0|v=nVcgJn_F;wU1-ayC0;(; z?px;=)ag@fy@5-Q^?6--N`AAsbgk`){ce}4x!xft2(PMv;X77}>2j?3xp~K`r9U7| zB5I!B{0dI33`d^xNUpF!-cy&}j1yx6!m$n~*2Pz=85P>8nWtnCZdx1S!*{6^+T~L7 z^QK*@R{BwcBG{#8^G0Q7rcx=!@IO6?RBE)4&yT_~;&3E0_wWe*3G{71`OSED+mN4k zKPA3;y&J%OL>6-TH=soL9+rZ;JZyg6yoUqS_z$VLXqk67v7@;xZ23bs4@cf|$j8MZ zG~~3$a76AE@gGMh$#+^58jU1=yi2&<8cAIKEN>(%ZCMjvtw_*e|6Ey$LqVrV_^}{G zcg2GFx%pVo(c?E#b^i*Vf>+?UwqKp|2?d$^%Er+dNmk*_RP|py+w0)9w)bDjUo8hW z;vJJEg6g>?YWR+oBD)-Ges12eja2@+RN1Vm%1{`Nd~}u_>tA~XtLv^0ps?Ox9>6cx zy7wv{?{0bJu)@26{I|(c4i5(w3E#_7beEUS&ztsgpdNQg)xpy^d5q(!-X0jKUdeO5 zQTr&!zltZRy`P|~nujAJGXd3{sdu_U!AYPPJjrnOIl}K|OWyGf`N_=KVAt{+N8FL1 z!~8L_6i0$ik?oBx10zLZ`QM08!hEGpT!i7I@ zRo-yqC8+@Si?(2MlsD4_+_T%Kk!bti9(QP5lwgmRVd{;|x zU9L7iZ`#!g4IZ>l)FaV%Sk3w|1D@M0!^HBNpTmB14Dsv@%oW3t+h4$4jRPZH?V;I8 z6$^?jH<+OLxsc8_LwfmsA1}B4mH29TSj0pV~n zSr}^@^NWGI#aF)=(2`_85^x8GR_XAgMJnWq7W4DPM2nV6k%P|0!E8eyF7ohh_hF-w zDWtA87KS6Ap5%yF-0G8TCNqhA)QVIa@8QU!;{lvC1WNBEfDTTh1c!zYMbH6mfsC%N?^y8yM$QyI}scLZ$IK}EnowKciC^t<>SLg z-2tFx`FTN8_*o4M-WCb^`=#hE_nV(L@BSdwUoH*iu6|TVZRY7hqTSNk$DOTYs?)J#VQy!-@XSKd$R~=~o#mpDj7=EHY6-6UnSi^- z<{;xs{%^pvlbGWSnPsD}@SB;OIKcs6-$A+7R(QTUELtP+rv!J=q_&1h_~9wd;|fpn zbMxWZ8qM#MZWO&Zj6!2PwKkFu=)ujwDq`s=)8WYDZt|IFl`WK{+v!)bQB)3GCn8Wx zqT%Mn>*Y6lx83%j7rLV|kn!sT5o^Rs%KHi#evC+AT`^*QZazi=mF<(Z5v`dsgF2Qt zb=WAE;dz1KNc%SSq<%SyOXK1{N!Hx0VNm1F&^}>$t$WLab1DlI} znsUcc$Z{T#3^?>crXGG%BMst;R`YZ7(HgSKM-68KwW)|QPcR1_l9pM3$Q#1pRBO<4 z`DJyr84=B9=x)9IblV5g?$`}g&@Ga@BLfV_2;s-AG=?i~&CkupZK%e)G-E|A?#{ff zyPK}KAA;#xalz0D`{cXmeWC7j4-7}Xww*g%#}R%RohB(fZ;0sm;HL4KtOzEvX^g*E zelp{0%jLyOZ*+&3hf__I6XQP5@8P>y3gvRM`MG&FdxY+kdJ7+5o(FD{Hy-<*CKRzE zpp6a@`c?6^S>YAa1+Y5O_B!#^%1)h}o+f{H)KMWu_|})=xU6q}Zr=J%bv`83v6&tt zT0ZCC8~-8?$NwRABsltg1_rm}+@{}h`Ot&s+|lpiQxl~`?7Myq-}X`PqT5-%{8mL_QCoa5;k!->=W?C-xp~+53Vw~WfpARlg=BD%e%aU$ zN9w-yRUhBVngzkpsYz$KK}P9w`9|+e!o7B1w*6XswR)Q-q&O)Hn*$wP`NQ|SRK(?X z^K_3O^ zAt{o}L+0nrdB`sFFQiJ~25eS!1}@f`<9O95&1NfwJ=wy}VzmUXjKq$>J#}!I-_3~% z+{3&-2k-n2NB(Br$DhLQw7s47yH-oN*zseBV5|Fk{?P|7t9%P2M0aw3u?@c-NE5p1f%&=ldT@W);!mXWMg8KQaVMTD zOTY~+u&wO+PjRq2Mogk|aNe)F14PycH_c92tkDRoW8NLY?bpapwk~hE?Wf|a)if%3 zzDPp3ja1^o4-zS)D@e@G%?F86_{T4ZDlPnEyH5qWz~RWMcmc$BidPKg+-24q9-i5exzeY{r9kyhv0*TYXz=yWtjv2Lt(kOVAR{y^hG?`&NqX z@~!!K)4mN<{WfVZ;b=ZIhlh4!seJj^F<6cJvjFd6-s&yVCTRvGO&)&Tg&k>jG$Xc0p_niRLym2pYcUq^K^>nV*~YT#)>iE{ZS~ zmF&9f5uJypL<`kY5>~vg{{Z{We}+Z0N1jrf*}(I2A&R5p+w$h$ch@r&&!F9Uoe%R%VE*`4 zQ7P@+-)~+2GKC+51^A{Q=IsB1%Y^S?DZIa!4%t9&l2(0UkOH&J_DK1n>R>Z$K<Eindo7hY3DxjTmy?;qKwNc7-D`DoA+dZ_%D)HkxjaZrMo3h!RZd;c~zqdnb((Y4QS29 z@}qUBfTwt|=_Se3tKIb#wuwFFHEuUHX8m?SNO-exf$*Iw#dbN>{M@`#8*6b;n#$j| zP``}?G|5MAZrZQ1X!AZDd99C6e<(g$qalCgB-^sYb7mb34&RqjT$eA+&tdses{8oY ziI5k5w3ajI64(i&1kYe}M&0*`bz1j{jV1Camuxdqj31)B^7stm-)H*@Cw0j6K`80%2NJ7H8R(1jk{I~<9gVDI_vlr#xD zOPQmdMqAV0{AS@UbJVllZ=(5h+upahJ=lo#=LBi@&_^L@_}-KvyS!`%uUx}3apa-b5XFB`3pXaC6UOT`L#`{`g`I@!KWkoEPW6B@n`rKm0+ znx8M$hfev2rD6R2heze`ij3jNCntS;C>mf~EBA4uct>zJ^6$d`zU%F-f|4UWg5vrO zw=0=M8{Bnu#alh0afAG1&St}1S3BO;ATqQCdYd5cA2r%!!jCAaqAQ}z&leq0+PYPw zu|?oG{X2tn#&KgQEHri;=Xh%>W&-FnA1;6Nb`e4LaC!diy5SNa%e{hfgGdRW5PpzI z#auyRehx240@Qk^w63CaFawPTEyIyU9fVIS;MdtNw{^c$*RPWGo$nAOIB9cgMQ4oZ zZXpQ|-(yl_m&eS{;dxBzkd#L9?JV|{N~82hk|DZ^sQoOMzehzGv%_C$u*>S2cZoV_ zCT|^n{yfvxRtxs0oAIjzVc#n028ZuUDXz};a)SFS+zpTak=6vbs=^KS0!p5XX4Z5+;1}N}*ilH9t3RUXN10kxGf&0d9Sm%gz})=c>6%7LKD-V*9f> zW6Vg{<|s&A9AK?-A{jnKQtA?3UNRSLw1K0Ujocx!f33CVbaQ;a#pZ zKVO7vgB1C!sl2mF>0KV^H&5fe#|96l?zltY8)kIRpNO9wKH%TNx3v_;Woz^Erftmv zAC$U^{u@_+8XXEIOs7CbgBKzn`#url0^cQ-5zQ8~Yp}^D`l1&PM}F{^yaEvM%acU=XM-;{$c_AB{?%uMM{MoU zQrnZ?uZVdYw~vUDA|djM6TT;;ST0YPpPToDSL!`dbx{T6rkz}3p-`<{jradgJe#|Y zMZZURop_!ad5!BT~0z>YmDD5bzk4+psME-G<5yC}BN zpxXMJML9L?vp~g+-H7n-hE0X|5qw0s@exB?#7<%5=^BNI+O?KJ;smTuHGfA2%i>I)YHw13#^Dp5Ks5=ByJpV_O7cN)9!gsM0(dASmEq4|09KJ-)d^0Okug#$}Q+L$lygezStiTN13KUX?XDpZTGPyLbX#K0pa z%F@f5I9T$qk9$42wDoTB)#FJe@4d2w!<$NY_#TxayF6-s-n2)RI{ced8N7H;PVFnSzV`{?A9G4iafMdtuSATQ8%y1+wn>D@YDrv6lJH$3MRK{s z{M@`t+$!B>s^pxchMsXavYCd>|J9XyKk2ruXsw7(TK?(?eflYUn@Uk!HZ?ytZ&SM} zKbES9hUy|8JedX~lnm&czWor5&Z)UOXWZ|(n7lUQ_B-$Lwt{PIpZ%1=?O~baiIRaM za>Ak>e(*_yxPs68yy@TzOXa8EEj%XTck>~2Dv^%mVLQ~pe9D*~j$H9z(J?#bq~-LK zW2_Y#&qgyKegouFtKL9f+Vc8Oy92p35`R;0_Zv=!W|r{7TAIfd*5>Et!@4!*{iSrH zj62bE^Z($0a)T)|zcHEL#*w8hcmK6JU|g(@OMs*0l7fWqA}Nr|Mds(`UF1@zE)}}y zmIEIbJ7$!Ng?t%$zH2Us36uu~EHZAsZaA4OUlP1N>=ytZ`HWACamngu6#)>IsE?Hl z903#-_3#5w8pIWV=I2cZU|1?Y?EIVh=f%NQo<@Iy+P!WB~H=jKByOnsmI z_hGh)a%DWHT;9m`?ZG4|KJYUP+D#&=y}03%%)J%4nJt6FdG z`FYcBbqf9)saz+#V2LY4Dp@f&@w3$Zb>+9ZVSZn+KKenV%k%C?&$vdLx z;_@p=JN)RA#&AWS`FYdP7mmVvzbJeaV$>cjP0+0?yGx}6?Av_bzlou4(3$@*v~ls> z%(B-TzvK<*rL7%D<8x6Ad?A_;f|I<06+#66LZ{>5LksQUUMQx_7N{`q3KBn@LBW`!#QDueDYF zNfFzv5&V-v2xp|XhFAD;FOB7jd-Lt#Y{Cp8^kxC_`-rx${QC7{D6Eg<9`bIMl!;!~6JD{a=g5^t=#o)|w;M>Cf*7h>L z*EBQh0%x^!{_LhDj%$uTDEulT#dG<_{M@{6{3X92)f08aiE7{=a3UN6a~EmgAfG4b z@B5Cs&cNNmH+|P#W&GJ~l{j{gKPY?$N%33`GCw!(Ab-i^dTV$N1f3KG5>q(Ck=n4g<>gG-@jNR34cR;uPJ za7jcAPjDWcnHi4!r`R0pxSK{eOK#zhP4R)xwvhm*xhTV#K*35BZcwi-2th9~8@`U; z{TH_nphSP9wGu0_qQ-$=Epoq^4 zZmw5Z?g4n4_~fn;K}-9=T*DTPh>*$gMvT!H`SPhi&o$R9qd)WPd2a<}n#KkCAV{ zIUc#>repyc9Av#;oPE0_m8c|cDrawokK4?T)72UHce_m8Eei=O$v9e#j-_ypG=0>eCQ#T9BYr@pVow!pAPoG`udMufh9kff#pZx ztN-c@CqK*sB8c85)i;C4{GtpZKV>67kp{6sr&uV7$L(bBz$K9(w@)8A(CXmvYGDtb zC;ZG6KJtSje7rOs@l$Cpu9#?3FX{miLiY((sP&?D$ovu*LSA)u3uD^bpAsBZF5Poy z&u}FCmS=ZwtAodq-X1hZ|IHON@`EF2tg_c^c!S0I^#KtikCrN%?Tq;)Fi0#l^MZms zI8xa}j@y=d?(A+w`jd&ZIzn73*u&)Hf4IU#esF||i$M9`y|LngJRkyQKq_wrjQJ%n zU|hPsO^~rg4L__UaQEEVI~)nWTl&d29^TrV#;b%qa#nufiX8dD9ywkT@Bg_ccD$em zMD*mP0nF$zzXU~(SKF@&LNb2%qQ9}w^O%o|d6U*8!7Q~sLcaK)t_YDI%n0E!Km4UL zB>3wCA_m?iRWxJ3{GyBjp|mI|oes$vM+Uq~mXf(F*dXLw_Nq_bFO7y>342I<|5vV% zkRQyD@U_D~UvNfcZ7=&TX%Zd`!IX}?lQR64L*8=PnwG;R zx;<7N@!zgkksr)hu@!vsucbM7tYiD>0TCBp6Y^UF9P^7ZE^InJQ`pMWn$WW~C8NAM zpMv|t3vd=I{6yr5H{LI8idPkTv^?iGu4s`T%xE#Ik(W^C|2U&30Q!K4rvDWBSkYvD zQASgM&a=X{GPdlcya*i#hgyjb_suVOSl#C?WJ2)H}4?WL0d0Z?Mv}8>|h;5IQySKO^ zMSd_NMHKpS8v|jzmR1SG=LbY2yhbW%MuPc883{ta`$SRcd9%5pH5#I?ax#2!u0c(5y)kUq5AZkK10tfn zEwr(69P>-#h;p0edBUo)b)pR?ldulmiWcd#*wfIO(UeVed)!Q2>WUlr!HgSQ!Q3`y zq}YCXK*Yu~q_SpfV}4P_hE2y8iQ+OEV4wwCl3S6cT(+l`X^NEF9tY{mTyY>jm~kLW z-TV+|5XkQjhzRJBYMK#Xeo;n%RB%z0mF|cAFs&Hed}p+kz9*sWj*mao<#_qQbUYPV z_-&`x>Ei>!2mXn(&ePxNl{Sx+tv^B6-=$1JbC78?x&Q(t%^N1Zh5#XHsl90 zHUeyteV8+10-z6wIO>zeFyqMlqKu;eozDnzGP>w+6T}^ymz{cv)f12Smhe zm1Z#`&itYoab83HzM$#fs9AVw*1$?3uW7$_;r}A$NEv&;eR{hq;N*vf0Y{`h@Ho9_ zlScgi|K{;i(jaE2nO~X?HPZTLf}nq#;huy2c;%#Q-7=v^+BfI#zew|_V~@3GKG79x z@`EDQJj5RPgrI2iz#kAz+qZ>Iwi!YBMKj(!dS5T>9N9XT$mU~niApka%!pjN_007z zpoPKf#rd)}8vrie07Pwu5ps&BZL2&2MJpbA5~WhsC;_mz?}bEa{t(Xx*hx*$%+o!0 z&H!%Y)NaDHi4(j6ho|1l@N@ig&!?XsA&x1EpQqvZtjt`ZG>e$1z4eWccLHY59u|019L5n;%9R8h)TzuBr+Sgqb6Ne5y}&`p0`&nX zA}IZf3e;}{J^ngL>EbScngoMQ7$w-&o4pw%F65_nS1TFE7dCjb>Na>Q81FU8c43(H z_7<={2*nn+5h6LAOE|a=TbXTEOaHxm-1RS(OtlaE*Cgu1l9<3wVuYOUY_3QGyUCyV%uR z5Da9xzV3cDUc7}0`Gnp1Rwz_~!+tKqWm=#XUu)=Mw5Zru zN{;YEzaPCHSXyH{!E}3znPRTU7VT&)r$gDK0gn?guddeeItshYY1qo#hFZ(b)v}DV zfSbuehNMlq`4;fA)pB_$ESqwy^~^*#j<H*`&8DV|?dU8SP&AlD8u|m3S^8PU{&7YQ6*bWrVD_0%OkF# zNq(;u5O4rte&>|@^2R9`gTo>j1D9W-(iLdIa3(jMNY19aW4M8(n~SU{X;<^7viX#t zTzjdC@(eD~75O^SDI6wrV0@6dI+u>{B z-Y+0X6%0eIbL-8o{%$M zWYHfv)aCpGG*5VtrcsJj6cmQvvw-UmQp#J&tZEMJ3gQ4WFXHDLb8ctNLHZ1ZkQ@TjO3FLvuJ*b@9010Ijh_2bx4cIFB+AhxBK}@+!Lw!P zDG0YIxWx~EfLr?*FH6c7?Oiyy%2p!Rl}Ov7;m|Iix%ek+?4>ukg|i`d^#HQ2f$Z-> znyVjWnrFN;vuUX1*(5tUs&3fe*1%jL-7|?z8uI=WyZrA=ic}4HjcG@81F|UEKC8w* zZKk&;*4LFHBp|vx20{M=9{vY7L&TW3MW0TWPZ>s$s9g{!A8LhC(nv$s zn1d{zuyG}4JiJlD=qKFvy=)0D&2(~4`YB)tFJ3PR$<-mY3&$HUV(;&soI(e5;!`G?l;;GnNy|%8o5A08Wcg`|;a-h@iEXlmJi+hyY|n34!0i z4|9n!%2F5EaDB#y74DZYO5Ff^(j!@|_q@XgmOho3MI)s}J@PjHz!E@NtZXxZAOI{2 z!R2kkRy{*1qp)F%lGEFjRa^92+<8Zop@qr*91Jq%s+j$p5$%bU>&iGk1sw+fBDZo- z-Q%%<=-ZfI#*<)+I@rI3w0k+66Uiv6RXU03&t7Or?IN8} ziZoL)4A3AsJAorz)^4Ur(4KzZS}Rmq+C8nYi$ zvUj5G3XUkt6bpr160RN3S2504M00b8xgk-82pbO9b;nCaG2!g8;!5(k^Rfhm_JbV{ zkRgQ;&nb(*v=xo=u_%aCR{9d0Xf@q`B*ONFJ7f)&lG6+Xu@-wy;SmKGbOGtp%Crft z1TU0Q*n_go>*|RjnK7oaC+8CBEOtn%6WoKo*dq&g2<9MmmtfupbChV6Yvfbk=N5Xp zidVkFcpOmMlo>jr#NZ|_JXbs8CN;;jklz^r`h^EHZGlcGK`_9W5#fE-(`$1p+?`A% zQv?0Bwl(T$g{5OCoe=b*BBk?I7tALMGgG5ehrx$5HL)h#<{jS54woz024Vh$tdxT?vJwIz>o>u$I&O-dSZ2jWCiI98}A3Kz#iD zZZ8UYdtsA5-1{%4(TmEk6!2pJcNUp%RD=#lIm;|IDnrv{$->-RR_yv%QkIy-l&&r+ zt9Oi1Ey14I!rW8}-b#S_@kJhx=RK1wh~#0aaoB3RH7nbaU~3zuR>`- z;ue)SY;A$}0-No;+E3_A8qrRPY4$Oti3yg&4&;odsgm|fWmAPphNsF?%5ElwRgT9h zU20M|pDs{C9u&8YT|IrWUBv%`Xcs&wpg?xJksBVQR04*)d~pNNTUEA&tEtzHC;-m ze4&z^S(p+!J61!+JSC)MvgJf6naQ5S6zfK%d$UlBrb~$u=8dyT)Qo*HPE>D?LXxon zqdH}@=! ztJz%Y8oc4KfMe*5ySXv;9_UFX%4u+5rOK--!r{xx0SPQE<%($`=a^DX=$^+Cu=N|7 z)Wg6(sdSE!DCHJxojHIb%AO-#Fy>`9HLtWfuMz^GF=Y>5C@*A|u3EzRj#6o!#q+)SSD_d|o14=Na;8wF#VMd&! z*-)}U`v}d2nIcLvNs+8HVOcGZMc3X!UQh~xO(1Kzt`uN8k>Yv_6M@tea)G##C???$ zmn$MJyZ+4GvP?mZq4%ps3n{tnPDyR*z$i0}sv+Pn*jLA}4kavINEaw4o>$fwa0+hF z!z7xJ7nDdy;Bz^`EUPgvZ)(vxt;C7e7-qP$v=mtreV=!gYR|WaH}p(Hok4e?W05~P01U8+La556q~pMVM-1U&MW6;fFLH!<6`Xg zppW=)MAcp{8c}cNjY}m{HxJ;k#CDP3dZ+&gG*6&yY7kBnlia)n`WeB~JEN4EPM=KB zPKEkEa_90mkKiR^2H#i1K|6@HDB8u(dT{Uz8+L;BQOGuBRff4Pnei`f;mPc;{JGm? zGpAC}O#;)A=W;xJ>y>T@B=XoO!E85IkL_xX*>paUD<8cY=*=m6GVDe93~68At^t6K ziM;Q!kGfey!vWlZrrh;%LRmGFCD;SRYe2Ut{SU;B6e>qyuNFicYtydOCSL%{0B;+3 zMcGpTJLL=bGY1pUQ|_| z*#)afnkt{l!trKmbs{3Ty;BT{)Q#10g*Nf9k-C&-&u4R(|1#{f(mXIm;&v=)?^VW? zcr+)j$CIGvl+7L(N`z8>Zx5#Gk$3X~<<`G+hZ3Yt6AN?G1zO+$WJa_i^1(f8KGIIK zdk~&!r$KDud+4Iq36XRhKn7qqL615xFHLIqJ5VR$WQUjCTf}PzE|r z-Vn>0l4YsV1#@>yYC}niQABE0Ny?UK6=|7^hNP2=sbsU{oIciVl2G_ew2xOj={XPJT$|fXH zo)h}9z~f4#9I&%WnAOk>bamsVr*UD}+lSo^oqP2sCN_1BD~*=Mmb3OU*7`HIxCuf4 znB$(J(w{is#=V<#dqh_Bz}D>%vL(Rl(DAAmw#%AQVTmhJuBvn%!tiNRCbt?$4sk?o zyOJDC=HXJq6eMi0DJX^+EY8{_XXg?aL@Tf3j=*ZNq*@|@!;IcjYV8kHrMz{(Q~0d1 zaIrcKQ=@dMM9kKE3ZGN96;^{fsAr%DHmG^rvldvWzo)Nf z$g9#=uz29p{z0!&9f7QRx^@kA_j|QE6IiORdskm?mshQhKnaI>hlU2ayn3ApEY&?Q zI5^nT?Nw|kP{iKe{(jgQ=+$gnAh&_R?k=(J0%Gsn zJ-`$@f`BBVL|$klqdXVX)sUn_MuLzir94426a*wGC30I3k`(U|CW;0jS#t^9P^u0K zYDkoAnNj9-03(Wwiz{((+p%FISX1&PppE2dB@*TqTvX2}6_;2W;hGW*8}BXE+m-wQ zW+S&vjT`8*$VG!-HgemQxTKxjk~*aw=(CYqRO29_vc#JY#MuZIJwRHd#55n85qXNh zTEdjA4dk@DbEgsu<^3=di1Sy|8WVw#kl^e|q@Twi`8(ZX5OH8Ig$D+g1wrprt3XZ9 z#!J&E5vO5 zr#y$1l5h~oz(EdIzjcpOq}eBFU4{3`ihc83q+MC$fSfyW;I}F9`NEVq(&rcyomEyd zTpFV3h&4~F=4-slejaq18VW}?w_)S*uJCt!M5$<+C^)(h@5cRQ7FeI zctMc1WSFx}(OvF-50C&6mzx05m01oxizp-Z&BNn&@Ow@1J4`4`$f^P|Zj|P-WwFG( z?g80_$FuuR$?HQtl3$&rO+g!i)@ifCNLnyxr@<)D$`?#4)ID=<62HU1DY|lu{^y#h zt9QC3C@B#IsEXAl4j5 zPdDyBuYG{&teVPU0F+7-8K{o5g9||8o=^Zv9Xs&g-W4&bJuK9Pn|*{TbJZ@7Vl6wG z-#2gIY{PY)nrj*fXd`8uG3tcB?}xwRwIe9(AG&P>zvoaT_;E#?daIk7z>ly6R7C12 zJUn<-U|xS#wtX(l-b4w`-m*5^U*y(C`g=d@T|dMdd7@(L)rfeCi2Se{rZj-tvN+0Q zo$SN8+!&OkV`dkGFh92!b^cM3+ogRG7vvT#Dv_vrVVYyVV)c~oD)s0yFCB8ErMGx=8bj{KS;+8jL0iu6wl0X!xQ%< zBW=tVW3bz34@_*~`YUcAiwe#E^?(dN>CYXa0GuJIR`%d{qtpHc%0^!AcB^k$(Wh)m@&W({4%5c5 zYTlSIoTsYKd(3Y#MmW$M`2sKY-tK0aFC2kcYCuE<;u+?~PiZzm3;K40?vv;&LyH%q zih?Hyp=|v{Zj*~LiTnZz0G-m2Lx78@q!2hHb+1BDM}3cb>bqcQwc0~;##UbU`<;)w zY-s~_ngjbKU(xM}PS4)wZTIwfl6A+9Jy+m5nB#(l)nIro0ZXc4WVWIM zwKpDTlm#rq_Tf~(>RY)Jd8c^|G%djO8r|JJM%T14)H9G8*oDZ9XJaNW)d6m(&pOBt z$nBn`I%x;GR(p^AqU!cIx0O#cvtEgXJpK?TU0r3yST$4D5zO?kwd;hWfRX`hoNJz3 z$t0OcR4Taru`U{ed#;jRl@Rj(B=37!6{yeO<%_~&8;5D*FHl_bP;|x#h7&i&?Mm0s z-e8pOB+&~w<-Mr;k%Eo54Q)}IVD9G zUhI{uEAb=&)hZAp?x}XtL1j$*05K#4wOnWh1NB}SIyMT2 z7hogLA=oYe@}9qrL+$-{yF)yaIB5ufV~cr>?agAN z)S*OS&drJEh`@N;8)&pkmECZ+_MAO_&U-v8eS$QR>zJT;tH&Xtb%k^cU>B5TNs1%b z=LO<5_qaXl>e}Q&^I4Bfs%C59%~}>$w(wBNCZW3* zm)}TX);#2;p&aSWi#_R$DTTX9F-56)niR7PY|tyhhNtq*^v&6#Xd+NPJUL4t}lRXn;GhwW#*H~}_xH=sJf9|X#U`s$Hd(+NB5$agAyz?a8 z|F+X6Lb~uwxUDdsC}ww-;nus@l&})`VdRA@`sA9dMYeLAAPvz)SE{3nQ%w3NpEF5| z?N>W4jz>9*FNP4C&WodT%(|N!4=sYw_3OfokiFurucv!DtBaEyc8=ji_8caM3OES0 zx5F9FJ$M(#E}I&sX1SPWpT6VoO`l#=B*Oj_CcG>NKjib_5Vpn?y}dYvU;7XbD&j4m zkF)yG4>SGW`G=6?hkA-)$JpMV4vQ>|HpM$R19;`j@~c_wfd}#9Qf*r=E>5_q2f`!I zV!^+9J{)@#VgC6b9AE&_^(Qgu)R)5|jkf|qN{ja1$+TZx4~I4!K&A_EYR_c4ANqbc zbgl3n80tlHzlHtyUtbA_K3qw{XQ3ibW5GZC-{BCp1Rorr?R{Yfpc&wU12{#n(mMKs zX!z9@(#LjXy>;~II=g!7=EBqMELAaIjfXrmxY67nG2*2x(|0*ko$NIKwg+U1zBk<5IcdEVhnn8U zBgS9;O*k&HQ5VCkjk}nGb;$bSk|7(1=kGpD%O0QdaPZo+Ii|P|3QkUyc9JV*7Iwng z65P)io8%>iNwnOv!}W{Rhr{mHK47r&%2qYPzyMpx)fO`7$7X)Ll?+gWdJ7rQk{26kEuk z8#P#L9Rt{Z4h)uC$$;iUTF8JZ+Da=Kpa!cgWUvc;u--}rIIgR=j=>;Rw2f9Wz#c8~ zs+RQ!a3}>Bw6~A}9m%57DJxBwAHm>+}^P-%9 ztDS;$G;Gp1PcCS8g-jbCYNO-Gg8oRW=%YWybot(Y3TKi6ce2phgphqaWZA8H)dQy( zL4jJxVK3Khg#7W4A?KY>yo0X7l?qERaaw{3&psW4` z?oVD7QZvTOh$3bdL-wo9JiWBxbiH-v>FvX0f8-r(p0`{YPAhNMpdV*8>MhiuA2rx$ zAp=?mjI?Z>sHb-jHE3@kgCWdh7hC9LY9>}&$pB3hZJ~*1`l_py46vaa37Y}z!Vs;{ za_d^5ewtq$X<1I*Gth-y`|9o73T^pC=>6D054J)P5umML(2G-V;~~4(vDNY!-mR7w zl`Z@3eB|-ne8}TF`*uO*uoyB2TaPm^NRu;SbKl3p>e6VXl=p(Iv}`X}&j777jJ&8- zyK#U4wxo;Vcu3D>p?CNL)Y;Tp$p9xnM{a4IiReuIxL6TC(Fzlx58^Ln4PMa#2D`As zUu~feXcBtl#Vzvz&k@&Kr@>Gc`5@#5+tv&X(P6z}3mNoaJy>iVgF)IrbE0+iV6YqK z>Eq&^n;(Q!56o+O&^)y#UQ4ghSvSvJ+%%|3obrjEw}?3A6072vXXuh+s`cNkB92{e zbmBy)Hn&x(fk7P2*FxTD<6uBbM_=Jt&j*Ec=)lf^SNa8m@aMPT&Mu6ekybLm2#U9o z0Y*_xjAugI`E4!%fQc}Q7RCOtbH5CKxIv2;@hiD|3~P(IJ&JbGfa!OcL0FTy4hH0d zr?-#+t&%*Wg$$^J?`Rl(X3+QnTH48HZ#(A%QHF6uHz*av%lJM;k`+(`*O*bqMW=|=b((6*-f z*SJq^!Q{c-ZzT|C0nf-ZBAF7%Ilm3`2Hv}KTYya)y@ z@WB8bCy8$7dT{lxLU-~2O(CzevMr)6bC@+~K~^zHW8(EzYJfdjy@d?u0<_gVtuql_ zA|LToG`?Z&cph$ug7;{Q6yLWO_gu2ZIJ$|AFWUfnjCfG;sQC_nAIieRnMR6Fz&p;u zM`P~2K>&yAw9F@Liyp!ZxHg0LI0ENI55UfO4$kjpefZY>`0gu}==QACIK1Wpq@y0v zz#E^*gx};eBYDbzZaknHO*-kXcn1ufu8C)Sly%IHKgTma4je(OBLz65lg3*G zfOVIjSRFf1Xx7xRi7I-ES0t=4xV#sQA1^v9u6S5A6|wz}?ApZymUUg64RDm5&>q%Q=&eP3Flc4B1wd!g1*R8K_$$xEL>ub>1ssG@Vwt6A>97xx#@emI9lSZrV}E* z-7hKBUazXyqJ;NC_Z4N4V~JBLKFi8NaHCL>EB3OoV$W6cChD{jwL6)Fr_Pzy2_VRAGm}XH4=4fHmq7r4hR57ju;k9LkxTJI5gTlLc;F{A^ z*F3~VO%(QWqo1M9?MdK;pd+3dK))v{g)H<2^lEa{9|Etnz-}#M5#l= z+|CTY#-GT)TKB68`Q+6Fu%3-X#ElD|b`m*0ISM~U?&M6`x+v5|qnFm)*Wbi(dY^fp zsM($oejFaiGe|4zs#;I`<)%y*E39}Z6D(KArw^kU@Ng?C8~HK|YV}}D4zCn*07v|R zNN{grL6WO~NlnfMi~19@+6lh*Ix21z_>R-Wb{Hm{>!KDusNE4UHrOD|`ZlIUvki@@ zVY9j6Z(xiezCjx>^*QcqpQ#kA9|c?XCuNhL_COW=VNfv+!EFi9jEXNbGXBwr3J5BG>n!-*>m51WFfh8$3fg{2@8KD;E+L5T!QHHR(;y zb8xCwlHzx9Z;|VFq9C%TA(1^j*6b-r4(xb98G;$6FF zwDq^_sKcrl+qDZPN~4cpS6EvBJ=A&uR&Uhy?V_3K_>&qmk-O-A%#o)u?9*!5uqs6_ z_l0%rn8Z8Vu7GQd3!*P=_qXhk!YK~P?VjIpl(7@~hPiAK>6DD)*?dJlRx$4BiD*y) zclV9M>yhQdRS<5-bM2x71Beari0gMvEeU}SP>$w|M7}D7AMxkraQcGB=|rnz2lVeL zumt6Jtm`&^axmBd##h9~tD=98`r@Qb;O;}%<8AEDrzTD%iqL}iJX#YGmBOBXSypvY zVDoxXxb`MV_`HD=ZIVQ>Qu2t=6-Z-uD&=p0bulC8?78o9CS8bt1bPZLNcc<$1l5 zJ_fp=SJKZy+kA#Sj;JFoxiJ{?RC2zCdM9XDNzB{c5a`Ed{(`us`-(@(jL8Xi-Il$m zxGh^!w=T_&H$YlBO*f6PH-sQJn1YxIuu~#u5*+uuTH!>)iJKhVs0q4uiAkKdm@Hh_ zLODAx!9yM}3JxQx9;$Bo6BVx+uUqn=e<67G=)A zDxUAQh7eA)<@3P-$}v0}jn#NeT}DJ}Xf1mv@w5go@-EJZtW-ydrz!nKZM?YhsisSx zuW%aIm!DF#RegDA+jI2IERVHnqtbVX5AEvX=`7`xBEE-*)$`LDxC%n zS4ktHG6&H^rK1`+%bQHiyANRaY;j9sk0%+g*KXJ%^ z&FtL*3ZPX^G{XU{Q+p!!f6sf2?A`-7Q1m{P3lwzL79!vW)YwF$G*QhU4!rD><} zdNUlz56u+7HYn4KNEr9UW(uIE=bI@&^`Myo=;_5KJl%ty-e|^3=;@^;Oiw%{|-;kyg?_t(bIj8(;(C#KXR2{wVXhQ}yJ=icV& z+yyCo7Z#Iw=D6gMU#90fC>1XmaN9@O@aE;UQ*0$`B1RUZa{Q2#;$@`hi``|VHTGs< z&pfC&c9z>!Yt$eS#S-3OP~ox9>c^ST%WjiXq!Kn>%H}J_XiNd*YGRIa>tkgjDshL5 z3g32o`r|5&*JfZ-#1uIbNX5m)h+fIakASEvDUBw|hAGpckm*{FOi6$pElralRt4&+ z$GIg>l#|&kIucl}o@G0H(}Qxv#G)rAq#1CXs3z8lyqb;T1p2D_=Nb5UP5m?O!#J=0 zxePx?l>Wwr=6R(>58=BetLmTej_ft{&nVft`e%&9^Xi|g@biZ9=fm*pwoj;n>M)vg zNc}U_bM?=-kD;ji8JF;D>R&NpR@6VEN!Qgsqs`7Ke;$Wlm;Oqn^*CyMR{b-@vifH< z%9{FT48wKx&sq5Sy!vOG1icLV_F7>ad_L%x-eB5tQ{WAvflKN*9d|CPP z3*gtHvdww{I(uIIa}j=CRR4@dSyKMIJC#eI?Cr|BzdKVvz;-nt59=klY$883mW2&n z>D)q*R?Va85~aj+7VX^;0GTuLKodY+YS2lz?}{)(O3WVI9AwZ7$|C`wxhg6-7Jz^& zkfyFlWB@fDfT|=gP)?{3Mm`M^0Vb}-WD?oga&;C_88xab5;${BxdJuU3NVPf}wCO002=wYoNvIY7o2;R>0`p2!Ox?I9LlVs3GtKWfq>- zMuD~|yWi1;Vkuj|j<7udQvxp&yX{KQUZ^KKW)O5n34$vM;rErG-_up>cFqPt zs`&!;YpVemcw!DYt*If#bjdgckaaaATY`AYqxI@a(7`zvaby#@soih^S%TcLO_}x` z%x3@$yQqO=djP6TYcAOWv{O^#iA*kW63x0@yF>{BgY=Ioi##_0)rq^O4khSnc<_xp zIuroOL)(fr8VSHa@5F{23ji%7GE;|8(Q!2>lPDF+85Zh90F2+ziw7VIH*!B00I8-D zr=Z^eiHb_pp#+BFV!-dP$runzYJ^ctauroWvUAfopr{2P@m92+54yUNi`k1uMfY z7hu>C04u@$Dv0S)V+?o$DLZvIu|Un{SO5^70G+xzJDZrTQdkEdO9gE1r$(!#a`q(l z@FyCBomp>OT_8&_no$D^6y);(fIN0cWV}T+iVjsQsegxa9PIIBH3qtFc$^mua9W8u zl9+})ZtTi4YLszmYBG_XIz-QZoDITZ>$R!|%wi2+Q~rK5ouQG;c{L(8HJZs%bF&cu zN==PbAxRgh=Y>GzK|FhaeSbtbDm|J@O&x*Vu^H@|rrCMh0@33}3AUdB(e_3#Ond>i zJrFkm2Q2K&qk-tjYH603cc@{d>;n3#ON|iM#SR4^;0ax#GNQylmzy}1nHqycIt}cW z1Aw`?g_1$f@tzJqRi{R?FiK5e!@8ozWfJK!^!ETd7XT{2_*AsObv3M<$idvDEqmCe zoCP>$Ktqg*M%56U3j{=m5-|bU52Q8}7DEB3YAFHzcL|joQNy5{=cM995auLDVO)*L zrczuvGXa=%9^W5_eaRqGF#wm(Kvx8qc{Qd`N=!|_PDL1O1F)tBR-wxh>DL)GY9Uvs zWT%cK(lqE<2>?Q)f&MwGgiJyzn=7DHt3enT%AP_U*8)J$reY7Z9tfFayPpdLU6Z9j zUp)XcORAp_K+I)vz_1a3$fv6~w!EN*7`bX1D`!MGUj_Pb2HPG4!ES!L8jzhfxQ0Xn zFf%Yck;dtsjsQ?8Q>~z%x|EpX*pu)Oa!3ifCV>)R~<&trrdcPAGBDM=}}Z z&v5Y3T9=vk><^O*4Z9~s4<4KvGv=q{QqMN!48@*oDmw+6jVq-By1%Fd?uGUS08!-# zZm$7PJttw;9FEF5)G(-F(x4+s)V_H*KE&^^6_p^nhUe5Mn9ihB^t=*saPP#_9tfAx z!qibPFieMH=Cl!rpM=FPSAh%a0x1KItR{*)&k#{2{Ld{w|7LlkO9?zwNN3?R#MIFe z7-?$XJRTW?aV|)GPFdziArGm0DFNr1OTYwjYT9uNW$Nl2sRASIsol9^CINMh`mQl$ zXL*#s;zhlwgXugpSj~Y`y{PcoE`DkX%$^#}l|T-7*@i`s|(74&#M;j?2H9%S9Sx(V6YFt3FNjbF%$5HIG$Rcn#5$8 zCz8k2=)z28YHtCoLKDCJzHq_Ia;bAo39CaV8jn{#glzU?n*l48h)h zH4t(b5Np8*Y`4~x5Nku&Anuom-p31sZQI?e^%jusEUiC`w{Ted#$*R+1NI`thid@) z0T|Z-;wGS)29U1YtZM)Va1T%Xp^asv-ObT<4IplXit7MrYo!K|clSrX&aMfvcsJd^ z6xTq~GlMk^z2T5K+FXNVH*Hz0YawwXRP-B-6&gV1bsaJ3m8rM}$!@x-v!;Wjt$cM2 zB%MEwYE+5to<7w4n~gQ^rtRW!EhN9}mk82?*;&qTzGwWJN>aD(`At&9L9@j#WoI1!M+Dod1BsssU zA?FZvt6E5sQwK?xW!JTkBwHDdU-zj{l;?kaObLpBsq1E z+-GVbsUH1{hMaUmUt9}Ga%v&To;pZAM)d;?IeRERwU8vI4w8E~EhO3VyoQ{;B&QaV z>X8nTx}&-llIqb9HRPoCkK$TLl2ZrSPwkQxk}{hgX~;>g(ScKSVKRL#W^QRhe?m}C9bC3rTWnAxX{+ z4LRu`Yg`LS@u`EPUZ$>vBsu?0L(U%TW#T$WJ}RVzBztNhG53!CyM~;-6rVasdX=}P zg(Nw(kR<1SXvo<|a_S(dm#JwXvGuNNA<>)BpKHiTH;~1(kZ7fv780#g*Fs{R-yf_YC-rf0EhNdQ zg(Q1wA<6ICH00zpaxEmusf8ptwU8v|r5bWl9~aj`Vjox2LXwBPb9`;6lb}$yO&!eAuuE;;|%?#HEB585;G7a5n8%10TiI%TvAxU>FB-PE| zZY<{jU8oq>LXwZPkR+!TlH}Cb_CSlPBQ<_n^Hl*ZqRRqnXBhagARwB3F~z{|1_7}} zTzm!t+aIsqFGN?UN4~~k^z0xYYCZB32F?TkX%aoMjak1j2#EE3@!L%Ct{@;faq%fk z@q7@F%=2UhKKco2t?B9L+EbYIa{_>z$DU?jCJ0E%2;iH7fT+yb$1%mf3Id`FYcFTu z_kw^Fxi4kl!=9+tdI(+kWzU60-o0VewyZ{(;$Q$pN{YXsLlL!(Ka@Qa528p7%Re#e z*9HMm>(#$t;GIE0Z2D{Be){hO0J|y4UVSwSdD)ZHhJ*{?P@Ok2awrgqoo@VjET$2N zM9o+Khmo%jL}Fx&e1nle6{njPAr^ne$WH{)#Mp>@pON1WLh==XA~=HTPB&fs7mu@* z+W%jGJ!x_(+Rw=HwH@6(r2D%W`RFGH_=qOaqB`7rNh5Jr+j9bG zQp|5*zh?rG6!YI@Id2O@VtrqIFC*^`LefxVWSNma3PfV-KJv%HO1~3eCAx<-{v<{Q zHJ#lwF}HdbBcBsUlX?On=Z%3#)II)7rum0~Nb>tb*z$J=A!#5Kyz)$sJoVrXcv7=MDZGtg1k_JW)J0c=QU{d(7;kh_a0jIyPy$u zJ@hQH9!=DJRU_(pD6i9_N%dWaCgpXJ|Hs~ZLqLS|P+qsF5lcO^??3XdO!I6YP3q%z zaDVjOKqTe!I@~E+)3OqsC5UU(qaMoE^k`x`A9*9|9@K01^pNg?`@^21?zwvCo?Sie z==W`pVeZylv)*2&hx0lezf)eP#hs5GyqLKM4M}@w8C8!awsqUJG}3M7dng0!(4pB! zlae21jRu2!L?;yLI^OI@$dEE(}NT%Z%Bcinl8XxsgUZl*RdOJ_t!G-jfDwKKq8K2568D)wq;fW35_H1bD{+mK$$0CO7ce6Mx}*h@2er!{Iv zFJ*vQF;8zKM0FyBGC)0=I0tw}OHOR-;u`%?Z!gCDS)KY$M}4&9qzrIGM|a8q^=P8* z(ck3=2^vB7QU(}#0waUQ@4ea?U@v8WaUG4cGr(TT0OL9uQ3j}GB|7-JrV}BQ0qW7j z2&w7FNppZ&G$~hH)UhWW@UIK*K{MpNlq;Uo(Vb4?>&c1vQuOH>QAfF=7EPKhjJ||v z295Z7>HK(9Cz2^w)Z>nQM@`4_gQ)weKnC{3lq+g+=Pe^T_M}{~qSMaP@!(sukk~4| zTnnk43Gfjw9gQdh)Upz7E;+9g$#mpck0$#4f)-8myB>XRoZ4AsA7z!%XEe@O`Y5Z6i&^)eHT}MRY#Gkz=&qer z_Vr_g)O2*Gtn#c*gwVX=Z8~+6a>Wsi%&L!a#WgMN)Yj?Hqzv$!4o$v6NMrooM;YLG zEt=YW9A|(!KH|I7G-iqWXcbti#!&_s*NJ4x09QpM|3$#eNgvGt-mViNvIAy_ETQ>UJZNp(<-nI_kPOj zqFUTh_ic}3%Lnyb{j>^P)3AI$WosjXd(fz-pJ(>o#oUATob>a|o<@Z9Q?|BUXcW}T z^wVVotJ`@M_?rPS-%oRZ@qc7FgLcjJ^PWA8y<7d1t<^O0x_+7itchA2G=A@=9IP&A zUV6ED#i5_}>~-k)opP`b>cl6_?A3I9L^;^%AF(}y);s!XX78g~+^H68amU? z*^B=f%h?-bPoCL}aV*^sh{W~H)qi7}uL(rrntpVGkwL9uKke>|YV11hryQ&Vf$&mF8+R&GiZ-)Kh4)IYGf?^1E_mV$DWjfoe&xYwu-d28+{YY z8I%e1Qx3MO(8>gToHI~e)eK$_TV*T2HZ zJA;s%t$mS^fjt6cYc-8^gnrJ}bZRkWYZ;yRq}_e~%u z$OIQm;L~OX`eJ>(UCDvznSR(30~e`~&pSL1ffF+6MP@um2lL(@A!Jktd4r92Z%=Fp z8Nwe>cc`#Cf`7agA$5Cuq#7eajZZsC^-XsV?HZtFrO!j^X*0kqX(6ukAf(s@c%NV{ zdoy08fBF&ZqmN(Zb^!R2p6&+Fy2tsFl684^Hzjr>cd&v>Z*r5%88a1lhAdGj1Hq_p z`(vK&c4rk{F(2qN&G0^!?k*1w5b#X<(V0nlO(Jrd`|EFcaOJr~E;sG~*FVHWXP@C_ zUe07^SiZkw$Xh&+Z23r`LT{~iQ-u_M`j`*ULe&FMk{oBd0YDJjdqG?vZ zYEOJgOi;-nLh;6g((oi$DVq$UQfo}53@YS|#sbxqq@)@6|M<$4%{KOr2WP-+V5Hj7 zhDJ)jOCb5w1iU_H2!h!{jQ@sKewLenlp$-cN%NkXB(^s1tX5`*Vl&xNxq@#01XFw2 zZL-2SV2LC?A44rKwv-)WKmW76K~gei@ZF18sj^TsI_1A6;U7?L@iT6j&B&O6mw02- zg+lI{M6POd(m(01P^|WX;9}4^`;>}a7hDP(b)RCj2F2LQJ_X|q3Z~#eHhdYxr)b@y zAnAWxys!`G7TJcs~}K!|z*fiUS@VLBF@fyYp~@40gZ zXbqL!*}%+PB~~o%hxbR2)nBtLw?9I*5BPJ(j$-kO7(5n}%#6dslSw8u;vr?Zn`m}o z*$HTUk#hW2x4-aL3<*l$0I}j#6A(#w1ukdIOVGM6$YF}7cuj$vpji`fx+-Wq>cMs; zJ*FD-=vS)dA&D_|ri|%oI_6+n@i3L(VzE@1iQ#{;IRmTLs>p0UXI3vKG+ijcgOBiB zJG}OVWuQp?W9$}Vhm_b^q>?EaiBuB)Q?ZrWXiy3=qoT#*d;|1!u8^Fy;O82^t9cu~ z%n@_$rS9O95#v+``gW65XBnQ}j2(o>f=Z%ot>5B~Bn>J~2FU_=($Xa=jxzgnY17pi zvsvym|Az5=g-VJYPF}OdLV3@^D01}b5%A9XdhWJcUBQ;8m6th}uP>fi4i(P0?jJSa}@C+d5!abxl;4e&(XhOaB}@S1DVzz!1{JX@C?S#-CW(ji>H5wRyd5i1+V9o&>1 zgN_1{SL{|xM!CEb(u9f;(u9`Qnq%?qye9oOoSy+b# zBOVRBBBhLzN2^E|W`33{S?><*|+hMnmj}Y=ncp z!-Fis`-eL*UBSO#nCwZU#50BXkrP4UmDXc@|p2XJ)wYnBsOPEb-OO$ z8x7&KBcf}WscXP-3bI`r&NF(;9%*EiaJj_v1!ne6f7BcJ1Jf(BxKR>AgJsXqz-hKT z)WSnJ`lr_|qhhp_Hz&p1=(%Z=bWu%u8e9w$#uJs)J`uiPw6*KF=6)_F8%-y1o5Q4u>NU61AD=Pi0ad??o2AS4$o9ZVwSz4zYm85QIqRt}P6}DBCNvHvb&L`Rd!$jY zqwYp&Gyzk#AZfhJ`hP*8j}XnYZ(MC(Y75Ze@W?4vf3wVDgEBCO;809iXSh3y5-HDczLuA>15vAiKP!e9^~*4g79GGc+iDsWB|c%z~K zNW{Z5ht)1LP=x1P97VP_P$iK{l_u>Db(CIfz|av2j*?LgzGe_PO0G8GX@;w#)HY9@ zP_%RwQ^#^w+|$Y_${)8PlWV4vOsBi^YD~u4IIYevABq+(d7KhkomKXI**Ez-Kf;gI{$y=`7^#<;@TI)f&e`mwf#W|T+ z_+7Nqz4kutaldWWJn124x#@)?i8;e-*{IU8?(zrWap-w3fx2g=!dcKJFkjPfh6R3O zuYcQO$Ky~n+5iu)G{a-cqHh?_bKmgLK7Zngax$CUcT+Wy+Ye7Lvxn9jc_@n$jfV_; zdD~UA-BU}Qx*L+yv1~e1VRq*|?4-l2NThy=m%E+GOU+ZQoea@<#=d-NvLME|nFbQd z0#x@|z@ko(gL$s1!h||Sju>f1pVL8$Y3ZmAwu|X**TGtu_R-S5xngC3%MR(3-Ot#X z4)zFRH*~O*jBRhw$B?f`ezv_sfesx;w!+M^OQ)3d^}e#0;9qO9)Ny9E+H5fq1818q z*TW1~nlISPCC})TglFd&J+6b^$Jj+3EKn9PJ*ETSH<3-}nS5LeFNmMe0Z)o7eVa~n zPL`@HM??p`Kf&PBI&$n!~tQADm>rwpUW`7n0j z_GzK@7jgb#+0HCeots+#3$EP6Nl3L{CLt0rXH+tU6ww`ptw8MNx{}~*HlM<*jTQ&* zZMy)BkyHJb`HA5v?1yAU+q1Ne0u=0pC5;RKO_Ib zgDh4`hZDGH9Tx(=Ye>zOH=%~SEN+eE~A1V}Pt3_#`h~WQ; zU26VAbSUB>N~*cU0?Z^!icvxF-Oo}}?CztT&x>zm`#j;w0O%kc!CHSKL#?SaulC)8 zwEK8P2RcLxQ5#Aq?u!@_vt8S#IEWtn%m6WmXpeOJo7`gZ9>+mr2LBkm-4G}H#ymS0 zy$bbo)Asan4^cm8KhAD-DWS=em4kWFLoX}q7@~R(iuO4OH7QXmK`5B3hHWrR?nDp} zMB9(MN*TJ?0BTRRmx8dz!HZ0Ctr5(|{%j+xo&RbOn24HYk2i!`@@5)hS+8OcZj?8L zFmgNyNsHcgwZ?+b$EtawY)79CLNky!uq3s{XyU-=GfK3h^O{n2UaoE?mMEpmQ_yB6 zXXmI1KBr`0HLN{+Nzmc|w*>Do8?1D;lBrI|VCfAuA><6$_;S-u+QVBd?>q?`*9xVb zHb}bg%mQp@OBAy-#ZxRmd>W+~4sgfu@3;^s8lAdl&ecX|^Q;^;dz!~)o90nI1v}S_ zldx?KhTP@dWk`K#N%Mtlu+Lt+!H7eWRva+{C<@9y4~a6gKB=+E$#GkpE>*cPw{jbq z*zJJ)DYhFXSDkrQe5X6lx;T46RLvFg2Vo~;7M9e?bEx;c(EG_($>QRsWTMNN zLN%9yVHb7X2MpPN-t4XmRtcD8)=SH1d%mxC^iAxTq|%|1q*cCz`~U#JTV2` zLN+x@rD(K=Z7f^hoZ1_;Nz^S{_!awmPHMF0hJL& zLcw&hHdWL~)0S4c3{5uy?Mx?=Wb9;Sm`U0cw-H3DY!Oiliavr$-J>E@Q5+Pdf?`y_ z`YJlF`fAlzjeFgH=iKwX&oXzO$)uSv|Ig?D=JO%+n|ro;OAAF(r=N$dUZLg%`!AHoYLF)NlCZiQ`;`u zbQ4KtEA5H5T71RRZk-*8-V6;o(w@Cj`wTyo>!}bSQGY$OZGLQdHWMG>Do**xVh*5M zo4}i5R>so(wCwCS8-E}X(T?(5*(TcFQ+v*6SBqMxa+a)AIJcLx+gw~@+NjE`&8SaU z3e_F;U!}oCYqG3C7-@@|@U1lX?CiyJyRsvh zMI)(v3p28F)IZ3^@U7*!(p#R^|W=j ze?u-w=QUgf=>97UeObA|wxLdswpd*y-E@OAzFkkzb8!<@$P2D$j&rcSDRibOyqLCwDW@7J)+)%s=3f^G7M_2Gip(V z$R}Rq8%;Byo(C<+a?Z!${GDdZ*UhSd4jNFhJ9Dyh20;m{j>NtFRKFRRQ| zZsd&iVMynkpY)ax1%YDNkjbp3Z$d8AasN8+(ZMClD%Kk+D%TONb2Je`=Uzyu>lkin zMR|45{LWZODPEHpiOGi2yt28h@~Xd)JyzULo;T}pvd3#laHSt-nI+3&BeAL`Y%3S! zRZX=h66=?*0kXI-eZ8RhgG6k2)iR=PGOC4-zxrr>nos0av$WJ-ZmEy32uZ3c$k*#- zzPl*XLnF+pq73i(*yOIDKEV)7_~p-ABH~|fI7Bb<<1Ne5W}1}G?A(~`r_cUs8H@TF zQzo#6C=VL`_GTy>>%TOS%Wwq^Vc_9xJ@k@NG%ibI-4SNQqfY_QncocUhpAec!CE71 zecuMLp_&V=TBT8IL%~lIG1T5v6Bw*D*dn9(A?hfHllkgp>}#Oc>HVWwI?hP}6Uiq= z`!iDFW%1|R9C<}$eI;1_BMsG}QpvALj=3%1i8s|j8X;io#1Kw7HFuucInOP#!sowB-M&3~V zDe4oKRqD?W^;&!~pN26`fKVlg8uiIXwwtd~VEHOA0!?SVMU};-L~a|MBv_ppWdC1c zbgI-{@m|E1ZRDjvI`x<4mDz4=vOIsY9%a~8Yx)H5Xz3jpqhlN*fHNRpd{&{nfwN6o zor%X%Jh=zzixa$z8Nmns<+eJTp^v|+ywqF#sa1}b@zF^8bP(q{V&vMEuQ*c4k&#ql z=_sF0jeev2(1e$EP#;z5qqyR6O&AOnnn7noMz84c5>nuY5@`>Z8C8bJq~vP8w?Sf! zjmL;Db%ZVpuR+2?6E>N&&9ibE9yUx5aZ6{&aJYD{UiK=M!Q9Qf5f zIx(vzr0D-G$-J64(1&p>O9JG=EtRvxzTnRRYPU&qubQbPPmDpgGn3%8luj4P*D21w z6u(|xly($*8TouCeOQ^tJa_m8vMMfW=hT+XetWinteo;6=VD?@#q^p{-U}brv21(7 zG*Oc~LlM`Pdt14MCciS3d^3>9CHgCTz6U$YWq7?qYYrnTX@ZI7EA86IAMv|U93OwV zE=3>Rd0mIq_qEJYDx-F)O|N#lQM#(SARU6+&3^IFmw>Vlnv>SIQyWvi>etX5*^*qDr4^6S#n zTBcQ`Nr#o4k+l3sCfheON_U^^Osi>O5n}lZaoR0Ef3a^_S8xb@r1UFR?6fNQ+wQ|1p=EtO+UPpexZ7WdGMK|{D5mCf$l%~K z{ep^R{(#esk3p|pRyHWN8LRtino3H>O0-CWLW1yD)>lQpMZ;xf=4N#!y{gZGtIA`nvQU+G z9ko62?Nx=AjKI}GE0wE!l~xyMl&lu$&AJrtay7@{O>xSOXJakj&&vv2{P{gyj-$Rg z_6i)7FYr`mrx-~gsqRCI8pYt{qdGW3Mkt8DfcxZ(-py1mEcqPP#M$_97(C!N!O1?!| zX8u5OEYVNnSL))+Vl7MS7?MDt5%nL>RCT7i)f}(grEa%4X6ZFI$u9@2VUNg z36;DfvO@n7^j(p4YbSoPTJLvO+hgB0;$aYplZF1#s9)h7Lh&lk_&h7>; z^|lx-V8m!0irc6##!{}07MYeLZP95d3+(uemQ^fcBFt+8dC#-Ht+H7(x*nU!H4f@j z7kkdfPJ>rpV~hcH-{!3KY)p^lar;2gznEM)y41$j;`Q>4=&a4?>R{WYbmeJd!1i5K zaGRwk^fVmC1dW#Ay@CO^3#c*)8n?;V`rJ0Et57Fl3owDYISE<@p=uBLGNrDRN(8GL;-!luCD8l(!N zCr!u1cmoAxeab()v|1jN(xJ{jXsG&2?l{fWTgjXlsup)bl zbjQgi=;B4{rURle`SFw0&i)~A(mS$K62hOOk zPcCMitR-w{K9hD)i3Ai#U>d${x^B{E5)IH=GHL4c-BBKzcA%;1NFUt{&_7DO*m*6q zHHUUJr2A+ms`zfg@SR--P7B)J-odwB6mF4L{>Qs?0NJ!7)EunHptdG)7}(`qn0Prs!t44H-QF8q!lK=H?_bO^+tuV#=w|cvsKXN zf--RVSUfe_k3l0Tn=r;THcNunMDlzOC?7gvTEj4#ws|3%Vl>R|IGq|34>~(FZ8n~M z&+?uNsh0?e2$t!b`xI@497O^&xm8T~R|QvrE><%`CEwAC<6ggx+3>GfGQ+VkwQ1O= zrHT4~no(K8-`G^v5=jU0Gn_dU#ch)JGO(o$-kz!$lEmeR8|&FDpV{*?x}^7{=^i0+=(%H&j77M zs8S;b6%F4T4x*Zc`b$DwW8Ua;Ki@jF(r?ls>c5*Wk;}O@^n|O8)%fF3M)DOJm<9eF zB{g9=?8c$BL0-HIBfuVw=&E2BB5g{`q;)q`L}6F>#*mJZKk;etz}_AcH6qs*EDSW8 z%L{x3e>%Quhk~1iBQlW5%M0^S|32H`SgVJWg(^&HKdoA~C@#NTU8NtkcYxbQbJH}M zUrl{8yKO%jnhJ|$P8-(Ire4e~;(VraeZ4J|;;P(llSW+H)XfW}+|^2myGscgC9Y%H z6_6Oy(;Sxj`^z%oQM1}=X-pR1PG-u!E2-6p+6_<8xPU~P;^ZPR zmZjZj>@%KD^69rMV-LO-WGm+r6l)`EQG1+8Bg}772}k|sifA5Z1ux~xxOB1x=hM=l zI+OtMmGlLT2HQ54BTBC)7ZG@&Yju4!^2WFR#Zv3&IR@H%Uqxfo*urOP)N6XOBB_3p zOAbKykgeNh@PwxLrP=U{O-*4ByPS{nk`ebhV_fZo3tPQR;8$ylYfzbq|dyjMlm z3SKLc9@S@l-7+G&ia40&txC-8r{8imK_3|Ng77e(9zq18?CR+ z!80-R^)_{WmZU#lllw9+OoS9%^nP_Q_5B?Bop(^RcbeBa>D!C((r!5*h_s#1FmOqQr&UCh_*Grp> z18%mvdAfy9TF3&zn2fz&{br*cG%uvEl^L`1S_Tu`6{p=pk$``zuLFlBt|K(7LoQ;4 zl!bBsu(5gQtKQ4B+n>qTMjW7JUp_{s z2-AaP-lU<Qc7 zaF0=A42O*9y3H&rXy3H7*)*bRj9onsdTwN_-WWvm*yjtVv}l1^csTi9+ZY+gVHbo{mR`8{k{3Wv7+qf8;cBU1gjvsra1dVlQuQzmM zkR6U}J3`ADpZTbj!>not86EI&e5jnP`U-oehGk^MHo~_bZfn7ffb)%J&oGD%kMg%7 z-RitOftuv?Ldm~#^xTuM0o&A_H|cCcT`j;8^`v6KSV*Z%+eS_ee@kNXlh+xog-0%b z6c!#9+7;JVr{y)Q@VkZfN7ZT71C_xK2yOa?s&dt%=MfA7KQ#?4+ncSCmhX2RuaQ=* z&-v#~g_t_YX`k1VHejXyx{1Ssi9!{f!nUOrHqVhL;Tx)j&wKhw7{_X1)cYY_h8Ak! zbDd`rZP}W*s8Mujiq^s-3-~UsNG)9MtynJJ@mhGP)#q6~=kS;0FznCku3v3j7lU_8 zJ@~U3+q!?ycN5ZhB$2b5XRdEX!*17ke_qup6LZ91)(x36qES-#m$&_j8aq^Ny`KE> zPI2qolD`{oH0rsw(e8ZdXi^>vZvOjTG#9)=%)Ez;zqO-Aj%>3ulk|@+9?PG{lND|P zinTSd?R?{0@S~FLubA0($z8mJR}7=bY<{WXA{Xrv_2y~t4w3seQ!bT}`VdpSznbe} z*~T!-_K8O}7ggXMk-g}q>UJz9S_}ERq$+K*W%nOhxO}ywtDSrm{izi9apUF1?M%N?O!4{=c3>0JxPQeoXalvyUYCl! z_lhyEF^p+ZAK?6DM^l2yTqZqCYj)Dk9`GHDIb~%xE>3K@2iqK9zS|D$0vn)_oSMg^ zGhuWXqDB5qyg~n6R-RjL=b!95v1`+DZ%{aMdO9w<4;#1W+P2#AxITQe20C{CSPk~^ zh-pC$blf}yPM+@y{#n4XTC$O}%Ko=y!bAFCn5t$Yvh$7>E9V6)oNt~oqTDWPhgQ#I)k2Fo#en}P#gW@7HEn(^v|U2mR1585 zp-O0a?ovw&#Am-Vn+Ojrmu?h~9-i>l^0uwT$y>MB5UkM#t|!GW$_A1r&GiVE z4fN7I(N2Q){r1UNyWBjqY;Vb**0Fbq*xOu_z1<-W-r{NEvsTj&xG7Cdm&w`F5-tBo z*{j-{VvV$17$t-Dug1 zqjbGtGOn*8u^yB#+V^9fv019ohuWP>F#BUW67j*IMRd()RZr2)vNs}iV2Cin>%H~scz-O$xXPk)kLN~CACrLgtn*SL8}tK*Ow?#cBlJx_>S z(4Y`;xvpI`OIJ$U__|x_>$)CUmf;4fUomsIx%QQh*LD3T|8L$U0UjV z)v|Fhb@E7iYKBZ*{Q2RiH1f0!9lR~s|^b*4-_vN$wDCbeexw;3|2i1_;qnbdm{|Ck|@+JpMfnK3Qy;5PkV zGi2)I`tRyO*%nR4-1Ab8(QxwsoB&6rCS@#kl% zi=#dIg_&}x@5lRR%EcXNX{KCi-roA+40WkPfzjd&xzwd%!3So@)vdlxXUxT=Y<+2F zy4qDA9R2bPxzuaY!3Sr^)yAbA9*Ws6xBJ@Tqst3)n1+!IuXc8DhDbZqq~>{g?v!XDu| z^0q44T=k?|JP58rja*CA_$fLex;|br7e{>Hlfw1(chzKJTd0fMcx$FyogDGMnc4Wb zt#t|a$>C4U%))jxLMhFZOFisd_;d}rWL||9_6J9%8kmSo~EX%vu2c*i>WjU#xcPP z8Yzc#l2|I-7%JR}?{)%AvRHv}dtw(~)K%f~0OR$I3f!LAza{4EpE>ll*EqRTyTw>{ ztDwW?;A-&p8F6rR`{0Z?xM2(%E1(sua+;8~F1ZgDcduUZ9_@8Cw-pM}LcV`;x>!d*|XM?eWEGXzoKvGGn17iLS221MS=5yxDudA7#94ptZHFf1o`PX5yKgxLf63SA4 zXmNMEYY88PFZfc%7q`YcTl>2ci@Re?IqpZDVouIqOWf`yLcH0ocA0Q!B8yE1je&|C3NUcG%E5HIXbas z5KmMlrW>gZ(xNYEn?XBi(5h4SEeX2*BQZ#O^meGzx0JbHtbATxD5;TNs_x9g!ypq; zUpg(Zmrm7=kjQ|)NNiNwNDFqce!jed$S3_Jd&v1|Mj|iykh`*`wtf+5$j6Yrcr2}s zf=lmLFd7Bh1v+az{X6*1Dv~+nqn`Zb>QX9mr`Jb^{;!1q$1_r3OU2M(Mu?VzNlXy?qS@MbLd z>yC&fW5a@r#Zf?}?5UPDkB?te&BsHumxsr-t;V3TU<@iEEIK|NTkq;M8&@0J zvenp}Kwwi%ozZH{?6t}|ErTuBmg7!5h$}wym_Bf1t|P}E!yz+4O;)~Is-=s5G@D87 zB95ZLp=+#DFJk#bR|jpN@@>6)%d2ZSucy4vG|Ic2eB=7n%bmV@65Z&-ExMAF)31;1 z>>KHKvFxjb#jB-guxLjtoY}suVLJ7a8(ox$<#+L3z(ud3S5@e7^VR&@+v^3*xuzNI z+49lkarQ#P*|W?IM&lkO=bK7gcSN^r+qHg0Z`b0s4s+~K8Z8eU+JM@U8;CPGg=jLq zOSi2BTpIQ}yRBqWrw8if3a}90;IG@OV?~!D6K~tKhEABstzxDvQDa8Tt6&MY*b}%z z@MCvr1xysD&4p-G4;qas6R^8@2O{mR!spJIw@S`CQp+I{(sS@L@|p8XJ0qM<|6P=! z)YWjf(cx75Z#qQ2h+EYX4N>#%{XNA1#CpZeMUWN z+{45qPMNi-iIeQO_`-Y^m#Oi@-`d2;&P;B5Sq)lN9zMFb`Irgc^TZEW@%a+6=8S zMAH!-tS)?A+2O%psFGlP@S9GV+IPl~;h}r5KkicfwZgef=2t~_;1t8SPhiQ-Fz2=K z|M{3Ejgj496*a<&YL_C?x2TZztTCmbiI&k+4qtjpw|OQK{pwbmfbWwkXj~cQWm#riG8V1QvC3eujE9Zca=s{~kG^A5o;Pw18GiGaLv?`{0upI? zccMiDt`kNh?BV1X)YPgfX+W%2b=GBT`@9v_T2v{-P&eX3xIQUVJ#MLzs^M)t#!T$1o${If4Ud^Ar&qy)b%*fD5c{}0JA?GZ4EH~)B4!Wd z)57o@>U`Ba-D@JfZMLG3*!#P-k8BJh|Bo(rH)nJw6^CS+?%W`nL+Fz~W!vW|b1LWc z>$l3K0ji$RANtg~9s9SnJYJNWa$ASDQ|f%2_V`!rlGm>%zTnn!spS^=m{T&E`f|og zM)?>=Mp`^~PNGIm%30Us2Unukbu$JHMs@+!eg5v3X}OZo3Nr~EBcTuYRWyX6EHA)v zsWY#k97%KibQk+p8ZxHTQ5Z!og}=`yN{Da8GSAI0V->?BPBotH3FSvfN&ggr-~*p< z2Wc~pH&_~o-5uKQic%|b;9TK&MGgwaJWWMqcm_>d6F@t$V!~|=y>pLVkPM!{b;i!< ziXCRFrwLBgfNBo$+1`p4s2T-7l;DR4JeqB>G`~YliwN6OQJ782i!U3~u35I~4B&N!uEDsW<=^nRL|NXZht?A}T#BV@HFiV;fJU5XBTW z(RnH2DLQMll)vGKBnyjP<@rKVB)uRR_b2HANu(l))6uqesV$h+hvXB*d3n{-=tX!d z%5u-jMAT?uxv+>v)wT^8>KnOLQBErwvEq^L`o!P{AVwb#l>gxMM=xY8y!p%r|mr{=mXQhWA-9~O(A^jPF_Mh6`rBFooS^asZ} zDnqbhkjsGPqFiQ_g%nVu9{jYs!U)Z(2pYzUS$!|*L|TM z%*BSq@B=ka3+2ISD0N&Gr=g<{FcCO84IzDU3E}>VgyLLO;`yk=U$+ZX$EBLfanH1r@qJ?=@pn2??5iWqnhH3nOqw8&xm<2mgM8PRM_hA z(#aVyZ|xn9(ff%!q~BMOk$l8GpL~2u6i-#G$3!SZXiv)f%hJra@C|U#;L-)o&64&R zHJ9nk1=<7Aimfz0**B=hS~4eOVq>?jjOnAZU*7~pVQ4g6MELV zUWV@9bMvQbNuwjw#$)Qhv*ly*!Oy!TIfJ2&P&*Hjt&hl%^bZ~~=VBSurRIwD)gi+j zL!oKNFfrdf4H<403Qt3ZONCZWLx%f=BGZuJ%AYOMkm07C=rm-lA!+CW73ui9mKy)O zdbDV=;-@A^XfRLX1}dnDid63MR7XY&-;naW>I=HqJ=Kxts7NBU+O9oprHb=n9?=|8 z6BsxD!4}Q2=_XT$>Vmlb=bjH~3z*Ca655NkaqjTElr(pi{MM)k)$t~I;uB4S(~y= zhF*>|*R|CAHp0jTTKOVE3p)?ay;=5ZrDY}kBF?~d<)b^z z=~9)?r`khndU`K#{cSiF=TSG_(6fvu=G=Pe5lN{_2eT5}dKbyOBP(d58@0LBe8z9>9tP?bGC;o5OSFX zHlvi+E?;=4ZKIsG&}kd{?=0@>as#zEcUBYe{-H#T5=(C=m*_G~ zyu)kE>I>N_O5MG=JlAwDe}4V#upGLgJS<(D zJ7T#CjHEA=7Mt!lSDUYk#>K5_sXe;3!sWiNz_OmUkmm5joVS^e8tg7j^zd&iHNbO% z=e6*Mlxx#yvynfo)*VFhM)b-AebUhKi#sNH8@jsid=2e5hz+u{OPl?2;ugu1Es0!> zBCVI#B65iB!<#76n`v#SMW&cZ^@mpcDX)Wx=>?Z+GB!?4G)-&MQ=_$r+*FILbmpLs zN`aQuHqeXkiIEyioq-QjQ7xkthUvvdXX=4Xbcfr(uIU9^HHDVTwKYdWuqMd^)K=u_ z-RJ2ojn?E@saG?Ku3$}qd26_unVsI!;7kjvPadJ1wjGEXE_F3YG^wCAWb>*{WSg{> z&h8i&p)-!^>JAa{FN{OUKE&-r{L8AuvY4T+gqAn;dQyWKdSGX0n7g3p1Jc2L^h=f7 za5YRqQ`kcHGSk)_O@QW02}{Xf`*XKMco=Ue!z2 zjt|I!A02h6ovm%GxV>9n+gpXUt+UH9@=!G+hiSGtK^~y>^O4oDZ3&*h2qMy*LvJo? zw{zE*rFYb*ThR=GY79<=ZEIJzwOJpOA=HDF%HBoYq23V>-X+w@2P;J(eQornI8^Ao zptQuX!6eVJ-hG0UdBsqdW>&N4Tof_Jte9;c;7gonwl&bSubL(qE@&35DO{t!I#kVS zLOonp$zMF@#IJkHT%}qD!pCpOh!0&|T%}ogilExq(K9`DnlU})lI<$W#oZlLCe{;D zlpSBGP?Vl?gZodbQe$mO{)ReG6D7C(^B2@2lkHqkjnbVfbrW9nS<+j5u~M$w)M{zJ z8{~I@XBhmJY@tg?5;*9 zGTWDFp<#n~m}Zb$hGSz()uAjp%0eZ4z}S(XsAwF8-Cmn%N`mMnjBQ4WE}5ryX4S#| z-l14da*LQ&N7ao+BTY`MgFwMu6>o2X7Vm^2P%uhgwz3JLP{y)&X&y)H%0v2 z#1D~>%@!t$!x2x;v>0BuNBmS4HA3EALED*?m#}Tl*`sWm)K6diU%Hp{U1aqCipJ@g zI@Arb)}zw#_u1W;LB_3b>AUiU<=i30WQ&G*R|Q?aM4JzJqK|gJ#ncDcLBs2MfU~fS zkD2+{uf2OBXe{WKaa=K)8A&Y9$7Ay7;}lfo`gG4)M$aC$y|S{RS6umU{L|jbT|>Zl zP)g^7R#WJP`>_$VON(E?Q9H1fdscKT<55#DS2C}vn?BhVv}8WqrL})?Rv#r?wcL%JL;Pl)t64lPpG0+vd2*38thA zawY^6nMc$s3{kW>S{>vW$@KI7k}wuN&bOc8&`zfN3xtxcMu{gkgrpVG$i z@na4AG{?#|kost$oL%dnvdzZmUK-k}%j(@*xr)Z8o1v3O@HroogH@&pwR6hZ9g9nb z#fI`7vD9e7t=!=bnrjD8=_$6OjAGMDw0r0(DbEorZ}691Qtnm`H-6?#9-he2{%G%# z`X)o8e$ye7q6yutncU!_u|--++oB=fD~DA+U584yOF(|y4svaEEwa>=5_AN?o0Djy zJSVltO7NvdGyzHPB~y@%50_VzT4azNbaI3YlC!ELr(npLN&f6z-?Wk3n@8(#^SCKS z_KmEgX&T(DV8Oz_+9gm+PU%LVNG8K`9HqykuX*y%i5~Pu&tl{%oEW))Ry<`n{+R@852l!`V|4htr36U{g@ji(~=W>`@Z1Gg= zHyl!sY+ARtrFimlm60FaL^!YH zc^Ebu47HqvS8Y&>v_af+EXpV1qq)Q)x|}GU%(twf3qW$zQRF%H4qh&`{m*u;YSG{v z`j3nza@&(5nWf3hqAV#%QQwn_4d&I!H27bTXhqi8{@5z zBs&DRxGrsX@?68?G!@*E8(Ws78jFK54Us>Z?W6N1L#h_fZ-|D?>((#hIzcWv1ozj` zMXqt6x}!gUbD%%0X9=&1Q~4ne&5dx<%ETDNFKCE(a{sc7EDAM3{&Mw!B-Nm){t7(p z+u4WJzBx6qLN%jHlM*@FKcDEMGi&;*cXwVsC|nzX93h8Soozi_*3!=u>aQi27^bVB zupxxoCebwBFilD7BStd0U8rPw;gPZWYd|E7(iu12-+_i+GPJi*>NaoQEE*>3uYnE(*y6X;Uwob_3!Mnh;oRPV z`fK0|;rbKHbeAZOiZ)7*-EE1UY@_s`_Yy5b_17YCyfIDF6tuZ3w~L!k?#@Kv{zfUZ zd$qm<&E&-$XslOs;XeKux74DR;p?@6a(2P$( zdEVaCpJYzIT=7xNjJn`-1$|=B5Oe{qhJC($+-qhZ7l&&Ef8ku5O!se2_N!C+^XJ%( zzMCdID|2K?j9NO^t=fC){qk+CZD%%-_BbRk zM@5sT>2P(2v|1yaBO~aZBin}39N91sOUY&0?1=DJ=O#R}snNWyBGEZ=MA9~3j+~HA zrh52(I&DYzp}8rHp#)76QUj@4PUG?)y@E2s3tkU*oTHZJ@_qCrMOX0g2bJ7uk4p)H z=7n<3;H`#9mBY14?KVy3x9g%R;(hl2bO)2o&~g&3n-0a2b{A8aqxut1=HjE&>1&?^ z=BlgX4LR$VQ)@Op%c;Y|jgC<&ly2TxLpFr)X1eP=?f*!G^7e-q?X%`vJ#~o$=c-{V zGh>e0wfIKbIz{Ih`t1O*<|sho8#zKoY&-VMksZmjT4D6`I@TNoNh*GD}KxRYZJAsd9}Dmgrn{Hkni=-RJ(6 z2+WaB)IflTMcO5WIWmN{8pdfoMVk?xqv43`G@#Qx+7N4w4B=|*X2aQo`=Nns9)hn{fNMN^tf zm$>Y(=Exm%#ii4vmFCC@U1glU#w->6mdSr+rj-`I>4nZdI#-;yU|@KpWrf1@X-uDB z(OJG2bGV;@o^2*CnB_K;!!^P_Wyq(6{tSPDWfm*G6=Z z5tDOm1fS45d9GuE5B?o8j=%nAnhm>l@Oi>J=DIlenBq-yZ3Lfw9G`0=TKP(hch9*M z+-4T$+zM_q-!SJ^aI1OMoLj-o=6mMc3T`*Ao^va>;e6wqTfr^oHFItSH=Wj;TfuGT zQFGm&wsG58I-~p))_=G|ZR57{_&N6lx1G(#JsAIKUvS&`zjN*jZaWWRSJ0ddzT3F% zymqc@Y8$tmyXV{rZad#R=T>mr`Ib4ig4@pP=GqE%qwNiIZUwiU56-z2+;-kL=T>mr zxqr^B;I{MYjkh8@oVYTU>t8gOc|m`2U?7#;wg~@s-Os#)!=w04IZm|w+lP1Zu!gCe z+Kl1$Jg`TMY5C6F8q?a!Fq$x|%u z#;%v=JziG@9w(h=I!P}~(0akpB6X{Gj*iG=Mrqah0_Sh?2eQ&K9;SAP_?UkzwVv*Z zCc+6^u5*c<9fy!KY>m@{tm@&q(n(v?IDi}CyfB;EDuYk$PgWCH!8Iu+{5KO zw^pOmSMhdI-bI3Y&!=&|>vr@R+UvxLBco`9O7%RG3@~rVWYoerWxX^*A#@ZkPY(&O z_c#=|gyg7P)VQ)^raoj@Gxeio_;IFM?bq85M}5?&M%9Zzd2dCUoAYs8A@k1KTM9U5 zO)^g{V4NT4n4DqhQ3%kkPJQFG6G~Gvl;fN&Y*m;0HoZ;8ke8gI+vpmLVLiWnGt)vZ z8D7`gs(XK1GEK)3LII8I@N6UDT-u%KcPb z3=ByQN=Gwevx74TI4N%GJgYr8@KWL?TO_)Q&_;EH{{^hX`qpk-Q(JGtz>=|~#;ExPqvpHV$g9iKab=6axZvvYTJK`ydYe!;*BX3#rsrE08;Kcw zTc+nDTMf3c>DlNiMT2c**=H;TT@ z&DEF_{6<4R)yhh0R~nq#@;hT$JW?Mm%TeG+3W-Q2wTo(*Wu%c7@D;x1jVj{PUy=wf zbOP~haVl=k8y!vbCaKJ>k*gK0Dz}$PZ{f(JIG9#mv}SoDykX%yH0JfMr`ehB*X%%nGq!JE z%soo+IgZjrJsqs&hJ%_ zN2ei%NBOy%OxpE$UeITFcM0B}U!M^U{;Y}`-Ij|~r1Ock3_aY=Jz+2-#=PF& z7){Q7wACl%&Le+15L{X+c8b=tog%xFMz7gag05!ot=2V`{JIzx;VJ85jI!4D>aKW* zE~9VZU!F%F!+vk)C~}XAr}?UYOLFm!mWnP3`aL+p93CAf7&=_C$1?ngkJMG8ZQt`o zZ|gMgNN}p>F1c~vw1o@yBxrEP5pFt;OqeO1w2}Txbn6j^`DZ;mASyzX_xVI`J z-I?d3aJ;P5o_FNMTeqxPv$bbE2mZ&rjtLyOv~P1yWNY8bjVqRJ?cK1NXrlP4*WVZc z?Yyzh&=NXWPOlL1-E)yxKEIQ0|6h(b(hJ5TN;>GMW6bo^*U6$-KHb{Vw<|poE4wN< z*eexGtF+5Ysmvt%Bct2sIyEYAdh~%zEPY81{r`4NSz}_*tEU`@qgb6oUW(jjT+EMf zP+~b8=!SrLg5=*Rc`0n%91bZdqa^mP~Q~7QpSi?=A1J zjDV+?OE`9_hkLT0E$WxISKHcn-99)Ij!s^)4bOms9x@}2=nObI)!w*5RSvo`nVN)+ z{PgI$Rm<2<79QKW{QH$WOhxXR2esWyeA${ph%UUR9RYNU#K@*3tqbvR#T!M@s*ynF zJ#(XUO?8fzxYB)*i&v52g7G?7rMO#_mYbn%lf7z7K5AQdJyeapny^5X{(<(3R#VnE zlZA1LL8_CUXD3QV^>EimYM|{ZY}c<<>48j7oG%ZgYz9z{Z(dn8l+*EBfo)wppC#53 zJmlNfS72S0&(n>PthiW}dux0!v$b<^YjOy`*{9@Yk~5!?T1zd-Hh$gXxargrJvikE7) zowq#&uc+0L>LJo-?c}Odmr0k}JZ;Q$aj9ChOXpH8)$AGdT3ryY#!O#K>bbgLvv}q^ z)7rk6OSM$9?dk(QTDx>ERjYP#F4a=)vmulf=kv=tTM0Rtj26I9_eH+=$rCMm0 zy884VPS=WcbE%dd66vp*mV6157i-R{TDuOuxkg8JhPc5l_>kiXVqOkW;~bx7WxW#{ zPx0v&UE5c=G{Sz9T53PmD828tD!;tvqMlW2Wqq$?JRpT;U(qK)OM=JnA$s>dJsQ)a zK|MdDIQkPi*3)}TG;d4KsmZ^Hxn#_Wy0yeoBQ$K{&0ZOvLd` z971}tc`JQO3H|&U={viGzR951j?zT}Mg7S^db-dvZCAWbLfM!-0gGo$cIq@aRx?t@ zWYhs;GD_{nqYVSR6>eRcziutOA-LjV?RGm0^wmW3KY0WZhZFCvpzCkb^l&=I)IfO- zZ1LOq67c-!w%CTDTp~Y|N%0qd=p>&)AdgpRNo0l>fvId|RBSIF=j5Vbjr5 zh?_SXB@w;eJA*gxNSmQQxuXI@*q-p&{VUK;=+@VcegAHJEv5@@HTTCWBRl zVJNj}qmhSfHHKUThJrr>l>==O+f>1|5q~DiIBhZ8R3R@@*HtaR3LGJSHQSOS^kr#e zKj_cld`8g=?c6Je5z>$SNLO1spj@;aAs&KSS4+Js4d{*ojWIo&n~$~7OQA%x(y#dy zqC_rtX(E@Q**mq!R`gr=5^7InInJmox-TH*Bv)pM>BV|7Bt6o{eFNDOH0E|(Tr|yr zeQ2~ha&;!nx7APinM7~xnrc?l9v#khQ#CcVakShyO4s-jeW)5enT1tOnqwm3QZEY z6RVY_6L_8Kvu)}|sWUGq=@@m{=pt5MVJoo!vSvDBj_9VFMDp--#5|e~)k@5R<4CQ< zJb2C4NUWa5?nVZ0ux<8E;@O2ZVU&iKFc;goi68aEEv!v(>9d?$SiR(#ZLgwrpH=-- zwWIj~J3*!i5Kl})OrBJ)q0$RU;0R1(x)Zf+-8|SYzE1-2V?KrIsXS-+RUUfQFPWt^6?(@z z&u>JBeZEH)*@Rh4%_CG+{dZXna|mTderQ@kwiGX2@Ag|zv!ya|kKUlT-|qv)CeOC1 zslNz}IQz%iT0PW6yWn9^%N%-xhMl7RN-m1tQa<+7vh>K?%c452ysx#hal_b0xl za1>GxO1DR6X&*a(kZeIfF8ryVTODIM)$B&}{ZilG>dV1*bBcy_vOK+~rrM--2gyg} znvO2ZsK=HAxWW4fJyBpdn#@O%nQO?I>>N*2)gyqLja6rf+a)b(5N?;Iu8jTZj5G1c%cmbN!F=A~;WpHosb0 zFg@)QIMPn$ZX;ANnKlev%*@?>sgzd4YqDO!@^NVyX=pEo`#W38j@>*1?U}K=i)lSA z-_!kCKBlZZBevVG$Y|1yywpOMfZLOSQ${;nKEwc1g~`2WmB~HU%30ZO zWQ9(VWVd1nSwgSrl*YxRmx{@Hti1g5{I>YkP-rP{K`Fkya`LiXHKATIlI@R;Y+~3o z6V9JUzfOy+SAI|rK|I97&^HoO??D%^QO23ZE2pHhRO<%l*erjuN2^mi6++dy|DDzf zl1);>)unn$>@1_iJoegGFLI4qd2;#CvNA1y*B-*GjxM!%M^>igHKjkEP%d|vKEW1U zF`A*lO_sjgMq<=%c_VF=VfW0=)w>@A9?hi^`FP7{a(yD3qEodzBixN+@3}tRzRg;` z$M4Urzx__Mv~kQvKO-@_=%$(E!2KjVzd4`mPshBTUvyZOyX97RYQ8_aA(vFMSU8{m zDSKF2i{Gb_&hOw3(p$y!0wz5!!gEwS0T%t5?5KJCe-76{DkHQZE1lG98eZz;r;7JRm8|>e`1WZmFCH%8n64`Iu?(iP0cBC4G;HA z4ZqV-rw<7oR$cUlGCf_%S6`_1B$lFE=d(1&c)?)_b}G4QqPT*nUMP5ZdC#Z^Zil5N zN3olysktl_%WMs$=Ty>Zo>bM%pDd*AG7PTaA+2eeZ@$2#MYaI8x3tRCLh}yq=x&~U z{%aPVaph&U?s18tK#V30w;&J?%i1`74Ch;V>G!OQ(Q9YWv~%{w=Nb2OG-C8X8`m?r z1p9-0y%*ie!%n52eI5p=d(n?Lk3&K8uj|-|asQb47EzM02PS(VWS~t{A0_XS|L}SqU~GE9;aFd+>dz5mD{>NN?w5*PAi- z@q>DPWVw~_OxfESt%PT5gKhG?`#-;_W3S~zSGNRLwh_VQXjvj!#u}@oH6&`98mtCm zQZ8E>s|EXqqm9+FSn@JdA1$l-aX*s^>7)U4Vtk9@jWg;vpdI>I_#rX#lhy?)Z2re1Ah2;+|D@BN_> zDwgod*#VTnAO2WB6|&PnMtNJ%wclJvFQwEjYd#UWcE!cL5=-L^h@~{02&R3LRNnOT zZNKQ5Xpo*>kCwd+(Bk$QoVL3GYSII7KJ7}OwGu`Dg*p~}dSJU2AA$H!|D%49t4f@f zhNZ0cHNrgrK zTu==~&z}0|8PRj9yriVoi+Q${DoD6Kv-O_-iK?HTp0|eN7Qc`FvyK&HAa2jc2QQTA z|H=BwC+E;j9ORzTsCE8zh;PcUT9BTGdn)TbhNGD53kJc=q{*>+tWedL*Ef5APMqHeE$apb@(Et1v{2~IRde;M z7rYpmp%{Et*^+E)4%JO6}JwxGy7rD@!TVHgxQ;Xh7x1k zdD+*FgmE0fwHrb&#d>)9M~8WFl1^xDrc06%y(t<<^M0J@rR6JV9yU(}ewI;zu}6=u z{aBRUo*eV;XgS@W&*T>+#^|%LaVzZoJ+)Jl^Uw zy)~O9T_-2BP#34yrRuu?ZPjOC*RhgT`q)Zxa|mw!$RqZUqCSpDXR@<(Lgh^g!7Iz# zl351&+6*sGW#Nb?oV`c7i90O$aatwHxA1RX9G?ABe`RMxN9y7XF_xBR)Dk>aPA;bP}ICtw_JL>gOM+`^Q-r z+^65qAi-e>exx3PsR!D~JAz1V6mnf5d^q19PUPw@%i{NBU^RSH9X!F}?IBz7vm*KC zdPvUeFG&kulK0j_s;A!wnf=D$yIAbCeNlS8d_F#WbRE1bvSrN5-(7+F3|b{ND3%j= z!ROGZv6E{S4zcfa>yS&R&X5||@>JU+b!d}yjp?O8ob?W@%FVJ>*Je3MuffQN`BbC4 z&5PNk^TpebA7^{JK1Io&v!#R5QN8LJbr7D+t0qr;Qmm&>5-FGDiF!&-XE;>ECpazrm?4`|2q7P zm))fXNOq#{Kz*dkc4SZQ*jAt3QO*RY-+BaMo!YoHlKo`fw$gn&Vzs zQlNi2sXhv5u6Y1Y9R%^U`lx+r%v=^!QWj8902BlP<1h|B#O0`y_O_>#D;J&ZS8e zM#Zm+mP_lTg^GG@X2a@bl!0QM{l6oYqZiUgbPuv0W$+ru^1AdO>Qi93=fw)kcv5I~ z4G>ohdXqJlmtB(KfHa+VIXRhC+iZ*H>*F|Ftq)2e7f-8CxUvEgTc~sMN%uXkCdsS% z*0q!LNQ0!~`0^H9fU#>qeSCtpzi%CxK3;#**GtzTu8BhaEEi9>7}d~>91r>G;hW%@ z5-zva$u+|rOLV0To-U$4S0~W}e3@5=dNkuHQi*<2C&^Nt>r(VcB`*k;aGU*8Pp?n7 zkWWZz;3P46piWW;>D#)0AT~lvRtXqhL^Jv3I;o&op-xbjXEUybajuSfvp2M(|^z1Wm_xZUDc(}odJ5q(T@aM?5Kse-!;5?**z?EgyLg=_1-E7qU!?D|+w!;3Y^JioHO zT9q~rD>0*&t@Ef!%EJCkD|U;k-c+ZYINQj&)RQ}b+hhgsfwSu4DOFo->!awILeHtA zbOcebNj&q8v+E<<@l1DX2L)+lTs-qgoxZ@OgR;l-Yw2hKX({1tk$KOnPcG7#k>yv6 z(pObVzDlO>_}gDWky_eq2?yWrgNHmiGC zY#rNZi=0n(f@XH=;zXYI+9Y2|rVpd0(pi0FG%wsXn&iDq=e3Mx`{}D&ZLP$i%lY-$ zGj2PxvND__4b)kgGhMMcksKW2YBf>kRyjtG8D>XT&^=V!VsXA)dji9>4?6W~R;A~&~#3Hns|=_zHM;m4boHHTc^>cM*)BKj5Sa}2XC0)-ADzzTYgU? z74Qz3y^U1B(<}QLser?Deo_|&2YOxV6a(5#Ya7|v>NCjMzw=_}#*W{r_D&U$t)<^|hlXo{#0oUX`ja0xjd2b^X zaG$)dfeO?!#rqqnfNS!BMk?T%e6W!UxF#QJqynzV^YO$(BSv;zT$6(zkq+n04H%nt zaYYOKQWRYI{Q3`m+qkJHHOadAJC3oBK+Wny%su#R;~cyd7kD}M&(ChY*rR}(ir|N3 zvhuf$a1l2ZS-d5C!nyS?gLdxpOA*OIYaZb(HS}Qm1+vZb3$>+IyTWT8C2;j6B$TZG%6Sy|(u@C=(n?r#2uH zZbxyG@yrJ6;8x?=4c5Vp_Zf}Vv4kte*$vjg-RScgtb=>f=Qmgfw^G3d>)_6!xv@GH zbANGi19W(%9=pt`$62>j*t;Lb-u)lcv5lgwjU%~CYD1)Fsl95nSGQ{=Zxr#%h%wtSwc11n?)vqQbQmt)>ky1JL!js1o(t9!YwPgVFk*Ux8u zt=#z4z1+qq`dJb~O|+9N|&W zFHcp?H>jx8wsIiRvftK$(R3WI^){J=xn0?j%p$%oqhc|Kj5nEFH*B~#=ydf6m)ya! z7oGw~O39gWq~u;|$d{7qt?+j)xr>ayr?#$0&@t@D@-^!-nUQ=;e`c7rNpi(8ZGrPz zvhfr@HN<|Okm+(AY4da#x6ngw{mONUF0j~-ZiKecrIKl0rdgKvBTBfa#y;prmE`A- zM3g^K!bNq!*ZN$BYaZDYTpyAPre36v(rYKs%bTF-^|hPLW>;2`qDlOP(De=@IjAaN z=xh2r;U){?y7vlXI$wAP)1;s_ge~?>PYA(OkGG9+N?sWvL;>_2rWP?5x+eTYC7ejR zZN9e!bo3?iyM`qi{mXMOuJfJpHeD_;HqAjiA7)xT7#EA9Lsg^*$pS+Wmvqa*iqSxe z;#^l$>c%B6_K7(Ed@6?j`}Kbw_&*Q)|HK1FP(Ghdzd{)PHvxA5KO49k_yXVyfnNx` z1vmm61s(t%0)7o}7Wii1G2p$x1>pOEcLP5LJP!Oz;61>Bd6FLs_*CG%z!v~d051jJ z2fPKi2%HAq5Bx^pN#NUn4**X9mw>+td=U5tz*E4#2R;NmpUQ&EBY+n~pA9@8xC6Ke z_+`KgfTO@c;2prtz}EwZfbRhA2Hpo827VNHCGbyyBfx(H-U8foq}U$?em?LJ@P)ux z;Psjw1IjpK@=0i&jF)o2Q>z8v2zvb%=`Fy)kM)q#0)hAFbbNB$39JXcdx7<*%Ey59 z0QghD`jh2eU_B82Jh1+Bc>q`sh`$P~KVcpL)}Jnu!1|NramJM2@FkMJe*+hQn~#$8 zBJjn)lfXIP!V2Nvqv@9mzF(&Umw-#4{}=ES@bjJ``T`dT|I2{Gz!~5W=x+gTLiv1x z@v)R2j2u4)yb}0(pdW|4-vUpp5`9M>E&LJCpU#;46QoCk`KJrGwC+5GF9L3g2!1(m z6nHzZ1^imz3E-Q6!#^fN=;sc`6w?KKQho$DdacCQJ)pOS&r0`jfD@|XS07u^>_-0N22Elt79~TH% zQCZRXBJc$8cYuq)KL?%!KH?bRF9AObcnY`+IDlIj*8n#GzmhTKXX-k!Cj%UMz2Mga zTek|ni803q{P8}Jr-* zDF|)`w%#DP2RO7#@TI`fs|4qPOCy5c3><`f3pjxE&jJ^(7W&74$9D?;CGf=S1Rq6t zSMl(A!OsScjtPDtaOpLI*8_(}1rGuj_6UA8a1nSMc=A?B|B&W?m*6jH{&x%hF7O2S z{}(uNo1{OLe9!g<-y`@e;Hhs){eJ;)GuK$5ibt`N09y`WAgtv{QoD$q)$(&@kLmizw9YN)joFu7fu#@8SvBzf;mi? z-a1k6JAlVe5_~ss;4!Jc-v-V;L(+c_9BdMN(lbO}0P;J4$G!=`AsK@{t$2r@Hp^l#?&T9KOoaa3C2|4 zt+z{mwHx%Md1B8efG3U@`~$}1?+N(txRZrn&xdd3vbW6NYNYdd4|ci}5y z?>m8`4+;Jf_(S0T0n#U*Ci9Q<8R zfPY39vpxH%AnE63;Ov(Ke*(DpNx|O$p7^ZbDNTQm;FC@zdF0Os+RqmNM}e0!CVc_O zdj)U_`m>D5Uq>Q8yOCbF;#_6loxtP34+1w$K3}E(Skr$_@IN#?@F}N>{>Xij-U>Vp z{?))upO^F@;NStlHvyM`_W_4LE$NQ~M}dC>oCQ95f#{zAeh%d^j($h* z6~G1HHv<L93(i1!J|uV{W3s0k z_2ekJqY|Qe9t`&9Qy1+ zRbPG$Tmqi=OtCln8A(4CIDC)b=K~jzzF5=WE9ny{yUn=M{?akyxlD-T$ zv`X+Ga0%&e0ggc5CxFL+zYUxP{u6NYERlB_O|Y@PY*26)uyu~$2=F-4(>fh^H*n#_ zLjOVFrk4o54>)j%;BPagcv^r>hJQhNWR0YsNZkadHzWN;jJf@7m-LOm4lPhCh+72!L5vmehcU~B0c&l zNq-g6hmd{)(wjC(`W;9gL;6>cUV?v~MEY)|ANd@yXL7yppU#-{??L*Dk)DM=)*(HM z`GO46OPFtXBhm{2DOA1)c=HnK9Kz3-xg?(wjak^j`*^`iS5k0*@m< ze_~ASbr9|KDbx*d`89n^=$jc+`OZiAhLK*_A?X_#A4ARkb0i+GKzbPZb^~WWD)jHw z_=|#zz@^U${xR_Q=L8=?!#=iW3h8G9TlY%(%XIqZ1?Pa9?iaiVIPe9*_X9^D?+3u4 z`y~Buz`;)lZfX|&yPfq#?`To^dlY!$gMxp^nDVdRM)?EMBl9j$^e50TfcdQ> z1h)ZC94UB{#zzU>2|WH3!In-xTJTqZry#!s9D=-mX$*O1oiF->koRJZAukRbeX7X6 z2DosD{y{&tGCq#tAO83>(j$M7^oN0`{w4SajE@fljzjtWf$?$FUt)a6X0bntmgqYd z*t%En8sO}^1n&Tj0>2wL@?}YX7`Rvz{72x)_X$4h1)?wd9>JGryif4!feRbxAM|4Z zPi_?aAaJ%%@UMUi>jgi9!hrJ=*&_Hwz*Cz9$AKqaF8GbWh06qg9Jqw^Zvz)EmGr*= zk0brri$q@&(w72HTrTu!;PF=oeuqxKP;e1AaE{>L0vE%A&kTwDN%(g$aPT4V7cX;h zey1K6+z%Z7mf&5$6TmlW{%=eAoxp*w3I2jkKU4HS4m^3Z;6DRTMFbz$D*8i@2>){# z9}x)b$M?pIkv$@jd#Rvlx@VCZ8$tUdov2Lv+`rD&96AJ^EA8p8^j5Uhwt6#or445O66V z^1cB)bwJX81>E$c;N#mx|M(MvL%;>#OEms(Nxu>}^drIV1#bF>;4cABJXQ4nP^bSw z(*Ft^{)ym|J4Aoe{|LT-@iCP3v!%UViuCM3Nq+_K__93%MXPSQ{16Gi!)!Jbf3^ z16w8iE5PH=f_`8N=}+qtdDhb2jvNdGv}4=Oz8vB_h8W=`UeS<(Iuu(qD=6 zZlqt2^zk=H`X`XS66qzz6c1Yv4}lkoyyAe+pUIf=vjz0akZui1dK~FPNFPV~1pKiV z>0?NLlrgst(DxJIA>c!dkEicBv^S@{h%m)-0r9+$G1*hV{)Cml7VrRY5%`V3(f9YL z_UI1AR38qVxJlt6a1izNhrnUre=sKhj^8fz^|T8GXTL-PA^PbAEsjsgz>hl)a9 z0G@n6@NK|>FAM%K@WfXI-^ZBz@ier@-$Ht1xA=bwxNxoD<6bQGg^_*^aPcjY{u1CQ z(q9f7yk63GYI?|f6JzrC0rU^=MEb-{LcbU3yHUOmAw7ch?*fM)?-#(u8-@Sxj46Ll zNB){#BKR4=&5XHy`aBK%=w}6R_(8$1VodQgiSgTOfwPFGcYwZF6#9FCCms;IAK3bw z;O_%x?-TqR#$;a;>^bVCqHhfHPX{glcQYn?Cm`<<#^k>e{Fg%d)P5=7Yk?zQ6Z|3I z(8Gcs*7S&ngTRG{B>kT{9sExVi@hhn-m@9AJ&y?e3mKC=dr)3cqzC6qe7~A8`LhIn z-U2)Y{7K-zwo3#2^L54~Km2sz{~2TA-wl5p0v-oGu1DxYrwaY^flI(k7!!XJ4duJ&^xN#`CCsIZfn0!1(w;;6(W238Y)cOZp#yOD73#T1xcfpQ#%ufqu>d zUWxgkrNB)$N&02LA>a|<2=EQSSzzAe&honD!VX0xlqZHE`rHN#71U33;z(O!^NZ9&bQ;@Vi3)Uf|Gw3BCvPdl4_+NBYFCCH;3u z--q;5mWh2+$4dPpQ+}r4zqbJ&0=^6M**k^* zKBVu5f1X5o^bSd%0v?C`Pgx=UIR*KB7GsK!;=|(4mjajgLz#YF0h~qpmB7(&NcuZ~ zCy{=)#@~|k$APCF68v+W{x!k>U`+W9Tp{s((nVs=_!S4c|I3)7-0f#S>^hw~Rze@UVfV03)dzsiX1snp-{!QpN09ykh zZwGL3z2KXGo05V*rRk3q|9uBI_!Pl^1P+9S{%IGB{@@nD9l(=3aZ5k11TL)<{CeQ% zvjpD`902|2fP>wV{v`0!i_TH<0;@$|(@P}%bl}O01a|`mdIY}$xX2Tw^m8?E_E~~& z2cCGQ;C;a3rwjkLfFlb8{{c93n&4-w5qpZK3SOx3)5P9&z>yOK?*N{BzTi86r_L8V z32dDv`0v1>GXyuU6@Afm!F|AiF2M!h@vFq1PXkZhCHSYnQy&+6#yXKVb+6!;0Z)Ej z@ausCMZuo{4uk*aI{gtzKRyC^PYP}a4nI@udnIt-*@CYFE`Ck$SAZiQ75s1D?B@h` zUn24+z99Gt;Ly(n->mUjg74P!LBR)rC%-54Hj7CzXTpXUi@=RpXh5kQ}9B@)P6Lh{aAza&_9HKJ8@y9tEp#Oz}F9EimBX|V3^gO}00tcTj`TrJh=(&QA*(ma+ zfWyE|=Scca;E6tw_c7qerGiVq#Z7`wq0cyO-wR`cR{&c#2z+zFS<$yGAfCvoW^bDfmi_&lG$oa1im!mnt)T6nOkOf=7WT zgM#16_!ycmIgK1eKX(Bi0R95-e5_}D2Y3PSFBp?Q0_bo53Ovyy@=v1A2u?385Zn%2 zI9+fbV~Y0>;+>zRRrI_NNI!dkvrkI=e;oAPp#Lh;!;eY&lfZ%R2>uh}9`{2c_& zenjHo$jimPray`Pvl)}T68M)RJ^C|Ae+6T*e+%^QMEVrcZ$Nq!=^tRs{wR=R=;!mm zVSI1>05}5tJK!kr39k_Q3cnD0UjQ7P61)yL@E5@a;2DFVC zo&pY@CjPw|IP|!r-@=&q3*f&C>4EP_`a{4`_@e|oh5qZW8vl>v|Jazw+YNcoV$AKu z?ILeIaQIfi*8)d@@6+j^|1D$ke;EFM`Zkf*bcgVt4Ln&A{VxPA0QWJb_OOKY)gj>E z25BE(3w$>YbX&mtfWOT6h(KU5xb=~jR z`R8~4(WB?%{rOzib*{6_+;iVhee`FS>*6%~(HaMfHQrs=T_Qh>V~jV$+8n=kk?!vm zkxR?(;Vk|RyZ=*u3j6rNz8WvY^>M;J*v(fv9N<3KDXV-m_V9B!i&ta!Le=lYK0b&; zd~DPAA@;s8&;X}mbff2dKop0{uke}NN!DgWErJm2H| zK40Z~bUcUo{<;y4{(RnT)^>gT{^2kjoL{GKz8N@OMt%#s7s~r_tdv}80ONI#uZ`SJ z?t@eK@hGpZd@;^6k#jgvSN;pTRpmO#?9x$ zl%K`Pi{#gF+WumO`T7ximF4pXF~0r94D)prcIL}naT*WBv6q$4zyV%~vo9&%Wqpo$ zKf<3UEVy6x@U?gV?t@c!R#ab2_wO=mvmc2BaJHPh*V;TUX7jv0VSTRoeNWzRoI6DG#}=r* zHg*`Vy|sPb&_9^mZ=m`ovDaE&VttPJyo>ek!6810oh^Dlb4g0|E^dhv*ux$kgMIu0 z4)8{t#h>F4AG0>czmfMVMISIW`|m%X^}9I3_1Of6eU;yCZH~{`s`Wo+UDCXs@%vBD z;{dP2AmPhYS`oTy(xB{Q2%XFJ^4@^(mxHm52$`A_V89~b3EY< zx}Lu!56J()@FruDg9HD3M5wdM9Wq~H8CHQFC?9|w4DRFBt3^&HHmxbC*W-TwC~{+6uSald z<`sqOtN5VmGcU>Yt^2s@?dto!unx2`>gzY)c>5k8OQA}nwhUK>aQ&qdr0%e zE|crxbXEE0D8E=9g8gywM4TKizhZ6nBg64;iOl|dfwSa);2e&PRDXzTS)2WHrfK{( zIPtW6yY;z_Q;Gd~fc`xFGpWyAuKL%ocZs|UJMHCz*ndJU@v!C(ua@g#=Q_D9&R3Ir z<23s<3Mc9)e=(|WAiop2mAoH&P2@8;Q(vw$O6!R?mK#}{{dW53`tF8f_yOvJv8sQ{ z+FZZc`7P|_;4G)!rG5+biKcF0eiY}gkz-)Vb=Yetd)T=|9*@&C<&`*IU*3bm zdh#)xuO*jxRP&{;kegt?hU{Uly8NiM*^iA}Z*y@Lzkzq)&v6bPvo_aTmg6Zt+W1_@ zsm%3N&D!Mga+>u1TUkz}4$o~r66Z@ByDfA;aR#9GnllVjIoKk-t2S024N{?y2 z*kI*ta0U;urwxGdlj>QQl4YG@Q9i-iWimtNttO{w)`b)A*U%s;`OD zcgVL!c|Cayc8{q)i1Jd(w_(4#{5#J6q52BrHDCUSd_B%yq~jfAUBo=Ud3~Epp88Yu zZ{hT<8vp0WeImvBl|UkJU2}BbFlM@3%LV?&jF9%d89R&pTA#9B1#7Z^h0aIfWCy>3W(P`6qcH4t&+W zXKnUB%l;oBcPA(>Gg@BrfR&N*gq@}!|}W1iPqL=lp+TZT2J2@tq|1W@!BK)0LkjZ)9!O7mQZkgWMU~qHz8(feo>G4fGsvz`)+cm7kx_WZElb*#<&vE{07i=9>Sy*M>regeBI zaHM<+r+=4Ar!{}>FZnWSv;QvNkGHZm>rJuVp48_n>3j^ssdDlZoa267Wo?c>#_@j^ z<)u{rGkFE_f~U2fBzZY&)9;dBP97Afza!2#@=)q)Q~x}U<2R{y|I_jA!^wZ;)6_Sj z{?cbOe*(9*Hs{MfSM&A6?s@WX>f2I39VhV;>a)~u!r}Sq|Csvj)c;JLATK&Y>+#5| zTATHxi>bd6`2g};$^9bAQ{*Y~>E!vc%9oIjB;SI4ypMXPwCaDwX?)g9t;hYJ^2#`a zueLVla}wiq!fD(e&&FeLfM;3T`{itnzZ!=)hjYc1=doWxEA@sje@IKeu1_@$;-bI75B}=Wy}anlF!Q;8)?^Za}Or|}H>v#+Ut1$IWr??t(*`3_-! zr*h|c%^#m4SF$$q*Jl0(QSK@4h(ml2PR>+5mHs&WYsgc>mG8DLY5sg9KTrD+pDfd@ zaKBFDKY2e{Zm!nn?7zG)uY=?E4hZ#Dk+)@FZ>@bkO>@KIdu1=VLOomaTNtFVikVXsfDFz<|Wcgy$T;68ag zj^URg+rK!Iu2}Jk~ovz79LM3(oadJ^&}MALRp;&&1i= za&zox044vA3h<^a=m;VdA!Cyf?fOFWkL==DFZn8KbAOHG=X1@- zlZe_ih1spP31%ID!c=lfM_GhR4D&*u%~;cC@? zgtO1dKjO?%`6PCi%O&TV@yz`nzA9J6u@~fPar_mzO;k^RckI5b{9YX3N27k`pNCBOjJ0S{E_TTh8x`YOx;nZjHaGYB!kH^^~@?0Ei!13VtG38rvP@sG-PQIi3SDbi5{yXY_ zQ$A~(=;rY=YXYnwc!;jPN z*}tgJd_9fBq>gvKbrJJ=&-q_Np14K%CTnwlSL6QvfIM4Y`9AEh|A%pKrSelamDT(u z7MbzP^C#f-yNtD&Kj6j4)@Ho!ihQ!QIUjkR_j|0(@nt!_i(WA{$KyPq z{sGoz{E_spBln+Ie#+YHcXjr=%`)|e4=JBzZTkIaedI~as=1+}O|2H^q z|DqQ2)!UP}ZR*{}m48P*oBX;J%AL{5r&^o!1mxe5XE@&LRw`dgKEv9KA7}of zr7tKTn`KM{`?VZ)9)U;yfEL2W53F=^~!zR9cPX!f6>}pe>J%Nej-mD zQQmNa$<2Dab(;SPYqMXCSpObtyZ+x*Ut^;jUVCBTddA{xE%`H?Ybe)yo&Kw3ABUI7 zpX2m(a`iV<@70!v;W+i1aHf&+bKX>a>@v9*PT9Y>(|j$lHphPn$A7}w9AC)uw9_W_ zho4j~tY3_C_*CRCly}~&de8nvfadE}?BIg8lslg)?}pRl%W&pnn_JibNs z*(a1w!2U$}8=Sdb^$oVNo}1ykH-1<3u_84--_Clb%hPaTfa(w6aD*IxPxV1t)sMv~{2@+^QN6oE^hn`n?_+PQ@~?4brt-!+RiC>{`81sFEq{kY`xncb zuZFu+AMd36X`H=D{sCuhmaqSi@lUJ&1?+ZKejKN}$T#m+efF^Gmt&`^@=_luPj{0C zVdpp1e}oh5mDkKM|1#x|;p|h&zr_C2a)UjpPkgTWnK<*2d@OPY)pz<>_5PpAm*LE8 z<)@?kdAZ9cs?Q#v9{aPD|AS-C$sImbeX@jk$eXVhaqLFr|6>0#jo0%t)w`{gufh3N z^0}WYcktaf)T?_9emHnVUXRl&1e)0FJPk$&6!I_=%CLHXN zOa7qxWHY%ZPPC9SINeq*dQkPTTjkrZ+e3Z@JD&V6PS}6A!+hQFqx#*x@(dgsB7bjv zj(PvU_XF1+VtqF#AA@tF+x@#?k3-oXMHEk zNi|=qtc#fQ%lq?^zblXTR()@r`CIjGTbugB)K@&F`owY754ARVp8P}dSS95b|DpUO z`7rAO^M1RW@?GT4@D_#ZtM#XH?=Hl4be{guzRHsibGXUOvdm3RJ2d2R9~)@JTCX|d;s~w)@FT9C*`}zQ{R)Va=FgEAFRnaZUwJ=klkX*emps)#d5sdvL-O&~X8u$;<;Spl zk$iti)gPw*XPn1(oTL8i1*+d>ZRS5oUcZ#`Ofwzdcx#h8BU%(bANG;wW~#sXxvCFW zsD8M$sV_nO4jjW}&QpCnruv7hO??IOZ^$zxm0xcT*5)qx0&8>p&Th?L^aACz$@^K` z^Rr#~R`NJ`jhOOy6^%d4+Kk_b{9W?Y*XqBxwDJV`Bi3g8b{mLg> zoAHz6KanSoDsNFnd3W-;*7o?mSN=P>N8YZia<8Udj}}^+x7rClPx-~#wr;z<@O&jM zlwCa4+OB`2#{UX?@5pt^DbK8xAH~_t@@|~^T&_@F^@->8{&Wy_@D?1-QGQ_s)u-_Q zoW*bAB>m@ARDEiO`fsx~Q+r?N_~zq0zaRD+cHUCntdjbZE7kuL_WscN4_TY@Gl2bV zQCaoje$`LGu@c(veK=o6u2n_#=_2xQoI6i`C(3`&c;{ZE`rvNO-__dw?a0oAu`T{O=p`6#1n!m8Us>_hF~6##?P|)|>uE`%%1>9Q0Y zzi=MkP)GgFB#rkpj^S^yi|f`^eH@R(3H&Zj;{VlCy@&6@Df}w-@!vR&+gz^x0MEb~ z9O5j#{0i0Q@F*PO_i!GUt*?6LNgaQ09K$QIi%;P=ZW~vB0?)!pd;oj6{*|hCXKKDj zafT4>&PT`IXmDPd*0c@lNbaR(*wQ zRUgCsu+Mm};VeFbUFthFP=6fH!3q3hWcKUohN{oLp!t35F#d-)Nq?nArrz9NG49uU zaN-f&Uu&_??^_pKXX@?qk=Lu6u=AN-pXOSd@dD}(`8bb%#o3msZ_-Nr&fB^kCgE_O{29)&p6WNK zKEy+CjQ&m7`CR=aTbp`wyxlqf-LN-8^DnSA*QZN;-rBq#cwFzz+Q=z98TlZ5q73%zRK-YAH(-x z7q7u_daKj zzOIwat0KY;b8tj&7dgz_yoZT}%c z^Hn^lJa)6(9lNdN#W-jtAH`l1`Py3;zl}T&r@G1?VxRR@?5uj9yq~pMZ;JIU$0PA6 z?BjM_)Sv00@u%W^XL*mcc|Tj5_p=pm)%ZEyFZHoD`;q5(S6Q3;VG`%>KXSL7#%tSE z`3*x_6zzAn9t+2kMPdJNW$WrrsRiWgK5GYcqdH{tEUVbqmKojdKsnJ#SaN(^FoDgRb&&E-mWs6N+S9*Vub@^0)jlWX-TrBzdQtzF^1;}{TXD)) ze*T^6uS@@()@J`*Ue8~(Hv8qDtnApY|8VN!Dur%$m-3*rJPUheL+2({zHf6>roF?rT#};o4=p3 z`-7@KLjD0h%%4wa`jGO8jK303!tO}rPvU3rWPH}c%BSE5@l<>WPs6v5QvEi(6Hmv@ z9#Osnufn@lZYrkqfsXRgcoVCf_^OP5zY-~RY;(8rsZJw7qcwQbNFF}6C6xGM@ z4r?=BxJ>)ibgHr0PnYi(Ud0~sSDdE$Oh?WCIL<9l|L@jj{>z!a_jHZt)BiaR@J&xC z&*H5(#Mh;jJMU?~R#@Bpxl!}GPs`3`&Ht>mT|f0DpOF)Iw6)o<3LO8h*u{6wFu7TO zj`i=cHsg8px0xyX_)Q$(hO?As@k$)xYR@WncIbGX#V#)Xobm)7g+2T;_VL}bRUhCl ztnK++qy4yXj_hub-@u9Wa^2^Z=Uh3Qlm`psA8>A{JUCFE=`0_|=`Ql4 z^Od{gMPHWFw<>=Udw0qe7bws5k^}4pa4QSLmad@D}iX3OZu z8*moKm(xF6{jXS?>n(HQ^1}HJS)29NXT5b^Rh~a`MPWW1JHN@BaptI8YK7`!dASF6 zcgRbzzg<3s)1lmMrTXJP$S>gFHTf{ku9L4`rTXN0c`QzCkoVvW{Z%rmch)MuABXsD zoMZmdt5xrDJbiGuTm5Ts;zRkI*HoWgCEtRx8TmOJk{`g{YUS0}n0|A=C8EzCtos8^6}QTf1mOlkq^sd)+tYLe0N!!=WBMKe&23k^Dp1o1^ znQh8DVm~WCWo`CnBkTE;+})(S{OiiI9~F&UcATnr|=j-GW2>thJdxyG#9h$q$oP z*{t~kJ`cRp+MFNfeZ77yu{P&Btf}9Z{4Mffz5j0Xmg>Dq`hIFG4*5Lx18XyXezWE; z^|rCu|2*^GWNnUrDewQLV~_p#*xK}`x&EqU8SizCcek|}?2>kb_MUS5uqj_M2ESAAF@-)3#jr}JQo!v0m{ z$s)>&eW1Jqc`s{oeZ=c3e-)=Lm;c2fdB>fqPhF<uUt4|-=h>eh zqx@mzO+Qq9c&|JK`;+CbvCH|te7EX@70MrvyhQ#Kr(c$Qiy~4(!yISKwqV`3#QNkvo5^ez&%~C^GZ?hEv~Yeb;}Y zdcUDO6^AS3FLA!HT<23$Z=M$^o)2TK?fLJhJcq*ua+%MRXaAA!z|Q6JBAh-YACKyB z>(AAn$Fs2euj&ut6zBVjFI4Zc{-HR@{q|OrSJeKTv)9y{#Ok%5mi{sqdtGfVG)F!}E6?d1{dIQ#gC6-1#f@2bahT zaGd;49OHgz`L(Gx&*LP|^`tw0U&I&K<@4_9->BZBez3LKk6@(cTW@XpYxDh_ z^R4Pr)VHxV_3jDPKaI1jXJ3?a|5x9y`W*Q{oO)ON8*s2)J}XqcPkxKFIX;)y%h}du zKR2?U`*E7{8~;vufXCqs-h;Ea!U5Iia9!!ukBu+U$>4Oz+1Uf3MvATkC%U z$8MHC#6eOn|AXoiUF6=8?~s?{pr`y7_It^#4yr%&|9j(p#zbkqFH;V54Sew&*%EtU~Tp< z;b{Mg{3Hj9^?v7OYqQ_^+cn-?9Pch4q267s{sup*-?#s8kokHHdtYe0UD$nCdHG*d z@2*gO5B5Hl*W+v>)fXI5y<`7jBlFb?yA@SG+1ji(d{FEAG;+Xx9A&37De{tQn1C*Sm|@;J}e=W*Cx`2n2cdb{j5)hD?g9>np!s(%~j$;30Z^89M$SN^X0{BC&+PQEAa!p?fR%rVs`-<0pNHrInYU;DX= zJoUWtlh~OnxBf%@iGK17YqP#I*Vk9p_WsIkyW7^Mpe;J$gKF#OD4`X+k*0UX_ z_`JQ$N!5o*t(6jQ5YVdB2w^(z5XSz432(z}Oaro{2}|@9-pi#XqW_jUT~F z@eaHZUwBIOJMi6jFJ6TYJ=TW_)%Jau{y$-WB&x62XJsozWi*}C;ycniu|9v9mkK! zWs0jl{kwb@&hY(h2FIB%Z*5-RuHyCW+7jyb8E-UB<83(kr^b(!H1+oR$@>M*+KiWI z*R$~c%2=EI4{K<@{=pt@bB^k-X8u{$raoI*{09yl@o`@P+5n|F81< zaPDmNziVyQo8x?zK2P3@@3uDc=l)awO6(O^zrC1ke@J~Nd>GHQw*6<+|1`Q?^Ia5E{YmQY$4)O@pIdPWT&1+Bx9>OB>GPEV*yDNqwzZkh`Ah35 z{Xb)SKNRTmmw`CZSN+?q&3Ka-uY4I}dw(!rZ|wBbdR9d_KC7(iUEIyuzFslj0z4c4 zW^LA&Ii>YAzEF10(*8e*bH(I+*5>&hd$2{}^;Wl>>O=BJtW92l{6q3Q`9%Yy~z8;Y;CC`xmMc$UYZ6)C(S>T^YPKK5Ii>#+jYV_jEv z@gvse`hJG@1H14Hd{H%%oAtR@>G~aPZN{rj|2sI2%T+hInLo8$^WTTPmGT=njnA*4 zdiPc3J+Qw*UWAk6$F0r$aqgFT^%XcjK%lzk!qW<&lC;|Db#<%I}n$H&K0>{3)DzM0tpFb>yp>sy<&& z9*x~<@<%w;N3Pz?)SLS`sHpcBgRIT<8s4FNGxlzgW6e!&p3gq-Uv9HD_1-AuORdfQ z>+^bZ%Gy3ZdH;Un^{P*fQ~h)tyG;JV+B_c`@_eX~P<_bp4YM}mPh$Lc$vyV7TnpuC z@_Vh#`W&v;^*GJ-c~(ot@1^;>TAT4_)4!D5>!SP=c|e|QML+pV)~0_cd7eCXz4}|+ zpgco9)7q>r*HHO>@{Q#6T9aR^{9$V|ewKU(d7l2VZK!Xo`o7kteh2mIaSoq#qsh(r zY0LBKCTn{=4AAp^4tdDW3lCb`_Ya)^hHX`!-KzR0vD;Ly2cKD+@so`2wo|=3SoMRf zP3}IZ*ZbG4&G=cyKexT=6F;i{E*y;0_^(=<{_c!_GRoi8=Mil?sNefQo^5UFJ?1-X zZT2Uq*s}2Trcp;ZF}p>fC*r;A*XP#ed}S->`=^?n)@Os!!v-*uPl$8&Q5**GI`)OugBUfcF#aa0XAY zHplB;sQ$e;Sx&yBv+@-A2x~K5mj3nR3D#4ri|R84>hFTxqVi&#XZ#&H>@k1F+FlP_KY8*j`+t2m^~YlBpN5mA z<bBE-NL+b57p;!51e!L=NT48InLuWZhVLOGk5}yH7!#({uelo>-1E8vYN(! z7^mvhcv$M0cn_SfUzN1TA&%XI!1M>*b(1Nl zi`_bMR~(R!$01%D<*err_UOOhF2?sYUSk|m-ya9$=_tod;N?+H|GvnKe_?Np7vNhWb39`s)4vLbjDH9xW@tUt@78#U$#NSU;DI<~{F&I9 zqWU+mhY#Q^KBo`k&ry9n9J2m_*u72pYV6??IKWN%YP=AS!ftoPa*zKYITKCY8yI{Aj@(EFnU&8_Z3WvDV z0FI}g`kP@7r*MGh;Sj$a<*esGl;e{3GX5PJzb^K05(ju#l(WCna7cc|eT;Xx#+!yc zTy7xwaOLx{hg%I&9^k`~neVat$r-QgV8-jI@!r89`Ozr9LV4*Ss`v0!IKW+Sh(|>A zjK4Ul$Dd-izQ#Wl)#C~&){C#fA?_BL@rGe{s>Yic_0N%4M|oV{g+2Upl=o6z;sMR? zGhQ9+k$1uY{e!Ucy!t2Okn^z|yCanEiTWAux2T@^N)OfiA^A1fWBksM8E+VN@6`Cu z;KVd}9nRAKDGumAg+p9z81r*{ZLoW##v6z|{7hu#UyTF&2@dfI?B1pEDh=m+GhR#V zk>4HVcpMJ#0_=JkZ(G!l4@Uj?>=7Iv^VP)eRqF4EJvw!J;Cvix=7P}9s|3Kus<%>sZJP!}T z0iKUTycfHD)E|48e%u`gcqR_<``GQP{vxC3$IWqoN8%8#j&hFoFn0TCJogdC!@Y1A z?GJXZRsHKYp#I;epZ#j|sKyJ)2Vjr>r?A^!<7II`|LLfIobo248IODb4j6Ail;aS) z4b)$449ACC;Q&7n<*X;bA^8sMHq>~hqI&E;rt#f}ly|`a`E(rOccPs6{*L+^slS}h zdhwMwz#Sv={2GWu@`>2JPU9_(>SxIBVSk(a3wEZU+D?Gt?xFL3%s(uRg@O~WN78B^lFJZTt`v1lr?mJQS0p5T^ zTzZmnx4HW7!5)4V2lyQv;-gXj_3AJ4q{j2`bvVFxVP~f5pNs18M>wSZKkOz{Ut==k z!EOun_s1Tdg9H3d)Q^uv{Vmmh(NxxpJL3S4 z!y#UY-B#-VJnF}1Ph-8@Usq#yr0Va&9-fA??C)(L5Dv*7e@1ygUUdfJkJ9*?u!p^w)Z?>f$st~b-AB~_ zb(C{_&a>1rUmfh;p!y{Ca4It6&Bg)w>o~**u-jVW#h%lA9&U&O+$%EUKaNB4wb*T= z@xF?DpIme{P3wpITS?BT^Yzz3s#T>5#9 z=eARSXYAoIIKXe=5dRkSw^x6)xg0xC3@Os(%{x@LM>*hogR6=0*0Wlll|b!y|Bj103R9)PIxu&w7dd!F6zeZ^a>g z5W6?4e_oVxeZCvzk1GEid(@W+n2)>#4)8D>vfpd4JCO0BocbE`*^kl6JK%u%#^DgZ zh&{%8JL*rW|3H-E>Mv{j0Qbl4Q>y;}`}oQQrrvy>nOona@bk=OIQo3ElePVPc#%H; zos1p49cTHxxY$C~`&BP49Iq~R2k7s!xETk%`1>)ibA#$vBKa4Y;{1VO&l(*sR6Y?)Ocbgnrtnssb(NO)>y8*gyZQhCvdu(+$YN0%9F6$R{OUGXWJ?N68ksG|3&p}R9|zc z=JT5=?--f&4#D}`l|O^y9pw#?lkzt>V0}ej(fDC|%~u~MZ&Q7j$e!{MQT^TWZ0z)w z-;8{-&d0ady-_Z@O#6SB{jXzfu3x94@+9`!%0qGPR{1%cY%jlo-K6|&)ZbY?YdQPJ z{55g1r`CHL4tmHFtj*60W|r3dxDe06Tkv8W;zUK&pSHI5V-{G)|#{V0qm+1H_tWbUGBIQ?Fo1cgI zt$P;UADzjQ%TzxQ2N$b;Dh?~luUMP=C(rrYVQr2l&-xBh?{`!Ee>nfW)?0q1=D&`g z$6aG>j>o%Mc~_iip#C8^XvunTJ|Vw~-E-v~QGHSQ5RMg-i?7mr8S+}zX8lfo{rtEM zxqq$J(-+5Y(Eg0Y&iNYe1)S}v`Zpr8pL?*sT>ZaBKC5cs{-2%EdUD0(8aTX9_1EM0 zZyLV`j&;`jk64@Yagy`#qP01m6xY`#oaFZ>zNSC@xW+$&og$jQ%4&@ltZz}czUJ85 zAbZ%|D38M-UKsViu6%pc|Au@x>VH!{=QYh2;(9pPr2HoAZI)BmeM^2O>c?xN{c`un{&$uC81-+LORUv=?t5|_?0qG7 z#Qw|jV4UFh;nPu$U&A5wpW-a}3GB?(coo)Z{=@>gab)tI*vDgV76;gQLH%2Ba*F&z z)X(ofoV{N2WpQonWmMlDJFDeE_}9VmbR3XpaN;%PAL9`JiTyRo%WW|8o9C&+pEqx0 zZSI%f82@&h$D{D?crHGMH{n0Juk1v`P0e=u~jlpnyUU*v_@J1Fmt>JQ2P;P}t-6>n?&A8sD8G-+?pp<(W7?Mc$25gXOb! zuzxAJLF9h&eK@sV4sbRr@5Sz7x%B(2XPw*)hb!f|kypzHaB8Mp?E}^`RPKP?KJsWB zdskkClU1}oU*dR0x#Uibml-Z!gX6R1emJ&Po`>De@=hFh^64mlL%w1c;~$al!r4*s zM4TQZza8a|%fI6ANx9O88ZXvC?ue65$&cc2fc!en_LYxE{VjBVUAkN2rOGSshTS{0 zf8%kixt?dMqx!0<{}v}dQ+=tA81G}bDRvT?Z-BLVf8ji&_aD!a$66}iN?wBe7ctNyyyrawjhP2@g#A9A030(pXbE_s^# zE%Jc;6Y_xkgta-o*{tW>kB!ZK?6{$4;qlkBE->GpR@M3%kT+q!Iz)Ln&y z{ZyQML-h-A7H`El#`_Y-R;d2>$m`{zpRvBxav7Z1AYY1uHF5*&FP59*_!7AzPA-zW zTATlk@%?{K?Be@z9FM^XoW@B!AA5M6wY~mUX})dPSs;IcGYjSYk>|_5VsEMZueJH# z6yultT=sD}YcpT`P1RSmHs||#&Uanx;H#-mf1%$8z6HlVmj~e-o`y4@Dqj}WNM-wOP<=T`XkucC7;G=T>1;sZ?3P}TwgVHO@_(=V?V+TKgUHnv( z?@|3CYcqbF@i#~HpD5pDZT2g{{)FU7*8dMqeWv;{d$pd}2lAyj%Y4nO&3uiR?>1{Q zzSBm}r#r|GKi*l#BPiQ}E+ z(>Q}m?$hx(w<`aiwOM})_Qxgnn=8M}+MNG@=kb-+=KQ&wzZN)wZ>B$2z3}jz+pW#` zEg63RdA^$Rq1JYMt}h=iWxi?DJFe zzge5{{GB>qC#(z1pKrcLuiph71s-J^{e)1w~bG)rM-nHcUzRKSs_dDtO+=XwTejoLT3Uv!N_$c--lh67} z$D6J#SHj+<@)bCwz9n`$D8C&C_2m1p(?%YPW4FumaJrlPdgSWzhd9w%K8&5J^1nFc z%4NRR`rV7=S~z6>COBJ5`K{P1C*L3S*OVvXczJm~4%^8aqx#D7E*vBO4*MMM8JxaN z^%s4k^`;uj4RNN6+!2S&-!t+<$_L`?ae0ijxxVvUPcM-tk11bC?o8G7zmq)uhw?AU zW8{C4XZtHJ`K{I)oRBM8oB3So8(Nn#_tz5LpB=5u{pxf7^{3yX|3UiW^v@)Zv)%>d z3Gys?_Giuiaa2E5K7c*`yi4BN+%K)U{)_H6HurOSuGC!Nsi|O@)*avkK7|aL7u)t;}s9J{&0?58T&is zD{!9ctp(2XQQjHnzLN*x^h9}dluwgqMET?LBJ8~+Z^X$r<W3F|MzG+$Y~`ZLZe@*XL(A;Pf7POJ#tr^Wc__``ab0&tj+b-miK>8;v}A9 zZT9m<_H!xy$sX!oi+zq~2mRgY|CT&)h3bFB4*Puy2ju4-((xx*e^qNU|6b;gZmS4ePH~CF#^E?Xq_Xl@d+xvC5 zUhluNHtPu){}1Z3Jim$@)_m!~8m|TpM#(L4W~kgB=N^&A<5)_5!P?AsnE5u4Cr2ya zX>IneE&KNa^?B-@pR^wL0o7NvHpk<yKf4zc(G4eK?#^2!NW6J-C`hEGlpS9i$z7(hSxP{|4!tsyg&e)$`sW2ac z6K(Y8f1k20Vm{A{zW*W5u2TOFoGM$bu>V`^zoY(RII%@O?-#8vF;=dDJzu^CC;!oS z9izOWj_+>lvWTmi?pzT(*5s{BSA z;9fYpPx&zHy(>?P{H44Ir(V?Yyn!=2lz)l?@}oG03x3slL&mR&bL3ZJ=OvAQ6OQBi zv4^MO1pP1L?0LGL-onYRw7$==zf;af^&iP4e$)E0AIjBmNS=uNo$?;oKOhgo!B6sJ zoW%jo99Oi+^5b$0L)s!&&a1yKs{FQ8-UN6MOg-?5@y!+oFCP zVjnxlw4MyEhSQAK5c{XJ-p)9CMjjaXKluq9k}tx+|FoVg_RGj$M*TD8Q`mb}cK={~ zv*cFT+aceH-S_3uIESB)`ll#=4Tsa@o!FZy|A3vzdcOaSbJOGt{?vM6yOUj$z zcp%?~{Tnp?!`4O2?=SLtGB2thto>Vs6Dj#!91f5_$7%ATQI3lpXMMv|UkxWl$jxzf zpq#|Hd0OASI6hweHVqPOxNqk4P>yM2|HJE`@?ab29~r@SRj;@fbnzw#m2#ZTZ6&%=4V z24@DUe<#l3@1p*DmH!>};|u=Qdfn%hUy9Su$xX07TfQB~=E_5GVxBxPs-K|id5(1v z^ZhyZ*9!71`TICCN%i02@M)d@f3dq&F87bto4{9Lcc13J3CA|dy{*msBbom}^6VSR zC*jOn@?0Ejkyqj5D_Y;XIDWs@^PROB-)H^{&*RcKmeS7)s#@F6FZev7K6ZBM=f|zEi<8y`=JVETwcg&?KdJXWgK+F) z<)b1O(fNHcaxdkxajLAm82e@9*Kn?$ye+EltMR_JE@G|+uFn(XnK7y_TSV(kJSI25 zaoi1O%4xj8IA2~Ki-QXCtSHBeaH^v6%~6g&!w%ygvo`yk;qU*gTvXnO6F7@|;~jW1 z&fzuI=6qx-Y5r~2=6Z;8em^7kOX_+#6gjK?IA(3uvzPG-&eC}PCF~#eE|u%zSY3_R zJaT2t-wmhmP@Kk7vBUlHEOt-p`k5cq&(eIWaI%5s+l0NDs^5eCS@I#ABL6R{=YBi4 zn2s;kQ0uK?UBrA|$n|qYls8h|9LMU(U2tl!Jed9*{Zq(8^2OwP$+waR?8j#~c8SLO z6(@Q9Kksatg{<;n#2)zhiCY3ubG7 zKe4vY3$B;%$m7o|KW=S44?N80t3`^d{xJ3D<2zm>q+o@>P_xktb7p8exvn`#@>w@eG;3KiNEB-kxQ%p zIL_Rm`|F&NoR9W$6&ycbj$@~kd;`vZt?@hK)YI}EQC?j2L#)m9m*e&OF&yIQIFA=& z=N`RYZN)LXAG`QCj^pCzXubrlij%lG_V8^uh5K6t=jwP<@g~SGC(n^LBX3K7GkLs)#=na^N&WzNntUvIck&tJdGZD19{D=* zYuIi{X5P!)AdyBJRM&;Ay>qS_Ugad+8pnI=y=GpfyVQq{uAmS z9OX^rC#}u><~*$XXGT;%MB~4Jy%}2n672K&(`z{OqVg?K&h@d^+N>|d`to=rE^@xf z&FevXem)elE-*izKdAN9#M%Awby40>$9EG>_0xLq#bG<;kK$x!c^Y<})Ow%CnZGpt zt5JOi)o;dOUHJp+BIf&T*1s>R=l$o8`5=w=p0!#3Y}Ws|wHfauKQH{5`k=4+|Hk>=^0_fnUtq4k&$K_)B6B}ni{lGb z-w}Jy>ipeqZH}h{$I};g#Dl5#i>iMj4nL5ewKnU`@P1|yd2F2WZPsS|le}N~5|`lT z$-hybnXLMgI5kAaQ>wI%FFr~xhjYW_OR?WU``H+~B{g1KoGm4H!?7Lezc=z)?Z+sb zoU8gtI9#p#1)P3PUWZd7HQu{8ew)_w74}3FwT zoBPG*^>-ijC0PIW)aPcO<=C%3u={P%LZ4Gc$Cts?aQZQG5az2PPL7c~Vt1^3cho;x z9&K&@cO&b6o;*8F`FiY6kay#N@xI6L7u>@6iegm|VjORM zoaX*-L4Rtg&R18Q*{Jb`{OOZT&VrY zvOkrr&Gi-kLiy$7JIGs*yMHL}LY^bPC(6&$^*t)``SR1$@1=fOlwY8HD|tx%Ek2C@ zpgzO%>a?}F-eNqT&nu_(XMLToi*ahKd>xKY*ZSMz@EW-%PCudgd!zcP%7W0bo8NyLP*%TR`ThTKb?0$6)PLN^rxletqR^r# zDwTAkMbxiBq_Rw8OJz_I%F!Z<8cHeTXhB+x2w8F{rA>ntrRAheQcc>V?P#O@{(i6b z>w7=$$9?_rd-VLhKi_qhvtAc#vmUR3uCL#*zfsReYt&U9eIOr#<9ez;!P=aUA?ITo z9O3TPX1utb#v5d9*Rx3TyAj84%6H)s^PP>4<@ceN<1+b6IJ#HuKXC0Q$=_J-V&=!= zk5^Cg?Zo3rE!-I&iM!xatWEp$1s#vGaE|9k-K@?2)#H2^ihVrJ+FYOYxIU+mm-zQ4 z7vsj%uf}=2iS|D2w^`fyG(5cOeE0*0_iBE-)mNTW)A_wWE)7@x(Kr|_pXBOC$n9`= zzS>`8ZPu4?f4$PxzoLAc^W7SMqP1CX#Qpky^1`R;e?ImVOm+s-%06rI{9_#UlV@SSulzg?ddnZ;>^Y5B_fU-=UZy;c3xnle*vBJr1s8GfgXXsg z7l$$)&f^*lSnm+!$K&);`C?pLrTNXo(N^WFT>iEEEzW%@=MGcvum$u25V6U3` zABFuo@(f&FEx&++HS!jm;cC8)*G`UCQ|n#K^Q#)F?})<}PNWzPpy9jj&{n==ywB)4*2r1|y4;nDI{E^jQ~hBN%ItG`S4 ztJKv`l0V1!MD42|sqrhDwEm-T_Njapj&OgR9H{l(hSR4t{}L{>RQ@W?wUW1CpM1}w zG=9kVKCb+y@y~F6O8rOH=KQP2`8S?CJzf1jh~sBe{|xm$^&4?xyq)?o^V|Dq&8IY8 z?Hl6!kDAY!E^n#)5}Z3t9*vXlG@rz^Z>4+VNmf8b95t<8>r1bHD0{ zgKyRUrLG>2!P#u}KL`8x4cC65@^4-Jb?R^TV>Ev9hvst}F7J@f$Ntl5f2GUuL>zvs z`7goI0@ZKCNv!?&&6)GR*0HSrPL08$o`an6&6;7X?U_u`QGuExPR+Rv@HI8ffd zsrnDDJFseh&%p^Eh4X_{KL?laJGk6J?YCpUtLkf?p#Gz7^2s>7K<x1om6Wvz*D_$0^?ZWcDZ4c+GJ#TJDFlo8+mk{&e;KEKbKN|JLPaC_nHN^x-FB+qm8{pB}sp`ZLSuHZvX)p*5|l()gz74i^V9;x}x#`#fl8T&(2 z{|C+um5*wn{)5ZpPB_EY;^=bavv8%X{#Rp<vJJ^jcFf$}N1jMw1MSNvmQFSvA$d~6%_S869;f{V*E-V7Wbulx;MIa}Vnt=d=ilbhg>_Lt$pG#$VD zarC{s4tsaYe^{IS>cxIFIZOSg_bTs$<2D-aHXMARd<8Bq)%>?voBksDJG`Cx^E&JN zXoLNqb^Q8SoBBc2k0UR2QT>z7_sUyvJXzkoz50*p>3lg72X*DMaZElK=MGXn-g%t* zTaKd}}R{j>w)BabS zdr5iyb2Wa#eA?lR^W`dBzDnoYR2&YIpTN;r`6HK)lfCoUzuV=baN!oYD^AI8!nujc z7vgAwT*moDI^Xy2sQz=qmAA*7 z@5Dv&Cvp6Z>ND*9DA(<5`Zw2Gf$J@_Huw8VBh6=|^H-{W2zxo@DUQEX{y9!NDzDW= z{Y69Mme?OGUxnkJ)c#&;GoO*n=Xvt1sp`MPm4oD(q5Ai0%K1cT@P7ars;q+UrXQQ=QPt1CD>8k#Mzm*?@i*t3nds>_N z3Dn8t(&_Un>8D!v*T^*ly~tNPoTY3_Q--9PhLy^T)ZN@~60rYhIxG zVny>g!TAfh7fv}pZpMB!^|uI@I6vRSIgbBd)@J<)^ETfJA{-^Pm z(pOgT)9V{ggv|x$2TkA zj?;_u_*J{N`u8u9Ps3>+xgSn$QTsb_Wvuc=xHL|F6PNqTf8cnyeCUN5&!hdh&IRQo zu|HZ~jI-0tYM9{wYnFKZw(%I^HP`dTP9{ah~_r z>-E=o#r>3@gwwBeK6S-ObLCg!ASd7De3HBrmrs<-uKj89-#FT${`~u1NoZ+sxf(K%6kjB3m=kRpw+OXrBjw9*!u544F5Ig9pMlfy@?sp~6lc`GhjX{7ej6@L zmG>O1`Niai;M`>8r(2u#hOD=@%b!wyB`$T*`fj#1_ro&x!+Xe+<*HwT%M;`jhi|C; zr?lTl`+vzJzE4qSi012usz1uw%&!;o3&=yhpVHmh%qOG2q2%758b8JXpLfo}$@MxO z%W=3)Dx<-*Gb zuT%XzTz*Mj?dnTf-+Q>kZ1Q)_enR`|TNi?vyQW4;eH zl=_VNvDkZ~ch&Vih4#Tj&2NddIUZX%9&cKk{<3SeUtd!nFIW8zYjb>k`rG>|IpTOX zur~9HhG~CV;{Xq|HvJd49>?Jr-;axU1y1mLxP-sQDXuY0{g?5PIK%C51^2_=6ezV-7C!eTFBoH%-^?E7s=tL>!+laEy0YoAW=<^?JZHs!zyIur~88_t1E4txbIk z>U)!?*DEhLuhZ+{yKp>5`>`Ac`zikbm-)Ql$2Wq34fZ;v%1~?m2?>@_A|#9JW+_U!38I&U`+)499#P`Z3No*8G3L=>s|*wXWBA zg+65fVDZ_ z&gXnvL0;nXw#_)~tNwPoLE}Z|s{K*ezh7=+ZO+et>!}ZUwodu=u6<9<_d#63smu91 za+|feALhAV9C)L~&-YUM_SWWpkaB(ZCy!p%cw=#HvOEtL3-T+p&uG7eynL(jzp=Mk zK76#+*Mar5#v$%!ZSF70?m9l>uz$bK&&OQ8zw%eD&HTMLdsp4BKPQhLQohR=^%u^S z8{njl+zFQ=?MFXcxk4V}>U+!6tj%~n{!{=i?$?j}!bIF5x|6jhEu1 zaT#~P86J)+_(ALq(SAIObND^%;~#Jy?>AQC2l!ZPdw%hGU3Z-EdET`+-c{$vG}=e( z{}S@@g*qQT#6>q-+CM`(*58ETx7rY8L#<< z9Ph)e&H8=rCtY!Jw(iF_VUN#8pK|pzHU1aYX8n0ypZ!T*zDD_Bx0&4RcffwPw>IPD zPg6dCyaV|-@^YwrHhD=W@gwrUq?{iL|eQ~| z{d|qT5r@3L`3p|?eWq$tOnY-aC!EiRTATeTex&v%;nG@-*U{RnCu2W*lV>B946B zqTI^m{C+?;oRAN~IeuT_7HhNK66;OK%lv-GN?e(t^}U7D%e0=aaQuMA{}*SxU$_6= zT2G1fG{Y-#M{9F_L<`j4Ae>()--^rRvz^JG!If2--$q;=A zkEbbbVr}+gCHrwMdG0OMUyRcksvm)a0UCcgE?uMgW!NvO{vBMz+p%}I@>=(5KIv4s zIgZG?S)2K#%_lIlm}GQJnb{J!mC96YT0mvBb?W?aF);&iU+ z_nF50Cd-X*ZmN7b&f~5)xL^5TYqQ>D#D!Js8)t3rPyBxJOdM_OU6n7#DZhXFI_)E# z-)$i;lmCe`y#I9dpVrlQ$6A~53$$;8z1x*vNPWWiSL65t&F4<+Z;~Hz_2kduhG%{24f#T@UZx_%p4o8!NZ>#c>gc|1<}{r7Xp%jB2PKH~9cB+l{sPcw0z z&u5ldoAWv1dVd?oxZ?bj&Y#=^norF6*vQ(npFrLY7x86y2A+%)ywuvPZzJ=6gM0z` zx7KDq!W*?8-h-+Sd3|%JwHZHQz9(9ndY|{}FT^=~8}@JsCmVHtei@g(*Ld5l&HOUv zSM4FW!1xWU?eRKM_vbtg=c&K*aEZsKLDuGaDRck5o!ldTlzb!k%jC%l-G4XX_yIlt z_|@9XFBqx&LG_0U7KX9-~t~Fcz^`O6|*5-H@3rAPo@B88u--9doCF~DZ{U12Q z`A5`WuCMZ5xN?zv8!lWTuX4UZ{stE>mveKpz9QFWGix*7%9YCd;^->5=yJRY7l$dY zV2|}QnydbjAoBi&|{`4fTFuxJF)L-?}oG+7Kz&ZRij^}Fs_kL94mB-6XaD1QK z4VUhfuf>Hs4Wk?^E6&mlv`r&VYx3Zj+IB_kon#3+TW`DDd$_{ zcX9lP{2Na2zVkJHX_oTl*5-VzaK3gXFV0ck&v~{y!rB~AC?1LoF(_i`CH{NxHL_^ z+qIu5&&U1)@@gDSmp{kl+vOd&bh*6$W13&Sr`!aW@p(8mM0sx z>FNi_kKxil`8n7AL3y3EIUc<^9-GMXS1I3$izDU#uy>POYa#2IBsao^qTB+LE{|6}9#?LYXSw!!>{)ewl&sD9QsMr+*46)}e~;;1oZlgT;oAQo|Bj14 z%KI*2J%7m!aIU(>Yl{6pl%I*if8-uGuBH0Rak-{E3MX4tKNUxHl+VV&{_=9y{uudH zoWq|u|E~Ui!Rb$Ojm26|Qjw3q!Jg``xwYB9o$OzG^7L@!eXw_gd^N6+--Z)B6KD8w z?9+a=wYgsud4BR5dGMd+w*jaB%A2WAc)Zw(OZa!3;ysqA|1v(%+T0J4gEapJIA(r% zmmj9QEsof~PR^V!y{*lDc{l3*G|<|tCu6*8sSmen{^M|h@20*&{Y-LiAB{i9+Vo$Y z{vRhVdCH%`0sFHWr@JbD6X)v5@8gW~>oc6+OZhj}X8t?5e{aWLUp-&@6IaK(KW^&n z{q;b#&*2>7H?TJSc|+Cyc=8JSe-;inAG%qa_2yXbr7k~I{TFaZ{YV_wRXz^;^gjs~ z8z`S= zQ*jQ@vo`(t^!I|b*^i5u&)e3ve~#}q+DF6m@7?`{7#b@Id)OWQu{rk&~s#@PgxG+y1Xl>@}vmZCOyrg_Q4wuVQtj&5aX1x!) z`i=Vc*q2+I{_^zq7J2Dwrt--g3=9-K4x84la>T z!ciu7#>Fq?VXmHh0xo~9e6BO~YjFvGg>zd}|1S=3y(cuknEp?7Chvt)JQC-=P=62N z0^>c0Bk~Qn!hE;mB6*D`HGabQN8psaCH83F9p~`~*B(#78SNLl_RQ}Umowg%*eCxF z2e|GE&96ZJ&9P7Wj=1uf_G2JU$;aU``7E3rr1uL}SyB=uf^WMjOTo)T>EK_7vNU7hzH_I1J&P!Gx8<4z zR^f#4zQjfHU7uI~KJ6Rhl>BU5X8eJ;LVg?0SJ!w8aD>aQJ+9y!^QrTK#?RxEagO>6 zaY#NI7w`i(p?;OCXTG0eAA74bUIib4J>1@TU#({#&hIZz!C6gtDK6|MZ*Zo5Cl2x9 zFLFGoZ;dnDAN!0y!8xb?OE|(G;u799RsT80YmB{GYTq6g8E+`glTX9}<1fMy`Rh0# z{~nidoz)sYp#PI_O#5Cq!J}MG`-gE#p5hFDhI914>l%%hay*W}MSK>H=>KwDAioor z{?z?{A8;5^s{6k;X_%S{USMUIwr~Pd>#PeKE{p+|u z{v9sj8n1ACsXq=EnD4nbz(a73`bpR)U+UV|(e+TqNj-Td4$14is`0Y}l(%xGz8_BU zo!CE6^$T%`*W)7nZ+9lIzfR+oae)20>Td{+8E+~skT1m^?cc`<`LDRd_;p@mJo4r^ z$9lWt0FS{X{1C3tezj}Q{I%%H^K@1cfh%C)c;jD#P_&*{5Ux4z$xSR!6Erb z?ER$ok7wX$ySxhL>3=gW(EeXs#D{Ls_#y2BTq2Kf8IQpp{XdKY=KDO(;mtV1f8z?T z?;5{!?-Aqudi$*w0}&{!aOw&eSi!5q=G))PIgE_)nZ?{Ce+cKKbv}e+yi| zJ#mU}z&_*6z_}mP{&Acz-Wxa|{{n}M{}(Qh@BhB$QzCDIGu#n}^nWQX(mrm!6CjGXRoM!2Cmf9{w>AvtIF5mJpLS)@n0_gN$n5Z zr1?d^$SrV=yem#B%7-~qKLy8lInJnm1LwA@{WmzI|7ss={E++@T*T+%3=hMB8z1L? zR{!&H%J{G1h&;mu#{Ux+$!l-ce9Gh}V2}RJ#|1nDmuP>7Ymeu;oc`A03i)R^$9i_+ zfc_8oMDwX|e>?%F_&i*s|A9CmACJRdwLi0Qv_pOg=gB|A>2J#a!3p&ZKGl3;+y;BU ztNvn_|E}|K6fV&JOdS5H`~_UBq4uA-`gi4OpE2Iwsy`kFjNcjO8Gj(onEwPEkw1cq z%;yDX@(*!^{8#MLU)@aeDdH1xiT3B?GQQH8{wCuJ`9hp?#{)<7zs2RW{|9HBF9&_D z`IN{{#VL6YT=_x!cO{PIX@76Pg=dsc!lmPtKY+6(@?xC6tojrui=NI+wWB*tAG@Pft11?{x{`%nLGWja(T`rHq*+6*)&fP3Of%66V zWgHHdKgQ8h@^)8$wY>Wmnt$$Ext{X~xj8P6lsn<*2Du;3-zZ;)voZ4RIAOlCus=@u z6F9s@eho)>GcMpCaphLk@A0MPAKoq>jEfWH6LI-Y`CMEfzZ_?il*cZgEI;6Um%I!| zMR_fbr^+AU3|Fv!ukvbNX}%SF2==BaZ-&eGJRHwdJ^+XJ%cF4a0eLd^XUUJa`b1uV z<45FmIGrPZjuX!Jovyx*@_oN%{+ypjVDBE~r{Ut`@;SJ)RPN#Yls=ChilYmZ$2fRQ zpJz|T-j&J|mtR@+@u643K2C9YrRq00ub02IHlJ5^;Pc2`ztMUMuPHyk+T%HJaPX>J zbF0=9Q{T|qe7>81U3m-g3FKXH5l7S~Z>s)!@)_hs^3og1=aVPoDS7;s@(;-ukXOiq zvhx4POXRt4HD8bY^l^ptoosE6*GlR;x_XXxfAW<42D}bWqQ3H|?$>j0p2zc)`ZD#O zktc_0zJFSq&)-XYAE^2^_BT>~2rl-QTjE?lxrcLYd4Q`wTONTk<}=0GjOX$9ZswE6 zXQ=*Z=LYh}*!xY_%l9}tQ2Bp2cu(HvJJY}UyuUA>_cyRM-}gxQ{&(Kmet&`S&$2e> zQ@BR$d*EU!560ye<+`0u9d&T`IqE>a1rnK zz2=+YhPe2$>QBKTJ{Kprx63cp_hklIoBasbkJ04CzMAh8Z2rN%ssZNVtfAg7TV-v| z-;JDKU*Zh^OMRGXe`^1r`4?W48{r&ofy=9vcfjFA8vjCTGvA2$UO}F&(ET{ZMP9!> zfFthL%W)3BW^Lvl^ZPs*F7f*#J8&8A`=jbB_(+_)yLHw6oR0Ij8xHYcYjZxvr|A1x zW66^_YCj!&{C?6B?DOw0uEjO@eW{P|Uic@xH{RnXGoCrWvxeq>%+EnM-$*_M7mk)Y z;b6J;vo9_kqy4|md9FOk+8mF1e1GX-@=87Rw+sgd$*m+e_KzuhaEZ*iJ@ zI1Z-EZC(D6JOpPmB){N1UVb0v2g(&3J|b7&uJPkL=S#$Yv z*S?v2GtS>5&%uRzlck*!N=p`6xDZd?kQh_OaGH^z+or(ZkM;0AH(^x<<+>@SN<6LUF4r} zda_*WSIw{diQE+DGPylYabKK#u6(4+IbUvf?I$arX>G3GjK`D5u=lop|LFzl%h##? zU7Wv7-hzW$$`YH4HyT@;ufAF~SI@sSV`_|_1E#mR58F?~B`B|?1Y58KD738aN z@T5H1+T8!Pa=%_kUL=3n+N{@SeedD`e{OB&?{oeCh8yE*znk1#`r$~8cM#4qpX0H2 zrSdi|ZzFfd$z5`PTp2B2@7lBe$vDJwtj&IT?AJ1^( zVQuDL8d$UH{#0j&oDSW$%BSGCp4r&_F8!>$)?cjuQ@I6BKaelN!RzuET-YK%ii?@N0q54pf8hL!@}Ylgyz;wpI~;D6 zhvDcAc?M1f$t!SSp8Pou=EybwQU9f@I=nV&-FQ?mrRtn>IMc7vq%gb6-pQ{2uD>F6`|oKaRs)<+oh! z$=h(5`n~_te3HGCH^CL^+v8ky3m1CGL#)mHzaRJiTdd9gru6?1_0enE|5Z4BOx}d! z_43a+<9gd~SIsXiC_e_5YBE1us3l*Bi!D_@3j27vwRt?v^Z2__ng{+{+4+>7>~;e@}} z{Wp$|(Bo1J)7k5qU*GK@T;|4Fz^{bM-8ui!z{e}N0w+e71z#E0S- zw{&K{J#mHpuf-FnpNbReAIBN%TW@Xm^Dw>M+iGprx0Chlwx^u&`xuAefZso8<;>p; z=!s)|4NmbC>?N(Mo}VnjA^p9IBm9M{zfbl5;R5-=)igh!{8Sv1cf$esFlWY}h$Hg( zu039BZLaT_>-&8i9jEjACtSHy?^oMydkOB>y~s=t}!+4ZVlgLD7Lo3Zz|{JZmC@;>JGyzKds?vxwi{2%gZ*!xrN zij$RkKVvX1oS^-_&E?JHdAM}EyauOxslQKLJ;&!??4Pf^ZcWXv)KxwS7rHSY9QKxn zVXu!o0sFn=1vooU^Lf$Lx7Ge`cKM;ocj8h#x&FTFS6%sJT&yj3#^uB1K`y8N2{_kK z`2rjqA+L4q8^|BwQg!(!TxhKIRNqhYiT6`}1Ws$ot#Fu=d*S3*`D&csL;X#{UMqP% zE^d=w!qGAE7dXIs`a1Qsul_{Ff2pq+75f`WFd|TqYO82AJaOp+) zOI%(q|Az}t$%oa_{K6ITnK(y2z~xUUABUqWt1dV10ayR8*7po9alLJ_HqQsP*45+l z57<9n_V(BKX?Lyf036(;{u|@s9rCHT!2S0e*Zvlbe*w;DKhV`rRQnOm&uF~yIPN7s z?DBRxJ}=;~J=cS^DXq@^W(RqcseQHDT2I_nKFHdvzsTcxGxGFi&8I!i4OV?0=W{gP z2wa(^{hxq~om4*;r&p=JRW2W-{dgA_TByGtaS7L`!~S2S{^~lj-s5n1zsCQc%O8|O zob*)tq1NUKX-r`-#i~$ z$LqC5xQts`o2|)zq4{>f;ZThq;R?PQM=ex;J5D!iyy>{mT=_!mP1gQA=i1{9&L=AW z28YMWe_5NZ@~p4cftqjSDCLcD+FU*Zhqx;)zpCTiA4hM>*IJwYThRXm@`QXQc|iU+ zd2XHBufY}if1mme)NivkuZR4zFRI$0f33~&NSo;S>3(&!9>1CP?=WlgdL-cWM^p0P zd+q1{tWAGgd41IxS8!k2S9pK(O5B0|Zm>4T+pneLdk6MHT^|ooA5Yf&7FwI}Zl(XH zsjtl9{G>j2wd&u;A>(bKK6**}^_#U>N|EQY2iB8A_UkxnGnIIr>RaLPXYEfXT>eFl zu=kyOwX6R@9*=WB$GQ_)R$Lt@bmhkEnmr+MGYV*#DQQ4|%@uKK8%X@&3x% z9N(QB-yPOw{6X|r;~-;G8m-lMb#cD4)_bhAY45ew`Q4Vh@U@QLMYw{m$0a<)+RWGQ zqx0thYtvtK`ddOCv7S}d=K87d_xawnHuKA!to8hWOHHb_*Za@fOtrvzY9FlnRDbTs zYh-Qmk>sb67iiysJSOi$9@2gY`2_MYG5PN< zU!%O{A)0Rs@)NDi(u<3gw;}I99+6j8D8Gih7x}#|e^L2D@@ycc{j% zJg@u!YqRtT#7s5>~hxsIe9&D?=a@~ ztlHPHHuGytehPW`xbpVoEyyo*?VnbDJ$VQ687^O~{BiPL1sQ$C7(2Kfw^Kc{>#`2zB{$kRQPZ^gNtx*zX!?xB3& z!!@7qNZk*P#_?Oa9$Vm?`Cga(>5RQUl@E6H|Hxx-(oy|S!-Y=rQfpIMJq|*-kIPTcd`4KCu4gcxd&sl% zRKLj8x0Ki7xTE|DjylOZaj~iTuisGft>Bi{X1s*)E+#LvQ~S|4JYSxMbIj)noF1?K zKfuAB^7qzeKL)TLyEM}H!8z)$p0#=W7{ud4Q(VApsn43LzAN@mlKVTqtno(R0-kDZ z*0+-L@mXs#pB#@*ACfO%{lC&acZ&M2air$!pDG`Qi>$Ymwdub^``&mZ9zuPkzuJ$+ zDaZRBTq1we+RU#W^IK_c`cLU^J@sBs^|u)p=cA-fqE@@O`+5=UbcWZzR{-)8vggU)Ecjt&ezpv>AKmdoK288};|n-(Td( z03EM=k1_4d^Sxk&KJPjhXMCP?oVA&6p7Bn{Nqe0S=i(OR7g?LG{T=FmgteJ}%={;i zrweubX5!#n9pB}+^0e|-Tz;PN%z29Tb34wxt?{av*R^)Om$Kga)+P$g_oD323D#yl zA%9<~EqU%0jn@swjCTdDysrF49M)BTci_TC&2J{oe<&})K}GFf#F_bCiTx>CoBj7T zX#c;pHuI~r*8cuZ?w-HzejMv*TGiaEV{N*wH?(!t|IrX{y-IFwZMJG-sZCYh&f4^! zjneCZUe;#6{F27I)Y|M<W;@q^6FjlRSj;lHd7xtPyNlX{(t(PPksJL^}iCwM{2$6aDn^l`?!d|zv(Ik{`g$gw;}h&w62;!Z}Q}9<->7>{-)rttNLH!>d#UAdRNcq8JV>? z9|P_u|KS;2&j*~KyaRb7Ycs!G6Ya;z)@Hw|Grtbx@sY}Vk>|(oWvg`ld`SEF1FipC@AB)|1m#@ z;B=(!cgI_s^?9f2{Af)cllR8C0jeL2{iC(tH{4*s-KJF3G&l8YN`Dx;~f6Z+H@7N zAJxtCRO?>2p|$BMT&n(B;b@869jB+O|LbTU(SAC4`A*d@!wKWRgEPDxrw^*W=Be!8 z)mm?3oL(=ViA&eY7rC7Mx&asFslR)$cdI-Hm-&4E8EezkAm;xLd2WvCKgR|3-)o`y zl}2d%M%W)Cx54oZavz-McwdXXKXmG7f9<8hHXVY*rNS;f5nb(6Qa(}4u7s)Hv zX})EgEs#IQ-a>f?POg#nJWcB^va-dZSFS(9&a8bxBo7k{VCxnkzd3?U+u@+ zxWayXic7Oq|1-{bzOhRyt+&!rc`a+Rl!Cjy$rJMC*5-H?xL=+{{YdJ&Q}4x9)AcUL z<#}5FHMAc|`*F07X+M>GG3Uoz+J~#Ozfa;~Ca=ZO7I~wqXTIO#GWp*w=l#U}PuKcm z&X-2cleC|$tWDPwnBN8D-rvfH;v(z25hpFQpHo~t^OuN%I=|cF_z4}Ko;bh1#=FARm$jcGtYtQqa$DEH>z81$#!0VZlga(}b$sXGjQ871IJiRNzlbYKhBoxE67{9oc_+krDp2CFD@Lf^xFNO&$JXrw0{LB%T8Wf^!eZyS3MR3v=ZIus>fu21g6!GjN{AgI?G>PU|h;aJf7dXS}|d zfy*nDKaS(4+z=Hv=BTpMCuYQi^?~@;DZPu62{si*I5z( zf_w^jK>rDOK>h@I{Hl)U>*OUq|NDu&_^I;$toJs@gXbT$&HGaJ{7FaZ{hCJBCJ)}x z<3)38v%X?A-A~$Do8#Ak@w=19519Yc{0zXQuQXl(dsppVmEVCQJO_shRKLR7%x4DY z^K0Z8`4(L0sQ!M#~?|GVE$o!7Mz3>^_Zfwft0!g{}<{UF-!q&{OmtC@A%`Il;Iz4dW?fZP-( zb>uT~NPRa~|E2Ovt2auQU(0C(pfbXGx0`(>G!X(wd;XGB&uy>RE zJNECE_v)PQr-z?hv+=B~`E1!$QI@X)h{{F)GPO9I#i`G}-`N82hAwSXD9KYu|er?IUXVtzt z&Y9QU_UCdO-l*|Ljdsk2U|Ex{_>C<{XQ2TuK?;W81ZES7w>5Sisyu{~u9dMrat9s&aj`n|`wfWDK z^^LMN_xB?A|0&d$=c#@Hju*(!oy zjL*xzC(qrW{BLWsKEJ5P%e}g3J%vMbJ|E%SO!wCSdxt9T?ea+)e=trb$~WTpR;~A5 zSC5~xHpegF_`QNlJU`q-eL6<{{eXSGkFd)Hns0^o2kT&u{AirREnWSyI=<&S@1pe$ z!SQbL1eY`4`*E;A?H6JHXYJ=2oNiM7zBBb(UHym3|G=dW&E%H470BY6;xX+P4L`boI>zUm)#?HPYL4hCrdUv~Lg?aznS=KLvfJ$y-Cj`1TneN*{UIOr?C>CEfl zk6k_Ar}-I&xqLV-z9^rHEBJg|=J#XzWB(=9 zU+;20f4dupydGSF)1g&|$6JE~{2}&UP=DKS5&w(*Rmu-A_c42XqUYqsIKyY+Vye6g zF0GL-vo>2(o%3Z3dAM5n6dZjfKZ3LSw4Wmc>_IqEV`IqRg z0glYy@wGqAtnK}1*FIHlL!MkxMX!r%6a)z$t!YctMI{R}0uJC@=71n0_jQxzQ&HP$0zv<9P<9#i8$l){&qNB zXF4%I7h0SD>_C6Rt<8KY%;y&J`%)6)Ur1FQ~bvKkNG*m z+T3d0_p_UkrzffZb8-G6)%U@Li{+u%$D>_-iSmiKO#ZMl{grTq$D z0{itDc`{#*55HKO_3z|-t}%%9kvFn7xp$WCcde~WeIaC&;9Kw9JJQ+qnE7Bp$!(Rzt3=S znfwcm=gWHzR(-rgu8(ui%gu1IMsA0rwerQ-!y{aK>L+6VCDqTxDfO#xO#U7&y`uVW zaBiLa7cRak?>|KI&*7tS@nz+wTbunWvVYyk^Xrul!P#r_IO=Cm{{VULy7J{XWj^b$ zpDNFs-;j6U1n)gm^G)X|KO85tZ-M>Q$~(LIN9F$5<9Lm6UaEYm^Cddp=i;z~uE!T} z^sDOM#=&p$7F_&E{@2<(-`L9Yn**;jHs|L{TrW+m&G}X;tNtwPzbRjc%m2z(J2U&?{j^;NA7vbzrmH0b${FKD$Ot7P_Bo|{J!uB*gr}8)6v>o zs%Kr(rs@W8F?n*J@@uTkQ11PJvE+p6z52R;)EK7q|IOE}{3c!RaMUwPy7eBd){b3T2~`Lvz-9Iv1Lvo_-wxS!T3 z7@My1{Qm5bxN^A0I|JvMYybP;z)^N=y?V|hp z;kYs9--$Sn+hC8^R~K8G^(GJL^ORB6_V}!8U3I`_Sev1XXY2Q^p2WdY9q+es{(@Rn z^;@jX{#@%GuUz{Pn*RY;tG{Hn-E_}85$6)QGtT3oxPO20`nwzZcqz`~ zw{VDm#&J&_pWJoqKW>JjMasM2c!_)!&MlTFyY}uN>p}YI&Bm zxgTxh?^QiZo>BikuH2{k?at&iM`}LaaOF*Kj{ZA3lMlt=G}Vu{HrHo~`$OXL$;w|K zUrD~1yh8uKlBeYRj?#RhNowEJ+VsDUJhV2KR+;ZN_qR6d&shIhycIuSZ7%gnqW&JY zHur<;xF5Vi9&^9=948m6ewQ26-kT*Kjf+F%_Bgsn?r&}8TV}qowV7|q`wi2n_c^{R zaUOq+6aF6EE;nlYLLc?-V~_a-I419hGd$MX?$1X3e)2=u|44oYNBDi5;O)4=e%2nX z`NW*Bd26%YjjXo|d5QC55P3#^3we?ABf-&KTHjjgw^F}_JiJEvpX3$tI%71S;uPhl z;FR;HhqamCPU=UJ$4gZ|2?r&49`#Z`|EZ-wy=#OVU% zN8;pZxj7D+?^ktvI^p73@<5lLC&$?DC_m)t@k*TUqc)v8z8{ehugGH#oak`QGC+e$ZJy#<{!P4u_Y?y>a1Ac?izW zmv46MACsr!GJeYC3zWZu{fY9IIAVXcJ1FG$<6-#{sGf@8B)I-#tQY`Jcg4e6B zkpnC6L8VV=AEEsw=fdB>k?^-0IrcMf*yI856mocX@O*N98o1rGUkW~5vFhK)a6Ne; z*|-&aqnV%M;SY-Cd>pw6=i4Vt`=7%84RY=`;4jFrM)20lCBL+PVGgd}_fah6XUC)d zlgP1$U_X~!I0JfuZ2SuPsiw~F`TtC@w10@_i>s+eXnz~^!dldSEjjQQ_;r&X2Y*S9 zJptb7JowK&2|kECNPi9FEc3_6k*8sQikbgK@TKJ7OW-@mg}1;joBBK8P0vU9k$-^q zCTBkfPbU{QfV;@SufUg@{2ur&a%4T&AP>F<-t+>LSNsTk0D15e@IrEI)1W?IXUO?_ z@Gnhf{eDXhjf7qx50GCZ=QfA_7C9US|AU;`8NAtrh|eJJLe72<`dD(V8eB&%ZUde{ z4)FcNq|TIk`+*N7NB0LGLoOT)ZX?GI0-r`Ml7FsP>OY3%t)iZ)g8jqP z!_;3h^>NTYBM*!Rf9GfLS5N!ViY0!7`uEAv-C@6g9A^7=k_!`|XU+WN%M{CccaZxl zzfvsYt)Ba}chWvE0r?*w7Y+nJW$LW|%gn!w<8?iCV=V0dsaTzFS)Z*gMtzEZ!G7*& za*EG;9!f6!0{SuJ7=Pa&K_1}uOS9zYhp@kj9FX4`R)6jzhu#OjPBxhTD^q8A!AlTd zl)OJV^(*NF`7?tYs6qXj$-!Fi>EvP^cm+8!34E(!X^$fJ1B&DsY@hdNAEo`js2jB3 z>*t6sMZHe3_#32tJawZU<(*1BaM5HP|IO56{2u5N z)E83^QvV6{F!g(>4^V%edW8BH)Qi-&y%heV)N2$=)90wqq8_7uGW9(5<3(K z{xJ0{^$(~U)HnSl%3sIlb@x{+q8<*9F={Y%t? z)c;0(#JT9NomZgz6vtyVIY*9?!{3pESpKw=2gzrdycP5-$oZ|ox07RP5|BSnk%Ldl zBq4u3B?le@?|2#F2|Nz2B?q4XA4`sG2Y*R&jC>xsScLrw#WJ22vAu3K^*5p4LC!x4 zE|MdUfIlP~pMk$5$36#-xE%3@9|G^LSjvmByo0Ex-hzH8^$zNDsApe?-b{`e;8Vy2 z@_?y-0sSh)(i9=?53Vxpso!Jr2G~DGjywQKAzjyr*KRUyAY9 zQ4f6yeLD4i>c^V;SI`sW{MX>Lss9;#4!Q6e_!9Eqj_B{36ifL7JiZ>KUVH=gFOXwv z!S9g={saC8Ik*Y@ZF(i@mu3I$Og32GgUEqFR*&mJML2@TK_Ac!E6-!a4@cebL zVu?S?_PL(+;Y|@wUa?&775Tj3{mdWX`SU62>!`oV{6V(Qhl<62j_ot@Dq)#lvedt; zSoA#gL#RhyK)f?e`#*tCBp1Gg_`1na9zUll7HJ0KJCAzgJ>*|O4m|~4MNX{;|Iy^X zf}b$?e(;|aOT5e3ULPqIX*J(>`ln(kKf>|9<<;OZyq~?RVzCcqa6P>rd64^W_2fV| z^rK9B@(GI7e#m_2ixsQ$#ixjG8QJ&<{1fuv$KY$p10R5ICl^MbJs(gk|2&oB<9X_- zHLy3RN7=srHucSs|2x-6ercZpw$E;gCBDKI(8p3=LH!Ww;g{immTCWY@DIqbe}mh| z5yrEO9J~taor}!;AHx1x#cKbn9_{rz>Z$jk7pMpRg#DmDDOTgv>|fdkK7sw$=d&>N$hT4d!^znTw$SIBW5_vjf^3`*eJMFa{X%kpoFf;=zc=%f zA0&P+k`{cm8_`T;%uSI=ABT@biA*MZfHaSLaCI{b!|5L~Y`Df(f z*6@EFx$qI}?O3#cKSqJr5!W=>ITs=&$fUmmH-3 zc5=QO<^4#pl((AxuOb)7chY{4?fDqFxGnO(K{n0Wy%_lqBuDoJ zA4!fJ2#%A3bHG{Cem3|9lfS_De}o+R1pE%!VE!-2gMS{^U$rXGiVAGvS>_-w^8)fRYuy;QMGrHgp}xrO>#>T8%k_D{tB3iTrOzmeCG zN34W@gS-oQJ$YYKUxM?;1o9yD8H#0o32%>hPax-$;3bNszD3seV&)I?{C^#J1O5Gh z9EhR3wTi`mbOQXnOimpJ{z$R3$7wuYZ+bK1IRyHy9ns`EbTjj#{w^j5Q{dkymi}AE{(FRaI1T-E>IU^M z6-#^8GyW03LA-_4?s_+Nan)SCXSM zkpC7_KLz|C^AFPBE94F24;4%N5yt;Dc?NmpEvS#t27h}f7W*jmF!kK;_SEssB}cCX zca!tCgD)h9R)KFJXMYQRhCE1rACrr}hQ7_Mh-cs$@WG0uy#hZ%`^=%9qyG#!e;w>E zAqQ^)-)ZXCga1TM-2ncVV!0kNc)hdBD)1oh4~|!?#{0dnKZ+d5gAt=E&S(bKZaZ&AF5d5%^nrj z{Wa6%t+AgLC+DA(Amq<7a-j%bK@L&Bl^lEu`orYhGvIg0foH*+=23oR8nuB$N}1)PmVkQe>akYYrq9^{s!<1WaB#Udy1vMg6yxasfV^j zc{}_L@ee)^`+do=o4{dmo_qv3_b~LCJ`VgYIrl5@r-~)sF^o5GJNyrR3&+n$a^OF(-&L{LhiQL+ zVv)||{5OgAsY_r#lN{Ux{*EUbY`<>P{sY*bNzQ!)9#Aapk?Ti$U9DK8dhXZUs#x07 z;Cy*MIq(9;$McG%y#~g@-|OTc`F+~wLh%1N_2^EpAMpp~=ljRok)ywX{#|nLMDTv( z)Bt!Qx$raaQRKiy;2)AB96z1p&`Rh_$wApiR)3b0^EX1jRI&6&J^SM(#nK)j*8eVY zg#0w~7dRf*kq0k;|MiN+UvAZ8UEWvZ)WzU!?tnf(-iw?kPb3$~N0JB0$B_eHs z0~O2hnOltGvsUpYGX5__drea;<8u+$SMwB0Jh@%r??l?ic)seO9%FwjVg4A8@3R$4 z`R4me7chTdd-QjXoW1?Kx_@pb=kEm%l2hILY5lva5pU#C+&>SK18F=TI+dI&?xXFy z$b*OMuK67Dz)m=RFDDmw2CpJ#ua-uTKcTx&Ui6QM=QwildOTmSglzm8A9(%;Iq-Xw zzun!)A3GQJ2a@v-!e28v_#EudGkFKZa}7DSBlvD|>=ERDi=27{?Xkh+gVA0G|B>H5Aw4*Ue`?JvoNi%_0=Pg9MT!3)6Ed@y;ysC+zY+C4gB&=&O4nzA9JvVfx!L41 z5YH3j!3*L4HB)~K`sVi`p1@t;eaX3A@Fa3}U)1L^a^Ytv?>2JyBKUup9D4xyza|Ht z29LfURsS#$iasZ&nx6eJFYkWMlMc3eBXT#{$usv zY2@qx+Ve!RQHAU4lgR@QWBmV=oL>XJg&f`$$Ipx8+*V_C{Wg0D_+_c zczL{LO z9Pt*(#%18oO#P6Mj(4X=P+tBL9FNuHVAT#n0(`Qirz$M_F$+6492a<~qfg8x#UxI&N z=3fQQkPDB3e@Px30N-rtSAq-Va1Q(mIe#wr6SA=!JhI4mZwK#b@*lu;h2$x^X`KD>-)+&L4q4p}ffT;GM{UYr*5l#zC9w^UE}H@IdhKroJDzmmC`d z{;|nn@Z~1Ix})}Y8+mX~tY@Dlr(TD?o}Aqk`p9*NH@rFcKyq#?@GNrlpUB@u4(J#_*(`XlfX za{eUn<);0K;M>UIB=|9M?uXzv$VMCZYjU;|Jn9w17y28!GTn#?U z*;~_$6}eWbj93{uKCIe?~m{<>1}Pg&4S&oQ;F$kRusz2RW4hpG_XT z9DJo|e-8NfKB9C$@xpb%S}E3 zd=oia!1}yE4m=2cnOq?Mot%3J`Zj+-JcE3me?M}F?~}|TM;^fX;tX=&$Cw}T$4&`vH{26SLEo!IGPCf}B4K`h(=)TR1+qdK38ve*yc&+&bMIx8~rZ)(?X6!M#ylnq2q=+UIU^?key<$&p@g?RxkNUyt%K$j7$ z+hTv_c~cL9KQZ;6ZlU{s>km*~p7$3IAQysY-v*Pn1TQ2Pw*YsNjS=7QINqmIziyY6_lB3*Dyq_H6eq!Wf*k^CU_&kwpaDG399Oi!F@5uwt!v0m0 zw@3SZMhPL&<~OPiZun$MgB*BFEd~po z6PJ=x+)uoM9Oiyvo;<+g{jcO8_Y-&egz=BZ@z_O=6VEbr z?k9do&T>C~>wh4Bj^~48$b*eIUI)l2?kDESVeTjXogCtRV%_KP7v_HAEb;*7_w&ew zHq3`Pa+LG&(`1A5^_OJ%K_@*w?eqow$GD$(06EC*tr4a7q$uMcz#L_azF8Rrk+9j70LPMF@JqXF5Zg$mo5JZek$-?}tOKty?XNpn$M-ZjyFbeRoSeG_{=WMq${$z-o6540eui!t-{lvYBe7xws7aKL0}g0QVDn$+?rDuO&yg zpSZ`rVP9;6-b)Vs5UjpysP4Z+F9GlUA8=?9xQ}cc4u0C?)6sro1K-y9jX78!-$Wi< z2_C%(^xUqPPfsQfaz0u^PI0}u)26V`azC+y9N~WAqvRsjD<6@A+)v!?TgV^de&SK& z5cd<)ztcLx_%@JSz9`HWoLGB+O zN-o?7eE~W2f8di${UY!=W`6E(-bBtm4*d}`Klc;gCg*;M^XC>@Af5vE4@2aEZskb~S${G6QPe&WtsqP!^g6YIzU?kAo=PH{i+Tyli_iMN={{lpi@VeTh>O&*+u zc=jBL@&Z%AlgTmeCpMA8+)q4*9N~Uqo}B#|^1nciazF74a_%(fyMKrMSN?)1Lc@?~w~P!vA-+VtaBwv5Fkweqtke;1$dtr;}4%I3KSh z2f3g40C|x6hwI3(9L_(Vk;B|i+-hr-pFLo6eZCn@PH{i+2y%XZ=<~?Aao|pq|BU^D z|1e+^9@rlCUE~P&6E7kg zFCm^)CjSNeC^^9W#MjAr^1sMI?kDcBE#gUWKe3t|=6>SQ#-dP2j!B0hV_-In)CESaOv6iM^(NG4zYcVeTjX!DRN=i{!!k zu|N0;Irji~s~r$ejQfdW$RX}0P9vwdpV&ms)nWa2F1f(_m475>&&K@mH*%5teG7L) zd4(m2|1y*Jf&C^sK@W33F-(qfKe5Twm&5*ia*+OCA*VXve>3?`v_4+BpV&>#llR$$ z@qB^fFG|j>!TI$(vT+vtJweX%{@Ul{DD^!@!C&f4%s-1w=6>Rn3a`qwUr;)?lPrTl==YHbI?;(GH`-x%lz%JN-Swt>A4Szo( z7izKIzS(3xAN8D>e=p3p{~Ur7#d zKk;sIl>3P)=olP@O^kbgs7LB5NeBR@o5Nq(K2Cx1-N@_ErsMoWF=QZ>fsO?Ol*?Z2A#_5>Y2+e#K6xEEPBzGC@_O>=({`w~J2=Z!jki3>Wiu^J;M1Ge% zhWt-*n7rk_sDC|qcXEVWMV>)ElpH0`CNCnNM2?Y9A$O23Ag9PzDwh7}V1N9MoFcEG zeLwAABxlL%$;-)KkO#jpPtH z&HTBw$bULH_7M0d{|Pxv-h2%7 zdh$->2zg)f400_wN)Zy=vW4&06L zcL8|>`4{9M`6lux@@jI3yp}wM{AY5Q`~kV1{5d&7-sAwZ#|-k$a`KJj0rDTnE65L%bL3~pE6Hz=^W+c7tI2@_+5hCN$!p2G zl8fZgl$1L7qC>ucRJ*1p3Y7?4#g2$ODgopHZype;4Zirpf2y zd)*tzv7dprnSlC+{*3WBTCwDh9fSObP>)fMQZM`qdK)?ND)=S+Mi85 z$NFDx=I8sHdD_?GvBT>I9#nS!;?Wa-??F0McsD}*1o1%W`_R!Cv9;1FG^{Lcvqn@L_Rq?Fw2!g8&uDMZeq_DVKBQRMJ4gFk#S(w$4a7IgW#3Hu6+0r{e%i-qe-ZW2HPCM$ z2VMi;P5T_}i_{I4|1Ncd`qzqW_1k_D;?1%@$0%0uzKM7br@oT$&8HrteiHRrY|kut zHSI5@eUA3GD7KaVAnkK3e;w@&+J8)aE&XkF2;+MT@$IHq+B@_Mv`3hFjQVuNw(?Fe z?Ym%~rhSg~%c;k9g?=@4gZk}?ZT=poeP}f74cdp^Mtq-BpU?K$>idX4MtyI^68}2Z zubz62`W)&fFn=p`gZe4d*E9bB_0T&g|0cz@c<-V82HHPI`xx!lyX^l>`vUuC$3qc+ zj`jyAw)u}Jmiid9Ur2j{_FdEi-$Q$yMLqN`;$1;K%l2PIJw|{4m6mqrcr1tNDa_wPIWRGiV><_&AaFq4yA9ugm^?+6R7ycyhFl(f$tVIr@8& zdXD;=if!d@p#6xQ;BTA5887WeD^}y3?RN!wJz!8j>_B$(vK8nbF|MZw$=X;+RtGAS7~q1{!^FzhzQ~}evNqdP^{*|_YvY+UJqsTEH|1sLf zXupJd_7||fka~{#b<{&wKwnMWp#C)V$l1`}CL65(m$VOkfcS!w89&S0PqD-wqkbs$ zR?a8$sOPA6D7LlV8MM!_em|$ZLHl1*5A`6v0`<^`i038hi`f1jk|P|yn@(YTv>&C| zR(_RY89y=FPo;g1_Qz2VU5)Znt zrG1R{UsGRBefz11KSzCxVq1KNE0+3XIX>sp-k|+S)C+8nEcMXe5Z|SWZT@bdy+Qj2 zX&iq-sbCG;?LgZgypv0I>@Ks_{w_|nu3_SbUiG3r-S zk8r(yJM|p(#}(V^XVBi@@$xzC4cc!t-D$tKVu?TSOT<^NSj{(|Aig=&yUg=H^%(V2 z6x+%lp#2K=?@hGN(f%Hn{d2Srv3=Lm-k|-zUG_U3iFjAi{{f0syq_Z82=y4}gN4*% z)Vrv!X8yCN=cunxY^%>I+D91Q8rmDQf5l}#Nc+&fXwS`OFuuPdzTFk8_TCM8HT4+v z8H#P?pGf-{%kQOqj`ruf>~p3)%fEy62JN48*}qBqwQP?Kv=4oTc(iXg{=P;3&is`Um3Q zS+ULjAjJ}Y=nU9Tp?!?@i%gyU(?dN+{cOcHf0xrf$NJ@IZ_xe`>ILerQV)HO_&!x^ z^EcvX#1~_I_E4_wsl=ih7QEjQVNRmrysTUr7CI>eo>ZeSvsZE4Ib+H0^VY z=WW`@X#b_lJ~#{UuV?@5r&!|8(f&}yHvjWzzk&80v^QvfhRgovv>&lE`tR4Y4{bpF z1(*Fxv^UuPAJRTX`%Py%;~Aw`#>Xi7uTreyr~Ooy{c*G(L;Do%4cebWJ;wR_P5i11^qux`yA~Jm;L9o&(i-^$1q;n@2%JtPrYI_Kkkq5 zH;4A2e>M>q#oPQJ^QjwLALpot0{A}Q9g1!Ko}_(@ z{re{EW3=Buy}_FhdD`b_{|NOFyP&?WQa7l7NlgI|g zQ`MW7r@okCt!qh_-qrB_6F@AH|?*2Zjb{vfj_5xXe8p>>IB4Zya;`7 zlb-|EE0+4iXg`N~j@Q$z!h+vg^7KlvWo8?=9pdgx4)zn*NIv`8lD zK;Ylxz*Eq7{2|->JE+eAie-MhhsS4xdW`x)>T9TXQO{97i~4fLw}QGseHHa5nSTxS z&{in_73zfzh;NV_V|_M1k?l$Q-4#o`2HUfmdXD-G>XEPD??iHr{(5O|(EfbtD;R%{ zdT49JcLzB}euDNZY5xW}lEd-#IXSly{GBGmpJV=zVu?T73cbeU{lQ1k-k^OG^}x%h zPcJ$05%@gXhqghySDW@D;P3b3>>IFOOZyn@|6=NU!TwW|_W*AZWBjz=U9rTUSf354~X8 z^Z0*}_BqCph&z_&b7Jq`yt% z$Nvu9$RF4d`KOU1A#jh$qrjIbmg}D%@%fZTsYiE#{uMdIct-cYe{3Z5M#WN}&f{b^nLn}KR5z>AvsU}gdE)xddm{nr?vpEAs7FG`j1=+JoO%;HSt2`LE>2Ea+dD`T6@>!81`_iu!1B zj66|zTZt#X2jYp43oqgQ-($#uJ)!@Q9D5Ubi?FJW`KQ;#7rOWw7vJvUM_l|T7aK1A zz{NXfo$*X@@ef?Q%*9u@_y!l>;o`?!{DO=B?Bcgw{DF%JDHmW$`R_#_wq*u^VcoOkgeR26yK2dymeD85-?;pZ$lrSTTO)sKZ*z1*0B0RY93!dsaAdsL~He0 zF}0SGRy(mO93D><|0g*lbwX<*K4DU#Z9+}mqzNr`wM2~i z+*VUvJ3+@{rcSWCHA|b|)#?)`c(u;NxQluypsm*N(_FJ1C z$4G7Qj91DrUF!c2G)-wdc5<|-amIq_Q<@s)&k8h6PxQ8QM5oQ3mrV9%T-Y=_+1Jw> z@9de?nd}KP9bH{hEB|d;G<$Z_Hkbn|I+`NsQ#t@Q=|SRd1p1$ z1)7>#+LKK+b>r)6Y9}<;gvXC>YG~{0X=!ShJ~iGOKQhrfWm#_`+MC`8%UOw@_TG+4 zhVv3#iFhXAZ{n&yf{Qm#st(uH)sL@lZEC32(X}UfCD@zC*Ga#wbHJd z8oJ|MUC9X?%6P__ZfYs*abXG&@sdoV#o!McJf#!%gw- z*4l|pt?~5IPB|u|oZ0cr;y_b#W@$X7|JmHv)|sptbHF^QLLxo3YHDYuC7x~#xYMJF z#Nx6MBcI zs*I=fwOK-AOT4E?HN>=Zx;#;-<*D;!U|FfUc*#G#t1r{xomy2Y&a_rdFg=~@F3X?| zyi*;uHy!E!Z|s#rzr8G1n=K@%-sILL@tziGs^s*zSyxGx)@Vzlr}tT{C27+;d*WU5 zlZz8(?Imqy&ysjoXKPtcxFuW9iZmzD9`Eg3l3?MC(IzygS-g}i(alO)b(xb`$_}E1 zB%tPGrK&NOakJItiBb%<;cH8^x451jFkIC?)pSr5XqLg9kwXRzHMUCigOuk=mD#>5 z4F$RkRU*35L%^8u5YVb+LM9>OQD9HfnRmw*CmQ;C<#6y#tZI{5jAwDm zo@W|ehQ;1iNR^(^i-@wdMT_)uI+4kYYwMB&Os0y4WIElKk|ZwStJWGLj zm~dfhRZN@6@!QamXjz=;v(4kCGQ-QM$C0b;o$YTWnGLOX!4m0lU7eX;X_Q&=f946> zQ;N!!s$6KuWfxa6l1Z+kS`u9iz5TK!Afa`s>vnHdZIO5?QeSVuY8|~L<1B1pysOX0 zA40OZl)Z5s*tGtZM4~m(>RL0I-hIsG%Pvo{&tB(5cdB=pUzKg5v&JRCS>aN8S$#{A zySi%YDeV`6O>~A(5}YBF(#t|9N&X>}HMm^x_a*$Ivx&~=N`f=GQhHf*C265!JT&N0 znNZ6)^sYHJ%^_e3$9DF1z}h3pn$_V%*_w_V)@EV_do5M_=bGSy=s3{F0DJpR;mB$3rbfyR)w%tHf4r7QKoa#p=Nuod5LzJ zrW0u;m`1Ig?TJjUvXXTqoOg&^B6JuOTYn*;bf&Cf?s0LwZ*_EHner+1wOxnmJTwrq zhR#%n+Fj90d0U+27P9P8d7VYrJjiOMf<8IZJ#-=3sB$^lq;gS5Hq0KnC~Z`^C~dM4 zMM-aqsk2?$Te@|mbCPm)EpJv+o|}@*L-aTs+)`xK)FG!mZ?!QY+ex;3_MSFpgi=RK zfaqp>7U?;u8?WF>wzlLd*?`KZyB#fyyVVv#$*2`WL1&g~R**K%$B}YWm%Jx1ki5LR zB!BOALznk-+TH574V#+zF>1A3kTeC!%jO#0w7Pgdi6EE^NOGZ&h5u-nLR zR8EF0)n+$DsWwZWQhVhjw`lG>HB-v%=eRX#mEuwsYLi{=hq2u)O%8>zRb_LzQ?}14 zF2yyMJ5~E!?o{G^@)Ut*C@t#VnOr}pR`j-zJrue5ruU}QZVJYc(|vcJPeuDuvRx_H zW?q?~d3L`#%}i;qMwBZ*RI8sn)cNzu6Ky9}1}}ajQLW_t`Xk|-;hC>ZZXQVgt9=Of zxTSP#GTrKyq~mAyv`nxLE;^Isd5P9O{eZ#zcypJ#vFsBLvy{y_Ojk3^lm=JLOG~;5 zb=Hy04E@QpS0yCbQGwQ>mVhvj|2Ft70n030>!mWCy=zvcOgHzW8vB|TCze@l4LiA& zo$5+Voz^%+JY{yCQI%PF#HQu~bA9YwHK~YXpvnC#dr04QTb2KLle+rr46p0F)x z9O-)PQ0AsBp)L`uqfK9@0a;vpO z_fV%MrDUs_Jq%`M=Jqu7rI%E)iN@3MZmUx~oXE2fUGel3d7x}|Uzc@0@HH$qvg%V_ zos#5Lmy+sJk&=N|ElO&oD!8r6<9Bu?DlTV%;}YqlF4pXJDC*LBep2qIIFs$Y4?~~+ z*P9AB!V+CwohjMFmNB7w5tVd~3Lg_!bNX17H>;1Kt9gB_e44qUwWGOxEakbsqv9>e z=1z6vu5#1F<*|jHgnHa%V{^3XgQ$Xas=9ijZhpUpw;A|0yUnIjqub1Uo7`qIWP_L4 z`ZRY+p7k4|j+Q|~vb$N@xOHe(6$3iXW2 z!!L4AL`7OQKbFR_l5LjypYxNG^+@%px6K>@dj_Ge8s$W5JM~yo#_V`H(^1;SvC^Y5 zn#&4}N`&Q!6Y4!IYpShNrsZ=%Pq$BLZE_$^>1;3aEsxSx*Q@6M)R8((ZCtw!YsYkH zHl<3OT)KX;%4fRT_4RP$S!0#Ov({Shs<{@tYOe&xD%}y6R(v9JtehOV)V^L>WxCZf zx9%Et$CouH^wmOQcCs~ErmGpiGts`ZFdJAIOSZEe5Qkv!4PwS+tBkER7QxlVymff?sXuj z?0O3HZqJz+waV~pMv2BV-FpaNgm`9vgy#X>qf3QXVFJ>!JbWlmB6{ZRYxYd{o&1!) z`ANTaQca=8_=NHqNM$tTTI-V5I;7ML>=B8~+MVt5lk%uTuWcD!8jTL!d;iZ-M5U3< zlS);^v!{v^PJ9ml)4=b%S#nY75HY>@9wMf}kcWuV(B}}Tsa4~Dwth6gHAAa-O>rZd z_{c;rLh|g+N{xbE_8VO_wKjbt;+UOWqUJfzD5!0W7tdq3rdFD9BXY|#@V+rn+Xyf6 zK$Q1XQd0|Q<9sxpZ0!R&jtTK0(nk2uOCCA-U|nR}P} zRr2JsdhSWuWUkj@NIewfYN^t;=EQn=rpsTQRK6mz<(*W1swk;7_4O4z*VkD0$gL4p z$}8{wRm@vgrk*lAnRZ?$bacnnc7XankGs$gbzVY0fre&qDE2$XPC-3V=8-|aeBe-I z`_jQ`5nPtwSl@QH)=1!Z7QrKQr|gK`DcOT}DW&M0f+KvV)S{lGYjkF`)lC@-me%ho zp&3tFqn)e-@54sP_O>y(w2f+|So@7;N?G%D>4l11F4;Ch((*E%YS+XPJe)hW3Xdfs zI;tI=t%=F)@=mL-4Ft0Xb+&j{ubge?iGO*YjH5yeE^p-p+AFMcsDx6DOG#Fhtt3aC zk(!w{`N+vL=Qu*hsFz8j@;*o+6HO=8trCaa*VEZQ(<`4{D0OPOWun?*HkeJLQEiS3Yc_ zdKJ~&**;f2`^nalG9<-**`wl7?@Xw>a_SwSXz95XCGqZu-GS`RVq14we@gaKdwLyL zH#(EsqEU?~Paks0(I;;_+BLPui&v9M_XLzzN1u_MeI|)L$sSd^dHTR|+-p-VQj1$M zsxxLt5i`|$*S2;kol0tIt<#XoWE1MF`}l65bg;Q{SZ70b4(oK~7W@jYx30`&?`eFc z>E5L~jyacRpYYvMY2tP%jw#=zx#xT>+a`UJOA~}naZLNAl*zNF)>Ps}9IF$!o~mgXKC%1)>G_J*=>wY{0-Xnix$-TpP> ztA}WRr-i%yovN$-U81A?otnG-ovKIsD+6cyGsSjcAnjjDbhI^-<^P(T{pA#V^ORQL zr82ZL=?!c5xFnUO$x2boZR13h>+XCj&A0QFg{$+;BuD3)iO$aNYnJUQ*+}YYtmu);Eh zQeQfxq#-ThjQ+}rS3!H#gC*&*H0C3ie}67BM(6~{W$9%OgCKN?@wm5l3GE#*4ew>oKQ&5DJ>Vy zLOy5W5l<%3(>l3J#(YIl#>wK+=8ip391Rr%SgKw}^>VKT|Ilo*SNX_@H^yXHU-lF~ zqKvD$xh`oOiuu-!{kYRpqVrM|c_^qRRlB|mp604Rclgx*2QPYx@HGvkv5bE8RZf1@@d^WgS^+%BG;LX`h+z@cGIjYA@-4HWO`i5 znN{9yaUHDQr6~JGDMl_Pdsi?ed+jZaD#rtui0DY|xR}{5We@At$=`zsbpQ z@!uEe7*M_?%F{!7@Tkl0u~i=D4Aa2BRUH;Sjj3Pd)=wBuo;G=^$HU(kWdmB6CXdaBlJJb1-|))mh93cxv1y)#uf!+K{hTTm8G`Y|j_sT)(2I%~q( zu>KkTsEd2a(|4omAcsV%%Kj}sdBaJfAldPhoR3wV>8_-f7+;` zFWY%+D35MaU%z@a#3AoFgJrN_qKTiMOxJ|)?8yydtK>hfrnMydwiAvab!{(SQ}DkW zaT?5*Paq`I@wD}zy_XlYL!!UXV831v!|^`xl_Yn3Rqe@U{ar6>pIen@rCJ+9j#TS$ zBuA>X*{D*d%8Ls2Hd3s=CLsS`dcVrFEGg!@@TH15bDCcjsH{8BlVw+h&ihp=h`1d8 zlczP>-kx%%Ivwf@NDn9Ky0WVL;!&IHPhr|Fwy`HQL0;dnH&ZFqSt8OU!g6Ct^s=2N zpX@CwP7=Lr%Xh|F^!nGlB$yR%F1=i%8U`|Fr-rzkM&wv@6sI0(loN}7^lRo+yVRO! zi_2RVwrR?-DQ3#bfx01;kWVYfWs}{5UVTq%nA$k`=*fQR&T8r$^E~Z!s>@n`?L_Z2 zI^4@wYARh8$SpekbsfiLnj|*r3qIRqWp`>Wt<~zh%68XYwX#EFlb1HG%PizxNQY{2 z9iz{drNd=LKZ8@UZBOVTlg%c6X`G@9CoaC@{r+^yOto@S305md?Lxt(Ww*4d`(8L zOGL7#r25$vkGFttv&ilIR`r=-Tc@jKyJND_3C>boOZ$!6jPT1;@nCajG8fL3rZ=BF z70b!!sm~lWW#d!sL6i;743|>wMV6KB9za@<7Iz#_W};(2s6@U~F2;2CHwblb}I&(>>ooGF2;8N;q{gg>H&MK6=O_Cq7u#F|zcw_|C6DC=Y z1v<--pI-3GGtsY{>blZxf0sA;83>;U>ip^>-h5g|6zg$|vU2?DQ&)Nn#GR+kr`@XS z>YV*wYPY)5TjFKj9P1`qTi4b3wt@Woh-!`cC zZG-v=zTSM=K>c2eX8^T+z9zYbNBP;+Tx&R%crw0m!&IIA98VOf?y_Gol`q2`s^{gD z)1v%ZO3KhzQtmm(N_Wpe@`?U_*&dWt1D_<*S9|uRS`wG1&&n6R@>wnUB1Ljse@%GO zn5L%r(-zGiC%>$rZiJ6j-`w&NGxDl_PrIM2e#>F3S+a7g?wiYXNi><1j}yxsS_S@k zNw{dF%}-dC4<-TJvza|!BE ztdFG{A(gE0DREmv=r34urnzi)0P!V1#2_*3MMmqGKm)Z;=h8ewMetB6vn!)dl_Zp zGFhH>>mQ}5;BG;W+}4p>;H?dE)gg~rbWQ8;P3Xn7>n<(5F6dd@lU&*}Sw8oou2Yuz zy0%>f*;~{(XK1JT*%OcE^e~mu7W8DyiOgyN#~5_9w}%h;Mv8p+Tn?Y8d`Eey+=tgy zaJca94-a2*Y-JL*nmW9c_mo#hxx2}u6#qW*H1_Bq4?Dk~46+}sZX5nskf(|HGeI7r z^9O=F4311X&NF&csE^p|c}c&dlSo@UcF6ZDm z@_R>)k)!Vo=&4LDb!7KqfqFu^+`<}Q4oN2abYG@-N?QFgN@MhB>xy1CTta?nBq>8* z#;tP>lyjF^lA6}%mUfPiuOy4)oMGiLE$h1%)-mbjL=3H%D;lZ|0!O7(g6&ADq?Io0 zbl_!s4LVgn%2S#k9sXRJ^D@>eH!NJ`cE{yc!OXeH*y`@0AT6+G`L$y7D>7m-* z(K1zQ2+8K6J0?rhTaUh~Y$!T4+q+)67CG-3mP4|xXUZk(f~H)uu4u|7>yoBSs&!7P_AqL#i<Tcp zG{M<0)>WTeuUpqO<+-ejyK>3DHA{mM4ojE0<&uAElrD73bNRPM z=~A~mmw#)NE_Tav`L{;ta2kAN@*f+eE8g;4{$r!`X^`?<{$r!wzcuRpkCf6Y zmt|#5@^7fpUXMGM{OYC8n4ehM>qI7>^NsvmpKYP;bXJnoMWjRPl^3R#%6ApzCELl3 z4Kp35`EjYmo&9pLrDkjS)i?P}q&m~gn>t4xROwSUb?lyC>^|j|Qn6DnxsqyUbzD5t zqh7|Dt1m%kw#srtF4olNF?sjRZ79j|MqQu$K#${Eq0DTV{0u;U1rzze3reWcKhre1 zOJ?1G(~CQ%DqMgLVdNRND{3yFot_#?A$#fztOr7!`K)wx?^Tv!>WgVk3wdWvzWFtO zSt?O3%$29*-PUXwj|_<(c}_4bPtUh{i1JHN?HVPf^d<|6_SM;X~uUsTd<|j9z zPdv=z8zfCo_B24&6Zp3CTH8r!l8vlec%xt+~PEH&-Q+GbvS zX=86|C3(TTS-x_mtd;UPXDimlW4@BF(8-fOc#*19t5TxtEJ$u&a12hfRhKX>TmDK0oXs&Vd|Qf)o#tnfT7ZRcNev(oAYIG(4Aq6~;J&ImOn^y_m@Vax%}d@w9)tmb9U>s#^C?S*wB$&=@@HtgCcqm8TvT{ia0Pcv5btDX$6Y=PC|#@K9Ra2ffzqGRR9dxnUt zuYBF^H2^F#?hsb&5SOuR7FINuTTt?gV?WW}|+WBTMhQQK;nb<%~%a#Ig#ufyG8 zFi)P=EQ_nmLT%>{ZKbYBhqltcg6wVySBbLDtnA3W!1AiQ?e~%^7Uw!`d%4mkLpOpp z+nCU_q5SxC#kjnu1xHJnPheN{LnEJ2?d8wf0I%p*o+wox9&=p@cr{-}-)65|TiD>f zk-J#=37~2J{aL`C3$-kZAl3W7oL=m?d>pfF)Y2N`LH)c(CfOw)TX$DZO=9xhdSgFQ(~J*4r4x8(~s*LQ#IygYO&R%ge0X zU#6wAQ}3tg--FlPpe{3YW#SI8EN`>yU3yo=rj+Nx+E)K=ud_HVY(*(sCYqAR5)sQ* zPj_m`>g`P{p3ZQbdb+bDkMO8@xNK1m^XqLoy?fBeu19W?;f}cmEGldml_{>i?*Uz?p8jc)ggO4 zu3T+ui*E{sf|ukKhWcG3uX^iQVnX#a&!b9yBr+EqDT{*YxkzW>&ovr%J?dPJ*qTEYn zntHoKdvV8(hq62`e)zza>}$F*bz8dIScOy%&GJBNHqUD+O&V^@dNM8MO$t04=kVBpnXx(YfNtqv87-Ds$iy!EL`_xVPL zAjzIRq0)UFc?;9LT5_7F_h~-9r>TdHJl!b4r`R5OTgJ8pt7ijUH~CVkD89LTyG8P8 z%_pbFIvvF+!6%P*@^r7NPLF%1x;K4vnbYI)%!q|$xLjCc77KIz`c^6Ht_HJ^^k z)TU)xyn?gI3x?7?4}H4>d5y`V{!WVt8(~tpmQs@i^3gW;<(s><3w$OedpJWnschh_ zx;N!@VDb@ouZl~ukCQ%6bNNWUM+?u9Z`6A>$DBT&bnj&O`3d)RtqxwLd*_(%70&#! z)0H~O%ujn(Ns@hB`y9XXJ-!+sc@#KvFXSwQ4jUg_K zy-dnWvitE^6e%axg?=LKWg+*aysvJ0)g3F(+S?S*O**A}UPAWCO5fY1O)0BnUyokI zxtfrvUK?n(mp+tW8;p*0+f?pIx6R)weX8rmx=O>H z8GT!?RBa{5<=ia!xiV*>^Xg5Rd0f1yWce$r0cU2U&21}pD@tQ;T;3Q;s8OJeqe3D;19wbK7<^SY6 zk@A^+^$40*;zC*8yVIx26JPqPHhzLvCb^wa=19`KOy%Jo*(-26*N@Nek&{eim4}Yo z1J@zm$zFjhkb|nMB$eo8?3vb?!7q`y%WRWph}+6s>kBRQ5SZJ%ProI=RJF0Dmz`s) zX3EcvCcCCfFPd3wqI9fRDi&k()yl4gAgmGWFJ!I4SYt#)F07Duu>gQvNf z=rG24!<0%@ccweCsF~3#B4>J8mhv)G1~b)WUOK4cySv@;E|#7Mbjv#rA(@Tj14$|L z)=YEE$#JTB*6I`6Vc~Hs*ax>7qHwkV6FlBB(Iwmd*@{;uZ7Ju8i(PK-H`CB{C zQ=;`RJc0t$zd@$k0hSs0;=^>QK_<}DCO=Txq<@#Lt-Dtyp60$b`34C;oTqOCB3=GF zwo3lfq{eYVe#XS})b0O_feJo&2+dYx6Fe9WRnCL8&n zLdoRV&Q|&5b{i{CHjby;xh+?+X_hbc=wzFnq{-Wy&9)SYu|*zll}dUhs-a><)|%9# zwLHbcsLLL{xCr;l#Odljk~2vTHQT6A%_uqe zQkv7!(N)?|zAk7p!JC$|6Y}b${CIn*-0n{KN>)$1G^s5yr5*(JNaCSmRjv;&WU7Uh z&aD?MXtn9uhfc*m?a6G#s452O`kzd0EM>(%VS<0tMjd^+G+jcow6GO~x+NiPTT*4+ zgbjIBYukLGv)Y)00@H_>mKIVfqlBuS88BN#_B3_OJY@BW5#v&xL(`shl5AN5Qqxs` zG_|*MN0VL40_}3MwXeBKVjb5j--(jv*iRmplzRb8K@+x*RJH)Eyag+}wC#;u>Z3Qd!vDAU+#aQIhr{Qw z#~wReeug6=tktI;J9pkx^}5|R56$Ip_+p%q=pW7q>2CPqo7*DeY&avd91cf}YWa}) z=Dn-k$nOZs4DpQ*hPGt7B{5_E{OB;c8jhyY)8{v?U1{$9#;)WE=|s9kZtf1x=yJFl zjs~+FHp*Rgc^72(Dh!9i5hE`Ad2Jh&Rr5EGvdkq{_20Pq9*&1CTK!yWGR-FfhAUKu z*J13gWN%}lU47tu7^W_^YRTm=#@Q#Ip;i|adg&qGd>pQJb@?5>i1po8br>`zWR(|} z=Z%Le=5o)&7xnaXT#ts~iq-Ttd=U=w8WdyJ;dJ<7UC^VxPnwbUcGP)AZZZ$sxGncQ zd{Ga}`Wfviu7)M9{$X4`r~9XN%8x>|%BA%;pG5kn_N9hzO6s=`?coS**p~BYeOWL} z!?)jBbPq=zhi9Fk_V|vG>*ry(=C)i7$G9)u6B#dGq~bfGA&i| zlt5fIb^iCT=tsBwa599;)8Z93HR#(@^*6An6tPQkm}Z;R#ONejb+o zSis>vJl>>B8)bjCD=|~{w};2&|1c5ybi)5S8Tzl;s?0;!WRA;q(uc3y^9GJh2SEPGllHXq=!>4KmP z28_sJE(FQAeBw<(5%v|ej|{3YJIWv%R|+?j(~A;MApuM_qf5_-xj?$6 zu7ls88*v60RAWllAWPQ6IA-f(ch~ZfW<%65doxr-;|f(#jV}V|m#Cv^`50Makw`%@ zZp&dNAVjjWbthL7rWUiqnP6A5%VaLP^k{n!cV$AG1<}~N77JwVkIt;3`aayoot1bB zlw}ZkW*TJQNeXxsYw=!8OWJWc=Y#)YRF$eo#?&v0=6f{$YtDD5-$4eNGUY4kYE=ml zXp-@zt4Y6)kSW^rU1Tf>zlS^o<@XVXSS;UftsA0jBqm3T^sV<6s@wNip3@!St>8XDK2ls z9V3cnR4FK;aodm78&TWN^kTM~3C3;nZycq6E?%sPz745TkIOw$2#<%$A+qx)!U=g% zAabVj1g?<1%0z?TbkO<*KK{a76B#v-&Ai_p4pRK}qj zyQxlYF7OT+y;IeZBi;d!b%djs`xm@10Sqv-RnNJkOc^*I~Av2VSjd}t4b%d?Rr zbcPexh@|L=idf{5ht;&BtoX%w7}%t#TE+Il{qTVn;m7}JSNxOn?hrWViozM!{iBJ}}iMe9#KgO1pp54qoiP3oJN<611;@ft7b#Z!WUpgd=Y&8H&U{dm}BGk)`F z7aqU$Of^2U#>r%So=xJhS;x_2#7S!(9Y&Odb!-@uVe{ZEI^9UiirjTX6sOq6#B6WW zjS)69@fu6S;?0`71h**Ce6*Skb1e4-`@cAGT(?b0knTo_N8H_d4fT#Tok@8B*WG)_ z!=f8q9uD;g@{pNm_`qsK0q)`@mhJ<@Pk8P7-oDWx{J6zG=Gn^}<2r&A9Ewr6goiDe zifa^{zk0MJcVGl&{e)xlOy}|Wd^kJHMqN)wY2F!3o0Ma7Ej+<-g)H6GF~*r81sV+Z zX9?Zk=In!Ud3LGCmNU~Iyd&?Lc683^!c=5o6Uo?oUg8x$gt^D%R1%HNtM&rMFHue?9XEo9cD~eUpHQs_3G$s_y!n=^BV3b*`b%G`vq2X1cad}mXuXy^Q`(8lvYY~pavkVQg zD8~@7k8Tu>Wo+POhHMeoz1&kSY?S~o0^@b$-;Mu^`44(p@|~OE)bcK^(L?nex=77jn4W!4pmA{~?O+vFKAEsA1>zitMJ2m zv{F&5HnB|-bJM0KlcpJkQxVw^VZI1Lnz{HCBQ`e1^Lva)J;hgOt*!9jh|+u+cDhZZOay$}Bu^*G!|J`s<9RxM*oh;ZbSvjF8d zauwkw%(d>d7~|PTHwwqrmFY~r=^o=!676-v#G~;3&*$0Khu@K_FY*ZS(v8e<%+XQu ztEqP8*6O;rvBUTB0(r-IaZl-v3%=kduMSZ}cvqr7`ocJhKx>FAsQD6m<{~K~lly;9 zuGW3O&<(B;-01-mjX_N@9*L|+3~CXkn|wH0C_s_kqN6(XP>gcC9HiTM-Ai5< zc+r~=hdZ`iP||TNQK-dozzW`!!!inM%H7Z`N%4!}xcI#6nxW?r3S{kvT-^0m z5Q#A7>F70kzRt#7mxXlPT{LO;FjpcGLoD;o7jP-le{ZMbsAD2sv&9e*!`nH8l^cPr z7%vZ`oJ*kdlu9E+W-^TkBj@+x%W&2?`ttYUE?;%+CEC&;2)konODdh$LZTBz6Tin! z%}et$p0w|}Rqzt-EXz4gy1L(A$keU=jw3|Vi7gj}zJZU;nc#3k+yO1ZkkvQr) zGKrlSo`f71%R6iEJi$Xq-Pa|M$!6wpF#HEUIvZO7s!{eHMU0$Mf=GmMB?xuzPKrT2i^ z#0BN3A8~FT?ZqT^5RX`YXE&a$(cd|Ww+4V%%w|S35Bj@%@n!&s#nZI?-Tino0K{T) zb`Wo(_jeCta&{DxvzRkr_b6sFBigk6-Q$RJb3ft^rGL;l{cO2z_7D0Ir_;f1MCEvJ z7*PeqG?4oTG3VyNVZ0p*IE!aF_77rejf10jraL%`IcQ_*vxB3Ew#LCx%oz~V);Nf% zwhv+&E(b?3XTWj9bu;GXwSN$C9{^%8)%J1B8E_nP2E<&^4mfa8cW;BY(Q z3^?45xCR_t^qL}nBXkt4A_Y|19l>=0f##=XFx=!Z~rK!);NkeH;?-9=H~8hykWMx z8*h~D9>g1D2NCy8hY?+8hX?Ui%)`TYmhoXkufbu&UCv=d>;EXCg?ALu@;QoV5gbKS z)JOf!<4fMTj1le=@m85hDn_`YNv~6sBgEDF>)+^Z5z@>5NcnA4JahL;Mnzw;{O+yO zTh{^d6mUcp6dg{SeWagb|SH&~Ro}aV%1#Y@fQuLxzqHY@V3DQ!o@TP5X()A_= zQKK6;9p?<+1nRQ$QG9g0x1;F9ku$waP8y}F@j+Z!v^rZKbD^YSEZOBb?tZ78Fg4Po zwXR?3d6>@f)mAbr-soP+*28KtNpjd(pZSkZz0ah(HtC8+${Sqi4$u@#ud6Qt#Bk+# zlCJx%Xn@uRle~t~+E)i_Xo>EPBrvsHxU$(K zibbA{lA<^-M#HuDyY;ls^E|^$;eXasf=ZRDA(qzq{e`v(v}W>t z0TPV1W>!f@STq&U7?PAt-&B;vGAA9EZ^5cwrjxfVku<1xGT&qnhNztmXR`!~dhG|Z zLIlsB7t6ObXGoCNzgNR`^>8h%->^$r+glZ+NGc&xOTWO>j7Dnx`}CnEUPt5VI*U1K zud`*$aYp1K4mFUw8P3zS^Jay5LFCyhPVyusmk!maQ)7drJ=FLyGNq6(Bh3y)Zll}C zO*{&sYi~u`l3ja`9wt0lcMB0BHBFY^AF;$2i{U64@WZ*0dJ5)IGGEF^<}cHEG`+pS z+8%0s?6o~DVyd;Yh^N2P;tpm=q^`w@Q8An*3i|ZsGDZat*v} z(SKmpk5|u&0j}mJpL+D?pH=VrIT$KJ+_cG?oW;oVxkIN*-wbnS8((i(!N_&#!qp{WBR6J@e;uhN$}^XTPXXj>A7=BG5@& zQVg;jew9r^8aCHGZp~|-i^i&YgJaZ9tL{y+2g+;K-KcN5zLXWN8=&32iR+%1cCT^W zBf0K1?tYM>D*JKo!)shOQnb5N*NqGAUgNsa!`*9KH^#Vojq66ccdqfnr{mf&_}!cM z;Yx1ptLWX^_~A;f|KUn*?JPUprTXDYuK(dmuK(dmuK(dm?!za?+Buv$57pfdS8}@_ zzI3del%u;;KU~Ruc!eKsIexfK{cx4~;TrX$6e=zWtRD=x=_Eu9yzp_s>+wPRslf+2 zv&SXMIs&|0%u_VE=CDD359oB8}a zgfTQjK+MP1JIBiq%NT(gEp_39-Ua%|CQd%k-kZ#Z(~J2y{U}?O>Z7=j!DBjEevl2O z>inLLmyaJ<=k3=Is_YSu70!~YWciqlJI5NeoE4AB>sgAhoR6w6{m2;@BQme09I2`g zJJXF8CfK@h*xyY)cx6iGh!04|A8ydilKIDPMxKYSf5IY+T0h)M$GzTBPtbmm^&6@Ijb5O)GT)NQt+leP`=3vN0GSMy>xN${NWEE$Qe z{GguX@OL_EyTtXi_;oIxlRt*}m@Zh2)5&C(K5WTGQ*C3noT z)gl>xU7Tj)?w2F0N_TCBn7MR5{XEM?PyY!LvKfkVRQDg+?!jV~E~DJHU#qp8AIK2+hql?R{7+aa#J$4XAts%a!iP%WeU4sg zRPZ~ViPY2z5Bi6S^*Nn?Xnkc`ft|IVQE6e2*GSf^`5l6KTh{yzv9IlFevhjf?P`9H z+Xby^Ui;PZSOcu(>uK2x%Cwi|)2-L7d9vI}k!HGmYT@A5?UQ+$B$mnRa%(g!aFh72 ze>=s$*u&i>IEiVc9-1g245^)-X(Du&59b9fMcvqaR+{9xH`SyTvAuVB ziXZ3u4fu#{Q~~9fE}Z7=cm791>3mTBB^yF5)=cQj^p_zurb_a zcU|BRjG_*>x!sk!Ak(#pf=ZNjkwWh>3kIvj0^ZZ46OrL$KD$kL(0Ad*Ak#9qKQM2G ze=PIM?4{+Uq$VQWdEp7yNit{<6Io*q9B9@^TLIl?1JOdjY|E3r8iv+5{0UG=W}SsB zNp$P(x8Va3l`?Me} z*;SrMwwNwwNtbCXNpu@wY0-J4OA_7qm~~aKOrRqV%g$!c6VzOIWv z6%Db4>g>i^(N?$2MyeNANz*VD$i%SK#d;%$7?zc{a2{jJ`H0i%}VurWl%WX<`I)C-?v{ zLYi%#y{hYNO{!%?W(!)alMC0G3yP-i*=0X~*f*@O|iYS>nQ6GSv;u z<0h(`T0#wUcVqVy%V0MKx0HvP;*TRu9g|#)=~L2+GKEGN5>CKMiLG`^y0MgQNimkn zEh$D(xHRN1&Y~F>?DqK;&xn&c8ji;o6ND;uo;K2%^r^=|kMYRCIsLiq(=~M}J!iu) zq8RZ=<$TT}9FZgcDxJ4}z_5-_O%|E!A2xL&8%k2s+uTL(qn0O&88Q@f?q|(jo)qaH z2?tQdBTCfcQCnsme8`p%Y10vNDDtf+X*kEQ%fvM+O)$dpVo{8;!2A$9g@{Y4OEE&T zZITh%O?#L)yVcX-Je$+SFLnkYms`h)QqsG^1~VElT%_*K8l^gA&qf^4VaI!w76tA~ zU8YaT?2T6W%^h=EGiYx~94;et!_}(5TbSKD00zdXvu$%T*L6SQ z(%b7UKQ_=d^=0e98e>=p3qHwle`#1DM zSEpX-%Z%zIHOR)v; zC@mCS*mVNTmgu=if{HN)aLhX&-(^oY`0Cg+_KrvJvnx8C_cMY}gk8*oayG_jok6R6 z3pKF_t;9`>$@TEL>%us~0bqoIndJF}%<-5{@yc>%L!wHs>wqsQeoxZrV^>QDBSkczU?2XDgQxad5#aLaN$ z87`5@XVcp-+B%z>w2-H;({B<~5B4aTY1f(wRx~g8SVZtTi?M>v*aLhSp&vD&%e3e`u9%ompk2q8L5g#hMWh$4rBSw$&z%h+ zP>3<6C_?Yo;SaLN@<_29lk7X1S zE%qpM91U}1hKSI4icB0ifu|^XintPlBJmY(m0z&m{tRk;i0JB$ohXQPU7bOt^JbQ5 z#2Vu^u_(>!u0EM58Is(UrJMth5M;kZHt7iN7eS8(RmTBU5{fW71+iFmpQJWu_asnQ zw@W(n5fX^w`al$cT_|dw+dk*hn!n9&n2=q|cSA&rzs|B-YijX*RQE zqPBLNwS3{dC9$q9POF)FU1z$!$hxz;8?!feWA^6WcEo1xwadcXt~d8$_U7Jh%x1a)F=`fM-e4Cw5iFlDwMa|Z0koB{hWXTW~U8L%I72JFY20sAp$ zz<$gbupe^h&cleV$Ohrm^0uY-k?1=h&P*#cDhR}zr#_* zvg=BYpjKS6DWZ5?mlWUB{iX?WbaZT$ykHT->u%oFh_D-U$aUThTJ$#G59X^mCo$GJ zB|D}v_R`xtYmt|n=5@2dqG&!3DFsWXB)TrC?hRE;MQNiZf=n|VGTw+*n#8)c)1;;U z?$Vo^2Rewxbqr7tL`2_pm$anQRmhS|NBI`XXq6{h4=J9vU(FH<#+Pw}oAsAVZ&-}d z^lrHE-By?0<|DyJY17CTAFU1nFp`{j2oi~YMzdjooE!4=V8f#bmnbfPr$3VMO^ydk z^JSV8X4djfovr!C-H@k~@i?VCr^DG56fgofI%#0H5rG=wOaj@CN(*8Lr$V&Lv864Q z&zQTnn7c99!~qj7Nn|hQ&x_?-41$zlb@Pm2c0(1dc%mbU-_!B(F-B7_rZ|*NVl@_5 z0l(x)vib84w(LOe0(WAU^hQ=5qqWzV>+_An-5usOe#4?lC*I)rx)|ae$1Z_1Hg||8 z&q-o5LP$4m8ciCedV?Kbl0(VI=wLDlVyTr8!s(}3{>FNmmxm~e8n2U4m&wW^*L7=^ z9k+7Q_BX~MD8_Gfbc(SFMjkoQ2TtU1vvI1w&_LYK{U0P3yMH%4g9-7sADh1ok77dn z9mM8u!(*oqe}}R8+wk}`#NSbD{x&?(4e^J|f-!7BN*5JxYn(=P1a$Uz%B79y#91Ue zdeiN`#6^rVpJy^gx01IomX9K1Z-BUy7K67kIH$iGMJbyEqi9i+U=+2tvK=5Xq^L+< zXVR;(8PTPBNfplb>ukY?Y0Hj>hbB$z&_~03+{qR0rN<7H&3%L>&3U$n#vjw#{D7;% zRB1<|Jd24S362+DN=)c)U}0}1rbQ7iPYuLv}~T7 zMRAEm8(MHq;gSd*_`@9?SQGSY>}j^zG?1rkHR$sAKui$%k7r%GWpjI?3J)x2Tm?+Wz5&o2wALqYYiLL3$fHPJ{F|w3~zU zHZ+@q^ft7bL-dX#%kOwYXJ3%N4V`mAdK)^^g7h|Yjs)l(Y#M`X(L<7x4Ue%D8M+FO zeajd8)5(DM(%XDZ^^%LUw8|!5@E&cDBpc>cbyzGzqwxC1#wl(cqO>`?m`}1#J!BCY zJw=meI$x~txXkDgiSa@H`papz)l!PILiQg~=|0kpjwgvc$#R5lAP3ciUw`3zuidS1Ion+7 zcx7NZe=q8z?D-*`Bh^r}Dd@0|3Kko`Ea41ohx9m+#NUtmarOoIA~uW!tml40gio`@ zh7pzZ#M3$4s>{<~{vKuKJ8~Dq&y@5xbey$mz`F@wG~p}F;!OkN+VDR>sPm>VxNYcv zn-{}L981yZ;~arhCmY6RIh+@qLg(`=8$BU@eHOv@Ar&RgU6SGR0227ro22=su2Pp> zgDPd+iZFx73h$MMWGspuuJ>4NX7(c4piC>KLC*xWZ!m)B%6^Dt&(kVI)_er!;xB2M z;vkuBo^r|>FM?!8M;y=LadwTVaVkuN80&~27HdHhCEmuJ3(i3 zxRzzn>h5FZ5kh1(4N$1?6Tw-_Oo=s&rhJ?ownZ;WPnr~?Y}RdpQFw&Q`&#U*BPdQL zCiZ(#sJ)W$EEQ99f|10>JZfDRk4sH59-r|vJeg!_!HCA6ZgGq?h&U_>#^W*D^lF2p z2bnvNipE#8%{Or-h(+V=YBgJ?ktPPyB6B4+y|}H7Lv1qJ{4q;=xJ^b8&Xjr8h07G1 zl#O%Nx@-wrUni3yiLuAi+{HNdR_%>Q>nUE3K1J-(ru2+->9~r+M9MKr5Pb*;140bp9Qn*uB{fi<;YR4WAG5JbTf^qBOlivwPz!BsIs~ znvdQ}G^r?!cPMsmx-7@Mzz|tdK!e)iAY;s-2WmAhHu+9C7qJi{%2S1=9@*}}UWb-|eAmgaP?!D&{ z?Am`Wy(m2hSKW6qO*W5p71G;0NKSl@|CWnIciG$Ix=P-r7Devd>JFQ6{=UcmRU4QL z<|R&HSEJ=m|M#bPvfO%HE*HHdo7^Tt9Iby(myh4`beY^`|MgRv^-gDq1j&E;|B%Iu z{`$*w%OtBA0Fjj0$ zW=Q8HO9Qz2D;Lh{IR6=N@s|Oo$Jl!!(30Sy)-b&Gd%Zx>D%D@4i$oB1$;qa9s&iWV z@P=%B|Nfa?>FM!JyvdN>c2k0?U|(V>%!jkKAB@?%N7Bt$IK-D&LOpd%|48Z994)&( zLD3y5oUioo5acMCoi1O|bE4!_rQ#~t4xx&VDOI40n^0=VR#a&L%s0afSN~%;TP5{G z^S8w^+Ztjt;s2-U0xviJJQ9T?{?+3MHKS>sFHVZ*^*{RM^s4no)6sLaj+66~vkG65 z>CwXoXN|7pguRR$=h*c{u9Pe|~-(7LUDO@t+FL^LQWT#55_EHAwV~cW<2h zsF{RfNEMI6on~^t>hB-4!rR~JH{&g51!YB?{|q(Ae^gpY7$ZspJV_}x<5e+LA|wdx zxiNTpO0J-ghSTb(az4LJkSMcQcBC@EQ&OvbOJwr45s_JnYumqK2xXgp4$I;E zmF(f^MlwxCuRIy$-VU9>;ZZy$<4xF~q_4^NI>U-VlT}qKHIH}x z@<1VJb?ANg2L>2oNEdyFyHUwTBZy)N5a_wwsMk1MYR;X0hONvdk~2tb{`n^3Mw`+P zNGN--r;KTBTeI76NZm??;sq$e4beW1zn zCszV9$y?wK-tbE5YYRlp0GZ>h@C!VH0+THnum1%*K3Y`5?M9kls8KCWQ!FHc%YQaQLjj! zVGx`SM~}(R2HFOc5HX+4RwOT`wkd$<`UaEMopzR^oFlz{3# zkV*Z5;wZyG28_AQiWE0h}ASJQ@+g&KOX5rhv*Y3H00J z7Vm?|Wt@x$*(x6;KbOU#pzM(nlFz5j*zg@}F$;(T#9D*@_*Pfi;E;#jtBMJDc0CBg zQY=t8Z<5CI;*5Wl{Ljguo_@NPk@f`NE#I@S8XE;oWH+Qzq2U z6)>1B>GN{kXtD~0QU@kf!n4Jq=o1uT^&(tyjw~sA^}{Cf?X0euCe+_dV5m0GAojIG zq4?WjLcQ(yHcww`hKB_X@CXXbWPk&Jm2h|rsvowb9^P)hoE{wZ_k!!M?22E7%TWG; zF^a=Hn-toKJAz{a57SD`odDYH?fr>DxxKAaMPU4|9^>@-$)D)!*A|x>k$TD8yY;g{jHwD-9PU_2;_0a`9(;xh%;N>ERQn(E)Ii3 zU=8RYk*n1!RV7Lgus?>rw7OA1cu}K$R*8Iz)OU!>OUW|weDN?GqYq$>)wBALjo(P^ z(+qaEvzjkLI{*4*fYb?axNn5*uvBYGTL>Ny!q!xy;k@Rv!y~im&``2_(d|gosg8(ApgQlAXK^ah$X! z<3fWKF~3`@tyjr%xG4`e7{_Zfev_veB1+bm)D5z2K*>F)*gCE&<=ep>6ccg{to`L6 zS<-Y}zk}A-o;;Ah&7bDk%Y1DG<*q1dT>;@CbuBVv`$=+WBh zc|=z9zQAfx2B9fv10-rFCxikimY9YGzJcQ-RN>$a>BVP$%Nmr)iXxxw&$1SgNkko> zsGuQ^?D<*!B1ceJf1XTXzrj_6} z2&NR8!l1Vq=i|XF9VsP@$?6Uih5UfJZj;3f;XrVJOIC7OP^C@i1IAk8qiKScq@y*y zC}4@uSfedgyU*4Q>{av1os(r`?a%xt#kpGDAf`xfAYEp(f*_#u3D`V$G{BIZ1G&KD zgtNmbt;auD1D`xMHRya)GoSYETKR&@<1h>k`>Y2Ut`UOKyCYu;&LzqQlr`wTKAX_j zCC=6!cmdAk!1U>TnvA`$Gf|z!v2Xr9%confTcq}Kcn}fd|$$-+NQXY#kL1ykmtaM?zb^$&-(RwB@^r=n@k+a=*fX zgt#OTf7Bq8HTzRiURT;qi05gR=c~o?f>vVRvgDxiAcB9&k1C=t$8d!}6()!vN|JFh z_Tq9}8HcXPARVMOn__to4|_^mLPk4M2qYp)D3@`V))ocgHDl?}x<$Xg$DwyBNJvAt zRF6){gN7~;;iXn&hO@`h@B3d&H3v-4NH)I!l`{!V84(#>+R!VL=YM)@kyp-;nNzJq`m zI#@xlj(4&^4CfrAg$5{~$jx z+)_i@x6$6nyHDD@h8K#ndb>>K)8%6q{wu)@B2*piPS_Jn7H~4&w5S+HPdA z%^j>Bmcwb$$_x(kR|zQT#urVOB5LnyNz&epL!I7-JZ*-5LpJ{*!hU&UtPM}S9&{7U z4?#SB6DWglQ9hf5jqpZ{Vo8}76xn8y>ehC_8LoCxuxm%A>H^3*l9n%%Rc@+f-( z?_qW2D!San?PM$Az<(%@&ZYYQP%a_Q@^<{Y@>q>?gO`w^T0#mh&9+i(1k)Mawz*!- z_IwbhR+Z7H9>P-p4 z6F!=+^BIRRIE({99Dkjq#;H0PKfL-ncSkBQC9dK}!qQM^Dl*UhJcV!=+_-dcvGLrBl!ZC+Cs*YDt zlbg=6hv5u+VHovA~Z-#t3UHGP;vH04aE6OVBcfoigT{o9^gYU*wr|8UJuW% zi3gi=@@8Yyhp0HXsuQcj-#D}#uNLr=<0$#2NLJ%4ysx&2qua?dZ3GFGotW#LlY{F1X znmXdFIf1tY#3N#7dmEFSL!{(EGxuBBz?L1##3=mbWc0Mz$11L*+t(XcZ-$Gk!vZB= zy1u!V3sCuGaJ70~?6p+E^KAJDiPAuT|E6}17$@${;|4x0Nfw(0JtnvZh10{gGEqE5 zOTOWpqt^4yS_&%+L~81qjUhZ7e?dSK$7JTU4Q6ih8iRxQ#rf4@eRT@-^+2#Zqs#W%}!@nccW zl`%i+H%o_fs#>{(_1C{?9182v*N=G}SOdF9d3BH&xweLJHd={Sduq|hmxW>8Kulus zWN(S8u7lLI3!(6w4WbSQIf8Ioi(;1Quqf7JNCASiNEADXlmrcEP#V}oHXyCk<#j(E zpNP<4po`c)8gOu8idV|H>yH+tPGW>5nojT2^$P~4TQDfn0WPe?B&-h-T-NX7^Cii$sdcfPCnh%!Q zQ!>9_VsWiU?@cp4Dx=4|svWJN{aPsU^w)g5=Yz_eBR-H`x_v-CVc%x0=mU?F$q*4# zSHp#j#jPw^65}4Hq4y$kJN=P(CxXi15uzk?;b)v-9(bD=8irK<9S4VC($@q6dzYaJ zd7AJMC%5!|Dc;1bcEvP7`U$f6WDs*jD8dy6Q`$#X1O2lzrR_yXMj|bAl_M(m4>^L! zM9`kk3KsYF7g`m4yr#wfB)QkpOpE&moDM(z;s5M@0e=D~9QDDW5rb7qZ5h(ICD^ZS z6+EPCp{g#hc83IvtW4*Wrqgfc0(!%m+SjQ0>iH5edp^)2NuKUmg?OPWuj~D{gKZv5 z?B@OIoy`Rlez4)B=hM;hd2zq9y}$3R!N551>R*$_aTAT5J+J;ZXzc7aVf44XtAs(L zzum-Xf7`1{EgDU2>2Du2NUXno*obk|gt6P$+Py{^2Y8aEIw#E59yQi-)FiRp?Iu2U zcbfRv?KeqmcfXO3gGN3M@up6#Jofudqj109#K(SPTlVRtrFuSgn?~~fZqq2--))lm z{$5k>@9#CuhW*A-xZgOl_Z$0mf4^yb9PKp8o~UhE^UOH8kSrxS@vQ zCN*%p+t3w_O5pe~Fyd$j6fo%cD9)$z8E_AWau^u2d3onf9z!@i?}s>1dHW;5zas>v z`>1)*ao=*jY>gfEM|g>258RrxwO?-jimzqbo9xDqI3DRcb4T9q+O2BG-LuHn6!gKjT!3t@xK8DlgGJZvNvb+p6(VWmFwP+~dYA&eoep z2}?qMg=@2G)&s4dx2y#YnwRxuXnnPY2>H7WB&a%hjfTy!)ov%YmUEFiMf1J}C-6Qa z28~>TEjon*s~Y*9<0{+zbCxIftaggV4;Fbgf(xOoQd8(HMWfK$sHq~MCtmIaWeDZX zzcIIF5q9bKI1whlg>dCJwim*N{}s2t5Yy5;4CLC;PT>n=p+#gXP|32n59Ehgv(^xp z<7@@5#r?lm8S+v}fi*TwY6b1zJ`BWC~Dhu|5ihX3&&NllEiuTpV%U>#tgLo>Nb& z*(1KO49(U;w7yzHhGOo?V_;~978=iBQ`?68p*E^p%g0l@CbC}B1DvcO31JK%ytBBs ziM1R2wZ^wKjMkaa%FNWOMWY_eq3dapK#w#rUf@N5Hd|WBJyy4Q%T<(7O?$DC6{2l^ zAWrKVTgw$`;k2qnW8YIAfmWZ0VcKeeVusdP75IY|DqG=|fdTie2DkpM!E7@-nXJ53 zp0<+BGP`fTXfiXPe4pU2g+H{xT<#g4vU-u}VszZ<`N4mv+~VVQQp5I(lcP25zLePL zWf5a8H4ofYyS0)!h1S$W)|l;H&DYQYE6(3}FLG=)b+|;%hc8VZh&}5)ovh3KLfEb7 z!S$beb0a0T*p7%X-ALL(uAyxPCe;Z04}@|2M(>sU<$jux68#H51IO_s`Y#bDLO-`g z`DnM_JEa?q#p?Ou{QR6hkmdAS9M&7iBCV>4MtPTp(|I;a2ZM8*y&1?3s5i`~Si|Tt z0GvpE#7c!F4F(;VpFN_9r}}>gYRScE|mW3!A^Q8mWl&!{4PzQsq+@)_+%R zHGL>bzf$P1A#dH$vIonsAOqA5955R+LteO%&o?_Y4uVDYJUmYrgH z{-ps64-O#$tO;wJozgK!11*7t#`y8L+rl6*VR32XuYa>1M)`zPPlyjdcHR z(Tx?qUn&?c#2V2)%@%L!U->MqEWM^;+B}a@HQbLya+MR2RL_H zmNZm}ZUzdz!OWnH^T=l=2w#;C%McZk-^ub4FKl5riJxC^(VzZiG6NBoik~C!UDlQ4 z`Paz={#L@okMEE0D>0*Dz#tWx4*LTJDSu$9bOLm>gA)n}+0yMgKU6iv^P$aNiJ;RE zl*7Oalp{yM&Qh37IgMCVa;@?i7-cLj7LUTB5=t82AW;#ISA~aA#nIER*({;-+6J-| z1b2iZ2L*D4V3q3*QWeo9{GQZaWn+v|i!Iq(>SMFhRGAj2o>odAE`9Q!aM0)%A z(!~_-x``XdjL&rltn1{3i}=IxF9BpJ5__fm_}4NUGHS6L|ApGnd%!Hg6S(=BAa%F008I$#NoJ10H6oD%^o1%FtdH%h?T5D zY9;#L>q*+Hm(7EcL4(WRNQ84@|AhE|`|Z1hA&NZnftv&p zzx`(6|MpuQu1)*5?;%`V+ek;&V0dsQh4>x%enhW~QtbcEcFEm1`JAuP-{%K=ms$3- zGUm-V{qfywxA+|*PEeyE{Ido(#SLvz!Ez|Uw7zByD}QUX!UDC`2^T%#8T4hbdKi{8 zbdjY#bg891bSYB$c_`dH!sL6zL2U_}B}2R~^oKD!@fN~O_EKUzuV$$EH&Y6_C?p9W zIQZX#-9I04nx?WsDsV>tm(fjr8x7e2aQRe=o3KWvj^qO5oX3IacVvrozD8%--=g3W zn|DJPM1cC-#>1j@ZKy^<;-V`A+e|ZDu6^_1iv%2rA$$3qDJd#SX|1=~^czQwS`qO$lfWLH-%yBP{3_+BaU&rVVzYV1$!1|MhRT$Y$~hnd0RF;g%w9 zn%S=yDj5X)798FiKkE^}H7W)Vn&Yn>oNj|B(= z@Cwh*4Eb^x7v9iqFQ<&4pWn_^{$%m>!z#rfnG>wI%wFK>=kGZLQ-6ql?Z1pI_uC56r_ylB957ObXOmU1J zCDKA<>Myd_)!$e6!~R9jLR3p=Ut@k_{uZt&38uwFq88WLl3N2$n-o%Nm1!cy-2lE5 zs(+{(>UxSz+~w991g&N~QP? z^2l=HvI+ui#7|0qdcE1ERF=Ag42VsK-*$#?n`V-zll~+p4*h#d!Oqy21|g)ZgFxv~ zYJg)(+ZgJ#2e%mfpc%6C%M1y&_0@bq;8!>aUyxyi0ig2zI=m;8C>^4-W zT#Elt=2^`u7h2sTp9Z%Fy)JaedSkS9>1Pdb zIvVBGp0*23p=yXb2sFSL1y&jRujj0WjB;mqXh?N@m>|ypF~PnOqT$}w;5}`f7E^Y= z{vgL_w3%0reZ&7Z8YK&*o$!SLDd&e(E>54c9Lf*8EiS>sU`^sQNl=uJue(D?7h6L} zms&$emsW<5hB!kA<<%ji3*CXD0meWv%A5hAAyx61AkTm>!M*{Z;pTwQg`NSSUX8B^ z7sjVY;g{&Pcr|uaz8d5T7yyri?NX~58dQ6GX#&lS2T_iGi*EjCU%Z;J`FZQTlb86z~J}c5IW)hL|JNhPbV^p+@UnfFlJP zT$M%z?vY9b$0r>d$&%8%IK`Msr=NNhjY@M{4l3w$aeRwC;&7(SJd|D)K)xs-LVl8*l_E4bGKFD?~VaBuEzy~tc%!5)0| zi-yaq*tfrVX%DEpf_?YTJ1;hu8`zUEr}Dz&O-6V^SPm0in$E+eC-bqnrs;3;ml-*X z#KAM+1Y2MiysI7 z1MlG}o#bI{DA{x%-%M5=m<-wzOyj>_&TQ>w7U_n_LPKZC5>rXYB5S!Ct>oJQD`T*)37^ee7A+Ylar{sVqENNr~%LwEO2Gz44z+m-j}7x z59Aw@)t043N0o&tX)xG8$5+ZpHWfnh8*Y3B_%cLNU6&dadPxz$q?6NY-o3tU3*!u& zQo!YE;r}a|6Zke9U&lnSEVw{0Tpk@r!n^;wMMT=+D^uNS)6>{&gX~8{oa5rB#JhVk}CYaybn= zds<^-?1S1P*^6O}=KIq=Wo*BPp`v!U+>ZNGEMYd^kqJ!Na4Sqj8YgDk5`#fBKB^ zlnK*=s&c3?QptM_g58(^qPKPTBZG(GWj3GQLHs9jXFhx=&N$$foI1@9>MDKUXOw>TFJaow*$zehuUR^39AHc_+@tpv> zEV>ANyX6&d`91Ms%eX92ShHbKoM;6;qMx7bpQrZEbn-U9Pd;BX1ci!e@giF#m9(=?8tH0|untaX{C{5f(9-~e`TdU0_%e2_hk zHR=?}=3u!B8;O2n%TKvnsHOO+pV7g(#cu=!$}e!!UFby5M_TU#c9j-Hp9Te8JCfwC zv%zZgNM?jxf;cL>UV*61Juf^(1pbWAkBu5k&7QoDa3v1$omBf|_=6sTXMDrHgKGm- z6PtQ@nc(oAnj*NKCUXpt5p|M2=!1d5Z~Z9@HjK!j$Ta~BICe0O6-IWJJglbIa0W;%J2guTEg{Pd+p=82MFpBIZh#0RMzP-V(jSPZBM$jb(fRZzDJivP8NUrC zE2WY_t6Y;7u}PvLIsdOPm4|pkPU6T?aj{n;;ty-WvbAj#S`2{%Km$xjTsdSC3;MV? z*J>_ZoGh2PlqjL+6!c|CFJ0Va^!ZS&Z*WBJWq2A`;)@@up>S=QF#e%nu6djmv?ml~ z_)m>UVbf9u6e>+@!yFO(&)7ev^@{kZ77Fo8Z|}s#+EG_EfRLcHbUTf@e0X)Meb zctL0OI<(3uGo-5^l5g>oho@c&M429#@~3>l(5QdFA%uEmK+Z^LWm?6=)hLnxq9QN3 z?RIULLj^NK<#9#(DFQHTIu zymW>jJ%n$a(gFf|fw3vVl2!#=t>yO^MSrPMX^YCjg){-_2*}wZQPJ%!Q=~sJ@Q|9; z`Dut8o1-Gp!$$oQijjZep*hNfC;O9&u8q(oF3{b9UrQJfRCf|y@M&PA@h}SRg z$#Ez=e{Qkl#40A2Dw%4+vXC_Isr0KFQ)VITcd6yfQW6TeBcyB94^mB+Y*H1jC2oHB zZO-X~D$IUY4%`Cf5RFqA2z|545kH=Mh6h8)2U$8NH1pIkM`1HbKe2}t{jYwU>+J`c zsRr!@?!ht}T*mgbQWK=MVTLIp_(VJjM3*AS^%j7;#s5f>#mNkB1F33s!40$lZb3r9 z(2bgF=#SY@Ocs&4m^2Nxf77Kf_6xa;++oKrJ~9eq2b4HUr&}czEVUgdu~1UQQkxJ1 z4MqBdrCRJIK^jU9F#8Ju@P1~R=yy5<@EELjQ@~gF-l&L++mQ9WG9jv@6uOB*LVugYKWhdPL7T>1s=B%Ms+S7{4x(aXI!=o1gkf9m}rCbV13H-~O<8!4B{ z-9;E<@l|G41(soy!2H9&Q6zZkx4|o=;9?h)BN1ZPDZ+Eq z%ByJo3gZyNiu4(%(K7by-5u+9g`sR0UcZc!I|Y}ot#itNQ?A_PRYNHO4aU1N%qw4O z&sGJ(&dJZ&nAfHX6qi}iQ4|@4YhXyTWynd_{eoBO3T=s0NHF+UjEKl$BCI>ytir&c zTVKr`;dX)Xu~<;#Ff^GqamYl!zz`v^VJ;zD&l0$SdYepX6PqiY5TIz?I8gm#kQs@J zu9D?rHb(R7`6EAcpdtdfoo&>kz}1NvLSoCq!?8taw}Bh3PC5}iwBTZ`;aNg!S+;O& zePT4s#0s^`!V!+MFvrYOzbBoy4R|3TnKiQg*+56STK!mR)CM{Pbt#Nfwud}a+UNvB zsCZ=ItH@ENCL*;{3S7ax(cq$=4G2GJo3)RHCvkvNW$F$^IFFJS}jW6JXs#@*iy;aN`a%{|8K14&Y1VGwRP`si0b%G>7Rq97#L0ZD+(5bx zM!_@p!`T;pn%Lx#VUOwW0=-k+PJs{FvIL>zahy+s!#|n-_zLscwBqPE$+g%t+Ap@g z)#db&DS#xK2*J{}ifg~isxtOtNpy=G`6fd>g=~GJC3N8@9AY5G(E5%yU#D{Kr3h5? zrP!mnXzqxZAPX*QMT{2u*R05dm7&6_BPqmR?vMhTSUNKv!tKn)Z3F5b=_1&YsR4BP zf8>!qfYDClT?Wo57G0pN#cimo%O97|Gr#=FrO_7-4M>-+eGTV#5F?U8c$7{B+iRzX zv8t-1g3IdlVnSw**?ko}evU_~b8E8^z?6%0J?ez>17i*&!2aT_w*CpC^OL~{3Cu>1 zGQF#zUMftud(8?0Hl3p0+FD^eep#<#?-#aOuJD59!{Eu-52=TrJ5Ur-11%VNzhoyb z;#?p|tYDFUerpi=k47=R_!s#~6AirjA;E~EXY}!s-3+nLV9y(}NJZsB#lfAP&AAKB zi%~8?azs@z`Sb|iPM_(yjml^XRR9+W-YRQ@k7i;iYJ-{1f8Zg>v9pSEL+R>@Y@oU) zWi`)$SB){3LVzQKMhz$Ek5fES=v$Pz9_CW;5bO*KC%}z`!!|F%MAE9nExa1O8IMv9 z)pIUQBF3)t8J7Zsmuk6g@`$R(^!AuVi!g3rrFlk_g%_Cg7LJg8b^cjMH@+chVcZVx z#00Hx8+M{(X*E=*uug3Ap&T$us3OB*c|*k-(;Ux7HJ>V(C+nA-IXj9_mmQFw2`?WnZUaL1R&cXWnycR7&9 zr>+Z#wVn4n8Gk&dyuwXivFk-0I>7top5?iY>WGan5;;q< zy9+XC@rm0k#a_ufZXHa>wXQ;2^mUjxG9rIDTWfj6(dmk>iXE`Z40Z$GRIM}P8}G*1 zfW!UJt{Z^}Q9+_eBU2{^|5jbzVXdFLHd0{f+DJ8%(zMg->-As;D)(U4aDd$sjX-)- z3U45-sw&h)@R-hx$6h?J9uQ}iQ5BKS{X$yq7=`?bSB66wqYwDZzC5>f+&bzByoSKH2 z8nYFbK0PVu3-Oo-V)VqCV#;gZ*dGobaKa)_H}p~+U`kasq+}~!5SR%~j$}VpIFX?t zEOc3gh_+}$-})dpl~ohUH3YOKdhLi(+`Dy%k9>{B z(phU#vz^ClEB#gB)dqVi7_SgSKcdX(>~s*bytc+9CqKEiRgqF2C#UMta)kk4hmS^i z>>xHg8H+=t>aic4yI2UM^edHE82;6o-j)8;TjFr9`ZWb5uyMqnqB-0>{;kP`Hrb5F z$pO)!J`e4b4}ECH)QZwP4y~N}vT#fcZ_{OT>dg=dbg;9n<^2(|L#%R|%*GTXQ_Grx z%NxUbWOP$o1S_qJHDjs4l8SMY+d{!DJqlUW#zz~=%l}Q#{_>-@vXjK8zxMTPXqX$~ z)z8m)GJGoE7j^9&fyASu3CXJm#rKeFW!wvhd(ciZPC&flO@RD!Ou$%F#7e-}Gq9Q( z#H2J5LW}4`tJ;pXnkz?s1l$w}1a$FyvrxPO$fa4QbcKJH;bIBBT4CKq^UKwXwGPFA zmU8JzUE&=^F768*H8-?JUa~M;I0-VVeV z9_7JotH(qTWJa0WW-VIIllcTUOW6rne4VpfK;3V()V#?|_%n|+Q~6L-Rx7d*;!C{_ zB9oX{&}->5(tz_wC=DnwX@3rK{Yq zfy9G4i>7F5(?nV8|S&)yChjWXTyAj+~?v~kNAhY=LErNQ%yVwmg z#eckDHk!?so$YOmW4_nfMl13+q{7>-A^btJE-%qeiZ_uzJE*T5+y*(6*lV%eP8e8y z18tKb$_Q%rXud%FGHt6U*@1{{cEXoUAO%1Rdp%6N8sSXTk*nb84I91hWSYZ^!T(mr z9h+aKA!_=@?lP&Zq=Di$OC^cA4}b^i;iGW+7| zwtfNRTdYbI!aVS*(~HMTtqX=fq&XIh2QV=BPyZNXkZ|HR*GF~^BKn#U@!Z4;5hRbn zCQF3kF`ZOTsF^27TJ~6TbpyHHV65Vl%P(XD$Ba*JL`LK{C-Y*C8?g%>Oy4na=svYh zJ7uXUZl1x8*O%x+BHh%;0i|<>uY7>%u@0_BK?)XRxMzz_keICoh`HR?k*;$FDi@#m z=#eRC1uxU|Dkw#AT;E(P)g;1l+lRLzo^=~bgc-_XXH2whAD%XBuQpcPkH zTc5g3v4GgeBSWZXQ)*+moAoNx;mDM26}jplv~Z@GzF~{Cz}^&Ch-vXT=ZA(3->HKj zj-l-1a|h)%Srs)1$V{XCy4=4f6Rfg4f~*;9QLTKW_Ok8;6X&b^sezjuBe<4^La1&h ztg37@TbqOtE!#bewj1nztJ=Lrw3{S(`hsKEh5=Jjt)-}pfiRNqG|Osc!Fecd6WjxD znlyZLnvwU94e?;54qijQv68PH02-sFQ(ut2kgmj&S3JNNX*91fi9j39@gwa;86@dy zV{DVz@G{k%?ag(SR{4dnBTT+Z*e%AtyRMc{X4?NDgX$Si9}oQbG~sZZdXwp zL!b$2d_yCWMi-Hge(qjqfS4e$4Xqy*u(#xDsmE4TwMTfzfRHm9jMNSsLt~+u7bs%qxpOkC(0PQZ{TYo9Q+i&c>Uee0M2C^} zNQwqgpJnDjH4yj{%88@q&Va7H=OMvyzq*gZNLtm-wT%{bhtNC`O_iIp^5`R*WAEfl zeEw$2S-I!{$|8t#$q!_=nHg5fvh7lSWg%y`6YQ3S#=2D&8mp8p^db82jHOF|%lYt} znmLD^Q^qOzoH9=Du6q+ zc{U+S;Txq9MtAfKP?|f*(J-)Ra9?N3inf#>8i=J8Rnh`DFp2?@W3Lh+K%hz*2^7-H zbfg#YV2M?OOj1uNxvlbRylzC9#GFEy9?lIy&>lP?fAmbG^%|LBQGk7$i);IdI(W1Q z;!)E}Bq6=6#0cU`o-`~M=QIy6@dASw4aB;b!zF11p_V_Ss3^jZF5@=saV1QTw`gj+~oF4{g&joR&9y|YoNa}+!({CyZZC@xhvO+^* zROh82Ia-i3B)3!WmVPuQ(Y%oK^ zovsn6Fed9V0rW^VA0Vf$G1^AL2E!#fBz(h+sHpf6t1JrY8XypCi3iKf#v?!!@pX0& zjPjY0{%R@GtXgPH?O!mBF@b_kS?xorA4Tfx6}dVBe$EYn$5JVg}y!@YHv zIipU0Wuiz_gOGUaM5pI7v`E5>%-r=Hpjh4isVp&ol{pp9(!$BT2(VmK>~Vo|Xdrs< z6b9k1eHw-qhctI+D|h~io-5)F|}h?v+fIxK^UTve>X@jY2;QQG;HqreAs2d%=9&VX~W zMP0K&;gF}R%-~|YQ!WKb=ba=q8_o3qFg0-=jfKrmr3CxGrW^{tWI5jZgTM{#&$Q77 z3Mj3trV7YMZ&eMaz}P9!Bi4Mq&5!w7zYI#Smpdx~L4bmpeV~$3fH}9R)K`oA;v;oG-g^gyJIK8I>lcQF;bjC{>Qwn9#0+&b z3--VdusJU?Gh+}}Zyo{HsE#U{myzN4_Z8k^;dZN$=ddzFVoFY|VQ=Y}8Ej*v;plus zyH$kQx^|lQ$aYNjuxG^Kr-uL=k>VD6k6o5+aJ&cwYvaUB{>Ksu-^}xJfs~N{_|2goNE6BAaa2%;FKm0Lw6;2&Wya{b~w|Le+|!9ifiCvcr^nmD&)!v;#ddqdPgmykS@ zZ$jnlZZ|L3m!GhFaPih}q)qKxw_Y_lRhvQbW%qaibQD%ujL0H!S%_-f?P`avt2H8;Gn^YB13p+9Z3eH)=%*gi6G_ z=Z-W}@o*4tlDU>DT&w{&ap9@vH$w38+Y*79E5m2aBE+RDHbP0cxGGJ-c+gaVA)|rb z6#a(RF2&1g#>y~HUiP-PrT%xCVZppM1TgekPh-y|ka?Cm-(BQTo*5R0_k-$H=P)jg z;%XkVF}|~JIR~}TVmPL>b*}Vb_Hks1?E!K`;zz2?4o1^{ARi44^nYu3IecFmVE^}G znu~p(kAMmHQ_vfG-{%?__}1Lgd%rgk0yN5fxR*i+_J42hzI`NY3_lfX1MMSXA^2&~ z#C5{AdC>A8G55tj`X<~@zOt+Jk*Oe6X}LGny-OAB3vs_r3?QefT)rhmJGTK2ocT%J zHaK4G(`H+6emd3@H z00wof4@6JLG<^M?VpgR}^^)+$w2DS5FM!%k(30z30;s_xBg3ik2RYKdBM??_q)jge z?S(w}M#HQnfq}kZ!2nvkJY$(*v^3z}M%W-^ETuMEqBRpV60Q+h>}DBTGuNzgAdNRWRU$Ef^!*Tyezl=OIJ*&)pI#TZVkp79Z0 z%cKY~`@vRWD8k&;p&0B~Ge5&N!Z|=p3sq*W5i<&Ks)k`8ZNrpal5{15ODSb7;)aTQ z{D;!X(u&uEISOl91@4sJtMcz0_igX80lR}DUeIDgbHO}9Bp6LE#J-A84U$>4+veu` z8u(#0e_p*yrBs7+49TzH>Y&3~`2|C=+WP1re4FGOhxM zwz?|@McH17myE@*z-=_Iv{kt)GL#1;4Jl8P;_Bk+-0mGR7b=@4qtIPeDj>5D2#BF3 z2D4$kQ@QHrQXsgrpXA6amF3@VFU{iT>_@^rANwR-JnpAn?G_?}>A+Gre;v(MmM2M`DML(hx@;u)0%k8)yXm8&? zu8#WwI=g;3ADhWljQ%~|4bb29_xtgIf4m(Zc)5A5Z<|)zz{%iQte)8rENttlSS=P%={S;tw9ja zbKftF>t6O-X0$DI4ltIq;UQa}#7UPygm}D%DXV$}N2yon8>xx3*u#_)Y;$BgO!;{TuvPLn~j4O9>@AFT8R5I-k9{yCO<)K?B&> zHnQnYj1TWLCn4)e37ak;sYT;jil3DL;Wf1E+L&u>i3K$=o|+3#!f`OK#F0 z@8e$O2|ISn##J6s0b_ZX(&e_tX$yxMNsi~UF-!PLptv+?KHY8K6m0Q+arE6;`tHFD~dCA;P=vsr#m57!84;Ku^Er7(6@{ER(Yon{ZGu#`!DezjYt9M1z&|jQO3;$fkURi@(qpI<$d_Qy$^w906!EiVI*U!kC@-lM?w7S~c({~s%#z-$e9kpqbhqG`p}|UyO2byXj7=x)MZt zEaj2fbGm}&02i%tTAwOo+$y$ha2sTp+!DYSo&p3_a3uCd0SvgJG1r*JSUY|NWd_|) z42r=y7b0C;{^k}+m*}_Kiz=kZWs5a*(3{i?dmzxtp(8EmqD8~|&EG((=FSd$PxvD+ruT3shRvO-pxT7ef#gqkBtE4M|w$KiY|i9HS&fT#8lc{ZH!0Yz4j zg@tRJY9V(EU>F-k97gEkk);bjz) zQa8V&-wq41sKNqHHY^riXd_qB!WDRk<)Sz<8zc%%Hn2oISrd|(qfV@r4&E^KX0s{) zL8_>WS1`eVQJ}hjim*3ZT0E77;EeawT)kB++f=HL8Iqt;Z-_ytE zjAeZai3&-fCAh?m3-18qZ#i@2FP!w6z?&q;qpfUM5H{|96W$lJiiBDUT9=ek#+sDi zU>)c*ho~dXzlDGhV@Q@_XF6fw9SAJ30b^inD0}1Pr)V%&fkiq&)3{dIUMKV|a zsxk_}r?T6GPWtFC>JsrUj)!^Z50>y;$s*jtq`#0}B2jE7^d5+a!vzH2e1V23aIKOM zCt!{0BC70Q5nWK;?A;+OZsg|RMUE1^nF}-hH*(2z(AV;sbL3DT)FYKI#ho1 zG`)cu@_xhCiI4fpbShaFJ4Y`$^uD;dQ6>3>9_QQXABCr!fl)v8O2ohvED^#}(ZH#j zk|tXH)GRRrQ?x_~O;raYG-VyM@YJm!2F9uv?~8vbm$ZEwl<@g_R0Hn{^7X>QoAW>of}BbqWRGhKZ>$8q^8!nuOb^Oo&FUE)fXL z95-kZkf~E705|Copwy}ng4b&iU^FNZU^MBF-F|}(VT2Ysgz)Ng2*De42%|LW5P{V~ zhY(_&4k3804$%m;Iz(eN=nw<1ZkRi0bvlGln{^0d1$78R8+8a_)#wlg*XR&}*XR%e z*U!ijqh5y)UXyT}bO_U^(;*U}nd5pLLS$-m2!R`P2%*&J5Qf+45W=X}A%xMSL-ra} z2*F!u5TMm55P%!>2Vpd-4@PRCJ%CrIJOHlM9SUBnIuufa<|xtX#ulAiO#~LGT7e!6=QILSVH}6@*x)D+pezEHpx+ zfS62!y3o|>$G(GBr!WY$Sz|C(P-QT*QD+cVjnZInjn*J|joKh^{ZuS5nuS-VIfzb^ z>X0~LEh`b4Ij+|pM5ac45V%2q5K5f_VR)?uA&hzzLKsatq{*X7@D>^bXmtt%;0FCc z7>(+Kky>aE;MFM)fNOP!g4e1Jh18%qO0>GMZDZBx4PZ8_4MGZP4FWbQ4ItI%41(6E z41jAi2B7uRPb1Xp3!pWKv`JeKg*rn+z#EyZR}~;qqbUGwP!zzZ(-Q=)RTDs{*AhVR zD2bGg$LR@l|3Rk<_Nxd7%h3=Hw5lLn1fPDW;P};pgXU-l2kI&ZAK29mKAfs*@MAf{ zIE>^d1_#lr7hD`uEx0hBR&a1^rQiZ>o!~%imEZs?lgtaRC>=4-e!=XH5?wwEB^JU5{J z8LknWxvk6HS#1N{`D{b0GueeZL(d0xX0Jx^&f5}d&e*clH&->(o~326JwJ81Ju`K2 zWvn}p%52o|kT5(mu>8iEdnO>vNoBt2&+M6|i>q@?gPhq_mb>#xLn<>$Lp*aSr^Gka z4ZAA#&m#$SW|1td&LIWx%^(f)&mRePW{)g&=Z;zI&Kwg~oi{er87NhtGiM}%cg84~ zIbT$nZ?;I7Jy%qrJyT?w?@#>%yxOw~FD6VLyU1 zfej?@BsSsZL^jKPli7gV6WRpWliGmT6Wah(CRYVkncxOSSU{eMZhq%Xb{ka3Q)SW{ zpV|}O08}Tx0dy3A32~Kx0jnqi1Lm8F%X~HBhg_@cV`0JqbJ0L?C!+!K%tjOHosJel zU_Kf+?u0Zzl^N;6DpS%$@XX07iaX}~7&5@V45l)r%$$mG?ap3A-(w)dQtd_CrR5m_#=CT3tOlAY>&Sn!- zna&2VI-d<-WkSn|<~pY6QifjP&yr+u{_hnoWT-(%W9@5c0$d=`OpZ$f8crTZm*f>5 zUZ(_yiU$22(6X*eaB;}|`=q3IW0@9kqLB(3PWgRdMXxMHHkqeYSrM5H2D5yNfNuBZ zx-wDpnVy?f)MOF8Anugm9tGuDGDnb+nqzDM+j2Wma1cP!<>+Gp2F@2xYbaPtlA%_Gk!%5NY zK&cu^K_R!(n2bKMQ8j|Q6kgj*B>0{Srzd!(k;Bi0p!njtJnMy#0>gA78lSg6eK*=E0-I@@RV88vZBh%! z7#ac3ORW}YaHhCgNXe2%?EE3!V8;P6MyUIwjojj`p#yqwETL{T&NIC4>VA&QV8&?S3MhiY=MstyC(RR1@0Uoyl@x@Da+2`(Mt>5 zMIh29br-=;4JbkgH=%umQ8u8*7VUAzD#URo(QeR|V+>dhoemmv8FU5RI z(!|*;fWri5&hR%!tZV!rd!Oal6=SfyK|oK=H>2U=#Ij~c|HApne7-M5l3NDf=X1ZlJf8U;_oHQ|V}(*)ubfF^M5o_t4xB;3sm3q4|xJU>|BsU{1K z=__-XE$QU}+M>WprC6R$%h4UZ;5s8$a^E6~hT_$;)HRUP0`GFPr^N{1O{kF)p%qDk zmY6F9tf8P^J4+Rb%wh#>Te$+>DpB?~xRvIUkl#7}#E zfL%^%$q2o{`hY04cx^7Wa>R`gDudQK-}({mSK%C-P2Nb3z#O!|8;n{?x>-NGX%-7? zF2Uvu(LaP`l`q5^dqCc^1_L(>F3TVi4DNY3V7jF$ju`NYq}P$jVU zkKLkxJLnyXRe6^&y*U$@F|rfNzpOZxv9HatlI^yvHjO?8EUQB0n$Vw5a(*5pIeU;6 zF^C;KId@|}l;_Va9)=1Z>o8)xMId_~E`-If;`gCh`J{cMBRZ4ks|5lp;Sd zc1Wy7Yl>hTWKt9F&#I`gawJ6)`h@p^@`kzMriHz7u_BGNS*bt}HnN&|z@8Uh!J(D= zfc9&%+b~U2;X?YBRtabv8`-7vA^~e#F%PpoaZlJ0ALHt>3#^heR{9kl>TT36G5B+f zaN9fZG#z%JF|fm;kuv9aey(B^r#MbSgJOj!V&f0%iqG_QB?FgHHJ=wNM08qnhc}tv z^v!CdkRJP?4I)srrADy8a?M(`o&BPCxS^+bc4dKm*vCiM7y~#IkpG?{FjTXjnk2Z? zX|D^D`*4VD^<^5j;kPTy1T<#Hdz1;GBBIvbt7?iV87m#8Z3@J}dslzXOUEl?1xj6_)IEEK3WA-vaYuLrg#-W=V zvtKJ_ArnJC6DSwTR?mxq1&}p79OivBAKMc_;;-lpwyd)q-WCfE_o`>)6wsv1l_E~w&C5mk z^eiC7wo^4AN;-dP0O@om2U?k1d0SaqIa?W9`8L`er4GtvXfhm-=Q!yJ=T(_%d!lLS_n?&pCz6hrdGR^FSf<389er%uvXDiYR10R}?azGzyu| z9*NvlO+K7$Yue7P*2CLfdbX)7ceNfL9=GPXtMxj&TCcOK_3(1oj?(UGJ-jW}p0c~E zh4A`VTgrZW`@A~Zg=?=PJ?ht%-77pB*p6%GNe}b2rK3mn+Hvh=aW@-w_a7hbD9erk zcf4a@9PjABV>|@cS_i%*X(=b)ib&kH(b*g}{K_v1EReoiWMHc63+b z4D|*_91Y+?0!OQ@Z!|o*6=-j9dN9QUPyD)80RHV~Ny|sgk#&aoZMK>68!zA?3LvS< zF9?F&f(zNVpm9yIa{Vj_N(wmb_Ehjc=jhX^;0k%=N}bc-+5^|S6~-I?5v(U8+T5&h zAWnZt6yZqssX3+d-d!oN z#NjxvQEMtJ23j$Pv6OBPhZ)cCIv(xh1aF7o>#hdW>8%YgUxPKExJE!6e944*Rt!=#9!AsnT%nC5gA=2KjOIgiDhHCUqAfPi;y2y*Q zO9*Vq>XL8y1QMnvIJ%-5B5SIbN*b`YC`~JJvaasURFEYW*J)YcC^(-O3juD{P9Q(R zI6^gzz;VY^5LY-RPL-4dB(z&_L&Ve06Im5^>;k5(tO1WV-^}7L-Y!kvpf1B~Ec^C? zeTcI|%u5agwT2qEjuCAC<^`VEX;juDXk<5$cv$00$!8RKPW3~LQB@%{cf!=j8iT3= z)#75!m(TvTJl2FR>S!)nON7LY*L3QulfBvAK0o+^c<5wu zrBSSt@WIXV1KQv3!qYOb3y%|NX19w*3(|W$*ZLFmsc03gM_`fy12MbpH)fEtb{^*sBjH|=g;V^RZ<;W5t-1)(=j?#w}}>v=`p3$ zk4bHfBnfoI_b9%>VE7*SMp`mf06i%tNpMJDR&YXH(@>5aa78S;LS+eD>X94+yB_!f z;6+!-Dgv{7!AYZ1W9c!=UwLBEJ+e}7s+ERZPuHlMdx$6RO#?^w+rD9k@9@4Ky{$<{ z)izX8i}5!6a4Io)v1LPVJOsY(TT)jfRi~oM)mYT&5TaU7+049FSOo4Xsjq=`i$4mGuape$=x)xh>C5V>#Kp5_pl zt)n{X#ZKs3#Kp2j6uSEKxs6+f9;jHLA>sS5nkQ7i?lUY*NVD8_p7B{8WN7{BCN zVSsXr*}x#CkqubmTv)aZ@6*}9Iwm8n9uU#jo+!zFT(&aNbxy?I3yKpUO`@FBSx0i( zRI^mgO|_VfYFt4JrRJs>L$w!;5dbMCK%gqodp$WJzi5-%5rhshf$NJexqykbBPffd zTB)u8ZPbLSUDIx+#Tu_dM>`H0SAYvnUL+A4$IiH^_gea$aE7@|h zoz2I%g5}5CQo8vau9DZYat#%q4Z%If5#CRMl0_y5IYhJsQK?)4K++ubGDaStX*8Ro z9(_v+(!$XILTR88cleSHs6z=opk<~y`rdK>6;7sA5{B(e^{V@-cX-^$D}Z;UrPFMg zTjzKeb@%Y)t2Dj1$PC(!G_+9(9ki<|D|?6t9pIU0TX29Xa5Rbe)$y z-3$cSN&ouQVP7{y=Ox2-rRwW~;Wf8i)JL7ep00j}K|9kN_qzRFp3jko?no&Xb?Vh_ zXD98eBi&rx4j{Wybo>2YFVDjRcckmRe65>|0K4c9U-!B%b))qhY)7j8q3%h1@1pMX zI>);D@L>RGSDNn8@vE1w^LzqyM@peaQNKWk$~ zZQUpyx!%!5NlG`VPUiQ;L;b#(i?d@Wlc(gRaI#L<3IV2$)Fd#kpXWjJ4kat%k=Rf> zhn&!W9v(fyGdSC&I}_#%LpMfa-d@YfaV-+6rHC1U=n7w)oWQ8b=jGk9x?i>x{Bs>$ z7qf!%+rnO#X%t-|jlw%yu**|10w>k4MU8Ftx;U5I&gu`9Q8sH9O)B2*lQ)Cp@L7)! znnn^$-+7V%8%`=3c^0`xwas<6sUg0eQ0TW9dszm$TLMxI;RsBdb-`y69%YRaI^_{? z%}gW&uIo4|{*tQd0eRG^G&-`@|`Du!JojIKS477F0JIhUSc!F zX31fok|YomBo_u^aIv5moVRr$p~pBc(i|3i{+(cCpF7-CLyV$o1UWn*i}O%`fE>@h zEQ$#|beUsnoQ?@7d~JBP2e6SBO<2LAWxbHWWl2B71cX*sZ7med8>aUJ#DV z7b|sSFv4n%RlCsN{cjus9LL6y>=;S)T9WYd@7>k_trX{71=8a z2D5RsnMws|JS+LtWO~Cl33JS{**G(^7*|>~^51zu9F@2%q&u2){x#m--a2Pm-#rAt zv35FHp^KSZgCZCX7g8r-7SA7q)Q$~Y%A7fHKtDo>FTY!{U* zdjr>!lFx+992t`h0h}hqDkOXoYYqGm!gpLzR7^i6S}9cdzKG#aCCOZ_MsvuwbjV)* zsgF(Zt?hv@`g9*8`> zB}IN@c-uTO1W0pf92wri|C9uJtROW6EWA3`?oD(*90*Dm>1h_< zzENNTkkZYGh5&LP6Kqk9w{w=MsbvYi+zMGm0L)`HuS%r{u%1lQnLVh|l1d-$Dp4kw zV1g}kG9~&b-8~vgrkd4LJ`@)V5XjVejc>@|MNuco4p3SbZfEOyGaz-wZ^>W@h)Y3{ z3-GBe5}ab8X>q{Tb&%xF$|%kA3@(SyV)JQmQlAeJ+iLv|2gsKaFe=3*(QUP+?`b(- ziK7e!6!k%I->VR=BTL+(NEueV-i7m#M2Z;Fvh&oZBH1!H0 zcZ8OCdp{n`(vY7d!8*ZE!vWHO*Q7K=CL=4P3O>ci^}7mXMO2 zLy|e57$qT%1Gg}gNYR}-t!PAz&?&G+oxrD17z~1Xj=5GY-(|xqA}(>(w%W|oU9hz3 zjH7{os|P(4C!@D(>~sVTe}9qysFs;PoQ&9@_6-Rosm^=2Ga3~v$a@HrT#5{VrOk^( z$v&a(5~TF`7Mn@~)aaT(>ktQNI8H`6O7%d7OiGtacU4sz-Zy7uAUHhG;WC+*PGHPJ zHt>z&T$gKHITvILp5-bqChr`dbO=`)8o4K5irHMPnuPn>)+Lu@I5uDd2-#CtB^^@A zM53roq)v*}gPI+w#kJ{Vgl};t>c1QHWGdgwvbT7{DGG7De%LkCfOf@%K#|puCH>3` zWjppB%eY??WwPI}27{}UR}z6qA@wcnx9A}FXHjUm8^ZoeV3ZV|jNIBI@Y!+~*1tMy zQ)S9987liHJ1O%rkH_#aWRGcfi$x0bH8%Ob7 zF2(k5Qqd=DwDNtnOEHV-M|4B8eRBCk? zFsT;B*KEXO2P_kO%jJPTowbO_5$7V*!*b}t5T+28Qxo@{_YMx!i4V?Bf*qTv+2YrjpgYu`_2wO{9#C% z!)mKYA8?6H9t8y8n2o+Q$cUZq+c?}*JOU@ZD3vPEkaXOG#7>M=Ev6MVwxIxTw$VPP zk+HyKJrPpF>NwNN1ja1SpyY=Y8hLs6hf}DLNdYHrWaqZnrUL+4QpCQB1B=p<8d)+# zoFLAYBRZOZFq1wESR^U_n(q(((z`+ika@tuZy^(5peOtu0*FJW z_)$kgGUY`Yu6Qxv@6qE7QT0EVbuYCnczw=#bi(t}K?oRpjlI#yG(>=46R z-gsNfX}2w4aZ+* zLM>g$?Js>aata{X*?}&JoS3we(TT}HG%&TFZH6R4M3E>9@p-4OTVqILKX&O`FRBX| zaEtWwNuv@p&V=Yj0tT3LN(f*mxcJFQ@k^i~ov#YRvsA`2M(6OOK6le`27c;?Zea9+=-^Yr@p7v9O!g77WkAg%t>$^3M z3=|InGGo0?9fi-qWn{-0WgHt3uyod0qjZS?j=ycs5!N{rvpruDnOGp zU`%{u(8=-dlfnR0%x4djV>N;dx@P&T(hYGZFI_HBM5Q4H=jc$EzajFgdtm81NZF$S17GJShbe50P^$Pz|x&+ejf55J^`; zogK&AwjxK!I)yY6hCQ~fDmL!7a7Rlem1i6as1=kkI3)tW)UFt21T%fT6(KTbG>BAR z_)|0)f6LZkfMl>;%5I@+3J#MI3&xNb8sB#k135H)2H?>65rzP>@`_TO8!d5(0~acs zl1XD1f~Nh}62T?lI-JVlzTc7oj=Xa5bOA1^=P_r{ImDvmp>$pm(&TwaT$3N0T(%`u z$Yxq?E8&a6Kw1sN_M?evG8_A*pb)8f71W6I%m~(OhzcP<^VDl_PP-+ae7np`e}6)X z6s_=r!9CyLNWdHR;gOJYuNX*}_QAt3tln+`kln~fh-#U8IfC+|TsqvXvoUvXeP@aY z(h*gfTOOe54P{(joPz}OO>DGCYx3vgVp0;+HwQP|yH!O|`NK2y{rbjDH`aCNvPxu2V3{HlzfjP)GRl5YFax%f3moA~V8S-^GGDShXQjAq@m$3ghZ4$#nYgi9vYX zCN&O2=ILyJzo80fE}_&KsyAhv@?P$`>9|@P>AFwR76fqT*Tb|(OQ5E$VFmzOOJ$t7 z;@f$C1S6F#v-et!GW-}ukck>MQskrv6ESr-f%_c^&%{H9O=5y=ljO|>1Ee~T0%&B$ zWCC&Jx-c6gSR1vYFc~iUX!xlk)T`L4^2_U25gfwW@t4`CTz$eDD71NTG5p# zcXyJ83_G>_1Q>I%EZdO?A}h)T-Z%VsWEjSjn>$4r-(-Yr!l~0{bAS?0#qleb1~8on zYnqq>lx8WL58qaGy{OZyvPnU_#Qhs*pY19cMzNDLqwHpfRwHPU(x{z4THXMXHe&RF zs2bU@1~98_HMtIcAm`EuYPE&AD}r$28b0?$X`)&-9(?!5gLaIiQD_aA5&9w$0Cf?` zXQfx#T$y38&B~%Ez@$T*aPe1k$Bu2vU}`Y|x#vhJ%7=bk+(Uk5=S=`+eHI}b5jBQ% zsKgx~xbhR(5r7&&IEPV+ul&pOF*ABMy@DS0146R z@BPx$3II)$4#pv2gh{VpF2R|=^q%!(Iwumaw>`l=$_XfFodrUkLY;XEpZ%6Wh}{}a zZV=MivdQ-cu{xfI2PTEV1s^kp9-D#Wwq=;7khiO?pMmM@j}eWX9-!6y3y1hcTZqbH zw5&I2t%mi#v~G0H07-tYOR~p^d)dTCTQlR5b~#S+e7$)IKdMB`pF&%8csUfd%k1t9 z6J~(-N7K$^d(Ay<~u)*ZLHnJnQPM6&)69M{OtVt1)O)J1T z%$T};)4@*oOKGVL;S26qX$HZVHvxESgAG}+rLg3FEp{6o4^=n#4kHFq0GLz+%xl6K zPO6AXL)5Wa-asxTArye*t(KL~pd(PukYGmX42A^CDb*s1!jRsY?dTO$3|zpo#oh2J zW)S4OunQS8bb!lp$@DNn<6_Yvsnr1&_*C4(!BwJaTI+zJV*Bnb(?o3dOOJ=Qh+zP z0aXJdm0U(*Jus3{pXECR?#SjDm;}q}5(^!%lqvNdhC#fkK)di8dO_w;az;QYlyO~C ziiTX{B+8wciOD@6^(GPNC6plKf1_z|wyx|{nHBBQH5oySDiOGuFF_Z{023?`j&EAR z?o1psDJX3W29WA9)08G)b+fPGO+;2p>EMT1W}n$Cq@plLN>~BRvmjwB3kAPj46Pv| z*K`eVuP5TUpfsMkNAc!UhX<&LF_LKe^mJTPI!9o(D>CsJ7GJ(5>I4(aRnXgp zZD{7WiKhccE=FP&_Yf|YC+gr3fcIKy20%%Zhx%Mxje;J>9OYUVvjOyZxy5;BssTKJ zH$sYN&t1^Nkyo~_5p)hjIC8<*L*Um_$v8lV_5FFn$U6i54;6OPR% zZo>&U{F(#)$^d*ZL~C0*JfMUa9B?x5u?NNVYlge-D4e(?hI^>k`SF($^E$8qf6>V= z&RK-=OHvI-^s!0l`wtmSm;h^a^b{eYMI%f$8Ko3;RkMS`9RFBrt(A9Zfcbu#!}8 z$CCR3SDfmd>>4h0b&0)MR*34-os;L_0SxHUwDT;@+!-kQ%H=h9sNbl)Vc_vlpGpl; zgH1l~q{D)z|BOH=&B`=<2blU-*feX|#9-Qk$q7N_zJwO6gcMT})Tp}y3yV`GzQUoU zkmnx8R*u%_9B89`Cf7Pq0%aRKMkv3T2ua)82*SNXd?3$Dwul?*`;-KiUK|nXq>vsl zR17ULs5uFm1=fgM@FSfoGF0h&5n@$Z949kfHqah$@uUvX>57mp>xF%NDn4*@_^b?r zD8ZPQTje{U!FkD$1{cj@hIxR#8zmk>l+o8a6_k?+^r-L#2-qvdVv|$PvcR1#M56$z zmT;#l7lUgZT-AXw`i12)>|s>*ZI^tADme4En4eox@nO)GSxY%EN~$)KTNl=TI4;xr zfQ9`e3ziH}w9rpk>mwaHqrn+zY6$|Qkwj;VF)2RgV>;MLkTtX|{grRk*i!|2L``+$ zLgL{TybYcW2WFE}!7fXiKDFTYT# zTY(qwH~8Cd`1a)bd ze=MwjM<&)TFW1K^-Lo~)6LLr9ga*GyDB`p-*~`1yRsu0$8Z;N{_I4deJHbXu#_lLQ z=FySRNVf$!eQ%GwA?cSYq>WDy}EfG@j4L#q{ z#$QvIc}Nm7ABu})auBNs(sX5z(UY;LQ$avJEG>CP)QOU+x>&}|lMmK4`2vC$-sWmNof5ItsujtDjI?y$N^#D*;mAksEhs+>jZqjzC{T@d zh&ZEiHxFsxm~0i=U@hJ)j#!)1@d2^V(h&X~>~5pIvvGMqHB(VeVn zTT?tC>@;mtoYO@lH*h{yG>OgLkOG{{lmd*oax1glL`)&&K-M`8yeJj#+7D2ZbSm~j zz_RJrz!;p;F^p%VB!}aWBuCi2IJZnb#?&C%EX0kBqr&AAXyBRg@Dn|eG(p745q?c^ z4_(t=96b(SzI<~Me!o3^`SPb4XYkOr+$qn1&hMS7VZ$-AECeqj9T>o4E|AQd zB!5cn-o?Z%d;-y#ak+RCJOKl@t3N2#6Q9M)JfxUrk5KUIigNbet**a2MJ>0)FTd#n1X z{5Yrly27*fp>8L9!N84>!O$rgSSM$Zw~?o#6_$4bG!8A-VV8!2%IS z#;P0zW4JVopj+rHnL}#Crb6`8M8}`yS6C-07`FYf*dReLRYh_$o4l7TeN(gS$Ay1L zUHoV)IUZyiXrIE|sLZWf1pZl0SaVo|BJ7C?GK#=r>2&q5d z+G2|Mn+bBZ^e}z_H^E_j#zSAU`K%5=(d;ufLlhY&6g2blcB92OL2yS$#!Vqh_?68T zQtY8cp(|kRgr8#|0u1YY`XmdXuV*!FlCNQx77;vKXgI6E$xsC$MOx3`HEiCp!m_P( z5WF!9uR4X2)ezeAOQXoatUMCN-NIq_Fma1edNij=djuO811iR5+Jzh)ntWlqVsYr2 z&@?|K-@ZwkW+hhSMI@oKJ25YynblA~+y$do0G(nbpoAp`88LzBK&=H8!Gbat+e`+M@b zM4OVQujmW1Pfvm=?N1WO6sat!=1{ z|GvUabO6n$b5%YJ;RQ=34ax!6R4E4xp{QltgNoI>!d|k5lQk?1mIE9Th*3o$oldtK zY^YQc4fcm2p|FJf;53&Y9%4lZH$YkP>8uHO=DWEW5stf?lTMVP;^6cX8T?^+!9*KB zKX|jowIRKsrojWYRkvU`s8I~)seu4FhwI~4EMw&I=7|I-rS!nhE?T{&bihP=f$(t8 z58grvb;Z7f(eU$w542&GfJ=m4%>jvtO9UH|0r^8IIs_+a03_AbZ=wo;G6Jt;T@zH- zEQhCZMNCVAyfLV;5fgK}!q%LGsA~ZMWivAyoN^WPviHa?hHW)Sz(WyDow$UZ(dt2W zEE#X3@^myJ+dzP2omdZ~x2U*m;p=?szTGUO%Fr)FgJdfH4gD;@-EBXAQZA=3z*^$Y zDhGsmuH8xJknF|%tA!kEfLP6N#+@ zIGn({LX{w;b_8%SZzD+k7r5i*VRRYBv;@MwE(eEKjA?qv<_u;MfBPARBU?I|gplAO zG%)T`pNgMQjo}hdXeXQl&?ZRG2VmynYLYnFBiPX?LX)3^?q*0dwByz#anKzp=`0M9 z;bA~RCy&kA82G)pv70F^!=g-@pHW?lVDB7_MriVDJhr;Kd}JQ-D8-Hv(pYP@YlJ?M z(rQCW>*0^2HrkgGJMbQ9vjG*-?rgz8l((CJ@5q_wU$eOq__4HBgK=u3Ed=~Aw!X>q zgpKL5b`tP?_~tDYlLN6My%dH)LIzPHaY0bx{0~76|MoMEPM1}@8E_AlCGa&IwJQ$D z3pWIv;u?mWxFg4G2neTEJwJ%*RRa-Jw1|K%RUqCZ1+OJj)aM7ahe);_bOztG-lG&p zJ1IWH3e_Z7zy%C00&%$yC5-U6-aE|6XoLtuv6SwU7iWim1C2alX+LziS@Q#Zx(Nuw zrve7K>BfH2uzNORf>#(@9dyA6o5rhBsr-0x&2Ji2x;|ZSlD($(j*X!U9Ia!h+!l5#k}I zbWl-IQe)^$(GOMkDecM3=J|kUS%+><_0Ls;Uk`LQ0V~3NXWsGW4Ej|<<)kn0fW2QstIY7mdLU!2!xB! zEHN4Skb;xt3th}da8L!uq}S=k)f)u%#9^CxDCr=xZl3}X|gp)d;kLN+3b z6yvr5IBY_!5+JF6Lmg)pIn#*A%O+A~r3U7c=7S|?ak1S{WFNtwT8^TFqw`@k0d>-? zOo`$gH!!MN*UeEKK(Y*gWuw|d^f>WAH6|FQM|A*YIp|RhqHI(H(kOg3dO<>vMyc}A z>*@691+X~~09@k<9avDMR=lBhruzt7c2JsXge%p2*pB!VxY@i4E?XcVvWAvmT`!4I zO`Z_C-4)!*TK7O8&$=Oiv!<6|yPSC^$P~IK0)`(6MW{X;tU!lM9T4zyB?kkv*@*#D zYgtD}|KtD^ZWL1nFo3~9ClKUY$Zit`4t{wE&nJpSG;vsjGsKioq3>~Gi+W)vStfzc zV<=7FgY$BcP2rp(L!aZy3|gcZt(YUObt z3#UttXcSmY5hJb9?P0k4`}07{N~Zj9N@jrYREP!QuQ&+P2x2&2h$PaIU%P?lkpWU& z0?$&~`Uq~@dh@3IB-AJbnm%`PGBSg*i{%g7zX-trte#H*z|AykW&{mXsvTRbkToXk zLqeq)1|!V)y6lD3kdWO1pLZ>IV zoX(-JPxI121*=OO&{mk>{3md_Mxy5jXEocz`s^JH4;dh|;rzb_7Z`<(wL)B@AvGc> zX_ELeUL|Sa6Hz%Ql##dfk~?6uwKhOB@?4I;!M1N);GSL=gx&NHU_RV)gw7O*)9_C= zRN+rtGWaGAy{}kN*F%Y=%(#&i67%O87z}yB^UlEk2nFOmaA^J+@^By+x!|yl6Aw7x zC;udt2PflkDw%_@9k#PgcWD@m^L-dCq=Z?j2EFWdX3*$!2~FL^P}#^1u)Ps^`_2%M z|49M;HdG-d=gAnq&`G}bj6_8u{`2*zOGZ~S?w4n-Iso*kzHXtRgMZEtVGm~MmzV&E zCXPgf!`(!aNB2FV3zb_xh5bk9%n@vy*lLUUW7I*iP-W>aUp4ptj>*&N8mS>x(Pe#U=xG6ZDZgDivgiAVvBr<-|gMYD(?1239!}+!NqK07_}X&TOeHIPbtKK7IsmH={Uy@29wF z;Nt#869J2I`eOGFigScV@A=O``RBpE4__YrUi-sI!g*jDY&+UK`(MwBXSl|GG2Lud z2lP*eW42u*`7h6Io;hyM{3r$7R9rl;iEI%-W=dK3tNym)Uw&1FK~r|C!FgS2y-{C)-MFf zr1~E;&5PCS1^HDRI4-|DBhAHZFOg&3)>s-&VSC%wd`G|gseUlNnf!y6v(&4XEGo|ky+#Zz%%RwZot9BYug0ih z*Xg=(3_BW;nnza{v!nIHYE!*Hr0xR@q4lPvDxJQ_lU^cy7TXF#@d|)no~?@UvwwFx zzi&~&V_l9u&u^C}N7{!BzI#T5-Oex17(!Bmn&zknfV<7pL=Kk7bPlhYQ>Jy!0Z~D9 z=4gGQU4GX+3tIrXK9wzJRk=;i- z#*mk4kf#=Il&vSY*Gq^GSaFDo_l$AX`_3MzN9!3|+mv(Mjn8iINFAL(#}4SVH3SP} zJtTL?==VD$Q=fYz3_#4fmTBK_D++hLE{YlrBxR>n4c(g5QjY1|nuRrk$mD8()55kT zMrF36dt2zfb4p=uoxN4^=ZM84EK|NRR#OXaRCUiy>$J-H)aaXv- zh)#Ekc@*yf;Kln<&k*mD0mUeewZowXRWH^KkHM46*&J z%cUy$@$YS;1a}yCCM-#q)K8HFvx z2>RKJo7s4Fa7r&c$jU&k#a^%f=!pY<9r1L7ZBE2Et!Ok`;oA3LGQx>MhAKznx;VJx7vlb23i0g~Dw6F` z#YYFHTLd=8K~{m+)^jEl8}$H@QFC3y^H`612d7+wMoJtx9v;9;A4;r+>-3M>u%zj^ zC{|8ZK$Vxvu+RD{9u7G86#{&TV}~6ipO<$yL|C3|H@H>8GPZ*h!9?-IXN7m2@Dd%~ z1Z^F&`@Fv#@~))f^Uy1XcAGNU0EPHs+^yVA}w^ou6LTg~vjfXUm0E+85-6xbBj z_MCC!Bhhdrm>SGo$sO)k5JYwj(<63hntiPwEZ==~*Q{@= z(U#`8KXVH`_kGN%ptxCIiShJ(3_l{?(^BpszmFXc_#aw8xBI_XzrmjIM|II)Mz1zI z&OeOjeKA3FBggcIwg9$7Ka}4;&p%$={6T&KKWN00(K8O+>HPG2Cei}-r|a#DvZxAs>o{T0_I-0?m(>)zL-5)?W+|DMf-G6IS?UD5p zPKEZVcKZffZLPnL)eV+&wrhD>yR?^$41a!L`HZuK@2l`5Tj5Eyx|`sR=EXy?nE!vB z@=FKH?&=J|=S2fGX`nRHbE5l@660aba%+f?zC$s2p`*B9;4b_H&J_`*fNosrJ;*r4 zagy{Av3E9z0F@mm;TC54f;BvZ*uvFTSg8^mTO&L;HK?|0y3&kz9In4uaF{a~-8kzk zp`t7_8W%94G^EXwil5DE0>AwY{3ng8d%WF>njU9xG)PdxcY}hef`gC4Mttx zzs*2(eM%N^YjqkohB_x z8RJA;XMLzn?u&ds6|-P2@J^lZt(Q?$M}R)1UD;kl&G{utb2Yd|ZS@ruV6eb*D_BR+ppPqS1cihIu>-j)C(k> zN+Ae-#k!uao~{{v^-({BnY5%BD!;-}2nC2}DLyk|JJf>@70H~X-UNiw#HS$+Mr7F0 z)I*4HyPgMoHaUI>{Q2sm9xn{6u^gz)dsRcvS>9!Z1@sbXP7^wCw{=a#EgRK_LLfZ> zXfKco;ZH8$?x3Z3fLmuD0e1_}uxoH{atj!a;Ykn4#+j6-bri6Y2&FU$5Kd$_LGKZ~ zyp%O_Fp7xUu^*9L#V@m(jE+;W$%Y$;Tx_nHL1#-?%jYu#fnF%Z9~CUrH2n*N>OfT3 zd=Q0O#7xcxFgvWUC4c1ROn?rk0`BEPXdT%o390dB6g}yeO5)QFsVfbzdz-aEely!( z6N*P=nn~btfg=DtBt!1GHpnZ&R`FNi!b=CLNU%ymiFZdwE+-=u~vGuIT;m zY*!puPvNE_#7G1qhBik)ZB%+n3SF}xa0i6JPF{eidrH2EfKBS1&41zEjcc$9*F^@e zYP_A76obvcQOk(4w@|;#4kLoS$w8A5oQCync1!}r4a=*Mf*wFHTZNxFH4@NkjC3y3 zM6t9+50Y_d-o^>X_bg3O+WNw|3)G!M%U#&~hiz12O$XBI zWM7+_n7VkjpB1D?z=QigWcQ%6v29!g4QB3srdB$Q+o;mMl6B5~vJpoFP}$oJfUS&p z!t5|fYfnQb8`n^Zo>;<1jD$pf_zB&I*tgE4Af<@t`))jF)oBsjGLtsZo6%@9Dzi?m zcBVLz%o?Umf*IkQl@I;Wwo;MIwcan!zLKDhmhNW0FhYl^(U_YXS{MXR{J@*C9t=B> z$r3V#vTUg)-Jc{wH3};1tkgnzVN0?rdDyEY7T)-6hpk(zZdA|8>eeaEWNE?YRJ6il z9pET(w$6met!2!WK7N6+T;DzW_aW=D)YkU}S`qft34-RR)*6IEs4tR)wo%FY4rkQ$ zj@1EY4kZFFDmM9ThKjsWw3@Th0fON$6u{b!R6^Z$GdCsWgR7R+#Y&Bl z;@1lIEB2))&K-v$*pd5Ik`e*>r8nunp%X ziQnbkBZGYmXD3b4aCg$^c84c} zuIch*5VblznY8V0PX@WSrD-@mF=_7lIbkV>oVyN z^8;9FC#WC5kWEy7a3S3}h;oGb0VOqDp?(C{HfN|Gz&mq?`T-nsho~RG(sqgZ2FCk3 zMSTNn=o*h5GwtaX^`FW7NoQR9$ia5^qvU$DcU9V%<<3z*fTebi`T-1c2dN*xa+iyg zW8ZXu(we5NJ)fK`i}{OoS1CtlJ4-PxS&IpGsSIN{OgRee6Q!)h zErL~Ynqo8^3gm865s^7gB{*)#qK##QYUim4Zd{*4Oy)qP;F$|m#O-vVic~Nh3~p2r zmOD}@gfn=Lu2cz^Ia5hQ7Dr2>ghN#hPA*j$MmkkxDCI7b;i6+z29K^)89X^xWr*Zn zl_R2qRfb3|RuO^W6rHRRu<2$MaV?Hk0&lunMZBNM+Sw{#oz;fv$)ZUxUV@Er6QK-4 zo9Nu>Y6nGfyV69t6B#j$Q2} z(Y33cBsh1qQ$+W!c9P)Wr6__Q2pOeV6_!q3K4HVnOTwFuUJ{#Jy#&;9_HtGGwhl+%~S2)8edkd9vple>N?WW)JOVU_!r#%KpHh09#PG_L6crtocU zV2VgOf@y?y1=Bd;45ksu@kzs#LzqHkE@2ucox(B|ZO8QN7zX#jfktGGVhWku!K|bSE1ks@gCHg-W61)i zPtax>4r81);Izw_LS;^43YWW$1!U84OksAojs-e*H7NX(b~umiNE0>X+5K>Kk0lo|55S zPG;>4O*b=5{(s4i8EfZv*+#|mdpVowDi+T7@td8Gw(Vhdjf^N8l$IPH!b24~6`hwq z9^KnW<&M`*cQ~E3CgKAfY!O@B&UUBUX&x)OCTbArn2@$D`!$I;JABmSOXTU=+BOh0 z$-eJSE^|Q3+bxv_2NSIWKvCs3TxOwNiai(_=4ygrFxP8@?bh{p#2HN!e~&ww=JX8? zX_~>eSvAJ?iNkkar!<}W|1-BVT?`!iJlQcVMP~P3fQRpr-5h zL>D!eICD~qz!!KhZh;u*e0-;Np*tMad}?gp=kw^vCS27R-|DR9vFdS3;jZS;O z@CbdB(A!B?%I$PEj_A|$t61VSKD5or4Wb+(5zd!F9;XEySW`=!BHla93J@+|P;ANx z(kaju4?i)-`3)X&l?+ldpWY@O(*m)BO-_Ifz$EM~`-i3`8Nf z%W{V3QG)FQ-m|aL;5mI*qxD4Uw-jM1G{f5xFDT%7LOigVK)4pb+p6jN3)*pl_DY~x zfhTHYk@SFlyIswz2hlq3CU``O+RYlJ@6eXDB;HJC)k>6@3>%ktwIt^MzM79uQD}6} zg8~lt<(vrmP~s63*-IY~(;m}BmK?G3rXsHon9Q4L>aq`bkR*-p58FTRP{Ss*#E0#A zvAvrn08W--_V_*7rXh#V?XpUp{A+<@JV9OF;HmMHxFH69ovqOg%T%^sG1>8wUg)T^ zw}asu4D$8E@B(3iAQ)1M5f0&lT9D(inyibJY=<*?+5iSD!xP*~7NUX9M21TYVTx>= zim-InNC-ZIq?g5XUVKSybCzM(XnD~9XK7fU)p|gk)gSTLmKXs5RQKxp617W%_N*T8 ztD>=O-1kA6n*UW`SW8*=U)5~ckWGItV8okh@b_W~k&=4g?+EjCC%feD#X~V2eiSLD z#k#7eipiATpA04Y`?UH)NXWlWx8vd-Vk;7SOuvdWcs^njrk?m%t`I#c5$eW5{OOx* zLPB^JYlJcmC7=hi0eB+-wIELe_+yeXA4N$jycUGs<~N*%@4k*oOm)1Q7ul*34?+N(lOP)YeRfyeZAB>{$w{aT@s>+H`yzRGgeCXRXQDsPMRD+&Nva^8 za^(d+LDs45&k+S&H3x()E?^?govT=l2idlq4y2N}+oqaKx3LWNRK0KYy#IV1ZkB7f*p+2ZpnV@HQ15$J+ zfj%Mp)RY9%jT|L}xh&UEH)Eweh*oR`L%6vX2G`s5on)|{J)~B+s1a=`F{&5EQerod zhQpKjYFgZsa)r5I#M|<=KyMAtC`t!~H!)j@NwEe&urEqXCR+GXj*LBf%TkI0OgAyO zSx30{F!fx{EGhZHN)10pVAhQEGsTxvq?eHb(!98z4u8dq!4mxcxFnle90{h3`OO5<)C6cbg{)5Bsf`C|X&I#M z8C18M;oAx$M=-(c84mFB7d9J-6QU#P)qL3JQ5zJ0j$r9Iqqh~ zH?(>o_E;vSAxEFrvfc#v$4uzT*TtR4?z&jaQm&c%%8KMLq^hnh(h9t-d|bb1|dnei!}^CBKa-GXtv=Zkkn z8~#d*6u&vm|??a-`S$E;h&tXs#dTgR+h$E;h&tXs$Iw~kpiL{$$XRkTCLtXtQtTi2|cm;r)s z*Q{IDtXtQtTi2{x*Q{IDtXtQtThFXp&#YU|?6;m-x1L$Io>{k^S+|~9x1L$Io>{lP zS+~Afx4v1ozFD`vS+~Afx4v1ozFD`vS+~Afw}%_R6f=E3-O5L+iSCKug$u>HtY7ehK_)vfc=s$1u!RkzMdt8Sf_R^2);t-5tyT6OEZH0x&SB^^^Q>6m&+ z$J9$Yre4x9^^%UMmvl_Mq+{wO9aAsqn0iUa)Jr<1UeYo3l8&jDbWFXZW9lUxQ!nY5 zdP&FBOFE`r(lPatj;WV)OueLI>LndhFX@6m&+$J9$Yre4x9^^%UMmvl_Mq+{wO9aAsqn0iUa)Jr<1UeYo35(K6(*7=U9mvl_M zq+{wO9aAsqn0iUa)Jr<1UeYo3l8&jDbWFXZW9lUxQ!nY5dP&FBOFE`r(lPatj;WV) zOueLI>LndhFX@6m&+$J9$Yre4x9^^%UM zmvl_Mq+{wO9aAsqn0iUa)Jr<1UeYo3l8&jDbWFXZW9lVcQ!nY7dP&#ROS-0B(lzyx zuBn%FO}(UR>Lp!MFX@_kN!Qd%x~5*zHT9CNsh4z3y`*dEC0$c5>6&^;*VIe8re4xD z^^&fsmvl|Nq-*LWT~jaVntDms)JwXiUeY!7lCG(jbWOdaYw9IkQ!nY7dP&#ROS-0B z(lzyxuBn%FO}(UR>Lp!MFX@_kN!Qd%x~5*zHT9CNsh4z3y`*dEC0$c5>6&^;*VIe8 zre4xD^^&fsmvl|Nq-*LWT~jaVntDms)JwXiUeY!7lCG(jbWOdaYw9IkQ!nY7dP&#R zOS-0B(lzyxuBn%FO}(UR>Lp!MFX@_kN!Qd%x~5*zHT9CNsh4z3y`*dEC0$c5>6&^; z*VIe8re4xD^^&fsmvl|Nq-*LWT~jaVntDms)JwXiUeY!7lCG(jbWOdaYw9IkQ!nY7 zdP&#ROS-0B(lhmvo~f7gOueLM>Loo>FX@?jNzc?vdZu2|Gxd_5sh9Ljy`*RAB|TFw z>6v;-&(uqLre4xB^^%^cm-I}%q-W|SJyS2~nR-dj)JuA%UeYu5lAfuT^h~{^XX+(A zQ!nY6dP&dJOM0eW(lhmvo~f7gOueLM>Loo>FX@?jNzc?vdZu2|Gxd_5sh9Ljy`*RA zB|TFw>6v;-&(uqLre4xB^^%^cm-I}%q-W|SJyS2~nR-dj)JuA%UeYu5lAfuT^h~{^ zXX+(AQ!nY6dP&dJOM0eW(lhmvo~f7gOueLM>Loo>FX@?jNzc?vdZu2|Gxd_5sh9Lj zy`*RAB|TFw>6v;-&(uqLre4xB^^%^cm-I}%q-W|SJyS2~nR-dj)JuA%UeYu5lAfuT z^h~{^XX+(AQ!nY6dP&dJOM0eW(lhmvo~f7gOueLM>Lq6>~<-_%R`re4xF^^(4+m-J1&q;KjaeN!*#n|ev#)JyuNUeY)9 zlD?^z^i92_Z|Ws|Q!nY8dP(2ZOZui>(l_;zzNwe=O}(UV>Lq6>~<-_%R`re4xF^^(4+m-J1&q;KjaeN!*#n|ev#)JyuN zUeY)9lD?^z^i92_Z|Ws|Q!nY8dP(2ZOZui>(l_;zzNwe=O}(UV>Lq6>~<-_%R`re4xF^^(4+m-J1&q;KjaeN!*#n|ev# z)JyuNUeY)9lD?^z^i92_Z|Ws|Q!nY8dP(2ZOZui>(l_;zzNwe=O}(UV>LqLo{}UUFpWB}b-Sa%AcyN2XqKWa=eHre0zSjU!W8F(rv9 zNK83miV;(am_o#qA*Kj1C5S0NO!;Ao4^w)W!o!pursyzbgef9S31JEdQ$CpD!ITcB za4=xmr#Lvls6*1Ur6stX?%k5|ZKiv_ozI(4f}B=}x2ZFaU^@>4Vo0v?uDA@c z>QRiyl~X%Dxg@u1J$?PuM2MO5ZZX@uhl9*_ zB!zR!6AR0)1w1to1+SpeJ~bU)9;nN=4~U^Q8*yw$dTQ_UY7F1BZ({X+R+8h&xcmwq zswY;Q%fbvkQh-o+sC^3q7e<}gTp`-PQ+ZI#W{T<6`{}qBIfk$2{%PM; zt>97d=3!G_SH3~^UJ+f|UlFO|?g`_`rFx1?S1CT>X^Z_DgKLHsd}4~YY&{_tIEbD> zmDy*oA|&r+h44Z9&?3??{K1x+YXp39EeuCbENlBUK)GIjD$DVCwLd*Mx-K^tU+_-! zyt?13jFWkFb8tYh%MYJQzo#xUbs~#~C1&YfnTRCyQxdq@vsViCaowjAi4boN?Mv!h zW%r?8miHKR2v$(c_nz*nVz!?OLwd^-M)evI>Ad*ZyDZMtakrK*FTZlwN&G!2=&WCS}Qz zPj=ftQ`D}R_wT6<^~$?Hw>wmB$sg+8;^Mc#UhVURl)YckrnF?Wrf_d5|Lx~9M2zgw z%V*CI-cvM#hrLo9JuwC5;B7G~Db;z27;}>nI_yKc;7O(PDZe!p8g5i`UKGW3kGh5Y z5Xl80JL=7oi;Q4PcTZ}at7^L`pHx4e;)!*`%bAEA_GUJDx1``p&kruQo6lIwaJASr z#6vfFi{~Jd*l7J;{4@_T~|?OFEu=oa`ou(MQ;2l5=mF+mi0lX`QFrON>~FzA2|i zMTg5timNBKh?R8DqN=1%XqQI1Z_V$~*1>kvpPY~a@yN(Z#QRM~(0ju383Nm3GCZDv zPjFpTgDFDtJ)Yq6vfi#%AjPKI>3NT&*{P2^_2ZGaeh~irdlt{IrvZ7cU-O(Y3w|vSu^4Lz>a|hJrkMMT;a}KbD>&D$9 zszyNcP5YsitKMITGy2o;>u@xwhCDU=Z^Y%F-98N0?)5!J4QaRs+Pd5faTK<}<6T2K zXyW*+J}q$N@=K(AsE3;=om~t^_!m1wPv(KB5+=HbZI>Z2m&m=cH{{vi$)q1?C|Oab7H`^kn+H;M2qqL!Y-Bi1^APPuUBh--&P zngIxYw5h$^tOdlMOM{i$PvgfGV$dN9+)u+nIXa~%jun9X)x!y*rB-W^IckP1 z7>~;*8eur1Sv_cq;SgdPQJsfFCvt|P>D}-a(a|+zvMttQ2f|UvdiB$=Kmc@<;1;35 zmz!JqvE7XD2f?k~zXhbiY>61`!`pib>HO1hg4l*N-tKi7P7q@-lHddPlcl4-LubzM zt_6jg_AySWn+b%! 0 { - // Not enough information to determine the exact field. - // (See below.) - return &RequiredNotSetError{"{Unknown}"} - } return nil // input is satisfied } return fmt.Errorf("proto: %s: wiretype end group for non-group", st) @@ -395,20 +390,16 @@ func (o *Buffer) unmarshalType(st reflect.Type, prop *StructProperties, is_group if !ok { // Maybe it's an extension? if prop.extendable { - if e, eok := structPointer_Interface(base, st).(extensionsBytes); eok { - if isExtensionField(e, int32(tag)) { - if err = o.skip(st, tag, wire); err == nil { - ext := e.GetExtensions() + if e := structPointer_Interface(base, st).(extendableProto); isExtensionField(e, int32(tag)) { + if err = o.skip(st, tag, wire); err == nil { + if ee, eok := e.(extensionsMap); eok { + ext := ee.ExtensionMap()[int32(tag)] // may be missing + ext.enc = append(ext.enc, o.buf[oi:o.index]...) + ee.ExtensionMap()[int32(tag)] = ext + } else if ee, eok := e.(extensionsBytes); eok { + ext := ee.GetExtensions() *ext = append(*ext, o.buf[oi:o.index]...) } - continue - } - } else if e, _ := extendable(structPointer_Interface(base, st)); isExtensionField(e, int32(tag)) { - if err = o.skip(st, tag, wire); err == nil { - extmap := e.extensionsWrite() - ext := extmap[int32(tag)] // may be missing - ext.enc = append(ext.enc, o.buf[oi:o.index]...) - extmap[int32(tag)] = ext } continue } diff --git a/vendor/github.com/gogo/protobuf/proto/decode_gogo.go b/vendor/github.com/gogo/protobuf/proto/decode_gogo.go index ecc6387..603dabe 100644 --- a/vendor/github.com/gogo/protobuf/proto/decode_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/decode_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are diff --git a/vendor/github.com/gogo/protobuf/proto/duration.go b/vendor/github.com/gogo/protobuf/proto/duration.go deleted file mode 100644 index 93464c9..0000000 --- a/vendor/github.com/gogo/protobuf/proto/duration.go +++ /dev/null @@ -1,100 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2016 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// This file implements conversions between google.protobuf.Duration -// and time.Duration. - -import ( - "errors" - "fmt" - "time" -) - -const ( - // Range of a Duration in seconds, as specified in - // google/protobuf/duration.proto. This is about 10,000 years in seconds. - maxSeconds = int64(10000 * 365.25 * 24 * 60 * 60) - minSeconds = -maxSeconds -) - -// validateDuration determines whether the Duration is valid according to the -// definition in google/protobuf/duration.proto. A valid Duration -// may still be too large to fit into a time.Duration (the range of Duration -// is about 10,000 years, and the range of time.Duration is about 290). -func validateDuration(d *duration) error { - if d == nil { - return errors.New("duration: nil Duration") - } - if d.Seconds < minSeconds || d.Seconds > maxSeconds { - return fmt.Errorf("duration: %#v: seconds out of range", d) - } - if d.Nanos <= -1e9 || d.Nanos >= 1e9 { - return fmt.Errorf("duration: %#v: nanos out of range", d) - } - // Seconds and Nanos must have the same sign, unless d.Nanos is zero. - if (d.Seconds < 0 && d.Nanos > 0) || (d.Seconds > 0 && d.Nanos < 0) { - return fmt.Errorf("duration: %#v: seconds and nanos have different signs", d) - } - return nil -} - -// DurationFromProto converts a Duration to a time.Duration. DurationFromProto -// returns an error if the Duration is invalid or is too large to be -// represented in a time.Duration. -func durationFromProto(p *duration) (time.Duration, error) { - if err := validateDuration(p); err != nil { - return 0, err - } - d := time.Duration(p.Seconds) * time.Second - if int64(d/time.Second) != p.Seconds { - return 0, fmt.Errorf("duration: %#v is out of range for time.Duration", p) - } - if p.Nanos != 0 { - d += time.Duration(p.Nanos) - if (d < 0) != (p.Nanos < 0) { - return 0, fmt.Errorf("duration: %#v is out of range for time.Duration", p) - } - } - return d, nil -} - -// DurationProto converts a time.Duration to a Duration. -func durationProto(d time.Duration) *duration { - nanos := d.Nanoseconds() - secs := nanos / 1e9 - nanos -= secs * 1e9 - return &duration{ - Seconds: secs, - Nanos: int32(nanos), - } -} diff --git a/vendor/github.com/gogo/protobuf/proto/duration_gogo.go b/vendor/github.com/gogo/protobuf/proto/duration_gogo.go deleted file mode 100644 index a93cb9d..0000000 --- a/vendor/github.com/gogo/protobuf/proto/duration_gogo.go +++ /dev/null @@ -1,202 +0,0 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2016, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "reflect" - "time" -) - -var durationType = reflect.TypeOf((*time.Duration)(nil)).Elem() - -type duration struct { - Seconds int64 `protobuf:"varint,1,opt,name=seconds,proto3" json:"seconds,omitempty"` - Nanos int32 `protobuf:"varint,2,opt,name=nanos,proto3" json:"nanos,omitempty"` -} - -func (m *duration) Reset() { *m = duration{} } -func (*duration) ProtoMessage() {} -func (*duration) String() string { return "duration" } - -func init() { - RegisterType((*duration)(nil), "gogo.protobuf.proto.duration") -} - -func (o *Buffer) decDuration() (time.Duration, error) { - b, err := o.DecodeRawBytes(true) - if err != nil { - return 0, err - } - dproto := &duration{} - if err := Unmarshal(b, dproto); err != nil { - return 0, err - } - return durationFromProto(dproto) -} - -func (o *Buffer) dec_duration(p *Properties, base structPointer) error { - d, err := o.decDuration() - if err != nil { - return err - } - word64_Set(structPointer_Word64(base, p.field), o, uint64(d)) - return nil -} - -func (o *Buffer) dec_ref_duration(p *Properties, base structPointer) error { - d, err := o.decDuration() - if err != nil { - return err - } - word64Val_Set(structPointer_Word64Val(base, p.field), o, uint64(d)) - return nil -} - -func (o *Buffer) dec_slice_duration(p *Properties, base structPointer) error { - d, err := o.decDuration() - if err != nil { - return err - } - newBas := appendStructPointer(base, p.field, reflect.SliceOf(reflect.PtrTo(durationType))) - setPtrCustomType(newBas, 0, &d) - return nil -} - -func (o *Buffer) dec_slice_ref_duration(p *Properties, base structPointer) error { - d, err := o.decDuration() - if err != nil { - return err - } - structPointer_Word64Slice(base, p.field).Append(uint64(d)) - return nil -} - -func size_duration(p *Properties, base structPointer) (n int) { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return 0 - } - dur := structPointer_Interface(structp, durationType).(*time.Duration) - d := durationProto(*dur) - size := Size(d) - return size + sizeVarint(uint64(size)) + len(p.tagcode) -} - -func (o *Buffer) enc_duration(p *Properties, base structPointer) error { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return ErrNil - } - dur := structPointer_Interface(structp, durationType).(*time.Duration) - d := durationProto(*dur) - data, err := Marshal(d) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_ref_duration(p *Properties, base structPointer) (n int) { - dur := structPointer_InterfaceAt(base, p.field, durationType).(*time.Duration) - d := durationProto(*dur) - size := Size(d) - return size + sizeVarint(uint64(size)) + len(p.tagcode) -} - -func (o *Buffer) enc_ref_duration(p *Properties, base structPointer) error { - dur := structPointer_InterfaceAt(base, p.field, durationType).(*time.Duration) - d := durationProto(*dur) - data, err := Marshal(d) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_slice_duration(p *Properties, base structPointer) (n int) { - pdurs := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(durationType))).(*[]*time.Duration) - durs := *pdurs - for i := 0; i < len(durs); i++ { - if durs[i] == nil { - return 0 - } - dproto := durationProto(*durs[i]) - size := Size(dproto) - n += len(p.tagcode) + size + sizeVarint(uint64(size)) - } - return n -} - -func (o *Buffer) enc_slice_duration(p *Properties, base structPointer) error { - pdurs := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(durationType))).(*[]*time.Duration) - durs := *pdurs - for i := 0; i < len(durs); i++ { - if durs[i] == nil { - return errRepeatedHasNil - } - dproto := durationProto(*durs[i]) - data, err := Marshal(dproto) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - } - return nil -} - -func size_slice_ref_duration(p *Properties, base structPointer) (n int) { - pdurs := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(durationType)).(*[]time.Duration) - durs := *pdurs - for i := 0; i < len(durs); i++ { - dproto := durationProto(durs[i]) - size := Size(dproto) - n += len(p.tagcode) + size + sizeVarint(uint64(size)) - } - return n -} - -func (o *Buffer) enc_slice_ref_duration(p *Properties, base structPointer) error { - pdurs := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(durationType)).(*[]time.Duration) - durs := *pdurs - for i := 0; i < len(durs); i++ { - dproto := durationProto(durs[i]) - data, err := Marshal(dproto) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - } - return nil -} diff --git a/vendor/github.com/gogo/protobuf/proto/encode.go b/vendor/github.com/gogo/protobuf/proto/encode.go index 68b9b30..eb7e047 100644 --- a/vendor/github.com/gogo/protobuf/proto/encode.go +++ b/vendor/github.com/gogo/protobuf/proto/encode.go @@ -70,10 +70,6 @@ var ( // ErrNil is the error returned if Marshal is called with nil. ErrNil = errors.New("proto: Marshal called with nil") - - // ErrTooLarge is the error returned if Marshal is called with a - // message that encodes to >2GB. - ErrTooLarge = errors.New("proto: message encodes to over 2 GB") ) // The fundamental encoders that put bytes on the wire. @@ -82,10 +78,6 @@ var ( const maxVarintBytes = 10 // maximum length of a varint -// maxMarshalSize is the largest allowed size of an encoded protobuf, -// since C++ and Java use signed int32s for the size. -const maxMarshalSize = 1<<31 - 1 - // EncodeVarint returns the varint encoding of x. // This is the format for the // int32, int64, uint32, uint64, bool, and enum @@ -234,6 +226,10 @@ func Marshal(pb Message) ([]byte, error) { } p := NewBuffer(nil) err := p.Marshal(pb) + var state errorState + if err != nil && !state.shouldContinue(err, nil) { + return nil, err + } if p.buf == nil && err == nil { // Return a non-nil slice on success. return []byte{}, nil @@ -262,8 +258,11 @@ func (p *Buffer) Marshal(pb Message) error { // Can the object marshal itself? if m, ok := pb.(Marshaler); ok { data, err := m.Marshal() + if err != nil { + return err + } p.buf = append(p.buf, data...) - return err + return nil } t, base, err := getbase(pb) @@ -275,12 +274,9 @@ func (p *Buffer) Marshal(pb Message) error { } if collectStats { - (stats).Encode++ // Parens are to work around a goimports bug. + stats.Encode++ } - if len(p.buf) > maxMarshalSize { - return ErrTooLarge - } return err } @@ -302,7 +298,7 @@ func Size(pb Message) (n int) { } if collectStats { - (stats).Size++ // Parens are to work around a goimports bug. + stats.Size++ } return @@ -1007,6 +1003,7 @@ func size_slice_struct_message(p *Properties, base structPointer) (n int) { if p.isMarshaler { m := structPointer_Interface(structp, p.stype).(Marshaler) data, _ := m.Marshal() + n += len(p.tagcode) n += sizeRawBytes(data) continue } @@ -1065,25 +1062,10 @@ func size_slice_struct_group(p *Properties, base structPointer) (n int) { // Encode an extension map. func (o *Buffer) enc_map(p *Properties, base structPointer) error { - exts := structPointer_ExtMap(base, p.field) - if err := encodeExtensionsMap(*exts); err != nil { + v := *structPointer_ExtMap(base, p.field) + if err := encodeExtensionMap(v); err != nil { return err } - - return o.enc_map_body(*exts) -} - -func (o *Buffer) enc_exts(p *Properties, base structPointer) error { - exts := structPointer_Extensions(base, p.field) - if err := encodeExtensions(exts); err != nil { - return err - } - v, _ := exts.extensionsRead() - - return o.enc_map_body(v) -} - -func (o *Buffer) enc_map_body(v map[int32]Extension) error { // Fast-path for common cases: zero or one extensions. if len(v) <= 1 { for _, e := range v { @@ -1106,13 +1088,8 @@ func (o *Buffer) enc_map_body(v map[int32]Extension) error { } func size_map(p *Properties, base structPointer) int { - v := structPointer_ExtMap(base, p.field) - return extensionsMapSize(*v) -} - -func size_exts(p *Properties, base structPointer) int { - v := structPointer_Extensions(base, p.field) - return extensionsSize(v) + v := *structPointer_ExtMap(base, p.field) + return sizeExtensionMap(v) } // Encode a map field. @@ -1141,7 +1118,7 @@ func (o *Buffer) enc_new_map(p *Properties, base structPointer) error { if err := p.mkeyprop.enc(o, p.mkeyprop, keybase); err != nil { return err } - if err := p.mvalprop.enc(o, p.mvalprop, valbase); err != nil && err != ErrNil { + if err := p.mvalprop.enc(o, p.mvalprop, valbase); err != nil { return err } return nil @@ -1151,6 +1128,11 @@ func (o *Buffer) enc_new_map(p *Properties, base structPointer) error { for _, key := range v.MapKeys() { val := v.MapIndex(key) + // The only illegal map entry values are nil message pointers. + if val.Kind() == reflect.Ptr && val.IsNil() { + return errors.New("proto: map has nil element") + } + keycopy.Set(key) valcopy.Set(val) @@ -1238,9 +1220,6 @@ func (o *Buffer) enc_struct(prop *StructProperties, base structPointer) error { return err } } - if len(o.buf) > maxMarshalSize { - return ErrTooLarge - } } } @@ -1257,9 +1236,6 @@ func (o *Buffer) enc_struct(prop *StructProperties, base structPointer) error { // Add unrecognized fields at the end. if prop.unrecField.IsValid() { v := *structPointer_Bytes(base, prop.unrecField) - if len(o.buf)+len(v) > maxMarshalSize { - return ErrTooLarge - } if len(v) > 0 { o.buf = append(o.buf, v...) } diff --git a/vendor/github.com/gogo/protobuf/proto/encode_gogo.go b/vendor/github.com/gogo/protobuf/proto/encode_gogo.go index 66e7e16..f77cfb1 100644 --- a/vendor/github.com/gogo/protobuf/proto/encode_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/encode_gogo.go @@ -1,7 +1,7 @@ -// Protocol Buffers for Go with Gadgets +// Extensions for Protocol Buffers to create more go like structures. // -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Go support for Protocol Buffers - Google's data interchange format // diff --git a/vendor/github.com/gogo/protobuf/proto/equal.go b/vendor/github.com/gogo/protobuf/proto/equal.go index 2ed1cf5..f5db1de 100644 --- a/vendor/github.com/gogo/protobuf/proto/equal.go +++ b/vendor/github.com/gogo/protobuf/proto/equal.go @@ -54,17 +54,13 @@ Equality is defined in this way: in a proto3 .proto file, fields are not "set"; specifically, zero length proto3 "bytes" fields are equal (nil == {}). - Two repeated fields are equal iff their lengths are the same, - and their corresponding elements are equal. Note a "bytes" field, - although represented by []byte, is not a repeated field and the - rule for the scalar fields described above applies. + and their corresponding elements are equal (a "bytes" field, + although represented by []byte, is not a repeated field) - Two unset fields are equal. - Two unknown field sets are equal if their current encoded state is equal. - Two extension sets are equal iff they have corresponding elements that are pairwise equal. - - Two map fields are equal iff their lengths are the same, - and they contain the same set of elements. Zero-length map - fields are equal. - Every other combination of things are not equal. The return value is undefined if a and b are not protocol buffers. @@ -125,16 +121,9 @@ func equalStruct(v1, v2 reflect.Value) bool { } } - if em1 := v1.FieldByName("XXX_InternalExtensions"); em1.IsValid() { - em2 := v2.FieldByName("XXX_InternalExtensions") - if !equalExtensions(v1.Type(), em1.Interface().(XXX_InternalExtensions), em2.Interface().(XXX_InternalExtensions)) { - return false - } - } - if em1 := v1.FieldByName("XXX_extensions"); em1.IsValid() { em2 := v2.FieldByName("XXX_extensions") - if !equalExtMap(v1.Type(), em1.Interface().(map[int32]Extension), em2.Interface().(map[int32]Extension)) { + if !equalExtensions(v1.Type(), em1.Interface().(map[int32]Extension), em2.Interface().(map[int32]Extension)) { return false } } @@ -195,13 +184,6 @@ func equalAny(v1, v2 reflect.Value, prop *Properties) bool { } return true case reflect.Ptr: - // Maps may have nil values in them, so check for nil. - if v1.IsNil() && v2.IsNil() { - return true - } - if v1.IsNil() != v2.IsNil() { - return false - } return equalAny(v1.Elem(), v2.Elem(), prop) case reflect.Slice: if v1.Type().Elem().Kind() == reflect.Uint8 { @@ -241,14 +223,8 @@ func equalAny(v1, v2 reflect.Value, prop *Properties) bool { } // base is the struct type that the extensions are based on. -// x1 and x2 are InternalExtensions. -func equalExtensions(base reflect.Type, x1, x2 XXX_InternalExtensions) bool { - em1, _ := x1.extensionsRead() - em2, _ := x2.extensionsRead() - return equalExtMap(base, em1, em2) -} - -func equalExtMap(base reflect.Type, em1, em2 map[int32]Extension) bool { +// em1 and em2 are extension maps. +func equalExtensions(base reflect.Type, em1, em2 map[int32]Extension) bool { if len(em1) != len(em2) { return false } diff --git a/vendor/github.com/gogo/protobuf/proto/extensions.go b/vendor/github.com/gogo/protobuf/proto/extensions.go index 5ab5e4c..6180347 100644 --- a/vendor/github.com/gogo/protobuf/proto/extensions.go +++ b/vendor/github.com/gogo/protobuf/proto/extensions.go @@ -52,112 +52,23 @@ type ExtensionRange struct { Start, End int32 // both inclusive } -// extendableProto is an interface implemented by any protocol buffer generated by the current -// proto compiler that may be extended. +// extendableProto is an interface implemented by any protocol buffer that may be extended. type extendableProto interface { Message ExtensionRangeArray() []ExtensionRange - extensionsWrite() map[int32]Extension - extensionsRead() (map[int32]Extension, sync.Locker) } -// extendableProtoV1 is an interface implemented by a protocol buffer generated by the previous -// version of the proto compiler that may be extended. -type extendableProtoV1 interface { - Message - ExtensionRangeArray() []ExtensionRange +type extensionsMap interface { + extendableProto ExtensionMap() map[int32]Extension } type extensionsBytes interface { - Message - ExtensionRangeArray() []ExtensionRange + extendableProto GetExtensions() *[]byte } -// extensionAdapter is a wrapper around extendableProtoV1 that implements extendableProto. -type extensionAdapter struct { - extendableProtoV1 -} - -func (e extensionAdapter) extensionsWrite() map[int32]Extension { - return e.ExtensionMap() -} - -func (e extensionAdapter) extensionsRead() (map[int32]Extension, sync.Locker) { - return e.ExtensionMap(), notLocker{} -} - -// notLocker is a sync.Locker whose Lock and Unlock methods are nops. -type notLocker struct{} - -func (n notLocker) Lock() {} -func (n notLocker) Unlock() {} - -// extendable returns the extendableProto interface for the given generated proto message. -// If the proto message has the old extension format, it returns a wrapper that implements -// the extendableProto interface. -func extendable(p interface{}) (extendableProto, bool) { - if ep, ok := p.(extendableProto); ok { - return ep, ok - } - if ep, ok := p.(extendableProtoV1); ok { - return extensionAdapter{ep}, ok - } - return nil, false -} - -// XXX_InternalExtensions is an internal representation of proto extensions. -// -// Each generated message struct type embeds an anonymous XXX_InternalExtensions field, -// thus gaining the unexported 'extensions' method, which can be called only from the proto package. -// -// The methods of XXX_InternalExtensions are not concurrency safe in general, -// but calls to logically read-only methods such as has and get may be executed concurrently. -type XXX_InternalExtensions struct { - // The struct must be indirect so that if a user inadvertently copies a - // generated message and its embedded XXX_InternalExtensions, they - // avoid the mayhem of a copied mutex. - // - // The mutex serializes all logically read-only operations to p.extensionMap. - // It is up to the client to ensure that write operations to p.extensionMap are - // mutually exclusive with other accesses. - p *struct { - mu sync.Mutex - extensionMap map[int32]Extension - } -} - -// extensionsWrite returns the extension map, creating it on first use. -func (e *XXX_InternalExtensions) extensionsWrite() map[int32]Extension { - if e.p == nil { - e.p = new(struct { - mu sync.Mutex - extensionMap map[int32]Extension - }) - e.p.extensionMap = make(map[int32]Extension) - } - return e.p.extensionMap -} - -// extensionsRead returns the extensions map for read-only use. It may be nil. -// The caller must hold the returned mutex's lock when accessing Elements within the map. -func (e *XXX_InternalExtensions) extensionsRead() (map[int32]Extension, sync.Locker) { - if e.p == nil { - return nil, nil - } - return e.p.extensionMap, &e.p.mu -} - -type extensionRange interface { - Message - ExtensionRangeArray() []ExtensionRange -} - var extendableProtoType = reflect.TypeOf((*extendableProto)(nil)).Elem() -var extendableProtoV1Type = reflect.TypeOf((*extendableProtoV1)(nil)).Elem() -var extendableBytesType = reflect.TypeOf((*extensionsBytes)(nil)).Elem() -var extensionRangeType = reflect.TypeOf((*extensionRange)(nil)).Elem() // ExtensionDesc represents an extension specification. // Used in generated code from the protocol compiler. @@ -190,23 +101,20 @@ type Extension struct { } // SetRawExtension is for testing only. -func SetRawExtension(base Message, id int32, b []byte) { - if ebase, ok := base.(extensionsBytes); ok { +func SetRawExtension(base extendableProto, id int32, b []byte) { + if ebase, ok := base.(extensionsMap); ok { + ebase.ExtensionMap()[id] = Extension{enc: b} + } else if ebase, ok := base.(extensionsBytes); ok { clearExtension(base, id) ext := ebase.GetExtensions() *ext = append(*ext, b...) - return + } else { + panic("unreachable") } - epb, ok := extendable(base) - if !ok { - return - } - extmap := epb.extensionsWrite() - extmap[id] = Extension{enc: b} } // isExtensionField returns true iff the given field number is in an extension range. -func isExtensionField(pb extensionRange, field int32) bool { +func isExtensionField(pb extendableProto, field int32) bool { for _, er := range pb.ExtensionRangeArray() { if er.Start <= field && field <= er.End { return true @@ -217,12 +125,8 @@ func isExtensionField(pb extensionRange, field int32) bool { // checkExtensionTypes checks that the given extension is valid for pb. func checkExtensionTypes(pb extendableProto, extension *ExtensionDesc) error { - var pbi interface{} = pb // Check the extended type. - if ea, ok := pbi.(extensionAdapter); ok { - pbi = ea.extendableProtoV1 - } - if a, b := reflect.TypeOf(pbi), reflect.TypeOf(extension.ExtendedType); a != b { + if a, b := reflect.TypeOf(pb), reflect.TypeOf(extension.ExtendedType); a != b { return errors.New("proto: bad extended type; " + b.String() + " does not extend " + a.String()) } // Check the range. @@ -268,57 +172,43 @@ func extensionProperties(ed *ExtensionDesc) *Properties { return prop } -// encode encodes any unmarshaled (unencoded) extensions in e. -func encodeExtensions(e *XXX_InternalExtensions) error { - m, mu := e.extensionsRead() - if m == nil { - return nil // fast path - } - mu.Lock() - defer mu.Unlock() - return encodeExtensionsMap(m) -} - -// encode encodes any unmarshaled (unencoded) extensions in e. -func encodeExtensionsMap(m map[int32]Extension) error { +// encodeExtensionMap encodes any unmarshaled (unencoded) extensions in m. +func encodeExtensionMap(m map[int32]Extension) error { for k, e := range m { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - continue - } - - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - p := NewBuffer(nil) - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { + err := encodeExtension(&e) + if err != nil { return err } - e.enc = p.buf m[k] = e } return nil } -func extensionsSize(e *XXX_InternalExtensions) (n int) { - m, mu := e.extensionsRead() - if m == nil { - return 0 +func encodeExtension(e *Extension) error { + if e.value == nil || e.desc == nil { + // Extension is only in its encoded form. + return nil } - mu.Lock() - defer mu.Unlock() - return extensionsMapSize(m) + // We don't skip extensions that have an encoded form set, + // because the extension value may have been mutated after + // the last time this function was called. + + et := reflect.TypeOf(e.desc.ExtensionType) + props := extensionProperties(e.desc) + + p := NewBuffer(nil) + // If e.value has type T, the encoder expects a *struct{ X T }. + // Pass a *T with a zero field and hope it all works out. + x := reflect.New(et) + x.Elem().Set(reflect.ValueOf(e.value)) + if err := props.enc(p, props, toStructPointer(x)); err != nil { + return err + } + e.enc = p.buf + return nil } -func extensionsMapSize(m map[int32]Extension) (n int) { +func sizeExtensionMap(m map[int32]Extension) (n int) { for _, e := range m { if e.value == nil || e.desc == nil { // Extension is only in its encoded form. @@ -343,8 +233,12 @@ func extensionsMapSize(m map[int32]Extension) (n int) { } // HasExtension returns whether the given extension is present in pb. -func HasExtension(pb Message, extension *ExtensionDesc) bool { - if epb, doki := pb.(extensionsBytes); doki { +func HasExtension(pb extendableProto, extension *ExtensionDesc) bool { + // TODO: Check types, field numbers, etc.? + if epb, doki := pb.(extensionsMap); doki { + _, ok := epb.ExtensionMap()[extension.Field] + return ok + } else if epb, doki := pb.(extensionsBytes); doki { ext := epb.GetExtensions() buf := *ext o := 0 @@ -364,19 +258,7 @@ func HasExtension(pb Message, extension *ExtensionDesc) bool { } return false } - // TODO: Check types, field numbers, etc.? - epb, ok := extendable(pb) - if !ok { - return false - } - extmap, mu := epb.extensionsRead() - if extmap == nil { - return false - } - mu.Lock() - _, ok = extmap[extension.Field] - mu.Unlock() - return ok + panic("unreachable") } func deleteExtension(pb extensionsBytes, theFieldNum int32, offset int) int { @@ -399,32 +281,64 @@ func deleteExtension(pb extensionsBytes, theFieldNum int32, offset int) int { return -1 } -// ClearExtension removes the given extension from pb. -func ClearExtension(pb Message, extension *ExtensionDesc) { - clearExtension(pb, extension.Field) -} - -func clearExtension(pb Message, fieldNum int32) { - if epb, doki := pb.(extensionsBytes); doki { +func clearExtension(pb extendableProto, fieldNum int32) { + if epb, doki := pb.(extensionsMap); doki { + delete(epb.ExtensionMap(), fieldNum) + } else if epb, doki := pb.(extensionsBytes); doki { offset := 0 for offset != -1 { offset = deleteExtension(epb, fieldNum, offset) } - return - } - epb, ok := extendable(pb) - if !ok { - return + } else { + panic("unreachable") } +} + +// ClearExtension removes the given extension from pb. +func ClearExtension(pb extendableProto, extension *ExtensionDesc) { // TODO: Check types, field numbers, etc.? - extmap := epb.extensionsWrite() - delete(extmap, fieldNum) + clearExtension(pb, extension.Field) } // GetExtension parses and returns the given extension of pb. -// If the extension is not present and has no default value it returns ErrMissingExtension. -func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { - if epb, doki := pb.(extensionsBytes); doki { +// If the extension is not present it returns ErrMissingExtension. +func GetExtension(pb extendableProto, extension *ExtensionDesc) (interface{}, error) { + if err := checkExtensionTypes(pb, extension); err != nil { + return nil, err + } + + if epb, doki := pb.(extensionsMap); doki { + emap := epb.ExtensionMap() + e, ok := emap[extension.Field] + if !ok { + // defaultExtensionValue returns the default value or + // ErrMissingExtension if there is no default. + return defaultExtensionValue(extension) + } + if e.value != nil { + // Already decoded. Check the descriptor, though. + if e.desc != extension { + // This shouldn't happen. If it does, it means that + // GetExtension was called twice with two different + // descriptors with the same field number. + return nil, errors.New("proto: descriptor conflict") + } + return e.value, nil + } + + v, err := decodeExtension(e.enc, extension) + if err != nil { + return nil, err + } + + // Remember the decoded version and drop the encoded version. + // That way it is safe to mutate what we return. + e.value = v + e.desc = extension + e.enc = nil + emap[extension.Field] = e + return e.value, nil + } else if epb, doki := pb.(extensionsBytes); doki { ext := epb.GetExtensions() o := 0 for o < len(*ext) { @@ -446,50 +360,7 @@ func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { } return defaultExtensionValue(extension) } - epb, ok := extendable(pb) - if !ok { - return nil, errors.New("proto: not an extendable proto") - } - if err := checkExtensionTypes(epb, extension); err != nil { - return nil, err - } - - emap, mu := epb.extensionsRead() - if emap == nil { - return defaultExtensionValue(extension) - } - mu.Lock() - defer mu.Unlock() - e, ok := emap[extension.Field] - if !ok { - // defaultExtensionValue returns the default value or - // ErrMissingExtension if there is no default. - return defaultExtensionValue(extension) - } - - if e.value != nil { - // Already decoded. Check the descriptor, though. - if e.desc != extension { - // This shouldn't happen. If it does, it means that - // GetExtension was called twice with two different - // descriptors with the same field number. - return nil, errors.New("proto: descriptor conflict") - } - return e.value, nil - } - - v, err := decodeExtension(e.enc, extension) - if err != nil { - return nil, err - } - - // Remember the decoded version and drop the encoded version. - // That way it is safe to mutate what we return. - e.value = v - e.desc = extension - e.enc = nil - emap[extension.Field] = e - return e.value, nil + panic("unreachable") } // defaultExtensionValue returns the default value for extension. @@ -563,9 +434,14 @@ func decodeExtension(b []byte, extension *ExtensionDesc) (interface{}, error) { // GetExtensions returns a slice of the extensions present in pb that are also listed in es. // The returned slice has the same length as es; missing extensions will appear as nil elements. func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, err error) { + epb, ok := pb.(extendableProto) + if !ok { + err = errors.New("proto: not an extendable proto") + return + } extensions = make([]interface{}, len(es)) for i, e := range es { - extensions[i], err = GetExtension(pb, e) + extensions[i], err = GetExtension(epb, e) if err == ErrMissingExtension { err = nil } @@ -576,58 +452,9 @@ func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, e return } -// ExtensionDescs returns a new slice containing pb's extension descriptors, in undefined order. -// For non-registered extensions, ExtensionDescs returns an incomplete descriptor containing -// just the Field field, which defines the extension's field number. -func ExtensionDescs(pb Message) ([]*ExtensionDesc, error) { - epb, ok := extendable(pb) - if !ok { - return nil, fmt.Errorf("proto: %T is not an extendable proto.Message", pb) - } - registeredExtensions := RegisteredExtensions(pb) - - emap, mu := epb.extensionsRead() - if emap == nil { - return nil, nil - } - mu.Lock() - defer mu.Unlock() - extensions := make([]*ExtensionDesc, 0, len(emap)) - for extid, e := range emap { - desc := e.desc - if desc == nil { - desc = registeredExtensions[extid] - if desc == nil { - desc = &ExtensionDesc{Field: extid} - } - } - - extensions = append(extensions, desc) - } - return extensions, nil -} - // SetExtension sets the specified extension of pb to the specified value. -func SetExtension(pb Message, extension *ExtensionDesc, value interface{}) error { - if epb, doki := pb.(extensionsBytes); doki { - ClearExtension(pb, extension) - ext := epb.GetExtensions() - et := reflect.TypeOf(extension.ExtensionType) - props := extensionProperties(extension) - p := NewBuffer(nil) - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { - return err - } - *ext = append(*ext, p.buf...) - return nil - } - epb, ok := extendable(pb) - if !ok { - return errors.New("proto: not an extendable proto") - } - if err := checkExtensionTypes(epb, extension); err != nil { +func SetExtension(pb extendableProto, extension *ExtensionDesc, value interface{}) error { + if err := checkExtensionTypes(pb, extension); err != nil { return err } typ := reflect.TypeOf(extension.ExtensionType) @@ -642,27 +469,26 @@ func SetExtension(pb Message, extension *ExtensionDesc, value interface{}) error if reflect.ValueOf(value).IsNil() { return fmt.Errorf("proto: SetExtension called with nil value of type %T", value) } - - extmap := epb.extensionsWrite() - extmap[extension.Field] = Extension{desc: extension, value: value} - return nil + return setExtension(pb, extension, value) } -// ClearAllExtensions clears all extensions from pb. -func ClearAllExtensions(pb Message) { - if epb, doki := pb.(extensionsBytes); doki { +func setExtension(pb extendableProto, extension *ExtensionDesc, value interface{}) error { + if epb, doki := pb.(extensionsMap); doki { + epb.ExtensionMap()[extension.Field] = Extension{desc: extension, value: value} + } else if epb, doki := pb.(extensionsBytes); doki { + ClearExtension(pb, extension) ext := epb.GetExtensions() - *ext = []byte{} - return - } - epb, ok := extendable(pb) - if !ok { - return - } - m := epb.extensionsWrite() - for k := range m { - delete(m, k) + et := reflect.TypeOf(extension.ExtensionType) + props := extensionProperties(extension) + p := NewBuffer(nil) + x := reflect.New(et) + x.Elem().Set(reflect.ValueOf(value)) + if err := props.enc(p, props, toStructPointer(x)); err != nil { + return err + } + *ext = append(*ext, p.buf...) } + return nil } // A global registry of extensions. diff --git a/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go b/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go index ea6478f..86b1fa2 100644 --- a/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are @@ -35,10 +33,9 @@ import ( "reflect" "sort" "strings" - "sync" ) -func GetBoolExtension(pb Message, extension *ExtensionDesc, ifnotset bool) bool { +func GetBoolExtension(pb extendableProto, extension *ExtensionDesc, ifnotset bool) bool { if reflect.ValueOf(pb).IsNil() { return ifnotset } @@ -63,12 +60,8 @@ func (this *Extension) Compare(that *Extension) int { return bytes.Compare(this.enc, that.enc) } -func SizeOfInternalExtension(m extendableProto) (n int) { - return SizeOfExtensionMap(m.extensionsWrite()) -} - func SizeOfExtensionMap(m map[int32]Extension) (n int) { - return extensionsMapSize(m) + return sizeExtensionMap(m) } type sortableMapElem struct { @@ -101,10 +94,6 @@ func (this sortableExtensions) String() string { return "map[" + strings.Join(ss, ",") + "]" } -func StringFromInternalExtension(m extendableProto) string { - return StringFromExtensionsMap(m.extensionsWrite()) -} - func StringFromExtensionsMap(m map[int32]Extension) string { return newSortableExtensionsFromMap(m).String() } @@ -117,12 +106,8 @@ func StringFromExtensionsBytes(ext []byte) string { return StringFromExtensionsMap(m) } -func EncodeInternalExtension(m extendableProto, data []byte) (n int, err error) { - return EncodeExtensionMap(m.extensionsWrite(), data) -} - func EncodeExtensionMap(m map[int32]Extension, data []byte) (n int, err error) { - if err := encodeExtensionsMap(m); err != nil { + if err := encodeExtensionMap(m); err != nil { return 0, err } keys := make([]int, 0, len(m)) @@ -140,7 +125,7 @@ func GetRawExtension(m map[int32]Extension, id int32) ([]byte, error) { if m[id].value == nil || m[id].desc == nil { return m[id].enc, nil } - if err := encodeExtensionsMap(m); err != nil { + if err := encodeExtensionMap(m); err != nil { return nil, err } return m[id].enc, nil @@ -204,42 +189,15 @@ func NewExtension(e []byte) Extension { return ee } -func AppendExtension(e Message, tag int32, buf []byte) { - if ee, eok := e.(extensionsBytes); eok { +func AppendExtension(e extendableProto, tag int32, buf []byte) { + if ee, eok := e.(extensionsMap); eok { + ext := ee.ExtensionMap()[int32(tag)] // may be missing + ext.enc = append(ext.enc, buf...) + ee.ExtensionMap()[int32(tag)] = ext + } else if ee, eok := e.(extensionsBytes); eok { ext := ee.GetExtensions() *ext = append(*ext, buf...) - return } - if ee, eok := e.(extendableProto); eok { - m := ee.extensionsWrite() - ext := m[int32(tag)] // may be missing - ext.enc = append(ext.enc, buf...) - m[int32(tag)] = ext - } -} - -func encodeExtension(e *Extension) error { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - return nil - } - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - p := NewBuffer(nil) - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { - return err - } - e.enc = p.buf - return nil } func (this Extension) GoString() string { @@ -251,7 +209,7 @@ func (this Extension) GoString() string { return fmt.Sprintf("proto.NewExtension(%#v)", this.enc) } -func SetUnsafeExtension(pb Message, fieldNum int32, value interface{}) error { +func SetUnsafeExtension(pb extendableProto, fieldNum int32, value interface{}) error { typ := reflect.TypeOf(pb).Elem() ext, ok := extensionMaps[typ] if !ok { @@ -261,10 +219,10 @@ func SetUnsafeExtension(pb Message, fieldNum int32, value interface{}) error { if !ok { return errors.New("proto: bad extension number; not in declared ranges") } - return SetExtension(pb, desc, value) + return setExtension(pb, desc, value) } -func GetUnsafeExtension(pb Message, fieldNum int32) (interface{}, error) { +func GetUnsafeExtension(pb extendableProto, fieldNum int32) (interface{}, error) { typ := reflect.TypeOf(pb).Elem() ext, ok := extensionMaps[typ] if !ok { @@ -276,19 +234,3 @@ func GetUnsafeExtension(pb Message, fieldNum int32) (interface{}, error) { } return GetExtension(pb, desc) } - -func NewUnsafeXXX_InternalExtensions(m map[int32]Extension) XXX_InternalExtensions { - x := &XXX_InternalExtensions{ - p: new(struct { - mu sync.Mutex - extensionMap map[int32]Extension - }), - } - x.p.extensionMap = m - return *x -} - -func GetUnsafeExtensionsMap(extendable Message) map[int32]Extension { - pb := extendable.(extendableProto) - return pb.extensionsWrite() -} diff --git a/vendor/github.com/gogo/protobuf/proto/lib.go b/vendor/github.com/gogo/protobuf/proto/lib.go index 7580bb4..2e35ae2 100644 --- a/vendor/github.com/gogo/protobuf/proto/lib.go +++ b/vendor/github.com/gogo/protobuf/proto/lib.go @@ -308,7 +308,7 @@ func GetStats() Stats { return stats } // temporary Buffer and are fine for most applications. type Buffer struct { buf []byte // encode/decode byte stream - index int // read point + index int // write point // pools of basic types to amortize allocation. bools []bool @@ -889,10 +889,6 @@ func isProto3Zero(v reflect.Value) bool { return false } -// ProtoPackageIsVersion2 is referenced from generated protocol buffer files -// to assert that that code is compatible with this version of the proto package. -const GoGoProtoPackageIsVersion2 = true - // ProtoPackageIsVersion1 is referenced from generated protocol buffer files // to assert that that code is compatible with this version of the proto package. const GoGoProtoPackageIsVersion1 = true diff --git a/vendor/github.com/gogo/protobuf/proto/lib_gogo.go b/vendor/github.com/gogo/protobuf/proto/lib_gogo.go index 4b4f7c9..a6c2c06 100644 --- a/vendor/github.com/gogo/protobuf/proto/lib_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/lib_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are diff --git a/vendor/github.com/gogo/protobuf/proto/message_set.go b/vendor/github.com/gogo/protobuf/proto/message_set.go index fd982de..e25e01e 100644 --- a/vendor/github.com/gogo/protobuf/proto/message_set.go +++ b/vendor/github.com/gogo/protobuf/proto/message_set.go @@ -149,21 +149,9 @@ func skipVarint(buf []byte) []byte { // MarshalMessageSet encodes the extension map represented by m in the message set wire format. // It is called by generated Marshal methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSet(exts interface{}) ([]byte, error) { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - if err := encodeExtensions(exts); err != nil { - return nil, err - } - m, _ = exts.extensionsRead() - case map[int32]Extension: - if err := encodeExtensionsMap(exts); err != nil { - return nil, err - } - m = exts - default: - return nil, errors.New("proto: not an extension map") +func MarshalMessageSet(m map[int32]Extension) ([]byte, error) { + if err := encodeExtensionMap(m); err != nil { + return nil, err } // Sort extension IDs to provide a deterministic encoding. @@ -190,17 +178,7 @@ func MarshalMessageSet(exts interface{}) ([]byte, error) { // UnmarshalMessageSet decodes the extension map encoded in buf in the message set wire format. // It is called by generated Unmarshal methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSet(buf []byte, exts interface{}) error { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - m = exts.extensionsWrite() - case map[int32]Extension: - m = exts - default: - return errors.New("proto: not an extension map") - } - +func UnmarshalMessageSet(buf []byte, m map[int32]Extension) error { ms := new(messageSet) if err := Unmarshal(buf, ms); err != nil { return err @@ -231,16 +209,7 @@ func UnmarshalMessageSet(buf []byte, exts interface{}) error { // MarshalMessageSetJSON encodes the extension map represented by m in JSON format. // It is called by generated MarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSetJSON(exts interface{}) ([]byte, error) { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - m, _ = exts.extensionsRead() - case map[int32]Extension: - m = exts - default: - return nil, errors.New("proto: not an extension map") - } +func MarshalMessageSetJSON(m map[int32]Extension) ([]byte, error) { var b bytes.Buffer b.WriteByte('{') @@ -283,7 +252,7 @@ func MarshalMessageSetJSON(exts interface{}) ([]byte, error) { // UnmarshalMessageSetJSON decodes the extension map encoded in buf in JSON format. // It is called by generated UnmarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSetJSON(buf []byte, exts interface{}) error { +func UnmarshalMessageSetJSON(buf []byte, m map[int32]Extension) error { // Common-case fast path. if len(buf) == 0 || bytes.Equal(buf, []byte("{}")) { return nil diff --git a/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go b/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go index fb512e2..749919d 100644 --- a/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go +++ b/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go @@ -29,7 +29,7 @@ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -// +build appengine js +// +build appengine // This file contains an implementation of proto field accesses using package reflect. // It is slower than the code in pointer_unsafe.go but it avoids package unsafe and can @@ -139,11 +139,6 @@ func structPointer_StringSlice(p structPointer, f field) *[]string { return structPointer_ifield(p, f).(*[]string) } -// Extensions returns the address of an extension map field in the struct. -func structPointer_Extensions(p structPointer, f field) *XXX_InternalExtensions { - return structPointer_ifield(p, f).(*XXX_InternalExtensions) -} - // ExtMap returns the address of an extension map field in the struct. func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { return structPointer_ifield(p, f).(*map[int32]Extension) diff --git a/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go b/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go index 6b5567d..e9be0fe 100644 --- a/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go +++ b/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go @@ -29,7 +29,7 @@ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -// +build !appengine,!js +// +build !appengine // This file contains the implementation of the proto field accesses using package unsafe. @@ -126,10 +126,6 @@ func structPointer_StringSlice(p structPointer, f field) *[]string { } // ExtMap returns the address of an extension map field in the struct. -func structPointer_Extensions(p structPointer, f field) *XXX_InternalExtensions { - return (*XXX_InternalExtensions)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { return (*map[int32]Extension)(unsafe.Pointer(uintptr(p) + uintptr(f))) } diff --git a/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go b/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go index ad7c851..6bc85fa 100644 --- a/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are @@ -72,13 +70,16 @@ func structPointer_Copy(oldptr structPointer, newptr structPointer, size int) { func appendStructPointer(base structPointer, f field, typ reflect.Type) structPointer { size := typ.Elem().Size() - oldHeader := structPointer_GetSliceHeader(base, f) - oldSlice := reflect.NewAt(typ, unsafe.Pointer(oldHeader)).Elem() newLen := oldHeader.Len + 1 - newSlice := reflect.MakeSlice(typ, newLen, newLen) - reflect.Copy(newSlice, oldSlice) - bas := toStructPointer(newSlice) + slice := reflect.MakeSlice(typ, newLen, newLen) + bas := toStructPointer(slice) + for i := 0; i < oldHeader.Len; i++ { + newElemptr := uintptr(bas) + uintptr(i)*size + oldElemptr := oldHeader.Data + uintptr(i)*size + copyUintPtr(oldElemptr, newElemptr, int(size)) + } + oldHeader.Data = uintptr(bas) oldHeader.Len = newLen oldHeader.Cap = newLen diff --git a/vendor/github.com/gogo/protobuf/proto/properties.go b/vendor/github.com/gogo/protobuf/proto/properties.go index 44b3320..5e6a0b3 100644 --- a/vendor/github.com/gogo/protobuf/proto/properties.go +++ b/vendor/github.com/gogo/protobuf/proto/properties.go @@ -1,7 +1,7 @@ -// Protocol Buffers for Go with Gadgets +// Extensions for Protocol Buffers to create more go like structures. // -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Go support for Protocol Buffers - Google's data interchange format // @@ -190,11 +190,10 @@ type Properties struct { proto3 bool // whether this is known to be a proto3 field; set for []byte only oneof bool // whether this is a oneof field - Default string // default value - HasDefault bool // whether an explicit default was provided - CustomType string - StdTime bool - StdDuration bool + Default string // default value + HasDefault bool // whether an explicit default was provided + CustomType string + def_uint64 uint64 enc encoder valEnc valueEncoder // set for bool and numeric types only @@ -341,10 +340,6 @@ func (p *Properties) Parse(s string) { p.OrigName = strings.Split(f, "=")[1] case strings.HasPrefix(f, "customtype="): p.CustomType = strings.Split(f, "=")[1] - case f == "stdtime": - p.StdTime = true - case f == "stdduration": - p.StdDuration = true } } } @@ -360,22 +355,11 @@ func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lock p.enc = nil p.dec = nil p.size = nil - isMap := typ.Kind() == reflect.Map - if len(p.CustomType) > 0 && !isMap { + if len(p.CustomType) > 0 { p.setCustomEncAndDec(typ) p.setTag(lockGetProp) return } - if p.StdTime && !isMap { - p.setTimeEncAndDec(typ) - p.setTag(lockGetProp) - return - } - if p.StdDuration && !isMap { - p.setDurationEncAndDec(typ) - p.setTag(lockGetProp) - return - } switch t1 := typ; t1.Kind() { default: fmt.Fprintf(os.Stderr, "proto: no coders for %v\n", t1) @@ -558,13 +542,17 @@ func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lock p.dec = (*Buffer).dec_slice_int64 p.packedDec = (*Buffer).dec_slice_packed_int64 case reflect.Uint8: + p.enc = (*Buffer).enc_slice_byte p.dec = (*Buffer).dec_slice_byte - if p.proto3 { + p.size = size_slice_byte + // This is a []byte, which is either a bytes field, + // or the value of a map field. In the latter case, + // we always encode an empty []byte, so we should not + // use the proto3 enc/size funcs. + // f == nil iff this is the key/value of a map field. + if p.proto3 && f != nil { p.enc = (*Buffer).enc_proto3_slice_byte p.size = size_proto3_slice_byte - } else { - p.enc = (*Buffer).enc_slice_byte - p.size = size_slice_byte } case reflect.Float32, reflect.Float64: switch t2.Bits() { @@ -646,10 +634,6 @@ func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lock // so we need encoders for the pointer to this type. vtype = reflect.PtrTo(vtype) } - - p.mvalprop.CustomType = p.CustomType - p.mvalprop.StdDuration = p.StdDuration - p.mvalprop.StdTime = p.StdTime p.mvalprop.init(vtype, "Value", f.Tag.Get("protobuf_val"), nil, lockGetProp) } p.setTag(lockGetProp) @@ -760,9 +744,7 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { propertiesMap[t] = prop // build properties - prop.extendable = reflect.PtrTo(t).Implements(extendableProtoType) || - reflect.PtrTo(t).Implements(extendableProtoV1Type) || - reflect.PtrTo(t).Implements(extendableBytesType) + prop.extendable = reflect.PtrTo(t).Implements(extendableProtoType) prop.unrecField = invalidField prop.Prop = make([]*Properties, t.NumField()) prop.order = make([]int, t.NumField()) @@ -774,11 +756,7 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { name := f.Name p.init(f.Type, name, f.Tag.Get("protobuf"), &f, false) - if f.Name == "XXX_InternalExtensions" { // special case - p.enc = (*Buffer).enc_exts - p.dec = nil // not needed - p.size = size_exts - } else if f.Name == "XXX_extensions" { // special case + if f.Name == "XXX_extensions" { // special case if len(f.Tag.Get("protobuf")) > 0 { p.enc = (*Buffer).enc_ext_slice_byte p.dec = nil // not needed @@ -788,14 +766,13 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { p.dec = nil // not needed p.size = size_map } - } else if f.Name == "XXX_unrecognized" { // special case + } + if f.Name == "XXX_unrecognized" { // special case prop.unrecField = toField(&f) } - oneof := f.Tag.Get("protobuf_oneof") // special case - if oneof != "" { + oneof := f.Tag.Get("protobuf_oneof") != "" // special case + if oneof { isOneofMessage = true - // Oneof fields don't use the traditional protobuf tag. - p.OrigName = oneof } prop.Prop[i] = p prop.order[i] = i @@ -806,7 +783,7 @@ func getPropertiesLocked(t reflect.Type) *StructProperties { } print("\n") } - if p.enc == nil && !strings.HasPrefix(f.Name, "XXX_") && oneof == "" { + if p.enc == nil && !strings.HasPrefix(f.Name, "XXX_") && !oneof { fmt.Fprintln(os.Stderr, "proto: no encoder for", f.Name, f.Type.String(), "[GetProperties]") } } @@ -940,29 +917,7 @@ func RegisterType(x Message, name string) { } // MessageName returns the fully-qualified proto name for the given message type. -func MessageName(x Message) string { - type xname interface { - XXX_MessageName() string - } - if m, ok := x.(xname); ok { - return m.XXX_MessageName() - } - return revProtoTypes[reflect.TypeOf(x)] -} +func MessageName(x Message) string { return revProtoTypes[reflect.TypeOf(x)] } // MessageType returns the message type (pointer to struct) for a named message. func MessageType(name string) reflect.Type { return protoTypes[name] } - -// A registry of all linked proto files. -var ( - protoFiles = make(map[string][]byte) // file name => fileDescriptor -) - -// RegisterFile is called from generated code and maps from the -// full file name of a .proto file to its compressed FileDescriptorProto. -func RegisterFile(filename string, fileDescriptor []byte) { - protoFiles[filename] = fileDescriptor -} - -// FileDescriptor returns the compressed FileDescriptorProto for a .proto file. -func FileDescriptor(filename string) []byte { return protoFiles[filename] } diff --git a/vendor/github.com/gogo/protobuf/proto/properties_gogo.go b/vendor/github.com/gogo/protobuf/proto/properties_gogo.go index b6b7176..8daf9f7 100644 --- a/vendor/github.com/gogo/protobuf/proto/properties_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/properties_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are @@ -51,51 +49,6 @@ func (p *Properties) setCustomEncAndDec(typ reflect.Type) { } } -func (p *Properties) setDurationEncAndDec(typ reflect.Type) { - if p.Repeated { - if typ.Elem().Kind() == reflect.Ptr { - p.enc = (*Buffer).enc_slice_duration - p.dec = (*Buffer).dec_slice_duration - p.size = size_slice_duration - } else { - p.enc = (*Buffer).enc_slice_ref_duration - p.dec = (*Buffer).dec_slice_ref_duration - p.size = size_slice_ref_duration - } - } else if typ.Kind() == reflect.Ptr { - p.enc = (*Buffer).enc_duration - p.dec = (*Buffer).dec_duration - p.size = size_duration - } else { - p.enc = (*Buffer).enc_ref_duration - p.dec = (*Buffer).dec_ref_duration - p.size = size_ref_duration - } -} - -func (p *Properties) setTimeEncAndDec(typ reflect.Type) { - if p.Repeated { - if typ.Elem().Kind() == reflect.Ptr { - p.enc = (*Buffer).enc_slice_time - p.dec = (*Buffer).dec_slice_time - p.size = size_slice_time - } else { - p.enc = (*Buffer).enc_slice_ref_time - p.dec = (*Buffer).dec_slice_ref_time - p.size = size_slice_ref_time - } - } else if typ.Kind() == reflect.Ptr { - p.enc = (*Buffer).enc_time - p.dec = (*Buffer).dec_time - p.size = size_time - } else { - p.enc = (*Buffer).enc_ref_time - p.dec = (*Buffer).dec_ref_time - p.size = size_ref_time - } - -} - func (p *Properties) setSliceOfNonPointerStructs(typ reflect.Type) { t2 := typ.Elem() p.sstype = typ diff --git a/vendor/github.com/gogo/protobuf/proto/skip_gogo.go b/vendor/github.com/gogo/protobuf/proto/skip_gogo.go index 5a5fd93..4fe7e08 100644 --- a/vendor/github.com/gogo/protobuf/proto/skip_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/skip_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are diff --git a/vendor/github.com/gogo/protobuf/proto/text.go b/vendor/github.com/gogo/protobuf/proto/text.go index d63732f..b60be28 100644 --- a/vendor/github.com/gogo/protobuf/proto/text.go +++ b/vendor/github.com/gogo/protobuf/proto/text.go @@ -1,7 +1,7 @@ -// Protocol Buffers for Go with Gadgets +// Extensions for Protocol Buffers to create more go like structures. // -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Go support for Protocol Buffers - Google's data interchange format // @@ -50,8 +50,6 @@ import ( "reflect" "sort" "strings" - "sync" - "time" ) var ( @@ -161,7 +159,7 @@ func (w *textWriter) indent() { w.ind++ } func (w *textWriter) unindent() { if w.ind == 0 { - log.Print("proto: textWriter unindented too far") + log.Printf("proto: textWriter unindented too far") return } w.ind-- @@ -182,93 +180,7 @@ type raw interface { Bytes() []byte } -func requiresQuotes(u string) bool { - // When type URL contains any characters except [0-9A-Za-z./\-]*, it must be quoted. - for _, ch := range u { - switch { - case ch == '.' || ch == '/' || ch == '_': - continue - case '0' <= ch && ch <= '9': - continue - case 'A' <= ch && ch <= 'Z': - continue - case 'a' <= ch && ch <= 'z': - continue - default: - return true - } - } - return false -} - -// isAny reports whether sv is a google.protobuf.Any message -func isAny(sv reflect.Value) bool { - type wkt interface { - XXX_WellKnownType() string - } - t, ok := sv.Addr().Interface().(wkt) - return ok && t.XXX_WellKnownType() == "Any" -} - -// writeProto3Any writes an expanded google.protobuf.Any message. -// -// It returns (false, nil) if sv value can't be unmarshaled (e.g. because -// required messages are not linked in). -// -// It returns (true, error) when sv was written in expanded format or an error -// was encountered. -func (tm *TextMarshaler) writeProto3Any(w *textWriter, sv reflect.Value) (bool, error) { - turl := sv.FieldByName("TypeUrl") - val := sv.FieldByName("Value") - if !turl.IsValid() || !val.IsValid() { - return true, errors.New("proto: invalid google.protobuf.Any message") - } - - b, ok := val.Interface().([]byte) - if !ok { - return true, errors.New("proto: invalid google.protobuf.Any message") - } - - parts := strings.Split(turl.String(), "/") - mt := MessageType(parts[len(parts)-1]) - if mt == nil { - return false, nil - } - m := reflect.New(mt.Elem()) - if err := Unmarshal(b, m.Interface().(Message)); err != nil { - return false, nil - } - w.Write([]byte("[")) - u := turl.String() - if requiresQuotes(u) { - writeString(w, u) - } else { - w.Write([]byte(u)) - } - if w.compact { - w.Write([]byte("]:<")) - } else { - w.Write([]byte("]: <\n")) - w.ind++ - } - if err := tm.writeStruct(w, m.Elem()); err != nil { - return true, err - } - if w.compact { - w.Write([]byte("> ")) - } else { - w.ind-- - w.Write([]byte(">\n")) - } - return true, nil -} - -func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { - if tm.ExpandAny && isAny(sv) { - if canExpand, err := tm.writeProto3Any(w, sv); canExpand { - return err - } - } +func writeStruct(w *textWriter, sv reflect.Value) error { st := sv.Type() sprops := GetProperties(st) for i := 0; i < sv.NumField(); i++ { @@ -321,10 +233,10 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { continue } if len(props.Enum) > 0 { - if err := tm.writeEnum(w, v, props); err != nil { + if err := writeEnum(w, v, props); err != nil { return err } - } else if err := tm.writeAny(w, v, props); err != nil { + } else if err := writeAny(w, v, props); err != nil { return err } if err := w.WriteByte('\n'); err != nil { @@ -366,7 +278,7 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { return err } } - if err := tm.writeAny(w, key, props.mkeyprop); err != nil { + if err := writeAny(w, key, props.mkeyprop); err != nil { return err } if err := w.WriteByte('\n'); err != nil { @@ -383,7 +295,7 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { return err } } - if err := tm.writeAny(w, val, props.mvalprop); err != nil { + if err := writeAny(w, val, props.mvalprop); err != nil { return err } if err := w.WriteByte('\n'); err != nil { @@ -455,10 +367,10 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { } if len(props.Enum) > 0 { - if err := tm.writeEnum(w, fv, props); err != nil { + if err := writeEnum(w, fv, props); err != nil { return err } - } else if err := tm.writeAny(w, fv, props); err != nil { + } else if err := writeAny(w, fv, props); err != nil { return err } @@ -475,8 +387,8 @@ func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { pv = reflect.New(sv.Type()) pv.Elem().Set(sv) } - if pv.Type().Implements(extensionRangeType) { - if err := tm.writeExtensions(w, pv); err != nil { + if pv.Type().Implements(extendableProtoType) { + if err := writeExtensions(w, pv); err != nil { return err } } @@ -506,45 +418,20 @@ func writeRaw(w *textWriter, b []byte) error { } // writeAny writes an arbitrary field. -func (tm *TextMarshaler) writeAny(w *textWriter, v reflect.Value, props *Properties) error { +func writeAny(w *textWriter, v reflect.Value, props *Properties) error { v = reflect.Indirect(v) - if props != nil { - if len(props.CustomType) > 0 { - custom, ok := v.Interface().(Marshaler) - if ok { - data, err := custom.Marshal() - if err != nil { - return err - } - if err := writeString(w, string(data)); err != nil { - return err - } - return nil - } - } else if props.StdTime { - t, ok := v.Interface().(time.Time) - if !ok { - return fmt.Errorf("stdtime is not time.Time, but %T", v.Interface()) - } - tproto, err := timestampProto(t) + if props != nil && len(props.CustomType) > 0 { + custom, ok := v.Interface().(Marshaler) + if ok { + data, err := custom.Marshal() if err != nil { return err } - props.StdTime = false - err = tm.writeAny(w, reflect.ValueOf(tproto), props) - props.StdTime = true - return err - } else if props.StdDuration { - d, ok := v.Interface().(time.Duration) - if !ok { - return fmt.Errorf("stdtime is not time.Duration, but %T", v.Interface()) + if err := writeString(w, string(data)); err != nil { + return err } - dproto := durationProto(d) - props.StdDuration = false - err := tm.writeAny(w, reflect.ValueOf(dproto), props) - props.StdDuration = true - return err + return nil } } @@ -594,15 +481,15 @@ func (tm *TextMarshaler) writeAny(w *textWriter, v reflect.Value, props *Propert } } w.indent() - if etm, ok := v.Interface().(encoding.TextMarshaler); ok { - text, err := etm.MarshalText() + if tm, ok := v.Interface().(encoding.TextMarshaler); ok { + text, err := tm.MarshalText() if err != nil { return err } if _, err = w.Write(text); err != nil { return err } - } else if err := tm.writeStruct(w, v); err != nil { + } else if err := writeStruct(w, v); err != nil { return err } w.unindent() @@ -746,39 +633,30 @@ func (s int32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] } // writeExtensions writes all the extensions in pv. // pv is assumed to be a pointer to a protocol message struct that is extendable. -func (tm *TextMarshaler) writeExtensions(w *textWriter, pv reflect.Value) error { +func writeExtensions(w *textWriter, pv reflect.Value) error { emap := extensionMaps[pv.Type().Elem()] - e := pv.Interface().(Message) + ep := pv.Interface().(extendableProto) + // Order the extensions by ID. + // This isn't strictly necessary, but it will give us + // canonical output, which will also make testing easier. var m map[int32]Extension - var mu sync.Locker - if em, ok := e.(extensionsBytes); ok { + if em, ok := ep.(extensionsMap); ok { + m = em.ExtensionMap() + } else if em, ok := ep.(extensionsBytes); ok { eb := em.GetExtensions() var err error m, err = BytesToExtensionsMap(*eb) if err != nil { return err } - mu = notLocker{} - } else if _, ok := e.(extendableProto); ok { - ep, _ := extendable(e) - m, mu = ep.extensionsRead() - if m == nil { - return nil - } } - // Order the extensions by ID. - // This isn't strictly necessary, but it will give us - // canonical output, which will also make testing easier. - - mu.Lock() ids := make([]int32, 0, len(m)) for id := range m { ids = append(ids, id) } sort.Sort(int32Slice(ids)) - mu.Unlock() for _, extNum := range ids { ext := m[extNum] @@ -794,20 +672,20 @@ func (tm *TextMarshaler) writeExtensions(w *textWriter, pv reflect.Value) error continue } - pb, err := GetExtension(e, desc) + pb, err := GetExtension(ep, desc) if err != nil { return fmt.Errorf("failed getting extension: %v", err) } // Repeated extensions will appear as a slice. if !desc.repeated() { - if err := tm.writeExtension(w, desc.Name, pb); err != nil { + if err := writeExtension(w, desc.Name, pb); err != nil { return err } } else { v := reflect.ValueOf(pb) for i := 0; i < v.Len(); i++ { - if err := tm.writeExtension(w, desc.Name, v.Index(i).Interface()); err != nil { + if err := writeExtension(w, desc.Name, v.Index(i).Interface()); err != nil { return err } } @@ -816,7 +694,7 @@ func (tm *TextMarshaler) writeExtensions(w *textWriter, pv reflect.Value) error return nil } -func (tm *TextMarshaler) writeExtension(w *textWriter, name string, pb interface{}) error { +func writeExtension(w *textWriter, name string, pb interface{}) error { if _, err := fmt.Fprintf(w, "[%s]:", name); err != nil { return err } @@ -825,7 +703,7 @@ func (tm *TextMarshaler) writeExtension(w *textWriter, name string, pb interface return err } } - if err := tm.writeAny(w, reflect.ValueOf(pb), nil); err != nil { + if err := writeAny(w, reflect.ValueOf(pb), nil); err != nil { return err } if err := w.WriteByte('\n'); err != nil { @@ -852,13 +730,12 @@ func (w *textWriter) writeIndent() { // TextMarshaler is a configurable text format marshaler. type TextMarshaler struct { - Compact bool // use compact text format (one line). - ExpandAny bool // expand google.protobuf.Any messages of known types + Compact bool // use compact text format (one line). } // Marshal writes a given protocol buffer in text format. // The only errors returned are from w. -func (tm *TextMarshaler) Marshal(w io.Writer, pb Message) error { +func (m *TextMarshaler) Marshal(w io.Writer, pb Message) error { val := reflect.ValueOf(pb) if pb == nil || val.IsNil() { w.Write([]byte("")) @@ -873,11 +750,11 @@ func (tm *TextMarshaler) Marshal(w io.Writer, pb Message) error { aw := &textWriter{ w: ww, complete: true, - compact: tm.Compact, + compact: m.Compact, } - if etm, ok := pb.(encoding.TextMarshaler); ok { - text, err := etm.MarshalText() + if tm, ok := pb.(encoding.TextMarshaler); ok { + text, err := tm.MarshalText() if err != nil { return err } @@ -891,7 +768,7 @@ func (tm *TextMarshaler) Marshal(w io.Writer, pb Message) error { } // Dereference the received pointer so we don't have outer < and >. v := reflect.Indirect(val) - if err := tm.writeStruct(aw, v); err != nil { + if err := writeStruct(aw, v); err != nil { return err } if bw != nil { @@ -901,9 +778,9 @@ func (tm *TextMarshaler) Marshal(w io.Writer, pb Message) error { } // Text is the same as Marshal, but returns the string directly. -func (tm *TextMarshaler) Text(pb Message) string { +func (m *TextMarshaler) Text(pb Message) string { var buf bytes.Buffer - tm.Marshal(&buf, pb) + m.Marshal(&buf, pb) return buf.String() } diff --git a/vendor/github.com/gogo/protobuf/proto/text_gogo.go b/vendor/github.com/gogo/protobuf/proto/text_gogo.go index 1d6c6aa..cdb2337 100644 --- a/vendor/github.com/gogo/protobuf/proto/text_gogo.go +++ b/vendor/github.com/gogo/protobuf/proto/text_gogo.go @@ -1,7 +1,5 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are @@ -33,10 +31,10 @@ import ( "reflect" ) -func (tm *TextMarshaler) writeEnum(w *textWriter, v reflect.Value, props *Properties) error { +func writeEnum(w *textWriter, v reflect.Value, props *Properties) error { m, ok := enumStringMaps[props.Enum] if !ok { - if err := tm.writeAny(w, v, props); err != nil { + if err := writeAny(w, v, props); err != nil { return err } } @@ -48,7 +46,7 @@ func (tm *TextMarshaler) writeEnum(w *textWriter, v reflect.Value, props *Proper } s, ok := m[key] if !ok { - if err := tm.writeAny(w, v, props); err != nil { + if err := writeAny(w, v, props); err != nil { return err } } diff --git a/vendor/github.com/gogo/protobuf/proto/text_parser.go b/vendor/github.com/gogo/protobuf/proto/text_parser.go index 39b19f4..61b4bc8 100644 --- a/vendor/github.com/gogo/protobuf/proto/text_parser.go +++ b/vendor/github.com/gogo/protobuf/proto/text_parser.go @@ -1,7 +1,7 @@ -// Protocol Buffers for Go with Gadgets +// Extensions for Protocol Buffers to create more go like structures. // -// Copyright (c) 2013, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. +// http://github.com/gogo/protobuf/gogoproto // // Go support for Protocol Buffers - Google's data interchange format // @@ -46,13 +46,9 @@ import ( "reflect" "strconv" "strings" - "time" "unicode/utf8" ) -// Error string emitted when deserializing Any and fields are already set -const anyRepeatedlyUnpacked = "Any message unpacked multiple times, or %q already set" - type ParseError struct { Message string Line int // 1-based line number @@ -172,7 +168,7 @@ func (p *textParser) advance() { p.cur.offset, p.cur.line = p.offset, p.line p.cur.unquoted = "" switch p.s[0] { - case '<', '>', '{', '}', ':', '[', ']', ';', ',', '/': + case '<', '>', '{', '}', ':', '[', ']', ';', ',': // Single symbol p.cur.value, p.s = p.s[0:1], p.s[1:len(p.s)] case '"', '\'': @@ -460,10 +456,7 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { fieldSet := make(map[string]bool) // A struct is a sequence of "name: value", terminated by one of // '>' or '}', or the end of the input. A name may also be - // "[extension]" or "[type/url]". - // - // The whole struct can also be an expanded Any message, like: - // [type/url] < ... struct contents ... > + // "[extension]". for { tok := p.next() if tok.err != nil { @@ -473,74 +466,33 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { break } if tok.value == "[" { - // Looks like an extension or an Any. + // Looks like an extension. // // TODO: Check whether we need to handle // namespace rooted names (e.g. ".something.Foo"). - extName, err := p.consumeExtName() - if err != nil { - return err + tok = p.next() + if tok.err != nil { + return tok.err } - - if s := strings.LastIndex(extName, "/"); s >= 0 { - // If it contains a slash, it's an Any type URL. - messageName := extName[s+1:] - mt := MessageType(messageName) - if mt == nil { - return p.errorf("unrecognized message %q in google.protobuf.Any", messageName) - } - tok = p.next() - if tok.err != nil { - return tok.err - } - // consume an optional colon - if tok.value == ":" { - tok = p.next() - if tok.err != nil { - return tok.err - } - } - var terminator string - switch tok.value { - case "<": - terminator = ">" - case "{": - terminator = "}" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - v := reflect.New(mt.Elem()) - if pe := p.readStruct(v.Elem(), terminator); pe != nil { - return pe - } - b, err := Marshal(v.Interface().(Message)) - if err != nil { - return p.errorf("failed to marshal message of type %q: %v", messageName, err) - } - if fieldSet["type_url"] { - return p.errorf(anyRepeatedlyUnpacked, "type_url") - } - if fieldSet["value"] { - return p.errorf(anyRepeatedlyUnpacked, "value") - } - sv.FieldByName("TypeUrl").SetString(extName) - sv.FieldByName("Value").SetBytes(b) - fieldSet["type_url"] = true - fieldSet["value"] = true - continue - } - var desc *ExtensionDesc // This could be faster, but it's functional. // TODO: Do something smarter than a linear scan. for _, d := range RegisteredExtensions(reflect.New(st).Interface().(Message)) { - if d.Name == extName { + if d.Name == tok.value { desc = d break } } if desc == nil { - return p.errorf("unrecognized extension %q", extName) + return p.errorf("unrecognized extension %q", tok.value) + } + // Check the extension terminator. + tok = p.next() + if tok.err != nil { + return tok.err + } + if tok.value != "]" { + return p.errorf("unrecognized extension terminator %q", tok.value) } props := &Properties{} @@ -567,7 +519,7 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { } reqFieldErr = err } - ep := sv.Addr().Interface().(Message) + ep := sv.Addr().Interface().(extendableProto) if !rep { SetExtension(ep, desc, ext.Interface()) } else { @@ -619,9 +571,8 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { // The map entry should be this sequence of tokens: // < key : KEY value : VALUE > - // However, implementations may omit key or value, and technically - // we should support them in any order. See b/28924776 for a time - // this went wrong. + // Technically the "key" and "value" could come in any order, + // but in practice they won't. tok := p.next() var terminator string @@ -633,39 +584,32 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { default: return p.errorf("expected '{' or '<', found %q", tok.value) } - for { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == terminator { - break - } - switch tok.value { - case "key": - if err := p.consumeToken(":"); err != nil { - return err - } - if err := p.readAny(key, props.mkeyprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - case "value": - if err := p.checkForColon(props.mvalprop, dst.Type().Elem()); err != nil { - return err - } - if err := p.readAny(val, props.mvalprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - default: - p.back() - return p.errorf(`expected "key", "value", or %q, found %q`, terminator, tok.value) - } + if err := p.consumeToken("key"); err != nil { + return err + } + if err := p.consumeToken(":"); err != nil { + return err + } + if err := p.readAny(key, props.mkeyprop); err != nil { + return err + } + if err := p.consumeOptionalSeparator(); err != nil { + return err + } + if err := p.consumeToken("value"); err != nil { + return err + } + if err := p.checkForColon(props.mvalprop, dst.Type().Elem()); err != nil { + return err + } + if err := p.readAny(val, props.mvalprop); err != nil { + return err + } + if err := p.consumeOptionalSeparator(); err != nil { + return err + } + if err := p.consumeToken(terminator); err != nil { + return err } dst.SetMapIndex(key, val) @@ -688,8 +632,7 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { return err } reqFieldErr = err - } - if props.Required { + } else if props.Required { reqCount-- } @@ -705,35 +648,6 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { return reqFieldErr } -// consumeExtName consumes extension name or expanded Any type URL and the -// following ']'. It returns the name or URL consumed. -func (p *textParser) consumeExtName() (string, error) { - tok := p.next() - if tok.err != nil { - return "", tok.err - } - - // If extension name or type url is quoted, it's a single token. - if len(tok.value) > 2 && isQuote(tok.value[0]) && tok.value[len(tok.value)-1] == tok.value[0] { - name, err := unquoteC(tok.value[1:len(tok.value)-1], rune(tok.value[0])) - if err != nil { - return "", err - } - return name, p.consumeToken("]") - } - - // Consume everything up to "]" - var parts []string - for tok.value != "]" { - parts = append(parts, tok.value) - tok = p.next() - if tok.err != nil { - return "", p.errorf("unrecognized type_url or extension name: %s", tok.err) - } - } - return strings.Join(parts, ""), nil -} - // consumeOptionalSeparator consumes an optional semicolon or comma. // It is used in readStruct to provide backward compatibility. func (p *textParser) consumeOptionalSeparator() error { @@ -794,80 +708,6 @@ func (p *textParser) readAny(v reflect.Value, props *Properties) error { } return nil } - if props.StdTime { - fv := v - p.back() - props.StdTime = false - tproto := ×tamp{} - err := p.readAny(reflect.ValueOf(tproto).Elem(), props) - props.StdTime = true - if err != nil { - return err - } - tim, err := timestampFromProto(tproto) - if err != nil { - return err - } - if props.Repeated { - t := reflect.TypeOf(v.Interface()) - if t.Kind() == reflect.Slice { - if t.Elem().Kind() == reflect.Ptr { - ts := fv.Interface().([]*time.Time) - ts = append(ts, &tim) - fv.Set(reflect.ValueOf(ts)) - return nil - } else { - ts := fv.Interface().([]time.Time) - ts = append(ts, tim) - fv.Set(reflect.ValueOf(ts)) - return nil - } - } - } - if reflect.TypeOf(v.Interface()).Kind() == reflect.Ptr { - v.Set(reflect.ValueOf(&tim)) - } else { - v.Set(reflect.Indirect(reflect.ValueOf(&tim))) - } - return nil - } - if props.StdDuration { - fv := v - p.back() - props.StdDuration = false - dproto := &duration{} - err := p.readAny(reflect.ValueOf(dproto).Elem(), props) - props.StdDuration = true - if err != nil { - return err - } - dur, err := durationFromProto(dproto) - if err != nil { - return err - } - if props.Repeated { - t := reflect.TypeOf(v.Interface()) - if t.Kind() == reflect.Slice { - if t.Elem().Kind() == reflect.Ptr { - ds := fv.Interface().([]*time.Duration) - ds = append(ds, &dur) - fv.Set(reflect.ValueOf(ds)) - return nil - } else { - ds := fv.Interface().([]time.Duration) - ds = append(ds, dur) - fv.Set(reflect.ValueOf(ds)) - return nil - } - } - } - if reflect.TypeOf(v.Interface()).Kind() == reflect.Ptr { - v.Set(reflect.ValueOf(&dur)) - } else { - v.Set(reflect.Indirect(reflect.ValueOf(&dur))) - } - return nil - } switch fv := v; fv.Kind() { case reflect.Slice: at := v.Type() @@ -910,12 +750,12 @@ func (p *textParser) readAny(v reflect.Value, props *Properties) error { fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) return p.readAny(fv.Index(fv.Len()-1), props) case reflect.Bool: - // true/1/t/True or false/f/0/False. + // Either "true", "false", 1 or 0. switch tok.value { - case "true", "1", "t", "True": + case "true", "1": fv.SetBool(true) return nil - case "false", "0", "f", "False": + case "false", "0": fv.SetBool(false) return nil } diff --git a/vendor/github.com/gogo/protobuf/proto/timestamp.go b/vendor/github.com/gogo/protobuf/proto/timestamp.go deleted file mode 100644 index 9324f65..0000000 --- a/vendor/github.com/gogo/protobuf/proto/timestamp.go +++ /dev/null @@ -1,113 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2016 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// This file implements operations on google.protobuf.Timestamp. - -import ( - "errors" - "fmt" - "time" -) - -const ( - // Seconds field of the earliest valid Timestamp. - // This is time.Date(1, 1, 1, 0, 0, 0, 0, time.UTC).Unix(). - minValidSeconds = -62135596800 - // Seconds field just after the latest valid Timestamp. - // This is time.Date(10000, 1, 1, 0, 0, 0, 0, time.UTC).Unix(). - maxValidSeconds = 253402300800 -) - -// validateTimestamp determines whether a Timestamp is valid. -// A valid timestamp represents a time in the range -// [0001-01-01, 10000-01-01) and has a Nanos field -// in the range [0, 1e9). -// -// If the Timestamp is valid, validateTimestamp returns nil. -// Otherwise, it returns an error that describes -// the problem. -// -// Every valid Timestamp can be represented by a time.Time, but the converse is not true. -func validateTimestamp(ts *timestamp) error { - if ts == nil { - return errors.New("timestamp: nil Timestamp") - } - if ts.Seconds < minValidSeconds { - return fmt.Errorf("timestamp: %#v before 0001-01-01", ts) - } - if ts.Seconds >= maxValidSeconds { - return fmt.Errorf("timestamp: %#v after 10000-01-01", ts) - } - if ts.Nanos < 0 || ts.Nanos >= 1e9 { - return fmt.Errorf("timestamp: %#v: nanos not in range [0, 1e9)", ts) - } - return nil -} - -// TimestampFromProto converts a google.protobuf.Timestamp proto to a time.Time. -// It returns an error if the argument is invalid. -// -// Unlike most Go functions, if Timestamp returns an error, the first return value -// is not the zero time.Time. Instead, it is the value obtained from the -// time.Unix function when passed the contents of the Timestamp, in the UTC -// locale. This may or may not be a meaningful time; many invalid Timestamps -// do map to valid time.Times. -// -// A nil Timestamp returns an error. The first return value in that case is -// undefined. -func timestampFromProto(ts *timestamp) (time.Time, error) { - // Don't return the zero value on error, because corresponds to a valid - // timestamp. Instead return whatever time.Unix gives us. - var t time.Time - if ts == nil { - t = time.Unix(0, 0).UTC() // treat nil like the empty Timestamp - } else { - t = time.Unix(ts.Seconds, int64(ts.Nanos)).UTC() - } - return t, validateTimestamp(ts) -} - -// TimestampProto converts the time.Time to a google.protobuf.Timestamp proto. -// It returns an error if the resulting Timestamp is invalid. -func timestampProto(t time.Time) (*timestamp, error) { - seconds := t.Unix() - nanos := int32(t.Sub(time.Unix(seconds, 0))) - ts := ×tamp{ - Seconds: seconds, - Nanos: nanos, - } - if err := validateTimestamp(ts); err != nil { - return nil, err - } - return ts, nil -} diff --git a/vendor/github.com/gogo/protobuf/proto/timestamp_gogo.go b/vendor/github.com/gogo/protobuf/proto/timestamp_gogo.go deleted file mode 100644 index 526ccf3..0000000 --- a/vendor/github.com/gogo/protobuf/proto/timestamp_gogo.go +++ /dev/null @@ -1,227 +0,0 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2016, The GoGo Authors. All rights reserved. -// http://github.com/gogo/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "reflect" - "time" -) - -var timeType = reflect.TypeOf((*time.Time)(nil)).Elem() - -type timestamp struct { - Seconds int64 `protobuf:"varint,1,opt,name=seconds,proto3" json:"seconds,omitempty"` - Nanos int32 `protobuf:"varint,2,opt,name=nanos,proto3" json:"nanos,omitempty"` -} - -func (m *timestamp) Reset() { *m = timestamp{} } -func (*timestamp) ProtoMessage() {} -func (*timestamp) String() string { return "timestamp" } - -func init() { - RegisterType((*timestamp)(nil), "gogo.protobuf.proto.timestamp") -} - -func (o *Buffer) decTimestamp() (time.Time, error) { - b, err := o.DecodeRawBytes(true) - if err != nil { - return time.Time{}, err - } - tproto := ×tamp{} - if err := Unmarshal(b, tproto); err != nil { - return time.Time{}, err - } - return timestampFromProto(tproto) -} - -func (o *Buffer) dec_time(p *Properties, base structPointer) error { - t, err := o.decTimestamp() - if err != nil { - return err - } - setPtrCustomType(base, p.field, &t) - return nil -} - -func (o *Buffer) dec_ref_time(p *Properties, base structPointer) error { - t, err := o.decTimestamp() - if err != nil { - return err - } - setCustomType(base, p.field, &t) - return nil -} - -func (o *Buffer) dec_slice_time(p *Properties, base structPointer) error { - t, err := o.decTimestamp() - if err != nil { - return err - } - newBas := appendStructPointer(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType))) - setPtrCustomType(newBas, 0, &t) - return nil -} - -func (o *Buffer) dec_slice_ref_time(p *Properties, base structPointer) error { - t, err := o.decTimestamp() - if err != nil { - return err - } - newBas := appendStructPointer(base, p.field, reflect.SliceOf(timeType)) - setCustomType(newBas, 0, &t) - return nil -} - -func size_time(p *Properties, base structPointer) (n int) { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return 0 - } - tim := structPointer_Interface(structp, timeType).(*time.Time) - t, err := timestampProto(*tim) - if err != nil { - return 0 - } - size := Size(t) - return size + sizeVarint(uint64(size)) + len(p.tagcode) -} - -func (o *Buffer) enc_time(p *Properties, base structPointer) error { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return ErrNil - } - tim := structPointer_Interface(structp, timeType).(*time.Time) - t, err := timestampProto(*tim) - if err != nil { - return err - } - data, err := Marshal(t) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_ref_time(p *Properties, base structPointer) (n int) { - tim := structPointer_InterfaceAt(base, p.field, timeType).(*time.Time) - t, err := timestampProto(*tim) - if err != nil { - return 0 - } - size := Size(t) - return size + sizeVarint(uint64(size)) + len(p.tagcode) -} - -func (o *Buffer) enc_ref_time(p *Properties, base structPointer) error { - tim := structPointer_InterfaceAt(base, p.field, timeType).(*time.Time) - t, err := timestampProto(*tim) - if err != nil { - return err - } - data, err := Marshal(t) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_slice_time(p *Properties, base structPointer) (n int) { - ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType))).(*[]*time.Time) - tims := *ptims - for i := 0; i < len(tims); i++ { - if tims[i] == nil { - return 0 - } - tproto, err := timestampProto(*tims[i]) - if err != nil { - return 0 - } - size := Size(tproto) - n += len(p.tagcode) + size + sizeVarint(uint64(size)) - } - return n -} - -func (o *Buffer) enc_slice_time(p *Properties, base structPointer) error { - ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType))).(*[]*time.Time) - tims := *ptims - for i := 0; i < len(tims); i++ { - if tims[i] == nil { - return errRepeatedHasNil - } - tproto, err := timestampProto(*tims[i]) - if err != nil { - return err - } - data, err := Marshal(tproto) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - } - return nil -} - -func size_slice_ref_time(p *Properties, base structPointer) (n int) { - ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(timeType)).(*[]time.Time) - tims := *ptims - for i := 0; i < len(tims); i++ { - tproto, err := timestampProto(tims[i]) - if err != nil { - return 0 - } - size := Size(tproto) - n += len(p.tagcode) + size + sizeVarint(uint64(size)) - } - return n -} - -func (o *Buffer) enc_slice_ref_time(p *Properties, base structPointer) error { - ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(timeType)).(*[]time.Time) - tims := *ptims - for i := 0; i < len(tims); i++ { - tproto, err := timestampProto(tims[i]) - if err != nil { - return err - } - data, err := Marshal(tproto) - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - } - return nil -} diff --git a/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go b/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go index ceadde6..c52878d 100644 --- a/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go +++ b/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go @@ -1,6 +1,4 @@ -// Protocol Buffers for Go with Gadgets -// -// Copyright (c) 2013, The GoGo Authors. All rights reserved. +// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. // http://github.com/gogo/protobuf // // Redistribution and use in source and binary forms, with or without diff --git a/vendor/github.com/golang/glog/README b/vendor/github.com/golang/glog/README index 387b4eb..5f9c114 100644 --- a/vendor/github.com/golang/glog/README +++ b/vendor/github.com/golang/glog/README @@ -5,7 +5,7 @@ Leveled execution logs for Go. This is an efficient pure Go implementation of leveled logs in the manner of the open source C++ package - https://github.com/google/glog + http://code.google.com/p/google-glog By binding methods to booleans it is possible to use the log package without paying the expense of evaluating the arguments to the log. diff --git a/vendor/github.com/golang/glog/glog.go b/vendor/github.com/golang/glog/glog.go index 54bd7af..3e63fff 100644 --- a/vendor/github.com/golang/glog/glog.go +++ b/vendor/github.com/golang/glog/glog.go @@ -676,10 +676,7 @@ func (l *loggingT) output(s severity, buf *buffer, file string, line int, alsoTo } } data := buf.Bytes() - if !flag.Parsed() { - os.Stderr.Write([]byte("ERROR: logging before flag.Parse: ")) - os.Stderr.Write(data) - } else if l.toStderr { + if l.toStderr { os.Stderr.Write(data) } else { if alsoToStderr || l.alsoToStderr || s >= l.stderrThreshold.get() { diff --git a/vendor/github.com/golang/protobuf/proto/decode.go b/vendor/github.com/golang/protobuf/proto/decode.go index aa20729..07288a2 100644 --- a/vendor/github.com/golang/protobuf/proto/decode.go +++ b/vendor/github.com/golang/protobuf/proto/decode.go @@ -61,6 +61,7 @@ var ErrInternalBadWireType = errors.New("proto: internal error: bad wiretype for // int32, int64, uint32, uint64, bool, and enum // protocol buffer types. func DecodeVarint(buf []byte) (x uint64, n int) { + // x, n already 0 for shift := uint(0); shift < 64; shift += 7 { if n >= len(buf) { return 0, 0 @@ -77,7 +78,13 @@ func DecodeVarint(buf []byte) (x uint64, n int) { return 0, 0 } -func (p *Buffer) decodeVarintSlow() (x uint64, err error) { +// DecodeVarint reads a varint-encoded integer from the Buffer. +// This is the format for the +// int32, int64, uint32, uint64, bool, and enum +// protocol buffer types. +func (p *Buffer) DecodeVarint() (x uint64, err error) { + // x, err already 0 + i := p.index l := len(p.buf) @@ -100,107 +107,6 @@ func (p *Buffer) decodeVarintSlow() (x uint64, err error) { return } -// DecodeVarint reads a varint-encoded integer from the Buffer. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func (p *Buffer) DecodeVarint() (x uint64, err error) { - i := p.index - buf := p.buf - - if i >= len(buf) { - return 0, io.ErrUnexpectedEOF - } else if buf[i] < 0x80 { - p.index++ - return uint64(buf[i]), nil - } else if len(buf)-i < 10 { - return p.decodeVarintSlow() - } - - var b uint64 - // we already checked the first byte - x = uint64(buf[i]) - 0x80 - i++ - - b = uint64(buf[i]) - i++ - x += b << 7 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 7 - - b = uint64(buf[i]) - i++ - x += b << 14 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 14 - - b = uint64(buf[i]) - i++ - x += b << 21 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 21 - - b = uint64(buf[i]) - i++ - x += b << 28 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 28 - - b = uint64(buf[i]) - i++ - x += b << 35 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 35 - - b = uint64(buf[i]) - i++ - x += b << 42 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 42 - - b = uint64(buf[i]) - i++ - x += b << 49 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 49 - - b = uint64(buf[i]) - i++ - x += b << 56 - if b&0x80 == 0 { - goto done - } - x -= 0x80 << 56 - - b = uint64(buf[i]) - i++ - x += b << 63 - if b&0x80 == 0 { - goto done - } - // x -= 0x80 << 63 // Always zero. - - return 0, errOverflow - -done: - p.index = i - return x, nil -} - // DecodeFixed64 reads a 64-bit integer from the Buffer. // This is the format for the // fixed64, sfixed64, and double protocol buffer types. @@ -434,8 +340,6 @@ func (p *Buffer) DecodeGroup(pb Message) error { // Buffer and places the decoded result in pb. If the struct // underlying pb does not match the data in the buffer, the results can be // unpredictable. -// -// Unlike proto.Unmarshal, this does not reset pb before starting to unmarshal. func (p *Buffer) Unmarshal(pb Message) error { // If the object can unmarshal itself, let it. if u, ok := pb.(Unmarshaler); ok { @@ -474,11 +378,6 @@ func (o *Buffer) unmarshalType(st reflect.Type, prop *StructProperties, is_group wire := int(u & 0x7) if wire == WireEndGroup { if is_group { - if required > 0 { - // Not enough information to determine the exact field. - // (See below.) - return &RequiredNotSetError{"{Unknown}"} - } return nil // input is satisfied } return fmt.Errorf("proto: %s: wiretype end group for non-group", st) diff --git a/vendor/github.com/golang/protobuf/proto/encode.go b/vendor/github.com/golang/protobuf/proto/encode.go index 68b9b30..8c1b8fd 100644 --- a/vendor/github.com/golang/protobuf/proto/encode.go +++ b/vendor/github.com/golang/protobuf/proto/encode.go @@ -234,6 +234,10 @@ func Marshal(pb Message) ([]byte, error) { } p := NewBuffer(nil) err := p.Marshal(pb) + var state errorState + if err != nil && !state.shouldContinue(err, nil) { + return nil, err + } if p.buf == nil && err == nil { // Return a non-nil slice on success. return []byte{}, nil @@ -262,8 +266,11 @@ func (p *Buffer) Marshal(pb Message) error { // Can the object marshal itself? if m, ok := pb.(Marshaler); ok { data, err := m.Marshal() + if err != nil { + return err + } p.buf = append(p.buf, data...) - return err + return nil } t, base, err := getbase(pb) @@ -275,7 +282,7 @@ func (p *Buffer) Marshal(pb Message) error { } if collectStats { - (stats).Encode++ // Parens are to work around a goimports bug. + stats.Encode++ } if len(p.buf) > maxMarshalSize { @@ -302,7 +309,7 @@ func Size(pb Message) (n int) { } if collectStats { - (stats).Size++ // Parens are to work around a goimports bug. + stats.Size++ } return @@ -1007,6 +1014,7 @@ func size_slice_struct_message(p *Properties, base structPointer) (n int) { if p.isMarshaler { m := structPointer_Interface(structp, p.stype).(Marshaler) data, _ := m.Marshal() + n += len(p.tagcode) n += sizeRawBytes(data) continue } diff --git a/vendor/github.com/golang/protobuf/proto/equal.go b/vendor/github.com/golang/protobuf/proto/equal.go index 2ed1cf5..8b16f95 100644 --- a/vendor/github.com/golang/protobuf/proto/equal.go +++ b/vendor/github.com/golang/protobuf/proto/equal.go @@ -54,17 +54,13 @@ Equality is defined in this way: in a proto3 .proto file, fields are not "set"; specifically, zero length proto3 "bytes" fields are equal (nil == {}). - Two repeated fields are equal iff their lengths are the same, - and their corresponding elements are equal. Note a "bytes" field, - although represented by []byte, is not a repeated field and the - rule for the scalar fields described above applies. + and their corresponding elements are equal (a "bytes" field, + although represented by []byte, is not a repeated field) - Two unset fields are equal. - Two unknown field sets are equal if their current encoded state is equal. - Two extension sets are equal iff they have corresponding elements that are pairwise equal. - - Two map fields are equal iff their lengths are the same, - and they contain the same set of elements. Zero-length map - fields are equal. - Every other combination of things are not equal. The return value is undefined if a and b are not protocol buffers. diff --git a/vendor/github.com/golang/protobuf/proto/extensions.go b/vendor/github.com/golang/protobuf/proto/extensions.go index 6b9b363..9f484f5 100644 --- a/vendor/github.com/golang/protobuf/proto/extensions.go +++ b/vendor/github.com/golang/protobuf/proto/extensions.go @@ -489,37 +489,6 @@ func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, e return } -// ExtensionDescs returns a new slice containing pb's extension descriptors, in undefined order. -// For non-registered extensions, ExtensionDescs returns an incomplete descriptor containing -// just the Field field, which defines the extension's field number. -func ExtensionDescs(pb Message) ([]*ExtensionDesc, error) { - epb, ok := extendable(pb) - if !ok { - return nil, fmt.Errorf("proto: %T is not an extendable proto.Message", pb) - } - registeredExtensions := RegisteredExtensions(pb) - - emap, mu := epb.extensionsRead() - if emap == nil { - return nil, nil - } - mu.Lock() - defer mu.Unlock() - extensions := make([]*ExtensionDesc, 0, len(emap)) - for extid, e := range emap { - desc := e.desc - if desc == nil { - desc = registeredExtensions[extid] - if desc == nil { - desc = &ExtensionDesc{Field: extid} - } - } - - extensions = append(extensions, desc) - } - return extensions, nil -} - // SetExtension sets the specified extension of pb to the specified value. func SetExtension(pb Message, extension *ExtensionDesc, value interface{}) error { epb, ok := extendable(pb) diff --git a/vendor/github.com/golang/protobuf/proto/lib.go b/vendor/github.com/golang/protobuf/proto/lib.go index ac4ddbc..170b8e8 100644 --- a/vendor/github.com/golang/protobuf/proto/lib.go +++ b/vendor/github.com/golang/protobuf/proto/lib.go @@ -308,7 +308,7 @@ func GetStats() Stats { return stats } // temporary Buffer and are fine for most applications. type Buffer struct { buf []byte // encode/decode byte stream - index int // read point + index int // write point // pools of basic types to amortize allocation. bools []bool diff --git a/vendor/github.com/golang/protobuf/proto/properties.go b/vendor/github.com/golang/protobuf/proto/properties.go index ec2289c..69ddda8 100644 --- a/vendor/github.com/golang/protobuf/proto/properties.go +++ b/vendor/github.com/golang/protobuf/proto/properties.go @@ -844,15 +844,7 @@ func RegisterType(x Message, name string) { } // MessageName returns the fully-qualified proto name for the given message type. -func MessageName(x Message) string { - type xname interface { - XXX_MessageName() string - } - if m, ok := x.(xname); ok { - return m.XXX_MessageName() - } - return revProtoTypes[reflect.TypeOf(x)] -} +func MessageName(x Message) string { return revProtoTypes[reflect.TypeOf(x)] } // MessageType returns the message type (pointer to struct) for a named message. func MessageType(name string) reflect.Type { return protoTypes[name] } diff --git a/vendor/github.com/golang/protobuf/proto/text.go b/vendor/github.com/golang/protobuf/proto/text.go index 965876b..8214ce3 100644 --- a/vendor/github.com/golang/protobuf/proto/text.go +++ b/vendor/github.com/golang/protobuf/proto/text.go @@ -154,7 +154,7 @@ func (w *textWriter) indent() { w.ind++ } func (w *textWriter) unindent() { if w.ind == 0 { - log.Print("proto: textWriter unindented too far") + log.Printf("proto: textWriter unindented too far") return } w.ind-- diff --git a/vendor/github.com/golang/protobuf/proto/text_parser.go b/vendor/github.com/golang/protobuf/proto/text_parser.go index 4fd0531..0b8c59f 100644 --- a/vendor/github.com/golang/protobuf/proto/text_parser.go +++ b/vendor/github.com/golang/protobuf/proto/text_parser.go @@ -44,9 +44,6 @@ import ( "unicode/utf8" ) -// Error string emitted when deserializing Any and fields are already set -const anyRepeatedlyUnpacked = "Any message unpacked multiple times, or %q already set" - type ParseError struct { Message string Line int // 1-based line number @@ -511,16 +508,8 @@ func (p *textParser) readStruct(sv reflect.Value, terminator string) error { if err != nil { return p.errorf("failed to marshal message of type %q: %v", messageName, err) } - if fieldSet["type_url"] { - return p.errorf(anyRepeatedlyUnpacked, "type_url") - } - if fieldSet["value"] { - return p.errorf(anyRepeatedlyUnpacked, "value") - } sv.FieldByName("TypeUrl").SetString(extName) sv.FieldByName("Value").SetBytes(b) - fieldSet["type_url"] = true - fieldSet["value"] = true continue } @@ -792,12 +781,12 @@ func (p *textParser) readAny(v reflect.Value, props *Properties) error { fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) return p.readAny(fv.Index(fv.Len()-1), props) case reflect.Bool: - // true/1/t/True or false/f/0/False. + // Either "true", "false", 1 or 0. switch tok.value { - case "true", "1", "t", "True": + case "true", "1": fv.SetBool(true) return nil - case "false", "0", "f", "False": + case "false", "0": fv.SetBool(false) return nil } diff --git a/vendor/github.com/google/cadvisor/LICENSE b/vendor/github.com/google/cadvisor/LICENSE deleted file mode 100644 index 97cec18..0000000 --- a/vendor/github.com/google/cadvisor/LICENSE +++ /dev/null @@ -1,190 +0,0 @@ - Copyright 2014 The cAdvisor 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. - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS diff --git a/vendor/github.com/google/cadvisor/info/v1/container.go b/vendor/github.com/google/cadvisor/info/v1/container.go deleted file mode 100644 index 6c9be7c..0000000 --- a/vendor/github.com/google/cadvisor/info/v1/container.go +++ /dev/null @@ -1,607 +0,0 @@ -// Copyright 2014 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 v1 - -import ( - "reflect" - "time" -) - -type CpuSpec struct { - Limit uint64 `json:"limit"` - MaxLimit uint64 `json:"max_limit"` - Mask string `json:"mask,omitempty"` - Quota uint64 `json:"quota,omitempty"` - Period uint64 `json:"period,omitempty"` -} - -type MemorySpec struct { - // The amount of memory requested. Default is unlimited (-1). - // Units: bytes. - Limit uint64 `json:"limit,omitempty"` - - // The amount of guaranteed memory. Default is 0. - // Units: bytes. - Reservation uint64 `json:"reservation,omitempty"` - - // The amount of swap space requested. Default is unlimited (-1). - // Units: bytes. - SwapLimit uint64 `json:"swap_limit,omitempty"` -} - -type ContainerSpec struct { - // Time at which the container was created. - CreationTime time.Time `json:"creation_time,omitempty"` - - // Metadata labels associated with this container. - Labels map[string]string `json:"labels,omitempty"` - // Metadata envs associated with this container. Only whitelisted envs are added. - Envs map[string]string `json:"envs,omitempty"` - - HasCpu bool `json:"has_cpu"` - Cpu CpuSpec `json:"cpu,omitempty"` - - HasMemory bool `json:"has_memory"` - Memory MemorySpec `json:"memory,omitempty"` - - HasNetwork bool `json:"has_network"` - - HasFilesystem bool `json:"has_filesystem"` - - // HasDiskIo when true, indicates that DiskIo stats will be available. - HasDiskIo bool `json:"has_diskio"` - - HasCustomMetrics bool `json:"has_custom_metrics"` - CustomMetrics []MetricSpec `json:"custom_metrics,omitempty"` - - // Image name used for this container. - Image string `json:"image,omitempty"` -} - -// Container reference contains enough information to uniquely identify a container -type ContainerReference struct { - // The container id - Id string `json:"id,omitempty"` - - // The absolute name of the container. This is unique on the machine. - Name string `json:"name"` - - // Other names by which the container is known within a certain namespace. - // This is unique within that namespace. - Aliases []string `json:"aliases,omitempty"` - - // Namespace under which the aliases of a container are unique. - // An example of a namespace is "docker" for Docker containers. - Namespace string `json:"namespace,omitempty"` - - Labels map[string]string `json:"labels,omitempty"` -} - -// Sorts by container name. -type ContainerReferenceSlice []ContainerReference - -func (self ContainerReferenceSlice) Len() int { return len(self) } -func (self ContainerReferenceSlice) Swap(i, j int) { self[i], self[j] = self[j], self[i] } -func (self ContainerReferenceSlice) Less(i, j int) bool { return self[i].Name < self[j].Name } - -// ContainerInfoRequest is used when users check a container info from the REST API. -// It specifies how much data users want to get about a container -type ContainerInfoRequest struct { - // Max number of stats to return. Specify -1 for all stats currently available. - // Default: 60 - NumStats int `json:"num_stats,omitempty"` - - // Start time for which to query information. - // If ommitted, the beginning of time is assumed. - Start time.Time `json:"start,omitempty"` - - // End time for which to query information. - // If ommitted, current time is assumed. - End time.Time `json:"end,omitempty"` -} - -// Returns a ContainerInfoRequest with all default values specified. -func DefaultContainerInfoRequest() ContainerInfoRequest { - return ContainerInfoRequest{ - NumStats: 60, - } -} - -func (self *ContainerInfoRequest) Equals(other ContainerInfoRequest) bool { - return self.NumStats == other.NumStats && - self.Start.Equal(other.Start) && - self.End.Equal(other.End) -} - -type ContainerInfo struct { - ContainerReference - - // The direct subcontainers of the current container. - Subcontainers []ContainerReference `json:"subcontainers,omitempty"` - - // The isolation used in the container. - Spec ContainerSpec `json:"spec,omitempty"` - - // Historical statistics gathered from the container. - Stats []*ContainerStats `json:"stats,omitempty"` -} - -// TODO(vmarmol): Refactor to not need this equality comparison. -// ContainerInfo may be (un)marshaled by json or other en/decoder. In that -// case, the Timestamp field in each stats/sample may not be precisely -// en/decoded. This will lead to small but acceptable differences between a -// ContainerInfo and its encode-then-decode version. Eq() is used to compare -// two ContainerInfo accepting small difference (<10ms) of Time fields. -func (self *ContainerInfo) Eq(b *ContainerInfo) bool { - - // If both self and b are nil, then Eq() returns true - if self == nil { - return b == nil - } - if b == nil { - return self == nil - } - - // For fields other than time.Time, we will compare them precisely. - // This would require that any slice should have same order. - if !reflect.DeepEqual(self.ContainerReference, b.ContainerReference) { - return false - } - if !reflect.DeepEqual(self.Subcontainers, b.Subcontainers) { - return false - } - if !self.Spec.Eq(&b.Spec) { - return false - } - - for i, expectedStats := range b.Stats { - selfStats := self.Stats[i] - if !expectedStats.Eq(selfStats) { - return false - } - } - - return true -} - -func (self *ContainerSpec) Eq(b *ContainerSpec) bool { - // Creation within 1s of each other. - diff := self.CreationTime.Sub(b.CreationTime) - if (diff > time.Second) || (diff < -time.Second) { - return false - } - - if self.HasCpu != b.HasCpu { - return false - } - if !reflect.DeepEqual(self.Cpu, b.Cpu) { - return false - } - if self.HasMemory != b.HasMemory { - return false - } - if !reflect.DeepEqual(self.Memory, b.Memory) { - return false - } - if self.HasNetwork != b.HasNetwork { - return false - } - if self.HasFilesystem != b.HasFilesystem { - return false - } - if self.HasDiskIo != b.HasDiskIo { - return false - } - if self.HasCustomMetrics != b.HasCustomMetrics { - return false - } - return true -} - -func (self *ContainerInfo) StatsAfter(ref time.Time) []*ContainerStats { - n := len(self.Stats) + 1 - for i, s := range self.Stats { - if s.Timestamp.After(ref) { - n = i - break - } - } - if n > len(self.Stats) { - return nil - } - return self.Stats[n:] -} - -func (self *ContainerInfo) StatsStartTime() time.Time { - var ret time.Time - for _, s := range self.Stats { - if s.Timestamp.Before(ret) || ret.IsZero() { - ret = s.Timestamp - } - } - return ret -} - -func (self *ContainerInfo) StatsEndTime() time.Time { - var ret time.Time - for i := len(self.Stats) - 1; i >= 0; i-- { - s := self.Stats[i] - if s.Timestamp.After(ret) { - ret = s.Timestamp - } - } - return ret -} - -// This mirrors kernel internal structure. -type LoadStats struct { - // Number of sleeping tasks. - NrSleeping uint64 `json:"nr_sleeping"` - - // Number of running tasks. - NrRunning uint64 `json:"nr_running"` - - // Number of tasks in stopped state - NrStopped uint64 `json:"nr_stopped"` - - // Number of tasks in uninterruptible state - NrUninterruptible uint64 `json:"nr_uninterruptible"` - - // Number of tasks waiting on IO - NrIoWait uint64 `json:"nr_io_wait"` -} - -// CPU usage time statistics. -type CpuUsage struct { - // Total CPU usage. - // Unit: nanoseconds. - Total uint64 `json:"total"` - - // Per CPU/core usage of the container. - // Unit: nanoseconds. - PerCpu []uint64 `json:"per_cpu_usage,omitempty"` - - // Time spent in user space. - // Unit: nanoseconds. - User uint64 `json:"user"` - - // Time spent in kernel space. - // Unit: nanoseconds. - System uint64 `json:"system"` -} - -// Cpu Completely Fair Scheduler statistics. -type CpuCFS struct { - // Total number of elapsed enforcement intervals. - Periods uint64 `json:"periods"` - - // Total number of times tasks in the cgroup have been throttled. - ThrottledPeriods uint64 `json:"throttled_periods"` - - // Total time duration for which tasks in the cgroup have been throttled. - // Unit: nanoseconds. - ThrottledTime uint64 `json:"throttled_time"` -} - -// All CPU usage metrics are cumulative from the creation of the container -type CpuStats struct { - Usage CpuUsage `json:"usage"` - CFS CpuCFS `json:"cfs"` - // Smoothed average of number of runnable threads x 1000. - // We multiply by thousand to avoid using floats, but preserving precision. - // Load is smoothed over the last 10 seconds. Instantaneous value can be read - // from LoadStats.NrRunning. - LoadAverage int32 `json:"load_average"` -} - -type PerDiskStats struct { - Major uint64 `json:"major"` - Minor uint64 `json:"minor"` - Stats map[string]uint64 `json:"stats"` -} - -type DiskIoStats struct { - IoServiceBytes []PerDiskStats `json:"io_service_bytes,omitempty"` - IoServiced []PerDiskStats `json:"io_serviced,omitempty"` - IoQueued []PerDiskStats `json:"io_queued,omitempty"` - Sectors []PerDiskStats `json:"sectors,omitempty"` - IoServiceTime []PerDiskStats `json:"io_service_time,omitempty"` - IoWaitTime []PerDiskStats `json:"io_wait_time,omitempty"` - IoMerged []PerDiskStats `json:"io_merged,omitempty"` - IoTime []PerDiskStats `json:"io_time,omitempty"` -} - -type MemoryStats struct { - // Current memory usage, this includes all memory regardless of when it was - // accessed. - // Units: Bytes. - Usage uint64 `json:"usage"` - - // Number of bytes of page cache memory. - // Units: Bytes. - Cache uint64 `json:"cache"` - - // The amount of anonymous and swap cache memory (includes transparent - // hugepages). - // Units: Bytes. - RSS uint64 `json:"rss"` - - // The amount of swap currently used by the processes in this cgroup - // Units: Bytes. - Swap uint64 `json:"swap"` - - // The amount of working set memory, this includes recently accessed memory, - // dirty memory, and kernel memory. Working set is <= "usage". - // Units: Bytes. - WorkingSet uint64 `json:"working_set"` - - Failcnt uint64 `json:"failcnt"` - - ContainerData MemoryStatsMemoryData `json:"container_data,omitempty"` - HierarchicalData MemoryStatsMemoryData `json:"hierarchical_data,omitempty"` -} - -type MemoryStatsMemoryData struct { - Pgfault uint64 `json:"pgfault"` - Pgmajfault uint64 `json:"pgmajfault"` -} - -type InterfaceStats struct { - // The name of the interface. - Name string `json:"name"` - // Cumulative count of bytes received. - RxBytes uint64 `json:"rx_bytes"` - // Cumulative count of packets received. - RxPackets uint64 `json:"rx_packets"` - // Cumulative count of receive errors encountered. - RxErrors uint64 `json:"rx_errors"` - // Cumulative count of packets dropped while receiving. - RxDropped uint64 `json:"rx_dropped"` - // Cumulative count of bytes transmitted. - TxBytes uint64 `json:"tx_bytes"` - // Cumulative count of packets transmitted. - TxPackets uint64 `json:"tx_packets"` - // Cumulative count of transmit errors encountered. - TxErrors uint64 `json:"tx_errors"` - // Cumulative count of packets dropped while transmitting. - TxDropped uint64 `json:"tx_dropped"` -} - -type NetworkStats struct { - InterfaceStats `json:",inline"` - Interfaces []InterfaceStats `json:"interfaces,omitempty"` - // TCP connection stats (Established, Listen...) - Tcp TcpStat `json:"tcp"` - // TCP6 connection stats (Established, Listen...) - Tcp6 TcpStat `json:"tcp6"` -} - -type TcpStat struct { - // Count of TCP connections in state "Established" - Established uint64 - // Count of TCP connections in state "Syn_Sent" - SynSent uint64 - // Count of TCP connections in state "Syn_Recv" - SynRecv uint64 - // Count of TCP connections in state "Fin_Wait1" - FinWait1 uint64 - // Count of TCP connections in state "Fin_Wait2" - FinWait2 uint64 - // Count of TCP connections in state "Time_Wait - TimeWait uint64 - // Count of TCP connections in state "Close" - Close uint64 - // Count of TCP connections in state "Close_Wait" - CloseWait uint64 - // Count of TCP connections in state "Listen_Ack" - LastAck uint64 - // Count of TCP connections in state "Listen" - Listen uint64 - // Count of TCP connections in state "Closing" - Closing uint64 -} - -type FsStats struct { - // The block device name associated with the filesystem. - Device string `json:"device,omitempty"` - - // Type of the filesytem. - Type string `json:"type"` - - // Number of bytes that can be consumed by the container on this filesystem. - Limit uint64 `json:"capacity"` - - // Number of bytes that is consumed by the container on this filesystem. - Usage uint64 `json:"usage"` - - // Base Usage that is consumed by the container's writable layer. - // This field is only applicable for docker container's as of now. - BaseUsage uint64 `json:"base_usage"` - - // Number of bytes available for non-root user. - Available uint64 `json:"available"` - - // HasInodes when true, indicates that Inodes info will be available. - HasInodes bool `json:"has_inodes"` - - // Number of Inodes - Inodes uint64 `json:"inodes"` - - // Number of available Inodes - InodesFree uint64 `json:"inodes_free"` - - // Number of reads completed - // This is the total number of reads completed successfully. - ReadsCompleted uint64 `json:"reads_completed"` - - // Number of reads merged - // Reads and writes which are adjacent to each other may be merged for - // efficiency. Thus two 4K reads may become one 8K read before it is - // ultimately handed to the disk, and so it will be counted (and queued) - // as only one I/O. This field lets you know how often this was done. - ReadsMerged uint64 `json:"reads_merged"` - - // Number of sectors read - // This is the total number of sectors read successfully. - SectorsRead uint64 `json:"sectors_read"` - - // Number of milliseconds spent reading - // This is the total number of milliseconds spent by all reads (as - // measured from __make_request() to end_that_request_last()). - ReadTime uint64 `json:"read_time"` - - // Number of writes completed - // This is the total number of writes completed successfully. - WritesCompleted uint64 `json:"writes_completed"` - - // Number of writes merged - // See the description of reads merged. - WritesMerged uint64 `json:"writes_merged"` - - // Number of sectors written - // This is the total number of sectors written successfully. - SectorsWritten uint64 `json:"sectors_written"` - - // Number of milliseconds spent writing - // This is the total number of milliseconds spent by all writes (as - // measured from __make_request() to end_that_request_last()). - WriteTime uint64 `json:"write_time"` - - // Number of I/Os currently in progress - // The only field that should go to zero. Incremented as requests are - // given to appropriate struct request_queue and decremented as they finish. - IoInProgress uint64 `json:"io_in_progress"` - - // Number of milliseconds spent doing I/Os - // This field increases so long as field 9 is nonzero. - IoTime uint64 `json:"io_time"` - - // weighted number of milliseconds spent doing I/Os - // This field is incremented at each I/O start, I/O completion, I/O - // merge, or read of these stats by the number of I/Os in progress - // (field 9) times the number of milliseconds spent doing I/O since the - // last update of this field. This can provide an easy measure of both - // I/O completion time and the backlog that may be accumulating. - WeightedIoTime uint64 `json:"weighted_io_time"` -} - -type ContainerStats struct { - // The time of this stat point. - Timestamp time.Time `json:"timestamp"` - Cpu CpuStats `json:"cpu,omitempty"` - DiskIo DiskIoStats `json:"diskio,omitempty"` - Memory MemoryStats `json:"memory,omitempty"` - Network NetworkStats `json:"network,omitempty"` - - // Filesystem statistics - Filesystem []FsStats `json:"filesystem,omitempty"` - - // Task load stats - TaskStats LoadStats `json:"task_stats,omitempty"` - - // Custom metrics from all collectors - CustomMetrics map[string][]MetricVal `json:"custom_metrics,omitempty"` -} - -func timeEq(t1, t2 time.Time, tolerance time.Duration) bool { - // t1 should not be later than t2 - if t1.After(t2) { - t1, t2 = t2, t1 - } - diff := t2.Sub(t1) - if diff <= tolerance { - return true - } - return false -} - -const ( - // 10ms, i.e. 0.01s - timePrecision time.Duration = 10 * time.Millisecond -) - -// This function is useful because we do not require precise time -// representation. -func (a *ContainerStats) Eq(b *ContainerStats) bool { - if !timeEq(a.Timestamp, b.Timestamp, timePrecision) { - return false - } - return a.StatsEq(b) -} - -// Checks equality of the stats values. -func (a *ContainerStats) StatsEq(b *ContainerStats) bool { - // TODO(vmarmol): Consider using this through reflection. - if !reflect.DeepEqual(a.Cpu, b.Cpu) { - return false - } - if !reflect.DeepEqual(a.Memory, b.Memory) { - return false - } - if !reflect.DeepEqual(a.DiskIo, b.DiskIo) { - return false - } - if !reflect.DeepEqual(a.Network, b.Network) { - return false - } - if !reflect.DeepEqual(a.Filesystem, b.Filesystem) { - return false - } - return true -} - -// Event contains information general to events such as the time at which they -// occurred, their specific type, and the actual event. Event types are -// differentiated by the EventType field of Event. -type Event struct { - // the absolute container name for which the event occurred - ContainerName string `json:"container_name"` - - // the time at which the event occurred - Timestamp time.Time `json:"timestamp"` - - // the type of event. EventType is an enumerated type - EventType EventType `json:"event_type"` - - // the original event object and all of its extraneous data, ex. an - // OomInstance - EventData EventData `json:"event_data,omitempty"` -} - -// EventType is an enumerated type which lists the categories under which -// events may fall. The Event field EventType is populated by this enum. -type EventType string - -const ( - EventOom EventType = "oom" - EventOomKill = "oomKill" - EventContainerCreation = "containerCreation" - EventContainerDeletion = "containerDeletion" -) - -// Extra information about an event. Only one type will be set. -type EventData struct { - // Information about an OOM kill event. - OomKill *OomKillEventData `json:"oom,omitempty"` -} - -// Information related to an OOM kill instance -type OomKillEventData struct { - // process id of the killed process - Pid int `json:"pid"` - - // The name of the killed process - ProcessName string `json:"process_name"` -} diff --git a/vendor/github.com/google/cadvisor/info/v1/docker.go b/vendor/github.com/google/cadvisor/info/v1/docker.go deleted file mode 100644 index 2703c53..0000000 --- a/vendor/github.com/google/cadvisor/info/v1/docker.go +++ /dev/null @@ -1,37 +0,0 @@ -// 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. - -// Types used for docker containers. -package v1 - -type DockerStatus struct { - Version string `json:"version"` - KernelVersion string `json:"kernel_version"` - OS string `json:"os"` - Hostname string `json:"hostname"` - RootDir string `json:"root_dir"` - Driver string `json:"driver"` - DriverStatus map[string]string `json:"driver_status"` - ExecDriver string `json:"exec_driver"` - NumImages int `json:"num_images"` - NumContainers int `json:"num_containers"` -} - -type DockerImage struct { - ID string `json:"id"` - RepoTags []string `json:"repo_tags"` // repository name and tags. - Created int64 `json:"created"` // unix time since creation. - VirtualSize int64 `json:"virtual_size"` - Size int64 `json:"size"` -} diff --git a/vendor/github.com/google/cadvisor/info/v1/machine.go b/vendor/github.com/google/cadvisor/info/v1/machine.go deleted file mode 100644 index 933b6f3..0000000 --- a/vendor/github.com/google/cadvisor/info/v1/machine.go +++ /dev/null @@ -1,208 +0,0 @@ -// Copyright 2014 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 v1 - -type FsInfo struct { - // Block device associated with the filesystem. - Device string `json:"device"` - - // Total number of bytes available on the filesystem. - Capacity uint64 `json:"capacity"` - - // Type of device. - Type string `json:"type"` - - // Total number of inodes available on the filesystem. - Inodes uint64 `json:"inodes"` - - // HasInodes when true, indicates that Inodes info will be available. - HasInodes bool `json:"has_inodes"` -} - -type Node struct { - Id int `json:"node_id"` - // Per-node memory - Memory uint64 `json:"memory"` - Cores []Core `json:"cores"` - Caches []Cache `json:"caches"` -} - -type Core struct { - Id int `json:"core_id"` - Threads []int `json:"thread_ids"` - Caches []Cache `json:"caches"` -} - -type Cache struct { - // Size of memory cache in bytes. - Size uint64 `json:"size"` - // Type of memory cache: data, instruction, or unified. - Type string `json:"type"` - // Level (distance from cpus) in a multi-level cache hierarchy. - Level int `json:"level"` -} - -func (self *Node) FindCore(id int) (bool, int) { - for i, n := range self.Cores { - if n.Id == id { - return true, i - } - } - return false, -1 -} - -func (self *Node) AddThread(thread int, core int) { - var coreIdx int - if core == -1 { - // Assume one hyperthread per core when topology data is missing. - core = thread - } - ok, coreIdx := self.FindCore(core) - - if !ok { - // New core - core := Core{Id: core} - self.Cores = append(self.Cores, core) - coreIdx = len(self.Cores) - 1 - } - self.Cores[coreIdx].Threads = append(self.Cores[coreIdx].Threads, thread) -} - -func (self *Node) AddNodeCache(c Cache) { - self.Caches = append(self.Caches, c) -} - -func (self *Node) AddPerCoreCache(c Cache) { - for idx := range self.Cores { - self.Cores[idx].Caches = append(self.Cores[idx].Caches, c) - } -} - -type DiskInfo struct { - // device name - Name string `json:"name"` - - // Major number - Major uint64 `json:"major"` - - // Minor number - Minor uint64 `json:"minor"` - - // Size in bytes - Size uint64 `json:"size"` - - // I/O Scheduler - one of "none", "noop", "cfq", "deadline" - Scheduler string `json:"scheduler"` -} - -type NetInfo struct { - // Device name - Name string `json:"name"` - - // Mac Address - MacAddress string `json:"mac_address"` - - // Speed in MBits/s - Speed int64 `json:"speed"` - - // Maximum Transmission Unit - Mtu int64 `json:"mtu"` -} - -type CloudProvider string - -const ( - GCE CloudProvider = "GCE" - AWS = "AWS" - Azure = "Azure" - Baremetal = "Baremetal" - UnknownProvider = "Unknown" -) - -type InstanceType string - -const ( - NoInstance InstanceType = "None" - UnknownInstance = "Unknown" -) - -type InstanceID string - -const ( - UnNamedInstance InstanceID = "None" -) - -type MachineInfo struct { - // The number of cores in this machine. - NumCores int `json:"num_cores"` - - // Maximum clock speed for the cores, in KHz. - CpuFrequency uint64 `json:"cpu_frequency_khz"` - - // The amount of memory (in bytes) in this machine - MemoryCapacity uint64 `json:"memory_capacity"` - - // The machine id - MachineID string `json:"machine_id"` - - // The system uuid - SystemUUID string `json:"system_uuid"` - - // The boot id - BootID string `json:"boot_id"` - - // Filesystems on this machine. - Filesystems []FsInfo `json:"filesystems"` - - // Disk map - DiskMap map[string]DiskInfo `json:"disk_map"` - - // Network devices - NetworkDevices []NetInfo `json:"network_devices"` - - // Machine Topology - // Describes cpu/memory layout and hierarchy. - Topology []Node `json:"topology"` - - // Cloud provider the machine belongs to. - CloudProvider CloudProvider `json:"cloud_provider"` - - // Type of cloud instance (e.g. GCE standard) the machine is. - InstanceType InstanceType `json:"instance_type"` - - // ID of cloud instance (e.g. instance-1) given to it by the cloud provider. - InstanceID InstanceID `json:"instance_id"` -} - -type VersionInfo struct { - // Kernel version. - KernelVersion string `json:"kernel_version"` - - // OS image being used for cadvisor container, or host image if running on host directly. - ContainerOsVersion string `json:"container_os_version"` - - // Docker version. - DockerVersion string `json:"docker_version"` - - // cAdvisor version. - CadvisorVersion string `json:"cadvisor_version"` - // cAdvisor git revision. - CadvisorRevision string `json:"cadvisor_revision"` -} - -type MachineInfoFactory interface { - GetMachineInfo() (*MachineInfo, error) - GetVersionInfo() (*VersionInfo, error) -} diff --git a/vendor/github.com/google/cadvisor/info/v1/metric.go b/vendor/github.com/google/cadvisor/info/v1/metric.go deleted file mode 100644 index 30c23ed..0000000 --- a/vendor/github.com/google/cadvisor/info/v1/metric.go +++ /dev/null @@ -1,79 +0,0 @@ -// Copyright 2015 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 v1 - -import ( - "time" -) - -// Type of metric being exported. -type MetricType string - -const ( - // Instantaneous value. May increase or decrease. - MetricGauge MetricType = "gauge" - - // A counter-like value that is only expected to increase. - MetricCumulative MetricType = "cumulative" - - // Rate over a time period. - MetricDelta MetricType = "delta" -) - -// DataType for metric being exported. -type DataType string - -const ( - IntType DataType = "int" - FloatType DataType = "float" -) - -// Spec for custom metric. -type MetricSpec struct { - // The name of the metric. - Name string `json:"name"` - - // Type of the metric. - Type MetricType `json:"type"` - - // Data Type for the stats. - Format DataType `json:"format"` - - // Display Units for the stats. - Units string `json:"units"` -} - -// An exported metric. -type MetricValBasic struct { - // Time at which the metric was queried - Timestamp time.Time `json:"timestamp"` - - // The value of the metric at this point. - IntValue int64 `json:"int_value,omitempty"` - FloatValue float64 `json:"float_value,omitempty"` -} - -// An exported metric. -type MetricVal struct { - // Label associated with a metric - Label string `json:"label,omitempty"` - - // Time at which the metric was queried - Timestamp time.Time `json:"timestamp"` - - // The value of the metric at this point. - IntValue int64 `json:"int_value,omitempty"` - FloatValue float64 `json:"float_value,omitempty"` -} diff --git a/vendor/github.com/google/gofuzz/README.md b/vendor/github.com/google/gofuzz/README.md index 64869af..68fcf2c 100644 --- a/vendor/github.com/google/gofuzz/README.md +++ b/vendor/github.com/google/gofuzz/README.md @@ -14,21 +14,21 @@ This is useful for testing: Import with ```import "github.com/google/gofuzz"``` You can use it on single variables: -```go +``` f := fuzz.New() var myInt int f.Fuzz(&myInt) // myInt gets a random value. ``` You can use it on maps: -```go +``` f := fuzz.New().NilChance(0).NumElements(1, 1) var myMap map[ComplexKeyType]string f.Fuzz(&myMap) // myMap will have exactly one element. ``` Customize the chance of getting a nil pointer: -```go +``` f := fuzz.New().NilChance(.5) var fancyStruct struct { A, B, C, D *string @@ -37,7 +37,7 @@ f.Fuzz(&fancyStruct) // About half the pointers should be set. ``` You can even customize the randomization completely if needed: -```go +``` type MyEnum string const ( A MyEnum = "A" diff --git a/vendor/github.com/google/gofuzz/fuzz.go b/vendor/github.com/google/gofuzz/fuzz.go index b3e4e6f..42d9a48 100644 --- a/vendor/github.com/google/gofuzz/fuzz.go +++ b/vendor/github.com/google/gofuzz/fuzz.go @@ -229,19 +229,12 @@ func (f *Fuzzer) doFuzz(v reflect.Value, flags uint64) { return } v.Set(reflect.Zero(v.Type())) - case reflect.Array: - if f.genShouldFill() { - n := v.Len() - for i := 0; i < n; i++ { - f.doFuzz(v.Index(i), 0) - } - return - } - v.Set(reflect.Zero(v.Type())) case reflect.Struct: for i := 0; i < v.NumField(); i++ { f.doFuzz(v.Field(i), 0) } + case reflect.Array: + fallthrough case reflect.Chan: fallthrough case reflect.Func: diff --git a/vendor/github.com/jonboulle/clockwork/.travis.yml b/vendor/github.com/jonboulle/clockwork/.travis.yml deleted file mode 100644 index aefda90..0000000 --- a/vendor/github.com/jonboulle/clockwork/.travis.yml +++ /dev/null @@ -1,5 +0,0 @@ -language: go -go: - - 1.3 - -sudo: false diff --git a/vendor/github.com/jonboulle/clockwork/README.md b/vendor/github.com/jonboulle/clockwork/README.md index 47bc136..236c86a 100644 --- a/vendor/github.com/jonboulle/clockwork/README.md +++ b/vendor/github.com/jonboulle/clockwork/README.md @@ -1,9 +1,6 @@ clockwork ========= -[![Build Status](https://travis-ci.org/jonboulle/clockwork.png?branch=master)](https://travis-ci.org/jonboulle/clockwork) -[![godoc](https://godoc.org/github.com/jonboulle/clockwork?status.svg)](http://godoc.org/github.com/jonboulle/clockwork) - a simple fake clock for golang # Usage @@ -35,12 +32,7 @@ func TestMyFunc(t *testing.T) { c := clockwork.NewFakeClock() // Start our sleepy function - var wg sync.WaitGroup - wg.Add(1) - go func() { - my_func(c) - wg.Done() - }() + my_func(c) // Ensure we wait until my_func is sleeping c.BlockUntil(1) @@ -48,10 +40,7 @@ func TestMyFunc(t *testing.T) { assert_state() // Advance the FakeClock forward in time - c.Advance(3 * time.Second) - - // Wait until the function completes - wg.Wait() + c.Advance(3) assert_state() } @@ -66,4 +55,4 @@ See [example_test.go](example_test.go) for a full example. # Credits -clockwork is inspired by @wickman's [threaded fake clock](https://gist.github.com/wickman/3840816), and the [Golang playground](http://blog.golang.org/playground#Faking time) +Inspired by @wickman's [threaded fake clock](https://gist.github.com/wickman/3840816), and the [Golang playground](http://blog.golang.org/playground#Faking time) diff --git a/vendor/github.com/jonboulle/clockwork/clockwork.go b/vendor/github.com/jonboulle/clockwork/clockwork.go index 999fddd..4b6918b 100644 --- a/vendor/github.com/jonboulle/clockwork/clockwork.go +++ b/vendor/github.com/jonboulle/clockwork/clockwork.go @@ -11,7 +11,6 @@ type Clock interface { After(d time.Duration) <-chan time.Time Sleep(d time.Duration) Now() time.Time - Since(t time.Time) time.Duration } // FakeClock provides an interface for a clock which can be @@ -33,17 +32,10 @@ func NewRealClock() Clock { } // NewFakeClock returns a FakeClock implementation which can be -// manually advanced through time for testing. The initial time of the -// FakeClock will be an arbitrary non-zero time. +// manually advanced through time for testing. func NewFakeClock() FakeClock { - // use a fixture that does not fulfill Time.IsZero() - return NewFakeClockAt(time.Date(1984, time.April, 4, 0, 0, 0, 0, time.UTC)) -} - -// NewFakeClockAt returns a FakeClock initialised at the given time.Time. -func NewFakeClockAt(t time.Time) FakeClock { return &fakeClock{ - time: t, + l: sync.RWMutex{}, } } @@ -61,10 +53,6 @@ func (rc *realClock) Now() time.Time { return time.Now() } -func (rc *realClock) Since(t time.Time) time.Duration { - return rc.Now().Sub(t) -} - type fakeClock struct { sleepers []*sleeper blockers []*blocker @@ -129,15 +117,9 @@ func (fc *fakeClock) Sleep(d time.Duration) { // Time returns the current time of the fakeClock func (fc *fakeClock) Now() time.Time { - fc.l.RLock() - t := fc.time - fc.l.RUnlock() - return t -} - -// Since returns the duration that has passed since the given time on the fakeClock -func (fc *fakeClock) Since(t time.Time) time.Duration { - return fc.Now().Sub(t) + fc.l.Lock() + defer fc.l.Unlock() + return fc.time } // Advance advances fakeClock to a new point in time, ensuring channels from any diff --git a/vendor/github.com/mailru/easyjson/jlexer/lexer.go b/vendor/github.com/mailru/easyjson/jlexer/lexer.go index c3d4ed2..d700c0a 100644 --- a/vendor/github.com/mailru/easyjson/jlexer/lexer.go +++ b/vendor/github.com/mailru/easyjson/jlexer/lexer.go @@ -5,7 +5,6 @@ package jlexer import ( - "encoding/base64" "fmt" "io" "reflect" @@ -506,7 +505,7 @@ func (r *Lexer) SkipRecursive() { return } case c == '\\' && inQuotes: - wasEscape = !wasEscape + wasEscape = true continue case c == '"' && inQuotes: inQuotes = wasEscape @@ -516,11 +515,8 @@ func (r *Lexer) SkipRecursive() { wasEscape = false } r.pos = len(r.Data) - r.err = &LexerError{ - Reason: "EOF reached while skipping array/object or token", - Offset: r.pos, - Data: string(r.Data[r.pos:]), - }} + r.err = io.EOF +} // Raw fetches the next item recursively as a data slice func (r *Lexer) Raw() []byte { @@ -564,28 +560,6 @@ func (r *Lexer) String() string { return ret } -// Bytes reads a string literal and base64 decodes it into a byte slice. -func (r *Lexer) Bytes() []byte { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenString { - r.errInvalidToken("string") - return nil - } - ret := make([]byte, base64.StdEncoding.DecodedLen(len(r.token.byteValue))) - len, err := base64.StdEncoding.Decode(ret, r.token.byteValue) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - return nil - } - - r.consume() - return ret[:len] -} - // Bool reads a true or false boolean keyword. func (r *Lexer) Bool() bool { if r.token.kind == tokenUndef && r.Ok() { diff --git a/vendor/github.com/mailru/easyjson/jwriter/writer.go b/vendor/github.com/mailru/easyjson/jwriter/writer.go index acd670f..907675f 100644 --- a/vendor/github.com/mailru/easyjson/jwriter/writer.go +++ b/vendor/github.com/mailru/easyjson/jwriter/writer.go @@ -2,7 +2,6 @@ package jwriter import ( - "encoding/base64" "io" "strconv" "unicode/utf8" @@ -60,19 +59,6 @@ func (w *Writer) Raw(data []byte, err error) { } } -// Base64Bytes appends data to the buffer after base64 encoding it -func (w *Writer) Base64Bytes(data []byte) { - if data == nil { - w.Buffer.AppendString("null") - return - } - w.Buffer.AppendByte('"') - dst := make([]byte, base64.StdEncoding.EncodedLen(len(data))) - base64.StdEncoding.Encode(dst, data) - w.Buffer.AppendBytes(dst) - w.Buffer.AppendByte('"') -} - func (w *Writer) Uint8(n uint8) { w.Buffer.EnsureSpace(3) w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) @@ -214,12 +200,6 @@ func (w *Writer) Bool(v bool) { const chars = "0123456789abcdef" -func isNotEscapedSingleChar(c byte) bool { - // Note: might make sense to use a table if there are more chars to escape. With 4 chars - // it benchmarks the same. - return c != '<' && c != '\\' && c != '"' && c != '>' && c >= 0x20 && c < utf8.RuneSelf -} - func (w *Writer) String(s string) { w.Buffer.AppendByte('"') @@ -229,32 +209,39 @@ func (w *Writer) String(s string) { p := 0 // last non-escape symbol for i := 0; i < len(s); { - c := s[i] - - if isNotEscapedSingleChar(c) { - // single-width character, no escaping is required - i++ - continue - } else if c < utf8.RuneSelf { - // single-with character, need to escape - w.Buffer.AppendString(s[p:i]) + // single-with character + if c := s[i]; c < utf8.RuneSelf { + var escape byte switch c { case '\t': - w.Buffer.AppendString(`\t`) + escape = 't' case '\r': - w.Buffer.AppendString(`\r`) + escape = 'r' case '\n': - w.Buffer.AppendString(`\n`) + escape = 'n' case '\\': - w.Buffer.AppendString(`\\`) + escape = '\\' case '"': - w.Buffer.AppendString(`\"`) + escape = '"' + case '<', '>': + // do nothing default: + if c >= 0x20 { + // no escaping is required + i++ + continue + } + } + if escape != 0 { + w.Buffer.AppendString(s[p:i]) + w.Buffer.AppendByte('\\') + w.Buffer.AppendByte(escape) + } else { + w.Buffer.AppendString(s[p:i]) w.Buffer.AppendString(`\u00`) w.Buffer.AppendByte(chars[c>>4]) w.Buffer.AppendByte(chars[c&0xf]) } - i++ p = i continue diff --git a/vendor/github.com/pborman/uuid/.travis.yml b/vendor/github.com/pborman/uuid/.travis.yml deleted file mode 100644 index d8156a6..0000000 --- a/vendor/github.com/pborman/uuid/.travis.yml +++ /dev/null @@ -1,9 +0,0 @@ -language: go - -go: - - 1.4.3 - - 1.5.3 - - tip - -script: - - go test -v ./... diff --git a/vendor/github.com/pborman/uuid/CONTRIBUTING.md b/vendor/github.com/pborman/uuid/CONTRIBUTING.md deleted file mode 100644 index 04fdf09..0000000 --- a/vendor/github.com/pborman/uuid/CONTRIBUTING.md +++ /dev/null @@ -1,10 +0,0 @@ -# How to contribute - -We definitely welcome patches and contribution to this project! - -### Legal requirements - -In order to protect both you and ourselves, you will need to sign the -[Contributor License Agreement](https://cla.developers.google.com/clas). - -You may have already signed it for other Google projects. diff --git a/vendor/github.com/pborman/uuid/README.md b/vendor/github.com/pborman/uuid/README.md deleted file mode 100644 index f023d47..0000000 --- a/vendor/github.com/pborman/uuid/README.md +++ /dev/null @@ -1,13 +0,0 @@ -This project was automatically exported from code.google.com/p/go-uuid - -# uuid ![build status](https://travis-ci.org/pborman/uuid.svg?branch=master) -The uuid package generates and inspects UUIDs based on [RFC 412](http://tools.ietf.org/html/rfc4122) and DCE 1.1: Authentication and Security Services. - -###### Install -`go get github.com/pborman/uuid` - -###### Documentation -[![GoDoc](https://godoc.org/github.com/pborman/uuid?status.svg)](http://godoc.org/github.com/pborman/uuid) - -Full `go doc` style documentation for the package can be viewed online without installing this package by using the GoDoc site here: -http://godoc.org/github.com/pborman/uuid diff --git a/vendor/github.com/pborman/uuid/dce.go b/vendor/github.com/pborman/uuid/dce.go old mode 100644 new mode 100755 diff --git a/vendor/github.com/pborman/uuid/doc.go b/vendor/github.com/pborman/uuid/doc.go old mode 100644 new mode 100755 diff --git a/vendor/github.com/pborman/uuid/hash.go b/vendor/github.com/pborman/uuid/hash.go index a0420c1..cdd4192 100644 --- a/vendor/github.com/pborman/uuid/hash.go +++ b/vendor/github.com/pborman/uuid/hash.go @@ -19,7 +19,7 @@ var ( NIL = Parse("00000000-0000-0000-0000-000000000000") ) -// NewHash returns a new UUID derived from the hash of space concatenated with +// NewHash returns a new UUID dervied from the hash of space concatenated with // data generated by h. The hash should be at least 16 byte in length. The // first 16 bytes of the hash are used to form the UUID. The version of the // UUID will be the lower 4 bits of version. NewHash is used to implement diff --git a/vendor/github.com/pborman/uuid/json.go b/vendor/github.com/pborman/uuid/json.go index 9dda1df..760580a 100644 --- a/vendor/github.com/pborman/uuid/json.go +++ b/vendor/github.com/pborman/uuid/json.go @@ -7,21 +7,17 @@ package uuid import "errors" func (u UUID) MarshalJSON() ([]byte, error) { - if len(u) != 16 { + if len(u) == 0 { return []byte(`""`), nil } - var js [38]byte - js[0] = '"' - encodeHex(js[1:], u) - js[37] = '"' - return js[:], nil + return []byte(`"` + u.String() + `"`), nil } func (u *UUID) UnmarshalJSON(data []byte) error { - if string(data) == `""` { + if len(data) == 0 || string(data) == `""` { return nil } - if data[0] != '"' { + if len(data) < 2 || data[0] != '"' || data[len(data)-1] != '"' { return errors.New("invalid UUID format") } data = data[1 : len(data)-1] diff --git a/vendor/github.com/pborman/uuid/node.go b/vendor/github.com/pborman/uuid/node.go old mode 100644 new mode 100755 index 42d60da..dd0a8ac --- a/vendor/github.com/pborman/uuid/node.go +++ b/vendor/github.com/pborman/uuid/node.go @@ -4,13 +4,9 @@ package uuid -import ( - "net" - "sync" -) +import "net" var ( - nodeMu sync.Mutex interfaces []net.Interface // cached list of interfaces ifname string // name of interface being used nodeID []byte // hardware for version 1 UUIDs @@ -20,8 +16,6 @@ var ( // derived. The interface "user" is returned if the NodeID was set by // SetNodeID. func NodeInterface() string { - defer nodeMu.Unlock() - nodeMu.Lock() return ifname } @@ -32,12 +26,6 @@ func NodeInterface() string { // // SetNodeInterface never fails when name is "". func SetNodeInterface(name string) bool { - defer nodeMu.Unlock() - nodeMu.Lock() - return setNodeInterface(name) -} - -func setNodeInterface(name string) bool { if interfaces == nil { var err error interfaces, err = net.Interfaces() @@ -71,10 +59,8 @@ func setNodeInterface(name string) bool { // NodeID returns a slice of a copy of the current Node ID, setting the Node ID // if not already set. func NodeID() []byte { - defer nodeMu.Unlock() - nodeMu.Lock() if nodeID == nil { - setNodeInterface("") + SetNodeInterface("") } nid := make([]byte, 6) copy(nid, nodeID) @@ -85,8 +71,6 @@ func NodeID() []byte { // of id are used. If id is less than 6 bytes then false is returned and the // Node ID is not set. func SetNodeID(id []byte) bool { - defer nodeMu.Unlock() - nodeMu.Lock() if setNodeID(id) { ifname = "user" return true diff --git a/vendor/github.com/pborman/uuid/sql.go b/vendor/github.com/pborman/uuid/sql.go deleted file mode 100644 index d015bfd..0000000 --- a/vendor/github.com/pborman/uuid/sql.go +++ /dev/null @@ -1,66 +0,0 @@ -// Copyright 2015 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "database/sql/driver" - "errors" - "fmt" -) - -// Scan implements sql.Scanner so UUIDs can be read from databases transparently -// Currently, database types that map to string and []byte are supported. Please -// consult database-specific driver documentation for matching types. -func (uuid *UUID) Scan(src interface{}) error { - switch src.(type) { - case string: - // if an empty UUID comes from a table, we return a null UUID - if src.(string) == "" { - return nil - } - - // see uuid.Parse for required string format - parsed := Parse(src.(string)) - - if parsed == nil { - return errors.New("Scan: invalid UUID format") - } - - *uuid = parsed - case []byte: - b := src.([]byte) - - // if an empty UUID comes from a table, we return a null UUID - if len(b) == 0 { - return nil - } - - // assumes a simple slice of bytes if 16 bytes - // otherwise attempts to parse - if len(b) == 16 { - *uuid = UUID(b) - } else { - u := Parse(string(b)) - - if u == nil { - return errors.New("Scan: invalid UUID format") - } - - *uuid = u - } - - default: - return fmt.Errorf("Scan: unable to scan type %T into UUID", src) - } - - return nil -} - -// Value implements sql.Valuer so that UUIDs can be written to databases -// transparently. Currently, UUIDs map to strings. Please consult -// database-specific driver documentation for matching types. -func (uuid UUID) Value() (driver.Value, error) { - return uuid.String(), nil -} diff --git a/vendor/github.com/pborman/uuid/time.go b/vendor/github.com/pborman/uuid/time.go old mode 100644 new mode 100755 index eedf242..7ebc9be --- a/vendor/github.com/pborman/uuid/time.go +++ b/vendor/github.com/pborman/uuid/time.go @@ -23,7 +23,7 @@ const ( ) var ( - timeMu sync.Mutex + mu sync.Mutex lasttime uint64 // last time we returned clock_seq uint16 // clock sequence for this run @@ -43,8 +43,8 @@ func (t Time) UnixTime() (sec, nsec int64) { // clock sequence as well as adjusting the clock sequence as needed. An error // is returned if the current time cannot be determined. func GetTime() (Time, uint16, error) { - defer timeMu.Unlock() - timeMu.Lock() + defer mu.Unlock() + mu.Lock() return getTime() } @@ -75,8 +75,8 @@ func getTime() (Time, uint16, error) { // ClockSequence, GetTime, or NewUUID. (section 4.2.1.1) sequence is generated // for func ClockSequence() int { - defer timeMu.Unlock() - timeMu.Lock() + defer mu.Unlock() + mu.Lock() return clockSequence() } @@ -90,8 +90,8 @@ func clockSequence() int { // SetClockSeq sets the clock sequence to the lower 14 bits of seq. Setting to // -1 causes a new sequence to be generated. func SetClockSequence(seq int) { - defer timeMu.Unlock() - timeMu.Lock() + defer mu.Unlock() + mu.Lock() setClockSequence(seq) } diff --git a/vendor/github.com/pborman/uuid/util.go b/vendor/github.com/pborman/uuid/util.go index fc8e052..de40b10 100644 --- a/vendor/github.com/pborman/uuid/util.go +++ b/vendor/github.com/pborman/uuid/util.go @@ -16,7 +16,7 @@ func randomBits(b []byte) { } // xvalues returns the value of a byte as a hexadecimal digit or 255. -var xvalues = [256]byte{ +var xvalues = []byte{ 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, diff --git a/vendor/github.com/pborman/uuid/uuid.go b/vendor/github.com/pborman/uuid/uuid.go old mode 100644 new mode 100755 index 7c643cf..2920fae --- a/vendor/github.com/pborman/uuid/uuid.go +++ b/vendor/github.com/pborman/uuid/uuid.go @@ -7,26 +7,11 @@ package uuid import ( "bytes" "crypto/rand" - "encoding/hex" "fmt" "io" "strings" ) -// Array is a pass-by-value UUID that can be used as an effecient key in a map. -type Array [16]byte - -// UUID converts uuid into a slice. -func (uuid Array) UUID() UUID { - return uuid[:] -} - -// String returns the string representation of uuid, -// xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx. -func (uuid Array) String() string { - return uuid.UUID().String() -} - // A UUID is a 128 bit (16 byte) Universal Unique IDentifier as defined in RFC // 4122. type UUID []byte @@ -69,8 +54,8 @@ func Parse(s string) UUID { if s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-' { return nil } - var uuid [16]byte - for i, x := range [16]int{ + uuid := make([]byte, 16) + for i, x := range []int{ 0, 2, 4, 6, 9, 11, 14, 16, @@ -82,7 +67,7 @@ func Parse(s string) UUID { uuid[i] = v } } - return uuid[:] + return uuid } // Equal returns true if uuid1 and uuid2 are equal. @@ -90,50 +75,26 @@ func Equal(uuid1, uuid2 UUID) bool { return bytes.Equal(uuid1, uuid2) } -// Array returns an array representation of uuid that can be used as a map key. -// Array panics if uuid is not valid. -func (uuid UUID) Array() Array { - if len(uuid) != 16 { - panic("invalid uuid") - } - var a Array - copy(a[:], uuid) - return a -} - // String returns the string form of uuid, xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx // , or "" if uuid is invalid. func (uuid UUID) String() string { - if len(uuid) != 16 { + if uuid == nil || len(uuid) != 16 { return "" } - var buf [36]byte - encodeHex(buf[:], uuid) - return string(buf[:]) + b := []byte(uuid) + return fmt.Sprintf("%08x-%04x-%04x-%04x-%012x", + b[:4], b[4:6], b[6:8], b[8:10], b[10:]) } // URN returns the RFC 2141 URN form of uuid, // urn:uuid:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx, or "" if uuid is invalid. func (uuid UUID) URN() string { - if len(uuid) != 16 { + if uuid == nil || len(uuid) != 16 { return "" } - var buf [36 + 9]byte - copy(buf[:], "urn:uuid:") - encodeHex(buf[9:], uuid) - return string(buf[:]) -} - -func encodeHex(dst []byte, uuid UUID) { - hex.Encode(dst[:], uuid[:4]) - dst[8] = '-' - hex.Encode(dst[9:13], uuid[4:6]) - dst[13] = '-' - hex.Encode(dst[14:18], uuid[6:8]) - dst[18] = '-' - hex.Encode(dst[19:23], uuid[8:10]) - dst[23] = '-' - hex.Encode(dst[24:], uuid[10:]) + b := []byte(uuid) + return fmt.Sprintf("urn:uuid:%08x-%04x-%04x-%04x-%012x", + b[:4], b[4:6], b[6:8], b[8:10], b[10:]) } // Variant returns the variant encoded in uuid. It returns Invalid if @@ -152,9 +113,10 @@ func (uuid UUID) Variant() Variant { default: return Reserved } + panic("unreachable") } -// Version returns the version of uuid. It returns false if uuid is not +// Version returns the verison of uuid. It returns false if uuid is not // valid. func (uuid UUID) Version() (Version, bool) { if len(uuid) != 16 { @@ -186,7 +148,7 @@ func (v Variant) String() string { return fmt.Sprintf("BadVariant%d", int(v)) } -// SetRand sets the random number generator to r, which implements io.Reader. +// SetRand sets the random number generator to r, which implents io.Reader. // If r.Read returns an error when the package requests random data then // a panic will be issued. // diff --git a/vendor/github.com/spf13/pflag/flag.go b/vendor/github.com/spf13/pflag/flag.go index 4258f45..b0b0d46 100644 --- a/vendor/github.com/spf13/pflag/flag.go +++ b/vendor/github.com/spf13/pflag/flag.go @@ -416,7 +416,7 @@ func Set(name, value string) error { // otherwise, the default values of all defined flags in the set. func (f *FlagSet) PrintDefaults() { usages := f.FlagUsages() - fmt.Fprint(f.out(), usages) + fmt.Fprintf(f.out(), "%s", usages) } // defaultIsZeroValue returns true if the default value for this flag represents diff --git a/vendor/github.com/spf13/pflag/string_array.go b/vendor/github.com/spf13/pflag/string_array.go index 93b4e43..f320f2e 100644 --- a/vendor/github.com/spf13/pflag/string_array.go +++ b/vendor/github.com/spf13/pflag/string_array.go @@ -2,6 +2,7 @@ package pflag import ( "fmt" + "strings" ) var _ = fmt.Fprint @@ -39,7 +40,7 @@ func (s *stringArrayValue) String() string { } func stringArrayConv(sval string) (interface{}, error) { - sval = sval[1 : len(sval)-1] + sval = strings.Trim(sval, "[]") // An empty string would cause a array with one (empty) string if len(sval) == 0 { return []string{}, nil diff --git a/vendor/github.com/spf13/pflag/string_slice.go b/vendor/github.com/spf13/pflag/string_slice.go index 7829cfa..51e3c5d 100644 --- a/vendor/github.com/spf13/pflag/string_slice.go +++ b/vendor/github.com/spf13/pflag/string_slice.go @@ -66,7 +66,7 @@ func (s *stringSliceValue) String() string { } func stringSliceConv(sval string) (interface{}, error) { - sval = sval[1 : len(sval)-1] + sval = strings.Trim(sval, "[]") // An empty string would cause a slice with one (empty) string if len(sval) == 0 { return []string{}, nil diff --git a/vendor/github.com/ugorji/go/codec/0doc.go b/vendor/github.com/ugorji/go/codec/0doc.go index 209f9eb..caa7e0a 100644 --- a/vendor/github.com/ugorji/go/codec/0doc.go +++ b/vendor/github.com/ugorji/go/codec/0doc.go @@ -64,11 +64,10 @@ Rich Feature Set includes: - Never silently skip data when decoding. User decides whether to return an error or silently skip data when keys or indexes in the data stream do not map to fields in the struct. - - Detect and error when encoding a cyclic reference (instead of stack overflow shutdown) - Encode/Decode from/to chan types (for iterative streaming support) - Drop-in replacement for encoding/json. `json:` key in struct tag supported. - Provides a RPC Server and Client Codec for net/rpc communication protocol. - - Handle unique idiosyncrasies of codecs e.g. + - Handle unique idiosynchracies of codecs e.g. - For messagepack, configure how ambiguities in handling raw bytes are resolved - For messagepack, provide rpc server/client codec to support msgpack-rpc protocol defined at: @@ -172,8 +171,6 @@ package codec // TODO: // -// - optimization for codecgen: -// if len of entity is <= 3 words, then support a value receiver for encode. // - (En|De)coder should store an error when it occurs. // Until reset, subsequent calls return that error that was stored. // This means that free panics must go away. @@ -181,19 +178,16 @@ package codec // - Decoding using a chan is good, but incurs concurrency costs. // This is because there's no fast way to use a channel without it // having to switch goroutines constantly. -// Callback pattern is still the best. Maybe consider supporting something like: +// Callback pattern is still the best. Maybe cnsider supporting something like: // type X struct { // Name string // Ys []Y // Ys chan <- Y -// Ys func(Y) -> call this function for each entry +// Ys func(interface{}) -> call this interface for each entry in there. // } // - Consider adding a isZeroer interface { isZero() bool } // It is used within isEmpty, for omitEmpty support. // - Consider making Handle used AS-IS within the encoding/decoding session. // This means that we don't cache Handle information within the (En|De)coder, // except we really need it at Reset(...) -// - Consider adding math/big support -// - Consider reducing the size of the generated functions: -// Maybe use one loop, and put the conditionals in the loop. -// for ... { if cLen > 0 { if j == cLen { break } } else if dd.CheckBreak() { break } } +// - Handle recursive types during encoding/decoding? diff --git a/vendor/github.com/ugorji/go/codec/README.md b/vendor/github.com/ugorji/go/codec/README.md index 91cb3a2..a790a52 100644 --- a/vendor/github.com/ugorji/go/codec/README.md +++ b/vendor/github.com/ugorji/go/codec/README.md @@ -68,7 +68,7 @@ Rich Feature Set includes: - Encode/Decode from/to chan types (for iterative streaming support) - Drop-in replacement for encoding/json. `json:` key in struct tag supported. - Provides a RPC Server and Client Codec for net/rpc communication protocol. - - Handle unique idiosyncrasies of codecs e.g. + - Handle unique idiosynchracies of codecs e.g. - For messagepack, configure how ambiguities in handling raw bytes are resolved - For messagepack, provide rpc server/client codec to support msgpack-rpc protocol defined at: diff --git a/vendor/github.com/ugorji/go/codec/binc.go b/vendor/github.com/ugorji/go/codec/binc.go index 33120dc..c884d14 100644 --- a/vendor/github.com/ugorji/go/codec/binc.go +++ b/vendor/github.com/ugorji/go/codec/binc.go @@ -348,13 +348,6 @@ func (d *bincDecDriver) readNextBd() { d.bdRead = true } -func (d *bincDecDriver) uncacheRead() { - if d.bdRead { - d.r.unreadn1() - d.bdRead = false - } -} - func (d *bincDecDriver) ContainerType() (vt valueType) { if d.vd == bincVdSpecial && d.vs == bincSpNil { return valueTypeNil @@ -712,7 +705,7 @@ func (d *bincDecDriver) decStringAndBytes(bs []byte, withString, zerocopy bool) } func (d *bincDecDriver) DecodeString() (s string) { - // DecodeBytes does not accommodate symbols, whose impl stores string version in map. + // DecodeBytes does not accomodate symbols, whose impl stores string version in map. // Use decStringAndBytes directly. // return string(d.DecodeBytes(d.b[:], true, true)) _, s = d.decStringAndBytes(d.b[:], true, true) @@ -915,14 +908,10 @@ func (h *BincHandle) newDecDriver(d *Decoder) decDriver { func (e *bincEncDriver) reset() { e.w = e.e.w - e.s = 0 - e.m = nil } func (d *bincDecDriver) reset() { d.r = d.d.r - d.s = nil - d.bd, d.bdRead, d.vd, d.vs = 0, false, 0, 0 } var _ decDriver = (*bincDecDriver)(nil) diff --git a/vendor/github.com/ugorji/go/codec/cbor.go b/vendor/github.com/ugorji/go/codec/cbor.go index 4fa349a..0e5d32b 100644 --- a/vendor/github.com/ugorji/go/codec/cbor.go +++ b/vendor/github.com/ugorji/go/codec/cbor.go @@ -188,13 +188,6 @@ func (d *cborDecDriver) readNextBd() { d.bdRead = true } -func (d *cborDecDriver) uncacheRead() { - if d.bdRead { - d.r.unreadn1() - d.bdRead = false - } -} - func (d *cborDecDriver) ContainerType() (vt valueType) { if d.bd == cborBdNil { return valueTypeNil @@ -515,7 +508,7 @@ func (d *cborDecDriver) DecodeNaked() { n.v = valueTypeExt n.u = d.decUint() n.l = nil - // d.bdRead = false + d.bdRead = false // d.d.decode(&re.Value) // handled by decode itself. // decodeFurther = true default: @@ -585,7 +578,6 @@ func (e *cborEncDriver) reset() { func (d *cborDecDriver) reset() { d.r = d.d.r - d.bd, d.bdRead = 0, false } var _ decDriver = (*cborDecDriver)(nil) diff --git a/vendor/github.com/ugorji/go/codec/decode.go b/vendor/github.com/ugorji/go/codec/decode.go index 52c1dfe..b3b99f0 100644 --- a/vendor/github.com/ugorji/go/codec/decode.go +++ b/vendor/github.com/ugorji/go/codec/decode.go @@ -91,12 +91,10 @@ type decDriver interface { uncacheRead() } -type decNoSeparator struct { -} +type decNoSeparator struct{} -func (_ decNoSeparator) ReadEnd() {} - -// func (_ decNoSeparator) uncacheRead() {} +func (_ decNoSeparator) ReadEnd() {} +func (_ decNoSeparator) uncacheRead() {} type DecodeOptions struct { // MapType specifies type to use during schema-less decoding of a map in the stream. @@ -163,15 +161,6 @@ type DecodeOptions struct { // Note: Handles will be smart when using the intern functionality. // So everything will not be interned. InternString bool - - // PreferArrayOverSlice controls whether to decode to an array or a slice. - // - // This only impacts decoding into a nil interface{}. - // Consequently, it has no effect on codecgen. - // - // *Note*: This only applies if using go1.5 and above, - // as it requires reflect.ArrayOf support which was absent before go1.5. - PreferArrayOverSlice bool } // ------------------------------------ @@ -444,10 +433,6 @@ func (f *decFnInfo) rawExt(rv reflect.Value) { f.d.d.DecodeExt(rv.Addr().Interface(), 0, nil) } -func (f *decFnInfo) raw(rv reflect.Value) { - rv.SetBytes(f.d.raw()) -} - func (f *decFnInfo) ext(rv reflect.Value) { f.d.d.DecodeExt(rv.Addr().Interface(), f.xfTag, f.xfFn) } @@ -598,16 +583,14 @@ func (f *decFnInfo) kInterfaceNaked() (rvn reflect.Value) { if d.mtid == 0 || d.mtid == mapIntfIntfTypId { l := len(n.ms) n.ms = append(n.ms, nil) - var v2 interface{} = &n.ms[l] - d.decode(v2) - rvn = reflect.ValueOf(v2).Elem() + d.decode(&n.ms[l]) + rvn = reflect.ValueOf(&n.ms[l]).Elem() n.ms = n.ms[:l] } else if d.mtid == mapStrIntfTypId { // for json performance l := len(n.ns) n.ns = append(n.ns, nil) - var v2 interface{} = &n.ns[l] - d.decode(v2) - rvn = reflect.ValueOf(v2).Elem() + d.decode(&n.ns[l]) + rvn = reflect.ValueOf(&n.ns[l]).Elem() n.ns = n.ns[:l] } else { rvn = reflect.New(d.h.MapType).Elem() @@ -618,13 +601,9 @@ func (f *decFnInfo) kInterfaceNaked() (rvn reflect.Value) { if d.stid == 0 || d.stid == intfSliceTypId { l := len(n.ss) n.ss = append(n.ss, nil) - var v2 interface{} = &n.ss[l] - d.decode(v2) + d.decode(&n.ss[l]) + rvn = reflect.ValueOf(&n.ss[l]).Elem() n.ss = n.ss[:l] - rvn = reflect.ValueOf(v2).Elem() - if reflectArrayOfSupported && d.stid == 0 && d.h.PreferArrayOverSlice { - rvn = reflectArrayOf(rvn) - } } else { rvn = reflect.New(d.h.SliceType).Elem() d.decodeValue(rvn, nil) @@ -636,9 +615,9 @@ func (f *decFnInfo) kInterfaceNaked() (rvn reflect.Value) { l := len(n.is) n.is = append(n.is, nil) v2 := &n.is[l] + n.is = n.is[:l] d.decode(v2) v = *v2 - n.is = n.is[:l] } bfn := d.h.getExtForTag(tag) if bfn == nil { @@ -1187,7 +1166,7 @@ type decRtidFn struct { // primitives are being decoded. // // maps and arrays are not handled by this mechanism. -// However, RawExt is, and we accommodate for extensions that decode +// However, RawExt is, and we accomodate for extensions that decode // RawExt from DecodeNaked, but need to decode the value subsequently. // kInterfaceNaked and swallow, which call DecodeNaked, handle this caveat. // @@ -1474,8 +1453,8 @@ func (d *Decoder) swallow() { l := len(n.is) n.is = append(n.is, nil) v2 := &n.is[l] - d.decode(v2) n.is = n.is[:l] + d.decode(v2) } } } @@ -1525,8 +1504,6 @@ func (d *Decoder) decode(iv interface{}) { *v = 0 case *[]uint8: *v = nil - case *Raw: - *v = nil case reflect.Value: if v.Kind() != reflect.Ptr || v.IsNil() { d.errNotValidPtrValue(v) @@ -1566,6 +1543,7 @@ func (d *Decoder) decode(iv interface{}) { d.decodeValueNotNil(v.Elem(), nil) case *string: + *v = d.d.DecodeString() case *bool: *v = d.d.DecodeBool() @@ -1596,9 +1574,6 @@ func (d *Decoder) decode(iv interface{}) { case *[]uint8: *v = d.d.DecodeBytes(*v, false, false) - case *Raw: - *v = d.raw() - case *interface{}: d.decodeValueNotNil(reflect.ValueOf(iv).Elem(), nil) @@ -1720,8 +1695,6 @@ func (d *Decoder) getDecFn(rt reflect.Type, checkFastpath, checkCodecSelfer bool fn.f = (*decFnInfo).selferUnmarshal } else if rtid == rawExtTypId { fn.f = (*decFnInfo).rawExt - } else if rtid == rawTypId { - fn.f = (*decFnInfo).raw } else if d.d.IsBuiltinType(rtid) { fn.f = (*decFnInfo).builtin } else if xfFn := d.h.getExt(rtid); xfFn != nil { @@ -1820,13 +1793,12 @@ func (d *Decoder) getDecFn(rt reflect.Type, checkFastpath, checkCodecSelfer bool } func (d *Decoder) structFieldNotFound(index int, rvkencname string) { - // NOTE: rvkencname may be a stringView, so don't pass it to another function. if d.h.ErrorIfNoField { if index >= 0 { d.errorf("no matching struct field found when decoding stream array at index %v", index) return } else if rvkencname != "" { - d.errorf("no matching struct field found when decoding stream map with key " + rvkencname) + d.errorf("no matching struct field found when decoding stream map with key %s", rvkencname) return } } @@ -1890,7 +1862,6 @@ func (d *Decoder) intern(s string) { } } -// nextValueBytes returns the next value in the stream as a set of bytes. func (d *Decoder) nextValueBytes() []byte { d.d.uncacheRead() d.r.track() @@ -1898,15 +1869,6 @@ func (d *Decoder) nextValueBytes() []byte { return d.r.stopTrack() } -func (d *Decoder) raw() []byte { - // ensure that this is not a view into the bytes - // i.e. make new copy always. - bs := d.nextValueBytes() - bs2 := make([]byte, len(bs)) - copy(bs2, bs) - return bs2 -} - // -------------------------------------------------- // decSliceHelper assists when decoding into a slice, from a map or an array in the stream. diff --git a/vendor/github.com/ugorji/go/codec/decode_go.go b/vendor/github.com/ugorji/go/codec/decode_go.go deleted file mode 100644 index ba289ce..0000000 --- a/vendor/github.com/ugorji/go/codec/decode_go.go +++ /dev/null @@ -1,16 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// +build go1.5 - -package codec - -import "reflect" - -const reflectArrayOfSupported = true - -func reflectArrayOf(rvn reflect.Value) (rvn2 reflect.Value) { - rvn2 = reflect.New(reflect.ArrayOf(rvn.Len(), intfTyp)).Elem() - reflect.Copy(rvn2, rvn) - return -} diff --git a/vendor/github.com/ugorji/go/codec/decode_go14.go b/vendor/github.com/ugorji/go/codec/decode_go14.go deleted file mode 100644 index 50063bc..0000000 --- a/vendor/github.com/ugorji/go/codec/decode_go14.go +++ /dev/null @@ -1,14 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// +build !go1.5 - -package codec - -import "reflect" - -const reflectArrayOfSupported = false - -func reflectArrayOf(rvn reflect.Value) (rvn2 reflect.Value) { - panic("reflect.ArrayOf unsupported") -} diff --git a/vendor/github.com/ugorji/go/codec/encode.go b/vendor/github.com/ugorji/go/codec/encode.go index 28ad347..99af6fa 100644 --- a/vendor/github.com/ugorji/go/codec/encode.go +++ b/vendor/github.com/ugorji/go/codec/encode.go @@ -110,28 +110,6 @@ type EncodeOptions struct { // Canonical bool - // CheckCircularRef controls whether we check for circular references - // and error fast during an encode. - // - // If enabled, an error is received if a pointer to a struct - // references itself either directly or through one of its fields (iteratively). - // - // This is opt-in, as there may be a performance hit to checking circular references. - CheckCircularRef bool - - // RecursiveEmptyCheck controls whether we descend into interfaces, structs and pointers - // when checking if a value is empty. - // - // Note that this may make OmitEmpty more expensive, as it incurs a lot more reflect calls. - RecursiveEmptyCheck bool - - // Raw controls whether we encode Raw values. - // This is a "dangerous" option and must be explicitly set. - // If set, we blindly encode Raw values as-is, without checking - // if they are a correct representation of a value in that format. - // If unset, we error out. - Raw bool - // AsSymbols defines what should be encoded as symbols. // // Encoding as symbols can reduce the encoded size significantly. @@ -154,16 +132,13 @@ type simpleIoEncWriterWriter struct { w io.Writer bw io.ByteWriter sw ioEncStringWriter - bs [1]byte } func (o *simpleIoEncWriterWriter) WriteByte(c byte) (err error) { if o.bw != nil { return o.bw.WriteByte(c) } - // _, err = o.w.Write([]byte{c}) - o.bs[0] = c - _, err = o.w.Write(o.bs[:]) + _, err = o.w.Write([]byte{c}) return } @@ -255,8 +230,8 @@ func (z *bytesEncWriter) writen1(b1 byte) { func (z *bytesEncWriter) writen2(b1 byte, b2 byte) { c := z.grow(2) - z.b[c+1] = b2 z.b[c] = b1 + z.b[c+1] = b2 } func (z *bytesEncWriter) atEndOfEncode() { @@ -295,10 +270,6 @@ func (f *encFnInfo) builtin(rv reflect.Value) { f.e.e.EncodeBuiltin(f.ti.rtid, rv.Interface()) } -func (f *encFnInfo) raw(rv reflect.Value) { - f.e.raw(rv.Interface().(Raw)) -} - func (f *encFnInfo) rawExt(rv reflect.Value) { // rev := rv.Interface().(RawExt) // f.e.e.EncodeRawExt(&rev, f.e) @@ -325,7 +296,7 @@ func (f *encFnInfo) getValueForMarshalInterface(rv reflect.Value, indir int8) (v v = rv.Interface() } else if indir == -1 { // If a non-pointer was passed to Encode(), then that value is not addressable. - // Take addr if addressable, else copy value to an addressable value. + // Take addr if addresable, else copy value to an addressable value. if rv.CanAddr() { v = rv.Addr().Interface() } else { @@ -493,7 +464,7 @@ func (f *encFnInfo) kSlice(rv reflect.Value) { for j := 0; j < l; j++ { if cr != nil { if ti.mbs { - if j%2 == 0 { + if l%2 == 0 { cr.sendContainerState(containerMapKey) } else { cr.sendContainerState(containerMapValue) @@ -532,7 +503,7 @@ func (f *encFnInfo) kStruct(rv reflect.Value) { newlen := len(fti.sfi) // Use sync.Pool to reduce allocating slices unnecessarily. - // The cost of sync.Pool is less than the cost of new allocation. + // The cost of the occasional locking is less than the cost of new allocation. pool, poolv, fkvs := encStructPoolGet(newlen) // if toMap, use the sorted array. If toArray, use unsorted array (to match sequence in struct) @@ -541,20 +512,25 @@ func (f *encFnInfo) kStruct(rv reflect.Value) { } newlen = 0 var kv stringRv - recur := e.h.RecursiveEmptyCheck for _, si := range tisfi { kv.r = si.field(rv, false) + // if si.i != -1 { + // rvals[newlen] = rv.Field(int(si.i)) + // } else { + // rvals[newlen] = rv.FieldByIndex(si.is) + // } if toMap { - if si.omitEmpty && isEmptyValue(kv.r, recur, recur) { + if si.omitEmpty && isEmptyValue(kv.r) { continue } kv.v = si.encName } else { // use the zero value. // if a reference or struct, set to nil (so you do not output too much) - if si.omitEmpty && isEmptyValue(kv.r, recur, recur) { + if si.omitEmpty && isEmptyValue(kv.r) { switch kv.r.Kind() { - case reflect.Struct, reflect.Interface, reflect.Ptr, reflect.Array, reflect.Map, reflect.Slice: + case reflect.Struct, reflect.Interface, reflect.Ptr, reflect.Array, + reflect.Map, reflect.Slice: kv.r = reflect.Value{} //encode as nil } } @@ -565,7 +541,7 @@ func (f *encFnInfo) kStruct(rv reflect.Value) { // debugf(">>>> kStruct: newlen: %v", newlen) // sep := !e.be - ee := e.e //don't dereference every time + ee := e.e //don't dereference everytime if toMap { ee.EncodeMapStart(newlen) @@ -620,15 +596,13 @@ func (f *encFnInfo) kStruct(rv reflect.Value) { // f.e.encodeValue(rv.Elem()) // } -// func (f *encFnInfo) kInterface(rv reflect.Value) { -// println("kInterface called") -// debug.PrintStack() -// if rv.IsNil() { -// f.e.e.EncodeNil() -// return -// } -// f.e.encodeValue(rv.Elem(), nil) -// } +func (f *encFnInfo) kInterface(rv reflect.Value) { + if rv.IsNil() { + f.e.e.EncodeNil() + return + } + f.e.encodeValue(rv.Elem(), nil) +} func (f *encFnInfo) kMap(rv reflect.Value) { ee := f.e.e @@ -903,7 +877,6 @@ type Encoder struct { // as the handler MAY need to do some coordination. w encWriter s []encRtidFn - ci set be bool // is binary encoding js bool // is json handle @@ -952,7 +925,7 @@ func newEncoder(h Handle) *Encoder { // Reset the Encoder with a new output stream. // -// This accommodates using the state of the Encoder, +// This accomodates using the state of the Encoder, // where it has "cached" information about sub-engines. func (e *Encoder) Reset(w io.Writer) { ww, ok := w.(ioEncWriterWriter) @@ -1084,8 +1057,7 @@ func (e *Encoder) encode(iv interface{}) { e.e.EncodeNil() case Selfer: v.CodecEncodeSelf(e) - case Raw: - e.raw(v) + case reflect.Value: e.encodeValue(v, nil) @@ -1161,23 +1133,20 @@ func (e *Encoder) encode(iv interface{}) { } } -func (e *Encoder) preEncodeValue(rv reflect.Value) (rv2 reflect.Value, sptr uintptr, proceed bool) { +func (e *Encoder) encodeI(iv interface{}, checkFastpath, checkCodecSelfer bool) { + if rv, proceed := e.preEncodeValue(reflect.ValueOf(iv)); proceed { + rt := rv.Type() + rtid := reflect.ValueOf(rt).Pointer() + fn := e.getEncFn(rtid, rt, checkFastpath, checkCodecSelfer) + fn.f(&fn.i, rv) + } +} + +func (e *Encoder) preEncodeValue(rv reflect.Value) (rv2 reflect.Value, proceed bool) { // use a goto statement instead of a recursive function for ptr/interface. TOP: switch rv.Kind() { - case reflect.Ptr: - if rv.IsNil() { - e.e.EncodeNil() - return - } - rv = rv.Elem() - if e.h.CheckCircularRef && rv.Kind() == reflect.Struct { - // TODO: Movable pointers will be an issue here. Future problem. - sptr = rv.UnsafeAddr() - break TOP - } - goto TOP - case reflect.Interface: + case reflect.Ptr, reflect.Interface: if rv.IsNil() { e.e.EncodeNil() return @@ -1194,40 +1163,18 @@ TOP: return } - proceed = true - rv2 = rv - return -} - -func (e *Encoder) doEncodeValue(rv reflect.Value, fn *encFn, sptr uintptr, - checkFastpath, checkCodecSelfer bool) { - if sptr != 0 { - if (&e.ci).add(sptr) { - e.errorf("circular reference found: # %d", sptr) - } - } - if fn == nil { - rt := rv.Type() - rtid := reflect.ValueOf(rt).Pointer() - // fn = e.getEncFn(rtid, rt, true, true) - fn = e.getEncFn(rtid, rt, checkFastpath, checkCodecSelfer) - } - fn.f(&fn.i, rv) - if sptr != 0 { - (&e.ci).remove(sptr) - } -} - -func (e *Encoder) encodeI(iv interface{}, checkFastpath, checkCodecSelfer bool) { - if rv, sptr, proceed := e.preEncodeValue(reflect.ValueOf(iv)); proceed { - e.doEncodeValue(rv, nil, sptr, checkFastpath, checkCodecSelfer) - } + return rv, true } func (e *Encoder) encodeValue(rv reflect.Value, fn *encFn) { // if a valid fn is passed, it MUST BE for the dereferenced type of rv - if rv, sptr, proceed := e.preEncodeValue(rv); proceed { - e.doEncodeValue(rv, fn, sptr, true, true) + if rv, proceed := e.preEncodeValue(rv); proceed { + if fn == nil { + rt := rv.Type() + rtid := reflect.ValueOf(rt).Pointer() + fn = e.getEncFn(rtid, rt, true, true) + } + fn.f(&fn.i, rv) } } @@ -1270,8 +1217,6 @@ func (e *Encoder) getEncFn(rtid uintptr, rt reflect.Type, checkFastpath, checkCo if checkCodecSelfer && ti.cs { fn.f = (*encFnInfo).selferMarshal - } else if rtid == rawTypId { - fn.f = (*encFnInfo).raw } else if rtid == rawExtTypId { fn.f = (*encFnInfo).rawExt } else if e.e.IsBuiltinType(rtid) { @@ -1289,7 +1234,7 @@ func (e *Encoder) getEncFn(rtid uintptr, rt reflect.Type, checkFastpath, checkCo } else { rk := rt.Kind() if fastpathEnabled && checkFastpath && (rk == reflect.Map || rk == reflect.Slice) { - if rt.PkgPath() == "" { // un-named slice or map + if rt.PkgPath() == "" { if idx := fastpathAV.index(rtid); idx != -1 { fn.f = fastpathAV[idx].encfn } @@ -1339,11 +1284,10 @@ func (e *Encoder) getEncFn(rtid uintptr, rt reflect.Type, checkFastpath, checkCo fn.f = (*encFnInfo).kSlice case reflect.Struct: fn.f = (*encFnInfo).kStruct - // reflect.Ptr and reflect.Interface are handled already by preEncodeValue // case reflect.Ptr: // fn.f = (*encFnInfo).kPtr - // case reflect.Interface: - // fn.f = (*encFnInfo).kInterface + case reflect.Interface: + fn.f = (*encFnInfo).kInterface case reflect.Map: fn.f = (*encFnInfo).kMap default: @@ -1376,18 +1320,6 @@ func (e *Encoder) asis(v []byte) { } } -func (e *Encoder) raw(vv Raw) { - v := []byte(vv) - if !e.h.Raw { - e.errorf("Raw values cannot be encoded: %v", v) - } - if e.as == nil { - e.w.writeb(v) - } else { - e.as.EncodeAsis(v) - } -} - func (e *Encoder) errorf(format string, params ...interface{}) { err := fmt.Errorf(format, params...) panic(err) @@ -1421,6 +1353,25 @@ func encStructPoolGet(newlen int) (p *sync.Pool, v interface{}, s []stringRv) { // panic(errors.New("encStructPoolLen must be equal to 4")) // defensive, in case it is changed // } // idxpool := newlen / 8 + + // if pool == nil { + // fkvs = make([]stringRv, newlen) + // } else { + // poolv = pool.Get() + // switch vv := poolv.(type) { + // case *[8]stringRv: + // fkvs = vv[:newlen] + // case *[16]stringRv: + // fkvs = vv[:newlen] + // case *[32]stringRv: + // fkvs = vv[:newlen] + // case *[64]stringRv: + // fkvs = vv[:newlen] + // case *[128]stringRv: + // fkvs = vv[:newlen] + // } + // } + if newlen <= 8 { p = &encStructPool[0] v = p.Get() diff --git a/vendor/github.com/ugorji/go/codec/fast-path.generated.go b/vendor/github.com/ugorji/go/codec/fast-path.generated.go index f2e5d2d..d968a50 100644 --- a/vendor/github.com/ugorji/go/codec/fast-path.generated.go +++ b/vendor/github.com/ugorji/go/codec/fast-path.generated.go @@ -23,7 +23,7 @@ package codec // Currently support // - slice of all builtin types, // - map of all builtin types to string or interface value -// - symmetrical maps of all builtin types (e.g. str-str, uint8-uint8) +// - symetrical maps of all builtin types (e.g. str-str, uint8-uint8) // This should provide adequate "typical" implementations. // // Note that fast track decode functions must handle values for which an address cannot be obtained. @@ -38,8 +38,6 @@ import ( "sort" ) -const fastpathEnabled = true - const fastpathCheckNilFalse = false // for reflect const fastpathCheckNilTrue = true // for type switch @@ -83,6 +81,9 @@ var fastpathAV fastpathA // due to possible initialization loop error, make fastpath in an init() func init() { + if !fastpathEnabled { + return + } i := 0 fn := func(v interface{}, fe func(*encFnInfo, reflect.Value), fd func(*decFnInfo, reflect.Value)) (f fastpathE) { xrt := reflect.TypeOf(v) @@ -372,6 +373,9 @@ func init() { // -- -- fast path type switch func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { case []interface{}: @@ -1737,6 +1741,9 @@ func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { } func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { case []interface{}: @@ -1822,6 +1829,9 @@ func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { } func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { case map[interface{}]interface{}: @@ -3114,11 +3124,7 @@ func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { // -- -- fast path functions func (f *encFnInfo) fastpathEncSliceIntfR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceIntfV(rv.Interface().([]interface{}), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceIntfV(rv.Interface().([]interface{}), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceIntfV(rv.Interface().([]interface{}), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceIntfV(v []interface{}, checkNil bool, e *Encoder) { ee := e.e @@ -3139,39 +3145,8 @@ func (_ fastpathT) EncSliceIntfV(v []interface{}, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceIntfV(v []interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - e.encode(v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceStringR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceStringV(rv.Interface().([]string), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceStringV(rv.Interface().([]string), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceStringV(rv.Interface().([]string), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceStringV(v []string, checkNil bool, e *Encoder) { ee := e.e @@ -3192,39 +3167,8 @@ func (_ fastpathT) EncSliceStringV(v []string, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceStringV(v []string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeString(c_UTF8, v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceFloat32R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceFloat32V(rv.Interface().([]float32), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceFloat32V(rv.Interface().([]float32), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceFloat32V(rv.Interface().([]float32), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceFloat32V(v []float32, checkNil bool, e *Encoder) { ee := e.e @@ -3245,39 +3189,8 @@ func (_ fastpathT) EncSliceFloat32V(v []float32, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceFloat32V(v []float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeFloat32(v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceFloat64R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceFloat64V(rv.Interface().([]float64), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceFloat64V(rv.Interface().([]float64), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceFloat64V(rv.Interface().([]float64), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceFloat64V(v []float64, checkNil bool, e *Encoder) { ee := e.e @@ -3298,39 +3211,8 @@ func (_ fastpathT) EncSliceFloat64V(v []float64, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceFloat64V(v []float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeFloat64(v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceUintR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceUintV(rv.Interface().([]uint), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceUintV(rv.Interface().([]uint), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceUintV(rv.Interface().([]uint), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceUintV(v []uint, checkNil bool, e *Encoder) { ee := e.e @@ -3351,39 +3233,8 @@ func (_ fastpathT) EncSliceUintV(v []uint, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceUintV(v []uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceUint16R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceUint16V(rv.Interface().([]uint16), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceUint16V(rv.Interface().([]uint16), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceUint16V(rv.Interface().([]uint16), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceUint16V(v []uint16, checkNil bool, e *Encoder) { ee := e.e @@ -3404,39 +3255,8 @@ func (_ fastpathT) EncSliceUint16V(v []uint16, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceUint16V(v []uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceUint32R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceUint32V(rv.Interface().([]uint32), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceUint32V(rv.Interface().([]uint32), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceUint32V(rv.Interface().([]uint32), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceUint32V(v []uint32, checkNil bool, e *Encoder) { ee := e.e @@ -3457,39 +3277,8 @@ func (_ fastpathT) EncSliceUint32V(v []uint32, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceUint32V(v []uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceUint64R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceUint64V(rv.Interface().([]uint64), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceUint64V(rv.Interface().([]uint64), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceUint64V(rv.Interface().([]uint64), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceUint64V(v []uint64, checkNil bool, e *Encoder) { ee := e.e @@ -3510,39 +3299,8 @@ func (_ fastpathT) EncSliceUint64V(v []uint64, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceUint64V(v []uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceUintptrR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceUintptrV(rv.Interface().([]uintptr), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceUintptrV(rv.Interface().([]uintptr), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceUintptrV(rv.Interface().([]uintptr), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceUintptrV(v []uintptr, checkNil bool, e *Encoder) { ee := e.e @@ -3563,39 +3321,8 @@ func (_ fastpathT) EncSliceUintptrV(v []uintptr, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceUintptrV(v []uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - e.encode(v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceIntR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceIntV(rv.Interface().([]int), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceIntV(rv.Interface().([]int), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceIntV(rv.Interface().([]int), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceIntV(v []int, checkNil bool, e *Encoder) { ee := e.e @@ -3616,39 +3343,8 @@ func (_ fastpathT) EncSliceIntV(v []int, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceIntV(v []int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceInt8R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceInt8V(rv.Interface().([]int8), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceInt8V(rv.Interface().([]int8), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceInt8V(rv.Interface().([]int8), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceInt8V(v []int8, checkNil bool, e *Encoder) { ee := e.e @@ -3669,39 +3365,8 @@ func (_ fastpathT) EncSliceInt8V(v []int8, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceInt8V(v []int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceInt16R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceInt16V(rv.Interface().([]int16), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceInt16V(rv.Interface().([]int16), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceInt16V(rv.Interface().([]int16), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceInt16V(v []int16, checkNil bool, e *Encoder) { ee := e.e @@ -3722,39 +3387,8 @@ func (_ fastpathT) EncSliceInt16V(v []int16, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceInt16V(v []int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceInt32R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceInt32V(rv.Interface().([]int32), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceInt32V(rv.Interface().([]int32), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceInt32V(rv.Interface().([]int32), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceInt32V(v []int32, checkNil bool, e *Encoder) { ee := e.e @@ -3775,39 +3409,8 @@ func (_ fastpathT) EncSliceInt32V(v []int32, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceInt32V(v []int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceInt64R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceInt64V(rv.Interface().([]int64), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceInt64V(rv.Interface().([]int64), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceInt64V(rv.Interface().([]int64), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceInt64V(v []int64, checkNil bool, e *Encoder) { ee := e.e @@ -3828,39 +3431,8 @@ func (_ fastpathT) EncSliceInt64V(v []int64, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceInt64V(v []int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncSliceBoolR(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.EncAsMapSliceBoolV(rv.Interface().([]bool), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.EncSliceBoolV(rv.Interface().([]bool), fastpathCheckNilFalse, f.e) - } + fastpathTV.EncSliceBoolV(rv.Interface().([]bool), fastpathCheckNilFalse, f.e) } func (_ fastpathT) EncSliceBoolV(v []bool, checkNil bool, e *Encoder) { ee := e.e @@ -3881,33 +3453,6 @@ func (_ fastpathT) EncSliceBoolV(v []bool, checkNil bool, e *Encoder) { } } -func (_ fastpathT) EncAsMapSliceBoolV(v []bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - ee.EncodeBool(v2) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - func (f *encFnInfo) fastpathEncMapIntfIntfR(rv reflect.Value) { fastpathTV.EncMapIntfIntfV(rv.Interface().(map[interface{}]interface{}), fastpathCheckNilFalse, f.e) } @@ -15944,6 +15489,9 @@ func (_ fastpathT) EncMapBoolBoolV(v map[bool]bool, checkNil bool, e *Encoder) { // -- -- fast path type switch func fastpathDecodeTypeSwitch(iv interface{}, d *Decoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { case []interface{}: @@ -18164,7 +17712,7 @@ func (_ fastpathT) DecSliceIntfV(v []interface{}, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18223,7 +17771,7 @@ func (_ fastpathT) DecSliceIntfV(v []interface{}, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]interface{}, 1, 4) @@ -18298,7 +17846,7 @@ func (_ fastpathT) DecSliceStringV(v []string, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18357,7 +17905,7 @@ func (_ fastpathT) DecSliceStringV(v []string, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]string, 1, 4) @@ -18431,7 +17979,7 @@ func (_ fastpathT) DecSliceFloat32V(v []float32, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18490,7 +18038,7 @@ func (_ fastpathT) DecSliceFloat32V(v []float32, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]float32, 1, 4) @@ -18564,7 +18112,7 @@ func (_ fastpathT) DecSliceFloat64V(v []float64, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18623,7 +18171,7 @@ func (_ fastpathT) DecSliceFloat64V(v []float64, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]float64, 1, 4) @@ -18697,7 +18245,7 @@ func (_ fastpathT) DecSliceUintV(v []uint, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18756,7 +18304,7 @@ func (_ fastpathT) DecSliceUintV(v []uint, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]uint, 1, 4) @@ -18830,7 +18378,7 @@ func (_ fastpathT) DecSliceUint16V(v []uint16, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -18889,7 +18437,7 @@ func (_ fastpathT) DecSliceUint16V(v []uint16, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]uint16, 1, 4) @@ -18963,7 +18511,7 @@ func (_ fastpathT) DecSliceUint32V(v []uint32, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19022,7 +18570,7 @@ func (_ fastpathT) DecSliceUint32V(v []uint32, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]uint32, 1, 4) @@ -19096,7 +18644,7 @@ func (_ fastpathT) DecSliceUint64V(v []uint64, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19155,7 +18703,7 @@ func (_ fastpathT) DecSliceUint64V(v []uint64, checkNil bool, canChange bool, d changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]uint64, 1, 4) @@ -19229,7 +18777,7 @@ func (_ fastpathT) DecSliceUintptrV(v []uintptr, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19288,7 +18836,7 @@ func (_ fastpathT) DecSliceUintptrV(v []uintptr, checkNil bool, canChange bool, changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]uintptr, 1, 4) @@ -19362,7 +18910,7 @@ func (_ fastpathT) DecSliceIntV(v []int, checkNil bool, canChange bool, d *Decod changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19421,7 +18969,7 @@ func (_ fastpathT) DecSliceIntV(v []int, checkNil bool, canChange bool, d *Decod changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]int, 1, 4) @@ -19495,7 +19043,7 @@ func (_ fastpathT) DecSliceInt8V(v []int8, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19554,7 +19102,7 @@ func (_ fastpathT) DecSliceInt8V(v []int8, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]int8, 1, 4) @@ -19628,7 +19176,7 @@ func (_ fastpathT) DecSliceInt16V(v []int16, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19687,7 +19235,7 @@ func (_ fastpathT) DecSliceInt16V(v []int16, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]int16, 1, 4) @@ -19761,7 +19309,7 @@ func (_ fastpathT) DecSliceInt32V(v []int32, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19820,7 +19368,7 @@ func (_ fastpathT) DecSliceInt32V(v []int32, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]int32, 1, 4) @@ -19894,7 +19442,7 @@ func (_ fastpathT) DecSliceInt64V(v []int64, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -19953,7 +19501,7 @@ func (_ fastpathT) DecSliceInt64V(v []int64, checkNil bool, canChange bool, d *D changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]int64, 1, 4) @@ -20027,7 +19575,7 @@ func (_ fastpathT) DecSliceBoolV(v []bool, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -20086,7 +19634,7 @@ func (_ fastpathT) DecSliceBoolV(v []bool, checkNil bool, canChange bool, d *Dec changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]bool, 1, 4) diff --git a/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl b/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl index c3ffdf9..58cc6df 100644 --- a/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl +++ b/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl @@ -23,7 +23,7 @@ package codec // Currently support // - slice of all builtin types, // - map of all builtin types to string or interface value -// - symmetrical maps of all builtin types (e.g. str-str, uint8-uint8) +// - symetrical maps of all builtin types (e.g. str-str, uint8-uint8) // This should provide adequate "typical" implementations. // // Note that fast track decode functions must handle values for which an address cannot be obtained. @@ -38,8 +38,6 @@ import ( "sort" ) -const fastpathEnabled = true - const fastpathCheckNilFalse = false // for reflect const fastpathCheckNilTrue = true // for type switch @@ -83,6 +81,9 @@ var fastpathAV fastpathA // due to possible initialization loop error, make fastpath in an init() func init() { + if !fastpathEnabled { + return + } i := 0 fn := func(v interface{}, fe func(*encFnInfo, reflect.Value), fd func(*decFnInfo, reflect.Value)) (f fastpathE) { xrt := reflect.TypeOf(v) @@ -105,6 +106,9 @@ func init() { // -- -- fast path type switch func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { {{range .Values}}{{if not .Primitive}}{{if not .MapKey }} case []{{ .Elem }}:{{else}} @@ -122,6 +126,9 @@ func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { } func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { {{range .Values}}{{if not .Primitive}}{{if not .MapKey }} case []{{ .Elem }}: @@ -137,6 +144,9 @@ func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { } func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { {{range .Values}}{{if not .Primitive}}{{if .MapKey }} case map[{{ .MapKey }}]{{ .Elem }}: @@ -155,11 +165,7 @@ func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { {{range .Values}}{{if not .Primitive}}{{if not .MapKey }} func (f *encFnInfo) {{ .MethodNamePfx "fastpathEnc" false }}R(rv reflect.Value) { - if f.ti.mbs { - fastpathTV.{{ .MethodNamePfx "EncAsMap" false }}V(rv.Interface().([]{{ .Elem }}), fastpathCheckNilFalse, f.e) - } else { - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(rv.Interface().([]{{ .Elem }}), fastpathCheckNilFalse, f.e) - } + fastpathTV.{{ .MethodNamePfx "Enc" false }}V(rv.Interface().([]{{ .Elem }}), fastpathCheckNilFalse, f.e) } func (_ fastpathT) {{ .MethodNamePfx "Enc" false }}V(v []{{ .Elem }}, checkNil bool, e *Encoder) { ee := e.e @@ -176,31 +182,6 @@ func (_ fastpathT) {{ .MethodNamePfx "Enc" false }}V(v []{{ .Elem }}, checkNil b if cr != nil { cr.sendContainerState(containerArrayEnd) }{{/* ee.EncodeEnd() */}} } -func (_ fastpathT) {{ .MethodNamePfx "EncAsMap" false }}V(v []{{ .Elem }}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - if len(v)%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", len(v)) - return - } - ee.EncodeMapStart(len(v) / 2) - for j, v2 := range v { - if cr != nil { - if j%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } - {{ encmd .Elem "v2"}} - } - if cr != nil { cr.sendContainerState(containerMapEnd) } -} - {{end}}{{end}}{{end}} {{range .Values}}{{if not .Primitive}}{{if .MapKey }} @@ -276,6 +257,9 @@ func (_ fastpathT) {{ .MethodNamePfx "Enc" false }}V(v map[{{ .MapKey }}]{{ .Ele // -- -- fast path type switch func fastpathDecodeTypeSwitch(iv interface{}, d *Decoder) bool { + if !fastpathEnabled { + return false + } switch v := iv.(type) { {{range .Values}}{{if not .Primitive}}{{if not .MapKey }} case []{{ .Elem }}:{{else}} @@ -344,7 +328,7 @@ func (_ fastpathT) {{ .MethodNamePfx "Dec" false }}V(v []{{ .Elem }}, checkNil b changed = true } slh.End() - return v, changed + return } if containerLenS > 0 { @@ -407,7 +391,7 @@ func (_ fastpathT) {{ .MethodNamePfx "Dec" false }}V(v []{{ .Elem }}, checkNil b changed = true } slh.End() - return v, changed + return } if cap(v) == 0 { v = make([]{{ .Elem }}, 1, 4) diff --git a/vendor/github.com/ugorji/go/codec/fast-path.not.go b/vendor/github.com/ugorji/go/codec/fast-path.not.go index 63e5911..d6f5f0c 100644 --- a/vendor/github.com/ugorji/go/codec/fast-path.not.go +++ b/vendor/github.com/ugorji/go/codec/fast-path.not.go @@ -4,8 +4,6 @@ package codec import "reflect" -const fastpathEnabled = false - // The generated fast-path code is very large, and adds a few seconds to the build time. // This causes test execution, execution of small tools which use codec, etc // to take a long time. diff --git a/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl b/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl index 32df541..2caae5b 100644 --- a/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl +++ b/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl @@ -1,7 +1,6 @@ {{var "v"}} := {{if not isArray}}*{{end}}{{ .Varname }} -{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}}{{if not isArray}} +{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}} var {{var "c"}} bool {{/* // changed */}} -_ = {{var "c"}}{{end}} if {{var "l"}} == 0 { {{if isSlice }}if {{var "v"}} == nil { {{var "v"}} = []{{ .Typ }}{} @@ -27,8 +26,6 @@ if {{var "l"}} == 0 { } {{ else }} var {{var "rr"}}, {{var "rl"}} int {{/* // num2read, length of slice/array/chan */}} var {{var "rt"}} bool {{/* truncated */}} - _, _ = {{var "rl"}}, {{var "rt"}} - {{var "rr"}} = {{var "l"}} // len({{var "v"}}) if {{var "l"}} > cap({{var "v"}}) { {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "l"}}) {{ else }}{{if not .Immutable }} diff --git a/vendor/github.com/ugorji/go/codec/gen-helper.generated.go b/vendor/github.com/ugorji/go/codec/gen-helper.generated.go index 96a6b61..22bce77 100644 --- a/vendor/github.com/ugorji/go/codec/gen-helper.generated.go +++ b/vendor/github.com/ugorji/go/codec/gen-helper.generated.go @@ -1,4 +1,4 @@ -// // +build ignore +// //+build ignore // Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. // Use of this source code is governed by a MIT license found in the LICENSE file. @@ -17,7 +17,7 @@ import ( // This file is used to generate helper code for codecgen. // The values here i.e. genHelper(En|De)coder are not to be used directly by -// library users. They WILL change continuously and without notice. +// library users. They WILL change continously and without notice. // // To help enforce this, we create an unexported type with exported members. // The only way to get the type is via the one exported type that we control (somewhat). @@ -83,11 +83,6 @@ func (f genHelperEncoder) EncBinaryMarshal(iv encoding.BinaryMarshaler) { f.e.marshal(bs, fnerr, false, c_RAW) } -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncRaw(iv Raw) { - f.e.raw(iv) -} - // FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* func (f genHelperEncoder) TimeRtidIfBinc() uintptr { if _, ok := f.e.hh.(*BincHandle); ok { @@ -196,11 +191,6 @@ func (f genHelperDecoder) DecBinaryUnmarshal(bm encoding.BinaryUnmarshaler) { } } -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecRaw() []byte { - return f.d.raw() -} - // FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* func (f genHelperDecoder) TimeRtidIfBinc() uintptr { if _, ok := f.d.hh.(*BincHandle); ok { diff --git a/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl b/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl index 9b276d4..3195857 100644 --- a/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl +++ b/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl @@ -1,4 +1,4 @@ -// // +build ignore +// //+build ignore // Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. // Use of this source code is governed by a MIT license found in the LICENSE file. @@ -17,7 +17,7 @@ import ( // This file is used to generate helper code for codecgen. // The values here i.e. genHelper(En|De)coder are not to be used directly by -// library users. They WILL change continuously and without notice. +// library users. They WILL change continously and without notice. // // To help enforce this, we create an unexported type with exported members. // The only way to get the type is via the one exported type that we control (somewhat). @@ -79,10 +79,6 @@ func (f genHelperEncoder) EncBinaryMarshal(iv encoding.BinaryMarshaler) { f.e.marshal(bs, fnerr, false, c_RAW) } // FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncRaw(iv Raw) { - f.e.raw(iv) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* func (f genHelperEncoder) TimeRtidIfBinc() uintptr { if _, ok := f.e.hh.(*BincHandle); ok { return timeTypId @@ -176,10 +172,6 @@ func (f genHelperDecoder) DecBinaryUnmarshal(bm encoding.BinaryUnmarshaler) { } } // FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecRaw() []byte { - return f.d.raw() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* func (f genHelperDecoder) TimeRtidIfBinc() uintptr { if _, ok := f.d.hh.(*BincHandle); ok { return timeTypId diff --git a/vendor/github.com/ugorji/go/codec/gen.generated.go b/vendor/github.com/ugorji/go/codec/gen.generated.go index 2ace97b..fb6f4b8 100644 --- a/vendor/github.com/ugorji/go/codec/gen.generated.go +++ b/vendor/github.com/ugorji/go/codec/gen.generated.go @@ -68,9 +68,8 @@ z.DecSendContainerState(codecSelfer_containerMapEnd{{ .Sfx }}) const genDecListTmpl = ` {{var "v"}} := {{if not isArray}}*{{end}}{{ .Varname }} -{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}}{{if not isArray}} +{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}} var {{var "c"}} bool {{/* // changed */}} -_ = {{var "c"}}{{end}} if {{var "l"}} == 0 { {{if isSlice }}if {{var "v"}} == nil { {{var "v"}} = []{{ .Typ }}{} @@ -96,8 +95,6 @@ if {{var "l"}} == 0 { } {{ else }} var {{var "rr"}}, {{var "rl"}} int {{/* // num2read, length of slice/array/chan */}} var {{var "rt"}} bool {{/* truncated */}} - _, _ = {{var "rl"}}, {{var "rt"}} - {{var "rr"}} = {{var "l"}} // len({{var "v"}}) if {{var "l"}} > cap({{var "v"}}) { {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "l"}}) {{ else }}{{if not .Immutable }} diff --git a/vendor/github.com/ugorji/go/codec/gen.go b/vendor/github.com/ugorji/go/codec/gen.go index 1a27675..a075e7c 100644 --- a/vendor/github.com/ugorji/go/codec/gen.go +++ b/vendor/github.com/ugorji/go/codec/gen.go @@ -12,6 +12,7 @@ import ( "io" "io/ioutil" "math/rand" + "os" "reflect" "regexp" "sort" @@ -20,14 +21,11 @@ import ( "sync" "text/template" "time" - "unicode" - "unicode/utf8" ) // --------------------------------------------------- // codecgen supports the full cycle of reflection-based codec: // - RawExt -// - Raw // - Builtins // - Extensions // - (Binary|Text|JSON)(Unm|M)arshal @@ -78,7 +76,7 @@ import ( // codecgen will panic if the file was generated with an old version of the library in use. // // Note: -// It was a conscious decision to have gen.go always explicitly call EncodeNil or TryDecodeAsNil. +// It was a concious decision to have gen.go always explicitly call EncodeNil or TryDecodeAsNil. // This way, there isn't a function call overhead just to see that we should not enter a block of code. // GenVersion is the current version of codecgen. @@ -126,7 +124,6 @@ var ( genExpectArrayOrMapErr = errors.New("unexpected type. Expecting array/map/slice") genBase64enc = base64.NewEncoding("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789__") genQNameRegex = regexp.MustCompile(`[A-Za-z_.]+`) - genCheckVendor bool ) // genRunner holds some state used during a Gen run. @@ -165,16 +162,6 @@ type genRunner struct { // // Library users: *DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE.* func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeInfos, typ ...reflect.Type) { - // trim out all types which already implement Selfer - typ2 := make([]reflect.Type, 0, len(typ)) - for _, t := range typ { - if reflect.PtrTo(t).Implements(selferTyp) || t.Implements(selferTyp) { - continue - } - typ2 = append(typ2, t) - } - typ = typ2 - if len(typ) == 0 { return } @@ -212,7 +199,7 @@ func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeIn x.genRefPkgs(t) } if buildTags != "" { - x.line("// +build " + buildTags) + x.line("//+build " + buildTags) x.line("") } x.line(` @@ -279,7 +266,6 @@ func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeIn x.line("type " + x.hn + " struct{}") x.line("") - x.varsfxreset() x.line("func init() {") x.linef("if %sGenVersion != %v {", x.cpfx, GenVersion) x.line("_, file, _, _ := runtime.Caller(0)") @@ -323,7 +309,6 @@ func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeIn for _, t := range x.ts { rtid := reflect.ValueOf(t).Pointer() // generate enc functions for all these slice/map types. - x.varsfxreset() x.linef("func (x %s) enc%s(v %s%s, e *%sEncoder) {", x.hn, x.genMethodNameT(t), x.arr2str(t, "*"), x.genTypeName(t), x.cpfx) x.genRequiredMethodVars(true) switch t.Kind() { @@ -338,7 +323,6 @@ func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeIn x.line("") // generate dec functions for all these slice/map types. - x.varsfxreset() x.linef("func (x %s) dec%s(v *%s, d *%sDecoder) {", x.hn, x.genMethodNameT(t), x.genTypeName(t), x.cpfx) x.genRequiredMethodVars(false) switch t.Kind() { @@ -393,7 +377,7 @@ func (x *genRunner) genRefPkgs(t reflect.Type) { x.imn[tpkg] = tpkg } else { x.imc++ - x.imn[tpkg] = "pkg" + strconv.FormatUint(x.imc, 10) + "_" + genGoIdentifier(tpkg[idx+1:], false) + x.imn[tpkg] = "pkg" + strconv.FormatUint(x.imc, 10) + "_" + tpkg[idx+1:] } } } @@ -424,10 +408,6 @@ func (x *genRunner) varsfx() string { return strconv.FormatUint(x.c, 10) } -func (x *genRunner) varsfxreset() { - x.c = 0 -} - func (x *genRunner) out(s string) { if _, err := io.WriteString(x.w, s); err != nil { panic(err) @@ -514,7 +494,6 @@ func (x *genRunner) selfer(encode bool) { // always make decode use a pointer receiver, // and structs always use a ptr receiver (encode|decode) isptr := !encode || t.Kind() == reflect.Struct - x.varsfxreset() fnSigPfx := "func (x " if isptr { fnSigPfx += "*" @@ -587,28 +566,9 @@ func (x *genRunner) xtraSM(varname string, encode bool, t reflect.Type) { } else { x.linef("h.dec%s((*%s)(%s), d)", x.genMethodNameT(t), x.genTypeName(t), varname) } - x.registerXtraT(t) -} - -func (x *genRunner) registerXtraT(t reflect.Type) { - // recursively register the types - if _, ok := x.tm[t]; ok { - return - } - var tkey reflect.Type - switch t.Kind() { - case reflect.Chan, reflect.Slice, reflect.Array: - case reflect.Map: - tkey = t.Key() - default: - return - } - x.tm[t] = struct{}{} - x.ts = append(x.ts, t) - // check if this refers to any xtra types eg. a slice of array: add the array - x.registerXtraT(t.Elem()) - if tkey != nil { - x.registerXtraT(tkey) + if _, ok := x.tm[t]; !ok { + x.tm[t] = struct{}{} + x.ts = append(x.ts, t) } } @@ -648,33 +608,22 @@ func (x *genRunner) encVar(varname string, t reflect.Type) { } -// enc will encode a variable (varname) of type t, -// except t is of kind reflect.Struct or reflect.Array, wherein varname is of type ptrTo(T) (to prevent copying) +// enc will encode a variable (varname) of type T, +// except t is of kind reflect.Struct or reflect.Array, wherein varname is of type *T (to prevent copying) func (x *genRunner) enc(varname string, t reflect.Type) { + // varName here must be to a pointer to a struct/array, or to a value directly. rtid := reflect.ValueOf(t).Pointer() // We call CodecEncodeSelf if one of the following are honored: // - the type already implements Selfer, call that // - the type has a Selfer implementation just created, use that // - the type is in the list of the ones we will generate for, but it is not currently being generated - mi := x.varsfx() tptr := reflect.PtrTo(t) tk := t.Kind() if x.checkForSelfer(t, varname) { - if tk == reflect.Array || tk == reflect.Struct { // varname is of type *T - if tptr.Implements(selferTyp) || t.Implements(selferTyp) { - x.line(varname + ".CodecEncodeSelf(e)") - return - } - } else { // varname is of type T - if t.Implements(selferTyp) { - x.line(varname + ".CodecEncodeSelf(e)") - return - } else if tptr.Implements(selferTyp) { - x.linef("%ssf%s := &%s", genTempVarPfx, mi, varname) - x.linef("%ssf%s.CodecEncodeSelf(e)", genTempVarPfx, mi) - return - } + if t.Implements(selferTyp) || (tptr.Implements(selferTyp) && (tk == reflect.Array || tk == reflect.Struct)) { + x.line(varname + ".CodecEncodeSelf(e)") + return } if _, ok := x.te[rtid]; ok { @@ -702,17 +651,14 @@ func (x *genRunner) enc(varname string, t reflect.Type) { } // check if - // - type is RawExt, Raw + // - type is RawExt // - the type implements (Text|JSON|Binary)(Unm|M)arshal + mi := x.varsfx() x.linef("%sm%s := z.EncBinary()", genTempVarPfx, mi) x.linef("_ = %sm%s", genTempVarPfx, mi) x.line("if false {") //start if block defer func() { x.line("}") }() //end if block - if t == rawTyp { - x.linef("} else { z.EncRaw(%v)", varname) - return - } if t == rawExtTyp { x.linef("} else { r.EncodeRawExt(%v, e)", varname) return @@ -730,31 +676,15 @@ func (x *genRunner) enc(varname string, t reflect.Type) { // first check if extensions are configued, before doing the interface conversion x.linef("} else if z.HasExtensions() && z.EncExt(%s) {", varname) } - if tk == reflect.Array || tk == reflect.Struct { // varname is of type *T - if t.Implements(binaryMarshalerTyp) || tptr.Implements(binaryMarshalerTyp) { - x.linef("} else if %sm%s { z.EncBinaryMarshal(%v) ", genTempVarPfx, mi, varname) - } - if t.Implements(jsonMarshalerTyp) || tptr.Implements(jsonMarshalerTyp) { - x.linef("} else if !%sm%s && z.IsJSONHandle() { z.EncJSONMarshal(%v) ", genTempVarPfx, mi, varname) - } else if t.Implements(textMarshalerTyp) || tptr.Implements(textMarshalerTyp) { - x.linef("} else if !%sm%s { z.EncTextMarshal(%v) ", genTempVarPfx, mi, varname) - } - } else { // varname is of type T - if t.Implements(binaryMarshalerTyp) { - x.linef("} else if %sm%s { z.EncBinaryMarshal(%v) ", genTempVarPfx, mi, varname) - } else if tptr.Implements(binaryMarshalerTyp) { - x.linef("} else if %sm%s { z.EncBinaryMarshal(&%v) ", genTempVarPfx, mi, varname) - } - if t.Implements(jsonMarshalerTyp) { - x.linef("} else if !%sm%s && z.IsJSONHandle() { z.EncJSONMarshal(%v) ", genTempVarPfx, mi, varname) - } else if tptr.Implements(jsonMarshalerTyp) { - x.linef("} else if !%sm%s && z.IsJSONHandle() { z.EncJSONMarshal(&%v) ", genTempVarPfx, mi, varname) - } else if t.Implements(textMarshalerTyp) { - x.linef("} else if !%sm%s { z.EncTextMarshal(%v) ", genTempVarPfx, mi, varname) - } else if tptr.Implements(textMarshalerTyp) { - x.linef("} else if !%sm%s { z.EncTextMarshal(&%v) ", genTempVarPfx, mi, varname) - } + if t.Implements(binaryMarshalerTyp) || tptr.Implements(binaryMarshalerTyp) { + x.linef("} else if %sm%s { z.EncBinaryMarshal(%v) ", genTempVarPfx, mi, varname) } + if t.Implements(jsonMarshalerTyp) || tptr.Implements(jsonMarshalerTyp) { + x.linef("} else if !%sm%s && z.IsJSONHandle() { z.EncJSONMarshal(%v) ", genTempVarPfx, mi, varname) + } else if t.Implements(textMarshalerTyp) || tptr.Implements(textMarshalerTyp) { + x.linef("} else if !%sm%s { z.EncTextMarshal(%v) ", genTempVarPfx, mi, varname) + } + x.line("} else {") switch t.Kind() { @@ -992,14 +922,6 @@ func (x *genRunner) encStruct(varname string, rtid uintptr, t reflect.Type) { } func (x *genRunner) encListFallback(varname string, t reflect.Type) { - if t.AssignableTo(uint8SliceTyp) { - x.linef("r.EncodeStringBytes(codecSelferC_RAW%s, []byte(%s))", x.xs, varname) - return - } - if t.Kind() == reflect.Array && t.Elem().Kind() == reflect.Uint8 { - x.linef("r.EncodeStringBytes(codecSelferC_RAW%s, ([%v]byte(%s))[:])", x.xs, t.Len(), varname) - return - } i := x.varsfx() g := genTempVarPfx x.line("r.EncodeArrayStart(len(" + varname + "))") @@ -1098,8 +1020,6 @@ func (x *genRunner) decVar(varname string, t reflect.Type, canBeNil bool) { } } -// dec will decode a variable (varname) of type ptrTo(t). -// t is always a basetype (i.e. not of kind reflect.Ptr). func (x *genRunner) dec(varname string, t reflect.Type) { // assumptions: // - the varname is to a pointer already. No need to take address of it @@ -1136,7 +1056,7 @@ func (x *genRunner) dec(varname string, t reflect.Type) { } // check if - // - type is Raw, RawExt + // - type is RawExt // - the type implements (Text|JSON|Binary)(Unm|M)arshal mi := x.varsfx() x.linef("%sm%s := z.DecBinary()", genTempVarPfx, mi) @@ -1144,10 +1064,6 @@ func (x *genRunner) dec(varname string, t reflect.Type) { x.line("if false {") //start if block defer func() { x.line("}") }() //end if block - if t == rawTyp { - x.linef("} else { *%v = z.DecRaw()", varname) - return - } if t == rawExtTyp { x.linef("} else { r.DecodeExt(%v, 0, nil)", varname) return @@ -1273,49 +1189,59 @@ func (x *genRunner) dec(varname string, t reflect.Type) { } func (x *genRunner) decTryAssignPrimitive(varname string, t reflect.Type) (tryAsPtr bool) { - // This should only be used for exact primitives (ie un-named types). - // Named types may be implementations of Selfer, Unmarshaler, etc. - // They should be handled by dec(...) + // We have to use the actual type name when doing a direct assignment. + // We don't have the luxury of casting the pointer to the underlying type. + // + // Consequently, in the situation of a + // type Message int32 + // var x Message + // var i int32 = 32 + // x = i // this will bomb + // x = Message(i) // this will work + // *((*int32)(&x)) = i // this will work + // + // Consequently, we replace: + // case reflect.Uint32: x.line(varname + " = uint32(r.DecodeUint(32))") + // with: + // case reflect.Uint32: x.line(varname + " = " + genTypeNamePrim(t, x.tc) + "(r.DecodeUint(32))") - if t.Name() != "" { - tryAsPtr = true - return + xfn := func(t reflect.Type) string { + return x.genTypeNamePrim(t) } - switch t.Kind() { case reflect.Int: - x.linef("%s = r.DecodeInt(codecSelferBitsize%s)", varname, x.xs) + x.linef("%s = %s(r.DecodeInt(codecSelferBitsize%s))", varname, xfn(t), x.xs) case reflect.Int8: - x.linef("%s = r.DecodeInt(8)", varname) + x.linef("%s = %s(r.DecodeInt(8))", varname, xfn(t)) case reflect.Int16: - x.linef("%s = r.DecodeInt(16)", varname) + x.linef("%s = %s(r.DecodeInt(16))", varname, xfn(t)) case reflect.Int32: - x.linef("%s = r.DecodeInt(32)", varname) + x.linef("%s = %s(r.DecodeInt(32))", varname, xfn(t)) case reflect.Int64: - x.linef("%s = r.DecodeInt(64)", varname) + x.linef("%s = %s(r.DecodeInt(64))", varname, xfn(t)) case reflect.Uint: - x.linef("%s = r.DecodeUint(codecSelferBitsize%s)", varname, x.xs) + x.linef("%s = %s(r.DecodeUint(codecSelferBitsize%s))", varname, xfn(t), x.xs) case reflect.Uint8: - x.linef("%s = r.DecodeUint(8)", varname) + x.linef("%s = %s(r.DecodeUint(8))", varname, xfn(t)) case reflect.Uint16: - x.linef("%s = r.DecodeUint(16)", varname) + x.linef("%s = %s(r.DecodeUint(16))", varname, xfn(t)) case reflect.Uint32: - x.linef("%s = r.DecodeUint(32)", varname) + x.linef("%s = %s(r.DecodeUint(32))", varname, xfn(t)) case reflect.Uint64: - x.linef("%s = r.DecodeUint(64)", varname) + x.linef("%s = %s(r.DecodeUint(64))", varname, xfn(t)) case reflect.Uintptr: - x.linef("%s = r.DecodeUint(codecSelferBitsize%s)", varname, x.xs) + x.linef("%s = %s(r.DecodeUint(codecSelferBitsize%s))", varname, xfn(t), x.xs) case reflect.Float32: - x.linef("%s = r.DecodeFloat(true)", varname) + x.linef("%s = %s(r.DecodeFloat(true))", varname, xfn(t)) case reflect.Float64: - x.linef("%s = r.DecodeFloat(false)", varname) + x.linef("%s = %s(r.DecodeFloat(false))", varname, xfn(t)) case reflect.Bool: - x.linef("%s = r.DecodeBool()", varname) + x.linef("%s = %s(r.DecodeBool())", varname, xfn(t)) case reflect.String: - x.linef("%s = r.DecodeString()", varname) + x.linef("%s = %s(r.DecodeString())", varname, xfn(t)) default: tryAsPtr = true } @@ -1323,14 +1249,6 @@ func (x *genRunner) decTryAssignPrimitive(varname string, t reflect.Type) (tryAs } func (x *genRunner) decListFallback(varname string, rtid uintptr, t reflect.Type) { - if t.AssignableTo(uint8SliceTyp) { - x.line("*" + varname + " = r.DecodeBytes(*((*[]byte)(" + varname + ")), false, false)") - return - } - if t.Kind() == reflect.Array && t.Elem().Kind() == reflect.Uint8 { - x.linef("r.DecodeBytes( ((*[%s]byte)(%s))[:], false, true)", t.Len(), varname) - return - } type tstruc struct { TempVar string Rand string @@ -1446,7 +1364,7 @@ func (x *genRunner) decStructMapSwitch(kName string, varname string, rtid uintpt if si.i != -1 { t2 = t.Field(int(si.i)) } else { - //we must accommodate anonymous fields, where the embedded field is a nil pointer in the value. + //we must accomodate anonymous fields, where the embedded field is a nil pointer in the value. // t2 = t.FieldByIndex(si.is) t2typ := t varname3 := varname @@ -1534,7 +1452,7 @@ func (x *genRunner) decStructArray(varname, lenvarname, breakString string, rtid if si.i != -1 { t2 = t.Field(int(si.i)) } else { - //we must accommodate anonymous fields, where the embedded field is a nil pointer in the value. + //we must accomodate anonymous fields, where the embedded field is a nil pointer in the value. // t2 = t.FieldByIndex(si.is) t2typ := t varname3 := varname @@ -1651,6 +1569,8 @@ func (x *genV) MethodNamePfx(prefix string, prim bool) string { } +var genCheckVendor = os.Getenv("GO15VENDOREXPERIMENT") == "1" + // genImportPath returns import path of a non-predeclared named typed, or an empty string otherwise. // // This handles the misbehaviour that occurs when 1.5-style vendoring is enabled, @@ -1672,26 +1592,6 @@ func genImportPath(t reflect.Type) (s string) { return } -// A go identifier is (letter|_)[letter|number|_]* -func genGoIdentifier(s string, checkFirstChar bool) string { - b := make([]byte, 0, len(s)) - t := make([]byte, 4) - var n int - for i, r := range s { - if checkFirstChar && i == 0 && !unicode.IsLetter(r) { - b = append(b, '_') - } - // r must be unicode_letter, unicode_digit or _ - if unicode.IsLetter(r) || unicode.IsDigit(r) { - n = utf8.EncodeRune(t, r) - b = append(b, t[:n]...) - } else { - b = append(b, '_') - } - } - return string(b) -} - func genNonPtr(t reflect.Type) reflect.Type { for t.Kind() == reflect.Ptr { t = t.Elem() @@ -1701,7 +1601,7 @@ func genNonPtr(t reflect.Type) reflect.Type { func genTitleCaseName(s string) string { switch s { - case "interface{}", "interface {}": + case "interface{}": return "Intf" default: return strings.ToUpper(s[0:1]) + s[1:] @@ -1804,7 +1704,7 @@ func (x genInternal) FastpathLen() (l int) { func genInternalZeroValue(s string) string { switch s { - case "interface{}", "interface {}": + case "interface{}": return "nil" case "bool": return "false" @@ -1956,7 +1856,7 @@ func genInternalInit() { } var gt genInternal - // For each slice or map type, there must be a (symmetrical) Encode and Decode fast-path function + // For each slice or map type, there must be a (symetrical) Encode and Decode fast-path function for _, s := range types { gt.Values = append(gt.Values, genV{Primitive: s, Size: mapvaltypes2[s]}) if s != "uint8" { // do not generate fast path for slice of bytes. Treat specially already. diff --git a/vendor/github.com/ugorji/go/codec/gen_15.go b/vendor/github.com/ugorji/go/codec/gen_15.go deleted file mode 100644 index ab76c31..0000000 --- a/vendor/github.com/ugorji/go/codec/gen_15.go +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// +build go1.5,!go1.6 - -package codec - -import "os" - -func init() { - genCheckVendor = os.Getenv("GO15VENDOREXPERIMENT") == "1" -} diff --git a/vendor/github.com/ugorji/go/codec/gen_16.go b/vendor/github.com/ugorji/go/codec/gen_16.go deleted file mode 100644 index 87c04e2..0000000 --- a/vendor/github.com/ugorji/go/codec/gen_16.go +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// +build go1.6 - -package codec - -import "os" - -func init() { - genCheckVendor = os.Getenv("GO15VENDOREXPERIMENT") != "0" -} diff --git a/vendor/github.com/ugorji/go/codec/gen_17.go b/vendor/github.com/ugorji/go/codec/gen_17.go deleted file mode 100644 index 3881a43..0000000 --- a/vendor/github.com/ugorji/go/codec/gen_17.go +++ /dev/null @@ -1,10 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// +build go1.7 - -package codec - -func init() { - genCheckVendor = true -} diff --git a/vendor/github.com/ugorji/go/codec/helper.go b/vendor/github.com/ugorji/go/codec/helper.go index bf954ab..560014a 100644 --- a/vendor/github.com/ugorji/go/codec/helper.go +++ b/vendor/github.com/ugorji/go/codec/helper.go @@ -137,6 +137,17 @@ const ( // Note that this will always cause rpc tests to fail, since they need io.EOF sent via panic. recoverPanicToErr = true + // Fast path functions try to create a fast path encode or decode implementation + // for common maps and slices, by by-passing reflection altogether. + fastpathEnabled = true + + // if checkStructForEmptyValue, check structs fields to see if an empty value. + // This could be an expensive call, so possibly disable it. + checkStructForEmptyValue = false + + // if derefForIsEmptyValue, deref pointers and interfaces when checking isEmptyValue + derefForIsEmptyValue = false + // if resetSliceElemToZeroValue, then on decoding a slice, reset the element to a zero value first. // Only concern is that, if the slice already contained some garbage, we will decode into that garbage. // The chances of this are slim, so leave this "optimization". @@ -144,10 +155,8 @@ const ( resetSliceElemToZeroValue bool = false ) -var ( - oneByteArr = [1]byte{0} - zeroByteSlice = oneByteArr[:0:0] -) +var oneByteArr = [1]byte{0} +var zeroByteSlice = oneByteArr[:0:0] type charEncoding uint8 @@ -206,41 +215,6 @@ const ( containerArrayEnd ) -// sfiIdx used for tracking where a (field/enc)Name is seen in a []*structFieldInfo -type sfiIdx struct { - name string - index int -} - -// do not recurse if a containing type refers to an embedded type -// which refers back to its containing type (via a pointer). -// The second time this back-reference happens, break out, -// so as not to cause an infinite loop. -const rgetMaxRecursion = 2 - -// Anecdotally, we believe most types have <= 12 fields. -// Java's PMD rules set TooManyFields threshold to 15. -const rgetPoolTArrayLen = 12 - -type rgetT struct { - fNames []string - encNames []string - etypes []uintptr - sfis []*structFieldInfo -} - -type rgetPoolT struct { - fNames [rgetPoolTArrayLen]string - encNames [rgetPoolTArrayLen]string - etypes [rgetPoolTArrayLen]uintptr - sfis [rgetPoolTArrayLen]*structFieldInfo - sfiidx [rgetPoolTArrayLen]sfiIdx -} - -var rgetPool = sync.Pool{ - New: func() interface{} { return new(rgetPoolT) }, -} - type containerStateRecv interface { sendContainerState(containerState) } @@ -266,7 +240,6 @@ var ( stringTyp = reflect.TypeOf("") timeTyp = reflect.TypeOf(time.Time{}) rawExtTyp = reflect.TypeOf(RawExt{}) - rawTyp = reflect.TypeOf(Raw{}) uint8SliceTyp = reflect.TypeOf([]uint8(nil)) mapBySliceTyp = reflect.TypeOf((*MapBySlice)(nil)).Elem() @@ -284,7 +257,6 @@ var ( uint8SliceTypId = reflect.ValueOf(uint8SliceTyp).Pointer() rawExtTypId = reflect.ValueOf(rawExtTyp).Pointer() - rawTypId = reflect.ValueOf(rawTyp).Pointer() intfTypId = reflect.ValueOf(intfTyp).Pointer() timeTypId = reflect.ValueOf(timeTyp).Pointer() stringTypId = reflect.ValueOf(stringTyp).Pointer() @@ -365,11 +337,6 @@ type Handle interface { isBinary() bool } -// Raw represents raw formatted bytes. -// We "blindly" store it during encode and store the raw bytes during decode. -// Note: it is dangerous during encode, so we may gate the behaviour behind an Encode flag which must be explicitly set. -type Raw []byte - // RawExt represents raw unprocessed extension data. // Some codecs will decode extension data as a *RawExt if there is no registered extension for the tag. // @@ -380,7 +347,7 @@ type RawExt struct { // Data is used by codecs (e.g. binc, msgpack, simple) which do custom serialization of the types Data []byte // Value represents the extension, if Data is nil. - // Value is used by codecs (e.g. cbor, json) which use the format to do custom serialization of the types. + // Value is used by codecs (e.g. cbor) which use the format to do custom serialization of the types. Value interface{} } @@ -558,7 +525,7 @@ func (o *extHandle) AddExt( func (o *extHandle) SetExt(rt reflect.Type, tag uint64, ext Ext) (err error) { // o is a pointer, because we may need to initialize it if rt.PkgPath() == "" || rt.Kind() == reflect.Interface { - err = fmt.Errorf("codec.Handle.AddExt: Takes named type, not a pointer or interface: %T", + err = fmt.Errorf("codec.Handle.AddExt: Takes named type, especially not a pointer or interface: %T", reflect.Zero(rt).Interface()) return } @@ -601,8 +568,7 @@ func (o extHandle) getExtForTag(tag uint64) *extTypeTagFn { } type structFieldInfo struct { - encName string // encode name - fieldName string // field name + encName string // encode name // only one of 'i' or 'is' can be set. If 'i' is -1, then 'is' has been set. @@ -748,7 +714,6 @@ type typeInfo struct { } func (ti *typeInfo) indexForEncName(name string) int { - // NOTE: name may be a stringView, so don't pass it to another function. //tisfi := ti.sfi const binarySearchThreshold = 16 if sfilen := len(ti.sfi); sfilen < binarySearchThreshold { @@ -863,19 +828,19 @@ func (x *TypeInfos) get(rtid uintptr, rt reflect.Type) (pti *typeInfo) { } if rt.Kind() == reflect.Struct { - var omitEmpty bool + var siInfo *structFieldInfo if f, ok := rt.FieldByName(structInfoFieldName); ok { - siInfo := parseStructFieldInfo(structInfoFieldName, x.structTag(f.Tag)) + siInfo = parseStructFieldInfo(structInfoFieldName, x.structTag(f.Tag)) ti.toArray = siInfo.toArray - omitEmpty = siInfo.omitEmpty } - pi := rgetPool.Get() - pv := pi.(*rgetPoolT) - pv.etypes[0] = ti.baseId - vv := rgetT{pv.fNames[:0], pv.encNames[:0], pv.etypes[:1], pv.sfis[:0]} - x.rget(rt, rtid, omitEmpty, nil, &vv) - ti.sfip, ti.sfi = rgetResolveSFI(vv.sfis, pv.sfiidx[:0]) - rgetPool.Put(pi) + sfip := make([]*structFieldInfo, 0, rt.NumField()) + x.rget(rt, nil, make(map[string]bool, 16), &sfip, siInfo) + + ti.sfip = make([]*structFieldInfo, len(sfip)) + ti.sfi = make([]*structFieldInfo, len(sfip)) + copy(ti.sfip, sfip) + sort.Sort(sfiSortedByEncName(sfip)) + copy(ti.sfi, sfip) } // sfi = sfip @@ -888,30 +853,17 @@ func (x *TypeInfos) get(rtid uintptr, rt reflect.Type) (pti *typeInfo) { return } -func (x *TypeInfos) rget(rt reflect.Type, rtid uintptr, omitEmpty bool, - indexstack []int, pv *rgetT, +func (x *TypeInfos) rget(rt reflect.Type, indexstack []int, fnameToHastag map[string]bool, + sfi *[]*structFieldInfo, siInfo *structFieldInfo, ) { - // Read up fields and store how to access the value. - // - // It uses go's rules for message selectors, - // which say that the field with the shallowest depth is selected. - // - // Note: we consciously use slices, not a map, to simulate a set. - // Typically, types have < 16 fields, - // and iteration using equals is faster than maps there - -LOOP: - for j, jlen := 0, rt.NumField(); j < jlen; j++ { + for j := 0; j < rt.NumField(); j++ { f := rt.Field(j) fkind := f.Type.Kind() // skip if a func type, or is unexported, or structTag value == "-" - switch fkind { - case reflect.Func, reflect.Complex64, reflect.Complex128, reflect.UnsafePointer: - continue LOOP + if fkind == reflect.Func { + continue } - - // if r1, _ := utf8.DecodeRuneInString(f.Name); - // r1 == utf8.RuneError || !unicode.IsUpper(r1) { + // if r1, _ := utf8.DecodeRuneInString(f.Name); r1 == utf8.RuneError || !unicode.IsUpper(r1) { if f.PkgPath != "" && !f.Anonymous { // unexported, not embedded continue } @@ -920,8 +872,7 @@ LOOP: continue } var si *structFieldInfo - // if anonymous and no struct tag (or it's blank), - // and a struct (or pointer to struct), inline it. + // if anonymous and no struct tag (or it's blank), and a struct (or pointer to struct), inline it. if f.Anonymous && fkind != reflect.Interface { doInline := stag == "" if !doInline { @@ -935,31 +886,11 @@ LOOP: ft = ft.Elem() } if ft.Kind() == reflect.Struct { - // if etypes contains this, don't call rget again (as fields are already seen here) - ftid := reflect.ValueOf(ft).Pointer() - // We cannot recurse forever, but we need to track other field depths. - // So - we break if we see a type twice (not the first time). - // This should be sufficient to handle an embedded type that refers to its - // owning type, which then refers to its embedded type. - processIt := true - numk := 0 - for _, k := range pv.etypes { - if k == ftid { - numk++ - if numk == rgetMaxRecursion { - processIt = false - break - } - } - } - if processIt { - pv.etypes = append(pv.etypes, ftid) - indexstack2 := make([]int, len(indexstack)+1) - copy(indexstack2, indexstack) - indexstack2[len(indexstack)] = j - // indexstack2 := append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) - x.rget(ft, ftid, omitEmpty, indexstack2, pv) - } + indexstack2 := make([]int, len(indexstack)+1, len(indexstack)+4) + copy(indexstack2, indexstack) + indexstack2[len(indexstack)] = j + // indexstack2 := append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) + x.rget(ft, indexstack2, fnameToHastag, sfi, siInfo) continue } } @@ -970,86 +901,36 @@ LOOP: continue } + // do not let fields with same name in embedded structs override field at higher level. + // this must be done after anonymous check, to allow anonymous field + // still include their child fields + if _, ok := fnameToHastag[f.Name]; ok { + continue + } if f.Name == "" { panic(noFieldNameToStructFieldInfoErr) } - - pv.fNames = append(pv.fNames, f.Name) - if si == nil { si = parseStructFieldInfo(f.Name, stag) } else if si.encName == "" { si.encName = f.Name } - si.fieldName = f.Name - - pv.encNames = append(pv.encNames, si.encName) - // si.ikind = int(f.Type.Kind()) if len(indexstack) == 0 { si.i = int16(j) } else { si.i = -1 - si.is = make([]int, len(indexstack)+1) - copy(si.is, indexstack) - si.is[len(indexstack)] = j - // si.is = append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) + si.is = append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) } - if omitEmpty { - si.omitEmpty = true - } - pv.sfis = append(pv.sfis, si) - } -} - -// resolves the struct field info got from a call to rget. -// Returns a trimmed, unsorted and sorted []*structFieldInfo. -func rgetResolveSFI(x []*structFieldInfo, pv []sfiIdx) (y, z []*structFieldInfo) { - var n int - for i, v := range x { - xn := v.encName //TODO: fieldName or encName? use encName for now. - var found bool - for j, k := range pv { - if k.name == xn { - // one of them must be reset to nil, and the index updated appropriately to the other one - if len(v.is) == len(x[k.index].is) { - } else if len(v.is) < len(x[k.index].is) { - pv[j].index = i - if x[k.index] != nil { - x[k.index] = nil - n++ - } - } else { - if x[i] != nil { - x[i] = nil - n++ - } - } - found = true - break + if siInfo != nil { + if siInfo.omitEmpty { + si.omitEmpty = true } } - if !found { - pv = append(pv, sfiIdx{xn, i}) - } + *sfi = append(*sfi, si) + fnameToHastag[f.Name] = stag != "" } - - // remove all the nils - y = make([]*structFieldInfo, len(x)-n) - n = 0 - for _, v := range x { - if v == nil { - continue - } - y[n] = v - n++ - } - - z = make([]*structFieldInfo, len(y)) - copy(z, y) - sort.Sort(sfiSortedByEncName(z)) - return } func panicToErr(err *error) { @@ -1246,73 +1127,3 @@ type bytesISlice []bytesI func (p bytesISlice) Len() int { return len(p) } func (p bytesISlice) Less(i, j int) bool { return bytes.Compare(p[i].v, p[j].v) == -1 } func (p bytesISlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -// ----------------- - -type set []uintptr - -func (s *set) add(v uintptr) (exists bool) { - // e.ci is always nil, or len >= 1 - // defer func() { fmt.Printf("$$$$$$$$$$$ cirRef Add: %v, exists: %v\n", v, exists) }() - x := *s - if x == nil { - x = make([]uintptr, 1, 8) - x[0] = v - *s = x - return - } - // typically, length will be 1. make this perform. - if len(x) == 1 { - if j := x[0]; j == 0 { - x[0] = v - } else if j == v { - exists = true - } else { - x = append(x, v) - *s = x - } - return - } - // check if it exists - for _, j := range x { - if j == v { - exists = true - return - } - } - // try to replace a "deleted" slot - for i, j := range x { - if j == 0 { - x[i] = v - return - } - } - // if unable to replace deleted slot, just append it. - x = append(x, v) - *s = x - return -} - -func (s *set) remove(v uintptr) (exists bool) { - // defer func() { fmt.Printf("$$$$$$$$$$$ cirRef Rm: %v, exists: %v\n", v, exists) }() - x := *s - if len(x) == 0 { - return - } - if len(x) == 1 { - if x[0] == v { - x[0] = 0 - } - return - } - for i, j := range x { - if j == v { - exists = true - x[i] = 0 // set it to 0, as way to delete it. - // copy(x[i:], x[i+1:]) - // x = x[:len(x)-1] - return - } - } - return -} diff --git a/vendor/github.com/ugorji/go/codec/helper_internal.go b/vendor/github.com/ugorji/go/codec/helper_internal.go index 5d0727f..dea981f 100644 --- a/vendor/github.com/ugorji/go/codec/helper_internal.go +++ b/vendor/github.com/ugorji/go/codec/helper_internal.go @@ -70,8 +70,8 @@ func hIsEmptyValue(v reflect.Value, deref, checkStruct bool) bool { return false } -func isEmptyValue(v reflect.Value, deref, checkStruct bool) bool { - return hIsEmptyValue(v, deref, checkStruct) +func isEmptyValue(v reflect.Value) bool { + return hIsEmptyValue(v, derefForIsEmptyValue, checkStructForEmptyValue) } func pruneSignExt(v []byte, pos bool) (n int) { diff --git a/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go b/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go index 8b06a00..7c2ffc0 100644 --- a/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go +++ b/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go @@ -1,4 +1,4 @@ -// +build !unsafe +//+build !unsafe // Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. // Use of this source code is governed by a MIT license found in the LICENSE file. diff --git a/vendor/github.com/ugorji/go/codec/helper_unsafe.go b/vendor/github.com/ugorji/go/codec/helper_unsafe.go index 0f596c7..373b2b1 100644 --- a/vendor/github.com/ugorji/go/codec/helper_unsafe.go +++ b/vendor/github.com/ugorji/go/codec/helper_unsafe.go @@ -1,4 +1,4 @@ -// +build unsafe +//+build unsafe // Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. // Use of this source code is governed by a MIT license found in the LICENSE file. @@ -16,7 +16,7 @@ type unsafeString struct { Len int } -type unsafeSlice struct { +type unsafeBytes struct { Data uintptr Len int Cap int @@ -29,10 +29,8 @@ func stringView(v []byte) string { if len(v) == 0 { return "" } - - bx := (*unsafeSlice)(unsafe.Pointer(&v)) - sx := unsafeString{bx.Data, bx.Len} - return *(*string)(unsafe.Pointer(&sx)) + x := unsafeString{uintptr(unsafe.Pointer(&v[0])), len(v)} + return *(*string)(unsafe.Pointer(&x)) } // bytesView returns a view of the string as a []byte. @@ -42,8 +40,6 @@ func bytesView(v string) []byte { if len(v) == 0 { return zeroByteSlice } - - sx := (*unsafeString)(unsafe.Pointer(&v)) - bx := unsafeSlice{sx.Data, sx.Len, sx.Len} - return *(*[]byte)(unsafe.Pointer(&bx)) + x := unsafeBytes{uintptr(unsafe.Pointer(&v)), len(v), len(v)} + return *(*[]byte)(unsafe.Pointer(&x)) } diff --git a/vendor/github.com/ugorji/go/codec/json.go b/vendor/github.com/ugorji/go/codec/json.go index 13af12b..a18a5f7 100644 --- a/vendor/github.com/ugorji/go/codec/json.go +++ b/vendor/github.com/ugorji/go/codec/json.go @@ -43,23 +43,18 @@ import ( //-------------------------------- -var ( - jsonLiterals = [...]byte{'t', 'r', 'u', 'e', 'f', 'a', 'l', 's', 'e', 'n', 'u', 'l', 'l'} +var jsonLiterals = [...]byte{'t', 'r', 'u', 'e', 'f', 'a', 'l', 's', 'e', 'n', 'u', 'l', 'l'} - jsonFloat64Pow10 = [...]float64{ - 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, - 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, - 1e20, 1e21, 1e22, - } +var jsonFloat64Pow10 = [...]float64{ + 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, + 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, + 1e20, 1e21, 1e22, +} - jsonUint64Pow10 = [...]uint64{ - 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, - 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, - } - - // jsonTabs and jsonSpaces are used as caches for indents - jsonTabs, jsonSpaces string -) +var jsonUint64Pow10 = [...]uint64{ + 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, + 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, +} const ( // jsonUnreadAfterDecNum controls whether we unread after decoding a number. @@ -90,23 +85,8 @@ const ( jsonNumUintMaxVal = 1< 1<<53 || v < -(1<<53)) { - e.w.writen1('"') - e.w.writeb(strconv.AppendInt(e.b[:0], v, 10)) - e.w.writen1('"') - return - } e.w.writeb(strconv.AppendInt(e.b[:0], v, 10)) } func (e *jsonEncDriver) EncodeUint(v uint64) { - if x := e.h.IntegerAsString; x == 'A' || x == 'L' && v > 1<<53 { - e.w.writen1('"') - e.w.writeb(strconv.AppendUint(e.b[:0], v, 10)) - e.w.writen1('"') - return - } e.w.writeb(strconv.AppendUint(e.b[:0], v, 10)) } @@ -251,17 +165,11 @@ func (e *jsonEncDriver) EncodeRawExt(re *RawExt, en *Encoder) { } func (e *jsonEncDriver) EncodeArrayStart(length int) { - if e.d { - e.dl++ - } e.w.writen1('[') e.c = containerArrayStart } func (e *jsonEncDriver) EncodeMapStart(length int) { - if e.d { - e.dl++ - } e.w.writen1('{') e.c = containerMapStart } @@ -656,11 +564,6 @@ func (d *jsonDecDriver) decNum(storeBytes bool) { d.tok = b } b := d.tok - var str bool - if b == '"' { - str = true - b = d.r.readn1() - } if !(b == '+' || b == '-' || b == '.' || (b >= '0' && b <= '9')) { d.d.errorf("json: decNum: got first char '%c'", b) return @@ -675,10 +578,6 @@ func (d *jsonDecDriver) decNum(storeBytes bool) { n.reset() d.bs = d.bs[:0] - if str && storeBytes { - d.bs = append(d.bs, '"') - } - // The format of a number is as below: // parsing: sign? digit* dot? digit* e? sign? digit* // states: 0 1* 2 3* 4 5* 6 7 @@ -769,14 +668,6 @@ LOOP: default: break LOOP } - case '"': - if str { - if storeBytes { - d.bs = append(d.bs, '"') - } - b, eof = r.readn1eof() - } - break LOOP default: break LOOP } @@ -1142,24 +1033,6 @@ type JsonHandle struct { // RawBytesExt, if configured, is used to encode and decode raw bytes in a custom way. // If not configured, raw bytes are encoded to/from base64 text. RawBytesExt InterfaceExt - - // Indent indicates how a value is encoded. - // - If positive, indent by that number of spaces. - // - If negative, indent by that number of tabs. - Indent int8 - - // IntegerAsString controls how integers (signed and unsigned) are encoded. - // - // Per the JSON Spec, JSON numbers are 64-bit floating point numbers. - // Consequently, integers > 2^53 cannot be represented as a JSON number without losing precision. - // This can be mitigated by configuring how to encode integers. - // - // IntegerAsString interpretes the following values: - // - if 'L', then encode integers > 2^53 as a json string. - // - if 'A', then encode all integers as a json string - // containing the exact integer representation as a decimal. - // - else encode all integers as a json number (default) - IntegerAsString uint8 } func (h *JsonHandle) SetInterfaceExt(rt reflect.Type, tag uint64, ext InterfaceExt) (err error) { @@ -1167,48 +1040,26 @@ func (h *JsonHandle) SetInterfaceExt(rt reflect.Type, tag uint64, ext InterfaceE } func (h *JsonHandle) newEncDriver(e *Encoder) encDriver { - hd := jsonEncDriver{e: e, h: h} + hd := jsonEncDriver{e: e, w: e.w, h: h} hd.bs = hd.b[:0] - - hd.reset() - + hd.se.i = h.RawBytesExt return &hd } func (h *JsonHandle) newDecDriver(d *Decoder) decDriver { // d := jsonDecDriver{r: r.(*bytesDecReader), h: h} - hd := jsonDecDriver{d: d, h: h} + hd := jsonDecDriver{d: d, r: d.r, h: h} hd.bs = hd.b[:0] - hd.reset() + hd.se.i = h.RawBytesExt return &hd } func (e *jsonEncDriver) reset() { e.w = e.e.w - e.se.i = e.h.RawBytesExt - if e.bs != nil { - e.bs = e.bs[:0] - } - e.d, e.dt, e.dl, e.ds = false, false, 0, "" - e.c = 0 - if e.h.Indent > 0 { - e.d = true - e.ds = jsonSpaces[:e.h.Indent] - } else if e.h.Indent < 0 { - e.d = true - e.dt = true - e.ds = jsonTabs[:-(e.h.Indent)] - } } func (d *jsonDecDriver) reset() { d.r = d.d.r - d.se.i = d.h.RawBytesExt - if d.bs != nil { - d.bs = d.bs[:0] - } - d.c, d.tok = 0, 0 - d.n.reset() } var jsonEncodeTerminate = []byte{' '} diff --git a/vendor/github.com/ugorji/go/codec/msgpack.go b/vendor/github.com/ugorji/go/codec/msgpack.go index e79830b..5eb4c96 100644 --- a/vendor/github.com/ugorji/go/codec/msgpack.go +++ b/vendor/github.com/ugorji/go/codec/msgpack.go @@ -374,7 +374,7 @@ func (d *msgpackDecDriver) DecodeNaked() { } if n.v == valueTypeUint && d.h.SignedInteger { n.v = valueTypeInt - n.i = int64(n.u) + n.i = int64(n.v) } return } @@ -561,13 +561,6 @@ func (d *msgpackDecDriver) readNextBd() { d.bdRead = true } -func (d *msgpackDecDriver) uncacheRead() { - if d.bdRead { - d.r.unreadn1() - d.bdRead = false - } -} - func (d *msgpackDecDriver) ContainerType() (vt valueType) { bd := d.bd if bd == mpNil { @@ -736,7 +729,6 @@ func (e *msgpackEncDriver) reset() { func (d *msgpackDecDriver) reset() { d.r = d.d.r - d.bd, d.bdRead = 0, false } //-------------------------------------------------- diff --git a/vendor/github.com/ugorji/go/codec/prebuild.sh b/vendor/github.com/ugorji/go/codec/prebuild.sh index 909f4bb..98f4424 100755 --- a/vendor/github.com/ugorji/go/codec/prebuild.sh +++ b/vendor/github.com/ugorji/go/codec/prebuild.sh @@ -171,7 +171,7 @@ do 'xf') zforce=1;; 'xb') zbak=1;; 'xx') zexternal=1;; - *) echo "prebuild.sh accepts [-fbx] only"; return 1;; + *) echo "prebuild.sh accepts [-fb] only"; return 1;; esac done shift $((OPTIND-1)) diff --git a/vendor/github.com/ugorji/go/codec/rpc.go b/vendor/github.com/ugorji/go/codec/rpc.go index 8062bed..dad53d0 100644 --- a/vendor/github.com/ugorji/go/codec/rpc.go +++ b/vendor/github.com/ugorji/go/codec/rpc.go @@ -25,7 +25,7 @@ type Rpc interface { } // RpcCodecBuffered allows access to the underlying bufio.Reader/Writer -// used by the rpc connection. It accommodates use-cases where the connection +// used by the rpc connection. It accomodates use-cases where the connection // should be used by rpc and non-rpc functions, e.g. streaming a file after // sending an rpc response. type RpcCodecBuffered interface { diff --git a/vendor/github.com/ugorji/go/codec/simple.go b/vendor/github.com/ugorji/go/codec/simple.go index 231d503..c150496 100644 --- a/vendor/github.com/ugorji/go/codec/simple.go +++ b/vendor/github.com/ugorji/go/codec/simple.go @@ -166,13 +166,6 @@ func (d *simpleDecDriver) readNextBd() { d.bdRead = true } -func (d *simpleDecDriver) uncacheRead() { - if d.bdRead { - d.r.unreadn1() - d.bdRead = false - } -} - func (d *simpleDecDriver) ContainerType() (vt valueType) { if d.bd == simpleVdNil { return valueTypeNil @@ -481,7 +474,7 @@ func (d *simpleDecDriver) DecodeNaked() { // SimpleHandle is a Handle for a very simple encoding format. // // simple is a simplistic codec similar to binc, but not as compact. -// - Encoding of a value is always preceded by the descriptor byte (bd) +// - Encoding of a value is always preceeded by the descriptor byte (bd) // - True, false, nil are encoded fully in 1 byte (the descriptor) // - Integers (intXXX, uintXXX) are encoded in 1, 2, 4 or 8 bytes (plus a descriptor byte). // There are positive (uintXXX and intXXX >= 0) and negative (intXXX < 0) integers. @@ -519,7 +512,6 @@ func (e *simpleEncDriver) reset() { func (d *simpleDecDriver) reset() { d.r = d.d.r - d.bd, d.bdRead = 0, false } var _ decDriver = (*simpleDecDriver)(nil) diff --git a/vendor/github.com/ugorji/go/codec/test.py b/vendor/github.com/ugorji/go/codec/test.py index c0ad20b..dfe3b0c 100755 --- a/vendor/github.com/ugorji/go/codec/test.py +++ b/vendor/github.com/ugorji/go/codec/test.py @@ -9,8 +9,6 @@ # sudo apt-get install python-pip # pip install --user msgpack-python msgpack-rpc-python cbor -# Ensure all "string" keys are utf strings (else encoded as bytes) - import cbor, msgpack, msgpackrpc, sys, os, threading def get_test_data_list(): @@ -28,39 +26,35 @@ def get_test_data_list(): -3232.0, -6464646464.0, 3232.0, - 6464.0, 6464646464.0, False, True, - u"null", None, u"someday", - 1328176922000002000, u"", - -2206187877999998000, u"bytestring", + 1328176922000002000, + -2206187877999998000, 270, - u"none", -2013855847999995777, #-6795364578871345152, ] l1 = [ { "true": True, "false": False }, - { "true": u"True", + { "true": "True", "false": False, "uint16(1616)": 1616 }, { "list": [1616, 32323232, True, -3232.0, {"TRUE":True, "FALSE":False}, [True, False] ], "int32":32323232, "bool": True, - "LONG STRING": u"123456789012345678901234567890123456789012345678901234567890", - "SHORT STRING": u"1234567890" }, - { True: "true", 138: False, "false": 200 } + "LONG STRING": "123456789012345678901234567890123456789012345678901234567890", + "SHORT STRING": "1234567890" }, + { True: "true", 8: False, "false": 0 } ] l = [] l.extend(l0) l.append(l0) - l.append(1) l.extend(l1) return l diff --git a/vendor/github.com/ugorji/go/codec/tests.sh b/vendor/github.com/ugorji/go/codec/tests.sh index 00857b6..b1602ea 100755 --- a/vendor/github.com/ugorji/go/codec/tests.sh +++ b/vendor/github.com/ugorji/go/codec/tests.sh @@ -6,7 +6,6 @@ _run() { # 1. VARIATIONS: regular (t), canonical (c), IO R/W (i), # binc-nosymbols (n), struct2array (s), intern string (e), - # json-indent (d), circular (l) # 2. MODE: reflection (r), external (x), codecgen (g), unsafe (u), notfastpath (f) # 3. OPTIONS: verbose (v), reset (z), must (m), # @@ -17,7 +16,7 @@ _run() { zargs="" local OPTIND OPTIND=1 - while getopts "_xurtcinsvgzmefdl" flag + while getopts "xurtcinsvgzmef" flag do case "x$flag" in 'xr') ;; @@ -28,7 +27,6 @@ _run() { 'xv') zargs="$zargs -tv" ;; 'xz') zargs="$zargs -tr" ;; 'xm') zargs="$zargs -tm" ;; - 'xl') zargs="$zargs -tl" ;; *) ;; esac done @@ -37,19 +35,15 @@ _run() { # echo ">>>>>>> TAGS: $ztags" OPTIND=1 - while getopts "_xurtcinsvgzmefdl" flag + while getopts "xurtcinsvgzmef" flag do case "x$flag" in 'xt') printf ">>>>>>> REGULAR : "; go test "-tags=$ztags" $zargs ; sleep 2 ;; 'xc') printf ">>>>>>> CANONICAL : "; go test "-tags=$ztags" $zargs -tc; sleep 2 ;; 'xi') printf ">>>>>>> I/O : "; go test "-tags=$ztags" $zargs -ti; sleep 2 ;; - 'xn') printf ">>>>>>> NO_SYMBOLS : "; go test "-tags=$ztags" -run=Binc $zargs -tn; sleep 2 ;; + 'xn') printf ">>>>>>> NO_SYMBOLS : "; go test "-tags=$ztags" $zargs -tn; sleep 2 ;; 'xs') printf ">>>>>>> TO_ARRAY : "; go test "-tags=$ztags" $zargs -ts; sleep 2 ;; 'xe') printf ">>>>>>> INTERN : "; go test "-tags=$ztags" $zargs -te; sleep 2 ;; - 'xd') printf ">>>>>>> INDENT : "; - go test "-tags=$ztags" -run=JsonCodecsTable -td=-1 $zargs; - go test "-tags=$ztags" -run=JsonCodecsTable -td=8 $zargs; - sleep 2 ;; *) ;; esac done @@ -61,20 +55,20 @@ _run() { # echo ">>>>>>> RUNNING VARIATIONS OF TESTS" if [[ "x$@" = "x" ]]; then # All: r, x, g, gu - _run "-_tcinsed_ml" # regular - _run "-_tcinsed_ml_z" # regular with reset - _run "-_tcinsed_ml_f" # regular with no fastpath (notfastpath) - _run "-x_tcinsed_ml" # external - _run "-gx_tcinsed_ml" # codecgen: requires external - _run "-gxu_tcinsed_ml" # codecgen + unsafe + _run "-rtcinsm" # regular + _run "-rtcinsmz" # regular with reset + _run "-rtcinsmf" # regular with no fastpath (notfastpath) + _run "-xtcinsm" # external + _run "-gxtcinsm" # codecgen: requires external + _run "-gxutcinsm" # codecgen + unsafe elif [[ "x$@" = "x-Z" ]]; then # Regular - _run "-_tcinsed_ml" # regular - _run "-_tcinsed_ml_z" # regular with reset + _run "-rtcinsm" # regular + _run "-rtcinsmz" # regular with reset elif [[ "x$@" = "x-F" ]]; then # regular with notfastpath - _run "-_tcinsed_ml_f" # regular - _run "-_tcinsed_ml_zf" # regular with reset + _run "-rtcinsmf" # regular + _run "-rtcinsmzf" # regular with reset else _run "$@" fi diff --git a/vendor/github.com/ugorji/go/codec/time.go b/vendor/github.com/ugorji/go/codec/time.go index 718b731..fc4c63e 100644 --- a/vendor/github.com/ugorji/go/codec/time.go +++ b/vendor/github.com/ugorji/go/codec/time.go @@ -5,22 +5,11 @@ package codec import ( "fmt" - "reflect" "time" ) var ( - timeDigits = [...]byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'} - timeExtEncFn = func(rv reflect.Value) (bs []byte, err error) { - defer panicToErr(&err) - bs = timeExt{}.WriteExt(rv.Interface()) - return - } - timeExtDecFn = func(rv reflect.Value, bs []byte) (err error) { - defer panicToErr(&err) - timeExt{}.ReadExt(rv.Interface(), bs) - return - } + timeDigits = [...]byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'} ) type timeExt struct{} diff --git a/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go b/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go index 22eabff..f31d882 100644 --- a/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +++ b/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go @@ -27,17 +27,7 @@ func Do(ctx context.Context, client *http.Client, req *http.Request) (*http.Resp if client == nil { client = http.DefaultClient } - resp, err := client.Do(req.WithContext(ctx)) - // If we got an error, and the context has been canceled, - // the context's error is probably more useful. - if err != nil { - select { - case <-ctx.Done(): - err = ctx.Err() - default: - } - } - return resp, err + return client.Do(req.WithContext(ctx)) } // Get issues a GET request via the Do function. diff --git a/vendor/golang.org/x/net/http2/client_conn_pool.go b/vendor/golang.org/x/net/http2/client_conn_pool.go index b139412..547e238 100644 --- a/vendor/golang.org/x/net/http2/client_conn_pool.go +++ b/vendor/golang.org/x/net/http2/client_conn_pool.go @@ -53,13 +53,13 @@ const ( ) func (p *clientConnPool) getClientConn(req *http.Request, addr string, dialOnMiss bool) (*ClientConn, error) { - if isConnectionCloseRequest(req) && dialOnMiss { + if req.Close && dialOnMiss { // It gets its own connection. - const singleUse = true - cc, err := p.t.dialClientConn(addr, singleUse) + cc, err := p.t.dialClientConn(addr) if err != nil { return nil, err } + cc.singleUse = true return cc, nil } p.mu.Lock() @@ -104,8 +104,7 @@ func (p *clientConnPool) getStartDialLocked(addr string) *dialCall { // run in its own goroutine. func (c *dialCall) dial(addr string) { - const singleUse = false // shared conn - c.res, c.err = c.p.t.dialClientConn(addr, singleUse) + c.res, c.err = c.p.t.dialClientConn(addr) close(c.done) c.p.mu.Lock() diff --git a/vendor/golang.org/x/net/http2/errors.go b/vendor/golang.org/x/net/http2/errors.go index 20fd762..71a4e29 100644 --- a/vendor/golang.org/x/net/http2/errors.go +++ b/vendor/golang.org/x/net/http2/errors.go @@ -64,17 +64,9 @@ func (e ConnectionError) Error() string { return fmt.Sprintf("connection error: type StreamError struct { StreamID uint32 Code ErrCode - Cause error // optional additional detail -} - -func streamError(id uint32, code ErrCode) StreamError { - return StreamError{StreamID: id, Code: code} } func (e StreamError) Error() string { - if e.Cause != nil { - return fmt.Sprintf("stream error: stream ID %d; %v; %v", e.StreamID, e.Code, e.Cause) - } return fmt.Sprintf("stream error: stream ID %d; %v", e.StreamID, e.Code) } diff --git a/vendor/golang.org/x/net/http2/frame.go b/vendor/golang.org/x/net/http2/frame.go index b0c79b0..981d407 100644 --- a/vendor/golang.org/x/net/http2/frame.go +++ b/vendor/golang.org/x/net/http2/frame.go @@ -594,7 +594,6 @@ func parseDataFrame(fh FrameHeader, payload []byte) (Frame, error) { var ( errStreamID = errors.New("invalid stream ID") errDepStreamID = errors.New("invalid dependent stream ID") - errPadLength = errors.New("pad length too large") ) func validStreamIDOrZero(streamID uint32) bool { @@ -608,40 +607,18 @@ func validStreamID(streamID uint32) bool { // WriteData writes a DATA frame. // // It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility not to violate the maximum frame size -// and to not call other Write methods concurrently. +// It is the caller's responsibility to not call other Write methods concurrently. func (f *Framer) WriteData(streamID uint32, endStream bool, data []byte) error { - return f.WriteDataPadded(streamID, endStream, data, nil) -} - -// WriteData writes a DATA frame with optional padding. -// -// If pad is nil, the padding bit is not sent. -// The length of pad must not exceed 255 bytes. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility not to violate the maximum frame size -// and to not call other Write methods concurrently. -func (f *Framer) WriteDataPadded(streamID uint32, endStream bool, data, pad []byte) error { + // TODO: ignoring padding for now. will add when somebody cares. if !validStreamID(streamID) && !f.AllowIllegalWrites { return errStreamID } - if len(pad) > 255 { - return errPadLength - } var flags Flags if endStream { flags |= FlagDataEndStream } - if pad != nil { - flags |= FlagDataPadded - } f.startWrite(FrameData, flags, streamID) - if pad != nil { - f.wbuf = append(f.wbuf, byte(len(pad))) - } f.wbuf = append(f.wbuf, data...) - f.wbuf = append(f.wbuf, pad...) return f.endWrite() } @@ -737,7 +714,7 @@ func (f *Framer) WriteSettings(settings ...Setting) error { return f.endWrite() } -// WriteSettingsAck writes an empty SETTINGS frame with the ACK bit set. +// WriteSettings writes an empty SETTINGS frame with the ACK bit set. // // It will perform exactly one Write to the underlying Writer. // It is the caller's responsibility to not call other Write methods concurrently. @@ -863,7 +840,7 @@ func parseWindowUpdateFrame(fh FrameHeader, p []byte) (Frame, error) { if fh.StreamID == 0 { return nil, ConnectionError(ErrCodeProtocol) } - return nil, streamError(fh.StreamID, ErrCodeProtocol) + return nil, StreamError{fh.StreamID, ErrCodeProtocol} } return &WindowUpdateFrame{ FrameHeader: fh, @@ -944,7 +921,7 @@ func parseHeadersFrame(fh FrameHeader, p []byte) (_ Frame, err error) { } } if len(p)-int(padLength) <= 0 { - return nil, streamError(fh.StreamID, ErrCodeProtocol) + return nil, StreamError{fh.StreamID, ErrCodeProtocol} } hf.headerFragBuf = p[:len(p)-int(padLength)] return hf, nil @@ -1419,9 +1396,6 @@ func (fr *Framer) readMetaFrame(hf *HeadersFrame) (*MetaHeadersFrame, error) { hdec.SetEmitEnabled(true) hdec.SetMaxStringLength(fr.maxHeaderStringLen()) hdec.SetEmitFunc(func(hf hpack.HeaderField) { - if VerboseLogs && logFrameReads { - log.Printf("http2: decoded hpack field %+v", hf) - } if !httplex.ValidHeaderFieldValue(hf.Value) { invalid = headerFieldValueError(hf.Value) } @@ -1480,17 +1454,11 @@ func (fr *Framer) readMetaFrame(hf *HeadersFrame) (*MetaHeadersFrame, error) { } if invalid != nil { fr.errDetail = invalid - if VerboseLogs { - log.Printf("http2: invalid header: %v", invalid) - } - return nil, StreamError{mh.StreamID, ErrCodeProtocol, invalid} + return nil, StreamError{mh.StreamID, ErrCodeProtocol} } if err := mh.checkPseudos(); err != nil { fr.errDetail = err - if VerboseLogs { - log.Printf("http2: invalid pseudo headers: %v", err) - } - return nil, StreamError{mh.StreamID, ErrCodeProtocol, err} + return nil, StreamError{mh.StreamID, ErrCodeProtocol} } return mh, nil } diff --git a/vendor/golang.org/x/net/http2/go17.go b/vendor/golang.org/x/net/http2/go17.go index 47b7fae..730319d 100644 --- a/vendor/golang.org/x/net/http2/go17.go +++ b/vendor/golang.org/x/net/http2/go17.go @@ -39,13 +39,6 @@ type clientTrace httptrace.ClientTrace func reqContext(r *http.Request) context.Context { return r.Context() } -func (t *Transport) idleConnTimeout() time.Duration { - if t.t1 != nil { - return t.t1.IdleConnTimeout - } - return 0 -} - func setResponseUncompressed(res *http.Response) { res.Uncompressed = true } func traceGotConn(req *http.Request, cc *ClientConn) { @@ -99,8 +92,3 @@ func requestTrace(req *http.Request) *clientTrace { trace := httptrace.ContextClientTrace(req.Context()) return (*clientTrace)(trace) } - -// Ping sends a PING frame to the server and waits for the ack. -func (cc *ClientConn) Ping(ctx context.Context) error { - return cc.ping(ctx) -} diff --git a/vendor/golang.org/x/net/http2/go17_not18.go b/vendor/golang.org/x/net/http2/go17_not18.go deleted file mode 100644 index b4c52ec..0000000 --- a/vendor/golang.org/x/net/http2/go17_not18.go +++ /dev/null @@ -1,36 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.7,!go1.8 - -package http2 - -import "crypto/tls" - -// temporary copy of Go 1.7's private tls.Config.clone: -func cloneTLSConfig(c *tls.Config) *tls.Config { - return &tls.Config{ - Rand: c.Rand, - Time: c.Time, - Certificates: c.Certificates, - NameToCertificate: c.NameToCertificate, - GetCertificate: c.GetCertificate, - RootCAs: c.RootCAs, - NextProtos: c.NextProtos, - ServerName: c.ServerName, - ClientAuth: c.ClientAuth, - ClientCAs: c.ClientCAs, - InsecureSkipVerify: c.InsecureSkipVerify, - CipherSuites: c.CipherSuites, - PreferServerCipherSuites: c.PreferServerCipherSuites, - SessionTicketsDisabled: c.SessionTicketsDisabled, - SessionTicketKey: c.SessionTicketKey, - ClientSessionCache: c.ClientSessionCache, - MinVersion: c.MinVersion, - MaxVersion: c.MaxVersion, - CurvePreferences: c.CurvePreferences, - DynamicRecordSizingDisabled: c.DynamicRecordSizingDisabled, - Renegotiation: c.Renegotiation, - } -} diff --git a/vendor/golang.org/x/net/http2/go18.go b/vendor/golang.org/x/net/http2/go18.go deleted file mode 100644 index c2ae167..0000000 --- a/vendor/golang.org/x/net/http2/go18.go +++ /dev/null @@ -1,11 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.8 - -package http2 - -import "crypto/tls" - -func cloneTLSConfig(c *tls.Config) *tls.Config { return c.Clone() } diff --git a/vendor/golang.org/x/net/http2/hpack/hpack.go b/vendor/golang.org/x/net/http2/hpack/hpack.go index 135b9f6..8aa197a 100644 --- a/vendor/golang.org/x/net/http2/hpack/hpack.go +++ b/vendor/golang.org/x/net/http2/hpack/hpack.go @@ -57,7 +57,7 @@ func (hf HeaderField) String() string { return fmt.Sprintf("header field %q = %q%s", hf.Name, hf.Value, suffix) } -// Size returns the size of an entry per RFC 7541 section 4.1. +// Size returns the size of an entry per RFC 7540 section 5.2. func (hf HeaderField) Size() uint32 { // http://http2.github.io/http2-spec/compression.html#rfc.section.4.1 // "The size of the dynamic table is the sum of the size of diff --git a/vendor/golang.org/x/net/http2/http2.go b/vendor/golang.org/x/net/http2/http2.go index 40b46ae..0173aed 100644 --- a/vendor/golang.org/x/net/http2/http2.go +++ b/vendor/golang.org/x/net/http2/http2.go @@ -13,7 +13,6 @@ // See https://http2.github.io/ for more information on HTTP/2. // // See https://http2.golang.org/ for a test server running this code. -// package http2 import ( @@ -343,23 +342,10 @@ func (s *sorter) Keys(h http.Header) []string { } func (s *sorter) SortStrings(ss []string) { - // Our sorter works on s.v, which sorter owns, so + // Our sorter works on s.v, which sorter owners, so // stash it away while we sort the user's buffer. save := s.v s.v = ss sort.Sort(s) s.v = save } - -// validPseudoPath reports whether v is a valid :path pseudo-header -// value. It must be either: -// -// *) a non-empty string starting with '/', but not with with "//", -// *) the string '*', for OPTIONS requests. -// -// For now this is only used a quick check for deciding when to clean -// up Opaque URLs before sending requests from the Transport. -// See golang.org/issue/16847 -func validPseudoPath(v string) bool { - return (len(v) > 0 && v[0] == '/' && (len(v) == 1 || v[1] != '/')) || v == "*" -} diff --git a/vendor/golang.org/x/net/http2/not_go17.go b/vendor/golang.org/x/net/http2/not_go17.go index 140434a..28df0c1 100644 --- a/vendor/golang.org/x/net/http2/not_go17.go +++ b/vendor/golang.org/x/net/http2/not_go17.go @@ -7,16 +7,11 @@ package http2 import ( - "crypto/tls" "net" "net/http" - "time" ) -type contextContext interface { - Done() <-chan struct{} - Err() error -} +type contextContext interface{} type fakeContext struct{} @@ -54,34 +49,3 @@ func contextWithCancel(ctx contextContext) (_ contextContext, cancel func()) { func requestWithContext(req *http.Request, ctx contextContext) *http.Request { return req } - -// temporary copy of Go 1.6's private tls.Config.clone: -func cloneTLSConfig(c *tls.Config) *tls.Config { - return &tls.Config{ - Rand: c.Rand, - Time: c.Time, - Certificates: c.Certificates, - NameToCertificate: c.NameToCertificate, - GetCertificate: c.GetCertificate, - RootCAs: c.RootCAs, - NextProtos: c.NextProtos, - ServerName: c.ServerName, - ClientAuth: c.ClientAuth, - ClientCAs: c.ClientCAs, - InsecureSkipVerify: c.InsecureSkipVerify, - CipherSuites: c.CipherSuites, - PreferServerCipherSuites: c.PreferServerCipherSuites, - SessionTicketsDisabled: c.SessionTicketsDisabled, - SessionTicketKey: c.SessionTicketKey, - ClientSessionCache: c.ClientSessionCache, - MinVersion: c.MinVersion, - MaxVersion: c.MaxVersion, - CurvePreferences: c.CurvePreferences, - } -} - -func (cc *ClientConn) Ping(ctx contextContext) error { - return cc.ping(ctx) -} - -func (t *Transport) idleConnTimeout() time.Duration { return 0 } diff --git a/vendor/golang.org/x/net/http2/server.go b/vendor/golang.org/x/net/http2/server.go index c986bc1..f368738 100644 --- a/vendor/golang.org/x/net/http2/server.go +++ b/vendor/golang.org/x/net/http2/server.go @@ -922,7 +922,7 @@ func (sc *serverConn) wroteFrame(res frameWriteResult) { // state here anyway, after telling the peer // we're hanging up on them. st.state = stateHalfClosedLocal // won't last long, but necessary for closeStream via resetStream - errCancel := streamError(st.id, ErrCodeCancel) + errCancel := StreamError{st.id, ErrCodeCancel} sc.resetStream(errCancel) case stateHalfClosedRemote: sc.closeStream(st, errHandlerComplete) @@ -1133,7 +1133,7 @@ func (sc *serverConn) processWindowUpdate(f *WindowUpdateFrame) error { return nil } if !st.flow.add(int32(f.Increment)) { - return streamError(f.StreamID, ErrCodeFlowControl) + return StreamError{f.StreamID, ErrCodeFlowControl} } default: // connection-level flow control if !sc.flow.add(int32(f.Increment)) { @@ -1159,7 +1159,7 @@ func (sc *serverConn) processResetStream(f *RSTStreamFrame) error { if st != nil { st.gotReset = true st.cancelCtx() - sc.closeStream(st, streamError(f.StreamID, f.ErrCode)) + sc.closeStream(st, StreamError{f.StreamID, f.ErrCode}) } return nil } @@ -1176,10 +1176,6 @@ func (sc *serverConn) closeStream(st *stream, err error) { } delete(sc.streams, st.id) if p := st.body; p != nil { - // Return any buffered unread bytes worth of conn-level flow control. - // See golang.org/issue/16481 - sc.sendWindowUpdate(nil, p.Len()) - p.CloseWithError(err) } st.cw.Close() // signals Handler's CloseNotifier, unblocks writes, etc @@ -1281,8 +1277,6 @@ func (sc *serverConn) processSettingInitialWindowSize(val uint32) error { func (sc *serverConn) processData(f *DataFrame) error { sc.serveG.check() - data := f.Data() - // "If a DATA frame is received whose stream is not in "open" // or "half closed (local)" state, the recipient MUST respond // with a stream error (Section 5.4.2) of type STREAM_CLOSED." @@ -1294,55 +1288,32 @@ func (sc *serverConn) processData(f *DataFrame) error { // the http.Handler returned, so it's done reading & // done writing). Try to stop the client from sending // more DATA. - - // But still enforce their connection-level flow control, - // and return any flow control bytes since we're not going - // to consume them. - if sc.inflow.available() < int32(f.Length) { - return streamError(id, ErrCodeFlowControl) - } - // Deduct the flow control from inflow, since we're - // going to immediately add it back in - // sendWindowUpdate, which also schedules sending the - // frames. - sc.inflow.take(int32(f.Length)) - sc.sendWindowUpdate(nil, int(f.Length)) // conn-level - - return streamError(id, ErrCodeStreamClosed) + return StreamError{id, ErrCodeStreamClosed} } if st.body == nil { panic("internal error: should have a body in this state") } + data := f.Data() // Sender sending more than they'd declared? if st.declBodyBytes != -1 && st.bodyBytes+int64(len(data)) > st.declBodyBytes { st.body.CloseWithError(fmt.Errorf("sender tried to send more than declared Content-Length of %d bytes", st.declBodyBytes)) - return streamError(id, ErrCodeStreamClosed) + return StreamError{id, ErrCodeStreamClosed} } - if f.Length > 0 { + if len(data) > 0 { // Check whether the client has flow control quota. - if st.inflow.available() < int32(f.Length) { - return streamError(id, ErrCodeFlowControl) + if int(st.inflow.available()) < len(data) { + return StreamError{id, ErrCodeFlowControl} } - st.inflow.take(int32(f.Length)) - - if len(data) > 0 { - wrote, err := st.body.Write(data) - if err != nil { - return streamError(id, ErrCodeStreamClosed) - } - if wrote != len(data) { - panic("internal error: bad Writer") - } - st.bodyBytes += int64(len(data)) + st.inflow.take(int32(len(data))) + wrote, err := st.body.Write(data) + if err != nil { + return StreamError{id, ErrCodeStreamClosed} } - - // Return any padded flow control now, since we won't - // refund it later on body reads. - if pad := int32(f.Length) - int32(len(data)); pad > 0 { - sc.sendWindowUpdate32(nil, pad) - sc.sendWindowUpdate32(st, pad) + if wrote != len(data) { + panic("internal error: bad Writer") } + st.bodyBytes += int64(len(data)) } if f.StreamEnded() { st.endStream() @@ -1446,14 +1417,14 @@ func (sc *serverConn) processHeaders(f *MetaHeadersFrame) error { // REFUSED_STREAM." if sc.unackedSettings == 0 { // They should know better. - return streamError(st.id, ErrCodeProtocol) + return StreamError{st.id, ErrCodeProtocol} } // Assume it's a network race, where they just haven't // received our last SETTINGS update. But actually // this can't happen yet, because we don't yet provide // a way for users to adjust server parameters at // runtime. - return streamError(st.id, ErrCodeRefusedStream) + return StreamError{st.id, ErrCodeRefusedStream} } rw, req, err := sc.newWriterAndRequest(st, f) @@ -1475,19 +1446,6 @@ func (sc *serverConn) processHeaders(f *MetaHeadersFrame) error { handler = new400Handler(err) } - // The net/http package sets the read deadline from the - // http.Server.ReadTimeout during the TLS handshake, but then - // passes the connection off to us with the deadline already - // set. Disarm it here after the request headers are read, similar - // to how the http1 server works. - // Unlike http1, though, we never re-arm it yet, though. - // TODO(bradfitz): figure out golang.org/issue/14204 - // (IdleTimeout) and how this relates. Maybe the default - // IdleTimeout is ReadTimeout. - if sc.hs.ReadTimeout != 0 { - sc.conn.SetReadDeadline(time.Time{}) - } - go sc.runHandler(rw, req, handler) return nil } @@ -1500,11 +1458,11 @@ func (st *stream) processTrailerHeaders(f *MetaHeadersFrame) error { } st.gotTrailerHeader = true if !f.StreamEnded() { - return streamError(st.id, ErrCodeProtocol) + return StreamError{st.id, ErrCodeProtocol} } if len(f.PseudoFields()) > 0 { - return streamError(st.id, ErrCodeProtocol) + return StreamError{st.id, ErrCodeProtocol} } if st.trailer != nil { for _, hf := range f.RegularFields() { @@ -1513,7 +1471,7 @@ func (st *stream) processTrailerHeaders(f *MetaHeadersFrame) error { // TODO: send more details to the peer somehow. But http2 has // no way to send debug data at a stream level. Discuss with // HTTP folk. - return streamError(st.id, ErrCodeProtocol) + return StreamError{st.id, ErrCodeProtocol} } st.trailer[key] = append(st.trailer[key], hf.Value) } @@ -1574,7 +1532,7 @@ func (sc *serverConn) newWriterAndRequest(st *stream, f *MetaHeadersFrame) (*res isConnect := method == "CONNECT" if isConnect { if path != "" || scheme != "" || authority == "" { - return nil, nil, streamError(f.StreamID, ErrCodeProtocol) + return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} } } else if method == "" || path == "" || (scheme != "https" && scheme != "http") { @@ -1588,13 +1546,13 @@ func (sc *serverConn) newWriterAndRequest(st *stream, f *MetaHeadersFrame) (*res // "All HTTP/2 requests MUST include exactly one valid // value for the :method, :scheme, and :path // pseudo-header fields" - return nil, nil, streamError(f.StreamID, ErrCodeProtocol) + return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} } bodyOpen := !f.StreamEnded() if method == "HEAD" && bodyOpen { // HEAD requests can't have bodies - return nil, nil, streamError(f.StreamID, ErrCodeProtocol) + return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} } var tlsState *tls.ConnectionState // nil if not scheme https @@ -1652,7 +1610,7 @@ func (sc *serverConn) newWriterAndRequest(st *stream, f *MetaHeadersFrame) (*res var err error url_, err = url.ParseRequestURI(path) if err != nil { - return nil, nil, streamError(f.StreamID, ErrCodeProtocol) + return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} } requestURI = path } diff --git a/vendor/golang.org/x/net/http2/transport.go b/vendor/golang.org/x/net/http2/transport.go index b939fed..fb8dd99 100644 --- a/vendor/golang.org/x/net/http2/transport.go +++ b/vendor/golang.org/x/net/http2/transport.go @@ -10,14 +10,12 @@ import ( "bufio" "bytes" "compress/gzip" - "crypto/rand" "crypto/tls" "errors" "fmt" "io" "io/ioutil" "log" - "math" "net" "net/http" "sort" @@ -27,7 +25,6 @@ import ( "time" "golang.org/x/net/http2/hpack" - "golang.org/x/net/idna" "golang.org/x/net/lex/httplex" ) @@ -151,32 +148,27 @@ type ClientConn struct { readerDone chan struct{} // closed on error readerErr error // set before readerDone is closed - idleTimeout time.Duration // or 0 for never - idleTimer *time.Timer + mu sync.Mutex // guards following + cond *sync.Cond // hold mu; broadcast on flow/closed changes + flow flow // our conn-level flow control quota (cs.flow is per stream) + inflow flow // peer's conn-level flow control + closed bool + goAway *GoAwayFrame // if non-nil, the GoAwayFrame we received + goAwayDebug string // goAway frame's debug data, retained as a string + streams map[uint32]*clientStream // client-initiated + nextStreamID uint32 + bw *bufio.Writer + br *bufio.Reader + fr *Framer + lastActive time.Time - mu sync.Mutex // guards following - cond *sync.Cond // hold mu; broadcast on flow/closed changes - flow flow // our conn-level flow control quota (cs.flow is per stream) - inflow flow // peer's conn-level flow control - closed bool - wantSettingsAck bool // we sent a SETTINGS frame and haven't heard back - goAway *GoAwayFrame // if non-nil, the GoAwayFrame we received - goAwayDebug string // goAway frame's debug data, retained as a string - streams map[uint32]*clientStream // client-initiated - nextStreamID uint32 - pings map[[8]byte]chan struct{} // in flight ping data to notification channel - bw *bufio.Writer - br *bufio.Reader - fr *Framer - lastActive time.Time - // Settings from peer: (also guarded by mu) + // Settings from peer: maxFrameSize uint32 maxConcurrentStreams uint32 initialWindowSize uint32 - - hbuf bytes.Buffer // HPACK encoder writes into this - henc *hpack.Encoder - freeBuf [][]byte + hbuf bytes.Buffer // HPACK encoder writes into this + henc *hpack.Encoder + freeBuf [][]byte wmu sync.Mutex // held while writing; acquire AFTER mu if holding both werr error // first write error that has occurred @@ -291,18 +283,14 @@ func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { // authorityAddr returns a given authority (a host/IP, or host:port / ip:port) // and returns a host:port. The port 443 is added if needed. func authorityAddr(scheme string, authority string) (addr string) { - host, port, err := net.SplitHostPort(authority) - if err != nil { // authority didn't have a port - port = "443" - if scheme == "http" { - port = "80" - } - host = authority + if _, _, err := net.SplitHostPort(authority); err == nil { + return authority } - if a, err := idna.ToASCII(host); err == nil { - host = a + port := "443" + if scheme == "http" { + port = "80" } - return net.JoinHostPort(host, port) + return net.JoinHostPort(authority, port) } // RoundTripOpt is like RoundTrip, but takes options. @@ -351,7 +339,7 @@ func shouldRetryRequest(req *http.Request, err error) bool { return err == errClientConnUnusable } -func (t *Transport) dialClientConn(addr string, singleUse bool) (*ClientConn, error) { +func (t *Transport) dialClientConn(addr string) (*ClientConn, error) { host, _, err := net.SplitHostPort(addr) if err != nil { return nil, err @@ -360,13 +348,13 @@ func (t *Transport) dialClientConn(addr string, singleUse bool) (*ClientConn, er if err != nil { return nil, err } - return t.newClientConn(tconn, singleUse) + return t.NewClientConn(tconn) } func (t *Transport) newTLSConfig(host string) *tls.Config { cfg := new(tls.Config) if t.TLSClientConfig != nil { - *cfg = *cloneTLSConfig(t.TLSClientConfig) + *cfg = *t.TLSClientConfig } if !strSliceContains(cfg.NextProtos, NextProtoTLS) { cfg.NextProtos = append([]string{NextProtoTLS}, cfg.NextProtos...) @@ -421,10 +409,14 @@ func (t *Transport) expectContinueTimeout() time.Duration { } func (t *Transport) NewClientConn(c net.Conn) (*ClientConn, error) { - return t.newClientConn(c, false) -} + if VerboseLogs { + t.vlogf("http2: Transport creating client conn to %v", c.RemoteAddr()) + } + if _, err := c.Write(clientPreface); err != nil { + t.vlogf("client preface write error: %v", err) + return nil, err + } -func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, error) { cc := &ClientConn{ t: t, tconn: c, @@ -434,18 +426,7 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro initialWindowSize: 65535, // spec default maxConcurrentStreams: 1000, // "infinite", per spec. 1000 seems good enough. streams: make(map[uint32]*clientStream), - singleUse: singleUse, - wantSettingsAck: true, - pings: make(map[[8]byte]chan struct{}), } - if d := t.idleConnTimeout(); d != 0 { - cc.idleTimeout = d - cc.idleTimer = time.AfterFunc(d, cc.onIdleTimeout) - } - if VerboseLogs { - t.vlogf("http2: Transport creating client conn %p to %v", cc, c.RemoteAddr()) - } - cc.cond = sync.NewCond(&cc.mu) cc.flow.add(int32(initialWindowSize)) @@ -473,8 +454,6 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro if max := t.maxHeaderListSize(); max != 0 { initialSettings = append(initialSettings, Setting{ID: SettingMaxHeaderListSize, Val: max}) } - - cc.bw.Write(clientPreface) cc.fr.WriteSettings(initialSettings...) cc.fr.WriteWindowUpdate(0, transportDefaultConnFlow) cc.inflow.add(transportDefaultConnFlow + initialWindowSize) @@ -483,6 +462,33 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro return nil, cc.werr } + // Read the obligatory SETTINGS frame + f, err := cc.fr.ReadFrame() + if err != nil { + return nil, err + } + sf, ok := f.(*SettingsFrame) + if !ok { + return nil, fmt.Errorf("expected settings frame, got: %T", f) + } + cc.fr.WriteSettingsAck() + cc.bw.Flush() + + sf.ForeachSetting(func(s Setting) error { + switch s.ID { + case SettingMaxFrameSize: + cc.maxFrameSize = s.Val + case SettingMaxConcurrentStreams: + cc.maxConcurrentStreams = s.Val + case SettingInitialWindowSize: + cc.initialWindowSize = s.Val + default: + // TODO(bradfitz): handle more; at least SETTINGS_HEADER_TABLE_SIZE? + t.vlogf("Unhandled Setting: %v", s) + } + return nil + }) + go cc.readLoop() return cc, nil } @@ -515,17 +521,7 @@ func (cc *ClientConn) canTakeNewRequestLocked() bool { } return cc.goAway == nil && !cc.closed && int64(len(cc.streams)+1) < int64(cc.maxConcurrentStreams) && - cc.nextStreamID < math.MaxInt32 -} - -// onIdleTimeout is called from a time.AfterFunc goroutine. It will -// only be called when we're idle, but because we're coming from a new -// goroutine, there could be a new request coming in at the same time, -// so this simply calls the synchronized closeIfIdle to shut down this -// connection. The timer could just call closeIfIdle, but this is more -// clear. -func (cc *ClientConn) onIdleTimeout() { - cc.closeIfIdle() + cc.nextStreamID < 2147483647 } func (cc *ClientConn) closeIfIdle() { @@ -535,13 +531,9 @@ func (cc *ClientConn) closeIfIdle() { return } cc.closed = true - nextID := cc.nextStreamID // TODO: do clients send GOAWAY too? maybe? Just Close: cc.mu.Unlock() - if VerboseLogs { - cc.vlogf("http2: Transport closing idle conn %p (forSingleUse=%v, maxStream=%v)", cc, cc.singleUse, nextID-2) - } cc.tconn.Close() } @@ -624,13 +616,13 @@ func (cc *ClientConn) responseHeaderTimeout() time.Duration { // Certain headers are special-cased as okay but not transmitted later. func checkConnHeaders(req *http.Request) error { if v := req.Header.Get("Upgrade"); v != "" { - return fmt.Errorf("http2: invalid Upgrade request header: %q", req.Header["Upgrade"]) + return errors.New("http2: invalid Upgrade request header") } - if vv := req.Header["Transfer-Encoding"]; len(vv) > 0 && (len(vv) > 1 || vv[0] != "" && vv[0] != "chunked") { - return fmt.Errorf("http2: invalid Transfer-Encoding request header: %q", vv) + if v := req.Header.Get("Transfer-Encoding"); (v != "" && v != "chunked") || len(req.Header["Transfer-Encoding"]) > 1 { + return errors.New("http2: invalid Transfer-Encoding request header") } - if vv := req.Header["Connection"]; len(vv) > 0 && (len(vv) > 1 || vv[0] != "" && vv[0] != "close" && vv[0] != "keep-alive") { - return fmt.Errorf("http2: invalid Connection request header: %q", vv) + if v := req.Header.Get("Connection"); (v != "" && v != "close" && v != "keep-alive") || len(req.Header["Connection"]) > 1 { + return errors.New("http2: invalid Connection request header") } return nil } @@ -643,27 +635,19 @@ func bodyAndLength(req *http.Request) (body io.Reader, contentLen int64) { if req.ContentLength != 0 { return req.Body, req.ContentLength } - // Don't try to sniff the size if they're doing an expect - // request (Issue 16002): - if req.Header.Get("Expect") == "100-continue" { - return req.Body, -1 - } // We have a body but a zero content length. Test to see if // it's actually zero or just unset. var buf [1]byte - n, rerr := body.Read(buf[:]) + n, rerr := io.ReadFull(body, buf[:]) if rerr != nil && rerr != io.EOF { return errorReader{rerr}, -1 } if n == 1 { // Oh, guess there is data in this Body Reader after all. // The ContentLength field just wasn't set. - // Stitch the Body back together again, re-attaching our + // Stich the Body back together again, re-attaching our // consumed byte. - if rerr == io.EOF { - return bytes.NewReader(buf[:]), 1 - } return io.MultiReader(bytes.NewReader(buf[:]), body), -1 } // Body is actually zero bytes. @@ -674,9 +658,6 @@ func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { if err := checkConnHeaders(req); err != nil { return nil, err } - if cc.idleTimer != nil { - cc.idleTimer.Stop() - } trailers, err := commaSeparatedTrailers(req) if err != nil { @@ -684,6 +665,9 @@ func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { } hasTrailers := trailers != "" + body, contentLen := bodyAndLength(req) + hasBody := body != nil + cc.mu.Lock() cc.lastActive = time.Now() if cc.closed || !cc.canTakeNewRequestLocked() { @@ -691,9 +675,6 @@ func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { return nil, errClientConnUnusable } - body, contentLen := bodyAndLength(req) - hasBody := body != nil - // TODO(bradfitz): this is a copy of the logic in net/http. Unify somewhere? var requestedGzip bool if !cc.t.disableCompression() && @@ -766,34 +747,30 @@ func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { bodyWritten := false ctx := reqContext(req) - handleReadLoopResponse := func(re resAndError) (*http.Response, error) { - res := re.res - if re.err != nil || res.StatusCode > 299 { - // On error or status code 3xx, 4xx, 5xx, etc abort any - // ongoing write, assuming that the server doesn't care - // about our request body. If the server replied with 1xx or - // 2xx, however, then assume the server DOES potentially - // want our body (e.g. full-duplex streaming: - // golang.org/issue/13444). If it turns out the server - // doesn't, they'll RST_STREAM us soon enough. This is a - // heuristic to avoid adding knobs to Transport. Hopefully - // we can keep it. - bodyWriter.cancel() - cs.abortRequestBodyWrite(errStopReqBodyWrite) - } - if re.err != nil { - cc.forgetStreamID(cs.ID) - return nil, re.err - } - res.Request = req - res.TLS = cc.tlsState - return res, nil - } - for { select { case re := <-readLoopResCh: - return handleReadLoopResponse(re) + res := re.res + if re.err != nil || res.StatusCode > 299 { + // On error or status code 3xx, 4xx, 5xx, etc abort any + // ongoing write, assuming that the server doesn't care + // about our request body. If the server replied with 1xx or + // 2xx, however, then assume the server DOES potentially + // want our body (e.g. full-duplex streaming: + // golang.org/issue/13444). If it turns out the server + // doesn't, they'll RST_STREAM us soon enough. This is a + // heuristic to avoid adding knobs to Transport. Hopefully + // we can keep it. + bodyWriter.cancel() + cs.abortRequestBodyWrite(errStopReqBodyWrite) + } + if re.err != nil { + cc.forgetStreamID(cs.ID) + return nil, re.err + } + res.Request = req + res.TLS = cc.tlsState + return res, nil case <-respHeaderTimer: cc.forgetStreamID(cs.ID) if !hasBody || bodyWritten { @@ -827,12 +804,6 @@ func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { // forgetStreamID. return nil, cs.resetErr case err := <-bodyWriter.resc: - // Prefer the read loop's response, if available. Issue 16102. - select { - case re := <-readLoopResCh: - return handleReadLoopResponse(re) - default: - } if err != nil { return nil, err } @@ -937,11 +908,10 @@ func (cs *clientStream) writeRequestBody(body io.Reader, bodyCloser io.Closer) ( err = cc.fr.WriteData(cs.ID, sentEnd, data) if err == nil { // TODO(bradfitz): this flush is for latency, not bandwidth. - // Most requests won't need this. Make this opt-in or - // opt-out? Use some heuristic on the body type? Nagel-like - // timers? Based on 'n'? Only last chunk of this for loop, - // unless flow control tokens are low? For now, always. - // If we change this, see comment below. + // Most requests won't need this. Make this opt-in or opt-out? + // Use some heuristic on the body type? Nagel-like timers? + // Based on 'n'? Only last chunk of this for loop, unless flow control + // tokens are low? For now, always: err = cc.bw.Flush() } cc.wmu.Unlock() @@ -951,33 +921,28 @@ func (cs *clientStream) writeRequestBody(body io.Reader, bodyCloser io.Closer) ( } } - if sentEnd { - // Already sent END_STREAM (which implies we have no - // trailers) and flushed, because currently all - // WriteData frames above get a flush. So we're done. - return nil - } - - var trls []byte - if hasTrailers { - cc.mu.Lock() - defer cc.mu.Unlock() - trls = cc.encodeTrailers(req) - } - cc.wmu.Lock() - defer cc.wmu.Unlock() + if !sentEnd { + var trls []byte + if hasTrailers { + cc.mu.Lock() + trls = cc.encodeTrailers(req) + cc.mu.Unlock() + } - // Two ways to send END_STREAM: either with trailers, or - // with an empty DATA frame. - if len(trls) > 0 { - err = cc.writeHeaders(cs.ID, true, trls) - } else { - err = cc.fr.WriteData(cs.ID, true, nil) + // Avoid forgetting to send an END_STREAM if the encoded + // trailers are 0 bytes. Both results produce and END_STREAM. + if len(trls) > 0 { + err = cc.writeHeaders(cs.ID, true, trls) + } else { + err = cc.fr.WriteData(cs.ID, true, nil) + } } if ferr := cc.bw.Flush(); ferr != nil && err == nil { err = ferr } + cc.wmu.Unlock() + return err } @@ -1030,26 +995,6 @@ func (cc *ClientConn) encodeHeaders(req *http.Request, addGzipHeader bool, trail if host == "" { host = req.URL.Host } - host, err := httplex.PunycodeHostPort(host) - if err != nil { - return nil, err - } - - var path string - if req.Method != "CONNECT" { - path = req.URL.RequestURI() - if !validPseudoPath(path) { - orig := path - path = strings.TrimPrefix(path, req.URL.Scheme+"://"+host) - if !validPseudoPath(path) { - if req.URL.Opaque != "" { - return nil, fmt.Errorf("invalid request :path %q from URL.Opaque = %q", orig, req.URL.Opaque) - } else { - return nil, fmt.Errorf("invalid request :path %q", orig) - } - } - } - } // Check for any invalid headers and return an error before we // potentially pollute our hpack state. (We want to be able to @@ -1073,8 +1018,8 @@ func (cc *ClientConn) encodeHeaders(req *http.Request, addGzipHeader bool, trail cc.writeHeader(":authority", host) cc.writeHeader(":method", req.Method) if req.Method != "CONNECT" { - cc.writeHeader(":path", path) - cc.writeHeader(":scheme", req.URL.Scheme) + cc.writeHeader(":path", req.URL.RequestURI()) + cc.writeHeader(":scheme", "https") } if trailers != "" { cc.writeHeader("trailer", trailers) @@ -1201,9 +1146,6 @@ func (cc *ClientConn) streamByID(id uint32, andRemove bool) *clientStream { if andRemove && cs != nil && !cc.closed { cc.lastActive = time.Now() delete(cc.streams, id) - if len(cc.streams) == 0 && cc.idleTimer != nil { - cc.idleTimer.Reset(cc.idleTimeout) - } close(cs.done) cc.cond.Broadcast() // wake up checkResetOrDone via clientStream.awaitFlowControl } @@ -1246,37 +1188,27 @@ func (e GoAwayError) Error() string { e.LastStreamID, e.ErrCode, e.DebugData) } -func isEOFOrNetReadError(err error) bool { - if err == io.EOF { - return true - } - ne, ok := err.(*net.OpError) - return ok && ne.Op == "read" -} - func (rl *clientConnReadLoop) cleanup() { cc := rl.cc defer cc.tconn.Close() defer cc.t.connPool().MarkDead(cc) defer close(cc.readerDone) - if cc.idleTimer != nil { - cc.idleTimer.Stop() - } - // Close any response bodies if the server closes prematurely. // TODO: also do this if we've written the headers but not // gotten a response yet. err := cc.readerErr cc.mu.Lock() - if cc.goAway != nil && isEOFOrNetReadError(err) { - err = GoAwayError{ - LastStreamID: cc.goAway.LastStreamID, - ErrCode: cc.goAway.ErrCode, - DebugData: cc.goAwayDebug, + if err == io.EOF { + if cc.goAway != nil { + err = GoAwayError{ + LastStreamID: cc.goAway.LastStreamID, + ErrCode: cc.goAway.ErrCode, + DebugData: cc.goAwayDebug, + } + } else { + err = io.ErrUnexpectedEOF } - } else if err == io.EOF { - err = io.ErrUnexpectedEOF } for _, cs := range rl.activeRes { cs.bufPipe.CloseWithError(err) @@ -1296,20 +1228,15 @@ func (rl *clientConnReadLoop) cleanup() { func (rl *clientConnReadLoop) run() error { cc := rl.cc rl.closeWhenIdle = cc.t.disableKeepAlives() || cc.singleUse - gotReply := false // ever saw a HEADERS reply - gotSettings := false + gotReply := false // ever saw a reply for { f, err := cc.fr.ReadFrame() if err != nil { - cc.vlogf("http2: Transport readFrame error on conn %p: (%T) %v", cc, err, err) + cc.vlogf("Transport readFrame error: (%T) %v", err, err) } if se, ok := err.(StreamError); ok { if cs := cc.streamByID(se.StreamID, true /*ended; remove it*/); cs != nil { - cs.cc.writeStreamReset(cs.ID, se.Code, err) - if se.Cause == nil { - se.Cause = cc.fr.errDetail - } - rl.endStreamError(cs, se) + rl.endStreamError(cs, cc.fr.errDetail) } continue } else if err != nil { @@ -1318,13 +1245,6 @@ func (rl *clientConnReadLoop) run() error { if VerboseLogs { cc.vlogf("http2: Transport received %s", summarizeFrame(f)) } - if !gotSettings { - if _, ok := f.(*SettingsFrame); !ok { - cc.logf("protocol error: received %T before a SETTINGS frame", f) - return ConnectionError(ErrCodeProtocol) - } - gotSettings = true - } maybeIdle := false // whether frame might transition us to idle switch f := f.(type) { @@ -1353,9 +1273,6 @@ func (rl *clientConnReadLoop) run() error { cc.logf("Transport: unhandled response frame type %T", f) } if err != nil { - if VerboseLogs { - cc.vlogf("http2: Transport conn %p received error from processing frame %v: %v", cc, summarizeFrame(f), err) - } return err } if rl.closeWhenIdle && gotReply && maybeIdle && len(rl.activeRes) == 0 { @@ -1605,27 +1522,10 @@ var errClosedResponseBody = errors.New("http2: response body closed") func (b transportResponseBody) Close() error { cs := b.cs - cc := cs.cc - - serverSentStreamEnd := cs.bufPipe.Err() == io.EOF - unread := cs.bufPipe.Len() - - if unread > 0 || !serverSentStreamEnd { - cc.mu.Lock() - cc.wmu.Lock() - if !serverSentStreamEnd { - cc.fr.WriteRSTStream(cs.ID, ErrCodeCancel) - } - // Return connection-level flow control. - if unread > 0 { - cc.inflow.add(int32(unread)) - cc.fr.WriteWindowUpdate(0, uint32(unread)) - } - cc.bw.Flush() - cc.wmu.Unlock() - cc.mu.Unlock() + if cs.bufPipe.Err() != io.EOF { + // TODO: write test for this + cs.cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) } - cs.bufPipe.BreakWithError(errClosedResponseBody) return nil } @@ -1633,7 +1533,6 @@ func (b transportResponseBody) Close() error { func (rl *clientConnReadLoop) processData(f *DataFrame) error { cc := rl.cc cs := cc.streamByID(f.StreamID, f.StreamEnded()) - data := f.Data() if cs == nil { cc.mu.Lock() neverSent := cc.nextStreamID @@ -1647,22 +1546,10 @@ func (rl *clientConnReadLoop) processData(f *DataFrame) error { // TODO: be stricter here? only silently ignore things which // we canceled, but not things which were closed normally // by the peer? Tough without accumulating too much state. - - // But at least return their flow control: - if f.Length > 0 { - cc.mu.Lock() - cc.inflow.add(int32(f.Length)) - cc.mu.Unlock() - - cc.wmu.Lock() - cc.fr.WriteWindowUpdate(0, uint32(f.Length)) - cc.bw.Flush() - cc.wmu.Unlock() - } return nil } - if f.Length > 0 { - if len(data) > 0 && cs.bufPipe.b == nil { + if data := f.Data(); len(data) > 0 { + if cs.bufPipe.b == nil { // Data frame after it's already closed? cc.logf("http2: Transport received DATA frame for closed stream; closing connection") return ConnectionError(ErrCodeProtocol) @@ -1670,30 +1557,17 @@ func (rl *clientConnReadLoop) processData(f *DataFrame) error { // Check connection-level flow control. cc.mu.Lock() - if cs.inflow.available() >= int32(f.Length) { - cs.inflow.take(int32(f.Length)) + if cs.inflow.available() >= int32(len(data)) { + cs.inflow.take(int32(len(data))) } else { cc.mu.Unlock() return ConnectionError(ErrCodeFlowControl) } - // Return any padded flow control now, since we won't - // refund it later on body reads. - if pad := int32(f.Length) - int32(len(data)); pad > 0 { - cs.inflow.add(pad) - cc.inflow.add(pad) - cc.wmu.Lock() - cc.fr.WriteWindowUpdate(0, uint32(pad)) - cc.fr.WriteWindowUpdate(cs.ID, uint32(pad)) - cc.bw.Flush() - cc.wmu.Unlock() - } cc.mu.Unlock() - if len(data) > 0 { - if _, err := cs.bufPipe.Write(data); err != nil { - rl.endStreamError(cs, err) - return err - } + if _, err := cs.bufPipe.Write(data); err != nil { + rl.endStreamError(cs, err) + return err } } @@ -1719,14 +1593,9 @@ func (rl *clientConnReadLoop) endStreamError(cs *clientStream, err error) { } cs.bufPipe.closeWithErrorAndCode(err, code) delete(rl.activeRes, cs.ID) - if isConnectionCloseRequest(cs.req) { + if cs.req.Close || cs.req.Header.Get("Connection") == "close" { rl.closeWhenIdle = true } - - select { - case cs.resc <- resAndError{err: err}: - default: - } } func (cs *clientStream) copyTrailers() { @@ -1754,39 +1623,18 @@ func (rl *clientConnReadLoop) processSettings(f *SettingsFrame) error { cc := rl.cc cc.mu.Lock() defer cc.mu.Unlock() - - if f.IsAck() { - if cc.wantSettingsAck { - cc.wantSettingsAck = false - return nil - } - return ConnectionError(ErrCodeProtocol) - } - - err := f.ForeachSetting(func(s Setting) error { + return f.ForeachSetting(func(s Setting) error { switch s.ID { case SettingMaxFrameSize: cc.maxFrameSize = s.Val case SettingMaxConcurrentStreams: cc.maxConcurrentStreams = s.Val case SettingInitialWindowSize: - // Values above the maximum flow-control - // window size of 2^31-1 MUST be treated as a - // connection error (Section 5.4.1) of type - // FLOW_CONTROL_ERROR. - if s.Val > math.MaxInt32 { - return ConnectionError(ErrCodeFlowControl) - } + // TODO: error if this is too large. - // Adjust flow control of currently-open + // TODO: adjust flow control of still-open // frames by the difference of the old initial // window size and this one. - delta := int32(s.Val) - int32(cc.initialWindowSize) - for _, cs := range cc.streams { - cs.flow.add(delta) - } - cc.cond.Broadcast() - cc.initialWindowSize = s.Val default: // TODO(bradfitz): handle more settings? SETTINGS_HEADER_TABLE_SIZE probably. @@ -1794,16 +1642,6 @@ func (rl *clientConnReadLoop) processSettings(f *SettingsFrame) error { } return nil }) - if err != nil { - return err - } - - cc.wmu.Lock() - defer cc.wmu.Unlock() - - cc.fr.WriteSettingsAck() - cc.bw.Flush() - return cc.werr } func (rl *clientConnReadLoop) processWindowUpdate(f *WindowUpdateFrame) error { @@ -1840,7 +1678,7 @@ func (rl *clientConnReadLoop) processResetStream(f *RSTStreamFrame) error { // which closes this, so there // isn't a race. default: - err := streamError(cs.ID, f.ErrCode) + err := StreamError{cs.ID, f.ErrCode} cs.resetErr = err close(cs.peerReset) cs.bufPipe.CloseWithError(err) @@ -1850,56 +1688,10 @@ func (rl *clientConnReadLoop) processResetStream(f *RSTStreamFrame) error { return nil } -// Ping sends a PING frame to the server and waits for the ack. -// Public implementation is in go17.go and not_go17.go -func (cc *ClientConn) ping(ctx contextContext) error { - c := make(chan struct{}) - // Generate a random payload - var p [8]byte - for { - if _, err := rand.Read(p[:]); err != nil { - return err - } - cc.mu.Lock() - // check for dup before insert - if _, found := cc.pings[p]; !found { - cc.pings[p] = c - cc.mu.Unlock() - break - } - cc.mu.Unlock() - } - cc.wmu.Lock() - if err := cc.fr.WritePing(false, p); err != nil { - cc.wmu.Unlock() - return err - } - if err := cc.bw.Flush(); err != nil { - cc.wmu.Unlock() - return err - } - cc.wmu.Unlock() - select { - case <-c: - return nil - case <-ctx.Done(): - return ctx.Err() - case <-cc.readerDone: - // connection closed - return cc.readerErr - } -} - func (rl *clientConnReadLoop) processPing(f *PingFrame) error { if f.IsAck() { - cc := rl.cc - cc.mu.Lock() - defer cc.mu.Unlock() - // If ack, notify listener if any - if c, ok := cc.pings[f.Data]; ok { - close(c) - delete(cc.pings, f.Data) - } + // 6.7 PING: " An endpoint MUST NOT respond to PING frames + // containing this flag." return nil } cc := rl.cc @@ -1923,10 +1715,8 @@ func (rl *clientConnReadLoop) processPushPromise(f *PushPromiseFrame) error { } func (cc *ClientConn) writeStreamReset(streamID uint32, code ErrCode, err error) { - // TODO: map err to more interesting error codes, once the - // HTTP community comes up with some. But currently for - // RST_STREAM there's no equivalent to GOAWAY frame's debug - // data, and the error codes are all pretty vague ("cancel"). + // TODO: do something with err? send it as a debug frame to the peer? + // But that's only in GOAWAY. Invent a new frame type? Is there one already? cc.wmu.Lock() cc.fr.WriteRSTStream(streamID, code) cc.bw.Flush() @@ -2076,9 +1866,3 @@ func (s bodyWriterState) scheduleBodyWrite() { s.timer.Reset(s.delay) } } - -// isConnectionCloseRequest reports whether req should use its own -// connection for a single request and then close the connection. -func isConnectionCloseRequest(req *http.Request) bool { - return req.Close || httplex.HeaderValuesContainsToken(req.Header["Connection"], "close") -} diff --git a/vendor/golang.org/x/net/lex/httplex/httplex.go b/vendor/golang.org/x/net/lex/httplex/httplex.go index 20f2b89..bd0ec24 100644 --- a/vendor/golang.org/x/net/lex/httplex/httplex.go +++ b/vendor/golang.org/x/net/lex/httplex/httplex.go @@ -10,11 +10,8 @@ package httplex import ( - "net" "strings" "unicode/utf8" - - "golang.org/x/net/idna" ) var isTokenTable = [127]bool{ @@ -313,39 +310,3 @@ func ValidHeaderFieldValue(v string) bool { } return true } - -func isASCII(s string) bool { - for i := 0; i < len(s); i++ { - if s[i] >= utf8.RuneSelf { - return false - } - } - return true -} - -// PunycodeHostPort returns the IDNA Punycode version -// of the provided "host" or "host:port" string. -func PunycodeHostPort(v string) (string, error) { - if isASCII(v) { - return v, nil - } - - host, port, err := net.SplitHostPort(v) - if err != nil { - // The input 'v' argument was just a "host" argument, - // without a port. This error should not be returned - // to the caller. - host = v - port = "" - } - host, err = idna.ToASCII(host) - if err != nil { - // Non-UTF-8? Not representable in Punycode, in any - // case. - return "", err - } - if port == "" { - return host, nil - } - return net.JoinHostPort(host, port), nil -} diff --git a/vendor/golang.org/x/text/cases/cases.go b/vendor/golang.org/x/text/cases/cases.go index 9c84bb1..13b3a57 100644 --- a/vendor/golang.org/x/text/cases/cases.go +++ b/vendor/golang.org/x/text/cases/cases.go @@ -35,7 +35,7 @@ import ( // A Caser may be stateful and should therefore not be shared between // goroutines. type Caser struct { - t transform.SpanningTransformer + t transform.Transformer } // Bytes returns a new byte slice with the result of converting b to the case @@ -56,17 +56,12 @@ func (c Caser) String(s string) string { // Transform. func (c Caser) Reset() { c.t.Reset() } -// Transform implements the transform.Transformer interface and transforms the -// given input to the case form implemented by c. +// Transform implements the Transformer interface and transforms the given input +// to the case form implemented by c. func (c Caser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { return c.t.Transform(dst, src, atEOF) } -// Span implements the transform.SpanningTransformer interface. -func (c Caser) Span(src []byte, atEOF bool) (n int, err error) { - return c.t.Span(src, atEOF) -} - // Upper returns a Caser for language-specific uppercasing. func Upper(t language.Tag, opts ...Option) Caser { return Caser{makeUpper(t, getOpts(opts...))} @@ -95,13 +90,7 @@ func Fold(opts ...Option) Caser { } // An Option is used to modify the behavior of a Caser. -type Option func(o options) options - -// TODO: consider these options to take a boolean as well, like FinalSigma. -// The advantage of using this approach is that other providers of a lower-case -// algorithm could set different defaults by prefixing a user-provided slice -// of options with their own. This is handy, for instance, for the precis -// package which would override the default to not handle the Greek final sigma. +type Option func(o *options) var ( // NoLower disables the lowercasing of non-leading letters for a title @@ -121,42 +110,20 @@ type options struct { // TODO: segmenter, max ignorable, alternative versions, etc. - ignoreFinalSigma bool + noFinalSigma bool // Only used for testing. } func getOpts(o ...Option) (res options) { for _, f := range o { - res = f(res) + f(&res) } return } -func noLower(o options) options { +func noLower(o *options) { o.noLower = true - return o } -func compact(o options) options { +func compact(o *options) { o.simple = true - return o -} - -// HandleFinalSigma specifies whether the special handling of Greek final sigma -// should be enabled. Unicode prescribes handling the Greek final sigma for all -// locales, but standards like IDNA and PRECIS override this default. -func HandleFinalSigma(enable bool) Option { - if enable { - return handleFinalSigma - } - return ignoreFinalSigma -} - -func ignoreFinalSigma(o options) options { - o.ignoreFinalSigma = true - return o -} - -func handleFinalSigma(o options) options { - o.ignoreFinalSigma = false - return o } diff --git a/vendor/golang.org/x/text/cases/context.go b/vendor/golang.org/x/text/cases/context.go index e9aa9e1..0d2e497 100644 --- a/vendor/golang.org/x/text/cases/context.go +++ b/vendor/golang.org/x/text/cases/context.go @@ -4,7 +4,9 @@ package cases -import "golang.org/x/text/transform" +import ( + "golang.org/x/text/transform" +) // A context is used for iterating over source bytes, fetching case info and // writing to a destination buffer. @@ -54,14 +56,6 @@ func (c *context) ret() (nDst, nSrc int, err error) { return c.nDst, c.nSrc, transform.ErrShortSrc } -// retSpan returns the return values for the Span method. It checks whether -// there were insufficient bytes in src to complete and introduces an error -// accordingly, if necessary. -func (c *context) retSpan() (n int, err error) { - _, nSrc, err := c.ret() - return nSrc, err -} - // checkpoint sets the return value buffer points for Transform to the current // positions. func (c *context) checkpoint() { @@ -206,23 +200,6 @@ func lower(c *context) bool { return c.copy() } -func isLower(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cLower { - return true - } - if c.info&exceptionBit == 0 { - c.err = transform.ErrEndOfSpan - return false - } - e := exceptions[c.info>>exceptionShift:] - if nLower := (e[1] >> lengthBits) & lengthMask; nLower != noChange { - c.err = transform.ErrEndOfSpan - return false - } - return true -} - // upper writes the uppercase version of the current rune to dst. func upper(c *context) bool { ct := c.caseType() @@ -249,29 +226,6 @@ func upper(c *context) bool { return c.copy() } -// isUpper writes the isUppercase version of the current rune to dst. -func isUpper(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cUpper { - return true - } - if c.info&exceptionBit == 0 { - c.err = transform.ErrEndOfSpan - return false - } - e := exceptions[c.info>>exceptionShift:] - // Get length of first special case mapping. - n := (e[1] >> lengthBits) & lengthMask - if ct == cTitle { - n = e[1] & lengthMask - } - if n != noChange { - c.err = transform.ErrEndOfSpan - return false - } - return true -} - // title writes the title case version of the current rune to dst. func title(c *context) bool { ct := c.caseType() @@ -303,33 +257,6 @@ func title(c *context) bool { return c.copy() } -// isTitle reports whether the current rune is in title case. -func isTitle(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cTitle { - return true - } - if c.info&exceptionBit == 0 { - if ct == cLower { - c.err = transform.ErrEndOfSpan - return false - } - return true - } - // Get the exception data. - e := exceptions[c.info>>exceptionShift:] - if nTitle := e[1] & lengthMask; nTitle != noChange { - c.err = transform.ErrEndOfSpan - return false - } - nFirst := (e[1] >> lengthBits) & lengthMask - if ct == cLower && nFirst != noChange { - c.err = transform.ErrEndOfSpan - return false - } - return true -} - // foldFull writes the foldFull version of the current rune to dst. func foldFull(c *context) bool { if c.info&hasMappingMask == 0 { @@ -352,25 +279,3 @@ func foldFull(c *context) bool { } return c.writeString(e[2 : 2+n]) } - -// isFoldFull reports whether the current run is mapped to foldFull -func isFoldFull(c *context) bool { - if c.info&hasMappingMask == 0 { - return true - } - ct := c.caseType() - if c.info&exceptionBit == 0 { - if ct != cLower || c.info&inverseFoldBit != 0 { - c.err = transform.ErrEndOfSpan - return false - } - return true - } - e := exceptions[c.info>>exceptionShift:] - n := e[0] & lengthMask - if n == 0 && ct == cLower { - return true - } - c.err = transform.ErrEndOfSpan - return false -} diff --git a/vendor/golang.org/x/text/cases/fold.go b/vendor/golang.org/x/text/cases/fold.go index 85cc434..e95bfa8 100644 --- a/vendor/golang.org/x/text/cases/fold.go +++ b/vendor/golang.org/x/text/cases/fold.go @@ -18,15 +18,7 @@ func (t *caseFolder) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err return c.ret() } -func (t *caseFolder) Span(src []byte, atEOF bool) (n int, err error) { - c := context{src: src, atEOF: atEOF} - for c.next() && isFoldFull(&c) { - c.checkpoint() - } - return c.retSpan() -} - -func makeFold(o options) transform.SpanningTransformer { +func makeFold(o options) transform.Transformer { // TODO: Special case folding, through option Language, Special/Turkic, or // both. // TODO: Implement Compact options. diff --git a/vendor/golang.org/x/text/cases/gen.go b/vendor/golang.org/x/text/cases/gen.go index eb399ba..f46170f 100644 --- a/vendor/golang.org/x/text/cases/gen.go +++ b/vendor/golang.org/x/text/cases/gen.go @@ -76,7 +76,7 @@ type breakCategory int const ( breakBreak breakCategory = iota breakLetter - breakMid + breakIgnored ) // mapping returns the case mapping for the given case type. @@ -162,14 +162,9 @@ func parseUCD() []runeInfo { // We collapse the word breaking properties onto the categories we need. switch p.String(1) { // TODO: officially we need to canonicalize. - case "MidLetter", "MidNumLet", "Single_Quote": - ri.BreakCat = breakMid - if !ri.CaseIgnorable { - // finalSigma relies on the fact that all breakMid runes are - // also a Case_Ignorable. Revisit this code when this changes. - log.Fatalf("Rune %U, which has a break category mid, is not a case ignorable", ri) - } - case "ALetter", "Hebrew_Letter", "Numeric", "Extend", "ExtendNumLet", "Format", "ZWJ": + case "Format", "MidLetter", "MidNumLet", "Single_Quote": + ri.BreakCat = breakIgnored + case "ALetter", "Hebrew_Letter", "Numeric", "Extend", "ExtendNumLet": ri.BreakCat = breakLetter } }) @@ -245,11 +240,8 @@ func makeEntry(ri *runeInfo) { case above: // Above ccc = cccAbove } - switch ri.BreakCat { - case breakBreak: + if ri.BreakCat == breakBreak { ccc = cccBreak - case breakMid: - ri.entry |= isMidBit } ri.entry |= ccc @@ -698,7 +690,7 @@ func genTablesTest() { parse("auxiliary/WordBreakProperty.txt", func(p *ucd.Parser) { switch p.String(1) { case "Extend", "Format", "MidLetter", "MidNumLet", "Single_Quote", - "ALetter", "Hebrew_Letter", "Numeric", "ExtendNumLet", "ZWJ": + "ALetter", "Hebrew_Letter", "Numeric", "ExtendNumLet": notBreak[p.Rune(0)] = true } }) diff --git a/vendor/golang.org/x/text/cases/gen_trieval.go b/vendor/golang.org/x/text/cases/gen_trieval.go index 376d22c..cf1a99d 100644 --- a/vendor/golang.org/x/text/cases/gen_trieval.go +++ b/vendor/golang.org/x/text/cases/gen_trieval.go @@ -26,7 +26,6 @@ package main // Only 13..8 are used for XOR patterns. // 7 inverseFold (fold to upper, not to lower) // 6 index: interpret the XOR pattern as an index -// or isMid if case mode is cIgnorableUncased. // 5..4 CCC: zero (normal or break), above or other // } // 3 exception: interpret this value as an exception index @@ -49,7 +48,6 @@ const ( ignorableValue = 0x0004 inverseFoldBit = 1 << 7 - isMidBit = 1 << 6 exceptionBit = 1 << 3 exceptionShift = 5 @@ -59,7 +57,7 @@ const ( xorShift = 8 // There is no mapping if all xor bits and the exception bit are zero. - hasMappingMask = 0xff80 | exceptionBit + hasMappingMask = 0xffc0 | exceptionBit ) // The case mode bits encodes the case type of a rune. This includes uncased, @@ -97,6 +95,10 @@ func (c info) isCaseIgnorable() bool { return c&ignorableMask == ignorableValue } +func (c info) isCaseIgnorableAndNonBreakStarter() bool { + return c&(fullCasedMask|cccMask) == (ignorableValue | cccZero) +} + func (c info) isNotCasedAndNotCaseIgnorable() bool { return c&fullCasedMask == 0 } @@ -105,10 +107,6 @@ func (c info) isCaseIgnorableAndNotCased() bool { return c&fullCasedMask == cIgnorableUncased } -func (c info) isMid() bool { - return c&(fullCasedMask|isMidBit) == isMidBit|cIgnorableUncased -} - // The case mapping implementation will need to know about various Canonical // Combining Class (CCC) values. We encode two of these in the trie value: // cccZero (0) and cccAbove (230). If the value is cccOther, it means that diff --git a/vendor/golang.org/x/text/cases/icu.go b/vendor/golang.org/x/text/cases/icu.go deleted file mode 100644 index 46530d1..0000000 --- a/vendor/golang.org/x/text/cases/icu.go +++ /dev/null @@ -1,61 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build icu - -package cases - -// Ideally these functions would be defined in a test file, but go test doesn't -// allow CGO in tests. The build tag should ensure either way that these -// functions will not end up in the package. - -// TODO: Ensure that the correct ICU version is set. - -/* -#cgo LDFLAGS: -licui18n.57 -licuuc.57 -#include -#include -#include -#include -#include -*/ -import "C" - -import "unsafe" - -func doICU(tag, caser, input string) string { - err := C.UErrorCode(0) - loc := C.CString(tag) - cm := C.ucasemap_open(loc, C.uint32_t(0), &err) - - buf := make([]byte, len(input)*4) - dst := (*C.char)(unsafe.Pointer(&buf[0])) - src := C.CString(input) - - cn := C.int32_t(0) - - switch caser { - case "fold": - cn = C.ucasemap_utf8FoldCase(cm, - dst, C.int32_t(len(buf)), - src, C.int32_t(len(input)), - &err) - case "lower": - cn = C.ucasemap_utf8ToLower(cm, - dst, C.int32_t(len(buf)), - src, C.int32_t(len(input)), - &err) - case "upper": - cn = C.ucasemap_utf8ToUpper(cm, - dst, C.int32_t(len(buf)), - src, C.int32_t(len(input)), - &err) - case "title": - cn = C.ucasemap_utf8ToTitle(cm, - dst, C.int32_t(len(buf)), - src, C.int32_t(len(input)), - &err) - } - return string(buf[:cn]) -} diff --git a/vendor/golang.org/x/text/cases/info.go b/vendor/golang.org/x/text/cases/info.go index 3b51f03..669d7ae 100644 --- a/vendor/golang.org/x/text/cases/info.go +++ b/vendor/golang.org/x/text/cases/info.go @@ -28,6 +28,9 @@ func (c info) cccType() info { // only makes sense, though, if the performance and/or space penalty of using // the generic breaker is big. Extra data will only be needed for non-cased // runes, which means there are sufficient bits left in the caseType. +// Also note that the standard breaking algorithm doesn't always make sense +// for title casing. For example, a4a -> A4a, but a"4a -> A"4A (where " stands +// for modifier \u0308). // ICU prohibits breaking in such cases as well. // For the purpose of title casing we use an approximation of the Unicode Word @@ -38,19 +41,17 @@ func (c info) cccType() info { // categories, with associated rules: // // 1) Letter: -// ALetter, Hebrew_Letter, Numeric, ExtendNumLet, Extend, Format_FE, ZWJ. +// ALetter, Hebrew_Letter, Numeric, ExtendNumLet, Extend. // Rule: Never break between consecutive runes of this category. // // 2) Mid: -// MidLetter, MidNumLet, Single_Quote. -// (Cf. case-ignorable: MidLetter, MidNumLet, Single_Quote or cat is Mn, -// Me, Cf, Lm or Sk). +// Format, MidLetter, MidNumLet, Single_Quote. +// (Cf. case-ignorable: MidLetter, MidNumLet or cat is Mn, Me, Cf, Lm or Sk). // Rule: Don't break between Letter and Mid, but break between two Mids. // // 3) Break: -// Any other category: NewLine, MidNum, CR, LF, Double_Quote, Katakana, and -// Other. -// These categories should always result in a break between two cased letters. +// Any other category, including NewLine, CR, LF and Double_Quote. These +// categories should always result in a break between two cased letters. // Rule: Always break. // // Note 1: the Katakana and MidNum categories can, in esoteric cases, result in diff --git a/vendor/golang.org/x/text/cases/map.go b/vendor/golang.org/x/text/cases/map.go index 4baebaa..f2a8e96 100644 --- a/vendor/golang.org/x/text/cases/map.go +++ b/vendor/golang.org/x/text/cases/map.go @@ -13,7 +13,6 @@ import ( "unicode" "unicode/utf8" - "golang.org/x/text/internal" "golang.org/x/text/language" "golang.org/x/text/transform" "golang.org/x/text/unicode/norm" @@ -25,11 +24,6 @@ import ( // dst so far won't need changing as we see more source bytes. type mapFunc func(*context) bool -// A spanFunc takes a context set to the current rune and returns whether this -// rune would be altered when written to the output. It may advance the context -// to the next rune. It returns whether a checkpoint is possible. -type spanFunc func(*context) bool - // maxIgnorable defines the maximum number of ignorables to consider for // lookahead operations. const maxIgnorable = 30 @@ -42,12 +36,12 @@ func init() { for _, s := range strings.Split(supported, " ") { tags = append(tags, language.MustParse(s)) } - matcher = internal.NewInheritanceMatcher(tags) + matcher = language.NewMatcher(tags) Supported = language.NewCoverage(tags) } var ( - matcher *internal.InheritanceMatcher + matcher language.Matcher Supported language.Coverage @@ -56,69 +50,56 @@ var ( // Some uppercase mappers are stateless, so we can precompute the // Transformers and save a bit on runtime allocations. - upperFunc = []struct { - upper mapFunc - span spanFunc - }{ - {nil, nil}, // und - {nil, nil}, // af - {aztrUpper(upper), isUpper}, // az - {elUpper, noSpan}, // el - {ltUpper(upper), noSpan}, // lt - {nil, nil}, // nl - {aztrUpper(upper), isUpper}, // tr + upperFunc = []mapFunc{ + nil, // und + nil, // af + aztrUpper(upper), // az + elUpper, // el + ltUpper(upper), // lt + nil, // nl + aztrUpper(upper), // tr } - undUpper transform.SpanningTransformer = &undUpperCaser{} - undLower transform.SpanningTransformer = &undLowerCaser{} - undLowerIgnoreSigma transform.SpanningTransformer = &undLowerIgnoreSigmaCaser{} + undUpper transform.Transformer = &undUpperCaser{} lowerFunc = []mapFunc{ - nil, // und - nil, // af + lower, // und + lower, // af aztrLower, // az - nil, // el + lower, // el ltLower, // lt - nil, // nl + lower, // nl aztrLower, // tr } titleInfos = []struct { - title mapFunc - lower mapFunc - titleSpan spanFunc - rewrite func(*context) + title, lower mapFunc + rewrite func(*context) }{ - {title, lower, isTitle, nil}, // und - {title, lower, isTitle, afnlRewrite}, // af - {aztrUpper(title), aztrLower, isTitle, nil}, // az - {title, lower, isTitle, nil}, // el - {ltUpper(title), ltLower, noSpan, nil}, // lt - {nlTitle, lower, nlTitleSpan, afnlRewrite}, // nl - {aztrUpper(title), aztrLower, isTitle, nil}, // tr + {title, lower, nil}, // und + {title, lower, afnlRewrite}, // af + {aztrUpper(title), aztrLower, nil}, // az + {title, lower, nil}, // el + {ltUpper(title), ltLower, nil}, // lt + {nlTitle, lower, afnlRewrite}, // nl + {aztrUpper(title), aztrLower, nil}, // tr } ) -func makeUpper(t language.Tag, o options) transform.SpanningTransformer { +func makeUpper(t language.Tag, o options) transform.Transformer { _, i, _ := matcher.Match(t) - f := upperFunc[i].upper + f := upperFunc[i] if f == nil { return undUpper } - return &simpleCaser{f: f, span: upperFunc[i].span} + return &simpleCaser{f: f} } -func makeLower(t language.Tag, o options) transform.SpanningTransformer { +func makeLower(t language.Tag, o options) transform.Transformer { _, i, _ := matcher.Match(t) f := lowerFunc[i] - if f == nil { - if o.ignoreFinalSigma { - return undLowerIgnoreSigma - } - return undLower - } - if o.ignoreFinalSigma { - return &simpleCaser{f: f, span: isLower} + if o.noFinalSigma { + return &simpleCaser{f: f} } return &lowerCaser{ first: f, @@ -126,28 +107,22 @@ func makeLower(t language.Tag, o options) transform.SpanningTransformer { } } -func makeTitle(t language.Tag, o options) transform.SpanningTransformer { +func makeTitle(t language.Tag, o options) transform.Transformer { _, i, _ := matcher.Match(t) x := &titleInfos[i] lower := x.lower if o.noLower { lower = (*context).copy - } else if !o.ignoreFinalSigma { + } else if !o.noFinalSigma { lower = finalSigma(lower) } return &titleCaser{ - title: x.title, - lower: lower, - titleSpan: x.titleSpan, - rewrite: x.rewrite, + title: x.title, + lower: lower, + rewrite: x.rewrite, } } -func noSpan(c *context) bool { - c.err = transform.ErrEndOfSpan - return false -} - // TODO: consider a similar special case for the fast majority lower case. This // is a bit more involved so will require some more precise benchmarking to // justify it. @@ -157,7 +132,7 @@ type undUpperCaser struct{ transform.NopResetter } // undUpperCaser implements the Transformer interface for doing an upper case // mapping for the root locale (und). It eliminates the need for an allocation // as it prevents escaping by not using function pointers. -func (t undUpperCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { +func (t *undUpperCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { c := context{dst: dst, src: src, atEOF: atEOF} for c.next() { upper(&c) @@ -166,117 +141,26 @@ func (t undUpperCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, e return c.ret() } -func (t undUpperCaser) Span(src []byte, atEOF bool) (n int, err error) { - c := context{src: src, atEOF: atEOF} - for c.next() && isUpper(&c) { - c.checkpoint() - } - return c.retSpan() -} - -// undLowerIgnoreSigmaCaser implements the Transformer interface for doing -// a lower case mapping for the root locale (und) ignoring final sigma -// handling. This casing algorithm is used in some performance-critical packages -// like secure/precis and x/net/http/idna, which warrants its special-casing. -type undLowerIgnoreSigmaCaser struct{ transform.NopResetter } - -func (t undLowerIgnoreSigmaCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - c := context{dst: dst, src: src, atEOF: atEOF} - for c.next() && lower(&c) { - c.checkpoint() - } - return c.ret() - -} - -// Span implements a generic lower-casing. This is possible as isLower works -// for all lowercasing variants. All lowercase variants only vary in how they -// transform a non-lowercase letter. They will never change an already lowercase -// letter. In addition, there is no state. -func (t undLowerIgnoreSigmaCaser) Span(src []byte, atEOF bool) (n int, err error) { - c := context{src: src, atEOF: atEOF} - for c.next() && isLower(&c) { - c.checkpoint() - } - return c.retSpan() -} - type simpleCaser struct { context - f mapFunc - span spanFunc + f mapFunc } // simpleCaser implements the Transformer interface for doing a case operation // on a rune-by-rune basis. func (t *simpleCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - c := context{dst: dst, src: src, atEOF: atEOF} - for c.next() && t.f(&c) { + t.context = context{dst: dst, src: src, atEOF: atEOF} + c := &t.context + for c.next() && t.f(c) { c.checkpoint() } return c.ret() } -func (t *simpleCaser) Span(src []byte, atEOF bool) (n int, err error) { - c := context{src: src, atEOF: atEOF} - for c.next() && t.span(&c) { - c.checkpoint() - } - return c.retSpan() -} - -// undLowerCaser implements the Transformer interface for doing a lower case -// mapping for the root locale (und) ignoring final sigma handling. This casing -// algorithm is used in some performance-critical packages like secure/precis -// and x/net/http/idna, which warrants its special-casing. -type undLowerCaser struct{ transform.NopResetter } - -func (t undLowerCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - c := context{dst: dst, src: src, atEOF: atEOF} - - for isInterWord := true; c.next(); { - if isInterWord { - if c.info.isCased() { - if !lower(&c) { - break - } - isInterWord = false - } else if !c.copy() { - break - } - } else { - if c.info.isNotCasedAndNotCaseIgnorable() { - if !c.copy() { - break - } - isInterWord = true - } else if !c.hasPrefix("Σ") { - if !lower(&c) { - break - } - } else if !finalSigmaBody(&c) { - break - } - } - c.checkpoint() - } - return c.ret() -} - -func (t undLowerCaser) Span(src []byte, atEOF bool) (n int, err error) { - c := context{src: src, atEOF: atEOF} - for c.next() && isLower(&c) { - c.checkpoint() - } - return c.retSpan() -} - // lowerCaser implements the Transformer interface. The default Unicode lower // casing requires different treatment for the first and subsequent characters // of a word, most notably to handle the Greek final Sigma. type lowerCaser struct { - undLowerIgnoreSigmaCaser - context first, midWord mapFunc @@ -318,9 +202,7 @@ type titleCaser struct { context // rune mappings used by the actual casing algorithms. - title mapFunc - lower mapFunc - titleSpan spanFunc + title, lower mapFunc rewrite func(*context) } @@ -346,10 +228,10 @@ func (t *titleCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err t.rewrite(c) } - wasMid := p.isMid() + wasMid := p.isCaseIgnorableAndNonBreakStarter() // Break out of this loop on failure to ensure we do not modify the // state incorrectly. - if p.isCased() { + if p.isCased() && !p.isCaseIgnorableAndNotCased() { if !c.isMidWord { if !t.title(c) { break @@ -360,139 +242,71 @@ func (t *titleCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err } } else if !c.copy() { break - } else if p.isBreak() { + } + + // TODO: make this an "else if" if we can prove that no rune that does + // not match the first condition of the if statement can be a break. + if p.isBreak() { c.isMidWord = false } // As we save the state of the transformer, it is safe to call // checkpoint after any successful write. - if !(c.isMidWord && wasMid) { - c.checkpoint() - } + c.checkpoint() if !c.next() { break } - if wasMid && c.info.isMid() { + if wasMid && c.info.isCaseIgnorableAndNonBreakStarter() { c.isMidWord = false } } return c.ret() } -func (t *titleCaser) Span(src []byte, atEOF bool) (n int, err error) { - t.context = context{src: src, atEOF: atEOF, isMidWord: t.isMidWord} - c := &t.context - - if !c.next() { - return c.retSpan() - } - - for { - p := c.info - if t.rewrite != nil { - t.rewrite(c) - } - - wasMid := p.isMid() - // Break out of this loop on failure to ensure we do not modify the - // state incorrectly. - if p.isCased() { - if !c.isMidWord { - if !t.titleSpan(c) { - break - } - c.isMidWord = true - } else if !isLower(c) { - break - } - } else if p.isBreak() { - c.isMidWord = false - } - // As we save the state of the transformer, it is safe to call - // checkpoint after any successful write. - if !(c.isMidWord && wasMid) { - c.checkpoint() - } - - if !c.next() { - break - } - if wasMid && c.info.isMid() { - c.isMidWord = false - } - } - return c.retSpan() -} - // finalSigma adds Greek final Sigma handing to another casing function. It // determines whether a lowercased sigma should be σ or ς, by looking ahead for // case-ignorables and a cased letters. func finalSigma(f mapFunc) mapFunc { return func(c *context) bool { + // ::NFD(); + // # 03A3; 03C2; 03A3; 03A3; Final_Sigma; # GREEK CAPITAL LETTER SIGMA + // Σ } [:case-ignorable:]* [:cased:] → σ; + // [:cased:] [:case-ignorable:]* { Σ → ς; + // ::Any-Lower; + // ::NFC(); + if !c.hasPrefix("Σ") { return f(c) } - return finalSigmaBody(c) - } -} -func finalSigmaBody(c *context) bool { - // Current rune must be ∑. - - // ::NFD(); - // # 03A3; 03C2; 03A3; 03A3; Final_Sigma; # GREEK CAPITAL LETTER SIGMA - // Σ } [:case-ignorable:]* [:cased:] → σ; - // [:cased:] [:case-ignorable:]* { Σ → ς; - // ::Any-Lower; - // ::NFC(); - - p := c.pDst - c.writeString("ς") - - // TODO: we should do this here, but right now this will never have an - // effect as this is called when the prefix is Sigma, whereas Dutch and - // Afrikaans only test for an apostrophe. - // - // if t.rewrite != nil { - // t.rewrite(c) - // } - - // We need to do one more iteration after maxIgnorable, as a cased - // letter is not an ignorable and may modify the result. - wasMid := false - for i := 0; i < maxIgnorable+1; i++ { - if !c.next() { - return false - } - if !c.info.isCaseIgnorable() { - // All Midword runes are also case ignorable, so we are - // guaranteed to have a letter or word break here. As we are - // unreading the run, there is no need to unset c.isMidWord; - // the title caser will handle this. - if c.info.isCased() { - // p+1 is guaranteed to be in bounds: if writing ς was - // successful, p+1 will contain the second byte of ς. If not, - // this function will have returned after c.next returned false. - c.dst[p+1]++ // ς → σ + p := c.pDst + c.writeString("ς") + // We need to do one more iteration after maxIgnorable, as a cased + // letter is not an ignorable and may modify the result. + for i := 0; i < maxIgnorable+1; i++ { + if !c.next() { + return false } - c.unreadRune() - return true + if !c.info.isCaseIgnorable() { + if c.info.isCased() { + // p+1 is guaranteed to be in bounds: if writing ς was + // successful, p+1 will contain the second byte of ς. If not, + // this function will have returned after c.next returned false. + c.dst[p+1]++ // ς → σ + } + c.unreadRune() + return true + } + // A case ignorable may also introduce a word break, so we may need + // to continue searching even after detecting a break. + c.isMidWord = c.isMidWord && !c.info.isBreak() + c.copy() } - // A case ignorable may also introduce a word break, so we may need - // to continue searching even after detecting a break. - isMid := c.info.isMid() - if (wasMid && isMid) || c.info.isBreak() { - c.isMidWord = false - } - wasMid = isMid - c.copy() + return true } - return true } -// finalSigmaSpan would be the same as isLower. - // elUpper implements Greek upper casing, which entails removing a predefined // set of non-blocked modifiers. Note that these accents should not be removed // for title casing! @@ -562,8 +376,6 @@ func elUpper(c *context) bool { return i == maxIgnorable } -// TODO: implement elUpperSpan (low-priority: complex and infrequent). - func ltLower(c *context) bool { // From CLDR: // # Introduce an explicit dot above when lowercasing capital I's and J's @@ -578,10 +390,10 @@ func ltLower(c *context) bool { // ::NFD(); // I } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → i \u0307; // J } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → j \u0307; - // I \u0328 (Į) } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → i \u0328 \u0307; - // I \u0300 (Ì) → i \u0307 \u0300; - // I \u0301 (Í) → i \u0307 \u0301; - // I \u0303 (Ĩ) → i \u0307 \u0303; + // Į } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → į \u0307; + // Ì → i \u0307 \u0300; + // Í → i \u0307 \u0301; + // Ĩ → i \u0307 \u0303; // ::Any-Lower(); // ::NFC(); @@ -633,16 +445,9 @@ func ltLower(c *context) bool { return i == maxIgnorable } -// ltLowerSpan would be the same as isLower. - func ltUpper(f mapFunc) mapFunc { return func(c *context) bool { - // Unicode: - // 0307; 0307; ; ; lt After_Soft_Dotted; # COMBINING DOT ABOVE - // // From CLDR: - // # Remove \u0307 following soft-dotteds (i, j, and the like), with possible - // # intervening non-230 marks. // ::NFD(); // [:Soft_Dotted:] [^[:ccc=Not_Reordered:][:ccc=Above:]]* { \u0307 → ; // ::Any-Upper(); @@ -706,8 +511,6 @@ func ltUpper(f mapFunc) mapFunc { } } -// TODO: implement ltUpperSpan (low priority: complex and infrequent). - func aztrUpper(f mapFunc) mapFunc { return func(c *context) bool { // i→İ; @@ -768,8 +571,6 @@ Loop: return c.writeString("ı") && c.writeBytes(c.src[start:c.pSrc+c.sz]) && done } -// aztrLowerSpan would be the same as isLower. - func nlTitle(c *context) bool { // From CLDR: // # Special titlecasing for Dutch initial "ij". @@ -790,24 +591,6 @@ func nlTitle(c *context) bool { return true } -func nlTitleSpan(c *context) bool { - // From CLDR: - // # Special titlecasing for Dutch initial "ij". - // ::Any-Title(); - // # Fix up Ij at the beginning of a "word" (per Any-Title, notUAX #29) - // [:^WB=ALetter:] [:WB=Extend:]* [[:WB=MidLetter:][:WB=MidNumLet:]]? { Ij } → IJ ; - if c.src[c.pSrc] != 'I' { - return isTitle(c) - } - if !c.next() || c.src[c.pSrc] == 'j' { - return false - } - if c.src[c.pSrc] != 'J' { - c.unreadRune() - } - return true -} - // Not part of CLDR, but see http://unicode.org/cldr/trac/ticket/7078. func afnlRewrite(c *context) { if c.hasPrefix("'") || c.hasPrefix("’") { diff --git a/vendor/golang.org/x/text/cases/tables.go b/vendor/golang.org/x/text/cases/tables.go index 32ee8fa..4257e57 100644 --- a/vendor/golang.org/x/text/cases/tables.go +++ b/vendor/golang.org/x/text/cases/tables.go @@ -216,7 +216,7 @@ func (t *caseTrie) lookupStringUnsafe(s string) uint16 { return 0 } -// caseTrie. Total size: 11742 bytes (11.47 KiB). Checksum: 147a11466b427436. +// caseTrie. Total size: 11750 bytes (11.47 KiB). Checksum: 9ec26581a3006e0d. type caseTrie struct{} func newCaseTrie(i int) *caseTrie { @@ -238,10 +238,10 @@ func (t *caseTrie) lookupValue(n uint32, b byte) uint16 { // The third block is the zero block. var caseValues = [1280]uint16{ // Block 0x0, offset 0x0 - 0x27: 0x0054, - 0x2e: 0x0054, + 0x27: 0x0014, + 0x2e: 0x0014, 0x30: 0x0010, 0x31: 0x0010, 0x32: 0x0010, 0x33: 0x0010, 0x34: 0x0010, 0x35: 0x0010, - 0x36: 0x0010, 0x37: 0x0010, 0x38: 0x0010, 0x39: 0x0010, 0x3a: 0x0054, + 0x36: 0x0010, 0x37: 0x0010, 0x38: 0x0010, 0x39: 0x0010, 0x3a: 0x0014, // Block 0x1, offset 0x40 0x41: 0x2013, 0x42: 0x2013, 0x43: 0x2013, 0x44: 0x2013, 0x45: 0x2013, 0x46: 0x2013, 0x47: 0x2013, 0x48: 0x2013, 0x49: 0x2013, 0x4a: 0x2013, 0x4b: 0x2013, @@ -316,7 +316,7 @@ var caseValues = [1280]uint16{ 0x1fc: 0x5052, 0x1fd: 0x5052, 0x1ff: 0x5353, // Block 0x8, offset 0x200 0x204: 0x0004, 0x205: 0x0004, - 0x206: 0x2a13, 0x207: 0x0054, 0x208: 0x2513, 0x209: 0x2713, 0x20a: 0x2513, + 0x206: 0x2a13, 0x207: 0x0014, 0x208: 0x2513, 0x209: 0x2713, 0x20a: 0x2513, 0x20c: 0x5653, 0x20e: 0x5953, 0x20f: 0x5c53, 0x210: 0x1e2a, 0x211: 0x2013, 0x212: 0x2013, 0x213: 0x2013, 0x214: 0x2013, 0x215: 0x2013, 0x216: 0x2013, 0x217: 0x2013, 0x218: 0x2013, 0x219: 0x2013, 0x21a: 0x2013, 0x21b: 0x2013, 0x21c: 0x2013, 0x21d: 0x2013, @@ -571,10 +571,10 @@ var caseIndex = [1600]uint16{ } // sparseOffsets: 272 entries, 544 bytes -var sparseOffsets = []uint16{0x0, 0x9, 0xf, 0x18, 0x24, 0x2e, 0x3a, 0x3d, 0x41, 0x44, 0x48, 0x52, 0x54, 0x59, 0x69, 0x70, 0x75, 0x83, 0x84, 0x92, 0xa1, 0xab, 0xae, 0xb4, 0xbc, 0xbe, 0xc0, 0xce, 0xd4, 0xe2, 0xed, 0xf8, 0x103, 0x10f, 0x119, 0x124, 0x12f, 0x13b, 0x147, 0x14f, 0x157, 0x161, 0x16c, 0x178, 0x17e, 0x189, 0x18e, 0x196, 0x199, 0x19e, 0x1a2, 0x1a6, 0x1ad, 0x1b6, 0x1be, 0x1bf, 0x1c8, 0x1cf, 0x1d7, 0x1dd, 0x1e3, 0x1e8, 0x1ec, 0x1ef, 0x1f1, 0x1f4, 0x1f9, 0x1fa, 0x1fc, 0x1fe, 0x200, 0x207, 0x20c, 0x210, 0x219, 0x21c, 0x21f, 0x225, 0x226, 0x231, 0x232, 0x233, 0x238, 0x245, 0x24d, 0x255, 0x25e, 0x267, 0x270, 0x275, 0x278, 0x281, 0x28e, 0x290, 0x297, 0x299, 0x2a4, 0x2a5, 0x2b0, 0x2b8, 0x2c0, 0x2c6, 0x2c7, 0x2d5, 0x2da, 0x2dd, 0x2e2, 0x2e6, 0x2ec, 0x2f1, 0x2f4, 0x2f9, 0x2fe, 0x2ff, 0x305, 0x307, 0x308, 0x30a, 0x30c, 0x30f, 0x310, 0x312, 0x315, 0x31b, 0x31f, 0x321, 0x327, 0x32e, 0x332, 0x33b, 0x33c, 0x344, 0x348, 0x34d, 0x355, 0x35b, 0x361, 0x36b, 0x370, 0x379, 0x37f, 0x386, 0x38a, 0x392, 0x394, 0x396, 0x399, 0x39b, 0x39d, 0x39e, 0x39f, 0x3a1, 0x3a3, 0x3a9, 0x3ae, 0x3b0, 0x3b6, 0x3b9, 0x3bb, 0x3c1, 0x3c6, 0x3c8, 0x3c9, 0x3ca, 0x3cb, 0x3cd, 0x3cf, 0x3d1, 0x3d4, 0x3d6, 0x3d9, 0x3e1, 0x3e4, 0x3e8, 0x3f0, 0x3f2, 0x3f3, 0x3f4, 0x3f6, 0x3fc, 0x3fe, 0x3ff, 0x401, 0x403, 0x405, 0x412, 0x413, 0x414, 0x418, 0x41a, 0x41b, 0x41c, 0x41d, 0x41e, 0x422, 0x426, 0x42c, 0x42e, 0x435, 0x438, 0x43c, 0x442, 0x44b, 0x451, 0x457, 0x461, 0x46b, 0x46d, 0x474, 0x47a, 0x480, 0x486, 0x489, 0x48f, 0x492, 0x49a, 0x49b, 0x4a2, 0x4a3, 0x4a6, 0x4a7, 0x4ad, 0x4b0, 0x4b8, 0x4b9, 0x4ba, 0x4bb, 0x4bc, 0x4be, 0x4c0, 0x4c2, 0x4c6, 0x4c7, 0x4c9, 0x4ca, 0x4cb, 0x4cd, 0x4d2, 0x4d7, 0x4db, 0x4dc, 0x4df, 0x4e3, 0x4ee, 0x4f2, 0x4fa, 0x4ff, 0x503, 0x506, 0x50a, 0x50d, 0x510, 0x515, 0x519, 0x51d, 0x521, 0x525, 0x527, 0x529, 0x52c, 0x531, 0x533, 0x538, 0x541, 0x546, 0x547, 0x54a, 0x54b, 0x54c, 0x54e, 0x54f, 0x550} +var sparseOffsets = []uint16{0x0, 0x9, 0xf, 0x18, 0x24, 0x2e, 0x3a, 0x3d, 0x41, 0x44, 0x48, 0x52, 0x54, 0x59, 0x69, 0x70, 0x75, 0x83, 0x84, 0x92, 0xa1, 0xab, 0xae, 0xb4, 0xbc, 0xbe, 0xc0, 0xce, 0xd4, 0xe2, 0xed, 0xf8, 0x103, 0x10f, 0x119, 0x124, 0x12f, 0x13b, 0x147, 0x14f, 0x157, 0x161, 0x16c, 0x178, 0x17e, 0x189, 0x18e, 0x196, 0x199, 0x19e, 0x1a2, 0x1a6, 0x1ad, 0x1b6, 0x1be, 0x1bf, 0x1c8, 0x1cf, 0x1d7, 0x1dd, 0x1e3, 0x1e8, 0x1ec, 0x1ef, 0x1f1, 0x1f4, 0x1f9, 0x1fa, 0x1fc, 0x1fe, 0x200, 0x207, 0x20c, 0x210, 0x219, 0x21c, 0x21f, 0x225, 0x226, 0x231, 0x232, 0x233, 0x238, 0x245, 0x24d, 0x255, 0x25e, 0x267, 0x270, 0x275, 0x278, 0x281, 0x28e, 0x290, 0x297, 0x299, 0x2a4, 0x2a5, 0x2b0, 0x2b8, 0x2c2, 0x2c8, 0x2c9, 0x2d7, 0x2dc, 0x2df, 0x2e4, 0x2e8, 0x2ee, 0x2f3, 0x2f6, 0x2fb, 0x300, 0x301, 0x307, 0x309, 0x30a, 0x30c, 0x30e, 0x311, 0x312, 0x314, 0x317, 0x31d, 0x321, 0x323, 0x329, 0x330, 0x334, 0x33d, 0x33e, 0x346, 0x34a, 0x34f, 0x357, 0x35d, 0x363, 0x36d, 0x372, 0x37b, 0x381, 0x388, 0x38c, 0x394, 0x396, 0x398, 0x39b, 0x39d, 0x39f, 0x3a0, 0x3a1, 0x3a3, 0x3a5, 0x3ab, 0x3b0, 0x3b2, 0x3b8, 0x3bb, 0x3bd, 0x3c3, 0x3c8, 0x3ca, 0x3cb, 0x3cc, 0x3cd, 0x3cf, 0x3d1, 0x3d3, 0x3d6, 0x3d8, 0x3db, 0x3e3, 0x3e6, 0x3ea, 0x3f2, 0x3f4, 0x3f5, 0x3f6, 0x3f8, 0x3fe, 0x400, 0x401, 0x403, 0x405, 0x407, 0x414, 0x415, 0x416, 0x41a, 0x41c, 0x41d, 0x41e, 0x41f, 0x420, 0x424, 0x428, 0x42e, 0x430, 0x437, 0x43a, 0x43e, 0x444, 0x44d, 0x453, 0x459, 0x463, 0x46d, 0x46f, 0x476, 0x47c, 0x482, 0x488, 0x48b, 0x491, 0x494, 0x49c, 0x49d, 0x4a4, 0x4a5, 0x4a8, 0x4a9, 0x4af, 0x4b2, 0x4ba, 0x4bb, 0x4bc, 0x4bd, 0x4be, 0x4c0, 0x4c2, 0x4c4, 0x4c8, 0x4c9, 0x4cb, 0x4cc, 0x4cd, 0x4cf, 0x4d4, 0x4d9, 0x4dd, 0x4de, 0x4e1, 0x4e5, 0x4f0, 0x4f4, 0x4fc, 0x501, 0x505, 0x508, 0x50c, 0x50f, 0x512, 0x517, 0x51b, 0x51f, 0x523, 0x527, 0x529, 0x52b, 0x52e, 0x533, 0x535, 0x53a, 0x543, 0x548, 0x549, 0x54c, 0x54d, 0x54e, 0x550, 0x551, 0x552} -// sparseValues: 1360 entries, 5440 bytes -var sparseValues = [1360]valueRange{ +// sparseValues: 1362 entries, 5448 bytes +var sparseValues = [1362]valueRange{ // Block 0x0, offset 0x0 {value: 0x0004, lo: 0xa8, hi: 0xa8}, {value: 0x0012, lo: 0xaa, hi: 0xaa}, @@ -582,7 +582,7 @@ var sparseValues = [1360]valueRange{ {value: 0x0004, lo: 0xaf, hi: 0xaf}, {value: 0x0004, lo: 0xb4, hi: 0xb4}, {value: 0x002a, lo: 0xb5, hi: 0xb5}, - {value: 0x0054, lo: 0xb7, hi: 0xb7}, + {value: 0x0014, lo: 0xb7, hi: 0xb7}, {value: 0x0004, lo: 0xb8, hi: 0xb8}, {value: 0x0012, lo: 0xba, hi: 0xba}, // Block 0x1, offset 0x9 @@ -631,7 +631,7 @@ var sparseValues = [1360]valueRange{ {value: 0x0004, lo: 0x82, hi: 0x85}, {value: 0x0014, lo: 0x86, hi: 0x91}, {value: 0x0004, lo: 0x92, hi: 0x96}, - {value: 0x0054, lo: 0x97, hi: 0x97}, + {value: 0x0014, lo: 0x97, hi: 0x97}, {value: 0x0004, lo: 0x98, hi: 0x9f}, {value: 0x0015, lo: 0xa0, hi: 0xa4}, {value: 0x0004, lo: 0xa5, hi: 0xab}, @@ -701,7 +701,7 @@ var sparseValues = [1360]valueRange{ {value: 0x0034, lo: 0x87, hi: 0x87}, {value: 0x0010, lo: 0x90, hi: 0xaa}, {value: 0x0010, lo: 0xb0, hi: 0xb3}, - {value: 0x0054, lo: 0xb4, hi: 0xb4}, + {value: 0x0014, lo: 0xb4, hi: 0xb4}, // Block 0xf, offset 0x70 {value: 0x0014, lo: 0x80, hi: 0x85}, {value: 0x0024, lo: 0x90, hi: 0x97}, @@ -1372,23 +1372,25 @@ var sparseValues = [1360]valueRange{ {value: 0x0813, lo: 0xb8, hi: 0xbf}, // Block 0x63, offset 0x2b8 {value: 0x0004, lo: 0x8b, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8f}, - {value: 0x0054, lo: 0x98, hi: 0x99}, - {value: 0x0054, lo: 0xa4, hi: 0xa4}, - {value: 0x0054, lo: 0xa7, hi: 0xa7}, + {value: 0x0014, lo: 0x8c, hi: 0x8c}, + {value: 0x0004, lo: 0x8d, hi: 0x8d}, + {value: 0x0014, lo: 0x8e, hi: 0x8f}, + {value: 0x0014, lo: 0x98, hi: 0x99}, + {value: 0x0014, lo: 0xa4, hi: 0xa4}, + {value: 0x0014, lo: 0xa7, hi: 0xa7}, {value: 0x0014, lo: 0xaa, hi: 0xae}, {value: 0x0010, lo: 0xaf, hi: 0xaf}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x64, offset 0x2c0 + // Block 0x64, offset 0x2c2 {value: 0x0010, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x94, hi: 0x94}, {value: 0x0014, lo: 0xa0, hi: 0xa4}, {value: 0x0014, lo: 0xa6, hi: 0xaf}, {value: 0x0015, lo: 0xb1, hi: 0xb1}, {value: 0x0015, lo: 0xbf, hi: 0xbf}, - // Block 0x65, offset 0x2c6 + // Block 0x65, offset 0x2c8 {value: 0x0015, lo: 0x90, hi: 0x9c}, - // Block 0x66, offset 0x2c7 + // Block 0x66, offset 0x2c9 {value: 0x0024, lo: 0x90, hi: 0x91}, {value: 0x0034, lo: 0x92, hi: 0x93}, {value: 0x0024, lo: 0x94, hi: 0x97}, @@ -1403,112 +1405,112 @@ var sparseValues = [1360]valueRange{ {value: 0x0024, lo: 0xa9, hi: 0xa9}, {value: 0x0034, lo: 0xaa, hi: 0xaf}, {value: 0x0024, lo: 0xb0, hi: 0xb0}, - // Block 0x67, offset 0x2d5 + // Block 0x67, offset 0x2d7 {value: 0x0016, lo: 0x85, hi: 0x86}, {value: 0x0012, lo: 0x87, hi: 0x89}, {value: 0x9d52, lo: 0x8e, hi: 0x8e}, {value: 0x1013, lo: 0xa0, hi: 0xaf}, {value: 0x1012, lo: 0xb0, hi: 0xbf}, - // Block 0x68, offset 0x2da + // Block 0x68, offset 0x2dc {value: 0x0010, lo: 0x80, hi: 0x82}, {value: 0x0716, lo: 0x83, hi: 0x84}, {value: 0x0010, lo: 0x85, hi: 0x88}, - // Block 0x69, offset 0x2dd + // Block 0x69, offset 0x2df {value: 0xa053, lo: 0xb6, hi: 0xb7}, {value: 0xa353, lo: 0xb8, hi: 0xb9}, {value: 0xa653, lo: 0xba, hi: 0xbb}, {value: 0xa353, lo: 0xbc, hi: 0xbd}, {value: 0xa053, lo: 0xbe, hi: 0xbf}, - // Block 0x6a, offset 0x2e2 + // Block 0x6a, offset 0x2e4 {value: 0x3013, lo: 0x80, hi: 0x8f}, {value: 0x6553, lo: 0x90, hi: 0x9f}, {value: 0xa953, lo: 0xa0, hi: 0xae}, {value: 0x3012, lo: 0xb0, hi: 0xbf}, - // Block 0x6b, offset 0x2e6 + // Block 0x6b, offset 0x2e8 {value: 0x0117, lo: 0x80, hi: 0xa3}, {value: 0x0012, lo: 0xa4, hi: 0xa4}, {value: 0x0716, lo: 0xab, hi: 0xac}, {value: 0x0316, lo: 0xad, hi: 0xae}, {value: 0x0024, lo: 0xaf, hi: 0xb1}, {value: 0x0117, lo: 0xb2, hi: 0xb3}, - // Block 0x6c, offset 0x2ec + // Block 0x6c, offset 0x2ee {value: 0x6c52, lo: 0x80, hi: 0x9f}, {value: 0x7052, lo: 0xa0, hi: 0xa5}, {value: 0x7052, lo: 0xa7, hi: 0xa7}, {value: 0x7052, lo: 0xad, hi: 0xad}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x6d, offset 0x2f1 + // Block 0x6d, offset 0x2f3 {value: 0x0010, lo: 0x80, hi: 0xa7}, {value: 0x0014, lo: 0xaf, hi: 0xaf}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0x6e, offset 0x2f4 + // Block 0x6e, offset 0x2f6 {value: 0x0010, lo: 0x80, hi: 0x96}, {value: 0x0010, lo: 0xa0, hi: 0xa6}, {value: 0x0010, lo: 0xa8, hi: 0xae}, {value: 0x0010, lo: 0xb0, hi: 0xb6}, {value: 0x0010, lo: 0xb8, hi: 0xbe}, - // Block 0x6f, offset 0x2f9 + // Block 0x6f, offset 0x2fb {value: 0x0010, lo: 0x80, hi: 0x86}, {value: 0x0010, lo: 0x88, hi: 0x8e}, {value: 0x0010, lo: 0x90, hi: 0x96}, {value: 0x0010, lo: 0x98, hi: 0x9e}, {value: 0x0024, lo: 0xa0, hi: 0xbf}, - // Block 0x70, offset 0x2fe + // Block 0x70, offset 0x300 {value: 0x0014, lo: 0xaf, hi: 0xaf}, - // Block 0x71, offset 0x2ff + // Block 0x71, offset 0x301 {value: 0x0014, lo: 0x85, hi: 0x85}, {value: 0x0034, lo: 0xaa, hi: 0xad}, {value: 0x0030, lo: 0xae, hi: 0xaf}, {value: 0x0004, lo: 0xb1, hi: 0xb5}, {value: 0x0014, lo: 0xbb, hi: 0xbb}, {value: 0x0010, lo: 0xbc, hi: 0xbc}, - // Block 0x72, offset 0x305 + // Block 0x72, offset 0x307 {value: 0x0034, lo: 0x99, hi: 0x9a}, {value: 0x0004, lo: 0x9b, hi: 0x9e}, - // Block 0x73, offset 0x307 + // Block 0x73, offset 0x309 {value: 0x0004, lo: 0xbc, hi: 0xbe}, - // Block 0x74, offset 0x308 + // Block 0x74, offset 0x30a {value: 0x0010, lo: 0x85, hi: 0xad}, {value: 0x0010, lo: 0xb1, hi: 0xbf}, - // Block 0x75, offset 0x30a + // Block 0x75, offset 0x30c {value: 0x0010, lo: 0x80, hi: 0x8e}, {value: 0x0010, lo: 0xa0, hi: 0xba}, - // Block 0x76, offset 0x30c + // Block 0x76, offset 0x30e {value: 0x0010, lo: 0x80, hi: 0x94}, {value: 0x0014, lo: 0x95, hi: 0x95}, {value: 0x0010, lo: 0x96, hi: 0xbf}, - // Block 0x77, offset 0x30f + // Block 0x77, offset 0x311 {value: 0x0010, lo: 0x80, hi: 0x8c}, - // Block 0x78, offset 0x310 + // Block 0x78, offset 0x312 {value: 0x0010, lo: 0x90, hi: 0xb7}, {value: 0x0014, lo: 0xb8, hi: 0xbd}, - // Block 0x79, offset 0x312 + // Block 0x79, offset 0x314 {value: 0x0010, lo: 0x80, hi: 0x8b}, {value: 0x0014, lo: 0x8c, hi: 0x8c}, {value: 0x0010, lo: 0x90, hi: 0xab}, - // Block 0x7a, offset 0x315 + // Block 0x7a, offset 0x317 {value: 0x0117, lo: 0x80, hi: 0xad}, {value: 0x0010, lo: 0xae, hi: 0xae}, {value: 0x0024, lo: 0xaf, hi: 0xaf}, {value: 0x0014, lo: 0xb0, hi: 0xb2}, {value: 0x0024, lo: 0xb4, hi: 0xbd}, {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x7b, offset 0x31b + // Block 0x7b, offset 0x31d {value: 0x0117, lo: 0x80, hi: 0x9b}, {value: 0x0015, lo: 0x9c, hi: 0x9d}, {value: 0x0024, lo: 0x9e, hi: 0x9f}, {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x7c, offset 0x31f + // Block 0x7c, offset 0x321 {value: 0x0010, lo: 0x80, hi: 0xaf}, {value: 0x0024, lo: 0xb0, hi: 0xb1}, - // Block 0x7d, offset 0x321 + // Block 0x7d, offset 0x323 {value: 0x0004, lo: 0x80, hi: 0x96}, {value: 0x0014, lo: 0x97, hi: 0x9f}, {value: 0x0004, lo: 0xa0, hi: 0xa1}, {value: 0x0117, lo: 0xa2, hi: 0xaf}, {value: 0x0012, lo: 0xb0, hi: 0xb1}, {value: 0x0117, lo: 0xb2, hi: 0xbf}, - // Block 0x7e, offset 0x327 + // Block 0x7e, offset 0x329 {value: 0x0117, lo: 0x80, hi: 0xaf}, {value: 0x0015, lo: 0xb0, hi: 0xb0}, {value: 0x0012, lo: 0xb1, hi: 0xb8}, @@ -1516,12 +1518,12 @@ var sparseValues = [1360]valueRange{ {value: 0x0716, lo: 0xbb, hi: 0xbc}, {value: 0x8453, lo: 0xbd, hi: 0xbd}, {value: 0x0117, lo: 0xbe, hi: 0xbf}, - // Block 0x7f, offset 0x32e + // Block 0x7f, offset 0x330 {value: 0x0010, lo: 0xb7, hi: 0xb7}, {value: 0x0015, lo: 0xb8, hi: 0xb9}, {value: 0x0012, lo: 0xba, hi: 0xba}, {value: 0x0010, lo: 0xbb, hi: 0xbf}, - // Block 0x80, offset 0x332 + // Block 0x80, offset 0x334 {value: 0x0010, lo: 0x80, hi: 0x81}, {value: 0x0014, lo: 0x82, hi: 0x82}, {value: 0x0010, lo: 0x83, hi: 0x85}, @@ -1531,9 +1533,9 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0x8c, hi: 0xa4}, {value: 0x0014, lo: 0xa5, hi: 0xa6}, {value: 0x0010, lo: 0xa7, hi: 0xa7}, - // Block 0x81, offset 0x33b + // Block 0x81, offset 0x33d {value: 0x0010, lo: 0x80, hi: 0xb3}, - // Block 0x82, offset 0x33c + // Block 0x82, offset 0x33e {value: 0x0010, lo: 0x80, hi: 0x83}, {value: 0x0034, lo: 0x84, hi: 0x84}, {value: 0x0014, lo: 0x85, hi: 0x85}, @@ -1542,18 +1544,18 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xb2, hi: 0xb7}, {value: 0x0010, lo: 0xbb, hi: 0xbb}, {value: 0x0010, lo: 0xbd, hi: 0xbd}, - // Block 0x83, offset 0x344 + // Block 0x83, offset 0x346 {value: 0x0010, lo: 0x80, hi: 0xa5}, {value: 0x0014, lo: 0xa6, hi: 0xaa}, {value: 0x0034, lo: 0xab, hi: 0xad}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x84, offset 0x348 + // Block 0x84, offset 0x34a {value: 0x0010, lo: 0x80, hi: 0x86}, {value: 0x0014, lo: 0x87, hi: 0x91}, {value: 0x0010, lo: 0x92, hi: 0x92}, {value: 0x0030, lo: 0x93, hi: 0x93}, {value: 0x0010, lo: 0xa0, hi: 0xbc}, - // Block 0x85, offset 0x34d + // Block 0x85, offset 0x34f {value: 0x0014, lo: 0x80, hi: 0x82}, {value: 0x0010, lo: 0x83, hi: 0xb2}, {value: 0x0034, lo: 0xb3, hi: 0xb3}, @@ -1562,21 +1564,21 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xba, hi: 0xbb}, {value: 0x0014, lo: 0xbc, hi: 0xbc}, {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x86, offset 0x355 + // Block 0x86, offset 0x357 {value: 0x0030, lo: 0x80, hi: 0x80}, {value: 0x0014, lo: 0x8f, hi: 0x8f}, {value: 0x0010, lo: 0x90, hi: 0x99}, {value: 0x0014, lo: 0xa5, hi: 0xa5}, {value: 0x0004, lo: 0xa6, hi: 0xa6}, {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0x87, offset 0x35b + // Block 0x87, offset 0x35d {value: 0x0010, lo: 0x80, hi: 0xa8}, {value: 0x0014, lo: 0xa9, hi: 0xae}, {value: 0x0010, lo: 0xaf, hi: 0xb0}, {value: 0x0014, lo: 0xb1, hi: 0xb2}, {value: 0x0010, lo: 0xb3, hi: 0xb4}, {value: 0x0014, lo: 0xb5, hi: 0xb6}, - // Block 0x88, offset 0x361 + // Block 0x88, offset 0x363 {value: 0x0010, lo: 0x80, hi: 0x82}, {value: 0x0014, lo: 0x83, hi: 0x83}, {value: 0x0010, lo: 0x84, hi: 0x8b}, @@ -1587,13 +1589,13 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xbb, hi: 0xbb}, {value: 0x0014, lo: 0xbc, hi: 0xbc}, {value: 0x0010, lo: 0xbd, hi: 0xbd}, - // Block 0x89, offset 0x36b + // Block 0x89, offset 0x36d {value: 0x0024, lo: 0xb0, hi: 0xb0}, {value: 0x0024, lo: 0xb2, hi: 0xb3}, {value: 0x0034, lo: 0xb4, hi: 0xb4}, {value: 0x0024, lo: 0xb7, hi: 0xb8}, {value: 0x0024, lo: 0xbe, hi: 0xbf}, - // Block 0x8a, offset 0x370 + // Block 0x8a, offset 0x372 {value: 0x0024, lo: 0x81, hi: 0x81}, {value: 0x0004, lo: 0x9d, hi: 0x9d}, {value: 0x0010, lo: 0xa0, hi: 0xab}, @@ -1603,14 +1605,14 @@ var sparseValues = [1360]valueRange{ {value: 0x0014, lo: 0xb3, hi: 0xb4}, {value: 0x0010, lo: 0xb5, hi: 0xb5}, {value: 0x0034, lo: 0xb6, hi: 0xb6}, - // Block 0x8b, offset 0x379 + // Block 0x8b, offset 0x37b {value: 0x0010, lo: 0x81, hi: 0x86}, {value: 0x0010, lo: 0x89, hi: 0x8e}, {value: 0x0010, lo: 0x91, hi: 0x96}, {value: 0x0010, lo: 0xa0, hi: 0xa6}, {value: 0x0010, lo: 0xa8, hi: 0xae}, {value: 0x0012, lo: 0xb0, hi: 0xbf}, - // Block 0x8c, offset 0x37f + // Block 0x8c, offset 0x381 {value: 0x0012, lo: 0x80, hi: 0x92}, {value: 0xac52, lo: 0x93, hi: 0x93}, {value: 0x0012, lo: 0x94, hi: 0x9a}, @@ -1618,12 +1620,12 @@ var sparseValues = [1360]valueRange{ {value: 0x0015, lo: 0x9c, hi: 0x9f}, {value: 0x0012, lo: 0xa0, hi: 0xa5}, {value: 0x74d2, lo: 0xb0, hi: 0xbf}, - // Block 0x8d, offset 0x386 + // Block 0x8d, offset 0x388 {value: 0x78d2, lo: 0x80, hi: 0x8f}, {value: 0x7cd2, lo: 0x90, hi: 0x9f}, {value: 0x80d2, lo: 0xa0, hi: 0xaf}, {value: 0x7cd2, lo: 0xb0, hi: 0xbf}, - // Block 0x8e, offset 0x38a + // Block 0x8e, offset 0x38c {value: 0x0010, lo: 0x80, hi: 0xa4}, {value: 0x0014, lo: 0xa5, hi: 0xa5}, {value: 0x0010, lo: 0xa6, hi: 0xa7}, @@ -1632,105 +1634,105 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xac, hi: 0xac}, {value: 0x0034, lo: 0xad, hi: 0xad}, {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0x8f, offset 0x392 + // Block 0x8f, offset 0x394 {value: 0x0010, lo: 0x80, hi: 0xa3}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x90, offset 0x394 + // Block 0x90, offset 0x396 {value: 0x0010, lo: 0x80, hi: 0x86}, {value: 0x0010, lo: 0x8b, hi: 0xbb}, - // Block 0x91, offset 0x396 + // Block 0x91, offset 0x398 {value: 0x0010, lo: 0x80, hi: 0x81}, {value: 0x0010, lo: 0x83, hi: 0x84}, {value: 0x0010, lo: 0x86, hi: 0xbf}, - // Block 0x92, offset 0x399 + // Block 0x92, offset 0x39b {value: 0x0010, lo: 0x80, hi: 0xb1}, {value: 0x0004, lo: 0xb2, hi: 0xbf}, - // Block 0x93, offset 0x39b + // Block 0x93, offset 0x39d {value: 0x0004, lo: 0x80, hi: 0x81}, {value: 0x0010, lo: 0x93, hi: 0xbf}, - // Block 0x94, offset 0x39d + // Block 0x94, offset 0x39f {value: 0x0010, lo: 0x80, hi: 0xbd}, - // Block 0x95, offset 0x39e + // Block 0x95, offset 0x3a0 {value: 0x0010, lo: 0x90, hi: 0xbf}, - // Block 0x96, offset 0x39f + // Block 0x96, offset 0x3a1 {value: 0x0010, lo: 0x80, hi: 0x8f}, {value: 0x0010, lo: 0x92, hi: 0xbf}, - // Block 0x97, offset 0x3a1 + // Block 0x97, offset 0x3a3 {value: 0x0010, lo: 0x80, hi: 0x87}, {value: 0x0010, lo: 0xb0, hi: 0xbb}, - // Block 0x98, offset 0x3a3 + // Block 0x98, offset 0x3a5 {value: 0x0014, lo: 0x80, hi: 0x8f}, - {value: 0x0054, lo: 0x93, hi: 0x93}, + {value: 0x0014, lo: 0x93, hi: 0x93}, {value: 0x0024, lo: 0xa0, hi: 0xa6}, {value: 0x0034, lo: 0xa7, hi: 0xad}, {value: 0x0024, lo: 0xae, hi: 0xaf}, {value: 0x0010, lo: 0xb3, hi: 0xb4}, - // Block 0x99, offset 0x3a9 + // Block 0x99, offset 0x3ab {value: 0x0010, lo: 0x8d, hi: 0x8f}, - {value: 0x0054, lo: 0x92, hi: 0x92}, - {value: 0x0054, lo: 0x95, hi: 0x95}, + {value: 0x0014, lo: 0x92, hi: 0x92}, + {value: 0x0014, lo: 0x95, hi: 0x95}, {value: 0x0010, lo: 0xb0, hi: 0xb4}, {value: 0x0010, lo: 0xb6, hi: 0xbf}, - // Block 0x9a, offset 0x3ae + // Block 0x9a, offset 0x3b0 {value: 0x0010, lo: 0x80, hi: 0xbc}, {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x9b, offset 0x3b0 - {value: 0x0054, lo: 0x87, hi: 0x87}, - {value: 0x0054, lo: 0x8e, hi: 0x8e}, - {value: 0x0054, lo: 0x9a, hi: 0x9a}, + // Block 0x9b, offset 0x3b2 + {value: 0x0014, lo: 0x87, hi: 0x87}, + {value: 0x0014, lo: 0x8e, hi: 0x8e}, + {value: 0x0014, lo: 0x9a, hi: 0x9a}, {value: 0x5f53, lo: 0xa1, hi: 0xba}, {value: 0x0004, lo: 0xbe, hi: 0xbe}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x9c, offset 0x3b6 + // Block 0x9c, offset 0x3b8 {value: 0x0004, lo: 0x80, hi: 0x80}, {value: 0x5f52, lo: 0x81, hi: 0x9a}, {value: 0x0004, lo: 0xb0, hi: 0xb0}, - // Block 0x9d, offset 0x3b9 + // Block 0x9d, offset 0x3bb {value: 0x0014, lo: 0x9e, hi: 0x9f}, {value: 0x0010, lo: 0xa0, hi: 0xbe}, - // Block 0x9e, offset 0x3bb + // Block 0x9e, offset 0x3bd {value: 0x0010, lo: 0x82, hi: 0x87}, {value: 0x0010, lo: 0x8a, hi: 0x8f}, {value: 0x0010, lo: 0x92, hi: 0x97}, {value: 0x0010, lo: 0x9a, hi: 0x9c}, {value: 0x0004, lo: 0xa3, hi: 0xa3}, {value: 0x0014, lo: 0xb9, hi: 0xbb}, - // Block 0x9f, offset 0x3c1 + // Block 0x9f, offset 0x3c3 {value: 0x0010, lo: 0x80, hi: 0x8b}, {value: 0x0010, lo: 0x8d, hi: 0xa6}, {value: 0x0010, lo: 0xa8, hi: 0xba}, {value: 0x0010, lo: 0xbc, hi: 0xbd}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xa0, offset 0x3c6 + // Block 0xa0, offset 0x3c8 {value: 0x0010, lo: 0x80, hi: 0x8d}, {value: 0x0010, lo: 0x90, hi: 0x9d}, - // Block 0xa1, offset 0x3c8 + // Block 0xa1, offset 0x3ca {value: 0x0010, lo: 0x80, hi: 0xba}, - // Block 0xa2, offset 0x3c9 + // Block 0xa2, offset 0x3cb {value: 0x0010, lo: 0x80, hi: 0xb4}, - // Block 0xa3, offset 0x3ca + // Block 0xa3, offset 0x3cc {value: 0x0034, lo: 0xbd, hi: 0xbd}, - // Block 0xa4, offset 0x3cb + // Block 0xa4, offset 0x3cd {value: 0x0010, lo: 0x80, hi: 0x9c}, {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0xa5, offset 0x3cd + // Block 0xa5, offset 0x3cf {value: 0x0010, lo: 0x80, hi: 0x90}, {value: 0x0034, lo: 0xa0, hi: 0xa0}, - // Block 0xa6, offset 0x3cf + // Block 0xa6, offset 0x3d1 {value: 0x0010, lo: 0x80, hi: 0x9f}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xa7, offset 0x3d1 + // Block 0xa7, offset 0x3d3 {value: 0x0010, lo: 0x80, hi: 0x8a}, {value: 0x0010, lo: 0x90, hi: 0xb5}, {value: 0x0024, lo: 0xb6, hi: 0xba}, - // Block 0xa8, offset 0x3d4 + // Block 0xa8, offset 0x3d6 {value: 0x0010, lo: 0x80, hi: 0x9d}, {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0xa9, offset 0x3d6 + // Block 0xa9, offset 0x3d8 {value: 0x0010, lo: 0x80, hi: 0x83}, {value: 0x0010, lo: 0x88, hi: 0x8f}, {value: 0x0010, lo: 0x91, hi: 0x95}, - // Block 0xaa, offset 0x3d9 + // Block 0xaa, offset 0x3db {value: 0x2813, lo: 0x80, hi: 0x87}, {value: 0x3813, lo: 0x88, hi: 0x8f}, {value: 0x2813, lo: 0x90, hi: 0x97}, @@ -1739,16 +1741,16 @@ var sparseValues = [1360]valueRange{ {value: 0x2812, lo: 0xa8, hi: 0xaf}, {value: 0x3812, lo: 0xb0, hi: 0xb7}, {value: 0x2812, lo: 0xb8, hi: 0xbf}, - // Block 0xab, offset 0x3e1 + // Block 0xab, offset 0x3e3 {value: 0xaf52, lo: 0x80, hi: 0x87}, {value: 0xb252, lo: 0x88, hi: 0x8f}, {value: 0x0010, lo: 0x90, hi: 0xbf}, - // Block 0xac, offset 0x3e4 + // Block 0xac, offset 0x3e6 {value: 0x0010, lo: 0x80, hi: 0x9d}, {value: 0x0010, lo: 0xa0, hi: 0xa9}, {value: 0xb253, lo: 0xb0, hi: 0xb7}, {value: 0xaf53, lo: 0xb8, hi: 0xbf}, - // Block 0xad, offset 0x3e8 + // Block 0xad, offset 0x3ea {value: 0x2813, lo: 0x80, hi: 0x87}, {value: 0x3813, lo: 0x88, hi: 0x8f}, {value: 0x2813, lo: 0x90, hi: 0x93}, @@ -1757,38 +1759,38 @@ var sparseValues = [1360]valueRange{ {value: 0x2812, lo: 0xa8, hi: 0xaf}, {value: 0x3812, lo: 0xb0, hi: 0xb7}, {value: 0x2812, lo: 0xb8, hi: 0xbb}, - // Block 0xae, offset 0x3f0 + // Block 0xae, offset 0x3f2 {value: 0x0010, lo: 0x80, hi: 0xa7}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xaf, offset 0x3f2 + // Block 0xaf, offset 0x3f4 {value: 0x0010, lo: 0x80, hi: 0xa3}, - // Block 0xb0, offset 0x3f3 + // Block 0xb0, offset 0x3f5 {value: 0x0010, lo: 0x80, hi: 0xb6}, - // Block 0xb1, offset 0x3f4 + // Block 0xb1, offset 0x3f6 {value: 0x0010, lo: 0x80, hi: 0x95}, {value: 0x0010, lo: 0xa0, hi: 0xa7}, - // Block 0xb2, offset 0x3f6 + // Block 0xb2, offset 0x3f8 {value: 0x0010, lo: 0x80, hi: 0x85}, {value: 0x0010, lo: 0x88, hi: 0x88}, {value: 0x0010, lo: 0x8a, hi: 0xb5}, {value: 0x0010, lo: 0xb7, hi: 0xb8}, {value: 0x0010, lo: 0xbc, hi: 0xbc}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xb3, offset 0x3fc + // Block 0xb3, offset 0x3fe {value: 0x0010, lo: 0x80, hi: 0x95}, {value: 0x0010, lo: 0xa0, hi: 0xb6}, - // Block 0xb4, offset 0x3fe + // Block 0xb4, offset 0x400 {value: 0x0010, lo: 0x80, hi: 0x9e}, - // Block 0xb5, offset 0x3ff + // Block 0xb5, offset 0x401 {value: 0x0010, lo: 0xa0, hi: 0xb2}, {value: 0x0010, lo: 0xb4, hi: 0xb5}, - // Block 0xb6, offset 0x401 + // Block 0xb6, offset 0x403 {value: 0x0010, lo: 0x80, hi: 0x95}, {value: 0x0010, lo: 0xa0, hi: 0xb9}, - // Block 0xb7, offset 0x403 + // Block 0xb7, offset 0x405 {value: 0x0010, lo: 0x80, hi: 0xb7}, {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0xb8, offset 0x405 + // Block 0xb8, offset 0x407 {value: 0x0010, lo: 0x80, hi: 0x80}, {value: 0x0014, lo: 0x81, hi: 0x83}, {value: 0x0014, lo: 0x85, hi: 0x86}, @@ -1802,47 +1804,47 @@ var sparseValues = [1360]valueRange{ {value: 0x0024, lo: 0xb8, hi: 0xb8}, {value: 0x0034, lo: 0xb9, hi: 0xba}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xb9, offset 0x412 + // Block 0xb9, offset 0x414 {value: 0x0010, lo: 0xa0, hi: 0xbc}, - // Block 0xba, offset 0x413 + // Block 0xba, offset 0x415 {value: 0x0010, lo: 0x80, hi: 0x9c}, - // Block 0xbb, offset 0x414 + // Block 0xbb, offset 0x416 {value: 0x0010, lo: 0x80, hi: 0x87}, {value: 0x0010, lo: 0x89, hi: 0xa4}, {value: 0x0024, lo: 0xa5, hi: 0xa5}, {value: 0x0034, lo: 0xa6, hi: 0xa6}, - // Block 0xbc, offset 0x418 + // Block 0xbc, offset 0x41a {value: 0x0010, lo: 0x80, hi: 0x95}, {value: 0x0010, lo: 0xa0, hi: 0xb2}, - // Block 0xbd, offset 0x41a + // Block 0xbd, offset 0x41c {value: 0x0010, lo: 0x80, hi: 0x91}, - // Block 0xbe, offset 0x41b + // Block 0xbe, offset 0x41d {value: 0x0010, lo: 0x80, hi: 0x88}, - // Block 0xbf, offset 0x41c + // Block 0xbf, offset 0x41e {value: 0x5653, lo: 0x80, hi: 0xb2}, - // Block 0xc0, offset 0x41d + // Block 0xc0, offset 0x41f {value: 0x5652, lo: 0x80, hi: 0xb2}, - // Block 0xc1, offset 0x41e + // Block 0xc1, offset 0x420 {value: 0x0010, lo: 0x80, hi: 0x80}, {value: 0x0014, lo: 0x81, hi: 0x81}, {value: 0x0010, lo: 0x82, hi: 0xb7}, {value: 0x0014, lo: 0xb8, hi: 0xbf}, - // Block 0xc2, offset 0x422 + // Block 0xc2, offset 0x424 {value: 0x0014, lo: 0x80, hi: 0x85}, {value: 0x0034, lo: 0x86, hi: 0x86}, {value: 0x0010, lo: 0xa6, hi: 0xaf}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xc3, offset 0x426 + // Block 0xc3, offset 0x428 {value: 0x0014, lo: 0x80, hi: 0x81}, {value: 0x0010, lo: 0x82, hi: 0xb2}, {value: 0x0014, lo: 0xb3, hi: 0xb6}, {value: 0x0010, lo: 0xb7, hi: 0xb8}, {value: 0x0034, lo: 0xb9, hi: 0xba}, {value: 0x0014, lo: 0xbd, hi: 0xbd}, - // Block 0xc4, offset 0x42c + // Block 0xc4, offset 0x42e {value: 0x0010, lo: 0x90, hi: 0xa8}, {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xc5, offset 0x42e + // Block 0xc5, offset 0x430 {value: 0x0024, lo: 0x80, hi: 0x82}, {value: 0x0010, lo: 0x83, hi: 0xa6}, {value: 0x0014, lo: 0xa7, hi: 0xab}, @@ -1850,23 +1852,23 @@ var sparseValues = [1360]valueRange{ {value: 0x0014, lo: 0xad, hi: 0xb2}, {value: 0x0034, lo: 0xb3, hi: 0xb4}, {value: 0x0010, lo: 0xb6, hi: 0xbf}, - // Block 0xc6, offset 0x435 + // Block 0xc6, offset 0x437 {value: 0x0010, lo: 0x90, hi: 0xb2}, {value: 0x0034, lo: 0xb3, hi: 0xb3}, {value: 0x0010, lo: 0xb6, hi: 0xb6}, - // Block 0xc7, offset 0x438 + // Block 0xc7, offset 0x43a {value: 0x0014, lo: 0x80, hi: 0x81}, {value: 0x0010, lo: 0x82, hi: 0xb5}, {value: 0x0014, lo: 0xb6, hi: 0xbe}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xc8, offset 0x43c + // Block 0xc8, offset 0x43e {value: 0x0030, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x81, hi: 0x84}, {value: 0x0034, lo: 0x8a, hi: 0x8a}, {value: 0x0014, lo: 0x8b, hi: 0x8c}, {value: 0x0010, lo: 0x90, hi: 0x9a}, {value: 0x0010, lo: 0x9c, hi: 0x9c}, - // Block 0xc9, offset 0x442 + // Block 0xc9, offset 0x444 {value: 0x0010, lo: 0x80, hi: 0x91}, {value: 0x0010, lo: 0x93, hi: 0xae}, {value: 0x0014, lo: 0xaf, hi: 0xb1}, @@ -1876,21 +1878,21 @@ var sparseValues = [1360]valueRange{ {value: 0x0034, lo: 0xb6, hi: 0xb6}, {value: 0x0014, lo: 0xb7, hi: 0xb7}, {value: 0x0014, lo: 0xbe, hi: 0xbe}, - // Block 0xca, offset 0x44b + // Block 0xca, offset 0x44d {value: 0x0010, lo: 0x80, hi: 0x86}, {value: 0x0010, lo: 0x88, hi: 0x88}, {value: 0x0010, lo: 0x8a, hi: 0x8d}, {value: 0x0010, lo: 0x8f, hi: 0x9d}, {value: 0x0010, lo: 0x9f, hi: 0xa8}, {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xcb, offset 0x451 + // Block 0xcb, offset 0x453 {value: 0x0010, lo: 0x80, hi: 0x9e}, {value: 0x0014, lo: 0x9f, hi: 0x9f}, {value: 0x0010, lo: 0xa0, hi: 0xa2}, {value: 0x0014, lo: 0xa3, hi: 0xa8}, {value: 0x0034, lo: 0xa9, hi: 0xaa}, {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xcc, offset 0x457 + // Block 0xcc, offset 0x459 {value: 0x0014, lo: 0x80, hi: 0x81}, {value: 0x0010, lo: 0x82, hi: 0x83}, {value: 0x0010, lo: 0x85, hi: 0x8c}, @@ -1901,7 +1903,7 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xb5, hi: 0xb9}, {value: 0x0034, lo: 0xbc, hi: 0xbc}, {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0xcd, offset 0x461 + // Block 0xcd, offset 0x463 {value: 0x0014, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x81, hi: 0x84}, {value: 0x0010, lo: 0x87, hi: 0x88}, @@ -1912,10 +1914,10 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0x9d, hi: 0xa3}, {value: 0x0024, lo: 0xa6, hi: 0xac}, {value: 0x0024, lo: 0xb0, hi: 0xb4}, - // Block 0xce, offset 0x46b + // Block 0xce, offset 0x46d {value: 0x0010, lo: 0x80, hi: 0xb7}, {value: 0x0014, lo: 0xb8, hi: 0xbf}, - // Block 0xcf, offset 0x46d + // Block 0xcf, offset 0x46f {value: 0x0010, lo: 0x80, hi: 0x81}, {value: 0x0034, lo: 0x82, hi: 0x82}, {value: 0x0014, lo: 0x83, hi: 0x84}, @@ -1923,43 +1925,43 @@ var sparseValues = [1360]valueRange{ {value: 0x0034, lo: 0x86, hi: 0x86}, {value: 0x0010, lo: 0x87, hi: 0x8a}, {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd0, offset 0x474 + // Block 0xd0, offset 0x476 {value: 0x0010, lo: 0x80, hi: 0xb2}, {value: 0x0014, lo: 0xb3, hi: 0xb8}, {value: 0x0010, lo: 0xb9, hi: 0xb9}, {value: 0x0014, lo: 0xba, hi: 0xba}, {value: 0x0010, lo: 0xbb, hi: 0xbe}, {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0xd1, offset 0x47a + // Block 0xd1, offset 0x47c {value: 0x0014, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x81, hi: 0x81}, {value: 0x0034, lo: 0x82, hi: 0x83}, {value: 0x0010, lo: 0x84, hi: 0x85}, {value: 0x0010, lo: 0x87, hi: 0x87}, {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd2, offset 0x480 + // Block 0xd2, offset 0x482 {value: 0x0010, lo: 0x80, hi: 0xb1}, {value: 0x0014, lo: 0xb2, hi: 0xb5}, {value: 0x0010, lo: 0xb8, hi: 0xbb}, {value: 0x0014, lo: 0xbc, hi: 0xbd}, {value: 0x0010, lo: 0xbe, hi: 0xbe}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xd3, offset 0x486 + // Block 0xd3, offset 0x488 {value: 0x0034, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x98, hi: 0x9b}, {value: 0x0014, lo: 0x9c, hi: 0x9d}, - // Block 0xd4, offset 0x489 + // Block 0xd4, offset 0x48b {value: 0x0010, lo: 0x80, hi: 0xb2}, {value: 0x0014, lo: 0xb3, hi: 0xba}, {value: 0x0010, lo: 0xbb, hi: 0xbc}, {value: 0x0014, lo: 0xbd, hi: 0xbd}, {value: 0x0010, lo: 0xbe, hi: 0xbe}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xd5, offset 0x48f + // Block 0xd5, offset 0x491 {value: 0x0014, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x84, hi: 0x84}, {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd6, offset 0x492 + // Block 0xd6, offset 0x494 {value: 0x0010, lo: 0x80, hi: 0xaa}, {value: 0x0014, lo: 0xab, hi: 0xab}, {value: 0x0010, lo: 0xac, hi: 0xac}, @@ -1968,9 +1970,9 @@ var sparseValues = [1360]valueRange{ {value: 0x0014, lo: 0xb0, hi: 0xb5}, {value: 0x0030, lo: 0xb6, hi: 0xb6}, {value: 0x0034, lo: 0xb7, hi: 0xb7}, - // Block 0xd7, offset 0x49a + // Block 0xd7, offset 0x49c {value: 0x0010, lo: 0x80, hi: 0x89}, - // Block 0xd8, offset 0x49b + // Block 0xd8, offset 0x49d {value: 0x0014, lo: 0x9d, hi: 0x9f}, {value: 0x0010, lo: 0xa0, hi: 0xa1}, {value: 0x0014, lo: 0xa2, hi: 0xa5}, @@ -1978,26 +1980,26 @@ var sparseValues = [1360]valueRange{ {value: 0x0014, lo: 0xa7, hi: 0xaa}, {value: 0x0034, lo: 0xab, hi: 0xab}, {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xd9, offset 0x4a2 + // Block 0xd9, offset 0x4a4 {value: 0x5f53, lo: 0xa0, hi: 0xbf}, - // Block 0xda, offset 0x4a3 + // Block 0xda, offset 0x4a5 {value: 0x5f52, lo: 0x80, hi: 0x9f}, {value: 0x0010, lo: 0xa0, hi: 0xa9}, {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xdb, offset 0x4a6 + // Block 0xdb, offset 0x4a8 {value: 0x0010, lo: 0x80, hi: 0xb8}, - // Block 0xdc, offset 0x4a7 + // Block 0xdc, offset 0x4a9 {value: 0x0010, lo: 0x80, hi: 0x88}, {value: 0x0010, lo: 0x8a, hi: 0xaf}, {value: 0x0014, lo: 0xb0, hi: 0xb6}, {value: 0x0014, lo: 0xb8, hi: 0xbd}, {value: 0x0010, lo: 0xbe, hi: 0xbe}, {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xdd, offset 0x4ad + // Block 0xdd, offset 0x4af {value: 0x0010, lo: 0x80, hi: 0x80}, {value: 0x0010, lo: 0x90, hi: 0x99}, {value: 0x0010, lo: 0xb2, hi: 0xbf}, - // Block 0xde, offset 0x4b0 + // Block 0xde, offset 0x4b2 {value: 0x0010, lo: 0x80, hi: 0x8f}, {value: 0x0014, lo: 0x92, hi: 0xa7}, {value: 0x0010, lo: 0xa9, hi: 0xa9}, @@ -2006,69 +2008,69 @@ var sparseValues = [1360]valueRange{ {value: 0x0014, lo: 0xb2, hi: 0xb3}, {value: 0x0010, lo: 0xb4, hi: 0xb4}, {value: 0x0014, lo: 0xb5, hi: 0xb6}, - // Block 0xdf, offset 0x4b8 + // Block 0xdf, offset 0x4ba {value: 0x0010, lo: 0x80, hi: 0x99}, - // Block 0xe0, offset 0x4b9 + // Block 0xe0, offset 0x4bb {value: 0x0010, lo: 0x80, hi: 0xae}, - // Block 0xe1, offset 0x4ba + // Block 0xe1, offset 0x4bc {value: 0x0010, lo: 0x80, hi: 0x83}, - // Block 0xe2, offset 0x4bb + // Block 0xe2, offset 0x4bd {value: 0x0010, lo: 0x80, hi: 0x86}, - // Block 0xe3, offset 0x4bc + // Block 0xe3, offset 0x4be {value: 0x0010, lo: 0x80, hi: 0x9e}, {value: 0x0010, lo: 0xa0, hi: 0xa9}, - // Block 0xe4, offset 0x4be + // Block 0xe4, offset 0x4c0 {value: 0x0010, lo: 0x90, hi: 0xad}, {value: 0x0034, lo: 0xb0, hi: 0xb4}, - // Block 0xe5, offset 0x4c0 + // Block 0xe5, offset 0x4c2 {value: 0x0010, lo: 0x80, hi: 0xaf}, {value: 0x0024, lo: 0xb0, hi: 0xb6}, - // Block 0xe6, offset 0x4c2 + // Block 0xe6, offset 0x4c4 {value: 0x0014, lo: 0x80, hi: 0x83}, {value: 0x0010, lo: 0x90, hi: 0x99}, {value: 0x0010, lo: 0xa3, hi: 0xb7}, {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0xe7, offset 0x4c6 + // Block 0xe7, offset 0x4c8 {value: 0x0010, lo: 0x80, hi: 0x8f}, - // Block 0xe8, offset 0x4c7 + // Block 0xe8, offset 0x4c9 {value: 0x0010, lo: 0x80, hi: 0x84}, {value: 0x0010, lo: 0x90, hi: 0xbe}, - // Block 0xe9, offset 0x4c9 + // Block 0xe9, offset 0x4cb {value: 0x0014, lo: 0x8f, hi: 0x9f}, - // Block 0xea, offset 0x4ca + // Block 0xea, offset 0x4cc {value: 0x0014, lo: 0xa0, hi: 0xa0}, - // Block 0xeb, offset 0x4cb + // Block 0xeb, offset 0x4cd {value: 0x0010, lo: 0x80, hi: 0xaa}, {value: 0x0010, lo: 0xb0, hi: 0xbc}, - // Block 0xec, offset 0x4cd + // Block 0xec, offset 0x4cf {value: 0x0010, lo: 0x80, hi: 0x88}, {value: 0x0010, lo: 0x90, hi: 0x99}, {value: 0x0014, lo: 0x9d, hi: 0x9d}, {value: 0x0034, lo: 0x9e, hi: 0x9e}, {value: 0x0014, lo: 0xa0, hi: 0xa3}, - // Block 0xed, offset 0x4d2 + // Block 0xed, offset 0x4d4 {value: 0x0030, lo: 0xa5, hi: 0xa6}, {value: 0x0034, lo: 0xa7, hi: 0xa9}, {value: 0x0030, lo: 0xad, hi: 0xb2}, {value: 0x0014, lo: 0xb3, hi: 0xba}, {value: 0x0034, lo: 0xbb, hi: 0xbf}, - // Block 0xee, offset 0x4d7 + // Block 0xee, offset 0x4d9 {value: 0x0034, lo: 0x80, hi: 0x82}, {value: 0x0024, lo: 0x85, hi: 0x89}, {value: 0x0034, lo: 0x8a, hi: 0x8b}, {value: 0x0024, lo: 0xaa, hi: 0xad}, - // Block 0xef, offset 0x4db + // Block 0xef, offset 0x4dd {value: 0x0024, lo: 0x82, hi: 0x84}, - // Block 0xf0, offset 0x4dc + // Block 0xf0, offset 0x4de {value: 0x0013, lo: 0x80, hi: 0x99}, {value: 0x0012, lo: 0x9a, hi: 0xb3}, {value: 0x0013, lo: 0xb4, hi: 0xbf}, - // Block 0xf1, offset 0x4df + // Block 0xf1, offset 0x4e1 {value: 0x0013, lo: 0x80, hi: 0x8d}, {value: 0x0012, lo: 0x8e, hi: 0x94}, {value: 0x0012, lo: 0x96, hi: 0xa7}, {value: 0x0013, lo: 0xa8, hi: 0xbf}, - // Block 0xf2, offset 0x4e3 + // Block 0xf2, offset 0x4e5 {value: 0x0013, lo: 0x80, hi: 0x81}, {value: 0x0012, lo: 0x82, hi: 0x9b}, {value: 0x0013, lo: 0x9c, hi: 0x9c}, @@ -2080,12 +2082,12 @@ var sparseValues = [1360]valueRange{ {value: 0x0012, lo: 0xb6, hi: 0xb9}, {value: 0x0012, lo: 0xbb, hi: 0xbb}, {value: 0x0012, lo: 0xbd, hi: 0xbf}, - // Block 0xf3, offset 0x4ee + // Block 0xf3, offset 0x4f0 {value: 0x0012, lo: 0x80, hi: 0x83}, {value: 0x0012, lo: 0x85, hi: 0x8f}, {value: 0x0013, lo: 0x90, hi: 0xa9}, {value: 0x0012, lo: 0xaa, hi: 0xbf}, - // Block 0xf4, offset 0x4f2 + // Block 0xf4, offset 0x4f4 {value: 0x0012, lo: 0x80, hi: 0x83}, {value: 0x0013, lo: 0x84, hi: 0x85}, {value: 0x0013, lo: 0x87, hi: 0x8a}, @@ -2094,86 +2096,86 @@ var sparseValues = [1360]valueRange{ {value: 0x0012, lo: 0x9e, hi: 0xb7}, {value: 0x0013, lo: 0xb8, hi: 0xb9}, {value: 0x0013, lo: 0xbb, hi: 0xbe}, - // Block 0xf5, offset 0x4fa + // Block 0xf5, offset 0x4fc {value: 0x0013, lo: 0x80, hi: 0x84}, {value: 0x0013, lo: 0x86, hi: 0x86}, {value: 0x0013, lo: 0x8a, hi: 0x90}, {value: 0x0012, lo: 0x92, hi: 0xab}, {value: 0x0013, lo: 0xac, hi: 0xbf}, - // Block 0xf6, offset 0x4ff + // Block 0xf6, offset 0x501 {value: 0x0013, lo: 0x80, hi: 0x85}, {value: 0x0012, lo: 0x86, hi: 0x9f}, {value: 0x0013, lo: 0xa0, hi: 0xb9}, {value: 0x0012, lo: 0xba, hi: 0xbf}, - // Block 0xf7, offset 0x503 + // Block 0xf7, offset 0x505 {value: 0x0012, lo: 0x80, hi: 0x93}, {value: 0x0013, lo: 0x94, hi: 0xad}, {value: 0x0012, lo: 0xae, hi: 0xbf}, - // Block 0xf8, offset 0x506 + // Block 0xf8, offset 0x508 {value: 0x0012, lo: 0x80, hi: 0x87}, {value: 0x0013, lo: 0x88, hi: 0xa1}, {value: 0x0012, lo: 0xa2, hi: 0xbb}, {value: 0x0013, lo: 0xbc, hi: 0xbf}, - // Block 0xf9, offset 0x50a + // Block 0xf9, offset 0x50c {value: 0x0013, lo: 0x80, hi: 0x95}, {value: 0x0012, lo: 0x96, hi: 0xaf}, {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0xfa, offset 0x50d + // Block 0xfa, offset 0x50f {value: 0x0013, lo: 0x80, hi: 0x89}, {value: 0x0012, lo: 0x8a, hi: 0xa5}, {value: 0x0013, lo: 0xa8, hi: 0xbf}, - // Block 0xfb, offset 0x510 + // Block 0xfb, offset 0x512 {value: 0x0013, lo: 0x80, hi: 0x80}, {value: 0x0012, lo: 0x82, hi: 0x9a}, {value: 0x0012, lo: 0x9c, hi: 0xa1}, {value: 0x0013, lo: 0xa2, hi: 0xba}, {value: 0x0012, lo: 0xbc, hi: 0xbf}, - // Block 0xfc, offset 0x515 + // Block 0xfc, offset 0x517 {value: 0x0012, lo: 0x80, hi: 0x94}, {value: 0x0012, lo: 0x96, hi: 0x9b}, {value: 0x0013, lo: 0x9c, hi: 0xb4}, {value: 0x0012, lo: 0xb6, hi: 0xbf}, - // Block 0xfd, offset 0x519 + // Block 0xfd, offset 0x51b {value: 0x0012, lo: 0x80, hi: 0x8e}, {value: 0x0012, lo: 0x90, hi: 0x95}, {value: 0x0013, lo: 0x96, hi: 0xae}, {value: 0x0012, lo: 0xb0, hi: 0xbf}, - // Block 0xfe, offset 0x51d + // Block 0xfe, offset 0x51f {value: 0x0012, lo: 0x80, hi: 0x88}, {value: 0x0012, lo: 0x8a, hi: 0x8f}, {value: 0x0013, lo: 0x90, hi: 0xa8}, {value: 0x0012, lo: 0xaa, hi: 0xbf}, - // Block 0xff, offset 0x521 + // Block 0xff, offset 0x523 {value: 0x0012, lo: 0x80, hi: 0x82}, {value: 0x0012, lo: 0x84, hi: 0x89}, {value: 0x0017, lo: 0x8a, hi: 0x8b}, {value: 0x0010, lo: 0x8e, hi: 0xbf}, - // Block 0x100, offset 0x525 + // Block 0x100, offset 0x527 {value: 0x0014, lo: 0x80, hi: 0xb6}, {value: 0x0014, lo: 0xbb, hi: 0xbf}, - // Block 0x101, offset 0x527 + // Block 0x101, offset 0x529 {value: 0x0014, lo: 0x80, hi: 0xac}, {value: 0x0014, lo: 0xb5, hi: 0xb5}, - // Block 0x102, offset 0x529 + // Block 0x102, offset 0x52b {value: 0x0014, lo: 0x84, hi: 0x84}, {value: 0x0014, lo: 0x9b, hi: 0x9f}, {value: 0x0014, lo: 0xa1, hi: 0xaf}, - // Block 0x103, offset 0x52c + // Block 0x103, offset 0x52e {value: 0x0024, lo: 0x80, hi: 0x86}, {value: 0x0024, lo: 0x88, hi: 0x98}, {value: 0x0024, lo: 0x9b, hi: 0xa1}, {value: 0x0024, lo: 0xa3, hi: 0xa4}, {value: 0x0024, lo: 0xa6, hi: 0xaa}, - // Block 0x104, offset 0x531 + // Block 0x104, offset 0x533 {value: 0x0010, lo: 0x80, hi: 0x84}, {value: 0x0034, lo: 0x90, hi: 0x96}, - // Block 0x105, offset 0x533 + // Block 0x105, offset 0x535 {value: 0xb552, lo: 0x80, hi: 0x81}, {value: 0xb852, lo: 0x82, hi: 0x83}, {value: 0x0024, lo: 0x84, hi: 0x89}, {value: 0x0034, lo: 0x8a, hi: 0x8a}, {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0x106, offset 0x538 + // Block 0x106, offset 0x53a {value: 0x0010, lo: 0x80, hi: 0x83}, {value: 0x0010, lo: 0x85, hi: 0x9f}, {value: 0x0010, lo: 0xa1, hi: 0xa2}, @@ -2183,29 +2185,29 @@ var sparseValues = [1360]valueRange{ {value: 0x0010, lo: 0xb4, hi: 0xb7}, {value: 0x0010, lo: 0xb9, hi: 0xb9}, {value: 0x0010, lo: 0xbb, hi: 0xbb}, - // Block 0x107, offset 0x541 + // Block 0x107, offset 0x543 {value: 0x0010, lo: 0x80, hi: 0x89}, {value: 0x0010, lo: 0x8b, hi: 0x9b}, {value: 0x0010, lo: 0xa1, hi: 0xa3}, {value: 0x0010, lo: 0xa5, hi: 0xa9}, {value: 0x0010, lo: 0xab, hi: 0xbb}, - // Block 0x108, offset 0x546 + // Block 0x108, offset 0x548 {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0x109, offset 0x547 + // Block 0x109, offset 0x549 {value: 0x0013, lo: 0x80, hi: 0x89}, {value: 0x0013, lo: 0x90, hi: 0xa9}, {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0x10a, offset 0x54a + // Block 0x10a, offset 0x54c {value: 0x0013, lo: 0x80, hi: 0x89}, - // Block 0x10b, offset 0x54b + // Block 0x10b, offset 0x54d {value: 0x0004, lo: 0xbb, hi: 0xbf}, - // Block 0x10c, offset 0x54c + // Block 0x10c, offset 0x54e {value: 0x0014, lo: 0x81, hi: 0x81}, {value: 0x0014, lo: 0xa0, hi: 0xbf}, - // Block 0x10d, offset 0x54e + // Block 0x10d, offset 0x550 {value: 0x0014, lo: 0x80, hi: 0xbf}, - // Block 0x10e, offset 0x54f + // Block 0x10e, offset 0x551 {value: 0x0014, lo: 0x80, hi: 0xaf}, } -// Total table size 13811 bytes (13KiB); checksum: 4CC48DA3 +// Total table size 13819 bytes (13KiB); checksum: 4CC48DA3 diff --git a/vendor/golang.org/x/text/cases/trieval.go b/vendor/golang.org/x/text/cases/trieval.go index a2edb10..7f2aa5b 100644 --- a/vendor/golang.org/x/text/cases/trieval.go +++ b/vendor/golang.org/x/text/cases/trieval.go @@ -22,7 +22,6 @@ package cases // Only 13..8 are used for XOR patterns. // 7 inverseFold (fold to upper, not to lower) // 6 index: interpret the XOR pattern as an index -// or isMid if case mode is cIgnorableUncased. // 5..4 CCC: zero (normal or break), above or other // } // 3 exception: interpret this value as an exception index @@ -45,7 +44,6 @@ const ( ignorableValue = 0x0004 inverseFoldBit = 1 << 7 - isMidBit = 1 << 6 exceptionBit = 1 << 3 exceptionShift = 5 @@ -55,7 +53,7 @@ const ( xorShift = 8 // There is no mapping if all xor bits and the exception bit are zero. - hasMappingMask = 0xff80 | exceptionBit + hasMappingMask = 0xffc0 | exceptionBit ) // The case mode bits encodes the case type of a rune. This includes uncased, @@ -93,6 +91,10 @@ func (c info) isCaseIgnorable() bool { return c&ignorableMask == ignorableValue } +func (c info) isCaseIgnorableAndNonBreakStarter() bool { + return c&(fullCasedMask|cccMask) == (ignorableValue | cccZero) +} + func (c info) isNotCasedAndNotCaseIgnorable() bool { return c&fullCasedMask == 0 } @@ -101,10 +103,6 @@ func (c info) isCaseIgnorableAndNotCased() bool { return c&fullCasedMask == cIgnorableUncased } -func (c info) isMid() bool { - return c&(fullCasedMask|isMidBit) == isMidBit|cIgnorableUncased -} - // The case mapping implementation will need to know about various Canonical // Combining Class (CCC) values. We encode two of these in the trie value: // cccZero (0) and cccAbove (230). If the value is cccOther, it means that diff --git a/vendor/golang.org/x/text/internal/gen.go b/vendor/golang.org/x/text/internal/gen.go deleted file mode 100644 index 1d678af..0000000 --- a/vendor/golang.org/x/text/internal/gen.go +++ /dev/null @@ -1,52 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -import ( - "log" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/language" - "golang.org/x/text/unicode/cldr" -) - -func main() { - r := gen.OpenCLDRCoreZip() - defer r.Close() - - d := &cldr.Decoder{} - data, err := d.DecodeZip(r) - if err != nil { - log.Fatalf("DecodeZip: %v", err) - } - - w := gen.NewCodeWriter() - defer w.WriteGoFile("tables.go", "internal") - - // Create parents table. - parents := make([]uint16, language.NumCompactTags) - for _, loc := range data.Locales() { - tag := language.MustParse(loc) - index, ok := language.CompactIndex(tag) - if !ok { - continue - } - parentIndex := 0 // und - for p := tag.Parent(); p != language.Und; p = p.Parent() { - if x, ok := language.CompactIndex(p); ok { - parentIndex = x - break - } - } - parents[index] = uint16(parentIndex) - } - - w.WriteComment(` - Parent maps a compact index of a tag to the compact index of the parent of - this tag.`) - w.WriteVar("Parent", parents) -} diff --git a/vendor/golang.org/x/text/internal/internal.go b/vendor/golang.org/x/text/internal/internal.go deleted file mode 100644 index b39dc21..0000000 --- a/vendor/golang.org/x/text/internal/internal.go +++ /dev/null @@ -1,51 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate go run gen.go - -// Package internal contains non-exported functionality that are used by -// packages in the text repository. -package internal - -import ( - "sort" - - "golang.org/x/text/language" -) - -// SortTags sorts tags in place. -func SortTags(tags []language.Tag) { - sort.Sort(sorter(tags)) -} - -type sorter []language.Tag - -func (s sorter) Len() int { - return len(s) -} - -func (s sorter) Swap(i, j int) { - s[i], s[j] = s[j], s[i] -} - -func (s sorter) Less(i, j int) bool { - return s[i].String() < s[j].String() -} - -// UniqueTags sorts and filters duplicate tags in place and returns a slice with -// only unique tags. -func UniqueTags(tags []language.Tag) []language.Tag { - if len(tags) <= 1 { - return tags - } - SortTags(tags) - k := 0 - for i := 1; i < len(tags); i++ { - if tags[k].String() < tags[i].String() { - k++ - tags[k] = tags[i] - } - } - return tags[:k+1] -} diff --git a/vendor/golang.org/x/text/internal/match.go b/vendor/golang.org/x/text/internal/match.go deleted file mode 100644 index a67fcac..0000000 --- a/vendor/golang.org/x/text/internal/match.go +++ /dev/null @@ -1,67 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package internal - -// This file contains matchers that implement CLDR inheritance. -// -// See http://unicode.org/reports/tr35/#Locale_Inheritance. -// -// Some of the inheritance described in this document is already handled by -// the cldr package. - -import ( - "golang.org/x/text/language" -) - -// TODO: consider if (some of the) matching algorithm needs to be public after -// getting some feel about what is generic and what is specific. - -// NewInheritanceMatcher returns a matcher that matches based on the inheritance -// chain. -// -// The matcher uses canonicalization and the parent relationship to find a -// match. The resulting match will always be either Und or a language with the -// same language and script as the requested language. It will not match -// languages for which there is understood to be mutual or one-directional -// intelligibility. -// -// A Match will indicate an Exact match if the language matches after -// canonicalization and High if the matched tag is a parent. -func NewInheritanceMatcher(t []language.Tag) *InheritanceMatcher { - tags := &InheritanceMatcher{make(map[language.Tag]int)} - for i, tag := range t { - ct, err := language.All.Canonicalize(tag) - if err != nil { - ct = tag - } - tags.index[ct] = i - } - return tags -} - -type InheritanceMatcher struct { - index map[language.Tag]int -} - -func (m InheritanceMatcher) Match(want ...language.Tag) (language.Tag, int, language.Confidence) { - for _, t := range want { - ct, err := language.All.Canonicalize(t) - if err != nil { - ct = t - } - conf := language.Exact - for { - if index, ok := m.index[ct]; ok { - return ct, index, conf - } - if ct == language.Und { - break - } - ct = ct.Parent() - conf = language.High - } - } - return language.Und, 0, language.No -} diff --git a/vendor/golang.org/x/text/internal/tables.go b/vendor/golang.org/x/text/internal/tables.go deleted file mode 100644 index 5e8f5fa..0000000 --- a/vendor/golang.org/x/text/internal/tables.go +++ /dev/null @@ -1,116 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package internal - -// Parent maps a compact index of a tag to the compact index of the parent of -// this tag. -var Parent = []uint16{ // 752 elements - // Entry 0 - 3F - 0x0000, 0x0053, 0x00e5, 0x0000, 0x0003, 0x0003, 0x0000, 0x0006, - 0x0000, 0x0008, 0x0000, 0x000a, 0x0000, 0x000c, 0x000c, 0x000c, - 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, - 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, - 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, 0x000c, - 0x000c, 0x0000, 0x0000, 0x002a, 0x0000, 0x002c, 0x0000, 0x002e, - 0x0000, 0x0000, 0x0031, 0x0030, 0x0030, 0x0000, 0x0035, 0x0000, - 0x0037, 0x0000, 0x0039, 0x0000, 0x003b, 0x0000, 0x003d, 0x0000, - // Entry 40 - 7F - 0x0000, 0x0040, 0x0000, 0x0042, 0x0042, 0x0000, 0x0045, 0x0045, - 0x0000, 0x0048, 0x0000, 0x004a, 0x0000, 0x0000, 0x004d, 0x004c, - 0x004c, 0x0000, 0x0051, 0x0051, 0x0051, 0x0051, 0x0000, 0x0056, - 0x0000, 0x0058, 0x0000, 0x005a, 0x0000, 0x005c, 0x005c, 0x0000, - 0x005f, 0x0000, 0x0061, 0x0000, 0x0063, 0x0000, 0x0065, 0x0065, - 0x0000, 0x0068, 0x0000, 0x006a, 0x006a, 0x006a, 0x006a, 0x006a, - 0x006a, 0x006a, 0x0000, 0x0072, 0x0000, 0x0074, 0x0000, 0x0076, - 0x0000, 0x0000, 0x0079, 0x0000, 0x007b, 0x0000, 0x007d, 0x0000, - // Entry 80 - BF - 0x007f, 0x007f, 0x0000, 0x0082, 0x0082, 0x0000, 0x0085, 0x0086, - 0x0086, 0x0086, 0x0085, 0x0087, 0x0086, 0x0086, 0x0086, 0x0085, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0087, 0x0086, - 0x0086, 0x0086, 0x0086, 0x0087, 0x0086, 0x0087, 0x0086, 0x0086, - 0x0087, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, - 0x0086, 0x0086, 0x0085, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0085, 0x0086, 0x0085, 0x0086, - // Entry C0 - FF - 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0087, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0085, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0087, 0x0086, 0x0086, - 0x0087, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, - 0x0086, 0x0086, 0x0086, 0x0086, 0x0085, 0x0085, 0x0086, 0x0086, - 0x0085, 0x0086, 0x0086, 0x0086, 0x0086, 0x0086, 0x0000, 0x00ee, - 0x0000, 0x00f0, 0x00f1, 0x00f1, 0x00f1, 0x00f1, 0x00f1, 0x00f1, - 0x00f1, 0x00f1, 0x00f0, 0x00f1, 0x00f0, 0x00f0, 0x00f1, 0x00f1, - // Entry 100 - 13F - 0x00f0, 0x00f1, 0x00f1, 0x00f1, 0x00f1, 0x00f0, 0x00f1, 0x00f1, - 0x00f1, 0x00f1, 0x00f1, 0x00f1, 0x0000, 0x010c, 0x0000, 0x010e, - 0x0000, 0x0110, 0x0000, 0x0112, 0x0112, 0x0000, 0x0115, 0x0115, - 0x0115, 0x0115, 0x0000, 0x011a, 0x0000, 0x011c, 0x0000, 0x011e, - 0x011e, 0x0000, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - // Entry 140 - 17F - 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, 0x0121, - 0x0000, 0x0150, 0x0000, 0x0152, 0x0000, 0x0154, 0x0000, 0x0156, - 0x0000, 0x0158, 0x0000, 0x015a, 0x015a, 0x015a, 0x0000, 0x015e, - 0x0000, 0x0000, 0x0161, 0x0000, 0x0163, 0x0000, 0x0165, 0x0165, - 0x0165, 0x0000, 0x0169, 0x0000, 0x016b, 0x0000, 0x016d, 0x0000, - 0x016f, 0x016f, 0x0000, 0x0172, 0x0000, 0x0174, 0x0000, 0x0176, - 0x0000, 0x0178, 0x0000, 0x017a, 0x0000, 0x017c, 0x0000, 0x017e, - // Entry 180 - 1BF - 0x0000, 0x0180, 0x0180, 0x0180, 0x0000, 0x0000, 0x0185, 0x0000, - 0x0000, 0x0188, 0x0000, 0x018a, 0x0000, 0x0000, 0x018d, 0x0000, - 0x018f, 0x0000, 0x0000, 0x0192, 0x0000, 0x0000, 0x0195, 0x0000, - 0x0197, 0x0000, 0x0199, 0x0000, 0x019b, 0x0000, 0x019d, 0x0000, - 0x019f, 0x0000, 0x01a1, 0x0000, 0x01a3, 0x0000, 0x01a5, 0x0000, - 0x01a7, 0x0000, 0x01a9, 0x01a9, 0x0000, 0x01ac, 0x0000, 0x01ae, - 0x0000, 0x01b0, 0x0000, 0x01b2, 0x0000, 0x01b4, 0x0000, 0x0000, - 0x01b7, 0x0000, 0x01b9, 0x0000, 0x01bb, 0x0000, 0x01bd, 0x0000, - // Entry 1C0 - 1FF - 0x01bf, 0x0000, 0x01c1, 0x0000, 0x01c3, 0x01c3, 0x01c3, 0x01c3, - 0x0000, 0x01c8, 0x0000, 0x01ca, 0x01ca, 0x0000, 0x01cd, 0x0000, - 0x01cf, 0x0000, 0x01d1, 0x0000, 0x01d3, 0x0000, 0x01d5, 0x0000, - 0x01d7, 0x01d7, 0x0000, 0x01da, 0x0000, 0x01dc, 0x0000, 0x01de, - 0x0000, 0x01e0, 0x0000, 0x01e2, 0x0000, 0x01e4, 0x0000, 0x01e6, - 0x0000, 0x01e8, 0x0000, 0x01ea, 0x0000, 0x01ec, 0x01ec, 0x01ec, - 0x0000, 0x01f0, 0x0000, 0x01f2, 0x0000, 0x01f4, 0x0000, 0x01f6, - 0x0000, 0x0000, 0x01f9, 0x0000, 0x01fb, 0x01fb, 0x0000, 0x01fe, - // Entry 200 - 23F - 0x0000, 0x0200, 0x0200, 0x0000, 0x0203, 0x0203, 0x0000, 0x0206, - 0x0206, 0x0206, 0x0206, 0x0206, 0x0206, 0x0206, 0x0000, 0x020e, - 0x0000, 0x0210, 0x0000, 0x0212, 0x0000, 0x0000, 0x0000, 0x0000, - 0x0000, 0x0218, 0x0000, 0x0000, 0x021b, 0x0000, 0x021d, 0x021d, - 0x0000, 0x0220, 0x0000, 0x0222, 0x0222, 0x0000, 0x0000, 0x0226, - 0x0225, 0x0225, 0x0000, 0x0000, 0x022b, 0x0000, 0x022d, 0x0000, - 0x022f, 0x0000, 0x023b, 0x0231, 0x023b, 0x023b, 0x023b, 0x023b, - 0x023b, 0x023b, 0x023b, 0x0231, 0x023b, 0x023b, 0x0000, 0x023e, - // Entry 240 - 27F - 0x023e, 0x023e, 0x0000, 0x0242, 0x0000, 0x0244, 0x0000, 0x0246, - 0x0246, 0x0000, 0x0249, 0x0000, 0x024b, 0x024b, 0x024b, 0x024b, - 0x024b, 0x024b, 0x0000, 0x0252, 0x0000, 0x0254, 0x0000, 0x0256, - 0x0000, 0x0258, 0x0000, 0x025a, 0x0000, 0x0000, 0x025d, 0x025d, - 0x025d, 0x0000, 0x0261, 0x0000, 0x0263, 0x0000, 0x0265, 0x0000, - 0x0000, 0x0268, 0x0267, 0x0267, 0x0000, 0x026c, 0x0000, 0x026e, - 0x0000, 0x0270, 0x0000, 0x0000, 0x0000, 0x0000, 0x0275, 0x0000, - 0x0000, 0x0278, 0x0000, 0x027a, 0x027a, 0x027a, 0x027a, 0x0000, - // Entry 280 - 2BF - 0x027f, 0x027f, 0x027f, 0x0000, 0x0283, 0x0283, 0x0283, 0x0283, - 0x0283, 0x0000, 0x0289, 0x0289, 0x0289, 0x0289, 0x0000, 0x0000, - 0x0000, 0x0000, 0x0291, 0x0291, 0x0291, 0x0000, 0x0295, 0x0295, - 0x0295, 0x0295, 0x0000, 0x0000, 0x029b, 0x029b, 0x029b, 0x029b, - 0x0000, 0x02a0, 0x0000, 0x02a2, 0x02a2, 0x0000, 0x02a5, 0x0000, - 0x02a7, 0x02a7, 0x0000, 0x0000, 0x02ab, 0x0000, 0x0000, 0x02ae, - 0x0000, 0x02b0, 0x02b0, 0x0000, 0x0000, 0x02b4, 0x0000, 0x02b6, - 0x0000, 0x02b8, 0x0000, 0x02ba, 0x0000, 0x02bc, 0x02bc, 0x0000, - // Entry 2C0 - 2FF - 0x0000, 0x02c0, 0x0000, 0x02c2, 0x02bf, 0x02bf, 0x0000, 0x0000, - 0x02c7, 0x02c6, 0x02c6, 0x0000, 0x0000, 0x02cc, 0x0000, 0x02ce, - 0x0000, 0x02d0, 0x0000, 0x0000, 0x02d3, 0x0000, 0x0000, 0x0000, - 0x02d7, 0x0000, 0x02d9, 0x0000, 0x02db, 0x0000, 0x02dd, 0x02dd, - 0x0000, 0x02e0, 0x0000, 0x02e2, 0x0000, 0x02e4, 0x02e4, 0x02e4, - 0x02e4, 0x02e4, 0x0000, 0x02ea, 0x02eb, 0x02ea, 0x0000, 0x02ee, -} // Size: 1528 bytes - -// Total table size 1528 bytes (1KiB); checksum: B99CF952 diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/internal/tag/tag.go b/vendor/golang.org/x/text/internal/tag/tag.go similarity index 100% rename from vendor/k8s.io/kubernetes/vendor/golang.org/x/text/internal/tag/tag.go rename to vendor/golang.org/x/text/internal/tag/tag.go diff --git a/vendor/golang.org/x/text/language/index.go b/vendor/golang.org/x/text/language/index.go index 50c7521..7fa9cc8 100644 --- a/vendor/golang.org/x/text/language/index.go +++ b/vendor/golang.org/x/text/language/index.go @@ -4,764 +4,759 @@ package language // NumCompactTags is the number of common tags. The maximum tag is // NumCompactTags-1. -const NumCompactTags = 752 +const NumCompactTags = 747 var specialTags = []Tag{ // 2 elements - 0: {lang: 0xd5, region: 0x6d, script: 0x0, pVariant: 0x5, pExt: 0xe, str: "ca-ES-valencia"}, - 1: {lang: 0x134, region: 0x134, script: 0x0, pVariant: 0x5, pExt: 0x5, str: "en-US-u-va-posix"}, + 0: {lang: 0x61, region: 0x6d, script: 0x0, pVariant: 0x5, pExt: 0xe, str: "ca-ES-valencia"}, + 1: {lang: 0x9b, region: 0x132, script: 0x0, pVariant: 0x5, pExt: 0x5, str: "en-US-u-va-posix"}, } // Size: 72 bytes var coreTags = map[uint32]uint16{ 0x0: 0, // und - 0x01500000: 3, // af - 0x015000d1: 4, // af-NA - 0x01500160: 5, // af-ZA - 0x01b00000: 6, // agq - 0x01b00051: 7, // agq-CM - 0x02000000: 8, // ak - 0x0200007f: 9, // ak-GH - 0x02600000: 10, // am - 0x0260006e: 11, // am-ET - 0x03900000: 12, // ar - 0x03900001: 13, // ar-001 - 0x03900022: 14, // ar-AE - 0x03900038: 15, // ar-BH - 0x03900061: 16, // ar-DJ - 0x03900066: 17, // ar-DZ - 0x0390006a: 18, // ar-EG - 0x0390006b: 19, // ar-EH - 0x0390006c: 20, // ar-ER - 0x03900096: 21, // ar-IL - 0x0390009a: 22, // ar-IQ - 0x039000a0: 23, // ar-JO - 0x039000a7: 24, // ar-KM - 0x039000ab: 25, // ar-KW - 0x039000af: 26, // ar-LB - 0x039000b8: 27, // ar-LY - 0x039000b9: 28, // ar-MA - 0x039000c8: 29, // ar-MR - 0x039000e0: 30, // ar-OM - 0x039000ec: 31, // ar-PS - 0x039000f2: 32, // ar-QA - 0x03900107: 33, // ar-SA - 0x0390010a: 34, // ar-SD - 0x03900114: 35, // ar-SO - 0x03900116: 36, // ar-SS - 0x0390011b: 37, // ar-SY - 0x0390011f: 38, // ar-TD - 0x03900127: 39, // ar-TN - 0x0390015d: 40, // ar-YE - 0x03f00000: 41, // ars - 0x04200000: 42, // as - 0x04200098: 43, // as-IN - 0x04300000: 44, // asa - 0x0430012e: 45, // asa-TZ - 0x04700000: 46, // ast - 0x0470006d: 47, // ast-ES - 0x05700000: 48, // az - 0x0571e000: 49, // az-Cyrl - 0x0571e031: 50, // az-Cyrl-AZ - 0x05752000: 51, // az-Latn - 0x05752031: 52, // az-Latn-AZ - 0x05d00000: 53, // bas - 0x05d00051: 54, // bas-CM - 0x07000000: 55, // be - 0x07000046: 56, // be-BY - 0x07400000: 57, // bem - 0x07400161: 58, // bem-ZM - 0x07800000: 59, // bez - 0x0780012e: 60, // bez-TZ - 0x07d00000: 61, // bg - 0x07d00037: 62, // bg-BG - 0x08100000: 63, // bh - 0x09e00000: 64, // bm - 0x09e000c2: 65, // bm-ML - 0x0a300000: 66, // bn - 0x0a300034: 67, // bn-BD - 0x0a300098: 68, // bn-IN - 0x0a700000: 69, // bo - 0x0a700052: 70, // bo-CN - 0x0a700098: 71, // bo-IN - 0x0b000000: 72, // br - 0x0b000077: 73, // br-FR - 0x0b300000: 74, // brx - 0x0b300098: 75, // brx-IN - 0x0b500000: 76, // bs - 0x0b51e000: 77, // bs-Cyrl - 0x0b51e032: 78, // bs-Cyrl-BA - 0x0b552000: 79, // bs-Latn - 0x0b552032: 80, // bs-Latn-BA - 0x0d500000: 81, // ca - 0x0d500021: 82, // ca-AD - 0x0d50006d: 83, // ca-ES - 0x0d500077: 84, // ca-FR - 0x0d50009d: 85, // ca-IT - 0x0da00000: 86, // ce - 0x0da00105: 87, // ce-RU - 0x0dd00000: 88, // cgg - 0x0dd00130: 89, // cgg-UG - 0x0e300000: 90, // chr - 0x0e300134: 91, // chr-US - 0x0e700000: 92, // ckb - 0x0e70009a: 93, // ckb-IQ - 0x0e70009b: 94, // ckb-IR - 0x0f600000: 95, // cs - 0x0f60005d: 96, // cs-CZ - 0x0fa00000: 97, // cu - 0x0fa00105: 98, // cu-RU - 0x0fc00000: 99, // cy - 0x0fc0007a: 100, // cy-GB - 0x0fd00000: 101, // da - 0x0fd00062: 102, // da-DK - 0x0fd00081: 103, // da-GL - 0x10400000: 104, // dav - 0x104000a3: 105, // dav-KE - 0x10900000: 106, // de - 0x1090002d: 107, // de-AT - 0x10900035: 108, // de-BE - 0x1090004d: 109, // de-CH - 0x1090005f: 110, // de-DE - 0x1090009d: 111, // de-IT - 0x109000b1: 112, // de-LI - 0x109000b6: 113, // de-LU - 0x11300000: 114, // dje - 0x113000d3: 115, // dje-NE - 0x11b00000: 116, // dsb - 0x11b0005f: 117, // dsb-DE - 0x12000000: 118, // dua - 0x12000051: 119, // dua-CM - 0x12400000: 120, // dv - 0x12700000: 121, // dyo - 0x12700113: 122, // dyo-SN - 0x12900000: 123, // dz - 0x12900042: 124, // dz-BT - 0x12b00000: 125, // ebu - 0x12b000a3: 126, // ebu-KE - 0x12c00000: 127, // ee - 0x12c0007f: 128, // ee-GH - 0x12c00121: 129, // ee-TG - 0x13100000: 130, // el - 0x1310005c: 131, // el-CY - 0x13100086: 132, // el-GR - 0x13400000: 133, // en - 0x13400001: 134, // en-001 - 0x1340001a: 135, // en-150 - 0x13400024: 136, // en-AG - 0x13400025: 137, // en-AI - 0x1340002c: 138, // en-AS - 0x1340002d: 139, // en-AT - 0x1340002e: 140, // en-AU - 0x13400033: 141, // en-BB - 0x13400035: 142, // en-BE - 0x13400039: 143, // en-BI - 0x1340003c: 144, // en-BM - 0x13400041: 145, // en-BS - 0x13400045: 146, // en-BW - 0x13400047: 147, // en-BZ - 0x13400048: 148, // en-CA - 0x13400049: 149, // en-CC - 0x1340004d: 150, // en-CH - 0x1340004f: 151, // en-CK - 0x13400051: 152, // en-CM - 0x1340005b: 153, // en-CX - 0x1340005c: 154, // en-CY - 0x1340005f: 155, // en-DE - 0x13400060: 156, // en-DG - 0x13400062: 157, // en-DK - 0x13400063: 158, // en-DM - 0x1340006c: 159, // en-ER - 0x13400071: 160, // en-FI - 0x13400072: 161, // en-FJ - 0x13400073: 162, // en-FK - 0x13400074: 163, // en-FM - 0x1340007a: 164, // en-GB - 0x1340007b: 165, // en-GD - 0x1340007e: 166, // en-GG - 0x1340007f: 167, // en-GH - 0x13400080: 168, // en-GI - 0x13400082: 169, // en-GM - 0x13400089: 170, // en-GU - 0x1340008b: 171, // en-GY - 0x1340008c: 172, // en-HK - 0x13400095: 173, // en-IE - 0x13400096: 174, // en-IL - 0x13400097: 175, // en-IM - 0x13400098: 176, // en-IN - 0x13400099: 177, // en-IO - 0x1340009e: 178, // en-JE - 0x1340009f: 179, // en-JM - 0x134000a3: 180, // en-KE - 0x134000a6: 181, // en-KI - 0x134000a8: 182, // en-KN - 0x134000ac: 183, // en-KY - 0x134000b0: 184, // en-LC - 0x134000b3: 185, // en-LR - 0x134000b4: 186, // en-LS - 0x134000be: 187, // en-MG - 0x134000bf: 188, // en-MH - 0x134000c5: 189, // en-MO - 0x134000c6: 190, // en-MP - 0x134000c9: 191, // en-MS - 0x134000ca: 192, // en-MT - 0x134000cb: 193, // en-MU - 0x134000cd: 194, // en-MW - 0x134000cf: 195, // en-MY - 0x134000d1: 196, // en-NA - 0x134000d4: 197, // en-NF - 0x134000d5: 198, // en-NG - 0x134000d8: 199, // en-NL - 0x134000dc: 200, // en-NR - 0x134000de: 201, // en-NU - 0x134000df: 202, // en-NZ - 0x134000e5: 203, // en-PG - 0x134000e6: 204, // en-PH - 0x134000e7: 205, // en-PK - 0x134000ea: 206, // en-PN - 0x134000eb: 207, // en-PR - 0x134000ef: 208, // en-PW - 0x13400106: 209, // en-RW - 0x13400108: 210, // en-SB - 0x13400109: 211, // en-SC - 0x1340010a: 212, // en-SD - 0x1340010b: 213, // en-SE - 0x1340010c: 214, // en-SG - 0x1340010d: 215, // en-SH - 0x1340010e: 216, // en-SI - 0x13400111: 217, // en-SL - 0x13400116: 218, // en-SS - 0x1340011a: 219, // en-SX - 0x1340011c: 220, // en-SZ - 0x1340011e: 221, // en-TC - 0x13400124: 222, // en-TK - 0x13400128: 223, // en-TO - 0x1340012b: 224, // en-TT - 0x1340012c: 225, // en-TV - 0x1340012e: 226, // en-TZ - 0x13400130: 227, // en-UG - 0x13400132: 228, // en-UM - 0x13400134: 229, // en-US - 0x13400138: 230, // en-VC - 0x1340013b: 231, // en-VG - 0x1340013c: 232, // en-VI - 0x1340013e: 233, // en-VU - 0x13400141: 234, // en-WS - 0x13400160: 235, // en-ZA - 0x13400161: 236, // en-ZM - 0x13400163: 237, // en-ZW - 0x13700000: 238, // eo - 0x13700001: 239, // eo-001 - 0x13900000: 240, // es - 0x1390001e: 241, // es-419 - 0x1390002b: 242, // es-AR - 0x1390003e: 243, // es-BO - 0x13900040: 244, // es-BR - 0x13900050: 245, // es-CL - 0x13900053: 246, // es-CO - 0x13900055: 247, // es-CR - 0x13900058: 248, // es-CU - 0x13900064: 249, // es-DO - 0x13900067: 250, // es-EA - 0x13900068: 251, // es-EC - 0x1390006d: 252, // es-ES - 0x13900085: 253, // es-GQ - 0x13900088: 254, // es-GT - 0x1390008e: 255, // es-HN - 0x13900093: 256, // es-IC - 0x139000ce: 257, // es-MX - 0x139000d7: 258, // es-NI - 0x139000e1: 259, // es-PA - 0x139000e3: 260, // es-PE - 0x139000e6: 261, // es-PH - 0x139000eb: 262, // es-PR - 0x139000f0: 263, // es-PY - 0x13900119: 264, // es-SV - 0x13900134: 265, // es-US - 0x13900135: 266, // es-UY - 0x1390013a: 267, // es-VE - 0x13b00000: 268, // et - 0x13b00069: 269, // et-EE - 0x14000000: 270, // eu - 0x1400006d: 271, // eu-ES - 0x14100000: 272, // ewo - 0x14100051: 273, // ewo-CM - 0x14300000: 274, // fa - 0x14300023: 275, // fa-AF - 0x1430009b: 276, // fa-IR - 0x14900000: 277, // ff - 0x14900051: 278, // ff-CM - 0x14900083: 279, // ff-GN - 0x149000c8: 280, // ff-MR - 0x14900113: 281, // ff-SN - 0x14c00000: 282, // fi - 0x14c00071: 283, // fi-FI - 0x14e00000: 284, // fil - 0x14e000e6: 285, // fil-PH - 0x15300000: 286, // fo - 0x15300062: 287, // fo-DK - 0x15300075: 288, // fo-FO - 0x15900000: 289, // fr - 0x15900035: 290, // fr-BE - 0x15900036: 291, // fr-BF - 0x15900039: 292, // fr-BI - 0x1590003a: 293, // fr-BJ - 0x1590003b: 294, // fr-BL - 0x15900048: 295, // fr-CA - 0x1590004a: 296, // fr-CD - 0x1590004b: 297, // fr-CF - 0x1590004c: 298, // fr-CG - 0x1590004d: 299, // fr-CH - 0x1590004e: 300, // fr-CI - 0x15900051: 301, // fr-CM - 0x15900061: 302, // fr-DJ - 0x15900066: 303, // fr-DZ - 0x15900077: 304, // fr-FR - 0x15900079: 305, // fr-GA - 0x1590007d: 306, // fr-GF - 0x15900083: 307, // fr-GN - 0x15900084: 308, // fr-GP - 0x15900085: 309, // fr-GQ - 0x15900090: 310, // fr-HT - 0x159000a7: 311, // fr-KM - 0x159000b6: 312, // fr-LU - 0x159000b9: 313, // fr-MA - 0x159000ba: 314, // fr-MC - 0x159000bd: 315, // fr-MF - 0x159000be: 316, // fr-MG - 0x159000c2: 317, // fr-ML - 0x159000c7: 318, // fr-MQ - 0x159000c8: 319, // fr-MR - 0x159000cb: 320, // fr-MU - 0x159000d2: 321, // fr-NC - 0x159000d3: 322, // fr-NE - 0x159000e4: 323, // fr-PF - 0x159000e9: 324, // fr-PM - 0x15900101: 325, // fr-RE - 0x15900106: 326, // fr-RW - 0x15900109: 327, // fr-SC - 0x15900113: 328, // fr-SN - 0x1590011b: 329, // fr-SY - 0x1590011f: 330, // fr-TD - 0x15900121: 331, // fr-TG - 0x15900127: 332, // fr-TN - 0x1590013e: 333, // fr-VU - 0x1590013f: 334, // fr-WF - 0x1590015e: 335, // fr-YT - 0x16400000: 336, // fur - 0x1640009d: 337, // fur-IT - 0x16800000: 338, // fy - 0x168000d8: 339, // fy-NL - 0x16900000: 340, // ga - 0x16900095: 341, // ga-IE - 0x17800000: 342, // gd - 0x1780007a: 343, // gd-GB - 0x18a00000: 344, // gl - 0x18a0006d: 345, // gl-ES - 0x19c00000: 346, // gsw - 0x19c0004d: 347, // gsw-CH - 0x19c00077: 348, // gsw-FR - 0x19c000b1: 349, // gsw-LI - 0x19d00000: 350, // gu - 0x19d00098: 351, // gu-IN - 0x1a200000: 352, // guw - 0x1a400000: 353, // guz - 0x1a4000a3: 354, // guz-KE - 0x1a500000: 355, // gv - 0x1a500097: 356, // gv-IM - 0x1ad00000: 357, // ha - 0x1ad0007f: 358, // ha-GH - 0x1ad000d3: 359, // ha-NE - 0x1ad000d5: 360, // ha-NG - 0x1b100000: 361, // haw - 0x1b100134: 362, // haw-US - 0x1b500000: 363, // he - 0x1b500096: 364, // he-IL - 0x1b700000: 365, // hi - 0x1b700098: 366, // hi-IN - 0x1ca00000: 367, // hr - 0x1ca00032: 368, // hr-BA - 0x1ca0008f: 369, // hr-HR - 0x1cb00000: 370, // hsb - 0x1cb0005f: 371, // hsb-DE - 0x1ce00000: 372, // hu - 0x1ce00091: 373, // hu-HU - 0x1d000000: 374, // hy - 0x1d000027: 375, // hy-AM - 0x1da00000: 376, // id - 0x1da00094: 377, // id-ID - 0x1df00000: 378, // ig - 0x1df000d5: 379, // ig-NG - 0x1e200000: 380, // ii - 0x1e200052: 381, // ii-CN - 0x1f000000: 382, // is - 0x1f00009c: 383, // is-IS - 0x1f100000: 384, // it - 0x1f10004d: 385, // it-CH - 0x1f10009d: 386, // it-IT - 0x1f100112: 387, // it-SM - 0x1f200000: 388, // iu - 0x1f800000: 389, // ja - 0x1f8000a1: 390, // ja-JP - 0x1fb00000: 391, // jbo - 0x1ff00000: 392, // jgo - 0x1ff00051: 393, // jgo-CM - 0x20200000: 394, // jmc - 0x2020012e: 395, // jmc-TZ - 0x20600000: 396, // jv - 0x20800000: 397, // ka - 0x2080007c: 398, // ka-GE - 0x20a00000: 399, // kab - 0x20a00066: 400, // kab-DZ - 0x20e00000: 401, // kaj - 0x20f00000: 402, // kam - 0x20f000a3: 403, // kam-KE - 0x21700000: 404, // kcg - 0x21b00000: 405, // kde - 0x21b0012e: 406, // kde-TZ - 0x21f00000: 407, // kea - 0x21f00059: 408, // kea-CV - 0x22c00000: 409, // khq - 0x22c000c2: 410, // khq-ML - 0x23100000: 411, // ki - 0x231000a3: 412, // ki-KE - 0x23a00000: 413, // kk - 0x23a000ad: 414, // kk-KZ - 0x23c00000: 415, // kkj - 0x23c00051: 416, // kkj-CM - 0x23d00000: 417, // kl - 0x23d00081: 418, // kl-GL - 0x23e00000: 419, // kln - 0x23e000a3: 420, // kln-KE - 0x24200000: 421, // km - 0x242000a5: 422, // km-KH - 0x24900000: 423, // kn - 0x24900098: 424, // kn-IN - 0x24b00000: 425, // ko - 0x24b000a9: 426, // ko-KP - 0x24b000aa: 427, // ko-KR - 0x24d00000: 428, // kok - 0x24d00098: 429, // kok-IN - 0x26100000: 430, // ks - 0x26100098: 431, // ks-IN - 0x26200000: 432, // ksb - 0x2620012e: 433, // ksb-TZ - 0x26400000: 434, // ksf - 0x26400051: 435, // ksf-CM - 0x26500000: 436, // ksh - 0x2650005f: 437, // ksh-DE - 0x26b00000: 438, // ku - 0x27800000: 439, // kw - 0x2780007a: 440, // kw-GB - 0x28100000: 441, // ky - 0x281000a4: 442, // ky-KG - 0x28800000: 443, // lag - 0x2880012e: 444, // lag-TZ - 0x28c00000: 445, // lb - 0x28c000b6: 446, // lb-LU - 0x29a00000: 447, // lg - 0x29a00130: 448, // lg-UG - 0x2a600000: 449, // lkt - 0x2a600134: 450, // lkt-US - 0x2ac00000: 451, // ln - 0x2ac00029: 452, // ln-AO - 0x2ac0004a: 453, // ln-CD - 0x2ac0004b: 454, // ln-CF - 0x2ac0004c: 455, // ln-CG - 0x2af00000: 456, // lo - 0x2af000ae: 457, // lo-LA - 0x2b600000: 458, // lrc - 0x2b60009a: 459, // lrc-IQ - 0x2b60009b: 460, // lrc-IR - 0x2b700000: 461, // lt - 0x2b7000b5: 462, // lt-LT - 0x2b900000: 463, // lu - 0x2b90004a: 464, // lu-CD - 0x2bb00000: 465, // luo - 0x2bb000a3: 466, // luo-KE - 0x2bc00000: 467, // luy - 0x2bc000a3: 468, // luy-KE - 0x2be00000: 469, // lv - 0x2be000b7: 470, // lv-LV - 0x2c800000: 471, // mas - 0x2c8000a3: 472, // mas-KE - 0x2c80012e: 473, // mas-TZ - 0x2e000000: 474, // mer - 0x2e0000a3: 475, // mer-KE - 0x2e400000: 476, // mfe - 0x2e4000cb: 477, // mfe-MU - 0x2e800000: 478, // mg - 0x2e8000be: 479, // mg-MG - 0x2e900000: 480, // mgh - 0x2e9000d0: 481, // mgh-MZ - 0x2eb00000: 482, // mgo - 0x2eb00051: 483, // mgo-CM - 0x2f600000: 484, // mk - 0x2f6000c1: 485, // mk-MK - 0x2fb00000: 486, // ml - 0x2fb00098: 487, // ml-IN - 0x30200000: 488, // mn - 0x302000c4: 489, // mn-MN - 0x31200000: 490, // mr - 0x31200098: 491, // mr-IN - 0x31600000: 492, // ms - 0x3160003d: 493, // ms-BN - 0x316000cf: 494, // ms-MY - 0x3160010c: 495, // ms-SG - 0x31700000: 496, // mt - 0x317000ca: 497, // mt-MT - 0x31c00000: 498, // mua - 0x31c00051: 499, // mua-CM - 0x32800000: 500, // my - 0x328000c3: 501, // my-MM - 0x33100000: 502, // mzn - 0x3310009b: 503, // mzn-IR - 0x33800000: 504, // nah - 0x33c00000: 505, // naq - 0x33c000d1: 506, // naq-NA - 0x33e00000: 507, // nb - 0x33e000d9: 508, // nb-NO - 0x33e0010f: 509, // nb-SJ - 0x34500000: 510, // nd - 0x34500163: 511, // nd-ZW - 0x34700000: 512, // nds - 0x3470005f: 513, // nds-DE - 0x347000d8: 514, // nds-NL - 0x34800000: 515, // ne - 0x34800098: 516, // ne-IN - 0x348000da: 517, // ne-NP - 0x35e00000: 518, // nl - 0x35e0002f: 519, // nl-AW - 0x35e00035: 520, // nl-BE - 0x35e0003f: 521, // nl-BQ - 0x35e0005a: 522, // nl-CW - 0x35e000d8: 523, // nl-NL - 0x35e00115: 524, // nl-SR - 0x35e0011a: 525, // nl-SX - 0x35f00000: 526, // nmg - 0x35f00051: 527, // nmg-CM - 0x36100000: 528, // nn - 0x361000d9: 529, // nn-NO - 0x36300000: 530, // nnh - 0x36300051: 531, // nnh-CM - 0x36600000: 532, // no - 0x36c00000: 533, // nqo - 0x36d00000: 534, // nr - 0x37100000: 535, // nso - 0x37700000: 536, // nus - 0x37700116: 537, // nus-SS - 0x37e00000: 538, // ny - 0x38000000: 539, // nyn - 0x38000130: 540, // nyn-UG - 0x38700000: 541, // om - 0x3870006e: 542, // om-ET - 0x387000a3: 543, // om-KE - 0x38c00000: 544, // or - 0x38c00098: 545, // or-IN - 0x38f00000: 546, // os - 0x38f0007c: 547, // os-GE - 0x38f00105: 548, // os-RU - 0x39400000: 549, // pa - 0x39405000: 550, // pa-Arab - 0x394050e7: 551, // pa-Arab-PK - 0x3942f000: 552, // pa-Guru - 0x3942f098: 553, // pa-Guru-IN - 0x39800000: 554, // pap - 0x3aa00000: 555, // pl - 0x3aa000e8: 556, // pl-PL - 0x3b400000: 557, // prg - 0x3b400001: 558, // prg-001 - 0x3b500000: 559, // ps - 0x3b500023: 560, // ps-AF - 0x3b700000: 561, // pt - 0x3b700029: 562, // pt-AO - 0x3b700040: 563, // pt-BR - 0x3b70004d: 564, // pt-CH - 0x3b700059: 565, // pt-CV - 0x3b700085: 566, // pt-GQ - 0x3b70008a: 567, // pt-GW - 0x3b7000b6: 568, // pt-LU - 0x3b7000c5: 569, // pt-MO - 0x3b7000d0: 570, // pt-MZ - 0x3b7000ed: 571, // pt-PT - 0x3b700117: 572, // pt-ST - 0x3b700125: 573, // pt-TL - 0x3bb00000: 574, // qu - 0x3bb0003e: 575, // qu-BO - 0x3bb00068: 576, // qu-EC - 0x3bb000e3: 577, // qu-PE - 0x3cb00000: 578, // rm - 0x3cb0004d: 579, // rm-CH - 0x3d000000: 580, // rn - 0x3d000039: 581, // rn-BI - 0x3d300000: 582, // ro - 0x3d3000bb: 583, // ro-MD - 0x3d300103: 584, // ro-RO - 0x3d500000: 585, // rof - 0x3d50012e: 586, // rof-TZ - 0x3d900000: 587, // ru - 0x3d900046: 588, // ru-BY - 0x3d9000a4: 589, // ru-KG - 0x3d9000ad: 590, // ru-KZ - 0x3d9000bb: 591, // ru-MD - 0x3d900105: 592, // ru-RU - 0x3d90012f: 593, // ru-UA - 0x3dc00000: 594, // rw - 0x3dc00106: 595, // rw-RW - 0x3dd00000: 596, // rwk - 0x3dd0012e: 597, // rwk-TZ - 0x3e200000: 598, // sah - 0x3e200105: 599, // sah-RU - 0x3e300000: 600, // saq - 0x3e3000a3: 601, // saq-KE - 0x3e900000: 602, // sbp - 0x3e90012e: 603, // sbp-TZ - 0x3f200000: 604, // sdh - 0x3f300000: 605, // se - 0x3f300071: 606, // se-FI - 0x3f3000d9: 607, // se-NO - 0x3f30010b: 608, // se-SE - 0x3f500000: 609, // seh - 0x3f5000d0: 610, // seh-MZ - 0x3f700000: 611, // ses - 0x3f7000c2: 612, // ses-ML - 0x3f800000: 613, // sg - 0x3f80004b: 614, // sg-CF - 0x3fe00000: 615, // shi - 0x3fe52000: 616, // shi-Latn - 0x3fe520b9: 617, // shi-Latn-MA - 0x3fed2000: 618, // shi-Tfng - 0x3fed20b9: 619, // shi-Tfng-MA - 0x40200000: 620, // si - 0x402000b2: 621, // si-LK - 0x40800000: 622, // sk - 0x40800110: 623, // sk-SK - 0x40c00000: 624, // sl - 0x40c0010e: 625, // sl-SI - 0x41200000: 626, // sma - 0x41300000: 627, // smi - 0x41400000: 628, // smj - 0x41500000: 629, // smn - 0x41500071: 630, // smn-FI - 0x41800000: 631, // sms - 0x41900000: 632, // sn - 0x41900163: 633, // sn-ZW - 0x41f00000: 634, // so - 0x41f00061: 635, // so-DJ - 0x41f0006e: 636, // so-ET - 0x41f000a3: 637, // so-KE - 0x41f00114: 638, // so-SO - 0x42700000: 639, // sq - 0x42700026: 640, // sq-AL - 0x427000c1: 641, // sq-MK - 0x4270014c: 642, // sq-XK - 0x42800000: 643, // sr - 0x4281e000: 644, // sr-Cyrl - 0x4281e032: 645, // sr-Cyrl-BA - 0x4281e0bc: 646, // sr-Cyrl-ME - 0x4281e104: 647, // sr-Cyrl-RS - 0x4281e14c: 648, // sr-Cyrl-XK - 0x42852000: 649, // sr-Latn - 0x42852032: 650, // sr-Latn-BA - 0x428520bc: 651, // sr-Latn-ME - 0x42852104: 652, // sr-Latn-RS - 0x4285214c: 653, // sr-Latn-XK - 0x42d00000: 654, // ss - 0x43000000: 655, // ssy - 0x43100000: 656, // st - 0x43a00000: 657, // sv - 0x43a00030: 658, // sv-AX - 0x43a00071: 659, // sv-FI - 0x43a0010b: 660, // sv-SE - 0x43b00000: 661, // sw - 0x43b0004a: 662, // sw-CD - 0x43b000a3: 663, // sw-KE - 0x43b0012e: 664, // sw-TZ - 0x43b00130: 665, // sw-UG - 0x44400000: 666, // syr - 0x44600000: 667, // ta - 0x44600098: 668, // ta-IN - 0x446000b2: 669, // ta-LK - 0x446000cf: 670, // ta-MY - 0x4460010c: 671, // ta-SG - 0x45700000: 672, // te - 0x45700098: 673, // te-IN - 0x45a00000: 674, // teo - 0x45a000a3: 675, // teo-KE - 0x45a00130: 676, // teo-UG - 0x46100000: 677, // th - 0x46100122: 678, // th-TH - 0x46500000: 679, // ti - 0x4650006c: 680, // ti-ER - 0x4650006e: 681, // ti-ET - 0x46700000: 682, // tig - 0x46c00000: 683, // tk - 0x46c00126: 684, // tk-TM - 0x47600000: 685, // tn - 0x47800000: 686, // to - 0x47800128: 687, // to-TO - 0x48000000: 688, // tr - 0x4800005c: 689, // tr-CY - 0x4800012a: 690, // tr-TR - 0x48400000: 691, // ts - 0x49a00000: 692, // twq - 0x49a000d3: 693, // twq-NE - 0x49f00000: 694, // tzm - 0x49f000b9: 695, // tzm-MA - 0x4a200000: 696, // ug - 0x4a200052: 697, // ug-CN - 0x4a400000: 698, // uk - 0x4a40012f: 699, // uk-UA - 0x4aa00000: 700, // ur - 0x4aa00098: 701, // ur-IN - 0x4aa000e7: 702, // ur-PK - 0x4b200000: 703, // uz - 0x4b205000: 704, // uz-Arab - 0x4b205023: 705, // uz-Arab-AF - 0x4b21e000: 706, // uz-Cyrl - 0x4b21e136: 707, // uz-Cyrl-UZ - 0x4b252000: 708, // uz-Latn - 0x4b252136: 709, // uz-Latn-UZ - 0x4b400000: 710, // vai - 0x4b452000: 711, // vai-Latn - 0x4b4520b3: 712, // vai-Latn-LR - 0x4b4d9000: 713, // vai-Vaii - 0x4b4d90b3: 714, // vai-Vaii-LR - 0x4b600000: 715, // ve - 0x4b900000: 716, // vi - 0x4b90013d: 717, // vi-VN - 0x4bf00000: 718, // vo - 0x4bf00001: 719, // vo-001 - 0x4c200000: 720, // vun - 0x4c20012e: 721, // vun-TZ - 0x4c400000: 722, // wa - 0x4c500000: 723, // wae - 0x4c50004d: 724, // wae-CH - 0x4db00000: 725, // wo - 0x4e800000: 726, // xh - 0x4f100000: 727, // xog - 0x4f100130: 728, // xog-UG - 0x4ff00000: 729, // yav - 0x4ff00051: 730, // yav-CM - 0x50800000: 731, // yi - 0x50800001: 732, // yi-001 - 0x50e00000: 733, // yo - 0x50e0003a: 734, // yo-BJ - 0x50e000d5: 735, // yo-NG - 0x51500000: 736, // yue - 0x5150008c: 737, // yue-HK - 0x51e00000: 738, // zgh - 0x51e000b9: 739, // zgh-MA - 0x51f00000: 740, // zh - 0x51f34000: 741, // zh-Hans - 0x51f34052: 742, // zh-Hans-CN - 0x51f3408c: 743, // zh-Hans-HK - 0x51f340c5: 744, // zh-Hans-MO - 0x51f3410c: 745, // zh-Hans-SG - 0x51f35000: 746, // zh-Hant - 0x51f3508c: 747, // zh-Hant-HK - 0x51f350c5: 748, // zh-Hant-MO - 0x51f3512d: 749, // zh-Hant-TW - 0x52400000: 750, // zu - 0x52400160: 751, // zu-ZA + 0x00a00000: 3, // af + 0x00a000d0: 4, // af-NA + 0x00a0015e: 5, // af-ZA + 0x00b00000: 6, // agq + 0x00b00051: 7, // agq-CM + 0x00d00000: 8, // ak + 0x00d0007e: 9, // ak-GH + 0x01100000: 10, // am + 0x0110006e: 11, // am-ET + 0x01500000: 12, // ar + 0x01500001: 13, // ar-001 + 0x01500022: 14, // ar-AE + 0x01500038: 15, // ar-BH + 0x01500061: 16, // ar-DJ + 0x01500066: 17, // ar-DZ + 0x0150006a: 18, // ar-EG + 0x0150006b: 19, // ar-EH + 0x0150006c: 20, // ar-ER + 0x01500095: 21, // ar-IL + 0x01500099: 22, // ar-IQ + 0x0150009f: 23, // ar-JO + 0x015000a6: 24, // ar-KM + 0x015000aa: 25, // ar-KW + 0x015000ae: 26, // ar-LB + 0x015000b7: 27, // ar-LY + 0x015000b8: 28, // ar-MA + 0x015000c7: 29, // ar-MR + 0x015000df: 30, // ar-OM + 0x015000eb: 31, // ar-PS + 0x015000f1: 32, // ar-QA + 0x01500106: 33, // ar-SA + 0x01500109: 34, // ar-SD + 0x01500113: 35, // ar-SO + 0x01500115: 36, // ar-SS + 0x0150011a: 37, // ar-SY + 0x0150011e: 38, // ar-TD + 0x01500126: 39, // ar-TN + 0x0150015b: 40, // ar-YE + 0x01c00000: 41, // as + 0x01c00097: 42, // as-IN + 0x01d00000: 43, // asa + 0x01d0012d: 44, // asa-TZ + 0x01f00000: 45, // ast + 0x01f0006d: 46, // ast-ES + 0x02400000: 47, // az + 0x0241e000: 48, // az-Cyrl + 0x0241e031: 49, // az-Cyrl-AZ + 0x02452000: 50, // az-Latn + 0x02452031: 51, // az-Latn-AZ + 0x02a00000: 52, // bas + 0x02a00051: 53, // bas-CM + 0x02f00000: 54, // be + 0x02f00046: 55, // be-BY + 0x03100000: 56, // bem + 0x0310015f: 57, // bem-ZM + 0x03300000: 58, // bez + 0x0330012d: 59, // bez-TZ + 0x03800000: 60, // bg + 0x03800037: 61, // bg-BG + 0x03c00000: 62, // bh + 0x04900000: 63, // bm + 0x049000c1: 64, // bm-ML + 0x04b00000: 65, // bn + 0x04b00034: 66, // bn-BD + 0x04b00097: 67, // bn-IN + 0x04c00000: 68, // bo + 0x04c00052: 69, // bo-CN + 0x04c00097: 70, // bo-IN + 0x05000000: 71, // br + 0x05000076: 72, // br-FR + 0x05300000: 73, // brx + 0x05300097: 74, // brx-IN + 0x05400000: 75, // bs + 0x0541e000: 76, // bs-Cyrl + 0x0541e032: 77, // bs-Cyrl-BA + 0x05452000: 78, // bs-Latn + 0x05452032: 79, // bs-Latn-BA + 0x06100000: 80, // ca + 0x06100021: 81, // ca-AD + 0x0610006d: 82, // ca-ES + 0x06100076: 83, // ca-FR + 0x0610009c: 84, // ca-IT + 0x06400000: 85, // ce + 0x06400104: 86, // ce-RU + 0x06600000: 87, // cgg + 0x0660012f: 88, // cgg-UG + 0x06c00000: 89, // chr + 0x06c00132: 90, // chr-US + 0x06f00000: 91, // ckb + 0x06f00099: 92, // ckb-IQ + 0x06f0009a: 93, // ckb-IR + 0x07900000: 94, // cs + 0x0790005d: 95, // cs-CZ + 0x07d00000: 96, // cu + 0x07d00104: 97, // cu-RU + 0x07f00000: 98, // cy + 0x07f00079: 99, // cy-GB + 0x08000000: 100, // da + 0x08000062: 101, // da-DK + 0x08000080: 102, // da-GL + 0x08300000: 103, // dav + 0x083000a2: 104, // dav-KE + 0x08500000: 105, // de + 0x0850002d: 106, // de-AT + 0x08500035: 107, // de-BE + 0x0850004d: 108, // de-CH + 0x0850005f: 109, // de-DE + 0x085000b0: 110, // de-LI + 0x085000b5: 111, // de-LU + 0x08800000: 112, // dje + 0x088000d2: 113, // dje-NE + 0x08b00000: 114, // dsb + 0x08b0005f: 115, // dsb-DE + 0x08f00000: 116, // dua + 0x08f00051: 117, // dua-CM + 0x09000000: 118, // dv + 0x09100000: 119, // dyo + 0x09100112: 120, // dyo-SN + 0x09300000: 121, // dz + 0x09300042: 122, // dz-BT + 0x09400000: 123, // ebu + 0x094000a2: 124, // ebu-KE + 0x09500000: 125, // ee + 0x0950007e: 126, // ee-GH + 0x09500120: 127, // ee-TG + 0x09a00000: 128, // el + 0x09a0005c: 129, // el-CY + 0x09a00085: 130, // el-GR + 0x09b00000: 131, // en + 0x09b00001: 132, // en-001 + 0x09b0001a: 133, // en-150 + 0x09b00024: 134, // en-AG + 0x09b00025: 135, // en-AI + 0x09b0002c: 136, // en-AS + 0x09b0002d: 137, // en-AT + 0x09b0002e: 138, // en-AU + 0x09b00033: 139, // en-BB + 0x09b00035: 140, // en-BE + 0x09b00039: 141, // en-BI + 0x09b0003c: 142, // en-BM + 0x09b00041: 143, // en-BS + 0x09b00045: 144, // en-BW + 0x09b00047: 145, // en-BZ + 0x09b00048: 146, // en-CA + 0x09b00049: 147, // en-CC + 0x09b0004d: 148, // en-CH + 0x09b0004f: 149, // en-CK + 0x09b00051: 150, // en-CM + 0x09b0005b: 151, // en-CX + 0x09b0005c: 152, // en-CY + 0x09b0005f: 153, // en-DE + 0x09b00060: 154, // en-DG + 0x09b00062: 155, // en-DK + 0x09b00063: 156, // en-DM + 0x09b0006c: 157, // en-ER + 0x09b00070: 158, // en-FI + 0x09b00071: 159, // en-FJ + 0x09b00072: 160, // en-FK + 0x09b00073: 161, // en-FM + 0x09b00079: 162, // en-GB + 0x09b0007a: 163, // en-GD + 0x09b0007d: 164, // en-GG + 0x09b0007e: 165, // en-GH + 0x09b0007f: 166, // en-GI + 0x09b00081: 167, // en-GM + 0x09b00088: 168, // en-GU + 0x09b0008a: 169, // en-GY + 0x09b0008b: 170, // en-HK + 0x09b00094: 171, // en-IE + 0x09b00095: 172, // en-IL + 0x09b00096: 173, // en-IM + 0x09b00097: 174, // en-IN + 0x09b00098: 175, // en-IO + 0x09b0009d: 176, // en-JE + 0x09b0009e: 177, // en-JM + 0x09b000a2: 178, // en-KE + 0x09b000a5: 179, // en-KI + 0x09b000a7: 180, // en-KN + 0x09b000ab: 181, // en-KY + 0x09b000af: 182, // en-LC + 0x09b000b2: 183, // en-LR + 0x09b000b3: 184, // en-LS + 0x09b000bd: 185, // en-MG + 0x09b000be: 186, // en-MH + 0x09b000c4: 187, // en-MO + 0x09b000c5: 188, // en-MP + 0x09b000c8: 189, // en-MS + 0x09b000c9: 190, // en-MT + 0x09b000ca: 191, // en-MU + 0x09b000cc: 192, // en-MW + 0x09b000ce: 193, // en-MY + 0x09b000d0: 194, // en-NA + 0x09b000d3: 195, // en-NF + 0x09b000d4: 196, // en-NG + 0x09b000d7: 197, // en-NL + 0x09b000db: 198, // en-NR + 0x09b000dd: 199, // en-NU + 0x09b000de: 200, // en-NZ + 0x09b000e4: 201, // en-PG + 0x09b000e5: 202, // en-PH + 0x09b000e6: 203, // en-PK + 0x09b000e9: 204, // en-PN + 0x09b000ea: 205, // en-PR + 0x09b000ee: 206, // en-PW + 0x09b00105: 207, // en-RW + 0x09b00107: 208, // en-SB + 0x09b00108: 209, // en-SC + 0x09b00109: 210, // en-SD + 0x09b0010a: 211, // en-SE + 0x09b0010b: 212, // en-SG + 0x09b0010c: 213, // en-SH + 0x09b0010d: 214, // en-SI + 0x09b00110: 215, // en-SL + 0x09b00115: 216, // en-SS + 0x09b00119: 217, // en-SX + 0x09b0011b: 218, // en-SZ + 0x09b0011d: 219, // en-TC + 0x09b00123: 220, // en-TK + 0x09b00127: 221, // en-TO + 0x09b0012a: 222, // en-TT + 0x09b0012b: 223, // en-TV + 0x09b0012d: 224, // en-TZ + 0x09b0012f: 225, // en-UG + 0x09b00131: 226, // en-UM + 0x09b00132: 227, // en-US + 0x09b00136: 228, // en-VC + 0x09b00139: 229, // en-VG + 0x09b0013a: 230, // en-VI + 0x09b0013c: 231, // en-VU + 0x09b0013f: 232, // en-WS + 0x09b0015e: 233, // en-ZA + 0x09b0015f: 234, // en-ZM + 0x09b00161: 235, // en-ZW + 0x09c00000: 236, // eo + 0x09c00001: 237, // eo-001 + 0x09d00000: 238, // es + 0x09d0001e: 239, // es-419 + 0x09d0002b: 240, // es-AR + 0x09d0003e: 241, // es-BO + 0x09d00040: 242, // es-BR + 0x09d00050: 243, // es-CL + 0x09d00053: 244, // es-CO + 0x09d00055: 245, // es-CR + 0x09d00058: 246, // es-CU + 0x09d00064: 247, // es-DO + 0x09d00067: 248, // es-EA + 0x09d00068: 249, // es-EC + 0x09d0006d: 250, // es-ES + 0x09d00084: 251, // es-GQ + 0x09d00087: 252, // es-GT + 0x09d0008d: 253, // es-HN + 0x09d00092: 254, // es-IC + 0x09d000cd: 255, // es-MX + 0x09d000d6: 256, // es-NI + 0x09d000e0: 257, // es-PA + 0x09d000e2: 258, // es-PE + 0x09d000e5: 259, // es-PH + 0x09d000ea: 260, // es-PR + 0x09d000ef: 261, // es-PY + 0x09d00118: 262, // es-SV + 0x09d00132: 263, // es-US + 0x09d00133: 264, // es-UY + 0x09d00138: 265, // es-VE + 0x09f00000: 266, // et + 0x09f00069: 267, // et-EE + 0x0a100000: 268, // eu + 0x0a10006d: 269, // eu-ES + 0x0a200000: 270, // ewo + 0x0a200051: 271, // ewo-CM + 0x0a400000: 272, // fa + 0x0a400023: 273, // fa-AF + 0x0a40009a: 274, // fa-IR + 0x0a600000: 275, // ff + 0x0a600051: 276, // ff-CM + 0x0a600082: 277, // ff-GN + 0x0a6000c7: 278, // ff-MR + 0x0a600112: 279, // ff-SN + 0x0a800000: 280, // fi + 0x0a800070: 281, // fi-FI + 0x0aa00000: 282, // fil + 0x0aa000e5: 283, // fil-PH + 0x0ad00000: 284, // fo + 0x0ad00062: 285, // fo-DK + 0x0ad00074: 286, // fo-FO + 0x0af00000: 287, // fr + 0x0af00035: 288, // fr-BE + 0x0af00036: 289, // fr-BF + 0x0af00039: 290, // fr-BI + 0x0af0003a: 291, // fr-BJ + 0x0af0003b: 292, // fr-BL + 0x0af00048: 293, // fr-CA + 0x0af0004a: 294, // fr-CD + 0x0af0004b: 295, // fr-CF + 0x0af0004c: 296, // fr-CG + 0x0af0004d: 297, // fr-CH + 0x0af0004e: 298, // fr-CI + 0x0af00051: 299, // fr-CM + 0x0af00061: 300, // fr-DJ + 0x0af00066: 301, // fr-DZ + 0x0af00076: 302, // fr-FR + 0x0af00078: 303, // fr-GA + 0x0af0007c: 304, // fr-GF + 0x0af00082: 305, // fr-GN + 0x0af00083: 306, // fr-GP + 0x0af00084: 307, // fr-GQ + 0x0af0008f: 308, // fr-HT + 0x0af000a6: 309, // fr-KM + 0x0af000b5: 310, // fr-LU + 0x0af000b8: 311, // fr-MA + 0x0af000b9: 312, // fr-MC + 0x0af000bc: 313, // fr-MF + 0x0af000bd: 314, // fr-MG + 0x0af000c1: 315, // fr-ML + 0x0af000c6: 316, // fr-MQ + 0x0af000c7: 317, // fr-MR + 0x0af000ca: 318, // fr-MU + 0x0af000d1: 319, // fr-NC + 0x0af000d2: 320, // fr-NE + 0x0af000e3: 321, // fr-PF + 0x0af000e8: 322, // fr-PM + 0x0af00100: 323, // fr-RE + 0x0af00105: 324, // fr-RW + 0x0af00108: 325, // fr-SC + 0x0af00112: 326, // fr-SN + 0x0af0011a: 327, // fr-SY + 0x0af0011e: 328, // fr-TD + 0x0af00120: 329, // fr-TG + 0x0af00126: 330, // fr-TN + 0x0af0013c: 331, // fr-VU + 0x0af0013d: 332, // fr-WF + 0x0af0015c: 333, // fr-YT + 0x0b600000: 334, // fur + 0x0b60009c: 335, // fur-IT + 0x0b900000: 336, // fy + 0x0b9000d7: 337, // fy-NL + 0x0ba00000: 338, // ga + 0x0ba00094: 339, // ga-IE + 0x0c200000: 340, // gd + 0x0c200079: 341, // gd-GB + 0x0c800000: 342, // gl + 0x0c80006d: 343, // gl-ES + 0x0d200000: 344, // gsw + 0x0d20004d: 345, // gsw-CH + 0x0d200076: 346, // gsw-FR + 0x0d2000b0: 347, // gsw-LI + 0x0d300000: 348, // gu + 0x0d300097: 349, // gu-IN + 0x0d700000: 350, // guw + 0x0d800000: 351, // guz + 0x0d8000a2: 352, // guz-KE + 0x0d900000: 353, // gv + 0x0d900096: 354, // gv-IM + 0x0dc00000: 355, // ha + 0x0dc0007e: 356, // ha-GH + 0x0dc000d2: 357, // ha-NE + 0x0dc000d4: 358, // ha-NG + 0x0de00000: 359, // haw + 0x0de00132: 360, // haw-US + 0x0e000000: 361, // he + 0x0e000095: 362, // he-IL + 0x0e100000: 363, // hi + 0x0e100097: 364, // hi-IN + 0x0ee00000: 365, // hr + 0x0ee00032: 366, // hr-BA + 0x0ee0008e: 367, // hr-HR + 0x0ef00000: 368, // hsb + 0x0ef0005f: 369, // hsb-DE + 0x0f200000: 370, // hu + 0x0f200090: 371, // hu-HU + 0x0f300000: 372, // hy + 0x0f300027: 373, // hy-AM + 0x0f800000: 374, // id + 0x0f800093: 375, // id-ID + 0x0fa00000: 376, // ig + 0x0fa000d4: 377, // ig-NG + 0x0fb00000: 378, // ii + 0x0fb00052: 379, // ii-CN + 0x10200000: 380, // is + 0x1020009b: 381, // is-IS + 0x10300000: 382, // it + 0x1030004d: 383, // it-CH + 0x1030009c: 384, // it-IT + 0x10300111: 385, // it-SM + 0x10400000: 386, // iu + 0x10700000: 387, // ja + 0x107000a0: 388, // ja-JP + 0x10900000: 389, // jbo + 0x10a00000: 390, // jgo + 0x10a00051: 391, // jgo-CM + 0x10c00000: 392, // jmc + 0x10c0012d: 393, // jmc-TZ + 0x10f00000: 394, // jv + 0x11100000: 395, // ka + 0x1110007b: 396, // ka-GE + 0x11300000: 397, // kab + 0x11300066: 398, // kab-DZ + 0x11500000: 399, // kaj + 0x11600000: 400, // kam + 0x116000a2: 401, // kam-KE + 0x11900000: 402, // kcg + 0x11b00000: 403, // kde + 0x11b0012d: 404, // kde-TZ + 0x11d00000: 405, // kea + 0x11d00059: 406, // kea-CV + 0x12800000: 407, // khq + 0x128000c1: 408, // khq-ML + 0x12b00000: 409, // ki + 0x12b000a2: 410, // ki-KE + 0x12f00000: 411, // kk + 0x12f000ac: 412, // kk-KZ + 0x13000000: 413, // kkj + 0x13000051: 414, // kkj-CM + 0x13100000: 415, // kl + 0x13100080: 416, // kl-GL + 0x13200000: 417, // kln + 0x132000a2: 418, // kln-KE + 0x13300000: 419, // km + 0x133000a4: 420, // km-KH + 0x13500000: 421, // kn + 0x13500097: 422, // kn-IN + 0x13600000: 423, // ko + 0x136000a8: 424, // ko-KP + 0x136000a9: 425, // ko-KR + 0x13800000: 426, // kok + 0x13800097: 427, // kok-IN + 0x14100000: 428, // ks + 0x14100097: 429, // ks-IN + 0x14200000: 430, // ksb + 0x1420012d: 431, // ksb-TZ + 0x14300000: 432, // ksf + 0x14300051: 433, // ksf-CM + 0x14400000: 434, // ksh + 0x1440005f: 435, // ksh-DE + 0x14500000: 436, // ku + 0x14a00000: 437, // kw + 0x14a00079: 438, // kw-GB + 0x14d00000: 439, // ky + 0x14d000a3: 440, // ky-KG + 0x15100000: 441, // lag + 0x1510012d: 442, // lag-TZ + 0x15400000: 443, // lb + 0x154000b5: 444, // lb-LU + 0x15a00000: 445, // lg + 0x15a0012f: 446, // lg-UG + 0x16100000: 447, // lkt + 0x16100132: 448, // lkt-US + 0x16400000: 449, // ln + 0x16400029: 450, // ln-AO + 0x1640004a: 451, // ln-CD + 0x1640004b: 452, // ln-CF + 0x1640004c: 453, // ln-CG + 0x16500000: 454, // lo + 0x165000ad: 455, // lo-LA + 0x16800000: 456, // lrc + 0x16800099: 457, // lrc-IQ + 0x1680009a: 458, // lrc-IR + 0x16900000: 459, // lt + 0x169000b4: 460, // lt-LT + 0x16b00000: 461, // lu + 0x16b0004a: 462, // lu-CD + 0x16d00000: 463, // luo + 0x16d000a2: 464, // luo-KE + 0x16e00000: 465, // luy + 0x16e000a2: 466, // luy-KE + 0x17000000: 467, // lv + 0x170000b6: 468, // lv-LV + 0x17a00000: 469, // mas + 0x17a000a2: 470, // mas-KE + 0x17a0012d: 471, // mas-TZ + 0x18000000: 472, // mer + 0x180000a2: 473, // mer-KE + 0x18200000: 474, // mfe + 0x182000ca: 475, // mfe-MU + 0x18300000: 476, // mg + 0x183000bd: 477, // mg-MG + 0x18400000: 478, // mgh + 0x184000cf: 479, // mgh-MZ + 0x18500000: 480, // mgo + 0x18500051: 481, // mgo-CM + 0x18c00000: 482, // mk + 0x18c000c0: 483, // mk-MK + 0x18d00000: 484, // ml + 0x18d00097: 485, // ml-IN + 0x18f00000: 486, // mn + 0x18f000c3: 487, // mn-MN + 0x19600000: 488, // mr + 0x19600097: 489, // mr-IN + 0x19a00000: 490, // ms + 0x19a0003d: 491, // ms-BN + 0x19a000ce: 492, // ms-MY + 0x19a0010b: 493, // ms-SG + 0x19b00000: 494, // mt + 0x19b000c9: 495, // mt-MT + 0x19d00000: 496, // mua + 0x19d00051: 497, // mua-CM + 0x1a500000: 498, // my + 0x1a5000c2: 499, // my-MM + 0x1a900000: 500, // mzn + 0x1a90009a: 501, // mzn-IR + 0x1ab00000: 502, // nah + 0x1ae00000: 503, // naq + 0x1ae000d0: 504, // naq-NA + 0x1af00000: 505, // nb + 0x1af000d8: 506, // nb-NO + 0x1af0010e: 507, // nb-SJ + 0x1b100000: 508, // nd + 0x1b100161: 509, // nd-ZW + 0x1b400000: 510, // ne + 0x1b400097: 511, // ne-IN + 0x1b4000d9: 512, // ne-NP + 0x1bd00000: 513, // nl + 0x1bd0002f: 514, // nl-AW + 0x1bd00035: 515, // nl-BE + 0x1bd0003f: 516, // nl-BQ + 0x1bd0005a: 517, // nl-CW + 0x1bd000d7: 518, // nl-NL + 0x1bd00114: 519, // nl-SR + 0x1bd00119: 520, // nl-SX + 0x1be00000: 521, // nmg + 0x1be00051: 522, // nmg-CM + 0x1bf00000: 523, // nn + 0x1bf000d8: 524, // nn-NO + 0x1c000000: 525, // nnh + 0x1c000051: 526, // nnh-CM + 0x1c100000: 527, // no + 0x1c500000: 528, // nqo + 0x1c600000: 529, // nr + 0x1c800000: 530, // nso + 0x1c900000: 531, // nus + 0x1c900115: 532, // nus-SS + 0x1cc00000: 533, // ny + 0x1ce00000: 534, // nyn + 0x1ce0012f: 535, // nyn-UG + 0x1d200000: 536, // om + 0x1d20006e: 537, // om-ET + 0x1d2000a2: 538, // om-KE + 0x1d300000: 539, // or + 0x1d300097: 540, // or-IN + 0x1d400000: 541, // os + 0x1d40007b: 542, // os-GE + 0x1d400104: 543, // os-RU + 0x1d700000: 544, // pa + 0x1d705000: 545, // pa-Arab + 0x1d7050e6: 546, // pa-Arab-PK + 0x1d72f000: 547, // pa-Guru + 0x1d72f097: 548, // pa-Guru-IN + 0x1db00000: 549, // pap + 0x1e700000: 550, // pl + 0x1e7000e7: 551, // pl-PL + 0x1ed00000: 552, // prg + 0x1ed00001: 553, // prg-001 + 0x1ee00000: 554, // ps + 0x1ee00023: 555, // ps-AF + 0x1ef00000: 556, // pt + 0x1ef00029: 557, // pt-AO + 0x1ef00040: 558, // pt-BR + 0x1ef0004d: 559, // pt-CH + 0x1ef00059: 560, // pt-CV + 0x1ef00084: 561, // pt-GQ + 0x1ef00089: 562, // pt-GW + 0x1ef000b5: 563, // pt-LU + 0x1ef000c4: 564, // pt-MO + 0x1ef000cf: 565, // pt-MZ + 0x1ef000ec: 566, // pt-PT + 0x1ef00116: 567, // pt-ST + 0x1ef00124: 568, // pt-TL + 0x1f100000: 569, // qu + 0x1f10003e: 570, // qu-BO + 0x1f100068: 571, // qu-EC + 0x1f1000e2: 572, // qu-PE + 0x1fc00000: 573, // rm + 0x1fc0004d: 574, // rm-CH + 0x20100000: 575, // rn + 0x20100039: 576, // rn-BI + 0x20300000: 577, // ro + 0x203000ba: 578, // ro-MD + 0x20300102: 579, // ro-RO + 0x20500000: 580, // rof + 0x2050012d: 581, // rof-TZ + 0x20700000: 582, // ru + 0x20700046: 583, // ru-BY + 0x207000a3: 584, // ru-KG + 0x207000ac: 585, // ru-KZ + 0x207000ba: 586, // ru-MD + 0x20700104: 587, // ru-RU + 0x2070012e: 588, // ru-UA + 0x20a00000: 589, // rw + 0x20a00105: 590, // rw-RW + 0x20b00000: 591, // rwk + 0x20b0012d: 592, // rwk-TZ + 0x20f00000: 593, // sah + 0x20f00104: 594, // sah-RU + 0x21000000: 595, // saq + 0x210000a2: 596, // saq-KE + 0x21400000: 597, // sbp + 0x2140012d: 598, // sbp-TZ + 0x21c00000: 599, // sdh + 0x21d00000: 600, // se + 0x21d00070: 601, // se-FI + 0x21d000d8: 602, // se-NO + 0x21d0010a: 603, // se-SE + 0x21f00000: 604, // seh + 0x21f000cf: 605, // seh-MZ + 0x22100000: 606, // ses + 0x221000c1: 607, // ses-ML + 0x22200000: 608, // sg + 0x2220004b: 609, // sg-CF + 0x22600000: 610, // shi + 0x22652000: 611, // shi-Latn + 0x226520b8: 612, // shi-Latn-MA + 0x226d2000: 613, // shi-Tfng + 0x226d20b8: 614, // shi-Tfng-MA + 0x22800000: 615, // si + 0x228000b1: 616, // si-LK + 0x22a00000: 617, // sk + 0x22a0010f: 618, // sk-SK + 0x22c00000: 619, // sl + 0x22c0010d: 620, // sl-SI + 0x23000000: 621, // sma + 0x23100000: 622, // smi + 0x23200000: 623, // smj + 0x23300000: 624, // smn + 0x23300070: 625, // smn-FI + 0x23500000: 626, // sms + 0x23600000: 627, // sn + 0x23600161: 628, // sn-ZW + 0x23800000: 629, // so + 0x23800061: 630, // so-DJ + 0x2380006e: 631, // so-ET + 0x238000a2: 632, // so-KE + 0x23800113: 633, // so-SO + 0x23a00000: 634, // sq + 0x23a00026: 635, // sq-AL + 0x23a000c0: 636, // sq-MK + 0x23a0014a: 637, // sq-XK + 0x23b00000: 638, // sr + 0x23b1e000: 639, // sr-Cyrl + 0x23b1e032: 640, // sr-Cyrl-BA + 0x23b1e0bb: 641, // sr-Cyrl-ME + 0x23b1e103: 642, // sr-Cyrl-RS + 0x23b1e14a: 643, // sr-Cyrl-XK + 0x23b52000: 644, // sr-Latn + 0x23b52032: 645, // sr-Latn-BA + 0x23b520bb: 646, // sr-Latn-ME + 0x23b52103: 647, // sr-Latn-RS + 0x23b5214a: 648, // sr-Latn-XK + 0x24000000: 649, // ss + 0x24100000: 650, // ssy + 0x24200000: 651, // st + 0x24700000: 652, // sv + 0x24700030: 653, // sv-AX + 0x24700070: 654, // sv-FI + 0x2470010a: 655, // sv-SE + 0x24800000: 656, // sw + 0x2480004a: 657, // sw-CD + 0x248000a2: 658, // sw-KE + 0x2480012d: 659, // sw-TZ + 0x2480012f: 660, // sw-UG + 0x24f00000: 661, // syr + 0x25100000: 662, // ta + 0x25100097: 663, // ta-IN + 0x251000b1: 664, // ta-LK + 0x251000ce: 665, // ta-MY + 0x2510010b: 666, // ta-SG + 0x25800000: 667, // te + 0x25800097: 668, // te-IN + 0x25a00000: 669, // teo + 0x25a000a2: 670, // teo-KE + 0x25a0012f: 671, // teo-UG + 0x25d00000: 672, // th + 0x25d00121: 673, // th-TH + 0x26100000: 674, // ti + 0x2610006c: 675, // ti-ER + 0x2610006e: 676, // ti-ET + 0x26200000: 677, // tig + 0x26400000: 678, // tk + 0x26400125: 679, // tk-TM + 0x26b00000: 680, // tn + 0x26c00000: 681, // to + 0x26c00127: 682, // to-TO + 0x26f00000: 683, // tr + 0x26f0005c: 684, // tr-CY + 0x26f00129: 685, // tr-TR + 0x27200000: 686, // ts + 0x27e00000: 687, // twq + 0x27e000d2: 688, // twq-NE + 0x28200000: 689, // tzm + 0x282000b8: 690, // tzm-MA + 0x28400000: 691, // ug + 0x28400052: 692, // ug-CN + 0x28600000: 693, // uk + 0x2860012e: 694, // uk-UA + 0x28c00000: 695, // ur + 0x28c00097: 696, // ur-IN + 0x28c000e6: 697, // ur-PK + 0x28d00000: 698, // uz + 0x28d05000: 699, // uz-Arab + 0x28d05023: 700, // uz-Arab-AF + 0x28d1e000: 701, // uz-Cyrl + 0x28d1e134: 702, // uz-Cyrl-UZ + 0x28d52000: 703, // uz-Latn + 0x28d52134: 704, // uz-Latn-UZ + 0x28e00000: 705, // vai + 0x28e52000: 706, // vai-Latn + 0x28e520b2: 707, // vai-Latn-LR + 0x28ed9000: 708, // vai-Vaii + 0x28ed90b2: 709, // vai-Vaii-LR + 0x28f00000: 710, // ve + 0x29200000: 711, // vi + 0x2920013b: 712, // vi-VN + 0x29700000: 713, // vo + 0x29700001: 714, // vo-001 + 0x29a00000: 715, // vun + 0x29a0012d: 716, // vun-TZ + 0x29b00000: 717, // wa + 0x29c00000: 718, // wae + 0x29c0004d: 719, // wae-CH + 0x2a400000: 720, // wo + 0x2a900000: 721, // xh + 0x2b100000: 722, // xog + 0x2b10012f: 723, // xog-UG + 0x2b700000: 724, // yav + 0x2b700051: 725, // yav-CM + 0x2b900000: 726, // yi + 0x2b900001: 727, // yi-001 + 0x2ba00000: 728, // yo + 0x2ba0003a: 729, // yo-BJ + 0x2ba000d4: 730, // yo-NG + 0x2bd00000: 731, // yue + 0x2bd0008b: 732, // yue-HK + 0x2c300000: 733, // zgh + 0x2c3000b8: 734, // zgh-MA + 0x2c400000: 735, // zh + 0x2c434000: 736, // zh-Hans + 0x2c434052: 737, // zh-Hans-CN + 0x2c43408b: 738, // zh-Hans-HK + 0x2c4340c4: 739, // zh-Hans-MO + 0x2c43410b: 740, // zh-Hans-SG + 0x2c435000: 741, // zh-Hant + 0x2c43508b: 742, // zh-Hant-HK + 0x2c4350c4: 743, // zh-Hant-MO + 0x2c43512c: 744, // zh-Hant-TW + 0x2c600000: 745, // zu + 0x2c60015e: 746, // zu-ZA } -// Total table size 4580 bytes (4KiB); checksum: A7F72A2A +// Total table size 4550 bytes (4KiB); checksum: B6D49547 diff --git a/vendor/golang.org/x/text/language/language.go b/vendor/golang.org/x/text/language/language.go index c24d4ad..5c6dcbd 100644 --- a/vendor/golang.org/x/text/language/language.go +++ b/vendor/golang.org/x/text/language/language.go @@ -593,7 +593,7 @@ func (t Tag) Extension(x byte) (ext Extension, ok bool) { return Extension{ext}, true } } - return Extension{}, false + return Extension{string(x)}, false } // Extensions returns all extensions of t. diff --git a/vendor/golang.org/x/text/language/maketables.go b/vendor/golang.org/x/text/language/maketables.go index 107f992..2cc995b 100644 --- a/vendor/golang.org/x/text/language/maketables.go +++ b/vendor/golang.org/x/text/language/maketables.go @@ -678,8 +678,6 @@ func (b *builder) parseIndices() { b.locale.parse(meta.DefaultContent.Locales) } -// TODO: region inclusion data will probably not be use used in future matchers. - func (b *builder) computeRegionGroups() { b.groups = make(map[int]index) @@ -688,11 +686,6 @@ func (b *builder) computeRegionGroups() { b.groups[i] = index(len(b.groups)) } for _, g := range b.supp.TerritoryContainment.Group { - // Skip UN and EURO zone as they are flattening the containment - // relationship. - if g.Type == "EZ" || g.Type == "UN" { - continue - } group := b.region.index(g.Type) if _, ok := b.groups[group]; !ok { b.groups[group] = index(len(b.groups)) @@ -789,7 +782,6 @@ func (b *builder) writeLanguage() { lang.updateLater("tw", "twi") lang.updateLater("nb", "nob") lang.updateLater("ak", "aka") - lang.updateLater("bh", "bih") // Ensure that each 2-letter code is matched with a 3-letter code. for _, v := range lang.s[1:] { @@ -1490,11 +1482,6 @@ func (b *builder) writeRegionInclusionData() { containment = make(map[index][]index) ) for _, g := range b.supp.TerritoryContainment.Group { - // Skip UN and EURO zone as they are flattening the containment - // relationship. - if g.Type == "EZ" || g.Type == "UN" { - continue - } group := b.region.index(g.Type) groupIdx := b.groups[group] for _, mem := range strings.Split(g.Contains, " ") { diff --git a/vendor/golang.org/x/text/language/match.go b/vendor/golang.org/x/text/language/match.go index 8ad9505..eec72bc 100644 --- a/vendor/golang.org/x/text/language/match.go +++ b/vendor/golang.org/x/text/language/match.go @@ -396,8 +396,8 @@ type matcher struct { // matchHeader has the lists of tags for exact matches and matches based on // maximized and canonicalized tags for a given language. type matchHeader struct { - exact []*haveTag - max []*haveTag + exact []haveTag + max []haveTag } // haveTag holds a supported Tag and its maximized script and region. The maximized @@ -457,7 +457,7 @@ func (h *matchHeader) addIfNew(n haveTag, exact bool) { } } if exact { - h.exact = append(h.exact, &n) + h.exact = append(h.exact, n) } // Allow duplicate maximized tags, but create a linked list to allow quickly // comparing the equivalents and bail out. @@ -472,7 +472,7 @@ func (h *matchHeader) addIfNew(n haveTag, exact bool) { break } } - h.max = append(h.max, &n) + h.max = append(h.max, n) } // header returns the matchHeader for the given language. It creates one if @@ -503,7 +503,7 @@ func newMatcher(supported []Tag) *matcher { pair, _ := makeHaveTag(tag, i) m.header(tag.lang).addIfNew(pair, true) } - m.default_ = m.header(supported[0].lang).exact[0] + m.default_ = &m.header(supported[0].lang).exact[0] for i, tag := range supported { pair, max := makeHaveTag(tag, i) if max != tag.lang { @@ -520,8 +520,7 @@ func newMatcher(supported []Tag) *matcher { return } hw := m.header(langID(want)) - for _, ht := range hh.max { - v := *ht + for _, v := range hh.max { if conf < v.conf { v.conf = conf } @@ -581,7 +580,7 @@ func (m *matcher) getBest(want ...Tag) (got *haveTag, orig Tag, c Confidence) { continue } for i := range h.exact { - have := h.exact[i] + have := &h.exact[i] if have.tag.equalsRest(w) { return have, w, Exact } @@ -592,7 +591,7 @@ func (m *matcher) getBest(want ...Tag) (got *haveTag, orig Tag, c Confidence) { // Base language is not defined. if h != nil { for i := range h.exact { - have := h.exact[i] + have := &h.exact[i] if have.tag.equalsRest(w) { return have, w, Exact } @@ -610,11 +609,11 @@ func (m *matcher) getBest(want ...Tag) (got *haveTag, orig Tag, c Confidence) { } // Check for match based on maximized tag. for i := range h.max { - have := h.max[i] + have := &h.max[i] best.update(have, w, max.script, max.region) if best.conf == Exact { for have.nextMax != 0 { - have = h.max[have.nextMax] + have = &h.max[have.nextMax] best.update(have, w, max.script, max.region) } return best.have, best.want, High diff --git a/vendor/golang.org/x/text/language/tables.go b/vendor/golang.org/x/text/language/tables.go index 1a92e58..5de0f85 100644 --- a/vendor/golang.org/x/text/language/tables.go +++ b/vendor/golang.org/x/text/language/tables.go @@ -5,118 +5,118 @@ package language import "golang.org/x/text/internal/tag" // CLDRVersion is the CLDR version from which the tables in this package are derived. -const CLDRVersion = "30" +const CLDRVersion = "29" const numLanguages = 8654 const numScripts = 230 -const numRegions = 356 +const numRegions = 354 type fromTo struct { from uint16 to uint16 } -const nonCanonicalUnd = 1191 +const nonCanonicalUnd = 649 const ( - _af = 21 - _am = 38 - _ar = 57 - _az = 87 - _bg = 125 - _bn = 163 - _ca = 213 - _cs = 246 - _da = 253 - _de = 265 - _el = 305 - _en = 308 - _es = 313 - _et = 315 - _fa = 323 - _fi = 332 - _fil = 334 - _fr = 345 - _gu = 413 - _he = 437 - _hi = 439 - _hr = 458 - _hu = 462 - _hy = 464 - _id = 474 - _is = 496 - _it = 497 - _ja = 504 - _ka = 520 - _kk = 570 - _km = 578 - _kn = 585 - _ko = 587 - _ky = 641 - _lo = 687 - _lt = 695 - _lv = 702 - _mk = 758 - _ml = 763 - _mn = 770 - _mo = 775 - _mr = 786 - _ms = 790 - _mul = 797 - _my = 808 - _nb = 830 - _ne = 840 - _nl = 862 - _no = 870 - _pa = 916 - _pl = 938 - _pt = 951 - _ro = 979 - _ru = 985 - _sh = 1021 - _si = 1026 - _sk = 1032 - _sl = 1036 - _sq = 1063 - _sr = 1064 - _sv = 1082 - _sw = 1083 - _ta = 1094 - _te = 1111 - _th = 1121 - _tl = 1136 - _tn = 1142 - _tr = 1152 - _uk = 1188 - _ur = 1194 - _uz = 1202 - _vi = 1209 - _zh = 1311 - _zu = 1316 - _jbo = 507 - _ami = 1639 - _bnn = 2346 - _hak = 431 - _tlh = 14456 - _lb = 652 - _nv = 890 - _pwn = 12044 - _tao = 14177 - _tay = 14187 - _tsu = 14651 - _nn = 865 - _sfb = 13618 - _vgt = 15690 - _sgg = 13649 - _cmn = 2996 - _nan = 826 - _hsn = 460 + _af = 10 + _am = 17 + _ar = 21 + _az = 36 + _bg = 56 + _bn = 75 + _ca = 97 + _cs = 121 + _da = 128 + _de = 133 + _el = 154 + _en = 155 + _es = 157 + _et = 159 + _fa = 164 + _fi = 168 + _fil = 170 + _fr = 175 + _gu = 211 + _he = 224 + _hi = 225 + _hr = 238 + _hu = 242 + _hy = 243 + _id = 248 + _is = 258 + _it = 259 + _ja = 263 + _ka = 273 + _kk = 303 + _km = 307 + _kn = 309 + _ko = 310 + _ky = 333 + _lo = 357 + _lt = 361 + _lv = 368 + _mk = 396 + _ml = 397 + _mn = 399 + _mo = 402 + _mr = 406 + _ms = 410 + _mul = 414 + _my = 421 + _nb = 431 + _ne = 436 + _nl = 445 + _no = 449 + _pa = 471 + _pl = 487 + _pt = 495 + _ro = 515 + _ru = 519 + _sh = 549 + _si = 552 + _sk = 554 + _sl = 556 + _sq = 570 + _sr = 571 + _sv = 583 + _sw = 584 + _ta = 593 + _te = 600 + _th = 605 + _tl = 616 + _tn = 619 + _tr = 623 + _uk = 646 + _ur = 652 + _uz = 653 + _vi = 658 + _zh = 708 + _zu = 710 + _jbo = 265 + _ami = 1033 + _bnn = 1740 + _hak = 221 + _tlh = 13850 + _lb = 340 + _nv = 458 + _pwn = 11438 + _tao = 13571 + _tay = 13581 + _tsu = 14045 + _nn = 447 + _sfb = 13012 + _vgt = 15084 + _sgg = 13043 + _cmn = 2390 + _nan = 428 + _hsn = 240 ) -const langPrivateStart = 0x2f67 +const langPrivateStart = 0x2d09 -const langPrivateEnd = 0x316e +const langPrivateEnd = 0x2f10 // lang holds an alphabetically sorted list of ISO-639 language identifiers. // All entries are 4 bytes. The index of the identifier (divided by 4) is the language tag. @@ -125,132 +125,72 @@ const langPrivateEnd = 0x316e // the second and third letter of the 3-letter ISO code. // - otherwise: a 0 and a by 2 bits right-shifted index into altLangISO3. // For 3-byte language identifiers the 4th byte is 0. -var lang tag.Index = "" + // Size: 5280 bytes - "---\x00aaaraai\x00aak\x00aau\x00abbkabi\x00abr\x00abt\x00aby\x00acd\x00a" + - "ce\x00ach\x00ada\x00ade\x00adj\x00ady\x00adz\x00aeveaeb\x00aey\x00affrag" + - "c\x00agd\x00agg\x00agm\x00ago\x00agq\x00aha\x00ahl\x00aho\x00ajg\x00akka" + - "akk\x00ala\x00ali\x00aln\x00alt\x00ammhamm\x00amn\x00amo\x00amp\x00anrga" + - "nc\x00ank\x00ann\x00any\x00aoj\x00aom\x00aoz\x00apc\x00apd\x00ape\x00apr" + - "\x00aps\x00apz\x00arraarc\x00arh\x00arn\x00aro\x00arq\x00ars\x00ary\x00a" + - "rz\x00assmasa\x00ase\x00asg\x00aso\x00ast\x00ata\x00atg\x00atj\x00auy" + - "\x00avvaavl\x00avn\x00avt\x00avu\x00awa\x00awb\x00awo\x00awx\x00ayymayb" + - "\x00azzebaakbal\x00ban\x00bap\x00bar\x00bas\x00bav\x00bax\x00bba\x00bbb" + - "\x00bbc\x00bbd\x00bbj\x00bbp\x00bbr\x00bcf\x00bch\x00bci\x00bcm\x00bcn" + - "\x00bco\x00bcq\x00bcu\x00bdd\x00beelbef\x00beh\x00bej\x00bem\x00bet\x00b" + - "ew\x00bex\x00bez\x00bfd\x00bfq\x00bft\x00bfy\x00bgulbgc\x00bgn\x00bgx" + - "\x00bhihbhb\x00bhg\x00bhi\x00bhk\x00bhl\x00bho\x00bhy\x00biisbib\x00big" + - "\x00bik\x00bim\x00bin\x00bio\x00biq\x00bjh\x00bji\x00bjj\x00bjn\x00bjo" + - "\x00bjr\x00bjz\x00bkc\x00bkm\x00bkq\x00bku\x00bkv\x00blt\x00bmambmh\x00b" + - "mk\x00bmq\x00bmu\x00bnenbng\x00bnm\x00bnp\x00boodboj\x00bom\x00bon\x00bp" + - "y\x00bqc\x00bqi\x00bqp\x00bqv\x00brrebra\x00brh\x00brx\x00brz\x00bsosbsj" + - "\x00bsq\x00bss\x00bst\x00bto\x00btt\x00btv\x00bua\x00buc\x00bud\x00bug" + - "\x00buk\x00bum\x00buo\x00bus\x00buu\x00bvb\x00bwd\x00bwr\x00bxh\x00bye" + - "\x00byn\x00byr\x00bys\x00byv\x00byx\x00bza\x00bze\x00bzf\x00bzh\x00bzw" + - "\x00caatcan\x00cbj\x00cch\x00ccp\x00ceheceb\x00cfa\x00cgg\x00chhachk\x00" + - "chm\x00cho\x00chp\x00chr\x00cja\x00cjm\x00cjv\x00ckb\x00ckl\x00cko\x00ck" + - "y\x00cla\x00cme\x00cooscop\x00cps\x00crrecrj\x00crk\x00crl\x00crm\x00crs" + - "\x00csescsb\x00csw\x00ctd\x00cuhucvhvcyymdaandad\x00daf\x00dag\x00dah" + - "\x00dak\x00dar\x00dav\x00dbd\x00dbq\x00dcc\x00ddn\x00deeuded\x00den\x00d" + - "ga\x00dgh\x00dgi\x00dgl\x00dgr\x00dgz\x00dia\x00dje\x00dnj\x00dob\x00doi" + - "\x00dop\x00dow\x00dri\x00drs\x00dsb\x00dtm\x00dtp\x00dts\x00dty\x00dua" + - "\x00duc\x00dud\x00dug\x00dvivdva\x00dww\x00dyo\x00dyu\x00dzzodzg\x00ebu" + - "\x00eeweefi\x00egl\x00egy\x00eky\x00elllema\x00emi\x00enngenn\x00enq\x00" + - "eopoeri\x00es\x00\x05esu\x00etstetr\x00ett\x00etu\x00etx\x00euusewo\x00e" + - "xt\x00faasfaa\x00fab\x00fag\x00fai\x00fan\x00ffulffi\x00ffm\x00fiinfia" + - "\x00fil\x00fit\x00fjijflr\x00fmp\x00foaofod\x00fon\x00for\x00fpe\x00fqs" + - "\x00frrafrc\x00frp\x00frr\x00frs\x00fub\x00fud\x00fue\x00fuf\x00fuh\x00f" + - "uq\x00fur\x00fuv\x00fuy\x00fvr\x00fyrygalegaa\x00gaf\x00gag\x00gah\x00ga" + - "j\x00gam\x00gan\x00gaw\x00gay\x00gbf\x00gbm\x00gby\x00gbz\x00gcr\x00gdla" + - "gde\x00gdn\x00gdr\x00geb\x00gej\x00gel\x00gez\x00gfk\x00ggn\x00ghs\x00gi" + - "l\x00gim\x00gjk\x00gjn\x00gju\x00gkn\x00gkp\x00gllgglk\x00gmm\x00gmv\x00" + - "gnrngnd\x00gng\x00god\x00gof\x00goi\x00gom\x00gon\x00gor\x00gos\x00got" + - "\x00grc\x00grt\x00grw\x00gsw\x00guujgub\x00guc\x00gud\x00gur\x00guw\x00g" + - "ux\x00guz\x00gvlvgvf\x00gvr\x00gvs\x00gwc\x00gwi\x00gwt\x00gyi\x00haauha" + - "g\x00hak\x00ham\x00haw\x00haz\x00hbb\x00hdy\x00heebhhy\x00hiinhia\x00hif" + - "\x00hig\x00hih\x00hil\x00hla\x00hlu\x00hmd\x00hmt\x00hnd\x00hne\x00hnj" + - "\x00hnn\x00hno\x00homohoc\x00hoj\x00hot\x00hrrvhsb\x00hsn\x00htathuunhui" + - "\x00hyyehzerianaian\x00iar\x00iba\x00ibb\x00iby\x00ica\x00ich\x00idndidd" + - "\x00idi\x00idu\x00ieleigboigb\x00ige\x00iiiiijj\x00ikpkikk\x00ikt\x00ikw" + - "\x00ikx\x00ilo\x00imo\x00inndinh\x00iodoiou\x00iri\x00isslittaiukuiw\x00" + - "\x03iwm\x00iws\x00izh\x00izi\x00japnjab\x00jam\x00jbo\x00jbu\x00jen\x00j" + - "gk\x00jgo\x00ji\x00\x06jib\x00jmc\x00jml\x00jra\x00jut\x00jvavjwavkaatka" + - "a\x00kab\x00kac\x00kad\x00kai\x00kaj\x00kam\x00kao\x00kbd\x00kbm\x00kbp" + - "\x00kbq\x00kbx\x00kby\x00kcg\x00kck\x00kcl\x00kct\x00kde\x00kdh\x00kdl" + - "\x00kdt\x00kea\x00ken\x00kez\x00kfo\x00kfr\x00kfy\x00kgonkge\x00kgf\x00k" + - "gp\x00kha\x00khb\x00khn\x00khq\x00khs\x00kht\x00khw\x00khz\x00kiikkij" + - "\x00kiu\x00kiw\x00kjuakjd\x00kjg\x00kjs\x00kjy\x00kkazkkc\x00kkj\x00klal" + - "kln\x00klq\x00klt\x00klx\x00kmhmkmb\x00kmh\x00kmo\x00kms\x00kmu\x00kmw" + - "\x00knanknp\x00koorkoi\x00kok\x00kol\x00kos\x00koz\x00kpe\x00kpf\x00kpo" + - "\x00kpr\x00kpx\x00kqb\x00kqf\x00kqs\x00kqy\x00kraukrc\x00kri\x00krj\x00k" + - "rl\x00krs\x00kru\x00ksasksb\x00ksd\x00ksf\x00ksh\x00ksj\x00ksr\x00ktb" + - "\x00ktm\x00kto\x00kuurkub\x00kud\x00kue\x00kuj\x00kum\x00kun\x00kup\x00k" + - "us\x00kvomkvg\x00kvr\x00kvx\x00kw\x00\x01kwj\x00kwo\x00kxa\x00kxc\x00kxm" + - "\x00kxp\x00kxw\x00kxz\x00kyirkye\x00kyx\x00kzr\x00laatlab\x00lad\x00lag" + - "\x00lah\x00laj\x00las\x00lbtzlbe\x00lbu\x00lbw\x00lcm\x00lcp\x00ldb\x00l" + - "ed\x00lee\x00lem\x00lep\x00leq\x00leu\x00lez\x00lguglgg\x00liimlia\x00li" + - "d\x00lif\x00lig\x00lih\x00lij\x00lis\x00ljp\x00lki\x00lkt\x00lle\x00lln" + - "\x00lmn\x00lmo\x00lmp\x00lninlns\x00lnu\x00loaoloj\x00lok\x00lol\x00lor" + - "\x00los\x00loz\x00lrc\x00ltitltg\x00luublua\x00luo\x00luy\x00luz\x00lvav" + - "lwl\x00lzh\x00lzz\x00mad\x00maf\x00mag\x00mai\x00mak\x00man\x00mas\x00ma" + - "w\x00maz\x00mbh\x00mbo\x00mbq\x00mbu\x00mbw\x00mci\x00mcp\x00mcq\x00mcr" + - "\x00mcu\x00mda\x00mde\x00mdf\x00mdh\x00mdj\x00mdr\x00mdx\x00med\x00mee" + - "\x00mek\x00men\x00mer\x00met\x00meu\x00mfa\x00mfe\x00mfn\x00mfo\x00mfq" + - "\x00mglgmgh\x00mgl\x00mgo\x00mgp\x00mgy\x00mhahmhi\x00mhl\x00mirimif\x00" + - "min\x00mis\x00miw\x00mkkdmki\x00mkl\x00mkp\x00mkw\x00mlalmle\x00mlp\x00m" + - "ls\x00mmo\x00mmu\x00mmx\x00mnonmna\x00mnf\x00mni\x00mnw\x00moolmoa\x00mo" + - "e\x00moh\x00mos\x00mox\x00mpp\x00mps\x00mpt\x00mpx\x00mql\x00mrarmrd\x00" + - "mrj\x00mro\x00mssamtltmtc\x00mtf\x00mti\x00mtr\x00mua\x00mul\x00mur\x00m" + - "us\x00mva\x00mvn\x00mvy\x00mwk\x00mwr\x00mwv\x00mxc\x00mxm\x00myyamyk" + - "\x00mym\x00myv\x00myw\x00myx\x00myz\x00mzk\x00mzm\x00mzn\x00mzp\x00mzw" + - "\x00mzz\x00naaunac\x00naf\x00nah\x00nak\x00nan\x00nap\x00naq\x00nas\x00n" + - "bobnca\x00nce\x00ncf\x00nch\x00nco\x00ncu\x00nddendc\x00nds\x00neepneb" + - "\x00new\x00nex\x00nfr\x00ngdonga\x00ngb\x00ngl\x00nhb\x00nhe\x00nhw\x00n" + - "if\x00nii\x00nij\x00nin\x00niu\x00niy\x00niz\x00njo\x00nkg\x00nko\x00nll" + - "dnmg\x00nmz\x00nnnonnf\x00nnh\x00nnk\x00nnm\x00noornod\x00noe\x00non\x00" + - "nop\x00nou\x00nqo\x00nrblnrb\x00nsk\x00nsn\x00nso\x00nss\x00ntm\x00ntr" + - "\x00nui\x00nup\x00nus\x00nuv\x00nux\x00nvavnwb\x00nxq\x00nxr\x00nyyanym" + - "\x00nyn\x00nzi\x00occiogc\x00ojjiokr\x00okv\x00omrmong\x00onn\x00ons\x00" + - "opm\x00orrioro\x00oru\x00osssosa\x00ota\x00otk\x00ozm\x00paanpag\x00pal" + - "\x00pam\x00pap\x00pau\x00pbi\x00pcd\x00pcm\x00pdc\x00pdt\x00ped\x00peo" + - "\x00pex\x00pfl\x00phl\x00phn\x00pilipil\x00pip\x00pka\x00pko\x00plolpla" + - "\x00pms\x00png\x00pnn\x00pnt\x00pon\x00ppo\x00pra\x00prd\x00prg\x00psusp" + - "ss\x00ptorptp\x00puu\x00pwa\x00quuequc\x00qug\x00rai\x00raj\x00rao\x00rc" + - "f\x00rej\x00rel\x00res\x00rgn\x00rhg\x00ria\x00rif\x00rjs\x00rkt\x00rmoh" + - "rmf\x00rmo\x00rmt\x00rmu\x00rnunrna\x00rng\x00roonrob\x00rof\x00roo\x00r" + - "ro\x00rtm\x00ruusrue\x00rug\x00rw\x00\x04rwk\x00rwo\x00ryu\x00saansaf" + - "\x00sah\x00saq\x00sas\x00sat\x00saz\x00sba\x00sbe\x00sbp\x00scrdsck\x00s" + - "cl\x00scn\x00sco\x00scs\x00sdndsdc\x00sdh\x00semesef\x00seh\x00sei\x00se" + - "s\x00sgagsga\x00sgs\x00sgw\x00sgz\x00sh\x00\x02shi\x00shk\x00shn\x00shu" + - "\x00siinsid\x00sig\x00sil\x00sim\x00sjr\x00sklkskc\x00skr\x00sks\x00sllv" + - "sld\x00sli\x00sll\x00sly\x00smmosma\x00smi\x00smj\x00smn\x00smp\x00smq" + - "\x00sms\x00snnasnc\x00snk\x00snp\x00snx\x00sny\x00soomsok\x00soq\x00sou" + - "\x00soy\x00spd\x00spl\x00sps\x00sqqisrrpsrb\x00srn\x00srr\x00srx\x00sssw" + - "ssd\x00ssg\x00ssy\x00stotstk\x00stq\x00suunsua\x00sue\x00suk\x00sur\x00s" + - "us\x00svweswwaswb\x00swc\x00swg\x00swp\x00swv\x00sxn\x00sxw\x00syl\x00sy" + - "r\x00szl\x00taamtaj\x00tal\x00tan\x00taq\x00tbc\x00tbd\x00tbf\x00tbg\x00" + - "tbo\x00tbw\x00tbz\x00tci\x00tcy\x00tdd\x00tdg\x00tdh\x00teelted\x00tem" + - "\x00teo\x00tet\x00tfi\x00tggktgc\x00tgo\x00tgu\x00thhathl\x00thq\x00thr" + - "\x00tiirtif\x00tig\x00tik\x00tim\x00tio\x00tiv\x00tkuktkl\x00tkr\x00tkt" + - "\x00tlgltlf\x00tlx\x00tly\x00tmh\x00tmy\x00tnsntnh\x00toontof\x00tog\x00" + - "toq\x00tpi\x00tpm\x00tpz\x00tqo\x00trurtru\x00trv\x00trw\x00tssotsd\x00t" + - "sf\x00tsg\x00tsj\x00tsw\x00ttatttd\x00tte\x00ttj\x00ttr\x00tts\x00ttt" + - "\x00tuh\x00tul\x00tum\x00tuq\x00tvd\x00tvl\x00tvu\x00twwitwh\x00twq\x00t" + - "xg\x00tyahtya\x00tyv\x00tzm\x00ubu\x00udm\x00ugiguga\x00ukkruli\x00umb" + - "\x00und\x00unr\x00unx\x00urrduri\x00urt\x00urw\x00usa\x00utr\x00uvh\x00u" + - "vl\x00uzzbvag\x00vai\x00van\x00veenvec\x00vep\x00viievic\x00viv\x00vls" + - "\x00vmf\x00vmw\x00voolvot\x00vro\x00vun\x00vut\x00walnwae\x00waj\x00wal" + - "\x00wan\x00war\x00wbp\x00wbq\x00wbr\x00wci\x00wer\x00wgi\x00whg\x00wib" + - "\x00wiu\x00wiv\x00wja\x00wji\x00wls\x00wmo\x00wnc\x00wni\x00wnu\x00woolw" + - "ob\x00wos\x00wrs\x00wsk\x00wtm\x00wuu\x00wuv\x00wwa\x00xav\x00xbi\x00xcr" + - "\x00xes\x00xhhoxla\x00xlc\x00xld\x00xmf\x00xmn\x00xmr\x00xna\x00xnr\x00x" + - "og\x00xon\x00xpr\x00xrb\x00xsa\x00xsi\x00xsm\x00xsr\x00xwe\x00yam\x00yao" + - "\x00yap\x00yas\x00yat\x00yav\x00yay\x00yaz\x00yba\x00ybb\x00yby\x00yer" + - "\x00ygr\x00ygw\x00yiidyko\x00yle\x00ylg\x00yll\x00yml\x00yooryon\x00yrb" + - "\x00yre\x00yrl\x00yss\x00yua\x00yue\x00yuj\x00yut\x00yuw\x00zahazag\x00z" + - "bl\x00zdj\x00zea\x00zgh\x00zhhozia\x00zlm\x00zmi\x00zne\x00zuulzxx\x00zz" + - "a\x00\xff\xff\xff\xff" +var lang tag.Index = "" + // Size: 2856 bytes + "---\x00aaarabbkabr\x00ace\x00ach\x00ada\x00ady\x00aeveaeb\x00affragq\x00" + + "aho\x00akkaakk\x00aln\x00alt\x00ammhamo\x00anrgaoz\x00arraarc\x00arn\x00" + + "aro\x00arq\x00ary\x00arz\x00assmasa\x00ase\x00ast\x00atj\x00avvaawa\x00a" + + "yymazzebaakbal\x00ban\x00bap\x00bar\x00bas\x00bax\x00bbc\x00bbj\x00bci" + + "\x00beelbej\x00bem\x00bew\x00bez\x00bfd\x00bfq\x00bft\x00bfy\x00bgulbgc" + + "\x00bgn\x00bgx\x00bhihbhb\x00bhi\x00bhk\x00bho\x00biisbik\x00bin\x00bjj" + + "\x00bjn\x00bkm\x00bku\x00blt\x00bmambmq\x00bnenboodbpy\x00bqi\x00bqv\x00" + + "brrebra\x00brh\x00brx\x00bsosbsq\x00bss\x00bto\x00btv\x00bua\x00buc\x00b" + + "ug\x00bum\x00bvb\x00byn\x00byv\x00bze\x00caatcch\x00ccp\x00ceheceb\x00cg" + + "g\x00chhachk\x00chm\x00cho\x00chp\x00chr\x00cja\x00cjm\x00ckb\x00cooscop" + + "\x00cps\x00crrecrj\x00crk\x00crl\x00crm\x00crs\x00csescsb\x00csw\x00ctd" + + "\x00cuhucvhvcyymdaandak\x00dar\x00dav\x00dcc\x00deeuden\x00dgr\x00dje" + + "\x00dnj\x00doi\x00dsb\x00dtm\x00dtp\x00dty\x00dua\x00dvivdyo\x00dyu\x00d" + + "zzoebu\x00eeweefi\x00egl\x00egy\x00eky\x00elllenngeopoes\x00\x05esu\x00e" + + "tstett\x00euusewo\x00ext\x00faasfan\x00ffulffm\x00fiinfia\x00fil\x00fit" + + "\x00fjijfoaofon\x00frrafrc\x00frp\x00frr\x00frs\x00fud\x00fuq\x00fur\x00" + + "fuv\x00fvr\x00fyrygalegaa\x00gag\x00gan\x00gay\x00gbm\x00gbz\x00gcr\x00g" + + "dlagez\x00ggn\x00gil\x00gjk\x00gju\x00gllgglk\x00gnrngom\x00gon\x00gor" + + "\x00gos\x00got\x00grc\x00grt\x00gsw\x00guujgub\x00guc\x00gur\x00guw\x00g" + + "uz\x00gvlvgvr\x00gwi\x00haauhak\x00haw\x00haz\x00heebhiinhif\x00hil\x00h" + + "lu\x00hmd\x00hnd\x00hne\x00hnj\x00hnn\x00hno\x00homohoc\x00hoj\x00hrrvhs" + + "b\x00hsn\x00htathuunhyyehzerianaiba\x00ibb\x00idndieleigboiiiiikpkikt" + + "\x00ilo\x00inndinh\x00iodoisslittaiukuiw\x00\x03izh\x00japnjam\x00jbo" + + "\x00jgo\x00ji\x00\x06jmc\x00jml\x00jut\x00jvavjwavkaatkaa\x00kab\x00kac" + + "\x00kaj\x00kam\x00kao\x00kbd\x00kcg\x00kck\x00kde\x00kdt\x00kea\x00ken" + + "\x00kfo\x00kfr\x00kfy\x00kgonkge\x00kgp\x00kha\x00khb\x00khn\x00khq\x00k" + + "ht\x00khw\x00kiikkiu\x00kjuakjg\x00kkazkkj\x00klalkln\x00kmhmkmb\x00knan" + + "koorkoi\x00kok\x00kos\x00kpe\x00kraukrc\x00kri\x00krj\x00krl\x00kru\x00k" + + "sasksb\x00ksf\x00ksh\x00kuurkum\x00kvomkvr\x00kvx\x00kw\x00\x01kxm\x00kx" + + "p\x00kyirlaatlab\x00lad\x00lag\x00lah\x00laj\x00lbtzlbe\x00lbw\x00lcp" + + "\x00lep\x00lez\x00lgugliimlif\x00lij\x00lis\x00ljp\x00lki\x00lkt\x00lmn" + + "\x00lmo\x00lninloaolol\x00loz\x00lrc\x00ltitltg\x00luublua\x00luo\x00luy" + + "\x00luz\x00lvavlwl\x00lzh\x00lzz\x00mad\x00maf\x00mag\x00mai\x00mak\x00m" + + "an\x00mas\x00maz\x00mdf\x00mdh\x00mdr\x00men\x00mer\x00mfa\x00mfe\x00mgl" + + "gmgh\x00mgo\x00mgp\x00mgy\x00mhahmirimin\x00mis\x00mkkdmlalmls\x00mnonmn" + + "i\x00mnw\x00moolmoe\x00moh\x00mos\x00mrarmrd\x00mrj\x00mro\x00mssamtltmt" + + "r\x00mua\x00mul\x00mus\x00mvy\x00mwk\x00mwr\x00mwv\x00mxc\x00myyamyv\x00" + + "myx\x00myz\x00mzn\x00naaunah\x00nan\x00nap\x00naq\x00nbobnch\x00nddendc" + + "\x00nds\x00neepnew\x00ngdongl\x00nhe\x00nhw\x00nij\x00niu\x00njo\x00nlld" + + "nmg\x00nnnonnh\x00noornod\x00noe\x00non\x00nqo\x00nrblnsk\x00nso\x00nus" + + "\x00nvavnxq\x00nyyanym\x00nyn\x00nzi\x00occiojjiomrmorriosssosa\x00otk" + + "\x00paanpag\x00pal\x00pam\x00pap\x00pau\x00pcd\x00pcm\x00pdc\x00pdt\x00p" + + "eo\x00pfl\x00phn\x00pilipka\x00pko\x00plolpms\x00pnt\x00pon\x00pra\x00pr" + + "d\x00prg\x00psusptorpuu\x00quuequc\x00qug\x00raj\x00rcf\x00rej\x00rgn" + + "\x00ria\x00rif\x00rjs\x00rkt\x00rmohrmf\x00rmo\x00rmt\x00rmu\x00rnunrng" + + "\x00roonrob\x00rof\x00rtm\x00ruusrue\x00rug\x00rw\x00\x04rwk\x00ryu\x00s" + + "aansaf\x00sah\x00saq\x00sas\x00sat\x00saz\x00sbp\x00scrdsck\x00scn\x00sc" + + "o\x00scs\x00sdndsdc\x00sdh\x00semesef\x00seh\x00sei\x00ses\x00sgagsga" + + "\x00sgs\x00sh\x00\x02shi\x00shn\x00siinsid\x00sklkskr\x00sllvsli\x00sly" + + "\x00smmosma\x00smi\x00smj\x00smn\x00smp\x00sms\x00snnasnk\x00soomsou\x00" + + "sqqisrrpsrb\x00srn\x00srr\x00srx\x00ssswssy\x00stotstq\x00suunsuk\x00sus" + + "\x00svweswwaswb\x00swc\x00swg\x00swv\x00sxn\x00syl\x00syr\x00szl\x00taam" + + "taj\x00tbw\x00tcy\x00tdd\x00tdg\x00tdh\x00teeltem\x00teo\x00tet\x00tggkt" + + "hhathl\x00thq\x00thr\x00tiirtig\x00tiv\x00tkuktkl\x00tkr\x00tkt\x00tlglt" + + "ly\x00tmh\x00tnsntoontog\x00tpi\x00trurtru\x00trv\x00tssotsd\x00tsf\x00t" + + "sg\x00tsj\x00ttatttj\x00tts\x00ttt\x00tum\x00tvl\x00twwitwq\x00txg\x00ty" + + "ahtyv\x00tzm\x00udm\x00ugiguga\x00ukkruli\x00umb\x00und\x00unr\x00unx" + + "\x00urrduzzbvai\x00veenvec\x00vep\x00viievic\x00vls\x00vmf\x00vmw\x00voo" + + "lvot\x00vro\x00vun\x00walnwae\x00wal\x00war\x00wbp\x00wbq\x00wbr\x00wls" + + "\x00wni\x00woolwtm\x00wuu\x00xav\x00xcr\x00xhhoxlc\x00xld\x00xmf\x00xmn" + + "\x00xmr\x00xna\x00xnr\x00xog\x00xpr\x00xsa\x00xsr\x00yao\x00yap\x00yav" + + "\x00ybb\x00yiidyooryrl\x00yua\x00yue\x00zahazag\x00zbl\x00zdj\x00zea\x00" + + "zgh\x00zhhozmi\x00zuulzxx\x00zza\x00\xff\xff\xff\xff" -const langNoIndexOffset = 1319 +const langNoIndexOffset = 713 // langNoIndex is a bit vector of all 3-letter language codes that are not used as an index // in lookup tables. The language ids for these language codes are derived directly @@ -258,194 +198,194 @@ const langNoIndexOffset = 1319 // Size: 2197 bytes, 2197 elements var langNoIndex = [2197]uint8{ // Entry 0 - 3F - 0xff, 0xf8, 0xed, 0xfe, 0xeb, 0xd7, 0x3b, 0xd2, - 0xfb, 0xbf, 0x7a, 0xfa, 0x37, 0x1d, 0x3c, 0x57, - 0x6e, 0x97, 0x73, 0x38, 0xfb, 0xea, 0xbf, 0x70, - 0xad, 0x03, 0xff, 0xff, 0xcf, 0x05, 0x84, 0x62, - 0xe9, 0xbf, 0xfd, 0xbf, 0xbf, 0xf7, 0xfd, 0x77, - 0x0f, 0xff, 0xef, 0x6f, 0xff, 0xfb, 0xdf, 0xe2, - 0xc9, 0xf8, 0x7f, 0x7e, 0x4d, 0xb8, 0x0a, 0x6a, - 0x7c, 0xea, 0xe3, 0xfa, 0x7a, 0xbf, 0x67, 0xff, + 0xff, 0xfd, 0xfd, 0xfe, 0xef, 0xf7, 0xbf, 0xd2, + 0xfb, 0xbf, 0xfe, 0xfa, 0xb7, 0x1d, 0x3c, 0x57, + 0x6f, 0x97, 0x73, 0xf8, 0xff, 0xef, 0xff, 0x70, + 0xaf, 0x03, 0xff, 0xff, 0xcf, 0x05, 0x85, 0x62, + 0xe9, 0xbf, 0xfd, 0xff, 0xff, 0xf7, 0xfd, 0x77, + 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe3, + 0xc9, 0xff, 0xff, 0xff, 0x4d, 0xb8, 0x0a, 0x6a, + 0x7e, 0xfa, 0xe3, 0xfe, 0x7e, 0xff, 0x77, 0xff, // Entry 40 - 7F - 0xff, 0xff, 0xff, 0xdf, 0x2a, 0x54, 0x91, 0xc0, - 0x5d, 0xe3, 0x97, 0x14, 0x07, 0x20, 0xdd, 0xed, - 0x9f, 0x3f, 0xc9, 0x21, 0xf8, 0x3f, 0x94, 0x35, - 0x7c, 0x5f, 0xff, 0x5f, 0x8e, 0x6e, 0xdf, 0xff, - 0xff, 0xff, 0x55, 0x7c, 0xd3, 0xfd, 0xbf, 0xb5, - 0x7b, 0xdf, 0x7f, 0xf7, 0xca, 0xfe, 0xdb, 0xa3, - 0xa8, 0xff, 0x1f, 0x67, 0x7f, 0xeb, 0xef, 0xce, - 0xff, 0xff, 0x9f, 0xff, 0xb7, 0xef, 0xfe, 0xcf, + 0xff, 0xff, 0xff, 0xdf, 0x2b, 0xf4, 0xf1, 0xe0, + 0x5d, 0xe7, 0x9f, 0x14, 0x07, 0x20, 0xdf, 0xed, + 0x9f, 0x3f, 0xc9, 0x21, 0xf8, 0x3f, 0x94, 0xf7, + 0x7e, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xff, + 0xff, 0xff, 0x5f, 0xfc, 0xdb, 0xfd, 0xbf, 0xb5, + 0x7b, 0xdf, 0x7f, 0xf7, 0xeb, 0xfe, 0xff, 0xa7, + 0xbd, 0xff, 0x7f, 0xf7, 0xff, 0xef, 0xef, 0xef, + 0xff, 0xff, 0x9f, 0xff, 0xff, 0xef, 0xff, 0xdf, // Entry 80 - BF - 0xdb, 0xff, 0xf3, 0xcd, 0xfb, 0x2f, 0xff, 0xff, - 0xbb, 0xee, 0xf7, 0xbd, 0xdb, 0xff, 0x5f, 0xf7, - 0xfd, 0xf2, 0xfd, 0xff, 0x5e, 0x2f, 0x3b, 0xba, - 0x7e, 0xff, 0xff, 0xfe, 0xf7, 0xff, 0xdd, 0xff, - 0xfd, 0xdf, 0xfb, 0xfe, 0x9d, 0xb4, 0xd3, 0xff, - 0xef, 0xff, 0xdf, 0xf7, 0x7f, 0xb7, 0xfd, 0xd5, + 0xff, 0xff, 0xf3, 0xff, 0xfb, 0x2f, 0xff, 0xff, + 0xfb, 0xee, 0xff, 0xbd, 0xdb, 0xff, 0xdf, 0xf7, + 0xff, 0xfa, 0xfd, 0xff, 0x7e, 0xaf, 0x7b, 0xfe, + 0x7f, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xdf, 0xff, + 0xff, 0xdf, 0xfb, 0xff, 0xfd, 0xfc, 0xfb, 0xff, + 0xff, 0xff, 0xff, 0xf7, 0x7f, 0xbf, 0xfd, 0xd5, 0xa5, 0x77, 0x40, 0xff, 0x9c, 0xc1, 0x41, 0x2c, - 0x08, 0x20, 0x41, 0x00, 0x50, 0x40, 0x00, 0x80, + 0x08, 0x24, 0x41, 0x00, 0x50, 0x40, 0x00, 0x80, // Entry C0 - FF 0xfb, 0x4a, 0xf2, 0x9f, 0xb4, 0x42, 0x41, 0x96, - 0x1b, 0x14, 0x08, 0xf2, 0x2b, 0xe7, 0x17, 0x56, - 0x45, 0x7d, 0x0e, 0x1c, 0x37, 0x71, 0xf3, 0xef, + 0x9b, 0x14, 0x88, 0xf6, 0x7b, 0xe7, 0x17, 0x56, + 0x55, 0x7d, 0x0e, 0x1c, 0x37, 0x71, 0xf3, 0xef, 0x97, 0xff, 0x5d, 0x38, 0x64, 0x08, 0x00, 0x10, 0xbc, 0x87, 0xaf, 0xdf, 0xff, 0xf7, 0x73, 0x35, 0x3e, 0x87, 0xc7, 0xdf, 0xff, 0x00, 0x81, 0x00, 0xb0, 0x05, 0x80, 0x00, 0x00, 0x00, 0x00, 0x03, - 0x40, 0x00, 0x40, 0x92, 0x21, 0x50, 0xb1, 0x5d, + 0x40, 0x00, 0x40, 0x92, 0x21, 0xd0, 0xbf, 0x5d, // Entry 100 - 13F - 0xfd, 0xdc, 0xbe, 0x5e, 0x00, 0x00, 0x02, 0x64, - 0x0d, 0x19, 0x41, 0xdf, 0x79, 0x22, 0x00, 0x00, - 0x00, 0x5e, 0x64, 0xdc, 0x24, 0xe5, 0xd9, 0xe3, + 0xfd, 0xde, 0xfe, 0x5e, 0x00, 0x00, 0x02, 0x64, + 0x8d, 0x19, 0xc1, 0xdf, 0x79, 0x22, 0x00, 0x00, + 0x00, 0xdf, 0x6d, 0xdc, 0x26, 0xe5, 0xd9, 0xf3, 0xfe, 0xff, 0xfd, 0xcb, 0x9f, 0x14, 0x01, 0x0c, 0x86, 0x00, 0xd1, 0x00, 0xf0, 0xc5, 0x67, 0x5f, - 0x56, 0x89, 0x5e, 0xb5, 0x6c, 0xaf, 0x03, 0x00, - 0x02, 0x00, 0x00, 0x00, 0xc0, 0x37, 0xda, 0x56, - 0x90, 0x69, 0x01, 0x2c, 0x96, 0x69, 0x20, 0xfb, + 0x56, 0x89, 0x5e, 0xb7, 0xec, 0xef, 0x03, 0x00, + 0x02, 0x00, 0x00, 0x00, 0xc0, 0x77, 0xda, 0x57, + 0x90, 0x69, 0x01, 0x2c, 0x96, 0x79, 0xe0, 0xff, // Entry 140 - 17F - 0xff, 0x3f, 0x00, 0x00, 0x00, 0x01, 0x08, 0x16, - 0x01, 0x00, 0x00, 0xb0, 0x14, 0x03, 0x50, 0x06, + 0xff, 0x7f, 0x00, 0x00, 0x00, 0x01, 0x08, 0x56, + 0x01, 0x00, 0x00, 0xb0, 0x14, 0x03, 0x50, 0x16, 0x0a, 0x00, 0x01, 0x00, 0x00, 0x00, 0x11, 0x09, 0x00, 0x00, 0x60, 0x10, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x44, 0x00, 0x00, 0x10, 0x00, 0x04, 0x08, 0x00, 0x00, 0x04, 0x00, 0x80, 0x28, 0x04, 0x00, 0x00, 0x50, 0xd5, 0x2d, 0x00, 0x64, 0x35, - 0x24, 0x52, 0xf4, 0xd4, 0xbd, 0x62, 0xc9, 0x03, + 0x24, 0x53, 0xf5, 0xd4, 0xbd, 0xe2, 0xcd, 0x03, // Entry 180 - 1BF 0x00, 0x80, 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x04, 0x13, 0x39, 0x01, 0xdd, 0x57, 0x98, - 0x21, 0x18, 0x81, 0x00, 0x00, 0x01, 0x40, 0x82, + 0x00, 0x04, 0x17, 0x39, 0x01, 0xdd, 0x57, 0x98, + 0x21, 0x98, 0xa5, 0x00, 0x00, 0x01, 0x40, 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x01, 0x40, 0x00, 0x44, 0x00, 0x00, 0x80, 0xea, + 0x01, 0x40, 0x00, 0x44, 0x00, 0x00, 0xb0, 0xfe, 0xa9, 0x39, 0x00, 0x02, 0x00, 0x00, 0x00, 0x04, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, // Entry 1C0 - 1FF 0x00, 0x01, 0x28, 0x05, 0x00, 0x00, 0x00, 0x00, - 0x04, 0x20, 0x04, 0xa6, 0x00, 0x04, 0x00, 0x00, - 0x81, 0x50, 0x00, 0x00, 0x00, 0x11, 0x84, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x06, 0x55, - 0x02, 0x10, 0x08, 0x04, 0x00, 0x00, 0x00, 0x40, - 0x30, 0x83, 0x01, 0x00, 0x00, 0x00, 0x11, 0x00, + 0x04, 0x20, 0x04, 0xa6, 0x08, 0x04, 0x00, 0x08, + 0x81, 0x50, 0x00, 0x00, 0x08, 0x11, 0x86, 0x40, + 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x06, 0x55, + 0x02, 0x10, 0x08, 0x04, 0x00, 0x00, 0x00, 0x60, + 0x3b, 0x83, 0x11, 0x00, 0x00, 0x00, 0x11, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x1e, 0xcd, 0xbf, 0x7e, 0xbf, + 0x00, 0x00, 0x00, 0xbe, 0xdf, 0xff, 0xfe, 0xbf, // Entry 200 - 23F - 0xdf, 0xc3, 0x83, 0x82, 0xc0, 0xfb, 0x57, 0x27, - 0xcd, 0x55, 0xe7, 0x01, 0x00, 0x20, 0xb2, 0xc5, - 0xa4, 0x45, 0x25, 0x9b, 0x02, 0xcf, 0xe0, 0xdf, - 0x03, 0x44, 0x08, 0x10, 0x01, 0x04, 0x01, 0xe3, - 0x92, 0x54, 0xdb, 0x28, 0xd1, 0x5f, 0xf6, 0x6d, - 0x79, 0xed, 0x1c, 0x7d, 0x04, 0x08, 0x00, 0x01, - 0x21, 0x12, 0x6c, 0x5f, 0xdd, 0x0e, 0x85, 0x4f, - 0x40, 0x40, 0x00, 0x04, 0xf1, 0xfd, 0x3d, 0x54, + 0xdf, 0xc7, 0x83, 0x82, 0xc0, 0xff, 0xdf, 0x27, + 0xcf, 0x5f, 0xe7, 0x01, 0x10, 0x20, 0xb2, 0xc5, + 0xa4, 0x45, 0x25, 0x9b, 0x03, 0xcf, 0xf0, 0xdf, + 0x03, 0xc4, 0x08, 0x10, 0x01, 0x0e, 0x01, 0xe3, + 0x92, 0x54, 0xdb, 0x38, 0xf1, 0x7f, 0xf7, 0x6d, + 0xf9, 0xff, 0x1c, 0x7d, 0x04, 0x08, 0x00, 0x01, + 0x21, 0x12, 0x6c, 0x5f, 0xdd, 0x0f, 0x85, 0x4f, + 0x40, 0x40, 0x00, 0x04, 0xf9, 0xfd, 0xbd, 0xd4, // Entry 240 - 27F - 0xe8, 0x03, 0xb4, 0x27, 0x23, 0x0d, 0x00, 0x00, - 0x20, 0x7b, 0x38, 0x02, 0x05, 0x84, 0x00, 0xf0, - 0xbb, 0x7e, 0x5a, 0x00, 0x18, 0x04, 0x81, 0x00, - 0x00, 0x00, 0x80, 0x10, 0x90, 0x1c, 0x01, 0x00, + 0xe8, 0x13, 0xf4, 0x27, 0xa3, 0x0d, 0x00, 0x00, + 0x20, 0x7b, 0x39, 0x02, 0x05, 0x84, 0x00, 0xf0, + 0xbf, 0x7f, 0xda, 0x00, 0x18, 0x04, 0x81, 0x00, + 0x00, 0x00, 0x80, 0x10, 0x94, 0x1c, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x40, 0x00, 0x04, - 0x08, 0xa0, 0x70, 0xa5, 0x0c, 0x40, 0x00, 0x00, - 0x11, 0x04, 0x04, 0x68, 0x00, 0x20, 0x70, 0xff, - 0x7b, 0x7f, 0x60, 0x00, 0x05, 0x9b, 0xdd, 0x66, + 0x08, 0xb4, 0x7c, 0xa5, 0x0c, 0x40, 0x00, 0x00, + 0x11, 0x04, 0x04, 0x6c, 0x00, 0x20, 0x70, 0xff, + 0xfb, 0x7f, 0x60, 0x00, 0x05, 0x9b, 0xdd, 0x6e, // Entry 280 - 2BF 0x03, 0x00, 0x11, 0x00, 0x00, 0x00, 0x40, 0x05, 0xb5, 0xb6, 0x80, 0x08, 0x04, 0x00, 0x04, 0x51, - 0xe2, 0xef, 0xfd, 0x3f, 0x05, 0x09, 0x08, 0x05, + 0xe2, 0xff, 0xfd, 0x3f, 0x05, 0x09, 0x08, 0x05, 0x40, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, - 0x08, 0x00, 0x00, 0x00, 0x00, 0x81, 0x00, 0x60, - 0xe5, 0x48, 0x00, 0x81, 0x20, 0xc0, 0x05, 0x80, - 0x03, 0x00, 0x00, 0x00, 0xcc, 0x50, 0x40, 0x04, - 0x84, 0x47, 0x84, 0x40, 0x20, 0x10, 0x00, 0x20, + 0x08, 0x00, 0x00, 0x00, 0x00, 0xa1, 0x02, 0x60, + 0xe5, 0x48, 0x14, 0x89, 0x20, 0xc0, 0x47, 0x80, + 0x07, 0x00, 0x00, 0x00, 0xcc, 0x50, 0x40, 0x24, + 0x85, 0x47, 0x84, 0x40, 0x20, 0x10, 0x00, 0x20, // Entry 2C0 - 2FF - 0x02, 0x50, 0x80, 0x11, 0x00, 0x91, 0x6c, 0xe2, - 0x50, 0x27, 0x1d, 0x11, 0x29, 0x06, 0x59, 0xe9, - 0x33, 0x08, 0x00, 0x20, 0x04, 0x40, 0x10, 0x00, - 0x00, 0x00, 0x50, 0x44, 0x92, 0x49, 0xd6, 0x5d, + 0x02, 0x50, 0x88, 0x11, 0x00, 0xd1, 0x6c, 0xee, + 0x50, 0x27, 0x1d, 0x11, 0x69, 0x06, 0x59, 0xe9, + 0x33, 0x08, 0x00, 0x20, 0x05, 0x40, 0x10, 0x00, + 0x00, 0x00, 0x50, 0x44, 0x96, 0x49, 0xd6, 0x5d, 0xa7, 0x81, 0x47, 0x97, 0xfb, 0x00, 0x10, 0x00, - 0x08, 0x00, 0x80, 0x00, 0x40, 0x04, 0x00, 0x01, - 0x02, 0x00, 0x01, 0x40, 0x80, 0x00, 0x00, 0x08, - 0xd8, 0xeb, 0xf6, 0x39, 0xc4, 0x89, 0x12, 0x00, + 0x08, 0x00, 0x80, 0x00, 0x40, 0x45, 0x00, 0x01, + 0x02, 0x00, 0x01, 0x40, 0x80, 0x00, 0x04, 0x08, + 0xf8, 0xeb, 0xf6, 0x39, 0xc4, 0x89, 0x16, 0x00, // Entry 300 - 33F - 0x00, 0x0c, 0x04, 0x01, 0x20, 0x20, 0xdd, 0xa0, - 0x01, 0x00, 0x00, 0x00, 0x12, 0x00, 0x00, 0x00, - 0x04, 0x10, 0xd0, 0x9d, 0x95, 0x13, 0x04, 0x80, + 0x00, 0x0c, 0x04, 0x01, 0x20, 0x20, 0xdd, 0xa2, + 0x01, 0x00, 0x00, 0x00, 0x12, 0x04, 0x00, 0x00, + 0x04, 0x10, 0xf0, 0x9d, 0x95, 0x13, 0x04, 0x80, 0x00, 0x01, 0xd0, 0x12, 0x40, 0x00, 0x10, 0xb0, 0x10, 0x62, 0x4c, 0xd2, 0x02, 0x01, 0x4a, 0x00, - 0x46, 0x04, 0x00, 0x08, 0x02, 0x00, 0x20, 0x80, + 0x46, 0x04, 0x00, 0x08, 0x02, 0x00, 0x20, 0xc0, 0x00, 0x80, 0x06, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0xf0, 0xd8, 0x6f, 0x15, 0x02, 0x08, 0x00, // Entry 340 - 37F 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x10, 0x01, - 0x00, 0x10, 0x00, 0x00, 0x00, 0xf0, 0x84, 0xe3, - 0xdd, 0xbf, 0xf9, 0xf9, 0x3b, 0x7f, 0x7f, 0xdb, - 0xfd, 0xfc, 0xfe, 0xdf, 0xff, 0xfd, 0xff, 0xf6, - 0xfb, 0xfc, 0xf7, 0x1f, 0xff, 0xb3, 0x6c, 0xff, - 0xd9, 0xad, 0xdf, 0xfe, 0xef, 0xba, 0xdf, 0xff, - 0xff, 0xff, 0xb7, 0xdd, 0x7d, 0xbf, 0xab, 0xff, - 0xfd, 0xfd, 0xdf, 0x2f, 0x9c, 0xdf, 0xf3, 0x6f, + 0x00, 0x10, 0x00, 0x00, 0x00, 0xf8, 0x85, 0xe3, + 0xdd, 0xff, 0xff, 0xff, 0xbb, 0xff, 0x7f, 0xfb, + 0xff, 0xfc, 0xfe, 0xdf, 0xff, 0xff, 0xff, 0xf6, + 0xfb, 0xfe, 0xf7, 0x1f, 0xff, 0xb3, 0xed, 0xff, + 0xdb, 0xed, 0xff, 0xfe, 0xff, 0xfe, 0xdf, 0xff, + 0xff, 0xff, 0xf7, 0xff, 0xfd, 0xff, 0xff, 0xff, + 0xfd, 0xff, 0xdf, 0xaf, 0x9c, 0xff, 0xfb, 0xff, // Entry 380 - 3BF - 0xdf, 0xdd, 0xff, 0xfb, 0xee, 0xd2, 0xab, 0x5f, - 0xd5, 0xdf, 0x7f, 0xff, 0xeb, 0xff, 0xe4, 0x4d, - 0xf9, 0xff, 0xfe, 0xf7, 0xfd, 0xdf, 0xfb, 0xbf, - 0xee, 0xdb, 0x6f, 0xef, 0xff, 0x7f, 0xff, 0xff, - 0xf7, 0x5f, 0xd3, 0x3b, 0xfd, 0xd9, 0xdf, 0xeb, - 0xbc, 0x08, 0x05, 0x24, 0xff, 0x07, 0x70, 0xfe, - 0xe6, 0x5e, 0x00, 0x08, 0x00, 0x83, 0x3d, 0x1b, - 0x06, 0xe6, 0x72, 0x60, 0xd1, 0x3c, 0x7f, 0x44, + 0xff, 0xff, 0xff, 0xff, 0xef, 0xd2, 0xbb, 0xdf, + 0xf5, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xef, + 0xfd, 0xff, 0xff, 0xf7, 0xfd, 0xff, 0xff, 0xff, + 0xef, 0xdb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, + 0xff, 0x5f, 0xd3, 0x7b, 0xfd, 0xd9, 0xdf, 0xef, + 0xbc, 0x18, 0x05, 0x2c, 0xff, 0x07, 0xf0, 0xff, + 0xf7, 0x5f, 0x00, 0x08, 0x00, 0xc3, 0x3d, 0x1b, + 0x06, 0xe6, 0x72, 0xf0, 0xdd, 0x3c, 0x7f, 0x44, // Entry 3C0 - 3FF - 0x02, 0x30, 0x9f, 0x7a, 0x16, 0xbd, 0x7f, 0x57, - 0xf2, 0xff, 0x31, 0xff, 0xf2, 0x1e, 0x90, 0xf7, - 0xf1, 0xf9, 0x45, 0x80, 0x01, 0x02, 0x00, 0x00, + 0x02, 0x30, 0x9f, 0x7a, 0x16, 0xfd, 0xff, 0x57, + 0xf2, 0xff, 0x39, 0xff, 0xf2, 0x1e, 0x95, 0xf7, + 0xf7, 0xff, 0x45, 0x80, 0x01, 0x02, 0x00, 0x00, 0x40, 0x54, 0x9f, 0x8a, 0xd9, 0xd9, 0x0e, 0x11, 0x84, 0x51, 0xc0, 0xf3, 0xfb, 0x47, 0x00, 0x01, 0x05, 0xd1, 0x50, 0x58, 0x00, 0x00, 0x00, 0x10, 0x04, 0x02, 0x00, 0x00, 0x0a, 0x00, 0x17, 0xd2, - 0xb9, 0xfd, 0xfc, 0xba, 0xfe, 0xef, 0xc7, 0xbe, + 0xf9, 0xfd, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, // Entry 400 - 43F - 0x53, 0x6f, 0xdf, 0xe7, 0xdb, 0x65, 0xbb, 0x7f, - 0xfa, 0xff, 0x77, 0xf3, 0xef, 0xbf, 0xfd, 0xf7, - 0xdf, 0xdf, 0x9b, 0x7f, 0xff, 0xff, 0x7f, 0x6f, - 0xf7, 0xfb, 0xeb, 0xdf, 0xbc, 0xff, 0xbf, 0x6b, - 0x7b, 0xfb, 0xff, 0xce, 0x76, 0xbd, 0xf7, 0xf7, - 0xdf, 0xdc, 0xf7, 0xf7, 0xff, 0xdf, 0xf3, 0xfe, - 0xef, 0xff, 0xff, 0xff, 0xb6, 0x7f, 0x7f, 0xde, - 0xf7, 0xb9, 0xeb, 0x77, 0xff, 0xfb, 0xbf, 0xdf, + 0xd7, 0x6f, 0xff, 0xff, 0xdf, 0x7d, 0xbb, 0xff, + 0xff, 0xff, 0xf7, 0xf3, 0xef, 0xff, 0xff, 0xf7, + 0xff, 0xdf, 0xdb, 0x7f, 0xff, 0xff, 0x7f, 0xff, + 0xff, 0xff, 0xef, 0xff, 0xbc, 0xff, 0xff, 0xfb, + 0xff, 0xfb, 0xff, 0xde, 0x76, 0xbd, 0xff, 0xf7, + 0xff, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xf3, 0xfe, + 0xef, 0xff, 0xff, 0xff, 0xff, 0x7f, 0x7f, 0xde, + 0xf7, 0xbb, 0xef, 0xf7, 0xff, 0xfb, 0xbf, 0xdf, // Entry 440 - 47F - 0xfd, 0xfe, 0xfb, 0xff, 0xfe, 0xeb, 0x1f, 0x7d, - 0x2f, 0xfd, 0xb6, 0xb5, 0xa5, 0xfc, 0xff, 0xfd, - 0x7f, 0x4e, 0xbf, 0x8e, 0xae, 0xff, 0xee, 0xdf, - 0x7f, 0xf7, 0x73, 0x02, 0x02, 0x04, 0xfc, 0xf7, - 0xff, 0xb7, 0xd7, 0xef, 0xfe, 0xcd, 0xf5, 0xce, - 0xe2, 0x8e, 0xe7, 0xbf, 0xb7, 0xff, 0x56, 0xbd, - 0xcd, 0xff, 0xfb, 0xff, 0xdf, 0xd7, 0xea, 0xff, - 0xe5, 0x5f, 0x6d, 0x0f, 0xa7, 0x51, 0x04, 0x44, + 0xfd, 0xfe, 0xff, 0xff, 0xfe, 0xff, 0x5f, 0x7d, + 0x7f, 0xff, 0xff, 0xf7, 0xe5, 0xfc, 0xff, 0xfd, + 0x7f, 0x7f, 0xff, 0x9e, 0xae, 0xff, 0xee, 0xff, + 0x7f, 0xf7, 0x7b, 0x02, 0x82, 0x04, 0xff, 0xf7, + 0xff, 0xbf, 0xd7, 0xef, 0xfe, 0xdf, 0xf7, 0xfe, + 0xe2, 0x8e, 0xe7, 0xff, 0xf7, 0xff, 0x56, 0xbd, + 0xcd, 0xff, 0xfb, 0xff, 0xff, 0xdf, 0xef, 0xff, + 0xe5, 0xdf, 0x7d, 0x0f, 0xa7, 0x51, 0x04, 0x44, // Entry 480 - 4BF - 0x13, 0x50, 0x5d, 0xaf, 0xa6, 0xfd, 0x99, 0xfb, - 0x63, 0x1d, 0x53, 0xff, 0xef, 0xb7, 0x35, 0x20, - 0x14, 0x00, 0x55, 0x51, 0x82, 0x65, 0xf5, 0x41, + 0x13, 0xd0, 0x5d, 0xaf, 0xa6, 0xfd, 0xb9, 0xff, + 0x63, 0x5d, 0x5b, 0xff, 0xff, 0xbf, 0x3f, 0x20, + 0x14, 0x00, 0x57, 0x51, 0x82, 0x65, 0xf5, 0x49, 0xe2, 0xff, 0xfc, 0xdf, 0x00, 0x05, 0xc5, 0x05, 0x00, 0x22, 0x00, 0x74, 0x69, 0x10, 0x08, 0x04, 0x41, 0x00, 0x01, 0x06, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x51, 0x20, 0x05, 0x04, 0x01, 0x00, 0x00, + 0x00, 0x51, 0x60, 0x05, 0x04, 0x01, 0x00, 0x00, 0x06, 0x01, 0x20, 0x00, 0x18, 0x01, 0x92, 0xb1, // Entry 4C0 - 4FF - 0xfd, 0x47, 0x49, 0x06, 0x95, 0x06, 0x57, 0xed, - 0xfb, 0x4c, 0x1c, 0x6b, 0x83, 0x04, 0x62, 0x40, - 0x00, 0x11, 0x42, 0x00, 0x00, 0x00, 0x54, 0x83, - 0xb8, 0x4f, 0x10, 0x8c, 0x89, 0x46, 0xde, 0xf7, + 0xfd, 0x67, 0x4b, 0x06, 0x95, 0x06, 0x57, 0xed, + 0xfb, 0x4c, 0x9d, 0x7b, 0x83, 0x04, 0x62, 0x40, + 0x00, 0x15, 0x42, 0x00, 0x00, 0x00, 0x54, 0x83, + 0xf9, 0x4f, 0x10, 0x8c, 0xc9, 0x46, 0xde, 0xf7, 0x13, 0x31, 0x00, 0x20, 0x00, 0x00, 0x00, 0x90, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0a, 0x10, 0x00, - 0x01, 0x00, 0x00, 0xf0, 0x5b, 0xf4, 0xbe, 0x3d, + 0x01, 0x40, 0x00, 0xf0, 0x5b, 0xf4, 0xbe, 0x7d, 0xba, 0xcf, 0xf7, 0xaf, 0x42, 0x04, 0x84, 0x41, // Entry 500 - 53F - 0x30, 0xff, 0x79, 0x72, 0x04, 0x00, 0x00, 0x49, - 0x2d, 0x14, 0x27, 0x57, 0xed, 0xf1, 0x3f, 0xe7, - 0x3f, 0x00, 0x00, 0x02, 0xc6, 0xa0, 0x1e, 0xf8, - 0xbb, 0xff, 0xfd, 0xfb, 0xb7, 0xfd, 0xe5, 0xf7, - 0xfd, 0xfc, 0xd5, 0xed, 0x47, 0xf4, 0x7e, 0x10, + 0xb0, 0xff, 0x79, 0x7a, 0x04, 0x00, 0x00, 0x49, + 0x2d, 0x14, 0x27, 0x77, 0xed, 0xf1, 0xbf, 0xef, + 0x3f, 0x00, 0x00, 0x02, 0xc6, 0xa0, 0x1e, 0xfc, + 0xbb, 0xff, 0xfd, 0xfb, 0xb7, 0xfd, 0xf5, 0xff, + 0xfd, 0xfc, 0xd5, 0xed, 0x47, 0xf4, 0x7f, 0x10, 0x01, 0x01, 0x84, 0x6d, 0xff, 0xf7, 0xdd, 0xf9, - 0x5b, 0x05, 0x86, 0xed, 0xf5, 0x77, 0xbd, 0x3c, - 0x00, 0x00, 0x00, 0x42, 0x71, 0x42, 0x00, 0x40, + 0x5f, 0x05, 0x86, 0xef, 0xf5, 0x77, 0xbd, 0x3c, + 0x00, 0x00, 0x00, 0x43, 0x71, 0x42, 0x00, 0x40, // Entry 540 - 57F 0x00, 0x00, 0x01, 0x43, 0x19, 0x00, 0x08, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, @@ -459,43 +399,43 @@ var langNoIndex = [2197]uint8{ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xab, 0xbd, 0xe7, 0x57, 0xee, 0x13, 0x5d, 0x09, 0xc1, 0x40, 0x21, 0xfa, 0x17, 0x01, 0x80, - 0x00, 0x00, 0x00, 0x00, 0xf0, 0xce, 0xfb, 0xbf, + 0x00, 0x00, 0x00, 0x00, 0xf0, 0xde, 0xff, 0xbf, 0x00, 0x23, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, - 0x00, 0x30, 0x15, 0xa3, 0x10, 0x00, 0x00, 0x00, - 0x11, 0x04, 0x16, 0x00, 0x00, 0x02, 0x00, 0x81, + 0x00, 0x30, 0x95, 0xe3, 0x10, 0x00, 0x00, 0x00, + 0x11, 0x04, 0x16, 0x00, 0x01, 0x02, 0x00, 0x81, 0xa3, 0x01, 0x50, 0x00, 0x00, 0x83, 0x11, 0x40, // Entry 5C0 - 5FF - 0x00, 0x00, 0x00, 0xf0, 0xdd, 0x7b, 0x3e, 0x02, - 0xaa, 0x10, 0x5d, 0x98, 0x52, 0x00, 0x80, 0x20, - 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x02, 0x02, + 0x00, 0x00, 0x00, 0xf0, 0xdd, 0x7b, 0x7e, 0x02, + 0xaa, 0x10, 0x5d, 0xd8, 0x52, 0x00, 0x80, 0x20, + 0x00, 0x00, 0x00, 0x00, 0x40, 0x10, 0x02, 0x02, 0x19, 0x00, 0x10, 0x02, 0x10, 0x61, 0x5a, 0x9d, - 0x31, 0x00, 0x00, 0x00, 0x01, 0x10, 0x02, 0x20, + 0x31, 0x00, 0x00, 0x00, 0x01, 0x50, 0x02, 0x20, 0x00, 0x00, 0x01, 0x00, 0x42, 0x00, 0x20, 0x00, - 0x00, 0x1f, 0xdf, 0xf2, 0xb9, 0xff, 0xfd, 0x3f, - 0x1f, 0x18, 0xcf, 0x9c, 0xbf, 0xaf, 0x5f, 0xfe, + 0x00, 0x1f, 0xdf, 0xf2, 0xfd, 0xff, 0xfd, 0x3f, + 0x9f, 0x18, 0xcf, 0x9c, 0xbf, 0xaf, 0x5f, 0xfe, // Entry 600 - 63F - 0x7b, 0x4b, 0x40, 0x10, 0xe1, 0xfd, 0xaf, 0xd9, - 0xb7, 0xf6, 0xfb, 0xb3, 0xc7, 0xff, 0x6f, 0xf1, - 0x73, 0xb1, 0x7f, 0x9f, 0x7f, 0xbd, 0xfc, 0xb7, - 0xee, 0x1c, 0xfa, 0xcb, 0xef, 0xdd, 0xf9, 0xbd, - 0x6e, 0xae, 0x55, 0xfd, 0x6e, 0x81, 0x76, 0x1f, - 0xd4, 0x77, 0xf5, 0x7d, 0xfb, 0xff, 0xeb, 0xfe, - 0xbe, 0x5f, 0x46, 0x1b, 0xe9, 0x5f, 0x50, 0x18, - 0x02, 0xfa, 0xf7, 0x9d, 0x15, 0x97, 0x05, 0x0f, + 0x7b, 0x4b, 0x40, 0x10, 0xe1, 0xfd, 0xaf, 0xfd, + 0xb7, 0xf7, 0xff, 0xf3, 0xdf, 0xff, 0x6f, 0xf1, + 0x7b, 0xf1, 0x7f, 0xdf, 0x7f, 0xbf, 0xfe, 0xb7, + 0xee, 0x1c, 0xfb, 0xdb, 0xef, 0xdf, 0xff, 0xfd, + 0x7e, 0xbe, 0x57, 0xff, 0x6f, 0x81, 0x76, 0x1f, + 0xd4, 0x77, 0xf5, 0xfd, 0xff, 0xff, 0xeb, 0xfe, + 0xbf, 0x5f, 0x57, 0x1b, 0xeb, 0x5f, 0x50, 0x18, + 0x02, 0xfa, 0xff, 0x9d, 0x15, 0x97, 0x15, 0x0f, // Entry 640 - 67F - 0x75, 0xc4, 0x7d, 0x81, 0x82, 0xf1, 0x57, 0x6c, - 0xff, 0xe4, 0xef, 0x6f, 0xff, 0xfc, 0xdd, 0xde, - 0xfc, 0xfd, 0x76, 0x5f, 0x7a, 0x1f, 0x00, 0x98, - 0x02, 0xfb, 0xa3, 0xef, 0xf3, 0xd6, 0xf2, 0xff, - 0xb9, 0xda, 0x7d, 0x50, 0x1e, 0x15, 0x7b, 0xb4, - 0xf5, 0x3e, 0xff, 0xff, 0xf1, 0xf7, 0xff, 0xe7, - 0x5f, 0xff, 0xff, 0x9e, 0xdb, 0xf6, 0xd7, 0xb9, - 0xef, 0x27, 0x80, 0xbb, 0xc5, 0xff, 0xff, 0xe3, + 0x75, 0xc4, 0x7d, 0x81, 0x82, 0xf1, 0xd7, 0x7e, + 0xff, 0xff, 0xff, 0xef, 0xff, 0xfd, 0xdd, 0xde, + 0xfc, 0xfd, 0xf6, 0x5f, 0x7a, 0x1f, 0x40, 0x98, + 0x02, 0xff, 0xe3, 0xff, 0xf3, 0xd6, 0xf2, 0xff, + 0xfb, 0xdf, 0x7d, 0x50, 0x1e, 0x15, 0x7b, 0xb4, + 0xf5, 0xbe, 0xff, 0xff, 0xf3, 0xf7, 0xff, 0xf7, + 0x7f, 0xff, 0xff, 0xbe, 0xdb, 0xf7, 0xd7, 0xf9, + 0xef, 0x2f, 0x80, 0xbf, 0xc5, 0xff, 0xff, 0xf3, // Entry 680 - 6BF - 0x97, 0x9d, 0xbf, 0x9f, 0xf7, 0xc7, 0xfd, 0x37, - 0xce, 0x7f, 0x04, 0x1d, 0x53, 0x7f, 0xf8, 0xda, - 0x5d, 0xce, 0x7d, 0x06, 0xb9, 0xea, 0x69, 0xa0, - 0x1a, 0x20, 0x00, 0x30, 0x02, 0x04, 0x24, 0x08, + 0x97, 0x9d, 0xff, 0xff, 0xf7, 0xcf, 0xfd, 0xbf, + 0xde, 0x7f, 0x06, 0x1d, 0x57, 0xff, 0xf8, 0xda, + 0x5d, 0xce, 0x7d, 0x16, 0xb9, 0xea, 0x69, 0xa0, + 0x1a, 0x20, 0x00, 0x30, 0x02, 0x04, 0x24, 0x48, 0x04, 0x00, 0x00, 0x40, 0xd4, 0x02, 0x04, 0x00, 0x00, 0x04, 0x00, 0x04, 0x00, 0x20, 0x01, 0x06, 0x50, 0x00, 0x08, 0x00, 0x00, 0x00, 0x24, 0x00, @@ -503,64 +443,64 @@ var langNoIndex = [2197]uint8{ // Entry 6C0 - 6FF 0x14, 0x4d, 0xf1, 0x16, 0x44, 0xd1, 0x42, 0x08, 0x40, 0x00, 0x00, 0x40, 0x00, 0x08, 0x00, 0x00, - 0x00, 0xdc, 0xfb, 0xcb, 0x0e, 0x58, 0x08, 0x41, - 0x04, 0x20, 0x04, 0x00, 0x30, 0x12, 0x40, 0x00, + 0x00, 0xdc, 0xff, 0xeb, 0x1f, 0x58, 0x08, 0x41, + 0x04, 0xa0, 0x04, 0x00, 0x30, 0x12, 0x40, 0x22, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x01, 0x00, 0x00, 0x00, 0x80, 0x10, 0x10, 0xab, - 0x6d, 0x93, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, + 0x01, 0x00, 0x00, 0x00, 0x80, 0x10, 0x10, 0xaf, + 0x6f, 0x93, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0x80, 0x25, 0x00, 0x00, // Entry 700 - 73F 0x00, 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, - 0x80, 0x86, 0xc2, 0x00, 0x00, 0x00, 0x00, 0x01, + 0x80, 0x86, 0xc2, 0x02, 0x00, 0x00, 0x00, 0x01, 0xdf, 0x18, 0x00, 0x00, 0x02, 0xf0, 0xfd, 0x79, 0x3b, 0x00, 0x25, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x03, 0x00, 0x09, 0x20, 0x00, 0x00, 0x01, 0x00, - 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, + 0x00, 0x81, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // Entry 740 - 77F - 0x00, 0x00, 0x00, 0xef, 0xd5, 0xfd, 0xcf, 0x7e, - 0xa0, 0x11, 0x00, 0x00, 0x00, 0x92, 0x01, 0x44, - 0xcd, 0xf9, 0x5c, 0x00, 0x01, 0x00, 0x30, 0x04, - 0x04, 0x55, 0x00, 0x01, 0x04, 0xf4, 0x3f, 0x4a, - 0x01, 0x00, 0x00, 0xb0, 0x80, 0x00, 0x55, 0x55, - 0x97, 0x7c, 0x9f, 0x31, 0xcc, 0x68, 0xd1, 0x03, - 0xd5, 0x57, 0x27, 0x14, 0x01, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x2c, 0xf7, 0xcb, 0x1f, 0x14, 0x60, + 0x00, 0x00, 0x00, 0xef, 0xf7, 0xfd, 0xcf, 0x7e, + 0xa0, 0x11, 0x10, 0x00, 0x00, 0x92, 0x01, 0x44, + 0xcd, 0xf9, 0x5e, 0x00, 0x01, 0x00, 0x30, 0x14, + 0x04, 0x55, 0x10, 0x01, 0x04, 0xf6, 0x3f, 0x7a, + 0x05, 0x04, 0x00, 0xb0, 0x80, 0x00, 0x55, 0x55, + 0x97, 0x7c, 0x9f, 0x71, 0xcc, 0x78, 0xd1, 0x43, + 0xf5, 0x57, 0x67, 0x14, 0x01, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x2c, 0xf7, 0xdb, 0x1f, 0x54, 0x60, // Entry 780 - 7BF - 0x03, 0x68, 0x01, 0x10, 0x8b, 0x38, 0x8a, 0x01, - 0x00, 0x00, 0x20, 0x00, 0x24, 0x44, 0x00, 0x00, + 0x03, 0x68, 0x01, 0x10, 0x8b, 0x38, 0xaa, 0x01, + 0x00, 0x00, 0x30, 0x00, 0x24, 0x44, 0x00, 0x00, 0x10, 0x03, 0x11, 0x02, 0x01, 0x00, 0x00, 0xf0, - 0xf5, 0xff, 0xd5, 0x97, 0xbc, 0x70, 0xd6, 0x78, - 0x78, 0x15, 0x50, 0x00, 0xa4, 0x84, 0xa9, 0x41, + 0xf5, 0xff, 0xd5, 0xd7, 0xbc, 0x70, 0xd6, 0x78, + 0x78, 0x15, 0x50, 0x00, 0xa4, 0x84, 0xe9, 0x41, 0x00, 0x00, 0x00, 0x6b, 0x39, 0x52, 0x74, 0x00, 0xe8, 0x30, 0x90, 0x6a, 0x92, 0x00, 0x00, 0x02, - 0xff, 0xef, 0xff, 0x4b, 0x85, 0x53, 0xf4, 0xed, + 0xff, 0xef, 0xff, 0x4f, 0x85, 0x53, 0xf4, 0xed, // Entry 7C0 - 7FF - 0xdd, 0xbf, 0x72, 0x19, 0xc7, 0x0c, 0xd5, 0x42, - 0x54, 0xdd, 0x77, 0x14, 0x00, 0x80, 0x40, 0x56, - 0xcc, 0x16, 0x9e, 0xea, 0x35, 0x7d, 0xef, 0xff, - 0xbd, 0xa4, 0xaf, 0x01, 0x44, 0x18, 0x01, 0x4d, + 0xdd, 0xbf, 0x72, 0x19, 0xc7, 0x0c, 0xf5, 0x42, + 0x54, 0xdd, 0x77, 0x14, 0x00, 0x80, 0xc0, 0x56, + 0xcc, 0x16, 0x9e, 0xfb, 0x35, 0x7d, 0xef, 0xff, + 0xbd, 0xa4, 0xaf, 0x01, 0x44, 0x18, 0x01, 0x5d, 0x4e, 0x4a, 0x08, 0x50, 0x28, 0x30, 0xe0, 0x80, - 0x10, 0x20, 0x24, 0x00, 0xff, 0x2f, 0xd3, 0x60, - 0xfe, 0x01, 0x02, 0x88, 0x0a, 0x40, 0x16, 0x01, - 0x01, 0x15, 0x2b, 0x3c, 0x01, 0x00, 0x00, 0x10, + 0x10, 0x20, 0x24, 0x00, 0xff, 0x3f, 0xdf, 0x67, + 0xfe, 0x01, 0x06, 0x88, 0x0a, 0x40, 0x16, 0x01, + 0x01, 0x15, 0x2b, 0x3e, 0x01, 0x00, 0x00, 0x10, // Entry 800 - 83F - 0x90, 0x49, 0x41, 0x02, 0x02, 0x01, 0xe1, 0xbf, - 0xbf, 0x03, 0x00, 0x00, 0x10, 0xd4, 0xa3, 0xd1, - 0x40, 0x9c, 0x44, 0xdf, 0xf5, 0x8f, 0x66, 0xb3, - 0x55, 0x20, 0xd4, 0xc1, 0xd8, 0x30, 0x3d, 0x80, - 0x00, 0x00, 0x00, 0x04, 0xd4, 0x11, 0xc5, 0x84, - 0x2e, 0x50, 0x00, 0x22, 0x50, 0x6e, 0xbd, 0x93, + 0x90, 0x69, 0x45, 0x02, 0x02, 0x01, 0xe1, 0xbf, + 0xbf, 0x03, 0x00, 0x00, 0x10, 0xd4, 0xa7, 0xd1, + 0x54, 0x9e, 0x44, 0xdf, 0xfd, 0x8f, 0x66, 0xb3, + 0x55, 0x20, 0xd4, 0xc3, 0xd8, 0x30, 0x3d, 0x80, + 0x00, 0x00, 0x00, 0x4c, 0xd4, 0x11, 0xc5, 0x84, + 0x6e, 0x50, 0x00, 0x22, 0x50, 0x6e, 0xbf, 0xdb, 0x07, 0x00, 0x20, 0x10, 0x84, 0xb2, 0x45, 0x10, 0x06, 0x44, 0x00, 0x00, 0x12, 0x02, 0x11, 0x00, // Entry 840 - 87F 0xf0, 0xfb, 0xfd, 0x3f, 0x05, 0x00, 0x12, 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x02, 0x00, 0x00, 0x00, 0x00, 0x03, 0x30, 0x02, 0x28, - 0x84, 0x00, 0x23, 0xc0, 0x23, 0x24, 0x00, 0x00, - 0x00, 0xcb, 0xe4, 0x3a, 0x42, 0x88, 0x14, 0xf1, - 0xef, 0xff, 0x7f, 0x12, 0x01, 0x01, 0x84, 0x50, + 0x84, 0x00, 0x33, 0xc0, 0x23, 0x24, 0x00, 0x00, + 0x00, 0xcb, 0xe4, 0x3a, 0x42, 0xc8, 0x14, 0xf1, + 0xef, 0xff, 0x7f, 0x16, 0x01, 0x01, 0x84, 0x50, 0x07, 0xfc, 0xff, 0xff, 0x0f, 0x01, 0x00, 0x40, 0x10, 0x38, 0x01, 0x01, 0x1c, 0x12, 0x40, 0xe1, // Entry 880 - 8BF @@ -577,191 +517,189 @@ var altLangISO3 tag.Index = "---\x00cor\x00hbs\x01heb\x02kin\x03spa\x04yid\x05\x // altLangIndex is used to convert indexes in altLangISO3 to langIDs. // Size: 12 bytes, 6 elements var altLangIndex = [6]uint16{ - 0x0278, 0x03fd, 0x01f3, 0x03dc, 0x0139, 0x0200, + 0x014a, 0x0225, 0x0105, 0x020a, 0x009d, 0x010b, } // langAliasMap maps langIDs to their suggested replacements. -// Size: 644 bytes, 161 elements -var langAliasMap = [161]fromTo{ - 0: {from: 0x81, to: 0x87}, - 1: {from: 0x181, to: 0x1a7}, - 2: {from: 0x1eb, to: 0x1da}, - 3: {from: 0x1f3, to: 0x1b5}, - 4: {from: 0x200, to: 0x508}, - 5: {from: 0x207, to: 0x206}, - 6: {from: 0x307, to: 0x3d3}, - 7: {from: 0x33e, to: 0x366}, - 8: {from: 0x3fd, to: 0x428}, - 9: {from: 0x470, to: 0x14e}, - 10: {from: 0x486, to: 0x447}, - 11: {from: 0x498, to: 0x20}, - 12: {from: 0x533, to: 0x539}, - 13: {from: 0x584, to: 0x129}, - 14: {from: 0x625, to: 0x1ea6}, - 15: {from: 0x646, to: 0x427}, - 16: {from: 0x657, to: 0x427}, - 17: {from: 0x6e2, to: 0x39}, - 18: {from: 0x6ed, to: 0x1d0}, - 19: {from: 0x733, to: 0x2196}, - 20: {from: 0x7a8, to: 0x55}, - 21: {from: 0x7ae, to: 0x2990}, - 22: {from: 0x7ba, to: 0x57}, - 23: {from: 0x7db, to: 0x140}, - 24: {from: 0x801, to: 0x59}, - 25: {from: 0x80a, to: 0x8c}, - 26: {from: 0x873, to: 0x805}, - 27: {from: 0x8b8, to: 0xed8}, - 28: {from: 0x9e4, to: 0x328}, - 29: {from: 0xa2b, to: 0x2bc}, - 30: {from: 0xa32, to: 0xbd}, - 31: {from: 0xab3, to: 0x3317}, - 32: {from: 0xb2d, to: 0x51f}, - 33: {from: 0xb6a, to: 0x264f}, - 34: {from: 0xb73, to: 0xbb8}, - 35: {from: 0xb90, to: 0x444}, - 36: {from: 0xbb1, to: 0x421e}, - 37: {from: 0xbb4, to: 0x51f}, - 38: {from: 0xbf3, to: 0x2d9c}, - 39: {from: 0xc23, to: 0x3176}, - 40: {from: 0xcae, to: 0xf0}, - 41: {from: 0xcfd, to: 0xf6}, - 42: {from: 0xdbd, to: 0x116}, - 43: {from: 0xdcc, to: 0x324}, - 44: {from: 0xded, to: 0xdf0}, - 45: {from: 0xdf3, to: 0x526}, - 46: {from: 0xed4, to: 0x204f}, - 47: {from: 0xee3, to: 0x2e8f}, - 48: {from: 0xf2e, to: 0x35e}, - 49: {from: 0x10c5, to: 0x13b}, - 50: {from: 0x10f9, to: 0x2c7}, - 51: {from: 0x1195, to: 0x1e4}, - 52: {from: 0x126e, to: 0x20}, - 53: {from: 0x1419, to: 0x159}, - 54: {from: 0x1465, to: 0x149}, - 55: {from: 0x1514, to: 0xd90}, - 56: {from: 0x1518, to: 0x387}, - 57: {from: 0x1527, to: 0x16ba}, - 58: {from: 0x1575, to: 0x208}, - 59: {from: 0x1578, to: 0x109}, - 60: {from: 0x1598, to: 0x3ca4}, - 61: {from: 0x165f, to: 0x195}, - 62: {from: 0x16bd, to: 0x131}, - 63: {from: 0x16f5, to: 0x29ed}, - 64: {from: 0x170d, to: 0x18e}, - 65: {from: 0x171c, to: 0xf34}, - 66: {from: 0x176f, to: 0x1519}, - 67: {from: 0x17fe, to: 0x17ab}, - 68: {from: 0x180b, to: 0x18e8}, - 69: {from: 0x187f, to: 0x42c}, - 70: {from: 0x196e, to: 0x1cf6}, - 71: {from: 0x1a69, to: 0x2ba5}, - 72: {from: 0x1a7f, to: 0x1f0}, - 73: {from: 0x1b4f, to: 0x1f2}, - 74: {from: 0x1b7b, to: 0x150a}, - 75: {from: 0x202d, to: 0x37a6}, - 76: {from: 0x2032, to: 0x20d2}, - 77: {from: 0x204f, to: 0x302}, - 78: {from: 0x20d8, to: 0x26b}, - 79: {from: 0x20e3, to: 0x25a}, - 80: {from: 0x20e7, to: 0x225}, - 81: {from: 0x20ee, to: 0x24d}, - 82: {from: 0x2104, to: 0x21e0}, - 83: {from: 0x212a, to: 0x274}, - 84: {from: 0x218e, to: 0x11d}, - 85: {from: 0x21c3, to: 0x1556}, - 86: {from: 0x21db, to: 0x4fa}, - 87: {from: 0x21e9, to: 0x495}, - 88: {from: 0x2222, to: 0x11d}, - 89: {from: 0x222c, to: 0x11d}, - 90: {from: 0x2257, to: 0x91f}, - 91: {from: 0x230b, to: 0x321b}, - 92: {from: 0x2377, to: 0x335a}, - 93: {from: 0x2467, to: 0x2be}, - 94: {from: 0x24d9, to: 0x2f6}, - 95: {from: 0x24e5, to: 0x2f1}, - 96: {from: 0x24ef, to: 0x316}, - 97: {from: 0x2545, to: 0xb50}, - 98: {from: 0x259e, to: 0xe0}, - 99: {from: 0x2633, to: 0x2c7}, - 100: {from: 0x26be, to: 0x26a9}, - 101: {from: 0x26ee, to: 0x3bf}, - 102: {from: 0x271c, to: 0x3ca4}, - 103: {from: 0x275a, to: 0x26a9}, - 104: {from: 0x277e, to: 0x434d}, - 105: {from: 0x28e4, to: 0x282c}, - 106: {from: 0x2909, to: 0x348}, - 107: {from: 0x297b, to: 0x2d9c}, - 108: {from: 0x2b0f, to: 0x384}, - 109: {from: 0x2bf1, to: 0x38c}, - 110: {from: 0x2c34, to: 0x3ca4}, - 111: {from: 0x2cf1, to: 0x3b5}, - 112: {from: 0x2d08, to: 0x58c}, - 113: {from: 0x2d3c, to: 0x143}, - 114: {from: 0x2d3d, to: 0x143}, - 115: {from: 0x2df4, to: 0x2e8}, - 116: {from: 0x2dfd, to: 0x19c1}, - 117: {from: 0x2e0f, to: 0x2d8a}, - 118: {from: 0x2e16, to: 0x289}, - 119: {from: 0x2e49, to: 0x7c}, - 120: {from: 0x2e5a, to: 0x2277}, - 121: {from: 0x2e95, to: 0x2e90}, - 122: {from: 0x2ee4, to: 0x2ecc}, - 123: {from: 0x3188, to: 0x3bb}, - 124: {from: 0x335b, to: 0x3383}, - 125: {from: 0x341f, to: 0x3d3}, - 126: {from: 0x34e3, to: 0x18c5}, - 127: {from: 0x35db, to: 0x408}, - 128: {from: 0x364d, to: 0x23e}, - 129: {from: 0x366b, to: 0x3ea}, - 130: {from: 0x36f2, to: 0x43b}, - 131: {from: 0x37b5, to: 0x11d}, - 132: {from: 0x380b, to: 0x38e7}, - 133: {from: 0x3820, to: 0x2c90}, - 134: {from: 0x3824, to: 0xa7}, - 135: {from: 0x3827, to: 0x321d}, - 136: {from: 0x3861, to: 0x399b}, - 137: {from: 0x3887, to: 0x3fb5}, - 138: {from: 0x389a, to: 0x39cc}, - 139: {from: 0x38a9, to: 0x1f99}, - 140: {from: 0x38aa, to: 0x2e8f}, - 141: {from: 0x3951, to: 0x474}, - 142: {from: 0x3b43, to: 0xd86}, - 143: {from: 0x3b6d, to: 0x132}, - 144: {from: 0x3c8e, to: 0x4b2}, - 145: {from: 0x3fb2, to: 0xfc}, - 146: {from: 0x41fd, to: 0xa86}, - 147: {from: 0x42b3, to: 0x568}, - 148: {from: 0x42ee, to: 0x3f55}, - 149: {from: 0x436d, to: 0x251}, - 150: {from: 0x43c0, to: 0x36c0}, - 151: {from: 0x43c2, to: 0x10b}, - 152: {from: 0x44a4, to: 0x3317}, - 153: {from: 0x44d8, to: 0x508}, - 154: {from: 0x45bf, to: 0x23fe}, - 155: {from: 0x45d2, to: 0x26d1}, - 156: {from: 0x4605, to: 0x48a3}, - 157: {from: 0x46a3, to: 0x4695}, - 158: {from: 0x4733, to: 0x473a}, - 159: {from: 0x490b, to: 0x316}, - 160: {from: 0x499c, to: 0x519}, +// Size: 640 bytes, 160 elements +var langAliasMap = [160]fromTo{ + 0: {from: 0xc4, to: 0xda}, + 1: {from: 0xff, to: 0xf8}, + 2: {from: 0x105, to: 0xe0}, + 3: {from: 0x10b, to: 0x2b9}, + 4: {from: 0x110, to: 0x10f}, + 5: {from: 0x192, to: 0x203}, + 6: {from: 0x1af, to: 0x1c1}, + 7: {from: 0x225, to: 0x23b}, + 8: {from: 0x268, to: 0xaa}, + 9: {from: 0x274, to: 0x252}, + 10: {from: 0x27d, to: 0xd}, + 11: {from: 0x2d5, to: 0x2db}, + 12: {from: 0x326, to: 0x93}, + 13: {from: 0x3c7, to: 0x1c48}, + 14: {from: 0x3e8, to: 0x23a}, + 15: {from: 0x3f9, to: 0x23a}, + 16: {from: 0x484, to: 0x15}, + 17: {from: 0x48f, to: 0xf3}, + 18: {from: 0x4d5, to: 0x1f38}, + 19: {from: 0x54a, to: 0x23}, + 20: {from: 0x550, to: 0x2732}, + 21: {from: 0x55c, to: 0x24}, + 22: {from: 0x57d, to: 0xa1}, + 23: {from: 0x5a3, to: 0x26}, + 24: {from: 0x5ac, to: 0x42}, + 25: {from: 0x615, to: 0x5a7}, + 26: {from: 0x65a, to: 0xc7a}, + 27: {from: 0x786, to: 0x1a5}, + 28: {from: 0x7cd, to: 0x16e}, + 29: {from: 0x7d4, to: 0x59}, + 30: {from: 0x855, to: 0x30b9}, + 31: {from: 0x8cf, to: 0x2c4}, + 32: {from: 0x90c, to: 0x23f1}, + 33: {from: 0x915, to: 0x95a}, + 34: {from: 0x932, to: 0x24f}, + 35: {from: 0x953, to: 0x3fc0}, + 36: {from: 0x956, to: 0x2c4}, + 37: {from: 0x995, to: 0x2b3e}, + 38: {from: 0x9c5, to: 0x2f18}, + 39: {from: 0xa50, to: 0x73}, + 40: {from: 0xa9f, to: 0x79}, + 41: {from: 0xb5f, to: 0x8a}, + 42: {from: 0xb6e, to: 0x1a2}, + 43: {from: 0xb8f, to: 0xb92}, + 44: {from: 0xb95, to: 0x2c8}, + 45: {from: 0xc76, to: 0x1df1}, + 46: {from: 0xc85, to: 0x2c31}, + 47: {from: 0xcd0, to: 0x1bd}, + 48: {from: 0xe67, to: 0x9f}, + 49: {from: 0xe9b, to: 0x179}, + 50: {from: 0xf37, to: 0xfc}, + 51: {from: 0x1010, to: 0xd}, + 52: {from: 0x11bb, to: 0xaf}, + 53: {from: 0x1207, to: 0xa6}, + 54: {from: 0x12b6, to: 0xb32}, + 55: {from: 0x12ba, to: 0x1d2}, + 56: {from: 0x12c9, to: 0x145c}, + 57: {from: 0x1317, to: 0x111}, + 58: {from: 0x131a, to: 0x85}, + 59: {from: 0x133a, to: 0x3a46}, + 60: {from: 0x1401, to: 0xcc}, + 61: {from: 0x145f, to: 0x9a}, + 62: {from: 0x1497, to: 0x278f}, + 63: {from: 0x14af, to: 0xca}, + 64: {from: 0x14be, to: 0xcd6}, + 65: {from: 0x1511, to: 0x12bb}, + 66: {from: 0x15a0, to: 0x154d}, + 67: {from: 0x15ad, to: 0x168a}, + 68: {from: 0x1621, to: 0x23f}, + 69: {from: 0x1710, to: 0x1a98}, + 70: {from: 0x180b, to: 0x2947}, + 71: {from: 0x1821, to: 0x102}, + 72: {from: 0x18f1, to: 0x104}, + 73: {from: 0x191d, to: 0x12ac}, + 74: {from: 0x1dcf, to: 0x3548}, + 75: {from: 0x1dd4, to: 0x1e74}, + 76: {from: 0x1df1, to: 0x18f}, + 77: {from: 0x1e7a, to: 0x145}, + 78: {from: 0x1e85, to: 0x13b}, + 79: {from: 0x1e89, to: 0x122}, + 80: {from: 0x1e90, to: 0x138}, + 81: {from: 0x1ea6, to: 0x1f82}, + 82: {from: 0x1ecc, to: 0x147}, + 83: {from: 0x1f30, to: 0x8d}, + 84: {from: 0x1f65, to: 0x12f8}, + 85: {from: 0x1f7d, to: 0x4235}, + 86: {from: 0x1f8b, to: 0x371a}, + 87: {from: 0x1fc4, to: 0x8d}, + 88: {from: 0x1fce, to: 0x8d}, + 89: {from: 0x1ff9, to: 0x6c1}, + 90: {from: 0x20ad, to: 0x2fbd}, + 91: {from: 0x2119, to: 0x30fc}, + 92: {from: 0x2209, to: 0x170}, + 93: {from: 0x227b, to: 0x18c}, + 94: {from: 0x2287, to: 0x189}, + 95: {from: 0x2291, to: 0x19a}, + 96: {from: 0x22e7, to: 0x8f2}, + 97: {from: 0x2340, to: 0x69}, + 98: {from: 0x23d5, to: 0x179}, + 99: {from: 0x2460, to: 0x244b}, + 100: {from: 0x2490, to: 0x1f4}, + 101: {from: 0x24be, to: 0x3a46}, + 102: {from: 0x24fc, to: 0x244b}, + 103: {from: 0x2520, to: 0x40ef}, + 104: {from: 0x2686, to: 0x25ce}, + 105: {from: 0x26ab, to: 0x1b4}, + 106: {from: 0x271d, to: 0x2b3e}, + 107: {from: 0x28b1, to: 0x1d1}, + 108: {from: 0x2993, to: 0x1d3}, + 109: {from: 0x29d6, to: 0x3a46}, + 110: {from: 0x2a93, to: 0x1ee}, + 111: {from: 0x2aaa, to: 0x32e}, + 112: {from: 0x2ade, to: 0xa4}, + 113: {from: 0x2adf, to: 0xa4}, + 114: {from: 0x2b96, to: 0x183}, + 115: {from: 0x2b9f, to: 0x1763}, + 116: {from: 0x2bb1, to: 0x2b2c}, + 117: {from: 0x2bb8, to: 0x152}, + 118: {from: 0x2beb, to: 0x37}, + 119: {from: 0x2bfc, to: 0x2019}, + 120: {from: 0x2c37, to: 0x2c32}, + 121: {from: 0x2c86, to: 0x2c6e}, + 122: {from: 0x2f2a, to: 0x1f1}, + 123: {from: 0x30fd, to: 0x3125}, + 124: {from: 0x31c1, to: 0x203}, + 125: {from: 0x3285, to: 0x1667}, + 126: {from: 0x337d, to: 0x22a}, + 127: {from: 0x33ef, to: 0x132}, + 128: {from: 0x340d, to: 0x215}, + 129: {from: 0x3494, to: 0x248}, + 130: {from: 0x3557, to: 0x8d}, + 131: {from: 0x35ad, to: 0x3689}, + 132: {from: 0x35c2, to: 0x2a32}, + 133: {from: 0x35c6, to: 0x4c}, + 134: {from: 0x35c9, to: 0x2fbf}, + 135: {from: 0x3603, to: 0x373d}, + 136: {from: 0x3629, to: 0x3d57}, + 137: {from: 0x363c, to: 0x376e}, + 138: {from: 0x364b, to: 0x1d3b}, + 139: {from: 0x364c, to: 0x2c31}, + 140: {from: 0x36f3, to: 0x26a}, + 141: {from: 0x38e5, to: 0xb28}, + 142: {from: 0x390f, to: 0xe91}, + 143: {from: 0x3a30, to: 0x28d}, + 144: {from: 0x3d54, to: 0x7f}, + 145: {from: 0x3f9f, to: 0x828}, + 146: {from: 0x4055, to: 0x30a}, + 147: {from: 0x4090, to: 0x3cf7}, + 148: {from: 0x410f, to: 0x13a}, + 149: {from: 0x4162, to: 0x3462}, + 150: {from: 0x4164, to: 0x86}, + 151: {from: 0x4246, to: 0x30b9}, + 152: {from: 0x427a, to: 0x2b9}, + 153: {from: 0x4361, to: 0x21a0}, + 154: {from: 0x4374, to: 0x2473}, + 155: {from: 0x43a7, to: 0x4645}, + 156: {from: 0x4445, to: 0x4437}, + 157: {from: 0x44d5, to: 0x44dc}, + 158: {from: 0x46ad, to: 0x19a}, + 159: {from: 0x473e, to: 0x2be}, } -// Size: 161 bytes, 161 elements -var langAliasTypes = [161]langAliasType{ +// Size: 160 bytes, 160 elements +var langAliasTypes = [160]langAliasType{ // Entry 0 - 3F - 1, 0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 1, 0, 0, 1, 2, - 1, 1, 2, 0, 1, 0, 1, 2, 1, 1, 0, 0, 2, 1, 1, 0, - 2, 0, 0, 1, 0, 1, 0, 0, 1, 2, 1, 1, 1, 1, 0, 0, - 2, 1, 1, 1, 1, 2, 1, 0, 1, 1, 2, 2, 0, 1, 2, 0, + 0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 1, 0, 0, 1, 2, 1, + 1, 2, 0, 1, 0, 1, 2, 1, 1, 0, 0, 2, 1, 1, 0, 2, + 0, 0, 1, 0, 1, 0, 0, 1, 2, 1, 1, 1, 1, 0, 0, 2, + 1, 1, 1, 1, 2, 1, 0, 1, 1, 2, 2, 0, 1, 2, 0, 1, // Entry 40 - 7F - 1, 0, 1, 1, 1, 1, 0, 0, 2, 1, 0, 0, 0, 1, 1, 1, - 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 2, - 2, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, - 0, 2, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 2, 0, 2, + 0, 1, 1, 1, 1, 0, 0, 2, 1, 0, 0, 0, 1, 1, 1, 1, + 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 2, 2, + 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, + 2, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 2, 0, 2, 1, // Entry 80 - BF - 1, 1, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 1, 1, 0, - 1, 2, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, - 1, + 1, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, + 2, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, } const ( @@ -797,194 +735,110 @@ var script tag.Index = "" + // Size: 928 bytes // suppressScript is an index from langID to the dominant script for that language, // if it exists. If a script is given, it should be suppressed from the language tag. -// Size: 1319 bytes, 1319 elements -var suppressScript = [1319]uint8{ +// Size: 713 bytes, 713 elements +var suppressScript = [713]uint8{ // Entry 0 - 3F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x27, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 40 - 7F - 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x1e, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x27, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x00, - // Entry 80 - BF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + // Entry 40 - 7F 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, + 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, + // Entry 80 - BF + 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, + 0xd4, 0x00, 0x00, 0xd6, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x2d, 0x52, 0x52, 0x52, 0x00, 0x52, + 0x00, 0x52, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, + 0x52, 0x00, 0x00, 0x00, 0x52, 0x52, 0x00, 0x52, + 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, // Entry C0 - FF 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, + 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x52, 0x2e, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x37, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x52, + 0x00, 0x52, 0x52, 0x08, 0x00, 0x00, 0x00, 0x00, + 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, // Entry 100 - 13F + 0x00, 0x00, 0x52, 0x52, 0x00, 0x37, 0x00, 0x41, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0xd4, 0x00, 0x00, 0x00, - 0x00, 0xd6, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x2d, 0x00, 0x00, 0x52, 0x00, 0x00, 0x52, - 0x00, 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - // Entry 140 - 17F - 0x52, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x29, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 180 - 1BF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x2e, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x37, 0x00, 0x20, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 1C0 - 1FF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x52, 0x00, 0x52, 0x52, 0x00, - 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x52, 0x00, 0x37, 0x00, 0x00, 0x00, 0x00, - 0x41, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 200 - 23F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x29, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x1e, 0x00, 0x00, 0x52, 0x00, 0x00, - // Entry 240 - 27F - 0x00, 0x00, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x4a, 0x00, 0x4b, 0x00, 0x20, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 280 - 2BF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x4f, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - // Entry 2C0 - 2FF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, - 0x00, 0x00, 0x00, 0x64, 0x00, 0x00, 0x00, 0x00, - // Entry 300 - 33F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x52, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x6b, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - // Entry 340 - 37F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x52, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, + 0x00, 0x52, 0x00, 0x46, 0x00, 0x4a, 0x4b, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + // Entry 140 - 17F 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x70, 0x52, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - // Entry 380 - 3BF + 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x52, 0x4f, 0x00, 0x00, + 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x75, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x2f, 0x00, 0x00, 0x00, + // Entry 180 - 1BF + 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, + 0x52, 0x00, 0x00, 0x00, 0x1e, 0x64, 0x00, 0x00, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x20, 0x00, + 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x6b, 0x00, 0x00, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, + 0x00, 0x52, 0x00, 0x52, 0x20, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x52, 0x00, 0x52, 0x00, 0x52, + // Entry 1C0 - 1FF + 0x00, 0x52, 0x00, 0x00, 0x00, 0x70, 0x52, 0x00, + 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x52, 0x75, 0x00, 0x00, 0x00, 0x2f, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x52, + 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, + // Entry 200 - 23F + 0x00, 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x1e, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - // Entry 3C0 - 3FF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x1e, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0xc1, 0x00, 0x52, 0x00, 0x52, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, + // Entry 240 - 27F + 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 400 - 43F - 0x00, 0x00, 0xc1, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, + 0x00, 0xcd, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0xd0, 0x52, 0x00, 0x00, 0x00, 0xd5, 0x00, 0x00, + 0x00, 0x27, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, + 0x52, 0x00, 0x52, 0x52, 0x52, 0x00, 0x52, 0x52, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, + // Entry 280 - 2BF + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x52, + 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, - // Entry 440 - 47F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xcd, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xd0, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0xd5, 0x00, 0x00, 0x00, 0x27, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x52, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - // Entry 480 - 4BF - 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 4C0 - 4FF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 500 - 53F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x37, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, + 0x00, 0x37, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + // Entry 2C0 - 2FF + 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, + 0x00, } const ( @@ -993,15 +847,15 @@ const ( _BR = 64 _CA = 72 _ES = 109 - _GB = 122 - _MD = 187 - _PT = 237 - _UK = 305 - _US = 308 - _ZZ = 356 - _XA = 322 - _XC = 324 - _XK = 332 + _GB = 121 + _MD = 186 + _PT = 236 + _UK = 304 + _US = 306 + _ZZ = 354 + _XA = 320 + _XC = 322 + _XK = 330 ) // isoRegionOffset needs to be added to the index of regionISO to obtain the regionID @@ -1010,8 +864,8 @@ const ( const isoRegionOffset = 31 // regionTypes defines the status of a region for various standards. -// Size: 357 bytes, 357 elements -var regionTypes = [357]uint8{ +// Size: 355 bytes, 355 elements +var regionTypes = [355]uint8{ // Entry 0 - 3F 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, @@ -1028,41 +882,41 @@ var regionTypes = [357]uint8{ 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, 0x04, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, - 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x04, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, // Entry 80 - BF 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x00, 0x04, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x00, 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - // Entry C0 - FF - 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, - 0x06, 0x06, 0x06, 0x00, 0x06, 0x04, 0x06, 0x06, - 0x06, 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, - 0x06, 0x00, 0x06, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - // Entry 100 - 13F - 0x05, 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x02, 0x06, 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - // Entry 140 - 17F + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, + // Entry C0 - FF + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x06, + 0x06, 0x06, 0x00, 0x06, 0x04, 0x06, 0x06, 0x06, + 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x06, 0x00, 0x06, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, + // Entry 100 - 13F + 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, + 0x02, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, + 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, + // Entry 140 - 17F 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x04, 0x06, 0x06, 0x04, - 0x06, 0x06, 0x04, 0x06, 0x05, + 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, + 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, + 0x05, 0x05, 0x04, 0x06, 0x06, 0x04, 0x06, 0x06, + 0x04, 0x06, 0x05, } // regionISO holds a list of alphabetically sorted 2-letter ISO region codes. @@ -1070,27 +924,27 @@ var regionTypes = [357]uint8{ // - [A-Z}{2}: the first letter of the 2-letter code plus these two // letters form the 3-letter ISO code. // - 0, n: index into altRegionISO3. -var regionISO tag.Index = "" + // Size: 1308 bytes +var regionISO tag.Index = "" + // Size: 1300 bytes "AAAAACSCADNDAEREAFFGAGTGAIIAALLBAMRMANNTAOGOAQTAARRGASSMATUTAUUSAWBWAXLA" + "AZZEBAIHBBRBBDGDBEELBFFABGGRBHHRBIDIBJENBLLMBMMUBNRNBOOLBQESBRRABSHSBTTN" + "BUURBVVTBWWABYLRBZLZCAANCCCKCDODCFAFCGOGCHHECIIVCKOKCLHLCMMRCNHNCOOLCPPT" + "CRRICS\x00\x00CTTECUUBCVPVCWUWCXXRCYYPCZZEDDDRDEEUDGGADJJIDKNKDMMADOOMDY" + - "HYDZZAEA ECCUEESTEGGYEHSHERRIESSPETTHEU\x00\x03EZ FIINFJJIFKLKFMSMFORO" + - "FQ\x00\x18FRRAFXXXGAABGBBRGDRDGEEOGFUFGGGYGHHAGIIBGLRLGMMBGNINGPLPGQNQGR" + - "RCGS\x00\x06GTTMGUUMGWNBGYUYHKKGHMMDHNNDHRRVHTTIHUUNHVVOIC IDDNIERLILSR" + - "IMMNINNDIOOTIQRQIRRNISSLITTAJEEYJMAMJOORJPPNJTTNKEENKGGZKHHMKIIRKM\x00" + - "\x09KNNAKP\x00\x0cKRORKWWTKY\x00\x0fKZAZLAAOLBBNLCCALIIELKKALRBRLSSOLTTU" + - "LUUXLVVALYBYMAARMCCOMDDAMENEMFAFMGDGMHHLMIIDMKKDMLLIMMMRMNNGMOACMPNPMQTQ" + - "MRRTMSSRMTLTMUUSMVDVMWWIMXEXMYYSMZOZNAAMNCCLNEERNFFKNGGANHHBNIICNLLDNOOR" + - "NPPLNQ\x00\x1eNRRUNTTZNUIUNZZLOMMNPAANPCCIPEERPFYFPGNGPHHLPKAKPLOLPM\x00" + - "\x12PNCNPRRIPSSEPTRTPUUSPWLWPYRYPZCZQAATQMMMQNNNQOOOQPPPQQQQQRRRQSSSQTTT" + - "QU\x00\x03QVVVQWWWQXXXQYYYQZZZREEURHHOROOURS\x00\x15RUUSRWWASAAUSBLBSCYC" + - "SDDNSEWESGGPSHHNSIVNSJJMSKVKSLLESMMRSNENSOOMSRURSSSDSTTPSUUNSVLVSXXMSYYR" + - "SZWZTAAATCCATDCDTF\x00\x18TGGOTHHATJJKTKKLTLLSTMKMTNUNTOONTPMPTRURTTTOTV" + - "UVTWWNTZZAUAKRUGGAUK UMMIUN USSAUYRYUZZBVAATVCCTVDDRVEENVGGBVIIRVNNMVU" + - "UTWFLFWKAKWSSMXAAAXBBBXCCCXDDDXEEEXFFFXGGGXHHHXIIIXJJJXKKKXLLLXMMMXNNNXO" + - "OOXPPPXQQQXRRRXSSSXTTTXUUUXVVVXWWWXXXXXYYYXZZZYDMDYEEMYT\x00\x1bYUUGZAAF" + - "ZMMBZRARZWWEZZZZ\xff\xff\xff\xff" + "HYDZZAEA ECCUEESTEGGYEHSHERRIESSPETTHEU\x00\x03FIINFJJIFKLKFMSMFOROFQ" + + "\x00\x18FRRAFXXXGAABGBBRGDRDGEEOGFUFGGGYGHHAGIIBGLRLGMMBGNINGPLPGQNQGRRC" + + "GS\x00\x06GTTMGUUMGWNBGYUYHKKGHMMDHNNDHRRVHTTIHUUNHVVOIC IDDNIERLILSRIM" + + "MNINNDIOOTIQRQIRRNISSLITTAJEEYJMAMJOORJPPNJTTNKEENKGGZKHHMKIIRKM\x00\x09" + + "KNNAKP\x00\x0cKRORKWWTKY\x00\x0fKZAZLAAOLBBNLCCALIIELKKALRBRLSSOLTTULUUX" + + "LVVALYBYMAARMCCOMDDAMENEMFAFMGDGMHHLMIIDMKKDMLLIMMMRMNNGMOACMPNPMQTQMRRT" + + "MSSRMTLTMUUSMVDVMWWIMXEXMYYSMZOZNAAMNCCLNEERNFFKNGGANHHBNIICNLLDNOORNPPL" + + "NQ\x00\x1eNRRUNTTZNUIUNZZLOMMNPAANPCCIPEERPFYFPGNGPHHLPKAKPLOLPM\x00\x12" + + "PNCNPRRIPSSEPTRTPUUSPWLWPYRYPZCZQAATQMMMQNNNQOOOQPPPQQQQQRRRQSSSQTTTQU" + + "\x00\x03QVVVQWWWQXXXQYYYQZZZREEURHHOROOURS\x00\x15RUUSRWWASAAUSBLBSCYCSD" + + "DNSEWESGGPSHHNSIVNSJJMSKVKSLLESMMRSNENSOOMSRURSSSDSTTPSUUNSVLVSXXMSYYRSZ" + + "WZTAAATCCATDCDTF\x00\x18TGGOTHHATJJKTKKLTLLSTMKMTNUNTOONTPMPTRURTTTOTVUV" + + "TWWNTZZAUAKRUGGAUK UMMIUSSAUYRYUZZBVAATVCCTVDDRVEENVGGBVIIRVNNMVUUTWFLF" + + "WKAKWSSMXAAAXBBBXCCCXDDDXEEEXFFFXGGGXHHHXIIIXJJJXKKKXLLLXMMMXNNNXOOOXPPP" + + "XQQQXRRRXSSSXTTTXUUUXVVVXWWWXXXXXYYYXZZZYDMDYEEMYT\x00\x1bYUUGZAAFZMMBZR" + + "ARZWWEZZZZ\xff\xff\xff\xff" // altRegionISO3 holds a list of 3-letter region codes that cannot be // mapped to 2-letter codes using the default algorithm. This is a short list. @@ -1100,38 +954,38 @@ var altRegionISO3 string = "SCGQUUSGSCOMPRKCYMSPMSRBATFMYTATN" // of the 3-letter ISO codes in altRegionISO3. // Size: 22 bytes, 11 elements var altRegionIDs = [11]uint16{ - 0x0056, 0x006f, 0x0087, 0x00a7, 0x00a9, 0x00ac, 0x00e9, 0x0104, - 0x0120, 0x015e, 0x00db, + 0x0056, 0x006f, 0x0086, 0x00a6, 0x00a8, 0x00ab, 0x00e8, 0x0103, + 0x011f, 0x015c, 0x00da, } // Size: 80 bytes, 20 elements var regionOldMap = [20]fromTo{ - 0: {from: 0x43, to: 0xc3}, - 1: {from: 0x57, to: 0xa6}, + 0: {from: 0x43, to: 0xc2}, + 1: {from: 0x57, to: 0xa5}, 2: {from: 0x5e, to: 0x5f}, 3: {from: 0x65, to: 0x3a}, - 4: {from: 0x78, to: 0x77}, - 5: {from: 0x92, to: 0x36}, - 6: {from: 0xa2, to: 0x132}, - 7: {from: 0xc0, to: 0x132}, - 8: {from: 0xd6, to: 0x13e}, - 9: {from: 0xdb, to: 0x2a}, - 10: {from: 0xee, to: 0x132}, - 11: {from: 0xf1, to: 0xe1}, - 12: {from: 0xfb, to: 0x6f}, - 13: {from: 0x102, to: 0x163}, - 14: {from: 0x129, to: 0x125}, - 15: {from: 0x131, to: 0x7a}, - 16: {from: 0x139, to: 0x13d}, - 17: {from: 0x140, to: 0x132}, - 18: {from: 0x15c, to: 0x15d}, - 19: {from: 0x162, to: 0x4a}, + 4: {from: 0x77, to: 0x76}, + 5: {from: 0x91, to: 0x36}, + 6: {from: 0xa1, to: 0x131}, + 7: {from: 0xbf, to: 0x131}, + 8: {from: 0xd5, to: 0x13c}, + 9: {from: 0xda, to: 0x2a}, + 10: {from: 0xed, to: 0x131}, + 11: {from: 0xf0, to: 0xe0}, + 12: {from: 0xfa, to: 0x6f}, + 13: {from: 0x101, to: 0x161}, + 14: {from: 0x128, to: 0x124}, + 15: {from: 0x130, to: 0x79}, + 16: {from: 0x137, to: 0x13b}, + 17: {from: 0x13e, to: 0x131}, + 18: {from: 0x15a, to: 0x15b}, + 19: {from: 0x160, to: 0x4a}, } // m49 maps regionIDs to UN.M49 codes. The first isoRegionOffset entries are // codes indicating collections of regions. -// Size: 714 bytes, 357 elements -var m49 = [357]int16{ +// Size: 710 bytes, 355 elements +var m49 = [355]int16{ // Entry 0 - 3F 0, 1, 2, 3, 5, 9, 11, 13, 14, 15, 17, 18, 19, 21, 29, 30, @@ -1148,41 +1002,41 @@ var m49 = [357]int16{ 192, 132, 531, 162, 196, 203, 278, 276, 0, 262, 208, 212, 214, 204, 12, 0, 218, 233, 818, 732, 232, 724, 231, 967, - 0, 246, 242, 238, 583, 234, 0, 250, - 249, 266, 826, 308, 268, 254, 831, 288, + 246, 242, 238, 583, 234, 0, 250, 249, + 266, 826, 308, 268, 254, 831, 288, 292, // Entry 80 - BF - 292, 304, 270, 324, 312, 226, 300, 239, - 320, 316, 624, 328, 344, 334, 340, 191, - 332, 348, 854, 0, 360, 372, 376, 833, - 356, 86, 368, 364, 352, 380, 832, 388, - 400, 392, 581, 404, 417, 116, 296, 174, - 659, 408, 410, 414, 136, 398, 418, 422, - 662, 438, 144, 430, 426, 440, 442, 428, - 434, 504, 492, 498, 499, 663, 450, 584, + 304, 270, 324, 312, 226, 300, 239, 320, + 316, 624, 328, 344, 334, 340, 191, 332, + 348, 854, 0, 360, 372, 376, 833, 356, + 86, 368, 364, 352, 380, 832, 388, 400, + 392, 581, 404, 417, 116, 296, 174, 659, + 408, 410, 414, 136, 398, 418, 422, 662, + 438, 144, 430, 426, 440, 442, 428, 434, + 504, 492, 498, 499, 663, 450, 584, 581, // Entry C0 - FF - 581, 807, 466, 104, 496, 446, 580, 474, - 478, 500, 470, 480, 462, 454, 484, 458, - 508, 516, 540, 562, 574, 566, 548, 558, - 528, 578, 524, 10, 520, 536, 570, 554, - 512, 591, 0, 604, 258, 598, 608, 586, - 616, 666, 612, 630, 275, 620, 581, 585, - 600, 591, 634, 959, 960, 961, 962, 963, - 964, 965, 966, 967, 968, 969, 970, 971, + 807, 466, 104, 496, 446, 580, 474, 478, + 500, 470, 480, 462, 454, 484, 458, 508, + 516, 540, 562, 574, 566, 548, 558, 528, + 578, 524, 10, 520, 536, 570, 554, 512, + 591, 0, 604, 258, 598, 608, 586, 616, + 666, 612, 630, 275, 620, 581, 585, 600, + 591, 634, 959, 960, 961, 962, 963, 964, + 965, 966, 967, 968, 969, 970, 971, 972, // Entry 100 - 13F - 972, 638, 716, 642, 688, 643, 646, 682, - 90, 690, 729, 752, 702, 654, 705, 744, - 703, 694, 674, 686, 706, 740, 728, 678, - 810, 222, 534, 760, 748, 0, 796, 148, - 260, 768, 764, 762, 772, 626, 795, 788, - 776, 626, 792, 780, 798, 158, 834, 804, - 800, 826, 581, 0, 840, 858, 860, 336, - 670, 704, 862, 92, 850, 704, 548, 876, + 638, 716, 642, 688, 643, 646, 682, 90, + 690, 729, 752, 702, 654, 705, 744, 703, + 694, 674, 686, 706, 740, 728, 678, 810, + 222, 534, 760, 748, 0, 796, 148, 260, + 768, 764, 762, 772, 626, 795, 788, 776, + 626, 792, 780, 798, 158, 834, 804, 800, + 826, 581, 840, 858, 860, 336, 670, 704, + 862, 92, 850, 704, 548, 876, 581, 882, // Entry 140 - 17F - 581, 882, 973, 974, 975, 976, 977, 978, - 979, 980, 981, 982, 983, 984, 985, 986, - 987, 988, 989, 990, 991, 992, 993, 994, - 995, 996, 997, 998, 720, 887, 175, 891, - 710, 894, 180, 716, 999, + 973, 974, 975, 976, 977, 978, 979, 980, + 981, 982, 983, 984, 985, 986, 987, 988, + 989, 990, 991, 992, 993, 994, 995, 996, + 997, 998, 720, 887, 175, 891, 710, 894, + 180, 716, 999, } // m49Index gives indexes into fromM49 based on the three most significant bits @@ -1206,50 +1060,50 @@ var fromM49 = [332]uint16{ 0x402b, 0x4410, 0x4611, 0x482e, 0x4e12, 0x502d, 0x5841, 0x6038, 0x6434, 0x6627, 0x6833, 0x6a13, 0x6c14, 0x7035, 0x7215, 0x783c, 0x7a16, 0x8042, 0x883e, 0x8c32, 0x9045, 0x9444, 0x9840, 0xa847, - 0xac99, 0xb508, 0xb93b, 0xc03d, 0xc837, 0xd0c3, 0xd839, 0xe046, - 0xe8a5, 0xf051, 0xf848, 0x0859, 0x10ac, 0x184b, 0x1c17, 0x1e18, + 0xac98, 0xb507, 0xb939, 0xc03d, 0xc837, 0xd0c2, 0xd839, 0xe046, + 0xe8a4, 0xf051, 0xf848, 0x0859, 0x10ab, 0x184b, 0x1c17, 0x1e18, // Entry 40 - 7F - 0x20b2, 0x2219, 0x291f, 0x2c1a, 0x2e1b, 0x3050, 0x341c, 0x361d, - 0x3852, 0x3d2d, 0x445b, 0x4c49, 0x5453, 0x5ca7, 0x5f5e, 0x644c, - 0x684a, 0x704f, 0x7855, 0x7e8f, 0x8058, 0x885c, 0x965d, 0x983a, - 0xa062, 0xa863, 0xac64, 0xb468, 0xbd19, 0xc485, 0xcc6e, 0xce6e, - 0xd06c, 0xd269, 0xd475, 0xdc73, 0xde87, 0xe472, 0xec71, 0xf030, - 0xf278, 0xf477, 0xfc7d, 0x04e4, 0x0920, 0x0c61, 0x1479, 0x187c, - 0x1c82, 0x26ec, 0x285f, 0x2c5e, 0x305f, 0x407f, 0x4880, 0x50a6, - 0x5886, 0x6081, 0x687b, 0x7084, 0x7889, 0x8088, 0x8883, 0x908b, + 0x20b1, 0x2219, 0x291e, 0x2c1a, 0x2e1b, 0x3050, 0x341c, 0x361d, + 0x3852, 0x3d2c, 0x445b, 0x4c49, 0x5453, 0x5ca6, 0x5f5c, 0x644c, + 0x684a, 0x704f, 0x7855, 0x7e8e, 0x8058, 0x885c, 0x965d, 0x983a, + 0xa062, 0xa863, 0xac64, 0xb468, 0xbd18, 0xc484, 0xcc6e, 0xce6e, + 0xd06c, 0xd269, 0xd474, 0xdc72, 0xde86, 0xe471, 0xec70, 0xf030, + 0xf277, 0xf476, 0xfc7c, 0x04e3, 0x091f, 0x0c61, 0x1478, 0x187b, + 0x1c81, 0x26eb, 0x285f, 0x2c5e, 0x305f, 0x407e, 0x487f, 0x50a5, + 0x5885, 0x6080, 0x687a, 0x7083, 0x7888, 0x8087, 0x8882, 0x908a, // Entry 80 - BF - 0x9890, 0x9c8d, 0xa137, 0xa88e, 0xb08c, 0xb891, 0xc09c, 0xc898, - 0xd094, 0xd89b, 0xe09a, 0xe895, 0xf096, 0xf89d, 0x004e, 0x089f, - 0x10a1, 0x1cad, 0x20a0, 0x28a3, 0x30a9, 0x34aa, 0x3cab, 0x42a4, - 0x44ae, 0x461e, 0x4caf, 0x54b4, 0x58b7, 0x5cb3, 0x64b8, 0x6cb1, - 0x70b5, 0x74b6, 0x7cc5, 0x84be, 0x8ccd, 0x94cf, 0x9ccc, 0xa4c2, - 0xacca, 0xb4c7, 0xbcc8, 0xc0cb, 0xc8ce, 0xd8ba, 0xe0c4, 0xe4bb, - 0xe6bc, 0xe8c9, 0xf0b9, 0xf8d0, 0x00e0, 0x08d1, 0x10dc, 0x18da, - 0x20d8, 0x2428, 0x265a, 0x2a2f, 0x2d1a, 0x2e3f, 0x30dd, 0x38d2, + 0x988f, 0x9c8c, 0xa135, 0xa88d, 0xb08b, 0xb890, 0xc09b, 0xc897, + 0xd093, 0xd89a, 0xe099, 0xe894, 0xf095, 0xf89c, 0x004e, 0x089e, + 0x10a0, 0x1cac, 0x209f, 0x28a2, 0x30a8, 0x34a9, 0x3caa, 0x42a3, + 0x44ad, 0x461e, 0x4cae, 0x54b3, 0x58b6, 0x5cb2, 0x64b7, 0x6cb0, + 0x70b4, 0x74b5, 0x7cc4, 0x84bd, 0x8ccc, 0x94ce, 0x9ccb, 0xa4c1, + 0xacc9, 0xb4c6, 0xbcc7, 0xc0ca, 0xc8cd, 0xd8b9, 0xe0c3, 0xe4ba, + 0xe6bb, 0xe8c8, 0xf0b8, 0xf8cf, 0x00df, 0x08d0, 0x10db, 0x18d9, + 0x20d7, 0x2428, 0x265a, 0x2a2f, 0x2d19, 0x2e3f, 0x30dc, 0x38d1, // Entry C0 - FF - 0x493e, 0x54df, 0x5cd7, 0x64d3, 0x6cd5, 0x74de, 0x7cd4, 0x84d9, - 0x88c6, 0x8b32, 0x8e74, 0x90bf, 0x92ef, 0x94e7, 0x9ee1, 0xace5, - 0xb0f0, 0xb8e3, 0xc0e6, 0xc8ea, 0xd0e8, 0xd8ed, 0xe08a, 0xe525, - 0xeceb, 0xf4f2, 0xfd01, 0x0503, 0x0705, 0x0d06, 0x183b, 0x1d0d, - 0x26a8, 0x2825, 0x2cb0, 0x2ebd, 0x34e9, 0x3d38, 0x4512, 0x4d17, - 0x5507, 0x5d13, 0x6104, 0x6509, 0x6d11, 0x7d0c, 0x7f10, 0x813d, - 0x830e, 0x8514, 0x8d60, 0x9963, 0xa15c, 0xa86d, 0xb116, 0xb30a, - 0xb86b, 0xc10a, 0xc915, 0xd10f, 0xd91c, 0xe10b, 0xe84d, 0xf11b, + 0x493c, 0x54de, 0x5cd6, 0x64d2, 0x6cd4, 0x74dd, 0x7cd3, 0x84d8, + 0x88c5, 0x8b31, 0x8e73, 0x90be, 0x92ee, 0x94e6, 0x9ee0, 0xace4, + 0xb0ef, 0xb8e2, 0xc0e5, 0xc8e9, 0xd0e7, 0xd8ec, 0xe089, 0xe524, + 0xecea, 0xf4f1, 0xfd00, 0x0502, 0x0704, 0x0d05, 0x183b, 0x1d0c, + 0x26a7, 0x2825, 0x2caf, 0x2ebc, 0x34e8, 0x3d36, 0x4511, 0x4d16, + 0x5506, 0x5d12, 0x6103, 0x6508, 0x6d10, 0x7d0b, 0x7f0f, 0x813b, + 0x830d, 0x8513, 0x8d5e, 0x9961, 0xa15a, 0xa86d, 0xb115, 0xb309, + 0xb86b, 0xc109, 0xc914, 0xd10e, 0xd91b, 0xe10a, 0xe84d, 0xf11a, // Entry 100 - 13F - 0xf523, 0xf922, 0x0121, 0x0924, 0x1128, 0x192b, 0x2022, 0x2927, - 0x312a, 0x3726, 0x391e, 0x3d2c, 0x4130, 0x492f, 0x4ec1, 0x5518, - 0x646a, 0x747a, 0x7e7e, 0x809e, 0x8297, 0x852e, 0x9134, 0xa53c, - 0xac36, 0xb535, 0xb936, 0xbd3a, 0xd93f, 0xe541, 0xed5d, 0xef5d, - 0xf656, 0xfd61, 0x7c1f, 0x7ef3, 0x80f4, 0x82f5, 0x84f6, 0x86f7, - 0x88f8, 0x8af9, 0x8cfa, 0x8e6f, 0x90fc, 0x92fd, 0x94fe, 0x96ff, - 0x9900, 0x9b42, 0x9d43, 0x9f44, 0xa145, 0xa346, 0xa547, 0xa748, - 0xa949, 0xab4a, 0xad4b, 0xaf4c, 0xb14d, 0xb34e, 0xb54f, 0xb750, + 0xf522, 0xf921, 0x0120, 0x0923, 0x1127, 0x192a, 0x2022, 0x2926, + 0x3129, 0x3725, 0x391d, 0x3d2b, 0x412f, 0x492e, 0x4ec0, 0x5517, + 0x646a, 0x7479, 0x7e7d, 0x809d, 0x8296, 0x852d, 0x9132, 0xa53a, + 0xac36, 0xb533, 0xb934, 0xbd38, 0xd93d, 0xe53f, 0xed5b, 0xef5b, + 0xf656, 0xfd5f, 0x7c1f, 0x7ef2, 0x80f3, 0x82f4, 0x84f5, 0x86f6, + 0x88f7, 0x8af8, 0x8cf9, 0x8e6f, 0x90fb, 0x92fc, 0x94fd, 0x96fe, + 0x98ff, 0x9b40, 0x9d41, 0x9f42, 0xa143, 0xa344, 0xa545, 0xa746, + 0xa947, 0xab48, 0xad49, 0xaf4a, 0xb14b, 0xb34c, 0xb54d, 0xb74e, // Entry 140 - 17F - 0xb951, 0xbb52, 0xbd53, 0xbf54, 0xc155, 0xc356, 0xc557, 0xc758, - 0xc959, 0xcb5a, 0xcd5b, 0xcf64, + 0xb94f, 0xbb50, 0xbd51, 0xbf52, 0xc153, 0xc354, 0xc555, 0xc756, + 0xc957, 0xcb58, 0xcd59, 0xcf62, } -// Size: 1463 bytes +// Size: 1444 bytes var variantIndex = map[string]uint8{ "1606nict": 0x0, "1694acad": 0x1, @@ -1278,9 +1132,8 @@ var variantIndex = map[string]uint8{ "ekavsk": 0x15, "emodeng": 0x16, "fonipa": 0x48, - "fonnapa": 0x49, - "fonupa": 0x4a, - "fonxsamp": 0x4b, + "fonupa": 0x49, + "fonxsamp": 0x4a, "hepburn": 0x17, "heploc": 0x46, "hognorsk": 0x18, @@ -1313,7 +1166,7 @@ var variantIndex = map[string]uint8{ "rumgr": 0x30, "scotland": 0x31, "scouse": 0x32, - "simple": 0x4c, + "simple": 0x4b, "solba": 0x44, "sotav": 0x33, "surmiran": 0x34, @@ -1345,145 +1198,145 @@ type likelyLangRegion struct { // languages and regions given a script. // Size: 928 bytes, 232 elements var likelyScript = [232]likelyLangRegion{ - 1: {lang: 0x149, region: 0x83}, - 3: {lang: 0x299, region: 0x105}, - 4: {lang: 0x1e, region: 0x98}, - 5: {lang: 0x39, region: 0x6a}, - 7: {lang: 0x3a, region: 0x9b}, - 8: {lang: 0x1d0, region: 0x27}, - 9: {lang: 0x12, region: 0x9b}, - 10: {lang: 0x5a, region: 0x94}, - 11: {lang: 0x5f, region: 0x51}, - 12: {lang: 0xb7, region: 0xb3}, - 13: {lang: 0x62, region: 0x94}, - 14: {lang: 0xa3, region: 0x34}, - 15: {lang: 0x3e0, region: 0x98}, - 17: {lang: 0x51f, region: 0x12d}, - 18: {lang: 0x3a8, region: 0x98}, - 19: {lang: 0x159, region: 0x77}, - 20: {lang: 0xc0, region: 0x94}, - 21: {lang: 0x9b, region: 0xe6}, - 22: {lang: 0xd9, region: 0x34}, - 23: {lang: 0xf0, region: 0x48}, - 24: {lang: 0x4e6, region: 0x12a}, - 25: {lang: 0xe5, region: 0x13d}, - 26: {lang: 0xe3, region: 0x134}, - 28: {lang: 0xee, region: 0x6a}, - 29: {lang: 0x199, region: 0x5c}, - 30: {lang: 0x3d9, region: 0x105}, - 32: {lang: 0x1b7, region: 0x98}, - 34: {lang: 0x159, region: 0x77}, - 37: {lang: 0x12f, region: 0x6a}, - 38: {lang: 0x427, region: 0x26}, - 39: {lang: 0x26, region: 0x6e}, - 41: {lang: 0x208, region: 0x7c}, - 42: {lang: 0xfa, region: 0x37}, - 43: {lang: 0x198, region: 0x12f}, - 44: {lang: 0x3e0, region: 0x98}, - 45: {lang: 0x131, region: 0x86}, - 46: {lang: 0x19d, region: 0x98}, - 47: {lang: 0x394, region: 0x98}, - 48: {lang: 0x51f, region: 0x12d}, - 49: {lang: 0x24b, region: 0xaa}, - 50: {lang: 0x51f, region: 0x52}, - 51: {lang: 0x1c4, region: 0xe6}, - 52: {lang: 0x51f, region: 0x52}, - 53: {lang: 0x51f, region: 0x12d}, - 54: {lang: 0x2f4, region: 0x9a}, - 55: {lang: 0x1b5, region: 0x96}, - 56: {lang: 0x1f8, region: 0xa1}, - 57: {lang: 0x1be, region: 0x12a}, - 58: {lang: 0x1c3, region: 0xae}, - 60: {lang: 0x1ce, region: 0x91}, - 62: {lang: 0x13d, region: 0x9d}, - 63: {lang: 0x24b, region: 0xaa}, - 64: {lang: 0x206, region: 0x94}, - 65: {lang: 0x1f8, region: 0xa1}, - 67: {lang: 0x130, region: 0xc3}, - 68: {lang: 0x1f8, region: 0xa1}, - 69: {lang: 0x3b2, region: 0xe7}, - 70: {lang: 0x242, region: 0xa5}, - 71: {lang: 0x3f0, region: 0x98}, - 74: {lang: 0x249, region: 0x98}, - 75: {lang: 0x24b, region: 0xaa}, - 77: {lang: 0x87, region: 0x98}, - 78: {lang: 0x367, region: 0x122}, - 79: {lang: 0x2af, region: 0xae}, - 84: {lang: 0x296, region: 0x98}, - 85: {lang: 0x29f, region: 0x98}, - 86: {lang: 0x286, region: 0x86}, - 87: {lang: 0x199, region: 0x86}, - 88: {lang: 0x2a3, region: 0x52}, - 90: {lang: 0x4ea, region: 0x12a}, - 91: {lang: 0x4eb, region: 0x12a}, - 92: {lang: 0x1b7, region: 0x98}, - 93: {lang: 0x32e, region: 0x9b}, - 94: {lang: 0x4ed, region: 0x52}, - 95: {lang: 0xa7, region: 0x52}, - 97: {lang: 0x2df, region: 0x111}, - 98: {lang: 0x4ee, region: 0x10a}, - 99: {lang: 0x4ee, region: 0x10a}, - 100: {lang: 0x2fb, region: 0x98}, - 101: {lang: 0x312, region: 0x98}, - 102: {lang: 0x302, region: 0x52}, - 104: {lang: 0x315, region: 0x34}, - 105: {lang: 0x305, region: 0x98}, - 106: {lang: 0x40a, region: 0xe7}, - 107: {lang: 0x328, region: 0xc3}, - 108: {lang: 0x4ef, region: 0x107}, - 109: {lang: 0x3a, region: 0xa0}, - 110: {lang: 0x34a, region: 0xda}, - 112: {lang: 0x2c7, region: 0x83}, - 114: {lang: 0x3f9, region: 0x95}, - 115: {lang: 0x3e5, region: 0x98}, - 116: {lang: 0x392, region: 0xc4}, - 117: {lang: 0x38c, region: 0x98}, - 118: {lang: 0x390, region: 0x134}, - 119: {lang: 0x41f, region: 0x114}, - 120: {lang: 0x3a, region: 0x11b}, - 121: {lang: 0xf9, region: 0xc3}, - 122: {lang: 0x274, region: 0x105}, - 123: {lang: 0x2c0, region: 0x52}, - 124: {lang: 0x396, region: 0x9b}, - 125: {lang: 0x396, region: 0x52}, - 127: {lang: 0x3a4, region: 0xaf}, - 129: {lang: 0x1bf, region: 0x52}, - 130: {lang: 0x4f3, region: 0x9b}, - 181: {lang: 0x3c2, region: 0x94}, - 183: {lang: 0x369, region: 0x10b}, - 184: {lang: 0x416, region: 0x96}, - 186: {lang: 0x4f5, region: 0x15d}, - 187: {lang: 0x3e6, region: 0x98}, - 188: {lang: 0x44, region: 0x134}, - 189: {lang: 0x134, region: 0x7a}, - 190: {lang: 0x3e0, region: 0x98}, - 191: {lang: 0x3e0, region: 0x98}, - 192: {lang: 0x3f0, region: 0x98}, - 193: {lang: 0x402, region: 0xb2}, - 194: {lang: 0x429, region: 0x98}, - 195: {lang: 0x434, region: 0x94}, - 196: {lang: 0x443, region: 0x34}, - 197: {lang: 0x444, region: 0x9a}, - 201: {lang: 0x450, region: 0xe6}, - 202: {lang: 0x116, region: 0x98}, - 203: {lang: 0x454, region: 0x52}, - 204: {lang: 0x22a, region: 0x52}, - 205: {lang: 0x446, region: 0x98}, - 206: {lang: 0x49b, region: 0x52}, - 207: {lang: 0x9d, region: 0x13d}, - 208: {lang: 0x457, region: 0x98}, - 210: {lang: 0x51e, region: 0xb9}, - 211: {lang: 0x14e, region: 0xe6}, - 212: {lang: 0x124, region: 0xcc}, - 213: {lang: 0x461, region: 0x122}, - 214: {lang: 0xa7, region: 0x52}, - 215: {lang: 0x2c5, region: 0x98}, - 216: {lang: 0x4a3, region: 0x11b}, - 217: {lang: 0x4b4, region: 0xb3}, - 219: {lang: 0x1c7, region: 0x98}, - 221: {lang: 0x3a0, region: 0x9b}, - 222: {lang: 0x21, region: 0x9a}, - 223: {lang: 0x1e2, region: 0x52}, + 1: {lang: 0xa6, region: 0x82}, + 3: {lang: 0x159, region: 0x104}, + 4: {lang: 0xc, region: 0x97}, + 5: {lang: 0x15, region: 0x6a}, + 7: {lang: 0x16, region: 0x9a}, + 8: {lang: 0xf3, region: 0x27}, + 9: {lang: 0x8, region: 0x9a}, + 10: {lang: 0x27, region: 0x93}, + 11: {lang: 0x2b, region: 0x51}, + 12: {lang: 0x55, region: 0xb2}, + 13: {lang: 0x2c, region: 0x93}, + 14: {lang: 0x4b, region: 0x34}, + 15: {lang: 0x20d, region: 0x97}, + 17: {lang: 0x2c4, region: 0x12c}, + 18: {lang: 0x1e5, region: 0x97}, + 19: {lang: 0xaf, region: 0x76}, + 20: {lang: 0x5b, region: 0x93}, + 21: {lang: 0x47, region: 0xe5}, + 22: {lang: 0x63, region: 0x34}, + 23: {lang: 0x73, region: 0x48}, + 24: {lang: 0x2a8, region: 0x129}, + 25: {lang: 0x6e, region: 0x13b}, + 26: {lang: 0x6c, region: 0x132}, + 28: {lang: 0x71, region: 0x6a}, + 29: {lang: 0xd0, region: 0x5c}, + 30: {lang: 0x207, region: 0x104}, + 32: {lang: 0xe1, region: 0x97}, + 34: {lang: 0xaf, region: 0x76}, + 37: {lang: 0x98, region: 0x6a}, + 38: {lang: 0x23a, region: 0x26}, + 39: {lang: 0x11, region: 0x6e}, + 41: {lang: 0x111, region: 0x7b}, + 42: {lang: 0x7d, region: 0x37}, + 43: {lang: 0xcf, region: 0x12e}, + 44: {lang: 0x20d, region: 0x97}, + 45: {lang: 0x9a, region: 0x85}, + 46: {lang: 0xd3, region: 0x97}, + 47: {lang: 0x1d7, region: 0x97}, + 48: {lang: 0x2c4, region: 0x12c}, + 49: {lang: 0x136, region: 0xa9}, + 50: {lang: 0x2c4, region: 0x52}, + 51: {lang: 0xe9, region: 0xe5}, + 52: {lang: 0x2c4, region: 0x52}, + 53: {lang: 0x2c4, region: 0x12c}, + 54: {lang: 0x18b, region: 0x99}, + 55: {lang: 0xe0, region: 0x95}, + 56: {lang: 0x107, region: 0xa0}, + 57: {lang: 0xe4, region: 0x129}, + 58: {lang: 0xe8, region: 0xad}, + 60: {lang: 0xf2, region: 0x90}, + 62: {lang: 0xa0, region: 0x9c}, + 63: {lang: 0x136, region: 0xa9}, + 64: {lang: 0x10f, region: 0x93}, + 65: {lang: 0x107, region: 0xa0}, + 67: {lang: 0x99, region: 0xc2}, + 68: {lang: 0x107, region: 0xa0}, + 69: {lang: 0x1eb, region: 0xe6}, + 70: {lang: 0x133, region: 0xa4}, + 71: {lang: 0x21a, region: 0x97}, + 74: {lang: 0x135, region: 0x97}, + 75: {lang: 0x136, region: 0xa9}, + 77: {lang: 0x40, region: 0x97}, + 78: {lang: 0x1c2, region: 0x121}, + 79: {lang: 0x165, region: 0xad}, + 84: {lang: 0x158, region: 0x97}, + 85: {lang: 0x15c, region: 0x97}, + 86: {lang: 0x14f, region: 0x85}, + 87: {lang: 0xd0, region: 0x85}, + 88: {lang: 0x15e, region: 0x52}, + 90: {lang: 0x2aa, region: 0x129}, + 91: {lang: 0x2ab, region: 0x129}, + 92: {lang: 0xe1, region: 0x97}, + 93: {lang: 0x1a8, region: 0x9a}, + 94: {lang: 0x2ad, region: 0x52}, + 95: {lang: 0x4c, region: 0x52}, + 97: {lang: 0x17f, region: 0x110}, + 98: {lang: 0x2ae, region: 0x109}, + 99: {lang: 0x2ae, region: 0x109}, + 100: {lang: 0x18d, region: 0x97}, + 101: {lang: 0x196, region: 0x97}, + 102: {lang: 0x18f, region: 0x52}, + 104: {lang: 0x199, region: 0x34}, + 105: {lang: 0x190, region: 0x97}, + 106: {lang: 0x22b, region: 0xe6}, + 107: {lang: 0x1a5, region: 0xc2}, + 108: {lang: 0x2af, region: 0x106}, + 109: {lang: 0x16, region: 0x9f}, + 110: {lang: 0x1b5, region: 0xd9}, + 112: {lang: 0x179, region: 0x82}, + 114: {lang: 0x223, region: 0x94}, + 115: {lang: 0x212, region: 0x97}, + 116: {lang: 0x1d6, region: 0xc3}, + 117: {lang: 0x1d3, region: 0x97}, + 118: {lang: 0x1d5, region: 0x132}, + 119: {lang: 0x238, region: 0x113}, + 120: {lang: 0x16, region: 0x11a}, + 121: {lang: 0x7c, region: 0xc2}, + 122: {lang: 0x147, region: 0x104}, + 123: {lang: 0x172, region: 0x52}, + 124: {lang: 0x1d9, region: 0x9a}, + 125: {lang: 0x1d9, region: 0x52}, + 127: {lang: 0x1e3, region: 0xae}, + 129: {lang: 0xe5, region: 0x52}, + 130: {lang: 0x2b2, region: 0x9a}, + 181: {lang: 0x1f6, region: 0x93}, + 183: {lang: 0x1c4, region: 0x10a}, + 184: {lang: 0x234, region: 0x95}, + 186: {lang: 0x2b3, region: 0x15b}, + 187: {lang: 0x213, region: 0x97}, + 188: {lang: 0x1e, region: 0x132}, + 189: {lang: 0x9b, region: 0x79}, + 190: {lang: 0x20d, region: 0x97}, + 191: {lang: 0x20d, region: 0x97}, + 192: {lang: 0x21a, region: 0x97}, + 193: {lang: 0x228, region: 0xb1}, + 194: {lang: 0x23c, region: 0x97}, + 195: {lang: 0x244, region: 0x93}, + 196: {lang: 0x24e, region: 0x34}, + 197: {lang: 0x24f, region: 0x99}, + 201: {lang: 0x253, region: 0xe5}, + 202: {lang: 0x8a, region: 0x97}, + 203: {lang: 0x255, region: 0x52}, + 204: {lang: 0x126, region: 0x52}, + 205: {lang: 0x251, region: 0x97}, + 206: {lang: 0x27f, region: 0x52}, + 207: {lang: 0x48, region: 0x13b}, + 208: {lang: 0x258, region: 0x97}, + 210: {lang: 0x2c3, region: 0xb8}, + 211: {lang: 0xaa, region: 0xe5}, + 212: {lang: 0x90, region: 0xcb}, + 213: {lang: 0x25d, region: 0x121}, + 214: {lang: 0x4c, region: 0x52}, + 215: {lang: 0x177, region: 0x97}, + 216: {lang: 0x285, region: 0x11a}, + 217: {lang: 0x28e, region: 0xb2}, + 219: {lang: 0xec, region: 0x97}, + 221: {lang: 0x1e1, region: 0x9a}, + 222: {lang: 0xe, region: 0x99}, + 223: {lang: 0xfb, region: 0x52}, } type likelyScriptRegion struct { @@ -1496,1413 +1349,807 @@ type likelyScriptRegion struct { // scripts and regions given incomplete information. If more entries exist for a // given language, region and script are the index and size respectively // of the list in likelyLangList. -// Size: 5276 bytes, 1319 elements -var likelyLang = [1319]likelyScriptRegion{ - 0: {region: 0x134, script: 0x52, flags: 0x0}, - 1: {region: 0x6e, script: 0x52, flags: 0x0}, - 2: {region: 0x164, script: 0x52, flags: 0x0}, - 3: {region: 0x164, script: 0x52, flags: 0x0}, - 4: {region: 0x164, script: 0x52, flags: 0x0}, - 5: {region: 0x7c, script: 0x1e, flags: 0x0}, - 6: {region: 0x164, script: 0x52, flags: 0x0}, - 7: {region: 0x7f, script: 0x52, flags: 0x0}, - 8: {region: 0x164, script: 0x52, flags: 0x0}, - 9: {region: 0x164, script: 0x52, flags: 0x0}, - 10: {region: 0x164, script: 0x52, flags: 0x0}, - 11: {region: 0x94, script: 0x52, flags: 0x0}, - 12: {region: 0x130, script: 0x52, flags: 0x0}, - 13: {region: 0x7f, script: 0x52, flags: 0x0}, - 14: {region: 0x164, script: 0x52, flags: 0x0}, - 15: {region: 0x164, script: 0x52, flags: 0x0}, - 16: {region: 0x105, script: 0x1e, flags: 0x0}, - 17: {region: 0x164, script: 0x52, flags: 0x0}, - 18: {region: 0x9b, script: 0x9, flags: 0x0}, - 19: {region: 0x127, script: 0x5, flags: 0x0}, - 20: {region: 0x164, script: 0x52, flags: 0x0}, - 21: {region: 0x160, script: 0x52, flags: 0x0}, - 22: {region: 0x164, script: 0x52, flags: 0x0}, - 23: {region: 0x164, script: 0x52, flags: 0x0}, - 24: {region: 0x164, script: 0x52, flags: 0x0}, - 25: {region: 0x164, script: 0x52, flags: 0x0}, - 26: {region: 0x164, script: 0x52, flags: 0x0}, - 27: {region: 0x51, script: 0x52, flags: 0x0}, - 28: {region: 0x164, script: 0x52, flags: 0x0}, - 29: {region: 0x164, script: 0x52, flags: 0x0}, - 30: {region: 0x98, script: 0x4, flags: 0x0}, - 31: {region: 0x164, script: 0x52, flags: 0x0}, - 32: {region: 0x7f, script: 0x52, flags: 0x0}, - 33: {region: 0x9a, script: 0xde, flags: 0x0}, - 34: {region: 0x164, script: 0x52, flags: 0x0}, - 35: {region: 0x164, script: 0x52, flags: 0x0}, - 36: {region: 0x14c, script: 0x52, flags: 0x0}, - 37: {region: 0x105, script: 0x1e, flags: 0x0}, - 38: {region: 0x6e, script: 0x27, flags: 0x0}, - 39: {region: 0x164, script: 0x52, flags: 0x0}, - 40: {region: 0x164, script: 0x52, flags: 0x0}, - 41: {region: 0xd5, script: 0x52, flags: 0x0}, - 42: {region: 0x164, script: 0x52, flags: 0x0}, - 44: {region: 0x164, script: 0x52, flags: 0x0}, - 45: {region: 0x164, script: 0x52, flags: 0x0}, - 46: {region: 0x164, script: 0x52, flags: 0x0}, - 47: {region: 0x164, script: 0x52, flags: 0x0}, - 48: {region: 0x164, script: 0x52, flags: 0x0}, - 49: {region: 0x164, script: 0x52, flags: 0x0}, - 50: {region: 0x94, script: 0x52, flags: 0x0}, - 51: {region: 0x164, script: 0x5, flags: 0x0}, - 52: {region: 0x121, script: 0x5, flags: 0x0}, - 53: {region: 0x164, script: 0x52, flags: 0x0}, - 54: {region: 0x164, script: 0x52, flags: 0x0}, - 55: {region: 0x164, script: 0x52, flags: 0x0}, - 56: {region: 0x164, script: 0x52, flags: 0x0}, - 57: {region: 0x6a, script: 0x5, flags: 0x0}, - 58: {region: 0x0, script: 0x3, flags: 0x1}, - 59: {region: 0x164, script: 0x52, flags: 0x0}, - 60: {region: 0x50, script: 0x52, flags: 0x0}, - 61: {region: 0x3e, script: 0x52, flags: 0x0}, - 62: {region: 0x66, script: 0x5, flags: 0x0}, - 64: {region: 0xb9, script: 0x5, flags: 0x0}, - 65: {region: 0x6a, script: 0x5, flags: 0x0}, - 66: {region: 0x98, script: 0xe, flags: 0x0}, - 67: {region: 0x12e, script: 0x52, flags: 0x0}, - 68: {region: 0x134, script: 0xbc, flags: 0x0}, - 69: {region: 0x164, script: 0x52, flags: 0x0}, - 70: {region: 0x164, script: 0x52, flags: 0x0}, - 71: {region: 0x6d, script: 0x52, flags: 0x0}, - 72: {region: 0x164, script: 0x52, flags: 0x0}, - 73: {region: 0x164, script: 0x52, flags: 0x0}, - 74: {region: 0x48, script: 0x52, flags: 0x0}, - 75: {region: 0x164, script: 0x52, flags: 0x0}, - 76: {region: 0x105, script: 0x1e, flags: 0x0}, - 77: {region: 0x164, script: 0x5, flags: 0x0}, - 78: {region: 0x164, script: 0x52, flags: 0x0}, - 79: {region: 0x164, script: 0x52, flags: 0x0}, - 80: {region: 0x164, script: 0x52, flags: 0x0}, - 81: {region: 0x98, script: 0x20, flags: 0x0}, - 82: {region: 0x164, script: 0x52, flags: 0x0}, - 83: {region: 0x164, script: 0x52, flags: 0x0}, - 84: {region: 0x164, script: 0x52, flags: 0x0}, - 85: {region: 0x3e, script: 0x52, flags: 0x0}, - 86: {region: 0x164, script: 0x52, flags: 0x0}, - 87: {region: 0x3, script: 0x5, flags: 0x1}, - 88: {region: 0x105, script: 0x1e, flags: 0x0}, - 89: {region: 0xe7, script: 0x5, flags: 0x0}, - 90: {region: 0x94, script: 0x52, flags: 0x0}, - 91: {region: 0xda, script: 0x20, flags: 0x0}, - 92: {region: 0x2d, script: 0x52, flags: 0x0}, - 93: {region: 0x51, script: 0x52, flags: 0x0}, - 94: {region: 0x164, script: 0x52, flags: 0x0}, - 95: {region: 0x51, script: 0xb, flags: 0x0}, - 96: {region: 0x164, script: 0x52, flags: 0x0}, - 97: {region: 0x164, script: 0x52, flags: 0x0}, - 98: {region: 0x94, script: 0x52, flags: 0x0}, - 99: {region: 0x164, script: 0x52, flags: 0x0}, - 100: {region: 0x51, script: 0x52, flags: 0x0}, - 101: {region: 0x164, script: 0x52, flags: 0x0}, - 102: {region: 0x164, script: 0x52, flags: 0x0}, - 103: {region: 0x164, script: 0x52, flags: 0x0}, - 104: {region: 0x164, script: 0x52, flags: 0x0}, - 105: {region: 0x4e, script: 0x52, flags: 0x0}, - 106: {region: 0x164, script: 0x52, flags: 0x0}, - 107: {region: 0x164, script: 0x52, flags: 0x0}, - 108: {region: 0x164, script: 0x52, flags: 0x0}, - 109: {region: 0x164, script: 0x27, flags: 0x0}, - 110: {region: 0x164, script: 0x52, flags: 0x0}, - 111: {region: 0x164, script: 0x52, flags: 0x0}, - 112: {region: 0x46, script: 0x1e, flags: 0x0}, - 113: {region: 0x164, script: 0x52, flags: 0x0}, - 114: {region: 0x164, script: 0x52, flags: 0x0}, - 115: {region: 0x10a, script: 0x5, flags: 0x0}, - 116: {region: 0x161, script: 0x52, flags: 0x0}, - 117: {region: 0x164, script: 0x52, flags: 0x0}, - 118: {region: 0x94, script: 0x52, flags: 0x0}, - 119: {region: 0x164, script: 0x52, flags: 0x0}, - 120: {region: 0x12e, script: 0x52, flags: 0x0}, - 121: {region: 0x51, script: 0x52, flags: 0x0}, - 122: {region: 0x98, script: 0xcd, flags: 0x0}, - 123: {region: 0xe7, script: 0x5, flags: 0x0}, - 124: {region: 0x98, script: 0x20, flags: 0x0}, - 125: {region: 0x37, script: 0x1e, flags: 0x0}, - 126: {region: 0x98, script: 0x20, flags: 0x0}, - 127: {region: 0xe7, script: 0x5, flags: 0x0}, - 128: {region: 0x12a, script: 0x2d, flags: 0x0}, - 130: {region: 0x98, script: 0x20, flags: 0x0}, - 131: {region: 0x164, script: 0x52, flags: 0x0}, - 132: {region: 0x98, script: 0x20, flags: 0x0}, - 133: {region: 0xe6, script: 0x52, flags: 0x0}, - 134: {region: 0x164, script: 0x52, flags: 0x0}, - 135: {region: 0x98, script: 0x20, flags: 0x0}, - 136: {region: 0x164, script: 0x52, flags: 0x0}, - 137: {region: 0x13e, script: 0x52, flags: 0x0}, - 138: {region: 0x164, script: 0x52, flags: 0x0}, - 139: {region: 0x164, script: 0x52, flags: 0x0}, - 140: {region: 0xe6, script: 0x52, flags: 0x0}, - 141: {region: 0x164, script: 0x52, flags: 0x0}, - 142: {region: 0xd5, script: 0x52, flags: 0x0}, - 143: {region: 0x164, script: 0x52, flags: 0x0}, - 144: {region: 0x164, script: 0x52, flags: 0x0}, - 145: {region: 0x164, script: 0x52, flags: 0x0}, - 146: {region: 0x164, script: 0x27, flags: 0x0}, - 147: {region: 0x98, script: 0x20, flags: 0x0}, - 148: {region: 0x94, script: 0x52, flags: 0x0}, - 149: {region: 0x164, script: 0x52, flags: 0x0}, - 150: {region: 0x164, script: 0x52, flags: 0x0}, - 151: {region: 0x164, script: 0x52, flags: 0x0}, - 152: {region: 0x164, script: 0x52, flags: 0x0}, - 153: {region: 0x51, script: 0x52, flags: 0x0}, - 154: {region: 0x164, script: 0x52, flags: 0x0}, - 155: {region: 0xe6, script: 0x52, flags: 0x0}, - 156: {region: 0x164, script: 0x52, flags: 0x0}, - 157: {region: 0x13d, script: 0xcf, flags: 0x0}, - 158: {region: 0xc2, script: 0x52, flags: 0x0}, - 159: {region: 0x164, script: 0x52, flags: 0x0}, - 160: {region: 0x164, script: 0x52, flags: 0x0}, - 161: {region: 0xc2, script: 0x52, flags: 0x0}, - 162: {region: 0x164, script: 0x52, flags: 0x0}, - 163: {region: 0x34, script: 0xe, flags: 0x0}, - 164: {region: 0x164, script: 0x52, flags: 0x0}, - 165: {region: 0x164, script: 0x52, flags: 0x0}, - 166: {region: 0x164, script: 0x52, flags: 0x0}, - 167: {region: 0x52, script: 0xd6, flags: 0x0}, - 168: {region: 0x164, script: 0x52, flags: 0x0}, - 169: {region: 0x164, script: 0x52, flags: 0x0}, - 170: {region: 0x164, script: 0x52, flags: 0x0}, - 171: {region: 0x98, script: 0xe, flags: 0x0}, - 172: {region: 0x164, script: 0x52, flags: 0x0}, - 173: {region: 0x9b, script: 0x5, flags: 0x0}, - 174: {region: 0x164, script: 0x52, flags: 0x0}, - 175: {region: 0x4e, script: 0x52, flags: 0x0}, - 176: {region: 0x77, script: 0x52, flags: 0x0}, - 177: {region: 0x98, script: 0x20, flags: 0x0}, - 178: {region: 0xe7, script: 0x5, flags: 0x0}, - 179: {region: 0x98, script: 0x20, flags: 0x0}, - 180: {region: 0x164, script: 0x52, flags: 0x0}, - 181: {region: 0x32, script: 0x52, flags: 0x0}, - 182: {region: 0x164, script: 0x52, flags: 0x0}, - 183: {region: 0xb3, script: 0xc, flags: 0x0}, - 184: {region: 0x51, script: 0x52, flags: 0x0}, - 185: {region: 0x164, script: 0x27, flags: 0x0}, - 186: {region: 0xe6, script: 0x52, flags: 0x0}, - 187: {region: 0x164, script: 0x52, flags: 0x0}, - 188: {region: 0xe7, script: 0x20, flags: 0x0}, - 189: {region: 0x105, script: 0x1e, flags: 0x0}, - 190: {region: 0x15e, script: 0x52, flags: 0x0}, - 191: {region: 0x164, script: 0x52, flags: 0x0}, - 192: {region: 0x94, script: 0x52, flags: 0x0}, - 193: {region: 0x164, script: 0x52, flags: 0x0}, - 194: {region: 0x51, script: 0x52, flags: 0x0}, - 195: {region: 0x164, script: 0x52, flags: 0x0}, - 196: {region: 0x164, script: 0x52, flags: 0x0}, - 197: {region: 0x164, script: 0x52, flags: 0x0}, - 198: {region: 0x85, script: 0x52, flags: 0x0}, - 199: {region: 0x164, script: 0x52, flags: 0x0}, - 200: {region: 0x164, script: 0x52, flags: 0x0}, - 201: {region: 0x164, script: 0x52, flags: 0x0}, - 202: {region: 0x164, script: 0x52, flags: 0x0}, - 203: {region: 0x6c, script: 0x27, flags: 0x0}, - 204: {region: 0x164, script: 0x52, flags: 0x0}, - 205: {region: 0x164, script: 0x52, flags: 0x0}, - 206: {region: 0x51, script: 0x52, flags: 0x0}, - 207: {region: 0x164, script: 0x52, flags: 0x0}, - 208: {region: 0x164, script: 0x52, flags: 0x0}, - 209: {region: 0xc2, script: 0x52, flags: 0x0}, - 210: {region: 0x164, script: 0x52, flags: 0x0}, - 211: {region: 0x164, script: 0x52, flags: 0x0}, - 212: {region: 0x164, script: 0x52, flags: 0x0}, - 213: {region: 0x6d, script: 0x52, flags: 0x0}, - 214: {region: 0x164, script: 0x52, flags: 0x0}, - 215: {region: 0x164, script: 0x52, flags: 0x0}, - 216: {region: 0xd5, script: 0x52, flags: 0x0}, - 217: {region: 0x8, script: 0x2, flags: 0x1}, - 218: {region: 0x105, script: 0x1e, flags: 0x0}, - 219: {region: 0xe6, script: 0x52, flags: 0x0}, - 220: {region: 0x164, script: 0x52, flags: 0x0}, - 221: {region: 0x130, script: 0x52, flags: 0x0}, - 222: {region: 0x89, script: 0x52, flags: 0x0}, - 223: {region: 0x74, script: 0x52, flags: 0x0}, - 224: {region: 0x105, script: 0x1e, flags: 0x0}, - 225: {region: 0x134, script: 0x52, flags: 0x0}, - 226: {region: 0x48, script: 0x52, flags: 0x0}, - 227: {region: 0x134, script: 0x1a, flags: 0x0}, - 228: {region: 0xa5, script: 0x5, flags: 0x0}, - 229: {region: 0x13d, script: 0x19, flags: 0x0}, - 230: {region: 0x164, script: 0x52, flags: 0x0}, - 231: {region: 0x9a, script: 0x5, flags: 0x0}, - 232: {region: 0x164, script: 0x52, flags: 0x0}, - 233: {region: 0x164, script: 0x52, flags: 0x0}, - 234: {region: 0x164, script: 0x52, flags: 0x0}, - 235: {region: 0x164, script: 0x52, flags: 0x0}, - 236: {region: 0x164, script: 0x52, flags: 0x0}, - 237: {region: 0x77, script: 0x52, flags: 0x0}, - 238: {region: 0x6a, script: 0x1c, flags: 0x0}, - 239: {region: 0xe6, script: 0x52, flags: 0x0}, - 240: {region: 0x48, script: 0x17, flags: 0x0}, - 241: {region: 0x48, script: 0x17, flags: 0x0}, - 242: {region: 0x48, script: 0x17, flags: 0x0}, - 243: {region: 0x48, script: 0x17, flags: 0x0}, - 244: {region: 0x48, script: 0x17, flags: 0x0}, - 245: {region: 0x109, script: 0x52, flags: 0x0}, - 246: {region: 0x5d, script: 0x52, flags: 0x0}, - 247: {region: 0xe8, script: 0x52, flags: 0x0}, - 248: {region: 0x48, script: 0x17, flags: 0x0}, - 249: {region: 0xc3, script: 0x79, flags: 0x0}, - 250: {region: 0xa, script: 0x2, flags: 0x1}, - 251: {region: 0x105, script: 0x1e, flags: 0x0}, - 252: {region: 0x7a, script: 0x52, flags: 0x0}, - 253: {region: 0x62, script: 0x52, flags: 0x0}, - 254: {region: 0x164, script: 0x52, flags: 0x0}, - 255: {region: 0x164, script: 0x52, flags: 0x0}, - 256: {region: 0x164, script: 0x52, flags: 0x0}, - 257: {region: 0x164, script: 0x52, flags: 0x0}, - 258: {region: 0x134, script: 0x52, flags: 0x0}, - 259: {region: 0x105, script: 0x1e, flags: 0x0}, - 260: {region: 0xa3, script: 0x52, flags: 0x0}, - 261: {region: 0x164, script: 0x52, flags: 0x0}, - 262: {region: 0x164, script: 0x52, flags: 0x0}, - 263: {region: 0x98, script: 0x5, flags: 0x0}, - 264: {region: 0x164, script: 0x52, flags: 0x0}, - 265: {region: 0x5f, script: 0x52, flags: 0x0}, - 266: {region: 0x164, script: 0x52, flags: 0x0}, - 267: {region: 0x48, script: 0x52, flags: 0x0}, - 268: {region: 0x164, script: 0x52, flags: 0x0}, - 269: {region: 0x164, script: 0x52, flags: 0x0}, - 270: {region: 0x164, script: 0x52, flags: 0x0}, - 271: {region: 0x164, script: 0x5, flags: 0x0}, - 272: {region: 0x48, script: 0x52, flags: 0x0}, - 273: {region: 0x164, script: 0x52, flags: 0x0}, - 274: {region: 0x164, script: 0x52, flags: 0x0}, - 275: {region: 0xd3, script: 0x52, flags: 0x0}, - 276: {region: 0x4e, script: 0x52, flags: 0x0}, - 277: {region: 0x164, script: 0x52, flags: 0x0}, - 278: {region: 0x98, script: 0x5, flags: 0x0}, - 279: {region: 0x164, script: 0x52, flags: 0x0}, - 280: {region: 0x164, script: 0x52, flags: 0x0}, - 281: {region: 0x164, script: 0x52, flags: 0x0}, - 282: {region: 0x164, script: 0x27, flags: 0x0}, - 283: {region: 0x5f, script: 0x52, flags: 0x0}, - 284: {region: 0xc2, script: 0x52, flags: 0x0}, - 285: {region: 0xcf, script: 0x52, flags: 0x0}, - 286: {region: 0x164, script: 0x52, flags: 0x0}, - 287: {region: 0xda, script: 0x20, flags: 0x0}, - 288: {region: 0x51, script: 0x52, flags: 0x0}, - 289: {region: 0x164, script: 0x52, flags: 0x0}, - 290: {region: 0x164, script: 0x52, flags: 0x0}, - 291: {region: 0x164, script: 0x52, flags: 0x0}, - 292: {region: 0xcc, script: 0xd4, flags: 0x0}, - 293: {region: 0x164, script: 0x52, flags: 0x0}, - 294: {region: 0x164, script: 0x52, flags: 0x0}, - 295: {region: 0x113, script: 0x52, flags: 0x0}, - 296: {region: 0x36, script: 0x52, flags: 0x0}, - 297: {region: 0x42, script: 0xd6, flags: 0x0}, - 298: {region: 0x164, script: 0x52, flags: 0x0}, - 299: {region: 0xa3, script: 0x52, flags: 0x0}, - 300: {region: 0x7f, script: 0x52, flags: 0x0}, - 301: {region: 0xd5, script: 0x52, flags: 0x0}, - 302: {region: 0x9d, script: 0x52, flags: 0x0}, - 303: {region: 0x6a, script: 0x25, flags: 0x0}, - 304: {region: 0xc3, script: 0x43, flags: 0x0}, - 305: {region: 0x86, script: 0x2d, flags: 0x0}, - 306: {region: 0x164, script: 0x52, flags: 0x0}, - 307: {region: 0x164, script: 0x52, flags: 0x0}, - 308: {region: 0xc, script: 0x2, flags: 0x1}, - 309: {region: 0x164, script: 0x52, flags: 0x0}, - 310: {region: 0x164, script: 0x52, flags: 0x0}, - 311: {region: 0x1, script: 0x52, flags: 0x0}, - 312: {region: 0x164, script: 0x52, flags: 0x0}, - 313: {region: 0x6d, script: 0x52, flags: 0x0}, - 314: {region: 0x134, script: 0x52, flags: 0x0}, - 315: {region: 0x69, script: 0x52, flags: 0x0}, - 316: {region: 0x164, script: 0x52, flags: 0x0}, - 317: {region: 0x9d, script: 0x3e, flags: 0x0}, - 318: {region: 0x164, script: 0x52, flags: 0x0}, - 319: {region: 0x164, script: 0x52, flags: 0x0}, - 320: {region: 0x6d, script: 0x52, flags: 0x0}, - 321: {region: 0x51, script: 0x52, flags: 0x0}, - 322: {region: 0x6d, script: 0x52, flags: 0x0}, - 323: {region: 0x9b, script: 0x5, flags: 0x0}, - 324: {region: 0x164, script: 0x52, flags: 0x0}, - 325: {region: 0x164, script: 0x52, flags: 0x0}, - 326: {region: 0x164, script: 0x52, flags: 0x0}, - 327: {region: 0x164, script: 0x52, flags: 0x0}, - 328: {region: 0x85, script: 0x52, flags: 0x0}, - 329: {region: 0xe, script: 0x2, flags: 0x1}, - 330: {region: 0x164, script: 0x52, flags: 0x0}, - 331: {region: 0xc2, script: 0x52, flags: 0x0}, - 332: {region: 0x71, script: 0x52, flags: 0x0}, - 333: {region: 0x10a, script: 0x5, flags: 0x0}, - 334: {region: 0xe6, script: 0x52, flags: 0x0}, - 335: {region: 0x10b, script: 0x52, flags: 0x0}, - 336: {region: 0x72, script: 0x52, flags: 0x0}, - 337: {region: 0x164, script: 0x52, flags: 0x0}, - 338: {region: 0x164, script: 0x52, flags: 0x0}, - 339: {region: 0x75, script: 0x52, flags: 0x0}, - 340: {region: 0x164, script: 0x52, flags: 0x0}, - 341: {region: 0x3a, script: 0x52, flags: 0x0}, - 342: {region: 0x164, script: 0x52, flags: 0x0}, - 343: {region: 0x164, script: 0x52, flags: 0x0}, - 344: {region: 0x164, script: 0x52, flags: 0x0}, - 345: {region: 0x77, script: 0x52, flags: 0x0}, - 346: {region: 0x134, script: 0x52, flags: 0x0}, - 347: {region: 0x77, script: 0x52, flags: 0x0}, - 348: {region: 0x5f, script: 0x52, flags: 0x0}, - 349: {region: 0x5f, script: 0x52, flags: 0x0}, - 350: {region: 0x51, script: 0x5, flags: 0x0}, - 351: {region: 0x13f, script: 0x52, flags: 0x0}, - 352: {region: 0x164, script: 0x52, flags: 0x0}, - 353: {region: 0x83, script: 0x52, flags: 0x0}, - 354: {region: 0x164, script: 0x52, flags: 0x0}, - 355: {region: 0xd3, script: 0x52, flags: 0x0}, - 356: {region: 0x9d, script: 0x52, flags: 0x0}, - 357: {region: 0xd5, script: 0x52, flags: 0x0}, - 358: {region: 0x164, script: 0x52, flags: 0x0}, - 359: {region: 0x10a, script: 0x52, flags: 0x0}, - 360: {region: 0xd8, script: 0x52, flags: 0x0}, - 361: {region: 0x95, script: 0x52, flags: 0x0}, - 362: {region: 0x7f, script: 0x52, flags: 0x0}, - 363: {region: 0x164, script: 0x52, flags: 0x0}, - 364: {region: 0xbb, script: 0x52, flags: 0x0}, - 365: {region: 0x164, script: 0x52, flags: 0x0}, - 366: {region: 0x164, script: 0x52, flags: 0x0}, - 367: {region: 0x164, script: 0x52, flags: 0x0}, - 368: {region: 0x52, script: 0x34, flags: 0x0}, - 369: {region: 0x164, script: 0x52, flags: 0x0}, - 370: {region: 0x94, script: 0x52, flags: 0x0}, - 371: {region: 0x164, script: 0x52, flags: 0x0}, - 372: {region: 0x98, script: 0x20, flags: 0x0}, - 373: {region: 0x164, script: 0x52, flags: 0x0}, - 374: {region: 0x9b, script: 0x5, flags: 0x0}, - 375: {region: 0x7d, script: 0x52, flags: 0x0}, - 376: {region: 0x7a, script: 0x52, flags: 0x0}, - 377: {region: 0x164, script: 0x52, flags: 0x0}, - 378: {region: 0x164, script: 0x52, flags: 0x0}, - 379: {region: 0x164, script: 0x52, flags: 0x0}, - 380: {region: 0x164, script: 0x52, flags: 0x0}, - 381: {region: 0x164, script: 0x52, flags: 0x0}, - 382: {region: 0x164, script: 0x52, flags: 0x0}, - 383: {region: 0x6e, script: 0x27, flags: 0x0}, - 384: {region: 0x164, script: 0x52, flags: 0x0}, - 385: {region: 0xda, script: 0x20, flags: 0x0}, - 386: {region: 0x164, script: 0x52, flags: 0x0}, - 387: {region: 0xa6, script: 0x52, flags: 0x0}, - 388: {region: 0x164, script: 0x52, flags: 0x0}, - 389: {region: 0xe7, script: 0x5, flags: 0x0}, - 390: {region: 0x164, script: 0x52, flags: 0x0}, - 391: {region: 0xe7, script: 0x5, flags: 0x0}, - 392: {region: 0x164, script: 0x52, flags: 0x0}, - 393: {region: 0x164, script: 0x52, flags: 0x0}, - 394: {region: 0x6d, script: 0x52, flags: 0x0}, - 395: {region: 0x9b, script: 0x5, flags: 0x0}, - 396: {region: 0x164, script: 0x52, flags: 0x0}, - 397: {region: 0x164, script: 0x27, flags: 0x0}, - 398: {region: 0xf0, script: 0x52, flags: 0x0}, - 399: {region: 0x164, script: 0x52, flags: 0x0}, - 400: {region: 0x164, script: 0x52, flags: 0x0}, - 401: {region: 0x164, script: 0x52, flags: 0x0}, - 402: {region: 0x164, script: 0x27, flags: 0x0}, - 403: {region: 0x164, script: 0x52, flags: 0x0}, - 404: {region: 0x98, script: 0x20, flags: 0x0}, - 405: {region: 0x98, script: 0xd0, flags: 0x0}, - 406: {region: 0x94, script: 0x52, flags: 0x0}, - 407: {region: 0xd8, script: 0x52, flags: 0x0}, - 408: {region: 0x12f, script: 0x2b, flags: 0x0}, - 409: {region: 0x10, script: 0x2, flags: 0x1}, - 410: {region: 0x98, script: 0xe, flags: 0x0}, - 411: {region: 0x164, script: 0x52, flags: 0x0}, - 412: {region: 0x4d, script: 0x52, flags: 0x0}, - 413: {region: 0x98, script: 0x2e, flags: 0x0}, - 414: {region: 0x40, script: 0x52, flags: 0x0}, - 415: {region: 0x53, script: 0x52, flags: 0x0}, - 416: {region: 0x164, script: 0x52, flags: 0x0}, - 417: {region: 0x7f, script: 0x52, flags: 0x0}, - 418: {region: 0x164, script: 0x52, flags: 0x0}, - 419: {region: 0x164, script: 0x52, flags: 0x0}, - 420: {region: 0xa3, script: 0x52, flags: 0x0}, - 421: {region: 0x97, script: 0x52, flags: 0x0}, - 422: {region: 0x164, script: 0x52, flags: 0x0}, - 423: {region: 0xda, script: 0x20, flags: 0x0}, - 424: {region: 0x164, script: 0x52, flags: 0x0}, - 425: {region: 0x164, script: 0x5, flags: 0x0}, - 426: {region: 0x48, script: 0x52, flags: 0x0}, - 427: {region: 0x164, script: 0x5, flags: 0x0}, - 428: {region: 0x164, script: 0x52, flags: 0x0}, - 429: {region: 0x12, script: 0x3, flags: 0x1}, - 430: {region: 0x164, script: 0x52, flags: 0x0}, - 431: {region: 0x52, script: 0x34, flags: 0x0}, - 432: {region: 0x164, script: 0x52, flags: 0x0}, - 433: {region: 0x134, script: 0x52, flags: 0x0}, - 434: {region: 0x23, script: 0x5, flags: 0x0}, - 435: {region: 0x164, script: 0x52, flags: 0x0}, - 436: {region: 0x164, script: 0x27, flags: 0x0}, - 437: {region: 0x96, script: 0x37, flags: 0x0}, - 438: {region: 0x164, script: 0x52, flags: 0x0}, - 439: {region: 0x98, script: 0x20, flags: 0x0}, - 440: {region: 0x164, script: 0x52, flags: 0x0}, - 441: {region: 0x72, script: 0x52, flags: 0x0}, - 442: {region: 0x164, script: 0x52, flags: 0x0}, - 443: {region: 0x164, script: 0x52, flags: 0x0}, - 444: {region: 0xe6, script: 0x52, flags: 0x0}, - 445: {region: 0x164, script: 0x52, flags: 0x0}, - 446: {region: 0x12a, script: 0x39, flags: 0x0}, - 447: {region: 0x52, script: 0x81, flags: 0x0}, - 448: {region: 0x164, script: 0x52, flags: 0x0}, - 449: {region: 0xe7, script: 0x5, flags: 0x0}, - 450: {region: 0x98, script: 0x20, flags: 0x0}, - 451: {region: 0xae, script: 0x3a, flags: 0x0}, - 452: {region: 0xe6, script: 0x52, flags: 0x0}, - 453: {region: 0xe7, script: 0x5, flags: 0x0}, - 454: {region: 0xe5, script: 0x52, flags: 0x0}, - 455: {region: 0x98, script: 0x20, flags: 0x0}, - 456: {region: 0x98, script: 0x20, flags: 0x0}, - 457: {region: 0x164, script: 0x52, flags: 0x0}, - 458: {region: 0x8f, script: 0x52, flags: 0x0}, - 459: {region: 0x5f, script: 0x52, flags: 0x0}, - 460: {region: 0x52, script: 0x34, flags: 0x0}, - 461: {region: 0x90, script: 0x52, flags: 0x0}, - 462: {region: 0x91, script: 0x52, flags: 0x0}, - 463: {region: 0x164, script: 0x52, flags: 0x0}, - 464: {region: 0x27, script: 0x8, flags: 0x0}, - 465: {region: 0xd1, script: 0x52, flags: 0x0}, - 466: {region: 0x77, script: 0x52, flags: 0x0}, - 467: {region: 0x164, script: 0x52, flags: 0x0}, - 468: {region: 0x164, script: 0x52, flags: 0x0}, - 469: {region: 0xcf, script: 0x52, flags: 0x0}, - 470: {region: 0xd5, script: 0x52, flags: 0x0}, - 471: {region: 0x164, script: 0x52, flags: 0x0}, - 472: {region: 0x164, script: 0x52, flags: 0x0}, - 473: {region: 0x164, script: 0x52, flags: 0x0}, - 474: {region: 0x94, script: 0x52, flags: 0x0}, - 475: {region: 0x164, script: 0x52, flags: 0x0}, - 476: {region: 0x164, script: 0x52, flags: 0x0}, - 477: {region: 0x164, script: 0x52, flags: 0x0}, - 479: {region: 0xd5, script: 0x52, flags: 0x0}, - 480: {region: 0x164, script: 0x52, flags: 0x0}, - 481: {region: 0x164, script: 0x52, flags: 0x0}, - 482: {region: 0x52, script: 0xdf, flags: 0x0}, - 483: {region: 0x164, script: 0x52, flags: 0x0}, - 484: {region: 0x134, script: 0x52, flags: 0x0}, - 485: {region: 0x164, script: 0x52, flags: 0x0}, - 486: {region: 0x48, script: 0x52, flags: 0x0}, - 487: {region: 0x164, script: 0x52, flags: 0x0}, - 488: {region: 0x164, script: 0x52, flags: 0x0}, - 489: {region: 0xe6, script: 0x52, flags: 0x0}, - 490: {region: 0x164, script: 0x52, flags: 0x0}, - 491: {region: 0x94, script: 0x52, flags: 0x0}, - 492: {region: 0x105, script: 0x1e, flags: 0x0}, - 494: {region: 0x164, script: 0x52, flags: 0x0}, - 495: {region: 0x164, script: 0x52, flags: 0x0}, - 496: {region: 0x9c, script: 0x52, flags: 0x0}, - 497: {region: 0x9d, script: 0x52, flags: 0x0}, - 498: {region: 0x48, script: 0x17, flags: 0x0}, - 499: {region: 0x96, script: 0x37, flags: 0x0}, - 500: {region: 0x164, script: 0x52, flags: 0x0}, - 501: {region: 0x164, script: 0x52, flags: 0x0}, - 502: {region: 0x105, script: 0x52, flags: 0x0}, - 503: {region: 0x164, script: 0x52, flags: 0x0}, - 504: {region: 0xa1, script: 0x41, flags: 0x0}, - 505: {region: 0x164, script: 0x52, flags: 0x0}, - 506: {region: 0x9f, script: 0x52, flags: 0x0}, - 508: {region: 0x164, script: 0x52, flags: 0x0}, - 509: {region: 0x164, script: 0x52, flags: 0x0}, - 510: {region: 0x164, script: 0x52, flags: 0x0}, - 511: {region: 0x51, script: 0x52, flags: 0x0}, - 512: {region: 0x12f, script: 0x37, flags: 0x0}, - 513: {region: 0x164, script: 0x52, flags: 0x0}, - 514: {region: 0x12e, script: 0x52, flags: 0x0}, - 515: {region: 0xda, script: 0x20, flags: 0x0}, - 516: {region: 0x164, script: 0x52, flags: 0x0}, - 517: {region: 0x62, script: 0x52, flags: 0x0}, - 518: {region: 0x94, script: 0x52, flags: 0x0}, - 519: {region: 0x94, script: 0x52, flags: 0x0}, - 520: {region: 0x7c, script: 0x29, flags: 0x0}, - 521: {region: 0x136, script: 0x1e, flags: 0x0}, - 522: {region: 0x66, script: 0x52, flags: 0x0}, - 523: {region: 0xc3, script: 0x52, flags: 0x0}, - 524: {region: 0x164, script: 0x52, flags: 0x0}, - 525: {region: 0x164, script: 0x52, flags: 0x0}, - 526: {region: 0xd5, script: 0x52, flags: 0x0}, - 527: {region: 0xa3, script: 0x52, flags: 0x0}, - 528: {region: 0xc2, script: 0x52, flags: 0x0}, - 529: {region: 0x105, script: 0x1e, flags: 0x0}, - 530: {region: 0x164, script: 0x52, flags: 0x0}, - 531: {region: 0x164, script: 0x52, flags: 0x0}, - 532: {region: 0x164, script: 0x52, flags: 0x0}, - 533: {region: 0x164, script: 0x52, flags: 0x0}, - 534: {region: 0xd3, script: 0x5, flags: 0x0}, - 535: {region: 0xd5, script: 0x52, flags: 0x0}, - 536: {region: 0x163, script: 0x52, flags: 0x0}, - 537: {region: 0x164, script: 0x52, flags: 0x0}, - 538: {region: 0x164, script: 0x52, flags: 0x0}, - 539: {region: 0x12e, script: 0x52, flags: 0x0}, - 540: {region: 0x121, script: 0x5, flags: 0x0}, - 541: {region: 0x164, script: 0x52, flags: 0x0}, - 542: {region: 0x122, script: 0xd5, flags: 0x0}, - 543: {region: 0x59, script: 0x52, flags: 0x0}, - 544: {region: 0x51, script: 0x52, flags: 0x0}, - 545: {region: 0x164, script: 0x52, flags: 0x0}, - 546: {region: 0x4e, script: 0x52, flags: 0x0}, - 547: {region: 0x98, script: 0x20, flags: 0x0}, - 548: {region: 0x98, script: 0x20, flags: 0x0}, - 549: {region: 0x4a, script: 0x52, flags: 0x0}, - 550: {region: 0x94, script: 0x52, flags: 0x0}, - 551: {region: 0x164, script: 0x52, flags: 0x0}, - 552: {region: 0x40, script: 0x52, flags: 0x0}, - 553: {region: 0x98, script: 0x52, flags: 0x0}, - 554: {region: 0x52, script: 0xcc, flags: 0x0}, - 555: {region: 0x98, script: 0x20, flags: 0x0}, - 556: {region: 0xc2, script: 0x52, flags: 0x0}, - 557: {region: 0x164, script: 0x52, flags: 0x0}, - 558: {region: 0x98, script: 0x6b, flags: 0x0}, - 559: {region: 0xe7, script: 0x5, flags: 0x0}, - 560: {region: 0x164, script: 0x52, flags: 0x0}, - 561: {region: 0xa3, script: 0x52, flags: 0x0}, - 562: {region: 0x164, script: 0x52, flags: 0x0}, - 563: {region: 0x12a, script: 0x52, flags: 0x0}, - 564: {region: 0x164, script: 0x52, flags: 0x0}, - 565: {region: 0xd1, script: 0x52, flags: 0x0}, - 566: {region: 0x164, script: 0x52, flags: 0x0}, - 567: {region: 0xae, script: 0x4f, flags: 0x0}, - 568: {region: 0x164, script: 0x52, flags: 0x0}, - 569: {region: 0x164, script: 0x52, flags: 0x0}, - 570: {region: 0x15, script: 0x6, flags: 0x1}, - 571: {region: 0x164, script: 0x52, flags: 0x0}, - 572: {region: 0x51, script: 0x52, flags: 0x0}, - 573: {region: 0x81, script: 0x52, flags: 0x0}, - 574: {region: 0xa3, script: 0x52, flags: 0x0}, - 575: {region: 0x164, script: 0x52, flags: 0x0}, - 576: {region: 0x164, script: 0x52, flags: 0x0}, - 577: {region: 0x164, script: 0x52, flags: 0x0}, - 578: {region: 0xa5, script: 0x46, flags: 0x0}, - 579: {region: 0x29, script: 0x52, flags: 0x0}, - 580: {region: 0x164, script: 0x52, flags: 0x0}, - 581: {region: 0x164, script: 0x52, flags: 0x0}, - 582: {region: 0x164, script: 0x52, flags: 0x0}, - 583: {region: 0x164, script: 0x52, flags: 0x0}, - 584: {region: 0x164, script: 0x52, flags: 0x0}, - 585: {region: 0x98, script: 0x4a, flags: 0x0}, - 586: {region: 0x164, script: 0x52, flags: 0x0}, - 587: {region: 0xaa, script: 0x4b, flags: 0x0}, - 588: {region: 0x105, script: 0x1e, flags: 0x0}, - 589: {region: 0x98, script: 0x20, flags: 0x0}, - 590: {region: 0x164, script: 0x52, flags: 0x0}, - 591: {region: 0x74, script: 0x52, flags: 0x0}, - 592: {region: 0x164, script: 0x52, flags: 0x0}, - 593: {region: 0xb3, script: 0x52, flags: 0x0}, - 594: {region: 0x164, script: 0x52, flags: 0x0}, - 595: {region: 0x164, script: 0x52, flags: 0x0}, - 596: {region: 0x164, script: 0x52, flags: 0x0}, - 597: {region: 0x164, script: 0x52, flags: 0x0}, - 598: {region: 0x164, script: 0x52, flags: 0x0}, - 599: {region: 0x164, script: 0x52, flags: 0x0}, - 600: {region: 0x164, script: 0x52, flags: 0x0}, - 601: {region: 0x164, script: 0x27, flags: 0x0}, - 603: {region: 0x105, script: 0x1e, flags: 0x0}, - 604: {region: 0x111, script: 0x52, flags: 0x0}, - 605: {region: 0xe6, script: 0x52, flags: 0x0}, - 606: {region: 0x105, script: 0x52, flags: 0x0}, - 607: {region: 0x164, script: 0x52, flags: 0x0}, - 608: {region: 0x98, script: 0x20, flags: 0x0}, - 609: {region: 0x98, script: 0x5, flags: 0x0}, - 610: {region: 0x12e, script: 0x52, flags: 0x0}, - 611: {region: 0x164, script: 0x52, flags: 0x0}, - 612: {region: 0x51, script: 0x52, flags: 0x0}, - 613: {region: 0x5f, script: 0x52, flags: 0x0}, - 614: {region: 0x164, script: 0x52, flags: 0x0}, - 615: {region: 0x164, script: 0x52, flags: 0x0}, - 616: {region: 0x164, script: 0x27, flags: 0x0}, - 617: {region: 0x164, script: 0x52, flags: 0x0}, - 618: {region: 0x164, script: 0x52, flags: 0x0}, - 619: {region: 0x1b, script: 0x3, flags: 0x1}, - 620: {region: 0x164, script: 0x52, flags: 0x0}, - 621: {region: 0x164, script: 0x52, flags: 0x0}, - 622: {region: 0x164, script: 0x52, flags: 0x0}, - 623: {region: 0x164, script: 0x52, flags: 0x0}, - 624: {region: 0x105, script: 0x1e, flags: 0x0}, - 625: {region: 0x164, script: 0x52, flags: 0x0}, - 626: {region: 0x164, script: 0x52, flags: 0x0}, - 627: {region: 0x164, script: 0x52, flags: 0x0}, - 628: {region: 0x105, script: 0x1e, flags: 0x0}, - 629: {region: 0x164, script: 0x52, flags: 0x0}, - 630: {region: 0x94, script: 0x52, flags: 0x0}, - 631: {region: 0xe7, script: 0x5, flags: 0x0}, - 632: {region: 0x7a, script: 0x52, flags: 0x0}, - 633: {region: 0x164, script: 0x52, flags: 0x0}, - 634: {region: 0x164, script: 0x52, flags: 0x0}, - 635: {region: 0x164, script: 0x52, flags: 0x0}, - 636: {region: 0x164, script: 0x27, flags: 0x0}, - 637: {region: 0x122, script: 0xd5, flags: 0x0}, - 638: {region: 0xe7, script: 0x5, flags: 0x0}, - 639: {region: 0x164, script: 0x52, flags: 0x0}, - 640: {region: 0x164, script: 0x52, flags: 0x0}, - 641: {region: 0x1e, script: 0x5, flags: 0x1}, - 642: {region: 0x164, script: 0x52, flags: 0x0}, - 643: {region: 0x164, script: 0x52, flags: 0x0}, - 644: {region: 0x164, script: 0x52, flags: 0x0}, - 645: {region: 0x137, script: 0x52, flags: 0x0}, - 646: {region: 0x86, script: 0x56, flags: 0x0}, - 647: {region: 0x96, script: 0x37, flags: 0x0}, - 648: {region: 0x12e, script: 0x52, flags: 0x0}, - 649: {region: 0xe7, script: 0x5, flags: 0x0}, - 650: {region: 0x130, script: 0x52, flags: 0x0}, - 651: {region: 0x164, script: 0x52, flags: 0x0}, - 652: {region: 0xb6, script: 0x52, flags: 0x0}, - 653: {region: 0x105, script: 0x1e, flags: 0x0}, - 654: {region: 0x164, script: 0x52, flags: 0x0}, - 655: {region: 0x94, script: 0x52, flags: 0x0}, - 656: {region: 0x164, script: 0x52, flags: 0x0}, - 657: {region: 0x52, script: 0xd5, flags: 0x0}, - 658: {region: 0x164, script: 0x52, flags: 0x0}, - 659: {region: 0x164, script: 0x52, flags: 0x0}, - 660: {region: 0x164, script: 0x52, flags: 0x0}, - 661: {region: 0x164, script: 0x52, flags: 0x0}, - 662: {region: 0x98, script: 0x54, flags: 0x0}, - 663: {region: 0x164, script: 0x52, flags: 0x0}, - 664: {region: 0x164, script: 0x52, flags: 0x0}, - 665: {region: 0x105, script: 0x1e, flags: 0x0}, - 666: {region: 0x130, script: 0x52, flags: 0x0}, - 667: {region: 0x164, script: 0x52, flags: 0x0}, - 668: {region: 0xd8, script: 0x52, flags: 0x0}, - 669: {region: 0x164, script: 0x52, flags: 0x0}, - 670: {region: 0x164, script: 0x52, flags: 0x0}, - 671: {region: 0x23, script: 0x2, flags: 0x1}, - 672: {region: 0x164, script: 0x52, flags: 0x0}, - 673: {region: 0x164, script: 0x52, flags: 0x0}, - 674: {region: 0x9d, script: 0x52, flags: 0x0}, - 675: {region: 0x52, script: 0x58, flags: 0x0}, - 676: {region: 0x94, script: 0x52, flags: 0x0}, - 677: {region: 0x9b, script: 0x5, flags: 0x0}, - 678: {region: 0x134, script: 0x52, flags: 0x0}, - 679: {region: 0x164, script: 0x52, flags: 0x0}, - 680: {region: 0x164, script: 0x52, flags: 0x0}, - 681: {region: 0x98, script: 0xd0, flags: 0x0}, - 682: {region: 0x9d, script: 0x52, flags: 0x0}, - 683: {region: 0x164, script: 0x52, flags: 0x0}, - 684: {region: 0x4a, script: 0x52, flags: 0x0}, - 685: {region: 0x164, script: 0x52, flags: 0x0}, - 686: {region: 0x164, script: 0x52, flags: 0x0}, - 687: {region: 0xae, script: 0x4f, flags: 0x0}, - 688: {region: 0x164, script: 0x52, flags: 0x0}, - 689: {region: 0x164, script: 0x52, flags: 0x0}, - 690: {region: 0x4a, script: 0x52, flags: 0x0}, - 691: {region: 0x164, script: 0x52, flags: 0x0}, - 692: {region: 0x164, script: 0x52, flags: 0x0}, - 693: {region: 0x161, script: 0x52, flags: 0x0}, - 694: {region: 0x9b, script: 0x5, flags: 0x0}, - 695: {region: 0xb5, script: 0x52, flags: 0x0}, - 696: {region: 0xb7, script: 0x52, flags: 0x0}, - 697: {region: 0x4a, script: 0x52, flags: 0x0}, - 698: {region: 0x4a, script: 0x52, flags: 0x0}, - 699: {region: 0xa3, script: 0x52, flags: 0x0}, - 700: {region: 0xa3, script: 0x52, flags: 0x0}, - 701: {region: 0x9b, script: 0x5, flags: 0x0}, - 702: {region: 0xb7, script: 0x52, flags: 0x0}, - 703: {region: 0x122, script: 0xd5, flags: 0x0}, - 704: {region: 0x52, script: 0x34, flags: 0x0}, - 705: {region: 0x12a, script: 0x52, flags: 0x0}, - 706: {region: 0x94, script: 0x52, flags: 0x0}, - 707: {region: 0x51, script: 0x52, flags: 0x0}, - 708: {region: 0x98, script: 0x20, flags: 0x0}, - 709: {region: 0x98, script: 0x20, flags: 0x0}, - 710: {region: 0x94, script: 0x52, flags: 0x0}, - 711: {region: 0x25, script: 0x3, flags: 0x1}, - 712: {region: 0xa3, script: 0x52, flags: 0x0}, - 713: {region: 0x164, script: 0x52, flags: 0x0}, - 714: {region: 0xce, script: 0x52, flags: 0x0}, - 715: {region: 0x164, script: 0x52, flags: 0x0}, - 716: {region: 0x164, script: 0x52, flags: 0x0}, - 717: {region: 0x164, script: 0x52, flags: 0x0}, - 718: {region: 0x164, script: 0x52, flags: 0x0}, - 719: {region: 0x164, script: 0x52, flags: 0x0}, - 720: {region: 0x164, script: 0x52, flags: 0x0}, - 721: {region: 0x164, script: 0x52, flags: 0x0}, - 722: {region: 0x164, script: 0x52, flags: 0x0}, - 723: {region: 0x164, script: 0x52, flags: 0x0}, - 724: {region: 0x164, script: 0x52, flags: 0x0}, - 725: {region: 0x164, script: 0x52, flags: 0x0}, - 726: {region: 0x164, script: 0x5, flags: 0x0}, - 727: {region: 0x105, script: 0x1e, flags: 0x0}, - 728: {region: 0xe6, script: 0x52, flags: 0x0}, - 729: {region: 0x164, script: 0x52, flags: 0x0}, - 730: {region: 0x94, script: 0x52, flags: 0x0}, - 731: {region: 0x164, script: 0x27, flags: 0x0}, - 732: {region: 0x164, script: 0x52, flags: 0x0}, - 733: {region: 0x164, script: 0x52, flags: 0x0}, - 734: {region: 0x164, script: 0x52, flags: 0x0}, - 735: {region: 0x111, script: 0x52, flags: 0x0}, - 736: {region: 0xa3, script: 0x52, flags: 0x0}, - 737: {region: 0x164, script: 0x52, flags: 0x0}, - 738: {region: 0x164, script: 0x52, flags: 0x0}, - 739: {region: 0x122, script: 0x5, flags: 0x0}, - 740: {region: 0xcb, script: 0x52, flags: 0x0}, - 741: {region: 0x164, script: 0x52, flags: 0x0}, - 742: {region: 0x164, script: 0x52, flags: 0x0}, - 743: {region: 0x164, script: 0x52, flags: 0x0}, - 744: {region: 0xbe, script: 0x52, flags: 0x0}, - 745: {region: 0xd0, script: 0x52, flags: 0x0}, - 746: {region: 0x164, script: 0x52, flags: 0x0}, - 747: {region: 0x51, script: 0x52, flags: 0x0}, - 748: {region: 0xda, script: 0x20, flags: 0x0}, - 749: {region: 0x12e, script: 0x52, flags: 0x0}, - 750: {region: 0xbf, script: 0x52, flags: 0x0}, - 751: {region: 0x164, script: 0x52, flags: 0x0}, - 752: {region: 0x164, script: 0x52, flags: 0x0}, - 753: {region: 0xdf, script: 0x52, flags: 0x0}, - 754: {region: 0x164, script: 0x52, flags: 0x0}, - 755: {region: 0x94, script: 0x52, flags: 0x0}, - 756: {region: 0x9a, script: 0x36, flags: 0x0}, - 757: {region: 0x164, script: 0x52, flags: 0x0}, - 758: {region: 0xc1, script: 0x1e, flags: 0x0}, - 759: {region: 0x164, script: 0x5, flags: 0x0}, - 760: {region: 0x164, script: 0x52, flags: 0x0}, - 761: {region: 0x164, script: 0x52, flags: 0x0}, - 762: {region: 0x164, script: 0x52, flags: 0x0}, - 763: {region: 0x98, script: 0x64, flags: 0x0}, - 764: {region: 0x164, script: 0x52, flags: 0x0}, - 765: {region: 0x164, script: 0x52, flags: 0x0}, - 766: {region: 0x10a, script: 0x52, flags: 0x0}, - 767: {region: 0x164, script: 0x52, flags: 0x0}, - 768: {region: 0x164, script: 0x52, flags: 0x0}, - 769: {region: 0x164, script: 0x52, flags: 0x0}, - 770: {region: 0x28, script: 0x3, flags: 0x1}, - 771: {region: 0x164, script: 0x52, flags: 0x0}, - 772: {region: 0x164, script: 0x52, flags: 0x0}, - 773: {region: 0x98, script: 0xe, flags: 0x0}, - 774: {region: 0xc3, script: 0x6b, flags: 0x0}, - 776: {region: 0x164, script: 0x52, flags: 0x0}, - 777: {region: 0x48, script: 0x52, flags: 0x0}, - 778: {region: 0x48, script: 0x52, flags: 0x0}, - 779: {region: 0x36, script: 0x52, flags: 0x0}, - 780: {region: 0x164, script: 0x52, flags: 0x0}, - 781: {region: 0x164, script: 0x52, flags: 0x0}, - 782: {region: 0x164, script: 0x52, flags: 0x0}, - 783: {region: 0x164, script: 0x52, flags: 0x0}, - 784: {region: 0x164, script: 0x52, flags: 0x0}, - 785: {region: 0x164, script: 0x52, flags: 0x0}, - 786: {region: 0x98, script: 0x20, flags: 0x0}, - 787: {region: 0xda, script: 0x20, flags: 0x0}, - 788: {region: 0x105, script: 0x1e, flags: 0x0}, - 789: {region: 0x34, script: 0x68, flags: 0x0}, - 790: {region: 0x2b, script: 0x3, flags: 0x1}, - 791: {region: 0xca, script: 0x52, flags: 0x0}, - 792: {region: 0x164, script: 0x52, flags: 0x0}, - 793: {region: 0x164, script: 0x52, flags: 0x0}, - 794: {region: 0x164, script: 0x52, flags: 0x0}, - 795: {region: 0x98, script: 0x20, flags: 0x0}, - 796: {region: 0x51, script: 0x52, flags: 0x0}, - 798: {region: 0x164, script: 0x52, flags: 0x0}, - 799: {region: 0x134, script: 0x52, flags: 0x0}, - 800: {region: 0x164, script: 0x52, flags: 0x0}, - 801: {region: 0x164, script: 0x52, flags: 0x0}, - 802: {region: 0xe7, script: 0x5, flags: 0x0}, - 803: {region: 0xc2, script: 0x52, flags: 0x0}, - 804: {region: 0x98, script: 0x20, flags: 0x0}, - 805: {region: 0x94, script: 0x52, flags: 0x0}, - 806: {region: 0x163, script: 0x52, flags: 0x0}, - 807: {region: 0x164, script: 0x52, flags: 0x0}, - 808: {region: 0xc3, script: 0x6b, flags: 0x0}, - 809: {region: 0x164, script: 0x52, flags: 0x0}, - 810: {region: 0x164, script: 0x27, flags: 0x0}, - 811: {region: 0x105, script: 0x1e, flags: 0x0}, - 812: {region: 0x164, script: 0x52, flags: 0x0}, - 813: {region: 0x130, script: 0x52, flags: 0x0}, - 814: {region: 0x9b, script: 0x5d, flags: 0x0}, - 815: {region: 0x164, script: 0x52, flags: 0x0}, - 816: {region: 0x164, script: 0x52, flags: 0x0}, - 817: {region: 0x9b, script: 0x5, flags: 0x0}, - 818: {region: 0x164, script: 0x52, flags: 0x0}, - 819: {region: 0x164, script: 0x52, flags: 0x0}, - 820: {region: 0x164, script: 0x52, flags: 0x0}, - 821: {region: 0xdc, script: 0x52, flags: 0x0}, - 822: {region: 0x164, script: 0x52, flags: 0x0}, - 823: {region: 0x164, script: 0x52, flags: 0x0}, - 825: {region: 0x164, script: 0x52, flags: 0x0}, - 826: {region: 0x52, script: 0x34, flags: 0x0}, - 827: {region: 0x9d, script: 0x52, flags: 0x0}, - 828: {region: 0xd1, script: 0x52, flags: 0x0}, - 829: {region: 0x164, script: 0x52, flags: 0x0}, - 830: {region: 0xd9, script: 0x52, flags: 0x0}, - 831: {region: 0x164, script: 0x52, flags: 0x0}, - 832: {region: 0x164, script: 0x52, flags: 0x0}, - 833: {region: 0x164, script: 0x52, flags: 0x0}, - 834: {region: 0xce, script: 0x52, flags: 0x0}, - 835: {region: 0x164, script: 0x52, flags: 0x0}, - 836: {region: 0x164, script: 0x52, flags: 0x0}, - 837: {region: 0x163, script: 0x52, flags: 0x0}, - 838: {region: 0xd0, script: 0x52, flags: 0x0}, - 839: {region: 0x5f, script: 0x52, flags: 0x0}, - 840: {region: 0xda, script: 0x20, flags: 0x0}, - 841: {region: 0x164, script: 0x52, flags: 0x0}, - 842: {region: 0xda, script: 0x20, flags: 0x0}, - 843: {region: 0x164, script: 0x52, flags: 0x0}, - 844: {region: 0x164, script: 0x52, flags: 0x0}, - 845: {region: 0xd1, script: 0x52, flags: 0x0}, - 846: {region: 0x164, script: 0x52, flags: 0x0}, - 847: {region: 0x164, script: 0x52, flags: 0x0}, - 848: {region: 0xd0, script: 0x52, flags: 0x0}, - 849: {region: 0x164, script: 0x52, flags: 0x0}, - 850: {region: 0xce, script: 0x52, flags: 0x0}, - 851: {region: 0xce, script: 0x52, flags: 0x0}, - 852: {region: 0x164, script: 0x52, flags: 0x0}, - 853: {region: 0x164, script: 0x52, flags: 0x0}, - 854: {region: 0x94, script: 0x52, flags: 0x0}, - 855: {region: 0x164, script: 0x52, flags: 0x0}, - 856: {region: 0xde, script: 0x52, flags: 0x0}, - 857: {region: 0x164, script: 0x52, flags: 0x0}, - 858: {region: 0x164, script: 0x52, flags: 0x0}, - 859: {region: 0x98, script: 0x52, flags: 0x0}, - 860: {region: 0x164, script: 0x52, flags: 0x0}, - 861: {region: 0x164, script: 0x52, flags: 0x0}, - 862: {region: 0xd8, script: 0x52, flags: 0x0}, - 863: {region: 0x51, script: 0x52, flags: 0x0}, - 864: {region: 0x164, script: 0x52, flags: 0x0}, - 865: {region: 0xd9, script: 0x52, flags: 0x0}, - 866: {region: 0x164, script: 0x52, flags: 0x0}, - 867: {region: 0x51, script: 0x52, flags: 0x0}, - 868: {region: 0x164, script: 0x52, flags: 0x0}, - 869: {region: 0x164, script: 0x52, flags: 0x0}, - 870: {region: 0xd9, script: 0x52, flags: 0x0}, - 871: {region: 0x122, script: 0x4e, flags: 0x0}, - 872: {region: 0x98, script: 0x20, flags: 0x0}, - 873: {region: 0x10b, script: 0xb7, flags: 0x0}, - 874: {region: 0x164, script: 0x52, flags: 0x0}, - 875: {region: 0x164, script: 0x52, flags: 0x0}, - 876: {region: 0x83, script: 0x70, flags: 0x0}, - 877: {region: 0x160, script: 0x52, flags: 0x0}, - 878: {region: 0x164, script: 0x52, flags: 0x0}, - 879: {region: 0x48, script: 0x17, flags: 0x0}, - 880: {region: 0x164, script: 0x52, flags: 0x0}, - 881: {region: 0x160, script: 0x52, flags: 0x0}, - 882: {region: 0x164, script: 0x52, flags: 0x0}, - 883: {region: 0x164, script: 0x52, flags: 0x0}, - 884: {region: 0x164, script: 0x52, flags: 0x0}, - 885: {region: 0x164, script: 0x52, flags: 0x0}, - 886: {region: 0x164, script: 0x52, flags: 0x0}, - 887: {region: 0x116, script: 0x52, flags: 0x0}, - 888: {region: 0x164, script: 0x52, flags: 0x0}, - 889: {region: 0x164, script: 0x52, flags: 0x0}, - 890: {region: 0x134, script: 0x52, flags: 0x0}, - 891: {region: 0x164, script: 0x52, flags: 0x0}, - 892: {region: 0x52, script: 0x52, flags: 0x0}, - 893: {region: 0x164, script: 0x52, flags: 0x0}, - 894: {region: 0xcd, script: 0x52, flags: 0x0}, - 895: {region: 0x12e, script: 0x52, flags: 0x0}, - 896: {region: 0x130, script: 0x52, flags: 0x0}, - 897: {region: 0x7f, script: 0x52, flags: 0x0}, - 898: {region: 0x77, script: 0x52, flags: 0x0}, - 899: {region: 0x164, script: 0x52, flags: 0x0}, - 901: {region: 0x164, script: 0x52, flags: 0x0}, - 902: {region: 0x164, script: 0x52, flags: 0x0}, - 903: {region: 0x6e, script: 0x52, flags: 0x0}, - 904: {region: 0x164, script: 0x52, flags: 0x0}, - 905: {region: 0x164, script: 0x52, flags: 0x0}, - 906: {region: 0x164, script: 0x52, flags: 0x0}, - 907: {region: 0x164, script: 0x52, flags: 0x0}, - 908: {region: 0x98, script: 0x75, flags: 0x0}, - 909: {region: 0x164, script: 0x52, flags: 0x0}, - 910: {region: 0x164, script: 0x5, flags: 0x0}, - 911: {region: 0x7c, script: 0x1e, flags: 0x0}, - 912: {region: 0x134, script: 0x76, flags: 0x0}, - 913: {region: 0x164, script: 0x5, flags: 0x0}, - 914: {region: 0xc4, script: 0x74, flags: 0x0}, - 915: {region: 0x164, script: 0x52, flags: 0x0}, - 916: {region: 0x2e, script: 0x3, flags: 0x1}, - 917: {region: 0xe6, script: 0x52, flags: 0x0}, - 918: {region: 0x31, script: 0x2, flags: 0x1}, - 919: {region: 0xe6, script: 0x52, flags: 0x0}, - 920: {region: 0x2f, script: 0x52, flags: 0x0}, - 921: {region: 0xef, script: 0x52, flags: 0x0}, - 922: {region: 0x164, script: 0x52, flags: 0x0}, - 923: {region: 0x77, script: 0x52, flags: 0x0}, - 924: {region: 0xd5, script: 0x52, flags: 0x0}, - 925: {region: 0x134, script: 0x52, flags: 0x0}, - 926: {region: 0x48, script: 0x52, flags: 0x0}, - 927: {region: 0x164, script: 0x52, flags: 0x0}, - 928: {region: 0x9b, script: 0xdd, flags: 0x0}, - 929: {region: 0x164, script: 0x52, flags: 0x0}, - 930: {region: 0x5f, script: 0x52, flags: 0x0}, - 931: {region: 0x164, script: 0x5, flags: 0x0}, - 932: {region: 0xaf, script: 0x7f, flags: 0x0}, - 934: {region: 0x164, script: 0x52, flags: 0x0}, - 935: {region: 0x164, script: 0x52, flags: 0x0}, - 936: {region: 0x98, script: 0x12, flags: 0x0}, - 937: {region: 0xa3, script: 0x52, flags: 0x0}, - 938: {region: 0xe8, script: 0x52, flags: 0x0}, - 939: {region: 0x164, script: 0x52, flags: 0x0}, - 940: {region: 0x9d, script: 0x52, flags: 0x0}, - 941: {region: 0x164, script: 0x52, flags: 0x0}, - 942: {region: 0x164, script: 0x52, flags: 0x0}, - 943: {region: 0x86, script: 0x2d, flags: 0x0}, - 944: {region: 0x74, script: 0x52, flags: 0x0}, - 945: {region: 0x164, script: 0x52, flags: 0x0}, - 946: {region: 0xe7, script: 0x45, flags: 0x0}, - 947: {region: 0x9b, script: 0x5, flags: 0x0}, - 948: {region: 0x1, script: 0x52, flags: 0x0}, - 949: {region: 0x23, script: 0x5, flags: 0x0}, - 950: {region: 0x164, script: 0x52, flags: 0x0}, - 951: {region: 0x40, script: 0x52, flags: 0x0}, - 952: {region: 0x164, script: 0x52, flags: 0x0}, - 953: {region: 0x79, script: 0x52, flags: 0x0}, - 954: {region: 0x164, script: 0x52, flags: 0x0}, - 955: {region: 0xe3, script: 0x52, flags: 0x0}, - 956: {region: 0x88, script: 0x52, flags: 0x0}, - 957: {region: 0x68, script: 0x52, flags: 0x0}, - 958: {region: 0x164, script: 0x52, flags: 0x0}, - 959: {region: 0x98, script: 0x20, flags: 0x0}, - 960: {region: 0x164, script: 0x52, flags: 0x0}, - 961: {region: 0x101, script: 0x52, flags: 0x0}, - 962: {region: 0x94, script: 0x52, flags: 0x0}, - 963: {region: 0x164, script: 0x52, flags: 0x0}, - 964: {region: 0x164, script: 0x52, flags: 0x0}, - 965: {region: 0x9d, script: 0x52, flags: 0x0}, - 966: {region: 0x164, script: 0x5, flags: 0x0}, - 967: {region: 0x98, script: 0x52, flags: 0x0}, - 968: {region: 0x33, script: 0x2, flags: 0x1}, - 969: {region: 0xda, script: 0x20, flags: 0x0}, - 970: {region: 0x34, script: 0xe, flags: 0x0}, - 971: {region: 0x4d, script: 0x52, flags: 0x0}, - 972: {region: 0x71, script: 0x52, flags: 0x0}, - 973: {region: 0x4d, script: 0x52, flags: 0x0}, - 974: {region: 0x9b, script: 0x5, flags: 0x0}, - 975: {region: 0x10b, script: 0x52, flags: 0x0}, - 976: {region: 0x39, script: 0x52, flags: 0x0}, - 977: {region: 0x164, script: 0x52, flags: 0x0}, - 978: {region: 0xd0, script: 0x52, flags: 0x0}, - 979: {region: 0x103, script: 0x52, flags: 0x0}, - 980: {region: 0x94, script: 0x52, flags: 0x0}, - 981: {region: 0x12e, script: 0x52, flags: 0x0}, - 982: {region: 0x164, script: 0x52, flags: 0x0}, - 983: {region: 0x164, script: 0x52, flags: 0x0}, - 984: {region: 0x72, script: 0x52, flags: 0x0}, - 985: {region: 0x105, script: 0x1e, flags: 0x0}, - 986: {region: 0x12f, script: 0x1e, flags: 0x0}, - 987: {region: 0x108, script: 0x52, flags: 0x0}, - 988: {region: 0x106, script: 0x52, flags: 0x0}, - 989: {region: 0x12e, script: 0x52, flags: 0x0}, - 990: {region: 0x164, script: 0x52, flags: 0x0}, - 991: {region: 0xa1, script: 0x44, flags: 0x0}, - 992: {region: 0x98, script: 0x20, flags: 0x0}, - 993: {region: 0x7f, script: 0x52, flags: 0x0}, - 994: {region: 0x105, script: 0x1e, flags: 0x0}, - 995: {region: 0xa3, script: 0x52, flags: 0x0}, - 996: {region: 0x94, script: 0x52, flags: 0x0}, - 997: {region: 0x98, script: 0x52, flags: 0x0}, - 998: {region: 0x98, script: 0xbb, flags: 0x0}, - 999: {region: 0x164, script: 0x52, flags: 0x0}, - 1000: {region: 0x164, script: 0x52, flags: 0x0}, - 1001: {region: 0x12e, script: 0x52, flags: 0x0}, - 1002: {region: 0x9d, script: 0x52, flags: 0x0}, - 1003: {region: 0x98, script: 0x20, flags: 0x0}, - 1004: {region: 0x164, script: 0x5, flags: 0x0}, - 1005: {region: 0x9d, script: 0x52, flags: 0x0}, - 1006: {region: 0x7a, script: 0x52, flags: 0x0}, - 1007: {region: 0x48, script: 0x52, flags: 0x0}, - 1008: {region: 0x35, script: 0x4, flags: 0x1}, - 1009: {region: 0x9d, script: 0x52, flags: 0x0}, - 1010: {region: 0x9b, script: 0x5, flags: 0x0}, - 1011: {region: 0xd9, script: 0x52, flags: 0x0}, - 1012: {region: 0x4e, script: 0x52, flags: 0x0}, - 1013: {region: 0xd0, script: 0x52, flags: 0x0}, - 1014: {region: 0xce, script: 0x52, flags: 0x0}, - 1015: {region: 0xc2, script: 0x52, flags: 0x0}, - 1016: {region: 0x4b, script: 0x52, flags: 0x0}, - 1017: {region: 0x95, script: 0x72, flags: 0x0}, - 1018: {region: 0xb5, script: 0x52, flags: 0x0}, - 1019: {region: 0x164, script: 0x27, flags: 0x0}, - 1020: {region: 0x164, script: 0x52, flags: 0x0}, - 1022: {region: 0xb9, script: 0xd2, flags: 0x0}, - 1023: {region: 0x164, script: 0x52, flags: 0x0}, - 1024: {region: 0xc3, script: 0x6b, flags: 0x0}, - 1025: {region: 0x164, script: 0x5, flags: 0x0}, - 1026: {region: 0xb2, script: 0xc1, flags: 0x0}, - 1027: {region: 0x6e, script: 0x52, flags: 0x0}, - 1028: {region: 0x164, script: 0x52, flags: 0x0}, - 1029: {region: 0x164, script: 0x52, flags: 0x0}, - 1030: {region: 0x164, script: 0x52, flags: 0x0}, - 1031: {region: 0x164, script: 0x52, flags: 0x0}, - 1032: {region: 0x110, script: 0x52, flags: 0x0}, - 1033: {region: 0x164, script: 0x52, flags: 0x0}, - 1034: {region: 0xe7, script: 0x5, flags: 0x0}, - 1035: {region: 0x164, script: 0x52, flags: 0x0}, - 1036: {region: 0x10e, script: 0x52, flags: 0x0}, - 1037: {region: 0x164, script: 0x52, flags: 0x0}, - 1038: {region: 0xe8, script: 0x52, flags: 0x0}, - 1039: {region: 0x164, script: 0x52, flags: 0x0}, - 1040: {region: 0x94, script: 0x52, flags: 0x0}, - 1041: {region: 0x141, script: 0x52, flags: 0x0}, - 1042: {region: 0x10b, script: 0x52, flags: 0x0}, - 1044: {region: 0x10b, script: 0x52, flags: 0x0}, - 1045: {region: 0x71, script: 0x52, flags: 0x0}, - 1046: {region: 0x96, script: 0xb8, flags: 0x0}, - 1047: {region: 0x164, script: 0x52, flags: 0x0}, - 1048: {region: 0x71, script: 0x52, flags: 0x0}, - 1049: {region: 0x163, script: 0x52, flags: 0x0}, - 1050: {region: 0x164, script: 0x52, flags: 0x0}, - 1051: {region: 0xc2, script: 0x52, flags: 0x0}, - 1052: {region: 0x164, script: 0x52, flags: 0x0}, - 1053: {region: 0x164, script: 0x52, flags: 0x0}, - 1054: {region: 0x164, script: 0x52, flags: 0x0}, - 1055: {region: 0x114, script: 0x52, flags: 0x0}, - 1056: {region: 0x164, script: 0x52, flags: 0x0}, - 1057: {region: 0x164, script: 0x52, flags: 0x0}, - 1058: {region: 0x122, script: 0xd5, flags: 0x0}, - 1059: {region: 0x164, script: 0x52, flags: 0x0}, - 1060: {region: 0x164, script: 0x52, flags: 0x0}, - 1061: {region: 0x164, script: 0x52, flags: 0x0}, - 1062: {region: 0x164, script: 0x52, flags: 0x0}, - 1063: {region: 0x26, script: 0x52, flags: 0x0}, - 1064: {region: 0x39, script: 0x5, flags: 0x1}, - 1065: {region: 0x98, script: 0xc2, flags: 0x0}, - 1066: {region: 0x115, script: 0x52, flags: 0x0}, - 1067: {region: 0x113, script: 0x52, flags: 0x0}, - 1068: {region: 0x98, script: 0x20, flags: 0x0}, - 1069: {region: 0x160, script: 0x52, flags: 0x0}, - 1070: {region: 0x164, script: 0x52, flags: 0x0}, - 1071: {region: 0x164, script: 0x52, flags: 0x0}, - 1072: {region: 0x6c, script: 0x52, flags: 0x0}, - 1073: {region: 0x160, script: 0x52, flags: 0x0}, - 1074: {region: 0x164, script: 0x52, flags: 0x0}, - 1075: {region: 0x5f, script: 0x52, flags: 0x0}, - 1076: {region: 0x94, script: 0x52, flags: 0x0}, - 1077: {region: 0x164, script: 0x52, flags: 0x0}, - 1078: {region: 0x164, script: 0x52, flags: 0x0}, - 1079: {region: 0x12e, script: 0x52, flags: 0x0}, - 1080: {region: 0x164, script: 0x52, flags: 0x0}, - 1081: {region: 0x83, script: 0x52, flags: 0x0}, - 1082: {region: 0x10b, script: 0x52, flags: 0x0}, - 1083: {region: 0x12e, script: 0x52, flags: 0x0}, - 1084: {region: 0x15e, script: 0x5, flags: 0x0}, - 1085: {region: 0x4a, script: 0x52, flags: 0x0}, - 1086: {region: 0x5f, script: 0x52, flags: 0x0}, - 1087: {region: 0x164, script: 0x52, flags: 0x0}, - 1088: {region: 0x98, script: 0x20, flags: 0x0}, - 1089: {region: 0x94, script: 0x52, flags: 0x0}, - 1090: {region: 0x164, script: 0x52, flags: 0x0}, - 1091: {region: 0x34, script: 0xe, flags: 0x0}, - 1092: {region: 0x9a, script: 0xc5, flags: 0x0}, - 1093: {region: 0xe8, script: 0x52, flags: 0x0}, - 1094: {region: 0x98, script: 0xcd, flags: 0x0}, - 1095: {region: 0xda, script: 0x20, flags: 0x0}, - 1096: {region: 0x164, script: 0x52, flags: 0x0}, - 1097: {region: 0x164, script: 0x52, flags: 0x0}, - 1098: {region: 0x164, script: 0x52, flags: 0x0}, - 1099: {region: 0x164, script: 0x52, flags: 0x0}, - 1100: {region: 0x164, script: 0x52, flags: 0x0}, - 1101: {region: 0x164, script: 0x52, flags: 0x0}, - 1102: {region: 0x164, script: 0x52, flags: 0x0}, - 1103: {region: 0x164, script: 0x52, flags: 0x0}, - 1104: {region: 0xe6, script: 0x52, flags: 0x0}, - 1105: {region: 0x164, script: 0x52, flags: 0x0}, - 1106: {region: 0x164, script: 0x52, flags: 0x0}, - 1107: {region: 0x98, script: 0x4a, flags: 0x0}, - 1108: {region: 0x52, script: 0xcb, flags: 0x0}, - 1109: {region: 0xda, script: 0x20, flags: 0x0}, - 1110: {region: 0xda, script: 0x20, flags: 0x0}, - 1111: {region: 0x98, script: 0xd0, flags: 0x0}, - 1112: {region: 0x164, script: 0x52, flags: 0x0}, - 1113: {region: 0x111, script: 0x52, flags: 0x0}, - 1114: {region: 0x130, script: 0x52, flags: 0x0}, - 1115: {region: 0x125, script: 0x52, flags: 0x0}, - 1116: {region: 0x164, script: 0x52, flags: 0x0}, - 1117: {region: 0x3e, script: 0x3, flags: 0x1}, - 1118: {region: 0x164, script: 0x52, flags: 0x0}, - 1119: {region: 0x164, script: 0x52, flags: 0x0}, - 1120: {region: 0x164, script: 0x52, flags: 0x0}, - 1121: {region: 0x122, script: 0xd5, flags: 0x0}, - 1122: {region: 0xda, script: 0x20, flags: 0x0}, - 1123: {region: 0xda, script: 0x20, flags: 0x0}, - 1124: {region: 0xda, script: 0x20, flags: 0x0}, - 1125: {region: 0x6e, script: 0x27, flags: 0x0}, - 1126: {region: 0x164, script: 0x52, flags: 0x0}, - 1127: {region: 0x6c, script: 0x27, flags: 0x0}, - 1128: {region: 0x164, script: 0x52, flags: 0x0}, - 1129: {region: 0x164, script: 0x52, flags: 0x0}, - 1130: {region: 0x164, script: 0x52, flags: 0x0}, - 1131: {region: 0xd5, script: 0x52, flags: 0x0}, - 1132: {region: 0x126, script: 0x52, flags: 0x0}, - 1133: {region: 0x124, script: 0x52, flags: 0x0}, - 1134: {region: 0x31, script: 0x52, flags: 0x0}, - 1135: {region: 0xda, script: 0x20, flags: 0x0}, - 1136: {region: 0xe6, script: 0x52, flags: 0x0}, - 1137: {region: 0x164, script: 0x52, flags: 0x0}, - 1138: {region: 0x164, script: 0x52, flags: 0x0}, - 1139: {region: 0x31, script: 0x52, flags: 0x0}, - 1140: {region: 0xd3, script: 0x52, flags: 0x0}, - 1141: {region: 0x164, script: 0x52, flags: 0x0}, - 1142: {region: 0x160, script: 0x52, flags: 0x0}, - 1143: {region: 0x164, script: 0x52, flags: 0x0}, - 1144: {region: 0x128, script: 0x52, flags: 0x0}, - 1145: {region: 0x164, script: 0x52, flags: 0x0}, - 1146: {region: 0xcd, script: 0x52, flags: 0x0}, - 1147: {region: 0x164, script: 0x52, flags: 0x0}, - 1148: {region: 0xe5, script: 0x52, flags: 0x0}, - 1149: {region: 0x164, script: 0x52, flags: 0x0}, - 1150: {region: 0x164, script: 0x52, flags: 0x0}, - 1151: {region: 0x164, script: 0x52, flags: 0x0}, - 1152: {region: 0x12a, script: 0x52, flags: 0x0}, - 1153: {region: 0x12a, script: 0x52, flags: 0x0}, - 1154: {region: 0x12d, script: 0x52, flags: 0x0}, - 1155: {region: 0x164, script: 0x5, flags: 0x0}, - 1156: {region: 0x160, script: 0x52, flags: 0x0}, - 1157: {region: 0x86, script: 0x2d, flags: 0x0}, - 1158: {region: 0xda, script: 0x20, flags: 0x0}, - 1159: {region: 0xe6, script: 0x52, flags: 0x0}, - 1160: {region: 0x42, script: 0xd6, flags: 0x0}, - 1161: {region: 0x164, script: 0x52, flags: 0x0}, - 1162: {region: 0x105, script: 0x1e, flags: 0x0}, - 1163: {region: 0x164, script: 0x52, flags: 0x0}, - 1164: {region: 0x164, script: 0x52, flags: 0x0}, - 1165: {region: 0x130, script: 0x52, flags: 0x0}, - 1166: {region: 0x164, script: 0x52, flags: 0x0}, - 1167: {region: 0x122, script: 0xd5, flags: 0x0}, - 1168: {region: 0x31, script: 0x52, flags: 0x0}, - 1169: {region: 0x164, script: 0x52, flags: 0x0}, - 1170: {region: 0x164, script: 0x52, flags: 0x0}, - 1171: {region: 0xcd, script: 0x52, flags: 0x0}, - 1172: {region: 0x164, script: 0x52, flags: 0x0}, - 1173: {region: 0x164, script: 0x52, flags: 0x0}, - 1174: {region: 0x12c, script: 0x52, flags: 0x0}, - 1175: {region: 0x164, script: 0x52, flags: 0x0}, - 1177: {region: 0x164, script: 0x52, flags: 0x0}, - 1178: {region: 0xd3, script: 0x52, flags: 0x0}, - 1179: {region: 0x52, script: 0xce, flags: 0x0}, - 1180: {region: 0xe4, script: 0x52, flags: 0x0}, - 1181: {region: 0x164, script: 0x52, flags: 0x0}, - 1182: {region: 0x105, script: 0x1e, flags: 0x0}, - 1183: {region: 0xb9, script: 0x52, flags: 0x0}, - 1184: {region: 0x164, script: 0x52, flags: 0x0}, - 1185: {region: 0x105, script: 0x1e, flags: 0x0}, - 1186: {region: 0x41, script: 0x4, flags: 0x1}, - 1187: {region: 0x11b, script: 0xd8, flags: 0x0}, - 1188: {region: 0x12f, script: 0x1e, flags: 0x0}, - 1189: {region: 0x74, script: 0x52, flags: 0x0}, - 1190: {region: 0x29, script: 0x52, flags: 0x0}, - 1192: {region: 0x45, script: 0x3, flags: 0x1}, - 1193: {region: 0x98, script: 0xe, flags: 0x0}, - 1194: {region: 0xe7, script: 0x5, flags: 0x0}, - 1195: {region: 0x164, script: 0x52, flags: 0x0}, - 1196: {region: 0x164, script: 0x52, flags: 0x0}, - 1197: {region: 0x164, script: 0x52, flags: 0x0}, - 1198: {region: 0x164, script: 0x52, flags: 0x0}, - 1199: {region: 0x164, script: 0x52, flags: 0x0}, - 1200: {region: 0x164, script: 0x52, flags: 0x0}, - 1201: {region: 0x164, script: 0x52, flags: 0x0}, - 1202: {region: 0x48, script: 0x4, flags: 0x1}, - 1203: {region: 0x164, script: 0x52, flags: 0x0}, - 1204: {region: 0xb3, script: 0xd9, flags: 0x0}, - 1205: {region: 0x164, script: 0x52, flags: 0x0}, - 1206: {region: 0x160, script: 0x52, flags: 0x0}, - 1207: {region: 0x9d, script: 0x52, flags: 0x0}, - 1208: {region: 0x105, script: 0x52, flags: 0x0}, - 1209: {region: 0x13d, script: 0x52, flags: 0x0}, - 1210: {region: 0x11a, script: 0x52, flags: 0x0}, - 1211: {region: 0x164, script: 0x52, flags: 0x0}, - 1212: {region: 0x35, script: 0x52, flags: 0x0}, - 1213: {region: 0x5f, script: 0x52, flags: 0x0}, - 1214: {region: 0xd0, script: 0x52, flags: 0x0}, - 1215: {region: 0x1, script: 0x52, flags: 0x0}, - 1216: {region: 0x105, script: 0x52, flags: 0x0}, - 1217: {region: 0x69, script: 0x52, flags: 0x0}, - 1218: {region: 0x12e, script: 0x52, flags: 0x0}, - 1219: {region: 0x164, script: 0x52, flags: 0x0}, - 1220: {region: 0x35, script: 0x52, flags: 0x0}, - 1221: {region: 0x4d, script: 0x52, flags: 0x0}, - 1222: {region: 0x164, script: 0x52, flags: 0x0}, - 1223: {region: 0x6e, script: 0x27, flags: 0x0}, - 1224: {region: 0x164, script: 0x52, flags: 0x0}, - 1225: {region: 0xe6, script: 0x52, flags: 0x0}, - 1226: {region: 0x2e, script: 0x52, flags: 0x0}, - 1227: {region: 0x98, script: 0xd0, flags: 0x0}, - 1228: {region: 0x98, script: 0x20, flags: 0x0}, - 1229: {region: 0x164, script: 0x52, flags: 0x0}, - 1230: {region: 0x164, script: 0x52, flags: 0x0}, - 1231: {region: 0x164, script: 0x52, flags: 0x0}, - 1232: {region: 0x164, script: 0x52, flags: 0x0}, - 1233: {region: 0x164, script: 0x52, flags: 0x0}, - 1234: {region: 0x164, script: 0x52, flags: 0x0}, - 1235: {region: 0x164, script: 0x52, flags: 0x0}, - 1236: {region: 0x164, script: 0x52, flags: 0x0}, - 1237: {region: 0x164, script: 0x52, flags: 0x0}, - 1238: {region: 0x13f, script: 0x52, flags: 0x0}, - 1239: {region: 0x164, script: 0x52, flags: 0x0}, - 1240: {region: 0x164, script: 0x52, flags: 0x0}, - 1241: {region: 0xa7, script: 0x5, flags: 0x0}, - 1242: {region: 0x164, script: 0x52, flags: 0x0}, - 1243: {region: 0x113, script: 0x52, flags: 0x0}, - 1244: {region: 0x164, script: 0x52, flags: 0x0}, - 1245: {region: 0x164, script: 0x52, flags: 0x0}, - 1246: {region: 0x164, script: 0x52, flags: 0x0}, - 1247: {region: 0x164, script: 0x52, flags: 0x0}, - 1248: {region: 0x98, script: 0x20, flags: 0x0}, - 1249: {region: 0x52, script: 0x34, flags: 0x0}, - 1250: {region: 0x164, script: 0x52, flags: 0x0}, - 1251: {region: 0x164, script: 0x52, flags: 0x0}, - 1252: {region: 0x40, script: 0x52, flags: 0x0}, - 1253: {region: 0x164, script: 0x52, flags: 0x0}, - 1254: {region: 0x12a, script: 0x18, flags: 0x0}, - 1255: {region: 0x164, script: 0x52, flags: 0x0}, - 1256: {region: 0x160, script: 0x52, flags: 0x0}, - 1257: {region: 0x164, script: 0x52, flags: 0x0}, - 1258: {region: 0x12a, script: 0x5a, flags: 0x0}, - 1259: {region: 0x12a, script: 0x5b, flags: 0x0}, - 1260: {region: 0x7c, script: 0x29, flags: 0x0}, - 1261: {region: 0x52, script: 0x5e, flags: 0x0}, - 1262: {region: 0x10a, script: 0x62, flags: 0x0}, - 1263: {region: 0x107, script: 0x6c, flags: 0x0}, - 1264: {region: 0x98, script: 0x20, flags: 0x0}, - 1265: {region: 0x130, script: 0x52, flags: 0x0}, - 1266: {region: 0x164, script: 0x52, flags: 0x0}, - 1267: {region: 0x9b, script: 0x82, flags: 0x0}, - 1268: {region: 0x164, script: 0x52, flags: 0x0}, - 1269: {region: 0x15d, script: 0xba, flags: 0x0}, - 1270: {region: 0x164, script: 0x52, flags: 0x0}, - 1271: {region: 0x164, script: 0x52, flags: 0x0}, - 1272: {region: 0xda, script: 0x20, flags: 0x0}, - 1273: {region: 0x164, script: 0x52, flags: 0x0}, - 1274: {region: 0x164, script: 0x52, flags: 0x0}, - 1275: {region: 0xd0, script: 0x52, flags: 0x0}, - 1276: {region: 0x74, script: 0x52, flags: 0x0}, - 1277: {region: 0x164, script: 0x52, flags: 0x0}, - 1278: {region: 0x164, script: 0x52, flags: 0x0}, - 1279: {region: 0x51, script: 0x52, flags: 0x0}, - 1280: {region: 0x164, script: 0x52, flags: 0x0}, - 1281: {region: 0x164, script: 0x52, flags: 0x0}, - 1282: {region: 0x164, script: 0x52, flags: 0x0}, - 1283: {region: 0x51, script: 0x52, flags: 0x0}, - 1284: {region: 0x164, script: 0x52, flags: 0x0}, - 1285: {region: 0x164, script: 0x52, flags: 0x0}, - 1286: {region: 0x164, script: 0x52, flags: 0x0}, - 1287: {region: 0x164, script: 0x52, flags: 0x0}, - 1288: {region: 0x1, script: 0x37, flags: 0x0}, - 1289: {region: 0x164, script: 0x52, flags: 0x0}, - 1290: {region: 0x164, script: 0x52, flags: 0x0}, - 1291: {region: 0x164, script: 0x52, flags: 0x0}, - 1292: {region: 0x164, script: 0x52, flags: 0x0}, - 1293: {region: 0x164, script: 0x52, flags: 0x0}, - 1294: {region: 0xd5, script: 0x52, flags: 0x0}, - 1295: {region: 0x164, script: 0x52, flags: 0x0}, - 1296: {region: 0x164, script: 0x52, flags: 0x0}, - 1297: {region: 0x164, script: 0x52, flags: 0x0}, - 1298: {region: 0x40, script: 0x52, flags: 0x0}, - 1299: {region: 0x164, script: 0x52, flags: 0x0}, - 1300: {region: 0xce, script: 0x52, flags: 0x0}, - 1301: {region: 0x4c, script: 0x3, flags: 0x1}, - 1302: {region: 0x164, script: 0x52, flags: 0x0}, - 1303: {region: 0x164, script: 0x52, flags: 0x0}, - 1304: {region: 0x164, script: 0x52, flags: 0x0}, - 1305: {region: 0x52, script: 0x52, flags: 0x0}, - 1306: {region: 0x10a, script: 0x52, flags: 0x0}, - 1308: {region: 0xa7, script: 0x5, flags: 0x0}, - 1309: {region: 0xd8, script: 0x52, flags: 0x0}, - 1310: {region: 0xb9, script: 0xd2, flags: 0x0}, - 1311: {region: 0x4f, script: 0x14, flags: 0x1}, - 1312: {region: 0x164, script: 0x52, flags: 0x0}, - 1313: {region: 0x121, script: 0x52, flags: 0x0}, - 1314: {region: 0xcf, script: 0x52, flags: 0x0}, - 1315: {region: 0x164, script: 0x52, flags: 0x0}, - 1316: {region: 0x160, script: 0x52, flags: 0x0}, - 1318: {region: 0x12a, script: 0x52, flags: 0x0}, +// Size: 2852 bytes, 713 elements +var likelyLang = [713]likelyScriptRegion{ + 0: {region: 0x132, script: 0x52, flags: 0x0}, + 1: {region: 0x6e, script: 0x52, flags: 0x0}, + 2: {region: 0x7b, script: 0x1e, flags: 0x0}, + 3: {region: 0x7e, script: 0x52, flags: 0x0}, + 4: {region: 0x93, script: 0x52, flags: 0x0}, + 5: {region: 0x12f, script: 0x52, flags: 0x0}, + 6: {region: 0x7e, script: 0x52, flags: 0x0}, + 7: {region: 0x104, script: 0x1e, flags: 0x0}, + 8: {region: 0x9a, script: 0x9, flags: 0x0}, + 9: {region: 0x126, script: 0x5, flags: 0x0}, + 10: {region: 0x15e, script: 0x52, flags: 0x0}, + 11: {region: 0x51, script: 0x52, flags: 0x0}, + 12: {region: 0x97, script: 0x4, flags: 0x0}, + 13: {region: 0x7e, script: 0x52, flags: 0x0}, + 14: {region: 0x99, script: 0xde, flags: 0x0}, + 15: {region: 0x14a, script: 0x52, flags: 0x0}, + 16: {region: 0x104, script: 0x1e, flags: 0x0}, + 17: {region: 0x6e, script: 0x27, flags: 0x0}, + 18: {region: 0xd4, script: 0x52, flags: 0x0}, + 20: {region: 0x93, script: 0x52, flags: 0x0}, + 21: {region: 0x6a, script: 0x5, flags: 0x0}, + 22: {region: 0x0, script: 0x3, flags: 0x1}, + 23: {region: 0x50, script: 0x52, flags: 0x0}, + 24: {region: 0x3e, script: 0x52, flags: 0x0}, + 25: {region: 0x66, script: 0x5, flags: 0x0}, + 26: {region: 0xb8, script: 0x5, flags: 0x0}, + 27: {region: 0x6a, script: 0x5, flags: 0x0}, + 28: {region: 0x97, script: 0xe, flags: 0x0}, + 29: {region: 0x12d, script: 0x52, flags: 0x0}, + 30: {region: 0x132, script: 0xbc, flags: 0x0}, + 31: {region: 0x6d, script: 0x52, flags: 0x0}, + 32: {region: 0x48, script: 0x52, flags: 0x0}, + 33: {region: 0x104, script: 0x1e, flags: 0x0}, + 34: {region: 0x97, script: 0x20, flags: 0x0}, + 35: {region: 0x3e, script: 0x52, flags: 0x0}, + 36: {region: 0x3, script: 0x5, flags: 0x1}, + 37: {region: 0x104, script: 0x1e, flags: 0x0}, + 38: {region: 0xe6, script: 0x5, flags: 0x0}, + 39: {region: 0x93, script: 0x52, flags: 0x0}, + 40: {region: 0xd9, script: 0x20, flags: 0x0}, + 41: {region: 0x2d, script: 0x52, flags: 0x0}, + 42: {region: 0x51, script: 0x52, flags: 0x0}, + 43: {region: 0x51, script: 0xb, flags: 0x0}, + 44: {region: 0x93, script: 0x52, flags: 0x0}, + 45: {region: 0x51, script: 0x52, flags: 0x0}, + 46: {region: 0x4e, script: 0x52, flags: 0x0}, + 47: {region: 0x46, script: 0x1e, flags: 0x0}, + 48: {region: 0x109, script: 0x5, flags: 0x0}, + 49: {region: 0x15f, script: 0x52, flags: 0x0}, + 50: {region: 0x93, script: 0x52, flags: 0x0}, + 51: {region: 0x12d, script: 0x52, flags: 0x0}, + 52: {region: 0x51, script: 0x52, flags: 0x0}, + 53: {region: 0x97, script: 0xcd, flags: 0x0}, + 54: {region: 0xe6, script: 0x5, flags: 0x0}, + 55: {region: 0x97, script: 0x20, flags: 0x0}, + 56: {region: 0x37, script: 0x1e, flags: 0x0}, + 57: {region: 0x97, script: 0x20, flags: 0x0}, + 58: {region: 0xe6, script: 0x5, flags: 0x0}, + 59: {region: 0x129, script: 0x2d, flags: 0x0}, + 61: {region: 0x97, script: 0x20, flags: 0x0}, + 62: {region: 0x97, script: 0x20, flags: 0x0}, + 63: {region: 0xe5, script: 0x52, flags: 0x0}, + 64: {region: 0x97, script: 0x20, flags: 0x0}, + 65: {region: 0x13c, script: 0x52, flags: 0x0}, + 66: {region: 0xe5, script: 0x52, flags: 0x0}, + 67: {region: 0xd4, script: 0x52, flags: 0x0}, + 68: {region: 0x97, script: 0x20, flags: 0x0}, + 69: {region: 0x93, script: 0x52, flags: 0x0}, + 70: {region: 0x51, script: 0x52, flags: 0x0}, + 71: {region: 0xe5, script: 0x52, flags: 0x0}, + 72: {region: 0x13b, script: 0xcf, flags: 0x0}, + 73: {region: 0xc1, script: 0x52, flags: 0x0}, + 74: {region: 0xc1, script: 0x52, flags: 0x0}, + 75: {region: 0x34, script: 0xe, flags: 0x0}, + 76: {region: 0x52, script: 0xd6, flags: 0x0}, + 77: {region: 0x97, script: 0xe, flags: 0x0}, + 78: {region: 0x9a, script: 0x5, flags: 0x0}, + 79: {region: 0x4e, script: 0x52, flags: 0x0}, + 80: {region: 0x76, script: 0x52, flags: 0x0}, + 81: {region: 0x97, script: 0x20, flags: 0x0}, + 82: {region: 0xe6, script: 0x5, flags: 0x0}, + 83: {region: 0x97, script: 0x20, flags: 0x0}, + 84: {region: 0x32, script: 0x52, flags: 0x0}, + 85: {region: 0xb2, script: 0xc, flags: 0x0}, + 86: {region: 0x51, script: 0x52, flags: 0x0}, + 87: {region: 0xe5, script: 0x52, flags: 0x0}, + 88: {region: 0xe6, script: 0x20, flags: 0x0}, + 89: {region: 0x104, script: 0x1e, flags: 0x0}, + 90: {region: 0x15c, script: 0x52, flags: 0x0}, + 91: {region: 0x93, script: 0x52, flags: 0x0}, + 92: {region: 0x51, script: 0x52, flags: 0x0}, + 93: {region: 0x84, script: 0x52, flags: 0x0}, + 94: {region: 0x6c, script: 0x27, flags: 0x0}, + 95: {region: 0x51, script: 0x52, flags: 0x0}, + 96: {region: 0xc1, script: 0x52, flags: 0x0}, + 97: {region: 0x6d, script: 0x52, flags: 0x0}, + 98: {region: 0xd4, script: 0x52, flags: 0x0}, + 99: {region: 0x8, script: 0x2, flags: 0x1}, + 100: {region: 0x104, script: 0x1e, flags: 0x0}, + 101: {region: 0xe5, script: 0x52, flags: 0x0}, + 102: {region: 0x12f, script: 0x52, flags: 0x0}, + 103: {region: 0x88, script: 0x52, flags: 0x0}, + 104: {region: 0x73, script: 0x52, flags: 0x0}, + 105: {region: 0x104, script: 0x1e, flags: 0x0}, + 106: {region: 0x132, script: 0x52, flags: 0x0}, + 107: {region: 0x48, script: 0x52, flags: 0x0}, + 108: {region: 0x132, script: 0x1a, flags: 0x0}, + 109: {region: 0xa4, script: 0x5, flags: 0x0}, + 110: {region: 0x13b, script: 0x19, flags: 0x0}, + 111: {region: 0x99, script: 0x5, flags: 0x0}, + 112: {region: 0x76, script: 0x52, flags: 0x0}, + 113: {region: 0x6a, script: 0x1c, flags: 0x0}, + 114: {region: 0xe5, script: 0x52, flags: 0x0}, + 115: {region: 0x48, script: 0x17, flags: 0x0}, + 116: {region: 0x48, script: 0x17, flags: 0x0}, + 117: {region: 0x48, script: 0x17, flags: 0x0}, + 118: {region: 0x48, script: 0x17, flags: 0x0}, + 119: {region: 0x48, script: 0x17, flags: 0x0}, + 120: {region: 0x108, script: 0x52, flags: 0x0}, + 121: {region: 0x5d, script: 0x52, flags: 0x0}, + 122: {region: 0xe7, script: 0x52, flags: 0x0}, + 123: {region: 0x48, script: 0x17, flags: 0x0}, + 124: {region: 0xc2, script: 0x79, flags: 0x0}, + 125: {region: 0xa, script: 0x2, flags: 0x1}, + 126: {region: 0x104, script: 0x1e, flags: 0x0}, + 127: {region: 0x79, script: 0x52, flags: 0x0}, + 128: {region: 0x62, script: 0x52, flags: 0x0}, + 129: {region: 0x132, script: 0x52, flags: 0x0}, + 130: {region: 0x104, script: 0x1e, flags: 0x0}, + 131: {region: 0xa2, script: 0x52, flags: 0x0}, + 132: {region: 0x97, script: 0x5, flags: 0x0}, + 133: {region: 0x5f, script: 0x52, flags: 0x0}, + 134: {region: 0x48, script: 0x52, flags: 0x0}, + 135: {region: 0x48, script: 0x52, flags: 0x0}, + 136: {region: 0xd2, script: 0x52, flags: 0x0}, + 137: {region: 0x4e, script: 0x52, flags: 0x0}, + 138: {region: 0x97, script: 0x5, flags: 0x0}, + 139: {region: 0x5f, script: 0x52, flags: 0x0}, + 140: {region: 0xc1, script: 0x52, flags: 0x0}, + 141: {region: 0xce, script: 0x52, flags: 0x0}, + 142: {region: 0xd9, script: 0x20, flags: 0x0}, + 143: {region: 0x51, script: 0x52, flags: 0x0}, + 144: {region: 0xcb, script: 0xd4, flags: 0x0}, + 145: {region: 0x112, script: 0x52, flags: 0x0}, + 146: {region: 0x36, script: 0x52, flags: 0x0}, + 147: {region: 0x42, script: 0xd6, flags: 0x0}, + 148: {region: 0xa2, script: 0x52, flags: 0x0}, + 149: {region: 0x7e, script: 0x52, flags: 0x0}, + 150: {region: 0xd4, script: 0x52, flags: 0x0}, + 151: {region: 0x9c, script: 0x52, flags: 0x0}, + 152: {region: 0x6a, script: 0x25, flags: 0x0}, + 153: {region: 0xc2, script: 0x43, flags: 0x0}, + 154: {region: 0x85, script: 0x2d, flags: 0x0}, + 155: {region: 0xc, script: 0x2, flags: 0x1}, + 156: {region: 0x1, script: 0x52, flags: 0x0}, + 157: {region: 0x6d, script: 0x52, flags: 0x0}, + 158: {region: 0x132, script: 0x52, flags: 0x0}, + 159: {region: 0x69, script: 0x52, flags: 0x0}, + 160: {region: 0x9c, script: 0x3e, flags: 0x0}, + 161: {region: 0x6d, script: 0x52, flags: 0x0}, + 162: {region: 0x51, script: 0x52, flags: 0x0}, + 163: {region: 0x6d, script: 0x52, flags: 0x0}, + 164: {region: 0x9a, script: 0x5, flags: 0x0}, + 165: {region: 0x84, script: 0x52, flags: 0x0}, + 166: {region: 0xe, script: 0x2, flags: 0x1}, + 167: {region: 0xc1, script: 0x52, flags: 0x0}, + 168: {region: 0x70, script: 0x52, flags: 0x0}, + 169: {region: 0x109, script: 0x5, flags: 0x0}, + 170: {region: 0xe5, script: 0x52, flags: 0x0}, + 171: {region: 0x10a, script: 0x52, flags: 0x0}, + 172: {region: 0x71, script: 0x52, flags: 0x0}, + 173: {region: 0x74, script: 0x52, flags: 0x0}, + 174: {region: 0x3a, script: 0x52, flags: 0x0}, + 175: {region: 0x76, script: 0x52, flags: 0x0}, + 176: {region: 0x132, script: 0x52, flags: 0x0}, + 177: {region: 0x76, script: 0x52, flags: 0x0}, + 178: {region: 0x5f, script: 0x52, flags: 0x0}, + 179: {region: 0x5f, script: 0x52, flags: 0x0}, + 180: {region: 0x13d, script: 0x52, flags: 0x0}, + 181: {region: 0xd2, script: 0x52, flags: 0x0}, + 182: {region: 0x9c, script: 0x52, flags: 0x0}, + 183: {region: 0xd4, script: 0x52, flags: 0x0}, + 184: {region: 0x109, script: 0x52, flags: 0x0}, + 185: {region: 0xd7, script: 0x52, flags: 0x0}, + 186: {region: 0x94, script: 0x52, flags: 0x0}, + 187: {region: 0x7e, script: 0x52, flags: 0x0}, + 188: {region: 0xba, script: 0x52, flags: 0x0}, + 189: {region: 0x52, script: 0x34, flags: 0x0}, + 190: {region: 0x93, script: 0x52, flags: 0x0}, + 191: {region: 0x97, script: 0x20, flags: 0x0}, + 192: {region: 0x9a, script: 0x5, flags: 0x0}, + 193: {region: 0x7c, script: 0x52, flags: 0x0}, + 194: {region: 0x79, script: 0x52, flags: 0x0}, + 195: {region: 0x6e, script: 0x27, flags: 0x0}, + 196: {region: 0xd9, script: 0x20, flags: 0x0}, + 197: {region: 0xa5, script: 0x52, flags: 0x0}, + 198: {region: 0xe6, script: 0x5, flags: 0x0}, + 199: {region: 0xe6, script: 0x5, flags: 0x0}, + 200: {region: 0x6d, script: 0x52, flags: 0x0}, + 201: {region: 0x9a, script: 0x5, flags: 0x0}, + 202: {region: 0xef, script: 0x52, flags: 0x0}, + 203: {region: 0x97, script: 0x20, flags: 0x0}, + 204: {region: 0x97, script: 0xd0, flags: 0x0}, + 205: {region: 0x93, script: 0x52, flags: 0x0}, + 206: {region: 0xd7, script: 0x52, flags: 0x0}, + 207: {region: 0x12e, script: 0x2b, flags: 0x0}, + 208: {region: 0x10, script: 0x2, flags: 0x1}, + 209: {region: 0x97, script: 0xe, flags: 0x0}, + 210: {region: 0x4d, script: 0x52, flags: 0x0}, + 211: {region: 0x97, script: 0x2e, flags: 0x0}, + 212: {region: 0x40, script: 0x52, flags: 0x0}, + 213: {region: 0x53, script: 0x52, flags: 0x0}, + 214: {region: 0x7e, script: 0x52, flags: 0x0}, + 216: {region: 0xa2, script: 0x52, flags: 0x0}, + 217: {region: 0x96, script: 0x52, flags: 0x0}, + 218: {region: 0xd9, script: 0x20, flags: 0x0}, + 219: {region: 0x48, script: 0x52, flags: 0x0}, + 220: {region: 0x12, script: 0x3, flags: 0x1}, + 221: {region: 0x52, script: 0x34, flags: 0x0}, + 222: {region: 0x132, script: 0x52, flags: 0x0}, + 223: {region: 0x23, script: 0x5, flags: 0x0}, + 224: {region: 0x95, script: 0x37, flags: 0x0}, + 225: {region: 0x97, script: 0x20, flags: 0x0}, + 226: {region: 0x71, script: 0x52, flags: 0x0}, + 227: {region: 0xe5, script: 0x52, flags: 0x0}, + 228: {region: 0x129, script: 0x39, flags: 0x0}, + 229: {region: 0x52, script: 0x81, flags: 0x0}, + 230: {region: 0xe6, script: 0x5, flags: 0x0}, + 231: {region: 0x97, script: 0x20, flags: 0x0}, + 232: {region: 0xad, script: 0x3a, flags: 0x0}, + 233: {region: 0xe5, script: 0x52, flags: 0x0}, + 234: {region: 0xe6, script: 0x5, flags: 0x0}, + 235: {region: 0xe4, script: 0x52, flags: 0x0}, + 236: {region: 0x97, script: 0x20, flags: 0x0}, + 237: {region: 0x97, script: 0x20, flags: 0x0}, + 238: {region: 0x8e, script: 0x52, flags: 0x0}, + 239: {region: 0x5f, script: 0x52, flags: 0x0}, + 240: {region: 0x52, script: 0x34, flags: 0x0}, + 241: {region: 0x8f, script: 0x52, flags: 0x0}, + 242: {region: 0x90, script: 0x52, flags: 0x0}, + 243: {region: 0x27, script: 0x8, flags: 0x0}, + 244: {region: 0xd0, script: 0x52, flags: 0x0}, + 245: {region: 0x76, script: 0x52, flags: 0x0}, + 246: {region: 0xce, script: 0x52, flags: 0x0}, + 247: {region: 0xd4, script: 0x52, flags: 0x0}, + 248: {region: 0x93, script: 0x52, flags: 0x0}, + 250: {region: 0xd4, script: 0x52, flags: 0x0}, + 251: {region: 0x52, script: 0xdf, flags: 0x0}, + 252: {region: 0x132, script: 0x52, flags: 0x0}, + 253: {region: 0x48, script: 0x52, flags: 0x0}, + 254: {region: 0xe5, script: 0x52, flags: 0x0}, + 255: {region: 0x93, script: 0x52, flags: 0x0}, + 256: {region: 0x104, script: 0x1e, flags: 0x0}, + 258: {region: 0x9b, script: 0x52, flags: 0x0}, + 259: {region: 0x9c, script: 0x52, flags: 0x0}, + 260: {region: 0x48, script: 0x17, flags: 0x0}, + 261: {region: 0x95, script: 0x37, flags: 0x0}, + 262: {region: 0x104, script: 0x52, flags: 0x0}, + 263: {region: 0xa0, script: 0x41, flags: 0x0}, + 264: {region: 0x9e, script: 0x52, flags: 0x0}, + 266: {region: 0x51, script: 0x52, flags: 0x0}, + 267: {region: 0x12e, script: 0x37, flags: 0x0}, + 268: {region: 0x12d, script: 0x52, flags: 0x0}, + 269: {region: 0xd9, script: 0x20, flags: 0x0}, + 270: {region: 0x62, script: 0x52, flags: 0x0}, + 271: {region: 0x93, script: 0x52, flags: 0x0}, + 272: {region: 0x93, script: 0x52, flags: 0x0}, + 273: {region: 0x7b, script: 0x29, flags: 0x0}, + 274: {region: 0x134, script: 0x1e, flags: 0x0}, + 275: {region: 0x66, script: 0x52, flags: 0x0}, + 276: {region: 0xc2, script: 0x52, flags: 0x0}, + 277: {region: 0xd4, script: 0x52, flags: 0x0}, + 278: {region: 0xa2, script: 0x52, flags: 0x0}, + 279: {region: 0xc1, script: 0x52, flags: 0x0}, + 280: {region: 0x104, script: 0x1e, flags: 0x0}, + 281: {region: 0xd4, script: 0x52, flags: 0x0}, + 282: {region: 0x161, script: 0x52, flags: 0x0}, + 283: {region: 0x12d, script: 0x52, flags: 0x0}, + 284: {region: 0x121, script: 0xd5, flags: 0x0}, + 285: {region: 0x59, script: 0x52, flags: 0x0}, + 286: {region: 0x51, script: 0x52, flags: 0x0}, + 287: {region: 0x4e, script: 0x52, flags: 0x0}, + 288: {region: 0x97, script: 0x20, flags: 0x0}, + 289: {region: 0x97, script: 0x20, flags: 0x0}, + 290: {region: 0x4a, script: 0x52, flags: 0x0}, + 291: {region: 0x93, script: 0x52, flags: 0x0}, + 292: {region: 0x40, script: 0x52, flags: 0x0}, + 293: {region: 0x97, script: 0x52, flags: 0x0}, + 294: {region: 0x52, script: 0xcc, flags: 0x0}, + 295: {region: 0x97, script: 0x20, flags: 0x0}, + 296: {region: 0xc1, script: 0x52, flags: 0x0}, + 297: {region: 0x97, script: 0x6b, flags: 0x0}, + 298: {region: 0xe6, script: 0x5, flags: 0x0}, + 299: {region: 0xa2, script: 0x52, flags: 0x0}, + 300: {region: 0x129, script: 0x52, flags: 0x0}, + 301: {region: 0xd0, script: 0x52, flags: 0x0}, + 302: {region: 0xad, script: 0x4f, flags: 0x0}, + 303: {region: 0x15, script: 0x6, flags: 0x1}, + 304: {region: 0x51, script: 0x52, flags: 0x0}, + 305: {region: 0x80, script: 0x52, flags: 0x0}, + 306: {region: 0xa2, script: 0x52, flags: 0x0}, + 307: {region: 0xa4, script: 0x46, flags: 0x0}, + 308: {region: 0x29, script: 0x52, flags: 0x0}, + 309: {region: 0x97, script: 0x4a, flags: 0x0}, + 310: {region: 0xa9, script: 0x4b, flags: 0x0}, + 311: {region: 0x104, script: 0x1e, flags: 0x0}, + 312: {region: 0x97, script: 0x20, flags: 0x0}, + 313: {region: 0x73, script: 0x52, flags: 0x0}, + 314: {region: 0xb2, script: 0x52, flags: 0x0}, + 316: {region: 0x104, script: 0x1e, flags: 0x0}, + 317: {region: 0x110, script: 0x52, flags: 0x0}, + 318: {region: 0xe5, script: 0x52, flags: 0x0}, + 319: {region: 0x104, script: 0x52, flags: 0x0}, + 320: {region: 0x97, script: 0x20, flags: 0x0}, + 321: {region: 0x97, script: 0x5, flags: 0x0}, + 322: {region: 0x12d, script: 0x52, flags: 0x0}, + 323: {region: 0x51, script: 0x52, flags: 0x0}, + 324: {region: 0x5f, script: 0x52, flags: 0x0}, + 325: {region: 0x1b, script: 0x3, flags: 0x1}, + 326: {region: 0x104, script: 0x1e, flags: 0x0}, + 327: {region: 0x104, script: 0x1e, flags: 0x0}, + 328: {region: 0x93, script: 0x52, flags: 0x0}, + 329: {region: 0xe6, script: 0x5, flags: 0x0}, + 330: {region: 0x79, script: 0x52, flags: 0x0}, + 331: {region: 0x121, script: 0xd5, flags: 0x0}, + 332: {region: 0xe6, script: 0x5, flags: 0x0}, + 333: {region: 0x1e, script: 0x5, flags: 0x1}, + 334: {region: 0x135, script: 0x52, flags: 0x0}, + 335: {region: 0x85, script: 0x56, flags: 0x0}, + 336: {region: 0x95, script: 0x37, flags: 0x0}, + 337: {region: 0x12d, script: 0x52, flags: 0x0}, + 338: {region: 0xe6, script: 0x5, flags: 0x0}, + 339: {region: 0x12f, script: 0x52, flags: 0x0}, + 340: {region: 0xb5, script: 0x52, flags: 0x0}, + 341: {region: 0x104, script: 0x1e, flags: 0x0}, + 342: {region: 0x93, script: 0x52, flags: 0x0}, + 343: {region: 0x52, script: 0xd5, flags: 0x0}, + 344: {region: 0x97, script: 0x54, flags: 0x0}, + 345: {region: 0x104, script: 0x1e, flags: 0x0}, + 346: {region: 0x12f, script: 0x52, flags: 0x0}, + 347: {region: 0xd7, script: 0x52, flags: 0x0}, + 348: {region: 0x23, script: 0x2, flags: 0x1}, + 349: {region: 0x9c, script: 0x52, flags: 0x0}, + 350: {region: 0x52, script: 0x58, flags: 0x0}, + 351: {region: 0x93, script: 0x52, flags: 0x0}, + 352: {region: 0x9a, script: 0x5, flags: 0x0}, + 353: {region: 0x132, script: 0x52, flags: 0x0}, + 354: {region: 0x97, script: 0xd0, flags: 0x0}, + 355: {region: 0x9c, script: 0x52, flags: 0x0}, + 356: {region: 0x4a, script: 0x52, flags: 0x0}, + 357: {region: 0xad, script: 0x4f, flags: 0x0}, + 358: {region: 0x4a, script: 0x52, flags: 0x0}, + 359: {region: 0x15f, script: 0x52, flags: 0x0}, + 360: {region: 0x9a, script: 0x5, flags: 0x0}, + 361: {region: 0xb4, script: 0x52, flags: 0x0}, + 362: {region: 0xb6, script: 0x52, flags: 0x0}, + 363: {region: 0x4a, script: 0x52, flags: 0x0}, + 364: {region: 0x4a, script: 0x52, flags: 0x0}, + 365: {region: 0xa2, script: 0x52, flags: 0x0}, + 366: {region: 0xa2, script: 0x52, flags: 0x0}, + 367: {region: 0x9a, script: 0x5, flags: 0x0}, + 368: {region: 0xb6, script: 0x52, flags: 0x0}, + 369: {region: 0x121, script: 0xd5, flags: 0x0}, + 370: {region: 0x52, script: 0x34, flags: 0x0}, + 371: {region: 0x129, script: 0x52, flags: 0x0}, + 372: {region: 0x93, script: 0x52, flags: 0x0}, + 373: {region: 0x51, script: 0x52, flags: 0x0}, + 374: {region: 0x97, script: 0x20, flags: 0x0}, + 375: {region: 0x97, script: 0x20, flags: 0x0}, + 376: {region: 0x93, script: 0x52, flags: 0x0}, + 377: {region: 0x25, script: 0x3, flags: 0x1}, + 378: {region: 0xa2, script: 0x52, flags: 0x0}, + 379: {region: 0xcd, script: 0x52, flags: 0x0}, + 380: {region: 0x104, script: 0x1e, flags: 0x0}, + 381: {region: 0xe5, script: 0x52, flags: 0x0}, + 382: {region: 0x93, script: 0x52, flags: 0x0}, + 383: {region: 0x110, script: 0x52, flags: 0x0}, + 384: {region: 0xa2, script: 0x52, flags: 0x0}, + 385: {region: 0x121, script: 0x5, flags: 0x0}, + 386: {region: 0xca, script: 0x52, flags: 0x0}, + 387: {region: 0xbd, script: 0x52, flags: 0x0}, + 388: {region: 0xcf, script: 0x52, flags: 0x0}, + 389: {region: 0x51, script: 0x52, flags: 0x0}, + 390: {region: 0xd9, script: 0x20, flags: 0x0}, + 391: {region: 0x12d, script: 0x52, flags: 0x0}, + 392: {region: 0xbe, script: 0x52, flags: 0x0}, + 393: {region: 0xde, script: 0x52, flags: 0x0}, + 394: {region: 0x93, script: 0x52, flags: 0x0}, + 395: {region: 0x99, script: 0x36, flags: 0x0}, + 396: {region: 0xc0, script: 0x1e, flags: 0x0}, + 397: {region: 0x97, script: 0x64, flags: 0x0}, + 398: {region: 0x109, script: 0x52, flags: 0x0}, + 399: {region: 0x28, script: 0x3, flags: 0x1}, + 400: {region: 0x97, script: 0xe, flags: 0x0}, + 401: {region: 0xc2, script: 0x6b, flags: 0x0}, + 403: {region: 0x48, script: 0x52, flags: 0x0}, + 404: {region: 0x48, script: 0x52, flags: 0x0}, + 405: {region: 0x36, script: 0x52, flags: 0x0}, + 406: {region: 0x97, script: 0x20, flags: 0x0}, + 407: {region: 0xd9, script: 0x20, flags: 0x0}, + 408: {region: 0x104, script: 0x1e, flags: 0x0}, + 409: {region: 0x34, script: 0x68, flags: 0x0}, + 410: {region: 0x2b, script: 0x3, flags: 0x1}, + 411: {region: 0xc9, script: 0x52, flags: 0x0}, + 412: {region: 0x97, script: 0x20, flags: 0x0}, + 413: {region: 0x51, script: 0x52, flags: 0x0}, + 415: {region: 0x132, script: 0x52, flags: 0x0}, + 416: {region: 0xe6, script: 0x5, flags: 0x0}, + 417: {region: 0xc1, script: 0x52, flags: 0x0}, + 418: {region: 0x97, script: 0x20, flags: 0x0}, + 419: {region: 0x93, script: 0x52, flags: 0x0}, + 420: {region: 0x161, script: 0x52, flags: 0x0}, + 421: {region: 0xc2, script: 0x6b, flags: 0x0}, + 422: {region: 0x104, script: 0x1e, flags: 0x0}, + 423: {region: 0x12f, script: 0x52, flags: 0x0}, + 424: {region: 0x9a, script: 0x5d, flags: 0x0}, + 425: {region: 0x9a, script: 0x5, flags: 0x0}, + 426: {region: 0xdb, script: 0x52, flags: 0x0}, + 428: {region: 0x52, script: 0x34, flags: 0x0}, + 429: {region: 0x9c, script: 0x52, flags: 0x0}, + 430: {region: 0xd0, script: 0x52, flags: 0x0}, + 431: {region: 0xd8, script: 0x52, flags: 0x0}, + 432: {region: 0xcd, script: 0x52, flags: 0x0}, + 433: {region: 0x161, script: 0x52, flags: 0x0}, + 434: {region: 0xcf, script: 0x52, flags: 0x0}, + 435: {region: 0x5f, script: 0x52, flags: 0x0}, + 436: {region: 0xd9, script: 0x20, flags: 0x0}, + 437: {region: 0xd9, script: 0x20, flags: 0x0}, + 438: {region: 0xd0, script: 0x52, flags: 0x0}, + 439: {region: 0xcf, script: 0x52, flags: 0x0}, + 440: {region: 0xcd, script: 0x52, flags: 0x0}, + 441: {region: 0xcd, script: 0x52, flags: 0x0}, + 442: {region: 0x93, script: 0x52, flags: 0x0}, + 443: {region: 0xdd, script: 0x52, flags: 0x0}, + 444: {region: 0x97, script: 0x52, flags: 0x0}, + 445: {region: 0xd7, script: 0x52, flags: 0x0}, + 446: {region: 0x51, script: 0x52, flags: 0x0}, + 447: {region: 0xd8, script: 0x52, flags: 0x0}, + 448: {region: 0x51, script: 0x52, flags: 0x0}, + 449: {region: 0xd8, script: 0x52, flags: 0x0}, + 450: {region: 0x121, script: 0x4e, flags: 0x0}, + 451: {region: 0x97, script: 0x20, flags: 0x0}, + 452: {region: 0x10a, script: 0xb7, flags: 0x0}, + 453: {region: 0x82, script: 0x70, flags: 0x0}, + 454: {region: 0x15e, script: 0x52, flags: 0x0}, + 455: {region: 0x48, script: 0x17, flags: 0x0}, + 456: {region: 0x15e, script: 0x52, flags: 0x0}, + 457: {region: 0x115, script: 0x52, flags: 0x0}, + 458: {region: 0x132, script: 0x52, flags: 0x0}, + 459: {region: 0x52, script: 0x52, flags: 0x0}, + 460: {region: 0xcc, script: 0x52, flags: 0x0}, + 461: {region: 0x12d, script: 0x52, flags: 0x0}, + 462: {region: 0x12f, script: 0x52, flags: 0x0}, + 463: {region: 0x7e, script: 0x52, flags: 0x0}, + 464: {region: 0x76, script: 0x52, flags: 0x0}, + 466: {region: 0x6e, script: 0x52, flags: 0x0}, + 467: {region: 0x97, script: 0x75, flags: 0x0}, + 468: {region: 0x7b, script: 0x1e, flags: 0x0}, + 469: {region: 0x132, script: 0x76, flags: 0x0}, + 470: {region: 0xc3, script: 0x74, flags: 0x0}, + 471: {region: 0x2e, script: 0x3, flags: 0x1}, + 472: {region: 0xe5, script: 0x52, flags: 0x0}, + 473: {region: 0x31, script: 0x2, flags: 0x1}, + 474: {region: 0xe5, script: 0x52, flags: 0x0}, + 475: {region: 0x2f, script: 0x52, flags: 0x0}, + 476: {region: 0xee, script: 0x52, flags: 0x0}, + 477: {region: 0x76, script: 0x52, flags: 0x0}, + 478: {region: 0xd4, script: 0x52, flags: 0x0}, + 479: {region: 0x132, script: 0x52, flags: 0x0}, + 480: {region: 0x48, script: 0x52, flags: 0x0}, + 481: {region: 0x9a, script: 0xdd, flags: 0x0}, + 482: {region: 0x5f, script: 0x52, flags: 0x0}, + 483: {region: 0xae, script: 0x7f, flags: 0x0}, + 485: {region: 0x97, script: 0x12, flags: 0x0}, + 486: {region: 0xa2, script: 0x52, flags: 0x0}, + 487: {region: 0xe7, script: 0x52, flags: 0x0}, + 488: {region: 0x9c, script: 0x52, flags: 0x0}, + 489: {region: 0x85, script: 0x2d, flags: 0x0}, + 490: {region: 0x73, script: 0x52, flags: 0x0}, + 491: {region: 0xe6, script: 0x45, flags: 0x0}, + 492: {region: 0x9a, script: 0x5, flags: 0x0}, + 493: {region: 0x1, script: 0x52, flags: 0x0}, + 494: {region: 0x23, script: 0x5, flags: 0x0}, + 495: {region: 0x40, script: 0x52, flags: 0x0}, + 496: {region: 0x78, script: 0x52, flags: 0x0}, + 497: {region: 0xe2, script: 0x52, flags: 0x0}, + 498: {region: 0x87, script: 0x52, flags: 0x0}, + 499: {region: 0x68, script: 0x52, flags: 0x0}, + 500: {region: 0x97, script: 0x20, flags: 0x0}, + 501: {region: 0x100, script: 0x52, flags: 0x0}, + 502: {region: 0x93, script: 0x52, flags: 0x0}, + 503: {region: 0x9c, script: 0x52, flags: 0x0}, + 504: {region: 0x97, script: 0x52, flags: 0x0}, + 505: {region: 0x33, script: 0x2, flags: 0x1}, + 506: {region: 0xd9, script: 0x20, flags: 0x0}, + 507: {region: 0x34, script: 0xe, flags: 0x0}, + 508: {region: 0x4d, script: 0x52, flags: 0x0}, + 509: {region: 0x70, script: 0x52, flags: 0x0}, + 510: {region: 0x4d, script: 0x52, flags: 0x0}, + 511: {region: 0x9a, script: 0x5, flags: 0x0}, + 512: {region: 0x10a, script: 0x52, flags: 0x0}, + 513: {region: 0x39, script: 0x52, flags: 0x0}, + 514: {region: 0xcf, script: 0x52, flags: 0x0}, + 515: {region: 0x102, script: 0x52, flags: 0x0}, + 516: {region: 0x93, script: 0x52, flags: 0x0}, + 517: {region: 0x12d, script: 0x52, flags: 0x0}, + 518: {region: 0x71, script: 0x52, flags: 0x0}, + 519: {region: 0x104, script: 0x1e, flags: 0x0}, + 520: {region: 0x12e, script: 0x1e, flags: 0x0}, + 521: {region: 0x107, script: 0x52, flags: 0x0}, + 522: {region: 0x105, script: 0x52, flags: 0x0}, + 523: {region: 0x12d, script: 0x52, flags: 0x0}, + 524: {region: 0xa0, script: 0x44, flags: 0x0}, + 525: {region: 0x97, script: 0x20, flags: 0x0}, + 526: {region: 0x7e, script: 0x52, flags: 0x0}, + 527: {region: 0x104, script: 0x1e, flags: 0x0}, + 528: {region: 0xa2, script: 0x52, flags: 0x0}, + 529: {region: 0x93, script: 0x52, flags: 0x0}, + 530: {region: 0x97, script: 0x52, flags: 0x0}, + 531: {region: 0x97, script: 0xbb, flags: 0x0}, + 532: {region: 0x12d, script: 0x52, flags: 0x0}, + 533: {region: 0x9c, script: 0x52, flags: 0x0}, + 534: {region: 0x97, script: 0x20, flags: 0x0}, + 535: {region: 0x9c, script: 0x52, flags: 0x0}, + 536: {region: 0x79, script: 0x52, flags: 0x0}, + 537: {region: 0x48, script: 0x52, flags: 0x0}, + 538: {region: 0x35, script: 0x4, flags: 0x1}, + 539: {region: 0x9c, script: 0x52, flags: 0x0}, + 540: {region: 0x9a, script: 0x5, flags: 0x0}, + 541: {region: 0xd8, script: 0x52, flags: 0x0}, + 542: {region: 0x4e, script: 0x52, flags: 0x0}, + 543: {region: 0xcf, script: 0x52, flags: 0x0}, + 544: {region: 0xcd, script: 0x52, flags: 0x0}, + 545: {region: 0xc1, script: 0x52, flags: 0x0}, + 546: {region: 0x4b, script: 0x52, flags: 0x0}, + 547: {region: 0x94, script: 0x72, flags: 0x0}, + 548: {region: 0xb4, script: 0x52, flags: 0x0}, + 550: {region: 0xb8, script: 0xd2, flags: 0x0}, + 551: {region: 0xc2, script: 0x6b, flags: 0x0}, + 552: {region: 0xb1, script: 0xc1, flags: 0x0}, + 553: {region: 0x6e, script: 0x52, flags: 0x0}, + 554: {region: 0x10f, script: 0x52, flags: 0x0}, + 555: {region: 0xe6, script: 0x5, flags: 0x0}, + 556: {region: 0x10d, script: 0x52, flags: 0x0}, + 557: {region: 0xe7, script: 0x52, flags: 0x0}, + 558: {region: 0x93, script: 0x52, flags: 0x0}, + 559: {region: 0x13f, script: 0x52, flags: 0x0}, + 560: {region: 0x10a, script: 0x52, flags: 0x0}, + 562: {region: 0x10a, script: 0x52, flags: 0x0}, + 563: {region: 0x70, script: 0x52, flags: 0x0}, + 564: {region: 0x95, script: 0xb8, flags: 0x0}, + 565: {region: 0x70, script: 0x52, flags: 0x0}, + 566: {region: 0x161, script: 0x52, flags: 0x0}, + 567: {region: 0xc1, script: 0x52, flags: 0x0}, + 568: {region: 0x113, script: 0x52, flags: 0x0}, + 569: {region: 0x121, script: 0xd5, flags: 0x0}, + 570: {region: 0x26, script: 0x52, flags: 0x0}, + 571: {region: 0x39, script: 0x5, flags: 0x1}, + 572: {region: 0x97, script: 0xc2, flags: 0x0}, + 573: {region: 0x114, script: 0x52, flags: 0x0}, + 574: {region: 0x112, script: 0x52, flags: 0x0}, + 575: {region: 0x97, script: 0x20, flags: 0x0}, + 576: {region: 0x15e, script: 0x52, flags: 0x0}, + 577: {region: 0x6c, script: 0x52, flags: 0x0}, + 578: {region: 0x15e, script: 0x52, flags: 0x0}, + 579: {region: 0x5f, script: 0x52, flags: 0x0}, + 580: {region: 0x93, script: 0x52, flags: 0x0}, + 581: {region: 0x12d, script: 0x52, flags: 0x0}, + 582: {region: 0x82, script: 0x52, flags: 0x0}, + 583: {region: 0x10a, script: 0x52, flags: 0x0}, + 584: {region: 0x12d, script: 0x52, flags: 0x0}, + 585: {region: 0x15c, script: 0x5, flags: 0x0}, + 586: {region: 0x4a, script: 0x52, flags: 0x0}, + 587: {region: 0x5f, script: 0x52, flags: 0x0}, + 588: {region: 0x97, script: 0x20, flags: 0x0}, + 589: {region: 0x93, script: 0x52, flags: 0x0}, + 590: {region: 0x34, script: 0xe, flags: 0x0}, + 591: {region: 0x99, script: 0xc5, flags: 0x0}, + 592: {region: 0xe7, script: 0x52, flags: 0x0}, + 593: {region: 0x97, script: 0xcd, flags: 0x0}, + 594: {region: 0xd9, script: 0x20, flags: 0x0}, + 595: {region: 0xe5, script: 0x52, flags: 0x0}, + 596: {region: 0x97, script: 0x4a, flags: 0x0}, + 597: {region: 0x52, script: 0xcb, flags: 0x0}, + 598: {region: 0xd9, script: 0x20, flags: 0x0}, + 599: {region: 0xd9, script: 0x20, flags: 0x0}, + 600: {region: 0x97, script: 0xd0, flags: 0x0}, + 601: {region: 0x110, script: 0x52, flags: 0x0}, + 602: {region: 0x12f, script: 0x52, flags: 0x0}, + 603: {region: 0x124, script: 0x52, flags: 0x0}, + 604: {region: 0x3e, script: 0x3, flags: 0x1}, + 605: {region: 0x121, script: 0xd5, flags: 0x0}, + 606: {region: 0xd9, script: 0x20, flags: 0x0}, + 607: {region: 0xd9, script: 0x20, flags: 0x0}, + 608: {region: 0xd9, script: 0x20, flags: 0x0}, + 609: {region: 0x6e, script: 0x27, flags: 0x0}, + 610: {region: 0x6c, script: 0x27, flags: 0x0}, + 611: {region: 0xd4, script: 0x52, flags: 0x0}, + 612: {region: 0x125, script: 0x52, flags: 0x0}, + 613: {region: 0x123, script: 0x52, flags: 0x0}, + 614: {region: 0x31, script: 0x52, flags: 0x0}, + 615: {region: 0xd9, script: 0x20, flags: 0x0}, + 616: {region: 0xe5, script: 0x52, flags: 0x0}, + 617: {region: 0x31, script: 0x52, flags: 0x0}, + 618: {region: 0xd2, script: 0x52, flags: 0x0}, + 619: {region: 0x15e, script: 0x52, flags: 0x0}, + 620: {region: 0x127, script: 0x52, flags: 0x0}, + 621: {region: 0xcc, script: 0x52, flags: 0x0}, + 622: {region: 0xe4, script: 0x52, flags: 0x0}, + 623: {region: 0x129, script: 0x52, flags: 0x0}, + 624: {region: 0x129, script: 0x52, flags: 0x0}, + 625: {region: 0x12c, script: 0x52, flags: 0x0}, + 626: {region: 0x15e, script: 0x52, flags: 0x0}, + 627: {region: 0x85, script: 0x2d, flags: 0x0}, + 628: {region: 0xd9, script: 0x20, flags: 0x0}, + 629: {region: 0xe5, script: 0x52, flags: 0x0}, + 630: {region: 0x42, script: 0xd6, flags: 0x0}, + 631: {region: 0x104, script: 0x1e, flags: 0x0}, + 632: {region: 0x12f, script: 0x52, flags: 0x0}, + 633: {region: 0x121, script: 0xd5, flags: 0x0}, + 634: {region: 0x31, script: 0x52, flags: 0x0}, + 635: {region: 0xcc, script: 0x52, flags: 0x0}, + 636: {region: 0x12b, script: 0x52, flags: 0x0}, + 638: {region: 0xd2, script: 0x52, flags: 0x0}, + 639: {region: 0x52, script: 0xce, flags: 0x0}, + 640: {region: 0xe3, script: 0x52, flags: 0x0}, + 641: {region: 0x104, script: 0x1e, flags: 0x0}, + 642: {region: 0xb8, script: 0x52, flags: 0x0}, + 643: {region: 0x104, script: 0x1e, flags: 0x0}, + 644: {region: 0x41, script: 0x4, flags: 0x1}, + 645: {region: 0x11a, script: 0xd8, flags: 0x0}, + 646: {region: 0x12e, script: 0x1e, flags: 0x0}, + 647: {region: 0x73, script: 0x52, flags: 0x0}, + 648: {region: 0x29, script: 0x52, flags: 0x0}, + 650: {region: 0x45, script: 0x3, flags: 0x1}, + 651: {region: 0x97, script: 0xe, flags: 0x0}, + 652: {region: 0xe6, script: 0x5, flags: 0x0}, + 653: {region: 0x48, script: 0x4, flags: 0x1}, + 654: {region: 0xb2, script: 0xd9, flags: 0x0}, + 655: {region: 0x15e, script: 0x52, flags: 0x0}, + 656: {region: 0x9c, script: 0x52, flags: 0x0}, + 657: {region: 0x104, script: 0x52, flags: 0x0}, + 658: {region: 0x13b, script: 0x52, flags: 0x0}, + 659: {region: 0x119, script: 0x52, flags: 0x0}, + 660: {region: 0x35, script: 0x52, flags: 0x0}, + 661: {region: 0x5f, script: 0x52, flags: 0x0}, + 662: {region: 0xcf, script: 0x52, flags: 0x0}, + 663: {region: 0x1, script: 0x52, flags: 0x0}, + 664: {region: 0x104, script: 0x52, flags: 0x0}, + 665: {region: 0x69, script: 0x52, flags: 0x0}, + 666: {region: 0x12d, script: 0x52, flags: 0x0}, + 667: {region: 0x35, script: 0x52, flags: 0x0}, + 668: {region: 0x4d, script: 0x52, flags: 0x0}, + 669: {region: 0x6e, script: 0x27, flags: 0x0}, + 670: {region: 0xe5, script: 0x52, flags: 0x0}, + 671: {region: 0x2e, script: 0x52, flags: 0x0}, + 672: {region: 0x97, script: 0xd0, flags: 0x0}, + 673: {region: 0x97, script: 0x20, flags: 0x0}, + 674: {region: 0x13d, script: 0x52, flags: 0x0}, + 675: {region: 0xa6, script: 0x5, flags: 0x0}, + 676: {region: 0x112, script: 0x52, flags: 0x0}, + 677: {region: 0x97, script: 0x20, flags: 0x0}, + 678: {region: 0x52, script: 0x34, flags: 0x0}, + 679: {region: 0x40, script: 0x52, flags: 0x0}, + 680: {region: 0x129, script: 0x18, flags: 0x0}, + 681: {region: 0x15e, script: 0x52, flags: 0x0}, + 682: {region: 0x129, script: 0x5a, flags: 0x0}, + 683: {region: 0x129, script: 0x5b, flags: 0x0}, + 684: {region: 0x7b, script: 0x29, flags: 0x0}, + 685: {region: 0x52, script: 0x5e, flags: 0x0}, + 686: {region: 0x109, script: 0x62, flags: 0x0}, + 687: {region: 0x106, script: 0x6c, flags: 0x0}, + 688: {region: 0x97, script: 0x20, flags: 0x0}, + 689: {region: 0x12f, script: 0x52, flags: 0x0}, + 690: {region: 0x9a, script: 0x82, flags: 0x0}, + 691: {region: 0x15b, script: 0xba, flags: 0x0}, + 692: {region: 0xd9, script: 0x20, flags: 0x0}, + 693: {region: 0xcf, script: 0x52, flags: 0x0}, + 694: {region: 0x73, script: 0x52, flags: 0x0}, + 695: {region: 0x51, script: 0x52, flags: 0x0}, + 696: {region: 0x51, script: 0x52, flags: 0x0}, + 697: {region: 0x1, script: 0x37, flags: 0x0}, + 698: {region: 0xd4, script: 0x52, flags: 0x0}, + 699: {region: 0x40, script: 0x52, flags: 0x0}, + 700: {region: 0xcd, script: 0x52, flags: 0x0}, + 701: {region: 0x4c, script: 0x3, flags: 0x1}, + 702: {region: 0x52, script: 0x52, flags: 0x0}, + 703: {region: 0x109, script: 0x52, flags: 0x0}, + 705: {region: 0xa6, script: 0x5, flags: 0x0}, + 706: {region: 0xd7, script: 0x52, flags: 0x0}, + 707: {region: 0xb8, script: 0xd2, flags: 0x0}, + 708: {region: 0x4f, script: 0x14, flags: 0x1}, + 709: {region: 0xce, script: 0x52, flags: 0x0}, + 710: {region: 0x15e, script: 0x52, flags: 0x0}, + 712: {region: 0x129, script: 0x52, flags: 0x0}, } // likelyLangList holds lists info associated with likelyLang. // Size: 396 bytes, 99 elements var likelyLangList = [99]likelyScriptRegion{ - 0: {region: 0x9b, script: 0x7, flags: 0x0}, - 1: {region: 0xa0, script: 0x6d, flags: 0x2}, - 2: {region: 0x11b, script: 0x78, flags: 0x2}, + 0: {region: 0x9a, script: 0x7, flags: 0x0}, + 1: {region: 0x9f, script: 0x6d, flags: 0x2}, + 2: {region: 0x11a, script: 0x78, flags: 0x2}, 3: {region: 0x31, script: 0x52, flags: 0x0}, - 4: {region: 0x9a, script: 0x5, flags: 0x4}, - 5: {region: 0x9b, script: 0x5, flags: 0x4}, - 6: {region: 0x105, script: 0x1e, flags: 0x4}, - 7: {region: 0x9b, script: 0x5, flags: 0x2}, - 8: {region: 0x98, script: 0xe, flags: 0x0}, + 4: {region: 0x99, script: 0x5, flags: 0x4}, + 5: {region: 0x9a, script: 0x5, flags: 0x4}, + 6: {region: 0x104, script: 0x1e, flags: 0x4}, + 7: {region: 0x9a, script: 0x5, flags: 0x2}, + 8: {region: 0x97, script: 0xe, flags: 0x0}, 9: {region: 0x34, script: 0x16, flags: 0x2}, - 10: {region: 0x105, script: 0x1e, flags: 0x0}, + 10: {region: 0x104, script: 0x1e, flags: 0x0}, 11: {region: 0x37, script: 0x2a, flags: 0x2}, - 12: {region: 0x134, script: 0x52, flags: 0x0}, - 13: {region: 0x7a, script: 0xbd, flags: 0x2}, - 14: {region: 0x113, script: 0x52, flags: 0x0}, - 15: {region: 0x83, script: 0x1, flags: 0x2}, + 12: {region: 0x132, script: 0x52, flags: 0x0}, + 13: {region: 0x79, script: 0xbd, flags: 0x2}, + 14: {region: 0x112, script: 0x52, flags: 0x0}, + 15: {region: 0x82, script: 0x1, flags: 0x2}, 16: {region: 0x5c, script: 0x1d, flags: 0x0}, - 17: {region: 0x86, script: 0x57, flags: 0x2}, - 18: {region: 0xd5, script: 0x52, flags: 0x0}, + 17: {region: 0x85, script: 0x57, flags: 0x2}, + 18: {region: 0xd4, script: 0x52, flags: 0x0}, 19: {region: 0x51, script: 0x5, flags: 0x4}, - 20: {region: 0x10a, script: 0x5, flags: 0x4}, - 21: {region: 0xad, script: 0x1e, flags: 0x0}, + 20: {region: 0x109, script: 0x5, flags: 0x4}, + 21: {region: 0xac, script: 0x1e, flags: 0x0}, 22: {region: 0x23, script: 0x5, flags: 0x4}, 23: {region: 0x52, script: 0x5, flags: 0x4}, - 24: {region: 0x9b, script: 0x5, flags: 0x4}, - 25: {region: 0xc4, script: 0x5, flags: 0x4}, + 24: {region: 0x9a, script: 0x5, flags: 0x4}, + 25: {region: 0xc3, script: 0x5, flags: 0x4}, 26: {region: 0x52, script: 0x5, flags: 0x2}, - 27: {region: 0x12a, script: 0x52, flags: 0x0}, - 28: {region: 0xaf, script: 0x5, flags: 0x4}, - 29: {region: 0x9a, script: 0x5, flags: 0x2}, - 30: {region: 0xa4, script: 0x1e, flags: 0x0}, + 27: {region: 0x129, script: 0x52, flags: 0x0}, + 28: {region: 0xae, script: 0x5, flags: 0x4}, + 29: {region: 0x99, script: 0x5, flags: 0x2}, + 30: {region: 0xa3, script: 0x1e, flags: 0x0}, 31: {region: 0x52, script: 0x5, flags: 0x4}, - 32: {region: 0x12a, script: 0x52, flags: 0x4}, + 32: {region: 0x129, script: 0x52, flags: 0x4}, 33: {region: 0x52, script: 0x5, flags: 0x2}, - 34: {region: 0x12a, script: 0x52, flags: 0x2}, - 35: {region: 0xda, script: 0x20, flags: 0x0}, - 36: {region: 0x98, script: 0x55, flags: 0x2}, - 37: {region: 0x82, script: 0x52, flags: 0x0}, - 38: {region: 0x83, script: 0x70, flags: 0x4}, - 39: {region: 0x83, script: 0x70, flags: 0x2}, - 40: {region: 0xc4, script: 0x1e, flags: 0x0}, + 34: {region: 0x129, script: 0x52, flags: 0x2}, + 35: {region: 0xd9, script: 0x20, flags: 0x0}, + 36: {region: 0x97, script: 0x55, flags: 0x2}, + 37: {region: 0x81, script: 0x52, flags: 0x0}, + 38: {region: 0x82, script: 0x70, flags: 0x4}, + 39: {region: 0x82, script: 0x70, flags: 0x2}, + 40: {region: 0xc3, script: 0x1e, flags: 0x0}, 41: {region: 0x52, script: 0x66, flags: 0x4}, 42: {region: 0x52, script: 0x66, flags: 0x2}, - 43: {region: 0xcf, script: 0x52, flags: 0x0}, + 43: {region: 0xce, script: 0x52, flags: 0x0}, 44: {region: 0x49, script: 0x5, flags: 0x4}, - 45: {region: 0x94, script: 0x5, flags: 0x4}, - 46: {region: 0x98, script: 0x2f, flags: 0x0}, - 47: {region: 0xe7, script: 0x5, flags: 0x4}, - 48: {region: 0xe7, script: 0x5, flags: 0x2}, - 49: {region: 0x9b, script: 0x7c, flags: 0x0}, + 45: {region: 0x93, script: 0x5, flags: 0x4}, + 46: {region: 0x97, script: 0x2f, flags: 0x0}, + 47: {region: 0xe6, script: 0x5, flags: 0x4}, + 48: {region: 0xe6, script: 0x5, flags: 0x2}, + 49: {region: 0x9a, script: 0x7c, flags: 0x0}, 50: {region: 0x52, script: 0x7d, flags: 0x2}, - 51: {region: 0xb9, script: 0xd2, flags: 0x0}, - 52: {region: 0xd8, script: 0x52, flags: 0x4}, - 53: {region: 0xe7, script: 0x5, flags: 0x0}, - 54: {region: 0x98, script: 0x20, flags: 0x2}, - 55: {region: 0x98, script: 0x47, flags: 0x2}, - 56: {region: 0x98, script: 0xc0, flags: 0x2}, - 57: {region: 0x104, script: 0x1e, flags: 0x0}, - 58: {region: 0xbc, script: 0x52, flags: 0x4}, - 59: {region: 0x103, script: 0x52, flags: 0x4}, - 60: {region: 0x105, script: 0x52, flags: 0x4}, - 61: {region: 0x12a, script: 0x52, flags: 0x4}, - 62: {region: 0x123, script: 0x1e, flags: 0x0}, - 63: {region: 0xe7, script: 0x5, flags: 0x4}, - 64: {region: 0xe7, script: 0x5, flags: 0x2}, + 51: {region: 0xb8, script: 0xd2, flags: 0x0}, + 52: {region: 0xd7, script: 0x52, flags: 0x4}, + 53: {region: 0xe6, script: 0x5, flags: 0x0}, + 54: {region: 0x97, script: 0x20, flags: 0x2}, + 55: {region: 0x97, script: 0x47, flags: 0x2}, + 56: {region: 0x97, script: 0xc0, flags: 0x2}, + 57: {region: 0x103, script: 0x1e, flags: 0x0}, + 58: {region: 0xbb, script: 0x52, flags: 0x4}, + 59: {region: 0x102, script: 0x52, flags: 0x4}, + 60: {region: 0x104, script: 0x52, flags: 0x4}, + 61: {region: 0x129, script: 0x52, flags: 0x4}, + 62: {region: 0x122, script: 0x1e, flags: 0x0}, + 63: {region: 0xe6, script: 0x5, flags: 0x4}, + 64: {region: 0xe6, script: 0x5, flags: 0x2}, 65: {region: 0x52, script: 0x5, flags: 0x0}, - 66: {region: 0xad, script: 0x1e, flags: 0x4}, - 67: {region: 0xc4, script: 0x1e, flags: 0x4}, - 68: {region: 0xad, script: 0x1e, flags: 0x2}, - 69: {region: 0x98, script: 0xe, flags: 0x0}, - 70: {region: 0xda, script: 0x20, flags: 0x4}, - 71: {region: 0xda, script: 0x20, flags: 0x2}, - 72: {region: 0x136, script: 0x52, flags: 0x0}, + 66: {region: 0xac, script: 0x1e, flags: 0x4}, + 67: {region: 0xc3, script: 0x1e, flags: 0x4}, + 68: {region: 0xac, script: 0x1e, flags: 0x2}, + 69: {region: 0x97, script: 0xe, flags: 0x0}, + 70: {region: 0xd9, script: 0x20, flags: 0x4}, + 71: {region: 0xd9, script: 0x20, flags: 0x2}, + 72: {region: 0x134, script: 0x52, flags: 0x0}, 73: {region: 0x23, script: 0x5, flags: 0x4}, 74: {region: 0x52, script: 0x1e, flags: 0x4}, 75: {region: 0x23, script: 0x5, flags: 0x2}, - 76: {region: 0x8c, script: 0x35, flags: 0x0}, + 76: {region: 0x8b, script: 0x35, flags: 0x0}, 77: {region: 0x52, script: 0x34, flags: 0x4}, 78: {region: 0x52, script: 0x34, flags: 0x2}, 79: {region: 0x52, script: 0x34, flags: 0x0}, 80: {region: 0x2e, script: 0x35, flags: 0x4}, 81: {region: 0x3d, script: 0x35, flags: 0x4}, - 82: {region: 0x7a, script: 0x35, flags: 0x4}, - 83: {region: 0x7d, script: 0x35, flags: 0x4}, - 84: {region: 0x8c, script: 0x35, flags: 0x4}, - 85: {region: 0x94, script: 0x35, flags: 0x4}, - 86: {region: 0xc5, script: 0x35, flags: 0x4}, - 87: {region: 0xcf, script: 0x35, flags: 0x4}, - 88: {region: 0xe1, script: 0x35, flags: 0x4}, - 89: {region: 0xe4, script: 0x35, flags: 0x4}, - 90: {region: 0xe6, script: 0x35, flags: 0x4}, - 91: {region: 0x115, script: 0x35, flags: 0x4}, - 92: {region: 0x122, script: 0x35, flags: 0x4}, - 93: {region: 0x12d, script: 0x35, flags: 0x4}, - 94: {region: 0x134, script: 0x35, flags: 0x4}, - 95: {region: 0x13d, script: 0x35, flags: 0x4}, - 96: {region: 0x12d, script: 0x11, flags: 0x2}, - 97: {region: 0x12d, script: 0x30, flags: 0x2}, - 98: {region: 0x12d, script: 0x35, flags: 0x2}, + 82: {region: 0x79, script: 0x35, flags: 0x4}, + 83: {region: 0x7c, script: 0x35, flags: 0x4}, + 84: {region: 0x8b, script: 0x35, flags: 0x4}, + 85: {region: 0x93, script: 0x35, flags: 0x4}, + 86: {region: 0xc4, script: 0x35, flags: 0x4}, + 87: {region: 0xce, script: 0x35, flags: 0x4}, + 88: {region: 0xe0, script: 0x35, flags: 0x4}, + 89: {region: 0xe3, script: 0x35, flags: 0x4}, + 90: {region: 0xe5, script: 0x35, flags: 0x4}, + 91: {region: 0x114, script: 0x35, flags: 0x4}, + 92: {region: 0x121, script: 0x35, flags: 0x4}, + 93: {region: 0x12c, script: 0x35, flags: 0x4}, + 94: {region: 0x132, script: 0x35, flags: 0x4}, + 95: {region: 0x13b, script: 0x35, flags: 0x4}, + 96: {region: 0x12c, script: 0x11, flags: 0x2}, + 97: {region: 0x12c, script: 0x30, flags: 0x2}, + 98: {region: 0x12c, script: 0x35, flags: 0x2}, } type likelyLangScript struct { @@ -2916,310 +2163,307 @@ type likelyLangScript struct { // for a given regionID, lang and script are the index and size respectively // of the list in likelyRegionList. // TODO: exclude containers and user-definable regions from the list. -// Size: 1428 bytes, 357 elements -var likelyRegion = [357]likelyLangScript{ - 33: {lang: 0xd5, script: 0x52, flags: 0x0}, - 34: {lang: 0x39, script: 0x5, flags: 0x0}, +// Size: 1420 bytes, 355 elements +var likelyRegion = [355]likelyLangScript{ + 33: {lang: 0x61, script: 0x52, flags: 0x0}, + 34: {lang: 0x15, script: 0x5, flags: 0x0}, 35: {lang: 0x0, script: 0x2, flags: 0x1}, 38: {lang: 0x2, script: 0x2, flags: 0x1}, 39: {lang: 0x4, script: 0x2, flags: 0x1}, - 41: {lang: 0x3b7, script: 0x52, flags: 0x0}, + 41: {lang: 0x1ef, script: 0x52, flags: 0x0}, 42: {lang: 0x0, script: 0x52, flags: 0x0}, - 43: {lang: 0x139, script: 0x52, flags: 0x0}, - 44: {lang: 0x411, script: 0x52, flags: 0x0}, - 45: {lang: 0x109, script: 0x52, flags: 0x0}, - 47: {lang: 0x35e, script: 0x52, flags: 0x0}, - 48: {lang: 0x43a, script: 0x52, flags: 0x0}, - 49: {lang: 0x57, script: 0x52, flags: 0x0}, + 43: {lang: 0x9d, script: 0x52, flags: 0x0}, + 44: {lang: 0x22f, script: 0x52, flags: 0x0}, + 45: {lang: 0x85, script: 0x52, flags: 0x0}, + 47: {lang: 0x1bd, script: 0x52, flags: 0x0}, + 48: {lang: 0x247, script: 0x52, flags: 0x0}, + 49: {lang: 0x24, script: 0x52, flags: 0x0}, 50: {lang: 0x6, script: 0x2, flags: 0x1}, - 52: {lang: 0xa3, script: 0xe, flags: 0x0}, - 53: {lang: 0x35e, script: 0x52, flags: 0x0}, - 54: {lang: 0x159, script: 0x52, flags: 0x0}, - 55: {lang: 0x7d, script: 0x1e, flags: 0x0}, - 56: {lang: 0x39, script: 0x5, flags: 0x0}, - 57: {lang: 0x3d0, script: 0x52, flags: 0x0}, - 58: {lang: 0x159, script: 0x52, flags: 0x0}, - 59: {lang: 0x159, script: 0x52, flags: 0x0}, - 61: {lang: 0x316, script: 0x52, flags: 0x0}, - 62: {lang: 0x139, script: 0x52, flags: 0x0}, - 63: {lang: 0x398, script: 0x52, flags: 0x0}, - 64: {lang: 0x3b7, script: 0x52, flags: 0x0}, + 52: {lang: 0x4b, script: 0xe, flags: 0x0}, + 53: {lang: 0x1bd, script: 0x52, flags: 0x0}, + 54: {lang: 0xaf, script: 0x52, flags: 0x0}, + 55: {lang: 0x38, script: 0x1e, flags: 0x0}, + 56: {lang: 0x15, script: 0x5, flags: 0x0}, + 57: {lang: 0x201, script: 0x52, flags: 0x0}, + 58: {lang: 0xaf, script: 0x52, flags: 0x0}, + 59: {lang: 0xaf, script: 0x52, flags: 0x0}, + 61: {lang: 0x19a, script: 0x52, flags: 0x0}, + 62: {lang: 0x9d, script: 0x52, flags: 0x0}, + 63: {lang: 0x1db, script: 0x52, flags: 0x0}, + 64: {lang: 0x1ef, script: 0x52, flags: 0x0}, 66: {lang: 0x8, script: 0x2, flags: 0x1}, 68: {lang: 0x0, script: 0x52, flags: 0x0}, - 70: {lang: 0x70, script: 0x1e, flags: 0x0}, - 72: {lang: 0x508, script: 0x37, flags: 0x2}, - 73: {lang: 0x316, script: 0x5, flags: 0x2}, - 74: {lang: 0x43b, script: 0x52, flags: 0x0}, - 75: {lang: 0x159, script: 0x52, flags: 0x0}, - 76: {lang: 0x159, script: 0x52, flags: 0x0}, - 77: {lang: 0x109, script: 0x52, flags: 0x0}, - 78: {lang: 0x159, script: 0x52, flags: 0x0}, - 80: {lang: 0x139, script: 0x52, flags: 0x0}, - 81: {lang: 0x159, script: 0x52, flags: 0x0}, + 70: {lang: 0x2f, script: 0x1e, flags: 0x0}, + 72: {lang: 0x2b9, script: 0x37, flags: 0x2}, + 73: {lang: 0x19a, script: 0x5, flags: 0x2}, + 74: {lang: 0x248, script: 0x52, flags: 0x0}, + 75: {lang: 0xaf, script: 0x52, flags: 0x0}, + 76: {lang: 0xaf, script: 0x52, flags: 0x0}, + 77: {lang: 0x85, script: 0x52, flags: 0x0}, + 78: {lang: 0xaf, script: 0x52, flags: 0x0}, + 80: {lang: 0x9d, script: 0x52, flags: 0x0}, + 81: {lang: 0xaf, script: 0x52, flags: 0x0}, 82: {lang: 0xa, script: 0x5, flags: 0x1}, - 83: {lang: 0x139, script: 0x52, flags: 0x0}, + 83: {lang: 0x9d, script: 0x52, flags: 0x0}, 84: {lang: 0x0, script: 0x52, flags: 0x0}, - 85: {lang: 0x139, script: 0x52, flags: 0x0}, - 88: {lang: 0x139, script: 0x52, flags: 0x0}, - 89: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 90: {lang: 0x398, script: 0x52, flags: 0x0}, + 85: {lang: 0x9d, script: 0x52, flags: 0x0}, + 88: {lang: 0x9d, script: 0x52, flags: 0x0}, + 89: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 90: {lang: 0x1db, script: 0x52, flags: 0x0}, 92: {lang: 0xf, script: 0x2, flags: 0x1}, - 93: {lang: 0xf6, script: 0x52, flags: 0x0}, - 95: {lang: 0x109, script: 0x52, flags: 0x0}, + 93: {lang: 0x79, script: 0x52, flags: 0x0}, + 95: {lang: 0x85, script: 0x52, flags: 0x0}, 97: {lang: 0x1, script: 0x52, flags: 0x0}, - 98: {lang: 0xfd, script: 0x52, flags: 0x0}, - 100: {lang: 0x139, script: 0x52, flags: 0x0}, + 98: {lang: 0x80, script: 0x52, flags: 0x0}, + 100: {lang: 0x9d, script: 0x52, flags: 0x0}, 102: {lang: 0x11, script: 0x2, flags: 0x1}, - 103: {lang: 0x139, script: 0x52, flags: 0x0}, - 104: {lang: 0x139, script: 0x52, flags: 0x0}, - 105: {lang: 0x13b, script: 0x52, flags: 0x0}, - 106: {lang: 0x39, script: 0x5, flags: 0x0}, - 107: {lang: 0x39, script: 0x5, flags: 0x0}, - 108: {lang: 0x465, script: 0x27, flags: 0x0}, - 109: {lang: 0x139, script: 0x52, flags: 0x0}, + 103: {lang: 0x9d, script: 0x52, flags: 0x0}, + 104: {lang: 0x9d, script: 0x52, flags: 0x0}, + 105: {lang: 0x9f, script: 0x52, flags: 0x0}, + 106: {lang: 0x15, script: 0x5, flags: 0x0}, + 107: {lang: 0x15, script: 0x5, flags: 0x0}, + 108: {lang: 0x261, script: 0x27, flags: 0x0}, + 109: {lang: 0x9d, script: 0x52, flags: 0x0}, 110: {lang: 0x13, script: 0x2, flags: 0x1}, - 112: {lang: 0x109, script: 0x52, flags: 0x0}, - 113: {lang: 0x14c, script: 0x52, flags: 0x0}, - 114: {lang: 0x1b9, script: 0x20, flags: 0x2}, - 117: {lang: 0x153, script: 0x52, flags: 0x0}, - 119: {lang: 0x159, script: 0x52, flags: 0x0}, - 121: {lang: 0x159, script: 0x52, flags: 0x0}, - 122: {lang: 0x15, script: 0x2, flags: 0x1}, - 124: {lang: 0x17, script: 0x3, flags: 0x1}, - 125: {lang: 0x159, script: 0x52, flags: 0x0}, - 127: {lang: 0x20, script: 0x52, flags: 0x0}, - 129: {lang: 0x23d, script: 0x52, flags: 0x0}, - 131: {lang: 0x159, script: 0x52, flags: 0x0}, - 132: {lang: 0x159, script: 0x52, flags: 0x0}, - 133: {lang: 0x139, script: 0x52, flags: 0x0}, - 134: {lang: 0x1a, script: 0x2, flags: 0x1}, - 135: {lang: 0x0, script: 0x52, flags: 0x0}, - 136: {lang: 0x139, script: 0x52, flags: 0x0}, - 138: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 140: {lang: 0x51f, script: 0x35, flags: 0x0}, - 141: {lang: 0x0, script: 0x52, flags: 0x0}, - 142: {lang: 0x139, script: 0x52, flags: 0x0}, - 143: {lang: 0x1ca, script: 0x52, flags: 0x0}, - 144: {lang: 0x1cd, script: 0x52, flags: 0x0}, - 145: {lang: 0x1ce, script: 0x52, flags: 0x0}, - 147: {lang: 0x139, script: 0x52, flags: 0x0}, - 148: {lang: 0x1c, script: 0x2, flags: 0x1}, - 150: {lang: 0x1b5, script: 0x37, flags: 0x0}, - 152: {lang: 0x1e, script: 0x3, flags: 0x1}, - 154: {lang: 0x39, script: 0x5, flags: 0x0}, - 155: {lang: 0x21, script: 0x2, flags: 0x1}, - 156: {lang: 0x1f0, script: 0x52, flags: 0x0}, - 157: {lang: 0x1f1, script: 0x52, flags: 0x0}, - 160: {lang: 0x39, script: 0x5, flags: 0x0}, - 161: {lang: 0x1f8, script: 0x41, flags: 0x0}, - 163: {lang: 0x43b, script: 0x52, flags: 0x0}, - 164: {lang: 0x281, script: 0x1e, flags: 0x0}, - 165: {lang: 0x23, script: 0x3, flags: 0x1}, - 167: {lang: 0x26, script: 0x2, flags: 0x1}, - 169: {lang: 0x24b, script: 0x4b, flags: 0x0}, - 170: {lang: 0x24b, script: 0x4b, flags: 0x0}, - 171: {lang: 0x39, script: 0x5, flags: 0x0}, - 173: {lang: 0x3d9, script: 0x1e, flags: 0x0}, - 174: {lang: 0x28, script: 0x2, flags: 0x1}, - 175: {lang: 0x39, script: 0x5, flags: 0x0}, - 177: {lang: 0x109, script: 0x52, flags: 0x0}, - 178: {lang: 0x402, script: 0xc1, flags: 0x0}, - 180: {lang: 0x431, script: 0x52, flags: 0x0}, - 181: {lang: 0x2b7, script: 0x52, flags: 0x0}, - 182: {lang: 0x159, script: 0x52, flags: 0x0}, - 183: {lang: 0x2be, script: 0x52, flags: 0x0}, - 184: {lang: 0x39, script: 0x5, flags: 0x0}, - 185: {lang: 0x2a, script: 0x2, flags: 0x1}, - 186: {lang: 0x159, script: 0x52, flags: 0x0}, - 187: {lang: 0x2c, script: 0x2, flags: 0x1}, - 188: {lang: 0x428, script: 0x52, flags: 0x0}, - 189: {lang: 0x159, script: 0x52, flags: 0x0}, - 190: {lang: 0x2e8, script: 0x52, flags: 0x0}, - 193: {lang: 0x2e, script: 0x2, flags: 0x1}, - 194: {lang: 0x9e, script: 0x52, flags: 0x0}, - 195: {lang: 0x30, script: 0x2, flags: 0x1}, - 196: {lang: 0x32, script: 0x2, flags: 0x1}, - 197: {lang: 0x34, script: 0x2, flags: 0x1}, - 199: {lang: 0x159, script: 0x52, flags: 0x0}, - 200: {lang: 0x36, script: 0x2, flags: 0x1}, - 202: {lang: 0x317, script: 0x52, flags: 0x0}, - 203: {lang: 0x38, script: 0x3, flags: 0x1}, - 204: {lang: 0x124, script: 0xd4, flags: 0x0}, - 206: {lang: 0x139, script: 0x52, flags: 0x0}, - 207: {lang: 0x316, script: 0x52, flags: 0x0}, - 208: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 209: {lang: 0x15, script: 0x52, flags: 0x0}, - 210: {lang: 0x159, script: 0x52, flags: 0x0}, - 211: {lang: 0x1ad, script: 0x52, flags: 0x0}, - 213: {lang: 0x1ad, script: 0x5, flags: 0x2}, - 215: {lang: 0x139, script: 0x52, flags: 0x0}, - 216: {lang: 0x35e, script: 0x52, flags: 0x0}, - 217: {lang: 0x33e, script: 0x52, flags: 0x0}, - 218: {lang: 0x348, script: 0x20, flags: 0x0}, - 224: {lang: 0x39, script: 0x5, flags: 0x0}, - 225: {lang: 0x139, script: 0x52, flags: 0x0}, - 227: {lang: 0x139, script: 0x52, flags: 0x0}, - 228: {lang: 0x159, script: 0x52, flags: 0x0}, - 229: {lang: 0x47c, script: 0x52, flags: 0x0}, - 230: {lang: 0x14e, script: 0x52, flags: 0x0}, - 231: {lang: 0x3b, script: 0x3, flags: 0x1}, - 232: {lang: 0x3e, script: 0x2, flags: 0x1}, - 233: {lang: 0x159, script: 0x52, flags: 0x0}, - 235: {lang: 0x139, script: 0x52, flags: 0x0}, - 236: {lang: 0x39, script: 0x5, flags: 0x0}, - 237: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 239: {lang: 0x399, script: 0x52, flags: 0x0}, - 240: {lang: 0x18e, script: 0x52, flags: 0x0}, - 242: {lang: 0x39, script: 0x5, flags: 0x0}, - 257: {lang: 0x159, script: 0x52, flags: 0x0}, - 259: {lang: 0x40, script: 0x2, flags: 0x1}, - 260: {lang: 0x428, script: 0x1e, flags: 0x0}, - 261: {lang: 0x42, script: 0x2, flags: 0x1}, - 262: {lang: 0x3dc, script: 0x52, flags: 0x0}, - 263: {lang: 0x39, script: 0x5, flags: 0x0}, - 265: {lang: 0x159, script: 0x52, flags: 0x0}, - 266: {lang: 0x39, script: 0x5, flags: 0x0}, - 267: {lang: 0x44, script: 0x2, flags: 0x1}, - 270: {lang: 0x40c, script: 0x52, flags: 0x0}, - 271: {lang: 0x33e, script: 0x52, flags: 0x0}, - 272: {lang: 0x46, script: 0x2, flags: 0x1}, - 274: {lang: 0x1f1, script: 0x52, flags: 0x0}, - 275: {lang: 0x159, script: 0x52, flags: 0x0}, - 276: {lang: 0x41f, script: 0x52, flags: 0x0}, - 277: {lang: 0x35e, script: 0x52, flags: 0x0}, - 279: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 281: {lang: 0x139, script: 0x52, flags: 0x0}, - 283: {lang: 0x48, script: 0x2, flags: 0x1}, - 287: {lang: 0x159, script: 0x52, flags: 0x0}, - 288: {lang: 0x159, script: 0x52, flags: 0x0}, - 289: {lang: 0x4a, script: 0x2, flags: 0x1}, - 290: {lang: 0x4c, script: 0x3, flags: 0x1}, - 291: {lang: 0x4f, script: 0x2, flags: 0x1}, - 292: {lang: 0x46d, script: 0x52, flags: 0x0}, - 293: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 294: {lang: 0x46c, script: 0x52, flags: 0x0}, - 295: {lang: 0x51, script: 0x2, flags: 0x1}, - 296: {lang: 0x478, script: 0x52, flags: 0x0}, - 298: {lang: 0x53, script: 0x4, flags: 0x1}, - 300: {lang: 0x496, script: 0x52, flags: 0x0}, - 301: {lang: 0x57, script: 0x2, flags: 0x1}, - 302: {lang: 0x43b, script: 0x52, flags: 0x0}, - 303: {lang: 0x59, script: 0x3, flags: 0x1}, - 304: {lang: 0x43b, script: 0x52, flags: 0x0}, - 308: {lang: 0x508, script: 0x37, flags: 0x2}, - 309: {lang: 0x139, script: 0x52, flags: 0x0}, - 310: {lang: 0x4b2, script: 0x52, flags: 0x0}, - 311: {lang: 0x1f1, script: 0x52, flags: 0x0}, - 314: {lang: 0x139, script: 0x52, flags: 0x0}, - 317: {lang: 0x4b9, script: 0x52, flags: 0x0}, - 318: {lang: 0x89, script: 0x52, flags: 0x0}, - 319: {lang: 0x159, script: 0x52, flags: 0x0}, - 321: {lang: 0x411, script: 0x52, flags: 0x0}, - 332: {lang: 0x5c, script: 0x2, flags: 0x1}, - 349: {lang: 0x39, script: 0x5, flags: 0x0}, - 350: {lang: 0x5e, script: 0x2, flags: 0x1}, - 355: {lang: 0x419, script: 0x52, flags: 0x0}, + 112: {lang: 0xa8, script: 0x52, flags: 0x0}, + 113: {lang: 0xe2, script: 0x20, flags: 0x2}, + 116: {lang: 0xad, script: 0x52, flags: 0x0}, + 118: {lang: 0xaf, script: 0x52, flags: 0x0}, + 120: {lang: 0xaf, script: 0x52, flags: 0x0}, + 121: {lang: 0x15, script: 0x2, flags: 0x1}, + 123: {lang: 0x17, script: 0x3, flags: 0x1}, + 124: {lang: 0xaf, script: 0x52, flags: 0x0}, + 126: {lang: 0xd, script: 0x52, flags: 0x0}, + 128: {lang: 0x131, script: 0x52, flags: 0x0}, + 130: {lang: 0xaf, script: 0x52, flags: 0x0}, + 131: {lang: 0xaf, script: 0x52, flags: 0x0}, + 132: {lang: 0x9d, script: 0x52, flags: 0x0}, + 133: {lang: 0x1a, script: 0x2, flags: 0x1}, + 134: {lang: 0x0, script: 0x52, flags: 0x0}, + 135: {lang: 0x9d, script: 0x52, flags: 0x0}, + 137: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 139: {lang: 0x2c4, script: 0x35, flags: 0x0}, + 140: {lang: 0x0, script: 0x52, flags: 0x0}, + 141: {lang: 0x9d, script: 0x52, flags: 0x0}, + 142: {lang: 0xee, script: 0x52, flags: 0x0}, + 143: {lang: 0xf1, script: 0x52, flags: 0x0}, + 144: {lang: 0xf2, script: 0x52, flags: 0x0}, + 146: {lang: 0x9d, script: 0x52, flags: 0x0}, + 147: {lang: 0x1c, script: 0x2, flags: 0x1}, + 149: {lang: 0xe0, script: 0x37, flags: 0x0}, + 151: {lang: 0x1e, script: 0x3, flags: 0x1}, + 153: {lang: 0x15, script: 0x5, flags: 0x0}, + 154: {lang: 0x21, script: 0x2, flags: 0x1}, + 155: {lang: 0x102, script: 0x52, flags: 0x0}, + 156: {lang: 0x103, script: 0x52, flags: 0x0}, + 159: {lang: 0x15, script: 0x5, flags: 0x0}, + 160: {lang: 0x107, script: 0x41, flags: 0x0}, + 162: {lang: 0x248, script: 0x52, flags: 0x0}, + 163: {lang: 0x14d, script: 0x1e, flags: 0x0}, + 164: {lang: 0x23, script: 0x3, flags: 0x1}, + 166: {lang: 0x26, script: 0x2, flags: 0x1}, + 168: {lang: 0x136, script: 0x4b, flags: 0x0}, + 169: {lang: 0x136, script: 0x4b, flags: 0x0}, + 170: {lang: 0x15, script: 0x5, flags: 0x0}, + 172: {lang: 0x207, script: 0x1e, flags: 0x0}, + 173: {lang: 0x28, script: 0x2, flags: 0x1}, + 174: {lang: 0x15, script: 0x5, flags: 0x0}, + 176: {lang: 0x85, script: 0x52, flags: 0x0}, + 177: {lang: 0x228, script: 0xc1, flags: 0x0}, + 179: {lang: 0x242, script: 0x52, flags: 0x0}, + 180: {lang: 0x169, script: 0x52, flags: 0x0}, + 181: {lang: 0xaf, script: 0x52, flags: 0x0}, + 182: {lang: 0x170, script: 0x52, flags: 0x0}, + 183: {lang: 0x15, script: 0x5, flags: 0x0}, + 184: {lang: 0x2a, script: 0x2, flags: 0x1}, + 185: {lang: 0xaf, script: 0x52, flags: 0x0}, + 186: {lang: 0x2c, script: 0x2, flags: 0x1}, + 187: {lang: 0x23b, script: 0x52, flags: 0x0}, + 188: {lang: 0xaf, script: 0x52, flags: 0x0}, + 189: {lang: 0x183, script: 0x52, flags: 0x0}, + 192: {lang: 0x2e, script: 0x2, flags: 0x1}, + 193: {lang: 0x49, script: 0x52, flags: 0x0}, + 194: {lang: 0x30, script: 0x2, flags: 0x1}, + 195: {lang: 0x32, script: 0x2, flags: 0x1}, + 196: {lang: 0x34, script: 0x2, flags: 0x1}, + 198: {lang: 0xaf, script: 0x52, flags: 0x0}, + 199: {lang: 0x36, script: 0x2, flags: 0x1}, + 201: {lang: 0x19b, script: 0x52, flags: 0x0}, + 202: {lang: 0x38, script: 0x3, flags: 0x1}, + 203: {lang: 0x90, script: 0xd4, flags: 0x0}, + 205: {lang: 0x9d, script: 0x52, flags: 0x0}, + 206: {lang: 0x19a, script: 0x52, flags: 0x0}, + 207: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 208: {lang: 0xa, script: 0x52, flags: 0x0}, + 209: {lang: 0xaf, script: 0x52, flags: 0x0}, + 210: {lang: 0xdc, script: 0x52, flags: 0x0}, + 212: {lang: 0xdc, script: 0x5, flags: 0x2}, + 214: {lang: 0x9d, script: 0x52, flags: 0x0}, + 215: {lang: 0x1bd, script: 0x52, flags: 0x0}, + 216: {lang: 0x1af, script: 0x52, flags: 0x0}, + 217: {lang: 0x1b4, script: 0x20, flags: 0x0}, + 223: {lang: 0x15, script: 0x5, flags: 0x0}, + 224: {lang: 0x9d, script: 0x52, flags: 0x0}, + 226: {lang: 0x9d, script: 0x52, flags: 0x0}, + 227: {lang: 0xaf, script: 0x52, flags: 0x0}, + 228: {lang: 0x26e, script: 0x52, flags: 0x0}, + 229: {lang: 0xaa, script: 0x52, flags: 0x0}, + 230: {lang: 0x3b, script: 0x3, flags: 0x1}, + 231: {lang: 0x3e, script: 0x2, flags: 0x1}, + 232: {lang: 0xaf, script: 0x52, flags: 0x0}, + 234: {lang: 0x9d, script: 0x52, flags: 0x0}, + 235: {lang: 0x15, script: 0x5, flags: 0x0}, + 236: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 238: {lang: 0x1dc, script: 0x52, flags: 0x0}, + 239: {lang: 0xca, script: 0x52, flags: 0x0}, + 241: {lang: 0x15, script: 0x5, flags: 0x0}, + 256: {lang: 0xaf, script: 0x52, flags: 0x0}, + 258: {lang: 0x40, script: 0x2, flags: 0x1}, + 259: {lang: 0x23b, script: 0x1e, flags: 0x0}, + 260: {lang: 0x42, script: 0x2, flags: 0x1}, + 261: {lang: 0x20a, script: 0x52, flags: 0x0}, + 262: {lang: 0x15, script: 0x5, flags: 0x0}, + 264: {lang: 0xaf, script: 0x52, flags: 0x0}, + 265: {lang: 0x15, script: 0x5, flags: 0x0}, + 266: {lang: 0x44, script: 0x2, flags: 0x1}, + 269: {lang: 0x22c, script: 0x52, flags: 0x0}, + 270: {lang: 0x1af, script: 0x52, flags: 0x0}, + 271: {lang: 0x46, script: 0x2, flags: 0x1}, + 273: {lang: 0x103, script: 0x52, flags: 0x0}, + 274: {lang: 0xaf, script: 0x52, flags: 0x0}, + 275: {lang: 0x238, script: 0x52, flags: 0x0}, + 276: {lang: 0x1bd, script: 0x52, flags: 0x0}, + 278: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 280: {lang: 0x9d, script: 0x52, flags: 0x0}, + 282: {lang: 0x48, script: 0x2, flags: 0x1}, + 286: {lang: 0xaf, script: 0x52, flags: 0x0}, + 287: {lang: 0xaf, script: 0x52, flags: 0x0}, + 288: {lang: 0xaf, script: 0x52, flags: 0x0}, + 289: {lang: 0x4a, script: 0x3, flags: 0x1}, + 290: {lang: 0x4d, script: 0x2, flags: 0x1}, + 291: {lang: 0x265, script: 0x52, flags: 0x0}, + 292: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 293: {lang: 0x264, script: 0x52, flags: 0x0}, + 294: {lang: 0x4f, script: 0x2, flags: 0x1}, + 295: {lang: 0x26c, script: 0x52, flags: 0x0}, + 297: {lang: 0x51, script: 0x4, flags: 0x1}, + 299: {lang: 0x27c, script: 0x52, flags: 0x0}, + 300: {lang: 0x55, script: 0x2, flags: 0x1}, + 301: {lang: 0x248, script: 0x52, flags: 0x0}, + 302: {lang: 0x57, script: 0x3, flags: 0x1}, + 303: {lang: 0x248, script: 0x52, flags: 0x0}, + 306: {lang: 0x2b9, script: 0x37, flags: 0x2}, + 307: {lang: 0x9d, script: 0x52, flags: 0x0}, + 308: {lang: 0x28d, script: 0x52, flags: 0x0}, + 309: {lang: 0x103, script: 0x52, flags: 0x0}, + 312: {lang: 0x9d, script: 0x52, flags: 0x0}, + 315: {lang: 0x292, script: 0x52, flags: 0x0}, + 316: {lang: 0x41, script: 0x52, flags: 0x0}, + 317: {lang: 0xaf, script: 0x52, flags: 0x0}, + 319: {lang: 0x22f, script: 0x52, flags: 0x0}, + 330: {lang: 0x5a, script: 0x2, flags: 0x1}, + 347: {lang: 0x15, script: 0x5, flags: 0x0}, + 348: {lang: 0x5c, script: 0x2, flags: 0x1}, + 353: {lang: 0x236, script: 0x52, flags: 0x0}, } // likelyRegionList holds lists info associated with likelyRegion. -// Size: 384 bytes, 96 elements -var likelyRegionList = [96]likelyLangScript{ - 0: {lang: 0x143, script: 0x5, flags: 0x0}, - 1: {lang: 0x46c, script: 0x52, flags: 0x0}, - 2: {lang: 0x427, script: 0x52, flags: 0x0}, - 3: {lang: 0x2f6, script: 0x1e, flags: 0x0}, - 4: {lang: 0x1d0, script: 0x8, flags: 0x0}, - 5: {lang: 0x26b, script: 0x52, flags: 0x0}, - 6: {lang: 0xb5, script: 0x52, flags: 0x0}, - 7: {lang: 0x428, script: 0x1e, flags: 0x0}, - 8: {lang: 0x129, script: 0xd6, flags: 0x0}, - 9: {lang: 0x348, script: 0x20, flags: 0x0}, - 10: {lang: 0x51f, script: 0x34, flags: 0x0}, - 11: {lang: 0x4a2, script: 0x5, flags: 0x0}, - 12: {lang: 0x515, script: 0x35, flags: 0x0}, - 13: {lang: 0x519, script: 0x52, flags: 0x0}, - 14: {lang: 0x291, script: 0xd5, flags: 0x0}, - 15: {lang: 0x131, script: 0x2d, flags: 0x0}, - 16: {lang: 0x480, script: 0x52, flags: 0x0}, - 17: {lang: 0x39, script: 0x5, flags: 0x0}, - 18: {lang: 0x159, script: 0x52, flags: 0x0}, - 19: {lang: 0x26, script: 0x27, flags: 0x0}, - 20: {lang: 0x134, script: 0x52, flags: 0x0}, - 21: {lang: 0x261, script: 0x5, flags: 0x2}, - 22: {lang: 0x508, script: 0x37, flags: 0x2}, - 23: {lang: 0x208, script: 0x29, flags: 0x0}, - 24: {lang: 0x5, script: 0x1e, flags: 0x0}, - 25: {lang: 0x26b, script: 0x52, flags: 0x0}, - 26: {lang: 0x131, script: 0x2d, flags: 0x0}, - 27: {lang: 0x2f6, script: 0x1e, flags: 0x0}, - 28: {lang: 0x1da, script: 0x52, flags: 0x0}, - 29: {lang: 0x316, script: 0x5, flags: 0x0}, - 30: {lang: 0x1b7, script: 0x20, flags: 0x0}, - 31: {lang: 0x4aa, script: 0x5, flags: 0x0}, - 32: {lang: 0x22e, script: 0x6b, flags: 0x0}, - 33: {lang: 0x143, script: 0x5, flags: 0x0}, - 34: {lang: 0x46c, script: 0x52, flags: 0x0}, - 35: {lang: 0x242, script: 0x46, flags: 0x0}, - 36: {lang: 0xe4, script: 0x5, flags: 0x0}, - 37: {lang: 0x21e, script: 0xd5, flags: 0x0}, - 38: {lang: 0x39, script: 0x5, flags: 0x0}, - 39: {lang: 0x159, script: 0x52, flags: 0x0}, - 40: {lang: 0x2af, script: 0x4f, flags: 0x0}, - 41: {lang: 0x21e, script: 0xd5, flags: 0x0}, - 42: {lang: 0x39, script: 0x5, flags: 0x0}, - 43: {lang: 0x159, script: 0x52, flags: 0x0}, - 44: {lang: 0x3d3, script: 0x52, flags: 0x0}, - 45: {lang: 0x4a4, script: 0x1e, flags: 0x0}, - 46: {lang: 0x2f6, script: 0x1e, flags: 0x0}, - 47: {lang: 0x427, script: 0x52, flags: 0x0}, - 48: {lang: 0x328, script: 0x6b, flags: 0x0}, - 49: {lang: 0x20b, script: 0x52, flags: 0x0}, - 50: {lang: 0x302, script: 0x1e, flags: 0x0}, - 51: {lang: 0x23a, script: 0x5, flags: 0x0}, - 52: {lang: 0x51f, script: 0x35, flags: 0x0}, - 53: {lang: 0x3b7, script: 0x52, flags: 0x0}, - 54: {lang: 0x39, script: 0x5, flags: 0x0}, - 55: {lang: 0x159, script: 0x52, flags: 0x0}, - 56: {lang: 0x2e4, script: 0x52, flags: 0x0}, - 57: {lang: 0x4aa, script: 0x5, flags: 0x0}, - 58: {lang: 0x87, script: 0x20, flags: 0x0}, - 59: {lang: 0x4aa, script: 0x5, flags: 0x0}, - 60: {lang: 0x4aa, script: 0x5, flags: 0x0}, - 61: {lang: 0xbc, script: 0x20, flags: 0x0}, - 62: {lang: 0x3aa, script: 0x52, flags: 0x0}, - 63: {lang: 0x70, script: 0x1e, flags: 0x0}, - 64: {lang: 0x3d3, script: 0x52, flags: 0x0}, - 65: {lang: 0x7d, script: 0x1e, flags: 0x0}, - 66: {lang: 0x3d9, script: 0x1e, flags: 0x0}, - 67: {lang: 0x25e, script: 0x52, flags: 0x0}, - 68: {lang: 0x43a, script: 0x52, flags: 0x0}, - 69: {lang: 0x508, script: 0x37, flags: 0x0}, - 70: {lang: 0x408, script: 0x52, flags: 0x0}, - 71: {lang: 0x4a4, script: 0x1e, flags: 0x0}, - 72: {lang: 0x39, script: 0x5, flags: 0x0}, - 73: {lang: 0x159, script: 0x52, flags: 0x0}, - 74: {lang: 0x159, script: 0x52, flags: 0x0}, - 75: {lang: 0x34, script: 0x5, flags: 0x0}, - 76: {lang: 0x461, script: 0xd5, flags: 0x0}, - 77: {lang: 0x2e3, script: 0x5, flags: 0x0}, - 78: {lang: 0x306, script: 0x6b, flags: 0x0}, - 79: {lang: 0x45d, script: 0x1e, flags: 0x0}, - 80: {lang: 0x143, script: 0x5, flags: 0x0}, - 81: {lang: 0x39, script: 0x5, flags: 0x0}, - 82: {lang: 0x159, script: 0x52, flags: 0x0}, - 83: {lang: 0x480, script: 0x52, flags: 0x0}, - 84: {lang: 0x57, script: 0x5, flags: 0x0}, - 85: {lang: 0x211, script: 0x1e, flags: 0x0}, - 86: {lang: 0x80, script: 0x2d, flags: 0x0}, - 87: {lang: 0x51f, script: 0x35, flags: 0x0}, - 88: {lang: 0x482, script: 0x52, flags: 0x0}, - 89: {lang: 0x4a4, script: 0x1e, flags: 0x0}, - 90: {lang: 0x508, script: 0x37, flags: 0x0}, - 91: {lang: 0x3aa, script: 0x52, flags: 0x0}, - 92: {lang: 0x427, script: 0x52, flags: 0x0}, - 93: {lang: 0x428, script: 0x1e, flags: 0x0}, - 94: {lang: 0x159, script: 0x52, flags: 0x0}, - 95: {lang: 0x43c, script: 0x5, flags: 0x0}, +// Size: 376 bytes, 94 elements +var likelyRegionList = [94]likelyLangScript{ + 0: {lang: 0xa4, script: 0x5, flags: 0x0}, + 1: {lang: 0x264, script: 0x52, flags: 0x0}, + 2: {lang: 0x23a, script: 0x52, flags: 0x0}, + 3: {lang: 0x18c, script: 0x1e, flags: 0x0}, + 4: {lang: 0xf3, script: 0x8, flags: 0x0}, + 5: {lang: 0x145, script: 0x52, flags: 0x0}, + 6: {lang: 0x54, script: 0x52, flags: 0x0}, + 7: {lang: 0x23b, script: 0x1e, flags: 0x0}, + 8: {lang: 0x93, script: 0xd6, flags: 0x0}, + 9: {lang: 0x1b4, script: 0x20, flags: 0x0}, + 10: {lang: 0x2c4, script: 0x34, flags: 0x0}, + 11: {lang: 0x284, script: 0x5, flags: 0x0}, + 12: {lang: 0x2bd, script: 0x35, flags: 0x0}, + 13: {lang: 0x2be, script: 0x52, flags: 0x0}, + 14: {lang: 0x157, script: 0xd5, flags: 0x0}, + 15: {lang: 0x9a, script: 0x2d, flags: 0x0}, + 16: {lang: 0x26f, script: 0x52, flags: 0x0}, + 17: {lang: 0x15, script: 0x5, flags: 0x0}, + 18: {lang: 0xaf, script: 0x52, flags: 0x0}, + 19: {lang: 0x11, script: 0x27, flags: 0x0}, + 20: {lang: 0x9b, script: 0x52, flags: 0x0}, + 21: {lang: 0x141, script: 0x5, flags: 0x2}, + 22: {lang: 0x2b9, script: 0x37, flags: 0x2}, + 23: {lang: 0x111, script: 0x29, flags: 0x0}, + 24: {lang: 0x2, script: 0x1e, flags: 0x0}, + 25: {lang: 0x145, script: 0x52, flags: 0x0}, + 26: {lang: 0x9a, script: 0x2d, flags: 0x0}, + 27: {lang: 0x18c, script: 0x1e, flags: 0x0}, + 28: {lang: 0xf8, script: 0x52, flags: 0x0}, + 29: {lang: 0x19a, script: 0x5, flags: 0x0}, + 30: {lang: 0xe1, script: 0x20, flags: 0x0}, + 31: {lang: 0x28c, script: 0x5, flags: 0x0}, + 32: {lang: 0x129, script: 0x6b, flags: 0x0}, + 33: {lang: 0xa4, script: 0x5, flags: 0x0}, + 34: {lang: 0x264, script: 0x52, flags: 0x0}, + 35: {lang: 0x133, script: 0x46, flags: 0x0}, + 36: {lang: 0x6d, script: 0x5, flags: 0x0}, + 37: {lang: 0x11c, script: 0xd5, flags: 0x0}, + 38: {lang: 0x15, script: 0x5, flags: 0x0}, + 39: {lang: 0xaf, script: 0x52, flags: 0x0}, + 40: {lang: 0x165, script: 0x4f, flags: 0x0}, + 41: {lang: 0x11c, script: 0xd5, flags: 0x0}, + 42: {lang: 0x15, script: 0x5, flags: 0x0}, + 43: {lang: 0xaf, script: 0x52, flags: 0x0}, + 44: {lang: 0x203, script: 0x52, flags: 0x0}, + 45: {lang: 0x286, script: 0x1e, flags: 0x0}, + 46: {lang: 0x18c, script: 0x1e, flags: 0x0}, + 47: {lang: 0x23a, script: 0x52, flags: 0x0}, + 48: {lang: 0x1a5, script: 0x6b, flags: 0x0}, + 49: {lang: 0x114, script: 0x52, flags: 0x0}, + 50: {lang: 0x18f, script: 0x1e, flags: 0x0}, + 51: {lang: 0x12f, script: 0x5, flags: 0x0}, + 52: {lang: 0x2c4, script: 0x35, flags: 0x0}, + 53: {lang: 0x1ef, script: 0x52, flags: 0x0}, + 54: {lang: 0x15, script: 0x5, flags: 0x0}, + 55: {lang: 0xaf, script: 0x52, flags: 0x0}, + 56: {lang: 0x182, script: 0x52, flags: 0x0}, + 57: {lang: 0x28c, script: 0x5, flags: 0x0}, + 58: {lang: 0x40, script: 0x20, flags: 0x0}, + 59: {lang: 0x28c, script: 0x5, flags: 0x0}, + 60: {lang: 0x28c, script: 0x5, flags: 0x0}, + 61: {lang: 0x58, script: 0x20, flags: 0x0}, + 62: {lang: 0x1e7, script: 0x52, flags: 0x0}, + 63: {lang: 0x2f, script: 0x1e, flags: 0x0}, + 64: {lang: 0x203, script: 0x52, flags: 0x0}, + 65: {lang: 0x38, script: 0x1e, flags: 0x0}, + 66: {lang: 0x207, script: 0x1e, flags: 0x0}, + 67: {lang: 0x13f, script: 0x52, flags: 0x0}, + 68: {lang: 0x247, script: 0x52, flags: 0x0}, + 69: {lang: 0x2b9, script: 0x37, flags: 0x0}, + 70: {lang: 0x22a, script: 0x52, flags: 0x0}, + 71: {lang: 0x286, script: 0x1e, flags: 0x0}, + 72: {lang: 0x15, script: 0x5, flags: 0x0}, + 73: {lang: 0xaf, script: 0x52, flags: 0x0}, + 74: {lang: 0x25d, script: 0xd5, flags: 0x0}, + 75: {lang: 0x181, script: 0x5, flags: 0x0}, + 76: {lang: 0x191, script: 0x6b, flags: 0x0}, + 77: {lang: 0x25c, script: 0x1e, flags: 0x0}, + 78: {lang: 0xa4, script: 0x5, flags: 0x0}, + 79: {lang: 0x15, script: 0x5, flags: 0x0}, + 80: {lang: 0xaf, script: 0x52, flags: 0x0}, + 81: {lang: 0x26f, script: 0x52, flags: 0x0}, + 82: {lang: 0x24, script: 0x5, flags: 0x0}, + 83: {lang: 0x118, script: 0x1e, flags: 0x0}, + 84: {lang: 0x3b, script: 0x2d, flags: 0x0}, + 85: {lang: 0x2c4, script: 0x35, flags: 0x0}, + 86: {lang: 0x271, script: 0x52, flags: 0x0}, + 87: {lang: 0x286, script: 0x1e, flags: 0x0}, + 88: {lang: 0x2b9, script: 0x37, flags: 0x0}, + 89: {lang: 0x1e7, script: 0x52, flags: 0x0}, + 90: {lang: 0x23a, script: 0x52, flags: 0x0}, + 91: {lang: 0x23b, script: 0x1e, flags: 0x0}, + 92: {lang: 0xaf, script: 0x52, flags: 0x0}, + 93: {lang: 0x249, script: 0x5, flags: 0x0}, } type likelyTag struct { @@ -3230,37 +2474,37 @@ type likelyTag struct { // Size: 192 bytes, 32 elements var likelyRegionGroup = [32]likelyTag{ - 1: {lang: 0x134, region: 0xd5, script: 0x52}, - 2: {lang: 0x134, region: 0x134, script: 0x52}, - 3: {lang: 0x3b7, region: 0x40, script: 0x52}, - 4: {lang: 0x134, region: 0x2e, script: 0x52}, - 5: {lang: 0x134, region: 0xd5, script: 0x52}, - 6: {lang: 0x139, region: 0xce, script: 0x52}, - 7: {lang: 0x43b, region: 0x12e, script: 0x52}, - 8: {lang: 0x39, region: 0x6a, script: 0x5}, - 9: {lang: 0x43b, region: 0x4a, script: 0x52}, - 10: {lang: 0x134, region: 0x160, script: 0x52}, - 11: {lang: 0x134, region: 0x134, script: 0x52}, - 12: {lang: 0x134, region: 0x134, script: 0x52}, - 13: {lang: 0x139, region: 0x58, script: 0x52}, - 14: {lang: 0x51f, region: 0x52, script: 0x34}, - 15: {lang: 0x1b7, region: 0x98, script: 0x20}, - 16: {lang: 0x1da, region: 0x94, script: 0x52}, - 17: {lang: 0x1f1, region: 0x9d, script: 0x52}, - 18: {lang: 0x134, region: 0x2e, script: 0x52}, - 19: {lang: 0x134, region: 0xe5, script: 0x52}, - 20: {lang: 0x134, region: 0x89, script: 0x52}, - 21: {lang: 0x411, region: 0x141, script: 0x52}, - 22: {lang: 0x51f, region: 0x52, script: 0x34}, - 23: {lang: 0x4b2, region: 0x136, script: 0x52}, - 24: {lang: 0x39, region: 0x107, script: 0x5}, - 25: {lang: 0x3d9, region: 0x105, script: 0x1e}, - 26: {lang: 0x3d9, region: 0x105, script: 0x1e}, - 27: {lang: 0x134, region: 0x7a, script: 0x52}, - 28: {lang: 0x109, region: 0x5f, script: 0x52}, - 29: {lang: 0x139, region: 0x1e, script: 0x52}, - 30: {lang: 0x134, region: 0x99, script: 0x52}, - 31: {lang: 0x134, region: 0x7a, script: 0x52}, + 1: {lang: 0x9b, region: 0xd4, script: 0x52}, + 2: {lang: 0x9b, region: 0x132, script: 0x52}, + 3: {lang: 0x1ef, region: 0x40, script: 0x52}, + 4: {lang: 0x9b, region: 0x2e, script: 0x52}, + 5: {lang: 0x9b, region: 0xd4, script: 0x52}, + 6: {lang: 0x9d, region: 0xcd, script: 0x52}, + 7: {lang: 0x248, region: 0x12d, script: 0x52}, + 8: {lang: 0x15, region: 0x6a, script: 0x5}, + 9: {lang: 0x248, region: 0x4a, script: 0x52}, + 10: {lang: 0x9b, region: 0x15e, script: 0x52}, + 11: {lang: 0x9b, region: 0x132, script: 0x52}, + 12: {lang: 0x9b, region: 0x132, script: 0x52}, + 13: {lang: 0x9d, region: 0x58, script: 0x52}, + 14: {lang: 0x2c4, region: 0x52, script: 0x34}, + 15: {lang: 0xe1, region: 0x97, script: 0x20}, + 16: {lang: 0xf8, region: 0x93, script: 0x52}, + 17: {lang: 0x103, region: 0x9c, script: 0x52}, + 18: {lang: 0x9b, region: 0x2e, script: 0x52}, + 19: {lang: 0x9b, region: 0xe4, script: 0x52}, + 20: {lang: 0x9b, region: 0x88, script: 0x52}, + 21: {lang: 0x22f, region: 0x13f, script: 0x52}, + 22: {lang: 0x2c4, region: 0x52, script: 0x34}, + 23: {lang: 0x28d, region: 0x134, script: 0x52}, + 24: {lang: 0x15, region: 0x106, script: 0x5}, + 25: {lang: 0x207, region: 0x104, script: 0x1e}, + 26: {lang: 0x207, region: 0x104, script: 0x1e}, + 27: {lang: 0x9b, region: 0x79, script: 0x52}, + 28: {lang: 0x85, region: 0x5f, script: 0x52}, + 29: {lang: 0x9d, region: 0x1e, script: 0x52}, + 30: {lang: 0x9b, region: 0x98, script: 0x52}, + 31: {lang: 0x9b, region: 0x79, script: 0x52}, } type mutualIntelligibility struct { @@ -3282,132 +2526,132 @@ type scriptIntelligibility struct { // whether the intelligibility goes one or both ways. // Size: 708 bytes, 118 elements var matchLang = [118]mutualIntelligibility{ - 0: {want: 0x366, have: 0x33e, conf: 0x2, oneway: false}, - 1: {want: 0x26b, have: 0xe7, conf: 0x2, oneway: false}, - 2: {want: 0x1ca, have: 0xb5, conf: 0x2, oneway: false}, - 3: {want: 0x3fd, have: 0xb5, conf: 0x2, oneway: false}, - 4: {want: 0x428, have: 0xb5, conf: 0x2, oneway: false}, - 5: {want: 0x3fd, have: 0x1ca, conf: 0x2, oneway: false}, - 6: {want: 0x428, have: 0x1ca, conf: 0x2, oneway: false}, - 7: {want: 0x3fd, have: 0x428, conf: 0x2, oneway: false}, - 8: {want: 0x430, have: 0x1, conf: 0x2, oneway: false}, - 9: {want: 0x19c, have: 0x109, conf: 0x2, oneway: true}, - 10: {want: 0x28c, have: 0x109, conf: 0x2, oneway: true}, - 11: {want: 0xfd, have: 0x366, conf: 0x2, oneway: false}, - 12: {want: 0xfd, have: 0x33e, conf: 0x2, oneway: false}, - 13: {want: 0xe7, have: 0x26b, conf: 0x2, oneway: false}, - 14: {want: 0x5, have: 0x3d9, conf: 0x2, oneway: true}, - 15: {want: 0xc, have: 0x134, conf: 0x2, oneway: true}, - 16: {want: 0x15, have: 0x35e, conf: 0x2, oneway: true}, - 17: {want: 0x20, have: 0x134, conf: 0x2, oneway: true}, - 18: {want: 0x55, have: 0x139, conf: 0x2, oneway: true}, - 19: {want: 0x57, have: 0x3d9, conf: 0x2, oneway: true}, - 20: {want: 0x70, have: 0x3d9, conf: 0x2, oneway: true}, - 21: {want: 0x74, have: 0x134, conf: 0x2, oneway: true}, - 22: {want: 0x81, have: 0x1b7, conf: 0x2, oneway: true}, - 23: {want: 0xa3, have: 0x134, conf: 0x2, oneway: true}, - 24: {want: 0xb0, have: 0x159, conf: 0x2, oneway: true}, - 25: {want: 0xdb, have: 0x14e, conf: 0x2, oneway: true}, - 26: {want: 0xe3, have: 0x134, conf: 0x2, oneway: true}, - 27: {want: 0xe7, have: 0x39, conf: 0x2, oneway: true}, - 28: {want: 0xed, have: 0x159, conf: 0x2, oneway: true}, - 29: {want: 0xf5, have: 0x159, conf: 0x2, oneway: true}, - 30: {want: 0xfc, have: 0x134, conf: 0x2, oneway: true}, - 31: {want: 0x12c, have: 0x134, conf: 0x2, oneway: true}, - 32: {want: 0x137, have: 0x134, conf: 0x2, oneway: true}, - 33: {want: 0x13b, have: 0x14c, conf: 0x2, oneway: true}, - 34: {want: 0x140, have: 0x139, conf: 0x2, oneway: true}, - 35: {want: 0x153, have: 0xfd, conf: 0x2, oneway: true}, - 36: {want: 0x168, have: 0x35e, conf: 0x2, oneway: true}, - 37: {want: 0x169, have: 0x134, conf: 0x2, oneway: true}, - 38: {want: 0x16a, have: 0x134, conf: 0x2, oneway: true}, - 39: {want: 0x178, have: 0x134, conf: 0x2, oneway: true}, - 40: {want: 0x18a, have: 0x139, conf: 0x2, oneway: true}, - 41: {want: 0x18e, have: 0x139, conf: 0x2, oneway: true}, - 42: {want: 0x19d, have: 0x1b7, conf: 0x2, oneway: true}, - 43: {want: 0x1ad, have: 0x134, conf: 0x2, oneway: true}, - 44: {want: 0x1b1, have: 0x134, conf: 0x2, oneway: true}, - 45: {want: 0x1cd, have: 0x159, conf: 0x2, oneway: true}, - 46: {want: 0x1d0, have: 0x3d9, conf: 0x2, oneway: true}, - 47: {want: 0x1d2, have: 0x134, conf: 0x2, oneway: true}, - 48: {want: 0x1df, have: 0x134, conf: 0x2, oneway: true}, - 49: {want: 0x1f0, have: 0x134, conf: 0x2, oneway: true}, - 50: {want: 0x206, have: 0x1da, conf: 0x2, oneway: true}, - 51: {want: 0x208, have: 0x134, conf: 0x2, oneway: true}, - 52: {want: 0x225, have: 0x159, conf: 0x2, oneway: true}, - 53: {want: 0x23a, have: 0x3d9, conf: 0x2, oneway: true}, - 54: {want: 0x242, have: 0x134, conf: 0x2, oneway: true}, - 55: {want: 0x249, have: 0x134, conf: 0x2, oneway: true}, - 56: {want: 0x25c, have: 0x134, conf: 0x2, oneway: true}, - 57: {want: 0x26b, have: 0x480, conf: 0x2, oneway: true}, - 58: {want: 0x281, have: 0x3d9, conf: 0x2, oneway: true}, - 59: {want: 0x285, have: 0x1f1, conf: 0x2, oneway: true}, - 60: {want: 0x29a, have: 0x134, conf: 0x2, oneway: true}, - 61: {want: 0x2ac, have: 0x159, conf: 0x2, oneway: true}, - 62: {want: 0x2af, have: 0x134, conf: 0x2, oneway: true}, - 63: {want: 0x2b5, have: 0x134, conf: 0x2, oneway: true}, - 64: {want: 0x2ba, have: 0x159, conf: 0x2, oneway: true}, - 65: {want: 0x2e4, have: 0x134, conf: 0x2, oneway: true}, - 66: {want: 0x2e8, have: 0x159, conf: 0x2, oneway: true}, - 67: {want: 0x2f1, have: 0x134, conf: 0x2, oneway: true}, - 68: {want: 0x2f6, have: 0x7d, conf: 0x2, oneway: true}, - 69: {want: 0x2fb, have: 0x134, conf: 0x2, oneway: true}, - 70: {want: 0x302, have: 0x3d9, conf: 0x2, oneway: true}, - 71: {want: 0x312, have: 0x1b7, conf: 0x2, oneway: true}, - 72: {want: 0x316, have: 0x1da, conf: 0x2, oneway: true}, - 73: {want: 0x317, have: 0x134, conf: 0x2, oneway: true}, - 74: {want: 0x328, have: 0x134, conf: 0x2, oneway: true}, - 75: {want: 0x348, have: 0x134, conf: 0x2, oneway: true}, - 76: {want: 0x361, have: 0x33e, conf: 0x2, oneway: false}, - 77: {want: 0x361, have: 0x366, conf: 0x2, oneway: true}, - 78: {want: 0x371, have: 0x134, conf: 0x2, oneway: true}, - 79: {want: 0x37e, have: 0x134, conf: 0x2, oneway: true}, - 80: {want: 0x380, have: 0x134, conf: 0x2, oneway: true}, - 81: {want: 0x382, have: 0x159, conf: 0x2, oneway: true}, - 82: {want: 0x387, have: 0x134, conf: 0x2, oneway: true}, - 83: {want: 0x38c, have: 0x134, conf: 0x2, oneway: true}, - 84: {want: 0x394, have: 0x134, conf: 0x2, oneway: true}, - 85: {want: 0x39c, have: 0x134, conf: 0x2, oneway: true}, - 86: {want: 0x3b5, have: 0x134, conf: 0x2, oneway: true}, - 87: {want: 0x3bb, have: 0x139, conf: 0x2, oneway: true}, - 88: {want: 0x3cb, have: 0x109, conf: 0x2, oneway: true}, - 89: {want: 0x3d0, have: 0x134, conf: 0x2, oneway: true}, - 90: {want: 0x3dc, have: 0x159, conf: 0x2, oneway: true}, - 91: {want: 0x3e0, have: 0x1b7, conf: 0x2, oneway: true}, - 92: {want: 0x3f0, have: 0x134, conf: 0x2, oneway: true}, - 93: {want: 0x402, have: 0x134, conf: 0x2, oneway: true}, - 94: {want: 0x419, have: 0x134, conf: 0x2, oneway: true}, - 95: {want: 0x41f, have: 0x134, conf: 0x2, oneway: true}, - 96: {want: 0x427, have: 0x134, conf: 0x2, oneway: true}, - 97: {want: 0x431, have: 0x134, conf: 0x2, oneway: true}, - 98: {want: 0x434, have: 0x1da, conf: 0x2, oneway: true}, - 99: {want: 0x43b, have: 0x134, conf: 0x2, oneway: true}, - 100: {want: 0x446, have: 0x134, conf: 0x2, oneway: true}, - 101: {want: 0x457, have: 0x134, conf: 0x2, oneway: true}, - 102: {want: 0x45d, have: 0x3d9, conf: 0x2, oneway: true}, - 103: {want: 0x465, have: 0x134, conf: 0x2, oneway: true}, - 104: {want: 0x46c, have: 0x3d9, conf: 0x2, oneway: true}, - 105: {want: 0x3878, have: 0x134, conf: 0x2, oneway: true}, - 106: {want: 0x476, have: 0x134, conf: 0x2, oneway: true}, - 107: {want: 0x478, have: 0x134, conf: 0x2, oneway: true}, - 108: {want: 0x48a, have: 0x3d9, conf: 0x2, oneway: true}, - 109: {want: 0x493, have: 0x134, conf: 0x2, oneway: true}, - 110: {want: 0x4a2, have: 0x51f, conf: 0x2, oneway: true}, - 111: {want: 0x4aa, have: 0x134, conf: 0x2, oneway: true}, - 112: {want: 0x4b2, have: 0x3d9, conf: 0x2, oneway: true}, - 113: {want: 0x4db, have: 0x159, conf: 0x2, oneway: true}, - 114: {want: 0x4e8, have: 0x134, conf: 0x2, oneway: true}, - 115: {want: 0x508, have: 0x134, conf: 0x2, oneway: true}, - 116: {want: 0x50e, have: 0x134, conf: 0x2, oneway: true}, - 117: {want: 0x524, have: 0x134, conf: 0x2, oneway: true}, + 0: {want: 0x1c1, have: 0x1af, conf: 0x2, oneway: false}, + 1: {want: 0x145, have: 0x6f, conf: 0x2, oneway: false}, + 2: {want: 0xee, have: 0x54, conf: 0x2, oneway: false}, + 3: {want: 0x225, have: 0x54, conf: 0x2, oneway: false}, + 4: {want: 0x23b, have: 0x54, conf: 0x2, oneway: false}, + 5: {want: 0x225, have: 0xee, conf: 0x2, oneway: false}, + 6: {want: 0x23b, have: 0xee, conf: 0x2, oneway: false}, + 7: {want: 0x225, have: 0x23b, conf: 0x2, oneway: false}, + 8: {want: 0x241, have: 0x1, conf: 0x2, oneway: false}, + 9: {want: 0xd2, have: 0x85, conf: 0x2, oneway: true}, + 10: {want: 0x154, have: 0x85, conf: 0x2, oneway: true}, + 11: {want: 0x80, have: 0x1c1, conf: 0x2, oneway: false}, + 12: {want: 0x80, have: 0x1af, conf: 0x2, oneway: false}, + 13: {want: 0x6f, have: 0x145, conf: 0x2, oneway: false}, + 14: {want: 0x2, have: 0x207, conf: 0x2, oneway: true}, + 15: {want: 0x5, have: 0x9b, conf: 0x2, oneway: true}, + 16: {want: 0xa, have: 0x1bd, conf: 0x2, oneway: true}, + 17: {want: 0xd, have: 0x9b, conf: 0x2, oneway: true}, + 18: {want: 0x23, have: 0x9d, conf: 0x2, oneway: true}, + 19: {want: 0x24, have: 0x207, conf: 0x2, oneway: true}, + 20: {want: 0x2f, have: 0x207, conf: 0x2, oneway: true}, + 21: {want: 0x31, have: 0x9b, conf: 0x2, oneway: true}, + 22: {want: 0x3c, have: 0xe1, conf: 0x2, oneway: true}, + 23: {want: 0x4b, have: 0x9b, conf: 0x2, oneway: true}, + 24: {want: 0x50, have: 0xaf, conf: 0x2, oneway: true}, + 25: {want: 0x65, have: 0xaa, conf: 0x2, oneway: true}, + 26: {want: 0x6c, have: 0x9b, conf: 0x2, oneway: true}, + 27: {want: 0x6f, have: 0x15, conf: 0x2, oneway: true}, + 28: {want: 0x70, have: 0xaf, conf: 0x2, oneway: true}, + 29: {want: 0x78, have: 0xaf, conf: 0x2, oneway: true}, + 30: {want: 0x7f, have: 0x9b, conf: 0x2, oneway: true}, + 31: {want: 0x95, have: 0x9b, conf: 0x2, oneway: true}, + 32: {want: 0x9c, have: 0x9b, conf: 0x2, oneway: true}, + 33: {want: 0x9f, have: 0xa8, conf: 0x2, oneway: true}, + 34: {want: 0xa1, have: 0x9d, conf: 0x2, oneway: true}, + 35: {want: 0xad, have: 0x80, conf: 0x2, oneway: true}, + 36: {want: 0xb9, have: 0x1bd, conf: 0x2, oneway: true}, + 37: {want: 0xba, have: 0x9b, conf: 0x2, oneway: true}, + 38: {want: 0xbb, have: 0x9b, conf: 0x2, oneway: true}, + 39: {want: 0xc2, have: 0x9b, conf: 0x2, oneway: true}, + 40: {want: 0xc8, have: 0x9d, conf: 0x2, oneway: true}, + 41: {want: 0xca, have: 0x9d, conf: 0x2, oneway: true}, + 42: {want: 0xd3, have: 0xe1, conf: 0x2, oneway: true}, + 43: {want: 0xdc, have: 0x9b, conf: 0x2, oneway: true}, + 44: {want: 0xde, have: 0x9b, conf: 0x2, oneway: true}, + 45: {want: 0xf1, have: 0xaf, conf: 0x2, oneway: true}, + 46: {want: 0xf3, have: 0x207, conf: 0x2, oneway: true}, + 47: {want: 0xf5, have: 0x9b, conf: 0x2, oneway: true}, + 48: {want: 0xfa, have: 0x9b, conf: 0x2, oneway: true}, + 49: {want: 0x102, have: 0x9b, conf: 0x2, oneway: true}, + 50: {want: 0x10f, have: 0xf8, conf: 0x2, oneway: true}, + 51: {want: 0x111, have: 0x9b, conf: 0x2, oneway: true}, + 52: {want: 0x122, have: 0xaf, conf: 0x2, oneway: true}, + 53: {want: 0x12f, have: 0x207, conf: 0x2, oneway: true}, + 54: {want: 0x133, have: 0x9b, conf: 0x2, oneway: true}, + 55: {want: 0x135, have: 0x9b, conf: 0x2, oneway: true}, + 56: {want: 0x13d, have: 0x9b, conf: 0x2, oneway: true}, + 57: {want: 0x145, have: 0x26f, conf: 0x2, oneway: true}, + 58: {want: 0x14d, have: 0x207, conf: 0x2, oneway: true}, + 59: {want: 0x14e, have: 0x103, conf: 0x2, oneway: true}, + 60: {want: 0x15a, have: 0x9b, conf: 0x2, oneway: true}, + 61: {want: 0x164, have: 0xaf, conf: 0x2, oneway: true}, + 62: {want: 0x165, have: 0x9b, conf: 0x2, oneway: true}, + 63: {want: 0x167, have: 0x9b, conf: 0x2, oneway: true}, + 64: {want: 0x16c, have: 0xaf, conf: 0x2, oneway: true}, + 65: {want: 0x182, have: 0x9b, conf: 0x2, oneway: true}, + 66: {want: 0x183, have: 0xaf, conf: 0x2, oneway: true}, + 67: {want: 0x189, have: 0x9b, conf: 0x2, oneway: true}, + 68: {want: 0x18c, have: 0x38, conf: 0x2, oneway: true}, + 69: {want: 0x18d, have: 0x9b, conf: 0x2, oneway: true}, + 70: {want: 0x18f, have: 0x207, conf: 0x2, oneway: true}, + 71: {want: 0x196, have: 0xe1, conf: 0x2, oneway: true}, + 72: {want: 0x19a, have: 0xf8, conf: 0x2, oneway: true}, + 73: {want: 0x19b, have: 0x9b, conf: 0x2, oneway: true}, + 74: {want: 0x1a5, have: 0x9b, conf: 0x2, oneway: true}, + 75: {want: 0x1b4, have: 0x9b, conf: 0x2, oneway: true}, + 76: {want: 0x1bf, have: 0x1af, conf: 0x2, oneway: false}, + 77: {want: 0x1bf, have: 0x1c1, conf: 0x2, oneway: true}, + 78: {want: 0x1c8, have: 0x9b, conf: 0x2, oneway: true}, + 79: {want: 0x1cc, have: 0x9b, conf: 0x2, oneway: true}, + 80: {want: 0x1ce, have: 0x9b, conf: 0x2, oneway: true}, + 81: {want: 0x1d0, have: 0xaf, conf: 0x2, oneway: true}, + 82: {want: 0x1d2, have: 0x9b, conf: 0x2, oneway: true}, + 83: {want: 0x1d3, have: 0x9b, conf: 0x2, oneway: true}, + 84: {want: 0x1d7, have: 0x9b, conf: 0x2, oneway: true}, + 85: {want: 0x1de, have: 0x9b, conf: 0x2, oneway: true}, + 86: {want: 0x1ee, have: 0x9b, conf: 0x2, oneway: true}, + 87: {want: 0x1f1, have: 0x9d, conf: 0x2, oneway: true}, + 88: {want: 0x1fc, have: 0x85, conf: 0x2, oneway: true}, + 89: {want: 0x201, have: 0x9b, conf: 0x2, oneway: true}, + 90: {want: 0x20a, have: 0xaf, conf: 0x2, oneway: true}, + 91: {want: 0x20d, have: 0xe1, conf: 0x2, oneway: true}, + 92: {want: 0x21a, have: 0x9b, conf: 0x2, oneway: true}, + 93: {want: 0x228, have: 0x9b, conf: 0x2, oneway: true}, + 94: {want: 0x236, have: 0x9b, conf: 0x2, oneway: true}, + 95: {want: 0x238, have: 0x9b, conf: 0x2, oneway: true}, + 96: {want: 0x23a, have: 0x9b, conf: 0x2, oneway: true}, + 97: {want: 0x242, have: 0x9b, conf: 0x2, oneway: true}, + 98: {want: 0x244, have: 0xf8, conf: 0x2, oneway: true}, + 99: {want: 0x248, have: 0x9b, conf: 0x2, oneway: true}, + 100: {want: 0x251, have: 0x9b, conf: 0x2, oneway: true}, + 101: {want: 0x258, have: 0x9b, conf: 0x2, oneway: true}, + 102: {want: 0x25c, have: 0x207, conf: 0x2, oneway: true}, + 103: {want: 0x261, have: 0x9b, conf: 0x2, oneway: true}, + 104: {want: 0x264, have: 0x207, conf: 0x2, oneway: true}, + 105: {want: 0x361a, have: 0x9b, conf: 0x2, oneway: true}, + 106: {want: 0x26b, have: 0x9b, conf: 0x2, oneway: true}, + 107: {want: 0x26c, have: 0x9b, conf: 0x2, oneway: true}, + 108: {want: 0x277, have: 0x207, conf: 0x2, oneway: true}, + 109: {want: 0x27b, have: 0x9b, conf: 0x2, oneway: true}, + 110: {want: 0x284, have: 0x2c4, conf: 0x2, oneway: true}, + 111: {want: 0x28c, have: 0x9b, conf: 0x2, oneway: true}, + 112: {want: 0x28d, have: 0x207, conf: 0x2, oneway: true}, + 113: {want: 0x2a4, have: 0xaf, conf: 0x2, oneway: true}, + 114: {want: 0x2a9, have: 0x9b, conf: 0x2, oneway: true}, + 115: {want: 0x2b9, have: 0x9b, conf: 0x2, oneway: true}, + 116: {want: 0x2ba, have: 0x9b, conf: 0x2, oneway: true}, + 117: {want: 0x2c6, have: 0x9b, conf: 0x2, oneway: true}, } // matchScript holds pairs of scriptIDs where readers of one script // can typically also read the other. Each is associated with a confidence. // Size: 24 bytes, 4 elements var matchScript = [4]scriptIntelligibility{ - 0: {lang: 0x428, want: 0x52, have: 0x1e, conf: 0x2}, - 1: {lang: 0x428, want: 0x1e, have: 0x52, conf: 0x2}, + 0: {lang: 0x23b, want: 0x52, have: 0x1e, conf: 0x2}, + 1: {lang: 0x23b, want: 0x1e, have: 0x52, conf: 0x2}, 2: {lang: 0x0, want: 0x34, have: 0x35, conf: 0x1}, 3: {lang: 0x0, want: 0x35, have: 0x34, conf: 0x1}, } @@ -3427,8 +2671,8 @@ var regionContainment = [32]uint32{ // regionInclusion maps region identifiers to sets of regions in regionInclusionBits, // where each set holds all groupings that are directly connected in a region // containment graph. -// Size: 357 bytes, 357 elements -var regionInclusion = [357]uint8{ +// Size: 355 bytes, 355 elements +var regionInclusion = [355]uint8{ // Entry 0 - 3F 0x00, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, @@ -3445,41 +2689,41 @@ var regionInclusion = [357]uint8{ 0x25, 0x2c, 0x25, 0x21, 0x36, 0x2d, 0x34, 0x29, 0x21, 0x2e, 0x37, 0x25, 0x25, 0x20, 0x38, 0x38, 0x27, 0x37, 0x38, 0x38, 0x2e, 0x39, 0x2e, 0x1f, - 0x20, 0x37, 0x3a, 0x27, 0x3b, 0x2b, 0x20, 0x29, - 0x34, 0x26, 0x37, 0x25, 0x23, 0x27, 0x2b, 0x2c, + 0x37, 0x3a, 0x27, 0x3b, 0x2b, 0x20, 0x29, 0x34, + 0x26, 0x37, 0x25, 0x23, 0x27, 0x2b, 0x2c, 0x22, // Entry 80 - BF - 0x22, 0x2f, 0x2c, 0x2c, 0x25, 0x26, 0x39, 0x21, - 0x33, 0x3b, 0x2c, 0x27, 0x35, 0x21, 0x33, 0x39, - 0x25, 0x2d, 0x20, 0x38, 0x30, 0x37, 0x23, 0x2b, - 0x24, 0x21, 0x23, 0x24, 0x2b, 0x39, 0x2b, 0x25, - 0x23, 0x35, 0x20, 0x2e, 0x3c, 0x30, 0x3b, 0x2e, - 0x25, 0x35, 0x35, 0x23, 0x25, 0x3c, 0x30, 0x23, - 0x25, 0x34, 0x24, 0x2c, 0x31, 0x37, 0x29, 0x37, - 0x38, 0x38, 0x34, 0x32, 0x22, 0x25, 0x2e, 0x3b, + 0x2f, 0x2c, 0x2c, 0x25, 0x26, 0x39, 0x21, 0x33, + 0x3b, 0x2c, 0x27, 0x35, 0x21, 0x33, 0x39, 0x25, + 0x2d, 0x20, 0x38, 0x30, 0x37, 0x23, 0x2b, 0x24, + 0x21, 0x23, 0x24, 0x2b, 0x39, 0x2b, 0x25, 0x23, + 0x35, 0x20, 0x2e, 0x3c, 0x30, 0x3b, 0x2e, 0x25, + 0x35, 0x35, 0x23, 0x25, 0x3c, 0x30, 0x23, 0x25, + 0x34, 0x24, 0x2c, 0x31, 0x37, 0x29, 0x37, 0x38, + 0x38, 0x34, 0x32, 0x22, 0x25, 0x2e, 0x3b, 0x20, // Entry C0 - FF - 0x20, 0x22, 0x2c, 0x30, 0x35, 0x35, 0x3b, 0x25, - 0x2c, 0x25, 0x39, 0x2e, 0x24, 0x2e, 0x33, 0x30, - 0x2e, 0x31, 0x3a, 0x2c, 0x2a, 0x2c, 0x20, 0x33, - 0x29, 0x2b, 0x24, 0x20, 0x3b, 0x23, 0x28, 0x2a, - 0x23, 0x33, 0x20, 0x27, 0x28, 0x3a, 0x30, 0x24, - 0x2d, 0x2f, 0x28, 0x25, 0x23, 0x39, 0x20, 0x3b, - 0x27, 0x20, 0x23, 0x20, 0x20, 0x1e, 0x20, 0x20, + 0x22, 0x2c, 0x30, 0x35, 0x35, 0x3b, 0x25, 0x2c, + 0x25, 0x39, 0x2e, 0x24, 0x2e, 0x33, 0x30, 0x2e, + 0x31, 0x3a, 0x2c, 0x2a, 0x2c, 0x20, 0x33, 0x29, + 0x2b, 0x24, 0x20, 0x3b, 0x23, 0x28, 0x2a, 0x23, + 0x33, 0x20, 0x27, 0x28, 0x3a, 0x30, 0x24, 0x2d, + 0x2f, 0x28, 0x25, 0x23, 0x39, 0x20, 0x3b, 0x27, + 0x20, 0x23, 0x20, 0x20, 0x1e, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, // Entry 100 - 13F - 0x20, 0x2e, 0x20, 0x2d, 0x22, 0x32, 0x2e, 0x23, - 0x3a, 0x2e, 0x38, 0x37, 0x30, 0x2c, 0x39, 0x2b, - 0x2d, 0x2c, 0x22, 0x2c, 0x2e, 0x27, 0x2e, 0x26, - 0x32, 0x33, 0x25, 0x23, 0x31, 0x21, 0x25, 0x26, - 0x21, 0x2c, 0x30, 0x3c, 0x28, 0x30, 0x3c, 0x38, - 0x28, 0x30, 0x23, 0x25, 0x28, 0x35, 0x2e, 0x32, - 0x2e, 0x20, 0x21, 0x20, 0x2f, 0x27, 0x3c, 0x22, - 0x25, 0x20, 0x27, 0x25, 0x25, 0x30, 0x3a, 0x28, + 0x2e, 0x20, 0x2d, 0x22, 0x32, 0x2e, 0x23, 0x3a, + 0x2e, 0x38, 0x37, 0x30, 0x2c, 0x39, 0x2b, 0x2d, + 0x2c, 0x22, 0x2c, 0x2e, 0x27, 0x2e, 0x26, 0x32, + 0x33, 0x25, 0x23, 0x31, 0x21, 0x25, 0x26, 0x21, + 0x2c, 0x30, 0x3c, 0x28, 0x30, 0x3c, 0x38, 0x28, + 0x30, 0x23, 0x25, 0x28, 0x35, 0x2e, 0x32, 0x2e, + 0x20, 0x21, 0x2f, 0x27, 0x3c, 0x22, 0x25, 0x20, + 0x27, 0x25, 0x25, 0x30, 0x3a, 0x28, 0x20, 0x28, // Entry 140 - 17F - 0x20, 0x28, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x20, 0x20, 0x22, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x20, 0x20, 0x23, 0x23, 0x2e, 0x22, - 0x31, 0x2e, 0x26, 0x2e, 0x20, + 0x20, 0x20, 0x22, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x23, 0x23, 0x2e, 0x22, 0x31, 0x2e, + 0x26, 0x2e, 0x20, } // regionInclusionBits is an array of bit vectors where every vector represents @@ -3537,11 +2781,11 @@ type parentRel struct { // Size: 412 bytes, 5 elements var parents = [5]parentRel{ - 0: {lang: 0x134, script: 0x0, maxScript: 0x52, toRegion: 0x1, fromRegion: []uint16{0x1a, 0x24, 0x25, 0x2e, 0x33, 0x35, 0x3c, 0x41, 0x45, 0x47, 0x48, 0x49, 0x4f, 0x51, 0x5b, 0x5c, 0x60, 0x63, 0x6c, 0x72, 0x73, 0x74, 0x7a, 0x7b, 0x7e, 0x7f, 0x80, 0x82, 0x8b, 0x8c, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9e, 0x9f, 0xa3, 0xa6, 0xa8, 0xac, 0xb0, 0xb3, 0xb4, 0xbe, 0xc5, 0xc9, 0xca, 0xcb, 0xcd, 0xcf, 0xd1, 0xd4, 0xd5, 0xdc, 0xde, 0xdf, 0xe5, 0xe6, 0xe7, 0xea, 0xef, 0x106, 0x108, 0x109, 0x10a, 0x10c, 0x10d, 0x111, 0x116, 0x11a, 0x11c, 0x11e, 0x124, 0x128, 0x12b, 0x12c, 0x12e, 0x130, 0x138, 0x13b, 0x13e, 0x141, 0x160, 0x161, 0x163}}, - 1: {lang: 0x134, script: 0x0, maxScript: 0x52, toRegion: 0x1a, fromRegion: []uint16{0x2d, 0x4d, 0x5f, 0x62, 0x71, 0xd8, 0x10b, 0x10e}}, - 2: {lang: 0x139, script: 0x0, maxScript: 0x52, toRegion: 0x1e, fromRegion: []uint16{0x2b, 0x3e, 0x40, 0x50, 0x53, 0x55, 0x58, 0x64, 0x68, 0x88, 0x8e, 0xce, 0xd7, 0xe1, 0xe3, 0xeb, 0xf0, 0x119, 0x134, 0x135, 0x13a}}, - 3: {lang: 0x3b7, script: 0x0, maxScript: 0x52, toRegion: 0xed, fromRegion: []uint16{0x29, 0x4d, 0x59, 0x85, 0x8a, 0xb6, 0xc5, 0xd0, 0x117, 0x125}}, - 4: {lang: 0x51f, script: 0x35, maxScript: 0x35, toRegion: 0x8c, fromRegion: []uint16{0xc5}}, + 0: {lang: 0x9b, script: 0x0, maxScript: 0x52, toRegion: 0x1, fromRegion: []uint16{0x1a, 0x24, 0x25, 0x2e, 0x33, 0x35, 0x3c, 0x41, 0x45, 0x47, 0x48, 0x49, 0x4f, 0x51, 0x5b, 0x5c, 0x60, 0x63, 0x6c, 0x71, 0x72, 0x73, 0x79, 0x7a, 0x7d, 0x7e, 0x7f, 0x81, 0x8a, 0x8b, 0x94, 0x95, 0x96, 0x97, 0x98, 0x9d, 0x9e, 0xa2, 0xa5, 0xa7, 0xab, 0xaf, 0xb2, 0xb3, 0xbd, 0xc4, 0xc8, 0xc9, 0xca, 0xcc, 0xce, 0xd0, 0xd3, 0xd4, 0xdb, 0xdd, 0xde, 0xe4, 0xe5, 0xe6, 0xe9, 0xee, 0x105, 0x107, 0x108, 0x109, 0x10b, 0x10c, 0x110, 0x115, 0x119, 0x11b, 0x11d, 0x123, 0x127, 0x12a, 0x12b, 0x12d, 0x12f, 0x136, 0x139, 0x13c, 0x13f, 0x15e, 0x15f, 0x161}}, + 1: {lang: 0x9b, script: 0x0, maxScript: 0x52, toRegion: 0x1a, fromRegion: []uint16{0x2d, 0x4d, 0x5f, 0x62, 0x70, 0xd7, 0x10a, 0x10d}}, + 2: {lang: 0x9d, script: 0x0, maxScript: 0x52, toRegion: 0x1e, fromRegion: []uint16{0x2b, 0x3e, 0x40, 0x50, 0x53, 0x55, 0x58, 0x64, 0x68, 0x87, 0x8d, 0xcd, 0xd6, 0xe0, 0xe2, 0xea, 0xef, 0x118, 0x132, 0x133, 0x138}}, + 3: {lang: 0x1ef, script: 0x0, maxScript: 0x52, toRegion: 0xec, fromRegion: []uint16{0x29, 0x4d, 0x59, 0x84, 0x89, 0xb5, 0xc4, 0xcf, 0x116, 0x124}}, + 4: {lang: 0x2c4, script: 0x35, maxScript: 0x35, toRegion: 0x8b, fromRegion: []uint16{0xc4}}, } -// Total table size 25825 bytes (25KiB); checksum: 4E97CC5E +// Total table size 20315 bytes (19KiB); checksum: C16EF251 diff --git a/vendor/golang.org/x/text/runes/cond.go b/vendor/golang.org/x/text/runes/cond.go index df7aa02..ae7a921 100644 --- a/vendor/golang.org/x/text/runes/cond.go +++ b/vendor/golang.org/x/text/runes/cond.go @@ -41,35 +41,20 @@ func If(s Set, tIn, tNotIn transform.Transformer) Transformer { if tNotIn == nil { tNotIn = transform.Nop } - sIn, ok := tIn.(transform.SpanningTransformer) - if !ok { - sIn = dummySpan{tIn} - } - sNotIn, ok := tNotIn.(transform.SpanningTransformer) - if !ok { - sNotIn = dummySpan{tNotIn} - } - a := &cond{ - tIn: sIn, - tNotIn: sNotIn, + tIn: tIn, + tNotIn: tNotIn, f: s.Contains, } a.Reset() return Transformer{a} } -type dummySpan struct{ transform.Transformer } - -func (d dummySpan) Span(src []byte, atEOF bool) (n int, err error) { - return 0, transform.ErrEndOfSpan -} - type cond struct { - tIn, tNotIn transform.SpanningTransformer + tIn, tNotIn transform.Transformer f func(rune) bool - check func(rune) bool // current check to perform - t transform.SpanningTransformer // current transformer to use + check func(rune) bool // current check to perform + t transform.Transformer // current transformer to use } // Reset implements transform.Transformer. @@ -99,51 +84,6 @@ func (t *cond) isNot(r rune) bool { return false } -// This implementation of Span doesn't help all too much, but it needs to be -// there to satisfy this package's Transformer interface. -// TODO: there are certainly room for improvements, though. For example, if -// t.t == transform.Nop (which will a common occurrence) it will save a bundle -// to special-case that loop. -func (t *cond) Span(src []byte, atEOF bool) (n int, err error) { - p := 0 - for n < len(src) && err == nil { - // Don't process too much at a time as the Spanner that will be - // called on this block may terminate early. - const maxChunk = 4096 - max := len(src) - if v := n + maxChunk; v < max { - max = v - } - atEnd := false - size := 0 - current := t.t - for ; p < max; p += size { - r := rune(src[p]) - if r < utf8.RuneSelf { - size = 1 - } else if r, size = utf8.DecodeRune(src[p:]); size == 1 { - if !atEOF && !utf8.FullRune(src[p:]) { - err = transform.ErrShortSrc - break - } - } - if !t.check(r) { - // The next rune will be the start of a new run. - atEnd = true - break - } - } - n2, err2 := current.Span(src[n:p], atEnd || (atEOF && p == len(src))) - n += n2 - if err2 != nil { - return n, err2 - } - // At this point either err != nil or t.check will pass for the rune at p. - p = n + size - } - return n, err -} - func (t *cond) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { p := 0 for nSrc < len(src) && err == nil { @@ -159,10 +99,9 @@ func (t *cond) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error size := 0 current := t.t for ; p < max; p += size { - r := rune(src[p]) - if r < utf8.RuneSelf { - size = 1 - } else if r, size = utf8.DecodeRune(src[p:]); size == 1 { + var r rune + r, size = utf8.DecodeRune(src[p:]) + if r == utf8.RuneError && size == 1 { if !atEOF && !utf8.FullRune(src[p:]) { err = transform.ErrShortSrc break diff --git a/vendor/golang.org/x/text/runes/runes.go b/vendor/golang.org/x/text/runes/runes.go index 6a3195c..291de65 100644 --- a/vendor/golang.org/x/text/runes/runes.go +++ b/vendor/golang.org/x/text/runes/runes.go @@ -46,19 +46,9 @@ func Predicate(f func(rune) bool) Set { // Transformer implements the transform.Transformer interface. type Transformer struct { - t transform.SpanningTransformer + transform.Transformer } -func (t Transformer) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - return t.t.Transform(dst, src, atEOF) -} - -func (t Transformer) Span(b []byte, atEOF bool) (n int, err error) { - return t.t.Span(b, atEOF) -} - -func (t Transformer) Reset() { t.t.Reset() } - // Bytes returns a new byte slice with the result of converting b using t. It // calls Reset on t. It returns nil if any error was found. This can only happen // if an error-producing Transformer is passed to If. @@ -106,57 +96,39 @@ type remove func(r rune) bool func (remove) Reset() {} -// Span implements transform.Spanner. -func (t remove) Span(src []byte, atEOF bool) (n int, err error) { - for r, size := rune(0), 0; n < len(src); { - if r = rune(src[n]); r < utf8.RuneSelf { - size = 1 - } else if r, size = utf8.DecodeRune(src[n:]); size == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src[n:]) { - err = transform.ErrShortSrc - } else { - err = transform.ErrEndOfSpan - } - break - } - if t(r) { - err = transform.ErrEndOfSpan - break - } - n += size - } - return -} - // Transform implements transform.Transformer. func (t remove) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { for r, size := rune(0), 0; nSrc < len(src); { if r = rune(src[nSrc]); r < utf8.RuneSelf { size = 1 - } else if r, size = utf8.DecodeRune(src[nSrc:]); size == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src[nSrc:]) { - err = transform.ErrShortSrc - break - } - // We replace illegal bytes with RuneError. Not doing so might - // otherwise turn a sequence of invalid UTF-8 into valid UTF-8. - // The resulting byte sequence may subsequently contain runes - // for which t(r) is true that were passed unnoticed. - if !t(utf8.RuneError) { - if nDst+3 > len(dst) { - err = transform.ErrShortDst + } else { + r, size = utf8.DecodeRune(src[nSrc:]) + + if size == 1 { + // Invalid rune. + if !atEOF && !utf8.FullRune(src[nSrc:]) { + err = transform.ErrShortSrc break } - dst[nDst+0] = runeErrorString[0] - dst[nDst+1] = runeErrorString[1] - dst[nDst+2] = runeErrorString[2] - nDst += 3 + // We replace illegal bytes with RuneError. Not doing so might + // otherwise turn a sequence of invalid UTF-8 into valid UTF-8. + // The resulting byte sequence may subsequently contain runes + // for which t(r) is true that were passed unnoticed. + if !t(utf8.RuneError) { + if nDst+3 > len(dst) { + err = transform.ErrShortDst + break + } + dst[nDst+0] = runeErrorString[0] + dst[nDst+1] = runeErrorString[1] + dst[nDst+2] = runeErrorString[2] + nDst += 3 + } + nSrc++ + continue } - nSrc++ - continue } + if t(r) { nSrc += size continue @@ -185,28 +157,6 @@ type mapper func(rune) rune func (mapper) Reset() {} -// Span implements transform.Spanner. -func (t mapper) Span(src []byte, atEOF bool) (n int, err error) { - for r, size := rune(0), 0; n < len(src); n += size { - if r = rune(src[n]); r < utf8.RuneSelf { - size = 1 - } else if r, size = utf8.DecodeRune(src[n:]); size == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src[n:]) { - err = transform.ErrShortSrc - } else { - err = transform.ErrEndOfSpan - } - break - } - if t(r) != r { - err = transform.ErrEndOfSpan - break - } - } - return n, err -} - // Transform implements transform.Transformer. func (t mapper) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { var replacement rune @@ -280,51 +230,24 @@ func ReplaceIllFormed() Transformer { type replaceIllFormed struct{ transform.NopResetter } -func (t replaceIllFormed) Span(src []byte, atEOF bool) (n int, err error) { - for n < len(src) { - // ASCII fast path. - if src[n] < utf8.RuneSelf { - n++ - continue - } - - r, size := utf8.DecodeRune(src[n:]) - - // Look for a valid non-ASCII rune. - if r != utf8.RuneError || size != 1 { - n += size - continue - } - - // Look for short source data. - if !atEOF && !utf8.FullRune(src[n:]) { - err = transform.ErrShortSrc - break - } - - // We have an invalid rune. - err = transform.ErrEndOfSpan - break - } - return n, err -} - func (t replaceIllFormed) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { for nSrc < len(src) { - // ASCII fast path. - if r := src[nSrc]; r < utf8.RuneSelf { + r, size := utf8.DecodeRune(src[nSrc:]) + + // Look for an ASCII rune. + if r < utf8.RuneSelf { if nDst == len(dst) { err = transform.ErrShortDst break } - dst[nDst] = r + dst[nDst] = byte(r) nDst++ nSrc++ continue } // Look for a valid non-ASCII rune. - if _, size := utf8.DecodeRune(src[nSrc:]); size != 1 { + if r != utf8.RuneError || size != 1 { if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { err = transform.ErrShortDst break diff --git a/vendor/golang.org/x/text/secure/bidirule/bidirule.go b/vendor/golang.org/x/text/secure/bidirule/bidirule.go index a7161bd..277257f 100644 --- a/vendor/golang.org/x/text/secure/bidirule/bidirule.go +++ b/vendor/golang.org/x/text/secure/bidirule/bidirule.go @@ -123,64 +123,34 @@ var transitions = [...][2]ruleTransition{ // vice versa. const exclusiveRTL = uint16(1<>2) - b, err := buf.enforce(p, src, false) + b, err := buf.enforce(p, src) if err != nil { return nil, err } @@ -187,7 +180,7 @@ func (p *Profile) Append(dst, src []byte) ([]byte, error) { func (p *Profile) Bytes(b []byte) ([]byte, error) { var buf buffers buf.init(8 + len(b) + len(b)>>2) - b, err := buf.enforce(p, b, false) + b, err := buf.enforce(p, b) if err != nil { return nil, err } @@ -203,7 +196,7 @@ func (p *Profile) Bytes(b []byte) ([]byte, error) { func (p *Profile) String(s string) (string, error) { var buf buffers buf.init(8 + len(s) + len(s)>>2) - b, err := buf.enforce(p, []byte(s), false) + b, err := buf.enforce(p, []byte(s)) if err != nil { return "", err } @@ -214,21 +207,22 @@ func (p *Profile) String(s string) (string, error) { // (byte-for-byte equality). If either string cannot be enforced, the comparison // is false. func (p *Profile) Compare(a, b string) bool { - var buf buffers - - buf.init(8 + len(a) + len(a)>>2) - str, err := buf.enforce(p, []byte(a), true) + a, err := p.String(a) if err != nil { return false } - a = string(str) - - buf.init(8 + len(b) + len(b)>>2) - str, err = buf.enforce(p, []byte(b), true) + b, err = p.String(b) if err != nil { return false } - b = string(str) + + // TODO: This is out of order. Need to extract the transformation logic and + // put this in where the normal case folding would go (but only for + // comparison). + if p.options.ignorecase { + a = width.Fold.String(a) + b = width.Fold.String(a) + } return a == b } diff --git a/vendor/golang.org/x/text/secure/precis/profiles.go b/vendor/golang.org/x/text/secure/precis/profiles.go index 89089c2..ad50ae8 100644 --- a/vendor/golang.org/x/text/secure/precis/profiles.go +++ b/vendor/golang.org/x/text/secure/precis/profiles.go @@ -32,7 +32,7 @@ var ( ) usernameCaseMap = NewIdentifier( FoldWidth, - LowerCase(), + FoldCase(), Norm(norm.NFC), BidiRule, ) diff --git a/vendor/golang.org/x/text/transform/transform.go b/vendor/golang.org/x/text/transform/transform.go index 24dcca6..51862b0 100644 --- a/vendor/golang.org/x/text/transform/transform.go +++ b/vendor/golang.org/x/text/transform/transform.go @@ -24,10 +24,6 @@ var ( // complete the transformation. ErrShortSrc = errors.New("transform: short source buffer") - // ErrEndOfSpan means that the input and output (the transformed input) - // are not identical. - ErrEndOfSpan = errors.New("transform: input and output are not identical") - // errInconsistentByteCount means that Transform returned success (nil // error) but also returned nSrc inconsistent with the src argument. errInconsistentByteCount = errors.New("transform: inconsistent byte count returned") @@ -64,41 +60,6 @@ type Transformer interface { Reset() } -// SpanningTransformer extends the Transformer interface with a Span method -// that determines how much of the input already conforms to the Transformer. -type SpanningTransformer interface { - Transformer - - // Span returns a position in src such that transforming src[:n] results in - // identical output src[:n] for these bytes. It does not necessarily return - // the largest such n. The atEOF argument tells whether src represents the - // last bytes of the input. - // - // Callers should always account for the n bytes consumed before - // considering the error err. - // - // A nil error means that all input bytes are known to be identical to the - // output produced by the Transformer. A nil error can be be returned - // regardless of whether atEOF is true. If err is nil, then then n must - // equal len(src); the converse is not necessarily true. - // - // ErrEndOfSpan means that the Transformer output may differ from the - // input after n bytes. Note that n may be len(src), meaning that the output - // would contain additional bytes after otherwise identical output. - // ErrShortSrc means that src had insufficient data to determine whether the - // remaining bytes would change. Other than the error conditions listed - // here, implementations are free to report other errors that arise. - // - // Calling Span can modify the Transformer state as a side effect. In - // effect, it does the transformation just as calling Transform would, only - // without copying to a destination buffer and only up to a point it can - // determine the input and output bytes are the same. This is obviously more - // limited than calling Transform, but can be more efficient in terms of - // copying and allocating buffers. Calls to Span and Transform may be - // interleaved. - Span(src []byte, atEOF bool) (n int, err error) -} - // NopResetter can be embedded by implementations of Transformer to add a nop // Reset method. type NopResetter struct{} @@ -317,10 +278,6 @@ func (nop) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { return n, n, err } -func (nop) Span(src []byte, atEOF bool) (n int, err error) { - return len(src), nil -} - type discard struct{ NopResetter } func (discard) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { @@ -332,8 +289,8 @@ var ( // by consuming all bytes and writing nothing. Discard Transformer = discard{} - // Nop is a SpanningTransformer that copies src to dst. - Nop SpanningTransformer = nop{} + // Nop is a Transformer that copies src to dst. + Nop Transformer = nop{} ) // chain is a sequence of links. A chain with N Transformers has N+1 links and @@ -401,8 +358,6 @@ func (c *chain) Reset() { } } -// TODO: make chain use Span (is going to be fun to implement!) - // Transform applies the transformers of c in sequence. func (c *chain) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { // Set up src and dst in the chain. @@ -493,7 +448,8 @@ func (c *chain) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err erro return dstL.n, srcL.p, err } -// Deprecated: use runes.Remove instead. +// RemoveFunc returns a Transformer that removes from the input all runes r for +// which f(r) is true. Illegal bytes in the input are replaced by RuneError. func RemoveFunc(f func(r rune) bool) Transformer { return removeF(f) } diff --git a/vendor/golang.org/x/text/unicode/bidi/bracket.go b/vendor/golang.org/x/text/unicode/bidi/bracket.go index 601e259..e88119d 100644 --- a/vendor/golang.org/x/text/unicode/bidi/bracket.go +++ b/vendor/golang.org/x/text/unicode/bidi/bracket.go @@ -84,7 +84,7 @@ func resolvePairedBrackets(s *isolatingRunSequence) { dirEmbed = R } p.locateBrackets(s.p.pairTypes, s.p.pairValues) - p.resolveBrackets(dirEmbed, s.p.initialTypes) + p.resolveBrackets(dirEmbed) } type bracketPairer struct { @@ -125,8 +125,6 @@ func (p *bracketPairer) matchOpener(pairValues []rune, opener, closer int) bool return pairValues[p.indexes[opener]] == pairValues[p.indexes[closer]] } -const maxPairingDepth = 63 - // locateBrackets locates matching bracket pairs according to BD16. // // This implementation uses a linked list instead of a stack, because, while @@ -138,17 +136,11 @@ func (p *bracketPairer) locateBrackets(pairTypes []bracketType, pairValues []run for i, index := range p.indexes { // look at the bracket type for each character - if pairTypes[index] == bpNone || p.codesIsolatedRun[i] != ON { - // continue scanning - continue - } switch pairTypes[index] { + case bpNone: + // continue scanning + case bpOpen: - // check if maximum pairing depth reached - if p.openers.Len() == maxPairingDepth { - p.openers.Init() - return - } // remember opener location, most recent first p.openers.PushFront(i) @@ -278,7 +270,7 @@ func (p *bracketPairer) classBeforePair(loc bracketPair) Class { } // assignBracketType implements rule N0 for a single bracket pair. -func (p *bracketPairer) assignBracketType(loc bracketPair, dirEmbed Class, initialTypes []Class) { +func (p *bracketPairer) assignBracketType(loc bracketPair, dirEmbed Class) { // rule "N0, a", inspect contents of pair dirPair := p.classifyPairContent(loc, dirEmbed) @@ -303,33 +295,13 @@ func (p *bracketPairer) assignBracketType(loc bracketPair, dirEmbed Class, initi // direction // set the bracket types to the type found - p.setBracketsToType(loc, dirPair, initialTypes) -} - -func (p *bracketPairer) setBracketsToType(loc bracketPair, dirPair Class, initialTypes []Class) { p.codesIsolatedRun[loc.opener] = dirPair p.codesIsolatedRun[loc.closer] = dirPair - - for i := loc.opener + 1; i < loc.closer; i++ { - index := p.indexes[i] - if initialTypes[index] != NSM { - break - } - p.codesIsolatedRun[i] = dirPair - } - - for i := loc.closer + 1; i < len(p.indexes); i++ { - index := p.indexes[i] - if initialTypes[index] != NSM { - break - } - p.codesIsolatedRun[i] = dirPair - } } // resolveBrackets implements rule N0 for a list of pairs. -func (p *bracketPairer) resolveBrackets(dirEmbed Class, initialTypes []Class) { +func (p *bracketPairer) resolveBrackets(dirEmbed Class) { for _, loc := range p.pairPositions { - p.assignBracketType(loc, dirEmbed, initialTypes) + p.assignBracketType(loc, dirEmbed) } } diff --git a/vendor/golang.org/x/text/unicode/bidi/core.go b/vendor/golang.org/x/text/unicode/bidi/core.go index ec52f14..381f30a 100644 --- a/vendor/golang.org/x/text/unicode/bidi/core.go +++ b/vendor/golang.org/x/text/unicode/bidi/core.go @@ -309,9 +309,6 @@ func (p *paragraph) determineExplicitEmbeddingLevels() { } if isIsolate { p.resultLevels[i] = stack.lastEmbeddingLevel() - if stack.lastDirectionalOverrideStatus() != ON { - p.resultTypes[i] = stack.lastDirectionalOverrideStatus() - } } var newLevel level diff --git a/vendor/golang.org/x/text/unicode/norm/normalize.go b/vendor/golang.org/x/text/unicode/norm/normalize.go index 209b9b9..a70805c 100644 --- a/vendor/golang.org/x/text/unicode/norm/normalize.go +++ b/vendor/golang.org/x/text/unicode/norm/normalize.go @@ -8,11 +8,7 @@ // Package norm contains types and functions for normalizing Unicode strings. package norm -import ( - "unicode/utf8" - - "golang.org/x/text/transform" -) +import "unicode/utf8" // A Form denotes a canonical representation of Unicode code points. // The Unicode-defined normalization and equivalence forms are: @@ -267,34 +263,6 @@ func (f Form) QuickSpan(b []byte) int { return n } -// Span implements transform.SpanningTransformer. It returns a boundary n such -// that b[0:n] == f(b[0:n]). It is not guaranteed to return the largest such n. -func (f Form) Span(b []byte, atEOF bool) (n int, err error) { - n, ok := formTable[f].quickSpan(inputBytes(b), 0, len(b), atEOF) - if n < len(b) { - if !ok { - err = transform.ErrEndOfSpan - } else { - err = transform.ErrShortSrc - } - } - return n, err -} - -// SpanString returns a boundary n such that s[0:n] == f(s[0:n]). -// It is not guaranteed to return the largest such n. -func (f Form) SpanString(s string, atEOF bool) (n int, err error) { - n, ok := formTable[f].quickSpan(inputString(s), 0, len(s), atEOF) - if n < len(s) { - if !ok { - err = transform.ErrEndOfSpan - } else { - err = transform.ErrShortSrc - } - } - return n, err -} - // quickSpan returns a boundary n such that src[0:n] == f(src[0:n]) and // whether any non-normalized parts were found. If atEOF is false, n will // not point past the last segment if this segment might be become @@ -353,7 +321,7 @@ func (f *formInfo) quickSpan(src input, i, end int, atEOF bool) (n int, ok bool) return lastSegStart, false } -// QuickSpanString returns a boundary n such that s[0:n] == f(s[0:n]). +// QuickSpanString returns a boundary n such that b[0:n] == f(s[0:n]). // It is not guaranteed to return the largest such n. func (f Form) QuickSpanString(s string) int { n, _ := formTable[f].quickSpan(inputString(s), 0, len(s), true) diff --git a/vendor/golang.org/x/text/width/transform.go b/vendor/golang.org/x/text/width/transform.go index 0049f70..2ed2509 100644 --- a/vendor/golang.org/x/text/width/transform.go +++ b/vendor/golang.org/x/text/width/transform.go @@ -14,32 +14,6 @@ type foldTransform struct { transform.NopResetter } -func (foldTransform) Span(src []byte, atEOF bool) (n int, err error) { - for n < len(src) { - if src[n] < utf8.RuneSelf { - // ASCII fast path. - for n++; n < len(src) && src[n] < utf8.RuneSelf; n++ { - } - continue - } - v, size := trie.lookup(src[n:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - err = transform.ErrShortSrc - } else { - n = len(src) - } - break - } - if elem(v)&tagNeedsFold != 0 { - err = transform.ErrEndOfSpan - break - } - n += size - } - return n, err -} - func (foldTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { for nSrc < len(src) { if src[nSrc] < utf8.RuneSelf { @@ -96,33 +70,6 @@ type narrowTransform struct { transform.NopResetter } -func (narrowTransform) Span(src []byte, atEOF bool) (n int, err error) { - for n < len(src) { - if src[n] < utf8.RuneSelf { - // ASCII fast path. - for n++; n < len(src) && src[n] < utf8.RuneSelf; n++ { - } - continue - } - v, size := trie.lookup(src[n:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - err = transform.ErrShortSrc - } else { - n = len(src) - } - break - } - if k := elem(v).kind(); byte(v) == 0 || k != EastAsianFullwidth && k != EastAsianWide && k != EastAsianAmbiguous { - } else { - err = transform.ErrEndOfSpan - break - } - n += size - } - return n, err -} - func (narrowTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { for nSrc < len(src) { if src[nSrc] < utf8.RuneSelf { @@ -179,30 +126,6 @@ type wideTransform struct { transform.NopResetter } -func (wideTransform) Span(src []byte, atEOF bool) (n int, err error) { - for n < len(src) { - // TODO: Consider ASCII fast path. Special-casing ASCII handling can - // reduce the ns/op of BenchmarkWideASCII by about 30%. This is probably - // not enough to warrant the extra code and complexity. - v, size := trie.lookup(src[n:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - err = transform.ErrShortSrc - } else { - n = len(src) - } - break - } - if k := elem(v).kind(); byte(v) == 0 || k != EastAsianHalfwidth && k != EastAsianNarrow { - } else { - err = transform.ErrEndOfSpan - break - } - n += size - } - return n, err -} - func (wideTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { for nSrc < len(src) { // TODO: Consider ASCII fast path. Special-casing ASCII handling can diff --git a/vendor/golang.org/x/text/width/width.go b/vendor/golang.org/x/text/width/width.go index 0c9aec4..c32d772 100644 --- a/vendor/golang.org/x/text/width/width.go +++ b/vendor/golang.org/x/text/width/width.go @@ -153,22 +153,17 @@ func (p Properties) Wide() rune { // Transformer implements the transform.Transformer interface. type Transformer struct { - t transform.SpanningTransformer + t transform.Transformer } // Reset implements the transform.Transformer interface. func (t Transformer) Reset() { t.t.Reset() } -// Transform implements the transform.Transformer interface. +// Transform implements the Transformer interface. func (t Transformer) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { return t.t.Transform(dst, src, atEOF) } -// Span implements the transform.SpanningTransformer interface. -func (t Transformer) Span(src []byte, atEOF bool) (n int, err error) { - return t.t.Span(src, atEOF) -} - // Bytes returns a new byte slice with the result of applying t to b. func (t Transformer) Bytes(b []byte) []byte { b, _, _ = transform.Bytes(t, b) diff --git a/vendor/google.golang.org/appengine/.travis.yml b/vendor/google.golang.org/appengine/.travis.yml index 0762cb9..12ea385 100644 --- a/vendor/google.golang.org/appengine/.travis.yml +++ b/vendor/google.golang.org/appengine/.travis.yml @@ -2,13 +2,13 @@ language: go go: - 1.6.3 - - 1.7.1 + - 1.7rc6 install: - go get -v -t -d google.golang.org/appengine/... - mkdir sdk - curl -o sdk.zip "https://storage.googleapis.com/appengine-sdks/featured/go_appengine_sdk_linux_amd64-1.9.40.zip" - - unzip -q sdk.zip -d sdk + - unzip sdk.zip -d sdk - export APPENGINE_DEV_APPSERVER=$(pwd)/sdk/go_appengine/dev_appserver.py script: diff --git a/vendor/google.golang.org/appengine/README.md b/vendor/google.golang.org/appengine/README.md index b6b11d9..1efd955 100644 --- a/vendor/google.golang.org/appengine/README.md +++ b/vendor/google.golang.org/appengine/README.md @@ -66,8 +66,6 @@ This list summarises the differences: * `appengine.BackendHostname` and `appengine.BackendInstance` were for the deprecated backends feature. Use `appengine.ModuleHostname`and `appengine.ModuleName` instead. * Most of `appengine/file` and parts of `appengine/blobstore` are deprecated. - Use [Google Cloud Storage](https://godoc.org/cloud.google.com/go/storage) if the - feature you require is not present in the new - [blobstore package](https://google.golang.org/appengine/blobstore). + Use [Google Cloud Storage](https://godoc.org/google.golang.org/cloud/storage) instead. * `appengine/socket` is not required on App Engine flexible environment / Managed VMs. Use the standard `net` package instead. diff --git a/vendor/google.golang.org/appengine/internal/api.go b/vendor/google.golang.org/appengine/internal/api.go index 09562c4..ec5aa59 100644 --- a/vendor/google.golang.org/appengine/internal/api.go +++ b/vendor/google.golang.org/appengine/internal/api.go @@ -32,8 +32,7 @@ import ( ) const ( - apiPath = "/rpc_http" - defaultTicketSuffix = "/default.20150612t184001.0" + apiPath = "/rpc_http" ) var ( @@ -61,9 +60,6 @@ var ( Dial: limitDial, }, } - - defaultTicketOnce sync.Once - defaultTicket string ) func apiURL() *url.URL { @@ -270,24 +266,6 @@ func WithContext(parent netcontext.Context, req *http.Request) netcontext.Contex return withContext(parent, c) } -// DefaultTicket returns a ticket used for background context or dev_appserver. -func DefaultTicket() string { - defaultTicketOnce.Do(func() { - if IsDevAppServer() { - defaultTicket = "testapp" + defaultTicketSuffix - return - } - appID := partitionlessAppID() - escAppID := strings.Replace(strings.Replace(appID, ":", "_", -1), ".", "_", -1) - majVersion := VersionID(nil) - if i := strings.Index(majVersion, "."); i > 0 { - majVersion = majVersion[:i] - } - defaultTicket = fmt.Sprintf("%s/%s.%s.%s", escAppID, ModuleName(nil), majVersion, InstanceID()) - }) - return defaultTicket -} - func BackgroundContext() netcontext.Context { ctxs.Lock() defer ctxs.Unlock() @@ -297,7 +275,13 @@ func BackgroundContext() netcontext.Context { } // Compute background security ticket. - ticket := DefaultTicket() + appID := partitionlessAppID() + escAppID := strings.Replace(strings.Replace(appID, ":", "_", -1), ".", "_", -1) + majVersion := VersionID(nil) + if i := strings.Index(majVersion, "."); i > 0 { + majVersion = majVersion[:i] + } + ticket := fmt.Sprintf("%s/%s.%s.%s", escAppID, ModuleName(nil), majVersion, InstanceID()) ctxs.bg = &context{ req: &http.Request{ @@ -491,16 +475,6 @@ func Call(ctx netcontext.Context, service, method string, in, out proto.Message) } ticket := c.req.Header.Get(ticketHeader) - // Use a test ticket under test environment. - if ticket == "" { - if appid := ctx.Value(&appIDOverrideKey); appid != nil { - ticket = appid.(string) + defaultTicketSuffix - } - } - // Fall back to use background ticket when the request ticket is not available in Flex or dev_appserver. - if ticket == "" { - ticket = DefaultTicket() - } req := &remotepb.Request{ ServiceName: &service, Method: &method, diff --git a/vendor/google.golang.org/appengine/internal/api_common.go b/vendor/google.golang.org/appengine/internal/api_common.go index 8c3eece..2db33a7 100644 --- a/vendor/google.golang.org/appengine/internal/api_common.go +++ b/vendor/google.golang.org/appengine/internal/api_common.go @@ -5,8 +5,6 @@ package internal import ( - "os" - "github.com/golang/protobuf/proto" netcontext "golang.org/x/net/context" ) @@ -86,31 +84,3 @@ func Logf(ctx netcontext.Context, level int64, format string, args ...interface{ func NamespacedContext(ctx netcontext.Context, namespace string) netcontext.Context { return withNamespace(ctx, namespace) } - -// SetTestEnv sets the env variables for testing background ticket in Flex. -func SetTestEnv() func() { - var environ = []struct { - key, value string - }{ - {"GAE_LONG_APP_ID", "my-app-id"}, - {"GAE_MINOR_VERSION", "067924799508853122"}, - {"GAE_MODULE_INSTANCE", "0"}, - {"GAE_MODULE_NAME", "default"}, - {"GAE_MODULE_VERSION", "20150612t184001"}, - } - - for _, v := range environ { - old := os.Getenv(v.key) - os.Setenv(v.key, v.value) - v.value = old - } - return func() { // Restore old environment after the test completes. - for _, v := range environ { - if v.value == "" { - os.Unsetenv(v.key) - continue - } - os.Setenv(v.key, v.value) - } - } -} diff --git a/vendor/gopkg.in/yaml.v2/.travis.yml b/vendor/gopkg.in/yaml.v2/.travis.yml deleted file mode 100644 index 004172a..0000000 --- a/vendor/gopkg.in/yaml.v2/.travis.yml +++ /dev/null @@ -1,9 +0,0 @@ -language: go - -go: - - 1.4 - - 1.5 - - 1.6 - - tip - -go_import_path: gopkg.in/yaml.v2 diff --git a/vendor/gopkg.in/yaml.v2/LICENSE b/vendor/gopkg.in/yaml.v2/LICENSE index 866d74a..a68e67f 100644 --- a/vendor/gopkg.in/yaml.v2/LICENSE +++ b/vendor/gopkg.in/yaml.v2/LICENSE @@ -1,13 +1,188 @@ -Copyright 2011-2016 Canonical Ltd. -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 +Copyright (c) 2011-2014 - Canonical Inc. - http://www.apache.org/licenses/LICENSE-2.0 +This software is licensed under the LGPLv3, included below. -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. +As a special exception to the GNU Lesser General Public License version 3 +("LGPL3"), the copyright holders of this Library give you permission to +convey to a third party a Combined Work that links statically or dynamically +to this Library without providing any Minimal Corresponding Source or +Minimal Application Code as set out in 4d or providing the installation +information set out in section 4e, provided that you comply with the other +provisions of LGPL3 and provided that you meet, for the Application the +terms and conditions of the license(s) which apply to the Application. + +Except as stated in this special exception, the provisions of LGPL3 will +continue to comply in full to this Library. If you modify this Library, you +may apply this exception to your version of this Library, but you are not +obliged to do so. If you do not wish to do so, delete this exception +statement from your version. This exception does not (and cannot) modify any +license terms which apply to the Application, with which you must still +comply. + + + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. diff --git a/vendor/gopkg.in/yaml.v2/README.md b/vendor/gopkg.in/yaml.v2/README.md index 1884de6..7b8bd86 100644 --- a/vendor/gopkg.in/yaml.v2/README.md +++ b/vendor/gopkg.in/yaml.v2/README.md @@ -42,7 +42,7 @@ The package API for yaml v2 will remain stable as described in [gopkg.in](https: License ------- -The yaml package is licensed under the Apache License 2.0. Please see the LICENSE file for details. +The yaml package is licensed under the LGPL with an exception that allows it to be linked statically. Please see the LICENSE file for details. Example diff --git a/vendor/gopkg.in/yaml.v2/decode.go b/vendor/gopkg.in/yaml.v2/decode.go index b13ab9f..085cddc 100644 --- a/vendor/gopkg.in/yaml.v2/decode.go +++ b/vendor/gopkg.in/yaml.v2/decode.go @@ -251,7 +251,7 @@ func (d *decoder) callUnmarshaler(n *node, u Unmarshaler) (good bool) { // // If n holds a null value, prepare returns before doing anything. func (d *decoder) prepare(n *node, out reflect.Value) (newout reflect.Value, unmarshaled, good bool) { - if n.tag == yaml_NULL_TAG || n.kind == scalarNode && n.tag == "" && (n.value == "null" || n.value == "" && n.implicit) { + if n.tag == yaml_NULL_TAG || n.kind == scalarNode && n.tag == "" && (n.value == "null" || n.value == "") { return out, false, false } again := true diff --git a/vendor/gopkg.in/yaml.v2/readerc.go b/vendor/gopkg.in/yaml.v2/readerc.go index f450791..d5fb097 100644 --- a/vendor/gopkg.in/yaml.v2/readerc.go +++ b/vendor/gopkg.in/yaml.v2/readerc.go @@ -247,7 +247,7 @@ func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { if parser.encoding == yaml_UTF16LE_ENCODING { low, high = 0, 1 } else { - low, high = 1, 0 + high, low = 1, 0 } // The UTF-16 encoding is not as simple as one might @@ -357,26 +357,23 @@ func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { if value <= 0x7F { // 0000 0000-0000 007F . 0xxxxxxx parser.buffer[buffer_len+0] = byte(value) - buffer_len += 1 } else if value <= 0x7FF { // 0000 0080-0000 07FF . 110xxxxx 10xxxxxx parser.buffer[buffer_len+0] = byte(0xC0 + (value >> 6)) parser.buffer[buffer_len+1] = byte(0x80 + (value & 0x3F)) - buffer_len += 2 } else if value <= 0xFFFF { // 0000 0800-0000 FFFF . 1110xxxx 10xxxxxx 10xxxxxx parser.buffer[buffer_len+0] = byte(0xE0 + (value >> 12)) parser.buffer[buffer_len+1] = byte(0x80 + ((value >> 6) & 0x3F)) parser.buffer[buffer_len+2] = byte(0x80 + (value & 0x3F)) - buffer_len += 3 } else { // 0001 0000-0010 FFFF . 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx parser.buffer[buffer_len+0] = byte(0xF0 + (value >> 18)) parser.buffer[buffer_len+1] = byte(0x80 + ((value >> 12) & 0x3F)) parser.buffer[buffer_len+2] = byte(0x80 + ((value >> 6) & 0x3F)) parser.buffer[buffer_len+3] = byte(0x80 + (value & 0x3F)) - buffer_len += 4 } + buffer_len += width parser.unread++ } diff --git a/vendor/gopkg.in/yaml.v2/scannerc.go b/vendor/gopkg.in/yaml.v2/scannerc.go index 2580800..d97d76f 100644 --- a/vendor/gopkg.in/yaml.v2/scannerc.go +++ b/vendor/gopkg.in/yaml.v2/scannerc.go @@ -1546,7 +1546,7 @@ func yaml_parser_scan_directive(parser *yaml_parser_t, token *yaml_token_t) bool // Unknown directive. } else { yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "found unknown directive name") + start_mark, "found uknown directive name") return false } diff --git a/vendor/gopkg.in/yaml.v2/yaml.go b/vendor/gopkg.in/yaml.v2/yaml.go index 36d6b88..d133edf 100644 --- a/vendor/gopkg.in/yaml.v2/yaml.go +++ b/vendor/gopkg.in/yaml.v2/yaml.go @@ -222,7 +222,7 @@ func getStructInfo(st reflect.Type) (*structInfo, error) { inlineMap := -1 for i := 0; i != n; i++ { field := st.Field(i) - if field.PkgPath != "" && !field.Anonymous { + if field.PkgPath != "" { continue // Private field } diff --git a/vendor/k8s.io/kubernetes/LICENSE b/vendor/k8s.io/client-go/LICENSE similarity index 100% rename from vendor/k8s.io/kubernetes/LICENSE rename to vendor/k8s.io/client-go/LICENSE diff --git a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/discovery_client.go b/vendor/k8s.io/client-go/discovery/discovery_client.go similarity index 88% rename from vendor/k8s.io/kubernetes/pkg/client/typed/discovery/discovery_client.go rename to vendor/k8s.io/client-go/discovery/discovery_client.go index 5e08cee..51c3231 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/discovery_client.go +++ b/vendor/k8s.io/client-go/discovery/discovery_client.go @@ -25,19 +25,20 @@ import ( "github.com/emicklei/go-restful/swagger" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/errors" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer" - "k8s.io/kubernetes/pkg/version" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/errors" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer" + "k8s.io/client-go/pkg/version" + "k8s.io/client-go/rest" ) // DiscoveryInterface holds the methods that discover server-supported API groups, // versions and resources. type DiscoveryInterface interface { + RESTClient() rest.Interface ServerGroupsInterface ServerResourcesInterface ServerVersionInterface @@ -80,7 +81,7 @@ type SwaggerSchemaInterface interface { // DiscoveryClient implements the functions that discover server-supported API groups, // versions and resources. type DiscoveryClient struct { - *restclient.RESTClient + restClient rest.Interface LegacyPrefix string } @@ -107,7 +108,7 @@ func apiVersionsToAPIGroup(apiVersions *unversioned.APIVersions) (apiGroup unver func (d *DiscoveryClient) ServerGroups() (apiGroupList *unversioned.APIGroupList, err error) { // Get the groupVersions exposed at /api v := &unversioned.APIVersions{} - err = d.Get().AbsPath(d.LegacyPrefix).Do().Into(v) + err = d.restClient.Get().AbsPath(d.LegacyPrefix).Do().Into(v) apiGroup := unversioned.APIGroup{} if err == nil { apiGroup = apiVersionsToAPIGroup(v) @@ -118,7 +119,7 @@ func (d *DiscoveryClient) ServerGroups() (apiGroupList *unversioned.APIGroupList // Get the groupVersions exposed at /apis apiGroupList = &unversioned.APIGroupList{} - err = d.Get().AbsPath("/apis").Do().Into(apiGroupList) + err = d.restClient.Get().AbsPath("/apis").Do().Into(apiGroupList) if err != nil && !errors.IsNotFound(err) && !errors.IsForbidden(err) { return nil, err } @@ -144,7 +145,7 @@ func (d *DiscoveryClient) ServerResourcesForGroupVersion(groupVersion string) (r url.Path = "/apis/" + groupVersion } resources = &unversioned.APIResourceList{} - err = d.Get().AbsPath(url.String()).Do().Into(resources) + err = d.restClient.Get().AbsPath(url.String()).Do().Into(resources) if err != nil { // ignore 403 or 404 error to be compatible with an v1.0 server. if groupVersion == "v1" && (errors.IsNotFound(err) || errors.IsForbidden(err)) { @@ -255,7 +256,7 @@ func (d *DiscoveryClient) ServerPreferredNamespacedResources() ([]unversioned.Gr // ServerVersion retrieves and parses the server's version (git version). func (d *DiscoveryClient) ServerVersion() (*version.Info, error) { - body, err := d.Get().AbsPath("/version").Do().Raw() + body, err := d.restClient.Get().AbsPath("/version").Do().Raw() if err != nil { return nil, err } @@ -289,7 +290,7 @@ func (d *DiscoveryClient) SwaggerSchema(version unversioned.GroupVersion) (*swag path = "/swaggerapi/apis/" + version.Group + "/" + version.Version } - body, err := d.Get().AbsPath(path).Do().Raw() + body, err := d.restClient.Get().AbsPath(path).Do().Raw() if err != nil { return nil, err } @@ -301,34 +302,31 @@ func (d *DiscoveryClient) SwaggerSchema(version unversioned.GroupVersion) (*swag return &schema, nil } -func setDiscoveryDefaults(config *restclient.Config) error { +func setDiscoveryDefaults(config *rest.Config) error { config.APIPath = "" config.GroupVersion = nil codec := runtime.NoopEncoder{Decoder: api.Codecs.UniversalDecoder()} - config.NegotiatedSerializer = serializer.NegotiatedSerializerWrapper( - runtime.SerializerInfo{Serializer: codec}, - runtime.StreamSerializerInfo{}, - ) + config.NegotiatedSerializer = serializer.NegotiatedSerializerWrapper(runtime.SerializerInfo{Serializer: codec}) if len(config.UserAgent) == 0 { - config.UserAgent = restclient.DefaultKubernetesUserAgent() + config.UserAgent = rest.DefaultKubernetesUserAgent() } return nil } // NewDiscoveryClientForConfig creates a new DiscoveryClient for the given config. This client // can be used to discover supported resources in the API server. -func NewDiscoveryClientForConfig(c *restclient.Config) (*DiscoveryClient, error) { +func NewDiscoveryClientForConfig(c *rest.Config) (*DiscoveryClient, error) { config := *c if err := setDiscoveryDefaults(&config); err != nil { return nil, err } - client, err := restclient.UnversionedRESTClientFor(&config) - return &DiscoveryClient{RESTClient: client, LegacyPrefix: "/api"}, err + client, err := rest.UnversionedRESTClientFor(&config) + return &DiscoveryClient{restClient: client, LegacyPrefix: "/api"}, err } // NewDiscoveryClientForConfig creates a new DiscoveryClient for the given config. If // there is an error, it panics. -func NewDiscoveryClientForConfigOrDie(c *restclient.Config) *DiscoveryClient { +func NewDiscoveryClientForConfigOrDie(c *rest.Config) *DiscoveryClient { client, err := NewDiscoveryClientForConfig(c) if err != nil { panic(err) @@ -338,8 +336,8 @@ func NewDiscoveryClientForConfigOrDie(c *restclient.Config) *DiscoveryClient { } // New creates a new DiscoveryClient for the given RESTClient. -func NewDiscoveryClient(c *restclient.RESTClient) *DiscoveryClient { - return &DiscoveryClient{RESTClient: c, LegacyPrefix: "/api"} +func NewDiscoveryClient(c rest.Interface) *DiscoveryClient { + return &DiscoveryClient{restClient: c, LegacyPrefix: "/api"} } func stringDoesntExistIn(str string, slice []string) bool { @@ -350,3 +348,12 @@ func stringDoesntExistIn(str string, slice []string) bool { } return true } + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *DiscoveryClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/discovery/helper.go b/vendor/k8s.io/client-go/discovery/helper.go new file mode 100644 index 0000000..0e830d8 --- /dev/null +++ b/vendor/k8s.io/client-go/discovery/helper.go @@ -0,0 +1,135 @@ +/* +Copyright 2016 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. +*/ + +package discovery + +import ( + "fmt" + + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/util/sets" + "k8s.io/client-go/pkg/version" + "k8s.io/client-go/rest" + // Import solely to initialize client auth plugins. + _ "k8s.io/client-go/plugin/pkg/client/auth" +) + +// MatchesServerVersion queries the server to compares the build version +// (git hash) of the client with the server's build version. It returns an error +// if it failed to contact the server or if the versions are not an exact match. +func MatchesServerVersion(client DiscoveryInterface, c *rest.Config) error { + var err error + if client == nil { + client, err = NewDiscoveryClientForConfig(c) + if err != nil { + return err + } + } + cVer := version.Get() + sVer, err := client.ServerVersion() + if err != nil { + return fmt.Errorf("couldn't read version from server: %v\n", err) + } + // GitVersion includes GitCommit and GitTreeState, but best to be safe? + if cVer.GitVersion != sVer.GitVersion || cVer.GitCommit != sVer.GitCommit || cVer.GitTreeState != sVer.GitTreeState { + return fmt.Errorf("server version (%#v) differs from client version (%#v)!\n", sVer, cVer) + } + + return nil +} + +// NegotiateVersion queries the server's supported api versions to find +// a version that both client and server support. +// - If no version is provided, try registered client versions in order of +// preference. +// - If version is provided, but not default config (explicitly requested via +// commandline flag), and is unsupported by the server, print a warning to +// stderr and try client's registered versions in order of preference. +// - If version is config default, and the server does not support it, +// return an error. +func NegotiateVersion(client DiscoveryInterface, c *rest.Config, requestedGV *unversioned.GroupVersion, clientRegisteredGVs []unversioned.GroupVersion) (*unversioned.GroupVersion, error) { + var err error + if client == nil { + client, err = NewDiscoveryClientForConfig(c) + if err != nil { + return nil, err + } + } + clientVersions := sets.String{} + for _, gv := range clientRegisteredGVs { + clientVersions.Insert(gv.String()) + } + groups, err := client.ServerGroups() + if err != nil { + // This is almost always a connection error, and higher level code should treat this as a generic error, + // not a negotiation specific error. + return nil, err + } + versions := unversioned.ExtractGroupVersions(groups) + serverVersions := sets.String{} + for _, v := range versions { + serverVersions.Insert(v) + } + + // If no version requested, use config version (may also be empty). + // make a copy of the original so we don't risk mutating input here or in the returned value + var preferredGV *unversioned.GroupVersion + switch { + case requestedGV != nil: + t := *requestedGV + preferredGV = &t + case c.GroupVersion != nil: + t := *c.GroupVersion + preferredGV = &t + } + + // If version explicitly requested verify that both client and server support it. + // If server does not support warn, but try to negotiate a lower version. + if preferredGV != nil { + if !clientVersions.Has(preferredGV.String()) { + return nil, fmt.Errorf("client does not support API version %q; client supported API versions: %v", preferredGV, clientVersions) + + } + // If the server supports no versions, then we should just use the preferredGV + // This can happen because discovery fails due to 403 Forbidden errors + if len(serverVersions) == 0 { + return preferredGV, nil + } + if serverVersions.Has(preferredGV.String()) { + return preferredGV, nil + } + // If we are using an explicit config version the server does not support, fail. + if (c.GroupVersion != nil) && (*preferredGV == *c.GroupVersion) { + return nil, fmt.Errorf("server does not support API version %q", preferredGV) + } + } + + for _, clientGV := range clientRegisteredGVs { + if serverVersions.Has(clientGV.String()) { + // Version was not explicitly requested in command config (--api-version). + // Ok to fall back to a supported version with a warning. + // TODO: caesarxuchao: enable the warning message when we have + // proper fix. Please refer to issue #14895. + // if len(version) != 0 { + // glog.Warningf("Server does not support API version '%s'. Falling back to '%s'.", version, clientVersion) + // } + t := clientGV + return &t, nil + } + } + return nil, fmt.Errorf("failed to negotiate an api version; server supports: %v, client supports: %v", + serverVersions, clientVersions) +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/restmapper.go b/vendor/k8s.io/client-go/discovery/restmapper.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/client/typed/discovery/restmapper.go rename to vendor/k8s.io/client-go/discovery/restmapper.go index 49cbe15..c3fcc09 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/restmapper.go +++ b/vendor/k8s.io/client-go/discovery/restmapper.go @@ -20,9 +20,9 @@ import ( "fmt" "sync" - "k8s.io/kubernetes/pkg/api/errors" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/errors" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" ) // APIGroupResources is an API group with a mapping of versions to diff --git a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/unstructured.go b/vendor/k8s.io/client-go/discovery/unstructured.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/typed/discovery/unstructured.go rename to vendor/k8s.io/client-go/discovery/unstructured.go index afa74e7..c4b8791 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/typed/discovery/unstructured.go +++ b/vendor/k8s.io/client-go/discovery/unstructured.go @@ -19,8 +19,8 @@ package discovery import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // UnstructuredObjectTyper provides a runtime.ObjectTyper implmentation for diff --git a/vendor/k8s.io/client-go/kubernetes/clientset.go b/vendor/k8s.io/client-go/kubernetes/clientset.go new file mode 100644 index 0000000..6f6bce5 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/clientset.go @@ -0,0 +1,261 @@ +/* +Copyright 2016 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. +*/ + +package kubernetes + +import ( + "github.com/golang/glog" + discovery "k8s.io/client-go/discovery" + v1alpha1apps "k8s.io/client-go/kubernetes/typed/apps/v1alpha1" + v1beta1authentication "k8s.io/client-go/kubernetes/typed/authentication/v1beta1" + v1beta1authorization "k8s.io/client-go/kubernetes/typed/authorization/v1beta1" + v1autoscaling "k8s.io/client-go/kubernetes/typed/autoscaling/v1" + v1batch "k8s.io/client-go/kubernetes/typed/batch/v1" + v1alpha1certificates "k8s.io/client-go/kubernetes/typed/certificates/v1alpha1" + v1core "k8s.io/client-go/kubernetes/typed/core/v1" + v1beta1extensions "k8s.io/client-go/kubernetes/typed/extensions/v1beta1" + v1alpha1policy "k8s.io/client-go/kubernetes/typed/policy/v1alpha1" + v1alpha1rbac "k8s.io/client-go/kubernetes/typed/rbac/v1alpha1" + v1beta1storage "k8s.io/client-go/kubernetes/typed/storage/v1beta1" + "k8s.io/client-go/pkg/util/flowcontrol" + _ "k8s.io/client-go/plugin/pkg/client/auth" + rest "k8s.io/client-go/rest" +) + +type Interface interface { + Discovery() discovery.DiscoveryInterface + Core() v1core.CoreInterface + Apps() v1alpha1apps.AppsInterface + Authentication() v1beta1authentication.AuthenticationInterface + Authorization() v1beta1authorization.AuthorizationInterface + Autoscaling() v1autoscaling.AutoscalingInterface + Batch() v1batch.BatchInterface + Certificates() v1alpha1certificates.CertificatesInterface + Extensions() v1beta1extensions.ExtensionsInterface + Policy() v1alpha1policy.PolicyInterface + Rbac() v1alpha1rbac.RbacInterface + Storage() v1beta1storage.StorageInterface +} + +// Clientset contains the clients for groups. Each group has exactly one +// version included in a Clientset. +type Clientset struct { + *discovery.DiscoveryClient + *v1core.CoreClient + *v1alpha1apps.AppsClient + *v1beta1authentication.AuthenticationClient + *v1beta1authorization.AuthorizationClient + *v1autoscaling.AutoscalingClient + *v1batch.BatchClient + *v1alpha1certificates.CertificatesClient + *v1beta1extensions.ExtensionsClient + *v1alpha1policy.PolicyClient + *v1alpha1rbac.RbacClient + *v1beta1storage.StorageClient +} + +// Core retrieves the CoreClient +func (c *Clientset) Core() v1core.CoreInterface { + if c == nil { + return nil + } + return c.CoreClient +} + +// Apps retrieves the AppsClient +func (c *Clientset) Apps() v1alpha1apps.AppsInterface { + if c == nil { + return nil + } + return c.AppsClient +} + +// Authentication retrieves the AuthenticationClient +func (c *Clientset) Authentication() v1beta1authentication.AuthenticationInterface { + if c == nil { + return nil + } + return c.AuthenticationClient +} + +// Authorization retrieves the AuthorizationClient +func (c *Clientset) Authorization() v1beta1authorization.AuthorizationInterface { + if c == nil { + return nil + } + return c.AuthorizationClient +} + +// Autoscaling retrieves the AutoscalingClient +func (c *Clientset) Autoscaling() v1autoscaling.AutoscalingInterface { + if c == nil { + return nil + } + return c.AutoscalingClient +} + +// Batch retrieves the BatchClient +func (c *Clientset) Batch() v1batch.BatchInterface { + if c == nil { + return nil + } + return c.BatchClient +} + +// Certificates retrieves the CertificatesClient +func (c *Clientset) Certificates() v1alpha1certificates.CertificatesInterface { + if c == nil { + return nil + } + return c.CertificatesClient +} + +// Extensions retrieves the ExtensionsClient +func (c *Clientset) Extensions() v1beta1extensions.ExtensionsInterface { + if c == nil { + return nil + } + return c.ExtensionsClient +} + +// Policy retrieves the PolicyClient +func (c *Clientset) Policy() v1alpha1policy.PolicyInterface { + if c == nil { + return nil + } + return c.PolicyClient +} + +// Rbac retrieves the RbacClient +func (c *Clientset) Rbac() v1alpha1rbac.RbacInterface { + if c == nil { + return nil + } + return c.RbacClient +} + +// Storage retrieves the StorageClient +func (c *Clientset) Storage() v1beta1storage.StorageInterface { + if c == nil { + return nil + } + return c.StorageClient +} + +// Discovery retrieves the DiscoveryClient +func (c *Clientset) Discovery() discovery.DiscoveryInterface { + return c.DiscoveryClient +} + +// NewForConfig creates a new Clientset for the given config. +func NewForConfig(c *rest.Config) (*Clientset, error) { + configShallowCopy := *c + if configShallowCopy.RateLimiter == nil && configShallowCopy.QPS > 0 { + configShallowCopy.RateLimiter = flowcontrol.NewTokenBucketRateLimiter(configShallowCopy.QPS, configShallowCopy.Burst) + } + var clientset Clientset + var err error + clientset.CoreClient, err = v1core.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.AppsClient, err = v1alpha1apps.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.AuthenticationClient, err = v1beta1authentication.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.AuthorizationClient, err = v1beta1authorization.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.AutoscalingClient, err = v1autoscaling.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.BatchClient, err = v1batch.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.CertificatesClient, err = v1alpha1certificates.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.ExtensionsClient, err = v1beta1extensions.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.PolicyClient, err = v1alpha1policy.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.RbacClient, err = v1alpha1rbac.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + clientset.StorageClient, err = v1beta1storage.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } + + clientset.DiscoveryClient, err = discovery.NewDiscoveryClientForConfig(&configShallowCopy) + if err != nil { + glog.Errorf("failed to create the DiscoveryClient: %v", err) + return nil, err + } + return &clientset, nil +} + +// NewForConfigOrDie creates a new Clientset for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *Clientset { + var clientset Clientset + clientset.CoreClient = v1core.NewForConfigOrDie(c) + clientset.AppsClient = v1alpha1apps.NewForConfigOrDie(c) + clientset.AuthenticationClient = v1beta1authentication.NewForConfigOrDie(c) + clientset.AuthorizationClient = v1beta1authorization.NewForConfigOrDie(c) + clientset.AutoscalingClient = v1autoscaling.NewForConfigOrDie(c) + clientset.BatchClient = v1batch.NewForConfigOrDie(c) + clientset.CertificatesClient = v1alpha1certificates.NewForConfigOrDie(c) + clientset.ExtensionsClient = v1beta1extensions.NewForConfigOrDie(c) + clientset.PolicyClient = v1alpha1policy.NewForConfigOrDie(c) + clientset.RbacClient = v1alpha1rbac.NewForConfigOrDie(c) + clientset.StorageClient = v1beta1storage.NewForConfigOrDie(c) + + clientset.DiscoveryClient = discovery.NewDiscoveryClientForConfigOrDie(c) + return &clientset +} + +// New creates a new Clientset for the given RESTClient. +func New(c rest.Interface) *Clientset { + var clientset Clientset + clientset.CoreClient = v1core.New(c) + clientset.AppsClient = v1alpha1apps.New(c) + clientset.AuthenticationClient = v1beta1authentication.New(c) + clientset.AuthorizationClient = v1beta1authorization.New(c) + clientset.AutoscalingClient = v1autoscaling.New(c) + clientset.BatchClient = v1batch.New(c) + clientset.CertificatesClient = v1alpha1certificates.New(c) + clientset.ExtensionsClient = v1beta1extensions.New(c) + clientset.PolicyClient = v1alpha1policy.New(c) + clientset.RbacClient = v1alpha1rbac.New(c) + clientset.StorageClient = v1beta1storage.New(c) + + clientset.DiscoveryClient = discovery.NewDiscoveryClient(c) + return &clientset +} diff --git a/vendor/k8s.io/client-go/kubernetes/doc.go b/vendor/k8s.io/client-go/kubernetes/doc.go new file mode 100644 index 0000000..bd09a35 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated clientset. +package kubernetes diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/import_known_versions.go b/vendor/k8s.io/client-go/kubernetes/import_known_versions.go similarity index 54% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/import_known_versions.go rename to vendor/k8s.io/client-go/kubernetes/import_known_versions.go index 85dc5bb..57fb7f9 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/import_known_versions.go +++ b/vendor/k8s.io/client-go/kubernetes/import_known_versions.go @@ -1,5 +1,5 @@ /* -Copyright 2015 The Kubernetes Authors. +Copyright 2016 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. @@ -14,25 +14,24 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package kubernetes // These imports are the API groups the client will support. import ( "fmt" - _ "k8s.io/kubernetes/pkg/api/install" - "k8s.io/kubernetes/pkg/apimachinery/registered" - _ "k8s.io/kubernetes/pkg/apis/apps/install" - _ "k8s.io/kubernetes/pkg/apis/authentication/install" - _ "k8s.io/kubernetes/pkg/apis/authorization/install" - _ "k8s.io/kubernetes/pkg/apis/autoscaling/install" - _ "k8s.io/kubernetes/pkg/apis/batch/install" - _ "k8s.io/kubernetes/pkg/apis/certificates/install" - _ "k8s.io/kubernetes/pkg/apis/componentconfig/install" - _ "k8s.io/kubernetes/pkg/apis/extensions/install" - _ "k8s.io/kubernetes/pkg/apis/policy/install" - _ "k8s.io/kubernetes/pkg/apis/rbac/install" - _ "k8s.io/kubernetes/pkg/apis/storage/install" + _ "k8s.io/client-go/pkg/api/install" + "k8s.io/client-go/pkg/apimachinery/registered" + _ "k8s.io/client-go/pkg/apis/apps/install" + _ "k8s.io/client-go/pkg/apis/authentication/install" + _ "k8s.io/client-go/pkg/apis/authorization/install" + _ "k8s.io/client-go/pkg/apis/autoscaling/install" + _ "k8s.io/client-go/pkg/apis/batch/install" + _ "k8s.io/client-go/pkg/apis/certificates/install" + _ "k8s.io/client-go/pkg/apis/extensions/install" + _ "k8s.io/client-go/pkg/apis/policy/install" + _ "k8s.io/client-go/pkg/apis/rbac/install" + _ "k8s.io/client-go/pkg/apis/storage/install" ) func init() { diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/apps_client.go b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/apps_client.go similarity index 57% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/apps_client.go rename to vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/apps_client.go index 6d9edf7..8a51581 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/apps_client.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/apps_client.go @@ -14,35 +14,36 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1alpha1 import ( - api "k8s.io/kubernetes/pkg/api" - registered "k8s.io/kubernetes/pkg/apimachinery/registered" - restclient "k8s.io/kubernetes/pkg/client/restclient" + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" ) type AppsInterface interface { - GetRESTClient() *restclient.RESTClient - PetSetsGetter + RESTClient() rest.Interface + StatefulSetsGetter } // AppsClient is used to interact with features provided by the Apps group. type AppsClient struct { - *restclient.RESTClient + restClient rest.Interface } -func (c *AppsClient) PetSets(namespace string) PetSetInterface { - return newPetSets(c, namespace) +func (c *AppsClient) StatefulSets(namespace string) StatefulSetInterface { + return newStatefulSets(c, namespace) } // NewForConfig creates a new AppsClient for the given config. -func NewForConfig(c *restclient.Config) (*AppsClient, error) { +func NewForConfig(c *rest.Config) (*AppsClient, error) { config := *c if err := setConfigDefaults(&config); err != nil { return nil, err } - client, err := restclient.RESTClientFor(&config) + client, err := rest.RESTClientFor(&config) if err != nil { return nil, err } @@ -51,7 +52,7 @@ func NewForConfig(c *restclient.Config) (*AppsClient, error) { // NewForConfigOrDie creates a new AppsClient for the given config and // panics if there is an error in the config. -func NewForConfigOrDie(c *restclient.Config) *AppsClient { +func NewForConfigOrDie(c *rest.Config) *AppsClient { client, err := NewForConfig(c) if err != nil { panic(err) @@ -60,11 +61,11 @@ func NewForConfigOrDie(c *restclient.Config) *AppsClient { } // New creates a new AppsClient for the given RESTClient. -func New(c *restclient.RESTClient) *AppsClient { +func New(c rest.Interface) *AppsClient { return &AppsClient{c} } -func setConfigDefaults(config *restclient.Config) error { +func setConfigDefaults(config *rest.Config) error { // if apps group is not registered, return an error g, err := registered.Group("apps") if err != nil { @@ -72,28 +73,24 @@ func setConfigDefaults(config *restclient.Config) error { } config.APIPath = "/apis" if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() + config.UserAgent = rest.DefaultKubernetesUserAgent() } - if config.GroupVersion == nil || config.GroupVersion.Group != g.GroupVersion.Group { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - config.NegotiatedSerializer = api.Codecs + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} - if config.QPS == 0 { - config.QPS = 5 - } - if config.Burst == 0 { - config.Burst = 10 - } return nil } -// GetRESTClient returns a RESTClient that is used to communicate +// RESTClient returns a RESTClient that is used to communicate // with API server by this client implementation. -func (c *AppsClient) GetRESTClient() *restclient.RESTClient { +func (c *AppsClient) RESTClient() rest.Interface { if c == nil { return nil } - return c.RESTClient + return c.restClient } diff --git a/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/doc.go new file mode 100644 index 0000000..0c1ca41 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/generated_expansion.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/componentconfig/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/generated_expansion.go index 98ea9b5..bbf6c91 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/generated_expansion.go @@ -14,7 +14,6 @@ See the License for the specific language governing permissions and limitations under the License. */ -// +k8s:deepcopy-gen=package,register -// +k8s:openapi-gen=true +package v1alpha1 -package componentconfig +type StatefulSetExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/statefulset.go b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/statefulset.go new file mode 100644 index 0000000..d5e3f9f --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/apps/v1alpha1/statefulset.go @@ -0,0 +1,167 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/apps/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// StatefulSetsGetter has a method to return a StatefulSetInterface. +// A group's client should implement this interface. +type StatefulSetsGetter interface { + StatefulSets(namespace string) StatefulSetInterface +} + +// StatefulSetInterface has methods to work with StatefulSet resources. +type StatefulSetInterface interface { + Create(*v1alpha1.StatefulSet) (*v1alpha1.StatefulSet, error) + Update(*v1alpha1.StatefulSet) (*v1alpha1.StatefulSet, error) + UpdateStatus(*v1alpha1.StatefulSet) (*v1alpha1.StatefulSet, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.StatefulSet, error) + List(opts v1.ListOptions) (*v1alpha1.StatefulSetList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.StatefulSet, err error) + StatefulSetExpansion +} + +// statefulSets implements StatefulSetInterface +type statefulSets struct { + client rest.Interface + ns string +} + +// newStatefulSets returns a StatefulSets +func newStatefulSets(c *AppsClient, namespace string) *statefulSets { + return &statefulSets{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a statefulSet and creates it. Returns the server's representation of the statefulSet, and an error, if there is any. +func (c *statefulSets) Create(statefulSet *v1alpha1.StatefulSet) (result *v1alpha1.StatefulSet, err error) { + result = &v1alpha1.StatefulSet{} + err = c.client.Post(). + Namespace(c.ns). + Resource("statefulsets"). + Body(statefulSet). + Do(). + Into(result) + return +} + +// Update takes the representation of a statefulSet and updates it. Returns the server's representation of the statefulSet, and an error, if there is any. +func (c *statefulSets) Update(statefulSet *v1alpha1.StatefulSet) (result *v1alpha1.StatefulSet, err error) { + result = &v1alpha1.StatefulSet{} + err = c.client.Put(). + Namespace(c.ns). + Resource("statefulsets"). + Name(statefulSet.Name). + Body(statefulSet). + Do(). + Into(result) + return +} + +func (c *statefulSets) UpdateStatus(statefulSet *v1alpha1.StatefulSet) (result *v1alpha1.StatefulSet, err error) { + result = &v1alpha1.StatefulSet{} + err = c.client.Put(). + Namespace(c.ns). + Resource("statefulsets"). + Name(statefulSet.Name). + SubResource("status"). + Body(statefulSet). + Do(). + Into(result) + return +} + +// Delete takes name of the statefulSet and deletes it. Returns an error if one occurs. +func (c *statefulSets) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("statefulsets"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *statefulSets) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("statefulsets"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the statefulSet, and returns the corresponding statefulSet object, and an error if there is any. +func (c *statefulSets) Get(name string) (result *v1alpha1.StatefulSet, err error) { + result = &v1alpha1.StatefulSet{} + err = c.client.Get(). + Namespace(c.ns). + Resource("statefulsets"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of StatefulSets that match those selectors. +func (c *statefulSets) List(opts v1.ListOptions) (result *v1alpha1.StatefulSetList, err error) { + result = &v1alpha1.StatefulSetList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("statefulsets"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested statefulSets. +func (c *statefulSets) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("statefulsets"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched statefulSet. +func (c *statefulSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.StatefulSet, err error) { + result = &v1alpha1.StatefulSet{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("statefulsets"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/authentication_client.go b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/authentication_client.go new file mode 100644 index 0000000..950096b --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/authentication_client.go @@ -0,0 +1,96 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type AuthenticationInterface interface { + RESTClient() rest.Interface + TokenReviewsGetter +} + +// AuthenticationClient is used to interact with features provided by the Authentication group. +type AuthenticationClient struct { + restClient rest.Interface +} + +func (c *AuthenticationClient) TokenReviews() TokenReviewInterface { + return newTokenReviews(c) +} + +// NewForConfig creates a new AuthenticationClient for the given config. +func NewForConfig(c *rest.Config) (*AuthenticationClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &AuthenticationClient{client}, nil +} + +// NewForConfigOrDie creates a new AuthenticationClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *AuthenticationClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new AuthenticationClient for the given RESTClient. +func New(c rest.Interface) *AuthenticationClient { + return &AuthenticationClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if authentication group is not registered, return an error + g, err := registered.Group("authentication.k8s.io") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *AuthenticationClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/doc.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/doc.go index 1e6a8ff..5616c95 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/doc.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -// This package is generated by client-gen with the default arguments. +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] // This package has the automatically generated typed clients. -package unversioned +package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/generated_expansion.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/generated_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/generated_expansion.go index a12d6f3..f307100 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/generated_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/generated_expansion.go @@ -14,8 +14,6 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 -type JobExpansion interface{} - -type ScheduledJobExpansion interface{} +type TokenReviewExpansion interface{} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/tokenreviews.go b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/tokenreview.go similarity index 56% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/tokenreviews.go rename to vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/tokenreview.go index 91c6bb6..8442ec6 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/tokenreviews.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/authentication/v1beta1/tokenreview.go @@ -14,36 +14,31 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - "k8s.io/kubernetes/pkg/apis/authentication" + rest "k8s.io/client-go/rest" ) -// TokenReviews has methods to work with TokenReview resources in a namespace -type TokenReviewsInterface interface { +// TokenReviewsGetter has a method to return a TokenReviewInterface. +// A group's client should implement this interface. +type TokenReviewsGetter interface { TokenReviews() TokenReviewInterface } // TokenReviewInterface has methods to work with TokenReview resources. type TokenReviewInterface interface { - Create(tokenReview *authentication.TokenReview) (*authentication.TokenReview, error) + TokenReviewExpansion } -// tokenReviews implements TokenReviewsNamespacer interface +// tokenReviews implements TokenReviewInterface type tokenReviews struct { - client *AuthenticationClient + client rest.Interface } -// newTokenReviews returns a tokenReviews +// newTokenReviews returns a TokenReviews func newTokenReviews(c *AuthenticationClient) *tokenReviews { return &tokenReviews{ - client: c, + client: c.RESTClient(), } } - -func (c *tokenReviews) Create(obj *authentication.TokenReview) (result *authentication.TokenReview, err error) { - result = &authentication.TokenReview{} - err = c.client.Post().Resource("tokenreviews").Body(obj).Do().Into(result) - return -} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/authorization_client.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/authorization_client.go new file mode 100644 index 0000000..a57434d --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/authorization_client.go @@ -0,0 +1,106 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type AuthorizationInterface interface { + RESTClient() rest.Interface + LocalSubjectAccessReviewsGetter + SelfSubjectAccessReviewsGetter + SubjectAccessReviewsGetter +} + +// AuthorizationClient is used to interact with features provided by the Authorization group. +type AuthorizationClient struct { + restClient rest.Interface +} + +func (c *AuthorizationClient) LocalSubjectAccessReviews(namespace string) LocalSubjectAccessReviewInterface { + return newLocalSubjectAccessReviews(c, namespace) +} + +func (c *AuthorizationClient) SelfSubjectAccessReviews() SelfSubjectAccessReviewInterface { + return newSelfSubjectAccessReviews(c) +} + +func (c *AuthorizationClient) SubjectAccessReviews() SubjectAccessReviewInterface { + return newSubjectAccessReviews(c) +} + +// NewForConfig creates a new AuthorizationClient for the given config. +func NewForConfig(c *rest.Config) (*AuthorizationClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &AuthorizationClient{client}, nil +} + +// NewForConfigOrDie creates a new AuthorizationClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *AuthorizationClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new AuthorizationClient for the given RESTClient. +func New(c rest.Interface) *AuthorizationClient { + return &AuthorizationClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if authorization group is not registered, return an error + g, err := registered.Group("authorization.k8s.io") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *AuthorizationClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/doc.go new file mode 100644 index 0000000..5616c95 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1beta1 diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/generated_expansion.go new file mode 100644 index 0000000..0e5d86e --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/generated_expansion.go @@ -0,0 +1,21 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +type LocalSubjectAccessReviewExpansion interface{} + +type SelfSubjectAccessReviewExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/localsubjectaccessreview.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/localsubjectaccessreview.go new file mode 100644 index 0000000..62cc83a --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/localsubjectaccessreview.go @@ -0,0 +1,46 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + rest "k8s.io/client-go/rest" +) + +// LocalSubjectAccessReviewsGetter has a method to return a LocalSubjectAccessReviewInterface. +// A group's client should implement this interface. +type LocalSubjectAccessReviewsGetter interface { + LocalSubjectAccessReviews(namespace string) LocalSubjectAccessReviewInterface +} + +// LocalSubjectAccessReviewInterface has methods to work with LocalSubjectAccessReview resources. +type LocalSubjectAccessReviewInterface interface { + LocalSubjectAccessReviewExpansion +} + +// localSubjectAccessReviews implements LocalSubjectAccessReviewInterface +type localSubjectAccessReviews struct { + client rest.Interface + ns string +} + +// newLocalSubjectAccessReviews returns a LocalSubjectAccessReviews +func newLocalSubjectAccessReviews(c *AuthorizationClient, namespace string) *localSubjectAccessReviews { + return &localSubjectAccessReviews{ + client: c.RESTClient(), + ns: namespace, + } +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/selfsubjectaccessreview.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/selfsubjectaccessreview.go new file mode 100644 index 0000000..4a3273d --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/selfsubjectaccessreview.go @@ -0,0 +1,44 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + rest "k8s.io/client-go/rest" +) + +// SelfSubjectAccessReviewsGetter has a method to return a SelfSubjectAccessReviewInterface. +// A group's client should implement this interface. +type SelfSubjectAccessReviewsGetter interface { + SelfSubjectAccessReviews() SelfSubjectAccessReviewInterface +} + +// SelfSubjectAccessReviewInterface has methods to work with SelfSubjectAccessReview resources. +type SelfSubjectAccessReviewInterface interface { + SelfSubjectAccessReviewExpansion +} + +// selfSubjectAccessReviews implements SelfSubjectAccessReviewInterface +type selfSubjectAccessReviews struct { + client rest.Interface +} + +// newSelfSubjectAccessReviews returns a SelfSubjectAccessReviews +func newSelfSubjectAccessReviews(c *AuthorizationClient) *selfSubjectAccessReviews { + return &selfSubjectAccessReviews{ + client: c.RESTClient(), + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/subjectaccessreview.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview.go similarity index 56% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/subjectaccessreview.go rename to vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview.go index b7a2c59..9e1fe96 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/subjectaccessreview.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview.go @@ -1,5 +1,5 @@ /* -Copyright 2015 The Kubernetes Authors. +Copyright 2016 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. @@ -14,32 +14,31 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - "k8s.io/kubernetes/pkg/apis/authorization" + rest "k8s.io/client-go/rest" ) -type SubjectAccessReviewsInterface interface { +// SubjectAccessReviewsGetter has a method to return a SubjectAccessReviewInterface. +// A group's client should implement this interface. +type SubjectAccessReviewsGetter interface { SubjectAccessReviews() SubjectAccessReviewInterface } +// SubjectAccessReviewInterface has methods to work with SubjectAccessReview resources. type SubjectAccessReviewInterface interface { - Create(subjectAccessReview *authorization.SubjectAccessReview) (*authorization.SubjectAccessReview, error) + SubjectAccessReviewExpansion } +// subjectAccessReviews implements SubjectAccessReviewInterface type subjectAccessReviews struct { - client *AuthorizationClient + client rest.Interface } +// newSubjectAccessReviews returns a SubjectAccessReviews func newSubjectAccessReviews(c *AuthorizationClient) *subjectAccessReviews { return &subjectAccessReviews{ - client: c, + client: c.RESTClient(), } } - -func (c *subjectAccessReviews) Create(subjectAccessReview *authorization.SubjectAccessReview) (result *authorization.SubjectAccessReview, err error) { - result = &authorization.SubjectAccessReview{} - err = c.client.Post().Resource("subjectAccessReviews").Body(subjectAccessReview).Do().Into(result) - return -} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview_expansion.go new file mode 100644 index 0000000..8d03b08 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/authorization/v1beta1/subjectaccessreview_expansion.go @@ -0,0 +1,36 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + authorizationapi "k8s.io/client-go/pkg/apis/authorization/v1beta1" +) + +// The SubjectAccessReviewExpansion interface allows manually adding extra methods to the AuthorizationInterface. +type SubjectAccessReviewExpansion interface { + Create(sar *authorizationapi.SubjectAccessReview) (result *authorizationapi.SubjectAccessReview, err error) +} + +func (c *subjectAccessReviews) Create(sar *authorizationapi.SubjectAccessReview) (result *authorizationapi.SubjectAccessReview, err error) { + result = &authorizationapi.SubjectAccessReview{} + err = c.client.Post(). + Resource("subjectaccessreviews"). + Body(sar). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/autoscaling_client.go b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/autoscaling_client.go new file mode 100644 index 0000000..406916d --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/autoscaling_client.go @@ -0,0 +1,96 @@ +/* +Copyright 2016 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. +*/ + +package v1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type AutoscalingInterface interface { + RESTClient() rest.Interface + HorizontalPodAutoscalersGetter +} + +// AutoscalingClient is used to interact with features provided by the Autoscaling group. +type AutoscalingClient struct { + restClient rest.Interface +} + +func (c *AutoscalingClient) HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface { + return newHorizontalPodAutoscalers(c, namespace) +} + +// NewForConfig creates a new AutoscalingClient for the given config. +func NewForConfig(c *rest.Config) (*AutoscalingClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &AutoscalingClient{client}, nil +} + +// NewForConfigOrDie creates a new AutoscalingClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *AutoscalingClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new AutoscalingClient for the given RESTClient. +func New(c rest.Interface) *AutoscalingClient { + return &AutoscalingClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if autoscaling group is not registered, return an error + g, err := registered.Group("autoscaling") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *AutoscalingClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/doc.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/doc.go index 1e6a8ff..fe27cf5 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/doc.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -// This package is generated by client-gen with the default arguments. +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] // This package has the automatically generated typed clients. -package unversioned +package v1 diff --git a/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/generated_expansion.go new file mode 100644 index 0000000..3e37a64 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/generated_expansion.go @@ -0,0 +1,19 @@ +/* +Copyright 2016 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. +*/ + +package v1 + +type HorizontalPodAutoscalerExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/horizontalpodautoscaler.go b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/horizontalpodautoscaler.go new file mode 100644 index 0000000..ed44db7 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/autoscaling/v1/horizontalpodautoscaler.go @@ -0,0 +1,167 @@ +/* +Copyright 2016 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. +*/ + +package v1 + +import ( + api "k8s.io/client-go/pkg/api" + api_v1 "k8s.io/client-go/pkg/api/v1" + v1 "k8s.io/client-go/pkg/apis/autoscaling/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// HorizontalPodAutoscalersGetter has a method to return a HorizontalPodAutoscalerInterface. +// A group's client should implement this interface. +type HorizontalPodAutoscalersGetter interface { + HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface +} + +// HorizontalPodAutoscalerInterface has methods to work with HorizontalPodAutoscaler resources. +type HorizontalPodAutoscalerInterface interface { + Create(*v1.HorizontalPodAutoscaler) (*v1.HorizontalPodAutoscaler, error) + Update(*v1.HorizontalPodAutoscaler) (*v1.HorizontalPodAutoscaler, error) + UpdateStatus(*v1.HorizontalPodAutoscaler) (*v1.HorizontalPodAutoscaler, error) + Delete(name string, options *api_v1.DeleteOptions) error + DeleteCollection(options *api_v1.DeleteOptions, listOptions api_v1.ListOptions) error + Get(name string) (*v1.HorizontalPodAutoscaler, error) + List(opts api_v1.ListOptions) (*v1.HorizontalPodAutoscalerList, error) + Watch(opts api_v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.HorizontalPodAutoscaler, err error) + HorizontalPodAutoscalerExpansion +} + +// horizontalPodAutoscalers implements HorizontalPodAutoscalerInterface +type horizontalPodAutoscalers struct { + client rest.Interface + ns string +} + +// newHorizontalPodAutoscalers returns a HorizontalPodAutoscalers +func newHorizontalPodAutoscalers(c *AutoscalingClient, namespace string) *horizontalPodAutoscalers { + return &horizontalPodAutoscalers{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a horizontalPodAutoscaler and creates it. Returns the server's representation of the horizontalPodAutoscaler, and an error, if there is any. +func (c *horizontalPodAutoscalers) Create(horizontalPodAutoscaler *v1.HorizontalPodAutoscaler) (result *v1.HorizontalPodAutoscaler, err error) { + result = &v1.HorizontalPodAutoscaler{} + err = c.client.Post(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + Body(horizontalPodAutoscaler). + Do(). + Into(result) + return +} + +// Update takes the representation of a horizontalPodAutoscaler and updates it. Returns the server's representation of the horizontalPodAutoscaler, and an error, if there is any. +func (c *horizontalPodAutoscalers) Update(horizontalPodAutoscaler *v1.HorizontalPodAutoscaler) (result *v1.HorizontalPodAutoscaler, err error) { + result = &v1.HorizontalPodAutoscaler{} + err = c.client.Put(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + Name(horizontalPodAutoscaler.Name). + Body(horizontalPodAutoscaler). + Do(). + Into(result) + return +} + +func (c *horizontalPodAutoscalers) UpdateStatus(horizontalPodAutoscaler *v1.HorizontalPodAutoscaler) (result *v1.HorizontalPodAutoscaler, err error) { + result = &v1.HorizontalPodAutoscaler{} + err = c.client.Put(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + Name(horizontalPodAutoscaler.Name). + SubResource("status"). + Body(horizontalPodAutoscaler). + Do(). + Into(result) + return +} + +// Delete takes name of the horizontalPodAutoscaler and deletes it. Returns an error if one occurs. +func (c *horizontalPodAutoscalers) Delete(name string, options *api_v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *horizontalPodAutoscalers) DeleteCollection(options *api_v1.DeleteOptions, listOptions api_v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the horizontalPodAutoscaler, and returns the corresponding horizontalPodAutoscaler object, and an error if there is any. +func (c *horizontalPodAutoscalers) Get(name string) (result *v1.HorizontalPodAutoscaler, err error) { + result = &v1.HorizontalPodAutoscaler{} + err = c.client.Get(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of HorizontalPodAutoscalers that match those selectors. +func (c *horizontalPodAutoscalers) List(opts api_v1.ListOptions) (result *v1.HorizontalPodAutoscalerList, err error) { + result = &v1.HorizontalPodAutoscalerList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested horizontalPodAutoscalers. +func (c *horizontalPodAutoscalers) Watch(opts api_v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched horizontalPodAutoscaler. +func (c *horizontalPodAutoscalers) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.HorizontalPodAutoscaler, err error) { + result = &v1.HorizontalPodAutoscaler{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("horizontalpodautoscalers"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/batch_client.go b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/batch_client.go similarity index 58% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/batch_client.go rename to vendor/k8s.io/client-go/kubernetes/typed/batch/v1/batch_client.go index f924797..fb7ab36 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/batch_client.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/batch_client.go @@ -14,40 +14,36 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - registered "k8s.io/kubernetes/pkg/apimachinery/registered" - restclient "k8s.io/kubernetes/pkg/client/restclient" + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" ) type BatchInterface interface { - GetRESTClient() *restclient.RESTClient + RESTClient() rest.Interface JobsGetter - ScheduledJobsGetter } // BatchClient is used to interact with features provided by the Batch group. type BatchClient struct { - *restclient.RESTClient + restClient rest.Interface } func (c *BatchClient) Jobs(namespace string) JobInterface { return newJobs(c, namespace) } -func (c *BatchClient) ScheduledJobs(namespace string) ScheduledJobInterface { - return newScheduledJobs(c, namespace) -} - // NewForConfig creates a new BatchClient for the given config. -func NewForConfig(c *restclient.Config) (*BatchClient, error) { +func NewForConfig(c *rest.Config) (*BatchClient, error) { config := *c if err := setConfigDefaults(&config); err != nil { return nil, err } - client, err := restclient.RESTClientFor(&config) + client, err := rest.RESTClientFor(&config) if err != nil { return nil, err } @@ -56,7 +52,7 @@ func NewForConfig(c *restclient.Config) (*BatchClient, error) { // NewForConfigOrDie creates a new BatchClient for the given config and // panics if there is an error in the config. -func NewForConfigOrDie(c *restclient.Config) *BatchClient { +func NewForConfigOrDie(c *rest.Config) *BatchClient { client, err := NewForConfig(c) if err != nil { panic(err) @@ -65,11 +61,11 @@ func NewForConfigOrDie(c *restclient.Config) *BatchClient { } // New creates a new BatchClient for the given RESTClient. -func New(c *restclient.RESTClient) *BatchClient { +func New(c rest.Interface) *BatchClient { return &BatchClient{c} } -func setConfigDefaults(config *restclient.Config) error { +func setConfigDefaults(config *rest.Config) error { // if batch group is not registered, return an error g, err := registered.Group("batch") if err != nil { @@ -77,28 +73,24 @@ func setConfigDefaults(config *restclient.Config) error { } config.APIPath = "/apis" if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() + config.UserAgent = rest.DefaultKubernetesUserAgent() } - if config.GroupVersion == nil || config.GroupVersion.Group != g.GroupVersion.Group { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - config.NegotiatedSerializer = api.Codecs + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} - if config.QPS == 0 { - config.QPS = 5 - } - if config.Burst == 0 { - config.Burst = 10 - } return nil } -// GetRESTClient returns a RESTClient that is used to communicate +// RESTClient returns a RESTClient that is used to communicate // with API server by this client implementation. -func (c *BatchClient) GetRESTClient() *restclient.RESTClient { +func (c *BatchClient) RESTClient() rest.Interface { if c == nil { return nil } - return c.RESTClient + return c.restClient } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/doc.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/batch/v1/doc.go index 1e6a8ff..fe27cf5 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/doc.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -// This package is generated by client-gen with the default arguments. +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] // This package has the automatically generated typed clients. -package unversioned +package v1 diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/generated_expansion.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/generated_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/batch/v1/generated_expansion.go index 552b3cf..b24faa3 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/generated_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/generated_expansion.go @@ -14,6 +14,6 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 -type PetSetExpansion interface{} +type JobExpansion interface{} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/job.go b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/job.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/job.go rename to vendor/k8s.io/client-go/kubernetes/typed/batch/v1/job.go index 8d209fb..5d7d9a2 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/job.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/batch/v1/job.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - batch "k8s.io/kubernetes/pkg/apis/batch" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + api_v1 "k8s.io/client-go/pkg/api/v1" + v1 "k8s.io/client-go/pkg/apis/batch/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // JobsGetter has a method to return a JobInterface. @@ -30,35 +32,35 @@ type JobsGetter interface { // JobInterface has methods to work with Job resources. type JobInterface interface { - Create(*batch.Job) (*batch.Job, error) - Update(*batch.Job) (*batch.Job, error) - UpdateStatus(*batch.Job) (*batch.Job, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*batch.Job, error) - List(opts api.ListOptions) (*batch.JobList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *batch.Job, err error) + Create(*v1.Job) (*v1.Job, error) + Update(*v1.Job) (*v1.Job, error) + UpdateStatus(*v1.Job) (*v1.Job, error) + Delete(name string, options *api_v1.DeleteOptions) error + DeleteCollection(options *api_v1.DeleteOptions, listOptions api_v1.ListOptions) error + Get(name string) (*v1.Job, error) + List(opts api_v1.ListOptions) (*v1.JobList, error) + Watch(opts api_v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Job, err error) JobExpansion } // jobs implements JobInterface type jobs struct { - client *BatchClient + client rest.Interface ns string } // newJobs returns a Jobs func newJobs(c *BatchClient, namespace string) *jobs { return &jobs{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a job and creates it. Returns the server's representation of the job, and an error, if there is any. -func (c *jobs) Create(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} +func (c *jobs) Create(job *v1.Job) (result *v1.Job, err error) { + result = &v1.Job{} err = c.client.Post(). Namespace(c.ns). Resource("jobs"). @@ -69,8 +71,8 @@ func (c *jobs) Create(job *batch.Job) (result *batch.Job, err error) { } // Update takes the representation of a job and updates it. Returns the server's representation of the job, and an error, if there is any. -func (c *jobs) Update(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} +func (c *jobs) Update(job *v1.Job) (result *v1.Job, err error) { + result = &v1.Job{} err = c.client.Put(). Namespace(c.ns). Resource("jobs"). @@ -81,8 +83,8 @@ func (c *jobs) Update(job *batch.Job) (result *batch.Job, err error) { return } -func (c *jobs) UpdateStatus(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} +func (c *jobs) UpdateStatus(job *v1.Job) (result *v1.Job, err error) { + result = &v1.Job{} err = c.client.Put(). Namespace(c.ns). Resource("jobs"). @@ -95,7 +97,7 @@ func (c *jobs) UpdateStatus(job *batch.Job) (result *batch.Job, err error) { } // Delete takes name of the job and deletes it. Returns an error if one occurs. -func (c *jobs) Delete(name string, options *api.DeleteOptions) error { +func (c *jobs) Delete(name string, options *api_v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("jobs"). @@ -106,7 +108,7 @@ func (c *jobs) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *jobs) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *jobs) DeleteCollection(options *api_v1.DeleteOptions, listOptions api_v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("jobs"). @@ -117,8 +119,8 @@ func (c *jobs) DeleteCollection(options *api.DeleteOptions, listOptions api.List } // Get takes name of the job, and returns the corresponding job object, and an error if there is any. -func (c *jobs) Get(name string) (result *batch.Job, err error) { - result = &batch.Job{} +func (c *jobs) Get(name string) (result *v1.Job, err error) { + result = &v1.Job{} err = c.client.Get(). Namespace(c.ns). Resource("jobs"). @@ -129,8 +131,8 @@ func (c *jobs) Get(name string) (result *batch.Job, err error) { } // List takes label and field selectors, and returns the list of Jobs that match those selectors. -func (c *jobs) List(opts api.ListOptions) (result *batch.JobList, err error) { - result = &batch.JobList{} +func (c *jobs) List(opts api_v1.ListOptions) (result *v1.JobList, err error) { + result = &v1.JobList{} err = c.client.Get(). Namespace(c.ns). Resource("jobs"). @@ -141,7 +143,7 @@ func (c *jobs) List(opts api.ListOptions) (result *batch.JobList, err error) { } // Watch returns a watch.Interface that watches the requested jobs. -func (c *jobs) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *jobs) Watch(opts api_v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -151,8 +153,8 @@ func (c *jobs) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched job. -func (c *jobs) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *batch.Job, err error) { - result = &batch.Job{} +func (c *jobs) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Job, err error) { + result = &v1.Job{} err = c.client.Patch(pt). Namespace(c.ns). Resource("jobs"). diff --git a/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificates_client.go b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificates_client.go new file mode 100644 index 0000000..872367e --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificates_client.go @@ -0,0 +1,96 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type CertificatesInterface interface { + RESTClient() rest.Interface + CertificateSigningRequestsGetter +} + +// CertificatesClient is used to interact with features provided by the Certificates group. +type CertificatesClient struct { + restClient rest.Interface +} + +func (c *CertificatesClient) CertificateSigningRequests() CertificateSigningRequestInterface { + return newCertificateSigningRequests(c) +} + +// NewForConfig creates a new CertificatesClient for the given config. +func NewForConfig(c *rest.Config) (*CertificatesClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &CertificatesClient{client}, nil +} + +// NewForConfigOrDie creates a new CertificatesClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *CertificatesClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new CertificatesClient for the given RESTClient. +func New(c rest.Interface) *CertificatesClient { + return &CertificatesClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if certificates group is not registered, return an error + g, err := registered.Group("certificates.k8s.io") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *CertificatesClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificatesigningrequest.go b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificatesigningrequest.go new file mode 100644 index 0000000..1726874 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/certificatesigningrequest.go @@ -0,0 +1,156 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/certificates/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// CertificateSigningRequestsGetter has a method to return a CertificateSigningRequestInterface. +// A group's client should implement this interface. +type CertificateSigningRequestsGetter interface { + CertificateSigningRequests() CertificateSigningRequestInterface +} + +// CertificateSigningRequestInterface has methods to work with CertificateSigningRequest resources. +type CertificateSigningRequestInterface interface { + Create(*v1alpha1.CertificateSigningRequest) (*v1alpha1.CertificateSigningRequest, error) + Update(*v1alpha1.CertificateSigningRequest) (*v1alpha1.CertificateSigningRequest, error) + UpdateStatus(*v1alpha1.CertificateSigningRequest) (*v1alpha1.CertificateSigningRequest, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.CertificateSigningRequest, error) + List(opts v1.ListOptions) (*v1alpha1.CertificateSigningRequestList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.CertificateSigningRequest, err error) + CertificateSigningRequestExpansion +} + +// certificateSigningRequests implements CertificateSigningRequestInterface +type certificateSigningRequests struct { + client rest.Interface +} + +// newCertificateSigningRequests returns a CertificateSigningRequests +func newCertificateSigningRequests(c *CertificatesClient) *certificateSigningRequests { + return &certificateSigningRequests{ + client: c.RESTClient(), + } +} + +// Create takes the representation of a certificateSigningRequest and creates it. Returns the server's representation of the certificateSigningRequest, and an error, if there is any. +func (c *certificateSigningRequests) Create(certificateSigningRequest *v1alpha1.CertificateSigningRequest) (result *v1alpha1.CertificateSigningRequest, err error) { + result = &v1alpha1.CertificateSigningRequest{} + err = c.client.Post(). + Resource("certificatesigningrequests"). + Body(certificateSigningRequest). + Do(). + Into(result) + return +} + +// Update takes the representation of a certificateSigningRequest and updates it. Returns the server's representation of the certificateSigningRequest, and an error, if there is any. +func (c *certificateSigningRequests) Update(certificateSigningRequest *v1alpha1.CertificateSigningRequest) (result *v1alpha1.CertificateSigningRequest, err error) { + result = &v1alpha1.CertificateSigningRequest{} + err = c.client.Put(). + Resource("certificatesigningrequests"). + Name(certificateSigningRequest.Name). + Body(certificateSigningRequest). + Do(). + Into(result) + return +} + +func (c *certificateSigningRequests) UpdateStatus(certificateSigningRequest *v1alpha1.CertificateSigningRequest) (result *v1alpha1.CertificateSigningRequest, err error) { + result = &v1alpha1.CertificateSigningRequest{} + err = c.client.Put(). + Resource("certificatesigningrequests"). + Name(certificateSigningRequest.Name). + SubResource("status"). + Body(certificateSigningRequest). + Do(). + Into(result) + return +} + +// Delete takes name of the certificateSigningRequest and deletes it. Returns an error if one occurs. +func (c *certificateSigningRequests) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Resource("certificatesigningrequests"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *certificateSigningRequests) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Resource("certificatesigningrequests"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the certificateSigningRequest, and returns the corresponding certificateSigningRequest object, and an error if there is any. +func (c *certificateSigningRequests) Get(name string) (result *v1alpha1.CertificateSigningRequest, err error) { + result = &v1alpha1.CertificateSigningRequest{} + err = c.client.Get(). + Resource("certificatesigningrequests"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of CertificateSigningRequests that match those selectors. +func (c *certificateSigningRequests) List(opts v1.ListOptions) (result *v1alpha1.CertificateSigningRequestList, err error) { + result = &v1alpha1.CertificateSigningRequestList{} + err = c.client.Get(). + Resource("certificatesigningrequests"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested certificateSigningRequests. +func (c *certificateSigningRequests) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Resource("certificatesigningrequests"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched certificateSigningRequest. +func (c *certificateSigningRequests) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.CertificateSigningRequest, err error) { + result = &v1alpha1.CertificateSigningRequest{} + err = c.client.Patch(pt). + Resource("certificatesigningrequests"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/doc.go new file mode 100644 index 0000000..0c1ca41 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1alpha1 diff --git a/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/generated_expansion.go new file mode 100644 index 0000000..1f67dc9 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/certificates/v1alpha1/generated_expansion.go @@ -0,0 +1,19 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +type CertificateSigningRequestExpansion interface{} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/componentstatus.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/componentstatus.go similarity index 67% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/componentstatus.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/componentstatus.go index ffdaeb4..cf9896e 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/componentstatus.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/componentstatus.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ComponentStatusesGetter has a method to return a ComponentStatusInterface. @@ -29,32 +31,32 @@ type ComponentStatusesGetter interface { // ComponentStatusInterface has methods to work with ComponentStatus resources. type ComponentStatusInterface interface { - Create(*api.ComponentStatus) (*api.ComponentStatus, error) - Update(*api.ComponentStatus) (*api.ComponentStatus, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.ComponentStatus, error) - List(opts api.ListOptions) (*api.ComponentStatusList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ComponentStatus, err error) + Create(*v1.ComponentStatus) (*v1.ComponentStatus, error) + Update(*v1.ComponentStatus) (*v1.ComponentStatus, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.ComponentStatus, error) + List(opts v1.ListOptions) (*v1.ComponentStatusList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ComponentStatus, err error) ComponentStatusExpansion } // componentStatuses implements ComponentStatusInterface type componentStatuses struct { - client *CoreClient + client rest.Interface } // newComponentStatuses returns a ComponentStatuses func newComponentStatuses(c *CoreClient) *componentStatuses { return &componentStatuses{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a componentStatus and creates it. Returns the server's representation of the componentStatus, and an error, if there is any. -func (c *componentStatuses) Create(componentStatus *api.ComponentStatus) (result *api.ComponentStatus, err error) { - result = &api.ComponentStatus{} +func (c *componentStatuses) Create(componentStatus *v1.ComponentStatus) (result *v1.ComponentStatus, err error) { + result = &v1.ComponentStatus{} err = c.client.Post(). Resource("componentstatuses"). Body(componentStatus). @@ -64,8 +66,8 @@ func (c *componentStatuses) Create(componentStatus *api.ComponentStatus) (result } // Update takes the representation of a componentStatus and updates it. Returns the server's representation of the componentStatus, and an error, if there is any. -func (c *componentStatuses) Update(componentStatus *api.ComponentStatus) (result *api.ComponentStatus, err error) { - result = &api.ComponentStatus{} +func (c *componentStatuses) Update(componentStatus *v1.ComponentStatus) (result *v1.ComponentStatus, err error) { + result = &v1.ComponentStatus{} err = c.client.Put(). Resource("componentstatuses"). Name(componentStatus.Name). @@ -76,7 +78,7 @@ func (c *componentStatuses) Update(componentStatus *api.ComponentStatus) (result } // Delete takes name of the componentStatus and deletes it. Returns an error if one occurs. -func (c *componentStatuses) Delete(name string, options *api.DeleteOptions) error { +func (c *componentStatuses) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("componentstatuses"). Name(name). @@ -86,7 +88,7 @@ func (c *componentStatuses) Delete(name string, options *api.DeleteOptions) erro } // DeleteCollection deletes a collection of objects. -func (c *componentStatuses) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *componentStatuses) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("componentstatuses"). VersionedParams(&listOptions, api.ParameterCodec). @@ -96,8 +98,8 @@ func (c *componentStatuses) DeleteCollection(options *api.DeleteOptions, listOpt } // Get takes name of the componentStatus, and returns the corresponding componentStatus object, and an error if there is any. -func (c *componentStatuses) Get(name string) (result *api.ComponentStatus, err error) { - result = &api.ComponentStatus{} +func (c *componentStatuses) Get(name string) (result *v1.ComponentStatus, err error) { + result = &v1.ComponentStatus{} err = c.client.Get(). Resource("componentstatuses"). Name(name). @@ -107,8 +109,8 @@ func (c *componentStatuses) Get(name string) (result *api.ComponentStatus, err e } // List takes label and field selectors, and returns the list of ComponentStatuses that match those selectors. -func (c *componentStatuses) List(opts api.ListOptions) (result *api.ComponentStatusList, err error) { - result = &api.ComponentStatusList{} +func (c *componentStatuses) List(opts v1.ListOptions) (result *v1.ComponentStatusList, err error) { + result = &v1.ComponentStatusList{} err = c.client.Get(). Resource("componentstatuses"). VersionedParams(&opts, api.ParameterCodec). @@ -118,7 +120,7 @@ func (c *componentStatuses) List(opts api.ListOptions) (result *api.ComponentSta } // Watch returns a watch.Interface that watches the requested componentStatuses. -func (c *componentStatuses) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *componentStatuses) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("componentstatuses"). @@ -127,8 +129,8 @@ func (c *componentStatuses) Watch(opts api.ListOptions) (watch.Interface, error) } // Patch applies the patch and returns the patched componentStatus. -func (c *componentStatuses) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ComponentStatus, err error) { - result = &api.ComponentStatus{} +func (c *componentStatuses) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ComponentStatus, err error) { + result = &v1.ComponentStatus{} err = c.client.Patch(pt). Resource("componentstatuses"). SubResource(subresources...). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/configmap.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/configmap.go similarity index 69% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/configmap.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/configmap.go index c937328..88573f1 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/configmap.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/configmap.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ConfigMapsGetter has a method to return a ConfigMapInterface. @@ -29,34 +31,34 @@ type ConfigMapsGetter interface { // ConfigMapInterface has methods to work with ConfigMap resources. type ConfigMapInterface interface { - Create(*api.ConfigMap) (*api.ConfigMap, error) - Update(*api.ConfigMap) (*api.ConfigMap, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.ConfigMap, error) - List(opts api.ListOptions) (*api.ConfigMapList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ConfigMap, err error) + Create(*v1.ConfigMap) (*v1.ConfigMap, error) + Update(*v1.ConfigMap) (*v1.ConfigMap, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.ConfigMap, error) + List(opts v1.ListOptions) (*v1.ConfigMapList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ConfigMap, err error) ConfigMapExpansion } // configMaps implements ConfigMapInterface type configMaps struct { - client *CoreClient + client rest.Interface ns string } // newConfigMaps returns a ConfigMaps func newConfigMaps(c *CoreClient, namespace string) *configMaps { return &configMaps{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a configMap and creates it. Returns the server's representation of the configMap, and an error, if there is any. -func (c *configMaps) Create(configMap *api.ConfigMap) (result *api.ConfigMap, err error) { - result = &api.ConfigMap{} +func (c *configMaps) Create(configMap *v1.ConfigMap) (result *v1.ConfigMap, err error) { + result = &v1.ConfigMap{} err = c.client.Post(). Namespace(c.ns). Resource("configmaps"). @@ -67,8 +69,8 @@ func (c *configMaps) Create(configMap *api.ConfigMap) (result *api.ConfigMap, er } // Update takes the representation of a configMap and updates it. Returns the server's representation of the configMap, and an error, if there is any. -func (c *configMaps) Update(configMap *api.ConfigMap) (result *api.ConfigMap, err error) { - result = &api.ConfigMap{} +func (c *configMaps) Update(configMap *v1.ConfigMap) (result *v1.ConfigMap, err error) { + result = &v1.ConfigMap{} err = c.client.Put(). Namespace(c.ns). Resource("configmaps"). @@ -80,7 +82,7 @@ func (c *configMaps) Update(configMap *api.ConfigMap) (result *api.ConfigMap, er } // Delete takes name of the configMap and deletes it. Returns an error if one occurs. -func (c *configMaps) Delete(name string, options *api.DeleteOptions) error { +func (c *configMaps) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("configmaps"). @@ -91,7 +93,7 @@ func (c *configMaps) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *configMaps) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *configMaps) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("configmaps"). @@ -102,8 +104,8 @@ func (c *configMaps) DeleteCollection(options *api.DeleteOptions, listOptions ap } // Get takes name of the configMap, and returns the corresponding configMap object, and an error if there is any. -func (c *configMaps) Get(name string) (result *api.ConfigMap, err error) { - result = &api.ConfigMap{} +func (c *configMaps) Get(name string) (result *v1.ConfigMap, err error) { + result = &v1.ConfigMap{} err = c.client.Get(). Namespace(c.ns). Resource("configmaps"). @@ -114,8 +116,8 @@ func (c *configMaps) Get(name string) (result *api.ConfigMap, err error) { } // List takes label and field selectors, and returns the list of ConfigMaps that match those selectors. -func (c *configMaps) List(opts api.ListOptions) (result *api.ConfigMapList, err error) { - result = &api.ConfigMapList{} +func (c *configMaps) List(opts v1.ListOptions) (result *v1.ConfigMapList, err error) { + result = &v1.ConfigMapList{} err = c.client.Get(). Namespace(c.ns). Resource("configmaps"). @@ -126,7 +128,7 @@ func (c *configMaps) List(opts api.ListOptions) (result *api.ConfigMapList, err } // Watch returns a watch.Interface that watches the requested configMaps. -func (c *configMaps) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *configMaps) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *configMaps) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched configMap. -func (c *configMaps) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ConfigMap, err error) { - result = &api.ConfigMap{} +func (c *configMaps) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ConfigMap, err error) { + result = &v1.ConfigMap{} err = c.client.Patch(pt). Namespace(c.ns). Resource("configmaps"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/core_client.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/core_client.go similarity index 77% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/core_client.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/core_client.go index e44eaf8..c01c7c2 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/core_client.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/core_client.go @@ -14,16 +14,17 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - registered "k8s.io/kubernetes/pkg/apimachinery/registered" - restclient "k8s.io/kubernetes/pkg/client/restclient" + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" ) type CoreInterface interface { - GetRESTClient() *restclient.RESTClient + RESTClient() rest.Interface ComponentStatusesGetter ConfigMapsGetter EndpointsGetter @@ -44,7 +45,7 @@ type CoreInterface interface { // CoreClient is used to interact with features provided by the Core group. type CoreClient struct { - *restclient.RESTClient + restClient rest.Interface } func (c *CoreClient) ComponentStatuses() ComponentStatusInterface { @@ -112,12 +113,12 @@ func (c *CoreClient) ServiceAccounts(namespace string) ServiceAccountInterface { } // NewForConfig creates a new CoreClient for the given config. -func NewForConfig(c *restclient.Config) (*CoreClient, error) { +func NewForConfig(c *rest.Config) (*CoreClient, error) { config := *c if err := setConfigDefaults(&config); err != nil { return nil, err } - client, err := restclient.RESTClientFor(&config) + client, err := rest.RESTClientFor(&config) if err != nil { return nil, err } @@ -126,7 +127,7 @@ func NewForConfig(c *restclient.Config) (*CoreClient, error) { // NewForConfigOrDie creates a new CoreClient for the given config and // panics if there is an error in the config. -func NewForConfigOrDie(c *restclient.Config) *CoreClient { +func NewForConfigOrDie(c *rest.Config) *CoreClient { client, err := NewForConfig(c) if err != nil { panic(err) @@ -135,11 +136,11 @@ func NewForConfigOrDie(c *restclient.Config) *CoreClient { } // New creates a new CoreClient for the given RESTClient. -func New(c *restclient.RESTClient) *CoreClient { +func New(c rest.Interface) *CoreClient { return &CoreClient{c} } -func setConfigDefaults(config *restclient.Config) error { +func setConfigDefaults(config *rest.Config) error { // if core group is not registered, return an error g, err := registered.Group("") if err != nil { @@ -147,28 +148,24 @@ func setConfigDefaults(config *restclient.Config) error { } config.APIPath = "/api" if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() + config.UserAgent = rest.DefaultKubernetesUserAgent() } - if config.GroupVersion == nil || config.GroupVersion.Group != g.GroupVersion.Group { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - config.NegotiatedSerializer = api.Codecs + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} - if config.QPS == 0 { - config.QPS = 5 - } - if config.Burst == 0 { - config.Burst = 10 - } return nil } -// GetRESTClient returns a RESTClient that is used to communicate +// RESTClient returns a RESTClient that is used to communicate // with API server by this client implementation. -func (c *CoreClient) GetRESTClient() *restclient.RESTClient { +func (c *CoreClient) RESTClient() rest.Interface { if c == nil { return nil } - return c.RESTClient + return c.restClient } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/doc.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/doc.go index 1e6a8ff..fe27cf5 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/doc.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -// This package is generated by client-gen with the default arguments. +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] // This package has the automatically generated typed clients. -package unversioned +package v1 diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/endpoints.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/endpoints.go similarity index 69% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/endpoints.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/endpoints.go index d5f383d..92d03b7 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/endpoints.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/endpoints.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // EndpointsGetter has a method to return a EndpointsInterface. @@ -29,34 +31,34 @@ type EndpointsGetter interface { // EndpointsInterface has methods to work with Endpoints resources. type EndpointsInterface interface { - Create(*api.Endpoints) (*api.Endpoints, error) - Update(*api.Endpoints) (*api.Endpoints, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Endpoints, error) - List(opts api.ListOptions) (*api.EndpointsList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Endpoints, err error) + Create(*v1.Endpoints) (*v1.Endpoints, error) + Update(*v1.Endpoints) (*v1.Endpoints, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Endpoints, error) + List(opts v1.ListOptions) (*v1.EndpointsList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Endpoints, err error) EndpointsExpansion } // endpoints implements EndpointsInterface type endpoints struct { - client *CoreClient + client rest.Interface ns string } // newEndpoints returns a Endpoints func newEndpoints(c *CoreClient, namespace string) *endpoints { return &endpoints{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a endpoints and creates it. Returns the server's representation of the endpoints, and an error, if there is any. -func (c *endpoints) Create(endpoints *api.Endpoints) (result *api.Endpoints, err error) { - result = &api.Endpoints{} +func (c *endpoints) Create(endpoints *v1.Endpoints) (result *v1.Endpoints, err error) { + result = &v1.Endpoints{} err = c.client.Post(). Namespace(c.ns). Resource("endpoints"). @@ -67,8 +69,8 @@ func (c *endpoints) Create(endpoints *api.Endpoints) (result *api.Endpoints, err } // Update takes the representation of a endpoints and updates it. Returns the server's representation of the endpoints, and an error, if there is any. -func (c *endpoints) Update(endpoints *api.Endpoints) (result *api.Endpoints, err error) { - result = &api.Endpoints{} +func (c *endpoints) Update(endpoints *v1.Endpoints) (result *v1.Endpoints, err error) { + result = &v1.Endpoints{} err = c.client.Put(). Namespace(c.ns). Resource("endpoints"). @@ -80,7 +82,7 @@ func (c *endpoints) Update(endpoints *api.Endpoints) (result *api.Endpoints, err } // Delete takes name of the endpoints and deletes it. Returns an error if one occurs. -func (c *endpoints) Delete(name string, options *api.DeleteOptions) error { +func (c *endpoints) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("endpoints"). @@ -91,7 +93,7 @@ func (c *endpoints) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *endpoints) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *endpoints) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("endpoints"). @@ -102,8 +104,8 @@ func (c *endpoints) DeleteCollection(options *api.DeleteOptions, listOptions api } // Get takes name of the endpoints, and returns the corresponding endpoints object, and an error if there is any. -func (c *endpoints) Get(name string) (result *api.Endpoints, err error) { - result = &api.Endpoints{} +func (c *endpoints) Get(name string) (result *v1.Endpoints, err error) { + result = &v1.Endpoints{} err = c.client.Get(). Namespace(c.ns). Resource("endpoints"). @@ -114,8 +116,8 @@ func (c *endpoints) Get(name string) (result *api.Endpoints, err error) { } // List takes label and field selectors, and returns the list of Endpoints that match those selectors. -func (c *endpoints) List(opts api.ListOptions) (result *api.EndpointsList, err error) { - result = &api.EndpointsList{} +func (c *endpoints) List(opts v1.ListOptions) (result *v1.EndpointsList, err error) { + result = &v1.EndpointsList{} err = c.client.Get(). Namespace(c.ns). Resource("endpoints"). @@ -126,7 +128,7 @@ func (c *endpoints) List(opts api.ListOptions) (result *api.EndpointsList, err e } // Watch returns a watch.Interface that watches the requested endpoints. -func (c *endpoints) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *endpoints) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *endpoints) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched endpoints. -func (c *endpoints) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Endpoints, err error) { - result = &api.Endpoints{} +func (c *endpoints) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Endpoints, err error) { + result = &v1.Endpoints{} err = c.client.Patch(pt). Namespace(c.ns). Resource("endpoints"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/event.go similarity index 70% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/event.go index d4edcd3..fcd37e2 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/event.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // EventsGetter has a method to return a EventInterface. @@ -29,34 +31,34 @@ type EventsGetter interface { // EventInterface has methods to work with Event resources. type EventInterface interface { - Create(*api.Event) (*api.Event, error) - Update(*api.Event) (*api.Event, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Event, error) - List(opts api.ListOptions) (*api.EventList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Event, err error) + Create(*v1.Event) (*v1.Event, error) + Update(*v1.Event) (*v1.Event, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Event, error) + List(opts v1.ListOptions) (*v1.EventList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Event, err error) EventExpansion } // events implements EventInterface type events struct { - client *CoreClient + client rest.Interface ns string } // newEvents returns a Events func newEvents(c *CoreClient, namespace string) *events { return &events{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a event and creates it. Returns the server's representation of the event, and an error, if there is any. -func (c *events) Create(event *api.Event) (result *api.Event, err error) { - result = &api.Event{} +func (c *events) Create(event *v1.Event) (result *v1.Event, err error) { + result = &v1.Event{} err = c.client.Post(). Namespace(c.ns). Resource("events"). @@ -67,8 +69,8 @@ func (c *events) Create(event *api.Event) (result *api.Event, err error) { } // Update takes the representation of a event and updates it. Returns the server's representation of the event, and an error, if there is any. -func (c *events) Update(event *api.Event) (result *api.Event, err error) { - result = &api.Event{} +func (c *events) Update(event *v1.Event) (result *v1.Event, err error) { + result = &v1.Event{} err = c.client.Put(). Namespace(c.ns). Resource("events"). @@ -80,7 +82,7 @@ func (c *events) Update(event *api.Event) (result *api.Event, err error) { } // Delete takes name of the event and deletes it. Returns an error if one occurs. -func (c *events) Delete(name string, options *api.DeleteOptions) error { +func (c *events) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("events"). @@ -91,7 +93,7 @@ func (c *events) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *events) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *events) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("events"). @@ -102,8 +104,8 @@ func (c *events) DeleteCollection(options *api.DeleteOptions, listOptions api.Li } // Get takes name of the event, and returns the corresponding event object, and an error if there is any. -func (c *events) Get(name string) (result *api.Event, err error) { - result = &api.Event{} +func (c *events) Get(name string) (result *v1.Event, err error) { + result = &v1.Event{} err = c.client.Get(). Namespace(c.ns). Resource("events"). @@ -114,8 +116,8 @@ func (c *events) Get(name string) (result *api.Event, err error) { } // List takes label and field selectors, and returns the list of Events that match those selectors. -func (c *events) List(opts api.ListOptions) (result *api.EventList, err error) { - result = &api.EventList{} +func (c *events) List(opts v1.ListOptions) (result *v1.EventList, err error) { + result = &v1.EventList{} err = c.client.Get(). Namespace(c.ns). Resource("events"). @@ -126,7 +128,7 @@ func (c *events) List(opts api.ListOptions) (result *api.EventList, err error) { } // Watch returns a watch.Interface that watches the requested events. -func (c *events) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *events) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *events) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched event. -func (c *events) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Event, err error) { - result = &api.Event{} +func (c *events) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Event, err error) { + result = &v1.Event{} err = c.client.Patch(pt). Namespace(c.ns). Resource("events"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/event_expansion.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/event_expansion.go index f3d6f46..5a893ca 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/event_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/event_expansion.go @@ -14,25 +14,26 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/runtime" ) // The EventExpansion interface allows manually adding extra methods to the EventInterface. type EventExpansion interface { // CreateWithEventNamespace is the same as a Create, except that it sends the request to the event.Namespace. - CreateWithEventNamespace(event *api.Event) (*api.Event, error) + CreateWithEventNamespace(event *v1.Event) (*v1.Event, error) // UpdateWithEventNamespace is the same as a Update, except that it sends the request to the event.Namespace. - UpdateWithEventNamespace(event *api.Event) (*api.Event, error) - PatchWithEventNamespace(event *api.Event, data []byte) (*api.Event, error) + UpdateWithEventNamespace(event *v1.Event) (*v1.Event, error) + PatchWithEventNamespace(event *v1.Event, data []byte) (*v1.Event, error) // Search finds events about the specified object - Search(objOrRef runtime.Object) (*api.EventList, error) + Search(objOrRef runtime.Object) (*v1.EventList, error) // Returns the appropriate field selector based on the API version being used to communicate with the server. // The returned field selector can be used with List and Watch to filter desired events. GetFieldSelector(involvedObjectName, involvedObjectNamespace, involvedObjectKind, involvedObjectUID *string) fields.Selector @@ -42,11 +43,11 @@ type EventExpansion interface { // or an error. The namespace to create the event within is deduced from the // event; it must either match this event client's namespace, or this event // client must have been created with the "" namespace. -func (e *events) CreateWithEventNamespace(event *api.Event) (*api.Event, error) { +func (e *events) CreateWithEventNamespace(event *v1.Event) (*v1.Event, error) { if e.ns != "" && event.Namespace != e.ns { return nil, fmt.Errorf("can't create an event with namespace '%v' in namespace '%v'", event.Namespace, e.ns) } - result := &api.Event{} + result := &v1.Event{} err := e.client.Post(). NamespaceIfScoped(event.Namespace, len(event.Namespace) > 0). Resource("events"). @@ -61,8 +62,8 @@ func (e *events) CreateWithEventNamespace(event *api.Event) (*api.Event, error) // namespace must either match this event client's namespace, or this event client must have been // created with the "" namespace. Update also requires the ResourceVersion to be set in the event // object. -func (e *events) UpdateWithEventNamespace(event *api.Event) (*api.Event, error) { - result := &api.Event{} +func (e *events) UpdateWithEventNamespace(event *v1.Event) (*v1.Event, error) { + result := &v1.Event{} err := e.client.Put(). NamespaceIfScoped(event.Namespace, len(event.Namespace) > 0). Resource("events"). @@ -78,11 +79,11 @@ func (e *events) UpdateWithEventNamespace(event *api.Event) (*api.Event, error) // target event is deduced from the incompleteEvent. The namespace must either // match this event client's namespace, or this event client must have been // created with the "" namespace. -func (e *events) PatchWithEventNamespace(incompleteEvent *api.Event, data []byte) (*api.Event, error) { +func (e *events) PatchWithEventNamespace(incompleteEvent *v1.Event, data []byte) (*v1.Event, error) { if e.ns != "" && incompleteEvent.Namespace != e.ns { return nil, fmt.Errorf("can't patch an event with namespace '%v' in namespace '%v'", incompleteEvent.Namespace, e.ns) } - result := &api.Event{} + result := &v1.Event{} err := e.client.Patch(api.StrategicMergePatchType). NamespaceIfScoped(incompleteEvent.Namespace, len(incompleteEvent.Namespace) > 0). Resource("events"). @@ -96,7 +97,7 @@ func (e *events) PatchWithEventNamespace(incompleteEvent *api.Event, data []byte // Search finds events about the specified object. The namespace of the // object must match this event's client namespace unless the event client // was made with the "" namespace. -func (e *events) Search(objOrRef runtime.Object) (*api.EventList, error) { +func (e *events) Search(objOrRef runtime.Object) (*v1.EventList, error) { ref, err := api.GetReference(objOrRef) if err != nil { return nil, err @@ -115,7 +116,7 @@ func (e *events) Search(objOrRef runtime.Object) (*api.EventList, error) { refUID = &stringRefUID } fieldSelector := e.GetFieldSelector(&ref.Name, &ref.Namespace, refKind, refUID) - return e.List(api.ListOptions{FieldSelector: fieldSelector}) + return e.List(v1.ListOptions{FieldSelector: fieldSelector.String()}) } // Returns the appropriate field selector based on the API version being used to communicate with the server. @@ -148,14 +149,14 @@ type EventSinkImpl struct { Interface EventInterface } -func (e *EventSinkImpl) Create(event *api.Event) (*api.Event, error) { +func (e *EventSinkImpl) Create(event *v1.Event) (*v1.Event, error) { return e.Interface.CreateWithEventNamespace(event) } -func (e *EventSinkImpl) Update(event *api.Event) (*api.Event, error) { +func (e *EventSinkImpl) Update(event *v1.Event) (*v1.Event, error) { return e.Interface.UpdateWithEventNamespace(event) } -func (e *EventSinkImpl) Patch(event *api.Event, data []byte) (*api.Event, error) { +func (e *EventSinkImpl) Patch(event *v1.Event, data []byte) (*v1.Event, error) { return e.Interface.PatchWithEventNamespace(event, data) } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/generated_expansion.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/generated_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/generated_expansion.go index 2524115..0039ffd 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/generated_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/generated_expansion.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 type ComponentStatusExpansion interface{} @@ -24,6 +24,8 @@ type EndpointsExpansion interface{} type LimitRangeExpansion interface{} +type NodeExpansion interface{} + type PersistentVolumeExpansion interface{} type PersistentVolumeClaimExpansion interface{} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/limitrange.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/limitrange.go similarity index 69% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/limitrange.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/limitrange.go index 70cd4fb..4b1672b 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/limitrange.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/limitrange.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // LimitRangesGetter has a method to return a LimitRangeInterface. @@ -29,34 +31,34 @@ type LimitRangesGetter interface { // LimitRangeInterface has methods to work with LimitRange resources. type LimitRangeInterface interface { - Create(*api.LimitRange) (*api.LimitRange, error) - Update(*api.LimitRange) (*api.LimitRange, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.LimitRange, error) - List(opts api.ListOptions) (*api.LimitRangeList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.LimitRange, err error) + Create(*v1.LimitRange) (*v1.LimitRange, error) + Update(*v1.LimitRange) (*v1.LimitRange, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.LimitRange, error) + List(opts v1.ListOptions) (*v1.LimitRangeList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.LimitRange, err error) LimitRangeExpansion } // limitRanges implements LimitRangeInterface type limitRanges struct { - client *CoreClient + client rest.Interface ns string } // newLimitRanges returns a LimitRanges func newLimitRanges(c *CoreClient, namespace string) *limitRanges { return &limitRanges{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a limitRange and creates it. Returns the server's representation of the limitRange, and an error, if there is any. -func (c *limitRanges) Create(limitRange *api.LimitRange) (result *api.LimitRange, err error) { - result = &api.LimitRange{} +func (c *limitRanges) Create(limitRange *v1.LimitRange) (result *v1.LimitRange, err error) { + result = &v1.LimitRange{} err = c.client.Post(). Namespace(c.ns). Resource("limitranges"). @@ -67,8 +69,8 @@ func (c *limitRanges) Create(limitRange *api.LimitRange) (result *api.LimitRange } // Update takes the representation of a limitRange and updates it. Returns the server's representation of the limitRange, and an error, if there is any. -func (c *limitRanges) Update(limitRange *api.LimitRange) (result *api.LimitRange, err error) { - result = &api.LimitRange{} +func (c *limitRanges) Update(limitRange *v1.LimitRange) (result *v1.LimitRange, err error) { + result = &v1.LimitRange{} err = c.client.Put(). Namespace(c.ns). Resource("limitranges"). @@ -80,7 +82,7 @@ func (c *limitRanges) Update(limitRange *api.LimitRange) (result *api.LimitRange } // Delete takes name of the limitRange and deletes it. Returns an error if one occurs. -func (c *limitRanges) Delete(name string, options *api.DeleteOptions) error { +func (c *limitRanges) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("limitranges"). @@ -91,7 +93,7 @@ func (c *limitRanges) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *limitRanges) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *limitRanges) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("limitranges"). @@ -102,8 +104,8 @@ func (c *limitRanges) DeleteCollection(options *api.DeleteOptions, listOptions a } // Get takes name of the limitRange, and returns the corresponding limitRange object, and an error if there is any. -func (c *limitRanges) Get(name string) (result *api.LimitRange, err error) { - result = &api.LimitRange{} +func (c *limitRanges) Get(name string) (result *v1.LimitRange, err error) { + result = &v1.LimitRange{} err = c.client.Get(). Namespace(c.ns). Resource("limitranges"). @@ -114,8 +116,8 @@ func (c *limitRanges) Get(name string) (result *api.LimitRange, err error) { } // List takes label and field selectors, and returns the list of LimitRanges that match those selectors. -func (c *limitRanges) List(opts api.ListOptions) (result *api.LimitRangeList, err error) { - result = &api.LimitRangeList{} +func (c *limitRanges) List(opts v1.ListOptions) (result *v1.LimitRangeList, err error) { + result = &v1.LimitRangeList{} err = c.client.Get(). Namespace(c.ns). Resource("limitranges"). @@ -126,7 +128,7 @@ func (c *limitRanges) List(opts api.ListOptions) (result *api.LimitRangeList, er } // Watch returns a watch.Interface that watches the requested limitRanges. -func (c *limitRanges) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *limitRanges) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *limitRanges) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched limitRange. -func (c *limitRanges) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.LimitRange, err error) { - result = &api.LimitRange{} +func (c *limitRanges) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.LimitRange, err error) { + result = &v1.LimitRange{} err = c.client.Patch(pt). Namespace(c.ns). Resource("limitranges"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace.go similarity index 66% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace.go index 7b39f2b..d00aded 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // NamespacesGetter has a method to return a NamespaceInterface. @@ -29,33 +31,33 @@ type NamespacesGetter interface { // NamespaceInterface has methods to work with Namespace resources. type NamespaceInterface interface { - Create(*api.Namespace) (*api.Namespace, error) - Update(*api.Namespace) (*api.Namespace, error) - UpdateStatus(*api.Namespace) (*api.Namespace, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Namespace, error) - List(opts api.ListOptions) (*api.NamespaceList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Namespace, err error) + Create(*v1.Namespace) (*v1.Namespace, error) + Update(*v1.Namespace) (*v1.Namespace, error) + UpdateStatus(*v1.Namespace) (*v1.Namespace, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Namespace, error) + List(opts v1.ListOptions) (*v1.NamespaceList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Namespace, err error) NamespaceExpansion } // namespaces implements NamespaceInterface type namespaces struct { - client *CoreClient + client rest.Interface } // newNamespaces returns a Namespaces func newNamespaces(c *CoreClient) *namespaces { return &namespaces{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a namespace and creates it. Returns the server's representation of the namespace, and an error, if there is any. -func (c *namespaces) Create(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) Create(namespace *v1.Namespace) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Post(). Resource("namespaces"). Body(namespace). @@ -65,8 +67,8 @@ func (c *namespaces) Create(namespace *api.Namespace) (result *api.Namespace, er } // Update takes the representation of a namespace and updates it. Returns the server's representation of the namespace, and an error, if there is any. -func (c *namespaces) Update(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) Update(namespace *v1.Namespace) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Put(). Resource("namespaces"). Name(namespace.Name). @@ -76,8 +78,8 @@ func (c *namespaces) Update(namespace *api.Namespace) (result *api.Namespace, er return } -func (c *namespaces) UpdateStatus(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) UpdateStatus(namespace *v1.Namespace) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Put(). Resource("namespaces"). Name(namespace.Name). @@ -89,7 +91,7 @@ func (c *namespaces) UpdateStatus(namespace *api.Namespace) (result *api.Namespa } // Delete takes name of the namespace and deletes it. Returns an error if one occurs. -func (c *namespaces) Delete(name string, options *api.DeleteOptions) error { +func (c *namespaces) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("namespaces"). Name(name). @@ -99,7 +101,7 @@ func (c *namespaces) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *namespaces) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *namespaces) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("namespaces"). VersionedParams(&listOptions, api.ParameterCodec). @@ -109,8 +111,8 @@ func (c *namespaces) DeleteCollection(options *api.DeleteOptions, listOptions ap } // Get takes name of the namespace, and returns the corresponding namespace object, and an error if there is any. -func (c *namespaces) Get(name string) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) Get(name string) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Get(). Resource("namespaces"). Name(name). @@ -120,8 +122,8 @@ func (c *namespaces) Get(name string) (result *api.Namespace, err error) { } // List takes label and field selectors, and returns the list of Namespaces that match those selectors. -func (c *namespaces) List(opts api.ListOptions) (result *api.NamespaceList, err error) { - result = &api.NamespaceList{} +func (c *namespaces) List(opts v1.ListOptions) (result *v1.NamespaceList, err error) { + result = &v1.NamespaceList{} err = c.client.Get(). Resource("namespaces"). VersionedParams(&opts, api.ParameterCodec). @@ -131,7 +133,7 @@ func (c *namespaces) List(opts api.ListOptions) (result *api.NamespaceList, err } // Watch returns a watch.Interface that watches the requested namespaces. -func (c *namespaces) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *namespaces) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("namespaces"). @@ -140,8 +142,8 @@ func (c *namespaces) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched namespace. -func (c *namespaces) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Patch(pt). Resource("namespaces"). SubResource(subresources...). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace_expansion.go similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace_expansion.go index 15049da..2034300 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/namespace_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/namespace_expansion.go @@ -14,18 +14,18 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 -import "k8s.io/kubernetes/pkg/api" +import "k8s.io/client-go/pkg/api/v1" // The NamespaceExpansion interface allows manually adding extra methods to the NamespaceInterface. type NamespaceExpansion interface { - Finalize(item *api.Namespace) (*api.Namespace, error) + Finalize(item *v1.Namespace) (*v1.Namespace, error) } // Finalize takes the representation of a namespace to update. Returns the server's representation of the namespace, and an error, if it occurs. -func (c *namespaces) Finalize(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} +func (c *namespaces) Finalize(namespace *v1.Namespace) (result *v1.Namespace, err error) { + result = &v1.Namespace{} err = c.client.Put().Resource("namespaces").Name(namespace.Name).SubResource("finalize").Body(namespace).Do().Into(result) return } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/node.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/node.go index 8f4ffcd..60bc523 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/node.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // NodesGetter has a method to return a NodeInterface. @@ -29,33 +31,33 @@ type NodesGetter interface { // NodeInterface has methods to work with Node resources. type NodeInterface interface { - Create(*api.Node) (*api.Node, error) - Update(*api.Node) (*api.Node, error) - UpdateStatus(*api.Node) (*api.Node, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Node, error) - List(opts api.ListOptions) (*api.NodeList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Node, err error) + Create(*v1.Node) (*v1.Node, error) + Update(*v1.Node) (*v1.Node, error) + UpdateStatus(*v1.Node) (*v1.Node, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Node, error) + List(opts v1.ListOptions) (*v1.NodeList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Node, err error) NodeExpansion } // nodes implements NodeInterface type nodes struct { - client *CoreClient + client rest.Interface } // newNodes returns a Nodes func newNodes(c *CoreClient) *nodes { return &nodes{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a node and creates it. Returns the server's representation of the node, and an error, if there is any. -func (c *nodes) Create(node *api.Node) (result *api.Node, err error) { - result = &api.Node{} +func (c *nodes) Create(node *v1.Node) (result *v1.Node, err error) { + result = &v1.Node{} err = c.client.Post(). Resource("nodes"). Body(node). @@ -65,8 +67,8 @@ func (c *nodes) Create(node *api.Node) (result *api.Node, err error) { } // Update takes the representation of a node and updates it. Returns the server's representation of the node, and an error, if there is any. -func (c *nodes) Update(node *api.Node) (result *api.Node, err error) { - result = &api.Node{} +func (c *nodes) Update(node *v1.Node) (result *v1.Node, err error) { + result = &v1.Node{} err = c.client.Put(). Resource("nodes"). Name(node.Name). @@ -76,8 +78,8 @@ func (c *nodes) Update(node *api.Node) (result *api.Node, err error) { return } -func (c *nodes) UpdateStatus(node *api.Node) (result *api.Node, err error) { - result = &api.Node{} +func (c *nodes) UpdateStatus(node *v1.Node) (result *v1.Node, err error) { + result = &v1.Node{} err = c.client.Put(). Resource("nodes"). Name(node.Name). @@ -89,7 +91,7 @@ func (c *nodes) UpdateStatus(node *api.Node) (result *api.Node, err error) { } // Delete takes name of the node and deletes it. Returns an error if one occurs. -func (c *nodes) Delete(name string, options *api.DeleteOptions) error { +func (c *nodes) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("nodes"). Name(name). @@ -99,7 +101,7 @@ func (c *nodes) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *nodes) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *nodes) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("nodes"). VersionedParams(&listOptions, api.ParameterCodec). @@ -109,8 +111,8 @@ func (c *nodes) DeleteCollection(options *api.DeleteOptions, listOptions api.Lis } // Get takes name of the node, and returns the corresponding node object, and an error if there is any. -func (c *nodes) Get(name string) (result *api.Node, err error) { - result = &api.Node{} +func (c *nodes) Get(name string) (result *v1.Node, err error) { + result = &v1.Node{} err = c.client.Get(). Resource("nodes"). Name(name). @@ -120,8 +122,8 @@ func (c *nodes) Get(name string) (result *api.Node, err error) { } // List takes label and field selectors, and returns the list of Nodes that match those selectors. -func (c *nodes) List(opts api.ListOptions) (result *api.NodeList, err error) { - result = &api.NodeList{} +func (c *nodes) List(opts v1.ListOptions) (result *v1.NodeList, err error) { + result = &v1.NodeList{} err = c.client.Get(). Resource("nodes"). VersionedParams(&opts, api.ParameterCodec). @@ -131,7 +133,7 @@ func (c *nodes) List(opts api.ListOptions) (result *api.NodeList, err error) { } // Watch returns a watch.Interface that watches the requested nodes. -func (c *nodes) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *nodes) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("nodes"). @@ -140,8 +142,8 @@ func (c *nodes) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched node. -func (c *nodes) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Node, err error) { - result = &api.Node{} +func (c *nodes) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Node, err error) { + result = &v1.Node{} err = c.client.Patch(pt). Resource("nodes"). SubResource(subresources...). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolume.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolume.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolume.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolume.go index ecca7a3..01e3023 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolume.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolume.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // PersistentVolumesGetter has a method to return a PersistentVolumeInterface. @@ -29,33 +31,33 @@ type PersistentVolumesGetter interface { // PersistentVolumeInterface has methods to work with PersistentVolume resources. type PersistentVolumeInterface interface { - Create(*api.PersistentVolume) (*api.PersistentVolume, error) - Update(*api.PersistentVolume) (*api.PersistentVolume, error) - UpdateStatus(*api.PersistentVolume) (*api.PersistentVolume, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.PersistentVolume, error) - List(opts api.ListOptions) (*api.PersistentVolumeList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PersistentVolume, err error) + Create(*v1.PersistentVolume) (*v1.PersistentVolume, error) + Update(*v1.PersistentVolume) (*v1.PersistentVolume, error) + UpdateStatus(*v1.PersistentVolume) (*v1.PersistentVolume, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.PersistentVolume, error) + List(opts v1.ListOptions) (*v1.PersistentVolumeList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PersistentVolume, err error) PersistentVolumeExpansion } // persistentVolumes implements PersistentVolumeInterface type persistentVolumes struct { - client *CoreClient + client rest.Interface } // newPersistentVolumes returns a PersistentVolumes func newPersistentVolumes(c *CoreClient) *persistentVolumes { return &persistentVolumes{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a persistentVolume and creates it. Returns the server's representation of the persistentVolume, and an error, if there is any. -func (c *persistentVolumes) Create(persistentVolume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} +func (c *persistentVolumes) Create(persistentVolume *v1.PersistentVolume) (result *v1.PersistentVolume, err error) { + result = &v1.PersistentVolume{} err = c.client.Post(). Resource("persistentvolumes"). Body(persistentVolume). @@ -65,8 +67,8 @@ func (c *persistentVolumes) Create(persistentVolume *api.PersistentVolume) (resu } // Update takes the representation of a persistentVolume and updates it. Returns the server's representation of the persistentVolume, and an error, if there is any. -func (c *persistentVolumes) Update(persistentVolume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} +func (c *persistentVolumes) Update(persistentVolume *v1.PersistentVolume) (result *v1.PersistentVolume, err error) { + result = &v1.PersistentVolume{} err = c.client.Put(). Resource("persistentvolumes"). Name(persistentVolume.Name). @@ -76,8 +78,8 @@ func (c *persistentVolumes) Update(persistentVolume *api.PersistentVolume) (resu return } -func (c *persistentVolumes) UpdateStatus(persistentVolume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} +func (c *persistentVolumes) UpdateStatus(persistentVolume *v1.PersistentVolume) (result *v1.PersistentVolume, err error) { + result = &v1.PersistentVolume{} err = c.client.Put(). Resource("persistentvolumes"). Name(persistentVolume.Name). @@ -89,7 +91,7 @@ func (c *persistentVolumes) UpdateStatus(persistentVolume *api.PersistentVolume) } // Delete takes name of the persistentVolume and deletes it. Returns an error if one occurs. -func (c *persistentVolumes) Delete(name string, options *api.DeleteOptions) error { +func (c *persistentVolumes) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("persistentvolumes"). Name(name). @@ -99,7 +101,7 @@ func (c *persistentVolumes) Delete(name string, options *api.DeleteOptions) erro } // DeleteCollection deletes a collection of objects. -func (c *persistentVolumes) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *persistentVolumes) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("persistentvolumes"). VersionedParams(&listOptions, api.ParameterCodec). @@ -109,8 +111,8 @@ func (c *persistentVolumes) DeleteCollection(options *api.DeleteOptions, listOpt } // Get takes name of the persistentVolume, and returns the corresponding persistentVolume object, and an error if there is any. -func (c *persistentVolumes) Get(name string) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} +func (c *persistentVolumes) Get(name string) (result *v1.PersistentVolume, err error) { + result = &v1.PersistentVolume{} err = c.client.Get(). Resource("persistentvolumes"). Name(name). @@ -120,8 +122,8 @@ func (c *persistentVolumes) Get(name string) (result *api.PersistentVolume, err } // List takes label and field selectors, and returns the list of PersistentVolumes that match those selectors. -func (c *persistentVolumes) List(opts api.ListOptions) (result *api.PersistentVolumeList, err error) { - result = &api.PersistentVolumeList{} +func (c *persistentVolumes) List(opts v1.ListOptions) (result *v1.PersistentVolumeList, err error) { + result = &v1.PersistentVolumeList{} err = c.client.Get(). Resource("persistentvolumes"). VersionedParams(&opts, api.ParameterCodec). @@ -131,7 +133,7 @@ func (c *persistentVolumes) List(opts api.ListOptions) (result *api.PersistentVo } // Watch returns a watch.Interface that watches the requested persistentVolumes. -func (c *persistentVolumes) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *persistentVolumes) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("persistentvolumes"). @@ -140,8 +142,8 @@ func (c *persistentVolumes) Watch(opts api.ListOptions) (watch.Interface, error) } // Patch applies the patch and returns the patched persistentVolume. -func (c *persistentVolumes) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} +func (c *persistentVolumes) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PersistentVolume, err error) { + result = &v1.PersistentVolume{} err = c.client.Patch(pt). Resource("persistentvolumes"). SubResource(subresources...). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolumeclaim.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolumeclaim.go similarity index 66% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolumeclaim.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolumeclaim.go index 45d22eb..37267fe 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/persistentvolumeclaim.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/persistentvolumeclaim.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // PersistentVolumeClaimsGetter has a method to return a PersistentVolumeClaimInterface. @@ -29,35 +31,35 @@ type PersistentVolumeClaimsGetter interface { // PersistentVolumeClaimInterface has methods to work with PersistentVolumeClaim resources. type PersistentVolumeClaimInterface interface { - Create(*api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - Update(*api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - UpdateStatus(*api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.PersistentVolumeClaim, error) - List(opts api.ListOptions) (*api.PersistentVolumeClaimList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PersistentVolumeClaim, err error) + Create(*v1.PersistentVolumeClaim) (*v1.PersistentVolumeClaim, error) + Update(*v1.PersistentVolumeClaim) (*v1.PersistentVolumeClaim, error) + UpdateStatus(*v1.PersistentVolumeClaim) (*v1.PersistentVolumeClaim, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.PersistentVolumeClaim, error) + List(opts v1.ListOptions) (*v1.PersistentVolumeClaimList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PersistentVolumeClaim, err error) PersistentVolumeClaimExpansion } // persistentVolumeClaims implements PersistentVolumeClaimInterface type persistentVolumeClaims struct { - client *CoreClient + client rest.Interface ns string } // newPersistentVolumeClaims returns a PersistentVolumeClaims func newPersistentVolumeClaims(c *CoreClient, namespace string) *persistentVolumeClaims { return &persistentVolumeClaims{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a persistentVolumeClaim and creates it. Returns the server's representation of the persistentVolumeClaim, and an error, if there is any. -func (c *persistentVolumeClaims) Create(persistentVolumeClaim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} +func (c *persistentVolumeClaims) Create(persistentVolumeClaim *v1.PersistentVolumeClaim) (result *v1.PersistentVolumeClaim, err error) { + result = &v1.PersistentVolumeClaim{} err = c.client.Post(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -68,8 +70,8 @@ func (c *persistentVolumeClaims) Create(persistentVolumeClaim *api.PersistentVol } // Update takes the representation of a persistentVolumeClaim and updates it. Returns the server's representation of the persistentVolumeClaim, and an error, if there is any. -func (c *persistentVolumeClaims) Update(persistentVolumeClaim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} +func (c *persistentVolumeClaims) Update(persistentVolumeClaim *v1.PersistentVolumeClaim) (result *v1.PersistentVolumeClaim, err error) { + result = &v1.PersistentVolumeClaim{} err = c.client.Put(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -80,8 +82,8 @@ func (c *persistentVolumeClaims) Update(persistentVolumeClaim *api.PersistentVol return } -func (c *persistentVolumeClaims) UpdateStatus(persistentVolumeClaim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} +func (c *persistentVolumeClaims) UpdateStatus(persistentVolumeClaim *v1.PersistentVolumeClaim) (result *v1.PersistentVolumeClaim, err error) { + result = &v1.PersistentVolumeClaim{} err = c.client.Put(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -94,7 +96,7 @@ func (c *persistentVolumeClaims) UpdateStatus(persistentVolumeClaim *api.Persist } // Delete takes name of the persistentVolumeClaim and deletes it. Returns an error if one occurs. -func (c *persistentVolumeClaims) Delete(name string, options *api.DeleteOptions) error { +func (c *persistentVolumeClaims) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -105,7 +107,7 @@ func (c *persistentVolumeClaims) Delete(name string, options *api.DeleteOptions) } // DeleteCollection deletes a collection of objects. -func (c *persistentVolumeClaims) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *persistentVolumeClaims) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -116,8 +118,8 @@ func (c *persistentVolumeClaims) DeleteCollection(options *api.DeleteOptions, li } // Get takes name of the persistentVolumeClaim, and returns the corresponding persistentVolumeClaim object, and an error if there is any. -func (c *persistentVolumeClaims) Get(name string) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} +func (c *persistentVolumeClaims) Get(name string) (result *v1.PersistentVolumeClaim, err error) { + result = &v1.PersistentVolumeClaim{} err = c.client.Get(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -128,8 +130,8 @@ func (c *persistentVolumeClaims) Get(name string) (result *api.PersistentVolumeC } // List takes label and field selectors, and returns the list of PersistentVolumeClaims that match those selectors. -func (c *persistentVolumeClaims) List(opts api.ListOptions) (result *api.PersistentVolumeClaimList, err error) { - result = &api.PersistentVolumeClaimList{} +func (c *persistentVolumeClaims) List(opts v1.ListOptions) (result *v1.PersistentVolumeClaimList, err error) { + result = &v1.PersistentVolumeClaimList{} err = c.client.Get(). Namespace(c.ns). Resource("persistentvolumeclaims"). @@ -140,7 +142,7 @@ func (c *persistentVolumeClaims) List(opts api.ListOptions) (result *api.Persist } // Watch returns a watch.Interface that watches the requested persistentVolumeClaims. -func (c *persistentVolumeClaims) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *persistentVolumeClaims) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -150,8 +152,8 @@ func (c *persistentVolumeClaims) Watch(opts api.ListOptions) (watch.Interface, e } // Patch applies the patch and returns the patched persistentVolumeClaim. -func (c *persistentVolumeClaims) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} +func (c *persistentVolumeClaims) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PersistentVolumeClaim, err error) { + result = &v1.PersistentVolumeClaim{} err = c.client.Patch(pt). Namespace(c.ns). Resource("persistentvolumeclaims"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod.go similarity index 69% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod.go index 595462a..4ac1300 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // PodsGetter has a method to return a PodInterface. @@ -29,35 +31,35 @@ type PodsGetter interface { // PodInterface has methods to work with Pod resources. type PodInterface interface { - Create(*api.Pod) (*api.Pod, error) - Update(*api.Pod) (*api.Pod, error) - UpdateStatus(*api.Pod) (*api.Pod, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Pod, error) - List(opts api.ListOptions) (*api.PodList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Pod, err error) + Create(*v1.Pod) (*v1.Pod, error) + Update(*v1.Pod) (*v1.Pod, error) + UpdateStatus(*v1.Pod) (*v1.Pod, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Pod, error) + List(opts v1.ListOptions) (*v1.PodList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Pod, err error) PodExpansion } // pods implements PodInterface type pods struct { - client *CoreClient + client rest.Interface ns string } // newPods returns a Pods func newPods(c *CoreClient, namespace string) *pods { return &pods{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a pod and creates it. Returns the server's representation of the pod, and an error, if there is any. -func (c *pods) Create(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} +func (c *pods) Create(pod *v1.Pod) (result *v1.Pod, err error) { + result = &v1.Pod{} err = c.client.Post(). Namespace(c.ns). Resource("pods"). @@ -68,8 +70,8 @@ func (c *pods) Create(pod *api.Pod) (result *api.Pod, err error) { } // Update takes the representation of a pod and updates it. Returns the server's representation of the pod, and an error, if there is any. -func (c *pods) Update(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} +func (c *pods) Update(pod *v1.Pod) (result *v1.Pod, err error) { + result = &v1.Pod{} err = c.client.Put(). Namespace(c.ns). Resource("pods"). @@ -80,8 +82,8 @@ func (c *pods) Update(pod *api.Pod) (result *api.Pod, err error) { return } -func (c *pods) UpdateStatus(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} +func (c *pods) UpdateStatus(pod *v1.Pod) (result *v1.Pod, err error) { + result = &v1.Pod{} err = c.client.Put(). Namespace(c.ns). Resource("pods"). @@ -94,7 +96,7 @@ func (c *pods) UpdateStatus(pod *api.Pod) (result *api.Pod, err error) { } // Delete takes name of the pod and deletes it. Returns an error if one occurs. -func (c *pods) Delete(name string, options *api.DeleteOptions) error { +func (c *pods) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("pods"). @@ -105,7 +107,7 @@ func (c *pods) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *pods) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *pods) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("pods"). @@ -116,8 +118,8 @@ func (c *pods) DeleteCollection(options *api.DeleteOptions, listOptions api.List } // Get takes name of the pod, and returns the corresponding pod object, and an error if there is any. -func (c *pods) Get(name string) (result *api.Pod, err error) { - result = &api.Pod{} +func (c *pods) Get(name string) (result *v1.Pod, err error) { + result = &v1.Pod{} err = c.client.Get(). Namespace(c.ns). Resource("pods"). @@ -128,8 +130,8 @@ func (c *pods) Get(name string) (result *api.Pod, err error) { } // List takes label and field selectors, and returns the list of Pods that match those selectors. -func (c *pods) List(opts api.ListOptions) (result *api.PodList, err error) { - result = &api.PodList{} +func (c *pods) List(opts v1.ListOptions) (result *v1.PodList, err error) { + result = &v1.PodList{} err = c.client.Get(). Namespace(c.ns). Resource("pods"). @@ -140,7 +142,7 @@ func (c *pods) List(opts api.ListOptions) (result *api.PodList, err error) { } // Watch returns a watch.Interface that watches the requested pods. -func (c *pods) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *pods) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -150,8 +152,8 @@ func (c *pods) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched pod. -func (c *pods) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Pod, err error) { - result = &api.Pod{} +func (c *pods) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Pod, err error) { + result = &v1.Pod{} err = c.client.Patch(pt). Namespace(c.ns). Resource("pods"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod_expansion.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod_expansion.go index a72b843..88fa277 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/pod_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/pod_expansion.go @@ -14,25 +14,32 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/v1" + policy "k8s.io/client-go/pkg/apis/policy/v1alpha1" + "k8s.io/client-go/rest" ) // The PodExpansion interface allows manually adding extra methods to the PodInterface. type PodExpansion interface { - Bind(binding *api.Binding) error - GetLogs(name string, opts *api.PodLogOptions) *restclient.Request + Bind(binding *v1.Binding) error + Evict(eviction *policy.Eviction) error + GetLogs(name string, opts *v1.PodLogOptions) *rest.Request } // Bind applies the provided binding to the named pod in the current namespace (binding.Namespace is ignored). -func (c *pods) Bind(binding *api.Binding) error { +func (c *pods) Bind(binding *v1.Binding) error { return c.client.Post().Namespace(c.ns).Resource("pods").Name(binding.Name).SubResource("binding").Body(binding).Do().Error() } +func (c *pods) Evict(eviction *policy.Eviction) error { + return c.client.Post().Namespace(c.ns).Resource("pods").Name(eviction.Name).SubResource("eviction").Body(eviction).Do().Error() +} + // Get constructs a request for getting the logs for a pod -func (c *pods) GetLogs(name string, opts *api.PodLogOptions) *restclient.Request { +func (c *pods) GetLogs(name string, opts *v1.PodLogOptions) *rest.Request { return c.client.Get().Namespace(c.ns).Name(name).Resource("pods").SubResource("log").VersionedParams(opts, api.ParameterCodec) } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/podtemplate.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/podtemplate.go similarity index 69% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/podtemplate.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/podtemplate.go index 4494bd3..ce2a83f 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/podtemplate.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/podtemplate.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // PodTemplatesGetter has a method to return a PodTemplateInterface. @@ -29,34 +31,34 @@ type PodTemplatesGetter interface { // PodTemplateInterface has methods to work with PodTemplate resources. type PodTemplateInterface interface { - Create(*api.PodTemplate) (*api.PodTemplate, error) - Update(*api.PodTemplate) (*api.PodTemplate, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.PodTemplate, error) - List(opts api.ListOptions) (*api.PodTemplateList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PodTemplate, err error) + Create(*v1.PodTemplate) (*v1.PodTemplate, error) + Update(*v1.PodTemplate) (*v1.PodTemplate, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.PodTemplate, error) + List(opts v1.ListOptions) (*v1.PodTemplateList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PodTemplate, err error) PodTemplateExpansion } // podTemplates implements PodTemplateInterface type podTemplates struct { - client *CoreClient + client rest.Interface ns string } // newPodTemplates returns a PodTemplates func newPodTemplates(c *CoreClient, namespace string) *podTemplates { return &podTemplates{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a podTemplate and creates it. Returns the server's representation of the podTemplate, and an error, if there is any. -func (c *podTemplates) Create(podTemplate *api.PodTemplate) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} +func (c *podTemplates) Create(podTemplate *v1.PodTemplate) (result *v1.PodTemplate, err error) { + result = &v1.PodTemplate{} err = c.client.Post(). Namespace(c.ns). Resource("podtemplates"). @@ -67,8 +69,8 @@ func (c *podTemplates) Create(podTemplate *api.PodTemplate) (result *api.PodTemp } // Update takes the representation of a podTemplate and updates it. Returns the server's representation of the podTemplate, and an error, if there is any. -func (c *podTemplates) Update(podTemplate *api.PodTemplate) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} +func (c *podTemplates) Update(podTemplate *v1.PodTemplate) (result *v1.PodTemplate, err error) { + result = &v1.PodTemplate{} err = c.client.Put(). Namespace(c.ns). Resource("podtemplates"). @@ -80,7 +82,7 @@ func (c *podTemplates) Update(podTemplate *api.PodTemplate) (result *api.PodTemp } // Delete takes name of the podTemplate and deletes it. Returns an error if one occurs. -func (c *podTemplates) Delete(name string, options *api.DeleteOptions) error { +func (c *podTemplates) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("podtemplates"). @@ -91,7 +93,7 @@ func (c *podTemplates) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *podTemplates) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *podTemplates) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("podtemplates"). @@ -102,8 +104,8 @@ func (c *podTemplates) DeleteCollection(options *api.DeleteOptions, listOptions } // Get takes name of the podTemplate, and returns the corresponding podTemplate object, and an error if there is any. -func (c *podTemplates) Get(name string) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} +func (c *podTemplates) Get(name string) (result *v1.PodTemplate, err error) { + result = &v1.PodTemplate{} err = c.client.Get(). Namespace(c.ns). Resource("podtemplates"). @@ -114,8 +116,8 @@ func (c *podTemplates) Get(name string) (result *api.PodTemplate, err error) { } // List takes label and field selectors, and returns the list of PodTemplates that match those selectors. -func (c *podTemplates) List(opts api.ListOptions) (result *api.PodTemplateList, err error) { - result = &api.PodTemplateList{} +func (c *podTemplates) List(opts v1.ListOptions) (result *v1.PodTemplateList, err error) { + result = &v1.PodTemplateList{} err = c.client.Get(). Namespace(c.ns). Resource("podtemplates"). @@ -126,7 +128,7 @@ func (c *podTemplates) List(opts api.ListOptions) (result *api.PodTemplateList, } // Watch returns a watch.Interface that watches the requested podTemplates. -func (c *podTemplates) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *podTemplates) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *podTemplates) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched podTemplate. -func (c *podTemplates) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} +func (c *podTemplates) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.PodTemplate, err error) { + result = &v1.PodTemplate{} err = c.client.Patch(pt). Namespace(c.ns). Resource("podtemplates"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/replicationcontroller.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/replicationcontroller.go similarity index 66% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/replicationcontroller.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/replicationcontroller.go index a1b1757..a01a907 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/replicationcontroller.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/replicationcontroller.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ReplicationControllersGetter has a method to return a ReplicationControllerInterface. @@ -29,35 +31,35 @@ type ReplicationControllersGetter interface { // ReplicationControllerInterface has methods to work with ReplicationController resources. type ReplicationControllerInterface interface { - Create(*api.ReplicationController) (*api.ReplicationController, error) - Update(*api.ReplicationController) (*api.ReplicationController, error) - UpdateStatus(*api.ReplicationController) (*api.ReplicationController, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.ReplicationController, error) - List(opts api.ListOptions) (*api.ReplicationControllerList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ReplicationController, err error) + Create(*v1.ReplicationController) (*v1.ReplicationController, error) + Update(*v1.ReplicationController) (*v1.ReplicationController, error) + UpdateStatus(*v1.ReplicationController) (*v1.ReplicationController, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.ReplicationController, error) + List(opts v1.ListOptions) (*v1.ReplicationControllerList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ReplicationController, err error) ReplicationControllerExpansion } // replicationControllers implements ReplicationControllerInterface type replicationControllers struct { - client *CoreClient + client rest.Interface ns string } // newReplicationControllers returns a ReplicationControllers func newReplicationControllers(c *CoreClient, namespace string) *replicationControllers { return &replicationControllers{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a replicationController and creates it. Returns the server's representation of the replicationController, and an error, if there is any. -func (c *replicationControllers) Create(replicationController *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} +func (c *replicationControllers) Create(replicationController *v1.ReplicationController) (result *v1.ReplicationController, err error) { + result = &v1.ReplicationController{} err = c.client.Post(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -68,8 +70,8 @@ func (c *replicationControllers) Create(replicationController *api.ReplicationCo } // Update takes the representation of a replicationController and updates it. Returns the server's representation of the replicationController, and an error, if there is any. -func (c *replicationControllers) Update(replicationController *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} +func (c *replicationControllers) Update(replicationController *v1.ReplicationController) (result *v1.ReplicationController, err error) { + result = &v1.ReplicationController{} err = c.client.Put(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -80,8 +82,8 @@ func (c *replicationControllers) Update(replicationController *api.ReplicationCo return } -func (c *replicationControllers) UpdateStatus(replicationController *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} +func (c *replicationControllers) UpdateStatus(replicationController *v1.ReplicationController) (result *v1.ReplicationController, err error) { + result = &v1.ReplicationController{} err = c.client.Put(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -94,7 +96,7 @@ func (c *replicationControllers) UpdateStatus(replicationController *api.Replica } // Delete takes name of the replicationController and deletes it. Returns an error if one occurs. -func (c *replicationControllers) Delete(name string, options *api.DeleteOptions) error { +func (c *replicationControllers) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -105,7 +107,7 @@ func (c *replicationControllers) Delete(name string, options *api.DeleteOptions) } // DeleteCollection deletes a collection of objects. -func (c *replicationControllers) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *replicationControllers) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -116,8 +118,8 @@ func (c *replicationControllers) DeleteCollection(options *api.DeleteOptions, li } // Get takes name of the replicationController, and returns the corresponding replicationController object, and an error if there is any. -func (c *replicationControllers) Get(name string) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} +func (c *replicationControllers) Get(name string) (result *v1.ReplicationController, err error) { + result = &v1.ReplicationController{} err = c.client.Get(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -128,8 +130,8 @@ func (c *replicationControllers) Get(name string) (result *api.ReplicationContro } // List takes label and field selectors, and returns the list of ReplicationControllers that match those selectors. -func (c *replicationControllers) List(opts api.ListOptions) (result *api.ReplicationControllerList, err error) { - result = &api.ReplicationControllerList{} +func (c *replicationControllers) List(opts v1.ListOptions) (result *v1.ReplicationControllerList, err error) { + result = &v1.ReplicationControllerList{} err = c.client.Get(). Namespace(c.ns). Resource("replicationcontrollers"). @@ -140,7 +142,7 @@ func (c *replicationControllers) List(opts api.ListOptions) (result *api.Replica } // Watch returns a watch.Interface that watches the requested replicationControllers. -func (c *replicationControllers) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *replicationControllers) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -150,8 +152,8 @@ func (c *replicationControllers) Watch(opts api.ListOptions) (watch.Interface, e } // Patch applies the patch and returns the patched replicationController. -func (c *replicationControllers) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} +func (c *replicationControllers) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ReplicationController, err error) { + result = &v1.ReplicationController{} err = c.client.Patch(pt). Namespace(c.ns). Resource("replicationcontrollers"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/resourcequota.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/resourcequota.go similarity index 67% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/resourcequota.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/resourcequota.go index 1aa175b..1c8bae2 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/resourcequota.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/resourcequota.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ResourceQuotasGetter has a method to return a ResourceQuotaInterface. @@ -29,35 +31,35 @@ type ResourceQuotasGetter interface { // ResourceQuotaInterface has methods to work with ResourceQuota resources. type ResourceQuotaInterface interface { - Create(*api.ResourceQuota) (*api.ResourceQuota, error) - Update(*api.ResourceQuota) (*api.ResourceQuota, error) - UpdateStatus(*api.ResourceQuota) (*api.ResourceQuota, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.ResourceQuota, error) - List(opts api.ListOptions) (*api.ResourceQuotaList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ResourceQuota, err error) + Create(*v1.ResourceQuota) (*v1.ResourceQuota, error) + Update(*v1.ResourceQuota) (*v1.ResourceQuota, error) + UpdateStatus(*v1.ResourceQuota) (*v1.ResourceQuota, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.ResourceQuota, error) + List(opts v1.ListOptions) (*v1.ResourceQuotaList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ResourceQuota, err error) ResourceQuotaExpansion } // resourceQuotas implements ResourceQuotaInterface type resourceQuotas struct { - client *CoreClient + client rest.Interface ns string } // newResourceQuotas returns a ResourceQuotas func newResourceQuotas(c *CoreClient, namespace string) *resourceQuotas { return &resourceQuotas{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a resourceQuota and creates it. Returns the server's representation of the resourceQuota, and an error, if there is any. -func (c *resourceQuotas) Create(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} +func (c *resourceQuotas) Create(resourceQuota *v1.ResourceQuota) (result *v1.ResourceQuota, err error) { + result = &v1.ResourceQuota{} err = c.client.Post(). Namespace(c.ns). Resource("resourcequotas"). @@ -68,8 +70,8 @@ func (c *resourceQuotas) Create(resourceQuota *api.ResourceQuota) (result *api.R } // Update takes the representation of a resourceQuota and updates it. Returns the server's representation of the resourceQuota, and an error, if there is any. -func (c *resourceQuotas) Update(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} +func (c *resourceQuotas) Update(resourceQuota *v1.ResourceQuota) (result *v1.ResourceQuota, err error) { + result = &v1.ResourceQuota{} err = c.client.Put(). Namespace(c.ns). Resource("resourcequotas"). @@ -80,8 +82,8 @@ func (c *resourceQuotas) Update(resourceQuota *api.ResourceQuota) (result *api.R return } -func (c *resourceQuotas) UpdateStatus(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} +func (c *resourceQuotas) UpdateStatus(resourceQuota *v1.ResourceQuota) (result *v1.ResourceQuota, err error) { + result = &v1.ResourceQuota{} err = c.client.Put(). Namespace(c.ns). Resource("resourcequotas"). @@ -94,7 +96,7 @@ func (c *resourceQuotas) UpdateStatus(resourceQuota *api.ResourceQuota) (result } // Delete takes name of the resourceQuota and deletes it. Returns an error if one occurs. -func (c *resourceQuotas) Delete(name string, options *api.DeleteOptions) error { +func (c *resourceQuotas) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("resourcequotas"). @@ -105,7 +107,7 @@ func (c *resourceQuotas) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *resourceQuotas) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *resourceQuotas) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("resourcequotas"). @@ -116,8 +118,8 @@ func (c *resourceQuotas) DeleteCollection(options *api.DeleteOptions, listOption } // Get takes name of the resourceQuota, and returns the corresponding resourceQuota object, and an error if there is any. -func (c *resourceQuotas) Get(name string) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} +func (c *resourceQuotas) Get(name string) (result *v1.ResourceQuota, err error) { + result = &v1.ResourceQuota{} err = c.client.Get(). Namespace(c.ns). Resource("resourcequotas"). @@ -128,8 +130,8 @@ func (c *resourceQuotas) Get(name string) (result *api.ResourceQuota, err error) } // List takes label and field selectors, and returns the list of ResourceQuotas that match those selectors. -func (c *resourceQuotas) List(opts api.ListOptions) (result *api.ResourceQuotaList, err error) { - result = &api.ResourceQuotaList{} +func (c *resourceQuotas) List(opts v1.ListOptions) (result *v1.ResourceQuotaList, err error) { + result = &v1.ResourceQuotaList{} err = c.client.Get(). Namespace(c.ns). Resource("resourcequotas"). @@ -140,7 +142,7 @@ func (c *resourceQuotas) List(opts api.ListOptions) (result *api.ResourceQuotaLi } // Watch returns a watch.Interface that watches the requested resourceQuotas. -func (c *resourceQuotas) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *resourceQuotas) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -150,8 +152,8 @@ func (c *resourceQuotas) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched resourceQuota. -func (c *resourceQuotas) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} +func (c *resourceQuotas) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ResourceQuota, err error) { + result = &v1.ResourceQuota{} err = c.client.Patch(pt). Namespace(c.ns). Resource("resourcequotas"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/secret.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/secret.go similarity index 70% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/secret.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/secret.go index f87263c..31f442c 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/secret.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/secret.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // SecretsGetter has a method to return a SecretInterface. @@ -29,34 +31,34 @@ type SecretsGetter interface { // SecretInterface has methods to work with Secret resources. type SecretInterface interface { - Create(*api.Secret) (*api.Secret, error) - Update(*api.Secret) (*api.Secret, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Secret, error) - List(opts api.ListOptions) (*api.SecretList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Secret, err error) + Create(*v1.Secret) (*v1.Secret, error) + Update(*v1.Secret) (*v1.Secret, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Secret, error) + List(opts v1.ListOptions) (*v1.SecretList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Secret, err error) SecretExpansion } // secrets implements SecretInterface type secrets struct { - client *CoreClient + client rest.Interface ns string } // newSecrets returns a Secrets func newSecrets(c *CoreClient, namespace string) *secrets { return &secrets{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a secret and creates it. Returns the server's representation of the secret, and an error, if there is any. -func (c *secrets) Create(secret *api.Secret) (result *api.Secret, err error) { - result = &api.Secret{} +func (c *secrets) Create(secret *v1.Secret) (result *v1.Secret, err error) { + result = &v1.Secret{} err = c.client.Post(). Namespace(c.ns). Resource("secrets"). @@ -67,8 +69,8 @@ func (c *secrets) Create(secret *api.Secret) (result *api.Secret, err error) { } // Update takes the representation of a secret and updates it. Returns the server's representation of the secret, and an error, if there is any. -func (c *secrets) Update(secret *api.Secret) (result *api.Secret, err error) { - result = &api.Secret{} +func (c *secrets) Update(secret *v1.Secret) (result *v1.Secret, err error) { + result = &v1.Secret{} err = c.client.Put(). Namespace(c.ns). Resource("secrets"). @@ -80,7 +82,7 @@ func (c *secrets) Update(secret *api.Secret) (result *api.Secret, err error) { } // Delete takes name of the secret and deletes it. Returns an error if one occurs. -func (c *secrets) Delete(name string, options *api.DeleteOptions) error { +func (c *secrets) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("secrets"). @@ -91,7 +93,7 @@ func (c *secrets) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *secrets) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *secrets) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("secrets"). @@ -102,8 +104,8 @@ func (c *secrets) DeleteCollection(options *api.DeleteOptions, listOptions api.L } // Get takes name of the secret, and returns the corresponding secret object, and an error if there is any. -func (c *secrets) Get(name string) (result *api.Secret, err error) { - result = &api.Secret{} +func (c *secrets) Get(name string) (result *v1.Secret, err error) { + result = &v1.Secret{} err = c.client.Get(). Namespace(c.ns). Resource("secrets"). @@ -114,8 +116,8 @@ func (c *secrets) Get(name string) (result *api.Secret, err error) { } // List takes label and field selectors, and returns the list of Secrets that match those selectors. -func (c *secrets) List(opts api.ListOptions) (result *api.SecretList, err error) { - result = &api.SecretList{} +func (c *secrets) List(opts v1.ListOptions) (result *v1.SecretList, err error) { + result = &v1.SecretList{} err = c.client.Get(). Namespace(c.ns). Resource("secrets"). @@ -126,7 +128,7 @@ func (c *secrets) List(opts api.ListOptions) (result *api.SecretList, err error) } // Watch returns a watch.Interface that watches the requested secrets. -func (c *secrets) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *secrets) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *secrets) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched secret. -func (c *secrets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Secret, err error) { - result = &api.Secret{} +func (c *secrets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Secret, err error) { + result = &v1.Secret{} err = c.client.Patch(pt). Namespace(c.ns). Resource("secrets"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/service.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/service.go index 86fa3b2..9ae2e77 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/service.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ServicesGetter has a method to return a ServiceInterface. @@ -29,35 +31,35 @@ type ServicesGetter interface { // ServiceInterface has methods to work with Service resources. type ServiceInterface interface { - Create(*api.Service) (*api.Service, error) - Update(*api.Service) (*api.Service, error) - UpdateStatus(*api.Service) (*api.Service, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.Service, error) - List(opts api.ListOptions) (*api.ServiceList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Service, err error) + Create(*v1.Service) (*v1.Service, error) + Update(*v1.Service) (*v1.Service, error) + UpdateStatus(*v1.Service) (*v1.Service, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.Service, error) + List(opts v1.ListOptions) (*v1.ServiceList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Service, err error) ServiceExpansion } // services implements ServiceInterface type services struct { - client *CoreClient + client rest.Interface ns string } // newServices returns a Services func newServices(c *CoreClient, namespace string) *services { return &services{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a service and creates it. Returns the server's representation of the service, and an error, if there is any. -func (c *services) Create(service *api.Service) (result *api.Service, err error) { - result = &api.Service{} +func (c *services) Create(service *v1.Service) (result *v1.Service, err error) { + result = &v1.Service{} err = c.client.Post(). Namespace(c.ns). Resource("services"). @@ -68,8 +70,8 @@ func (c *services) Create(service *api.Service) (result *api.Service, err error) } // Update takes the representation of a service and updates it. Returns the server's representation of the service, and an error, if there is any. -func (c *services) Update(service *api.Service) (result *api.Service, err error) { - result = &api.Service{} +func (c *services) Update(service *v1.Service) (result *v1.Service, err error) { + result = &v1.Service{} err = c.client.Put(). Namespace(c.ns). Resource("services"). @@ -80,8 +82,8 @@ func (c *services) Update(service *api.Service) (result *api.Service, err error) return } -func (c *services) UpdateStatus(service *api.Service) (result *api.Service, err error) { - result = &api.Service{} +func (c *services) UpdateStatus(service *v1.Service) (result *v1.Service, err error) { + result = &v1.Service{} err = c.client.Put(). Namespace(c.ns). Resource("services"). @@ -94,7 +96,7 @@ func (c *services) UpdateStatus(service *api.Service) (result *api.Service, err } // Delete takes name of the service and deletes it. Returns an error if one occurs. -func (c *services) Delete(name string, options *api.DeleteOptions) error { +func (c *services) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("services"). @@ -105,7 +107,7 @@ func (c *services) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *services) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *services) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("services"). @@ -116,8 +118,8 @@ func (c *services) DeleteCollection(options *api.DeleteOptions, listOptions api. } // Get takes name of the service, and returns the corresponding service object, and an error if there is any. -func (c *services) Get(name string) (result *api.Service, err error) { - result = &api.Service{} +func (c *services) Get(name string) (result *v1.Service, err error) { + result = &v1.Service{} err = c.client.Get(). Namespace(c.ns). Resource("services"). @@ -128,8 +130,8 @@ func (c *services) Get(name string) (result *api.Service, err error) { } // List takes label and field selectors, and returns the list of Services that match those selectors. -func (c *services) List(opts api.ListOptions) (result *api.ServiceList, err error) { - result = &api.ServiceList{} +func (c *services) List(opts v1.ListOptions) (result *v1.ServiceList, err error) { + result = &v1.ServiceList{} err = c.client.Get(). Namespace(c.ns). Resource("services"). @@ -140,7 +142,7 @@ func (c *services) List(opts api.ListOptions) (result *api.ServiceList, err erro } // Watch returns a watch.Interface that watches the requested services. -func (c *services) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *services) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -150,8 +152,8 @@ func (c *services) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched service. -func (c *services) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.Service, err error) { - result = &api.Service{} +func (c *services) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.Service, err error) { + result = &v1.Service{} err = c.client.Patch(pt). Namespace(c.ns). Resource("services"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/service_expansion.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/service_expansion.go index de8f21c..687589c 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/service_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/service_expansion.go @@ -14,20 +14,20 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/util/net" + "k8s.io/client-go/pkg/util/net" + "k8s.io/client-go/rest" ) // The ServiceExpansion interface allows manually adding extra methods to the ServiceInterface. type ServiceExpansion interface { - ProxyGet(scheme, name, port, path string, params map[string]string) restclient.ResponseWrapper + ProxyGet(scheme, name, port, path string, params map[string]string) rest.ResponseWrapper } // ProxyGet returns a response of the service by calling it through the proxy. -func (c *services) ProxyGet(scheme, name, port, path string, params map[string]string) restclient.ResponseWrapper { +func (c *services) ProxyGet(scheme, name, port, path string, params map[string]string) rest.ResponseWrapper { request := c.client.Get(). Prefix("proxy"). Namespace(c.ns). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/serviceaccount.go b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/serviceaccount.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/serviceaccount.go rename to vendor/k8s.io/client-go/kubernetes/typed/core/v1/serviceaccount.go index 14c56b2..0d90771 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/serviceaccount.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/core/v1/serviceaccount.go @@ -14,11 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1 import ( - api "k8s.io/kubernetes/pkg/api" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ServiceAccountsGetter has a method to return a ServiceAccountInterface. @@ -29,34 +31,34 @@ type ServiceAccountsGetter interface { // ServiceAccountInterface has methods to work with ServiceAccount resources. type ServiceAccountInterface interface { - Create(*api.ServiceAccount) (*api.ServiceAccount, error) - Update(*api.ServiceAccount) (*api.ServiceAccount, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*api.ServiceAccount, error) - List(opts api.ListOptions) (*api.ServiceAccountList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ServiceAccount, err error) + Create(*v1.ServiceAccount) (*v1.ServiceAccount, error) + Update(*v1.ServiceAccount) (*v1.ServiceAccount, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1.ServiceAccount, error) + List(opts v1.ListOptions) (*v1.ServiceAccountList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ServiceAccount, err error) ServiceAccountExpansion } // serviceAccounts implements ServiceAccountInterface type serviceAccounts struct { - client *CoreClient + client rest.Interface ns string } // newServiceAccounts returns a ServiceAccounts func newServiceAccounts(c *CoreClient, namespace string) *serviceAccounts { return &serviceAccounts{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a serviceAccount and creates it. Returns the server's representation of the serviceAccount, and an error, if there is any. -func (c *serviceAccounts) Create(serviceAccount *api.ServiceAccount) (result *api.ServiceAccount, err error) { - result = &api.ServiceAccount{} +func (c *serviceAccounts) Create(serviceAccount *v1.ServiceAccount) (result *v1.ServiceAccount, err error) { + result = &v1.ServiceAccount{} err = c.client.Post(). Namespace(c.ns). Resource("serviceaccounts"). @@ -67,8 +69,8 @@ func (c *serviceAccounts) Create(serviceAccount *api.ServiceAccount) (result *ap } // Update takes the representation of a serviceAccount and updates it. Returns the server's representation of the serviceAccount, and an error, if there is any. -func (c *serviceAccounts) Update(serviceAccount *api.ServiceAccount) (result *api.ServiceAccount, err error) { - result = &api.ServiceAccount{} +func (c *serviceAccounts) Update(serviceAccount *v1.ServiceAccount) (result *v1.ServiceAccount, err error) { + result = &v1.ServiceAccount{} err = c.client.Put(). Namespace(c.ns). Resource("serviceaccounts"). @@ -80,7 +82,7 @@ func (c *serviceAccounts) Update(serviceAccount *api.ServiceAccount) (result *ap } // Delete takes name of the serviceAccount and deletes it. Returns an error if one occurs. -func (c *serviceAccounts) Delete(name string, options *api.DeleteOptions) error { +func (c *serviceAccounts) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("serviceaccounts"). @@ -91,7 +93,7 @@ func (c *serviceAccounts) Delete(name string, options *api.DeleteOptions) error } // DeleteCollection deletes a collection of objects. -func (c *serviceAccounts) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *serviceAccounts) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("serviceaccounts"). @@ -102,8 +104,8 @@ func (c *serviceAccounts) DeleteCollection(options *api.DeleteOptions, listOptio } // Get takes name of the serviceAccount, and returns the corresponding serviceAccount object, and an error if there is any. -func (c *serviceAccounts) Get(name string) (result *api.ServiceAccount, err error) { - result = &api.ServiceAccount{} +func (c *serviceAccounts) Get(name string) (result *v1.ServiceAccount, err error) { + result = &v1.ServiceAccount{} err = c.client.Get(). Namespace(c.ns). Resource("serviceaccounts"). @@ -114,8 +116,8 @@ func (c *serviceAccounts) Get(name string) (result *api.ServiceAccount, err erro } // List takes label and field selectors, and returns the list of ServiceAccounts that match those selectors. -func (c *serviceAccounts) List(opts api.ListOptions) (result *api.ServiceAccountList, err error) { - result = &api.ServiceAccountList{} +func (c *serviceAccounts) List(opts v1.ListOptions) (result *v1.ServiceAccountList, err error) { + result = &v1.ServiceAccountList{} err = c.client.Get(). Namespace(c.ns). Resource("serviceaccounts"). @@ -126,7 +128,7 @@ func (c *serviceAccounts) List(opts api.ListOptions) (result *api.ServiceAccount } // Watch returns a watch.Interface that watches the requested serviceAccounts. -func (c *serviceAccounts) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *serviceAccounts) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -136,8 +138,8 @@ func (c *serviceAccounts) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched serviceAccount. -func (c *serviceAccounts) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *api.ServiceAccount, err error) { - result = &api.ServiceAccount{} +func (c *serviceAccounts) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1.ServiceAccount, err error) { + result = &v1.ServiceAccount{} err = c.client.Patch(pt). Namespace(c.ns). Resource("serviceaccounts"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/daemonset.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/daemonset.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/daemonset.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/daemonset.go index 827677d..bdd0aaf 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/daemonset.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/daemonset.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // DaemonSetsGetter has a method to return a DaemonSetInterface. @@ -30,35 +32,35 @@ type DaemonSetsGetter interface { // DaemonSetInterface has methods to work with DaemonSet resources. type DaemonSetInterface interface { - Create(*extensions.DaemonSet) (*extensions.DaemonSet, error) - Update(*extensions.DaemonSet) (*extensions.DaemonSet, error) - UpdateStatus(*extensions.DaemonSet) (*extensions.DaemonSet, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.DaemonSet, error) - List(opts api.ListOptions) (*extensions.DaemonSetList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.DaemonSet, err error) + Create(*v1beta1.DaemonSet) (*v1beta1.DaemonSet, error) + Update(*v1beta1.DaemonSet) (*v1beta1.DaemonSet, error) + UpdateStatus(*v1beta1.DaemonSet) (*v1beta1.DaemonSet, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.DaemonSet, error) + List(opts v1.ListOptions) (*v1beta1.DaemonSetList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.DaemonSet, err error) DaemonSetExpansion } // daemonSets implements DaemonSetInterface type daemonSets struct { - client *ExtensionsClient + client rest.Interface ns string } // newDaemonSets returns a DaemonSets func newDaemonSets(c *ExtensionsClient, namespace string) *daemonSets { return &daemonSets{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a daemonSet and creates it. Returns the server's representation of the daemonSet, and an error, if there is any. -func (c *daemonSets) Create(daemonSet *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} +func (c *daemonSets) Create(daemonSet *v1beta1.DaemonSet) (result *v1beta1.DaemonSet, err error) { + result = &v1beta1.DaemonSet{} err = c.client.Post(). Namespace(c.ns). Resource("daemonsets"). @@ -69,8 +71,8 @@ func (c *daemonSets) Create(daemonSet *extensions.DaemonSet) (result *extensions } // Update takes the representation of a daemonSet and updates it. Returns the server's representation of the daemonSet, and an error, if there is any. -func (c *daemonSets) Update(daemonSet *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} +func (c *daemonSets) Update(daemonSet *v1beta1.DaemonSet) (result *v1beta1.DaemonSet, err error) { + result = &v1beta1.DaemonSet{} err = c.client.Put(). Namespace(c.ns). Resource("daemonsets"). @@ -81,8 +83,8 @@ func (c *daemonSets) Update(daemonSet *extensions.DaemonSet) (result *extensions return } -func (c *daemonSets) UpdateStatus(daemonSet *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} +func (c *daemonSets) UpdateStatus(daemonSet *v1beta1.DaemonSet) (result *v1beta1.DaemonSet, err error) { + result = &v1beta1.DaemonSet{} err = c.client.Put(). Namespace(c.ns). Resource("daemonsets"). @@ -95,7 +97,7 @@ func (c *daemonSets) UpdateStatus(daemonSet *extensions.DaemonSet) (result *exte } // Delete takes name of the daemonSet and deletes it. Returns an error if one occurs. -func (c *daemonSets) Delete(name string, options *api.DeleteOptions) error { +func (c *daemonSets) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("daemonsets"). @@ -106,7 +108,7 @@ func (c *daemonSets) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *daemonSets) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *daemonSets) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("daemonsets"). @@ -117,8 +119,8 @@ func (c *daemonSets) DeleteCollection(options *api.DeleteOptions, listOptions ap } // Get takes name of the daemonSet, and returns the corresponding daemonSet object, and an error if there is any. -func (c *daemonSets) Get(name string) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} +func (c *daemonSets) Get(name string) (result *v1beta1.DaemonSet, err error) { + result = &v1beta1.DaemonSet{} err = c.client.Get(). Namespace(c.ns). Resource("daemonsets"). @@ -129,8 +131,8 @@ func (c *daemonSets) Get(name string) (result *extensions.DaemonSet, err error) } // List takes label and field selectors, and returns the list of DaemonSets that match those selectors. -func (c *daemonSets) List(opts api.ListOptions) (result *extensions.DaemonSetList, err error) { - result = &extensions.DaemonSetList{} +func (c *daemonSets) List(opts v1.ListOptions) (result *v1beta1.DaemonSetList, err error) { + result = &v1beta1.DaemonSetList{} err = c.client.Get(). Namespace(c.ns). Resource("daemonsets"). @@ -141,7 +143,7 @@ func (c *daemonSets) List(opts api.ListOptions) (result *extensions.DaemonSetLis } // Watch returns a watch.Interface that watches the requested daemonSets. -func (c *daemonSets) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *daemonSets) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -151,8 +153,8 @@ func (c *daemonSets) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched daemonSet. -func (c *daemonSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} +func (c *daemonSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.DaemonSet, err error) { + result = &v1beta1.DaemonSet{} err = c.client.Patch(pt). Namespace(c.ns). Resource("daemonsets"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment.go index 894a7d3..9e60781 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // DeploymentsGetter has a method to return a DeploymentInterface. @@ -30,35 +32,35 @@ type DeploymentsGetter interface { // DeploymentInterface has methods to work with Deployment resources. type DeploymentInterface interface { - Create(*extensions.Deployment) (*extensions.Deployment, error) - Update(*extensions.Deployment) (*extensions.Deployment, error) - UpdateStatus(*extensions.Deployment) (*extensions.Deployment, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.Deployment, error) - List(opts api.ListOptions) (*extensions.DeploymentList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.Deployment, err error) + Create(*v1beta1.Deployment) (*v1beta1.Deployment, error) + Update(*v1beta1.Deployment) (*v1beta1.Deployment, error) + UpdateStatus(*v1beta1.Deployment) (*v1beta1.Deployment, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.Deployment, error) + List(opts v1.ListOptions) (*v1beta1.DeploymentList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Deployment, err error) DeploymentExpansion } // deployments implements DeploymentInterface type deployments struct { - client *ExtensionsClient + client rest.Interface ns string } // newDeployments returns a Deployments func newDeployments(c *ExtensionsClient, namespace string) *deployments { return &deployments{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a deployment and creates it. Returns the server's representation of the deployment, and an error, if there is any. -func (c *deployments) Create(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} +func (c *deployments) Create(deployment *v1beta1.Deployment) (result *v1beta1.Deployment, err error) { + result = &v1beta1.Deployment{} err = c.client.Post(). Namespace(c.ns). Resource("deployments"). @@ -69,8 +71,8 @@ func (c *deployments) Create(deployment *extensions.Deployment) (result *extensi } // Update takes the representation of a deployment and updates it. Returns the server's representation of the deployment, and an error, if there is any. -func (c *deployments) Update(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} +func (c *deployments) Update(deployment *v1beta1.Deployment) (result *v1beta1.Deployment, err error) { + result = &v1beta1.Deployment{} err = c.client.Put(). Namespace(c.ns). Resource("deployments"). @@ -81,8 +83,8 @@ func (c *deployments) Update(deployment *extensions.Deployment) (result *extensi return } -func (c *deployments) UpdateStatus(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} +func (c *deployments) UpdateStatus(deployment *v1beta1.Deployment) (result *v1beta1.Deployment, err error) { + result = &v1beta1.Deployment{} err = c.client.Put(). Namespace(c.ns). Resource("deployments"). @@ -95,7 +97,7 @@ func (c *deployments) UpdateStatus(deployment *extensions.Deployment) (result *e } // Delete takes name of the deployment and deletes it. Returns an error if one occurs. -func (c *deployments) Delete(name string, options *api.DeleteOptions) error { +func (c *deployments) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("deployments"). @@ -106,7 +108,7 @@ func (c *deployments) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *deployments) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *deployments) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("deployments"). @@ -117,8 +119,8 @@ func (c *deployments) DeleteCollection(options *api.DeleteOptions, listOptions a } // Get takes name of the deployment, and returns the corresponding deployment object, and an error if there is any. -func (c *deployments) Get(name string) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} +func (c *deployments) Get(name string) (result *v1beta1.Deployment, err error) { + result = &v1beta1.Deployment{} err = c.client.Get(). Namespace(c.ns). Resource("deployments"). @@ -129,8 +131,8 @@ func (c *deployments) Get(name string) (result *extensions.Deployment, err error } // List takes label and field selectors, and returns the list of Deployments that match those selectors. -func (c *deployments) List(opts api.ListOptions) (result *extensions.DeploymentList, err error) { - result = &extensions.DeploymentList{} +func (c *deployments) List(opts v1.ListOptions) (result *v1beta1.DeploymentList, err error) { + result = &v1beta1.DeploymentList{} err = c.client.Get(). Namespace(c.ns). Resource("deployments"). @@ -141,7 +143,7 @@ func (c *deployments) List(opts api.ListOptions) (result *extensions.DeploymentL } // Watch returns a watch.Interface that watches the requested deployments. -func (c *deployments) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *deployments) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -151,8 +153,8 @@ func (c *deployments) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched deployment. -func (c *deployments) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} +func (c *deployments) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Deployment, err error) { + result = &v1beta1.Deployment{} err = c.client.Patch(pt). Namespace(c.ns). Resource("deployments"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment_expansion.go similarity index 82% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment_expansion.go index 4d89330..e737f09 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/deployment_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/deployment_expansion.go @@ -14,16 +14,16 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 -import "k8s.io/kubernetes/pkg/apis/extensions" +import "k8s.io/client-go/pkg/apis/extensions/v1beta1" // The DeploymentExpansion interface allows manually adding extra methods to the DeploymentInterface. type DeploymentExpansion interface { - Rollback(*extensions.DeploymentRollback) error + Rollback(*v1beta1.DeploymentRollback) error } // Rollback applied the provided DeploymentRollback to the named deployment in the current namespace. -func (c *deployments) Rollback(deploymentRollback *extensions.DeploymentRollback) error { +func (c *deployments) Rollback(deploymentRollback *v1beta1.DeploymentRollback) error { return c.client.Post().Namespace(c.ns).Resource("deployments").Name(deploymentRollback.Name).SubResource("rollback").Body(deploymentRollback).Do().Error() } diff --git a/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/doc.go new file mode 100644 index 0000000..5616c95 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/extensions_client.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/extensions_client.go similarity index 67% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/extensions_client.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/extensions_client.go index b1e281e..cab9ab5 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/extensions_client.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/extensions_client.go @@ -14,20 +14,21 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - registered "k8s.io/kubernetes/pkg/apimachinery/registered" - restclient "k8s.io/kubernetes/pkg/client/restclient" + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" ) type ExtensionsInterface interface { - GetRESTClient() *restclient.RESTClient + RESTClient() rest.Interface DaemonSetsGetter DeploymentsGetter IngressesGetter - NetworkPoliciesGetter + JobsGetter PodSecurityPoliciesGetter ReplicaSetsGetter ScalesGetter @@ -36,7 +37,7 @@ type ExtensionsInterface interface { // ExtensionsClient is used to interact with features provided by the Extensions group. type ExtensionsClient struct { - *restclient.RESTClient + restClient rest.Interface } func (c *ExtensionsClient) DaemonSets(namespace string) DaemonSetInterface { @@ -51,8 +52,8 @@ func (c *ExtensionsClient) Ingresses(namespace string) IngressInterface { return newIngresses(c, namespace) } -func (c *ExtensionsClient) NetworkPolicies(namespace string) NetworkPolicyInterface { - return newNetworkPolicies(c, namespace) +func (c *ExtensionsClient) Jobs(namespace string) JobInterface { + return newJobs(c, namespace) } func (c *ExtensionsClient) PodSecurityPolicies() PodSecurityPolicyInterface { @@ -72,12 +73,12 @@ func (c *ExtensionsClient) ThirdPartyResources() ThirdPartyResourceInterface { } // NewForConfig creates a new ExtensionsClient for the given config. -func NewForConfig(c *restclient.Config) (*ExtensionsClient, error) { +func NewForConfig(c *rest.Config) (*ExtensionsClient, error) { config := *c if err := setConfigDefaults(&config); err != nil { return nil, err } - client, err := restclient.RESTClientFor(&config) + client, err := rest.RESTClientFor(&config) if err != nil { return nil, err } @@ -86,7 +87,7 @@ func NewForConfig(c *restclient.Config) (*ExtensionsClient, error) { // NewForConfigOrDie creates a new ExtensionsClient for the given config and // panics if there is an error in the config. -func NewForConfigOrDie(c *restclient.Config) *ExtensionsClient { +func NewForConfigOrDie(c *rest.Config) *ExtensionsClient { client, err := NewForConfig(c) if err != nil { panic(err) @@ -95,11 +96,11 @@ func NewForConfigOrDie(c *restclient.Config) *ExtensionsClient { } // New creates a new ExtensionsClient for the given RESTClient. -func New(c *restclient.RESTClient) *ExtensionsClient { +func New(c rest.Interface) *ExtensionsClient { return &ExtensionsClient{c} } -func setConfigDefaults(config *restclient.Config) error { +func setConfigDefaults(config *rest.Config) error { // if extensions group is not registered, return an error g, err := registered.Group("extensions") if err != nil { @@ -107,28 +108,24 @@ func setConfigDefaults(config *restclient.Config) error { } config.APIPath = "/apis" if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() + config.UserAgent = rest.DefaultKubernetesUserAgent() } - if config.GroupVersion == nil || config.GroupVersion.Group != g.GroupVersion.Group { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - config.NegotiatedSerializer = api.Codecs + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} - if config.QPS == 0 { - config.QPS = 5 - } - if config.Burst == 0 { - config.Burst = 10 - } return nil } -// GetRESTClient returns a RESTClient that is used to communicate +// RESTClient returns a RESTClient that is used to communicate // with API server by this client implementation. -func (c *ExtensionsClient) GetRESTClient() *restclient.RESTClient { +func (c *ExtensionsClient) RESTClient() rest.Interface { if c == nil { return nil } - return c.RESTClient + return c.restClient } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/generated_expansion.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/generated_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/generated_expansion.go index 6a14055..60cf61d 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/generated_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/generated_expansion.go @@ -14,13 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 type DaemonSetExpansion interface{} type IngressExpansion interface{} -type NetworkPolicyExpansion interface{} +type JobExpansion interface{} type PodSecurityPolicyExpansion interface{} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/ingress.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/ingress.go similarity index 67% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/ingress.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/ingress.go index 7d941ac..d6a831f 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/ingress.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/ingress.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // IngressesGetter has a method to return a IngressInterface. @@ -30,35 +32,35 @@ type IngressesGetter interface { // IngressInterface has methods to work with Ingress resources. type IngressInterface interface { - Create(*extensions.Ingress) (*extensions.Ingress, error) - Update(*extensions.Ingress) (*extensions.Ingress, error) - UpdateStatus(*extensions.Ingress) (*extensions.Ingress, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.Ingress, error) - List(opts api.ListOptions) (*extensions.IngressList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.Ingress, err error) + Create(*v1beta1.Ingress) (*v1beta1.Ingress, error) + Update(*v1beta1.Ingress) (*v1beta1.Ingress, error) + UpdateStatus(*v1beta1.Ingress) (*v1beta1.Ingress, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.Ingress, error) + List(opts v1.ListOptions) (*v1beta1.IngressList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Ingress, err error) IngressExpansion } // ingresses implements IngressInterface type ingresses struct { - client *ExtensionsClient + client rest.Interface ns string } // newIngresses returns a Ingresses func newIngresses(c *ExtensionsClient, namespace string) *ingresses { return &ingresses{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a ingress and creates it. Returns the server's representation of the ingress, and an error, if there is any. -func (c *ingresses) Create(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} +func (c *ingresses) Create(ingress *v1beta1.Ingress) (result *v1beta1.Ingress, err error) { + result = &v1beta1.Ingress{} err = c.client.Post(). Namespace(c.ns). Resource("ingresses"). @@ -69,8 +71,8 @@ func (c *ingresses) Create(ingress *extensions.Ingress) (result *extensions.Ingr } // Update takes the representation of a ingress and updates it. Returns the server's representation of the ingress, and an error, if there is any. -func (c *ingresses) Update(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} +func (c *ingresses) Update(ingress *v1beta1.Ingress) (result *v1beta1.Ingress, err error) { + result = &v1beta1.Ingress{} err = c.client.Put(). Namespace(c.ns). Resource("ingresses"). @@ -81,8 +83,8 @@ func (c *ingresses) Update(ingress *extensions.Ingress) (result *extensions.Ingr return } -func (c *ingresses) UpdateStatus(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} +func (c *ingresses) UpdateStatus(ingress *v1beta1.Ingress) (result *v1beta1.Ingress, err error) { + result = &v1beta1.Ingress{} err = c.client.Put(). Namespace(c.ns). Resource("ingresses"). @@ -95,7 +97,7 @@ func (c *ingresses) UpdateStatus(ingress *extensions.Ingress) (result *extension } // Delete takes name of the ingress and deletes it. Returns an error if one occurs. -func (c *ingresses) Delete(name string, options *api.DeleteOptions) error { +func (c *ingresses) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("ingresses"). @@ -106,7 +108,7 @@ func (c *ingresses) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *ingresses) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *ingresses) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("ingresses"). @@ -117,8 +119,8 @@ func (c *ingresses) DeleteCollection(options *api.DeleteOptions, listOptions api } // Get takes name of the ingress, and returns the corresponding ingress object, and an error if there is any. -func (c *ingresses) Get(name string) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} +func (c *ingresses) Get(name string) (result *v1beta1.Ingress, err error) { + result = &v1beta1.Ingress{} err = c.client.Get(). Namespace(c.ns). Resource("ingresses"). @@ -129,8 +131,8 @@ func (c *ingresses) Get(name string) (result *extensions.Ingress, err error) { } // List takes label and field selectors, and returns the list of Ingresses that match those selectors. -func (c *ingresses) List(opts api.ListOptions) (result *extensions.IngressList, err error) { - result = &extensions.IngressList{} +func (c *ingresses) List(opts v1.ListOptions) (result *v1beta1.IngressList, err error) { + result = &v1beta1.IngressList{} err = c.client.Get(). Namespace(c.ns). Resource("ingresses"). @@ -141,7 +143,7 @@ func (c *ingresses) List(opts api.ListOptions) (result *extensions.IngressList, } // Watch returns a watch.Interface that watches the requested ingresses. -func (c *ingresses) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *ingresses) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -151,8 +153,8 @@ func (c *ingresses) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched ingress. -func (c *ingresses) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} +func (c *ingresses) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Ingress, err error) { + result = &v1beta1.Ingress{} err = c.client.Patch(pt). Namespace(c.ns). Resource("ingresses"). diff --git a/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/job.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/job.go new file mode 100644 index 0000000..8984a30 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/job.go @@ -0,0 +1,167 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// JobsGetter has a method to return a JobInterface. +// A group's client should implement this interface. +type JobsGetter interface { + Jobs(namespace string) JobInterface +} + +// JobInterface has methods to work with Job resources. +type JobInterface interface { + Create(*v1beta1.Job) (*v1beta1.Job, error) + Update(*v1beta1.Job) (*v1beta1.Job, error) + UpdateStatus(*v1beta1.Job) (*v1beta1.Job, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.Job, error) + List(opts v1.ListOptions) (*v1beta1.JobList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Job, err error) + JobExpansion +} + +// jobs implements JobInterface +type jobs struct { + client rest.Interface + ns string +} + +// newJobs returns a Jobs +func newJobs(c *ExtensionsClient, namespace string) *jobs { + return &jobs{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a job and creates it. Returns the server's representation of the job, and an error, if there is any. +func (c *jobs) Create(job *v1beta1.Job) (result *v1beta1.Job, err error) { + result = &v1beta1.Job{} + err = c.client.Post(). + Namespace(c.ns). + Resource("jobs"). + Body(job). + Do(). + Into(result) + return +} + +// Update takes the representation of a job and updates it. Returns the server's representation of the job, and an error, if there is any. +func (c *jobs) Update(job *v1beta1.Job) (result *v1beta1.Job, err error) { + result = &v1beta1.Job{} + err = c.client.Put(). + Namespace(c.ns). + Resource("jobs"). + Name(job.Name). + Body(job). + Do(). + Into(result) + return +} + +func (c *jobs) UpdateStatus(job *v1beta1.Job) (result *v1beta1.Job, err error) { + result = &v1beta1.Job{} + err = c.client.Put(). + Namespace(c.ns). + Resource("jobs"). + Name(job.Name). + SubResource("status"). + Body(job). + Do(). + Into(result) + return +} + +// Delete takes name of the job and deletes it. Returns an error if one occurs. +func (c *jobs) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("jobs"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *jobs) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("jobs"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the job, and returns the corresponding job object, and an error if there is any. +func (c *jobs) Get(name string) (result *v1beta1.Job, err error) { + result = &v1beta1.Job{} + err = c.client.Get(). + Namespace(c.ns). + Resource("jobs"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of Jobs that match those selectors. +func (c *jobs) List(opts v1.ListOptions) (result *v1beta1.JobList, err error) { + result = &v1beta1.JobList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("jobs"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested jobs. +func (c *jobs) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("jobs"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched job. +func (c *jobs) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.Job, err error) { + result = &v1beta1.Job{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("jobs"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/podsecuritypolicy.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/podsecuritypolicy.go similarity index 64% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/podsecuritypolicy.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/podsecuritypolicy.go index e59ba01..f284137 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/podsecuritypolicy.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/podsecuritypolicy.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // PodSecurityPoliciesGetter has a method to return a PodSecurityPolicyInterface. @@ -30,32 +32,32 @@ type PodSecurityPoliciesGetter interface { // PodSecurityPolicyInterface has methods to work with PodSecurityPolicy resources. type PodSecurityPolicyInterface interface { - Create(*extensions.PodSecurityPolicy) (*extensions.PodSecurityPolicy, error) - Update(*extensions.PodSecurityPolicy) (*extensions.PodSecurityPolicy, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.PodSecurityPolicy, error) - List(opts api.ListOptions) (*extensions.PodSecurityPolicyList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.PodSecurityPolicy, err error) + Create(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) + Update(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.PodSecurityPolicy, error) + List(opts v1.ListOptions) (*v1beta1.PodSecurityPolicyList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.PodSecurityPolicy, err error) PodSecurityPolicyExpansion } // podSecurityPolicies implements PodSecurityPolicyInterface type podSecurityPolicies struct { - client *ExtensionsClient + client rest.Interface } // newPodSecurityPolicies returns a PodSecurityPolicies func newPodSecurityPolicies(c *ExtensionsClient) *podSecurityPolicies { return &podSecurityPolicies{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a podSecurityPolicy and creates it. Returns the server's representation of the podSecurityPolicy, and an error, if there is any. -func (c *podSecurityPolicies) Create(podSecurityPolicy *extensions.PodSecurityPolicy) (result *extensions.PodSecurityPolicy, err error) { - result = &extensions.PodSecurityPolicy{} +func (c *podSecurityPolicies) Create(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { + result = &v1beta1.PodSecurityPolicy{} err = c.client.Post(). Resource("podsecuritypolicies"). Body(podSecurityPolicy). @@ -65,8 +67,8 @@ func (c *podSecurityPolicies) Create(podSecurityPolicy *extensions.PodSecurityPo } // Update takes the representation of a podSecurityPolicy and updates it. Returns the server's representation of the podSecurityPolicy, and an error, if there is any. -func (c *podSecurityPolicies) Update(podSecurityPolicy *extensions.PodSecurityPolicy) (result *extensions.PodSecurityPolicy, err error) { - result = &extensions.PodSecurityPolicy{} +func (c *podSecurityPolicies) Update(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { + result = &v1beta1.PodSecurityPolicy{} err = c.client.Put(). Resource("podsecuritypolicies"). Name(podSecurityPolicy.Name). @@ -77,7 +79,7 @@ func (c *podSecurityPolicies) Update(podSecurityPolicy *extensions.PodSecurityPo } // Delete takes name of the podSecurityPolicy and deletes it. Returns an error if one occurs. -func (c *podSecurityPolicies) Delete(name string, options *api.DeleteOptions) error { +func (c *podSecurityPolicies) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("podsecuritypolicies"). Name(name). @@ -87,7 +89,7 @@ func (c *podSecurityPolicies) Delete(name string, options *api.DeleteOptions) er } // DeleteCollection deletes a collection of objects. -func (c *podSecurityPolicies) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *podSecurityPolicies) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("podsecuritypolicies"). VersionedParams(&listOptions, api.ParameterCodec). @@ -97,8 +99,8 @@ func (c *podSecurityPolicies) DeleteCollection(options *api.DeleteOptions, listO } // Get takes name of the podSecurityPolicy, and returns the corresponding podSecurityPolicy object, and an error if there is any. -func (c *podSecurityPolicies) Get(name string) (result *extensions.PodSecurityPolicy, err error) { - result = &extensions.PodSecurityPolicy{} +func (c *podSecurityPolicies) Get(name string) (result *v1beta1.PodSecurityPolicy, err error) { + result = &v1beta1.PodSecurityPolicy{} err = c.client.Get(). Resource("podsecuritypolicies"). Name(name). @@ -108,8 +110,8 @@ func (c *podSecurityPolicies) Get(name string) (result *extensions.PodSecurityPo } // List takes label and field selectors, and returns the list of PodSecurityPolicies that match those selectors. -func (c *podSecurityPolicies) List(opts api.ListOptions) (result *extensions.PodSecurityPolicyList, err error) { - result = &extensions.PodSecurityPolicyList{} +func (c *podSecurityPolicies) List(opts v1.ListOptions) (result *v1beta1.PodSecurityPolicyList, err error) { + result = &v1beta1.PodSecurityPolicyList{} err = c.client.Get(). Resource("podsecuritypolicies"). VersionedParams(&opts, api.ParameterCodec). @@ -119,7 +121,7 @@ func (c *podSecurityPolicies) List(opts api.ListOptions) (result *extensions.Pod } // Watch returns a watch.Interface that watches the requested podSecurityPolicies. -func (c *podSecurityPolicies) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *podSecurityPolicies) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("podsecuritypolicies"). @@ -128,8 +130,8 @@ func (c *podSecurityPolicies) Watch(opts api.ListOptions) (watch.Interface, erro } // Patch applies the patch and returns the patched podSecurityPolicy. -func (c *podSecurityPolicies) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.PodSecurityPolicy, err error) { - result = &extensions.PodSecurityPolicy{} +func (c *podSecurityPolicies) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.PodSecurityPolicy, err error) { + result = &v1beta1.PodSecurityPolicy{} err = c.client.Patch(pt). Resource("podsecuritypolicies"). SubResource(subresources...). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/replicaset.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/replicaset.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/replicaset.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/replicaset.go index fc6987b..f0f8bc7 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/replicaset.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/replicaset.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ReplicaSetsGetter has a method to return a ReplicaSetInterface. @@ -30,35 +32,35 @@ type ReplicaSetsGetter interface { // ReplicaSetInterface has methods to work with ReplicaSet resources. type ReplicaSetInterface interface { - Create(*extensions.ReplicaSet) (*extensions.ReplicaSet, error) - Update(*extensions.ReplicaSet) (*extensions.ReplicaSet, error) - UpdateStatus(*extensions.ReplicaSet) (*extensions.ReplicaSet, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.ReplicaSet, error) - List(opts api.ListOptions) (*extensions.ReplicaSetList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.ReplicaSet, err error) + Create(*v1beta1.ReplicaSet) (*v1beta1.ReplicaSet, error) + Update(*v1beta1.ReplicaSet) (*v1beta1.ReplicaSet, error) + UpdateStatus(*v1beta1.ReplicaSet) (*v1beta1.ReplicaSet, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.ReplicaSet, error) + List(opts v1.ListOptions) (*v1beta1.ReplicaSetList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.ReplicaSet, err error) ReplicaSetExpansion } // replicaSets implements ReplicaSetInterface type replicaSets struct { - client *ExtensionsClient + client rest.Interface ns string } // newReplicaSets returns a ReplicaSets func newReplicaSets(c *ExtensionsClient, namespace string) *replicaSets { return &replicaSets{ - client: c, + client: c.RESTClient(), ns: namespace, } } // Create takes the representation of a replicaSet and creates it. Returns the server's representation of the replicaSet, and an error, if there is any. -func (c *replicaSets) Create(replicaSet *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} +func (c *replicaSets) Create(replicaSet *v1beta1.ReplicaSet) (result *v1beta1.ReplicaSet, err error) { + result = &v1beta1.ReplicaSet{} err = c.client.Post(). Namespace(c.ns). Resource("replicasets"). @@ -69,8 +71,8 @@ func (c *replicaSets) Create(replicaSet *extensions.ReplicaSet) (result *extensi } // Update takes the representation of a replicaSet and updates it. Returns the server's representation of the replicaSet, and an error, if there is any. -func (c *replicaSets) Update(replicaSet *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} +func (c *replicaSets) Update(replicaSet *v1beta1.ReplicaSet) (result *v1beta1.ReplicaSet, err error) { + result = &v1beta1.ReplicaSet{} err = c.client.Put(). Namespace(c.ns). Resource("replicasets"). @@ -81,8 +83,8 @@ func (c *replicaSets) Update(replicaSet *extensions.ReplicaSet) (result *extensi return } -func (c *replicaSets) UpdateStatus(replicaSet *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} +func (c *replicaSets) UpdateStatus(replicaSet *v1beta1.ReplicaSet) (result *v1beta1.ReplicaSet, err error) { + result = &v1beta1.ReplicaSet{} err = c.client.Put(). Namespace(c.ns). Resource("replicasets"). @@ -95,7 +97,7 @@ func (c *replicaSets) UpdateStatus(replicaSet *extensions.ReplicaSet) (result *e } // Delete takes name of the replicaSet and deletes it. Returns an error if one occurs. -func (c *replicaSets) Delete(name string, options *api.DeleteOptions) error { +func (c *replicaSets) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("replicasets"). @@ -106,7 +108,7 @@ func (c *replicaSets) Delete(name string, options *api.DeleteOptions) error { } // DeleteCollection deletes a collection of objects. -func (c *replicaSets) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *replicaSets) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Namespace(c.ns). Resource("replicasets"). @@ -117,8 +119,8 @@ func (c *replicaSets) DeleteCollection(options *api.DeleteOptions, listOptions a } // Get takes name of the replicaSet, and returns the corresponding replicaSet object, and an error if there is any. -func (c *replicaSets) Get(name string) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} +func (c *replicaSets) Get(name string) (result *v1beta1.ReplicaSet, err error) { + result = &v1beta1.ReplicaSet{} err = c.client.Get(). Namespace(c.ns). Resource("replicasets"). @@ -129,8 +131,8 @@ func (c *replicaSets) Get(name string) (result *extensions.ReplicaSet, err error } // List takes label and field selectors, and returns the list of ReplicaSets that match those selectors. -func (c *replicaSets) List(opts api.ListOptions) (result *extensions.ReplicaSetList, err error) { - result = &extensions.ReplicaSetList{} +func (c *replicaSets) List(opts v1.ListOptions) (result *v1beta1.ReplicaSetList, err error) { + result = &v1beta1.ReplicaSetList{} err = c.client.Get(). Namespace(c.ns). Resource("replicasets"). @@ -141,7 +143,7 @@ func (c *replicaSets) List(opts api.ListOptions) (result *extensions.ReplicaSetL } // Watch returns a watch.Interface that watches the requested replicaSets. -func (c *replicaSets) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *replicaSets) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Namespace(c.ns). @@ -151,8 +153,8 @@ func (c *replicaSets) Watch(opts api.ListOptions) (watch.Interface, error) { } // Patch applies the patch and returns the patched replicaSet. -func (c *replicaSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} +func (c *replicaSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.ReplicaSet, err error) { + result = &v1beta1.ReplicaSet{} err = c.client.Patch(pt). Namespace(c.ns). Resource("replicasets"). diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale.go index 12455ca..90c7ed5 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale.go @@ -14,7 +14,11 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 + +import ( + rest "k8s.io/client-go/rest" +) // ScalesGetter has a method to return a ScaleInterface. // A group's client should implement this interface. @@ -29,14 +33,14 @@ type ScaleInterface interface { // scales implements ScaleInterface type scales struct { - client *ExtensionsClient + client rest.Interface ns string } // newScales returns a Scales func newScales(c *ExtensionsClient, namespace string) *scales { return &scales{ - client: c, + client: c.RESTClient(), ns: namespace, } } diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale_expansion.go similarity index 74% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale_expansion.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale_expansion.go index 8dbba79..08421dc 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/scale_expansion.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/scale_expansion.go @@ -14,23 +14,23 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apis/extensions" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/apis/extensions/v1beta1" ) // The ScaleExpansion interface allows manually adding extra methods to the ScaleInterface. type ScaleExpansion interface { - Get(kind string, name string) (*extensions.Scale, error) - Update(kind string, scale *extensions.Scale) (*extensions.Scale, error) + Get(kind string, name string) (*v1beta1.Scale, error) + Update(kind string, scale *v1beta1.Scale) (*v1beta1.Scale, error) } // Get takes the reference to scale subresource and returns the subresource or error, if one occurs. -func (c *scales) Get(kind string, name string) (result *extensions.Scale, err error) { - result = &extensions.Scale{} +func (c *scales) Get(kind string, name string) (result *v1beta1.Scale, err error) { + result = &v1beta1.Scale{} // TODO this method needs to take a proper unambiguous kind fullyQualifiedKind := unversioned.GroupVersionKind{Kind: kind} @@ -46,8 +46,8 @@ func (c *scales) Get(kind string, name string) (result *extensions.Scale, err er return } -func (c *scales) Update(kind string, scale *extensions.Scale) (result *extensions.Scale, err error) { - result = &extensions.Scale{} +func (c *scales) Update(kind string, scale *v1beta1.Scale) (result *v1beta1.Scale, err error) { + result = &v1beta1.Scale{} // TODO this method needs to take a proper unambiguous kind fullyQualifiedKind := unversioned.GroupVersionKind{Kind: kind} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/thirdpartyresource.go b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/thirdpartyresource.go similarity index 64% rename from vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/thirdpartyresource.go rename to vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/thirdpartyresource.go index 914ae24..18b30c0 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/thirdpartyresource.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/extensions/v1beta1/thirdpartyresource.go @@ -14,12 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package unversioned +package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/extensions/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" ) // ThirdPartyResourcesGetter has a method to return a ThirdPartyResourceInterface. @@ -30,32 +32,32 @@ type ThirdPartyResourcesGetter interface { // ThirdPartyResourceInterface has methods to work with ThirdPartyResource resources. type ThirdPartyResourceInterface interface { - Create(*extensions.ThirdPartyResource) (*extensions.ThirdPartyResource, error) - Update(*extensions.ThirdPartyResource) (*extensions.ThirdPartyResource, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.ThirdPartyResource, error) - List(opts api.ListOptions) (*extensions.ThirdPartyResourceList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.ThirdPartyResource, err error) + Create(*v1beta1.ThirdPartyResource) (*v1beta1.ThirdPartyResource, error) + Update(*v1beta1.ThirdPartyResource) (*v1beta1.ThirdPartyResource, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.ThirdPartyResource, error) + List(opts v1.ListOptions) (*v1beta1.ThirdPartyResourceList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.ThirdPartyResource, err error) ThirdPartyResourceExpansion } // thirdPartyResources implements ThirdPartyResourceInterface type thirdPartyResources struct { - client *ExtensionsClient + client rest.Interface } // newThirdPartyResources returns a ThirdPartyResources func newThirdPartyResources(c *ExtensionsClient) *thirdPartyResources { return &thirdPartyResources{ - client: c, + client: c.RESTClient(), } } // Create takes the representation of a thirdPartyResource and creates it. Returns the server's representation of the thirdPartyResource, and an error, if there is any. -func (c *thirdPartyResources) Create(thirdPartyResource *extensions.ThirdPartyResource) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} +func (c *thirdPartyResources) Create(thirdPartyResource *v1beta1.ThirdPartyResource) (result *v1beta1.ThirdPartyResource, err error) { + result = &v1beta1.ThirdPartyResource{} err = c.client.Post(). Resource("thirdpartyresources"). Body(thirdPartyResource). @@ -65,8 +67,8 @@ func (c *thirdPartyResources) Create(thirdPartyResource *extensions.ThirdPartyRe } // Update takes the representation of a thirdPartyResource and updates it. Returns the server's representation of the thirdPartyResource, and an error, if there is any. -func (c *thirdPartyResources) Update(thirdPartyResource *extensions.ThirdPartyResource) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} +func (c *thirdPartyResources) Update(thirdPartyResource *v1beta1.ThirdPartyResource) (result *v1beta1.ThirdPartyResource, err error) { + result = &v1beta1.ThirdPartyResource{} err = c.client.Put(). Resource("thirdpartyresources"). Name(thirdPartyResource.Name). @@ -77,7 +79,7 @@ func (c *thirdPartyResources) Update(thirdPartyResource *extensions.ThirdPartyRe } // Delete takes name of the thirdPartyResource and deletes it. Returns an error if one occurs. -func (c *thirdPartyResources) Delete(name string, options *api.DeleteOptions) error { +func (c *thirdPartyResources) Delete(name string, options *v1.DeleteOptions) error { return c.client.Delete(). Resource("thirdpartyresources"). Name(name). @@ -87,7 +89,7 @@ func (c *thirdPartyResources) Delete(name string, options *api.DeleteOptions) er } // DeleteCollection deletes a collection of objects. -func (c *thirdPartyResources) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { +func (c *thirdPartyResources) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { return c.client.Delete(). Resource("thirdpartyresources"). VersionedParams(&listOptions, api.ParameterCodec). @@ -97,8 +99,8 @@ func (c *thirdPartyResources) DeleteCollection(options *api.DeleteOptions, listO } // Get takes name of the thirdPartyResource, and returns the corresponding thirdPartyResource object, and an error if there is any. -func (c *thirdPartyResources) Get(name string) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} +func (c *thirdPartyResources) Get(name string) (result *v1beta1.ThirdPartyResource, err error) { + result = &v1beta1.ThirdPartyResource{} err = c.client.Get(). Resource("thirdpartyresources"). Name(name). @@ -108,8 +110,8 @@ func (c *thirdPartyResources) Get(name string) (result *extensions.ThirdPartyRes } // List takes label and field selectors, and returns the list of ThirdPartyResources that match those selectors. -func (c *thirdPartyResources) List(opts api.ListOptions) (result *extensions.ThirdPartyResourceList, err error) { - result = &extensions.ThirdPartyResourceList{} +func (c *thirdPartyResources) List(opts v1.ListOptions) (result *v1beta1.ThirdPartyResourceList, err error) { + result = &v1beta1.ThirdPartyResourceList{} err = c.client.Get(). Resource("thirdpartyresources"). VersionedParams(&opts, api.ParameterCodec). @@ -119,7 +121,7 @@ func (c *thirdPartyResources) List(opts api.ListOptions) (result *extensions.Thi } // Watch returns a watch.Interface that watches the requested thirdPartyResources. -func (c *thirdPartyResources) Watch(opts api.ListOptions) (watch.Interface, error) { +func (c *thirdPartyResources) Watch(opts v1.ListOptions) (watch.Interface, error) { return c.client.Get(). Prefix("watch"). Resource("thirdpartyresources"). @@ -128,8 +130,8 @@ func (c *thirdPartyResources) Watch(opts api.ListOptions) (watch.Interface, erro } // Patch applies the patch and returns the patched thirdPartyResource. -func (c *thirdPartyResources) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} +func (c *thirdPartyResources) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.ThirdPartyResource, err error) { + result = &v1beta1.ThirdPartyResource{} err = c.client.Patch(pt). Resource("thirdpartyresources"). SubResource(subresources...). diff --git a/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/doc.go new file mode 100644 index 0000000..0c1ca41 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1alpha1 diff --git a/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/generated_expansion.go new file mode 100644 index 0000000..a2e74c8 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/generated_expansion.go @@ -0,0 +1,19 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +type PodDisruptionBudgetExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/poddisruptionbudget.go b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/poddisruptionbudget.go new file mode 100644 index 0000000..3618bba --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/poddisruptionbudget.go @@ -0,0 +1,167 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/policy/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// PodDisruptionBudgetsGetter has a method to return a PodDisruptionBudgetInterface. +// A group's client should implement this interface. +type PodDisruptionBudgetsGetter interface { + PodDisruptionBudgets(namespace string) PodDisruptionBudgetInterface +} + +// PodDisruptionBudgetInterface has methods to work with PodDisruptionBudget resources. +type PodDisruptionBudgetInterface interface { + Create(*v1alpha1.PodDisruptionBudget) (*v1alpha1.PodDisruptionBudget, error) + Update(*v1alpha1.PodDisruptionBudget) (*v1alpha1.PodDisruptionBudget, error) + UpdateStatus(*v1alpha1.PodDisruptionBudget) (*v1alpha1.PodDisruptionBudget, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.PodDisruptionBudget, error) + List(opts v1.ListOptions) (*v1alpha1.PodDisruptionBudgetList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.PodDisruptionBudget, err error) + PodDisruptionBudgetExpansion +} + +// podDisruptionBudgets implements PodDisruptionBudgetInterface +type podDisruptionBudgets struct { + client rest.Interface + ns string +} + +// newPodDisruptionBudgets returns a PodDisruptionBudgets +func newPodDisruptionBudgets(c *PolicyClient, namespace string) *podDisruptionBudgets { + return &podDisruptionBudgets{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a podDisruptionBudget and creates it. Returns the server's representation of the podDisruptionBudget, and an error, if there is any. +func (c *podDisruptionBudgets) Create(podDisruptionBudget *v1alpha1.PodDisruptionBudget) (result *v1alpha1.PodDisruptionBudget, err error) { + result = &v1alpha1.PodDisruptionBudget{} + err = c.client.Post(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + Body(podDisruptionBudget). + Do(). + Into(result) + return +} + +// Update takes the representation of a podDisruptionBudget and updates it. Returns the server's representation of the podDisruptionBudget, and an error, if there is any. +func (c *podDisruptionBudgets) Update(podDisruptionBudget *v1alpha1.PodDisruptionBudget) (result *v1alpha1.PodDisruptionBudget, err error) { + result = &v1alpha1.PodDisruptionBudget{} + err = c.client.Put(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + Name(podDisruptionBudget.Name). + Body(podDisruptionBudget). + Do(). + Into(result) + return +} + +func (c *podDisruptionBudgets) UpdateStatus(podDisruptionBudget *v1alpha1.PodDisruptionBudget) (result *v1alpha1.PodDisruptionBudget, err error) { + result = &v1alpha1.PodDisruptionBudget{} + err = c.client.Put(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + Name(podDisruptionBudget.Name). + SubResource("status"). + Body(podDisruptionBudget). + Do(). + Into(result) + return +} + +// Delete takes name of the podDisruptionBudget and deletes it. Returns an error if one occurs. +func (c *podDisruptionBudgets) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *podDisruptionBudgets) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the podDisruptionBudget, and returns the corresponding podDisruptionBudget object, and an error if there is any. +func (c *podDisruptionBudgets) Get(name string) (result *v1alpha1.PodDisruptionBudget, err error) { + result = &v1alpha1.PodDisruptionBudget{} + err = c.client.Get(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of PodDisruptionBudgets that match those selectors. +func (c *podDisruptionBudgets) List(opts v1.ListOptions) (result *v1alpha1.PodDisruptionBudgetList, err error) { + result = &v1alpha1.PodDisruptionBudgetList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested podDisruptionBudgets. +func (c *podDisruptionBudgets) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched podDisruptionBudget. +func (c *podDisruptionBudgets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.PodDisruptionBudget, err error) { + result = &v1alpha1.PodDisruptionBudget{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("poddisruptionbudgets"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/policy_client.go b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/policy_client.go new file mode 100644 index 0000000..6d48a07 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/policy/v1alpha1/policy_client.go @@ -0,0 +1,96 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type PolicyInterface interface { + RESTClient() rest.Interface + PodDisruptionBudgetsGetter +} + +// PolicyClient is used to interact with features provided by the Policy group. +type PolicyClient struct { + restClient rest.Interface +} + +func (c *PolicyClient) PodDisruptionBudgets(namespace string) PodDisruptionBudgetInterface { + return newPodDisruptionBudgets(c, namespace) +} + +// NewForConfig creates a new PolicyClient for the given config. +func NewForConfig(c *rest.Config) (*PolicyClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &PolicyClient{client}, nil +} + +// NewForConfigOrDie creates a new PolicyClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *PolicyClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new PolicyClient for the given RESTClient. +func New(c rest.Interface) *PolicyClient { + return &PolicyClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if policy group is not registered, return an error + g, err := registered.Group("policy") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *PolicyClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrole.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrole.go new file mode 100644 index 0000000..d62f5ed --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrole.go @@ -0,0 +1,143 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/rbac/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// ClusterRolesGetter has a method to return a ClusterRoleInterface. +// A group's client should implement this interface. +type ClusterRolesGetter interface { + ClusterRoles() ClusterRoleInterface +} + +// ClusterRoleInterface has methods to work with ClusterRole resources. +type ClusterRoleInterface interface { + Create(*v1alpha1.ClusterRole) (*v1alpha1.ClusterRole, error) + Update(*v1alpha1.ClusterRole) (*v1alpha1.ClusterRole, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.ClusterRole, error) + List(opts v1.ListOptions) (*v1alpha1.ClusterRoleList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.ClusterRole, err error) + ClusterRoleExpansion +} + +// clusterRoles implements ClusterRoleInterface +type clusterRoles struct { + client rest.Interface +} + +// newClusterRoles returns a ClusterRoles +func newClusterRoles(c *RbacClient) *clusterRoles { + return &clusterRoles{ + client: c.RESTClient(), + } +} + +// Create takes the representation of a clusterRole and creates it. Returns the server's representation of the clusterRole, and an error, if there is any. +func (c *clusterRoles) Create(clusterRole *v1alpha1.ClusterRole) (result *v1alpha1.ClusterRole, err error) { + result = &v1alpha1.ClusterRole{} + err = c.client.Post(). + Resource("clusterroles"). + Body(clusterRole). + Do(). + Into(result) + return +} + +// Update takes the representation of a clusterRole and updates it. Returns the server's representation of the clusterRole, and an error, if there is any. +func (c *clusterRoles) Update(clusterRole *v1alpha1.ClusterRole) (result *v1alpha1.ClusterRole, err error) { + result = &v1alpha1.ClusterRole{} + err = c.client.Put(). + Resource("clusterroles"). + Name(clusterRole.Name). + Body(clusterRole). + Do(). + Into(result) + return +} + +// Delete takes name of the clusterRole and deletes it. Returns an error if one occurs. +func (c *clusterRoles) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Resource("clusterroles"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *clusterRoles) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Resource("clusterroles"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the clusterRole, and returns the corresponding clusterRole object, and an error if there is any. +func (c *clusterRoles) Get(name string) (result *v1alpha1.ClusterRole, err error) { + result = &v1alpha1.ClusterRole{} + err = c.client.Get(). + Resource("clusterroles"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of ClusterRoles that match those selectors. +func (c *clusterRoles) List(opts v1.ListOptions) (result *v1alpha1.ClusterRoleList, err error) { + result = &v1alpha1.ClusterRoleList{} + err = c.client.Get(). + Resource("clusterroles"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested clusterRoles. +func (c *clusterRoles) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Resource("clusterroles"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched clusterRole. +func (c *clusterRoles) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.ClusterRole, err error) { + result = &v1alpha1.ClusterRole{} + err = c.client.Patch(pt). + Resource("clusterroles"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrolebinding.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrolebinding.go new file mode 100644 index 0000000..d068327 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/clusterrolebinding.go @@ -0,0 +1,143 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/rbac/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// ClusterRoleBindingsGetter has a method to return a ClusterRoleBindingInterface. +// A group's client should implement this interface. +type ClusterRoleBindingsGetter interface { + ClusterRoleBindings() ClusterRoleBindingInterface +} + +// ClusterRoleBindingInterface has methods to work with ClusterRoleBinding resources. +type ClusterRoleBindingInterface interface { + Create(*v1alpha1.ClusterRoleBinding) (*v1alpha1.ClusterRoleBinding, error) + Update(*v1alpha1.ClusterRoleBinding) (*v1alpha1.ClusterRoleBinding, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.ClusterRoleBinding, error) + List(opts v1.ListOptions) (*v1alpha1.ClusterRoleBindingList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.ClusterRoleBinding, err error) + ClusterRoleBindingExpansion +} + +// clusterRoleBindings implements ClusterRoleBindingInterface +type clusterRoleBindings struct { + client rest.Interface +} + +// newClusterRoleBindings returns a ClusterRoleBindings +func newClusterRoleBindings(c *RbacClient) *clusterRoleBindings { + return &clusterRoleBindings{ + client: c.RESTClient(), + } +} + +// Create takes the representation of a clusterRoleBinding and creates it. Returns the server's representation of the clusterRoleBinding, and an error, if there is any. +func (c *clusterRoleBindings) Create(clusterRoleBinding *v1alpha1.ClusterRoleBinding) (result *v1alpha1.ClusterRoleBinding, err error) { + result = &v1alpha1.ClusterRoleBinding{} + err = c.client.Post(). + Resource("clusterrolebindings"). + Body(clusterRoleBinding). + Do(). + Into(result) + return +} + +// Update takes the representation of a clusterRoleBinding and updates it. Returns the server's representation of the clusterRoleBinding, and an error, if there is any. +func (c *clusterRoleBindings) Update(clusterRoleBinding *v1alpha1.ClusterRoleBinding) (result *v1alpha1.ClusterRoleBinding, err error) { + result = &v1alpha1.ClusterRoleBinding{} + err = c.client.Put(). + Resource("clusterrolebindings"). + Name(clusterRoleBinding.Name). + Body(clusterRoleBinding). + Do(). + Into(result) + return +} + +// Delete takes name of the clusterRoleBinding and deletes it. Returns an error if one occurs. +func (c *clusterRoleBindings) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Resource("clusterrolebindings"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *clusterRoleBindings) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Resource("clusterrolebindings"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the clusterRoleBinding, and returns the corresponding clusterRoleBinding object, and an error if there is any. +func (c *clusterRoleBindings) Get(name string) (result *v1alpha1.ClusterRoleBinding, err error) { + result = &v1alpha1.ClusterRoleBinding{} + err = c.client.Get(). + Resource("clusterrolebindings"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of ClusterRoleBindings that match those selectors. +func (c *clusterRoleBindings) List(opts v1.ListOptions) (result *v1alpha1.ClusterRoleBindingList, err error) { + result = &v1alpha1.ClusterRoleBindingList{} + err = c.client.Get(). + Resource("clusterrolebindings"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested clusterRoleBindings. +func (c *clusterRoleBindings) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Resource("clusterrolebindings"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched clusterRoleBinding. +func (c *clusterRoleBindings) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.ClusterRoleBinding, err error) { + result = &v1alpha1.ClusterRoleBinding{} + err = c.client.Patch(pt). + Resource("clusterrolebindings"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/doc.go new file mode 100644 index 0000000..0c1ca41 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/generated_expansion.go similarity index 79% rename from vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/doc.go rename to vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/generated_expansion.go index 233f24f..86def26 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/doc.go +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/generated_expansion.go @@ -14,8 +14,12 @@ See the License for the specific language governing permissions and limitations under the License. */ -// +k8s:deepcopy-gen=package,register -// +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/componentconfig -// +k8s:openapi-gen=true - package v1alpha1 + +type ClusterRoleExpansion interface{} + +type ClusterRoleBindingExpansion interface{} + +type RoleExpansion interface{} + +type RoleBindingExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rbac_client.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rbac_client.go new file mode 100644 index 0000000..47814d0 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rbac_client.go @@ -0,0 +1,111 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type RbacInterface interface { + RESTClient() rest.Interface + ClusterRolesGetter + ClusterRoleBindingsGetter + RolesGetter + RoleBindingsGetter +} + +// RbacClient is used to interact with features provided by the Rbac group. +type RbacClient struct { + restClient rest.Interface +} + +func (c *RbacClient) ClusterRoles() ClusterRoleInterface { + return newClusterRoles(c) +} + +func (c *RbacClient) ClusterRoleBindings() ClusterRoleBindingInterface { + return newClusterRoleBindings(c) +} + +func (c *RbacClient) Roles(namespace string) RoleInterface { + return newRoles(c, namespace) +} + +func (c *RbacClient) RoleBindings(namespace string) RoleBindingInterface { + return newRoleBindings(c, namespace) +} + +// NewForConfig creates a new RbacClient for the given config. +func NewForConfig(c *rest.Config) (*RbacClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &RbacClient{client}, nil +} + +// NewForConfigOrDie creates a new RbacClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *RbacClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new RbacClient for the given RESTClient. +func New(c rest.Interface) *RbacClient { + return &RbacClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if rbac group is not registered, return an error + g, err := registered.Group("rbac.authorization.k8s.io") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *RbacClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/role.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/role.go new file mode 100644 index 0000000..49e8d8a --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/role.go @@ -0,0 +1,153 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/rbac/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// RolesGetter has a method to return a RoleInterface. +// A group's client should implement this interface. +type RolesGetter interface { + Roles(namespace string) RoleInterface +} + +// RoleInterface has methods to work with Role resources. +type RoleInterface interface { + Create(*v1alpha1.Role) (*v1alpha1.Role, error) + Update(*v1alpha1.Role) (*v1alpha1.Role, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.Role, error) + List(opts v1.ListOptions) (*v1alpha1.RoleList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.Role, err error) + RoleExpansion +} + +// roles implements RoleInterface +type roles struct { + client rest.Interface + ns string +} + +// newRoles returns a Roles +func newRoles(c *RbacClient, namespace string) *roles { + return &roles{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a role and creates it. Returns the server's representation of the role, and an error, if there is any. +func (c *roles) Create(role *v1alpha1.Role) (result *v1alpha1.Role, err error) { + result = &v1alpha1.Role{} + err = c.client.Post(). + Namespace(c.ns). + Resource("roles"). + Body(role). + Do(). + Into(result) + return +} + +// Update takes the representation of a role and updates it. Returns the server's representation of the role, and an error, if there is any. +func (c *roles) Update(role *v1alpha1.Role) (result *v1alpha1.Role, err error) { + result = &v1alpha1.Role{} + err = c.client.Put(). + Namespace(c.ns). + Resource("roles"). + Name(role.Name). + Body(role). + Do(). + Into(result) + return +} + +// Delete takes name of the role and deletes it. Returns an error if one occurs. +func (c *roles) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("roles"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *roles) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("roles"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the role, and returns the corresponding role object, and an error if there is any. +func (c *roles) Get(name string) (result *v1alpha1.Role, err error) { + result = &v1alpha1.Role{} + err = c.client.Get(). + Namespace(c.ns). + Resource("roles"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of Roles that match those selectors. +func (c *roles) List(opts v1.ListOptions) (result *v1alpha1.RoleList, err error) { + result = &v1alpha1.RoleList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("roles"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested roles. +func (c *roles) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("roles"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched role. +func (c *roles) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.Role, err error) { + result = &v1alpha1.Role{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("roles"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rolebinding.go b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rolebinding.go new file mode 100644 index 0000000..c1792d4 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/rbac/v1alpha1/rolebinding.go @@ -0,0 +1,153 @@ +/* +Copyright 2016 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. +*/ + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1alpha1 "k8s.io/client-go/pkg/apis/rbac/v1alpha1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// RoleBindingsGetter has a method to return a RoleBindingInterface. +// A group's client should implement this interface. +type RoleBindingsGetter interface { + RoleBindings(namespace string) RoleBindingInterface +} + +// RoleBindingInterface has methods to work with RoleBinding resources. +type RoleBindingInterface interface { + Create(*v1alpha1.RoleBinding) (*v1alpha1.RoleBinding, error) + Update(*v1alpha1.RoleBinding) (*v1alpha1.RoleBinding, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1alpha1.RoleBinding, error) + List(opts v1.ListOptions) (*v1alpha1.RoleBindingList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.RoleBinding, err error) + RoleBindingExpansion +} + +// roleBindings implements RoleBindingInterface +type roleBindings struct { + client rest.Interface + ns string +} + +// newRoleBindings returns a RoleBindings +func newRoleBindings(c *RbacClient, namespace string) *roleBindings { + return &roleBindings{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Create takes the representation of a roleBinding and creates it. Returns the server's representation of the roleBinding, and an error, if there is any. +func (c *roleBindings) Create(roleBinding *v1alpha1.RoleBinding) (result *v1alpha1.RoleBinding, err error) { + result = &v1alpha1.RoleBinding{} + err = c.client.Post(). + Namespace(c.ns). + Resource("rolebindings"). + Body(roleBinding). + Do(). + Into(result) + return +} + +// Update takes the representation of a roleBinding and updates it. Returns the server's representation of the roleBinding, and an error, if there is any. +func (c *roleBindings) Update(roleBinding *v1alpha1.RoleBinding) (result *v1alpha1.RoleBinding, err error) { + result = &v1alpha1.RoleBinding{} + err = c.client.Put(). + Namespace(c.ns). + Resource("rolebindings"). + Name(roleBinding.Name). + Body(roleBinding). + Do(). + Into(result) + return +} + +// Delete takes name of the roleBinding and deletes it. Returns an error if one occurs. +func (c *roleBindings) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("rolebindings"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *roleBindings) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("rolebindings"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the roleBinding, and returns the corresponding roleBinding object, and an error if there is any. +func (c *roleBindings) Get(name string) (result *v1alpha1.RoleBinding, err error) { + result = &v1alpha1.RoleBinding{} + err = c.client.Get(). + Namespace(c.ns). + Resource("rolebindings"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of RoleBindings that match those selectors. +func (c *roleBindings) List(opts v1.ListOptions) (result *v1alpha1.RoleBindingList, err error) { + result = &v1alpha1.RoleBindingList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("rolebindings"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested roleBindings. +func (c *roleBindings) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Namespace(c.ns). + Resource("rolebindings"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched roleBinding. +func (c *roleBindings) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1alpha1.RoleBinding, err error) { + result = &v1alpha1.RoleBinding{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("rolebindings"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/doc.go b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/doc.go new file mode 100644 index 0000000..5616c95 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/doc.go @@ -0,0 +1,20 @@ +/* +Copyright 2016 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. +*/ + +// This package is generated by client-gen with arguments: --clientset-name=release_1_5 --input=[api/v1,apps/v1alpha1,authentication/v1beta1,authorization/v1beta1,autoscaling/v1,batch/v1,certificates/v1alpha1,extensions/v1beta1,policy/v1alpha1,rbac/v1alpha1,storage/v1beta1] + +// This package has the automatically generated typed clients. +package v1beta1 diff --git a/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/generated_expansion.go b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/generated_expansion.go new file mode 100644 index 0000000..b18dda0 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/generated_expansion.go @@ -0,0 +1,19 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +type StorageClassExpansion interface{} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storage_client.go b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storage_client.go new file mode 100644 index 0000000..bb63944 --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storage_client.go @@ -0,0 +1,96 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + api "k8s.io/client-go/pkg/api" + registered "k8s.io/client-go/pkg/apimachinery/registered" + serializer "k8s.io/client-go/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type StorageInterface interface { + RESTClient() rest.Interface + StorageClassesGetter +} + +// StorageClient is used to interact with features provided by the Storage group. +type StorageClient struct { + restClient rest.Interface +} + +func (c *StorageClient) StorageClasses() StorageClassInterface { + return newStorageClasses(c) +} + +// NewForConfig creates a new StorageClient for the given config. +func NewForConfig(c *rest.Config) (*StorageClient, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &StorageClient{client}, nil +} + +// NewForConfigOrDie creates a new StorageClient for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *StorageClient { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new StorageClient for the given RESTClient. +func New(c rest.Interface) *StorageClient { + return &StorageClient{c} +} + +func setConfigDefaults(config *rest.Config) error { + // if storage group is not registered, return an error + g, err := registered.Group("storage.k8s.io") + if err != nil { + return err + } + config.APIPath = "/apis" + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + // TODO: Unconditionally set the config.Version, until we fix the config. + //if config.Version == "" { + copyGroupVersion := g.GroupVersion + config.GroupVersion = ©GroupVersion + //} + + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: api.Codecs} + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *StorageClient) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storageclass.go b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storageclass.go new file mode 100644 index 0000000..3c37b9e --- /dev/null +++ b/vendor/k8s.io/client-go/kubernetes/typed/storage/v1beta1/storageclass.go @@ -0,0 +1,143 @@ +/* +Copyright 2016 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. +*/ + +package v1beta1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + v1beta1 "k8s.io/client-go/pkg/apis/storage/v1beta1" + watch "k8s.io/client-go/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// StorageClassesGetter has a method to return a StorageClassInterface. +// A group's client should implement this interface. +type StorageClassesGetter interface { + StorageClasses() StorageClassInterface +} + +// StorageClassInterface has methods to work with StorageClass resources. +type StorageClassInterface interface { + Create(*v1beta1.StorageClass) (*v1beta1.StorageClass, error) + Update(*v1beta1.StorageClass) (*v1beta1.StorageClass, error) + Delete(name string, options *v1.DeleteOptions) error + DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error + Get(name string) (*v1beta1.StorageClass, error) + List(opts v1.ListOptions) (*v1beta1.StorageClassList, error) + Watch(opts v1.ListOptions) (watch.Interface, error) + Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.StorageClass, err error) + StorageClassExpansion +} + +// storageClasses implements StorageClassInterface +type storageClasses struct { + client rest.Interface +} + +// newStorageClasses returns a StorageClasses +func newStorageClasses(c *StorageClient) *storageClasses { + return &storageClasses{ + client: c.RESTClient(), + } +} + +// Create takes the representation of a storageClass and creates it. Returns the server's representation of the storageClass, and an error, if there is any. +func (c *storageClasses) Create(storageClass *v1beta1.StorageClass) (result *v1beta1.StorageClass, err error) { + result = &v1beta1.StorageClass{} + err = c.client.Post(). + Resource("storageclasses"). + Body(storageClass). + Do(). + Into(result) + return +} + +// Update takes the representation of a storageClass and updates it. Returns the server's representation of the storageClass, and an error, if there is any. +func (c *storageClasses) Update(storageClass *v1beta1.StorageClass) (result *v1beta1.StorageClass, err error) { + result = &v1beta1.StorageClass{} + err = c.client.Put(). + Resource("storageclasses"). + Name(storageClass.Name). + Body(storageClass). + Do(). + Into(result) + return +} + +// Delete takes name of the storageClass and deletes it. Returns an error if one occurs. +func (c *storageClasses) Delete(name string, options *v1.DeleteOptions) error { + return c.client.Delete(). + Resource("storageclasses"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *storageClasses) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + return c.client.Delete(). + Resource("storageclasses"). + VersionedParams(&listOptions, api.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Get takes name of the storageClass, and returns the corresponding storageClass object, and an error if there is any. +func (c *storageClasses) Get(name string) (result *v1beta1.StorageClass, err error) { + result = &v1beta1.StorageClass{} + err = c.client.Get(). + Resource("storageclasses"). + Name(name). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of StorageClasses that match those selectors. +func (c *storageClasses) List(opts v1.ListOptions) (result *v1beta1.StorageClassList, err error) { + result = &v1beta1.StorageClassList{} + err = c.client.Get(). + Resource("storageclasses"). + VersionedParams(&opts, api.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested storageClasses. +func (c *storageClasses) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.client.Get(). + Prefix("watch"). + Resource("storageclasses"). + VersionedParams(&opts, api.ParameterCodec). + Watch() +} + +// Patch applies the patch and returns the patched storageClass. +func (c *storageClasses) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *v1beta1.StorageClass, err error) { + result = &v1beta1.StorageClass{} + err = c.client.Patch(pt). + Resource("storageclasses"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/vendor/k8s.io/kubernetes/pkg/api/OWNERS b/vendor/k8s.io/client-go/pkg/api/OWNERS similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/OWNERS rename to vendor/k8s.io/client-go/pkg/api/OWNERS diff --git a/vendor/k8s.io/kubernetes/pkg/api/context.go b/vendor/k8s.io/client-go/pkg/api/context.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/context.go rename to vendor/k8s.io/client-go/pkg/api/context.go index 0f735f4..71e0e2d 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/context.go +++ b/vendor/k8s.io/client-go/pkg/api/context.go @@ -21,8 +21,8 @@ import ( "time" "golang.org/x/net/context" - "k8s.io/kubernetes/pkg/auth/user" - "k8s.io/kubernetes/pkg/types" + "k8s.io/client-go/pkg/auth/user" + "k8s.io/client-go/pkg/types" ) // Context carries values across API boundaries. diff --git a/vendor/k8s.io/kubernetes/pkg/api/conversion.go b/vendor/k8s.io/client-go/pkg/api/conversion.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/api/conversion.go rename to vendor/k8s.io/client-go/pkg/api/conversion.go index 4a9f50b..3ff0a15 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/conversion.go +++ b/vendor/k8s.io/client-go/pkg/api/conversion.go @@ -19,15 +19,15 @@ package api import ( "fmt" - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/intstr" - utillabels "k8s.io/kubernetes/pkg/util/labels" - "k8s.io/kubernetes/pkg/util/validation/field" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/intstr" + utillabels "k8s.io/client-go/pkg/util/labels" + "k8s.io/client-go/pkg/util/validation/field" ) func addConversionFuncs(scheme *runtime.Scheme) error { @@ -153,6 +153,7 @@ func Convert_bool_To_Pointer_bool(in *bool, out **bool, s conversion.Scope) erro return nil } +// +k8s:conversion-fn=drop func Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(in, out *unversioned.TypeMeta, s conversion.Scope) error { // These values are explicitly not copied //out.APIVersion = in.APIVersion @@ -160,16 +161,19 @@ func Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(in, out *unversioned.T return nil } +// +k8s:conversion-fn=copy-only func Convert_unversioned_ListMeta_To_unversioned_ListMeta(in, out *unversioned.ListMeta, s conversion.Scope) error { *out = *in return nil } +// +k8s:conversion-fn=copy-only func Convert_intstr_IntOrString_To_intstr_IntOrString(in, out *intstr.IntOrString, s conversion.Scope) error { *out = *in return nil } +// +k8s:conversion-fn=copy-only func Convert_unversioned_Time_To_unversioned_Time(in *unversioned.Time, out *unversioned.Time, s conversion.Scope) error { // Cannot deep copy these, because time.Time has unexported fields. *out = *in @@ -219,6 +223,7 @@ func Convert_fields_Selector_To_string(in *fields.Selector, out *string, s conve return nil } +// +k8s:conversion-fn=copy-only func Convert_resource_Quantity_To_resource_Quantity(in *resource.Quantity, out *resource.Quantity, s conversion.Scope) error { *out = *in return nil diff --git a/vendor/k8s.io/kubernetes/pkg/api/defaults.go b/vendor/k8s.io/client-go/pkg/api/defaults.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/api/defaults.go rename to vendor/k8s.io/client-go/pkg/api/defaults.go index a2b01b7..745f610 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/defaults.go +++ b/vendor/k8s.io/client-go/pkg/api/defaults.go @@ -17,9 +17,9 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/api/doc.go b/vendor/k8s.io/client-go/pkg/api/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/doc.go rename to vendor/k8s.io/client-go/pkg/api/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/errors/doc.go b/vendor/k8s.io/client-go/pkg/api/errors/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/errors/doc.go rename to vendor/k8s.io/client-go/pkg/api/errors/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/errors/errors.go b/vendor/k8s.io/client-go/pkg/api/errors/errors.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/errors/errors.go rename to vendor/k8s.io/client-go/pkg/api/errors/errors.go index 8623b3a..accd8f4 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/errors/errors.go +++ b/vendor/k8s.io/client-go/pkg/api/errors/errors.go @@ -22,9 +22,9 @@ import ( "net/http" "strings" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/validation/field" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/validation/field" ) // HTTP Status codes not in the golang http package. diff --git a/vendor/k8s.io/kubernetes/pkg/api/field_constants.go b/vendor/k8s.io/client-go/pkg/api/field_constants.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/field_constants.go rename to vendor/k8s.io/client-go/pkg/api/field_constants.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/generate.go b/vendor/k8s.io/client-go/pkg/api/generate.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/generate.go rename to vendor/k8s.io/client-go/pkg/api/generate.go index 19379d3..a4a003b 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/generate.go +++ b/vendor/k8s.io/client-go/pkg/api/generate.go @@ -19,7 +19,7 @@ package api import ( "fmt" - utilrand "k8s.io/kubernetes/pkg/util/rand" + utilrand "k8s.io/client-go/pkg/util/rand" ) // NameGenerator generates names for objects. Some backends may have more information diff --git a/vendor/k8s.io/kubernetes/pkg/api/helpers.go b/vendor/k8s.io/client-go/pkg/api/helpers.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/api/helpers.go rename to vendor/k8s.io/client-go/pkg/api/helpers.go index e31bbdd..8f494c1 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/helpers.go +++ b/vendor/k8s.io/client-go/pkg/api/helpers.go @@ -24,15 +24,15 @@ import ( "strings" "time" - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/selection" - "k8s.io/kubernetes/pkg/types" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/selection" + "k8s.io/client-go/pkg/types" + "k8s.io/client-go/pkg/util/sets" "github.com/davecgh/go-spew/spew" ) @@ -120,6 +120,22 @@ func IsStandardContainerResourceName(str string) bool { return standardContainerResources.Has(str) } +// IsOpaqueIntResourceName returns true if the resource name has the opaque +// integer resource prefix. +func IsOpaqueIntResourceName(name ResourceName) bool { + return strings.HasPrefix(string(name), ResourceOpaqueIntPrefix) +} + +// OpaqueIntResourceName returns a ResourceName with the canonical opaque +// integer prefix prepended. If the argument already has the prefix, it is +// returned unmodified. +func OpaqueIntResourceName(name string) ResourceName { + if IsOpaqueIntResourceName(ResourceName(name)) { + return ResourceName(name) + } + return ResourceName(fmt.Sprintf("%s%s", ResourceOpaqueIntPrefix, name)) +} + var standardLimitRangeTypes = sets.NewString( string(LimitTypePod), string(LimitTypeContainer), @@ -171,6 +187,7 @@ var standardResources = sets.NewString( string(ResourceConfigMaps), string(ResourcePersistentVolumeClaims), string(ResourceStorage), + string(ResourceRequestsStorage), ) // IsStandardResourceName returns true if the resource is known to the system @@ -192,7 +209,7 @@ var integerResources = sets.NewString( // IsIntegerResourceName returns true if the resource is measured in integer values func IsIntegerResourceName(str string) bool { - return integerResources.Has(str) + return integerResources.Has(str) || IsOpaqueIntResourceName(ResourceName(str)) } // NewDeleteOptions returns a DeleteOptions indicating the resource should @@ -236,6 +253,20 @@ var standardFinalizers = sets.NewString( FinalizerOrphan, ) +// HasAnnotation returns a bool if passed in annotation exists +func HasAnnotation(obj ObjectMeta, ann string) bool { + _, found := obj.Annotations[ann] + return found +} + +// SetMetaDataAnnotation sets the annotation and value +func SetMetaDataAnnotation(obj *ObjectMeta, ann string, value string) { + if obj.Annotations == nil { + obj.Annotations = make(map[string]string) + } + obj.Annotations[ann] = value +} + func IsStandardFinalizerName(str string) bool { return standardFinalizers.Has(str) } @@ -402,7 +433,7 @@ func NodeSelectorRequirementsAsSelector(nsm []NodeSelectorRequirement) (labels.S default: return nil, fmt.Errorf("%q is not a valid node selector operator", expr.Operator) } - r, err := labels.NewRequirement(expr.Key, op, sets.NewString(expr.Values...)) + r, err := labels.NewRequirement(expr.Key, op, expr.Values) if err != nil { return nil, err } @@ -512,7 +543,6 @@ func TolerationToleratesTaint(toleration *Toleration, taint *Taint) bool { return true } return false - } // TaintToleratedByTolerations checks if taint is tolerated by any of the tolerations. diff --git a/vendor/k8s.io/kubernetes/pkg/api/install/install.go b/vendor/k8s.io/client-go/pkg/api/install/install.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/api/install/install.go rename to vendor/k8s.io/client-go/pkg/api/install/install.go index 644daad..e41dd63 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/install/install.go +++ b/vendor/k8s.io/client-go/pkg/api/install/install.go @@ -23,17 +23,17 @@ import ( "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/apimachinery" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/apimachinery" + "k8s.io/client-go/pkg/apimachinery/registered" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/sets" ) -const importPrefix = "k8s.io/kubernetes/pkg/api" +const importPrefix = "k8s.io/client-go/pkg/api" var accessor = meta.NewAccessor() diff --git a/vendor/k8s.io/kubernetes/pkg/api/mapper.go b/vendor/k8s.io/client-go/pkg/api/mapper.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/api/mapper.go rename to vendor/k8s.io/client-go/pkg/api/mapper.go index c5743c4..db72bdf 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/mapper.go +++ b/vendor/k8s.io/client-go/pkg/api/mapper.go @@ -19,10 +19,10 @@ package api import ( "strings" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/sets" ) // Instantiates a DefaultRESTMapper based on types registered in api.Scheme diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta.go b/vendor/k8s.io/client-go/pkg/api/meta.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/meta.go rename to vendor/k8s.io/client-go/pkg/api/meta.go index a05d694..0f76d94 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta.go +++ b/vendor/k8s.io/client-go/pkg/api/meta.go @@ -17,13 +17,13 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/meta/metatypes" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/types" - "k8s.io/kubernetes/pkg/util/uuid" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/meta/metatypes" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/types" + "k8s.io/client-go/pkg/util/uuid" ) // FillObjectMetaSystemFields populates fields that are managed by the system on ObjectMeta. diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/doc.go b/vendor/k8s.io/client-go/pkg/api/meta/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/meta/doc.go rename to vendor/k8s.io/client-go/pkg/api/meta/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/errors.go b/vendor/k8s.io/client-go/pkg/api/meta/errors.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/meta/errors.go rename to vendor/k8s.io/client-go/pkg/api/meta/errors.go index 7045296..9de77d6 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/errors.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/errors.go @@ -19,7 +19,7 @@ package meta import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // AmbiguousResourceError is returned if the RESTMapper finds multiple matches for a resource diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/firsthit_restmapper.go b/vendor/k8s.io/client-go/pkg/api/meta/firsthit_restmapper.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/api/meta/firsthit_restmapper.go rename to vendor/k8s.io/client-go/pkg/api/meta/firsthit_restmapper.go index 8a21b54..3c576db 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/firsthit_restmapper.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/firsthit_restmapper.go @@ -19,8 +19,8 @@ package meta import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" - utilerrors "k8s.io/kubernetes/pkg/util/errors" + "k8s.io/client-go/pkg/api/unversioned" + utilerrors "k8s.io/client-go/pkg/util/errors" ) // FirstHitRESTMapper is a wrapper for multiple RESTMappers which returns the diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/help.go b/vendor/k8s.io/client-go/pkg/api/meta/help.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/meta/help.go rename to vendor/k8s.io/client-go/pkg/api/meta/help.go index 0d733a5..4a45c8c 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/help.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/help.go @@ -20,8 +20,8 @@ import ( "fmt" "reflect" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" ) // IsListType returns true if the provided Object has a slice called Items diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/interfaces.go b/vendor/k8s.io/client-go/pkg/api/meta/interfaces.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/api/meta/interfaces.go rename to vendor/k8s.io/client-go/pkg/api/meta/interfaces.go index 488f78d..6dd5700 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/interfaces.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/interfaces.go @@ -17,10 +17,10 @@ limitations under the License. package meta import ( - "k8s.io/kubernetes/pkg/api/meta/metatypes" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/types" + "k8s.io/client-go/pkg/api/meta/metatypes" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/types" ) // VersionInterfaces contains the interfaces one should use for dealing with types of a particular version. diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/meta.go b/vendor/k8s.io/client-go/pkg/api/meta/meta.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/meta/meta.go rename to vendor/k8s.io/client-go/pkg/api/meta/meta.go index 876aa4f..9f11215 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/meta.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/meta.go @@ -20,11 +20,11 @@ import ( "fmt" "reflect" - "k8s.io/kubernetes/pkg/api/meta/metatypes" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/types" + "k8s.io/client-go/pkg/api/meta/metatypes" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/types" "github.com/golang/glog" ) diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/metatypes/types.go b/vendor/k8s.io/client-go/pkg/api/meta/metatypes/types.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/api/meta/metatypes/types.go rename to vendor/k8s.io/client-go/pkg/api/meta/metatypes/types.go index 41e6596..70b5aad 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/metatypes/types.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/metatypes/types.go @@ -19,7 +19,7 @@ limitations under the License. // API objects because it causes import cycle. package metatypes -import "k8s.io/kubernetes/pkg/types" +import "k8s.io/client-go/pkg/types" type OwnerReference struct { APIVersion string diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/multirestmapper.go b/vendor/k8s.io/client-go/pkg/api/meta/multirestmapper.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/meta/multirestmapper.go rename to vendor/k8s.io/client-go/pkg/api/meta/multirestmapper.go index 7b239e0..c8ee8d1 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/multirestmapper.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/multirestmapper.go @@ -20,9 +20,9 @@ import ( "fmt" "strings" - "k8s.io/kubernetes/pkg/api/unversioned" - utilerrors "k8s.io/kubernetes/pkg/util/errors" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api/unversioned" + utilerrors "k8s.io/client-go/pkg/util/errors" + "k8s.io/client-go/pkg/util/sets" ) // MultiRESTMapper is a wrapper for multiple RESTMappers. diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/priority.go b/vendor/k8s.io/client-go/pkg/api/meta/priority.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/meta/priority.go rename to vendor/k8s.io/client-go/pkg/api/meta/priority.go index 2e46060..b0ba309 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/priority.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/priority.go @@ -19,7 +19,7 @@ package meta import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) const ( diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/restmapper.go b/vendor/k8s.io/client-go/pkg/api/meta/restmapper.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/meta/restmapper.go rename to vendor/k8s.io/client-go/pkg/api/meta/restmapper.go index 19d0b25..98add7f 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/restmapper.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/restmapper.go @@ -22,8 +22,8 @@ import ( "sort" "strings" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // Implements RESTScope interface diff --git a/vendor/k8s.io/kubernetes/pkg/api/meta/unstructured.go b/vendor/k8s.io/client-go/pkg/api/meta/unstructured.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/api/meta/unstructured.go rename to vendor/k8s.io/client-go/pkg/api/meta/unstructured.go index 784cbf0..cb5a4e3 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/meta/unstructured.go +++ b/vendor/k8s.io/client-go/pkg/api/meta/unstructured.go @@ -17,8 +17,8 @@ limitations under the License. package meta import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // InterfacesForUnstructured returns VersionInterfaces suitable for diff --git a/vendor/k8s.io/kubernetes/pkg/api/ref.go b/vendor/k8s.io/client-go/pkg/api/ref.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/api/ref.go rename to vendor/k8s.io/client-go/pkg/api/ref.go index 443343a..afa8000 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/ref.go +++ b/vendor/k8s.io/client-go/pkg/api/ref.go @@ -22,9 +22,9 @@ import ( "net/url" "strings" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) var ( diff --git a/vendor/k8s.io/kubernetes/pkg/api/register.go b/vendor/k8s.io/client-go/pkg/api/register.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/api/register.go rename to vendor/k8s.io/client-go/pkg/api/register.go index 26cb658..d5533b4 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/register.go +++ b/vendor/k8s.io/client-go/pkg/api/register.go @@ -17,9 +17,9 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer" ) // Scheme is the default instance of runtime.Scheme to which types in the Kubernetes API are already registered. diff --git a/vendor/k8s.io/kubernetes/pkg/api/requestcontext.go b/vendor/k8s.io/client-go/pkg/api/requestcontext.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/requestcontext.go rename to vendor/k8s.io/client-go/pkg/api/requestcontext.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/amount.go b/vendor/k8s.io/client-go/pkg/api/resource/amount.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/amount.go rename to vendor/k8s.io/client-go/pkg/api/resource/amount.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/generated.pb.go b/vendor/k8s.io/client-go/pkg/api/resource/generated.pb.go similarity index 50% rename from vendor/k8s.io/kubernetes/pkg/api/resource/generated.pb.go rename to vendor/k8s.io/client-go/pkg/api/resource/generated.pb.go index 3bde152..d70ee30 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/resource/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/api/resource/generated.pb.go @@ -47,23 +47,24 @@ func (*Quantity) ProtoMessage() {} func (*Quantity) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{0} } func init() { - proto.RegisterType((*Quantity)(nil), "k8s.io.kubernetes.pkg.api.resource.Quantity") + proto.RegisterType((*Quantity)(nil), "k8s.io.client-go.pkg.api.resource.Quantity") } var fileDescriptorGenerated = []byte{ - // 222 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xe2, 0x32, 0xca, 0xb6, 0x28, 0xd6, - 0xcb, 0xcc, 0xd7, 0xcf, 0x2e, 0x4d, 0x4a, 0x2d, 0xca, 0x4b, 0x2d, 0x49, 0x2d, 0xd6, 0x2f, 0xc8, - 0x4e, 0xd7, 0x4f, 0x2c, 0xc8, 0xd4, 0x2f, 0x4a, 0x2d, 0xce, 0x2f, 0x2d, 0x4a, 0x4e, 0xd5, 0x4f, - 0x4f, 0xcd, 0x4b, 0x2d, 0x4a, 0x2c, 0x49, 0x4d, 0xd1, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x52, - 0x82, 0xe8, 0xd1, 0x43, 0xe8, 0xd1, 0x03, 0xea, 0xd1, 0x03, 0xea, 0xd1, 0x83, 0xe9, 0x91, 0xd2, - 0x4d, 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x4f, 0xcf, 0x4f, 0xcf, 0xd7, - 0x07, 0x6b, 0x4d, 0x2a, 0x4d, 0x03, 0xf3, 0xc0, 0x1c, 0x30, 0x0b, 0x62, 0xa4, 0x94, 0x21, 0x76, - 0x67, 0x94, 0x96, 0x64, 0xe6, 0xe8, 0x67, 0xe6, 0x95, 0x14, 0x97, 0x14, 0xa1, 0xbb, 0x42, 0xc9, - 0x82, 0x8b, 0x23, 0xb0, 0x34, 0x31, 0xaf, 0x24, 0xb3, 0xa4, 0x52, 0x48, 0x8c, 0x8b, 0x0d, 0xa8, - 0x24, 0x33, 0x2f, 0x5d, 0x82, 0x51, 0x81, 0x51, 0x83, 0x33, 0x08, 0xca, 0xb3, 0x12, 0x99, 0xb1, - 0x40, 0x9e, 0xa1, 0x63, 0xa1, 0x3c, 0xc3, 0x04, 0x20, 0x5e, 0x00, 0xc4, 0x0d, 0x77, 0x14, 0x18, - 0x9c, 0xb4, 0x4e, 0x3c, 0x94, 0x63, 0xb8, 0x00, 0xc4, 0x37, 0x80, 0xb8, 0xe1, 0x91, 0x1c, 0xe3, - 0x09, 0x20, 0xbe, 0x00, 0xc4, 0x0f, 0x80, 0x78, 0xc2, 0x63, 0x39, 0x86, 0x28, 0x0e, 0x98, 0x3f, - 0x00, 0x01, 0x00, 0x00, 0xff, 0xff, 0x90, 0x1c, 0x7f, 0xff, 0x20, 0x01, 0x00, 0x00, + // 236 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x6c, 0x8f, 0xa1, 0x4e, 0x03, 0x41, + 0x10, 0x86, 0x67, 0x0d, 0x29, 0x27, 0x1b, 0x42, 0x48, 0xc5, 0x5e, 0x53, 0x45, 0x48, 0xd8, 0x09, + 0xa8, 0x06, 0xc9, 0x1b, 0x80, 0xc4, 0xdd, 0x95, 0x61, 0x99, 0x1c, 0xec, 0x6e, 0x76, 0x67, 0x05, + 0xae, 0x12, 0x59, 0x89, 0xec, 0xbd, 0x4d, 0x65, 0x25, 0x02, 0xc1, 0x1d, 0x2f, 0x42, 0x72, 0xa5, + 0x21, 0x21, 0xb8, 0xf9, 0xc4, 0x37, 0xf9, 0xfe, 0xe2, 0xb2, 0x99, 0x27, 0xc3, 0x1e, 0x9b, 0x5c, + 0x53, 0x74, 0x24, 0x94, 0x30, 0x34, 0x16, 0xab, 0xc0, 0x18, 0x29, 0xf9, 0x1c, 0x17, 0x84, 0x96, + 0x1c, 0xc5, 0x4a, 0xe8, 0xde, 0x84, 0xe8, 0xc5, 0x8f, 0x67, 0x3b, 0xc7, 0xfc, 0x3a, 0x26, 0x34, + 0xd6, 0x54, 0x81, 0xcd, 0xde, 0x99, 0x9c, 0x5b, 0x96, 0xc7, 0x5c, 0x9b, 0x85, 0x7f, 0x46, 0xeb, + 0xad, 0xc7, 0x41, 0xad, 0xf3, 0xc3, 0x40, 0x03, 0x0c, 0xd7, 0xee, 0xe5, 0xe4, 0xe2, 0xff, 0x8c, + 0x2c, 0xfc, 0x84, 0xec, 0x24, 0x49, 0xfc, 0x5b, 0x31, 0x9b, 0x17, 0xa3, 0x9b, 0x5c, 0x39, 0x61, + 0x79, 0x19, 0x1f, 0x17, 0x07, 0x49, 0x22, 0x3b, 0x7b, 0xa2, 0xa6, 0xea, 0xf4, 0xf0, 0xf6, 0x87, + 0xae, 0x8e, 0xde, 0xd6, 0x25, 0xbc, 0xb6, 0x25, 0xac, 0xda, 0x12, 0xd6, 0x6d, 0x09, 0xcb, 0x8f, + 0x29, 0x5c, 0x9f, 0x6d, 0x3a, 0x0d, 0xdb, 0x4e, 0xc3, 0x7b, 0xa7, 0x61, 0xd9, 0x6b, 0xb5, 0xe9, + 0xb5, 0xda, 0xf6, 0x5a, 0x7d, 0xf6, 0x5a, 0xad, 0xbe, 0x34, 0xdc, 0x8d, 0xf6, 0x3b, 0xbe, 0x03, + 0x00, 0x00, 0xff, 0xff, 0x90, 0x1c, 0x7f, 0xff, 0x20, 0x01, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/generated.proto b/vendor/k8s.io/client-go/pkg/api/resource/generated.proto similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/generated.proto rename to vendor/k8s.io/client-go/pkg/api/resource/generated.proto diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/math.go b/vendor/k8s.io/client-go/pkg/api/resource/math.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/math.go rename to vendor/k8s.io/client-go/pkg/api/resource/math.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/quantity.go b/vendor/k8s.io/client-go/pkg/api/resource/quantity.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/resource/quantity.go rename to vendor/k8s.io/client-go/pkg/api/resource/quantity.go index d8f2718..d0a4a40 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/resource/quantity.go +++ b/vendor/k8s.io/client-go/pkg/api/resource/quantity.go @@ -29,7 +29,7 @@ import ( "github.com/go-openapi/spec" inf "gopkg.in/inf.v0" - "k8s.io/kubernetes/pkg/genericapiserver/openapi/common" + "k8s.io/client-go/pkg/genericapiserver/openapi/common" ) // Quantity is a fixed-point representation of a number. diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/quantity_proto.go b/vendor/k8s.io/client-go/pkg/api/resource/quantity_proto.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/quantity_proto.go rename to vendor/k8s.io/client-go/pkg/api/resource/quantity_proto.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/scale_int.go b/vendor/k8s.io/client-go/pkg/api/resource/scale_int.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/scale_int.go rename to vendor/k8s.io/client-go/pkg/api/resource/scale_int.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource/suffix.go b/vendor/k8s.io/client-go/pkg/api/resource/suffix.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/resource/suffix.go rename to vendor/k8s.io/client-go/pkg/api/resource/suffix.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/resource_helpers.go b/vendor/k8s.io/client-go/pkg/api/resource_helpers.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/resource_helpers.go rename to vendor/k8s.io/client-go/pkg/api/resource_helpers.go index e926094..3d78fc8 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/resource_helpers.go +++ b/vendor/k8s.io/client-go/pkg/api/resource_helpers.go @@ -19,8 +19,8 @@ package api import ( "time" - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" ) // Returns string version of ResourceName. diff --git a/vendor/k8s.io/kubernetes/pkg/api/types.generated.go b/vendor/k8s.io/client-go/pkg/api/types.generated.go similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/api/types.generated.go rename to vendor/k8s.io/client-go/pkg/api/types.generated.go index b2125f2..d82c3e3 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/api/types.generated.go @@ -25,13 +25,13 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg3_resource "k8s.io/kubernetes/pkg/api/resource" - pkg2_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg6_fields "k8s.io/kubernetes/pkg/fields" - pkg5_labels "k8s.io/kubernetes/pkg/labels" - pkg7_runtime "k8s.io/kubernetes/pkg/runtime" - pkg1_types "k8s.io/kubernetes/pkg/types" - pkg4_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg3_resource "k8s.io/client-go/pkg/api/resource" + pkg2_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg6_fields "k8s.io/client-go/pkg/fields" + pkg5_labels "k8s.io/client-go/pkg/labels" + pkg7_runtime "k8s.io/client-go/pkg/runtime" + pkg1_types "k8s.io/client-go/pkg/types" + pkg4_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -26573,7 +26573,7 @@ func (x *WeightedPodAffinityTerm) codecDecodeSelfFromMap(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Weight = 0 } else { - x.Weight = int(r.DecodeInt(codecSelferBitsize1234)) + x.Weight = int32(r.DecodeInt(32)) } case "podAffinityTerm": if r.TryDecodeAsNil() { @@ -26610,7 +26610,7 @@ func (x *WeightedPodAffinityTerm) codecDecodeSelfFromArray(l int, d *codec1978.D if r.TryDecodeAsNil() { x.Weight = 0 } else { - x.Weight = int(r.DecodeInt(codecSelferBitsize1234)) + x.Weight = int32(r.DecodeInt(32)) } yyj1969++ if yyhl1969 { @@ -32527,16 +32527,15 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } else { yysep2477 := !z.EncBinary() yy2arr2477 := z.EncBasicHandle().StructToArray - var yyq2477 [6]bool + var yyq2477 [5]bool _, _, _ = yysep2477, yyq2477, yy2arr2477 const yyr2477 bool = false yyq2477[2] = true - yyq2477[3] = true - yyq2477[4] = x.Reason != "" - yyq2477[5] = x.Message != "" + yyq2477[3] = x.Reason != "" + yyq2477[4] = x.Message != "" var yynn2477 int if yyr2477 || yy2arr2477 { - r.EncodeArrayStart(6) + r.EncodeArrayStart(5) } else { yynn2477 = 2 for _, b := range yyq2477 { @@ -32568,7 +32567,7 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { if yyr2477 || yy2arr2477 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq2477[2] { - yy2481 := &x.LastProbeTime + yy2481 := &x.LastTransitionTime yym2482 := z.EncBinary() _ = yym2482 if false { @@ -32586,9 +32585,9 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } else { if yyq2477[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) + r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2483 := &x.LastProbeTime + yy2483 := &x.LastTransitionTime yym2484 := z.EncBinary() _ = yym2484 if false { @@ -32605,45 +32604,8 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { if yyr2477 || yy2arr2477 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq2477[3] { - yy2486 := &x.LastTransitionTime - yym2487 := z.EncBinary() - _ = yym2487 - if false { - } else if z.HasExtensions() && z.EncExt(yy2486) { - } else if yym2487 { - z.EncBinaryMarshal(yy2486) - } else if !yym2487 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2486) - } else { - z.EncFallback(yy2486) - } - } else { - r.EncodeNil() - } - } else { - if yyq2477[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2488 := &x.LastTransitionTime - yym2489 := z.EncBinary() - _ = yym2489 - if false { - } else if z.HasExtensions() && z.EncExt(yy2488) { - } else if yym2489 { - z.EncBinaryMarshal(yy2488) - } else if !yym2489 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2488) - } else { - z.EncFallback(yy2488) - } - } - } - if yyr2477 || yy2arr2477 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2477[4] { - yym2491 := z.EncBinary() - _ = yym2491 + yym2486 := z.EncBinary() + _ = yym2486 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -32652,12 +32614,12 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2477[4] { + if yyq2477[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2492 := z.EncBinary() - _ = yym2492 + yym2487 := z.EncBinary() + _ = yym2487 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -32666,9 +32628,9 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } if yyr2477 || yy2arr2477 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2477[5] { - yym2494 := z.EncBinary() - _ = yym2494 + if yyq2477[4] { + yym2489 := z.EncBinary() + _ = yym2489 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -32677,12 +32639,12 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2477[5] { + if yyq2477[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2495 := z.EncBinary() - _ = yym2495 + yym2490 := z.EncBinary() + _ = yym2490 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -32702,25 +32664,25 @@ func (x *ReplicationControllerCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2496 := z.DecBinary() - _ = yym2496 + yym2491 := z.DecBinary() + _ = yym2491 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2497 := r.ContainerType() - if yyct2497 == codecSelferValueTypeMap1234 { - yyl2497 := r.ReadMapStart() - if yyl2497 == 0 { + yyct2492 := r.ContainerType() + if yyct2492 == codecSelferValueTypeMap1234 { + yyl2492 := r.ReadMapStart() + if yyl2492 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2497, d) + x.codecDecodeSelfFromMap(yyl2492, d) } - } else if yyct2497 == codecSelferValueTypeArray1234 { - yyl2497 := r.ReadArrayStart() - if yyl2497 == 0 { + } else if yyct2492 == codecSelferValueTypeArray1234 { + yyl2492 := r.ReadArrayStart() + if yyl2492 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2497, d) + x.codecDecodeSelfFromArray(yyl2492, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -32732,12 +32694,12 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2498Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2498Slc - var yyhl2498 bool = l >= 0 - for yyj2498 := 0; ; yyj2498++ { - if yyhl2498 { - if yyj2498 >= l { + var yys2493Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2493Slc + var yyhl2493 bool = l >= 0 + for yyj2493 := 0; ; yyj2493++ { + if yyhl2493 { + if yyj2493 >= l { break } } else { @@ -32746,10 +32708,10 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2498Slc = r.DecodeBytes(yys2498Slc, true, true) - yys2498 := string(yys2498Slc) + yys2493Slc = r.DecodeBytes(yys2493Slc, true, true) + yys2493 := string(yys2493Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2498 { + switch yys2493 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -32762,38 +32724,21 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 } else { x.Status = ConditionStatus(r.DecodeString()) } - case "lastProbeTime": - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg2_unversioned.Time{} - } else { - yyv2501 := &x.LastProbeTime - yym2502 := z.DecBinary() - _ = yym2502 - if false { - } else if z.HasExtensions() && z.DecExt(yyv2501) { - } else if yym2502 { - z.DecBinaryUnmarshal(yyv2501) - } else if !yym2502 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2501) - } else { - z.DecFallback(yyv2501, false) - } - } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv2503 := &x.LastTransitionTime - yym2504 := z.DecBinary() - _ = yym2504 + yyv2496 := &x.LastTransitionTime + yym2497 := z.DecBinary() + _ = yym2497 if false { - } else if z.HasExtensions() && z.DecExt(yyv2503) { - } else if yym2504 { - z.DecBinaryUnmarshal(yyv2503) - } else if !yym2504 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2503) + } else if z.HasExtensions() && z.DecExt(yyv2496) { + } else if yym2497 { + z.DecBinaryUnmarshal(yyv2496) + } else if !yym2497 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2496) } else { - z.DecFallback(yyv2503, false) + z.DecFallback(yyv2496, false) } } case "reason": @@ -32809,9 +32754,9 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2498) - } // end switch yys2498 - } // end for yyj2498 + z.DecStructFieldNotFound(-1, yys2493) + } // end switch yys2493 + } // end for yyj2493 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -32819,16 +32764,16 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2507 int - var yyb2507 bool - var yyhl2507 bool = l >= 0 - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + var yyj2500 int + var yyb2500 bool + var yyhl2500 bool = l >= 0 + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { + if yyb2500 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32838,13 +32783,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Type = ReplicationControllerConditionType(r.DecodeString()) } - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { + if yyb2500 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32854,40 +32799,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg2_unversioned.Time{} - } else { - yyv2510 := &x.LastProbeTime - yym2511 := z.DecBinary() - _ = yym2511 - if false { - } else if z.HasExtensions() && z.DecExt(yyv2510) { - } else if yym2511 { - z.DecBinaryUnmarshal(yyv2510) - } else if !yym2511 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2510) - } else { - z.DecFallback(yyv2510, false) - } - } - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l - } else { - yyb2507 = r.CheckBreak() - } - if yyb2507 { + if yyb2500 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32895,26 +32813,26 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv2512 := &x.LastTransitionTime - yym2513 := z.DecBinary() - _ = yym2513 + yyv2503 := &x.LastTransitionTime + yym2504 := z.DecBinary() + _ = yym2504 if false { - } else if z.HasExtensions() && z.DecExt(yyv2512) { - } else if yym2513 { - z.DecBinaryUnmarshal(yyv2512) - } else if !yym2513 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2512) + } else if z.HasExtensions() && z.DecExt(yyv2503) { + } else if yym2504 { + z.DecBinaryUnmarshal(yyv2503) + } else if !yym2504 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2503) } else { - z.DecFallback(yyv2512, false) + z.DecFallback(yyv2503, false) } } - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { + if yyb2500 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32924,13 +32842,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Reason = string(r.DecodeString()) } - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { + if yyb2500 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32941,17 +32859,17 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code x.Message = string(r.DecodeString()) } for { - yyj2507++ - if yyhl2507 { - yyb2507 = yyj2507 > l + yyj2500++ + if yyhl2500 { + yyb2500 = yyj2500 > l } else { - yyb2507 = r.CheckBreak() + yyb2500 = r.CheckBreak() } - if yyb2507 { + if yyb2500 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2507-1, "") + z.DecStructFieldNotFound(yyj2500-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -32963,39 +32881,39 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2516 := z.EncBinary() - _ = yym2516 + yym2507 := z.EncBinary() + _ = yym2507 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2517 := !z.EncBinary() - yy2arr2517 := z.EncBasicHandle().StructToArray - var yyq2517 [5]bool - _, _, _ = yysep2517, yyq2517, yy2arr2517 - const yyr2517 bool = false - yyq2517[0] = x.Kind != "" - yyq2517[1] = x.APIVersion != "" - yyq2517[2] = true - yyq2517[3] = true - yyq2517[4] = true - var yynn2517 int - if yyr2517 || yy2arr2517 { + yysep2508 := !z.EncBinary() + yy2arr2508 := z.EncBasicHandle().StructToArray + var yyq2508 [5]bool + _, _, _ = yysep2508, yyq2508, yy2arr2508 + const yyr2508 bool = false + yyq2508[0] = x.Kind != "" + yyq2508[1] = x.APIVersion != "" + yyq2508[2] = true + yyq2508[3] = true + yyq2508[4] = true + var yynn2508 int + if yyr2508 || yy2arr2508 { r.EncodeArrayStart(5) } else { - yynn2517 = 0 - for _, b := range yyq2517 { + yynn2508 = 0 + for _, b := range yyq2508 { if b { - yynn2517++ + yynn2508++ } } - r.EncodeMapStart(yynn2517) - yynn2517 = 0 + r.EncodeMapStart(yynn2508) + yynn2508 = 0 } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2517[0] { - yym2519 := z.EncBinary() - _ = yym2519 + if yyq2508[0] { + yym2510 := z.EncBinary() + _ = yym2510 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -33004,23 +32922,23 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2517[0] { + if yyq2508[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2520 := z.EncBinary() - _ = yym2520 + yym2511 := z.EncBinary() + _ = yym2511 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2517[1] { - yym2522 := z.EncBinary() - _ = yym2522 + if yyq2508[1] { + yym2513 := z.EncBinary() + _ = yym2513 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -33029,70 +32947,70 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2517[1] { + if yyq2508[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2523 := z.EncBinary() - _ = yym2523 + yym2514 := z.EncBinary() + _ = yym2514 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2517[2] { - yy2525 := &x.ObjectMeta - yy2525.CodecEncodeSelf(e) + if yyq2508[2] { + yy2516 := &x.ObjectMeta + yy2516.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2517[2] { + if yyq2508[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2526 := &x.ObjectMeta - yy2526.CodecEncodeSelf(e) + yy2517 := &x.ObjectMeta + yy2517.CodecEncodeSelf(e) } } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2517[3] { - yy2528 := &x.Spec - yy2528.CodecEncodeSelf(e) + if yyq2508[3] { + yy2519 := &x.Spec + yy2519.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2517[3] { + if yyq2508[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2529 := &x.Spec - yy2529.CodecEncodeSelf(e) + yy2520 := &x.Spec + yy2520.CodecEncodeSelf(e) } } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2517[4] { - yy2531 := &x.Status - yy2531.CodecEncodeSelf(e) + if yyq2508[4] { + yy2522 := &x.Status + yy2522.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2517[4] { + if yyq2508[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2532 := &x.Status - yy2532.CodecEncodeSelf(e) + yy2523 := &x.Status + yy2523.CodecEncodeSelf(e) } } - if yyr2517 || yy2arr2517 { + if yyr2508 || yy2arr2508 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33105,25 +33023,25 @@ func (x *ReplicationController) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2533 := z.DecBinary() - _ = yym2533 + yym2524 := z.DecBinary() + _ = yym2524 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2534 := r.ContainerType() - if yyct2534 == codecSelferValueTypeMap1234 { - yyl2534 := r.ReadMapStart() - if yyl2534 == 0 { + yyct2525 := r.ContainerType() + if yyct2525 == codecSelferValueTypeMap1234 { + yyl2525 := r.ReadMapStart() + if yyl2525 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2534, d) + x.codecDecodeSelfFromMap(yyl2525, d) } - } else if yyct2534 == codecSelferValueTypeArray1234 { - yyl2534 := r.ReadArrayStart() - if yyl2534 == 0 { + } else if yyct2525 == codecSelferValueTypeArray1234 { + yyl2525 := r.ReadArrayStart() + if yyl2525 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2534, d) + x.codecDecodeSelfFromArray(yyl2525, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33135,12 +33053,12 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2535Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2535Slc - var yyhl2535 bool = l >= 0 - for yyj2535 := 0; ; yyj2535++ { - if yyhl2535 { - if yyj2535 >= l { + var yys2526Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2526Slc + var yyhl2526 bool = l >= 0 + for yyj2526 := 0; ; yyj2526++ { + if yyhl2526 { + if yyj2526 >= l { break } } else { @@ -33149,10 +33067,10 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2535Slc = r.DecodeBytes(yys2535Slc, true, true) - yys2535 := string(yys2535Slc) + yys2526Slc = r.DecodeBytes(yys2526Slc, true, true) + yys2526 := string(yys2526Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2535 { + switch yys2526 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -33169,27 +33087,27 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2538 := &x.ObjectMeta - yyv2538.CodecDecodeSelf(d) + yyv2529 := &x.ObjectMeta + yyv2529.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ReplicationControllerSpec{} } else { - yyv2539 := &x.Spec - yyv2539.CodecDecodeSelf(d) + yyv2530 := &x.Spec + yyv2530.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ReplicationControllerStatus{} } else { - yyv2540 := &x.Status - yyv2540.CodecDecodeSelf(d) + yyv2531 := &x.Status + yyv2531.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2535) - } // end switch yys2535 - } // end for yyj2535 + z.DecStructFieldNotFound(-1, yys2526) + } // end switch yys2526 + } // end for yyj2526 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33197,16 +33115,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2541 int - var yyb2541 bool - var yyhl2541 bool = l >= 0 - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + var yyj2532 int + var yyb2532 bool + var yyhl2532 bool = l >= 0 + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33216,13 +33134,13 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Kind = string(r.DecodeString()) } - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33232,13 +33150,13 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.APIVersion = string(r.DecodeString()) } - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33246,16 +33164,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2544 := &x.ObjectMeta - yyv2544.CodecDecodeSelf(d) + yyv2535 := &x.ObjectMeta + yyv2535.CodecDecodeSelf(d) } - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33263,16 +33181,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Spec = ReplicationControllerSpec{} } else { - yyv2545 := &x.Spec - yyv2545.CodecDecodeSelf(d) + yyv2536 := &x.Spec + yyv2536.CodecDecodeSelf(d) } - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33280,21 +33198,21 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Status = ReplicationControllerStatus{} } else { - yyv2546 := &x.Status - yyv2546.CodecDecodeSelf(d) + yyv2537 := &x.Status + yyv2537.CodecDecodeSelf(d) } for { - yyj2541++ - if yyhl2541 { - yyb2541 = yyj2541 > l + yyj2532++ + if yyhl2532 { + yyb2532 = yyj2532 > l } else { - yyb2541 = r.CheckBreak() + yyb2532 = r.CheckBreak() } - if yyb2541 { + if yyb2532 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2541-1, "") + z.DecStructFieldNotFound(yyj2532-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33306,37 +33224,37 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2547 := z.EncBinary() - _ = yym2547 + yym2538 := z.EncBinary() + _ = yym2538 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2548 := !z.EncBinary() - yy2arr2548 := z.EncBasicHandle().StructToArray - var yyq2548 [4]bool - _, _, _ = yysep2548, yyq2548, yy2arr2548 - const yyr2548 bool = false - yyq2548[0] = x.Kind != "" - yyq2548[1] = x.APIVersion != "" - yyq2548[2] = true - var yynn2548 int - if yyr2548 || yy2arr2548 { + yysep2539 := !z.EncBinary() + yy2arr2539 := z.EncBasicHandle().StructToArray + var yyq2539 [4]bool + _, _, _ = yysep2539, yyq2539, yy2arr2539 + const yyr2539 bool = false + yyq2539[0] = x.Kind != "" + yyq2539[1] = x.APIVersion != "" + yyq2539[2] = true + var yynn2539 int + if yyr2539 || yy2arr2539 { r.EncodeArrayStart(4) } else { - yynn2548 = 1 - for _, b := range yyq2548 { + yynn2539 = 1 + for _, b := range yyq2539 { if b { - yynn2548++ + yynn2539++ } } - r.EncodeMapStart(yynn2548) - yynn2548 = 0 + r.EncodeMapStart(yynn2539) + yynn2539 = 0 } - if yyr2548 || yy2arr2548 { + if yyr2539 || yy2arr2539 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2548[0] { - yym2550 := z.EncBinary() - _ = yym2550 + if yyq2539[0] { + yym2541 := z.EncBinary() + _ = yym2541 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -33345,23 +33263,23 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2548[0] { + if yyq2539[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2551 := z.EncBinary() - _ = yym2551 + yym2542 := z.EncBinary() + _ = yym2542 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2548 || yy2arr2548 { + if yyr2539 || yy2arr2539 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2548[1] { - yym2553 := z.EncBinary() - _ = yym2553 + if yyq2539[1] { + yym2544 := z.EncBinary() + _ = yym2544 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -33370,54 +33288,54 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2548[1] { + if yyq2539[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2554 := z.EncBinary() - _ = yym2554 + yym2545 := z.EncBinary() + _ = yym2545 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2548 || yy2arr2548 { + if yyr2539 || yy2arr2539 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2548[2] { - yy2556 := &x.ListMeta - yym2557 := z.EncBinary() - _ = yym2557 + if yyq2539[2] { + yy2547 := &x.ListMeta + yym2548 := z.EncBinary() + _ = yym2548 if false { - } else if z.HasExtensions() && z.EncExt(yy2556) { + } else if z.HasExtensions() && z.EncExt(yy2547) { } else { - z.EncFallback(yy2556) + z.EncFallback(yy2547) } } else { r.EncodeNil() } } else { - if yyq2548[2] { + if yyq2539[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2558 := &x.ListMeta - yym2559 := z.EncBinary() - _ = yym2559 + yy2549 := &x.ListMeta + yym2550 := z.EncBinary() + _ = yym2550 if false { - } else if z.HasExtensions() && z.EncExt(yy2558) { + } else if z.HasExtensions() && z.EncExt(yy2549) { } else { - z.EncFallback(yy2558) + z.EncFallback(yy2549) } } } - if yyr2548 || yy2arr2548 { + if yyr2539 || yy2arr2539 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2561 := z.EncBinary() - _ = yym2561 + yym2552 := z.EncBinary() + _ = yym2552 if false { } else { h.encSliceReplicationController(([]ReplicationController)(x.Items), e) @@ -33430,15 +33348,15 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2562 := z.EncBinary() - _ = yym2562 + yym2553 := z.EncBinary() + _ = yym2553 if false { } else { h.encSliceReplicationController(([]ReplicationController)(x.Items), e) } } } - if yyr2548 || yy2arr2548 { + if yyr2539 || yy2arr2539 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33451,25 +33369,25 @@ func (x *ReplicationControllerList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2563 := z.DecBinary() - _ = yym2563 + yym2554 := z.DecBinary() + _ = yym2554 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2564 := r.ContainerType() - if yyct2564 == codecSelferValueTypeMap1234 { - yyl2564 := r.ReadMapStart() - if yyl2564 == 0 { + yyct2555 := r.ContainerType() + if yyct2555 == codecSelferValueTypeMap1234 { + yyl2555 := r.ReadMapStart() + if yyl2555 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2564, d) + x.codecDecodeSelfFromMap(yyl2555, d) } - } else if yyct2564 == codecSelferValueTypeArray1234 { - yyl2564 := r.ReadArrayStart() - if yyl2564 == 0 { + } else if yyct2555 == codecSelferValueTypeArray1234 { + yyl2555 := r.ReadArrayStart() + if yyl2555 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2564, d) + x.codecDecodeSelfFromArray(yyl2555, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33481,12 +33399,12 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2565Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2565Slc - var yyhl2565 bool = l >= 0 - for yyj2565 := 0; ; yyj2565++ { - if yyhl2565 { - if yyj2565 >= l { + var yys2556Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2556Slc + var yyhl2556 bool = l >= 0 + for yyj2556 := 0; ; yyj2556++ { + if yyhl2556 { + if yyj2556 >= l { break } } else { @@ -33495,10 +33413,10 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2565Slc = r.DecodeBytes(yys2565Slc, true, true) - yys2565 := string(yys2565Slc) + yys2556Slc = r.DecodeBytes(yys2556Slc, true, true) + yys2556 := string(yys2556Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2565 { + switch yys2556 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -33515,31 +33433,31 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2568 := &x.ListMeta - yym2569 := z.DecBinary() - _ = yym2569 + yyv2559 := &x.ListMeta + yym2560 := z.DecBinary() + _ = yym2560 if false { - } else if z.HasExtensions() && z.DecExt(yyv2568) { + } else if z.HasExtensions() && z.DecExt(yyv2559) { } else { - z.DecFallback(yyv2568, false) + z.DecFallback(yyv2559, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2570 := &x.Items - yym2571 := z.DecBinary() - _ = yym2571 + yyv2561 := &x.Items + yym2562 := z.DecBinary() + _ = yym2562 if false { } else { - h.decSliceReplicationController((*[]ReplicationController)(yyv2570), d) + h.decSliceReplicationController((*[]ReplicationController)(yyv2561), d) } } default: - z.DecStructFieldNotFound(-1, yys2565) - } // end switch yys2565 - } // end for yyj2565 + z.DecStructFieldNotFound(-1, yys2556) + } // end switch yys2556 + } // end for yyj2556 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33547,16 +33465,16 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2572 int - var yyb2572 bool - var yyhl2572 bool = l >= 0 - yyj2572++ - if yyhl2572 { - yyb2572 = yyj2572 > l + var yyj2563 int + var yyb2563 bool + var yyhl2563 bool = l >= 0 + yyj2563++ + if yyhl2563 { + yyb2563 = yyj2563 > l } else { - yyb2572 = r.CheckBreak() + yyb2563 = r.CheckBreak() } - if yyb2572 { + if yyb2563 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33566,13 +33484,13 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 } else { x.Kind = string(r.DecodeString()) } - yyj2572++ - if yyhl2572 { - yyb2572 = yyj2572 > l + yyj2563++ + if yyhl2563 { + yyb2563 = yyj2563 > l } else { - yyb2572 = r.CheckBreak() + yyb2563 = r.CheckBreak() } - if yyb2572 { + if yyb2563 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33582,13 +33500,13 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 } else { x.APIVersion = string(r.DecodeString()) } - yyj2572++ - if yyhl2572 { - yyb2572 = yyj2572 > l + yyj2563++ + if yyhl2563 { + yyb2563 = yyj2563 > l } else { - yyb2572 = r.CheckBreak() + yyb2563 = r.CheckBreak() } - if yyb2572 { + if yyb2563 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33596,22 +33514,22 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2575 := &x.ListMeta - yym2576 := z.DecBinary() - _ = yym2576 + yyv2566 := &x.ListMeta + yym2567 := z.DecBinary() + _ = yym2567 if false { - } else if z.HasExtensions() && z.DecExt(yyv2575) { + } else if z.HasExtensions() && z.DecExt(yyv2566) { } else { - z.DecFallback(yyv2575, false) + z.DecFallback(yyv2566, false) } } - yyj2572++ - if yyhl2572 { - yyb2572 = yyj2572 > l + yyj2563++ + if yyhl2563 { + yyb2563 = yyj2563 > l } else { - yyb2572 = r.CheckBreak() + yyb2563 = r.CheckBreak() } - if yyb2572 { + if yyb2563 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33619,26 +33537,26 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2577 := &x.Items - yym2578 := z.DecBinary() - _ = yym2578 + yyv2568 := &x.Items + yym2569 := z.DecBinary() + _ = yym2569 if false { } else { - h.decSliceReplicationController((*[]ReplicationController)(yyv2577), d) + h.decSliceReplicationController((*[]ReplicationController)(yyv2568), d) } } for { - yyj2572++ - if yyhl2572 { - yyb2572 = yyj2572 > l + yyj2563++ + if yyhl2563 { + yyb2563 = yyj2563 > l } else { - yyb2572 = r.CheckBreak() + yyb2563 = r.CheckBreak() } - if yyb2572 { + if yyb2563 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2572-1, "") + z.DecStructFieldNotFound(yyj2563-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33650,37 +33568,37 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2579 := z.EncBinary() - _ = yym2579 + yym2570 := z.EncBinary() + _ = yym2570 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2580 := !z.EncBinary() - yy2arr2580 := z.EncBasicHandle().StructToArray - var yyq2580 [4]bool - _, _, _ = yysep2580, yyq2580, yy2arr2580 - const yyr2580 bool = false - yyq2580[0] = x.Kind != "" - yyq2580[1] = x.APIVersion != "" - yyq2580[2] = true - var yynn2580 int - if yyr2580 || yy2arr2580 { + yysep2571 := !z.EncBinary() + yy2arr2571 := z.EncBasicHandle().StructToArray + var yyq2571 [4]bool + _, _, _ = yysep2571, yyq2571, yy2arr2571 + const yyr2571 bool = false + yyq2571[0] = x.Kind != "" + yyq2571[1] = x.APIVersion != "" + yyq2571[2] = true + var yynn2571 int + if yyr2571 || yy2arr2571 { r.EncodeArrayStart(4) } else { - yynn2580 = 1 - for _, b := range yyq2580 { + yynn2571 = 1 + for _, b := range yyq2571 { if b { - yynn2580++ + yynn2571++ } } - r.EncodeMapStart(yynn2580) - yynn2580 = 0 + r.EncodeMapStart(yynn2571) + yynn2571 = 0 } - if yyr2580 || yy2arr2580 { + if yyr2571 || yy2arr2571 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2580[0] { - yym2582 := z.EncBinary() - _ = yym2582 + if yyq2571[0] { + yym2573 := z.EncBinary() + _ = yym2573 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -33689,23 +33607,23 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2580[0] { + if yyq2571[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2583 := z.EncBinary() - _ = yym2583 + yym2574 := z.EncBinary() + _ = yym2574 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2580 || yy2arr2580 { + if yyr2571 || yy2arr2571 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2580[1] { - yym2585 := z.EncBinary() - _ = yym2585 + if yyq2571[1] { + yym2576 := z.EncBinary() + _ = yym2576 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -33714,54 +33632,54 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2580[1] { + if yyq2571[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2586 := z.EncBinary() - _ = yym2586 + yym2577 := z.EncBinary() + _ = yym2577 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2580 || yy2arr2580 { + if yyr2571 || yy2arr2571 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2580[2] { - yy2588 := &x.ListMeta - yym2589 := z.EncBinary() - _ = yym2589 + if yyq2571[2] { + yy2579 := &x.ListMeta + yym2580 := z.EncBinary() + _ = yym2580 if false { - } else if z.HasExtensions() && z.EncExt(yy2588) { + } else if z.HasExtensions() && z.EncExt(yy2579) { } else { - z.EncFallback(yy2588) + z.EncFallback(yy2579) } } else { r.EncodeNil() } } else { - if yyq2580[2] { + if yyq2571[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2590 := &x.ListMeta - yym2591 := z.EncBinary() - _ = yym2591 + yy2581 := &x.ListMeta + yym2582 := z.EncBinary() + _ = yym2582 if false { - } else if z.HasExtensions() && z.EncExt(yy2590) { + } else if z.HasExtensions() && z.EncExt(yy2581) { } else { - z.EncFallback(yy2590) + z.EncFallback(yy2581) } } } - if yyr2580 || yy2arr2580 { + if yyr2571 || yy2arr2571 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2593 := z.EncBinary() - _ = yym2593 + yym2584 := z.EncBinary() + _ = yym2584 if false { } else { h.encSliceService(([]Service)(x.Items), e) @@ -33774,15 +33692,15 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2594 := z.EncBinary() - _ = yym2594 + yym2585 := z.EncBinary() + _ = yym2585 if false { } else { h.encSliceService(([]Service)(x.Items), e) } } } - if yyr2580 || yy2arr2580 { + if yyr2571 || yy2arr2571 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33795,25 +33713,25 @@ func (x *ServiceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2595 := z.DecBinary() - _ = yym2595 + yym2586 := z.DecBinary() + _ = yym2586 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2596 := r.ContainerType() - if yyct2596 == codecSelferValueTypeMap1234 { - yyl2596 := r.ReadMapStart() - if yyl2596 == 0 { + yyct2587 := r.ContainerType() + if yyct2587 == codecSelferValueTypeMap1234 { + yyl2587 := r.ReadMapStart() + if yyl2587 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2596, d) + x.codecDecodeSelfFromMap(yyl2587, d) } - } else if yyct2596 == codecSelferValueTypeArray1234 { - yyl2596 := r.ReadArrayStart() - if yyl2596 == 0 { + } else if yyct2587 == codecSelferValueTypeArray1234 { + yyl2587 := r.ReadArrayStart() + if yyl2587 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2596, d) + x.codecDecodeSelfFromArray(yyl2587, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33825,12 +33743,12 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2597Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2597Slc - var yyhl2597 bool = l >= 0 - for yyj2597 := 0; ; yyj2597++ { - if yyhl2597 { - if yyj2597 >= l { + var yys2588Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2588Slc + var yyhl2588 bool = l >= 0 + for yyj2588 := 0; ; yyj2588++ { + if yyhl2588 { + if yyj2588 >= l { break } } else { @@ -33839,10 +33757,10 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2597Slc = r.DecodeBytes(yys2597Slc, true, true) - yys2597 := string(yys2597Slc) + yys2588Slc = r.DecodeBytes(yys2588Slc, true, true) + yys2588 := string(yys2588Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2597 { + switch yys2588 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -33859,31 +33777,31 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2600 := &x.ListMeta - yym2601 := z.DecBinary() - _ = yym2601 + yyv2591 := &x.ListMeta + yym2592 := z.DecBinary() + _ = yym2592 if false { - } else if z.HasExtensions() && z.DecExt(yyv2600) { + } else if z.HasExtensions() && z.DecExt(yyv2591) { } else { - z.DecFallback(yyv2600, false) + z.DecFallback(yyv2591, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2602 := &x.Items - yym2603 := z.DecBinary() - _ = yym2603 + yyv2593 := &x.Items + yym2594 := z.DecBinary() + _ = yym2594 if false { } else { - h.decSliceService((*[]Service)(yyv2602), d) + h.decSliceService((*[]Service)(yyv2593), d) } } default: - z.DecStructFieldNotFound(-1, yys2597) - } // end switch yys2597 - } // end for yyj2597 + z.DecStructFieldNotFound(-1, yys2588) + } // end switch yys2588 + } // end for yyj2588 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33891,16 +33809,16 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2604 int - var yyb2604 bool - var yyhl2604 bool = l >= 0 - yyj2604++ - if yyhl2604 { - yyb2604 = yyj2604 > l + var yyj2595 int + var yyb2595 bool + var yyhl2595 bool = l >= 0 + yyj2595++ + if yyhl2595 { + yyb2595 = yyj2595 > l } else { - yyb2604 = r.CheckBreak() + yyb2595 = r.CheckBreak() } - if yyb2604 { + if yyb2595 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33910,13 +33828,13 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2604++ - if yyhl2604 { - yyb2604 = yyj2604 > l + yyj2595++ + if yyhl2595 { + yyb2595 = yyj2595 > l } else { - yyb2604 = r.CheckBreak() + yyb2595 = r.CheckBreak() } - if yyb2604 { + if yyb2595 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33926,13 +33844,13 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2604++ - if yyhl2604 { - yyb2604 = yyj2604 > l + yyj2595++ + if yyhl2595 { + yyb2595 = yyj2595 > l } else { - yyb2604 = r.CheckBreak() + yyb2595 = r.CheckBreak() } - if yyb2604 { + if yyb2595 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33940,22 +33858,22 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2607 := &x.ListMeta - yym2608 := z.DecBinary() - _ = yym2608 + yyv2598 := &x.ListMeta + yym2599 := z.DecBinary() + _ = yym2599 if false { - } else if z.HasExtensions() && z.DecExt(yyv2607) { + } else if z.HasExtensions() && z.DecExt(yyv2598) { } else { - z.DecFallback(yyv2607, false) + z.DecFallback(yyv2598, false) } } - yyj2604++ - if yyhl2604 { - yyb2604 = yyj2604 > l + yyj2595++ + if yyhl2595 { + yyb2595 = yyj2595 > l } else { - yyb2604 = r.CheckBreak() + yyb2595 = r.CheckBreak() } - if yyb2604 { + if yyb2595 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33963,26 +33881,26 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2609 := &x.Items - yym2610 := z.DecBinary() - _ = yym2610 + yyv2600 := &x.Items + yym2601 := z.DecBinary() + _ = yym2601 if false { } else { - h.decSliceService((*[]Service)(yyv2609), d) + h.decSliceService((*[]Service)(yyv2600), d) } } for { - yyj2604++ - if yyhl2604 { - yyb2604 = yyj2604 > l + yyj2595++ + if yyhl2595 { + yyb2595 = yyj2595 > l } else { - yyb2604 = r.CheckBreak() + yyb2595 = r.CheckBreak() } - if yyb2604 { + if yyb2595 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2604-1, "") + z.DecStructFieldNotFound(yyj2595-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33991,8 +33909,8 @@ func (x ServiceAffinity) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym2611 := z.EncBinary() - _ = yym2611 + yym2602 := z.EncBinary() + _ = yym2602 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -34004,8 +33922,8 @@ func (x *ServiceAffinity) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2612 := z.DecBinary() - _ = yym2612 + yym2603 := z.DecBinary() + _ = yym2603 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -34017,8 +33935,8 @@ func (x ServiceType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym2613 := z.EncBinary() - _ = yym2613 + yym2604 := z.EncBinary() + _ = yym2604 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -34030,8 +33948,8 @@ func (x *ServiceType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2614 := z.DecBinary() - _ = yym2614 + yym2605 := z.DecBinary() + _ = yym2605 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -34046,48 +33964,48 @@ func (x *ServiceStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2615 := z.EncBinary() - _ = yym2615 + yym2606 := z.EncBinary() + _ = yym2606 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2616 := !z.EncBinary() - yy2arr2616 := z.EncBasicHandle().StructToArray - var yyq2616 [1]bool - _, _, _ = yysep2616, yyq2616, yy2arr2616 - const yyr2616 bool = false - yyq2616[0] = true - var yynn2616 int - if yyr2616 || yy2arr2616 { + yysep2607 := !z.EncBinary() + yy2arr2607 := z.EncBasicHandle().StructToArray + var yyq2607 [1]bool + _, _, _ = yysep2607, yyq2607, yy2arr2607 + const yyr2607 bool = false + yyq2607[0] = true + var yynn2607 int + if yyr2607 || yy2arr2607 { r.EncodeArrayStart(1) } else { - yynn2616 = 0 - for _, b := range yyq2616 { + yynn2607 = 0 + for _, b := range yyq2607 { if b { - yynn2616++ + yynn2607++ } } - r.EncodeMapStart(yynn2616) - yynn2616 = 0 + r.EncodeMapStart(yynn2607) + yynn2607 = 0 } - if yyr2616 || yy2arr2616 { + if yyr2607 || yy2arr2607 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2616[0] { - yy2618 := &x.LoadBalancer - yy2618.CodecEncodeSelf(e) + if yyq2607[0] { + yy2609 := &x.LoadBalancer + yy2609.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2616[0] { + if yyq2607[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancer")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2619 := &x.LoadBalancer - yy2619.CodecEncodeSelf(e) + yy2610 := &x.LoadBalancer + yy2610.CodecEncodeSelf(e) } } - if yyr2616 || yy2arr2616 { + if yyr2607 || yy2arr2607 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34100,25 +34018,25 @@ func (x *ServiceStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2620 := z.DecBinary() - _ = yym2620 + yym2611 := z.DecBinary() + _ = yym2611 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2621 := r.ContainerType() - if yyct2621 == codecSelferValueTypeMap1234 { - yyl2621 := r.ReadMapStart() - if yyl2621 == 0 { + yyct2612 := r.ContainerType() + if yyct2612 == codecSelferValueTypeMap1234 { + yyl2612 := r.ReadMapStart() + if yyl2612 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2621, d) + x.codecDecodeSelfFromMap(yyl2612, d) } - } else if yyct2621 == codecSelferValueTypeArray1234 { - yyl2621 := r.ReadArrayStart() - if yyl2621 == 0 { + } else if yyct2612 == codecSelferValueTypeArray1234 { + yyl2612 := r.ReadArrayStart() + if yyl2612 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2621, d) + x.codecDecodeSelfFromArray(yyl2612, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34130,12 +34048,12 @@ func (x *ServiceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2622Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2622Slc - var yyhl2622 bool = l >= 0 - for yyj2622 := 0; ; yyj2622++ { - if yyhl2622 { - if yyj2622 >= l { + var yys2613Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2613Slc + var yyhl2613 bool = l >= 0 + for yyj2613 := 0; ; yyj2613++ { + if yyhl2613 { + if yyj2613 >= l { break } } else { @@ -34144,21 +34062,21 @@ func (x *ServiceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2622Slc = r.DecodeBytes(yys2622Slc, true, true) - yys2622 := string(yys2622Slc) + yys2613Slc = r.DecodeBytes(yys2613Slc, true, true) + yys2613 := string(yys2613Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2622 { + switch yys2613 { case "loadBalancer": if r.TryDecodeAsNil() { x.LoadBalancer = LoadBalancerStatus{} } else { - yyv2623 := &x.LoadBalancer - yyv2623.CodecDecodeSelf(d) + yyv2614 := &x.LoadBalancer + yyv2614.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2622) - } // end switch yys2622 - } // end for yyj2622 + z.DecStructFieldNotFound(-1, yys2613) + } // end switch yys2613 + } // end for yyj2613 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34166,16 +34084,16 @@ func (x *ServiceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2624 int - var yyb2624 bool - var yyhl2624 bool = l >= 0 - yyj2624++ - if yyhl2624 { - yyb2624 = yyj2624 > l + var yyj2615 int + var yyb2615 bool + var yyhl2615 bool = l >= 0 + yyj2615++ + if yyhl2615 { + yyb2615 = yyj2615 > l } else { - yyb2624 = r.CheckBreak() + yyb2615 = r.CheckBreak() } - if yyb2624 { + if yyb2615 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34183,21 +34101,21 @@ func (x *ServiceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancer = LoadBalancerStatus{} } else { - yyv2625 := &x.LoadBalancer - yyv2625.CodecDecodeSelf(d) + yyv2616 := &x.LoadBalancer + yyv2616.CodecDecodeSelf(d) } for { - yyj2624++ - if yyhl2624 { - yyb2624 = yyj2624 > l + yyj2615++ + if yyhl2615 { + yyb2615 = yyj2615 > l } else { - yyb2624 = r.CheckBreak() + yyb2615 = r.CheckBreak() } - if yyb2624 { + if yyb2615 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2624-1, "") + z.DecStructFieldNotFound(yyj2615-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34209,38 +34127,38 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2626 := z.EncBinary() - _ = yym2626 + yym2617 := z.EncBinary() + _ = yym2617 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2627 := !z.EncBinary() - yy2arr2627 := z.EncBasicHandle().StructToArray - var yyq2627 [1]bool - _, _, _ = yysep2627, yyq2627, yy2arr2627 - const yyr2627 bool = false - yyq2627[0] = len(x.Ingress) != 0 - var yynn2627 int - if yyr2627 || yy2arr2627 { + yysep2618 := !z.EncBinary() + yy2arr2618 := z.EncBasicHandle().StructToArray + var yyq2618 [1]bool + _, _, _ = yysep2618, yyq2618, yy2arr2618 + const yyr2618 bool = false + yyq2618[0] = len(x.Ingress) != 0 + var yynn2618 int + if yyr2618 || yy2arr2618 { r.EncodeArrayStart(1) } else { - yynn2627 = 0 - for _, b := range yyq2627 { + yynn2618 = 0 + for _, b := range yyq2618 { if b { - yynn2627++ + yynn2618++ } } - r.EncodeMapStart(yynn2627) - yynn2627 = 0 + r.EncodeMapStart(yynn2618) + yynn2618 = 0 } - if yyr2627 || yy2arr2627 { + if yyr2618 || yy2arr2618 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2627[0] { + if yyq2618[0] { if x.Ingress == nil { r.EncodeNil() } else { - yym2629 := z.EncBinary() - _ = yym2629 + yym2620 := z.EncBinary() + _ = yym2620 if false { } else { h.encSliceLoadBalancerIngress(([]LoadBalancerIngress)(x.Ingress), e) @@ -34250,15 +34168,15 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2627[0] { + if yyq2618[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ingress")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ingress == nil { r.EncodeNil() } else { - yym2630 := z.EncBinary() - _ = yym2630 + yym2621 := z.EncBinary() + _ = yym2621 if false { } else { h.encSliceLoadBalancerIngress(([]LoadBalancerIngress)(x.Ingress), e) @@ -34266,7 +34184,7 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2627 || yy2arr2627 { + if yyr2618 || yy2arr2618 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34279,25 +34197,25 @@ func (x *LoadBalancerStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2631 := z.DecBinary() - _ = yym2631 + yym2622 := z.DecBinary() + _ = yym2622 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2632 := r.ContainerType() - if yyct2632 == codecSelferValueTypeMap1234 { - yyl2632 := r.ReadMapStart() - if yyl2632 == 0 { + yyct2623 := r.ContainerType() + if yyct2623 == codecSelferValueTypeMap1234 { + yyl2623 := r.ReadMapStart() + if yyl2623 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2632, d) + x.codecDecodeSelfFromMap(yyl2623, d) } - } else if yyct2632 == codecSelferValueTypeArray1234 { - yyl2632 := r.ReadArrayStart() - if yyl2632 == 0 { + } else if yyct2623 == codecSelferValueTypeArray1234 { + yyl2623 := r.ReadArrayStart() + if yyl2623 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2632, d) + x.codecDecodeSelfFromArray(yyl2623, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34309,12 +34227,12 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2633Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2633Slc - var yyhl2633 bool = l >= 0 - for yyj2633 := 0; ; yyj2633++ { - if yyhl2633 { - if yyj2633 >= l { + var yys2624Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2624Slc + var yyhl2624 bool = l >= 0 + for yyj2624 := 0; ; yyj2624++ { + if yyhl2624 { + if yyj2624 >= l { break } } else { @@ -34323,26 +34241,26 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2633Slc = r.DecodeBytes(yys2633Slc, true, true) - yys2633 := string(yys2633Slc) + yys2624Slc = r.DecodeBytes(yys2624Slc, true, true) + yys2624 := string(yys2624Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2633 { + switch yys2624 { case "ingress": if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv2634 := &x.Ingress - yym2635 := z.DecBinary() - _ = yym2635 + yyv2625 := &x.Ingress + yym2626 := z.DecBinary() + _ = yym2626 if false { } else { - h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2634), d) + h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2625), d) } } default: - z.DecStructFieldNotFound(-1, yys2633) - } // end switch yys2633 - } // end for yyj2633 + z.DecStructFieldNotFound(-1, yys2624) + } // end switch yys2624 + } // end for yyj2624 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34350,16 +34268,16 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2636 int - var yyb2636 bool - var yyhl2636 bool = l >= 0 - yyj2636++ - if yyhl2636 { - yyb2636 = yyj2636 > l + var yyj2627 int + var yyb2627 bool + var yyhl2627 bool = l >= 0 + yyj2627++ + if yyhl2627 { + yyb2627 = yyj2627 > l } else { - yyb2636 = r.CheckBreak() + yyb2627 = r.CheckBreak() } - if yyb2636 { + if yyb2627 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34367,26 +34285,26 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv2637 := &x.Ingress - yym2638 := z.DecBinary() - _ = yym2638 + yyv2628 := &x.Ingress + yym2629 := z.DecBinary() + _ = yym2629 if false { } else { - h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2637), d) + h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2628), d) } } for { - yyj2636++ - if yyhl2636 { - yyb2636 = yyj2636 > l + yyj2627++ + if yyhl2627 { + yyb2627 = yyj2627 > l } else { - yyb2636 = r.CheckBreak() + yyb2627 = r.CheckBreak() } - if yyb2636 { + if yyb2627 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2636-1, "") + z.DecStructFieldNotFound(yyj2627-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34398,36 +34316,36 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2639 := z.EncBinary() - _ = yym2639 + yym2630 := z.EncBinary() + _ = yym2630 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2640 := !z.EncBinary() - yy2arr2640 := z.EncBasicHandle().StructToArray - var yyq2640 [2]bool - _, _, _ = yysep2640, yyq2640, yy2arr2640 - const yyr2640 bool = false - yyq2640[0] = x.IP != "" - yyq2640[1] = x.Hostname != "" - var yynn2640 int - if yyr2640 || yy2arr2640 { + yysep2631 := !z.EncBinary() + yy2arr2631 := z.EncBasicHandle().StructToArray + var yyq2631 [2]bool + _, _, _ = yysep2631, yyq2631, yy2arr2631 + const yyr2631 bool = false + yyq2631[0] = x.IP != "" + yyq2631[1] = x.Hostname != "" + var yynn2631 int + if yyr2631 || yy2arr2631 { r.EncodeArrayStart(2) } else { - yynn2640 = 0 - for _, b := range yyq2640 { + yynn2631 = 0 + for _, b := range yyq2631 { if b { - yynn2640++ + yynn2631++ } } - r.EncodeMapStart(yynn2640) - yynn2640 = 0 + r.EncodeMapStart(yynn2631) + yynn2631 = 0 } - if yyr2640 || yy2arr2640 { + if yyr2631 || yy2arr2631 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2640[0] { - yym2642 := z.EncBinary() - _ = yym2642 + if yyq2631[0] { + yym2633 := z.EncBinary() + _ = yym2633 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) @@ -34436,23 +34354,23 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2640[0] { + if yyq2631[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ip")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2643 := z.EncBinary() - _ = yym2643 + yym2634 := z.EncBinary() + _ = yym2634 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) } } } - if yyr2640 || yy2arr2640 { + if yyr2631 || yy2arr2631 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2640[1] { - yym2645 := z.EncBinary() - _ = yym2645 + if yyq2631[1] { + yym2636 := z.EncBinary() + _ = yym2636 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) @@ -34461,19 +34379,19 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2640[1] { + if yyq2631[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostname")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2646 := z.EncBinary() - _ = yym2646 + yym2637 := z.EncBinary() + _ = yym2637 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) } } } - if yyr2640 || yy2arr2640 { + if yyr2631 || yy2arr2631 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34486,25 +34404,25 @@ func (x *LoadBalancerIngress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2647 := z.DecBinary() - _ = yym2647 + yym2638 := z.DecBinary() + _ = yym2638 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2648 := r.ContainerType() - if yyct2648 == codecSelferValueTypeMap1234 { - yyl2648 := r.ReadMapStart() - if yyl2648 == 0 { + yyct2639 := r.ContainerType() + if yyct2639 == codecSelferValueTypeMap1234 { + yyl2639 := r.ReadMapStart() + if yyl2639 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2648, d) + x.codecDecodeSelfFromMap(yyl2639, d) } - } else if yyct2648 == codecSelferValueTypeArray1234 { - yyl2648 := r.ReadArrayStart() - if yyl2648 == 0 { + } else if yyct2639 == codecSelferValueTypeArray1234 { + yyl2639 := r.ReadArrayStart() + if yyl2639 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2648, d) + x.codecDecodeSelfFromArray(yyl2639, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34516,12 +34434,12 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2649Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2649Slc - var yyhl2649 bool = l >= 0 - for yyj2649 := 0; ; yyj2649++ { - if yyhl2649 { - if yyj2649 >= l { + var yys2640Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2640Slc + var yyhl2640 bool = l >= 0 + for yyj2640 := 0; ; yyj2640++ { + if yyhl2640 { + if yyj2640 >= l { break } } else { @@ -34530,10 +34448,10 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2649Slc = r.DecodeBytes(yys2649Slc, true, true) - yys2649 := string(yys2649Slc) + yys2640Slc = r.DecodeBytes(yys2640Slc, true, true) + yys2640 := string(yys2640Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2649 { + switch yys2640 { case "ip": if r.TryDecodeAsNil() { x.IP = "" @@ -34547,9 +34465,9 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Hostname = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2649) - } // end switch yys2649 - } // end for yyj2649 + z.DecStructFieldNotFound(-1, yys2640) + } // end switch yys2640 + } // end for yyj2640 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34557,16 +34475,16 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2652 int - var yyb2652 bool - var yyhl2652 bool = l >= 0 - yyj2652++ - if yyhl2652 { - yyb2652 = yyj2652 > l + var yyj2643 int + var yyb2643 bool + var yyhl2643 bool = l >= 0 + yyj2643++ + if yyhl2643 { + yyb2643 = yyj2643 > l } else { - yyb2652 = r.CheckBreak() + yyb2643 = r.CheckBreak() } - if yyb2652 { + if yyb2643 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34576,13 +34494,13 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.IP = string(r.DecodeString()) } - yyj2652++ - if yyhl2652 { - yyb2652 = yyj2652 > l + yyj2643++ + if yyhl2643 { + yyb2643 = yyj2643 > l } else { - yyb2652 = r.CheckBreak() + yyb2643 = r.CheckBreak() } - if yyb2652 { + if yyb2643 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34593,17 +34511,17 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Hostname = string(r.DecodeString()) } for { - yyj2652++ - if yyhl2652 { - yyb2652 = yyj2652 > l + yyj2643++ + if yyhl2643 { + yyb2643 = yyj2643 > l } else { - yyb2652 = r.CheckBreak() + yyb2643 = r.CheckBreak() } - if yyb2652 { + if yyb2643 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2652-1, "") + z.DecStructFieldNotFound(yyj2643-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34615,57 +34533,57 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2655 := z.EncBinary() - _ = yym2655 + yym2646 := z.EncBinary() + _ = yym2646 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2656 := !z.EncBinary() - yy2arr2656 := z.EncBasicHandle().StructToArray - var yyq2656 [9]bool - _, _, _ = yysep2656, yyq2656, yy2arr2656 - const yyr2656 bool = false - yyq2656[0] = x.Type != "" - yyq2656[3] = x.ClusterIP != "" - yyq2656[5] = len(x.ExternalIPs) != 0 - yyq2656[6] = x.LoadBalancerIP != "" - yyq2656[7] = x.SessionAffinity != "" - yyq2656[8] = len(x.LoadBalancerSourceRanges) != 0 - var yynn2656 int - if yyr2656 || yy2arr2656 { + yysep2647 := !z.EncBinary() + yy2arr2647 := z.EncBasicHandle().StructToArray + var yyq2647 [9]bool + _, _, _ = yysep2647, yyq2647, yy2arr2647 + const yyr2647 bool = false + yyq2647[0] = x.Type != "" + yyq2647[3] = x.ClusterIP != "" + yyq2647[5] = len(x.ExternalIPs) != 0 + yyq2647[6] = x.LoadBalancerIP != "" + yyq2647[7] = x.SessionAffinity != "" + yyq2647[8] = len(x.LoadBalancerSourceRanges) != 0 + var yynn2647 int + if yyr2647 || yy2arr2647 { r.EncodeArrayStart(9) } else { - yynn2656 = 3 - for _, b := range yyq2656 { + yynn2647 = 3 + for _, b := range yyq2647 { if b { - yynn2656++ + yynn2647++ } } - r.EncodeMapStart(yynn2656) - yynn2656 = 0 + r.EncodeMapStart(yynn2647) + yynn2647 = 0 } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[0] { + if yyq2647[0] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2656[0] { + if yyq2647[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Ports == nil { r.EncodeNil() } else { - yym2659 := z.EncBinary() - _ = yym2659 + yym2650 := z.EncBinary() + _ = yym2650 if false { } else { h.encSliceServicePort(([]ServicePort)(x.Ports), e) @@ -34678,21 +34596,21 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Ports == nil { r.EncodeNil() } else { - yym2660 := z.EncBinary() - _ = yym2660 + yym2651 := z.EncBinary() + _ = yym2651 if false { } else { h.encSliceServicePort(([]ServicePort)(x.Ports), e) } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Selector == nil { r.EncodeNil() } else { - yym2662 := z.EncBinary() - _ = yym2662 + yym2653 := z.EncBinary() + _ = yym2653 if false { } else { z.F.EncMapStringStringV(x.Selector, false, e) @@ -34705,19 +34623,19 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - yym2663 := z.EncBinary() - _ = yym2663 + yym2654 := z.EncBinary() + _ = yym2654 if false { } else { z.F.EncMapStringStringV(x.Selector, false, e) } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[3] { - yym2665 := z.EncBinary() - _ = yym2665 + if yyq2647[3] { + yym2656 := z.EncBinary() + _ = yym2656 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ClusterIP)) @@ -34726,22 +34644,22 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2656[3] { + if yyq2647[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("clusterIP")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2666 := z.EncBinary() - _ = yym2666 + yym2657 := z.EncBinary() + _ = yym2657 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ClusterIP)) } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2668 := z.EncBinary() - _ = yym2668 + yym2659 := z.EncBinary() + _ = yym2659 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalName)) @@ -34750,21 +34668,21 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ExternalName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2669 := z.EncBinary() - _ = yym2669 + yym2660 := z.EncBinary() + _ = yym2660 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalName)) } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[5] { + if yyq2647[5] { if x.ExternalIPs == nil { r.EncodeNil() } else { - yym2671 := z.EncBinary() - _ = yym2671 + yym2662 := z.EncBinary() + _ = yym2662 if false { } else { z.F.EncSliceStringV(x.ExternalIPs, false, e) @@ -34774,15 +34692,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2656[5] { + if yyq2647[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("externalIPs")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ExternalIPs == nil { r.EncodeNil() } else { - yym2672 := z.EncBinary() - _ = yym2672 + yym2663 := z.EncBinary() + _ = yym2663 if false { } else { z.F.EncSliceStringV(x.ExternalIPs, false, e) @@ -34790,11 +34708,11 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[6] { - yym2674 := z.EncBinary() - _ = yym2674 + if yyq2647[6] { + yym2665 := z.EncBinary() + _ = yym2665 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.LoadBalancerIP)) @@ -34803,41 +34721,41 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2656[6] { + if yyq2647[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancerIP")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2675 := z.EncBinary() - _ = yym2675 + yym2666 := z.EncBinary() + _ = yym2666 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.LoadBalancerIP)) } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[7] { + if yyq2647[7] { x.SessionAffinity.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2656[7] { + if yyq2647[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("sessionAffinity")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.SessionAffinity.CodecEncodeSelf(e) } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2656[8] { + if yyq2647[8] { if x.LoadBalancerSourceRanges == nil { r.EncodeNil() } else { - yym2678 := z.EncBinary() - _ = yym2678 + yym2669 := z.EncBinary() + _ = yym2669 if false { } else { z.F.EncSliceStringV(x.LoadBalancerSourceRanges, false, e) @@ -34847,15 +34765,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2656[8] { + if yyq2647[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancerSourceRanges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.LoadBalancerSourceRanges == nil { r.EncodeNil() } else { - yym2679 := z.EncBinary() - _ = yym2679 + yym2670 := z.EncBinary() + _ = yym2670 if false { } else { z.F.EncSliceStringV(x.LoadBalancerSourceRanges, false, e) @@ -34863,7 +34781,7 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2656 || yy2arr2656 { + if yyr2647 || yy2arr2647 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34876,25 +34794,25 @@ func (x *ServiceSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2680 := z.DecBinary() - _ = yym2680 + yym2671 := z.DecBinary() + _ = yym2671 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2681 := r.ContainerType() - if yyct2681 == codecSelferValueTypeMap1234 { - yyl2681 := r.ReadMapStart() - if yyl2681 == 0 { + yyct2672 := r.ContainerType() + if yyct2672 == codecSelferValueTypeMap1234 { + yyl2672 := r.ReadMapStart() + if yyl2672 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2681, d) + x.codecDecodeSelfFromMap(yyl2672, d) } - } else if yyct2681 == codecSelferValueTypeArray1234 { - yyl2681 := r.ReadArrayStart() - if yyl2681 == 0 { + } else if yyct2672 == codecSelferValueTypeArray1234 { + yyl2672 := r.ReadArrayStart() + if yyl2672 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2681, d) + x.codecDecodeSelfFromArray(yyl2672, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34906,12 +34824,12 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2682Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2682Slc - var yyhl2682 bool = l >= 0 - for yyj2682 := 0; ; yyj2682++ { - if yyhl2682 { - if yyj2682 >= l { + var yys2673Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2673Slc + var yyhl2673 bool = l >= 0 + for yyj2673 := 0; ; yyj2673++ { + if yyhl2673 { + if yyj2673 >= l { break } } else { @@ -34920,10 +34838,10 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2682Slc = r.DecodeBytes(yys2682Slc, true, true) - yys2682 := string(yys2682Slc) + yys2673Slc = r.DecodeBytes(yys2673Slc, true, true) + yys2673 := string(yys2673Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2682 { + switch yys2673 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -34934,24 +34852,24 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2684 := &x.Ports - yym2685 := z.DecBinary() - _ = yym2685 + yyv2675 := &x.Ports + yym2676 := z.DecBinary() + _ = yym2676 if false { } else { - h.decSliceServicePort((*[]ServicePort)(yyv2684), d) + h.decSliceServicePort((*[]ServicePort)(yyv2675), d) } } case "selector": if r.TryDecodeAsNil() { x.Selector = nil } else { - yyv2686 := &x.Selector - yym2687 := z.DecBinary() - _ = yym2687 + yyv2677 := &x.Selector + yym2678 := z.DecBinary() + _ = yym2678 if false { } else { - z.F.DecMapStringStringX(yyv2686, false, d) + z.F.DecMapStringStringX(yyv2677, false, d) } } case "clusterIP": @@ -34970,12 +34888,12 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ExternalIPs = nil } else { - yyv2690 := &x.ExternalIPs - yym2691 := z.DecBinary() - _ = yym2691 + yyv2681 := &x.ExternalIPs + yym2682 := z.DecBinary() + _ = yym2682 if false { } else { - z.F.DecSliceStringX(yyv2690, false, d) + z.F.DecSliceStringX(yyv2681, false, d) } } case "loadBalancerIP": @@ -34994,18 +34912,18 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancerSourceRanges = nil } else { - yyv2694 := &x.LoadBalancerSourceRanges - yym2695 := z.DecBinary() - _ = yym2695 + yyv2685 := &x.LoadBalancerSourceRanges + yym2686 := z.DecBinary() + _ = yym2686 if false { } else { - z.F.DecSliceStringX(yyv2694, false, d) + z.F.DecSliceStringX(yyv2685, false, d) } } default: - z.DecStructFieldNotFound(-1, yys2682) - } // end switch yys2682 - } // end for yyj2682 + z.DecStructFieldNotFound(-1, yys2673) + } // end switch yys2673 + } // end for yyj2673 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35013,16 +34931,16 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2696 int - var yyb2696 bool - var yyhl2696 bool = l >= 0 - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + var yyj2687 int + var yyb2687 bool + var yyhl2687 bool = l >= 0 + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35032,13 +34950,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = ServiceType(r.DecodeString()) } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35046,21 +34964,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2698 := &x.Ports - yym2699 := z.DecBinary() - _ = yym2699 + yyv2689 := &x.Ports + yym2690 := z.DecBinary() + _ = yym2690 if false { } else { - h.decSliceServicePort((*[]ServicePort)(yyv2698), d) + h.decSliceServicePort((*[]ServicePort)(yyv2689), d) } } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35068,21 +34986,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Selector = nil } else { - yyv2700 := &x.Selector - yym2701 := z.DecBinary() - _ = yym2701 + yyv2691 := &x.Selector + yym2692 := z.DecBinary() + _ = yym2692 if false { } else { - z.F.DecMapStringStringX(yyv2700, false, d) + z.F.DecMapStringStringX(yyv2691, false, d) } } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35092,13 +35010,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ClusterIP = string(r.DecodeString()) } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35108,13 +35026,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ExternalName = string(r.DecodeString()) } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35122,21 +35040,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ExternalIPs = nil } else { - yyv2704 := &x.ExternalIPs - yym2705 := z.DecBinary() - _ = yym2705 + yyv2695 := &x.ExternalIPs + yym2696 := z.DecBinary() + _ = yym2696 if false { } else { - z.F.DecSliceStringX(yyv2704, false, d) + z.F.DecSliceStringX(yyv2695, false, d) } } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35146,13 +35064,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.LoadBalancerIP = string(r.DecodeString()) } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35162,13 +35080,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.SessionAffinity = ServiceAffinity(r.DecodeString()) } - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35176,26 +35094,26 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancerSourceRanges = nil } else { - yyv2708 := &x.LoadBalancerSourceRanges - yym2709 := z.DecBinary() - _ = yym2709 + yyv2699 := &x.LoadBalancerSourceRanges + yym2700 := z.DecBinary() + _ = yym2700 if false { } else { - z.F.DecSliceStringX(yyv2708, false, d) + z.F.DecSliceStringX(yyv2699, false, d) } } for { - yyj2696++ - if yyhl2696 { - yyb2696 = yyj2696 > l + yyj2687++ + if yyhl2687 { + yyb2687 = yyj2687 > l } else { - yyb2696 = r.CheckBreak() + yyb2687 = r.CheckBreak() } - if yyb2696 { + if yyb2687 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2696-1, "") + z.DecStructFieldNotFound(yyj2687-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -35207,33 +35125,33 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2710 := z.EncBinary() - _ = yym2710 + yym2701 := z.EncBinary() + _ = yym2701 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2711 := !z.EncBinary() - yy2arr2711 := z.EncBasicHandle().StructToArray - var yyq2711 [5]bool - _, _, _ = yysep2711, yyq2711, yy2arr2711 - const yyr2711 bool = false - var yynn2711 int - if yyr2711 || yy2arr2711 { + yysep2702 := !z.EncBinary() + yy2arr2702 := z.EncBasicHandle().StructToArray + var yyq2702 [5]bool + _, _, _ = yysep2702, yyq2702, yy2arr2702 + const yyr2702 bool = false + var yynn2702 int + if yyr2702 || yy2arr2702 { r.EncodeArrayStart(5) } else { - yynn2711 = 5 - for _, b := range yyq2711 { + yynn2702 = 5 + for _, b := range yyq2702 { if b { - yynn2711++ + yynn2702++ } } - r.EncodeMapStart(yynn2711) - yynn2711 = 0 + r.EncodeMapStart(yynn2702) + yynn2702 = 0 } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2713 := z.EncBinary() - _ = yym2713 + yym2704 := z.EncBinary() + _ = yym2704 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -35242,14 +35160,14 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2714 := z.EncBinary() - _ = yym2714 + yym2705 := z.EncBinary() + _ = yym2705 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Protocol.CodecEncodeSelf(e) } else { @@ -35258,10 +35176,10 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Protocol.CodecEncodeSelf(e) } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2717 := z.EncBinary() - _ = yym2717 + yym2708 := z.EncBinary() + _ = yym2708 if false { } else { r.EncodeInt(int64(x.Port)) @@ -35270,44 +35188,44 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2718 := z.EncBinary() - _ = yym2718 + yym2709 := z.EncBinary() + _ = yym2709 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy2720 := &x.TargetPort - yym2721 := z.EncBinary() - _ = yym2721 + yy2711 := &x.TargetPort + yym2712 := z.EncBinary() + _ = yym2712 if false { - } else if z.HasExtensions() && z.EncExt(yy2720) { - } else if !yym2721 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2720) + } else if z.HasExtensions() && z.EncExt(yy2711) { + } else if !yym2712 && z.IsJSONHandle() { + z.EncJSONMarshal(yy2711) } else { - z.EncFallback(yy2720) + z.EncFallback(yy2711) } } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("targetPort")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2722 := &x.TargetPort - yym2723 := z.EncBinary() - _ = yym2723 + yy2713 := &x.TargetPort + yym2714 := z.EncBinary() + _ = yym2714 if false { - } else if z.HasExtensions() && z.EncExt(yy2722) { - } else if !yym2723 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2722) + } else if z.HasExtensions() && z.EncExt(yy2713) { + } else if !yym2714 && z.IsJSONHandle() { + z.EncJSONMarshal(yy2713) } else { - z.EncFallback(yy2722) + z.EncFallback(yy2713) } } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2725 := z.EncBinary() - _ = yym2725 + yym2716 := z.EncBinary() + _ = yym2716 if false { } else { r.EncodeInt(int64(x.NodePort)) @@ -35316,14 +35234,14 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodePort")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2726 := z.EncBinary() - _ = yym2726 + yym2717 := z.EncBinary() + _ = yym2717 if false { } else { r.EncodeInt(int64(x.NodePort)) } } - if yyr2711 || yy2arr2711 { + if yyr2702 || yy2arr2702 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -35336,25 +35254,25 @@ func (x *ServicePort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2727 := z.DecBinary() - _ = yym2727 + yym2718 := z.DecBinary() + _ = yym2718 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2728 := r.ContainerType() - if yyct2728 == codecSelferValueTypeMap1234 { - yyl2728 := r.ReadMapStart() - if yyl2728 == 0 { + yyct2719 := r.ContainerType() + if yyct2719 == codecSelferValueTypeMap1234 { + yyl2719 := r.ReadMapStart() + if yyl2719 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2728, d) + x.codecDecodeSelfFromMap(yyl2719, d) } - } else if yyct2728 == codecSelferValueTypeArray1234 { - yyl2728 := r.ReadArrayStart() - if yyl2728 == 0 { + } else if yyct2719 == codecSelferValueTypeArray1234 { + yyl2719 := r.ReadArrayStart() + if yyl2719 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2728, d) + x.codecDecodeSelfFromArray(yyl2719, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -35366,12 +35284,12 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2729Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2729Slc - var yyhl2729 bool = l >= 0 - for yyj2729 := 0; ; yyj2729++ { - if yyhl2729 { - if yyj2729 >= l { + var yys2720Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2720Slc + var yyhl2720 bool = l >= 0 + for yyj2720 := 0; ; yyj2720++ { + if yyhl2720 { + if yyj2720 >= l { break } } else { @@ -35380,10 +35298,10 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2729Slc = r.DecodeBytes(yys2729Slc, true, true) - yys2729 := string(yys2729Slc) + yys2720Slc = r.DecodeBytes(yys2720Slc, true, true) + yys2720 := string(yys2720Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2729 { + switch yys2720 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -35406,15 +35324,15 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TargetPort = pkg4_intstr.IntOrString{} } else { - yyv2733 := &x.TargetPort - yym2734 := z.DecBinary() - _ = yym2734 + yyv2724 := &x.TargetPort + yym2725 := z.DecBinary() + _ = yym2725 if false { - } else if z.HasExtensions() && z.DecExt(yyv2733) { - } else if !yym2734 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2733) + } else if z.HasExtensions() && z.DecExt(yyv2724) { + } else if !yym2725 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2724) } else { - z.DecFallback(yyv2733, false) + z.DecFallback(yyv2724, false) } } case "nodePort": @@ -35424,9 +35342,9 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.NodePort = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys2729) - } // end switch yys2729 - } // end for yyj2729 + z.DecStructFieldNotFound(-1, yys2720) + } // end switch yys2720 + } // end for yyj2720 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35434,16 +35352,16 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2736 int - var yyb2736 bool - var yyhl2736 bool = l >= 0 - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + var yyj2727 int + var yyb2727 bool + var yyhl2727 bool = l >= 0 + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35453,13 +35371,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35469,13 +35387,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Protocol = Protocol(r.DecodeString()) } - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35485,13 +35403,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Port = int32(r.DecodeInt(32)) } - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35499,24 +35417,24 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TargetPort = pkg4_intstr.IntOrString{} } else { - yyv2740 := &x.TargetPort - yym2741 := z.DecBinary() - _ = yym2741 + yyv2731 := &x.TargetPort + yym2732 := z.DecBinary() + _ = yym2732 if false { - } else if z.HasExtensions() && z.DecExt(yyv2740) { - } else if !yym2741 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2740) + } else if z.HasExtensions() && z.DecExt(yyv2731) { + } else if !yym2732 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2731) } else { - z.DecFallback(yyv2740, false) + z.DecFallback(yyv2731, false) } } - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35527,17 +35445,17 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.NodePort = int32(r.DecodeInt(32)) } for { - yyj2736++ - if yyhl2736 { - yyb2736 = yyj2736 > l + yyj2727++ + if yyhl2727 { + yyb2727 = yyj2727 > l } else { - yyb2736 = r.CheckBreak() + yyb2727 = r.CheckBreak() } - if yyb2736 { + if yyb2727 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2736-1, "") + z.DecStructFieldNotFound(yyj2727-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -35549,39 +35467,39 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2743 := z.EncBinary() - _ = yym2743 + yym2734 := z.EncBinary() + _ = yym2734 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2744 := !z.EncBinary() - yy2arr2744 := z.EncBasicHandle().StructToArray - var yyq2744 [5]bool - _, _, _ = yysep2744, yyq2744, yy2arr2744 - const yyr2744 bool = false - yyq2744[0] = x.Kind != "" - yyq2744[1] = x.APIVersion != "" - yyq2744[2] = true - yyq2744[3] = true - yyq2744[4] = true - var yynn2744 int - if yyr2744 || yy2arr2744 { + yysep2735 := !z.EncBinary() + yy2arr2735 := z.EncBasicHandle().StructToArray + var yyq2735 [5]bool + _, _, _ = yysep2735, yyq2735, yy2arr2735 + const yyr2735 bool = false + yyq2735[0] = x.Kind != "" + yyq2735[1] = x.APIVersion != "" + yyq2735[2] = true + yyq2735[3] = true + yyq2735[4] = true + var yynn2735 int + if yyr2735 || yy2arr2735 { r.EncodeArrayStart(5) } else { - yynn2744 = 0 - for _, b := range yyq2744 { + yynn2735 = 0 + for _, b := range yyq2735 { if b { - yynn2744++ + yynn2735++ } } - r.EncodeMapStart(yynn2744) - yynn2744 = 0 + r.EncodeMapStart(yynn2735) + yynn2735 = 0 } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2744[0] { - yym2746 := z.EncBinary() - _ = yym2746 + if yyq2735[0] { + yym2737 := z.EncBinary() + _ = yym2737 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -35590,23 +35508,23 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2744[0] { + if yyq2735[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2747 := z.EncBinary() - _ = yym2747 + yym2738 := z.EncBinary() + _ = yym2738 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2744[1] { - yym2749 := z.EncBinary() - _ = yym2749 + if yyq2735[1] { + yym2740 := z.EncBinary() + _ = yym2740 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -35615,70 +35533,70 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2744[1] { + if yyq2735[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2750 := z.EncBinary() - _ = yym2750 + yym2741 := z.EncBinary() + _ = yym2741 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2744[2] { - yy2752 := &x.ObjectMeta - yy2752.CodecEncodeSelf(e) + if yyq2735[2] { + yy2743 := &x.ObjectMeta + yy2743.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2744[2] { + if yyq2735[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2753 := &x.ObjectMeta - yy2753.CodecEncodeSelf(e) + yy2744 := &x.ObjectMeta + yy2744.CodecEncodeSelf(e) } } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2744[3] { - yy2755 := &x.Spec - yy2755.CodecEncodeSelf(e) + if yyq2735[3] { + yy2746 := &x.Spec + yy2746.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2744[3] { + if yyq2735[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2756 := &x.Spec - yy2756.CodecEncodeSelf(e) + yy2747 := &x.Spec + yy2747.CodecEncodeSelf(e) } } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2744[4] { - yy2758 := &x.Status - yy2758.CodecEncodeSelf(e) + if yyq2735[4] { + yy2749 := &x.Status + yy2749.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2744[4] { + if yyq2735[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2759 := &x.Status - yy2759.CodecEncodeSelf(e) + yy2750 := &x.Status + yy2750.CodecEncodeSelf(e) } } - if yyr2744 || yy2arr2744 { + if yyr2735 || yy2arr2735 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -35691,25 +35609,25 @@ func (x *Service) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2760 := z.DecBinary() - _ = yym2760 + yym2751 := z.DecBinary() + _ = yym2751 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2761 := r.ContainerType() - if yyct2761 == codecSelferValueTypeMap1234 { - yyl2761 := r.ReadMapStart() - if yyl2761 == 0 { + yyct2752 := r.ContainerType() + if yyct2752 == codecSelferValueTypeMap1234 { + yyl2752 := r.ReadMapStart() + if yyl2752 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2761, d) + x.codecDecodeSelfFromMap(yyl2752, d) } - } else if yyct2761 == codecSelferValueTypeArray1234 { - yyl2761 := r.ReadArrayStart() - if yyl2761 == 0 { + } else if yyct2752 == codecSelferValueTypeArray1234 { + yyl2752 := r.ReadArrayStart() + if yyl2752 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2761, d) + x.codecDecodeSelfFromArray(yyl2752, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -35721,12 +35639,12 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2762Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2762Slc - var yyhl2762 bool = l >= 0 - for yyj2762 := 0; ; yyj2762++ { - if yyhl2762 { - if yyj2762 >= l { + var yys2753Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2753Slc + var yyhl2753 bool = l >= 0 + for yyj2753 := 0; ; yyj2753++ { + if yyhl2753 { + if yyj2753 >= l { break } } else { @@ -35735,10 +35653,10 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2762Slc = r.DecodeBytes(yys2762Slc, true, true) - yys2762 := string(yys2762Slc) + yys2753Slc = r.DecodeBytes(yys2753Slc, true, true) + yys2753 := string(yys2753Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2762 { + switch yys2753 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -35755,27 +35673,27 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2765 := &x.ObjectMeta - yyv2765.CodecDecodeSelf(d) + yyv2756 := &x.ObjectMeta + yyv2756.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ServiceSpec{} } else { - yyv2766 := &x.Spec - yyv2766.CodecDecodeSelf(d) + yyv2757 := &x.Spec + yyv2757.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ServiceStatus{} } else { - yyv2767 := &x.Status - yyv2767.CodecDecodeSelf(d) + yyv2758 := &x.Status + yyv2758.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2762) - } // end switch yys2762 - } // end for yyj2762 + z.DecStructFieldNotFound(-1, yys2753) + } // end switch yys2753 + } // end for yyj2753 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35783,16 +35701,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2768 int - var yyb2768 bool - var yyhl2768 bool = l >= 0 - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + var yyj2759 int + var yyb2759 bool + var yyhl2759 bool = l >= 0 + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35802,13 +35720,13 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35818,13 +35736,13 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35832,16 +35750,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2771 := &x.ObjectMeta - yyv2771.CodecDecodeSelf(d) + yyv2762 := &x.ObjectMeta + yyv2762.CodecDecodeSelf(d) } - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35849,16 +35767,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ServiceSpec{} } else { - yyv2772 := &x.Spec - yyv2772.CodecDecodeSelf(d) + yyv2763 := &x.Spec + yyv2763.CodecDecodeSelf(d) } - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35866,21 +35784,21 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ServiceStatus{} } else { - yyv2773 := &x.Status - yyv2773.CodecDecodeSelf(d) + yyv2764 := &x.Status + yyv2764.CodecDecodeSelf(d) } for { - yyj2768++ - if yyhl2768 { - yyb2768 = yyj2768 > l + yyj2759++ + if yyhl2759 { + yyb2759 = yyj2759 > l } else { - yyb2768 = r.CheckBreak() + yyb2759 = r.CheckBreak() } - if yyb2768 { + if yyb2759 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2768-1, "") + z.DecStructFieldNotFound(yyj2759-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -35892,38 +35810,38 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2774 := z.EncBinary() - _ = yym2774 + yym2765 := z.EncBinary() + _ = yym2765 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2775 := !z.EncBinary() - yy2arr2775 := z.EncBasicHandle().StructToArray - var yyq2775 [5]bool - _, _, _ = yysep2775, yyq2775, yy2arr2775 - const yyr2775 bool = false - yyq2775[0] = x.Kind != "" - yyq2775[1] = x.APIVersion != "" - yyq2775[2] = true - yyq2775[4] = len(x.ImagePullSecrets) != 0 - var yynn2775 int - if yyr2775 || yy2arr2775 { + yysep2766 := !z.EncBinary() + yy2arr2766 := z.EncBasicHandle().StructToArray + var yyq2766 [5]bool + _, _, _ = yysep2766, yyq2766, yy2arr2766 + const yyr2766 bool = false + yyq2766[0] = x.Kind != "" + yyq2766[1] = x.APIVersion != "" + yyq2766[2] = true + yyq2766[4] = len(x.ImagePullSecrets) != 0 + var yynn2766 int + if yyr2766 || yy2arr2766 { r.EncodeArrayStart(5) } else { - yynn2775 = 1 - for _, b := range yyq2775 { + yynn2766 = 1 + for _, b := range yyq2766 { if b { - yynn2775++ + yynn2766++ } } - r.EncodeMapStart(yynn2775) - yynn2775 = 0 + r.EncodeMapStart(yynn2766) + yynn2766 = 0 } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2775[0] { - yym2777 := z.EncBinary() - _ = yym2777 + if yyq2766[0] { + yym2768 := z.EncBinary() + _ = yym2768 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -35932,23 +35850,23 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2775[0] { + if yyq2766[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2778 := z.EncBinary() - _ = yym2778 + yym2769 := z.EncBinary() + _ = yym2769 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2775[1] { - yym2780 := z.EncBinary() - _ = yym2780 + if yyq2766[1] { + yym2771 := z.EncBinary() + _ = yym2771 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -35957,42 +35875,42 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2775[1] { + if yyq2766[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2781 := z.EncBinary() - _ = yym2781 + yym2772 := z.EncBinary() + _ = yym2772 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2775[2] { - yy2783 := &x.ObjectMeta - yy2783.CodecEncodeSelf(e) + if yyq2766[2] { + yy2774 := &x.ObjectMeta + yy2774.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2775[2] { + if yyq2766[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2784 := &x.ObjectMeta - yy2784.CodecEncodeSelf(e) + yy2775 := &x.ObjectMeta + yy2775.CodecEncodeSelf(e) } } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Secrets == nil { r.EncodeNil() } else { - yym2786 := z.EncBinary() - _ = yym2786 + yym2777 := z.EncBinary() + _ = yym2777 if false { } else { h.encSliceObjectReference(([]ObjectReference)(x.Secrets), e) @@ -36005,22 +35923,22 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { if x.Secrets == nil { r.EncodeNil() } else { - yym2787 := z.EncBinary() - _ = yym2787 + yym2778 := z.EncBinary() + _ = yym2778 if false { } else { h.encSliceObjectReference(([]ObjectReference)(x.Secrets), e) } } } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2775[4] { + if yyq2766[4] { if x.ImagePullSecrets == nil { r.EncodeNil() } else { - yym2789 := z.EncBinary() - _ = yym2789 + yym2780 := z.EncBinary() + _ = yym2780 if false { } else { h.encSliceLocalObjectReference(([]LocalObjectReference)(x.ImagePullSecrets), e) @@ -36030,15 +35948,15 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2775[4] { + if yyq2766[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("imagePullSecrets")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ImagePullSecrets == nil { r.EncodeNil() } else { - yym2790 := z.EncBinary() - _ = yym2790 + yym2781 := z.EncBinary() + _ = yym2781 if false { } else { h.encSliceLocalObjectReference(([]LocalObjectReference)(x.ImagePullSecrets), e) @@ -36046,7 +35964,7 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2775 || yy2arr2775 { + if yyr2766 || yy2arr2766 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36059,25 +35977,25 @@ func (x *ServiceAccount) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2791 := z.DecBinary() - _ = yym2791 + yym2782 := z.DecBinary() + _ = yym2782 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2792 := r.ContainerType() - if yyct2792 == codecSelferValueTypeMap1234 { - yyl2792 := r.ReadMapStart() - if yyl2792 == 0 { + yyct2783 := r.ContainerType() + if yyct2783 == codecSelferValueTypeMap1234 { + yyl2783 := r.ReadMapStart() + if yyl2783 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2792, d) + x.codecDecodeSelfFromMap(yyl2783, d) } - } else if yyct2792 == codecSelferValueTypeArray1234 { - yyl2792 := r.ReadArrayStart() - if yyl2792 == 0 { + } else if yyct2783 == codecSelferValueTypeArray1234 { + yyl2783 := r.ReadArrayStart() + if yyl2783 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2792, d) + x.codecDecodeSelfFromArray(yyl2783, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36089,12 +36007,12 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2793Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2793Slc - var yyhl2793 bool = l >= 0 - for yyj2793 := 0; ; yyj2793++ { - if yyhl2793 { - if yyj2793 >= l { + var yys2784Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2784Slc + var yyhl2784 bool = l >= 0 + for yyj2784 := 0; ; yyj2784++ { + if yyhl2784 { + if yyj2784 >= l { break } } else { @@ -36103,10 +36021,10 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2793Slc = r.DecodeBytes(yys2793Slc, true, true) - yys2793 := string(yys2793Slc) + yys2784Slc = r.DecodeBytes(yys2784Slc, true, true) + yys2784 := string(yys2784Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2793 { + switch yys2784 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -36123,37 +36041,37 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2796 := &x.ObjectMeta - yyv2796.CodecDecodeSelf(d) + yyv2787 := &x.ObjectMeta + yyv2787.CodecDecodeSelf(d) } case "secrets": if r.TryDecodeAsNil() { x.Secrets = nil } else { - yyv2797 := &x.Secrets - yym2798 := z.DecBinary() - _ = yym2798 + yyv2788 := &x.Secrets + yym2789 := z.DecBinary() + _ = yym2789 if false { } else { - h.decSliceObjectReference((*[]ObjectReference)(yyv2797), d) + h.decSliceObjectReference((*[]ObjectReference)(yyv2788), d) } } case "imagePullSecrets": if r.TryDecodeAsNil() { x.ImagePullSecrets = nil } else { - yyv2799 := &x.ImagePullSecrets - yym2800 := z.DecBinary() - _ = yym2800 + yyv2790 := &x.ImagePullSecrets + yym2791 := z.DecBinary() + _ = yym2791 if false { } else { - h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2799), d) + h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2790), d) } } default: - z.DecStructFieldNotFound(-1, yys2793) - } // end switch yys2793 - } // end for yyj2793 + z.DecStructFieldNotFound(-1, yys2784) + } // end switch yys2784 + } // end for yyj2784 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36161,16 +36079,16 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2801 int - var yyb2801 bool - var yyhl2801 bool = l >= 0 - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + var yyj2792 int + var yyb2792 bool + var yyhl2792 bool = l >= 0 + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36180,13 +36098,13 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36196,13 +36114,13 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36210,16 +36128,16 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2804 := &x.ObjectMeta - yyv2804.CodecDecodeSelf(d) + yyv2795 := &x.ObjectMeta + yyv2795.CodecDecodeSelf(d) } - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36227,21 +36145,21 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Secrets = nil } else { - yyv2805 := &x.Secrets - yym2806 := z.DecBinary() - _ = yym2806 + yyv2796 := &x.Secrets + yym2797 := z.DecBinary() + _ = yym2797 if false { } else { - h.decSliceObjectReference((*[]ObjectReference)(yyv2805), d) + h.decSliceObjectReference((*[]ObjectReference)(yyv2796), d) } } - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36249,26 +36167,26 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ImagePullSecrets = nil } else { - yyv2807 := &x.ImagePullSecrets - yym2808 := z.DecBinary() - _ = yym2808 + yyv2798 := &x.ImagePullSecrets + yym2799 := z.DecBinary() + _ = yym2799 if false { } else { - h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2807), d) + h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2798), d) } } for { - yyj2801++ - if yyhl2801 { - yyb2801 = yyj2801 > l + yyj2792++ + if yyhl2792 { + yyb2792 = yyj2792 > l } else { - yyb2801 = r.CheckBreak() + yyb2792 = r.CheckBreak() } - if yyb2801 { + if yyb2792 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2801-1, "") + z.DecStructFieldNotFound(yyj2792-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36280,37 +36198,37 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2809 := z.EncBinary() - _ = yym2809 + yym2800 := z.EncBinary() + _ = yym2800 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2810 := !z.EncBinary() - yy2arr2810 := z.EncBasicHandle().StructToArray - var yyq2810 [4]bool - _, _, _ = yysep2810, yyq2810, yy2arr2810 - const yyr2810 bool = false - yyq2810[0] = x.Kind != "" - yyq2810[1] = x.APIVersion != "" - yyq2810[2] = true - var yynn2810 int - if yyr2810 || yy2arr2810 { + yysep2801 := !z.EncBinary() + yy2arr2801 := z.EncBasicHandle().StructToArray + var yyq2801 [4]bool + _, _, _ = yysep2801, yyq2801, yy2arr2801 + const yyr2801 bool = false + yyq2801[0] = x.Kind != "" + yyq2801[1] = x.APIVersion != "" + yyq2801[2] = true + var yynn2801 int + if yyr2801 || yy2arr2801 { r.EncodeArrayStart(4) } else { - yynn2810 = 1 - for _, b := range yyq2810 { + yynn2801 = 1 + for _, b := range yyq2801 { if b { - yynn2810++ + yynn2801++ } } - r.EncodeMapStart(yynn2810) - yynn2810 = 0 + r.EncodeMapStart(yynn2801) + yynn2801 = 0 } - if yyr2810 || yy2arr2810 { + if yyr2801 || yy2arr2801 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2810[0] { - yym2812 := z.EncBinary() - _ = yym2812 + if yyq2801[0] { + yym2803 := z.EncBinary() + _ = yym2803 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -36319,23 +36237,23 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2810[0] { + if yyq2801[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2813 := z.EncBinary() - _ = yym2813 + yym2804 := z.EncBinary() + _ = yym2804 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2810 || yy2arr2810 { + if yyr2801 || yy2arr2801 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2810[1] { - yym2815 := z.EncBinary() - _ = yym2815 + if yyq2801[1] { + yym2806 := z.EncBinary() + _ = yym2806 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -36344,54 +36262,54 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2810[1] { + if yyq2801[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2816 := z.EncBinary() - _ = yym2816 + yym2807 := z.EncBinary() + _ = yym2807 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2810 || yy2arr2810 { + if yyr2801 || yy2arr2801 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2810[2] { - yy2818 := &x.ListMeta - yym2819 := z.EncBinary() - _ = yym2819 + if yyq2801[2] { + yy2809 := &x.ListMeta + yym2810 := z.EncBinary() + _ = yym2810 if false { - } else if z.HasExtensions() && z.EncExt(yy2818) { + } else if z.HasExtensions() && z.EncExt(yy2809) { } else { - z.EncFallback(yy2818) + z.EncFallback(yy2809) } } else { r.EncodeNil() } } else { - if yyq2810[2] { + if yyq2801[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2820 := &x.ListMeta - yym2821 := z.EncBinary() - _ = yym2821 + yy2811 := &x.ListMeta + yym2812 := z.EncBinary() + _ = yym2812 if false { - } else if z.HasExtensions() && z.EncExt(yy2820) { + } else if z.HasExtensions() && z.EncExt(yy2811) { } else { - z.EncFallback(yy2820) + z.EncFallback(yy2811) } } } - if yyr2810 || yy2arr2810 { + if yyr2801 || yy2arr2801 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2823 := z.EncBinary() - _ = yym2823 + yym2814 := z.EncBinary() + _ = yym2814 if false { } else { h.encSliceServiceAccount(([]ServiceAccount)(x.Items), e) @@ -36404,15 +36322,15 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2824 := z.EncBinary() - _ = yym2824 + yym2815 := z.EncBinary() + _ = yym2815 if false { } else { h.encSliceServiceAccount(([]ServiceAccount)(x.Items), e) } } } - if yyr2810 || yy2arr2810 { + if yyr2801 || yy2arr2801 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36425,25 +36343,25 @@ func (x *ServiceAccountList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2825 := z.DecBinary() - _ = yym2825 + yym2816 := z.DecBinary() + _ = yym2816 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2826 := r.ContainerType() - if yyct2826 == codecSelferValueTypeMap1234 { - yyl2826 := r.ReadMapStart() - if yyl2826 == 0 { + yyct2817 := r.ContainerType() + if yyct2817 == codecSelferValueTypeMap1234 { + yyl2817 := r.ReadMapStart() + if yyl2817 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2826, d) + x.codecDecodeSelfFromMap(yyl2817, d) } - } else if yyct2826 == codecSelferValueTypeArray1234 { - yyl2826 := r.ReadArrayStart() - if yyl2826 == 0 { + } else if yyct2817 == codecSelferValueTypeArray1234 { + yyl2817 := r.ReadArrayStart() + if yyl2817 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2826, d) + x.codecDecodeSelfFromArray(yyl2817, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36455,12 +36373,12 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2827Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2827Slc - var yyhl2827 bool = l >= 0 - for yyj2827 := 0; ; yyj2827++ { - if yyhl2827 { - if yyj2827 >= l { + var yys2818Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2818Slc + var yyhl2818 bool = l >= 0 + for yyj2818 := 0; ; yyj2818++ { + if yyhl2818 { + if yyj2818 >= l { break } } else { @@ -36469,10 +36387,10 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2827Slc = r.DecodeBytes(yys2827Slc, true, true) - yys2827 := string(yys2827Slc) + yys2818Slc = r.DecodeBytes(yys2818Slc, true, true) + yys2818 := string(yys2818Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2827 { + switch yys2818 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -36489,31 +36407,31 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2830 := &x.ListMeta - yym2831 := z.DecBinary() - _ = yym2831 + yyv2821 := &x.ListMeta + yym2822 := z.DecBinary() + _ = yym2822 if false { - } else if z.HasExtensions() && z.DecExt(yyv2830) { + } else if z.HasExtensions() && z.DecExt(yyv2821) { } else { - z.DecFallback(yyv2830, false) + z.DecFallback(yyv2821, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2832 := &x.Items - yym2833 := z.DecBinary() - _ = yym2833 + yyv2823 := &x.Items + yym2824 := z.DecBinary() + _ = yym2824 if false { } else { - h.decSliceServiceAccount((*[]ServiceAccount)(yyv2832), d) + h.decSliceServiceAccount((*[]ServiceAccount)(yyv2823), d) } } default: - z.DecStructFieldNotFound(-1, yys2827) - } // end switch yys2827 - } // end for yyj2827 + z.DecStructFieldNotFound(-1, yys2818) + } // end switch yys2818 + } // end for yyj2818 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36521,16 +36439,16 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2834 int - var yyb2834 bool - var yyhl2834 bool = l >= 0 - yyj2834++ - if yyhl2834 { - yyb2834 = yyj2834 > l + var yyj2825 int + var yyb2825 bool + var yyhl2825 bool = l >= 0 + yyj2825++ + if yyhl2825 { + yyb2825 = yyj2825 > l } else { - yyb2834 = r.CheckBreak() + yyb2825 = r.CheckBreak() } - if yyb2834 { + if yyb2825 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36540,13 +36458,13 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Kind = string(r.DecodeString()) } - yyj2834++ - if yyhl2834 { - yyb2834 = yyj2834 > l + yyj2825++ + if yyhl2825 { + yyb2825 = yyj2825 > l } else { - yyb2834 = r.CheckBreak() + yyb2825 = r.CheckBreak() } - if yyb2834 { + if yyb2825 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36556,13 +36474,13 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.APIVersion = string(r.DecodeString()) } - yyj2834++ - if yyhl2834 { - yyb2834 = yyj2834 > l + yyj2825++ + if yyhl2825 { + yyb2825 = yyj2825 > l } else { - yyb2834 = r.CheckBreak() + yyb2825 = r.CheckBreak() } - if yyb2834 { + if yyb2825 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36570,22 +36488,22 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2837 := &x.ListMeta - yym2838 := z.DecBinary() - _ = yym2838 + yyv2828 := &x.ListMeta + yym2829 := z.DecBinary() + _ = yym2829 if false { - } else if z.HasExtensions() && z.DecExt(yyv2837) { + } else if z.HasExtensions() && z.DecExt(yyv2828) { } else { - z.DecFallback(yyv2837, false) + z.DecFallback(yyv2828, false) } } - yyj2834++ - if yyhl2834 { - yyb2834 = yyj2834 > l + yyj2825++ + if yyhl2825 { + yyb2825 = yyj2825 > l } else { - yyb2834 = r.CheckBreak() + yyb2825 = r.CheckBreak() } - if yyb2834 { + if yyb2825 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36593,26 +36511,26 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2839 := &x.Items - yym2840 := z.DecBinary() - _ = yym2840 + yyv2830 := &x.Items + yym2831 := z.DecBinary() + _ = yym2831 if false { } else { - h.decSliceServiceAccount((*[]ServiceAccount)(yyv2839), d) + h.decSliceServiceAccount((*[]ServiceAccount)(yyv2830), d) } } for { - yyj2834++ - if yyhl2834 { - yyb2834 = yyj2834 > l + yyj2825++ + if yyhl2825 { + yyb2825 = yyj2825 > l } else { - yyb2834 = r.CheckBreak() + yyb2825 = r.CheckBreak() } - if yyb2834 { + if yyb2825 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2834-1, "") + z.DecStructFieldNotFound(yyj2825-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36624,37 +36542,37 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2841 := z.EncBinary() - _ = yym2841 + yym2832 := z.EncBinary() + _ = yym2832 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2842 := !z.EncBinary() - yy2arr2842 := z.EncBasicHandle().StructToArray - var yyq2842 [4]bool - _, _, _ = yysep2842, yyq2842, yy2arr2842 - const yyr2842 bool = false - yyq2842[0] = x.Kind != "" - yyq2842[1] = x.APIVersion != "" - yyq2842[2] = true - var yynn2842 int - if yyr2842 || yy2arr2842 { + yysep2833 := !z.EncBinary() + yy2arr2833 := z.EncBasicHandle().StructToArray + var yyq2833 [4]bool + _, _, _ = yysep2833, yyq2833, yy2arr2833 + const yyr2833 bool = false + yyq2833[0] = x.Kind != "" + yyq2833[1] = x.APIVersion != "" + yyq2833[2] = true + var yynn2833 int + if yyr2833 || yy2arr2833 { r.EncodeArrayStart(4) } else { - yynn2842 = 1 - for _, b := range yyq2842 { + yynn2833 = 1 + for _, b := range yyq2833 { if b { - yynn2842++ + yynn2833++ } } - r.EncodeMapStart(yynn2842) - yynn2842 = 0 + r.EncodeMapStart(yynn2833) + yynn2833 = 0 } - if yyr2842 || yy2arr2842 { + if yyr2833 || yy2arr2833 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2842[0] { - yym2844 := z.EncBinary() - _ = yym2844 + if yyq2833[0] { + yym2835 := z.EncBinary() + _ = yym2835 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -36663,23 +36581,23 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2842[0] { + if yyq2833[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2845 := z.EncBinary() - _ = yym2845 + yym2836 := z.EncBinary() + _ = yym2836 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2842 || yy2arr2842 { + if yyr2833 || yy2arr2833 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2842[1] { - yym2847 := z.EncBinary() - _ = yym2847 + if yyq2833[1] { + yym2838 := z.EncBinary() + _ = yym2838 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -36688,42 +36606,42 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2842[1] { + if yyq2833[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2848 := z.EncBinary() - _ = yym2848 + yym2839 := z.EncBinary() + _ = yym2839 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2842 || yy2arr2842 { + if yyr2833 || yy2arr2833 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2842[2] { - yy2850 := &x.ObjectMeta - yy2850.CodecEncodeSelf(e) + if yyq2833[2] { + yy2841 := &x.ObjectMeta + yy2841.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2842[2] { + if yyq2833[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2851 := &x.ObjectMeta - yy2851.CodecEncodeSelf(e) + yy2842 := &x.ObjectMeta + yy2842.CodecEncodeSelf(e) } } - if yyr2842 || yy2arr2842 { + if yyr2833 || yy2arr2833 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Subsets == nil { r.EncodeNil() } else { - yym2853 := z.EncBinary() - _ = yym2853 + yym2844 := z.EncBinary() + _ = yym2844 if false { } else { h.encSliceEndpointSubset(([]EndpointSubset)(x.Subsets), e) @@ -36736,15 +36654,15 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x.Subsets == nil { r.EncodeNil() } else { - yym2854 := z.EncBinary() - _ = yym2854 + yym2845 := z.EncBinary() + _ = yym2845 if false { } else { h.encSliceEndpointSubset(([]EndpointSubset)(x.Subsets), e) } } } - if yyr2842 || yy2arr2842 { + if yyr2833 || yy2arr2833 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36757,25 +36675,25 @@ func (x *Endpoints) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2855 := z.DecBinary() - _ = yym2855 + yym2846 := z.DecBinary() + _ = yym2846 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2856 := r.ContainerType() - if yyct2856 == codecSelferValueTypeMap1234 { - yyl2856 := r.ReadMapStart() - if yyl2856 == 0 { + yyct2847 := r.ContainerType() + if yyct2847 == codecSelferValueTypeMap1234 { + yyl2847 := r.ReadMapStart() + if yyl2847 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2856, d) + x.codecDecodeSelfFromMap(yyl2847, d) } - } else if yyct2856 == codecSelferValueTypeArray1234 { - yyl2856 := r.ReadArrayStart() - if yyl2856 == 0 { + } else if yyct2847 == codecSelferValueTypeArray1234 { + yyl2847 := r.ReadArrayStart() + if yyl2847 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2856, d) + x.codecDecodeSelfFromArray(yyl2847, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36787,12 +36705,12 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2857Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2857Slc - var yyhl2857 bool = l >= 0 - for yyj2857 := 0; ; yyj2857++ { - if yyhl2857 { - if yyj2857 >= l { + var yys2848Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2848Slc + var yyhl2848 bool = l >= 0 + for yyj2848 := 0; ; yyj2848++ { + if yyhl2848 { + if yyj2848 >= l { break } } else { @@ -36801,10 +36719,10 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2857Slc = r.DecodeBytes(yys2857Slc, true, true) - yys2857 := string(yys2857Slc) + yys2848Slc = r.DecodeBytes(yys2848Slc, true, true) + yys2848 := string(yys2848Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2857 { + switch yys2848 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -36821,25 +36739,25 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2860 := &x.ObjectMeta - yyv2860.CodecDecodeSelf(d) + yyv2851 := &x.ObjectMeta + yyv2851.CodecDecodeSelf(d) } case "Subsets": if r.TryDecodeAsNil() { x.Subsets = nil } else { - yyv2861 := &x.Subsets - yym2862 := z.DecBinary() - _ = yym2862 + yyv2852 := &x.Subsets + yym2853 := z.DecBinary() + _ = yym2853 if false { } else { - h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2861), d) + h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2852), d) } } default: - z.DecStructFieldNotFound(-1, yys2857) - } // end switch yys2857 - } // end for yyj2857 + z.DecStructFieldNotFound(-1, yys2848) + } // end switch yys2848 + } // end for yyj2848 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36847,16 +36765,16 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2863 int - var yyb2863 bool - var yyhl2863 bool = l >= 0 - yyj2863++ - if yyhl2863 { - yyb2863 = yyj2863 > l + var yyj2854 int + var yyb2854 bool + var yyhl2854 bool = l >= 0 + yyj2854++ + if yyhl2854 { + yyb2854 = yyj2854 > l } else { - yyb2863 = r.CheckBreak() + yyb2854 = r.CheckBreak() } - if yyb2863 { + if yyb2854 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36866,13 +36784,13 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2863++ - if yyhl2863 { - yyb2863 = yyj2863 > l + yyj2854++ + if yyhl2854 { + yyb2854 = yyj2854 > l } else { - yyb2863 = r.CheckBreak() + yyb2854 = r.CheckBreak() } - if yyb2863 { + if yyb2854 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36882,13 +36800,13 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2863++ - if yyhl2863 { - yyb2863 = yyj2863 > l + yyj2854++ + if yyhl2854 { + yyb2854 = yyj2854 > l } else { - yyb2863 = r.CheckBreak() + yyb2854 = r.CheckBreak() } - if yyb2863 { + if yyb2854 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36896,16 +36814,16 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2866 := &x.ObjectMeta - yyv2866.CodecDecodeSelf(d) + yyv2857 := &x.ObjectMeta + yyv2857.CodecDecodeSelf(d) } - yyj2863++ - if yyhl2863 { - yyb2863 = yyj2863 > l + yyj2854++ + if yyhl2854 { + yyb2854 = yyj2854 > l } else { - yyb2863 = r.CheckBreak() + yyb2854 = r.CheckBreak() } - if yyb2863 { + if yyb2854 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36913,26 +36831,26 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Subsets = nil } else { - yyv2867 := &x.Subsets - yym2868 := z.DecBinary() - _ = yym2868 + yyv2858 := &x.Subsets + yym2859 := z.DecBinary() + _ = yym2859 if false { } else { - h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2867), d) + h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2858), d) } } for { - yyj2863++ - if yyhl2863 { - yyb2863 = yyj2863 > l + yyj2854++ + if yyhl2854 { + yyb2854 = yyj2854 > l } else { - yyb2863 = r.CheckBreak() + yyb2854 = r.CheckBreak() } - if yyb2863 { + if yyb2854 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2863-1, "") + z.DecStructFieldNotFound(yyj2854-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36944,36 +36862,36 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2869 := z.EncBinary() - _ = yym2869 + yym2860 := z.EncBinary() + _ = yym2860 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2870 := !z.EncBinary() - yy2arr2870 := z.EncBasicHandle().StructToArray - var yyq2870 [3]bool - _, _, _ = yysep2870, yyq2870, yy2arr2870 - const yyr2870 bool = false - var yynn2870 int - if yyr2870 || yy2arr2870 { + yysep2861 := !z.EncBinary() + yy2arr2861 := z.EncBasicHandle().StructToArray + var yyq2861 [3]bool + _, _, _ = yysep2861, yyq2861, yy2arr2861 + const yyr2861 bool = false + var yynn2861 int + if yyr2861 || yy2arr2861 { r.EncodeArrayStart(3) } else { - yynn2870 = 3 - for _, b := range yyq2870 { + yynn2861 = 3 + for _, b := range yyq2861 { if b { - yynn2870++ + yynn2861++ } } - r.EncodeMapStart(yynn2870) - yynn2870 = 0 + r.EncodeMapStart(yynn2861) + yynn2861 = 0 } - if yyr2870 || yy2arr2870 { + if yyr2861 || yy2arr2861 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Addresses == nil { r.EncodeNil() } else { - yym2872 := z.EncBinary() - _ = yym2872 + yym2863 := z.EncBinary() + _ = yym2863 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.Addresses), e) @@ -36986,21 +36904,21 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { if x.Addresses == nil { r.EncodeNil() } else { - yym2873 := z.EncBinary() - _ = yym2873 + yym2864 := z.EncBinary() + _ = yym2864 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.Addresses), e) } } } - if yyr2870 || yy2arr2870 { + if yyr2861 || yy2arr2861 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.NotReadyAddresses == nil { r.EncodeNil() } else { - yym2875 := z.EncBinary() - _ = yym2875 + yym2866 := z.EncBinary() + _ = yym2866 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.NotReadyAddresses), e) @@ -37013,21 +36931,21 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { if x.NotReadyAddresses == nil { r.EncodeNil() } else { - yym2876 := z.EncBinary() - _ = yym2876 + yym2867 := z.EncBinary() + _ = yym2867 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.NotReadyAddresses), e) } } } - if yyr2870 || yy2arr2870 { + if yyr2861 || yy2arr2861 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Ports == nil { r.EncodeNil() } else { - yym2878 := z.EncBinary() - _ = yym2878 + yym2869 := z.EncBinary() + _ = yym2869 if false { } else { h.encSliceEndpointPort(([]EndpointPort)(x.Ports), e) @@ -37040,15 +36958,15 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { if x.Ports == nil { r.EncodeNil() } else { - yym2879 := z.EncBinary() - _ = yym2879 + yym2870 := z.EncBinary() + _ = yym2870 if false { } else { h.encSliceEndpointPort(([]EndpointPort)(x.Ports), e) } } } - if yyr2870 || yy2arr2870 { + if yyr2861 || yy2arr2861 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37061,25 +36979,25 @@ func (x *EndpointSubset) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2880 := z.DecBinary() - _ = yym2880 + yym2871 := z.DecBinary() + _ = yym2871 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2881 := r.ContainerType() - if yyct2881 == codecSelferValueTypeMap1234 { - yyl2881 := r.ReadMapStart() - if yyl2881 == 0 { + yyct2872 := r.ContainerType() + if yyct2872 == codecSelferValueTypeMap1234 { + yyl2872 := r.ReadMapStart() + if yyl2872 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2881, d) + x.codecDecodeSelfFromMap(yyl2872, d) } - } else if yyct2881 == codecSelferValueTypeArray1234 { - yyl2881 := r.ReadArrayStart() - if yyl2881 == 0 { + } else if yyct2872 == codecSelferValueTypeArray1234 { + yyl2872 := r.ReadArrayStart() + if yyl2872 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2881, d) + x.codecDecodeSelfFromArray(yyl2872, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37091,12 +37009,12 @@ func (x *EndpointSubset) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2882Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2882Slc - var yyhl2882 bool = l >= 0 - for yyj2882 := 0; ; yyj2882++ { - if yyhl2882 { - if yyj2882 >= l { + var yys2873Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2873Slc + var yyhl2873 bool = l >= 0 + for yyj2873 := 0; ; yyj2873++ { + if yyhl2873 { + if yyj2873 >= l { break } } else { @@ -37105,50 +37023,50 @@ func (x *EndpointSubset) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2882Slc = r.DecodeBytes(yys2882Slc, true, true) - yys2882 := string(yys2882Slc) + yys2873Slc = r.DecodeBytes(yys2873Slc, true, true) + yys2873 := string(yys2873Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2882 { + switch yys2873 { case "Addresses": if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv2883 := &x.Addresses - yym2884 := z.DecBinary() - _ = yym2884 + yyv2874 := &x.Addresses + yym2875 := z.DecBinary() + _ = yym2875 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2883), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2874), d) } } case "NotReadyAddresses": if r.TryDecodeAsNil() { x.NotReadyAddresses = nil } else { - yyv2885 := &x.NotReadyAddresses - yym2886 := z.DecBinary() - _ = yym2886 + yyv2876 := &x.NotReadyAddresses + yym2877 := z.DecBinary() + _ = yym2877 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2885), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2876), d) } } case "Ports": if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2887 := &x.Ports - yym2888 := z.DecBinary() - _ = yym2888 + yyv2878 := &x.Ports + yym2879 := z.DecBinary() + _ = yym2879 if false { } else { - h.decSliceEndpointPort((*[]EndpointPort)(yyv2887), d) + h.decSliceEndpointPort((*[]EndpointPort)(yyv2878), d) } } default: - z.DecStructFieldNotFound(-1, yys2882) - } // end switch yys2882 - } // end for yyj2882 + z.DecStructFieldNotFound(-1, yys2873) + } // end switch yys2873 + } // end for yyj2873 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37156,16 +37074,16 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2889 int - var yyb2889 bool - var yyhl2889 bool = l >= 0 - yyj2889++ - if yyhl2889 { - yyb2889 = yyj2889 > l + var yyj2880 int + var yyb2880 bool + var yyhl2880 bool = l >= 0 + yyj2880++ + if yyhl2880 { + yyb2880 = yyj2880 > l } else { - yyb2889 = r.CheckBreak() + yyb2880 = r.CheckBreak() } - if yyb2889 { + if yyb2880 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37173,21 +37091,21 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv2890 := &x.Addresses - yym2891 := z.DecBinary() - _ = yym2891 + yyv2881 := &x.Addresses + yym2882 := z.DecBinary() + _ = yym2882 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2890), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2881), d) } } - yyj2889++ - if yyhl2889 { - yyb2889 = yyj2889 > l + yyj2880++ + if yyhl2880 { + yyb2880 = yyj2880 > l } else { - yyb2889 = r.CheckBreak() + yyb2880 = r.CheckBreak() } - if yyb2889 { + if yyb2880 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37195,21 +37113,21 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.NotReadyAddresses = nil } else { - yyv2892 := &x.NotReadyAddresses - yym2893 := z.DecBinary() - _ = yym2893 + yyv2883 := &x.NotReadyAddresses + yym2884 := z.DecBinary() + _ = yym2884 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2892), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2883), d) } } - yyj2889++ - if yyhl2889 { - yyb2889 = yyj2889 > l + yyj2880++ + if yyhl2880 { + yyb2880 = yyj2880 > l } else { - yyb2889 = r.CheckBreak() + yyb2880 = r.CheckBreak() } - if yyb2889 { + if yyb2880 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37217,26 +37135,26 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2894 := &x.Ports - yym2895 := z.DecBinary() - _ = yym2895 + yyv2885 := &x.Ports + yym2886 := z.DecBinary() + _ = yym2886 if false { } else { - h.decSliceEndpointPort((*[]EndpointPort)(yyv2894), d) + h.decSliceEndpointPort((*[]EndpointPort)(yyv2885), d) } } for { - yyj2889++ - if yyhl2889 { - yyb2889 = yyj2889 > l + yyj2880++ + if yyhl2880 { + yyb2880 = yyj2880 > l } else { - yyb2889 = r.CheckBreak() + yyb2880 = r.CheckBreak() } - if yyb2889 { + if yyb2880 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2889-1, "") + z.DecStructFieldNotFound(yyj2880-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37248,35 +37166,35 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2896 := z.EncBinary() - _ = yym2896 + yym2887 := z.EncBinary() + _ = yym2887 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2897 := !z.EncBinary() - yy2arr2897 := z.EncBasicHandle().StructToArray - var yyq2897 [4]bool - _, _, _ = yysep2897, yyq2897, yy2arr2897 - const yyr2897 bool = false - yyq2897[1] = x.Hostname != "" - yyq2897[2] = x.NodeName != nil - var yynn2897 int - if yyr2897 || yy2arr2897 { + yysep2888 := !z.EncBinary() + yy2arr2888 := z.EncBasicHandle().StructToArray + var yyq2888 [4]bool + _, _, _ = yysep2888, yyq2888, yy2arr2888 + const yyr2888 bool = false + yyq2888[1] = x.Hostname != "" + yyq2888[2] = x.NodeName != nil + var yynn2888 int + if yyr2888 || yy2arr2888 { r.EncodeArrayStart(4) } else { - yynn2897 = 2 - for _, b := range yyq2897 { + yynn2888 = 2 + for _, b := range yyq2888 { if b { - yynn2897++ + yynn2888++ } } - r.EncodeMapStart(yynn2897) - yynn2897 = 0 + r.EncodeMapStart(yynn2888) + yynn2888 = 0 } - if yyr2897 || yy2arr2897 { + if yyr2888 || yy2arr2888 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2899 := z.EncBinary() - _ = yym2899 + yym2890 := z.EncBinary() + _ = yym2890 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) @@ -37285,18 +37203,18 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("IP")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2900 := z.EncBinary() - _ = yym2900 + yym2891 := z.EncBinary() + _ = yym2891 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) } } - if yyr2897 || yy2arr2897 { + if yyr2888 || yy2arr2888 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2897[1] { - yym2902 := z.EncBinary() - _ = yym2902 + if yyq2888[1] { + yym2893 := z.EncBinary() + _ = yym2893 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) @@ -37305,54 +37223,54 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2897[1] { + if yyq2888[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostname")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2903 := z.EncBinary() - _ = yym2903 + yym2894 := z.EncBinary() + _ = yym2894 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) } } } - if yyr2897 || yy2arr2897 { + if yyr2888 || yy2arr2888 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2897[2] { + if yyq2888[2] { if x.NodeName == nil { r.EncodeNil() } else { - yy2905 := *x.NodeName - yym2906 := z.EncBinary() - _ = yym2906 + yy2896 := *x.NodeName + yym2897 := z.EncBinary() + _ = yym2897 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy2905)) + r.EncodeString(codecSelferC_UTF81234, string(yy2896)) } } } else { r.EncodeNil() } } else { - if yyq2897[2] { + if yyq2888[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodeName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.NodeName == nil { r.EncodeNil() } else { - yy2907 := *x.NodeName - yym2908 := z.EncBinary() - _ = yym2908 + yy2898 := *x.NodeName + yym2899 := z.EncBinary() + _ = yym2899 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy2907)) + r.EncodeString(codecSelferC_UTF81234, string(yy2898)) } } } } - if yyr2897 || yy2arr2897 { + if yyr2888 || yy2arr2888 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.TargetRef == nil { r.EncodeNil() @@ -37369,7 +37287,7 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { x.TargetRef.CodecEncodeSelf(e) } } - if yyr2897 || yy2arr2897 { + if yyr2888 || yy2arr2888 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37382,25 +37300,25 @@ func (x *EndpointAddress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2910 := z.DecBinary() - _ = yym2910 + yym2901 := z.DecBinary() + _ = yym2901 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2911 := r.ContainerType() - if yyct2911 == codecSelferValueTypeMap1234 { - yyl2911 := r.ReadMapStart() - if yyl2911 == 0 { + yyct2902 := r.ContainerType() + if yyct2902 == codecSelferValueTypeMap1234 { + yyl2902 := r.ReadMapStart() + if yyl2902 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2911, d) + x.codecDecodeSelfFromMap(yyl2902, d) } - } else if yyct2911 == codecSelferValueTypeArray1234 { - yyl2911 := r.ReadArrayStart() - if yyl2911 == 0 { + } else if yyct2902 == codecSelferValueTypeArray1234 { + yyl2902 := r.ReadArrayStart() + if yyl2902 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2911, d) + x.codecDecodeSelfFromArray(yyl2902, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37412,12 +37330,12 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2912Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2912Slc - var yyhl2912 bool = l >= 0 - for yyj2912 := 0; ; yyj2912++ { - if yyhl2912 { - if yyj2912 >= l { + var yys2903Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2903Slc + var yyhl2903 bool = l >= 0 + for yyj2903 := 0; ; yyj2903++ { + if yyhl2903 { + if yyj2903 >= l { break } } else { @@ -37426,10 +37344,10 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2912Slc = r.DecodeBytes(yys2912Slc, true, true) - yys2912 := string(yys2912Slc) + yys2903Slc = r.DecodeBytes(yys2903Slc, true, true) + yys2903 := string(yys2903Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2912 { + switch yys2903 { case "IP": if r.TryDecodeAsNil() { x.IP = "" @@ -37451,8 +37369,8 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.NodeName == nil { x.NodeName = new(string) } - yym2916 := z.DecBinary() - _ = yym2916 + yym2907 := z.DecBinary() + _ = yym2907 if false { } else { *((*string)(x.NodeName)) = r.DecodeString() @@ -37470,9 +37388,9 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.TargetRef.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2912) - } // end switch yys2912 - } // end for yyj2912 + z.DecStructFieldNotFound(-1, yys2903) + } // end switch yys2903 + } // end for yyj2903 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37480,16 +37398,16 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2918 int - var yyb2918 bool - var yyhl2918 bool = l >= 0 - yyj2918++ - if yyhl2918 { - yyb2918 = yyj2918 > l + var yyj2909 int + var yyb2909 bool + var yyhl2909 bool = l >= 0 + yyj2909++ + if yyhl2909 { + yyb2909 = yyj2909 > l } else { - yyb2918 = r.CheckBreak() + yyb2909 = r.CheckBreak() } - if yyb2918 { + if yyb2909 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37499,13 +37417,13 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.IP = string(r.DecodeString()) } - yyj2918++ - if yyhl2918 { - yyb2918 = yyj2918 > l + yyj2909++ + if yyhl2909 { + yyb2909 = yyj2909 > l } else { - yyb2918 = r.CheckBreak() + yyb2909 = r.CheckBreak() } - if yyb2918 { + if yyb2909 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37515,13 +37433,13 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Hostname = string(r.DecodeString()) } - yyj2918++ - if yyhl2918 { - yyb2918 = yyj2918 > l + yyj2909++ + if yyhl2909 { + yyb2909 = yyj2909 > l } else { - yyb2918 = r.CheckBreak() + yyb2909 = r.CheckBreak() } - if yyb2918 { + if yyb2909 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37534,20 +37452,20 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.NodeName == nil { x.NodeName = new(string) } - yym2922 := z.DecBinary() - _ = yym2922 + yym2913 := z.DecBinary() + _ = yym2913 if false { } else { *((*string)(x.NodeName)) = r.DecodeString() } } - yyj2918++ - if yyhl2918 { - yyb2918 = yyj2918 > l + yyj2909++ + if yyhl2909 { + yyb2909 = yyj2909 > l } else { - yyb2918 = r.CheckBreak() + yyb2909 = r.CheckBreak() } - if yyb2918 { + if yyb2909 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37563,17 +37481,17 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.TargetRef.CodecDecodeSelf(d) } for { - yyj2918++ - if yyhl2918 { - yyb2918 = yyj2918 > l + yyj2909++ + if yyhl2909 { + yyb2909 = yyj2909 > l } else { - yyb2918 = r.CheckBreak() + yyb2909 = r.CheckBreak() } - if yyb2918 { + if yyb2909 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2918-1, "") + z.DecStructFieldNotFound(yyj2909-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37585,33 +37503,33 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2924 := z.EncBinary() - _ = yym2924 + yym2915 := z.EncBinary() + _ = yym2915 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2925 := !z.EncBinary() - yy2arr2925 := z.EncBasicHandle().StructToArray - var yyq2925 [3]bool - _, _, _ = yysep2925, yyq2925, yy2arr2925 - const yyr2925 bool = false - var yynn2925 int - if yyr2925 || yy2arr2925 { + yysep2916 := !z.EncBinary() + yy2arr2916 := z.EncBasicHandle().StructToArray + var yyq2916 [3]bool + _, _, _ = yysep2916, yyq2916, yy2arr2916 + const yyr2916 bool = false + var yynn2916 int + if yyr2916 || yy2arr2916 { r.EncodeArrayStart(3) } else { - yynn2925 = 3 - for _, b := range yyq2925 { + yynn2916 = 3 + for _, b := range yyq2916 { if b { - yynn2925++ + yynn2916++ } } - r.EncodeMapStart(yynn2925) - yynn2925 = 0 + r.EncodeMapStart(yynn2916) + yynn2916 = 0 } - if yyr2925 || yy2arr2925 { + if yyr2916 || yy2arr2916 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2927 := z.EncBinary() - _ = yym2927 + yym2918 := z.EncBinary() + _ = yym2918 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -37620,17 +37538,17 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2928 := z.EncBinary() - _ = yym2928 + yym2919 := z.EncBinary() + _ = yym2919 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr2925 || yy2arr2925 { + if yyr2916 || yy2arr2916 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2930 := z.EncBinary() - _ = yym2930 + yym2921 := z.EncBinary() + _ = yym2921 if false { } else { r.EncodeInt(int64(x.Port)) @@ -37639,14 +37557,14 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2931 := z.EncBinary() - _ = yym2931 + yym2922 := z.EncBinary() + _ = yym2922 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr2925 || yy2arr2925 { + if yyr2916 || yy2arr2916 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Protocol.CodecEncodeSelf(e) } else { @@ -37655,7 +37573,7 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Protocol.CodecEncodeSelf(e) } - if yyr2925 || yy2arr2925 { + if yyr2916 || yy2arr2916 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37668,25 +37586,25 @@ func (x *EndpointPort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2933 := z.DecBinary() - _ = yym2933 + yym2924 := z.DecBinary() + _ = yym2924 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2934 := r.ContainerType() - if yyct2934 == codecSelferValueTypeMap1234 { - yyl2934 := r.ReadMapStart() - if yyl2934 == 0 { + yyct2925 := r.ContainerType() + if yyct2925 == codecSelferValueTypeMap1234 { + yyl2925 := r.ReadMapStart() + if yyl2925 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2934, d) + x.codecDecodeSelfFromMap(yyl2925, d) } - } else if yyct2934 == codecSelferValueTypeArray1234 { - yyl2934 := r.ReadArrayStart() - if yyl2934 == 0 { + } else if yyct2925 == codecSelferValueTypeArray1234 { + yyl2925 := r.ReadArrayStart() + if yyl2925 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2934, d) + x.codecDecodeSelfFromArray(yyl2925, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37698,12 +37616,12 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2935Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2935Slc - var yyhl2935 bool = l >= 0 - for yyj2935 := 0; ; yyj2935++ { - if yyhl2935 { - if yyj2935 >= l { + var yys2926Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2926Slc + var yyhl2926 bool = l >= 0 + for yyj2926 := 0; ; yyj2926++ { + if yyhl2926 { + if yyj2926 >= l { break } } else { @@ -37712,10 +37630,10 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2935Slc = r.DecodeBytes(yys2935Slc, true, true) - yys2935 := string(yys2935Slc) + yys2926Slc = r.DecodeBytes(yys2926Slc, true, true) + yys2926 := string(yys2926Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2935 { + switch yys2926 { case "Name": if r.TryDecodeAsNil() { x.Name = "" @@ -37735,9 +37653,9 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Protocol = Protocol(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2935) - } // end switch yys2935 - } // end for yyj2935 + z.DecStructFieldNotFound(-1, yys2926) + } // end switch yys2926 + } // end for yyj2926 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37745,16 +37663,16 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2939 int - var yyb2939 bool - var yyhl2939 bool = l >= 0 - yyj2939++ - if yyhl2939 { - yyb2939 = yyj2939 > l + var yyj2930 int + var yyb2930 bool + var yyhl2930 bool = l >= 0 + yyj2930++ + if yyhl2930 { + yyb2930 = yyj2930 > l } else { - yyb2939 = r.CheckBreak() + yyb2930 = r.CheckBreak() } - if yyb2939 { + if yyb2930 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37764,13 +37682,13 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj2939++ - if yyhl2939 { - yyb2939 = yyj2939 > l + yyj2930++ + if yyhl2930 { + yyb2930 = yyj2930 > l } else { - yyb2939 = r.CheckBreak() + yyb2930 = r.CheckBreak() } - if yyb2939 { + if yyb2930 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37780,13 +37698,13 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Port = int32(r.DecodeInt(32)) } - yyj2939++ - if yyhl2939 { - yyb2939 = yyj2939 > l + yyj2930++ + if yyhl2930 { + yyb2930 = yyj2930 > l } else { - yyb2939 = r.CheckBreak() + yyb2930 = r.CheckBreak() } - if yyb2939 { + if yyb2930 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37797,17 +37715,17 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Protocol = Protocol(r.DecodeString()) } for { - yyj2939++ - if yyhl2939 { - yyb2939 = yyj2939 > l + yyj2930++ + if yyhl2930 { + yyb2930 = yyj2930 > l } else { - yyb2939 = r.CheckBreak() + yyb2930 = r.CheckBreak() } - if yyb2939 { + if yyb2930 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2939-1, "") + z.DecStructFieldNotFound(yyj2930-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37819,37 +37737,37 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2943 := z.EncBinary() - _ = yym2943 + yym2934 := z.EncBinary() + _ = yym2934 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2944 := !z.EncBinary() - yy2arr2944 := z.EncBasicHandle().StructToArray - var yyq2944 [4]bool - _, _, _ = yysep2944, yyq2944, yy2arr2944 - const yyr2944 bool = false - yyq2944[0] = x.Kind != "" - yyq2944[1] = x.APIVersion != "" - yyq2944[2] = true - var yynn2944 int - if yyr2944 || yy2arr2944 { + yysep2935 := !z.EncBinary() + yy2arr2935 := z.EncBasicHandle().StructToArray + var yyq2935 [4]bool + _, _, _ = yysep2935, yyq2935, yy2arr2935 + const yyr2935 bool = false + yyq2935[0] = x.Kind != "" + yyq2935[1] = x.APIVersion != "" + yyq2935[2] = true + var yynn2935 int + if yyr2935 || yy2arr2935 { r.EncodeArrayStart(4) } else { - yynn2944 = 1 - for _, b := range yyq2944 { + yynn2935 = 1 + for _, b := range yyq2935 { if b { - yynn2944++ + yynn2935++ } } - r.EncodeMapStart(yynn2944) - yynn2944 = 0 + r.EncodeMapStart(yynn2935) + yynn2935 = 0 } - if yyr2944 || yy2arr2944 { + if yyr2935 || yy2arr2935 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2944[0] { - yym2946 := z.EncBinary() - _ = yym2946 + if yyq2935[0] { + yym2937 := z.EncBinary() + _ = yym2937 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -37858,23 +37776,23 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2944[0] { + if yyq2935[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2947 := z.EncBinary() - _ = yym2947 + yym2938 := z.EncBinary() + _ = yym2938 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2944 || yy2arr2944 { + if yyr2935 || yy2arr2935 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2944[1] { - yym2949 := z.EncBinary() - _ = yym2949 + if yyq2935[1] { + yym2940 := z.EncBinary() + _ = yym2940 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -37883,54 +37801,54 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2944[1] { + if yyq2935[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2950 := z.EncBinary() - _ = yym2950 + yym2941 := z.EncBinary() + _ = yym2941 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2944 || yy2arr2944 { + if yyr2935 || yy2arr2935 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2944[2] { - yy2952 := &x.ListMeta - yym2953 := z.EncBinary() - _ = yym2953 + if yyq2935[2] { + yy2943 := &x.ListMeta + yym2944 := z.EncBinary() + _ = yym2944 if false { - } else if z.HasExtensions() && z.EncExt(yy2952) { + } else if z.HasExtensions() && z.EncExt(yy2943) { } else { - z.EncFallback(yy2952) + z.EncFallback(yy2943) } } else { r.EncodeNil() } } else { - if yyq2944[2] { + if yyq2935[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2954 := &x.ListMeta - yym2955 := z.EncBinary() - _ = yym2955 + yy2945 := &x.ListMeta + yym2946 := z.EncBinary() + _ = yym2946 if false { - } else if z.HasExtensions() && z.EncExt(yy2954) { + } else if z.HasExtensions() && z.EncExt(yy2945) { } else { - z.EncFallback(yy2954) + z.EncFallback(yy2945) } } } - if yyr2944 || yy2arr2944 { + if yyr2935 || yy2arr2935 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2957 := z.EncBinary() - _ = yym2957 + yym2948 := z.EncBinary() + _ = yym2948 if false { } else { h.encSliceEndpoints(([]Endpoints)(x.Items), e) @@ -37943,15 +37861,15 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2958 := z.EncBinary() - _ = yym2958 + yym2949 := z.EncBinary() + _ = yym2949 if false { } else { h.encSliceEndpoints(([]Endpoints)(x.Items), e) } } } - if yyr2944 || yy2arr2944 { + if yyr2935 || yy2arr2935 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37964,25 +37882,25 @@ func (x *EndpointsList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2959 := z.DecBinary() - _ = yym2959 + yym2950 := z.DecBinary() + _ = yym2950 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2960 := r.ContainerType() - if yyct2960 == codecSelferValueTypeMap1234 { - yyl2960 := r.ReadMapStart() - if yyl2960 == 0 { + yyct2951 := r.ContainerType() + if yyct2951 == codecSelferValueTypeMap1234 { + yyl2951 := r.ReadMapStart() + if yyl2951 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2960, d) + x.codecDecodeSelfFromMap(yyl2951, d) } - } else if yyct2960 == codecSelferValueTypeArray1234 { - yyl2960 := r.ReadArrayStart() - if yyl2960 == 0 { + } else if yyct2951 == codecSelferValueTypeArray1234 { + yyl2951 := r.ReadArrayStart() + if yyl2951 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2960, d) + x.codecDecodeSelfFromArray(yyl2951, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37994,12 +37912,12 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2961Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2961Slc - var yyhl2961 bool = l >= 0 - for yyj2961 := 0; ; yyj2961++ { - if yyhl2961 { - if yyj2961 >= l { + var yys2952Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2952Slc + var yyhl2952 bool = l >= 0 + for yyj2952 := 0; ; yyj2952++ { + if yyhl2952 { + if yyj2952 >= l { break } } else { @@ -38008,10 +37926,10 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2961Slc = r.DecodeBytes(yys2961Slc, true, true) - yys2961 := string(yys2961Slc) + yys2952Slc = r.DecodeBytes(yys2952Slc, true, true) + yys2952 := string(yys2952Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2961 { + switch yys2952 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -38028,31 +37946,31 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2964 := &x.ListMeta - yym2965 := z.DecBinary() - _ = yym2965 + yyv2955 := &x.ListMeta + yym2956 := z.DecBinary() + _ = yym2956 if false { - } else if z.HasExtensions() && z.DecExt(yyv2964) { + } else if z.HasExtensions() && z.DecExt(yyv2955) { } else { - z.DecFallback(yyv2964, false) + z.DecFallback(yyv2955, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2966 := &x.Items - yym2967 := z.DecBinary() - _ = yym2967 + yyv2957 := &x.Items + yym2958 := z.DecBinary() + _ = yym2958 if false { } else { - h.decSliceEndpoints((*[]Endpoints)(yyv2966), d) + h.decSliceEndpoints((*[]Endpoints)(yyv2957), d) } } default: - z.DecStructFieldNotFound(-1, yys2961) - } // end switch yys2961 - } // end for yyj2961 + z.DecStructFieldNotFound(-1, yys2952) + } // end switch yys2952 + } // end for yyj2952 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38060,16 +37978,16 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2968 int - var yyb2968 bool - var yyhl2968 bool = l >= 0 - yyj2968++ - if yyhl2968 { - yyb2968 = yyj2968 > l + var yyj2959 int + var yyb2959 bool + var yyhl2959 bool = l >= 0 + yyj2959++ + if yyhl2959 { + yyb2959 = yyj2959 > l } else { - yyb2968 = r.CheckBreak() + yyb2959 = r.CheckBreak() } - if yyb2968 { + if yyb2959 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38079,13 +37997,13 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2968++ - if yyhl2968 { - yyb2968 = yyj2968 > l + yyj2959++ + if yyhl2959 { + yyb2959 = yyj2959 > l } else { - yyb2968 = r.CheckBreak() + yyb2959 = r.CheckBreak() } - if yyb2968 { + if yyb2959 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38095,13 +38013,13 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2968++ - if yyhl2968 { - yyb2968 = yyj2968 > l + yyj2959++ + if yyhl2959 { + yyb2959 = yyj2959 > l } else { - yyb2968 = r.CheckBreak() + yyb2959 = r.CheckBreak() } - if yyb2968 { + if yyb2959 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38109,22 +38027,22 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2971 := &x.ListMeta - yym2972 := z.DecBinary() - _ = yym2972 + yyv2962 := &x.ListMeta + yym2963 := z.DecBinary() + _ = yym2963 if false { - } else if z.HasExtensions() && z.DecExt(yyv2971) { + } else if z.HasExtensions() && z.DecExt(yyv2962) { } else { - z.DecFallback(yyv2971, false) + z.DecFallback(yyv2962, false) } } - yyj2968++ - if yyhl2968 { - yyb2968 = yyj2968 > l + yyj2959++ + if yyhl2959 { + yyb2959 = yyj2959 > l } else { - yyb2968 = r.CheckBreak() + yyb2959 = r.CheckBreak() } - if yyb2968 { + if yyb2959 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38132,26 +38050,26 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2973 := &x.Items - yym2974 := z.DecBinary() - _ = yym2974 + yyv2964 := &x.Items + yym2965 := z.DecBinary() + _ = yym2965 if false { } else { - h.decSliceEndpoints((*[]Endpoints)(yyv2973), d) + h.decSliceEndpoints((*[]Endpoints)(yyv2964), d) } } for { - yyj2968++ - if yyhl2968 { - yyb2968 = yyj2968 > l + yyj2959++ + if yyhl2959 { + yyb2959 = yyj2959 > l } else { - yyb2968 = r.CheckBreak() + yyb2959 = r.CheckBreak() } - if yyb2968 { + if yyb2959 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2968-1, "") + z.DecStructFieldNotFound(yyj2959-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38163,38 +38081,38 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2975 := z.EncBinary() - _ = yym2975 + yym2966 := z.EncBinary() + _ = yym2966 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2976 := !z.EncBinary() - yy2arr2976 := z.EncBasicHandle().StructToArray - var yyq2976 [4]bool - _, _, _ = yysep2976, yyq2976, yy2arr2976 - const yyr2976 bool = false - yyq2976[0] = x.PodCIDR != "" - yyq2976[1] = x.ExternalID != "" - yyq2976[2] = x.ProviderID != "" - yyq2976[3] = x.Unschedulable != false - var yynn2976 int - if yyr2976 || yy2arr2976 { + yysep2967 := !z.EncBinary() + yy2arr2967 := z.EncBasicHandle().StructToArray + var yyq2967 [4]bool + _, _, _ = yysep2967, yyq2967, yy2arr2967 + const yyr2967 bool = false + yyq2967[0] = x.PodCIDR != "" + yyq2967[1] = x.ExternalID != "" + yyq2967[2] = x.ProviderID != "" + yyq2967[3] = x.Unschedulable != false + var yynn2967 int + if yyr2967 || yy2arr2967 { r.EncodeArrayStart(4) } else { - yynn2976 = 0 - for _, b := range yyq2976 { + yynn2967 = 0 + for _, b := range yyq2967 { if b { - yynn2976++ + yynn2967++ } } - r.EncodeMapStart(yynn2976) - yynn2976 = 0 + r.EncodeMapStart(yynn2967) + yynn2967 = 0 } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2976[0] { - yym2978 := z.EncBinary() - _ = yym2978 + if yyq2967[0] { + yym2969 := z.EncBinary() + _ = yym2969 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) @@ -38203,23 +38121,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2976[0] { + if yyq2967[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podCIDR")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2979 := z.EncBinary() - _ = yym2979 + yym2970 := z.EncBinary() + _ = yym2970 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) } } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2976[1] { - yym2981 := z.EncBinary() - _ = yym2981 + if yyq2967[1] { + yym2972 := z.EncBinary() + _ = yym2972 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalID)) @@ -38228,23 +38146,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2976[1] { + if yyq2967[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("externalID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2982 := z.EncBinary() - _ = yym2982 + yym2973 := z.EncBinary() + _ = yym2973 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalID)) } } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2976[2] { - yym2984 := z.EncBinary() - _ = yym2984 + if yyq2967[2] { + yym2975 := z.EncBinary() + _ = yym2975 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ProviderID)) @@ -38253,23 +38171,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2976[2] { + if yyq2967[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("providerID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2985 := z.EncBinary() - _ = yym2985 + yym2976 := z.EncBinary() + _ = yym2976 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ProviderID)) } } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2976[3] { - yym2987 := z.EncBinary() - _ = yym2987 + if yyq2967[3] { + yym2978 := z.EncBinary() + _ = yym2978 if false { } else { r.EncodeBool(bool(x.Unschedulable)) @@ -38278,19 +38196,19 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq2976[3] { + if yyq2967[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("unschedulable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2988 := z.EncBinary() - _ = yym2988 + yym2979 := z.EncBinary() + _ = yym2979 if false { } else { r.EncodeBool(bool(x.Unschedulable)) } } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -38303,25 +38221,25 @@ func (x *NodeSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2989 := z.DecBinary() - _ = yym2989 + yym2980 := z.DecBinary() + _ = yym2980 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2990 := r.ContainerType() - if yyct2990 == codecSelferValueTypeMap1234 { - yyl2990 := r.ReadMapStart() - if yyl2990 == 0 { + yyct2981 := r.ContainerType() + if yyct2981 == codecSelferValueTypeMap1234 { + yyl2981 := r.ReadMapStart() + if yyl2981 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2990, d) + x.codecDecodeSelfFromMap(yyl2981, d) } - } else if yyct2990 == codecSelferValueTypeArray1234 { - yyl2990 := r.ReadArrayStart() - if yyl2990 == 0 { + } else if yyct2981 == codecSelferValueTypeArray1234 { + yyl2981 := r.ReadArrayStart() + if yyl2981 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2990, d) + x.codecDecodeSelfFromArray(yyl2981, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38333,12 +38251,12 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2991Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2991Slc - var yyhl2991 bool = l >= 0 - for yyj2991 := 0; ; yyj2991++ { - if yyhl2991 { - if yyj2991 >= l { + var yys2982Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2982Slc + var yyhl2982 bool = l >= 0 + for yyj2982 := 0; ; yyj2982++ { + if yyhl2982 { + if yyj2982 >= l { break } } else { @@ -38347,10 +38265,10 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2991Slc = r.DecodeBytes(yys2991Slc, true, true) - yys2991 := string(yys2991Slc) + yys2982Slc = r.DecodeBytes(yys2982Slc, true, true) + yys2982 := string(yys2982Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2991 { + switch yys2982 { case "podCIDR": if r.TryDecodeAsNil() { x.PodCIDR = "" @@ -38376,9 +38294,9 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Unschedulable = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys2991) - } // end switch yys2991 - } // end for yyj2991 + z.DecStructFieldNotFound(-1, yys2982) + } // end switch yys2982 + } // end for yyj2982 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38386,16 +38304,16 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2996 int - var yyb2996 bool - var yyhl2996 bool = l >= 0 - yyj2996++ - if yyhl2996 { - yyb2996 = yyj2996 > l + var yyj2987 int + var yyb2987 bool + var yyhl2987 bool = l >= 0 + yyj2987++ + if yyhl2987 { + yyb2987 = yyj2987 > l } else { - yyb2996 = r.CheckBreak() + yyb2987 = r.CheckBreak() } - if yyb2996 { + if yyb2987 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38405,13 +38323,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.PodCIDR = string(r.DecodeString()) } - yyj2996++ - if yyhl2996 { - yyb2996 = yyj2996 > l + yyj2987++ + if yyhl2987 { + yyb2987 = yyj2987 > l } else { - yyb2996 = r.CheckBreak() + yyb2987 = r.CheckBreak() } - if yyb2996 { + if yyb2987 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38421,13 +38339,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ExternalID = string(r.DecodeString()) } - yyj2996++ - if yyhl2996 { - yyb2996 = yyj2996 > l + yyj2987++ + if yyhl2987 { + yyb2987 = yyj2987 > l } else { - yyb2996 = r.CheckBreak() + yyb2987 = r.CheckBreak() } - if yyb2996 { + if yyb2987 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38437,13 +38355,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ProviderID = string(r.DecodeString()) } - yyj2996++ - if yyhl2996 { - yyb2996 = yyj2996 > l + yyj2987++ + if yyhl2987 { + yyb2987 = yyj2987 > l } else { - yyb2996 = r.CheckBreak() + yyb2987 = r.CheckBreak() } - if yyb2996 { + if yyb2987 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38454,17 +38372,17 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Unschedulable = bool(r.DecodeBool()) } for { - yyj2996++ - if yyhl2996 { - yyb2996 = yyj2996 > l + yyj2987++ + if yyhl2987 { + yyb2987 = yyj2987 > l } else { - yyb2996 = r.CheckBreak() + yyb2987 = r.CheckBreak() } - if yyb2996 { + if yyb2987 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2996-1, "") + z.DecStructFieldNotFound(yyj2987-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38476,33 +38394,33 @@ func (x *DaemonEndpoint) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3001 := z.EncBinary() - _ = yym3001 + yym2992 := z.EncBinary() + _ = yym2992 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3002 := !z.EncBinary() - yy2arr3002 := z.EncBasicHandle().StructToArray - var yyq3002 [1]bool - _, _, _ = yysep3002, yyq3002, yy2arr3002 - const yyr3002 bool = false - var yynn3002 int - if yyr3002 || yy2arr3002 { + yysep2993 := !z.EncBinary() + yy2arr2993 := z.EncBasicHandle().StructToArray + var yyq2993 [1]bool + _, _, _ = yysep2993, yyq2993, yy2arr2993 + const yyr2993 bool = false + var yynn2993 int + if yyr2993 || yy2arr2993 { r.EncodeArrayStart(1) } else { - yynn3002 = 1 - for _, b := range yyq3002 { + yynn2993 = 1 + for _, b := range yyq2993 { if b { - yynn3002++ + yynn2993++ } } - r.EncodeMapStart(yynn3002) - yynn3002 = 0 + r.EncodeMapStart(yynn2993) + yynn2993 = 0 } - if yyr3002 || yy2arr3002 { + if yyr2993 || yy2arr2993 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3004 := z.EncBinary() - _ = yym3004 + yym2995 := z.EncBinary() + _ = yym2995 if false { } else { r.EncodeInt(int64(x.Port)) @@ -38511,14 +38429,14 @@ func (x *DaemonEndpoint) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3005 := z.EncBinary() - _ = yym3005 + yym2996 := z.EncBinary() + _ = yym2996 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr3002 || yy2arr3002 { + if yyr2993 || yy2arr2993 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -38531,25 +38449,25 @@ func (x *DaemonEndpoint) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3006 := z.DecBinary() - _ = yym3006 + yym2997 := z.DecBinary() + _ = yym2997 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3007 := r.ContainerType() - if yyct3007 == codecSelferValueTypeMap1234 { - yyl3007 := r.ReadMapStart() - if yyl3007 == 0 { + yyct2998 := r.ContainerType() + if yyct2998 == codecSelferValueTypeMap1234 { + yyl2998 := r.ReadMapStart() + if yyl2998 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3007, d) + x.codecDecodeSelfFromMap(yyl2998, d) } - } else if yyct3007 == codecSelferValueTypeArray1234 { - yyl3007 := r.ReadArrayStart() - if yyl3007 == 0 { + } else if yyct2998 == codecSelferValueTypeArray1234 { + yyl2998 := r.ReadArrayStart() + if yyl2998 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3007, d) + x.codecDecodeSelfFromArray(yyl2998, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38561,12 +38479,12 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3008Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3008Slc - var yyhl3008 bool = l >= 0 - for yyj3008 := 0; ; yyj3008++ { - if yyhl3008 { - if yyj3008 >= l { + var yys2999Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2999Slc + var yyhl2999 bool = l >= 0 + for yyj2999 := 0; ; yyj2999++ { + if yyhl2999 { + if yyj2999 >= l { break } } else { @@ -38575,10 +38493,10 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3008Slc = r.DecodeBytes(yys3008Slc, true, true) - yys3008 := string(yys3008Slc) + yys2999Slc = r.DecodeBytes(yys2999Slc, true, true) + yys2999 := string(yys2999Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3008 { + switch yys2999 { case "Port": if r.TryDecodeAsNil() { x.Port = 0 @@ -38586,9 +38504,9 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Port = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys3008) - } // end switch yys3008 - } // end for yyj3008 + z.DecStructFieldNotFound(-1, yys2999) + } // end switch yys2999 + } // end for yyj2999 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38596,16 +38514,16 @@ func (x *DaemonEndpoint) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3010 int - var yyb3010 bool - var yyhl3010 bool = l >= 0 - yyj3010++ - if yyhl3010 { - yyb3010 = yyj3010 > l + var yyj3001 int + var yyb3001 bool + var yyhl3001 bool = l >= 0 + yyj3001++ + if yyhl3001 { + yyb3001 = yyj3001 > l } else { - yyb3010 = r.CheckBreak() + yyb3001 = r.CheckBreak() } - if yyb3010 { + if yyb3001 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38616,17 +38534,17 @@ func (x *DaemonEndpoint) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Port = int32(r.DecodeInt(32)) } for { - yyj3010++ - if yyhl3010 { - yyb3010 = yyj3010 > l + yyj3001++ + if yyhl3001 { + yyb3001 = yyj3001 > l } else { - yyb3010 = r.CheckBreak() + yyb3001 = r.CheckBreak() } - if yyb3010 { + if yyb3001 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3010-1, "") + z.DecStructFieldNotFound(yyj3001-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38638,48 +38556,48 @@ func (x *NodeDaemonEndpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3012 := z.EncBinary() - _ = yym3012 + yym3003 := z.EncBinary() + _ = yym3003 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3013 := !z.EncBinary() - yy2arr3013 := z.EncBasicHandle().StructToArray - var yyq3013 [1]bool - _, _, _ = yysep3013, yyq3013, yy2arr3013 - const yyr3013 bool = false - yyq3013[0] = true - var yynn3013 int - if yyr3013 || yy2arr3013 { + yysep3004 := !z.EncBinary() + yy2arr3004 := z.EncBasicHandle().StructToArray + var yyq3004 [1]bool + _, _, _ = yysep3004, yyq3004, yy2arr3004 + const yyr3004 bool = false + yyq3004[0] = true + var yynn3004 int + if yyr3004 || yy2arr3004 { r.EncodeArrayStart(1) } else { - yynn3013 = 0 - for _, b := range yyq3013 { + yynn3004 = 0 + for _, b := range yyq3004 { if b { - yynn3013++ + yynn3004++ } } - r.EncodeMapStart(yynn3013) - yynn3013 = 0 + r.EncodeMapStart(yynn3004) + yynn3004 = 0 } - if yyr3013 || yy2arr3013 { + if yyr3004 || yy2arr3004 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3013[0] { - yy3015 := &x.KubeletEndpoint - yy3015.CodecEncodeSelf(e) + if yyq3004[0] { + yy3006 := &x.KubeletEndpoint + yy3006.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3013[0] { + if yyq3004[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeletEndpoint")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3016 := &x.KubeletEndpoint - yy3016.CodecEncodeSelf(e) + yy3007 := &x.KubeletEndpoint + yy3007.CodecEncodeSelf(e) } } - if yyr3013 || yy2arr3013 { + if yyr3004 || yy2arr3004 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -38692,25 +38610,25 @@ func (x *NodeDaemonEndpoints) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3017 := z.DecBinary() - _ = yym3017 + yym3008 := z.DecBinary() + _ = yym3008 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3018 := r.ContainerType() - if yyct3018 == codecSelferValueTypeMap1234 { - yyl3018 := r.ReadMapStart() - if yyl3018 == 0 { + yyct3009 := r.ContainerType() + if yyct3009 == codecSelferValueTypeMap1234 { + yyl3009 := r.ReadMapStart() + if yyl3009 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3018, d) + x.codecDecodeSelfFromMap(yyl3009, d) } - } else if yyct3018 == codecSelferValueTypeArray1234 { - yyl3018 := r.ReadArrayStart() - if yyl3018 == 0 { + } else if yyct3009 == codecSelferValueTypeArray1234 { + yyl3009 := r.ReadArrayStart() + if yyl3009 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3018, d) + x.codecDecodeSelfFromArray(yyl3009, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38722,12 +38640,12 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3019Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3019Slc - var yyhl3019 bool = l >= 0 - for yyj3019 := 0; ; yyj3019++ { - if yyhl3019 { - if yyj3019 >= l { + var yys3010Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3010Slc + var yyhl3010 bool = l >= 0 + for yyj3010 := 0; ; yyj3010++ { + if yyhl3010 { + if yyj3010 >= l { break } } else { @@ -38736,21 +38654,21 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3019Slc = r.DecodeBytes(yys3019Slc, true, true) - yys3019 := string(yys3019Slc) + yys3010Slc = r.DecodeBytes(yys3010Slc, true, true) + yys3010 := string(yys3010Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3019 { + switch yys3010 { case "kubeletEndpoint": if r.TryDecodeAsNil() { x.KubeletEndpoint = DaemonEndpoint{} } else { - yyv3020 := &x.KubeletEndpoint - yyv3020.CodecDecodeSelf(d) + yyv3011 := &x.KubeletEndpoint + yyv3011.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3019) - } // end switch yys3019 - } // end for yyj3019 + z.DecStructFieldNotFound(-1, yys3010) + } // end switch yys3010 + } // end for yyj3010 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38758,16 +38676,16 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3021 int - var yyb3021 bool - var yyhl3021 bool = l >= 0 - yyj3021++ - if yyhl3021 { - yyb3021 = yyj3021 > l + var yyj3012 int + var yyb3012 bool + var yyhl3012 bool = l >= 0 + yyj3012++ + if yyhl3012 { + yyb3012 = yyj3012 > l } else { - yyb3021 = r.CheckBreak() + yyb3012 = r.CheckBreak() } - if yyb3021 { + if yyb3012 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38775,21 +38693,21 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.KubeletEndpoint = DaemonEndpoint{} } else { - yyv3022 := &x.KubeletEndpoint - yyv3022.CodecDecodeSelf(d) + yyv3013 := &x.KubeletEndpoint + yyv3013.CodecDecodeSelf(d) } for { - yyj3021++ - if yyhl3021 { - yyb3021 = yyj3021 > l + yyj3012++ + if yyhl3012 { + yyb3012 = yyj3012 > l } else { - yyb3021 = r.CheckBreak() + yyb3012 = r.CheckBreak() } - if yyb3021 { + if yyb3012 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3021-1, "") + z.DecStructFieldNotFound(yyj3012-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38801,33 +38719,33 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3023 := z.EncBinary() - _ = yym3023 + yym3014 := z.EncBinary() + _ = yym3014 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3024 := !z.EncBinary() - yy2arr3024 := z.EncBasicHandle().StructToArray - var yyq3024 [10]bool - _, _, _ = yysep3024, yyq3024, yy2arr3024 - const yyr3024 bool = false - var yynn3024 int - if yyr3024 || yy2arr3024 { + yysep3015 := !z.EncBinary() + yy2arr3015 := z.EncBasicHandle().StructToArray + var yyq3015 [10]bool + _, _, _ = yysep3015, yyq3015, yy2arr3015 + const yyr3015 bool = false + var yynn3015 int + if yyr3015 || yy2arr3015 { r.EncodeArrayStart(10) } else { - yynn3024 = 10 - for _, b := range yyq3024 { + yynn3015 = 10 + for _, b := range yyq3015 { if b { - yynn3024++ + yynn3015++ } } - r.EncodeMapStart(yynn3024) - yynn3024 = 0 + r.EncodeMapStart(yynn3015) + yynn3015 = 0 } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3026 := z.EncBinary() - _ = yym3026 + yym3017 := z.EncBinary() + _ = yym3017 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.MachineID)) @@ -38836,17 +38754,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("machineID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3027 := z.EncBinary() - _ = yym3027 + yym3018 := z.EncBinary() + _ = yym3018 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.MachineID)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3029 := z.EncBinary() - _ = yym3029 + yym3020 := z.EncBinary() + _ = yym3020 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SystemUUID)) @@ -38855,17 +38773,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("systemUUID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3030 := z.EncBinary() - _ = yym3030 + yym3021 := z.EncBinary() + _ = yym3021 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SystemUUID)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3032 := z.EncBinary() - _ = yym3032 + yym3023 := z.EncBinary() + _ = yym3023 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.BootID)) @@ -38874,17 +38792,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("bootID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3033 := z.EncBinary() - _ = yym3033 + yym3024 := z.EncBinary() + _ = yym3024 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.BootID)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3035 := z.EncBinary() - _ = yym3035 + yym3026 := z.EncBinary() + _ = yym3026 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KernelVersion)) @@ -38893,17 +38811,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kernelVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3036 := z.EncBinary() - _ = yym3036 + yym3027 := z.EncBinary() + _ = yym3027 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KernelVersion)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3038 := z.EncBinary() - _ = yym3038 + yym3029 := z.EncBinary() + _ = yym3029 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OSImage)) @@ -38912,17 +38830,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("osImage")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3039 := z.EncBinary() - _ = yym3039 + yym3030 := z.EncBinary() + _ = yym3030 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OSImage)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3041 := z.EncBinary() - _ = yym3041 + yym3032 := z.EncBinary() + _ = yym3032 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntimeVersion)) @@ -38931,17 +38849,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("containerRuntimeVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3042 := z.EncBinary() - _ = yym3042 + yym3033 := z.EncBinary() + _ = yym3033 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntimeVersion)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3044 := z.EncBinary() - _ = yym3044 + yym3035 := z.EncBinary() + _ = yym3035 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeletVersion)) @@ -38950,17 +38868,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeletVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3045 := z.EncBinary() - _ = yym3045 + yym3036 := z.EncBinary() + _ = yym3036 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeletVersion)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3047 := z.EncBinary() - _ = yym3047 + yym3038 := z.EncBinary() + _ = yym3038 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeProxyVersion)) @@ -38969,17 +38887,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeProxyVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3048 := z.EncBinary() - _ = yym3048 + yym3039 := z.EncBinary() + _ = yym3039 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeProxyVersion)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3050 := z.EncBinary() - _ = yym3050 + yym3041 := z.EncBinary() + _ = yym3041 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OperatingSystem)) @@ -38988,17 +38906,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("operatingSystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3051 := z.EncBinary() - _ = yym3051 + yym3042 := z.EncBinary() + _ = yym3042 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OperatingSystem)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3053 := z.EncBinary() - _ = yym3053 + yym3044 := z.EncBinary() + _ = yym3044 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Architecture)) @@ -39007,14 +38925,14 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("architecture")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3054 := z.EncBinary() - _ = yym3054 + yym3045 := z.EncBinary() + _ = yym3045 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Architecture)) } } - if yyr3024 || yy2arr3024 { + if yyr3015 || yy2arr3015 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -39027,25 +38945,25 @@ func (x *NodeSystemInfo) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3055 := z.DecBinary() - _ = yym3055 + yym3046 := z.DecBinary() + _ = yym3046 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3056 := r.ContainerType() - if yyct3056 == codecSelferValueTypeMap1234 { - yyl3056 := r.ReadMapStart() - if yyl3056 == 0 { + yyct3047 := r.ContainerType() + if yyct3047 == codecSelferValueTypeMap1234 { + yyl3047 := r.ReadMapStart() + if yyl3047 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3056, d) + x.codecDecodeSelfFromMap(yyl3047, d) } - } else if yyct3056 == codecSelferValueTypeArray1234 { - yyl3056 := r.ReadArrayStart() - if yyl3056 == 0 { + } else if yyct3047 == codecSelferValueTypeArray1234 { + yyl3047 := r.ReadArrayStart() + if yyl3047 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3056, d) + x.codecDecodeSelfFromArray(yyl3047, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -39057,12 +38975,12 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3057Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3057Slc - var yyhl3057 bool = l >= 0 - for yyj3057 := 0; ; yyj3057++ { - if yyhl3057 { - if yyj3057 >= l { + var yys3048Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3048Slc + var yyhl3048 bool = l >= 0 + for yyj3048 := 0; ; yyj3048++ { + if yyhl3048 { + if yyj3048 >= l { break } } else { @@ -39071,10 +38989,10 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3057Slc = r.DecodeBytes(yys3057Slc, true, true) - yys3057 := string(yys3057Slc) + yys3048Slc = r.DecodeBytes(yys3048Slc, true, true) + yys3048 := string(yys3048Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3057 { + switch yys3048 { case "machineID": if r.TryDecodeAsNil() { x.MachineID = "" @@ -39136,9 +39054,9 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Architecture = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3057) - } // end switch yys3057 - } // end for yyj3057 + z.DecStructFieldNotFound(-1, yys3048) + } // end switch yys3048 + } // end for yyj3048 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -39146,16 +39064,16 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3068 int - var yyb3068 bool - var yyhl3068 bool = l >= 0 - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + var yyj3059 int + var yyb3059 bool + var yyhl3059 bool = l >= 0 + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39165,13 +39083,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.MachineID = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39181,13 +39099,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.SystemUUID = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39197,13 +39115,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.BootID = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39213,13 +39131,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KernelVersion = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39229,13 +39147,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.OSImage = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39245,13 +39163,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ContainerRuntimeVersion = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39261,13 +39179,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KubeletVersion = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39277,13 +39195,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KubeProxyVersion = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39293,13 +39211,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.OperatingSystem = string(r.DecodeString()) } - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39310,17 +39228,17 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Architecture = string(r.DecodeString()) } for { - yyj3068++ - if yyhl3068 { - yyb3068 = yyj3068 > l + yyj3059++ + if yyhl3059 { + yyb3059 = yyj3059 > l } else { - yyb3068 = r.CheckBreak() + yyb3059 = r.CheckBreak() } - if yyb3068 { + if yyb3059 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3068-1, "") + z.DecStructFieldNotFound(yyj3059-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -39332,42 +39250,42 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3079 := z.EncBinary() - _ = yym3079 + yym3070 := z.EncBinary() + _ = yym3070 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3080 := !z.EncBinary() - yy2arr3080 := z.EncBasicHandle().StructToArray - var yyq3080 [10]bool - _, _, _ = yysep3080, yyq3080, yy2arr3080 - const yyr3080 bool = false - yyq3080[0] = len(x.Capacity) != 0 - yyq3080[1] = len(x.Allocatable) != 0 - yyq3080[2] = x.Phase != "" - yyq3080[3] = len(x.Conditions) != 0 - yyq3080[4] = len(x.Addresses) != 0 - yyq3080[5] = true - yyq3080[6] = true - yyq3080[7] = len(x.Images) != 0 - yyq3080[8] = len(x.VolumesInUse) != 0 - yyq3080[9] = len(x.VolumesAttached) != 0 - var yynn3080 int - if yyr3080 || yy2arr3080 { + yysep3071 := !z.EncBinary() + yy2arr3071 := z.EncBasicHandle().StructToArray + var yyq3071 [10]bool + _, _, _ = yysep3071, yyq3071, yy2arr3071 + const yyr3071 bool = false + yyq3071[0] = len(x.Capacity) != 0 + yyq3071[1] = len(x.Allocatable) != 0 + yyq3071[2] = x.Phase != "" + yyq3071[3] = len(x.Conditions) != 0 + yyq3071[4] = len(x.Addresses) != 0 + yyq3071[5] = true + yyq3071[6] = true + yyq3071[7] = len(x.Images) != 0 + yyq3071[8] = len(x.VolumesInUse) != 0 + yyq3071[9] = len(x.VolumesAttached) != 0 + var yynn3071 int + if yyr3071 || yy2arr3071 { r.EncodeArrayStart(10) } else { - yynn3080 = 0 - for _, b := range yyq3080 { + yynn3071 = 0 + for _, b := range yyq3071 { if b { - yynn3080++ + yynn3071++ } } - r.EncodeMapStart(yynn3080) - yynn3080 = 0 + r.EncodeMapStart(yynn3071) + yynn3071 = 0 } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[0] { + if yyq3071[0] { if x.Capacity == nil { r.EncodeNil() } else { @@ -39377,7 +39295,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[0] { + if yyq3071[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("capacity")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -39388,9 +39306,9 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[1] { + if yyq3071[1] { if x.Allocatable == nil { r.EncodeNil() } else { @@ -39400,7 +39318,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[1] { + if yyq3071[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("allocatable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -39411,29 +39329,29 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[2] { + if yyq3071[2] { x.Phase.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3080[2] { + if yyq3071[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("phase")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Phase.CodecEncodeSelf(e) } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[3] { + if yyq3071[3] { if x.Conditions == nil { r.EncodeNil() } else { - yym3085 := z.EncBinary() - _ = yym3085 + yym3076 := z.EncBinary() + _ = yym3076 if false { } else { h.encSliceNodeCondition(([]NodeCondition)(x.Conditions), e) @@ -39443,15 +39361,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[3] { + if yyq3071[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym3086 := z.EncBinary() - _ = yym3086 + yym3077 := z.EncBinary() + _ = yym3077 if false { } else { h.encSliceNodeCondition(([]NodeCondition)(x.Conditions), e) @@ -39459,14 +39377,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[4] { + if yyq3071[4] { if x.Addresses == nil { r.EncodeNil() } else { - yym3088 := z.EncBinary() - _ = yym3088 + yym3079 := z.EncBinary() + _ = yym3079 if false { } else { h.encSliceNodeAddress(([]NodeAddress)(x.Addresses), e) @@ -39476,15 +39394,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[4] { + if yyq3071[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("addresses")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Addresses == nil { r.EncodeNil() } else { - yym3089 := z.EncBinary() - _ = yym3089 + yym3080 := z.EncBinary() + _ = yym3080 if false { } else { h.encSliceNodeAddress(([]NodeAddress)(x.Addresses), e) @@ -39492,48 +39410,48 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[5] { - yy3091 := &x.DaemonEndpoints - yy3091.CodecEncodeSelf(e) + if yyq3071[5] { + yy3082 := &x.DaemonEndpoints + yy3082.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3080[5] { + if yyq3071[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("daemonEndpoints")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3092 := &x.DaemonEndpoints - yy3092.CodecEncodeSelf(e) + yy3083 := &x.DaemonEndpoints + yy3083.CodecEncodeSelf(e) } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[6] { - yy3094 := &x.NodeInfo - yy3094.CodecEncodeSelf(e) + if yyq3071[6] { + yy3085 := &x.NodeInfo + yy3085.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3080[6] { + if yyq3071[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodeInfo")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3095 := &x.NodeInfo - yy3095.CodecEncodeSelf(e) + yy3086 := &x.NodeInfo + yy3086.CodecEncodeSelf(e) } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[7] { + if yyq3071[7] { if x.Images == nil { r.EncodeNil() } else { - yym3097 := z.EncBinary() - _ = yym3097 + yym3088 := z.EncBinary() + _ = yym3088 if false { } else { h.encSliceContainerImage(([]ContainerImage)(x.Images), e) @@ -39543,15 +39461,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[7] { + if yyq3071[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("images")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Images == nil { r.EncodeNil() } else { - yym3098 := z.EncBinary() - _ = yym3098 + yym3089 := z.EncBinary() + _ = yym3089 if false { } else { h.encSliceContainerImage(([]ContainerImage)(x.Images), e) @@ -39559,14 +39477,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[8] { + if yyq3071[8] { if x.VolumesInUse == nil { r.EncodeNil() } else { - yym3100 := z.EncBinary() - _ = yym3100 + yym3091 := z.EncBinary() + _ = yym3091 if false { } else { h.encSliceUniqueVolumeName(([]UniqueVolumeName)(x.VolumesInUse), e) @@ -39576,15 +39494,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[8] { + if yyq3071[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumesInUse")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.VolumesInUse == nil { r.EncodeNil() } else { - yym3101 := z.EncBinary() - _ = yym3101 + yym3092 := z.EncBinary() + _ = yym3092 if false { } else { h.encSliceUniqueVolumeName(([]UniqueVolumeName)(x.VolumesInUse), e) @@ -39592,14 +39510,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3080[9] { + if yyq3071[9] { if x.VolumesAttached == nil { r.EncodeNil() } else { - yym3103 := z.EncBinary() - _ = yym3103 + yym3094 := z.EncBinary() + _ = yym3094 if false { } else { h.encSliceAttachedVolume(([]AttachedVolume)(x.VolumesAttached), e) @@ -39609,15 +39527,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3080[9] { + if yyq3071[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumesAttached")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.VolumesAttached == nil { r.EncodeNil() } else { - yym3104 := z.EncBinary() - _ = yym3104 + yym3095 := z.EncBinary() + _ = yym3095 if false { } else { h.encSliceAttachedVolume(([]AttachedVolume)(x.VolumesAttached), e) @@ -39625,7 +39543,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3080 || yy2arr3080 { + if yyr3071 || yy2arr3071 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -39638,25 +39556,25 @@ func (x *NodeStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3105 := z.DecBinary() - _ = yym3105 + yym3096 := z.DecBinary() + _ = yym3096 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3106 := r.ContainerType() - if yyct3106 == codecSelferValueTypeMap1234 { - yyl3106 := r.ReadMapStart() - if yyl3106 == 0 { + yyct3097 := r.ContainerType() + if yyct3097 == codecSelferValueTypeMap1234 { + yyl3097 := r.ReadMapStart() + if yyl3097 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3106, d) + x.codecDecodeSelfFromMap(yyl3097, d) } - } else if yyct3106 == codecSelferValueTypeArray1234 { - yyl3106 := r.ReadArrayStart() - if yyl3106 == 0 { + } else if yyct3097 == codecSelferValueTypeArray1234 { + yyl3097 := r.ReadArrayStart() + if yyl3097 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3106, d) + x.codecDecodeSelfFromArray(yyl3097, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -39668,12 +39586,12 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3107Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3107Slc - var yyhl3107 bool = l >= 0 - for yyj3107 := 0; ; yyj3107++ { - if yyhl3107 { - if yyj3107 >= l { + var yys3098Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3098Slc + var yyhl3098 bool = l >= 0 + for yyj3098 := 0; ; yyj3098++ { + if yyhl3098 { + if yyj3098 >= l { break } } else { @@ -39682,23 +39600,23 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3107Slc = r.DecodeBytes(yys3107Slc, true, true) - yys3107 := string(yys3107Slc) + yys3098Slc = r.DecodeBytes(yys3098Slc, true, true) + yys3098 := string(yys3098Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3107 { + switch yys3098 { case "capacity": if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3108 := &x.Capacity - yyv3108.CodecDecodeSelf(d) + yyv3099 := &x.Capacity + yyv3099.CodecDecodeSelf(d) } case "allocatable": if r.TryDecodeAsNil() { x.Allocatable = nil } else { - yyv3109 := &x.Allocatable - yyv3109.CodecDecodeSelf(d) + yyv3100 := &x.Allocatable + yyv3100.CodecDecodeSelf(d) } case "phase": if r.TryDecodeAsNil() { @@ -39710,80 +39628,80 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv3111 := &x.Conditions - yym3112 := z.DecBinary() - _ = yym3112 + yyv3102 := &x.Conditions + yym3103 := z.DecBinary() + _ = yym3103 if false { } else { - h.decSliceNodeCondition((*[]NodeCondition)(yyv3111), d) + h.decSliceNodeCondition((*[]NodeCondition)(yyv3102), d) } } case "addresses": if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv3113 := &x.Addresses - yym3114 := z.DecBinary() - _ = yym3114 + yyv3104 := &x.Addresses + yym3105 := z.DecBinary() + _ = yym3105 if false { } else { - h.decSliceNodeAddress((*[]NodeAddress)(yyv3113), d) + h.decSliceNodeAddress((*[]NodeAddress)(yyv3104), d) } } case "daemonEndpoints": if r.TryDecodeAsNil() { x.DaemonEndpoints = NodeDaemonEndpoints{} } else { - yyv3115 := &x.DaemonEndpoints - yyv3115.CodecDecodeSelf(d) + yyv3106 := &x.DaemonEndpoints + yyv3106.CodecDecodeSelf(d) } case "nodeInfo": if r.TryDecodeAsNil() { x.NodeInfo = NodeSystemInfo{} } else { - yyv3116 := &x.NodeInfo - yyv3116.CodecDecodeSelf(d) + yyv3107 := &x.NodeInfo + yyv3107.CodecDecodeSelf(d) } case "images": if r.TryDecodeAsNil() { x.Images = nil } else { - yyv3117 := &x.Images - yym3118 := z.DecBinary() - _ = yym3118 + yyv3108 := &x.Images + yym3109 := z.DecBinary() + _ = yym3109 if false { } else { - h.decSliceContainerImage((*[]ContainerImage)(yyv3117), d) + h.decSliceContainerImage((*[]ContainerImage)(yyv3108), d) } } case "volumesInUse": if r.TryDecodeAsNil() { x.VolumesInUse = nil } else { - yyv3119 := &x.VolumesInUse - yym3120 := z.DecBinary() - _ = yym3120 + yyv3110 := &x.VolumesInUse + yym3111 := z.DecBinary() + _ = yym3111 if false { } else { - h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3119), d) + h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3110), d) } } case "volumesAttached": if r.TryDecodeAsNil() { x.VolumesAttached = nil } else { - yyv3121 := &x.VolumesAttached - yym3122 := z.DecBinary() - _ = yym3122 + yyv3112 := &x.VolumesAttached + yym3113 := z.DecBinary() + _ = yym3113 if false { } else { - h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3121), d) + h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3112), d) } } default: - z.DecStructFieldNotFound(-1, yys3107) - } // end switch yys3107 - } // end for yyj3107 + z.DecStructFieldNotFound(-1, yys3098) + } // end switch yys3098 + } // end for yyj3098 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -39791,16 +39709,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3123 int - var yyb3123 bool - var yyhl3123 bool = l >= 0 - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + var yyj3114 int + var yyb3114 bool + var yyhl3114 bool = l >= 0 + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39808,16 +39726,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3124 := &x.Capacity - yyv3124.CodecDecodeSelf(d) + yyv3115 := &x.Capacity + yyv3115.CodecDecodeSelf(d) } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39825,16 +39743,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Allocatable = nil } else { - yyv3125 := &x.Allocatable - yyv3125.CodecDecodeSelf(d) + yyv3116 := &x.Allocatable + yyv3116.CodecDecodeSelf(d) } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39844,13 +39762,13 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Phase = NodePhase(r.DecodeString()) } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39858,21 +39776,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv3127 := &x.Conditions - yym3128 := z.DecBinary() - _ = yym3128 + yyv3118 := &x.Conditions + yym3119 := z.DecBinary() + _ = yym3119 if false { } else { - h.decSliceNodeCondition((*[]NodeCondition)(yyv3127), d) + h.decSliceNodeCondition((*[]NodeCondition)(yyv3118), d) } } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39880,21 +39798,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv3129 := &x.Addresses - yym3130 := z.DecBinary() - _ = yym3130 + yyv3120 := &x.Addresses + yym3121 := z.DecBinary() + _ = yym3121 if false { } else { - h.decSliceNodeAddress((*[]NodeAddress)(yyv3129), d) + h.decSliceNodeAddress((*[]NodeAddress)(yyv3120), d) } } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39902,16 +39820,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.DaemonEndpoints = NodeDaemonEndpoints{} } else { - yyv3131 := &x.DaemonEndpoints - yyv3131.CodecDecodeSelf(d) + yyv3122 := &x.DaemonEndpoints + yyv3122.CodecDecodeSelf(d) } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39919,16 +39837,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.NodeInfo = NodeSystemInfo{} } else { - yyv3132 := &x.NodeInfo - yyv3132.CodecDecodeSelf(d) + yyv3123 := &x.NodeInfo + yyv3123.CodecDecodeSelf(d) } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39936,21 +39854,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Images = nil } else { - yyv3133 := &x.Images - yym3134 := z.DecBinary() - _ = yym3134 + yyv3124 := &x.Images + yym3125 := z.DecBinary() + _ = yym3125 if false { } else { - h.decSliceContainerImage((*[]ContainerImage)(yyv3133), d) + h.decSliceContainerImage((*[]ContainerImage)(yyv3124), d) } } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39958,21 +39876,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.VolumesInUse = nil } else { - yyv3135 := &x.VolumesInUse - yym3136 := z.DecBinary() - _ = yym3136 + yyv3126 := &x.VolumesInUse + yym3127 := z.DecBinary() + _ = yym3127 if false { } else { - h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3135), d) + h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3126), d) } } - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39980,26 +39898,26 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.VolumesAttached = nil } else { - yyv3137 := &x.VolumesAttached - yym3138 := z.DecBinary() - _ = yym3138 + yyv3128 := &x.VolumesAttached + yym3129 := z.DecBinary() + _ = yym3129 if false { } else { - h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3137), d) + h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3128), d) } } for { - yyj3123++ - if yyhl3123 { - yyb3123 = yyj3123 > l + yyj3114++ + if yyhl3114 { + yyb3114 = yyj3114 > l } else { - yyb3123 = r.CheckBreak() + yyb3114 = r.CheckBreak() } - if yyb3123 { + if yyb3114 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3123-1, "") + z.DecStructFieldNotFound(yyj3114-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40008,8 +39926,8 @@ func (x UniqueVolumeName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3139 := z.EncBinary() - _ = yym3139 + yym3130 := z.EncBinary() + _ = yym3130 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -40021,8 +39939,8 @@ func (x *UniqueVolumeName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3140 := z.DecBinary() - _ = yym3140 + yym3131 := z.DecBinary() + _ = yym3131 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -40037,30 +39955,30 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3141 := z.EncBinary() - _ = yym3141 + yym3132 := z.EncBinary() + _ = yym3132 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3142 := !z.EncBinary() - yy2arr3142 := z.EncBasicHandle().StructToArray - var yyq3142 [2]bool - _, _, _ = yysep3142, yyq3142, yy2arr3142 - const yyr3142 bool = false - var yynn3142 int - if yyr3142 || yy2arr3142 { + yysep3133 := !z.EncBinary() + yy2arr3133 := z.EncBasicHandle().StructToArray + var yyq3133 [2]bool + _, _, _ = yysep3133, yyq3133, yy2arr3133 + const yyr3133 bool = false + var yynn3133 int + if yyr3133 || yy2arr3133 { r.EncodeArrayStart(2) } else { - yynn3142 = 2 - for _, b := range yyq3142 { + yynn3133 = 2 + for _, b := range yyq3133 { if b { - yynn3142++ + yynn3133++ } } - r.EncodeMapStart(yynn3142) - yynn3142 = 0 + r.EncodeMapStart(yynn3133) + yynn3133 = 0 } - if yyr3142 || yy2arr3142 { + if yyr3133 || yy2arr3133 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Name.CodecEncodeSelf(e) } else { @@ -40069,10 +39987,10 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Name.CodecEncodeSelf(e) } - if yyr3142 || yy2arr3142 { + if yyr3133 || yy2arr3133 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3145 := z.EncBinary() - _ = yym3145 + yym3136 := z.EncBinary() + _ = yym3136 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.DevicePath)) @@ -40081,14 +39999,14 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("devicePath")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3146 := z.EncBinary() - _ = yym3146 + yym3137 := z.EncBinary() + _ = yym3137 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.DevicePath)) } } - if yyr3142 || yy2arr3142 { + if yyr3133 || yy2arr3133 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40101,25 +40019,25 @@ func (x *AttachedVolume) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3147 := z.DecBinary() - _ = yym3147 + yym3138 := z.DecBinary() + _ = yym3138 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3148 := r.ContainerType() - if yyct3148 == codecSelferValueTypeMap1234 { - yyl3148 := r.ReadMapStart() - if yyl3148 == 0 { + yyct3139 := r.ContainerType() + if yyct3139 == codecSelferValueTypeMap1234 { + yyl3139 := r.ReadMapStart() + if yyl3139 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3148, d) + x.codecDecodeSelfFromMap(yyl3139, d) } - } else if yyct3148 == codecSelferValueTypeArray1234 { - yyl3148 := r.ReadArrayStart() - if yyl3148 == 0 { + } else if yyct3139 == codecSelferValueTypeArray1234 { + yyl3139 := r.ReadArrayStart() + if yyl3139 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3148, d) + x.codecDecodeSelfFromArray(yyl3139, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40131,12 +40049,12 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3149Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3149Slc - var yyhl3149 bool = l >= 0 - for yyj3149 := 0; ; yyj3149++ { - if yyhl3149 { - if yyj3149 >= l { + var yys3140Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3140Slc + var yyhl3140 bool = l >= 0 + for yyj3140 := 0; ; yyj3140++ { + if yyhl3140 { + if yyj3140 >= l { break } } else { @@ -40145,10 +40063,10 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3149Slc = r.DecodeBytes(yys3149Slc, true, true) - yys3149 := string(yys3149Slc) + yys3140Slc = r.DecodeBytes(yys3140Slc, true, true) + yys3140 := string(yys3140Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3149 { + switch yys3140 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -40162,9 +40080,9 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.DevicePath = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3149) - } // end switch yys3149 - } // end for yyj3149 + z.DecStructFieldNotFound(-1, yys3140) + } // end switch yys3140 + } // end for yyj3140 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40172,16 +40090,16 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3152 int - var yyb3152 bool - var yyhl3152 bool = l >= 0 - yyj3152++ - if yyhl3152 { - yyb3152 = yyj3152 > l + var yyj3143 int + var yyb3143 bool + var yyhl3143 bool = l >= 0 + yyj3143++ + if yyhl3143 { + yyb3143 = yyj3143 > l } else { - yyb3152 = r.CheckBreak() + yyb3143 = r.CheckBreak() } - if yyb3152 { + if yyb3143 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40191,13 +40109,13 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = UniqueVolumeName(r.DecodeString()) } - yyj3152++ - if yyhl3152 { - yyb3152 = yyj3152 > l + yyj3143++ + if yyhl3143 { + yyb3143 = yyj3143 > l } else { - yyb3152 = r.CheckBreak() + yyb3143 = r.CheckBreak() } - if yyb3152 { + if yyb3143 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40208,17 +40126,17 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.DevicePath = string(r.DecodeString()) } for { - yyj3152++ - if yyhl3152 { - yyb3152 = yyj3152 > l + yyj3143++ + if yyhl3143 { + yyb3143 = yyj3143 > l } else { - yyb3152 = r.CheckBreak() + yyb3143 = r.CheckBreak() } - if yyb3152 { + if yyb3143 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3152-1, "") + z.DecStructFieldNotFound(yyj3143-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40230,38 +40148,38 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3155 := z.EncBinary() - _ = yym3155 + yym3146 := z.EncBinary() + _ = yym3146 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3156 := !z.EncBinary() - yy2arr3156 := z.EncBasicHandle().StructToArray - var yyq3156 [1]bool - _, _, _ = yysep3156, yyq3156, yy2arr3156 - const yyr3156 bool = false - yyq3156[0] = len(x.PreferAvoidPods) != 0 - var yynn3156 int - if yyr3156 || yy2arr3156 { + yysep3147 := !z.EncBinary() + yy2arr3147 := z.EncBasicHandle().StructToArray + var yyq3147 [1]bool + _, _, _ = yysep3147, yyq3147, yy2arr3147 + const yyr3147 bool = false + yyq3147[0] = len(x.PreferAvoidPods) != 0 + var yynn3147 int + if yyr3147 || yy2arr3147 { r.EncodeArrayStart(1) } else { - yynn3156 = 0 - for _, b := range yyq3156 { + yynn3147 = 0 + for _, b := range yyq3147 { if b { - yynn3156++ + yynn3147++ } } - r.EncodeMapStart(yynn3156) - yynn3156 = 0 + r.EncodeMapStart(yynn3147) + yynn3147 = 0 } - if yyr3156 || yy2arr3156 { + if yyr3147 || yy2arr3147 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3156[0] { + if yyq3147[0] { if x.PreferAvoidPods == nil { r.EncodeNil() } else { - yym3158 := z.EncBinary() - _ = yym3158 + yym3149 := z.EncBinary() + _ = yym3149 if false { } else { h.encSlicePreferAvoidPodsEntry(([]PreferAvoidPodsEntry)(x.PreferAvoidPods), e) @@ -40271,15 +40189,15 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3156[0] { + if yyq3147[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("preferAvoidPods")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.PreferAvoidPods == nil { r.EncodeNil() } else { - yym3159 := z.EncBinary() - _ = yym3159 + yym3150 := z.EncBinary() + _ = yym3150 if false { } else { h.encSlicePreferAvoidPodsEntry(([]PreferAvoidPodsEntry)(x.PreferAvoidPods), e) @@ -40287,7 +40205,7 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3156 || yy2arr3156 { + if yyr3147 || yy2arr3147 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40300,25 +40218,25 @@ func (x *AvoidPods) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3160 := z.DecBinary() - _ = yym3160 + yym3151 := z.DecBinary() + _ = yym3151 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3161 := r.ContainerType() - if yyct3161 == codecSelferValueTypeMap1234 { - yyl3161 := r.ReadMapStart() - if yyl3161 == 0 { + yyct3152 := r.ContainerType() + if yyct3152 == codecSelferValueTypeMap1234 { + yyl3152 := r.ReadMapStart() + if yyl3152 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3161, d) + x.codecDecodeSelfFromMap(yyl3152, d) } - } else if yyct3161 == codecSelferValueTypeArray1234 { - yyl3161 := r.ReadArrayStart() - if yyl3161 == 0 { + } else if yyct3152 == codecSelferValueTypeArray1234 { + yyl3152 := r.ReadArrayStart() + if yyl3152 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3161, d) + x.codecDecodeSelfFromArray(yyl3152, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40330,12 +40248,12 @@ func (x *AvoidPods) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3162Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3162Slc - var yyhl3162 bool = l >= 0 - for yyj3162 := 0; ; yyj3162++ { - if yyhl3162 { - if yyj3162 >= l { + var yys3153Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3153Slc + var yyhl3153 bool = l >= 0 + for yyj3153 := 0; ; yyj3153++ { + if yyhl3153 { + if yyj3153 >= l { break } } else { @@ -40344,26 +40262,26 @@ func (x *AvoidPods) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3162Slc = r.DecodeBytes(yys3162Slc, true, true) - yys3162 := string(yys3162Slc) + yys3153Slc = r.DecodeBytes(yys3153Slc, true, true) + yys3153 := string(yys3153Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3162 { + switch yys3153 { case "preferAvoidPods": if r.TryDecodeAsNil() { x.PreferAvoidPods = nil } else { - yyv3163 := &x.PreferAvoidPods - yym3164 := z.DecBinary() - _ = yym3164 + yyv3154 := &x.PreferAvoidPods + yym3155 := z.DecBinary() + _ = yym3155 if false { } else { - h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3163), d) + h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3154), d) } } default: - z.DecStructFieldNotFound(-1, yys3162) - } // end switch yys3162 - } // end for yyj3162 + z.DecStructFieldNotFound(-1, yys3153) + } // end switch yys3153 + } // end for yyj3153 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40371,16 +40289,16 @@ func (x *AvoidPods) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3165 int - var yyb3165 bool - var yyhl3165 bool = l >= 0 - yyj3165++ - if yyhl3165 { - yyb3165 = yyj3165 > l + var yyj3156 int + var yyb3156 bool + var yyhl3156 bool = l >= 0 + yyj3156++ + if yyhl3156 { + yyb3156 = yyj3156 > l } else { - yyb3165 = r.CheckBreak() + yyb3156 = r.CheckBreak() } - if yyb3165 { + if yyb3156 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40388,26 +40306,26 @@ func (x *AvoidPods) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.PreferAvoidPods = nil } else { - yyv3166 := &x.PreferAvoidPods - yym3167 := z.DecBinary() - _ = yym3167 + yyv3157 := &x.PreferAvoidPods + yym3158 := z.DecBinary() + _ = yym3158 if false { } else { - h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3166), d) + h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3157), d) } } for { - yyj3165++ - if yyhl3165 { - yyb3165 = yyj3165 > l + yyj3156++ + if yyhl3156 { + yyb3156 = yyj3156 > l } else { - yyb3165 = r.CheckBreak() + yyb3156 = r.CheckBreak() } - if yyb3165 { + if yyb3156 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3165-1, "") + z.DecStructFieldNotFound(yyj3156-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40419,85 +40337,85 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3168 := z.EncBinary() - _ = yym3168 + yym3159 := z.EncBinary() + _ = yym3159 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3169 := !z.EncBinary() - yy2arr3169 := z.EncBasicHandle().StructToArray - var yyq3169 [4]bool - _, _, _ = yysep3169, yyq3169, yy2arr3169 - const yyr3169 bool = false - yyq3169[1] = true - yyq3169[2] = x.Reason != "" - yyq3169[3] = x.Message != "" - var yynn3169 int - if yyr3169 || yy2arr3169 { + yysep3160 := !z.EncBinary() + yy2arr3160 := z.EncBasicHandle().StructToArray + var yyq3160 [4]bool + _, _, _ = yysep3160, yyq3160, yy2arr3160 + const yyr3160 bool = false + yyq3160[1] = true + yyq3160[2] = x.Reason != "" + yyq3160[3] = x.Message != "" + var yynn3160 int + if yyr3160 || yy2arr3160 { r.EncodeArrayStart(4) } else { - yynn3169 = 1 - for _, b := range yyq3169 { + yynn3160 = 1 + for _, b := range yyq3160 { if b { - yynn3169++ + yynn3160++ } } - r.EncodeMapStart(yynn3169) - yynn3169 = 0 + r.EncodeMapStart(yynn3160) + yynn3160 = 0 } - if yyr3169 || yy2arr3169 { + if yyr3160 || yy2arr3160 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3171 := &x.PodSignature - yy3171.CodecEncodeSelf(e) + yy3162 := &x.PodSignature + yy3162.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSignature")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3172 := &x.PodSignature - yy3172.CodecEncodeSelf(e) + yy3163 := &x.PodSignature + yy3163.CodecEncodeSelf(e) } - if yyr3169 || yy2arr3169 { + if yyr3160 || yy2arr3160 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3169[1] { - yy3174 := &x.EvictionTime - yym3175 := z.EncBinary() - _ = yym3175 + if yyq3160[1] { + yy3165 := &x.EvictionTime + yym3166 := z.EncBinary() + _ = yym3166 if false { - } else if z.HasExtensions() && z.EncExt(yy3174) { - } else if yym3175 { - z.EncBinaryMarshal(yy3174) - } else if !yym3175 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3174) + } else if z.HasExtensions() && z.EncExt(yy3165) { + } else if yym3166 { + z.EncBinaryMarshal(yy3165) + } else if !yym3166 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3165) } else { - z.EncFallback(yy3174) + z.EncFallback(yy3165) } } else { r.EncodeNil() } } else { - if yyq3169[1] { + if yyq3160[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("evictionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3176 := &x.EvictionTime - yym3177 := z.EncBinary() - _ = yym3177 + yy3167 := &x.EvictionTime + yym3168 := z.EncBinary() + _ = yym3168 if false { - } else if z.HasExtensions() && z.EncExt(yy3176) { - } else if yym3177 { - z.EncBinaryMarshal(yy3176) - } else if !yym3177 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3176) + } else if z.HasExtensions() && z.EncExt(yy3167) { + } else if yym3168 { + z.EncBinaryMarshal(yy3167) + } else if !yym3168 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3167) } else { - z.EncFallback(yy3176) + z.EncFallback(yy3167) } } } - if yyr3169 || yy2arr3169 { + if yyr3160 || yy2arr3160 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3169[2] { - yym3179 := z.EncBinary() - _ = yym3179 + if yyq3160[2] { + yym3170 := z.EncBinary() + _ = yym3170 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -40506,23 +40424,23 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3169[2] { + if yyq3160[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3180 := z.EncBinary() - _ = yym3180 + yym3171 := z.EncBinary() + _ = yym3171 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3169 || yy2arr3169 { + if yyr3160 || yy2arr3160 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3169[3] { - yym3182 := z.EncBinary() - _ = yym3182 + if yyq3160[3] { + yym3173 := z.EncBinary() + _ = yym3173 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -40531,19 +40449,19 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3169[3] { + if yyq3160[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3183 := z.EncBinary() - _ = yym3183 + yym3174 := z.EncBinary() + _ = yym3174 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr3169 || yy2arr3169 { + if yyr3160 || yy2arr3160 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40556,25 +40474,25 @@ func (x *PreferAvoidPodsEntry) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3184 := z.DecBinary() - _ = yym3184 + yym3175 := z.DecBinary() + _ = yym3175 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3185 := r.ContainerType() - if yyct3185 == codecSelferValueTypeMap1234 { - yyl3185 := r.ReadMapStart() - if yyl3185 == 0 { + yyct3176 := r.ContainerType() + if yyct3176 == codecSelferValueTypeMap1234 { + yyl3176 := r.ReadMapStart() + if yyl3176 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3185, d) + x.codecDecodeSelfFromMap(yyl3176, d) } - } else if yyct3185 == codecSelferValueTypeArray1234 { - yyl3185 := r.ReadArrayStart() - if yyl3185 == 0 { + } else if yyct3176 == codecSelferValueTypeArray1234 { + yyl3176 := r.ReadArrayStart() + if yyl3176 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3185, d) + x.codecDecodeSelfFromArray(yyl3176, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40586,12 +40504,12 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3186Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3186Slc - var yyhl3186 bool = l >= 0 - for yyj3186 := 0; ; yyj3186++ { - if yyhl3186 { - if yyj3186 >= l { + var yys3177Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3177Slc + var yyhl3177 bool = l >= 0 + for yyj3177 := 0; ; yyj3177++ { + if yyhl3177 { + if yyj3177 >= l { break } } else { @@ -40600,32 +40518,32 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3186Slc = r.DecodeBytes(yys3186Slc, true, true) - yys3186 := string(yys3186Slc) + yys3177Slc = r.DecodeBytes(yys3177Slc, true, true) + yys3177 := string(yys3177Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3186 { + switch yys3177 { case "podSignature": if r.TryDecodeAsNil() { x.PodSignature = PodSignature{} } else { - yyv3187 := &x.PodSignature - yyv3187.CodecDecodeSelf(d) + yyv3178 := &x.PodSignature + yyv3178.CodecDecodeSelf(d) } case "evictionTime": if r.TryDecodeAsNil() { x.EvictionTime = pkg2_unversioned.Time{} } else { - yyv3188 := &x.EvictionTime - yym3189 := z.DecBinary() - _ = yym3189 + yyv3179 := &x.EvictionTime + yym3180 := z.DecBinary() + _ = yym3180 if false { - } else if z.HasExtensions() && z.DecExt(yyv3188) { - } else if yym3189 { - z.DecBinaryUnmarshal(yyv3188) - } else if !yym3189 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3188) + } else if z.HasExtensions() && z.DecExt(yyv3179) { + } else if yym3180 { + z.DecBinaryUnmarshal(yyv3179) + } else if !yym3180 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3179) } else { - z.DecFallback(yyv3188, false) + z.DecFallback(yyv3179, false) } } case "reason": @@ -40641,9 +40559,9 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3186) - } // end switch yys3186 - } // end for yyj3186 + z.DecStructFieldNotFound(-1, yys3177) + } // end switch yys3177 + } // end for yyj3177 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40651,16 +40569,16 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3192 int - var yyb3192 bool - var yyhl3192 bool = l >= 0 - yyj3192++ - if yyhl3192 { - yyb3192 = yyj3192 > l + var yyj3183 int + var yyb3183 bool + var yyhl3183 bool = l >= 0 + yyj3183++ + if yyhl3183 { + yyb3183 = yyj3183 > l } else { - yyb3192 = r.CheckBreak() + yyb3183 = r.CheckBreak() } - if yyb3192 { + if yyb3183 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40668,16 +40586,16 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.PodSignature = PodSignature{} } else { - yyv3193 := &x.PodSignature - yyv3193.CodecDecodeSelf(d) + yyv3184 := &x.PodSignature + yyv3184.CodecDecodeSelf(d) } - yyj3192++ - if yyhl3192 { - yyb3192 = yyj3192 > l + yyj3183++ + if yyhl3183 { + yyb3183 = yyj3183 > l } else { - yyb3192 = r.CheckBreak() + yyb3183 = r.CheckBreak() } - if yyb3192 { + if yyb3183 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40685,26 +40603,26 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.EvictionTime = pkg2_unversioned.Time{} } else { - yyv3194 := &x.EvictionTime - yym3195 := z.DecBinary() - _ = yym3195 + yyv3185 := &x.EvictionTime + yym3186 := z.DecBinary() + _ = yym3186 if false { - } else if z.HasExtensions() && z.DecExt(yyv3194) { - } else if yym3195 { - z.DecBinaryUnmarshal(yyv3194) - } else if !yym3195 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3194) + } else if z.HasExtensions() && z.DecExt(yyv3185) { + } else if yym3186 { + z.DecBinaryUnmarshal(yyv3185) + } else if !yym3186 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3185) } else { - z.DecFallback(yyv3194, false) + z.DecFallback(yyv3185, false) } } - yyj3192++ - if yyhl3192 { - yyb3192 = yyj3192 > l + yyj3183++ + if yyhl3183 { + yyb3183 = yyj3183 > l } else { - yyb3192 = r.CheckBreak() + yyb3183 = r.CheckBreak() } - if yyb3192 { + if yyb3183 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40714,13 +40632,13 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco } else { x.Reason = string(r.DecodeString()) } - yyj3192++ - if yyhl3192 { - yyb3192 = yyj3192 > l + yyj3183++ + if yyhl3183 { + yyb3183 = yyj3183 > l } else { - yyb3192 = r.CheckBreak() + yyb3183 = r.CheckBreak() } - if yyb3192 { + if yyb3183 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40731,17 +40649,17 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco x.Message = string(r.DecodeString()) } for { - yyj3192++ - if yyhl3192 { - yyb3192 = yyj3192 > l + yyj3183++ + if yyhl3183 { + yyb3183 = yyj3183 > l } else { - yyb3192 = r.CheckBreak() + yyb3183 = r.CheckBreak() } - if yyb3192 { + if yyb3183 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3192-1, "") + z.DecStructFieldNotFound(yyj3183-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40753,33 +40671,33 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3198 := z.EncBinary() - _ = yym3198 + yym3189 := z.EncBinary() + _ = yym3189 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3199 := !z.EncBinary() - yy2arr3199 := z.EncBasicHandle().StructToArray - var yyq3199 [1]bool - _, _, _ = yysep3199, yyq3199, yy2arr3199 - const yyr3199 bool = false - yyq3199[0] = x.PodController != nil - var yynn3199 int - if yyr3199 || yy2arr3199 { + yysep3190 := !z.EncBinary() + yy2arr3190 := z.EncBasicHandle().StructToArray + var yyq3190 [1]bool + _, _, _ = yysep3190, yyq3190, yy2arr3190 + const yyr3190 bool = false + yyq3190[0] = x.PodController != nil + var yynn3190 int + if yyr3190 || yy2arr3190 { r.EncodeArrayStart(1) } else { - yynn3199 = 0 - for _, b := range yyq3199 { + yynn3190 = 0 + for _, b := range yyq3190 { if b { - yynn3199++ + yynn3190++ } } - r.EncodeMapStart(yynn3199) - yynn3199 = 0 + r.EncodeMapStart(yynn3190) + yynn3190 = 0 } - if yyr3199 || yy2arr3199 { + if yyr3190 || yy2arr3190 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3199[0] { + if yyq3190[0] { if x.PodController == nil { r.EncodeNil() } else { @@ -40789,7 +40707,7 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3199[0] { + if yyq3190[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podController")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -40800,7 +40718,7 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3199 || yy2arr3199 { + if yyr3190 || yy2arr3190 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40813,25 +40731,25 @@ func (x *PodSignature) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3201 := z.DecBinary() - _ = yym3201 + yym3192 := z.DecBinary() + _ = yym3192 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3202 := r.ContainerType() - if yyct3202 == codecSelferValueTypeMap1234 { - yyl3202 := r.ReadMapStart() - if yyl3202 == 0 { + yyct3193 := r.ContainerType() + if yyct3193 == codecSelferValueTypeMap1234 { + yyl3193 := r.ReadMapStart() + if yyl3193 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3202, d) + x.codecDecodeSelfFromMap(yyl3193, d) } - } else if yyct3202 == codecSelferValueTypeArray1234 { - yyl3202 := r.ReadArrayStart() - if yyl3202 == 0 { + } else if yyct3193 == codecSelferValueTypeArray1234 { + yyl3193 := r.ReadArrayStart() + if yyl3193 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3202, d) + x.codecDecodeSelfFromArray(yyl3193, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40843,12 +40761,12 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3203Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3203Slc - var yyhl3203 bool = l >= 0 - for yyj3203 := 0; ; yyj3203++ { - if yyhl3203 { - if yyj3203 >= l { + var yys3194Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3194Slc + var yyhl3194 bool = l >= 0 + for yyj3194 := 0; ; yyj3194++ { + if yyhl3194 { + if yyj3194 >= l { break } } else { @@ -40857,10 +40775,10 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3203Slc = r.DecodeBytes(yys3203Slc, true, true) - yys3203 := string(yys3203Slc) + yys3194Slc = r.DecodeBytes(yys3194Slc, true, true) + yys3194 := string(yys3194Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3203 { + switch yys3194 { case "podController": if r.TryDecodeAsNil() { if x.PodController != nil { @@ -40873,9 +40791,9 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.PodController.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3203) - } // end switch yys3203 - } // end for yyj3203 + z.DecStructFieldNotFound(-1, yys3194) + } // end switch yys3194 + } // end for yyj3194 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40883,16 +40801,16 @@ func (x *PodSignature) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3205 int - var yyb3205 bool - var yyhl3205 bool = l >= 0 - yyj3205++ - if yyhl3205 { - yyb3205 = yyj3205 > l + var yyj3196 int + var yyb3196 bool + var yyhl3196 bool = l >= 0 + yyj3196++ + if yyhl3196 { + yyb3196 = yyj3196 > l } else { - yyb3205 = r.CheckBreak() + yyb3196 = r.CheckBreak() } - if yyb3205 { + if yyb3196 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40908,17 +40826,17 @@ func (x *PodSignature) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.PodController.CodecDecodeSelf(d) } for { - yyj3205++ - if yyhl3205 { - yyb3205 = yyj3205 > l + yyj3196++ + if yyhl3196 { + yyb3196 = yyj3196 > l } else { - yyb3205 = r.CheckBreak() + yyb3196 = r.CheckBreak() } - if yyb3205 { + if yyb3196 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3205-1, "") + z.DecStructFieldNotFound(yyj3196-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40930,37 +40848,37 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3207 := z.EncBinary() - _ = yym3207 + yym3198 := z.EncBinary() + _ = yym3198 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3208 := !z.EncBinary() - yy2arr3208 := z.EncBasicHandle().StructToArray - var yyq3208 [2]bool - _, _, _ = yysep3208, yyq3208, yy2arr3208 - const yyr3208 bool = false - yyq3208[1] = x.SizeBytes != 0 - var yynn3208 int - if yyr3208 || yy2arr3208 { + yysep3199 := !z.EncBinary() + yy2arr3199 := z.EncBasicHandle().StructToArray + var yyq3199 [2]bool + _, _, _ = yysep3199, yyq3199, yy2arr3199 + const yyr3199 bool = false + yyq3199[1] = x.SizeBytes != 0 + var yynn3199 int + if yyr3199 || yy2arr3199 { r.EncodeArrayStart(2) } else { - yynn3208 = 1 - for _, b := range yyq3208 { + yynn3199 = 1 + for _, b := range yyq3199 { if b { - yynn3208++ + yynn3199++ } } - r.EncodeMapStart(yynn3208) - yynn3208 = 0 + r.EncodeMapStart(yynn3199) + yynn3199 = 0 } - if yyr3208 || yy2arr3208 { + if yyr3199 || yy2arr3199 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Names == nil { r.EncodeNil() } else { - yym3210 := z.EncBinary() - _ = yym3210 + yym3201 := z.EncBinary() + _ = yym3201 if false { } else { z.F.EncSliceStringV(x.Names, false, e) @@ -40973,19 +40891,19 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { if x.Names == nil { r.EncodeNil() } else { - yym3211 := z.EncBinary() - _ = yym3211 + yym3202 := z.EncBinary() + _ = yym3202 if false { } else { z.F.EncSliceStringV(x.Names, false, e) } } } - if yyr3208 || yy2arr3208 { + if yyr3199 || yy2arr3199 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3208[1] { - yym3213 := z.EncBinary() - _ = yym3213 + if yyq3199[1] { + yym3204 := z.EncBinary() + _ = yym3204 if false { } else { r.EncodeInt(int64(x.SizeBytes)) @@ -40994,19 +40912,19 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq3208[1] { + if yyq3199[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("sizeBytes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3214 := z.EncBinary() - _ = yym3214 + yym3205 := z.EncBinary() + _ = yym3205 if false { } else { r.EncodeInt(int64(x.SizeBytes)) } } } - if yyr3208 || yy2arr3208 { + if yyr3199 || yy2arr3199 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41019,25 +40937,25 @@ func (x *ContainerImage) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3215 := z.DecBinary() - _ = yym3215 + yym3206 := z.DecBinary() + _ = yym3206 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3216 := r.ContainerType() - if yyct3216 == codecSelferValueTypeMap1234 { - yyl3216 := r.ReadMapStart() - if yyl3216 == 0 { + yyct3207 := r.ContainerType() + if yyct3207 == codecSelferValueTypeMap1234 { + yyl3207 := r.ReadMapStart() + if yyl3207 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3216, d) + x.codecDecodeSelfFromMap(yyl3207, d) } - } else if yyct3216 == codecSelferValueTypeArray1234 { - yyl3216 := r.ReadArrayStart() - if yyl3216 == 0 { + } else if yyct3207 == codecSelferValueTypeArray1234 { + yyl3207 := r.ReadArrayStart() + if yyl3207 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3216, d) + x.codecDecodeSelfFromArray(yyl3207, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41049,12 +40967,12 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3217Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3217Slc - var yyhl3217 bool = l >= 0 - for yyj3217 := 0; ; yyj3217++ { - if yyhl3217 { - if yyj3217 >= l { + var yys3208Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3208Slc + var yyhl3208 bool = l >= 0 + for yyj3208 := 0; ; yyj3208++ { + if yyhl3208 { + if yyj3208 >= l { break } } else { @@ -41063,20 +40981,20 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3217Slc = r.DecodeBytes(yys3217Slc, true, true) - yys3217 := string(yys3217Slc) + yys3208Slc = r.DecodeBytes(yys3208Slc, true, true) + yys3208 := string(yys3208Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3217 { + switch yys3208 { case "names": if r.TryDecodeAsNil() { x.Names = nil } else { - yyv3218 := &x.Names - yym3219 := z.DecBinary() - _ = yym3219 + yyv3209 := &x.Names + yym3210 := z.DecBinary() + _ = yym3210 if false { } else { - z.F.DecSliceStringX(yyv3218, false, d) + z.F.DecSliceStringX(yyv3209, false, d) } } case "sizeBytes": @@ -41086,9 +41004,9 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.SizeBytes = int64(r.DecodeInt(64)) } default: - z.DecStructFieldNotFound(-1, yys3217) - } // end switch yys3217 - } // end for yyj3217 + z.DecStructFieldNotFound(-1, yys3208) + } // end switch yys3208 + } // end for yyj3208 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41096,16 +41014,16 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3221 int - var yyb3221 bool - var yyhl3221 bool = l >= 0 - yyj3221++ - if yyhl3221 { - yyb3221 = yyj3221 > l + var yyj3212 int + var yyb3212 bool + var yyhl3212 bool = l >= 0 + yyj3212++ + if yyhl3212 { + yyb3212 = yyj3212 > l } else { - yyb3221 = r.CheckBreak() + yyb3212 = r.CheckBreak() } - if yyb3221 { + if yyb3212 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41113,21 +41031,21 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Names = nil } else { - yyv3222 := &x.Names - yym3223 := z.DecBinary() - _ = yym3223 + yyv3213 := &x.Names + yym3214 := z.DecBinary() + _ = yym3214 if false { } else { - z.F.DecSliceStringX(yyv3222, false, d) + z.F.DecSliceStringX(yyv3213, false, d) } } - yyj3221++ - if yyhl3221 { - yyb3221 = yyj3221 > l + yyj3212++ + if yyhl3212 { + yyb3212 = yyj3212 > l } else { - yyb3221 = r.CheckBreak() + yyb3212 = r.CheckBreak() } - if yyb3221 { + if yyb3212 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41138,17 +41056,17 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.SizeBytes = int64(r.DecodeInt(64)) } for { - yyj3221++ - if yyhl3221 { - yyb3221 = yyj3221 > l + yyj3212++ + if yyhl3212 { + yyb3212 = yyj3212 > l } else { - yyb3221 = r.CheckBreak() + yyb3212 = r.CheckBreak() } - if yyb3221 { + if yyb3212 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3221-1, "") + z.DecStructFieldNotFound(yyj3212-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41157,8 +41075,8 @@ func (x NodePhase) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3225 := z.EncBinary() - _ = yym3225 + yym3216 := z.EncBinary() + _ = yym3216 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41170,8 +41088,8 @@ func (x *NodePhase) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3226 := z.DecBinary() - _ = yym3226 + yym3217 := z.DecBinary() + _ = yym3217 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41183,8 +41101,8 @@ func (x NodeConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3227 := z.EncBinary() - _ = yym3227 + yym3218 := z.EncBinary() + _ = yym3218 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41196,8 +41114,8 @@ func (x *NodeConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3228 := z.DecBinary() - _ = yym3228 + yym3219 := z.DecBinary() + _ = yym3219 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41212,34 +41130,34 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3229 := z.EncBinary() - _ = yym3229 + yym3220 := z.EncBinary() + _ = yym3220 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3230 := !z.EncBinary() - yy2arr3230 := z.EncBasicHandle().StructToArray - var yyq3230 [6]bool - _, _, _ = yysep3230, yyq3230, yy2arr3230 - const yyr3230 bool = false - yyq3230[2] = true - yyq3230[3] = true - yyq3230[4] = x.Reason != "" - yyq3230[5] = x.Message != "" - var yynn3230 int - if yyr3230 || yy2arr3230 { + yysep3221 := !z.EncBinary() + yy2arr3221 := z.EncBasicHandle().StructToArray + var yyq3221 [6]bool + _, _, _ = yysep3221, yyq3221, yy2arr3221 + const yyr3221 bool = false + yyq3221[2] = true + yyq3221[3] = true + yyq3221[4] = x.Reason != "" + yyq3221[5] = x.Message != "" + var yynn3221 int + if yyr3221 || yy2arr3221 { r.EncodeArrayStart(6) } else { - yynn3230 = 2 - for _, b := range yyq3230 { + yynn3221 = 2 + for _, b := range yyq3221 { if b { - yynn3230++ + yynn3221++ } } - r.EncodeMapStart(yynn3230) - yynn3230 = 0 + r.EncodeMapStart(yynn3221) + yynn3221 = 0 } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -41248,7 +41166,7 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Status.CodecEncodeSelf(e) } else { @@ -41257,85 +41175,85 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Status.CodecEncodeSelf(e) } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3230[2] { - yy3234 := &x.LastHeartbeatTime - yym3235 := z.EncBinary() - _ = yym3235 + if yyq3221[2] { + yy3225 := &x.LastHeartbeatTime + yym3226 := z.EncBinary() + _ = yym3226 if false { - } else if z.HasExtensions() && z.EncExt(yy3234) { - } else if yym3235 { - z.EncBinaryMarshal(yy3234) - } else if !yym3235 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3234) + } else if z.HasExtensions() && z.EncExt(yy3225) { + } else if yym3226 { + z.EncBinaryMarshal(yy3225) + } else if !yym3226 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3225) } else { - z.EncFallback(yy3234) + z.EncFallback(yy3225) } } else { r.EncodeNil() } } else { - if yyq3230[2] { + if yyq3221[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastHeartbeatTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3236 := &x.LastHeartbeatTime - yym3237 := z.EncBinary() - _ = yym3237 + yy3227 := &x.LastHeartbeatTime + yym3228 := z.EncBinary() + _ = yym3228 if false { - } else if z.HasExtensions() && z.EncExt(yy3236) { - } else if yym3237 { - z.EncBinaryMarshal(yy3236) - } else if !yym3237 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3236) + } else if z.HasExtensions() && z.EncExt(yy3227) { + } else if yym3228 { + z.EncBinaryMarshal(yy3227) + } else if !yym3228 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3227) } else { - z.EncFallback(yy3236) + z.EncFallback(yy3227) } } } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3230[3] { - yy3239 := &x.LastTransitionTime - yym3240 := z.EncBinary() - _ = yym3240 + if yyq3221[3] { + yy3230 := &x.LastTransitionTime + yym3231 := z.EncBinary() + _ = yym3231 if false { - } else if z.HasExtensions() && z.EncExt(yy3239) { - } else if yym3240 { - z.EncBinaryMarshal(yy3239) - } else if !yym3240 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3239) + } else if z.HasExtensions() && z.EncExt(yy3230) { + } else if yym3231 { + z.EncBinaryMarshal(yy3230) + } else if !yym3231 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3230) } else { - z.EncFallback(yy3239) + z.EncFallback(yy3230) } } else { r.EncodeNil() } } else { - if yyq3230[3] { + if yyq3221[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3241 := &x.LastTransitionTime - yym3242 := z.EncBinary() - _ = yym3242 + yy3232 := &x.LastTransitionTime + yym3233 := z.EncBinary() + _ = yym3233 if false { - } else if z.HasExtensions() && z.EncExt(yy3241) { - } else if yym3242 { - z.EncBinaryMarshal(yy3241) - } else if !yym3242 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3241) + } else if z.HasExtensions() && z.EncExt(yy3232) { + } else if yym3233 { + z.EncBinaryMarshal(yy3232) + } else if !yym3233 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3232) } else { - z.EncFallback(yy3241) + z.EncFallback(yy3232) } } } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3230[4] { - yym3244 := z.EncBinary() - _ = yym3244 + if yyq3221[4] { + yym3235 := z.EncBinary() + _ = yym3235 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -41344,23 +41262,23 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3230[4] { + if yyq3221[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3245 := z.EncBinary() - _ = yym3245 + yym3236 := z.EncBinary() + _ = yym3236 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3230[5] { - yym3247 := z.EncBinary() - _ = yym3247 + if yyq3221[5] { + yym3238 := z.EncBinary() + _ = yym3238 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -41369,19 +41287,19 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3230[5] { + if yyq3221[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3248 := z.EncBinary() - _ = yym3248 + yym3239 := z.EncBinary() + _ = yym3239 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr3230 || yy2arr3230 { + if yyr3221 || yy2arr3221 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41394,25 +41312,25 @@ func (x *NodeCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3249 := z.DecBinary() - _ = yym3249 + yym3240 := z.DecBinary() + _ = yym3240 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3250 := r.ContainerType() - if yyct3250 == codecSelferValueTypeMap1234 { - yyl3250 := r.ReadMapStart() - if yyl3250 == 0 { + yyct3241 := r.ContainerType() + if yyct3241 == codecSelferValueTypeMap1234 { + yyl3241 := r.ReadMapStart() + if yyl3241 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3250, d) + x.codecDecodeSelfFromMap(yyl3241, d) } - } else if yyct3250 == codecSelferValueTypeArray1234 { - yyl3250 := r.ReadArrayStart() - if yyl3250 == 0 { + } else if yyct3241 == codecSelferValueTypeArray1234 { + yyl3241 := r.ReadArrayStart() + if yyl3241 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3250, d) + x.codecDecodeSelfFromArray(yyl3241, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41424,12 +41342,12 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3251Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3251Slc - var yyhl3251 bool = l >= 0 - for yyj3251 := 0; ; yyj3251++ { - if yyhl3251 { - if yyj3251 >= l { + var yys3242Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3242Slc + var yyhl3242 bool = l >= 0 + for yyj3242 := 0; ; yyj3242++ { + if yyhl3242 { + if yyj3242 >= l { break } } else { @@ -41438,10 +41356,10 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3251Slc = r.DecodeBytes(yys3251Slc, true, true) - yys3251 := string(yys3251Slc) + yys3242Slc = r.DecodeBytes(yys3242Slc, true, true) + yys3242 := string(yys3242Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3251 { + switch yys3242 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -41458,34 +41376,34 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastHeartbeatTime = pkg2_unversioned.Time{} } else { - yyv3254 := &x.LastHeartbeatTime - yym3255 := z.DecBinary() - _ = yym3255 + yyv3245 := &x.LastHeartbeatTime + yym3246 := z.DecBinary() + _ = yym3246 if false { - } else if z.HasExtensions() && z.DecExt(yyv3254) { - } else if yym3255 { - z.DecBinaryUnmarshal(yyv3254) - } else if !yym3255 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3254) + } else if z.HasExtensions() && z.DecExt(yyv3245) { + } else if yym3246 { + z.DecBinaryUnmarshal(yyv3245) + } else if !yym3246 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3245) } else { - z.DecFallback(yyv3254, false) + z.DecFallback(yyv3245, false) } } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv3256 := &x.LastTransitionTime - yym3257 := z.DecBinary() - _ = yym3257 + yyv3247 := &x.LastTransitionTime + yym3248 := z.DecBinary() + _ = yym3248 if false { - } else if z.HasExtensions() && z.DecExt(yyv3256) { - } else if yym3257 { - z.DecBinaryUnmarshal(yyv3256) - } else if !yym3257 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3256) + } else if z.HasExtensions() && z.DecExt(yyv3247) { + } else if yym3248 { + z.DecBinaryUnmarshal(yyv3247) + } else if !yym3248 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3247) } else { - z.DecFallback(yyv3256, false) + z.DecFallback(yyv3247, false) } } case "reason": @@ -41501,9 +41419,9 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3251) - } // end switch yys3251 - } // end for yyj3251 + z.DecStructFieldNotFound(-1, yys3242) + } // end switch yys3242 + } // end for yyj3242 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41511,16 +41429,16 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3260 int - var yyb3260 bool - var yyhl3260 bool = l >= 0 - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + var yyj3251 int + var yyb3251 bool + var yyhl3251 bool = l >= 0 + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41530,13 +41448,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = NodeConditionType(r.DecodeString()) } - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41546,13 +41464,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41560,26 +41478,26 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastHeartbeatTime = pkg2_unversioned.Time{} } else { - yyv3263 := &x.LastHeartbeatTime - yym3264 := z.DecBinary() - _ = yym3264 + yyv3254 := &x.LastHeartbeatTime + yym3255 := z.DecBinary() + _ = yym3255 if false { - } else if z.HasExtensions() && z.DecExt(yyv3263) { - } else if yym3264 { - z.DecBinaryUnmarshal(yyv3263) - } else if !yym3264 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3263) + } else if z.HasExtensions() && z.DecExt(yyv3254) { + } else if yym3255 { + z.DecBinaryUnmarshal(yyv3254) + } else if !yym3255 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3254) } else { - z.DecFallback(yyv3263, false) + z.DecFallback(yyv3254, false) } } - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41587,26 +41505,26 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv3265 := &x.LastTransitionTime - yym3266 := z.DecBinary() - _ = yym3266 + yyv3256 := &x.LastTransitionTime + yym3257 := z.DecBinary() + _ = yym3257 if false { - } else if z.HasExtensions() && z.DecExt(yyv3265) { - } else if yym3266 { - z.DecBinaryUnmarshal(yyv3265) - } else if !yym3266 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3265) + } else if z.HasExtensions() && z.DecExt(yyv3256) { + } else if yym3257 { + z.DecBinaryUnmarshal(yyv3256) + } else if !yym3257 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3256) } else { - z.DecFallback(yyv3265, false) + z.DecFallback(yyv3256, false) } } - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41616,13 +41534,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41633,17 +41551,17 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } for { - yyj3260++ - if yyhl3260 { - yyb3260 = yyj3260 > l + yyj3251++ + if yyhl3251 { + yyb3251 = yyj3251 > l } else { - yyb3260 = r.CheckBreak() + yyb3251 = r.CheckBreak() } - if yyb3260 { + if yyb3251 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3260-1, "") + z.DecStructFieldNotFound(yyj3251-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41652,8 +41570,8 @@ func (x NodeAddressType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3269 := z.EncBinary() - _ = yym3269 + yym3260 := z.EncBinary() + _ = yym3260 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41665,8 +41583,8 @@ func (x *NodeAddressType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3270 := z.DecBinary() - _ = yym3270 + yym3261 := z.DecBinary() + _ = yym3261 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41681,30 +41599,30 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3271 := z.EncBinary() - _ = yym3271 + yym3262 := z.EncBinary() + _ = yym3262 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3272 := !z.EncBinary() - yy2arr3272 := z.EncBasicHandle().StructToArray - var yyq3272 [2]bool - _, _, _ = yysep3272, yyq3272, yy2arr3272 - const yyr3272 bool = false - var yynn3272 int - if yyr3272 || yy2arr3272 { + yysep3263 := !z.EncBinary() + yy2arr3263 := z.EncBasicHandle().StructToArray + var yyq3263 [2]bool + _, _, _ = yysep3263, yyq3263, yy2arr3263 + const yyr3263 bool = false + var yynn3263 int + if yyr3263 || yy2arr3263 { r.EncodeArrayStart(2) } else { - yynn3272 = 2 - for _, b := range yyq3272 { + yynn3263 = 2 + for _, b := range yyq3263 { if b { - yynn3272++ + yynn3263++ } } - r.EncodeMapStart(yynn3272) - yynn3272 = 0 + r.EncodeMapStart(yynn3263) + yynn3263 = 0 } - if yyr3272 || yy2arr3272 { + if yyr3263 || yy2arr3263 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -41713,10 +41631,10 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr3272 || yy2arr3272 { + if yyr3263 || yy2arr3263 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3275 := z.EncBinary() - _ = yym3275 + yym3266 := z.EncBinary() + _ = yym3266 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Address)) @@ -41725,14 +41643,14 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("address")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3276 := z.EncBinary() - _ = yym3276 + yym3267 := z.EncBinary() + _ = yym3267 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Address)) } } - if yyr3272 || yy2arr3272 { + if yyr3263 || yy2arr3263 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41745,25 +41663,25 @@ func (x *NodeAddress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3277 := z.DecBinary() - _ = yym3277 + yym3268 := z.DecBinary() + _ = yym3268 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3278 := r.ContainerType() - if yyct3278 == codecSelferValueTypeMap1234 { - yyl3278 := r.ReadMapStart() - if yyl3278 == 0 { + yyct3269 := r.ContainerType() + if yyct3269 == codecSelferValueTypeMap1234 { + yyl3269 := r.ReadMapStart() + if yyl3269 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3278, d) + x.codecDecodeSelfFromMap(yyl3269, d) } - } else if yyct3278 == codecSelferValueTypeArray1234 { - yyl3278 := r.ReadArrayStart() - if yyl3278 == 0 { + } else if yyct3269 == codecSelferValueTypeArray1234 { + yyl3269 := r.ReadArrayStart() + if yyl3269 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3278, d) + x.codecDecodeSelfFromArray(yyl3269, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41775,12 +41693,12 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3279Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3279Slc - var yyhl3279 bool = l >= 0 - for yyj3279 := 0; ; yyj3279++ { - if yyhl3279 { - if yyj3279 >= l { + var yys3270Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3270Slc + var yyhl3270 bool = l >= 0 + for yyj3270 := 0; ; yyj3270++ { + if yyhl3270 { + if yyj3270 >= l { break } } else { @@ -41789,10 +41707,10 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3279Slc = r.DecodeBytes(yys3279Slc, true, true) - yys3279 := string(yys3279Slc) + yys3270Slc = r.DecodeBytes(yys3270Slc, true, true) + yys3270 := string(yys3270Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3279 { + switch yys3270 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -41806,9 +41724,9 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Address = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3279) - } // end switch yys3279 - } // end for yyj3279 + z.DecStructFieldNotFound(-1, yys3270) + } // end switch yys3270 + } // end for yyj3270 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41816,16 +41734,16 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3282 int - var yyb3282 bool - var yyhl3282 bool = l >= 0 - yyj3282++ - if yyhl3282 { - yyb3282 = yyj3282 > l + var yyj3273 int + var yyb3273 bool + var yyhl3273 bool = l >= 0 + yyj3273++ + if yyhl3273 { + yyb3273 = yyj3273 > l } else { - yyb3282 = r.CheckBreak() + yyb3273 = r.CheckBreak() } - if yyb3282 { + if yyb3273 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41835,13 +41753,13 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = NodeAddressType(r.DecodeString()) } - yyj3282++ - if yyhl3282 { - yyb3282 = yyj3282 > l + yyj3273++ + if yyhl3273 { + yyb3273 = yyj3273 > l } else { - yyb3282 = r.CheckBreak() + yyb3273 = r.CheckBreak() } - if yyb3282 { + if yyb3273 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41852,17 +41770,17 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Address = string(r.DecodeString()) } for { - yyj3282++ - if yyhl3282 { - yyb3282 = yyj3282 > l + yyj3273++ + if yyhl3273 { + yyb3273 = yyj3273 > l } else { - yyb3282 = r.CheckBreak() + yyb3273 = r.CheckBreak() } - if yyb3282 { + if yyb3273 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3282-1, "") + z.DecStructFieldNotFound(yyj3273-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41874,33 +41792,33 @@ func (x *NodeResources) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3285 := z.EncBinary() - _ = yym3285 + yym3276 := z.EncBinary() + _ = yym3276 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3286 := !z.EncBinary() - yy2arr3286 := z.EncBasicHandle().StructToArray - var yyq3286 [1]bool - _, _, _ = yysep3286, yyq3286, yy2arr3286 - const yyr3286 bool = false - yyq3286[0] = len(x.Capacity) != 0 - var yynn3286 int - if yyr3286 || yy2arr3286 { + yysep3277 := !z.EncBinary() + yy2arr3277 := z.EncBasicHandle().StructToArray + var yyq3277 [1]bool + _, _, _ = yysep3277, yyq3277, yy2arr3277 + const yyr3277 bool = false + yyq3277[0] = len(x.Capacity) != 0 + var yynn3277 int + if yyr3277 || yy2arr3277 { r.EncodeArrayStart(1) } else { - yynn3286 = 0 - for _, b := range yyq3286 { + yynn3277 = 0 + for _, b := range yyq3277 { if b { - yynn3286++ + yynn3277++ } } - r.EncodeMapStart(yynn3286) - yynn3286 = 0 + r.EncodeMapStart(yynn3277) + yynn3277 = 0 } - if yyr3286 || yy2arr3286 { + if yyr3277 || yy2arr3277 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3286[0] { + if yyq3277[0] { if x.Capacity == nil { r.EncodeNil() } else { @@ -41910,7 +41828,7 @@ func (x *NodeResources) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3286[0] { + if yyq3277[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("capacity")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -41921,7 +41839,7 @@ func (x *NodeResources) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3286 || yy2arr3286 { + if yyr3277 || yy2arr3277 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41934,25 +41852,25 @@ func (x *NodeResources) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3288 := z.DecBinary() - _ = yym3288 + yym3279 := z.DecBinary() + _ = yym3279 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3289 := r.ContainerType() - if yyct3289 == codecSelferValueTypeMap1234 { - yyl3289 := r.ReadMapStart() - if yyl3289 == 0 { + yyct3280 := r.ContainerType() + if yyct3280 == codecSelferValueTypeMap1234 { + yyl3280 := r.ReadMapStart() + if yyl3280 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3289, d) + x.codecDecodeSelfFromMap(yyl3280, d) } - } else if yyct3289 == codecSelferValueTypeArray1234 { - yyl3289 := r.ReadArrayStart() - if yyl3289 == 0 { + } else if yyct3280 == codecSelferValueTypeArray1234 { + yyl3280 := r.ReadArrayStart() + if yyl3280 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3289, d) + x.codecDecodeSelfFromArray(yyl3280, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41964,12 +41882,12 @@ func (x *NodeResources) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3290Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3290Slc - var yyhl3290 bool = l >= 0 - for yyj3290 := 0; ; yyj3290++ { - if yyhl3290 { - if yyj3290 >= l { + var yys3281Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3281Slc + var yyhl3281 bool = l >= 0 + for yyj3281 := 0; ; yyj3281++ { + if yyhl3281 { + if yyj3281 >= l { break } } else { @@ -41978,21 +41896,21 @@ func (x *NodeResources) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3290Slc = r.DecodeBytes(yys3290Slc, true, true) - yys3290 := string(yys3290Slc) + yys3281Slc = r.DecodeBytes(yys3281Slc, true, true) + yys3281 := string(yys3281Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3290 { + switch yys3281 { case "capacity": if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3291 := &x.Capacity - yyv3291.CodecDecodeSelf(d) + yyv3282 := &x.Capacity + yyv3282.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3290) - } // end switch yys3290 - } // end for yyj3290 + z.DecStructFieldNotFound(-1, yys3281) + } // end switch yys3281 + } // end for yyj3281 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42000,16 +41918,16 @@ func (x *NodeResources) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3292 int - var yyb3292 bool - var yyhl3292 bool = l >= 0 - yyj3292++ - if yyhl3292 { - yyb3292 = yyj3292 > l + var yyj3283 int + var yyb3283 bool + var yyhl3283 bool = l >= 0 + yyj3283++ + if yyhl3283 { + yyb3283 = yyj3283 > l } else { - yyb3292 = r.CheckBreak() + yyb3283 = r.CheckBreak() } - if yyb3292 { + if yyb3283 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42017,21 +41935,21 @@ func (x *NodeResources) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3293 := &x.Capacity - yyv3293.CodecDecodeSelf(d) + yyv3284 := &x.Capacity + yyv3284.CodecDecodeSelf(d) } for { - yyj3292++ - if yyhl3292 { - yyb3292 = yyj3292 > l + yyj3283++ + if yyhl3283 { + yyb3283 = yyj3283 > l } else { - yyb3292 = r.CheckBreak() + yyb3283 = r.CheckBreak() } - if yyb3292 { + if yyb3283 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3292-1, "") + z.DecStructFieldNotFound(yyj3283-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42040,8 +41958,8 @@ func (x ResourceName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3294 := z.EncBinary() - _ = yym3294 + yym3285 := z.EncBinary() + _ = yym3285 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -42053,8 +41971,8 @@ func (x *ResourceName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3295 := z.DecBinary() - _ = yym3295 + yym3286 := z.DecBinary() + _ = yym3286 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -42069,8 +41987,8 @@ func (x ResourceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3296 := z.EncBinary() - _ = yym3296 + yym3287 := z.EncBinary() + _ = yym3287 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -42083,8 +42001,8 @@ func (x *ResourceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3297 := z.DecBinary() - _ = yym3297 + yym3288 := z.DecBinary() + _ = yym3288 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -42099,39 +42017,39 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3298 := z.EncBinary() - _ = yym3298 + yym3289 := z.EncBinary() + _ = yym3289 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3299 := !z.EncBinary() - yy2arr3299 := z.EncBasicHandle().StructToArray - var yyq3299 [5]bool - _, _, _ = yysep3299, yyq3299, yy2arr3299 - const yyr3299 bool = false - yyq3299[0] = x.Kind != "" - yyq3299[1] = x.APIVersion != "" - yyq3299[2] = true - yyq3299[3] = true - yyq3299[4] = true - var yynn3299 int - if yyr3299 || yy2arr3299 { + yysep3290 := !z.EncBinary() + yy2arr3290 := z.EncBasicHandle().StructToArray + var yyq3290 [5]bool + _, _, _ = yysep3290, yyq3290, yy2arr3290 + const yyr3290 bool = false + yyq3290[0] = x.Kind != "" + yyq3290[1] = x.APIVersion != "" + yyq3290[2] = true + yyq3290[3] = true + yyq3290[4] = true + var yynn3290 int + if yyr3290 || yy2arr3290 { r.EncodeArrayStart(5) } else { - yynn3299 = 0 - for _, b := range yyq3299 { + yynn3290 = 0 + for _, b := range yyq3290 { if b { - yynn3299++ + yynn3290++ } } - r.EncodeMapStart(yynn3299) - yynn3299 = 0 + r.EncodeMapStart(yynn3290) + yynn3290 = 0 } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3299[0] { - yym3301 := z.EncBinary() - _ = yym3301 + if yyq3290[0] { + yym3292 := z.EncBinary() + _ = yym3292 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -42140,23 +42058,23 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3299[0] { + if yyq3290[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3302 := z.EncBinary() - _ = yym3302 + yym3293 := z.EncBinary() + _ = yym3293 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3299[1] { - yym3304 := z.EncBinary() - _ = yym3304 + if yyq3290[1] { + yym3295 := z.EncBinary() + _ = yym3295 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -42165,70 +42083,70 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3299[1] { + if yyq3290[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3305 := z.EncBinary() - _ = yym3305 + yym3296 := z.EncBinary() + _ = yym3296 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3299[2] { - yy3307 := &x.ObjectMeta - yy3307.CodecEncodeSelf(e) + if yyq3290[2] { + yy3298 := &x.ObjectMeta + yy3298.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3299[2] { + if yyq3290[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3308 := &x.ObjectMeta - yy3308.CodecEncodeSelf(e) + yy3299 := &x.ObjectMeta + yy3299.CodecEncodeSelf(e) } } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3299[3] { - yy3310 := &x.Spec - yy3310.CodecEncodeSelf(e) + if yyq3290[3] { + yy3301 := &x.Spec + yy3301.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3299[3] { + if yyq3290[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3311 := &x.Spec - yy3311.CodecEncodeSelf(e) + yy3302 := &x.Spec + yy3302.CodecEncodeSelf(e) } } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3299[4] { - yy3313 := &x.Status - yy3313.CodecEncodeSelf(e) + if yyq3290[4] { + yy3304 := &x.Status + yy3304.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3299[4] { + if yyq3290[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3314 := &x.Status - yy3314.CodecEncodeSelf(e) + yy3305 := &x.Status + yy3305.CodecEncodeSelf(e) } } - if yyr3299 || yy2arr3299 { + if yyr3290 || yy2arr3290 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42241,25 +42159,25 @@ func (x *Node) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3315 := z.DecBinary() - _ = yym3315 + yym3306 := z.DecBinary() + _ = yym3306 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3316 := r.ContainerType() - if yyct3316 == codecSelferValueTypeMap1234 { - yyl3316 := r.ReadMapStart() - if yyl3316 == 0 { + yyct3307 := r.ContainerType() + if yyct3307 == codecSelferValueTypeMap1234 { + yyl3307 := r.ReadMapStart() + if yyl3307 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3316, d) + x.codecDecodeSelfFromMap(yyl3307, d) } - } else if yyct3316 == codecSelferValueTypeArray1234 { - yyl3316 := r.ReadArrayStart() - if yyl3316 == 0 { + } else if yyct3307 == codecSelferValueTypeArray1234 { + yyl3307 := r.ReadArrayStart() + if yyl3307 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3316, d) + x.codecDecodeSelfFromArray(yyl3307, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42271,12 +42189,12 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3317Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3317Slc - var yyhl3317 bool = l >= 0 - for yyj3317 := 0; ; yyj3317++ { - if yyhl3317 { - if yyj3317 >= l { + var yys3308Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3308Slc + var yyhl3308 bool = l >= 0 + for yyj3308 := 0; ; yyj3308++ { + if yyhl3308 { + if yyj3308 >= l { break } } else { @@ -42285,10 +42203,10 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3317Slc = r.DecodeBytes(yys3317Slc, true, true) - yys3317 := string(yys3317Slc) + yys3308Slc = r.DecodeBytes(yys3308Slc, true, true) + yys3308 := string(yys3308Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3317 { + switch yys3308 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -42305,27 +42223,27 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3320 := &x.ObjectMeta - yyv3320.CodecDecodeSelf(d) + yyv3311 := &x.ObjectMeta + yyv3311.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NodeSpec{} } else { - yyv3321 := &x.Spec - yyv3321.CodecDecodeSelf(d) + yyv3312 := &x.Spec + yyv3312.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = NodeStatus{} } else { - yyv3322 := &x.Status - yyv3322.CodecDecodeSelf(d) + yyv3313 := &x.Status + yyv3313.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3317) - } // end switch yys3317 - } // end for yyj3317 + z.DecStructFieldNotFound(-1, yys3308) + } // end switch yys3308 + } // end for yyj3308 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42333,16 +42251,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3323 int - var yyb3323 bool - var yyhl3323 bool = l >= 0 - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + var yyj3314 int + var yyb3314 bool + var yyhl3314 bool = l >= 0 + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42352,13 +42270,13 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42368,13 +42286,13 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42382,16 +42300,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3326 := &x.ObjectMeta - yyv3326.CodecDecodeSelf(d) + yyv3317 := &x.ObjectMeta + yyv3317.CodecDecodeSelf(d) } - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42399,16 +42317,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NodeSpec{} } else { - yyv3327 := &x.Spec - yyv3327.CodecDecodeSelf(d) + yyv3318 := &x.Spec + yyv3318.CodecDecodeSelf(d) } - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42416,21 +42334,21 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = NodeStatus{} } else { - yyv3328 := &x.Status - yyv3328.CodecDecodeSelf(d) + yyv3319 := &x.Status + yyv3319.CodecDecodeSelf(d) } for { - yyj3323++ - if yyhl3323 { - yyb3323 = yyj3323 > l + yyj3314++ + if yyhl3314 { + yyb3314 = yyj3314 > l } else { - yyb3323 = r.CheckBreak() + yyb3314 = r.CheckBreak() } - if yyb3323 { + if yyb3314 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3323-1, "") + z.DecStructFieldNotFound(yyj3314-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42442,37 +42360,37 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3329 := z.EncBinary() - _ = yym3329 + yym3320 := z.EncBinary() + _ = yym3320 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3330 := !z.EncBinary() - yy2arr3330 := z.EncBasicHandle().StructToArray - var yyq3330 [4]bool - _, _, _ = yysep3330, yyq3330, yy2arr3330 - const yyr3330 bool = false - yyq3330[0] = x.Kind != "" - yyq3330[1] = x.APIVersion != "" - yyq3330[2] = true - var yynn3330 int - if yyr3330 || yy2arr3330 { + yysep3321 := !z.EncBinary() + yy2arr3321 := z.EncBasicHandle().StructToArray + var yyq3321 [4]bool + _, _, _ = yysep3321, yyq3321, yy2arr3321 + const yyr3321 bool = false + yyq3321[0] = x.Kind != "" + yyq3321[1] = x.APIVersion != "" + yyq3321[2] = true + var yynn3321 int + if yyr3321 || yy2arr3321 { r.EncodeArrayStart(4) } else { - yynn3330 = 1 - for _, b := range yyq3330 { + yynn3321 = 1 + for _, b := range yyq3321 { if b { - yynn3330++ + yynn3321++ } } - r.EncodeMapStart(yynn3330) - yynn3330 = 0 + r.EncodeMapStart(yynn3321) + yynn3321 = 0 } - if yyr3330 || yy2arr3330 { + if yyr3321 || yy2arr3321 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3330[0] { - yym3332 := z.EncBinary() - _ = yym3332 + if yyq3321[0] { + yym3323 := z.EncBinary() + _ = yym3323 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -42481,23 +42399,23 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3330[0] { + if yyq3321[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3333 := z.EncBinary() - _ = yym3333 + yym3324 := z.EncBinary() + _ = yym3324 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3330 || yy2arr3330 { + if yyr3321 || yy2arr3321 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3330[1] { - yym3335 := z.EncBinary() - _ = yym3335 + if yyq3321[1] { + yym3326 := z.EncBinary() + _ = yym3326 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -42506,54 +42424,54 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3330[1] { + if yyq3321[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3336 := z.EncBinary() - _ = yym3336 + yym3327 := z.EncBinary() + _ = yym3327 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3330 || yy2arr3330 { + if yyr3321 || yy2arr3321 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3330[2] { - yy3338 := &x.ListMeta - yym3339 := z.EncBinary() - _ = yym3339 + if yyq3321[2] { + yy3329 := &x.ListMeta + yym3330 := z.EncBinary() + _ = yym3330 if false { - } else if z.HasExtensions() && z.EncExt(yy3338) { + } else if z.HasExtensions() && z.EncExt(yy3329) { } else { - z.EncFallback(yy3338) + z.EncFallback(yy3329) } } else { r.EncodeNil() } } else { - if yyq3330[2] { + if yyq3321[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3340 := &x.ListMeta - yym3341 := z.EncBinary() - _ = yym3341 + yy3331 := &x.ListMeta + yym3332 := z.EncBinary() + _ = yym3332 if false { - } else if z.HasExtensions() && z.EncExt(yy3340) { + } else if z.HasExtensions() && z.EncExt(yy3331) { } else { - z.EncFallback(yy3340) + z.EncFallback(yy3331) } } } - if yyr3330 || yy2arr3330 { + if yyr3321 || yy2arr3321 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym3343 := z.EncBinary() - _ = yym3343 + yym3334 := z.EncBinary() + _ = yym3334 if false { } else { h.encSliceNode(([]Node)(x.Items), e) @@ -42566,15 +42484,15 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym3344 := z.EncBinary() - _ = yym3344 + yym3335 := z.EncBinary() + _ = yym3335 if false { } else { h.encSliceNode(([]Node)(x.Items), e) } } } - if yyr3330 || yy2arr3330 { + if yyr3321 || yy2arr3321 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42587,25 +42505,25 @@ func (x *NodeList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3345 := z.DecBinary() - _ = yym3345 + yym3336 := z.DecBinary() + _ = yym3336 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3346 := r.ContainerType() - if yyct3346 == codecSelferValueTypeMap1234 { - yyl3346 := r.ReadMapStart() - if yyl3346 == 0 { + yyct3337 := r.ContainerType() + if yyct3337 == codecSelferValueTypeMap1234 { + yyl3337 := r.ReadMapStart() + if yyl3337 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3346, d) + x.codecDecodeSelfFromMap(yyl3337, d) } - } else if yyct3346 == codecSelferValueTypeArray1234 { - yyl3346 := r.ReadArrayStart() - if yyl3346 == 0 { + } else if yyct3337 == codecSelferValueTypeArray1234 { + yyl3337 := r.ReadArrayStart() + if yyl3337 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3346, d) + x.codecDecodeSelfFromArray(yyl3337, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42617,12 +42535,12 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3347Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3347Slc - var yyhl3347 bool = l >= 0 - for yyj3347 := 0; ; yyj3347++ { - if yyhl3347 { - if yyj3347 >= l { + var yys3338Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3338Slc + var yyhl3338 bool = l >= 0 + for yyj3338 := 0; ; yyj3338++ { + if yyhl3338 { + if yyj3338 >= l { break } } else { @@ -42631,10 +42549,10 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3347Slc = r.DecodeBytes(yys3347Slc, true, true) - yys3347 := string(yys3347Slc) + yys3338Slc = r.DecodeBytes(yys3338Slc, true, true) + yys3338 := string(yys3338Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3347 { + switch yys3338 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -42651,31 +42569,31 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3350 := &x.ListMeta - yym3351 := z.DecBinary() - _ = yym3351 + yyv3341 := &x.ListMeta + yym3342 := z.DecBinary() + _ = yym3342 if false { - } else if z.HasExtensions() && z.DecExt(yyv3350) { + } else if z.HasExtensions() && z.DecExt(yyv3341) { } else { - z.DecFallback(yyv3350, false) + z.DecFallback(yyv3341, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3352 := &x.Items - yym3353 := z.DecBinary() - _ = yym3353 + yyv3343 := &x.Items + yym3344 := z.DecBinary() + _ = yym3344 if false { } else { - h.decSliceNode((*[]Node)(yyv3352), d) + h.decSliceNode((*[]Node)(yyv3343), d) } } default: - z.DecStructFieldNotFound(-1, yys3347) - } // end switch yys3347 - } // end for yyj3347 + z.DecStructFieldNotFound(-1, yys3338) + } // end switch yys3338 + } // end for yyj3338 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42683,16 +42601,16 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3354 int - var yyb3354 bool - var yyhl3354 bool = l >= 0 - yyj3354++ - if yyhl3354 { - yyb3354 = yyj3354 > l + var yyj3345 int + var yyb3345 bool + var yyhl3345 bool = l >= 0 + yyj3345++ + if yyhl3345 { + yyb3345 = yyj3345 > l } else { - yyb3354 = r.CheckBreak() + yyb3345 = r.CheckBreak() } - if yyb3354 { + if yyb3345 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42702,13 +42620,13 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3354++ - if yyhl3354 { - yyb3354 = yyj3354 > l + yyj3345++ + if yyhl3345 { + yyb3345 = yyj3345 > l } else { - yyb3354 = r.CheckBreak() + yyb3345 = r.CheckBreak() } - if yyb3354 { + if yyb3345 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42718,13 +42636,13 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3354++ - if yyhl3354 { - yyb3354 = yyj3354 > l + yyj3345++ + if yyhl3345 { + yyb3345 = yyj3345 > l } else { - yyb3354 = r.CheckBreak() + yyb3345 = r.CheckBreak() } - if yyb3354 { + if yyb3345 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42732,22 +42650,22 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3357 := &x.ListMeta - yym3358 := z.DecBinary() - _ = yym3358 + yyv3348 := &x.ListMeta + yym3349 := z.DecBinary() + _ = yym3349 if false { - } else if z.HasExtensions() && z.DecExt(yyv3357) { + } else if z.HasExtensions() && z.DecExt(yyv3348) { } else { - z.DecFallback(yyv3357, false) + z.DecFallback(yyv3348, false) } } - yyj3354++ - if yyhl3354 { - yyb3354 = yyj3354 > l + yyj3345++ + if yyhl3345 { + yyb3345 = yyj3345 > l } else { - yyb3354 = r.CheckBreak() + yyb3345 = r.CheckBreak() } - if yyb3354 { + if yyb3345 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42755,26 +42673,26 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3359 := &x.Items - yym3360 := z.DecBinary() - _ = yym3360 + yyv3350 := &x.Items + yym3351 := z.DecBinary() + _ = yym3351 if false { } else { - h.decSliceNode((*[]Node)(yyv3359), d) + h.decSliceNode((*[]Node)(yyv3350), d) } } for { - yyj3354++ - if yyhl3354 { - yyb3354 = yyj3354 > l + yyj3345++ + if yyhl3345 { + yyb3345 = yyj3345 > l } else { - yyb3354 = r.CheckBreak() + yyb3345 = r.CheckBreak() } - if yyb3354 { + if yyb3345 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3354-1, "") + z.DecStructFieldNotFound(yyj3345-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42786,36 +42704,36 @@ func (x *NamespaceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3361 := z.EncBinary() - _ = yym3361 + yym3352 := z.EncBinary() + _ = yym3352 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3362 := !z.EncBinary() - yy2arr3362 := z.EncBasicHandle().StructToArray - var yyq3362 [1]bool - _, _, _ = yysep3362, yyq3362, yy2arr3362 - const yyr3362 bool = false - var yynn3362 int - if yyr3362 || yy2arr3362 { + yysep3353 := !z.EncBinary() + yy2arr3353 := z.EncBasicHandle().StructToArray + var yyq3353 [1]bool + _, _, _ = yysep3353, yyq3353, yy2arr3353 + const yyr3353 bool = false + var yynn3353 int + if yyr3353 || yy2arr3353 { r.EncodeArrayStart(1) } else { - yynn3362 = 1 - for _, b := range yyq3362 { + yynn3353 = 1 + for _, b := range yyq3353 { if b { - yynn3362++ + yynn3353++ } } - r.EncodeMapStart(yynn3362) - yynn3362 = 0 + r.EncodeMapStart(yynn3353) + yynn3353 = 0 } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Finalizers == nil { r.EncodeNil() } else { - yym3364 := z.EncBinary() - _ = yym3364 + yym3355 := z.EncBinary() + _ = yym3355 if false { } else { h.encSliceFinalizerName(([]FinalizerName)(x.Finalizers), e) @@ -42828,15 +42746,15 @@ func (x *NamespaceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Finalizers == nil { r.EncodeNil() } else { - yym3365 := z.EncBinary() - _ = yym3365 + yym3356 := z.EncBinary() + _ = yym3356 if false { } else { h.encSliceFinalizerName(([]FinalizerName)(x.Finalizers), e) } } } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42849,25 +42767,25 @@ func (x *NamespaceSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3366 := z.DecBinary() - _ = yym3366 + yym3357 := z.DecBinary() + _ = yym3357 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3367 := r.ContainerType() - if yyct3367 == codecSelferValueTypeMap1234 { - yyl3367 := r.ReadMapStart() - if yyl3367 == 0 { + yyct3358 := r.ContainerType() + if yyct3358 == codecSelferValueTypeMap1234 { + yyl3358 := r.ReadMapStart() + if yyl3358 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3367, d) + x.codecDecodeSelfFromMap(yyl3358, d) } - } else if yyct3367 == codecSelferValueTypeArray1234 { - yyl3367 := r.ReadArrayStart() - if yyl3367 == 0 { + } else if yyct3358 == codecSelferValueTypeArray1234 { + yyl3358 := r.ReadArrayStart() + if yyl3358 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3367, d) + x.codecDecodeSelfFromArray(yyl3358, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42879,12 +42797,12 @@ func (x *NamespaceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3368Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3368Slc - var yyhl3368 bool = l >= 0 - for yyj3368 := 0; ; yyj3368++ { - if yyhl3368 { - if yyj3368 >= l { + var yys3359Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3359Slc + var yyhl3359 bool = l >= 0 + for yyj3359 := 0; ; yyj3359++ { + if yyhl3359 { + if yyj3359 >= l { break } } else { @@ -42893,26 +42811,26 @@ func (x *NamespaceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3368Slc = r.DecodeBytes(yys3368Slc, true, true) - yys3368 := string(yys3368Slc) + yys3359Slc = r.DecodeBytes(yys3359Slc, true, true) + yys3359 := string(yys3359Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3368 { + switch yys3359 { case "Finalizers": if r.TryDecodeAsNil() { x.Finalizers = nil } else { - yyv3369 := &x.Finalizers - yym3370 := z.DecBinary() - _ = yym3370 + yyv3360 := &x.Finalizers + yym3361 := z.DecBinary() + _ = yym3361 if false { } else { - h.decSliceFinalizerName((*[]FinalizerName)(yyv3369), d) + h.decSliceFinalizerName((*[]FinalizerName)(yyv3360), d) } } default: - z.DecStructFieldNotFound(-1, yys3368) - } // end switch yys3368 - } // end for yyj3368 + z.DecStructFieldNotFound(-1, yys3359) + } // end switch yys3359 + } // end for yyj3359 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42920,16 +42838,16 @@ func (x *NamespaceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3371 int - var yyb3371 bool - var yyhl3371 bool = l >= 0 - yyj3371++ - if yyhl3371 { - yyb3371 = yyj3371 > l + var yyj3362 int + var yyb3362 bool + var yyhl3362 bool = l >= 0 + yyj3362++ + if yyhl3362 { + yyb3362 = yyj3362 > l } else { - yyb3371 = r.CheckBreak() + yyb3362 = r.CheckBreak() } - if yyb3371 { + if yyb3362 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42937,26 +42855,26 @@ func (x *NamespaceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Finalizers = nil } else { - yyv3372 := &x.Finalizers - yym3373 := z.DecBinary() - _ = yym3373 + yyv3363 := &x.Finalizers + yym3364 := z.DecBinary() + _ = yym3364 if false { } else { - h.decSliceFinalizerName((*[]FinalizerName)(yyv3372), d) + h.decSliceFinalizerName((*[]FinalizerName)(yyv3363), d) } } for { - yyj3371++ - if yyhl3371 { - yyb3371 = yyj3371 > l + yyj3362++ + if yyhl3362 { + yyb3362 = yyj3362 > l } else { - yyb3371 = r.CheckBreak() + yyb3362 = r.CheckBreak() } - if yyb3371 { + if yyb3362 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3371-1, "") + z.DecStructFieldNotFound(yyj3362-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42965,8 +42883,8 @@ func (x FinalizerName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3374 := z.EncBinary() - _ = yym3374 + yym3365 := z.EncBinary() + _ = yym3365 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -42978,8 +42896,8 @@ func (x *FinalizerName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3375 := z.DecBinary() - _ = yym3375 + yym3366 := z.DecBinary() + _ = yym3366 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -42994,46 +42912,46 @@ func (x *NamespaceStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3376 := z.EncBinary() - _ = yym3376 + yym3367 := z.EncBinary() + _ = yym3367 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3377 := !z.EncBinary() - yy2arr3377 := z.EncBasicHandle().StructToArray - var yyq3377 [1]bool - _, _, _ = yysep3377, yyq3377, yy2arr3377 - const yyr3377 bool = false - yyq3377[0] = x.Phase != "" - var yynn3377 int - if yyr3377 || yy2arr3377 { + yysep3368 := !z.EncBinary() + yy2arr3368 := z.EncBasicHandle().StructToArray + var yyq3368 [1]bool + _, _, _ = yysep3368, yyq3368, yy2arr3368 + const yyr3368 bool = false + yyq3368[0] = x.Phase != "" + var yynn3368 int + if yyr3368 || yy2arr3368 { r.EncodeArrayStart(1) } else { - yynn3377 = 0 - for _, b := range yyq3377 { + yynn3368 = 0 + for _, b := range yyq3368 { if b { - yynn3377++ + yynn3368++ } } - r.EncodeMapStart(yynn3377) - yynn3377 = 0 + r.EncodeMapStart(yynn3368) + yynn3368 = 0 } - if yyr3377 || yy2arr3377 { + if yyr3368 || yy2arr3368 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3377[0] { + if yyq3368[0] { x.Phase.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3377[0] { + if yyq3368[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("phase")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Phase.CodecEncodeSelf(e) } } - if yyr3377 || yy2arr3377 { + if yyr3368 || yy2arr3368 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43046,25 +42964,25 @@ func (x *NamespaceStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3379 := z.DecBinary() - _ = yym3379 + yym3370 := z.DecBinary() + _ = yym3370 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3380 := r.ContainerType() - if yyct3380 == codecSelferValueTypeMap1234 { - yyl3380 := r.ReadMapStart() - if yyl3380 == 0 { + yyct3371 := r.ContainerType() + if yyct3371 == codecSelferValueTypeMap1234 { + yyl3371 := r.ReadMapStart() + if yyl3371 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3380, d) + x.codecDecodeSelfFromMap(yyl3371, d) } - } else if yyct3380 == codecSelferValueTypeArray1234 { - yyl3380 := r.ReadArrayStart() - if yyl3380 == 0 { + } else if yyct3371 == codecSelferValueTypeArray1234 { + yyl3371 := r.ReadArrayStart() + if yyl3371 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3380, d) + x.codecDecodeSelfFromArray(yyl3371, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43076,12 +42994,12 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3381Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3381Slc - var yyhl3381 bool = l >= 0 - for yyj3381 := 0; ; yyj3381++ { - if yyhl3381 { - if yyj3381 >= l { + var yys3372Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3372Slc + var yyhl3372 bool = l >= 0 + for yyj3372 := 0; ; yyj3372++ { + if yyhl3372 { + if yyj3372 >= l { break } } else { @@ -43090,10 +43008,10 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3381Slc = r.DecodeBytes(yys3381Slc, true, true) - yys3381 := string(yys3381Slc) + yys3372Slc = r.DecodeBytes(yys3372Slc, true, true) + yys3372 := string(yys3372Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3381 { + switch yys3372 { case "phase": if r.TryDecodeAsNil() { x.Phase = "" @@ -43101,9 +43019,9 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Phase = NamespacePhase(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3381) - } // end switch yys3381 - } // end for yyj3381 + z.DecStructFieldNotFound(-1, yys3372) + } // end switch yys3372 + } // end for yyj3372 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43111,16 +43029,16 @@ func (x *NamespaceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3383 int - var yyb3383 bool - var yyhl3383 bool = l >= 0 - yyj3383++ - if yyhl3383 { - yyb3383 = yyj3383 > l + var yyj3374 int + var yyb3374 bool + var yyhl3374 bool = l >= 0 + yyj3374++ + if yyhl3374 { + yyb3374 = yyj3374 > l } else { - yyb3383 = r.CheckBreak() + yyb3374 = r.CheckBreak() } - if yyb3383 { + if yyb3374 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43131,17 +43049,17 @@ func (x *NamespaceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Phase = NamespacePhase(r.DecodeString()) } for { - yyj3383++ - if yyhl3383 { - yyb3383 = yyj3383 > l + yyj3374++ + if yyhl3374 { + yyb3374 = yyj3374 > l } else { - yyb3383 = r.CheckBreak() + yyb3374 = r.CheckBreak() } - if yyb3383 { + if yyb3374 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3383-1, "") + z.DecStructFieldNotFound(yyj3374-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43150,8 +43068,8 @@ func (x NamespacePhase) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3385 := z.EncBinary() - _ = yym3385 + yym3376 := z.EncBinary() + _ = yym3376 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -43163,8 +43081,8 @@ func (x *NamespacePhase) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3386 := z.DecBinary() - _ = yym3386 + yym3377 := z.DecBinary() + _ = yym3377 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -43179,39 +43097,39 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3387 := z.EncBinary() - _ = yym3387 + yym3378 := z.EncBinary() + _ = yym3378 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3388 := !z.EncBinary() - yy2arr3388 := z.EncBasicHandle().StructToArray - var yyq3388 [5]bool - _, _, _ = yysep3388, yyq3388, yy2arr3388 - const yyr3388 bool = false - yyq3388[0] = x.Kind != "" - yyq3388[1] = x.APIVersion != "" - yyq3388[2] = true - yyq3388[3] = true - yyq3388[4] = true - var yynn3388 int - if yyr3388 || yy2arr3388 { + yysep3379 := !z.EncBinary() + yy2arr3379 := z.EncBasicHandle().StructToArray + var yyq3379 [5]bool + _, _, _ = yysep3379, yyq3379, yy2arr3379 + const yyr3379 bool = false + yyq3379[0] = x.Kind != "" + yyq3379[1] = x.APIVersion != "" + yyq3379[2] = true + yyq3379[3] = true + yyq3379[4] = true + var yynn3379 int + if yyr3379 || yy2arr3379 { r.EncodeArrayStart(5) } else { - yynn3388 = 0 - for _, b := range yyq3388 { + yynn3379 = 0 + for _, b := range yyq3379 { if b { - yynn3388++ + yynn3379++ } } - r.EncodeMapStart(yynn3388) - yynn3388 = 0 + r.EncodeMapStart(yynn3379) + yynn3379 = 0 } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3388[0] { - yym3390 := z.EncBinary() - _ = yym3390 + if yyq3379[0] { + yym3381 := z.EncBinary() + _ = yym3381 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -43220,23 +43138,23 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3388[0] { + if yyq3379[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3391 := z.EncBinary() - _ = yym3391 + yym3382 := z.EncBinary() + _ = yym3382 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3388[1] { - yym3393 := z.EncBinary() - _ = yym3393 + if yyq3379[1] { + yym3384 := z.EncBinary() + _ = yym3384 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -43245,70 +43163,70 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3388[1] { + if yyq3379[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3394 := z.EncBinary() - _ = yym3394 + yym3385 := z.EncBinary() + _ = yym3385 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3388[2] { - yy3396 := &x.ObjectMeta - yy3396.CodecEncodeSelf(e) + if yyq3379[2] { + yy3387 := &x.ObjectMeta + yy3387.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3388[2] { + if yyq3379[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3397 := &x.ObjectMeta - yy3397.CodecEncodeSelf(e) + yy3388 := &x.ObjectMeta + yy3388.CodecEncodeSelf(e) } } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3388[3] { - yy3399 := &x.Spec - yy3399.CodecEncodeSelf(e) + if yyq3379[3] { + yy3390 := &x.Spec + yy3390.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3388[3] { + if yyq3379[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3400 := &x.Spec - yy3400.CodecEncodeSelf(e) + yy3391 := &x.Spec + yy3391.CodecEncodeSelf(e) } } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3388[4] { - yy3402 := &x.Status - yy3402.CodecEncodeSelf(e) + if yyq3379[4] { + yy3393 := &x.Status + yy3393.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3388[4] { + if yyq3379[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3403 := &x.Status - yy3403.CodecEncodeSelf(e) + yy3394 := &x.Status + yy3394.CodecEncodeSelf(e) } } - if yyr3388 || yy2arr3388 { + if yyr3379 || yy2arr3379 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43321,25 +43239,25 @@ func (x *Namespace) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3404 := z.DecBinary() - _ = yym3404 + yym3395 := z.DecBinary() + _ = yym3395 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3405 := r.ContainerType() - if yyct3405 == codecSelferValueTypeMap1234 { - yyl3405 := r.ReadMapStart() - if yyl3405 == 0 { + yyct3396 := r.ContainerType() + if yyct3396 == codecSelferValueTypeMap1234 { + yyl3396 := r.ReadMapStart() + if yyl3396 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3405, d) + x.codecDecodeSelfFromMap(yyl3396, d) } - } else if yyct3405 == codecSelferValueTypeArray1234 { - yyl3405 := r.ReadArrayStart() - if yyl3405 == 0 { + } else if yyct3396 == codecSelferValueTypeArray1234 { + yyl3396 := r.ReadArrayStart() + if yyl3396 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3405, d) + x.codecDecodeSelfFromArray(yyl3396, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43351,12 +43269,12 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3406Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3406Slc - var yyhl3406 bool = l >= 0 - for yyj3406 := 0; ; yyj3406++ { - if yyhl3406 { - if yyj3406 >= l { + var yys3397Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3397Slc + var yyhl3397 bool = l >= 0 + for yyj3397 := 0; ; yyj3397++ { + if yyhl3397 { + if yyj3397 >= l { break } } else { @@ -43365,10 +43283,10 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3406Slc = r.DecodeBytes(yys3406Slc, true, true) - yys3406 := string(yys3406Slc) + yys3397Slc = r.DecodeBytes(yys3397Slc, true, true) + yys3397 := string(yys3397Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3406 { + switch yys3397 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -43385,27 +43303,27 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3409 := &x.ObjectMeta - yyv3409.CodecDecodeSelf(d) + yyv3400 := &x.ObjectMeta + yyv3400.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NamespaceSpec{} } else { - yyv3410 := &x.Spec - yyv3410.CodecDecodeSelf(d) + yyv3401 := &x.Spec + yyv3401.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = NamespaceStatus{} } else { - yyv3411 := &x.Status - yyv3411.CodecDecodeSelf(d) + yyv3402 := &x.Status + yyv3402.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3406) - } // end switch yys3406 - } // end for yyj3406 + z.DecStructFieldNotFound(-1, yys3397) + } // end switch yys3397 + } // end for yyj3397 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43413,16 +43331,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3412 int - var yyb3412 bool - var yyhl3412 bool = l >= 0 - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + var yyj3403 int + var yyb3403 bool + var yyhl3403 bool = l >= 0 + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43432,13 +43350,13 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43448,13 +43366,13 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43462,16 +43380,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3415 := &x.ObjectMeta - yyv3415.CodecDecodeSelf(d) + yyv3406 := &x.ObjectMeta + yyv3406.CodecDecodeSelf(d) } - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43479,16 +43397,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NamespaceSpec{} } else { - yyv3416 := &x.Spec - yyv3416.CodecDecodeSelf(d) + yyv3407 := &x.Spec + yyv3407.CodecDecodeSelf(d) } - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43496,21 +43414,21 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = NamespaceStatus{} } else { - yyv3417 := &x.Status - yyv3417.CodecDecodeSelf(d) + yyv3408 := &x.Status + yyv3408.CodecDecodeSelf(d) } for { - yyj3412++ - if yyhl3412 { - yyb3412 = yyj3412 > l + yyj3403++ + if yyhl3403 { + yyb3403 = yyj3403 > l } else { - yyb3412 = r.CheckBreak() + yyb3403 = r.CheckBreak() } - if yyb3412 { + if yyb3403 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3412-1, "") + z.DecStructFieldNotFound(yyj3403-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43522,37 +43440,37 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3418 := z.EncBinary() - _ = yym3418 + yym3409 := z.EncBinary() + _ = yym3409 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3419 := !z.EncBinary() - yy2arr3419 := z.EncBasicHandle().StructToArray - var yyq3419 [4]bool - _, _, _ = yysep3419, yyq3419, yy2arr3419 - const yyr3419 bool = false - yyq3419[0] = x.Kind != "" - yyq3419[1] = x.APIVersion != "" - yyq3419[2] = true - var yynn3419 int - if yyr3419 || yy2arr3419 { + yysep3410 := !z.EncBinary() + yy2arr3410 := z.EncBasicHandle().StructToArray + var yyq3410 [4]bool + _, _, _ = yysep3410, yyq3410, yy2arr3410 + const yyr3410 bool = false + yyq3410[0] = x.Kind != "" + yyq3410[1] = x.APIVersion != "" + yyq3410[2] = true + var yynn3410 int + if yyr3410 || yy2arr3410 { r.EncodeArrayStart(4) } else { - yynn3419 = 1 - for _, b := range yyq3419 { + yynn3410 = 1 + for _, b := range yyq3410 { if b { - yynn3419++ + yynn3410++ } } - r.EncodeMapStart(yynn3419) - yynn3419 = 0 + r.EncodeMapStart(yynn3410) + yynn3410 = 0 } - if yyr3419 || yy2arr3419 { + if yyr3410 || yy2arr3410 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3419[0] { - yym3421 := z.EncBinary() - _ = yym3421 + if yyq3410[0] { + yym3412 := z.EncBinary() + _ = yym3412 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -43561,23 +43479,23 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3419[0] { + if yyq3410[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3422 := z.EncBinary() - _ = yym3422 + yym3413 := z.EncBinary() + _ = yym3413 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3419 || yy2arr3419 { + if yyr3410 || yy2arr3410 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3419[1] { - yym3424 := z.EncBinary() - _ = yym3424 + if yyq3410[1] { + yym3415 := z.EncBinary() + _ = yym3415 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -43586,54 +43504,54 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3419[1] { + if yyq3410[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3425 := z.EncBinary() - _ = yym3425 + yym3416 := z.EncBinary() + _ = yym3416 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3419 || yy2arr3419 { + if yyr3410 || yy2arr3410 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3419[2] { - yy3427 := &x.ListMeta - yym3428 := z.EncBinary() - _ = yym3428 + if yyq3410[2] { + yy3418 := &x.ListMeta + yym3419 := z.EncBinary() + _ = yym3419 if false { - } else if z.HasExtensions() && z.EncExt(yy3427) { + } else if z.HasExtensions() && z.EncExt(yy3418) { } else { - z.EncFallback(yy3427) + z.EncFallback(yy3418) } } else { r.EncodeNil() } } else { - if yyq3419[2] { + if yyq3410[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3429 := &x.ListMeta - yym3430 := z.EncBinary() - _ = yym3430 + yy3420 := &x.ListMeta + yym3421 := z.EncBinary() + _ = yym3421 if false { - } else if z.HasExtensions() && z.EncExt(yy3429) { + } else if z.HasExtensions() && z.EncExt(yy3420) { } else { - z.EncFallback(yy3429) + z.EncFallback(yy3420) } } } - if yyr3419 || yy2arr3419 { + if yyr3410 || yy2arr3410 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym3432 := z.EncBinary() - _ = yym3432 + yym3423 := z.EncBinary() + _ = yym3423 if false { } else { h.encSliceNamespace(([]Namespace)(x.Items), e) @@ -43646,15 +43564,15 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym3433 := z.EncBinary() - _ = yym3433 + yym3424 := z.EncBinary() + _ = yym3424 if false { } else { h.encSliceNamespace(([]Namespace)(x.Items), e) } } } - if yyr3419 || yy2arr3419 { + if yyr3410 || yy2arr3410 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43667,25 +43585,25 @@ func (x *NamespaceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3434 := z.DecBinary() - _ = yym3434 + yym3425 := z.DecBinary() + _ = yym3425 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3435 := r.ContainerType() - if yyct3435 == codecSelferValueTypeMap1234 { - yyl3435 := r.ReadMapStart() - if yyl3435 == 0 { + yyct3426 := r.ContainerType() + if yyct3426 == codecSelferValueTypeMap1234 { + yyl3426 := r.ReadMapStart() + if yyl3426 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3435, d) + x.codecDecodeSelfFromMap(yyl3426, d) } - } else if yyct3435 == codecSelferValueTypeArray1234 { - yyl3435 := r.ReadArrayStart() - if yyl3435 == 0 { + } else if yyct3426 == codecSelferValueTypeArray1234 { + yyl3426 := r.ReadArrayStart() + if yyl3426 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3435, d) + x.codecDecodeSelfFromArray(yyl3426, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43697,12 +43615,12 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3436Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3436Slc - var yyhl3436 bool = l >= 0 - for yyj3436 := 0; ; yyj3436++ { - if yyhl3436 { - if yyj3436 >= l { + var yys3427Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3427Slc + var yyhl3427 bool = l >= 0 + for yyj3427 := 0; ; yyj3427++ { + if yyhl3427 { + if yyj3427 >= l { break } } else { @@ -43711,10 +43629,10 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3436Slc = r.DecodeBytes(yys3436Slc, true, true) - yys3436 := string(yys3436Slc) + yys3427Slc = r.DecodeBytes(yys3427Slc, true, true) + yys3427 := string(yys3427Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3436 { + switch yys3427 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -43731,31 +43649,31 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3439 := &x.ListMeta - yym3440 := z.DecBinary() - _ = yym3440 + yyv3430 := &x.ListMeta + yym3431 := z.DecBinary() + _ = yym3431 if false { - } else if z.HasExtensions() && z.DecExt(yyv3439) { + } else if z.HasExtensions() && z.DecExt(yyv3430) { } else { - z.DecFallback(yyv3439, false) + z.DecFallback(yyv3430, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3441 := &x.Items - yym3442 := z.DecBinary() - _ = yym3442 + yyv3432 := &x.Items + yym3433 := z.DecBinary() + _ = yym3433 if false { } else { - h.decSliceNamespace((*[]Namespace)(yyv3441), d) + h.decSliceNamespace((*[]Namespace)(yyv3432), d) } } default: - z.DecStructFieldNotFound(-1, yys3436) - } // end switch yys3436 - } // end for yyj3436 + z.DecStructFieldNotFound(-1, yys3427) + } // end switch yys3427 + } // end for yyj3427 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43763,16 +43681,16 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3443 int - var yyb3443 bool - var yyhl3443 bool = l >= 0 - yyj3443++ - if yyhl3443 { - yyb3443 = yyj3443 > l + var yyj3434 int + var yyb3434 bool + var yyhl3434 bool = l >= 0 + yyj3434++ + if yyhl3434 { + yyb3434 = yyj3434 > l } else { - yyb3443 = r.CheckBreak() + yyb3434 = r.CheckBreak() } - if yyb3443 { + if yyb3434 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43782,13 +43700,13 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3443++ - if yyhl3443 { - yyb3443 = yyj3443 > l + yyj3434++ + if yyhl3434 { + yyb3434 = yyj3434 > l } else { - yyb3443 = r.CheckBreak() + yyb3434 = r.CheckBreak() } - if yyb3443 { + if yyb3434 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43798,13 +43716,13 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3443++ - if yyhl3443 { - yyb3443 = yyj3443 > l + yyj3434++ + if yyhl3434 { + yyb3434 = yyj3434 > l } else { - yyb3443 = r.CheckBreak() + yyb3434 = r.CheckBreak() } - if yyb3443 { + if yyb3434 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43812,22 +43730,22 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3446 := &x.ListMeta - yym3447 := z.DecBinary() - _ = yym3447 + yyv3437 := &x.ListMeta + yym3438 := z.DecBinary() + _ = yym3438 if false { - } else if z.HasExtensions() && z.DecExt(yyv3446) { + } else if z.HasExtensions() && z.DecExt(yyv3437) { } else { - z.DecFallback(yyv3446, false) + z.DecFallback(yyv3437, false) } } - yyj3443++ - if yyhl3443 { - yyb3443 = yyj3443 > l + yyj3434++ + if yyhl3434 { + yyb3434 = yyj3434 > l } else { - yyb3443 = r.CheckBreak() + yyb3434 = r.CheckBreak() } - if yyb3443 { + if yyb3434 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43835,26 +43753,26 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3448 := &x.Items - yym3449 := z.DecBinary() - _ = yym3449 + yyv3439 := &x.Items + yym3440 := z.DecBinary() + _ = yym3440 if false { } else { - h.decSliceNamespace((*[]Namespace)(yyv3448), d) + h.decSliceNamespace((*[]Namespace)(yyv3439), d) } } for { - yyj3443++ - if yyhl3443 { - yyb3443 = yyj3443 > l + yyj3434++ + if yyhl3434 { + yyb3434 = yyj3434 > l } else { - yyb3443 = r.CheckBreak() + yyb3434 = r.CheckBreak() } - if yyb3443 { + if yyb3434 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3443-1, "") + z.DecStructFieldNotFound(yyj3434-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43866,37 +43784,37 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3450 := z.EncBinary() - _ = yym3450 + yym3441 := z.EncBinary() + _ = yym3441 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3451 := !z.EncBinary() - yy2arr3451 := z.EncBasicHandle().StructToArray - var yyq3451 [4]bool - _, _, _ = yysep3451, yyq3451, yy2arr3451 - const yyr3451 bool = false - yyq3451[0] = x.Kind != "" - yyq3451[1] = x.APIVersion != "" - yyq3451[2] = true - var yynn3451 int - if yyr3451 || yy2arr3451 { + yysep3442 := !z.EncBinary() + yy2arr3442 := z.EncBasicHandle().StructToArray + var yyq3442 [4]bool + _, _, _ = yysep3442, yyq3442, yy2arr3442 + const yyr3442 bool = false + yyq3442[0] = x.Kind != "" + yyq3442[1] = x.APIVersion != "" + yyq3442[2] = true + var yynn3442 int + if yyr3442 || yy2arr3442 { r.EncodeArrayStart(4) } else { - yynn3451 = 1 - for _, b := range yyq3451 { + yynn3442 = 1 + for _, b := range yyq3442 { if b { - yynn3451++ + yynn3442++ } } - r.EncodeMapStart(yynn3451) - yynn3451 = 0 + r.EncodeMapStart(yynn3442) + yynn3442 = 0 } - if yyr3451 || yy2arr3451 { + if yyr3442 || yy2arr3442 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3451[0] { - yym3453 := z.EncBinary() - _ = yym3453 + if yyq3442[0] { + yym3444 := z.EncBinary() + _ = yym3444 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -43905,23 +43823,23 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3451[0] { + if yyq3442[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3454 := z.EncBinary() - _ = yym3454 + yym3445 := z.EncBinary() + _ = yym3445 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3451 || yy2arr3451 { + if yyr3442 || yy2arr3442 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3451[1] { - yym3456 := z.EncBinary() - _ = yym3456 + if yyq3442[1] { + yym3447 := z.EncBinary() + _ = yym3447 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -43930,47 +43848,47 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3451[1] { + if yyq3442[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3457 := z.EncBinary() - _ = yym3457 + yym3448 := z.EncBinary() + _ = yym3448 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3451 || yy2arr3451 { + if yyr3442 || yy2arr3442 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3451[2] { - yy3459 := &x.ObjectMeta - yy3459.CodecEncodeSelf(e) + if yyq3442[2] { + yy3450 := &x.ObjectMeta + yy3450.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3451[2] { + if yyq3442[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3460 := &x.ObjectMeta - yy3460.CodecEncodeSelf(e) + yy3451 := &x.ObjectMeta + yy3451.CodecEncodeSelf(e) } } - if yyr3451 || yy2arr3451 { + if yyr3442 || yy2arr3442 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3462 := &x.Target - yy3462.CodecEncodeSelf(e) + yy3453 := &x.Target + yy3453.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("target")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3463 := &x.Target - yy3463.CodecEncodeSelf(e) + yy3454 := &x.Target + yy3454.CodecEncodeSelf(e) } - if yyr3451 || yy2arr3451 { + if yyr3442 || yy2arr3442 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43983,25 +43901,25 @@ func (x *Binding) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3464 := z.DecBinary() - _ = yym3464 + yym3455 := z.DecBinary() + _ = yym3455 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3465 := r.ContainerType() - if yyct3465 == codecSelferValueTypeMap1234 { - yyl3465 := r.ReadMapStart() - if yyl3465 == 0 { + yyct3456 := r.ContainerType() + if yyct3456 == codecSelferValueTypeMap1234 { + yyl3456 := r.ReadMapStart() + if yyl3456 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3465, d) + x.codecDecodeSelfFromMap(yyl3456, d) } - } else if yyct3465 == codecSelferValueTypeArray1234 { - yyl3465 := r.ReadArrayStart() - if yyl3465 == 0 { + } else if yyct3456 == codecSelferValueTypeArray1234 { + yyl3456 := r.ReadArrayStart() + if yyl3456 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3465, d) + x.codecDecodeSelfFromArray(yyl3456, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44013,12 +43931,12 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3466Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3466Slc - var yyhl3466 bool = l >= 0 - for yyj3466 := 0; ; yyj3466++ { - if yyhl3466 { - if yyj3466 >= l { + var yys3457Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3457Slc + var yyhl3457 bool = l >= 0 + for yyj3457 := 0; ; yyj3457++ { + if yyhl3457 { + if yyj3457 >= l { break } } else { @@ -44027,10 +43945,10 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3466Slc = r.DecodeBytes(yys3466Slc, true, true) - yys3466 := string(yys3466Slc) + yys3457Slc = r.DecodeBytes(yys3457Slc, true, true) + yys3457 := string(yys3457Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3466 { + switch yys3457 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -44047,20 +43965,20 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3469 := &x.ObjectMeta - yyv3469.CodecDecodeSelf(d) + yyv3460 := &x.ObjectMeta + yyv3460.CodecDecodeSelf(d) } case "target": if r.TryDecodeAsNil() { x.Target = ObjectReference{} } else { - yyv3470 := &x.Target - yyv3470.CodecDecodeSelf(d) + yyv3461 := &x.Target + yyv3461.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3466) - } // end switch yys3466 - } // end for yyj3466 + z.DecStructFieldNotFound(-1, yys3457) + } // end switch yys3457 + } // end for yyj3457 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -44068,16 +43986,16 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3471 int - var yyb3471 bool - var yyhl3471 bool = l >= 0 - yyj3471++ - if yyhl3471 { - yyb3471 = yyj3471 > l + var yyj3462 int + var yyb3462 bool + var yyhl3462 bool = l >= 0 + yyj3462++ + if yyhl3462 { + yyb3462 = yyj3462 > l } else { - yyb3471 = r.CheckBreak() + yyb3462 = r.CheckBreak() } - if yyb3471 { + if yyb3462 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44087,13 +44005,13 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3471++ - if yyhl3471 { - yyb3471 = yyj3471 > l + yyj3462++ + if yyhl3462 { + yyb3462 = yyj3462 > l } else { - yyb3471 = r.CheckBreak() + yyb3462 = r.CheckBreak() } - if yyb3471 { + if yyb3462 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44103,13 +44021,13 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3471++ - if yyhl3471 { - yyb3471 = yyj3471 > l + yyj3462++ + if yyhl3462 { + yyb3462 = yyj3462 > l } else { - yyb3471 = r.CheckBreak() + yyb3462 = r.CheckBreak() } - if yyb3471 { + if yyb3462 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44117,16 +44035,16 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3474 := &x.ObjectMeta - yyv3474.CodecDecodeSelf(d) + yyv3465 := &x.ObjectMeta + yyv3465.CodecDecodeSelf(d) } - yyj3471++ - if yyhl3471 { - yyb3471 = yyj3471 > l + yyj3462++ + if yyhl3462 { + yyb3462 = yyj3462 > l } else { - yyb3471 = r.CheckBreak() + yyb3462 = r.CheckBreak() } - if yyb3471 { + if yyb3462 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44134,21 +44052,21 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Target = ObjectReference{} } else { - yyv3475 := &x.Target - yyv3475.CodecDecodeSelf(d) + yyv3466 := &x.Target + yyv3466.CodecDecodeSelf(d) } for { - yyj3471++ - if yyhl3471 { - yyb3471 = yyj3471 > l + yyj3462++ + if yyhl3462 { + yyb3462 = yyj3462 > l } else { - yyb3471 = r.CheckBreak() + yyb3462 = r.CheckBreak() } - if yyb3471 { + if yyb3462 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3471-1, "") + z.DecStructFieldNotFound(yyj3462-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44160,68 +44078,68 @@ func (x *Preconditions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3476 := z.EncBinary() - _ = yym3476 + yym3467 := z.EncBinary() + _ = yym3467 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3477 := !z.EncBinary() - yy2arr3477 := z.EncBasicHandle().StructToArray - var yyq3477 [1]bool - _, _, _ = yysep3477, yyq3477, yy2arr3477 - const yyr3477 bool = false - yyq3477[0] = x.UID != nil - var yynn3477 int - if yyr3477 || yy2arr3477 { + yysep3468 := !z.EncBinary() + yy2arr3468 := z.EncBasicHandle().StructToArray + var yyq3468 [1]bool + _, _, _ = yysep3468, yyq3468, yy2arr3468 + const yyr3468 bool = false + yyq3468[0] = x.UID != nil + var yynn3468 int + if yyr3468 || yy2arr3468 { r.EncodeArrayStart(1) } else { - yynn3477 = 0 - for _, b := range yyq3477 { + yynn3468 = 0 + for _, b := range yyq3468 { if b { - yynn3477++ + yynn3468++ } } - r.EncodeMapStart(yynn3477) - yynn3477 = 0 + r.EncodeMapStart(yynn3468) + yynn3468 = 0 } - if yyr3477 || yy2arr3477 { + if yyr3468 || yy2arr3468 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3477[0] { + if yyq3468[0] { if x.UID == nil { r.EncodeNil() } else { - yy3479 := *x.UID - yym3480 := z.EncBinary() - _ = yym3480 + yy3470 := *x.UID + yym3471 := z.EncBinary() + _ = yym3471 if false { - } else if z.HasExtensions() && z.EncExt(yy3479) { + } else if z.HasExtensions() && z.EncExt(yy3470) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy3479)) + r.EncodeString(codecSelferC_UTF81234, string(yy3470)) } } } else { r.EncodeNil() } } else { - if yyq3477[0] { + if yyq3468[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("uid")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.UID == nil { r.EncodeNil() } else { - yy3481 := *x.UID - yym3482 := z.EncBinary() - _ = yym3482 + yy3472 := *x.UID + yym3473 := z.EncBinary() + _ = yym3473 if false { - } else if z.HasExtensions() && z.EncExt(yy3481) { + } else if z.HasExtensions() && z.EncExt(yy3472) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy3481)) + r.EncodeString(codecSelferC_UTF81234, string(yy3472)) } } } } - if yyr3477 || yy2arr3477 { + if yyr3468 || yy2arr3468 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -44234,25 +44152,25 @@ func (x *Preconditions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3483 := z.DecBinary() - _ = yym3483 + yym3474 := z.DecBinary() + _ = yym3474 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3484 := r.ContainerType() - if yyct3484 == codecSelferValueTypeMap1234 { - yyl3484 := r.ReadMapStart() - if yyl3484 == 0 { + yyct3475 := r.ContainerType() + if yyct3475 == codecSelferValueTypeMap1234 { + yyl3475 := r.ReadMapStart() + if yyl3475 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3484, d) + x.codecDecodeSelfFromMap(yyl3475, d) } - } else if yyct3484 == codecSelferValueTypeArray1234 { - yyl3484 := r.ReadArrayStart() - if yyl3484 == 0 { + } else if yyct3475 == codecSelferValueTypeArray1234 { + yyl3475 := r.ReadArrayStart() + if yyl3475 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3484, d) + x.codecDecodeSelfFromArray(yyl3475, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44264,12 +44182,12 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3485Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3485Slc - var yyhl3485 bool = l >= 0 - for yyj3485 := 0; ; yyj3485++ { - if yyhl3485 { - if yyj3485 >= l { + var yys3476Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3476Slc + var yyhl3476 bool = l >= 0 + for yyj3476 := 0; ; yyj3476++ { + if yyhl3476 { + if yyj3476 >= l { break } } else { @@ -44278,10 +44196,10 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3485Slc = r.DecodeBytes(yys3485Slc, true, true) - yys3485 := string(yys3485Slc) + yys3476Slc = r.DecodeBytes(yys3476Slc, true, true) + yys3476 := string(yys3476Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3485 { + switch yys3476 { case "uid": if r.TryDecodeAsNil() { if x.UID != nil { @@ -44291,8 +44209,8 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.UID == nil { x.UID = new(pkg1_types.UID) } - yym3487 := z.DecBinary() - _ = yym3487 + yym3478 := z.DecBinary() + _ = yym3478 if false { } else if z.HasExtensions() && z.DecExt(x.UID) { } else { @@ -44300,9 +44218,9 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } default: - z.DecStructFieldNotFound(-1, yys3485) - } // end switch yys3485 - } // end for yyj3485 + z.DecStructFieldNotFound(-1, yys3476) + } // end switch yys3476 + } // end for yyj3476 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -44310,16 +44228,16 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3488 int - var yyb3488 bool - var yyhl3488 bool = l >= 0 - yyj3488++ - if yyhl3488 { - yyb3488 = yyj3488 > l + var yyj3479 int + var yyb3479 bool + var yyhl3479 bool = l >= 0 + yyj3479++ + if yyhl3479 { + yyb3479 = yyj3479 > l } else { - yyb3488 = r.CheckBreak() + yyb3479 = r.CheckBreak() } - if yyb3488 { + if yyb3479 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44332,8 +44250,8 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.UID == nil { x.UID = new(pkg1_types.UID) } - yym3490 := z.DecBinary() - _ = yym3490 + yym3481 := z.DecBinary() + _ = yym3481 if false { } else if z.HasExtensions() && z.DecExt(x.UID) { } else { @@ -44341,17 +44259,17 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } for { - yyj3488++ - if yyhl3488 { - yyb3488 = yyj3488 > l + yyj3479++ + if yyhl3479 { + yyb3479 = yyj3479 > l } else { - yyb3488 = r.CheckBreak() + yyb3479 = r.CheckBreak() } - if yyb3488 { + if yyb3479 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3488-1, "") + z.DecStructFieldNotFound(yyj3479-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44363,39 +44281,39 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3491 := z.EncBinary() - _ = yym3491 + yym3482 := z.EncBinary() + _ = yym3482 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3492 := !z.EncBinary() - yy2arr3492 := z.EncBasicHandle().StructToArray - var yyq3492 [5]bool - _, _, _ = yysep3492, yyq3492, yy2arr3492 - const yyr3492 bool = false - yyq3492[0] = x.Kind != "" - yyq3492[1] = x.APIVersion != "" - yyq3492[2] = x.GracePeriodSeconds != nil - yyq3492[3] = x.Preconditions != nil - yyq3492[4] = x.OrphanDependents != nil - var yynn3492 int - if yyr3492 || yy2arr3492 { + yysep3483 := !z.EncBinary() + yy2arr3483 := z.EncBasicHandle().StructToArray + var yyq3483 [5]bool + _, _, _ = yysep3483, yyq3483, yy2arr3483 + const yyr3483 bool = false + yyq3483[0] = x.Kind != "" + yyq3483[1] = x.APIVersion != "" + yyq3483[2] = x.GracePeriodSeconds != nil + yyq3483[3] = x.Preconditions != nil + yyq3483[4] = x.OrphanDependents != nil + var yynn3483 int + if yyr3483 || yy2arr3483 { r.EncodeArrayStart(5) } else { - yynn3492 = 0 - for _, b := range yyq3492 { + yynn3483 = 0 + for _, b := range yyq3483 { if b { - yynn3492++ + yynn3483++ } } - r.EncodeMapStart(yynn3492) - yynn3492 = 0 + r.EncodeMapStart(yynn3483) + yynn3483 = 0 } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3492[0] { - yym3494 := z.EncBinary() - _ = yym3494 + if yyq3483[0] { + yym3485 := z.EncBinary() + _ = yym3485 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -44404,23 +44322,23 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3492[0] { + if yyq3483[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3495 := z.EncBinary() - _ = yym3495 + yym3486 := z.EncBinary() + _ = yym3486 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3492[1] { - yym3497 := z.EncBinary() - _ = yym3497 + if yyq3483[1] { + yym3488 := z.EncBinary() + _ = yym3488 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -44429,56 +44347,56 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3492[1] { + if yyq3483[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3498 := z.EncBinary() - _ = yym3498 + yym3489 := z.EncBinary() + _ = yym3489 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3492[2] { + if yyq3483[2] { if x.GracePeriodSeconds == nil { r.EncodeNil() } else { - yy3500 := *x.GracePeriodSeconds - yym3501 := z.EncBinary() - _ = yym3501 + yy3491 := *x.GracePeriodSeconds + yym3492 := z.EncBinary() + _ = yym3492 if false { } else { - r.EncodeInt(int64(yy3500)) + r.EncodeInt(int64(yy3491)) } } } else { r.EncodeNil() } } else { - if yyq3492[2] { + if yyq3483[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("gracePeriodSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.GracePeriodSeconds == nil { r.EncodeNil() } else { - yy3502 := *x.GracePeriodSeconds - yym3503 := z.EncBinary() - _ = yym3503 + yy3493 := *x.GracePeriodSeconds + yym3494 := z.EncBinary() + _ = yym3494 if false { } else { - r.EncodeInt(int64(yy3502)) + r.EncodeInt(int64(yy3493)) } } } } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3492[3] { + if yyq3483[3] { if x.Preconditions == nil { r.EncodeNil() } else { @@ -44488,7 +44406,7 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3492[3] { + if yyq3483[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("preconditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -44499,42 +44417,42 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3492[4] { + if yyq3483[4] { if x.OrphanDependents == nil { r.EncodeNil() } else { - yy3506 := *x.OrphanDependents - yym3507 := z.EncBinary() - _ = yym3507 + yy3497 := *x.OrphanDependents + yym3498 := z.EncBinary() + _ = yym3498 if false { } else { - r.EncodeBool(bool(yy3506)) + r.EncodeBool(bool(yy3497)) } } } else { r.EncodeNil() } } else { - if yyq3492[4] { + if yyq3483[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("orphanDependents")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.OrphanDependents == nil { r.EncodeNil() } else { - yy3508 := *x.OrphanDependents - yym3509 := z.EncBinary() - _ = yym3509 + yy3499 := *x.OrphanDependents + yym3500 := z.EncBinary() + _ = yym3500 if false { } else { - r.EncodeBool(bool(yy3508)) + r.EncodeBool(bool(yy3499)) } } } } - if yyr3492 || yy2arr3492 { + if yyr3483 || yy2arr3483 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -44547,25 +44465,25 @@ func (x *DeleteOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3510 := z.DecBinary() - _ = yym3510 + yym3501 := z.DecBinary() + _ = yym3501 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3511 := r.ContainerType() - if yyct3511 == codecSelferValueTypeMap1234 { - yyl3511 := r.ReadMapStart() - if yyl3511 == 0 { + yyct3502 := r.ContainerType() + if yyct3502 == codecSelferValueTypeMap1234 { + yyl3502 := r.ReadMapStart() + if yyl3502 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3511, d) + x.codecDecodeSelfFromMap(yyl3502, d) } - } else if yyct3511 == codecSelferValueTypeArray1234 { - yyl3511 := r.ReadArrayStart() - if yyl3511 == 0 { + } else if yyct3502 == codecSelferValueTypeArray1234 { + yyl3502 := r.ReadArrayStart() + if yyl3502 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3511, d) + x.codecDecodeSelfFromArray(yyl3502, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44577,12 +44495,12 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3512Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3512Slc - var yyhl3512 bool = l >= 0 - for yyj3512 := 0; ; yyj3512++ { - if yyhl3512 { - if yyj3512 >= l { + var yys3503Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3503Slc + var yyhl3503 bool = l >= 0 + for yyj3503 := 0; ; yyj3503++ { + if yyhl3503 { + if yyj3503 >= l { break } } else { @@ -44591,10 +44509,10 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3512Slc = r.DecodeBytes(yys3512Slc, true, true) - yys3512 := string(yys3512Slc) + yys3503Slc = r.DecodeBytes(yys3503Slc, true, true) + yys3503 := string(yys3503Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3512 { + switch yys3503 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -44616,8 +44534,8 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.GracePeriodSeconds == nil { x.GracePeriodSeconds = new(int64) } - yym3516 := z.DecBinary() - _ = yym3516 + yym3507 := z.DecBinary() + _ = yym3507 if false { } else { *((*int64)(x.GracePeriodSeconds)) = int64(r.DecodeInt(64)) @@ -44643,17 +44561,17 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.OrphanDependents == nil { x.OrphanDependents = new(bool) } - yym3519 := z.DecBinary() - _ = yym3519 + yym3510 := z.DecBinary() + _ = yym3510 if false { } else { *((*bool)(x.OrphanDependents)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys3512) - } // end switch yys3512 - } // end for yyj3512 + z.DecStructFieldNotFound(-1, yys3503) + } // end switch yys3503 + } // end for yyj3503 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -44661,16 +44579,16 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3520 int - var yyb3520 bool - var yyhl3520 bool = l >= 0 - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + var yyj3511 int + var yyb3511 bool + var yyhl3511 bool = l >= 0 + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44680,13 +44598,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44696,13 +44614,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44715,20 +44633,20 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.GracePeriodSeconds == nil { x.GracePeriodSeconds = new(int64) } - yym3524 := z.DecBinary() - _ = yym3524 + yym3515 := z.DecBinary() + _ = yym3515 if false { } else { *((*int64)(x.GracePeriodSeconds)) = int64(r.DecodeInt(64)) } } - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44743,13 +44661,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } x.Preconditions.CodecDecodeSelf(d) } - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44762,25 +44680,25 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.OrphanDependents == nil { x.OrphanDependents = new(bool) } - yym3527 := z.DecBinary() - _ = yym3527 + yym3518 := z.DecBinary() + _ = yym3518 if false { } else { *((*bool)(x.OrphanDependents)) = r.DecodeBool() } } for { - yyj3520++ - if yyhl3520 { - yyb3520 = yyj3520 > l + yyj3511++ + if yyhl3511 { + yyb3511 = yyj3511 > l } else { - yyb3520 = r.CheckBreak() + yyb3511 = r.CheckBreak() } - if yyb3520 { + if yyb3511 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3520-1, "") + z.DecStructFieldNotFound(yyj3511-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44792,36 +44710,36 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3528 := z.EncBinary() - _ = yym3528 + yym3519 := z.EncBinary() + _ = yym3519 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3529 := !z.EncBinary() - yy2arr3529 := z.EncBasicHandle().StructToArray - var yyq3529 [4]bool - _, _, _ = yysep3529, yyq3529, yy2arr3529 - const yyr3529 bool = false - yyq3529[0] = x.Kind != "" - yyq3529[1] = x.APIVersion != "" - var yynn3529 int - if yyr3529 || yy2arr3529 { + yysep3520 := !z.EncBinary() + yy2arr3520 := z.EncBasicHandle().StructToArray + var yyq3520 [4]bool + _, _, _ = yysep3520, yyq3520, yy2arr3520 + const yyr3520 bool = false + yyq3520[0] = x.Kind != "" + yyq3520[1] = x.APIVersion != "" + var yynn3520 int + if yyr3520 || yy2arr3520 { r.EncodeArrayStart(4) } else { - yynn3529 = 2 - for _, b := range yyq3529 { + yynn3520 = 2 + for _, b := range yyq3520 { if b { - yynn3529++ + yynn3520++ } } - r.EncodeMapStart(yynn3529) - yynn3529 = 0 + r.EncodeMapStart(yynn3520) + yynn3520 = 0 } - if yyr3529 || yy2arr3529 { + if yyr3520 || yy2arr3520 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3529[0] { - yym3531 := z.EncBinary() - _ = yym3531 + if yyq3520[0] { + yym3522 := z.EncBinary() + _ = yym3522 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -44830,23 +44748,23 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3529[0] { + if yyq3520[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3532 := z.EncBinary() - _ = yym3532 + yym3523 := z.EncBinary() + _ = yym3523 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3529 || yy2arr3529 { + if yyr3520 || yy2arr3520 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3529[1] { - yym3534 := z.EncBinary() - _ = yym3534 + if yyq3520[1] { + yym3525 := z.EncBinary() + _ = yym3525 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -44855,22 +44773,22 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3529[1] { + if yyq3520[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3535 := z.EncBinary() - _ = yym3535 + yym3526 := z.EncBinary() + _ = yym3526 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3529 || yy2arr3529 { + if yyr3520 || yy2arr3520 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3537 := z.EncBinary() - _ = yym3537 + yym3528 := z.EncBinary() + _ = yym3528 if false { } else { r.EncodeBool(bool(x.Export)) @@ -44879,17 +44797,17 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("export")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3538 := z.EncBinary() - _ = yym3538 + yym3529 := z.EncBinary() + _ = yym3529 if false { } else { r.EncodeBool(bool(x.Export)) } } - if yyr3529 || yy2arr3529 { + if yyr3520 || yy2arr3520 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3540 := z.EncBinary() - _ = yym3540 + yym3531 := z.EncBinary() + _ = yym3531 if false { } else { r.EncodeBool(bool(x.Exact)) @@ -44898,14 +44816,14 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("exact")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3541 := z.EncBinary() - _ = yym3541 + yym3532 := z.EncBinary() + _ = yym3532 if false { } else { r.EncodeBool(bool(x.Exact)) } } - if yyr3529 || yy2arr3529 { + if yyr3520 || yy2arr3520 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -44918,25 +44836,25 @@ func (x *ExportOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3542 := z.DecBinary() - _ = yym3542 + yym3533 := z.DecBinary() + _ = yym3533 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3543 := r.ContainerType() - if yyct3543 == codecSelferValueTypeMap1234 { - yyl3543 := r.ReadMapStart() - if yyl3543 == 0 { + yyct3534 := r.ContainerType() + if yyct3534 == codecSelferValueTypeMap1234 { + yyl3534 := r.ReadMapStart() + if yyl3534 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3543, d) + x.codecDecodeSelfFromMap(yyl3534, d) } - } else if yyct3543 == codecSelferValueTypeArray1234 { - yyl3543 := r.ReadArrayStart() - if yyl3543 == 0 { + } else if yyct3534 == codecSelferValueTypeArray1234 { + yyl3534 := r.ReadArrayStart() + if yyl3534 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3543, d) + x.codecDecodeSelfFromArray(yyl3534, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44948,12 +44866,12 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3544Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3544Slc - var yyhl3544 bool = l >= 0 - for yyj3544 := 0; ; yyj3544++ { - if yyhl3544 { - if yyj3544 >= l { + var yys3535Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3535Slc + var yyhl3535 bool = l >= 0 + for yyj3535 := 0; ; yyj3535++ { + if yyhl3535 { + if yyj3535 >= l { break } } else { @@ -44962,10 +44880,10 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3544Slc = r.DecodeBytes(yys3544Slc, true, true) - yys3544 := string(yys3544Slc) + yys3535Slc = r.DecodeBytes(yys3535Slc, true, true) + yys3535 := string(yys3535Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3544 { + switch yys3535 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -44991,9 +44909,9 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Exact = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys3544) - } // end switch yys3544 - } // end for yyj3544 + z.DecStructFieldNotFound(-1, yys3535) + } // end switch yys3535 + } // end for yyj3535 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -45001,16 +44919,16 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3549 int - var yyb3549 bool - var yyhl3549 bool = l >= 0 - yyj3549++ - if yyhl3549 { - yyb3549 = yyj3549 > l + var yyj3540 int + var yyb3540 bool + var yyhl3540 bool = l >= 0 + yyj3540++ + if yyhl3540 { + yyb3540 = yyj3540 > l } else { - yyb3549 = r.CheckBreak() + yyb3540 = r.CheckBreak() } - if yyb3549 { + if yyb3540 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45020,13 +44938,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3549++ - if yyhl3549 { - yyb3549 = yyj3549 > l + yyj3540++ + if yyhl3540 { + yyb3540 = yyj3540 > l } else { - yyb3549 = r.CheckBreak() + yyb3540 = r.CheckBreak() } - if yyb3549 { + if yyb3540 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45036,13 +44954,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3549++ - if yyhl3549 { - yyb3549 = yyj3549 > l + yyj3540++ + if yyhl3540 { + yyb3540 = yyj3540 > l } else { - yyb3549 = r.CheckBreak() + yyb3540 = r.CheckBreak() } - if yyb3549 { + if yyb3540 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45052,13 +44970,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Export = bool(r.DecodeBool()) } - yyj3549++ - if yyhl3549 { - yyb3549 = yyj3549 > l + yyj3540++ + if yyhl3540 { + yyb3540 = yyj3540 > l } else { - yyb3549 = r.CheckBreak() + yyb3540 = r.CheckBreak() } - if yyb3549 { + if yyb3540 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45069,17 +44987,17 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Exact = bool(r.DecodeBool()) } for { - yyj3549++ - if yyhl3549 { - yyb3549 = yyj3549 > l + yyj3540++ + if yyhl3540 { + yyb3540 = yyj3540 > l } else { - yyb3549 = r.CheckBreak() + yyb3540 = r.CheckBreak() } - if yyb3549 { + if yyb3540 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3549-1, "") + z.DecStructFieldNotFound(yyj3540-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -45091,36 +45009,36 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3554 := z.EncBinary() - _ = yym3554 + yym3545 := z.EncBinary() + _ = yym3545 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3555 := !z.EncBinary() - yy2arr3555 := z.EncBasicHandle().StructToArray - var yyq3555 [7]bool - _, _, _ = yysep3555, yyq3555, yy2arr3555 - const yyr3555 bool = false - yyq3555[0] = x.Kind != "" - yyq3555[1] = x.APIVersion != "" - var yynn3555 int - if yyr3555 || yy2arr3555 { + yysep3546 := !z.EncBinary() + yy2arr3546 := z.EncBasicHandle().StructToArray + var yyq3546 [7]bool + _, _, _ = yysep3546, yyq3546, yy2arr3546 + const yyr3546 bool = false + yyq3546[0] = x.Kind != "" + yyq3546[1] = x.APIVersion != "" + var yynn3546 int + if yyr3546 || yy2arr3546 { r.EncodeArrayStart(7) } else { - yynn3555 = 5 - for _, b := range yyq3555 { + yynn3546 = 5 + for _, b := range yyq3546 { if b { - yynn3555++ + yynn3546++ } } - r.EncodeMapStart(yynn3555) - yynn3555 = 0 + r.EncodeMapStart(yynn3546) + yynn3546 = 0 } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3555[0] { - yym3557 := z.EncBinary() - _ = yym3557 + if yyq3546[0] { + yym3548 := z.EncBinary() + _ = yym3548 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -45129,23 +45047,23 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3555[0] { + if yyq3546[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3558 := z.EncBinary() - _ = yym3558 + yym3549 := z.EncBinary() + _ = yym3549 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3555[1] { - yym3560 := z.EncBinary() - _ = yym3560 + if yyq3546[1] { + yym3551 := z.EncBinary() + _ = yym3551 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -45154,25 +45072,25 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3555[1] { + if yyq3546[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3561 := z.EncBinary() - _ = yym3561 + yym3552 := z.EncBinary() + _ = yym3552 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.LabelSelector == nil { r.EncodeNil() } else { - yym3563 := z.EncBinary() - _ = yym3563 + yym3554 := z.EncBinary() + _ = yym3554 if false { } else if z.HasExtensions() && z.EncExt(x.LabelSelector) { } else { @@ -45186,8 +45104,8 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.LabelSelector == nil { r.EncodeNil() } else { - yym3564 := z.EncBinary() - _ = yym3564 + yym3555 := z.EncBinary() + _ = yym3555 if false { } else if z.HasExtensions() && z.EncExt(x.LabelSelector) { } else { @@ -45195,13 +45113,13 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.FieldSelector == nil { r.EncodeNil() } else { - yym3566 := z.EncBinary() - _ = yym3566 + yym3557 := z.EncBinary() + _ = yym3557 if false { } else if z.HasExtensions() && z.EncExt(x.FieldSelector) { } else { @@ -45215,8 +45133,8 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.FieldSelector == nil { r.EncodeNil() } else { - yym3567 := z.EncBinary() - _ = yym3567 + yym3558 := z.EncBinary() + _ = yym3558 if false { } else if z.HasExtensions() && z.EncExt(x.FieldSelector) { } else { @@ -45224,10 +45142,10 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3569 := z.EncBinary() - _ = yym3569 + yym3560 := z.EncBinary() + _ = yym3560 if false { } else { r.EncodeBool(bool(x.Watch)) @@ -45236,17 +45154,17 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Watch")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3570 := z.EncBinary() - _ = yym3570 + yym3561 := z.EncBinary() + _ = yym3561 if false { } else { r.EncodeBool(bool(x.Watch)) } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3572 := z.EncBinary() - _ = yym3572 + yym3563 := z.EncBinary() + _ = yym3563 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) @@ -45255,24 +45173,24 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ResourceVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3573 := z.EncBinary() - _ = yym3573 + yym3564 := z.EncBinary() + _ = yym3564 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.TimeoutSeconds == nil { r.EncodeNil() } else { - yy3575 := *x.TimeoutSeconds - yym3576 := z.EncBinary() - _ = yym3576 + yy3566 := *x.TimeoutSeconds + yym3567 := z.EncBinary() + _ = yym3567 if false { } else { - r.EncodeInt(int64(yy3575)) + r.EncodeInt(int64(yy3566)) } } } else { @@ -45282,16 +45200,16 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.TimeoutSeconds == nil { r.EncodeNil() } else { - yy3577 := *x.TimeoutSeconds - yym3578 := z.EncBinary() - _ = yym3578 + yy3568 := *x.TimeoutSeconds + yym3569 := z.EncBinary() + _ = yym3569 if false { } else { - r.EncodeInt(int64(yy3577)) + r.EncodeInt(int64(yy3568)) } } } - if yyr3555 || yy2arr3555 { + if yyr3546 || yy2arr3546 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -45304,25 +45222,25 @@ func (x *ListOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3579 := z.DecBinary() - _ = yym3579 + yym3570 := z.DecBinary() + _ = yym3570 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3580 := r.ContainerType() - if yyct3580 == codecSelferValueTypeMap1234 { - yyl3580 := r.ReadMapStart() - if yyl3580 == 0 { + yyct3571 := r.ContainerType() + if yyct3571 == codecSelferValueTypeMap1234 { + yyl3571 := r.ReadMapStart() + if yyl3571 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3580, d) + x.codecDecodeSelfFromMap(yyl3571, d) } - } else if yyct3580 == codecSelferValueTypeArray1234 { - yyl3580 := r.ReadArrayStart() - if yyl3580 == 0 { + } else if yyct3571 == codecSelferValueTypeArray1234 { + yyl3571 := r.ReadArrayStart() + if yyl3571 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3580, d) + x.codecDecodeSelfFromArray(yyl3571, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -45334,12 +45252,12 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3581Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3581Slc - var yyhl3581 bool = l >= 0 - for yyj3581 := 0; ; yyj3581++ { - if yyhl3581 { - if yyj3581 >= l { + var yys3572Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3572Slc + var yyhl3572 bool = l >= 0 + for yyj3572 := 0; ; yyj3572++ { + if yyhl3572 { + if yyj3572 >= l { break } } else { @@ -45348,10 +45266,10 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3581Slc = r.DecodeBytes(yys3581Slc, true, true) - yys3581 := string(yys3581Slc) + yys3572Slc = r.DecodeBytes(yys3572Slc, true, true) + yys3572 := string(yys3572Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3581 { + switch yys3572 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -45368,26 +45286,26 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LabelSelector = nil } else { - yyv3584 := &x.LabelSelector - yym3585 := z.DecBinary() - _ = yym3585 + yyv3575 := &x.LabelSelector + yym3576 := z.DecBinary() + _ = yym3576 if false { - } else if z.HasExtensions() && z.DecExt(yyv3584) { + } else if z.HasExtensions() && z.DecExt(yyv3575) { } else { - z.DecFallback(yyv3584, true) + z.DecFallback(yyv3575, true) } } case "FieldSelector": if r.TryDecodeAsNil() { x.FieldSelector = nil } else { - yyv3586 := &x.FieldSelector - yym3587 := z.DecBinary() - _ = yym3587 + yyv3577 := &x.FieldSelector + yym3578 := z.DecBinary() + _ = yym3578 if false { - } else if z.HasExtensions() && z.DecExt(yyv3586) { + } else if z.HasExtensions() && z.DecExt(yyv3577) { } else { - z.DecFallback(yyv3586, true) + z.DecFallback(yyv3577, true) } } case "Watch": @@ -45411,17 +45329,17 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.TimeoutSeconds == nil { x.TimeoutSeconds = new(int64) } - yym3591 := z.DecBinary() - _ = yym3591 + yym3582 := z.DecBinary() + _ = yym3582 if false { } else { *((*int64)(x.TimeoutSeconds)) = int64(r.DecodeInt(64)) } } default: - z.DecStructFieldNotFound(-1, yys3581) - } // end switch yys3581 - } // end for yyj3581 + z.DecStructFieldNotFound(-1, yys3572) + } // end switch yys3572 + } // end for yyj3572 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -45429,16 +45347,16 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3592 int - var yyb3592 bool - var yyhl3592 bool = l >= 0 - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + var yyj3583 int + var yyb3583 bool + var yyhl3583 bool = l >= 0 + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45448,13 +45366,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45464,13 +45382,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45478,22 +45396,22 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LabelSelector = nil } else { - yyv3595 := &x.LabelSelector - yym3596 := z.DecBinary() - _ = yym3596 + yyv3586 := &x.LabelSelector + yym3587 := z.DecBinary() + _ = yym3587 if false { - } else if z.HasExtensions() && z.DecExt(yyv3595) { + } else if z.HasExtensions() && z.DecExt(yyv3586) { } else { - z.DecFallback(yyv3595, true) + z.DecFallback(yyv3586, true) } } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45501,22 +45419,22 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.FieldSelector = nil } else { - yyv3597 := &x.FieldSelector - yym3598 := z.DecBinary() - _ = yym3598 + yyv3588 := &x.FieldSelector + yym3589 := z.DecBinary() + _ = yym3589 if false { - } else if z.HasExtensions() && z.DecExt(yyv3597) { + } else if z.HasExtensions() && z.DecExt(yyv3588) { } else { - z.DecFallback(yyv3597, true) + z.DecFallback(yyv3588, true) } } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45526,13 +45444,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Watch = bool(r.DecodeBool()) } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45542,13 +45460,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ResourceVersion = string(r.DecodeString()) } - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45561,25 +45479,25 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.TimeoutSeconds == nil { x.TimeoutSeconds = new(int64) } - yym3602 := z.DecBinary() - _ = yym3602 + yym3593 := z.DecBinary() + _ = yym3593 if false { } else { *((*int64)(x.TimeoutSeconds)) = int64(r.DecodeInt(64)) } } for { - yyj3592++ - if yyhl3592 { - yyb3592 = yyj3592 > l + yyj3583++ + if yyhl3583 { + yyb3583 = yyj3583 > l } else { - yyb3592 = r.CheckBreak() + yyb3583 = r.CheckBreak() } - if yyb3592 { + if yyb3583 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3592-1, "") + z.DecStructFieldNotFound(yyj3583-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -45591,36 +45509,36 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3603 := z.EncBinary() - _ = yym3603 + yym3594 := z.EncBinary() + _ = yym3594 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3604 := !z.EncBinary() - yy2arr3604 := z.EncBasicHandle().StructToArray - var yyq3604 [10]bool - _, _, _ = yysep3604, yyq3604, yy2arr3604 - const yyr3604 bool = false - yyq3604[0] = x.Kind != "" - yyq3604[1] = x.APIVersion != "" - var yynn3604 int - if yyr3604 || yy2arr3604 { + yysep3595 := !z.EncBinary() + yy2arr3595 := z.EncBasicHandle().StructToArray + var yyq3595 [10]bool + _, _, _ = yysep3595, yyq3595, yy2arr3595 + const yyr3595 bool = false + yyq3595[0] = x.Kind != "" + yyq3595[1] = x.APIVersion != "" + var yynn3595 int + if yyr3595 || yy2arr3595 { r.EncodeArrayStart(10) } else { - yynn3604 = 8 - for _, b := range yyq3604 { + yynn3595 = 8 + for _, b := range yyq3595 { if b { - yynn3604++ + yynn3595++ } } - r.EncodeMapStart(yynn3604) - yynn3604 = 0 + r.EncodeMapStart(yynn3595) + yynn3595 = 0 } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3604[0] { - yym3606 := z.EncBinary() - _ = yym3606 + if yyq3595[0] { + yym3597 := z.EncBinary() + _ = yym3597 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -45629,23 +45547,23 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3604[0] { + if yyq3595[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3607 := z.EncBinary() - _ = yym3607 + yym3598 := z.EncBinary() + _ = yym3598 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3604[1] { - yym3609 := z.EncBinary() - _ = yym3609 + if yyq3595[1] { + yym3600 := z.EncBinary() + _ = yym3600 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -45654,22 +45572,22 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3604[1] { + if yyq3595[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3610 := z.EncBinary() - _ = yym3610 + yym3601 := z.EncBinary() + _ = yym3601 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3612 := z.EncBinary() - _ = yym3612 + yym3603 := z.EncBinary() + _ = yym3603 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) @@ -45678,17 +45596,17 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Container")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3613 := z.EncBinary() - _ = yym3613 + yym3604 := z.EncBinary() + _ = yym3604 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3615 := z.EncBinary() - _ = yym3615 + yym3606 := z.EncBinary() + _ = yym3606 if false { } else { r.EncodeBool(bool(x.Follow)) @@ -45697,17 +45615,17 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Follow")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3616 := z.EncBinary() - _ = yym3616 + yym3607 := z.EncBinary() + _ = yym3607 if false { } else { r.EncodeBool(bool(x.Follow)) } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3618 := z.EncBinary() - _ = yym3618 + yym3609 := z.EncBinary() + _ = yym3609 if false { } else { r.EncodeBool(bool(x.Previous)) @@ -45716,24 +45634,24 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Previous")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3619 := z.EncBinary() - _ = yym3619 + yym3610 := z.EncBinary() + _ = yym3610 if false { } else { r.EncodeBool(bool(x.Previous)) } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.SinceSeconds == nil { r.EncodeNil() } else { - yy3621 := *x.SinceSeconds - yym3622 := z.EncBinary() - _ = yym3622 + yy3612 := *x.SinceSeconds + yym3613 := z.EncBinary() + _ = yym3613 if false { } else { - r.EncodeInt(int64(yy3621)) + r.EncodeInt(int64(yy3612)) } } } else { @@ -45743,27 +45661,27 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.SinceSeconds == nil { r.EncodeNil() } else { - yy3623 := *x.SinceSeconds - yym3624 := z.EncBinary() - _ = yym3624 + yy3614 := *x.SinceSeconds + yym3615 := z.EncBinary() + _ = yym3615 if false { } else { - r.EncodeInt(int64(yy3623)) + r.EncodeInt(int64(yy3614)) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.SinceTime == nil { r.EncodeNil() } else { - yym3626 := z.EncBinary() - _ = yym3626 + yym3617 := z.EncBinary() + _ = yym3617 if false { } else if z.HasExtensions() && z.EncExt(x.SinceTime) { - } else if yym3626 { + } else if yym3617 { z.EncBinaryMarshal(x.SinceTime) - } else if !yym3626 && z.IsJSONHandle() { + } else if !yym3617 && z.IsJSONHandle() { z.EncJSONMarshal(x.SinceTime) } else { z.EncFallback(x.SinceTime) @@ -45776,23 +45694,23 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.SinceTime == nil { r.EncodeNil() } else { - yym3627 := z.EncBinary() - _ = yym3627 + yym3618 := z.EncBinary() + _ = yym3618 if false { } else if z.HasExtensions() && z.EncExt(x.SinceTime) { - } else if yym3627 { + } else if yym3618 { z.EncBinaryMarshal(x.SinceTime) - } else if !yym3627 && z.IsJSONHandle() { + } else if !yym3618 && z.IsJSONHandle() { z.EncJSONMarshal(x.SinceTime) } else { z.EncFallback(x.SinceTime) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3629 := z.EncBinary() - _ = yym3629 + yym3620 := z.EncBinary() + _ = yym3620 if false { } else { r.EncodeBool(bool(x.Timestamps)) @@ -45801,24 +45719,24 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Timestamps")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3630 := z.EncBinary() - _ = yym3630 + yym3621 := z.EncBinary() + _ = yym3621 if false { } else { r.EncodeBool(bool(x.Timestamps)) } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.TailLines == nil { r.EncodeNil() } else { - yy3632 := *x.TailLines - yym3633 := z.EncBinary() - _ = yym3633 + yy3623 := *x.TailLines + yym3624 := z.EncBinary() + _ = yym3624 if false { } else { - r.EncodeInt(int64(yy3632)) + r.EncodeInt(int64(yy3623)) } } } else { @@ -45828,26 +45746,26 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.TailLines == nil { r.EncodeNil() } else { - yy3634 := *x.TailLines - yym3635 := z.EncBinary() - _ = yym3635 + yy3625 := *x.TailLines + yym3626 := z.EncBinary() + _ = yym3626 if false { } else { - r.EncodeInt(int64(yy3634)) + r.EncodeInt(int64(yy3625)) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.LimitBytes == nil { r.EncodeNil() } else { - yy3637 := *x.LimitBytes - yym3638 := z.EncBinary() - _ = yym3638 + yy3628 := *x.LimitBytes + yym3629 := z.EncBinary() + _ = yym3629 if false { } else { - r.EncodeInt(int64(yy3637)) + r.EncodeInt(int64(yy3628)) } } } else { @@ -45857,16 +45775,16 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.LimitBytes == nil { r.EncodeNil() } else { - yy3639 := *x.LimitBytes - yym3640 := z.EncBinary() - _ = yym3640 + yy3630 := *x.LimitBytes + yym3631 := z.EncBinary() + _ = yym3631 if false { } else { - r.EncodeInt(int64(yy3639)) + r.EncodeInt(int64(yy3630)) } } } - if yyr3604 || yy2arr3604 { + if yyr3595 || yy2arr3595 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -45879,25 +45797,25 @@ func (x *PodLogOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3641 := z.DecBinary() - _ = yym3641 + yym3632 := z.DecBinary() + _ = yym3632 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3642 := r.ContainerType() - if yyct3642 == codecSelferValueTypeMap1234 { - yyl3642 := r.ReadMapStart() - if yyl3642 == 0 { + yyct3633 := r.ContainerType() + if yyct3633 == codecSelferValueTypeMap1234 { + yyl3633 := r.ReadMapStart() + if yyl3633 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3642, d) + x.codecDecodeSelfFromMap(yyl3633, d) } - } else if yyct3642 == codecSelferValueTypeArray1234 { - yyl3642 := r.ReadArrayStart() - if yyl3642 == 0 { + } else if yyct3633 == codecSelferValueTypeArray1234 { + yyl3633 := r.ReadArrayStart() + if yyl3633 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3642, d) + x.codecDecodeSelfFromArray(yyl3633, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -45909,12 +45827,12 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3643Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3643Slc - var yyhl3643 bool = l >= 0 - for yyj3643 := 0; ; yyj3643++ { - if yyhl3643 { - if yyj3643 >= l { + var yys3634Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3634Slc + var yyhl3634 bool = l >= 0 + for yyj3634 := 0; ; yyj3634++ { + if yyhl3634 { + if yyj3634 >= l { break } } else { @@ -45923,10 +45841,10 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3643Slc = r.DecodeBytes(yys3643Slc, true, true) - yys3643 := string(yys3643Slc) + yys3634Slc = r.DecodeBytes(yys3634Slc, true, true) + yys3634 := string(yys3634Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3643 { + switch yys3634 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -45966,8 +45884,8 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.SinceSeconds == nil { x.SinceSeconds = new(int64) } - yym3650 := z.DecBinary() - _ = yym3650 + yym3641 := z.DecBinary() + _ = yym3641 if false { } else { *((*int64)(x.SinceSeconds)) = int64(r.DecodeInt(64)) @@ -45982,13 +45900,13 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.SinceTime == nil { x.SinceTime = new(pkg2_unversioned.Time) } - yym3652 := z.DecBinary() - _ = yym3652 + yym3643 := z.DecBinary() + _ = yym3643 if false { } else if z.HasExtensions() && z.DecExt(x.SinceTime) { - } else if yym3652 { + } else if yym3643 { z.DecBinaryUnmarshal(x.SinceTime) - } else if !yym3652 && z.IsJSONHandle() { + } else if !yym3643 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.SinceTime) } else { z.DecFallback(x.SinceTime, false) @@ -46009,8 +45927,8 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.TailLines == nil { x.TailLines = new(int64) } - yym3655 := z.DecBinary() - _ = yym3655 + yym3646 := z.DecBinary() + _ = yym3646 if false { } else { *((*int64)(x.TailLines)) = int64(r.DecodeInt(64)) @@ -46025,17 +45943,17 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.LimitBytes == nil { x.LimitBytes = new(int64) } - yym3657 := z.DecBinary() - _ = yym3657 + yym3648 := z.DecBinary() + _ = yym3648 if false { } else { *((*int64)(x.LimitBytes)) = int64(r.DecodeInt(64)) } } default: - z.DecStructFieldNotFound(-1, yys3643) - } // end switch yys3643 - } // end for yyj3643 + z.DecStructFieldNotFound(-1, yys3634) + } // end switch yys3634 + } // end for yyj3634 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -46043,16 +45961,16 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3658 int - var yyb3658 bool - var yyhl3658 bool = l >= 0 - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + var yyj3649 int + var yyb3649 bool + var yyhl3649 bool = l >= 0 + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46062,13 +45980,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46078,13 +45996,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46094,13 +46012,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Container = string(r.DecodeString()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46110,13 +46028,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Follow = bool(r.DecodeBool()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46126,13 +46044,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Previous = bool(r.DecodeBool()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46145,20 +46063,20 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.SinceSeconds == nil { x.SinceSeconds = new(int64) } - yym3665 := z.DecBinary() - _ = yym3665 + yym3656 := z.DecBinary() + _ = yym3656 if false { } else { *((*int64)(x.SinceSeconds)) = int64(r.DecodeInt(64)) } } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46171,25 +46089,25 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.SinceTime == nil { x.SinceTime = new(pkg2_unversioned.Time) } - yym3667 := z.DecBinary() - _ = yym3667 + yym3658 := z.DecBinary() + _ = yym3658 if false { } else if z.HasExtensions() && z.DecExt(x.SinceTime) { - } else if yym3667 { + } else if yym3658 { z.DecBinaryUnmarshal(x.SinceTime) - } else if !yym3667 && z.IsJSONHandle() { + } else if !yym3658 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.SinceTime) } else { z.DecFallback(x.SinceTime, false) } } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46199,13 +46117,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Timestamps = bool(r.DecodeBool()) } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46218,20 +46136,20 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.TailLines == nil { x.TailLines = new(int64) } - yym3670 := z.DecBinary() - _ = yym3670 + yym3661 := z.DecBinary() + _ = yym3661 if false { } else { *((*int64)(x.TailLines)) = int64(r.DecodeInt(64)) } } - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46244,25 +46162,25 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.LimitBytes == nil { x.LimitBytes = new(int64) } - yym3672 := z.DecBinary() - _ = yym3672 + yym3663 := z.DecBinary() + _ = yym3663 if false { } else { *((*int64)(x.LimitBytes)) = int64(r.DecodeInt(64)) } } for { - yyj3658++ - if yyhl3658 { - yyb3658 = yyj3658 > l + yyj3649++ + if yyhl3649 { + yyb3649 = yyj3649 > l } else { - yyb3658 = r.CheckBreak() + yyb3649 = r.CheckBreak() } - if yyb3658 { + if yyb3649 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3658-1, "") + z.DecStructFieldNotFound(yyj3649-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -46274,41 +46192,41 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3673 := z.EncBinary() - _ = yym3673 + yym3664 := z.EncBinary() + _ = yym3664 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3674 := !z.EncBinary() - yy2arr3674 := z.EncBasicHandle().StructToArray - var yyq3674 [7]bool - _, _, _ = yysep3674, yyq3674, yy2arr3674 - const yyr3674 bool = false - yyq3674[0] = x.Kind != "" - yyq3674[1] = x.APIVersion != "" - yyq3674[2] = x.Stdin != false - yyq3674[3] = x.Stdout != false - yyq3674[4] = x.Stderr != false - yyq3674[5] = x.TTY != false - yyq3674[6] = x.Container != "" - var yynn3674 int - if yyr3674 || yy2arr3674 { + yysep3665 := !z.EncBinary() + yy2arr3665 := z.EncBasicHandle().StructToArray + var yyq3665 [7]bool + _, _, _ = yysep3665, yyq3665, yy2arr3665 + const yyr3665 bool = false + yyq3665[0] = x.Kind != "" + yyq3665[1] = x.APIVersion != "" + yyq3665[2] = x.Stdin != false + yyq3665[3] = x.Stdout != false + yyq3665[4] = x.Stderr != false + yyq3665[5] = x.TTY != false + yyq3665[6] = x.Container != "" + var yynn3665 int + if yyr3665 || yy2arr3665 { r.EncodeArrayStart(7) } else { - yynn3674 = 0 - for _, b := range yyq3674 { + yynn3665 = 0 + for _, b := range yyq3665 { if b { - yynn3674++ + yynn3665++ } } - r.EncodeMapStart(yynn3674) - yynn3674 = 0 + r.EncodeMapStart(yynn3665) + yynn3665 = 0 } - if yyr3674 || yy2arr3674 { + if yyr3665 || yy2arr3665 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[0] { - yym3676 := z.EncBinary() - _ = yym3676 + if yyq3665[0] { + yym3667 := z.EncBinary() + _ = yym3667 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -46317,149 +46235,149 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3674[0] { + if yyq3665[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3668 := z.EncBinary() + _ = yym3668 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr3665 || yy2arr3665 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3665[1] { + yym3670 := z.EncBinary() + _ = yym3670 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3665[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3671 := z.EncBinary() + _ = yym3671 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3665 || yy2arr3665 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3665[2] { + yym3673 := z.EncBinary() + _ = yym3673 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3665[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdin")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3674 := z.EncBinary() + _ = yym3674 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } + } + if yyr3665 || yy2arr3665 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3665[3] { + yym3676 := z.EncBinary() + _ = yym3676 + if false { + } else { + r.EncodeBool(bool(x.Stdout)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3665[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdout")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3677 := z.EncBinary() _ = yym3677 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeBool(bool(x.Stdout)) } } } - if yyr3674 || yy2arr3674 { + if yyr3665 || yy2arr3665 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[1] { + if yyq3665[4] { yym3679 := z.EncBinary() _ = yym3679 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } else { - r.EncodeString(codecSelferC_UTF81234, "") + r.EncodeBool(false) } } else { - if yyq3674[1] { + if yyq3665[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + r.EncodeString(codecSelferC_UTF81234, string("stderr")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3680 := z.EncBinary() _ = yym3680 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } } - if yyr3674 || yy2arr3674 { + if yyr3665 || yy2arr3665 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[2] { + if yyq3665[5] { yym3682 := z.EncBinary() _ = yym3682 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } else { r.EncodeBool(false) } } else { - if yyq3674[2] { + if yyq3665[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdin")) + r.EncodeString(codecSelferC_UTF81234, string("tty")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3683 := z.EncBinary() _ = yym3683 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } } - if yyr3674 || yy2arr3674 { + if yyr3665 || yy2arr3665 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[3] { + if yyq3665[6] { yym3685 := z.EncBinary() _ = yym3685 if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3674[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3686 := z.EncBinary() - _ = yym3686 - if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } - } - if yyr3674 || yy2arr3674 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[4] { - yym3688 := z.EncBinary() - _ = yym3688 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3674[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stderr")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3689 := z.EncBinary() - _ = yym3689 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } - } - if yyr3674 || yy2arr3674 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[5] { - yym3691 := z.EncBinary() - _ = yym3691 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3674[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("tty")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3692 := z.EncBinary() - _ = yym3692 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } - } - if yyr3674 || yy2arr3674 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3674[6] { - yym3694 := z.EncBinary() - _ = yym3694 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } @@ -46467,19 +46385,19 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3674[6] { + if yyq3665[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("container")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3695 := z.EncBinary() - _ = yym3695 + yym3686 := z.EncBinary() + _ = yym3686 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } } } - if yyr3674 || yy2arr3674 { + if yyr3665 || yy2arr3665 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -46492,25 +46410,25 @@ func (x *PodAttachOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3696 := z.DecBinary() - _ = yym3696 + yym3687 := z.DecBinary() + _ = yym3687 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3697 := r.ContainerType() - if yyct3697 == codecSelferValueTypeMap1234 { - yyl3697 := r.ReadMapStart() - if yyl3697 == 0 { + yyct3688 := r.ContainerType() + if yyct3688 == codecSelferValueTypeMap1234 { + yyl3688 := r.ReadMapStart() + if yyl3688 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3697, d) + x.codecDecodeSelfFromMap(yyl3688, d) } - } else if yyct3697 == codecSelferValueTypeArray1234 { - yyl3697 := r.ReadArrayStart() - if yyl3697 == 0 { + } else if yyct3688 == codecSelferValueTypeArray1234 { + yyl3688 := r.ReadArrayStart() + if yyl3688 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3697, d) + x.codecDecodeSelfFromArray(yyl3688, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -46522,12 +46440,12 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3698Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3698Slc - var yyhl3698 bool = l >= 0 - for yyj3698 := 0; ; yyj3698++ { - if yyhl3698 { - if yyj3698 >= l { + var yys3689Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3689Slc + var yyhl3689 bool = l >= 0 + for yyj3689 := 0; ; yyj3689++ { + if yyhl3689 { + if yyj3689 >= l { break } } else { @@ -46536,10 +46454,10 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3698Slc = r.DecodeBytes(yys3698Slc, true, true) - yys3698 := string(yys3698Slc) + yys3689Slc = r.DecodeBytes(yys3689Slc, true, true) + yys3689 := string(yys3689Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3698 { + switch yys3689 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -46583,9 +46501,9 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Container = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3698) - } // end switch yys3698 - } // end for yyj3698 + z.DecStructFieldNotFound(-1, yys3689) + } // end switch yys3689 + } // end for yyj3689 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -46593,16 +46511,16 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3706 int - var yyb3706 bool - var yyhl3706 bool = l >= 0 - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + var yyj3697 int + var yyb3697 bool + var yyhl3697 bool = l >= 0 + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46612,13 +46530,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46628,13 +46546,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46644,13 +46562,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stdin = bool(r.DecodeBool()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46660,13 +46578,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stdout = bool(r.DecodeBool()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46676,13 +46594,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stderr = bool(r.DecodeBool()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46692,13 +46610,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.TTY = bool(r.DecodeBool()) } - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46709,17 +46627,17 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Container = string(r.DecodeString()) } for { - yyj3706++ - if yyhl3706 { - yyb3706 = yyj3706 > l + yyj3697++ + if yyhl3697 { + yyb3697 = yyj3697 > l } else { - yyb3706 = r.CheckBreak() + yyb3697 = r.CheckBreak() } - if yyb3706 { + if yyb3697 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3706-1, "") + z.DecStructFieldNotFound(yyj3697-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -46731,36 +46649,36 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3714 := z.EncBinary() - _ = yym3714 + yym3705 := z.EncBinary() + _ = yym3705 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3715 := !z.EncBinary() - yy2arr3715 := z.EncBasicHandle().StructToArray - var yyq3715 [8]bool - _, _, _ = yysep3715, yyq3715, yy2arr3715 - const yyr3715 bool = false - yyq3715[0] = x.Kind != "" - yyq3715[1] = x.APIVersion != "" - var yynn3715 int - if yyr3715 || yy2arr3715 { + yysep3706 := !z.EncBinary() + yy2arr3706 := z.EncBasicHandle().StructToArray + var yyq3706 [8]bool + _, _, _ = yysep3706, yyq3706, yy2arr3706 + const yyr3706 bool = false + yyq3706[0] = x.Kind != "" + yyq3706[1] = x.APIVersion != "" + var yynn3706 int + if yyr3706 || yy2arr3706 { r.EncodeArrayStart(8) } else { - yynn3715 = 6 - for _, b := range yyq3715 { + yynn3706 = 6 + for _, b := range yyq3706 { if b { - yynn3715++ + yynn3706++ } } - r.EncodeMapStart(yynn3715) - yynn3715 = 0 + r.EncodeMapStart(yynn3706) + yynn3706 = 0 } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3715[0] { - yym3717 := z.EncBinary() - _ = yym3717 + if yyq3706[0] { + yym3708 := z.EncBinary() + _ = yym3708 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -46769,23 +46687,23 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3715[0] { + if yyq3706[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3718 := z.EncBinary() - _ = yym3718 + yym3709 := z.EncBinary() + _ = yym3709 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3715[1] { - yym3720 := z.EncBinary() - _ = yym3720 + if yyq3706[1] { + yym3711 := z.EncBinary() + _ = yym3711 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -46794,22 +46712,22 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3715[1] { + if yyq3706[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3721 := z.EncBinary() - _ = yym3721 + yym3712 := z.EncBinary() + _ = yym3712 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3723 := z.EncBinary() - _ = yym3723 + yym3714 := z.EncBinary() + _ = yym3714 if false { } else { r.EncodeBool(bool(x.Stdin)) @@ -46818,17 +46736,17 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Stdin")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3724 := z.EncBinary() - _ = yym3724 + yym3715 := z.EncBinary() + _ = yym3715 if false { } else { r.EncodeBool(bool(x.Stdin)) } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3726 := z.EncBinary() - _ = yym3726 + yym3717 := z.EncBinary() + _ = yym3717 if false { } else { r.EncodeBool(bool(x.Stdout)) @@ -46837,17 +46755,17 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Stdout")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3727 := z.EncBinary() - _ = yym3727 + yym3718 := z.EncBinary() + _ = yym3718 if false { } else { r.EncodeBool(bool(x.Stdout)) } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3729 := z.EncBinary() - _ = yym3729 + yym3720 := z.EncBinary() + _ = yym3720 if false { } else { r.EncodeBool(bool(x.Stderr)) @@ -46856,17 +46774,17 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Stderr")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3730 := z.EncBinary() - _ = yym3730 + yym3721 := z.EncBinary() + _ = yym3721 if false { } else { r.EncodeBool(bool(x.Stderr)) } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3732 := z.EncBinary() - _ = yym3732 + yym3723 := z.EncBinary() + _ = yym3723 if false { } else { r.EncodeBool(bool(x.TTY)) @@ -46875,17 +46793,17 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("TTY")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3733 := z.EncBinary() - _ = yym3733 + yym3724 := z.EncBinary() + _ = yym3724 if false { } else { r.EncodeBool(bool(x.TTY)) } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3735 := z.EncBinary() - _ = yym3735 + yym3726 := z.EncBinary() + _ = yym3726 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) @@ -46894,20 +46812,20 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Container")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3736 := z.EncBinary() - _ = yym3736 + yym3727 := z.EncBinary() + _ = yym3727 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Command == nil { r.EncodeNil() } else { - yym3738 := z.EncBinary() - _ = yym3738 + yym3729 := z.EncBinary() + _ = yym3729 if false { } else { z.F.EncSliceStringV(x.Command, false, e) @@ -46920,15 +46838,15 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.Command == nil { r.EncodeNil() } else { - yym3739 := z.EncBinary() - _ = yym3739 + yym3730 := z.EncBinary() + _ = yym3730 if false { } else { z.F.EncSliceStringV(x.Command, false, e) } } } - if yyr3715 || yy2arr3715 { + if yyr3706 || yy2arr3706 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -46941,25 +46859,25 @@ func (x *PodExecOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3740 := z.DecBinary() - _ = yym3740 + yym3731 := z.DecBinary() + _ = yym3731 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3741 := r.ContainerType() - if yyct3741 == codecSelferValueTypeMap1234 { - yyl3741 := r.ReadMapStart() - if yyl3741 == 0 { + yyct3732 := r.ContainerType() + if yyct3732 == codecSelferValueTypeMap1234 { + yyl3732 := r.ReadMapStart() + if yyl3732 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3741, d) + x.codecDecodeSelfFromMap(yyl3732, d) } - } else if yyct3741 == codecSelferValueTypeArray1234 { - yyl3741 := r.ReadArrayStart() - if yyl3741 == 0 { + } else if yyct3732 == codecSelferValueTypeArray1234 { + yyl3732 := r.ReadArrayStart() + if yyl3732 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3741, d) + x.codecDecodeSelfFromArray(yyl3732, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -46971,12 +46889,12 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3742Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3742Slc - var yyhl3742 bool = l >= 0 - for yyj3742 := 0; ; yyj3742++ { - if yyhl3742 { - if yyj3742 >= l { + var yys3733Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3733Slc + var yyhl3733 bool = l >= 0 + for yyj3733 := 0; ; yyj3733++ { + if yyhl3733 { + if yyj3733 >= l { break } } else { @@ -46985,10 +46903,10 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3742Slc = r.DecodeBytes(yys3742Slc, true, true) - yys3742 := string(yys3742Slc) + yys3733Slc = r.DecodeBytes(yys3733Slc, true, true) + yys3733 := string(yys3733Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3742 { + switch yys3733 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47035,18 +46953,18 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Command = nil } else { - yyv3750 := &x.Command - yym3751 := z.DecBinary() - _ = yym3751 + yyv3741 := &x.Command + yym3742 := z.DecBinary() + _ = yym3742 if false { } else { - z.F.DecSliceStringX(yyv3750, false, d) + z.F.DecSliceStringX(yyv3741, false, d) } } default: - z.DecStructFieldNotFound(-1, yys3742) - } // end switch yys3742 - } // end for yyj3742 + z.DecStructFieldNotFound(-1, yys3733) + } // end switch yys3733 + } // end for yyj3733 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47054,16 +46972,16 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3752 int - var yyb3752 bool - var yyhl3752 bool = l >= 0 - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + var yyj3743 int + var yyb3743 bool + var yyhl3743 bool = l >= 0 + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47073,13 +46991,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47089,13 +47007,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47105,13 +47023,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stdin = bool(r.DecodeBool()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47121,13 +47039,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stdout = bool(r.DecodeBool()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47137,13 +47055,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stderr = bool(r.DecodeBool()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47153,13 +47071,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.TTY = bool(r.DecodeBool()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47169,13 +47087,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Container = string(r.DecodeString()) } - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47183,26 +47101,26 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Command = nil } else { - yyv3760 := &x.Command - yym3761 := z.DecBinary() - _ = yym3761 + yyv3751 := &x.Command + yym3752 := z.DecBinary() + _ = yym3752 if false { } else { - z.F.DecSliceStringX(yyv3760, false, d) + z.F.DecSliceStringX(yyv3751, false, d) } } for { - yyj3752++ - if yyhl3752 { - yyb3752 = yyj3752 > l + yyj3743++ + if yyhl3743 { + yyb3743 = yyj3743 > l } else { - yyb3752 = r.CheckBreak() + yyb3743 = r.CheckBreak() } - if yyb3752 { + if yyb3743 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3752-1, "") + z.DecStructFieldNotFound(yyj3743-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47214,36 +47132,36 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3762 := z.EncBinary() - _ = yym3762 + yym3753 := z.EncBinary() + _ = yym3753 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3763 := !z.EncBinary() - yy2arr3763 := z.EncBasicHandle().StructToArray - var yyq3763 [3]bool - _, _, _ = yysep3763, yyq3763, yy2arr3763 - const yyr3763 bool = false - yyq3763[0] = x.Kind != "" - yyq3763[1] = x.APIVersion != "" - var yynn3763 int - if yyr3763 || yy2arr3763 { + yysep3754 := !z.EncBinary() + yy2arr3754 := z.EncBasicHandle().StructToArray + var yyq3754 [3]bool + _, _, _ = yysep3754, yyq3754, yy2arr3754 + const yyr3754 bool = false + yyq3754[0] = x.Kind != "" + yyq3754[1] = x.APIVersion != "" + var yynn3754 int + if yyr3754 || yy2arr3754 { r.EncodeArrayStart(3) } else { - yynn3763 = 1 - for _, b := range yyq3763 { + yynn3754 = 1 + for _, b := range yyq3754 { if b { - yynn3763++ + yynn3754++ } } - r.EncodeMapStart(yynn3763) - yynn3763 = 0 + r.EncodeMapStart(yynn3754) + yynn3754 = 0 } - if yyr3763 || yy2arr3763 { + if yyr3754 || yy2arr3754 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3763[0] { - yym3765 := z.EncBinary() - _ = yym3765 + if yyq3754[0] { + yym3756 := z.EncBinary() + _ = yym3756 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47252,23 +47170,23 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3763[0] { + if yyq3754[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3766 := z.EncBinary() - _ = yym3766 + yym3757 := z.EncBinary() + _ = yym3757 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3763 || yy2arr3763 { + if yyr3754 || yy2arr3754 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3763[1] { - yym3768 := z.EncBinary() - _ = yym3768 + if yyq3754[1] { + yym3759 := z.EncBinary() + _ = yym3759 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -47277,22 +47195,22 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3763[1] { + if yyq3754[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3769 := z.EncBinary() - _ = yym3769 + yym3760 := z.EncBinary() + _ = yym3760 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3763 || yy2arr3763 { + if yyr3754 || yy2arr3754 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3771 := z.EncBinary() - _ = yym3771 + yym3762 := z.EncBinary() + _ = yym3762 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -47301,14 +47219,14 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3772 := z.EncBinary() - _ = yym3772 + yym3763 := z.EncBinary() + _ = yym3763 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } - if yyr3763 || yy2arr3763 { + if yyr3754 || yy2arr3754 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47321,25 +47239,25 @@ func (x *PodProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3773 := z.DecBinary() - _ = yym3773 + yym3764 := z.DecBinary() + _ = yym3764 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3774 := r.ContainerType() - if yyct3774 == codecSelferValueTypeMap1234 { - yyl3774 := r.ReadMapStart() - if yyl3774 == 0 { + yyct3765 := r.ContainerType() + if yyct3765 == codecSelferValueTypeMap1234 { + yyl3765 := r.ReadMapStart() + if yyl3765 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3774, d) + x.codecDecodeSelfFromMap(yyl3765, d) } - } else if yyct3774 == codecSelferValueTypeArray1234 { - yyl3774 := r.ReadArrayStart() - if yyl3774 == 0 { + } else if yyct3765 == codecSelferValueTypeArray1234 { + yyl3765 := r.ReadArrayStart() + if yyl3765 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3774, d) + x.codecDecodeSelfFromArray(yyl3765, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47351,12 +47269,12 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3775Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3775Slc - var yyhl3775 bool = l >= 0 - for yyj3775 := 0; ; yyj3775++ { - if yyhl3775 { - if yyj3775 >= l { + var yys3766Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3766Slc + var yyhl3766 bool = l >= 0 + for yyj3766 := 0; ; yyj3766++ { + if yyhl3766 { + if yyj3766 >= l { break } } else { @@ -47365,10 +47283,10 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3775Slc = r.DecodeBytes(yys3775Slc, true, true) - yys3775 := string(yys3775Slc) + yys3766Slc = r.DecodeBytes(yys3766Slc, true, true) + yys3766 := string(yys3766Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3775 { + switch yys3766 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47388,9 +47306,9 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3775) - } // end switch yys3775 - } // end for yyj3775 + z.DecStructFieldNotFound(-1, yys3766) + } // end switch yys3766 + } // end for yyj3766 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47398,16 +47316,16 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3779 int - var yyb3779 bool - var yyhl3779 bool = l >= 0 - yyj3779++ - if yyhl3779 { - yyb3779 = yyj3779 > l + var yyj3770 int + var yyb3770 bool + var yyhl3770 bool = l >= 0 + yyj3770++ + if yyhl3770 { + yyb3770 = yyj3770 > l } else { - yyb3779 = r.CheckBreak() + yyb3770 = r.CheckBreak() } - if yyb3779 { + if yyb3770 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47417,13 +47335,13 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3779++ - if yyhl3779 { - yyb3779 = yyj3779 > l + yyj3770++ + if yyhl3770 { + yyb3770 = yyj3770 > l } else { - yyb3779 = r.CheckBreak() + yyb3770 = r.CheckBreak() } - if yyb3779 { + if yyb3770 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47433,13 +47351,13 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3779++ - if yyhl3779 { - yyb3779 = yyj3779 > l + yyj3770++ + if yyhl3770 { + yyb3770 = yyj3770 > l } else { - yyb3779 = r.CheckBreak() + yyb3770 = r.CheckBreak() } - if yyb3779 { + if yyb3770 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47450,17 +47368,17 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Path = string(r.DecodeString()) } for { - yyj3779++ - if yyhl3779 { - yyb3779 = yyj3779 > l + yyj3770++ + if yyhl3770 { + yyb3770 = yyj3770 > l } else { - yyb3779 = r.CheckBreak() + yyb3770 = r.CheckBreak() } - if yyb3779 { + if yyb3770 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3779-1, "") + z.DecStructFieldNotFound(yyj3770-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47472,36 +47390,36 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3783 := z.EncBinary() - _ = yym3783 + yym3774 := z.EncBinary() + _ = yym3774 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3784 := !z.EncBinary() - yy2arr3784 := z.EncBasicHandle().StructToArray - var yyq3784 [3]bool - _, _, _ = yysep3784, yyq3784, yy2arr3784 - const yyr3784 bool = false - yyq3784[0] = x.Kind != "" - yyq3784[1] = x.APIVersion != "" - var yynn3784 int - if yyr3784 || yy2arr3784 { + yysep3775 := !z.EncBinary() + yy2arr3775 := z.EncBasicHandle().StructToArray + var yyq3775 [3]bool + _, _, _ = yysep3775, yyq3775, yy2arr3775 + const yyr3775 bool = false + yyq3775[0] = x.Kind != "" + yyq3775[1] = x.APIVersion != "" + var yynn3775 int + if yyr3775 || yy2arr3775 { r.EncodeArrayStart(3) } else { - yynn3784 = 1 - for _, b := range yyq3784 { + yynn3775 = 1 + for _, b := range yyq3775 { if b { - yynn3784++ + yynn3775++ } } - r.EncodeMapStart(yynn3784) - yynn3784 = 0 + r.EncodeMapStart(yynn3775) + yynn3775 = 0 } - if yyr3784 || yy2arr3784 { + if yyr3775 || yy2arr3775 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3784[0] { - yym3786 := z.EncBinary() - _ = yym3786 + if yyq3775[0] { + yym3777 := z.EncBinary() + _ = yym3777 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47510,23 +47428,23 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3784[0] { + if yyq3775[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3787 := z.EncBinary() - _ = yym3787 + yym3778 := z.EncBinary() + _ = yym3778 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3784 || yy2arr3784 { + if yyr3775 || yy2arr3775 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3784[1] { - yym3789 := z.EncBinary() - _ = yym3789 + if yyq3775[1] { + yym3780 := z.EncBinary() + _ = yym3780 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -47535,22 +47453,22 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3784[1] { + if yyq3775[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3790 := z.EncBinary() - _ = yym3790 + yym3781 := z.EncBinary() + _ = yym3781 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3784 || yy2arr3784 { + if yyr3775 || yy2arr3775 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3792 := z.EncBinary() - _ = yym3792 + yym3783 := z.EncBinary() + _ = yym3783 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -47559,14 +47477,14 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3793 := z.EncBinary() - _ = yym3793 + yym3784 := z.EncBinary() + _ = yym3784 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } - if yyr3784 || yy2arr3784 { + if yyr3775 || yy2arr3775 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47579,25 +47497,25 @@ func (x *NodeProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3794 := z.DecBinary() - _ = yym3794 + yym3785 := z.DecBinary() + _ = yym3785 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3795 := r.ContainerType() - if yyct3795 == codecSelferValueTypeMap1234 { - yyl3795 := r.ReadMapStart() - if yyl3795 == 0 { + yyct3786 := r.ContainerType() + if yyct3786 == codecSelferValueTypeMap1234 { + yyl3786 := r.ReadMapStart() + if yyl3786 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3795, d) + x.codecDecodeSelfFromMap(yyl3786, d) } - } else if yyct3795 == codecSelferValueTypeArray1234 { - yyl3795 := r.ReadArrayStart() - if yyl3795 == 0 { + } else if yyct3786 == codecSelferValueTypeArray1234 { + yyl3786 := r.ReadArrayStart() + if yyl3786 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3795, d) + x.codecDecodeSelfFromArray(yyl3786, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47609,12 +47527,12 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3796Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3796Slc - var yyhl3796 bool = l >= 0 - for yyj3796 := 0; ; yyj3796++ { - if yyhl3796 { - if yyj3796 >= l { + var yys3787Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3787Slc + var yyhl3787 bool = l >= 0 + for yyj3787 := 0; ; yyj3787++ { + if yyhl3787 { + if yyj3787 >= l { break } } else { @@ -47623,10 +47541,10 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3796Slc = r.DecodeBytes(yys3796Slc, true, true) - yys3796 := string(yys3796Slc) + yys3787Slc = r.DecodeBytes(yys3787Slc, true, true) + yys3787 := string(yys3787Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3796 { + switch yys3787 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47646,9 +47564,9 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3796) - } // end switch yys3796 - } // end for yyj3796 + z.DecStructFieldNotFound(-1, yys3787) + } // end switch yys3787 + } // end for yyj3787 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47656,16 +47574,16 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3800 int - var yyb3800 bool - var yyhl3800 bool = l >= 0 - yyj3800++ - if yyhl3800 { - yyb3800 = yyj3800 > l + var yyj3791 int + var yyb3791 bool + var yyhl3791 bool = l >= 0 + yyj3791++ + if yyhl3791 { + yyb3791 = yyj3791 > l } else { - yyb3800 = r.CheckBreak() + yyb3791 = r.CheckBreak() } - if yyb3800 { + if yyb3791 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47675,13 +47593,13 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3800++ - if yyhl3800 { - yyb3800 = yyj3800 > l + yyj3791++ + if yyhl3791 { + yyb3791 = yyj3791 > l } else { - yyb3800 = r.CheckBreak() + yyb3791 = r.CheckBreak() } - if yyb3800 { + if yyb3791 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47691,13 +47609,13 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3800++ - if yyhl3800 { - yyb3800 = yyj3800 > l + yyj3791++ + if yyhl3791 { + yyb3791 = yyj3791 > l } else { - yyb3800 = r.CheckBreak() + yyb3791 = r.CheckBreak() } - if yyb3800 { + if yyb3791 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47708,17 +47626,17 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Path = string(r.DecodeString()) } for { - yyj3800++ - if yyhl3800 { - yyb3800 = yyj3800 > l + yyj3791++ + if yyhl3791 { + yyb3791 = yyj3791 > l } else { - yyb3800 = r.CheckBreak() + yyb3791 = r.CheckBreak() } - if yyb3800 { + if yyb3791 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3800-1, "") + z.DecStructFieldNotFound(yyj3791-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47730,36 +47648,36 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3804 := z.EncBinary() - _ = yym3804 + yym3795 := z.EncBinary() + _ = yym3795 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3805 := !z.EncBinary() - yy2arr3805 := z.EncBasicHandle().StructToArray - var yyq3805 [3]bool - _, _, _ = yysep3805, yyq3805, yy2arr3805 - const yyr3805 bool = false - yyq3805[0] = x.Kind != "" - yyq3805[1] = x.APIVersion != "" - var yynn3805 int - if yyr3805 || yy2arr3805 { + yysep3796 := !z.EncBinary() + yy2arr3796 := z.EncBasicHandle().StructToArray + var yyq3796 [3]bool + _, _, _ = yysep3796, yyq3796, yy2arr3796 + const yyr3796 bool = false + yyq3796[0] = x.Kind != "" + yyq3796[1] = x.APIVersion != "" + var yynn3796 int + if yyr3796 || yy2arr3796 { r.EncodeArrayStart(3) } else { - yynn3805 = 1 - for _, b := range yyq3805 { + yynn3796 = 1 + for _, b := range yyq3796 { if b { - yynn3805++ + yynn3796++ } } - r.EncodeMapStart(yynn3805) - yynn3805 = 0 + r.EncodeMapStart(yynn3796) + yynn3796 = 0 } - if yyr3805 || yy2arr3805 { + if yyr3796 || yy2arr3796 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3805[0] { - yym3807 := z.EncBinary() - _ = yym3807 + if yyq3796[0] { + yym3798 := z.EncBinary() + _ = yym3798 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47768,23 +47686,23 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3805[0] { + if yyq3796[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3808 := z.EncBinary() - _ = yym3808 + yym3799 := z.EncBinary() + _ = yym3799 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3805 || yy2arr3805 { + if yyr3796 || yy2arr3796 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3805[1] { - yym3810 := z.EncBinary() - _ = yym3810 + if yyq3796[1] { + yym3801 := z.EncBinary() + _ = yym3801 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -47793,22 +47711,22 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3805[1] { + if yyq3796[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3811 := z.EncBinary() - _ = yym3811 + yym3802 := z.EncBinary() + _ = yym3802 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3805 || yy2arr3805 { + if yyr3796 || yy2arr3796 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3813 := z.EncBinary() - _ = yym3813 + yym3804 := z.EncBinary() + _ = yym3804 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -47817,14 +47735,14 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3814 := z.EncBinary() - _ = yym3814 + yym3805 := z.EncBinary() + _ = yym3805 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } - if yyr3805 || yy2arr3805 { + if yyr3796 || yy2arr3796 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47837,25 +47755,25 @@ func (x *ServiceProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3815 := z.DecBinary() - _ = yym3815 + yym3806 := z.DecBinary() + _ = yym3806 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3816 := r.ContainerType() - if yyct3816 == codecSelferValueTypeMap1234 { - yyl3816 := r.ReadMapStart() - if yyl3816 == 0 { + yyct3807 := r.ContainerType() + if yyct3807 == codecSelferValueTypeMap1234 { + yyl3807 := r.ReadMapStart() + if yyl3807 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3816, d) + x.codecDecodeSelfFromMap(yyl3807, d) } - } else if yyct3816 == codecSelferValueTypeArray1234 { - yyl3816 := r.ReadArrayStart() - if yyl3816 == 0 { + } else if yyct3807 == codecSelferValueTypeArray1234 { + yyl3807 := r.ReadArrayStart() + if yyl3807 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3816, d) + x.codecDecodeSelfFromArray(yyl3807, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47867,12 +47785,12 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3817Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3817Slc - var yyhl3817 bool = l >= 0 - for yyj3817 := 0; ; yyj3817++ { - if yyhl3817 { - if yyj3817 >= l { + var yys3808Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3808Slc + var yyhl3808 bool = l >= 0 + for yyj3808 := 0; ; yyj3808++ { + if yyhl3808 { + if yyj3808 >= l { break } } else { @@ -47881,10 +47799,10 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3817Slc = r.DecodeBytes(yys3817Slc, true, true) - yys3817 := string(yys3817Slc) + yys3808Slc = r.DecodeBytes(yys3808Slc, true, true) + yys3808 := string(yys3808Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3817 { + switch yys3808 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47904,9 +47822,9 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3817) - } // end switch yys3817 - } // end for yyj3817 + z.DecStructFieldNotFound(-1, yys3808) + } // end switch yys3808 + } // end for yyj3808 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47914,16 +47832,16 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3821 int - var yyb3821 bool - var yyhl3821 bool = l >= 0 - yyj3821++ - if yyhl3821 { - yyb3821 = yyj3821 > l + var yyj3812 int + var yyb3812 bool + var yyhl3812 bool = l >= 0 + yyj3812++ + if yyhl3812 { + yyb3812 = yyj3812 > l } else { - yyb3821 = r.CheckBreak() + yyb3812 = r.CheckBreak() } - if yyb3821 { + if yyb3812 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47933,13 +47851,13 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj3821++ - if yyhl3821 { - yyb3821 = yyj3821 > l + yyj3812++ + if yyhl3812 { + yyb3812 = yyj3812 > l } else { - yyb3821 = r.CheckBreak() + yyb3812 = r.CheckBreak() } - if yyb3821 { + if yyb3812 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47949,13 +47867,13 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj3821++ - if yyhl3821 { - yyb3821 = yyj3821 > l + yyj3812++ + if yyhl3812 { + yyb3812 = yyj3812 > l } else { - yyb3821 = r.CheckBreak() + yyb3812 = r.CheckBreak() } - if yyb3821 { + if yyb3812 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47966,17 +47884,17 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Path = string(r.DecodeString()) } for { - yyj3821++ - if yyhl3821 { - yyb3821 = yyj3821 > l + yyj3812++ + if yyhl3812 { + yyb3812 = yyj3812 > l } else { - yyb3821 = r.CheckBreak() + yyb3812 = r.CheckBreak() } - if yyb3821 { + if yyb3812 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3821-1, "") + z.DecStructFieldNotFound(yyj3812-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47988,34 +47906,34 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3825 := z.EncBinary() - _ = yym3825 + yym3816 := z.EncBinary() + _ = yym3816 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3826 := !z.EncBinary() - yy2arr3826 := z.EncBasicHandle().StructToArray - var yyq3826 [5]bool - _, _, _ = yysep3826, yyq3826, yy2arr3826 - const yyr3826 bool = false - yyq3826[4] = x.Controller != nil - var yynn3826 int - if yyr3826 || yy2arr3826 { + yysep3817 := !z.EncBinary() + yy2arr3817 := z.EncBasicHandle().StructToArray + var yyq3817 [5]bool + _, _, _ = yysep3817, yyq3817, yy2arr3817 + const yyr3817 bool = false + yyq3817[4] = x.Controller != nil + var yynn3817 int + if yyr3817 || yy2arr3817 { r.EncodeArrayStart(5) } else { - yynn3826 = 4 - for _, b := range yyq3826 { + yynn3817 = 4 + for _, b := range yyq3817 { if b { - yynn3826++ + yynn3817++ } } - r.EncodeMapStart(yynn3826) - yynn3826 = 0 + r.EncodeMapStart(yynn3817) + yynn3817 = 0 } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3828 := z.EncBinary() - _ = yym3828 + yym3819 := z.EncBinary() + _ = yym3819 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -48024,17 +47942,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3829 := z.EncBinary() - _ = yym3829 + yym3820 := z.EncBinary() + _ = yym3820 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3831 := z.EncBinary() - _ = yym3831 + yym3822 := z.EncBinary() + _ = yym3822 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -48043,17 +47961,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3832 := z.EncBinary() - _ = yym3832 + yym3823 := z.EncBinary() + _ = yym3823 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3834 := z.EncBinary() - _ = yym3834 + yym3825 := z.EncBinary() + _ = yym3825 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -48062,17 +47980,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3835 := z.EncBinary() - _ = yym3835 + yym3826 := z.EncBinary() + _ = yym3826 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3837 := z.EncBinary() - _ = yym3837 + yym3828 := z.EncBinary() + _ = yym3828 if false { } else if z.HasExtensions() && z.EncExt(x.UID) { } else { @@ -48082,50 +48000,50 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("uid")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3838 := z.EncBinary() - _ = yym3838 + yym3829 := z.EncBinary() + _ = yym3829 if false { } else if z.HasExtensions() && z.EncExt(x.UID) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.UID)) } } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3826[4] { + if yyq3817[4] { if x.Controller == nil { r.EncodeNil() } else { - yy3840 := *x.Controller - yym3841 := z.EncBinary() - _ = yym3841 + yy3831 := *x.Controller + yym3832 := z.EncBinary() + _ = yym3832 if false { } else { - r.EncodeBool(bool(yy3840)) + r.EncodeBool(bool(yy3831)) } } } else { r.EncodeNil() } } else { - if yyq3826[4] { + if yyq3817[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("controller")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Controller == nil { r.EncodeNil() } else { - yy3842 := *x.Controller - yym3843 := z.EncBinary() - _ = yym3843 + yy3833 := *x.Controller + yym3834 := z.EncBinary() + _ = yym3834 if false { } else { - r.EncodeBool(bool(yy3842)) + r.EncodeBool(bool(yy3833)) } } } } - if yyr3826 || yy2arr3826 { + if yyr3817 || yy2arr3817 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48138,25 +48056,25 @@ func (x *OwnerReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3844 := z.DecBinary() - _ = yym3844 + yym3835 := z.DecBinary() + _ = yym3835 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3845 := r.ContainerType() - if yyct3845 == codecSelferValueTypeMap1234 { - yyl3845 := r.ReadMapStart() - if yyl3845 == 0 { + yyct3836 := r.ContainerType() + if yyct3836 == codecSelferValueTypeMap1234 { + yyl3836 := r.ReadMapStart() + if yyl3836 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3845, d) + x.codecDecodeSelfFromMap(yyl3836, d) } - } else if yyct3845 == codecSelferValueTypeArray1234 { - yyl3845 := r.ReadArrayStart() - if yyl3845 == 0 { + } else if yyct3836 == codecSelferValueTypeArray1234 { + yyl3836 := r.ReadArrayStart() + if yyl3836 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3845, d) + x.codecDecodeSelfFromArray(yyl3836, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48168,12 +48086,12 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3846Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3846Slc - var yyhl3846 bool = l >= 0 - for yyj3846 := 0; ; yyj3846++ { - if yyhl3846 { - if yyj3846 >= l { + var yys3837Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3837Slc + var yyhl3837 bool = l >= 0 + for yyj3837 := 0; ; yyj3837++ { + if yyhl3837 { + if yyj3837 >= l { break } } else { @@ -48182,10 +48100,10 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3846Slc = r.DecodeBytes(yys3846Slc, true, true) - yys3846 := string(yys3846Slc) + yys3837Slc = r.DecodeBytes(yys3837Slc, true, true) + yys3837 := string(yys3837Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3846 { + switch yys3837 { case "apiVersion": if r.TryDecodeAsNil() { x.APIVersion = "" @@ -48219,17 +48137,17 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Controller == nil { x.Controller = new(bool) } - yym3852 := z.DecBinary() - _ = yym3852 + yym3843 := z.DecBinary() + _ = yym3843 if false { } else { *((*bool)(x.Controller)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys3846) - } // end switch yys3846 - } // end for yyj3846 + z.DecStructFieldNotFound(-1, yys3837) + } // end switch yys3837 + } // end for yyj3837 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48237,16 +48155,16 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3853 int - var yyb3853 bool - var yyhl3853 bool = l >= 0 - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + var yyj3844 int + var yyb3844 bool + var yyhl3844 bool = l >= 0 + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48256,13 +48174,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48272,13 +48190,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48288,13 +48206,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48304,13 +48222,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.UID = pkg1_types.UID(r.DecodeString()) } - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48323,25 +48241,25 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Controller == nil { x.Controller = new(bool) } - yym3859 := z.DecBinary() - _ = yym3859 + yym3850 := z.DecBinary() + _ = yym3850 if false { } else { *((*bool)(x.Controller)) = r.DecodeBool() } } for { - yyj3853++ - if yyhl3853 { - yyb3853 = yyj3853 > l + yyj3844++ + if yyhl3844 { + yyb3844 = yyj3844 > l } else { - yyb3853 = r.CheckBreak() + yyb3844 = r.CheckBreak() } - if yyb3853 { + if yyb3844 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3853-1, "") + z.DecStructFieldNotFound(yyj3844-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48353,41 +48271,41 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3860 := z.EncBinary() - _ = yym3860 + yym3851 := z.EncBinary() + _ = yym3851 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3861 := !z.EncBinary() - yy2arr3861 := z.EncBasicHandle().StructToArray - var yyq3861 [7]bool - _, _, _ = yysep3861, yyq3861, yy2arr3861 - const yyr3861 bool = false - yyq3861[0] = x.Kind != "" - yyq3861[1] = x.Namespace != "" - yyq3861[2] = x.Name != "" - yyq3861[3] = x.UID != "" - yyq3861[4] = x.APIVersion != "" - yyq3861[5] = x.ResourceVersion != "" - yyq3861[6] = x.FieldPath != "" - var yynn3861 int - if yyr3861 || yy2arr3861 { + yysep3852 := !z.EncBinary() + yy2arr3852 := z.EncBasicHandle().StructToArray + var yyq3852 [7]bool + _, _, _ = yysep3852, yyq3852, yy2arr3852 + const yyr3852 bool = false + yyq3852[0] = x.Kind != "" + yyq3852[1] = x.Namespace != "" + yyq3852[2] = x.Name != "" + yyq3852[3] = x.UID != "" + yyq3852[4] = x.APIVersion != "" + yyq3852[5] = x.ResourceVersion != "" + yyq3852[6] = x.FieldPath != "" + var yynn3852 int + if yyr3852 || yy2arr3852 { r.EncodeArrayStart(7) } else { - yynn3861 = 0 - for _, b := range yyq3861 { + yynn3852 = 0 + for _, b := range yyq3852 { if b { - yynn3861++ + yynn3852++ } } - r.EncodeMapStart(yynn3861) - yynn3861 = 0 + r.EncodeMapStart(yynn3852) + yynn3852 = 0 } - if yyr3861 || yy2arr3861 { + if yyr3852 || yy2arr3852 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[0] { - yym3863 := z.EncBinary() - _ = yym3863 + if yyq3852[0] { + yym3854 := z.EncBinary() + _ = yym3854 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -48396,23 +48314,23 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3861[0] { + if yyq3852[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3864 := z.EncBinary() - _ = yym3864 + yym3855 := z.EncBinary() + _ = yym3855 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3861 || yy2arr3861 { + if yyr3852 || yy2arr3852 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[1] { - yym3866 := z.EncBinary() - _ = yym3866 + if yyq3852[1] { + yym3857 := z.EncBinary() + _ = yym3857 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) @@ -48421,146 +48339,146 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3861[1] { + if yyq3852[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("namespace")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3858 := z.EncBinary() + _ = yym3858 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) + } + } + } + if yyr3852 || yy2arr3852 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3852[2] { + yym3860 := z.EncBinary() + _ = yym3860 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3852[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("name")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3861 := z.EncBinary() + _ = yym3861 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + } + } + } + if yyr3852 || yy2arr3852 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3852[3] { + yym3863 := z.EncBinary() + _ = yym3863 + if false { + } else if z.HasExtensions() && z.EncExt(x.UID) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3852[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("uid")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3864 := z.EncBinary() + _ = yym3864 + if false { + } else if z.HasExtensions() && z.EncExt(x.UID) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + } + } + } + if yyr3852 || yy2arr3852 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3852[4] { + yym3866 := z.EncBinary() + _ = yym3866 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3852[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3867 := z.EncBinary() _ = yym3867 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3861 || yy2arr3861 { + if yyr3852 || yy2arr3852 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[2] { + if yyq3852[5] { yym3869 := z.EncBinary() _ = yym3869 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3861[2] { + if yyq3852[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("name")) + r.EncodeString(codecSelferC_UTF81234, string("resourceVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3870 := z.EncBinary() _ = yym3870 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } } - if yyr3861 || yy2arr3861 { + if yyr3852 || yy2arr3852 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[3] { + if yyq3852[6] { yym3872 := z.EncBinary() _ = yym3872 if false { - } else if z.HasExtensions() && z.EncExt(x.UID) { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3861[3] { + if yyq3852[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("uid")) + r.EncodeString(codecSelferC_UTF81234, string("fieldPath")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3873 := z.EncBinary() _ = yym3873 if false { - } else if z.HasExtensions() && z.EncExt(x.UID) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.UID)) - } - } - } - if yyr3861 || yy2arr3861 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[4] { - yym3875 := z.EncBinary() - _ = yym3875 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3861[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3876 := z.EncBinary() - _ = yym3876 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr3861 || yy2arr3861 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[5] { - yym3878 := z.EncBinary() - _ = yym3878 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3861[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("resourceVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3879 := z.EncBinary() - _ = yym3879 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) - } - } - } - if yyr3861 || yy2arr3861 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3861[6] { - yym3881 := z.EncBinary() - _ = yym3881 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3861[6] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("fieldPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3882 := z.EncBinary() - _ = yym3882 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) } } } - if yyr3861 || yy2arr3861 { + if yyr3852 || yy2arr3852 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48573,25 +48491,25 @@ func (x *ObjectReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3883 := z.DecBinary() - _ = yym3883 + yym3874 := z.DecBinary() + _ = yym3874 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3884 := r.ContainerType() - if yyct3884 == codecSelferValueTypeMap1234 { - yyl3884 := r.ReadMapStart() - if yyl3884 == 0 { + yyct3875 := r.ContainerType() + if yyct3875 == codecSelferValueTypeMap1234 { + yyl3875 := r.ReadMapStart() + if yyl3875 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3884, d) + x.codecDecodeSelfFromMap(yyl3875, d) } - } else if yyct3884 == codecSelferValueTypeArray1234 { - yyl3884 := r.ReadArrayStart() - if yyl3884 == 0 { + } else if yyct3875 == codecSelferValueTypeArray1234 { + yyl3875 := r.ReadArrayStart() + if yyl3875 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3884, d) + x.codecDecodeSelfFromArray(yyl3875, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48603,12 +48521,12 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3885Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3885Slc - var yyhl3885 bool = l >= 0 - for yyj3885 := 0; ; yyj3885++ { - if yyhl3885 { - if yyj3885 >= l { + var yys3876Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3876Slc + var yyhl3876 bool = l >= 0 + for yyj3876 := 0; ; yyj3876++ { + if yyhl3876 { + if yyj3876 >= l { break } } else { @@ -48617,10 +48535,10 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3885Slc = r.DecodeBytes(yys3885Slc, true, true) - yys3885 := string(yys3885Slc) + yys3876Slc = r.DecodeBytes(yys3876Slc, true, true) + yys3876 := string(yys3876Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3885 { + switch yys3876 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -48664,9 +48582,9 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.FieldPath = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3885) - } // end switch yys3885 - } // end for yyj3885 + z.DecStructFieldNotFound(-1, yys3876) + } // end switch yys3876 + } // end for yyj3876 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48674,16 +48592,16 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3893 int - var yyb3893 bool - var yyhl3893 bool = l >= 0 - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + var yyj3884 int + var yyb3884 bool + var yyhl3884 bool = l >= 0 + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48693,13 +48611,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48709,13 +48627,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Namespace = string(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48725,13 +48643,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Name = string(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48741,13 +48659,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UID = pkg1_types.UID(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48757,13 +48675,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48773,13 +48691,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ResourceVersion = string(r.DecodeString()) } - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48790,17 +48708,17 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.FieldPath = string(r.DecodeString()) } for { - yyj3893++ - if yyhl3893 { - yyb3893 = yyj3893 > l + yyj3884++ + if yyhl3884 { + yyb3884 = yyj3884 > l } else { - yyb3893 = r.CheckBreak() + yyb3884 = r.CheckBreak() } - if yyb3893 { + if yyb3884 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3893-1, "") + z.DecStructFieldNotFound(yyj3884-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48812,33 +48730,33 @@ func (x *LocalObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3901 := z.EncBinary() - _ = yym3901 + yym3892 := z.EncBinary() + _ = yym3892 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3902 := !z.EncBinary() - yy2arr3902 := z.EncBasicHandle().StructToArray - var yyq3902 [1]bool - _, _, _ = yysep3902, yyq3902, yy2arr3902 - const yyr3902 bool = false - var yynn3902 int - if yyr3902 || yy2arr3902 { + yysep3893 := !z.EncBinary() + yy2arr3893 := z.EncBasicHandle().StructToArray + var yyq3893 [1]bool + _, _, _ = yysep3893, yyq3893, yy2arr3893 + const yyr3893 bool = false + var yynn3893 int + if yyr3893 || yy2arr3893 { r.EncodeArrayStart(1) } else { - yynn3902 = 1 - for _, b := range yyq3902 { + yynn3893 = 1 + for _, b := range yyq3893 { if b { - yynn3902++ + yynn3893++ } } - r.EncodeMapStart(yynn3902) - yynn3902 = 0 + r.EncodeMapStart(yynn3893) + yynn3893 = 0 } - if yyr3902 || yy2arr3902 { + if yyr3893 || yy2arr3893 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3904 := z.EncBinary() - _ = yym3904 + yym3895 := z.EncBinary() + _ = yym3895 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -48847,14 +48765,14 @@ func (x *LocalObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3905 := z.EncBinary() - _ = yym3905 + yym3896 := z.EncBinary() + _ = yym3896 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr3902 || yy2arr3902 { + if yyr3893 || yy2arr3893 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48867,25 +48785,25 @@ func (x *LocalObjectReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3906 := z.DecBinary() - _ = yym3906 + yym3897 := z.DecBinary() + _ = yym3897 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3907 := r.ContainerType() - if yyct3907 == codecSelferValueTypeMap1234 { - yyl3907 := r.ReadMapStart() - if yyl3907 == 0 { + yyct3898 := r.ContainerType() + if yyct3898 == codecSelferValueTypeMap1234 { + yyl3898 := r.ReadMapStart() + if yyl3898 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3907, d) + x.codecDecodeSelfFromMap(yyl3898, d) } - } else if yyct3907 == codecSelferValueTypeArray1234 { - yyl3907 := r.ReadArrayStart() - if yyl3907 == 0 { + } else if yyct3898 == codecSelferValueTypeArray1234 { + yyl3898 := r.ReadArrayStart() + if yyl3898 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3907, d) + x.codecDecodeSelfFromArray(yyl3898, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48897,12 +48815,12 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3908Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3908Slc - var yyhl3908 bool = l >= 0 - for yyj3908 := 0; ; yyj3908++ { - if yyhl3908 { - if yyj3908 >= l { + var yys3899Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3899Slc + var yyhl3899 bool = l >= 0 + for yyj3899 := 0; ; yyj3899++ { + if yyhl3899 { + if yyj3899 >= l { break } } else { @@ -48911,10 +48829,10 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3908Slc = r.DecodeBytes(yys3908Slc, true, true) - yys3908 := string(yys3908Slc) + yys3899Slc = r.DecodeBytes(yys3899Slc, true, true) + yys3899 := string(yys3899Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3908 { + switch yys3899 { case "Name": if r.TryDecodeAsNil() { x.Name = "" @@ -48922,9 +48840,9 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode x.Name = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3908) - } // end switch yys3908 - } // end for yyj3908 + z.DecStructFieldNotFound(-1, yys3899) + } // end switch yys3899 + } // end for yyj3899 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48932,16 +48850,16 @@ func (x *LocalObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3910 int - var yyb3910 bool - var yyhl3910 bool = l >= 0 - yyj3910++ - if yyhl3910 { - yyb3910 = yyj3910 > l + var yyj3901 int + var yyb3901 bool + var yyhl3901 bool = l >= 0 + yyj3901++ + if yyhl3901 { + yyb3901 = yyj3901 > l } else { - yyb3910 = r.CheckBreak() + yyb3901 = r.CheckBreak() } - if yyb3910 { + if yyb3901 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48952,17 +48870,17 @@ func (x *LocalObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Deco x.Name = string(r.DecodeString()) } for { - yyj3910++ - if yyhl3910 { - yyb3910 = yyj3910 > l + yyj3901++ + if yyhl3901 { + yyb3901 = yyj3901 > l } else { - yyb3910 = r.CheckBreak() + yyb3901 = r.CheckBreak() } - if yyb3910 { + if yyb3901 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3910-1, "") + z.DecStructFieldNotFound(yyj3901-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48974,37 +48892,37 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3912 := z.EncBinary() - _ = yym3912 + yym3903 := z.EncBinary() + _ = yym3903 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3913 := !z.EncBinary() - yy2arr3913 := z.EncBasicHandle().StructToArray - var yyq3913 [3]bool - _, _, _ = yysep3913, yyq3913, yy2arr3913 - const yyr3913 bool = false - yyq3913[0] = x.Kind != "" - yyq3913[1] = x.APIVersion != "" - yyq3913[2] = true - var yynn3913 int - if yyr3913 || yy2arr3913 { + yysep3904 := !z.EncBinary() + yy2arr3904 := z.EncBasicHandle().StructToArray + var yyq3904 [3]bool + _, _, _ = yysep3904, yyq3904, yy2arr3904 + const yyr3904 bool = false + yyq3904[0] = x.Kind != "" + yyq3904[1] = x.APIVersion != "" + yyq3904[2] = true + var yynn3904 int + if yyr3904 || yy2arr3904 { r.EncodeArrayStart(3) } else { - yynn3913 = 0 - for _, b := range yyq3913 { + yynn3904 = 0 + for _, b := range yyq3904 { if b { - yynn3913++ + yynn3904++ } } - r.EncodeMapStart(yynn3913) - yynn3913 = 0 + r.EncodeMapStart(yynn3904) + yynn3904 = 0 } - if yyr3913 || yy2arr3913 { + if yyr3904 || yy2arr3904 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3913[0] { - yym3915 := z.EncBinary() - _ = yym3915 + if yyq3904[0] { + yym3906 := z.EncBinary() + _ = yym3906 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -49013,23 +48931,23 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3913[0] { + if yyq3904[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3916 := z.EncBinary() - _ = yym3916 + yym3907 := z.EncBinary() + _ = yym3907 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3913 || yy2arr3913 { + if yyr3904 || yy2arr3904 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3913[1] { - yym3918 := z.EncBinary() - _ = yym3918 + if yyq3904[1] { + yym3909 := z.EncBinary() + _ = yym3909 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -49038,36 +48956,36 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3913[1] { + if yyq3904[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3919 := z.EncBinary() - _ = yym3919 + yym3910 := z.EncBinary() + _ = yym3910 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3913 || yy2arr3913 { + if yyr3904 || yy2arr3904 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3913[2] { - yy3921 := &x.Reference - yy3921.CodecEncodeSelf(e) + if yyq3904[2] { + yy3912 := &x.Reference + yy3912.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3913[2] { + if yyq3904[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reference")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3922 := &x.Reference - yy3922.CodecEncodeSelf(e) + yy3913 := &x.Reference + yy3913.CodecEncodeSelf(e) } } - if yyr3913 || yy2arr3913 { + if yyr3904 || yy2arr3904 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -49080,25 +48998,25 @@ func (x *SerializedReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3923 := z.DecBinary() - _ = yym3923 + yym3914 := z.DecBinary() + _ = yym3914 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3924 := r.ContainerType() - if yyct3924 == codecSelferValueTypeMap1234 { - yyl3924 := r.ReadMapStart() - if yyl3924 == 0 { + yyct3915 := r.ContainerType() + if yyct3915 == codecSelferValueTypeMap1234 { + yyl3915 := r.ReadMapStart() + if yyl3915 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3924, d) + x.codecDecodeSelfFromMap(yyl3915, d) } - } else if yyct3924 == codecSelferValueTypeArray1234 { - yyl3924 := r.ReadArrayStart() - if yyl3924 == 0 { + } else if yyct3915 == codecSelferValueTypeArray1234 { + yyl3915 := r.ReadArrayStart() + if yyl3915 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3924, d) + x.codecDecodeSelfFromArray(yyl3915, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -49110,12 +49028,12 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3925Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3925Slc - var yyhl3925 bool = l >= 0 - for yyj3925 := 0; ; yyj3925++ { - if yyhl3925 { - if yyj3925 >= l { + var yys3916Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3916Slc + var yyhl3916 bool = l >= 0 + for yyj3916 := 0; ; yyj3916++ { + if yyhl3916 { + if yyj3916 >= l { break } } else { @@ -49124,10 +49042,10 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3925Slc = r.DecodeBytes(yys3925Slc, true, true) - yys3925 := string(yys3925Slc) + yys3916Slc = r.DecodeBytes(yys3916Slc, true, true) + yys3916 := string(yys3916Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3925 { + switch yys3916 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -49144,13 +49062,13 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Reference = ObjectReference{} } else { - yyv3928 := &x.Reference - yyv3928.CodecDecodeSelf(d) + yyv3919 := &x.Reference + yyv3919.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3925) - } // end switch yys3925 - } // end for yyj3925 + z.DecStructFieldNotFound(-1, yys3916) + } // end switch yys3916 + } // end for yyj3916 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -49158,16 +49076,16 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3929 int - var yyb3929 bool - var yyhl3929 bool = l >= 0 - yyj3929++ - if yyhl3929 { - yyb3929 = yyj3929 > l + var yyj3920 int + var yyb3920 bool + var yyhl3920 bool = l >= 0 + yyj3920++ + if yyhl3920 { + yyb3920 = yyj3920 > l } else { - yyb3929 = r.CheckBreak() + yyb3920 = r.CheckBreak() } - if yyb3929 { + if yyb3920 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49177,13 +49095,13 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj3929++ - if yyhl3929 { - yyb3929 = yyj3929 > l + yyj3920++ + if yyhl3920 { + yyb3920 = yyj3920 > l } else { - yyb3929 = r.CheckBreak() + yyb3920 = r.CheckBreak() } - if yyb3929 { + if yyb3920 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49193,13 +49111,13 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj3929++ - if yyhl3929 { - yyb3929 = yyj3929 > l + yyj3920++ + if yyhl3920 { + yyb3920 = yyj3920 > l } else { - yyb3929 = r.CheckBreak() + yyb3920 = r.CheckBreak() } - if yyb3929 { + if yyb3920 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49207,21 +49125,21 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Reference = ObjectReference{} } else { - yyv3932 := &x.Reference - yyv3932.CodecDecodeSelf(d) + yyv3923 := &x.Reference + yyv3923.CodecDecodeSelf(d) } for { - yyj3929++ - if yyhl3929 { - yyb3929 = yyj3929 > l + yyj3920++ + if yyhl3920 { + yyb3920 = yyj3920 > l } else { - yyb3929 = r.CheckBreak() + yyb3920 = r.CheckBreak() } - if yyb3929 { + if yyb3920 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3929-1, "") + z.DecStructFieldNotFound(yyj3920-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -49233,36 +49151,36 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3933 := z.EncBinary() - _ = yym3933 + yym3924 := z.EncBinary() + _ = yym3924 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3934 := !z.EncBinary() - yy2arr3934 := z.EncBasicHandle().StructToArray - var yyq3934 [2]bool - _, _, _ = yysep3934, yyq3934, yy2arr3934 - const yyr3934 bool = false - yyq3934[0] = x.Component != "" - yyq3934[1] = x.Host != "" - var yynn3934 int - if yyr3934 || yy2arr3934 { + yysep3925 := !z.EncBinary() + yy2arr3925 := z.EncBasicHandle().StructToArray + var yyq3925 [2]bool + _, _, _ = yysep3925, yyq3925, yy2arr3925 + const yyr3925 bool = false + yyq3925[0] = x.Component != "" + yyq3925[1] = x.Host != "" + var yynn3925 int + if yyr3925 || yy2arr3925 { r.EncodeArrayStart(2) } else { - yynn3934 = 0 - for _, b := range yyq3934 { + yynn3925 = 0 + for _, b := range yyq3925 { if b { - yynn3934++ + yynn3925++ } } - r.EncodeMapStart(yynn3934) - yynn3934 = 0 + r.EncodeMapStart(yynn3925) + yynn3925 = 0 } - if yyr3934 || yy2arr3934 { + if yyr3925 || yy2arr3925 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3934[0] { - yym3936 := z.EncBinary() - _ = yym3936 + if yyq3925[0] { + yym3927 := z.EncBinary() + _ = yym3927 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Component)) @@ -49271,23 +49189,23 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3934[0] { + if yyq3925[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("component")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3937 := z.EncBinary() - _ = yym3937 + yym3928 := z.EncBinary() + _ = yym3928 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Component)) } } } - if yyr3934 || yy2arr3934 { + if yyr3925 || yy2arr3925 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3934[1] { - yym3939 := z.EncBinary() - _ = yym3939 + if yyq3925[1] { + yym3930 := z.EncBinary() + _ = yym3930 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) @@ -49296,19 +49214,19 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3934[1] { + if yyq3925[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("host")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3940 := z.EncBinary() - _ = yym3940 + yym3931 := z.EncBinary() + _ = yym3931 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) } } } - if yyr3934 || yy2arr3934 { + if yyr3925 || yy2arr3925 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -49321,25 +49239,25 @@ func (x *EventSource) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3941 := z.DecBinary() - _ = yym3941 + yym3932 := z.DecBinary() + _ = yym3932 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3942 := r.ContainerType() - if yyct3942 == codecSelferValueTypeMap1234 { - yyl3942 := r.ReadMapStart() - if yyl3942 == 0 { + yyct3933 := r.ContainerType() + if yyct3933 == codecSelferValueTypeMap1234 { + yyl3933 := r.ReadMapStart() + if yyl3933 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3942, d) + x.codecDecodeSelfFromMap(yyl3933, d) } - } else if yyct3942 == codecSelferValueTypeArray1234 { - yyl3942 := r.ReadArrayStart() - if yyl3942 == 0 { + } else if yyct3933 == codecSelferValueTypeArray1234 { + yyl3933 := r.ReadArrayStart() + if yyl3933 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3942, d) + x.codecDecodeSelfFromArray(yyl3933, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -49351,12 +49269,12 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3943Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3943Slc - var yyhl3943 bool = l >= 0 - for yyj3943 := 0; ; yyj3943++ { - if yyhl3943 { - if yyj3943 >= l { + var yys3934Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3934Slc + var yyhl3934 bool = l >= 0 + for yyj3934 := 0; ; yyj3934++ { + if yyhl3934 { + if yyj3934 >= l { break } } else { @@ -49365,10 +49283,10 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3943Slc = r.DecodeBytes(yys3943Slc, true, true) - yys3943 := string(yys3943Slc) + yys3934Slc = r.DecodeBytes(yys3934Slc, true, true) + yys3934 := string(yys3934Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3943 { + switch yys3934 { case "component": if r.TryDecodeAsNil() { x.Component = "" @@ -49382,9 +49300,9 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Host = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3943) - } // end switch yys3943 - } // end for yyj3943 + z.DecStructFieldNotFound(-1, yys3934) + } // end switch yys3934 + } // end for yyj3934 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -49392,16 +49310,16 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3946 int - var yyb3946 bool - var yyhl3946 bool = l >= 0 - yyj3946++ - if yyhl3946 { - yyb3946 = yyj3946 > l + var yyj3937 int + var yyb3937 bool + var yyhl3937 bool = l >= 0 + yyj3937++ + if yyhl3937 { + yyb3937 = yyj3937 > l } else { - yyb3946 = r.CheckBreak() + yyb3937 = r.CheckBreak() } - if yyb3946 { + if yyb3937 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49411,13 +49329,13 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Component = string(r.DecodeString()) } - yyj3946++ - if yyhl3946 { - yyb3946 = yyj3946 > l + yyj3937++ + if yyhl3937 { + yyb3937 = yyj3937 > l } else { - yyb3946 = r.CheckBreak() + yyb3937 = r.CheckBreak() } - if yyb3946 { + if yyb3937 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49428,17 +49346,17 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Host = string(r.DecodeString()) } for { - yyj3946++ - if yyhl3946 { - yyb3946 = yyj3946 > l + yyj3937++ + if yyhl3937 { + yyb3937 = yyj3937 > l } else { - yyb3946 = r.CheckBreak() + yyb3937 = r.CheckBreak() } - if yyb3946 { + if yyb3937 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3946-1, "") + z.DecStructFieldNotFound(yyj3937-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -49450,45 +49368,45 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3949 := z.EncBinary() - _ = yym3949 + yym3940 := z.EncBinary() + _ = yym3940 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3950 := !z.EncBinary() - yy2arr3950 := z.EncBasicHandle().StructToArray - var yyq3950 [11]bool - _, _, _ = yysep3950, yyq3950, yy2arr3950 - const yyr3950 bool = false - yyq3950[0] = x.Kind != "" - yyq3950[1] = x.APIVersion != "" - yyq3950[2] = true - yyq3950[3] = true - yyq3950[4] = x.Reason != "" - yyq3950[5] = x.Message != "" - yyq3950[6] = true - yyq3950[7] = true - yyq3950[8] = true - yyq3950[9] = x.Count != 0 - yyq3950[10] = x.Type != "" - var yynn3950 int - if yyr3950 || yy2arr3950 { + yysep3941 := !z.EncBinary() + yy2arr3941 := z.EncBasicHandle().StructToArray + var yyq3941 [11]bool + _, _, _ = yysep3941, yyq3941, yy2arr3941 + const yyr3941 bool = false + yyq3941[0] = x.Kind != "" + yyq3941[1] = x.APIVersion != "" + yyq3941[2] = true + yyq3941[3] = true + yyq3941[4] = x.Reason != "" + yyq3941[5] = x.Message != "" + yyq3941[6] = true + yyq3941[7] = true + yyq3941[8] = true + yyq3941[9] = x.Count != 0 + yyq3941[10] = x.Type != "" + var yynn3941 int + if yyr3941 || yy2arr3941 { r.EncodeArrayStart(11) } else { - yynn3950 = 0 - for _, b := range yyq3950 { + yynn3941 = 0 + for _, b := range yyq3941 { if b { - yynn3950++ + yynn3941++ } } - r.EncodeMapStart(yynn3950) - yynn3950 = 0 + r.EncodeMapStart(yynn3941) + yynn3941 = 0 } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[0] { - yym3952 := z.EncBinary() - _ = yym3952 + if yyq3941[0] { + yym3943 := z.EncBinary() + _ = yym3943 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -49497,23 +49415,23 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3950[0] { + if yyq3941[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3953 := z.EncBinary() - _ = yym3953 + yym3944 := z.EncBinary() + _ = yym3944 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[1] { - yym3955 := z.EncBinary() - _ = yym3955 + if yyq3941[1] { + yym3946 := z.EncBinary() + _ = yym3946 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -49522,198 +49440,198 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3950[1] { + if yyq3941[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3947 := z.EncBinary() + _ = yym3947 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3941 || yy2arr3941 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3941[2] { + yy3949 := &x.ObjectMeta + yy3949.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq3941[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy3950 := &x.ObjectMeta + yy3950.CodecEncodeSelf(e) + } + } + if yyr3941 || yy2arr3941 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3941[3] { + yy3952 := &x.InvolvedObject + yy3952.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq3941[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("involvedObject")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy3953 := &x.InvolvedObject + yy3953.CodecEncodeSelf(e) + } + } + if yyr3941 || yy2arr3941 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3941[4] { + yym3955 := z.EncBinary() + _ = yym3955 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3941[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3956 := z.EncBinary() _ = yym3956 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[2] { - yy3958 := &x.ObjectMeta - yy3958.CodecEncodeSelf(e) + if yyq3941[5] { + yym3958 := z.EncBinary() + _ = yym3958 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } } else { - r.EncodeNil() + r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3950[2] { + if yyq3941[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) + r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3959 := &x.ObjectMeta - yy3959.CodecEncodeSelf(e) + yym3959 := z.EncBinary() + _ = yym3959 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[3] { - yy3961 := &x.InvolvedObject + if yyq3941[6] { + yy3961 := &x.Source yy3961.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3950[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("involvedObject")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3962 := &x.InvolvedObject - yy3962.CodecEncodeSelf(e) - } - } - if yyr3950 || yy2arr3950 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[4] { - yym3964 := z.EncBinary() - _ = yym3964 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3950[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("reason")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3965 := z.EncBinary() - _ = yym3965 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } - } - if yyr3950 || yy2arr3950 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[5] { - yym3967 := z.EncBinary() - _ = yym3967 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Message)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3950[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("message")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3968 := z.EncBinary() - _ = yym3968 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Message)) - } - } - } - if yyr3950 || yy2arr3950 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[6] { - yy3970 := &x.Source - yy3970.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq3950[6] { + if yyq3941[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("source")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3971 := &x.Source - yy3971.CodecEncodeSelf(e) + yy3962 := &x.Source + yy3962.CodecEncodeSelf(e) } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[7] { - yy3973 := &x.FirstTimestamp - yym3974 := z.EncBinary() - _ = yym3974 + if yyq3941[7] { + yy3964 := &x.FirstTimestamp + yym3965 := z.EncBinary() + _ = yym3965 if false { - } else if z.HasExtensions() && z.EncExt(yy3973) { - } else if yym3974 { - z.EncBinaryMarshal(yy3973) - } else if !yym3974 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3973) + } else if z.HasExtensions() && z.EncExt(yy3964) { + } else if yym3965 { + z.EncBinaryMarshal(yy3964) + } else if !yym3965 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3964) } else { - z.EncFallback(yy3973) + z.EncFallback(yy3964) } } else { r.EncodeNil() } } else { - if yyq3950[7] { + if yyq3941[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("firstTimestamp")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3975 := &x.FirstTimestamp - yym3976 := z.EncBinary() - _ = yym3976 + yy3966 := &x.FirstTimestamp + yym3967 := z.EncBinary() + _ = yym3967 if false { - } else if z.HasExtensions() && z.EncExt(yy3975) { - } else if yym3976 { - z.EncBinaryMarshal(yy3975) - } else if !yym3976 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3975) + } else if z.HasExtensions() && z.EncExt(yy3966) { + } else if yym3967 { + z.EncBinaryMarshal(yy3966) + } else if !yym3967 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3966) } else { - z.EncFallback(yy3975) + z.EncFallback(yy3966) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[8] { - yy3978 := &x.LastTimestamp - yym3979 := z.EncBinary() - _ = yym3979 + if yyq3941[8] { + yy3969 := &x.LastTimestamp + yym3970 := z.EncBinary() + _ = yym3970 if false { - } else if z.HasExtensions() && z.EncExt(yy3978) { - } else if yym3979 { - z.EncBinaryMarshal(yy3978) - } else if !yym3979 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3978) + } else if z.HasExtensions() && z.EncExt(yy3969) { + } else if yym3970 { + z.EncBinaryMarshal(yy3969) + } else if !yym3970 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3969) } else { - z.EncFallback(yy3978) + z.EncFallback(yy3969) } } else { r.EncodeNil() } } else { - if yyq3950[8] { + if yyq3941[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTimestamp")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3980 := &x.LastTimestamp - yym3981 := z.EncBinary() - _ = yym3981 + yy3971 := &x.LastTimestamp + yym3972 := z.EncBinary() + _ = yym3972 if false { - } else if z.HasExtensions() && z.EncExt(yy3980) { - } else if yym3981 { - z.EncBinaryMarshal(yy3980) - } else if !yym3981 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3980) + } else if z.HasExtensions() && z.EncExt(yy3971) { + } else if yym3972 { + z.EncBinaryMarshal(yy3971) + } else if !yym3972 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3971) } else { - z.EncFallback(yy3980) + z.EncFallback(yy3971) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[9] { - yym3983 := z.EncBinary() - _ = yym3983 + if yyq3941[9] { + yym3974 := z.EncBinary() + _ = yym3974 if false { } else { r.EncodeInt(int64(x.Count)) @@ -49722,23 +49640,23 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq3950[9] { + if yyq3941[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("count")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3984 := z.EncBinary() - _ = yym3984 + yym3975 := z.EncBinary() + _ = yym3975 if false { } else { r.EncodeInt(int64(x.Count)) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3950[10] { - yym3986 := z.EncBinary() - _ = yym3986 + if yyq3941[10] { + yym3977 := z.EncBinary() + _ = yym3977 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Type)) @@ -49747,19 +49665,19 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3950[10] { + if yyq3941[10] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3987 := z.EncBinary() - _ = yym3987 + yym3978 := z.EncBinary() + _ = yym3978 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Type)) } } } - if yyr3950 || yy2arr3950 { + if yyr3941 || yy2arr3941 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -49772,25 +49690,25 @@ func (x *Event) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3988 := z.DecBinary() - _ = yym3988 + yym3979 := z.DecBinary() + _ = yym3979 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3989 := r.ContainerType() - if yyct3989 == codecSelferValueTypeMap1234 { - yyl3989 := r.ReadMapStart() - if yyl3989 == 0 { + yyct3980 := r.ContainerType() + if yyct3980 == codecSelferValueTypeMap1234 { + yyl3980 := r.ReadMapStart() + if yyl3980 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3989, d) + x.codecDecodeSelfFromMap(yyl3980, d) } - } else if yyct3989 == codecSelferValueTypeArray1234 { - yyl3989 := r.ReadArrayStart() - if yyl3989 == 0 { + } else if yyct3980 == codecSelferValueTypeArray1234 { + yyl3980 := r.ReadArrayStart() + if yyl3980 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3989, d) + x.codecDecodeSelfFromArray(yyl3980, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -49802,12 +49720,12 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3990Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3990Slc - var yyhl3990 bool = l >= 0 - for yyj3990 := 0; ; yyj3990++ { - if yyhl3990 { - if yyj3990 >= l { + var yys3981Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3981Slc + var yyhl3981 bool = l >= 0 + for yyj3981 := 0; ; yyj3981++ { + if yyhl3981 { + if yyj3981 >= l { break } } else { @@ -49816,10 +49734,10 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3990Slc = r.DecodeBytes(yys3990Slc, true, true) - yys3990 := string(yys3990Slc) + yys3981Slc = r.DecodeBytes(yys3981Slc, true, true) + yys3981 := string(yys3981Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3990 { + switch yys3981 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -49836,15 +49754,15 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3993 := &x.ObjectMeta - yyv3993.CodecDecodeSelf(d) + yyv3984 := &x.ObjectMeta + yyv3984.CodecDecodeSelf(d) } case "involvedObject": if r.TryDecodeAsNil() { x.InvolvedObject = ObjectReference{} } else { - yyv3994 := &x.InvolvedObject - yyv3994.CodecDecodeSelf(d) + yyv3985 := &x.InvolvedObject + yyv3985.CodecDecodeSelf(d) } case "reason": if r.TryDecodeAsNil() { @@ -49862,41 +49780,41 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Source = EventSource{} } else { - yyv3997 := &x.Source - yyv3997.CodecDecodeSelf(d) + yyv3988 := &x.Source + yyv3988.CodecDecodeSelf(d) } case "firstTimestamp": if r.TryDecodeAsNil() { x.FirstTimestamp = pkg2_unversioned.Time{} } else { - yyv3998 := &x.FirstTimestamp - yym3999 := z.DecBinary() - _ = yym3999 + yyv3989 := &x.FirstTimestamp + yym3990 := z.DecBinary() + _ = yym3990 if false { - } else if z.HasExtensions() && z.DecExt(yyv3998) { - } else if yym3999 { - z.DecBinaryUnmarshal(yyv3998) - } else if !yym3999 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3998) + } else if z.HasExtensions() && z.DecExt(yyv3989) { + } else if yym3990 { + z.DecBinaryUnmarshal(yyv3989) + } else if !yym3990 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3989) } else { - z.DecFallback(yyv3998, false) + z.DecFallback(yyv3989, false) } } case "lastTimestamp": if r.TryDecodeAsNil() { x.LastTimestamp = pkg2_unversioned.Time{} } else { - yyv4000 := &x.LastTimestamp - yym4001 := z.DecBinary() - _ = yym4001 + yyv3991 := &x.LastTimestamp + yym3992 := z.DecBinary() + _ = yym3992 if false { - } else if z.HasExtensions() && z.DecExt(yyv4000) { - } else if yym4001 { - z.DecBinaryUnmarshal(yyv4000) - } else if !yym4001 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4000) + } else if z.HasExtensions() && z.DecExt(yyv3991) { + } else if yym3992 { + z.DecBinaryUnmarshal(yyv3991) + } else if !yym3992 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3991) } else { - z.DecFallback(yyv4000, false) + z.DecFallback(yyv3991, false) } } case "count": @@ -49912,9 +49830,9 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Type = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3990) - } // end switch yys3990 - } // end for yyj3990 + z.DecStructFieldNotFound(-1, yys3981) + } // end switch yys3981 + } // end for yyj3981 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -49922,16 +49840,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4004 int - var yyb4004 bool - var yyhl4004 bool = l >= 0 - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + var yyj3995 int + var yyb3995 bool + var yyhl3995 bool = l >= 0 + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49941,13 +49859,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49957,13 +49875,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49971,16 +49889,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4007 := &x.ObjectMeta - yyv4007.CodecDecodeSelf(d) + yyv3998 := &x.ObjectMeta + yyv3998.CodecDecodeSelf(d) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49988,16 +49906,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.InvolvedObject = ObjectReference{} } else { - yyv4008 := &x.InvolvedObject - yyv4008.CodecDecodeSelf(d) + yyv3999 := &x.InvolvedObject + yyv3999.CodecDecodeSelf(d) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50007,13 +49925,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50023,13 +49941,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Message = string(r.DecodeString()) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50037,16 +49955,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Source = EventSource{} } else { - yyv4011 := &x.Source - yyv4011.CodecDecodeSelf(d) + yyv4002 := &x.Source + yyv4002.CodecDecodeSelf(d) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50054,26 +49972,26 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.FirstTimestamp = pkg2_unversioned.Time{} } else { - yyv4012 := &x.FirstTimestamp - yym4013 := z.DecBinary() - _ = yym4013 + yyv4003 := &x.FirstTimestamp + yym4004 := z.DecBinary() + _ = yym4004 if false { - } else if z.HasExtensions() && z.DecExt(yyv4012) { - } else if yym4013 { - z.DecBinaryUnmarshal(yyv4012) - } else if !yym4013 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4012) + } else if z.HasExtensions() && z.DecExt(yyv4003) { + } else if yym4004 { + z.DecBinaryUnmarshal(yyv4003) + } else if !yym4004 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4003) } else { - z.DecFallback(yyv4012, false) + z.DecFallback(yyv4003, false) } } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50081,26 +49999,26 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTimestamp = pkg2_unversioned.Time{} } else { - yyv4014 := &x.LastTimestamp - yym4015 := z.DecBinary() - _ = yym4015 + yyv4005 := &x.LastTimestamp + yym4006 := z.DecBinary() + _ = yym4006 if false { - } else if z.HasExtensions() && z.DecExt(yyv4014) { - } else if yym4015 { - z.DecBinaryUnmarshal(yyv4014) - } else if !yym4015 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4014) + } else if z.HasExtensions() && z.DecExt(yyv4005) { + } else if yym4006 { + z.DecBinaryUnmarshal(yyv4005) + } else if !yym4006 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4005) } else { - z.DecFallback(yyv4014, false) + z.DecFallback(yyv4005, false) } } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50110,13 +50028,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Count = int32(r.DecodeInt(32)) } - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50127,17 +50045,17 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Type = string(r.DecodeString()) } for { - yyj4004++ - if yyhl4004 { - yyb4004 = yyj4004 > l + yyj3995++ + if yyhl3995 { + yyb3995 = yyj3995 > l } else { - yyb4004 = r.CheckBreak() + yyb3995 = r.CheckBreak() } - if yyb4004 { + if yyb3995 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4004-1, "") + z.DecStructFieldNotFound(yyj3995-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50149,37 +50067,37 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4018 := z.EncBinary() - _ = yym4018 + yym4009 := z.EncBinary() + _ = yym4009 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4019 := !z.EncBinary() - yy2arr4019 := z.EncBasicHandle().StructToArray - var yyq4019 [4]bool - _, _, _ = yysep4019, yyq4019, yy2arr4019 - const yyr4019 bool = false - yyq4019[0] = x.Kind != "" - yyq4019[1] = x.APIVersion != "" - yyq4019[2] = true - var yynn4019 int - if yyr4019 || yy2arr4019 { + yysep4010 := !z.EncBinary() + yy2arr4010 := z.EncBasicHandle().StructToArray + var yyq4010 [4]bool + _, _, _ = yysep4010, yyq4010, yy2arr4010 + const yyr4010 bool = false + yyq4010[0] = x.Kind != "" + yyq4010[1] = x.APIVersion != "" + yyq4010[2] = true + var yynn4010 int + if yyr4010 || yy2arr4010 { r.EncodeArrayStart(4) } else { - yynn4019 = 1 - for _, b := range yyq4019 { + yynn4010 = 1 + for _, b := range yyq4010 { if b { - yynn4019++ + yynn4010++ } } - r.EncodeMapStart(yynn4019) - yynn4019 = 0 + r.EncodeMapStart(yynn4010) + yynn4010 = 0 } - if yyr4019 || yy2arr4019 { + if yyr4010 || yy2arr4010 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4019[0] { - yym4021 := z.EncBinary() - _ = yym4021 + if yyq4010[0] { + yym4012 := z.EncBinary() + _ = yym4012 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -50188,23 +50106,23 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4019[0] { + if yyq4010[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4022 := z.EncBinary() - _ = yym4022 + yym4013 := z.EncBinary() + _ = yym4013 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4019 || yy2arr4019 { + if yyr4010 || yy2arr4010 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4019[1] { - yym4024 := z.EncBinary() - _ = yym4024 + if yyq4010[1] { + yym4015 := z.EncBinary() + _ = yym4015 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -50213,54 +50131,54 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4019[1] { + if yyq4010[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4025 := z.EncBinary() - _ = yym4025 + yym4016 := z.EncBinary() + _ = yym4016 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4019 || yy2arr4019 { + if yyr4010 || yy2arr4010 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4019[2] { - yy4027 := &x.ListMeta - yym4028 := z.EncBinary() - _ = yym4028 + if yyq4010[2] { + yy4018 := &x.ListMeta + yym4019 := z.EncBinary() + _ = yym4019 if false { - } else if z.HasExtensions() && z.EncExt(yy4027) { + } else if z.HasExtensions() && z.EncExt(yy4018) { } else { - z.EncFallback(yy4027) + z.EncFallback(yy4018) } } else { r.EncodeNil() } } else { - if yyq4019[2] { + if yyq4010[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4029 := &x.ListMeta - yym4030 := z.EncBinary() - _ = yym4030 + yy4020 := &x.ListMeta + yym4021 := z.EncBinary() + _ = yym4021 if false { - } else if z.HasExtensions() && z.EncExt(yy4029) { + } else if z.HasExtensions() && z.EncExt(yy4020) { } else { - z.EncFallback(yy4029) + z.EncFallback(yy4020) } } } - if yyr4019 || yy2arr4019 { + if yyr4010 || yy2arr4010 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4032 := z.EncBinary() - _ = yym4032 + yym4023 := z.EncBinary() + _ = yym4023 if false { } else { h.encSliceEvent(([]Event)(x.Items), e) @@ -50273,15 +50191,15 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4033 := z.EncBinary() - _ = yym4033 + yym4024 := z.EncBinary() + _ = yym4024 if false { } else { h.encSliceEvent(([]Event)(x.Items), e) } } } - if yyr4019 || yy2arr4019 { + if yyr4010 || yy2arr4010 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50294,25 +50212,25 @@ func (x *EventList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4034 := z.DecBinary() - _ = yym4034 + yym4025 := z.DecBinary() + _ = yym4025 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4035 := r.ContainerType() - if yyct4035 == codecSelferValueTypeMap1234 { - yyl4035 := r.ReadMapStart() - if yyl4035 == 0 { + yyct4026 := r.ContainerType() + if yyct4026 == codecSelferValueTypeMap1234 { + yyl4026 := r.ReadMapStart() + if yyl4026 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4035, d) + x.codecDecodeSelfFromMap(yyl4026, d) } - } else if yyct4035 == codecSelferValueTypeArray1234 { - yyl4035 := r.ReadArrayStart() - if yyl4035 == 0 { + } else if yyct4026 == codecSelferValueTypeArray1234 { + yyl4026 := r.ReadArrayStart() + if yyl4026 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4035, d) + x.codecDecodeSelfFromArray(yyl4026, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50324,12 +50242,12 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4036Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4036Slc - var yyhl4036 bool = l >= 0 - for yyj4036 := 0; ; yyj4036++ { - if yyhl4036 { - if yyj4036 >= l { + var yys4027Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4027Slc + var yyhl4027 bool = l >= 0 + for yyj4027 := 0; ; yyj4027++ { + if yyhl4027 { + if yyj4027 >= l { break } } else { @@ -50338,10 +50256,10 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4036Slc = r.DecodeBytes(yys4036Slc, true, true) - yys4036 := string(yys4036Slc) + yys4027Slc = r.DecodeBytes(yys4027Slc, true, true) + yys4027 := string(yys4027Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4036 { + switch yys4027 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -50358,31 +50276,31 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4039 := &x.ListMeta - yym4040 := z.DecBinary() - _ = yym4040 + yyv4030 := &x.ListMeta + yym4031 := z.DecBinary() + _ = yym4031 if false { - } else if z.HasExtensions() && z.DecExt(yyv4039) { + } else if z.HasExtensions() && z.DecExt(yyv4030) { } else { - z.DecFallback(yyv4039, false) + z.DecFallback(yyv4030, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4041 := &x.Items - yym4042 := z.DecBinary() - _ = yym4042 + yyv4032 := &x.Items + yym4033 := z.DecBinary() + _ = yym4033 if false { } else { - h.decSliceEvent((*[]Event)(yyv4041), d) + h.decSliceEvent((*[]Event)(yyv4032), d) } } default: - z.DecStructFieldNotFound(-1, yys4036) - } // end switch yys4036 - } // end for yyj4036 + z.DecStructFieldNotFound(-1, yys4027) + } // end switch yys4027 + } // end for yyj4027 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -50390,16 +50308,16 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4043 int - var yyb4043 bool - var yyhl4043 bool = l >= 0 - yyj4043++ - if yyhl4043 { - yyb4043 = yyj4043 > l + var yyj4034 int + var yyb4034 bool + var yyhl4034 bool = l >= 0 + yyj4034++ + if yyhl4034 { + yyb4034 = yyj4034 > l } else { - yyb4043 = r.CheckBreak() + yyb4034 = r.CheckBreak() } - if yyb4043 { + if yyb4034 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50409,13 +50327,13 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4043++ - if yyhl4043 { - yyb4043 = yyj4043 > l + yyj4034++ + if yyhl4034 { + yyb4034 = yyj4034 > l } else { - yyb4043 = r.CheckBreak() + yyb4034 = r.CheckBreak() } - if yyb4043 { + if yyb4034 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50425,13 +50343,13 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4043++ - if yyhl4043 { - yyb4043 = yyj4043 > l + yyj4034++ + if yyhl4034 { + yyb4034 = yyj4034 > l } else { - yyb4043 = r.CheckBreak() + yyb4034 = r.CheckBreak() } - if yyb4043 { + if yyb4034 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50439,22 +50357,22 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4046 := &x.ListMeta - yym4047 := z.DecBinary() - _ = yym4047 + yyv4037 := &x.ListMeta + yym4038 := z.DecBinary() + _ = yym4038 if false { - } else if z.HasExtensions() && z.DecExt(yyv4046) { + } else if z.HasExtensions() && z.DecExt(yyv4037) { } else { - z.DecFallback(yyv4046, false) + z.DecFallback(yyv4037, false) } } - yyj4043++ - if yyhl4043 { - yyb4043 = yyj4043 > l + yyj4034++ + if yyhl4034 { + yyb4034 = yyj4034 > l } else { - yyb4043 = r.CheckBreak() + yyb4034 = r.CheckBreak() } - if yyb4043 { + if yyb4034 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50462,26 +50380,26 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4048 := &x.Items - yym4049 := z.DecBinary() - _ = yym4049 + yyv4039 := &x.Items + yym4040 := z.DecBinary() + _ = yym4040 if false { } else { - h.decSliceEvent((*[]Event)(yyv4048), d) + h.decSliceEvent((*[]Event)(yyv4039), d) } } for { - yyj4043++ - if yyhl4043 { - yyb4043 = yyj4043 > l + yyj4034++ + if yyhl4034 { + yyb4034 = yyj4034 > l } else { - yyb4043 = r.CheckBreak() + yyb4034 = r.CheckBreak() } - if yyb4043 { + if yyb4034 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4043-1, "") + z.DecStructFieldNotFound(yyj4034-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50493,37 +50411,37 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4050 := z.EncBinary() - _ = yym4050 + yym4041 := z.EncBinary() + _ = yym4041 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4051 := !z.EncBinary() - yy2arr4051 := z.EncBasicHandle().StructToArray - var yyq4051 [4]bool - _, _, _ = yysep4051, yyq4051, yy2arr4051 - const yyr4051 bool = false - yyq4051[0] = x.Kind != "" - yyq4051[1] = x.APIVersion != "" - yyq4051[2] = true - var yynn4051 int - if yyr4051 || yy2arr4051 { + yysep4042 := !z.EncBinary() + yy2arr4042 := z.EncBasicHandle().StructToArray + var yyq4042 [4]bool + _, _, _ = yysep4042, yyq4042, yy2arr4042 + const yyr4042 bool = false + yyq4042[0] = x.Kind != "" + yyq4042[1] = x.APIVersion != "" + yyq4042[2] = true + var yynn4042 int + if yyr4042 || yy2arr4042 { r.EncodeArrayStart(4) } else { - yynn4051 = 1 - for _, b := range yyq4051 { + yynn4042 = 1 + for _, b := range yyq4042 { if b { - yynn4051++ + yynn4042++ } } - r.EncodeMapStart(yynn4051) - yynn4051 = 0 + r.EncodeMapStart(yynn4042) + yynn4042 = 0 } - if yyr4051 || yy2arr4051 { + if yyr4042 || yy2arr4042 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4051[0] { - yym4053 := z.EncBinary() - _ = yym4053 + if yyq4042[0] { + yym4044 := z.EncBinary() + _ = yym4044 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -50532,23 +50450,23 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4051[0] { + if yyq4042[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4054 := z.EncBinary() - _ = yym4054 + yym4045 := z.EncBinary() + _ = yym4045 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4051 || yy2arr4051 { + if yyr4042 || yy2arr4042 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4051[1] { - yym4056 := z.EncBinary() - _ = yym4056 + if yyq4042[1] { + yym4047 := z.EncBinary() + _ = yym4047 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -50557,54 +50475,54 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4051[1] { + if yyq4042[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4057 := z.EncBinary() - _ = yym4057 + yym4048 := z.EncBinary() + _ = yym4048 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4051 || yy2arr4051 { + if yyr4042 || yy2arr4042 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4051[2] { - yy4059 := &x.ListMeta - yym4060 := z.EncBinary() - _ = yym4060 + if yyq4042[2] { + yy4050 := &x.ListMeta + yym4051 := z.EncBinary() + _ = yym4051 if false { - } else if z.HasExtensions() && z.EncExt(yy4059) { + } else if z.HasExtensions() && z.EncExt(yy4050) { } else { - z.EncFallback(yy4059) + z.EncFallback(yy4050) } } else { r.EncodeNil() } } else { - if yyq4051[2] { + if yyq4042[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4061 := &x.ListMeta - yym4062 := z.EncBinary() - _ = yym4062 + yy4052 := &x.ListMeta + yym4053 := z.EncBinary() + _ = yym4053 if false { - } else if z.HasExtensions() && z.EncExt(yy4061) { + } else if z.HasExtensions() && z.EncExt(yy4052) { } else { - z.EncFallback(yy4061) + z.EncFallback(yy4052) } } } - if yyr4051 || yy2arr4051 { + if yyr4042 || yy2arr4042 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4064 := z.EncBinary() - _ = yym4064 + yym4055 := z.EncBinary() + _ = yym4055 if false { } else { h.encSliceruntime_Object(([]pkg7_runtime.Object)(x.Items), e) @@ -50617,15 +50535,15 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4065 := z.EncBinary() - _ = yym4065 + yym4056 := z.EncBinary() + _ = yym4056 if false { } else { h.encSliceruntime_Object(([]pkg7_runtime.Object)(x.Items), e) } } } - if yyr4051 || yy2arr4051 { + if yyr4042 || yy2arr4042 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50638,25 +50556,25 @@ func (x *List) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4066 := z.DecBinary() - _ = yym4066 + yym4057 := z.DecBinary() + _ = yym4057 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4067 := r.ContainerType() - if yyct4067 == codecSelferValueTypeMap1234 { - yyl4067 := r.ReadMapStart() - if yyl4067 == 0 { + yyct4058 := r.ContainerType() + if yyct4058 == codecSelferValueTypeMap1234 { + yyl4058 := r.ReadMapStart() + if yyl4058 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4067, d) + x.codecDecodeSelfFromMap(yyl4058, d) } - } else if yyct4067 == codecSelferValueTypeArray1234 { - yyl4067 := r.ReadArrayStart() - if yyl4067 == 0 { + } else if yyct4058 == codecSelferValueTypeArray1234 { + yyl4058 := r.ReadArrayStart() + if yyl4058 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4067, d) + x.codecDecodeSelfFromArray(yyl4058, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50668,12 +50586,12 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4068Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4068Slc - var yyhl4068 bool = l >= 0 - for yyj4068 := 0; ; yyj4068++ { - if yyhl4068 { - if yyj4068 >= l { + var yys4059Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4059Slc + var yyhl4059 bool = l >= 0 + for yyj4059 := 0; ; yyj4059++ { + if yyhl4059 { + if yyj4059 >= l { break } } else { @@ -50682,10 +50600,10 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4068Slc = r.DecodeBytes(yys4068Slc, true, true) - yys4068 := string(yys4068Slc) + yys4059Slc = r.DecodeBytes(yys4059Slc, true, true) + yys4059 := string(yys4059Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4068 { + switch yys4059 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -50702,31 +50620,31 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4071 := &x.ListMeta - yym4072 := z.DecBinary() - _ = yym4072 + yyv4062 := &x.ListMeta + yym4063 := z.DecBinary() + _ = yym4063 if false { - } else if z.HasExtensions() && z.DecExt(yyv4071) { + } else if z.HasExtensions() && z.DecExt(yyv4062) { } else { - z.DecFallback(yyv4071, false) + z.DecFallback(yyv4062, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4073 := &x.Items - yym4074 := z.DecBinary() - _ = yym4074 + yyv4064 := &x.Items + yym4065 := z.DecBinary() + _ = yym4065 if false { } else { - h.decSliceruntime_Object((*[]pkg7_runtime.Object)(yyv4073), d) + h.decSliceruntime_Object((*[]pkg7_runtime.Object)(yyv4064), d) } } default: - z.DecStructFieldNotFound(-1, yys4068) - } // end switch yys4068 - } // end for yyj4068 + z.DecStructFieldNotFound(-1, yys4059) + } // end switch yys4059 + } // end for yyj4059 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -50734,16 +50652,16 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4075 int - var yyb4075 bool - var yyhl4075 bool = l >= 0 - yyj4075++ - if yyhl4075 { - yyb4075 = yyj4075 > l + var yyj4066 int + var yyb4066 bool + var yyhl4066 bool = l >= 0 + yyj4066++ + if yyhl4066 { + yyb4066 = yyj4066 > l } else { - yyb4075 = r.CheckBreak() + yyb4066 = r.CheckBreak() } - if yyb4075 { + if yyb4066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50753,13 +50671,13 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4075++ - if yyhl4075 { - yyb4075 = yyj4075 > l + yyj4066++ + if yyhl4066 { + yyb4066 = yyj4066 > l } else { - yyb4075 = r.CheckBreak() + yyb4066 = r.CheckBreak() } - if yyb4075 { + if yyb4066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50769,13 +50687,13 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4075++ - if yyhl4075 { - yyb4075 = yyj4075 > l + yyj4066++ + if yyhl4066 { + yyb4066 = yyj4066 > l } else { - yyb4075 = r.CheckBreak() + yyb4066 = r.CheckBreak() } - if yyb4075 { + if yyb4066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50783,22 +50701,22 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4078 := &x.ListMeta - yym4079 := z.DecBinary() - _ = yym4079 + yyv4069 := &x.ListMeta + yym4070 := z.DecBinary() + _ = yym4070 if false { - } else if z.HasExtensions() && z.DecExt(yyv4078) { + } else if z.HasExtensions() && z.DecExt(yyv4069) { } else { - z.DecFallback(yyv4078, false) + z.DecFallback(yyv4069, false) } } - yyj4075++ - if yyhl4075 { - yyb4075 = yyj4075 > l + yyj4066++ + if yyhl4066 { + yyb4066 = yyj4066 > l } else { - yyb4075 = r.CheckBreak() + yyb4066 = r.CheckBreak() } - if yyb4075 { + if yyb4066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50806,26 +50724,26 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4080 := &x.Items - yym4081 := z.DecBinary() - _ = yym4081 + yyv4071 := &x.Items + yym4072 := z.DecBinary() + _ = yym4072 if false { } else { - h.decSliceruntime_Object((*[]pkg7_runtime.Object)(yyv4080), d) + h.decSliceruntime_Object((*[]pkg7_runtime.Object)(yyv4071), d) } } for { - yyj4075++ - if yyhl4075 { - yyb4075 = yyj4075 > l + yyj4066++ + if yyhl4066 { + yyb4066 = yyj4066 > l } else { - yyb4075 = r.CheckBreak() + yyb4066 = r.CheckBreak() } - if yyb4075 { + if yyb4066 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4075-1, "") + z.DecStructFieldNotFound(yyj4066-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50834,8 +50752,8 @@ func (x LimitType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4082 := z.EncBinary() - _ = yym4082 + yym4073 := z.EncBinary() + _ = yym4073 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -50847,8 +50765,8 @@ func (x *LimitType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4083 := z.DecBinary() - _ = yym4083 + yym4074 := z.DecBinary() + _ = yym4074 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -50863,53 +50781,53 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4084 := z.EncBinary() - _ = yym4084 + yym4075 := z.EncBinary() + _ = yym4075 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4085 := !z.EncBinary() - yy2arr4085 := z.EncBasicHandle().StructToArray - var yyq4085 [6]bool - _, _, _ = yysep4085, yyq4085, yy2arr4085 - const yyr4085 bool = false - yyq4085[0] = x.Type != "" - yyq4085[1] = len(x.Max) != 0 - yyq4085[2] = len(x.Min) != 0 - yyq4085[3] = len(x.Default) != 0 - yyq4085[4] = len(x.DefaultRequest) != 0 - yyq4085[5] = len(x.MaxLimitRequestRatio) != 0 - var yynn4085 int - if yyr4085 || yy2arr4085 { + yysep4076 := !z.EncBinary() + yy2arr4076 := z.EncBasicHandle().StructToArray + var yyq4076 [6]bool + _, _, _ = yysep4076, yyq4076, yy2arr4076 + const yyr4076 bool = false + yyq4076[0] = x.Type != "" + yyq4076[1] = len(x.Max) != 0 + yyq4076[2] = len(x.Min) != 0 + yyq4076[3] = len(x.Default) != 0 + yyq4076[4] = len(x.DefaultRequest) != 0 + yyq4076[5] = len(x.MaxLimitRequestRatio) != 0 + var yynn4076 int + if yyr4076 || yy2arr4076 { r.EncodeArrayStart(6) } else { - yynn4085 = 0 - for _, b := range yyq4085 { + yynn4076 = 0 + for _, b := range yyq4076 { if b { - yynn4085++ + yynn4076++ } } - r.EncodeMapStart(yynn4085) - yynn4085 = 0 + r.EncodeMapStart(yynn4076) + yynn4076 = 0 } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[0] { + if yyq4076[0] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4085[0] { + if yyq4076[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[1] { + if yyq4076[1] { if x.Max == nil { r.EncodeNil() } else { @@ -50919,7 +50837,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4085[1] { + if yyq4076[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("max")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50930,9 +50848,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[2] { + if yyq4076[2] { if x.Min == nil { r.EncodeNil() } else { @@ -50942,7 +50860,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4085[2] { + if yyq4076[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("min")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50953,9 +50871,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[3] { + if yyq4076[3] { if x.Default == nil { r.EncodeNil() } else { @@ -50965,7 +50883,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4085[3] { + if yyq4076[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("default")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50976,9 +50894,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[4] { + if yyq4076[4] { if x.DefaultRequest == nil { r.EncodeNil() } else { @@ -50988,7 +50906,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4085[4] { + if yyq4076[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("defaultRequest")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50999,9 +50917,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4085[5] { + if yyq4076[5] { if x.MaxLimitRequestRatio == nil { r.EncodeNil() } else { @@ -51011,7 +50929,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4085[5] { + if yyq4076[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxLimitRequestRatio")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -51022,7 +50940,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4085 || yy2arr4085 { + if yyr4076 || yy2arr4076 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51035,25 +50953,25 @@ func (x *LimitRangeItem) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4092 := z.DecBinary() - _ = yym4092 + yym4083 := z.DecBinary() + _ = yym4083 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4093 := r.ContainerType() - if yyct4093 == codecSelferValueTypeMap1234 { - yyl4093 := r.ReadMapStart() - if yyl4093 == 0 { + yyct4084 := r.ContainerType() + if yyct4084 == codecSelferValueTypeMap1234 { + yyl4084 := r.ReadMapStart() + if yyl4084 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4093, d) + x.codecDecodeSelfFromMap(yyl4084, d) } - } else if yyct4093 == codecSelferValueTypeArray1234 { - yyl4093 := r.ReadArrayStart() - if yyl4093 == 0 { + } else if yyct4084 == codecSelferValueTypeArray1234 { + yyl4084 := r.ReadArrayStart() + if yyl4084 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4093, d) + x.codecDecodeSelfFromArray(yyl4084, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51065,12 +50983,12 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4094Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4094Slc - var yyhl4094 bool = l >= 0 - for yyj4094 := 0; ; yyj4094++ { - if yyhl4094 { - if yyj4094 >= l { + var yys4085Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4085Slc + var yyhl4085 bool = l >= 0 + for yyj4085 := 0; ; yyj4085++ { + if yyhl4085 { + if yyj4085 >= l { break } } else { @@ -51079,10 +50997,10 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4094Slc = r.DecodeBytes(yys4094Slc, true, true) - yys4094 := string(yys4094Slc) + yys4085Slc = r.DecodeBytes(yys4085Slc, true, true) + yys4085 := string(yys4085Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4094 { + switch yys4085 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -51093,41 +51011,41 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Max = nil } else { - yyv4096 := &x.Max - yyv4096.CodecDecodeSelf(d) + yyv4087 := &x.Max + yyv4087.CodecDecodeSelf(d) } case "min": if r.TryDecodeAsNil() { x.Min = nil } else { - yyv4097 := &x.Min - yyv4097.CodecDecodeSelf(d) + yyv4088 := &x.Min + yyv4088.CodecDecodeSelf(d) } case "default": if r.TryDecodeAsNil() { x.Default = nil } else { - yyv4098 := &x.Default - yyv4098.CodecDecodeSelf(d) + yyv4089 := &x.Default + yyv4089.CodecDecodeSelf(d) } case "defaultRequest": if r.TryDecodeAsNil() { x.DefaultRequest = nil } else { - yyv4099 := &x.DefaultRequest - yyv4099.CodecDecodeSelf(d) + yyv4090 := &x.DefaultRequest + yyv4090.CodecDecodeSelf(d) } case "maxLimitRequestRatio": if r.TryDecodeAsNil() { x.MaxLimitRequestRatio = nil } else { - yyv4100 := &x.MaxLimitRequestRatio - yyv4100.CodecDecodeSelf(d) + yyv4091 := &x.MaxLimitRequestRatio + yyv4091.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4094) - } // end switch yys4094 - } // end for yyj4094 + z.DecStructFieldNotFound(-1, yys4085) + } // end switch yys4085 + } // end for yyj4085 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51135,16 +51053,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4101 int - var yyb4101 bool - var yyhl4101 bool = l >= 0 - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + var yyj4092 int + var yyb4092 bool + var yyhl4092 bool = l >= 0 + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51154,13 +51072,13 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = LimitType(r.DecodeString()) } - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51168,16 +51086,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Max = nil } else { - yyv4103 := &x.Max - yyv4103.CodecDecodeSelf(d) + yyv4094 := &x.Max + yyv4094.CodecDecodeSelf(d) } - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51185,16 +51103,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Min = nil } else { - yyv4104 := &x.Min - yyv4104.CodecDecodeSelf(d) + yyv4095 := &x.Min + yyv4095.CodecDecodeSelf(d) } - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51202,16 +51120,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Default = nil } else { - yyv4105 := &x.Default - yyv4105.CodecDecodeSelf(d) + yyv4096 := &x.Default + yyv4096.CodecDecodeSelf(d) } - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51219,16 +51137,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.DefaultRequest = nil } else { - yyv4106 := &x.DefaultRequest - yyv4106.CodecDecodeSelf(d) + yyv4097 := &x.DefaultRequest + yyv4097.CodecDecodeSelf(d) } - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51236,21 +51154,21 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.MaxLimitRequestRatio = nil } else { - yyv4107 := &x.MaxLimitRequestRatio - yyv4107.CodecDecodeSelf(d) + yyv4098 := &x.MaxLimitRequestRatio + yyv4098.CodecDecodeSelf(d) } for { - yyj4101++ - if yyhl4101 { - yyb4101 = yyj4101 > l + yyj4092++ + if yyhl4092 { + yyb4092 = yyj4092 > l } else { - yyb4101 = r.CheckBreak() + yyb4092 = r.CheckBreak() } - if yyb4101 { + if yyb4092 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4101-1, "") + z.DecStructFieldNotFound(yyj4092-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51262,36 +51180,36 @@ func (x *LimitRangeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4108 := z.EncBinary() - _ = yym4108 + yym4099 := z.EncBinary() + _ = yym4099 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4109 := !z.EncBinary() - yy2arr4109 := z.EncBasicHandle().StructToArray - var yyq4109 [1]bool - _, _, _ = yysep4109, yyq4109, yy2arr4109 - const yyr4109 bool = false - var yynn4109 int - if yyr4109 || yy2arr4109 { + yysep4100 := !z.EncBinary() + yy2arr4100 := z.EncBasicHandle().StructToArray + var yyq4100 [1]bool + _, _, _ = yysep4100, yyq4100, yy2arr4100 + const yyr4100 bool = false + var yynn4100 int + if yyr4100 || yy2arr4100 { r.EncodeArrayStart(1) } else { - yynn4109 = 1 - for _, b := range yyq4109 { + yynn4100 = 1 + for _, b := range yyq4100 { if b { - yynn4109++ + yynn4100++ } } - r.EncodeMapStart(yynn4109) - yynn4109 = 0 + r.EncodeMapStart(yynn4100) + yynn4100 = 0 } - if yyr4109 || yy2arr4109 { + if yyr4100 || yy2arr4100 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Limits == nil { r.EncodeNil() } else { - yym4111 := z.EncBinary() - _ = yym4111 + yym4102 := z.EncBinary() + _ = yym4102 if false { } else { h.encSliceLimitRangeItem(([]LimitRangeItem)(x.Limits), e) @@ -51304,15 +51222,15 @@ func (x *LimitRangeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Limits == nil { r.EncodeNil() } else { - yym4112 := z.EncBinary() - _ = yym4112 + yym4103 := z.EncBinary() + _ = yym4103 if false { } else { h.encSliceLimitRangeItem(([]LimitRangeItem)(x.Limits), e) } } } - if yyr4109 || yy2arr4109 { + if yyr4100 || yy2arr4100 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51325,25 +51243,25 @@ func (x *LimitRangeSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4113 := z.DecBinary() - _ = yym4113 + yym4104 := z.DecBinary() + _ = yym4104 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4114 := r.ContainerType() - if yyct4114 == codecSelferValueTypeMap1234 { - yyl4114 := r.ReadMapStart() - if yyl4114 == 0 { + yyct4105 := r.ContainerType() + if yyct4105 == codecSelferValueTypeMap1234 { + yyl4105 := r.ReadMapStart() + if yyl4105 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4114, d) + x.codecDecodeSelfFromMap(yyl4105, d) } - } else if yyct4114 == codecSelferValueTypeArray1234 { - yyl4114 := r.ReadArrayStart() - if yyl4114 == 0 { + } else if yyct4105 == codecSelferValueTypeArray1234 { + yyl4105 := r.ReadArrayStart() + if yyl4105 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4114, d) + x.codecDecodeSelfFromArray(yyl4105, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51355,12 +51273,12 @@ func (x *LimitRangeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4115Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4115Slc - var yyhl4115 bool = l >= 0 - for yyj4115 := 0; ; yyj4115++ { - if yyhl4115 { - if yyj4115 >= l { + var yys4106Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4106Slc + var yyhl4106 bool = l >= 0 + for yyj4106 := 0; ; yyj4106++ { + if yyhl4106 { + if yyj4106 >= l { break } } else { @@ -51369,26 +51287,26 @@ func (x *LimitRangeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4115Slc = r.DecodeBytes(yys4115Slc, true, true) - yys4115 := string(yys4115Slc) + yys4106Slc = r.DecodeBytes(yys4106Slc, true, true) + yys4106 := string(yys4106Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4115 { + switch yys4106 { case "limits": if r.TryDecodeAsNil() { x.Limits = nil } else { - yyv4116 := &x.Limits - yym4117 := z.DecBinary() - _ = yym4117 + yyv4107 := &x.Limits + yym4108 := z.DecBinary() + _ = yym4108 if false { } else { - h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4116), d) + h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4107), d) } } default: - z.DecStructFieldNotFound(-1, yys4115) - } // end switch yys4115 - } // end for yyj4115 + z.DecStructFieldNotFound(-1, yys4106) + } // end switch yys4106 + } // end for yyj4106 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51396,16 +51314,16 @@ func (x *LimitRangeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4118 int - var yyb4118 bool - var yyhl4118 bool = l >= 0 - yyj4118++ - if yyhl4118 { - yyb4118 = yyj4118 > l + var yyj4109 int + var yyb4109 bool + var yyhl4109 bool = l >= 0 + yyj4109++ + if yyhl4109 { + yyb4109 = yyj4109 > l } else { - yyb4118 = r.CheckBreak() + yyb4109 = r.CheckBreak() } - if yyb4118 { + if yyb4109 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51413,26 +51331,26 @@ func (x *LimitRangeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Limits = nil } else { - yyv4119 := &x.Limits - yym4120 := z.DecBinary() - _ = yym4120 + yyv4110 := &x.Limits + yym4111 := z.DecBinary() + _ = yym4111 if false { } else { - h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4119), d) + h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4110), d) } } for { - yyj4118++ - if yyhl4118 { - yyb4118 = yyj4118 > l + yyj4109++ + if yyhl4109 { + yyb4109 = yyj4109 > l } else { - yyb4118 = r.CheckBreak() + yyb4109 = r.CheckBreak() } - if yyb4118 { + if yyb4109 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4118-1, "") + z.DecStructFieldNotFound(yyj4109-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51444,38 +51362,38 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4121 := z.EncBinary() - _ = yym4121 + yym4112 := z.EncBinary() + _ = yym4112 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4122 := !z.EncBinary() - yy2arr4122 := z.EncBasicHandle().StructToArray - var yyq4122 [4]bool - _, _, _ = yysep4122, yyq4122, yy2arr4122 - const yyr4122 bool = false - yyq4122[0] = x.Kind != "" - yyq4122[1] = x.APIVersion != "" - yyq4122[2] = true - yyq4122[3] = true - var yynn4122 int - if yyr4122 || yy2arr4122 { + yysep4113 := !z.EncBinary() + yy2arr4113 := z.EncBasicHandle().StructToArray + var yyq4113 [4]bool + _, _, _ = yysep4113, yyq4113, yy2arr4113 + const yyr4113 bool = false + yyq4113[0] = x.Kind != "" + yyq4113[1] = x.APIVersion != "" + yyq4113[2] = true + yyq4113[3] = true + var yynn4113 int + if yyr4113 || yy2arr4113 { r.EncodeArrayStart(4) } else { - yynn4122 = 0 - for _, b := range yyq4122 { + yynn4113 = 0 + for _, b := range yyq4113 { if b { - yynn4122++ + yynn4113++ } } - r.EncodeMapStart(yynn4122) - yynn4122 = 0 + r.EncodeMapStart(yynn4113) + yynn4113 = 0 } - if yyr4122 || yy2arr4122 { + if yyr4113 || yy2arr4113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4122[0] { - yym4124 := z.EncBinary() - _ = yym4124 + if yyq4113[0] { + yym4115 := z.EncBinary() + _ = yym4115 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -51484,23 +51402,23 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4122[0] { + if yyq4113[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4125 := z.EncBinary() - _ = yym4125 + yym4116 := z.EncBinary() + _ = yym4116 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4122 || yy2arr4122 { + if yyr4113 || yy2arr4113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4122[1] { - yym4127 := z.EncBinary() - _ = yym4127 + if yyq4113[1] { + yym4118 := z.EncBinary() + _ = yym4118 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -51509,53 +51427,53 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4122[1] { + if yyq4113[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4128 := z.EncBinary() - _ = yym4128 + yym4119 := z.EncBinary() + _ = yym4119 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4122 || yy2arr4122 { + if yyr4113 || yy2arr4113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4122[2] { - yy4130 := &x.ObjectMeta - yy4130.CodecEncodeSelf(e) + if yyq4113[2] { + yy4121 := &x.ObjectMeta + yy4121.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4122[2] { + if yyq4113[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4131 := &x.ObjectMeta - yy4131.CodecEncodeSelf(e) + yy4122 := &x.ObjectMeta + yy4122.CodecEncodeSelf(e) } } - if yyr4122 || yy2arr4122 { + if yyr4113 || yy2arr4113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4122[3] { - yy4133 := &x.Spec - yy4133.CodecEncodeSelf(e) + if yyq4113[3] { + yy4124 := &x.Spec + yy4124.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4122[3] { + if yyq4113[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4134 := &x.Spec - yy4134.CodecEncodeSelf(e) + yy4125 := &x.Spec + yy4125.CodecEncodeSelf(e) } } - if yyr4122 || yy2arr4122 { + if yyr4113 || yy2arr4113 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51568,25 +51486,25 @@ func (x *LimitRange) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4135 := z.DecBinary() - _ = yym4135 + yym4126 := z.DecBinary() + _ = yym4126 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4136 := r.ContainerType() - if yyct4136 == codecSelferValueTypeMap1234 { - yyl4136 := r.ReadMapStart() - if yyl4136 == 0 { + yyct4127 := r.ContainerType() + if yyct4127 == codecSelferValueTypeMap1234 { + yyl4127 := r.ReadMapStart() + if yyl4127 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4136, d) + x.codecDecodeSelfFromMap(yyl4127, d) } - } else if yyct4136 == codecSelferValueTypeArray1234 { - yyl4136 := r.ReadArrayStart() - if yyl4136 == 0 { + } else if yyct4127 == codecSelferValueTypeArray1234 { + yyl4127 := r.ReadArrayStart() + if yyl4127 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4136, d) + x.codecDecodeSelfFromArray(yyl4127, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51598,12 +51516,12 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4137Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4137Slc - var yyhl4137 bool = l >= 0 - for yyj4137 := 0; ; yyj4137++ { - if yyhl4137 { - if yyj4137 >= l { + var yys4128Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4128Slc + var yyhl4128 bool = l >= 0 + for yyj4128 := 0; ; yyj4128++ { + if yyhl4128 { + if yyj4128 >= l { break } } else { @@ -51612,10 +51530,10 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4137Slc = r.DecodeBytes(yys4137Slc, true, true) - yys4137 := string(yys4137Slc) + yys4128Slc = r.DecodeBytes(yys4128Slc, true, true) + yys4128 := string(yys4128Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4137 { + switch yys4128 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -51632,20 +51550,20 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4140 := &x.ObjectMeta - yyv4140.CodecDecodeSelf(d) + yyv4131 := &x.ObjectMeta + yyv4131.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = LimitRangeSpec{} } else { - yyv4141 := &x.Spec - yyv4141.CodecDecodeSelf(d) + yyv4132 := &x.Spec + yyv4132.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4137) - } // end switch yys4137 - } // end for yyj4137 + z.DecStructFieldNotFound(-1, yys4128) + } // end switch yys4128 + } // end for yyj4128 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51653,16 +51571,16 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4142 int - var yyb4142 bool - var yyhl4142 bool = l >= 0 - yyj4142++ - if yyhl4142 { - yyb4142 = yyj4142 > l + var yyj4133 int + var yyb4133 bool + var yyhl4133 bool = l >= 0 + yyj4133++ + if yyhl4133 { + yyb4133 = yyj4133 > l } else { - yyb4142 = r.CheckBreak() + yyb4133 = r.CheckBreak() } - if yyb4142 { + if yyb4133 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51672,13 +51590,13 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4142++ - if yyhl4142 { - yyb4142 = yyj4142 > l + yyj4133++ + if yyhl4133 { + yyb4133 = yyj4133 > l } else { - yyb4142 = r.CheckBreak() + yyb4133 = r.CheckBreak() } - if yyb4142 { + if yyb4133 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51688,13 +51606,13 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4142++ - if yyhl4142 { - yyb4142 = yyj4142 > l + yyj4133++ + if yyhl4133 { + yyb4133 = yyj4133 > l } else { - yyb4142 = r.CheckBreak() + yyb4133 = r.CheckBreak() } - if yyb4142 { + if yyb4133 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51702,16 +51620,16 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4145 := &x.ObjectMeta - yyv4145.CodecDecodeSelf(d) + yyv4136 := &x.ObjectMeta + yyv4136.CodecDecodeSelf(d) } - yyj4142++ - if yyhl4142 { - yyb4142 = yyj4142 > l + yyj4133++ + if yyhl4133 { + yyb4133 = yyj4133 > l } else { - yyb4142 = r.CheckBreak() + yyb4133 = r.CheckBreak() } - if yyb4142 { + if yyb4133 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51719,21 +51637,21 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = LimitRangeSpec{} } else { - yyv4146 := &x.Spec - yyv4146.CodecDecodeSelf(d) + yyv4137 := &x.Spec + yyv4137.CodecDecodeSelf(d) } for { - yyj4142++ - if yyhl4142 { - yyb4142 = yyj4142 > l + yyj4133++ + if yyhl4133 { + yyb4133 = yyj4133 > l } else { - yyb4142 = r.CheckBreak() + yyb4133 = r.CheckBreak() } - if yyb4142 { + if yyb4133 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4142-1, "") + z.DecStructFieldNotFound(yyj4133-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51745,37 +51663,37 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4147 := z.EncBinary() - _ = yym4147 + yym4138 := z.EncBinary() + _ = yym4138 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4148 := !z.EncBinary() - yy2arr4148 := z.EncBasicHandle().StructToArray - var yyq4148 [4]bool - _, _, _ = yysep4148, yyq4148, yy2arr4148 - const yyr4148 bool = false - yyq4148[0] = x.Kind != "" - yyq4148[1] = x.APIVersion != "" - yyq4148[2] = true - var yynn4148 int - if yyr4148 || yy2arr4148 { + yysep4139 := !z.EncBinary() + yy2arr4139 := z.EncBasicHandle().StructToArray + var yyq4139 [4]bool + _, _, _ = yysep4139, yyq4139, yy2arr4139 + const yyr4139 bool = false + yyq4139[0] = x.Kind != "" + yyq4139[1] = x.APIVersion != "" + yyq4139[2] = true + var yynn4139 int + if yyr4139 || yy2arr4139 { r.EncodeArrayStart(4) } else { - yynn4148 = 1 - for _, b := range yyq4148 { + yynn4139 = 1 + for _, b := range yyq4139 { if b { - yynn4148++ + yynn4139++ } } - r.EncodeMapStart(yynn4148) - yynn4148 = 0 + r.EncodeMapStart(yynn4139) + yynn4139 = 0 } - if yyr4148 || yy2arr4148 { + if yyr4139 || yy2arr4139 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4148[0] { - yym4150 := z.EncBinary() - _ = yym4150 + if yyq4139[0] { + yym4141 := z.EncBinary() + _ = yym4141 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -51784,23 +51702,23 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4148[0] { + if yyq4139[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4151 := z.EncBinary() - _ = yym4151 + yym4142 := z.EncBinary() + _ = yym4142 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4148 || yy2arr4148 { + if yyr4139 || yy2arr4139 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4148[1] { - yym4153 := z.EncBinary() - _ = yym4153 + if yyq4139[1] { + yym4144 := z.EncBinary() + _ = yym4144 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -51809,54 +51727,54 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4148[1] { + if yyq4139[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4154 := z.EncBinary() - _ = yym4154 + yym4145 := z.EncBinary() + _ = yym4145 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4148 || yy2arr4148 { + if yyr4139 || yy2arr4139 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4148[2] { - yy4156 := &x.ListMeta - yym4157 := z.EncBinary() - _ = yym4157 + if yyq4139[2] { + yy4147 := &x.ListMeta + yym4148 := z.EncBinary() + _ = yym4148 if false { - } else if z.HasExtensions() && z.EncExt(yy4156) { + } else if z.HasExtensions() && z.EncExt(yy4147) { } else { - z.EncFallback(yy4156) + z.EncFallback(yy4147) } } else { r.EncodeNil() } } else { - if yyq4148[2] { + if yyq4139[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4158 := &x.ListMeta - yym4159 := z.EncBinary() - _ = yym4159 + yy4149 := &x.ListMeta + yym4150 := z.EncBinary() + _ = yym4150 if false { - } else if z.HasExtensions() && z.EncExt(yy4158) { + } else if z.HasExtensions() && z.EncExt(yy4149) { } else { - z.EncFallback(yy4158) + z.EncFallback(yy4149) } } } - if yyr4148 || yy2arr4148 { + if yyr4139 || yy2arr4139 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4161 := z.EncBinary() - _ = yym4161 + yym4152 := z.EncBinary() + _ = yym4152 if false { } else { h.encSliceLimitRange(([]LimitRange)(x.Items), e) @@ -51869,15 +51787,15 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4162 := z.EncBinary() - _ = yym4162 + yym4153 := z.EncBinary() + _ = yym4153 if false { } else { h.encSliceLimitRange(([]LimitRange)(x.Items), e) } } } - if yyr4148 || yy2arr4148 { + if yyr4139 || yy2arr4139 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51890,25 +51808,25 @@ func (x *LimitRangeList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4163 := z.DecBinary() - _ = yym4163 + yym4154 := z.DecBinary() + _ = yym4154 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4164 := r.ContainerType() - if yyct4164 == codecSelferValueTypeMap1234 { - yyl4164 := r.ReadMapStart() - if yyl4164 == 0 { + yyct4155 := r.ContainerType() + if yyct4155 == codecSelferValueTypeMap1234 { + yyl4155 := r.ReadMapStart() + if yyl4155 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4164, d) + x.codecDecodeSelfFromMap(yyl4155, d) } - } else if yyct4164 == codecSelferValueTypeArray1234 { - yyl4164 := r.ReadArrayStart() - if yyl4164 == 0 { + } else if yyct4155 == codecSelferValueTypeArray1234 { + yyl4155 := r.ReadArrayStart() + if yyl4155 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4164, d) + x.codecDecodeSelfFromArray(yyl4155, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51920,12 +51838,12 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4165Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4165Slc - var yyhl4165 bool = l >= 0 - for yyj4165 := 0; ; yyj4165++ { - if yyhl4165 { - if yyj4165 >= l { + var yys4156Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4156Slc + var yyhl4156 bool = l >= 0 + for yyj4156 := 0; ; yyj4156++ { + if yyhl4156 { + if yyj4156 >= l { break } } else { @@ -51934,10 +51852,10 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4165Slc = r.DecodeBytes(yys4165Slc, true, true) - yys4165 := string(yys4165Slc) + yys4156Slc = r.DecodeBytes(yys4156Slc, true, true) + yys4156 := string(yys4156Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4165 { + switch yys4156 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -51954,31 +51872,31 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4168 := &x.ListMeta - yym4169 := z.DecBinary() - _ = yym4169 + yyv4159 := &x.ListMeta + yym4160 := z.DecBinary() + _ = yym4160 if false { - } else if z.HasExtensions() && z.DecExt(yyv4168) { + } else if z.HasExtensions() && z.DecExt(yyv4159) { } else { - z.DecFallback(yyv4168, false) + z.DecFallback(yyv4159, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4170 := &x.Items - yym4171 := z.DecBinary() - _ = yym4171 + yyv4161 := &x.Items + yym4162 := z.DecBinary() + _ = yym4162 if false { } else { - h.decSliceLimitRange((*[]LimitRange)(yyv4170), d) + h.decSliceLimitRange((*[]LimitRange)(yyv4161), d) } } default: - z.DecStructFieldNotFound(-1, yys4165) - } // end switch yys4165 - } // end for yyj4165 + z.DecStructFieldNotFound(-1, yys4156) + } // end switch yys4156 + } // end for yyj4156 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51986,16 +51904,16 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4172 int - var yyb4172 bool - var yyhl4172 bool = l >= 0 - yyj4172++ - if yyhl4172 { - yyb4172 = yyj4172 > l + var yyj4163 int + var yyb4163 bool + var yyhl4163 bool = l >= 0 + yyj4163++ + if yyhl4163 { + yyb4163 = yyj4163 > l } else { - yyb4172 = r.CheckBreak() + yyb4163 = r.CheckBreak() } - if yyb4172 { + if yyb4163 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52005,13 +51923,13 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4172++ - if yyhl4172 { - yyb4172 = yyj4172 > l + yyj4163++ + if yyhl4163 { + yyb4163 = yyj4163 > l } else { - yyb4172 = r.CheckBreak() + yyb4163 = r.CheckBreak() } - if yyb4172 { + if yyb4163 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52021,13 +51939,13 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4172++ - if yyhl4172 { - yyb4172 = yyj4172 > l + yyj4163++ + if yyhl4163 { + yyb4163 = yyj4163 > l } else { - yyb4172 = r.CheckBreak() + yyb4163 = r.CheckBreak() } - if yyb4172 { + if yyb4163 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52035,22 +51953,22 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4175 := &x.ListMeta - yym4176 := z.DecBinary() - _ = yym4176 + yyv4166 := &x.ListMeta + yym4167 := z.DecBinary() + _ = yym4167 if false { - } else if z.HasExtensions() && z.DecExt(yyv4175) { + } else if z.HasExtensions() && z.DecExt(yyv4166) { } else { - z.DecFallback(yyv4175, false) + z.DecFallback(yyv4166, false) } } - yyj4172++ - if yyhl4172 { - yyb4172 = yyj4172 > l + yyj4163++ + if yyhl4163 { + yyb4163 = yyj4163 > l } else { - yyb4172 = r.CheckBreak() + yyb4163 = r.CheckBreak() } - if yyb4172 { + if yyb4163 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52058,26 +51976,26 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4177 := &x.Items - yym4178 := z.DecBinary() - _ = yym4178 + yyv4168 := &x.Items + yym4169 := z.DecBinary() + _ = yym4169 if false { } else { - h.decSliceLimitRange((*[]LimitRange)(yyv4177), d) + h.decSliceLimitRange((*[]LimitRange)(yyv4168), d) } } for { - yyj4172++ - if yyhl4172 { - yyb4172 = yyj4172 > l + yyj4163++ + if yyhl4163 { + yyb4163 = yyj4163 > l } else { - yyb4172 = r.CheckBreak() + yyb4163 = r.CheckBreak() } - if yyb4172 { + if yyb4163 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4172-1, "") + z.DecStructFieldNotFound(yyj4163-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52086,8 +52004,8 @@ func (x ResourceQuotaScope) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4179 := z.EncBinary() - _ = yym4179 + yym4170 := z.EncBinary() + _ = yym4170 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -52099,8 +52017,8 @@ func (x *ResourceQuotaScope) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4180 := z.DecBinary() - _ = yym4180 + yym4171 := z.DecBinary() + _ = yym4171 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -52115,34 +52033,34 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4181 := z.EncBinary() - _ = yym4181 + yym4172 := z.EncBinary() + _ = yym4172 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4182 := !z.EncBinary() - yy2arr4182 := z.EncBasicHandle().StructToArray - var yyq4182 [2]bool - _, _, _ = yysep4182, yyq4182, yy2arr4182 - const yyr4182 bool = false - yyq4182[0] = len(x.Hard) != 0 - yyq4182[1] = len(x.Scopes) != 0 - var yynn4182 int - if yyr4182 || yy2arr4182 { + yysep4173 := !z.EncBinary() + yy2arr4173 := z.EncBasicHandle().StructToArray + var yyq4173 [2]bool + _, _, _ = yysep4173, yyq4173, yy2arr4173 + const yyr4173 bool = false + yyq4173[0] = len(x.Hard) != 0 + yyq4173[1] = len(x.Scopes) != 0 + var yynn4173 int + if yyr4173 || yy2arr4173 { r.EncodeArrayStart(2) } else { - yynn4182 = 0 - for _, b := range yyq4182 { + yynn4173 = 0 + for _, b := range yyq4173 { if b { - yynn4182++ + yynn4173++ } } - r.EncodeMapStart(yynn4182) - yynn4182 = 0 + r.EncodeMapStart(yynn4173) + yynn4173 = 0 } - if yyr4182 || yy2arr4182 { + if yyr4173 || yy2arr4173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4182[0] { + if yyq4173[0] { if x.Hard == nil { r.EncodeNil() } else { @@ -52152,7 +52070,7 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4182[0] { + if yyq4173[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hard")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -52163,14 +52081,14 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4182 || yy2arr4182 { + if yyr4173 || yy2arr4173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4182[1] { + if yyq4173[1] { if x.Scopes == nil { r.EncodeNil() } else { - yym4185 := z.EncBinary() - _ = yym4185 + yym4176 := z.EncBinary() + _ = yym4176 if false { } else { h.encSliceResourceQuotaScope(([]ResourceQuotaScope)(x.Scopes), e) @@ -52180,15 +52098,15 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4182[1] { + if yyq4173[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("scopes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Scopes == nil { r.EncodeNil() } else { - yym4186 := z.EncBinary() - _ = yym4186 + yym4177 := z.EncBinary() + _ = yym4177 if false { } else { h.encSliceResourceQuotaScope(([]ResourceQuotaScope)(x.Scopes), e) @@ -52196,7 +52114,7 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4182 || yy2arr4182 { + if yyr4173 || yy2arr4173 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52209,25 +52127,25 @@ func (x *ResourceQuotaSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4187 := z.DecBinary() - _ = yym4187 + yym4178 := z.DecBinary() + _ = yym4178 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4188 := r.ContainerType() - if yyct4188 == codecSelferValueTypeMap1234 { - yyl4188 := r.ReadMapStart() - if yyl4188 == 0 { + yyct4179 := r.ContainerType() + if yyct4179 == codecSelferValueTypeMap1234 { + yyl4179 := r.ReadMapStart() + if yyl4179 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4188, d) + x.codecDecodeSelfFromMap(yyl4179, d) } - } else if yyct4188 == codecSelferValueTypeArray1234 { - yyl4188 := r.ReadArrayStart() - if yyl4188 == 0 { + } else if yyct4179 == codecSelferValueTypeArray1234 { + yyl4179 := r.ReadArrayStart() + if yyl4179 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4188, d) + x.codecDecodeSelfFromArray(yyl4179, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52239,12 +52157,12 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4189Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4189Slc - var yyhl4189 bool = l >= 0 - for yyj4189 := 0; ; yyj4189++ { - if yyhl4189 { - if yyj4189 >= l { + var yys4180Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4180Slc + var yyhl4180 bool = l >= 0 + for yyj4180 := 0; ; yyj4180++ { + if yyhl4180 { + if yyj4180 >= l { break } } else { @@ -52253,33 +52171,33 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4189Slc = r.DecodeBytes(yys4189Slc, true, true) - yys4189 := string(yys4189Slc) + yys4180Slc = r.DecodeBytes(yys4180Slc, true, true) + yys4180 := string(yys4180Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4189 { + switch yys4180 { case "hard": if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4190 := &x.Hard - yyv4190.CodecDecodeSelf(d) + yyv4181 := &x.Hard + yyv4181.CodecDecodeSelf(d) } case "scopes": if r.TryDecodeAsNil() { x.Scopes = nil } else { - yyv4191 := &x.Scopes - yym4192 := z.DecBinary() - _ = yym4192 + yyv4182 := &x.Scopes + yym4183 := z.DecBinary() + _ = yym4183 if false { } else { - h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4191), d) + h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4182), d) } } default: - z.DecStructFieldNotFound(-1, yys4189) - } // end switch yys4189 - } // end for yyj4189 + z.DecStructFieldNotFound(-1, yys4180) + } // end switch yys4180 + } // end for yyj4180 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52287,16 +52205,16 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4193 int - var yyb4193 bool - var yyhl4193 bool = l >= 0 - yyj4193++ - if yyhl4193 { - yyb4193 = yyj4193 > l + var yyj4184 int + var yyb4184 bool + var yyhl4184 bool = l >= 0 + yyj4184++ + if yyhl4184 { + yyb4184 = yyj4184 > l } else { - yyb4193 = r.CheckBreak() + yyb4184 = r.CheckBreak() } - if yyb4193 { + if yyb4184 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52304,16 +52222,16 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4194 := &x.Hard - yyv4194.CodecDecodeSelf(d) + yyv4185 := &x.Hard + yyv4185.CodecDecodeSelf(d) } - yyj4193++ - if yyhl4193 { - yyb4193 = yyj4193 > l + yyj4184++ + if yyhl4184 { + yyb4184 = yyj4184 > l } else { - yyb4193 = r.CheckBreak() + yyb4184 = r.CheckBreak() } - if yyb4193 { + if yyb4184 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52321,26 +52239,26 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Scopes = nil } else { - yyv4195 := &x.Scopes - yym4196 := z.DecBinary() - _ = yym4196 + yyv4186 := &x.Scopes + yym4187 := z.DecBinary() + _ = yym4187 if false { } else { - h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4195), d) + h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4186), d) } } for { - yyj4193++ - if yyhl4193 { - yyb4193 = yyj4193 > l + yyj4184++ + if yyhl4184 { + yyb4184 = yyj4184 > l } else { - yyb4193 = r.CheckBreak() + yyb4184 = r.CheckBreak() } - if yyb4193 { + if yyb4184 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4193-1, "") + z.DecStructFieldNotFound(yyj4184-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52352,34 +52270,34 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4197 := z.EncBinary() - _ = yym4197 + yym4188 := z.EncBinary() + _ = yym4188 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4198 := !z.EncBinary() - yy2arr4198 := z.EncBasicHandle().StructToArray - var yyq4198 [2]bool - _, _, _ = yysep4198, yyq4198, yy2arr4198 - const yyr4198 bool = false - yyq4198[0] = len(x.Hard) != 0 - yyq4198[1] = len(x.Used) != 0 - var yynn4198 int - if yyr4198 || yy2arr4198 { + yysep4189 := !z.EncBinary() + yy2arr4189 := z.EncBasicHandle().StructToArray + var yyq4189 [2]bool + _, _, _ = yysep4189, yyq4189, yy2arr4189 + const yyr4189 bool = false + yyq4189[0] = len(x.Hard) != 0 + yyq4189[1] = len(x.Used) != 0 + var yynn4189 int + if yyr4189 || yy2arr4189 { r.EncodeArrayStart(2) } else { - yynn4198 = 0 - for _, b := range yyq4198 { + yynn4189 = 0 + for _, b := range yyq4189 { if b { - yynn4198++ + yynn4189++ } } - r.EncodeMapStart(yynn4198) - yynn4198 = 0 + r.EncodeMapStart(yynn4189) + yynn4189 = 0 } - if yyr4198 || yy2arr4198 { + if yyr4189 || yy2arr4189 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4198[0] { + if yyq4189[0] { if x.Hard == nil { r.EncodeNil() } else { @@ -52389,7 +52307,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4198[0] { + if yyq4189[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hard")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -52400,9 +52318,9 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4198 || yy2arr4198 { + if yyr4189 || yy2arr4189 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4198[1] { + if yyq4189[1] { if x.Used == nil { r.EncodeNil() } else { @@ -52412,7 +52330,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4198[1] { + if yyq4189[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("used")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -52423,7 +52341,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4198 || yy2arr4198 { + if yyr4189 || yy2arr4189 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52436,25 +52354,25 @@ func (x *ResourceQuotaStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4201 := z.DecBinary() - _ = yym4201 + yym4192 := z.DecBinary() + _ = yym4192 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4202 := r.ContainerType() - if yyct4202 == codecSelferValueTypeMap1234 { - yyl4202 := r.ReadMapStart() - if yyl4202 == 0 { + yyct4193 := r.ContainerType() + if yyct4193 == codecSelferValueTypeMap1234 { + yyl4193 := r.ReadMapStart() + if yyl4193 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4202, d) + x.codecDecodeSelfFromMap(yyl4193, d) } - } else if yyct4202 == codecSelferValueTypeArray1234 { - yyl4202 := r.ReadArrayStart() - if yyl4202 == 0 { + } else if yyct4193 == codecSelferValueTypeArray1234 { + yyl4193 := r.ReadArrayStart() + if yyl4193 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4202, d) + x.codecDecodeSelfFromArray(yyl4193, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52466,12 +52384,12 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4203Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4203Slc - var yyhl4203 bool = l >= 0 - for yyj4203 := 0; ; yyj4203++ { - if yyhl4203 { - if yyj4203 >= l { + var yys4194Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4194Slc + var yyhl4194 bool = l >= 0 + for yyj4194 := 0; ; yyj4194++ { + if yyhl4194 { + if yyj4194 >= l { break } } else { @@ -52480,28 +52398,28 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4203Slc = r.DecodeBytes(yys4203Slc, true, true) - yys4203 := string(yys4203Slc) + yys4194Slc = r.DecodeBytes(yys4194Slc, true, true) + yys4194 := string(yys4194Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4203 { + switch yys4194 { case "hard": if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4204 := &x.Hard - yyv4204.CodecDecodeSelf(d) + yyv4195 := &x.Hard + yyv4195.CodecDecodeSelf(d) } case "used": if r.TryDecodeAsNil() { x.Used = nil } else { - yyv4205 := &x.Used - yyv4205.CodecDecodeSelf(d) + yyv4196 := &x.Used + yyv4196.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4203) - } // end switch yys4203 - } // end for yyj4203 + z.DecStructFieldNotFound(-1, yys4194) + } // end switch yys4194 + } // end for yyj4194 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52509,16 +52427,16 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4206 int - var yyb4206 bool - var yyhl4206 bool = l >= 0 - yyj4206++ - if yyhl4206 { - yyb4206 = yyj4206 > l + var yyj4197 int + var yyb4197 bool + var yyhl4197 bool = l >= 0 + yyj4197++ + if yyhl4197 { + yyb4197 = yyj4197 > l } else { - yyb4206 = r.CheckBreak() + yyb4197 = r.CheckBreak() } - if yyb4206 { + if yyb4197 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52526,16 +52444,16 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4207 := &x.Hard - yyv4207.CodecDecodeSelf(d) + yyv4198 := &x.Hard + yyv4198.CodecDecodeSelf(d) } - yyj4206++ - if yyhl4206 { - yyb4206 = yyj4206 > l + yyj4197++ + if yyhl4197 { + yyb4197 = yyj4197 > l } else { - yyb4206 = r.CheckBreak() + yyb4197 = r.CheckBreak() } - if yyb4206 { + if yyb4197 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52543,21 +52461,21 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Used = nil } else { - yyv4208 := &x.Used - yyv4208.CodecDecodeSelf(d) + yyv4199 := &x.Used + yyv4199.CodecDecodeSelf(d) } for { - yyj4206++ - if yyhl4206 { - yyb4206 = yyj4206 > l + yyj4197++ + if yyhl4197 { + yyb4197 = yyj4197 > l } else { - yyb4206 = r.CheckBreak() + yyb4197 = r.CheckBreak() } - if yyb4206 { + if yyb4197 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4206-1, "") + z.DecStructFieldNotFound(yyj4197-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52569,39 +52487,39 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4209 := z.EncBinary() - _ = yym4209 + yym4200 := z.EncBinary() + _ = yym4200 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4210 := !z.EncBinary() - yy2arr4210 := z.EncBasicHandle().StructToArray - var yyq4210 [5]bool - _, _, _ = yysep4210, yyq4210, yy2arr4210 - const yyr4210 bool = false - yyq4210[0] = x.Kind != "" - yyq4210[1] = x.APIVersion != "" - yyq4210[2] = true - yyq4210[3] = true - yyq4210[4] = true - var yynn4210 int - if yyr4210 || yy2arr4210 { + yysep4201 := !z.EncBinary() + yy2arr4201 := z.EncBasicHandle().StructToArray + var yyq4201 [5]bool + _, _, _ = yysep4201, yyq4201, yy2arr4201 + const yyr4201 bool = false + yyq4201[0] = x.Kind != "" + yyq4201[1] = x.APIVersion != "" + yyq4201[2] = true + yyq4201[3] = true + yyq4201[4] = true + var yynn4201 int + if yyr4201 || yy2arr4201 { r.EncodeArrayStart(5) } else { - yynn4210 = 0 - for _, b := range yyq4210 { + yynn4201 = 0 + for _, b := range yyq4201 { if b { - yynn4210++ + yynn4201++ } } - r.EncodeMapStart(yynn4210) - yynn4210 = 0 + r.EncodeMapStart(yynn4201) + yynn4201 = 0 } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4210[0] { - yym4212 := z.EncBinary() - _ = yym4212 + if yyq4201[0] { + yym4203 := z.EncBinary() + _ = yym4203 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -52610,23 +52528,23 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4210[0] { + if yyq4201[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4213 := z.EncBinary() - _ = yym4213 + yym4204 := z.EncBinary() + _ = yym4204 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4210[1] { - yym4215 := z.EncBinary() - _ = yym4215 + if yyq4201[1] { + yym4206 := z.EncBinary() + _ = yym4206 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -52635,70 +52553,70 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4210[1] { + if yyq4201[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4216 := z.EncBinary() - _ = yym4216 + yym4207 := z.EncBinary() + _ = yym4207 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4210[2] { - yy4218 := &x.ObjectMeta - yy4218.CodecEncodeSelf(e) + if yyq4201[2] { + yy4209 := &x.ObjectMeta + yy4209.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4210[2] { + if yyq4201[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4219 := &x.ObjectMeta - yy4219.CodecEncodeSelf(e) + yy4210 := &x.ObjectMeta + yy4210.CodecEncodeSelf(e) } } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4210[3] { - yy4221 := &x.Spec - yy4221.CodecEncodeSelf(e) + if yyq4201[3] { + yy4212 := &x.Spec + yy4212.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4210[3] { + if yyq4201[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4222 := &x.Spec - yy4222.CodecEncodeSelf(e) + yy4213 := &x.Spec + yy4213.CodecEncodeSelf(e) } } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4210[4] { - yy4224 := &x.Status - yy4224.CodecEncodeSelf(e) + if yyq4201[4] { + yy4215 := &x.Status + yy4215.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4210[4] { + if yyq4201[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4225 := &x.Status - yy4225.CodecEncodeSelf(e) + yy4216 := &x.Status + yy4216.CodecEncodeSelf(e) } } - if yyr4210 || yy2arr4210 { + if yyr4201 || yy2arr4201 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52711,25 +52629,25 @@ func (x *ResourceQuota) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4226 := z.DecBinary() - _ = yym4226 + yym4217 := z.DecBinary() + _ = yym4217 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4227 := r.ContainerType() - if yyct4227 == codecSelferValueTypeMap1234 { - yyl4227 := r.ReadMapStart() - if yyl4227 == 0 { + yyct4218 := r.ContainerType() + if yyct4218 == codecSelferValueTypeMap1234 { + yyl4218 := r.ReadMapStart() + if yyl4218 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4227, d) + x.codecDecodeSelfFromMap(yyl4218, d) } - } else if yyct4227 == codecSelferValueTypeArray1234 { - yyl4227 := r.ReadArrayStart() - if yyl4227 == 0 { + } else if yyct4218 == codecSelferValueTypeArray1234 { + yyl4218 := r.ReadArrayStart() + if yyl4218 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4227, d) + x.codecDecodeSelfFromArray(yyl4218, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52741,12 +52659,12 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4228Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4228Slc - var yyhl4228 bool = l >= 0 - for yyj4228 := 0; ; yyj4228++ { - if yyhl4228 { - if yyj4228 >= l { + var yys4219Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4219Slc + var yyhl4219 bool = l >= 0 + for yyj4219 := 0; ; yyj4219++ { + if yyhl4219 { + if yyj4219 >= l { break } } else { @@ -52755,10 +52673,10 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4228Slc = r.DecodeBytes(yys4228Slc, true, true) - yys4228 := string(yys4228Slc) + yys4219Slc = r.DecodeBytes(yys4219Slc, true, true) + yys4219 := string(yys4219Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4228 { + switch yys4219 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -52775,27 +52693,27 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4231 := &x.ObjectMeta - yyv4231.CodecDecodeSelf(d) + yyv4222 := &x.ObjectMeta + yyv4222.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ResourceQuotaSpec{} } else { - yyv4232 := &x.Spec - yyv4232.CodecDecodeSelf(d) + yyv4223 := &x.Spec + yyv4223.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ResourceQuotaStatus{} } else { - yyv4233 := &x.Status - yyv4233.CodecDecodeSelf(d) + yyv4224 := &x.Status + yyv4224.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4228) - } // end switch yys4228 - } // end for yyj4228 + z.DecStructFieldNotFound(-1, yys4219) + } // end switch yys4219 + } // end for yyj4219 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52803,16 +52721,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4234 int - var yyb4234 bool - var yyhl4234 bool = l >= 0 - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + var yyj4225 int + var yyb4225 bool + var yyhl4225 bool = l >= 0 + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52822,13 +52740,13 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52838,13 +52756,13 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52852,16 +52770,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4237 := &x.ObjectMeta - yyv4237.CodecDecodeSelf(d) + yyv4228 := &x.ObjectMeta + yyv4228.CodecDecodeSelf(d) } - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52869,16 +52787,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ResourceQuotaSpec{} } else { - yyv4238 := &x.Spec - yyv4238.CodecDecodeSelf(d) + yyv4229 := &x.Spec + yyv4229.CodecDecodeSelf(d) } - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52886,21 +52804,21 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ResourceQuotaStatus{} } else { - yyv4239 := &x.Status - yyv4239.CodecDecodeSelf(d) + yyv4230 := &x.Status + yyv4230.CodecDecodeSelf(d) } for { - yyj4234++ - if yyhl4234 { - yyb4234 = yyj4234 > l + yyj4225++ + if yyhl4225 { + yyb4225 = yyj4225 > l } else { - yyb4234 = r.CheckBreak() + yyb4225 = r.CheckBreak() } - if yyb4234 { + if yyb4225 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4234-1, "") + z.DecStructFieldNotFound(yyj4225-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52912,37 +52830,37 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4240 := z.EncBinary() - _ = yym4240 + yym4231 := z.EncBinary() + _ = yym4231 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4241 := !z.EncBinary() - yy2arr4241 := z.EncBasicHandle().StructToArray - var yyq4241 [4]bool - _, _, _ = yysep4241, yyq4241, yy2arr4241 - const yyr4241 bool = false - yyq4241[0] = x.Kind != "" - yyq4241[1] = x.APIVersion != "" - yyq4241[2] = true - var yynn4241 int - if yyr4241 || yy2arr4241 { + yysep4232 := !z.EncBinary() + yy2arr4232 := z.EncBasicHandle().StructToArray + var yyq4232 [4]bool + _, _, _ = yysep4232, yyq4232, yy2arr4232 + const yyr4232 bool = false + yyq4232[0] = x.Kind != "" + yyq4232[1] = x.APIVersion != "" + yyq4232[2] = true + var yynn4232 int + if yyr4232 || yy2arr4232 { r.EncodeArrayStart(4) } else { - yynn4241 = 1 - for _, b := range yyq4241 { + yynn4232 = 1 + for _, b := range yyq4232 { if b { - yynn4241++ + yynn4232++ } } - r.EncodeMapStart(yynn4241) - yynn4241 = 0 + r.EncodeMapStart(yynn4232) + yynn4232 = 0 } - if yyr4241 || yy2arr4241 { + if yyr4232 || yy2arr4232 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4241[0] { - yym4243 := z.EncBinary() - _ = yym4243 + if yyq4232[0] { + yym4234 := z.EncBinary() + _ = yym4234 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -52951,23 +52869,23 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4241[0] { + if yyq4232[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4244 := z.EncBinary() - _ = yym4244 + yym4235 := z.EncBinary() + _ = yym4235 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4241 || yy2arr4241 { + if yyr4232 || yy2arr4232 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4241[1] { - yym4246 := z.EncBinary() - _ = yym4246 + if yyq4232[1] { + yym4237 := z.EncBinary() + _ = yym4237 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -52976,54 +52894,54 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4241[1] { + if yyq4232[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4247 := z.EncBinary() - _ = yym4247 + yym4238 := z.EncBinary() + _ = yym4238 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4241 || yy2arr4241 { + if yyr4232 || yy2arr4232 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4241[2] { - yy4249 := &x.ListMeta - yym4250 := z.EncBinary() - _ = yym4250 + if yyq4232[2] { + yy4240 := &x.ListMeta + yym4241 := z.EncBinary() + _ = yym4241 if false { - } else if z.HasExtensions() && z.EncExt(yy4249) { + } else if z.HasExtensions() && z.EncExt(yy4240) { } else { - z.EncFallback(yy4249) + z.EncFallback(yy4240) } } else { r.EncodeNil() } } else { - if yyq4241[2] { + if yyq4232[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4251 := &x.ListMeta - yym4252 := z.EncBinary() - _ = yym4252 + yy4242 := &x.ListMeta + yym4243 := z.EncBinary() + _ = yym4243 if false { - } else if z.HasExtensions() && z.EncExt(yy4251) { + } else if z.HasExtensions() && z.EncExt(yy4242) { } else { - z.EncFallback(yy4251) + z.EncFallback(yy4242) } } } - if yyr4241 || yy2arr4241 { + if yyr4232 || yy2arr4232 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4254 := z.EncBinary() - _ = yym4254 + yym4245 := z.EncBinary() + _ = yym4245 if false { } else { h.encSliceResourceQuota(([]ResourceQuota)(x.Items), e) @@ -53036,15 +52954,15 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4255 := z.EncBinary() - _ = yym4255 + yym4246 := z.EncBinary() + _ = yym4246 if false { } else { h.encSliceResourceQuota(([]ResourceQuota)(x.Items), e) } } } - if yyr4241 || yy2arr4241 { + if yyr4232 || yy2arr4232 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53057,25 +52975,25 @@ func (x *ResourceQuotaList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4256 := z.DecBinary() - _ = yym4256 + yym4247 := z.DecBinary() + _ = yym4247 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4257 := r.ContainerType() - if yyct4257 == codecSelferValueTypeMap1234 { - yyl4257 := r.ReadMapStart() - if yyl4257 == 0 { + yyct4248 := r.ContainerType() + if yyct4248 == codecSelferValueTypeMap1234 { + yyl4248 := r.ReadMapStart() + if yyl4248 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4257, d) + x.codecDecodeSelfFromMap(yyl4248, d) } - } else if yyct4257 == codecSelferValueTypeArray1234 { - yyl4257 := r.ReadArrayStart() - if yyl4257 == 0 { + } else if yyct4248 == codecSelferValueTypeArray1234 { + yyl4248 := r.ReadArrayStart() + if yyl4248 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4257, d) + x.codecDecodeSelfFromArray(yyl4248, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53087,12 +53005,12 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4258Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4258Slc - var yyhl4258 bool = l >= 0 - for yyj4258 := 0; ; yyj4258++ { - if yyhl4258 { - if yyj4258 >= l { + var yys4249Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4249Slc + var yyhl4249 bool = l >= 0 + for yyj4249 := 0; ; yyj4249++ { + if yyhl4249 { + if yyj4249 >= l { break } } else { @@ -53101,10 +53019,10 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4258Slc = r.DecodeBytes(yys4258Slc, true, true) - yys4258 := string(yys4258Slc) + yys4249Slc = r.DecodeBytes(yys4249Slc, true, true) + yys4249 := string(yys4249Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4258 { + switch yys4249 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53121,31 +53039,31 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4261 := &x.ListMeta - yym4262 := z.DecBinary() - _ = yym4262 + yyv4252 := &x.ListMeta + yym4253 := z.DecBinary() + _ = yym4253 if false { - } else if z.HasExtensions() && z.DecExt(yyv4261) { + } else if z.HasExtensions() && z.DecExt(yyv4252) { } else { - z.DecFallback(yyv4261, false) + z.DecFallback(yyv4252, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4263 := &x.Items - yym4264 := z.DecBinary() - _ = yym4264 + yyv4254 := &x.Items + yym4255 := z.DecBinary() + _ = yym4255 if false { } else { - h.decSliceResourceQuota((*[]ResourceQuota)(yyv4263), d) + h.decSliceResourceQuota((*[]ResourceQuota)(yyv4254), d) } } default: - z.DecStructFieldNotFound(-1, yys4258) - } // end switch yys4258 - } // end for yyj4258 + z.DecStructFieldNotFound(-1, yys4249) + } // end switch yys4249 + } // end for yyj4249 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -53153,16 +53071,16 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4265 int - var yyb4265 bool - var yyhl4265 bool = l >= 0 - yyj4265++ - if yyhl4265 { - yyb4265 = yyj4265 > l + var yyj4256 int + var yyb4256 bool + var yyhl4256 bool = l >= 0 + yyj4256++ + if yyhl4256 { + yyb4256 = yyj4256 > l } else { - yyb4265 = r.CheckBreak() + yyb4256 = r.CheckBreak() } - if yyb4265 { + if yyb4256 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53172,13 +53090,13 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj4265++ - if yyhl4265 { - yyb4265 = yyj4265 > l + yyj4256++ + if yyhl4256 { + yyb4256 = yyj4256 > l } else { - yyb4265 = r.CheckBreak() + yyb4256 = r.CheckBreak() } - if yyb4265 { + if yyb4256 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53188,13 +53106,13 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj4265++ - if yyhl4265 { - yyb4265 = yyj4265 > l + yyj4256++ + if yyhl4256 { + yyb4256 = yyj4256 > l } else { - yyb4265 = r.CheckBreak() + yyb4256 = r.CheckBreak() } - if yyb4265 { + if yyb4256 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53202,22 +53120,22 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4268 := &x.ListMeta - yym4269 := z.DecBinary() - _ = yym4269 + yyv4259 := &x.ListMeta + yym4260 := z.DecBinary() + _ = yym4260 if false { - } else if z.HasExtensions() && z.DecExt(yyv4268) { + } else if z.HasExtensions() && z.DecExt(yyv4259) { } else { - z.DecFallback(yyv4268, false) + z.DecFallback(yyv4259, false) } } - yyj4265++ - if yyhl4265 { - yyb4265 = yyj4265 > l + yyj4256++ + if yyhl4256 { + yyb4256 = yyj4256 > l } else { - yyb4265 = r.CheckBreak() + yyb4256 = r.CheckBreak() } - if yyb4265 { + if yyb4256 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53225,26 +53143,26 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4270 := &x.Items - yym4271 := z.DecBinary() - _ = yym4271 + yyv4261 := &x.Items + yym4262 := z.DecBinary() + _ = yym4262 if false { } else { - h.decSliceResourceQuota((*[]ResourceQuota)(yyv4270), d) + h.decSliceResourceQuota((*[]ResourceQuota)(yyv4261), d) } } for { - yyj4265++ - if yyhl4265 { - yyb4265 = yyj4265 > l + yyj4256++ + if yyhl4256 { + yyb4256 = yyj4256 > l } else { - yyb4265 = r.CheckBreak() + yyb4256 = r.CheckBreak() } - if yyb4265 { + if yyb4256 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4265-1, "") + z.DecStructFieldNotFound(yyj4256-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53256,39 +53174,39 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4272 := z.EncBinary() - _ = yym4272 + yym4263 := z.EncBinary() + _ = yym4263 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4273 := !z.EncBinary() - yy2arr4273 := z.EncBasicHandle().StructToArray - var yyq4273 [5]bool - _, _, _ = yysep4273, yyq4273, yy2arr4273 - const yyr4273 bool = false - yyq4273[0] = x.Kind != "" - yyq4273[1] = x.APIVersion != "" - yyq4273[2] = true - yyq4273[3] = len(x.Data) != 0 - yyq4273[4] = x.Type != "" - var yynn4273 int - if yyr4273 || yy2arr4273 { + yysep4264 := !z.EncBinary() + yy2arr4264 := z.EncBasicHandle().StructToArray + var yyq4264 [5]bool + _, _, _ = yysep4264, yyq4264, yy2arr4264 + const yyr4264 bool = false + yyq4264[0] = x.Kind != "" + yyq4264[1] = x.APIVersion != "" + yyq4264[2] = true + yyq4264[3] = len(x.Data) != 0 + yyq4264[4] = x.Type != "" + var yynn4264 int + if yyr4264 || yy2arr4264 { r.EncodeArrayStart(5) } else { - yynn4273 = 0 - for _, b := range yyq4273 { + yynn4264 = 0 + for _, b := range yyq4264 { if b { - yynn4273++ + yynn4264++ } } - r.EncodeMapStart(yynn4273) - yynn4273 = 0 + r.EncodeMapStart(yynn4264) + yynn4264 = 0 } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4273[0] { - yym4275 := z.EncBinary() - _ = yym4275 + if yyq4264[0] { + yym4266 := z.EncBinary() + _ = yym4266 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -53297,23 +53215,23 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4273[0] { + if yyq4264[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4276 := z.EncBinary() - _ = yym4276 + yym4267 := z.EncBinary() + _ = yym4267 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4273[1] { - yym4278 := z.EncBinary() - _ = yym4278 + if yyq4264[1] { + yym4269 := z.EncBinary() + _ = yym4269 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -53322,43 +53240,43 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4273[1] { + if yyq4264[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4279 := z.EncBinary() - _ = yym4279 + yym4270 := z.EncBinary() + _ = yym4270 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4273[2] { - yy4281 := &x.ObjectMeta - yy4281.CodecEncodeSelf(e) + if yyq4264[2] { + yy4272 := &x.ObjectMeta + yy4272.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4273[2] { + if yyq4264[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4282 := &x.ObjectMeta - yy4282.CodecEncodeSelf(e) + yy4273 := &x.ObjectMeta + yy4273.CodecEncodeSelf(e) } } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4273[3] { + if yyq4264[3] { if x.Data == nil { r.EncodeNil() } else { - yym4284 := z.EncBinary() - _ = yym4284 + yym4275 := z.EncBinary() + _ = yym4275 if false { } else { h.encMapstringSliceuint8((map[string][]uint8)(x.Data), e) @@ -53368,15 +53286,15 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4273[3] { + if yyq4264[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("data")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Data == nil { r.EncodeNil() } else { - yym4285 := z.EncBinary() - _ = yym4285 + yym4276 := z.EncBinary() + _ = yym4276 if false { } else { h.encMapstringSliceuint8((map[string][]uint8)(x.Data), e) @@ -53384,22 +53302,22 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4273[4] { + if yyq4264[4] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4273[4] { + if yyq4264[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr4273 || yy2arr4273 { + if yyr4264 || yy2arr4264 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53412,25 +53330,25 @@ func (x *Secret) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4287 := z.DecBinary() - _ = yym4287 + yym4278 := z.DecBinary() + _ = yym4278 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4288 := r.ContainerType() - if yyct4288 == codecSelferValueTypeMap1234 { - yyl4288 := r.ReadMapStart() - if yyl4288 == 0 { + yyct4279 := r.ContainerType() + if yyct4279 == codecSelferValueTypeMap1234 { + yyl4279 := r.ReadMapStart() + if yyl4279 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4288, d) + x.codecDecodeSelfFromMap(yyl4279, d) } - } else if yyct4288 == codecSelferValueTypeArray1234 { - yyl4288 := r.ReadArrayStart() - if yyl4288 == 0 { + } else if yyct4279 == codecSelferValueTypeArray1234 { + yyl4279 := r.ReadArrayStart() + if yyl4279 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4288, d) + x.codecDecodeSelfFromArray(yyl4279, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53442,12 +53360,12 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4289Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4289Slc - var yyhl4289 bool = l >= 0 - for yyj4289 := 0; ; yyj4289++ { - if yyhl4289 { - if yyj4289 >= l { + var yys4280Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4280Slc + var yyhl4280 bool = l >= 0 + for yyj4280 := 0; ; yyj4280++ { + if yyhl4280 { + if yyj4280 >= l { break } } else { @@ -53456,10 +53374,10 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4289Slc = r.DecodeBytes(yys4289Slc, true, true) - yys4289 := string(yys4289Slc) + yys4280Slc = r.DecodeBytes(yys4280Slc, true, true) + yys4280 := string(yys4280Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4289 { + switch yys4280 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53476,19 +53394,19 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4292 := &x.ObjectMeta - yyv4292.CodecDecodeSelf(d) + yyv4283 := &x.ObjectMeta + yyv4283.CodecDecodeSelf(d) } case "data": if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4293 := &x.Data - yym4294 := z.DecBinary() - _ = yym4294 + yyv4284 := &x.Data + yym4285 := z.DecBinary() + _ = yym4285 if false { } else { - h.decMapstringSliceuint8((*map[string][]uint8)(yyv4293), d) + h.decMapstringSliceuint8((*map[string][]uint8)(yyv4284), d) } } case "type": @@ -53498,9 +53416,9 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Type = SecretType(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4289) - } // end switch yys4289 - } // end for yyj4289 + z.DecStructFieldNotFound(-1, yys4280) + } // end switch yys4280 + } // end for yyj4280 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -53508,16 +53426,16 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4296 int - var yyb4296 bool - var yyhl4296 bool = l >= 0 - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + var yyj4287 int + var yyb4287 bool + var yyhl4287 bool = l >= 0 + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53527,13 +53445,13 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53543,13 +53461,13 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53557,16 +53475,16 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4299 := &x.ObjectMeta - yyv4299.CodecDecodeSelf(d) + yyv4290 := &x.ObjectMeta + yyv4290.CodecDecodeSelf(d) } - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53574,21 +53492,21 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4300 := &x.Data - yym4301 := z.DecBinary() - _ = yym4301 + yyv4291 := &x.Data + yym4292 := z.DecBinary() + _ = yym4292 if false { } else { - h.decMapstringSliceuint8((*map[string][]uint8)(yyv4300), d) + h.decMapstringSliceuint8((*map[string][]uint8)(yyv4291), d) } } - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53599,17 +53517,17 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Type = SecretType(r.DecodeString()) } for { - yyj4296++ - if yyhl4296 { - yyb4296 = yyj4296 > l + yyj4287++ + if yyhl4287 { + yyb4287 = yyj4287 > l } else { - yyb4296 = r.CheckBreak() + yyb4287 = r.CheckBreak() } - if yyb4296 { + if yyb4287 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4296-1, "") + z.DecStructFieldNotFound(yyj4287-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53618,8 +53536,8 @@ func (x SecretType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4303 := z.EncBinary() - _ = yym4303 + yym4294 := z.EncBinary() + _ = yym4294 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -53631,8 +53549,8 @@ func (x *SecretType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4304 := z.DecBinary() - _ = yym4304 + yym4295 := z.DecBinary() + _ = yym4295 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -53647,37 +53565,37 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4305 := z.EncBinary() - _ = yym4305 + yym4296 := z.EncBinary() + _ = yym4296 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4306 := !z.EncBinary() - yy2arr4306 := z.EncBasicHandle().StructToArray - var yyq4306 [4]bool - _, _, _ = yysep4306, yyq4306, yy2arr4306 - const yyr4306 bool = false - yyq4306[0] = x.Kind != "" - yyq4306[1] = x.APIVersion != "" - yyq4306[2] = true - var yynn4306 int - if yyr4306 || yy2arr4306 { + yysep4297 := !z.EncBinary() + yy2arr4297 := z.EncBasicHandle().StructToArray + var yyq4297 [4]bool + _, _, _ = yysep4297, yyq4297, yy2arr4297 + const yyr4297 bool = false + yyq4297[0] = x.Kind != "" + yyq4297[1] = x.APIVersion != "" + yyq4297[2] = true + var yynn4297 int + if yyr4297 || yy2arr4297 { r.EncodeArrayStart(4) } else { - yynn4306 = 1 - for _, b := range yyq4306 { + yynn4297 = 1 + for _, b := range yyq4297 { if b { - yynn4306++ + yynn4297++ } } - r.EncodeMapStart(yynn4306) - yynn4306 = 0 + r.EncodeMapStart(yynn4297) + yynn4297 = 0 } - if yyr4306 || yy2arr4306 { + if yyr4297 || yy2arr4297 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4306[0] { - yym4308 := z.EncBinary() - _ = yym4308 + if yyq4297[0] { + yym4299 := z.EncBinary() + _ = yym4299 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -53686,23 +53604,23 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4306[0] { + if yyq4297[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4309 := z.EncBinary() - _ = yym4309 + yym4300 := z.EncBinary() + _ = yym4300 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4306 || yy2arr4306 { + if yyr4297 || yy2arr4297 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4306[1] { - yym4311 := z.EncBinary() - _ = yym4311 + if yyq4297[1] { + yym4302 := z.EncBinary() + _ = yym4302 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -53711,54 +53629,54 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4306[1] { + if yyq4297[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4312 := z.EncBinary() - _ = yym4312 + yym4303 := z.EncBinary() + _ = yym4303 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4306 || yy2arr4306 { + if yyr4297 || yy2arr4297 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4306[2] { - yy4314 := &x.ListMeta - yym4315 := z.EncBinary() - _ = yym4315 + if yyq4297[2] { + yy4305 := &x.ListMeta + yym4306 := z.EncBinary() + _ = yym4306 if false { - } else if z.HasExtensions() && z.EncExt(yy4314) { + } else if z.HasExtensions() && z.EncExt(yy4305) { } else { - z.EncFallback(yy4314) + z.EncFallback(yy4305) } } else { r.EncodeNil() } } else { - if yyq4306[2] { + if yyq4297[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4316 := &x.ListMeta - yym4317 := z.EncBinary() - _ = yym4317 + yy4307 := &x.ListMeta + yym4308 := z.EncBinary() + _ = yym4308 if false { - } else if z.HasExtensions() && z.EncExt(yy4316) { + } else if z.HasExtensions() && z.EncExt(yy4307) { } else { - z.EncFallback(yy4316) + z.EncFallback(yy4307) } } } - if yyr4306 || yy2arr4306 { + if yyr4297 || yy2arr4297 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4319 := z.EncBinary() - _ = yym4319 + yym4310 := z.EncBinary() + _ = yym4310 if false { } else { h.encSliceSecret(([]Secret)(x.Items), e) @@ -53771,15 +53689,15 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4320 := z.EncBinary() - _ = yym4320 + yym4311 := z.EncBinary() + _ = yym4311 if false { } else { h.encSliceSecret(([]Secret)(x.Items), e) } } } - if yyr4306 || yy2arr4306 { + if yyr4297 || yy2arr4297 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53792,25 +53710,25 @@ func (x *SecretList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4321 := z.DecBinary() - _ = yym4321 + yym4312 := z.DecBinary() + _ = yym4312 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4322 := r.ContainerType() - if yyct4322 == codecSelferValueTypeMap1234 { - yyl4322 := r.ReadMapStart() - if yyl4322 == 0 { + yyct4313 := r.ContainerType() + if yyct4313 == codecSelferValueTypeMap1234 { + yyl4313 := r.ReadMapStart() + if yyl4313 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4322, d) + x.codecDecodeSelfFromMap(yyl4313, d) } - } else if yyct4322 == codecSelferValueTypeArray1234 { - yyl4322 := r.ReadArrayStart() - if yyl4322 == 0 { + } else if yyct4313 == codecSelferValueTypeArray1234 { + yyl4313 := r.ReadArrayStart() + if yyl4313 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4322, d) + x.codecDecodeSelfFromArray(yyl4313, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53822,12 +53740,12 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4323Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4323Slc - var yyhl4323 bool = l >= 0 - for yyj4323 := 0; ; yyj4323++ { - if yyhl4323 { - if yyj4323 >= l { + var yys4314Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4314Slc + var yyhl4314 bool = l >= 0 + for yyj4314 := 0; ; yyj4314++ { + if yyhl4314 { + if yyj4314 >= l { break } } else { @@ -53836,10 +53754,10 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4323Slc = r.DecodeBytes(yys4323Slc, true, true) - yys4323 := string(yys4323Slc) + yys4314Slc = r.DecodeBytes(yys4314Slc, true, true) + yys4314 := string(yys4314Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4323 { + switch yys4314 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53856,31 +53774,31 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4326 := &x.ListMeta - yym4327 := z.DecBinary() - _ = yym4327 + yyv4317 := &x.ListMeta + yym4318 := z.DecBinary() + _ = yym4318 if false { - } else if z.HasExtensions() && z.DecExt(yyv4326) { + } else if z.HasExtensions() && z.DecExt(yyv4317) { } else { - z.DecFallback(yyv4326, false) + z.DecFallback(yyv4317, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4328 := &x.Items - yym4329 := z.DecBinary() - _ = yym4329 + yyv4319 := &x.Items + yym4320 := z.DecBinary() + _ = yym4320 if false { } else { - h.decSliceSecret((*[]Secret)(yyv4328), d) + h.decSliceSecret((*[]Secret)(yyv4319), d) } } default: - z.DecStructFieldNotFound(-1, yys4323) - } // end switch yys4323 - } // end for yyj4323 + z.DecStructFieldNotFound(-1, yys4314) + } // end switch yys4314 + } // end for yyj4314 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -53888,16 +53806,16 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4330 int - var yyb4330 bool - var yyhl4330 bool = l >= 0 - yyj4330++ - if yyhl4330 { - yyb4330 = yyj4330 > l + var yyj4321 int + var yyb4321 bool + var yyhl4321 bool = l >= 0 + yyj4321++ + if yyhl4321 { + yyb4321 = yyj4321 > l } else { - yyb4330 = r.CheckBreak() + yyb4321 = r.CheckBreak() } - if yyb4330 { + if yyb4321 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53907,13 +53825,13 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4330++ - if yyhl4330 { - yyb4330 = yyj4330 > l + yyj4321++ + if yyhl4321 { + yyb4321 = yyj4321 > l } else { - yyb4330 = r.CheckBreak() + yyb4321 = r.CheckBreak() } - if yyb4330 { + if yyb4321 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53923,13 +53841,13 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4330++ - if yyhl4330 { - yyb4330 = yyj4330 > l + yyj4321++ + if yyhl4321 { + yyb4321 = yyj4321 > l } else { - yyb4330 = r.CheckBreak() + yyb4321 = r.CheckBreak() } - if yyb4330 { + if yyb4321 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53937,22 +53855,22 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4333 := &x.ListMeta - yym4334 := z.DecBinary() - _ = yym4334 + yyv4324 := &x.ListMeta + yym4325 := z.DecBinary() + _ = yym4325 if false { - } else if z.HasExtensions() && z.DecExt(yyv4333) { + } else if z.HasExtensions() && z.DecExt(yyv4324) { } else { - z.DecFallback(yyv4333, false) + z.DecFallback(yyv4324, false) } } - yyj4330++ - if yyhl4330 { - yyb4330 = yyj4330 > l + yyj4321++ + if yyhl4321 { + yyb4321 = yyj4321 > l } else { - yyb4330 = r.CheckBreak() + yyb4321 = r.CheckBreak() } - if yyb4330 { + if yyb4321 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53960,26 +53878,26 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4335 := &x.Items - yym4336 := z.DecBinary() - _ = yym4336 + yyv4326 := &x.Items + yym4327 := z.DecBinary() + _ = yym4327 if false { } else { - h.decSliceSecret((*[]Secret)(yyv4335), d) + h.decSliceSecret((*[]Secret)(yyv4326), d) } } for { - yyj4330++ - if yyhl4330 { - yyb4330 = yyj4330 > l + yyj4321++ + if yyhl4321 { + yyb4321 = yyj4321 > l } else { - yyb4330 = r.CheckBreak() + yyb4321 = r.CheckBreak() } - if yyb4330 { + if yyb4321 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4330-1, "") + z.DecStructFieldNotFound(yyj4321-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53991,38 +53909,38 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4337 := z.EncBinary() - _ = yym4337 + yym4328 := z.EncBinary() + _ = yym4328 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4338 := !z.EncBinary() - yy2arr4338 := z.EncBasicHandle().StructToArray - var yyq4338 [4]bool - _, _, _ = yysep4338, yyq4338, yy2arr4338 - const yyr4338 bool = false - yyq4338[0] = x.Kind != "" - yyq4338[1] = x.APIVersion != "" - yyq4338[2] = true - yyq4338[3] = len(x.Data) != 0 - var yynn4338 int - if yyr4338 || yy2arr4338 { + yysep4329 := !z.EncBinary() + yy2arr4329 := z.EncBasicHandle().StructToArray + var yyq4329 [4]bool + _, _, _ = yysep4329, yyq4329, yy2arr4329 + const yyr4329 bool = false + yyq4329[0] = x.Kind != "" + yyq4329[1] = x.APIVersion != "" + yyq4329[2] = true + yyq4329[3] = len(x.Data) != 0 + var yynn4329 int + if yyr4329 || yy2arr4329 { r.EncodeArrayStart(4) } else { - yynn4338 = 0 - for _, b := range yyq4338 { + yynn4329 = 0 + for _, b := range yyq4329 { if b { - yynn4338++ + yynn4329++ } } - r.EncodeMapStart(yynn4338) - yynn4338 = 0 + r.EncodeMapStart(yynn4329) + yynn4329 = 0 } - if yyr4338 || yy2arr4338 { + if yyr4329 || yy2arr4329 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4338[0] { - yym4340 := z.EncBinary() - _ = yym4340 + if yyq4329[0] { + yym4331 := z.EncBinary() + _ = yym4331 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -54031,23 +53949,23 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4338[0] { + if yyq4329[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4341 := z.EncBinary() - _ = yym4341 + yym4332 := z.EncBinary() + _ = yym4332 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4338 || yy2arr4338 { + if yyr4329 || yy2arr4329 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4338[1] { - yym4343 := z.EncBinary() - _ = yym4343 + if yyq4329[1] { + yym4334 := z.EncBinary() + _ = yym4334 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -54056,43 +53974,43 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4338[1] { + if yyq4329[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4344 := z.EncBinary() - _ = yym4344 + yym4335 := z.EncBinary() + _ = yym4335 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4338 || yy2arr4338 { + if yyr4329 || yy2arr4329 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4338[2] { - yy4346 := &x.ObjectMeta - yy4346.CodecEncodeSelf(e) + if yyq4329[2] { + yy4337 := &x.ObjectMeta + yy4337.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4338[2] { + if yyq4329[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4347 := &x.ObjectMeta - yy4347.CodecEncodeSelf(e) + yy4338 := &x.ObjectMeta + yy4338.CodecEncodeSelf(e) } } - if yyr4338 || yy2arr4338 { + if yyr4329 || yy2arr4329 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4338[3] { + if yyq4329[3] { if x.Data == nil { r.EncodeNil() } else { - yym4349 := z.EncBinary() - _ = yym4349 + yym4340 := z.EncBinary() + _ = yym4340 if false { } else { z.F.EncMapStringStringV(x.Data, false, e) @@ -54102,15 +54020,15 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4338[3] { + if yyq4329[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("data")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Data == nil { r.EncodeNil() } else { - yym4350 := z.EncBinary() - _ = yym4350 + yym4341 := z.EncBinary() + _ = yym4341 if false { } else { z.F.EncMapStringStringV(x.Data, false, e) @@ -54118,7 +54036,7 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4338 || yy2arr4338 { + if yyr4329 || yy2arr4329 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54131,25 +54049,25 @@ func (x *ConfigMap) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4351 := z.DecBinary() - _ = yym4351 + yym4342 := z.DecBinary() + _ = yym4342 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4352 := r.ContainerType() - if yyct4352 == codecSelferValueTypeMap1234 { - yyl4352 := r.ReadMapStart() - if yyl4352 == 0 { + yyct4343 := r.ContainerType() + if yyct4343 == codecSelferValueTypeMap1234 { + yyl4343 := r.ReadMapStart() + if yyl4343 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4352, d) + x.codecDecodeSelfFromMap(yyl4343, d) } - } else if yyct4352 == codecSelferValueTypeArray1234 { - yyl4352 := r.ReadArrayStart() - if yyl4352 == 0 { + } else if yyct4343 == codecSelferValueTypeArray1234 { + yyl4343 := r.ReadArrayStart() + if yyl4343 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4352, d) + x.codecDecodeSelfFromArray(yyl4343, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54161,12 +54079,12 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4353Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4353Slc - var yyhl4353 bool = l >= 0 - for yyj4353 := 0; ; yyj4353++ { - if yyhl4353 { - if yyj4353 >= l { + var yys4344Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4344Slc + var yyhl4344 bool = l >= 0 + for yyj4344 := 0; ; yyj4344++ { + if yyhl4344 { + if yyj4344 >= l { break } } else { @@ -54175,10 +54093,10 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4353Slc = r.DecodeBytes(yys4353Slc, true, true) - yys4353 := string(yys4353Slc) + yys4344Slc = r.DecodeBytes(yys4344Slc, true, true) + yys4344 := string(yys4344Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4353 { + switch yys4344 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -54195,25 +54113,25 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4356 := &x.ObjectMeta - yyv4356.CodecDecodeSelf(d) + yyv4347 := &x.ObjectMeta + yyv4347.CodecDecodeSelf(d) } case "data": if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4357 := &x.Data - yym4358 := z.DecBinary() - _ = yym4358 + yyv4348 := &x.Data + yym4349 := z.DecBinary() + _ = yym4349 if false { } else { - z.F.DecMapStringStringX(yyv4357, false, d) + z.F.DecMapStringStringX(yyv4348, false, d) } } default: - z.DecStructFieldNotFound(-1, yys4353) - } // end switch yys4353 - } // end for yyj4353 + z.DecStructFieldNotFound(-1, yys4344) + } // end switch yys4344 + } // end for yyj4344 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54221,16 +54139,16 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4359 int - var yyb4359 bool - var yyhl4359 bool = l >= 0 - yyj4359++ - if yyhl4359 { - yyb4359 = yyj4359 > l + var yyj4350 int + var yyb4350 bool + var yyhl4350 bool = l >= 0 + yyj4350++ + if yyhl4350 { + yyb4350 = yyj4350 > l } else { - yyb4359 = r.CheckBreak() + yyb4350 = r.CheckBreak() } - if yyb4359 { + if yyb4350 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54240,13 +54158,13 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4359++ - if yyhl4359 { - yyb4359 = yyj4359 > l + yyj4350++ + if yyhl4350 { + yyb4350 = yyj4350 > l } else { - yyb4359 = r.CheckBreak() + yyb4350 = r.CheckBreak() } - if yyb4359 { + if yyb4350 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54256,13 +54174,13 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4359++ - if yyhl4359 { - yyb4359 = yyj4359 > l + yyj4350++ + if yyhl4350 { + yyb4350 = yyj4350 > l } else { - yyb4359 = r.CheckBreak() + yyb4350 = r.CheckBreak() } - if yyb4359 { + if yyb4350 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54270,16 +54188,16 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4362 := &x.ObjectMeta - yyv4362.CodecDecodeSelf(d) + yyv4353 := &x.ObjectMeta + yyv4353.CodecDecodeSelf(d) } - yyj4359++ - if yyhl4359 { - yyb4359 = yyj4359 > l + yyj4350++ + if yyhl4350 { + yyb4350 = yyj4350 > l } else { - yyb4359 = r.CheckBreak() + yyb4350 = r.CheckBreak() } - if yyb4359 { + if yyb4350 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54287,26 +54205,26 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4363 := &x.Data - yym4364 := z.DecBinary() - _ = yym4364 + yyv4354 := &x.Data + yym4355 := z.DecBinary() + _ = yym4355 if false { } else { - z.F.DecMapStringStringX(yyv4363, false, d) + z.F.DecMapStringStringX(yyv4354, false, d) } } for { - yyj4359++ - if yyhl4359 { - yyb4359 = yyj4359 > l + yyj4350++ + if yyhl4350 { + yyb4350 = yyj4350 > l } else { - yyb4359 = r.CheckBreak() + yyb4350 = r.CheckBreak() } - if yyb4359 { + if yyb4350 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4359-1, "") + z.DecStructFieldNotFound(yyj4350-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54318,37 +54236,37 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4365 := z.EncBinary() - _ = yym4365 + yym4356 := z.EncBinary() + _ = yym4356 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4366 := !z.EncBinary() - yy2arr4366 := z.EncBasicHandle().StructToArray - var yyq4366 [4]bool - _, _, _ = yysep4366, yyq4366, yy2arr4366 - const yyr4366 bool = false - yyq4366[0] = x.Kind != "" - yyq4366[1] = x.APIVersion != "" - yyq4366[2] = true - var yynn4366 int - if yyr4366 || yy2arr4366 { + yysep4357 := !z.EncBinary() + yy2arr4357 := z.EncBasicHandle().StructToArray + var yyq4357 [4]bool + _, _, _ = yysep4357, yyq4357, yy2arr4357 + const yyr4357 bool = false + yyq4357[0] = x.Kind != "" + yyq4357[1] = x.APIVersion != "" + yyq4357[2] = true + var yynn4357 int + if yyr4357 || yy2arr4357 { r.EncodeArrayStart(4) } else { - yynn4366 = 1 - for _, b := range yyq4366 { + yynn4357 = 1 + for _, b := range yyq4357 { if b { - yynn4366++ + yynn4357++ } } - r.EncodeMapStart(yynn4366) - yynn4366 = 0 + r.EncodeMapStart(yynn4357) + yynn4357 = 0 } - if yyr4366 || yy2arr4366 { + if yyr4357 || yy2arr4357 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4366[0] { - yym4368 := z.EncBinary() - _ = yym4368 + if yyq4357[0] { + yym4359 := z.EncBinary() + _ = yym4359 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -54357,23 +54275,23 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4366[0] { + if yyq4357[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4369 := z.EncBinary() - _ = yym4369 + yym4360 := z.EncBinary() + _ = yym4360 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4366 || yy2arr4366 { + if yyr4357 || yy2arr4357 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4366[1] { - yym4371 := z.EncBinary() - _ = yym4371 + if yyq4357[1] { + yym4362 := z.EncBinary() + _ = yym4362 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -54382,54 +54300,54 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4366[1] { + if yyq4357[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4372 := z.EncBinary() - _ = yym4372 + yym4363 := z.EncBinary() + _ = yym4363 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4366 || yy2arr4366 { + if yyr4357 || yy2arr4357 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4366[2] { - yy4374 := &x.ListMeta - yym4375 := z.EncBinary() - _ = yym4375 + if yyq4357[2] { + yy4365 := &x.ListMeta + yym4366 := z.EncBinary() + _ = yym4366 if false { - } else if z.HasExtensions() && z.EncExt(yy4374) { + } else if z.HasExtensions() && z.EncExt(yy4365) { } else { - z.EncFallback(yy4374) + z.EncFallback(yy4365) } } else { r.EncodeNil() } } else { - if yyq4366[2] { + if yyq4357[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4376 := &x.ListMeta - yym4377 := z.EncBinary() - _ = yym4377 + yy4367 := &x.ListMeta + yym4368 := z.EncBinary() + _ = yym4368 if false { - } else if z.HasExtensions() && z.EncExt(yy4376) { + } else if z.HasExtensions() && z.EncExt(yy4367) { } else { - z.EncFallback(yy4376) + z.EncFallback(yy4367) } } } - if yyr4366 || yy2arr4366 { + if yyr4357 || yy2arr4357 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4379 := z.EncBinary() - _ = yym4379 + yym4370 := z.EncBinary() + _ = yym4370 if false { } else { h.encSliceConfigMap(([]ConfigMap)(x.Items), e) @@ -54442,15 +54360,15 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4380 := z.EncBinary() - _ = yym4380 + yym4371 := z.EncBinary() + _ = yym4371 if false { } else { h.encSliceConfigMap(([]ConfigMap)(x.Items), e) } } } - if yyr4366 || yy2arr4366 { + if yyr4357 || yy2arr4357 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54463,25 +54381,25 @@ func (x *ConfigMapList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4381 := z.DecBinary() - _ = yym4381 + yym4372 := z.DecBinary() + _ = yym4372 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4382 := r.ContainerType() - if yyct4382 == codecSelferValueTypeMap1234 { - yyl4382 := r.ReadMapStart() - if yyl4382 == 0 { + yyct4373 := r.ContainerType() + if yyct4373 == codecSelferValueTypeMap1234 { + yyl4373 := r.ReadMapStart() + if yyl4373 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4382, d) + x.codecDecodeSelfFromMap(yyl4373, d) } - } else if yyct4382 == codecSelferValueTypeArray1234 { - yyl4382 := r.ReadArrayStart() - if yyl4382 == 0 { + } else if yyct4373 == codecSelferValueTypeArray1234 { + yyl4373 := r.ReadArrayStart() + if yyl4373 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4382, d) + x.codecDecodeSelfFromArray(yyl4373, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54493,12 +54411,12 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4383Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4383Slc - var yyhl4383 bool = l >= 0 - for yyj4383 := 0; ; yyj4383++ { - if yyhl4383 { - if yyj4383 >= l { + var yys4374Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4374Slc + var yyhl4374 bool = l >= 0 + for yyj4374 := 0; ; yyj4374++ { + if yyhl4374 { + if yyj4374 >= l { break } } else { @@ -54507,10 +54425,10 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4383Slc = r.DecodeBytes(yys4383Slc, true, true) - yys4383 := string(yys4383Slc) + yys4374Slc = r.DecodeBytes(yys4374Slc, true, true) + yys4374 := string(yys4374Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4383 { + switch yys4374 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -54527,31 +54445,31 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4386 := &x.ListMeta - yym4387 := z.DecBinary() - _ = yym4387 + yyv4377 := &x.ListMeta + yym4378 := z.DecBinary() + _ = yym4378 if false { - } else if z.HasExtensions() && z.DecExt(yyv4386) { + } else if z.HasExtensions() && z.DecExt(yyv4377) { } else { - z.DecFallback(yyv4386, false) + z.DecFallback(yyv4377, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4388 := &x.Items - yym4389 := z.DecBinary() - _ = yym4389 + yyv4379 := &x.Items + yym4380 := z.DecBinary() + _ = yym4380 if false { } else { - h.decSliceConfigMap((*[]ConfigMap)(yyv4388), d) + h.decSliceConfigMap((*[]ConfigMap)(yyv4379), d) } } default: - z.DecStructFieldNotFound(-1, yys4383) - } // end switch yys4383 - } // end for yyj4383 + z.DecStructFieldNotFound(-1, yys4374) + } // end switch yys4374 + } // end for yyj4374 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54559,16 +54477,16 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4390 int - var yyb4390 bool - var yyhl4390 bool = l >= 0 - yyj4390++ - if yyhl4390 { - yyb4390 = yyj4390 > l + var yyj4381 int + var yyb4381 bool + var yyhl4381 bool = l >= 0 + yyj4381++ + if yyhl4381 { + yyb4381 = yyj4381 > l } else { - yyb4390 = r.CheckBreak() + yyb4381 = r.CheckBreak() } - if yyb4390 { + if yyb4381 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54578,13 +54496,13 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4390++ - if yyhl4390 { - yyb4390 = yyj4390 > l + yyj4381++ + if yyhl4381 { + yyb4381 = yyj4381 > l } else { - yyb4390 = r.CheckBreak() + yyb4381 = r.CheckBreak() } - if yyb4390 { + if yyb4381 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54594,13 +54512,13 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4390++ - if yyhl4390 { - yyb4390 = yyj4390 > l + yyj4381++ + if yyhl4381 { + yyb4381 = yyj4381 > l } else { - yyb4390 = r.CheckBreak() + yyb4381 = r.CheckBreak() } - if yyb4390 { + if yyb4381 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54608,22 +54526,22 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4393 := &x.ListMeta - yym4394 := z.DecBinary() - _ = yym4394 + yyv4384 := &x.ListMeta + yym4385 := z.DecBinary() + _ = yym4385 if false { - } else if z.HasExtensions() && z.DecExt(yyv4393) { + } else if z.HasExtensions() && z.DecExt(yyv4384) { } else { - z.DecFallback(yyv4393, false) + z.DecFallback(yyv4384, false) } } - yyj4390++ - if yyhl4390 { - yyb4390 = yyj4390 > l + yyj4381++ + if yyhl4381 { + yyb4381 = yyj4381 > l } else { - yyb4390 = r.CheckBreak() + yyb4381 = r.CheckBreak() } - if yyb4390 { + if yyb4381 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54631,26 +54549,26 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4395 := &x.Items - yym4396 := z.DecBinary() - _ = yym4396 + yyv4386 := &x.Items + yym4387 := z.DecBinary() + _ = yym4387 if false { } else { - h.decSliceConfigMap((*[]ConfigMap)(yyv4395), d) + h.decSliceConfigMap((*[]ConfigMap)(yyv4386), d) } } for { - yyj4390++ - if yyhl4390 { - yyb4390 = yyj4390 > l + yyj4381++ + if yyhl4381 { + yyb4381 = yyj4381 > l } else { - yyb4390 = r.CheckBreak() + yyb4381 = r.CheckBreak() } - if yyb4390 { + if yyb4381 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4390-1, "") + z.DecStructFieldNotFound(yyj4381-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54659,8 +54577,8 @@ func (x PatchType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4397 := z.EncBinary() - _ = yym4397 + yym4388 := z.EncBinary() + _ = yym4388 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -54672,8 +54590,8 @@ func (x *PatchType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4398 := z.DecBinary() - _ = yym4398 + yym4389 := z.DecBinary() + _ = yym4389 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -54685,8 +54603,8 @@ func (x ComponentConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4399 := z.EncBinary() - _ = yym4399 + yym4390 := z.EncBinary() + _ = yym4390 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -54698,8 +54616,8 @@ func (x *ComponentConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4400 := z.DecBinary() - _ = yym4400 + yym4391 := z.DecBinary() + _ = yym4391 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -54714,32 +54632,32 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4401 := z.EncBinary() - _ = yym4401 + yym4392 := z.EncBinary() + _ = yym4392 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4402 := !z.EncBinary() - yy2arr4402 := z.EncBasicHandle().StructToArray - var yyq4402 [4]bool - _, _, _ = yysep4402, yyq4402, yy2arr4402 - const yyr4402 bool = false - yyq4402[2] = x.Message != "" - yyq4402[3] = x.Error != "" - var yynn4402 int - if yyr4402 || yy2arr4402 { + yysep4393 := !z.EncBinary() + yy2arr4393 := z.EncBasicHandle().StructToArray + var yyq4393 [4]bool + _, _, _ = yysep4393, yyq4393, yy2arr4393 + const yyr4393 bool = false + yyq4393[2] = x.Message != "" + yyq4393[3] = x.Error != "" + var yynn4393 int + if yyr4393 || yy2arr4393 { r.EncodeArrayStart(4) } else { - yynn4402 = 2 - for _, b := range yyq4402 { + yynn4393 = 2 + for _, b := range yyq4393 { if b { - yynn4402++ + yynn4393++ } } - r.EncodeMapStart(yynn4402) - yynn4402 = 0 + r.EncodeMapStart(yynn4393) + yynn4393 = 0 } - if yyr4402 || yy2arr4402 { + if yyr4393 || yy2arr4393 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -54748,7 +54666,7 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr4402 || yy2arr4402 { + if yyr4393 || yy2arr4393 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Status.CodecEncodeSelf(e) } else { @@ -54757,11 +54675,11 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Status.CodecEncodeSelf(e) } - if yyr4402 || yy2arr4402 { + if yyr4393 || yy2arr4393 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4402[2] { - yym4406 := z.EncBinary() - _ = yym4406 + if yyq4393[2] { + yym4397 := z.EncBinary() + _ = yym4397 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -54770,23 +54688,23 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4402[2] { + if yyq4393[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4407 := z.EncBinary() - _ = yym4407 + yym4398 := z.EncBinary() + _ = yym4398 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr4402 || yy2arr4402 { + if yyr4393 || yy2arr4393 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4402[3] { - yym4409 := z.EncBinary() - _ = yym4409 + if yyq4393[3] { + yym4400 := z.EncBinary() + _ = yym4400 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Error)) @@ -54795,19 +54713,19 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4402[3] { + if yyq4393[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("error")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4410 := z.EncBinary() - _ = yym4410 + yym4401 := z.EncBinary() + _ = yym4401 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Error)) } } } - if yyr4402 || yy2arr4402 { + if yyr4393 || yy2arr4393 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54820,25 +54738,25 @@ func (x *ComponentCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4411 := z.DecBinary() - _ = yym4411 + yym4402 := z.DecBinary() + _ = yym4402 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4412 := r.ContainerType() - if yyct4412 == codecSelferValueTypeMap1234 { - yyl4412 := r.ReadMapStart() - if yyl4412 == 0 { + yyct4403 := r.ContainerType() + if yyct4403 == codecSelferValueTypeMap1234 { + yyl4403 := r.ReadMapStart() + if yyl4403 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4412, d) + x.codecDecodeSelfFromMap(yyl4403, d) } - } else if yyct4412 == codecSelferValueTypeArray1234 { - yyl4412 := r.ReadArrayStart() - if yyl4412 == 0 { + } else if yyct4403 == codecSelferValueTypeArray1234 { + yyl4403 := r.ReadArrayStart() + if yyl4403 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4412, d) + x.codecDecodeSelfFromArray(yyl4403, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54850,12 +54768,12 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4413Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4413Slc - var yyhl4413 bool = l >= 0 - for yyj4413 := 0; ; yyj4413++ { - if yyhl4413 { - if yyj4413 >= l { + var yys4404Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4404Slc + var yyhl4404 bool = l >= 0 + for yyj4404 := 0; ; yyj4404++ { + if yyhl4404 { + if yyj4404 >= l { break } } else { @@ -54864,10 +54782,10 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4413Slc = r.DecodeBytes(yys4413Slc, true, true) - yys4413 := string(yys4413Slc) + yys4404Slc = r.DecodeBytes(yys4404Slc, true, true) + yys4404 := string(yys4404Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4413 { + switch yys4404 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -54893,9 +54811,9 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) x.Error = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4413) - } // end switch yys4413 - } // end for yyj4413 + z.DecStructFieldNotFound(-1, yys4404) + } // end switch yys4404 + } // end for yyj4404 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54903,16 +54821,16 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4418 int - var yyb4418 bool - var yyhl4418 bool = l >= 0 - yyj4418++ - if yyhl4418 { - yyb4418 = yyj4418 > l + var yyj4409 int + var yyb4409 bool + var yyhl4409 bool = l >= 0 + yyj4409++ + if yyhl4409 { + yyb4409 = yyj4409 > l } else { - yyb4418 = r.CheckBreak() + yyb4409 = r.CheckBreak() } - if yyb4418 { + if yyb4409 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54922,13 +54840,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Type = ComponentConditionType(r.DecodeString()) } - yyj4418++ - if yyhl4418 { - yyb4418 = yyj4418 > l + yyj4409++ + if yyhl4409 { + yyb4409 = yyj4409 > l } else { - yyb4418 = r.CheckBreak() + yyb4409 = r.CheckBreak() } - if yyb4418 { + if yyb4409 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54938,13 +54856,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj4418++ - if yyhl4418 { - yyb4418 = yyj4418 > l + yyj4409++ + if yyhl4409 { + yyb4409 = yyj4409 > l } else { - yyb4418 = r.CheckBreak() + yyb4409 = r.CheckBreak() } - if yyb4418 { + if yyb4409 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54954,13 +54872,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Message = string(r.DecodeString()) } - yyj4418++ - if yyhl4418 { - yyb4418 = yyj4418 > l + yyj4409++ + if yyhl4409 { + yyb4409 = yyj4409 > l } else { - yyb4418 = r.CheckBreak() + yyb4409 = r.CheckBreak() } - if yyb4418 { + if yyb4409 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54971,17 +54889,17 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode x.Error = string(r.DecodeString()) } for { - yyj4418++ - if yyhl4418 { - yyb4418 = yyj4418 > l + yyj4409++ + if yyhl4409 { + yyb4409 = yyj4409 > l } else { - yyb4418 = r.CheckBreak() + yyb4409 = r.CheckBreak() } - if yyb4418 { + if yyb4409 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4418-1, "") + z.DecStructFieldNotFound(yyj4409-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54993,38 +54911,38 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4423 := z.EncBinary() - _ = yym4423 + yym4414 := z.EncBinary() + _ = yym4414 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4424 := !z.EncBinary() - yy2arr4424 := z.EncBasicHandle().StructToArray - var yyq4424 [4]bool - _, _, _ = yysep4424, yyq4424, yy2arr4424 - const yyr4424 bool = false - yyq4424[0] = x.Kind != "" - yyq4424[1] = x.APIVersion != "" - yyq4424[2] = true - yyq4424[3] = len(x.Conditions) != 0 - var yynn4424 int - if yyr4424 || yy2arr4424 { + yysep4415 := !z.EncBinary() + yy2arr4415 := z.EncBasicHandle().StructToArray + var yyq4415 [4]bool + _, _, _ = yysep4415, yyq4415, yy2arr4415 + const yyr4415 bool = false + yyq4415[0] = x.Kind != "" + yyq4415[1] = x.APIVersion != "" + yyq4415[2] = true + yyq4415[3] = len(x.Conditions) != 0 + var yynn4415 int + if yyr4415 || yy2arr4415 { r.EncodeArrayStart(4) } else { - yynn4424 = 0 - for _, b := range yyq4424 { + yynn4415 = 0 + for _, b := range yyq4415 { if b { - yynn4424++ + yynn4415++ } } - r.EncodeMapStart(yynn4424) - yynn4424 = 0 + r.EncodeMapStart(yynn4415) + yynn4415 = 0 } - if yyr4424 || yy2arr4424 { + if yyr4415 || yy2arr4415 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4424[0] { - yym4426 := z.EncBinary() - _ = yym4426 + if yyq4415[0] { + yym4417 := z.EncBinary() + _ = yym4417 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -55033,23 +54951,23 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4424[0] { + if yyq4415[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4427 := z.EncBinary() - _ = yym4427 + yym4418 := z.EncBinary() + _ = yym4418 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4424 || yy2arr4424 { + if yyr4415 || yy2arr4415 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4424[1] { - yym4429 := z.EncBinary() - _ = yym4429 + if yyq4415[1] { + yym4420 := z.EncBinary() + _ = yym4420 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -55058,43 +54976,43 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4424[1] { + if yyq4415[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4430 := z.EncBinary() - _ = yym4430 + yym4421 := z.EncBinary() + _ = yym4421 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4424 || yy2arr4424 { + if yyr4415 || yy2arr4415 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4424[2] { - yy4432 := &x.ObjectMeta - yy4432.CodecEncodeSelf(e) + if yyq4415[2] { + yy4423 := &x.ObjectMeta + yy4423.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4424[2] { + if yyq4415[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4433 := &x.ObjectMeta - yy4433.CodecEncodeSelf(e) + yy4424 := &x.ObjectMeta + yy4424.CodecEncodeSelf(e) } } - if yyr4424 || yy2arr4424 { + if yyr4415 || yy2arr4415 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4424[3] { + if yyq4415[3] { if x.Conditions == nil { r.EncodeNil() } else { - yym4435 := z.EncBinary() - _ = yym4435 + yym4426 := z.EncBinary() + _ = yym4426 if false { } else { h.encSliceComponentCondition(([]ComponentCondition)(x.Conditions), e) @@ -55104,15 +55022,15 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4424[3] { + if yyq4415[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym4436 := z.EncBinary() - _ = yym4436 + yym4427 := z.EncBinary() + _ = yym4427 if false { } else { h.encSliceComponentCondition(([]ComponentCondition)(x.Conditions), e) @@ -55120,7 +55038,7 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4424 || yy2arr4424 { + if yyr4415 || yy2arr4415 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55133,25 +55051,25 @@ func (x *ComponentStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4437 := z.DecBinary() - _ = yym4437 + yym4428 := z.DecBinary() + _ = yym4428 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4438 := r.ContainerType() - if yyct4438 == codecSelferValueTypeMap1234 { - yyl4438 := r.ReadMapStart() - if yyl4438 == 0 { + yyct4429 := r.ContainerType() + if yyct4429 == codecSelferValueTypeMap1234 { + yyl4429 := r.ReadMapStart() + if yyl4429 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4438, d) + x.codecDecodeSelfFromMap(yyl4429, d) } - } else if yyct4438 == codecSelferValueTypeArray1234 { - yyl4438 := r.ReadArrayStart() - if yyl4438 == 0 { + } else if yyct4429 == codecSelferValueTypeArray1234 { + yyl4429 := r.ReadArrayStart() + if yyl4429 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4438, d) + x.codecDecodeSelfFromArray(yyl4429, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55163,12 +55081,12 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4439Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4439Slc - var yyhl4439 bool = l >= 0 - for yyj4439 := 0; ; yyj4439++ { - if yyhl4439 { - if yyj4439 >= l { + var yys4430Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4430Slc + var yyhl4430 bool = l >= 0 + for yyj4430 := 0; ; yyj4430++ { + if yyhl4430 { + if yyj4430 >= l { break } } else { @@ -55177,10 +55095,10 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4439Slc = r.DecodeBytes(yys4439Slc, true, true) - yys4439 := string(yys4439Slc) + yys4430Slc = r.DecodeBytes(yys4430Slc, true, true) + yys4430 := string(yys4430Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4439 { + switch yys4430 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -55197,25 +55115,25 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4442 := &x.ObjectMeta - yyv4442.CodecDecodeSelf(d) + yyv4433 := &x.ObjectMeta + yyv4433.CodecDecodeSelf(d) } case "conditions": if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv4443 := &x.Conditions - yym4444 := z.DecBinary() - _ = yym4444 + yyv4434 := &x.Conditions + yym4435 := z.DecBinary() + _ = yym4435 if false { } else { - h.decSliceComponentCondition((*[]ComponentCondition)(yyv4443), d) + h.decSliceComponentCondition((*[]ComponentCondition)(yyv4434), d) } } default: - z.DecStructFieldNotFound(-1, yys4439) - } // end switch yys4439 - } // end for yyj4439 + z.DecStructFieldNotFound(-1, yys4430) + } // end switch yys4430 + } // end for yyj4430 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -55223,16 +55141,16 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4445 int - var yyb4445 bool - var yyhl4445 bool = l >= 0 - yyj4445++ - if yyhl4445 { - yyb4445 = yyj4445 > l + var yyj4436 int + var yyb4436 bool + var yyhl4436 bool = l >= 0 + yyj4436++ + if yyhl4436 { + yyb4436 = yyj4436 > l } else { - yyb4445 = r.CheckBreak() + yyb4436 = r.CheckBreak() } - if yyb4445 { + if yyb4436 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55242,13 +55160,13 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj4445++ - if yyhl4445 { - yyb4445 = yyj4445 > l + yyj4436++ + if yyhl4436 { + yyb4436 = yyj4436 > l } else { - yyb4445 = r.CheckBreak() + yyb4436 = r.CheckBreak() } - if yyb4445 { + if yyb4436 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55258,13 +55176,13 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj4445++ - if yyhl4445 { - yyb4445 = yyj4445 > l + yyj4436++ + if yyhl4436 { + yyb4436 = yyj4436 > l } else { - yyb4445 = r.CheckBreak() + yyb4436 = r.CheckBreak() } - if yyb4445 { + if yyb4436 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55272,16 +55190,16 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4448 := &x.ObjectMeta - yyv4448.CodecDecodeSelf(d) + yyv4439 := &x.ObjectMeta + yyv4439.CodecDecodeSelf(d) } - yyj4445++ - if yyhl4445 { - yyb4445 = yyj4445 > l + yyj4436++ + if yyhl4436 { + yyb4436 = yyj4436 > l } else { - yyb4445 = r.CheckBreak() + yyb4436 = r.CheckBreak() } - if yyb4445 { + if yyb4436 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55289,26 +55207,26 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv4449 := &x.Conditions - yym4450 := z.DecBinary() - _ = yym4450 + yyv4440 := &x.Conditions + yym4441 := z.DecBinary() + _ = yym4441 if false { } else { - h.decSliceComponentCondition((*[]ComponentCondition)(yyv4449), d) + h.decSliceComponentCondition((*[]ComponentCondition)(yyv4440), d) } } for { - yyj4445++ - if yyhl4445 { - yyb4445 = yyj4445 > l + yyj4436++ + if yyhl4436 { + yyb4436 = yyj4436 > l } else { - yyb4445 = r.CheckBreak() + yyb4436 = r.CheckBreak() } - if yyb4445 { + if yyb4436 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4445-1, "") + z.DecStructFieldNotFound(yyj4436-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -55320,37 +55238,37 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4451 := z.EncBinary() - _ = yym4451 + yym4442 := z.EncBinary() + _ = yym4442 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4452 := !z.EncBinary() - yy2arr4452 := z.EncBasicHandle().StructToArray - var yyq4452 [4]bool - _, _, _ = yysep4452, yyq4452, yy2arr4452 - const yyr4452 bool = false - yyq4452[0] = x.Kind != "" - yyq4452[1] = x.APIVersion != "" - yyq4452[2] = true - var yynn4452 int - if yyr4452 || yy2arr4452 { + yysep4443 := !z.EncBinary() + yy2arr4443 := z.EncBasicHandle().StructToArray + var yyq4443 [4]bool + _, _, _ = yysep4443, yyq4443, yy2arr4443 + const yyr4443 bool = false + yyq4443[0] = x.Kind != "" + yyq4443[1] = x.APIVersion != "" + yyq4443[2] = true + var yynn4443 int + if yyr4443 || yy2arr4443 { r.EncodeArrayStart(4) } else { - yynn4452 = 1 - for _, b := range yyq4452 { + yynn4443 = 1 + for _, b := range yyq4443 { if b { - yynn4452++ + yynn4443++ } } - r.EncodeMapStart(yynn4452) - yynn4452 = 0 + r.EncodeMapStart(yynn4443) + yynn4443 = 0 } - if yyr4452 || yy2arr4452 { + if yyr4443 || yy2arr4443 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4452[0] { - yym4454 := z.EncBinary() - _ = yym4454 + if yyq4443[0] { + yym4445 := z.EncBinary() + _ = yym4445 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -55359,23 +55277,23 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4452[0] { + if yyq4443[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4455 := z.EncBinary() - _ = yym4455 + yym4446 := z.EncBinary() + _ = yym4446 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4452 || yy2arr4452 { + if yyr4443 || yy2arr4443 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4452[1] { - yym4457 := z.EncBinary() - _ = yym4457 + if yyq4443[1] { + yym4448 := z.EncBinary() + _ = yym4448 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -55384,54 +55302,54 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4452[1] { + if yyq4443[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4458 := z.EncBinary() - _ = yym4458 + yym4449 := z.EncBinary() + _ = yym4449 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4452 || yy2arr4452 { + if yyr4443 || yy2arr4443 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4452[2] { - yy4460 := &x.ListMeta - yym4461 := z.EncBinary() - _ = yym4461 + if yyq4443[2] { + yy4451 := &x.ListMeta + yym4452 := z.EncBinary() + _ = yym4452 if false { - } else if z.HasExtensions() && z.EncExt(yy4460) { + } else if z.HasExtensions() && z.EncExt(yy4451) { } else { - z.EncFallback(yy4460) + z.EncFallback(yy4451) } } else { r.EncodeNil() } } else { - if yyq4452[2] { + if yyq4443[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4462 := &x.ListMeta - yym4463 := z.EncBinary() - _ = yym4463 + yy4453 := &x.ListMeta + yym4454 := z.EncBinary() + _ = yym4454 if false { - } else if z.HasExtensions() && z.EncExt(yy4462) { + } else if z.HasExtensions() && z.EncExt(yy4453) { } else { - z.EncFallback(yy4462) + z.EncFallback(yy4453) } } } - if yyr4452 || yy2arr4452 { + if yyr4443 || yy2arr4443 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4465 := z.EncBinary() - _ = yym4465 + yym4456 := z.EncBinary() + _ = yym4456 if false { } else { h.encSliceComponentStatus(([]ComponentStatus)(x.Items), e) @@ -55444,15 +55362,15 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4466 := z.EncBinary() - _ = yym4466 + yym4457 := z.EncBinary() + _ = yym4457 if false { } else { h.encSliceComponentStatus(([]ComponentStatus)(x.Items), e) } } } - if yyr4452 || yy2arr4452 { + if yyr4443 || yy2arr4443 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55465,25 +55383,25 @@ func (x *ComponentStatusList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4467 := z.DecBinary() - _ = yym4467 + yym4458 := z.DecBinary() + _ = yym4458 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4468 := r.ContainerType() - if yyct4468 == codecSelferValueTypeMap1234 { - yyl4468 := r.ReadMapStart() - if yyl4468 == 0 { + yyct4459 := r.ContainerType() + if yyct4459 == codecSelferValueTypeMap1234 { + yyl4459 := r.ReadMapStart() + if yyl4459 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4468, d) + x.codecDecodeSelfFromMap(yyl4459, d) } - } else if yyct4468 == codecSelferValueTypeArray1234 { - yyl4468 := r.ReadArrayStart() - if yyl4468 == 0 { + } else if yyct4459 == codecSelferValueTypeArray1234 { + yyl4459 := r.ReadArrayStart() + if yyl4459 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4468, d) + x.codecDecodeSelfFromArray(yyl4459, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55495,12 +55413,12 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4469Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4469Slc - var yyhl4469 bool = l >= 0 - for yyj4469 := 0; ; yyj4469++ { - if yyhl4469 { - if yyj4469 >= l { + var yys4460Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4460Slc + var yyhl4460 bool = l >= 0 + for yyj4460 := 0; ; yyj4460++ { + if yyhl4460 { + if yyj4460 >= l { break } } else { @@ -55509,10 +55427,10 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4469Slc = r.DecodeBytes(yys4469Slc, true, true) - yys4469 := string(yys4469Slc) + yys4460Slc = r.DecodeBytes(yys4460Slc, true, true) + yys4460 := string(yys4460Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4469 { + switch yys4460 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -55529,31 +55447,31 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4472 := &x.ListMeta - yym4473 := z.DecBinary() - _ = yym4473 + yyv4463 := &x.ListMeta + yym4464 := z.DecBinary() + _ = yym4464 if false { - } else if z.HasExtensions() && z.DecExt(yyv4472) { + } else if z.HasExtensions() && z.DecExt(yyv4463) { } else { - z.DecFallback(yyv4472, false) + z.DecFallback(yyv4463, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4474 := &x.Items - yym4475 := z.DecBinary() - _ = yym4475 + yyv4465 := &x.Items + yym4466 := z.DecBinary() + _ = yym4466 if false { } else { - h.decSliceComponentStatus((*[]ComponentStatus)(yyv4474), d) + h.decSliceComponentStatus((*[]ComponentStatus)(yyv4465), d) } } default: - z.DecStructFieldNotFound(-1, yys4469) - } // end switch yys4469 - } // end for yyj4469 + z.DecStructFieldNotFound(-1, yys4460) + } // end switch yys4460 + } // end for yyj4460 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -55561,16 +55479,16 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4476 int - var yyb4476 bool - var yyhl4476 bool = l >= 0 - yyj4476++ - if yyhl4476 { - yyb4476 = yyj4476 > l + var yyj4467 int + var yyb4467 bool + var yyhl4467 bool = l >= 0 + yyj4467++ + if yyhl4467 { + yyb4467 = yyj4467 > l } else { - yyb4476 = r.CheckBreak() + yyb4467 = r.CheckBreak() } - if yyb4476 { + if yyb4467 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55580,13 +55498,13 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj4476++ - if yyhl4476 { - yyb4476 = yyj4476 > l + yyj4467++ + if yyhl4467 { + yyb4467 = yyj4467 > l } else { - yyb4476 = r.CheckBreak() + yyb4467 = r.CheckBreak() } - if yyb4476 { + if yyb4467 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55596,13 +55514,13 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj4476++ - if yyhl4476 { - yyb4476 = yyj4476 > l + yyj4467++ + if yyhl4467 { + yyb4467 = yyj4467 > l } else { - yyb4476 = r.CheckBreak() + yyb4467 = r.CheckBreak() } - if yyb4476 { + if yyb4467 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55610,22 +55528,22 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4479 := &x.ListMeta - yym4480 := z.DecBinary() - _ = yym4480 + yyv4470 := &x.ListMeta + yym4471 := z.DecBinary() + _ = yym4471 if false { - } else if z.HasExtensions() && z.DecExt(yyv4479) { + } else if z.HasExtensions() && z.DecExt(yyv4470) { } else { - z.DecFallback(yyv4479, false) + z.DecFallback(yyv4470, false) } } - yyj4476++ - if yyhl4476 { - yyb4476 = yyj4476 > l + yyj4467++ + if yyhl4467 { + yyb4467 = yyj4467 > l } else { - yyb4476 = r.CheckBreak() + yyb4467 = r.CheckBreak() } - if yyb4476 { + if yyb4467 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55633,26 +55551,26 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4481 := &x.Items - yym4482 := z.DecBinary() - _ = yym4482 + yyv4472 := &x.Items + yym4473 := z.DecBinary() + _ = yym4473 if false { } else { - h.decSliceComponentStatus((*[]ComponentStatus)(yyv4481), d) + h.decSliceComponentStatus((*[]ComponentStatus)(yyv4472), d) } } for { - yyj4476++ - if yyhl4476 { - yyb4476 = yyj4476 > l + yyj4467++ + if yyhl4467 { + yyb4467 = yyj4467 > l } else { - yyb4476 = r.CheckBreak() + yyb4467 = r.CheckBreak() } - if yyb4476 { + if yyb4467 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4476-1, "") + z.DecStructFieldNotFound(yyj4467-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -55664,38 +55582,38 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4483 := z.EncBinary() - _ = yym4483 + yym4474 := z.EncBinary() + _ = yym4474 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4484 := !z.EncBinary() - yy2arr4484 := z.EncBasicHandle().StructToArray - var yyq4484 [6]bool - _, _, _ = yysep4484, yyq4484, yy2arr4484 - const yyr4484 bool = false - yyq4484[0] = x.Capabilities != nil - yyq4484[1] = x.Privileged != nil - yyq4484[2] = x.SELinuxOptions != nil - yyq4484[3] = x.RunAsUser != nil - yyq4484[4] = x.RunAsNonRoot != nil - yyq4484[5] = x.ReadOnlyRootFilesystem != nil - var yynn4484 int - if yyr4484 || yy2arr4484 { + yysep4475 := !z.EncBinary() + yy2arr4475 := z.EncBasicHandle().StructToArray + var yyq4475 [6]bool + _, _, _ = yysep4475, yyq4475, yy2arr4475 + const yyr4475 bool = false + yyq4475[0] = x.Capabilities != nil + yyq4475[1] = x.Privileged != nil + yyq4475[2] = x.SELinuxOptions != nil + yyq4475[3] = x.RunAsUser != nil + yyq4475[4] = x.RunAsNonRoot != nil + yyq4475[5] = x.ReadOnlyRootFilesystem != nil + var yynn4475 int + if yyr4475 || yy2arr4475 { r.EncodeArrayStart(6) } else { - yynn4484 = 0 - for _, b := range yyq4484 { + yynn4475 = 0 + for _, b := range yyq4475 { if b { - yynn4484++ + yynn4475++ } } - r.EncodeMapStart(yynn4484) - yynn4484 = 0 + r.EncodeMapStart(yynn4475) + yynn4475 = 0 } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[0] { + if yyq4475[0] { if x.Capabilities == nil { r.EncodeNil() } else { @@ -55705,7 +55623,7 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4484[0] { + if yyq4475[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("capabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55716,44 +55634,44 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[1] { + if yyq4475[1] { if x.Privileged == nil { r.EncodeNil() } else { - yy4487 := *x.Privileged - yym4488 := z.EncBinary() - _ = yym4488 + yy4478 := *x.Privileged + yym4479 := z.EncBinary() + _ = yym4479 if false { } else { - r.EncodeBool(bool(yy4487)) + r.EncodeBool(bool(yy4478)) } } } else { r.EncodeNil() } } else { - if yyq4484[1] { + if yyq4475[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("privileged")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Privileged == nil { r.EncodeNil() } else { - yy4489 := *x.Privileged - yym4490 := z.EncBinary() - _ = yym4490 + yy4480 := *x.Privileged + yym4481 := z.EncBinary() + _ = yym4481 if false { } else { - r.EncodeBool(bool(yy4489)) + r.EncodeBool(bool(yy4480)) } } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[2] { + if yyq4475[2] { if x.SELinuxOptions == nil { r.EncodeNil() } else { @@ -55763,7 +55681,7 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4484[2] { + if yyq4475[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinuxOptions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55774,112 +55692,112 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[3] { + if yyq4475[3] { if x.RunAsUser == nil { r.EncodeNil() } else { - yy4493 := *x.RunAsUser - yym4494 := z.EncBinary() - _ = yym4494 + yy4484 := *x.RunAsUser + yym4485 := z.EncBinary() + _ = yym4485 if false { } else { - r.EncodeInt(int64(yy4493)) + r.EncodeInt(int64(yy4484)) } } } else { r.EncodeNil() } } else { - if yyq4484[3] { + if yyq4475[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsUser")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RunAsUser == nil { r.EncodeNil() } else { - yy4495 := *x.RunAsUser - yym4496 := z.EncBinary() - _ = yym4496 + yy4486 := *x.RunAsUser + yym4487 := z.EncBinary() + _ = yym4487 if false { } else { - r.EncodeInt(int64(yy4495)) + r.EncodeInt(int64(yy4486)) } } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[4] { + if yyq4475[4] { if x.RunAsNonRoot == nil { r.EncodeNil() } else { - yy4498 := *x.RunAsNonRoot - yym4499 := z.EncBinary() - _ = yym4499 + yy4489 := *x.RunAsNonRoot + yym4490 := z.EncBinary() + _ = yym4490 if false { } else { - r.EncodeBool(bool(yy4498)) + r.EncodeBool(bool(yy4489)) } } } else { r.EncodeNil() } } else { - if yyq4484[4] { + if yyq4475[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsNonRoot")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RunAsNonRoot == nil { r.EncodeNil() } else { - yy4500 := *x.RunAsNonRoot - yym4501 := z.EncBinary() - _ = yym4501 + yy4491 := *x.RunAsNonRoot + yym4492 := z.EncBinary() + _ = yym4492 if false { } else { - r.EncodeBool(bool(yy4500)) + r.EncodeBool(bool(yy4491)) } } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4484[5] { + if yyq4475[5] { if x.ReadOnlyRootFilesystem == nil { r.EncodeNil() } else { - yy4503 := *x.ReadOnlyRootFilesystem - yym4504 := z.EncBinary() - _ = yym4504 + yy4494 := *x.ReadOnlyRootFilesystem + yym4495 := z.EncBinary() + _ = yym4495 if false { } else { - r.EncodeBool(bool(yy4503)) + r.EncodeBool(bool(yy4494)) } } } else { r.EncodeNil() } } else { - if yyq4484[5] { + if yyq4475[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readOnlyRootFilesystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ReadOnlyRootFilesystem == nil { r.EncodeNil() } else { - yy4505 := *x.ReadOnlyRootFilesystem - yym4506 := z.EncBinary() - _ = yym4506 + yy4496 := *x.ReadOnlyRootFilesystem + yym4497 := z.EncBinary() + _ = yym4497 if false { } else { - r.EncodeBool(bool(yy4505)) + r.EncodeBool(bool(yy4496)) } } } } - if yyr4484 || yy2arr4484 { + if yyr4475 || yy2arr4475 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55892,25 +55810,25 @@ func (x *SecurityContext) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4507 := z.DecBinary() - _ = yym4507 + yym4498 := z.DecBinary() + _ = yym4498 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4508 := r.ContainerType() - if yyct4508 == codecSelferValueTypeMap1234 { - yyl4508 := r.ReadMapStart() - if yyl4508 == 0 { + yyct4499 := r.ContainerType() + if yyct4499 == codecSelferValueTypeMap1234 { + yyl4499 := r.ReadMapStart() + if yyl4499 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4508, d) + x.codecDecodeSelfFromMap(yyl4499, d) } - } else if yyct4508 == codecSelferValueTypeArray1234 { - yyl4508 := r.ReadArrayStart() - if yyl4508 == 0 { + } else if yyct4499 == codecSelferValueTypeArray1234 { + yyl4499 := r.ReadArrayStart() + if yyl4499 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4508, d) + x.codecDecodeSelfFromArray(yyl4499, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55922,12 +55840,12 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4509Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4509Slc - var yyhl4509 bool = l >= 0 - for yyj4509 := 0; ; yyj4509++ { - if yyhl4509 { - if yyj4509 >= l { + var yys4500Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4500Slc + var yyhl4500 bool = l >= 0 + for yyj4500 := 0; ; yyj4500++ { + if yyhl4500 { + if yyj4500 >= l { break } } else { @@ -55936,10 +55854,10 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4509Slc = r.DecodeBytes(yys4509Slc, true, true) - yys4509 := string(yys4509Slc) + yys4500Slc = r.DecodeBytes(yys4500Slc, true, true) + yys4500 := string(yys4500Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4509 { + switch yys4500 { case "capabilities": if r.TryDecodeAsNil() { if x.Capabilities != nil { @@ -55960,8 +55878,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Privileged == nil { x.Privileged = new(bool) } - yym4512 := z.DecBinary() - _ = yym4512 + yym4503 := z.DecBinary() + _ = yym4503 if false { } else { *((*bool)(x.Privileged)) = r.DecodeBool() @@ -55987,8 +55905,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RunAsUser == nil { x.RunAsUser = new(int64) } - yym4515 := z.DecBinary() - _ = yym4515 + yym4506 := z.DecBinary() + _ = yym4506 if false { } else { *((*int64)(x.RunAsUser)) = int64(r.DecodeInt(64)) @@ -56003,8 +55921,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RunAsNonRoot == nil { x.RunAsNonRoot = new(bool) } - yym4517 := z.DecBinary() - _ = yym4517 + yym4508 := z.DecBinary() + _ = yym4508 if false { } else { *((*bool)(x.RunAsNonRoot)) = r.DecodeBool() @@ -56019,17 +55937,17 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ReadOnlyRootFilesystem == nil { x.ReadOnlyRootFilesystem = new(bool) } - yym4519 := z.DecBinary() - _ = yym4519 + yym4510 := z.DecBinary() + _ = yym4510 if false { } else { *((*bool)(x.ReadOnlyRootFilesystem)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys4509) - } // end switch yys4509 - } // end for yyj4509 + z.DecStructFieldNotFound(-1, yys4500) + } // end switch yys4500 + } // end for yyj4500 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56037,16 +55955,16 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4520 int - var yyb4520 bool - var yyhl4520 bool = l >= 0 - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + var yyj4511 int + var yyb4511 bool + var yyhl4511 bool = l >= 0 + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56061,13 +55979,13 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } x.Capabilities.CodecDecodeSelf(d) } - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56080,20 +55998,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.Privileged == nil { x.Privileged = new(bool) } - yym4523 := z.DecBinary() - _ = yym4523 + yym4514 := z.DecBinary() + _ = yym4514 if false { } else { *((*bool)(x.Privileged)) = r.DecodeBool() } } - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56108,13 +56026,13 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } x.SELinuxOptions.CodecDecodeSelf(d) } - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56127,20 +56045,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.RunAsUser == nil { x.RunAsUser = new(int64) } - yym4526 := z.DecBinary() - _ = yym4526 + yym4517 := z.DecBinary() + _ = yym4517 if false { } else { *((*int64)(x.RunAsUser)) = int64(r.DecodeInt(64)) } } - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56153,20 +56071,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.RunAsNonRoot == nil { x.RunAsNonRoot = new(bool) } - yym4528 := z.DecBinary() - _ = yym4528 + yym4519 := z.DecBinary() + _ = yym4519 if false { } else { *((*bool)(x.RunAsNonRoot)) = r.DecodeBool() } } - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56179,25 +56097,25 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.ReadOnlyRootFilesystem == nil { x.ReadOnlyRootFilesystem = new(bool) } - yym4530 := z.DecBinary() - _ = yym4530 + yym4521 := z.DecBinary() + _ = yym4521 if false { } else { *((*bool)(x.ReadOnlyRootFilesystem)) = r.DecodeBool() } } for { - yyj4520++ - if yyhl4520 { - yyb4520 = yyj4520 > l + yyj4511++ + if yyhl4511 { + yyb4511 = yyj4511 > l } else { - yyb4520 = r.CheckBreak() + yyb4511 = r.CheckBreak() } - if yyb4520 { + if yyb4511 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4520-1, "") + z.DecStructFieldNotFound(yyj4511-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56209,38 +56127,38 @@ func (x *SELinuxOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4531 := z.EncBinary() - _ = yym4531 + yym4522 := z.EncBinary() + _ = yym4522 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4532 := !z.EncBinary() - yy2arr4532 := z.EncBasicHandle().StructToArray - var yyq4532 [4]bool - _, _, _ = yysep4532, yyq4532, yy2arr4532 - const yyr4532 bool = false - yyq4532[0] = x.User != "" - yyq4532[1] = x.Role != "" - yyq4532[2] = x.Type != "" - yyq4532[3] = x.Level != "" - var yynn4532 int - if yyr4532 || yy2arr4532 { + yysep4523 := !z.EncBinary() + yy2arr4523 := z.EncBasicHandle().StructToArray + var yyq4523 [4]bool + _, _, _ = yysep4523, yyq4523, yy2arr4523 + const yyr4523 bool = false + yyq4523[0] = x.User != "" + yyq4523[1] = x.Role != "" + yyq4523[2] = x.Type != "" + yyq4523[3] = x.Level != "" + var yynn4523 int + if yyr4523 || yy2arr4523 { r.EncodeArrayStart(4) } else { - yynn4532 = 0 - for _, b := range yyq4532 { + yynn4523 = 0 + for _, b := range yyq4523 { if b { - yynn4532++ + yynn4523++ } } - r.EncodeMapStart(yynn4532) - yynn4532 = 0 + r.EncodeMapStart(yynn4523) + yynn4523 = 0 } - if yyr4532 || yy2arr4532 { + if yyr4523 || yy2arr4523 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4532[0] { - yym4534 := z.EncBinary() - _ = yym4534 + if yyq4523[0] { + yym4525 := z.EncBinary() + _ = yym4525 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.User)) @@ -56249,94 +56167,94 @@ func (x *SELinuxOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4532[0] { + if yyq4523[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("user")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4526 := z.EncBinary() + _ = yym4526 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.User)) + } + } + } + if yyr4523 || yy2arr4523 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4523[1] { + yym4528 := z.EncBinary() + _ = yym4528 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Role)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4523[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("role")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4529 := z.EncBinary() + _ = yym4529 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Role)) + } + } + } + if yyr4523 || yy2arr4523 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4523[2] { + yym4531 := z.EncBinary() + _ = yym4531 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Type)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4523[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("type")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4532 := z.EncBinary() + _ = yym4532 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Type)) + } + } + } + if yyr4523 || yy2arr4523 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4523[3] { + yym4534 := z.EncBinary() + _ = yym4534 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Level)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4523[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("level")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym4535 := z.EncBinary() _ = yym4535 if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.User)) - } - } - } - if yyr4532 || yy2arr4532 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4532[1] { - yym4537 := z.EncBinary() - _ = yym4537 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Role)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4532[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("role")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4538 := z.EncBinary() - _ = yym4538 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Role)) - } - } - } - if yyr4532 || yy2arr4532 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4532[2] { - yym4540 := z.EncBinary() - _ = yym4540 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Type)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4532[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("type")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4541 := z.EncBinary() - _ = yym4541 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Type)) - } - } - } - if yyr4532 || yy2arr4532 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4532[3] { - yym4543 := z.EncBinary() - _ = yym4543 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Level)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4532[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("level")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4544 := z.EncBinary() - _ = yym4544 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Level)) } } } - if yyr4532 || yy2arr4532 { + if yyr4523 || yy2arr4523 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -56349,25 +56267,25 @@ func (x *SELinuxOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4545 := z.DecBinary() - _ = yym4545 + yym4536 := z.DecBinary() + _ = yym4536 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4546 := r.ContainerType() - if yyct4546 == codecSelferValueTypeMap1234 { - yyl4546 := r.ReadMapStart() - if yyl4546 == 0 { + yyct4537 := r.ContainerType() + if yyct4537 == codecSelferValueTypeMap1234 { + yyl4537 := r.ReadMapStart() + if yyl4537 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4546, d) + x.codecDecodeSelfFromMap(yyl4537, d) } - } else if yyct4546 == codecSelferValueTypeArray1234 { - yyl4546 := r.ReadArrayStart() - if yyl4546 == 0 { + } else if yyct4537 == codecSelferValueTypeArray1234 { + yyl4537 := r.ReadArrayStart() + if yyl4537 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4546, d) + x.codecDecodeSelfFromArray(yyl4537, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -56379,12 +56297,12 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4547Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4547Slc - var yyhl4547 bool = l >= 0 - for yyj4547 := 0; ; yyj4547++ { - if yyhl4547 { - if yyj4547 >= l { + var yys4538Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4538Slc + var yyhl4538 bool = l >= 0 + for yyj4538 := 0; ; yyj4538++ { + if yyhl4538 { + if yyj4538 >= l { break } } else { @@ -56393,10 +56311,10 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4547Slc = r.DecodeBytes(yys4547Slc, true, true) - yys4547 := string(yys4547Slc) + yys4538Slc = r.DecodeBytes(yys4538Slc, true, true) + yys4538 := string(yys4538Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4547 { + switch yys4538 { case "user": if r.TryDecodeAsNil() { x.User = "" @@ -56422,9 +56340,9 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Level = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4547) - } // end switch yys4547 - } // end for yyj4547 + z.DecStructFieldNotFound(-1, yys4538) + } // end switch yys4538 + } // end for yyj4538 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56432,16 +56350,16 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4552 int - var yyb4552 bool - var yyhl4552 bool = l >= 0 - yyj4552++ - if yyhl4552 { - yyb4552 = yyj4552 > l + var yyj4543 int + var yyb4543 bool + var yyhl4543 bool = l >= 0 + yyj4543++ + if yyhl4543 { + yyb4543 = yyj4543 > l } else { - yyb4552 = r.CheckBreak() + yyb4543 = r.CheckBreak() } - if yyb4552 { + if yyb4543 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56451,13 +56369,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.User = string(r.DecodeString()) } - yyj4552++ - if yyhl4552 { - yyb4552 = yyj4552 > l + yyj4543++ + if yyhl4543 { + yyb4543 = yyj4543 > l } else { - yyb4552 = r.CheckBreak() + yyb4543 = r.CheckBreak() } - if yyb4552 { + if yyb4543 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56467,13 +56385,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Role = string(r.DecodeString()) } - yyj4552++ - if yyhl4552 { - yyb4552 = yyj4552 > l + yyj4543++ + if yyhl4543 { + yyb4543 = yyj4543 > l } else { - yyb4552 = r.CheckBreak() + yyb4543 = r.CheckBreak() } - if yyb4552 { + if yyb4543 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56483,13 +56401,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = string(r.DecodeString()) } - yyj4552++ - if yyhl4552 { - yyb4552 = yyj4552 > l + yyj4543++ + if yyhl4543 { + yyb4543 = yyj4543 > l } else { - yyb4552 = r.CheckBreak() + yyb4543 = r.CheckBreak() } - if yyb4552 { + if yyb4543 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56500,17 +56418,17 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Level = string(r.DecodeString()) } for { - yyj4552++ - if yyhl4552 { - yyb4552 = yyj4552 > l + yyj4543++ + if yyhl4543 { + yyb4543 = yyj4543 > l } else { - yyb4552 = r.CheckBreak() + yyb4543 = r.CheckBreak() } - if yyb4552 { + if yyb4543 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4552-1, "") + z.DecStructFieldNotFound(yyj4543-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56522,37 +56440,37 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4557 := z.EncBinary() - _ = yym4557 + yym4548 := z.EncBinary() + _ = yym4548 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4558 := !z.EncBinary() - yy2arr4558 := z.EncBasicHandle().StructToArray - var yyq4558 [5]bool - _, _, _ = yysep4558, yyq4558, yy2arr4558 - const yyr4558 bool = false - yyq4558[0] = x.Kind != "" - yyq4558[1] = x.APIVersion != "" - yyq4558[2] = true - var yynn4558 int - if yyr4558 || yy2arr4558 { + yysep4549 := !z.EncBinary() + yy2arr4549 := z.EncBasicHandle().StructToArray + var yyq4549 [5]bool + _, _, _ = yysep4549, yyq4549, yy2arr4549 + const yyr4549 bool = false + yyq4549[0] = x.Kind != "" + yyq4549[1] = x.APIVersion != "" + yyq4549[2] = true + var yynn4549 int + if yyr4549 || yy2arr4549 { r.EncodeArrayStart(5) } else { - yynn4558 = 2 - for _, b := range yyq4558 { + yynn4549 = 2 + for _, b := range yyq4549 { if b { - yynn4558++ + yynn4549++ } } - r.EncodeMapStart(yynn4558) - yynn4558 = 0 + r.EncodeMapStart(yynn4549) + yynn4549 = 0 } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4558[0] { - yym4560 := z.EncBinary() - _ = yym4560 + if yyq4549[0] { + yym4551 := z.EncBinary() + _ = yym4551 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -56561,23 +56479,23 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4558[0] { + if yyq4549[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4561 := z.EncBinary() - _ = yym4561 + yym4552 := z.EncBinary() + _ = yym4552 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4558[1] { - yym4563 := z.EncBinary() - _ = yym4563 + if yyq4549[1] { + yym4554 := z.EncBinary() + _ = yym4554 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -56586,39 +56504,39 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4558[1] { + if yyq4549[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4564 := z.EncBinary() - _ = yym4564 + yym4555 := z.EncBinary() + _ = yym4555 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4558[2] { - yy4566 := &x.ObjectMeta - yy4566.CodecEncodeSelf(e) + if yyq4549[2] { + yy4557 := &x.ObjectMeta + yy4557.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4558[2] { + if yyq4549[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4567 := &x.ObjectMeta - yy4567.CodecEncodeSelf(e) + yy4558 := &x.ObjectMeta + yy4558.CodecEncodeSelf(e) } } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym4569 := z.EncBinary() - _ = yym4569 + yym4560 := z.EncBinary() + _ = yym4560 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Range)) @@ -56627,20 +56545,20 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("range")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4570 := z.EncBinary() - _ = yym4570 + yym4561 := z.EncBinary() + _ = yym4561 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Range)) } } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Data == nil { r.EncodeNil() } else { - yym4572 := z.EncBinary() - _ = yym4572 + yym4563 := z.EncBinary() + _ = yym4563 if false { } else { r.EncodeStringBytes(codecSelferC_RAW1234, []byte(x.Data)) @@ -56653,15 +56571,15 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { if x.Data == nil { r.EncodeNil() } else { - yym4573 := z.EncBinary() - _ = yym4573 + yym4564 := z.EncBinary() + _ = yym4564 if false { } else { r.EncodeStringBytes(codecSelferC_RAW1234, []byte(x.Data)) } } } - if yyr4558 || yy2arr4558 { + if yyr4549 || yy2arr4549 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -56674,25 +56592,25 @@ func (x *RangeAllocation) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4574 := z.DecBinary() - _ = yym4574 + yym4565 := z.DecBinary() + _ = yym4565 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4575 := r.ContainerType() - if yyct4575 == codecSelferValueTypeMap1234 { - yyl4575 := r.ReadMapStart() - if yyl4575 == 0 { + yyct4566 := r.ContainerType() + if yyct4566 == codecSelferValueTypeMap1234 { + yyl4566 := r.ReadMapStart() + if yyl4566 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4575, d) + x.codecDecodeSelfFromMap(yyl4566, d) } - } else if yyct4575 == codecSelferValueTypeArray1234 { - yyl4575 := r.ReadArrayStart() - if yyl4575 == 0 { + } else if yyct4566 == codecSelferValueTypeArray1234 { + yyl4566 := r.ReadArrayStart() + if yyl4566 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4575, d) + x.codecDecodeSelfFromArray(yyl4566, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -56704,12 +56622,12 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4576Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4576Slc - var yyhl4576 bool = l >= 0 - for yyj4576 := 0; ; yyj4576++ { - if yyhl4576 { - if yyj4576 >= l { + var yys4567Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4567Slc + var yyhl4567 bool = l >= 0 + for yyj4567 := 0; ; yyj4567++ { + if yyhl4567 { + if yyj4567 >= l { break } } else { @@ -56718,10 +56636,10 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4576Slc = r.DecodeBytes(yys4576Slc, true, true) - yys4576 := string(yys4576Slc) + yys4567Slc = r.DecodeBytes(yys4567Slc, true, true) + yys4567 := string(yys4567Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4576 { + switch yys4567 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -56738,8 +56656,8 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4579 := &x.ObjectMeta - yyv4579.CodecDecodeSelf(d) + yyv4570 := &x.ObjectMeta + yyv4570.CodecDecodeSelf(d) } case "range": if r.TryDecodeAsNil() { @@ -56751,18 +56669,18 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4581 := &x.Data - yym4582 := z.DecBinary() - _ = yym4582 + yyv4572 := &x.Data + yym4573 := z.DecBinary() + _ = yym4573 if false { } else { - *yyv4581 = r.DecodeBytes(*(*[]byte)(yyv4581), false, false) + *yyv4572 = r.DecodeBytes(*(*[]byte)(yyv4572), false, false) } } default: - z.DecStructFieldNotFound(-1, yys4576) - } // end switch yys4576 - } // end for yyj4576 + z.DecStructFieldNotFound(-1, yys4567) + } // end switch yys4567 + } // end for yyj4567 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56770,16 +56688,16 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4583 int - var yyb4583 bool - var yyhl4583 bool = l >= 0 - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + var yyj4574 int + var yyb4574 bool + var yyhl4574 bool = l >= 0 + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56789,13 +56707,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56805,13 +56723,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56819,16 +56737,16 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4586 := &x.ObjectMeta - yyv4586.CodecDecodeSelf(d) + yyv4577 := &x.ObjectMeta + yyv4577.CodecDecodeSelf(d) } - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56838,13 +56756,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Range = string(r.DecodeString()) } - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56852,26 +56770,26 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4588 := &x.Data - yym4589 := z.DecBinary() - _ = yym4589 + yyv4579 := &x.Data + yym4580 := z.DecBinary() + _ = yym4580 if false { } else { - *yyv4588 = r.DecodeBytes(*(*[]byte)(yyv4588), false, false) + *yyv4579 = r.DecodeBytes(*(*[]byte)(yyv4579), false, false) } } for { - yyj4583++ - if yyhl4583 { - yyb4583 = yyj4583 > l + yyj4574++ + if yyhl4574 { + yyb4574 = yyj4574 > l } else { - yyb4583 = r.CheckBreak() + yyb4574 = r.CheckBreak() } - if yyb4583 { + if yyb4574 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4583-1, "") + z.DecStructFieldNotFound(yyj4574-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56881,10 +56799,10 @@ func (x codecSelfer1234) encSliceOwnerReference(v []OwnerReference, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4590 := range v { + for _, yyv4581 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4591 := &yyv4590 - yy4591.CodecEncodeSelf(e) + yy4582 := &yyv4581 + yy4582.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56894,83 +56812,83 @@ func (x codecSelfer1234) decSliceOwnerReference(v *[]OwnerReference, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4592 := *v - yyh4592, yyl4592 := z.DecSliceHelperStart() - var yyc4592 bool - if yyl4592 == 0 { - if yyv4592 == nil { - yyv4592 = []OwnerReference{} - yyc4592 = true - } else if len(yyv4592) != 0 { - yyv4592 = yyv4592[:0] - yyc4592 = true + yyv4583 := *v + yyh4583, yyl4583 := z.DecSliceHelperStart() + var yyc4583 bool + if yyl4583 == 0 { + if yyv4583 == nil { + yyv4583 = []OwnerReference{} + yyc4583 = true + } else if len(yyv4583) != 0 { + yyv4583 = yyv4583[:0] + yyc4583 = true } - } else if yyl4592 > 0 { - var yyrr4592, yyrl4592 int - var yyrt4592 bool - if yyl4592 > cap(yyv4592) { + } else if yyl4583 > 0 { + var yyrr4583, yyrl4583 int + var yyrt4583 bool + if yyl4583 > cap(yyv4583) { - yyrg4592 := len(yyv4592) > 0 - yyv24592 := yyv4592 - yyrl4592, yyrt4592 = z.DecInferLen(yyl4592, z.DecBasicHandle().MaxInitLen, 72) - if yyrt4592 { - if yyrl4592 <= cap(yyv4592) { - yyv4592 = yyv4592[:yyrl4592] + yyrg4583 := len(yyv4583) > 0 + yyv24583 := yyv4583 + yyrl4583, yyrt4583 = z.DecInferLen(yyl4583, z.DecBasicHandle().MaxInitLen, 72) + if yyrt4583 { + if yyrl4583 <= cap(yyv4583) { + yyv4583 = yyv4583[:yyrl4583] } else { - yyv4592 = make([]OwnerReference, yyrl4592) + yyv4583 = make([]OwnerReference, yyrl4583) } } else { - yyv4592 = make([]OwnerReference, yyrl4592) + yyv4583 = make([]OwnerReference, yyrl4583) } - yyc4592 = true - yyrr4592 = len(yyv4592) - if yyrg4592 { - copy(yyv4592, yyv24592) + yyc4583 = true + yyrr4583 = len(yyv4583) + if yyrg4583 { + copy(yyv4583, yyv24583) } - } else if yyl4592 != len(yyv4592) { - yyv4592 = yyv4592[:yyl4592] - yyc4592 = true + } else if yyl4583 != len(yyv4583) { + yyv4583 = yyv4583[:yyl4583] + yyc4583 = true } - yyj4592 := 0 - for ; yyj4592 < yyrr4592; yyj4592++ { - yyh4592.ElemContainerState(yyj4592) + yyj4583 := 0 + for ; yyj4583 < yyrr4583; yyj4583++ { + yyh4583.ElemContainerState(yyj4583) if r.TryDecodeAsNil() { - yyv4592[yyj4592] = OwnerReference{} + yyv4583[yyj4583] = OwnerReference{} } else { - yyv4593 := &yyv4592[yyj4592] - yyv4593.CodecDecodeSelf(d) + yyv4584 := &yyv4583[yyj4583] + yyv4584.CodecDecodeSelf(d) } } - if yyrt4592 { - for ; yyj4592 < yyl4592; yyj4592++ { - yyv4592 = append(yyv4592, OwnerReference{}) - yyh4592.ElemContainerState(yyj4592) + if yyrt4583 { + for ; yyj4583 < yyl4583; yyj4583++ { + yyv4583 = append(yyv4583, OwnerReference{}) + yyh4583.ElemContainerState(yyj4583) if r.TryDecodeAsNil() { - yyv4592[yyj4592] = OwnerReference{} + yyv4583[yyj4583] = OwnerReference{} } else { - yyv4594 := &yyv4592[yyj4592] - yyv4594.CodecDecodeSelf(d) + yyv4585 := &yyv4583[yyj4583] + yyv4585.CodecDecodeSelf(d) } } } } else { - yyj4592 := 0 - for ; !r.CheckBreak(); yyj4592++ { + yyj4583 := 0 + for ; !r.CheckBreak(); yyj4583++ { - if yyj4592 >= len(yyv4592) { - yyv4592 = append(yyv4592, OwnerReference{}) // var yyz4592 OwnerReference - yyc4592 = true + if yyj4583 >= len(yyv4583) { + yyv4583 = append(yyv4583, OwnerReference{}) // var yyz4583 OwnerReference + yyc4583 = true } - yyh4592.ElemContainerState(yyj4592) - if yyj4592 < len(yyv4592) { + yyh4583.ElemContainerState(yyj4583) + if yyj4583 < len(yyv4583) { if r.TryDecodeAsNil() { - yyv4592[yyj4592] = OwnerReference{} + yyv4583[yyj4583] = OwnerReference{} } else { - yyv4595 := &yyv4592[yyj4592] - yyv4595.CodecDecodeSelf(d) + yyv4586 := &yyv4583[yyj4583] + yyv4586.CodecDecodeSelf(d) } } else { @@ -56978,17 +56896,17 @@ func (x codecSelfer1234) decSliceOwnerReference(v *[]OwnerReference, d *codec197 } } - if yyj4592 < len(yyv4592) { - yyv4592 = yyv4592[:yyj4592] - yyc4592 = true - } else if yyj4592 == 0 && yyv4592 == nil { - yyv4592 = []OwnerReference{} - yyc4592 = true + if yyj4583 < len(yyv4583) { + yyv4583 = yyv4583[:yyj4583] + yyc4583 = true + } else if yyj4583 == 0 && yyv4583 == nil { + yyv4583 = []OwnerReference{} + yyc4583 = true } } - yyh4592.End() - if yyc4592 { - *v = yyv4592 + yyh4583.End() + if yyc4583 { + *v = yyv4583 } } @@ -56997,9 +56915,9 @@ func (x codecSelfer1234) encSlicePersistentVolumeAccessMode(v []PersistentVolume z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4596 := range v { + for _, yyv4587 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4596.CodecEncodeSelf(e) + yyv4587.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57009,75 +56927,75 @@ func (x codecSelfer1234) decSlicePersistentVolumeAccessMode(v *[]PersistentVolum z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4597 := *v - yyh4597, yyl4597 := z.DecSliceHelperStart() - var yyc4597 bool - if yyl4597 == 0 { - if yyv4597 == nil { - yyv4597 = []PersistentVolumeAccessMode{} - yyc4597 = true - } else if len(yyv4597) != 0 { - yyv4597 = yyv4597[:0] - yyc4597 = true + yyv4588 := *v + yyh4588, yyl4588 := z.DecSliceHelperStart() + var yyc4588 bool + if yyl4588 == 0 { + if yyv4588 == nil { + yyv4588 = []PersistentVolumeAccessMode{} + yyc4588 = true + } else if len(yyv4588) != 0 { + yyv4588 = yyv4588[:0] + yyc4588 = true } - } else if yyl4597 > 0 { - var yyrr4597, yyrl4597 int - var yyrt4597 bool - if yyl4597 > cap(yyv4597) { + } else if yyl4588 > 0 { + var yyrr4588, yyrl4588 int + var yyrt4588 bool + if yyl4588 > cap(yyv4588) { - yyrl4597, yyrt4597 = z.DecInferLen(yyl4597, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4597 { - if yyrl4597 <= cap(yyv4597) { - yyv4597 = yyv4597[:yyrl4597] + yyrl4588, yyrt4588 = z.DecInferLen(yyl4588, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4588 { + if yyrl4588 <= cap(yyv4588) { + yyv4588 = yyv4588[:yyrl4588] } else { - yyv4597 = make([]PersistentVolumeAccessMode, yyrl4597) + yyv4588 = make([]PersistentVolumeAccessMode, yyrl4588) } } else { - yyv4597 = make([]PersistentVolumeAccessMode, yyrl4597) + yyv4588 = make([]PersistentVolumeAccessMode, yyrl4588) } - yyc4597 = true - yyrr4597 = len(yyv4597) - } else if yyl4597 != len(yyv4597) { - yyv4597 = yyv4597[:yyl4597] - yyc4597 = true + yyc4588 = true + yyrr4588 = len(yyv4588) + } else if yyl4588 != len(yyv4588) { + yyv4588 = yyv4588[:yyl4588] + yyc4588 = true } - yyj4597 := 0 - for ; yyj4597 < yyrr4597; yyj4597++ { - yyh4597.ElemContainerState(yyj4597) + yyj4588 := 0 + for ; yyj4588 < yyrr4588; yyj4588++ { + yyh4588.ElemContainerState(yyj4588) if r.TryDecodeAsNil() { - yyv4597[yyj4597] = "" + yyv4588[yyj4588] = "" } else { - yyv4597[yyj4597] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4588[yyj4588] = PersistentVolumeAccessMode(r.DecodeString()) } } - if yyrt4597 { - for ; yyj4597 < yyl4597; yyj4597++ { - yyv4597 = append(yyv4597, "") - yyh4597.ElemContainerState(yyj4597) + if yyrt4588 { + for ; yyj4588 < yyl4588; yyj4588++ { + yyv4588 = append(yyv4588, "") + yyh4588.ElemContainerState(yyj4588) if r.TryDecodeAsNil() { - yyv4597[yyj4597] = "" + yyv4588[yyj4588] = "" } else { - yyv4597[yyj4597] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4588[yyj4588] = PersistentVolumeAccessMode(r.DecodeString()) } } } } else { - yyj4597 := 0 - for ; !r.CheckBreak(); yyj4597++ { + yyj4588 := 0 + for ; !r.CheckBreak(); yyj4588++ { - if yyj4597 >= len(yyv4597) { - yyv4597 = append(yyv4597, "") // var yyz4597 PersistentVolumeAccessMode - yyc4597 = true + if yyj4588 >= len(yyv4588) { + yyv4588 = append(yyv4588, "") // var yyz4588 PersistentVolumeAccessMode + yyc4588 = true } - yyh4597.ElemContainerState(yyj4597) - if yyj4597 < len(yyv4597) { + yyh4588.ElemContainerState(yyj4588) + if yyj4588 < len(yyv4588) { if r.TryDecodeAsNil() { - yyv4597[yyj4597] = "" + yyv4588[yyj4588] = "" } else { - yyv4597[yyj4597] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4588[yyj4588] = PersistentVolumeAccessMode(r.DecodeString()) } } else { @@ -57085,17 +57003,17 @@ func (x codecSelfer1234) decSlicePersistentVolumeAccessMode(v *[]PersistentVolum } } - if yyj4597 < len(yyv4597) { - yyv4597 = yyv4597[:yyj4597] - yyc4597 = true - } else if yyj4597 == 0 && yyv4597 == nil { - yyv4597 = []PersistentVolumeAccessMode{} - yyc4597 = true + if yyj4588 < len(yyv4588) { + yyv4588 = yyv4588[:yyj4588] + yyc4588 = true + } else if yyj4588 == 0 && yyv4588 == nil { + yyv4588 = []PersistentVolumeAccessMode{} + yyc4588 = true } } - yyh4597.End() - if yyc4597 { - *v = yyv4597 + yyh4588.End() + if yyc4588 { + *v = yyv4588 } } @@ -57104,10 +57022,10 @@ func (x codecSelfer1234) encSlicePersistentVolume(v []PersistentVolume, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4601 := range v { + for _, yyv4592 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4602 := &yyv4601 - yy4602.CodecEncodeSelf(e) + yy4593 := &yyv4592 + yy4593.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57117,83 +57035,83 @@ func (x codecSelfer1234) decSlicePersistentVolume(v *[]PersistentVolume, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4603 := *v - yyh4603, yyl4603 := z.DecSliceHelperStart() - var yyc4603 bool - if yyl4603 == 0 { - if yyv4603 == nil { - yyv4603 = []PersistentVolume{} - yyc4603 = true - } else if len(yyv4603) != 0 { - yyv4603 = yyv4603[:0] - yyc4603 = true + yyv4594 := *v + yyh4594, yyl4594 := z.DecSliceHelperStart() + var yyc4594 bool + if yyl4594 == 0 { + if yyv4594 == nil { + yyv4594 = []PersistentVolume{} + yyc4594 = true + } else if len(yyv4594) != 0 { + yyv4594 = yyv4594[:0] + yyc4594 = true } - } else if yyl4603 > 0 { - var yyrr4603, yyrl4603 int - var yyrt4603 bool - if yyl4603 > cap(yyv4603) { + } else if yyl4594 > 0 { + var yyrr4594, yyrl4594 int + var yyrt4594 bool + if yyl4594 > cap(yyv4594) { - yyrg4603 := len(yyv4603) > 0 - yyv24603 := yyv4603 - yyrl4603, yyrt4603 = z.DecInferLen(yyl4603, z.DecBasicHandle().MaxInitLen, 488) - if yyrt4603 { - if yyrl4603 <= cap(yyv4603) { - yyv4603 = yyv4603[:yyrl4603] + yyrg4594 := len(yyv4594) > 0 + yyv24594 := yyv4594 + yyrl4594, yyrt4594 = z.DecInferLen(yyl4594, z.DecBasicHandle().MaxInitLen, 488) + if yyrt4594 { + if yyrl4594 <= cap(yyv4594) { + yyv4594 = yyv4594[:yyrl4594] } else { - yyv4603 = make([]PersistentVolume, yyrl4603) + yyv4594 = make([]PersistentVolume, yyrl4594) } } else { - yyv4603 = make([]PersistentVolume, yyrl4603) + yyv4594 = make([]PersistentVolume, yyrl4594) } - yyc4603 = true - yyrr4603 = len(yyv4603) - if yyrg4603 { - copy(yyv4603, yyv24603) + yyc4594 = true + yyrr4594 = len(yyv4594) + if yyrg4594 { + copy(yyv4594, yyv24594) } - } else if yyl4603 != len(yyv4603) { - yyv4603 = yyv4603[:yyl4603] - yyc4603 = true + } else if yyl4594 != len(yyv4594) { + yyv4594 = yyv4594[:yyl4594] + yyc4594 = true } - yyj4603 := 0 - for ; yyj4603 < yyrr4603; yyj4603++ { - yyh4603.ElemContainerState(yyj4603) + yyj4594 := 0 + for ; yyj4594 < yyrr4594; yyj4594++ { + yyh4594.ElemContainerState(yyj4594) if r.TryDecodeAsNil() { - yyv4603[yyj4603] = PersistentVolume{} + yyv4594[yyj4594] = PersistentVolume{} } else { - yyv4604 := &yyv4603[yyj4603] - yyv4604.CodecDecodeSelf(d) + yyv4595 := &yyv4594[yyj4594] + yyv4595.CodecDecodeSelf(d) } } - if yyrt4603 { - for ; yyj4603 < yyl4603; yyj4603++ { - yyv4603 = append(yyv4603, PersistentVolume{}) - yyh4603.ElemContainerState(yyj4603) + if yyrt4594 { + for ; yyj4594 < yyl4594; yyj4594++ { + yyv4594 = append(yyv4594, PersistentVolume{}) + yyh4594.ElemContainerState(yyj4594) if r.TryDecodeAsNil() { - yyv4603[yyj4603] = PersistentVolume{} + yyv4594[yyj4594] = PersistentVolume{} } else { - yyv4605 := &yyv4603[yyj4603] - yyv4605.CodecDecodeSelf(d) + yyv4596 := &yyv4594[yyj4594] + yyv4596.CodecDecodeSelf(d) } } } } else { - yyj4603 := 0 - for ; !r.CheckBreak(); yyj4603++ { + yyj4594 := 0 + for ; !r.CheckBreak(); yyj4594++ { - if yyj4603 >= len(yyv4603) { - yyv4603 = append(yyv4603, PersistentVolume{}) // var yyz4603 PersistentVolume - yyc4603 = true + if yyj4594 >= len(yyv4594) { + yyv4594 = append(yyv4594, PersistentVolume{}) // var yyz4594 PersistentVolume + yyc4594 = true } - yyh4603.ElemContainerState(yyj4603) - if yyj4603 < len(yyv4603) { + yyh4594.ElemContainerState(yyj4594) + if yyj4594 < len(yyv4594) { if r.TryDecodeAsNil() { - yyv4603[yyj4603] = PersistentVolume{} + yyv4594[yyj4594] = PersistentVolume{} } else { - yyv4606 := &yyv4603[yyj4603] - yyv4606.CodecDecodeSelf(d) + yyv4597 := &yyv4594[yyj4594] + yyv4597.CodecDecodeSelf(d) } } else { @@ -57201,17 +57119,17 @@ func (x codecSelfer1234) decSlicePersistentVolume(v *[]PersistentVolume, d *code } } - if yyj4603 < len(yyv4603) { - yyv4603 = yyv4603[:yyj4603] - yyc4603 = true - } else if yyj4603 == 0 && yyv4603 == nil { - yyv4603 = []PersistentVolume{} - yyc4603 = true + if yyj4594 < len(yyv4594) { + yyv4594 = yyv4594[:yyj4594] + yyc4594 = true + } else if yyj4594 == 0 && yyv4594 == nil { + yyv4594 = []PersistentVolume{} + yyc4594 = true } } - yyh4603.End() - if yyc4603 { - *v = yyv4603 + yyh4594.End() + if yyc4594 { + *v = yyv4594 } } @@ -57220,10 +57138,10 @@ func (x codecSelfer1234) encSlicePersistentVolumeClaim(v []PersistentVolumeClaim z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4607 := range v { + for _, yyv4598 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4608 := &yyv4607 - yy4608.CodecEncodeSelf(e) + yy4599 := &yyv4598 + yy4599.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57233,83 +57151,83 @@ func (x codecSelfer1234) decSlicePersistentVolumeClaim(v *[]PersistentVolumeClai z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4609 := *v - yyh4609, yyl4609 := z.DecSliceHelperStart() - var yyc4609 bool - if yyl4609 == 0 { - if yyv4609 == nil { - yyv4609 = []PersistentVolumeClaim{} - yyc4609 = true - } else if len(yyv4609) != 0 { - yyv4609 = yyv4609[:0] - yyc4609 = true + yyv4600 := *v + yyh4600, yyl4600 := z.DecSliceHelperStart() + var yyc4600 bool + if yyl4600 == 0 { + if yyv4600 == nil { + yyv4600 = []PersistentVolumeClaim{} + yyc4600 = true + } else if len(yyv4600) != 0 { + yyv4600 = yyv4600[:0] + yyc4600 = true } - } else if yyl4609 > 0 { - var yyrr4609, yyrl4609 int - var yyrt4609 bool - if yyl4609 > cap(yyv4609) { + } else if yyl4600 > 0 { + var yyrr4600, yyrl4600 int + var yyrt4600 bool + if yyl4600 > cap(yyv4600) { - yyrg4609 := len(yyv4609) > 0 - yyv24609 := yyv4609 - yyrl4609, yyrt4609 = z.DecInferLen(yyl4609, z.DecBasicHandle().MaxInitLen, 368) - if yyrt4609 { - if yyrl4609 <= cap(yyv4609) { - yyv4609 = yyv4609[:yyrl4609] + yyrg4600 := len(yyv4600) > 0 + yyv24600 := yyv4600 + yyrl4600, yyrt4600 = z.DecInferLen(yyl4600, z.DecBasicHandle().MaxInitLen, 368) + if yyrt4600 { + if yyrl4600 <= cap(yyv4600) { + yyv4600 = yyv4600[:yyrl4600] } else { - yyv4609 = make([]PersistentVolumeClaim, yyrl4609) + yyv4600 = make([]PersistentVolumeClaim, yyrl4600) } } else { - yyv4609 = make([]PersistentVolumeClaim, yyrl4609) + yyv4600 = make([]PersistentVolumeClaim, yyrl4600) } - yyc4609 = true - yyrr4609 = len(yyv4609) - if yyrg4609 { - copy(yyv4609, yyv24609) + yyc4600 = true + yyrr4600 = len(yyv4600) + if yyrg4600 { + copy(yyv4600, yyv24600) } - } else if yyl4609 != len(yyv4609) { - yyv4609 = yyv4609[:yyl4609] - yyc4609 = true + } else if yyl4600 != len(yyv4600) { + yyv4600 = yyv4600[:yyl4600] + yyc4600 = true } - yyj4609 := 0 - for ; yyj4609 < yyrr4609; yyj4609++ { - yyh4609.ElemContainerState(yyj4609) + yyj4600 := 0 + for ; yyj4600 < yyrr4600; yyj4600++ { + yyh4600.ElemContainerState(yyj4600) if r.TryDecodeAsNil() { - yyv4609[yyj4609] = PersistentVolumeClaim{} + yyv4600[yyj4600] = PersistentVolumeClaim{} } else { - yyv4610 := &yyv4609[yyj4609] - yyv4610.CodecDecodeSelf(d) + yyv4601 := &yyv4600[yyj4600] + yyv4601.CodecDecodeSelf(d) } } - if yyrt4609 { - for ; yyj4609 < yyl4609; yyj4609++ { - yyv4609 = append(yyv4609, PersistentVolumeClaim{}) - yyh4609.ElemContainerState(yyj4609) + if yyrt4600 { + for ; yyj4600 < yyl4600; yyj4600++ { + yyv4600 = append(yyv4600, PersistentVolumeClaim{}) + yyh4600.ElemContainerState(yyj4600) if r.TryDecodeAsNil() { - yyv4609[yyj4609] = PersistentVolumeClaim{} + yyv4600[yyj4600] = PersistentVolumeClaim{} } else { - yyv4611 := &yyv4609[yyj4609] - yyv4611.CodecDecodeSelf(d) + yyv4602 := &yyv4600[yyj4600] + yyv4602.CodecDecodeSelf(d) } } } } else { - yyj4609 := 0 - for ; !r.CheckBreak(); yyj4609++ { + yyj4600 := 0 + for ; !r.CheckBreak(); yyj4600++ { - if yyj4609 >= len(yyv4609) { - yyv4609 = append(yyv4609, PersistentVolumeClaim{}) // var yyz4609 PersistentVolumeClaim - yyc4609 = true + if yyj4600 >= len(yyv4600) { + yyv4600 = append(yyv4600, PersistentVolumeClaim{}) // var yyz4600 PersistentVolumeClaim + yyc4600 = true } - yyh4609.ElemContainerState(yyj4609) - if yyj4609 < len(yyv4609) { + yyh4600.ElemContainerState(yyj4600) + if yyj4600 < len(yyv4600) { if r.TryDecodeAsNil() { - yyv4609[yyj4609] = PersistentVolumeClaim{} + yyv4600[yyj4600] = PersistentVolumeClaim{} } else { - yyv4612 := &yyv4609[yyj4609] - yyv4612.CodecDecodeSelf(d) + yyv4603 := &yyv4600[yyj4600] + yyv4603.CodecDecodeSelf(d) } } else { @@ -57317,17 +57235,17 @@ func (x codecSelfer1234) decSlicePersistentVolumeClaim(v *[]PersistentVolumeClai } } - if yyj4609 < len(yyv4609) { - yyv4609 = yyv4609[:yyj4609] - yyc4609 = true - } else if yyj4609 == 0 && yyv4609 == nil { - yyv4609 = []PersistentVolumeClaim{} - yyc4609 = true + if yyj4600 < len(yyv4600) { + yyv4600 = yyv4600[:yyj4600] + yyc4600 = true + } else if yyj4600 == 0 && yyv4600 == nil { + yyv4600 = []PersistentVolumeClaim{} + yyc4600 = true } } - yyh4609.End() - if yyc4609 { - *v = yyv4609 + yyh4600.End() + if yyc4600 { + *v = yyv4600 } } @@ -57336,10 +57254,10 @@ func (x codecSelfer1234) encSliceKeyToPath(v []KeyToPath, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4613 := range v { + for _, yyv4604 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4614 := &yyv4613 - yy4614.CodecEncodeSelf(e) + yy4605 := &yyv4604 + yy4605.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57349,83 +57267,83 @@ func (x codecSelfer1234) decSliceKeyToPath(v *[]KeyToPath, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4615 := *v - yyh4615, yyl4615 := z.DecSliceHelperStart() - var yyc4615 bool - if yyl4615 == 0 { - if yyv4615 == nil { - yyv4615 = []KeyToPath{} - yyc4615 = true - } else if len(yyv4615) != 0 { - yyv4615 = yyv4615[:0] - yyc4615 = true + yyv4606 := *v + yyh4606, yyl4606 := z.DecSliceHelperStart() + var yyc4606 bool + if yyl4606 == 0 { + if yyv4606 == nil { + yyv4606 = []KeyToPath{} + yyc4606 = true + } else if len(yyv4606) != 0 { + yyv4606 = yyv4606[:0] + yyc4606 = true } - } else if yyl4615 > 0 { - var yyrr4615, yyrl4615 int - var yyrt4615 bool - if yyl4615 > cap(yyv4615) { + } else if yyl4606 > 0 { + var yyrr4606, yyrl4606 int + var yyrt4606 bool + if yyl4606 > cap(yyv4606) { - yyrg4615 := len(yyv4615) > 0 - yyv24615 := yyv4615 - yyrl4615, yyrt4615 = z.DecInferLen(yyl4615, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4615 { - if yyrl4615 <= cap(yyv4615) { - yyv4615 = yyv4615[:yyrl4615] + yyrg4606 := len(yyv4606) > 0 + yyv24606 := yyv4606 + yyrl4606, yyrt4606 = z.DecInferLen(yyl4606, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4606 { + if yyrl4606 <= cap(yyv4606) { + yyv4606 = yyv4606[:yyrl4606] } else { - yyv4615 = make([]KeyToPath, yyrl4615) + yyv4606 = make([]KeyToPath, yyrl4606) } } else { - yyv4615 = make([]KeyToPath, yyrl4615) + yyv4606 = make([]KeyToPath, yyrl4606) } - yyc4615 = true - yyrr4615 = len(yyv4615) - if yyrg4615 { - copy(yyv4615, yyv24615) + yyc4606 = true + yyrr4606 = len(yyv4606) + if yyrg4606 { + copy(yyv4606, yyv24606) } - } else if yyl4615 != len(yyv4615) { - yyv4615 = yyv4615[:yyl4615] - yyc4615 = true + } else if yyl4606 != len(yyv4606) { + yyv4606 = yyv4606[:yyl4606] + yyc4606 = true } - yyj4615 := 0 - for ; yyj4615 < yyrr4615; yyj4615++ { - yyh4615.ElemContainerState(yyj4615) + yyj4606 := 0 + for ; yyj4606 < yyrr4606; yyj4606++ { + yyh4606.ElemContainerState(yyj4606) if r.TryDecodeAsNil() { - yyv4615[yyj4615] = KeyToPath{} + yyv4606[yyj4606] = KeyToPath{} } else { - yyv4616 := &yyv4615[yyj4615] - yyv4616.CodecDecodeSelf(d) + yyv4607 := &yyv4606[yyj4606] + yyv4607.CodecDecodeSelf(d) } } - if yyrt4615 { - for ; yyj4615 < yyl4615; yyj4615++ { - yyv4615 = append(yyv4615, KeyToPath{}) - yyh4615.ElemContainerState(yyj4615) + if yyrt4606 { + for ; yyj4606 < yyl4606; yyj4606++ { + yyv4606 = append(yyv4606, KeyToPath{}) + yyh4606.ElemContainerState(yyj4606) if r.TryDecodeAsNil() { - yyv4615[yyj4615] = KeyToPath{} + yyv4606[yyj4606] = KeyToPath{} } else { - yyv4617 := &yyv4615[yyj4615] - yyv4617.CodecDecodeSelf(d) + yyv4608 := &yyv4606[yyj4606] + yyv4608.CodecDecodeSelf(d) } } } } else { - yyj4615 := 0 - for ; !r.CheckBreak(); yyj4615++ { + yyj4606 := 0 + for ; !r.CheckBreak(); yyj4606++ { - if yyj4615 >= len(yyv4615) { - yyv4615 = append(yyv4615, KeyToPath{}) // var yyz4615 KeyToPath - yyc4615 = true + if yyj4606 >= len(yyv4606) { + yyv4606 = append(yyv4606, KeyToPath{}) // var yyz4606 KeyToPath + yyc4606 = true } - yyh4615.ElemContainerState(yyj4615) - if yyj4615 < len(yyv4615) { + yyh4606.ElemContainerState(yyj4606) + if yyj4606 < len(yyv4606) { if r.TryDecodeAsNil() { - yyv4615[yyj4615] = KeyToPath{} + yyv4606[yyj4606] = KeyToPath{} } else { - yyv4618 := &yyv4615[yyj4615] - yyv4618.CodecDecodeSelf(d) + yyv4609 := &yyv4606[yyj4606] + yyv4609.CodecDecodeSelf(d) } } else { @@ -57433,17 +57351,17 @@ func (x codecSelfer1234) decSliceKeyToPath(v *[]KeyToPath, d *codec1978.Decoder) } } - if yyj4615 < len(yyv4615) { - yyv4615 = yyv4615[:yyj4615] - yyc4615 = true - } else if yyj4615 == 0 && yyv4615 == nil { - yyv4615 = []KeyToPath{} - yyc4615 = true + if yyj4606 < len(yyv4606) { + yyv4606 = yyv4606[:yyj4606] + yyc4606 = true + } else if yyj4606 == 0 && yyv4606 == nil { + yyv4606 = []KeyToPath{} + yyc4606 = true } } - yyh4615.End() - if yyc4615 { - *v = yyv4615 + yyh4606.End() + if yyc4606 { + *v = yyv4606 } } @@ -57452,10 +57370,10 @@ func (x codecSelfer1234) encSliceDownwardAPIVolumeFile(v []DownwardAPIVolumeFile z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4619 := range v { + for _, yyv4610 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4620 := &yyv4619 - yy4620.CodecEncodeSelf(e) + yy4611 := &yyv4610 + yy4611.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57465,83 +57383,83 @@ func (x codecSelfer1234) decSliceDownwardAPIVolumeFile(v *[]DownwardAPIVolumeFil z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4621 := *v - yyh4621, yyl4621 := z.DecSliceHelperStart() - var yyc4621 bool - if yyl4621 == 0 { - if yyv4621 == nil { - yyv4621 = []DownwardAPIVolumeFile{} - yyc4621 = true - } else if len(yyv4621) != 0 { - yyv4621 = yyv4621[:0] - yyc4621 = true + yyv4612 := *v + yyh4612, yyl4612 := z.DecSliceHelperStart() + var yyc4612 bool + if yyl4612 == 0 { + if yyv4612 == nil { + yyv4612 = []DownwardAPIVolumeFile{} + yyc4612 = true + } else if len(yyv4612) != 0 { + yyv4612 = yyv4612[:0] + yyc4612 = true } - } else if yyl4621 > 0 { - var yyrr4621, yyrl4621 int - var yyrt4621 bool - if yyl4621 > cap(yyv4621) { + } else if yyl4612 > 0 { + var yyrr4612, yyrl4612 int + var yyrt4612 bool + if yyl4612 > cap(yyv4612) { - yyrg4621 := len(yyv4621) > 0 - yyv24621 := yyv4621 - yyrl4621, yyrt4621 = z.DecInferLen(yyl4621, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4621 { - if yyrl4621 <= cap(yyv4621) { - yyv4621 = yyv4621[:yyrl4621] + yyrg4612 := len(yyv4612) > 0 + yyv24612 := yyv4612 + yyrl4612, yyrt4612 = z.DecInferLen(yyl4612, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4612 { + if yyrl4612 <= cap(yyv4612) { + yyv4612 = yyv4612[:yyrl4612] } else { - yyv4621 = make([]DownwardAPIVolumeFile, yyrl4621) + yyv4612 = make([]DownwardAPIVolumeFile, yyrl4612) } } else { - yyv4621 = make([]DownwardAPIVolumeFile, yyrl4621) + yyv4612 = make([]DownwardAPIVolumeFile, yyrl4612) } - yyc4621 = true - yyrr4621 = len(yyv4621) - if yyrg4621 { - copy(yyv4621, yyv24621) + yyc4612 = true + yyrr4612 = len(yyv4612) + if yyrg4612 { + copy(yyv4612, yyv24612) } - } else if yyl4621 != len(yyv4621) { - yyv4621 = yyv4621[:yyl4621] - yyc4621 = true + } else if yyl4612 != len(yyv4612) { + yyv4612 = yyv4612[:yyl4612] + yyc4612 = true } - yyj4621 := 0 - for ; yyj4621 < yyrr4621; yyj4621++ { - yyh4621.ElemContainerState(yyj4621) + yyj4612 := 0 + for ; yyj4612 < yyrr4612; yyj4612++ { + yyh4612.ElemContainerState(yyj4612) if r.TryDecodeAsNil() { - yyv4621[yyj4621] = DownwardAPIVolumeFile{} + yyv4612[yyj4612] = DownwardAPIVolumeFile{} } else { - yyv4622 := &yyv4621[yyj4621] - yyv4622.CodecDecodeSelf(d) + yyv4613 := &yyv4612[yyj4612] + yyv4613.CodecDecodeSelf(d) } } - if yyrt4621 { - for ; yyj4621 < yyl4621; yyj4621++ { - yyv4621 = append(yyv4621, DownwardAPIVolumeFile{}) - yyh4621.ElemContainerState(yyj4621) + if yyrt4612 { + for ; yyj4612 < yyl4612; yyj4612++ { + yyv4612 = append(yyv4612, DownwardAPIVolumeFile{}) + yyh4612.ElemContainerState(yyj4612) if r.TryDecodeAsNil() { - yyv4621[yyj4621] = DownwardAPIVolumeFile{} + yyv4612[yyj4612] = DownwardAPIVolumeFile{} } else { - yyv4623 := &yyv4621[yyj4621] - yyv4623.CodecDecodeSelf(d) + yyv4614 := &yyv4612[yyj4612] + yyv4614.CodecDecodeSelf(d) } } } } else { - yyj4621 := 0 - for ; !r.CheckBreak(); yyj4621++ { + yyj4612 := 0 + for ; !r.CheckBreak(); yyj4612++ { - if yyj4621 >= len(yyv4621) { - yyv4621 = append(yyv4621, DownwardAPIVolumeFile{}) // var yyz4621 DownwardAPIVolumeFile - yyc4621 = true + if yyj4612 >= len(yyv4612) { + yyv4612 = append(yyv4612, DownwardAPIVolumeFile{}) // var yyz4612 DownwardAPIVolumeFile + yyc4612 = true } - yyh4621.ElemContainerState(yyj4621) - if yyj4621 < len(yyv4621) { + yyh4612.ElemContainerState(yyj4612) + if yyj4612 < len(yyv4612) { if r.TryDecodeAsNil() { - yyv4621[yyj4621] = DownwardAPIVolumeFile{} + yyv4612[yyj4612] = DownwardAPIVolumeFile{} } else { - yyv4624 := &yyv4621[yyj4621] - yyv4624.CodecDecodeSelf(d) + yyv4615 := &yyv4612[yyj4612] + yyv4615.CodecDecodeSelf(d) } } else { @@ -57549,17 +57467,17 @@ func (x codecSelfer1234) decSliceDownwardAPIVolumeFile(v *[]DownwardAPIVolumeFil } } - if yyj4621 < len(yyv4621) { - yyv4621 = yyv4621[:yyj4621] - yyc4621 = true - } else if yyj4621 == 0 && yyv4621 == nil { - yyv4621 = []DownwardAPIVolumeFile{} - yyc4621 = true + if yyj4612 < len(yyv4612) { + yyv4612 = yyv4612[:yyj4612] + yyc4612 = true + } else if yyj4612 == 0 && yyv4612 == nil { + yyv4612 = []DownwardAPIVolumeFile{} + yyc4612 = true } } - yyh4621.End() - if yyc4621 { - *v = yyv4621 + yyh4612.End() + if yyc4612 { + *v = yyv4612 } } @@ -57568,10 +57486,10 @@ func (x codecSelfer1234) encSliceHTTPHeader(v []HTTPHeader, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4625 := range v { + for _, yyv4616 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4626 := &yyv4625 - yy4626.CodecEncodeSelf(e) + yy4617 := &yyv4616 + yy4617.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57581,83 +57499,83 @@ func (x codecSelfer1234) decSliceHTTPHeader(v *[]HTTPHeader, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4627 := *v - yyh4627, yyl4627 := z.DecSliceHelperStart() - var yyc4627 bool - if yyl4627 == 0 { - if yyv4627 == nil { - yyv4627 = []HTTPHeader{} - yyc4627 = true - } else if len(yyv4627) != 0 { - yyv4627 = yyv4627[:0] - yyc4627 = true + yyv4618 := *v + yyh4618, yyl4618 := z.DecSliceHelperStart() + var yyc4618 bool + if yyl4618 == 0 { + if yyv4618 == nil { + yyv4618 = []HTTPHeader{} + yyc4618 = true + } else if len(yyv4618) != 0 { + yyv4618 = yyv4618[:0] + yyc4618 = true } - } else if yyl4627 > 0 { - var yyrr4627, yyrl4627 int - var yyrt4627 bool - if yyl4627 > cap(yyv4627) { + } else if yyl4618 > 0 { + var yyrr4618, yyrl4618 int + var yyrt4618 bool + if yyl4618 > cap(yyv4618) { - yyrg4627 := len(yyv4627) > 0 - yyv24627 := yyv4627 - yyrl4627, yyrt4627 = z.DecInferLen(yyl4627, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4627 { - if yyrl4627 <= cap(yyv4627) { - yyv4627 = yyv4627[:yyrl4627] + yyrg4618 := len(yyv4618) > 0 + yyv24618 := yyv4618 + yyrl4618, yyrt4618 = z.DecInferLen(yyl4618, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4618 { + if yyrl4618 <= cap(yyv4618) { + yyv4618 = yyv4618[:yyrl4618] } else { - yyv4627 = make([]HTTPHeader, yyrl4627) + yyv4618 = make([]HTTPHeader, yyrl4618) } } else { - yyv4627 = make([]HTTPHeader, yyrl4627) + yyv4618 = make([]HTTPHeader, yyrl4618) } - yyc4627 = true - yyrr4627 = len(yyv4627) - if yyrg4627 { - copy(yyv4627, yyv24627) + yyc4618 = true + yyrr4618 = len(yyv4618) + if yyrg4618 { + copy(yyv4618, yyv24618) } - } else if yyl4627 != len(yyv4627) { - yyv4627 = yyv4627[:yyl4627] - yyc4627 = true + } else if yyl4618 != len(yyv4618) { + yyv4618 = yyv4618[:yyl4618] + yyc4618 = true } - yyj4627 := 0 - for ; yyj4627 < yyrr4627; yyj4627++ { - yyh4627.ElemContainerState(yyj4627) + yyj4618 := 0 + for ; yyj4618 < yyrr4618; yyj4618++ { + yyh4618.ElemContainerState(yyj4618) if r.TryDecodeAsNil() { - yyv4627[yyj4627] = HTTPHeader{} + yyv4618[yyj4618] = HTTPHeader{} } else { - yyv4628 := &yyv4627[yyj4627] - yyv4628.CodecDecodeSelf(d) + yyv4619 := &yyv4618[yyj4618] + yyv4619.CodecDecodeSelf(d) } } - if yyrt4627 { - for ; yyj4627 < yyl4627; yyj4627++ { - yyv4627 = append(yyv4627, HTTPHeader{}) - yyh4627.ElemContainerState(yyj4627) + if yyrt4618 { + for ; yyj4618 < yyl4618; yyj4618++ { + yyv4618 = append(yyv4618, HTTPHeader{}) + yyh4618.ElemContainerState(yyj4618) if r.TryDecodeAsNil() { - yyv4627[yyj4627] = HTTPHeader{} + yyv4618[yyj4618] = HTTPHeader{} } else { - yyv4629 := &yyv4627[yyj4627] - yyv4629.CodecDecodeSelf(d) + yyv4620 := &yyv4618[yyj4618] + yyv4620.CodecDecodeSelf(d) } } } } else { - yyj4627 := 0 - for ; !r.CheckBreak(); yyj4627++ { + yyj4618 := 0 + for ; !r.CheckBreak(); yyj4618++ { - if yyj4627 >= len(yyv4627) { - yyv4627 = append(yyv4627, HTTPHeader{}) // var yyz4627 HTTPHeader - yyc4627 = true + if yyj4618 >= len(yyv4618) { + yyv4618 = append(yyv4618, HTTPHeader{}) // var yyz4618 HTTPHeader + yyc4618 = true } - yyh4627.ElemContainerState(yyj4627) - if yyj4627 < len(yyv4627) { + yyh4618.ElemContainerState(yyj4618) + if yyj4618 < len(yyv4618) { if r.TryDecodeAsNil() { - yyv4627[yyj4627] = HTTPHeader{} + yyv4618[yyj4618] = HTTPHeader{} } else { - yyv4630 := &yyv4627[yyj4627] - yyv4630.CodecDecodeSelf(d) + yyv4621 := &yyv4618[yyj4618] + yyv4621.CodecDecodeSelf(d) } } else { @@ -57665,17 +57583,17 @@ func (x codecSelfer1234) decSliceHTTPHeader(v *[]HTTPHeader, d *codec1978.Decode } } - if yyj4627 < len(yyv4627) { - yyv4627 = yyv4627[:yyj4627] - yyc4627 = true - } else if yyj4627 == 0 && yyv4627 == nil { - yyv4627 = []HTTPHeader{} - yyc4627 = true + if yyj4618 < len(yyv4618) { + yyv4618 = yyv4618[:yyj4618] + yyc4618 = true + } else if yyj4618 == 0 && yyv4618 == nil { + yyv4618 = []HTTPHeader{} + yyc4618 = true } } - yyh4627.End() - if yyc4627 { - *v = yyv4627 + yyh4618.End() + if yyc4618 { + *v = yyv4618 } } @@ -57684,9 +57602,9 @@ func (x codecSelfer1234) encSliceCapability(v []Capability, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4631 := range v { + for _, yyv4622 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4631.CodecEncodeSelf(e) + yyv4622.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57696,75 +57614,75 @@ func (x codecSelfer1234) decSliceCapability(v *[]Capability, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4632 := *v - yyh4632, yyl4632 := z.DecSliceHelperStart() - var yyc4632 bool - if yyl4632 == 0 { - if yyv4632 == nil { - yyv4632 = []Capability{} - yyc4632 = true - } else if len(yyv4632) != 0 { - yyv4632 = yyv4632[:0] - yyc4632 = true + yyv4623 := *v + yyh4623, yyl4623 := z.DecSliceHelperStart() + var yyc4623 bool + if yyl4623 == 0 { + if yyv4623 == nil { + yyv4623 = []Capability{} + yyc4623 = true + } else if len(yyv4623) != 0 { + yyv4623 = yyv4623[:0] + yyc4623 = true } - } else if yyl4632 > 0 { - var yyrr4632, yyrl4632 int - var yyrt4632 bool - if yyl4632 > cap(yyv4632) { + } else if yyl4623 > 0 { + var yyrr4623, yyrl4623 int + var yyrt4623 bool + if yyl4623 > cap(yyv4623) { - yyrl4632, yyrt4632 = z.DecInferLen(yyl4632, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4632 { - if yyrl4632 <= cap(yyv4632) { - yyv4632 = yyv4632[:yyrl4632] + yyrl4623, yyrt4623 = z.DecInferLen(yyl4623, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4623 { + if yyrl4623 <= cap(yyv4623) { + yyv4623 = yyv4623[:yyrl4623] } else { - yyv4632 = make([]Capability, yyrl4632) + yyv4623 = make([]Capability, yyrl4623) } } else { - yyv4632 = make([]Capability, yyrl4632) + yyv4623 = make([]Capability, yyrl4623) } - yyc4632 = true - yyrr4632 = len(yyv4632) - } else if yyl4632 != len(yyv4632) { - yyv4632 = yyv4632[:yyl4632] - yyc4632 = true + yyc4623 = true + yyrr4623 = len(yyv4623) + } else if yyl4623 != len(yyv4623) { + yyv4623 = yyv4623[:yyl4623] + yyc4623 = true } - yyj4632 := 0 - for ; yyj4632 < yyrr4632; yyj4632++ { - yyh4632.ElemContainerState(yyj4632) + yyj4623 := 0 + for ; yyj4623 < yyrr4623; yyj4623++ { + yyh4623.ElemContainerState(yyj4623) if r.TryDecodeAsNil() { - yyv4632[yyj4632] = "" + yyv4623[yyj4623] = "" } else { - yyv4632[yyj4632] = Capability(r.DecodeString()) + yyv4623[yyj4623] = Capability(r.DecodeString()) } } - if yyrt4632 { - for ; yyj4632 < yyl4632; yyj4632++ { - yyv4632 = append(yyv4632, "") - yyh4632.ElemContainerState(yyj4632) + if yyrt4623 { + for ; yyj4623 < yyl4623; yyj4623++ { + yyv4623 = append(yyv4623, "") + yyh4623.ElemContainerState(yyj4623) if r.TryDecodeAsNil() { - yyv4632[yyj4632] = "" + yyv4623[yyj4623] = "" } else { - yyv4632[yyj4632] = Capability(r.DecodeString()) + yyv4623[yyj4623] = Capability(r.DecodeString()) } } } } else { - yyj4632 := 0 - for ; !r.CheckBreak(); yyj4632++ { + yyj4623 := 0 + for ; !r.CheckBreak(); yyj4623++ { - if yyj4632 >= len(yyv4632) { - yyv4632 = append(yyv4632, "") // var yyz4632 Capability - yyc4632 = true + if yyj4623 >= len(yyv4623) { + yyv4623 = append(yyv4623, "") // var yyz4623 Capability + yyc4623 = true } - yyh4632.ElemContainerState(yyj4632) - if yyj4632 < len(yyv4632) { + yyh4623.ElemContainerState(yyj4623) + if yyj4623 < len(yyv4623) { if r.TryDecodeAsNil() { - yyv4632[yyj4632] = "" + yyv4623[yyj4623] = "" } else { - yyv4632[yyj4632] = Capability(r.DecodeString()) + yyv4623[yyj4623] = Capability(r.DecodeString()) } } else { @@ -57772,17 +57690,17 @@ func (x codecSelfer1234) decSliceCapability(v *[]Capability, d *codec1978.Decode } } - if yyj4632 < len(yyv4632) { - yyv4632 = yyv4632[:yyj4632] - yyc4632 = true - } else if yyj4632 == 0 && yyv4632 == nil { - yyv4632 = []Capability{} - yyc4632 = true + if yyj4623 < len(yyv4623) { + yyv4623 = yyv4623[:yyj4623] + yyc4623 = true + } else if yyj4623 == 0 && yyv4623 == nil { + yyv4623 = []Capability{} + yyc4623 = true } } - yyh4632.End() - if yyc4632 { - *v = yyv4632 + yyh4623.End() + if yyc4623 { + *v = yyv4623 } } @@ -57791,10 +57709,10 @@ func (x codecSelfer1234) encSliceContainerPort(v []ContainerPort, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4636 := range v { + for _, yyv4627 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4637 := &yyv4636 - yy4637.CodecEncodeSelf(e) + yy4628 := &yyv4627 + yy4628.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57804,83 +57722,83 @@ func (x codecSelfer1234) decSliceContainerPort(v *[]ContainerPort, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4638 := *v - yyh4638, yyl4638 := z.DecSliceHelperStart() - var yyc4638 bool - if yyl4638 == 0 { - if yyv4638 == nil { - yyv4638 = []ContainerPort{} - yyc4638 = true - } else if len(yyv4638) != 0 { - yyv4638 = yyv4638[:0] - yyc4638 = true + yyv4629 := *v + yyh4629, yyl4629 := z.DecSliceHelperStart() + var yyc4629 bool + if yyl4629 == 0 { + if yyv4629 == nil { + yyv4629 = []ContainerPort{} + yyc4629 = true + } else if len(yyv4629) != 0 { + yyv4629 = yyv4629[:0] + yyc4629 = true } - } else if yyl4638 > 0 { - var yyrr4638, yyrl4638 int - var yyrt4638 bool - if yyl4638 > cap(yyv4638) { + } else if yyl4629 > 0 { + var yyrr4629, yyrl4629 int + var yyrt4629 bool + if yyl4629 > cap(yyv4629) { - yyrg4638 := len(yyv4638) > 0 - yyv24638 := yyv4638 - yyrl4638, yyrt4638 = z.DecInferLen(yyl4638, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4638 { - if yyrl4638 <= cap(yyv4638) { - yyv4638 = yyv4638[:yyrl4638] + yyrg4629 := len(yyv4629) > 0 + yyv24629 := yyv4629 + yyrl4629, yyrt4629 = z.DecInferLen(yyl4629, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4629 { + if yyrl4629 <= cap(yyv4629) { + yyv4629 = yyv4629[:yyrl4629] } else { - yyv4638 = make([]ContainerPort, yyrl4638) + yyv4629 = make([]ContainerPort, yyrl4629) } } else { - yyv4638 = make([]ContainerPort, yyrl4638) + yyv4629 = make([]ContainerPort, yyrl4629) } - yyc4638 = true - yyrr4638 = len(yyv4638) - if yyrg4638 { - copy(yyv4638, yyv24638) + yyc4629 = true + yyrr4629 = len(yyv4629) + if yyrg4629 { + copy(yyv4629, yyv24629) } - } else if yyl4638 != len(yyv4638) { - yyv4638 = yyv4638[:yyl4638] - yyc4638 = true + } else if yyl4629 != len(yyv4629) { + yyv4629 = yyv4629[:yyl4629] + yyc4629 = true } - yyj4638 := 0 - for ; yyj4638 < yyrr4638; yyj4638++ { - yyh4638.ElemContainerState(yyj4638) + yyj4629 := 0 + for ; yyj4629 < yyrr4629; yyj4629++ { + yyh4629.ElemContainerState(yyj4629) if r.TryDecodeAsNil() { - yyv4638[yyj4638] = ContainerPort{} + yyv4629[yyj4629] = ContainerPort{} } else { - yyv4639 := &yyv4638[yyj4638] - yyv4639.CodecDecodeSelf(d) + yyv4630 := &yyv4629[yyj4629] + yyv4630.CodecDecodeSelf(d) } } - if yyrt4638 { - for ; yyj4638 < yyl4638; yyj4638++ { - yyv4638 = append(yyv4638, ContainerPort{}) - yyh4638.ElemContainerState(yyj4638) + if yyrt4629 { + for ; yyj4629 < yyl4629; yyj4629++ { + yyv4629 = append(yyv4629, ContainerPort{}) + yyh4629.ElemContainerState(yyj4629) if r.TryDecodeAsNil() { - yyv4638[yyj4638] = ContainerPort{} + yyv4629[yyj4629] = ContainerPort{} } else { - yyv4640 := &yyv4638[yyj4638] - yyv4640.CodecDecodeSelf(d) + yyv4631 := &yyv4629[yyj4629] + yyv4631.CodecDecodeSelf(d) } } } } else { - yyj4638 := 0 - for ; !r.CheckBreak(); yyj4638++ { + yyj4629 := 0 + for ; !r.CheckBreak(); yyj4629++ { - if yyj4638 >= len(yyv4638) { - yyv4638 = append(yyv4638, ContainerPort{}) // var yyz4638 ContainerPort - yyc4638 = true + if yyj4629 >= len(yyv4629) { + yyv4629 = append(yyv4629, ContainerPort{}) // var yyz4629 ContainerPort + yyc4629 = true } - yyh4638.ElemContainerState(yyj4638) - if yyj4638 < len(yyv4638) { + yyh4629.ElemContainerState(yyj4629) + if yyj4629 < len(yyv4629) { if r.TryDecodeAsNil() { - yyv4638[yyj4638] = ContainerPort{} + yyv4629[yyj4629] = ContainerPort{} } else { - yyv4641 := &yyv4638[yyj4638] - yyv4641.CodecDecodeSelf(d) + yyv4632 := &yyv4629[yyj4629] + yyv4632.CodecDecodeSelf(d) } } else { @@ -57888,17 +57806,17 @@ func (x codecSelfer1234) decSliceContainerPort(v *[]ContainerPort, d *codec1978. } } - if yyj4638 < len(yyv4638) { - yyv4638 = yyv4638[:yyj4638] - yyc4638 = true - } else if yyj4638 == 0 && yyv4638 == nil { - yyv4638 = []ContainerPort{} - yyc4638 = true + if yyj4629 < len(yyv4629) { + yyv4629 = yyv4629[:yyj4629] + yyc4629 = true + } else if yyj4629 == 0 && yyv4629 == nil { + yyv4629 = []ContainerPort{} + yyc4629 = true } } - yyh4638.End() - if yyc4638 { - *v = yyv4638 + yyh4629.End() + if yyc4629 { + *v = yyv4629 } } @@ -57907,10 +57825,10 @@ func (x codecSelfer1234) encSliceEnvVar(v []EnvVar, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4642 := range v { + for _, yyv4633 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4643 := &yyv4642 - yy4643.CodecEncodeSelf(e) + yy4634 := &yyv4633 + yy4634.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57920,83 +57838,83 @@ func (x codecSelfer1234) decSliceEnvVar(v *[]EnvVar, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4644 := *v - yyh4644, yyl4644 := z.DecSliceHelperStart() - var yyc4644 bool - if yyl4644 == 0 { - if yyv4644 == nil { - yyv4644 = []EnvVar{} - yyc4644 = true - } else if len(yyv4644) != 0 { - yyv4644 = yyv4644[:0] - yyc4644 = true + yyv4635 := *v + yyh4635, yyl4635 := z.DecSliceHelperStart() + var yyc4635 bool + if yyl4635 == 0 { + if yyv4635 == nil { + yyv4635 = []EnvVar{} + yyc4635 = true + } else if len(yyv4635) != 0 { + yyv4635 = yyv4635[:0] + yyc4635 = true } - } else if yyl4644 > 0 { - var yyrr4644, yyrl4644 int - var yyrt4644 bool - if yyl4644 > cap(yyv4644) { + } else if yyl4635 > 0 { + var yyrr4635, yyrl4635 int + var yyrt4635 bool + if yyl4635 > cap(yyv4635) { - yyrg4644 := len(yyv4644) > 0 - yyv24644 := yyv4644 - yyrl4644, yyrt4644 = z.DecInferLen(yyl4644, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4644 { - if yyrl4644 <= cap(yyv4644) { - yyv4644 = yyv4644[:yyrl4644] + yyrg4635 := len(yyv4635) > 0 + yyv24635 := yyv4635 + yyrl4635, yyrt4635 = z.DecInferLen(yyl4635, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4635 { + if yyrl4635 <= cap(yyv4635) { + yyv4635 = yyv4635[:yyrl4635] } else { - yyv4644 = make([]EnvVar, yyrl4644) + yyv4635 = make([]EnvVar, yyrl4635) } } else { - yyv4644 = make([]EnvVar, yyrl4644) + yyv4635 = make([]EnvVar, yyrl4635) } - yyc4644 = true - yyrr4644 = len(yyv4644) - if yyrg4644 { - copy(yyv4644, yyv24644) + yyc4635 = true + yyrr4635 = len(yyv4635) + if yyrg4635 { + copy(yyv4635, yyv24635) } - } else if yyl4644 != len(yyv4644) { - yyv4644 = yyv4644[:yyl4644] - yyc4644 = true + } else if yyl4635 != len(yyv4635) { + yyv4635 = yyv4635[:yyl4635] + yyc4635 = true } - yyj4644 := 0 - for ; yyj4644 < yyrr4644; yyj4644++ { - yyh4644.ElemContainerState(yyj4644) + yyj4635 := 0 + for ; yyj4635 < yyrr4635; yyj4635++ { + yyh4635.ElemContainerState(yyj4635) if r.TryDecodeAsNil() { - yyv4644[yyj4644] = EnvVar{} + yyv4635[yyj4635] = EnvVar{} } else { - yyv4645 := &yyv4644[yyj4644] - yyv4645.CodecDecodeSelf(d) + yyv4636 := &yyv4635[yyj4635] + yyv4636.CodecDecodeSelf(d) } } - if yyrt4644 { - for ; yyj4644 < yyl4644; yyj4644++ { - yyv4644 = append(yyv4644, EnvVar{}) - yyh4644.ElemContainerState(yyj4644) + if yyrt4635 { + for ; yyj4635 < yyl4635; yyj4635++ { + yyv4635 = append(yyv4635, EnvVar{}) + yyh4635.ElemContainerState(yyj4635) if r.TryDecodeAsNil() { - yyv4644[yyj4644] = EnvVar{} + yyv4635[yyj4635] = EnvVar{} } else { - yyv4646 := &yyv4644[yyj4644] - yyv4646.CodecDecodeSelf(d) + yyv4637 := &yyv4635[yyj4635] + yyv4637.CodecDecodeSelf(d) } } } } else { - yyj4644 := 0 - for ; !r.CheckBreak(); yyj4644++ { + yyj4635 := 0 + for ; !r.CheckBreak(); yyj4635++ { - if yyj4644 >= len(yyv4644) { - yyv4644 = append(yyv4644, EnvVar{}) // var yyz4644 EnvVar - yyc4644 = true + if yyj4635 >= len(yyv4635) { + yyv4635 = append(yyv4635, EnvVar{}) // var yyz4635 EnvVar + yyc4635 = true } - yyh4644.ElemContainerState(yyj4644) - if yyj4644 < len(yyv4644) { + yyh4635.ElemContainerState(yyj4635) + if yyj4635 < len(yyv4635) { if r.TryDecodeAsNil() { - yyv4644[yyj4644] = EnvVar{} + yyv4635[yyj4635] = EnvVar{} } else { - yyv4647 := &yyv4644[yyj4644] - yyv4647.CodecDecodeSelf(d) + yyv4638 := &yyv4635[yyj4635] + yyv4638.CodecDecodeSelf(d) } } else { @@ -58004,17 +57922,17 @@ func (x codecSelfer1234) decSliceEnvVar(v *[]EnvVar, d *codec1978.Decoder) { } } - if yyj4644 < len(yyv4644) { - yyv4644 = yyv4644[:yyj4644] - yyc4644 = true - } else if yyj4644 == 0 && yyv4644 == nil { - yyv4644 = []EnvVar{} - yyc4644 = true + if yyj4635 < len(yyv4635) { + yyv4635 = yyv4635[:yyj4635] + yyc4635 = true + } else if yyj4635 == 0 && yyv4635 == nil { + yyv4635 = []EnvVar{} + yyc4635 = true } } - yyh4644.End() - if yyc4644 { - *v = yyv4644 + yyh4635.End() + if yyc4635 { + *v = yyv4635 } } @@ -58023,10 +57941,10 @@ func (x codecSelfer1234) encSliceVolumeMount(v []VolumeMount, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4648 := range v { + for _, yyv4639 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4649 := &yyv4648 - yy4649.CodecEncodeSelf(e) + yy4640 := &yyv4639 + yy4640.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58036,83 +57954,83 @@ func (x codecSelfer1234) decSliceVolumeMount(v *[]VolumeMount, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4650 := *v - yyh4650, yyl4650 := z.DecSliceHelperStart() - var yyc4650 bool - if yyl4650 == 0 { - if yyv4650 == nil { - yyv4650 = []VolumeMount{} - yyc4650 = true - } else if len(yyv4650) != 0 { - yyv4650 = yyv4650[:0] - yyc4650 = true + yyv4641 := *v + yyh4641, yyl4641 := z.DecSliceHelperStart() + var yyc4641 bool + if yyl4641 == 0 { + if yyv4641 == nil { + yyv4641 = []VolumeMount{} + yyc4641 = true + } else if len(yyv4641) != 0 { + yyv4641 = yyv4641[:0] + yyc4641 = true } - } else if yyl4650 > 0 { - var yyrr4650, yyrl4650 int - var yyrt4650 bool - if yyl4650 > cap(yyv4650) { + } else if yyl4641 > 0 { + var yyrr4641, yyrl4641 int + var yyrt4641 bool + if yyl4641 > cap(yyv4641) { - yyrg4650 := len(yyv4650) > 0 - yyv24650 := yyv4650 - yyrl4650, yyrt4650 = z.DecInferLen(yyl4650, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4650 { - if yyrl4650 <= cap(yyv4650) { - yyv4650 = yyv4650[:yyrl4650] + yyrg4641 := len(yyv4641) > 0 + yyv24641 := yyv4641 + yyrl4641, yyrt4641 = z.DecInferLen(yyl4641, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4641 { + if yyrl4641 <= cap(yyv4641) { + yyv4641 = yyv4641[:yyrl4641] } else { - yyv4650 = make([]VolumeMount, yyrl4650) + yyv4641 = make([]VolumeMount, yyrl4641) } } else { - yyv4650 = make([]VolumeMount, yyrl4650) + yyv4641 = make([]VolumeMount, yyrl4641) } - yyc4650 = true - yyrr4650 = len(yyv4650) - if yyrg4650 { - copy(yyv4650, yyv24650) + yyc4641 = true + yyrr4641 = len(yyv4641) + if yyrg4641 { + copy(yyv4641, yyv24641) } - } else if yyl4650 != len(yyv4650) { - yyv4650 = yyv4650[:yyl4650] - yyc4650 = true + } else if yyl4641 != len(yyv4641) { + yyv4641 = yyv4641[:yyl4641] + yyc4641 = true } - yyj4650 := 0 - for ; yyj4650 < yyrr4650; yyj4650++ { - yyh4650.ElemContainerState(yyj4650) + yyj4641 := 0 + for ; yyj4641 < yyrr4641; yyj4641++ { + yyh4641.ElemContainerState(yyj4641) if r.TryDecodeAsNil() { - yyv4650[yyj4650] = VolumeMount{} + yyv4641[yyj4641] = VolumeMount{} } else { - yyv4651 := &yyv4650[yyj4650] - yyv4651.CodecDecodeSelf(d) + yyv4642 := &yyv4641[yyj4641] + yyv4642.CodecDecodeSelf(d) } } - if yyrt4650 { - for ; yyj4650 < yyl4650; yyj4650++ { - yyv4650 = append(yyv4650, VolumeMount{}) - yyh4650.ElemContainerState(yyj4650) + if yyrt4641 { + for ; yyj4641 < yyl4641; yyj4641++ { + yyv4641 = append(yyv4641, VolumeMount{}) + yyh4641.ElemContainerState(yyj4641) if r.TryDecodeAsNil() { - yyv4650[yyj4650] = VolumeMount{} + yyv4641[yyj4641] = VolumeMount{} } else { - yyv4652 := &yyv4650[yyj4650] - yyv4652.CodecDecodeSelf(d) + yyv4643 := &yyv4641[yyj4641] + yyv4643.CodecDecodeSelf(d) } } } } else { - yyj4650 := 0 - for ; !r.CheckBreak(); yyj4650++ { + yyj4641 := 0 + for ; !r.CheckBreak(); yyj4641++ { - if yyj4650 >= len(yyv4650) { - yyv4650 = append(yyv4650, VolumeMount{}) // var yyz4650 VolumeMount - yyc4650 = true + if yyj4641 >= len(yyv4641) { + yyv4641 = append(yyv4641, VolumeMount{}) // var yyz4641 VolumeMount + yyc4641 = true } - yyh4650.ElemContainerState(yyj4650) - if yyj4650 < len(yyv4650) { + yyh4641.ElemContainerState(yyj4641) + if yyj4641 < len(yyv4641) { if r.TryDecodeAsNil() { - yyv4650[yyj4650] = VolumeMount{} + yyv4641[yyj4641] = VolumeMount{} } else { - yyv4653 := &yyv4650[yyj4650] - yyv4653.CodecDecodeSelf(d) + yyv4644 := &yyv4641[yyj4641] + yyv4644.CodecDecodeSelf(d) } } else { @@ -58120,17 +58038,17 @@ func (x codecSelfer1234) decSliceVolumeMount(v *[]VolumeMount, d *codec1978.Deco } } - if yyj4650 < len(yyv4650) { - yyv4650 = yyv4650[:yyj4650] - yyc4650 = true - } else if yyj4650 == 0 && yyv4650 == nil { - yyv4650 = []VolumeMount{} - yyc4650 = true + if yyj4641 < len(yyv4641) { + yyv4641 = yyv4641[:yyj4641] + yyc4641 = true + } else if yyj4641 == 0 && yyv4641 == nil { + yyv4641 = []VolumeMount{} + yyc4641 = true } } - yyh4650.End() - if yyc4650 { - *v = yyv4650 + yyh4641.End() + if yyc4641 { + *v = yyv4641 } } @@ -58139,10 +58057,10 @@ func (x codecSelfer1234) encSlicePod(v []Pod, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4654 := range v { + for _, yyv4645 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4655 := &yyv4654 - yy4655.CodecEncodeSelf(e) + yy4646 := &yyv4645 + yy4646.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58152,83 +58070,83 @@ func (x codecSelfer1234) decSlicePod(v *[]Pod, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4656 := *v - yyh4656, yyl4656 := z.DecSliceHelperStart() - var yyc4656 bool - if yyl4656 == 0 { - if yyv4656 == nil { - yyv4656 = []Pod{} - yyc4656 = true - } else if len(yyv4656) != 0 { - yyv4656 = yyv4656[:0] - yyc4656 = true + yyv4647 := *v + yyh4647, yyl4647 := z.DecSliceHelperStart() + var yyc4647 bool + if yyl4647 == 0 { + if yyv4647 == nil { + yyv4647 = []Pod{} + yyc4647 = true + } else if len(yyv4647) != 0 { + yyv4647 = yyv4647[:0] + yyc4647 = true } - } else if yyl4656 > 0 { - var yyrr4656, yyrl4656 int - var yyrt4656 bool - if yyl4656 > cap(yyv4656) { + } else if yyl4647 > 0 { + var yyrr4647, yyrl4647 int + var yyrt4647 bool + if yyl4647 > cap(yyv4647) { - yyrg4656 := len(yyv4656) > 0 - yyv24656 := yyv4656 - yyrl4656, yyrt4656 = z.DecInferLen(yyl4656, z.DecBasicHandle().MaxInitLen, 640) - if yyrt4656 { - if yyrl4656 <= cap(yyv4656) { - yyv4656 = yyv4656[:yyrl4656] + yyrg4647 := len(yyv4647) > 0 + yyv24647 := yyv4647 + yyrl4647, yyrt4647 = z.DecInferLen(yyl4647, z.DecBasicHandle().MaxInitLen, 640) + if yyrt4647 { + if yyrl4647 <= cap(yyv4647) { + yyv4647 = yyv4647[:yyrl4647] } else { - yyv4656 = make([]Pod, yyrl4656) + yyv4647 = make([]Pod, yyrl4647) } } else { - yyv4656 = make([]Pod, yyrl4656) + yyv4647 = make([]Pod, yyrl4647) } - yyc4656 = true - yyrr4656 = len(yyv4656) - if yyrg4656 { - copy(yyv4656, yyv24656) + yyc4647 = true + yyrr4647 = len(yyv4647) + if yyrg4647 { + copy(yyv4647, yyv24647) } - } else if yyl4656 != len(yyv4656) { - yyv4656 = yyv4656[:yyl4656] - yyc4656 = true + } else if yyl4647 != len(yyv4647) { + yyv4647 = yyv4647[:yyl4647] + yyc4647 = true } - yyj4656 := 0 - for ; yyj4656 < yyrr4656; yyj4656++ { - yyh4656.ElemContainerState(yyj4656) + yyj4647 := 0 + for ; yyj4647 < yyrr4647; yyj4647++ { + yyh4647.ElemContainerState(yyj4647) if r.TryDecodeAsNil() { - yyv4656[yyj4656] = Pod{} + yyv4647[yyj4647] = Pod{} } else { - yyv4657 := &yyv4656[yyj4656] - yyv4657.CodecDecodeSelf(d) + yyv4648 := &yyv4647[yyj4647] + yyv4648.CodecDecodeSelf(d) } } - if yyrt4656 { - for ; yyj4656 < yyl4656; yyj4656++ { - yyv4656 = append(yyv4656, Pod{}) - yyh4656.ElemContainerState(yyj4656) + if yyrt4647 { + for ; yyj4647 < yyl4647; yyj4647++ { + yyv4647 = append(yyv4647, Pod{}) + yyh4647.ElemContainerState(yyj4647) if r.TryDecodeAsNil() { - yyv4656[yyj4656] = Pod{} + yyv4647[yyj4647] = Pod{} } else { - yyv4658 := &yyv4656[yyj4656] - yyv4658.CodecDecodeSelf(d) + yyv4649 := &yyv4647[yyj4647] + yyv4649.CodecDecodeSelf(d) } } } } else { - yyj4656 := 0 - for ; !r.CheckBreak(); yyj4656++ { + yyj4647 := 0 + for ; !r.CheckBreak(); yyj4647++ { - if yyj4656 >= len(yyv4656) { - yyv4656 = append(yyv4656, Pod{}) // var yyz4656 Pod - yyc4656 = true + if yyj4647 >= len(yyv4647) { + yyv4647 = append(yyv4647, Pod{}) // var yyz4647 Pod + yyc4647 = true } - yyh4656.ElemContainerState(yyj4656) - if yyj4656 < len(yyv4656) { + yyh4647.ElemContainerState(yyj4647) + if yyj4647 < len(yyv4647) { if r.TryDecodeAsNil() { - yyv4656[yyj4656] = Pod{} + yyv4647[yyj4647] = Pod{} } else { - yyv4659 := &yyv4656[yyj4656] - yyv4659.CodecDecodeSelf(d) + yyv4650 := &yyv4647[yyj4647] + yyv4650.CodecDecodeSelf(d) } } else { @@ -58236,17 +58154,17 @@ func (x codecSelfer1234) decSlicePod(v *[]Pod, d *codec1978.Decoder) { } } - if yyj4656 < len(yyv4656) { - yyv4656 = yyv4656[:yyj4656] - yyc4656 = true - } else if yyj4656 == 0 && yyv4656 == nil { - yyv4656 = []Pod{} - yyc4656 = true + if yyj4647 < len(yyv4647) { + yyv4647 = yyv4647[:yyj4647] + yyc4647 = true + } else if yyj4647 == 0 && yyv4647 == nil { + yyv4647 = []Pod{} + yyc4647 = true } } - yyh4656.End() - if yyc4656 { - *v = yyv4656 + yyh4647.End() + if yyc4647 { + *v = yyv4647 } } @@ -58255,10 +58173,10 @@ func (x codecSelfer1234) encSliceNodeSelectorTerm(v []NodeSelectorTerm, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4660 := range v { + for _, yyv4651 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4661 := &yyv4660 - yy4661.CodecEncodeSelf(e) + yy4652 := &yyv4651 + yy4652.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58268,83 +58186,83 @@ func (x codecSelfer1234) decSliceNodeSelectorTerm(v *[]NodeSelectorTerm, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4662 := *v - yyh4662, yyl4662 := z.DecSliceHelperStart() - var yyc4662 bool - if yyl4662 == 0 { - if yyv4662 == nil { - yyv4662 = []NodeSelectorTerm{} - yyc4662 = true - } else if len(yyv4662) != 0 { - yyv4662 = yyv4662[:0] - yyc4662 = true + yyv4653 := *v + yyh4653, yyl4653 := z.DecSliceHelperStart() + var yyc4653 bool + if yyl4653 == 0 { + if yyv4653 == nil { + yyv4653 = []NodeSelectorTerm{} + yyc4653 = true + } else if len(yyv4653) != 0 { + yyv4653 = yyv4653[:0] + yyc4653 = true } - } else if yyl4662 > 0 { - var yyrr4662, yyrl4662 int - var yyrt4662 bool - if yyl4662 > cap(yyv4662) { + } else if yyl4653 > 0 { + var yyrr4653, yyrl4653 int + var yyrt4653 bool + if yyl4653 > cap(yyv4653) { - yyrg4662 := len(yyv4662) > 0 - yyv24662 := yyv4662 - yyrl4662, yyrt4662 = z.DecInferLen(yyl4662, z.DecBasicHandle().MaxInitLen, 24) - if yyrt4662 { - if yyrl4662 <= cap(yyv4662) { - yyv4662 = yyv4662[:yyrl4662] + yyrg4653 := len(yyv4653) > 0 + yyv24653 := yyv4653 + yyrl4653, yyrt4653 = z.DecInferLen(yyl4653, z.DecBasicHandle().MaxInitLen, 24) + if yyrt4653 { + if yyrl4653 <= cap(yyv4653) { + yyv4653 = yyv4653[:yyrl4653] } else { - yyv4662 = make([]NodeSelectorTerm, yyrl4662) + yyv4653 = make([]NodeSelectorTerm, yyrl4653) } } else { - yyv4662 = make([]NodeSelectorTerm, yyrl4662) + yyv4653 = make([]NodeSelectorTerm, yyrl4653) } - yyc4662 = true - yyrr4662 = len(yyv4662) - if yyrg4662 { - copy(yyv4662, yyv24662) + yyc4653 = true + yyrr4653 = len(yyv4653) + if yyrg4653 { + copy(yyv4653, yyv24653) } - } else if yyl4662 != len(yyv4662) { - yyv4662 = yyv4662[:yyl4662] - yyc4662 = true + } else if yyl4653 != len(yyv4653) { + yyv4653 = yyv4653[:yyl4653] + yyc4653 = true } - yyj4662 := 0 - for ; yyj4662 < yyrr4662; yyj4662++ { - yyh4662.ElemContainerState(yyj4662) + yyj4653 := 0 + for ; yyj4653 < yyrr4653; yyj4653++ { + yyh4653.ElemContainerState(yyj4653) if r.TryDecodeAsNil() { - yyv4662[yyj4662] = NodeSelectorTerm{} + yyv4653[yyj4653] = NodeSelectorTerm{} } else { - yyv4663 := &yyv4662[yyj4662] - yyv4663.CodecDecodeSelf(d) + yyv4654 := &yyv4653[yyj4653] + yyv4654.CodecDecodeSelf(d) } } - if yyrt4662 { - for ; yyj4662 < yyl4662; yyj4662++ { - yyv4662 = append(yyv4662, NodeSelectorTerm{}) - yyh4662.ElemContainerState(yyj4662) + if yyrt4653 { + for ; yyj4653 < yyl4653; yyj4653++ { + yyv4653 = append(yyv4653, NodeSelectorTerm{}) + yyh4653.ElemContainerState(yyj4653) if r.TryDecodeAsNil() { - yyv4662[yyj4662] = NodeSelectorTerm{} + yyv4653[yyj4653] = NodeSelectorTerm{} } else { - yyv4664 := &yyv4662[yyj4662] - yyv4664.CodecDecodeSelf(d) + yyv4655 := &yyv4653[yyj4653] + yyv4655.CodecDecodeSelf(d) } } } } else { - yyj4662 := 0 - for ; !r.CheckBreak(); yyj4662++ { + yyj4653 := 0 + for ; !r.CheckBreak(); yyj4653++ { - if yyj4662 >= len(yyv4662) { - yyv4662 = append(yyv4662, NodeSelectorTerm{}) // var yyz4662 NodeSelectorTerm - yyc4662 = true + if yyj4653 >= len(yyv4653) { + yyv4653 = append(yyv4653, NodeSelectorTerm{}) // var yyz4653 NodeSelectorTerm + yyc4653 = true } - yyh4662.ElemContainerState(yyj4662) - if yyj4662 < len(yyv4662) { + yyh4653.ElemContainerState(yyj4653) + if yyj4653 < len(yyv4653) { if r.TryDecodeAsNil() { - yyv4662[yyj4662] = NodeSelectorTerm{} + yyv4653[yyj4653] = NodeSelectorTerm{} } else { - yyv4665 := &yyv4662[yyj4662] - yyv4665.CodecDecodeSelf(d) + yyv4656 := &yyv4653[yyj4653] + yyv4656.CodecDecodeSelf(d) } } else { @@ -58352,17 +58270,17 @@ func (x codecSelfer1234) decSliceNodeSelectorTerm(v *[]NodeSelectorTerm, d *code } } - if yyj4662 < len(yyv4662) { - yyv4662 = yyv4662[:yyj4662] - yyc4662 = true - } else if yyj4662 == 0 && yyv4662 == nil { - yyv4662 = []NodeSelectorTerm{} - yyc4662 = true + if yyj4653 < len(yyv4653) { + yyv4653 = yyv4653[:yyj4653] + yyc4653 = true + } else if yyj4653 == 0 && yyv4653 == nil { + yyv4653 = []NodeSelectorTerm{} + yyc4653 = true } } - yyh4662.End() - if yyc4662 { - *v = yyv4662 + yyh4653.End() + if yyc4653 { + *v = yyv4653 } } @@ -58371,10 +58289,10 @@ func (x codecSelfer1234) encSliceNodeSelectorRequirement(v []NodeSelectorRequire z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4666 := range v { + for _, yyv4657 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4667 := &yyv4666 - yy4667.CodecEncodeSelf(e) + yy4658 := &yyv4657 + yy4658.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58384,83 +58302,83 @@ func (x codecSelfer1234) decSliceNodeSelectorRequirement(v *[]NodeSelectorRequir z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4668 := *v - yyh4668, yyl4668 := z.DecSliceHelperStart() - var yyc4668 bool - if yyl4668 == 0 { - if yyv4668 == nil { - yyv4668 = []NodeSelectorRequirement{} - yyc4668 = true - } else if len(yyv4668) != 0 { - yyv4668 = yyv4668[:0] - yyc4668 = true + yyv4659 := *v + yyh4659, yyl4659 := z.DecSliceHelperStart() + var yyc4659 bool + if yyl4659 == 0 { + if yyv4659 == nil { + yyv4659 = []NodeSelectorRequirement{} + yyc4659 = true + } else if len(yyv4659) != 0 { + yyv4659 = yyv4659[:0] + yyc4659 = true } - } else if yyl4668 > 0 { - var yyrr4668, yyrl4668 int - var yyrt4668 bool - if yyl4668 > cap(yyv4668) { + } else if yyl4659 > 0 { + var yyrr4659, yyrl4659 int + var yyrt4659 bool + if yyl4659 > cap(yyv4659) { - yyrg4668 := len(yyv4668) > 0 - yyv24668 := yyv4668 - yyrl4668, yyrt4668 = z.DecInferLen(yyl4668, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4668 { - if yyrl4668 <= cap(yyv4668) { - yyv4668 = yyv4668[:yyrl4668] + yyrg4659 := len(yyv4659) > 0 + yyv24659 := yyv4659 + yyrl4659, yyrt4659 = z.DecInferLen(yyl4659, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4659 { + if yyrl4659 <= cap(yyv4659) { + yyv4659 = yyv4659[:yyrl4659] } else { - yyv4668 = make([]NodeSelectorRequirement, yyrl4668) + yyv4659 = make([]NodeSelectorRequirement, yyrl4659) } } else { - yyv4668 = make([]NodeSelectorRequirement, yyrl4668) + yyv4659 = make([]NodeSelectorRequirement, yyrl4659) } - yyc4668 = true - yyrr4668 = len(yyv4668) - if yyrg4668 { - copy(yyv4668, yyv24668) + yyc4659 = true + yyrr4659 = len(yyv4659) + if yyrg4659 { + copy(yyv4659, yyv24659) } - } else if yyl4668 != len(yyv4668) { - yyv4668 = yyv4668[:yyl4668] - yyc4668 = true + } else if yyl4659 != len(yyv4659) { + yyv4659 = yyv4659[:yyl4659] + yyc4659 = true } - yyj4668 := 0 - for ; yyj4668 < yyrr4668; yyj4668++ { - yyh4668.ElemContainerState(yyj4668) + yyj4659 := 0 + for ; yyj4659 < yyrr4659; yyj4659++ { + yyh4659.ElemContainerState(yyj4659) if r.TryDecodeAsNil() { - yyv4668[yyj4668] = NodeSelectorRequirement{} + yyv4659[yyj4659] = NodeSelectorRequirement{} } else { - yyv4669 := &yyv4668[yyj4668] - yyv4669.CodecDecodeSelf(d) + yyv4660 := &yyv4659[yyj4659] + yyv4660.CodecDecodeSelf(d) } } - if yyrt4668 { - for ; yyj4668 < yyl4668; yyj4668++ { - yyv4668 = append(yyv4668, NodeSelectorRequirement{}) - yyh4668.ElemContainerState(yyj4668) + if yyrt4659 { + for ; yyj4659 < yyl4659; yyj4659++ { + yyv4659 = append(yyv4659, NodeSelectorRequirement{}) + yyh4659.ElemContainerState(yyj4659) if r.TryDecodeAsNil() { - yyv4668[yyj4668] = NodeSelectorRequirement{} + yyv4659[yyj4659] = NodeSelectorRequirement{} } else { - yyv4670 := &yyv4668[yyj4668] - yyv4670.CodecDecodeSelf(d) + yyv4661 := &yyv4659[yyj4659] + yyv4661.CodecDecodeSelf(d) } } } } else { - yyj4668 := 0 - for ; !r.CheckBreak(); yyj4668++ { + yyj4659 := 0 + for ; !r.CheckBreak(); yyj4659++ { - if yyj4668 >= len(yyv4668) { - yyv4668 = append(yyv4668, NodeSelectorRequirement{}) // var yyz4668 NodeSelectorRequirement - yyc4668 = true + if yyj4659 >= len(yyv4659) { + yyv4659 = append(yyv4659, NodeSelectorRequirement{}) // var yyz4659 NodeSelectorRequirement + yyc4659 = true } - yyh4668.ElemContainerState(yyj4668) - if yyj4668 < len(yyv4668) { + yyh4659.ElemContainerState(yyj4659) + if yyj4659 < len(yyv4659) { if r.TryDecodeAsNil() { - yyv4668[yyj4668] = NodeSelectorRequirement{} + yyv4659[yyj4659] = NodeSelectorRequirement{} } else { - yyv4671 := &yyv4668[yyj4668] - yyv4671.CodecDecodeSelf(d) + yyv4662 := &yyv4659[yyj4659] + yyv4662.CodecDecodeSelf(d) } } else { @@ -58468,17 +58386,17 @@ func (x codecSelfer1234) decSliceNodeSelectorRequirement(v *[]NodeSelectorRequir } } - if yyj4668 < len(yyv4668) { - yyv4668 = yyv4668[:yyj4668] - yyc4668 = true - } else if yyj4668 == 0 && yyv4668 == nil { - yyv4668 = []NodeSelectorRequirement{} - yyc4668 = true + if yyj4659 < len(yyv4659) { + yyv4659 = yyv4659[:yyj4659] + yyc4659 = true + } else if yyj4659 == 0 && yyv4659 == nil { + yyv4659 = []NodeSelectorRequirement{} + yyc4659 = true } } - yyh4668.End() - if yyc4668 { - *v = yyv4668 + yyh4659.End() + if yyc4659 { + *v = yyv4659 } } @@ -58487,10 +58405,10 @@ func (x codecSelfer1234) encSlicePodAffinityTerm(v []PodAffinityTerm, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4672 := range v { + for _, yyv4663 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4673 := &yyv4672 - yy4673.CodecEncodeSelf(e) + yy4664 := &yyv4663 + yy4664.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58500,83 +58418,83 @@ func (x codecSelfer1234) decSlicePodAffinityTerm(v *[]PodAffinityTerm, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4674 := *v - yyh4674, yyl4674 := z.DecSliceHelperStart() - var yyc4674 bool - if yyl4674 == 0 { - if yyv4674 == nil { - yyv4674 = []PodAffinityTerm{} - yyc4674 = true - } else if len(yyv4674) != 0 { - yyv4674 = yyv4674[:0] - yyc4674 = true + yyv4665 := *v + yyh4665, yyl4665 := z.DecSliceHelperStart() + var yyc4665 bool + if yyl4665 == 0 { + if yyv4665 == nil { + yyv4665 = []PodAffinityTerm{} + yyc4665 = true + } else if len(yyv4665) != 0 { + yyv4665 = yyv4665[:0] + yyc4665 = true } - } else if yyl4674 > 0 { - var yyrr4674, yyrl4674 int - var yyrt4674 bool - if yyl4674 > cap(yyv4674) { + } else if yyl4665 > 0 { + var yyrr4665, yyrl4665 int + var yyrt4665 bool + if yyl4665 > cap(yyv4665) { - yyrg4674 := len(yyv4674) > 0 - yyv24674 := yyv4674 - yyrl4674, yyrt4674 = z.DecInferLen(yyl4674, z.DecBasicHandle().MaxInitLen, 48) - if yyrt4674 { - if yyrl4674 <= cap(yyv4674) { - yyv4674 = yyv4674[:yyrl4674] + yyrg4665 := len(yyv4665) > 0 + yyv24665 := yyv4665 + yyrl4665, yyrt4665 = z.DecInferLen(yyl4665, z.DecBasicHandle().MaxInitLen, 48) + if yyrt4665 { + if yyrl4665 <= cap(yyv4665) { + yyv4665 = yyv4665[:yyrl4665] } else { - yyv4674 = make([]PodAffinityTerm, yyrl4674) + yyv4665 = make([]PodAffinityTerm, yyrl4665) } } else { - yyv4674 = make([]PodAffinityTerm, yyrl4674) + yyv4665 = make([]PodAffinityTerm, yyrl4665) } - yyc4674 = true - yyrr4674 = len(yyv4674) - if yyrg4674 { - copy(yyv4674, yyv24674) + yyc4665 = true + yyrr4665 = len(yyv4665) + if yyrg4665 { + copy(yyv4665, yyv24665) } - } else if yyl4674 != len(yyv4674) { - yyv4674 = yyv4674[:yyl4674] - yyc4674 = true + } else if yyl4665 != len(yyv4665) { + yyv4665 = yyv4665[:yyl4665] + yyc4665 = true } - yyj4674 := 0 - for ; yyj4674 < yyrr4674; yyj4674++ { - yyh4674.ElemContainerState(yyj4674) + yyj4665 := 0 + for ; yyj4665 < yyrr4665; yyj4665++ { + yyh4665.ElemContainerState(yyj4665) if r.TryDecodeAsNil() { - yyv4674[yyj4674] = PodAffinityTerm{} + yyv4665[yyj4665] = PodAffinityTerm{} } else { - yyv4675 := &yyv4674[yyj4674] - yyv4675.CodecDecodeSelf(d) + yyv4666 := &yyv4665[yyj4665] + yyv4666.CodecDecodeSelf(d) } } - if yyrt4674 { - for ; yyj4674 < yyl4674; yyj4674++ { - yyv4674 = append(yyv4674, PodAffinityTerm{}) - yyh4674.ElemContainerState(yyj4674) + if yyrt4665 { + for ; yyj4665 < yyl4665; yyj4665++ { + yyv4665 = append(yyv4665, PodAffinityTerm{}) + yyh4665.ElemContainerState(yyj4665) if r.TryDecodeAsNil() { - yyv4674[yyj4674] = PodAffinityTerm{} + yyv4665[yyj4665] = PodAffinityTerm{} } else { - yyv4676 := &yyv4674[yyj4674] - yyv4676.CodecDecodeSelf(d) + yyv4667 := &yyv4665[yyj4665] + yyv4667.CodecDecodeSelf(d) } } } } else { - yyj4674 := 0 - for ; !r.CheckBreak(); yyj4674++ { + yyj4665 := 0 + for ; !r.CheckBreak(); yyj4665++ { - if yyj4674 >= len(yyv4674) { - yyv4674 = append(yyv4674, PodAffinityTerm{}) // var yyz4674 PodAffinityTerm - yyc4674 = true + if yyj4665 >= len(yyv4665) { + yyv4665 = append(yyv4665, PodAffinityTerm{}) // var yyz4665 PodAffinityTerm + yyc4665 = true } - yyh4674.ElemContainerState(yyj4674) - if yyj4674 < len(yyv4674) { + yyh4665.ElemContainerState(yyj4665) + if yyj4665 < len(yyv4665) { if r.TryDecodeAsNil() { - yyv4674[yyj4674] = PodAffinityTerm{} + yyv4665[yyj4665] = PodAffinityTerm{} } else { - yyv4677 := &yyv4674[yyj4674] - yyv4677.CodecDecodeSelf(d) + yyv4668 := &yyv4665[yyj4665] + yyv4668.CodecDecodeSelf(d) } } else { @@ -58584,17 +58502,17 @@ func (x codecSelfer1234) decSlicePodAffinityTerm(v *[]PodAffinityTerm, d *codec1 } } - if yyj4674 < len(yyv4674) { - yyv4674 = yyv4674[:yyj4674] - yyc4674 = true - } else if yyj4674 == 0 && yyv4674 == nil { - yyv4674 = []PodAffinityTerm{} - yyc4674 = true + if yyj4665 < len(yyv4665) { + yyv4665 = yyv4665[:yyj4665] + yyc4665 = true + } else if yyj4665 == 0 && yyv4665 == nil { + yyv4665 = []PodAffinityTerm{} + yyc4665 = true } } - yyh4674.End() - if yyc4674 { - *v = yyv4674 + yyh4665.End() + if yyc4665 { + *v = yyv4665 } } @@ -58603,10 +58521,10 @@ func (x codecSelfer1234) encSliceWeightedPodAffinityTerm(v []WeightedPodAffinity z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4678 := range v { + for _, yyv4669 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4679 := &yyv4678 - yy4679.CodecEncodeSelf(e) + yy4670 := &yyv4669 + yy4670.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58616,83 +58534,83 @@ func (x codecSelfer1234) decSliceWeightedPodAffinityTerm(v *[]WeightedPodAffinit z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4680 := *v - yyh4680, yyl4680 := z.DecSliceHelperStart() - var yyc4680 bool - if yyl4680 == 0 { - if yyv4680 == nil { - yyv4680 = []WeightedPodAffinityTerm{} - yyc4680 = true - } else if len(yyv4680) != 0 { - yyv4680 = yyv4680[:0] - yyc4680 = true + yyv4671 := *v + yyh4671, yyl4671 := z.DecSliceHelperStart() + var yyc4671 bool + if yyl4671 == 0 { + if yyv4671 == nil { + yyv4671 = []WeightedPodAffinityTerm{} + yyc4671 = true + } else if len(yyv4671) != 0 { + yyv4671 = yyv4671[:0] + yyc4671 = true } - } else if yyl4680 > 0 { - var yyrr4680, yyrl4680 int - var yyrt4680 bool - if yyl4680 > cap(yyv4680) { + } else if yyl4671 > 0 { + var yyrr4671, yyrl4671 int + var yyrt4671 bool + if yyl4671 > cap(yyv4671) { - yyrg4680 := len(yyv4680) > 0 - yyv24680 := yyv4680 - yyrl4680, yyrt4680 = z.DecInferLen(yyl4680, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4680 { - if yyrl4680 <= cap(yyv4680) { - yyv4680 = yyv4680[:yyrl4680] + yyrg4671 := len(yyv4671) > 0 + yyv24671 := yyv4671 + yyrl4671, yyrt4671 = z.DecInferLen(yyl4671, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4671 { + if yyrl4671 <= cap(yyv4671) { + yyv4671 = yyv4671[:yyrl4671] } else { - yyv4680 = make([]WeightedPodAffinityTerm, yyrl4680) + yyv4671 = make([]WeightedPodAffinityTerm, yyrl4671) } } else { - yyv4680 = make([]WeightedPodAffinityTerm, yyrl4680) + yyv4671 = make([]WeightedPodAffinityTerm, yyrl4671) } - yyc4680 = true - yyrr4680 = len(yyv4680) - if yyrg4680 { - copy(yyv4680, yyv24680) + yyc4671 = true + yyrr4671 = len(yyv4671) + if yyrg4671 { + copy(yyv4671, yyv24671) } - } else if yyl4680 != len(yyv4680) { - yyv4680 = yyv4680[:yyl4680] - yyc4680 = true + } else if yyl4671 != len(yyv4671) { + yyv4671 = yyv4671[:yyl4671] + yyc4671 = true } - yyj4680 := 0 - for ; yyj4680 < yyrr4680; yyj4680++ { - yyh4680.ElemContainerState(yyj4680) + yyj4671 := 0 + for ; yyj4671 < yyrr4671; yyj4671++ { + yyh4671.ElemContainerState(yyj4671) if r.TryDecodeAsNil() { - yyv4680[yyj4680] = WeightedPodAffinityTerm{} + yyv4671[yyj4671] = WeightedPodAffinityTerm{} } else { - yyv4681 := &yyv4680[yyj4680] - yyv4681.CodecDecodeSelf(d) + yyv4672 := &yyv4671[yyj4671] + yyv4672.CodecDecodeSelf(d) } } - if yyrt4680 { - for ; yyj4680 < yyl4680; yyj4680++ { - yyv4680 = append(yyv4680, WeightedPodAffinityTerm{}) - yyh4680.ElemContainerState(yyj4680) + if yyrt4671 { + for ; yyj4671 < yyl4671; yyj4671++ { + yyv4671 = append(yyv4671, WeightedPodAffinityTerm{}) + yyh4671.ElemContainerState(yyj4671) if r.TryDecodeAsNil() { - yyv4680[yyj4680] = WeightedPodAffinityTerm{} + yyv4671[yyj4671] = WeightedPodAffinityTerm{} } else { - yyv4682 := &yyv4680[yyj4680] - yyv4682.CodecDecodeSelf(d) + yyv4673 := &yyv4671[yyj4671] + yyv4673.CodecDecodeSelf(d) } } } } else { - yyj4680 := 0 - for ; !r.CheckBreak(); yyj4680++ { + yyj4671 := 0 + for ; !r.CheckBreak(); yyj4671++ { - if yyj4680 >= len(yyv4680) { - yyv4680 = append(yyv4680, WeightedPodAffinityTerm{}) // var yyz4680 WeightedPodAffinityTerm - yyc4680 = true + if yyj4671 >= len(yyv4671) { + yyv4671 = append(yyv4671, WeightedPodAffinityTerm{}) // var yyz4671 WeightedPodAffinityTerm + yyc4671 = true } - yyh4680.ElemContainerState(yyj4680) - if yyj4680 < len(yyv4680) { + yyh4671.ElemContainerState(yyj4671) + if yyj4671 < len(yyv4671) { if r.TryDecodeAsNil() { - yyv4680[yyj4680] = WeightedPodAffinityTerm{} + yyv4671[yyj4671] = WeightedPodAffinityTerm{} } else { - yyv4683 := &yyv4680[yyj4680] - yyv4683.CodecDecodeSelf(d) + yyv4674 := &yyv4671[yyj4671] + yyv4674.CodecDecodeSelf(d) } } else { @@ -58700,17 +58618,17 @@ func (x codecSelfer1234) decSliceWeightedPodAffinityTerm(v *[]WeightedPodAffinit } } - if yyj4680 < len(yyv4680) { - yyv4680 = yyv4680[:yyj4680] - yyc4680 = true - } else if yyj4680 == 0 && yyv4680 == nil { - yyv4680 = []WeightedPodAffinityTerm{} - yyc4680 = true + if yyj4671 < len(yyv4671) { + yyv4671 = yyv4671[:yyj4671] + yyc4671 = true + } else if yyj4671 == 0 && yyv4671 == nil { + yyv4671 = []WeightedPodAffinityTerm{} + yyc4671 = true } } - yyh4680.End() - if yyc4680 { - *v = yyv4680 + yyh4671.End() + if yyc4671 { + *v = yyv4671 } } @@ -58719,10 +58637,10 @@ func (x codecSelfer1234) encSlicePreferredSchedulingTerm(v []PreferredScheduling z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4684 := range v { + for _, yyv4675 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4685 := &yyv4684 - yy4685.CodecEncodeSelf(e) + yy4676 := &yyv4675 + yy4676.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58732,83 +58650,83 @@ func (x codecSelfer1234) decSlicePreferredSchedulingTerm(v *[]PreferredSchedulin z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4686 := *v - yyh4686, yyl4686 := z.DecSliceHelperStart() - var yyc4686 bool - if yyl4686 == 0 { - if yyv4686 == nil { - yyv4686 = []PreferredSchedulingTerm{} - yyc4686 = true - } else if len(yyv4686) != 0 { - yyv4686 = yyv4686[:0] - yyc4686 = true + yyv4677 := *v + yyh4677, yyl4677 := z.DecSliceHelperStart() + var yyc4677 bool + if yyl4677 == 0 { + if yyv4677 == nil { + yyv4677 = []PreferredSchedulingTerm{} + yyc4677 = true + } else if len(yyv4677) != 0 { + yyv4677 = yyv4677[:0] + yyc4677 = true } - } else if yyl4686 > 0 { - var yyrr4686, yyrl4686 int - var yyrt4686 bool - if yyl4686 > cap(yyv4686) { + } else if yyl4677 > 0 { + var yyrr4677, yyrl4677 int + var yyrt4677 bool + if yyl4677 > cap(yyv4677) { - yyrg4686 := len(yyv4686) > 0 - yyv24686 := yyv4686 - yyrl4686, yyrt4686 = z.DecInferLen(yyl4686, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4686 { - if yyrl4686 <= cap(yyv4686) { - yyv4686 = yyv4686[:yyrl4686] + yyrg4677 := len(yyv4677) > 0 + yyv24677 := yyv4677 + yyrl4677, yyrt4677 = z.DecInferLen(yyl4677, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4677 { + if yyrl4677 <= cap(yyv4677) { + yyv4677 = yyv4677[:yyrl4677] } else { - yyv4686 = make([]PreferredSchedulingTerm, yyrl4686) + yyv4677 = make([]PreferredSchedulingTerm, yyrl4677) } } else { - yyv4686 = make([]PreferredSchedulingTerm, yyrl4686) + yyv4677 = make([]PreferredSchedulingTerm, yyrl4677) } - yyc4686 = true - yyrr4686 = len(yyv4686) - if yyrg4686 { - copy(yyv4686, yyv24686) + yyc4677 = true + yyrr4677 = len(yyv4677) + if yyrg4677 { + copy(yyv4677, yyv24677) } - } else if yyl4686 != len(yyv4686) { - yyv4686 = yyv4686[:yyl4686] - yyc4686 = true + } else if yyl4677 != len(yyv4677) { + yyv4677 = yyv4677[:yyl4677] + yyc4677 = true } - yyj4686 := 0 - for ; yyj4686 < yyrr4686; yyj4686++ { - yyh4686.ElemContainerState(yyj4686) + yyj4677 := 0 + for ; yyj4677 < yyrr4677; yyj4677++ { + yyh4677.ElemContainerState(yyj4677) if r.TryDecodeAsNil() { - yyv4686[yyj4686] = PreferredSchedulingTerm{} + yyv4677[yyj4677] = PreferredSchedulingTerm{} } else { - yyv4687 := &yyv4686[yyj4686] - yyv4687.CodecDecodeSelf(d) + yyv4678 := &yyv4677[yyj4677] + yyv4678.CodecDecodeSelf(d) } } - if yyrt4686 { - for ; yyj4686 < yyl4686; yyj4686++ { - yyv4686 = append(yyv4686, PreferredSchedulingTerm{}) - yyh4686.ElemContainerState(yyj4686) + if yyrt4677 { + for ; yyj4677 < yyl4677; yyj4677++ { + yyv4677 = append(yyv4677, PreferredSchedulingTerm{}) + yyh4677.ElemContainerState(yyj4677) if r.TryDecodeAsNil() { - yyv4686[yyj4686] = PreferredSchedulingTerm{} + yyv4677[yyj4677] = PreferredSchedulingTerm{} } else { - yyv4688 := &yyv4686[yyj4686] - yyv4688.CodecDecodeSelf(d) + yyv4679 := &yyv4677[yyj4677] + yyv4679.CodecDecodeSelf(d) } } } } else { - yyj4686 := 0 - for ; !r.CheckBreak(); yyj4686++ { + yyj4677 := 0 + for ; !r.CheckBreak(); yyj4677++ { - if yyj4686 >= len(yyv4686) { - yyv4686 = append(yyv4686, PreferredSchedulingTerm{}) // var yyz4686 PreferredSchedulingTerm - yyc4686 = true + if yyj4677 >= len(yyv4677) { + yyv4677 = append(yyv4677, PreferredSchedulingTerm{}) // var yyz4677 PreferredSchedulingTerm + yyc4677 = true } - yyh4686.ElemContainerState(yyj4686) - if yyj4686 < len(yyv4686) { + yyh4677.ElemContainerState(yyj4677) + if yyj4677 < len(yyv4677) { if r.TryDecodeAsNil() { - yyv4686[yyj4686] = PreferredSchedulingTerm{} + yyv4677[yyj4677] = PreferredSchedulingTerm{} } else { - yyv4689 := &yyv4686[yyj4686] - yyv4689.CodecDecodeSelf(d) + yyv4680 := &yyv4677[yyj4677] + yyv4680.CodecDecodeSelf(d) } } else { @@ -58816,17 +58734,17 @@ func (x codecSelfer1234) decSlicePreferredSchedulingTerm(v *[]PreferredSchedulin } } - if yyj4686 < len(yyv4686) { - yyv4686 = yyv4686[:yyj4686] - yyc4686 = true - } else if yyj4686 == 0 && yyv4686 == nil { - yyv4686 = []PreferredSchedulingTerm{} - yyc4686 = true + if yyj4677 < len(yyv4677) { + yyv4677 = yyv4677[:yyj4677] + yyc4677 = true + } else if yyj4677 == 0 && yyv4677 == nil { + yyv4677 = []PreferredSchedulingTerm{} + yyc4677 = true } } - yyh4686.End() - if yyc4686 { - *v = yyv4686 + yyh4677.End() + if yyc4677 { + *v = yyv4677 } } @@ -58835,10 +58753,10 @@ func (x codecSelfer1234) encSliceVolume(v []Volume, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4690 := range v { + for _, yyv4681 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4691 := &yyv4690 - yy4691.CodecEncodeSelf(e) + yy4682 := &yyv4681 + yy4682.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58848,83 +58766,83 @@ func (x codecSelfer1234) decSliceVolume(v *[]Volume, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4692 := *v - yyh4692, yyl4692 := z.DecSliceHelperStart() - var yyc4692 bool - if yyl4692 == 0 { - if yyv4692 == nil { - yyv4692 = []Volume{} - yyc4692 = true - } else if len(yyv4692) != 0 { - yyv4692 = yyv4692[:0] - yyc4692 = true + yyv4683 := *v + yyh4683, yyl4683 := z.DecSliceHelperStart() + var yyc4683 bool + if yyl4683 == 0 { + if yyv4683 == nil { + yyv4683 = []Volume{} + yyc4683 = true + } else if len(yyv4683) != 0 { + yyv4683 = yyv4683[:0] + yyc4683 = true } - } else if yyl4692 > 0 { - var yyrr4692, yyrl4692 int - var yyrt4692 bool - if yyl4692 > cap(yyv4692) { + } else if yyl4683 > 0 { + var yyrr4683, yyrl4683 int + var yyrt4683 bool + if yyl4683 > cap(yyv4683) { - yyrg4692 := len(yyv4692) > 0 - yyv24692 := yyv4692 - yyrl4692, yyrt4692 = z.DecInferLen(yyl4692, z.DecBasicHandle().MaxInitLen, 192) - if yyrt4692 { - if yyrl4692 <= cap(yyv4692) { - yyv4692 = yyv4692[:yyrl4692] + yyrg4683 := len(yyv4683) > 0 + yyv24683 := yyv4683 + yyrl4683, yyrt4683 = z.DecInferLen(yyl4683, z.DecBasicHandle().MaxInitLen, 192) + if yyrt4683 { + if yyrl4683 <= cap(yyv4683) { + yyv4683 = yyv4683[:yyrl4683] } else { - yyv4692 = make([]Volume, yyrl4692) + yyv4683 = make([]Volume, yyrl4683) } } else { - yyv4692 = make([]Volume, yyrl4692) + yyv4683 = make([]Volume, yyrl4683) } - yyc4692 = true - yyrr4692 = len(yyv4692) - if yyrg4692 { - copy(yyv4692, yyv24692) + yyc4683 = true + yyrr4683 = len(yyv4683) + if yyrg4683 { + copy(yyv4683, yyv24683) } - } else if yyl4692 != len(yyv4692) { - yyv4692 = yyv4692[:yyl4692] - yyc4692 = true + } else if yyl4683 != len(yyv4683) { + yyv4683 = yyv4683[:yyl4683] + yyc4683 = true } - yyj4692 := 0 - for ; yyj4692 < yyrr4692; yyj4692++ { - yyh4692.ElemContainerState(yyj4692) + yyj4683 := 0 + for ; yyj4683 < yyrr4683; yyj4683++ { + yyh4683.ElemContainerState(yyj4683) if r.TryDecodeAsNil() { - yyv4692[yyj4692] = Volume{} + yyv4683[yyj4683] = Volume{} } else { - yyv4693 := &yyv4692[yyj4692] - yyv4693.CodecDecodeSelf(d) + yyv4684 := &yyv4683[yyj4683] + yyv4684.CodecDecodeSelf(d) } } - if yyrt4692 { - for ; yyj4692 < yyl4692; yyj4692++ { - yyv4692 = append(yyv4692, Volume{}) - yyh4692.ElemContainerState(yyj4692) + if yyrt4683 { + for ; yyj4683 < yyl4683; yyj4683++ { + yyv4683 = append(yyv4683, Volume{}) + yyh4683.ElemContainerState(yyj4683) if r.TryDecodeAsNil() { - yyv4692[yyj4692] = Volume{} + yyv4683[yyj4683] = Volume{} } else { - yyv4694 := &yyv4692[yyj4692] - yyv4694.CodecDecodeSelf(d) + yyv4685 := &yyv4683[yyj4683] + yyv4685.CodecDecodeSelf(d) } } } } else { - yyj4692 := 0 - for ; !r.CheckBreak(); yyj4692++ { + yyj4683 := 0 + for ; !r.CheckBreak(); yyj4683++ { - if yyj4692 >= len(yyv4692) { - yyv4692 = append(yyv4692, Volume{}) // var yyz4692 Volume - yyc4692 = true + if yyj4683 >= len(yyv4683) { + yyv4683 = append(yyv4683, Volume{}) // var yyz4683 Volume + yyc4683 = true } - yyh4692.ElemContainerState(yyj4692) - if yyj4692 < len(yyv4692) { + yyh4683.ElemContainerState(yyj4683) + if yyj4683 < len(yyv4683) { if r.TryDecodeAsNil() { - yyv4692[yyj4692] = Volume{} + yyv4683[yyj4683] = Volume{} } else { - yyv4695 := &yyv4692[yyj4692] - yyv4695.CodecDecodeSelf(d) + yyv4686 := &yyv4683[yyj4683] + yyv4686.CodecDecodeSelf(d) } } else { @@ -58932,17 +58850,17 @@ func (x codecSelfer1234) decSliceVolume(v *[]Volume, d *codec1978.Decoder) { } } - if yyj4692 < len(yyv4692) { - yyv4692 = yyv4692[:yyj4692] - yyc4692 = true - } else if yyj4692 == 0 && yyv4692 == nil { - yyv4692 = []Volume{} - yyc4692 = true + if yyj4683 < len(yyv4683) { + yyv4683 = yyv4683[:yyj4683] + yyc4683 = true + } else if yyj4683 == 0 && yyv4683 == nil { + yyv4683 = []Volume{} + yyc4683 = true } } - yyh4692.End() - if yyc4692 { - *v = yyv4692 + yyh4683.End() + if yyc4683 { + *v = yyv4683 } } @@ -58951,10 +58869,10 @@ func (x codecSelfer1234) encSliceContainer(v []Container, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4696 := range v { + for _, yyv4687 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4697 := &yyv4696 - yy4697.CodecEncodeSelf(e) + yy4688 := &yyv4687 + yy4688.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58964,83 +58882,83 @@ func (x codecSelfer1234) decSliceContainer(v *[]Container, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4698 := *v - yyh4698, yyl4698 := z.DecSliceHelperStart() - var yyc4698 bool - if yyl4698 == 0 { - if yyv4698 == nil { - yyv4698 = []Container{} - yyc4698 = true - } else if len(yyv4698) != 0 { - yyv4698 = yyv4698[:0] - yyc4698 = true + yyv4689 := *v + yyh4689, yyl4689 := z.DecSliceHelperStart() + var yyc4689 bool + if yyl4689 == 0 { + if yyv4689 == nil { + yyv4689 = []Container{} + yyc4689 = true + } else if len(yyv4689) != 0 { + yyv4689 = yyv4689[:0] + yyc4689 = true } - } else if yyl4698 > 0 { - var yyrr4698, yyrl4698 int - var yyrt4698 bool - if yyl4698 > cap(yyv4698) { + } else if yyl4689 > 0 { + var yyrr4689, yyrl4689 int + var yyrt4689 bool + if yyl4689 > cap(yyv4689) { - yyrg4698 := len(yyv4698) > 0 - yyv24698 := yyv4698 - yyrl4698, yyrt4698 = z.DecInferLen(yyl4698, z.DecBasicHandle().MaxInitLen, 256) - if yyrt4698 { - if yyrl4698 <= cap(yyv4698) { - yyv4698 = yyv4698[:yyrl4698] + yyrg4689 := len(yyv4689) > 0 + yyv24689 := yyv4689 + yyrl4689, yyrt4689 = z.DecInferLen(yyl4689, z.DecBasicHandle().MaxInitLen, 256) + if yyrt4689 { + if yyrl4689 <= cap(yyv4689) { + yyv4689 = yyv4689[:yyrl4689] } else { - yyv4698 = make([]Container, yyrl4698) + yyv4689 = make([]Container, yyrl4689) } } else { - yyv4698 = make([]Container, yyrl4698) + yyv4689 = make([]Container, yyrl4689) } - yyc4698 = true - yyrr4698 = len(yyv4698) - if yyrg4698 { - copy(yyv4698, yyv24698) + yyc4689 = true + yyrr4689 = len(yyv4689) + if yyrg4689 { + copy(yyv4689, yyv24689) } - } else if yyl4698 != len(yyv4698) { - yyv4698 = yyv4698[:yyl4698] - yyc4698 = true + } else if yyl4689 != len(yyv4689) { + yyv4689 = yyv4689[:yyl4689] + yyc4689 = true } - yyj4698 := 0 - for ; yyj4698 < yyrr4698; yyj4698++ { - yyh4698.ElemContainerState(yyj4698) + yyj4689 := 0 + for ; yyj4689 < yyrr4689; yyj4689++ { + yyh4689.ElemContainerState(yyj4689) if r.TryDecodeAsNil() { - yyv4698[yyj4698] = Container{} + yyv4689[yyj4689] = Container{} } else { - yyv4699 := &yyv4698[yyj4698] - yyv4699.CodecDecodeSelf(d) + yyv4690 := &yyv4689[yyj4689] + yyv4690.CodecDecodeSelf(d) } } - if yyrt4698 { - for ; yyj4698 < yyl4698; yyj4698++ { - yyv4698 = append(yyv4698, Container{}) - yyh4698.ElemContainerState(yyj4698) + if yyrt4689 { + for ; yyj4689 < yyl4689; yyj4689++ { + yyv4689 = append(yyv4689, Container{}) + yyh4689.ElemContainerState(yyj4689) if r.TryDecodeAsNil() { - yyv4698[yyj4698] = Container{} + yyv4689[yyj4689] = Container{} } else { - yyv4700 := &yyv4698[yyj4698] - yyv4700.CodecDecodeSelf(d) + yyv4691 := &yyv4689[yyj4689] + yyv4691.CodecDecodeSelf(d) } } } } else { - yyj4698 := 0 - for ; !r.CheckBreak(); yyj4698++ { + yyj4689 := 0 + for ; !r.CheckBreak(); yyj4689++ { - if yyj4698 >= len(yyv4698) { - yyv4698 = append(yyv4698, Container{}) // var yyz4698 Container - yyc4698 = true + if yyj4689 >= len(yyv4689) { + yyv4689 = append(yyv4689, Container{}) // var yyz4689 Container + yyc4689 = true } - yyh4698.ElemContainerState(yyj4698) - if yyj4698 < len(yyv4698) { + yyh4689.ElemContainerState(yyj4689) + if yyj4689 < len(yyv4689) { if r.TryDecodeAsNil() { - yyv4698[yyj4698] = Container{} + yyv4689[yyj4689] = Container{} } else { - yyv4701 := &yyv4698[yyj4698] - yyv4701.CodecDecodeSelf(d) + yyv4692 := &yyv4689[yyj4689] + yyv4692.CodecDecodeSelf(d) } } else { @@ -59048,17 +58966,17 @@ func (x codecSelfer1234) decSliceContainer(v *[]Container, d *codec1978.Decoder) } } - if yyj4698 < len(yyv4698) { - yyv4698 = yyv4698[:yyj4698] - yyc4698 = true - } else if yyj4698 == 0 && yyv4698 == nil { - yyv4698 = []Container{} - yyc4698 = true + if yyj4689 < len(yyv4689) { + yyv4689 = yyv4689[:yyj4689] + yyc4689 = true + } else if yyj4689 == 0 && yyv4689 == nil { + yyv4689 = []Container{} + yyc4689 = true } } - yyh4698.End() - if yyc4698 { - *v = yyv4698 + yyh4689.End() + if yyc4689 { + *v = yyv4689 } } @@ -59067,10 +58985,10 @@ func (x codecSelfer1234) encSliceLocalObjectReference(v []LocalObjectReference, z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4702 := range v { + for _, yyv4693 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4703 := &yyv4702 - yy4703.CodecEncodeSelf(e) + yy4694 := &yyv4693 + yy4694.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59080,83 +58998,83 @@ func (x codecSelfer1234) decSliceLocalObjectReference(v *[]LocalObjectReference, z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4704 := *v - yyh4704, yyl4704 := z.DecSliceHelperStart() - var yyc4704 bool - if yyl4704 == 0 { - if yyv4704 == nil { - yyv4704 = []LocalObjectReference{} - yyc4704 = true - } else if len(yyv4704) != 0 { - yyv4704 = yyv4704[:0] - yyc4704 = true + yyv4695 := *v + yyh4695, yyl4695 := z.DecSliceHelperStart() + var yyc4695 bool + if yyl4695 == 0 { + if yyv4695 == nil { + yyv4695 = []LocalObjectReference{} + yyc4695 = true + } else if len(yyv4695) != 0 { + yyv4695 = yyv4695[:0] + yyc4695 = true } - } else if yyl4704 > 0 { - var yyrr4704, yyrl4704 int - var yyrt4704 bool - if yyl4704 > cap(yyv4704) { + } else if yyl4695 > 0 { + var yyrr4695, yyrl4695 int + var yyrt4695 bool + if yyl4695 > cap(yyv4695) { - yyrg4704 := len(yyv4704) > 0 - yyv24704 := yyv4704 - yyrl4704, yyrt4704 = z.DecInferLen(yyl4704, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4704 { - if yyrl4704 <= cap(yyv4704) { - yyv4704 = yyv4704[:yyrl4704] + yyrg4695 := len(yyv4695) > 0 + yyv24695 := yyv4695 + yyrl4695, yyrt4695 = z.DecInferLen(yyl4695, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4695 { + if yyrl4695 <= cap(yyv4695) { + yyv4695 = yyv4695[:yyrl4695] } else { - yyv4704 = make([]LocalObjectReference, yyrl4704) + yyv4695 = make([]LocalObjectReference, yyrl4695) } } else { - yyv4704 = make([]LocalObjectReference, yyrl4704) + yyv4695 = make([]LocalObjectReference, yyrl4695) } - yyc4704 = true - yyrr4704 = len(yyv4704) - if yyrg4704 { - copy(yyv4704, yyv24704) + yyc4695 = true + yyrr4695 = len(yyv4695) + if yyrg4695 { + copy(yyv4695, yyv24695) } - } else if yyl4704 != len(yyv4704) { - yyv4704 = yyv4704[:yyl4704] - yyc4704 = true + } else if yyl4695 != len(yyv4695) { + yyv4695 = yyv4695[:yyl4695] + yyc4695 = true } - yyj4704 := 0 - for ; yyj4704 < yyrr4704; yyj4704++ { - yyh4704.ElemContainerState(yyj4704) + yyj4695 := 0 + for ; yyj4695 < yyrr4695; yyj4695++ { + yyh4695.ElemContainerState(yyj4695) if r.TryDecodeAsNil() { - yyv4704[yyj4704] = LocalObjectReference{} + yyv4695[yyj4695] = LocalObjectReference{} } else { - yyv4705 := &yyv4704[yyj4704] - yyv4705.CodecDecodeSelf(d) + yyv4696 := &yyv4695[yyj4695] + yyv4696.CodecDecodeSelf(d) } } - if yyrt4704 { - for ; yyj4704 < yyl4704; yyj4704++ { - yyv4704 = append(yyv4704, LocalObjectReference{}) - yyh4704.ElemContainerState(yyj4704) + if yyrt4695 { + for ; yyj4695 < yyl4695; yyj4695++ { + yyv4695 = append(yyv4695, LocalObjectReference{}) + yyh4695.ElemContainerState(yyj4695) if r.TryDecodeAsNil() { - yyv4704[yyj4704] = LocalObjectReference{} + yyv4695[yyj4695] = LocalObjectReference{} } else { - yyv4706 := &yyv4704[yyj4704] - yyv4706.CodecDecodeSelf(d) + yyv4697 := &yyv4695[yyj4695] + yyv4697.CodecDecodeSelf(d) } } } } else { - yyj4704 := 0 - for ; !r.CheckBreak(); yyj4704++ { + yyj4695 := 0 + for ; !r.CheckBreak(); yyj4695++ { - if yyj4704 >= len(yyv4704) { - yyv4704 = append(yyv4704, LocalObjectReference{}) // var yyz4704 LocalObjectReference - yyc4704 = true + if yyj4695 >= len(yyv4695) { + yyv4695 = append(yyv4695, LocalObjectReference{}) // var yyz4695 LocalObjectReference + yyc4695 = true } - yyh4704.ElemContainerState(yyj4704) - if yyj4704 < len(yyv4704) { + yyh4695.ElemContainerState(yyj4695) + if yyj4695 < len(yyv4695) { if r.TryDecodeAsNil() { - yyv4704[yyj4704] = LocalObjectReference{} + yyv4695[yyj4695] = LocalObjectReference{} } else { - yyv4707 := &yyv4704[yyj4704] - yyv4707.CodecDecodeSelf(d) + yyv4698 := &yyv4695[yyj4695] + yyv4698.CodecDecodeSelf(d) } } else { @@ -59164,17 +59082,17 @@ func (x codecSelfer1234) decSliceLocalObjectReference(v *[]LocalObjectReference, } } - if yyj4704 < len(yyv4704) { - yyv4704 = yyv4704[:yyj4704] - yyc4704 = true - } else if yyj4704 == 0 && yyv4704 == nil { - yyv4704 = []LocalObjectReference{} - yyc4704 = true + if yyj4695 < len(yyv4695) { + yyv4695 = yyv4695[:yyj4695] + yyc4695 = true + } else if yyj4695 == 0 && yyv4695 == nil { + yyv4695 = []LocalObjectReference{} + yyc4695 = true } } - yyh4704.End() - if yyc4704 { - *v = yyv4704 + yyh4695.End() + if yyc4695 { + *v = yyv4695 } } @@ -59183,10 +59101,10 @@ func (x codecSelfer1234) encSlicePodCondition(v []PodCondition, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4708 := range v { + for _, yyv4699 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4709 := &yyv4708 - yy4709.CodecEncodeSelf(e) + yy4700 := &yyv4699 + yy4700.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59196,83 +59114,83 @@ func (x codecSelfer1234) decSlicePodCondition(v *[]PodCondition, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4710 := *v - yyh4710, yyl4710 := z.DecSliceHelperStart() - var yyc4710 bool - if yyl4710 == 0 { - if yyv4710 == nil { - yyv4710 = []PodCondition{} - yyc4710 = true - } else if len(yyv4710) != 0 { - yyv4710 = yyv4710[:0] - yyc4710 = true + yyv4701 := *v + yyh4701, yyl4701 := z.DecSliceHelperStart() + var yyc4701 bool + if yyl4701 == 0 { + if yyv4701 == nil { + yyv4701 = []PodCondition{} + yyc4701 = true + } else if len(yyv4701) != 0 { + yyv4701 = yyv4701[:0] + yyc4701 = true } - } else if yyl4710 > 0 { - var yyrr4710, yyrl4710 int - var yyrt4710 bool - if yyl4710 > cap(yyv4710) { + } else if yyl4701 > 0 { + var yyrr4701, yyrl4701 int + var yyrt4701 bool + if yyl4701 > cap(yyv4701) { - yyrg4710 := len(yyv4710) > 0 - yyv24710 := yyv4710 - yyrl4710, yyrt4710 = z.DecInferLen(yyl4710, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4710 { - if yyrl4710 <= cap(yyv4710) { - yyv4710 = yyv4710[:yyrl4710] + yyrg4701 := len(yyv4701) > 0 + yyv24701 := yyv4701 + yyrl4701, yyrt4701 = z.DecInferLen(yyl4701, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4701 { + if yyrl4701 <= cap(yyv4701) { + yyv4701 = yyv4701[:yyrl4701] } else { - yyv4710 = make([]PodCondition, yyrl4710) + yyv4701 = make([]PodCondition, yyrl4701) } } else { - yyv4710 = make([]PodCondition, yyrl4710) + yyv4701 = make([]PodCondition, yyrl4701) } - yyc4710 = true - yyrr4710 = len(yyv4710) - if yyrg4710 { - copy(yyv4710, yyv24710) + yyc4701 = true + yyrr4701 = len(yyv4701) + if yyrg4701 { + copy(yyv4701, yyv24701) } - } else if yyl4710 != len(yyv4710) { - yyv4710 = yyv4710[:yyl4710] - yyc4710 = true + } else if yyl4701 != len(yyv4701) { + yyv4701 = yyv4701[:yyl4701] + yyc4701 = true } - yyj4710 := 0 - for ; yyj4710 < yyrr4710; yyj4710++ { - yyh4710.ElemContainerState(yyj4710) + yyj4701 := 0 + for ; yyj4701 < yyrr4701; yyj4701++ { + yyh4701.ElemContainerState(yyj4701) if r.TryDecodeAsNil() { - yyv4710[yyj4710] = PodCondition{} + yyv4701[yyj4701] = PodCondition{} } else { - yyv4711 := &yyv4710[yyj4710] - yyv4711.CodecDecodeSelf(d) + yyv4702 := &yyv4701[yyj4701] + yyv4702.CodecDecodeSelf(d) } } - if yyrt4710 { - for ; yyj4710 < yyl4710; yyj4710++ { - yyv4710 = append(yyv4710, PodCondition{}) - yyh4710.ElemContainerState(yyj4710) + if yyrt4701 { + for ; yyj4701 < yyl4701; yyj4701++ { + yyv4701 = append(yyv4701, PodCondition{}) + yyh4701.ElemContainerState(yyj4701) if r.TryDecodeAsNil() { - yyv4710[yyj4710] = PodCondition{} + yyv4701[yyj4701] = PodCondition{} } else { - yyv4712 := &yyv4710[yyj4710] - yyv4712.CodecDecodeSelf(d) + yyv4703 := &yyv4701[yyj4701] + yyv4703.CodecDecodeSelf(d) } } } } else { - yyj4710 := 0 - for ; !r.CheckBreak(); yyj4710++ { + yyj4701 := 0 + for ; !r.CheckBreak(); yyj4701++ { - if yyj4710 >= len(yyv4710) { - yyv4710 = append(yyv4710, PodCondition{}) // var yyz4710 PodCondition - yyc4710 = true + if yyj4701 >= len(yyv4701) { + yyv4701 = append(yyv4701, PodCondition{}) // var yyz4701 PodCondition + yyc4701 = true } - yyh4710.ElemContainerState(yyj4710) - if yyj4710 < len(yyv4710) { + yyh4701.ElemContainerState(yyj4701) + if yyj4701 < len(yyv4701) { if r.TryDecodeAsNil() { - yyv4710[yyj4710] = PodCondition{} + yyv4701[yyj4701] = PodCondition{} } else { - yyv4713 := &yyv4710[yyj4710] - yyv4713.CodecDecodeSelf(d) + yyv4704 := &yyv4701[yyj4701] + yyv4704.CodecDecodeSelf(d) } } else { @@ -59280,17 +59198,17 @@ func (x codecSelfer1234) decSlicePodCondition(v *[]PodCondition, d *codec1978.De } } - if yyj4710 < len(yyv4710) { - yyv4710 = yyv4710[:yyj4710] - yyc4710 = true - } else if yyj4710 == 0 && yyv4710 == nil { - yyv4710 = []PodCondition{} - yyc4710 = true + if yyj4701 < len(yyv4701) { + yyv4701 = yyv4701[:yyj4701] + yyc4701 = true + } else if yyj4701 == 0 && yyv4701 == nil { + yyv4701 = []PodCondition{} + yyc4701 = true } } - yyh4710.End() - if yyc4710 { - *v = yyv4710 + yyh4701.End() + if yyc4701 { + *v = yyv4701 } } @@ -59299,10 +59217,10 @@ func (x codecSelfer1234) encSliceContainerStatus(v []ContainerStatus, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4714 := range v { + for _, yyv4705 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4715 := &yyv4714 - yy4715.CodecEncodeSelf(e) + yy4706 := &yyv4705 + yy4706.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59312,83 +59230,83 @@ func (x codecSelfer1234) decSliceContainerStatus(v *[]ContainerStatus, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4716 := *v - yyh4716, yyl4716 := z.DecSliceHelperStart() - var yyc4716 bool - if yyl4716 == 0 { - if yyv4716 == nil { - yyv4716 = []ContainerStatus{} - yyc4716 = true - } else if len(yyv4716) != 0 { - yyv4716 = yyv4716[:0] - yyc4716 = true + yyv4707 := *v + yyh4707, yyl4707 := z.DecSliceHelperStart() + var yyc4707 bool + if yyl4707 == 0 { + if yyv4707 == nil { + yyv4707 = []ContainerStatus{} + yyc4707 = true + } else if len(yyv4707) != 0 { + yyv4707 = yyv4707[:0] + yyc4707 = true } - } else if yyl4716 > 0 { - var yyrr4716, yyrl4716 int - var yyrt4716 bool - if yyl4716 > cap(yyv4716) { + } else if yyl4707 > 0 { + var yyrr4707, yyrl4707 int + var yyrt4707 bool + if yyl4707 > cap(yyv4707) { - yyrg4716 := len(yyv4716) > 0 - yyv24716 := yyv4716 - yyrl4716, yyrt4716 = z.DecInferLen(yyl4716, z.DecBasicHandle().MaxInitLen, 120) - if yyrt4716 { - if yyrl4716 <= cap(yyv4716) { - yyv4716 = yyv4716[:yyrl4716] + yyrg4707 := len(yyv4707) > 0 + yyv24707 := yyv4707 + yyrl4707, yyrt4707 = z.DecInferLen(yyl4707, z.DecBasicHandle().MaxInitLen, 120) + if yyrt4707 { + if yyrl4707 <= cap(yyv4707) { + yyv4707 = yyv4707[:yyrl4707] } else { - yyv4716 = make([]ContainerStatus, yyrl4716) + yyv4707 = make([]ContainerStatus, yyrl4707) } } else { - yyv4716 = make([]ContainerStatus, yyrl4716) + yyv4707 = make([]ContainerStatus, yyrl4707) } - yyc4716 = true - yyrr4716 = len(yyv4716) - if yyrg4716 { - copy(yyv4716, yyv24716) + yyc4707 = true + yyrr4707 = len(yyv4707) + if yyrg4707 { + copy(yyv4707, yyv24707) } - } else if yyl4716 != len(yyv4716) { - yyv4716 = yyv4716[:yyl4716] - yyc4716 = true + } else if yyl4707 != len(yyv4707) { + yyv4707 = yyv4707[:yyl4707] + yyc4707 = true } - yyj4716 := 0 - for ; yyj4716 < yyrr4716; yyj4716++ { - yyh4716.ElemContainerState(yyj4716) + yyj4707 := 0 + for ; yyj4707 < yyrr4707; yyj4707++ { + yyh4707.ElemContainerState(yyj4707) if r.TryDecodeAsNil() { - yyv4716[yyj4716] = ContainerStatus{} + yyv4707[yyj4707] = ContainerStatus{} } else { - yyv4717 := &yyv4716[yyj4716] - yyv4717.CodecDecodeSelf(d) + yyv4708 := &yyv4707[yyj4707] + yyv4708.CodecDecodeSelf(d) } } - if yyrt4716 { - for ; yyj4716 < yyl4716; yyj4716++ { - yyv4716 = append(yyv4716, ContainerStatus{}) - yyh4716.ElemContainerState(yyj4716) + if yyrt4707 { + for ; yyj4707 < yyl4707; yyj4707++ { + yyv4707 = append(yyv4707, ContainerStatus{}) + yyh4707.ElemContainerState(yyj4707) if r.TryDecodeAsNil() { - yyv4716[yyj4716] = ContainerStatus{} + yyv4707[yyj4707] = ContainerStatus{} } else { - yyv4718 := &yyv4716[yyj4716] - yyv4718.CodecDecodeSelf(d) + yyv4709 := &yyv4707[yyj4707] + yyv4709.CodecDecodeSelf(d) } } } } else { - yyj4716 := 0 - for ; !r.CheckBreak(); yyj4716++ { + yyj4707 := 0 + for ; !r.CheckBreak(); yyj4707++ { - if yyj4716 >= len(yyv4716) { - yyv4716 = append(yyv4716, ContainerStatus{}) // var yyz4716 ContainerStatus - yyc4716 = true + if yyj4707 >= len(yyv4707) { + yyv4707 = append(yyv4707, ContainerStatus{}) // var yyz4707 ContainerStatus + yyc4707 = true } - yyh4716.ElemContainerState(yyj4716) - if yyj4716 < len(yyv4716) { + yyh4707.ElemContainerState(yyj4707) + if yyj4707 < len(yyv4707) { if r.TryDecodeAsNil() { - yyv4716[yyj4716] = ContainerStatus{} + yyv4707[yyj4707] = ContainerStatus{} } else { - yyv4719 := &yyv4716[yyj4716] - yyv4719.CodecDecodeSelf(d) + yyv4710 := &yyv4707[yyj4707] + yyv4710.CodecDecodeSelf(d) } } else { @@ -59396,17 +59314,17 @@ func (x codecSelfer1234) decSliceContainerStatus(v *[]ContainerStatus, d *codec1 } } - if yyj4716 < len(yyv4716) { - yyv4716 = yyv4716[:yyj4716] - yyc4716 = true - } else if yyj4716 == 0 && yyv4716 == nil { - yyv4716 = []ContainerStatus{} - yyc4716 = true + if yyj4707 < len(yyv4707) { + yyv4707 = yyv4707[:yyj4707] + yyc4707 = true + } else if yyj4707 == 0 && yyv4707 == nil { + yyv4707 = []ContainerStatus{} + yyc4707 = true } } - yyh4716.End() - if yyc4716 { - *v = yyv4716 + yyh4707.End() + if yyc4707 { + *v = yyv4707 } } @@ -59415,10 +59333,10 @@ func (x codecSelfer1234) encSlicePodTemplate(v []PodTemplate, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4720 := range v { + for _, yyv4711 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4721 := &yyv4720 - yy4721.CodecEncodeSelf(e) + yy4712 := &yyv4711 + yy4712.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59428,83 +59346,83 @@ func (x codecSelfer1234) decSlicePodTemplate(v *[]PodTemplate, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4722 := *v - yyh4722, yyl4722 := z.DecSliceHelperStart() - var yyc4722 bool - if yyl4722 == 0 { - if yyv4722 == nil { - yyv4722 = []PodTemplate{} - yyc4722 = true - } else if len(yyv4722) != 0 { - yyv4722 = yyv4722[:0] - yyc4722 = true + yyv4713 := *v + yyh4713, yyl4713 := z.DecSliceHelperStart() + var yyc4713 bool + if yyl4713 == 0 { + if yyv4713 == nil { + yyv4713 = []PodTemplate{} + yyc4713 = true + } else if len(yyv4713) != 0 { + yyv4713 = yyv4713[:0] + yyc4713 = true } - } else if yyl4722 > 0 { - var yyrr4722, yyrl4722 int - var yyrt4722 bool - if yyl4722 > cap(yyv4722) { + } else if yyl4713 > 0 { + var yyrr4713, yyrl4713 int + var yyrt4713 bool + if yyl4713 > cap(yyv4713) { - yyrg4722 := len(yyv4722) > 0 - yyv24722 := yyv4722 - yyrl4722, yyrt4722 = z.DecInferLen(yyl4722, z.DecBasicHandle().MaxInitLen, 704) - if yyrt4722 { - if yyrl4722 <= cap(yyv4722) { - yyv4722 = yyv4722[:yyrl4722] + yyrg4713 := len(yyv4713) > 0 + yyv24713 := yyv4713 + yyrl4713, yyrt4713 = z.DecInferLen(yyl4713, z.DecBasicHandle().MaxInitLen, 704) + if yyrt4713 { + if yyrl4713 <= cap(yyv4713) { + yyv4713 = yyv4713[:yyrl4713] } else { - yyv4722 = make([]PodTemplate, yyrl4722) + yyv4713 = make([]PodTemplate, yyrl4713) } } else { - yyv4722 = make([]PodTemplate, yyrl4722) + yyv4713 = make([]PodTemplate, yyrl4713) } - yyc4722 = true - yyrr4722 = len(yyv4722) - if yyrg4722 { - copy(yyv4722, yyv24722) + yyc4713 = true + yyrr4713 = len(yyv4713) + if yyrg4713 { + copy(yyv4713, yyv24713) } - } else if yyl4722 != len(yyv4722) { - yyv4722 = yyv4722[:yyl4722] - yyc4722 = true + } else if yyl4713 != len(yyv4713) { + yyv4713 = yyv4713[:yyl4713] + yyc4713 = true } - yyj4722 := 0 - for ; yyj4722 < yyrr4722; yyj4722++ { - yyh4722.ElemContainerState(yyj4722) + yyj4713 := 0 + for ; yyj4713 < yyrr4713; yyj4713++ { + yyh4713.ElemContainerState(yyj4713) if r.TryDecodeAsNil() { - yyv4722[yyj4722] = PodTemplate{} + yyv4713[yyj4713] = PodTemplate{} } else { - yyv4723 := &yyv4722[yyj4722] - yyv4723.CodecDecodeSelf(d) + yyv4714 := &yyv4713[yyj4713] + yyv4714.CodecDecodeSelf(d) } } - if yyrt4722 { - for ; yyj4722 < yyl4722; yyj4722++ { - yyv4722 = append(yyv4722, PodTemplate{}) - yyh4722.ElemContainerState(yyj4722) + if yyrt4713 { + for ; yyj4713 < yyl4713; yyj4713++ { + yyv4713 = append(yyv4713, PodTemplate{}) + yyh4713.ElemContainerState(yyj4713) if r.TryDecodeAsNil() { - yyv4722[yyj4722] = PodTemplate{} + yyv4713[yyj4713] = PodTemplate{} } else { - yyv4724 := &yyv4722[yyj4722] - yyv4724.CodecDecodeSelf(d) + yyv4715 := &yyv4713[yyj4713] + yyv4715.CodecDecodeSelf(d) } } } } else { - yyj4722 := 0 - for ; !r.CheckBreak(); yyj4722++ { + yyj4713 := 0 + for ; !r.CheckBreak(); yyj4713++ { - if yyj4722 >= len(yyv4722) { - yyv4722 = append(yyv4722, PodTemplate{}) // var yyz4722 PodTemplate - yyc4722 = true + if yyj4713 >= len(yyv4713) { + yyv4713 = append(yyv4713, PodTemplate{}) // var yyz4713 PodTemplate + yyc4713 = true } - yyh4722.ElemContainerState(yyj4722) - if yyj4722 < len(yyv4722) { + yyh4713.ElemContainerState(yyj4713) + if yyj4713 < len(yyv4713) { if r.TryDecodeAsNil() { - yyv4722[yyj4722] = PodTemplate{} + yyv4713[yyj4713] = PodTemplate{} } else { - yyv4725 := &yyv4722[yyj4722] - yyv4725.CodecDecodeSelf(d) + yyv4716 := &yyv4713[yyj4713] + yyv4716.CodecDecodeSelf(d) } } else { @@ -59512,17 +59430,17 @@ func (x codecSelfer1234) decSlicePodTemplate(v *[]PodTemplate, d *codec1978.Deco } } - if yyj4722 < len(yyv4722) { - yyv4722 = yyv4722[:yyj4722] - yyc4722 = true - } else if yyj4722 == 0 && yyv4722 == nil { - yyv4722 = []PodTemplate{} - yyc4722 = true + if yyj4713 < len(yyv4713) { + yyv4713 = yyv4713[:yyj4713] + yyc4713 = true + } else if yyj4713 == 0 && yyv4713 == nil { + yyv4713 = []PodTemplate{} + yyc4713 = true } } - yyh4722.End() - if yyc4722 { - *v = yyv4722 + yyh4713.End() + if yyc4713 { + *v = yyv4713 } } @@ -59531,10 +59449,10 @@ func (x codecSelfer1234) encSliceReplicationControllerCondition(v []ReplicationC z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4726 := range v { + for _, yyv4717 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4727 := &yyv4726 - yy4727.CodecEncodeSelf(e) + yy4718 := &yyv4717 + yy4718.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59544,83 +59462,83 @@ func (x codecSelfer1234) decSliceReplicationControllerCondition(v *[]Replication z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4728 := *v - yyh4728, yyl4728 := z.DecSliceHelperStart() - var yyc4728 bool - if yyl4728 == 0 { - if yyv4728 == nil { - yyv4728 = []ReplicationControllerCondition{} - yyc4728 = true - } else if len(yyv4728) != 0 { - yyv4728 = yyv4728[:0] - yyc4728 = true + yyv4719 := *v + yyh4719, yyl4719 := z.DecSliceHelperStart() + var yyc4719 bool + if yyl4719 == 0 { + if yyv4719 == nil { + yyv4719 = []ReplicationControllerCondition{} + yyc4719 = true + } else if len(yyv4719) != 0 { + yyv4719 = yyv4719[:0] + yyc4719 = true } - } else if yyl4728 > 0 { - var yyrr4728, yyrl4728 int - var yyrt4728 bool - if yyl4728 > cap(yyv4728) { + } else if yyl4719 > 0 { + var yyrr4719, yyrl4719 int + var yyrt4719 bool + if yyl4719 > cap(yyv4719) { - yyrg4728 := len(yyv4728) > 0 - yyv24728 := yyv4728 - yyrl4728, yyrt4728 = z.DecInferLen(yyl4728, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4728 { - if yyrl4728 <= cap(yyv4728) { - yyv4728 = yyv4728[:yyrl4728] + yyrg4719 := len(yyv4719) > 0 + yyv24719 := yyv4719 + yyrl4719, yyrt4719 = z.DecInferLen(yyl4719, z.DecBasicHandle().MaxInitLen, 88) + if yyrt4719 { + if yyrl4719 <= cap(yyv4719) { + yyv4719 = yyv4719[:yyrl4719] } else { - yyv4728 = make([]ReplicationControllerCondition, yyrl4728) + yyv4719 = make([]ReplicationControllerCondition, yyrl4719) } } else { - yyv4728 = make([]ReplicationControllerCondition, yyrl4728) + yyv4719 = make([]ReplicationControllerCondition, yyrl4719) } - yyc4728 = true - yyrr4728 = len(yyv4728) - if yyrg4728 { - copy(yyv4728, yyv24728) + yyc4719 = true + yyrr4719 = len(yyv4719) + if yyrg4719 { + copy(yyv4719, yyv24719) } - } else if yyl4728 != len(yyv4728) { - yyv4728 = yyv4728[:yyl4728] - yyc4728 = true + } else if yyl4719 != len(yyv4719) { + yyv4719 = yyv4719[:yyl4719] + yyc4719 = true } - yyj4728 := 0 - for ; yyj4728 < yyrr4728; yyj4728++ { - yyh4728.ElemContainerState(yyj4728) + yyj4719 := 0 + for ; yyj4719 < yyrr4719; yyj4719++ { + yyh4719.ElemContainerState(yyj4719) if r.TryDecodeAsNil() { - yyv4728[yyj4728] = ReplicationControllerCondition{} + yyv4719[yyj4719] = ReplicationControllerCondition{} } else { - yyv4729 := &yyv4728[yyj4728] - yyv4729.CodecDecodeSelf(d) + yyv4720 := &yyv4719[yyj4719] + yyv4720.CodecDecodeSelf(d) } } - if yyrt4728 { - for ; yyj4728 < yyl4728; yyj4728++ { - yyv4728 = append(yyv4728, ReplicationControllerCondition{}) - yyh4728.ElemContainerState(yyj4728) + if yyrt4719 { + for ; yyj4719 < yyl4719; yyj4719++ { + yyv4719 = append(yyv4719, ReplicationControllerCondition{}) + yyh4719.ElemContainerState(yyj4719) if r.TryDecodeAsNil() { - yyv4728[yyj4728] = ReplicationControllerCondition{} + yyv4719[yyj4719] = ReplicationControllerCondition{} } else { - yyv4730 := &yyv4728[yyj4728] - yyv4730.CodecDecodeSelf(d) + yyv4721 := &yyv4719[yyj4719] + yyv4721.CodecDecodeSelf(d) } } } } else { - yyj4728 := 0 - for ; !r.CheckBreak(); yyj4728++ { + yyj4719 := 0 + for ; !r.CheckBreak(); yyj4719++ { - if yyj4728 >= len(yyv4728) { - yyv4728 = append(yyv4728, ReplicationControllerCondition{}) // var yyz4728 ReplicationControllerCondition - yyc4728 = true + if yyj4719 >= len(yyv4719) { + yyv4719 = append(yyv4719, ReplicationControllerCondition{}) // var yyz4719 ReplicationControllerCondition + yyc4719 = true } - yyh4728.ElemContainerState(yyj4728) - if yyj4728 < len(yyv4728) { + yyh4719.ElemContainerState(yyj4719) + if yyj4719 < len(yyv4719) { if r.TryDecodeAsNil() { - yyv4728[yyj4728] = ReplicationControllerCondition{} + yyv4719[yyj4719] = ReplicationControllerCondition{} } else { - yyv4731 := &yyv4728[yyj4728] - yyv4731.CodecDecodeSelf(d) + yyv4722 := &yyv4719[yyj4719] + yyv4722.CodecDecodeSelf(d) } } else { @@ -59628,17 +59546,17 @@ func (x codecSelfer1234) decSliceReplicationControllerCondition(v *[]Replication } } - if yyj4728 < len(yyv4728) { - yyv4728 = yyv4728[:yyj4728] - yyc4728 = true - } else if yyj4728 == 0 && yyv4728 == nil { - yyv4728 = []ReplicationControllerCondition{} - yyc4728 = true + if yyj4719 < len(yyv4719) { + yyv4719 = yyv4719[:yyj4719] + yyc4719 = true + } else if yyj4719 == 0 && yyv4719 == nil { + yyv4719 = []ReplicationControllerCondition{} + yyc4719 = true } } - yyh4728.End() - if yyc4728 { - *v = yyv4728 + yyh4719.End() + if yyc4719 { + *v = yyv4719 } } @@ -59647,10 +59565,10 @@ func (x codecSelfer1234) encSliceReplicationController(v []ReplicationController z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4732 := range v { + for _, yyv4723 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4733 := &yyv4732 - yy4733.CodecEncodeSelf(e) + yy4724 := &yyv4723 + yy4724.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59660,83 +59578,83 @@ func (x codecSelfer1234) decSliceReplicationController(v *[]ReplicationControlle z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4734 := *v - yyh4734, yyl4734 := z.DecSliceHelperStart() - var yyc4734 bool - if yyl4734 == 0 { - if yyv4734 == nil { - yyv4734 = []ReplicationController{} - yyc4734 = true - } else if len(yyv4734) != 0 { - yyv4734 = yyv4734[:0] - yyc4734 = true + yyv4725 := *v + yyh4725, yyl4725 := z.DecSliceHelperStart() + var yyc4725 bool + if yyl4725 == 0 { + if yyv4725 == nil { + yyv4725 = []ReplicationController{} + yyc4725 = true + } else if len(yyv4725) != 0 { + yyv4725 = yyv4725[:0] + yyc4725 = true } - } else if yyl4734 > 0 { - var yyrr4734, yyrl4734 int - var yyrt4734 bool - if yyl4734 > cap(yyv4734) { + } else if yyl4725 > 0 { + var yyrr4725, yyrl4725 int + var yyrt4725 bool + if yyl4725 > cap(yyv4725) { - yyrg4734 := len(yyv4734) > 0 - yyv24734 := yyv4734 - yyrl4734, yyrt4734 = z.DecInferLen(yyl4734, z.DecBasicHandle().MaxInitLen, 328) - if yyrt4734 { - if yyrl4734 <= cap(yyv4734) { - yyv4734 = yyv4734[:yyrl4734] + yyrg4725 := len(yyv4725) > 0 + yyv24725 := yyv4725 + yyrl4725, yyrt4725 = z.DecInferLen(yyl4725, z.DecBasicHandle().MaxInitLen, 328) + if yyrt4725 { + if yyrl4725 <= cap(yyv4725) { + yyv4725 = yyv4725[:yyrl4725] } else { - yyv4734 = make([]ReplicationController, yyrl4734) + yyv4725 = make([]ReplicationController, yyrl4725) } } else { - yyv4734 = make([]ReplicationController, yyrl4734) + yyv4725 = make([]ReplicationController, yyrl4725) } - yyc4734 = true - yyrr4734 = len(yyv4734) - if yyrg4734 { - copy(yyv4734, yyv24734) + yyc4725 = true + yyrr4725 = len(yyv4725) + if yyrg4725 { + copy(yyv4725, yyv24725) } - } else if yyl4734 != len(yyv4734) { - yyv4734 = yyv4734[:yyl4734] - yyc4734 = true + } else if yyl4725 != len(yyv4725) { + yyv4725 = yyv4725[:yyl4725] + yyc4725 = true } - yyj4734 := 0 - for ; yyj4734 < yyrr4734; yyj4734++ { - yyh4734.ElemContainerState(yyj4734) + yyj4725 := 0 + for ; yyj4725 < yyrr4725; yyj4725++ { + yyh4725.ElemContainerState(yyj4725) if r.TryDecodeAsNil() { - yyv4734[yyj4734] = ReplicationController{} + yyv4725[yyj4725] = ReplicationController{} } else { - yyv4735 := &yyv4734[yyj4734] - yyv4735.CodecDecodeSelf(d) + yyv4726 := &yyv4725[yyj4725] + yyv4726.CodecDecodeSelf(d) } } - if yyrt4734 { - for ; yyj4734 < yyl4734; yyj4734++ { - yyv4734 = append(yyv4734, ReplicationController{}) - yyh4734.ElemContainerState(yyj4734) + if yyrt4725 { + for ; yyj4725 < yyl4725; yyj4725++ { + yyv4725 = append(yyv4725, ReplicationController{}) + yyh4725.ElemContainerState(yyj4725) if r.TryDecodeAsNil() { - yyv4734[yyj4734] = ReplicationController{} + yyv4725[yyj4725] = ReplicationController{} } else { - yyv4736 := &yyv4734[yyj4734] - yyv4736.CodecDecodeSelf(d) + yyv4727 := &yyv4725[yyj4725] + yyv4727.CodecDecodeSelf(d) } } } } else { - yyj4734 := 0 - for ; !r.CheckBreak(); yyj4734++ { + yyj4725 := 0 + for ; !r.CheckBreak(); yyj4725++ { - if yyj4734 >= len(yyv4734) { - yyv4734 = append(yyv4734, ReplicationController{}) // var yyz4734 ReplicationController - yyc4734 = true + if yyj4725 >= len(yyv4725) { + yyv4725 = append(yyv4725, ReplicationController{}) // var yyz4725 ReplicationController + yyc4725 = true } - yyh4734.ElemContainerState(yyj4734) - if yyj4734 < len(yyv4734) { + yyh4725.ElemContainerState(yyj4725) + if yyj4725 < len(yyv4725) { if r.TryDecodeAsNil() { - yyv4734[yyj4734] = ReplicationController{} + yyv4725[yyj4725] = ReplicationController{} } else { - yyv4737 := &yyv4734[yyj4734] - yyv4737.CodecDecodeSelf(d) + yyv4728 := &yyv4725[yyj4725] + yyv4728.CodecDecodeSelf(d) } } else { @@ -59744,17 +59662,17 @@ func (x codecSelfer1234) decSliceReplicationController(v *[]ReplicationControlle } } - if yyj4734 < len(yyv4734) { - yyv4734 = yyv4734[:yyj4734] - yyc4734 = true - } else if yyj4734 == 0 && yyv4734 == nil { - yyv4734 = []ReplicationController{} - yyc4734 = true + if yyj4725 < len(yyv4725) { + yyv4725 = yyv4725[:yyj4725] + yyc4725 = true + } else if yyj4725 == 0 && yyv4725 == nil { + yyv4725 = []ReplicationController{} + yyc4725 = true } } - yyh4734.End() - if yyc4734 { - *v = yyv4734 + yyh4725.End() + if yyc4725 { + *v = yyv4725 } } @@ -59763,10 +59681,10 @@ func (x codecSelfer1234) encSliceService(v []Service, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4738 := range v { + for _, yyv4729 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4739 := &yyv4738 - yy4739.CodecEncodeSelf(e) + yy4730 := &yyv4729 + yy4730.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59776,83 +59694,83 @@ func (x codecSelfer1234) decSliceService(v *[]Service, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4740 := *v - yyh4740, yyl4740 := z.DecSliceHelperStart() - var yyc4740 bool - if yyl4740 == 0 { - if yyv4740 == nil { - yyv4740 = []Service{} - yyc4740 = true - } else if len(yyv4740) != 0 { - yyv4740 = yyv4740[:0] - yyc4740 = true + yyv4731 := *v + yyh4731, yyl4731 := z.DecSliceHelperStart() + var yyc4731 bool + if yyl4731 == 0 { + if yyv4731 == nil { + yyv4731 = []Service{} + yyc4731 = true + } else if len(yyv4731) != 0 { + yyv4731 = yyv4731[:0] + yyc4731 = true } - } else if yyl4740 > 0 { - var yyrr4740, yyrl4740 int - var yyrt4740 bool - if yyl4740 > cap(yyv4740) { + } else if yyl4731 > 0 { + var yyrr4731, yyrl4731 int + var yyrt4731 bool + if yyl4731 > cap(yyv4731) { - yyrg4740 := len(yyv4740) > 0 - yyv24740 := yyv4740 - yyrl4740, yyrt4740 = z.DecInferLen(yyl4740, z.DecBasicHandle().MaxInitLen, 440) - if yyrt4740 { - if yyrl4740 <= cap(yyv4740) { - yyv4740 = yyv4740[:yyrl4740] + yyrg4731 := len(yyv4731) > 0 + yyv24731 := yyv4731 + yyrl4731, yyrt4731 = z.DecInferLen(yyl4731, z.DecBasicHandle().MaxInitLen, 440) + if yyrt4731 { + if yyrl4731 <= cap(yyv4731) { + yyv4731 = yyv4731[:yyrl4731] } else { - yyv4740 = make([]Service, yyrl4740) + yyv4731 = make([]Service, yyrl4731) } } else { - yyv4740 = make([]Service, yyrl4740) + yyv4731 = make([]Service, yyrl4731) } - yyc4740 = true - yyrr4740 = len(yyv4740) - if yyrg4740 { - copy(yyv4740, yyv24740) + yyc4731 = true + yyrr4731 = len(yyv4731) + if yyrg4731 { + copy(yyv4731, yyv24731) } - } else if yyl4740 != len(yyv4740) { - yyv4740 = yyv4740[:yyl4740] - yyc4740 = true + } else if yyl4731 != len(yyv4731) { + yyv4731 = yyv4731[:yyl4731] + yyc4731 = true } - yyj4740 := 0 - for ; yyj4740 < yyrr4740; yyj4740++ { - yyh4740.ElemContainerState(yyj4740) + yyj4731 := 0 + for ; yyj4731 < yyrr4731; yyj4731++ { + yyh4731.ElemContainerState(yyj4731) if r.TryDecodeAsNil() { - yyv4740[yyj4740] = Service{} + yyv4731[yyj4731] = Service{} } else { - yyv4741 := &yyv4740[yyj4740] - yyv4741.CodecDecodeSelf(d) + yyv4732 := &yyv4731[yyj4731] + yyv4732.CodecDecodeSelf(d) } } - if yyrt4740 { - for ; yyj4740 < yyl4740; yyj4740++ { - yyv4740 = append(yyv4740, Service{}) - yyh4740.ElemContainerState(yyj4740) + if yyrt4731 { + for ; yyj4731 < yyl4731; yyj4731++ { + yyv4731 = append(yyv4731, Service{}) + yyh4731.ElemContainerState(yyj4731) if r.TryDecodeAsNil() { - yyv4740[yyj4740] = Service{} + yyv4731[yyj4731] = Service{} } else { - yyv4742 := &yyv4740[yyj4740] - yyv4742.CodecDecodeSelf(d) + yyv4733 := &yyv4731[yyj4731] + yyv4733.CodecDecodeSelf(d) } } } } else { - yyj4740 := 0 - for ; !r.CheckBreak(); yyj4740++ { + yyj4731 := 0 + for ; !r.CheckBreak(); yyj4731++ { - if yyj4740 >= len(yyv4740) { - yyv4740 = append(yyv4740, Service{}) // var yyz4740 Service - yyc4740 = true + if yyj4731 >= len(yyv4731) { + yyv4731 = append(yyv4731, Service{}) // var yyz4731 Service + yyc4731 = true } - yyh4740.ElemContainerState(yyj4740) - if yyj4740 < len(yyv4740) { + yyh4731.ElemContainerState(yyj4731) + if yyj4731 < len(yyv4731) { if r.TryDecodeAsNil() { - yyv4740[yyj4740] = Service{} + yyv4731[yyj4731] = Service{} } else { - yyv4743 := &yyv4740[yyj4740] - yyv4743.CodecDecodeSelf(d) + yyv4734 := &yyv4731[yyj4731] + yyv4734.CodecDecodeSelf(d) } } else { @@ -59860,17 +59778,17 @@ func (x codecSelfer1234) decSliceService(v *[]Service, d *codec1978.Decoder) { } } - if yyj4740 < len(yyv4740) { - yyv4740 = yyv4740[:yyj4740] - yyc4740 = true - } else if yyj4740 == 0 && yyv4740 == nil { - yyv4740 = []Service{} - yyc4740 = true + if yyj4731 < len(yyv4731) { + yyv4731 = yyv4731[:yyj4731] + yyc4731 = true + } else if yyj4731 == 0 && yyv4731 == nil { + yyv4731 = []Service{} + yyc4731 = true } } - yyh4740.End() - if yyc4740 { - *v = yyv4740 + yyh4731.End() + if yyc4731 { + *v = yyv4731 } } @@ -59879,10 +59797,10 @@ func (x codecSelfer1234) encSliceLoadBalancerIngress(v []LoadBalancerIngress, e z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4744 := range v { + for _, yyv4735 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4745 := &yyv4744 - yy4745.CodecEncodeSelf(e) + yy4736 := &yyv4735 + yy4736.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59892,83 +59810,83 @@ func (x codecSelfer1234) decSliceLoadBalancerIngress(v *[]LoadBalancerIngress, d z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4746 := *v - yyh4746, yyl4746 := z.DecSliceHelperStart() - var yyc4746 bool - if yyl4746 == 0 { - if yyv4746 == nil { - yyv4746 = []LoadBalancerIngress{} - yyc4746 = true - } else if len(yyv4746) != 0 { - yyv4746 = yyv4746[:0] - yyc4746 = true + yyv4737 := *v + yyh4737, yyl4737 := z.DecSliceHelperStart() + var yyc4737 bool + if yyl4737 == 0 { + if yyv4737 == nil { + yyv4737 = []LoadBalancerIngress{} + yyc4737 = true + } else if len(yyv4737) != 0 { + yyv4737 = yyv4737[:0] + yyc4737 = true } - } else if yyl4746 > 0 { - var yyrr4746, yyrl4746 int - var yyrt4746 bool - if yyl4746 > cap(yyv4746) { + } else if yyl4737 > 0 { + var yyrr4737, yyrl4737 int + var yyrt4737 bool + if yyl4737 > cap(yyv4737) { - yyrg4746 := len(yyv4746) > 0 - yyv24746 := yyv4746 - yyrl4746, yyrt4746 = z.DecInferLen(yyl4746, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4746 { - if yyrl4746 <= cap(yyv4746) { - yyv4746 = yyv4746[:yyrl4746] + yyrg4737 := len(yyv4737) > 0 + yyv24737 := yyv4737 + yyrl4737, yyrt4737 = z.DecInferLen(yyl4737, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4737 { + if yyrl4737 <= cap(yyv4737) { + yyv4737 = yyv4737[:yyrl4737] } else { - yyv4746 = make([]LoadBalancerIngress, yyrl4746) + yyv4737 = make([]LoadBalancerIngress, yyrl4737) } } else { - yyv4746 = make([]LoadBalancerIngress, yyrl4746) + yyv4737 = make([]LoadBalancerIngress, yyrl4737) } - yyc4746 = true - yyrr4746 = len(yyv4746) - if yyrg4746 { - copy(yyv4746, yyv24746) + yyc4737 = true + yyrr4737 = len(yyv4737) + if yyrg4737 { + copy(yyv4737, yyv24737) } - } else if yyl4746 != len(yyv4746) { - yyv4746 = yyv4746[:yyl4746] - yyc4746 = true + } else if yyl4737 != len(yyv4737) { + yyv4737 = yyv4737[:yyl4737] + yyc4737 = true } - yyj4746 := 0 - for ; yyj4746 < yyrr4746; yyj4746++ { - yyh4746.ElemContainerState(yyj4746) + yyj4737 := 0 + for ; yyj4737 < yyrr4737; yyj4737++ { + yyh4737.ElemContainerState(yyj4737) if r.TryDecodeAsNil() { - yyv4746[yyj4746] = LoadBalancerIngress{} + yyv4737[yyj4737] = LoadBalancerIngress{} } else { - yyv4747 := &yyv4746[yyj4746] - yyv4747.CodecDecodeSelf(d) + yyv4738 := &yyv4737[yyj4737] + yyv4738.CodecDecodeSelf(d) } } - if yyrt4746 { - for ; yyj4746 < yyl4746; yyj4746++ { - yyv4746 = append(yyv4746, LoadBalancerIngress{}) - yyh4746.ElemContainerState(yyj4746) + if yyrt4737 { + for ; yyj4737 < yyl4737; yyj4737++ { + yyv4737 = append(yyv4737, LoadBalancerIngress{}) + yyh4737.ElemContainerState(yyj4737) if r.TryDecodeAsNil() { - yyv4746[yyj4746] = LoadBalancerIngress{} + yyv4737[yyj4737] = LoadBalancerIngress{} } else { - yyv4748 := &yyv4746[yyj4746] - yyv4748.CodecDecodeSelf(d) + yyv4739 := &yyv4737[yyj4737] + yyv4739.CodecDecodeSelf(d) } } } } else { - yyj4746 := 0 - for ; !r.CheckBreak(); yyj4746++ { + yyj4737 := 0 + for ; !r.CheckBreak(); yyj4737++ { - if yyj4746 >= len(yyv4746) { - yyv4746 = append(yyv4746, LoadBalancerIngress{}) // var yyz4746 LoadBalancerIngress - yyc4746 = true + if yyj4737 >= len(yyv4737) { + yyv4737 = append(yyv4737, LoadBalancerIngress{}) // var yyz4737 LoadBalancerIngress + yyc4737 = true } - yyh4746.ElemContainerState(yyj4746) - if yyj4746 < len(yyv4746) { + yyh4737.ElemContainerState(yyj4737) + if yyj4737 < len(yyv4737) { if r.TryDecodeAsNil() { - yyv4746[yyj4746] = LoadBalancerIngress{} + yyv4737[yyj4737] = LoadBalancerIngress{} } else { - yyv4749 := &yyv4746[yyj4746] - yyv4749.CodecDecodeSelf(d) + yyv4740 := &yyv4737[yyj4737] + yyv4740.CodecDecodeSelf(d) } } else { @@ -59976,17 +59894,17 @@ func (x codecSelfer1234) decSliceLoadBalancerIngress(v *[]LoadBalancerIngress, d } } - if yyj4746 < len(yyv4746) { - yyv4746 = yyv4746[:yyj4746] - yyc4746 = true - } else if yyj4746 == 0 && yyv4746 == nil { - yyv4746 = []LoadBalancerIngress{} - yyc4746 = true + if yyj4737 < len(yyv4737) { + yyv4737 = yyv4737[:yyj4737] + yyc4737 = true + } else if yyj4737 == 0 && yyv4737 == nil { + yyv4737 = []LoadBalancerIngress{} + yyc4737 = true } } - yyh4746.End() - if yyc4746 { - *v = yyv4746 + yyh4737.End() + if yyc4737 { + *v = yyv4737 } } @@ -59995,10 +59913,10 @@ func (x codecSelfer1234) encSliceServicePort(v []ServicePort, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4750 := range v { + for _, yyv4741 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4751 := &yyv4750 - yy4751.CodecEncodeSelf(e) + yy4742 := &yyv4741 + yy4742.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60008,83 +59926,83 @@ func (x codecSelfer1234) decSliceServicePort(v *[]ServicePort, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4752 := *v - yyh4752, yyl4752 := z.DecSliceHelperStart() - var yyc4752 bool - if yyl4752 == 0 { - if yyv4752 == nil { - yyv4752 = []ServicePort{} - yyc4752 = true - } else if len(yyv4752) != 0 { - yyv4752 = yyv4752[:0] - yyc4752 = true + yyv4743 := *v + yyh4743, yyl4743 := z.DecSliceHelperStart() + var yyc4743 bool + if yyl4743 == 0 { + if yyv4743 == nil { + yyv4743 = []ServicePort{} + yyc4743 = true + } else if len(yyv4743) != 0 { + yyv4743 = yyv4743[:0] + yyc4743 = true } - } else if yyl4752 > 0 { - var yyrr4752, yyrl4752 int - var yyrt4752 bool - if yyl4752 > cap(yyv4752) { + } else if yyl4743 > 0 { + var yyrr4743, yyrl4743 int + var yyrt4743 bool + if yyl4743 > cap(yyv4743) { - yyrg4752 := len(yyv4752) > 0 - yyv24752 := yyv4752 - yyrl4752, yyrt4752 = z.DecInferLen(yyl4752, z.DecBasicHandle().MaxInitLen, 80) - if yyrt4752 { - if yyrl4752 <= cap(yyv4752) { - yyv4752 = yyv4752[:yyrl4752] + yyrg4743 := len(yyv4743) > 0 + yyv24743 := yyv4743 + yyrl4743, yyrt4743 = z.DecInferLen(yyl4743, z.DecBasicHandle().MaxInitLen, 80) + if yyrt4743 { + if yyrl4743 <= cap(yyv4743) { + yyv4743 = yyv4743[:yyrl4743] } else { - yyv4752 = make([]ServicePort, yyrl4752) + yyv4743 = make([]ServicePort, yyrl4743) } } else { - yyv4752 = make([]ServicePort, yyrl4752) + yyv4743 = make([]ServicePort, yyrl4743) } - yyc4752 = true - yyrr4752 = len(yyv4752) - if yyrg4752 { - copy(yyv4752, yyv24752) + yyc4743 = true + yyrr4743 = len(yyv4743) + if yyrg4743 { + copy(yyv4743, yyv24743) } - } else if yyl4752 != len(yyv4752) { - yyv4752 = yyv4752[:yyl4752] - yyc4752 = true + } else if yyl4743 != len(yyv4743) { + yyv4743 = yyv4743[:yyl4743] + yyc4743 = true } - yyj4752 := 0 - for ; yyj4752 < yyrr4752; yyj4752++ { - yyh4752.ElemContainerState(yyj4752) + yyj4743 := 0 + for ; yyj4743 < yyrr4743; yyj4743++ { + yyh4743.ElemContainerState(yyj4743) if r.TryDecodeAsNil() { - yyv4752[yyj4752] = ServicePort{} + yyv4743[yyj4743] = ServicePort{} } else { - yyv4753 := &yyv4752[yyj4752] - yyv4753.CodecDecodeSelf(d) + yyv4744 := &yyv4743[yyj4743] + yyv4744.CodecDecodeSelf(d) } } - if yyrt4752 { - for ; yyj4752 < yyl4752; yyj4752++ { - yyv4752 = append(yyv4752, ServicePort{}) - yyh4752.ElemContainerState(yyj4752) + if yyrt4743 { + for ; yyj4743 < yyl4743; yyj4743++ { + yyv4743 = append(yyv4743, ServicePort{}) + yyh4743.ElemContainerState(yyj4743) if r.TryDecodeAsNil() { - yyv4752[yyj4752] = ServicePort{} + yyv4743[yyj4743] = ServicePort{} } else { - yyv4754 := &yyv4752[yyj4752] - yyv4754.CodecDecodeSelf(d) + yyv4745 := &yyv4743[yyj4743] + yyv4745.CodecDecodeSelf(d) } } } } else { - yyj4752 := 0 - for ; !r.CheckBreak(); yyj4752++ { + yyj4743 := 0 + for ; !r.CheckBreak(); yyj4743++ { - if yyj4752 >= len(yyv4752) { - yyv4752 = append(yyv4752, ServicePort{}) // var yyz4752 ServicePort - yyc4752 = true + if yyj4743 >= len(yyv4743) { + yyv4743 = append(yyv4743, ServicePort{}) // var yyz4743 ServicePort + yyc4743 = true } - yyh4752.ElemContainerState(yyj4752) - if yyj4752 < len(yyv4752) { + yyh4743.ElemContainerState(yyj4743) + if yyj4743 < len(yyv4743) { if r.TryDecodeAsNil() { - yyv4752[yyj4752] = ServicePort{} + yyv4743[yyj4743] = ServicePort{} } else { - yyv4755 := &yyv4752[yyj4752] - yyv4755.CodecDecodeSelf(d) + yyv4746 := &yyv4743[yyj4743] + yyv4746.CodecDecodeSelf(d) } } else { @@ -60092,17 +60010,17 @@ func (x codecSelfer1234) decSliceServicePort(v *[]ServicePort, d *codec1978.Deco } } - if yyj4752 < len(yyv4752) { - yyv4752 = yyv4752[:yyj4752] - yyc4752 = true - } else if yyj4752 == 0 && yyv4752 == nil { - yyv4752 = []ServicePort{} - yyc4752 = true + if yyj4743 < len(yyv4743) { + yyv4743 = yyv4743[:yyj4743] + yyc4743 = true + } else if yyj4743 == 0 && yyv4743 == nil { + yyv4743 = []ServicePort{} + yyc4743 = true } } - yyh4752.End() - if yyc4752 { - *v = yyv4752 + yyh4743.End() + if yyc4743 { + *v = yyv4743 } } @@ -60111,10 +60029,10 @@ func (x codecSelfer1234) encSliceObjectReference(v []ObjectReference, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4756 := range v { + for _, yyv4747 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4757 := &yyv4756 - yy4757.CodecEncodeSelf(e) + yy4748 := &yyv4747 + yy4748.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60124,83 +60042,83 @@ func (x codecSelfer1234) decSliceObjectReference(v *[]ObjectReference, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4758 := *v - yyh4758, yyl4758 := z.DecSliceHelperStart() - var yyc4758 bool - if yyl4758 == 0 { - if yyv4758 == nil { - yyv4758 = []ObjectReference{} - yyc4758 = true - } else if len(yyv4758) != 0 { - yyv4758 = yyv4758[:0] - yyc4758 = true + yyv4749 := *v + yyh4749, yyl4749 := z.DecSliceHelperStart() + var yyc4749 bool + if yyl4749 == 0 { + if yyv4749 == nil { + yyv4749 = []ObjectReference{} + yyc4749 = true + } else if len(yyv4749) != 0 { + yyv4749 = yyv4749[:0] + yyc4749 = true } - } else if yyl4758 > 0 { - var yyrr4758, yyrl4758 int - var yyrt4758 bool - if yyl4758 > cap(yyv4758) { + } else if yyl4749 > 0 { + var yyrr4749, yyrl4749 int + var yyrt4749 bool + if yyl4749 > cap(yyv4749) { - yyrg4758 := len(yyv4758) > 0 - yyv24758 := yyv4758 - yyrl4758, yyrt4758 = z.DecInferLen(yyl4758, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4758 { - if yyrl4758 <= cap(yyv4758) { - yyv4758 = yyv4758[:yyrl4758] + yyrg4749 := len(yyv4749) > 0 + yyv24749 := yyv4749 + yyrl4749, yyrt4749 = z.DecInferLen(yyl4749, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4749 { + if yyrl4749 <= cap(yyv4749) { + yyv4749 = yyv4749[:yyrl4749] } else { - yyv4758 = make([]ObjectReference, yyrl4758) + yyv4749 = make([]ObjectReference, yyrl4749) } } else { - yyv4758 = make([]ObjectReference, yyrl4758) + yyv4749 = make([]ObjectReference, yyrl4749) } - yyc4758 = true - yyrr4758 = len(yyv4758) - if yyrg4758 { - copy(yyv4758, yyv24758) + yyc4749 = true + yyrr4749 = len(yyv4749) + if yyrg4749 { + copy(yyv4749, yyv24749) } - } else if yyl4758 != len(yyv4758) { - yyv4758 = yyv4758[:yyl4758] - yyc4758 = true + } else if yyl4749 != len(yyv4749) { + yyv4749 = yyv4749[:yyl4749] + yyc4749 = true } - yyj4758 := 0 - for ; yyj4758 < yyrr4758; yyj4758++ { - yyh4758.ElemContainerState(yyj4758) + yyj4749 := 0 + for ; yyj4749 < yyrr4749; yyj4749++ { + yyh4749.ElemContainerState(yyj4749) if r.TryDecodeAsNil() { - yyv4758[yyj4758] = ObjectReference{} + yyv4749[yyj4749] = ObjectReference{} } else { - yyv4759 := &yyv4758[yyj4758] - yyv4759.CodecDecodeSelf(d) + yyv4750 := &yyv4749[yyj4749] + yyv4750.CodecDecodeSelf(d) } } - if yyrt4758 { - for ; yyj4758 < yyl4758; yyj4758++ { - yyv4758 = append(yyv4758, ObjectReference{}) - yyh4758.ElemContainerState(yyj4758) + if yyrt4749 { + for ; yyj4749 < yyl4749; yyj4749++ { + yyv4749 = append(yyv4749, ObjectReference{}) + yyh4749.ElemContainerState(yyj4749) if r.TryDecodeAsNil() { - yyv4758[yyj4758] = ObjectReference{} + yyv4749[yyj4749] = ObjectReference{} } else { - yyv4760 := &yyv4758[yyj4758] - yyv4760.CodecDecodeSelf(d) + yyv4751 := &yyv4749[yyj4749] + yyv4751.CodecDecodeSelf(d) } } } } else { - yyj4758 := 0 - for ; !r.CheckBreak(); yyj4758++ { + yyj4749 := 0 + for ; !r.CheckBreak(); yyj4749++ { - if yyj4758 >= len(yyv4758) { - yyv4758 = append(yyv4758, ObjectReference{}) // var yyz4758 ObjectReference - yyc4758 = true + if yyj4749 >= len(yyv4749) { + yyv4749 = append(yyv4749, ObjectReference{}) // var yyz4749 ObjectReference + yyc4749 = true } - yyh4758.ElemContainerState(yyj4758) - if yyj4758 < len(yyv4758) { + yyh4749.ElemContainerState(yyj4749) + if yyj4749 < len(yyv4749) { if r.TryDecodeAsNil() { - yyv4758[yyj4758] = ObjectReference{} + yyv4749[yyj4749] = ObjectReference{} } else { - yyv4761 := &yyv4758[yyj4758] - yyv4761.CodecDecodeSelf(d) + yyv4752 := &yyv4749[yyj4749] + yyv4752.CodecDecodeSelf(d) } } else { @@ -60208,17 +60126,17 @@ func (x codecSelfer1234) decSliceObjectReference(v *[]ObjectReference, d *codec1 } } - if yyj4758 < len(yyv4758) { - yyv4758 = yyv4758[:yyj4758] - yyc4758 = true - } else if yyj4758 == 0 && yyv4758 == nil { - yyv4758 = []ObjectReference{} - yyc4758 = true + if yyj4749 < len(yyv4749) { + yyv4749 = yyv4749[:yyj4749] + yyc4749 = true + } else if yyj4749 == 0 && yyv4749 == nil { + yyv4749 = []ObjectReference{} + yyc4749 = true } } - yyh4758.End() - if yyc4758 { - *v = yyv4758 + yyh4749.End() + if yyc4749 { + *v = yyv4749 } } @@ -60227,10 +60145,10 @@ func (x codecSelfer1234) encSliceServiceAccount(v []ServiceAccount, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4762 := range v { + for _, yyv4753 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4763 := &yyv4762 - yy4763.CodecEncodeSelf(e) + yy4754 := &yyv4753 + yy4754.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60240,83 +60158,83 @@ func (x codecSelfer1234) decSliceServiceAccount(v *[]ServiceAccount, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4764 := *v - yyh4764, yyl4764 := z.DecSliceHelperStart() - var yyc4764 bool - if yyl4764 == 0 { - if yyv4764 == nil { - yyv4764 = []ServiceAccount{} - yyc4764 = true - } else if len(yyv4764) != 0 { - yyv4764 = yyv4764[:0] - yyc4764 = true + yyv4755 := *v + yyh4755, yyl4755 := z.DecSliceHelperStart() + var yyc4755 bool + if yyl4755 == 0 { + if yyv4755 == nil { + yyv4755 = []ServiceAccount{} + yyc4755 = true + } else if len(yyv4755) != 0 { + yyv4755 = yyv4755[:0] + yyc4755 = true } - } else if yyl4764 > 0 { - var yyrr4764, yyrl4764 int - var yyrt4764 bool - if yyl4764 > cap(yyv4764) { + } else if yyl4755 > 0 { + var yyrr4755, yyrl4755 int + var yyrt4755 bool + if yyl4755 > cap(yyv4755) { - yyrg4764 := len(yyv4764) > 0 - yyv24764 := yyv4764 - yyrl4764, yyrt4764 = z.DecInferLen(yyl4764, z.DecBasicHandle().MaxInitLen, 304) - if yyrt4764 { - if yyrl4764 <= cap(yyv4764) { - yyv4764 = yyv4764[:yyrl4764] + yyrg4755 := len(yyv4755) > 0 + yyv24755 := yyv4755 + yyrl4755, yyrt4755 = z.DecInferLen(yyl4755, z.DecBasicHandle().MaxInitLen, 304) + if yyrt4755 { + if yyrl4755 <= cap(yyv4755) { + yyv4755 = yyv4755[:yyrl4755] } else { - yyv4764 = make([]ServiceAccount, yyrl4764) + yyv4755 = make([]ServiceAccount, yyrl4755) } } else { - yyv4764 = make([]ServiceAccount, yyrl4764) + yyv4755 = make([]ServiceAccount, yyrl4755) } - yyc4764 = true - yyrr4764 = len(yyv4764) - if yyrg4764 { - copy(yyv4764, yyv24764) + yyc4755 = true + yyrr4755 = len(yyv4755) + if yyrg4755 { + copy(yyv4755, yyv24755) } - } else if yyl4764 != len(yyv4764) { - yyv4764 = yyv4764[:yyl4764] - yyc4764 = true + } else if yyl4755 != len(yyv4755) { + yyv4755 = yyv4755[:yyl4755] + yyc4755 = true } - yyj4764 := 0 - for ; yyj4764 < yyrr4764; yyj4764++ { - yyh4764.ElemContainerState(yyj4764) + yyj4755 := 0 + for ; yyj4755 < yyrr4755; yyj4755++ { + yyh4755.ElemContainerState(yyj4755) if r.TryDecodeAsNil() { - yyv4764[yyj4764] = ServiceAccount{} + yyv4755[yyj4755] = ServiceAccount{} } else { - yyv4765 := &yyv4764[yyj4764] - yyv4765.CodecDecodeSelf(d) + yyv4756 := &yyv4755[yyj4755] + yyv4756.CodecDecodeSelf(d) } } - if yyrt4764 { - for ; yyj4764 < yyl4764; yyj4764++ { - yyv4764 = append(yyv4764, ServiceAccount{}) - yyh4764.ElemContainerState(yyj4764) + if yyrt4755 { + for ; yyj4755 < yyl4755; yyj4755++ { + yyv4755 = append(yyv4755, ServiceAccount{}) + yyh4755.ElemContainerState(yyj4755) if r.TryDecodeAsNil() { - yyv4764[yyj4764] = ServiceAccount{} + yyv4755[yyj4755] = ServiceAccount{} } else { - yyv4766 := &yyv4764[yyj4764] - yyv4766.CodecDecodeSelf(d) + yyv4757 := &yyv4755[yyj4755] + yyv4757.CodecDecodeSelf(d) } } } } else { - yyj4764 := 0 - for ; !r.CheckBreak(); yyj4764++ { + yyj4755 := 0 + for ; !r.CheckBreak(); yyj4755++ { - if yyj4764 >= len(yyv4764) { - yyv4764 = append(yyv4764, ServiceAccount{}) // var yyz4764 ServiceAccount - yyc4764 = true + if yyj4755 >= len(yyv4755) { + yyv4755 = append(yyv4755, ServiceAccount{}) // var yyz4755 ServiceAccount + yyc4755 = true } - yyh4764.ElemContainerState(yyj4764) - if yyj4764 < len(yyv4764) { + yyh4755.ElemContainerState(yyj4755) + if yyj4755 < len(yyv4755) { if r.TryDecodeAsNil() { - yyv4764[yyj4764] = ServiceAccount{} + yyv4755[yyj4755] = ServiceAccount{} } else { - yyv4767 := &yyv4764[yyj4764] - yyv4767.CodecDecodeSelf(d) + yyv4758 := &yyv4755[yyj4755] + yyv4758.CodecDecodeSelf(d) } } else { @@ -60324,17 +60242,17 @@ func (x codecSelfer1234) decSliceServiceAccount(v *[]ServiceAccount, d *codec197 } } - if yyj4764 < len(yyv4764) { - yyv4764 = yyv4764[:yyj4764] - yyc4764 = true - } else if yyj4764 == 0 && yyv4764 == nil { - yyv4764 = []ServiceAccount{} - yyc4764 = true + if yyj4755 < len(yyv4755) { + yyv4755 = yyv4755[:yyj4755] + yyc4755 = true + } else if yyj4755 == 0 && yyv4755 == nil { + yyv4755 = []ServiceAccount{} + yyc4755 = true } } - yyh4764.End() - if yyc4764 { - *v = yyv4764 + yyh4755.End() + if yyc4755 { + *v = yyv4755 } } @@ -60343,10 +60261,10 @@ func (x codecSelfer1234) encSliceEndpointSubset(v []EndpointSubset, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4768 := range v { + for _, yyv4759 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4769 := &yyv4768 - yy4769.CodecEncodeSelf(e) + yy4760 := &yyv4759 + yy4760.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60356,83 +60274,83 @@ func (x codecSelfer1234) decSliceEndpointSubset(v *[]EndpointSubset, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4770 := *v - yyh4770, yyl4770 := z.DecSliceHelperStart() - var yyc4770 bool - if yyl4770 == 0 { - if yyv4770 == nil { - yyv4770 = []EndpointSubset{} - yyc4770 = true - } else if len(yyv4770) != 0 { - yyv4770 = yyv4770[:0] - yyc4770 = true + yyv4761 := *v + yyh4761, yyl4761 := z.DecSliceHelperStart() + var yyc4761 bool + if yyl4761 == 0 { + if yyv4761 == nil { + yyv4761 = []EndpointSubset{} + yyc4761 = true + } else if len(yyv4761) != 0 { + yyv4761 = yyv4761[:0] + yyc4761 = true } - } else if yyl4770 > 0 { - var yyrr4770, yyrl4770 int - var yyrt4770 bool - if yyl4770 > cap(yyv4770) { + } else if yyl4761 > 0 { + var yyrr4761, yyrl4761 int + var yyrt4761 bool + if yyl4761 > cap(yyv4761) { - yyrg4770 := len(yyv4770) > 0 - yyv24770 := yyv4770 - yyrl4770, yyrt4770 = z.DecInferLen(yyl4770, z.DecBasicHandle().MaxInitLen, 72) - if yyrt4770 { - if yyrl4770 <= cap(yyv4770) { - yyv4770 = yyv4770[:yyrl4770] + yyrg4761 := len(yyv4761) > 0 + yyv24761 := yyv4761 + yyrl4761, yyrt4761 = z.DecInferLen(yyl4761, z.DecBasicHandle().MaxInitLen, 72) + if yyrt4761 { + if yyrl4761 <= cap(yyv4761) { + yyv4761 = yyv4761[:yyrl4761] } else { - yyv4770 = make([]EndpointSubset, yyrl4770) + yyv4761 = make([]EndpointSubset, yyrl4761) } } else { - yyv4770 = make([]EndpointSubset, yyrl4770) + yyv4761 = make([]EndpointSubset, yyrl4761) } - yyc4770 = true - yyrr4770 = len(yyv4770) - if yyrg4770 { - copy(yyv4770, yyv24770) + yyc4761 = true + yyrr4761 = len(yyv4761) + if yyrg4761 { + copy(yyv4761, yyv24761) } - } else if yyl4770 != len(yyv4770) { - yyv4770 = yyv4770[:yyl4770] - yyc4770 = true + } else if yyl4761 != len(yyv4761) { + yyv4761 = yyv4761[:yyl4761] + yyc4761 = true } - yyj4770 := 0 - for ; yyj4770 < yyrr4770; yyj4770++ { - yyh4770.ElemContainerState(yyj4770) + yyj4761 := 0 + for ; yyj4761 < yyrr4761; yyj4761++ { + yyh4761.ElemContainerState(yyj4761) if r.TryDecodeAsNil() { - yyv4770[yyj4770] = EndpointSubset{} + yyv4761[yyj4761] = EndpointSubset{} } else { - yyv4771 := &yyv4770[yyj4770] - yyv4771.CodecDecodeSelf(d) + yyv4762 := &yyv4761[yyj4761] + yyv4762.CodecDecodeSelf(d) } } - if yyrt4770 { - for ; yyj4770 < yyl4770; yyj4770++ { - yyv4770 = append(yyv4770, EndpointSubset{}) - yyh4770.ElemContainerState(yyj4770) + if yyrt4761 { + for ; yyj4761 < yyl4761; yyj4761++ { + yyv4761 = append(yyv4761, EndpointSubset{}) + yyh4761.ElemContainerState(yyj4761) if r.TryDecodeAsNil() { - yyv4770[yyj4770] = EndpointSubset{} + yyv4761[yyj4761] = EndpointSubset{} } else { - yyv4772 := &yyv4770[yyj4770] - yyv4772.CodecDecodeSelf(d) + yyv4763 := &yyv4761[yyj4761] + yyv4763.CodecDecodeSelf(d) } } } } else { - yyj4770 := 0 - for ; !r.CheckBreak(); yyj4770++ { + yyj4761 := 0 + for ; !r.CheckBreak(); yyj4761++ { - if yyj4770 >= len(yyv4770) { - yyv4770 = append(yyv4770, EndpointSubset{}) // var yyz4770 EndpointSubset - yyc4770 = true + if yyj4761 >= len(yyv4761) { + yyv4761 = append(yyv4761, EndpointSubset{}) // var yyz4761 EndpointSubset + yyc4761 = true } - yyh4770.ElemContainerState(yyj4770) - if yyj4770 < len(yyv4770) { + yyh4761.ElemContainerState(yyj4761) + if yyj4761 < len(yyv4761) { if r.TryDecodeAsNil() { - yyv4770[yyj4770] = EndpointSubset{} + yyv4761[yyj4761] = EndpointSubset{} } else { - yyv4773 := &yyv4770[yyj4770] - yyv4773.CodecDecodeSelf(d) + yyv4764 := &yyv4761[yyj4761] + yyv4764.CodecDecodeSelf(d) } } else { @@ -60440,17 +60358,17 @@ func (x codecSelfer1234) decSliceEndpointSubset(v *[]EndpointSubset, d *codec197 } } - if yyj4770 < len(yyv4770) { - yyv4770 = yyv4770[:yyj4770] - yyc4770 = true - } else if yyj4770 == 0 && yyv4770 == nil { - yyv4770 = []EndpointSubset{} - yyc4770 = true + if yyj4761 < len(yyv4761) { + yyv4761 = yyv4761[:yyj4761] + yyc4761 = true + } else if yyj4761 == 0 && yyv4761 == nil { + yyv4761 = []EndpointSubset{} + yyc4761 = true } } - yyh4770.End() - if yyc4770 { - *v = yyv4770 + yyh4761.End() + if yyc4761 { + *v = yyv4761 } } @@ -60459,10 +60377,10 @@ func (x codecSelfer1234) encSliceEndpointAddress(v []EndpointAddress, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4774 := range v { + for _, yyv4765 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4775 := &yyv4774 - yy4775.CodecEncodeSelf(e) + yy4766 := &yyv4765 + yy4766.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60472,83 +60390,83 @@ func (x codecSelfer1234) decSliceEndpointAddress(v *[]EndpointAddress, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4776 := *v - yyh4776, yyl4776 := z.DecSliceHelperStart() - var yyc4776 bool - if yyl4776 == 0 { - if yyv4776 == nil { - yyv4776 = []EndpointAddress{} - yyc4776 = true - } else if len(yyv4776) != 0 { - yyv4776 = yyv4776[:0] - yyc4776 = true + yyv4767 := *v + yyh4767, yyl4767 := z.DecSliceHelperStart() + var yyc4767 bool + if yyl4767 == 0 { + if yyv4767 == nil { + yyv4767 = []EndpointAddress{} + yyc4767 = true + } else if len(yyv4767) != 0 { + yyv4767 = yyv4767[:0] + yyc4767 = true } - } else if yyl4776 > 0 { - var yyrr4776, yyrl4776 int - var yyrt4776 bool - if yyl4776 > cap(yyv4776) { + } else if yyl4767 > 0 { + var yyrr4767, yyrl4767 int + var yyrt4767 bool + if yyl4767 > cap(yyv4767) { - yyrg4776 := len(yyv4776) > 0 - yyv24776 := yyv4776 - yyrl4776, yyrt4776 = z.DecInferLen(yyl4776, z.DecBasicHandle().MaxInitLen, 48) - if yyrt4776 { - if yyrl4776 <= cap(yyv4776) { - yyv4776 = yyv4776[:yyrl4776] + yyrg4767 := len(yyv4767) > 0 + yyv24767 := yyv4767 + yyrl4767, yyrt4767 = z.DecInferLen(yyl4767, z.DecBasicHandle().MaxInitLen, 48) + if yyrt4767 { + if yyrl4767 <= cap(yyv4767) { + yyv4767 = yyv4767[:yyrl4767] } else { - yyv4776 = make([]EndpointAddress, yyrl4776) + yyv4767 = make([]EndpointAddress, yyrl4767) } } else { - yyv4776 = make([]EndpointAddress, yyrl4776) + yyv4767 = make([]EndpointAddress, yyrl4767) } - yyc4776 = true - yyrr4776 = len(yyv4776) - if yyrg4776 { - copy(yyv4776, yyv24776) + yyc4767 = true + yyrr4767 = len(yyv4767) + if yyrg4767 { + copy(yyv4767, yyv24767) } - } else if yyl4776 != len(yyv4776) { - yyv4776 = yyv4776[:yyl4776] - yyc4776 = true + } else if yyl4767 != len(yyv4767) { + yyv4767 = yyv4767[:yyl4767] + yyc4767 = true } - yyj4776 := 0 - for ; yyj4776 < yyrr4776; yyj4776++ { - yyh4776.ElemContainerState(yyj4776) + yyj4767 := 0 + for ; yyj4767 < yyrr4767; yyj4767++ { + yyh4767.ElemContainerState(yyj4767) if r.TryDecodeAsNil() { - yyv4776[yyj4776] = EndpointAddress{} + yyv4767[yyj4767] = EndpointAddress{} } else { - yyv4777 := &yyv4776[yyj4776] - yyv4777.CodecDecodeSelf(d) + yyv4768 := &yyv4767[yyj4767] + yyv4768.CodecDecodeSelf(d) } } - if yyrt4776 { - for ; yyj4776 < yyl4776; yyj4776++ { - yyv4776 = append(yyv4776, EndpointAddress{}) - yyh4776.ElemContainerState(yyj4776) + if yyrt4767 { + for ; yyj4767 < yyl4767; yyj4767++ { + yyv4767 = append(yyv4767, EndpointAddress{}) + yyh4767.ElemContainerState(yyj4767) if r.TryDecodeAsNil() { - yyv4776[yyj4776] = EndpointAddress{} + yyv4767[yyj4767] = EndpointAddress{} } else { - yyv4778 := &yyv4776[yyj4776] - yyv4778.CodecDecodeSelf(d) + yyv4769 := &yyv4767[yyj4767] + yyv4769.CodecDecodeSelf(d) } } } } else { - yyj4776 := 0 - for ; !r.CheckBreak(); yyj4776++ { + yyj4767 := 0 + for ; !r.CheckBreak(); yyj4767++ { - if yyj4776 >= len(yyv4776) { - yyv4776 = append(yyv4776, EndpointAddress{}) // var yyz4776 EndpointAddress - yyc4776 = true + if yyj4767 >= len(yyv4767) { + yyv4767 = append(yyv4767, EndpointAddress{}) // var yyz4767 EndpointAddress + yyc4767 = true } - yyh4776.ElemContainerState(yyj4776) - if yyj4776 < len(yyv4776) { + yyh4767.ElemContainerState(yyj4767) + if yyj4767 < len(yyv4767) { if r.TryDecodeAsNil() { - yyv4776[yyj4776] = EndpointAddress{} + yyv4767[yyj4767] = EndpointAddress{} } else { - yyv4779 := &yyv4776[yyj4776] - yyv4779.CodecDecodeSelf(d) + yyv4770 := &yyv4767[yyj4767] + yyv4770.CodecDecodeSelf(d) } } else { @@ -60556,17 +60474,17 @@ func (x codecSelfer1234) decSliceEndpointAddress(v *[]EndpointAddress, d *codec1 } } - if yyj4776 < len(yyv4776) { - yyv4776 = yyv4776[:yyj4776] - yyc4776 = true - } else if yyj4776 == 0 && yyv4776 == nil { - yyv4776 = []EndpointAddress{} - yyc4776 = true + if yyj4767 < len(yyv4767) { + yyv4767 = yyv4767[:yyj4767] + yyc4767 = true + } else if yyj4767 == 0 && yyv4767 == nil { + yyv4767 = []EndpointAddress{} + yyc4767 = true } } - yyh4776.End() - if yyc4776 { - *v = yyv4776 + yyh4767.End() + if yyc4767 { + *v = yyv4767 } } @@ -60575,10 +60493,10 @@ func (x codecSelfer1234) encSliceEndpointPort(v []EndpointPort, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4780 := range v { + for _, yyv4771 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4781 := &yyv4780 - yy4781.CodecEncodeSelf(e) + yy4772 := &yyv4771 + yy4772.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60588,83 +60506,83 @@ func (x codecSelfer1234) decSliceEndpointPort(v *[]EndpointPort, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4782 := *v - yyh4782, yyl4782 := z.DecSliceHelperStart() - var yyc4782 bool - if yyl4782 == 0 { - if yyv4782 == nil { - yyv4782 = []EndpointPort{} - yyc4782 = true - } else if len(yyv4782) != 0 { - yyv4782 = yyv4782[:0] - yyc4782 = true + yyv4773 := *v + yyh4773, yyl4773 := z.DecSliceHelperStart() + var yyc4773 bool + if yyl4773 == 0 { + if yyv4773 == nil { + yyv4773 = []EndpointPort{} + yyc4773 = true + } else if len(yyv4773) != 0 { + yyv4773 = yyv4773[:0] + yyc4773 = true } - } else if yyl4782 > 0 { - var yyrr4782, yyrl4782 int - var yyrt4782 bool - if yyl4782 > cap(yyv4782) { + } else if yyl4773 > 0 { + var yyrr4773, yyrl4773 int + var yyrt4773 bool + if yyl4773 > cap(yyv4773) { - yyrg4782 := len(yyv4782) > 0 - yyv24782 := yyv4782 - yyrl4782, yyrt4782 = z.DecInferLen(yyl4782, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4782 { - if yyrl4782 <= cap(yyv4782) { - yyv4782 = yyv4782[:yyrl4782] + yyrg4773 := len(yyv4773) > 0 + yyv24773 := yyv4773 + yyrl4773, yyrt4773 = z.DecInferLen(yyl4773, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4773 { + if yyrl4773 <= cap(yyv4773) { + yyv4773 = yyv4773[:yyrl4773] } else { - yyv4782 = make([]EndpointPort, yyrl4782) + yyv4773 = make([]EndpointPort, yyrl4773) } } else { - yyv4782 = make([]EndpointPort, yyrl4782) + yyv4773 = make([]EndpointPort, yyrl4773) } - yyc4782 = true - yyrr4782 = len(yyv4782) - if yyrg4782 { - copy(yyv4782, yyv24782) + yyc4773 = true + yyrr4773 = len(yyv4773) + if yyrg4773 { + copy(yyv4773, yyv24773) } - } else if yyl4782 != len(yyv4782) { - yyv4782 = yyv4782[:yyl4782] - yyc4782 = true + } else if yyl4773 != len(yyv4773) { + yyv4773 = yyv4773[:yyl4773] + yyc4773 = true } - yyj4782 := 0 - for ; yyj4782 < yyrr4782; yyj4782++ { - yyh4782.ElemContainerState(yyj4782) + yyj4773 := 0 + for ; yyj4773 < yyrr4773; yyj4773++ { + yyh4773.ElemContainerState(yyj4773) if r.TryDecodeAsNil() { - yyv4782[yyj4782] = EndpointPort{} + yyv4773[yyj4773] = EndpointPort{} } else { - yyv4783 := &yyv4782[yyj4782] - yyv4783.CodecDecodeSelf(d) + yyv4774 := &yyv4773[yyj4773] + yyv4774.CodecDecodeSelf(d) } } - if yyrt4782 { - for ; yyj4782 < yyl4782; yyj4782++ { - yyv4782 = append(yyv4782, EndpointPort{}) - yyh4782.ElemContainerState(yyj4782) + if yyrt4773 { + for ; yyj4773 < yyl4773; yyj4773++ { + yyv4773 = append(yyv4773, EndpointPort{}) + yyh4773.ElemContainerState(yyj4773) if r.TryDecodeAsNil() { - yyv4782[yyj4782] = EndpointPort{} + yyv4773[yyj4773] = EndpointPort{} } else { - yyv4784 := &yyv4782[yyj4782] - yyv4784.CodecDecodeSelf(d) + yyv4775 := &yyv4773[yyj4773] + yyv4775.CodecDecodeSelf(d) } } } } else { - yyj4782 := 0 - for ; !r.CheckBreak(); yyj4782++ { + yyj4773 := 0 + for ; !r.CheckBreak(); yyj4773++ { - if yyj4782 >= len(yyv4782) { - yyv4782 = append(yyv4782, EndpointPort{}) // var yyz4782 EndpointPort - yyc4782 = true + if yyj4773 >= len(yyv4773) { + yyv4773 = append(yyv4773, EndpointPort{}) // var yyz4773 EndpointPort + yyc4773 = true } - yyh4782.ElemContainerState(yyj4782) - if yyj4782 < len(yyv4782) { + yyh4773.ElemContainerState(yyj4773) + if yyj4773 < len(yyv4773) { if r.TryDecodeAsNil() { - yyv4782[yyj4782] = EndpointPort{} + yyv4773[yyj4773] = EndpointPort{} } else { - yyv4785 := &yyv4782[yyj4782] - yyv4785.CodecDecodeSelf(d) + yyv4776 := &yyv4773[yyj4773] + yyv4776.CodecDecodeSelf(d) } } else { @@ -60672,17 +60590,17 @@ func (x codecSelfer1234) decSliceEndpointPort(v *[]EndpointPort, d *codec1978.De } } - if yyj4782 < len(yyv4782) { - yyv4782 = yyv4782[:yyj4782] - yyc4782 = true - } else if yyj4782 == 0 && yyv4782 == nil { - yyv4782 = []EndpointPort{} - yyc4782 = true + if yyj4773 < len(yyv4773) { + yyv4773 = yyv4773[:yyj4773] + yyc4773 = true + } else if yyj4773 == 0 && yyv4773 == nil { + yyv4773 = []EndpointPort{} + yyc4773 = true } } - yyh4782.End() - if yyc4782 { - *v = yyv4782 + yyh4773.End() + if yyc4773 { + *v = yyv4773 } } @@ -60691,10 +60609,10 @@ func (x codecSelfer1234) encSliceEndpoints(v []Endpoints, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4786 := range v { + for _, yyv4777 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4787 := &yyv4786 - yy4787.CodecEncodeSelf(e) + yy4778 := &yyv4777 + yy4778.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60704,83 +60622,83 @@ func (x codecSelfer1234) decSliceEndpoints(v *[]Endpoints, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4788 := *v - yyh4788, yyl4788 := z.DecSliceHelperStart() - var yyc4788 bool - if yyl4788 == 0 { - if yyv4788 == nil { - yyv4788 = []Endpoints{} - yyc4788 = true - } else if len(yyv4788) != 0 { - yyv4788 = yyv4788[:0] - yyc4788 = true + yyv4779 := *v + yyh4779, yyl4779 := z.DecSliceHelperStart() + var yyc4779 bool + if yyl4779 == 0 { + if yyv4779 == nil { + yyv4779 = []Endpoints{} + yyc4779 = true + } else if len(yyv4779) != 0 { + yyv4779 = yyv4779[:0] + yyc4779 = true } - } else if yyl4788 > 0 { - var yyrr4788, yyrl4788 int - var yyrt4788 bool - if yyl4788 > cap(yyv4788) { + } else if yyl4779 > 0 { + var yyrr4779, yyrl4779 int + var yyrt4779 bool + if yyl4779 > cap(yyv4779) { - yyrg4788 := len(yyv4788) > 0 - yyv24788 := yyv4788 - yyrl4788, yyrt4788 = z.DecInferLen(yyl4788, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4788 { - if yyrl4788 <= cap(yyv4788) { - yyv4788 = yyv4788[:yyrl4788] + yyrg4779 := len(yyv4779) > 0 + yyv24779 := yyv4779 + yyrl4779, yyrt4779 = z.DecInferLen(yyl4779, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4779 { + if yyrl4779 <= cap(yyv4779) { + yyv4779 = yyv4779[:yyrl4779] } else { - yyv4788 = make([]Endpoints, yyrl4788) + yyv4779 = make([]Endpoints, yyrl4779) } } else { - yyv4788 = make([]Endpoints, yyrl4788) + yyv4779 = make([]Endpoints, yyrl4779) } - yyc4788 = true - yyrr4788 = len(yyv4788) - if yyrg4788 { - copy(yyv4788, yyv24788) + yyc4779 = true + yyrr4779 = len(yyv4779) + if yyrg4779 { + copy(yyv4779, yyv24779) } - } else if yyl4788 != len(yyv4788) { - yyv4788 = yyv4788[:yyl4788] - yyc4788 = true + } else if yyl4779 != len(yyv4779) { + yyv4779 = yyv4779[:yyl4779] + yyc4779 = true } - yyj4788 := 0 - for ; yyj4788 < yyrr4788; yyj4788++ { - yyh4788.ElemContainerState(yyj4788) + yyj4779 := 0 + for ; yyj4779 < yyrr4779; yyj4779++ { + yyh4779.ElemContainerState(yyj4779) if r.TryDecodeAsNil() { - yyv4788[yyj4788] = Endpoints{} + yyv4779[yyj4779] = Endpoints{} } else { - yyv4789 := &yyv4788[yyj4788] - yyv4789.CodecDecodeSelf(d) + yyv4780 := &yyv4779[yyj4779] + yyv4780.CodecDecodeSelf(d) } } - if yyrt4788 { - for ; yyj4788 < yyl4788; yyj4788++ { - yyv4788 = append(yyv4788, Endpoints{}) - yyh4788.ElemContainerState(yyj4788) + if yyrt4779 { + for ; yyj4779 < yyl4779; yyj4779++ { + yyv4779 = append(yyv4779, Endpoints{}) + yyh4779.ElemContainerState(yyj4779) if r.TryDecodeAsNil() { - yyv4788[yyj4788] = Endpoints{} + yyv4779[yyj4779] = Endpoints{} } else { - yyv4790 := &yyv4788[yyj4788] - yyv4790.CodecDecodeSelf(d) + yyv4781 := &yyv4779[yyj4779] + yyv4781.CodecDecodeSelf(d) } } } } else { - yyj4788 := 0 - for ; !r.CheckBreak(); yyj4788++ { + yyj4779 := 0 + for ; !r.CheckBreak(); yyj4779++ { - if yyj4788 >= len(yyv4788) { - yyv4788 = append(yyv4788, Endpoints{}) // var yyz4788 Endpoints - yyc4788 = true + if yyj4779 >= len(yyv4779) { + yyv4779 = append(yyv4779, Endpoints{}) // var yyz4779 Endpoints + yyc4779 = true } - yyh4788.ElemContainerState(yyj4788) - if yyj4788 < len(yyv4788) { + yyh4779.ElemContainerState(yyj4779) + if yyj4779 < len(yyv4779) { if r.TryDecodeAsNil() { - yyv4788[yyj4788] = Endpoints{} + yyv4779[yyj4779] = Endpoints{} } else { - yyv4791 := &yyv4788[yyj4788] - yyv4791.CodecDecodeSelf(d) + yyv4782 := &yyv4779[yyj4779] + yyv4782.CodecDecodeSelf(d) } } else { @@ -60788,17 +60706,17 @@ func (x codecSelfer1234) decSliceEndpoints(v *[]Endpoints, d *codec1978.Decoder) } } - if yyj4788 < len(yyv4788) { - yyv4788 = yyv4788[:yyj4788] - yyc4788 = true - } else if yyj4788 == 0 && yyv4788 == nil { - yyv4788 = []Endpoints{} - yyc4788 = true + if yyj4779 < len(yyv4779) { + yyv4779 = yyv4779[:yyj4779] + yyc4779 = true + } else if yyj4779 == 0 && yyv4779 == nil { + yyv4779 = []Endpoints{} + yyc4779 = true } } - yyh4788.End() - if yyc4788 { - *v = yyv4788 + yyh4779.End() + if yyc4779 { + *v = yyv4779 } } @@ -60807,10 +60725,10 @@ func (x codecSelfer1234) encSliceNodeCondition(v []NodeCondition, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4792 := range v { + for _, yyv4783 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4793 := &yyv4792 - yy4793.CodecEncodeSelf(e) + yy4784 := &yyv4783 + yy4784.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60820,83 +60738,83 @@ func (x codecSelfer1234) decSliceNodeCondition(v *[]NodeCondition, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4794 := *v - yyh4794, yyl4794 := z.DecSliceHelperStart() - var yyc4794 bool - if yyl4794 == 0 { - if yyv4794 == nil { - yyv4794 = []NodeCondition{} - yyc4794 = true - } else if len(yyv4794) != 0 { - yyv4794 = yyv4794[:0] - yyc4794 = true + yyv4785 := *v + yyh4785, yyl4785 := z.DecSliceHelperStart() + var yyc4785 bool + if yyl4785 == 0 { + if yyv4785 == nil { + yyv4785 = []NodeCondition{} + yyc4785 = true + } else if len(yyv4785) != 0 { + yyv4785 = yyv4785[:0] + yyc4785 = true } - } else if yyl4794 > 0 { - var yyrr4794, yyrl4794 int - var yyrt4794 bool - if yyl4794 > cap(yyv4794) { + } else if yyl4785 > 0 { + var yyrr4785, yyrl4785 int + var yyrt4785 bool + if yyl4785 > cap(yyv4785) { - yyrg4794 := len(yyv4794) > 0 - yyv24794 := yyv4794 - yyrl4794, yyrt4794 = z.DecInferLen(yyl4794, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4794 { - if yyrl4794 <= cap(yyv4794) { - yyv4794 = yyv4794[:yyrl4794] + yyrg4785 := len(yyv4785) > 0 + yyv24785 := yyv4785 + yyrl4785, yyrt4785 = z.DecInferLen(yyl4785, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4785 { + if yyrl4785 <= cap(yyv4785) { + yyv4785 = yyv4785[:yyrl4785] } else { - yyv4794 = make([]NodeCondition, yyrl4794) + yyv4785 = make([]NodeCondition, yyrl4785) } } else { - yyv4794 = make([]NodeCondition, yyrl4794) + yyv4785 = make([]NodeCondition, yyrl4785) } - yyc4794 = true - yyrr4794 = len(yyv4794) - if yyrg4794 { - copy(yyv4794, yyv24794) + yyc4785 = true + yyrr4785 = len(yyv4785) + if yyrg4785 { + copy(yyv4785, yyv24785) } - } else if yyl4794 != len(yyv4794) { - yyv4794 = yyv4794[:yyl4794] - yyc4794 = true + } else if yyl4785 != len(yyv4785) { + yyv4785 = yyv4785[:yyl4785] + yyc4785 = true } - yyj4794 := 0 - for ; yyj4794 < yyrr4794; yyj4794++ { - yyh4794.ElemContainerState(yyj4794) + yyj4785 := 0 + for ; yyj4785 < yyrr4785; yyj4785++ { + yyh4785.ElemContainerState(yyj4785) if r.TryDecodeAsNil() { - yyv4794[yyj4794] = NodeCondition{} + yyv4785[yyj4785] = NodeCondition{} } else { - yyv4795 := &yyv4794[yyj4794] - yyv4795.CodecDecodeSelf(d) + yyv4786 := &yyv4785[yyj4785] + yyv4786.CodecDecodeSelf(d) } } - if yyrt4794 { - for ; yyj4794 < yyl4794; yyj4794++ { - yyv4794 = append(yyv4794, NodeCondition{}) - yyh4794.ElemContainerState(yyj4794) + if yyrt4785 { + for ; yyj4785 < yyl4785; yyj4785++ { + yyv4785 = append(yyv4785, NodeCondition{}) + yyh4785.ElemContainerState(yyj4785) if r.TryDecodeAsNil() { - yyv4794[yyj4794] = NodeCondition{} + yyv4785[yyj4785] = NodeCondition{} } else { - yyv4796 := &yyv4794[yyj4794] - yyv4796.CodecDecodeSelf(d) + yyv4787 := &yyv4785[yyj4785] + yyv4787.CodecDecodeSelf(d) } } } } else { - yyj4794 := 0 - for ; !r.CheckBreak(); yyj4794++ { + yyj4785 := 0 + for ; !r.CheckBreak(); yyj4785++ { - if yyj4794 >= len(yyv4794) { - yyv4794 = append(yyv4794, NodeCondition{}) // var yyz4794 NodeCondition - yyc4794 = true + if yyj4785 >= len(yyv4785) { + yyv4785 = append(yyv4785, NodeCondition{}) // var yyz4785 NodeCondition + yyc4785 = true } - yyh4794.ElemContainerState(yyj4794) - if yyj4794 < len(yyv4794) { + yyh4785.ElemContainerState(yyj4785) + if yyj4785 < len(yyv4785) { if r.TryDecodeAsNil() { - yyv4794[yyj4794] = NodeCondition{} + yyv4785[yyj4785] = NodeCondition{} } else { - yyv4797 := &yyv4794[yyj4794] - yyv4797.CodecDecodeSelf(d) + yyv4788 := &yyv4785[yyj4785] + yyv4788.CodecDecodeSelf(d) } } else { @@ -60904,17 +60822,17 @@ func (x codecSelfer1234) decSliceNodeCondition(v *[]NodeCondition, d *codec1978. } } - if yyj4794 < len(yyv4794) { - yyv4794 = yyv4794[:yyj4794] - yyc4794 = true - } else if yyj4794 == 0 && yyv4794 == nil { - yyv4794 = []NodeCondition{} - yyc4794 = true + if yyj4785 < len(yyv4785) { + yyv4785 = yyv4785[:yyj4785] + yyc4785 = true + } else if yyj4785 == 0 && yyv4785 == nil { + yyv4785 = []NodeCondition{} + yyc4785 = true } } - yyh4794.End() - if yyc4794 { - *v = yyv4794 + yyh4785.End() + if yyc4785 { + *v = yyv4785 } } @@ -60923,10 +60841,10 @@ func (x codecSelfer1234) encSliceNodeAddress(v []NodeAddress, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4798 := range v { + for _, yyv4789 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4799 := &yyv4798 - yy4799.CodecEncodeSelf(e) + yy4790 := &yyv4789 + yy4790.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60936,83 +60854,83 @@ func (x codecSelfer1234) decSliceNodeAddress(v *[]NodeAddress, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4800 := *v - yyh4800, yyl4800 := z.DecSliceHelperStart() - var yyc4800 bool - if yyl4800 == 0 { - if yyv4800 == nil { - yyv4800 = []NodeAddress{} - yyc4800 = true - } else if len(yyv4800) != 0 { - yyv4800 = yyv4800[:0] - yyc4800 = true + yyv4791 := *v + yyh4791, yyl4791 := z.DecSliceHelperStart() + var yyc4791 bool + if yyl4791 == 0 { + if yyv4791 == nil { + yyv4791 = []NodeAddress{} + yyc4791 = true + } else if len(yyv4791) != 0 { + yyv4791 = yyv4791[:0] + yyc4791 = true } - } else if yyl4800 > 0 { - var yyrr4800, yyrl4800 int - var yyrt4800 bool - if yyl4800 > cap(yyv4800) { + } else if yyl4791 > 0 { + var yyrr4791, yyrl4791 int + var yyrt4791 bool + if yyl4791 > cap(yyv4791) { - yyrg4800 := len(yyv4800) > 0 - yyv24800 := yyv4800 - yyrl4800, yyrt4800 = z.DecInferLen(yyl4800, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4800 { - if yyrl4800 <= cap(yyv4800) { - yyv4800 = yyv4800[:yyrl4800] + yyrg4791 := len(yyv4791) > 0 + yyv24791 := yyv4791 + yyrl4791, yyrt4791 = z.DecInferLen(yyl4791, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4791 { + if yyrl4791 <= cap(yyv4791) { + yyv4791 = yyv4791[:yyrl4791] } else { - yyv4800 = make([]NodeAddress, yyrl4800) + yyv4791 = make([]NodeAddress, yyrl4791) } } else { - yyv4800 = make([]NodeAddress, yyrl4800) + yyv4791 = make([]NodeAddress, yyrl4791) } - yyc4800 = true - yyrr4800 = len(yyv4800) - if yyrg4800 { - copy(yyv4800, yyv24800) + yyc4791 = true + yyrr4791 = len(yyv4791) + if yyrg4791 { + copy(yyv4791, yyv24791) } - } else if yyl4800 != len(yyv4800) { - yyv4800 = yyv4800[:yyl4800] - yyc4800 = true + } else if yyl4791 != len(yyv4791) { + yyv4791 = yyv4791[:yyl4791] + yyc4791 = true } - yyj4800 := 0 - for ; yyj4800 < yyrr4800; yyj4800++ { - yyh4800.ElemContainerState(yyj4800) + yyj4791 := 0 + for ; yyj4791 < yyrr4791; yyj4791++ { + yyh4791.ElemContainerState(yyj4791) if r.TryDecodeAsNil() { - yyv4800[yyj4800] = NodeAddress{} + yyv4791[yyj4791] = NodeAddress{} } else { - yyv4801 := &yyv4800[yyj4800] - yyv4801.CodecDecodeSelf(d) + yyv4792 := &yyv4791[yyj4791] + yyv4792.CodecDecodeSelf(d) } } - if yyrt4800 { - for ; yyj4800 < yyl4800; yyj4800++ { - yyv4800 = append(yyv4800, NodeAddress{}) - yyh4800.ElemContainerState(yyj4800) + if yyrt4791 { + for ; yyj4791 < yyl4791; yyj4791++ { + yyv4791 = append(yyv4791, NodeAddress{}) + yyh4791.ElemContainerState(yyj4791) if r.TryDecodeAsNil() { - yyv4800[yyj4800] = NodeAddress{} + yyv4791[yyj4791] = NodeAddress{} } else { - yyv4802 := &yyv4800[yyj4800] - yyv4802.CodecDecodeSelf(d) + yyv4793 := &yyv4791[yyj4791] + yyv4793.CodecDecodeSelf(d) } } } } else { - yyj4800 := 0 - for ; !r.CheckBreak(); yyj4800++ { + yyj4791 := 0 + for ; !r.CheckBreak(); yyj4791++ { - if yyj4800 >= len(yyv4800) { - yyv4800 = append(yyv4800, NodeAddress{}) // var yyz4800 NodeAddress - yyc4800 = true + if yyj4791 >= len(yyv4791) { + yyv4791 = append(yyv4791, NodeAddress{}) // var yyz4791 NodeAddress + yyc4791 = true } - yyh4800.ElemContainerState(yyj4800) - if yyj4800 < len(yyv4800) { + yyh4791.ElemContainerState(yyj4791) + if yyj4791 < len(yyv4791) { if r.TryDecodeAsNil() { - yyv4800[yyj4800] = NodeAddress{} + yyv4791[yyj4791] = NodeAddress{} } else { - yyv4803 := &yyv4800[yyj4800] - yyv4803.CodecDecodeSelf(d) + yyv4794 := &yyv4791[yyj4791] + yyv4794.CodecDecodeSelf(d) } } else { @@ -61020,17 +60938,17 @@ func (x codecSelfer1234) decSliceNodeAddress(v *[]NodeAddress, d *codec1978.Deco } } - if yyj4800 < len(yyv4800) { - yyv4800 = yyv4800[:yyj4800] - yyc4800 = true - } else if yyj4800 == 0 && yyv4800 == nil { - yyv4800 = []NodeAddress{} - yyc4800 = true + if yyj4791 < len(yyv4791) { + yyv4791 = yyv4791[:yyj4791] + yyc4791 = true + } else if yyj4791 == 0 && yyv4791 == nil { + yyv4791 = []NodeAddress{} + yyc4791 = true } } - yyh4800.End() - if yyc4800 { - *v = yyv4800 + yyh4791.End() + if yyc4791 { + *v = yyv4791 } } @@ -61039,10 +60957,10 @@ func (x codecSelfer1234) encSliceContainerImage(v []ContainerImage, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4804 := range v { + for _, yyv4795 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4805 := &yyv4804 - yy4805.CodecEncodeSelf(e) + yy4796 := &yyv4795 + yy4796.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61052,83 +60970,83 @@ func (x codecSelfer1234) decSliceContainerImage(v *[]ContainerImage, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4806 := *v - yyh4806, yyl4806 := z.DecSliceHelperStart() - var yyc4806 bool - if yyl4806 == 0 { - if yyv4806 == nil { - yyv4806 = []ContainerImage{} - yyc4806 = true - } else if len(yyv4806) != 0 { - yyv4806 = yyv4806[:0] - yyc4806 = true + yyv4797 := *v + yyh4797, yyl4797 := z.DecSliceHelperStart() + var yyc4797 bool + if yyl4797 == 0 { + if yyv4797 == nil { + yyv4797 = []ContainerImage{} + yyc4797 = true + } else if len(yyv4797) != 0 { + yyv4797 = yyv4797[:0] + yyc4797 = true } - } else if yyl4806 > 0 { - var yyrr4806, yyrl4806 int - var yyrt4806 bool - if yyl4806 > cap(yyv4806) { + } else if yyl4797 > 0 { + var yyrr4797, yyrl4797 int + var yyrt4797 bool + if yyl4797 > cap(yyv4797) { - yyrg4806 := len(yyv4806) > 0 - yyv24806 := yyv4806 - yyrl4806, yyrt4806 = z.DecInferLen(yyl4806, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4806 { - if yyrl4806 <= cap(yyv4806) { - yyv4806 = yyv4806[:yyrl4806] + yyrg4797 := len(yyv4797) > 0 + yyv24797 := yyv4797 + yyrl4797, yyrt4797 = z.DecInferLen(yyl4797, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4797 { + if yyrl4797 <= cap(yyv4797) { + yyv4797 = yyv4797[:yyrl4797] } else { - yyv4806 = make([]ContainerImage, yyrl4806) + yyv4797 = make([]ContainerImage, yyrl4797) } } else { - yyv4806 = make([]ContainerImage, yyrl4806) + yyv4797 = make([]ContainerImage, yyrl4797) } - yyc4806 = true - yyrr4806 = len(yyv4806) - if yyrg4806 { - copy(yyv4806, yyv24806) + yyc4797 = true + yyrr4797 = len(yyv4797) + if yyrg4797 { + copy(yyv4797, yyv24797) } - } else if yyl4806 != len(yyv4806) { - yyv4806 = yyv4806[:yyl4806] - yyc4806 = true + } else if yyl4797 != len(yyv4797) { + yyv4797 = yyv4797[:yyl4797] + yyc4797 = true } - yyj4806 := 0 - for ; yyj4806 < yyrr4806; yyj4806++ { - yyh4806.ElemContainerState(yyj4806) + yyj4797 := 0 + for ; yyj4797 < yyrr4797; yyj4797++ { + yyh4797.ElemContainerState(yyj4797) if r.TryDecodeAsNil() { - yyv4806[yyj4806] = ContainerImage{} + yyv4797[yyj4797] = ContainerImage{} } else { - yyv4807 := &yyv4806[yyj4806] - yyv4807.CodecDecodeSelf(d) + yyv4798 := &yyv4797[yyj4797] + yyv4798.CodecDecodeSelf(d) } } - if yyrt4806 { - for ; yyj4806 < yyl4806; yyj4806++ { - yyv4806 = append(yyv4806, ContainerImage{}) - yyh4806.ElemContainerState(yyj4806) + if yyrt4797 { + for ; yyj4797 < yyl4797; yyj4797++ { + yyv4797 = append(yyv4797, ContainerImage{}) + yyh4797.ElemContainerState(yyj4797) if r.TryDecodeAsNil() { - yyv4806[yyj4806] = ContainerImage{} + yyv4797[yyj4797] = ContainerImage{} } else { - yyv4808 := &yyv4806[yyj4806] - yyv4808.CodecDecodeSelf(d) + yyv4799 := &yyv4797[yyj4797] + yyv4799.CodecDecodeSelf(d) } } } } else { - yyj4806 := 0 - for ; !r.CheckBreak(); yyj4806++ { + yyj4797 := 0 + for ; !r.CheckBreak(); yyj4797++ { - if yyj4806 >= len(yyv4806) { - yyv4806 = append(yyv4806, ContainerImage{}) // var yyz4806 ContainerImage - yyc4806 = true + if yyj4797 >= len(yyv4797) { + yyv4797 = append(yyv4797, ContainerImage{}) // var yyz4797 ContainerImage + yyc4797 = true } - yyh4806.ElemContainerState(yyj4806) - if yyj4806 < len(yyv4806) { + yyh4797.ElemContainerState(yyj4797) + if yyj4797 < len(yyv4797) { if r.TryDecodeAsNil() { - yyv4806[yyj4806] = ContainerImage{} + yyv4797[yyj4797] = ContainerImage{} } else { - yyv4809 := &yyv4806[yyj4806] - yyv4809.CodecDecodeSelf(d) + yyv4800 := &yyv4797[yyj4797] + yyv4800.CodecDecodeSelf(d) } } else { @@ -61136,17 +61054,17 @@ func (x codecSelfer1234) decSliceContainerImage(v *[]ContainerImage, d *codec197 } } - if yyj4806 < len(yyv4806) { - yyv4806 = yyv4806[:yyj4806] - yyc4806 = true - } else if yyj4806 == 0 && yyv4806 == nil { - yyv4806 = []ContainerImage{} - yyc4806 = true + if yyj4797 < len(yyv4797) { + yyv4797 = yyv4797[:yyj4797] + yyc4797 = true + } else if yyj4797 == 0 && yyv4797 == nil { + yyv4797 = []ContainerImage{} + yyc4797 = true } } - yyh4806.End() - if yyc4806 { - *v = yyv4806 + yyh4797.End() + if yyc4797 { + *v = yyv4797 } } @@ -61155,9 +61073,9 @@ func (x codecSelfer1234) encSliceUniqueVolumeName(v []UniqueVolumeName, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4810 := range v { + for _, yyv4801 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4810.CodecEncodeSelf(e) + yyv4801.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61167,75 +61085,75 @@ func (x codecSelfer1234) decSliceUniqueVolumeName(v *[]UniqueVolumeName, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4811 := *v - yyh4811, yyl4811 := z.DecSliceHelperStart() - var yyc4811 bool - if yyl4811 == 0 { - if yyv4811 == nil { - yyv4811 = []UniqueVolumeName{} - yyc4811 = true - } else if len(yyv4811) != 0 { - yyv4811 = yyv4811[:0] - yyc4811 = true + yyv4802 := *v + yyh4802, yyl4802 := z.DecSliceHelperStart() + var yyc4802 bool + if yyl4802 == 0 { + if yyv4802 == nil { + yyv4802 = []UniqueVolumeName{} + yyc4802 = true + } else if len(yyv4802) != 0 { + yyv4802 = yyv4802[:0] + yyc4802 = true } - } else if yyl4811 > 0 { - var yyrr4811, yyrl4811 int - var yyrt4811 bool - if yyl4811 > cap(yyv4811) { + } else if yyl4802 > 0 { + var yyrr4802, yyrl4802 int + var yyrt4802 bool + if yyl4802 > cap(yyv4802) { - yyrl4811, yyrt4811 = z.DecInferLen(yyl4811, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4811 { - if yyrl4811 <= cap(yyv4811) { - yyv4811 = yyv4811[:yyrl4811] + yyrl4802, yyrt4802 = z.DecInferLen(yyl4802, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4802 { + if yyrl4802 <= cap(yyv4802) { + yyv4802 = yyv4802[:yyrl4802] } else { - yyv4811 = make([]UniqueVolumeName, yyrl4811) + yyv4802 = make([]UniqueVolumeName, yyrl4802) } } else { - yyv4811 = make([]UniqueVolumeName, yyrl4811) + yyv4802 = make([]UniqueVolumeName, yyrl4802) } - yyc4811 = true - yyrr4811 = len(yyv4811) - } else if yyl4811 != len(yyv4811) { - yyv4811 = yyv4811[:yyl4811] - yyc4811 = true + yyc4802 = true + yyrr4802 = len(yyv4802) + } else if yyl4802 != len(yyv4802) { + yyv4802 = yyv4802[:yyl4802] + yyc4802 = true } - yyj4811 := 0 - for ; yyj4811 < yyrr4811; yyj4811++ { - yyh4811.ElemContainerState(yyj4811) + yyj4802 := 0 + for ; yyj4802 < yyrr4802; yyj4802++ { + yyh4802.ElemContainerState(yyj4802) if r.TryDecodeAsNil() { - yyv4811[yyj4811] = "" + yyv4802[yyj4802] = "" } else { - yyv4811[yyj4811] = UniqueVolumeName(r.DecodeString()) + yyv4802[yyj4802] = UniqueVolumeName(r.DecodeString()) } } - if yyrt4811 { - for ; yyj4811 < yyl4811; yyj4811++ { - yyv4811 = append(yyv4811, "") - yyh4811.ElemContainerState(yyj4811) + if yyrt4802 { + for ; yyj4802 < yyl4802; yyj4802++ { + yyv4802 = append(yyv4802, "") + yyh4802.ElemContainerState(yyj4802) if r.TryDecodeAsNil() { - yyv4811[yyj4811] = "" + yyv4802[yyj4802] = "" } else { - yyv4811[yyj4811] = UniqueVolumeName(r.DecodeString()) + yyv4802[yyj4802] = UniqueVolumeName(r.DecodeString()) } } } } else { - yyj4811 := 0 - for ; !r.CheckBreak(); yyj4811++ { + yyj4802 := 0 + for ; !r.CheckBreak(); yyj4802++ { - if yyj4811 >= len(yyv4811) { - yyv4811 = append(yyv4811, "") // var yyz4811 UniqueVolumeName - yyc4811 = true + if yyj4802 >= len(yyv4802) { + yyv4802 = append(yyv4802, "") // var yyz4802 UniqueVolumeName + yyc4802 = true } - yyh4811.ElemContainerState(yyj4811) - if yyj4811 < len(yyv4811) { + yyh4802.ElemContainerState(yyj4802) + if yyj4802 < len(yyv4802) { if r.TryDecodeAsNil() { - yyv4811[yyj4811] = "" + yyv4802[yyj4802] = "" } else { - yyv4811[yyj4811] = UniqueVolumeName(r.DecodeString()) + yyv4802[yyj4802] = UniqueVolumeName(r.DecodeString()) } } else { @@ -61243,17 +61161,17 @@ func (x codecSelfer1234) decSliceUniqueVolumeName(v *[]UniqueVolumeName, d *code } } - if yyj4811 < len(yyv4811) { - yyv4811 = yyv4811[:yyj4811] - yyc4811 = true - } else if yyj4811 == 0 && yyv4811 == nil { - yyv4811 = []UniqueVolumeName{} - yyc4811 = true + if yyj4802 < len(yyv4802) { + yyv4802 = yyv4802[:yyj4802] + yyc4802 = true + } else if yyj4802 == 0 && yyv4802 == nil { + yyv4802 = []UniqueVolumeName{} + yyc4802 = true } } - yyh4811.End() - if yyc4811 { - *v = yyv4811 + yyh4802.End() + if yyc4802 { + *v = yyv4802 } } @@ -61262,10 +61180,10 @@ func (x codecSelfer1234) encSliceAttachedVolume(v []AttachedVolume, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4815 := range v { + for _, yyv4806 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4816 := &yyv4815 - yy4816.CodecEncodeSelf(e) + yy4807 := &yyv4806 + yy4807.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61275,83 +61193,83 @@ func (x codecSelfer1234) decSliceAttachedVolume(v *[]AttachedVolume, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4817 := *v - yyh4817, yyl4817 := z.DecSliceHelperStart() - var yyc4817 bool - if yyl4817 == 0 { - if yyv4817 == nil { - yyv4817 = []AttachedVolume{} - yyc4817 = true - } else if len(yyv4817) != 0 { - yyv4817 = yyv4817[:0] - yyc4817 = true + yyv4808 := *v + yyh4808, yyl4808 := z.DecSliceHelperStart() + var yyc4808 bool + if yyl4808 == 0 { + if yyv4808 == nil { + yyv4808 = []AttachedVolume{} + yyc4808 = true + } else if len(yyv4808) != 0 { + yyv4808 = yyv4808[:0] + yyc4808 = true } - } else if yyl4817 > 0 { - var yyrr4817, yyrl4817 int - var yyrt4817 bool - if yyl4817 > cap(yyv4817) { + } else if yyl4808 > 0 { + var yyrr4808, yyrl4808 int + var yyrt4808 bool + if yyl4808 > cap(yyv4808) { - yyrg4817 := len(yyv4817) > 0 - yyv24817 := yyv4817 - yyrl4817, yyrt4817 = z.DecInferLen(yyl4817, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4817 { - if yyrl4817 <= cap(yyv4817) { - yyv4817 = yyv4817[:yyrl4817] + yyrg4808 := len(yyv4808) > 0 + yyv24808 := yyv4808 + yyrl4808, yyrt4808 = z.DecInferLen(yyl4808, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4808 { + if yyrl4808 <= cap(yyv4808) { + yyv4808 = yyv4808[:yyrl4808] } else { - yyv4817 = make([]AttachedVolume, yyrl4817) + yyv4808 = make([]AttachedVolume, yyrl4808) } } else { - yyv4817 = make([]AttachedVolume, yyrl4817) + yyv4808 = make([]AttachedVolume, yyrl4808) } - yyc4817 = true - yyrr4817 = len(yyv4817) - if yyrg4817 { - copy(yyv4817, yyv24817) + yyc4808 = true + yyrr4808 = len(yyv4808) + if yyrg4808 { + copy(yyv4808, yyv24808) } - } else if yyl4817 != len(yyv4817) { - yyv4817 = yyv4817[:yyl4817] - yyc4817 = true + } else if yyl4808 != len(yyv4808) { + yyv4808 = yyv4808[:yyl4808] + yyc4808 = true } - yyj4817 := 0 - for ; yyj4817 < yyrr4817; yyj4817++ { - yyh4817.ElemContainerState(yyj4817) + yyj4808 := 0 + for ; yyj4808 < yyrr4808; yyj4808++ { + yyh4808.ElemContainerState(yyj4808) if r.TryDecodeAsNil() { - yyv4817[yyj4817] = AttachedVolume{} + yyv4808[yyj4808] = AttachedVolume{} } else { - yyv4818 := &yyv4817[yyj4817] - yyv4818.CodecDecodeSelf(d) + yyv4809 := &yyv4808[yyj4808] + yyv4809.CodecDecodeSelf(d) } } - if yyrt4817 { - for ; yyj4817 < yyl4817; yyj4817++ { - yyv4817 = append(yyv4817, AttachedVolume{}) - yyh4817.ElemContainerState(yyj4817) + if yyrt4808 { + for ; yyj4808 < yyl4808; yyj4808++ { + yyv4808 = append(yyv4808, AttachedVolume{}) + yyh4808.ElemContainerState(yyj4808) if r.TryDecodeAsNil() { - yyv4817[yyj4817] = AttachedVolume{} + yyv4808[yyj4808] = AttachedVolume{} } else { - yyv4819 := &yyv4817[yyj4817] - yyv4819.CodecDecodeSelf(d) + yyv4810 := &yyv4808[yyj4808] + yyv4810.CodecDecodeSelf(d) } } } } else { - yyj4817 := 0 - for ; !r.CheckBreak(); yyj4817++ { + yyj4808 := 0 + for ; !r.CheckBreak(); yyj4808++ { - if yyj4817 >= len(yyv4817) { - yyv4817 = append(yyv4817, AttachedVolume{}) // var yyz4817 AttachedVolume - yyc4817 = true + if yyj4808 >= len(yyv4808) { + yyv4808 = append(yyv4808, AttachedVolume{}) // var yyz4808 AttachedVolume + yyc4808 = true } - yyh4817.ElemContainerState(yyj4817) - if yyj4817 < len(yyv4817) { + yyh4808.ElemContainerState(yyj4808) + if yyj4808 < len(yyv4808) { if r.TryDecodeAsNil() { - yyv4817[yyj4817] = AttachedVolume{} + yyv4808[yyj4808] = AttachedVolume{} } else { - yyv4820 := &yyv4817[yyj4817] - yyv4820.CodecDecodeSelf(d) + yyv4811 := &yyv4808[yyj4808] + yyv4811.CodecDecodeSelf(d) } } else { @@ -61359,17 +61277,17 @@ func (x codecSelfer1234) decSliceAttachedVolume(v *[]AttachedVolume, d *codec197 } } - if yyj4817 < len(yyv4817) { - yyv4817 = yyv4817[:yyj4817] - yyc4817 = true - } else if yyj4817 == 0 && yyv4817 == nil { - yyv4817 = []AttachedVolume{} - yyc4817 = true + if yyj4808 < len(yyv4808) { + yyv4808 = yyv4808[:yyj4808] + yyc4808 = true + } else if yyj4808 == 0 && yyv4808 == nil { + yyv4808 = []AttachedVolume{} + yyc4808 = true } } - yyh4817.End() - if yyc4817 { - *v = yyv4817 + yyh4808.End() + if yyc4808 { + *v = yyv4808 } } @@ -61378,10 +61296,10 @@ func (x codecSelfer1234) encSlicePreferAvoidPodsEntry(v []PreferAvoidPodsEntry, z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4821 := range v { + for _, yyv4812 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4822 := &yyv4821 - yy4822.CodecEncodeSelf(e) + yy4813 := &yyv4812 + yy4813.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61391,83 +61309,83 @@ func (x codecSelfer1234) decSlicePreferAvoidPodsEntry(v *[]PreferAvoidPodsEntry, z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4823 := *v - yyh4823, yyl4823 := z.DecSliceHelperStart() - var yyc4823 bool - if yyl4823 == 0 { - if yyv4823 == nil { - yyv4823 = []PreferAvoidPodsEntry{} - yyc4823 = true - } else if len(yyv4823) != 0 { - yyv4823 = yyv4823[:0] - yyc4823 = true + yyv4814 := *v + yyh4814, yyl4814 := z.DecSliceHelperStart() + var yyc4814 bool + if yyl4814 == 0 { + if yyv4814 == nil { + yyv4814 = []PreferAvoidPodsEntry{} + yyc4814 = true + } else if len(yyv4814) != 0 { + yyv4814 = yyv4814[:0] + yyc4814 = true } - } else if yyl4823 > 0 { - var yyrr4823, yyrl4823 int - var yyrt4823 bool - if yyl4823 > cap(yyv4823) { + } else if yyl4814 > 0 { + var yyrr4814, yyrl4814 int + var yyrt4814 bool + if yyl4814 > cap(yyv4814) { - yyrg4823 := len(yyv4823) > 0 - yyv24823 := yyv4823 - yyrl4823, yyrt4823 = z.DecInferLen(yyl4823, z.DecBasicHandle().MaxInitLen, 64) - if yyrt4823 { - if yyrl4823 <= cap(yyv4823) { - yyv4823 = yyv4823[:yyrl4823] + yyrg4814 := len(yyv4814) > 0 + yyv24814 := yyv4814 + yyrl4814, yyrt4814 = z.DecInferLen(yyl4814, z.DecBasicHandle().MaxInitLen, 64) + if yyrt4814 { + if yyrl4814 <= cap(yyv4814) { + yyv4814 = yyv4814[:yyrl4814] } else { - yyv4823 = make([]PreferAvoidPodsEntry, yyrl4823) + yyv4814 = make([]PreferAvoidPodsEntry, yyrl4814) } } else { - yyv4823 = make([]PreferAvoidPodsEntry, yyrl4823) + yyv4814 = make([]PreferAvoidPodsEntry, yyrl4814) } - yyc4823 = true - yyrr4823 = len(yyv4823) - if yyrg4823 { - copy(yyv4823, yyv24823) + yyc4814 = true + yyrr4814 = len(yyv4814) + if yyrg4814 { + copy(yyv4814, yyv24814) } - } else if yyl4823 != len(yyv4823) { - yyv4823 = yyv4823[:yyl4823] - yyc4823 = true + } else if yyl4814 != len(yyv4814) { + yyv4814 = yyv4814[:yyl4814] + yyc4814 = true } - yyj4823 := 0 - for ; yyj4823 < yyrr4823; yyj4823++ { - yyh4823.ElemContainerState(yyj4823) + yyj4814 := 0 + for ; yyj4814 < yyrr4814; yyj4814++ { + yyh4814.ElemContainerState(yyj4814) if r.TryDecodeAsNil() { - yyv4823[yyj4823] = PreferAvoidPodsEntry{} + yyv4814[yyj4814] = PreferAvoidPodsEntry{} } else { - yyv4824 := &yyv4823[yyj4823] - yyv4824.CodecDecodeSelf(d) + yyv4815 := &yyv4814[yyj4814] + yyv4815.CodecDecodeSelf(d) } } - if yyrt4823 { - for ; yyj4823 < yyl4823; yyj4823++ { - yyv4823 = append(yyv4823, PreferAvoidPodsEntry{}) - yyh4823.ElemContainerState(yyj4823) + if yyrt4814 { + for ; yyj4814 < yyl4814; yyj4814++ { + yyv4814 = append(yyv4814, PreferAvoidPodsEntry{}) + yyh4814.ElemContainerState(yyj4814) if r.TryDecodeAsNil() { - yyv4823[yyj4823] = PreferAvoidPodsEntry{} + yyv4814[yyj4814] = PreferAvoidPodsEntry{} } else { - yyv4825 := &yyv4823[yyj4823] - yyv4825.CodecDecodeSelf(d) + yyv4816 := &yyv4814[yyj4814] + yyv4816.CodecDecodeSelf(d) } } } } else { - yyj4823 := 0 - for ; !r.CheckBreak(); yyj4823++ { + yyj4814 := 0 + for ; !r.CheckBreak(); yyj4814++ { - if yyj4823 >= len(yyv4823) { - yyv4823 = append(yyv4823, PreferAvoidPodsEntry{}) // var yyz4823 PreferAvoidPodsEntry - yyc4823 = true + if yyj4814 >= len(yyv4814) { + yyv4814 = append(yyv4814, PreferAvoidPodsEntry{}) // var yyz4814 PreferAvoidPodsEntry + yyc4814 = true } - yyh4823.ElemContainerState(yyj4823) - if yyj4823 < len(yyv4823) { + yyh4814.ElemContainerState(yyj4814) + if yyj4814 < len(yyv4814) { if r.TryDecodeAsNil() { - yyv4823[yyj4823] = PreferAvoidPodsEntry{} + yyv4814[yyj4814] = PreferAvoidPodsEntry{} } else { - yyv4826 := &yyv4823[yyj4823] - yyv4826.CodecDecodeSelf(d) + yyv4817 := &yyv4814[yyj4814] + yyv4817.CodecDecodeSelf(d) } } else { @@ -61475,17 +61393,17 @@ func (x codecSelfer1234) decSlicePreferAvoidPodsEntry(v *[]PreferAvoidPodsEntry, } } - if yyj4823 < len(yyv4823) { - yyv4823 = yyv4823[:yyj4823] - yyc4823 = true - } else if yyj4823 == 0 && yyv4823 == nil { - yyv4823 = []PreferAvoidPodsEntry{} - yyc4823 = true + if yyj4814 < len(yyv4814) { + yyv4814 = yyv4814[:yyj4814] + yyc4814 = true + } else if yyj4814 == 0 && yyv4814 == nil { + yyv4814 = []PreferAvoidPodsEntry{} + yyc4814 = true } } - yyh4823.End() - if yyc4823 { - *v = yyv4823 + yyh4814.End() + if yyc4814 { + *v = yyv4814 } } @@ -61494,19 +61412,19 @@ func (x codecSelfer1234) encResourceList(v ResourceList, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeMapStart(len(v)) - for yyk4827, yyv4827 := range v { + for yyk4818, yyv4818 := range v { z.EncSendContainerState(codecSelfer_containerMapKey1234) - yyk4827.CodecEncodeSelf(e) + yyk4818.CodecEncodeSelf(e) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4828 := &yyv4827 - yym4829 := z.EncBinary() - _ = yym4829 + yy4819 := &yyv4818 + yym4820 := z.EncBinary() + _ = yym4820 if false { - } else if z.HasExtensions() && z.EncExt(yy4828) { - } else if !yym4829 && z.IsJSONHandle() { - z.EncJSONMarshal(yy4828) + } else if z.HasExtensions() && z.EncExt(yy4819) { + } else if !yym4820 && z.IsJSONHandle() { + z.EncJSONMarshal(yy4819) } else { - z.EncFallback(yy4828) + z.EncFallback(yy4819) } } z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -61517,86 +61435,86 @@ func (x codecSelfer1234) decResourceList(v *ResourceList, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4830 := *v - yyl4830 := r.ReadMapStart() - yybh4830 := z.DecBasicHandle() - if yyv4830 == nil { - yyrl4830, _ := z.DecInferLen(yyl4830, yybh4830.MaxInitLen, 72) - yyv4830 = make(map[ResourceName]pkg3_resource.Quantity, yyrl4830) - *v = yyv4830 + yyv4821 := *v + yyl4821 := r.ReadMapStart() + yybh4821 := z.DecBasicHandle() + if yyv4821 == nil { + yyrl4821, _ := z.DecInferLen(yyl4821, yybh4821.MaxInitLen, 72) + yyv4821 = make(map[ResourceName]pkg3_resource.Quantity, yyrl4821) + *v = yyv4821 } - var yymk4830 ResourceName - var yymv4830 pkg3_resource.Quantity - var yymg4830 bool - if yybh4830.MapValueReset { - yymg4830 = true + var yymk4821 ResourceName + var yymv4821 pkg3_resource.Quantity + var yymg4821 bool + if yybh4821.MapValueReset { + yymg4821 = true } - if yyl4830 > 0 { - for yyj4830 := 0; yyj4830 < yyl4830; yyj4830++ { + if yyl4821 > 0 { + for yyj4821 := 0; yyj4821 < yyl4821; yyj4821++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4830 = "" + yymk4821 = "" } else { - yymk4830 = ResourceName(r.DecodeString()) + yymk4821 = ResourceName(r.DecodeString()) } - if yymg4830 { - yymv4830 = yyv4830[yymk4830] + if yymg4821 { + yymv4821 = yyv4821[yymk4821] } else { - yymv4830 = pkg3_resource.Quantity{} + yymv4821 = pkg3_resource.Quantity{} } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4830 = pkg3_resource.Quantity{} + yymv4821 = pkg3_resource.Quantity{} } else { - yyv4832 := &yymv4830 - yym4833 := z.DecBinary() - _ = yym4833 + yyv4823 := &yymv4821 + yym4824 := z.DecBinary() + _ = yym4824 if false { - } else if z.HasExtensions() && z.DecExt(yyv4832) { - } else if !yym4833 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4832) + } else if z.HasExtensions() && z.DecExt(yyv4823) { + } else if !yym4824 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4823) } else { - z.DecFallback(yyv4832, false) + z.DecFallback(yyv4823, false) } } - if yyv4830 != nil { - yyv4830[yymk4830] = yymv4830 + if yyv4821 != nil { + yyv4821[yymk4821] = yymv4821 } } - } else if yyl4830 < 0 { - for yyj4830 := 0; !r.CheckBreak(); yyj4830++ { + } else if yyl4821 < 0 { + for yyj4821 := 0; !r.CheckBreak(); yyj4821++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4830 = "" + yymk4821 = "" } else { - yymk4830 = ResourceName(r.DecodeString()) + yymk4821 = ResourceName(r.DecodeString()) } - if yymg4830 { - yymv4830 = yyv4830[yymk4830] + if yymg4821 { + yymv4821 = yyv4821[yymk4821] } else { - yymv4830 = pkg3_resource.Quantity{} + yymv4821 = pkg3_resource.Quantity{} } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4830 = pkg3_resource.Quantity{} + yymv4821 = pkg3_resource.Quantity{} } else { - yyv4835 := &yymv4830 - yym4836 := z.DecBinary() - _ = yym4836 + yyv4826 := &yymv4821 + yym4827 := z.DecBinary() + _ = yym4827 if false { - } else if z.HasExtensions() && z.DecExt(yyv4835) { - } else if !yym4836 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4835) + } else if z.HasExtensions() && z.DecExt(yyv4826) { + } else if !yym4827 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4826) } else { - z.DecFallback(yyv4835, false) + z.DecFallback(yyv4826, false) } } - if yyv4830 != nil { - yyv4830[yymk4830] = yymv4830 + if yyv4821 != nil { + yyv4821[yymk4821] = yymv4821 } } } // else len==0: TODO: Should we clear map entries? @@ -61608,10 +61526,10 @@ func (x codecSelfer1234) encSliceNode(v []Node, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4837 := range v { + for _, yyv4828 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4838 := &yyv4837 - yy4838.CodecEncodeSelf(e) + yy4829 := &yyv4828 + yy4829.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61621,83 +61539,83 @@ func (x codecSelfer1234) decSliceNode(v *[]Node, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4839 := *v - yyh4839, yyl4839 := z.DecSliceHelperStart() - var yyc4839 bool - if yyl4839 == 0 { - if yyv4839 == nil { - yyv4839 = []Node{} - yyc4839 = true - } else if len(yyv4839) != 0 { - yyv4839 = yyv4839[:0] - yyc4839 = true + yyv4830 := *v + yyh4830, yyl4830 := z.DecSliceHelperStart() + var yyc4830 bool + if yyl4830 == 0 { + if yyv4830 == nil { + yyv4830 = []Node{} + yyc4830 = true + } else if len(yyv4830) != 0 { + yyv4830 = yyv4830[:0] + yyc4830 = true } - } else if yyl4839 > 0 { - var yyrr4839, yyrl4839 int - var yyrt4839 bool - if yyl4839 > cap(yyv4839) { + } else if yyl4830 > 0 { + var yyrr4830, yyrl4830 int + var yyrt4830 bool + if yyl4830 > cap(yyv4830) { - yyrg4839 := len(yyv4839) > 0 - yyv24839 := yyv4839 - yyrl4839, yyrt4839 = z.DecInferLen(yyl4839, z.DecBasicHandle().MaxInitLen, 632) - if yyrt4839 { - if yyrl4839 <= cap(yyv4839) { - yyv4839 = yyv4839[:yyrl4839] + yyrg4830 := len(yyv4830) > 0 + yyv24830 := yyv4830 + yyrl4830, yyrt4830 = z.DecInferLen(yyl4830, z.DecBasicHandle().MaxInitLen, 632) + if yyrt4830 { + if yyrl4830 <= cap(yyv4830) { + yyv4830 = yyv4830[:yyrl4830] } else { - yyv4839 = make([]Node, yyrl4839) + yyv4830 = make([]Node, yyrl4830) } } else { - yyv4839 = make([]Node, yyrl4839) + yyv4830 = make([]Node, yyrl4830) } - yyc4839 = true - yyrr4839 = len(yyv4839) - if yyrg4839 { - copy(yyv4839, yyv24839) + yyc4830 = true + yyrr4830 = len(yyv4830) + if yyrg4830 { + copy(yyv4830, yyv24830) } - } else if yyl4839 != len(yyv4839) { - yyv4839 = yyv4839[:yyl4839] - yyc4839 = true + } else if yyl4830 != len(yyv4830) { + yyv4830 = yyv4830[:yyl4830] + yyc4830 = true } - yyj4839 := 0 - for ; yyj4839 < yyrr4839; yyj4839++ { - yyh4839.ElemContainerState(yyj4839) + yyj4830 := 0 + for ; yyj4830 < yyrr4830; yyj4830++ { + yyh4830.ElemContainerState(yyj4830) if r.TryDecodeAsNil() { - yyv4839[yyj4839] = Node{} + yyv4830[yyj4830] = Node{} } else { - yyv4840 := &yyv4839[yyj4839] - yyv4840.CodecDecodeSelf(d) + yyv4831 := &yyv4830[yyj4830] + yyv4831.CodecDecodeSelf(d) } } - if yyrt4839 { - for ; yyj4839 < yyl4839; yyj4839++ { - yyv4839 = append(yyv4839, Node{}) - yyh4839.ElemContainerState(yyj4839) + if yyrt4830 { + for ; yyj4830 < yyl4830; yyj4830++ { + yyv4830 = append(yyv4830, Node{}) + yyh4830.ElemContainerState(yyj4830) if r.TryDecodeAsNil() { - yyv4839[yyj4839] = Node{} + yyv4830[yyj4830] = Node{} } else { - yyv4841 := &yyv4839[yyj4839] - yyv4841.CodecDecodeSelf(d) + yyv4832 := &yyv4830[yyj4830] + yyv4832.CodecDecodeSelf(d) } } } } else { - yyj4839 := 0 - for ; !r.CheckBreak(); yyj4839++ { + yyj4830 := 0 + for ; !r.CheckBreak(); yyj4830++ { - if yyj4839 >= len(yyv4839) { - yyv4839 = append(yyv4839, Node{}) // var yyz4839 Node - yyc4839 = true + if yyj4830 >= len(yyv4830) { + yyv4830 = append(yyv4830, Node{}) // var yyz4830 Node + yyc4830 = true } - yyh4839.ElemContainerState(yyj4839) - if yyj4839 < len(yyv4839) { + yyh4830.ElemContainerState(yyj4830) + if yyj4830 < len(yyv4830) { if r.TryDecodeAsNil() { - yyv4839[yyj4839] = Node{} + yyv4830[yyj4830] = Node{} } else { - yyv4842 := &yyv4839[yyj4839] - yyv4842.CodecDecodeSelf(d) + yyv4833 := &yyv4830[yyj4830] + yyv4833.CodecDecodeSelf(d) } } else { @@ -61705,17 +61623,17 @@ func (x codecSelfer1234) decSliceNode(v *[]Node, d *codec1978.Decoder) { } } - if yyj4839 < len(yyv4839) { - yyv4839 = yyv4839[:yyj4839] - yyc4839 = true - } else if yyj4839 == 0 && yyv4839 == nil { - yyv4839 = []Node{} - yyc4839 = true + if yyj4830 < len(yyv4830) { + yyv4830 = yyv4830[:yyj4830] + yyc4830 = true + } else if yyj4830 == 0 && yyv4830 == nil { + yyv4830 = []Node{} + yyc4830 = true } } - yyh4839.End() - if yyc4839 { - *v = yyv4839 + yyh4830.End() + if yyc4830 { + *v = yyv4830 } } @@ -61724,9 +61642,9 @@ func (x codecSelfer1234) encSliceFinalizerName(v []FinalizerName, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4843 := range v { + for _, yyv4834 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4843.CodecEncodeSelf(e) + yyv4834.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61736,75 +61654,75 @@ func (x codecSelfer1234) decSliceFinalizerName(v *[]FinalizerName, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4844 := *v - yyh4844, yyl4844 := z.DecSliceHelperStart() - var yyc4844 bool - if yyl4844 == 0 { - if yyv4844 == nil { - yyv4844 = []FinalizerName{} - yyc4844 = true - } else if len(yyv4844) != 0 { - yyv4844 = yyv4844[:0] - yyc4844 = true + yyv4835 := *v + yyh4835, yyl4835 := z.DecSliceHelperStart() + var yyc4835 bool + if yyl4835 == 0 { + if yyv4835 == nil { + yyv4835 = []FinalizerName{} + yyc4835 = true + } else if len(yyv4835) != 0 { + yyv4835 = yyv4835[:0] + yyc4835 = true } - } else if yyl4844 > 0 { - var yyrr4844, yyrl4844 int - var yyrt4844 bool - if yyl4844 > cap(yyv4844) { + } else if yyl4835 > 0 { + var yyrr4835, yyrl4835 int + var yyrt4835 bool + if yyl4835 > cap(yyv4835) { - yyrl4844, yyrt4844 = z.DecInferLen(yyl4844, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4844 { - if yyrl4844 <= cap(yyv4844) { - yyv4844 = yyv4844[:yyrl4844] + yyrl4835, yyrt4835 = z.DecInferLen(yyl4835, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4835 { + if yyrl4835 <= cap(yyv4835) { + yyv4835 = yyv4835[:yyrl4835] } else { - yyv4844 = make([]FinalizerName, yyrl4844) + yyv4835 = make([]FinalizerName, yyrl4835) } } else { - yyv4844 = make([]FinalizerName, yyrl4844) + yyv4835 = make([]FinalizerName, yyrl4835) } - yyc4844 = true - yyrr4844 = len(yyv4844) - } else if yyl4844 != len(yyv4844) { - yyv4844 = yyv4844[:yyl4844] - yyc4844 = true + yyc4835 = true + yyrr4835 = len(yyv4835) + } else if yyl4835 != len(yyv4835) { + yyv4835 = yyv4835[:yyl4835] + yyc4835 = true } - yyj4844 := 0 - for ; yyj4844 < yyrr4844; yyj4844++ { - yyh4844.ElemContainerState(yyj4844) + yyj4835 := 0 + for ; yyj4835 < yyrr4835; yyj4835++ { + yyh4835.ElemContainerState(yyj4835) if r.TryDecodeAsNil() { - yyv4844[yyj4844] = "" + yyv4835[yyj4835] = "" } else { - yyv4844[yyj4844] = FinalizerName(r.DecodeString()) + yyv4835[yyj4835] = FinalizerName(r.DecodeString()) } } - if yyrt4844 { - for ; yyj4844 < yyl4844; yyj4844++ { - yyv4844 = append(yyv4844, "") - yyh4844.ElemContainerState(yyj4844) + if yyrt4835 { + for ; yyj4835 < yyl4835; yyj4835++ { + yyv4835 = append(yyv4835, "") + yyh4835.ElemContainerState(yyj4835) if r.TryDecodeAsNil() { - yyv4844[yyj4844] = "" + yyv4835[yyj4835] = "" } else { - yyv4844[yyj4844] = FinalizerName(r.DecodeString()) + yyv4835[yyj4835] = FinalizerName(r.DecodeString()) } } } } else { - yyj4844 := 0 - for ; !r.CheckBreak(); yyj4844++ { + yyj4835 := 0 + for ; !r.CheckBreak(); yyj4835++ { - if yyj4844 >= len(yyv4844) { - yyv4844 = append(yyv4844, "") // var yyz4844 FinalizerName - yyc4844 = true + if yyj4835 >= len(yyv4835) { + yyv4835 = append(yyv4835, "") // var yyz4835 FinalizerName + yyc4835 = true } - yyh4844.ElemContainerState(yyj4844) - if yyj4844 < len(yyv4844) { + yyh4835.ElemContainerState(yyj4835) + if yyj4835 < len(yyv4835) { if r.TryDecodeAsNil() { - yyv4844[yyj4844] = "" + yyv4835[yyj4835] = "" } else { - yyv4844[yyj4844] = FinalizerName(r.DecodeString()) + yyv4835[yyj4835] = FinalizerName(r.DecodeString()) } } else { @@ -61812,17 +61730,17 @@ func (x codecSelfer1234) decSliceFinalizerName(v *[]FinalizerName, d *codec1978. } } - if yyj4844 < len(yyv4844) { - yyv4844 = yyv4844[:yyj4844] - yyc4844 = true - } else if yyj4844 == 0 && yyv4844 == nil { - yyv4844 = []FinalizerName{} - yyc4844 = true + if yyj4835 < len(yyv4835) { + yyv4835 = yyv4835[:yyj4835] + yyc4835 = true + } else if yyj4835 == 0 && yyv4835 == nil { + yyv4835 = []FinalizerName{} + yyc4835 = true } } - yyh4844.End() - if yyc4844 { - *v = yyv4844 + yyh4835.End() + if yyc4835 { + *v = yyv4835 } } @@ -61831,10 +61749,10 @@ func (x codecSelfer1234) encSliceNamespace(v []Namespace, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4848 := range v { + for _, yyv4839 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4849 := &yyv4848 - yy4849.CodecEncodeSelf(e) + yy4840 := &yyv4839 + yy4840.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61844,83 +61762,83 @@ func (x codecSelfer1234) decSliceNamespace(v *[]Namespace, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4850 := *v - yyh4850, yyl4850 := z.DecSliceHelperStart() - var yyc4850 bool - if yyl4850 == 0 { - if yyv4850 == nil { - yyv4850 = []Namespace{} - yyc4850 = true - } else if len(yyv4850) != 0 { - yyv4850 = yyv4850[:0] - yyc4850 = true + yyv4841 := *v + yyh4841, yyl4841 := z.DecSliceHelperStart() + var yyc4841 bool + if yyl4841 == 0 { + if yyv4841 == nil { + yyv4841 = []Namespace{} + yyc4841 = true + } else if len(yyv4841) != 0 { + yyv4841 = yyv4841[:0] + yyc4841 = true } - } else if yyl4850 > 0 { - var yyrr4850, yyrl4850 int - var yyrt4850 bool - if yyl4850 > cap(yyv4850) { + } else if yyl4841 > 0 { + var yyrr4841, yyrl4841 int + var yyrt4841 bool + if yyl4841 > cap(yyv4841) { - yyrg4850 := len(yyv4850) > 0 - yyv24850 := yyv4850 - yyrl4850, yyrt4850 = z.DecInferLen(yyl4850, z.DecBasicHandle().MaxInitLen, 296) - if yyrt4850 { - if yyrl4850 <= cap(yyv4850) { - yyv4850 = yyv4850[:yyrl4850] + yyrg4841 := len(yyv4841) > 0 + yyv24841 := yyv4841 + yyrl4841, yyrt4841 = z.DecInferLen(yyl4841, z.DecBasicHandle().MaxInitLen, 296) + if yyrt4841 { + if yyrl4841 <= cap(yyv4841) { + yyv4841 = yyv4841[:yyrl4841] } else { - yyv4850 = make([]Namespace, yyrl4850) + yyv4841 = make([]Namespace, yyrl4841) } } else { - yyv4850 = make([]Namespace, yyrl4850) + yyv4841 = make([]Namespace, yyrl4841) } - yyc4850 = true - yyrr4850 = len(yyv4850) - if yyrg4850 { - copy(yyv4850, yyv24850) + yyc4841 = true + yyrr4841 = len(yyv4841) + if yyrg4841 { + copy(yyv4841, yyv24841) } - } else if yyl4850 != len(yyv4850) { - yyv4850 = yyv4850[:yyl4850] - yyc4850 = true + } else if yyl4841 != len(yyv4841) { + yyv4841 = yyv4841[:yyl4841] + yyc4841 = true } - yyj4850 := 0 - for ; yyj4850 < yyrr4850; yyj4850++ { - yyh4850.ElemContainerState(yyj4850) + yyj4841 := 0 + for ; yyj4841 < yyrr4841; yyj4841++ { + yyh4841.ElemContainerState(yyj4841) if r.TryDecodeAsNil() { - yyv4850[yyj4850] = Namespace{} + yyv4841[yyj4841] = Namespace{} } else { - yyv4851 := &yyv4850[yyj4850] - yyv4851.CodecDecodeSelf(d) + yyv4842 := &yyv4841[yyj4841] + yyv4842.CodecDecodeSelf(d) } } - if yyrt4850 { - for ; yyj4850 < yyl4850; yyj4850++ { - yyv4850 = append(yyv4850, Namespace{}) - yyh4850.ElemContainerState(yyj4850) + if yyrt4841 { + for ; yyj4841 < yyl4841; yyj4841++ { + yyv4841 = append(yyv4841, Namespace{}) + yyh4841.ElemContainerState(yyj4841) if r.TryDecodeAsNil() { - yyv4850[yyj4850] = Namespace{} + yyv4841[yyj4841] = Namespace{} } else { - yyv4852 := &yyv4850[yyj4850] - yyv4852.CodecDecodeSelf(d) + yyv4843 := &yyv4841[yyj4841] + yyv4843.CodecDecodeSelf(d) } } } } else { - yyj4850 := 0 - for ; !r.CheckBreak(); yyj4850++ { + yyj4841 := 0 + for ; !r.CheckBreak(); yyj4841++ { - if yyj4850 >= len(yyv4850) { - yyv4850 = append(yyv4850, Namespace{}) // var yyz4850 Namespace - yyc4850 = true + if yyj4841 >= len(yyv4841) { + yyv4841 = append(yyv4841, Namespace{}) // var yyz4841 Namespace + yyc4841 = true } - yyh4850.ElemContainerState(yyj4850) - if yyj4850 < len(yyv4850) { + yyh4841.ElemContainerState(yyj4841) + if yyj4841 < len(yyv4841) { if r.TryDecodeAsNil() { - yyv4850[yyj4850] = Namespace{} + yyv4841[yyj4841] = Namespace{} } else { - yyv4853 := &yyv4850[yyj4850] - yyv4853.CodecDecodeSelf(d) + yyv4844 := &yyv4841[yyj4841] + yyv4844.CodecDecodeSelf(d) } } else { @@ -61928,17 +61846,17 @@ func (x codecSelfer1234) decSliceNamespace(v *[]Namespace, d *codec1978.Decoder) } } - if yyj4850 < len(yyv4850) { - yyv4850 = yyv4850[:yyj4850] - yyc4850 = true - } else if yyj4850 == 0 && yyv4850 == nil { - yyv4850 = []Namespace{} - yyc4850 = true + if yyj4841 < len(yyv4841) { + yyv4841 = yyv4841[:yyj4841] + yyc4841 = true + } else if yyj4841 == 0 && yyv4841 == nil { + yyv4841 = []Namespace{} + yyc4841 = true } } - yyh4850.End() - if yyc4850 { - *v = yyv4850 + yyh4841.End() + if yyc4841 { + *v = yyv4841 } } @@ -61947,10 +61865,10 @@ func (x codecSelfer1234) encSliceEvent(v []Event, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4854 := range v { + for _, yyv4845 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4855 := &yyv4854 - yy4855.CodecEncodeSelf(e) + yy4846 := &yyv4845 + yy4846.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61960,83 +61878,83 @@ func (x codecSelfer1234) decSliceEvent(v *[]Event, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4856 := *v - yyh4856, yyl4856 := z.DecSliceHelperStart() - var yyc4856 bool - if yyl4856 == 0 { - if yyv4856 == nil { - yyv4856 = []Event{} - yyc4856 = true - } else if len(yyv4856) != 0 { - yyv4856 = yyv4856[:0] - yyc4856 = true + yyv4847 := *v + yyh4847, yyl4847 := z.DecSliceHelperStart() + var yyc4847 bool + if yyl4847 == 0 { + if yyv4847 == nil { + yyv4847 = []Event{} + yyc4847 = true + } else if len(yyv4847) != 0 { + yyv4847 = yyv4847[:0] + yyc4847 = true } - } else if yyl4856 > 0 { - var yyrr4856, yyrl4856 int - var yyrt4856 bool - if yyl4856 > cap(yyv4856) { + } else if yyl4847 > 0 { + var yyrr4847, yyrl4847 int + var yyrt4847 bool + if yyl4847 > cap(yyv4847) { - yyrg4856 := len(yyv4856) > 0 - yyv24856 := yyv4856 - yyrl4856, yyrt4856 = z.DecInferLen(yyl4856, z.DecBasicHandle().MaxInitLen, 504) - if yyrt4856 { - if yyrl4856 <= cap(yyv4856) { - yyv4856 = yyv4856[:yyrl4856] + yyrg4847 := len(yyv4847) > 0 + yyv24847 := yyv4847 + yyrl4847, yyrt4847 = z.DecInferLen(yyl4847, z.DecBasicHandle().MaxInitLen, 504) + if yyrt4847 { + if yyrl4847 <= cap(yyv4847) { + yyv4847 = yyv4847[:yyrl4847] } else { - yyv4856 = make([]Event, yyrl4856) + yyv4847 = make([]Event, yyrl4847) } } else { - yyv4856 = make([]Event, yyrl4856) + yyv4847 = make([]Event, yyrl4847) } - yyc4856 = true - yyrr4856 = len(yyv4856) - if yyrg4856 { - copy(yyv4856, yyv24856) + yyc4847 = true + yyrr4847 = len(yyv4847) + if yyrg4847 { + copy(yyv4847, yyv24847) } - } else if yyl4856 != len(yyv4856) { - yyv4856 = yyv4856[:yyl4856] - yyc4856 = true + } else if yyl4847 != len(yyv4847) { + yyv4847 = yyv4847[:yyl4847] + yyc4847 = true } - yyj4856 := 0 - for ; yyj4856 < yyrr4856; yyj4856++ { - yyh4856.ElemContainerState(yyj4856) + yyj4847 := 0 + for ; yyj4847 < yyrr4847; yyj4847++ { + yyh4847.ElemContainerState(yyj4847) if r.TryDecodeAsNil() { - yyv4856[yyj4856] = Event{} + yyv4847[yyj4847] = Event{} } else { - yyv4857 := &yyv4856[yyj4856] - yyv4857.CodecDecodeSelf(d) + yyv4848 := &yyv4847[yyj4847] + yyv4848.CodecDecodeSelf(d) } } - if yyrt4856 { - for ; yyj4856 < yyl4856; yyj4856++ { - yyv4856 = append(yyv4856, Event{}) - yyh4856.ElemContainerState(yyj4856) + if yyrt4847 { + for ; yyj4847 < yyl4847; yyj4847++ { + yyv4847 = append(yyv4847, Event{}) + yyh4847.ElemContainerState(yyj4847) if r.TryDecodeAsNil() { - yyv4856[yyj4856] = Event{} + yyv4847[yyj4847] = Event{} } else { - yyv4858 := &yyv4856[yyj4856] - yyv4858.CodecDecodeSelf(d) + yyv4849 := &yyv4847[yyj4847] + yyv4849.CodecDecodeSelf(d) } } } } else { - yyj4856 := 0 - for ; !r.CheckBreak(); yyj4856++ { + yyj4847 := 0 + for ; !r.CheckBreak(); yyj4847++ { - if yyj4856 >= len(yyv4856) { - yyv4856 = append(yyv4856, Event{}) // var yyz4856 Event - yyc4856 = true + if yyj4847 >= len(yyv4847) { + yyv4847 = append(yyv4847, Event{}) // var yyz4847 Event + yyc4847 = true } - yyh4856.ElemContainerState(yyj4856) - if yyj4856 < len(yyv4856) { + yyh4847.ElemContainerState(yyj4847) + if yyj4847 < len(yyv4847) { if r.TryDecodeAsNil() { - yyv4856[yyj4856] = Event{} + yyv4847[yyj4847] = Event{} } else { - yyv4859 := &yyv4856[yyj4856] - yyv4859.CodecDecodeSelf(d) + yyv4850 := &yyv4847[yyj4847] + yyv4850.CodecDecodeSelf(d) } } else { @@ -62044,17 +61962,17 @@ func (x codecSelfer1234) decSliceEvent(v *[]Event, d *codec1978.Decoder) { } } - if yyj4856 < len(yyv4856) { - yyv4856 = yyv4856[:yyj4856] - yyc4856 = true - } else if yyj4856 == 0 && yyv4856 == nil { - yyv4856 = []Event{} - yyc4856 = true + if yyj4847 < len(yyv4847) { + yyv4847 = yyv4847[:yyj4847] + yyc4847 = true + } else if yyj4847 == 0 && yyv4847 == nil { + yyv4847 = []Event{} + yyc4847 = true } } - yyh4856.End() - if yyc4856 { - *v = yyv4856 + yyh4847.End() + if yyc4847 { + *v = yyv4847 } } @@ -62063,17 +61981,17 @@ func (x codecSelfer1234) encSliceruntime_Object(v []pkg7_runtime.Object, e *code z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4860 := range v { + for _, yyv4851 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyv4860 == nil { + if yyv4851 == nil { r.EncodeNil() } else { - yym4861 := z.EncBinary() - _ = yym4861 + yym4852 := z.EncBinary() + _ = yym4852 if false { - } else if z.HasExtensions() && z.EncExt(yyv4860) { + } else if z.HasExtensions() && z.EncExt(yyv4851) { } else { - z.EncFallback(yyv4860) + z.EncFallback(yyv4851) } } } @@ -62085,12 +62003,146 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r + yyv4853 := *v + yyh4853, yyl4853 := z.DecSliceHelperStart() + var yyc4853 bool + if yyl4853 == 0 { + if yyv4853 == nil { + yyv4853 = []pkg7_runtime.Object{} + yyc4853 = true + } else if len(yyv4853) != 0 { + yyv4853 = yyv4853[:0] + yyc4853 = true + } + } else if yyl4853 > 0 { + var yyrr4853, yyrl4853 int + var yyrt4853 bool + if yyl4853 > cap(yyv4853) { + + yyrg4853 := len(yyv4853) > 0 + yyv24853 := yyv4853 + yyrl4853, yyrt4853 = z.DecInferLen(yyl4853, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4853 { + if yyrl4853 <= cap(yyv4853) { + yyv4853 = yyv4853[:yyrl4853] + } else { + yyv4853 = make([]pkg7_runtime.Object, yyrl4853) + } + } else { + yyv4853 = make([]pkg7_runtime.Object, yyrl4853) + } + yyc4853 = true + yyrr4853 = len(yyv4853) + if yyrg4853 { + copy(yyv4853, yyv24853) + } + } else if yyl4853 != len(yyv4853) { + yyv4853 = yyv4853[:yyl4853] + yyc4853 = true + } + yyj4853 := 0 + for ; yyj4853 < yyrr4853; yyj4853++ { + yyh4853.ElemContainerState(yyj4853) + if r.TryDecodeAsNil() { + yyv4853[yyj4853] = nil + } else { + yyv4854 := &yyv4853[yyj4853] + yym4855 := z.DecBinary() + _ = yym4855 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4854) { + } else { + z.DecFallback(yyv4854, true) + } + } + + } + if yyrt4853 { + for ; yyj4853 < yyl4853; yyj4853++ { + yyv4853 = append(yyv4853, nil) + yyh4853.ElemContainerState(yyj4853) + if r.TryDecodeAsNil() { + yyv4853[yyj4853] = nil + } else { + yyv4856 := &yyv4853[yyj4853] + yym4857 := z.DecBinary() + _ = yym4857 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4856) { + } else { + z.DecFallback(yyv4856, true) + } + } + + } + } + + } else { + yyj4853 := 0 + for ; !r.CheckBreak(); yyj4853++ { + + if yyj4853 >= len(yyv4853) { + yyv4853 = append(yyv4853, nil) // var yyz4853 pkg7_runtime.Object + yyc4853 = true + } + yyh4853.ElemContainerState(yyj4853) + if yyj4853 < len(yyv4853) { + if r.TryDecodeAsNil() { + yyv4853[yyj4853] = nil + } else { + yyv4858 := &yyv4853[yyj4853] + yym4859 := z.DecBinary() + _ = yym4859 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4858) { + } else { + z.DecFallback(yyv4858, true) + } + } + + } else { + z.DecSwallow() + } + + } + if yyj4853 < len(yyv4853) { + yyv4853 = yyv4853[:yyj4853] + yyc4853 = true + } else if yyj4853 == 0 && yyv4853 == nil { + yyv4853 = []pkg7_runtime.Object{} + yyc4853 = true + } + } + yyh4853.End() + if yyc4853 { + *v = yyv4853 + } +} + +func (x codecSelfer1234) encSliceLimitRangeItem(v []LimitRangeItem, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv4860 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy4861 := &yyv4860 + yy4861.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceLimitRangeItem(v *[]LimitRangeItem, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yyv4862 := *v yyh4862, yyl4862 := z.DecSliceHelperStart() var yyc4862 bool if yyl4862 == 0 { if yyv4862 == nil { - yyv4862 = []pkg7_runtime.Object{} + yyv4862 = []LimitRangeItem{} yyc4862 = true } else if len(yyv4862) != 0 { yyv4862 = yyv4862[:0] @@ -62103,15 +62155,15 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod yyrg4862 := len(yyv4862) > 0 yyv24862 := yyv4862 - yyrl4862, yyrt4862 = z.DecInferLen(yyl4862, z.DecBasicHandle().MaxInitLen, 16) + yyrl4862, yyrt4862 = z.DecInferLen(yyl4862, z.DecBasicHandle().MaxInitLen, 56) if yyrt4862 { if yyrl4862 <= cap(yyv4862) { yyv4862 = yyv4862[:yyrl4862] } else { - yyv4862 = make([]pkg7_runtime.Object, yyrl4862) + yyv4862 = make([]LimitRangeItem, yyrl4862) } } else { - yyv4862 = make([]pkg7_runtime.Object, yyrl4862) + yyv4862 = make([]LimitRangeItem, yyrl4862) } yyc4862 = true yyrr4862 = len(yyv4862) @@ -62126,34 +62178,22 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod for ; yyj4862 < yyrr4862; yyj4862++ { yyh4862.ElemContainerState(yyj4862) if r.TryDecodeAsNil() { - yyv4862[yyj4862] = nil + yyv4862[yyj4862] = LimitRangeItem{} } else { yyv4863 := &yyv4862[yyj4862] - yym4864 := z.DecBinary() - _ = yym4864 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4863) { - } else { - z.DecFallback(yyv4863, true) - } + yyv4863.CodecDecodeSelf(d) } } if yyrt4862 { for ; yyj4862 < yyl4862; yyj4862++ { - yyv4862 = append(yyv4862, nil) + yyv4862 = append(yyv4862, LimitRangeItem{}) yyh4862.ElemContainerState(yyj4862) if r.TryDecodeAsNil() { - yyv4862[yyj4862] = nil + yyv4862[yyj4862] = LimitRangeItem{} } else { - yyv4865 := &yyv4862[yyj4862] - yym4866 := z.DecBinary() - _ = yym4866 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4865) { - } else { - z.DecFallback(yyv4865, true) - } + yyv4864 := &yyv4862[yyj4862] + yyv4864.CodecDecodeSelf(d) } } @@ -62164,22 +62204,16 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod for ; !r.CheckBreak(); yyj4862++ { if yyj4862 >= len(yyv4862) { - yyv4862 = append(yyv4862, nil) // var yyz4862 pkg7_runtime.Object + yyv4862 = append(yyv4862, LimitRangeItem{}) // var yyz4862 LimitRangeItem yyc4862 = true } yyh4862.ElemContainerState(yyj4862) if yyj4862 < len(yyv4862) { if r.TryDecodeAsNil() { - yyv4862[yyj4862] = nil + yyv4862[yyj4862] = LimitRangeItem{} } else { - yyv4867 := &yyv4862[yyj4862] - yym4868 := z.DecBinary() - _ = yym4868 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4867) { - } else { - z.DecFallback(yyv4867, true) - } + yyv4865 := &yyv4862[yyj4862] + yyv4865.CodecDecodeSelf(d) } } else { @@ -62191,7 +62225,7 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod yyv4862 = yyv4862[:yyj4862] yyc4862 = true } else if yyj4862 == 0 && yyv4862 == nil { - yyv4862 = []pkg7_runtime.Object{} + yyv4862 = []LimitRangeItem{} yyc4862 = true } } @@ -62201,131 +62235,15 @@ func (x codecSelfer1234) decSliceruntime_Object(v *[]pkg7_runtime.Object, d *cod } } -func (x codecSelfer1234) encSliceLimitRangeItem(v []LimitRangeItem, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv4869 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4870 := &yyv4869 - yy4870.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceLimitRangeItem(v *[]LimitRangeItem, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv4871 := *v - yyh4871, yyl4871 := z.DecSliceHelperStart() - var yyc4871 bool - if yyl4871 == 0 { - if yyv4871 == nil { - yyv4871 = []LimitRangeItem{} - yyc4871 = true - } else if len(yyv4871) != 0 { - yyv4871 = yyv4871[:0] - yyc4871 = true - } - } else if yyl4871 > 0 { - var yyrr4871, yyrl4871 int - var yyrt4871 bool - if yyl4871 > cap(yyv4871) { - - yyrg4871 := len(yyv4871) > 0 - yyv24871 := yyv4871 - yyrl4871, yyrt4871 = z.DecInferLen(yyl4871, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4871 { - if yyrl4871 <= cap(yyv4871) { - yyv4871 = yyv4871[:yyrl4871] - } else { - yyv4871 = make([]LimitRangeItem, yyrl4871) - } - } else { - yyv4871 = make([]LimitRangeItem, yyrl4871) - } - yyc4871 = true - yyrr4871 = len(yyv4871) - if yyrg4871 { - copy(yyv4871, yyv24871) - } - } else if yyl4871 != len(yyv4871) { - yyv4871 = yyv4871[:yyl4871] - yyc4871 = true - } - yyj4871 := 0 - for ; yyj4871 < yyrr4871; yyj4871++ { - yyh4871.ElemContainerState(yyj4871) - if r.TryDecodeAsNil() { - yyv4871[yyj4871] = LimitRangeItem{} - } else { - yyv4872 := &yyv4871[yyj4871] - yyv4872.CodecDecodeSelf(d) - } - - } - if yyrt4871 { - for ; yyj4871 < yyl4871; yyj4871++ { - yyv4871 = append(yyv4871, LimitRangeItem{}) - yyh4871.ElemContainerState(yyj4871) - if r.TryDecodeAsNil() { - yyv4871[yyj4871] = LimitRangeItem{} - } else { - yyv4873 := &yyv4871[yyj4871] - yyv4873.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj4871 := 0 - for ; !r.CheckBreak(); yyj4871++ { - - if yyj4871 >= len(yyv4871) { - yyv4871 = append(yyv4871, LimitRangeItem{}) // var yyz4871 LimitRangeItem - yyc4871 = true - } - yyh4871.ElemContainerState(yyj4871) - if yyj4871 < len(yyv4871) { - if r.TryDecodeAsNil() { - yyv4871[yyj4871] = LimitRangeItem{} - } else { - yyv4874 := &yyv4871[yyj4871] - yyv4874.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj4871 < len(yyv4871) { - yyv4871 = yyv4871[:yyj4871] - yyc4871 = true - } else if yyj4871 == 0 && yyv4871 == nil { - yyv4871 = []LimitRangeItem{} - yyc4871 = true - } - } - yyh4871.End() - if yyc4871 { - *v = yyv4871 - } -} - func (x codecSelfer1234) encSliceLimitRange(v []LimitRange, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4875 := range v { + for _, yyv4866 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4876 := &yyv4875 - yy4876.CodecEncodeSelf(e) + yy4867 := &yyv4866 + yy4867.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62335,83 +62253,83 @@ func (x codecSelfer1234) decSliceLimitRange(v *[]LimitRange, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4877 := *v - yyh4877, yyl4877 := z.DecSliceHelperStart() - var yyc4877 bool - if yyl4877 == 0 { - if yyv4877 == nil { - yyv4877 = []LimitRange{} - yyc4877 = true - } else if len(yyv4877) != 0 { - yyv4877 = yyv4877[:0] - yyc4877 = true + yyv4868 := *v + yyh4868, yyl4868 := z.DecSliceHelperStart() + var yyc4868 bool + if yyl4868 == 0 { + if yyv4868 == nil { + yyv4868 = []LimitRange{} + yyc4868 = true + } else if len(yyv4868) != 0 { + yyv4868 = yyv4868[:0] + yyc4868 = true } - } else if yyl4877 > 0 { - var yyrr4877, yyrl4877 int - var yyrt4877 bool - if yyl4877 > cap(yyv4877) { + } else if yyl4868 > 0 { + var yyrr4868, yyrl4868 int + var yyrt4868 bool + if yyl4868 > cap(yyv4868) { - yyrg4877 := len(yyv4877) > 0 - yyv24877 := yyv4877 - yyrl4877, yyrt4877 = z.DecInferLen(yyl4877, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4877 { - if yyrl4877 <= cap(yyv4877) { - yyv4877 = yyv4877[:yyrl4877] + yyrg4868 := len(yyv4868) > 0 + yyv24868 := yyv4868 + yyrl4868, yyrt4868 = z.DecInferLen(yyl4868, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4868 { + if yyrl4868 <= cap(yyv4868) { + yyv4868 = yyv4868[:yyrl4868] } else { - yyv4877 = make([]LimitRange, yyrl4877) + yyv4868 = make([]LimitRange, yyrl4868) } } else { - yyv4877 = make([]LimitRange, yyrl4877) + yyv4868 = make([]LimitRange, yyrl4868) } - yyc4877 = true - yyrr4877 = len(yyv4877) - if yyrg4877 { - copy(yyv4877, yyv24877) + yyc4868 = true + yyrr4868 = len(yyv4868) + if yyrg4868 { + copy(yyv4868, yyv24868) } - } else if yyl4877 != len(yyv4877) { - yyv4877 = yyv4877[:yyl4877] - yyc4877 = true + } else if yyl4868 != len(yyv4868) { + yyv4868 = yyv4868[:yyl4868] + yyc4868 = true } - yyj4877 := 0 - for ; yyj4877 < yyrr4877; yyj4877++ { - yyh4877.ElemContainerState(yyj4877) + yyj4868 := 0 + for ; yyj4868 < yyrr4868; yyj4868++ { + yyh4868.ElemContainerState(yyj4868) if r.TryDecodeAsNil() { - yyv4877[yyj4877] = LimitRange{} + yyv4868[yyj4868] = LimitRange{} } else { - yyv4878 := &yyv4877[yyj4877] - yyv4878.CodecDecodeSelf(d) + yyv4869 := &yyv4868[yyj4868] + yyv4869.CodecDecodeSelf(d) } } - if yyrt4877 { - for ; yyj4877 < yyl4877; yyj4877++ { - yyv4877 = append(yyv4877, LimitRange{}) - yyh4877.ElemContainerState(yyj4877) + if yyrt4868 { + for ; yyj4868 < yyl4868; yyj4868++ { + yyv4868 = append(yyv4868, LimitRange{}) + yyh4868.ElemContainerState(yyj4868) if r.TryDecodeAsNil() { - yyv4877[yyj4877] = LimitRange{} + yyv4868[yyj4868] = LimitRange{} } else { - yyv4879 := &yyv4877[yyj4877] - yyv4879.CodecDecodeSelf(d) + yyv4870 := &yyv4868[yyj4868] + yyv4870.CodecDecodeSelf(d) } } } } else { - yyj4877 := 0 - for ; !r.CheckBreak(); yyj4877++ { + yyj4868 := 0 + for ; !r.CheckBreak(); yyj4868++ { - if yyj4877 >= len(yyv4877) { - yyv4877 = append(yyv4877, LimitRange{}) // var yyz4877 LimitRange - yyc4877 = true + if yyj4868 >= len(yyv4868) { + yyv4868 = append(yyv4868, LimitRange{}) // var yyz4868 LimitRange + yyc4868 = true } - yyh4877.ElemContainerState(yyj4877) - if yyj4877 < len(yyv4877) { + yyh4868.ElemContainerState(yyj4868) + if yyj4868 < len(yyv4868) { if r.TryDecodeAsNil() { - yyv4877[yyj4877] = LimitRange{} + yyv4868[yyj4868] = LimitRange{} } else { - yyv4880 := &yyv4877[yyj4877] - yyv4880.CodecDecodeSelf(d) + yyv4871 := &yyv4868[yyj4868] + yyv4871.CodecDecodeSelf(d) } } else { @@ -62419,17 +62337,17 @@ func (x codecSelfer1234) decSliceLimitRange(v *[]LimitRange, d *codec1978.Decode } } - if yyj4877 < len(yyv4877) { - yyv4877 = yyv4877[:yyj4877] - yyc4877 = true - } else if yyj4877 == 0 && yyv4877 == nil { - yyv4877 = []LimitRange{} - yyc4877 = true + if yyj4868 < len(yyv4868) { + yyv4868 = yyv4868[:yyj4868] + yyc4868 = true + } else if yyj4868 == 0 && yyv4868 == nil { + yyv4868 = []LimitRange{} + yyc4868 = true } } - yyh4877.End() - if yyc4877 { - *v = yyv4877 + yyh4868.End() + if yyc4868 { + *v = yyv4868 } } @@ -62438,9 +62356,9 @@ func (x codecSelfer1234) encSliceResourceQuotaScope(v []ResourceQuotaScope, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4881 := range v { + for _, yyv4872 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4881.CodecEncodeSelf(e) + yyv4872.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62450,75 +62368,75 @@ func (x codecSelfer1234) decSliceResourceQuotaScope(v *[]ResourceQuotaScope, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4882 := *v - yyh4882, yyl4882 := z.DecSliceHelperStart() - var yyc4882 bool - if yyl4882 == 0 { - if yyv4882 == nil { - yyv4882 = []ResourceQuotaScope{} - yyc4882 = true - } else if len(yyv4882) != 0 { - yyv4882 = yyv4882[:0] - yyc4882 = true + yyv4873 := *v + yyh4873, yyl4873 := z.DecSliceHelperStart() + var yyc4873 bool + if yyl4873 == 0 { + if yyv4873 == nil { + yyv4873 = []ResourceQuotaScope{} + yyc4873 = true + } else if len(yyv4873) != 0 { + yyv4873 = yyv4873[:0] + yyc4873 = true } - } else if yyl4882 > 0 { - var yyrr4882, yyrl4882 int - var yyrt4882 bool - if yyl4882 > cap(yyv4882) { + } else if yyl4873 > 0 { + var yyrr4873, yyrl4873 int + var yyrt4873 bool + if yyl4873 > cap(yyv4873) { - yyrl4882, yyrt4882 = z.DecInferLen(yyl4882, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4882 { - if yyrl4882 <= cap(yyv4882) { - yyv4882 = yyv4882[:yyrl4882] + yyrl4873, yyrt4873 = z.DecInferLen(yyl4873, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4873 { + if yyrl4873 <= cap(yyv4873) { + yyv4873 = yyv4873[:yyrl4873] } else { - yyv4882 = make([]ResourceQuotaScope, yyrl4882) + yyv4873 = make([]ResourceQuotaScope, yyrl4873) } } else { - yyv4882 = make([]ResourceQuotaScope, yyrl4882) + yyv4873 = make([]ResourceQuotaScope, yyrl4873) } - yyc4882 = true - yyrr4882 = len(yyv4882) - } else if yyl4882 != len(yyv4882) { - yyv4882 = yyv4882[:yyl4882] - yyc4882 = true + yyc4873 = true + yyrr4873 = len(yyv4873) + } else if yyl4873 != len(yyv4873) { + yyv4873 = yyv4873[:yyl4873] + yyc4873 = true } - yyj4882 := 0 - for ; yyj4882 < yyrr4882; yyj4882++ { - yyh4882.ElemContainerState(yyj4882) + yyj4873 := 0 + for ; yyj4873 < yyrr4873; yyj4873++ { + yyh4873.ElemContainerState(yyj4873) if r.TryDecodeAsNil() { - yyv4882[yyj4882] = "" + yyv4873[yyj4873] = "" } else { - yyv4882[yyj4882] = ResourceQuotaScope(r.DecodeString()) + yyv4873[yyj4873] = ResourceQuotaScope(r.DecodeString()) } } - if yyrt4882 { - for ; yyj4882 < yyl4882; yyj4882++ { - yyv4882 = append(yyv4882, "") - yyh4882.ElemContainerState(yyj4882) + if yyrt4873 { + for ; yyj4873 < yyl4873; yyj4873++ { + yyv4873 = append(yyv4873, "") + yyh4873.ElemContainerState(yyj4873) if r.TryDecodeAsNil() { - yyv4882[yyj4882] = "" + yyv4873[yyj4873] = "" } else { - yyv4882[yyj4882] = ResourceQuotaScope(r.DecodeString()) + yyv4873[yyj4873] = ResourceQuotaScope(r.DecodeString()) } } } } else { - yyj4882 := 0 - for ; !r.CheckBreak(); yyj4882++ { + yyj4873 := 0 + for ; !r.CheckBreak(); yyj4873++ { - if yyj4882 >= len(yyv4882) { - yyv4882 = append(yyv4882, "") // var yyz4882 ResourceQuotaScope - yyc4882 = true + if yyj4873 >= len(yyv4873) { + yyv4873 = append(yyv4873, "") // var yyz4873 ResourceQuotaScope + yyc4873 = true } - yyh4882.ElemContainerState(yyj4882) - if yyj4882 < len(yyv4882) { + yyh4873.ElemContainerState(yyj4873) + if yyj4873 < len(yyv4873) { if r.TryDecodeAsNil() { - yyv4882[yyj4882] = "" + yyv4873[yyj4873] = "" } else { - yyv4882[yyj4882] = ResourceQuotaScope(r.DecodeString()) + yyv4873[yyj4873] = ResourceQuotaScope(r.DecodeString()) } } else { @@ -62526,17 +62444,17 @@ func (x codecSelfer1234) decSliceResourceQuotaScope(v *[]ResourceQuotaScope, d * } } - if yyj4882 < len(yyv4882) { - yyv4882 = yyv4882[:yyj4882] - yyc4882 = true - } else if yyj4882 == 0 && yyv4882 == nil { - yyv4882 = []ResourceQuotaScope{} - yyc4882 = true + if yyj4873 < len(yyv4873) { + yyv4873 = yyv4873[:yyj4873] + yyc4873 = true + } else if yyj4873 == 0 && yyv4873 == nil { + yyv4873 = []ResourceQuotaScope{} + yyc4873 = true } } - yyh4882.End() - if yyc4882 { - *v = yyv4882 + yyh4873.End() + if yyc4873 { + *v = yyv4873 } } @@ -62545,10 +62463,10 @@ func (x codecSelfer1234) encSliceResourceQuota(v []ResourceQuota, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4886 := range v { + for _, yyv4877 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4887 := &yyv4886 - yy4887.CodecEncodeSelf(e) + yy4878 := &yyv4877 + yy4878.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62558,83 +62476,83 @@ func (x codecSelfer1234) decSliceResourceQuota(v *[]ResourceQuota, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4888 := *v - yyh4888, yyl4888 := z.DecSliceHelperStart() - var yyc4888 bool - if yyl4888 == 0 { - if yyv4888 == nil { - yyv4888 = []ResourceQuota{} - yyc4888 = true - } else if len(yyv4888) != 0 { - yyv4888 = yyv4888[:0] - yyc4888 = true + yyv4879 := *v + yyh4879, yyl4879 := z.DecSliceHelperStart() + var yyc4879 bool + if yyl4879 == 0 { + if yyv4879 == nil { + yyv4879 = []ResourceQuota{} + yyc4879 = true + } else if len(yyv4879) != 0 { + yyv4879 = yyv4879[:0] + yyc4879 = true } - } else if yyl4888 > 0 { - var yyrr4888, yyrl4888 int - var yyrt4888 bool - if yyl4888 > cap(yyv4888) { + } else if yyl4879 > 0 { + var yyrr4879, yyrl4879 int + var yyrt4879 bool + if yyl4879 > cap(yyv4879) { - yyrg4888 := len(yyv4888) > 0 - yyv24888 := yyv4888 - yyrl4888, yyrt4888 = z.DecInferLen(yyl4888, z.DecBasicHandle().MaxInitLen, 304) - if yyrt4888 { - if yyrl4888 <= cap(yyv4888) { - yyv4888 = yyv4888[:yyrl4888] + yyrg4879 := len(yyv4879) > 0 + yyv24879 := yyv4879 + yyrl4879, yyrt4879 = z.DecInferLen(yyl4879, z.DecBasicHandle().MaxInitLen, 304) + if yyrt4879 { + if yyrl4879 <= cap(yyv4879) { + yyv4879 = yyv4879[:yyrl4879] } else { - yyv4888 = make([]ResourceQuota, yyrl4888) + yyv4879 = make([]ResourceQuota, yyrl4879) } } else { - yyv4888 = make([]ResourceQuota, yyrl4888) + yyv4879 = make([]ResourceQuota, yyrl4879) } - yyc4888 = true - yyrr4888 = len(yyv4888) - if yyrg4888 { - copy(yyv4888, yyv24888) + yyc4879 = true + yyrr4879 = len(yyv4879) + if yyrg4879 { + copy(yyv4879, yyv24879) } - } else if yyl4888 != len(yyv4888) { - yyv4888 = yyv4888[:yyl4888] - yyc4888 = true + } else if yyl4879 != len(yyv4879) { + yyv4879 = yyv4879[:yyl4879] + yyc4879 = true } - yyj4888 := 0 - for ; yyj4888 < yyrr4888; yyj4888++ { - yyh4888.ElemContainerState(yyj4888) + yyj4879 := 0 + for ; yyj4879 < yyrr4879; yyj4879++ { + yyh4879.ElemContainerState(yyj4879) if r.TryDecodeAsNil() { - yyv4888[yyj4888] = ResourceQuota{} + yyv4879[yyj4879] = ResourceQuota{} } else { - yyv4889 := &yyv4888[yyj4888] - yyv4889.CodecDecodeSelf(d) + yyv4880 := &yyv4879[yyj4879] + yyv4880.CodecDecodeSelf(d) } } - if yyrt4888 { - for ; yyj4888 < yyl4888; yyj4888++ { - yyv4888 = append(yyv4888, ResourceQuota{}) - yyh4888.ElemContainerState(yyj4888) + if yyrt4879 { + for ; yyj4879 < yyl4879; yyj4879++ { + yyv4879 = append(yyv4879, ResourceQuota{}) + yyh4879.ElemContainerState(yyj4879) if r.TryDecodeAsNil() { - yyv4888[yyj4888] = ResourceQuota{} + yyv4879[yyj4879] = ResourceQuota{} } else { - yyv4890 := &yyv4888[yyj4888] - yyv4890.CodecDecodeSelf(d) + yyv4881 := &yyv4879[yyj4879] + yyv4881.CodecDecodeSelf(d) } } } } else { - yyj4888 := 0 - for ; !r.CheckBreak(); yyj4888++ { + yyj4879 := 0 + for ; !r.CheckBreak(); yyj4879++ { - if yyj4888 >= len(yyv4888) { - yyv4888 = append(yyv4888, ResourceQuota{}) // var yyz4888 ResourceQuota - yyc4888 = true + if yyj4879 >= len(yyv4879) { + yyv4879 = append(yyv4879, ResourceQuota{}) // var yyz4879 ResourceQuota + yyc4879 = true } - yyh4888.ElemContainerState(yyj4888) - if yyj4888 < len(yyv4888) { + yyh4879.ElemContainerState(yyj4879) + if yyj4879 < len(yyv4879) { if r.TryDecodeAsNil() { - yyv4888[yyj4888] = ResourceQuota{} + yyv4879[yyj4879] = ResourceQuota{} } else { - yyv4891 := &yyv4888[yyj4888] - yyv4891.CodecDecodeSelf(d) + yyv4882 := &yyv4879[yyj4879] + yyv4882.CodecDecodeSelf(d) } } else { @@ -62642,17 +62560,17 @@ func (x codecSelfer1234) decSliceResourceQuota(v *[]ResourceQuota, d *codec1978. } } - if yyj4888 < len(yyv4888) { - yyv4888 = yyv4888[:yyj4888] - yyc4888 = true - } else if yyj4888 == 0 && yyv4888 == nil { - yyv4888 = []ResourceQuota{} - yyc4888 = true + if yyj4879 < len(yyv4879) { + yyv4879 = yyv4879[:yyj4879] + yyc4879 = true + } else if yyj4879 == 0 && yyv4879 == nil { + yyv4879 = []ResourceQuota{} + yyc4879 = true } } - yyh4888.End() - if yyc4888 { - *v = yyv4888 + yyh4879.End() + if yyc4879 { + *v = yyv4879 } } @@ -62661,23 +62579,23 @@ func (x codecSelfer1234) encMapstringSliceuint8(v map[string][]uint8, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeMapStart(len(v)) - for yyk4892, yyv4892 := range v { + for yyk4883, yyv4883 := range v { z.EncSendContainerState(codecSelfer_containerMapKey1234) - yym4893 := z.EncBinary() - _ = yym4893 + yym4884 := z.EncBinary() + _ = yym4884 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yyk4892)) + r.EncodeString(codecSelferC_UTF81234, string(yyk4883)) } z.EncSendContainerState(codecSelfer_containerMapValue1234) - if yyv4892 == nil { + if yyv4883 == nil { r.EncodeNil() } else { - yym4894 := z.EncBinary() - _ = yym4894 + yym4885 := z.EncBinary() + _ = yym4885 if false { } else { - r.EncodeStringBytes(codecSelferC_RAW1234, []byte(yyv4892)) + r.EncodeStringBytes(codecSelferC_RAW1234, []byte(yyv4883)) } } } @@ -62689,80 +62607,80 @@ func (x codecSelfer1234) decMapstringSliceuint8(v *map[string][]uint8, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4895 := *v - yyl4895 := r.ReadMapStart() - yybh4895 := z.DecBasicHandle() - if yyv4895 == nil { - yyrl4895, _ := z.DecInferLen(yyl4895, yybh4895.MaxInitLen, 40) - yyv4895 = make(map[string][]uint8, yyrl4895) - *v = yyv4895 + yyv4886 := *v + yyl4886 := r.ReadMapStart() + yybh4886 := z.DecBasicHandle() + if yyv4886 == nil { + yyrl4886, _ := z.DecInferLen(yyl4886, yybh4886.MaxInitLen, 40) + yyv4886 = make(map[string][]uint8, yyrl4886) + *v = yyv4886 } - var yymk4895 string - var yymv4895 []uint8 - var yymg4895 bool - if yybh4895.MapValueReset { - yymg4895 = true + var yymk4886 string + var yymv4886 []uint8 + var yymg4886 bool + if yybh4886.MapValueReset { + yymg4886 = true } - if yyl4895 > 0 { - for yyj4895 := 0; yyj4895 < yyl4895; yyj4895++ { + if yyl4886 > 0 { + for yyj4886 := 0; yyj4886 < yyl4886; yyj4886++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4895 = "" + yymk4886 = "" } else { - yymk4895 = string(r.DecodeString()) + yymk4886 = string(r.DecodeString()) } - if yymg4895 { - yymv4895 = yyv4895[yymk4895] + if yymg4886 { + yymv4886 = yyv4886[yymk4886] } else { - yymv4895 = nil + yymv4886 = nil } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4895 = nil + yymv4886 = nil } else { - yyv4897 := &yymv4895 - yym4898 := z.DecBinary() - _ = yym4898 + yyv4888 := &yymv4886 + yym4889 := z.DecBinary() + _ = yym4889 if false { } else { - *yyv4897 = r.DecodeBytes(*(*[]byte)(yyv4897), false, false) + *yyv4888 = r.DecodeBytes(*(*[]byte)(yyv4888), false, false) } } - if yyv4895 != nil { - yyv4895[yymk4895] = yymv4895 + if yyv4886 != nil { + yyv4886[yymk4886] = yymv4886 } } - } else if yyl4895 < 0 { - for yyj4895 := 0; !r.CheckBreak(); yyj4895++ { + } else if yyl4886 < 0 { + for yyj4886 := 0; !r.CheckBreak(); yyj4886++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4895 = "" + yymk4886 = "" } else { - yymk4895 = string(r.DecodeString()) + yymk4886 = string(r.DecodeString()) } - if yymg4895 { - yymv4895 = yyv4895[yymk4895] + if yymg4886 { + yymv4886 = yyv4886[yymk4886] } else { - yymv4895 = nil + yymv4886 = nil } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4895 = nil + yymv4886 = nil } else { - yyv4900 := &yymv4895 - yym4901 := z.DecBinary() - _ = yym4901 + yyv4891 := &yymv4886 + yym4892 := z.DecBinary() + _ = yym4892 if false { } else { - *yyv4900 = r.DecodeBytes(*(*[]byte)(yyv4900), false, false) + *yyv4891 = r.DecodeBytes(*(*[]byte)(yyv4891), false, false) } } - if yyv4895 != nil { - yyv4895[yymk4895] = yymv4895 + if yyv4886 != nil { + yyv4886[yymk4886] = yymv4886 } } } // else len==0: TODO: Should we clear map entries? @@ -62774,10 +62692,10 @@ func (x codecSelfer1234) encSliceSecret(v []Secret, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4902 := range v { + for _, yyv4893 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4903 := &yyv4902 - yy4903.CodecEncodeSelf(e) + yy4894 := &yyv4893 + yy4894.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62787,83 +62705,83 @@ func (x codecSelfer1234) decSliceSecret(v *[]Secret, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4904 := *v - yyh4904, yyl4904 := z.DecSliceHelperStart() - var yyc4904 bool - if yyl4904 == 0 { - if yyv4904 == nil { - yyv4904 = []Secret{} - yyc4904 = true - } else if len(yyv4904) != 0 { - yyv4904 = yyv4904[:0] - yyc4904 = true + yyv4895 := *v + yyh4895, yyl4895 := z.DecSliceHelperStart() + var yyc4895 bool + if yyl4895 == 0 { + if yyv4895 == nil { + yyv4895 = []Secret{} + yyc4895 = true + } else if len(yyv4895) != 0 { + yyv4895 = yyv4895[:0] + yyc4895 = true } - } else if yyl4904 > 0 { - var yyrr4904, yyrl4904 int - var yyrt4904 bool - if yyl4904 > cap(yyv4904) { + } else if yyl4895 > 0 { + var yyrr4895, yyrl4895 int + var yyrt4895 bool + if yyl4895 > cap(yyv4895) { - yyrg4904 := len(yyv4904) > 0 - yyv24904 := yyv4904 - yyrl4904, yyrt4904 = z.DecInferLen(yyl4904, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4904 { - if yyrl4904 <= cap(yyv4904) { - yyv4904 = yyv4904[:yyrl4904] + yyrg4895 := len(yyv4895) > 0 + yyv24895 := yyv4895 + yyrl4895, yyrt4895 = z.DecInferLen(yyl4895, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4895 { + if yyrl4895 <= cap(yyv4895) { + yyv4895 = yyv4895[:yyrl4895] } else { - yyv4904 = make([]Secret, yyrl4904) + yyv4895 = make([]Secret, yyrl4895) } } else { - yyv4904 = make([]Secret, yyrl4904) + yyv4895 = make([]Secret, yyrl4895) } - yyc4904 = true - yyrr4904 = len(yyv4904) - if yyrg4904 { - copy(yyv4904, yyv24904) + yyc4895 = true + yyrr4895 = len(yyv4895) + if yyrg4895 { + copy(yyv4895, yyv24895) } - } else if yyl4904 != len(yyv4904) { - yyv4904 = yyv4904[:yyl4904] - yyc4904 = true + } else if yyl4895 != len(yyv4895) { + yyv4895 = yyv4895[:yyl4895] + yyc4895 = true } - yyj4904 := 0 - for ; yyj4904 < yyrr4904; yyj4904++ { - yyh4904.ElemContainerState(yyj4904) + yyj4895 := 0 + for ; yyj4895 < yyrr4895; yyj4895++ { + yyh4895.ElemContainerState(yyj4895) if r.TryDecodeAsNil() { - yyv4904[yyj4904] = Secret{} + yyv4895[yyj4895] = Secret{} } else { - yyv4905 := &yyv4904[yyj4904] - yyv4905.CodecDecodeSelf(d) + yyv4896 := &yyv4895[yyj4895] + yyv4896.CodecDecodeSelf(d) } } - if yyrt4904 { - for ; yyj4904 < yyl4904; yyj4904++ { - yyv4904 = append(yyv4904, Secret{}) - yyh4904.ElemContainerState(yyj4904) + if yyrt4895 { + for ; yyj4895 < yyl4895; yyj4895++ { + yyv4895 = append(yyv4895, Secret{}) + yyh4895.ElemContainerState(yyj4895) if r.TryDecodeAsNil() { - yyv4904[yyj4904] = Secret{} + yyv4895[yyj4895] = Secret{} } else { - yyv4906 := &yyv4904[yyj4904] - yyv4906.CodecDecodeSelf(d) + yyv4897 := &yyv4895[yyj4895] + yyv4897.CodecDecodeSelf(d) } } } } else { - yyj4904 := 0 - for ; !r.CheckBreak(); yyj4904++ { + yyj4895 := 0 + for ; !r.CheckBreak(); yyj4895++ { - if yyj4904 >= len(yyv4904) { - yyv4904 = append(yyv4904, Secret{}) // var yyz4904 Secret - yyc4904 = true + if yyj4895 >= len(yyv4895) { + yyv4895 = append(yyv4895, Secret{}) // var yyz4895 Secret + yyc4895 = true } - yyh4904.ElemContainerState(yyj4904) - if yyj4904 < len(yyv4904) { + yyh4895.ElemContainerState(yyj4895) + if yyj4895 < len(yyv4895) { if r.TryDecodeAsNil() { - yyv4904[yyj4904] = Secret{} + yyv4895[yyj4895] = Secret{} } else { - yyv4907 := &yyv4904[yyj4904] - yyv4907.CodecDecodeSelf(d) + yyv4898 := &yyv4895[yyj4895] + yyv4898.CodecDecodeSelf(d) } } else { @@ -62871,17 +62789,17 @@ func (x codecSelfer1234) decSliceSecret(v *[]Secret, d *codec1978.Decoder) { } } - if yyj4904 < len(yyv4904) { - yyv4904 = yyv4904[:yyj4904] - yyc4904 = true - } else if yyj4904 == 0 && yyv4904 == nil { - yyv4904 = []Secret{} - yyc4904 = true + if yyj4895 < len(yyv4895) { + yyv4895 = yyv4895[:yyj4895] + yyc4895 = true + } else if yyj4895 == 0 && yyv4895 == nil { + yyv4895 = []Secret{} + yyc4895 = true } } - yyh4904.End() - if yyc4904 { - *v = yyv4904 + yyh4895.End() + if yyc4895 { + *v = yyv4895 } } @@ -62890,10 +62808,10 @@ func (x codecSelfer1234) encSliceConfigMap(v []ConfigMap, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4908 := range v { + for _, yyv4899 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4909 := &yyv4908 - yy4909.CodecEncodeSelf(e) + yy4900 := &yyv4899 + yy4900.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62903,83 +62821,83 @@ func (x codecSelfer1234) decSliceConfigMap(v *[]ConfigMap, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4910 := *v - yyh4910, yyl4910 := z.DecSliceHelperStart() - var yyc4910 bool - if yyl4910 == 0 { - if yyv4910 == nil { - yyv4910 = []ConfigMap{} - yyc4910 = true - } else if len(yyv4910) != 0 { - yyv4910 = yyv4910[:0] - yyc4910 = true + yyv4901 := *v + yyh4901, yyl4901 := z.DecSliceHelperStart() + var yyc4901 bool + if yyl4901 == 0 { + if yyv4901 == nil { + yyv4901 = []ConfigMap{} + yyc4901 = true + } else if len(yyv4901) != 0 { + yyv4901 = yyv4901[:0] + yyc4901 = true } - } else if yyl4910 > 0 { - var yyrr4910, yyrl4910 int - var yyrt4910 bool - if yyl4910 > cap(yyv4910) { + } else if yyl4901 > 0 { + var yyrr4901, yyrl4901 int + var yyrt4901 bool + if yyl4901 > cap(yyv4901) { - yyrg4910 := len(yyv4910) > 0 - yyv24910 := yyv4910 - yyrl4910, yyrt4910 = z.DecInferLen(yyl4910, z.DecBasicHandle().MaxInitLen, 264) - if yyrt4910 { - if yyrl4910 <= cap(yyv4910) { - yyv4910 = yyv4910[:yyrl4910] + yyrg4901 := len(yyv4901) > 0 + yyv24901 := yyv4901 + yyrl4901, yyrt4901 = z.DecInferLen(yyl4901, z.DecBasicHandle().MaxInitLen, 264) + if yyrt4901 { + if yyrl4901 <= cap(yyv4901) { + yyv4901 = yyv4901[:yyrl4901] } else { - yyv4910 = make([]ConfigMap, yyrl4910) + yyv4901 = make([]ConfigMap, yyrl4901) } } else { - yyv4910 = make([]ConfigMap, yyrl4910) + yyv4901 = make([]ConfigMap, yyrl4901) } - yyc4910 = true - yyrr4910 = len(yyv4910) - if yyrg4910 { - copy(yyv4910, yyv24910) + yyc4901 = true + yyrr4901 = len(yyv4901) + if yyrg4901 { + copy(yyv4901, yyv24901) } - } else if yyl4910 != len(yyv4910) { - yyv4910 = yyv4910[:yyl4910] - yyc4910 = true + } else if yyl4901 != len(yyv4901) { + yyv4901 = yyv4901[:yyl4901] + yyc4901 = true } - yyj4910 := 0 - for ; yyj4910 < yyrr4910; yyj4910++ { - yyh4910.ElemContainerState(yyj4910) + yyj4901 := 0 + for ; yyj4901 < yyrr4901; yyj4901++ { + yyh4901.ElemContainerState(yyj4901) if r.TryDecodeAsNil() { - yyv4910[yyj4910] = ConfigMap{} + yyv4901[yyj4901] = ConfigMap{} } else { - yyv4911 := &yyv4910[yyj4910] - yyv4911.CodecDecodeSelf(d) + yyv4902 := &yyv4901[yyj4901] + yyv4902.CodecDecodeSelf(d) } } - if yyrt4910 { - for ; yyj4910 < yyl4910; yyj4910++ { - yyv4910 = append(yyv4910, ConfigMap{}) - yyh4910.ElemContainerState(yyj4910) + if yyrt4901 { + for ; yyj4901 < yyl4901; yyj4901++ { + yyv4901 = append(yyv4901, ConfigMap{}) + yyh4901.ElemContainerState(yyj4901) if r.TryDecodeAsNil() { - yyv4910[yyj4910] = ConfigMap{} + yyv4901[yyj4901] = ConfigMap{} } else { - yyv4912 := &yyv4910[yyj4910] - yyv4912.CodecDecodeSelf(d) + yyv4903 := &yyv4901[yyj4901] + yyv4903.CodecDecodeSelf(d) } } } } else { - yyj4910 := 0 - for ; !r.CheckBreak(); yyj4910++ { + yyj4901 := 0 + for ; !r.CheckBreak(); yyj4901++ { - if yyj4910 >= len(yyv4910) { - yyv4910 = append(yyv4910, ConfigMap{}) // var yyz4910 ConfigMap - yyc4910 = true + if yyj4901 >= len(yyv4901) { + yyv4901 = append(yyv4901, ConfigMap{}) // var yyz4901 ConfigMap + yyc4901 = true } - yyh4910.ElemContainerState(yyj4910) - if yyj4910 < len(yyv4910) { + yyh4901.ElemContainerState(yyj4901) + if yyj4901 < len(yyv4901) { if r.TryDecodeAsNil() { - yyv4910[yyj4910] = ConfigMap{} + yyv4901[yyj4901] = ConfigMap{} } else { - yyv4913 := &yyv4910[yyj4910] - yyv4913.CodecDecodeSelf(d) + yyv4904 := &yyv4901[yyj4901] + yyv4904.CodecDecodeSelf(d) } } else { @@ -62987,17 +62905,17 @@ func (x codecSelfer1234) decSliceConfigMap(v *[]ConfigMap, d *codec1978.Decoder) } } - if yyj4910 < len(yyv4910) { - yyv4910 = yyv4910[:yyj4910] - yyc4910 = true - } else if yyj4910 == 0 && yyv4910 == nil { - yyv4910 = []ConfigMap{} - yyc4910 = true + if yyj4901 < len(yyv4901) { + yyv4901 = yyv4901[:yyj4901] + yyc4901 = true + } else if yyj4901 == 0 && yyv4901 == nil { + yyv4901 = []ConfigMap{} + yyc4901 = true } } - yyh4910.End() - if yyc4910 { - *v = yyv4910 + yyh4901.End() + if yyc4901 { + *v = yyv4901 } } @@ -63006,10 +62924,10 @@ func (x codecSelfer1234) encSliceComponentCondition(v []ComponentCondition, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4914 := range v { + for _, yyv4905 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4915 := &yyv4914 - yy4915.CodecEncodeSelf(e) + yy4906 := &yyv4905 + yy4906.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -63019,83 +62937,83 @@ func (x codecSelfer1234) decSliceComponentCondition(v *[]ComponentCondition, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4916 := *v - yyh4916, yyl4916 := z.DecSliceHelperStart() - var yyc4916 bool - if yyl4916 == 0 { - if yyv4916 == nil { - yyv4916 = []ComponentCondition{} - yyc4916 = true - } else if len(yyv4916) != 0 { - yyv4916 = yyv4916[:0] - yyc4916 = true + yyv4907 := *v + yyh4907, yyl4907 := z.DecSliceHelperStart() + var yyc4907 bool + if yyl4907 == 0 { + if yyv4907 == nil { + yyv4907 = []ComponentCondition{} + yyc4907 = true + } else if len(yyv4907) != 0 { + yyv4907 = yyv4907[:0] + yyc4907 = true } - } else if yyl4916 > 0 { - var yyrr4916, yyrl4916 int - var yyrt4916 bool - if yyl4916 > cap(yyv4916) { + } else if yyl4907 > 0 { + var yyrr4907, yyrl4907 int + var yyrt4907 bool + if yyl4907 > cap(yyv4907) { - yyrg4916 := len(yyv4916) > 0 - yyv24916 := yyv4916 - yyrl4916, yyrt4916 = z.DecInferLen(yyl4916, z.DecBasicHandle().MaxInitLen, 64) - if yyrt4916 { - if yyrl4916 <= cap(yyv4916) { - yyv4916 = yyv4916[:yyrl4916] + yyrg4907 := len(yyv4907) > 0 + yyv24907 := yyv4907 + yyrl4907, yyrt4907 = z.DecInferLen(yyl4907, z.DecBasicHandle().MaxInitLen, 64) + if yyrt4907 { + if yyrl4907 <= cap(yyv4907) { + yyv4907 = yyv4907[:yyrl4907] } else { - yyv4916 = make([]ComponentCondition, yyrl4916) + yyv4907 = make([]ComponentCondition, yyrl4907) } } else { - yyv4916 = make([]ComponentCondition, yyrl4916) + yyv4907 = make([]ComponentCondition, yyrl4907) } - yyc4916 = true - yyrr4916 = len(yyv4916) - if yyrg4916 { - copy(yyv4916, yyv24916) + yyc4907 = true + yyrr4907 = len(yyv4907) + if yyrg4907 { + copy(yyv4907, yyv24907) } - } else if yyl4916 != len(yyv4916) { - yyv4916 = yyv4916[:yyl4916] - yyc4916 = true + } else if yyl4907 != len(yyv4907) { + yyv4907 = yyv4907[:yyl4907] + yyc4907 = true } - yyj4916 := 0 - for ; yyj4916 < yyrr4916; yyj4916++ { - yyh4916.ElemContainerState(yyj4916) + yyj4907 := 0 + for ; yyj4907 < yyrr4907; yyj4907++ { + yyh4907.ElemContainerState(yyj4907) if r.TryDecodeAsNil() { - yyv4916[yyj4916] = ComponentCondition{} + yyv4907[yyj4907] = ComponentCondition{} } else { - yyv4917 := &yyv4916[yyj4916] - yyv4917.CodecDecodeSelf(d) + yyv4908 := &yyv4907[yyj4907] + yyv4908.CodecDecodeSelf(d) } } - if yyrt4916 { - for ; yyj4916 < yyl4916; yyj4916++ { - yyv4916 = append(yyv4916, ComponentCondition{}) - yyh4916.ElemContainerState(yyj4916) + if yyrt4907 { + for ; yyj4907 < yyl4907; yyj4907++ { + yyv4907 = append(yyv4907, ComponentCondition{}) + yyh4907.ElemContainerState(yyj4907) if r.TryDecodeAsNil() { - yyv4916[yyj4916] = ComponentCondition{} + yyv4907[yyj4907] = ComponentCondition{} } else { - yyv4918 := &yyv4916[yyj4916] - yyv4918.CodecDecodeSelf(d) + yyv4909 := &yyv4907[yyj4907] + yyv4909.CodecDecodeSelf(d) } } } } else { - yyj4916 := 0 - for ; !r.CheckBreak(); yyj4916++ { + yyj4907 := 0 + for ; !r.CheckBreak(); yyj4907++ { - if yyj4916 >= len(yyv4916) { - yyv4916 = append(yyv4916, ComponentCondition{}) // var yyz4916 ComponentCondition - yyc4916 = true + if yyj4907 >= len(yyv4907) { + yyv4907 = append(yyv4907, ComponentCondition{}) // var yyz4907 ComponentCondition + yyc4907 = true } - yyh4916.ElemContainerState(yyj4916) - if yyj4916 < len(yyv4916) { + yyh4907.ElemContainerState(yyj4907) + if yyj4907 < len(yyv4907) { if r.TryDecodeAsNil() { - yyv4916[yyj4916] = ComponentCondition{} + yyv4907[yyj4907] = ComponentCondition{} } else { - yyv4919 := &yyv4916[yyj4916] - yyv4919.CodecDecodeSelf(d) + yyv4910 := &yyv4907[yyj4907] + yyv4910.CodecDecodeSelf(d) } } else { @@ -63103,17 +63021,17 @@ func (x codecSelfer1234) decSliceComponentCondition(v *[]ComponentCondition, d * } } - if yyj4916 < len(yyv4916) { - yyv4916 = yyv4916[:yyj4916] - yyc4916 = true - } else if yyj4916 == 0 && yyv4916 == nil { - yyv4916 = []ComponentCondition{} - yyc4916 = true + if yyj4907 < len(yyv4907) { + yyv4907 = yyv4907[:yyj4907] + yyc4907 = true + } else if yyj4907 == 0 && yyv4907 == nil { + yyv4907 = []ComponentCondition{} + yyc4907 = true } } - yyh4916.End() - if yyc4916 { - *v = yyv4916 + yyh4907.End() + if yyc4907 { + *v = yyv4907 } } @@ -63122,10 +63040,10 @@ func (x codecSelfer1234) encSliceComponentStatus(v []ComponentStatus, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4920 := range v { + for _, yyv4911 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4921 := &yyv4920 - yy4921.CodecEncodeSelf(e) + yy4912 := &yyv4911 + yy4912.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -63135,83 +63053,83 @@ func (x codecSelfer1234) decSliceComponentStatus(v *[]ComponentStatus, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4922 := *v - yyh4922, yyl4922 := z.DecSliceHelperStart() - var yyc4922 bool - if yyl4922 == 0 { - if yyv4922 == nil { - yyv4922 = []ComponentStatus{} - yyc4922 = true - } else if len(yyv4922) != 0 { - yyv4922 = yyv4922[:0] - yyc4922 = true + yyv4913 := *v + yyh4913, yyl4913 := z.DecSliceHelperStart() + var yyc4913 bool + if yyl4913 == 0 { + if yyv4913 == nil { + yyv4913 = []ComponentStatus{} + yyc4913 = true + } else if len(yyv4913) != 0 { + yyv4913 = yyv4913[:0] + yyc4913 = true } - } else if yyl4922 > 0 { - var yyrr4922, yyrl4922 int - var yyrt4922 bool - if yyl4922 > cap(yyv4922) { + } else if yyl4913 > 0 { + var yyrr4913, yyrl4913 int + var yyrt4913 bool + if yyl4913 > cap(yyv4913) { - yyrg4922 := len(yyv4922) > 0 - yyv24922 := yyv4922 - yyrl4922, yyrt4922 = z.DecInferLen(yyl4922, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4922 { - if yyrl4922 <= cap(yyv4922) { - yyv4922 = yyv4922[:yyrl4922] + yyrg4913 := len(yyv4913) > 0 + yyv24913 := yyv4913 + yyrl4913, yyrt4913 = z.DecInferLen(yyl4913, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4913 { + if yyrl4913 <= cap(yyv4913) { + yyv4913 = yyv4913[:yyrl4913] } else { - yyv4922 = make([]ComponentStatus, yyrl4922) + yyv4913 = make([]ComponentStatus, yyrl4913) } } else { - yyv4922 = make([]ComponentStatus, yyrl4922) + yyv4913 = make([]ComponentStatus, yyrl4913) } - yyc4922 = true - yyrr4922 = len(yyv4922) - if yyrg4922 { - copy(yyv4922, yyv24922) + yyc4913 = true + yyrr4913 = len(yyv4913) + if yyrg4913 { + copy(yyv4913, yyv24913) } - } else if yyl4922 != len(yyv4922) { - yyv4922 = yyv4922[:yyl4922] - yyc4922 = true + } else if yyl4913 != len(yyv4913) { + yyv4913 = yyv4913[:yyl4913] + yyc4913 = true } - yyj4922 := 0 - for ; yyj4922 < yyrr4922; yyj4922++ { - yyh4922.ElemContainerState(yyj4922) + yyj4913 := 0 + for ; yyj4913 < yyrr4913; yyj4913++ { + yyh4913.ElemContainerState(yyj4913) if r.TryDecodeAsNil() { - yyv4922[yyj4922] = ComponentStatus{} + yyv4913[yyj4913] = ComponentStatus{} } else { - yyv4923 := &yyv4922[yyj4922] - yyv4923.CodecDecodeSelf(d) + yyv4914 := &yyv4913[yyj4913] + yyv4914.CodecDecodeSelf(d) } } - if yyrt4922 { - for ; yyj4922 < yyl4922; yyj4922++ { - yyv4922 = append(yyv4922, ComponentStatus{}) - yyh4922.ElemContainerState(yyj4922) + if yyrt4913 { + for ; yyj4913 < yyl4913; yyj4913++ { + yyv4913 = append(yyv4913, ComponentStatus{}) + yyh4913.ElemContainerState(yyj4913) if r.TryDecodeAsNil() { - yyv4922[yyj4922] = ComponentStatus{} + yyv4913[yyj4913] = ComponentStatus{} } else { - yyv4924 := &yyv4922[yyj4922] - yyv4924.CodecDecodeSelf(d) + yyv4915 := &yyv4913[yyj4913] + yyv4915.CodecDecodeSelf(d) } } } } else { - yyj4922 := 0 - for ; !r.CheckBreak(); yyj4922++ { + yyj4913 := 0 + for ; !r.CheckBreak(); yyj4913++ { - if yyj4922 >= len(yyv4922) { - yyv4922 = append(yyv4922, ComponentStatus{}) // var yyz4922 ComponentStatus - yyc4922 = true + if yyj4913 >= len(yyv4913) { + yyv4913 = append(yyv4913, ComponentStatus{}) // var yyz4913 ComponentStatus + yyc4913 = true } - yyh4922.ElemContainerState(yyj4922) - if yyj4922 < len(yyv4922) { + yyh4913.ElemContainerState(yyj4913) + if yyj4913 < len(yyv4913) { if r.TryDecodeAsNil() { - yyv4922[yyj4922] = ComponentStatus{} + yyv4913[yyj4913] = ComponentStatus{} } else { - yyv4925 := &yyv4922[yyj4922] - yyv4925.CodecDecodeSelf(d) + yyv4916 := &yyv4913[yyj4913] + yyv4916.CodecDecodeSelf(d) } } else { @@ -63219,16 +63137,16 @@ func (x codecSelfer1234) decSliceComponentStatus(v *[]ComponentStatus, d *codec1 } } - if yyj4922 < len(yyv4922) { - yyv4922 = yyv4922[:yyj4922] - yyc4922 = true - } else if yyj4922 == 0 && yyv4922 == nil { - yyv4922 = []ComponentStatus{} - yyc4922 = true + if yyj4913 < len(yyv4913) { + yyv4913 = yyv4913[:yyj4913] + yyc4913 = true + } else if yyj4913 == 0 && yyv4913 == nil { + yyv4913 = []ComponentStatus{} + yyc4913 = true } } - yyh4922.End() - if yyc4922 { - *v = yyv4922 + yyh4913.End() + if yyc4913 { + *v = yyv4913 } } diff --git a/vendor/k8s.io/kubernetes/pkg/api/types.go b/vendor/k8s.io/client-go/pkg/api/types.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/api/types.go rename to vendor/k8s.io/client-go/pkg/api/types.go index fc944b1..dba9c0f 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/types.go +++ b/vendor/k8s.io/client-go/pkg/api/types.go @@ -17,13 +17,13 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/types" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/types" + "k8s.io/client-go/pkg/util/intstr" ) // Common string formats @@ -62,6 +62,7 @@ type ObjectMeta struct { // some resources may allow a client to request the generation of an appropriate name // automatically. Name is primarily intended for creation idempotence and configuration // definition. + // +optional Name string `json:"name,omitempty"` // GenerateName indicates that the name should be made unique by the server prior to persisting @@ -75,35 +76,42 @@ type ObjectMeta struct { // generated name exists - instead, it will either return 201 Created or 500 with Reason // ServerTimeout indicating a unique name could not be found in the time allotted, and the client // should retry (optionally after the time indicated in the Retry-After header). + // +optional GenerateName string `json:"generateName,omitempty"` // Namespace defines the space within which name must be unique. An empty namespace is // equivalent to the "default" namespace, but "default" is the canonical representation. // Not all objects are required to be scoped to a namespace - the value of this field for // those objects will be empty. + // +optional Namespace string `json:"namespace,omitempty"` // SelfLink is a URL representing this object. + // +optional SelfLink string `json:"selfLink,omitempty"` // UID is the unique in time and space value for this object. It is typically generated by // the server on successful creation of a resource and is not allowed to change on PUT // operations. + // +optional UID types.UID `json:"uid,omitempty"` // An opaque value that represents the version of this resource. May be used for optimistic // concurrency, change detection, and the watch operation on a resource or set of resources. // Clients must treat these values as opaque and values may only be valid for a particular // resource or set of resources. Only servers will generate resource versions. + // +optional ResourceVersion string `json:"resourceVersion,omitempty"` // A sequence number representing a specific generation of the desired state. // Populated by the system. Read-only. + // +optional Generation int64 `json:"generation,omitempty"` // CreationTimestamp is a timestamp representing the server time when this object was // created. It is not guaranteed to be set in happens-before order across separate operations. // Clients may not set this value. It is represented in RFC3339 form and is in UTC. + // +optional CreationTimestamp unversioned.Time `json:"creationTimestamp,omitempty"` // DeletionTimestamp is the time after which this resource will be deleted. This @@ -115,10 +123,12 @@ type ObjectMeta struct { // a pod is deleted in 30 seconds. The Kubelet will react by sending a graceful termination // signal to the containers in the pod. Once the resource is deleted in the API, the Kubelet // will send a hard termination signal to the container. + // +optional DeletionTimestamp *unversioned.Time `json:"deletionTimestamp,omitempty"` // DeletionGracePeriodSeconds records the graceful deletion value set when graceful deletion // was requested. Represents the most recent grace period, and may only be shortened once set. + // +optional DeletionGracePeriodSeconds *int64 `json:"deletionGracePeriodSeconds,omitempty"` // Labels are key value pairs that may be used to scope and select individual resources. @@ -130,29 +140,34 @@ type ObjectMeta struct { // The prefix is optional. If the prefix is not specified, the key is assumed to be private // to the user. Other system components that wish to use labels must specify a prefix. The // "kubernetes.io/" prefix is reserved for use by kubernetes components. + // +optional Labels map[string]string `json:"labels,omitempty"` // Annotations are unstructured key value data stored with a resource that may be set by // external tooling. They are not queryable and should be preserved when modifying // objects. Annotation keys have the same formatting restrictions as Label keys. See the // comments on Labels for details. + // +optional Annotations map[string]string `json:"annotations,omitempty"` // List of objects depended by this object. If ALL objects in the list have // been deleted, this object will be garbage collected. If this object is managed by a controller, // then an entry in this list will point to this controller, with the controller field set to true. // There cannot be more than one managing controller. + // +optional OwnerReferences []OwnerReference `json:"ownerReferences,omitempty"` // Must be empty before the object is deleted from the registry. Each entry // is an identifier for the responsible component that will remove the entry // from the list. If the deletionTimestamp of the object is non-nil, entries // in this list can only be removed. + // +optional Finalizers []string `json:"finalizers,omitempty"` // The name of the cluster which the object belongs to. // This is used to distinguish resources with same name and namespace in different clusters. // This field is not set anywhere right now and apiserver is going to ignore it if set in create or update request. + // +optional ClusterName string `json:"clusterName,omitempty"` } @@ -177,6 +192,7 @@ type Volume struct { // The VolumeSource represents the location and type of a volume to mount. // This is optional for now. If not specified, the Volume is implied to be an EmptyDir. // This implied behavior is deprecated and will be removed in a future version. + // +optional VolumeSource `json:",inline,omitempty"` } @@ -190,58 +206,80 @@ type VolumeSource struct { // --- // TODO(jonesdl) We need to restrict who can use host directory mounts and who can/can not // mount host directories as read/write. + // +optional HostPath *HostPathVolumeSource `json:"hostPath,omitempty"` // EmptyDir represents a temporary directory that shares a pod's lifetime. + // +optional EmptyDir *EmptyDirVolumeSource `json:"emptyDir,omitempty"` // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional GCEPersistentDisk *GCEPersistentDiskVolumeSource `json:"gcePersistentDisk,omitempty"` // AWSElasticBlockStore represents an AWS EBS disk that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional AWSElasticBlockStore *AWSElasticBlockStoreVolumeSource `json:"awsElasticBlockStore,omitempty"` // GitRepo represents a git repository at a particular revision. + // +optional GitRepo *GitRepoVolumeSource `json:"gitRepo,omitempty"` // Secret represents a secret that should populate this volume. + // +optional Secret *SecretVolumeSource `json:"secret,omitempty"` // NFS represents an NFS mount on the host that shares a pod's lifetime + // +optional NFS *NFSVolumeSource `json:"nfs,omitempty"` // ISCSIVolumeSource represents an ISCSI Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional ISCSI *ISCSIVolumeSource `json:"iscsi,omitempty"` // Glusterfs represents a Glusterfs mount on the host that shares a pod's lifetime + // +optional Glusterfs *GlusterfsVolumeSource `json:"glusterfs,omitempty"` // PersistentVolumeClaimVolumeSource represents a reference to a PersistentVolumeClaim in the same namespace + // +optional PersistentVolumeClaim *PersistentVolumeClaimVolumeSource `json:"persistentVolumeClaim,omitempty"` // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime + // +optional RBD *RBDVolumeSource `json:"rbd,omitempty"` // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional Quobyte *QuobyteVolumeSource `json:"quobyte,omitempty"` // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an alpha feature and may change in future. + // +optional FlexVolume *FlexVolumeSource `json:"flexVolume,omitempty"` // Cinder represents a cinder volume attached and mounted on kubelets host machine + // +optional Cinder *CinderVolumeSource `json:"cinder,omitempty"` // CephFS represents a Cephfs mount on the host that shares a pod's lifetime + // +optional CephFS *CephFSVolumeSource `json:"cephfs,omitempty"` // Flocker represents a Flocker volume attached to a kubelet's host machine. This depends on the Flocker control service being running + // +optional Flocker *FlockerVolumeSource `json:"flocker,omitempty"` // DownwardAPI represents metadata about the pod that should populate this volume + // +optional DownwardAPI *DownwardAPIVolumeSource `json:"downwardAPI,omitempty"` // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional FC *FCVolumeSource `json:"fc,omitempty"` // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional AzureFile *AzureFileVolumeSource `json:"azureFile,omitempty"` // ConfigMap represents a configMap that should populate this volume + // +optional ConfigMap *ConfigMapVolumeSource `json:"configMap,omitempty"` // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional VsphereVolume *VsphereVirtualDiskVolumeSource `json:"vsphereVolume,omitempty"` // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional AzureDisk *AzureDiskVolumeSource `json:"azureDisk,omitempty"` } @@ -250,42 +288,58 @@ type VolumeSource struct { type PersistentVolumeSource struct { // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional GCEPersistentDisk *GCEPersistentDiskVolumeSource `json:"gcePersistentDisk,omitempty"` // AWSElasticBlockStore represents an AWS EBS disk that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional AWSElasticBlockStore *AWSElasticBlockStoreVolumeSource `json:"awsElasticBlockStore,omitempty"` // HostPath represents a directory on the host. // Provisioned by a developer or tester. // This is useful for single-node development and testing only! // On-host storage is not supported in any way and WILL NOT WORK in a multi-node cluster. + // +optional HostPath *HostPathVolumeSource `json:"hostPath,omitempty"` // Glusterfs represents a Glusterfs volume that is attached to a host and exposed to the pod + // +optional Glusterfs *GlusterfsVolumeSource `json:"glusterfs,omitempty"` // NFS represents an NFS mount on the host that shares a pod's lifetime + // +optional NFS *NFSVolumeSource `json:"nfs,omitempty"` // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime + // +optional RBD *RBDVolumeSource `json:"rbd,omitempty"` // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional Quobyte *QuobyteVolumeSource `json:"quobyte,omitempty"` // ISCSIVolumeSource represents an ISCSI resource that is attached to a // kubelet's host machine and then exposed to the pod. + // +optional ISCSI *ISCSIVolumeSource `json:"iscsi,omitempty"` // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an alpha feature and may change in future. + // +optional FlexVolume *FlexVolumeSource `json:"flexVolume,omitempty"` // Cinder represents a cinder volume attached and mounted on kubelets host machine + // +optional Cinder *CinderVolumeSource `json:"cinder,omitempty"` // CephFS represents a Ceph FS mount on the host that shares a pod's lifetime + // +optional CephFS *CephFSVolumeSource `json:"cephfs,omitempty"` // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional FC *FCVolumeSource `json:"fc,omitempty"` // Flocker represents a Flocker volume attached to a kubelet's host machine. This depends on the Flocker control service being running + // +optional Flocker *FlockerVolumeSource `json:"flocker,omitempty"` // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional AzureFile *AzureFileVolumeSource `json:"azureFile,omitempty"` // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional VsphereVolume *VsphereVirtualDiskVolumeSource `json:"vsphereVolume,omitempty"` // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional AzureDisk *AzureDiskVolumeSource `json:"azureDisk,omitempty"` } @@ -294,6 +348,7 @@ type PersistentVolumeClaimVolumeSource struct { ClaimName string `json:"claimName"` // Optional: Defaults to false (read/write). ReadOnly here // will force the ReadOnly setting in VolumeMounts + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -302,12 +357,15 @@ type PersistentVolumeClaimVolumeSource struct { type PersistentVolume struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` //Spec defines a persistent volume owned by the cluster + // +optional Spec PersistentVolumeSpec `json:"spec,omitempty"` // Status represents the current information about persistent volume. + // +optional Status PersistentVolumeStatus `json:"status,omitempty"` } @@ -317,14 +375,17 @@ type PersistentVolumeSpec struct { // Source represents the location and type of a volume to mount. PersistentVolumeSource `json:",inline"` // AccessModes contains all ways the volume can be mounted + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty"` // ClaimRef is part of a bi-directional binding between PersistentVolume and PersistentVolumeClaim. // ClaimRef is expected to be non-nil when bound. // claim.VolumeName is the authoritative bind between PV and PVC. // When set to non-nil value, PVC.Spec.Selector of the referenced PVC is // ignored, i.e. labels of this PV do not need to match PVC selector. + // +optional ClaimRef *ObjectReference `json:"claimRef,omitempty"` // Optional: what happens to a persistent volume when released from its claim. + // +optional PersistentVolumeReclaimPolicy PersistentVolumeReclaimPolicy `json:"persistentVolumeReclaimPolicy,omitempty"` } @@ -345,15 +406,19 @@ const ( type PersistentVolumeStatus struct { // Phase indicates if a volume is available, bound to a claim, or released by a claim + // +optional Phase PersistentVolumePhase `json:"phase,omitempty"` // A human-readable message indicating details about why the volume is in this state. + // +optional Message string `json:"message,omitempty"` // Reason is a brief CamelCase string that describes any failure and is meant for machine parsing and tidy display in the CLI + // +optional Reason string `json:"reason,omitempty"` } type PersistentVolumeList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []PersistentVolume `json:"items"` } @@ -363,17 +428,21 @@ type PersistentVolumeList struct { // PersistentVolumeClaim is a user's request for and claim to a persistent volume type PersistentVolumeClaim struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the volume requested by a pod author + // +optional Spec PersistentVolumeClaimSpec `json:"spec,omitempty"` // Status represents the current information about a claim + // +optional Status PersistentVolumeClaimStatus `json:"status,omitempty"` } type PersistentVolumeClaimList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []PersistentVolumeClaim `json:"items"` } @@ -382,23 +451,30 @@ type PersistentVolumeClaimList struct { // and allows a Source for provider-specific attributes type PersistentVolumeClaimSpec struct { // Contains the types of access modes required + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty"` // A label query over volumes to consider for binding. This selector is // ignored when VolumeName is set + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // Resources represents the minimum resources required + // +optional Resources ResourceRequirements `json:"resources,omitempty"` // VolumeName is the binding reference to the PersistentVolume backing this // claim. When set to non-empty value Selector is not evaluated + // +optional VolumeName string `json:"volumeName,omitempty"` } type PersistentVolumeClaimStatus struct { // Phase represents the current phase of PersistentVolumeClaim + // +optional Phase PersistentVolumeClaimPhase `json:"phase,omitempty"` // AccessModes contains all ways the volume backing the PVC can be mounted + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty"` // Represents the actual resources of the underlying volume + // +optional Capacity ResourceList `json:"capacity,omitempty"` } @@ -459,6 +535,7 @@ type EmptyDirVolumeSource struct { // this will cover the most common needs. // Optional: what type of storage medium should back this directory. // The default is "" which means to use the node's default medium. + // +optional Medium StorageMedium `json:"medium,omitempty"` } @@ -493,13 +570,16 @@ type GCEPersistentDiskVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty"` // Optional: Partition on the disk to mount. // If omitted, kubelet will attempt to mount the device name. // Ex. For /dev/sda1, this field is "1", for /dev/sda, this field is 0 or empty. + // +optional Partition int32 `json:"partition,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -509,20 +589,26 @@ type GCEPersistentDiskVolumeSource struct { type ISCSIVolumeSource struct { // Required: iSCSI target portal // the portal is either an IP or ip_addr:port if port is other than default (typically TCP ports 860 and 3260) + // +optional TargetPortal string `json:"targetPortal,omitempty"` // Required: target iSCSI Qualified Name + // +optional IQN string `json:"iqn,omitempty"` // Required: iSCSI target lun number + // +optional Lun int32 `json:"lun,omitempty"` // Optional: Defaults to 'default' (tcp). iSCSI interface name that uses an iSCSI transport. + // +optional ISCSIInterface string `json:"iscsiInterface,omitempty"` // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -538,9 +624,11 @@ type FCVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -552,17 +640,21 @@ type FlexVolumeSource struct { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". The default filesystem depends on FlexVolume script. + // +optional FSType string `json:"fsType,omitempty"` // Optional: SecretRef is reference to the secret object containing // sensitive information to pass to the plugin scripts. This may be // empty if no secret object is specified. If the secret object // contains more than one secret, all secrets are passed to the plugin // scripts. + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` // Optional: Extra driver options if any. + // +optional Options map[string]string `json:"options,omitempty"` } @@ -579,13 +671,16 @@ type AWSElasticBlockStoreVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty"` // Optional: Partition on the disk to mount. // If omitted, kubelet will attempt to mount the device name. // Ex. For /dev/sda1, this field is "1", for /dev/sda, this field is 0 or empty. + // +optional Partition int32 `json:"partition,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -596,11 +691,13 @@ type GitRepoVolumeSource struct { // Repository URL Repository string `json:"repository"` // Commit hash, this is optional + // +optional Revision string `json:"revision,omitempty"` // Clone target, this is optional // Must not contain or start with '..'. If '.' is supplied, the volume directory will be the // git repository. Otherwise, if specified, the volume will contain the git repository in // the subdirectory with the given name. + // +optional Directory string `json:"directory,omitempty"` // TODO: Consider credentials here. } @@ -612,6 +709,7 @@ type GitRepoVolumeSource struct { // Secret volumes support ownership management and SELinux relabeling. type SecretVolumeSource struct { // Name of the secret in the pod's namespace to use. + // +optional SecretName string `json:"secretName,omitempty"` // If unspecified, each key-value pair in the Data field of the referenced // Secret will be projected into the volume as a file whose name is the @@ -620,12 +718,14 @@ type SecretVolumeSource struct { // present. If a key is specified which is not present in the Secret, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional Items []KeyToPath `json:"items,omitempty"` // Mode bits to use on created files by default. Must be a value between // 0 and 0777. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty"` } @@ -640,6 +740,7 @@ type NFSVolumeSource struct { // Optional: Defaults to false (read/write). ReadOnly here will force // the NFS export to be mounted with read-only permissions + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -656,14 +757,17 @@ type QuobyteVolumeSource struct { // Defaults to false (read/write). ReadOnly here will force // the Quobyte to be mounted with read-only permissions + // +optional ReadOnly bool `json:"readOnly,omitempty"` // User to map volume access to // Defaults to the root user + // +optional User string `json:"user,omitempty"` // Group to map volume access to // Default is no group + // +optional Group string `json:"group,omitempty"` } @@ -678,6 +782,7 @@ type GlusterfsVolumeSource struct { // Optional: Defaults to false (read/write). ReadOnly here will force // the Glusterfs to be mounted with read-only permissions + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -692,17 +797,23 @@ type RBDVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty"` // Optional: RadosPool is the rados pool name,default is rbd + // +optional RBDPool string `json:"pool,omitempty"` // Optional: RBDUser is the rados user name, default is admin + // +optional RadosUser string `json:"user,omitempty"` // Optional: Keyring is the path to key ring for RBDUser, default is /etc/ceph/keyring + // +optional Keyring string `json:"keyring,omitempty"` // Optional: SecretRef is name of the authentication secret for RBDUser, default is nil. + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -716,9 +827,11 @@ type CinderVolumeSource struct { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional FSType string `json:"fsType,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -728,15 +841,20 @@ type CephFSVolumeSource struct { // Required: Monitors is a collection of Ceph monitors Monitors []string `json:"monitors"` // Optional: Used as the mounted root, rather than the full Ceph tree, default is / + // +optional Path string `json:"path,omitempty"` // Optional: User is the rados user name, default is admin + // +optional User string `json:"user,omitempty"` // Optional: SecretFile is the path to key ring for User, default is /etc/ceph/user.secret + // +optional SecretFile string `json:"secretFile,omitempty"` // Optional: SecretRef is reference to the authentication secret for User, default is empty. + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -746,8 +864,10 @@ type CephFSVolumeSource struct { type FlockerVolumeSource struct { // Name of the dataset stored as metadata -> name on the dataset for Flocker // should be considered as deprecated + // +optional DatasetName string `json:"datasetName,omitempty"` // UUID of the dataset. This is unique identifier of a Flocker dataset + // +optional DatasetUUID string `json:"datasetUUID,omitempty"` } @@ -755,12 +875,14 @@ type FlockerVolumeSource struct { // Downward API volumes support ownership management and SELinux relabeling. type DownwardAPIVolumeSource struct { // Items is a list of DownwardAPIVolume file + // +optional Items []DownwardAPIVolumeFile `json:"items,omitempty"` // Mode bits to use on created files by default. Must be a value between // 0 and 0777. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty"` } @@ -769,14 +891,17 @@ type DownwardAPIVolumeFile struct { // Required: Path is the relative path name of the file to be created. Must not be absolute or contain the '..' path. Must be utf-8 encoded. The first item of the relative path must not start with '..' Path string `json:"path"` // Required: Selects a field of the pod: only annotations, labels, name and namespace are supported. + // +optional FieldRef *ObjectFieldSelector `json:"fieldRef,omitempty"` // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional ResourceFieldRef *ResourceFieldSelector `json:"resourceFieldRef,omitempty"` // Optional: mode bits to use on this file, must be a value between 0 // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional Mode *int32 `json:"mode,omitempty"` } @@ -788,6 +913,7 @@ type AzureFileVolumeSource struct { ShareName string `json:"shareName"` // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty"` } @@ -798,6 +924,7 @@ type VsphereVirtualDiskVolumeSource struct { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional FSType string `json:"fsType,omitempty"` } @@ -816,13 +943,16 @@ type AzureDiskVolumeSource struct { // The URI the the data disk in the blob storage DataDiskURI string `json:"diskURI"` // Host Caching mode: None, Read Only, Read Write. + // +optional CachingMode *AzureDataDiskCachingMode `json:"cachingMode,omitempty"` // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional FSType *string `json:"fsType,omitempty"` // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly *bool `json:"readOnly,omitempty"` } @@ -841,12 +971,14 @@ type ConfigMapVolumeSource struct { // present. If a key is specified which is not present in the ConfigMap, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional Items []KeyToPath `json:"items,omitempty"` // Mode bits to use on created files by default. Must be a value between // 0 and 0777. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty"` } @@ -864,6 +996,7 @@ type KeyToPath struct { // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional Mode *int32 `json:"mode,omitempty"` } @@ -871,15 +1004,19 @@ type KeyToPath struct { type ContainerPort struct { // Optional: If specified, this must be an IANA_SVC_NAME Each named port // in a pod must have a unique name. + // +optional Name string `json:"name,omitempty"` // Optional: If specified, this must be a valid port number, 0 < x < 65536. // If HostNetwork is specified, this must match ContainerPort. + // +optional HostPort int32 `json:"hostPort,omitempty"` // Required: This must be a valid port number, 0 < x < 65536. ContainerPort int32 `json:"containerPort"` // Required: Supports "TCP" and "UDP". + // +optional Protocol Protocol `json:"protocol,omitempty"` // Optional: What host IP to bind the external port to. + // +optional HostIP string `json:"hostIP,omitempty"` } @@ -888,11 +1025,13 @@ type VolumeMount struct { // Required: This must match the Name of a Volume [above]. Name string `json:"name"` // Optional: Defaults to false (read-write). + // +optional ReadOnly bool `json:"readOnly,omitempty"` // Required. Must not contain ':'. MountPath string `json:"mountPath"` // Path within the volume from which the container's volume should be mounted. // Defaults to "" (volume's root). + // +optional SubPath string `json:"subPath,omitempty"` } @@ -908,8 +1047,10 @@ type EnvVar struct { // syntax can be escaped with a double $$, ie: $$(VAR_NAME). Escaped // references will never be expanded, regardless of whether the variable // exists or not. + // +optional Value string `json:"value,omitempty"` // Optional: Specifies a source the value of this var should come from. + // +optional ValueFrom *EnvVarSource `json:"valueFrom,omitempty"` } @@ -918,13 +1059,17 @@ type EnvVar struct { type EnvVarSource struct { // Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, // spec.nodeName, spec.serviceAccountName, status.podIP. + // +optional FieldRef *ObjectFieldSelector `json:"fieldRef,omitempty"` // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional ResourceFieldRef *ResourceFieldSelector `json:"resourceFieldRef,omitempty"` // Selects a key of a ConfigMap. + // +optional ConfigMapKeyRef *ConfigMapKeySelector `json:"configMapKeyRef,omitempty"` // Selects a key of a secret in the pod's namespace. + // +optional SecretKeyRef *SecretKeySelector `json:"secretKeyRef,omitempty"` } @@ -941,10 +1086,12 @@ type ObjectFieldSelector struct { // ResourceFieldSelector represents container resources (cpu, memory) and their output format type ResourceFieldSelector struct { // Container name: required for volumes, optional for env vars + // +optional ContainerName string `json:"containerName,omitempty"` // Required: resource to select Resource string `json:"resource"` // Specifies the output format of the exposed resources, defaults to "1" + // +optional Divisor resource.Quantity `json:"divisor,omitempty"` } @@ -975,15 +1122,20 @@ type HTTPHeader struct { // HTTPGetAction describes an action based on HTTP Get requests. type HTTPGetAction struct { // Optional: Path to access on the HTTP server. + // +optional Path string `json:"path,omitempty"` // Required: Name or number of the port to access on the container. + // +optional Port intstr.IntOrString `json:"port,omitempty"` // Optional: Host name to connect to, defaults to the pod IP. You // probably want to set "Host" in httpHeaders instead. + // +optional Host string `json:"host,omitempty"` // Optional: Scheme to use for connecting to the host, defaults to HTTP. + // +optional Scheme URIScheme `json:"scheme,omitempty"` // Optional: Custom headers to set in the request. HTTP allows repeated headers. + // +optional HTTPHeaders []HTTPHeader `json:"httpHeaders,omitempty"` } @@ -1000,6 +1152,7 @@ const ( // TCPSocketAction describes an action based on opening a socket type TCPSocketAction struct { // Required: Port to connect to. + // +optional Port intstr.IntOrString `json:"port,omitempty"` } @@ -1009,6 +1162,7 @@ type ExecAction struct { // command is root ('/') in the container's filesystem. The command is simply exec'd, it is // not run inside a shell, so traditional shell instructions ('|', etc) won't work. To use // a shell, you need to explicitly call out to that shell. + // +optional Command []string `json:"command,omitempty"` } @@ -1018,15 +1172,20 @@ type Probe struct { // The action taken to determine the health of a container Handler `json:",inline"` // Length of time before health checking is activated. In seconds. + // +optional InitialDelaySeconds int32 `json:"initialDelaySeconds,omitempty"` // Length of time before health checking times out. In seconds. + // +optional TimeoutSeconds int32 `json:"timeoutSeconds,omitempty"` // How often (in seconds) to perform the probe. + // +optional PeriodSeconds int32 `json:"periodSeconds,omitempty"` // Minimum consecutive successes for the probe to be considered successful after having failed. // Must be 1 for liveness. + // +optional SuccessThreshold int32 `json:"successThreshold,omitempty"` // Minimum consecutive failures for the probe to be considered failed after having succeeded. + // +optional FailureThreshold int32 `json:"failureThreshold,omitempty"` } @@ -1048,18 +1207,22 @@ type Capability string // Capabilities represent POSIX capabilities that can be added or removed to a running container. type Capabilities struct { // Added capabilities + // +optional Add []Capability `json:"add,omitempty"` // Removed capabilities + // +optional Drop []Capability `json:"drop,omitempty"` } // ResourceRequirements describes the compute resource requirements. type ResourceRequirements struct { // Limits describes the maximum amount of compute resources allowed. + // +optional Limits ResourceList `json:"limits,omitempty"` // Requests describes the minimum amount of compute resources required. // If Request is omitted for a container, it defaults to Limits if that is explicitly specified, // otherwise to an implementation-defined value + // +optional Requests ResourceList `json:"requests,omitempty"` } @@ -1075,36 +1238,51 @@ type Container struct { // cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax // can be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded, // regardless of whether the variable exists or not. + // +optional Command []string `json:"command,omitempty"` // Optional: The docker image's cmd is used if this is not provided; cannot be updated. // Variable references $(VAR_NAME) are expanded using the container's environment. If a variable // cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax // can be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded, // regardless of whether the variable exists or not. + // +optional Args []string `json:"args,omitempty"` // Optional: Defaults to Docker's default. - WorkingDir string `json:"workingDir,omitempty"` - Ports []ContainerPort `json:"ports,omitempty"` - Env []EnvVar `json:"env,omitempty"` + // +optional + WorkingDir string `json:"workingDir,omitempty"` + // +optional + Ports []ContainerPort `json:"ports,omitempty"` + // +optional + Env []EnvVar `json:"env,omitempty"` // Compute resource requirements. - Resources ResourceRequirements `json:"resources,omitempty"` - VolumeMounts []VolumeMount `json:"volumeMounts,omitempty"` - LivenessProbe *Probe `json:"livenessProbe,omitempty"` - ReadinessProbe *Probe `json:"readinessProbe,omitempty"` - Lifecycle *Lifecycle `json:"lifecycle,omitempty"` + // +optional + Resources ResourceRequirements `json:"resources,omitempty"` + // +optional + VolumeMounts []VolumeMount `json:"volumeMounts,omitempty"` + // +optional + LivenessProbe *Probe `json:"livenessProbe,omitempty"` + // +optional + ReadinessProbe *Probe `json:"readinessProbe,omitempty"` + // +optional + Lifecycle *Lifecycle `json:"lifecycle,omitempty"` // Required. + // +optional TerminationMessagePath string `json:"terminationMessagePath,omitempty"` // Required: Policy for pulling images for this container ImagePullPolicy PullPolicy `json:"imagePullPolicy"` // Optional: SecurityContext defines the security options the container should be run with. // If set, the fields of SecurityContext override the equivalent fields of PodSecurityContext. + // +optional SecurityContext *SecurityContext `json:"securityContext,omitempty"` // Variables for interactive containers, these have very specialized use-cases (e.g. debugging) // and shouldn't be used for general purpose containers. - Stdin bool `json:"stdin,omitempty"` + // +optional + Stdin bool `json:"stdin,omitempty"` + // +optional StdinOnce bool `json:"stdinOnce,omitempty"` - TTY bool `json:"tty,omitempty"` + // +optional + TTY bool `json:"tty,omitempty"` } // Handler defines a specific action that should be taken @@ -1112,11 +1290,14 @@ type Container struct { type Handler struct { // One and only one of the following should be specified. // Exec specifies the action to take. + // +optional Exec *ExecAction `json:"exec,omitempty"` // HTTPGet specifies the http request to perform. + // +optional HTTPGet *HTTPGetAction `json:"httpGet,omitempty"` // TCPSocket specifies an action involving a TCP port. // TODO: implement a realistic TCP lifecycle hook + // +optional TCPSocket *TCPSocketAction `json:"tcpSocket,omitempty"` } @@ -1126,9 +1307,11 @@ type Handler struct { type Lifecycle struct { // PostStart is called immediately after a container is created. If the handler fails, the container // is terminated and restarted. + // +optional PostStart *Handler `json:"postStart,omitempty"` // PreStop is called immediately before a container is terminated. The reason for termination is // passed to the handler. Regardless of the outcome of the handler, the container is eventually terminated. + // +optional PreStop *Handler `json:"preStop,omitempty"` } @@ -1148,38 +1331,52 @@ const ( type ContainerStateWaiting struct { // A brief CamelCase string indicating details about why the container is in waiting state. + // +optional Reason string `json:"reason,omitempty"` // A human-readable message indicating details about why the container is in waiting state. + // +optional Message string `json:"message,omitempty"` } type ContainerStateRunning struct { + // +optional StartedAt unversioned.Time `json:"startedAt,omitempty"` } type ContainerStateTerminated struct { - ExitCode int32 `json:"exitCode"` - Signal int32 `json:"signal,omitempty"` - Reason string `json:"reason,omitempty"` - Message string `json:"message,omitempty"` - StartedAt unversioned.Time `json:"startedAt,omitempty"` - FinishedAt unversioned.Time `json:"finishedAt,omitempty"` - ContainerID string `json:"containerID,omitempty"` + ExitCode int32 `json:"exitCode"` + // +optional + Signal int32 `json:"signal,omitempty"` + // +optional + Reason string `json:"reason,omitempty"` + // +optional + Message string `json:"message,omitempty"` + // +optional + StartedAt unversioned.Time `json:"startedAt,omitempty"` + // +optional + FinishedAt unversioned.Time `json:"finishedAt,omitempty"` + // +optional + ContainerID string `json:"containerID,omitempty"` } // ContainerState holds a possible state of container. // Only one of its members may be specified. // If none of them is specified, the default one is ContainerStateWaiting. type ContainerState struct { - Waiting *ContainerStateWaiting `json:"waiting,omitempty"` - Running *ContainerStateRunning `json:"running,omitempty"` + // +optional + Waiting *ContainerStateWaiting `json:"waiting,omitempty"` + // +optional + Running *ContainerStateRunning `json:"running,omitempty"` + // +optional Terminated *ContainerStateTerminated `json:"terminated,omitempty"` } type ContainerStatus struct { // Each container in a pod must have a unique name. - Name string `json:"name"` - State ContainerState `json:"state,omitempty"` + Name string `json:"name"` + // +optional + State ContainerState `json:"state,omitempty"` + // +optional LastTerminationState ContainerState `json:"lastState,omitempty"` // Ready specifies whether the container has passed its readiness check. Ready bool `json:"ready"` @@ -1188,7 +1385,8 @@ type ContainerStatus struct { RestartCount int32 `json:"restartCount"` Image string `json:"image"` ImageID string `json:"imageID"` - ContainerID string `json:"containerID,omitempty"` + // +optional + ContainerID string `json:"containerID,omitempty"` } // PodPhase is a label for the condition of a pod at the current time. @@ -1225,15 +1423,22 @@ const ( PodReady PodConditionType = "Ready" // PodInitialized means that all init containers in the pod have started successfully. PodInitialized PodConditionType = "Initialized" + // PodReasonUnschedulable reason in PodScheduled PodCondition means that the scheduler + // can't schedule the pod right now, for example due to insufficient resources in the cluster. + PodReasonUnschedulable = "Unschedulable" ) type PodCondition struct { - Type PodConditionType `json:"type"` - Status ConditionStatus `json:"status"` - LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` + Type PodConditionType `json:"type"` + Status ConditionStatus `json:"status"` + // +optional + LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` - Reason string `json:"reason,omitempty"` - Message string `json:"message,omitempty"` + // +optional + Reason string `json:"reason,omitempty"` + // +optional + Message string `json:"message,omitempty"` } // RestartPolicy describes how the container should be restarted. @@ -1251,6 +1456,7 @@ const ( // PodList is a list of Pods. type PodList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Pod `json:"items"` @@ -1297,6 +1503,7 @@ type NodeSelectorRequirement struct { // the values array must be empty. If the operator is Gt or Lt, the values // array must have a single element, which will be interpreted as an integer. // This array is replaced during a strategic merge patch. + // +optional Values []string `json:"values,omitempty"` } @@ -1316,10 +1523,13 @@ const ( // Affinity is a group of affinity scheduling rules. type Affinity struct { // Describes node affinity scheduling rules for the pod. + // +optional NodeAffinity *NodeAffinity `json:"nodeAffinity,omitempty"` // Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)). + // +optional PodAffinity *PodAffinity `json:"podAffinity,omitempty"` // Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)). + // +optional PodAntiAffinity *PodAntiAffinity `json:"podAntiAffinity,omitempty"` } @@ -1333,6 +1543,7 @@ type PodAffinity struct { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1341,6 +1552,7 @@ type PodAffinity struct { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional RequiredDuringSchedulingIgnoredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty"` // The scheduler will prefer to schedule pods to nodes that satisfy // the affinity expressions specified by this field, but it may choose @@ -1351,6 +1563,7 @@ type PodAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []WeightedPodAffinityTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty"` } @@ -1364,6 +1577,7 @@ type PodAntiAffinity struct { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the anti-affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1372,6 +1586,7 @@ type PodAntiAffinity struct { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional RequiredDuringSchedulingIgnoredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty"` // The scheduler will prefer to schedule pods to nodes that satisfy // the anti-affinity expressions specified by this field, but it may choose @@ -1382,6 +1597,7 @@ type PodAntiAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []WeightedPodAffinityTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty"` } @@ -1389,7 +1605,7 @@ type PodAntiAffinity struct { type WeightedPodAffinityTerm struct { // weight associated with matching the corresponding podAffinityTerm, // in the range 1-100. - Weight int `json:"weight"` + Weight int32 `json:"weight"` // Required. A pod affinity term, associated with the corresponding weight. PodAffinityTerm PodAffinityTerm `json:"podAffinityTerm"` } @@ -1402,6 +1618,7 @@ type WeightedPodAffinityTerm struct { // a pod of the set of pods is running. type PodAffinityTerm struct { // A label query over a set of resources, in this case pods. + // +optional LabelSelector *unversioned.LabelSelector `json:"labelSelector,omitempty"` // namespaces specifies which namespaces the labelSelector applies to (matches against); // nil list means "this pod's namespace," empty list means "all namespaces" @@ -1415,6 +1632,7 @@ type PodAffinityTerm struct { // For PreferredDuringScheduling pod anti-affinity, empty topologyKey is interpreted as "all topologies" // ("all topologies" here means all the topologyKeys indicated by scheduler command-line argument --failure-domains); // for affinity and for RequiredDuringScheduling pod anti-affinity, empty topologyKey is not allowed. + // +optional TopologyKey string `json:"topologyKey,omitempty"` } @@ -1426,6 +1644,7 @@ type NodeAffinity struct { // If the affinity requirements specified by this field cease to be met // at some point during pod execution (e.g. due to an update), the system // will try to eventually evict the pod from its node. + // +optional // RequiredDuringSchedulingRequiredDuringExecution *NodeSelector `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the affinity requirements specified by this field are not met at @@ -1433,6 +1652,7 @@ type NodeAffinity struct { // If the affinity requirements specified by this field cease to be met // at some point during pod execution (e.g. due to an update), the system // may or may not try to eventually evict the pod from its node. + // +optional RequiredDuringSchedulingIgnoredDuringExecution *NodeSelector `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty"` // The scheduler will prefer to schedule pods to nodes that satisfy // the affinity expressions specified by this field, but it may choose @@ -1443,6 +1663,7 @@ type NodeAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node matches the corresponding matchExpressions; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []PreferredSchedulingTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty"` } @@ -1461,6 +1682,7 @@ type Taint struct { // Required. The taint key to be applied to a node. Key string `json:"key" patchStrategy:"merge" patchMergeKey:"key"` // Required. The taint value corresponding to the taint key. + // +optional Value string `json:"value,omitempty"` // Required. The effect of the taint on pods // that do not tolerate the taint. @@ -1498,17 +1720,21 @@ const ( // the triple using the matching operator . type Toleration struct { // Required. Key is the taint key that the toleration applies to. + // +optional Key string `json:"key,omitempty" patchStrategy:"merge" patchMergeKey:"key"` // operator represents a key's relationship to the value. // Valid operators are Exists and Equal. Defaults to Equal. // Exists is equivalent to wildcard for value, so that a pod can // tolerate all taints of a particular category. + // +optional Operator TolerationOperator `json:"operator,omitempty"` // Value is the taint value the toleration matches to. // If the operator is Exists, the value should be empty, otherwise just a regular string. + // +optional Value string `json:"value,omitempty"` // Effect indicates the taint effect to match. Empty means match all taint effects. // When specified, allowed values are NoSchedule and PreferNoSchedule. + // +optional Effect TaintEffect `json:"effect,omitempty"` // TODO: For forgiveness (#1574), we'd eventually add at least a grace period // here, and possibly an occurrence threshold and period. @@ -1528,7 +1754,8 @@ type PodSpec struct { // List of initialization containers belonging to the pod. InitContainers []Container `json:"-"` // List of containers belonging to the pod. - Containers []Container `json:"containers"` + Containers []Container `json:"containers"` + // +optional RestartPolicy RestartPolicy `json:"restartPolicy,omitempty"` // Optional duration in seconds the pod needs to terminate gracefully. May be decreased in delete request. // Value must be non-negative integer. The value zero indicates delete immediately. @@ -1536,13 +1763,17 @@ type PodSpec struct { // The grace period is the duration in seconds after the processes running in the pod are sent // a termination signal and the time when the processes are forcibly halted with a kill signal. // Set this value longer than the expected cleanup time for your process. + // +optional TerminationGracePeriodSeconds *int64 `json:"terminationGracePeriodSeconds,omitempty"` // Optional duration in seconds relative to the StartTime that the pod may be active on a node // before the system actively tries to terminate the pod; value must be positive integer + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty"` // Required: Set DNS policy. + // +optional DNSPolicy DNSPolicy `json:"dnsPolicy,omitempty"` // NodeSelector is a selector which must be true for the pod to fit on a node + // +optional NodeSelector map[string]string `json:"nodeSelector,omitempty"` // ServiceAccountName is the name of the ServiceAccount to use to run this pod @@ -1552,19 +1783,24 @@ type PodSpec struct { // NodeName is a request to schedule this pod onto a specific node. If it is non-empty, // the scheduler simply schedules this pod onto that node, assuming that it fits resource // requirements. + // +optional NodeName string `json:"nodeName,omitempty"` // SecurityContext holds pod-level security attributes and common container settings. // Optional: Defaults to empty. See type description for default values of each field. + // +optional SecurityContext *PodSecurityContext `json:"securityContext,omitempty"` // ImagePullSecrets is an optional list of references to secrets in the same namespace to use for pulling any of the images used by this PodSpec. // If specified, these secrets will be passed to individual puller implementations for them to use. For example, // in the case of docker, only DockerConfig type secrets are honored. + // +optional ImagePullSecrets []LocalObjectReference `json:"imagePullSecrets,omitempty"` // Specifies the hostname of the Pod. // If not specified, the pod's hostname will be set to a system-defined value. + // +optional Hostname string `json:"hostname,omitempty"` // If specified, the fully qualified Pod hostname will be "...svc.". // If not specified, the pod will not have a domainname at all. + // +optional Subdomain string `json:"subdomain,omitempty"` } @@ -1584,26 +1820,31 @@ type PodSecurityContext struct { // used must be specified. // Optional: Default to false // +k8s:conversion-gen=false + // +optional HostNetwork bool `json:"hostNetwork,omitempty"` // Use the host's pid namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional HostPID bool `json:"hostPID,omitempty"` // Use the host's ipc namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional HostIPC bool `json:"hostIPC,omitempty"` // The SELinux context to be applied to all containers. // If unspecified, the container runtime will allocate a random SELinux context for each // container. May also be set in SecurityContext. If set in // both SecurityContext and PodSecurityContext, the value specified in SecurityContext // takes precedence for that container. + // +optional SELinuxOptions *SELinuxOptions `json:"seLinuxOptions,omitempty"` // The UID to run the entrypoint of the container process. // Defaults to user specified in image metadata if unspecified. // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence // for that container. + // +optional RunAsUser *int64 `json:"runAsUser,omitempty"` // Indicates that the container must run as a non-root user. // If true, the Kubelet will validate the image at runtime to ensure that it @@ -1611,10 +1852,12 @@ type PodSecurityContext struct { // If unset or false, no such validation will be performed. // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsNonRoot *bool `json:"runAsNonRoot,omitempty"` // A list of groups applied to the first process run in each container, in addition // to the container's primary GID. If unspecified, no groups will be added to // any container. + // +optional SupplementalGroups []int64 `json:"supplementalGroups,omitempty"` // A special supplemental group that applies to all containers in a pod. // Some volume types allow the Kubelet to change the ownership of that volume @@ -1625,24 +1868,32 @@ type PodSecurityContext struct { // 3. The permission bits are OR'd with rw-rw---- // // If unset, the Kubelet will not modify the ownership and permissions of any volume. + // +optional FSGroup *int64 `json:"fsGroup,omitempty"` } // PodStatus represents information about the status of a pod. Status may trail the actual // state of a system. type PodStatus struct { - Phase PodPhase `json:"phase,omitempty"` + // +optional + Phase PodPhase `json:"phase,omitempty"` + // +optional Conditions []PodCondition `json:"conditions,omitempty"` // A human readable message indicating details about why the pod is in this state. + // +optional Message string `json:"message,omitempty"` // A brief CamelCase message indicating details about why the pod is in this state. e.g. 'OutOfDisk' + // +optional Reason string `json:"reason,omitempty"` + // +optional HostIP string `json:"hostIP,omitempty"` - PodIP string `json:"podIP,omitempty"` + // +optional + PodIP string `json:"podIP,omitempty"` // Date and time at which the object was acknowledged by the Kubelet. // This is before the Kubelet pulled the container image(s) for the pod. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty"` // The list has one entry per init container in the manifest. The most recent successful @@ -1655,15 +1906,18 @@ type PodStatus struct { // final and should not be relied upon. // TODO: Make real decisions about what our info should look like. Re-enable fuzz test // when we have done this. + // +optional ContainerStatuses []ContainerStatus `json:"containerStatuses,omitempty"` } // PodStatusResult is a wrapper for PodStatus returned by kubelet that can be encode/decoded type PodStatusResult struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Status represents the current information about a pod. This data may not be up // to date. + // +optional Status PodStatus `json:"status,omitempty"` } @@ -1672,22 +1926,27 @@ type PodStatusResult struct { // Pod is a collection of containers, used as either input (create, update) or as output (list, get). type Pod struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the behavior of a pod. + // +optional Spec PodSpec `json:"spec,omitempty"` // Status represents the current information about a pod. This data may not be up // to date. + // +optional Status PodStatus `json:"status,omitempty"` } // PodTemplateSpec describes the data a pod should have when created from a template type PodTemplateSpec struct { // Metadata of the pods created from this template. + // +optional ObjectMeta `json:"metadata,omitempty"` // Spec defines the behavior of a pod. + // +optional Spec PodSpec `json:"spec,omitempty"` } @@ -1696,15 +1955,18 @@ type PodTemplateSpec struct { // PodTemplate describes a template for creating copies of a predefined pod. type PodTemplate struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Template defines the pods that will be created from this pod template + // +optional Template PodTemplateSpec `json:"template,omitempty"` } // PodTemplateList is a list of PodTemplates. type PodTemplateList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []PodTemplate `json:"items"` @@ -1720,6 +1982,7 @@ type ReplicationControllerSpec struct { // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty"` // Selector is a label query over pods that should match the Replicas count. @@ -1728,11 +1991,13 @@ type ReplicationControllerSpec struct { // TemplateRef is a reference to an object that describes the pod that will be created if // insufficient replicas are detected. This reference is ignored if a Template is set. // Must be set before converting to a versioned API object + // +optional //TemplateRef *ObjectReference `json:"templateRef,omitempty"` // Template is the object that describes the pod that will be created if // insufficient replicas are detected. Internally, this takes precedence over a // TemplateRef. + // +optional Template *PodTemplateSpec `json:"template,omitempty"` } @@ -1743,18 +2008,23 @@ type ReplicationControllerStatus struct { Replicas int32 `json:"replicas"` // The number of pods that have labels matching the labels of the pod template of the replication controller. + // +optional FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty"` // The number of ready replicas for this replication controller. + // +optional ReadyReplicas int32 `json:"readyReplicas,omitempty"` // The number of available replicas (ready for at least minReadySeconds) for this replication controller. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty"` // ObservedGeneration is the most recent generation observed by the controller. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` // Represents the latest available observations of a replication controller's current state. + // +optional Conditions []ReplicationControllerCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` } @@ -1774,13 +2044,14 @@ type ReplicationControllerCondition struct { Type ReplicationControllerConditionType `json:"type"` // Status of the condition, one of True, False, Unknown. Status ConditionStatus `json:"status"` - // Last time we probed the condition. - LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` // The last time the condition transitioned from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` // The reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty"` // A human readable message indicating details about the transition. + // +optional Message string `json:"message,omitempty"` } @@ -1789,19 +2060,23 @@ type ReplicationControllerCondition struct { // ReplicationController represents the configuration of a replication controller. type ReplicationController struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the desired behavior of this replication controller. + // +optional Spec ReplicationControllerSpec `json:"spec,omitempty"` // Status is the current status of this replication controller. This data may be // out of date by some window of time. + // +optional Status ReplicationControllerStatus `json:"status,omitempty"` } // ReplicationControllerList is a collection of replication controllers. type ReplicationControllerList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []ReplicationController `json:"items"` @@ -1816,6 +2091,7 @@ const ( // ServiceList holds a list of services. type ServiceList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Service `json:"items"` @@ -1859,6 +2135,7 @@ const ( type ServiceStatus struct { // LoadBalancer contains the current status of the load-balancer, // if one is present. + // +optional LoadBalancer LoadBalancerStatus `json:"loadBalancer,omitempty"` } @@ -1866,6 +2143,7 @@ type ServiceStatus struct { type LoadBalancerStatus struct { // Ingress is a list containing ingress points for the load-balancer; // traffic intended for the service should be sent to these ingress points. + // +optional Ingress []LoadBalancerIngress `json:"ingress,omitempty"` } @@ -1874,10 +2152,12 @@ type LoadBalancerStatus struct { type LoadBalancerIngress struct { // IP is set for load-balancer ingress points that are IP based // (typically GCE or OpenStack load-balancers) + // +optional IP string `json:"ip,omitempty"` // Hostname is set for load-balancer ingress points that are DNS based // (typically AWS load-balancers) + // +optional Hostname string `json:"hostname,omitempty"` } @@ -1897,6 +2177,7 @@ type ServiceSpec struct { // external load-balancer (if supported in the current cloud) which routes // to the clusterIP. // More info: http://kubernetes.io/docs/user-guide/services#overview + // +optional Type ServiceType `json:"type,omitempty"` // Required: The list of ports that are exposed by this service. @@ -1919,6 +2200,7 @@ type ServiceSpec struct { // Only applies to types ClusterIP, NodePort, and LoadBalancer. Ignored if // type is ExternalName. // More info: http://kubernetes.io/docs/user-guide/services#virtual-ips-and-service-proxies + // +optional ClusterIP string `json:"clusterIP,omitempty"` // ExternalName is the external reference that kubedns or equivalent will @@ -1928,6 +2210,7 @@ type ServiceSpec struct { // ExternalIPs are used by external load balancers, or can be set by // users to handle external traffic that arrives at a node. + // +optional ExternalIPs []string `json:"externalIPs,omitempty"` // Only applies to Service Type: LoadBalancer @@ -1935,14 +2218,17 @@ type ServiceSpec struct { // This feature depends on whether the underlying cloud-provider supports specifying // the loadBalancerIP when a load balancer is created. // This field will be ignored if the cloud-provider does not support the feature. + // +optional LoadBalancerIP string `json:"loadBalancerIP,omitempty"` // Optional: Supports "ClientIP" and "None". Used to maintain session affinity. + // +optional SessionAffinity ServiceAffinity `json:"sessionAffinity,omitempty"` // Optional: If specified and supported by the platform, this will restrict traffic through the cloud-provider // load-balancer will be restricted to the specified client IPs. This field will be ignored if the // cloud-provider does not support the feature." + // +optional LoadBalancerSourceRanges []string `json:"loadBalancerSourceRanges,omitempty"` } @@ -1979,12 +2265,15 @@ type ServicePort struct { // will answer requests sent through the proxy. type Service struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the behavior of a service. + // +optional Spec ServiceSpec `json:"spec,omitempty"` // Status represents the current status of a service. + // +optional Status ServiceStatus `json:"status,omitempty"` } @@ -1996,7 +2285,8 @@ type Service struct { // * a set of secrets type ServiceAccount struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Secrets is the list of secrets allowed to be used by pods running using this ServiceAccount Secrets []ObjectReference `json:"secrets"` @@ -2004,12 +2294,14 @@ type ServiceAccount struct { // ImagePullSecrets is a list of references to secrets in the same namespace to use for pulling any images // in pods that reference this ServiceAccount. ImagePullSecrets are distinct from Secrets because Secrets // can be mounted in the pod, but ImagePullSecrets are only accessed by the kubelet. + // +optional ImagePullSecrets []LocalObjectReference `json:"imagePullSecrets,omitempty"` } // ServiceAccountList is a list of ServiceAccount objects type ServiceAccountList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []ServiceAccount `json:"items"` @@ -2031,7 +2323,8 @@ type ServiceAccountList struct { // ] type Endpoints struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // The set of all endpoints is the union of all subsets. Subsets []EndpointSubset @@ -2062,8 +2355,10 @@ type EndpointAddress struct { IP string // Optional: Hostname of this endpoint // Meant to be used by DNS servers etc. + // +optional Hostname string `json:"hostname,omitempty"` // Optional: Node hosting this endpoint. This can be used to determine endpoints local to a node. + // +optional NodeName *string `json:"nodeName,omitempty"` // Optional: The kubernetes object related to the entry point. TargetRef *ObjectReference @@ -2085,6 +2380,7 @@ type EndpointPort struct { // EndpointsList is a list of endpoints. type EndpointsList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Endpoints `json:"items"` @@ -2094,16 +2390,20 @@ type EndpointsList struct { type NodeSpec struct { // PodCIDR represents the pod IP range assigned to the node // Note: assigning IP ranges to nodes might need to be revisited when we support migratable IPs. + // +optional PodCIDR string `json:"podCIDR,omitempty"` // External ID of the node assigned by some machine database (e.g. a cloud provider) + // +optional ExternalID string `json:"externalID,omitempty"` // ID of the node assigned by the cloud provider // Note: format is "://" + // +optional ProviderID string `json:"providerID,omitempty"` // Unschedulable controls node schedulability of new pods. By default node is schedulable. + // +optional Unschedulable bool `json:"unschedulable,omitempty"` } @@ -2122,6 +2422,7 @@ type DaemonEndpoint struct { // NodeDaemonEndpoints lists ports opened by daemons running on the Node. type NodeDaemonEndpoints struct { // Endpoint on which Kubelet is listening. + // +optional KubeletEndpoint DaemonEndpoint `json:"kubeletEndpoint,omitempty"` } @@ -2156,24 +2457,34 @@ type NodeSystemInfo struct { // NodeStatus is information about the current status of a node. type NodeStatus struct { // Capacity represents the total resources of a node. + // +optional Capacity ResourceList `json:"capacity,omitempty"` // Allocatable represents the resources of a node that are available for scheduling. + // +optional Allocatable ResourceList `json:"allocatable,omitempty"` // NodePhase is the current lifecycle phase of the node. + // +optional Phase NodePhase `json:"phase,omitempty"` // Conditions is an array of current node conditions. + // +optional Conditions []NodeCondition `json:"conditions,omitempty"` // Queried from cloud provider, if available. + // +optional Addresses []NodeAddress `json:"addresses,omitempty"` // Endpoints of daemons running on the Node. + // +optional DaemonEndpoints NodeDaemonEndpoints `json:"daemonEndpoints,omitempty"` // Set of ids/uuids to uniquely identify the node. + // +optional NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty"` // List of container images on this node + // +optional Images []ContainerImage `json:"images,omitempty"` // List of attachable volumes in use (mounted) by the node. + // +optional VolumesInUse []UniqueVolumeName `json:"volumesInUse,omitempty"` // List of volumes that are attached to the node. + // +optional VolumesAttached []AttachedVolume `json:"volumesAttached,omitempty"` } @@ -2194,6 +2505,7 @@ type AttachedVolume struct { type AvoidPods struct { // Bounded-sized list of signatures of pods that should avoid this node, sorted // in timestamp order from oldest to newest. Size of the slice is unspecified. + // +optional PreferAvoidPods []PreferAvoidPodsEntry `json:"preferAvoidPods,omitempty"` } @@ -2202,10 +2514,13 @@ type PreferAvoidPodsEntry struct { // The class of pods. PodSignature PodSignature `json:"podSignature"` // Time at which this entry was added to the list. + // +optional EvictionTime unversioned.Time `json:"evictionTime,omitempty"` // (brief) reason why this entry was added to the list. + // +optional Reason string `json:"reason,omitempty"` // Human readable message indicating why this entry was added to the list. + // +optional Message string `json:"message,omitempty"` } @@ -2213,6 +2528,7 @@ type PreferAvoidPodsEntry struct { // Exactly one field should be set. type PodSignature struct { // Reference to controller whose pods should avoid this node. + // +optional PodController *OwnerReference `json:"podController,omitempty"` } @@ -2221,6 +2537,7 @@ type ContainerImage struct { // Names by which this image is known. Names []string `json:"names"` // The size of the image in bytes. + // +optional SizeBytes int64 `json:"sizeBytes,omitempty"` } @@ -2258,12 +2575,16 @@ const ( ) type NodeCondition struct { - Type NodeConditionType `json:"type"` - Status ConditionStatus `json:"status"` - LastHeartbeatTime unversioned.Time `json:"lastHeartbeatTime,omitempty"` - LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` - Reason string `json:"reason,omitempty"` - Message string `json:"message,omitempty"` + Type NodeConditionType `json:"type"` + Status ConditionStatus `json:"status"` + // +optional + LastHeartbeatTime unversioned.Time `json:"lastHeartbeatTime,omitempty"` + // +optional + LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` + // +optional + Reason string `json:"reason,omitempty"` + // +optional + Message string `json:"message,omitempty"` } type NodeAddressType string @@ -2286,6 +2607,7 @@ type NodeAddress struct { // see http://releases.k8s.io/HEAD/docs/design/resources.md for more details. type NodeResources struct { // Capacity represents the available resources of a node + // +optional Capacity ResourceList `json:"capacity,omitempty"` } @@ -2309,6 +2631,11 @@ const ( // Number of Pods that may be running on this Node: see ResourcePods ) +const ( + // Namespace prefix for opaque counted resources (alpha). + ResourceOpaqueIntPrefix = "pod.alpha.kubernetes.io/opaque-int-resource-" +) + // ResourceList is a set of (resource name, quantity) pairs. type ResourceList map[ResourceName]resource.Quantity @@ -2319,18 +2646,22 @@ type ResourceList map[ResourceName]resource.Quantity // The name of the node according to etcd is in ObjectMeta.Name. type Node struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the behavior of a node. + // +optional Spec NodeSpec `json:"spec,omitempty"` // Status describes the current status of a Node + // +optional Status NodeStatus `json:"status,omitempty"` } // NodeList is a list of nodes. type NodeList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Node `json:"items"` @@ -2353,6 +2684,7 @@ const ( // NamespaceStatus is information about the current status of a Namespace. type NamespaceStatus struct { // Phase is the current lifecycle phase of the namespace. + // +optional Phase NamespacePhase `json:"phase,omitempty"` } @@ -2373,18 +2705,22 @@ const ( // Use of multiple namespaces is optional type Namespace struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the behavior of the Namespace. + // +optional Spec NamespaceSpec `json:"spec,omitempty"` // Status describes the current status of a Namespace + // +optional Status NamespaceStatus `json:"status,omitempty"` } // NamespaceList is a list of Namespaces. type NamespaceList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Namespace `json:"items"` @@ -2394,6 +2730,7 @@ type NamespaceList struct { type Binding struct { unversioned.TypeMeta `json:",inline"` // ObjectMeta describes the object that is being bound. + // +optional ObjectMeta `json:"metadata,omitempty"` // Target is the object to bind to. @@ -2403,6 +2740,7 @@ type Binding struct { // Preconditions must be fulfilled before an operation (update, delete, etc.) is carried out. type Preconditions struct { // Specifies the target UID. + // +optional UID *types.UID `json:"uid,omitempty"` } @@ -2413,14 +2751,17 @@ type DeleteOptions struct { // Optional duration in seconds before the object should be deleted. Value must be non-negative integer. // The value zero indicates delete immediately. If this value is nil, the default grace period for the // specified type will be used. + // +optional GracePeriodSeconds *int64 `json:"gracePeriodSeconds,omitempty"` // Must be fulfilled before a deletion is carried out. If not possible, a 409 Conflict status will be // returned. + // +optional Preconditions *Preconditions `json:"preconditions,omitempty"` // Should the dependent objects be orphaned. If true/false, the "orphan" // finalizer will be added to/removed from the object's finalizers list. + // +optional OrphanDependents *bool `json:"orphanDependents,omitempty"` } @@ -2492,18 +2833,23 @@ type PodAttachOptions struct { unversioned.TypeMeta `json:",inline"` // Stdin if true indicates that stdin is to be redirected for the attach call + // +optional Stdin bool `json:"stdin,omitempty"` // Stdout if true indicates that stdout is to be redirected for the attach call + // +optional Stdout bool `json:"stdout,omitempty"` // Stderr if true indicates that stderr is to be redirected for the attach call + // +optional Stderr bool `json:"stderr,omitempty"` // TTY if true indicates that a tty will be allocated for the attach call + // +optional TTY bool `json:"tty,omitempty"` // Container to attach to. + // +optional Container string `json:"container,omitempty"` } @@ -2574,17 +2920,24 @@ type OwnerReference struct { // More info: http://kubernetes.io/docs/user-guide/identifiers#uids UID types.UID `json:"uid"` // If true, this reference points to the managing controller. + // +optional Controller *bool `json:"controller,omitempty"` } // ObjectReference contains enough information to let you inspect or modify the referred object. type ObjectReference struct { - Kind string `json:"kind,omitempty"` - Namespace string `json:"namespace,omitempty"` - Name string `json:"name,omitempty"` - UID types.UID `json:"uid,omitempty"` - APIVersion string `json:"apiVersion,omitempty"` - ResourceVersion string `json:"resourceVersion,omitempty"` + // +optional + Kind string `json:"kind,omitempty"` + // +optional + Namespace string `json:"namespace,omitempty"` + // +optional + Name string `json:"name,omitempty"` + // +optional + UID types.UID `json:"uid,omitempty"` + // +optional + APIVersion string `json:"apiVersion,omitempty"` + // +optional + ResourceVersion string `json:"resourceVersion,omitempty"` // Optional. If referring to a piece of an object instead of an entire object, this string // should contain information to identify the sub-object. For example, if the object @@ -2594,6 +2947,7 @@ type ObjectReference struct { // index 2 in this pod). This syntax is chosen only to have some well-defined way of // referencing a part of an object. // TODO: this design is not final and this field is subject to change in the future. + // +optional FieldPath string `json:"fieldPath,omitempty"` } @@ -2605,13 +2959,16 @@ type LocalObjectReference struct { type SerializedReference struct { unversioned.TypeMeta `json:",inline"` - Reference ObjectReference `json:"reference,omitempty"` + // +optional + Reference ObjectReference `json:"reference,omitempty"` } type EventSource struct { // Component from which the event is generated. + // +optional Component string `json:"component,omitempty"` // Node name on which the event is generated. + // +optional Host string `json:"host,omitempty"` } @@ -2629,40 +2986,50 @@ const ( // TODO: Decide whether to store these separately or with the object they apply to. type Event struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Required. The object that this event is about. + // +optional InvolvedObject ObjectReference `json:"involvedObject,omitempty"` // Optional; this should be a short, machine understandable string that gives the reason // for this event being generated. For example, if the event is reporting that a container // can't start, the Reason might be "ImageNotFound". // TODO: provide exact specification for format. + // +optional Reason string `json:"reason,omitempty"` // Optional. A human-readable description of the status of this operation. // TODO: decide on maximum length. + // +optional Message string `json:"message,omitempty"` // Optional. The component reporting this event. Should be a short machine understandable string. + // +optional Source EventSource `json:"source,omitempty"` // The time at which the event was first recorded. (Time of server receipt is in TypeMeta.) + // +optional FirstTimestamp unversioned.Time `json:"firstTimestamp,omitempty"` // The time at which the most recent occurrence of this event was recorded. + // +optional LastTimestamp unversioned.Time `json:"lastTimestamp,omitempty"` // The number of times this event has occurred. + // +optional Count int32 `json:"count,omitempty"` // Type of this event (Normal, Warning), new types could be added in the future. + // +optional Type string `json:"type,omitempty"` } // EventList is a list of events. type EventList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Event `json:"items"` @@ -2671,6 +3038,7 @@ type EventList struct { // List holds a list of objects, which may not be known by the server. type List struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []runtime.Object `json:"items"` @@ -2691,16 +3059,22 @@ const ( // LimitRangeItem defines a min/max usage limit for any resource that matches on kind type LimitRangeItem struct { // Type of resource that this limit applies to + // +optional Type LimitType `json:"type,omitempty"` // Max usage constraints on this kind by resource name + // +optional Max ResourceList `json:"max,omitempty"` // Min usage constraints on this kind by resource name + // +optional Min ResourceList `json:"min,omitempty"` // Default resource requirement limit value by resource name. + // +optional Default ResourceList `json:"default,omitempty"` // DefaultRequest resource requirement request value by resource name. + // +optional DefaultRequest ResourceList `json:"defaultRequest,omitempty"` // MaxLimitRequestRatio represents the max burst value for the named resource + // +optional MaxLimitRequestRatio ResourceList `json:"maxLimitRequestRatio,omitempty"` } @@ -2715,15 +3089,18 @@ type LimitRangeSpec struct { // LimitRange sets resource usage limits for each kind of resource in a Namespace type LimitRange struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the limits enforced + // +optional Spec LimitRangeSpec `json:"spec,omitempty"` } // LimitRangeList is a list of LimitRange items. type LimitRangeList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is a list of LimitRange objects @@ -2779,17 +3156,21 @@ const ( // ResourceQuotaSpec defines the desired hard limits to enforce for Quota type ResourceQuotaSpec struct { // Hard is the set of desired hard limits for each named resource + // +optional Hard ResourceList `json:"hard,omitempty"` // A collection of filters that must match each object tracked by a quota. // If not specified, the quota matches all objects. + // +optional Scopes []ResourceQuotaScope `json:"scopes,omitempty"` } // ResourceQuotaStatus defines the enforced hard limits and observed use type ResourceQuotaStatus struct { // Hard is the set of enforced hard limits for each named resource + // +optional Hard ResourceList `json:"hard,omitempty"` // Used is the current observed total usage of the resource in the namespace + // +optional Used ResourceList `json:"used,omitempty"` } @@ -2798,18 +3179,22 @@ type ResourceQuotaStatus struct { // ResourceQuota sets aggregate quota restrictions enforced per namespace type ResourceQuota struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Spec defines the desired quota + // +optional Spec ResourceQuotaSpec `json:"spec,omitempty"` // Status defines the actual enforced quota and its current usage + // +optional Status ResourceQuotaStatus `json:"status,omitempty"` } // ResourceQuotaList is a list of ResourceQuota items type ResourceQuotaList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is a list of ResourceQuota objects @@ -2822,15 +3207,18 @@ type ResourceQuotaList struct { // the Data field must be less than MaxSecretSize bytes. type Secret struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Data contains the secret data. Each key must be a valid DNS_SUBDOMAIN // or leading dot followed by valid DNS_SUBDOMAIN. // The serialized form of the secret data is a base64 encoded string, // representing the arbitrary (possibly non-string) data value here. + // +optional Data map[string][]byte `json:"data,omitempty"` // Used to facilitate programmatic handling of secret data. + // +optional Type SecretType `json:"type,omitempty"` } @@ -2920,6 +3308,7 @@ const ( type SecretList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []Secret `json:"items"` @@ -2930,16 +3319,19 @@ type SecretList struct { // ConfigMap holds configuration data for components or applications to consume. type ConfigMap struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // Data contains the configuration data. // Each key must be a valid DNS_SUBDOMAIN with an optional leading dot. + // +optional Data map[string]string `json:"data,omitempty"` } // ConfigMapList is a resource containing a list of ConfigMap objects. type ConfigMapList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of ConfigMaps. @@ -3007,10 +3399,12 @@ const ( ) type ComponentCondition struct { - Type ComponentConditionType `json:"type"` - Status ConditionStatus `json:"status"` - Message string `json:"message,omitempty"` - Error string `json:"error,omitempty"` + Type ComponentConditionType `json:"type"` + Status ConditionStatus `json:"status"` + // +optional + Message string `json:"message,omitempty"` + // +optional + Error string `json:"error,omitempty"` } // +genclient=true @@ -3019,13 +3413,16 @@ type ComponentCondition struct { // ComponentStatus (and ComponentStatusList) holds the cluster validation info. type ComponentStatus struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` + // +optional Conditions []ComponentCondition `json:"conditions,omitempty"` } type ComponentStatusList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []ComponentStatus `json:"items"` @@ -3037,20 +3434,24 @@ type ComponentStatusList struct { type SecurityContext struct { // The capabilities to add/drop when running containers. // Defaults to the default set of capabilities granted by the container runtime. + // +optional Capabilities *Capabilities `json:"capabilities,omitempty"` // Run container in privileged mode. // Processes in privileged containers are essentially equivalent to root on the host. // Defaults to false. + // +optional Privileged *bool `json:"privileged,omitempty"` // The SELinux context to be applied to the container. // If unspecified, the container runtime will allocate a random SELinux context for each // container. May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional SELinuxOptions *SELinuxOptions `json:"seLinuxOptions,omitempty"` // The UID to run the entrypoint of the container process. // Defaults to user specified in image metadata if unspecified. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsUser *int64 `json:"runAsUser,omitempty"` // Indicates that the container must run as a non-root user. // If true, the Kubelet will validate the image at runtime to ensure that it @@ -3058,21 +3459,27 @@ type SecurityContext struct { // If unset or false, no such validation will be performed. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsNonRoot *bool `json:"runAsNonRoot,omitempty"` // The read-only root filesystem allows you to restrict the locations that an application can write // files to, ensuring the persistent data can only be written to mounts. + // +optional ReadOnlyRootFilesystem *bool `json:"readOnlyRootFilesystem,omitempty"` } // SELinuxOptions are the labels to be applied to the container. type SELinuxOptions struct { // SELinux user label + // +optional User string `json:"user,omitempty"` // SELinux role label + // +optional Role string `json:"role,omitempty"` // SELinux type label + // +optional Type string `json:"type,omitempty"` // SELinux level label. + // +optional Level string `json:"level,omitempty"` } @@ -3085,7 +3492,8 @@ type SELinuxOptions struct { // of the cluster, thus the object is less strongly typed than most. type RangeAllocation struct { unversioned.TypeMeta `json:",inline"` - ObjectMeta `json:"metadata,omitempty"` + // +optional + ObjectMeta `json:"metadata,omitempty"` // A string representing a unique label for a range of resources, such as a CIDR "10.0.0.0/8" or // port range "10000-30000". Range is not strongly schema'd here. The Range is expected to define // a start and end unless there is an implicit end. diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/doc.go b/vendor/k8s.io/client-go/pkg/api/unversioned/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/doc.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/doc.go index 02566d2..720c686 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/doc.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/doc.go @@ -16,5 +16,6 @@ limitations under the License. // +k8s:deepcopy-gen=package // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package unversioned diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/duration.go b/vendor/k8s.io/client-go/pkg/api/unversioned/duration.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/duration.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/duration.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.pb.go b/vendor/k8s.io/client-go/pkg/api/unversioned/generated.pb.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.pb.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/generated.pb.go index f78dcba..a50052d 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/generated.pb.go @@ -176,30 +176,30 @@ func (*TypeMeta) ProtoMessage() {} func (*TypeMeta) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{23} } func init() { - proto.RegisterType((*APIGroup)(nil), "k8s.io.kubernetes.pkg.api.unversioned.APIGroup") - proto.RegisterType((*APIGroupList)(nil), "k8s.io.kubernetes.pkg.api.unversioned.APIGroupList") - proto.RegisterType((*APIResource)(nil), "k8s.io.kubernetes.pkg.api.unversioned.APIResource") - proto.RegisterType((*APIResourceList)(nil), "k8s.io.kubernetes.pkg.api.unversioned.APIResourceList") - proto.RegisterType((*APIVersions)(nil), "k8s.io.kubernetes.pkg.api.unversioned.APIVersions") - proto.RegisterType((*Duration)(nil), "k8s.io.kubernetes.pkg.api.unversioned.Duration") - proto.RegisterType((*ExportOptions)(nil), "k8s.io.kubernetes.pkg.api.unversioned.ExportOptions") - proto.RegisterType((*GroupKind)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupKind") - proto.RegisterType((*GroupResource)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupResource") - proto.RegisterType((*GroupVersion)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupVersion") - proto.RegisterType((*GroupVersionForDiscovery)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupVersionForDiscovery") - proto.RegisterType((*GroupVersionKind)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupVersionKind") - proto.RegisterType((*GroupVersionResource)(nil), "k8s.io.kubernetes.pkg.api.unversioned.GroupVersionResource") - proto.RegisterType((*LabelSelector)(nil), "k8s.io.kubernetes.pkg.api.unversioned.LabelSelector") - proto.RegisterType((*LabelSelectorRequirement)(nil), "k8s.io.kubernetes.pkg.api.unversioned.LabelSelectorRequirement") - proto.RegisterType((*ListMeta)(nil), "k8s.io.kubernetes.pkg.api.unversioned.ListMeta") - proto.RegisterType((*RootPaths)(nil), "k8s.io.kubernetes.pkg.api.unversioned.RootPaths") - proto.RegisterType((*ServerAddressByClientCIDR)(nil), "k8s.io.kubernetes.pkg.api.unversioned.ServerAddressByClientCIDR") - proto.RegisterType((*Status)(nil), "k8s.io.kubernetes.pkg.api.unversioned.Status") - proto.RegisterType((*StatusCause)(nil), "k8s.io.kubernetes.pkg.api.unversioned.StatusCause") - proto.RegisterType((*StatusDetails)(nil), "k8s.io.kubernetes.pkg.api.unversioned.StatusDetails") - proto.RegisterType((*Time)(nil), "k8s.io.kubernetes.pkg.api.unversioned.Time") - proto.RegisterType((*Timestamp)(nil), "k8s.io.kubernetes.pkg.api.unversioned.Timestamp") - proto.RegisterType((*TypeMeta)(nil), "k8s.io.kubernetes.pkg.api.unversioned.TypeMeta") + proto.RegisterType((*APIGroup)(nil), "k8s.io.client-go.pkg.api.unversioned.APIGroup") + proto.RegisterType((*APIGroupList)(nil), "k8s.io.client-go.pkg.api.unversioned.APIGroupList") + proto.RegisterType((*APIResource)(nil), "k8s.io.client-go.pkg.api.unversioned.APIResource") + proto.RegisterType((*APIResourceList)(nil), "k8s.io.client-go.pkg.api.unversioned.APIResourceList") + proto.RegisterType((*APIVersions)(nil), "k8s.io.client-go.pkg.api.unversioned.APIVersions") + proto.RegisterType((*Duration)(nil), "k8s.io.client-go.pkg.api.unversioned.Duration") + proto.RegisterType((*ExportOptions)(nil), "k8s.io.client-go.pkg.api.unversioned.ExportOptions") + proto.RegisterType((*GroupKind)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupKind") + proto.RegisterType((*GroupResource)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupResource") + proto.RegisterType((*GroupVersion)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupVersion") + proto.RegisterType((*GroupVersionForDiscovery)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupVersionForDiscovery") + proto.RegisterType((*GroupVersionKind)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupVersionKind") + proto.RegisterType((*GroupVersionResource)(nil), "k8s.io.client-go.pkg.api.unversioned.GroupVersionResource") + proto.RegisterType((*LabelSelector)(nil), "k8s.io.client-go.pkg.api.unversioned.LabelSelector") + proto.RegisterType((*LabelSelectorRequirement)(nil), "k8s.io.client-go.pkg.api.unversioned.LabelSelectorRequirement") + proto.RegisterType((*ListMeta)(nil), "k8s.io.client-go.pkg.api.unversioned.ListMeta") + proto.RegisterType((*RootPaths)(nil), "k8s.io.client-go.pkg.api.unversioned.RootPaths") + proto.RegisterType((*ServerAddressByClientCIDR)(nil), "k8s.io.client-go.pkg.api.unversioned.ServerAddressByClientCIDR") + proto.RegisterType((*Status)(nil), "k8s.io.client-go.pkg.api.unversioned.Status") + proto.RegisterType((*StatusCause)(nil), "k8s.io.client-go.pkg.api.unversioned.StatusCause") + proto.RegisterType((*StatusDetails)(nil), "k8s.io.client-go.pkg.api.unversioned.StatusDetails") + proto.RegisterType((*Time)(nil), "k8s.io.client-go.pkg.api.unversioned.Time") + proto.RegisterType((*Timestamp)(nil), "k8s.io.client-go.pkg.api.unversioned.Timestamp") + proto.RegisterType((*TypeMeta)(nil), "k8s.io.client-go.pkg.api.unversioned.TypeMeta") } func (m *APIGroup) Marshal() (data []byte, err error) { size := m.Size() @@ -4446,91 +4446,92 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 1376 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xcc, 0x57, 0xcd, 0x6f, 0x1b, 0x45, - 0x14, 0xf7, 0x47, 0xec, 0xae, 0x9f, 0x63, 0x92, 0x0e, 0xa9, 0x70, 0x2d, 0x11, 0x87, 0x45, 0xa0, - 0x54, 0x6a, 0x6d, 0x35, 0x02, 0x54, 0x15, 0xf1, 0x11, 0x27, 0x69, 0x15, 0x35, 0x49, 0xa3, 0x49, - 0x15, 0xa4, 0x16, 0x24, 0x36, 0xde, 0xb1, 0xb3, 0xb2, 0xbd, 0xbb, 0xec, 0xec, 0x56, 0x8d, 0x40, - 0xa2, 0x17, 0x24, 0x0e, 0x08, 0xe5, 0xc8, 0x05, 0xd4, 0x4a, 0xfc, 0x07, 0xfc, 0x13, 0x11, 0xa7, - 0x5e, 0x90, 0x38, 0xa0, 0x08, 0xca, 0x85, 0x2b, 0x57, 0x4e, 0xcc, 0xcc, 0xce, 0xec, 0x87, 0x53, - 0x93, 0x0d, 0xf4, 0xc0, 0x61, 0x15, 0xcf, 0xfb, 0x9e, 0xf7, 0x7e, 0xf3, 0xde, 0x0b, 0xbc, 0x39, - 0xb8, 0x46, 0x5b, 0x96, 0xd3, 0x1e, 0x04, 0x7b, 0xc4, 0xb3, 0x89, 0x4f, 0x68, 0xdb, 0x1d, 0xf4, - 0xdb, 0x86, 0x6b, 0xb5, 0x03, 0xfb, 0x3e, 0xf1, 0xa8, 0xe5, 0xd8, 0xc4, 0x6c, 0xf7, 0x89, 0x4d, - 0x3c, 0xc3, 0x27, 0x66, 0xcb, 0xf5, 0x1c, 0xdf, 0x41, 0xaf, 0x85, 0x6a, 0xad, 0x58, 0xad, 0xc5, - 0xd4, 0x5a, 0x4c, 0xad, 0x95, 0x50, 0x6b, 0x5c, 0xe9, 0x5b, 0xfe, 0x7e, 0xb0, 0xd7, 0xea, 0x3a, - 0xa3, 0x76, 0xdf, 0xe9, 0x3b, 0x6d, 0xa1, 0xbd, 0x17, 0xf4, 0xc4, 0x49, 0x1c, 0xc4, 0xaf, 0xd0, - 0x6a, 0xe3, 0xca, 0xb3, 0x83, 0xf1, 0x02, 0xdb, 0xb7, 0x46, 0x64, 0x3c, 0x88, 0xc6, 0xd5, 0x67, - 0x8b, 0x07, 0xbe, 0x35, 0x6c, 0x5b, 0xb6, 0x4f, 0x7d, 0x6f, 0x5c, 0x45, 0xff, 0xb1, 0x08, 0xda, - 0xf2, 0xf6, 0xfa, 0x4d, 0xcf, 0x09, 0x5c, 0xb4, 0x00, 0x53, 0xb6, 0x31, 0x22, 0xf5, 0xfc, 0x42, - 0x7e, 0xb1, 0xd2, 0x99, 0x3e, 0x3a, 0x6e, 0xe6, 0x9e, 0x1e, 0x37, 0xa7, 0xb6, 0x18, 0x0d, 0x0b, - 0x0e, 0x1a, 0x81, 0x26, 0x2f, 0x43, 0xeb, 0x85, 0x85, 0xe2, 0x62, 0x75, 0xe9, 0xbd, 0x56, 0xa6, - 0x9b, 0xb7, 0x84, 0x87, 0xdd, 0xf0, 0x78, 0xc3, 0xf1, 0x56, 0x2d, 0xda, 0x75, 0x18, 0xf7, 0xa0, - 0x33, 0x2b, 0xdd, 0x68, 0x92, 0x49, 0x71, 0xe4, 0x02, 0x7d, 0x91, 0x87, 0x59, 0xd7, 0x23, 0x3d, - 0xe2, 0x79, 0xc4, 0x94, 0xfc, 0x7a, 0x91, 0x45, 0xf7, 0x1c, 0xfc, 0xd6, 0xa5, 0xdf, 0xd9, 0xed, - 0x31, 0x07, 0xf8, 0x84, 0x4b, 0xf4, 0x7d, 0x1e, 0x1a, 0x94, 0x78, 0x4c, 0x6f, 0xd9, 0x34, 0x3d, - 0x42, 0x69, 0xe7, 0x60, 0x65, 0x68, 0x11, 0xdb, 0x5f, 0x59, 0x5f, 0xc5, 0xb4, 0x3e, 0x25, 0x32, - 0xf1, 0x7e, 0xc6, 0x88, 0x76, 0x26, 0x19, 0xea, 0xe8, 0x32, 0xa4, 0xc6, 0x44, 0x11, 0x8a, 0xff, - 0x21, 0x0e, 0xbd, 0x0f, 0xd3, 0xaa, 0x96, 0x1b, 0x16, 0xf5, 0xd1, 0x07, 0x50, 0xee, 0xf3, 0x03, - 0x65, 0x15, 0xe5, 0x11, 0xb6, 0x33, 0x46, 0xa8, 0x8c, 0x74, 0x5e, 0x90, 0x01, 0x95, 0xc5, 0x91, - 0x62, 0x69, 0x4e, 0x67, 0x75, 0xa9, 0x32, 0x21, 0x4c, 0xa8, 0x13, 0x78, 0x5d, 0x92, 0x01, 0x38, - 0x4b, 0x00, 0xfc, 0x2f, 0x75, 0x8d, 0x2e, 0x31, 0x19, 0x74, 0xf2, 0x8b, 0x5a, 0x07, 0x49, 0x39, - 0xd8, 0x8a, 0x38, 0x38, 0x21, 0xc5, 0xad, 0x0e, 0x2c, 0xdb, 0x14, 0x05, 0x4f, 0x58, 0xbd, 0xc5, - 0x68, 0x58, 0x70, 0xf4, 0x1f, 0xf2, 0x30, 0x93, 0x88, 0x43, 0x5c, 0xfa, 0x1a, 0x4c, 0xf7, 0x13, - 0x35, 0x97, 0x31, 0xcd, 0x49, 0xed, 0xe9, 0x24, 0x1e, 0x70, 0x4a, 0x12, 0xf5, 0xa0, 0xe2, 0x49, - 0x4b, 0x0a, 0xdd, 0x4b, 0xd9, 0x33, 0xa6, 0x82, 0x88, 0x5d, 0x25, 0x88, 0x14, 0xc7, 0xa6, 0xf5, - 0x3f, 0xc2, 0xec, 0x29, 0xbc, 0xa3, 0xc5, 0xc4, 0xa3, 0xe2, 0x85, 0x62, 0x77, 0x9d, 0xf0, 0x1e, - 0x4e, 0xc1, 0x61, 0xe1, 0xff, 0x81, 0xc3, 0xeb, 0xda, 0x37, 0x8f, 0x9a, 0xb9, 0x87, 0xbf, 0x2c, - 0xe4, 0xf4, 0x75, 0xd0, 0x56, 0x03, 0xd6, 0x6f, 0x78, 0x7a, 0xdf, 0x01, 0xcd, 0x94, 0xbf, 0x45, - 0x51, 0x8a, 0x9d, 0x57, 0xd4, 0xd3, 0x57, 0x32, 0x7f, 0x1d, 0x37, 0x6b, 0xbc, 0xb3, 0xb5, 0x14, - 0x01, 0x47, 0x2a, 0xfa, 0x87, 0x50, 0x5b, 0x7b, 0xe0, 0x3a, 0x9e, 0x7f, 0xdb, 0xf5, 0x45, 0x32, - 0x5e, 0x87, 0x32, 0x11, 0x04, 0x61, 0x4d, 0x8b, 0xc1, 0x1a, 0x8a, 0x61, 0xc9, 0x45, 0xaf, 0x42, - 0x89, 0x3c, 0x30, 0xba, 0xbe, 0x44, 0x5d, 0x4d, 0x8a, 0x95, 0xd6, 0x38, 0x11, 0x87, 0x3c, 0x66, - 0xbd, 0x22, 0x90, 0xc1, 0xc1, 0xc5, 0x35, 0x04, 0x30, 0x24, 0x76, 0x22, 0x0d, 0x21, 0x81, 0x43, - 0x5e, 0x84, 0xce, 0xc2, 0x24, 0x74, 0x26, 0xd2, 0x30, 0x84, 0x5a, 0xa8, 0xab, 0x1e, 0x4c, 0x26, - 0x0f, 0x97, 0x41, 0x53, 0xa0, 0x91, 0x5e, 0xa2, 0x5e, 0xa9, 0x0c, 0xe1, 0x48, 0x22, 0xe1, 0x6d, - 0x1f, 0x52, 0x28, 0xcf, 0xe6, 0xec, 0x12, 0x9c, 0x93, 0xd0, 0x90, 0xbe, 0x66, 0xa4, 0xd8, 0x39, - 0xf5, 0x58, 0x14, 0x3f, 0xe1, 0xe9, 0x73, 0xa8, 0x4f, 0xea, 0xaf, 0xff, 0xe1, 0x1d, 0x66, 0x0f, - 0x45, 0xff, 0x9a, 0x0d, 0x88, 0xa4, 0xa5, 0xec, 0xe5, 0xcb, 0xee, 0xe4, 0xf4, 0x3e, 0x94, 0xc8, - 0xc8, 0x77, 0x79, 0x98, 0x4b, 0x5d, 0xed, 0x4c, 0x15, 0x3f, 0x43, 0x50, 0x49, 0x70, 0x14, 0xcf, - 0x00, 0x8e, 0x9f, 0x0a, 0x50, 0xdb, 0x30, 0xf6, 0xc8, 0x70, 0x87, 0x0c, 0x49, 0xd7, 0x77, 0x3c, - 0xf4, 0x19, 0x54, 0x47, 0x86, 0xdf, 0xdd, 0x17, 0x54, 0x35, 0x2a, 0xd6, 0x32, 0x36, 0x91, 0x94, - 0xa9, 0xd6, 0x66, 0x6c, 0x67, 0xcd, 0xf6, 0xd9, 0x90, 0x7d, 0x51, 0xc6, 0x54, 0x4d, 0x70, 0x70, - 0xd2, 0x9d, 0x18, 0xf1, 0xe2, 0xcc, 0x5e, 0x2d, 0xef, 0x24, 0xff, 0x62, 0xb5, 0x48, 0xc5, 0x80, - 0xc9, 0x27, 0x81, 0xe5, 0x91, 0x11, 0x6b, 0x46, 0xf1, 0x88, 0xdf, 0x1c, 0x73, 0x80, 0x4f, 0xb8, - 0x6c, 0xbc, 0x0b, 0xb3, 0xe3, 0xd1, 0xa3, 0x59, 0x28, 0x0e, 0xc8, 0x41, 0x58, 0x31, 0xcc, 0x7f, - 0xa2, 0x39, 0x28, 0xdd, 0x37, 0x86, 0x81, 0x7c, 0x8f, 0x38, 0x3c, 0x5c, 0x2f, 0x5c, 0xcb, 0xeb, - 0xac, 0x35, 0xd7, 0x27, 0x05, 0x82, 0x5e, 0x4e, 0x18, 0xea, 0x54, 0x65, 0x54, 0xc5, 0x5b, 0xe4, - 0x20, 0xb4, 0xba, 0x06, 0x9a, 0xe3, 0xf2, 0xb5, 0xcc, 0xf1, 0x64, 0xdd, 0x2f, 0xa9, 0x5a, 0xde, - 0x96, 0x74, 0xd6, 0x19, 0x2f, 0xa4, 0xcc, 0x2b, 0x06, 0x8e, 0x54, 0x91, 0x0e, 0x65, 0x11, 0x0f, - 0x65, 0x80, 0xe0, 0x53, 0x04, 0x78, 0x33, 0xdc, 0x15, 0x14, 0x2c, 0x39, 0xfa, 0xa7, 0xa0, 0xf1, - 0x29, 0xb9, 0x49, 0x7c, 0x83, 0x43, 0x88, 0x92, 0x61, 0x6f, 0xc3, 0xb2, 0x07, 0x32, 0xb4, 0x08, - 0x42, 0x3b, 0x92, 0x8e, 0x23, 0x09, 0xb4, 0x0c, 0x33, 0x0a, 0x4e, 0xbb, 0x29, 0x8c, 0xbe, 0x24, - 0x95, 0x66, 0x70, 0x9a, 0x8d, 0xc7, 0xe5, 0xf5, 0xcb, 0x50, 0xc1, 0x8e, 0xe3, 0x6f, 0x1b, 0xfe, - 0x3e, 0x45, 0x4d, 0x28, 0xb9, 0xfc, 0x87, 0x1c, 0x79, 0x15, 0xfe, 0x18, 0x04, 0x07, 0x87, 0x74, - 0xfd, 0xab, 0x3c, 0x5c, 0x9c, 0x38, 0x80, 0xf8, 0x42, 0xd1, 0x8d, 0x4e, 0x32, 0xfc, 0x68, 0xa1, - 0x88, 0xe5, 0x70, 0x42, 0x0a, 0xbd, 0x0d, 0xb5, 0xd4, 0xd4, 0x92, 0x17, 0xb8, 0x20, 0xd5, 0x6a, - 0x29, 0x6f, 0x38, 0x2d, 0xab, 0xff, 0x59, 0x80, 0xf2, 0x8e, 0x6f, 0xf8, 0x01, 0x45, 0x1f, 0x81, - 0x36, 0x62, 0x09, 0x34, 0x0d, 0xdf, 0x10, 0x9e, 0xb3, 0x6f, 0x56, 0x2a, 0xf7, 0x71, 0xa6, 0x15, - 0x05, 0x47, 0x26, 0xf9, 0x60, 0xa3, 0xc2, 0x91, 0x8c, 0x2f, 0x1a, 0x6c, 0xa1, 0x7b, 0x2c, 0xb9, - 0xbc, 0x5b, 0xb0, 0x5d, 0x89, 0x1a, 0x7d, 0xd5, 0x01, 0xa2, 0x6e, 0xb1, 0x19, 0x92, 0xb1, 0xe2, - 0xa3, 0xb7, 0xa0, 0xec, 0x11, 0x83, 0xb2, 0x9a, 0x4d, 0x09, 0xc9, 0x79, 0x65, 0x12, 0x0b, 0x2a, - 0x43, 0xd7, 0xb4, 0x34, 0x2e, 0xce, 0x58, 0x4a, 0xa3, 0x7b, 0x70, 0xce, 0x64, 0x61, 0x59, 0xac, - 0x2f, 0x94, 0xc4, 0x45, 0xdf, 0xc8, 0xba, 0x5c, 0x08, 0x6b, 0xab, 0xa1, 0x6e, 0xa7, 0xca, 0x83, - 0x92, 0x07, 0xac, 0x2c, 0xf2, 0xbe, 0xda, 0x75, 0x4c, 0x52, 0x2f, 0x33, 0xcb, 0xa5, 0xb8, 0xaf, - 0xae, 0x30, 0x1a, 0x16, 0x1c, 0xfd, 0x90, 0x6d, 0x4a, 0xa1, 0xa5, 0x15, 0x23, 0xa0, 0x04, 0x5d, - 0x8d, 0xae, 0x11, 0x16, 0xfc, 0xa2, 0xd2, 0xb9, 0x73, 0xe0, 0x12, 0x76, 0x89, 0x8a, 0x10, 0xe3, - 0x87, 0xe8, 0x06, 0x89, 0x24, 0x15, 0x4e, 0x49, 0x12, 0x6b, 0xd1, 0x3d, 0x8b, 0x0c, 0x55, 0xa3, - 0x8f, 0x5a, 0xf4, 0x0d, 0x4e, 0xc4, 0x21, 0x4f, 0xff, 0x96, 0xf5, 0xcf, 0xd4, 0xe5, 0x32, 0x2c, - 0xbf, 0x51, 0xef, 0x2f, 0x64, 0xd8, 0x27, 0x26, 0x4e, 0x19, 0x74, 0x17, 0xca, 0x5d, 0x7e, 0x3f, - 0xf5, 0x0f, 0xc7, 0xd2, 0x99, 0x6a, 0x21, 0x52, 0x13, 0x63, 0x49, 0x1c, 0x19, 0x96, 0x42, 0x8b, - 0xe8, 0x26, 0x9c, 0xf7, 0x08, 0xeb, 0x79, 0xcb, 0x3d, 0x9f, 0x78, 0x3b, 0xa4, 0xeb, 0xd8, 0x66, - 0x58, 0xf2, 0x52, 0x94, 0xe4, 0xf3, 0x78, 0x5c, 0x00, 0x9f, 0xd4, 0x61, 0xab, 0xce, 0xd4, 0x1d, - 0xb6, 0xc1, 0xf1, 0xbc, 0x53, 0x69, 0x26, 0x5c, 0xf6, 0xa2, 0xbc, 0x2b, 0x65, 0xc5, 0xe7, 0xe9, - 0xb1, 0x0d, 0xdb, 0x09, 0xe1, 0x5e, 0x8a, 0xd3, 0xb3, 0xc5, 0x89, 0x38, 0xe4, 0x5d, 0x9f, 0xe3, - 0x13, 0xec, 0xcb, 0xc7, 0xcd, 0xdc, 0x21, 0xfb, 0x1e, 0x3d, 0x96, 0xd3, 0xec, 0x1e, 0x54, 0xb8, - 0x37, 0xf6, 0x20, 0x46, 0xee, 0xf3, 0x76, 0xa9, 0x7f, 0x0c, 0x1a, 0x87, 0x92, 0xe8, 0x95, 0xaa, - 0x3a, 0xf9, 0x89, 0xd5, 0x61, 0x0d, 0x89, 0x25, 0x3e, 0xdd, 0x1a, 0xa3, 0x86, 0x14, 0xaf, 0xfb, - 0x38, 0x21, 0xd5, 0xb9, 0x72, 0xf4, 0xdb, 0x7c, 0xee, 0x09, 0xfb, 0x7e, 0x66, 0xdf, 0xc3, 0xa7, - 0xf3, 0xf9, 0x23, 0xf6, 0x3d, 0x61, 0xdf, 0xaf, 0xec, 0x3b, 0xfc, 0x7d, 0x3e, 0x77, 0xb7, 0x9a, - 0x28, 0xe4, 0xdf, 0x01, 0x00, 0x00, 0xff, 0xff, 0x0a, 0x22, 0x00, 0xde, 0x9c, 0x10, 0x00, 0x00, + // 1390 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xcc, 0x57, 0x4f, 0x6f, 0x1b, 0x45, + 0x14, 0xf7, 0xda, 0xb1, 0xbb, 0x7e, 0x8e, 0x49, 0xba, 0xa4, 0x62, 0x1b, 0x09, 0xdb, 0x6c, 0x05, + 0x4a, 0xa5, 0xd6, 0x56, 0x23, 0x40, 0x55, 0x11, 0x7f, 0xe2, 0x24, 0xad, 0xa2, 0x36, 0x6d, 0x34, + 0xa9, 0x8a, 0xd4, 0x16, 0x89, 0x8d, 0x77, 0xe2, 0xac, 0x6c, 0xef, 0x2e, 0x33, 0xb3, 0x51, 0x2d, + 0x90, 0xe8, 0xa5, 0x12, 0x07, 0x84, 0x7a, 0xe4, 0x02, 0x6a, 0xa5, 0x7e, 0x03, 0xbe, 0x44, 0xc5, + 0xa9, 0x17, 0x24, 0x0e, 0xc8, 0xa2, 0xe1, 0xc2, 0x95, 0x6b, 0x4e, 0x68, 0x66, 0x67, 0xd6, 0xbb, + 0x6e, 0x4d, 0x36, 0xd0, 0x03, 0x27, 0xef, 0xfb, 0xff, 0xe6, 0xbd, 0xdf, 0xbc, 0x37, 0x86, 0xf7, + 0x7a, 0x17, 0x69, 0xd3, 0xf5, 0x5b, 0xbd, 0x70, 0x07, 0x13, 0x0f, 0x33, 0x4c, 0x5b, 0x41, 0xaf, + 0xdb, 0xb2, 0x03, 0xb7, 0x15, 0x7a, 0xfb, 0x98, 0x50, 0xd7, 0xf7, 0xb0, 0xd3, 0xea, 0x62, 0x0f, + 0x13, 0x9b, 0x61, 0xa7, 0x19, 0x10, 0x9f, 0xf9, 0xc6, 0xdb, 0x91, 0x59, 0x73, 0x6c, 0xd6, 0x0c, + 0x7a, 0xdd, 0xa6, 0x1d, 0xb8, 0xcd, 0x84, 0xd9, 0xe2, 0xf9, 0xae, 0xcb, 0xf6, 0xc2, 0x9d, 0x66, + 0xc7, 0x1f, 0xb4, 0xba, 0x7e, 0xd7, 0x6f, 0x09, 0xeb, 0x9d, 0x70, 0x57, 0x50, 0x82, 0x10, 0x5f, + 0x91, 0xd7, 0xc5, 0xf3, 0x2f, 0x4f, 0x86, 0x84, 0x1e, 0x73, 0x07, 0x78, 0x32, 0x89, 0xc5, 0x0b, + 0x2f, 0x57, 0x0f, 0x99, 0xdb, 0x6f, 0xb9, 0x1e, 0xa3, 0x8c, 0x4c, 0x9a, 0x58, 0x3f, 0x17, 0x40, + 0x5f, 0xd9, 0xda, 0xb8, 0x42, 0xfc, 0x30, 0x30, 0x1a, 0x30, 0xe3, 0xd9, 0x03, 0x6c, 0x6a, 0x0d, + 0x6d, 0xa9, 0xdc, 0x9e, 0x7d, 0x3a, 0xaa, 0xe7, 0x0e, 0x46, 0xf5, 0x99, 0xeb, 0xf6, 0x00, 0x23, + 0x21, 0x31, 0x06, 0xa0, 0xcb, 0xc3, 0x50, 0x33, 0xdf, 0x28, 0x2c, 0x55, 0x96, 0x3f, 0x6e, 0x66, + 0x3a, 0x79, 0x53, 0x44, 0xb8, 0x15, 0x91, 0x97, 0x7d, 0xb2, 0xe6, 0xd2, 0x8e, 0xbf, 0x8f, 0xc9, + 0xb0, 0x3d, 0x2f, 0xc3, 0xe8, 0x52, 0x48, 0x51, 0x1c, 0xc2, 0x78, 0xa0, 0xc1, 0x7c, 0x40, 0xf0, + 0x2e, 0x26, 0x04, 0x3b, 0x52, 0x6e, 0x16, 0x1a, 0xda, 0xab, 0x88, 0x6b, 0xca, 0xb8, 0xf3, 0x5b, + 0x13, 0x01, 0xd0, 0x0b, 0x21, 0x8d, 0x27, 0x1a, 0x2c, 0x52, 0x4c, 0xf6, 0x31, 0x59, 0x71, 0x1c, + 0x82, 0x29, 0x6d, 0x0f, 0x57, 0xfb, 0x2e, 0xf6, 0xd8, 0xea, 0xc6, 0x1a, 0xa2, 0xe6, 0x8c, 0xa8, + 0xc4, 0x27, 0x19, 0x33, 0xda, 0x9e, 0xe6, 0xa8, 0x6d, 0xc9, 0x94, 0x16, 0xa7, 0xaa, 0x50, 0xf4, + 0x0f, 0x79, 0x58, 0x5d, 0x98, 0x55, 0xbd, 0xbc, 0xe6, 0x52, 0x66, 0x7c, 0x0a, 0xa5, 0x2e, 0x27, + 0xa8, 0xa9, 0x89, 0x0c, 0x5b, 0x19, 0x33, 0x54, 0x4e, 0xda, 0xaf, 0xc9, 0x84, 0x4a, 0x82, 0xa4, + 0x48, 0xba, 0xb3, 0x1e, 0x68, 0x50, 0x59, 0xd9, 0xda, 0x40, 0x98, 0xfa, 0x21, 0xe9, 0xe0, 0x0c, + 0xc0, 0x59, 0x06, 0xe0, 0xbf, 0x34, 0xb0, 0x3b, 0xd8, 0x31, 0xf3, 0x0d, 0x6d, 0x49, 0x6f, 0x1b, + 0x52, 0x0f, 0xae, 0xc7, 0x12, 0x94, 0xd0, 0xe2, 0x5e, 0x7b, 0xae, 0xe7, 0x88, 0x86, 0x27, 0xbc, + 0x5e, 0x75, 0x3d, 0x07, 0x09, 0x89, 0xf5, 0x93, 0x06, 0x73, 0x89, 0x3c, 0xc4, 0xa1, 0x2f, 0xc2, + 0x6c, 0x37, 0xd1, 0x73, 0x99, 0xd3, 0x82, 0xb4, 0x9e, 0x4d, 0xe2, 0x01, 0xa5, 0x34, 0x8d, 0x5d, + 0x28, 0x13, 0xe9, 0x49, 0xa1, 0x7b, 0x39, 0x7b, 0xc5, 0x54, 0x12, 0xe3, 0x50, 0x09, 0x26, 0x45, + 0x63, 0xd7, 0xd6, 0x9f, 0x51, 0xf5, 0x14, 0xde, 0x8d, 0xa5, 0xc4, 0xa5, 0xe2, 0x8d, 0x2a, 0xb7, + 0x67, 0xa7, 0xdc, 0x87, 0x23, 0x70, 0x98, 0xff, 0x7f, 0xe0, 0xf0, 0x92, 0xfe, 0xfd, 0xa3, 0x7a, + 0xee, 0xfe, 0x6f, 0x8d, 0x9c, 0xb5, 0x01, 0xfa, 0x5a, 0x48, 0x6c, 0xc6, 0xcb, 0xfb, 0x21, 0xe8, + 0x8e, 0xfc, 0x16, 0x4d, 0x29, 0xb4, 0xdf, 0x52, 0x57, 0x5f, 0xe9, 0x1c, 0x8e, 0xea, 0x55, 0x3e, + 0xd9, 0x9a, 0x8a, 0x81, 0x62, 0x13, 0xeb, 0x2e, 0x54, 0xd7, 0xef, 0x05, 0x3e, 0x61, 0x37, 0x02, + 0x26, 0x8a, 0xf1, 0x0e, 0x94, 0xb0, 0x60, 0x08, 0x6f, 0xfa, 0x18, 0xac, 0x91, 0x1a, 0x92, 0x52, + 0xe3, 0x0c, 0x14, 0xf1, 0x3d, 0xbb, 0xc3, 0x24, 0xea, 0xaa, 0x52, 0xad, 0xb8, 0xce, 0x99, 0x28, + 0x92, 0x59, 0x77, 0xa1, 0x2c, 0x90, 0xc1, 0xc1, 0xc5, 0x2d, 0x04, 0x30, 0x24, 0x76, 0x62, 0x0b, + 0xa1, 0x81, 0x22, 0x59, 0x8c, 0xce, 0xfc, 0x34, 0x74, 0x26, 0xca, 0xd0, 0x87, 0x6a, 0x64, 0xab, + 0x2e, 0x4c, 0xa6, 0x08, 0xe7, 0x40, 0x57, 0xa0, 0x91, 0x51, 0xe2, 0x59, 0xa9, 0x1c, 0xa1, 0x58, + 0x23, 0x11, 0x6d, 0x0f, 0x52, 0x28, 0xcf, 0x16, 0xec, 0x2c, 0x9c, 0x90, 0xd0, 0x90, 0xb1, 0xe6, + 0xa4, 0xda, 0x09, 0x75, 0x59, 0x94, 0x3c, 0x11, 0xe9, 0x6b, 0x30, 0xa7, 0xcd, 0xd7, 0xff, 0x70, + 0x0f, 0xb3, 0xa7, 0x62, 0x7d, 0xa7, 0xc1, 0x7c, 0xd2, 0x53, 0xf6, 0xf6, 0x65, 0x0f, 0x72, 0xf4, + 0x1c, 0x4a, 0x54, 0xe4, 0x47, 0x0d, 0x16, 0x52, 0x47, 0x3b, 0x56, 0xc7, 0x8f, 0x91, 0x54, 0x12, + 0x1c, 0x85, 0x63, 0x80, 0xe3, 0x97, 0x3c, 0x54, 0xaf, 0xd9, 0x3b, 0xb8, 0xbf, 0x8d, 0xfb, 0xb8, + 0xc3, 0x7c, 0x62, 0x7c, 0x05, 0x95, 0x81, 0xcd, 0x3a, 0x7b, 0x82, 0xab, 0x56, 0xc5, 0x7a, 0xc6, + 0x21, 0x92, 0x72, 0xd5, 0xdc, 0x1c, 0xfb, 0x59, 0xf7, 0x18, 0x19, 0xb6, 0x5f, 0x97, 0x39, 0x55, + 0x12, 0x12, 0x94, 0x0c, 0x27, 0x56, 0xbc, 0xa0, 0xd7, 0xef, 0x05, 0x7c, 0x92, 0xfc, 0x8b, 0xa7, + 0x45, 0x2a, 0x07, 0x84, 0xbf, 0x08, 0x5d, 0x82, 0x07, 0xd8, 0x63, 0xe3, 0x15, 0xbf, 0x39, 0x11, + 0x00, 0xbd, 0x10, 0x72, 0xf1, 0x23, 0x98, 0x9f, 0xcc, 0xde, 0x98, 0x87, 0x42, 0x0f, 0x0f, 0xa3, + 0x8e, 0x21, 0xfe, 0x69, 0x2c, 0x40, 0x71, 0xdf, 0xee, 0x87, 0xf2, 0x3e, 0xa2, 0x88, 0xb8, 0x94, + 0xbf, 0xa8, 0x59, 0x4f, 0x34, 0x30, 0xa7, 0x25, 0x62, 0xbc, 0x99, 0x70, 0xd4, 0xae, 0xc8, 0xac, + 0x0a, 0x57, 0xf1, 0x30, 0xf2, 0xba, 0x0e, 0xba, 0x1f, 0xf0, 0x67, 0x99, 0x4f, 0x64, 0xdf, 0xcf, + 0xaa, 0x5e, 0xde, 0x90, 0xfc, 0xc3, 0x51, 0xfd, 0x54, 0xca, 0xbd, 0x12, 0xa0, 0xd8, 0xd4, 0xb0, + 0xa0, 0x24, 0xf2, 0xa1, 0x66, 0x41, 0x6c, 0x11, 0xe0, 0xc3, 0xf0, 0x96, 0xe0, 0x20, 0x29, 0xb1, + 0xbe, 0x04, 0x9d, 0x6f, 0xc9, 0x4d, 0xcc, 0x6c, 0x0e, 0x21, 0x8a, 0xfb, 0xbb, 0xd7, 0x5c, 0xaf, + 0x27, 0x53, 0x8b, 0x21, 0xb4, 0x2d, 0xf9, 0x28, 0xd6, 0x30, 0x56, 0x60, 0x4e, 0xc1, 0xe9, 0x56, + 0x0a, 0xa3, 0x6f, 0x48, 0xa3, 0x39, 0x94, 0x16, 0xa3, 0x49, 0x7d, 0xeb, 0x1c, 0x94, 0x91, 0xef, + 0xb3, 0x2d, 0x9b, 0xed, 0x51, 0xa3, 0x0e, 0xc5, 0x80, 0x7f, 0xc8, 0x95, 0x57, 0xe6, 0x97, 0x41, + 0x48, 0x50, 0xc4, 0xb7, 0xbe, 0xd5, 0xe0, 0xf4, 0xd4, 0x05, 0xc4, 0x1f, 0x14, 0x9d, 0x98, 0x92, + 0xe9, 0xc7, 0x0f, 0x8a, 0xb1, 0x1e, 0x4a, 0x68, 0x19, 0x1f, 0x40, 0x35, 0xb5, 0xb5, 0xe4, 0x01, + 0x4e, 0x49, 0xb3, 0x6a, 0x2a, 0x1a, 0x4a, 0xeb, 0x5a, 0x7f, 0xe5, 0xa1, 0xb4, 0xcd, 0x6c, 0x16, + 0x52, 0xe3, 0x33, 0xd0, 0x07, 0x98, 0xd9, 0x8e, 0xcd, 0x6c, 0x11, 0x39, 0xfb, 0xcb, 0x4a, 0xd5, + 0x7e, 0x5c, 0x69, 0xc5, 0x41, 0xb1, 0x4b, 0xbe, 0xd8, 0xa8, 0x08, 0x24, 0xf3, 0x8b, 0x17, 0x5b, + 0x14, 0x1e, 0x49, 0x29, 0x9f, 0x16, 0x03, 0x4c, 0xa9, 0xdd, 0x55, 0x13, 0x20, 0x9e, 0x16, 0x9b, + 0x11, 0x1b, 0x29, 0xb9, 0xf1, 0x3e, 0x94, 0x08, 0xb6, 0xa9, 0xef, 0x99, 0x33, 0x42, 0xb3, 0xa6, + 0x5c, 0x22, 0xc1, 0x3d, 0x1c, 0xd5, 0x67, 0xa5, 0x73, 0x41, 0x23, 0xa9, 0x6d, 0xdc, 0x81, 0x13, + 0x0e, 0x66, 0xb6, 0xdb, 0xa7, 0x66, 0x51, 0x1c, 0xf4, 0xdd, 0xac, 0x8f, 0x0b, 0xe1, 0x6d, 0x2d, + 0xb2, 0x6d, 0x57, 0x78, 0x52, 0x92, 0x40, 0xca, 0x23, 0x9f, 0xab, 0x1d, 0xdf, 0xc1, 0x66, 0xa9, + 0xa1, 0x2d, 0x15, 0xc7, 0x73, 0x75, 0xd5, 0x77, 0x30, 0x12, 0x12, 0xeb, 0xa1, 0x06, 0x95, 0xc8, + 0xd3, 0xaa, 0x1d, 0x52, 0x6c, 0x5c, 0x88, 0x8f, 0x11, 0x35, 0xfc, 0xb4, 0xb2, 0xb9, 0x39, 0x0c, + 0xf0, 0xe1, 0xa8, 0x5e, 0x16, 0x6a, 0x9c, 0x88, 0x4f, 0x90, 0x28, 0x52, 0xfe, 0x88, 0x22, 0x9d, + 0x81, 0xe2, 0xae, 0x8b, 0xfb, 0x6a, 0xd0, 0xc7, 0x23, 0xfa, 0x32, 0x67, 0xa2, 0x48, 0x66, 0xfd, + 0x90, 0x87, 0x6a, 0xea, 0x70, 0x19, 0x1e, 0xbf, 0xf1, 0xec, 0xcf, 0x67, 0x78, 0x4f, 0x4c, 0xdd, + 0x32, 0xc6, 0x6d, 0x28, 0x75, 0xf8, 0xf9, 0xd4, 0x1f, 0x8e, 0xe5, 0x63, 0xf5, 0x42, 0x94, 0x66, + 0x8c, 0x25, 0x41, 0x52, 0x24, 0x3d, 0x1a, 0x57, 0xe0, 0x24, 0xc1, 0x8c, 0x0c, 0x57, 0x76, 0x19, + 0x26, 0xdb, 0xb8, 0xe3, 0x7b, 0x4e, 0xd4, 0xf2, 0x62, 0x5c, 0xe4, 0x93, 0x68, 0x52, 0x01, 0xbd, + 0x68, 0x63, 0xf5, 0x61, 0xe6, 0xa6, 0x3b, 0xc0, 0xbc, 0xee, 0x54, 0xba, 0x89, 0x1e, 0x7b, 0x71, + 0xdd, 0x95, 0xb1, 0x92, 0xf3, 0xf2, 0x78, 0xb6, 0xe7, 0x47, 0x70, 0x2f, 0x8e, 0xcb, 0x73, 0x9d, + 0x33, 0x51, 0x24, 0xbb, 0xb4, 0xc0, 0x37, 0xd8, 0x37, 0x8f, 0xeb, 0xb9, 0x87, 0x8f, 0xeb, 0xb9, + 0x47, 0x8f, 0xe5, 0x36, 0xbb, 0x03, 0x65, 0x1e, 0x8d, 0x32, 0x7b, 0x10, 0xbc, 0xea, 0x90, 0xd6, + 0xe7, 0xa0, 0x73, 0x28, 0x89, 0x59, 0xa9, 0xba, 0xa3, 0x4d, 0xed, 0xce, 0x32, 0x80, 0x1d, 0xb8, + 0xe9, 0xd1, 0x18, 0x0f, 0xa4, 0xf1, 0x73, 0x1f, 0x25, 0xb4, 0xda, 0xe7, 0x9f, 0x3e, 0xaf, 0xe5, + 0x9e, 0x3d, 0xaf, 0xe5, 0x7e, 0x7d, 0x5e, 0xcb, 0xdd, 0x3f, 0xa8, 0x69, 0x4f, 0x0f, 0x6a, 0xda, + 0xb3, 0x83, 0x9a, 0xf6, 0xfb, 0x41, 0x4d, 0x7b, 0xf8, 0x47, 0x2d, 0x77, 0xbb, 0x92, 0x68, 0xe4, + 0xdf, 0x01, 0x00, 0x00, 0xff, 0xff, 0x0a, 0x22, 0x00, 0xde, 0x9c, 0x10, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.proto b/vendor/k8s.io/client-go/pkg/api/unversioned/generated.proto similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.proto rename to vendor/k8s.io/client-go/pkg/api/unversioned/generated.proto index cab7058..91d3fbf 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/generated.proto +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/generated.proto @@ -38,6 +38,7 @@ message APIGroup { // preferredVersion is the version preferred by the API server, which // probably is the storage version. + // +optional optional GroupVersionForDiscovery preferredVersion = 3; // a map of client CIDR to server address that is serving this group. @@ -185,9 +186,11 @@ message LabelSelector { // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels // map is equivalent to an element of matchExpressions, whose key field is "key", the // operator is "In", and the values array contains only "value". The requirements are ANDed. + // +optional map matchLabels = 1; // matchExpressions is a list of label selector requirements. The requirements are ANDed. + // +optional repeated LabelSelectorRequirement matchExpressions = 2; } @@ -205,6 +208,7 @@ message LabelSelectorRequirement { // the values array must be non-empty. If the operator is Exists or DoesNotExist, // the values array must be empty. This array is replaced during a strategic // merge patch. + // +optional repeated string values = 3; } @@ -214,6 +218,7 @@ message ListMeta { // SelfLink is a URL representing this object. // Populated by the system. // Read-only. + // +optional optional string selfLink = 1; // String that identifies the server's internal version of this object that @@ -222,6 +227,7 @@ message ListMeta { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional optional string resourceVersion = 2; } @@ -246,29 +252,35 @@ message ServerAddressByClientCIDR { message Status { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional ListMeta metadata = 1; // Status of the operation. // One of: "Success" or "Failure". // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional string status = 2; // A human-readable description of the status of this operation. + // +optional optional string message = 3; // A machine-readable description of why this operation is in the // "Failure" status. If this value is empty there // is no information available. A Reason clarifies an HTTP status // code but does not override it. + // +optional optional string reason = 4; // Extended data associated with the reason. Each reason may define its // own extended details. This field is optional and the data returned // is not guaranteed to conform to any schema except that defined by // the reason type. + // +optional optional StatusDetails details = 5; // Suggested HTTP return code for this status, 0 if not set. + // +optional optional int32 code = 6; } @@ -277,10 +289,12 @@ message Status { message StatusCause { // A machine-readable description of the cause of the error. If this value is // empty there is no information available. + // +optional optional string reason = 1; // A human-readable description of the cause of the error. This field may be // presented as-is to a reader. + // +optional optional string message = 2; // The field of the resource that has caused this error, as named by its JSON @@ -292,6 +306,7 @@ message StatusCause { // Examples: // "name" - the field "name" on the current resource // "items[0].name" - the field "name" on the first array entry in "items" + // +optional optional string field = 3; } @@ -304,21 +319,26 @@ message StatusCause { message StatusDetails { // The name attribute of the resource associated with the status StatusReason // (when there is a single name which can be described). + // +optional optional string name = 1; // The group attribute of the resource associated with the status StatusReason. + // +optional optional string group = 2; // The kind attribute of the resource associated with the status StatusReason. // On some operations may differ from the requested resource Kind. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional string kind = 3; // The Causes array includes more details associated with the StatusReason // failure. Not all StatusReasons may provide detailed causes. + // +optional repeated StatusCause causes = 4; // If specified, the time in seconds before the operation should be retried. + // +optional optional int32 retryAfterSeconds = 5; } @@ -367,12 +387,14 @@ message TypeMeta { // Cannot be updated. // In CamelCase. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional string kind = 1; // APIVersion defines the versioned schema of this representation of an object. // Servers should convert recognized schemas to the latest internal value, and // may reject unrecognized values. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#resources + // +optional optional string apiVersion = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/group_version.go b/vendor/k8s.io/client-go/pkg/api/unversioned/group_version.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/group_version.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/group_version.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/helpers.go b/vendor/k8s.io/client-go/pkg/api/unversioned/helpers.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/helpers.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/helpers.go index 5bd9051..8ef9b03 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/helpers.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/helpers.go @@ -19,9 +19,8 @@ package unversioned import ( "fmt" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/selection" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/selection" ) // LabelSelectorAsSelector converts the LabelSelector api type into a struct that implements @@ -36,7 +35,7 @@ func LabelSelectorAsSelector(ps *LabelSelector) (labels.Selector, error) { } selector := labels.NewSelector() for k, v := range ps.MatchLabels { - r, err := labels.NewRequirement(k, selection.Equals, sets.NewString(v)) + r, err := labels.NewRequirement(k, selection.Equals, []string{v}) if err != nil { return nil, err } @@ -56,7 +55,7 @@ func LabelSelectorAsSelector(ps *LabelSelector) (labels.Selector, error) { default: return nil, fmt.Errorf("%q is not a valid pod selector operator", expr.Operator) } - r, err := labels.NewRequirement(expr.Key, op, sets.NewString(expr.Values...)) + r, err := labels.NewRequirement(expr.Key, op, append([]string(nil), expr.Values...)) if err != nil { return nil, err } diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/meta.go b/vendor/k8s.io/client-go/pkg/api/unversioned/meta.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/meta.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/meta.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/register.go b/vendor/k8s.io/client-go/pkg/api/unversioned/register.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/register.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/register.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/time.go b/vendor/k8s.io/client-go/pkg/api/unversioned/time.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/time.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/time.go index 636e24a..d490f3b 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/time.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/time.go @@ -20,7 +20,7 @@ import ( "encoding/json" "time" - "k8s.io/kubernetes/pkg/genericapiserver/openapi/common" + "k8s.io/client-go/pkg/genericapiserver/openapi/common" "github.com/go-openapi/spec" "github.com/google/gofuzz" diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/time_proto.go b/vendor/k8s.io/client-go/pkg/api/unversioned/time_proto.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/time_proto.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/time_proto.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/types.go b/vendor/k8s.io/client-go/pkg/api/unversioned/types.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/types.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/types.go index 7d632b4..6178f19 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/types.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/types.go @@ -36,12 +36,14 @@ type TypeMeta struct { // Cannot be updated. // In CamelCase. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` // APIVersion defines the versioned schema of this representation of an object. // Servers should convert recognized schemas to the latest internal value, and // may reject unrecognized values. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#resources + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt,name=apiVersion"` } @@ -51,6 +53,7 @@ type ListMeta struct { // SelfLink is a URL representing this object. // Populated by the system. // Read-only. + // +optional SelfLink string `json:"selfLink,omitempty" protobuf:"bytes,1,opt,name=selfLink"` // String that identifies the server's internal version of this object that @@ -59,6 +62,7 @@ type ListMeta struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,2,opt,name=resourceVersion"` } @@ -76,25 +80,31 @@ type Status struct { TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Status of the operation. // One of: "Success" or "Failure". // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status string `json:"status,omitempty" protobuf:"bytes,2,opt,name=status"` // A human-readable description of the status of this operation. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,3,opt,name=message"` // A machine-readable description of why this operation is in the // "Failure" status. If this value is empty there // is no information available. A Reason clarifies an HTTP status // code but does not override it. + // +optional Reason StatusReason `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason,casttype=StatusReason"` // Extended data associated with the reason. Each reason may define its // own extended details. This field is optional and the data returned // is not guaranteed to conform to any schema except that defined by // the reason type. + // +optional Details *StatusDetails `json:"details,omitempty" protobuf:"bytes,5,opt,name=details"` // Suggested HTTP return code for this status, 0 if not set. + // +optional Code int32 `json:"code,omitempty" protobuf:"varint,6,opt,name=code"` } @@ -107,17 +117,22 @@ type Status struct { type StatusDetails struct { // The name attribute of the resource associated with the status StatusReason // (when there is a single name which can be described). + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` // The group attribute of the resource associated with the status StatusReason. + // +optional Group string `json:"group,omitempty" protobuf:"bytes,2,opt,name=group"` // The kind attribute of the resource associated with the status StatusReason. // On some operations may differ from the requested resource Kind. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional Kind string `json:"kind,omitempty" protobuf:"bytes,3,opt,name=kind"` // The Causes array includes more details associated with the StatusReason // failure. Not all StatusReasons may provide detailed causes. + // +optional Causes []StatusCause `json:"causes,omitempty" protobuf:"bytes,4,rep,name=causes"` // If specified, the time in seconds before the operation should be retried. + // +optional RetryAfterSeconds int32 `json:"retryAfterSeconds,omitempty" protobuf:"varint,5,opt,name=retryAfterSeconds"` } @@ -257,9 +272,11 @@ const ( type StatusCause struct { // A machine-readable description of the cause of the error. If this value is // empty there is no information available. + // +optional Type CauseType `json:"reason,omitempty" protobuf:"bytes,1,opt,name=reason,casttype=CauseType"` // A human-readable description of the cause of the error. This field may be // presented as-is to a reader. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` // The field of the resource that has caused this error, as named by its JSON // serialization. May include dot and postfix notation for nested attributes. @@ -270,6 +287,7 @@ type StatusCause struct { // Examples: // "name" - the field "name" on the current resource // "items[0].name" - the field "name" on the first array entry in "items" + // +optional Field string `json:"field,omitempty" protobuf:"bytes,3,opt,name=field"` } @@ -336,6 +354,7 @@ type APIGroup struct { Versions []GroupVersionForDiscovery `json:"versions" protobuf:"bytes,2,rep,name=versions"` // preferredVersion is the version preferred by the API server, which // probably is the storage version. + // +optional PreferredVersion GroupVersionForDiscovery `json:"preferredVersion,omitempty" protobuf:"bytes,3,opt,name=preferredVersion"` // a map of client CIDR to server address that is serving this group. // This is to help clients reach servers in the most network-efficient way possible. @@ -429,8 +448,10 @@ type LabelSelector struct { // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels // map is equivalent to an element of matchExpressions, whose key field is "key", the // operator is "In", and the values array contains only "value". The requirements are ANDed. + // +optional MatchLabels map[string]string `json:"matchLabels,omitempty" protobuf:"bytes,1,rep,name=matchLabels"` // matchExpressions is a list of label selector requirements. The requirements are ANDed. + // +optional MatchExpressions []LabelSelectorRequirement `json:"matchExpressions,omitempty" protobuf:"bytes,2,rep,name=matchExpressions"` } @@ -446,6 +467,7 @@ type LabelSelectorRequirement struct { // the values array must be non-empty. If the operator is Exists or DoesNotExist, // the values array must be empty. This array is replaced during a strategic // merge patch. + // +optional Values []string `json:"values,omitempty" protobuf:"bytes,3,rep,name=values"` } diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/api/unversioned/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/well_known_labels.go b/vendor/k8s.io/client-go/pkg/api/unversioned/well_known_labels.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/well_known_labels.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/well_known_labels.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/unversioned/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/api/unversioned/zz_generated.deepcopy.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/unversioned/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/api/unversioned/zz_generated.deepcopy.go index 627bb81..d70b91c 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/unversioned/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/api/unversioned/zz_generated.deepcopy.go @@ -21,7 +21,7 @@ limitations under the License. package unversioned import ( - conversion "k8s.io/kubernetes/pkg/conversion" + conversion "k8s.io/client-go/pkg/conversion" time "time" ) diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/conversion.go b/vendor/k8s.io/client-go/pkg/api/v1/conversion.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/v1/conversion.go rename to vendor/k8s.io/client-go/pkg/api/v1/conversion.go index 35be8a5..dba084a 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/conversion.go @@ -21,12 +21,12 @@ import ( "fmt" "reflect" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/validation/field" - "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/apis/extensions" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/validation/field" + "k8s.io/client-go/pkg/watch/versioned" ) const ( @@ -269,12 +269,6 @@ func addConversionFuncs(scheme *runtime.Scheme) error { } func Convert_v1_ReplicationController_to_extensions_ReplicaSet(in *ReplicationController, out *extensions.ReplicaSet, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*ReplicationController))(in) - } - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -288,9 +282,6 @@ func Convert_v1_ReplicationController_to_extensions_ReplicaSet(in *ReplicationCo } func Convert_v1_ReplicationControllerSpec_to_extensions_ReplicaSetSpec(in *ReplicationControllerSpec, out *extensions.ReplicaSetSpec, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*ReplicationControllerSpec))(in) - } out.Replicas = *in.Replicas if in.Selector != nil { api.Convert_map_to_unversioned_LabelSelector(&in.Selector, out.Selector, s) @@ -304,9 +295,6 @@ func Convert_v1_ReplicationControllerSpec_to_extensions_ReplicaSetSpec(in *Repli } func Convert_v1_ReplicationControllerStatus_to_extensions_ReplicaSetStatus(in *ReplicationControllerStatus, out *extensions.ReplicaSetStatus, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*ReplicationControllerStatus))(in) - } out.Replicas = in.Replicas out.FullyLabeledReplicas = in.FullyLabeledReplicas out.ReadyReplicas = in.ReadyReplicas @@ -316,12 +304,6 @@ func Convert_v1_ReplicationControllerStatus_to_extensions_ReplicaSetStatus(in *R } func Convert_extensions_ReplicaSet_to_v1_ReplicationController(in *extensions.ReplicaSet, out *ReplicationController, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*extensions.ReplicaSet))(in) - } - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -342,9 +324,6 @@ func Convert_extensions_ReplicaSet_to_v1_ReplicationController(in *extensions.Re } func Convert_extensions_ReplicaSetSpec_to_v1_ReplicationControllerSpec(in *extensions.ReplicaSetSpec, out *ReplicationControllerSpec, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*extensions.ReplicaSetSpec))(in) - } out.Replicas = new(int32) *out.Replicas = in.Replicas out.MinReadySeconds = in.MinReadySeconds @@ -360,9 +339,6 @@ func Convert_extensions_ReplicaSetSpec_to_v1_ReplicationControllerSpec(in *exten } func Convert_extensions_ReplicaSetStatus_to_v1_ReplicationControllerStatus(in *extensions.ReplicaSetStatus, out *ReplicationControllerStatus, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*extensions.ReplicaSetStatus))(in) - } out.Replicas = in.Replicas out.FullyLabeledReplicas = in.FullyLabeledReplicas out.ReadyReplicas = in.ReadyReplicas @@ -387,7 +363,9 @@ func Convert_api_ReplicationControllerSpec_To_v1_ReplicationControllerSpec(in *a } func Convert_v1_ReplicationControllerSpec_To_api_ReplicationControllerSpec(in *ReplicationControllerSpec, out *api.ReplicationControllerSpec, s conversion.Scope) error { - out.Replicas = *in.Replicas + if in.Replicas != nil { + out.Replicas = *in.Replicas + } out.MinReadySeconds = in.MinReadySeconds out.Selector = in.Selector if in.Template != nil { @@ -644,6 +622,11 @@ func Convert_v1_Pod_To_api_Pod(in *Pod, out *api.Pod, s conversion.Scope) error // taking responsibility to ensure mutation of in is not exposed // back to the caller. in.Spec.InitContainers = values + // Call defaulters explicitly until annotations are removed + for i := range in.Spec.InitContainers { + c := &in.Spec.InitContainers[i] + SetDefaults_Container(c) + } } // If there is a beta annotation, copy to alpha key. // See commit log for PR #31026 for why we do this. @@ -751,19 +734,20 @@ func Convert_v1_PodSecurityContext_To_api_PodSecurityContext(in *PodSecurityCont return nil } +// +k8s:conversion-fn=copy-only func Convert_v1_ResourceList_To_api_ResourceList(in *ResourceList, out *api.ResourceList, s conversion.Scope) error { if *in == nil { return nil } - if *out == nil { *out = make(api.ResourceList, len(*in)) } for key, val := range *in { + // Moved to defaults // TODO(#18538): We round up resource values to milli scale to maintain API compatibility. // In the future, we should instead reject values that need rounding. - const milliScale = -3 - val.RoundUp(milliScale) + // const milliScale = -3 + // val.RoundUp(milliScale) (*out)[api.ResourceName(key)] = val } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/defaults.go b/vendor/k8s.io/client-go/pkg/api/v1/defaults.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/api/v1/defaults.go rename to vendor/k8s.io/client-go/pkg/api/v1/defaults.go index 64120bf..92ddd38 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/defaults.go @@ -17,13 +17,14 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util" - "k8s.io/kubernetes/pkg/util/intstr" - "k8s.io/kubernetes/pkg/util/parsers" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util" + "k8s.io/client-go/pkg/util/intstr" + "k8s.io/client-go/pkg/util/parsers" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( SetDefaults_PodExecOptions, SetDefaults_PodAttachOptions, @@ -51,9 +52,21 @@ func addDefaultingFuncs(scheme *runtime.Scheme) error { SetDefaults_LimitRangeItem, SetDefaults_ConfigMap, SetDefaults_RBDVolumeSource, + SetDefaults_ResourceList, ) } +func SetDefaults_ResourceList(obj *ResourceList) { + for key, val := range *obj { + // TODO(#18538): We round up resource values to milli scale to maintain API compatibility. + // In the future, we should instead reject values that need rounding. + const milliScale = -3 + val.RoundUp(milliScale) + + (*obj)[ResourceName(key)] = val + } +} + func SetDefaults_PodExecOptions(obj *PodExecOptions) { obj.Stdout = true obj.Stderr = true diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/doc.go b/vendor/k8s.io/client-go/pkg/api/v1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/v1/doc.go rename to vendor/k8s.io/client-go/pkg/api/v1/doc.go index 16aa549..7c4d493 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/doc.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/doc.go @@ -17,6 +17,7 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/api // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta // Package v1 is the v1 version of the API. package v1 diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/generated.pb.go b/vendor/k8s.io/client-go/pkg/api/v1/generated.pb.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/api/v1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/api/v1/generated.pb.go index 164a774..ff16ae9 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/generated.pb.go @@ -187,11 +187,11 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_resource "k8s.io/kubernetes/pkg/api/resource" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_runtime "k8s.io/kubernetes/pkg/runtime" +import k8s_io_kubernetes_pkg_api_resource "k8s.io/client-go/pkg/api/resource" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_runtime "k8s.io/client-go/pkg/runtime" -import k8s_io_kubernetes_pkg_types "k8s.io/kubernetes/pkg/types" +import k8s_io_kubernetes_pkg_types "k8s.io/client-go/pkg/types" import strings "strings" import reflect "reflect" @@ -861,161 +861,161 @@ func (*WeightedPodAffinityTerm) Descriptor() ([]byte, []int) { } func init() { - proto.RegisterType((*AWSElasticBlockStoreVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.AWSElasticBlockStoreVolumeSource") - proto.RegisterType((*Affinity)(nil), "k8s.io.kubernetes.pkg.api.v1.Affinity") - proto.RegisterType((*AttachedVolume)(nil), "k8s.io.kubernetes.pkg.api.v1.AttachedVolume") - proto.RegisterType((*AvoidPods)(nil), "k8s.io.kubernetes.pkg.api.v1.AvoidPods") - proto.RegisterType((*AzureDiskVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.AzureDiskVolumeSource") - proto.RegisterType((*AzureFileVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.AzureFileVolumeSource") - proto.RegisterType((*Binding)(nil), "k8s.io.kubernetes.pkg.api.v1.Binding") - proto.RegisterType((*Capabilities)(nil), "k8s.io.kubernetes.pkg.api.v1.Capabilities") - proto.RegisterType((*CephFSVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.CephFSVolumeSource") - proto.RegisterType((*CinderVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.CinderVolumeSource") - proto.RegisterType((*ComponentCondition)(nil), "k8s.io.kubernetes.pkg.api.v1.ComponentCondition") - proto.RegisterType((*ComponentStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.ComponentStatus") - proto.RegisterType((*ComponentStatusList)(nil), "k8s.io.kubernetes.pkg.api.v1.ComponentStatusList") - proto.RegisterType((*ConfigMap)(nil), "k8s.io.kubernetes.pkg.api.v1.ConfigMap") - proto.RegisterType((*ConfigMapKeySelector)(nil), "k8s.io.kubernetes.pkg.api.v1.ConfigMapKeySelector") - proto.RegisterType((*ConfigMapList)(nil), "k8s.io.kubernetes.pkg.api.v1.ConfigMapList") - proto.RegisterType((*ConfigMapVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.ConfigMapVolumeSource") - proto.RegisterType((*Container)(nil), "k8s.io.kubernetes.pkg.api.v1.Container") - proto.RegisterType((*ContainerImage)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerImage") - proto.RegisterType((*ContainerPort)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerPort") - proto.RegisterType((*ContainerState)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerState") - proto.RegisterType((*ContainerStateRunning)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerStateRunning") - proto.RegisterType((*ContainerStateTerminated)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerStateTerminated") - proto.RegisterType((*ContainerStateWaiting)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerStateWaiting") - proto.RegisterType((*ContainerStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.ContainerStatus") - proto.RegisterType((*DaemonEndpoint)(nil), "k8s.io.kubernetes.pkg.api.v1.DaemonEndpoint") - proto.RegisterType((*DeleteOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.DeleteOptions") - proto.RegisterType((*DownwardAPIVolumeFile)(nil), "k8s.io.kubernetes.pkg.api.v1.DownwardAPIVolumeFile") - proto.RegisterType((*DownwardAPIVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.DownwardAPIVolumeSource") - proto.RegisterType((*EmptyDirVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.EmptyDirVolumeSource") - proto.RegisterType((*EndpointAddress)(nil), "k8s.io.kubernetes.pkg.api.v1.EndpointAddress") - proto.RegisterType((*EndpointPort)(nil), "k8s.io.kubernetes.pkg.api.v1.EndpointPort") - proto.RegisterType((*EndpointSubset)(nil), "k8s.io.kubernetes.pkg.api.v1.EndpointSubset") - proto.RegisterType((*Endpoints)(nil), "k8s.io.kubernetes.pkg.api.v1.Endpoints") - proto.RegisterType((*EndpointsList)(nil), "k8s.io.kubernetes.pkg.api.v1.EndpointsList") - proto.RegisterType((*EnvVar)(nil), "k8s.io.kubernetes.pkg.api.v1.EnvVar") - proto.RegisterType((*EnvVarSource)(nil), "k8s.io.kubernetes.pkg.api.v1.EnvVarSource") - proto.RegisterType((*Event)(nil), "k8s.io.kubernetes.pkg.api.v1.Event") - proto.RegisterType((*EventList)(nil), "k8s.io.kubernetes.pkg.api.v1.EventList") - proto.RegisterType((*EventSource)(nil), "k8s.io.kubernetes.pkg.api.v1.EventSource") - proto.RegisterType((*ExecAction)(nil), "k8s.io.kubernetes.pkg.api.v1.ExecAction") - proto.RegisterType((*ExportOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.ExportOptions") - proto.RegisterType((*FCVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.FCVolumeSource") - proto.RegisterType((*FlexVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.FlexVolumeSource") - proto.RegisterType((*FlockerVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.FlockerVolumeSource") - proto.RegisterType((*GCEPersistentDiskVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.GCEPersistentDiskVolumeSource") - proto.RegisterType((*GitRepoVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.GitRepoVolumeSource") - proto.RegisterType((*GlusterfsVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.GlusterfsVolumeSource") - proto.RegisterType((*HTTPGetAction)(nil), "k8s.io.kubernetes.pkg.api.v1.HTTPGetAction") - proto.RegisterType((*HTTPHeader)(nil), "k8s.io.kubernetes.pkg.api.v1.HTTPHeader") - proto.RegisterType((*Handler)(nil), "k8s.io.kubernetes.pkg.api.v1.Handler") - proto.RegisterType((*HostPathVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.HostPathVolumeSource") - proto.RegisterType((*ISCSIVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.ISCSIVolumeSource") - proto.RegisterType((*KeyToPath)(nil), "k8s.io.kubernetes.pkg.api.v1.KeyToPath") - proto.RegisterType((*Lifecycle)(nil), "k8s.io.kubernetes.pkg.api.v1.Lifecycle") - proto.RegisterType((*LimitRange)(nil), "k8s.io.kubernetes.pkg.api.v1.LimitRange") - proto.RegisterType((*LimitRangeItem)(nil), "k8s.io.kubernetes.pkg.api.v1.LimitRangeItem") - proto.RegisterType((*LimitRangeList)(nil), "k8s.io.kubernetes.pkg.api.v1.LimitRangeList") - proto.RegisterType((*LimitRangeSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.LimitRangeSpec") - proto.RegisterType((*List)(nil), "k8s.io.kubernetes.pkg.api.v1.List") - proto.RegisterType((*ListOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.ListOptions") - proto.RegisterType((*LoadBalancerIngress)(nil), "k8s.io.kubernetes.pkg.api.v1.LoadBalancerIngress") - proto.RegisterType((*LoadBalancerStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.LoadBalancerStatus") - proto.RegisterType((*LocalObjectReference)(nil), "k8s.io.kubernetes.pkg.api.v1.LocalObjectReference") - proto.RegisterType((*NFSVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.NFSVolumeSource") - proto.RegisterType((*Namespace)(nil), "k8s.io.kubernetes.pkg.api.v1.Namespace") - proto.RegisterType((*NamespaceList)(nil), "k8s.io.kubernetes.pkg.api.v1.NamespaceList") - proto.RegisterType((*NamespaceSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.NamespaceSpec") - proto.RegisterType((*NamespaceStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.NamespaceStatus") - proto.RegisterType((*Node)(nil), "k8s.io.kubernetes.pkg.api.v1.Node") - proto.RegisterType((*NodeAddress)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeAddress") - proto.RegisterType((*NodeAffinity)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeAffinity") - proto.RegisterType((*NodeCondition)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeCondition") - proto.RegisterType((*NodeDaemonEndpoints)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeDaemonEndpoints") - proto.RegisterType((*NodeList)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeList") - proto.RegisterType((*NodeProxyOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeProxyOptions") - proto.RegisterType((*NodeSelector)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeSelector") - proto.RegisterType((*NodeSelectorRequirement)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeSelectorRequirement") - proto.RegisterType((*NodeSelectorTerm)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeSelectorTerm") - proto.RegisterType((*NodeSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeSpec") - proto.RegisterType((*NodeStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeStatus") - proto.RegisterType((*NodeSystemInfo)(nil), "k8s.io.kubernetes.pkg.api.v1.NodeSystemInfo") - proto.RegisterType((*ObjectFieldSelector)(nil), "k8s.io.kubernetes.pkg.api.v1.ObjectFieldSelector") - proto.RegisterType((*ObjectMeta)(nil), "k8s.io.kubernetes.pkg.api.v1.ObjectMeta") - proto.RegisterType((*ObjectReference)(nil), "k8s.io.kubernetes.pkg.api.v1.ObjectReference") - proto.RegisterType((*OwnerReference)(nil), "k8s.io.kubernetes.pkg.api.v1.OwnerReference") - proto.RegisterType((*PersistentVolume)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolume") - proto.RegisterType((*PersistentVolumeClaim)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaim") - proto.RegisterType((*PersistentVolumeClaimList)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaimList") - proto.RegisterType((*PersistentVolumeClaimSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaimSpec") - proto.RegisterType((*PersistentVolumeClaimStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaimStatus") - proto.RegisterType((*PersistentVolumeClaimVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaimVolumeSource") - proto.RegisterType((*PersistentVolumeList)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeList") - proto.RegisterType((*PersistentVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeSource") - proto.RegisterType((*PersistentVolumeSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeSpec") - proto.RegisterType((*PersistentVolumeStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.PersistentVolumeStatus") - proto.RegisterType((*Pod)(nil), "k8s.io.kubernetes.pkg.api.v1.Pod") - proto.RegisterType((*PodAffinity)(nil), "k8s.io.kubernetes.pkg.api.v1.PodAffinity") - proto.RegisterType((*PodAffinityTerm)(nil), "k8s.io.kubernetes.pkg.api.v1.PodAffinityTerm") - proto.RegisterType((*PodAntiAffinity)(nil), "k8s.io.kubernetes.pkg.api.v1.PodAntiAffinity") - proto.RegisterType((*PodAttachOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.PodAttachOptions") - proto.RegisterType((*PodCondition)(nil), "k8s.io.kubernetes.pkg.api.v1.PodCondition") - proto.RegisterType((*PodExecOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.PodExecOptions") - proto.RegisterType((*PodList)(nil), "k8s.io.kubernetes.pkg.api.v1.PodList") - proto.RegisterType((*PodLogOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.PodLogOptions") - proto.RegisterType((*PodProxyOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.PodProxyOptions") - proto.RegisterType((*PodSecurityContext)(nil), "k8s.io.kubernetes.pkg.api.v1.PodSecurityContext") - proto.RegisterType((*PodSignature)(nil), "k8s.io.kubernetes.pkg.api.v1.PodSignature") - proto.RegisterType((*PodSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.PodSpec") - proto.RegisterType((*PodStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.PodStatus") - proto.RegisterType((*PodStatusResult)(nil), "k8s.io.kubernetes.pkg.api.v1.PodStatusResult") - proto.RegisterType((*PodTemplate)(nil), "k8s.io.kubernetes.pkg.api.v1.PodTemplate") - proto.RegisterType((*PodTemplateList)(nil), "k8s.io.kubernetes.pkg.api.v1.PodTemplateList") - proto.RegisterType((*PodTemplateSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.PodTemplateSpec") - proto.RegisterType((*Preconditions)(nil), "k8s.io.kubernetes.pkg.api.v1.Preconditions") - proto.RegisterType((*PreferAvoidPodsEntry)(nil), "k8s.io.kubernetes.pkg.api.v1.PreferAvoidPodsEntry") - proto.RegisterType((*PreferredSchedulingTerm)(nil), "k8s.io.kubernetes.pkg.api.v1.PreferredSchedulingTerm") - proto.RegisterType((*Probe)(nil), "k8s.io.kubernetes.pkg.api.v1.Probe") - proto.RegisterType((*QuobyteVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.QuobyteVolumeSource") - proto.RegisterType((*RBDVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.RBDVolumeSource") - proto.RegisterType((*RangeAllocation)(nil), "k8s.io.kubernetes.pkg.api.v1.RangeAllocation") - proto.RegisterType((*ReplicationController)(nil), "k8s.io.kubernetes.pkg.api.v1.ReplicationController") - proto.RegisterType((*ReplicationControllerCondition)(nil), "k8s.io.kubernetes.pkg.api.v1.ReplicationControllerCondition") - proto.RegisterType((*ReplicationControllerList)(nil), "k8s.io.kubernetes.pkg.api.v1.ReplicationControllerList") - proto.RegisterType((*ReplicationControllerSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.ReplicationControllerSpec") - proto.RegisterType((*ReplicationControllerStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.ReplicationControllerStatus") - proto.RegisterType((*ResourceFieldSelector)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceFieldSelector") - proto.RegisterType((*ResourceQuota)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceQuota") - proto.RegisterType((*ResourceQuotaList)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceQuotaList") - proto.RegisterType((*ResourceQuotaSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceQuotaSpec") - proto.RegisterType((*ResourceQuotaStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceQuotaStatus") - proto.RegisterType((*ResourceRequirements)(nil), "k8s.io.kubernetes.pkg.api.v1.ResourceRequirements") - proto.RegisterType((*SELinuxOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.SELinuxOptions") - proto.RegisterType((*Secret)(nil), "k8s.io.kubernetes.pkg.api.v1.Secret") - proto.RegisterType((*SecretKeySelector)(nil), "k8s.io.kubernetes.pkg.api.v1.SecretKeySelector") - proto.RegisterType((*SecretList)(nil), "k8s.io.kubernetes.pkg.api.v1.SecretList") - proto.RegisterType((*SecretVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.SecretVolumeSource") - proto.RegisterType((*SecurityContext)(nil), "k8s.io.kubernetes.pkg.api.v1.SecurityContext") - proto.RegisterType((*SerializedReference)(nil), "k8s.io.kubernetes.pkg.api.v1.SerializedReference") - proto.RegisterType((*Service)(nil), "k8s.io.kubernetes.pkg.api.v1.Service") - proto.RegisterType((*ServiceAccount)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceAccount") - proto.RegisterType((*ServiceAccountList)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceAccountList") - proto.RegisterType((*ServiceList)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceList") - proto.RegisterType((*ServicePort)(nil), "k8s.io.kubernetes.pkg.api.v1.ServicePort") - proto.RegisterType((*ServiceProxyOptions)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceProxyOptions") - proto.RegisterType((*ServiceSpec)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceSpec") - proto.RegisterType((*ServiceStatus)(nil), "k8s.io.kubernetes.pkg.api.v1.ServiceStatus") - proto.RegisterType((*TCPSocketAction)(nil), "k8s.io.kubernetes.pkg.api.v1.TCPSocketAction") - proto.RegisterType((*Taint)(nil), "k8s.io.kubernetes.pkg.api.v1.Taint") - proto.RegisterType((*Toleration)(nil), "k8s.io.kubernetes.pkg.api.v1.Toleration") - proto.RegisterType((*Volume)(nil), "k8s.io.kubernetes.pkg.api.v1.Volume") - proto.RegisterType((*VolumeMount)(nil), "k8s.io.kubernetes.pkg.api.v1.VolumeMount") - proto.RegisterType((*VolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.VolumeSource") - proto.RegisterType((*VsphereVirtualDiskVolumeSource)(nil), "k8s.io.kubernetes.pkg.api.v1.VsphereVirtualDiskVolumeSource") - proto.RegisterType((*WeightedPodAffinityTerm)(nil), "k8s.io.kubernetes.pkg.api.v1.WeightedPodAffinityTerm") + proto.RegisterType((*AWSElasticBlockStoreVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.AWSElasticBlockStoreVolumeSource") + proto.RegisterType((*Affinity)(nil), "k8s.io.client-go.pkg.api.v1.Affinity") + proto.RegisterType((*AttachedVolume)(nil), "k8s.io.client-go.pkg.api.v1.AttachedVolume") + proto.RegisterType((*AvoidPods)(nil), "k8s.io.client-go.pkg.api.v1.AvoidPods") + proto.RegisterType((*AzureDiskVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.AzureDiskVolumeSource") + proto.RegisterType((*AzureFileVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.AzureFileVolumeSource") + proto.RegisterType((*Binding)(nil), "k8s.io.client-go.pkg.api.v1.Binding") + proto.RegisterType((*Capabilities)(nil), "k8s.io.client-go.pkg.api.v1.Capabilities") + proto.RegisterType((*CephFSVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.CephFSVolumeSource") + proto.RegisterType((*CinderVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.CinderVolumeSource") + proto.RegisterType((*ComponentCondition)(nil), "k8s.io.client-go.pkg.api.v1.ComponentCondition") + proto.RegisterType((*ComponentStatus)(nil), "k8s.io.client-go.pkg.api.v1.ComponentStatus") + proto.RegisterType((*ComponentStatusList)(nil), "k8s.io.client-go.pkg.api.v1.ComponentStatusList") + proto.RegisterType((*ConfigMap)(nil), "k8s.io.client-go.pkg.api.v1.ConfigMap") + proto.RegisterType((*ConfigMapKeySelector)(nil), "k8s.io.client-go.pkg.api.v1.ConfigMapKeySelector") + proto.RegisterType((*ConfigMapList)(nil), "k8s.io.client-go.pkg.api.v1.ConfigMapList") + proto.RegisterType((*ConfigMapVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.ConfigMapVolumeSource") + proto.RegisterType((*Container)(nil), "k8s.io.client-go.pkg.api.v1.Container") + proto.RegisterType((*ContainerImage)(nil), "k8s.io.client-go.pkg.api.v1.ContainerImage") + proto.RegisterType((*ContainerPort)(nil), "k8s.io.client-go.pkg.api.v1.ContainerPort") + proto.RegisterType((*ContainerState)(nil), "k8s.io.client-go.pkg.api.v1.ContainerState") + proto.RegisterType((*ContainerStateRunning)(nil), "k8s.io.client-go.pkg.api.v1.ContainerStateRunning") + proto.RegisterType((*ContainerStateTerminated)(nil), "k8s.io.client-go.pkg.api.v1.ContainerStateTerminated") + proto.RegisterType((*ContainerStateWaiting)(nil), "k8s.io.client-go.pkg.api.v1.ContainerStateWaiting") + proto.RegisterType((*ContainerStatus)(nil), "k8s.io.client-go.pkg.api.v1.ContainerStatus") + proto.RegisterType((*DaemonEndpoint)(nil), "k8s.io.client-go.pkg.api.v1.DaemonEndpoint") + proto.RegisterType((*DeleteOptions)(nil), "k8s.io.client-go.pkg.api.v1.DeleteOptions") + proto.RegisterType((*DownwardAPIVolumeFile)(nil), "k8s.io.client-go.pkg.api.v1.DownwardAPIVolumeFile") + proto.RegisterType((*DownwardAPIVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.DownwardAPIVolumeSource") + proto.RegisterType((*EmptyDirVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.EmptyDirVolumeSource") + proto.RegisterType((*EndpointAddress)(nil), "k8s.io.client-go.pkg.api.v1.EndpointAddress") + proto.RegisterType((*EndpointPort)(nil), "k8s.io.client-go.pkg.api.v1.EndpointPort") + proto.RegisterType((*EndpointSubset)(nil), "k8s.io.client-go.pkg.api.v1.EndpointSubset") + proto.RegisterType((*Endpoints)(nil), "k8s.io.client-go.pkg.api.v1.Endpoints") + proto.RegisterType((*EndpointsList)(nil), "k8s.io.client-go.pkg.api.v1.EndpointsList") + proto.RegisterType((*EnvVar)(nil), "k8s.io.client-go.pkg.api.v1.EnvVar") + proto.RegisterType((*EnvVarSource)(nil), "k8s.io.client-go.pkg.api.v1.EnvVarSource") + proto.RegisterType((*Event)(nil), "k8s.io.client-go.pkg.api.v1.Event") + proto.RegisterType((*EventList)(nil), "k8s.io.client-go.pkg.api.v1.EventList") + proto.RegisterType((*EventSource)(nil), "k8s.io.client-go.pkg.api.v1.EventSource") + proto.RegisterType((*ExecAction)(nil), "k8s.io.client-go.pkg.api.v1.ExecAction") + proto.RegisterType((*ExportOptions)(nil), "k8s.io.client-go.pkg.api.v1.ExportOptions") + proto.RegisterType((*FCVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.FCVolumeSource") + proto.RegisterType((*FlexVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.FlexVolumeSource") + proto.RegisterType((*FlockerVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.FlockerVolumeSource") + proto.RegisterType((*GCEPersistentDiskVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.GCEPersistentDiskVolumeSource") + proto.RegisterType((*GitRepoVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.GitRepoVolumeSource") + proto.RegisterType((*GlusterfsVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.GlusterfsVolumeSource") + proto.RegisterType((*HTTPGetAction)(nil), "k8s.io.client-go.pkg.api.v1.HTTPGetAction") + proto.RegisterType((*HTTPHeader)(nil), "k8s.io.client-go.pkg.api.v1.HTTPHeader") + proto.RegisterType((*Handler)(nil), "k8s.io.client-go.pkg.api.v1.Handler") + proto.RegisterType((*HostPathVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.HostPathVolumeSource") + proto.RegisterType((*ISCSIVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.ISCSIVolumeSource") + proto.RegisterType((*KeyToPath)(nil), "k8s.io.client-go.pkg.api.v1.KeyToPath") + proto.RegisterType((*Lifecycle)(nil), "k8s.io.client-go.pkg.api.v1.Lifecycle") + proto.RegisterType((*LimitRange)(nil), "k8s.io.client-go.pkg.api.v1.LimitRange") + proto.RegisterType((*LimitRangeItem)(nil), "k8s.io.client-go.pkg.api.v1.LimitRangeItem") + proto.RegisterType((*LimitRangeList)(nil), "k8s.io.client-go.pkg.api.v1.LimitRangeList") + proto.RegisterType((*LimitRangeSpec)(nil), "k8s.io.client-go.pkg.api.v1.LimitRangeSpec") + proto.RegisterType((*List)(nil), "k8s.io.client-go.pkg.api.v1.List") + proto.RegisterType((*ListOptions)(nil), "k8s.io.client-go.pkg.api.v1.ListOptions") + proto.RegisterType((*LoadBalancerIngress)(nil), "k8s.io.client-go.pkg.api.v1.LoadBalancerIngress") + proto.RegisterType((*LoadBalancerStatus)(nil), "k8s.io.client-go.pkg.api.v1.LoadBalancerStatus") + proto.RegisterType((*LocalObjectReference)(nil), "k8s.io.client-go.pkg.api.v1.LocalObjectReference") + proto.RegisterType((*NFSVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.NFSVolumeSource") + proto.RegisterType((*Namespace)(nil), "k8s.io.client-go.pkg.api.v1.Namespace") + proto.RegisterType((*NamespaceList)(nil), "k8s.io.client-go.pkg.api.v1.NamespaceList") + proto.RegisterType((*NamespaceSpec)(nil), "k8s.io.client-go.pkg.api.v1.NamespaceSpec") + proto.RegisterType((*NamespaceStatus)(nil), "k8s.io.client-go.pkg.api.v1.NamespaceStatus") + proto.RegisterType((*Node)(nil), "k8s.io.client-go.pkg.api.v1.Node") + proto.RegisterType((*NodeAddress)(nil), "k8s.io.client-go.pkg.api.v1.NodeAddress") + proto.RegisterType((*NodeAffinity)(nil), "k8s.io.client-go.pkg.api.v1.NodeAffinity") + proto.RegisterType((*NodeCondition)(nil), "k8s.io.client-go.pkg.api.v1.NodeCondition") + proto.RegisterType((*NodeDaemonEndpoints)(nil), "k8s.io.client-go.pkg.api.v1.NodeDaemonEndpoints") + proto.RegisterType((*NodeList)(nil), "k8s.io.client-go.pkg.api.v1.NodeList") + proto.RegisterType((*NodeProxyOptions)(nil), "k8s.io.client-go.pkg.api.v1.NodeProxyOptions") + proto.RegisterType((*NodeSelector)(nil), "k8s.io.client-go.pkg.api.v1.NodeSelector") + proto.RegisterType((*NodeSelectorRequirement)(nil), "k8s.io.client-go.pkg.api.v1.NodeSelectorRequirement") + proto.RegisterType((*NodeSelectorTerm)(nil), "k8s.io.client-go.pkg.api.v1.NodeSelectorTerm") + proto.RegisterType((*NodeSpec)(nil), "k8s.io.client-go.pkg.api.v1.NodeSpec") + proto.RegisterType((*NodeStatus)(nil), "k8s.io.client-go.pkg.api.v1.NodeStatus") + proto.RegisterType((*NodeSystemInfo)(nil), "k8s.io.client-go.pkg.api.v1.NodeSystemInfo") + proto.RegisterType((*ObjectFieldSelector)(nil), "k8s.io.client-go.pkg.api.v1.ObjectFieldSelector") + proto.RegisterType((*ObjectMeta)(nil), "k8s.io.client-go.pkg.api.v1.ObjectMeta") + proto.RegisterType((*ObjectReference)(nil), "k8s.io.client-go.pkg.api.v1.ObjectReference") + proto.RegisterType((*OwnerReference)(nil), "k8s.io.client-go.pkg.api.v1.OwnerReference") + proto.RegisterType((*PersistentVolume)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolume") + proto.RegisterType((*PersistentVolumeClaim)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeClaim") + proto.RegisterType((*PersistentVolumeClaimList)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeClaimList") + proto.RegisterType((*PersistentVolumeClaimSpec)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeClaimSpec") + proto.RegisterType((*PersistentVolumeClaimStatus)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeClaimStatus") + proto.RegisterType((*PersistentVolumeClaimVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeClaimVolumeSource") + proto.RegisterType((*PersistentVolumeList)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeList") + proto.RegisterType((*PersistentVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeSource") + proto.RegisterType((*PersistentVolumeSpec)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeSpec") + proto.RegisterType((*PersistentVolumeStatus)(nil), "k8s.io.client-go.pkg.api.v1.PersistentVolumeStatus") + proto.RegisterType((*Pod)(nil), "k8s.io.client-go.pkg.api.v1.Pod") + proto.RegisterType((*PodAffinity)(nil), "k8s.io.client-go.pkg.api.v1.PodAffinity") + proto.RegisterType((*PodAffinityTerm)(nil), "k8s.io.client-go.pkg.api.v1.PodAffinityTerm") + proto.RegisterType((*PodAntiAffinity)(nil), "k8s.io.client-go.pkg.api.v1.PodAntiAffinity") + proto.RegisterType((*PodAttachOptions)(nil), "k8s.io.client-go.pkg.api.v1.PodAttachOptions") + proto.RegisterType((*PodCondition)(nil), "k8s.io.client-go.pkg.api.v1.PodCondition") + proto.RegisterType((*PodExecOptions)(nil), "k8s.io.client-go.pkg.api.v1.PodExecOptions") + proto.RegisterType((*PodList)(nil), "k8s.io.client-go.pkg.api.v1.PodList") + proto.RegisterType((*PodLogOptions)(nil), "k8s.io.client-go.pkg.api.v1.PodLogOptions") + proto.RegisterType((*PodProxyOptions)(nil), "k8s.io.client-go.pkg.api.v1.PodProxyOptions") + proto.RegisterType((*PodSecurityContext)(nil), "k8s.io.client-go.pkg.api.v1.PodSecurityContext") + proto.RegisterType((*PodSignature)(nil), "k8s.io.client-go.pkg.api.v1.PodSignature") + proto.RegisterType((*PodSpec)(nil), "k8s.io.client-go.pkg.api.v1.PodSpec") + proto.RegisterType((*PodStatus)(nil), "k8s.io.client-go.pkg.api.v1.PodStatus") + proto.RegisterType((*PodStatusResult)(nil), "k8s.io.client-go.pkg.api.v1.PodStatusResult") + proto.RegisterType((*PodTemplate)(nil), "k8s.io.client-go.pkg.api.v1.PodTemplate") + proto.RegisterType((*PodTemplateList)(nil), "k8s.io.client-go.pkg.api.v1.PodTemplateList") + proto.RegisterType((*PodTemplateSpec)(nil), "k8s.io.client-go.pkg.api.v1.PodTemplateSpec") + proto.RegisterType((*Preconditions)(nil), "k8s.io.client-go.pkg.api.v1.Preconditions") + proto.RegisterType((*PreferAvoidPodsEntry)(nil), "k8s.io.client-go.pkg.api.v1.PreferAvoidPodsEntry") + proto.RegisterType((*PreferredSchedulingTerm)(nil), "k8s.io.client-go.pkg.api.v1.PreferredSchedulingTerm") + proto.RegisterType((*Probe)(nil), "k8s.io.client-go.pkg.api.v1.Probe") + proto.RegisterType((*QuobyteVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.QuobyteVolumeSource") + proto.RegisterType((*RBDVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.RBDVolumeSource") + proto.RegisterType((*RangeAllocation)(nil), "k8s.io.client-go.pkg.api.v1.RangeAllocation") + proto.RegisterType((*ReplicationController)(nil), "k8s.io.client-go.pkg.api.v1.ReplicationController") + proto.RegisterType((*ReplicationControllerCondition)(nil), "k8s.io.client-go.pkg.api.v1.ReplicationControllerCondition") + proto.RegisterType((*ReplicationControllerList)(nil), "k8s.io.client-go.pkg.api.v1.ReplicationControllerList") + proto.RegisterType((*ReplicationControllerSpec)(nil), "k8s.io.client-go.pkg.api.v1.ReplicationControllerSpec") + proto.RegisterType((*ReplicationControllerStatus)(nil), "k8s.io.client-go.pkg.api.v1.ReplicationControllerStatus") + proto.RegisterType((*ResourceFieldSelector)(nil), "k8s.io.client-go.pkg.api.v1.ResourceFieldSelector") + proto.RegisterType((*ResourceQuota)(nil), "k8s.io.client-go.pkg.api.v1.ResourceQuota") + proto.RegisterType((*ResourceQuotaList)(nil), "k8s.io.client-go.pkg.api.v1.ResourceQuotaList") + proto.RegisterType((*ResourceQuotaSpec)(nil), "k8s.io.client-go.pkg.api.v1.ResourceQuotaSpec") + proto.RegisterType((*ResourceQuotaStatus)(nil), "k8s.io.client-go.pkg.api.v1.ResourceQuotaStatus") + proto.RegisterType((*ResourceRequirements)(nil), "k8s.io.client-go.pkg.api.v1.ResourceRequirements") + proto.RegisterType((*SELinuxOptions)(nil), "k8s.io.client-go.pkg.api.v1.SELinuxOptions") + proto.RegisterType((*Secret)(nil), "k8s.io.client-go.pkg.api.v1.Secret") + proto.RegisterType((*SecretKeySelector)(nil), "k8s.io.client-go.pkg.api.v1.SecretKeySelector") + proto.RegisterType((*SecretList)(nil), "k8s.io.client-go.pkg.api.v1.SecretList") + proto.RegisterType((*SecretVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.SecretVolumeSource") + proto.RegisterType((*SecurityContext)(nil), "k8s.io.client-go.pkg.api.v1.SecurityContext") + proto.RegisterType((*SerializedReference)(nil), "k8s.io.client-go.pkg.api.v1.SerializedReference") + proto.RegisterType((*Service)(nil), "k8s.io.client-go.pkg.api.v1.Service") + proto.RegisterType((*ServiceAccount)(nil), "k8s.io.client-go.pkg.api.v1.ServiceAccount") + proto.RegisterType((*ServiceAccountList)(nil), "k8s.io.client-go.pkg.api.v1.ServiceAccountList") + proto.RegisterType((*ServiceList)(nil), "k8s.io.client-go.pkg.api.v1.ServiceList") + proto.RegisterType((*ServicePort)(nil), "k8s.io.client-go.pkg.api.v1.ServicePort") + proto.RegisterType((*ServiceProxyOptions)(nil), "k8s.io.client-go.pkg.api.v1.ServiceProxyOptions") + proto.RegisterType((*ServiceSpec)(nil), "k8s.io.client-go.pkg.api.v1.ServiceSpec") + proto.RegisterType((*ServiceStatus)(nil), "k8s.io.client-go.pkg.api.v1.ServiceStatus") + proto.RegisterType((*TCPSocketAction)(nil), "k8s.io.client-go.pkg.api.v1.TCPSocketAction") + proto.RegisterType((*Taint)(nil), "k8s.io.client-go.pkg.api.v1.Taint") + proto.RegisterType((*Toleration)(nil), "k8s.io.client-go.pkg.api.v1.Toleration") + proto.RegisterType((*Volume)(nil), "k8s.io.client-go.pkg.api.v1.Volume") + proto.RegisterType((*VolumeMount)(nil), "k8s.io.client-go.pkg.api.v1.VolumeMount") + proto.RegisterType((*VolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.VolumeSource") + proto.RegisterType((*VsphereVirtualDiskVolumeSource)(nil), "k8s.io.client-go.pkg.api.v1.VsphereVirtualDiskVolumeSource") + proto.RegisterType((*WeightedPodAffinityTerm)(nil), "k8s.io.client-go.pkg.api.v1.WeightedPodAffinityTerm") } func (m *AWSElasticBlockStoreVolumeSource) Marshal() (data []byte, err error) { size := m.Size() @@ -6574,25 +6574,17 @@ func (m *ReplicationControllerCondition) MarshalTo(data []byte) (int, error) { i += copy(data[i:], m.Status) data[i] = 0x1a i++ - i = encodeVarintGenerated(data, i, uint64(m.LastProbeTime.Size())) - n135, err := m.LastProbeTime.MarshalTo(data[i:]) + i = encodeVarintGenerated(data, i, uint64(m.LastTransitionTime.Size())) + n135, err := m.LastTransitionTime.MarshalTo(data[i:]) if err != nil { return 0, err } i += n135 data[i] = 0x22 i++ - i = encodeVarintGenerated(data, i, uint64(m.LastTransitionTime.Size())) - n136, err := m.LastTransitionTime.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n136 - data[i] = 0x2a - i++ i = encodeVarintGenerated(data, i, uint64(len(m.Reason))) i += copy(data[i:], m.Reason) - data[i] = 0x32 + data[i] = 0x2a i++ i = encodeVarintGenerated(data, i, uint64(len(m.Message))) i += copy(data[i:], m.Message) @@ -6617,11 +6609,11 @@ func (m *ReplicationControllerList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n137, err := m.ListMeta.MarshalTo(data[i:]) + n136, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n137 + i += n136 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -6678,11 +6670,11 @@ func (m *ReplicationControllerSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.Template.Size())) - n138, err := m.Template.MarshalTo(data[i:]) + n137, err := m.Template.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n138 + i += n137 } data[i] = 0x20 i++ @@ -6761,11 +6753,11 @@ func (m *ResourceFieldSelector) MarshalTo(data []byte) (int, error) { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.Divisor.Size())) - n139, err := m.Divisor.MarshalTo(data[i:]) + n138, err := m.Divisor.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n139 + i += n138 return i, nil } @@ -6787,27 +6779,27 @@ func (m *ResourceQuota) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n140, err := m.ObjectMeta.MarshalTo(data[i:]) + n139, err := m.ObjectMeta.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n139 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n140, err := m.Spec.MarshalTo(data[i:]) if err != nil { return 0, err } i += n140 - data[i] = 0x12 + data[i] = 0x1a i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n141, err := m.Spec.MarshalTo(data[i:]) + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n141, err := m.Status.MarshalTo(data[i:]) if err != nil { return 0, err } i += n141 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n142, err := m.Status.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n142 return i, nil } @@ -6829,11 +6821,11 @@ func (m *ResourceQuotaList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n143, err := m.ListMeta.MarshalTo(data[i:]) + n142, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n143 + i += n142 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -6879,11 +6871,11 @@ func (m *ResourceQuotaSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64((&v).Size())) - n144, err := (&v).MarshalTo(data[i:]) + n143, err := (&v).MarshalTo(data[i:]) if err != nil { return 0, err } - i += n144 + i += n143 } } if len(m.Scopes) > 0 { @@ -6934,11 +6926,11 @@ func (m *ResourceQuotaStatus) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64((&v).Size())) - n145, err := (&v).MarshalTo(data[i:]) + n144, err := (&v).MarshalTo(data[i:]) if err != nil { return 0, err } - i += n145 + i += n144 } } if len(m.Used) > 0 { @@ -6956,11 +6948,11 @@ func (m *ResourceQuotaStatus) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64((&v).Size())) - n146, err := (&v).MarshalTo(data[i:]) + n145, err := (&v).MarshalTo(data[i:]) if err != nil { return 0, err } - i += n146 + i += n145 } } return i, nil @@ -6996,11 +6988,11 @@ func (m *ResourceRequirements) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64((&v).Size())) - n147, err := (&v).MarshalTo(data[i:]) + n146, err := (&v).MarshalTo(data[i:]) if err != nil { return 0, err } - i += n147 + i += n146 } } if len(m.Requests) > 0 { @@ -7018,11 +7010,11 @@ func (m *ResourceRequirements) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64((&v).Size())) - n148, err := (&v).MarshalTo(data[i:]) + n147, err := (&v).MarshalTo(data[i:]) if err != nil { return 0, err } - i += n148 + i += n147 } } return i, nil @@ -7080,11 +7072,11 @@ func (m *Secret) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n149, err := m.ObjectMeta.MarshalTo(data[i:]) + n148, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n149 + i += n148 if len(m.Data) > 0 { for k := range m.Data { data[i] = 0x12 @@ -7144,11 +7136,11 @@ func (m *SecretKeySelector) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.LocalObjectReference.Size())) - n150, err := m.LocalObjectReference.MarshalTo(data[i:]) + n149, err := m.LocalObjectReference.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n150 + i += n149 data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(len(m.Key))) @@ -7174,11 +7166,11 @@ func (m *SecretList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n151, err := m.ListMeta.MarshalTo(data[i:]) + n150, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n151 + i += n150 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -7252,11 +7244,11 @@ func (m *SecurityContext) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.Capabilities.Size())) - n152, err := m.Capabilities.MarshalTo(data[i:]) + n151, err := m.Capabilities.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n152 + i += n151 } if m.Privileged != nil { data[i] = 0x10 @@ -7272,11 +7264,11 @@ func (m *SecurityContext) MarshalTo(data []byte) (int, error) { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.SELinuxOptions.Size())) - n153, err := m.SELinuxOptions.MarshalTo(data[i:]) + n152, err := m.SELinuxOptions.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n153 + i += n152 } if m.RunAsUser != nil { data[i] = 0x20 @@ -7324,11 +7316,11 @@ func (m *SerializedReference) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.Reference.Size())) - n154, err := m.Reference.MarshalTo(data[i:]) + n153, err := m.Reference.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n154 + i += n153 return i, nil } @@ -7350,27 +7342,27 @@ func (m *Service) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n155, err := m.ObjectMeta.MarshalTo(data[i:]) + n154, err := m.ObjectMeta.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n154 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n155, err := m.Spec.MarshalTo(data[i:]) if err != nil { return 0, err } i += n155 - data[i] = 0x12 + data[i] = 0x1a i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n156, err := m.Spec.MarshalTo(data[i:]) + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n156, err := m.Status.MarshalTo(data[i:]) if err != nil { return 0, err } i += n156 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n157, err := m.Status.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n157 return i, nil } @@ -7392,11 +7384,11 @@ func (m *ServiceAccount) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n158, err := m.ObjectMeta.MarshalTo(data[i:]) + n157, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n158 + i += n157 if len(m.Secrets) > 0 { for _, msg := range m.Secrets { data[i] = 0x12 @@ -7442,11 +7434,11 @@ func (m *ServiceAccountList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n159, err := m.ListMeta.MarshalTo(data[i:]) + n158, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n159 + i += n158 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -7480,11 +7472,11 @@ func (m *ServiceList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n160, err := m.ListMeta.MarshalTo(data[i:]) + n159, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n160 + i += n159 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -7529,11 +7521,11 @@ func (m *ServicePort) MarshalTo(data []byte) (int, error) { data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.TargetPort.Size())) - n161, err := m.TargetPort.MarshalTo(data[i:]) + n160, err := m.TargetPort.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n161 + i += n160 data[i] = 0x28 i++ i = encodeVarintGenerated(data, i, uint64(m.NodePort)) @@ -7692,11 +7684,11 @@ func (m *ServiceStatus) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.LoadBalancer.Size())) - n162, err := m.LoadBalancer.MarshalTo(data[i:]) + n161, err := m.LoadBalancer.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n162 + i += n161 return i, nil } @@ -7718,11 +7710,11 @@ func (m *TCPSocketAction) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.Port.Size())) - n163, err := m.Port.MarshalTo(data[i:]) + n162, err := m.Port.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n163 + i += n162 return i, nil } @@ -7812,11 +7804,11 @@ func (m *Volume) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.VolumeSource.Size())) - n164, err := m.VolumeSource.MarshalTo(data[i:]) + n163, err := m.VolumeSource.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n164 + i += n163 return i, nil } @@ -7877,151 +7869,151 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.HostPath.Size())) - n165, err := m.HostPath.MarshalTo(data[i:]) + n164, err := m.HostPath.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n165 + i += n164 } if m.EmptyDir != nil { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.EmptyDir.Size())) - n166, err := m.EmptyDir.MarshalTo(data[i:]) + n165, err := m.EmptyDir.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n166 + i += n165 } if m.GCEPersistentDisk != nil { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.GCEPersistentDisk.Size())) - n167, err := m.GCEPersistentDisk.MarshalTo(data[i:]) + n166, err := m.GCEPersistentDisk.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n167 + i += n166 } if m.AWSElasticBlockStore != nil { data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.AWSElasticBlockStore.Size())) - n168, err := m.AWSElasticBlockStore.MarshalTo(data[i:]) + n167, err := m.AWSElasticBlockStore.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n168 + i += n167 } if m.GitRepo != nil { data[i] = 0x2a i++ i = encodeVarintGenerated(data, i, uint64(m.GitRepo.Size())) - n169, err := m.GitRepo.MarshalTo(data[i:]) + n168, err := m.GitRepo.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n169 + i += n168 } if m.Secret != nil { data[i] = 0x32 i++ i = encodeVarintGenerated(data, i, uint64(m.Secret.Size())) - n170, err := m.Secret.MarshalTo(data[i:]) + n169, err := m.Secret.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n170 + i += n169 } if m.NFS != nil { data[i] = 0x3a i++ i = encodeVarintGenerated(data, i, uint64(m.NFS.Size())) - n171, err := m.NFS.MarshalTo(data[i:]) + n170, err := m.NFS.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n171 + i += n170 } if m.ISCSI != nil { data[i] = 0x42 i++ i = encodeVarintGenerated(data, i, uint64(m.ISCSI.Size())) - n172, err := m.ISCSI.MarshalTo(data[i:]) + n171, err := m.ISCSI.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n172 + i += n171 } if m.Glusterfs != nil { data[i] = 0x4a i++ i = encodeVarintGenerated(data, i, uint64(m.Glusterfs.Size())) - n173, err := m.Glusterfs.MarshalTo(data[i:]) + n172, err := m.Glusterfs.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n173 + i += n172 } if m.PersistentVolumeClaim != nil { data[i] = 0x52 i++ i = encodeVarintGenerated(data, i, uint64(m.PersistentVolumeClaim.Size())) - n174, err := m.PersistentVolumeClaim.MarshalTo(data[i:]) + n173, err := m.PersistentVolumeClaim.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n174 + i += n173 } if m.RBD != nil { data[i] = 0x5a i++ i = encodeVarintGenerated(data, i, uint64(m.RBD.Size())) - n175, err := m.RBD.MarshalTo(data[i:]) + n174, err := m.RBD.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n175 + i += n174 } if m.FlexVolume != nil { data[i] = 0x62 i++ i = encodeVarintGenerated(data, i, uint64(m.FlexVolume.Size())) - n176, err := m.FlexVolume.MarshalTo(data[i:]) + n175, err := m.FlexVolume.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n176 + i += n175 } if m.Cinder != nil { data[i] = 0x6a i++ i = encodeVarintGenerated(data, i, uint64(m.Cinder.Size())) - n177, err := m.Cinder.MarshalTo(data[i:]) + n176, err := m.Cinder.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n177 + i += n176 } if m.CephFS != nil { data[i] = 0x72 i++ i = encodeVarintGenerated(data, i, uint64(m.CephFS.Size())) - n178, err := m.CephFS.MarshalTo(data[i:]) + n177, err := m.CephFS.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n178 + i += n177 } if m.Flocker != nil { data[i] = 0x7a i++ i = encodeVarintGenerated(data, i, uint64(m.Flocker.Size())) - n179, err := m.Flocker.MarshalTo(data[i:]) + n178, err := m.Flocker.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n179 + i += n178 } if m.DownwardAPI != nil { data[i] = 0x82 @@ -8029,11 +8021,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.DownwardAPI.Size())) - n180, err := m.DownwardAPI.MarshalTo(data[i:]) + n179, err := m.DownwardAPI.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n180 + i += n179 } if m.FC != nil { data[i] = 0x8a @@ -8041,11 +8033,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.FC.Size())) - n181, err := m.FC.MarshalTo(data[i:]) + n180, err := m.FC.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n181 + i += n180 } if m.AzureFile != nil { data[i] = 0x92 @@ -8053,11 +8045,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.AzureFile.Size())) - n182, err := m.AzureFile.MarshalTo(data[i:]) + n181, err := m.AzureFile.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n182 + i += n181 } if m.ConfigMap != nil { data[i] = 0x9a @@ -8065,11 +8057,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.ConfigMap.Size())) - n183, err := m.ConfigMap.MarshalTo(data[i:]) + n182, err := m.ConfigMap.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n183 + i += n182 } if m.VsphereVolume != nil { data[i] = 0xa2 @@ -8077,11 +8069,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.VsphereVolume.Size())) - n184, err := m.VsphereVolume.MarshalTo(data[i:]) + n183, err := m.VsphereVolume.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n184 + i += n183 } if m.Quobyte != nil { data[i] = 0xaa @@ -8089,11 +8081,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.Quobyte.Size())) - n185, err := m.Quobyte.MarshalTo(data[i:]) + n184, err := m.Quobyte.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n185 + i += n184 } if m.AzureDisk != nil { data[i] = 0xb2 @@ -8101,11 +8093,11 @@ func (m *VolumeSource) MarshalTo(data []byte) (int, error) { data[i] = 0x1 i++ i = encodeVarintGenerated(data, i, uint64(m.AzureDisk.Size())) - n186, err := m.AzureDisk.MarshalTo(data[i:]) + n185, err := m.AzureDisk.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n186 + i += n185 } return i, nil } @@ -8157,11 +8149,11 @@ func (m *WeightedPodAffinityTerm) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.PodAffinityTerm.Size())) - n187, err := m.PodAffinityTerm.MarshalTo(data[i:]) + n186, err := m.PodAffinityTerm.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n187 + i += n186 return i, nil } @@ -10240,8 +10232,6 @@ func (m *ReplicationControllerCondition) Size() (n int) { n += 1 + l + sovGenerated(uint64(l)) l = len(m.Status) n += 1 + l + sovGenerated(uint64(l)) - l = m.LastProbeTime.Size() - n += 1 + l + sovGenerated(uint64(l)) l = m.LastTransitionTime.Size() n += 1 + l + sovGenerated(uint64(l)) l = len(m.Reason) @@ -12536,7 +12526,6 @@ func (this *ReplicationControllerCondition) String() string { s := strings.Join([]string{`&ReplicationControllerCondition{`, `Type:` + fmt.Sprintf("%v", this.Type) + `,`, `Status:` + fmt.Sprintf("%v", this.Status) + `,`, - `LastProbeTime:` + strings.Replace(strings.Replace(this.LastProbeTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, `LastTransitionTime:` + strings.Replace(strings.Replace(this.LastTransitionTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, `Message:` + fmt.Sprintf("%v", this.Message) + `,`, @@ -32997,36 +32986,6 @@ func (m *ReplicationControllerCondition) Unmarshal(data []byte) error { m.Status = ConditionStatus(data[iNdEx:postIndex]) iNdEx = postIndex case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LastProbeTime", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.LastProbeTime.Unmarshal(data[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) } @@ -33056,7 +33015,7 @@ func (m *ReplicationControllerCondition) Unmarshal(data []byte) error { return err } iNdEx = postIndex - case 5: + case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) } @@ -33085,7 +33044,7 @@ func (m *ReplicationControllerCondition) Unmarshal(data []byte) error { } m.Reason = string(data[iNdEx:postIndex]) iNdEx = postIndex - case 6: + case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) } @@ -38931,623 +38890,628 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 9873 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x7d, 0x6d, 0x8c, 0x24, 0xc7, - 0x75, 0x98, 0x66, 0x66, 0xbf, 0xa6, 0xf6, 0xf3, 0xfa, 0x8e, 0xc7, 0xe5, 0x4a, 0xfc, 0x6a, 0x91, - 0x14, 0x79, 0xe4, 0xed, 0xf1, 0x8e, 0xa4, 0x49, 0x4a, 0x8a, 0xc4, 0xfd, 0xbc, 0x5b, 0xdf, 0xee, - 0xdd, 0xf0, 0xcd, 0xde, 0x9d, 0x64, 0x31, 0x32, 0x7b, 0x67, 0x7a, 0x77, 0x5b, 0x37, 0x3b, 0x3d, - 0xec, 0xee, 0xd9, 0xbb, 0xa5, 0x62, 0xc0, 0x71, 0x1c, 0x07, 0x81, 0x0d, 0x47, 0x46, 0x62, 0x24, - 0x40, 0x12, 0xc4, 0x09, 0x90, 0x20, 0x89, 0x11, 0xc7, 0x72, 0x14, 0x5b, 0x4a, 0x0c, 0x23, 0x40, - 0x1c, 0x41, 0xf9, 0x70, 0x20, 0x03, 0x41, 0xec, 0xd8, 0x80, 0x62, 0xd9, 0x08, 0xf2, 0x23, 0x7f, - 0x02, 0x24, 0x7f, 0x72, 0x30, 0x92, 0xd4, 0xab, 0xef, 0xea, 0xe9, 0xd9, 0xee, 0x59, 0xde, 0xac, - 0xcf, 0x86, 0x7f, 0x2c, 0xb0, 0xf3, 0xde, 0xab, 0x57, 0x1f, 0x5d, 0xf5, 0xea, 0xbd, 0x57, 0xaf, - 0x5e, 0x91, 0x57, 0xee, 0xbe, 0x15, 0x2f, 0x06, 0xe1, 0xa5, 0xbb, 0xdd, 0x1d, 0x3f, 0x6a, 0xfb, - 0x89, 0x1f, 0x5f, 0xea, 0xdc, 0xdd, 0xbb, 0xe4, 0x75, 0x82, 0x4b, 0x87, 0x97, 0x2f, 0xed, 0xf9, - 0x6d, 0x3f, 0xf2, 0x12, 0xbf, 0xb9, 0xd8, 0x89, 0xc2, 0x24, 0x74, 0x3e, 0xc1, 0xa9, 0x17, 0x35, - 0xf5, 0x22, 0xa5, 0x5e, 0xa4, 0xd4, 0x8b, 0x87, 0x97, 0x17, 0x2e, 0xee, 0x05, 0xc9, 0x7e, 0x77, - 0x67, 0xb1, 0x11, 0x1e, 0x5c, 0xda, 0x0b, 0xf7, 0xc2, 0x4b, 0xac, 0xd0, 0x4e, 0x77, 0x97, 0xfd, - 0x62, 0x3f, 0xd8, 0x7f, 0x9c, 0xd9, 0xc2, 0x95, 0xfe, 0x55, 0x47, 0x7e, 0x1c, 0x76, 0xa3, 0x86, - 0x9f, 0x6e, 0xc0, 0xc2, 0x1b, 0xfd, 0xcb, 0x74, 0xdb, 0x87, 0x7e, 0x14, 0x07, 0x61, 0xdb, 0x6f, - 0xf6, 0x14, 0xbb, 0x98, 0x5d, 0x2c, 0xea, 0xb6, 0x93, 0xe0, 0xa0, 0xb7, 0x96, 0xcb, 0xd9, 0xe4, - 0xdd, 0x24, 0x68, 0x5d, 0x0a, 0xda, 0x49, 0x9c, 0x44, 0xe9, 0x22, 0xee, 0x6f, 0x95, 0xc8, 0x33, - 0x4b, 0x77, 0xea, 0x6b, 0x2d, 0x2f, 0x4e, 0x82, 0xc6, 0x72, 0x2b, 0x6c, 0xdc, 0xad, 0x27, 0x61, - 0xe4, 0xdf, 0x0e, 0x5b, 0xdd, 0x03, 0xbf, 0xce, 0x7a, 0xe3, 0xbc, 0x42, 0x26, 0x0e, 0xd9, 0xef, - 0x8d, 0xd5, 0xf9, 0xd2, 0x33, 0xa5, 0x17, 0xab, 0xcb, 0x73, 0xdf, 0xf9, 0xde, 0xd3, 0x1f, 0xfb, - 0xfd, 0xef, 0x3d, 0x3d, 0x71, 0x5b, 0xc0, 0x41, 0x51, 0x38, 0x2f, 0x90, 0xb1, 0xdd, 0x78, 0xfb, - 0xa8, 0xe3, 0xcf, 0x97, 0x19, 0xed, 0x8c, 0xa0, 0x1d, 0x5b, 0xaf, 0x23, 0x14, 0x04, 0xd6, 0xb9, - 0x44, 0xaa, 0x1d, 0x2f, 0x4a, 0x82, 0x84, 0xf6, 0x7d, 0xbe, 0x42, 0x49, 0x47, 0x97, 0xcf, 0x08, - 0xd2, 0x6a, 0x4d, 0x22, 0x40, 0xd3, 0x60, 0x33, 0x22, 0xdf, 0x6b, 0xde, 0x6c, 0xb7, 0x8e, 0xe6, - 0x47, 0x28, 0xfd, 0x84, 0x6e, 0x06, 0x08, 0x38, 0x28, 0x0a, 0xf7, 0x9b, 0x65, 0x32, 0xb1, 0xb4, - 0xbb, 0x1b, 0xb4, 0x83, 0xe4, 0xc8, 0x79, 0x9f, 0x4c, 0xb5, 0xc3, 0xa6, 0x2f, 0x7f, 0xb3, 0x5e, - 0x4c, 0x5e, 0xb9, 0xb0, 0x78, 0xdc, 0xbc, 0x58, 0xbc, 0x61, 0x94, 0x58, 0x9e, 0xa3, 0xd5, 0x4c, - 0x99, 0x10, 0xb0, 0x38, 0x3a, 0xef, 0x91, 0xc9, 0x4e, 0xd8, 0x54, 0x15, 0x94, 0x59, 0x05, 0x2f, - 0x1d, 0x5f, 0x41, 0x4d, 0x17, 0x58, 0x9e, 0xa5, 0xfc, 0x27, 0x0d, 0x00, 0x98, 0xec, 0x9c, 0x16, - 0x99, 0xc5, 0x9f, 0xf4, 0xb3, 0xab, 0x1a, 0x2a, 0xac, 0x86, 0x8b, 0xf9, 0x35, 0x18, 0x85, 0x96, - 0xcf, 0xd2, 0x5a, 0x66, 0x53, 0x40, 0x48, 0xb3, 0x76, 0x3f, 0x24, 0x33, 0x4b, 0x49, 0xe2, 0x35, - 0xf6, 0xfd, 0x26, 0xff, 0xbe, 0xce, 0xeb, 0x64, 0xa4, 0xed, 0x1d, 0xf8, 0xe2, 0xeb, 0x3f, 0x23, - 0x86, 0x7d, 0xe4, 0x06, 0x85, 0x3d, 0xf8, 0xde, 0xd3, 0x73, 0xb7, 0xda, 0xc1, 0x07, 0x5d, 0x31, - 0x67, 0x10, 0x06, 0x8c, 0xda, 0xb9, 0x42, 0x48, 0xd3, 0x3f, 0x0c, 0x1a, 0x7e, 0xcd, 0x4b, 0xf6, - 0xc5, 0x6c, 0x70, 0x44, 0x59, 0xb2, 0xaa, 0x30, 0x60, 0x50, 0xb9, 0x3f, 0x56, 0x22, 0xd5, 0xa5, - 0xc3, 0x30, 0x68, 0xd2, 0x56, 0xc6, 0x4e, 0x97, 0xf6, 0x3b, 0xf2, 0x77, 0xfd, 0x48, 0x81, 0x68, - 0x13, 0x2a, 0xb4, 0xdf, 0x57, 0x72, 0xfa, 0x6d, 0x17, 0x5a, 0x6b, 0x27, 0xd1, 0xd1, 0xf2, 0xe3, - 0xa2, 0xea, 0xd9, 0x14, 0x16, 0xd2, 0x75, 0xb8, 0x3f, 0x53, 0x26, 0x8f, 0x2d, 0x7d, 0xd8, 0x8d, - 0xfc, 0xd5, 0x20, 0xbe, 0x9b, 0x5e, 0x0a, 0x4d, 0x0a, 0xbb, 0xa1, 0x07, 0x43, 0xcd, 0xc1, 0x55, - 0x01, 0x07, 0x45, 0xe1, 0x5c, 0x24, 0xe3, 0xf8, 0xff, 0x2d, 0xd8, 0x10, 0xbd, 0x3f, 0x2b, 0x88, - 0x27, 0x57, 0xbd, 0xc4, 0x5b, 0xe5, 0x28, 0x90, 0x34, 0xce, 0x16, 0x99, 0x6c, 0xd0, 0x51, 0x0f, - 0xda, 0x7b, 0x5b, 0x74, 0x6a, 0xb1, 0x2f, 0x5c, 0x5d, 0x7e, 0x19, 0xc9, 0x57, 0x34, 0x98, 0x8e, - 0xf7, 0x3c, 0x6f, 0x9b, 0x60, 0x61, 0xe0, 0xc0, 0x2c, 0xef, 0xb8, 0x6a, 0x21, 0x8e, 0x30, 0x4e, - 0x24, 0x63, 0x11, 0xbe, 0x68, 0xac, 0xa9, 0x51, 0xb6, 0xa6, 0xa6, 0xfa, 0xac, 0xa7, 0x7f, 0x5c, - 0x12, 0x63, 0xb2, 0x1e, 0xb4, 0x6c, 0xf1, 0x40, 0x3f, 0x73, 0xec, 0x37, 0x22, 0x3f, 0x31, 0x46, - 0x45, 0x7d, 0xe6, 0xba, 0xc2, 0x80, 0x41, 0x85, 0x8b, 0x3f, 0xde, 0xf7, 0x22, 0x36, 0x5b, 0xc4, - 0xd8, 0xa8, 0xc5, 0x5f, 0x97, 0x08, 0xd0, 0x34, 0xd6, 0xe2, 0xaf, 0xe4, 0x2e, 0xfe, 0x7f, 0x51, - 0x22, 0xe3, 0xcb, 0x41, 0xbb, 0x49, 0x87, 0xc2, 0xf9, 0x02, 0x99, 0x38, 0xf0, 0x13, 0xaf, 0x49, - 0x87, 0x4b, 0xac, 0xfb, 0x17, 0x8f, 0x9f, 0x3c, 0x37, 0x77, 0xbe, 0xe2, 0x37, 0x92, 0x2d, 0x5a, - 0x46, 0x77, 0x43, 0xc3, 0x40, 0x71, 0x73, 0x6e, 0x91, 0xb1, 0xc4, 0x8b, 0xf6, 0xfc, 0x44, 0x2c, - 0xf7, 0x8b, 0x45, 0xf8, 0x02, 0x4e, 0x35, 0xbf, 0xdd, 0xf0, 0xb5, 0x60, 0xdc, 0x66, 0x4c, 0x40, - 0x30, 0x73, 0x1b, 0x64, 0x6a, 0xc5, 0xeb, 0x78, 0x3b, 0x41, 0x8b, 0xca, 0x3d, 0x3f, 0x76, 0x3e, - 0x45, 0x2a, 0x5e, 0xb3, 0xc9, 0x26, 0x7e, 0x75, 0xf9, 0x31, 0x5a, 0xa0, 0xb2, 0xd4, 0x6c, 0xd2, - 0x69, 0x40, 0x14, 0xd5, 0x11, 0x20, 0x85, 0x73, 0x81, 0x8c, 0x34, 0xa3, 0xb0, 0x43, 0x5b, 0x83, - 0x94, 0xe7, 0x71, 0x85, 0xae, 0xd2, 0xdf, 0x29, 0x52, 0x46, 0xe3, 0xfe, 0x9b, 0x32, 0x71, 0x56, - 0xfc, 0xce, 0xfe, 0x7a, 0xdd, 0xfa, 0x96, 0x74, 0x3e, 0x1c, 0x84, 0x54, 0x08, 0x84, 0x51, 0x2c, - 0x2a, 0x64, 0xf3, 0x61, 0x4b, 0xc0, 0x40, 0x61, 0x9d, 0x67, 0xc8, 0x48, 0x47, 0x2f, 0xeb, 0x29, - 0x29, 0x12, 0xd8, 0x82, 0x66, 0x18, 0xa4, 0xe8, 0xc6, 0x7e, 0x24, 0xe6, 0xb1, 0xa2, 0xb8, 0x45, - 0x61, 0xc0, 0x30, 0x7a, 0xe6, 0xe0, 0x9c, 0x12, 0xb3, 0x34, 0x35, 0x73, 0x10, 0x03, 0x06, 0x95, - 0xf3, 0xc3, 0x74, 0xe6, 0xb0, 0x5f, 0x74, 0x20, 0xd9, 0x94, 0xcd, 0x15, 0x06, 0x9b, 0x61, 0xc3, - 0x6b, 0xa5, 0x07, 0x7f, 0x9a, 0xcd, 0x34, 0xc9, 0x08, 0x34, 0x4f, 0x6b, 0xa6, 0x8d, 0xe5, 0xce, - 0xb4, 0xbf, 0x51, 0xa2, 0xe3, 0x48, 0x67, 0x9a, 0x1f, 0x9d, 0xc2, 0x96, 0x39, 0xd8, 0x22, 0xf8, - 0x5d, 0x6c, 0x5a, 0x78, 0xd0, 0xa1, 0xaa, 0x45, 0x3b, 0x59, 0x09, 0xe9, 0x6a, 0x60, 0xdb, 0xe8, - 0xa7, 0xc9, 0x48, 0x82, 0x55, 0xf1, 0x66, 0xbd, 0x20, 0x3f, 0x0b, 0x56, 0x40, 0x67, 0xca, 0xf9, - 0xde, 0x12, 0xac, 0x09, 0xac, 0x8c, 0xf3, 0x36, 0x19, 0x8b, 0x13, 0x2f, 0xe9, 0xc6, 0xa2, 0xa1, - 0xcf, 0xca, 0x86, 0xd6, 0x19, 0x94, 0x96, 0x9f, 0x55, 0xc5, 0x38, 0x08, 0x44, 0x01, 0xe7, 0x25, - 0x32, 0x7e, 0xe0, 0xc7, 0xb1, 0xb7, 0x27, 0x05, 0xdb, 0xac, 0x28, 0x3b, 0xbe, 0xc5, 0xc1, 0x20, - 0xf1, 0xce, 0x27, 0xc9, 0xa8, 0x1f, 0x45, 0x61, 0x24, 0x66, 0xc4, 0xb4, 0x20, 0x1c, 0x5d, 0x43, - 0x20, 0x70, 0x9c, 0xfb, 0x9b, 0x25, 0x32, 0xab, 0xda, 0xca, 0xeb, 0x1a, 0xe2, 0x52, 0x6f, 0x12, - 0xd2, 0x90, 0x1d, 0x8b, 0xd9, 0x02, 0x9b, 0xbc, 0xf2, 0xea, 0xf1, 0xbc, 0x7b, 0x07, 0x52, 0xd7, - 0xa1, 0x40, 0x31, 0x18, 0x7c, 0xdd, 0xef, 0x94, 0xc8, 0xd9, 0x54, 0x9f, 0x36, 0x83, 0x38, 0x71, - 0xfe, 0x6c, 0x4f, 0xbf, 0x2e, 0x1d, 0x53, 0xb7, 0xa1, 0x51, 0x2e, 0x62, 0x71, 0xd6, 0x3d, 0x35, - 0x51, 0x24, 0xc4, 0xe8, 0x1c, 0x90, 0xd1, 0x20, 0xf1, 0x0f, 0x64, 0xbf, 0x2e, 0x16, 0xec, 0x17, - 0x6f, 0xa0, 0xfe, 0x3c, 0x1b, 0xc8, 0x03, 0x38, 0x2b, 0xf7, 0x7f, 0xd1, 0x7d, 0x9c, 0xf6, 0x72, - 0x37, 0xd8, 0xdb, 0xf2, 0x3a, 0x43, 0xfc, 0x30, 0x75, 0x2a, 0xf3, 0x90, 0x2b, 0x6f, 0xfa, 0xe5, - 0xbc, 0xa6, 0x8b, 0x06, 0x2d, 0xe2, 0xe6, 0xc9, 0xb5, 0x02, 0x25, 0x97, 0x10, 0x04, 0x8c, 0xd9, - 0xc2, 0x9b, 0xa4, 0xaa, 0x08, 0x9c, 0x39, 0x52, 0xb9, 0xeb, 0x73, 0x95, 0xb1, 0x0a, 0xf8, 0xaf, - 0x73, 0x8e, 0x8c, 0x1e, 0x7a, 0xad, 0xae, 0x58, 0xad, 0xc0, 0x7f, 0x7c, 0xba, 0xfc, 0x56, 0xc9, - 0xfd, 0xd5, 0x12, 0x39, 0xa7, 0x2a, 0xb9, 0xee, 0x1f, 0xd5, 0xfd, 0x16, 0x6d, 0x72, 0x18, 0x39, - 0x3f, 0x4e, 0x11, 0xad, 0x0c, 0x39, 0x24, 0x46, 0xe3, 0x24, 0x12, 0xec, 0x13, 0xa2, 0xe1, 0xe7, - 0xb2, 0xb0, 0x90, 0x59, 0x9b, 0xf3, 0x24, 0xef, 0x0b, 0x5f, 0xbc, 0x93, 0x82, 0x41, 0x85, 0x36, - 0x94, 0x75, 0x0c, 0x9b, 0x3f, 0xad, 0x9a, 0x7f, 0x1a, 0x33, 0x6f, 0xd3, 0x9e, 0x79, 0x9f, 0x2a, - 0xf8, 0xf9, 0xfa, 0xcc, 0xb9, 0xbf, 0x43, 0xd5, 0x36, 0x45, 0x63, 0x89, 0xe3, 0x47, 0x64, 0xf8, - 0x07, 0xeb, 0x2e, 0xfd, 0x2c, 0xdb, 0x21, 0xee, 0xa7, 0xd9, 0xdd, 0x75, 0x2e, 0x93, 0xc9, 0xa6, - 0xbf, 0xeb, 0x75, 0x5b, 0x89, 0x52, 0x17, 0x47, 0xb9, 0x1d, 0xb1, 0xaa, 0xc1, 0x60, 0xd2, 0xb8, - 0xbf, 0x51, 0x65, 0xab, 0x32, 0xf1, 0x02, 0x6a, 0x06, 0xe2, 0x06, 0x6d, 0x68, 0xf5, 0x53, 0xa6, - 0x56, 0x2f, 0x34, 0x78, 0x2a, 0x89, 0x83, 0x03, 0x14, 0xd9, 0x65, 0x5b, 0x12, 0x6f, 0x20, 0x10, - 0x38, 0xce, 0x79, 0x9e, 0x8c, 0x53, 0xd3, 0xf9, 0xc0, 0x6b, 0x37, 0x69, 0x1b, 0x50, 0x65, 0x98, - 0x44, 0xa9, 0xbe, 0xc2, 0x41, 0x20, 0x71, 0xce, 0x27, 0xc8, 0x08, 0xd5, 0x6f, 0x62, 0x2a, 0xd4, - 0x91, 0x66, 0x02, 0x6b, 0x5a, 0xa2, 0xbf, 0x81, 0x41, 0x51, 0x15, 0xb8, 0x17, 0x46, 0x77, 0xa9, - 0xc2, 0xb6, 0x1a, 0x44, 0x6c, 0x5f, 0x37, 0x54, 0x81, 0x3b, 0x0a, 0x03, 0x06, 0x95, 0x53, 0x23, - 0xa3, 0x9d, 0x30, 0x4a, 0x62, 0xba, 0x4d, 0xe3, 0x70, 0xbe, 0x9c, 0x3b, 0x7b, 0x78, 0xbf, 0x6b, - 0xb4, 0x8c, 0xee, 0x0a, 0xfe, 0xa2, 0x43, 0xca, 0x18, 0x39, 0x2b, 0xa4, 0xe2, 0xb7, 0x0f, 0xe7, - 0xc7, 0x19, 0xbf, 0xe7, 0x8e, 0xe7, 0xb7, 0xd6, 0x3e, 0xbc, 0xed, 0x45, 0x7a, 0x15, 0xd1, 0xdf, - 0x80, 0xa5, 0x9d, 0x06, 0xa9, 0x4a, 0x47, 0x40, 0x3c, 0x3f, 0x51, 0x64, 0x82, 0x81, 0x20, 0x07, - 0xff, 0x83, 0x6e, 0x10, 0xf9, 0x07, 0x54, 0xb8, 0xc6, 0x5a, 0x1f, 0x96, 0xd8, 0x18, 0x34, 0x5f, - 0x5a, 0xc9, 0x14, 0x57, 0x1f, 0xb6, 0xc2, 0x2e, 0xa5, 0x9e, 0xaf, 0xb2, 0x26, 0xe7, 0x18, 0x9c, - 0xb7, 0x75, 0x89, 0xe5, 0x73, 0x82, 0xfd, 0x94, 0x01, 0x8c, 0xc1, 0x62, 0x4a, 0x8d, 0xda, 0xe9, - 0x56, 0x70, 0xe8, 0xb7, 0xe9, 0xbe, 0x5c, 0x8b, 0xc2, 0x1d, 0x7f, 0x9e, 0xb0, 0xde, 0x7c, 0x32, - 0xcf, 0xf8, 0xa2, 0xa4, 0xcb, 0x67, 0x28, 0xef, 0xe9, 0x4d, 0xb3, 0x34, 0xd8, 0xcc, 0xa8, 0x26, - 0x37, 0x83, 0xba, 0x4a, 0xa0, 0xd9, 0x4f, 0x16, 0x67, 0xef, 0x50, 0xf6, 0x33, 0x60, 0x15, 0x87, - 0x14, 0x3b, 0x67, 0x9b, 0x54, 0x5b, 0xc1, 0xae, 0xdf, 0x38, 0x6a, 0x50, 0xed, 0x72, 0x8a, 0xf1, - 0xce, 0x59, 0x72, 0x9b, 0x92, 0x9c, 0xeb, 0x87, 0xea, 0x27, 0x68, 0x46, 0xce, 0x6d, 0x72, 0x3e, - 0xf1, 0xa3, 0x83, 0xa0, 0xed, 0xe1, 0xa6, 0x2d, 0x94, 0x17, 0x66, 0xe1, 0x4e, 0xb3, 0x59, 0xfb, - 0x94, 0x18, 0xd8, 0xf3, 0xdb, 0x99, 0x54, 0xd0, 0xa7, 0xb4, 0x73, 0x93, 0xcc, 0xb2, 0xf5, 0x54, - 0xeb, 0xb6, 0x5a, 0xb5, 0xb0, 0x15, 0x34, 0x8e, 0xe6, 0x67, 0x18, 0xc3, 0xe7, 0xa5, 0xdd, 0xba, - 0x61, 0xa3, 0x51, 0xaf, 0xd7, 0xbf, 0x20, 0x5d, 0x1a, 0x9d, 0x06, 0x54, 0xab, 0xed, 0x46, 0x54, - 0xe9, 0xc7, 0xb9, 0xef, 0xdf, 0x4f, 0xe6, 0x67, 0x8b, 0xd8, 0x29, 0x75, 0xbb, 0x10, 0x77, 0x1a, - 0xa4, 0x80, 0x90, 0x66, 0x8d, 0xa2, 0x22, 0x4e, 0xe8, 0xe8, 0xcf, 0xcf, 0x31, 0xc5, 0x54, 0xad, - 0xaf, 0x3a, 0x02, 0x81, 0xe3, 0x98, 0xd9, 0x87, 0xff, 0xdc, 0x44, 0xd9, 0x7b, 0x86, 0x11, 0x6a, - 0xb3, 0x4f, 0x22, 0x40, 0xd3, 0xe0, 0x86, 0x95, 0x24, 0x47, 0xf3, 0x0e, 0x23, 0x55, 0x4b, 0x6d, - 0x7b, 0xfb, 0x8b, 0x80, 0x70, 0x77, 0x87, 0xcc, 0xa8, 0x65, 0xcd, 0x46, 0xc7, 0x79, 0x9a, 0x8c, - 0xa2, 0xe4, 0x92, 0xd6, 0x4b, 0x15, 0x9b, 0x80, 0x02, 0x8d, 0x2e, 0x71, 0x06, 0x67, 0x4d, 0x08, - 0x3e, 0xf4, 0x97, 0x8f, 0x68, 0xaf, 0x99, 0x58, 0xab, 0x18, 0x4d, 0x90, 0x08, 0xd0, 0x34, 0xee, - 0xff, 0xe5, 0x9b, 0xa2, 0x96, 0x1d, 0x05, 0xe4, 0x26, 0x55, 0xd4, 0xf7, 0xc3, 0x38, 0x41, 0x6a, - 0x56, 0xc7, 0xa8, 0xde, 0x05, 0xaf, 0x09, 0x38, 0x28, 0x0a, 0xe7, 0x33, 0x64, 0xba, 0x61, 0x56, - 0x20, 0x44, 0xf9, 0x63, 0xa2, 0x88, 0x5d, 0x3b, 0xd8, 0xb4, 0xce, 0x5b, 0x64, 0x82, 0xb9, 0xf2, - 0x1a, 0x61, 0x4b, 0xe8, 0xcb, 0x72, 0x67, 0x9a, 0xa8, 0x09, 0xf8, 0x03, 0xe3, 0x7f, 0x50, 0xd4, - 0x68, 0x75, 0x60, 0x13, 0x36, 0x6a, 0x42, 0xdc, 0x2a, 0xab, 0xe3, 0x1a, 0x83, 0x82, 0xc0, 0xba, - 0xbf, 0x58, 0x36, 0x46, 0x19, 0x95, 0x3e, 0xdf, 0xf9, 0x21, 0x32, 0x7e, 0xcf, 0xa3, 0x4a, 0x6b, - 0x7b, 0x4f, 0xec, 0xa0, 0xaf, 0x15, 0x94, 0xbd, 0xac, 0xf8, 0x1d, 0x5e, 0x94, 0xef, 0x13, 0xe2, - 0x07, 0x48, 0x86, 0xc8, 0x3b, 0xea, 0xb6, 0xdb, 0xc8, 0xbb, 0x3c, 0x38, 0x6f, 0xe0, 0x45, 0x39, - 0x6f, 0xf1, 0x03, 0x24, 0x43, 0x67, 0x97, 0x10, 0xb9, 0xfa, 0xfc, 0xa6, 0x70, 0xa1, 0xfd, 0xc0, - 0x20, 0xec, 0xb7, 0x55, 0xe9, 0xe5, 0x19, 0xdc, 0x99, 0xf4, 0x6f, 0x30, 0x38, 0xbb, 0x5d, 0xa6, - 0x88, 0xf4, 0x36, 0x8b, 0x4a, 0x54, 0x3a, 0xb9, 0xbd, 0x88, 0xd2, 0x2c, 0x25, 0x62, 0xe8, 0x5e, - 0x2e, 0xa8, 0x50, 0x6d, 0x07, 0x07, 0xbe, 0xb9, 0x5a, 0x04, 0x17, 0xd0, 0x0c, 0xdd, 0x6f, 0x55, - 0xc8, 0x7c, 0xbf, 0xf6, 0xe2, 0x9c, 0xf4, 0xef, 0x07, 0xd4, 0x1a, 0x69, 0xf2, 0x99, 0x6b, 0xcc, - 0xc9, 0x35, 0x01, 0x07, 0x45, 0x81, 0x93, 0x23, 0x0e, 0xf6, 0xda, 0x5e, 0x4b, 0xcc, 0x5f, 0x35, - 0x39, 0xea, 0x0c, 0x0a, 0x02, 0x8b, 0x74, 0x54, 0xea, 0xc6, 0xc2, 0x85, 0x6b, 0x4c, 0x22, 0x60, - 0x50, 0x10, 0x58, 0xd3, 0xfc, 0x1b, 0xc9, 0x31, 0xff, 0xac, 0x31, 0x1a, 0x7d, 0xc8, 0x63, 0x44, - 0x77, 0x1d, 0x82, 0x6e, 0xce, 0x78, 0x9f, 0xb1, 0x1f, 0x1b, 0x9c, 0xbd, 0xd2, 0x4a, 0xd6, 0x15, - 0x1b, 0x30, 0x58, 0x3a, 0x6f, 0x90, 0x49, 0xb5, 0x42, 0xa9, 0xf5, 0x3f, 0x6e, 0x3b, 0xfe, 0xb4, - 0xb8, 0x5a, 0x05, 0x93, 0xce, 0xfd, 0x4a, 0x7a, 0xca, 0x88, 0x85, 0x61, 0x8c, 0x70, 0xa9, 0xe8, - 0x08, 0x97, 0x8f, 0x1f, 0x61, 0xf7, 0x3f, 0x57, 0xd0, 0x76, 0x36, 0x2a, 0xeb, 0xc6, 0x05, 0x84, - 0xda, 0xbb, 0x28, 0xe1, 0x69, 0xc3, 0xc4, 0xb2, 0x7c, 0x65, 0x90, 0x75, 0x63, 0xee, 0x07, 0xb8, - 0x1c, 0x38, 0x27, 0x67, 0x9f, 0xee, 0xd0, 0x5e, 0xcc, 0x2c, 0x49, 0x5f, 0x2c, 0xc7, 0xc1, 0xd8, - 0x6a, 0x2d, 0x9c, 0xb2, 0x31, 0x36, 0x5c, 0x5e, 0x8b, 0x66, 0x8e, 0xdb, 0x13, 0x6a, 0x07, 0xf2, - 0xe4, 0x40, 0x35, 0x07, 0x55, 0x88, 0x23, 0xe0, 0x38, 0x2a, 0x4b, 0xa7, 0xa8, 0x86, 0x85, 0x53, - 0x65, 0x05, 0x15, 0x20, 0x36, 0xf9, 0x46, 0xb5, 0xa6, 0x04, 0x06, 0x0e, 0x2c, 0x4a, 0xad, 0x28, - 0x8f, 0x1d, 0xa3, 0x28, 0xd3, 0x2f, 0xc4, 0xfe, 0x51, 0xb3, 0x42, 0x7d, 0xa1, 0x0d, 0x0e, 0x06, - 0x89, 0x4f, 0x4f, 0xa2, 0x89, 0x82, 0x93, 0xe8, 0x02, 0x99, 0x59, 0xf5, 0xfc, 0x83, 0xb0, 0xbd, - 0xd6, 0x6e, 0x76, 0xc2, 0x80, 0x36, 0x6c, 0x9e, 0x8c, 0xb0, 0x2d, 0x85, 0xaf, 0xf8, 0x11, 0xe4, - 0x00, 0x23, 0xa8, 0xec, 0xba, 0xff, 0x8f, 0xee, 0x6b, 0xab, 0xd4, 0x3e, 0x4d, 0xfc, 0x9b, 0x1d, - 0xe6, 0x7e, 0x70, 0xd6, 0x89, 0xb3, 0x17, 0x79, 0x0d, 0xbf, 0xe6, 0x47, 0x41, 0xd8, 0xa4, 0x3b, - 0x7e, 0xd8, 0x66, 0x0e, 0x77, 0xdc, 0x23, 0xd1, 0x9b, 0xe8, 0x5c, 0xed, 0xc1, 0x42, 0x46, 0x09, - 0xa7, 0x49, 0xa6, 0x3b, 0x91, 0x6f, 0xf9, 0x4b, 0x4a, 0xf9, 0xfa, 0x79, 0xcd, 0x2c, 0xc2, 0xd5, - 0x47, 0x0b, 0x04, 0x36, 0x53, 0xe7, 0x1d, 0x32, 0x17, 0x46, 0x9d, 0x7d, 0xaf, 0xbd, 0xea, 0x77, - 0xfc, 0x76, 0x13, 0x75, 0x66, 0xe1, 0x14, 0x3b, 0x47, 0xcb, 0xce, 0xdd, 0x4c, 0xe1, 0xa0, 0x87, - 0xda, 0xfd, 0x79, 0x6a, 0x2f, 0xae, 0x86, 0xf7, 0xda, 0xf7, 0xbc, 0xa8, 0xb9, 0x54, 0xdb, 0xe0, - 0x8a, 0x30, 0x73, 0x32, 0x4a, 0xe7, 0x66, 0xa9, 0xaf, 0x73, 0xf3, 0x4b, 0x64, 0x62, 0x37, 0xf0, - 0x5b, 0x4d, 0xf4, 0x42, 0xf2, 0xee, 0x5d, 0x2e, 0xe2, 0xd1, 0x58, 0xc7, 0x32, 0xd2, 0x2b, 0xc0, - 0x7d, 0xab, 0xeb, 0x82, 0x0d, 0x28, 0x86, 0x4e, 0x97, 0xcc, 0x49, 0x4d, 0x5f, 0x62, 0xc5, 0xea, - 0x78, 0xad, 0x98, 0x21, 0x61, 0x57, 0xc3, 0xc6, 0x03, 0x52, 0x0c, 0xa1, 0xa7, 0x0a, 0xb4, 0xd0, - 0x0e, 0x70, 0x77, 0x18, 0x61, 0x73, 0x85, 0x59, 0x68, 0xcc, 0x84, 0x64, 0x50, 0xf7, 0x1f, 0x94, - 0xc8, 0xe3, 0x3d, 0xa3, 0x25, 0xec, 0xeb, 0x2f, 0x48, 0xc3, 0x96, 0x9f, 0xce, 0xe4, 0xb4, 0x32, - 0x73, 0xcc, 0x8b, 0x19, 0xb9, 0xe5, 0x02, 0x46, 0xee, 0x4d, 0x72, 0x6e, 0xed, 0xa0, 0x93, 0x1c, - 0x51, 0x13, 0xd1, 0x6a, 0xe4, 0x9b, 0x64, 0xec, 0xc0, 0x6f, 0x06, 0xdd, 0x03, 0xf1, 0x59, 0x9f, - 0x96, 0x82, 0x74, 0x8b, 0x41, 0xa9, 0x96, 0x34, 0x8d, 0x67, 0x9f, 0x74, 0x01, 0x72, 0x00, 0x08, - 0x72, 0xf7, 0xfb, 0x25, 0x32, 0x2b, 0x17, 0xd4, 0x52, 0xb3, 0x49, 0xc7, 0x2d, 0x76, 0x16, 0x48, - 0x39, 0xe8, 0x08, 0x46, 0x44, 0x30, 0x2a, 0x53, 0xa5, 0x89, 0x42, 0xa9, 0x06, 0x53, 0xe5, 0xae, - 0x7c, 0x3d, 0x39, 0x06, 0x3c, 0x1a, 0x60, 0xd6, 0xc7, 0xb6, 0xe4, 0x01, 0x9a, 0x9d, 0xd4, 0x2c, - 0x99, 0xa8, 0xae, 0xd8, 0x8e, 0xe5, 0x6b, 0x02, 0x0e, 0x8a, 0x02, 0xdd, 0xf9, 0x78, 0x4a, 0xc9, - 0x4e, 0x59, 0xf8, 0xb6, 0xcb, 0xa6, 0xdc, 0x0d, 0x01, 0x03, 0x85, 0x75, 0x7f, 0xaa, 0x44, 0xa6, - 0x64, 0x1f, 0x0b, 0x2a, 0xb9, 0xb8, 0x48, 0xb4, 0x82, 0xab, 0x17, 0x09, 0x2a, 0xa9, 0x0c, 0x63, - 0xe9, 0xa6, 0x95, 0x41, 0x74, 0x53, 0xf7, 0x5b, 0x54, 0xe7, 0x94, 0xcd, 0xa9, 0x77, 0x77, 0x62, - 0x3f, 0x71, 0xbe, 0x4c, 0xaa, 0x1e, 0x1f, 0x7c, 0x5f, 0xce, 0xb3, 0x8b, 0x79, 0x16, 0xba, 0xf5, - 0xcd, 0xb4, 0x62, 0xb0, 0x24, 0xf9, 0x80, 0x66, 0xe9, 0x1c, 0x92, 0x33, 0xed, 0x30, 0x61, 0xfb, - 0x81, 0xc2, 0x17, 0xf3, 0x88, 0xa6, 0xeb, 0x79, 0x42, 0xd4, 0x73, 0xe6, 0x46, 0x9a, 0x1f, 0xf4, - 0x56, 0x41, 0xed, 0x3e, 0xe1, 0xc5, 0xa8, 0xb0, 0xba, 0x2e, 0x14, 0xab, 0xab, 0xbf, 0x13, 0xc3, - 0xfd, 0xb5, 0x12, 0xa9, 0x4a, 0xb2, 0x61, 0xfa, 0xc4, 0xef, 0x90, 0xf1, 0x98, 0x7d, 0x1a, 0x39, - 0x4c, 0xaf, 0x14, 0x6b, 0x3a, 0xff, 0x9e, 0x7a, 0xf3, 0xe3, 0xbf, 0x63, 0x90, 0xdc, 0x98, 0x1b, - 0x52, 0x75, 0xe0, 0xd1, 0x73, 0x43, 0xaa, 0xa6, 0xf5, 0x71, 0x43, 0xfe, 0xc3, 0x12, 0x19, 0xe3, - 0xce, 0xa1, 0x62, 0x1e, 0x36, 0xc3, 0x97, 0xac, 0x39, 0xde, 0x46, 0xa0, 0x70, 0x2d, 0xd3, 0x91, - 0xae, 0xb2, 0x7f, 0xd6, 0xa3, 0xf0, 0x40, 0x6c, 0x04, 0x17, 0x8a, 0x38, 0xa7, 0xb8, 0xe0, 0xe3, - 0xd2, 0xe4, 0xb6, 0x64, 0x00, 0x9a, 0x97, 0xfb, 0xab, 0x15, 0x5c, 0xf5, 0x9a, 0xd4, 0xda, 0xd6, - 0x4a, 0xa7, 0xb1, 0xad, 0x95, 0x87, 0xbf, 0xad, 0x7d, 0x40, 0x66, 0x1b, 0x86, 0x4f, 0x5e, 0x6f, - 0xa6, 0x57, 0x0a, 0xba, 0x9b, 0x0d, 0x47, 0x3e, 0x77, 0x86, 0xac, 0xd8, 0xec, 0x20, 0xcd, 0xdf, - 0xf1, 0xc9, 0x14, 0x3f, 0x50, 0x14, 0xf5, 0x8d, 0xe4, 0xce, 0x59, 0xee, 0x77, 0xe1, 0x25, 0x54, - 0x65, 0x2c, 0xe8, 0xa4, 0x6e, 0x30, 0x02, 0x8b, 0xad, 0xfb, 0xd7, 0x46, 0xc9, 0xe8, 0xda, 0x21, - 0xd5, 0x65, 0x86, 0xb8, 0xca, 0x0f, 0xc8, 0x4c, 0xd0, 0x3e, 0x0c, 0x5b, 0x87, 0x7e, 0x93, 0xe3, - 0x4f, 0xb6, 0xa3, 0x9d, 0x17, 0x95, 0xcc, 0x6c, 0x58, 0xcc, 0x20, 0xc5, 0x7c, 0x18, 0xf6, 0xe4, - 0xbb, 0xd4, 0x94, 0x65, 0x33, 0x42, 0x18, 0x93, 0x39, 0x4e, 0x52, 0x36, 0xa0, 0x62, 0xe5, 0x68, - 0xab, 0x97, 0xfb, 0x67, 0x05, 0x23, 0xe7, 0x2e, 0x99, 0xd9, 0x0d, 0x22, 0x6a, 0x71, 0x50, 0x83, - 0x90, 0x5a, 0x01, 0x07, 0x9d, 0x93, 0x18, 0x92, 0x6a, 0x48, 0xd6, 0x2d, 0x56, 0x90, 0x62, 0x4d, - 0x8d, 0xa4, 0x69, 0xb4, 0x63, 0x74, 0x5d, 0xe3, 0x83, 0xd7, 0xa5, 0x7c, 0x49, 0x9b, 0x26, 0x27, - 0xb0, 0x19, 0xa3, 0x30, 0x6a, 0x30, 0xc3, 0x67, 0x82, 0x6d, 0xe9, 0x4a, 0x18, 0x71, 0x8b, 0x87, - 0xe3, 0x50, 0xa6, 0xb1, 0xf3, 0xe3, 0xaa, 0x2d, 0xd3, 0xf4, 0x29, 0xb1, 0xfb, 0x0d, 0xdc, 0x80, - 0x70, 0x14, 0x4f, 0x43, 0x76, 0x5f, 0xb3, 0x65, 0xf7, 0x27, 0x0b, 0x7c, 0xdc, 0x3e, 0x72, 0xfb, - 0x7d, 0x32, 0x69, 0x7c, 0x7b, 0x74, 0x14, 0x36, 0xe4, 0x51, 0xa7, 0x10, 0xe0, 0x4a, 0x81, 0x50, - 0x67, 0xa0, 0xa0, 0x69, 0x70, 0x60, 0x50, 0xf1, 0x4a, 0x47, 0x44, 0xa0, 0x5a, 0x06, 0x0c, 0xe3, - 0xbe, 0x46, 0xc8, 0xda, 0x7d, 0xbf, 0xb1, 0xd4, 0x60, 0x07, 0xf1, 0xc6, 0xb9, 0x49, 0xa9, 0xff, - 0xb9, 0x89, 0xfb, 0x1e, 0xdd, 0x0c, 0xef, 0xe3, 0xce, 0x2e, 0xcd, 0x34, 0xba, 0x44, 0x7c, 0x06, - 0x60, 0xad, 0x9a, 0xd0, 0x93, 0x94, 0x93, 0x81, 0xc0, 0xb2, 0x63, 0xf4, 0xfb, 0x9e, 0x58, 0xb0, - 0x86, 0xc9, 0xbb, 0x86, 0x40, 0xe0, 0x38, 0xf7, 0xeb, 0x25, 0x32, 0xb3, 0xbe, 0x62, 0xe9, 0xc9, - 0x8b, 0x84, 0x70, 0x7d, 0xf3, 0xce, 0x9d, 0x1b, 0xd2, 0x8f, 0xca, 0x9d, 0x5d, 0x0a, 0x0a, 0x06, - 0x85, 0xf3, 0x04, 0xa9, 0xb4, 0xba, 0x6d, 0xa1, 0x06, 0x8e, 0xa3, 0x7f, 0x76, 0xb3, 0xdb, 0x06, - 0x84, 0x19, 0x81, 0x0d, 0x95, 0xc2, 0x81, 0x0d, 0xf9, 0xa1, 0x7d, 0x3f, 0x5b, 0x21, 0x73, 0xeb, - 0x2d, 0xff, 0xbe, 0xd5, 0x6a, 0x5a, 0x55, 0x33, 0x0a, 0xe8, 0xe4, 0x49, 0xbb, 0x49, 0x56, 0x19, - 0x14, 0x04, 0xb6, 0x70, 0xac, 0x85, 0x15, 0x67, 0x52, 0x19, 0x72, 0x9c, 0x49, 0x6e, 0x9f, 0x9d, - 0x5d, 0x32, 0x1e, 0xf2, 0xef, 0x4f, 0xa5, 0x18, 0x4e, 0xf4, 0xcf, 0x1c, 0xdf, 0x98, 0xf4, 0xf8, - 0x2c, 0x8a, 0xd9, 0xc3, 0x0f, 0xbd, 0x95, 0xb0, 0x14, 0x50, 0x90, 0xcc, 0x17, 0x3e, 0x4d, 0xa6, - 0x4c, 0xca, 0x81, 0x4e, 0xbf, 0xff, 0x42, 0x89, 0x9c, 0x5d, 0xc7, 0x10, 0xd2, 0x54, 0x30, 0xcc, - 0x1b, 0xd4, 0x86, 0xa3, 0x4b, 0x35, 0xb6, 0x22, 0xc4, 0xac, 0x50, 0x38, 0x81, 0x02, 0x93, 0xce, - 0x28, 0x76, 0xeb, 0xd6, 0xc6, 0x6a, 0x56, 0x04, 0x9d, 0x40, 0x81, 0x49, 0xe7, 0xfe, 0xc7, 0x12, - 0x79, 0xf2, 0xea, 0xca, 0x5a, 0x0d, 0xc5, 0x48, 0x9c, 0xd0, 0x85, 0xd9, 0x13, 0xc4, 0x47, 0xa7, - 0x40, 0xa7, 0x69, 0x34, 0x45, 0x4d, 0x81, 0xda, 0x2a, 0x6b, 0x85, 0xc0, 0x3e, 0x2a, 0x91, 0xac, - 0x54, 0x9f, 0x3c, 0x7b, 0x35, 0xa0, 0x73, 0xa6, 0x13, 0xa6, 0xe3, 0xee, 0x22, 0x0a, 0x8b, 0x31, - 0x1e, 0xeb, 0x28, 0x1d, 0x77, 0x07, 0x0a, 0x03, 0x06, 0x15, 0xaf, 0xf9, 0x30, 0x40, 0x01, 0x2b, - 0x3a, 0x65, 0xd4, 0xcc, 0xe1, 0xa0, 0x28, 0xb0, 0x63, 0xcd, 0x20, 0x62, 0xba, 0xc8, 0x91, 0x58, - 0xc1, 0xaa, 0x63, 0xab, 0x12, 0x01, 0x9a, 0xc6, 0xfd, 0x5b, 0x25, 0xf2, 0xd8, 0xd5, 0x56, 0x97, - 0x0e, 0x7b, 0xb4, 0x1b, 0x5b, 0x8d, 0x7d, 0x8d, 0x54, 0x7d, 0xa9, 0x37, 0x8b, 0xb6, 0xaa, 0x3d, - 0x49, 0x29, 0xd4, 0x3c, 0xe8, 0x4f, 0xd1, 0x15, 0x88, 0x31, 0x1b, 0x2c, 0x22, 0xea, 0x5f, 0x96, - 0xc9, 0xf4, 0xb5, 0xed, 0xed, 0xda, 0x55, 0x3f, 0x11, 0x32, 0x38, 0xdf, 0xd1, 0x53, 0x33, 0xac, - 0xdc, 0xc9, 0x2b, 0x8b, 0x7d, 0x56, 0x1d, 0xc6, 0x58, 0x2f, 0xf2, 0x18, 0xeb, 0xc5, 0x8d, 0x76, - 0x72, 0x33, 0xaa, 0x27, 0x11, 0x1e, 0x43, 0x64, 0x59, 0xc5, 0x72, 0x9f, 0xa8, 0xf4, 0xdb, 0x27, - 0xe8, 0x60, 0x8d, 0xc5, 0x8d, 0x7d, 0x5f, 0x19, 0xed, 0x1f, 0x57, 0x6a, 0x08, 0x83, 0x52, 0x9b, - 0xb9, 0x7a, 0x0b, 0x36, 0xf8, 0x0f, 0x10, 0xa4, 0x54, 0x60, 0x4d, 0xee, 0x27, 0x49, 0xe7, 0x1a, - 0xed, 0x2c, 0x9d, 0xfa, 0x42, 0x4a, 0xe4, 0x68, 0x81, 0x38, 0x18, 0xbc, 0x80, 0x5e, 0x58, 0x1a, - 0x16, 0x83, 0xc9, 0xd1, 0xad, 0x13, 0xa2, 0x71, 0x0f, 0xc9, 0xb4, 0x71, 0xff, 0x7c, 0x99, 0x8c, - 0x5f, 0xa3, 0xdb, 0x5c, 0x8b, 0xb2, 0x5c, 0x27, 0x23, 0x3e, 0xdd, 0x1e, 0x8b, 0x29, 0xb0, 0x7a, - 0x23, 0xe5, 0x9e, 0x2a, 0xfc, 0x0d, 0xac, 0xbc, 0x03, 0x64, 0x1c, 0xdb, 0x7d, 0x55, 0x05, 0x66, - 0xbe, 0x9c, 0x3f, 0x0a, 0x6a, 0x4a, 0xf0, 0x5d, 0x58, 0x80, 0x40, 0x32, 0x62, 0x3e, 0x9d, 0x46, - 0xa7, 0x8e, 0xc2, 0x2d, 0x29, 0x16, 0x7b, 0xbd, 0xbd, 0x52, 0xe3, 0xe4, 0x82, 0x2f, 0xf7, 0xe9, - 0x48, 0x20, 0x68, 0x76, 0xee, 0x5b, 0xe4, 0x1c, 0x3b, 0x15, 0xa4, 0xd3, 0xcd, 0x5a, 0x33, 0xb9, - 0x93, 0xd3, 0xfd, 0xbb, 0x65, 0x72, 0x66, 0xa3, 0xbe, 0x52, 0xb7, 0xbd, 0x71, 0x6f, 0x91, 0x29, - 0xbe, 0x3d, 0xe3, 0xa4, 0xf3, 0x5a, 0xa2, 0xbc, 0x72, 0x63, 0x6f, 0x1b, 0x38, 0xb0, 0x28, 0xf1, - 0xb8, 0x35, 0xf8, 0xa0, 0x9d, 0x8e, 0x0f, 0xda, 0x78, 0xf7, 0x06, 0x20, 0x1c, 0xd1, 0xb8, 0xd3, - 0x73, 0x11, 0xa7, 0xd0, 0x6a, 0xb7, 0xff, 0x1c, 0x35, 0x15, 0xe2, 0x46, 0x1c, 0xd0, 0x05, 0x40, - 0xd7, 0xbf, 0xd7, 0x90, 0xd3, 0x57, 0xeb, 0xfe, 0xd8, 0x54, 0x85, 0x85, 0x14, 0xb5, 0x21, 0x6f, - 0x47, 0x0b, 0x6b, 0x0b, 0xf9, 0x11, 0x9a, 0x5f, 0x21, 0x55, 0x15, 0x49, 0x23, 0x03, 0xa0, 0x4a, - 0xd9, 0x01, 0x50, 0x05, 0x04, 0x8e, 0xf4, 0x91, 0x56, 0x32, 0x7d, 0xa4, 0xff, 0x84, 0x6a, 0xbe, - 0x2a, 0x68, 0x80, 0xce, 0xc3, 0x2a, 0x15, 0xbc, 0x09, 0x3b, 0x86, 0x12, 0x93, 0xfa, 0xf9, 0x9c, - 0x99, 0xc8, 0x57, 0x02, 0x9f, 0x2b, 0x35, 0x59, 0x16, 0x34, 0x1b, 0x67, 0x93, 0x8c, 0x77, 0x22, - 0xbf, 0x9e, 0xb0, 0x30, 0xdf, 0x01, 0x38, 0xb2, 0x59, 0x5d, 0xe3, 0x25, 0x41, 0xb2, 0x70, 0x7f, - 0xb9, 0x44, 0xc8, 0x66, 0x70, 0x40, 0x37, 0x17, 0xaf, 0xbd, 0xe7, 0x0f, 0xd1, 0x8a, 0xbc, 0x41, - 0x46, 0xe2, 0x0e, 0x5d, 0xda, 0x85, 0x8e, 0x8e, 0x74, 0x8b, 0xea, 0xb4, 0x8c, 0xfe, 0x0c, 0xf8, - 0x0b, 0x18, 0x1f, 0xf7, 0x17, 0x08, 0x99, 0xd1, 0x64, 0xa8, 0xc6, 0x3b, 0x17, 0xad, 0xb8, 0xd6, - 0x27, 0x52, 0x71, 0xad, 0x55, 0x46, 0x6d, 0x84, 0xb2, 0x26, 0xa4, 0x72, 0xe0, 0xdd, 0x17, 0x56, - 0xc3, 0x1b, 0x45, 0x1b, 0x84, 0x35, 0x2d, 0x6e, 0x79, 0xf7, 0xb9, 0x1a, 0xf5, 0xb2, 0x9c, 0x40, - 0x14, 0xf2, 0x80, 0x1f, 0x10, 0xb1, 0x15, 0x88, 0x66, 0xca, 0x8f, 0xfd, 0x57, 0xfd, 0x9b, 0x09, - 0x45, 0xac, 0x8e, 0xd5, 0x1a, 0xb4, 0x85, 0xab, 0x6f, 0xc0, 0x5a, 0x83, 0x76, 0xba, 0xd6, 0xa0, - 0x5d, 0xa0, 0xd6, 0xa0, 0x8d, 0xe1, 0x6f, 0xe3, 0xc2, 0x43, 0xce, 0xc2, 0xaf, 0x26, 0xaf, 0xbc, - 0x3d, 0x50, 0xd5, 0xc2, 0xd5, 0xce, 0xab, 0xbf, 0x24, 0x75, 0x47, 0x01, 0xcd, 0x6d, 0x82, 0xac, - 0xda, 0xf9, 0x39, 0x6a, 0x6b, 0x88, 0xff, 0x31, 0xd2, 0x89, 0x1a, 0x9d, 0x62, 0x97, 0x7a, 0xe7, - 0x24, 0xad, 0x11, 0x2c, 0x78, 0xa3, 0x7e, 0x40, 0x8a, 0x18, 0x1b, 0x99, 0xdb, 0xb6, 0x54, 0x7b, - 0x9c, 0x6f, 0x96, 0xc8, 0x39, 0xfa, 0x9d, 0x78, 0x8d, 0x1c, 0x06, 0x78, 0xa0, 0x28, 0x42, 0xcc, - 0xd6, 0x07, 0x9d, 0x27, 0x3d, 0x8c, 0x78, 0x73, 0x3f, 0x2b, 0x8f, 0x2d, 0xb3, 0x48, 0x72, 0x1b, - 0x9d, 0xd9, 0xc2, 0x85, 0x26, 0x99, 0x90, 0x13, 0x33, 0x43, 0x6b, 0x5f, 0x36, 0x37, 0xe3, 0xe3, - 0x57, 0xa0, 0x74, 0xa0, 0x2d, 0xbe, 0xdb, 0xf5, 0xda, 0x09, 0x5e, 0x19, 0xd0, 0x3a, 0x3e, 0xab, - 0x45, 0x4c, 0xc4, 0x21, 0xd6, 0xb2, 0x4f, 0xa6, 0xcc, 0x39, 0x37, 0xc4, 0x9a, 0x42, 0x72, 0x36, - 0x63, 0x3e, 0x0d, 0xb1, 0xc2, 0x2e, 0x79, 0xa2, 0xef, 0xbc, 0x18, 0x5e, 0xb5, 0x78, 0x28, 0x60, - 0x08, 0xcc, 0xd3, 0x70, 0xcc, 0x6c, 0xd9, 0x8e, 0x99, 0x17, 0x8b, 0x2e, 0x9d, 0x3e, 0xde, 0x99, - 0x5d, 0xb3, 0xfd, 0xb8, 0x13, 0x38, 0xdb, 0x64, 0xac, 0x85, 0x10, 0x79, 0x1a, 0xf4, 0xca, 0x20, - 0x8b, 0x53, 0x2b, 0x17, 0x0c, 0x1e, 0x83, 0xe0, 0xe5, 0xfe, 0x4a, 0x89, 0x8c, 0x9c, 0xc6, 0xf0, - 0xd4, 0xec, 0xe1, 0xe9, 0xa7, 0xa2, 0x8a, 0xbb, 0x9e, 0x8b, 0xe0, 0xdd, 0x5b, 0xbb, 0x4f, 0xad, - 0xd9, 0x98, 0xa9, 0x92, 0x99, 0x23, 0xf4, 0xf3, 0x65, 0x32, 0x89, 0x15, 0x49, 0x3f, 0xd1, 0x67, - 0xd0, 0x6f, 0xb8, 0xe3, 0xb7, 0xa4, 0x3b, 0x39, 0x6d, 0x76, 0x6d, 0x9a, 0x48, 0xb0, 0x69, 0xb1, - 0xf0, 0xae, 0xe9, 0x6d, 0x17, 0x2a, 0x91, 0x2a, 0x6c, 0xb9, 0xe2, 0xc1, 0xa6, 0x45, 0xcd, 0xff, - 0x9e, 0x97, 0x34, 0xf6, 0x85, 0x49, 0xa6, 0x9a, 0x7b, 0x07, 0x81, 0xc0, 0x71, 0xce, 0x12, 0x99, - 0x95, 0x33, 0xf6, 0x36, 0x1f, 0x3a, 0xa1, 0x2e, 0xaa, 0x7b, 0x7a, 0x60, 0xa3, 0x21, 0x4d, 0xef, - 0x7c, 0x9a, 0xcc, 0xe0, 0xe0, 0x84, 0xdd, 0x44, 0x06, 0x2b, 0x8c, 0xb2, 0x60, 0x05, 0x16, 0x1c, - 0xba, 0x6d, 0x61, 0x20, 0x45, 0xe9, 0xfe, 0x30, 0x39, 0xbb, 0x19, 0x7a, 0xcd, 0x65, 0xaf, 0xe5, - 0xb5, 0x1b, 0x7e, 0xb4, 0xd1, 0xde, 0xcb, 0x3d, 0xd7, 0x35, 0xcf, 0x5e, 0xcb, 0x79, 0x67, 0xaf, - 0x6e, 0x44, 0x1c, 0xb3, 0x02, 0x11, 0x66, 0xf3, 0x1e, 0x19, 0x0f, 0x78, 0x55, 0x62, 0xd6, 0x5e, - 0xce, 0x73, 0x2a, 0xf5, 0xb4, 0xd1, 0x08, 0x1b, 0xe1, 0x00, 0x90, 0x2c, 0xd1, 0x92, 0xc8, 0xf2, - 0x42, 0xe5, 0x1b, 0x6b, 0xee, 0x5f, 0x2e, 0x91, 0xd9, 0x1b, 0xa9, 0xcb, 0x60, 0x18, 0x03, 0xe6, - 0x47, 0x19, 0x2e, 0xb5, 0x3a, 0x83, 0x82, 0xc0, 0x3e, 0x74, 0x33, 0xfd, 0x27, 0xcb, 0xa4, 0xca, - 0x62, 0x36, 0x3b, 0x5e, 0x63, 0x98, 0x4a, 0xe9, 0x96, 0xa5, 0x94, 0xe6, 0x18, 0x89, 0xaa, 0x41, - 0xfd, 0x74, 0x52, 0xbc, 0x0e, 0x28, 0x2e, 0x47, 0x15, 0xb2, 0x0f, 0x35, 0x43, 0x7e, 0x8f, 0x66, - 0xc6, 0xbe, 0x4b, 0x25, 0x2f, 0x4e, 0xb1, 0xd3, 0x50, 0x45, 0xfb, 0xe8, 0x9d, 0x86, 0xaa, 0xa6, - 0xf5, 0x91, 0x4a, 0x35, 0xa3, 0xf5, 0x4c, 0x6c, 0x7f, 0x9e, 0x05, 0xe0, 0x79, 0xad, 0xe0, 0x43, - 0x5f, 0x5d, 0x32, 0x7c, 0x5a, 0xc4, 0xd3, 0x09, 0xe8, 0x03, 0x26, 0x60, 0xc4, 0x2f, 0x7e, 0x77, - 0x54, 0x17, 0x71, 0xaf, 0xd1, 0x99, 0x6a, 0x8f, 0x9d, 0xf3, 0x06, 0x19, 0xed, 0xec, 0x7b, 0xb1, - 0x9f, 0x8a, 0xec, 0x18, 0xad, 0x21, 0x90, 0x72, 0x9b, 0x51, 0x05, 0x18, 0x04, 0x38, 0xb5, 0xfb, - 0x87, 0x54, 0xd6, 0x63, 0x2c, 0xc4, 0x10, 0xe7, 0xd8, 0x35, 0x6b, 0x8e, 0xbd, 0x90, 0x7f, 0xe3, - 0xbc, 0xef, 0xf4, 0xaa, 0xa5, 0xa6, 0xd7, 0x8b, 0x05, 0x78, 0x1d, 0x3f, 0xb3, 0x0e, 0xc8, 0x24, - 0xbb, 0xd1, 0x2e, 0x42, 0x5a, 0x5e, 0xb3, 0x0c, 0xa8, 0xa7, 0x53, 0x06, 0xd4, 0xac, 0x41, 0x6a, - 0x98, 0x51, 0x2f, 0x91, 0x71, 0x11, 0x42, 0x91, 0x8e, 0x3a, 0x14, 0xb4, 0x20, 0xf1, 0xee, 0x2f, - 0x55, 0x88, 0x75, 0x83, 0xde, 0xf9, 0x76, 0x89, 0x50, 0xa5, 0x85, 0x5d, 0x79, 0x68, 0xae, 0x76, - 0xd1, 0x5f, 0x86, 0x2e, 0xad, 0x66, 0xb7, 0x45, 0xff, 0xdb, 0xd8, 0x6b, 0x87, 0x0a, 0x8c, 0xbe, - 0x9d, 0x2e, 0xf3, 0xae, 0x16, 0xbe, 0xb8, 0xaf, 0xce, 0x50, 0xaf, 0xd0, 0xb6, 0x2c, 0xc2, 0x40, - 0xb5, 0xc0, 0x80, 0xad, 0x72, 0x7e, 0xbb, 0x44, 0x2e, 0xf1, 0x3b, 0xe4, 0xc5, 0x7b, 0x52, 0xc8, - 0xf0, 0xac, 0x49, 0xa6, 0x9a, 0x1d, 0x06, 0x39, 0x2e, 0xbf, 0x29, 0x06, 0xf9, 0x52, 0x6d, 0xb0, - 0x5a, 0x61, 0xd0, 0x66, 0xba, 0xff, 0xba, 0x42, 0xd7, 0x2f, 0x1d, 0x4f, 0x7d, 0x7f, 0xf4, 0x0d, - 0x6b, 0x9a, 0x3c, 0x9b, 0x9a, 0x26, 0x67, 0x2c, 0xe2, 0x87, 0x73, 0x75, 0x34, 0x21, 0x67, 0xf0, - 0x9c, 0xf2, 0x9a, 0xef, 0x45, 0xc9, 0x8e, 0xef, 0xb1, 0x03, 0x4b, 0xb1, 0x08, 0x06, 0x3a, 0x04, - 0x55, 0x71, 0x39, 0x9b, 0x69, 0x6e, 0xd0, 0x5b, 0x81, 0x73, 0x8f, 0x38, 0xec, 0x74, 0x34, 0xf2, - 0xa8, 0xd2, 0xc5, 0x3a, 0x13, 0x08, 0x87, 0xec, 0x80, 0xd5, 0x2e, 0x88, 0x6a, 0x9d, 0xcd, 0x1e, - 0x76, 0x90, 0x51, 0x85, 0x71, 0x04, 0x3e, 0x5a, 0xf4, 0x08, 0x7c, 0x2c, 0x27, 0xe0, 0xf7, 0x27, - 0x4a, 0xe4, 0x2c, 0x7e, 0x18, 0x3b, 0x38, 0x34, 0x76, 0x42, 0x32, 0x8b, 0x3d, 0x68, 0xf9, 0x89, - 0x84, 0x89, 0x15, 0x96, 0xa3, 0x4b, 0xdb, 0x7c, 0xb4, 0xc6, 0x76, 0xdd, 0x66, 0x06, 0x69, 0xee, - 0xee, 0x2f, 0x95, 0x08, 0x8b, 0x3e, 0x3b, 0x8d, 0x7d, 0xec, 0xaa, 0xbd, 0x8f, 0xb9, 0xf9, 0x42, - 0xa3, 0xcf, 0x16, 0xf6, 0x3a, 0x99, 0x43, 0x6c, 0x2d, 0x0a, 0xef, 0x1f, 0x49, 0xe5, 0x3a, 0xdf, - 0x37, 0xfb, 0x97, 0x4a, 0x5c, 0xdc, 0x29, 0xad, 0xf8, 0x1e, 0x06, 0x98, 0xe9, 0xdf, 0xb8, 0x90, - 0xa5, 0x12, 0xb8, 0x58, 0x5c, 0xa0, 0xb1, 0xf5, 0x6f, 0x44, 0x98, 0xa5, 0x18, 0x42, 0x6f, 0x1d, - 0xee, 0xdf, 0x2b, 0x91, 0xc7, 0x4d, 0x42, 0xe3, 0x9a, 0x59, 0x9e, 0x43, 0x74, 0x95, 0x4c, 0x84, - 0x1d, 0xcc, 0x18, 0xa3, 0x2c, 0x80, 0x17, 0xe5, 0x88, 0xdf, 0x14, 0x70, 0xba, 0x72, 0xcf, 0x99, - 0xdc, 0x25, 0x1c, 0x54, 0x49, 0xcc, 0x44, 0xc1, 0x2c, 0xd1, 0x58, 0x5c, 0x10, 0x64, 0x99, 0x28, - 0xd8, 0x31, 0x00, 0x5d, 0xe4, 0x1c, 0xe3, 0xfe, 0x95, 0x12, 0x1f, 0x65, 0xb3, 0xe9, 0xce, 0x57, - 0xc9, 0xdc, 0x01, 0x1a, 0x0b, 0x6b, 0xf7, 0x3b, 0xb8, 0x85, 0xb0, 0xe3, 0xcf, 0x52, 0x11, 0xc1, - 0xd9, 0xa7, 0xbb, 0xcb, 0xf3, 0xa2, 0xf5, 0x73, 0x5b, 0x29, 0xb6, 0xd0, 0x53, 0x91, 0xfb, 0x3b, - 0x62, 0xae, 0x32, 0xad, 0x85, 0x2e, 0xb6, 0x4e, 0xd8, 0x5c, 0xd9, 0x58, 0x05, 0x31, 0x56, 0x6a, - 0xb1, 0xd5, 0x38, 0x18, 0x24, 0x1e, 0xcf, 0xe5, 0x7c, 0x6a, 0xaa, 0x45, 0x54, 0x61, 0x51, 0xc7, - 0x96, 0x4a, 0x49, 0x58, 0x53, 0x18, 0x30, 0xa8, 0xb0, 0x4c, 0x27, 0x0a, 0x0f, 0x83, 0x26, 0x0b, - 0xf7, 0xae, 0xd8, 0x65, 0x6a, 0x0a, 0x03, 0x06, 0x15, 0x9a, 0x68, 0xdd, 0x76, 0xcc, 0x05, 0xb8, - 0xb7, 0x23, 0x12, 0x28, 0x4c, 0x68, 0x13, 0xed, 0x96, 0x89, 0x04, 0x9b, 0xd6, 0xfd, 0xcd, 0x2a, - 0x21, 0x5a, 0x45, 0x40, 0x0f, 0xe1, 0x44, 0xc3, 0xa3, 0x0a, 0x12, 0xcf, 0x8e, 0x53, 0xc9, 0xbf, - 0x17, 0xa3, 0x0b, 0x2f, 0xae, 0x88, 0x82, 0xdc, 0xb7, 0xf5, 0xaa, 0x9c, 0x20, 0x12, 0x9c, 0xeb, - 0xcf, 0x52, 0x35, 0x3b, 0x5f, 0x2b, 0x91, 0x49, 0xaf, 0x85, 0x77, 0x67, 0x13, 0xd6, 0xa3, 0x72, - 0x11, 0x67, 0xa5, 0xd1, 0x92, 0x25, 0x5d, 0x96, 0x37, 0xe6, 0x35, 0x79, 0xaa, 0x65, 0x60, 0x72, - 0xdb, 0x63, 0x36, 0xc1, 0x79, 0x55, 0xaa, 0x96, 0xfc, 0xa3, 0x2c, 0xa4, 0x55, 0xcb, 0x2a, 0x13, - 0x0d, 0x86, 0x56, 0x89, 0x37, 0x4c, 0x8c, 0xd8, 0xf7, 0x91, 0x22, 0x77, 0x53, 0xad, 0x4d, 0x33, - 0x2f, 0x4d, 0x00, 0x9e, 0x45, 0xe9, 0x48, 0xd8, 0xd1, 0x22, 0x17, 0x3f, 0x0d, 0xdd, 0x2d, 0x27, - 0x0a, 0x36, 0x21, 0xb3, 0x4d, 0x7b, 0x93, 0x10, 0xa1, 0x4d, 0x97, 0xf3, 0x6b, 0x48, 0xed, 0x2e, - 0x7a, 0x5b, 0x48, 0x21, 0x20, 0x5d, 0x05, 0xed, 0x11, 0x8b, 0x44, 0xde, 0x68, 0xef, 0x86, 0x22, - 0xba, 0xe9, 0x95, 0x02, 0xdf, 0xfc, 0x28, 0xa6, 0xe2, 0x19, 0xcb, 0xe8, 0x6d, 0xe0, 0x86, 0xe0, - 0x02, 0x8a, 0x1f, 0xba, 0x89, 0xd8, 0xad, 0x0a, 0xbc, 0x8b, 0x5b, 0x19, 0xe0, 0x82, 0x09, 0xbb, - 0x93, 0xa1, 0x37, 0x5f, 0xf6, 0x93, 0x8a, 0x2b, 0xce, 0x8b, 0xea, 0xf5, 0xe2, 0xaa, 0x6c, 0xbc, - 0xd1, 0xbe, 0x15, 0xfb, 0xec, 0xfe, 0x6d, 0x75, 0xf9, 0x39, 0x7d, 0xa1, 0x96, 0xc3, 0x33, 0xb3, - 0x23, 0x59, 0x25, 0x71, 0x0f, 0x16, 0xbf, 0x65, 0xd2, 0xa5, 0x79, 0x52, 0xa4, 0xa1, 0x76, 0x8a, - 0x26, 0x3d, 0xd8, 0xb7, 0x6d, 0x66, 0x90, 0xe6, 0xbe, 0x10, 0x90, 0x69, 0x6b, 0xc5, 0x0e, 0xd1, - 0xd9, 0xd9, 0x22, 0x73, 0xe9, 0x25, 0x39, 0x44, 0x1f, 0xe7, 0x1f, 0x8c, 0x90, 0x19, 0x7b, 0x62, - 0x60, 0x04, 0xc3, 0x01, 0x4b, 0x89, 0xa4, 0x13, 0xb1, 0xa8, 0xf9, 0xbf, 0x25, 0x11, 0xa0, 0x69, - 0x58, 0x4a, 0x1a, 0x56, 0xdc, 0x88, 0x39, 0xd1, 0x29, 0x69, 0x14, 0x06, 0x0c, 0x2a, 0x54, 0xd8, - 0x76, 0xc2, 0x30, 0x51, 0x82, 0x5b, 0xcd, 0x99, 0x65, 0x06, 0x05, 0x81, 0x45, 0x81, 0x7d, 0x17, - 0x3b, 0xd4, 0xb2, 0xfd, 0x5d, 0x4a, 0x60, 0x5f, 0x37, 0x91, 0x60, 0xd3, 0xe2, 0x06, 0x14, 0xc6, - 0x6c, 0x12, 0x0a, 0xb5, 0x50, 0xc7, 0xf0, 0xd4, 0xf9, 0x2d, 0x23, 0x89, 0x77, 0xbe, 0x48, 0x1e, - 0x57, 0x97, 0x82, 0x80, 0xfb, 0x0f, 0x65, 0x8d, 0x63, 0x96, 0x6d, 0xf7, 0xf8, 0x4a, 0x36, 0x19, - 0xf4, 0x2b, 0x8f, 0x47, 0xbc, 0x42, 0xa5, 0x93, 0x1c, 0xc7, 0xed, 0x23, 0xde, 0xeb, 0x16, 0x16, - 0x52, 0xd4, 0x54, 0x9f, 0x98, 0x43, 0x08, 0x53, 0xa5, 0x24, 0x07, 0x7e, 0xb9, 0x49, 0xed, 0xcc, - 0xd7, 0x53, 0x78, 0xe8, 0x29, 0x81, 0xae, 0x43, 0xae, 0x5b, 0xa0, 0x05, 0xc3, 0xbe, 0x83, 0x88, - 0x46, 0x54, 0x8b, 0xe0, 0xa6, 0x8d, 0x86, 0x34, 0x3d, 0x9e, 0x91, 0x7b, 0x11, 0xfd, 0xe8, 0x09, - 0x55, 0x11, 0xba, 0x11, 0xbf, 0xd9, 0x6e, 0x9c, 0x91, 0x2f, 0x19, 0x38, 0xb0, 0x28, 0xdd, 0x0f, - 0xc9, 0xd9, 0x8c, 0xa0, 0x67, 0x9c, 0x38, 0x74, 0x82, 0xca, 0x3e, 0xa5, 0xa2, 0x71, 0xf0, 0xa6, - 0x8b, 0xe8, 0x8d, 0x41, 0x85, 0xb3, 0x93, 0x39, 0x4e, 0x8d, 0xfc, 0x68, 0x6a, 0x76, 0xae, 0x4b, - 0x04, 0x68, 0x1a, 0xf7, 0x7f, 0xd0, 0x5d, 0x5b, 0xbb, 0x19, 0x0a, 0xc4, 0x60, 0xd0, 0x6e, 0xca, - 0x94, 0x7f, 0x46, 0xaa, 0x2d, 0xd5, 0xcd, 0xab, 0x06, 0x0e, 0x2c, 0x4a, 0x6c, 0x5b, 0x5b, 0x3a, - 0x4d, 0xd2, 0xb1, 0x3f, 0xca, 0x9b, 0x02, 0x9a, 0x06, 0x7d, 0x7c, 0xb1, 0xdf, 0xda, 0xdd, 0x0c, - 0xda, 0x77, 0xc5, 0xc4, 0x56, 0x52, 0xb9, 0x2e, 0xe0, 0xa0, 0x28, 0x9c, 0x77, 0x48, 0xa5, 0x1b, - 0x34, 0xc5, 0x54, 0x5e, 0x94, 0x7a, 0x27, 0x5d, 0x4d, 0x54, 0x62, 0x3e, 0x9d, 0x9d, 0xc7, 0x10, - 0xcd, 0xc8, 0x78, 0x11, 0x17, 0x1f, 0x16, 0xcd, 0xf2, 0x1f, 0x8f, 0x0d, 0xe8, 0x3f, 0xa6, 0xdf, - 0x4c, 0xf4, 0x59, 0xce, 0xe4, 0x8a, 0xfe, 0x66, 0x57, 0x15, 0x06, 0x0c, 0x2a, 0x34, 0x46, 0x1b, - 0xd4, 0x00, 0x93, 0xd6, 0x1a, 0x8f, 0xc8, 0x9d, 0xf8, 0x08, 0xc6, 0xe8, 0x4a, 0x9a, 0x1b, 0xf4, - 0x56, 0xe0, 0x74, 0xc8, 0x99, 0x26, 0xae, 0x23, 0xab, 0xd6, 0xea, 0x09, 0xe2, 0x80, 0xb1, 0xc6, - 0xd5, 0x34, 0x27, 0xe8, 0x65, 0xee, 0x7c, 0x99, 0x2c, 0x48, 0x60, 0xef, 0xb5, 0x3f, 0xb6, 0x5c, - 0x2a, 0xcb, 0x4f, 0x51, 0x6e, 0x0b, 0xab, 0x7d, 0xa9, 0xe0, 0x18, 0x0e, 0xce, 0x7b, 0x64, 0x8c, - 0x9d, 0x38, 0xc4, 0xf3, 0x93, 0x6c, 0xb7, 0x7b, 0xbd, 0xa8, 0xc3, 0x6d, 0x91, 0x9d, 0x5b, 0x88, - 0x40, 0x46, 0x7d, 0x8a, 0xc3, 0x80, 0x20, 0x78, 0xd2, 0xf1, 0x9a, 0xf4, 0xda, 0xed, 0x30, 0xf1, - 0xb8, 0x12, 0x36, 0x55, 0x44, 0x8f, 0x34, 0xaa, 0x58, 0xd2, 0x65, 0x79, 0x3d, 0x2a, 0x3a, 0xca, - 0xc0, 0x80, 0x59, 0x05, 0x6e, 0xe3, 0xe1, 0x3d, 0x14, 0x98, 0xd2, 0xe9, 0x1e, 0xcf, 0x4f, 0x17, - 0xd9, 0xc6, 0x6f, 0x5a, 0x85, 0x0c, 0x09, 0x66, 0x33, 0x83, 0x34, 0x77, 0x0c, 0xd3, 0x35, 0xfc, - 0xa8, 0x33, 0x3a, 0x4c, 0x57, 0xfb, 0x51, 0x4d, 0xb7, 0x29, 0xbb, 0x52, 0xca, 0x43, 0xf3, 0x98, - 0x24, 0x98, 0x4d, 0x5d, 0x29, 0xd5, 0x28, 0x30, 0xe9, 0x16, 0xde, 0x26, 0x93, 0xc6, 0x80, 0x0f, - 0x12, 0x0f, 0xba, 0xf0, 0x39, 0xba, 0xfb, 0xa7, 0x06, 0x72, 0xa0, 0x78, 0xd2, 0xff, 0x59, 0x26, - 0xb3, 0x19, 0x27, 0x19, 0x77, 0x03, 0x16, 0x31, 0x6d, 0x89, 0xbc, 0xeb, 0x14, 0x06, 0x0c, 0x63, - 0x0b, 0xae, 0x72, 0x01, 0xc1, 0x25, 0xa5, 0x68, 0xa5, 0xaf, 0x14, 0x15, 0xc2, 0x6a, 0xe4, 0xe4, - 0xc2, 0xca, 0xde, 0x1d, 0x46, 0x0b, 0xed, 0x0e, 0x0f, 0x41, 0xc0, 0x59, 0x1b, 0xcc, 0x78, 0x81, - 0x0d, 0xe6, 0x41, 0x89, 0xcc, 0xd8, 0x33, 0xaf, 0xc0, 0x88, 0x3f, 0xaa, 0x03, 0xb8, 0xc8, 0x0c, - 0xb1, 0x24, 0x0a, 0x5b, 0x2d, 0x3f, 0x12, 0x91, 0x62, 0x33, 0xc2, 0xae, 0x12, 0x50, 0x30, 0x28, - 0xdc, 0x9f, 0x2b, 0x93, 0x39, 0x1d, 0x36, 0x2c, 0x52, 0x9f, 0x0e, 0xef, 0x68, 0x60, 0xdb, 0x3a, - 0x1a, 0xc8, 0xcb, 0x68, 0x9a, 0x6a, 0x57, 0xdf, 0x63, 0x82, 0xf7, 0x52, 0xc7, 0x04, 0xaf, 0x0f, - 0xc8, 0xf7, 0xf8, 0x23, 0x83, 0x7f, 0x5a, 0x26, 0x8f, 0xa5, 0x8b, 0xac, 0xb4, 0xbc, 0xe0, 0x60, - 0x88, 0xe3, 0xf4, 0x45, 0x6b, 0x9c, 0xde, 0x1c, 0xac, 0x3f, 0xac, 0x71, 0x7d, 0x07, 0xcb, 0x4b, - 0x0d, 0xd6, 0xdb, 0x27, 0x61, 0x7e, 0xfc, 0x88, 0xfd, 0xa7, 0x12, 0x79, 0x22, 0xb3, 0xdc, 0x69, - 0xb8, 0x40, 0xbf, 0x60, 0xbb, 0x40, 0x5f, 0x3b, 0x41, 0xf7, 0xfa, 0xf8, 0x44, 0xff, 0x5b, 0xb9, - 0x4f, 0xb7, 0x98, 0xb7, 0xec, 0x26, 0xdd, 0x7e, 0x1b, 0x74, 0x93, 0x8a, 0x31, 0x36, 0x52, 0x1e, - 0xf2, 0x5d, 0x64, 0xfb, 0xa7, 0x06, 0xd3, 0xb5, 0xbf, 0x90, 0x66, 0xa1, 0xd1, 0x60, 0x72, 0xb0, - 0x73, 0x6a, 0x95, 0x87, 0x94, 0x53, 0x8b, 0xca, 0x98, 0x43, 0x65, 0xa5, 0xa7, 0x9d, 0x70, 0x86, - 0xfd, 0x6e, 0x50, 0x51, 0x35, 0x09, 0x75, 0x5a, 0x1e, 0x22, 0x31, 0x92, 0xbb, 0xe0, 0xac, 0x0f, - 0x68, 0xc6, 0x5b, 0xf0, 0x3b, 0x93, 0xca, 0x63, 0xa9, 0x78, 0xba, 0xdf, 0xa8, 0x90, 0x8f, 0x1f, - 0x33, 0xed, 0xe8, 0x26, 0x61, 0x9d, 0x7c, 0xbe, 0x9c, 0x76, 0x4f, 0x2d, 0x64, 0x16, 0xb6, 0xfc, - 0x55, 0xa9, 0x8f, 0x55, 0xfe, 0xc8, 0x1f, 0xeb, 0x67, 0x4d, 0x67, 0x22, 0x0f, 0x75, 0xbc, 0x7a, - 0xe2, 0x85, 0xf5, 0xf0, 0xbc, 0x8b, 0xa7, 0xe8, 0xf8, 0xc0, 0x34, 0xd6, 0xcf, 0x66, 0x76, 0xca, - 0x0a, 0xb0, 0xc0, 0x2b, 0x66, 0x08, 0x34, 0xee, 0xa2, 0xe8, 0x2b, 0x66, 0x12, 0x01, 0x9a, 0xc6, - 0x8a, 0xa3, 0x28, 0xe7, 0xc6, 0x51, 0xfc, 0xbb, 0x12, 0x39, 0x97, 0x6e, 0xc4, 0x69, 0x48, 0x9d, - 0xba, 0x2d, 0x75, 0x16, 0x07, 0xfb, 0xf6, 0x7d, 0x04, 0xce, 0xcf, 0x4c, 0x91, 0xf3, 0x3d, 0x9b, - 0x15, 0x1f, 0xc6, 0x1f, 0x2d, 0x91, 0x33, 0x7b, 0xcc, 0xbe, 0x30, 0x6e, 0xfc, 0x88, 0x8e, 0xe5, - 0x5c, 0x93, 0x3a, 0xf6, 0xa2, 0x10, 0xb7, 0x96, 0x7a, 0x48, 0xa0, 0xb7, 0x32, 0xe7, 0xa7, 0xe8, - 0x50, 0x7b, 0xf7, 0xe2, 0x9e, 0x3c, 0xfa, 0x62, 0x1e, 0x7d, 0x2e, 0xc7, 0x95, 0x97, 0x93, 0x81, - 0x7f, 0x79, 0x1e, 0x63, 0x45, 0xb3, 0xa8, 0x20, 0xb3, 0x56, 0xaa, 0x04, 0xf0, 0xec, 0x62, 0xa8, - 0xf6, 0x15, 0xba, 0xbb, 0x96, 0x75, 0xff, 0x80, 0xcb, 0x24, 0x89, 0x01, 0xc5, 0xd1, 0x79, 0x9f, - 0x54, 0xf7, 0xe4, 0x25, 0x1f, 0x21, 0xf4, 0x72, 0x76, 0x96, 0xcc, 0x3b, 0x41, 0x3c, 0xca, 0x5d, - 0xa1, 0x40, 0x33, 0x75, 0xae, 0x91, 0x4a, 0x7b, 0x37, 0x16, 0xf7, 0x75, 0xf3, 0xe2, 0x68, 0xec, - 0xa8, 0x25, 0x7e, 0x03, 0x91, 0x02, 0x01, 0x59, 0x20, 0xa7, 0x68, 0xa7, 0x29, 0x7c, 0xd8, 0x39, - 0x9c, 0x60, 0x79, 0xb5, 0x97, 0x13, 0x05, 0x02, 0xb2, 0x60, 0x01, 0x7b, 0x78, 0x5f, 0x41, 0x38, - 0xa8, 0x73, 0x2e, 0x73, 0xf7, 0xdc, 0xca, 0xe0, 0xa9, 0xe8, 0x18, 0x18, 0x38, 0x23, 0xf4, 0x4c, - 0x37, 0x58, 0xea, 0x68, 0xe1, 0x3f, 0xc8, 0x4b, 0x28, 0xdc, 0x93, 0x66, 0x9a, 0x1f, 0xa4, 0x71, - 0x38, 0x08, 0x5e, 0x8c, 0xab, 0xdf, 0xd9, 0xdf, 0x8d, 0x85, 0x7f, 0x20, 0x8f, 0x6b, 0x4f, 0x12, - 0x70, 0xc1, 0x95, 0xc1, 0x41, 0xf0, 0x72, 0x56, 0x49, 0x79, 0xb7, 0x21, 0xf2, 0x3f, 0xe6, 0x58, - 0xb4, 0xf6, 0x75, 0xd2, 0xe5, 0x31, 0x8c, 0xa0, 0x5b, 0x5f, 0x01, 0x5a, 0x9e, 0xea, 0x23, 0xe3, - 0xbb, 0xfc, 0x82, 0xa0, 0xc8, 0xf5, 0x78, 0x39, 0xef, 0x16, 0x63, 0xcf, 0x6d, 0x42, 0x7e, 0x93, - 0x41, 0x20, 0x40, 0xb2, 0xa3, 0xfb, 0x30, 0xd9, 0x55, 0x57, 0x1e, 0x45, 0xb2, 0xc7, 0xc5, 0xc1, - 0xae, 0x48, 0x0a, 0xeb, 0x59, 0x41, 0xc1, 0xe0, 0x88, 0x73, 0xde, 0x93, 0xd9, 0xef, 0x59, 0xa2, - 0xc7, 0xdc, 0x39, 0x9f, 0x99, 0x2c, 0x9f, 0xcf, 0x79, 0x85, 0x02, 0xcd, 0xd4, 0xe9, 0x92, 0xe9, - 0xc3, 0xb8, 0xb3, 0xef, 0xcb, 0xa5, 0xcf, 0xb2, 0x3f, 0x4e, 0x5e, 0xf9, 0x6c, 0x4e, 0x4a, 0x4f, - 0x51, 0x24, 0x88, 0x92, 0xae, 0xd7, 0xea, 0x91, 0x60, 0x2c, 0x8d, 0xd2, 0x6d, 0x93, 0x2d, 0xd8, - 0xb5, 0xe0, 0x27, 0xf9, 0xa0, 0x1b, 0xee, 0x1c, 0x25, 0xbe, 0xc8, 0x0e, 0x99, 0xf3, 0x49, 0xde, - 0xe5, 0xc4, 0xbd, 0x9f, 0x44, 0x20, 0x40, 0xb2, 0x53, 0x43, 0xc6, 0xa4, 0xf1, 0x5c, 0xe1, 0x21, - 0xeb, 0xe9, 0x83, 0x1e, 0x32, 0x26, 0x7d, 0x35, 0x53, 0xf7, 0x77, 0x46, 0x7b, 0x37, 0x38, 0xa6, - 0x7f, 0xfe, 0x74, 0xef, 0x71, 0xe6, 0x3b, 0x83, 0xdb, 0x57, 0x0f, 0xf1, 0x60, 0x93, 0xee, 0x0f, - 0xe7, 0x3b, 0x99, 0xbb, 0x97, 0xd8, 0x21, 0x06, 0x35, 0xd3, 0xf8, 0xd0, 0xa8, 0x5c, 0xa3, 0xd9, - 0x78, 0xe8, 0x53, 0x67, 0x5a, 0xe5, 0xab, 0x7c, 0x64, 0x95, 0xef, 0x0e, 0x1d, 0x6f, 0xd4, 0x52, - 0x74, 0xb2, 0x8b, 0x01, 0xf3, 0x43, 0xb0, 0xbd, 0x66, 0x45, 0xb0, 0x00, 0xc5, 0x0c, 0x07, 0xee, - 0xc9, 0x74, 0x27, 0xc0, 0x67, 0x68, 0x91, 0x24, 0x95, 0xfb, 0x02, 0xd6, 0xc5, 0x48, 0x3c, 0x59, - 0x3b, 0x8e, 0xf8, 0x41, 0x1e, 0x01, 0x1c, 0x5f, 0xd9, 0x69, 0xaa, 0x90, 0xff, 0xa8, 0x94, 0xa1, - 0xf0, 0x70, 0xa5, 0xff, 0xb3, 0xb6, 0xd2, 0xff, 0x42, 0x5a, 0xe9, 0xef, 0x31, 0xd1, 0x2d, 0x7d, - 0xbf, 0x78, 0xa2, 0xc0, 0xa2, 0xd9, 0x38, 0xdc, 0xff, 0x53, 0x22, 0x95, 0x5a, 0xd8, 0x1c, 0xa2, - 0x13, 0xe0, 0xaa, 0xe5, 0x04, 0x78, 0x3e, 0xf7, 0xd9, 0x9b, 0xbe, 0x26, 0xff, 0xcd, 0x94, 0xc9, - 0xff, 0xa9, 0x7c, 0x56, 0xc7, 0x1b, 0xf8, 0xdf, 0xac, 0x10, 0xf3, 0xe1, 0x1e, 0xe7, 0x37, 0x4e, - 0x12, 0xd5, 0x58, 0x29, 0xf6, 0x96, 0x8f, 0xa8, 0x83, 0xc5, 0x00, 0xc9, 0x2b, 0x4f, 0x7f, 0x6c, - 0x83, 0x1b, 0xef, 0xf8, 0xc1, 0xde, 0x7e, 0xe2, 0x37, 0xd3, 0x1d, 0x3b, 0xbd, 0xe0, 0xc6, 0xff, - 0x5e, 0x22, 0xb3, 0xa9, 0xda, 0x9d, 0x83, 0xac, 0x5b, 0x13, 0x27, 0xb5, 0xea, 0xcf, 0xe4, 0xde, - 0xb3, 0x58, 0x24, 0x44, 0x79, 0xa2, 0xa5, 0xed, 0xcd, 0xf4, 0x10, 0xe5, 0xaa, 0x8e, 0xc1, 0xa0, - 0x40, 0x2f, 0x7e, 0x12, 0x76, 0xc2, 0x56, 0xb8, 0x77, 0x74, 0xdd, 0x97, 0x97, 0xf2, 0x95, 0x17, - 0x7f, 0x5b, 0xa3, 0xc0, 0xa4, 0xc3, 0x44, 0x4f, 0xe9, 0x77, 0x9f, 0xfe, 0x74, 0xa2, 0xfe, 0xf1, - 0x99, 0xa8, 0xbf, 0x55, 0x22, 0x73, 0x58, 0x3b, 0x0b, 0xe1, 0x90, 0x21, 0x88, 0x2a, 0xe3, 0x76, - 0xe9, 0x98, 0x8c, 0xdb, 0x78, 0x87, 0x23, 0x69, 0x86, 0x5d, 0x99, 0x05, 0xc6, 0x90, 0x62, 0x08, - 0x05, 0x81, 0x15, 0x74, 0xb4, 0x4d, 0xe2, 0x7e, 0x86, 0x49, 0x47, 0xa1, 0x20, 0xb0, 0x32, 0x21, - 0xf7, 0x48, 0x76, 0x42, 0x6e, 0x9e, 0x34, 0x47, 0x84, 0x0e, 0x88, 0x9d, 0xd9, 0x48, 0x9a, 0x23, - 0x63, 0x0a, 0x34, 0x8d, 0xfb, 0xcf, 0x2b, 0x64, 0x0a, 0x23, 0xe8, 0x54, 0x78, 0xf1, 0xeb, 0x56, - 0x78, 0xf1, 0x33, 0xa9, 0xf0, 0xe2, 0x39, 0x93, 0xf6, 0xe1, 0x44, 0x17, 0x8b, 0xf4, 0x4a, 0x2c, - 0x65, 0xfc, 0x49, 0x23, 0x8b, 0xad, 0xf4, 0x4a, 0x8a, 0x13, 0xd8, 0x8c, 0xff, 0x44, 0x45, 0x14, - 0xff, 0x61, 0x89, 0xcc, 0xd0, 0x6f, 0x81, 0x53, 0xf4, 0x4f, 0xd2, 0x7c, 0x34, 0x93, 0x32, 0x8d, - 0x1d, 0x93, 0x94, 0xe9, 0x17, 0x4b, 0x04, 0x03, 0x3f, 0x4f, 0xc3, 0x9b, 0xb6, 0x6e, 0x7b, 0xd3, - 0x9e, 0xcd, 0x15, 0xbe, 0x7d, 0x1c, 0x68, 0xbf, 0x52, 0x21, 0xd3, 0xd8, 0xe4, 0x70, 0x4f, 0x7e, - 0x30, 0x6b, 0x70, 0x4a, 0x05, 0x06, 0x07, 0x13, 0x34, 0x84, 0xad, 0x56, 0x78, 0x2f, 0xfd, 0xf1, - 0xd6, 0x19, 0x14, 0x04, 0x16, 0xdd, 0x94, 0x1d, 0x4c, 0x22, 0x13, 0x76, 0xe3, 0xf4, 0x75, 0xaf, - 0x9a, 0x80, 0x83, 0xa2, 0xa0, 0x2b, 0x7e, 0x2a, 0x0e, 0xa8, 0x0d, 0x20, 0x63, 0x0b, 0x46, 0x58, - 0x6c, 0x01, 0xcf, 0x7d, 0x67, 0xc0, 0xc1, 0xa2, 0xa2, 0xaa, 0x66, 0x95, 0xfd, 0x66, 0x6b, 0xe8, - 0x04, 0x59, 0xc2, 0x79, 0x62, 0x26, 0xc9, 0x01, 0x34, 0x33, 0x3c, 0x06, 0x48, 0x64, 0x18, 0x44, - 0x2c, 0x8e, 0x0d, 0x95, 0x72, 0xaa, 0x02, 0x24, 0x30, 0x07, 0x96, 0xfa, 0xdf, 0x79, 0x19, 0x53, - 0xbe, 0x06, 0xad, 0x4d, 0x7c, 0x7d, 0x42, 0x04, 0x92, 0x88, 0x1c, 0xae, 0x02, 0x08, 0x1a, 0x8f, - 0x7b, 0x3e, 0xbb, 0x6c, 0xca, 0xdf, 0x20, 0x98, 0x60, 0xd4, 0x6c, 0xcf, 0xdf, 0x54, 0x50, 0x30, - 0x28, 0xdc, 0xd7, 0xd8, 0xde, 0x3d, 0x60, 0xf8, 0xf9, 0x77, 0xcb, 0xc4, 0xa9, 0xb1, 0x70, 0x0b, - 0xeb, 0x99, 0x86, 0x7d, 0x32, 0x13, 0x53, 0x63, 0xb5, 0xdd, 0xbd, 0x2f, 0x58, 0x15, 0x0b, 0xf8, - 0xaf, 0xaf, 0x99, 0x65, 0xf8, 0x05, 0x4b, 0x1b, 0x06, 0x29, 0xbe, 0x38, 0x24, 0x51, 0xb7, 0xbd, - 0x14, 0xe3, 0x7b, 0x6f, 0xe2, 0xa1, 0x05, 0x36, 0x24, 0x20, 0x81, 0xa0, 0xf1, 0x38, 0x07, 0xd8, - 0x8f, 0x1b, 0x54, 0x1a, 0x85, 0x61, 0x22, 0x67, 0x0d, 0xcb, 0xba, 0x6d, 0xc0, 0xc1, 0xa2, 0xc2, - 0x84, 0xd5, 0x71, 0xb7, 0xd3, 0x69, 0xb1, 0xd3, 0x1d, 0xaf, 0x75, 0x35, 0x0a, 0xbb, 0x1d, 0x1e, - 0x71, 0x2b, 0x12, 0x56, 0xd7, 0x7b, 0xb0, 0x90, 0x51, 0x02, 0x17, 0xfd, 0x6e, 0xcc, 0xfe, 0x17, - 0x17, 0x48, 0xb9, 0x8f, 0xa9, 0xce, 0x40, 0x20, 0x71, 0x6e, 0x97, 0x6d, 0x55, 0x2c, 0x01, 0x3e, - 0x46, 0x82, 0x39, 0x3e, 0x99, 0xee, 0xb0, 0xed, 0x48, 0x1e, 0x31, 0x17, 0x1a, 0xca, 0x54, 0xc0, - 0x07, 0x4f, 0x74, 0x6d, 0xb2, 0x01, 0x9b, 0xab, 0xfb, 0x1f, 0x08, 0x93, 0x35, 0xe2, 0x60, 0x6d, - 0x5c, 0x84, 0x73, 0x0a, 0x5d, 0xec, 0xb9, 0x22, 0x2f, 0xbe, 0x68, 0x39, 0x2e, 0x82, 0x43, 0x41, - 0x72, 0x71, 0xbe, 0xc4, 0xcf, 0xc8, 0xd9, 0xfa, 0x2e, 0xfe, 0x0c, 0x13, 0xa7, 0xb7, 0x02, 0x95, - 0x05, 0x0b, 0x30, 0xd8, 0x39, 0x9b, 0x64, 0x5a, 0x64, 0x49, 0x17, 0xb6, 0x7a, 0xc5, 0xb2, 0x57, - 0xa7, 0xc1, 0x44, 0x3e, 0x48, 0x03, 0xc0, 0x2e, 0xec, 0xec, 0x91, 0x27, 0x8d, 0xa7, 0x53, 0x32, - 0x82, 0x92, 0xb8, 0xe0, 0x78, 0x16, 0xbd, 0x00, 0xdb, 0xc7, 0x11, 0xc2, 0xf1, 0x7c, 0xe8, 0x20, - 0x3f, 0xe6, 0x35, 0x92, 0xe0, 0xd0, 0x5f, 0xf5, 0xbd, 0x26, 0xd5, 0xca, 0x7c, 0xfb, 0x76, 0xf1, - 0x13, 0xb4, 0x82, 0xc7, 0x96, 0xb2, 0x08, 0x20, 0xbb, 0x1c, 0xb5, 0xd7, 0xab, 0xcd, 0x76, 0x2c, - 0xc6, 0x60, 0xcc, 0x7a, 0x25, 0xa6, 0xba, 0x7a, 0xa3, 0xae, 0xfa, 0xaf, 0x7f, 0x80, 0x2e, 0xe0, - 0x7c, 0xc0, 0x1f, 0xaf, 0x55, 0x06, 0x09, 0x7f, 0x9d, 0xe8, 0xcd, 0x42, 0x26, 0xb0, 0x75, 0x11, - 0x82, 0xbb, 0xb1, 0x54, 0xf0, 0x9f, 0x75, 0x47, 0xc2, 0xaa, 0xc2, 0xf9, 0x41, 0xba, 0xb0, 0xfc, - 0x08, 0x1f, 0x65, 0x5d, 0x6a, 0xb0, 0xac, 0x8f, 0xec, 0x84, 0x6a, 0xc2, 0x8a, 0x80, 0x77, 0xea, - 0x3d, 0x14, 0x90, 0x51, 0xca, 0xb9, 0x86, 0x12, 0xc7, 0x84, 0x8a, 0x58, 0x4d, 0xa9, 0xda, 0xcd, - 0xaf, 0xfa, 0x98, 0xd8, 0x1d, 0xdf, 0xa8, 0xb0, 0x39, 0x42, 0xaa, 0x1c, 0x6e, 0x2b, 0x2a, 0x9b, - 0x35, 0xb1, 0x23, 0x0c, 0x7b, 0x33, 0x5a, 0xa3, 0xa5, 0x84, 0x27, 0x16, 0x37, 0xfc, 0x04, 0x9f, - 0x8c, 0x62, 0xfe, 0xe6, 0x09, 0x23, 0xcb, 0x95, 0x46, 0x81, 0x49, 0x87, 0x3a, 0x10, 0x3b, 0xe8, - 0xd8, 0x58, 0x65, 0x5e, 0xe4, 0x09, 0xbd, 0x76, 0xae, 0x71, 0x30, 0x48, 0xbc, 0x24, 0xdd, 0xa8, - 0xad, 0x30, 0x8f, 0x70, 0x8a, 0x94, 0x82, 0x41, 0xe2, 0x31, 0x3a, 0x2c, 0xfd, 0x16, 0xcf, 0x4c, - 0x11, 0xef, 0x7c, 0xaf, 0x04, 0x2f, 0xf8, 0x1c, 0xcf, 0x7d, 0x32, 0xa7, 0xde, 0x03, 0xe2, 0xe9, - 0x07, 0xe3, 0xf9, 0xd9, 0x22, 0x4f, 0xe7, 0x66, 0x66, 0x31, 0x54, 0xc1, 0xb9, 0x1b, 0x29, 0x9e, - 0xd0, 0x53, 0x8b, 0x75, 0x4b, 0x7e, 0x2e, 0x37, 0x43, 0x39, 0x3e, 0xc7, 0xd3, 0xdd, 0x69, 0x86, - 0x07, 0x54, 0x64, 0xb0, 0x17, 0x81, 0xcc, 0x87, 0x60, 0x25, 0x02, 0x34, 0xcd, 0xc2, 0xe7, 0xc9, - 0x99, 0x9e, 0x39, 0x3d, 0x50, 0x54, 0xd9, 0x4f, 0x8f, 0x90, 0xaa, 0xf2, 0xea, 0xd0, 0xfa, 0x2d, - 0x57, 0xda, 0x13, 0x69, 0x57, 0xda, 0x04, 0xee, 0xbc, 0xa6, 0xf7, 0xec, 0xcb, 0x19, 0x2f, 0x41, - 0x5e, 0xc8, 0xfd, 0x88, 0xc5, 0x2f, 0x77, 0x0c, 0xf0, 0x4e, 0xa6, 0x56, 0xeb, 0x47, 0x8e, 0x55, - 0xeb, 0x0b, 0x3e, 0xf4, 0x83, 0x0a, 0x3c, 0xdd, 0x79, 0x28, 0x59, 0xea, 0x11, 0x8b, 0x1a, 0x02, - 0x81, 0xe3, 0x98, 0xde, 0x85, 0x42, 0x99, 0xe9, 0x5d, 0xe3, 0x27, 0xd5, 0xbb, 0x24, 0x07, 0xd0, - 0xcc, 0x30, 0x01, 0x7b, 0xc3, 0x7e, 0x94, 0x44, 0xdd, 0xd9, 0xb8, 0x38, 0xc0, 0xa3, 0x20, 0x5d, - 0x23, 0x01, 0xfb, 0x4a, 0x9a, 0x1f, 0xf4, 0x56, 0x81, 0x17, 0xec, 0x67, 0xd5, 0x84, 0xa0, 0x3b, - 0x10, 0xa6, 0x2a, 0x1a, 0x9e, 0x23, 0xf3, 0xa6, 0x65, 0xa9, 0x3e, 0x04, 0xff, 0xe3, 0xaf, 0x97, - 0x98, 0xff, 0x71, 0xdb, 0x3f, 0xe8, 0xb4, 0xf0, 0xa5, 0x93, 0xe1, 0x35, 0xfd, 0x4b, 0x64, 0x22, - 0x11, 0xb5, 0x14, 0x4b, 0x02, 0x6d, 0x34, 0x8b, 0xf9, 0x63, 0x95, 0x20, 0x90, 0x50, 0x50, 0x0c, - 0xdd, 0x7f, 0xc5, 0xbf, 0x82, 0xc4, 0x9c, 0x86, 0x65, 0x75, 0xc3, 0xb6, 0xac, 0x5e, 0x2a, 0xdc, - 0x99, 0x3e, 0x16, 0xd6, 0x37, 0xec, 0x2e, 0x30, 0x85, 0xed, 0xd1, 0xf7, 0x88, 0xbb, 0x5b, 0xc4, - 0x7e, 0x68, 0x85, 0xaa, 0x2b, 0x2c, 0x5a, 0x93, 0x4b, 0xc4, 0x0b, 0x03, 0x46, 0x6a, 0xba, 0xbf, - 0x5c, 0x26, 0xe7, 0xb2, 0xde, 0x5f, 0x77, 0x9a, 0x64, 0xaa, 0x63, 0xa8, 0xcf, 0xc5, 0xee, 0xf2, - 0x9b, 0x0a, 0xb7, 0x56, 0x5d, 0x4c, 0x28, 0x58, 0x5c, 0x31, 0xf5, 0x3a, 0xbe, 0x26, 0xaf, 0xdc, - 0x2b, 0xe5, 0xc1, 0x45, 0x94, 0xaa, 0x66, 0xcd, 0x60, 0x04, 0x16, 0xdb, 0x21, 0xe4, 0x29, 0x77, - 0xff, 0x7e, 0x89, 0x3c, 0xde, 0xe7, 0xc2, 0x3f, 0x56, 0x77, 0x8f, 0x79, 0x21, 0xc5, 0x43, 0x3e, - 0xaa, 0x3a, 0xee, 0x9b, 0x04, 0x81, 0x75, 0x76, 0xf0, 0x1e, 0xa9, 0x7a, 0xdd, 0xb4, 0x5c, 0xe4, - 0x18, 0xbc, 0xe7, 0x72, 0xb1, 0x71, 0xef, 0x54, 0xbd, 0x67, 0x6a, 0x70, 0x75, 0xbf, 0x5e, 0x21, - 0xa3, 0xfc, 0x81, 0xc5, 0x1a, 0x55, 0x80, 0x78, 0x7e, 0xc1, 0xc1, 0xd2, 0x1b, 0x6a, 0x3d, 0x89, - 0x03, 0x40, 0xb2, 0x71, 0xb6, 0xc8, 0x59, 0xf4, 0xaf, 0x06, 0x5e, 0x6b, 0xd5, 0x6f, 0x79, 0x47, - 0x52, 0xf1, 0xe6, 0xb9, 0xa5, 0x65, 0x1a, 0xd4, 0xb3, 0x1b, 0xbd, 0x24, 0x90, 0x55, 0x0e, 0xaf, - 0x2b, 0xa5, 0x12, 0x04, 0xf1, 0xbc, 0x8d, 0xea, 0xba, 0xd2, 0xf1, 0x49, 0x82, 0xf0, 0xc6, 0x56, - 0xa7, 0xc7, 0xc4, 0x30, 0x5e, 0xe6, 0xb3, 0xcd, 0x0a, 0x9b, 0x16, 0xef, 0x3a, 0xc5, 0x5d, 0x76, - 0x46, 0xba, 0xbd, 0x4f, 0x2d, 0x99, 0xfd, 0xb0, 0xd5, 0x14, 0x2f, 0x4a, 0x29, 0x75, 0xaa, 0x9e, - 0xc2, 0x43, 0x4f, 0x09, 0xe4, 0xb2, 0xeb, 0x05, 0x2d, 0x3a, 0xb5, 0x35, 0x97, 0x31, 0x9b, 0xcb, - 0x7a, 0x0a, 0x0f, 0x3d, 0x25, 0xdc, 0xdf, 0x2b, 0x91, 0xb3, 0x19, 0x27, 0xf7, 0x3c, 0xa0, 0x6c, - 0x8f, 0x8a, 0x46, 0x95, 0x41, 0xd8, 0x08, 0x28, 0xe3, 0x70, 0x50, 0x14, 0x38, 0x0b, 0xb9, 0xdd, - 0x98, 0x4e, 0x88, 0x2c, 0x8e, 0x4a, 0x05, 0x76, 0xb0, 0x74, 0x3f, 0xea, 0x9d, 0xf8, 0x91, 0xbe, - 0xef, 0xc4, 0x53, 0xc5, 0x64, 0x4f, 0x59, 0xe7, 0x86, 0x62, 0xc2, 0xed, 0x73, 0x8e, 0xc3, 0xac, - 0xe0, 0xb3, 0xa9, 0x08, 0x1e, 0x6c, 0x48, 0xea, 0x39, 0x7b, 0xe6, 0x52, 0xc0, 0xd8, 0x96, 0x8c, - 0x27, 0xed, 0x5f, 0xb0, 0x5f, 0xbb, 0xd5, 0x6d, 0x5e, 0x5e, 0xb5, 0xde, 0xf1, 0x2a, 0x9a, 0xd5, - 0xfc, 0x93, 0x98, 0x3a, 0x58, 0x3d, 0xcb, 0xa8, 0x26, 0x3d, 0x65, 0x57, 0xa3, 0x60, 0x60, 0x48, - 0xe7, 0x79, 0xd1, 0xfb, 0x94, 0x73, 0x12, 0xbc, 0x66, 0x18, 0x1b, 0x43, 0x40, 0xe5, 0x08, 0x55, - 0x6b, 0xf1, 0x54, 0x20, 0xed, 0x9a, 0xbd, 0xce, 0xc1, 0x20, 0xf1, 0x76, 0xe6, 0xf2, 0xf1, 0x21, - 0x67, 0x2e, 0x9f, 0xc8, 0x8d, 0x42, 0xfc, 0x05, 0xba, 0x2b, 0xb2, 0xb4, 0x6b, 0xe2, 0x26, 0x28, - 0x3a, 0xf9, 0x87, 0xb7, 0x2b, 0xe2, 0x3b, 0x6f, 0x58, 0x59, 0x3a, 0xe9, 0x30, 0x6b, 0x01, 0x70, - 0x1c, 0x26, 0x71, 0x65, 0x55, 0xe3, 0xe7, 0x9b, 0xe2, 0x49, 0x5c, 0xf5, 0xeb, 0xdf, 0x2c, 0xc6, - 0x1d, 0xfc, 0x0e, 0xb5, 0xbd, 0x59, 0x63, 0xb5, 0x27, 0xe6, 0x51, 0x89, 0x71, 0xcf, 0x6c, 0xdc, - 0xc3, 0x8a, 0x71, 0xcf, 0x66, 0x7e, 0xbc, 0x0a, 0xfa, 0x5f, 0x2a, 0xe4, 0xa9, 0xcc, 0x72, 0xfa, - 0x58, 0x67, 0xdd, 0x3a, 0xd6, 0xb9, 0x92, 0x3a, 0xd6, 0x71, 0x8f, 0x2f, 0xfd, 0xa7, 0x07, 0x3d, - 0x7f, 0x74, 0x07, 0x3d, 0x78, 0x7f, 0x21, 0xf3, 0xeb, 0x3c, 0x7a, 0xf7, 0x17, 0x32, 0x9b, 0xd9, - 0x47, 0x57, 0xff, 0xab, 0x95, 0x3e, 0xdd, 0x62, 0x5a, 0xfb, 0x8b, 0x28, 0xe1, 0x18, 0x32, 0x16, - 0x0a, 0xd7, 0x14, 0x97, 0x6e, 0x1c, 0x06, 0x0a, 0xeb, 0xc4, 0x46, 0xfc, 0x3f, 0x6f, 0xe4, 0xda, - 0x09, 0x17, 0xef, 0xa2, 0xed, 0xa6, 0x33, 0x2f, 0xcf, 0xa6, 0x2e, 0x05, 0x60, 0xb4, 0x95, 0x32, - 0xc4, 0x2a, 0x27, 0x31, 0xc4, 0xa6, 0xb2, 0x8d, 0x30, 0xbc, 0x72, 0x76, 0x10, 0xb4, 0xd9, 0x03, - 0x65, 0xb6, 0xc6, 0xa3, 0xae, 0x9c, 0x6d, 0xd9, 0x68, 0x48, 0xd3, 0x2f, 0x50, 0x95, 0xe9, 0xe4, - 0xbe, 0x99, 0xef, 0x57, 0xc8, 0xc7, 0x8f, 0x11, 0x40, 0x7c, 0xe7, 0xb1, 0xbe, 0x8b, 0xb1, 0xf3, - 0xf4, 0x7c, 0x9b, 0x1a, 0x39, 0xb7, 0xdb, 0x6d, 0xb5, 0x8e, 0x58, 0x00, 0x86, 0xdf, 0x94, 0x14, - 0x42, 0x9b, 0x54, 0x4f, 0x87, 0xae, 0x67, 0xd0, 0x40, 0x66, 0x49, 0xf4, 0x8b, 0x86, 0x3b, 0x2c, - 0xeb, 0x61, 0x53, 0x5f, 0x0f, 0x66, 0x9f, 0xa0, 0xa2, 0xd7, 0xea, 0xcd, 0x1e, 0x0a, 0xc8, 0x28, - 0x85, 0xba, 0x25, 0x7b, 0x75, 0x54, 0x35, 0x2b, 0xa5, 0x5b, 0x82, 0x89, 0x04, 0x9b, 0x96, 0x1a, - 0x7f, 0x67, 0xbc, 0x43, 0xaa, 0xe4, 0xb1, 0xd4, 0x2e, 0x92, 0x01, 0x57, 0x2e, 0x95, 0xf3, 0x63, - 0x29, 0x4d, 0x00, 0xbd, 0x65, 0x9c, 0x8e, 0xe5, 0xce, 0xe2, 0x59, 0x8e, 0x3f, 0x7b, 0x82, 0x19, - 0x5c, 0xd8, 0xc1, 0xe5, 0xfe, 0x6e, 0x09, 0xb7, 0xd7, 0x8c, 0x07, 0xbd, 0xac, 0x77, 0xb0, 0x8d, - 0x2b, 0x11, 0xbd, 0xef, 0x60, 0x33, 0x4f, 0xaf, 0x4d, 0xcb, 0xa7, 0x46, 0xac, 0x43, 0x2a, 0x2d, - 0x4d, 0x56, 0x5c, 0x05, 0x52, 0x14, 0xf8, 0x76, 0x5d, 0x33, 0x38, 0x0c, 0xe2, 0x30, 0x2a, 0xf0, - 0xec, 0x6c, 0x4f, 0x98, 0x9e, 0x16, 0x97, 0xab, 0x9c, 0x09, 0x48, 0x6e, 0xee, 0x5f, 0x2f, 0x93, - 0x69, 0x59, 0x1f, 0x55, 0xb8, 0x99, 0x0c, 0x1b, 0x96, 0xd2, 0xf0, 0xae, 0xa5, 0x34, 0x5c, 0x2a, - 0x76, 0x1f, 0x8a, 0x35, 0xaa, 0xaf, 0xb2, 0xf0, 0xc5, 0x94, 0xb2, 0x70, 0x79, 0x10, 0xa6, 0xb9, - 0x7e, 0xaa, 0x33, 0x16, 0xfd, 0x23, 0x94, 0x65, 0x37, 0xab, 0x3b, 0x7d, 0x36, 0x8e, 0xaf, 0x97, - 0x53, 0xdd, 0x60, 0x1b, 0xc6, 0x57, 0xc9, 0xc8, 0xbe, 0x17, 0x35, 0xc5, 0xa1, 0xdc, 0xdb, 0x03, - 0x7e, 0x0a, 0x6a, 0x18, 0x47, 0x4d, 0x2e, 0xf6, 0x5f, 0x51, 0xcf, 0x81, 0x50, 0x50, 0x6e, 0x80, - 0x31, 0xab, 0xd4, 0x79, 0x0b, 0x9f, 0x0b, 0x09, 0x3b, 0x2a, 0x7e, 0xec, 0x19, 0xfe, 0x54, 0x08, - 0x42, 0x28, 0x07, 0xc7, 0xae, 0x0e, 0xc1, 0x20, 0xe8, 0x17, 0x7c, 0x52, 0x55, 0x55, 0x0f, 0x31, - 0x94, 0x95, 0x8a, 0xf5, 0xb3, 0x19, 0x53, 0xc5, 0xf9, 0x11, 0x6b, 0xd4, 0x3e, 0x33, 0xf0, 0x5c, - 0xfb, 0x88, 0xe3, 0xf6, 0x23, 0xcc, 0xf4, 0x6a, 0x8a, 0xb9, 0x71, 0x82, 0xea, 0xa9, 0x7d, 0x96, - 0xae, 0x1e, 0x41, 0xf9, 0xd5, 0x63, 0xb5, 0xa7, 0x34, 0xf8, 0x58, 0x8d, 0x6a, 0xe7, 0x10, 0xbf, - 0xf1, 0x8f, 0x8f, 0x90, 0x73, 0x59, 0x77, 0x2e, 0x9d, 0x9f, 0x28, 0xa5, 0xf2, 0x74, 0x7f, 0x6e, - 0xf0, 0x8b, 0x9b, 0x3c, 0x79, 0xb7, 0xc8, 0xc5, 0xb0, 0x68, 0x67, 0xee, 0xce, 0x1d, 0x6d, 0x51, - 0x3b, 0xbb, 0x14, 0x10, 0xf1, 0x94, 0xeb, 0x52, 0x1e, 0xbc, 0x73, 0x82, 0xa6, 0x88, 0xac, 0xed, - 0x71, 0xea, 0x52, 0x80, 0x04, 0xe7, 0x5f, 0x0a, 0x90, 0x6d, 0x58, 0xd8, 0xc3, 0x7c, 0xdd, 0xaa, - 0x5f, 0x43, 0x9c, 0x02, 0x01, 0xee, 0x49, 0x46, 0xab, 0x87, 0x38, 0x0d, 0xfe, 0x66, 0x89, 0xa4, - 0x02, 0x43, 0x94, 0x7f, 0xa7, 0xd4, 0xd7, 0xbf, 0x43, 0x29, 0xa8, 0x16, 0xe1, 0xa7, 0x13, 0x48, - 0x03, 0x85, 0x01, 0xc3, 0xa8, 0x47, 0x07, 0x2b, 0xfd, 0x1e, 0x1d, 0x44, 0xc3, 0xbf, 0xe5, 0x1f, - 0xfa, 0xd2, 0xdb, 0xa2, 0x84, 0xf7, 0x26, 0x02, 0x81, 0xe3, 0xdc, 0x6f, 0x57, 0xc8, 0x18, 0x77, - 0x69, 0x0c, 0x71, 0x5b, 0xae, 0x09, 0xef, 0x42, 0xa1, 0xdb, 0x8f, 0xbc, 0x35, 0x8b, 0xe8, 0x7e, - 0xe0, 0x13, 0x4a, 0xf5, 0x4d, 0x7b, 0x24, 0x9c, 0x45, 0xab, 0xf7, 0x0b, 0x29, 0xe3, 0x99, 0x70, - 0x1e, 0xc6, 0x58, 0xec, 0x13, 0x12, 0xb3, 0xf7, 0xa7, 0x90, 0x87, 0xc8, 0x40, 0xf7, 0x7a, 0xa1, - 0x76, 0xd4, 0x55, 0x31, 0xde, 0x1a, 0x9d, 0xfa, 0x4a, 0x21, 0xc0, 0xe0, 0xbd, 0xf0, 0x26, 0xa9, - 0x2a, 0xe2, 0x3c, 0x4d, 0x7f, 0xca, 0x9c, 0x92, 0x7f, 0x86, 0xcc, 0xa6, 0xea, 0x1a, 0xc8, 0x50, - 0xf8, 0x16, 0x55, 0x26, 0x7a, 0xde, 0x4b, 0xc5, 0x2c, 0x86, 0xe7, 0x5a, 0x19, 0xbe, 0x2c, 0xf1, - 0x81, 0x4f, 0xe2, 0x05, 0x53, 0x56, 0x42, 0x16, 0x16, 0x32, 0x6b, 0x93, 0x39, 0x35, 0xcb, 0xd9, - 0x39, 0x35, 0xd9, 0xa3, 0x3b, 0xbc, 0xed, 0xa7, 0xa1, 0x01, 0x6d, 0xd8, 0x1a, 0xd0, 0x73, 0x45, - 0xa6, 0x41, 0x1f, 0xd5, 0xe7, 0xdf, 0x96, 0x88, 0xc3, 0x09, 0xd2, 0xef, 0xd0, 0x71, 0xdf, 0xa0, - 0xa1, 0xb3, 0xeb, 0x79, 0xa3, 0x30, 0x60, 0x50, 0x0d, 0x98, 0x63, 0x5c, 0xbd, 0xdf, 0x54, 0xec, - 0x91, 0xf8, 0x4a, 0x81, 0x47, 0xe2, 0x7f, 0xbd, 0x42, 0xd2, 0x41, 0x14, 0xce, 0xfb, 0x64, 0x0a, - 0x2f, 0x6c, 0xed, 0x04, 0x2d, 0x6a, 0xaa, 0xf8, 0x71, 0xb1, 0x03, 0xaa, 0x15, 0xa3, 0x84, 0xf0, - 0x2e, 0x1b, 0x10, 0xb0, 0x38, 0x62, 0xe4, 0x5f, 0x27, 0xa2, 0x96, 0x42, 0xcb, 0xdf, 0x63, 0x7a, - 0x87, 0xca, 0x48, 0x52, 0x53, 0x50, 0x30, 0x28, 0x32, 0xa2, 0xf5, 0x2a, 0xa7, 0x11, 0xad, 0x37, - 0x32, 0x60, 0xb4, 0xde, 0x68, 0xa1, 0x68, 0x3d, 0x20, 0xe7, 0xa5, 0x53, 0x18, 0x7f, 0xe3, 0xa5, - 0x47, 0x9e, 0x44, 0x4f, 0xc4, 0x58, 0x2e, 0xe0, 0x45, 0x36, 0xc8, 0xa4, 0x80, 0x3e, 0x25, 0xdd, - 0x2e, 0x39, 0x5b, 0xf7, 0xa3, 0x80, 0xe5, 0x38, 0x6a, 0xea, 0x15, 0xf8, 0x65, 0x4c, 0x17, 0x61, - 0x2f, 0xfe, 0x01, 0xef, 0xa3, 0x19, 0x99, 0x22, 0xe4, 0x62, 0xd7, 0x2c, 0xdd, 0xbf, 0x58, 0x26, - 0xe3, 0x22, 0x58, 0x69, 0x88, 0x1b, 0xc9, 0x75, 0xcb, 0xbe, 0x7b, 0x29, 0x6f, 0xe5, 0xb2, 0xe6, - 0xf4, 0xb5, 0xec, 0xea, 0x29, 0xcb, 0xee, 0xe5, 0x62, 0xec, 0x8e, 0xb7, 0xe9, 0x7e, 0xad, 0x4c, - 0x77, 0x7b, 0x3b, 0x48, 0x6b, 0x78, 0xc3, 0xf1, 0x05, 0x32, 0x1e, 0x8b, 0x48, 0xa6, 0x42, 0xcf, - 0xf2, 0xa7, 0x3f, 0xa9, 0x7e, 0x70, 0x5e, 0xc4, 0x2e, 0x49, 0x76, 0x99, 0xc1, 0x52, 0x95, 0xd3, - 0x08, 0x96, 0x72, 0xbf, 0xcd, 0x44, 0xaa, 0x39, 0x80, 0xa7, 0xb1, 0x27, 0xbc, 0x6b, 0x4b, 0xdf, - 0x57, 0x0a, 0x4d, 0x05, 0xd1, 0xbe, 0x3e, 0x7b, 0xc3, 0x37, 0x4b, 0x64, 0x52, 0x10, 0x9e, 0x46, - 0x0f, 0x7e, 0xd0, 0xee, 0xc1, 0xf3, 0x85, 0x7a, 0xd0, 0xa7, 0xe9, 0x7f, 0xbb, 0xac, 0x9a, 0x5e, - 0x13, 0xef, 0x73, 0xe6, 0x66, 0x55, 0x9c, 0xe8, 0x44, 0x61, 0x12, 0x36, 0xc2, 0x96, 0xd8, 0xe5, - 0x3f, 0xa1, 0xe3, 0xdb, 0x39, 0xfc, 0x81, 0xf1, 0x3f, 0x28, 0x6a, 0x16, 0xb7, 0x8d, 0xaf, 0x89, - 0xf2, 0x2d, 0x2a, 0xeb, 0x75, 0xd0, 0x1d, 0xf9, 0xfa, 0x32, 0xc2, 0xc4, 0x99, 0xc1, 0xa0, 0xaf, - 0x8e, 0xea, 0x68, 0x75, 0xc5, 0x09, 0x0c, 0xae, 0x32, 0x90, 0x92, 0xd5, 0x30, 0x6a, 0xbb, 0x51, - 0x6f, 0x08, 0x38, 0x28, 0x0a, 0xf7, 0x4d, 0x26, 0x63, 0xd9, 0xf0, 0x0c, 0x16, 0x82, 0xfe, 0x93, - 0x63, 0x6a, 0x60, 0x99, 0x93, 0xe4, 0x06, 0xc6, 0x97, 0x45, 0xca, 0x0e, 0x2c, 0x26, 0xd0, 0xb0, - 0x09, 0x66, 0x28, 0x1a, 0x2d, 0x0f, 0x9c, 0x8d, 0xe3, 0xf7, 0xf8, 0xde, 0xdf, 0x2c, 0x2c, 0x23, - 0x07, 0xf0, 0xb6, 0xb3, 0x2c, 0x2d, 0x2c, 0x33, 0xc5, 0x46, 0x2d, 0x9d, 0x09, 0x73, 0x45, 0x22, - 0x40, 0xd3, 0xd0, 0x02, 0x5c, 0x5d, 0xb7, 0x1f, 0x6f, 0x95, 0xea, 0xba, 0x1c, 0x12, 0x43, 0x5f, - 0xa7, 0xfa, 0x8b, 0xca, 0x05, 0x5e, 0xe3, 0x29, 0x9d, 0xab, 0x5c, 0x7f, 0x59, 0xd3, 0x60, 0x30, - 0x69, 0xa8, 0x5a, 0x77, 0xb6, 0xa9, 0xe2, 0x66, 0x6b, 0xdd, 0x9d, 0x56, 0xd0, 0xc0, 0xa2, 0xfc, - 0xce, 0xca, 0xe3, 0x18, 0x24, 0xb1, 0xda, 0x8b, 0x86, 0xac, 0x32, 0xce, 0x36, 0xc6, 0xa6, 0xb2, - 0x9c, 0xe7, 0xf2, 0x76, 0x9b, 0x48, 0x15, 0x77, 0x41, 0x3a, 0xfd, 0xeb, 0x36, 0xfa, 0x01, 0x03, - 0x71, 0xa1, 0x20, 0x40, 0x90, 0x66, 0x81, 0xa1, 0x17, 0x2d, 0xf3, 0xed, 0xa2, 0x9a, 0x08, 0x1f, - 0x56, 0xa1, 0x17, 0xd6, 0xcb, 0x46, 0x35, 0x48, 0x51, 0x53, 0x69, 0x3f, 0x6f, 0x42, 0xc4, 0x85, - 0x76, 0x3c, 0xbe, 0x8d, 0x45, 0xb2, 0xe5, 0x4f, 0x60, 0xf0, 0xf0, 0x66, 0x1f, 0x1a, 0xe8, 0x5b, - 0x1a, 0x73, 0xa2, 0xca, 0x91, 0x34, 0x42, 0x89, 0x75, 0xd0, 0x8f, 0x81, 0x03, 0x8b, 0xf2, 0xa3, - 0x9d, 0x6d, 0x7c, 0x15, 0x0b, 0x1b, 0x9b, 0xaa, 0xf3, 0x15, 0x32, 0x65, 0xb6, 0x51, 0x88, 0xc9, - 0x57, 0x8b, 0xbf, 0x07, 0x25, 0x36, 0x67, 0xd5, 0x72, 0x13, 0x07, 0x16, 0x6f, 0xb7, 0x41, 0x66, - 0x53, 0xef, 0xd1, 0xaa, 0x87, 0x8d, 0x4b, 0x0f, 0xeb, 0x61, 0x63, 0x4c, 0x7a, 0x34, 0xba, 0xed, - 0x05, 0xf9, 0xaf, 0x0a, 0x14, 0x79, 0x19, 0xd8, 0x79, 0x83, 0x8c, 0xf9, 0xbb, 0xbb, 0x74, 0xb0, - 0xc5, 0x9a, 0x7b, 0x52, 0x3d, 0x73, 0xcf, 0xa0, 0xb8, 0x92, 0x58, 0x65, 0xfc, 0x27, 0x08, 0x62, - 0xf7, 0xdf, 0x53, 0xeb, 0x6a, 0x3b, 0x6c, 0xc9, 0x53, 0x96, 0x9c, 0x96, 0x2c, 0xf7, 0xbc, 0x6f, - 0xf0, 0x42, 0xc6, 0xfb, 0x06, 0x8e, 0x66, 0x98, 0xf1, 0xba, 0x81, 0xea, 0x4d, 0xa5, 0x50, 0x6f, - 0x46, 0x06, 0xe9, 0xcd, 0xd7, 0x4a, 0x44, 0x04, 0xd7, 0x14, 0xd8, 0x96, 0x9a, 0x32, 0x27, 0xb9, - 0x95, 0x59, 0xe2, 0x42, 0x91, 0x1b, 0x22, 0x22, 0x9f, 0x84, 0x9a, 0x4a, 0x56, 0x16, 0x09, 0x8b, - 0x2b, 0x9a, 0xde, 0x93, 0x1c, 0xbd, 0xc5, 0x14, 0xbe, 0xfc, 0x76, 0x0d, 0x94, 0xb5, 0x8a, 0xa5, - 0xec, 0x46, 0xc6, 0x2a, 0x79, 0x91, 0x99, 0xb2, 0x5b, 0x22, 0x40, 0xd3, 0xe0, 0x61, 0x76, 0xdc, - 0xdd, 0x61, 0xe4, 0xa9, 0x48, 0x9b, 0x3a, 0x07, 0x83, 0xc4, 0xbb, 0xff, 0x7b, 0x8e, 0x58, 0x5d, - 0xb3, 0x12, 0x25, 0x95, 0x1e, 0x7a, 0xa2, 0x24, 0xca, 0xdd, 0x3f, 0xe8, 0x24, 0x47, 0xab, 0x41, - 0x54, 0x2c, 0x69, 0xdd, 0x9a, 0xa0, 0xee, 0xe5, 0x2e, 0x31, 0xa0, 0x38, 0xf6, 0x49, 0x7b, 0x55, - 0x79, 0x24, 0xd2, 0x5e, 0x8d, 0xfc, 0x91, 0xa4, 0xbd, 0xa2, 0x16, 0xc2, 0x1e, 0x7f, 0x28, 0x5f, - 0xdc, 0x08, 0xcc, 0x39, 0xbe, 0xca, 0x78, 0x55, 0x9f, 0x5f, 0xfd, 0x12, 0x08, 0x90, 0xec, 0x30, - 0xa9, 0x12, 0x37, 0x16, 0x44, 0x26, 0xa9, 0x57, 0x8b, 0xb8, 0x51, 0x7a, 0x93, 0x2a, 0x89, 0x70, - 0x2a, 0xc1, 0x4b, 0xa6, 0xb9, 0x1a, 0xff, 0xe8, 0x69, 0xae, 0x54, 0x72, 0xaa, 0x89, 0x87, 0x95, - 0x9c, 0xca, 0x4a, 0xf2, 0x55, 0x1d, 0x46, 0x92, 0x2f, 0x2a, 0xdb, 0x1e, 0xeb, 0x64, 0xe5, 0xc8, - 0x13, 0x69, 0xa6, 0x3e, 0x7f, 0x82, 0x9c, 0x81, 0x56, 0xd5, 0xec, 0xa2, 0x56, 0x26, 0x19, 0x64, - 0x57, 0x2c, 0xb3, 0x85, 0x4d, 0x7e, 0xf4, 0x6c, 0x61, 0xc3, 0xce, 0x47, 0xa5, 0x73, 0x87, 0x4d, - 0x0f, 0x25, 0x77, 0xd8, 0xcc, 0x43, 0xcc, 0x1d, 0x66, 0x64, 0xfd, 0x9a, 0x7d, 0xb8, 0x59, 0xbf, - 0xf6, 0xc9, 0x64, 0x33, 0xbc, 0xd7, 0xbe, 0xe7, 0x45, 0xcd, 0xa5, 0xda, 0x86, 0x48, 0x32, 0x95, - 0x93, 0xcd, 0x61, 0x55, 0x17, 0xb0, 0x6a, 0xe0, 0xfe, 0x42, 0x8d, 0x04, 0x93, 0xb5, 0xc8, 0x7f, - 0x76, 0xe6, 0x23, 0xe6, 0x3f, 0xb3, 0xb2, 0x88, 0x39, 0xc3, 0xc8, 0x22, 0xf6, 0x3e, 0xbb, 0xd3, - 0xbd, 0x1b, 0xec, 0x6d, 0x79, 0x9d, 0xf9, 0xb3, 0x45, 0x6a, 0x58, 0x91, 0xe4, 0xbd, 0x35, 0x28, - 0x14, 0x68, 0xa6, 0xbd, 0x79, 0xca, 0xce, 0x9d, 0x76, 0x9e, 0xb2, 0xc7, 0x86, 0x98, 0xa7, 0xec, - 0xfc, 0x30, 0xf2, 0x94, 0xfd, 0x39, 0xf2, 0xd4, 0xf1, 0xfd, 0xd7, 0xa9, 0x67, 0x6b, 0xda, 0xa4, - 0x4e, 0xa5, 0x9e, 0x65, 0xba, 0x85, 0x41, 0x65, 0x84, 0x21, 0x97, 0x8f, 0x0b, 0x43, 0x76, 0xff, - 0x59, 0x89, 0x3c, 0xde, 0x27, 0x85, 0x49, 0xe1, 0x7b, 0x05, 0x1d, 0x32, 0xdb, 0xb1, 0x8b, 0x16, - 0xbe, 0x01, 0x64, 0xa5, 0x4c, 0x51, 0x71, 0x64, 0x29, 0x04, 0xa4, 0xd9, 0x2f, 0x3f, 0xf7, 0x9d, - 0xef, 0x3f, 0xf5, 0xb1, 0xef, 0xd2, 0xbf, 0xdf, 0xa6, 0x7f, 0x3f, 0xfa, 0xfb, 0x4f, 0x95, 0xbe, - 0x43, 0xff, 0xbe, 0x4b, 0xff, 0x7e, 0x8f, 0xfe, 0x7d, 0xed, 0x0f, 0x9e, 0xfa, 0xd8, 0x0f, 0x95, - 0x0f, 0x2f, 0xff, 0xff, 0x00, 0x00, 0x00, 0xff, 0xff, 0xc5, 0x01, 0x0d, 0x02, 0x08, 0xb4, 0x00, - 0x00, + // 9967 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x7d, 0x6d, 0x6c, 0x24, 0xc9, + 0x75, 0x98, 0x7a, 0x86, 0x5f, 0xf3, 0xf8, 0xb9, 0xb5, 0x1f, 0xc7, 0xa3, 0xee, 0x96, 0xab, 0x3e, + 0xdd, 0x6a, 0xef, 0x6e, 0x97, 0xd4, 0xee, 0xdd, 0xf9, 0x56, 0xba, 0xcb, 0x49, 0x24, 0x87, 0xdc, + 0xa5, 0x96, 0xdc, 0x9d, 0xab, 0xe1, 0xee, 0x9e, 0xa4, 0xcb, 0x9d, 0x9a, 0xd3, 0x45, 0xb2, 0xb5, + 0xc3, 0xee, 0xb9, 0xee, 0x1e, 0xee, 0x52, 0x8a, 0x01, 0x47, 0xb9, 0x38, 0x08, 0x2c, 0x38, 0x32, + 0x12, 0x21, 0x01, 0x92, 0x20, 0x4e, 0x80, 0x04, 0x4e, 0x8c, 0x38, 0x96, 0xa3, 0xd8, 0x52, 0x22, + 0x08, 0x01, 0xe2, 0x08, 0xca, 0x87, 0x03, 0x19, 0x30, 0x62, 0xc3, 0x06, 0x18, 0x1f, 0x8d, 0x20, + 0x3f, 0xf2, 0x23, 0x01, 0x92, 0x3f, 0x21, 0x8c, 0x24, 0xa8, 0xcf, 0xae, 0xea, 0xe9, 0x61, 0xf7, + 0xf0, 0x96, 0xcc, 0xda, 0xc8, 0xbf, 0x99, 0xf7, 0x5e, 0xbd, 0xfa, 0xe8, 0x57, 0x55, 0xef, 0xbd, + 0x7a, 0xf5, 0x0a, 0x2e, 0x3f, 0xb8, 0x1e, 0xcd, 0x78, 0xc1, 0xec, 0x83, 0xf6, 0x3a, 0x09, 0x7d, + 0x12, 0x93, 0x68, 0xb6, 0xf5, 0x60, 0x73, 0xd6, 0x69, 0x79, 0xb3, 0x3b, 0x57, 0x67, 0x37, 0x89, + 0x4f, 0x42, 0x27, 0x26, 0xee, 0x4c, 0x2b, 0x0c, 0xe2, 0x00, 0x3d, 0xc3, 0xa9, 0x67, 0x12, 0xea, + 0x99, 0xd6, 0x83, 0xcd, 0x19, 0xa7, 0xe5, 0xcd, 0xec, 0x5c, 0x9d, 0xba, 0xb2, 0xe9, 0xc5, 0x5b, + 0xed, 0xf5, 0x99, 0x46, 0xb0, 0x3d, 0xbb, 0x19, 0x6c, 0x06, 0xb3, 0xac, 0xd0, 0x7a, 0x7b, 0x83, + 0xfd, 0x63, 0x7f, 0xd8, 0x2f, 0xce, 0x6c, 0xea, 0x5a, 0xf7, 0xaa, 0x43, 0x12, 0x05, 0xed, 0xb0, + 0x41, 0xd2, 0x0d, 0x98, 0x7a, 0xb5, 0x7b, 0x99, 0xb6, 0xbf, 0x43, 0xc2, 0xc8, 0x0b, 0x7c, 0xe2, + 0x76, 0x14, 0xbb, 0x92, 0x5d, 0x2c, 0x6c, 0xfb, 0xb1, 0xb7, 0xdd, 0x59, 0xcb, 0xd5, 0x6c, 0xf2, + 0x76, 0xec, 0x35, 0x67, 0x3d, 0x3f, 0x8e, 0xe2, 0x30, 0x5d, 0xc4, 0xfe, 0x5d, 0x0b, 0x2e, 0xcc, + 0xdd, 0xaf, 0x2f, 0x36, 0x9d, 0x28, 0xf6, 0x1a, 0xf3, 0xcd, 0xa0, 0xf1, 0xa0, 0x1e, 0x07, 0x21, + 0xb9, 0x17, 0x34, 0xdb, 0xdb, 0xa4, 0xce, 0x7a, 0x83, 0x2e, 0xc3, 0xd0, 0x0e, 0xfb, 0xbf, 0x5c, + 0x9d, 0xb4, 0x2e, 0x58, 0x97, 0x2a, 0xf3, 0x13, 0x3f, 0xde, 0x9b, 0xfe, 0xd8, 0xfe, 0xde, 0xf4, + 0xd0, 0x3d, 0x01, 0xc7, 0x8a, 0x02, 0x5d, 0x84, 0x81, 0x8d, 0x68, 0x6d, 0xb7, 0x45, 0x26, 0x4b, + 0x8c, 0x76, 0x4c, 0xd0, 0x0e, 0x2c, 0xd5, 0x29, 0x14, 0x0b, 0x2c, 0x9a, 0x85, 0x4a, 0xcb, 0x09, + 0x63, 0x2f, 0xf6, 0x02, 0x7f, 0xb2, 0x7c, 0xc1, 0xba, 0xd4, 0x3f, 0x7f, 0x4a, 0x90, 0x56, 0x6a, + 0x12, 0x81, 0x13, 0x1a, 0xda, 0x8c, 0x90, 0x38, 0xee, 0x1d, 0xbf, 0xb9, 0x3b, 0xd9, 0x77, 0xc1, + 0xba, 0x34, 0x94, 0x34, 0x03, 0x0b, 0x38, 0x56, 0x14, 0xf6, 0xf7, 0x4a, 0x30, 0x34, 0xb7, 0xb1, + 0xe1, 0xf9, 0x5e, 0xbc, 0x8b, 0xbe, 0x02, 0x23, 0x7e, 0xe0, 0x12, 0xf9, 0x9f, 0xf5, 0x62, 0xf8, + 0xda, 0x8b, 0x33, 0x87, 0xc9, 0xc5, 0xcc, 0x6d, 0xad, 0xc4, 0xfc, 0xc4, 0xfe, 0xde, 0xf4, 0x88, + 0x0e, 0xc1, 0x06, 0x47, 0xf4, 0x0e, 0x0c, 0xb7, 0x02, 0x57, 0x55, 0x50, 0x62, 0x15, 0xbc, 0x70, + 0x78, 0x05, 0xb5, 0xa4, 0xc0, 0xfc, 0xf8, 0xfe, 0xde, 0xf4, 0xb0, 0x06, 0xc0, 0x3a, 0x3b, 0xd4, + 0x84, 0x71, 0xfa, 0xd7, 0x8f, 0x3d, 0x55, 0x43, 0x99, 0xd5, 0x70, 0x25, 0xbf, 0x06, 0xad, 0xd0, + 0xfc, 0xe9, 0xfd, 0xbd, 0xe9, 0xf1, 0x14, 0x10, 0xa7, 0x59, 0xdb, 0x5f, 0x83, 0xb1, 0xb9, 0x38, + 0x76, 0x1a, 0x5b, 0xc4, 0xe5, 0xdf, 0x17, 0xbd, 0x02, 0x7d, 0xbe, 0xb3, 0x4d, 0xc4, 0xd7, 0xbf, + 0x20, 0x86, 0xbd, 0xef, 0xb6, 0xb3, 0x4d, 0x0e, 0xf6, 0xa6, 0x27, 0xee, 0xfa, 0xde, 0xfb, 0x6d, + 0x21, 0x33, 0x14, 0x86, 0x19, 0x35, 0xba, 0x06, 0xe0, 0x92, 0x1d, 0xaf, 0x41, 0x6a, 0x4e, 0xbc, + 0x25, 0xa4, 0x01, 0x89, 0xb2, 0x50, 0x55, 0x18, 0xac, 0x51, 0xd9, 0xdf, 0xb0, 0xa0, 0x32, 0xb7, + 0x13, 0x78, 0x6e, 0x2d, 0x70, 0x23, 0xd4, 0x86, 0xf1, 0x56, 0x48, 0x36, 0x48, 0xa8, 0x40, 0x93, + 0xd6, 0x85, 0xf2, 0xa5, 0xe1, 0x6b, 0xd7, 0x72, 0xfa, 0x6d, 0x16, 0x5a, 0xf4, 0xe3, 0x70, 0x77, + 0xfe, 0x29, 0x51, 0xf5, 0x78, 0x0a, 0x8b, 0xd3, 0x75, 0xd8, 0xbf, 0x50, 0x82, 0xb3, 0x73, 0x5f, + 0x6b, 0x87, 0xa4, 0xea, 0x45, 0x0f, 0xd2, 0x53, 0xc1, 0xf5, 0xa2, 0x07, 0xb7, 0x93, 0xc1, 0x50, + 0x32, 0x58, 0x15, 0x70, 0xac, 0x28, 0xd0, 0x15, 0x18, 0xa4, 0xbf, 0xef, 0xe2, 0x65, 0xd1, 0xfb, + 0xd3, 0x82, 0x78, 0xb8, 0xea, 0xc4, 0x4e, 0x95, 0xa3, 0xb0, 0xa4, 0x41, 0xab, 0x30, 0xdc, 0x70, + 0x1a, 0x5b, 0x9e, 0xbf, 0xb9, 0x1a, 0xb8, 0x84, 0x7d, 0xe1, 0xca, 0xfc, 0x4b, 0x94, 0x7c, 0x21, + 0x01, 0x1f, 0xec, 0x4d, 0x4f, 0xf2, 0xb6, 0x09, 0x16, 0x1a, 0x0e, 0xeb, 0xe5, 0x91, 0xad, 0x26, + 0x62, 0x1f, 0xe3, 0x04, 0x19, 0x93, 0xf0, 0x92, 0x36, 0xa7, 0xfa, 0xd9, 0x9c, 0x1a, 0xe9, 0x32, + 0x9f, 0xfe, 0x91, 0x25, 0xc6, 0x64, 0xc9, 0x6b, 0x9a, 0xcb, 0xc3, 0x35, 0x80, 0x88, 0x34, 0x42, + 0x12, 0x6b, 0xa3, 0xa2, 0x3e, 0x73, 0x5d, 0x61, 0xb0, 0x46, 0x45, 0x27, 0x7f, 0xb4, 0xe5, 0x84, + 0x4c, 0x5a, 0xc4, 0xd8, 0xa8, 0xc9, 0x5f, 0x97, 0x08, 0x9c, 0xd0, 0x18, 0x93, 0xbf, 0x9c, 0x3b, + 0xf9, 0xff, 0xb9, 0x05, 0x83, 0xf3, 0x9e, 0xef, 0x7a, 0xfe, 0x26, 0x7a, 0x1b, 0x86, 0xb6, 0x49, + 0xec, 0xb8, 0x4e, 0xec, 0x88, 0x79, 0x7f, 0xe9, 0x70, 0xe1, 0xb9, 0xb3, 0xfe, 0x55, 0xd2, 0x88, + 0x57, 0x49, 0xec, 0x24, 0xdd, 0x48, 0x60, 0x58, 0x71, 0x43, 0x77, 0x61, 0x20, 0x76, 0xc2, 0x4d, + 0x12, 0x8b, 0xe9, 0x7e, 0xa5, 0x08, 0x5f, 0x4c, 0x45, 0x8d, 0xf8, 0x0d, 0x92, 0x2c, 0x8c, 0x6b, + 0x8c, 0x09, 0x16, 0xcc, 0xec, 0x06, 0x8c, 0x2c, 0x38, 0x2d, 0x67, 0xdd, 0x6b, 0x7a, 0xb1, 0x47, + 0x22, 0xf4, 0x29, 0x28, 0x3b, 0xae, 0xcb, 0x04, 0xbf, 0x32, 0x7f, 0x76, 0x7f, 0x6f, 0xba, 0x3c, + 0xe7, 0xba, 0x07, 0x7b, 0xd3, 0xa0, 0xa8, 0x76, 0x31, 0xa5, 0x40, 0x2f, 0x42, 0x9f, 0x1b, 0x06, + 0xad, 0xc9, 0x12, 0xa3, 0x3c, 0x47, 0x67, 0x68, 0x35, 0x0c, 0x5a, 0x29, 0x52, 0x46, 0x63, 0xff, + 0xeb, 0x12, 0xa0, 0x05, 0xd2, 0xda, 0x5a, 0xaa, 0x1b, 0xdf, 0xf2, 0x12, 0x0c, 0x6d, 0x07, 0xbe, + 0x17, 0x07, 0x61, 0x24, 0x2a, 0x64, 0xf2, 0xb0, 0x2a, 0x60, 0x58, 0x61, 0xd1, 0x05, 0xe8, 0x6b, + 0x25, 0xd3, 0x7a, 0x44, 0x2e, 0x09, 0x6c, 0x42, 0x33, 0x0c, 0xa5, 0x68, 0x47, 0x24, 0x14, 0x72, + 0xac, 0x28, 0xee, 0x46, 0x24, 0xc4, 0x0c, 0x93, 0x48, 0x0e, 0x95, 0x29, 0x21, 0xa5, 0x29, 0xc9, + 0xa1, 0x18, 0xac, 0x51, 0xa1, 0xf7, 0xa0, 0xc2, 0xff, 0x61, 0xb2, 0xc1, 0x44, 0x36, 0x77, 0x31, + 0x58, 0x09, 0x1a, 0x4e, 0x33, 0x3d, 0xf8, 0xa3, 0x4c, 0xd2, 0x24, 0x23, 0x9c, 0xf0, 0x34, 0x24, + 0x6d, 0x20, 0x57, 0xd2, 0xfe, 0x86, 0x05, 0x68, 0xc1, 0xf3, 0x5d, 0x12, 0x9e, 0xc0, 0x96, 0xd9, + 0xdb, 0x24, 0xf8, 0x03, 0xda, 0xb4, 0x60, 0xbb, 0x15, 0xf8, 0xc4, 0x8f, 0x17, 0x02, 0xdf, 0xe5, + 0xdb, 0xe8, 0x67, 0xa1, 0x2f, 0xa6, 0x55, 0xf1, 0x66, 0x5d, 0x94, 0x9f, 0x85, 0x56, 0x70, 0xb0, + 0x37, 0x7d, 0xae, 0xb3, 0x04, 0x6b, 0x02, 0x2b, 0x83, 0x3e, 0x03, 0x03, 0x51, 0xec, 0xc4, 0xed, + 0x48, 0x34, 0xf4, 0x13, 0xb2, 0xa1, 0x75, 0x06, 0x3d, 0xd8, 0x9b, 0x1e, 0x57, 0xc5, 0x38, 0x08, + 0x8b, 0x02, 0xe8, 0x05, 0x18, 0xdc, 0x26, 0x51, 0xe4, 0x6c, 0xca, 0x85, 0x6d, 0x5c, 0x94, 0x1d, + 0x5c, 0xe5, 0x60, 0x2c, 0xf1, 0xe8, 0x39, 0xe8, 0x27, 0x61, 0x18, 0x84, 0x42, 0x22, 0x46, 0x05, + 0x61, 0xff, 0x22, 0x05, 0x62, 0x8e, 0xb3, 0x7f, 0xdb, 0x82, 0x71, 0xd5, 0x56, 0x5e, 0xd7, 0x31, + 0x4e, 0x75, 0x17, 0xa0, 0x21, 0x3b, 0x16, 0xb1, 0x09, 0x36, 0x7c, 0xed, 0xd3, 0x87, 0xf3, 0xee, + 0x1c, 0xc8, 0xa4, 0x0e, 0x05, 0x8a, 0xb0, 0xc6, 0xd7, 0xfe, 0xb1, 0x05, 0xa7, 0x53, 0x7d, 0x5a, + 0xf1, 0xa2, 0x18, 0xfd, 0xd9, 0x8e, 0x7e, 0xcd, 0x1e, 0x52, 0xb7, 0xa6, 0x51, 0xce, 0xd0, 0xe2, + 0xac, 0x7b, 0x4a, 0x50, 0x24, 0x44, 0xeb, 0x1c, 0x86, 0x7e, 0x2f, 0x26, 0xdb, 0xb2, 0x5f, 0x57, + 0x0a, 0xf6, 0x8b, 0x37, 0x30, 0xf9, 0x3c, 0xcb, 0x94, 0x07, 0xe6, 0xac, 0xec, 0xff, 0x61, 0x41, + 0x65, 0x21, 0xf0, 0x37, 0xbc, 0xcd, 0x55, 0xa7, 0x75, 0x8c, 0x1f, 0xa6, 0x0e, 0x7d, 0x8c, 0x2b, + 0x6f, 0xfa, 0xd5, 0xbc, 0xa6, 0x8b, 0x06, 0xcd, 0xd0, 0xcd, 0x93, 0x6b, 0x05, 0x6a, 0x5d, 0xa2, + 0x20, 0xcc, 0x98, 0x4d, 0xbd, 0x06, 0x15, 0x45, 0x80, 0x26, 0xa0, 0xfc, 0x80, 0x70, 0x95, 0xb1, + 0x82, 0xe9, 0x4f, 0x74, 0x06, 0xfa, 0x77, 0x9c, 0x66, 0x5b, 0xcc, 0x56, 0xcc, 0xff, 0x7c, 0xb6, + 0x74, 0xdd, 0xb2, 0x7f, 0x60, 0xc1, 0x19, 0x55, 0xc9, 0x2d, 0xb2, 0x5b, 0x27, 0x4d, 0xd2, 0x88, + 0x83, 0x10, 0x7d, 0x60, 0xc1, 0x99, 0x66, 0xc6, 0x3a, 0x24, 0x46, 0xe3, 0x28, 0x2b, 0xd8, 0x33, + 0xa2, 0xe1, 0x67, 0xb2, 0xb0, 0x38, 0xb3, 0x36, 0xf4, 0x2c, 0xef, 0x0b, 0x9f, 0xbc, 0xc3, 0x82, + 0x41, 0xf9, 0x16, 0xd9, 0x65, 0x1d, 0xa3, 0xcd, 0x1f, 0x55, 0xcd, 0x3f, 0x09, 0xc9, 0x5b, 0x31, + 0x25, 0xef, 0x53, 0x05, 0x3f, 0x5f, 0x17, 0x99, 0xfb, 0x3b, 0x25, 0x38, 0xab, 0x68, 0x8c, 0xe5, + 0xf8, 0x09, 0x19, 0xfe, 0xde, 0xba, 0x7b, 0x8b, 0xec, 0xae, 0x05, 0x74, 0x3f, 0xcd, 0xee, 0x2e, + 0xba, 0x0a, 0xc3, 0x2e, 0xd9, 0x70, 0xda, 0xcd, 0x58, 0xa9, 0x8b, 0xfd, 0xdc, 0x8e, 0xa8, 0x26, + 0x60, 0xac, 0xd3, 0xd8, 0xbf, 0x55, 0x61, 0xb3, 0x32, 0x76, 0x3c, 0x9f, 0x84, 0x74, 0x83, 0xd6, + 0xb4, 0xfa, 0x11, 0x5d, 0xab, 0x17, 0x1a, 0xfc, 0x73, 0xd0, 0xef, 0x6d, 0xd3, 0x25, 0xbb, 0x64, + 0xae, 0xc4, 0xcb, 0x14, 0x88, 0x39, 0x0e, 0x3d, 0x0f, 0x83, 0x8d, 0x60, 0x7b, 0xdb, 0xf1, 0xdd, + 0xc9, 0x32, 0x53, 0x19, 0x86, 0xe9, 0xaa, 0xbe, 0xc0, 0x41, 0x58, 0xe2, 0xd0, 0x33, 0xd0, 0xe7, + 0x84, 0x9b, 0xd1, 0x64, 0x1f, 0xa3, 0x19, 0xa2, 0x35, 0xcd, 0x85, 0x9b, 0x11, 0x66, 0x50, 0xaa, + 0x0a, 0x3c, 0x0c, 0xc2, 0x07, 0x9e, 0xbf, 0x59, 0xf5, 0x42, 0xb6, 0xaf, 0x6b, 0xaa, 0xc0, 0x7d, + 0x85, 0xc1, 0x1a, 0x15, 0xaa, 0x41, 0x7f, 0x2b, 0x08, 0xe3, 0x68, 0x72, 0x80, 0x0d, 0xe7, 0x4b, + 0xb9, 0xd2, 0xc3, 0xfb, 0x5d, 0x0b, 0xc2, 0x38, 0xe9, 0x0a, 0xfd, 0x17, 0x61, 0xce, 0x08, 0x2d, + 0x40, 0x99, 0xf8, 0x3b, 0x93, 0x83, 0x8c, 0xdf, 0x27, 0x0f, 0xe7, 0xb7, 0xe8, 0xef, 0xdc, 0x73, + 0xc2, 0x64, 0x16, 0x2d, 0xfa, 0x3b, 0x98, 0x96, 0x46, 0x0d, 0xa8, 0x48, 0x47, 0x40, 0x34, 0x39, + 0x54, 0x44, 0xc0, 0xb0, 0x20, 0xc7, 0xe4, 0xfd, 0xb6, 0x17, 0x92, 0x6d, 0xe2, 0xc7, 0x51, 0xa2, + 0x0f, 0x4b, 0x6c, 0x84, 0x13, 0xbe, 0xa8, 0x01, 0x23, 0x5c, 0x7d, 0x58, 0x0d, 0xda, 0x7e, 0x1c, + 0x4d, 0x56, 0x58, 0x93, 0x73, 0x0c, 0xce, 0x7b, 0x49, 0x89, 0xf9, 0x33, 0x82, 0xfd, 0x88, 0x06, + 0x8c, 0xb0, 0xc1, 0x14, 0xbd, 0x03, 0xa3, 0x4d, 0x6f, 0x87, 0xf8, 0x24, 0x8a, 0x6a, 0x61, 0xb0, + 0x4e, 0x26, 0x81, 0xf5, 0xe6, 0xb9, 0x3c, 0xe3, 0x2b, 0x58, 0x27, 0xf3, 0xa7, 0xf6, 0xf7, 0xa6, + 0x47, 0x57, 0xf4, 0xd2, 0xd8, 0x64, 0x86, 0xde, 0x83, 0x31, 0xaa, 0xab, 0x78, 0x09, 0xfb, 0xe1, + 0xe2, 0xec, 0xd1, 0xfe, 0xde, 0xf4, 0x18, 0x36, 0x8a, 0xe3, 0x14, 0x3b, 0xb4, 0x06, 0x95, 0xa6, + 0xb7, 0x41, 0x1a, 0xbb, 0x8d, 0x26, 0x99, 0x1c, 0x61, 0xbc, 0x73, 0xa6, 0xdc, 0x8a, 0x24, 0xe7, + 0xfa, 0xa1, 0xfa, 0x8b, 0x13, 0x46, 0xe8, 0x1e, 0x9c, 0x8b, 0x49, 0xb8, 0xed, 0xf9, 0x0e, 0xdd, + 0xb4, 0x85, 0xf2, 0xc2, 0x2c, 0xdc, 0x51, 0x26, 0xb5, 0xe7, 0xc5, 0xc0, 0x9e, 0x5b, 0xcb, 0xa4, + 0xc2, 0x5d, 0x4a, 0xa3, 0x3b, 0x30, 0xce, 0xe6, 0x53, 0xad, 0xdd, 0x6c, 0xd6, 0x82, 0xa6, 0xd7, + 0xd8, 0x9d, 0x1c, 0x63, 0x0c, 0x9f, 0x97, 0x76, 0xeb, 0xb2, 0x89, 0xa6, 0x7a, 0x7d, 0xf2, 0x0f, + 0xa7, 0x4b, 0xa3, 0x26, 0x8c, 0x47, 0xa4, 0xd1, 0x0e, 0xbd, 0x78, 0x97, 0xca, 0x3e, 0x79, 0x14, + 0x4f, 0x8e, 0x17, 0xb1, 0x53, 0xea, 0x66, 0x21, 0xee, 0x34, 0x48, 0x01, 0x71, 0x9a, 0x35, 0x5d, + 0x2a, 0xa2, 0xd8, 0xf5, 0xfc, 0xc9, 0x09, 0xa6, 0x98, 0xaa, 0xf9, 0x55, 0xa7, 0x40, 0xcc, 0x71, + 0xcc, 0xec, 0xa3, 0x3f, 0xee, 0xd0, 0xb5, 0xf7, 0x14, 0x23, 0x4c, 0xcc, 0x3e, 0x89, 0xc0, 0x09, + 0x0d, 0xdd, 0xb0, 0xe2, 0x78, 0x77, 0x12, 0x31, 0x52, 0x35, 0xd5, 0xd6, 0xd6, 0xbe, 0x88, 0x29, + 0xdc, 0x5e, 0x87, 0x31, 0x35, 0xad, 0xd9, 0xe8, 0xa0, 0x69, 0xe8, 0xa7, 0x2b, 0x97, 0xb4, 0x5e, + 0x2a, 0xb4, 0x09, 0x74, 0x41, 0x8b, 0x30, 0x87, 0xb3, 0x26, 0x78, 0x5f, 0x23, 0xf3, 0xbb, 0x31, + 0xe1, 0x5a, 0x6c, 0x59, 0x6b, 0x82, 0x44, 0xe0, 0x84, 0xc6, 0xfe, 0xdf, 0x7c, 0x53, 0x4c, 0xd6, + 0x8e, 0x02, 0xeb, 0xe6, 0x65, 0x18, 0xda, 0x0a, 0xa2, 0x98, 0x52, 0xb3, 0x3a, 0xfa, 0x93, 0x5d, + 0xf0, 0xa6, 0x80, 0x63, 0x45, 0x81, 0x5e, 0x87, 0xd1, 0x86, 0x5e, 0x81, 0x58, 0xca, 0xcf, 0x8a, + 0x22, 0x66, 0xed, 0xd8, 0xa4, 0x45, 0xd7, 0x61, 0x88, 0xb9, 0xf2, 0x1a, 0x41, 0x53, 0xe8, 0xcb, + 0x72, 0x67, 0x1a, 0xaa, 0x09, 0xf8, 0x81, 0xf6, 0x1b, 0x2b, 0x6a, 0x6a, 0x75, 0xd0, 0x26, 0x2c, + 0xd7, 0xc4, 0x72, 0xab, 0xac, 0x8e, 0x9b, 0x0c, 0x8a, 0x05, 0xd6, 0xfe, 0xd5, 0x92, 0x36, 0xca, + 0x54, 0xe9, 0x23, 0xe8, 0x4b, 0x30, 0xf8, 0xd0, 0xf1, 0x62, 0xcf, 0xdf, 0x14, 0x3b, 0xe8, 0xcb, + 0x05, 0xd7, 0x5e, 0x56, 0xfc, 0x3e, 0x2f, 0xca, 0xf7, 0x09, 0xf1, 0x07, 0x4b, 0x86, 0x94, 0x77, + 0xd8, 0xf6, 0x7d, 0xca, 0xbb, 0xd4, 0x3b, 0x6f, 0xcc, 0x8b, 0x72, 0xde, 0xe2, 0x0f, 0x96, 0x0c, + 0xd1, 0x06, 0x80, 0x9c, 0x7d, 0xc4, 0x15, 0x2e, 0xb4, 0x9f, 0xea, 0x85, 0xfd, 0x9a, 0x2a, 0x3d, + 0x3f, 0x46, 0x77, 0xa6, 0xe4, 0x3f, 0xd6, 0x38, 0xdb, 0x6d, 0xa6, 0x88, 0x74, 0x36, 0x0b, 0xbd, + 0x43, 0x27, 0x80, 0x13, 0xc6, 0xc4, 0x9d, 0x8b, 0xc5, 0xd0, 0xbd, 0x54, 0x50, 0xa1, 0x5a, 0xf3, + 0xb6, 0x89, 0x3e, 0x5b, 0x04, 0x17, 0x9c, 0x30, 0xb4, 0xbf, 0x5f, 0x86, 0xc9, 0x6e, 0xed, 0xa5, + 0x32, 0x49, 0x1e, 0x79, 0xf1, 0x02, 0xd5, 0x15, 0x2c, 0x53, 0x26, 0x17, 0x05, 0x1c, 0x2b, 0x0a, + 0x2a, 0x1c, 0x91, 0xb7, 0xe9, 0x3b, 0x4d, 0x21, 0xbf, 0x4a, 0x38, 0xea, 0x0c, 0x8a, 0x05, 0x96, + 0xd2, 0x85, 0xc4, 0x89, 0x84, 0x0b, 0x57, 0x13, 0x22, 0xcc, 0xa0, 0x58, 0x60, 0x75, 0xf3, 0xaf, + 0x2f, 0xc7, 0xfc, 0x33, 0xc6, 0xa8, 0xff, 0x31, 0x8f, 0x11, 0x7a, 0x0f, 0x60, 0xc3, 0xf3, 0xbd, + 0x68, 0x8b, 0xb1, 0x1f, 0xe8, 0x9d, 0xbd, 0xd2, 0x4a, 0x96, 0x14, 0x1b, 0xac, 0xb1, 0x44, 0xaf, + 0xc2, 0xb0, 0x9a, 0xa1, 0xcb, 0xd5, 0xc9, 0x41, 0xd3, 0xf1, 0x97, 0x2c, 0x57, 0x55, 0xac, 0xd3, + 0xd9, 0x5f, 0x4d, 0x8b, 0x8c, 0x98, 0x18, 0xda, 0x08, 0x5b, 0x45, 0x47, 0xb8, 0x74, 0xf8, 0x08, + 0xdb, 0xff, 0xb1, 0x4c, 0x6d, 0x67, 0xad, 0xb2, 0x76, 0x54, 0x60, 0x51, 0x7b, 0x8b, 0xae, 0xf0, + 0x4e, 0x4c, 0xc4, 0xb4, 0xbc, 0xdc, 0xcb, 0xbc, 0xd1, 0xf7, 0x03, 0x3a, 0x1d, 0x38, 0x27, 0xb4, + 0x05, 0x95, 0xa6, 0x13, 0x31, 0x4b, 0x92, 0x88, 0xe9, 0xd8, 0x1b, 0xdb, 0x44, 0x0b, 0x77, 0xa2, + 0x58, 0xdb, 0x70, 0x79, 0x2d, 0x09, 0x73, 0xba, 0x3d, 0x51, 0xed, 0x40, 0x9e, 0x1c, 0xa8, 0xe6, + 0x50, 0x15, 0x62, 0x17, 0x73, 0x1c, 0xba, 0x0e, 0x23, 0x21, 0x61, 0xa2, 0xb2, 0x40, 0x15, 0x20, + 0x26, 0x7c, 0xfd, 0x89, 0xa6, 0x84, 0x35, 0x1c, 0x36, 0x28, 0x13, 0x45, 0x79, 0xe0, 0x10, 0x45, + 0xf9, 0x05, 0x18, 0x64, 0x3f, 0x94, 0x54, 0xa8, 0x2f, 0xb4, 0xcc, 0xc1, 0x58, 0xe2, 0xd3, 0x42, + 0x34, 0x54, 0x50, 0x88, 0x5e, 0x84, 0xb1, 0xaa, 0x43, 0xb6, 0x03, 0x7f, 0xd1, 0x77, 0x5b, 0x81, + 0xe7, 0xc7, 0x68, 0x12, 0xfa, 0xd8, 0x96, 0xc2, 0x67, 0x7c, 0x1f, 0xe5, 0x80, 0xfb, 0xa8, 0xb2, + 0x6b, 0xff, 0x1f, 0x0b, 0x46, 0xab, 0xa4, 0x49, 0x62, 0x72, 0xa7, 0xc5, 0xdc, 0x0f, 0x68, 0x09, + 0xd0, 0x66, 0xe8, 0x34, 0x48, 0x8d, 0x84, 0x5e, 0xe0, 0xd6, 0x49, 0x23, 0xf0, 0x99, 0xc3, 0x9d, + 0xee, 0x91, 0xe7, 0xf6, 0xf7, 0xa6, 0xd1, 0x8d, 0x0e, 0x2c, 0xce, 0x28, 0x81, 0x5c, 0x18, 0x6d, + 0x85, 0xc4, 0xf0, 0x97, 0x58, 0xf9, 0xfa, 0x79, 0x4d, 0x2f, 0xc2, 0xd5, 0x47, 0x03, 0x84, 0x4d, + 0xa6, 0xe8, 0xf3, 0x30, 0x11, 0x84, 0xad, 0x2d, 0xc7, 0xaf, 0x92, 0x16, 0xf1, 0x5d, 0xaa, 0x33, + 0x0b, 0xa7, 0xd8, 0x99, 0xfd, 0xbd, 0xe9, 0x89, 0x3b, 0x29, 0x1c, 0xee, 0xa0, 0xb6, 0x7f, 0xb9, + 0x04, 0x67, 0xab, 0xc1, 0x43, 0xff, 0xa1, 0x13, 0xba, 0x73, 0xb5, 0x65, 0xae, 0x08, 0x33, 0x27, + 0xa3, 0x74, 0x6e, 0x5a, 0x5d, 0x9d, 0x9b, 0x5f, 0x86, 0xa1, 0x0d, 0x8f, 0x34, 0x5d, 0x4c, 0x36, + 0x44, 0xf7, 0xae, 0x16, 0xf1, 0x68, 0x2c, 0xd1, 0x32, 0xd2, 0x2b, 0xc0, 0x7d, 0xab, 0x4b, 0x82, + 0x0d, 0x56, 0x0c, 0x51, 0x1b, 0x26, 0xa4, 0xa6, 0x2f, 0xb1, 0x62, 0x76, 0xbc, 0x5c, 0xcc, 0x90, + 0x30, 0xab, 0x61, 0xe3, 0x81, 0x53, 0x0c, 0x71, 0x47, 0x15, 0xd4, 0x42, 0xdb, 0xa6, 0xbb, 0x43, + 0x1f, 0x93, 0x15, 0x66, 0xa1, 0x31, 0x13, 0x92, 0x41, 0xed, 0x7f, 0x60, 0xc1, 0x53, 0x1d, 0xa3, + 0x25, 0xec, 0xeb, 0xb7, 0xa5, 0x61, 0xcb, 0x4f, 0x67, 0x72, 0x5a, 0x99, 0x39, 0xe6, 0xc5, 0x8c, + 0xdc, 0x52, 0x01, 0x23, 0xf7, 0x0e, 0x9c, 0x59, 0xdc, 0x6e, 0xc5, 0xbb, 0x55, 0xcf, 0xf4, 0xc9, + 0xbe, 0x06, 0x03, 0xdb, 0xc4, 0xf5, 0xda, 0xdb, 0xe2, 0xb3, 0x4e, 0xcb, 0x85, 0x74, 0x95, 0x41, + 0x0f, 0xf6, 0xa6, 0x47, 0xeb, 0x71, 0x10, 0x3a, 0x9b, 0x84, 0x03, 0xb0, 0x20, 0xb7, 0x3f, 0xb4, + 0x60, 0x5c, 0x4e, 0xa8, 0x39, 0xd7, 0x0d, 0x49, 0x14, 0xa1, 0x29, 0x28, 0x79, 0x2d, 0xc1, 0x08, + 0x04, 0xa3, 0xd2, 0x72, 0x0d, 0x97, 0xbc, 0x16, 0xfa, 0x12, 0x54, 0xb8, 0x2b, 0x3f, 0x11, 0x8e, + 0x1e, 0x8f, 0x06, 0x98, 0xf5, 0xb1, 0x26, 0x79, 0xe0, 0x84, 0x9d, 0xd4, 0x2c, 0xd9, 0x52, 0x5d, + 0x36, 0x1d, 0xcb, 0x37, 0x05, 0x1c, 0x2b, 0x0a, 0x74, 0x09, 0x86, 0xfc, 0xc0, 0xe5, 0xa7, 0x2c, + 0x7c, 0xdb, 0x65, 0x22, 0x77, 0x5b, 0xc0, 0xb0, 0xc2, 0xda, 0xdf, 0xb4, 0x60, 0x44, 0xf6, 0xb1, + 0xa0, 0x92, 0x4b, 0x27, 0x49, 0xa2, 0xe0, 0x26, 0x93, 0x84, 0x2a, 0xa9, 0x0c, 0x63, 0xe8, 0xa6, + 0xe5, 0x5e, 0x74, 0x53, 0xfb, 0xfb, 0x25, 0x18, 0x93, 0xcd, 0xa9, 0xb7, 0xd7, 0x23, 0x12, 0xa3, + 0x77, 0xa1, 0xe2, 0xf0, 0xc1, 0x27, 0x52, 0xce, 0xae, 0xe4, 0x59, 0xe8, 0xc6, 0x37, 0x4b, 0x14, + 0x83, 0x39, 0xc9, 0x07, 0x27, 0x2c, 0xd1, 0x0e, 0x9c, 0xf2, 0x83, 0x98, 0xed, 0x07, 0x0a, 0x5f, + 0xcc, 0x23, 0x9a, 0xae, 0xe7, 0x69, 0x51, 0xcf, 0xa9, 0xdb, 0x69, 0x7e, 0xb8, 0xb3, 0x0a, 0x74, + 0x47, 0x7a, 0x31, 0xca, 0xac, 0xae, 0x17, 0x8b, 0xd5, 0xd5, 0xdd, 0x89, 0x61, 0xff, 0xd0, 0x82, + 0x8a, 0x24, 0x3b, 0x4e, 0x9f, 0xf8, 0x7d, 0x18, 0x8c, 0xd8, 0xa7, 0x91, 0xc3, 0x74, 0xb9, 0x58, + 0xd3, 0xf9, 0xf7, 0x4c, 0x36, 0x3f, 0xfe, 0x3f, 0xc2, 0x92, 0x1b, 0x73, 0x43, 0xaa, 0x0e, 0x3c, + 0x79, 0x6e, 0x48, 0xd5, 0xb4, 0x2e, 0x6e, 0xc8, 0x5f, 0xb2, 0x60, 0x80, 0x3b, 0x87, 0x8a, 0x79, + 0xd8, 0x34, 0x5f, 0x72, 0xc2, 0xf1, 0x1e, 0x05, 0x0a, 0xd7, 0x32, 0xba, 0x0f, 0x15, 0xf6, 0x63, + 0x29, 0x0c, 0xb6, 0xc5, 0x46, 0xf0, 0x62, 0x11, 0xe7, 0x14, 0x5f, 0xf8, 0xf8, 0x6a, 0x72, 0x4f, + 0x32, 0xc0, 0x09, 0x2f, 0xfb, 0x07, 0x65, 0x3a, 0xeb, 0x13, 0x52, 0x63, 0x5b, 0xb3, 0x4e, 0x62, + 0x5b, 0x2b, 0x1d, 0xff, 0xb6, 0xf6, 0x3e, 0x8c, 0x37, 0x34, 0x9f, 0x7c, 0xb2, 0x99, 0x5e, 0x2b, + 0xe8, 0x6e, 0xd6, 0x1c, 0xf9, 0xdc, 0x19, 0xb2, 0x60, 0xb2, 0xc3, 0x69, 0xfe, 0x88, 0xc0, 0x08, + 0x3f, 0x50, 0x14, 0xf5, 0xf5, 0xe5, 0xca, 0x2c, 0xf7, 0xbb, 0xf0, 0x12, 0xaa, 0x32, 0x16, 0x74, + 0x52, 0xd7, 0x18, 0x61, 0x83, 0xad, 0xfd, 0xd7, 0xfa, 0xa1, 0x7f, 0x71, 0x87, 0xf8, 0xf1, 0x31, + 0xce, 0xf2, 0x6d, 0x18, 0xf3, 0xfc, 0x9d, 0xa0, 0xb9, 0x43, 0x5c, 0x8e, 0x3f, 0xda, 0x8e, 0x76, + 0x4e, 0x54, 0x32, 0xb6, 0x6c, 0x30, 0xc3, 0x29, 0xe6, 0xc7, 0x61, 0x4f, 0xbe, 0x05, 0x03, 0x5c, + 0x22, 0x84, 0x31, 0x99, 0xe3, 0x24, 0x65, 0x03, 0x2a, 0x66, 0x4e, 0x62, 0xf5, 0x72, 0xff, 0xac, + 0x60, 0x84, 0x1e, 0xc0, 0xd8, 0x86, 0x17, 0x46, 0x31, 0x35, 0x08, 0xa3, 0xd8, 0xd9, 0x6e, 0x1d, + 0xc5, 0x90, 0x54, 0x43, 0xb2, 0x64, 0xb0, 0xc2, 0x29, 0xd6, 0x68, 0x0b, 0x46, 0xa9, 0x1d, 0x93, + 0xd4, 0x35, 0xd8, 0x7b, 0x5d, 0xca, 0x97, 0xb4, 0xa2, 0x73, 0xc2, 0x26, 0x63, 0xba, 0x18, 0x35, + 0x98, 0xe1, 0x33, 0xc4, 0xb6, 0x74, 0xb5, 0x18, 0x71, 0x8b, 0x87, 0xe3, 0xe8, 0x9a, 0xc6, 0xce, + 0x8f, 0x2b, 0xe6, 0x9a, 0x96, 0x9c, 0x12, 0xdb, 0xdf, 0xa5, 0x1b, 0x10, 0x1d, 0xc5, 0x93, 0x58, + 0xbb, 0x6f, 0x9a, 0x6b, 0xf7, 0x73, 0x05, 0x3e, 0x6e, 0x97, 0x75, 0xfb, 0x2b, 0x30, 0xac, 0x7d, + 0x7b, 0x34, 0x0b, 0x95, 0x86, 0x3c, 0xea, 0x14, 0x0b, 0xb8, 0x52, 0x20, 0xd4, 0x19, 0x28, 0x4e, + 0x68, 0xe8, 0xc0, 0x50, 0xc5, 0x2b, 0x1d, 0x11, 0x41, 0xd5, 0x32, 0xcc, 0x30, 0xf6, 0xcb, 0x00, + 0x8b, 0x8f, 0x48, 0x63, 0xae, 0xc1, 0x0e, 0xe2, 0xb5, 0x73, 0x13, 0xab, 0xfb, 0xb9, 0x89, 0xfd, + 0x0e, 0x8c, 0x2e, 0x3e, 0xa2, 0x3b, 0xbb, 0x34, 0xd3, 0x2e, 0xc2, 0x00, 0x61, 0x00, 0xd6, 0xaa, + 0xa1, 0x44, 0x48, 0x39, 0x19, 0x16, 0x58, 0x76, 0x8c, 0xfe, 0xc8, 0x11, 0x13, 0x56, 0x33, 0x79, + 0x17, 0x29, 0x10, 0x73, 0x9c, 0xfd, 0x1d, 0x0b, 0xc6, 0x96, 0x16, 0x0c, 0x3d, 0x79, 0x06, 0x80, + 0xeb, 0x9b, 0xf7, 0xef, 0xdf, 0x96, 0x7e, 0x54, 0xee, 0xec, 0x52, 0x50, 0xac, 0x51, 0xa0, 0xa7, + 0xa1, 0xdc, 0x6c, 0xfb, 0x42, 0x0d, 0x1c, 0xdc, 0xdf, 0x9b, 0x2e, 0xaf, 0xb4, 0x7d, 0x4c, 0x61, + 0x5a, 0x60, 0x43, 0xb9, 0x70, 0x60, 0x43, 0x7e, 0x68, 0xdf, 0xb7, 0xcb, 0x30, 0xb1, 0xd4, 0x24, + 0x8f, 0x8c, 0x56, 0x5f, 0x84, 0x01, 0x37, 0xf4, 0x76, 0x48, 0x98, 0x76, 0x93, 0x54, 0x19, 0x14, + 0x0b, 0x6c, 0xe1, 0x58, 0x0b, 0x23, 0xce, 0xa4, 0x7c, 0xcc, 0x71, 0x26, 0xb9, 0x7d, 0x46, 0x1b, + 0x30, 0x18, 0xf0, 0xef, 0x3f, 0xd9, 0xcf, 0x04, 0xfd, 0xf5, 0xc3, 0x1b, 0x93, 0x1e, 0x9f, 0x19, + 0x21, 0x3d, 0xfc, 0xd0, 0x5b, 0x2d, 0x96, 0x02, 0x8a, 0x25, 0xf3, 0xa9, 0xcf, 0xc2, 0x88, 0x4e, + 0xd9, 0xd3, 0xe9, 0xf7, 0x5f, 0xb0, 0xe0, 0xf4, 0x52, 0x33, 0x68, 0x3c, 0x48, 0x05, 0xc3, 0xbc, + 0x0a, 0xc3, 0x74, 0xaa, 0x46, 0x46, 0x84, 0x98, 0x11, 0x0a, 0x27, 0x50, 0x58, 0xa7, 0xd3, 0x8a, + 0xdd, 0xbd, 0xbb, 0x5c, 0xcd, 0x8a, 0xa0, 0x13, 0x28, 0xac, 0xd3, 0xd9, 0xff, 0xc1, 0x82, 0x67, + 0x6f, 0x2c, 0x2c, 0xd6, 0xe8, 0x32, 0x12, 0xc5, 0xc4, 0x8f, 0x3b, 0x82, 0xf8, 0x2e, 0xc2, 0x40, + 0xcb, 0xd5, 0x9a, 0xa2, 0x44, 0xa0, 0x56, 0x65, 0xad, 0x10, 0xd8, 0x27, 0x25, 0x92, 0xf5, 0x97, + 0x2c, 0x38, 0x7d, 0xc3, 0x8b, 0x31, 0x69, 0x05, 0xe9, 0xb8, 0xbb, 0x90, 0xb4, 0x82, 0xc8, 0x8b, + 0x83, 0x70, 0x37, 0x1d, 0x77, 0x87, 0x15, 0x06, 0x6b, 0x54, 0xbc, 0xe6, 0x1d, 0x8f, 0x2e, 0xb0, + 0xa2, 0x53, 0x5a, 0xcd, 0x1c, 0x8e, 0x15, 0x05, 0xed, 0x98, 0xeb, 0x85, 0x4c, 0x17, 0xd9, 0x15, + 0x33, 0x58, 0x75, 0xac, 0x2a, 0x11, 0x38, 0xa1, 0xb1, 0xff, 0x96, 0x05, 0x67, 0x6f, 0x34, 0xdb, + 0x51, 0x4c, 0xc2, 0x8d, 0xc8, 0x68, 0xec, 0xcb, 0x50, 0x21, 0x52, 0x6f, 0x16, 0x6d, 0x55, 0x7b, + 0x92, 0x52, 0xa8, 0x79, 0xd0, 0x9f, 0xa2, 0x2b, 0x10, 0x63, 0xd6, 0x5b, 0x44, 0xd4, 0xbf, 0x28, + 0xc1, 0xe8, 0xcd, 0xb5, 0xb5, 0xda, 0x0d, 0x12, 0x8b, 0x35, 0x38, 0xdf, 0xd1, 0x53, 0xd3, 0xac, + 0xdc, 0xe1, 0x6b, 0x33, 0x5d, 0x66, 0x5d, 0x3b, 0xf6, 0x9a, 0x33, 0x3c, 0xc6, 0x7a, 0x66, 0xd9, + 0x8f, 0xef, 0x84, 0xf5, 0x38, 0xf4, 0xfc, 0xcd, 0x4c, 0xab, 0x58, 0xee, 0x13, 0xe5, 0x6e, 0xfb, + 0x04, 0x7a, 0x19, 0x06, 0xa2, 0xc6, 0x16, 0x51, 0x46, 0xfb, 0xc7, 0x95, 0x1a, 0xc2, 0xa0, 0x07, + 0x7b, 0xd3, 0x95, 0xbb, 0x78, 0x99, 0xff, 0xc1, 0x82, 0x14, 0xbd, 0x07, 0xc3, 0x5b, 0x71, 0xdc, + 0xba, 0x49, 0x1c, 0x97, 0x84, 0x72, 0x95, 0xc8, 0xd1, 0x02, 0xe9, 0x60, 0xf0, 0x02, 0xc9, 0xc4, + 0x4a, 0x60, 0x11, 0xd6, 0x39, 0xda, 0x75, 0x80, 0x04, 0xf7, 0x98, 0x4c, 0x1b, 0xfb, 0xcf, 0x97, + 0x60, 0xf0, 0xa6, 0xe3, 0xbb, 0x4d, 0x12, 0xa2, 0x25, 0xe8, 0x23, 0x8f, 0x48, 0xa3, 0x98, 0x02, + 0x9b, 0x6c, 0xa4, 0xdc, 0x53, 0x45, 0xff, 0x63, 0x56, 0x1e, 0x61, 0x18, 0xa4, 0xed, 0xbe, 0xa1, + 0x02, 0x33, 0x5f, 0xca, 0x1f, 0x05, 0x25, 0x12, 0x7c, 0x17, 0x16, 0x20, 0x2c, 0x19, 0x31, 0x9f, + 0x4e, 0xa3, 0x55, 0xa7, 0x8b, 0x5b, 0x5c, 0x2c, 0xf6, 0x7a, 0x6d, 0xa1, 0xc6, 0xc9, 0x05, 0x5f, + 0xee, 0xd3, 0x91, 0x40, 0x9c, 0xb0, 0xb3, 0xaf, 0xc3, 0x19, 0x76, 0x2a, 0xe8, 0xc4, 0x5b, 0xc6, + 0x9c, 0xc9, 0x15, 0x4e, 0xfb, 0xef, 0x96, 0xe0, 0xd4, 0x72, 0x7d, 0xa1, 0x6e, 0x7a, 0xe3, 0xae, + 0xc3, 0x08, 0xdf, 0x9e, 0xa9, 0xd0, 0x39, 0x4d, 0x51, 0x5e, 0xb9, 0xb1, 0xd7, 0x34, 0x1c, 0x36, + 0x28, 0xd1, 0xb3, 0x50, 0xf6, 0xde, 0xf7, 0xd3, 0xf1, 0x41, 0xcb, 0x6f, 0xdd, 0xc6, 0x14, 0x4e, + 0xd1, 0x74, 0xa7, 0xe7, 0x4b, 0x9c, 0x42, 0xab, 0xdd, 0xfe, 0x4d, 0x18, 0xf3, 0xa2, 0x46, 0xe4, + 0x2d, 0xfb, 0x74, 0xfe, 0x3b, 0x0d, 0x29, 0xbe, 0x89, 0xee, 0x4f, 0x9b, 0xaa, 0xb0, 0x38, 0x45, + 0xad, 0xad, 0xb7, 0xfd, 0x85, 0xb5, 0x85, 0xfc, 0x08, 0xcd, 0xaf, 0x42, 0x45, 0x45, 0xd2, 0xc8, + 0x00, 0x28, 0x2b, 0x3b, 0x00, 0xaa, 0xc0, 0x82, 0x23, 0x7d, 0xa4, 0xe5, 0x4c, 0x1f, 0xe9, 0x3f, + 0xb6, 0x20, 0x09, 0x1a, 0x40, 0x18, 0x2a, 0xad, 0x80, 0x1d, 0x40, 0x84, 0xf2, 0xb0, 0xef, 0xf9, + 0x1c, 0x49, 0xe4, 0x33, 0x81, 0xcb, 0x4a, 0x4d, 0x96, 0xc5, 0x09, 0x1b, 0xb4, 0x02, 0x83, 0xad, + 0x90, 0xd4, 0x63, 0x16, 0xe6, 0xdb, 0x03, 0x47, 0x26, 0xd5, 0x35, 0x5e, 0x12, 0x4b, 0x16, 0xf6, + 0xaf, 0x5b, 0x00, 0x2b, 0xde, 0xb6, 0x17, 0x63, 0xc7, 0xdf, 0x24, 0xc7, 0x68, 0x45, 0xde, 0x86, + 0xbe, 0xa8, 0x45, 0x1a, 0xc5, 0x8e, 0x8e, 0x92, 0x16, 0xd5, 0x5b, 0xa4, 0x91, 0x7c, 0x06, 0xfa, + 0x0f, 0x33, 0x3e, 0xf6, 0xaf, 0x00, 0x8c, 0x25, 0x64, 0x54, 0x8d, 0x47, 0x57, 0x8c, 0xb8, 0xd6, + 0xa7, 0x53, 0x71, 0xad, 0x15, 0x46, 0xad, 0x85, 0xb2, 0xc6, 0x50, 0xde, 0x76, 0x1e, 0x09, 0xab, + 0xe1, 0xd5, 0xa2, 0x0d, 0xa2, 0x35, 0xcd, 0xac, 0x3a, 0x8f, 0xb8, 0x1a, 0xf5, 0x92, 0x14, 0xa0, + 0x55, 0xe7, 0xd1, 0x01, 0x3f, 0x20, 0x62, 0x33, 0x90, 0x9a, 0x29, 0xdf, 0xf8, 0x4f, 0xc9, 0x7f, + 0xb6, 0x28, 0xd2, 0xea, 0x58, 0xad, 0x9e, 0x2f, 0x5c, 0x7d, 0x3d, 0xd6, 0xea, 0xf9, 0xe9, 0x5a, + 0x3d, 0xbf, 0x40, 0xad, 0x9e, 0x8f, 0x3e, 0xb0, 0x60, 0x50, 0x78, 0xc8, 0x59, 0xf8, 0xd5, 0xf0, + 0xb5, 0xcf, 0xf4, 0x54, 0xb5, 0x70, 0xb5, 0xf3, 0xea, 0x67, 0xa5, 0xee, 0x28, 0xa0, 0xb9, 0x4d, + 0x90, 0x55, 0xa3, 0x5f, 0xb4, 0x60, 0x4c, 0xfc, 0xc6, 0xe4, 0xfd, 0x36, 0x89, 0x62, 0xb1, 0x4b, + 0x7d, 0xfe, 0x28, 0xad, 0x11, 0x2c, 0x78, 0xa3, 0x7e, 0x4a, 0x2e, 0x31, 0x26, 0x32, 0xb7, 0x6d, + 0xa9, 0xf6, 0xa0, 0xef, 0x59, 0x70, 0x66, 0xdb, 0x79, 0xc4, 0x6b, 0xe4, 0x30, 0xec, 0xc4, 0x5e, + 0x20, 0x42, 0xcc, 0x96, 0x7a, 0x95, 0x93, 0x0e, 0x46, 0xbc, 0xb9, 0x6f, 0xc8, 0x63, 0xcb, 0x2c, + 0x92, 0xdc, 0x46, 0x67, 0xb6, 0x70, 0xca, 0x85, 0x21, 0x29, 0x98, 0x19, 0x5a, 0xfb, 0xbc, 0xbe, + 0x19, 0x1f, 0x3e, 0x03, 0xa5, 0x03, 0x6d, 0xe6, 0xad, 0xb6, 0xe3, 0xc7, 0x5e, 0xbc, 0xab, 0xe9, + 0xf8, 0xac, 0x16, 0x21, 0x88, 0xc7, 0x58, 0xcb, 0x16, 0x8c, 0xe8, 0x32, 0x77, 0x8c, 0x35, 0x05, + 0x70, 0x3a, 0x43, 0x9e, 0x8e, 0xb1, 0xc2, 0x36, 0x3c, 0xdd, 0x55, 0x2e, 0x8e, 0xaf, 0x5a, 0xfb, + 0x87, 0x96, 0xbe, 0x60, 0x9e, 0x84, 0x63, 0x66, 0xd5, 0x74, 0xcc, 0x5c, 0x2a, 0x3a, 0x75, 0xba, + 0x78, 0x67, 0x36, 0xf4, 0xf6, 0xd3, 0x9d, 0x00, 0xad, 0xc1, 0x40, 0x93, 0x42, 0xe4, 0x69, 0xd0, + 0xe5, 0x5e, 0x26, 0x67, 0xa2, 0x5c, 0x30, 0x78, 0x84, 0x05, 0x2f, 0xfb, 0x37, 0x2c, 0xe8, 0x3b, + 0x89, 0xe1, 0xa9, 0x99, 0xc3, 0xd3, 0x4d, 0x45, 0x15, 0x77, 0x3d, 0x67, 0xb0, 0xf3, 0x70, 0xf1, + 0x51, 0x4c, 0xfc, 0x88, 0xa9, 0x92, 0x99, 0x23, 0xf4, 0xcb, 0x25, 0x18, 0xa6, 0x15, 0x49, 0x3f, + 0xd1, 0xeb, 0x30, 0xda, 0x74, 0xd6, 0x49, 0x53, 0xba, 0x93, 0xd3, 0x66, 0xd7, 0x8a, 0x8e, 0xc4, + 0x26, 0x2d, 0x2d, 0xbc, 0xa1, 0x7b, 0xdb, 0x85, 0x4a, 0xa4, 0x0a, 0x1b, 0xae, 0x78, 0x6c, 0xd2, + 0x52, 0xcd, 0xff, 0xa1, 0x13, 0x37, 0xb6, 0x84, 0x49, 0xa6, 0x9a, 0x7b, 0x9f, 0x02, 0x31, 0xc7, + 0xa1, 0x39, 0x18, 0x97, 0x12, 0x7b, 0x8f, 0x0f, 0x9d, 0x50, 0x17, 0xd5, 0x3d, 0x3d, 0x6c, 0xa2, + 0x71, 0x9a, 0x1e, 0x7d, 0x16, 0xc6, 0xe8, 0xe0, 0x04, 0xed, 0x58, 0x06, 0x2b, 0xf4, 0xb3, 0x60, + 0x05, 0x16, 0x1c, 0xba, 0x66, 0x60, 0x70, 0x8a, 0xd2, 0x7e, 0x0f, 0x4e, 0xaf, 0x04, 0x8e, 0x3b, + 0xef, 0x34, 0x1d, 0xbf, 0x41, 0xc2, 0x65, 0x7f, 0x33, 0xf7, 0x5c, 0x57, 0x3f, 0x7b, 0x2d, 0xe5, + 0x9d, 0xbd, 0xda, 0x21, 0x20, 0xbd, 0x02, 0x11, 0x66, 0xf3, 0x0e, 0x0c, 0x7a, 0xbc, 0x2a, 0x21, + 0xb5, 0x57, 0xf3, 0x9c, 0x4a, 0x1d, 0x6d, 0xd4, 0xc2, 0x46, 0x38, 0x00, 0x4b, 0x96, 0xd4, 0x92, + 0xc8, 0xf2, 0x42, 0xe5, 0x1b, 0x6b, 0xf6, 0x5f, 0xb6, 0x60, 0xfc, 0x76, 0xea, 0x32, 0xd8, 0x45, + 0x18, 0x88, 0x48, 0x98, 0xe1, 0x52, 0xab, 0x33, 0x28, 0x16, 0xd8, 0xc7, 0x6e, 0xa6, 0xff, 0x5c, + 0x09, 0x2a, 0x2c, 0x66, 0xb3, 0xe5, 0x34, 0x8e, 0x53, 0x29, 0x5d, 0x35, 0x94, 0xd2, 0x1c, 0x23, + 0x51, 0x35, 0xa8, 0x9b, 0x4e, 0x8a, 0xee, 0xaa, 0xcb, 0x51, 0x85, 0xec, 0xc3, 0x84, 0x21, 0xbf, + 0x47, 0x33, 0x66, 0xde, 0xa5, 0x92, 0x17, 0xa7, 0xd8, 0x69, 0xa8, 0xa2, 0x7d, 0xf2, 0x4e, 0x43, + 0x55, 0xd3, 0xba, 0xac, 0x4a, 0x35, 0xad, 0xf5, 0x6c, 0xd9, 0xfe, 0x1c, 0x0b, 0xc0, 0x73, 0x9a, + 0xde, 0xd7, 0x88, 0xba, 0x64, 0x38, 0x2d, 0xe2, 0xe9, 0x04, 0xf4, 0x80, 0x2d, 0x30, 0xe2, 0x1f, + 0xbf, 0x3b, 0x9a, 0x14, 0xb1, 0x6f, 0xc2, 0x78, 0x6a, 0xec, 0xd0, 0xab, 0xd0, 0xdf, 0xda, 0x72, + 0x22, 0x92, 0x8a, 0xec, 0xe8, 0xaf, 0x51, 0xe0, 0xc1, 0xde, 0xf4, 0x98, 0x2a, 0xc0, 0x20, 0x98, + 0x53, 0xdb, 0x7f, 0x6c, 0x41, 0xdf, 0xed, 0xc0, 0x3d, 0x4e, 0x19, 0xbb, 0x69, 0xc8, 0xd8, 0xc5, + 0xfc, 0x1b, 0xe7, 0x5d, 0xc5, 0xab, 0x96, 0x12, 0xaf, 0x4b, 0x05, 0x78, 0x1d, 0x2e, 0x59, 0xdb, + 0x30, 0xcc, 0x6e, 0xb4, 0x8b, 0x90, 0x96, 0x97, 0x0d, 0x03, 0x6a, 0x3a, 0x65, 0x40, 0x8d, 0x6b, + 0xa4, 0x9a, 0x19, 0xf5, 0x02, 0x0c, 0x8a, 0x10, 0x8a, 0x74, 0xd4, 0xa1, 0xa0, 0xc5, 0x12, 0x6f, + 0xff, 0x5a, 0x19, 0x8c, 0x1b, 0xf4, 0xe8, 0x47, 0x16, 0xcc, 0x84, 0xfc, 0xca, 0x83, 0x5b, 0x6d, + 0x87, 0x9e, 0xbf, 0x59, 0x6f, 0x6c, 0x11, 0xb7, 0xdd, 0xf4, 0xfc, 0xcd, 0xe5, 0x4d, 0x3f, 0x50, + 0xe0, 0xc5, 0x47, 0xa4, 0xd1, 0x66, 0xde, 0xd5, 0xc2, 0x17, 0xf7, 0xd5, 0x19, 0xea, 0xb5, 0xfd, + 0xbd, 0xe9, 0x19, 0xdc, 0x53, 0x2d, 0xb8, 0xc7, 0x56, 0xa1, 0xdf, 0xb3, 0x60, 0x96, 0xdf, 0x21, + 0x2f, 0xde, 0x93, 0x42, 0x86, 0x67, 0x4d, 0x32, 0x4d, 0xd8, 0xad, 0x91, 0x70, 0x7b, 0xfe, 0x35, + 0x31, 0xc8, 0xb3, 0xb5, 0xde, 0x6a, 0xc5, 0xbd, 0x36, 0xd3, 0xfe, 0x57, 0x65, 0x18, 0xa5, 0xe3, + 0x99, 0xdc, 0x1f, 0x7d, 0xd5, 0x10, 0x93, 0x4f, 0xa4, 0xc4, 0xe4, 0x94, 0x41, 0xfc, 0x78, 0xae, + 0x8e, 0xc6, 0x70, 0xaa, 0xe9, 0x44, 0xf1, 0x4d, 0xe2, 0x84, 0xf1, 0x3a, 0x71, 0xd8, 0x81, 0xa5, + 0x98, 0x04, 0x3d, 0x1d, 0x82, 0xaa, 0xb8, 0x9c, 0x95, 0x34, 0x37, 0xdc, 0x59, 0x01, 0x7a, 0x08, + 0x88, 0x9d, 0x8e, 0x86, 0x8e, 0x1f, 0xf1, 0xce, 0x78, 0xc2, 0x21, 0xdb, 0x63, 0xb5, 0x53, 0xa2, + 0x5a, 0xb4, 0xd2, 0xc1, 0x0e, 0x67, 0x54, 0xa1, 0x1d, 0x81, 0xf7, 0x17, 0x3d, 0x02, 0x1f, 0xc8, + 0x09, 0xf8, 0xfd, 0x59, 0x0b, 0x4e, 0xd3, 0x0f, 0x63, 0x06, 0x87, 0x46, 0x28, 0x80, 0x71, 0xda, + 0x83, 0x26, 0x89, 0x25, 0x4c, 0xcc, 0xb0, 0x1c, 0x5d, 0xda, 0xe4, 0x93, 0x68, 0x6c, 0xb7, 0x4c, + 0x66, 0x38, 0xcd, 0xdd, 0xfe, 0x35, 0x0b, 0x58, 0xf4, 0xd9, 0x49, 0xec, 0x63, 0x37, 0xcc, 0x7d, + 0xcc, 0xce, 0x5f, 0x34, 0xba, 0x6c, 0x61, 0xaf, 0xc0, 0x04, 0xc5, 0xd6, 0xc2, 0xe0, 0xd1, 0xae, + 0x54, 0xae, 0xf3, 0x7d, 0xb3, 0x7f, 0xc9, 0xe2, 0xcb, 0x9d, 0xd2, 0x8a, 0x1f, 0xc2, 0x29, 0x5f, + 0xfb, 0x4f, 0x27, 0xb2, 0x54, 0x02, 0x67, 0x8a, 0x2f, 0x68, 0x6c, 0xfe, 0x6b, 0x11, 0x66, 0x29, + 0x86, 0xb8, 0xb3, 0x0e, 0xfb, 0xef, 0x59, 0xf0, 0x94, 0x4e, 0xa8, 0x5d, 0x33, 0xcb, 0x73, 0x88, + 0x56, 0x61, 0x28, 0x68, 0x91, 0xd0, 0x49, 0x2c, 0x80, 0x4b, 0x72, 0xc4, 0xef, 0x08, 0xf8, 0xc1, + 0xde, 0xf4, 0x19, 0x9d, 0xbb, 0x84, 0x63, 0x55, 0x12, 0xd9, 0x30, 0xc0, 0x2c, 0xd1, 0x48, 0x5c, + 0x10, 0x64, 0x99, 0x28, 0xd8, 0x31, 0x40, 0x84, 0x05, 0xc6, 0xfe, 0x2b, 0x16, 0x1f, 0x65, 0xbd, + 0xe9, 0xe8, 0xeb, 0x30, 0xb1, 0x4d, 0x8d, 0x85, 0xc5, 0x47, 0x2d, 0xba, 0x85, 0xb0, 0xe3, 0x4f, + 0xab, 0xc8, 0xc2, 0xd9, 0xa5, 0xbb, 0xf3, 0x93, 0xa2, 0xf5, 0x13, 0xab, 0x29, 0xb6, 0xb8, 0xa3, + 0x22, 0xfb, 0xf7, 0x85, 0xac, 0x32, 0xad, 0xe5, 0x05, 0x18, 0x6c, 0x05, 0xee, 0xc2, 0x72, 0x15, + 0x8b, 0xb1, 0x52, 0x93, 0xad, 0xc6, 0xc1, 0x58, 0xe2, 0xd1, 0x35, 0x00, 0xf2, 0x28, 0x26, 0xa1, + 0xef, 0x34, 0xd5, 0xb1, 0xa5, 0x52, 0x12, 0x16, 0x15, 0x06, 0x6b, 0x54, 0xb4, 0x4c, 0x2b, 0x0c, + 0x76, 0x3c, 0x97, 0x85, 0x7b, 0x97, 0xcd, 0x32, 0x35, 0x85, 0xc1, 0x1a, 0x15, 0x35, 0xd1, 0xda, + 0x7e, 0xc4, 0x17, 0x70, 0x67, 0x5d, 0x24, 0x50, 0x18, 0x4a, 0x4c, 0xb4, 0xbb, 0x3a, 0x12, 0x9b, + 0xb4, 0xf6, 0x6f, 0x57, 0x00, 0x12, 0x15, 0x01, 0x7d, 0x60, 0xc1, 0x50, 0xc3, 0x69, 0x39, 0x0d, + 0x9e, 0x1d, 0xa7, 0x9c, 0x7f, 0x2f, 0x26, 0x29, 0x3c, 0xb3, 0x20, 0x0a, 0x72, 0xdf, 0xd6, 0xa7, + 0xa5, 0x80, 0x48, 0x70, 0xae, 0x3f, 0x4b, 0xd5, 0x8c, 0xbe, 0x65, 0xc1, 0xb0, 0xd3, 0x6c, 0x06, + 0x0d, 0x27, 0x66, 0x3d, 0x2a, 0x15, 0x71, 0x56, 0x6a, 0x2d, 0x99, 0x4b, 0xca, 0xf2, 0xc6, 0xbc, + 0x2c, 0x4f, 0xb5, 0x34, 0x4c, 0x6e, 0x7b, 0xf4, 0x26, 0xa0, 0x4f, 0x4b, 0xd5, 0x92, 0x7f, 0x94, + 0xa9, 0xb4, 0x6a, 0x59, 0x61, 0x4b, 0x83, 0xa6, 0x55, 0xa2, 0xf7, 0x8c, 0x5c, 0x01, 0x7d, 0x45, + 0xee, 0xa6, 0x1a, 0x9b, 0x66, 0x5e, 0x9a, 0x00, 0xf4, 0x25, 0x3d, 0x12, 0xb6, 0xbf, 0xc8, 0xc5, + 0x4f, 0x4d, 0x77, 0xcb, 0x89, 0x82, 0x8d, 0x61, 0xdc, 0x35, 0x37, 0x09, 0x11, 0xda, 0x74, 0x35, + 0xbf, 0x86, 0xd4, 0xee, 0x92, 0x6c, 0x0b, 0x29, 0x04, 0x4e, 0x57, 0x81, 0xbe, 0xc4, 0xe3, 0x94, + 0x97, 0xfd, 0x8d, 0x40, 0x44, 0x37, 0x5d, 0x2e, 0xf0, 0xcd, 0x77, 0xa3, 0x98, 0x6c, 0xd3, 0x32, + 0xc9, 0x36, 0x70, 0x5b, 0x70, 0xc1, 0x8a, 0x1f, 0x5a, 0x83, 0x01, 0x76, 0xab, 0x22, 0x9a, 0x1c, + 0x2a, 0xe2, 0x26, 0x32, 0xef, 0x13, 0x26, 0x9b, 0x2f, 0xfb, 0x1b, 0x61, 0xc1, 0x0b, 0xdd, 0x94, + 0xf7, 0x6f, 0xa3, 0x65, 0xff, 0x6e, 0x44, 0xd8, 0xfd, 0xdb, 0xca, 0xfc, 0x27, 0x93, 0x0b, 0xb5, + 0x1c, 0x9e, 0x99, 0x1d, 0xc9, 0x28, 0x49, 0xf7, 0x60, 0xf1, 0x5f, 0x26, 0x5d, 0x9a, 0x84, 0x22, + 0x0d, 0x35, 0x53, 0x34, 0x25, 0x83, 0x7d, 0xcf, 0x64, 0x86, 0xd3, 0xdc, 0xa7, 0x3c, 0x18, 0x35, + 0x66, 0xec, 0x31, 0x3a, 0x3b, 0x9b, 0x30, 0x91, 0x9e, 0x92, 0xc7, 0xe8, 0xe3, 0xfc, 0xa3, 0x3e, + 0x18, 0x33, 0x05, 0x03, 0xcd, 0x42, 0x65, 0x9b, 0xa5, 0x44, 0x4a, 0x12, 0xb1, 0x28, 0xf9, 0x5f, + 0x95, 0x08, 0x9c, 0xd0, 0xb0, 0x94, 0x34, 0xac, 0xb8, 0x16, 0x73, 0x92, 0xa4, 0xa4, 0x51, 0x18, + 0xac, 0x51, 0x51, 0x85, 0x6d, 0x3d, 0x08, 0x62, 0xb5, 0x70, 0x2b, 0x99, 0x99, 0x67, 0x50, 0x2c, + 0xb0, 0x74, 0xc1, 0x7e, 0x40, 0x3b, 0xd4, 0x34, 0xfd, 0x5d, 0x6a, 0xc1, 0xbe, 0xa5, 0x23, 0xb1, + 0x49, 0x4b, 0x37, 0xa0, 0x20, 0x62, 0x42, 0x28, 0xd4, 0xc2, 0x24, 0x86, 0xa7, 0xce, 0x6f, 0x19, + 0x49, 0x3c, 0xfa, 0x22, 0x3c, 0xa5, 0x2e, 0x05, 0x61, 0xee, 0x3f, 0x94, 0x35, 0x0e, 0x18, 0xb6, + 0xdd, 0x53, 0x0b, 0xd9, 0x64, 0xb8, 0x5b, 0x79, 0xf4, 0x26, 0x8c, 0x09, 0x95, 0x4e, 0x72, 0x1c, + 0x34, 0x8f, 0x78, 0x6f, 0x19, 0x58, 0x9c, 0xa2, 0x46, 0x55, 0x98, 0xa0, 0x10, 0xa6, 0x4a, 0x49, + 0x0e, 0xfc, 0x72, 0x93, 0xda, 0x99, 0x6f, 0xa5, 0xf0, 0xb8, 0xa3, 0x04, 0x9a, 0x83, 0x71, 0xae, + 0x5b, 0x50, 0x0b, 0x86, 0x7d, 0x07, 0x11, 0x8d, 0xa8, 0x26, 0xc1, 0x1d, 0x13, 0x8d, 0xd3, 0xf4, + 0xe8, 0x3a, 0x8c, 0x38, 0x61, 0x63, 0xcb, 0x8b, 0x49, 0x23, 0x6e, 0x87, 0xfc, 0x66, 0xbb, 0x76, + 0x46, 0x3e, 0xa7, 0xe1, 0xb0, 0x41, 0x69, 0x7f, 0x0d, 0x4e, 0x67, 0x04, 0x3d, 0x53, 0xc1, 0x71, + 0x5a, 0x9e, 0xec, 0x53, 0x2a, 0x1a, 0x67, 0xae, 0xb6, 0x2c, 0x7b, 0xa3, 0x51, 0x51, 0xe9, 0x64, + 0x8e, 0x53, 0x2d, 0x3f, 0x9a, 0x92, 0xce, 0x25, 0x89, 0xc0, 0x09, 0x8d, 0xfd, 0x5f, 0x2b, 0xa0, + 0xb9, 0x19, 0x0a, 0xc4, 0x60, 0x5c, 0x87, 0x11, 0x99, 0xf2, 0x4f, 0x4b, 0xb5, 0xa5, 0xba, 0x79, + 0x43, 0xc3, 0x61, 0x83, 0x92, 0xb6, 0xcd, 0x97, 0x4e, 0x93, 0x74, 0xec, 0x8f, 0xf2, 0xa6, 0xe0, + 0x84, 0x06, 0x5d, 0x86, 0xa1, 0x88, 0x34, 0x37, 0x56, 0x3c, 0xff, 0x81, 0x10, 0x6c, 0xb5, 0x2a, + 0xd7, 0x05, 0x1c, 0x2b, 0x0a, 0xf4, 0x79, 0x28, 0xb7, 0x3d, 0x57, 0x88, 0xf2, 0x8c, 0xd4, 0x3b, + 0xef, 0x2e, 0x57, 0x0f, 0xf6, 0xa6, 0xa7, 0xb3, 0xf3, 0x18, 0x52, 0x33, 0x32, 0x9a, 0xa1, 0x93, + 0x8f, 0x16, 0xcd, 0xf2, 0x1f, 0x0f, 0xf4, 0xe8, 0x3f, 0xbe, 0x06, 0x20, 0xfa, 0x2c, 0x25, 0xb9, + 0x9c, 0x7c, 0xb3, 0x1b, 0x0a, 0x83, 0x35, 0x2a, 0x6a, 0x8c, 0x36, 0x42, 0xe2, 0x48, 0x6b, 0x8d, + 0x47, 0xe4, 0x0e, 0x7d, 0x04, 0x63, 0x74, 0x21, 0xcd, 0x0d, 0x77, 0x56, 0x80, 0x5a, 0x70, 0xca, + 0xa5, 0xf3, 0xc8, 0xa8, 0xb5, 0x72, 0x84, 0x38, 0x60, 0x5a, 0x63, 0x35, 0xcd, 0x09, 0x77, 0x32, + 0x47, 0xef, 0xc2, 0x94, 0x04, 0x76, 0x5e, 0xfb, 0x63, 0xd3, 0xa5, 0x3c, 0x7f, 0x7e, 0x7f, 0x6f, + 0x7a, 0xaa, 0xda, 0x95, 0x0a, 0x1f, 0xc2, 0x01, 0xbd, 0x03, 0x03, 0xec, 0xc4, 0x21, 0x9a, 0x1c, + 0x66, 0xbb, 0xdd, 0x2b, 0x45, 0x1d, 0x6e, 0x33, 0xec, 0xdc, 0x42, 0x04, 0x32, 0x26, 0xa7, 0x38, + 0x0c, 0x88, 0x05, 0x4f, 0xd4, 0x82, 0x61, 0xc7, 0xf7, 0x83, 0xd8, 0xe1, 0x4a, 0xd8, 0x48, 0x11, + 0x3d, 0x52, 0xab, 0x62, 0x2e, 0x29, 0xcb, 0xeb, 0x51, 0xd1, 0x51, 0x1a, 0x06, 0xeb, 0x55, 0xd0, + 0x6d, 0x3c, 0x78, 0x48, 0x17, 0x4c, 0xe9, 0x74, 0x8f, 0x26, 0x47, 0x8b, 0x6c, 0xe3, 0x77, 0x8c, + 0x42, 0xda, 0x0a, 0x66, 0x32, 0xc3, 0x69, 0xee, 0x68, 0xc6, 0xf0, 0xa3, 0x8e, 0x25, 0x61, 0xba, + 0x89, 0x1f, 0x55, 0x77, 0x9b, 0xb2, 0x2b, 0xa5, 0x3c, 0x34, 0x8f, 0xad, 0x04, 0xe3, 0xa9, 0x2b, + 0xa5, 0x09, 0x0a, 0xeb, 0x74, 0x53, 0x9f, 0x81, 0x61, 0x6d, 0xc0, 0x7b, 0x89, 0x07, 0x9d, 0x7a, + 0x13, 0x26, 0xd2, 0x03, 0xd9, 0x53, 0x3c, 0xe9, 0x7f, 0x2f, 0xc1, 0x78, 0xc6, 0x49, 0xc6, 0x03, + 0x8f, 0x45, 0x4c, 0x1b, 0x4b, 0xde, 0x2d, 0xcf, 0x77, 0x31, 0xc3, 0x98, 0x0b, 0x57, 0xa9, 0xc0, + 0xc2, 0x25, 0x57, 0xd1, 0x72, 0xd7, 0x55, 0x54, 0x2c, 0x56, 0x7d, 0x47, 0x5f, 0xac, 0xcc, 0xdd, + 0xa1, 0xbf, 0xd0, 0xee, 0xf0, 0x18, 0x16, 0x38, 0x63, 0x83, 0x19, 0x2c, 0xb0, 0xc1, 0x1c, 0x58, + 0x30, 0x66, 0x4a, 0x5e, 0x81, 0x11, 0x7f, 0x52, 0x07, 0x70, 0x86, 0x19, 0x62, 0x71, 0x18, 0x34, + 0x9b, 0x24, 0x14, 0x91, 0x62, 0x63, 0xc2, 0xae, 0x12, 0x50, 0xac, 0x51, 0xd8, 0xbf, 0x58, 0x82, + 0x89, 0x24, 0x6c, 0x58, 0xa4, 0x3e, 0x3d, 0xbe, 0xa3, 0x81, 0x35, 0xe3, 0x68, 0x20, 0x2f, 0xa3, + 0x69, 0xaa, 0x5d, 0x5d, 0x8f, 0x09, 0xde, 0x49, 0x1d, 0x13, 0xbc, 0xd2, 0x23, 0xdf, 0xc3, 0x8f, + 0x0c, 0xfe, 0x49, 0x09, 0xce, 0xa6, 0x8b, 0x2c, 0x34, 0x1d, 0x6f, 0xfb, 0x18, 0xc7, 0xe9, 0x8b, + 0xc6, 0x38, 0xbd, 0xd6, 0x5b, 0x7f, 0x58, 0xe3, 0xba, 0x0e, 0x96, 0x93, 0x1a, 0xac, 0xcf, 0x1c, + 0x85, 0xf9, 0xe1, 0x23, 0xf6, 0x3b, 0x16, 0x3c, 0x9d, 0x59, 0xee, 0x24, 0x5c, 0xa0, 0x6f, 0x9b, + 0x2e, 0xd0, 0x97, 0x8f, 0xd0, 0xbd, 0x2e, 0x3e, 0xd1, 0xff, 0x5c, 0xea, 0xd2, 0x2d, 0xe6, 0x2d, + 0xbb, 0x03, 0xc3, 0x4e, 0xa3, 0x41, 0xa2, 0x68, 0x35, 0x70, 0x55, 0x2e, 0x9e, 0x2b, 0x6c, 0xff, + 0x4c, 0xc0, 0x07, 0x7b, 0xd3, 0x53, 0x69, 0x16, 0x09, 0x1a, 0xeb, 0x1c, 0xcc, 0x9c, 0x5a, 0xa5, + 0x63, 0xca, 0xa9, 0x75, 0x0d, 0x60, 0x47, 0x59, 0xe9, 0x69, 0x27, 0x9c, 0x66, 0xbf, 0x6b, 0x54, + 0xe8, 0x5d, 0xa6, 0xf5, 0xf2, 0x10, 0x89, 0xbe, 0xdc, 0x09, 0x67, 0x7c, 0x40, 0x3d, 0xde, 0x82, + 0xdf, 0x99, 0x54, 0x1e, 0x4b, 0xc5, 0xd3, 0xfe, 0x6e, 0x19, 0x3e, 0x7e, 0x88, 0xd8, 0xa1, 0x39, + 0xf3, 0xe4, 0xf3, 0xa5, 0xb4, 0x7b, 0x6a, 0x2a, 0xb3, 0xb0, 0xe1, 0xaf, 0x4a, 0x7d, 0xac, 0xd2, + 0x47, 0xfe, 0x58, 0xdf, 0xd6, 0x9d, 0x89, 0x3c, 0xd4, 0xf1, 0xc6, 0x91, 0x27, 0xd6, 0xe3, 0xf3, + 0x2e, 0x9e, 0xa0, 0xe3, 0xc3, 0xfe, 0x86, 0x05, 0x9f, 0xc8, 0xec, 0x94, 0x11, 0x60, 0x31, 0x0b, + 0x95, 0x06, 0x05, 0x6a, 0x77, 0x51, 0x92, 0x2b, 0x66, 0x12, 0x81, 0x13, 0x1a, 0x23, 0x8e, 0xa2, + 0x94, 0x1b, 0x47, 0xf1, 0x6f, 0x2d, 0x38, 0x93, 0x6e, 0xc4, 0x49, 0xac, 0x3a, 0x75, 0x73, 0xd5, + 0x99, 0xe9, 0xed, 0xdb, 0x77, 0x59, 0x70, 0x7e, 0x61, 0x04, 0xce, 0x75, 0x6c, 0x56, 0x7c, 0x18, + 0x7f, 0xc6, 0x82, 0x53, 0x9b, 0xcc, 0xbe, 0xd0, 0x6e, 0xfc, 0x88, 0x8e, 0xe5, 0x5c, 0x93, 0x3a, + 0xf4, 0xa2, 0x10, 0xb7, 0x96, 0x3a, 0x48, 0x70, 0x67, 0x65, 0xe8, 0x9b, 0x16, 0x9c, 0x71, 0x1e, + 0x46, 0x1d, 0x79, 0xf4, 0x85, 0x1c, 0xbd, 0x99, 0xe3, 0xca, 0xcb, 0xc9, 0xc0, 0x3f, 0x3f, 0xb9, + 0xbf, 0x37, 0x7d, 0x26, 0x8b, 0x0a, 0x67, 0xd6, 0x8a, 0xde, 0x11, 0xf9, 0xc7, 0xa8, 0xda, 0x57, + 0xe8, 0xee, 0x5a, 0xd6, 0xfd, 0x03, 0xbe, 0x26, 0x49, 0x0c, 0x56, 0x1c, 0xd1, 0x57, 0xa0, 0xb2, + 0x29, 0x2f, 0xf9, 0x88, 0x45, 0x2f, 0x67, 0x67, 0xc9, 0xbc, 0x13, 0xc4, 0xa3, 0xdc, 0x15, 0x0a, + 0x27, 0x4c, 0xd1, 0x4d, 0x28, 0xfb, 0x1b, 0x91, 0xb8, 0xaf, 0x9b, 0x17, 0x47, 0x63, 0x46, 0x2d, + 0xf1, 0x1b, 0x88, 0xb7, 0x97, 0xea, 0x98, 0xb2, 0xa0, 0x9c, 0xc2, 0x75, 0x57, 0xf8, 0xb0, 0x73, + 0x38, 0xe1, 0xf9, 0x6a, 0x27, 0x27, 0x3c, 0x5f, 0xc5, 0x94, 0x05, 0x0b, 0xd8, 0x8b, 0x1a, 0x91, + 0x27, 0x1c, 0xd4, 0x39, 0x97, 0xb9, 0x3b, 0x6e, 0x65, 0xf0, 0x54, 0x74, 0x0c, 0x8c, 0x39, 0x23, + 0xb4, 0x06, 0x03, 0x0d, 0x96, 0x3a, 0x5a, 0xf8, 0x0f, 0xf2, 0x12, 0x0a, 0x77, 0xa4, 0x99, 0xe6, + 0x07, 0x69, 0x1c, 0x8e, 0x05, 0x2f, 0xc6, 0x95, 0xb4, 0xb6, 0x36, 0x22, 0xe1, 0x1f, 0xc8, 0xe3, + 0xda, 0x91, 0x04, 0x5c, 0x70, 0x65, 0x70, 0x2c, 0x78, 0xa1, 0x2a, 0x94, 0x36, 0x1a, 0x22, 0xff, + 0x63, 0x8e, 0x45, 0x6b, 0x5e, 0x27, 0x9d, 0x1f, 0xd8, 0xdf, 0x9b, 0x2e, 0x2d, 0x2d, 0xe0, 0xd2, + 0x46, 0x03, 0xbd, 0x0d, 0x83, 0x1b, 0xfc, 0x82, 0xa0, 0xc8, 0xf5, 0x78, 0x35, 0xef, 0x16, 0x63, + 0xc7, 0x6d, 0x42, 0x7e, 0x93, 0x41, 0x20, 0xb0, 0x64, 0x87, 0xde, 0x05, 0xd8, 0x50, 0x57, 0x1e, + 0x45, 0xb2, 0xc7, 0x99, 0xde, 0xae, 0x48, 0x0a, 0xeb, 0x59, 0x41, 0xb1, 0xc6, 0x91, 0xca, 0xbc, + 0x23, 0xb3, 0xdf, 0xb3, 0x44, 0x8f, 0xb9, 0x32, 0x9f, 0x99, 0x2c, 0x9f, 0xcb, 0xbc, 0x42, 0xe1, + 0x84, 0x29, 0x6a, 0xc3, 0xe8, 0x4e, 0xd4, 0xda, 0x22, 0x72, 0xea, 0xb3, 0xec, 0x8f, 0xc3, 0xd7, + 0xde, 0xc8, 0x49, 0xe9, 0x29, 0x8a, 0x78, 0x61, 0xdc, 0x76, 0x9a, 0x1d, 0x2b, 0x18, 0x4b, 0xa3, + 0x74, 0x4f, 0x67, 0x8b, 0xcd, 0x5a, 0xe8, 0x27, 0x79, 0xbf, 0x1d, 0xac, 0xef, 0xc6, 0x44, 0x64, + 0x87, 0xcc, 0xf9, 0x24, 0x6f, 0x71, 0xe2, 0xce, 0x4f, 0x22, 0x10, 0x58, 0xb2, 0x53, 0x43, 0xc6, + 0x56, 0xe3, 0x89, 0xc2, 0x43, 0xd6, 0xd1, 0x87, 0x64, 0xc8, 0xd8, 0xea, 0x9b, 0x30, 0xb5, 0x7f, + 0xbf, 0xbf, 0x73, 0x83, 0x63, 0xfa, 0xe7, 0xcf, 0x77, 0x1e, 0x67, 0x7e, 0xbe, 0x77, 0xfb, 0xea, + 0x31, 0x1e, 0x6c, 0x7e, 0xd3, 0x82, 0x73, 0xad, 0xcc, 0xdd, 0x4b, 0xec, 0x10, 0xbd, 0x9a, 0x69, + 0x7c, 0x68, 0x54, 0xae, 0xd1, 0x6c, 0x3c, 0xee, 0x52, 0x67, 0x5a, 0xe5, 0x2b, 0x7f, 0x64, 0x95, + 0xef, 0x3e, 0x0c, 0x31, 0x2d, 0x25, 0x49, 0x76, 0xd1, 0x63, 0x7e, 0x08, 0xb6, 0xd7, 0x2c, 0x08, + 0x16, 0x58, 0x31, 0xa3, 0x03, 0xf7, 0x6c, 0xba, 0x13, 0x98, 0x30, 0xb4, 0x48, 0x92, 0xca, 0x7d, + 0x01, 0x4b, 0x62, 0x24, 0x9e, 0xad, 0x1d, 0x46, 0x7c, 0x90, 0x47, 0x80, 0x0f, 0xaf, 0xec, 0x24, + 0x55, 0xc8, 0x7f, 0x68, 0x65, 0x28, 0x3c, 0x5c, 0xe9, 0x7f, 0xc3, 0x54, 0xfa, 0x2f, 0xa6, 0x95, + 0xfe, 0x0e, 0x13, 0xdd, 0xd0, 0xf7, 0x8b, 0x27, 0x0a, 0x2c, 0x9a, 0x8d, 0xc3, 0xfe, 0x5f, 0x16, + 0x94, 0x6b, 0x81, 0x7b, 0x8c, 0x4e, 0x80, 0x1b, 0x86, 0x13, 0xe0, 0xf9, 0xdc, 0x67, 0x6f, 0xba, + 0x9a, 0xfc, 0x77, 0x52, 0x26, 0xff, 0xa7, 0xf2, 0x59, 0x1d, 0x6e, 0xe0, 0x7f, 0xaf, 0x0c, 0xfa, + 0xc3, 0x3d, 0xe8, 0xb7, 0x8e, 0x12, 0xd5, 0x58, 0x2e, 0xf6, 0x96, 0x8f, 0xa8, 0x83, 0xc5, 0x00, + 0xc9, 0x2b, 0x4f, 0x7f, 0x62, 0x83, 0x1b, 0xef, 0x13, 0x6f, 0x73, 0x2b, 0x26, 0x6e, 0xba, 0x63, + 0x27, 0x17, 0xdc, 0xf8, 0x5f, 0x2c, 0x18, 0x4f, 0xd5, 0x8e, 0xb6, 0xb3, 0x6e, 0x4d, 0x1c, 0xd5, + 0xaa, 0x3f, 0x95, 0x7b, 0xcf, 0x62, 0x06, 0x40, 0x79, 0xa2, 0xa5, 0xed, 0xcd, 0xf4, 0x10, 0xe5, + 0xaa, 0x8e, 0xb0, 0x46, 0x81, 0x5e, 0x85, 0xe1, 0x38, 0x68, 0x05, 0xcd, 0x60, 0x73, 0xf7, 0x16, + 0x91, 0x97, 0xf2, 0x95, 0x17, 0x7f, 0x2d, 0x41, 0x61, 0x9d, 0xce, 0xfe, 0x41, 0x19, 0xd2, 0xef, + 0x3e, 0xfd, 0x7f, 0x41, 0xfd, 0x93, 0x23, 0xa8, 0xbf, 0x6b, 0xc1, 0x04, 0xad, 0x9d, 0x85, 0x70, + 0xc8, 0x10, 0x44, 0x95, 0x71, 0xdb, 0x3a, 0x24, 0xe3, 0xf6, 0x45, 0xba, 0xdc, 0xb9, 0x41, 0x5b, + 0x66, 0x81, 0xd1, 0x56, 0x31, 0x0a, 0xc5, 0x02, 0x2b, 0xe8, 0x48, 0x18, 0x8a, 0xfb, 0x19, 0x3a, + 0x1d, 0x09, 0x43, 0x2c, 0xb0, 0x32, 0x21, 0x77, 0x5f, 0x76, 0x42, 0x6e, 0x9e, 0x34, 0x47, 0x84, + 0x0e, 0x88, 0x9d, 0x59, 0x4b, 0x9a, 0x23, 0x63, 0x0a, 0x12, 0x1a, 0xfb, 0x9f, 0x95, 0x61, 0xa4, + 0x16, 0xb8, 0x49, 0x78, 0xf1, 0x2b, 0x46, 0x78, 0xf1, 0x85, 0x54, 0x78, 0xf1, 0x84, 0x4e, 0xfb, + 0x78, 0xa2, 0x8b, 0x45, 0x7a, 0x25, 0x96, 0x32, 0xfe, 0xa8, 0x91, 0xc5, 0x46, 0x7a, 0x25, 0xc5, + 0x09, 0x9b, 0x8c, 0xff, 0x54, 0x45, 0x14, 0xff, 0xb1, 0x05, 0x63, 0xb5, 0xc0, 0xa5, 0x22, 0xfa, + 0xa7, 0x49, 0x1e, 0xf5, 0xa4, 0x4c, 0x03, 0x87, 0x24, 0x65, 0xfa, 0x55, 0x0b, 0x06, 0x6b, 0x81, + 0x7b, 0x12, 0xde, 0xb4, 0x25, 0xd3, 0x9b, 0xf6, 0x89, 0xdc, 0xc5, 0xb7, 0x8b, 0x03, 0xed, 0x37, + 0xca, 0x30, 0x4a, 0x9b, 0x1c, 0x6c, 0xca, 0x0f, 0x66, 0x0c, 0x8e, 0x55, 0x60, 0x70, 0x2e, 0xc2, + 0xc0, 0x46, 0xd0, 0x6c, 0x06, 0x0f, 0xd3, 0x1f, 0x6f, 0x89, 0x41, 0xb1, 0xc0, 0xa2, 0xcb, 0x30, + 0xd4, 0x0a, 0xc9, 0x8e, 0x17, 0xb4, 0xa3, 0xf4, 0x75, 0xaf, 0x9a, 0x80, 0x63, 0x45, 0x81, 0x5e, + 0x81, 0x91, 0xc8, 0xf3, 0x1b, 0x44, 0xc6, 0x16, 0xf4, 0xb1, 0xd8, 0x02, 0x9e, 0xfb, 0x4e, 0x83, + 0x63, 0x83, 0x0a, 0xbd, 0x0d, 0x15, 0xf6, 0x9f, 0xcd, 0xa1, 0x23, 0x64, 0x09, 0xe7, 0x89, 0x99, + 0x24, 0x07, 0x9c, 0x30, 0x43, 0xd7, 0x00, 0x62, 0x19, 0x06, 0x11, 0x89, 0x63, 0x43, 0xa5, 0x9c, + 0xaa, 0x00, 0x89, 0x08, 0x6b, 0x54, 0xe8, 0x25, 0xa8, 0xc4, 0x8e, 0xd7, 0x5c, 0xf1, 0x7c, 0x12, + 0x89, 0x40, 0x12, 0x91, 0xc3, 0x55, 0x00, 0x71, 0x82, 0xa7, 0x7b, 0x3e, 0xbb, 0x6c, 0xca, 0xdf, + 0x20, 0x18, 0x62, 0xd4, 0x6c, 0xcf, 0x5f, 0x51, 0x50, 0xac, 0x51, 0xd8, 0x2f, 0xb3, 0xbd, 0xbb, + 0xc7, 0xf0, 0xf3, 0x9f, 0x94, 0x00, 0xd5, 0x58, 0xb8, 0x85, 0xf1, 0x4c, 0xc3, 0x16, 0x8c, 0x45, + 0x64, 0xc5, 0xf3, 0xdb, 0x8f, 0x04, 0xab, 0x62, 0x01, 0xff, 0xf5, 0x45, 0xbd, 0x0c, 0xbf, 0x60, + 0x69, 0xc2, 0x70, 0x8a, 0x2f, 0x1d, 0x92, 0xb0, 0xed, 0xcf, 0x45, 0x77, 0x23, 0x12, 0x8a, 0x87, + 0x16, 0xd8, 0x90, 0x60, 0x09, 0xc4, 0x09, 0x9e, 0xca, 0x00, 0xfb, 0x73, 0x3b, 0xf0, 0x71, 0x10, + 0xc4, 0x52, 0x6a, 0x58, 0xd6, 0x6d, 0x0d, 0x8e, 0x0d, 0x2a, 0xb4, 0x04, 0x28, 0x6a, 0xb7, 0x5a, + 0x4d, 0x76, 0xba, 0xe3, 0x34, 0x6f, 0x84, 0x41, 0xbb, 0xc5, 0x23, 0x6e, 0x45, 0xc2, 0xea, 0x7a, + 0x07, 0x16, 0x67, 0x94, 0xa0, 0x93, 0x7e, 0x23, 0x62, 0xbf, 0xc5, 0x05, 0x52, 0xee, 0x63, 0xaa, + 0x33, 0x10, 0x96, 0x38, 0xbb, 0xcd, 0xb6, 0x2a, 0x96, 0x00, 0x3f, 0x6e, 0x87, 0x04, 0x11, 0x18, + 0x6d, 0xb1, 0xed, 0x48, 0x1e, 0x31, 0x17, 0x1a, 0xca, 0x54, 0xc0, 0x07, 0x4f, 0x74, 0xad, 0xb3, + 0xc1, 0x26, 0x57, 0xfb, 0xdf, 0x03, 0x5b, 0x6b, 0xc4, 0xc1, 0xda, 0xa0, 0x08, 0xe7, 0x14, 0xba, + 0xd8, 0x27, 0x8b, 0xbc, 0xf8, 0x92, 0xac, 0xe3, 0x22, 0x38, 0x14, 0x4b, 0x2e, 0xe8, 0xcb, 0xfc, + 0x8c, 0x9c, 0xcd, 0xef, 0xe2, 0xcf, 0x30, 0x71, 0x7a, 0x23, 0x50, 0x59, 0xb0, 0xc0, 0x1a, 0x3b, + 0xb4, 0x02, 0xa3, 0x22, 0x4b, 0xba, 0xb0, 0xd5, 0xcb, 0x86, 0xbd, 0x3a, 0x8a, 0x75, 0xe4, 0x41, + 0x1a, 0x80, 0xcd, 0xc2, 0x68, 0x13, 0x9e, 0xd5, 0x9e, 0x4e, 0xc9, 0x08, 0x4a, 0xe2, 0x0b, 0xc7, + 0x27, 0xf6, 0xf7, 0xa6, 0x9f, 0x5d, 0x3b, 0x8c, 0x10, 0x1f, 0xce, 0x07, 0xdd, 0x81, 0xb3, 0x4e, + 0x23, 0xf6, 0x76, 0x48, 0x95, 0x38, 0x6e, 0xd3, 0xf3, 0x89, 0x79, 0xbb, 0xf8, 0xe9, 0xfd, 0xbd, + 0xe9, 0xb3, 0x73, 0x59, 0x04, 0x38, 0xbb, 0x1c, 0x7a, 0x03, 0x2a, 0xae, 0x1f, 0x89, 0x31, 0x18, + 0x30, 0x5e, 0x89, 0xa9, 0x54, 0x6f, 0xd7, 0x55, 0xff, 0x93, 0x3f, 0x38, 0x29, 0x80, 0xde, 0xe7, + 0x8f, 0xd7, 0x2a, 0x83, 0x84, 0xbf, 0x4e, 0xf4, 0x5a, 0x21, 0x13, 0xd8, 0xb8, 0x08, 0xc1, 0xdd, + 0x58, 0x2a, 0xf8, 0xcf, 0xb8, 0x23, 0x61, 0x54, 0x81, 0xbe, 0x00, 0x28, 0x22, 0xe1, 0x8e, 0xd7, + 0x20, 0x73, 0x0d, 0x96, 0xf5, 0x91, 0x9d, 0x50, 0x0d, 0x19, 0x11, 0xf0, 0xa8, 0xde, 0x41, 0x81, + 0x33, 0x4a, 0xa1, 0x9b, 0x74, 0xc5, 0xd1, 0xa1, 0x22, 0x56, 0x53, 0xaa, 0x76, 0x93, 0x55, 0xd2, + 0x0a, 0x49, 0xc3, 0x89, 0x89, 0x6b, 0x72, 0xc4, 0xa9, 0x72, 0x74, 0x5b, 0x51, 0xd9, 0xac, 0xc1, + 0x8c, 0x30, 0xec, 0xcc, 0x68, 0x4d, 0x2d, 0xa5, 0xad, 0x20, 0x8a, 0x6f, 0x93, 0xf8, 0x61, 0x10, + 0x3e, 0x60, 0xfe, 0xe6, 0x21, 0x2d, 0xcb, 0x55, 0x82, 0xc2, 0x3a, 0x1d, 0xd5, 0x81, 0xd8, 0x41, + 0xc7, 0x72, 0x95, 0x79, 0x91, 0x87, 0x92, 0xb9, 0x73, 0x93, 0x83, 0xb1, 0xc4, 0x4b, 0xd2, 0xe5, + 0xda, 0x02, 0xf3, 0x08, 0xa7, 0x48, 0x97, 0x6b, 0x0b, 0x58, 0xe2, 0x51, 0xd0, 0xf9, 0x16, 0xcf, + 0x58, 0x11, 0xef, 0x7c, 0xe7, 0x0a, 0x5e, 0xf0, 0x39, 0x9e, 0x47, 0x30, 0xa1, 0xde, 0x03, 0xe2, + 0xe9, 0x07, 0xa3, 0xc9, 0xf1, 0x22, 0x4f, 0xe7, 0x66, 0x66, 0x31, 0x54, 0xc1, 0xb9, 0xcb, 0x29, + 0x9e, 0xb8, 0xa3, 0x16, 0xe3, 0x96, 0xfc, 0x44, 0x6e, 0x86, 0xf2, 0x59, 0xa8, 0x44, 0xed, 0x75, + 0x37, 0xd8, 0x76, 0x3c, 0x9f, 0xbd, 0x08, 0xa4, 0x3f, 0x04, 0x2b, 0x11, 0x38, 0xa1, 0x99, 0xfa, + 0x1c, 0x9c, 0xea, 0x90, 0xe9, 0x9e, 0xa2, 0xca, 0x7e, 0xbe, 0x0f, 0x2a, 0xca, 0xab, 0x83, 0x66, + 0x4d, 0x57, 0xda, 0xd3, 0x69, 0x57, 0xda, 0x10, 0xdd, 0x79, 0x75, 0xef, 0xd9, 0xbb, 0x19, 0x2f, + 0x41, 0xbe, 0x98, 0xfb, 0x11, 0x8b, 0x5f, 0xee, 0xe8, 0xe1, 0x9d, 0xcc, 0x44, 0xad, 0xef, 0x3b, + 0x54, 0xad, 0x2f, 0xf8, 0xd0, 0x0f, 0x55, 0xe0, 0x5b, 0x81, 0xbb, 0x5c, 0x4b, 0x3f, 0x62, 0x51, + 0xa3, 0x40, 0xcc, 0x71, 0x4c, 0xef, 0xa2, 0x8b, 0x32, 0xd3, 0xbb, 0x06, 0x8f, 0xaa, 0x77, 0x49, + 0x0e, 0x38, 0x61, 0x86, 0x76, 0xe0, 0x54, 0xc3, 0x7c, 0x94, 0x44, 0xdd, 0xd9, 0xb8, 0xd2, 0xc3, + 0xa3, 0x20, 0x6d, 0x2d, 0x01, 0xfb, 0x42, 0x9a, 0x1f, 0xee, 0xac, 0xc2, 0xfe, 0x01, 0xf7, 0x02, + 0x09, 0xb3, 0x90, 0x44, 0xed, 0xe6, 0x71, 0xe6, 0x53, 0xbe, 0x63, 0x58, 0xaa, 0x8f, 0xc1, 0xff, + 0xf8, 0x9b, 0x16, 0xf3, 0x3f, 0xae, 0x91, 0xed, 0x56, 0xd3, 0x89, 0x8f, 0x33, 0x60, 0xed, 0xcb, + 0x30, 0x14, 0x8b, 0x5a, 0x8a, 0x25, 0x81, 0xd6, 0x9a, 0xc5, 0xfc, 0xb1, 0x6a, 0x21, 0x90, 0x50, + 0xac, 0x18, 0xda, 0xff, 0x92, 0x7f, 0x05, 0x89, 0x39, 0x09, 0xcb, 0xea, 0xb6, 0x69, 0x59, 0xbd, + 0x50, 0xb8, 0x33, 0x5d, 0x2c, 0xac, 0xef, 0x9a, 0x5d, 0x60, 0x0a, 0xdb, 0x93, 0xef, 0x11, 0xb7, + 0x57, 0xc1, 0x7c, 0x68, 0x05, 0xbd, 0xc1, 0xa3, 0x35, 0xf9, 0x8a, 0xf8, 0x62, 0x8f, 0x91, 0x9a, + 0xf6, 0xaf, 0x97, 0xe0, 0x4c, 0xd6, 0xfb, 0xeb, 0xc8, 0x85, 0x91, 0x96, 0xa6, 0x3e, 0x17, 0xbb, + 0xcb, 0xaf, 0x2b, 0xdc, 0x89, 0xea, 0xa2, 0x43, 0xb1, 0xc1, 0x15, 0x11, 0x18, 0x21, 0x3b, 0x5e, + 0x43, 0xb9, 0x57, 0x4a, 0xbd, 0x2f, 0x51, 0xaa, 0x9a, 0x45, 0x8d, 0x11, 0x36, 0xd8, 0x1e, 0x43, + 0x9e, 0x72, 0xfb, 0xef, 0x5b, 0xf0, 0x54, 0x97, 0x0b, 0xff, 0xb4, 0xba, 0x87, 0xcc, 0x0b, 0x29, + 0x1e, 0xf2, 0x51, 0xd5, 0x71, 0xdf, 0x24, 0x16, 0x58, 0xb4, 0x0e, 0xc0, 0x7d, 0x8b, 0xec, 0x75, + 0xd3, 0x52, 0x91, 0x63, 0xf0, 0x8e, 0xcb, 0xc5, 0xda, 0xbd, 0x53, 0xf5, 0x9e, 0xa9, 0xc6, 0xd5, + 0xfe, 0x4e, 0x19, 0xfa, 0xf9, 0x03, 0x8b, 0x35, 0x18, 0xdc, 0xe2, 0xf9, 0x05, 0x7b, 0x4b, 0x6f, + 0x98, 0xe8, 0x49, 0x1c, 0x80, 0x25, 0x1b, 0xb4, 0x0a, 0xa7, 0x3d, 0xdf, 0x8b, 0x3d, 0xa7, 0x59, + 0x25, 0x4d, 0x67, 0x57, 0x2a, 0xde, 0x3c, 0xb7, 0xb4, 0x4c, 0x83, 0x7a, 0x7a, 0xb9, 0x93, 0x04, + 0x67, 0x95, 0x43, 0x6f, 0x76, 0x24, 0x08, 0xe2, 0x79, 0x1b, 0xd5, 0x75, 0xa5, 0xc3, 0x93, 0x04, + 0xa1, 0xd7, 0x61, 0xb4, 0xd5, 0x61, 0x62, 0x68, 0x2f, 0xf3, 0x99, 0x66, 0x85, 0x49, 0x8b, 0xaa, + 0x30, 0x11, 0xb5, 0xd9, 0x19, 0xe9, 0xda, 0x56, 0x48, 0xa2, 0xad, 0xa0, 0xe9, 0x8a, 0x17, 0xa5, + 0x94, 0x3a, 0x55, 0x4f, 0xe1, 0x71, 0x47, 0x09, 0xca, 0x65, 0xc3, 0xf1, 0x9a, 0xed, 0x90, 0x24, + 0x5c, 0x06, 0x4c, 0x2e, 0x4b, 0x29, 0x3c, 0xee, 0x28, 0x61, 0xff, 0xa1, 0x05, 0xa7, 0x33, 0x4e, + 0xee, 0x79, 0x40, 0xd9, 0xa6, 0x17, 0xc5, 0x2a, 0x83, 0xb0, 0x16, 0x50, 0xc6, 0xe1, 0x58, 0x51, + 0x50, 0x29, 0xe4, 0x76, 0x63, 0x3a, 0x21, 0xb2, 0x38, 0x2a, 0x15, 0xd8, 0xde, 0xd2, 0xfd, 0xa8, + 0x77, 0xe2, 0xfb, 0xba, 0xbe, 0x13, 0xff, 0x1c, 0xf4, 0x6f, 0x2a, 0xeb, 0x5c, 0x53, 0x4c, 0xb8, + 0x7d, 0xce, 0x71, 0xf6, 0xb7, 0xcb, 0x30, 0x9e, 0x8a, 0xe0, 0xa1, 0x0d, 0x49, 0x3d, 0x67, 0xcf, + 0x5c, 0x0a, 0x0b, 0xa4, 0xb5, 0x95, 0xf1, 0xa4, 0xfd, 0x45, 0xf3, 0xb5, 0xdb, 0xa4, 0xcd, 0xf3, + 0x55, 0xe3, 0x1d, 0xaf, 0xa2, 0x59, 0xcd, 0x9f, 0x83, 0xbe, 0x56, 0xa0, 0x9e, 0x65, 0x54, 0x42, + 0x8f, 0xe7, 0xab, 0xb5, 0x20, 0x68, 0x62, 0x86, 0x44, 0xcf, 0x8b, 0xde, 0xa7, 0x9c, 0x93, 0xd8, + 0x71, 0x83, 0x48, 0x1b, 0x82, 0x17, 0x60, 0xf0, 0x01, 0xd9, 0x0d, 0x3d, 0x7f, 0x33, 0xed, 0x9a, + 0xbd, 0xc5, 0xc1, 0x58, 0xe2, 0xcd, 0xcc, 0xe5, 0x83, 0xc7, 0x9c, 0xb9, 0x7c, 0x28, 0x37, 0x0a, + 0xf1, 0x57, 0x2c, 0x18, 0x67, 0x69, 0xd7, 0xc4, 0x4d, 0x50, 0x2f, 0xf0, 0x8f, 0x71, 0x57, 0x7c, + 0x0e, 0xfa, 0x43, 0x5a, 0x59, 0x3a, 0xe9, 0x30, 0x6b, 0x01, 0xe6, 0x38, 0xf4, 0x8c, 0x78, 0x34, + 0x9c, 0x7e, 0xbe, 0x11, 0x9e, 0xc4, 0x35, 0x79, 0xfd, 0x9b, 0xc5, 0xb8, 0x63, 0xd2, 0x6a, 0x7a, + 0xbc, 0xb1, 0x89, 0x27, 0xe6, 0x49, 0x89, 0x71, 0xcf, 0x6c, 0xdc, 0xe3, 0x8a, 0x71, 0xcf, 0x66, + 0x7e, 0xb8, 0x0a, 0xfa, 0xdf, 0x4a, 0x70, 0x3e, 0xb3, 0x5c, 0x72, 0xac, 0xb3, 0x64, 0x1c, 0xeb, + 0x5c, 0x4b, 0x1d, 0xeb, 0xd8, 0x87, 0x97, 0x7e, 0x3c, 0x07, 0x3d, 0xd9, 0xc7, 0x2f, 0xe5, 0x93, + 0x3c, 0x7e, 0xe9, 0x2b, 0xaa, 0x2b, 0xf4, 0xe7, 0xe8, 0x0a, 0xbf, 0x63, 0xc1, 0xd3, 0x99, 0x63, + 0xf6, 0xe4, 0xdd, 0x2a, 0xc8, 0x6c, 0x66, 0x17, 0x0d, 0xfa, 0xaf, 0x96, 0xbb, 0x74, 0x8b, 0xe9, + 0xd2, 0x97, 0xe8, 0xba, 0xc3, 0x90, 0x91, 0x50, 0x83, 0x46, 0xf8, 0x9a, 0xc3, 0x61, 0x58, 0x61, + 0x51, 0xa4, 0x45, 0xe5, 0xf3, 0x46, 0x2e, 0x1e, 0x71, 0x4a, 0xcd, 0x98, 0xce, 0x33, 0xfd, 0x4a, + 0x6b, 0x2a, 0x54, 0x1f, 0xdd, 0xd7, 0xcc, 0xa3, 0xf2, 0x51, 0xcc, 0xa3, 0x91, 0x6c, 0xd3, 0x08, + 0xcd, 0xc1, 0xf8, 0xb6, 0xe7, 0xb3, 0x67, 0xc3, 0x4c, 0x3d, 0x44, 0x5d, 0x04, 0x5b, 0x35, 0xd1, + 0x38, 0x4d, 0x3f, 0xf5, 0x3a, 0x8c, 0x1e, 0xdd, 0x63, 0xf2, 0x61, 0x19, 0x3e, 0x7e, 0xc8, 0xb2, + 0xc0, 0xf7, 0x03, 0xe3, 0xbb, 0x68, 0xfb, 0x41, 0xc7, 0xb7, 0xa9, 0xc1, 0x99, 0x8d, 0x76, 0xb3, + 0xb9, 0xcb, 0xc2, 0x22, 0x88, 0x2b, 0x29, 0x84, 0x8e, 0xa7, 0x1e, 0xf4, 0x5c, 0xca, 0xa0, 0xc1, + 0x99, 0x25, 0xd1, 0x17, 0x00, 0x05, 0xeb, 0x2c, 0x17, 0xa1, 0x9b, 0x5c, 0xda, 0x65, 0x9f, 0xa0, + 0x9c, 0xcc, 0xd5, 0x3b, 0x1d, 0x14, 0x38, 0xa3, 0x14, 0xd5, 0xf8, 0xd8, 0x5b, 0xa0, 0xaa, 0x59, + 0x29, 0x8d, 0x0f, 0xeb, 0x48, 0x6c, 0xd2, 0xa2, 0x1b, 0x70, 0xca, 0xd9, 0x71, 0x3c, 0x9e, 0x70, + 0x45, 0x32, 0xe0, 0x2a, 0x9f, 0x72, 0x49, 0xcc, 0xa5, 0x09, 0x70, 0x67, 0x19, 0xd4, 0x32, 0x9c, + 0x4c, 0x3c, 0xf7, 0xf0, 0x1b, 0x47, 0x90, 0xe0, 0xc2, 0x6e, 0x27, 0xfb, 0x0f, 0x2c, 0xba, 0xe9, + 0x65, 0x3c, 0xb3, 0x65, 0xbc, 0x4e, 0xad, 0x5d, 0x54, 0xe8, 0x7c, 0x9d, 0x9a, 0xf9, 0x5f, 0x4d, + 0x5a, 0x2e, 0x1a, 0x51, 0x12, 0xe8, 0x68, 0xe8, 0x97, 0xe2, 0x82, 0x8e, 0xa2, 0x40, 0xf7, 0x61, + 0xd0, 0xf5, 0x76, 0xbc, 0x28, 0x08, 0x0b, 0x3c, 0x06, 0xdb, 0x11, 0x3c, 0x97, 0x2c, 0x97, 0x55, + 0xce, 0x04, 0x4b, 0x6e, 0xf6, 0x5f, 0x2f, 0xc1, 0xa8, 0xac, 0xef, 0xad, 0x76, 0xc0, 0xd6, 0xb0, + 0xe3, 0xda, 0xca, 0xdf, 0x32, 0xb6, 0xf2, 0xd9, 0x62, 0xb7, 0x94, 0x58, 0xa3, 0xba, 0x6e, 0xe1, + 0x5f, 0x4c, 0x6d, 0xe1, 0x57, 0x7b, 0x61, 0x9a, 0xeb, 0x3d, 0x3a, 0x65, 0xd0, 0x3f, 0x41, 0xb9, + 0x6f, 0xb3, 0xba, 0xd3, 0x65, 0xe3, 0xf8, 0x4e, 0x29, 0xd5, 0x0d, 0xb6, 0x61, 0x7c, 0x1d, 0xfa, + 0xb6, 0x9c, 0xd0, 0x15, 0x47, 0x65, 0x9f, 0xe9, 0xf1, 0x53, 0xcc, 0xdc, 0x74, 0x42, 0x97, 0x2f, + 0xfb, 0x97, 0xd5, 0x23, 0x1d, 0x4e, 0xe8, 0xe6, 0x86, 0xfd, 0xb2, 0x4a, 0xd1, 0x75, 0x18, 0x88, + 0x1a, 0x41, 0x4b, 0x45, 0x75, 0x5d, 0xe0, 0x0f, 0x78, 0x50, 0xc8, 0xc1, 0xde, 0x34, 0x32, 0xab, + 0xa3, 0x60, 0x2c, 0xe8, 0xa7, 0x08, 0x54, 0x54, 0xd5, 0xc7, 0x18, 0x60, 0xfa, 0x61, 0x19, 0x4e, + 0x67, 0x88, 0x0a, 0xfa, 0x69, 0x63, 0xd4, 0x5e, 0xef, 0x59, 0xd6, 0x3e, 0xe2, 0xb8, 0xfd, 0x34, + 0x33, 0x88, 0x5c, 0x21, 0x1b, 0x47, 0xa8, 0xfe, 0x6e, 0x44, 0xd2, 0xd5, 0x53, 0x50, 0x7e, 0xf5, + 0xb4, 0xda, 0x13, 0x1a, 0x7c, 0x5a, 0x8d, 0x6a, 0xe7, 0x31, 0x7e, 0xe3, 0x0f, 0xfa, 0xe0, 0x4c, + 0xd6, 0x4d, 0x48, 0xf4, 0xb3, 0x56, 0x2a, 0x7b, 0xf6, 0x9b, 0xbd, 0x5f, 0xa7, 0xe4, 0x29, 0xb5, + 0x45, 0x86, 0x84, 0x19, 0x33, 0x9f, 0x76, 0xee, 0x68, 0x8b, 0xda, 0x59, 0xa8, 0x7e, 0xc8, 0x13, + 0xa1, 0xcb, 0xf5, 0xe0, 0xf3, 0x47, 0x68, 0x8a, 0xc8, 0xa5, 0x1e, 0xa5, 0x42, 0xf5, 0x25, 0x38, + 0x3f, 0x54, 0x5f, 0xb6, 0x61, 0x6a, 0x13, 0x86, 0xb5, 0x7e, 0x1d, 0xa3, 0x08, 0x78, 0x74, 0x4f, + 0xd2, 0x5a, 0x7d, 0x8c, 0x62, 0xf0, 0x37, 0x2d, 0x48, 0x85, 0x6b, 0x28, 0xaf, 0x8b, 0xd5, 0xd5, + 0xeb, 0x72, 0x01, 0xfa, 0xc2, 0xa0, 0x49, 0xd2, 0x69, 0x9d, 0x71, 0xd0, 0x24, 0x98, 0x61, 0xd4, + 0x53, 0x80, 0xe5, 0x6e, 0x4f, 0x01, 0x52, 0x73, 0xbc, 0x49, 0x76, 0x88, 0xf4, 0x81, 0xa8, 0xc5, + 0x7b, 0x85, 0x02, 0x31, 0xc7, 0xd9, 0x3f, 0x2a, 0xc3, 0x00, 0x77, 0x34, 0x1c, 0xe3, 0xb6, 0x5c, + 0x13, 0x36, 0x7f, 0xa1, 0x3b, 0x89, 0xbc, 0x35, 0x33, 0x55, 0x27, 0x76, 0xb8, 0x40, 0xa9, 0xbe, + 0x25, 0x7e, 0x02, 0x34, 0x63, 0xf4, 0x7e, 0x2a, 0x65, 0xd2, 0x02, 0xe7, 0xa1, 0x8d, 0xc5, 0x16, + 0x40, 0xc4, 0x5e, 0x85, 0xa2, 0x3c, 0x44, 0x5e, 0xb8, 0x57, 0x0a, 0xb5, 0xa3, 0xae, 0x8a, 0xf1, + 0xd6, 0x24, 0x09, 0xa9, 0x14, 0x02, 0x6b, 0xbc, 0xa7, 0x5e, 0x83, 0x8a, 0x22, 0xce, 0xd3, 0xf4, + 0x47, 0x74, 0x91, 0xfc, 0x33, 0x30, 0x9e, 0xaa, 0xab, 0x27, 0x43, 0xe1, 0xfb, 0x16, 0x9c, 0xea, + 0x78, 0xc5, 0x14, 0x7d, 0x60, 0xc1, 0x99, 0x66, 0x86, 0x87, 0x49, 0x7c, 0xe0, 0xa3, 0xf8, 0xa6, + 0x92, 0x67, 0xff, 0x33, 0xb0, 0x38, 0xb3, 0x36, 0x99, 0xe9, 0xb2, 0x94, 0x9d, 0xe9, 0x92, 0x3d, + 0x85, 0xc3, 0xdb, 0x7e, 0x12, 0x1a, 0xd0, 0xb2, 0xa9, 0x01, 0x7d, 0xb2, 0x88, 0x18, 0x74, 0x51, + 0x7d, 0xfe, 0x8d, 0x05, 0x88, 0x13, 0xa4, 0x5f, 0x87, 0xe3, 0x1e, 0x3b, 0x4d, 0x67, 0x4f, 0xe4, + 0x46, 0x61, 0xb0, 0x46, 0xd5, 0x63, 0xe6, 0x6f, 0xf5, 0xaa, 0x52, 0xb1, 0xa7, 0xdb, 0xcb, 0x05, + 0x9e, 0x6e, 0xff, 0xcd, 0x32, 0xa4, 0x43, 0x1b, 0xd0, 0x57, 0x60, 0xa4, 0xe1, 0xb4, 0x9c, 0x75, + 0xaf, 0xe9, 0xc5, 0x1e, 0x89, 0x8a, 0x1d, 0x1b, 0x2d, 0x68, 0x25, 0x84, 0xcf, 0x57, 0x83, 0x60, + 0x83, 0x23, 0x9a, 0x01, 0x68, 0x85, 0xde, 0x8e, 0xd7, 0x24, 0x9b, 0x4c, 0xef, 0x50, 0x79, 0x42, + 0x6a, 0x0a, 0x8a, 0x35, 0x8a, 0x8c, 0x18, 0xba, 0xf2, 0x49, 0xc4, 0xd0, 0xf5, 0xf5, 0x18, 0x43, + 0xd7, 0x5f, 0x28, 0x86, 0x0e, 0xc3, 0x39, 0xe9, 0xaa, 0xa5, 0xff, 0x97, 0xbc, 0x26, 0xe1, 0xa9, + 0xed, 0x44, 0xe4, 0xe3, 0xd4, 0xfe, 0xde, 0xf4, 0x39, 0x9c, 0x49, 0x81, 0xbb, 0x94, 0xb4, 0xdb, + 0x70, 0xba, 0x4e, 0x42, 0x8f, 0x65, 0x1e, 0x72, 0x93, 0x19, 0xf8, 0x2e, 0x54, 0xc2, 0xd4, 0xe4, + 0xef, 0xf1, 0x96, 0x98, 0x96, 0xbf, 0x41, 0x4e, 0xf6, 0x84, 0xa5, 0xfd, 0x17, 0x4b, 0x30, 0x28, + 0x42, 0x88, 0x8e, 0x71, 0x23, 0xb9, 0x65, 0xd8, 0x77, 0x2f, 0xe4, 0xcd, 0x5c, 0xd6, 0x9c, 0xae, + 0x96, 0x5d, 0x3d, 0x65, 0xd9, 0xbd, 0x54, 0x8c, 0xdd, 0xe1, 0x36, 0xdd, 0x0f, 0x4b, 0x30, 0x66, + 0x86, 0x52, 0x1d, 0xe3, 0x70, 0xbc, 0x0d, 0x83, 0x91, 0x88, 0x2f, 0x2a, 0xf4, 0x58, 0x7e, 0xfa, + 0x93, 0x26, 0xcf, 0xc0, 0x8b, 0x88, 0x22, 0xc9, 0x2e, 0x33, 0x84, 0xa9, 0x7c, 0x12, 0x21, 0x4c, + 0xf6, 0x8f, 0xd8, 0x92, 0xaa, 0x0f, 0xe0, 0x49, 0xec, 0x09, 0x6f, 0x99, 0xab, 0xef, 0xe5, 0x42, + 0xa2, 0x20, 0xda, 0xd7, 0x65, 0x6f, 0xf8, 0x9e, 0x05, 0xc3, 0x82, 0xf0, 0x24, 0x7a, 0xf0, 0x05, + 0xb3, 0x07, 0xcf, 0x17, 0xea, 0x41, 0x97, 0xa6, 0xff, 0xed, 0x92, 0x6a, 0x7a, 0x4d, 0xbc, 0x9a, + 0x99, 0x9b, 0xeb, 0x70, 0xa8, 0x15, 0x06, 0x71, 0xd0, 0x08, 0x9a, 0x62, 0x97, 0x7f, 0x26, 0x89, + 0x3a, 0xe7, 0xf0, 0x03, 0xed, 0x37, 0x56, 0xd4, 0x2c, 0x9a, 0x3a, 0x08, 0x63, 0xb1, 0x45, 0x65, + 0xbd, 0xd9, 0xb9, 0x2e, 0xdf, 0x44, 0xa6, 0x30, 0x71, 0x65, 0xa3, 0xd7, 0xb7, 0x40, 0x93, 0x18, + 0x72, 0xc5, 0x09, 0x6b, 0x5c, 0x65, 0x78, 0x23, 0xab, 0xa1, 0xdf, 0x74, 0xa3, 0xde, 0x16, 0x70, + 0xac, 0x28, 0xec, 0xd7, 0xd8, 0x1a, 0xcb, 0x86, 0xa7, 0xb7, 0xc0, 0xf0, 0x9f, 0x1b, 0x50, 0x03, + 0xcb, 0x9c, 0x24, 0xb7, 0xa1, 0x9f, 0x76, 0x51, 0xda, 0x81, 0xc5, 0x16, 0x34, 0xda, 0x04, 0x3d, + 0x40, 0x2c, 0x8c, 0x23, 0xcc, 0xd9, 0x20, 0xd2, 0xe1, 0x7b, 0x7f, 0xad, 0xf0, 0x1a, 0xd9, 0x83, + 0xb7, 0x9d, 0xe5, 0x4e, 0x61, 0xf9, 0x22, 0x96, 0x6b, 0xe9, 0xfc, 0x94, 0x0b, 0x12, 0x81, 0x13, + 0x1a, 0x34, 0x2b, 0xd4, 0x75, 0xf3, 0x49, 0x55, 0xa9, 0xae, 0xcb, 0x21, 0xd1, 0xf4, 0xf5, 0xab, + 0x30, 0xac, 0x32, 0x74, 0xd7, 0x78, 0xa2, 0xe5, 0x0a, 0xd7, 0x5f, 0x16, 0x13, 0x30, 0xd6, 0x69, + 0xd0, 0x32, 0x9c, 0x76, 0x55, 0x34, 0x6b, 0xad, 0xbd, 0xde, 0xf4, 0x1a, 0xb4, 0x28, 0xbf, 0x49, + 0xf2, 0xd4, 0xfe, 0xde, 0xf4, 0xe9, 0x6a, 0x27, 0x1a, 0x67, 0x95, 0x41, 0x6b, 0x30, 0x1e, 0xf1, + 0x4c, 0xe4, 0xf2, 0xce, 0x99, 0x48, 0xe0, 0xf6, 0xa2, 0x74, 0xfa, 0xd7, 0x4d, 0xf4, 0x01, 0x03, + 0xf1, 0x45, 0x41, 0x80, 0x70, 0x9a, 0x05, 0x7a, 0x13, 0xc6, 0x9a, 0xfa, 0x8b, 0x42, 0x35, 0x11, + 0xd4, 0xab, 0x02, 0x22, 0x8c, 0xf7, 0x86, 0x6a, 0x38, 0x45, 0x8d, 0xde, 0x86, 0x49, 0x1d, 0x22, + 0xae, 0x99, 0x3b, 0xfe, 0x26, 0x89, 0x44, 0x0a, 0xe4, 0x67, 0xf6, 0xf7, 0xa6, 0x27, 0x57, 0xba, + 0xd0, 0xe0, 0xae, 0xa5, 0xd1, 0x75, 0x18, 0x91, 0x23, 0xa9, 0x05, 0xf8, 0x26, 0xa1, 0x38, 0x1a, + 0x0e, 0x1b, 0x94, 0x1f, 0xed, 0x6c, 0xe3, 0xeb, 0xb4, 0xb0, 0xb6, 0xa9, 0xa2, 0xaf, 0xc2, 0x88, + 0xde, 0x46, 0xb1, 0x4c, 0x7e, 0xba, 0xf8, 0x2b, 0x4d, 0x62, 0x73, 0x56, 0x2d, 0xd7, 0x71, 0xd8, + 0xe0, 0x6d, 0x37, 0x60, 0x3c, 0xf5, 0x4a, 0xac, 0x7a, 0x6e, 0xd8, 0x7a, 0x5c, 0xcf, 0x0d, 0xdb, + 0xdf, 0xb0, 0xa0, 0x7f, 0xcd, 0xf1, 0xf2, 0x73, 0xfd, 0x17, 0x79, 0xaf, 0x17, 0xbd, 0x0a, 0x03, + 0x64, 0x63, 0x83, 0x34, 0xe4, 0xf3, 0xc5, 0xcf, 0xaa, 0xc7, 0xe7, 0x19, 0x94, 0xce, 0x24, 0x56, + 0x19, 0xff, 0x8b, 0x05, 0xb1, 0xfd, 0xef, 0x2c, 0x80, 0xb5, 0xa0, 0x29, 0x4f, 0x59, 0x72, 0x5a, + 0x32, 0xdf, 0xf1, 0xea, 0xc0, 0xc5, 0x8c, 0x57, 0x07, 0x50, 0xc2, 0x30, 0xe3, 0xcd, 0x01, 0xd5, + 0x9b, 0x72, 0xa1, 0xde, 0xf4, 0xf5, 0xd2, 0x9b, 0x6f, 0x59, 0x20, 0x42, 0x5e, 0x0a, 0x6c, 0x4b, + 0xae, 0xcc, 0x14, 0x6e, 0xe4, 0x7b, 0x78, 0xb1, 0xc8, 0xbd, 0x0d, 0x91, 0xe5, 0x41, 0x89, 0x92, + 0x91, 0xdb, 0xc1, 0xe0, 0x4a, 0x4d, 0xef, 0x61, 0x8e, 0x5e, 0x65, 0x0a, 0x5f, 0x7e, 0xbb, 0x7a, + 0xca, 0x25, 0xc5, 0x12, 0x69, 0x53, 0xc6, 0x2a, 0xa5, 0x90, 0x9e, 0x48, 0x5b, 0x22, 0x70, 0x42, + 0x83, 0x5e, 0x80, 0xc1, 0xa8, 0xbd, 0xce, 0xc8, 0x53, 0xf1, 0x2f, 0x75, 0x0e, 0xc6, 0x12, 0x6f, + 0xff, 0xcf, 0x09, 0x30, 0xba, 0x66, 0xa4, 0x2f, 0xb2, 0x1e, 0x7b, 0xfa, 0xa2, 0x77, 0x60, 0x88, + 0x6c, 0xb7, 0xe2, 0xdd, 0xaa, 0x17, 0x16, 0x4b, 0x25, 0xb7, 0x28, 0xa8, 0x3b, 0xb9, 0x4b, 0x0c, + 0x56, 0x1c, 0xbb, 0x24, 0xa3, 0x2a, 0x3f, 0x11, 0xc9, 0xa8, 0xfa, 0xfe, 0x9f, 0x24, 0xa3, 0x7a, + 0x1b, 0x06, 0x37, 0xf9, 0xf3, 0xf5, 0xe2, 0x9e, 0x5e, 0xce, 0xf1, 0x55, 0xc6, 0x5b, 0xf7, 0xfc, + 0x42, 0x96, 0x40, 0x60, 0xc9, 0x0e, 0xad, 0xc1, 0x00, 0x37, 0x16, 0x44, 0x7e, 0xa7, 0x4f, 0x17, + 0x71, 0xa3, 0x74, 0xa6, 0x3a, 0x12, 0x41, 0x4e, 0x82, 0x97, 0x4c, 0x3e, 0x35, 0xf8, 0xd1, 0x93, + 0x4f, 0xa9, 0x94, 0x51, 0x43, 0x8f, 0x2b, 0x65, 0x94, 0x91, 0x7a, 0xab, 0x72, 0x1c, 0xa9, 0xb7, + 0xbe, 0x65, 0xc1, 0xd9, 0x56, 0x56, 0xe6, 0x3a, 0x91, 0xfc, 0xe9, 0x73, 0x47, 0xc8, 0xe4, 0x67, + 0x54, 0xcd, 0xae, 0x4f, 0x65, 0x92, 0xe1, 0xec, 0x8a, 0x65, 0x0e, 0xaf, 0xe1, 0x8f, 0x9e, 0xc3, + 0xeb, 0xb8, 0xb3, 0x44, 0x25, 0x19, 0xbd, 0x46, 0x8f, 0x25, 0xa3, 0xd7, 0xd8, 0x63, 0xcc, 0xe8, + 0xa5, 0xe5, 0xe2, 0x1a, 0x7f, 0xbc, 0xb9, 0xb8, 0xb6, 0x60, 0xd8, 0x0d, 0x1e, 0xfa, 0x0f, 0x9d, + 0xd0, 0x9d, 0xab, 0x2d, 0x8b, 0xd4, 0x4f, 0x39, 0x39, 0x16, 0xaa, 0x49, 0x01, 0xa3, 0x06, 0xee, + 0x2f, 0x4c, 0x90, 0x58, 0x67, 0x2d, 0xb2, 0x92, 0x9d, 0xfa, 0x88, 0x59, 0xc9, 0x8c, 0xdc, 0x5e, + 0xe8, 0x38, 0x72, 0x7b, 0x7d, 0x85, 0xdd, 0xb4, 0xde, 0xf0, 0x36, 0x57, 0x9d, 0xd6, 0xe4, 0xe9, + 0x22, 0x35, 0x2c, 0x48, 0xf2, 0xce, 0x1a, 0x14, 0x0a, 0x27, 0x4c, 0x3b, 0xb3, 0x87, 0x9d, 0x39, + 0xe9, 0xec, 0x61, 0x67, 0x8f, 0x31, 0x7b, 0xd8, 0xb9, 0xe3, 0xc8, 0x1e, 0xf6, 0xe7, 0xe0, 0xfc, + 0xe1, 0xfd, 0x4f, 0x12, 0xc2, 0xd6, 0x12, 0x93, 0x3a, 0x95, 0x10, 0x96, 0xe9, 0x16, 0x1a, 0x95, + 0x16, 0x1c, 0x5c, 0x3a, 0x2c, 0x38, 0xd8, 0xfe, 0xa7, 0x16, 0x3c, 0xd5, 0x25, 0xb1, 0x48, 0xe1, + 0x68, 0xff, 0x16, 0x8c, 0xb7, 0xcc, 0xa2, 0x85, 0xef, 0xe5, 0x18, 0x89, 0x4c, 0x54, 0x1c, 0x59, + 0x0a, 0x81, 0xd3, 0xec, 0xe7, 0x3f, 0xf9, 0xe3, 0x0f, 0xcf, 0x7f, 0xec, 0x27, 0x1f, 0x9e, 0xff, + 0xd8, 0xef, 0x7d, 0x78, 0xfe, 0x63, 0x3f, 0xb3, 0x7f, 0xde, 0xfa, 0xf1, 0xfe, 0x79, 0xeb, 0x27, + 0xfb, 0xe7, 0xad, 0x3f, 0xdc, 0x3f, 0x6f, 0x7d, 0xeb, 0x8f, 0xce, 0x7f, 0xec, 0x4b, 0xa5, 0x9d, + 0xab, 0xff, 0x37, 0x00, 0x00, 0xff, 0xff, 0x45, 0xe3, 0x62, 0xad, 0x9e, 0xb3, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/generated.proto b/vendor/k8s.io/client-go/pkg/api/v1/generated.proto similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/api/v1/generated.proto rename to vendor/k8s.io/client-go/pkg/api/v1/generated.proto index b9578c4..03499c9 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/api/v1/generated.proto @@ -45,29 +45,35 @@ message AWSElasticBlockStoreVolumeSource { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional optional string fsType = 2; // The partition in the volume that you want to mount. // If omitted, the default is to mount by volume name. // Examples: For volume /dev/sda1, you specify the partition as "1". // Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty). + // +optional optional int32 partition = 3; // Specify "true" to force and set the ReadOnly property in VolumeMounts to "true". // If omitted, the default is "false". // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional optional bool readOnly = 4; } // Affinity is a group of affinity scheduling rules. message Affinity { // Describes node affinity scheduling rules for the pod. + // +optional optional NodeAffinity nodeAffinity = 1; // Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)). + // +optional optional PodAffinity podAffinity = 2; // Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)). + // +optional optional PodAntiAffinity podAntiAffinity = 3; } @@ -76,7 +82,7 @@ message AttachedVolume { // Name of the attached volume optional string name = 1; - // DevicePath represents the device path where the volume should be avilable + // DevicePath represents the device path where the volume should be available optional string devicePath = 2; } @@ -86,6 +92,7 @@ message AttachedVolume { message AvoidPods { // Bounded-sized list of signatures of pods that should avoid this node, sorted // in timestamp order from oldest to newest. Size of the slice is unspecified. + // +optional repeated PreferAvoidPodsEntry preferAvoidPods = 1; } @@ -98,15 +105,18 @@ message AzureDiskVolumeSource { optional string diskURI = 2; // Host Caching mode: None, Read Only, Read Write. + // +optional optional string cachingMode = 3; // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional optional string fsType = 4; // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional optional bool readOnly = 5; } @@ -120,6 +130,7 @@ message AzureFileVolumeSource { // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional optional bool readOnly = 3; } @@ -128,6 +139,7 @@ message AzureFileVolumeSource { message Binding { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // The target object that you want to bind to the standard object. @@ -137,9 +149,11 @@ message Binding { // Adds and removes POSIX capabilities from running containers. message Capabilities { // Added capabilities + // +optional repeated string add = 1; // Removed capabilities + // +optional repeated string drop = 2; } @@ -151,23 +165,28 @@ message CephFSVolumeSource { repeated string monitors = 1; // Optional: Used as the mounted root, rather than the full Ceph tree, default is / + // +optional optional string path = 2; // Optional: User is the rados user name, default is admin // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional optional string user = 3; // Optional: SecretFile is the path to key ring for User, default is /etc/ceph/user.secret // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional optional string secretFile = 4; // Optional: SecretRef is reference to the authentication secret for User, default is empty. // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional optional LocalObjectReference secretRef = 5; // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional optional bool readOnly = 6; } @@ -184,11 +203,13 @@ message CinderVolumeSource { // Must be a filesystem type supported by the host operating system. // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional optional string fsType = 2; // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional optional bool readOnly = 3; } @@ -204,10 +225,12 @@ message ComponentCondition { // Message about the condition for a component. // For example, information about a health check. + // +optional optional string message = 3; // Condition error code for a component. // For example, a health check error code. + // +optional optional string error = 4; } @@ -215,9 +238,11 @@ message ComponentCondition { message ComponentStatus { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // List of component conditions observed + // +optional repeated ComponentCondition conditions = 2; } @@ -225,6 +250,7 @@ message ComponentStatus { message ComponentStatusList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of ComponentStatus objects. @@ -235,10 +261,12 @@ message ComponentStatusList { message ConfigMap { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Data contains the configuration data. // Each key must be a valid DNS_SUBDOMAIN with an optional leading dot. + // +optional map data = 2; } @@ -254,6 +282,7 @@ message ConfigMapKeySelector { // ConfigMapList is a resource containing a list of ConfigMap objects. message ConfigMapList { // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of ConfigMaps. @@ -276,6 +305,7 @@ message ConfigMapVolumeSource { // present. If a key is specified which is not present in the ConfigMap, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional repeated KeyToPath items = 2; // Optional: mode bits to use on created files by default. Must be a @@ -283,6 +313,7 @@ message ConfigMapVolumeSource { // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional optional int32 defaultMode = 3; } @@ -295,6 +326,7 @@ message Container { // Docker image name. // More info: http://kubernetes.io/docs/user-guide/images + // +optional optional string image = 2; // Entrypoint array. Not executed within a shell. @@ -305,6 +337,7 @@ message Container { // regardless of whether the variable exists or not. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/containers#containers-and-commands + // +optional repeated string command = 3; // Arguments to the entrypoint. @@ -315,12 +348,14 @@ message Container { // regardless of whether the variable exists or not. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/containers#containers-and-commands + // +optional repeated string args = 4; // Container's working directory. // If not specified, the container runtime's default will be used, which // might be configured in the container image. // Cannot be updated. + // +optional optional string workingDir = 5; // List of ports to expose from the container. Exposing a port here gives @@ -330,35 +365,42 @@ message Container { // listening on the default "0.0.0.0" address inside a container will be // accessible from the network. // Cannot be updated. + // +optional repeated ContainerPort ports = 6; // List of environment variables to set in the container. // Cannot be updated. + // +optional repeated EnvVar env = 7; // Compute Resources required by this container. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#resources + // +optional optional ResourceRequirements resources = 8; // Pod volumes to mount into the container's filesystem. // Cannot be updated. + // +optional repeated VolumeMount volumeMounts = 9; // Periodic probe of container liveness. // Container will be restarted if the probe fails. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional optional Probe livenessProbe = 10; // Periodic probe of container service readiness. // Container will be removed from service endpoints if the probe fails. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional optional Probe readinessProbe = 11; // Actions that the management system should take in response to container lifecycle events. // Cannot be updated. + // +optional optional Lifecycle lifecycle = 12; // Optional: Path at which the file to which the container's termination message @@ -366,6 +408,7 @@ message Container { // Message written is intended to be brief final status, such as an assertion failure message. // Defaults to /dev/termination-log. // Cannot be updated. + // +optional optional string terminationMessagePath = 13; // Image pull policy. @@ -373,15 +416,18 @@ message Container { // Defaults to Always if :latest tag is specified, or IfNotPresent otherwise. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/images#updating-images + // +optional optional string imagePullPolicy = 14; // Security options the pod should run with. // More info: http://releases.k8s.io/HEAD/docs/design/security_context.md + // +optional optional SecurityContext securityContext = 15; // Whether this container should allocate a buffer for stdin in the container runtime. If this // is not set, reads from stdin in the container will always result in EOF. // Default is false. + // +optional optional bool stdin = 16; // Whether the container runtime should close the stdin channel after it has been opened by @@ -391,10 +437,12 @@ message Container { // at which time stdin is closed and remains closed until the container is restarted. If this // flag is false, a container processes that reads from stdin will never receive an EOF. // Default is false + // +optional optional bool stdinOnce = 17; // Whether this container should allocate a TTY for itself, also requires 'stdin' to be true. // Default is false. + // +optional optional bool tty = 18; } @@ -405,6 +453,7 @@ message ContainerImage { repeated string names = 1; // The size of the image in bytes. + // +optional optional int64 sizeBytes = 2; } @@ -413,12 +462,14 @@ message ContainerPort { // If specified, this must be an IANA_SVC_NAME and unique within the pod. Each // named port in a pod must have a unique name. Name for the port that can be // referred to by services. + // +optional optional string name = 1; // Number of port to expose on the host. // If specified, this must be a valid port number, 0 < x < 65536. // If HostNetwork is specified, this must match ContainerPort. // Most containers do not need this. + // +optional optional int32 hostPort = 2; // Number of port to expose on the pod's IP address. @@ -427,9 +478,11 @@ message ContainerPort { // Protocol for port. Must be UDP or TCP. // Defaults to "TCP". + // +optional optional string protocol = 4; // What host IP to bind the external port to. + // +optional optional string hostIP = 5; } @@ -438,18 +491,22 @@ message ContainerPort { // If none of them is specified, the default one is ContainerStateWaiting. message ContainerState { // Details about a waiting container + // +optional optional ContainerStateWaiting waiting = 1; // Details about a running container + // +optional optional ContainerStateRunning running = 2; // Details about a terminated container + // +optional optional ContainerStateTerminated terminated = 3; } // ContainerStateRunning is a running state of a container. message ContainerStateRunning { // Time at which the container was last (re-)started + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startedAt = 1; } @@ -459,30 +516,38 @@ message ContainerStateTerminated { optional int32 exitCode = 1; // Signal from the last termination of the container + // +optional optional int32 signal = 2; // (brief) reason from the last termination of the container + // +optional optional string reason = 3; // Message regarding the last termination of the container + // +optional optional string message = 4; // Time at which previous execution of the container started + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startedAt = 5; // Time at which the container last terminated + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time finishedAt = 6; // Container's ID in the format 'docker://' + // +optional optional string containerID = 7; } // ContainerStateWaiting is a waiting state of a container. message ContainerStateWaiting { // (brief) reason the container is not yet running. + // +optional optional string reason = 1; // Message regarding why the container is not yet running. + // +optional optional string message = 2; } @@ -493,9 +558,11 @@ message ContainerStatus { optional string name = 1; // Details about the container's current condition. + // +optional optional ContainerState state = 2; // Details about the container's last termination condition. + // +optional optional ContainerState lastState = 3; // Specifies whether the container has passed its readiness probe. @@ -517,6 +584,7 @@ message ContainerStatus { // Container's ID in the format 'docker://'. // More info: http://kubernetes.io/docs/user-guide/container-environment#container-information + // +optional optional string containerID = 8; } @@ -532,14 +600,17 @@ message DeleteOptions { // The value zero indicates delete immediately. If this value is nil, the default grace period for the // specified type will be used. // Defaults to a per object value if not specified. zero means delete immediately. + // +optional optional int64 gracePeriodSeconds = 1; // Must be fulfilled before a deletion is carried out. If not possible, a 409 Conflict status will be // returned. + // +optional optional Preconditions preconditions = 2; // Should the dependent objects be orphaned. If true/false, the "orphan" // finalizer will be added to/removed from the object's finalizers list. + // +optional optional bool orphanDependents = 3; } @@ -549,16 +620,19 @@ message DownwardAPIVolumeFile { optional string path = 1; // Required: Selects a field of the pod: only annotations, labels, name and namespace are supported. + // +optional optional ObjectFieldSelector fieldRef = 2; // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional optional ResourceFieldSelector resourceFieldRef = 3; // Optional: mode bits to use on this file, must be a value between 0 // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional optional int32 mode = 4; } @@ -566,6 +640,7 @@ message DownwardAPIVolumeFile { // Downward API volumes support ownership management and SELinux relabeling. message DownwardAPIVolumeSource { // Items is a list of downward API volume file + // +optional repeated DownwardAPIVolumeFile items = 1; // Optional: mode bits to use on created files by default. Must be a @@ -573,6 +648,7 @@ message DownwardAPIVolumeSource { // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional optional int32 defaultMode = 2; } @@ -583,6 +659,7 @@ message EmptyDirVolumeSource { // The default is "" which means to use the node's default medium. // Must be an empty string (default) or Memory. // More info: http://kubernetes.io/docs/user-guide/volumes#emptydir + // +optional optional string medium = 1; } @@ -597,12 +674,15 @@ message EndpointAddress { optional string ip = 1; // The Hostname of this endpoint + // +optional optional string hostname = 3; // Optional: Node hosting this endpoint. This can be used to determine endpoints local to a node. + // +optional optional string nodeName = 4; // Reference to object providing the endpoint. + // +optional optional ObjectReference targetRef = 2; } @@ -611,6 +691,7 @@ message EndpointPort { // The name of this port (corresponds to ServicePort.Name). // Must be a DNS_LABEL. // Optional only if one port is defined. + // +optional optional string name = 1; // The port number of the endpoint. @@ -619,6 +700,7 @@ message EndpointPort { // The IP protocol for this port. // Must be UDP or TCP. // Default is TCP. + // +optional optional string protocol = 3; } @@ -635,14 +717,17 @@ message EndpointPort { message EndpointSubset { // IP addresses which offer the related ports that are marked as ready. These endpoints // should be considered safe for load balancers and clients to utilize. + // +optional repeated EndpointAddress addresses = 1; // IP addresses which offer the related ports but are not currently marked as ready // because they have not yet finished starting, have recently failed a readiness check, // or have recently failed a liveness check. + // +optional repeated EndpointAddress notReadyAddresses = 2; // Port numbers available on the related IP addresses. + // +optional repeated EndpointPort ports = 3; } @@ -661,6 +746,7 @@ message EndpointSubset { message Endpoints { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // The set of all endpoints is the union of all subsets. Addresses are placed into @@ -677,6 +763,7 @@ message Endpoints { message EndpointsList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of endpoints. @@ -696,9 +783,11 @@ message EnvVar { // references will never be expanded, regardless of whether the variable // exists or not. // Defaults to "". + // +optional optional string value = 2; // Source for the environment variable's value. Cannot be used if value is not empty. + // +optional optional EnvVarSource valueFrom = 3; } @@ -706,16 +795,20 @@ message EnvVar { message EnvVarSource { // Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, // spec.nodeName, spec.serviceAccountName, status.podIP. + // +optional optional ObjectFieldSelector fieldRef = 1; // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional optional ResourceFieldSelector resourceFieldRef = 2; // Selects a key of a ConfigMap. + // +optional optional ConfigMapKeySelector configMapKeyRef = 3; // Selects a key of a secret in the pod's namespace + // +optional optional SecretKeySelector secretKeyRef = 4; } @@ -732,25 +825,32 @@ message Event { // This should be a short, machine understandable string that gives the reason // for the transition into the object's current status. // TODO: provide exact specification for format. + // +optional optional string reason = 3; // A human-readable description of the status of this operation. // TODO: decide on maximum length. + // +optional optional string message = 4; // The component reporting this event. Should be a short machine understandable string. + // +optional optional EventSource source = 5; // The time at which the event was first recorded. (Time of server receipt is in TypeMeta.) + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time firstTimestamp = 6; // The time at which the most recent occurrence of this event was recorded. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTimestamp = 7; // The number of times this event has occurred. + // +optional optional int32 count = 8; // Type of this event (Normal, Warning), new types could be added in the future + // +optional optional string type = 9; } @@ -758,6 +858,7 @@ message Event { message EventList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of events @@ -767,9 +868,11 @@ message EventList { // EventSource contains information for an event. message EventSource { // Component from which the event is generated. + // +optional optional string component = 1; // Node name on which the event is generated. + // +optional optional string host = 2; } @@ -780,6 +883,7 @@ message ExecAction { // not run inside a shell, so traditional shell instructions ('|', etc) won't work. To use // a shell, you need to explicitly call out to that shell. // Exit status of 0 is treated as live/healthy and non-zero is unhealthy. + // +optional repeated string command = 1; } @@ -806,10 +910,12 @@ message FCVolumeSource { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional optional string fsType = 3; // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional optional bool readOnly = 4; } @@ -822,6 +928,7 @@ message FlexVolumeSource { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". The default filesystem depends on FlexVolume script. + // +optional optional string fsType = 2; // Optional: SecretRef is reference to the secret object containing @@ -829,13 +936,16 @@ message FlexVolumeSource { // empty if no secret object is specified. If the secret object // contains more than one secret, all secrets are passed to the plugin // scripts. + // +optional optional LocalObjectReference secretRef = 3; // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional optional bool readOnly = 4; // Optional: Extra command options if any. + // +optional map options = 5; } @@ -845,9 +955,11 @@ message FlexVolumeSource { message FlockerVolumeSource { // Name of the dataset stored as metadata -> name on the dataset for Flocker // should be considered as deprecated + // +optional optional string datasetName = 1; // UUID of the dataset. This is unique identifier of a Flocker dataset + // +optional optional string datasetUUID = 2; } @@ -867,6 +979,7 @@ message GCEPersistentDiskVolumeSource { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional optional string fsType = 2; // The partition in the volume that you want to mount. @@ -874,11 +987,13 @@ message GCEPersistentDiskVolumeSource { // Examples: For volume /dev/sda1, you specify the partition as "1". // Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty). // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional optional int32 partition = 3; // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional optional bool readOnly = 4; } @@ -890,12 +1005,14 @@ message GitRepoVolumeSource { optional string repository = 1; // Commit hash for the specified revision. + // +optional optional string revision = 2; // Target directory name. // Must not contain or start with '..'. If '.' is supplied, the volume directory will be the // git repository. Otherwise, if specified, the volume will contain the git repository in // the subdirectory with the given name. + // +optional optional string directory = 3; } @@ -913,12 +1030,14 @@ message GlusterfsVolumeSource { // ReadOnly here will force the Glusterfs volume to be mounted with read-only permissions. // Defaults to false. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md#create-a-pod + // +optional optional bool readOnly = 3; } // HTTPGetAction describes an action based on HTTP Get requests. message HTTPGetAction { // Path to access on the HTTP server. + // +optional optional string path = 1; // Name or number of the port to access on the container. @@ -928,13 +1047,16 @@ message HTTPGetAction { // Host name to connect to, defaults to the pod IP. You probably want to set // "Host" in httpHeaders instead. + // +optional optional string host = 3; // Scheme to use for connecting to the host. // Defaults to HTTP. + // +optional optional string scheme = 4; // Custom headers to set in the request. HTTP allows repeated headers. + // +optional repeated HTTPHeader httpHeaders = 5; } @@ -952,14 +1074,17 @@ message HTTPHeader { message Handler { // One and only one of the following should be specified. // Exec specifies the action to take. + // +optional optional ExecAction exec = 1; // HTTPGet specifies the http request to perform. + // +optional optional HTTPGetAction httpGet = 2; // TCPSocket specifies an action involving a TCP port. // TCP hooks not yet supported // TODO: implement a realistic TCP lifecycle hook + // +optional optional TCPSocketAction tcpSocket = 3; } @@ -986,6 +1111,7 @@ message ISCSIVolumeSource { optional int32 lun = 3; // Optional: Defaults to 'default' (tcp). iSCSI interface name that uses an iSCSI transport. + // +optional optional string iscsiInterface = 4; // Filesystem type of the volume that you want to mount. @@ -993,10 +1119,12 @@ message ISCSIVolumeSource { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#iscsi // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional optional string fsType = 5; // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. + // +optional optional bool readOnly = 6; } @@ -1015,6 +1143,7 @@ message KeyToPath { // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional optional int32 mode = 3; } @@ -1026,6 +1155,7 @@ message Lifecycle { // the container is terminated and restarted according to its restart policy. // Other management of the container blocks until the hook completes. // More info: http://kubernetes.io/docs/user-guide/container-environment#hook-details + // +optional optional Handler postStart = 1; // PreStop is called immediately before a container is terminated. @@ -1034,6 +1164,7 @@ message Lifecycle { // Regardless of the outcome of the handler, the container is eventually terminated. // Other management of the container blocks until the hook completes. // More info: http://kubernetes.io/docs/user-guide/container-environment#hook-details + // +optional optional Handler preStop = 2; } @@ -1041,31 +1172,39 @@ message Lifecycle { message LimitRange { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the limits enforced. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional LimitRangeSpec spec = 2; } // LimitRangeItem defines a min/max usage limit for any resource that matches on kind. message LimitRangeItem { // Type of resource that this limit applies to. + // +optional optional string type = 1; // Max usage constraints on this kind by resource name. + // +optional map max = 2; // Min usage constraints on this kind by resource name. + // +optional map min = 3; // Default resource requirement limit value by resource name if resource limit is omitted. + // +optional map default = 4; // DefaultRequest is the default resource requirement request value by resource name if resource request is omitted. + // +optional map defaultRequest = 5; // MaxLimitRequestRatio if specified, the named resource must have a request and limit that are both non-zero where limit divided by request is less than or equal to the enumerated value; this represents the max burst for the named resource. + // +optional map maxLimitRequestRatio = 6; } @@ -1073,6 +1212,7 @@ message LimitRangeItem { message LimitRangeList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of LimitRange objects. @@ -1090,6 +1230,7 @@ message LimitRangeSpec { message List { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of objects @@ -1100,21 +1241,26 @@ message List { message ListOptions { // A selector to restrict the list of returned objects by their labels. // Defaults to everything. + // +optional optional string labelSelector = 1; // A selector to restrict the list of returned objects by their fields. // Defaults to everything. + // +optional optional string fieldSelector = 2; // Watch for changes to the described resources and return them as a stream of // add, update, and remove notifications. Specify resourceVersion. + // +optional optional bool watch = 3; // When specified with a watch call, shows changes that occur after that particular version of a resource. // Defaults to changes from the beginning of history. + // +optional optional string resourceVersion = 4; // Timeout for the list/watch call. + // +optional optional int64 timeoutSeconds = 5; } @@ -1123,10 +1269,12 @@ message ListOptions { message LoadBalancerIngress { // IP is set for load-balancer ingress points that are IP based // (typically GCE or OpenStack load-balancers) + // +optional optional string ip = 1; // Hostname is set for load-balancer ingress points that are DNS based // (typically AWS load-balancers) + // +optional optional string hostname = 2; } @@ -1134,6 +1282,7 @@ message LoadBalancerIngress { message LoadBalancerStatus { // Ingress is a list containing ingress points for the load-balancer. // Traffic intended for the service should be sent to these ingress points. + // +optional repeated LoadBalancerIngress ingress = 1; } @@ -1143,6 +1292,7 @@ message LocalObjectReference { // Name of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#names // TODO: Add other useful fields. apiVersion, kind, uid? + // +optional optional string name = 1; } @@ -1161,6 +1311,7 @@ message NFSVolumeSource { // the NFS export to be mounted with read-only permissions. // Defaults to false. // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional optional bool readOnly = 3; } @@ -1169,14 +1320,17 @@ message NFSVolumeSource { message Namespace { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the behavior of the Namespace. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional NamespaceSpec spec = 2; // Status describes the current status of a Namespace. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional NamespaceStatus status = 3; } @@ -1184,6 +1338,7 @@ message Namespace { message NamespaceList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Namespace objects in the list. @@ -1195,6 +1350,7 @@ message NamespaceList { message NamespaceSpec { // Finalizers is an opaque list of values that must be empty to permanently remove object from storage. // More info: http://releases.k8s.io/HEAD/docs/design/namespaces.md#finalizers + // +optional repeated string finalizers = 1; } @@ -1202,6 +1358,7 @@ message NamespaceSpec { message NamespaceStatus { // Phase is the current lifecycle phase of the namespace. // More info: http://releases.k8s.io/HEAD/docs/design/namespaces.md#phases + // +optional optional string phase = 1; } @@ -1210,16 +1367,19 @@ message NamespaceStatus { message Node { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the behavior of a node. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional NodeSpec spec = 2; // Most recently observed status of the node. // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional NodeStatus status = 3; } @@ -1239,6 +1399,7 @@ message NodeAffinity { // If the affinity requirements specified by this field cease to be met // at some point during pod execution (e.g. due to an update), the system // may or may not try to eventually evict the pod from its node. + // +optional optional NodeSelector requiredDuringSchedulingIgnoredDuringExecution = 1; // The scheduler will prefer to schedule pods to nodes that satisfy @@ -1250,6 +1411,7 @@ message NodeAffinity { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node matches the corresponding matchExpressions; the // node(s) with the highest sum are the most preferred. + // +optional repeated PreferredSchedulingTerm preferredDuringSchedulingIgnoredDuringExecution = 2; } @@ -1262,21 +1424,26 @@ message NodeCondition { optional string status = 2; // Last time we got an update on a given condition. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastHeartbeatTime = 3; // Last time the condition transit from one status to another. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; // (brief) reason for the condition's last transition. + // +optional optional string reason = 5; // Human readable message indicating details about last transition. + // +optional optional string message = 6; } // NodeDaemonEndpoints lists ports opened by daemons running on the Node. message NodeDaemonEndpoints { // Endpoint on which Kubelet is listening. + // +optional optional DaemonEndpoint kubeletEndpoint = 1; } @@ -1284,6 +1451,7 @@ message NodeDaemonEndpoints { message NodeList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of nodes @@ -1293,6 +1461,7 @@ message NodeList { // NodeProxyOptions is the query options to a Node's proxy call. message NodeProxyOptions { // Path is the URL path to use for the current proxy request to node. + // +optional optional string path = 1; } @@ -1319,6 +1488,7 @@ message NodeSelectorRequirement { // the values array must be empty. If the operator is Gt or Lt, the values // array must have a single element, which will be interpreted as an integer. // This array is replaced during a strategic merge patch. + // +optional repeated string values = 3; } @@ -1331,17 +1501,21 @@ message NodeSelectorTerm { // NodeSpec describes the attributes that a node is created with. message NodeSpec { // PodCIDR represents the pod IP range assigned to the node. + // +optional optional string podCIDR = 1; // External ID of the node assigned by some machine database (e.g. a cloud provider). // Deprecated. + // +optional optional string externalID = 2; // ID of the node assigned by the cloud provider in the format: :// + // +optional optional string providerID = 3; // Unschedulable controls node schedulability of new pods. By default, node is schedulable. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#manual-node-administration"` + // +optional optional bool unschedulable = 4; } @@ -1349,40 +1523,50 @@ message NodeSpec { message NodeStatus { // Capacity represents the total resources of a node. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#capacity for more details. + // +optional map capacity = 1; // Allocatable represents the resources of a node that are available for scheduling. // Defaults to Capacity. + // +optional map allocatable = 2; // NodePhase is the recently observed lifecycle phase of the node. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-phase // The field is never populated, and now is deprecated. + // +optional optional string phase = 3; // Conditions is an array of current observed node conditions. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-condition + // +optional repeated NodeCondition conditions = 4; // List of addresses reachable to the node. // Queried from cloud provider, if available. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses + // +optional repeated NodeAddress addresses = 5; // Endpoints of daemons running on the Node. + // +optional optional NodeDaemonEndpoints daemonEndpoints = 6; // Set of ids/uuids to uniquely identify the node. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info + // +optional optional NodeSystemInfo nodeInfo = 7; // List of container images on this node + // +optional repeated ContainerImage images = 8; // List of attachable volumes in use (mounted) by the node. + // +optional repeated string volumesInUse = 9; // List of volumes that are attached to the node. + // +optional repeated AttachedVolume volumesAttached = 10; } @@ -1426,6 +1610,7 @@ message NodeSystemInfo { // ObjectFieldSelector selects an APIVersioned field of an object. message ObjectFieldSelector { // Version of the schema the FieldPath is written in terms of, defaults to "v1". + // +optional optional string apiVersion = 1; // Path of the field to select in the specified API version. @@ -1441,6 +1626,7 @@ message ObjectMeta { // definition. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional optional string name = 1; // GenerateName is an optional prefix, used by the server, to generate a unique @@ -1458,6 +1644,7 @@ message ObjectMeta { // // Applied only if Name is not specified. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#idempotency + // +optional optional string generateName = 2; // Namespace defines the space within each name must be unique. An empty namespace is @@ -1468,11 +1655,13 @@ message ObjectMeta { // Must be a DNS_LABEL. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/namespaces + // +optional optional string namespace = 3; // SelfLink is a URL representing this object. // Populated by the system. // Read-only. + // +optional optional string selfLink = 4; // UID is the unique in time and space value for this object. It is typically generated by @@ -1482,6 +1671,7 @@ message ObjectMeta { // Populated by the system. // Read-only. // More info: http://kubernetes.io/docs/user-guide/identifiers#uids + // +optional optional string uid = 5; // An opaque value that represents the internal version of this object that can @@ -1494,10 +1684,12 @@ message ObjectMeta { // Read-only. // Value must be treated as opaque by clients and . // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional optional string resourceVersion = 6; // A sequence number representing a specific generation of the desired state. // Populated by the system. Read-only. + // +optional optional int64 generation = 7; // CreationTimestamp is a timestamp representing the server time when this object was @@ -1508,6 +1700,7 @@ message ObjectMeta { // Read-only. // Null for lists. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time creationTimestamp = 8; // DeletionTimestamp is RFC 3339 date and time at which this resource will be deleted. This @@ -1524,41 +1717,48 @@ message ObjectMeta { // Populated by the system when a graceful deletion is requested. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time deletionTimestamp = 9; // Number of seconds allowed for this object to gracefully terminate before // it will be removed from the system. Only set when deletionTimestamp is also set. // May only be shortened. // Read-only. + // +optional optional int64 deletionGracePeriodSeconds = 10; // Map of string keys and values that can be used to organize and categorize // (scope and select) objects. May match selectors of replication controllers // and services. // More info: http://kubernetes.io/docs/user-guide/labels + // +optional map labels = 11; // Annotations is an unstructured key value map stored with a resource that may be // set by external tools to store and retrieve arbitrary metadata. They are not // queryable and should be preserved when modifying objects. // More info: http://kubernetes.io/docs/user-guide/annotations + // +optional map annotations = 12; // List of objects depended by this object. If ALL objects in the list have // been deleted, this object will be garbage collected. If this object is managed by a controller, // then an entry in this list will point to this controller, with the controller field set to true. // There cannot be more than one managing controller. + // +optional repeated OwnerReference ownerReferences = 13; // Must be empty before the object is deleted from the registry. Each entry // is an identifier for the responsible component that will remove the entry // from the list. If the deletionTimestamp of the object is non-nil, entries // in this list can only be removed. + // +optional repeated string finalizers = 14; // The name of the cluster which the object belongs to. // This is used to distinguish resources with same name and namespace in different clusters. // This field is not set anywhere right now and apiserver is going to ignore it if set in create or update request. + // +optional optional string clusterName = 15; } @@ -1566,25 +1766,31 @@ message ObjectMeta { message ObjectReference { // Kind of the referent. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional string kind = 1; // Namespace of the referent. // More info: http://kubernetes.io/docs/user-guide/namespaces + // +optional optional string namespace = 2; // Name of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional optional string name = 3; // UID of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#uids + // +optional optional string uid = 4; // API version of the referent. + // +optional optional string apiVersion = 5; // Specific resourceVersion to which this reference is made, if any. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional optional string resourceVersion = 6; // If referring to a piece of an object instead of an entire object, this string @@ -1595,6 +1801,7 @@ message ObjectReference { // index 2 in this pod). This syntax is chosen only to have some well-defined way of // referencing a part of an object. // TODO: this design is not final and this field is subject to change in the future. + // +optional optional string fieldPath = 7; } @@ -1618,6 +1825,7 @@ message OwnerReference { optional string uid = 4; // If true, this reference points to the managing controller. + // +optional optional bool controller = 6; } @@ -1627,17 +1835,20 @@ message OwnerReference { message PersistentVolume { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines a specification of a persistent volume owned by the cluster. // Provisioned by an administrator. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistent-volumes + // +optional optional PersistentVolumeSpec spec = 2; // Status represents the current information/status for the persistent volume. // Populated by the system. // Read-only. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistent-volumes + // +optional optional PersistentVolumeStatus status = 3; } @@ -1645,15 +1856,18 @@ message PersistentVolume { message PersistentVolumeClaim { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the desired characteristics of a volume requested by a pod author. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional optional PersistentVolumeClaimSpec spec = 2; // Status represents the current information/status of a persistent volume claim. // Read-only. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional optional PersistentVolumeClaimStatus status = 3; } @@ -1661,6 +1875,7 @@ message PersistentVolumeClaim { message PersistentVolumeClaimList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // A list of persistent volume claims. @@ -1673,29 +1888,36 @@ message PersistentVolumeClaimList { message PersistentVolumeClaimSpec { // AccessModes contains the desired access modes the volume should have. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes-1 + // +optional repeated string accessModes = 1; // A label query over volumes to consider for binding. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 4; // Resources represents the minimum resources the volume should have. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#resources + // +optional optional ResourceRequirements resources = 2; // VolumeName is the binding reference to the PersistentVolume backing this claim. + // +optional optional string volumeName = 3; } // PersistentVolumeClaimStatus is the current status of a persistent volume claim. message PersistentVolumeClaimStatus { // Phase represents the current phase of PersistentVolumeClaim. + // +optional optional string phase = 1; // AccessModes contains the actual access modes the volume backing the PVC has. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes-1 + // +optional repeated string accessModes = 2; // Represents the actual resources of the underlying volume. + // +optional map capacity = 3; } @@ -1710,6 +1932,7 @@ message PersistentVolumeClaimVolumeSource { // Will force the ReadOnly setting in VolumeMounts. // Default false. + // +optional optional bool readOnly = 2; } @@ -1717,6 +1940,7 @@ message PersistentVolumeClaimVolumeSource { message PersistentVolumeList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of persistent volumes. @@ -1730,11 +1954,13 @@ message PersistentVolumeSource { // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. Provisioned by an admin. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional optional GCEPersistentDiskVolumeSource gcePersistentDisk = 1; // AWSElasticBlockStore represents an AWS Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional optional AWSElasticBlockStoreVolumeSource awsElasticBlockStore = 2; // HostPath represents a directory on the host. @@ -1742,53 +1968,67 @@ message PersistentVolumeSource { // This is useful for single-node development and testing only! // On-host storage is not supported in any way and WILL NOT WORK in a multi-node cluster. // More info: http://kubernetes.io/docs/user-guide/volumes#hostpath + // +optional optional HostPathVolumeSource hostPath = 3; // Glusterfs represents a Glusterfs volume that is attached to a host and // exposed to the pod. Provisioned by an admin. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md + // +optional optional GlusterfsVolumeSource glusterfs = 4; // NFS represents an NFS mount on the host. Provisioned by an admin. // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional optional NFSVolumeSource nfs = 5; // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md + // +optional optional RBDVolumeSource rbd = 6; // ISCSI represents an ISCSI Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. Provisioned by an admin. + // +optional optional ISCSIVolumeSource iscsi = 7; // Cinder represents a cinder volume attached and mounted on kubelets host machine // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional optional CinderVolumeSource cinder = 8; // CephFS represents a Ceph FS mount on the host that shares a pod's lifetime + // +optional optional CephFSVolumeSource cephfs = 9; // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional optional FCVolumeSource fc = 10; // Flocker represents a Flocker volume attached to a kubelet's host machine and exposed to the pod for its usage. This depends on the Flocker control service being running + // +optional optional FlockerVolumeSource flocker = 11; // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an // alpha feature and may change in future. + // +optional optional FlexVolumeSource flexVolume = 12; // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional optional AzureFileVolumeSource azureFile = 13; // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional optional VsphereVirtualDiskVolumeSource vsphereVolume = 14; // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional optional QuobyteVolumeSource quobyte = 15; // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional optional AzureDiskVolumeSource azureDisk = 16; } @@ -1796,6 +2036,7 @@ message PersistentVolumeSource { message PersistentVolumeSpec { // A description of the persistent volume's resources and capacity. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#capacity + // +optional map capacity = 1; // The actual volume backing the persistent volume. @@ -1803,18 +2044,21 @@ message PersistentVolumeSpec { // AccessModes contains all ways the volume can be mounted. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes + // +optional repeated string accessModes = 3; // ClaimRef is part of a bi-directional binding between PersistentVolume and PersistentVolumeClaim. // Expected to be non-nil when bound. // claim.VolumeName is the authoritative bind between PV and PVC. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#binding + // +optional optional ObjectReference claimRef = 4; // What happens to a persistent volume when released from its claim. // Valid options are Retain (default) and Recycle. // Recycling must be supported by the volume plugin underlying this persistent volume. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#recycling-policy + // +optional optional string persistentVolumeReclaimPolicy = 5; } @@ -1822,13 +2066,16 @@ message PersistentVolumeSpec { message PersistentVolumeStatus { // Phase indicates if a volume is available, bound to a claim, or released by a claim. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#phase + // +optional optional string phase = 1; // A human-readable message indicating details about why the volume is in this state. + // +optional optional string message = 2; // Reason is a brief CamelCase string that describes any failure and is meant // for machine parsing and tidy display in the CLI. + // +optional optional string reason = 3; } @@ -1837,10 +2084,12 @@ message PersistentVolumeStatus { message Pod { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Specification of the desired behavior of the pod. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional PodSpec spec = 2; // Most recently observed status of the pod. @@ -1848,6 +2097,7 @@ message Pod { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional PodStatus status = 3; } @@ -1861,6 +2111,7 @@ message PodAffinity { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1869,6 +2120,7 @@ message PodAffinity { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional repeated PodAffinityTerm requiredDuringSchedulingIgnoredDuringExecution = 1; // The scheduler will prefer to schedule pods to nodes that satisfy @@ -1880,6 +2132,7 @@ message PodAffinity { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional repeated WeightedPodAffinityTerm preferredDuringSchedulingIgnoredDuringExecution = 2; } @@ -1891,6 +2144,7 @@ message PodAffinity { // a pod of the set of pods is running message PodAffinityTerm { // A label query over a set of resources, in this case pods. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector labelSelector = 1; // namespaces specifies which namespaces the labelSelector applies to (matches against); @@ -1906,6 +2160,7 @@ message PodAffinityTerm { // For PreferredDuringScheduling pod anti-affinity, empty topologyKey is interpreted as "all topologies" // ("all topologies" here means all the topologyKeys indicated by scheduler command-line argument --failure-domains); // for affinity and for RequiredDuringScheduling pod anti-affinity, empty topologyKey is not allowed. + // +optional optional string topologyKey = 3; } @@ -1919,6 +2174,7 @@ message PodAntiAffinity { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the anti-affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1927,6 +2183,7 @@ message PodAntiAffinity { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional repeated PodAffinityTerm requiredDuringSchedulingIgnoredDuringExecution = 1; // The scheduler will prefer to schedule pods to nodes that satisfy @@ -1938,6 +2195,7 @@ message PodAntiAffinity { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional repeated WeightedPodAffinityTerm preferredDuringSchedulingIgnoredDuringExecution = 2; } @@ -1948,24 +2206,29 @@ message PodAntiAffinity { message PodAttachOptions { // Stdin if true, redirects the standard input stream of the pod for this call. // Defaults to false. + // +optional optional bool stdin = 1; // Stdout if true indicates that stdout is to be redirected for the attach call. // Defaults to true. + // +optional optional bool stdout = 2; // Stderr if true indicates that stderr is to be redirected for the attach call. // Defaults to true. + // +optional optional bool stderr = 3; // TTY if true indicates that a tty will be allocated for the attach call. // This is passed through the container runtime so the tty // is allocated on the worker node by the container runtime. // Defaults to false. + // +optional optional bool tty = 4; // The container in which to execute the command. // Defaults to only container if there is only one container in the pod. + // +optional optional string container = 5; } @@ -1982,15 +2245,19 @@ message PodCondition { optional string status = 2; // Last time we probed the condition. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; // Last time the condition transitioned from one status to another. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; // Unique, one-word, CamelCase reason for the condition's last transition. + // +optional optional string reason = 5; // Human-readable message indicating details about last transition. + // +optional optional string message = 6; } @@ -2001,22 +2268,27 @@ message PodCondition { message PodExecOptions { // Redirect the standard input stream of the pod for this call. // Defaults to false. + // +optional optional bool stdin = 1; // Redirect the standard output stream of the pod for this call. // Defaults to true. + // +optional optional bool stdout = 2; // Redirect the standard error stream of the pod for this call. // Defaults to true. + // +optional optional bool stderr = 3; // TTY if true indicates that a tty will be allocated for the exec call. // Defaults to false. + // +optional optional bool tty = 4; // Container in which to execute the command. // Defaults to only container if there is only one container in the pod. + // +optional optional string container = 5; // Command is the remote command to execute. argv array. Not executed within a shell. @@ -2027,6 +2299,7 @@ message PodExecOptions { message PodList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of pods. @@ -2037,43 +2310,52 @@ message PodList { // PodLogOptions is the query options for a Pod's logs REST call. message PodLogOptions { // The container for which to stream logs. Defaults to only container if there is one container in the pod. + // +optional optional string container = 1; // Follow the log stream of the pod. Defaults to false. + // +optional optional bool follow = 2; // Return previous terminated container logs. Defaults to false. + // +optional optional bool previous = 3; // A relative time in seconds before the current time from which to show logs. If this value // precedes the time a pod was started, only logs since the pod start will be returned. // If this value is in the future, no logs will be returned. // Only one of sinceSeconds or sinceTime may be specified. + // +optional optional int64 sinceSeconds = 4; // An RFC3339 timestamp from which to show logs. If this value // precedes the time a pod was started, only logs since the pod start will be returned. // If this value is in the future, no logs will be returned. // Only one of sinceSeconds or sinceTime may be specified. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time sinceTime = 5; // If true, add an RFC3339 or RFC3339Nano timestamp at the beginning of every line // of log output. Defaults to false. + // +optional optional bool timestamps = 6; // If set, the number of lines from the end of the logs to show. If not specified, // logs are shown from the creation of the container or sinceSeconds or sinceTime + // +optional optional int64 tailLines = 7; // If set, the number of bytes to read from the server before terminating the // log output. This may not display a complete final line of logging, and may return // slightly more or slightly less than the specified limit. + // +optional optional int64 limitBytes = 8; } // PodProxyOptions is the query options to a Pod's proxy call. message PodProxyOptions { // Path is the URL path to use for the current proxy request to pod. + // +optional optional string path = 1; } @@ -2086,6 +2368,7 @@ message PodSecurityContext { // container. May also be set in SecurityContext. If set in // both SecurityContext and PodSecurityContext, the value specified in SecurityContext // takes precedence for that container. + // +optional optional SELinuxOptions seLinuxOptions = 1; // The UID to run the entrypoint of the container process. @@ -2093,6 +2376,7 @@ message PodSecurityContext { // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence // for that container. + // +optional optional int64 runAsUser = 2; // Indicates that the container must run as a non-root user. @@ -2101,11 +2385,13 @@ message PodSecurityContext { // If unset or false, no such validation will be performed. // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional optional bool runAsNonRoot = 3; // A list of groups applied to the first process run in each container, in addition // to the container's primary GID. If unspecified, no groups will be added to // any container. + // +optional repeated int64 supplementalGroups = 4; // A special supplemental group that applies to all containers in a pod. @@ -2117,6 +2403,7 @@ message PodSecurityContext { // 3. The permission bits are OR'd with rw-rw---- // // If unset, the Kubelet will not modify the ownership and permissions of any volume. + // +optional optional int64 fsGroup = 5; } @@ -2124,6 +2411,7 @@ message PodSecurityContext { // Exactly one field should be set. message PodSignature { // Reference to controller whose pods should avoid this node. + // +optional optional OwnerReference podController = 1; } @@ -2131,6 +2419,7 @@ message PodSignature { message PodSpec { // List of volumes that can be mounted by containers belonging to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes + // +optional repeated Volume volumes = 1; // List of containers belonging to the pod. @@ -2144,6 +2433,7 @@ message PodSpec { // One of Always, OnFailure, Never. // Default to Always. // More info: http://kubernetes.io/docs/user-guide/pod-states#restartpolicy + // +optional optional string restartPolicy = 3; // Optional duration in seconds the pod needs to terminate gracefully. May be decreased in delete request. @@ -2153,69 +2443,83 @@ message PodSpec { // a termination signal and the time when the processes are forcibly halted with a kill signal. // Set this value longer than the expected cleanup time for your process. // Defaults to 30 seconds. + // +optional optional int64 terminationGracePeriodSeconds = 4; // Optional duration in seconds the pod may be active on the node relative to // StartTime before the system will actively try to mark it failed and kill associated containers. // Value must be a positive integer. + // +optional optional int64 activeDeadlineSeconds = 5; // Set DNS policy for containers within the pod. // One of 'ClusterFirst' or 'Default'. // Defaults to "ClusterFirst". + // +optional optional string dnsPolicy = 6; // NodeSelector is a selector which must be true for the pod to fit on a node. // Selector which must match a node's labels for the pod to be scheduled on that node. // More info: http://kubernetes.io/docs/user-guide/node-selection/README + // +optional map nodeSelector = 7; // ServiceAccountName is the name of the ServiceAccount to use to run this pod. // More info: http://releases.k8s.io/HEAD/docs/design/service_accounts.md + // +optional optional string serviceAccountName = 8; // DeprecatedServiceAccount is a depreciated alias for ServiceAccountName. // Deprecated: Use serviceAccountName instead. // +k8s:conversion-gen=false + // +optional optional string serviceAccount = 9; // NodeName is a request to schedule this pod onto a specific node. If it is non-empty, // the scheduler simply schedules this pod onto that node, assuming that it fits resource // requirements. + // +optional optional string nodeName = 10; // Host networking requested for this pod. Use the host's network namespace. // If this option is set, the ports that will be used must be specified. // Default to false. // +k8s:conversion-gen=false + // +optional optional bool hostNetwork = 11; // Use the host's pid namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional optional bool hostPID = 12; // Use the host's ipc namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional optional bool hostIPC = 13; // SecurityContext holds pod-level security attributes and common container settings. // Optional: Defaults to empty. See type description for default values of each field. + // +optional optional PodSecurityContext securityContext = 14; // ImagePullSecrets is an optional list of references to secrets in the same namespace to use for pulling any of the images used by this PodSpec. // If specified, these secrets will be passed to individual puller implementations for them to use. For example, // in the case of docker, only DockerConfig type secrets are honored. // More info: http://kubernetes.io/docs/user-guide/images#specifying-imagepullsecrets-on-a-pod + // +optional repeated LocalObjectReference imagePullSecrets = 15; // Specifies the hostname of the Pod // If not specified, the pod's hostname will be set to a system-defined value. + // +optional optional string hostname = 16; // If specified, the fully qualified Pod hostname will be "...svc.". // If not specified, the pod will not have a domainname at all. + // +optional optional string subdomain = 17; } @@ -2224,33 +2528,41 @@ message PodSpec { message PodStatus { // Current condition of the pod. // More info: http://kubernetes.io/docs/user-guide/pod-states#pod-phase + // +optional optional string phase = 1; // Current service state of pod. // More info: http://kubernetes.io/docs/user-guide/pod-states#pod-conditions + // +optional repeated PodCondition conditions = 2; // A human readable message indicating details about why the pod is in this condition. + // +optional optional string message = 3; // A brief CamelCase message indicating details about why the pod is in this state. // e.g. 'OutOfDisk' + // +optional optional string reason = 4; // IP address of the host to which the pod is assigned. Empty if not yet scheduled. + // +optional optional string hostIP = 5; // IP address allocated to the pod. Routable at least within the cluster. // Empty if not yet allocated. + // +optional optional string podIP = 6; // RFC 3339 date and time at which the object was acknowledged by the Kubelet. // This is before the Kubelet pulled the container image(s) for the pod. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startTime = 7; // The list has one entry per container in the manifest. Each entry is currently the output // of `docker inspect`. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-statuses + // +optional repeated ContainerStatus containerStatuses = 8; } @@ -2258,6 +2570,7 @@ message PodStatus { message PodStatusResult { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Most recently observed status of the pod. @@ -2265,6 +2578,7 @@ message PodStatusResult { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional PodStatus status = 2; } @@ -2272,10 +2586,12 @@ message PodStatusResult { message PodTemplate { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Template defines the pods that will be created from this pod template. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional PodTemplateSpec template = 2; } @@ -2283,6 +2599,7 @@ message PodTemplate { message PodTemplateList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of pod templates @@ -2293,16 +2610,19 @@ message PodTemplateList { message PodTemplateSpec { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Specification of the desired behavior of the pod. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional PodSpec spec = 2; } // Preconditions must be fulfilled before an operation (update, delete, etc.) is carried out. message Preconditions { // Specifies the target UID. + // +optional optional string uid = 1; } @@ -2312,12 +2632,15 @@ message PreferAvoidPodsEntry { optional PodSignature podSignature = 1; // Time at which this entry was added to the list. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time evictionTime = 2; // (brief) reason why this entry was added to the list. + // +optional optional string reason = 3; // Human readable message indicating why this entry was added to the list. + // +optional optional string message = 4; } @@ -2339,23 +2662,28 @@ message Probe { // Number of seconds after the container has started before liveness probes are initiated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional optional int32 initialDelaySeconds = 2; // Number of seconds after which the probe times out. // Defaults to 1 second. Minimum value is 1. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional optional int32 timeoutSeconds = 3; // How often (in seconds) to perform the probe. // Default to 10 seconds. Minimum value is 1. + // +optional optional int32 periodSeconds = 4; // Minimum consecutive successes for the probe to be considered successful after having failed. // Defaults to 1. Must be 1 for liveness. Minimum value is 1. + // +optional optional int32 successThreshold = 5; // Minimum consecutive failures for the probe to be considered failed after having succeeded. // Defaults to 3. Minimum value is 1. + // +optional optional int32 failureThreshold = 6; } @@ -2372,14 +2700,17 @@ message QuobyteVolumeSource { // ReadOnly here will force the Quobyte volume to be mounted with read-only permissions. // Defaults to false. + // +optional optional bool readOnly = 3; // User to map volume access to // Defaults to serivceaccount user + // +optional optional string user = 4; // Group to map volume access to // Default is no group + // +optional optional string group = 5; } @@ -2399,32 +2730,38 @@ message RBDVolumeSource { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#rbd // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional optional string fsType = 3; // The rados pool name. // Default is rbd. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it. + // +optional optional string pool = 4; // The rados user name. // Default is admin. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional optional string user = 5; // Keyring is the path to key ring for RBDUser. // Default is /etc/ceph/keyring. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional optional string keyring = 6; // SecretRef is name of the authentication secret for RBDUser. If provided // overrides keyring. // Default is nil. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional optional LocalObjectReference secretRef = 7; // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional optional bool readOnly = 8; } @@ -2432,6 +2769,7 @@ message RBDVolumeSource { message RangeAllocation { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Range is string that identifies the range represented by 'data'. @@ -2446,10 +2784,12 @@ message ReplicationController { // If the Labels of a ReplicationController are empty, they are defaulted to // be the same as the Pod(s) that the replication controller manages. // Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the specification of the desired behavior of the replication controller. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ReplicationControllerSpec spec = 2; // Status is the most recently observed status of the replication controller. @@ -2457,6 +2797,7 @@ message ReplicationController { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ReplicationControllerStatus status = 3; } @@ -2468,23 +2809,24 @@ message ReplicationControllerCondition { // Status of the condition, one of True, False, Unknown. optional string status = 2; - // Last time we probed the condition. - optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; - // The last time the condition transitioned from one status to another. - optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 3; // The reason for the condition's last transition. - optional string reason = 5; + // +optional + optional string reason = 4; // A human readable message indicating details about the transition. - optional string message = 6; + // +optional + optional string message = 5; } // ReplicationControllerList is a collection of replication controllers. message ReplicationControllerList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of replication controllers. @@ -2498,11 +2840,13 @@ message ReplicationControllerSpec { // This is a pointer to distinguish between explicit zero and unspecified. // Defaults to 1. // More info: http://kubernetes.io/docs/user-guide/replication-controller#what-is-a-replication-controller + // +optional optional int32 replicas = 1; // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional optional int32 minReadySeconds = 4; // Selector is a label query over pods that should match the Replicas count. @@ -2510,11 +2854,13 @@ message ReplicationControllerSpec { // Label keys and values that must match in order to be controlled by this replication // controller, if empty defaulted to labels on Pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional map selector = 2; // Template is the object that describes the pod that will be created if // insufficient replicas are detected. This takes precedence over a TemplateRef. // More info: http://kubernetes.io/docs/user-guide/replication-controller#pod-template + // +optional optional PodTemplateSpec template = 3; } @@ -2526,30 +2872,37 @@ message ReplicationControllerStatus { optional int32 replicas = 1; // The number of pods that have labels matching the labels of the pod template of the replication controller. + // +optional optional int32 fullyLabeledReplicas = 2; // The number of ready replicas for this replication controller. + // +optional optional int32 readyReplicas = 4; // The number of available replicas (ready for at least minReadySeconds) for this replication controller. + // +optional optional int32 availableReplicas = 5; // ObservedGeneration reflects the generation of the most recently observed replication controller. + // +optional optional int64 observedGeneration = 3; // Represents the latest available observations of a replication controller's current state. + // +optional repeated ReplicationControllerCondition conditions = 6; } // ResourceFieldSelector represents container resources (cpu, memory) and their output format message ResourceFieldSelector { // Container name: required for volumes, optional for env vars + // +optional optional string containerName = 1; // Required: resource to select optional string resource = 2; // Specifies the output format of the exposed resources, defaults to "1" + // +optional optional k8s.io.kubernetes.pkg.api.resource.Quantity divisor = 3; } @@ -2557,14 +2910,17 @@ message ResourceFieldSelector { message ResourceQuota { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the desired quota. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ResourceQuotaSpec spec = 2; // Status defines the actual enforced quota and its current usage. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ResourceQuotaStatus status = 3; } @@ -2572,6 +2928,7 @@ message ResourceQuota { message ResourceQuotaList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of ResourceQuota objects. @@ -2583,10 +2940,12 @@ message ResourceQuotaList { message ResourceQuotaSpec { // Hard is the set of desired hard limits for each named resource. // More info: http://releases.k8s.io/HEAD/docs/design/admission_control_resource_quota.md#admissioncontrol-plugin-resourcequota + // +optional map hard = 1; // A collection of filters that must match each object tracked by a quota. // If not specified, the quota matches all objects. + // +optional repeated string scopes = 2; } @@ -2594,9 +2953,11 @@ message ResourceQuotaSpec { message ResourceQuotaStatus { // Hard is the set of enforced hard limits for each named resource. // More info: http://releases.k8s.io/HEAD/docs/design/admission_control_resource_quota.md#admissioncontrol-plugin-resourcequota + // +optional map hard = 1; // Used is the current observed total usage of the resource in the namespace. + // +optional map used = 2; } @@ -2604,27 +2965,33 @@ message ResourceQuotaStatus { message ResourceRequirements { // Limits describes the maximum amount of compute resources allowed. // More info: http://kubernetes.io/docs/user-guide/compute-resources/ + // +optional map limits = 1; // Requests describes the minimum amount of compute resources required. // If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, // otherwise to an implementation-defined value. // More info: http://kubernetes.io/docs/user-guide/compute-resources/ + // +optional map requests = 2; } // SELinuxOptions are the labels to be applied to the container message SELinuxOptions { // User is a SELinux user label that applies to the container. + // +optional optional string user = 1; // Role is a SELinux role label that applies to the container. + // +optional optional string role = 2; // Type is a SELinux type label that applies to the container. + // +optional optional string type = 3; // Level is SELinux level label that applies to the container. + // +optional optional string level = 4; } @@ -2633,6 +3000,7 @@ message SELinuxOptions { message Secret { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Data contains the secret data. Each key must be a valid DNS_SUBDOMAIN @@ -2640,6 +3008,7 @@ message Secret { // The serialized form of the secret data is a base64 encoded string, // representing the arbitrary (possibly non-string) data value here. // Described in https://tools.ietf.org/html/rfc4648#section-4 + // +optional map data = 2; // stringData allows specifying non-binary secret data in string form. @@ -2647,9 +3016,11 @@ message Secret { // All keys and values are merged into the data field on write, overwriting any existing values. // It is never output when reading from the API. // +k8s:conversion-gen=false + // +optional map stringData = 4; // Used to facilitate programmatic handling of secret data. + // +optional optional string type = 3; } @@ -2666,6 +3037,7 @@ message SecretKeySelector { message SecretList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of secret objects. @@ -2681,6 +3053,7 @@ message SecretList { message SecretVolumeSource { // Name of the secret in the pod's namespace to use. // More info: http://kubernetes.io/docs/user-guide/volumes#secrets + // +optional optional string secretName = 1; // If unspecified, each key-value pair in the Data field of the referenced @@ -2690,6 +3063,7 @@ message SecretVolumeSource { // present. If a key is specified which is not present in the Secret, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional repeated KeyToPath items = 2; // Optional: mode bits to use on created files by default. Must be a @@ -2697,6 +3071,7 @@ message SecretVolumeSource { // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional optional int32 defaultMode = 3; } @@ -2706,23 +3081,27 @@ message SecretVolumeSource { message SecurityContext { // The capabilities to add/drop when running containers. // Defaults to the default set of capabilities granted by the container runtime. + // +optional optional Capabilities capabilities = 1; // Run container in privileged mode. // Processes in privileged containers are essentially equivalent to root on the host. // Defaults to false. + // +optional optional bool privileged = 2; // The SELinux context to be applied to the container. // If unspecified, the container runtime will allocate a random SELinux context for each // container. May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional optional SELinuxOptions seLinuxOptions = 3; // The UID to run the entrypoint of the container process. // Defaults to user specified in image metadata if unspecified. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional optional int64 runAsUser = 4; // Indicates that the container must run as a non-root user. @@ -2731,16 +3110,19 @@ message SecurityContext { // If unset or false, no such validation will be performed. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional optional bool runAsNonRoot = 5; // Whether this container has a read-only root filesystem. // Default is false. + // +optional optional bool readOnlyRootFilesystem = 6; } // SerializedReference is a reference to serialized object. message SerializedReference { // The reference to an object in the system. + // +optional optional ObjectReference reference = 1; } @@ -2750,16 +3132,19 @@ message SerializedReference { message Service { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Spec defines the behavior of a service. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ServiceSpec spec = 2; // Most recently observed status of the service. // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ServiceStatus status = 3; } @@ -2770,16 +3155,19 @@ message Service { message ServiceAccount { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional ObjectMeta metadata = 1; // Secrets is the list of secrets allowed to be used by pods running using this ServiceAccount. // More info: http://kubernetes.io/docs/user-guide/secrets + // +optional repeated ObjectReference secrets = 2; // ImagePullSecrets is a list of references to secrets in the same namespace to use for pulling any images // in pods that reference this ServiceAccount. ImagePullSecrets are distinct from Secrets because Secrets // can be mounted in the pod, but ImagePullSecrets are only accessed by the kubelet. // More info: http://kubernetes.io/docs/user-guide/secrets#manually-specifying-an-imagepullsecret + // +optional repeated LocalObjectReference imagePullSecrets = 3; } @@ -2787,6 +3175,7 @@ message ServiceAccount { message ServiceAccountList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of ServiceAccounts. @@ -2798,6 +3187,7 @@ message ServiceAccountList { message ServiceList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of services @@ -2810,10 +3200,12 @@ message ServicePort { // All ports within a ServiceSpec must have unique names. This maps to // the 'Name' field in EndpointPort objects. // Optional if only one ServicePort is defined on this service. + // +optional optional string name = 1; // The IP protocol for this port. Supports "TCP" and "UDP". // Default is TCP. + // +optional optional string protocol = 2; // The port that will be exposed by this service. @@ -2827,6 +3219,7 @@ message ServicePort { // This field is ignored for services with clusterIP=None, and should be // omitted or set equal to the 'port' field. // More info: http://kubernetes.io/docs/user-guide/services#defining-a-service + // +optional optional k8s.io.kubernetes.pkg.util.intstr.IntOrString targetPort = 4; // The port on each node on which this service is exposed when type=NodePort or LoadBalancer. @@ -2834,6 +3227,7 @@ message ServicePort { // if unused or else creation of the service will fail. // Default is to auto-allocate a port if the ServiceType of this Service requires one. // More info: http://kubernetes.io/docs/user-guide/services#type--nodeport + // +optional optional int32 nodePort = 5; } @@ -2844,6 +3238,7 @@ message ServiceProxyOptions { // For example, the whole request URL is // http://localhost/api/v1/namespaces/kube-system/services/elasticsearch-logging/_search?q=user:kimchy. // Path is _search?q=user:kimchy. + // +optional optional string path = 1; } @@ -2859,6 +3254,7 @@ message ServiceSpec { // modify. Only applies to types ClusterIP, NodePort, and LoadBalancer. // Ignored if type is ExternalName. // More info: http://kubernetes.io/docs/user-guide/services#overview + // +optional map selector = 2; // clusterIP is the IP address of the service and is usually assigned @@ -2870,6 +3266,7 @@ message ServiceSpec { // Only applies to types ClusterIP, NodePort, and LoadBalancer. Ignored if // type is ExternalName. // More info: http://kubernetes.io/docs/user-guide/services#virtual-ips-and-service-proxies + // +optional optional string clusterIP = 3; // type determines how the Service is exposed. Defaults to ClusterIP. Valid @@ -2886,6 +3283,7 @@ message ServiceSpec { // external load-balancer (if supported in the current cloud) which routes // to the clusterIP. // More info: http://kubernetes.io/docs/user-guide/services#overview + // +optional optional string type = 4; // externalIPs is a list of IP addresses for which nodes in the cluster @@ -2895,6 +3293,7 @@ message ServiceSpec { // that are not part of the Kubernetes system. A previous form of this // functionality exists as the deprecatedPublicIPs field. When using this // field, callers should also clear the deprecatedPublicIPs field. + // +optional repeated string externalIPs = 5; // deprecatedPublicIPs is deprecated and replaced by the externalIPs field @@ -2903,6 +3302,7 @@ message ServiceSpec { // any new API revisions. If both deprecatedPublicIPs *and* externalIPs are // set, deprecatedPublicIPs is used. // +k8s:conversion-gen=false + // +optional repeated string deprecatedPublicIPs = 6; // Supports "ClientIP" and "None". Used to maintain session affinity. @@ -2910,6 +3310,7 @@ message ServiceSpec { // Must be ClientIP or None. // Defaults to None. // More info: http://kubernetes.io/docs/user-guide/services#virtual-ips-and-service-proxies + // +optional optional string sessionAffinity = 7; // Only applies to Service Type: LoadBalancer @@ -2917,17 +3318,20 @@ message ServiceSpec { // This feature depends on whether the underlying cloud-provider supports specifying // the loadBalancerIP when a load balancer is created. // This field will be ignored if the cloud-provider does not support the feature. + // +optional optional string loadBalancerIP = 8; // If specified and supported by the platform, this will restrict traffic through the cloud-provider // load-balancer will be restricted to the specified client IPs. This field will be ignored if the // cloud-provider does not support the feature." // More info: http://kubernetes.io/docs/user-guide/services-firewalls + // +optional repeated string loadBalancerSourceRanges = 9; // externalName is the external reference that kubedns or equivalent will // return as a CNAME record for this service. No proxying will be involved. // Must be a valid DNS name and requires Type to be ExternalName. + // +optional optional string externalName = 10; } @@ -2935,6 +3339,7 @@ message ServiceSpec { message ServiceStatus { // LoadBalancer contains the current status of the load-balancer, // if one is present. + // +optional optional LoadBalancerStatus loadBalancer = 1; } @@ -2953,6 +3358,7 @@ message Taint { optional string key = 1; // Required. The taint value corresponding to the taint key. + // +optional optional string value = 2; // Required. The effect of the taint on pods @@ -2965,20 +3371,24 @@ message Taint { // the triple using the matching operator . message Toleration { // Required. Key is the taint key that the toleration applies to. + // +optional optional string key = 1; // operator represents a key's relationship to the value. // Valid operators are Exists and Equal. Defaults to Equal. // Exists is equivalent to wildcard for value, so that a pod can // tolerate all taints of a particular category. + // +optional optional string operator = 2; // Value is the taint value the toleration matches to. // If the operator is Exists, the value should be empty, otherwise just a regular string. + // +optional optional string value = 3; // Effect indicates the taint effect to match. Empty means match all taint effects. // When specified, allowed values are NoSchedule and PreferNoSchedule. + // +optional optional string effect = 4; } @@ -3002,6 +3412,7 @@ message VolumeMount { // Mounted read-only if true, read-write otherwise (false or unspecified). // Defaults to false. + // +optional optional bool readOnly = 2; // Path within the container at which the volume should be mounted. Must @@ -3010,6 +3421,7 @@ message VolumeMount { // Path within the volume from which the container's volume should be mounted. // Defaults to "" (volume's root). + // +optional optional string subPath = 4; } @@ -3024,85 +3436,107 @@ message VolumeSource { // --- // TODO(jonesdl) We need to restrict who can use host directory mounts and who can/can not // mount host directories as read/write. + // +optional optional HostPathVolumeSource hostPath = 1; // EmptyDir represents a temporary directory that shares a pod's lifetime. // More info: http://kubernetes.io/docs/user-guide/volumes#emptydir + // +optional optional EmptyDirVolumeSource emptyDir = 2; // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional optional GCEPersistentDiskVolumeSource gcePersistentDisk = 3; // AWSElasticBlockStore represents an AWS Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional optional AWSElasticBlockStoreVolumeSource awsElasticBlockStore = 4; // GitRepo represents a git repository at a particular revision. + // +optional optional GitRepoVolumeSource gitRepo = 5; // Secret represents a secret that should populate this volume. // More info: http://kubernetes.io/docs/user-guide/volumes#secrets + // +optional optional SecretVolumeSource secret = 6; // NFS represents an NFS mount on the host that shares a pod's lifetime // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional optional NFSVolumeSource nfs = 7; // ISCSI represents an ISCSI Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://releases.k8s.io/HEAD/examples/volumes/iscsi/README.md + // +optional optional ISCSIVolumeSource iscsi = 8; // Glusterfs represents a Glusterfs mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md + // +optional optional GlusterfsVolumeSource glusterfs = 9; // PersistentVolumeClaimVolumeSource represents a reference to a // PersistentVolumeClaim in the same namespace. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional optional PersistentVolumeClaimVolumeSource persistentVolumeClaim = 10; // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md + // +optional optional RBDVolumeSource rbd = 11; // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an // alpha feature and may change in future. + // +optional optional FlexVolumeSource flexVolume = 12; // Cinder represents a cinder volume attached and mounted on kubelets host machine // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional optional CinderVolumeSource cinder = 13; // CephFS represents a Ceph FS mount on the host that shares a pod's lifetime + // +optional optional CephFSVolumeSource cephfs = 14; // Flocker represents a Flocker volume attached to a kubelet's host machine. This depends on the Flocker control service being running + // +optional optional FlockerVolumeSource flocker = 15; // DownwardAPI represents downward API about the pod that should populate this volume + // +optional optional DownwardAPIVolumeSource downwardAPI = 16; // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional optional FCVolumeSource fc = 17; // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional optional AzureFileVolumeSource azureFile = 18; // ConfigMap represents a configMap that should populate this volume + // +optional optional ConfigMapVolumeSource configMap = 19; // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional optional VsphereVirtualDiskVolumeSource vsphereVolume = 20; // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional optional QuobyteVolumeSource quobyte = 21; // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional optional AzureDiskVolumeSource azureDisk = 22; } @@ -3114,6 +3548,7 @@ message VsphereVirtualDiskVolumeSource { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional optional string fsType = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/helpers.go b/vendor/k8s.io/client-go/pkg/api/v1/helpers.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/api/v1/helpers.go rename to vendor/k8s.io/client-go/pkg/api/v1/helpers.go index 5ea0d32..d33a79c 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/helpers.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/helpers.go @@ -16,7 +16,7 @@ limitations under the License. package v1 -import "k8s.io/kubernetes/pkg/types" +import "k8s.io/client-go/pkg/types" // NewDeleteOptions returns a DeleteOptions indicating the resource should // be deleted within the specified grace period. Use zero to indicate diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/meta.go b/vendor/k8s.io/client-go/pkg/api/v1/meta.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/api/v1/meta.go rename to vendor/k8s.io/client-go/pkg/api/v1/meta.go index 6f95cf7..a641eb2 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/meta.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/meta.go @@ -17,10 +17,10 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/meta/metatypes" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/types" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/meta/metatypes" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/types" ) func (obj *ObjectMeta) GetObjectMeta() meta.Object { return obj } diff --git a/vendor/k8s.io/client-go/pkg/api/v1/ref.go b/vendor/k8s.io/client-go/pkg/api/v1/ref.go new file mode 100644 index 0000000..69bed2f --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/api/v1/ref.go @@ -0,0 +1,133 @@ +/* +Copyright 2014 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. +*/ + +package v1 + +import ( + "errors" + "fmt" + "k8s.io/client-go/pkg/api" + "net/url" + "strings" + + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" +) + +var ( + // Errors that could be returned by GetReference. + ErrNilObject = errors.New("can't reference a nil object") + ErrNoSelfLink = errors.New("selfLink was empty, can't make reference") +) + +// GetReference returns an ObjectReference which refers to the given +// object, or an error if the object doesn't follow the conventions +// that would allow this. +// TODO: should take a meta.Interface see http://issue.k8s.io/7127 +func GetReference(obj runtime.Object) (*ObjectReference, error) { + if obj == nil { + return nil, ErrNilObject + } + if ref, ok := obj.(*ObjectReference); ok { + // Don't make a reference to a reference. + return ref, nil + } + + gvk := obj.GetObjectKind().GroupVersionKind() + + // if the object referenced is actually persisted, we can just get kind from meta + // if we are building an object reference to something not yet persisted, we should fallback to scheme + kind := gvk.Kind + if len(kind) == 0 { + // TODO: this is wrong + gvks, _, err := api.Scheme.ObjectKinds(obj) + if err != nil { + return nil, err + } + kind = gvks[0].Kind + } + + // An object that implements only List has enough metadata to build a reference + var listMeta meta.List + objectMeta, err := meta.Accessor(obj) + if err != nil { + listMeta, err = meta.ListAccessor(obj) + if err != nil { + return nil, err + } + } else { + listMeta = objectMeta + } + + // if the object referenced is actually persisted, we can also get version from meta + version := gvk.GroupVersion().String() + if len(version) == 0 { + selfLink := listMeta.GetSelfLink() + if len(selfLink) == 0 { + return nil, ErrNoSelfLink + } + selfLinkUrl, err := url.Parse(selfLink) + if err != nil { + return nil, err + } + // example paths: ///* + parts := strings.Split(selfLinkUrl.Path, "/") + if len(parts) < 3 { + return nil, fmt.Errorf("unexpected self link format: '%v'; got version '%v'", selfLink, version) + } + version = parts[2] + } + + // only has list metadata + if objectMeta == nil { + return &ObjectReference{ + Kind: kind, + APIVersion: version, + ResourceVersion: listMeta.GetResourceVersion(), + }, nil + } + + return &ObjectReference{ + Kind: kind, + APIVersion: version, + Name: objectMeta.GetName(), + Namespace: objectMeta.GetNamespace(), + UID: objectMeta.GetUID(), + ResourceVersion: objectMeta.GetResourceVersion(), + }, nil +} + +// GetPartialReference is exactly like GetReference, but allows you to set the FieldPath. +func GetPartialReference(obj runtime.Object, fieldPath string) (*ObjectReference, error) { + ref, err := GetReference(obj) + if err != nil { + return nil, err + } + ref.FieldPath = fieldPath + return ref, nil +} + +// IsAnAPIObject allows clients to preemptively get a reference to an API object and pass it to places that +// intend only to get a reference to that object. This simplifies the event recording interface. +func (obj *ObjectReference) SetGroupVersionKind(gvk unversioned.GroupVersionKind) { + obj.APIVersion, obj.Kind = gvk.ToAPIVersionAndKind() +} +func (obj *ObjectReference) GroupVersionKind() unversioned.GroupVersionKind { + return unversioned.FromAPIVersionAndKind(obj.APIVersion, obj.Kind) +} + +func (obj *ObjectReference) GetObjectKind() unversioned.ObjectKind { return obj } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/register.go b/vendor/k8s.io/client-go/pkg/api/v1/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/api/v1/register.go rename to vendor/k8s.io/client-go/pkg/api/v1/register.go index f02ea82..7f31222 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/register.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/register.go @@ -17,9 +17,9 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/types.generated.go b/vendor/k8s.io/client-go/pkg/api/v1/types.generated.go similarity index 80% rename from vendor/k8s.io/kubernetes/pkg/api/v1/types.generated.go rename to vendor/k8s.io/client-go/pkg/api/v1/types.generated.go index 56fc8e7..ba4de5b 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg3_resource "k8s.io/kubernetes/pkg/api/resource" - pkg2_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg5_runtime "k8s.io/kubernetes/pkg/runtime" - pkg1_types "k8s.io/kubernetes/pkg/types" - pkg4_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg3_resource "k8s.io/client-go/pkg/api/resource" + pkg2_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg5_runtime "k8s.io/client-go/pkg/runtime" + pkg1_types "k8s.io/client-go/pkg/types" + pkg4_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -31821,16 +31821,15 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } else { yysep2422 := !z.EncBinary() yy2arr2422 := z.EncBasicHandle().StructToArray - var yyq2422 [6]bool + var yyq2422 [5]bool _, _, _ = yysep2422, yyq2422, yy2arr2422 const yyr2422 bool = false yyq2422[2] = true - yyq2422[3] = true - yyq2422[4] = x.Reason != "" - yyq2422[5] = x.Message != "" + yyq2422[3] = x.Reason != "" + yyq2422[4] = x.Message != "" var yynn2422 int if yyr2422 || yy2arr2422 { - r.EncodeArrayStart(6) + r.EncodeArrayStart(5) } else { yynn2422 = 2 for _, b := range yyq2422 { @@ -31862,7 +31861,7 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { if yyr2422 || yy2arr2422 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq2422[2] { - yy2426 := &x.LastProbeTime + yy2426 := &x.LastTransitionTime yym2427 := z.EncBinary() _ = yym2427 if false { @@ -31880,9 +31879,9 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } else { if yyq2422[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) + r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2428 := &x.LastProbeTime + yy2428 := &x.LastTransitionTime yym2429 := z.EncBinary() _ = yym2429 if false { @@ -31899,45 +31898,8 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { if yyr2422 || yy2arr2422 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq2422[3] { - yy2431 := &x.LastTransitionTime - yym2432 := z.EncBinary() - _ = yym2432 - if false { - } else if z.HasExtensions() && z.EncExt(yy2431) { - } else if yym2432 { - z.EncBinaryMarshal(yy2431) - } else if !yym2432 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2431) - } else { - z.EncFallback(yy2431) - } - } else { - r.EncodeNil() - } - } else { - if yyq2422[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2433 := &x.LastTransitionTime - yym2434 := z.EncBinary() - _ = yym2434 - if false { - } else if z.HasExtensions() && z.EncExt(yy2433) { - } else if yym2434 { - z.EncBinaryMarshal(yy2433) - } else if !yym2434 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2433) - } else { - z.EncFallback(yy2433) - } - } - } - if yyr2422 || yy2arr2422 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2422[4] { - yym2436 := z.EncBinary() - _ = yym2436 + yym2431 := z.EncBinary() + _ = yym2431 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -31946,12 +31908,12 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2422[4] { + if yyq2422[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2437 := z.EncBinary() - _ = yym2437 + yym2432 := z.EncBinary() + _ = yym2432 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -31960,9 +31922,9 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { } if yyr2422 || yy2arr2422 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2422[5] { - yym2439 := z.EncBinary() - _ = yym2439 + if yyq2422[4] { + yym2434 := z.EncBinary() + _ = yym2434 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -31971,12 +31933,12 @@ func (x *ReplicationControllerCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2422[5] { + if yyq2422[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2440 := z.EncBinary() - _ = yym2440 + yym2435 := z.EncBinary() + _ = yym2435 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -31996,25 +31958,25 @@ func (x *ReplicationControllerCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2441 := z.DecBinary() - _ = yym2441 + yym2436 := z.DecBinary() + _ = yym2436 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2442 := r.ContainerType() - if yyct2442 == codecSelferValueTypeMap1234 { - yyl2442 := r.ReadMapStart() - if yyl2442 == 0 { + yyct2437 := r.ContainerType() + if yyct2437 == codecSelferValueTypeMap1234 { + yyl2437 := r.ReadMapStart() + if yyl2437 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2442, d) + x.codecDecodeSelfFromMap(yyl2437, d) } - } else if yyct2442 == codecSelferValueTypeArray1234 { - yyl2442 := r.ReadArrayStart() - if yyl2442 == 0 { + } else if yyct2437 == codecSelferValueTypeArray1234 { + yyl2437 := r.ReadArrayStart() + if yyl2437 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2442, d) + x.codecDecodeSelfFromArray(yyl2437, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -32026,12 +31988,12 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2443Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2443Slc - var yyhl2443 bool = l >= 0 - for yyj2443 := 0; ; yyj2443++ { - if yyhl2443 { - if yyj2443 >= l { + var yys2438Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2438Slc + var yyhl2438 bool = l >= 0 + for yyj2438 := 0; ; yyj2438++ { + if yyhl2438 { + if yyj2438 >= l { break } } else { @@ -32040,10 +32002,10 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2443Slc = r.DecodeBytes(yys2443Slc, true, true) - yys2443 := string(yys2443Slc) + yys2438Slc = r.DecodeBytes(yys2438Slc, true, true) + yys2438 := string(yys2438Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2443 { + switch yys2438 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -32056,38 +32018,21 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 } else { x.Status = ConditionStatus(r.DecodeString()) } - case "lastProbeTime": - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg2_unversioned.Time{} - } else { - yyv2446 := &x.LastProbeTime - yym2447 := z.DecBinary() - _ = yym2447 - if false { - } else if z.HasExtensions() && z.DecExt(yyv2446) { - } else if yym2447 { - z.DecBinaryUnmarshal(yyv2446) - } else if !yym2447 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2446) - } else { - z.DecFallback(yyv2446, false) - } - } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv2448 := &x.LastTransitionTime - yym2449 := z.DecBinary() - _ = yym2449 + yyv2441 := &x.LastTransitionTime + yym2442 := z.DecBinary() + _ = yym2442 if false { - } else if z.HasExtensions() && z.DecExt(yyv2448) { - } else if yym2449 { - z.DecBinaryUnmarshal(yyv2448) - } else if !yym2449 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2448) + } else if z.HasExtensions() && z.DecExt(yyv2441) { + } else if yym2442 { + z.DecBinaryUnmarshal(yyv2441) + } else if !yym2442 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2441) } else { - z.DecFallback(yyv2448, false) + z.DecFallback(yyv2441, false) } } case "reason": @@ -32103,9 +32048,9 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromMap(l int, d *codec1 x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2443) - } // end switch yys2443 - } // end for yyj2443 + z.DecStructFieldNotFound(-1, yys2438) + } // end switch yys2438 + } // end for yyj2438 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -32113,16 +32058,16 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2452 int - var yyb2452 bool - var yyhl2452 bool = l >= 0 - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + var yyj2445 int + var yyb2445 bool + var yyhl2445 bool = l >= 0 + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { + if yyb2445 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32132,13 +32077,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Type = ReplicationControllerConditionType(r.DecodeString()) } - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { + if yyb2445 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32148,40 +32093,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg2_unversioned.Time{} - } else { - yyv2455 := &x.LastProbeTime - yym2456 := z.DecBinary() - _ = yym2456 - if false { - } else if z.HasExtensions() && z.DecExt(yyv2455) { - } else if yym2456 { - z.DecBinaryUnmarshal(yyv2455) - } else if !yym2456 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2455) - } else { - z.DecFallback(yyv2455, false) - } - } - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l - } else { - yyb2452 = r.CheckBreak() - } - if yyb2452 { + if yyb2445 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32189,26 +32107,26 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv2457 := &x.LastTransitionTime - yym2458 := z.DecBinary() - _ = yym2458 + yyv2448 := &x.LastTransitionTime + yym2449 := z.DecBinary() + _ = yym2449 if false { - } else if z.HasExtensions() && z.DecExt(yyv2457) { - } else if yym2458 { - z.DecBinaryUnmarshal(yyv2457) - } else if !yym2458 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2457) + } else if z.HasExtensions() && z.DecExt(yyv2448) { + } else if yym2449 { + z.DecBinaryUnmarshal(yyv2448) + } else if !yym2449 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2448) } else { - z.DecFallback(yyv2457, false) + z.DecFallback(yyv2448, false) } } - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { + if yyb2445 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32218,13 +32136,13 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code } else { x.Reason = string(r.DecodeString()) } - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { + if yyb2445 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32235,17 +32153,17 @@ func (x *ReplicationControllerCondition) codecDecodeSelfFromArray(l int, d *code x.Message = string(r.DecodeString()) } for { - yyj2452++ - if yyhl2452 { - yyb2452 = yyj2452 > l + yyj2445++ + if yyhl2445 { + yyb2445 = yyj2445 > l } else { - yyb2452 = r.CheckBreak() + yyb2445 = r.CheckBreak() } - if yyb2452 { + if yyb2445 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2452-1, "") + z.DecStructFieldNotFound(yyj2445-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -32257,39 +32175,39 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2461 := z.EncBinary() - _ = yym2461 + yym2452 := z.EncBinary() + _ = yym2452 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2462 := !z.EncBinary() - yy2arr2462 := z.EncBasicHandle().StructToArray - var yyq2462 [5]bool - _, _, _ = yysep2462, yyq2462, yy2arr2462 - const yyr2462 bool = false - yyq2462[0] = x.Kind != "" - yyq2462[1] = x.APIVersion != "" - yyq2462[2] = true - yyq2462[3] = true - yyq2462[4] = true - var yynn2462 int - if yyr2462 || yy2arr2462 { + yysep2453 := !z.EncBinary() + yy2arr2453 := z.EncBasicHandle().StructToArray + var yyq2453 [5]bool + _, _, _ = yysep2453, yyq2453, yy2arr2453 + const yyr2453 bool = false + yyq2453[0] = x.Kind != "" + yyq2453[1] = x.APIVersion != "" + yyq2453[2] = true + yyq2453[3] = true + yyq2453[4] = true + var yynn2453 int + if yyr2453 || yy2arr2453 { r.EncodeArrayStart(5) } else { - yynn2462 = 0 - for _, b := range yyq2462 { + yynn2453 = 0 + for _, b := range yyq2453 { if b { - yynn2462++ + yynn2453++ } } - r.EncodeMapStart(yynn2462) - yynn2462 = 0 + r.EncodeMapStart(yynn2453) + yynn2453 = 0 } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2462[0] { - yym2464 := z.EncBinary() - _ = yym2464 + if yyq2453[0] { + yym2455 := z.EncBinary() + _ = yym2455 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -32298,23 +32216,23 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2462[0] { + if yyq2453[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2465 := z.EncBinary() - _ = yym2465 + yym2456 := z.EncBinary() + _ = yym2456 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2462[1] { - yym2467 := z.EncBinary() - _ = yym2467 + if yyq2453[1] { + yym2458 := z.EncBinary() + _ = yym2458 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -32323,70 +32241,70 @@ func (x *ReplicationController) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2462[1] { + if yyq2453[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2468 := z.EncBinary() - _ = yym2468 + yym2459 := z.EncBinary() + _ = yym2459 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2462[2] { - yy2470 := &x.ObjectMeta - yy2470.CodecEncodeSelf(e) + if yyq2453[2] { + yy2461 := &x.ObjectMeta + yy2461.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2462[2] { + if yyq2453[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2471 := &x.ObjectMeta - yy2471.CodecEncodeSelf(e) + yy2462 := &x.ObjectMeta + yy2462.CodecEncodeSelf(e) } } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2462[3] { - yy2473 := &x.Spec - yy2473.CodecEncodeSelf(e) + if yyq2453[3] { + yy2464 := &x.Spec + yy2464.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2462[3] { + if yyq2453[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2474 := &x.Spec - yy2474.CodecEncodeSelf(e) + yy2465 := &x.Spec + yy2465.CodecEncodeSelf(e) } } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2462[4] { - yy2476 := &x.Status - yy2476.CodecEncodeSelf(e) + if yyq2453[4] { + yy2467 := &x.Status + yy2467.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2462[4] { + if yyq2453[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2477 := &x.Status - yy2477.CodecEncodeSelf(e) + yy2468 := &x.Status + yy2468.CodecEncodeSelf(e) } } - if yyr2462 || yy2arr2462 { + if yyr2453 || yy2arr2453 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -32399,25 +32317,25 @@ func (x *ReplicationController) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2478 := z.DecBinary() - _ = yym2478 + yym2469 := z.DecBinary() + _ = yym2469 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2479 := r.ContainerType() - if yyct2479 == codecSelferValueTypeMap1234 { - yyl2479 := r.ReadMapStart() - if yyl2479 == 0 { + yyct2470 := r.ContainerType() + if yyct2470 == codecSelferValueTypeMap1234 { + yyl2470 := r.ReadMapStart() + if yyl2470 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2479, d) + x.codecDecodeSelfFromMap(yyl2470, d) } - } else if yyct2479 == codecSelferValueTypeArray1234 { - yyl2479 := r.ReadArrayStart() - if yyl2479 == 0 { + } else if yyct2470 == codecSelferValueTypeArray1234 { + yyl2470 := r.ReadArrayStart() + if yyl2470 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2479, d) + x.codecDecodeSelfFromArray(yyl2470, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -32429,12 +32347,12 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2480Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2480Slc - var yyhl2480 bool = l >= 0 - for yyj2480 := 0; ; yyj2480++ { - if yyhl2480 { - if yyj2480 >= l { + var yys2471Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2471Slc + var yyhl2471 bool = l >= 0 + for yyj2471 := 0; ; yyj2471++ { + if yyhl2471 { + if yyj2471 >= l { break } } else { @@ -32443,10 +32361,10 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2480Slc = r.DecodeBytes(yys2480Slc, true, true) - yys2480 := string(yys2480Slc) + yys2471Slc = r.DecodeBytes(yys2471Slc, true, true) + yys2471 := string(yys2471Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2480 { + switch yys2471 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -32463,27 +32381,27 @@ func (x *ReplicationController) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2483 := &x.ObjectMeta - yyv2483.CodecDecodeSelf(d) + yyv2474 := &x.ObjectMeta + yyv2474.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ReplicationControllerSpec{} } else { - yyv2484 := &x.Spec - yyv2484.CodecDecodeSelf(d) + yyv2475 := &x.Spec + yyv2475.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ReplicationControllerStatus{} } else { - yyv2485 := &x.Status - yyv2485.CodecDecodeSelf(d) + yyv2476 := &x.Status + yyv2476.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2480) - } // end switch yys2480 - } // end for yyj2480 + z.DecStructFieldNotFound(-1, yys2471) + } // end switch yys2471 + } // end for yyj2471 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -32491,16 +32409,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2486 int - var yyb2486 bool - var yyhl2486 bool = l >= 0 - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + var yyj2477 int + var yyb2477 bool + var yyhl2477 bool = l >= 0 + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32510,13 +32428,13 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Kind = string(r.DecodeString()) } - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32526,13 +32444,13 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.APIVersion = string(r.DecodeString()) } - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32540,16 +32458,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2489 := &x.ObjectMeta - yyv2489.CodecDecodeSelf(d) + yyv2480 := &x.ObjectMeta + yyv2480.CodecDecodeSelf(d) } - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32557,16 +32475,16 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Spec = ReplicationControllerSpec{} } else { - yyv2490 := &x.Spec - yyv2490.CodecDecodeSelf(d) + yyv2481 := &x.Spec + yyv2481.CodecDecodeSelf(d) } - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32574,21 +32492,21 @@ func (x *ReplicationController) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Status = ReplicationControllerStatus{} } else { - yyv2491 := &x.Status - yyv2491.CodecDecodeSelf(d) + yyv2482 := &x.Status + yyv2482.CodecDecodeSelf(d) } for { - yyj2486++ - if yyhl2486 { - yyb2486 = yyj2486 > l + yyj2477++ + if yyhl2477 { + yyb2477 = yyj2477 > l } else { - yyb2486 = r.CheckBreak() + yyb2477 = r.CheckBreak() } - if yyb2486 { + if yyb2477 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2486-1, "") + z.DecStructFieldNotFound(yyj2477-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -32600,37 +32518,37 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2492 := z.EncBinary() - _ = yym2492 + yym2483 := z.EncBinary() + _ = yym2483 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2493 := !z.EncBinary() - yy2arr2493 := z.EncBasicHandle().StructToArray - var yyq2493 [4]bool - _, _, _ = yysep2493, yyq2493, yy2arr2493 - const yyr2493 bool = false - yyq2493[0] = x.Kind != "" - yyq2493[1] = x.APIVersion != "" - yyq2493[2] = true - var yynn2493 int - if yyr2493 || yy2arr2493 { + yysep2484 := !z.EncBinary() + yy2arr2484 := z.EncBasicHandle().StructToArray + var yyq2484 [4]bool + _, _, _ = yysep2484, yyq2484, yy2arr2484 + const yyr2484 bool = false + yyq2484[0] = x.Kind != "" + yyq2484[1] = x.APIVersion != "" + yyq2484[2] = true + var yynn2484 int + if yyr2484 || yy2arr2484 { r.EncodeArrayStart(4) } else { - yynn2493 = 1 - for _, b := range yyq2493 { + yynn2484 = 1 + for _, b := range yyq2484 { if b { - yynn2493++ + yynn2484++ } } - r.EncodeMapStart(yynn2493) - yynn2493 = 0 + r.EncodeMapStart(yynn2484) + yynn2484 = 0 } - if yyr2493 || yy2arr2493 { + if yyr2484 || yy2arr2484 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2493[0] { - yym2495 := z.EncBinary() - _ = yym2495 + if yyq2484[0] { + yym2486 := z.EncBinary() + _ = yym2486 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -32639,23 +32557,23 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2493[0] { + if yyq2484[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2496 := z.EncBinary() - _ = yym2496 + yym2487 := z.EncBinary() + _ = yym2487 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2493 || yy2arr2493 { + if yyr2484 || yy2arr2484 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2493[1] { - yym2498 := z.EncBinary() - _ = yym2498 + if yyq2484[1] { + yym2489 := z.EncBinary() + _ = yym2489 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -32664,54 +32582,54 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2493[1] { + if yyq2484[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2499 := z.EncBinary() - _ = yym2499 + yym2490 := z.EncBinary() + _ = yym2490 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2493 || yy2arr2493 { + if yyr2484 || yy2arr2484 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2493[2] { - yy2501 := &x.ListMeta - yym2502 := z.EncBinary() - _ = yym2502 + if yyq2484[2] { + yy2492 := &x.ListMeta + yym2493 := z.EncBinary() + _ = yym2493 if false { - } else if z.HasExtensions() && z.EncExt(yy2501) { + } else if z.HasExtensions() && z.EncExt(yy2492) { } else { - z.EncFallback(yy2501) + z.EncFallback(yy2492) } } else { r.EncodeNil() } } else { - if yyq2493[2] { + if yyq2484[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2503 := &x.ListMeta - yym2504 := z.EncBinary() - _ = yym2504 + yy2494 := &x.ListMeta + yym2495 := z.EncBinary() + _ = yym2495 if false { - } else if z.HasExtensions() && z.EncExt(yy2503) { + } else if z.HasExtensions() && z.EncExt(yy2494) { } else { - z.EncFallback(yy2503) + z.EncFallback(yy2494) } } } - if yyr2493 || yy2arr2493 { + if yyr2484 || yy2arr2484 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2506 := z.EncBinary() - _ = yym2506 + yym2497 := z.EncBinary() + _ = yym2497 if false { } else { h.encSliceReplicationController(([]ReplicationController)(x.Items), e) @@ -32724,15 +32642,15 @@ func (x *ReplicationControllerList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2507 := z.EncBinary() - _ = yym2507 + yym2498 := z.EncBinary() + _ = yym2498 if false { } else { h.encSliceReplicationController(([]ReplicationController)(x.Items), e) } } } - if yyr2493 || yy2arr2493 { + if yyr2484 || yy2arr2484 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -32745,25 +32663,25 @@ func (x *ReplicationControllerList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2508 := z.DecBinary() - _ = yym2508 + yym2499 := z.DecBinary() + _ = yym2499 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2509 := r.ContainerType() - if yyct2509 == codecSelferValueTypeMap1234 { - yyl2509 := r.ReadMapStart() - if yyl2509 == 0 { + yyct2500 := r.ContainerType() + if yyct2500 == codecSelferValueTypeMap1234 { + yyl2500 := r.ReadMapStart() + if yyl2500 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2509, d) + x.codecDecodeSelfFromMap(yyl2500, d) } - } else if yyct2509 == codecSelferValueTypeArray1234 { - yyl2509 := r.ReadArrayStart() - if yyl2509 == 0 { + } else if yyct2500 == codecSelferValueTypeArray1234 { + yyl2500 := r.ReadArrayStart() + if yyl2500 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2509, d) + x.codecDecodeSelfFromArray(yyl2500, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -32775,12 +32693,12 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2510Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2510Slc - var yyhl2510 bool = l >= 0 - for yyj2510 := 0; ; yyj2510++ { - if yyhl2510 { - if yyj2510 >= l { + var yys2501Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2501Slc + var yyhl2501 bool = l >= 0 + for yyj2501 := 0; ; yyj2501++ { + if yyhl2501 { + if yyj2501 >= l { break } } else { @@ -32789,10 +32707,10 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2510Slc = r.DecodeBytes(yys2510Slc, true, true) - yys2510 := string(yys2510Slc) + yys2501Slc = r.DecodeBytes(yys2501Slc, true, true) + yys2501 := string(yys2501Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2510 { + switch yys2501 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -32809,31 +32727,31 @@ func (x *ReplicationControllerList) codecDecodeSelfFromMap(l int, d *codec1978.D if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2513 := &x.ListMeta - yym2514 := z.DecBinary() - _ = yym2514 + yyv2504 := &x.ListMeta + yym2505 := z.DecBinary() + _ = yym2505 if false { - } else if z.HasExtensions() && z.DecExt(yyv2513) { + } else if z.HasExtensions() && z.DecExt(yyv2504) { } else { - z.DecFallback(yyv2513, false) + z.DecFallback(yyv2504, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2515 := &x.Items - yym2516 := z.DecBinary() - _ = yym2516 + yyv2506 := &x.Items + yym2507 := z.DecBinary() + _ = yym2507 if false { } else { - h.decSliceReplicationController((*[]ReplicationController)(yyv2515), d) + h.decSliceReplicationController((*[]ReplicationController)(yyv2506), d) } } default: - z.DecStructFieldNotFound(-1, yys2510) - } // end switch yys2510 - } // end for yyj2510 + z.DecStructFieldNotFound(-1, yys2501) + } // end switch yys2501 + } // end for yyj2501 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -32841,16 +32759,16 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2517 int - var yyb2517 bool - var yyhl2517 bool = l >= 0 - yyj2517++ - if yyhl2517 { - yyb2517 = yyj2517 > l + var yyj2508 int + var yyb2508 bool + var yyhl2508 bool = l >= 0 + yyj2508++ + if yyhl2508 { + yyb2508 = yyj2508 > l } else { - yyb2517 = r.CheckBreak() + yyb2508 = r.CheckBreak() } - if yyb2517 { + if yyb2508 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32860,13 +32778,13 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 } else { x.Kind = string(r.DecodeString()) } - yyj2517++ - if yyhl2517 { - yyb2517 = yyj2517 > l + yyj2508++ + if yyhl2508 { + yyb2508 = yyj2508 > l } else { - yyb2517 = r.CheckBreak() + yyb2508 = r.CheckBreak() } - if yyb2517 { + if yyb2508 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32876,13 +32794,13 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 } else { x.APIVersion = string(r.DecodeString()) } - yyj2517++ - if yyhl2517 { - yyb2517 = yyj2517 > l + yyj2508++ + if yyhl2508 { + yyb2508 = yyj2508 > l } else { - yyb2517 = r.CheckBreak() + yyb2508 = r.CheckBreak() } - if yyb2517 { + if yyb2508 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32890,22 +32808,22 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2520 := &x.ListMeta - yym2521 := z.DecBinary() - _ = yym2521 + yyv2511 := &x.ListMeta + yym2512 := z.DecBinary() + _ = yym2512 if false { - } else if z.HasExtensions() && z.DecExt(yyv2520) { + } else if z.HasExtensions() && z.DecExt(yyv2511) { } else { - z.DecFallback(yyv2520, false) + z.DecFallback(yyv2511, false) } } - yyj2517++ - if yyhl2517 { - yyb2517 = yyj2517 > l + yyj2508++ + if yyhl2508 { + yyb2508 = yyj2508 > l } else { - yyb2517 = r.CheckBreak() + yyb2508 = r.CheckBreak() } - if yyb2517 { + if yyb2508 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -32913,26 +32831,26 @@ func (x *ReplicationControllerList) codecDecodeSelfFromArray(l int, d *codec1978 if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2522 := &x.Items - yym2523 := z.DecBinary() - _ = yym2523 + yyv2513 := &x.Items + yym2514 := z.DecBinary() + _ = yym2514 if false { } else { - h.decSliceReplicationController((*[]ReplicationController)(yyv2522), d) + h.decSliceReplicationController((*[]ReplicationController)(yyv2513), d) } } for { - yyj2517++ - if yyhl2517 { - yyb2517 = yyj2517 > l + yyj2508++ + if yyhl2508 { + yyb2508 = yyj2508 > l } else { - yyb2517 = r.CheckBreak() + yyb2508 = r.CheckBreak() } - if yyb2517 { + if yyb2508 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2517-1, "") + z.DecStructFieldNotFound(yyj2508-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -32941,8 +32859,8 @@ func (x ServiceAffinity) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym2524 := z.EncBinary() - _ = yym2524 + yym2515 := z.EncBinary() + _ = yym2515 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -32954,8 +32872,8 @@ func (x *ServiceAffinity) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2525 := z.DecBinary() - _ = yym2525 + yym2516 := z.DecBinary() + _ = yym2516 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -32967,8 +32885,8 @@ func (x ServiceType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym2526 := z.EncBinary() - _ = yym2526 + yym2517 := z.EncBinary() + _ = yym2517 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -32980,8 +32898,8 @@ func (x *ServiceType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2527 := z.DecBinary() - _ = yym2527 + yym2518 := z.DecBinary() + _ = yym2518 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -32996,48 +32914,48 @@ func (x *ServiceStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2528 := z.EncBinary() - _ = yym2528 + yym2519 := z.EncBinary() + _ = yym2519 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2529 := !z.EncBinary() - yy2arr2529 := z.EncBasicHandle().StructToArray - var yyq2529 [1]bool - _, _, _ = yysep2529, yyq2529, yy2arr2529 - const yyr2529 bool = false - yyq2529[0] = true - var yynn2529 int - if yyr2529 || yy2arr2529 { + yysep2520 := !z.EncBinary() + yy2arr2520 := z.EncBasicHandle().StructToArray + var yyq2520 [1]bool + _, _, _ = yysep2520, yyq2520, yy2arr2520 + const yyr2520 bool = false + yyq2520[0] = true + var yynn2520 int + if yyr2520 || yy2arr2520 { r.EncodeArrayStart(1) } else { - yynn2529 = 0 - for _, b := range yyq2529 { + yynn2520 = 0 + for _, b := range yyq2520 { if b { - yynn2529++ + yynn2520++ } } - r.EncodeMapStart(yynn2529) - yynn2529 = 0 + r.EncodeMapStart(yynn2520) + yynn2520 = 0 } - if yyr2529 || yy2arr2529 { + if yyr2520 || yy2arr2520 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2529[0] { - yy2531 := &x.LoadBalancer - yy2531.CodecEncodeSelf(e) + if yyq2520[0] { + yy2522 := &x.LoadBalancer + yy2522.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2529[0] { + if yyq2520[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancer")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2532 := &x.LoadBalancer - yy2532.CodecEncodeSelf(e) + yy2523 := &x.LoadBalancer + yy2523.CodecEncodeSelf(e) } } - if yyr2529 || yy2arr2529 { + if yyr2520 || yy2arr2520 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33050,25 +32968,25 @@ func (x *ServiceStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2533 := z.DecBinary() - _ = yym2533 + yym2524 := z.DecBinary() + _ = yym2524 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2534 := r.ContainerType() - if yyct2534 == codecSelferValueTypeMap1234 { - yyl2534 := r.ReadMapStart() - if yyl2534 == 0 { + yyct2525 := r.ContainerType() + if yyct2525 == codecSelferValueTypeMap1234 { + yyl2525 := r.ReadMapStart() + if yyl2525 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2534, d) + x.codecDecodeSelfFromMap(yyl2525, d) } - } else if yyct2534 == codecSelferValueTypeArray1234 { - yyl2534 := r.ReadArrayStart() - if yyl2534 == 0 { + } else if yyct2525 == codecSelferValueTypeArray1234 { + yyl2525 := r.ReadArrayStart() + if yyl2525 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2534, d) + x.codecDecodeSelfFromArray(yyl2525, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33080,12 +32998,12 @@ func (x *ServiceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2535Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2535Slc - var yyhl2535 bool = l >= 0 - for yyj2535 := 0; ; yyj2535++ { - if yyhl2535 { - if yyj2535 >= l { + var yys2526Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2526Slc + var yyhl2526 bool = l >= 0 + for yyj2526 := 0; ; yyj2526++ { + if yyhl2526 { + if yyj2526 >= l { break } } else { @@ -33094,21 +33012,21 @@ func (x *ServiceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2535Slc = r.DecodeBytes(yys2535Slc, true, true) - yys2535 := string(yys2535Slc) + yys2526Slc = r.DecodeBytes(yys2526Slc, true, true) + yys2526 := string(yys2526Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2535 { + switch yys2526 { case "loadBalancer": if r.TryDecodeAsNil() { x.LoadBalancer = LoadBalancerStatus{} } else { - yyv2536 := &x.LoadBalancer - yyv2536.CodecDecodeSelf(d) + yyv2527 := &x.LoadBalancer + yyv2527.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2535) - } // end switch yys2535 - } // end for yyj2535 + z.DecStructFieldNotFound(-1, yys2526) + } // end switch yys2526 + } // end for yyj2526 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33116,16 +33034,16 @@ func (x *ServiceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2537 int - var yyb2537 bool - var yyhl2537 bool = l >= 0 - yyj2537++ - if yyhl2537 { - yyb2537 = yyj2537 > l + var yyj2528 int + var yyb2528 bool + var yyhl2528 bool = l >= 0 + yyj2528++ + if yyhl2528 { + yyb2528 = yyj2528 > l } else { - yyb2537 = r.CheckBreak() + yyb2528 = r.CheckBreak() } - if yyb2537 { + if yyb2528 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33133,21 +33051,21 @@ func (x *ServiceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancer = LoadBalancerStatus{} } else { - yyv2538 := &x.LoadBalancer - yyv2538.CodecDecodeSelf(d) + yyv2529 := &x.LoadBalancer + yyv2529.CodecDecodeSelf(d) } for { - yyj2537++ - if yyhl2537 { - yyb2537 = yyj2537 > l + yyj2528++ + if yyhl2528 { + yyb2528 = yyj2528 > l } else { - yyb2537 = r.CheckBreak() + yyb2528 = r.CheckBreak() } - if yyb2537 { + if yyb2528 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2537-1, "") + z.DecStructFieldNotFound(yyj2528-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33159,38 +33077,38 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2539 := z.EncBinary() - _ = yym2539 + yym2530 := z.EncBinary() + _ = yym2530 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2540 := !z.EncBinary() - yy2arr2540 := z.EncBasicHandle().StructToArray - var yyq2540 [1]bool - _, _, _ = yysep2540, yyq2540, yy2arr2540 - const yyr2540 bool = false - yyq2540[0] = len(x.Ingress) != 0 - var yynn2540 int - if yyr2540 || yy2arr2540 { + yysep2531 := !z.EncBinary() + yy2arr2531 := z.EncBasicHandle().StructToArray + var yyq2531 [1]bool + _, _, _ = yysep2531, yyq2531, yy2arr2531 + const yyr2531 bool = false + yyq2531[0] = len(x.Ingress) != 0 + var yynn2531 int + if yyr2531 || yy2arr2531 { r.EncodeArrayStart(1) } else { - yynn2540 = 0 - for _, b := range yyq2540 { + yynn2531 = 0 + for _, b := range yyq2531 { if b { - yynn2540++ + yynn2531++ } } - r.EncodeMapStart(yynn2540) - yynn2540 = 0 + r.EncodeMapStart(yynn2531) + yynn2531 = 0 } - if yyr2540 || yy2arr2540 { + if yyr2531 || yy2arr2531 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2540[0] { + if yyq2531[0] { if x.Ingress == nil { r.EncodeNil() } else { - yym2542 := z.EncBinary() - _ = yym2542 + yym2533 := z.EncBinary() + _ = yym2533 if false { } else { h.encSliceLoadBalancerIngress(([]LoadBalancerIngress)(x.Ingress), e) @@ -33200,15 +33118,15 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2540[0] { + if yyq2531[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ingress")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ingress == nil { r.EncodeNil() } else { - yym2543 := z.EncBinary() - _ = yym2543 + yym2534 := z.EncBinary() + _ = yym2534 if false { } else { h.encSliceLoadBalancerIngress(([]LoadBalancerIngress)(x.Ingress), e) @@ -33216,7 +33134,7 @@ func (x *LoadBalancerStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2540 || yy2arr2540 { + if yyr2531 || yy2arr2531 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33229,25 +33147,25 @@ func (x *LoadBalancerStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2544 := z.DecBinary() - _ = yym2544 + yym2535 := z.DecBinary() + _ = yym2535 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2545 := r.ContainerType() - if yyct2545 == codecSelferValueTypeMap1234 { - yyl2545 := r.ReadMapStart() - if yyl2545 == 0 { + yyct2536 := r.ContainerType() + if yyct2536 == codecSelferValueTypeMap1234 { + yyl2536 := r.ReadMapStart() + if yyl2536 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2545, d) + x.codecDecodeSelfFromMap(yyl2536, d) } - } else if yyct2545 == codecSelferValueTypeArray1234 { - yyl2545 := r.ReadArrayStart() - if yyl2545 == 0 { + } else if yyct2536 == codecSelferValueTypeArray1234 { + yyl2536 := r.ReadArrayStart() + if yyl2536 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2545, d) + x.codecDecodeSelfFromArray(yyl2536, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33259,12 +33177,12 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2546Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2546Slc - var yyhl2546 bool = l >= 0 - for yyj2546 := 0; ; yyj2546++ { - if yyhl2546 { - if yyj2546 >= l { + var yys2537Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2537Slc + var yyhl2537 bool = l >= 0 + for yyj2537 := 0; ; yyj2537++ { + if yyhl2537 { + if yyj2537 >= l { break } } else { @@ -33273,26 +33191,26 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2546Slc = r.DecodeBytes(yys2546Slc, true, true) - yys2546 := string(yys2546Slc) + yys2537Slc = r.DecodeBytes(yys2537Slc, true, true) + yys2537 := string(yys2537Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2546 { + switch yys2537 { case "ingress": if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv2547 := &x.Ingress - yym2548 := z.DecBinary() - _ = yym2548 + yyv2538 := &x.Ingress + yym2539 := z.DecBinary() + _ = yym2539 if false { } else { - h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2547), d) + h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2538), d) } } default: - z.DecStructFieldNotFound(-1, yys2546) - } // end switch yys2546 - } // end for yyj2546 + z.DecStructFieldNotFound(-1, yys2537) + } // end switch yys2537 + } // end for yyj2537 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33300,16 +33218,16 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2549 int - var yyb2549 bool - var yyhl2549 bool = l >= 0 - yyj2549++ - if yyhl2549 { - yyb2549 = yyj2549 > l + var yyj2540 int + var yyb2540 bool + var yyhl2540 bool = l >= 0 + yyj2540++ + if yyhl2540 { + yyb2540 = yyj2540 > l } else { - yyb2549 = r.CheckBreak() + yyb2540 = r.CheckBreak() } - if yyb2549 { + if yyb2540 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33317,26 +33235,26 @@ func (x *LoadBalancerStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv2550 := &x.Ingress - yym2551 := z.DecBinary() - _ = yym2551 + yyv2541 := &x.Ingress + yym2542 := z.DecBinary() + _ = yym2542 if false { } else { - h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2550), d) + h.decSliceLoadBalancerIngress((*[]LoadBalancerIngress)(yyv2541), d) } } for { - yyj2549++ - if yyhl2549 { - yyb2549 = yyj2549 > l + yyj2540++ + if yyhl2540 { + yyb2540 = yyj2540 > l } else { - yyb2549 = r.CheckBreak() + yyb2540 = r.CheckBreak() } - if yyb2549 { + if yyb2540 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2549-1, "") + z.DecStructFieldNotFound(yyj2540-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33348,36 +33266,36 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2552 := z.EncBinary() - _ = yym2552 + yym2543 := z.EncBinary() + _ = yym2543 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2553 := !z.EncBinary() - yy2arr2553 := z.EncBasicHandle().StructToArray - var yyq2553 [2]bool - _, _, _ = yysep2553, yyq2553, yy2arr2553 - const yyr2553 bool = false - yyq2553[0] = x.IP != "" - yyq2553[1] = x.Hostname != "" - var yynn2553 int - if yyr2553 || yy2arr2553 { + yysep2544 := !z.EncBinary() + yy2arr2544 := z.EncBasicHandle().StructToArray + var yyq2544 [2]bool + _, _, _ = yysep2544, yyq2544, yy2arr2544 + const yyr2544 bool = false + yyq2544[0] = x.IP != "" + yyq2544[1] = x.Hostname != "" + var yynn2544 int + if yyr2544 || yy2arr2544 { r.EncodeArrayStart(2) } else { - yynn2553 = 0 - for _, b := range yyq2553 { + yynn2544 = 0 + for _, b := range yyq2544 { if b { - yynn2553++ + yynn2544++ } } - r.EncodeMapStart(yynn2553) - yynn2553 = 0 + r.EncodeMapStart(yynn2544) + yynn2544 = 0 } - if yyr2553 || yy2arr2553 { + if yyr2544 || yy2arr2544 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2553[0] { - yym2555 := z.EncBinary() - _ = yym2555 + if yyq2544[0] { + yym2546 := z.EncBinary() + _ = yym2546 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) @@ -33386,23 +33304,23 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2553[0] { + if yyq2544[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ip")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2556 := z.EncBinary() - _ = yym2556 + yym2547 := z.EncBinary() + _ = yym2547 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) } } } - if yyr2553 || yy2arr2553 { + if yyr2544 || yy2arr2544 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2553[1] { - yym2558 := z.EncBinary() - _ = yym2558 + if yyq2544[1] { + yym2549 := z.EncBinary() + _ = yym2549 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) @@ -33411,19 +33329,19 @@ func (x *LoadBalancerIngress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2553[1] { + if yyq2544[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostname")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2559 := z.EncBinary() - _ = yym2559 + yym2550 := z.EncBinary() + _ = yym2550 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) } } } - if yyr2553 || yy2arr2553 { + if yyr2544 || yy2arr2544 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33436,25 +33354,25 @@ func (x *LoadBalancerIngress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2560 := z.DecBinary() - _ = yym2560 + yym2551 := z.DecBinary() + _ = yym2551 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2561 := r.ContainerType() - if yyct2561 == codecSelferValueTypeMap1234 { - yyl2561 := r.ReadMapStart() - if yyl2561 == 0 { + yyct2552 := r.ContainerType() + if yyct2552 == codecSelferValueTypeMap1234 { + yyl2552 := r.ReadMapStart() + if yyl2552 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2561, d) + x.codecDecodeSelfFromMap(yyl2552, d) } - } else if yyct2561 == codecSelferValueTypeArray1234 { - yyl2561 := r.ReadArrayStart() - if yyl2561 == 0 { + } else if yyct2552 == codecSelferValueTypeArray1234 { + yyl2552 := r.ReadArrayStart() + if yyl2552 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2561, d) + x.codecDecodeSelfFromArray(yyl2552, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33466,12 +33384,12 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2562Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2562Slc - var yyhl2562 bool = l >= 0 - for yyj2562 := 0; ; yyj2562++ { - if yyhl2562 { - if yyj2562 >= l { + var yys2553Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2553Slc + var yyhl2553 bool = l >= 0 + for yyj2553 := 0; ; yyj2553++ { + if yyhl2553 { + if yyj2553 >= l { break } } else { @@ -33480,10 +33398,10 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2562Slc = r.DecodeBytes(yys2562Slc, true, true) - yys2562 := string(yys2562Slc) + yys2553Slc = r.DecodeBytes(yys2553Slc, true, true) + yys2553 := string(yys2553Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2562 { + switch yys2553 { case "ip": if r.TryDecodeAsNil() { x.IP = "" @@ -33497,9 +33415,9 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Hostname = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2562) - } // end switch yys2562 - } // end for yyj2562 + z.DecStructFieldNotFound(-1, yys2553) + } // end switch yys2553 + } // end for yyj2553 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -33507,16 +33425,16 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2565 int - var yyb2565 bool - var yyhl2565 bool = l >= 0 - yyj2565++ - if yyhl2565 { - yyb2565 = yyj2565 > l + var yyj2556 int + var yyb2556 bool + var yyhl2556 bool = l >= 0 + yyj2556++ + if yyhl2556 { + yyb2556 = yyj2556 > l } else { - yyb2565 = r.CheckBreak() + yyb2556 = r.CheckBreak() } - if yyb2565 { + if yyb2556 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33526,13 +33444,13 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.IP = string(r.DecodeString()) } - yyj2565++ - if yyhl2565 { - yyb2565 = yyj2565 > l + yyj2556++ + if yyhl2556 { + yyb2556 = yyj2556 > l } else { - yyb2565 = r.CheckBreak() + yyb2556 = r.CheckBreak() } - if yyb2565 { + if yyb2556 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -33543,17 +33461,17 @@ func (x *LoadBalancerIngress) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Hostname = string(r.DecodeString()) } for { - yyj2565++ - if yyhl2565 { - yyb2565 = yyj2565 > l + yyj2556++ + if yyhl2556 { + yyb2556 = yyj2556 > l } else { - yyb2565 = r.CheckBreak() + yyb2556 = r.CheckBreak() } - if yyb2565 { + if yyb2556 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2565-1, "") + z.DecStructFieldNotFound(yyj2556-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -33565,45 +33483,45 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2568 := z.EncBinary() - _ = yym2568 + yym2559 := z.EncBinary() + _ = yym2559 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2569 := !z.EncBinary() - yy2arr2569 := z.EncBasicHandle().StructToArray - var yyq2569 [10]bool - _, _, _ = yysep2569, yyq2569, yy2arr2569 - const yyr2569 bool = false - yyq2569[1] = len(x.Selector) != 0 - yyq2569[2] = x.ClusterIP != "" - yyq2569[3] = x.Type != "" - yyq2569[4] = len(x.ExternalIPs) != 0 - yyq2569[5] = len(x.DeprecatedPublicIPs) != 0 - yyq2569[6] = x.SessionAffinity != "" - yyq2569[7] = x.LoadBalancerIP != "" - yyq2569[8] = len(x.LoadBalancerSourceRanges) != 0 - yyq2569[9] = x.ExternalName != "" - var yynn2569 int - if yyr2569 || yy2arr2569 { + yysep2560 := !z.EncBinary() + yy2arr2560 := z.EncBasicHandle().StructToArray + var yyq2560 [10]bool + _, _, _ = yysep2560, yyq2560, yy2arr2560 + const yyr2560 bool = false + yyq2560[1] = len(x.Selector) != 0 + yyq2560[2] = x.ClusterIP != "" + yyq2560[3] = x.Type != "" + yyq2560[4] = len(x.ExternalIPs) != 0 + yyq2560[5] = len(x.DeprecatedPublicIPs) != 0 + yyq2560[6] = x.SessionAffinity != "" + yyq2560[7] = x.LoadBalancerIP != "" + yyq2560[8] = len(x.LoadBalancerSourceRanges) != 0 + yyq2560[9] = x.ExternalName != "" + var yynn2560 int + if yyr2560 || yy2arr2560 { r.EncodeArrayStart(10) } else { - yynn2569 = 1 - for _, b := range yyq2569 { + yynn2560 = 1 + for _, b := range yyq2560 { if b { - yynn2569++ + yynn2560++ } } - r.EncodeMapStart(yynn2569) - yynn2569 = 0 + r.EncodeMapStart(yynn2560) + yynn2560 = 0 } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Ports == nil { r.EncodeNil() } else { - yym2571 := z.EncBinary() - _ = yym2571 + yym2562 := z.EncBinary() + _ = yym2562 if false { } else { h.encSliceServicePort(([]ServicePort)(x.Ports), e) @@ -33616,22 +33534,22 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Ports == nil { r.EncodeNil() } else { - yym2572 := z.EncBinary() - _ = yym2572 + yym2563 := z.EncBinary() + _ = yym2563 if false { } else { h.encSliceServicePort(([]ServicePort)(x.Ports), e) } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[1] { + if yyq2560[1] { if x.Selector == nil { r.EncodeNil() } else { - yym2574 := z.EncBinary() - _ = yym2574 + yym2565 := z.EncBinary() + _ = yym2565 if false { } else { z.F.EncMapStringStringV(x.Selector, false, e) @@ -33641,15 +33559,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2569[1] { + if yyq2560[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("selector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Selector == nil { r.EncodeNil() } else { - yym2575 := z.EncBinary() - _ = yym2575 + yym2566 := z.EncBinary() + _ = yym2566 if false { } else { z.F.EncMapStringStringV(x.Selector, false, e) @@ -33657,11 +33575,11 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[2] { - yym2577 := z.EncBinary() - _ = yym2577 + if yyq2560[2] { + yym2568 := z.EncBinary() + _ = yym2568 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ClusterIP)) @@ -33670,41 +33588,41 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2569[2] { + if yyq2560[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("clusterIP")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2578 := z.EncBinary() - _ = yym2578 + yym2569 := z.EncBinary() + _ = yym2569 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ClusterIP)) } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[3] { + if yyq2560[3] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2569[3] { + if yyq2560[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[4] { + if yyq2560[4] { if x.ExternalIPs == nil { r.EncodeNil() } else { - yym2581 := z.EncBinary() - _ = yym2581 + yym2572 := z.EncBinary() + _ = yym2572 if false { } else { z.F.EncSliceStringV(x.ExternalIPs, false, e) @@ -33714,15 +33632,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2569[4] { + if yyq2560[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("externalIPs")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ExternalIPs == nil { r.EncodeNil() } else { - yym2582 := z.EncBinary() - _ = yym2582 + yym2573 := z.EncBinary() + _ = yym2573 if false { } else { z.F.EncSliceStringV(x.ExternalIPs, false, e) @@ -33730,14 +33648,14 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[5] { + if yyq2560[5] { if x.DeprecatedPublicIPs == nil { r.EncodeNil() } else { - yym2584 := z.EncBinary() - _ = yym2584 + yym2575 := z.EncBinary() + _ = yym2575 if false { } else { z.F.EncSliceStringV(x.DeprecatedPublicIPs, false, e) @@ -33747,15 +33665,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2569[5] { + if yyq2560[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("deprecatedPublicIPs")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.DeprecatedPublicIPs == nil { r.EncodeNil() } else { - yym2585 := z.EncBinary() - _ = yym2585 + yym2576 := z.EncBinary() + _ = yym2576 if false { } else { z.F.EncSliceStringV(x.DeprecatedPublicIPs, false, e) @@ -33763,26 +33681,26 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[6] { + if yyq2560[6] { x.SessionAffinity.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2569[6] { + if yyq2560[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("sessionAffinity")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.SessionAffinity.CodecEncodeSelf(e) } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[7] { - yym2588 := z.EncBinary() - _ = yym2588 + if yyq2560[7] { + yym2579 := z.EncBinary() + _ = yym2579 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.LoadBalancerIP)) @@ -33791,26 +33709,26 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2569[7] { + if yyq2560[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancerIP")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2589 := z.EncBinary() - _ = yym2589 + yym2580 := z.EncBinary() + _ = yym2580 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.LoadBalancerIP)) } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[8] { + if yyq2560[8] { if x.LoadBalancerSourceRanges == nil { r.EncodeNil() } else { - yym2591 := z.EncBinary() - _ = yym2591 + yym2582 := z.EncBinary() + _ = yym2582 if false { } else { z.F.EncSliceStringV(x.LoadBalancerSourceRanges, false, e) @@ -33820,15 +33738,15 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2569[8] { + if yyq2560[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancerSourceRanges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.LoadBalancerSourceRanges == nil { r.EncodeNil() } else { - yym2592 := z.EncBinary() - _ = yym2592 + yym2583 := z.EncBinary() + _ = yym2583 if false { } else { z.F.EncSliceStringV(x.LoadBalancerSourceRanges, false, e) @@ -33836,11 +33754,11 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2569[9] { - yym2594 := z.EncBinary() - _ = yym2594 + if yyq2560[9] { + yym2585 := z.EncBinary() + _ = yym2585 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalName)) @@ -33849,19 +33767,19 @@ func (x *ServiceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2569[9] { + if yyq2560[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("externalName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2595 := z.EncBinary() - _ = yym2595 + yym2586 := z.EncBinary() + _ = yym2586 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalName)) } } } - if yyr2569 || yy2arr2569 { + if yyr2560 || yy2arr2560 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -33874,25 +33792,25 @@ func (x *ServiceSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2596 := z.DecBinary() - _ = yym2596 + yym2587 := z.DecBinary() + _ = yym2587 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2597 := r.ContainerType() - if yyct2597 == codecSelferValueTypeMap1234 { - yyl2597 := r.ReadMapStart() - if yyl2597 == 0 { + yyct2588 := r.ContainerType() + if yyct2588 == codecSelferValueTypeMap1234 { + yyl2588 := r.ReadMapStart() + if yyl2588 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2597, d) + x.codecDecodeSelfFromMap(yyl2588, d) } - } else if yyct2597 == codecSelferValueTypeArray1234 { - yyl2597 := r.ReadArrayStart() - if yyl2597 == 0 { + } else if yyct2588 == codecSelferValueTypeArray1234 { + yyl2588 := r.ReadArrayStart() + if yyl2588 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2597, d) + x.codecDecodeSelfFromArray(yyl2588, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -33904,12 +33822,12 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2598Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2598Slc - var yyhl2598 bool = l >= 0 - for yyj2598 := 0; ; yyj2598++ { - if yyhl2598 { - if yyj2598 >= l { + var yys2589Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2589Slc + var yyhl2589 bool = l >= 0 + for yyj2589 := 0; ; yyj2589++ { + if yyhl2589 { + if yyj2589 >= l { break } } else { @@ -33918,32 +33836,32 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2598Slc = r.DecodeBytes(yys2598Slc, true, true) - yys2598 := string(yys2598Slc) + yys2589Slc = r.DecodeBytes(yys2589Slc, true, true) + yys2589 := string(yys2589Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2598 { + switch yys2589 { case "ports": if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2599 := &x.Ports - yym2600 := z.DecBinary() - _ = yym2600 + yyv2590 := &x.Ports + yym2591 := z.DecBinary() + _ = yym2591 if false { } else { - h.decSliceServicePort((*[]ServicePort)(yyv2599), d) + h.decSliceServicePort((*[]ServicePort)(yyv2590), d) } } case "selector": if r.TryDecodeAsNil() { x.Selector = nil } else { - yyv2601 := &x.Selector - yym2602 := z.DecBinary() - _ = yym2602 + yyv2592 := &x.Selector + yym2593 := z.DecBinary() + _ = yym2593 if false { } else { - z.F.DecMapStringStringX(yyv2601, false, d) + z.F.DecMapStringStringX(yyv2592, false, d) } } case "clusterIP": @@ -33962,24 +33880,24 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ExternalIPs = nil } else { - yyv2605 := &x.ExternalIPs - yym2606 := z.DecBinary() - _ = yym2606 + yyv2596 := &x.ExternalIPs + yym2597 := z.DecBinary() + _ = yym2597 if false { } else { - z.F.DecSliceStringX(yyv2605, false, d) + z.F.DecSliceStringX(yyv2596, false, d) } } case "deprecatedPublicIPs": if r.TryDecodeAsNil() { x.DeprecatedPublicIPs = nil } else { - yyv2607 := &x.DeprecatedPublicIPs - yym2608 := z.DecBinary() - _ = yym2608 + yyv2598 := &x.DeprecatedPublicIPs + yym2599 := z.DecBinary() + _ = yym2599 if false { } else { - z.F.DecSliceStringX(yyv2607, false, d) + z.F.DecSliceStringX(yyv2598, false, d) } } case "sessionAffinity": @@ -33998,12 +33916,12 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancerSourceRanges = nil } else { - yyv2611 := &x.LoadBalancerSourceRanges - yym2612 := z.DecBinary() - _ = yym2612 + yyv2602 := &x.LoadBalancerSourceRanges + yym2603 := z.DecBinary() + _ = yym2603 if false { } else { - z.F.DecSliceStringX(yyv2611, false, d) + z.F.DecSliceStringX(yyv2602, false, d) } } case "externalName": @@ -34013,9 +33931,9 @@ func (x *ServiceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.ExternalName = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2598) - } // end switch yys2598 - } // end for yyj2598 + z.DecStructFieldNotFound(-1, yys2589) + } // end switch yys2589 + } // end for yyj2589 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34023,16 +33941,16 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2614 int - var yyb2614 bool - var yyhl2614 bool = l >= 0 - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + var yyj2605 int + var yyb2605 bool + var yyhl2605 bool = l >= 0 + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34040,21 +33958,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2615 := &x.Ports - yym2616 := z.DecBinary() - _ = yym2616 + yyv2606 := &x.Ports + yym2607 := z.DecBinary() + _ = yym2607 if false { } else { - h.decSliceServicePort((*[]ServicePort)(yyv2615), d) + h.decSliceServicePort((*[]ServicePort)(yyv2606), d) } } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34062,21 +33980,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Selector = nil } else { - yyv2617 := &x.Selector - yym2618 := z.DecBinary() - _ = yym2618 + yyv2608 := &x.Selector + yym2609 := z.DecBinary() + _ = yym2609 if false { } else { - z.F.DecMapStringStringX(yyv2617, false, d) + z.F.DecMapStringStringX(yyv2608, false, d) } } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34086,13 +34004,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ClusterIP = string(r.DecodeString()) } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34102,13 +34020,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = ServiceType(r.DecodeString()) } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34116,21 +34034,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ExternalIPs = nil } else { - yyv2621 := &x.ExternalIPs - yym2622 := z.DecBinary() - _ = yym2622 + yyv2612 := &x.ExternalIPs + yym2613 := z.DecBinary() + _ = yym2613 if false { } else { - z.F.DecSliceStringX(yyv2621, false, d) + z.F.DecSliceStringX(yyv2612, false, d) } } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34138,21 +34056,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.DeprecatedPublicIPs = nil } else { - yyv2623 := &x.DeprecatedPublicIPs - yym2624 := z.DecBinary() - _ = yym2624 + yyv2614 := &x.DeprecatedPublicIPs + yym2615 := z.DecBinary() + _ = yym2615 if false { } else { - z.F.DecSliceStringX(yyv2623, false, d) + z.F.DecSliceStringX(yyv2614, false, d) } } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34162,13 +34080,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.SessionAffinity = ServiceAffinity(r.DecodeString()) } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34178,13 +34096,13 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.LoadBalancerIP = string(r.DecodeString()) } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34192,21 +34110,21 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancerSourceRanges = nil } else { - yyv2627 := &x.LoadBalancerSourceRanges - yym2628 := z.DecBinary() - _ = yym2628 + yyv2618 := &x.LoadBalancerSourceRanges + yym2619 := z.DecBinary() + _ = yym2619 if false { } else { - z.F.DecSliceStringX(yyv2627, false, d) + z.F.DecSliceStringX(yyv2618, false, d) } } - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34217,17 +34135,17 @@ func (x *ServiceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.ExternalName = string(r.DecodeString()) } for { - yyj2614++ - if yyhl2614 { - yyb2614 = yyj2614 > l + yyj2605++ + if yyhl2605 { + yyb2605 = yyj2605 > l } else { - yyb2614 = r.CheckBreak() + yyb2605 = r.CheckBreak() } - if yyb2614 { + if yyb2605 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2614-1, "") + z.DecStructFieldNotFound(yyj2605-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34239,38 +34157,38 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2630 := z.EncBinary() - _ = yym2630 + yym2621 := z.EncBinary() + _ = yym2621 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2631 := !z.EncBinary() - yy2arr2631 := z.EncBasicHandle().StructToArray - var yyq2631 [5]bool - _, _, _ = yysep2631, yyq2631, yy2arr2631 - const yyr2631 bool = false - yyq2631[0] = x.Name != "" - yyq2631[1] = x.Protocol != "" - yyq2631[3] = true - yyq2631[4] = x.NodePort != 0 - var yynn2631 int - if yyr2631 || yy2arr2631 { + yysep2622 := !z.EncBinary() + yy2arr2622 := z.EncBasicHandle().StructToArray + var yyq2622 [5]bool + _, _, _ = yysep2622, yyq2622, yy2arr2622 + const yyr2622 bool = false + yyq2622[0] = x.Name != "" + yyq2622[1] = x.Protocol != "" + yyq2622[3] = true + yyq2622[4] = x.NodePort != 0 + var yynn2622 int + if yyr2622 || yy2arr2622 { r.EncodeArrayStart(5) } else { - yynn2631 = 1 - for _, b := range yyq2631 { + yynn2622 = 1 + for _, b := range yyq2622 { if b { - yynn2631++ + yynn2622++ } } - r.EncodeMapStart(yynn2631) - yynn2631 = 0 + r.EncodeMapStart(yynn2622) + yynn2622 = 0 } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2631[0] { - yym2633 := z.EncBinary() - _ = yym2633 + if yyq2622[0] { + yym2624 := z.EncBinary() + _ = yym2624 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -34279,37 +34197,37 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2631[0] { + if yyq2622[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2634 := z.EncBinary() - _ = yym2634 + yym2625 := z.EncBinary() + _ = yym2625 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2631[1] { + if yyq2622[1] { x.Protocol.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2631[1] { + if yyq2622[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("protocol")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Protocol.CodecEncodeSelf(e) } } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2637 := z.EncBinary() - _ = yym2637 + yym2628 := z.EncBinary() + _ = yym2628 if false { } else { r.EncodeInt(int64(x.Port)) @@ -34318,51 +34236,51 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2638 := z.EncBinary() - _ = yym2638 + yym2629 := z.EncBinary() + _ = yym2629 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2631[3] { - yy2640 := &x.TargetPort - yym2641 := z.EncBinary() - _ = yym2641 + if yyq2622[3] { + yy2631 := &x.TargetPort + yym2632 := z.EncBinary() + _ = yym2632 if false { - } else if z.HasExtensions() && z.EncExt(yy2640) { - } else if !yym2641 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2640) + } else if z.HasExtensions() && z.EncExt(yy2631) { + } else if !yym2632 && z.IsJSONHandle() { + z.EncJSONMarshal(yy2631) } else { - z.EncFallback(yy2640) + z.EncFallback(yy2631) } } else { r.EncodeNil() } } else { - if yyq2631[3] { + if yyq2622[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("targetPort")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2642 := &x.TargetPort - yym2643 := z.EncBinary() - _ = yym2643 + yy2633 := &x.TargetPort + yym2634 := z.EncBinary() + _ = yym2634 if false { - } else if z.HasExtensions() && z.EncExt(yy2642) { - } else if !yym2643 && z.IsJSONHandle() { - z.EncJSONMarshal(yy2642) + } else if z.HasExtensions() && z.EncExt(yy2633) { + } else if !yym2634 && z.IsJSONHandle() { + z.EncJSONMarshal(yy2633) } else { - z.EncFallback(yy2642) + z.EncFallback(yy2633) } } } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2631[4] { - yym2645 := z.EncBinary() - _ = yym2645 + if yyq2622[4] { + yym2636 := z.EncBinary() + _ = yym2636 if false { } else { r.EncodeInt(int64(x.NodePort)) @@ -34371,19 +34289,19 @@ func (x *ServicePort) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq2631[4] { + if yyq2622[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodePort")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2646 := z.EncBinary() - _ = yym2646 + yym2637 := z.EncBinary() + _ = yym2637 if false { } else { r.EncodeInt(int64(x.NodePort)) } } } - if yyr2631 || yy2arr2631 { + if yyr2622 || yy2arr2622 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34396,25 +34314,25 @@ func (x *ServicePort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2647 := z.DecBinary() - _ = yym2647 + yym2638 := z.DecBinary() + _ = yym2638 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2648 := r.ContainerType() - if yyct2648 == codecSelferValueTypeMap1234 { - yyl2648 := r.ReadMapStart() - if yyl2648 == 0 { + yyct2639 := r.ContainerType() + if yyct2639 == codecSelferValueTypeMap1234 { + yyl2639 := r.ReadMapStart() + if yyl2639 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2648, d) + x.codecDecodeSelfFromMap(yyl2639, d) } - } else if yyct2648 == codecSelferValueTypeArray1234 { - yyl2648 := r.ReadArrayStart() - if yyl2648 == 0 { + } else if yyct2639 == codecSelferValueTypeArray1234 { + yyl2639 := r.ReadArrayStart() + if yyl2639 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2648, d) + x.codecDecodeSelfFromArray(yyl2639, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34426,12 +34344,12 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2649Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2649Slc - var yyhl2649 bool = l >= 0 - for yyj2649 := 0; ; yyj2649++ { - if yyhl2649 { - if yyj2649 >= l { + var yys2640Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2640Slc + var yyhl2640 bool = l >= 0 + for yyj2640 := 0; ; yyj2640++ { + if yyhl2640 { + if yyj2640 >= l { break } } else { @@ -34440,10 +34358,10 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2649Slc = r.DecodeBytes(yys2649Slc, true, true) - yys2649 := string(yys2649Slc) + yys2640Slc = r.DecodeBytes(yys2640Slc, true, true) + yys2640 := string(yys2640Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2649 { + switch yys2640 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -34466,15 +34384,15 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TargetPort = pkg4_intstr.IntOrString{} } else { - yyv2653 := &x.TargetPort - yym2654 := z.DecBinary() - _ = yym2654 + yyv2644 := &x.TargetPort + yym2645 := z.DecBinary() + _ = yym2645 if false { - } else if z.HasExtensions() && z.DecExt(yyv2653) { - } else if !yym2654 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2653) + } else if z.HasExtensions() && z.DecExt(yyv2644) { + } else if !yym2645 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2644) } else { - z.DecFallback(yyv2653, false) + z.DecFallback(yyv2644, false) } } case "nodePort": @@ -34484,9 +34402,9 @@ func (x *ServicePort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.NodePort = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys2649) - } // end switch yys2649 - } // end for yyj2649 + z.DecStructFieldNotFound(-1, yys2640) + } // end switch yys2640 + } // end for yyj2640 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34494,16 +34412,16 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2656 int - var yyb2656 bool - var yyhl2656 bool = l >= 0 - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + var yyj2647 int + var yyb2647 bool + var yyhl2647 bool = l >= 0 + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34513,13 +34431,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34529,13 +34447,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Protocol = Protocol(r.DecodeString()) } - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34545,13 +34463,13 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Port = int32(r.DecodeInt(32)) } - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34559,24 +34477,24 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TargetPort = pkg4_intstr.IntOrString{} } else { - yyv2660 := &x.TargetPort - yym2661 := z.DecBinary() - _ = yym2661 + yyv2651 := &x.TargetPort + yym2652 := z.DecBinary() + _ = yym2652 if false { - } else if z.HasExtensions() && z.DecExt(yyv2660) { - } else if !yym2661 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv2660) + } else if z.HasExtensions() && z.DecExt(yyv2651) { + } else if !yym2652 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv2651) } else { - z.DecFallback(yyv2660, false) + z.DecFallback(yyv2651, false) } } - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34587,17 +34505,17 @@ func (x *ServicePort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.NodePort = int32(r.DecodeInt(32)) } for { - yyj2656++ - if yyhl2656 { - yyb2656 = yyj2656 > l + yyj2647++ + if yyhl2647 { + yyb2647 = yyj2647 > l } else { - yyb2656 = r.CheckBreak() + yyb2647 = r.CheckBreak() } - if yyb2656 { + if yyb2647 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2656-1, "") + z.DecStructFieldNotFound(yyj2647-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34609,39 +34527,39 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2663 := z.EncBinary() - _ = yym2663 + yym2654 := z.EncBinary() + _ = yym2654 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2664 := !z.EncBinary() - yy2arr2664 := z.EncBasicHandle().StructToArray - var yyq2664 [5]bool - _, _, _ = yysep2664, yyq2664, yy2arr2664 - const yyr2664 bool = false - yyq2664[0] = x.Kind != "" - yyq2664[1] = x.APIVersion != "" - yyq2664[2] = true - yyq2664[3] = true - yyq2664[4] = true - var yynn2664 int - if yyr2664 || yy2arr2664 { + yysep2655 := !z.EncBinary() + yy2arr2655 := z.EncBasicHandle().StructToArray + var yyq2655 [5]bool + _, _, _ = yysep2655, yyq2655, yy2arr2655 + const yyr2655 bool = false + yyq2655[0] = x.Kind != "" + yyq2655[1] = x.APIVersion != "" + yyq2655[2] = true + yyq2655[3] = true + yyq2655[4] = true + var yynn2655 int + if yyr2655 || yy2arr2655 { r.EncodeArrayStart(5) } else { - yynn2664 = 0 - for _, b := range yyq2664 { + yynn2655 = 0 + for _, b := range yyq2655 { if b { - yynn2664++ + yynn2655++ } } - r.EncodeMapStart(yynn2664) - yynn2664 = 0 + r.EncodeMapStart(yynn2655) + yynn2655 = 0 } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2664[0] { - yym2666 := z.EncBinary() - _ = yym2666 + if yyq2655[0] { + yym2657 := z.EncBinary() + _ = yym2657 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -34650,23 +34568,23 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2664[0] { + if yyq2655[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2667 := z.EncBinary() - _ = yym2667 + yym2658 := z.EncBinary() + _ = yym2658 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2664[1] { - yym2669 := z.EncBinary() - _ = yym2669 + if yyq2655[1] { + yym2660 := z.EncBinary() + _ = yym2660 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -34675,70 +34593,70 @@ func (x *Service) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2664[1] { + if yyq2655[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2670 := z.EncBinary() - _ = yym2670 + yym2661 := z.EncBinary() + _ = yym2661 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2664[2] { - yy2672 := &x.ObjectMeta - yy2672.CodecEncodeSelf(e) + if yyq2655[2] { + yy2663 := &x.ObjectMeta + yy2663.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2664[2] { + if yyq2655[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2673 := &x.ObjectMeta - yy2673.CodecEncodeSelf(e) + yy2664 := &x.ObjectMeta + yy2664.CodecEncodeSelf(e) } } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2664[3] { - yy2675 := &x.Spec - yy2675.CodecEncodeSelf(e) + if yyq2655[3] { + yy2666 := &x.Spec + yy2666.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2664[3] { + if yyq2655[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2676 := &x.Spec - yy2676.CodecEncodeSelf(e) + yy2667 := &x.Spec + yy2667.CodecEncodeSelf(e) } } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2664[4] { - yy2678 := &x.Status - yy2678.CodecEncodeSelf(e) + if yyq2655[4] { + yy2669 := &x.Status + yy2669.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2664[4] { + if yyq2655[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2679 := &x.Status - yy2679.CodecEncodeSelf(e) + yy2670 := &x.Status + yy2670.CodecEncodeSelf(e) } } - if yyr2664 || yy2arr2664 { + if yyr2655 || yy2arr2655 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -34751,25 +34669,25 @@ func (x *Service) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2680 := z.DecBinary() - _ = yym2680 + yym2671 := z.DecBinary() + _ = yym2671 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2681 := r.ContainerType() - if yyct2681 == codecSelferValueTypeMap1234 { - yyl2681 := r.ReadMapStart() - if yyl2681 == 0 { + yyct2672 := r.ContainerType() + if yyct2672 == codecSelferValueTypeMap1234 { + yyl2672 := r.ReadMapStart() + if yyl2672 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2681, d) + x.codecDecodeSelfFromMap(yyl2672, d) } - } else if yyct2681 == codecSelferValueTypeArray1234 { - yyl2681 := r.ReadArrayStart() - if yyl2681 == 0 { + } else if yyct2672 == codecSelferValueTypeArray1234 { + yyl2672 := r.ReadArrayStart() + if yyl2672 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2681, d) + x.codecDecodeSelfFromArray(yyl2672, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -34781,12 +34699,12 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2682Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2682Slc - var yyhl2682 bool = l >= 0 - for yyj2682 := 0; ; yyj2682++ { - if yyhl2682 { - if yyj2682 >= l { + var yys2673Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2673Slc + var yyhl2673 bool = l >= 0 + for yyj2673 := 0; ; yyj2673++ { + if yyhl2673 { + if yyj2673 >= l { break } } else { @@ -34795,10 +34713,10 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2682Slc = r.DecodeBytes(yys2682Slc, true, true) - yys2682 := string(yys2682Slc) + yys2673Slc = r.DecodeBytes(yys2673Slc, true, true) + yys2673 := string(yys2673Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2682 { + switch yys2673 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -34815,27 +34733,27 @@ func (x *Service) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2685 := &x.ObjectMeta - yyv2685.CodecDecodeSelf(d) + yyv2676 := &x.ObjectMeta + yyv2676.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ServiceSpec{} } else { - yyv2686 := &x.Spec - yyv2686.CodecDecodeSelf(d) + yyv2677 := &x.Spec + yyv2677.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ServiceStatus{} } else { - yyv2687 := &x.Status - yyv2687.CodecDecodeSelf(d) + yyv2678 := &x.Status + yyv2678.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2682) - } // end switch yys2682 - } // end for yyj2682 + z.DecStructFieldNotFound(-1, yys2673) + } // end switch yys2673 + } // end for yyj2673 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -34843,16 +34761,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2688 int - var yyb2688 bool - var yyhl2688 bool = l >= 0 - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + var yyj2679 int + var yyb2679 bool + var yyhl2679 bool = l >= 0 + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34862,13 +34780,13 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34878,13 +34796,13 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34892,16 +34810,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2691 := &x.ObjectMeta - yyv2691.CodecDecodeSelf(d) + yyv2682 := &x.ObjectMeta + yyv2682.CodecDecodeSelf(d) } - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34909,16 +34827,16 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ServiceSpec{} } else { - yyv2692 := &x.Spec - yyv2692.CodecDecodeSelf(d) + yyv2683 := &x.Spec + yyv2683.CodecDecodeSelf(d) } - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -34926,21 +34844,21 @@ func (x *Service) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ServiceStatus{} } else { - yyv2693 := &x.Status - yyv2693.CodecDecodeSelf(d) + yyv2684 := &x.Status + yyv2684.CodecDecodeSelf(d) } for { - yyj2688++ - if yyhl2688 { - yyb2688 = yyj2688 > l + yyj2679++ + if yyhl2679 { + yyb2679 = yyj2679 > l } else { - yyb2688 = r.CheckBreak() + yyb2679 = r.CheckBreak() } - if yyb2688 { + if yyb2679 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2688-1, "") + z.DecStructFieldNotFound(yyj2679-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -34952,37 +34870,37 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2694 := z.EncBinary() - _ = yym2694 + yym2685 := z.EncBinary() + _ = yym2685 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2695 := !z.EncBinary() - yy2arr2695 := z.EncBasicHandle().StructToArray - var yyq2695 [4]bool - _, _, _ = yysep2695, yyq2695, yy2arr2695 - const yyr2695 bool = false - yyq2695[0] = x.Kind != "" - yyq2695[1] = x.APIVersion != "" - yyq2695[2] = true - var yynn2695 int - if yyr2695 || yy2arr2695 { + yysep2686 := !z.EncBinary() + yy2arr2686 := z.EncBasicHandle().StructToArray + var yyq2686 [4]bool + _, _, _ = yysep2686, yyq2686, yy2arr2686 + const yyr2686 bool = false + yyq2686[0] = x.Kind != "" + yyq2686[1] = x.APIVersion != "" + yyq2686[2] = true + var yynn2686 int + if yyr2686 || yy2arr2686 { r.EncodeArrayStart(4) } else { - yynn2695 = 1 - for _, b := range yyq2695 { + yynn2686 = 1 + for _, b := range yyq2686 { if b { - yynn2695++ + yynn2686++ } } - r.EncodeMapStart(yynn2695) - yynn2695 = 0 + r.EncodeMapStart(yynn2686) + yynn2686 = 0 } - if yyr2695 || yy2arr2695 { + if yyr2686 || yy2arr2686 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2695[0] { - yym2697 := z.EncBinary() - _ = yym2697 + if yyq2686[0] { + yym2688 := z.EncBinary() + _ = yym2688 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -34991,23 +34909,23 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2695[0] { + if yyq2686[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2698 := z.EncBinary() - _ = yym2698 + yym2689 := z.EncBinary() + _ = yym2689 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2695 || yy2arr2695 { + if yyr2686 || yy2arr2686 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2695[1] { - yym2700 := z.EncBinary() - _ = yym2700 + if yyq2686[1] { + yym2691 := z.EncBinary() + _ = yym2691 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -35016,54 +34934,54 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2695[1] { + if yyq2686[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2701 := z.EncBinary() - _ = yym2701 + yym2692 := z.EncBinary() + _ = yym2692 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2695 || yy2arr2695 { + if yyr2686 || yy2arr2686 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2695[2] { - yy2703 := &x.ListMeta - yym2704 := z.EncBinary() - _ = yym2704 + if yyq2686[2] { + yy2694 := &x.ListMeta + yym2695 := z.EncBinary() + _ = yym2695 if false { - } else if z.HasExtensions() && z.EncExt(yy2703) { + } else if z.HasExtensions() && z.EncExt(yy2694) { } else { - z.EncFallback(yy2703) + z.EncFallback(yy2694) } } else { r.EncodeNil() } } else { - if yyq2695[2] { + if yyq2686[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2705 := &x.ListMeta - yym2706 := z.EncBinary() - _ = yym2706 + yy2696 := &x.ListMeta + yym2697 := z.EncBinary() + _ = yym2697 if false { - } else if z.HasExtensions() && z.EncExt(yy2705) { + } else if z.HasExtensions() && z.EncExt(yy2696) { } else { - z.EncFallback(yy2705) + z.EncFallback(yy2696) } } } - if yyr2695 || yy2arr2695 { + if yyr2686 || yy2arr2686 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2708 := z.EncBinary() - _ = yym2708 + yym2699 := z.EncBinary() + _ = yym2699 if false { } else { h.encSliceService(([]Service)(x.Items), e) @@ -35076,15 +34994,15 @@ func (x *ServiceList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2709 := z.EncBinary() - _ = yym2709 + yym2700 := z.EncBinary() + _ = yym2700 if false { } else { h.encSliceService(([]Service)(x.Items), e) } } } - if yyr2695 || yy2arr2695 { + if yyr2686 || yy2arr2686 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -35097,25 +35015,25 @@ func (x *ServiceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2710 := z.DecBinary() - _ = yym2710 + yym2701 := z.DecBinary() + _ = yym2701 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2711 := r.ContainerType() - if yyct2711 == codecSelferValueTypeMap1234 { - yyl2711 := r.ReadMapStart() - if yyl2711 == 0 { + yyct2702 := r.ContainerType() + if yyct2702 == codecSelferValueTypeMap1234 { + yyl2702 := r.ReadMapStart() + if yyl2702 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2711, d) + x.codecDecodeSelfFromMap(yyl2702, d) } - } else if yyct2711 == codecSelferValueTypeArray1234 { - yyl2711 := r.ReadArrayStart() - if yyl2711 == 0 { + } else if yyct2702 == codecSelferValueTypeArray1234 { + yyl2702 := r.ReadArrayStart() + if yyl2702 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2711, d) + x.codecDecodeSelfFromArray(yyl2702, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -35127,12 +35045,12 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2712Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2712Slc - var yyhl2712 bool = l >= 0 - for yyj2712 := 0; ; yyj2712++ { - if yyhl2712 { - if yyj2712 >= l { + var yys2703Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2703Slc + var yyhl2703 bool = l >= 0 + for yyj2703 := 0; ; yyj2703++ { + if yyhl2703 { + if yyj2703 >= l { break } } else { @@ -35141,10 +35059,10 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2712Slc = r.DecodeBytes(yys2712Slc, true, true) - yys2712 := string(yys2712Slc) + yys2703Slc = r.DecodeBytes(yys2703Slc, true, true) + yys2703 := string(yys2703Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2712 { + switch yys2703 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -35161,31 +35079,31 @@ func (x *ServiceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2715 := &x.ListMeta - yym2716 := z.DecBinary() - _ = yym2716 + yyv2706 := &x.ListMeta + yym2707 := z.DecBinary() + _ = yym2707 if false { - } else if z.HasExtensions() && z.DecExt(yyv2715) { + } else if z.HasExtensions() && z.DecExt(yyv2706) { } else { - z.DecFallback(yyv2715, false) + z.DecFallback(yyv2706, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2717 := &x.Items - yym2718 := z.DecBinary() - _ = yym2718 + yyv2708 := &x.Items + yym2709 := z.DecBinary() + _ = yym2709 if false { } else { - h.decSliceService((*[]Service)(yyv2717), d) + h.decSliceService((*[]Service)(yyv2708), d) } } default: - z.DecStructFieldNotFound(-1, yys2712) - } // end switch yys2712 - } // end for yyj2712 + z.DecStructFieldNotFound(-1, yys2703) + } // end switch yys2703 + } // end for yyj2703 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35193,16 +35111,16 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2719 int - var yyb2719 bool - var yyhl2719 bool = l >= 0 - yyj2719++ - if yyhl2719 { - yyb2719 = yyj2719 > l + var yyj2710 int + var yyb2710 bool + var yyhl2710 bool = l >= 0 + yyj2710++ + if yyhl2710 { + yyb2710 = yyj2710 > l } else { - yyb2719 = r.CheckBreak() + yyb2710 = r.CheckBreak() } - if yyb2719 { + if yyb2710 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35212,13 +35130,13 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2719++ - if yyhl2719 { - yyb2719 = yyj2719 > l + yyj2710++ + if yyhl2710 { + yyb2710 = yyj2710 > l } else { - yyb2719 = r.CheckBreak() + yyb2710 = r.CheckBreak() } - if yyb2719 { + if yyb2710 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35228,13 +35146,13 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2719++ - if yyhl2719 { - yyb2719 = yyj2719 > l + yyj2710++ + if yyhl2710 { + yyb2710 = yyj2710 > l } else { - yyb2719 = r.CheckBreak() + yyb2710 = r.CheckBreak() } - if yyb2719 { + if yyb2710 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35242,22 +35160,22 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2722 := &x.ListMeta - yym2723 := z.DecBinary() - _ = yym2723 + yyv2713 := &x.ListMeta + yym2714 := z.DecBinary() + _ = yym2714 if false { - } else if z.HasExtensions() && z.DecExt(yyv2722) { + } else if z.HasExtensions() && z.DecExt(yyv2713) { } else { - z.DecFallback(yyv2722, false) + z.DecFallback(yyv2713, false) } } - yyj2719++ - if yyhl2719 { - yyb2719 = yyj2719 > l + yyj2710++ + if yyhl2710 { + yyb2710 = yyj2710 > l } else { - yyb2719 = r.CheckBreak() + yyb2710 = r.CheckBreak() } - if yyb2719 { + if yyb2710 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35265,26 +35183,26 @@ func (x *ServiceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2724 := &x.Items - yym2725 := z.DecBinary() - _ = yym2725 + yyv2715 := &x.Items + yym2716 := z.DecBinary() + _ = yym2716 if false { } else { - h.decSliceService((*[]Service)(yyv2724), d) + h.decSliceService((*[]Service)(yyv2715), d) } } for { - yyj2719++ - if yyhl2719 { - yyb2719 = yyj2719 > l + yyj2710++ + if yyhl2710 { + yyb2710 = yyj2710 > l } else { - yyb2719 = r.CheckBreak() + yyb2710 = r.CheckBreak() } - if yyb2719 { + if yyb2710 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2719-1, "") + z.DecStructFieldNotFound(yyj2710-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -35296,39 +35214,39 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2726 := z.EncBinary() - _ = yym2726 + yym2717 := z.EncBinary() + _ = yym2717 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2727 := !z.EncBinary() - yy2arr2727 := z.EncBasicHandle().StructToArray - var yyq2727 [5]bool - _, _, _ = yysep2727, yyq2727, yy2arr2727 - const yyr2727 bool = false - yyq2727[0] = x.Kind != "" - yyq2727[1] = x.APIVersion != "" - yyq2727[2] = true - yyq2727[3] = len(x.Secrets) != 0 - yyq2727[4] = len(x.ImagePullSecrets) != 0 - var yynn2727 int - if yyr2727 || yy2arr2727 { + yysep2718 := !z.EncBinary() + yy2arr2718 := z.EncBasicHandle().StructToArray + var yyq2718 [5]bool + _, _, _ = yysep2718, yyq2718, yy2arr2718 + const yyr2718 bool = false + yyq2718[0] = x.Kind != "" + yyq2718[1] = x.APIVersion != "" + yyq2718[2] = true + yyq2718[3] = len(x.Secrets) != 0 + yyq2718[4] = len(x.ImagePullSecrets) != 0 + var yynn2718 int + if yyr2718 || yy2arr2718 { r.EncodeArrayStart(5) } else { - yynn2727 = 0 - for _, b := range yyq2727 { + yynn2718 = 0 + for _, b := range yyq2718 { if b { - yynn2727++ + yynn2718++ } } - r.EncodeMapStart(yynn2727) - yynn2727 = 0 + r.EncodeMapStart(yynn2718) + yynn2718 = 0 } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2727[0] { - yym2729 := z.EncBinary() - _ = yym2729 + if yyq2718[0] { + yym2720 := z.EncBinary() + _ = yym2720 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -35337,23 +35255,23 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2727[0] { + if yyq2718[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2730 := z.EncBinary() - _ = yym2730 + yym2721 := z.EncBinary() + _ = yym2721 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2727[1] { - yym2732 := z.EncBinary() - _ = yym2732 + if yyq2718[1] { + yym2723 := z.EncBinary() + _ = yym2723 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -35362,43 +35280,43 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2727[1] { + if yyq2718[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2733 := z.EncBinary() - _ = yym2733 + yym2724 := z.EncBinary() + _ = yym2724 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2727[2] { - yy2735 := &x.ObjectMeta - yy2735.CodecEncodeSelf(e) + if yyq2718[2] { + yy2726 := &x.ObjectMeta + yy2726.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2727[2] { + if yyq2718[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2736 := &x.ObjectMeta - yy2736.CodecEncodeSelf(e) + yy2727 := &x.ObjectMeta + yy2727.CodecEncodeSelf(e) } } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2727[3] { + if yyq2718[3] { if x.Secrets == nil { r.EncodeNil() } else { - yym2738 := z.EncBinary() - _ = yym2738 + yym2729 := z.EncBinary() + _ = yym2729 if false { } else { h.encSliceObjectReference(([]ObjectReference)(x.Secrets), e) @@ -35408,15 +35326,15 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2727[3] { + if yyq2718[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("secrets")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Secrets == nil { r.EncodeNil() } else { - yym2739 := z.EncBinary() - _ = yym2739 + yym2730 := z.EncBinary() + _ = yym2730 if false { } else { h.encSliceObjectReference(([]ObjectReference)(x.Secrets), e) @@ -35424,14 +35342,14 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2727[4] { + if yyq2718[4] { if x.ImagePullSecrets == nil { r.EncodeNil() } else { - yym2741 := z.EncBinary() - _ = yym2741 + yym2732 := z.EncBinary() + _ = yym2732 if false { } else { h.encSliceLocalObjectReference(([]LocalObjectReference)(x.ImagePullSecrets), e) @@ -35441,15 +35359,15 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2727[4] { + if yyq2718[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("imagePullSecrets")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ImagePullSecrets == nil { r.EncodeNil() } else { - yym2742 := z.EncBinary() - _ = yym2742 + yym2733 := z.EncBinary() + _ = yym2733 if false { } else { h.encSliceLocalObjectReference(([]LocalObjectReference)(x.ImagePullSecrets), e) @@ -35457,7 +35375,7 @@ func (x *ServiceAccount) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2727 || yy2arr2727 { + if yyr2718 || yy2arr2718 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -35470,25 +35388,25 @@ func (x *ServiceAccount) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2743 := z.DecBinary() - _ = yym2743 + yym2734 := z.DecBinary() + _ = yym2734 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2744 := r.ContainerType() - if yyct2744 == codecSelferValueTypeMap1234 { - yyl2744 := r.ReadMapStart() - if yyl2744 == 0 { + yyct2735 := r.ContainerType() + if yyct2735 == codecSelferValueTypeMap1234 { + yyl2735 := r.ReadMapStart() + if yyl2735 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2744, d) + x.codecDecodeSelfFromMap(yyl2735, d) } - } else if yyct2744 == codecSelferValueTypeArray1234 { - yyl2744 := r.ReadArrayStart() - if yyl2744 == 0 { + } else if yyct2735 == codecSelferValueTypeArray1234 { + yyl2735 := r.ReadArrayStart() + if yyl2735 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2744, d) + x.codecDecodeSelfFromArray(yyl2735, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -35500,12 +35418,12 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2745Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2745Slc - var yyhl2745 bool = l >= 0 - for yyj2745 := 0; ; yyj2745++ { - if yyhl2745 { - if yyj2745 >= l { + var yys2736Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2736Slc + var yyhl2736 bool = l >= 0 + for yyj2736 := 0; ; yyj2736++ { + if yyhl2736 { + if yyj2736 >= l { break } } else { @@ -35514,10 +35432,10 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2745Slc = r.DecodeBytes(yys2745Slc, true, true) - yys2745 := string(yys2745Slc) + yys2736Slc = r.DecodeBytes(yys2736Slc, true, true) + yys2736 := string(yys2736Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2745 { + switch yys2736 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -35534,37 +35452,37 @@ func (x *ServiceAccount) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2748 := &x.ObjectMeta - yyv2748.CodecDecodeSelf(d) + yyv2739 := &x.ObjectMeta + yyv2739.CodecDecodeSelf(d) } case "secrets": if r.TryDecodeAsNil() { x.Secrets = nil } else { - yyv2749 := &x.Secrets - yym2750 := z.DecBinary() - _ = yym2750 + yyv2740 := &x.Secrets + yym2741 := z.DecBinary() + _ = yym2741 if false { } else { - h.decSliceObjectReference((*[]ObjectReference)(yyv2749), d) + h.decSliceObjectReference((*[]ObjectReference)(yyv2740), d) } } case "imagePullSecrets": if r.TryDecodeAsNil() { x.ImagePullSecrets = nil } else { - yyv2751 := &x.ImagePullSecrets - yym2752 := z.DecBinary() - _ = yym2752 + yyv2742 := &x.ImagePullSecrets + yym2743 := z.DecBinary() + _ = yym2743 if false { } else { - h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2751), d) + h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2742), d) } } default: - z.DecStructFieldNotFound(-1, yys2745) - } // end switch yys2745 - } // end for yyj2745 + z.DecStructFieldNotFound(-1, yys2736) + } // end switch yys2736 + } // end for yyj2736 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35572,16 +35490,16 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2753 int - var yyb2753 bool - var yyhl2753 bool = l >= 0 - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + var yyj2744 int + var yyb2744 bool + var yyhl2744 bool = l >= 0 + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35591,13 +35509,13 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35607,13 +35525,13 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35621,16 +35539,16 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2756 := &x.ObjectMeta - yyv2756.CodecDecodeSelf(d) + yyv2747 := &x.ObjectMeta + yyv2747.CodecDecodeSelf(d) } - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35638,21 +35556,21 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Secrets = nil } else { - yyv2757 := &x.Secrets - yym2758 := z.DecBinary() - _ = yym2758 + yyv2748 := &x.Secrets + yym2749 := z.DecBinary() + _ = yym2749 if false { } else { - h.decSliceObjectReference((*[]ObjectReference)(yyv2757), d) + h.decSliceObjectReference((*[]ObjectReference)(yyv2748), d) } } - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35660,26 +35578,26 @@ func (x *ServiceAccount) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ImagePullSecrets = nil } else { - yyv2759 := &x.ImagePullSecrets - yym2760 := z.DecBinary() - _ = yym2760 + yyv2750 := &x.ImagePullSecrets + yym2751 := z.DecBinary() + _ = yym2751 if false { } else { - h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2759), d) + h.decSliceLocalObjectReference((*[]LocalObjectReference)(yyv2750), d) } } for { - yyj2753++ - if yyhl2753 { - yyb2753 = yyj2753 > l + yyj2744++ + if yyhl2744 { + yyb2744 = yyj2744 > l } else { - yyb2753 = r.CheckBreak() + yyb2744 = r.CheckBreak() } - if yyb2753 { + if yyb2744 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2753-1, "") + z.DecStructFieldNotFound(yyj2744-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -35691,37 +35609,37 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2761 := z.EncBinary() - _ = yym2761 + yym2752 := z.EncBinary() + _ = yym2752 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2762 := !z.EncBinary() - yy2arr2762 := z.EncBasicHandle().StructToArray - var yyq2762 [4]bool - _, _, _ = yysep2762, yyq2762, yy2arr2762 - const yyr2762 bool = false - yyq2762[0] = x.Kind != "" - yyq2762[1] = x.APIVersion != "" - yyq2762[2] = true - var yynn2762 int - if yyr2762 || yy2arr2762 { + yysep2753 := !z.EncBinary() + yy2arr2753 := z.EncBasicHandle().StructToArray + var yyq2753 [4]bool + _, _, _ = yysep2753, yyq2753, yy2arr2753 + const yyr2753 bool = false + yyq2753[0] = x.Kind != "" + yyq2753[1] = x.APIVersion != "" + yyq2753[2] = true + var yynn2753 int + if yyr2753 || yy2arr2753 { r.EncodeArrayStart(4) } else { - yynn2762 = 1 - for _, b := range yyq2762 { + yynn2753 = 1 + for _, b := range yyq2753 { if b { - yynn2762++ + yynn2753++ } } - r.EncodeMapStart(yynn2762) - yynn2762 = 0 + r.EncodeMapStart(yynn2753) + yynn2753 = 0 } - if yyr2762 || yy2arr2762 { + if yyr2753 || yy2arr2753 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2762[0] { - yym2764 := z.EncBinary() - _ = yym2764 + if yyq2753[0] { + yym2755 := z.EncBinary() + _ = yym2755 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -35730,23 +35648,23 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2762[0] { + if yyq2753[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2765 := z.EncBinary() - _ = yym2765 + yym2756 := z.EncBinary() + _ = yym2756 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2762 || yy2arr2762 { + if yyr2753 || yy2arr2753 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2762[1] { - yym2767 := z.EncBinary() - _ = yym2767 + if yyq2753[1] { + yym2758 := z.EncBinary() + _ = yym2758 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -35755,54 +35673,54 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2762[1] { + if yyq2753[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2768 := z.EncBinary() - _ = yym2768 + yym2759 := z.EncBinary() + _ = yym2759 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2762 || yy2arr2762 { + if yyr2753 || yy2arr2753 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2762[2] { - yy2770 := &x.ListMeta - yym2771 := z.EncBinary() - _ = yym2771 + if yyq2753[2] { + yy2761 := &x.ListMeta + yym2762 := z.EncBinary() + _ = yym2762 if false { - } else if z.HasExtensions() && z.EncExt(yy2770) { + } else if z.HasExtensions() && z.EncExt(yy2761) { } else { - z.EncFallback(yy2770) + z.EncFallback(yy2761) } } else { r.EncodeNil() } } else { - if yyq2762[2] { + if yyq2753[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2772 := &x.ListMeta - yym2773 := z.EncBinary() - _ = yym2773 + yy2763 := &x.ListMeta + yym2764 := z.EncBinary() + _ = yym2764 if false { - } else if z.HasExtensions() && z.EncExt(yy2772) { + } else if z.HasExtensions() && z.EncExt(yy2763) { } else { - z.EncFallback(yy2772) + z.EncFallback(yy2763) } } } - if yyr2762 || yy2arr2762 { + if yyr2753 || yy2arr2753 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2775 := z.EncBinary() - _ = yym2775 + yym2766 := z.EncBinary() + _ = yym2766 if false { } else { h.encSliceServiceAccount(([]ServiceAccount)(x.Items), e) @@ -35815,15 +35733,15 @@ func (x *ServiceAccountList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2776 := z.EncBinary() - _ = yym2776 + yym2767 := z.EncBinary() + _ = yym2767 if false { } else { h.encSliceServiceAccount(([]ServiceAccount)(x.Items), e) } } } - if yyr2762 || yy2arr2762 { + if yyr2753 || yy2arr2753 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -35836,25 +35754,25 @@ func (x *ServiceAccountList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2777 := z.DecBinary() - _ = yym2777 + yym2768 := z.DecBinary() + _ = yym2768 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2778 := r.ContainerType() - if yyct2778 == codecSelferValueTypeMap1234 { - yyl2778 := r.ReadMapStart() - if yyl2778 == 0 { + yyct2769 := r.ContainerType() + if yyct2769 == codecSelferValueTypeMap1234 { + yyl2769 := r.ReadMapStart() + if yyl2769 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2778, d) + x.codecDecodeSelfFromMap(yyl2769, d) } - } else if yyct2778 == codecSelferValueTypeArray1234 { - yyl2778 := r.ReadArrayStart() - if yyl2778 == 0 { + } else if yyct2769 == codecSelferValueTypeArray1234 { + yyl2769 := r.ReadArrayStart() + if yyl2769 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2778, d) + x.codecDecodeSelfFromArray(yyl2769, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -35866,12 +35784,12 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2779Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2779Slc - var yyhl2779 bool = l >= 0 - for yyj2779 := 0; ; yyj2779++ { - if yyhl2779 { - if yyj2779 >= l { + var yys2770Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2770Slc + var yyhl2770 bool = l >= 0 + for yyj2770 := 0; ; yyj2770++ { + if yyhl2770 { + if yyj2770 >= l { break } } else { @@ -35880,10 +35798,10 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2779Slc = r.DecodeBytes(yys2779Slc, true, true) - yys2779 := string(yys2779Slc) + yys2770Slc = r.DecodeBytes(yys2770Slc, true, true) + yys2770 := string(yys2770Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2779 { + switch yys2770 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -35900,31 +35818,31 @@ func (x *ServiceAccountList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2782 := &x.ListMeta - yym2783 := z.DecBinary() - _ = yym2783 + yyv2773 := &x.ListMeta + yym2774 := z.DecBinary() + _ = yym2774 if false { - } else if z.HasExtensions() && z.DecExt(yyv2782) { + } else if z.HasExtensions() && z.DecExt(yyv2773) { } else { - z.DecFallback(yyv2782, false) + z.DecFallback(yyv2773, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2784 := &x.Items - yym2785 := z.DecBinary() - _ = yym2785 + yyv2775 := &x.Items + yym2776 := z.DecBinary() + _ = yym2776 if false { } else { - h.decSliceServiceAccount((*[]ServiceAccount)(yyv2784), d) + h.decSliceServiceAccount((*[]ServiceAccount)(yyv2775), d) } } default: - z.DecStructFieldNotFound(-1, yys2779) - } // end switch yys2779 - } // end for yyj2779 + z.DecStructFieldNotFound(-1, yys2770) + } // end switch yys2770 + } // end for yyj2770 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -35932,16 +35850,16 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2786 int - var yyb2786 bool - var yyhl2786 bool = l >= 0 - yyj2786++ - if yyhl2786 { - yyb2786 = yyj2786 > l + var yyj2777 int + var yyb2777 bool + var yyhl2777 bool = l >= 0 + yyj2777++ + if yyhl2777 { + yyb2777 = yyj2777 > l } else { - yyb2786 = r.CheckBreak() + yyb2777 = r.CheckBreak() } - if yyb2786 { + if yyb2777 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35951,13 +35869,13 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Kind = string(r.DecodeString()) } - yyj2786++ - if yyhl2786 { - yyb2786 = yyj2786 > l + yyj2777++ + if yyhl2777 { + yyb2777 = yyj2777 > l } else { - yyb2786 = r.CheckBreak() + yyb2777 = r.CheckBreak() } - if yyb2786 { + if yyb2777 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35967,13 +35885,13 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.APIVersion = string(r.DecodeString()) } - yyj2786++ - if yyhl2786 { - yyb2786 = yyj2786 > l + yyj2777++ + if yyhl2777 { + yyb2777 = yyj2777 > l } else { - yyb2786 = r.CheckBreak() + yyb2777 = r.CheckBreak() } - if yyb2786 { + if yyb2777 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -35981,22 +35899,22 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2789 := &x.ListMeta - yym2790 := z.DecBinary() - _ = yym2790 + yyv2780 := &x.ListMeta + yym2781 := z.DecBinary() + _ = yym2781 if false { - } else if z.HasExtensions() && z.DecExt(yyv2789) { + } else if z.HasExtensions() && z.DecExt(yyv2780) { } else { - z.DecFallback(yyv2789, false) + z.DecFallback(yyv2780, false) } } - yyj2786++ - if yyhl2786 { - yyb2786 = yyj2786 > l + yyj2777++ + if yyhl2777 { + yyb2777 = yyj2777 > l } else { - yyb2786 = r.CheckBreak() + yyb2777 = r.CheckBreak() } - if yyb2786 { + if yyb2777 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36004,26 +35922,26 @@ func (x *ServiceAccountList) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2791 := &x.Items - yym2792 := z.DecBinary() - _ = yym2792 + yyv2782 := &x.Items + yym2783 := z.DecBinary() + _ = yym2783 if false { } else { - h.decSliceServiceAccount((*[]ServiceAccount)(yyv2791), d) + h.decSliceServiceAccount((*[]ServiceAccount)(yyv2782), d) } } for { - yyj2786++ - if yyhl2786 { - yyb2786 = yyj2786 > l + yyj2777++ + if yyhl2777 { + yyb2777 = yyj2777 > l } else { - yyb2786 = r.CheckBreak() + yyb2777 = r.CheckBreak() } - if yyb2786 { + if yyb2777 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2786-1, "") + z.DecStructFieldNotFound(yyj2777-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36035,37 +35953,37 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2793 := z.EncBinary() - _ = yym2793 + yym2784 := z.EncBinary() + _ = yym2784 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2794 := !z.EncBinary() - yy2arr2794 := z.EncBasicHandle().StructToArray - var yyq2794 [4]bool - _, _, _ = yysep2794, yyq2794, yy2arr2794 - const yyr2794 bool = false - yyq2794[0] = x.Kind != "" - yyq2794[1] = x.APIVersion != "" - yyq2794[2] = true - var yynn2794 int - if yyr2794 || yy2arr2794 { + yysep2785 := !z.EncBinary() + yy2arr2785 := z.EncBasicHandle().StructToArray + var yyq2785 [4]bool + _, _, _ = yysep2785, yyq2785, yy2arr2785 + const yyr2785 bool = false + yyq2785[0] = x.Kind != "" + yyq2785[1] = x.APIVersion != "" + yyq2785[2] = true + var yynn2785 int + if yyr2785 || yy2arr2785 { r.EncodeArrayStart(4) } else { - yynn2794 = 1 - for _, b := range yyq2794 { + yynn2785 = 1 + for _, b := range yyq2785 { if b { - yynn2794++ + yynn2785++ } } - r.EncodeMapStart(yynn2794) - yynn2794 = 0 + r.EncodeMapStart(yynn2785) + yynn2785 = 0 } - if yyr2794 || yy2arr2794 { + if yyr2785 || yy2arr2785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2794[0] { - yym2796 := z.EncBinary() - _ = yym2796 + if yyq2785[0] { + yym2787 := z.EncBinary() + _ = yym2787 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -36074,23 +35992,23 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2794[0] { + if yyq2785[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2797 := z.EncBinary() - _ = yym2797 + yym2788 := z.EncBinary() + _ = yym2788 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2794 || yy2arr2794 { + if yyr2785 || yy2arr2785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2794[1] { - yym2799 := z.EncBinary() - _ = yym2799 + if yyq2785[1] { + yym2790 := z.EncBinary() + _ = yym2790 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -36099,42 +36017,42 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2794[1] { + if yyq2785[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2800 := z.EncBinary() - _ = yym2800 + yym2791 := z.EncBinary() + _ = yym2791 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2794 || yy2arr2794 { + if yyr2785 || yy2arr2785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2794[2] { - yy2802 := &x.ObjectMeta - yy2802.CodecEncodeSelf(e) + if yyq2785[2] { + yy2793 := &x.ObjectMeta + yy2793.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2794[2] { + if yyq2785[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2803 := &x.ObjectMeta - yy2803.CodecEncodeSelf(e) + yy2794 := &x.ObjectMeta + yy2794.CodecEncodeSelf(e) } } - if yyr2794 || yy2arr2794 { + if yyr2785 || yy2arr2785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Subsets == nil { r.EncodeNil() } else { - yym2805 := z.EncBinary() - _ = yym2805 + yym2796 := z.EncBinary() + _ = yym2796 if false { } else { h.encSliceEndpointSubset(([]EndpointSubset)(x.Subsets), e) @@ -36147,15 +36065,15 @@ func (x *Endpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x.Subsets == nil { r.EncodeNil() } else { - yym2806 := z.EncBinary() - _ = yym2806 + yym2797 := z.EncBinary() + _ = yym2797 if false { } else { h.encSliceEndpointSubset(([]EndpointSubset)(x.Subsets), e) } } } - if yyr2794 || yy2arr2794 { + if yyr2785 || yy2arr2785 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36168,25 +36086,25 @@ func (x *Endpoints) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2807 := z.DecBinary() - _ = yym2807 + yym2798 := z.DecBinary() + _ = yym2798 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2808 := r.ContainerType() - if yyct2808 == codecSelferValueTypeMap1234 { - yyl2808 := r.ReadMapStart() - if yyl2808 == 0 { + yyct2799 := r.ContainerType() + if yyct2799 == codecSelferValueTypeMap1234 { + yyl2799 := r.ReadMapStart() + if yyl2799 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2808, d) + x.codecDecodeSelfFromMap(yyl2799, d) } - } else if yyct2808 == codecSelferValueTypeArray1234 { - yyl2808 := r.ReadArrayStart() - if yyl2808 == 0 { + } else if yyct2799 == codecSelferValueTypeArray1234 { + yyl2799 := r.ReadArrayStart() + if yyl2799 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2808, d) + x.codecDecodeSelfFromArray(yyl2799, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36198,12 +36116,12 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2809Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2809Slc - var yyhl2809 bool = l >= 0 - for yyj2809 := 0; ; yyj2809++ { - if yyhl2809 { - if yyj2809 >= l { + var yys2800Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2800Slc + var yyhl2800 bool = l >= 0 + for yyj2800 := 0; ; yyj2800++ { + if yyhl2800 { + if yyj2800 >= l { break } } else { @@ -36212,10 +36130,10 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2809Slc = r.DecodeBytes(yys2809Slc, true, true) - yys2809 := string(yys2809Slc) + yys2800Slc = r.DecodeBytes(yys2800Slc, true, true) + yys2800 := string(yys2800Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2809 { + switch yys2800 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -36232,25 +36150,25 @@ func (x *Endpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2812 := &x.ObjectMeta - yyv2812.CodecDecodeSelf(d) + yyv2803 := &x.ObjectMeta + yyv2803.CodecDecodeSelf(d) } case "subsets": if r.TryDecodeAsNil() { x.Subsets = nil } else { - yyv2813 := &x.Subsets - yym2814 := z.DecBinary() - _ = yym2814 + yyv2804 := &x.Subsets + yym2805 := z.DecBinary() + _ = yym2805 if false { } else { - h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2813), d) + h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2804), d) } } default: - z.DecStructFieldNotFound(-1, yys2809) - } // end switch yys2809 - } // end for yyj2809 + z.DecStructFieldNotFound(-1, yys2800) + } // end switch yys2800 + } // end for yyj2800 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36258,16 +36176,16 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2815 int - var yyb2815 bool - var yyhl2815 bool = l >= 0 - yyj2815++ - if yyhl2815 { - yyb2815 = yyj2815 > l + var yyj2806 int + var yyb2806 bool + var yyhl2806 bool = l >= 0 + yyj2806++ + if yyhl2806 { + yyb2806 = yyj2806 > l } else { - yyb2815 = r.CheckBreak() + yyb2806 = r.CheckBreak() } - if yyb2815 { + if yyb2806 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36277,13 +36195,13 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2815++ - if yyhl2815 { - yyb2815 = yyj2815 > l + yyj2806++ + if yyhl2806 { + yyb2806 = yyj2806 > l } else { - yyb2815 = r.CheckBreak() + yyb2806 = r.CheckBreak() } - if yyb2815 { + if yyb2806 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36293,13 +36211,13 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2815++ - if yyhl2815 { - yyb2815 = yyj2815 > l + yyj2806++ + if yyhl2806 { + yyb2806 = yyj2806 > l } else { - yyb2815 = r.CheckBreak() + yyb2806 = r.CheckBreak() } - if yyb2815 { + if yyb2806 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36307,16 +36225,16 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv2818 := &x.ObjectMeta - yyv2818.CodecDecodeSelf(d) + yyv2809 := &x.ObjectMeta + yyv2809.CodecDecodeSelf(d) } - yyj2815++ - if yyhl2815 { - yyb2815 = yyj2815 > l + yyj2806++ + if yyhl2806 { + yyb2806 = yyj2806 > l } else { - yyb2815 = r.CheckBreak() + yyb2806 = r.CheckBreak() } - if yyb2815 { + if yyb2806 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36324,26 +36242,26 @@ func (x *Endpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Subsets = nil } else { - yyv2819 := &x.Subsets - yym2820 := z.DecBinary() - _ = yym2820 + yyv2810 := &x.Subsets + yym2811 := z.DecBinary() + _ = yym2811 if false { } else { - h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2819), d) + h.decSliceEndpointSubset((*[]EndpointSubset)(yyv2810), d) } } for { - yyj2815++ - if yyhl2815 { - yyb2815 = yyj2815 > l + yyj2806++ + if yyhl2806 { + yyb2806 = yyj2806 > l } else { - yyb2815 = r.CheckBreak() + yyb2806 = r.CheckBreak() } - if yyb2815 { + if yyb2806 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2815-1, "") + z.DecStructFieldNotFound(yyj2806-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36355,40 +36273,40 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2821 := z.EncBinary() - _ = yym2821 + yym2812 := z.EncBinary() + _ = yym2812 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2822 := !z.EncBinary() - yy2arr2822 := z.EncBasicHandle().StructToArray - var yyq2822 [3]bool - _, _, _ = yysep2822, yyq2822, yy2arr2822 - const yyr2822 bool = false - yyq2822[0] = len(x.Addresses) != 0 - yyq2822[1] = len(x.NotReadyAddresses) != 0 - yyq2822[2] = len(x.Ports) != 0 - var yynn2822 int - if yyr2822 || yy2arr2822 { + yysep2813 := !z.EncBinary() + yy2arr2813 := z.EncBasicHandle().StructToArray + var yyq2813 [3]bool + _, _, _ = yysep2813, yyq2813, yy2arr2813 + const yyr2813 bool = false + yyq2813[0] = len(x.Addresses) != 0 + yyq2813[1] = len(x.NotReadyAddresses) != 0 + yyq2813[2] = len(x.Ports) != 0 + var yynn2813 int + if yyr2813 || yy2arr2813 { r.EncodeArrayStart(3) } else { - yynn2822 = 0 - for _, b := range yyq2822 { + yynn2813 = 0 + for _, b := range yyq2813 { if b { - yynn2822++ + yynn2813++ } } - r.EncodeMapStart(yynn2822) - yynn2822 = 0 + r.EncodeMapStart(yynn2813) + yynn2813 = 0 } - if yyr2822 || yy2arr2822 { + if yyr2813 || yy2arr2813 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2822[0] { + if yyq2813[0] { if x.Addresses == nil { r.EncodeNil() } else { - yym2824 := z.EncBinary() - _ = yym2824 + yym2815 := z.EncBinary() + _ = yym2815 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.Addresses), e) @@ -36398,15 +36316,15 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2822[0] { + if yyq2813[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("addresses")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Addresses == nil { r.EncodeNil() } else { - yym2825 := z.EncBinary() - _ = yym2825 + yym2816 := z.EncBinary() + _ = yym2816 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.Addresses), e) @@ -36414,14 +36332,14 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2822 || yy2arr2822 { + if yyr2813 || yy2arr2813 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2822[1] { + if yyq2813[1] { if x.NotReadyAddresses == nil { r.EncodeNil() } else { - yym2827 := z.EncBinary() - _ = yym2827 + yym2818 := z.EncBinary() + _ = yym2818 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.NotReadyAddresses), e) @@ -36431,15 +36349,15 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2822[1] { + if yyq2813[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("notReadyAddresses")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.NotReadyAddresses == nil { r.EncodeNil() } else { - yym2828 := z.EncBinary() - _ = yym2828 + yym2819 := z.EncBinary() + _ = yym2819 if false { } else { h.encSliceEndpointAddress(([]EndpointAddress)(x.NotReadyAddresses), e) @@ -36447,14 +36365,14 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2822 || yy2arr2822 { + if yyr2813 || yy2arr2813 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2822[2] { + if yyq2813[2] { if x.Ports == nil { r.EncodeNil() } else { - yym2830 := z.EncBinary() - _ = yym2830 + yym2821 := z.EncBinary() + _ = yym2821 if false { } else { h.encSliceEndpointPort(([]EndpointPort)(x.Ports), e) @@ -36464,15 +36382,15 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2822[2] { + if yyq2813[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ports")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ports == nil { r.EncodeNil() } else { - yym2831 := z.EncBinary() - _ = yym2831 + yym2822 := z.EncBinary() + _ = yym2822 if false { } else { h.encSliceEndpointPort(([]EndpointPort)(x.Ports), e) @@ -36480,7 +36398,7 @@ func (x *EndpointSubset) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2822 || yy2arr2822 { + if yyr2813 || yy2arr2813 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36493,25 +36411,25 @@ func (x *EndpointSubset) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2832 := z.DecBinary() - _ = yym2832 + yym2823 := z.DecBinary() + _ = yym2823 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2833 := r.ContainerType() - if yyct2833 == codecSelferValueTypeMap1234 { - yyl2833 := r.ReadMapStart() - if yyl2833 == 0 { + yyct2824 := r.ContainerType() + if yyct2824 == codecSelferValueTypeMap1234 { + yyl2824 := r.ReadMapStart() + if yyl2824 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2833, d) + x.codecDecodeSelfFromMap(yyl2824, d) } - } else if yyct2833 == codecSelferValueTypeArray1234 { - yyl2833 := r.ReadArrayStart() - if yyl2833 == 0 { + } else if yyct2824 == codecSelferValueTypeArray1234 { + yyl2824 := r.ReadArrayStart() + if yyl2824 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2833, d) + x.codecDecodeSelfFromArray(yyl2824, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36523,12 +36441,12 @@ func (x *EndpointSubset) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2834Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2834Slc - var yyhl2834 bool = l >= 0 - for yyj2834 := 0; ; yyj2834++ { - if yyhl2834 { - if yyj2834 >= l { + var yys2825Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2825Slc + var yyhl2825 bool = l >= 0 + for yyj2825 := 0; ; yyj2825++ { + if yyhl2825 { + if yyj2825 >= l { break } } else { @@ -36537,50 +36455,50 @@ func (x *EndpointSubset) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2834Slc = r.DecodeBytes(yys2834Slc, true, true) - yys2834 := string(yys2834Slc) + yys2825Slc = r.DecodeBytes(yys2825Slc, true, true) + yys2825 := string(yys2825Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2834 { + switch yys2825 { case "addresses": if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv2835 := &x.Addresses - yym2836 := z.DecBinary() - _ = yym2836 + yyv2826 := &x.Addresses + yym2827 := z.DecBinary() + _ = yym2827 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2835), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2826), d) } } case "notReadyAddresses": if r.TryDecodeAsNil() { x.NotReadyAddresses = nil } else { - yyv2837 := &x.NotReadyAddresses - yym2838 := z.DecBinary() - _ = yym2838 + yyv2828 := &x.NotReadyAddresses + yym2829 := z.DecBinary() + _ = yym2829 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2837), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2828), d) } } case "ports": if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2839 := &x.Ports - yym2840 := z.DecBinary() - _ = yym2840 + yyv2830 := &x.Ports + yym2831 := z.DecBinary() + _ = yym2831 if false { } else { - h.decSliceEndpointPort((*[]EndpointPort)(yyv2839), d) + h.decSliceEndpointPort((*[]EndpointPort)(yyv2830), d) } } default: - z.DecStructFieldNotFound(-1, yys2834) - } // end switch yys2834 - } // end for yyj2834 + z.DecStructFieldNotFound(-1, yys2825) + } // end switch yys2825 + } // end for yyj2825 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36588,16 +36506,16 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2841 int - var yyb2841 bool - var yyhl2841 bool = l >= 0 - yyj2841++ - if yyhl2841 { - yyb2841 = yyj2841 > l + var yyj2832 int + var yyb2832 bool + var yyhl2832 bool = l >= 0 + yyj2832++ + if yyhl2832 { + yyb2832 = yyj2832 > l } else { - yyb2841 = r.CheckBreak() + yyb2832 = r.CheckBreak() } - if yyb2841 { + if yyb2832 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36605,21 +36523,21 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv2842 := &x.Addresses - yym2843 := z.DecBinary() - _ = yym2843 + yyv2833 := &x.Addresses + yym2834 := z.DecBinary() + _ = yym2834 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2842), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2833), d) } } - yyj2841++ - if yyhl2841 { - yyb2841 = yyj2841 > l + yyj2832++ + if yyhl2832 { + yyb2832 = yyj2832 > l } else { - yyb2841 = r.CheckBreak() + yyb2832 = r.CheckBreak() } - if yyb2841 { + if yyb2832 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36627,21 +36545,21 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.NotReadyAddresses = nil } else { - yyv2844 := &x.NotReadyAddresses - yym2845 := z.DecBinary() - _ = yym2845 + yyv2835 := &x.NotReadyAddresses + yym2836 := z.DecBinary() + _ = yym2836 if false { } else { - h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2844), d) + h.decSliceEndpointAddress((*[]EndpointAddress)(yyv2835), d) } } - yyj2841++ - if yyhl2841 { - yyb2841 = yyj2841 > l + yyj2832++ + if yyhl2832 { + yyb2832 = yyj2832 > l } else { - yyb2841 = r.CheckBreak() + yyb2832 = r.CheckBreak() } - if yyb2841 { + if yyb2832 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36649,26 +36567,26 @@ func (x *EndpointSubset) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv2846 := &x.Ports - yym2847 := z.DecBinary() - _ = yym2847 + yyv2837 := &x.Ports + yym2838 := z.DecBinary() + _ = yym2838 if false { } else { - h.decSliceEndpointPort((*[]EndpointPort)(yyv2846), d) + h.decSliceEndpointPort((*[]EndpointPort)(yyv2837), d) } } for { - yyj2841++ - if yyhl2841 { - yyb2841 = yyj2841 > l + yyj2832++ + if yyhl2832 { + yyb2832 = yyj2832 > l } else { - yyb2841 = r.CheckBreak() + yyb2832 = r.CheckBreak() } - if yyb2841 { + if yyb2832 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2841-1, "") + z.DecStructFieldNotFound(yyj2832-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -36680,36 +36598,36 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2848 := z.EncBinary() - _ = yym2848 + yym2839 := z.EncBinary() + _ = yym2839 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2849 := !z.EncBinary() - yy2arr2849 := z.EncBasicHandle().StructToArray - var yyq2849 [4]bool - _, _, _ = yysep2849, yyq2849, yy2arr2849 - const yyr2849 bool = false - yyq2849[1] = x.Hostname != "" - yyq2849[2] = x.NodeName != nil - yyq2849[3] = x.TargetRef != nil - var yynn2849 int - if yyr2849 || yy2arr2849 { + yysep2840 := !z.EncBinary() + yy2arr2840 := z.EncBasicHandle().StructToArray + var yyq2840 [4]bool + _, _, _ = yysep2840, yyq2840, yy2arr2840 + const yyr2840 bool = false + yyq2840[1] = x.Hostname != "" + yyq2840[2] = x.NodeName != nil + yyq2840[3] = x.TargetRef != nil + var yynn2840 int + if yyr2840 || yy2arr2840 { r.EncodeArrayStart(4) } else { - yynn2849 = 1 - for _, b := range yyq2849 { + yynn2840 = 1 + for _, b := range yyq2840 { if b { - yynn2849++ + yynn2840++ } } - r.EncodeMapStart(yynn2849) - yynn2849 = 0 + r.EncodeMapStart(yynn2840) + yynn2840 = 0 } - if yyr2849 || yy2arr2849 { + if yyr2840 || yy2arr2840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2851 := z.EncBinary() - _ = yym2851 + yym2842 := z.EncBinary() + _ = yym2842 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) @@ -36718,18 +36636,18 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ip")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2852 := z.EncBinary() - _ = yym2852 + yym2843 := z.EncBinary() + _ = yym2843 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.IP)) } } - if yyr2849 || yy2arr2849 { + if yyr2840 || yy2arr2840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2849[1] { - yym2854 := z.EncBinary() - _ = yym2854 + if yyq2840[1] { + yym2845 := z.EncBinary() + _ = yym2845 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) @@ -36738,56 +36656,56 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2849[1] { + if yyq2840[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostname")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2855 := z.EncBinary() - _ = yym2855 + yym2846 := z.EncBinary() + _ = yym2846 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Hostname)) } } } - if yyr2849 || yy2arr2849 { + if yyr2840 || yy2arr2840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2849[2] { + if yyq2840[2] { if x.NodeName == nil { r.EncodeNil() } else { - yy2857 := *x.NodeName - yym2858 := z.EncBinary() - _ = yym2858 + yy2848 := *x.NodeName + yym2849 := z.EncBinary() + _ = yym2849 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy2857)) + r.EncodeString(codecSelferC_UTF81234, string(yy2848)) } } } else { r.EncodeNil() } } else { - if yyq2849[2] { + if yyq2840[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodeName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.NodeName == nil { r.EncodeNil() } else { - yy2859 := *x.NodeName - yym2860 := z.EncBinary() - _ = yym2860 + yy2850 := *x.NodeName + yym2851 := z.EncBinary() + _ = yym2851 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy2859)) + r.EncodeString(codecSelferC_UTF81234, string(yy2850)) } } } } - if yyr2849 || yy2arr2849 { + if yyr2840 || yy2arr2840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2849[3] { + if yyq2840[3] { if x.TargetRef == nil { r.EncodeNil() } else { @@ -36797,7 +36715,7 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq2849[3] { + if yyq2840[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("targetRef")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -36808,7 +36726,7 @@ func (x *EndpointAddress) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr2849 || yy2arr2849 { + if yyr2840 || yy2arr2840 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -36821,25 +36739,25 @@ func (x *EndpointAddress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2862 := z.DecBinary() - _ = yym2862 + yym2853 := z.DecBinary() + _ = yym2853 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2863 := r.ContainerType() - if yyct2863 == codecSelferValueTypeMap1234 { - yyl2863 := r.ReadMapStart() - if yyl2863 == 0 { + yyct2854 := r.ContainerType() + if yyct2854 == codecSelferValueTypeMap1234 { + yyl2854 := r.ReadMapStart() + if yyl2854 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2863, d) + x.codecDecodeSelfFromMap(yyl2854, d) } - } else if yyct2863 == codecSelferValueTypeArray1234 { - yyl2863 := r.ReadArrayStart() - if yyl2863 == 0 { + } else if yyct2854 == codecSelferValueTypeArray1234 { + yyl2854 := r.ReadArrayStart() + if yyl2854 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2863, d) + x.codecDecodeSelfFromArray(yyl2854, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -36851,12 +36769,12 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2864Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2864Slc - var yyhl2864 bool = l >= 0 - for yyj2864 := 0; ; yyj2864++ { - if yyhl2864 { - if yyj2864 >= l { + var yys2855Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2855Slc + var yyhl2855 bool = l >= 0 + for yyj2855 := 0; ; yyj2855++ { + if yyhl2855 { + if yyj2855 >= l { break } } else { @@ -36865,10 +36783,10 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2864Slc = r.DecodeBytes(yys2864Slc, true, true) - yys2864 := string(yys2864Slc) + yys2855Slc = r.DecodeBytes(yys2855Slc, true, true) + yys2855 := string(yys2855Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2864 { + switch yys2855 { case "ip": if r.TryDecodeAsNil() { x.IP = "" @@ -36890,8 +36808,8 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.NodeName == nil { x.NodeName = new(string) } - yym2868 := z.DecBinary() - _ = yym2868 + yym2859 := z.DecBinary() + _ = yym2859 if false { } else { *((*string)(x.NodeName)) = r.DecodeString() @@ -36909,9 +36827,9 @@ func (x *EndpointAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.TargetRef.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2864) - } // end switch yys2864 - } // end for yyj2864 + z.DecStructFieldNotFound(-1, yys2855) + } // end switch yys2855 + } // end for yyj2855 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -36919,16 +36837,16 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2870 int - var yyb2870 bool - var yyhl2870 bool = l >= 0 - yyj2870++ - if yyhl2870 { - yyb2870 = yyj2870 > l + var yyj2861 int + var yyb2861 bool + var yyhl2861 bool = l >= 0 + yyj2861++ + if yyhl2861 { + yyb2861 = yyj2861 > l } else { - yyb2870 = r.CheckBreak() + yyb2861 = r.CheckBreak() } - if yyb2870 { + if yyb2861 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36938,13 +36856,13 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.IP = string(r.DecodeString()) } - yyj2870++ - if yyhl2870 { - yyb2870 = yyj2870 > l + yyj2861++ + if yyhl2861 { + yyb2861 = yyj2861 > l } else { - yyb2870 = r.CheckBreak() + yyb2861 = r.CheckBreak() } - if yyb2870 { + if yyb2861 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36954,13 +36872,13 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Hostname = string(r.DecodeString()) } - yyj2870++ - if yyhl2870 { - yyb2870 = yyj2870 > l + yyj2861++ + if yyhl2861 { + yyb2861 = yyj2861 > l } else { - yyb2870 = r.CheckBreak() + yyb2861 = r.CheckBreak() } - if yyb2870 { + if yyb2861 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -36973,20 +36891,20 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.NodeName == nil { x.NodeName = new(string) } - yym2874 := z.DecBinary() - _ = yym2874 + yym2865 := z.DecBinary() + _ = yym2865 if false { } else { *((*string)(x.NodeName)) = r.DecodeString() } } - yyj2870++ - if yyhl2870 { - yyb2870 = yyj2870 > l + yyj2861++ + if yyhl2861 { + yyb2861 = yyj2861 > l } else { - yyb2870 = r.CheckBreak() + yyb2861 = r.CheckBreak() } - if yyb2870 { + if yyb2861 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37002,17 +36920,17 @@ func (x *EndpointAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.TargetRef.CodecDecodeSelf(d) } for { - yyj2870++ - if yyhl2870 { - yyb2870 = yyj2870 > l + yyj2861++ + if yyhl2861 { + yyb2861 = yyj2861 > l } else { - yyb2870 = r.CheckBreak() + yyb2861 = r.CheckBreak() } - if yyb2870 { + if yyb2861 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2870-1, "") + z.DecStructFieldNotFound(yyj2861-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37024,36 +36942,36 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2876 := z.EncBinary() - _ = yym2876 + yym2867 := z.EncBinary() + _ = yym2867 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2877 := !z.EncBinary() - yy2arr2877 := z.EncBasicHandle().StructToArray - var yyq2877 [3]bool - _, _, _ = yysep2877, yyq2877, yy2arr2877 - const yyr2877 bool = false - yyq2877[0] = x.Name != "" - yyq2877[2] = x.Protocol != "" - var yynn2877 int - if yyr2877 || yy2arr2877 { + yysep2868 := !z.EncBinary() + yy2arr2868 := z.EncBasicHandle().StructToArray + var yyq2868 [3]bool + _, _, _ = yysep2868, yyq2868, yy2arr2868 + const yyr2868 bool = false + yyq2868[0] = x.Name != "" + yyq2868[2] = x.Protocol != "" + var yynn2868 int + if yyr2868 || yy2arr2868 { r.EncodeArrayStart(3) } else { - yynn2877 = 1 - for _, b := range yyq2877 { + yynn2868 = 1 + for _, b := range yyq2868 { if b { - yynn2877++ + yynn2868++ } } - r.EncodeMapStart(yynn2877) - yynn2877 = 0 + r.EncodeMapStart(yynn2868) + yynn2868 = 0 } - if yyr2877 || yy2arr2877 { + if yyr2868 || yy2arr2868 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2877[0] { - yym2879 := z.EncBinary() - _ = yym2879 + if yyq2868[0] { + yym2870 := z.EncBinary() + _ = yym2870 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -37062,22 +36980,22 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2877[0] { + if yyq2868[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2880 := z.EncBinary() - _ = yym2880 + yym2871 := z.EncBinary() + _ = yym2871 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } } - if yyr2877 || yy2arr2877 { + if yyr2868 || yy2arr2868 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2882 := z.EncBinary() - _ = yym2882 + yym2873 := z.EncBinary() + _ = yym2873 if false { } else { r.EncodeInt(int64(x.Port)) @@ -37086,29 +37004,29 @@ func (x *EndpointPort) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2883 := z.EncBinary() - _ = yym2883 + yym2874 := z.EncBinary() + _ = yym2874 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr2877 || yy2arr2877 { + if yyr2868 || yy2arr2868 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2877[2] { + if yyq2868[2] { x.Protocol.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2877[2] { + if yyq2868[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("protocol")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Protocol.CodecEncodeSelf(e) } } - if yyr2877 || yy2arr2877 { + if yyr2868 || yy2arr2868 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37121,25 +37039,25 @@ func (x *EndpointPort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2885 := z.DecBinary() - _ = yym2885 + yym2876 := z.DecBinary() + _ = yym2876 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2886 := r.ContainerType() - if yyct2886 == codecSelferValueTypeMap1234 { - yyl2886 := r.ReadMapStart() - if yyl2886 == 0 { + yyct2877 := r.ContainerType() + if yyct2877 == codecSelferValueTypeMap1234 { + yyl2877 := r.ReadMapStart() + if yyl2877 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2886, d) + x.codecDecodeSelfFromMap(yyl2877, d) } - } else if yyct2886 == codecSelferValueTypeArray1234 { - yyl2886 := r.ReadArrayStart() - if yyl2886 == 0 { + } else if yyct2877 == codecSelferValueTypeArray1234 { + yyl2877 := r.ReadArrayStart() + if yyl2877 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2886, d) + x.codecDecodeSelfFromArray(yyl2877, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37151,12 +37069,12 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2887Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2887Slc - var yyhl2887 bool = l >= 0 - for yyj2887 := 0; ; yyj2887++ { - if yyhl2887 { - if yyj2887 >= l { + var yys2878Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2878Slc + var yyhl2878 bool = l >= 0 + for yyj2878 := 0; ; yyj2878++ { + if yyhl2878 { + if yyj2878 >= l { break } } else { @@ -37165,10 +37083,10 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2887Slc = r.DecodeBytes(yys2887Slc, true, true) - yys2887 := string(yys2887Slc) + yys2878Slc = r.DecodeBytes(yys2878Slc, true, true) + yys2878 := string(yys2878Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2887 { + switch yys2878 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -37188,9 +37106,9 @@ func (x *EndpointPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Protocol = Protocol(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys2887) - } // end switch yys2887 - } // end for yyj2887 + z.DecStructFieldNotFound(-1, yys2878) + } // end switch yys2878 + } // end for yyj2878 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37198,16 +37116,16 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2891 int - var yyb2891 bool - var yyhl2891 bool = l >= 0 - yyj2891++ - if yyhl2891 { - yyb2891 = yyj2891 > l + var yyj2882 int + var yyb2882 bool + var yyhl2882 bool = l >= 0 + yyj2882++ + if yyhl2882 { + yyb2882 = yyj2882 > l } else { - yyb2891 = r.CheckBreak() + yyb2882 = r.CheckBreak() } - if yyb2891 { + if yyb2882 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37217,13 +37135,13 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj2891++ - if yyhl2891 { - yyb2891 = yyj2891 > l + yyj2882++ + if yyhl2882 { + yyb2882 = yyj2882 > l } else { - yyb2891 = r.CheckBreak() + yyb2882 = r.CheckBreak() } - if yyb2891 { + if yyb2882 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37233,13 +37151,13 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Port = int32(r.DecodeInt(32)) } - yyj2891++ - if yyhl2891 { - yyb2891 = yyj2891 > l + yyj2882++ + if yyhl2882 { + yyb2882 = yyj2882 > l } else { - yyb2891 = r.CheckBreak() + yyb2882 = r.CheckBreak() } - if yyb2891 { + if yyb2882 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37250,17 +37168,17 @@ func (x *EndpointPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Protocol = Protocol(r.DecodeString()) } for { - yyj2891++ - if yyhl2891 { - yyb2891 = yyj2891 > l + yyj2882++ + if yyhl2882 { + yyb2882 = yyj2882 > l } else { - yyb2891 = r.CheckBreak() + yyb2882 = r.CheckBreak() } - if yyb2891 { + if yyb2882 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2891-1, "") + z.DecStructFieldNotFound(yyj2882-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37272,37 +37190,37 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2895 := z.EncBinary() - _ = yym2895 + yym2886 := z.EncBinary() + _ = yym2886 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2896 := !z.EncBinary() - yy2arr2896 := z.EncBasicHandle().StructToArray - var yyq2896 [4]bool - _, _, _ = yysep2896, yyq2896, yy2arr2896 - const yyr2896 bool = false - yyq2896[0] = x.Kind != "" - yyq2896[1] = x.APIVersion != "" - yyq2896[2] = true - var yynn2896 int - if yyr2896 || yy2arr2896 { + yysep2887 := !z.EncBinary() + yy2arr2887 := z.EncBasicHandle().StructToArray + var yyq2887 [4]bool + _, _, _ = yysep2887, yyq2887, yy2arr2887 + const yyr2887 bool = false + yyq2887[0] = x.Kind != "" + yyq2887[1] = x.APIVersion != "" + yyq2887[2] = true + var yynn2887 int + if yyr2887 || yy2arr2887 { r.EncodeArrayStart(4) } else { - yynn2896 = 1 - for _, b := range yyq2896 { + yynn2887 = 1 + for _, b := range yyq2887 { if b { - yynn2896++ + yynn2887++ } } - r.EncodeMapStart(yynn2896) - yynn2896 = 0 + r.EncodeMapStart(yynn2887) + yynn2887 = 0 } - if yyr2896 || yy2arr2896 { + if yyr2887 || yy2arr2887 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2896[0] { - yym2898 := z.EncBinary() - _ = yym2898 + if yyq2887[0] { + yym2889 := z.EncBinary() + _ = yym2889 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -37311,23 +37229,23 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2896[0] { + if yyq2887[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2899 := z.EncBinary() - _ = yym2899 + yym2890 := z.EncBinary() + _ = yym2890 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr2896 || yy2arr2896 { + if yyr2887 || yy2arr2887 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2896[1] { - yym2901 := z.EncBinary() - _ = yym2901 + if yyq2887[1] { + yym2892 := z.EncBinary() + _ = yym2892 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -37336,54 +37254,54 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2896[1] { + if yyq2887[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2902 := z.EncBinary() - _ = yym2902 + yym2893 := z.EncBinary() + _ = yym2893 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr2896 || yy2arr2896 { + if yyr2887 || yy2arr2887 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2896[2] { - yy2904 := &x.ListMeta - yym2905 := z.EncBinary() - _ = yym2905 + if yyq2887[2] { + yy2895 := &x.ListMeta + yym2896 := z.EncBinary() + _ = yym2896 if false { - } else if z.HasExtensions() && z.EncExt(yy2904) { + } else if z.HasExtensions() && z.EncExt(yy2895) { } else { - z.EncFallback(yy2904) + z.EncFallback(yy2895) } } else { r.EncodeNil() } } else { - if yyq2896[2] { + if yyq2887[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2906 := &x.ListMeta - yym2907 := z.EncBinary() - _ = yym2907 + yy2897 := &x.ListMeta + yym2898 := z.EncBinary() + _ = yym2898 if false { - } else if z.HasExtensions() && z.EncExt(yy2906) { + } else if z.HasExtensions() && z.EncExt(yy2897) { } else { - z.EncFallback(yy2906) + z.EncFallback(yy2897) } } } - if yyr2896 || yy2arr2896 { + if yyr2887 || yy2arr2887 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym2909 := z.EncBinary() - _ = yym2909 + yym2900 := z.EncBinary() + _ = yym2900 if false { } else { h.encSliceEndpoints(([]Endpoints)(x.Items), e) @@ -37396,15 +37314,15 @@ func (x *EndpointsList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym2910 := z.EncBinary() - _ = yym2910 + yym2901 := z.EncBinary() + _ = yym2901 if false { } else { h.encSliceEndpoints(([]Endpoints)(x.Items), e) } } } - if yyr2896 || yy2arr2896 { + if yyr2887 || yy2arr2887 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37417,25 +37335,25 @@ func (x *EndpointsList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2911 := z.DecBinary() - _ = yym2911 + yym2902 := z.DecBinary() + _ = yym2902 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2912 := r.ContainerType() - if yyct2912 == codecSelferValueTypeMap1234 { - yyl2912 := r.ReadMapStart() - if yyl2912 == 0 { + yyct2903 := r.ContainerType() + if yyct2903 == codecSelferValueTypeMap1234 { + yyl2903 := r.ReadMapStart() + if yyl2903 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2912, d) + x.codecDecodeSelfFromMap(yyl2903, d) } - } else if yyct2912 == codecSelferValueTypeArray1234 { - yyl2912 := r.ReadArrayStart() - if yyl2912 == 0 { + } else if yyct2903 == codecSelferValueTypeArray1234 { + yyl2903 := r.ReadArrayStart() + if yyl2903 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2912, d) + x.codecDecodeSelfFromArray(yyl2903, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37447,12 +37365,12 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2913Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2913Slc - var yyhl2913 bool = l >= 0 - for yyj2913 := 0; ; yyj2913++ { - if yyhl2913 { - if yyj2913 >= l { + var yys2904Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2904Slc + var yyhl2904 bool = l >= 0 + for yyj2904 := 0; ; yyj2904++ { + if yyhl2904 { + if yyj2904 >= l { break } } else { @@ -37461,10 +37379,10 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2913Slc = r.DecodeBytes(yys2913Slc, true, true) - yys2913 := string(yys2913Slc) + yys2904Slc = r.DecodeBytes(yys2904Slc, true, true) + yys2904 := string(yys2904Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2913 { + switch yys2904 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -37481,31 +37399,31 @@ func (x *EndpointsList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2916 := &x.ListMeta - yym2917 := z.DecBinary() - _ = yym2917 + yyv2907 := &x.ListMeta + yym2908 := z.DecBinary() + _ = yym2908 if false { - } else if z.HasExtensions() && z.DecExt(yyv2916) { + } else if z.HasExtensions() && z.DecExt(yyv2907) { } else { - z.DecFallback(yyv2916, false) + z.DecFallback(yyv2907, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2918 := &x.Items - yym2919 := z.DecBinary() - _ = yym2919 + yyv2909 := &x.Items + yym2910 := z.DecBinary() + _ = yym2910 if false { } else { - h.decSliceEndpoints((*[]Endpoints)(yyv2918), d) + h.decSliceEndpoints((*[]Endpoints)(yyv2909), d) } } default: - z.DecStructFieldNotFound(-1, yys2913) - } // end switch yys2913 - } // end for yyj2913 + z.DecStructFieldNotFound(-1, yys2904) + } // end switch yys2904 + } // end for yyj2904 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37513,16 +37431,16 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2920 int - var yyb2920 bool - var yyhl2920 bool = l >= 0 - yyj2920++ - if yyhl2920 { - yyb2920 = yyj2920 > l + var yyj2911 int + var yyb2911 bool + var yyhl2911 bool = l >= 0 + yyj2911++ + if yyhl2911 { + yyb2911 = yyj2911 > l } else { - yyb2920 = r.CheckBreak() + yyb2911 = r.CheckBreak() } - if yyb2920 { + if yyb2911 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37532,13 +37450,13 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj2920++ - if yyhl2920 { - yyb2920 = yyj2920 > l + yyj2911++ + if yyhl2911 { + yyb2911 = yyj2911 > l } else { - yyb2920 = r.CheckBreak() + yyb2911 = r.CheckBreak() } - if yyb2920 { + if yyb2911 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37548,13 +37466,13 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj2920++ - if yyhl2920 { - yyb2920 = yyj2920 > l + yyj2911++ + if yyhl2911 { + yyb2911 = yyj2911 > l } else { - yyb2920 = r.CheckBreak() + yyb2911 = r.CheckBreak() } - if yyb2920 { + if yyb2911 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37562,22 +37480,22 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv2923 := &x.ListMeta - yym2924 := z.DecBinary() - _ = yym2924 + yyv2914 := &x.ListMeta + yym2915 := z.DecBinary() + _ = yym2915 if false { - } else if z.HasExtensions() && z.DecExt(yyv2923) { + } else if z.HasExtensions() && z.DecExt(yyv2914) { } else { - z.DecFallback(yyv2923, false) + z.DecFallback(yyv2914, false) } } - yyj2920++ - if yyhl2920 { - yyb2920 = yyj2920 > l + yyj2911++ + if yyhl2911 { + yyb2911 = yyj2911 > l } else { - yyb2920 = r.CheckBreak() + yyb2911 = r.CheckBreak() } - if yyb2920 { + if yyb2911 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37585,26 +37503,26 @@ func (x *EndpointsList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv2925 := &x.Items - yym2926 := z.DecBinary() - _ = yym2926 + yyv2916 := &x.Items + yym2917 := z.DecBinary() + _ = yym2917 if false { } else { - h.decSliceEndpoints((*[]Endpoints)(yyv2925), d) + h.decSliceEndpoints((*[]Endpoints)(yyv2916), d) } } for { - yyj2920++ - if yyhl2920 { - yyb2920 = yyj2920 > l + yyj2911++ + if yyhl2911 { + yyb2911 = yyj2911 > l } else { - yyb2920 = r.CheckBreak() + yyb2911 = r.CheckBreak() } - if yyb2920 { + if yyb2911 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2920-1, "") + z.DecStructFieldNotFound(yyj2911-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37616,38 +37534,38 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2927 := z.EncBinary() - _ = yym2927 + yym2918 := z.EncBinary() + _ = yym2918 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2928 := !z.EncBinary() - yy2arr2928 := z.EncBasicHandle().StructToArray - var yyq2928 [4]bool - _, _, _ = yysep2928, yyq2928, yy2arr2928 - const yyr2928 bool = false - yyq2928[0] = x.PodCIDR != "" - yyq2928[1] = x.ExternalID != "" - yyq2928[2] = x.ProviderID != "" - yyq2928[3] = x.Unschedulable != false - var yynn2928 int - if yyr2928 || yy2arr2928 { + yysep2919 := !z.EncBinary() + yy2arr2919 := z.EncBasicHandle().StructToArray + var yyq2919 [4]bool + _, _, _ = yysep2919, yyq2919, yy2arr2919 + const yyr2919 bool = false + yyq2919[0] = x.PodCIDR != "" + yyq2919[1] = x.ExternalID != "" + yyq2919[2] = x.ProviderID != "" + yyq2919[3] = x.Unschedulable != false + var yynn2919 int + if yyr2919 || yy2arr2919 { r.EncodeArrayStart(4) } else { - yynn2928 = 0 - for _, b := range yyq2928 { + yynn2919 = 0 + for _, b := range yyq2919 { if b { - yynn2928++ + yynn2919++ } } - r.EncodeMapStart(yynn2928) - yynn2928 = 0 + r.EncodeMapStart(yynn2919) + yynn2919 = 0 } - if yyr2928 || yy2arr2928 { + if yyr2919 || yy2arr2919 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2928[0] { - yym2930 := z.EncBinary() - _ = yym2930 + if yyq2919[0] { + yym2921 := z.EncBinary() + _ = yym2921 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) @@ -37656,23 +37574,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2928[0] { + if yyq2919[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podCIDR")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2931 := z.EncBinary() - _ = yym2931 + yym2922 := z.EncBinary() + _ = yym2922 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) } } } - if yyr2928 || yy2arr2928 { + if yyr2919 || yy2arr2919 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2928[1] { - yym2933 := z.EncBinary() - _ = yym2933 + if yyq2919[1] { + yym2924 := z.EncBinary() + _ = yym2924 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalID)) @@ -37681,23 +37599,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2928[1] { + if yyq2919[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("externalID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2934 := z.EncBinary() - _ = yym2934 + yym2925 := z.EncBinary() + _ = yym2925 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ExternalID)) } } } - if yyr2928 || yy2arr2928 { + if yyr2919 || yy2arr2919 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2928[2] { - yym2936 := z.EncBinary() - _ = yym2936 + if yyq2919[2] { + yym2927 := z.EncBinary() + _ = yym2927 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ProviderID)) @@ -37706,23 +37624,23 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq2928[2] { + if yyq2919[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("providerID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2937 := z.EncBinary() - _ = yym2937 + yym2928 := z.EncBinary() + _ = yym2928 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ProviderID)) } } } - if yyr2928 || yy2arr2928 { + if yyr2919 || yy2arr2919 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2928[3] { - yym2939 := z.EncBinary() - _ = yym2939 + if yyq2919[3] { + yym2930 := z.EncBinary() + _ = yym2930 if false { } else { r.EncodeBool(bool(x.Unschedulable)) @@ -37731,19 +37649,19 @@ func (x *NodeSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq2928[3] { + if yyq2919[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("unschedulable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2940 := z.EncBinary() - _ = yym2940 + yym2931 := z.EncBinary() + _ = yym2931 if false { } else { r.EncodeBool(bool(x.Unschedulable)) } } } - if yyr2928 || yy2arr2928 { + if yyr2919 || yy2arr2919 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37756,25 +37674,25 @@ func (x *NodeSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2941 := z.DecBinary() - _ = yym2941 + yym2932 := z.DecBinary() + _ = yym2932 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2942 := r.ContainerType() - if yyct2942 == codecSelferValueTypeMap1234 { - yyl2942 := r.ReadMapStart() - if yyl2942 == 0 { + yyct2933 := r.ContainerType() + if yyct2933 == codecSelferValueTypeMap1234 { + yyl2933 := r.ReadMapStart() + if yyl2933 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2942, d) + x.codecDecodeSelfFromMap(yyl2933, d) } - } else if yyct2942 == codecSelferValueTypeArray1234 { - yyl2942 := r.ReadArrayStart() - if yyl2942 == 0 { + } else if yyct2933 == codecSelferValueTypeArray1234 { + yyl2933 := r.ReadArrayStart() + if yyl2933 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2942, d) + x.codecDecodeSelfFromArray(yyl2933, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -37786,12 +37704,12 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2943Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2943Slc - var yyhl2943 bool = l >= 0 - for yyj2943 := 0; ; yyj2943++ { - if yyhl2943 { - if yyj2943 >= l { + var yys2934Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2934Slc + var yyhl2934 bool = l >= 0 + for yyj2934 := 0; ; yyj2934++ { + if yyhl2934 { + if yyj2934 >= l { break } } else { @@ -37800,10 +37718,10 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2943Slc = r.DecodeBytes(yys2943Slc, true, true) - yys2943 := string(yys2943Slc) + yys2934Slc = r.DecodeBytes(yys2934Slc, true, true) + yys2934 := string(yys2934Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2943 { + switch yys2934 { case "podCIDR": if r.TryDecodeAsNil() { x.PodCIDR = "" @@ -37829,9 +37747,9 @@ func (x *NodeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Unschedulable = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys2943) - } // end switch yys2943 - } // end for yyj2943 + z.DecStructFieldNotFound(-1, yys2934) + } // end switch yys2934 + } // end for yyj2934 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -37839,16 +37757,16 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2948 int - var yyb2948 bool - var yyhl2948 bool = l >= 0 - yyj2948++ - if yyhl2948 { - yyb2948 = yyj2948 > l + var yyj2939 int + var yyb2939 bool + var yyhl2939 bool = l >= 0 + yyj2939++ + if yyhl2939 { + yyb2939 = yyj2939 > l } else { - yyb2948 = r.CheckBreak() + yyb2939 = r.CheckBreak() } - if yyb2948 { + if yyb2939 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37858,13 +37776,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.PodCIDR = string(r.DecodeString()) } - yyj2948++ - if yyhl2948 { - yyb2948 = yyj2948 > l + yyj2939++ + if yyhl2939 { + yyb2939 = yyj2939 > l } else { - yyb2948 = r.CheckBreak() + yyb2939 = r.CheckBreak() } - if yyb2948 { + if yyb2939 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37874,13 +37792,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ExternalID = string(r.DecodeString()) } - yyj2948++ - if yyhl2948 { - yyb2948 = yyj2948 > l + yyj2939++ + if yyhl2939 { + yyb2939 = yyj2939 > l } else { - yyb2948 = r.CheckBreak() + yyb2939 = r.CheckBreak() } - if yyb2948 { + if yyb2939 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37890,13 +37808,13 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ProviderID = string(r.DecodeString()) } - yyj2948++ - if yyhl2948 { - yyb2948 = yyj2948 > l + yyj2939++ + if yyhl2939 { + yyb2939 = yyj2939 > l } else { - yyb2948 = r.CheckBreak() + yyb2939 = r.CheckBreak() } - if yyb2948 { + if yyb2939 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -37907,17 +37825,17 @@ func (x *NodeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Unschedulable = bool(r.DecodeBool()) } for { - yyj2948++ - if yyhl2948 { - yyb2948 = yyj2948 > l + yyj2939++ + if yyhl2939 { + yyb2939 = yyj2939 > l } else { - yyb2948 = r.CheckBreak() + yyb2939 = r.CheckBreak() } - if yyb2948 { + if yyb2939 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2948-1, "") + z.DecStructFieldNotFound(yyj2939-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -37929,33 +37847,33 @@ func (x *DaemonEndpoint) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2953 := z.EncBinary() - _ = yym2953 + yym2944 := z.EncBinary() + _ = yym2944 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2954 := !z.EncBinary() - yy2arr2954 := z.EncBasicHandle().StructToArray - var yyq2954 [1]bool - _, _, _ = yysep2954, yyq2954, yy2arr2954 - const yyr2954 bool = false - var yynn2954 int - if yyr2954 || yy2arr2954 { + yysep2945 := !z.EncBinary() + yy2arr2945 := z.EncBasicHandle().StructToArray + var yyq2945 [1]bool + _, _, _ = yysep2945, yyq2945, yy2arr2945 + const yyr2945 bool = false + var yynn2945 int + if yyr2945 || yy2arr2945 { r.EncodeArrayStart(1) } else { - yynn2954 = 1 - for _, b := range yyq2954 { + yynn2945 = 1 + for _, b := range yyq2945 { if b { - yynn2954++ + yynn2945++ } } - r.EncodeMapStart(yynn2954) - yynn2954 = 0 + r.EncodeMapStart(yynn2945) + yynn2945 = 0 } - if yyr2954 || yy2arr2954 { + if yyr2945 || yy2arr2945 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2956 := z.EncBinary() - _ = yym2956 + yym2947 := z.EncBinary() + _ = yym2947 if false { } else { r.EncodeInt(int64(x.Port)) @@ -37964,14 +37882,14 @@ func (x *DaemonEndpoint) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("Port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2957 := z.EncBinary() - _ = yym2957 + yym2948 := z.EncBinary() + _ = yym2948 if false { } else { r.EncodeInt(int64(x.Port)) } } - if yyr2954 || yy2arr2954 { + if yyr2945 || yy2arr2945 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -37984,25 +37902,25 @@ func (x *DaemonEndpoint) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2958 := z.DecBinary() - _ = yym2958 + yym2949 := z.DecBinary() + _ = yym2949 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2959 := r.ContainerType() - if yyct2959 == codecSelferValueTypeMap1234 { - yyl2959 := r.ReadMapStart() - if yyl2959 == 0 { + yyct2950 := r.ContainerType() + if yyct2950 == codecSelferValueTypeMap1234 { + yyl2950 := r.ReadMapStart() + if yyl2950 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2959, d) + x.codecDecodeSelfFromMap(yyl2950, d) } - } else if yyct2959 == codecSelferValueTypeArray1234 { - yyl2959 := r.ReadArrayStart() - if yyl2959 == 0 { + } else if yyct2950 == codecSelferValueTypeArray1234 { + yyl2950 := r.ReadArrayStart() + if yyl2950 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2959, d) + x.codecDecodeSelfFromArray(yyl2950, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38014,12 +37932,12 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2960Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2960Slc - var yyhl2960 bool = l >= 0 - for yyj2960 := 0; ; yyj2960++ { - if yyhl2960 { - if yyj2960 >= l { + var yys2951Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2951Slc + var yyhl2951 bool = l >= 0 + for yyj2951 := 0; ; yyj2951++ { + if yyhl2951 { + if yyj2951 >= l { break } } else { @@ -38028,10 +37946,10 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2960Slc = r.DecodeBytes(yys2960Slc, true, true) - yys2960 := string(yys2960Slc) + yys2951Slc = r.DecodeBytes(yys2951Slc, true, true) + yys2951 := string(yys2951Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2960 { + switch yys2951 { case "Port": if r.TryDecodeAsNil() { x.Port = 0 @@ -38039,9 +37957,9 @@ func (x *DaemonEndpoint) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Port = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys2960) - } // end switch yys2960 - } // end for yyj2960 + z.DecStructFieldNotFound(-1, yys2951) + } // end switch yys2951 + } // end for yyj2951 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38049,16 +37967,16 @@ func (x *DaemonEndpoint) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2962 int - var yyb2962 bool - var yyhl2962 bool = l >= 0 - yyj2962++ - if yyhl2962 { - yyb2962 = yyj2962 > l + var yyj2953 int + var yyb2953 bool + var yyhl2953 bool = l >= 0 + yyj2953++ + if yyhl2953 { + yyb2953 = yyj2953 > l } else { - yyb2962 = r.CheckBreak() + yyb2953 = r.CheckBreak() } - if yyb2962 { + if yyb2953 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38069,17 +37987,17 @@ func (x *DaemonEndpoint) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Port = int32(r.DecodeInt(32)) } for { - yyj2962++ - if yyhl2962 { - yyb2962 = yyj2962 > l + yyj2953++ + if yyhl2953 { + yyb2953 = yyj2953 > l } else { - yyb2962 = r.CheckBreak() + yyb2953 = r.CheckBreak() } - if yyb2962 { + if yyb2953 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2962-1, "") + z.DecStructFieldNotFound(yyj2953-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38091,48 +38009,48 @@ func (x *NodeDaemonEndpoints) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2964 := z.EncBinary() - _ = yym2964 + yym2955 := z.EncBinary() + _ = yym2955 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2965 := !z.EncBinary() - yy2arr2965 := z.EncBasicHandle().StructToArray - var yyq2965 [1]bool - _, _, _ = yysep2965, yyq2965, yy2arr2965 - const yyr2965 bool = false - yyq2965[0] = true - var yynn2965 int - if yyr2965 || yy2arr2965 { + yysep2956 := !z.EncBinary() + yy2arr2956 := z.EncBasicHandle().StructToArray + var yyq2956 [1]bool + _, _, _ = yysep2956, yyq2956, yy2arr2956 + const yyr2956 bool = false + yyq2956[0] = true + var yynn2956 int + if yyr2956 || yy2arr2956 { r.EncodeArrayStart(1) } else { - yynn2965 = 0 - for _, b := range yyq2965 { + yynn2956 = 0 + for _, b := range yyq2956 { if b { - yynn2965++ + yynn2956++ } } - r.EncodeMapStart(yynn2965) - yynn2965 = 0 + r.EncodeMapStart(yynn2956) + yynn2956 = 0 } - if yyr2965 || yy2arr2965 { + if yyr2956 || yy2arr2956 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2965[0] { - yy2967 := &x.KubeletEndpoint - yy2967.CodecEncodeSelf(e) + if yyq2956[0] { + yy2958 := &x.KubeletEndpoint + yy2958.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq2965[0] { + if yyq2956[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeletEndpoint")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy2968 := &x.KubeletEndpoint - yy2968.CodecEncodeSelf(e) + yy2959 := &x.KubeletEndpoint + yy2959.CodecEncodeSelf(e) } } - if yyr2965 || yy2arr2965 { + if yyr2956 || yy2arr2956 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -38145,25 +38063,25 @@ func (x *NodeDaemonEndpoints) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym2969 := z.DecBinary() - _ = yym2969 + yym2960 := z.DecBinary() + _ = yym2960 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct2970 := r.ContainerType() - if yyct2970 == codecSelferValueTypeMap1234 { - yyl2970 := r.ReadMapStart() - if yyl2970 == 0 { + yyct2961 := r.ContainerType() + if yyct2961 == codecSelferValueTypeMap1234 { + yyl2961 := r.ReadMapStart() + if yyl2961 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl2970, d) + x.codecDecodeSelfFromMap(yyl2961, d) } - } else if yyct2970 == codecSelferValueTypeArray1234 { - yyl2970 := r.ReadArrayStart() - if yyl2970 == 0 { + } else if yyct2961 == codecSelferValueTypeArray1234 { + yyl2961 := r.ReadArrayStart() + if yyl2961 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl2970, d) + x.codecDecodeSelfFromArray(yyl2961, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38175,12 +38093,12 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys2971Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys2971Slc - var yyhl2971 bool = l >= 0 - for yyj2971 := 0; ; yyj2971++ { - if yyhl2971 { - if yyj2971 >= l { + var yys2962Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys2962Slc + var yyhl2962 bool = l >= 0 + for yyj2962 := 0; ; yyj2962++ { + if yyhl2962 { + if yyj2962 >= l { break } } else { @@ -38189,21 +38107,21 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys2971Slc = r.DecodeBytes(yys2971Slc, true, true) - yys2971 := string(yys2971Slc) + yys2962Slc = r.DecodeBytes(yys2962Slc, true, true) + yys2962 := string(yys2962Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys2971 { + switch yys2962 { case "kubeletEndpoint": if r.TryDecodeAsNil() { x.KubeletEndpoint = DaemonEndpoint{} } else { - yyv2972 := &x.KubeletEndpoint - yyv2972.CodecDecodeSelf(d) + yyv2963 := &x.KubeletEndpoint + yyv2963.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys2971) - } // end switch yys2971 - } // end for yyj2971 + z.DecStructFieldNotFound(-1, yys2962) + } // end switch yys2962 + } // end for yyj2962 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38211,16 +38129,16 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj2973 int - var yyb2973 bool - var yyhl2973 bool = l >= 0 - yyj2973++ - if yyhl2973 { - yyb2973 = yyj2973 > l + var yyj2964 int + var yyb2964 bool + var yyhl2964 bool = l >= 0 + yyj2964++ + if yyhl2964 { + yyb2964 = yyj2964 > l } else { - yyb2973 = r.CheckBreak() + yyb2964 = r.CheckBreak() } - if yyb2973 { + if yyb2964 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38228,21 +38146,21 @@ func (x *NodeDaemonEndpoints) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.KubeletEndpoint = DaemonEndpoint{} } else { - yyv2974 := &x.KubeletEndpoint - yyv2974.CodecDecodeSelf(d) + yyv2965 := &x.KubeletEndpoint + yyv2965.CodecDecodeSelf(d) } for { - yyj2973++ - if yyhl2973 { - yyb2973 = yyj2973 > l + yyj2964++ + if yyhl2964 { + yyb2964 = yyj2964 > l } else { - yyb2973 = r.CheckBreak() + yyb2964 = r.CheckBreak() } - if yyb2973 { + if yyb2964 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj2973-1, "") + z.DecStructFieldNotFound(yyj2964-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38254,33 +38172,33 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym2975 := z.EncBinary() - _ = yym2975 + yym2966 := z.EncBinary() + _ = yym2966 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep2976 := !z.EncBinary() - yy2arr2976 := z.EncBasicHandle().StructToArray - var yyq2976 [10]bool - _, _, _ = yysep2976, yyq2976, yy2arr2976 - const yyr2976 bool = false - var yynn2976 int - if yyr2976 || yy2arr2976 { + yysep2967 := !z.EncBinary() + yy2arr2967 := z.EncBasicHandle().StructToArray + var yyq2967 [10]bool + _, _, _ = yysep2967, yyq2967, yy2arr2967 + const yyr2967 bool = false + var yynn2967 int + if yyr2967 || yy2arr2967 { r.EncodeArrayStart(10) } else { - yynn2976 = 10 - for _, b := range yyq2976 { + yynn2967 = 10 + for _, b := range yyq2967 { if b { - yynn2976++ + yynn2967++ } } - r.EncodeMapStart(yynn2976) - yynn2976 = 0 + r.EncodeMapStart(yynn2967) + yynn2967 = 0 } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2978 := z.EncBinary() - _ = yym2978 + yym2969 := z.EncBinary() + _ = yym2969 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.MachineID)) @@ -38289,17 +38207,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("machineID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2979 := z.EncBinary() - _ = yym2979 + yym2970 := z.EncBinary() + _ = yym2970 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.MachineID)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2981 := z.EncBinary() - _ = yym2981 + yym2972 := z.EncBinary() + _ = yym2972 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SystemUUID)) @@ -38308,17 +38226,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("systemUUID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2982 := z.EncBinary() - _ = yym2982 + yym2973 := z.EncBinary() + _ = yym2973 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SystemUUID)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2984 := z.EncBinary() - _ = yym2984 + yym2975 := z.EncBinary() + _ = yym2975 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.BootID)) @@ -38327,17 +38245,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("bootID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2985 := z.EncBinary() - _ = yym2985 + yym2976 := z.EncBinary() + _ = yym2976 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.BootID)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2987 := z.EncBinary() - _ = yym2987 + yym2978 := z.EncBinary() + _ = yym2978 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KernelVersion)) @@ -38346,17 +38264,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kernelVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2988 := z.EncBinary() - _ = yym2988 + yym2979 := z.EncBinary() + _ = yym2979 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KernelVersion)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2990 := z.EncBinary() - _ = yym2990 + yym2981 := z.EncBinary() + _ = yym2981 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OSImage)) @@ -38365,17 +38283,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("osImage")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2991 := z.EncBinary() - _ = yym2991 + yym2982 := z.EncBinary() + _ = yym2982 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OSImage)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2993 := z.EncBinary() - _ = yym2993 + yym2984 := z.EncBinary() + _ = yym2984 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntimeVersion)) @@ -38384,17 +38302,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("containerRuntimeVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2994 := z.EncBinary() - _ = yym2994 + yym2985 := z.EncBinary() + _ = yym2985 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntimeVersion)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2996 := z.EncBinary() - _ = yym2996 + yym2987 := z.EncBinary() + _ = yym2987 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeletVersion)) @@ -38403,17 +38321,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeletVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym2997 := z.EncBinary() - _ = yym2997 + yym2988 := z.EncBinary() + _ = yym2988 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeletVersion)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym2999 := z.EncBinary() - _ = yym2999 + yym2990 := z.EncBinary() + _ = yym2990 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeProxyVersion)) @@ -38422,17 +38340,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kubeProxyVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3000 := z.EncBinary() - _ = yym3000 + yym2991 := z.EncBinary() + _ = yym2991 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.KubeProxyVersion)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3002 := z.EncBinary() - _ = yym3002 + yym2993 := z.EncBinary() + _ = yym2993 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OperatingSystem)) @@ -38441,17 +38359,17 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("operatingSystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3003 := z.EncBinary() - _ = yym3003 + yym2994 := z.EncBinary() + _ = yym2994 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.OperatingSystem)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3005 := z.EncBinary() - _ = yym3005 + yym2996 := z.EncBinary() + _ = yym2996 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Architecture)) @@ -38460,14 +38378,14 @@ func (x *NodeSystemInfo) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("architecture")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3006 := z.EncBinary() - _ = yym3006 + yym2997 := z.EncBinary() + _ = yym2997 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Architecture)) } } - if yyr2976 || yy2arr2976 { + if yyr2967 || yy2arr2967 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -38480,25 +38398,25 @@ func (x *NodeSystemInfo) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3007 := z.DecBinary() - _ = yym3007 + yym2998 := z.DecBinary() + _ = yym2998 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3008 := r.ContainerType() - if yyct3008 == codecSelferValueTypeMap1234 { - yyl3008 := r.ReadMapStart() - if yyl3008 == 0 { + yyct2999 := r.ContainerType() + if yyct2999 == codecSelferValueTypeMap1234 { + yyl2999 := r.ReadMapStart() + if yyl2999 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3008, d) + x.codecDecodeSelfFromMap(yyl2999, d) } - } else if yyct3008 == codecSelferValueTypeArray1234 { - yyl3008 := r.ReadArrayStart() - if yyl3008 == 0 { + } else if yyct2999 == codecSelferValueTypeArray1234 { + yyl2999 := r.ReadArrayStart() + if yyl2999 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3008, d) + x.codecDecodeSelfFromArray(yyl2999, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -38510,12 +38428,12 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3009Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3009Slc - var yyhl3009 bool = l >= 0 - for yyj3009 := 0; ; yyj3009++ { - if yyhl3009 { - if yyj3009 >= l { + var yys3000Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3000Slc + var yyhl3000 bool = l >= 0 + for yyj3000 := 0; ; yyj3000++ { + if yyhl3000 { + if yyj3000 >= l { break } } else { @@ -38524,10 +38442,10 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3009Slc = r.DecodeBytes(yys3009Slc, true, true) - yys3009 := string(yys3009Slc) + yys3000Slc = r.DecodeBytes(yys3000Slc, true, true) + yys3000 := string(yys3000Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3009 { + switch yys3000 { case "machineID": if r.TryDecodeAsNil() { x.MachineID = "" @@ -38589,9 +38507,9 @@ func (x *NodeSystemInfo) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Architecture = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3009) - } // end switch yys3009 - } // end for yyj3009 + z.DecStructFieldNotFound(-1, yys3000) + } // end switch yys3000 + } // end for yyj3000 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -38599,16 +38517,16 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3020 int - var yyb3020 bool - var yyhl3020 bool = l >= 0 - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + var yyj3011 int + var yyb3011 bool + var yyhl3011 bool = l >= 0 + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38618,13 +38536,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.MachineID = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38634,13 +38552,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.SystemUUID = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38650,13 +38568,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.BootID = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38666,13 +38584,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KernelVersion = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38682,13 +38600,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.OSImage = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38698,13 +38616,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ContainerRuntimeVersion = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38714,13 +38632,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KubeletVersion = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38730,13 +38648,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.KubeProxyVersion = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38746,13 +38664,13 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.OperatingSystem = string(r.DecodeString()) } - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -38763,17 +38681,17 @@ func (x *NodeSystemInfo) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Architecture = string(r.DecodeString()) } for { - yyj3020++ - if yyhl3020 { - yyb3020 = yyj3020 > l + yyj3011++ + if yyhl3011 { + yyb3011 = yyj3011 > l } else { - yyb3020 = r.CheckBreak() + yyb3011 = r.CheckBreak() } - if yyb3020 { + if yyb3011 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3020-1, "") + z.DecStructFieldNotFound(yyj3011-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -38785,42 +38703,42 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3031 := z.EncBinary() - _ = yym3031 + yym3022 := z.EncBinary() + _ = yym3022 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3032 := !z.EncBinary() - yy2arr3032 := z.EncBasicHandle().StructToArray - var yyq3032 [10]bool - _, _, _ = yysep3032, yyq3032, yy2arr3032 - const yyr3032 bool = false - yyq3032[0] = len(x.Capacity) != 0 - yyq3032[1] = len(x.Allocatable) != 0 - yyq3032[2] = x.Phase != "" - yyq3032[3] = len(x.Conditions) != 0 - yyq3032[4] = len(x.Addresses) != 0 - yyq3032[5] = true - yyq3032[6] = true - yyq3032[7] = len(x.Images) != 0 - yyq3032[8] = len(x.VolumesInUse) != 0 - yyq3032[9] = len(x.VolumesAttached) != 0 - var yynn3032 int - if yyr3032 || yy2arr3032 { + yysep3023 := !z.EncBinary() + yy2arr3023 := z.EncBasicHandle().StructToArray + var yyq3023 [10]bool + _, _, _ = yysep3023, yyq3023, yy2arr3023 + const yyr3023 bool = false + yyq3023[0] = len(x.Capacity) != 0 + yyq3023[1] = len(x.Allocatable) != 0 + yyq3023[2] = x.Phase != "" + yyq3023[3] = len(x.Conditions) != 0 + yyq3023[4] = len(x.Addresses) != 0 + yyq3023[5] = true + yyq3023[6] = true + yyq3023[7] = len(x.Images) != 0 + yyq3023[8] = len(x.VolumesInUse) != 0 + yyq3023[9] = len(x.VolumesAttached) != 0 + var yynn3023 int + if yyr3023 || yy2arr3023 { r.EncodeArrayStart(10) } else { - yynn3032 = 0 - for _, b := range yyq3032 { + yynn3023 = 0 + for _, b := range yyq3023 { if b { - yynn3032++ + yynn3023++ } } - r.EncodeMapStart(yynn3032) - yynn3032 = 0 + r.EncodeMapStart(yynn3023) + yynn3023 = 0 } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[0] { + if yyq3023[0] { if x.Capacity == nil { r.EncodeNil() } else { @@ -38830,7 +38748,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[0] { + if yyq3023[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("capacity")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -38841,9 +38759,9 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[1] { + if yyq3023[1] { if x.Allocatable == nil { r.EncodeNil() } else { @@ -38853,7 +38771,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[1] { + if yyq3023[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("allocatable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -38864,29 +38782,29 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[2] { + if yyq3023[2] { x.Phase.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3032[2] { + if yyq3023[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("phase")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Phase.CodecEncodeSelf(e) } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[3] { + if yyq3023[3] { if x.Conditions == nil { r.EncodeNil() } else { - yym3037 := z.EncBinary() - _ = yym3037 + yym3028 := z.EncBinary() + _ = yym3028 if false { } else { h.encSliceNodeCondition(([]NodeCondition)(x.Conditions), e) @@ -38896,15 +38814,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[3] { + if yyq3023[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym3038 := z.EncBinary() - _ = yym3038 + yym3029 := z.EncBinary() + _ = yym3029 if false { } else { h.encSliceNodeCondition(([]NodeCondition)(x.Conditions), e) @@ -38912,14 +38830,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[4] { + if yyq3023[4] { if x.Addresses == nil { r.EncodeNil() } else { - yym3040 := z.EncBinary() - _ = yym3040 + yym3031 := z.EncBinary() + _ = yym3031 if false { } else { h.encSliceNodeAddress(([]NodeAddress)(x.Addresses), e) @@ -38929,15 +38847,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[4] { + if yyq3023[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("addresses")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Addresses == nil { r.EncodeNil() } else { - yym3041 := z.EncBinary() - _ = yym3041 + yym3032 := z.EncBinary() + _ = yym3032 if false { } else { h.encSliceNodeAddress(([]NodeAddress)(x.Addresses), e) @@ -38945,48 +38863,48 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[5] { - yy3043 := &x.DaemonEndpoints - yy3043.CodecEncodeSelf(e) + if yyq3023[5] { + yy3034 := &x.DaemonEndpoints + yy3034.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3032[5] { + if yyq3023[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("daemonEndpoints")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3044 := &x.DaemonEndpoints - yy3044.CodecEncodeSelf(e) + yy3035 := &x.DaemonEndpoints + yy3035.CodecEncodeSelf(e) } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[6] { - yy3046 := &x.NodeInfo - yy3046.CodecEncodeSelf(e) + if yyq3023[6] { + yy3037 := &x.NodeInfo + yy3037.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3032[6] { + if yyq3023[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("nodeInfo")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3047 := &x.NodeInfo - yy3047.CodecEncodeSelf(e) + yy3038 := &x.NodeInfo + yy3038.CodecEncodeSelf(e) } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[7] { + if yyq3023[7] { if x.Images == nil { r.EncodeNil() } else { - yym3049 := z.EncBinary() - _ = yym3049 + yym3040 := z.EncBinary() + _ = yym3040 if false { } else { h.encSliceContainerImage(([]ContainerImage)(x.Images), e) @@ -38996,15 +38914,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[7] { + if yyq3023[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("images")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Images == nil { r.EncodeNil() } else { - yym3050 := z.EncBinary() - _ = yym3050 + yym3041 := z.EncBinary() + _ = yym3041 if false { } else { h.encSliceContainerImage(([]ContainerImage)(x.Images), e) @@ -39012,14 +38930,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[8] { + if yyq3023[8] { if x.VolumesInUse == nil { r.EncodeNil() } else { - yym3052 := z.EncBinary() - _ = yym3052 + yym3043 := z.EncBinary() + _ = yym3043 if false { } else { h.encSliceUniqueVolumeName(([]UniqueVolumeName)(x.VolumesInUse), e) @@ -39029,15 +38947,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[8] { + if yyq3023[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumesInUse")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.VolumesInUse == nil { r.EncodeNil() } else { - yym3053 := z.EncBinary() - _ = yym3053 + yym3044 := z.EncBinary() + _ = yym3044 if false { } else { h.encSliceUniqueVolumeName(([]UniqueVolumeName)(x.VolumesInUse), e) @@ -39045,14 +38963,14 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3032[9] { + if yyq3023[9] { if x.VolumesAttached == nil { r.EncodeNil() } else { - yym3055 := z.EncBinary() - _ = yym3055 + yym3046 := z.EncBinary() + _ = yym3046 if false { } else { h.encSliceAttachedVolume(([]AttachedVolume)(x.VolumesAttached), e) @@ -39062,15 +38980,15 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3032[9] { + if yyq3023[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumesAttached")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.VolumesAttached == nil { r.EncodeNil() } else { - yym3056 := z.EncBinary() - _ = yym3056 + yym3047 := z.EncBinary() + _ = yym3047 if false { } else { h.encSliceAttachedVolume(([]AttachedVolume)(x.VolumesAttached), e) @@ -39078,7 +38996,7 @@ func (x *NodeStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3032 || yy2arr3032 { + if yyr3023 || yy2arr3023 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -39091,25 +39009,25 @@ func (x *NodeStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3057 := z.DecBinary() - _ = yym3057 + yym3048 := z.DecBinary() + _ = yym3048 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3058 := r.ContainerType() - if yyct3058 == codecSelferValueTypeMap1234 { - yyl3058 := r.ReadMapStart() - if yyl3058 == 0 { + yyct3049 := r.ContainerType() + if yyct3049 == codecSelferValueTypeMap1234 { + yyl3049 := r.ReadMapStart() + if yyl3049 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3058, d) + x.codecDecodeSelfFromMap(yyl3049, d) } - } else if yyct3058 == codecSelferValueTypeArray1234 { - yyl3058 := r.ReadArrayStart() - if yyl3058 == 0 { + } else if yyct3049 == codecSelferValueTypeArray1234 { + yyl3049 := r.ReadArrayStart() + if yyl3049 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3058, d) + x.codecDecodeSelfFromArray(yyl3049, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -39121,12 +39039,12 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3059Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3059Slc - var yyhl3059 bool = l >= 0 - for yyj3059 := 0; ; yyj3059++ { - if yyhl3059 { - if yyj3059 >= l { + var yys3050Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3050Slc + var yyhl3050 bool = l >= 0 + for yyj3050 := 0; ; yyj3050++ { + if yyhl3050 { + if yyj3050 >= l { break } } else { @@ -39135,23 +39053,23 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3059Slc = r.DecodeBytes(yys3059Slc, true, true) - yys3059 := string(yys3059Slc) + yys3050Slc = r.DecodeBytes(yys3050Slc, true, true) + yys3050 := string(yys3050Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3059 { + switch yys3050 { case "capacity": if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3060 := &x.Capacity - yyv3060.CodecDecodeSelf(d) + yyv3051 := &x.Capacity + yyv3051.CodecDecodeSelf(d) } case "allocatable": if r.TryDecodeAsNil() { x.Allocatable = nil } else { - yyv3061 := &x.Allocatable - yyv3061.CodecDecodeSelf(d) + yyv3052 := &x.Allocatable + yyv3052.CodecDecodeSelf(d) } case "phase": if r.TryDecodeAsNil() { @@ -39163,80 +39081,80 @@ func (x *NodeStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv3063 := &x.Conditions - yym3064 := z.DecBinary() - _ = yym3064 + yyv3054 := &x.Conditions + yym3055 := z.DecBinary() + _ = yym3055 if false { } else { - h.decSliceNodeCondition((*[]NodeCondition)(yyv3063), d) + h.decSliceNodeCondition((*[]NodeCondition)(yyv3054), d) } } case "addresses": if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv3065 := &x.Addresses - yym3066 := z.DecBinary() - _ = yym3066 + yyv3056 := &x.Addresses + yym3057 := z.DecBinary() + _ = yym3057 if false { } else { - h.decSliceNodeAddress((*[]NodeAddress)(yyv3065), d) + h.decSliceNodeAddress((*[]NodeAddress)(yyv3056), d) } } case "daemonEndpoints": if r.TryDecodeAsNil() { x.DaemonEndpoints = NodeDaemonEndpoints{} } else { - yyv3067 := &x.DaemonEndpoints - yyv3067.CodecDecodeSelf(d) + yyv3058 := &x.DaemonEndpoints + yyv3058.CodecDecodeSelf(d) } case "nodeInfo": if r.TryDecodeAsNil() { x.NodeInfo = NodeSystemInfo{} } else { - yyv3068 := &x.NodeInfo - yyv3068.CodecDecodeSelf(d) + yyv3059 := &x.NodeInfo + yyv3059.CodecDecodeSelf(d) } case "images": if r.TryDecodeAsNil() { x.Images = nil } else { - yyv3069 := &x.Images - yym3070 := z.DecBinary() - _ = yym3070 + yyv3060 := &x.Images + yym3061 := z.DecBinary() + _ = yym3061 if false { } else { - h.decSliceContainerImage((*[]ContainerImage)(yyv3069), d) + h.decSliceContainerImage((*[]ContainerImage)(yyv3060), d) } } case "volumesInUse": if r.TryDecodeAsNil() { x.VolumesInUse = nil } else { - yyv3071 := &x.VolumesInUse - yym3072 := z.DecBinary() - _ = yym3072 + yyv3062 := &x.VolumesInUse + yym3063 := z.DecBinary() + _ = yym3063 if false { } else { - h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3071), d) + h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3062), d) } } case "volumesAttached": if r.TryDecodeAsNil() { x.VolumesAttached = nil } else { - yyv3073 := &x.VolumesAttached - yym3074 := z.DecBinary() - _ = yym3074 + yyv3064 := &x.VolumesAttached + yym3065 := z.DecBinary() + _ = yym3065 if false { } else { - h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3073), d) + h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3064), d) } } default: - z.DecStructFieldNotFound(-1, yys3059) - } // end switch yys3059 - } // end for yyj3059 + z.DecStructFieldNotFound(-1, yys3050) + } // end switch yys3050 + } // end for yyj3050 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -39244,16 +39162,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3075 int - var yyb3075 bool - var yyhl3075 bool = l >= 0 - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + var yyj3066 int + var yyb3066 bool + var yyhl3066 bool = l >= 0 + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39261,16 +39179,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Capacity = nil } else { - yyv3076 := &x.Capacity - yyv3076.CodecDecodeSelf(d) + yyv3067 := &x.Capacity + yyv3067.CodecDecodeSelf(d) } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39278,16 +39196,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Allocatable = nil } else { - yyv3077 := &x.Allocatable - yyv3077.CodecDecodeSelf(d) + yyv3068 := &x.Allocatable + yyv3068.CodecDecodeSelf(d) } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39297,13 +39215,13 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Phase = NodePhase(r.DecodeString()) } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39311,21 +39229,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv3079 := &x.Conditions - yym3080 := z.DecBinary() - _ = yym3080 + yyv3070 := &x.Conditions + yym3071 := z.DecBinary() + _ = yym3071 if false { } else { - h.decSliceNodeCondition((*[]NodeCondition)(yyv3079), d) + h.decSliceNodeCondition((*[]NodeCondition)(yyv3070), d) } } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39333,21 +39251,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Addresses = nil } else { - yyv3081 := &x.Addresses - yym3082 := z.DecBinary() - _ = yym3082 + yyv3072 := &x.Addresses + yym3073 := z.DecBinary() + _ = yym3073 if false { } else { - h.decSliceNodeAddress((*[]NodeAddress)(yyv3081), d) + h.decSliceNodeAddress((*[]NodeAddress)(yyv3072), d) } } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39355,16 +39273,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.DaemonEndpoints = NodeDaemonEndpoints{} } else { - yyv3083 := &x.DaemonEndpoints - yyv3083.CodecDecodeSelf(d) + yyv3074 := &x.DaemonEndpoints + yyv3074.CodecDecodeSelf(d) } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39372,16 +39290,16 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.NodeInfo = NodeSystemInfo{} } else { - yyv3084 := &x.NodeInfo - yyv3084.CodecDecodeSelf(d) + yyv3075 := &x.NodeInfo + yyv3075.CodecDecodeSelf(d) } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39389,21 +39307,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Images = nil } else { - yyv3085 := &x.Images - yym3086 := z.DecBinary() - _ = yym3086 + yyv3076 := &x.Images + yym3077 := z.DecBinary() + _ = yym3077 if false { } else { - h.decSliceContainerImage((*[]ContainerImage)(yyv3085), d) + h.decSliceContainerImage((*[]ContainerImage)(yyv3076), d) } } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39411,21 +39329,21 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.VolumesInUse = nil } else { - yyv3087 := &x.VolumesInUse - yym3088 := z.DecBinary() - _ = yym3088 + yyv3078 := &x.VolumesInUse + yym3079 := z.DecBinary() + _ = yym3079 if false { } else { - h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3087), d) + h.decSliceUniqueVolumeName((*[]UniqueVolumeName)(yyv3078), d) } } - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39433,26 +39351,26 @@ func (x *NodeStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.VolumesAttached = nil } else { - yyv3089 := &x.VolumesAttached - yym3090 := z.DecBinary() - _ = yym3090 + yyv3080 := &x.VolumesAttached + yym3081 := z.DecBinary() + _ = yym3081 if false { } else { - h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3089), d) + h.decSliceAttachedVolume((*[]AttachedVolume)(yyv3080), d) } } for { - yyj3075++ - if yyhl3075 { - yyb3075 = yyj3075 > l + yyj3066++ + if yyhl3066 { + yyb3066 = yyj3066 > l } else { - yyb3075 = r.CheckBreak() + yyb3066 = r.CheckBreak() } - if yyb3075 { + if yyb3066 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3075-1, "") + z.DecStructFieldNotFound(yyj3066-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -39461,8 +39379,8 @@ func (x UniqueVolumeName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3091 := z.EncBinary() - _ = yym3091 + yym3082 := z.EncBinary() + _ = yym3082 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -39474,8 +39392,8 @@ func (x *UniqueVolumeName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3092 := z.DecBinary() - _ = yym3092 + yym3083 := z.DecBinary() + _ = yym3083 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -39490,30 +39408,30 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3093 := z.EncBinary() - _ = yym3093 + yym3084 := z.EncBinary() + _ = yym3084 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3094 := !z.EncBinary() - yy2arr3094 := z.EncBasicHandle().StructToArray - var yyq3094 [2]bool - _, _, _ = yysep3094, yyq3094, yy2arr3094 - const yyr3094 bool = false - var yynn3094 int - if yyr3094 || yy2arr3094 { + yysep3085 := !z.EncBinary() + yy2arr3085 := z.EncBasicHandle().StructToArray + var yyq3085 [2]bool + _, _, _ = yysep3085, yyq3085, yy2arr3085 + const yyr3085 bool = false + var yynn3085 int + if yyr3085 || yy2arr3085 { r.EncodeArrayStart(2) } else { - yynn3094 = 2 - for _, b := range yyq3094 { + yynn3085 = 2 + for _, b := range yyq3085 { if b { - yynn3094++ + yynn3085++ } } - r.EncodeMapStart(yynn3094) - yynn3094 = 0 + r.EncodeMapStart(yynn3085) + yynn3085 = 0 } - if yyr3094 || yy2arr3094 { + if yyr3085 || yy2arr3085 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Name.CodecEncodeSelf(e) } else { @@ -39522,10 +39440,10 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Name.CodecEncodeSelf(e) } - if yyr3094 || yy2arr3094 { + if yyr3085 || yy2arr3085 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3097 := z.EncBinary() - _ = yym3097 + yym3088 := z.EncBinary() + _ = yym3088 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.DevicePath)) @@ -39534,14 +39452,14 @@ func (x *AttachedVolume) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("devicePath")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3098 := z.EncBinary() - _ = yym3098 + yym3089 := z.EncBinary() + _ = yym3089 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.DevicePath)) } } - if yyr3094 || yy2arr3094 { + if yyr3085 || yy2arr3085 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -39554,25 +39472,25 @@ func (x *AttachedVolume) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3099 := z.DecBinary() - _ = yym3099 + yym3090 := z.DecBinary() + _ = yym3090 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3100 := r.ContainerType() - if yyct3100 == codecSelferValueTypeMap1234 { - yyl3100 := r.ReadMapStart() - if yyl3100 == 0 { + yyct3091 := r.ContainerType() + if yyct3091 == codecSelferValueTypeMap1234 { + yyl3091 := r.ReadMapStart() + if yyl3091 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3100, d) + x.codecDecodeSelfFromMap(yyl3091, d) } - } else if yyct3100 == codecSelferValueTypeArray1234 { - yyl3100 := r.ReadArrayStart() - if yyl3100 == 0 { + } else if yyct3091 == codecSelferValueTypeArray1234 { + yyl3091 := r.ReadArrayStart() + if yyl3091 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3100, d) + x.codecDecodeSelfFromArray(yyl3091, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -39584,12 +39502,12 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3101Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3101Slc - var yyhl3101 bool = l >= 0 - for yyj3101 := 0; ; yyj3101++ { - if yyhl3101 { - if yyj3101 >= l { + var yys3092Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3092Slc + var yyhl3092 bool = l >= 0 + for yyj3092 := 0; ; yyj3092++ { + if yyhl3092 { + if yyj3092 >= l { break } } else { @@ -39598,10 +39516,10 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3101Slc = r.DecodeBytes(yys3101Slc, true, true) - yys3101 := string(yys3101Slc) + yys3092Slc = r.DecodeBytes(yys3092Slc, true, true) + yys3092 := string(yys3092Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3101 { + switch yys3092 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -39615,9 +39533,9 @@ func (x *AttachedVolume) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.DevicePath = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3101) - } // end switch yys3101 - } // end for yyj3101 + z.DecStructFieldNotFound(-1, yys3092) + } // end switch yys3092 + } // end for yyj3092 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -39625,16 +39543,16 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3104 int - var yyb3104 bool - var yyhl3104 bool = l >= 0 - yyj3104++ - if yyhl3104 { - yyb3104 = yyj3104 > l + var yyj3095 int + var yyb3095 bool + var yyhl3095 bool = l >= 0 + yyj3095++ + if yyhl3095 { + yyb3095 = yyj3095 > l } else { - yyb3104 = r.CheckBreak() + yyb3095 = r.CheckBreak() } - if yyb3104 { + if yyb3095 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39644,13 +39562,13 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = UniqueVolumeName(r.DecodeString()) } - yyj3104++ - if yyhl3104 { - yyb3104 = yyj3104 > l + yyj3095++ + if yyhl3095 { + yyb3095 = yyj3095 > l } else { - yyb3104 = r.CheckBreak() + yyb3095 = r.CheckBreak() } - if yyb3104 { + if yyb3095 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39661,17 +39579,17 @@ func (x *AttachedVolume) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.DevicePath = string(r.DecodeString()) } for { - yyj3104++ - if yyhl3104 { - yyb3104 = yyj3104 > l + yyj3095++ + if yyhl3095 { + yyb3095 = yyj3095 > l } else { - yyb3104 = r.CheckBreak() + yyb3095 = r.CheckBreak() } - if yyb3104 { + if yyb3095 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3104-1, "") + z.DecStructFieldNotFound(yyj3095-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -39683,38 +39601,38 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3107 := z.EncBinary() - _ = yym3107 + yym3098 := z.EncBinary() + _ = yym3098 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3108 := !z.EncBinary() - yy2arr3108 := z.EncBasicHandle().StructToArray - var yyq3108 [1]bool - _, _, _ = yysep3108, yyq3108, yy2arr3108 - const yyr3108 bool = false - yyq3108[0] = len(x.PreferAvoidPods) != 0 - var yynn3108 int - if yyr3108 || yy2arr3108 { + yysep3099 := !z.EncBinary() + yy2arr3099 := z.EncBasicHandle().StructToArray + var yyq3099 [1]bool + _, _, _ = yysep3099, yyq3099, yy2arr3099 + const yyr3099 bool = false + yyq3099[0] = len(x.PreferAvoidPods) != 0 + var yynn3099 int + if yyr3099 || yy2arr3099 { r.EncodeArrayStart(1) } else { - yynn3108 = 0 - for _, b := range yyq3108 { + yynn3099 = 0 + for _, b := range yyq3099 { if b { - yynn3108++ + yynn3099++ } } - r.EncodeMapStart(yynn3108) - yynn3108 = 0 + r.EncodeMapStart(yynn3099) + yynn3099 = 0 } - if yyr3108 || yy2arr3108 { + if yyr3099 || yy2arr3099 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3108[0] { + if yyq3099[0] { if x.PreferAvoidPods == nil { r.EncodeNil() } else { - yym3110 := z.EncBinary() - _ = yym3110 + yym3101 := z.EncBinary() + _ = yym3101 if false { } else { h.encSlicePreferAvoidPodsEntry(([]PreferAvoidPodsEntry)(x.PreferAvoidPods), e) @@ -39724,15 +39642,15 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3108[0] { + if yyq3099[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("preferAvoidPods")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.PreferAvoidPods == nil { r.EncodeNil() } else { - yym3111 := z.EncBinary() - _ = yym3111 + yym3102 := z.EncBinary() + _ = yym3102 if false { } else { h.encSlicePreferAvoidPodsEntry(([]PreferAvoidPodsEntry)(x.PreferAvoidPods), e) @@ -39740,7 +39658,7 @@ func (x *AvoidPods) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3108 || yy2arr3108 { + if yyr3099 || yy2arr3099 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -39753,25 +39671,25 @@ func (x *AvoidPods) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3112 := z.DecBinary() - _ = yym3112 + yym3103 := z.DecBinary() + _ = yym3103 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3113 := r.ContainerType() - if yyct3113 == codecSelferValueTypeMap1234 { - yyl3113 := r.ReadMapStart() - if yyl3113 == 0 { + yyct3104 := r.ContainerType() + if yyct3104 == codecSelferValueTypeMap1234 { + yyl3104 := r.ReadMapStart() + if yyl3104 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3113, d) + x.codecDecodeSelfFromMap(yyl3104, d) } - } else if yyct3113 == codecSelferValueTypeArray1234 { - yyl3113 := r.ReadArrayStart() - if yyl3113 == 0 { + } else if yyct3104 == codecSelferValueTypeArray1234 { + yyl3104 := r.ReadArrayStart() + if yyl3104 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3113, d) + x.codecDecodeSelfFromArray(yyl3104, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -39783,12 +39701,12 @@ func (x *AvoidPods) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3114Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3114Slc - var yyhl3114 bool = l >= 0 - for yyj3114 := 0; ; yyj3114++ { - if yyhl3114 { - if yyj3114 >= l { + var yys3105Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3105Slc + var yyhl3105 bool = l >= 0 + for yyj3105 := 0; ; yyj3105++ { + if yyhl3105 { + if yyj3105 >= l { break } } else { @@ -39797,26 +39715,26 @@ func (x *AvoidPods) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3114Slc = r.DecodeBytes(yys3114Slc, true, true) - yys3114 := string(yys3114Slc) + yys3105Slc = r.DecodeBytes(yys3105Slc, true, true) + yys3105 := string(yys3105Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3114 { + switch yys3105 { case "preferAvoidPods": if r.TryDecodeAsNil() { x.PreferAvoidPods = nil } else { - yyv3115 := &x.PreferAvoidPods - yym3116 := z.DecBinary() - _ = yym3116 + yyv3106 := &x.PreferAvoidPods + yym3107 := z.DecBinary() + _ = yym3107 if false { } else { - h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3115), d) + h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3106), d) } } default: - z.DecStructFieldNotFound(-1, yys3114) - } // end switch yys3114 - } // end for yyj3114 + z.DecStructFieldNotFound(-1, yys3105) + } // end switch yys3105 + } // end for yyj3105 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -39824,16 +39742,16 @@ func (x *AvoidPods) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3117 int - var yyb3117 bool - var yyhl3117 bool = l >= 0 - yyj3117++ - if yyhl3117 { - yyb3117 = yyj3117 > l + var yyj3108 int + var yyb3108 bool + var yyhl3108 bool = l >= 0 + yyj3108++ + if yyhl3108 { + yyb3108 = yyj3108 > l } else { - yyb3117 = r.CheckBreak() + yyb3108 = r.CheckBreak() } - if yyb3117 { + if yyb3108 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -39841,26 +39759,26 @@ func (x *AvoidPods) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.PreferAvoidPods = nil } else { - yyv3118 := &x.PreferAvoidPods - yym3119 := z.DecBinary() - _ = yym3119 + yyv3109 := &x.PreferAvoidPods + yym3110 := z.DecBinary() + _ = yym3110 if false { } else { - h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3118), d) + h.decSlicePreferAvoidPodsEntry((*[]PreferAvoidPodsEntry)(yyv3109), d) } } for { - yyj3117++ - if yyhl3117 { - yyb3117 = yyj3117 > l + yyj3108++ + if yyhl3108 { + yyb3108 = yyj3108 > l } else { - yyb3117 = r.CheckBreak() + yyb3108 = r.CheckBreak() } - if yyb3117 { + if yyb3108 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3117-1, "") + z.DecStructFieldNotFound(yyj3108-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -39872,85 +39790,85 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3120 := z.EncBinary() - _ = yym3120 + yym3111 := z.EncBinary() + _ = yym3111 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3121 := !z.EncBinary() - yy2arr3121 := z.EncBasicHandle().StructToArray - var yyq3121 [4]bool - _, _, _ = yysep3121, yyq3121, yy2arr3121 - const yyr3121 bool = false - yyq3121[1] = true - yyq3121[2] = x.Reason != "" - yyq3121[3] = x.Message != "" - var yynn3121 int - if yyr3121 || yy2arr3121 { + yysep3112 := !z.EncBinary() + yy2arr3112 := z.EncBasicHandle().StructToArray + var yyq3112 [4]bool + _, _, _ = yysep3112, yyq3112, yy2arr3112 + const yyr3112 bool = false + yyq3112[1] = true + yyq3112[2] = x.Reason != "" + yyq3112[3] = x.Message != "" + var yynn3112 int + if yyr3112 || yy2arr3112 { r.EncodeArrayStart(4) } else { - yynn3121 = 1 - for _, b := range yyq3121 { + yynn3112 = 1 + for _, b := range yyq3112 { if b { - yynn3121++ + yynn3112++ } } - r.EncodeMapStart(yynn3121) - yynn3121 = 0 + r.EncodeMapStart(yynn3112) + yynn3112 = 0 } - if yyr3121 || yy2arr3121 { + if yyr3112 || yy2arr3112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3123 := &x.PodSignature - yy3123.CodecEncodeSelf(e) + yy3114 := &x.PodSignature + yy3114.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSignature")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3124 := &x.PodSignature - yy3124.CodecEncodeSelf(e) + yy3115 := &x.PodSignature + yy3115.CodecEncodeSelf(e) } - if yyr3121 || yy2arr3121 { + if yyr3112 || yy2arr3112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3121[1] { - yy3126 := &x.EvictionTime - yym3127 := z.EncBinary() - _ = yym3127 + if yyq3112[1] { + yy3117 := &x.EvictionTime + yym3118 := z.EncBinary() + _ = yym3118 if false { - } else if z.HasExtensions() && z.EncExt(yy3126) { - } else if yym3127 { - z.EncBinaryMarshal(yy3126) - } else if !yym3127 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3126) + } else if z.HasExtensions() && z.EncExt(yy3117) { + } else if yym3118 { + z.EncBinaryMarshal(yy3117) + } else if !yym3118 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3117) } else { - z.EncFallback(yy3126) + z.EncFallback(yy3117) } } else { r.EncodeNil() } } else { - if yyq3121[1] { + if yyq3112[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("evictionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3128 := &x.EvictionTime - yym3129 := z.EncBinary() - _ = yym3129 + yy3119 := &x.EvictionTime + yym3120 := z.EncBinary() + _ = yym3120 if false { - } else if z.HasExtensions() && z.EncExt(yy3128) { - } else if yym3129 { - z.EncBinaryMarshal(yy3128) - } else if !yym3129 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3128) + } else if z.HasExtensions() && z.EncExt(yy3119) { + } else if yym3120 { + z.EncBinaryMarshal(yy3119) + } else if !yym3120 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3119) } else { - z.EncFallback(yy3128) + z.EncFallback(yy3119) } } } - if yyr3121 || yy2arr3121 { + if yyr3112 || yy2arr3112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3121[2] { - yym3131 := z.EncBinary() - _ = yym3131 + if yyq3112[2] { + yym3122 := z.EncBinary() + _ = yym3122 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -39959,23 +39877,23 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3121[2] { + if yyq3112[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3132 := z.EncBinary() - _ = yym3132 + yym3123 := z.EncBinary() + _ = yym3123 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3121 || yy2arr3121 { + if yyr3112 || yy2arr3112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3121[3] { - yym3134 := z.EncBinary() - _ = yym3134 + if yyq3112[3] { + yym3125 := z.EncBinary() + _ = yym3125 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -39984,19 +39902,19 @@ func (x *PreferAvoidPodsEntry) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3121[3] { + if yyq3112[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3135 := z.EncBinary() - _ = yym3135 + yym3126 := z.EncBinary() + _ = yym3126 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr3121 || yy2arr3121 { + if yyr3112 || yy2arr3112 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40009,25 +39927,25 @@ func (x *PreferAvoidPodsEntry) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3136 := z.DecBinary() - _ = yym3136 + yym3127 := z.DecBinary() + _ = yym3127 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3137 := r.ContainerType() - if yyct3137 == codecSelferValueTypeMap1234 { - yyl3137 := r.ReadMapStart() - if yyl3137 == 0 { + yyct3128 := r.ContainerType() + if yyct3128 == codecSelferValueTypeMap1234 { + yyl3128 := r.ReadMapStart() + if yyl3128 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3137, d) + x.codecDecodeSelfFromMap(yyl3128, d) } - } else if yyct3137 == codecSelferValueTypeArray1234 { - yyl3137 := r.ReadArrayStart() - if yyl3137 == 0 { + } else if yyct3128 == codecSelferValueTypeArray1234 { + yyl3128 := r.ReadArrayStart() + if yyl3128 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3137, d) + x.codecDecodeSelfFromArray(yyl3128, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40039,12 +39957,12 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3138Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3138Slc - var yyhl3138 bool = l >= 0 - for yyj3138 := 0; ; yyj3138++ { - if yyhl3138 { - if yyj3138 >= l { + var yys3129Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3129Slc + var yyhl3129 bool = l >= 0 + for yyj3129 := 0; ; yyj3129++ { + if yyhl3129 { + if yyj3129 >= l { break } } else { @@ -40053,32 +39971,32 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3138Slc = r.DecodeBytes(yys3138Slc, true, true) - yys3138 := string(yys3138Slc) + yys3129Slc = r.DecodeBytes(yys3129Slc, true, true) + yys3129 := string(yys3129Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3138 { + switch yys3129 { case "podSignature": if r.TryDecodeAsNil() { x.PodSignature = PodSignature{} } else { - yyv3139 := &x.PodSignature - yyv3139.CodecDecodeSelf(d) + yyv3130 := &x.PodSignature + yyv3130.CodecDecodeSelf(d) } case "evictionTime": if r.TryDecodeAsNil() { x.EvictionTime = pkg2_unversioned.Time{} } else { - yyv3140 := &x.EvictionTime - yym3141 := z.DecBinary() - _ = yym3141 + yyv3131 := &x.EvictionTime + yym3132 := z.DecBinary() + _ = yym3132 if false { - } else if z.HasExtensions() && z.DecExt(yyv3140) { - } else if yym3141 { - z.DecBinaryUnmarshal(yyv3140) - } else if !yym3141 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3140) + } else if z.HasExtensions() && z.DecExt(yyv3131) { + } else if yym3132 { + z.DecBinaryUnmarshal(yyv3131) + } else if !yym3132 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3131) } else { - z.DecFallback(yyv3140, false) + z.DecFallback(yyv3131, false) } } case "reason": @@ -40094,9 +40012,9 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromMap(l int, d *codec1978.Decode x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3138) - } // end switch yys3138 - } // end for yyj3138 + z.DecStructFieldNotFound(-1, yys3129) + } // end switch yys3129 + } // end for yyj3129 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40104,16 +40022,16 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3144 int - var yyb3144 bool - var yyhl3144 bool = l >= 0 - yyj3144++ - if yyhl3144 { - yyb3144 = yyj3144 > l + var yyj3135 int + var yyb3135 bool + var yyhl3135 bool = l >= 0 + yyj3135++ + if yyhl3135 { + yyb3135 = yyj3135 > l } else { - yyb3144 = r.CheckBreak() + yyb3135 = r.CheckBreak() } - if yyb3144 { + if yyb3135 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40121,16 +40039,16 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.PodSignature = PodSignature{} } else { - yyv3145 := &x.PodSignature - yyv3145.CodecDecodeSelf(d) + yyv3136 := &x.PodSignature + yyv3136.CodecDecodeSelf(d) } - yyj3144++ - if yyhl3144 { - yyb3144 = yyj3144 > l + yyj3135++ + if yyhl3135 { + yyb3135 = yyj3135 > l } else { - yyb3144 = r.CheckBreak() + yyb3135 = r.CheckBreak() } - if yyb3144 { + if yyb3135 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40138,26 +40056,26 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.EvictionTime = pkg2_unversioned.Time{} } else { - yyv3146 := &x.EvictionTime - yym3147 := z.DecBinary() - _ = yym3147 + yyv3137 := &x.EvictionTime + yym3138 := z.DecBinary() + _ = yym3138 if false { - } else if z.HasExtensions() && z.DecExt(yyv3146) { - } else if yym3147 { - z.DecBinaryUnmarshal(yyv3146) - } else if !yym3147 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3146) + } else if z.HasExtensions() && z.DecExt(yyv3137) { + } else if yym3138 { + z.DecBinaryUnmarshal(yyv3137) + } else if !yym3138 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3137) } else { - z.DecFallback(yyv3146, false) + z.DecFallback(yyv3137, false) } } - yyj3144++ - if yyhl3144 { - yyb3144 = yyj3144 > l + yyj3135++ + if yyhl3135 { + yyb3135 = yyj3135 > l } else { - yyb3144 = r.CheckBreak() + yyb3135 = r.CheckBreak() } - if yyb3144 { + if yyb3135 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40167,13 +40085,13 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco } else { x.Reason = string(r.DecodeString()) } - yyj3144++ - if yyhl3144 { - yyb3144 = yyj3144 > l + yyj3135++ + if yyhl3135 { + yyb3135 = yyj3135 > l } else { - yyb3144 = r.CheckBreak() + yyb3135 = r.CheckBreak() } - if yyb3144 { + if yyb3135 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40184,17 +40102,17 @@ func (x *PreferAvoidPodsEntry) codecDecodeSelfFromArray(l int, d *codec1978.Deco x.Message = string(r.DecodeString()) } for { - yyj3144++ - if yyhl3144 { - yyb3144 = yyj3144 > l + yyj3135++ + if yyhl3135 { + yyb3135 = yyj3135 > l } else { - yyb3144 = r.CheckBreak() + yyb3135 = r.CheckBreak() } - if yyb3144 { + if yyb3135 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3144-1, "") + z.DecStructFieldNotFound(yyj3135-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40206,33 +40124,33 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3150 := z.EncBinary() - _ = yym3150 + yym3141 := z.EncBinary() + _ = yym3141 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3151 := !z.EncBinary() - yy2arr3151 := z.EncBasicHandle().StructToArray - var yyq3151 [1]bool - _, _, _ = yysep3151, yyq3151, yy2arr3151 - const yyr3151 bool = false - yyq3151[0] = x.PodController != nil - var yynn3151 int - if yyr3151 || yy2arr3151 { + yysep3142 := !z.EncBinary() + yy2arr3142 := z.EncBasicHandle().StructToArray + var yyq3142 [1]bool + _, _, _ = yysep3142, yyq3142, yy2arr3142 + const yyr3142 bool = false + yyq3142[0] = x.PodController != nil + var yynn3142 int + if yyr3142 || yy2arr3142 { r.EncodeArrayStart(1) } else { - yynn3151 = 0 - for _, b := range yyq3151 { + yynn3142 = 0 + for _, b := range yyq3142 { if b { - yynn3151++ + yynn3142++ } } - r.EncodeMapStart(yynn3151) - yynn3151 = 0 + r.EncodeMapStart(yynn3142) + yynn3142 = 0 } - if yyr3151 || yy2arr3151 { + if yyr3142 || yy2arr3142 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3151[0] { + if yyq3142[0] { if x.PodController == nil { r.EncodeNil() } else { @@ -40242,7 +40160,7 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3151[0] { + if yyq3142[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podController")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -40253,7 +40171,7 @@ func (x *PodSignature) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3151 || yy2arr3151 { + if yyr3142 || yy2arr3142 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40266,25 +40184,25 @@ func (x *PodSignature) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3153 := z.DecBinary() - _ = yym3153 + yym3144 := z.DecBinary() + _ = yym3144 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3154 := r.ContainerType() - if yyct3154 == codecSelferValueTypeMap1234 { - yyl3154 := r.ReadMapStart() - if yyl3154 == 0 { + yyct3145 := r.ContainerType() + if yyct3145 == codecSelferValueTypeMap1234 { + yyl3145 := r.ReadMapStart() + if yyl3145 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3154, d) + x.codecDecodeSelfFromMap(yyl3145, d) } - } else if yyct3154 == codecSelferValueTypeArray1234 { - yyl3154 := r.ReadArrayStart() - if yyl3154 == 0 { + } else if yyct3145 == codecSelferValueTypeArray1234 { + yyl3145 := r.ReadArrayStart() + if yyl3145 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3154, d) + x.codecDecodeSelfFromArray(yyl3145, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40296,12 +40214,12 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3155Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3155Slc - var yyhl3155 bool = l >= 0 - for yyj3155 := 0; ; yyj3155++ { - if yyhl3155 { - if yyj3155 >= l { + var yys3146Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3146Slc + var yyhl3146 bool = l >= 0 + for yyj3146 := 0; ; yyj3146++ { + if yyhl3146 { + if yyj3146 >= l { break } } else { @@ -40310,10 +40228,10 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3155Slc = r.DecodeBytes(yys3155Slc, true, true) - yys3155 := string(yys3155Slc) + yys3146Slc = r.DecodeBytes(yys3146Slc, true, true) + yys3146 := string(yys3146Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3155 { + switch yys3146 { case "podController": if r.TryDecodeAsNil() { if x.PodController != nil { @@ -40326,9 +40244,9 @@ func (x *PodSignature) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.PodController.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3155) - } // end switch yys3155 - } // end for yyj3155 + z.DecStructFieldNotFound(-1, yys3146) + } // end switch yys3146 + } // end for yyj3146 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40336,16 +40254,16 @@ func (x *PodSignature) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3157 int - var yyb3157 bool - var yyhl3157 bool = l >= 0 - yyj3157++ - if yyhl3157 { - yyb3157 = yyj3157 > l + var yyj3148 int + var yyb3148 bool + var yyhl3148 bool = l >= 0 + yyj3148++ + if yyhl3148 { + yyb3148 = yyj3148 > l } else { - yyb3157 = r.CheckBreak() + yyb3148 = r.CheckBreak() } - if yyb3157 { + if yyb3148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40361,17 +40279,17 @@ func (x *PodSignature) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.PodController.CodecDecodeSelf(d) } for { - yyj3157++ - if yyhl3157 { - yyb3157 = yyj3157 > l + yyj3148++ + if yyhl3148 { + yyb3148 = yyj3148 > l } else { - yyb3157 = r.CheckBreak() + yyb3148 = r.CheckBreak() } - if yyb3157 { + if yyb3148 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3157-1, "") + z.DecStructFieldNotFound(yyj3148-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40383,37 +40301,37 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3159 := z.EncBinary() - _ = yym3159 + yym3150 := z.EncBinary() + _ = yym3150 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3160 := !z.EncBinary() - yy2arr3160 := z.EncBasicHandle().StructToArray - var yyq3160 [2]bool - _, _, _ = yysep3160, yyq3160, yy2arr3160 - const yyr3160 bool = false - yyq3160[1] = x.SizeBytes != 0 - var yynn3160 int - if yyr3160 || yy2arr3160 { + yysep3151 := !z.EncBinary() + yy2arr3151 := z.EncBasicHandle().StructToArray + var yyq3151 [2]bool + _, _, _ = yysep3151, yyq3151, yy2arr3151 + const yyr3151 bool = false + yyq3151[1] = x.SizeBytes != 0 + var yynn3151 int + if yyr3151 || yy2arr3151 { r.EncodeArrayStart(2) } else { - yynn3160 = 1 - for _, b := range yyq3160 { + yynn3151 = 1 + for _, b := range yyq3151 { if b { - yynn3160++ + yynn3151++ } } - r.EncodeMapStart(yynn3160) - yynn3160 = 0 + r.EncodeMapStart(yynn3151) + yynn3151 = 0 } - if yyr3160 || yy2arr3160 { + if yyr3151 || yy2arr3151 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Names == nil { r.EncodeNil() } else { - yym3162 := z.EncBinary() - _ = yym3162 + yym3153 := z.EncBinary() + _ = yym3153 if false { } else { z.F.EncSliceStringV(x.Names, false, e) @@ -40426,19 +40344,19 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { if x.Names == nil { r.EncodeNil() } else { - yym3163 := z.EncBinary() - _ = yym3163 + yym3154 := z.EncBinary() + _ = yym3154 if false { } else { z.F.EncSliceStringV(x.Names, false, e) } } } - if yyr3160 || yy2arr3160 { + if yyr3151 || yy2arr3151 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3160[1] { - yym3165 := z.EncBinary() - _ = yym3165 + if yyq3151[1] { + yym3156 := z.EncBinary() + _ = yym3156 if false { } else { r.EncodeInt(int64(x.SizeBytes)) @@ -40447,19 +40365,19 @@ func (x *ContainerImage) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq3160[1] { + if yyq3151[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("sizeBytes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3166 := z.EncBinary() - _ = yym3166 + yym3157 := z.EncBinary() + _ = yym3157 if false { } else { r.EncodeInt(int64(x.SizeBytes)) } } } - if yyr3160 || yy2arr3160 { + if yyr3151 || yy2arr3151 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40472,25 +40390,25 @@ func (x *ContainerImage) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3167 := z.DecBinary() - _ = yym3167 + yym3158 := z.DecBinary() + _ = yym3158 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3168 := r.ContainerType() - if yyct3168 == codecSelferValueTypeMap1234 { - yyl3168 := r.ReadMapStart() - if yyl3168 == 0 { + yyct3159 := r.ContainerType() + if yyct3159 == codecSelferValueTypeMap1234 { + yyl3159 := r.ReadMapStart() + if yyl3159 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3168, d) + x.codecDecodeSelfFromMap(yyl3159, d) } - } else if yyct3168 == codecSelferValueTypeArray1234 { - yyl3168 := r.ReadArrayStart() - if yyl3168 == 0 { + } else if yyct3159 == codecSelferValueTypeArray1234 { + yyl3159 := r.ReadArrayStart() + if yyl3159 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3168, d) + x.codecDecodeSelfFromArray(yyl3159, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40502,12 +40420,12 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3169Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3169Slc - var yyhl3169 bool = l >= 0 - for yyj3169 := 0; ; yyj3169++ { - if yyhl3169 { - if yyj3169 >= l { + var yys3160Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3160Slc + var yyhl3160 bool = l >= 0 + for yyj3160 := 0; ; yyj3160++ { + if yyhl3160 { + if yyj3160 >= l { break } } else { @@ -40516,20 +40434,20 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3169Slc = r.DecodeBytes(yys3169Slc, true, true) - yys3169 := string(yys3169Slc) + yys3160Slc = r.DecodeBytes(yys3160Slc, true, true) + yys3160 := string(yys3160Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3169 { + switch yys3160 { case "names": if r.TryDecodeAsNil() { x.Names = nil } else { - yyv3170 := &x.Names - yym3171 := z.DecBinary() - _ = yym3171 + yyv3161 := &x.Names + yym3162 := z.DecBinary() + _ = yym3162 if false { } else { - z.F.DecSliceStringX(yyv3170, false, d) + z.F.DecSliceStringX(yyv3161, false, d) } } case "sizeBytes": @@ -40539,9 +40457,9 @@ func (x *ContainerImage) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.SizeBytes = int64(r.DecodeInt(64)) } default: - z.DecStructFieldNotFound(-1, yys3169) - } // end switch yys3169 - } // end for yyj3169 + z.DecStructFieldNotFound(-1, yys3160) + } // end switch yys3160 + } // end for yyj3160 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40549,16 +40467,16 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3173 int - var yyb3173 bool - var yyhl3173 bool = l >= 0 - yyj3173++ - if yyhl3173 { - yyb3173 = yyj3173 > l + var yyj3164 int + var yyb3164 bool + var yyhl3164 bool = l >= 0 + yyj3164++ + if yyhl3164 { + yyb3164 = yyj3164 > l } else { - yyb3173 = r.CheckBreak() + yyb3164 = r.CheckBreak() } - if yyb3173 { + if yyb3164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40566,21 +40484,21 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Names = nil } else { - yyv3174 := &x.Names - yym3175 := z.DecBinary() - _ = yym3175 + yyv3165 := &x.Names + yym3166 := z.DecBinary() + _ = yym3166 if false { } else { - z.F.DecSliceStringX(yyv3174, false, d) + z.F.DecSliceStringX(yyv3165, false, d) } } - yyj3173++ - if yyhl3173 { - yyb3173 = yyj3173 > l + yyj3164++ + if yyhl3164 { + yyb3164 = yyj3164 > l } else { - yyb3173 = r.CheckBreak() + yyb3164 = r.CheckBreak() } - if yyb3173 { + if yyb3164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40591,17 +40509,17 @@ func (x *ContainerImage) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.SizeBytes = int64(r.DecodeInt(64)) } for { - yyj3173++ - if yyhl3173 { - yyb3173 = yyj3173 > l + yyj3164++ + if yyhl3164 { + yyb3164 = yyj3164 > l } else { - yyb3173 = r.CheckBreak() + yyb3164 = r.CheckBreak() } - if yyb3173 { + if yyb3164 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3173-1, "") + z.DecStructFieldNotFound(yyj3164-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -40610,8 +40528,8 @@ func (x NodePhase) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3177 := z.EncBinary() - _ = yym3177 + yym3168 := z.EncBinary() + _ = yym3168 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -40623,8 +40541,8 @@ func (x *NodePhase) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3178 := z.DecBinary() - _ = yym3178 + yym3169 := z.DecBinary() + _ = yym3169 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -40636,8 +40554,8 @@ func (x NodeConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3179 := z.EncBinary() - _ = yym3179 + yym3170 := z.EncBinary() + _ = yym3170 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -40649,8 +40567,8 @@ func (x *NodeConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3180 := z.DecBinary() - _ = yym3180 + yym3171 := z.DecBinary() + _ = yym3171 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -40665,34 +40583,34 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3181 := z.EncBinary() - _ = yym3181 + yym3172 := z.EncBinary() + _ = yym3172 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3182 := !z.EncBinary() - yy2arr3182 := z.EncBasicHandle().StructToArray - var yyq3182 [6]bool - _, _, _ = yysep3182, yyq3182, yy2arr3182 - const yyr3182 bool = false - yyq3182[2] = true - yyq3182[3] = true - yyq3182[4] = x.Reason != "" - yyq3182[5] = x.Message != "" - var yynn3182 int - if yyr3182 || yy2arr3182 { + yysep3173 := !z.EncBinary() + yy2arr3173 := z.EncBasicHandle().StructToArray + var yyq3173 [6]bool + _, _, _ = yysep3173, yyq3173, yy2arr3173 + const yyr3173 bool = false + yyq3173[2] = true + yyq3173[3] = true + yyq3173[4] = x.Reason != "" + yyq3173[5] = x.Message != "" + var yynn3173 int + if yyr3173 || yy2arr3173 { r.EncodeArrayStart(6) } else { - yynn3182 = 2 - for _, b := range yyq3182 { + yynn3173 = 2 + for _, b := range yyq3173 { if b { - yynn3182++ + yynn3173++ } } - r.EncodeMapStart(yynn3182) - yynn3182 = 0 + r.EncodeMapStart(yynn3173) + yynn3173 = 0 } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -40701,7 +40619,7 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Status.CodecEncodeSelf(e) } else { @@ -40710,85 +40628,85 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Status.CodecEncodeSelf(e) } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3182[2] { - yy3186 := &x.LastHeartbeatTime - yym3187 := z.EncBinary() - _ = yym3187 + if yyq3173[2] { + yy3177 := &x.LastHeartbeatTime + yym3178 := z.EncBinary() + _ = yym3178 if false { - } else if z.HasExtensions() && z.EncExt(yy3186) { - } else if yym3187 { - z.EncBinaryMarshal(yy3186) - } else if !yym3187 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3186) + } else if z.HasExtensions() && z.EncExt(yy3177) { + } else if yym3178 { + z.EncBinaryMarshal(yy3177) + } else if !yym3178 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3177) } else { - z.EncFallback(yy3186) + z.EncFallback(yy3177) } } else { r.EncodeNil() } } else { - if yyq3182[2] { + if yyq3173[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastHeartbeatTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3188 := &x.LastHeartbeatTime - yym3189 := z.EncBinary() - _ = yym3189 + yy3179 := &x.LastHeartbeatTime + yym3180 := z.EncBinary() + _ = yym3180 if false { - } else if z.HasExtensions() && z.EncExt(yy3188) { - } else if yym3189 { - z.EncBinaryMarshal(yy3188) - } else if !yym3189 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3188) + } else if z.HasExtensions() && z.EncExt(yy3179) { + } else if yym3180 { + z.EncBinaryMarshal(yy3179) + } else if !yym3180 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3179) } else { - z.EncFallback(yy3188) + z.EncFallback(yy3179) } } } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3182[3] { - yy3191 := &x.LastTransitionTime - yym3192 := z.EncBinary() - _ = yym3192 + if yyq3173[3] { + yy3182 := &x.LastTransitionTime + yym3183 := z.EncBinary() + _ = yym3183 if false { - } else if z.HasExtensions() && z.EncExt(yy3191) { - } else if yym3192 { - z.EncBinaryMarshal(yy3191) - } else if !yym3192 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3191) + } else if z.HasExtensions() && z.EncExt(yy3182) { + } else if yym3183 { + z.EncBinaryMarshal(yy3182) + } else if !yym3183 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3182) } else { - z.EncFallback(yy3191) + z.EncFallback(yy3182) } } else { r.EncodeNil() } } else { - if yyq3182[3] { + if yyq3173[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3193 := &x.LastTransitionTime - yym3194 := z.EncBinary() - _ = yym3194 + yy3184 := &x.LastTransitionTime + yym3185 := z.EncBinary() + _ = yym3185 if false { - } else if z.HasExtensions() && z.EncExt(yy3193) { - } else if yym3194 { - z.EncBinaryMarshal(yy3193) - } else if !yym3194 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3193) + } else if z.HasExtensions() && z.EncExt(yy3184) { + } else if yym3185 { + z.EncBinaryMarshal(yy3184) + } else if !yym3185 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3184) } else { - z.EncFallback(yy3193) + z.EncFallback(yy3184) } } } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3182[4] { - yym3196 := z.EncBinary() - _ = yym3196 + if yyq3173[4] { + yym3187 := z.EncBinary() + _ = yym3187 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -40797,23 +40715,23 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3182[4] { + if yyq3173[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3197 := z.EncBinary() - _ = yym3197 + yym3188 := z.EncBinary() + _ = yym3188 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3182[5] { - yym3199 := z.EncBinary() - _ = yym3199 + if yyq3173[5] { + yym3190 := z.EncBinary() + _ = yym3190 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -40822,19 +40740,19 @@ func (x *NodeCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3182[5] { + if yyq3173[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3200 := z.EncBinary() - _ = yym3200 + yym3191 := z.EncBinary() + _ = yym3191 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr3182 || yy2arr3182 { + if yyr3173 || yy2arr3173 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -40847,25 +40765,25 @@ func (x *NodeCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3201 := z.DecBinary() - _ = yym3201 + yym3192 := z.DecBinary() + _ = yym3192 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3202 := r.ContainerType() - if yyct3202 == codecSelferValueTypeMap1234 { - yyl3202 := r.ReadMapStart() - if yyl3202 == 0 { + yyct3193 := r.ContainerType() + if yyct3193 == codecSelferValueTypeMap1234 { + yyl3193 := r.ReadMapStart() + if yyl3193 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3202, d) + x.codecDecodeSelfFromMap(yyl3193, d) } - } else if yyct3202 == codecSelferValueTypeArray1234 { - yyl3202 := r.ReadArrayStart() - if yyl3202 == 0 { + } else if yyct3193 == codecSelferValueTypeArray1234 { + yyl3193 := r.ReadArrayStart() + if yyl3193 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3202, d) + x.codecDecodeSelfFromArray(yyl3193, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -40877,12 +40795,12 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3203Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3203Slc - var yyhl3203 bool = l >= 0 - for yyj3203 := 0; ; yyj3203++ { - if yyhl3203 { - if yyj3203 >= l { + var yys3194Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3194Slc + var yyhl3194 bool = l >= 0 + for yyj3194 := 0; ; yyj3194++ { + if yyhl3194 { + if yyj3194 >= l { break } } else { @@ -40891,10 +40809,10 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3203Slc = r.DecodeBytes(yys3203Slc, true, true) - yys3203 := string(yys3203Slc) + yys3194Slc = r.DecodeBytes(yys3194Slc, true, true) + yys3194 := string(yys3194Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3203 { + switch yys3194 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -40911,34 +40829,34 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastHeartbeatTime = pkg2_unversioned.Time{} } else { - yyv3206 := &x.LastHeartbeatTime - yym3207 := z.DecBinary() - _ = yym3207 + yyv3197 := &x.LastHeartbeatTime + yym3198 := z.DecBinary() + _ = yym3198 if false { - } else if z.HasExtensions() && z.DecExt(yyv3206) { - } else if yym3207 { - z.DecBinaryUnmarshal(yyv3206) - } else if !yym3207 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3206) + } else if z.HasExtensions() && z.DecExt(yyv3197) { + } else if yym3198 { + z.DecBinaryUnmarshal(yyv3197) + } else if !yym3198 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3197) } else { - z.DecFallback(yyv3206, false) + z.DecFallback(yyv3197, false) } } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv3208 := &x.LastTransitionTime - yym3209 := z.DecBinary() - _ = yym3209 + yyv3199 := &x.LastTransitionTime + yym3200 := z.DecBinary() + _ = yym3200 if false { - } else if z.HasExtensions() && z.DecExt(yyv3208) { - } else if yym3209 { - z.DecBinaryUnmarshal(yyv3208) - } else if !yym3209 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3208) + } else if z.HasExtensions() && z.DecExt(yyv3199) { + } else if yym3200 { + z.DecBinaryUnmarshal(yyv3199) + } else if !yym3200 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3199) } else { - z.DecFallback(yyv3208, false) + z.DecFallback(yyv3199, false) } } case "reason": @@ -40954,9 +40872,9 @@ func (x *NodeCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3203) - } // end switch yys3203 - } // end for yyj3203 + z.DecStructFieldNotFound(-1, yys3194) + } // end switch yys3194 + } // end for yyj3194 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -40964,16 +40882,16 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3212 int - var yyb3212 bool - var yyhl3212 bool = l >= 0 - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + var yyj3203 int + var yyb3203 bool + var yyhl3203 bool = l >= 0 + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40983,13 +40901,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = NodeConditionType(r.DecodeString()) } - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -40999,13 +40917,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41013,26 +40931,26 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastHeartbeatTime = pkg2_unversioned.Time{} } else { - yyv3215 := &x.LastHeartbeatTime - yym3216 := z.DecBinary() - _ = yym3216 + yyv3206 := &x.LastHeartbeatTime + yym3207 := z.DecBinary() + _ = yym3207 if false { - } else if z.HasExtensions() && z.DecExt(yyv3215) { - } else if yym3216 { - z.DecBinaryUnmarshal(yyv3215) - } else if !yym3216 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3215) + } else if z.HasExtensions() && z.DecExt(yyv3206) { + } else if yym3207 { + z.DecBinaryUnmarshal(yyv3206) + } else if !yym3207 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3206) } else { - z.DecFallback(yyv3215, false) + z.DecFallback(yyv3206, false) } } - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41040,26 +40958,26 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTransitionTime = pkg2_unversioned.Time{} } else { - yyv3217 := &x.LastTransitionTime - yym3218 := z.DecBinary() - _ = yym3218 + yyv3208 := &x.LastTransitionTime + yym3209 := z.DecBinary() + _ = yym3209 if false { - } else if z.HasExtensions() && z.DecExt(yyv3217) { - } else if yym3218 { - z.DecBinaryUnmarshal(yyv3217) - } else if !yym3218 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3217) + } else if z.HasExtensions() && z.DecExt(yyv3208) { + } else if yym3209 { + z.DecBinaryUnmarshal(yyv3208) + } else if !yym3209 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3208) } else { - z.DecFallback(yyv3217, false) + z.DecFallback(yyv3208, false) } } - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41069,13 +40987,13 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41086,17 +41004,17 @@ func (x *NodeCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } for { - yyj3212++ - if yyhl3212 { - yyb3212 = yyj3212 > l + yyj3203++ + if yyhl3203 { + yyb3203 = yyj3203 > l } else { - yyb3212 = r.CheckBreak() + yyb3203 = r.CheckBreak() } - if yyb3212 { + if yyb3203 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3212-1, "") + z.DecStructFieldNotFound(yyj3203-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41105,8 +41023,8 @@ func (x NodeAddressType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3221 := z.EncBinary() - _ = yym3221 + yym3212 := z.EncBinary() + _ = yym3212 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41118,8 +41036,8 @@ func (x *NodeAddressType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3222 := z.DecBinary() - _ = yym3222 + yym3213 := z.DecBinary() + _ = yym3213 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41134,30 +41052,30 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3223 := z.EncBinary() - _ = yym3223 + yym3214 := z.EncBinary() + _ = yym3214 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3224 := !z.EncBinary() - yy2arr3224 := z.EncBasicHandle().StructToArray - var yyq3224 [2]bool - _, _, _ = yysep3224, yyq3224, yy2arr3224 - const yyr3224 bool = false - var yynn3224 int - if yyr3224 || yy2arr3224 { + yysep3215 := !z.EncBinary() + yy2arr3215 := z.EncBasicHandle().StructToArray + var yyq3215 [2]bool + _, _, _ = yysep3215, yyq3215, yy2arr3215 + const yyr3215 bool = false + var yynn3215 int + if yyr3215 || yy2arr3215 { r.EncodeArrayStart(2) } else { - yynn3224 = 2 - for _, b := range yyq3224 { + yynn3215 = 2 + for _, b := range yyq3215 { if b { - yynn3224++ + yynn3215++ } } - r.EncodeMapStart(yynn3224) - yynn3224 = 0 + r.EncodeMapStart(yynn3215) + yynn3215 = 0 } - if yyr3224 || yy2arr3224 { + if yyr3215 || yy2arr3215 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -41166,10 +41084,10 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr3224 || yy2arr3224 { + if yyr3215 || yy2arr3215 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3227 := z.EncBinary() - _ = yym3227 + yym3218 := z.EncBinary() + _ = yym3218 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Address)) @@ -41178,14 +41096,14 @@ func (x *NodeAddress) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("address")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3228 := z.EncBinary() - _ = yym3228 + yym3219 := z.EncBinary() + _ = yym3219 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Address)) } } - if yyr3224 || yy2arr3224 { + if yyr3215 || yy2arr3215 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41198,25 +41116,25 @@ func (x *NodeAddress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3229 := z.DecBinary() - _ = yym3229 + yym3220 := z.DecBinary() + _ = yym3220 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3230 := r.ContainerType() - if yyct3230 == codecSelferValueTypeMap1234 { - yyl3230 := r.ReadMapStart() - if yyl3230 == 0 { + yyct3221 := r.ContainerType() + if yyct3221 == codecSelferValueTypeMap1234 { + yyl3221 := r.ReadMapStart() + if yyl3221 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3230, d) + x.codecDecodeSelfFromMap(yyl3221, d) } - } else if yyct3230 == codecSelferValueTypeArray1234 { - yyl3230 := r.ReadArrayStart() - if yyl3230 == 0 { + } else if yyct3221 == codecSelferValueTypeArray1234 { + yyl3221 := r.ReadArrayStart() + if yyl3221 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3230, d) + x.codecDecodeSelfFromArray(yyl3221, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41228,12 +41146,12 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3231Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3231Slc - var yyhl3231 bool = l >= 0 - for yyj3231 := 0; ; yyj3231++ { - if yyhl3231 { - if yyj3231 >= l { + var yys3222Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3222Slc + var yyhl3222 bool = l >= 0 + for yyj3222 := 0; ; yyj3222++ { + if yyhl3222 { + if yyj3222 >= l { break } } else { @@ -41242,10 +41160,10 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3231Slc = r.DecodeBytes(yys3231Slc, true, true) - yys3231 := string(yys3231Slc) + yys3222Slc = r.DecodeBytes(yys3222Slc, true, true) + yys3222 := string(yys3222Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3231 { + switch yys3222 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -41259,9 +41177,9 @@ func (x *NodeAddress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Address = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3231) - } // end switch yys3231 - } // end for yyj3231 + z.DecStructFieldNotFound(-1, yys3222) + } // end switch yys3222 + } // end for yyj3222 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41269,16 +41187,16 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3234 int - var yyb3234 bool - var yyhl3234 bool = l >= 0 - yyj3234++ - if yyhl3234 { - yyb3234 = yyj3234 > l + var yyj3225 int + var yyb3225 bool + var yyhl3225 bool = l >= 0 + yyj3225++ + if yyhl3225 { + yyb3225 = yyj3225 > l } else { - yyb3234 = r.CheckBreak() + yyb3225 = r.CheckBreak() } - if yyb3234 { + if yyb3225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41288,13 +41206,13 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = NodeAddressType(r.DecodeString()) } - yyj3234++ - if yyhl3234 { - yyb3234 = yyj3234 > l + yyj3225++ + if yyhl3225 { + yyb3225 = yyj3225 > l } else { - yyb3234 = r.CheckBreak() + yyb3225 = r.CheckBreak() } - if yyb3234 { + if yyb3225 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41305,17 +41223,17 @@ func (x *NodeAddress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Address = string(r.DecodeString()) } for { - yyj3234++ - if yyhl3234 { - yyb3234 = yyj3234 > l + yyj3225++ + if yyhl3225 { + yyb3225 = yyj3225 > l } else { - yyb3234 = r.CheckBreak() + yyb3225 = r.CheckBreak() } - if yyb3234 { + if yyb3225 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3234-1, "") + z.DecStructFieldNotFound(yyj3225-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41324,8 +41242,8 @@ func (x ResourceName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3237 := z.EncBinary() - _ = yym3237 + yym3228 := z.EncBinary() + _ = yym3228 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41337,8 +41255,8 @@ func (x *ResourceName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3238 := z.DecBinary() - _ = yym3238 + yym3229 := z.DecBinary() + _ = yym3229 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41353,8 +41271,8 @@ func (x ResourceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3239 := z.EncBinary() - _ = yym3239 + yym3230 := z.EncBinary() + _ = yym3230 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -41367,8 +41285,8 @@ func (x *ResourceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3240 := z.DecBinary() - _ = yym3240 + yym3231 := z.DecBinary() + _ = yym3231 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -41383,39 +41301,39 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3241 := z.EncBinary() - _ = yym3241 + yym3232 := z.EncBinary() + _ = yym3232 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3242 := !z.EncBinary() - yy2arr3242 := z.EncBasicHandle().StructToArray - var yyq3242 [5]bool - _, _, _ = yysep3242, yyq3242, yy2arr3242 - const yyr3242 bool = false - yyq3242[0] = x.Kind != "" - yyq3242[1] = x.APIVersion != "" - yyq3242[2] = true - yyq3242[3] = true - yyq3242[4] = true - var yynn3242 int - if yyr3242 || yy2arr3242 { + yysep3233 := !z.EncBinary() + yy2arr3233 := z.EncBasicHandle().StructToArray + var yyq3233 [5]bool + _, _, _ = yysep3233, yyq3233, yy2arr3233 + const yyr3233 bool = false + yyq3233[0] = x.Kind != "" + yyq3233[1] = x.APIVersion != "" + yyq3233[2] = true + yyq3233[3] = true + yyq3233[4] = true + var yynn3233 int + if yyr3233 || yy2arr3233 { r.EncodeArrayStart(5) } else { - yynn3242 = 0 - for _, b := range yyq3242 { + yynn3233 = 0 + for _, b := range yyq3233 { if b { - yynn3242++ + yynn3233++ } } - r.EncodeMapStart(yynn3242) - yynn3242 = 0 + r.EncodeMapStart(yynn3233) + yynn3233 = 0 } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3242[0] { - yym3244 := z.EncBinary() - _ = yym3244 + if yyq3233[0] { + yym3235 := z.EncBinary() + _ = yym3235 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -41424,23 +41342,23 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3242[0] { + if yyq3233[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3245 := z.EncBinary() - _ = yym3245 + yym3236 := z.EncBinary() + _ = yym3236 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3242[1] { - yym3247 := z.EncBinary() - _ = yym3247 + if yyq3233[1] { + yym3238 := z.EncBinary() + _ = yym3238 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -41449,70 +41367,70 @@ func (x *Node) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3242[1] { + if yyq3233[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3248 := z.EncBinary() - _ = yym3248 + yym3239 := z.EncBinary() + _ = yym3239 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3242[2] { - yy3250 := &x.ObjectMeta - yy3250.CodecEncodeSelf(e) + if yyq3233[2] { + yy3241 := &x.ObjectMeta + yy3241.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3242[2] { + if yyq3233[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3251 := &x.ObjectMeta - yy3251.CodecEncodeSelf(e) + yy3242 := &x.ObjectMeta + yy3242.CodecEncodeSelf(e) } } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3242[3] { - yy3253 := &x.Spec - yy3253.CodecEncodeSelf(e) + if yyq3233[3] { + yy3244 := &x.Spec + yy3244.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3242[3] { + if yyq3233[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3254 := &x.Spec - yy3254.CodecEncodeSelf(e) + yy3245 := &x.Spec + yy3245.CodecEncodeSelf(e) } } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3242[4] { - yy3256 := &x.Status - yy3256.CodecEncodeSelf(e) + if yyq3233[4] { + yy3247 := &x.Status + yy3247.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3242[4] { + if yyq3233[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3257 := &x.Status - yy3257.CodecEncodeSelf(e) + yy3248 := &x.Status + yy3248.CodecEncodeSelf(e) } } - if yyr3242 || yy2arr3242 { + if yyr3233 || yy2arr3233 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41525,25 +41443,25 @@ func (x *Node) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3258 := z.DecBinary() - _ = yym3258 + yym3249 := z.DecBinary() + _ = yym3249 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3259 := r.ContainerType() - if yyct3259 == codecSelferValueTypeMap1234 { - yyl3259 := r.ReadMapStart() - if yyl3259 == 0 { + yyct3250 := r.ContainerType() + if yyct3250 == codecSelferValueTypeMap1234 { + yyl3250 := r.ReadMapStart() + if yyl3250 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3259, d) + x.codecDecodeSelfFromMap(yyl3250, d) } - } else if yyct3259 == codecSelferValueTypeArray1234 { - yyl3259 := r.ReadArrayStart() - if yyl3259 == 0 { + } else if yyct3250 == codecSelferValueTypeArray1234 { + yyl3250 := r.ReadArrayStart() + if yyl3250 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3259, d) + x.codecDecodeSelfFromArray(yyl3250, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41555,12 +41473,12 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3260Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3260Slc - var yyhl3260 bool = l >= 0 - for yyj3260 := 0; ; yyj3260++ { - if yyhl3260 { - if yyj3260 >= l { + var yys3251Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3251Slc + var yyhl3251 bool = l >= 0 + for yyj3251 := 0; ; yyj3251++ { + if yyhl3251 { + if yyj3251 >= l { break } } else { @@ -41569,10 +41487,10 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3260Slc = r.DecodeBytes(yys3260Slc, true, true) - yys3260 := string(yys3260Slc) + yys3251Slc = r.DecodeBytes(yys3251Slc, true, true) + yys3251 := string(yys3251Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3260 { + switch yys3251 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -41589,27 +41507,27 @@ func (x *Node) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3263 := &x.ObjectMeta - yyv3263.CodecDecodeSelf(d) + yyv3254 := &x.ObjectMeta + yyv3254.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NodeSpec{} } else { - yyv3264 := &x.Spec - yyv3264.CodecDecodeSelf(d) + yyv3255 := &x.Spec + yyv3255.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = NodeStatus{} } else { - yyv3265 := &x.Status - yyv3265.CodecDecodeSelf(d) + yyv3256 := &x.Status + yyv3256.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3260) - } // end switch yys3260 - } // end for yyj3260 + z.DecStructFieldNotFound(-1, yys3251) + } // end switch yys3251 + } // end for yyj3251 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41617,16 +41535,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3266 int - var yyb3266 bool - var yyhl3266 bool = l >= 0 - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + var yyj3257 int + var yyb3257 bool + var yyhl3257 bool = l >= 0 + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41636,13 +41554,13 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41652,13 +41570,13 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41666,16 +41584,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3269 := &x.ObjectMeta - yyv3269.CodecDecodeSelf(d) + yyv3260 := &x.ObjectMeta + yyv3260.CodecDecodeSelf(d) } - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41683,16 +41601,16 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NodeSpec{} } else { - yyv3270 := &x.Spec - yyv3270.CodecDecodeSelf(d) + yyv3261 := &x.Spec + yyv3261.CodecDecodeSelf(d) } - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41700,21 +41618,21 @@ func (x *Node) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = NodeStatus{} } else { - yyv3271 := &x.Status - yyv3271.CodecDecodeSelf(d) + yyv3262 := &x.Status + yyv3262.CodecDecodeSelf(d) } for { - yyj3266++ - if yyhl3266 { - yyb3266 = yyj3266 > l + yyj3257++ + if yyhl3257 { + yyb3257 = yyj3257 > l } else { - yyb3266 = r.CheckBreak() + yyb3257 = r.CheckBreak() } - if yyb3266 { + if yyb3257 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3266-1, "") + z.DecStructFieldNotFound(yyj3257-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -41726,37 +41644,37 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3272 := z.EncBinary() - _ = yym3272 + yym3263 := z.EncBinary() + _ = yym3263 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3273 := !z.EncBinary() - yy2arr3273 := z.EncBasicHandle().StructToArray - var yyq3273 [4]bool - _, _, _ = yysep3273, yyq3273, yy2arr3273 - const yyr3273 bool = false - yyq3273[0] = x.Kind != "" - yyq3273[1] = x.APIVersion != "" - yyq3273[2] = true - var yynn3273 int - if yyr3273 || yy2arr3273 { + yysep3264 := !z.EncBinary() + yy2arr3264 := z.EncBasicHandle().StructToArray + var yyq3264 [4]bool + _, _, _ = yysep3264, yyq3264, yy2arr3264 + const yyr3264 bool = false + yyq3264[0] = x.Kind != "" + yyq3264[1] = x.APIVersion != "" + yyq3264[2] = true + var yynn3264 int + if yyr3264 || yy2arr3264 { r.EncodeArrayStart(4) } else { - yynn3273 = 1 - for _, b := range yyq3273 { + yynn3264 = 1 + for _, b := range yyq3264 { if b { - yynn3273++ + yynn3264++ } } - r.EncodeMapStart(yynn3273) - yynn3273 = 0 + r.EncodeMapStart(yynn3264) + yynn3264 = 0 } - if yyr3273 || yy2arr3273 { + if yyr3264 || yy2arr3264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3273[0] { - yym3275 := z.EncBinary() - _ = yym3275 + if yyq3264[0] { + yym3266 := z.EncBinary() + _ = yym3266 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -41765,23 +41683,23 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3273[0] { + if yyq3264[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3276 := z.EncBinary() - _ = yym3276 + yym3267 := z.EncBinary() + _ = yym3267 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3273 || yy2arr3273 { + if yyr3264 || yy2arr3264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3273[1] { - yym3278 := z.EncBinary() - _ = yym3278 + if yyq3264[1] { + yym3269 := z.EncBinary() + _ = yym3269 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -41790,54 +41708,54 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3273[1] { + if yyq3264[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3279 := z.EncBinary() - _ = yym3279 + yym3270 := z.EncBinary() + _ = yym3270 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3273 || yy2arr3273 { + if yyr3264 || yy2arr3264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3273[2] { - yy3281 := &x.ListMeta - yym3282 := z.EncBinary() - _ = yym3282 + if yyq3264[2] { + yy3272 := &x.ListMeta + yym3273 := z.EncBinary() + _ = yym3273 if false { - } else if z.HasExtensions() && z.EncExt(yy3281) { + } else if z.HasExtensions() && z.EncExt(yy3272) { } else { - z.EncFallback(yy3281) + z.EncFallback(yy3272) } } else { r.EncodeNil() } } else { - if yyq3273[2] { + if yyq3264[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3283 := &x.ListMeta - yym3284 := z.EncBinary() - _ = yym3284 + yy3274 := &x.ListMeta + yym3275 := z.EncBinary() + _ = yym3275 if false { - } else if z.HasExtensions() && z.EncExt(yy3283) { + } else if z.HasExtensions() && z.EncExt(yy3274) { } else { - z.EncFallback(yy3283) + z.EncFallback(yy3274) } } } - if yyr3273 || yy2arr3273 { + if yyr3264 || yy2arr3264 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym3286 := z.EncBinary() - _ = yym3286 + yym3277 := z.EncBinary() + _ = yym3277 if false { } else { h.encSliceNode(([]Node)(x.Items), e) @@ -41850,15 +41768,15 @@ func (x *NodeList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym3287 := z.EncBinary() - _ = yym3287 + yym3278 := z.EncBinary() + _ = yym3278 if false { } else { h.encSliceNode(([]Node)(x.Items), e) } } } - if yyr3273 || yy2arr3273 { + if yyr3264 || yy2arr3264 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -41871,25 +41789,25 @@ func (x *NodeList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3288 := z.DecBinary() - _ = yym3288 + yym3279 := z.DecBinary() + _ = yym3279 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3289 := r.ContainerType() - if yyct3289 == codecSelferValueTypeMap1234 { - yyl3289 := r.ReadMapStart() - if yyl3289 == 0 { + yyct3280 := r.ContainerType() + if yyct3280 == codecSelferValueTypeMap1234 { + yyl3280 := r.ReadMapStart() + if yyl3280 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3289, d) + x.codecDecodeSelfFromMap(yyl3280, d) } - } else if yyct3289 == codecSelferValueTypeArray1234 { - yyl3289 := r.ReadArrayStart() - if yyl3289 == 0 { + } else if yyct3280 == codecSelferValueTypeArray1234 { + yyl3280 := r.ReadArrayStart() + if yyl3280 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3289, d) + x.codecDecodeSelfFromArray(yyl3280, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -41901,12 +41819,12 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3290Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3290Slc - var yyhl3290 bool = l >= 0 - for yyj3290 := 0; ; yyj3290++ { - if yyhl3290 { - if yyj3290 >= l { + var yys3281Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3281Slc + var yyhl3281 bool = l >= 0 + for yyj3281 := 0; ; yyj3281++ { + if yyhl3281 { + if yyj3281 >= l { break } } else { @@ -41915,10 +41833,10 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3290Slc = r.DecodeBytes(yys3290Slc, true, true) - yys3290 := string(yys3290Slc) + yys3281Slc = r.DecodeBytes(yys3281Slc, true, true) + yys3281 := string(yys3281Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3290 { + switch yys3281 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -41935,31 +41853,31 @@ func (x *NodeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3293 := &x.ListMeta - yym3294 := z.DecBinary() - _ = yym3294 + yyv3284 := &x.ListMeta + yym3285 := z.DecBinary() + _ = yym3285 if false { - } else if z.HasExtensions() && z.DecExt(yyv3293) { + } else if z.HasExtensions() && z.DecExt(yyv3284) { } else { - z.DecFallback(yyv3293, false) + z.DecFallback(yyv3284, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3295 := &x.Items - yym3296 := z.DecBinary() - _ = yym3296 + yyv3286 := &x.Items + yym3287 := z.DecBinary() + _ = yym3287 if false { } else { - h.decSliceNode((*[]Node)(yyv3295), d) + h.decSliceNode((*[]Node)(yyv3286), d) } } default: - z.DecStructFieldNotFound(-1, yys3290) - } // end switch yys3290 - } // end for yyj3290 + z.DecStructFieldNotFound(-1, yys3281) + } // end switch yys3281 + } // end for yyj3281 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -41967,16 +41885,16 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3297 int - var yyb3297 bool - var yyhl3297 bool = l >= 0 - yyj3297++ - if yyhl3297 { - yyb3297 = yyj3297 > l + var yyj3288 int + var yyb3288 bool + var yyhl3288 bool = l >= 0 + yyj3288++ + if yyhl3288 { + yyb3288 = yyj3288 > l } else { - yyb3297 = r.CheckBreak() + yyb3288 = r.CheckBreak() } - if yyb3297 { + if yyb3288 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -41986,13 +41904,13 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3297++ - if yyhl3297 { - yyb3297 = yyj3297 > l + yyj3288++ + if yyhl3288 { + yyb3288 = yyj3288 > l } else { - yyb3297 = r.CheckBreak() + yyb3288 = r.CheckBreak() } - if yyb3297 { + if yyb3288 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42002,13 +41920,13 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3297++ - if yyhl3297 { - yyb3297 = yyj3297 > l + yyj3288++ + if yyhl3288 { + yyb3288 = yyj3288 > l } else { - yyb3297 = r.CheckBreak() + yyb3288 = r.CheckBreak() } - if yyb3297 { + if yyb3288 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42016,22 +41934,22 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3300 := &x.ListMeta - yym3301 := z.DecBinary() - _ = yym3301 + yyv3291 := &x.ListMeta + yym3292 := z.DecBinary() + _ = yym3292 if false { - } else if z.HasExtensions() && z.DecExt(yyv3300) { + } else if z.HasExtensions() && z.DecExt(yyv3291) { } else { - z.DecFallback(yyv3300, false) + z.DecFallback(yyv3291, false) } } - yyj3297++ - if yyhl3297 { - yyb3297 = yyj3297 > l + yyj3288++ + if yyhl3288 { + yyb3288 = yyj3288 > l } else { - yyb3297 = r.CheckBreak() + yyb3288 = r.CheckBreak() } - if yyb3297 { + if yyb3288 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42039,26 +41957,26 @@ func (x *NodeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3302 := &x.Items - yym3303 := z.DecBinary() - _ = yym3303 + yyv3293 := &x.Items + yym3294 := z.DecBinary() + _ = yym3294 if false { } else { - h.decSliceNode((*[]Node)(yyv3302), d) + h.decSliceNode((*[]Node)(yyv3293), d) } } for { - yyj3297++ - if yyhl3297 { - yyb3297 = yyj3297 > l + yyj3288++ + if yyhl3288 { + yyb3288 = yyj3288 > l } else { - yyb3297 = r.CheckBreak() + yyb3288 = r.CheckBreak() } - if yyb3297 { + if yyb3288 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3297-1, "") + z.DecStructFieldNotFound(yyj3288-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42067,8 +41985,8 @@ func (x FinalizerName) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3304 := z.EncBinary() - _ = yym3304 + yym3295 := z.EncBinary() + _ = yym3295 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -42080,8 +41998,8 @@ func (x *FinalizerName) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3305 := z.DecBinary() - _ = yym3305 + yym3296 := z.DecBinary() + _ = yym3296 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -42096,38 +42014,38 @@ func (x *NamespaceSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3306 := z.EncBinary() - _ = yym3306 + yym3297 := z.EncBinary() + _ = yym3297 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3307 := !z.EncBinary() - yy2arr3307 := z.EncBasicHandle().StructToArray - var yyq3307 [1]bool - _, _, _ = yysep3307, yyq3307, yy2arr3307 - const yyr3307 bool = false - yyq3307[0] = len(x.Finalizers) != 0 - var yynn3307 int - if yyr3307 || yy2arr3307 { + yysep3298 := !z.EncBinary() + yy2arr3298 := z.EncBasicHandle().StructToArray + var yyq3298 [1]bool + _, _, _ = yysep3298, yyq3298, yy2arr3298 + const yyr3298 bool = false + yyq3298[0] = len(x.Finalizers) != 0 + var yynn3298 int + if yyr3298 || yy2arr3298 { r.EncodeArrayStart(1) } else { - yynn3307 = 0 - for _, b := range yyq3307 { + yynn3298 = 0 + for _, b := range yyq3298 { if b { - yynn3307++ + yynn3298++ } } - r.EncodeMapStart(yynn3307) - yynn3307 = 0 + r.EncodeMapStart(yynn3298) + yynn3298 = 0 } - if yyr3307 || yy2arr3307 { + if yyr3298 || yy2arr3298 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3307[0] { + if yyq3298[0] { if x.Finalizers == nil { r.EncodeNil() } else { - yym3309 := z.EncBinary() - _ = yym3309 + yym3300 := z.EncBinary() + _ = yym3300 if false { } else { h.encSliceFinalizerName(([]FinalizerName)(x.Finalizers), e) @@ -42137,15 +42055,15 @@ func (x *NamespaceSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3307[0] { + if yyq3298[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("finalizers")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Finalizers == nil { r.EncodeNil() } else { - yym3310 := z.EncBinary() - _ = yym3310 + yym3301 := z.EncBinary() + _ = yym3301 if false { } else { h.encSliceFinalizerName(([]FinalizerName)(x.Finalizers), e) @@ -42153,7 +42071,7 @@ func (x *NamespaceSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3307 || yy2arr3307 { + if yyr3298 || yy2arr3298 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42166,25 +42084,25 @@ func (x *NamespaceSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3311 := z.DecBinary() - _ = yym3311 + yym3302 := z.DecBinary() + _ = yym3302 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3312 := r.ContainerType() - if yyct3312 == codecSelferValueTypeMap1234 { - yyl3312 := r.ReadMapStart() - if yyl3312 == 0 { + yyct3303 := r.ContainerType() + if yyct3303 == codecSelferValueTypeMap1234 { + yyl3303 := r.ReadMapStart() + if yyl3303 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3312, d) + x.codecDecodeSelfFromMap(yyl3303, d) } - } else if yyct3312 == codecSelferValueTypeArray1234 { - yyl3312 := r.ReadArrayStart() - if yyl3312 == 0 { + } else if yyct3303 == codecSelferValueTypeArray1234 { + yyl3303 := r.ReadArrayStart() + if yyl3303 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3312, d) + x.codecDecodeSelfFromArray(yyl3303, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42196,12 +42114,12 @@ func (x *NamespaceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3313Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3313Slc - var yyhl3313 bool = l >= 0 - for yyj3313 := 0; ; yyj3313++ { - if yyhl3313 { - if yyj3313 >= l { + var yys3304Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3304Slc + var yyhl3304 bool = l >= 0 + for yyj3304 := 0; ; yyj3304++ { + if yyhl3304 { + if yyj3304 >= l { break } } else { @@ -42210,26 +42128,26 @@ func (x *NamespaceSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3313Slc = r.DecodeBytes(yys3313Slc, true, true) - yys3313 := string(yys3313Slc) + yys3304Slc = r.DecodeBytes(yys3304Slc, true, true) + yys3304 := string(yys3304Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3313 { + switch yys3304 { case "finalizers": if r.TryDecodeAsNil() { x.Finalizers = nil } else { - yyv3314 := &x.Finalizers - yym3315 := z.DecBinary() - _ = yym3315 + yyv3305 := &x.Finalizers + yym3306 := z.DecBinary() + _ = yym3306 if false { } else { - h.decSliceFinalizerName((*[]FinalizerName)(yyv3314), d) + h.decSliceFinalizerName((*[]FinalizerName)(yyv3305), d) } } default: - z.DecStructFieldNotFound(-1, yys3313) - } // end switch yys3313 - } // end for yyj3313 + z.DecStructFieldNotFound(-1, yys3304) + } // end switch yys3304 + } // end for yyj3304 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42237,16 +42155,16 @@ func (x *NamespaceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3316 int - var yyb3316 bool - var yyhl3316 bool = l >= 0 - yyj3316++ - if yyhl3316 { - yyb3316 = yyj3316 > l + var yyj3307 int + var yyb3307 bool + var yyhl3307 bool = l >= 0 + yyj3307++ + if yyhl3307 { + yyb3307 = yyj3307 > l } else { - yyb3316 = r.CheckBreak() + yyb3307 = r.CheckBreak() } - if yyb3316 { + if yyb3307 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42254,26 +42172,26 @@ func (x *NamespaceSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Finalizers = nil } else { - yyv3317 := &x.Finalizers - yym3318 := z.DecBinary() - _ = yym3318 + yyv3308 := &x.Finalizers + yym3309 := z.DecBinary() + _ = yym3309 if false { } else { - h.decSliceFinalizerName((*[]FinalizerName)(yyv3317), d) + h.decSliceFinalizerName((*[]FinalizerName)(yyv3308), d) } } for { - yyj3316++ - if yyhl3316 { - yyb3316 = yyj3316 > l + yyj3307++ + if yyhl3307 { + yyb3307 = yyj3307 > l } else { - yyb3316 = r.CheckBreak() + yyb3307 = r.CheckBreak() } - if yyb3316 { + if yyb3307 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3316-1, "") + z.DecStructFieldNotFound(yyj3307-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42285,46 +42203,46 @@ func (x *NamespaceStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3319 := z.EncBinary() - _ = yym3319 + yym3310 := z.EncBinary() + _ = yym3310 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3320 := !z.EncBinary() - yy2arr3320 := z.EncBasicHandle().StructToArray - var yyq3320 [1]bool - _, _, _ = yysep3320, yyq3320, yy2arr3320 - const yyr3320 bool = false - yyq3320[0] = x.Phase != "" - var yynn3320 int - if yyr3320 || yy2arr3320 { + yysep3311 := !z.EncBinary() + yy2arr3311 := z.EncBasicHandle().StructToArray + var yyq3311 [1]bool + _, _, _ = yysep3311, yyq3311, yy2arr3311 + const yyr3311 bool = false + yyq3311[0] = x.Phase != "" + var yynn3311 int + if yyr3311 || yy2arr3311 { r.EncodeArrayStart(1) } else { - yynn3320 = 0 - for _, b := range yyq3320 { + yynn3311 = 0 + for _, b := range yyq3311 { if b { - yynn3320++ + yynn3311++ } } - r.EncodeMapStart(yynn3320) - yynn3320 = 0 + r.EncodeMapStart(yynn3311) + yynn3311 = 0 } - if yyr3320 || yy2arr3320 { + if yyr3311 || yy2arr3311 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3320[0] { + if yyq3311[0] { x.Phase.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3320[0] { + if yyq3311[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("phase")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Phase.CodecEncodeSelf(e) } } - if yyr3320 || yy2arr3320 { + if yyr3311 || yy2arr3311 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42337,25 +42255,25 @@ func (x *NamespaceStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3322 := z.DecBinary() - _ = yym3322 + yym3313 := z.DecBinary() + _ = yym3313 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3323 := r.ContainerType() - if yyct3323 == codecSelferValueTypeMap1234 { - yyl3323 := r.ReadMapStart() - if yyl3323 == 0 { + yyct3314 := r.ContainerType() + if yyct3314 == codecSelferValueTypeMap1234 { + yyl3314 := r.ReadMapStart() + if yyl3314 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3323, d) + x.codecDecodeSelfFromMap(yyl3314, d) } - } else if yyct3323 == codecSelferValueTypeArray1234 { - yyl3323 := r.ReadArrayStart() - if yyl3323 == 0 { + } else if yyct3314 == codecSelferValueTypeArray1234 { + yyl3314 := r.ReadArrayStart() + if yyl3314 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3323, d) + x.codecDecodeSelfFromArray(yyl3314, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42367,12 +42285,12 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3324Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3324Slc - var yyhl3324 bool = l >= 0 - for yyj3324 := 0; ; yyj3324++ { - if yyhl3324 { - if yyj3324 >= l { + var yys3315Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3315Slc + var yyhl3315 bool = l >= 0 + for yyj3315 := 0; ; yyj3315++ { + if yyhl3315 { + if yyj3315 >= l { break } } else { @@ -42381,10 +42299,10 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3324Slc = r.DecodeBytes(yys3324Slc, true, true) - yys3324 := string(yys3324Slc) + yys3315Slc = r.DecodeBytes(yys3315Slc, true, true) + yys3315 := string(yys3315Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3324 { + switch yys3315 { case "phase": if r.TryDecodeAsNil() { x.Phase = "" @@ -42392,9 +42310,9 @@ func (x *NamespaceStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Phase = NamespacePhase(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3324) - } // end switch yys3324 - } // end for yyj3324 + z.DecStructFieldNotFound(-1, yys3315) + } // end switch yys3315 + } // end for yyj3315 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42402,16 +42320,16 @@ func (x *NamespaceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3326 int - var yyb3326 bool - var yyhl3326 bool = l >= 0 - yyj3326++ - if yyhl3326 { - yyb3326 = yyj3326 > l + var yyj3317 int + var yyb3317 bool + var yyhl3317 bool = l >= 0 + yyj3317++ + if yyhl3317 { + yyb3317 = yyj3317 > l } else { - yyb3326 = r.CheckBreak() + yyb3317 = r.CheckBreak() } - if yyb3326 { + if yyb3317 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42422,17 +42340,17 @@ func (x *NamespaceStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Phase = NamespacePhase(r.DecodeString()) } for { - yyj3326++ - if yyhl3326 { - yyb3326 = yyj3326 > l + yyj3317++ + if yyhl3317 { + yyb3317 = yyj3317 > l } else { - yyb3326 = r.CheckBreak() + yyb3317 = r.CheckBreak() } - if yyb3326 { + if yyb3317 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3326-1, "") + z.DecStructFieldNotFound(yyj3317-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42441,8 +42359,8 @@ func (x NamespacePhase) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym3328 := z.EncBinary() - _ = yym3328 + yym3319 := z.EncBinary() + _ = yym3319 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -42454,8 +42372,8 @@ func (x *NamespacePhase) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3329 := z.DecBinary() - _ = yym3329 + yym3320 := z.DecBinary() + _ = yym3320 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -42470,39 +42388,39 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3330 := z.EncBinary() - _ = yym3330 + yym3321 := z.EncBinary() + _ = yym3321 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3331 := !z.EncBinary() - yy2arr3331 := z.EncBasicHandle().StructToArray - var yyq3331 [5]bool - _, _, _ = yysep3331, yyq3331, yy2arr3331 - const yyr3331 bool = false - yyq3331[0] = x.Kind != "" - yyq3331[1] = x.APIVersion != "" - yyq3331[2] = true - yyq3331[3] = true - yyq3331[4] = true - var yynn3331 int - if yyr3331 || yy2arr3331 { + yysep3322 := !z.EncBinary() + yy2arr3322 := z.EncBasicHandle().StructToArray + var yyq3322 [5]bool + _, _, _ = yysep3322, yyq3322, yy2arr3322 + const yyr3322 bool = false + yyq3322[0] = x.Kind != "" + yyq3322[1] = x.APIVersion != "" + yyq3322[2] = true + yyq3322[3] = true + yyq3322[4] = true + var yynn3322 int + if yyr3322 || yy2arr3322 { r.EncodeArrayStart(5) } else { - yynn3331 = 0 - for _, b := range yyq3331 { + yynn3322 = 0 + for _, b := range yyq3322 { if b { - yynn3331++ + yynn3322++ } } - r.EncodeMapStart(yynn3331) - yynn3331 = 0 + r.EncodeMapStart(yynn3322) + yynn3322 = 0 } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3331[0] { - yym3333 := z.EncBinary() - _ = yym3333 + if yyq3322[0] { + yym3324 := z.EncBinary() + _ = yym3324 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -42511,23 +42429,23 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3331[0] { + if yyq3322[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3334 := z.EncBinary() - _ = yym3334 + yym3325 := z.EncBinary() + _ = yym3325 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3331[1] { - yym3336 := z.EncBinary() - _ = yym3336 + if yyq3322[1] { + yym3327 := z.EncBinary() + _ = yym3327 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -42536,70 +42454,70 @@ func (x *Namespace) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3331[1] { + if yyq3322[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3337 := z.EncBinary() - _ = yym3337 + yym3328 := z.EncBinary() + _ = yym3328 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3331[2] { - yy3339 := &x.ObjectMeta - yy3339.CodecEncodeSelf(e) + if yyq3322[2] { + yy3330 := &x.ObjectMeta + yy3330.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3331[2] { + if yyq3322[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3340 := &x.ObjectMeta - yy3340.CodecEncodeSelf(e) + yy3331 := &x.ObjectMeta + yy3331.CodecEncodeSelf(e) } } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3331[3] { - yy3342 := &x.Spec - yy3342.CodecEncodeSelf(e) + if yyq3322[3] { + yy3333 := &x.Spec + yy3333.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3331[3] { + if yyq3322[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3343 := &x.Spec - yy3343.CodecEncodeSelf(e) + yy3334 := &x.Spec + yy3334.CodecEncodeSelf(e) } } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3331[4] { - yy3345 := &x.Status - yy3345.CodecEncodeSelf(e) + if yyq3322[4] { + yy3336 := &x.Status + yy3336.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3331[4] { + if yyq3322[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3346 := &x.Status - yy3346.CodecEncodeSelf(e) + yy3337 := &x.Status + yy3337.CodecEncodeSelf(e) } } - if yyr3331 || yy2arr3331 { + if yyr3322 || yy2arr3322 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42612,25 +42530,25 @@ func (x *Namespace) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3347 := z.DecBinary() - _ = yym3347 + yym3338 := z.DecBinary() + _ = yym3338 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3348 := r.ContainerType() - if yyct3348 == codecSelferValueTypeMap1234 { - yyl3348 := r.ReadMapStart() - if yyl3348 == 0 { + yyct3339 := r.ContainerType() + if yyct3339 == codecSelferValueTypeMap1234 { + yyl3339 := r.ReadMapStart() + if yyl3339 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3348, d) + x.codecDecodeSelfFromMap(yyl3339, d) } - } else if yyct3348 == codecSelferValueTypeArray1234 { - yyl3348 := r.ReadArrayStart() - if yyl3348 == 0 { + } else if yyct3339 == codecSelferValueTypeArray1234 { + yyl3339 := r.ReadArrayStart() + if yyl3339 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3348, d) + x.codecDecodeSelfFromArray(yyl3339, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42642,12 +42560,12 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3349Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3349Slc - var yyhl3349 bool = l >= 0 - for yyj3349 := 0; ; yyj3349++ { - if yyhl3349 { - if yyj3349 >= l { + var yys3340Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3340Slc + var yyhl3340 bool = l >= 0 + for yyj3340 := 0; ; yyj3340++ { + if yyhl3340 { + if yyj3340 >= l { break } } else { @@ -42656,10 +42574,10 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3349Slc = r.DecodeBytes(yys3349Slc, true, true) - yys3349 := string(yys3349Slc) + yys3340Slc = r.DecodeBytes(yys3340Slc, true, true) + yys3340 := string(yys3340Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3349 { + switch yys3340 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -42676,27 +42594,27 @@ func (x *Namespace) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3352 := &x.ObjectMeta - yyv3352.CodecDecodeSelf(d) + yyv3343 := &x.ObjectMeta + yyv3343.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NamespaceSpec{} } else { - yyv3353 := &x.Spec - yyv3353.CodecDecodeSelf(d) + yyv3344 := &x.Spec + yyv3344.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = NamespaceStatus{} } else { - yyv3354 := &x.Status - yyv3354.CodecDecodeSelf(d) + yyv3345 := &x.Status + yyv3345.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3349) - } // end switch yys3349 - } // end for yyj3349 + z.DecStructFieldNotFound(-1, yys3340) + } // end switch yys3340 + } // end for yyj3340 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -42704,16 +42622,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3355 int - var yyb3355 bool - var yyhl3355 bool = l >= 0 - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + var yyj3346 int + var yyb3346 bool + var yyhl3346 bool = l >= 0 + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42723,13 +42641,13 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42739,13 +42657,13 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42753,16 +42671,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3358 := &x.ObjectMeta - yyv3358.CodecDecodeSelf(d) + yyv3349 := &x.ObjectMeta + yyv3349.CodecDecodeSelf(d) } - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42770,16 +42688,16 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NamespaceSpec{} } else { - yyv3359 := &x.Spec - yyv3359.CodecDecodeSelf(d) + yyv3350 := &x.Spec + yyv3350.CodecDecodeSelf(d) } - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -42787,21 +42705,21 @@ func (x *Namespace) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = NamespaceStatus{} } else { - yyv3360 := &x.Status - yyv3360.CodecDecodeSelf(d) + yyv3351 := &x.Status + yyv3351.CodecDecodeSelf(d) } for { - yyj3355++ - if yyhl3355 { - yyb3355 = yyj3355 > l + yyj3346++ + if yyhl3346 { + yyb3346 = yyj3346 > l } else { - yyb3355 = r.CheckBreak() + yyb3346 = r.CheckBreak() } - if yyb3355 { + if yyb3346 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3355-1, "") + z.DecStructFieldNotFound(yyj3346-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -42813,37 +42731,37 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3361 := z.EncBinary() - _ = yym3361 + yym3352 := z.EncBinary() + _ = yym3352 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3362 := !z.EncBinary() - yy2arr3362 := z.EncBasicHandle().StructToArray - var yyq3362 [4]bool - _, _, _ = yysep3362, yyq3362, yy2arr3362 - const yyr3362 bool = false - yyq3362[0] = x.Kind != "" - yyq3362[1] = x.APIVersion != "" - yyq3362[2] = true - var yynn3362 int - if yyr3362 || yy2arr3362 { + yysep3353 := !z.EncBinary() + yy2arr3353 := z.EncBasicHandle().StructToArray + var yyq3353 [4]bool + _, _, _ = yysep3353, yyq3353, yy2arr3353 + const yyr3353 bool = false + yyq3353[0] = x.Kind != "" + yyq3353[1] = x.APIVersion != "" + yyq3353[2] = true + var yynn3353 int + if yyr3353 || yy2arr3353 { r.EncodeArrayStart(4) } else { - yynn3362 = 1 - for _, b := range yyq3362 { + yynn3353 = 1 + for _, b := range yyq3353 { if b { - yynn3362++ + yynn3353++ } } - r.EncodeMapStart(yynn3362) - yynn3362 = 0 + r.EncodeMapStart(yynn3353) + yynn3353 = 0 } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3362[0] { - yym3364 := z.EncBinary() - _ = yym3364 + if yyq3353[0] { + yym3355 := z.EncBinary() + _ = yym3355 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -42852,23 +42770,23 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3362[0] { + if yyq3353[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3365 := z.EncBinary() - _ = yym3365 + yym3356 := z.EncBinary() + _ = yym3356 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3362[1] { - yym3367 := z.EncBinary() - _ = yym3367 + if yyq3353[1] { + yym3358 := z.EncBinary() + _ = yym3358 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -42877,54 +42795,54 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3362[1] { + if yyq3353[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3368 := z.EncBinary() - _ = yym3368 + yym3359 := z.EncBinary() + _ = yym3359 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3362[2] { - yy3370 := &x.ListMeta - yym3371 := z.EncBinary() - _ = yym3371 + if yyq3353[2] { + yy3361 := &x.ListMeta + yym3362 := z.EncBinary() + _ = yym3362 if false { - } else if z.HasExtensions() && z.EncExt(yy3370) { + } else if z.HasExtensions() && z.EncExt(yy3361) { } else { - z.EncFallback(yy3370) + z.EncFallback(yy3361) } } else { r.EncodeNil() } } else { - if yyq3362[2] { + if yyq3353[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3372 := &x.ListMeta - yym3373 := z.EncBinary() - _ = yym3373 + yy3363 := &x.ListMeta + yym3364 := z.EncBinary() + _ = yym3364 if false { - } else if z.HasExtensions() && z.EncExt(yy3372) { + } else if z.HasExtensions() && z.EncExt(yy3363) { } else { - z.EncFallback(yy3372) + z.EncFallback(yy3363) } } } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym3375 := z.EncBinary() - _ = yym3375 + yym3366 := z.EncBinary() + _ = yym3366 if false { } else { h.encSliceNamespace(([]Namespace)(x.Items), e) @@ -42937,15 +42855,15 @@ func (x *NamespaceList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym3376 := z.EncBinary() - _ = yym3376 + yym3367 := z.EncBinary() + _ = yym3367 if false { } else { h.encSliceNamespace(([]Namespace)(x.Items), e) } } } - if yyr3362 || yy2arr3362 { + if yyr3353 || yy2arr3353 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -42958,25 +42876,25 @@ func (x *NamespaceList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3377 := z.DecBinary() - _ = yym3377 + yym3368 := z.DecBinary() + _ = yym3368 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3378 := r.ContainerType() - if yyct3378 == codecSelferValueTypeMap1234 { - yyl3378 := r.ReadMapStart() - if yyl3378 == 0 { + yyct3369 := r.ContainerType() + if yyct3369 == codecSelferValueTypeMap1234 { + yyl3369 := r.ReadMapStart() + if yyl3369 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3378, d) + x.codecDecodeSelfFromMap(yyl3369, d) } - } else if yyct3378 == codecSelferValueTypeArray1234 { - yyl3378 := r.ReadArrayStart() - if yyl3378 == 0 { + } else if yyct3369 == codecSelferValueTypeArray1234 { + yyl3369 := r.ReadArrayStart() + if yyl3369 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3378, d) + x.codecDecodeSelfFromArray(yyl3369, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -42988,12 +42906,12 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3379Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3379Slc - var yyhl3379 bool = l >= 0 - for yyj3379 := 0; ; yyj3379++ { - if yyhl3379 { - if yyj3379 >= l { + var yys3370Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3370Slc + var yyhl3370 bool = l >= 0 + for yyj3370 := 0; ; yyj3370++ { + if yyhl3370 { + if yyj3370 >= l { break } } else { @@ -43002,10 +42920,10 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3379Slc = r.DecodeBytes(yys3379Slc, true, true) - yys3379 := string(yys3379Slc) + yys3370Slc = r.DecodeBytes(yys3370Slc, true, true) + yys3370 := string(yys3370Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3379 { + switch yys3370 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -43022,31 +42940,31 @@ func (x *NamespaceList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3382 := &x.ListMeta - yym3383 := z.DecBinary() - _ = yym3383 + yyv3373 := &x.ListMeta + yym3374 := z.DecBinary() + _ = yym3374 if false { - } else if z.HasExtensions() && z.DecExt(yyv3382) { + } else if z.HasExtensions() && z.DecExt(yyv3373) { } else { - z.DecFallback(yyv3382, false) + z.DecFallback(yyv3373, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3384 := &x.Items - yym3385 := z.DecBinary() - _ = yym3385 + yyv3375 := &x.Items + yym3376 := z.DecBinary() + _ = yym3376 if false { } else { - h.decSliceNamespace((*[]Namespace)(yyv3384), d) + h.decSliceNamespace((*[]Namespace)(yyv3375), d) } } default: - z.DecStructFieldNotFound(-1, yys3379) - } // end switch yys3379 - } // end for yyj3379 + z.DecStructFieldNotFound(-1, yys3370) + } // end switch yys3370 + } // end for yyj3370 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43054,16 +42972,16 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3386 int - var yyb3386 bool - var yyhl3386 bool = l >= 0 - yyj3386++ - if yyhl3386 { - yyb3386 = yyj3386 > l + var yyj3377 int + var yyb3377 bool + var yyhl3377 bool = l >= 0 + yyj3377++ + if yyhl3377 { + yyb3377 = yyj3377 > l } else { - yyb3386 = r.CheckBreak() + yyb3377 = r.CheckBreak() } - if yyb3386 { + if yyb3377 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43073,13 +42991,13 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3386++ - if yyhl3386 { - yyb3386 = yyj3386 > l + yyj3377++ + if yyhl3377 { + yyb3377 = yyj3377 > l } else { - yyb3386 = r.CheckBreak() + yyb3377 = r.CheckBreak() } - if yyb3386 { + if yyb3377 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43089,13 +43007,13 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3386++ - if yyhl3386 { - yyb3386 = yyj3386 > l + yyj3377++ + if yyhl3377 { + yyb3377 = yyj3377 > l } else { - yyb3386 = r.CheckBreak() + yyb3377 = r.CheckBreak() } - if yyb3386 { + if yyb3377 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43103,22 +43021,22 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3389 := &x.ListMeta - yym3390 := z.DecBinary() - _ = yym3390 + yyv3380 := &x.ListMeta + yym3381 := z.DecBinary() + _ = yym3381 if false { - } else if z.HasExtensions() && z.DecExt(yyv3389) { + } else if z.HasExtensions() && z.DecExt(yyv3380) { } else { - z.DecFallback(yyv3389, false) + z.DecFallback(yyv3380, false) } } - yyj3386++ - if yyhl3386 { - yyb3386 = yyj3386 > l + yyj3377++ + if yyhl3377 { + yyb3377 = yyj3377 > l } else { - yyb3386 = r.CheckBreak() + yyb3377 = r.CheckBreak() } - if yyb3386 { + if yyb3377 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43126,26 +43044,26 @@ func (x *NamespaceList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3391 := &x.Items - yym3392 := z.DecBinary() - _ = yym3392 + yyv3382 := &x.Items + yym3383 := z.DecBinary() + _ = yym3383 if false { } else { - h.decSliceNamespace((*[]Namespace)(yyv3391), d) + h.decSliceNamespace((*[]Namespace)(yyv3382), d) } } for { - yyj3386++ - if yyhl3386 { - yyb3386 = yyj3386 > l + yyj3377++ + if yyhl3377 { + yyb3377 = yyj3377 > l } else { - yyb3386 = r.CheckBreak() + yyb3377 = r.CheckBreak() } - if yyb3386 { + if yyb3377 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3386-1, "") + z.DecStructFieldNotFound(yyj3377-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43157,37 +43075,37 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3393 := z.EncBinary() - _ = yym3393 + yym3384 := z.EncBinary() + _ = yym3384 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3394 := !z.EncBinary() - yy2arr3394 := z.EncBasicHandle().StructToArray - var yyq3394 [4]bool - _, _, _ = yysep3394, yyq3394, yy2arr3394 - const yyr3394 bool = false - yyq3394[0] = x.Kind != "" - yyq3394[1] = x.APIVersion != "" - yyq3394[2] = true - var yynn3394 int - if yyr3394 || yy2arr3394 { + yysep3385 := !z.EncBinary() + yy2arr3385 := z.EncBasicHandle().StructToArray + var yyq3385 [4]bool + _, _, _ = yysep3385, yyq3385, yy2arr3385 + const yyr3385 bool = false + yyq3385[0] = x.Kind != "" + yyq3385[1] = x.APIVersion != "" + yyq3385[2] = true + var yynn3385 int + if yyr3385 || yy2arr3385 { r.EncodeArrayStart(4) } else { - yynn3394 = 1 - for _, b := range yyq3394 { + yynn3385 = 1 + for _, b := range yyq3385 { if b { - yynn3394++ + yynn3385++ } } - r.EncodeMapStart(yynn3394) - yynn3394 = 0 + r.EncodeMapStart(yynn3385) + yynn3385 = 0 } - if yyr3394 || yy2arr3394 { + if yyr3385 || yy2arr3385 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3394[0] { - yym3396 := z.EncBinary() - _ = yym3396 + if yyq3385[0] { + yym3387 := z.EncBinary() + _ = yym3387 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -43196,23 +43114,23 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3394[0] { + if yyq3385[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3397 := z.EncBinary() - _ = yym3397 + yym3388 := z.EncBinary() + _ = yym3388 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3394 || yy2arr3394 { + if yyr3385 || yy2arr3385 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3394[1] { - yym3399 := z.EncBinary() - _ = yym3399 + if yyq3385[1] { + yym3390 := z.EncBinary() + _ = yym3390 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -43221,47 +43139,47 @@ func (x *Binding) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3394[1] { + if yyq3385[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3400 := z.EncBinary() - _ = yym3400 + yym3391 := z.EncBinary() + _ = yym3391 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3394 || yy2arr3394 { + if yyr3385 || yy2arr3385 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3394[2] { - yy3402 := &x.ObjectMeta - yy3402.CodecEncodeSelf(e) + if yyq3385[2] { + yy3393 := &x.ObjectMeta + yy3393.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3394[2] { + if yyq3385[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3403 := &x.ObjectMeta - yy3403.CodecEncodeSelf(e) + yy3394 := &x.ObjectMeta + yy3394.CodecEncodeSelf(e) } } - if yyr3394 || yy2arr3394 { + if yyr3385 || yy2arr3385 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3405 := &x.Target - yy3405.CodecEncodeSelf(e) + yy3396 := &x.Target + yy3396.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("target")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3406 := &x.Target - yy3406.CodecEncodeSelf(e) + yy3397 := &x.Target + yy3397.CodecEncodeSelf(e) } - if yyr3394 || yy2arr3394 { + if yyr3385 || yy2arr3385 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43274,25 +43192,25 @@ func (x *Binding) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3407 := z.DecBinary() - _ = yym3407 + yym3398 := z.DecBinary() + _ = yym3398 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3408 := r.ContainerType() - if yyct3408 == codecSelferValueTypeMap1234 { - yyl3408 := r.ReadMapStart() - if yyl3408 == 0 { + yyct3399 := r.ContainerType() + if yyct3399 == codecSelferValueTypeMap1234 { + yyl3399 := r.ReadMapStart() + if yyl3399 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3408, d) + x.codecDecodeSelfFromMap(yyl3399, d) } - } else if yyct3408 == codecSelferValueTypeArray1234 { - yyl3408 := r.ReadArrayStart() - if yyl3408 == 0 { + } else if yyct3399 == codecSelferValueTypeArray1234 { + yyl3399 := r.ReadArrayStart() + if yyl3399 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3408, d) + x.codecDecodeSelfFromArray(yyl3399, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43304,12 +43222,12 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3409Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3409Slc - var yyhl3409 bool = l >= 0 - for yyj3409 := 0; ; yyj3409++ { - if yyhl3409 { - if yyj3409 >= l { + var yys3400Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3400Slc + var yyhl3400 bool = l >= 0 + for yyj3400 := 0; ; yyj3400++ { + if yyhl3400 { + if yyj3400 >= l { break } } else { @@ -43318,10 +43236,10 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3409Slc = r.DecodeBytes(yys3409Slc, true, true) - yys3409 := string(yys3409Slc) + yys3400Slc = r.DecodeBytes(yys3400Slc, true, true) + yys3400 := string(yys3400Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3409 { + switch yys3400 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -43338,20 +43256,20 @@ func (x *Binding) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3412 := &x.ObjectMeta - yyv3412.CodecDecodeSelf(d) + yyv3403 := &x.ObjectMeta + yyv3403.CodecDecodeSelf(d) } case "target": if r.TryDecodeAsNil() { x.Target = ObjectReference{} } else { - yyv3413 := &x.Target - yyv3413.CodecDecodeSelf(d) + yyv3404 := &x.Target + yyv3404.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3409) - } // end switch yys3409 - } // end for yyj3409 + z.DecStructFieldNotFound(-1, yys3400) + } // end switch yys3400 + } // end for yyj3400 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43359,16 +43277,16 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3414 int - var yyb3414 bool - var yyhl3414 bool = l >= 0 - yyj3414++ - if yyhl3414 { - yyb3414 = yyj3414 > l + var yyj3405 int + var yyb3405 bool + var yyhl3405 bool = l >= 0 + yyj3405++ + if yyhl3405 { + yyb3405 = yyj3405 > l } else { - yyb3414 = r.CheckBreak() + yyb3405 = r.CheckBreak() } - if yyb3414 { + if yyb3405 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43378,13 +43296,13 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3414++ - if yyhl3414 { - yyb3414 = yyj3414 > l + yyj3405++ + if yyhl3405 { + yyb3405 = yyj3405 > l } else { - yyb3414 = r.CheckBreak() + yyb3405 = r.CheckBreak() } - if yyb3414 { + if yyb3405 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43394,13 +43312,13 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3414++ - if yyhl3414 { - yyb3414 = yyj3414 > l + yyj3405++ + if yyhl3405 { + yyb3405 = yyj3405 > l } else { - yyb3414 = r.CheckBreak() + yyb3405 = r.CheckBreak() } - if yyb3414 { + if yyb3405 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43408,16 +43326,16 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3417 := &x.ObjectMeta - yyv3417.CodecDecodeSelf(d) + yyv3408 := &x.ObjectMeta + yyv3408.CodecDecodeSelf(d) } - yyj3414++ - if yyhl3414 { - yyb3414 = yyj3414 > l + yyj3405++ + if yyhl3405 { + yyb3405 = yyj3405 > l } else { - yyb3414 = r.CheckBreak() + yyb3405 = r.CheckBreak() } - if yyb3414 { + if yyb3405 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43425,21 +43343,21 @@ func (x *Binding) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Target = ObjectReference{} } else { - yyv3418 := &x.Target - yyv3418.CodecDecodeSelf(d) + yyv3409 := &x.Target + yyv3409.CodecDecodeSelf(d) } for { - yyj3414++ - if yyhl3414 { - yyb3414 = yyj3414 > l + yyj3405++ + if yyhl3405 { + yyb3405 = yyj3405 > l } else { - yyb3414 = r.CheckBreak() + yyb3405 = r.CheckBreak() } - if yyb3414 { + if yyb3405 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3414-1, "") + z.DecStructFieldNotFound(yyj3405-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43451,68 +43369,68 @@ func (x *Preconditions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3419 := z.EncBinary() - _ = yym3419 + yym3410 := z.EncBinary() + _ = yym3410 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3420 := !z.EncBinary() - yy2arr3420 := z.EncBasicHandle().StructToArray - var yyq3420 [1]bool - _, _, _ = yysep3420, yyq3420, yy2arr3420 - const yyr3420 bool = false - yyq3420[0] = x.UID != nil - var yynn3420 int - if yyr3420 || yy2arr3420 { + yysep3411 := !z.EncBinary() + yy2arr3411 := z.EncBasicHandle().StructToArray + var yyq3411 [1]bool + _, _, _ = yysep3411, yyq3411, yy2arr3411 + const yyr3411 bool = false + yyq3411[0] = x.UID != nil + var yynn3411 int + if yyr3411 || yy2arr3411 { r.EncodeArrayStart(1) } else { - yynn3420 = 0 - for _, b := range yyq3420 { + yynn3411 = 0 + for _, b := range yyq3411 { if b { - yynn3420++ + yynn3411++ } } - r.EncodeMapStart(yynn3420) - yynn3420 = 0 + r.EncodeMapStart(yynn3411) + yynn3411 = 0 } - if yyr3420 || yy2arr3420 { + if yyr3411 || yy2arr3411 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3420[0] { + if yyq3411[0] { if x.UID == nil { r.EncodeNil() } else { - yy3422 := *x.UID - yym3423 := z.EncBinary() - _ = yym3423 + yy3413 := *x.UID + yym3414 := z.EncBinary() + _ = yym3414 if false { - } else if z.HasExtensions() && z.EncExt(yy3422) { + } else if z.HasExtensions() && z.EncExt(yy3413) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy3422)) + r.EncodeString(codecSelferC_UTF81234, string(yy3413)) } } } else { r.EncodeNil() } } else { - if yyq3420[0] { + if yyq3411[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("uid")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.UID == nil { r.EncodeNil() } else { - yy3424 := *x.UID - yym3425 := z.EncBinary() - _ = yym3425 + yy3415 := *x.UID + yym3416 := z.EncBinary() + _ = yym3416 if false { - } else if z.HasExtensions() && z.EncExt(yy3424) { + } else if z.HasExtensions() && z.EncExt(yy3415) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy3424)) + r.EncodeString(codecSelferC_UTF81234, string(yy3415)) } } } } - if yyr3420 || yy2arr3420 { + if yyr3411 || yy2arr3411 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43525,25 +43443,25 @@ func (x *Preconditions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3426 := z.DecBinary() - _ = yym3426 + yym3417 := z.DecBinary() + _ = yym3417 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3427 := r.ContainerType() - if yyct3427 == codecSelferValueTypeMap1234 { - yyl3427 := r.ReadMapStart() - if yyl3427 == 0 { + yyct3418 := r.ContainerType() + if yyct3418 == codecSelferValueTypeMap1234 { + yyl3418 := r.ReadMapStart() + if yyl3418 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3427, d) + x.codecDecodeSelfFromMap(yyl3418, d) } - } else if yyct3427 == codecSelferValueTypeArray1234 { - yyl3427 := r.ReadArrayStart() - if yyl3427 == 0 { + } else if yyct3418 == codecSelferValueTypeArray1234 { + yyl3418 := r.ReadArrayStart() + if yyl3418 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3427, d) + x.codecDecodeSelfFromArray(yyl3418, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43555,12 +43473,12 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3428Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3428Slc - var yyhl3428 bool = l >= 0 - for yyj3428 := 0; ; yyj3428++ { - if yyhl3428 { - if yyj3428 >= l { + var yys3419Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3419Slc + var yyhl3419 bool = l >= 0 + for yyj3419 := 0; ; yyj3419++ { + if yyhl3419 { + if yyj3419 >= l { break } } else { @@ -43569,10 +43487,10 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3428Slc = r.DecodeBytes(yys3428Slc, true, true) - yys3428 := string(yys3428Slc) + yys3419Slc = r.DecodeBytes(yys3419Slc, true, true) + yys3419 := string(yys3419Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3428 { + switch yys3419 { case "uid": if r.TryDecodeAsNil() { if x.UID != nil { @@ -43582,8 +43500,8 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.UID == nil { x.UID = new(pkg1_types.UID) } - yym3430 := z.DecBinary() - _ = yym3430 + yym3421 := z.DecBinary() + _ = yym3421 if false { } else if z.HasExtensions() && z.DecExt(x.UID) { } else { @@ -43591,9 +43509,9 @@ func (x *Preconditions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } default: - z.DecStructFieldNotFound(-1, yys3428) - } // end switch yys3428 - } // end for yyj3428 + z.DecStructFieldNotFound(-1, yys3419) + } // end switch yys3419 + } // end for yyj3419 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43601,16 +43519,16 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3431 int - var yyb3431 bool - var yyhl3431 bool = l >= 0 - yyj3431++ - if yyhl3431 { - yyb3431 = yyj3431 > l + var yyj3422 int + var yyb3422 bool + var yyhl3422 bool = l >= 0 + yyj3422++ + if yyhl3422 { + yyb3422 = yyj3422 > l } else { - yyb3431 = r.CheckBreak() + yyb3422 = r.CheckBreak() } - if yyb3431 { + if yyb3422 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43623,8 +43541,8 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.UID == nil { x.UID = new(pkg1_types.UID) } - yym3433 := z.DecBinary() - _ = yym3433 + yym3424 := z.DecBinary() + _ = yym3424 if false { } else if z.HasExtensions() && z.DecExt(x.UID) { } else { @@ -43632,17 +43550,17 @@ func (x *Preconditions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } for { - yyj3431++ - if yyhl3431 { - yyb3431 = yyj3431 > l + yyj3422++ + if yyhl3422 { + yyb3422 = yyj3422 > l } else { - yyb3431 = r.CheckBreak() + yyb3422 = r.CheckBreak() } - if yyb3431 { + if yyb3422 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3431-1, "") + z.DecStructFieldNotFound(yyj3422-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -43654,39 +43572,39 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3434 := z.EncBinary() - _ = yym3434 + yym3425 := z.EncBinary() + _ = yym3425 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3435 := !z.EncBinary() - yy2arr3435 := z.EncBasicHandle().StructToArray - var yyq3435 [5]bool - _, _, _ = yysep3435, yyq3435, yy2arr3435 - const yyr3435 bool = false - yyq3435[0] = x.Kind != "" - yyq3435[1] = x.APIVersion != "" - yyq3435[2] = x.GracePeriodSeconds != nil - yyq3435[3] = x.Preconditions != nil - yyq3435[4] = x.OrphanDependents != nil - var yynn3435 int - if yyr3435 || yy2arr3435 { + yysep3426 := !z.EncBinary() + yy2arr3426 := z.EncBasicHandle().StructToArray + var yyq3426 [5]bool + _, _, _ = yysep3426, yyq3426, yy2arr3426 + const yyr3426 bool = false + yyq3426[0] = x.Kind != "" + yyq3426[1] = x.APIVersion != "" + yyq3426[2] = x.GracePeriodSeconds != nil + yyq3426[3] = x.Preconditions != nil + yyq3426[4] = x.OrphanDependents != nil + var yynn3426 int + if yyr3426 || yy2arr3426 { r.EncodeArrayStart(5) } else { - yynn3435 = 0 - for _, b := range yyq3435 { + yynn3426 = 0 + for _, b := range yyq3426 { if b { - yynn3435++ + yynn3426++ } } - r.EncodeMapStart(yynn3435) - yynn3435 = 0 + r.EncodeMapStart(yynn3426) + yynn3426 = 0 } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3435[0] { - yym3437 := z.EncBinary() - _ = yym3437 + if yyq3426[0] { + yym3428 := z.EncBinary() + _ = yym3428 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -43695,23 +43613,23 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3435[0] { + if yyq3426[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3438 := z.EncBinary() - _ = yym3438 + yym3429 := z.EncBinary() + _ = yym3429 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3435[1] { - yym3440 := z.EncBinary() - _ = yym3440 + if yyq3426[1] { + yym3431 := z.EncBinary() + _ = yym3431 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -43720,56 +43638,56 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3435[1] { + if yyq3426[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3441 := z.EncBinary() - _ = yym3441 + yym3432 := z.EncBinary() + _ = yym3432 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3435[2] { + if yyq3426[2] { if x.GracePeriodSeconds == nil { r.EncodeNil() } else { - yy3443 := *x.GracePeriodSeconds - yym3444 := z.EncBinary() - _ = yym3444 + yy3434 := *x.GracePeriodSeconds + yym3435 := z.EncBinary() + _ = yym3435 if false { } else { - r.EncodeInt(int64(yy3443)) + r.EncodeInt(int64(yy3434)) } } } else { r.EncodeNil() } } else { - if yyq3435[2] { + if yyq3426[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("gracePeriodSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.GracePeriodSeconds == nil { r.EncodeNil() } else { - yy3445 := *x.GracePeriodSeconds - yym3446 := z.EncBinary() - _ = yym3446 + yy3436 := *x.GracePeriodSeconds + yym3437 := z.EncBinary() + _ = yym3437 if false { } else { - r.EncodeInt(int64(yy3445)) + r.EncodeInt(int64(yy3436)) } } } } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3435[3] { + if yyq3426[3] { if x.Preconditions == nil { r.EncodeNil() } else { @@ -43779,7 +43697,7 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq3435[3] { + if yyq3426[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("preconditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -43790,42 +43708,42 @@ func (x *DeleteOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3435[4] { + if yyq3426[4] { if x.OrphanDependents == nil { r.EncodeNil() } else { - yy3449 := *x.OrphanDependents - yym3450 := z.EncBinary() - _ = yym3450 + yy3440 := *x.OrphanDependents + yym3441 := z.EncBinary() + _ = yym3441 if false { } else { - r.EncodeBool(bool(yy3449)) + r.EncodeBool(bool(yy3440)) } } } else { r.EncodeNil() } } else { - if yyq3435[4] { + if yyq3426[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("orphanDependents")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.OrphanDependents == nil { r.EncodeNil() } else { - yy3451 := *x.OrphanDependents - yym3452 := z.EncBinary() - _ = yym3452 + yy3442 := *x.OrphanDependents + yym3443 := z.EncBinary() + _ = yym3443 if false { } else { - r.EncodeBool(bool(yy3451)) + r.EncodeBool(bool(yy3442)) } } } } - if yyr3435 || yy2arr3435 { + if yyr3426 || yy2arr3426 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -43838,25 +43756,25 @@ func (x *DeleteOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3453 := z.DecBinary() - _ = yym3453 + yym3444 := z.DecBinary() + _ = yym3444 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3454 := r.ContainerType() - if yyct3454 == codecSelferValueTypeMap1234 { - yyl3454 := r.ReadMapStart() - if yyl3454 == 0 { + yyct3445 := r.ContainerType() + if yyct3445 == codecSelferValueTypeMap1234 { + yyl3445 := r.ReadMapStart() + if yyl3445 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3454, d) + x.codecDecodeSelfFromMap(yyl3445, d) } - } else if yyct3454 == codecSelferValueTypeArray1234 { - yyl3454 := r.ReadArrayStart() - if yyl3454 == 0 { + } else if yyct3445 == codecSelferValueTypeArray1234 { + yyl3445 := r.ReadArrayStart() + if yyl3445 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3454, d) + x.codecDecodeSelfFromArray(yyl3445, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -43868,12 +43786,12 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3455Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3455Slc - var yyhl3455 bool = l >= 0 - for yyj3455 := 0; ; yyj3455++ { - if yyhl3455 { - if yyj3455 >= l { + var yys3446Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3446Slc + var yyhl3446 bool = l >= 0 + for yyj3446 := 0; ; yyj3446++ { + if yyhl3446 { + if yyj3446 >= l { break } } else { @@ -43882,10 +43800,10 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3455Slc = r.DecodeBytes(yys3455Slc, true, true) - yys3455 := string(yys3455Slc) + yys3446Slc = r.DecodeBytes(yys3446Slc, true, true) + yys3446 := string(yys3446Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3455 { + switch yys3446 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -43907,8 +43825,8 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.GracePeriodSeconds == nil { x.GracePeriodSeconds = new(int64) } - yym3459 := z.DecBinary() - _ = yym3459 + yym3450 := z.DecBinary() + _ = yym3450 if false { } else { *((*int64)(x.GracePeriodSeconds)) = int64(r.DecodeInt(64)) @@ -43934,17 +43852,17 @@ func (x *DeleteOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.OrphanDependents == nil { x.OrphanDependents = new(bool) } - yym3462 := z.DecBinary() - _ = yym3462 + yym3453 := z.DecBinary() + _ = yym3453 if false { } else { *((*bool)(x.OrphanDependents)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys3455) - } // end switch yys3455 - } // end for yyj3455 + z.DecStructFieldNotFound(-1, yys3446) + } // end switch yys3446 + } // end for yyj3446 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -43952,16 +43870,16 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3463 int - var yyb3463 bool - var yyhl3463 bool = l >= 0 - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + var yyj3454 int + var yyb3454 bool + var yyhl3454 bool = l >= 0 + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43971,13 +43889,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -43987,13 +43905,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44006,20 +43924,20 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.GracePeriodSeconds == nil { x.GracePeriodSeconds = new(int64) } - yym3467 := z.DecBinary() - _ = yym3467 + yym3458 := z.DecBinary() + _ = yym3458 if false { } else { *((*int64)(x.GracePeriodSeconds)) = int64(r.DecodeInt(64)) } } - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44034,13 +43952,13 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } x.Preconditions.CodecDecodeSelf(d) } - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44053,25 +43971,25 @@ func (x *DeleteOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.OrphanDependents == nil { x.OrphanDependents = new(bool) } - yym3470 := z.DecBinary() - _ = yym3470 + yym3461 := z.DecBinary() + _ = yym3461 if false { } else { *((*bool)(x.OrphanDependents)) = r.DecodeBool() } } for { - yyj3463++ - if yyhl3463 { - yyb3463 = yyj3463 > l + yyj3454++ + if yyhl3454 { + yyb3454 = yyj3454 > l } else { - yyb3463 = r.CheckBreak() + yyb3454 = r.CheckBreak() } - if yyb3463 { + if yyb3454 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3463-1, "") + z.DecStructFieldNotFound(yyj3454-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44083,36 +44001,36 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3471 := z.EncBinary() - _ = yym3471 + yym3462 := z.EncBinary() + _ = yym3462 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3472 := !z.EncBinary() - yy2arr3472 := z.EncBasicHandle().StructToArray - var yyq3472 [4]bool - _, _, _ = yysep3472, yyq3472, yy2arr3472 - const yyr3472 bool = false - yyq3472[0] = x.Kind != "" - yyq3472[1] = x.APIVersion != "" - var yynn3472 int - if yyr3472 || yy2arr3472 { + yysep3463 := !z.EncBinary() + yy2arr3463 := z.EncBasicHandle().StructToArray + var yyq3463 [4]bool + _, _, _ = yysep3463, yyq3463, yy2arr3463 + const yyr3463 bool = false + yyq3463[0] = x.Kind != "" + yyq3463[1] = x.APIVersion != "" + var yynn3463 int + if yyr3463 || yy2arr3463 { r.EncodeArrayStart(4) } else { - yynn3472 = 2 - for _, b := range yyq3472 { + yynn3463 = 2 + for _, b := range yyq3463 { if b { - yynn3472++ + yynn3463++ } } - r.EncodeMapStart(yynn3472) - yynn3472 = 0 + r.EncodeMapStart(yynn3463) + yynn3463 = 0 } - if yyr3472 || yy2arr3472 { + if yyr3463 || yy2arr3463 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3472[0] { - yym3474 := z.EncBinary() - _ = yym3474 + if yyq3463[0] { + yym3465 := z.EncBinary() + _ = yym3465 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -44121,23 +44039,23 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3472[0] { + if yyq3463[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3475 := z.EncBinary() - _ = yym3475 + yym3466 := z.EncBinary() + _ = yym3466 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3472 || yy2arr3472 { + if yyr3463 || yy2arr3463 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3472[1] { - yym3477 := z.EncBinary() - _ = yym3477 + if yyq3463[1] { + yym3468 := z.EncBinary() + _ = yym3468 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -44146,22 +44064,22 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3472[1] { + if yyq3463[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3478 := z.EncBinary() - _ = yym3478 + yym3469 := z.EncBinary() + _ = yym3469 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3472 || yy2arr3472 { + if yyr3463 || yy2arr3463 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3480 := z.EncBinary() - _ = yym3480 + yym3471 := z.EncBinary() + _ = yym3471 if false { } else { r.EncodeBool(bool(x.Export)) @@ -44170,17 +44088,17 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("export")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3481 := z.EncBinary() - _ = yym3481 + yym3472 := z.EncBinary() + _ = yym3472 if false { } else { r.EncodeBool(bool(x.Export)) } } - if yyr3472 || yy2arr3472 { + if yyr3463 || yy2arr3463 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3483 := z.EncBinary() - _ = yym3483 + yym3474 := z.EncBinary() + _ = yym3474 if false { } else { r.EncodeBool(bool(x.Exact)) @@ -44189,14 +44107,14 @@ func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("exact")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3484 := z.EncBinary() - _ = yym3484 + yym3475 := z.EncBinary() + _ = yym3475 if false { } else { r.EncodeBool(bool(x.Exact)) } } - if yyr3472 || yy2arr3472 { + if yyr3463 || yy2arr3463 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -44209,25 +44127,25 @@ func (x *ExportOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3485 := z.DecBinary() - _ = yym3485 + yym3476 := z.DecBinary() + _ = yym3476 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3486 := r.ContainerType() - if yyct3486 == codecSelferValueTypeMap1234 { - yyl3486 := r.ReadMapStart() - if yyl3486 == 0 { + yyct3477 := r.ContainerType() + if yyct3477 == codecSelferValueTypeMap1234 { + yyl3477 := r.ReadMapStart() + if yyl3477 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3486, d) + x.codecDecodeSelfFromMap(yyl3477, d) } - } else if yyct3486 == codecSelferValueTypeArray1234 { - yyl3486 := r.ReadArrayStart() - if yyl3486 == 0 { + } else if yyct3477 == codecSelferValueTypeArray1234 { + yyl3477 := r.ReadArrayStart() + if yyl3477 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3486, d) + x.codecDecodeSelfFromArray(yyl3477, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44239,12 +44157,12 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3487Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3487Slc - var yyhl3487 bool = l >= 0 - for yyj3487 := 0; ; yyj3487++ { - if yyhl3487 { - if yyj3487 >= l { + var yys3478Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3478Slc + var yyhl3478 bool = l >= 0 + for yyj3478 := 0; ; yyj3478++ { + if yyhl3478 { + if yyj3478 >= l { break } } else { @@ -44253,10 +44171,10 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3487Slc = r.DecodeBytes(yys3487Slc, true, true) - yys3487 := string(yys3487Slc) + yys3478Slc = r.DecodeBytes(yys3478Slc, true, true) + yys3478 := string(yys3478Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3487 { + switch yys3478 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -44282,9 +44200,9 @@ func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Exact = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys3487) - } // end switch yys3487 - } // end for yyj3487 + z.DecStructFieldNotFound(-1, yys3478) + } // end switch yys3478 + } // end for yyj3478 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -44292,16 +44210,16 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3492 int - var yyb3492 bool - var yyhl3492 bool = l >= 0 - yyj3492++ - if yyhl3492 { - yyb3492 = yyj3492 > l + var yyj3483 int + var yyb3483 bool + var yyhl3483 bool = l >= 0 + yyj3483++ + if yyhl3483 { + yyb3483 = yyj3483 > l } else { - yyb3492 = r.CheckBreak() + yyb3483 = r.CheckBreak() } - if yyb3492 { + if yyb3483 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44311,13 +44229,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3492++ - if yyhl3492 { - yyb3492 = yyj3492 > l + yyj3483++ + if yyhl3483 { + yyb3483 = yyj3483 > l } else { - yyb3492 = r.CheckBreak() + yyb3483 = r.CheckBreak() } - if yyb3492 { + if yyb3483 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44327,13 +44245,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3492++ - if yyhl3492 { - yyb3492 = yyj3492 > l + yyj3483++ + if yyhl3483 { + yyb3483 = yyj3483 > l } else { - yyb3492 = r.CheckBreak() + yyb3483 = r.CheckBreak() } - if yyb3492 { + if yyb3483 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44343,13 +44261,13 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Export = bool(r.DecodeBool()) } - yyj3492++ - if yyhl3492 { - yyb3492 = yyj3492 > l + yyj3483++ + if yyhl3483 { + yyb3483 = yyj3483 > l } else { - yyb3492 = r.CheckBreak() + yyb3483 = r.CheckBreak() } - if yyb3492 { + if yyb3483 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44360,17 +44278,17 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Exact = bool(r.DecodeBool()) } for { - yyj3492++ - if yyhl3492 { - yyb3492 = yyj3492 > l + yyj3483++ + if yyhl3483 { + yyb3483 = yyj3483 > l } else { - yyb3492 = r.CheckBreak() + yyb3483 = r.CheckBreak() } - if yyb3492 { + if yyb3483 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3492-1, "") + z.DecStructFieldNotFound(yyj3483-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44382,41 +44300,41 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3497 := z.EncBinary() - _ = yym3497 + yym3488 := z.EncBinary() + _ = yym3488 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3498 := !z.EncBinary() - yy2arr3498 := z.EncBasicHandle().StructToArray - var yyq3498 [7]bool - _, _, _ = yysep3498, yyq3498, yy2arr3498 - const yyr3498 bool = false - yyq3498[0] = x.Kind != "" - yyq3498[1] = x.APIVersion != "" - yyq3498[2] = x.LabelSelector != "" - yyq3498[3] = x.FieldSelector != "" - yyq3498[4] = x.Watch != false - yyq3498[5] = x.ResourceVersion != "" - yyq3498[6] = x.TimeoutSeconds != nil - var yynn3498 int - if yyr3498 || yy2arr3498 { + yysep3489 := !z.EncBinary() + yy2arr3489 := z.EncBasicHandle().StructToArray + var yyq3489 [7]bool + _, _, _ = yysep3489, yyq3489, yy2arr3489 + const yyr3489 bool = false + yyq3489[0] = x.Kind != "" + yyq3489[1] = x.APIVersion != "" + yyq3489[2] = x.LabelSelector != "" + yyq3489[3] = x.FieldSelector != "" + yyq3489[4] = x.Watch != false + yyq3489[5] = x.ResourceVersion != "" + yyq3489[6] = x.TimeoutSeconds != nil + var yynn3489 int + if yyr3489 || yy2arr3489 { r.EncodeArrayStart(7) } else { - yynn3498 = 0 - for _, b := range yyq3498 { + yynn3489 = 0 + for _, b := range yyq3489 { if b { - yynn3498++ + yynn3489++ } } - r.EncodeMapStart(yynn3498) - yynn3498 = 0 + r.EncodeMapStart(yynn3489) + yynn3489 = 0 } - if yyr3498 || yy2arr3498 { + if yyr3489 || yy2arr3489 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[0] { - yym3500 := z.EncBinary() - _ = yym3500 + if yyq3489[0] { + yym3491 := z.EncBinary() + _ = yym3491 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -44425,99 +44343,99 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3498[0] { + if yyq3489[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3492 := z.EncBinary() + _ = yym3492 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr3489 || yy2arr3489 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3489[1] { + yym3494 := z.EncBinary() + _ = yym3494 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3489[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3495 := z.EncBinary() + _ = yym3495 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3489 || yy2arr3489 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3489[2] { + yym3497 := z.EncBinary() + _ = yym3497 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.LabelSelector)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3489[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("labelSelector")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3498 := z.EncBinary() + _ = yym3498 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.LabelSelector)) + } + } + } + if yyr3489 || yy2arr3489 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3489[3] { + yym3500 := z.EncBinary() + _ = yym3500 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.FieldSelector)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3489[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("fieldSelector")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3501 := z.EncBinary() _ = yym3501 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeString(codecSelferC_UTF81234, string(x.FieldSelector)) } } } - if yyr3498 || yy2arr3498 { + if yyr3489 || yy2arr3489 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[1] { + if yyq3489[4] { yym3503 := z.EncBinary() _ = yym3503 if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3498[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3504 := z.EncBinary() - _ = yym3504 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr3498 || yy2arr3498 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[2] { - yym3506 := z.EncBinary() - _ = yym3506 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.LabelSelector)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3498[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("labelSelector")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3507 := z.EncBinary() - _ = yym3507 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.LabelSelector)) - } - } - } - if yyr3498 || yy2arr3498 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[3] { - yym3509 := z.EncBinary() - _ = yym3509 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FieldSelector)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3498[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("fieldSelector")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3510 := z.EncBinary() - _ = yym3510 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FieldSelector)) - } - } - } - if yyr3498 || yy2arr3498 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[4] { - yym3512 := z.EncBinary() - _ = yym3512 - if false { } else { r.EncodeBool(bool(x.Watch)) } @@ -44525,23 +44443,23 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq3498[4] { + if yyq3489[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("watch")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3513 := z.EncBinary() - _ = yym3513 + yym3504 := z.EncBinary() + _ = yym3504 if false { } else { r.EncodeBool(bool(x.Watch)) } } } - if yyr3498 || yy2arr3498 { + if yyr3489 || yy2arr3489 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[5] { - yym3515 := z.EncBinary() - _ = yym3515 + if yyq3489[5] { + yym3506 := z.EncBinary() + _ = yym3506 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) @@ -44550,54 +44468,54 @@ func (x *ListOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3498[5] { + if yyq3489[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("resourceVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3516 := z.EncBinary() - _ = yym3516 + yym3507 := z.EncBinary() + _ = yym3507 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } } - if yyr3498 || yy2arr3498 { + if yyr3489 || yy2arr3489 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3498[6] { + if yyq3489[6] { if x.TimeoutSeconds == nil { r.EncodeNil() } else { - yy3518 := *x.TimeoutSeconds - yym3519 := z.EncBinary() - _ = yym3519 + yy3509 := *x.TimeoutSeconds + yym3510 := z.EncBinary() + _ = yym3510 if false { } else { - r.EncodeInt(int64(yy3518)) + r.EncodeInt(int64(yy3509)) } } } else { r.EncodeNil() } } else { - if yyq3498[6] { + if yyq3489[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("timeoutSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.TimeoutSeconds == nil { r.EncodeNil() } else { - yy3520 := *x.TimeoutSeconds - yym3521 := z.EncBinary() - _ = yym3521 + yy3511 := *x.TimeoutSeconds + yym3512 := z.EncBinary() + _ = yym3512 if false { } else { - r.EncodeInt(int64(yy3520)) + r.EncodeInt(int64(yy3511)) } } } } - if yyr3498 || yy2arr3498 { + if yyr3489 || yy2arr3489 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -44610,25 +44528,25 @@ func (x *ListOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3522 := z.DecBinary() - _ = yym3522 + yym3513 := z.DecBinary() + _ = yym3513 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3523 := r.ContainerType() - if yyct3523 == codecSelferValueTypeMap1234 { - yyl3523 := r.ReadMapStart() - if yyl3523 == 0 { + yyct3514 := r.ContainerType() + if yyct3514 == codecSelferValueTypeMap1234 { + yyl3514 := r.ReadMapStart() + if yyl3514 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3523, d) + x.codecDecodeSelfFromMap(yyl3514, d) } - } else if yyct3523 == codecSelferValueTypeArray1234 { - yyl3523 := r.ReadArrayStart() - if yyl3523 == 0 { + } else if yyct3514 == codecSelferValueTypeArray1234 { + yyl3514 := r.ReadArrayStart() + if yyl3514 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3523, d) + x.codecDecodeSelfFromArray(yyl3514, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -44640,12 +44558,12 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3524Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3524Slc - var yyhl3524 bool = l >= 0 - for yyj3524 := 0; ; yyj3524++ { - if yyhl3524 { - if yyj3524 >= l { + var yys3515Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3515Slc + var yyhl3515 bool = l >= 0 + for yyj3515 := 0; ; yyj3515++ { + if yyhl3515 { + if yyj3515 >= l { break } } else { @@ -44654,10 +44572,10 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3524Slc = r.DecodeBytes(yys3524Slc, true, true) - yys3524 := string(yys3524Slc) + yys3515Slc = r.DecodeBytes(yys3515Slc, true, true) + yys3515 := string(yys3515Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3524 { + switch yys3515 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -44703,17 +44621,17 @@ func (x *ListOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.TimeoutSeconds == nil { x.TimeoutSeconds = new(int64) } - yym3532 := z.DecBinary() - _ = yym3532 + yym3523 := z.DecBinary() + _ = yym3523 if false { } else { *((*int64)(x.TimeoutSeconds)) = int64(r.DecodeInt(64)) } } default: - z.DecStructFieldNotFound(-1, yys3524) - } // end switch yys3524 - } // end for yyj3524 + z.DecStructFieldNotFound(-1, yys3515) + } // end switch yys3515 + } // end for yyj3515 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -44721,16 +44639,16 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3533 int - var yyb3533 bool - var yyhl3533 bool = l >= 0 - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + var yyj3524 int + var yyb3524 bool + var yyhl3524 bool = l >= 0 + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44740,13 +44658,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44756,13 +44674,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44772,13 +44690,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.LabelSelector = string(r.DecodeString()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44788,13 +44706,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.FieldSelector = string(r.DecodeString()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44804,13 +44722,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Watch = bool(r.DecodeBool()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44820,13 +44738,13 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.ResourceVersion = string(r.DecodeString()) } - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -44839,25 +44757,25 @@ func (x *ListOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.TimeoutSeconds == nil { x.TimeoutSeconds = new(int64) } - yym3541 := z.DecBinary() - _ = yym3541 + yym3532 := z.DecBinary() + _ = yym3532 if false { } else { *((*int64)(x.TimeoutSeconds)) = int64(r.DecodeInt(64)) } } for { - yyj3533++ - if yyhl3533 { - yyb3533 = yyj3533 > l + yyj3524++ + if yyhl3524 { + yyb3524 = yyj3524 > l } else { - yyb3533 = r.CheckBreak() + yyb3524 = r.CheckBreak() } - if yyb3533 { + if yyb3524 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3533-1, "") + z.DecStructFieldNotFound(yyj3524-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -44869,44 +44787,44 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3542 := z.EncBinary() - _ = yym3542 + yym3533 := z.EncBinary() + _ = yym3533 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3543 := !z.EncBinary() - yy2arr3543 := z.EncBasicHandle().StructToArray - var yyq3543 [10]bool - _, _, _ = yysep3543, yyq3543, yy2arr3543 - const yyr3543 bool = false - yyq3543[0] = x.Kind != "" - yyq3543[1] = x.APIVersion != "" - yyq3543[2] = x.Container != "" - yyq3543[3] = x.Follow != false - yyq3543[4] = x.Previous != false - yyq3543[5] = x.SinceSeconds != nil - yyq3543[6] = x.SinceTime != nil - yyq3543[7] = x.Timestamps != false - yyq3543[8] = x.TailLines != nil - yyq3543[9] = x.LimitBytes != nil - var yynn3543 int - if yyr3543 || yy2arr3543 { + yysep3534 := !z.EncBinary() + yy2arr3534 := z.EncBasicHandle().StructToArray + var yyq3534 [10]bool + _, _, _ = yysep3534, yyq3534, yy2arr3534 + const yyr3534 bool = false + yyq3534[0] = x.Kind != "" + yyq3534[1] = x.APIVersion != "" + yyq3534[2] = x.Container != "" + yyq3534[3] = x.Follow != false + yyq3534[4] = x.Previous != false + yyq3534[5] = x.SinceSeconds != nil + yyq3534[6] = x.SinceTime != nil + yyq3534[7] = x.Timestamps != false + yyq3534[8] = x.TailLines != nil + yyq3534[9] = x.LimitBytes != nil + var yynn3534 int + if yyr3534 || yy2arr3534 { r.EncodeArrayStart(10) } else { - yynn3543 = 0 - for _, b := range yyq3543 { + yynn3534 = 0 + for _, b := range yyq3534 { if b { - yynn3543++ + yynn3534++ } } - r.EncodeMapStart(yynn3543) - yynn3543 = 0 + r.EncodeMapStart(yynn3534) + yynn3534 = 0 } - if yyr3543 || yy2arr3543 { + if yyr3534 || yy2arr3534 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[0] { - yym3545 := z.EncBinary() - _ = yym3545 + if yyq3534[0] { + yym3536 := z.EncBinary() + _ = yym3536 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -44915,144 +44833,228 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3543[0] { + if yyq3534[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3537 := z.EncBinary() + _ = yym3537 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[1] { + yym3539 := z.EncBinary() + _ = yym3539 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3534[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3540 := z.EncBinary() + _ = yym3540 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[2] { + yym3542 := z.EncBinary() + _ = yym3542 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Container)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3534[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("container")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3543 := z.EncBinary() + _ = yym3543 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Container)) + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[3] { + yym3545 := z.EncBinary() + _ = yym3545 + if false { + } else { + r.EncodeBool(bool(x.Follow)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3534[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("follow")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3546 := z.EncBinary() _ = yym3546 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeBool(bool(x.Follow)) } } } - if yyr3543 || yy2arr3543 { + if yyr3534 || yy2arr3534 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[1] { + if yyq3534[4] { yym3548 := z.EncBinary() _ = yym3548 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Previous)) } } else { - r.EncodeString(codecSelferC_UTF81234, "") + r.EncodeBool(false) } } else { - if yyq3543[1] { + if yyq3534[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + r.EncodeString(codecSelferC_UTF81234, string("previous")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3549 := z.EncBinary() _ = yym3549 if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[2] { - yym3551 := z.EncBinary() - _ = yym3551 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Container)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3543[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("container")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3552 := z.EncBinary() - _ = yym3552 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Container)) - } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[3] { - yym3554 := z.EncBinary() - _ = yym3554 - if false { - } else { - r.EncodeBool(bool(x.Follow)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3543[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("follow")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3555 := z.EncBinary() - _ = yym3555 - if false { - } else { - r.EncodeBool(bool(x.Follow)) - } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[4] { - yym3557 := z.EncBinary() - _ = yym3557 - if false { - } else { - r.EncodeBool(bool(x.Previous)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3543[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("previous")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3558 := z.EncBinary() - _ = yym3558 - if false { } else { r.EncodeBool(bool(x.Previous)) } } } - if yyr3543 || yy2arr3543 { + if yyr3534 || yy2arr3534 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[5] { + if yyq3534[5] { if x.SinceSeconds == nil { r.EncodeNil() } else { - yy3560 := *x.SinceSeconds - yym3561 := z.EncBinary() - _ = yym3561 + yy3551 := *x.SinceSeconds + yym3552 := z.EncBinary() + _ = yym3552 if false { } else { - r.EncodeInt(int64(yy3560)) + r.EncodeInt(int64(yy3551)) } } } else { r.EncodeNil() } } else { - if yyq3543[5] { + if yyq3534[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("sinceSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.SinceSeconds == nil { r.EncodeNil() } else { - yy3562 := *x.SinceSeconds + yy3553 := *x.SinceSeconds + yym3554 := z.EncBinary() + _ = yym3554 + if false { + } else { + r.EncodeInt(int64(yy3553)) + } + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[6] { + if x.SinceTime == nil { + r.EncodeNil() + } else { + yym3556 := z.EncBinary() + _ = yym3556 + if false { + } else if z.HasExtensions() && z.EncExt(x.SinceTime) { + } else if yym3556 { + z.EncBinaryMarshal(x.SinceTime) + } else if !yym3556 && z.IsJSONHandle() { + z.EncJSONMarshal(x.SinceTime) + } else { + z.EncFallback(x.SinceTime) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq3534[6] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("sinceTime")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.SinceTime == nil { + r.EncodeNil() + } else { + yym3557 := z.EncBinary() + _ = yym3557 + if false { + } else if z.HasExtensions() && z.EncExt(x.SinceTime) { + } else if yym3557 { + z.EncBinaryMarshal(x.SinceTime) + } else if !yym3557 && z.IsJSONHandle() { + z.EncJSONMarshal(x.SinceTime) + } else { + z.EncFallback(x.SinceTime) + } + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[7] { + yym3559 := z.EncBinary() + _ = yym3559 + if false { + } else { + r.EncodeBool(bool(x.Timestamps)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3534[7] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("timestamps")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3560 := z.EncBinary() + _ = yym3560 + if false { + } else { + r.EncodeBool(bool(x.Timestamps)) + } + } + } + if yyr3534 || yy2arr3534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3534[8] { + if x.TailLines == nil { + r.EncodeNil() + } else { + yy3562 := *x.TailLines yym3563 := z.EncBinary() _ = yym3563 if false { @@ -45060,147 +45062,63 @@ func (x *PodLogOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(int64(yy3562)) } } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[6] { - if x.SinceTime == nil { - r.EncodeNil() - } else { - yym3565 := z.EncBinary() - _ = yym3565 - if false { - } else if z.HasExtensions() && z.EncExt(x.SinceTime) { - } else if yym3565 { - z.EncBinaryMarshal(x.SinceTime) - } else if !yym3565 && z.IsJSONHandle() { - z.EncJSONMarshal(x.SinceTime) - } else { - z.EncFallback(x.SinceTime) - } - } } else { r.EncodeNil() } } else { - if yyq3543[6] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("sinceTime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.SinceTime == nil { - r.EncodeNil() - } else { - yym3566 := z.EncBinary() - _ = yym3566 - if false { - } else if z.HasExtensions() && z.EncExt(x.SinceTime) { - } else if yym3566 { - z.EncBinaryMarshal(x.SinceTime) - } else if !yym3566 && z.IsJSONHandle() { - z.EncJSONMarshal(x.SinceTime) - } else { - z.EncFallback(x.SinceTime) - } - } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[7] { - yym3568 := z.EncBinary() - _ = yym3568 - if false { - } else { - r.EncodeBool(bool(x.Timestamps)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3543[7] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("timestamps")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3569 := z.EncBinary() - _ = yym3569 - if false { - } else { - r.EncodeBool(bool(x.Timestamps)) - } - } - } - if yyr3543 || yy2arr3543 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[8] { - if x.TailLines == nil { - r.EncodeNil() - } else { - yy3571 := *x.TailLines - yym3572 := z.EncBinary() - _ = yym3572 - if false { - } else { - r.EncodeInt(int64(yy3571)) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq3543[8] { + if yyq3534[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("tailLines")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.TailLines == nil { r.EncodeNil() } else { - yy3573 := *x.TailLines - yym3574 := z.EncBinary() - _ = yym3574 + yy3564 := *x.TailLines + yym3565 := z.EncBinary() + _ = yym3565 if false { } else { - r.EncodeInt(int64(yy3573)) + r.EncodeInt(int64(yy3564)) } } } } - if yyr3543 || yy2arr3543 { + if yyr3534 || yy2arr3534 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3543[9] { + if yyq3534[9] { if x.LimitBytes == nil { r.EncodeNil() } else { - yy3576 := *x.LimitBytes - yym3577 := z.EncBinary() - _ = yym3577 + yy3567 := *x.LimitBytes + yym3568 := z.EncBinary() + _ = yym3568 if false { } else { - r.EncodeInt(int64(yy3576)) + r.EncodeInt(int64(yy3567)) } } } else { r.EncodeNil() } } else { - if yyq3543[9] { + if yyq3534[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("limitBytes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.LimitBytes == nil { r.EncodeNil() } else { - yy3578 := *x.LimitBytes - yym3579 := z.EncBinary() - _ = yym3579 + yy3569 := *x.LimitBytes + yym3570 := z.EncBinary() + _ = yym3570 if false { } else { - r.EncodeInt(int64(yy3578)) + r.EncodeInt(int64(yy3569)) } } } } - if yyr3543 || yy2arr3543 { + if yyr3534 || yy2arr3534 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -45213,25 +45131,25 @@ func (x *PodLogOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3580 := z.DecBinary() - _ = yym3580 + yym3571 := z.DecBinary() + _ = yym3571 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3581 := r.ContainerType() - if yyct3581 == codecSelferValueTypeMap1234 { - yyl3581 := r.ReadMapStart() - if yyl3581 == 0 { + yyct3572 := r.ContainerType() + if yyct3572 == codecSelferValueTypeMap1234 { + yyl3572 := r.ReadMapStart() + if yyl3572 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3581, d) + x.codecDecodeSelfFromMap(yyl3572, d) } - } else if yyct3581 == codecSelferValueTypeArray1234 { - yyl3581 := r.ReadArrayStart() - if yyl3581 == 0 { + } else if yyct3572 == codecSelferValueTypeArray1234 { + yyl3572 := r.ReadArrayStart() + if yyl3572 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3581, d) + x.codecDecodeSelfFromArray(yyl3572, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -45243,12 +45161,12 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3582Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3582Slc - var yyhl3582 bool = l >= 0 - for yyj3582 := 0; ; yyj3582++ { - if yyhl3582 { - if yyj3582 >= l { + var yys3573Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3573Slc + var yyhl3573 bool = l >= 0 + for yyj3573 := 0; ; yyj3573++ { + if yyhl3573 { + if yyj3573 >= l { break } } else { @@ -45257,10 +45175,10 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3582Slc = r.DecodeBytes(yys3582Slc, true, true) - yys3582 := string(yys3582Slc) + yys3573Slc = r.DecodeBytes(yys3573Slc, true, true) + yys3573 := string(yys3573Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3582 { + switch yys3573 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -45300,8 +45218,8 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.SinceSeconds == nil { x.SinceSeconds = new(int64) } - yym3589 := z.DecBinary() - _ = yym3589 + yym3580 := z.DecBinary() + _ = yym3580 if false { } else { *((*int64)(x.SinceSeconds)) = int64(r.DecodeInt(64)) @@ -45316,13 +45234,13 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.SinceTime == nil { x.SinceTime = new(pkg2_unversioned.Time) } - yym3591 := z.DecBinary() - _ = yym3591 + yym3582 := z.DecBinary() + _ = yym3582 if false { } else if z.HasExtensions() && z.DecExt(x.SinceTime) { - } else if yym3591 { + } else if yym3582 { z.DecBinaryUnmarshal(x.SinceTime) - } else if !yym3591 && z.IsJSONHandle() { + } else if !yym3582 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.SinceTime) } else { z.DecFallback(x.SinceTime, false) @@ -45343,8 +45261,8 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.TailLines == nil { x.TailLines = new(int64) } - yym3594 := z.DecBinary() - _ = yym3594 + yym3585 := z.DecBinary() + _ = yym3585 if false { } else { *((*int64)(x.TailLines)) = int64(r.DecodeInt(64)) @@ -45359,17 +45277,17 @@ func (x *PodLogOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.LimitBytes == nil { x.LimitBytes = new(int64) } - yym3596 := z.DecBinary() - _ = yym3596 + yym3587 := z.DecBinary() + _ = yym3587 if false { } else { *((*int64)(x.LimitBytes)) = int64(r.DecodeInt(64)) } } default: - z.DecStructFieldNotFound(-1, yys3582) - } // end switch yys3582 - } // end for yyj3582 + z.DecStructFieldNotFound(-1, yys3573) + } // end switch yys3573 + } // end for yyj3573 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -45377,16 +45295,16 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3597 int - var yyb3597 bool - var yyhl3597 bool = l >= 0 - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + var yyj3588 int + var yyb3588 bool + var yyhl3588 bool = l >= 0 + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45396,13 +45314,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45412,13 +45330,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45428,13 +45346,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Container = string(r.DecodeString()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45444,13 +45362,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Follow = bool(r.DecodeBool()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45460,13 +45378,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Previous = bool(r.DecodeBool()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45479,20 +45397,20 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.SinceSeconds == nil { x.SinceSeconds = new(int64) } - yym3604 := z.DecBinary() - _ = yym3604 + yym3595 := z.DecBinary() + _ = yym3595 if false { } else { *((*int64)(x.SinceSeconds)) = int64(r.DecodeInt(64)) } } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45505,25 +45423,25 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.SinceTime == nil { x.SinceTime = new(pkg2_unversioned.Time) } - yym3606 := z.DecBinary() - _ = yym3606 + yym3597 := z.DecBinary() + _ = yym3597 if false { } else if z.HasExtensions() && z.DecExt(x.SinceTime) { - } else if yym3606 { + } else if yym3597 { z.DecBinaryUnmarshal(x.SinceTime) - } else if !yym3606 && z.IsJSONHandle() { + } else if !yym3597 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.SinceTime) } else { z.DecFallback(x.SinceTime, false) } } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45533,13 +45451,13 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Timestamps = bool(r.DecodeBool()) } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45552,20 +45470,20 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.TailLines == nil { x.TailLines = new(int64) } - yym3609 := z.DecBinary() - _ = yym3609 + yym3600 := z.DecBinary() + _ = yym3600 if false { } else { *((*int64)(x.TailLines)) = int64(r.DecodeInt(64)) } } - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45578,25 +45496,25 @@ func (x *PodLogOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.LimitBytes == nil { x.LimitBytes = new(int64) } - yym3611 := z.DecBinary() - _ = yym3611 + yym3602 := z.DecBinary() + _ = yym3602 if false { } else { *((*int64)(x.LimitBytes)) = int64(r.DecodeInt(64)) } } for { - yyj3597++ - if yyhl3597 { - yyb3597 = yyj3597 > l + yyj3588++ + if yyhl3588 { + yyb3588 = yyj3588 > l } else { - yyb3597 = r.CheckBreak() + yyb3588 = r.CheckBreak() } - if yyb3597 { + if yyb3588 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3597-1, "") + z.DecStructFieldNotFound(yyj3588-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -45608,41 +45526,41 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3612 := z.EncBinary() - _ = yym3612 + yym3603 := z.EncBinary() + _ = yym3603 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3613 := !z.EncBinary() - yy2arr3613 := z.EncBasicHandle().StructToArray - var yyq3613 [7]bool - _, _, _ = yysep3613, yyq3613, yy2arr3613 - const yyr3613 bool = false - yyq3613[0] = x.Kind != "" - yyq3613[1] = x.APIVersion != "" - yyq3613[2] = x.Stdin != false - yyq3613[3] = x.Stdout != false - yyq3613[4] = x.Stderr != false - yyq3613[5] = x.TTY != false - yyq3613[6] = x.Container != "" - var yynn3613 int - if yyr3613 || yy2arr3613 { + yysep3604 := !z.EncBinary() + yy2arr3604 := z.EncBasicHandle().StructToArray + var yyq3604 [7]bool + _, _, _ = yysep3604, yyq3604, yy2arr3604 + const yyr3604 bool = false + yyq3604[0] = x.Kind != "" + yyq3604[1] = x.APIVersion != "" + yyq3604[2] = x.Stdin != false + yyq3604[3] = x.Stdout != false + yyq3604[4] = x.Stderr != false + yyq3604[5] = x.TTY != false + yyq3604[6] = x.Container != "" + var yynn3604 int + if yyr3604 || yy2arr3604 { r.EncodeArrayStart(7) } else { - yynn3613 = 0 - for _, b := range yyq3613 { + yynn3604 = 0 + for _, b := range yyq3604 { if b { - yynn3613++ + yynn3604++ } } - r.EncodeMapStart(yynn3613) - yynn3613 = 0 + r.EncodeMapStart(yynn3604) + yynn3604 = 0 } - if yyr3613 || yy2arr3613 { + if yyr3604 || yy2arr3604 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[0] { - yym3615 := z.EncBinary() - _ = yym3615 + if yyq3604[0] { + yym3606 := z.EncBinary() + _ = yym3606 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -45651,149 +45569,149 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3613[0] { + if yyq3604[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3607 := z.EncBinary() + _ = yym3607 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr3604 || yy2arr3604 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3604[1] { + yym3609 := z.EncBinary() + _ = yym3609 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3604[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3610 := z.EncBinary() + _ = yym3610 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3604 || yy2arr3604 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3604[2] { + yym3612 := z.EncBinary() + _ = yym3612 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3604[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdin")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3613 := z.EncBinary() + _ = yym3613 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } + } + if yyr3604 || yy2arr3604 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3604[3] { + yym3615 := z.EncBinary() + _ = yym3615 + if false { + } else { + r.EncodeBool(bool(x.Stdout)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3604[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdout")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3616 := z.EncBinary() _ = yym3616 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeBool(bool(x.Stdout)) } } } - if yyr3613 || yy2arr3613 { + if yyr3604 || yy2arr3604 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[1] { + if yyq3604[4] { yym3618 := z.EncBinary() _ = yym3618 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } else { - r.EncodeString(codecSelferC_UTF81234, "") + r.EncodeBool(false) } } else { - if yyq3613[1] { + if yyq3604[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + r.EncodeString(codecSelferC_UTF81234, string("stderr")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3619 := z.EncBinary() _ = yym3619 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } } - if yyr3613 || yy2arr3613 { + if yyr3604 || yy2arr3604 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[2] { + if yyq3604[5] { yym3621 := z.EncBinary() _ = yym3621 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } else { r.EncodeBool(false) } } else { - if yyq3613[2] { + if yyq3604[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdin")) + r.EncodeString(codecSelferC_UTF81234, string("tty")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3622 := z.EncBinary() _ = yym3622 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } } - if yyr3613 || yy2arr3613 { + if yyr3604 || yy2arr3604 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[3] { + if yyq3604[6] { yym3624 := z.EncBinary() _ = yym3624 if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3613[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3625 := z.EncBinary() - _ = yym3625 - if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } - } - if yyr3613 || yy2arr3613 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[4] { - yym3627 := z.EncBinary() - _ = yym3627 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3613[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stderr")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3628 := z.EncBinary() - _ = yym3628 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } - } - if yyr3613 || yy2arr3613 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[5] { - yym3630 := z.EncBinary() - _ = yym3630 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3613[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("tty")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3631 := z.EncBinary() - _ = yym3631 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } - } - if yyr3613 || yy2arr3613 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3613[6] { - yym3633 := z.EncBinary() - _ = yym3633 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } @@ -45801,19 +45719,19 @@ func (x *PodAttachOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3613[6] { + if yyq3604[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("container")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3634 := z.EncBinary() - _ = yym3634 + yym3625 := z.EncBinary() + _ = yym3625 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } } } - if yyr3613 || yy2arr3613 { + if yyr3604 || yy2arr3604 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -45826,25 +45744,25 @@ func (x *PodAttachOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3635 := z.DecBinary() - _ = yym3635 + yym3626 := z.DecBinary() + _ = yym3626 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3636 := r.ContainerType() - if yyct3636 == codecSelferValueTypeMap1234 { - yyl3636 := r.ReadMapStart() - if yyl3636 == 0 { + yyct3627 := r.ContainerType() + if yyct3627 == codecSelferValueTypeMap1234 { + yyl3627 := r.ReadMapStart() + if yyl3627 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3636, d) + x.codecDecodeSelfFromMap(yyl3627, d) } - } else if yyct3636 == codecSelferValueTypeArray1234 { - yyl3636 := r.ReadArrayStart() - if yyl3636 == 0 { + } else if yyct3627 == codecSelferValueTypeArray1234 { + yyl3627 := r.ReadArrayStart() + if yyl3627 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3636, d) + x.codecDecodeSelfFromArray(yyl3627, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -45856,12 +45774,12 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3637Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3637Slc - var yyhl3637 bool = l >= 0 - for yyj3637 := 0; ; yyj3637++ { - if yyhl3637 { - if yyj3637 >= l { + var yys3628Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3628Slc + var yyhl3628 bool = l >= 0 + for yyj3628 := 0; ; yyj3628++ { + if yyhl3628 { + if yyj3628 >= l { break } } else { @@ -45870,10 +45788,10 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3637Slc = r.DecodeBytes(yys3637Slc, true, true) - yys3637 := string(yys3637Slc) + yys3628Slc = r.DecodeBytes(yys3628Slc, true, true) + yys3628 := string(yys3628Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3637 { + switch yys3628 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -45917,9 +45835,9 @@ func (x *PodAttachOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Container = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3637) - } // end switch yys3637 - } // end for yyj3637 + z.DecStructFieldNotFound(-1, yys3628) + } // end switch yys3628 + } // end for yyj3628 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -45927,16 +45845,16 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3645 int - var yyb3645 bool - var yyhl3645 bool = l >= 0 - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + var yyj3636 int + var yyb3636 bool + var yyhl3636 bool = l >= 0 + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45946,13 +45864,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45962,13 +45880,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45978,13 +45896,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stdin = bool(r.DecodeBool()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -45994,13 +45912,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stdout = bool(r.DecodeBool()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46010,13 +45928,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Stderr = bool(r.DecodeBool()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46026,13 +45944,13 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.TTY = bool(r.DecodeBool()) } - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46043,17 +45961,17 @@ func (x *PodAttachOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Container = string(r.DecodeString()) } for { - yyj3645++ - if yyhl3645 { - yyb3645 = yyj3645 > l + yyj3636++ + if yyhl3636 { + yyb3636 = yyj3636 > l } else { - yyb3645 = r.CheckBreak() + yyb3636 = r.CheckBreak() } - if yyb3645 { + if yyb3636 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3645-1, "") + z.DecStructFieldNotFound(yyj3636-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -46065,41 +45983,41 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3653 := z.EncBinary() - _ = yym3653 + yym3644 := z.EncBinary() + _ = yym3644 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3654 := !z.EncBinary() - yy2arr3654 := z.EncBasicHandle().StructToArray - var yyq3654 [8]bool - _, _, _ = yysep3654, yyq3654, yy2arr3654 - const yyr3654 bool = false - yyq3654[0] = x.Kind != "" - yyq3654[1] = x.APIVersion != "" - yyq3654[2] = x.Stdin != false - yyq3654[3] = x.Stdout != false - yyq3654[4] = x.Stderr != false - yyq3654[5] = x.TTY != false - yyq3654[6] = x.Container != "" - var yynn3654 int - if yyr3654 || yy2arr3654 { + yysep3645 := !z.EncBinary() + yy2arr3645 := z.EncBasicHandle().StructToArray + var yyq3645 [8]bool + _, _, _ = yysep3645, yyq3645, yy2arr3645 + const yyr3645 bool = false + yyq3645[0] = x.Kind != "" + yyq3645[1] = x.APIVersion != "" + yyq3645[2] = x.Stdin != false + yyq3645[3] = x.Stdout != false + yyq3645[4] = x.Stderr != false + yyq3645[5] = x.TTY != false + yyq3645[6] = x.Container != "" + var yynn3645 int + if yyr3645 || yy2arr3645 { r.EncodeArrayStart(8) } else { - yynn3654 = 1 - for _, b := range yyq3654 { + yynn3645 = 1 + for _, b := range yyq3645 { if b { - yynn3654++ + yynn3645++ } } - r.EncodeMapStart(yynn3654) - yynn3654 = 0 + r.EncodeMapStart(yynn3645) + yynn3645 = 0 } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[0] { - yym3656 := z.EncBinary() - _ = yym3656 + if yyq3645[0] { + yym3647 := z.EncBinary() + _ = yym3647 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -46108,149 +46026,149 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3654[0] { + if yyq3645[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3648 := z.EncBinary() + _ = yym3648 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr3645 || yy2arr3645 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3645[1] { + yym3650 := z.EncBinary() + _ = yym3650 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3645[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3651 := z.EncBinary() + _ = yym3651 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3645 || yy2arr3645 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3645[2] { + yym3653 := z.EncBinary() + _ = yym3653 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3645[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdin")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3654 := z.EncBinary() + _ = yym3654 + if false { + } else { + r.EncodeBool(bool(x.Stdin)) + } + } + } + if yyr3645 || yy2arr3645 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3645[3] { + yym3656 := z.EncBinary() + _ = yym3656 + if false { + } else { + r.EncodeBool(bool(x.Stdout)) + } + } else { + r.EncodeBool(false) + } + } else { + if yyq3645[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("stdout")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3657 := z.EncBinary() _ = yym3657 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeBool(bool(x.Stdout)) } } } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[1] { + if yyq3645[4] { yym3659 := z.EncBinary() _ = yym3659 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } else { - r.EncodeString(codecSelferC_UTF81234, "") + r.EncodeBool(false) } } else { - if yyq3654[1] { + if yyq3645[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + r.EncodeString(codecSelferC_UTF81234, string("stderr")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3660 := z.EncBinary() _ = yym3660 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeBool(bool(x.Stderr)) } } } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[2] { + if yyq3645[5] { yym3662 := z.EncBinary() _ = yym3662 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } else { r.EncodeBool(false) } } else { - if yyq3654[2] { + if yyq3645[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdin")) + r.EncodeString(codecSelferC_UTF81234, string("tty")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3663 := z.EncBinary() _ = yym3663 if false { } else { - r.EncodeBool(bool(x.Stdin)) + r.EncodeBool(bool(x.TTY)) } } } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[3] { + if yyq3645[6] { yym3665 := z.EncBinary() _ = yym3665 if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3654[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stdout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3666 := z.EncBinary() - _ = yym3666 - if false { - } else { - r.EncodeBool(bool(x.Stdout)) - } - } - } - if yyr3654 || yy2arr3654 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[4] { - yym3668 := z.EncBinary() - _ = yym3668 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3654[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("stderr")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3669 := z.EncBinary() - _ = yym3669 - if false { - } else { - r.EncodeBool(bool(x.Stderr)) - } - } - } - if yyr3654 || yy2arr3654 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[5] { - yym3671 := z.EncBinary() - _ = yym3671 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq3654[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("tty")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3672 := z.EncBinary() - _ = yym3672 - if false { - } else { - r.EncodeBool(bool(x.TTY)) - } - } - } - if yyr3654 || yy2arr3654 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3654[6] { - yym3674 := z.EncBinary() - _ = yym3674 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } @@ -46258,25 +46176,25 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3654[6] { + if yyq3645[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("container")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3675 := z.EncBinary() - _ = yym3675 + yym3666 := z.EncBinary() + _ = yym3666 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Container)) } } } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Command == nil { r.EncodeNil() } else { - yym3677 := z.EncBinary() - _ = yym3677 + yym3668 := z.EncBinary() + _ = yym3668 if false { } else { z.F.EncSliceStringV(x.Command, false, e) @@ -46289,15 +46207,15 @@ func (x *PodExecOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x.Command == nil { r.EncodeNil() } else { - yym3678 := z.EncBinary() - _ = yym3678 + yym3669 := z.EncBinary() + _ = yym3669 if false { } else { z.F.EncSliceStringV(x.Command, false, e) } } } - if yyr3654 || yy2arr3654 { + if yyr3645 || yy2arr3645 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -46310,25 +46228,25 @@ func (x *PodExecOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3679 := z.DecBinary() - _ = yym3679 + yym3670 := z.DecBinary() + _ = yym3670 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3680 := r.ContainerType() - if yyct3680 == codecSelferValueTypeMap1234 { - yyl3680 := r.ReadMapStart() - if yyl3680 == 0 { + yyct3671 := r.ContainerType() + if yyct3671 == codecSelferValueTypeMap1234 { + yyl3671 := r.ReadMapStart() + if yyl3671 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3680, d) + x.codecDecodeSelfFromMap(yyl3671, d) } - } else if yyct3680 == codecSelferValueTypeArray1234 { - yyl3680 := r.ReadArrayStart() - if yyl3680 == 0 { + } else if yyct3671 == codecSelferValueTypeArray1234 { + yyl3671 := r.ReadArrayStart() + if yyl3671 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3680, d) + x.codecDecodeSelfFromArray(yyl3671, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -46340,12 +46258,12 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3681Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3681Slc - var yyhl3681 bool = l >= 0 - for yyj3681 := 0; ; yyj3681++ { - if yyhl3681 { - if yyj3681 >= l { + var yys3672Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3672Slc + var yyhl3672 bool = l >= 0 + for yyj3672 := 0; ; yyj3672++ { + if yyhl3672 { + if yyj3672 >= l { break } } else { @@ -46354,10 +46272,10 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3681Slc = r.DecodeBytes(yys3681Slc, true, true) - yys3681 := string(yys3681Slc) + yys3672Slc = r.DecodeBytes(yys3672Slc, true, true) + yys3672 := string(yys3672Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3681 { + switch yys3672 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -46404,18 +46322,18 @@ func (x *PodExecOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Command = nil } else { - yyv3689 := &x.Command - yym3690 := z.DecBinary() - _ = yym3690 + yyv3680 := &x.Command + yym3681 := z.DecBinary() + _ = yym3681 if false { } else { - z.F.DecSliceStringX(yyv3689, false, d) + z.F.DecSliceStringX(yyv3680, false, d) } } default: - z.DecStructFieldNotFound(-1, yys3681) - } // end switch yys3681 - } // end for yyj3681 + z.DecStructFieldNotFound(-1, yys3672) + } // end switch yys3672 + } // end for yyj3672 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -46423,16 +46341,16 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3691 int - var yyb3691 bool - var yyhl3691 bool = l >= 0 - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + var yyj3682 int + var yyb3682 bool + var yyhl3682 bool = l >= 0 + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46442,13 +46360,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46458,13 +46376,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46474,13 +46392,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stdin = bool(r.DecodeBool()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46490,13 +46408,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stdout = bool(r.DecodeBool()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46506,13 +46424,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Stderr = bool(r.DecodeBool()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46522,13 +46440,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.TTY = bool(r.DecodeBool()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46538,13 +46456,13 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Container = string(r.DecodeString()) } - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46552,26 +46470,26 @@ func (x *PodExecOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Command = nil } else { - yyv3699 := &x.Command - yym3700 := z.DecBinary() - _ = yym3700 + yyv3690 := &x.Command + yym3691 := z.DecBinary() + _ = yym3691 if false { } else { - z.F.DecSliceStringX(yyv3699, false, d) + z.F.DecSliceStringX(yyv3690, false, d) } } for { - yyj3691++ - if yyhl3691 { - yyb3691 = yyj3691 > l + yyj3682++ + if yyhl3682 { + yyb3682 = yyj3682 > l } else { - yyb3691 = r.CheckBreak() + yyb3682 = r.CheckBreak() } - if yyb3691 { + if yyb3682 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3691-1, "") + z.DecStructFieldNotFound(yyj3682-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -46583,37 +46501,37 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3701 := z.EncBinary() - _ = yym3701 + yym3692 := z.EncBinary() + _ = yym3692 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3702 := !z.EncBinary() - yy2arr3702 := z.EncBasicHandle().StructToArray - var yyq3702 [3]bool - _, _, _ = yysep3702, yyq3702, yy2arr3702 - const yyr3702 bool = false - yyq3702[0] = x.Kind != "" - yyq3702[1] = x.APIVersion != "" - yyq3702[2] = x.Path != "" - var yynn3702 int - if yyr3702 || yy2arr3702 { + yysep3693 := !z.EncBinary() + yy2arr3693 := z.EncBasicHandle().StructToArray + var yyq3693 [3]bool + _, _, _ = yysep3693, yyq3693, yy2arr3693 + const yyr3693 bool = false + yyq3693[0] = x.Kind != "" + yyq3693[1] = x.APIVersion != "" + yyq3693[2] = x.Path != "" + var yynn3693 int + if yyr3693 || yy2arr3693 { r.EncodeArrayStart(3) } else { - yynn3702 = 0 - for _, b := range yyq3702 { + yynn3693 = 0 + for _, b := range yyq3693 { if b { - yynn3702++ + yynn3693++ } } - r.EncodeMapStart(yynn3702) - yynn3702 = 0 + r.EncodeMapStart(yynn3693) + yynn3693 = 0 } - if yyr3702 || yy2arr3702 { + if yyr3693 || yy2arr3693 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3702[0] { - yym3704 := z.EncBinary() - _ = yym3704 + if yyq3693[0] { + yym3695 := z.EncBinary() + _ = yym3695 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -46622,23 +46540,23 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3702[0] { + if yyq3693[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3705 := z.EncBinary() - _ = yym3705 + yym3696 := z.EncBinary() + _ = yym3696 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3702 || yy2arr3702 { + if yyr3693 || yy2arr3693 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3702[1] { - yym3707 := z.EncBinary() - _ = yym3707 + if yyq3693[1] { + yym3698 := z.EncBinary() + _ = yym3698 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -46647,23 +46565,23 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3702[1] { + if yyq3693[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3708 := z.EncBinary() - _ = yym3708 + yym3699 := z.EncBinary() + _ = yym3699 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3702 || yy2arr3702 { + if yyr3693 || yy2arr3693 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3702[2] { - yym3710 := z.EncBinary() - _ = yym3710 + if yyq3693[2] { + yym3701 := z.EncBinary() + _ = yym3701 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -46672,19 +46590,19 @@ func (x *PodProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3702[2] { + if yyq3693[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3711 := z.EncBinary() - _ = yym3711 + yym3702 := z.EncBinary() + _ = yym3702 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } } - if yyr3702 || yy2arr3702 { + if yyr3693 || yy2arr3693 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -46697,25 +46615,25 @@ func (x *PodProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3712 := z.DecBinary() - _ = yym3712 + yym3703 := z.DecBinary() + _ = yym3703 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3713 := r.ContainerType() - if yyct3713 == codecSelferValueTypeMap1234 { - yyl3713 := r.ReadMapStart() - if yyl3713 == 0 { + yyct3704 := r.ContainerType() + if yyct3704 == codecSelferValueTypeMap1234 { + yyl3704 := r.ReadMapStart() + if yyl3704 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3713, d) + x.codecDecodeSelfFromMap(yyl3704, d) } - } else if yyct3713 == codecSelferValueTypeArray1234 { - yyl3713 := r.ReadArrayStart() - if yyl3713 == 0 { + } else if yyct3704 == codecSelferValueTypeArray1234 { + yyl3704 := r.ReadArrayStart() + if yyl3704 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3713, d) + x.codecDecodeSelfFromArray(yyl3704, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -46727,12 +46645,12 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3714Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3714Slc - var yyhl3714 bool = l >= 0 - for yyj3714 := 0; ; yyj3714++ { - if yyhl3714 { - if yyj3714 >= l { + var yys3705Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3705Slc + var yyhl3705 bool = l >= 0 + for yyj3705 := 0; ; yyj3705++ { + if yyhl3705 { + if yyj3705 >= l { break } } else { @@ -46741,10 +46659,10 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3714Slc = r.DecodeBytes(yys3714Slc, true, true) - yys3714 := string(yys3714Slc) + yys3705Slc = r.DecodeBytes(yys3705Slc, true, true) + yys3705 := string(yys3705Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3714 { + switch yys3705 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -46764,9 +46682,9 @@ func (x *PodProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3714) - } // end switch yys3714 - } // end for yyj3714 + z.DecStructFieldNotFound(-1, yys3705) + } // end switch yys3705 + } // end for yyj3705 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -46774,16 +46692,16 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3718 int - var yyb3718 bool - var yyhl3718 bool = l >= 0 - yyj3718++ - if yyhl3718 { - yyb3718 = yyj3718 > l + var yyj3709 int + var yyb3709 bool + var yyhl3709 bool = l >= 0 + yyj3709++ + if yyhl3709 { + yyb3709 = yyj3709 > l } else { - yyb3718 = r.CheckBreak() + yyb3709 = r.CheckBreak() } - if yyb3718 { + if yyb3709 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46793,13 +46711,13 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3718++ - if yyhl3718 { - yyb3718 = yyj3718 > l + yyj3709++ + if yyhl3709 { + yyb3709 = yyj3709 > l } else { - yyb3718 = r.CheckBreak() + yyb3709 = r.CheckBreak() } - if yyb3718 { + if yyb3709 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46809,13 +46727,13 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3718++ - if yyhl3718 { - yyb3718 = yyj3718 > l + yyj3709++ + if yyhl3709 { + yyb3709 = yyj3709 > l } else { - yyb3718 = r.CheckBreak() + yyb3709 = r.CheckBreak() } - if yyb3718 { + if yyb3709 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -46826,17 +46744,17 @@ func (x *PodProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Path = string(r.DecodeString()) } for { - yyj3718++ - if yyhl3718 { - yyb3718 = yyj3718 > l + yyj3709++ + if yyhl3709 { + yyb3709 = yyj3709 > l } else { - yyb3718 = r.CheckBreak() + yyb3709 = r.CheckBreak() } - if yyb3718 { + if yyb3709 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3718-1, "") + z.DecStructFieldNotFound(yyj3709-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -46848,37 +46766,37 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3722 := z.EncBinary() - _ = yym3722 + yym3713 := z.EncBinary() + _ = yym3713 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3723 := !z.EncBinary() - yy2arr3723 := z.EncBasicHandle().StructToArray - var yyq3723 [3]bool - _, _, _ = yysep3723, yyq3723, yy2arr3723 - const yyr3723 bool = false - yyq3723[0] = x.Kind != "" - yyq3723[1] = x.APIVersion != "" - yyq3723[2] = x.Path != "" - var yynn3723 int - if yyr3723 || yy2arr3723 { + yysep3714 := !z.EncBinary() + yy2arr3714 := z.EncBasicHandle().StructToArray + var yyq3714 [3]bool + _, _, _ = yysep3714, yyq3714, yy2arr3714 + const yyr3714 bool = false + yyq3714[0] = x.Kind != "" + yyq3714[1] = x.APIVersion != "" + yyq3714[2] = x.Path != "" + var yynn3714 int + if yyr3714 || yy2arr3714 { r.EncodeArrayStart(3) } else { - yynn3723 = 0 - for _, b := range yyq3723 { + yynn3714 = 0 + for _, b := range yyq3714 { if b { - yynn3723++ + yynn3714++ } } - r.EncodeMapStart(yynn3723) - yynn3723 = 0 + r.EncodeMapStart(yynn3714) + yynn3714 = 0 } - if yyr3723 || yy2arr3723 { + if yyr3714 || yy2arr3714 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3723[0] { - yym3725 := z.EncBinary() - _ = yym3725 + if yyq3714[0] { + yym3716 := z.EncBinary() + _ = yym3716 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -46887,23 +46805,23 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3723[0] { + if yyq3714[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3726 := z.EncBinary() - _ = yym3726 + yym3717 := z.EncBinary() + _ = yym3717 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3723 || yy2arr3723 { + if yyr3714 || yy2arr3714 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3723[1] { - yym3728 := z.EncBinary() - _ = yym3728 + if yyq3714[1] { + yym3719 := z.EncBinary() + _ = yym3719 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -46912,23 +46830,23 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3723[1] { + if yyq3714[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3729 := z.EncBinary() - _ = yym3729 + yym3720 := z.EncBinary() + _ = yym3720 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3723 || yy2arr3723 { + if yyr3714 || yy2arr3714 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3723[2] { - yym3731 := z.EncBinary() - _ = yym3731 + if yyq3714[2] { + yym3722 := z.EncBinary() + _ = yym3722 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -46937,19 +46855,19 @@ func (x *NodeProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3723[2] { + if yyq3714[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3732 := z.EncBinary() - _ = yym3732 + yym3723 := z.EncBinary() + _ = yym3723 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } } - if yyr3723 || yy2arr3723 { + if yyr3714 || yy2arr3714 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -46962,25 +46880,25 @@ func (x *NodeProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3733 := z.DecBinary() - _ = yym3733 + yym3724 := z.DecBinary() + _ = yym3724 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3734 := r.ContainerType() - if yyct3734 == codecSelferValueTypeMap1234 { - yyl3734 := r.ReadMapStart() - if yyl3734 == 0 { + yyct3725 := r.ContainerType() + if yyct3725 == codecSelferValueTypeMap1234 { + yyl3725 := r.ReadMapStart() + if yyl3725 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3734, d) + x.codecDecodeSelfFromMap(yyl3725, d) } - } else if yyct3734 == codecSelferValueTypeArray1234 { - yyl3734 := r.ReadArrayStart() - if yyl3734 == 0 { + } else if yyct3725 == codecSelferValueTypeArray1234 { + yyl3725 := r.ReadArrayStart() + if yyl3725 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3734, d) + x.codecDecodeSelfFromArray(yyl3725, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -46992,12 +46910,12 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3735Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3735Slc - var yyhl3735 bool = l >= 0 - for yyj3735 := 0; ; yyj3735++ { - if yyhl3735 { - if yyj3735 >= l { + var yys3726Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3726Slc + var yyhl3726 bool = l >= 0 + for yyj3726 := 0; ; yyj3726++ { + if yyhl3726 { + if yyj3726 >= l { break } } else { @@ -47006,10 +46924,10 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3735Slc = r.DecodeBytes(yys3735Slc, true, true) - yys3735 := string(yys3735Slc) + yys3726Slc = r.DecodeBytes(yys3726Slc, true, true) + yys3726 := string(yys3726Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3735 { + switch yys3726 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47029,9 +46947,9 @@ func (x *NodeProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3735) - } // end switch yys3735 - } // end for yyj3735 + z.DecStructFieldNotFound(-1, yys3726) + } // end switch yys3726 + } // end for yyj3726 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47039,16 +46957,16 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3739 int - var yyb3739 bool - var yyhl3739 bool = l >= 0 - yyj3739++ - if yyhl3739 { - yyb3739 = yyj3739 > l + var yyj3730 int + var yyb3730 bool + var yyhl3730 bool = l >= 0 + yyj3730++ + if yyhl3730 { + yyb3730 = yyj3730 > l } else { - yyb3739 = r.CheckBreak() + yyb3730 = r.CheckBreak() } - if yyb3739 { + if yyb3730 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47058,13 +46976,13 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3739++ - if yyhl3739 { - yyb3739 = yyj3739 > l + yyj3730++ + if yyhl3730 { + yyb3730 = yyj3730 > l } else { - yyb3739 = r.CheckBreak() + yyb3730 = r.CheckBreak() } - if yyb3739 { + if yyb3730 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47074,13 +46992,13 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3739++ - if yyhl3739 { - yyb3739 = yyj3739 > l + yyj3730++ + if yyhl3730 { + yyb3730 = yyj3730 > l } else { - yyb3739 = r.CheckBreak() + yyb3730 = r.CheckBreak() } - if yyb3739 { + if yyb3730 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47091,17 +47009,17 @@ func (x *NodeProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.Path = string(r.DecodeString()) } for { - yyj3739++ - if yyhl3739 { - yyb3739 = yyj3739 > l + yyj3730++ + if yyhl3730 { + yyb3730 = yyj3730 > l } else { - yyb3739 = r.CheckBreak() + yyb3730 = r.CheckBreak() } - if yyb3739 { + if yyb3730 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3739-1, "") + z.DecStructFieldNotFound(yyj3730-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47113,37 +47031,37 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3743 := z.EncBinary() - _ = yym3743 + yym3734 := z.EncBinary() + _ = yym3734 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3744 := !z.EncBinary() - yy2arr3744 := z.EncBasicHandle().StructToArray - var yyq3744 [3]bool - _, _, _ = yysep3744, yyq3744, yy2arr3744 - const yyr3744 bool = false - yyq3744[0] = x.Kind != "" - yyq3744[1] = x.APIVersion != "" - yyq3744[2] = x.Path != "" - var yynn3744 int - if yyr3744 || yy2arr3744 { + yysep3735 := !z.EncBinary() + yy2arr3735 := z.EncBasicHandle().StructToArray + var yyq3735 [3]bool + _, _, _ = yysep3735, yyq3735, yy2arr3735 + const yyr3735 bool = false + yyq3735[0] = x.Kind != "" + yyq3735[1] = x.APIVersion != "" + yyq3735[2] = x.Path != "" + var yynn3735 int + if yyr3735 || yy2arr3735 { r.EncodeArrayStart(3) } else { - yynn3744 = 0 - for _, b := range yyq3744 { + yynn3735 = 0 + for _, b := range yyq3735 { if b { - yynn3744++ + yynn3735++ } } - r.EncodeMapStart(yynn3744) - yynn3744 = 0 + r.EncodeMapStart(yynn3735) + yynn3735 = 0 } - if yyr3744 || yy2arr3744 { + if yyr3735 || yy2arr3735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3744[0] { - yym3746 := z.EncBinary() - _ = yym3746 + if yyq3735[0] { + yym3737 := z.EncBinary() + _ = yym3737 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47152,23 +47070,23 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3744[0] { + if yyq3735[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3747 := z.EncBinary() - _ = yym3747 + yym3738 := z.EncBinary() + _ = yym3738 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3744 || yy2arr3744 { + if yyr3735 || yy2arr3735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3744[1] { - yym3749 := z.EncBinary() - _ = yym3749 + if yyq3735[1] { + yym3740 := z.EncBinary() + _ = yym3740 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -47177,23 +47095,23 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3744[1] { + if yyq3735[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3750 := z.EncBinary() - _ = yym3750 + yym3741 := z.EncBinary() + _ = yym3741 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3744 || yy2arr3744 { + if yyr3735 || yy2arr3735 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3744[2] { - yym3752 := z.EncBinary() - _ = yym3752 + if yyq3735[2] { + yym3743 := z.EncBinary() + _ = yym3743 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -47202,19 +47120,19 @@ func (x *ServiceProxyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3744[2] { + if yyq3735[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3753 := z.EncBinary() - _ = yym3753 + yym3744 := z.EncBinary() + _ = yym3744 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } } - if yyr3744 || yy2arr3744 { + if yyr3735 || yy2arr3735 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47227,25 +47145,25 @@ func (x *ServiceProxyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3754 := z.DecBinary() - _ = yym3754 + yym3745 := z.DecBinary() + _ = yym3745 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3755 := r.ContainerType() - if yyct3755 == codecSelferValueTypeMap1234 { - yyl3755 := r.ReadMapStart() - if yyl3755 == 0 { + yyct3746 := r.ContainerType() + if yyct3746 == codecSelferValueTypeMap1234 { + yyl3746 := r.ReadMapStart() + if yyl3746 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3755, d) + x.codecDecodeSelfFromMap(yyl3746, d) } - } else if yyct3755 == codecSelferValueTypeArray1234 { - yyl3755 := r.ReadArrayStart() - if yyl3755 == 0 { + } else if yyct3746 == codecSelferValueTypeArray1234 { + yyl3746 := r.ReadArrayStart() + if yyl3746 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3755, d) + x.codecDecodeSelfFromArray(yyl3746, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47257,12 +47175,12 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3756Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3756Slc - var yyhl3756 bool = l >= 0 - for yyj3756 := 0; ; yyj3756++ { - if yyhl3756 { - if yyj3756 >= l { + var yys3747Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3747Slc + var yyhl3747 bool = l >= 0 + for yyj3747 := 0; ; yyj3747++ { + if yyhl3747 { + if yyj3747 >= l { break } } else { @@ -47271,10 +47189,10 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3756Slc = r.DecodeBytes(yys3756Slc, true, true) - yys3756 := string(yys3756Slc) + yys3747Slc = r.DecodeBytes(yys3747Slc, true, true) + yys3747 := string(yys3747Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3756 { + switch yys3747 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -47294,9 +47212,9 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Path = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3756) - } // end switch yys3756 - } // end for yyj3756 + z.DecStructFieldNotFound(-1, yys3747) + } // end switch yys3747 + } // end for yyj3747 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47304,16 +47222,16 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3760 int - var yyb3760 bool - var yyhl3760 bool = l >= 0 - yyj3760++ - if yyhl3760 { - yyb3760 = yyj3760 > l + var yyj3751 int + var yyb3751 bool + var yyhl3751 bool = l >= 0 + yyj3751++ + if yyhl3751 { + yyb3751 = yyj3751 > l } else { - yyb3760 = r.CheckBreak() + yyb3751 = r.CheckBreak() } - if yyb3760 { + if yyb3751 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47323,13 +47241,13 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj3760++ - if yyhl3760 { - yyb3760 = yyj3760 > l + yyj3751++ + if yyhl3751 { + yyb3751 = yyj3751 > l } else { - yyb3760 = r.CheckBreak() + yyb3751 = r.CheckBreak() } - if yyb3760 { + if yyb3751 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47339,13 +47257,13 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj3760++ - if yyhl3760 { - yyb3760 = yyj3760 > l + yyj3751++ + if yyhl3751 { + yyb3751 = yyj3751 > l } else { - yyb3760 = r.CheckBreak() + yyb3751 = r.CheckBreak() } - if yyb3760 { + if yyb3751 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47356,17 +47274,17 @@ func (x *ServiceProxyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Path = string(r.DecodeString()) } for { - yyj3760++ - if yyhl3760 { - yyb3760 = yyj3760 > l + yyj3751++ + if yyhl3751 { + yyb3751 = yyj3751 > l } else { - yyb3760 = r.CheckBreak() + yyb3751 = r.CheckBreak() } - if yyb3760 { + if yyb3751 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3760-1, "") + z.DecStructFieldNotFound(yyj3751-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47378,34 +47296,34 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3764 := z.EncBinary() - _ = yym3764 + yym3755 := z.EncBinary() + _ = yym3755 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3765 := !z.EncBinary() - yy2arr3765 := z.EncBasicHandle().StructToArray - var yyq3765 [5]bool - _, _, _ = yysep3765, yyq3765, yy2arr3765 - const yyr3765 bool = false - yyq3765[4] = x.Controller != nil - var yynn3765 int - if yyr3765 || yy2arr3765 { + yysep3756 := !z.EncBinary() + yy2arr3756 := z.EncBasicHandle().StructToArray + var yyq3756 [5]bool + _, _, _ = yysep3756, yyq3756, yy2arr3756 + const yyr3756 bool = false + yyq3756[4] = x.Controller != nil + var yynn3756 int + if yyr3756 || yy2arr3756 { r.EncodeArrayStart(5) } else { - yynn3765 = 4 - for _, b := range yyq3765 { + yynn3756 = 4 + for _, b := range yyq3756 { if b { - yynn3765++ + yynn3756++ } } - r.EncodeMapStart(yynn3765) - yynn3765 = 0 + r.EncodeMapStart(yynn3756) + yynn3756 = 0 } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3767 := z.EncBinary() - _ = yym3767 + yym3758 := z.EncBinary() + _ = yym3758 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -47414,17 +47332,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3768 := z.EncBinary() - _ = yym3768 + yym3759 := z.EncBinary() + _ = yym3759 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3770 := z.EncBinary() - _ = yym3770 + yym3761 := z.EncBinary() + _ = yym3761 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47433,17 +47351,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3771 := z.EncBinary() - _ = yym3771 + yym3762 := z.EncBinary() + _ = yym3762 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3773 := z.EncBinary() - _ = yym3773 + yym3764 := z.EncBinary() + _ = yym3764 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -47452,17 +47370,17 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3774 := z.EncBinary() - _ = yym3774 + yym3765 := z.EncBinary() + _ = yym3765 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym3776 := z.EncBinary() - _ = yym3776 + yym3767 := z.EncBinary() + _ = yym3767 if false { } else if z.HasExtensions() && z.EncExt(x.UID) { } else { @@ -47472,50 +47390,50 @@ func (x *OwnerReference) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("uid")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3777 := z.EncBinary() - _ = yym3777 + yym3768 := z.EncBinary() + _ = yym3768 if false { } else if z.HasExtensions() && z.EncExt(x.UID) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.UID)) } } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3765[4] { + if yyq3756[4] { if x.Controller == nil { r.EncodeNil() } else { - yy3779 := *x.Controller - yym3780 := z.EncBinary() - _ = yym3780 + yy3770 := *x.Controller + yym3771 := z.EncBinary() + _ = yym3771 if false { } else { - r.EncodeBool(bool(yy3779)) + r.EncodeBool(bool(yy3770)) } } } else { r.EncodeNil() } } else { - if yyq3765[4] { + if yyq3756[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("controller")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Controller == nil { r.EncodeNil() } else { - yy3781 := *x.Controller - yym3782 := z.EncBinary() - _ = yym3782 + yy3772 := *x.Controller + yym3773 := z.EncBinary() + _ = yym3773 if false { } else { - r.EncodeBool(bool(yy3781)) + r.EncodeBool(bool(yy3772)) } } } } - if yyr3765 || yy2arr3765 { + if yyr3756 || yy2arr3756 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47528,25 +47446,25 @@ func (x *OwnerReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3783 := z.DecBinary() - _ = yym3783 + yym3774 := z.DecBinary() + _ = yym3774 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3784 := r.ContainerType() - if yyct3784 == codecSelferValueTypeMap1234 { - yyl3784 := r.ReadMapStart() - if yyl3784 == 0 { + yyct3775 := r.ContainerType() + if yyct3775 == codecSelferValueTypeMap1234 { + yyl3775 := r.ReadMapStart() + if yyl3775 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3784, d) + x.codecDecodeSelfFromMap(yyl3775, d) } - } else if yyct3784 == codecSelferValueTypeArray1234 { - yyl3784 := r.ReadArrayStart() - if yyl3784 == 0 { + } else if yyct3775 == codecSelferValueTypeArray1234 { + yyl3775 := r.ReadArrayStart() + if yyl3775 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3784, d) + x.codecDecodeSelfFromArray(yyl3775, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47558,12 +47476,12 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3785Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3785Slc - var yyhl3785 bool = l >= 0 - for yyj3785 := 0; ; yyj3785++ { - if yyhl3785 { - if yyj3785 >= l { + var yys3776Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3776Slc + var yyhl3776 bool = l >= 0 + for yyj3776 := 0; ; yyj3776++ { + if yyhl3776 { + if yyj3776 >= l { break } } else { @@ -47572,10 +47490,10 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3785Slc = r.DecodeBytes(yys3785Slc, true, true) - yys3785 := string(yys3785Slc) + yys3776Slc = r.DecodeBytes(yys3776Slc, true, true) + yys3776 := string(yys3776Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3785 { + switch yys3776 { case "apiVersion": if r.TryDecodeAsNil() { x.APIVersion = "" @@ -47609,17 +47527,17 @@ func (x *OwnerReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Controller == nil { x.Controller = new(bool) } - yym3791 := z.DecBinary() - _ = yym3791 + yym3782 := z.DecBinary() + _ = yym3782 if false { } else { *((*bool)(x.Controller)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys3785) - } // end switch yys3785 - } // end for yyj3785 + z.DecStructFieldNotFound(-1, yys3776) + } // end switch yys3776 + } // end for yyj3776 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -47627,16 +47545,16 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3792 int - var yyb3792 bool - var yyhl3792 bool = l >= 0 - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + var yyj3783 int + var yyb3783 bool + var yyhl3783 bool = l >= 0 + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47646,13 +47564,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47662,13 +47580,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47678,13 +47596,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Name = string(r.DecodeString()) } - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47694,13 +47612,13 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.UID = pkg1_types.UID(r.DecodeString()) } - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -47713,25 +47631,25 @@ func (x *OwnerReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Controller == nil { x.Controller = new(bool) } - yym3798 := z.DecBinary() - _ = yym3798 + yym3789 := z.DecBinary() + _ = yym3789 if false { } else { *((*bool)(x.Controller)) = r.DecodeBool() } } for { - yyj3792++ - if yyhl3792 { - yyb3792 = yyj3792 > l + yyj3783++ + if yyhl3783 { + yyb3783 = yyj3783 > l } else { - yyb3792 = r.CheckBreak() + yyb3783 = r.CheckBreak() } - if yyb3792 { + if yyb3783 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3792-1, "") + z.DecStructFieldNotFound(yyj3783-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -47743,41 +47661,41 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3799 := z.EncBinary() - _ = yym3799 + yym3790 := z.EncBinary() + _ = yym3790 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3800 := !z.EncBinary() - yy2arr3800 := z.EncBasicHandle().StructToArray - var yyq3800 [7]bool - _, _, _ = yysep3800, yyq3800, yy2arr3800 - const yyr3800 bool = false - yyq3800[0] = x.Kind != "" - yyq3800[1] = x.Namespace != "" - yyq3800[2] = x.Name != "" - yyq3800[3] = x.UID != "" - yyq3800[4] = x.APIVersion != "" - yyq3800[5] = x.ResourceVersion != "" - yyq3800[6] = x.FieldPath != "" - var yynn3800 int - if yyr3800 || yy2arr3800 { + yysep3791 := !z.EncBinary() + yy2arr3791 := z.EncBasicHandle().StructToArray + var yyq3791 [7]bool + _, _, _ = yysep3791, yyq3791, yy2arr3791 + const yyr3791 bool = false + yyq3791[0] = x.Kind != "" + yyq3791[1] = x.Namespace != "" + yyq3791[2] = x.Name != "" + yyq3791[3] = x.UID != "" + yyq3791[4] = x.APIVersion != "" + yyq3791[5] = x.ResourceVersion != "" + yyq3791[6] = x.FieldPath != "" + var yynn3791 int + if yyr3791 || yy2arr3791 { r.EncodeArrayStart(7) } else { - yynn3800 = 0 - for _, b := range yyq3800 { + yynn3791 = 0 + for _, b := range yyq3791 { if b { - yynn3800++ + yynn3791++ } } - r.EncodeMapStart(yynn3800) - yynn3800 = 0 + r.EncodeMapStart(yynn3791) + yynn3791 = 0 } - if yyr3800 || yy2arr3800 { + if yyr3791 || yy2arr3791 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[0] { - yym3802 := z.EncBinary() - _ = yym3802 + if yyq3791[0] { + yym3793 := z.EncBinary() + _ = yym3793 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -47786,23 +47704,23 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3800[0] { + if yyq3791[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3803 := z.EncBinary() - _ = yym3803 + yym3794 := z.EncBinary() + _ = yym3794 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3800 || yy2arr3800 { + if yyr3791 || yy2arr3791 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[1] { - yym3805 := z.EncBinary() - _ = yym3805 + if yyq3791[1] { + yym3796 := z.EncBinary() + _ = yym3796 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) @@ -47811,146 +47729,146 @@ func (x *ObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3800[1] { + if yyq3791[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("namespace")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3797 := z.EncBinary() + _ = yym3797 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) + } + } + } + if yyr3791 || yy2arr3791 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3791[2] { + yym3799 := z.EncBinary() + _ = yym3799 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3791[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("name")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3800 := z.EncBinary() + _ = yym3800 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + } + } + } + if yyr3791 || yy2arr3791 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3791[3] { + yym3802 := z.EncBinary() + _ = yym3802 + if false { + } else if z.HasExtensions() && z.EncExt(x.UID) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3791[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("uid")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3803 := z.EncBinary() + _ = yym3803 + if false { + } else if z.HasExtensions() && z.EncExt(x.UID) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + } + } + } + if yyr3791 || yy2arr3791 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3791[4] { + yym3805 := z.EncBinary() + _ = yym3805 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3791[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3806 := z.EncBinary() _ = yym3806 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Namespace)) + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3800 || yy2arr3800 { + if yyr3791 || yy2arr3791 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[2] { + if yyq3791[5] { yym3808 := z.EncBinary() _ = yym3808 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3800[2] { + if yyq3791[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("name")) + r.EncodeString(codecSelferC_UTF81234, string("resourceVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3809 := z.EncBinary() _ = yym3809 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Name)) + r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) } } } - if yyr3800 || yy2arr3800 { + if yyr3791 || yy2arr3791 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[3] { + if yyq3791[6] { yym3811 := z.EncBinary() _ = yym3811 if false { - } else if z.HasExtensions() && z.EncExt(x.UID) { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.UID)) + r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3800[3] { + if yyq3791[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("uid")) + r.EncodeString(codecSelferC_UTF81234, string("fieldPath")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3812 := z.EncBinary() _ = yym3812 if false { - } else if z.HasExtensions() && z.EncExt(x.UID) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.UID)) - } - } - } - if yyr3800 || yy2arr3800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[4] { - yym3814 := z.EncBinary() - _ = yym3814 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3800[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3815 := z.EncBinary() - _ = yym3815 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr3800 || yy2arr3800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[5] { - yym3817 := z.EncBinary() - _ = yym3817 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3800[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("resourceVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3818 := z.EncBinary() - _ = yym3818 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceVersion)) - } - } - } - if yyr3800 || yy2arr3800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3800[6] { - yym3820 := z.EncBinary() - _ = yym3820 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3800[6] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("fieldPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3821 := z.EncBinary() - _ = yym3821 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.FieldPath)) } } } - if yyr3800 || yy2arr3800 { + if yyr3791 || yy2arr3791 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -47963,25 +47881,25 @@ func (x *ObjectReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3822 := z.DecBinary() - _ = yym3822 + yym3813 := z.DecBinary() + _ = yym3813 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3823 := r.ContainerType() - if yyct3823 == codecSelferValueTypeMap1234 { - yyl3823 := r.ReadMapStart() - if yyl3823 == 0 { + yyct3814 := r.ContainerType() + if yyct3814 == codecSelferValueTypeMap1234 { + yyl3814 := r.ReadMapStart() + if yyl3814 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3823, d) + x.codecDecodeSelfFromMap(yyl3814, d) } - } else if yyct3823 == codecSelferValueTypeArray1234 { - yyl3823 := r.ReadArrayStart() - if yyl3823 == 0 { + } else if yyct3814 == codecSelferValueTypeArray1234 { + yyl3814 := r.ReadArrayStart() + if yyl3814 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3823, d) + x.codecDecodeSelfFromArray(yyl3814, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -47993,12 +47911,12 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3824Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3824Slc - var yyhl3824 bool = l >= 0 - for yyj3824 := 0; ; yyj3824++ { - if yyhl3824 { - if yyj3824 >= l { + var yys3815Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3815Slc + var yyhl3815 bool = l >= 0 + for yyj3815 := 0; ; yyj3815++ { + if yyhl3815 { + if yyj3815 >= l { break } } else { @@ -48007,10 +47925,10 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3824Slc = r.DecodeBytes(yys3824Slc, true, true) - yys3824 := string(yys3824Slc) + yys3815Slc = r.DecodeBytes(yys3815Slc, true, true) + yys3815 := string(yys3815Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3824 { + switch yys3815 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -48054,9 +47972,9 @@ func (x *ObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.FieldPath = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3824) - } // end switch yys3824 - } // end for yyj3824 + z.DecStructFieldNotFound(-1, yys3815) + } // end switch yys3815 + } // end for yyj3815 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48064,16 +47982,16 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3832 int - var yyb3832 bool - var yyhl3832 bool = l >= 0 - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + var yyj3823 int + var yyb3823 bool + var yyhl3823 bool = l >= 0 + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48083,13 +48001,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48099,13 +48017,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Namespace = string(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48115,13 +48033,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Name = string(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48131,13 +48049,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UID = pkg1_types.UID(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48147,13 +48065,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48163,13 +48081,13 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ResourceVersion = string(r.DecodeString()) } - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48180,17 +48098,17 @@ func (x *ObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.FieldPath = string(r.DecodeString()) } for { - yyj3832++ - if yyhl3832 { - yyb3832 = yyj3832 > l + yyj3823++ + if yyhl3823 { + yyb3823 = yyj3823 > l } else { - yyb3832 = r.CheckBreak() + yyb3823 = r.CheckBreak() } - if yyb3832 { + if yyb3823 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3832-1, "") + z.DecStructFieldNotFound(yyj3823-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48202,35 +48120,35 @@ func (x *LocalObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3840 := z.EncBinary() - _ = yym3840 + yym3831 := z.EncBinary() + _ = yym3831 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3841 := !z.EncBinary() - yy2arr3841 := z.EncBasicHandle().StructToArray - var yyq3841 [1]bool - _, _, _ = yysep3841, yyq3841, yy2arr3841 - const yyr3841 bool = false - yyq3841[0] = x.Name != "" - var yynn3841 int - if yyr3841 || yy2arr3841 { + yysep3832 := !z.EncBinary() + yy2arr3832 := z.EncBasicHandle().StructToArray + var yyq3832 [1]bool + _, _, _ = yysep3832, yyq3832, yy2arr3832 + const yyr3832 bool = false + yyq3832[0] = x.Name != "" + var yynn3832 int + if yyr3832 || yy2arr3832 { r.EncodeArrayStart(1) } else { - yynn3841 = 0 - for _, b := range yyq3841 { + yynn3832 = 0 + for _, b := range yyq3832 { if b { - yynn3841++ + yynn3832++ } } - r.EncodeMapStart(yynn3841) - yynn3841 = 0 + r.EncodeMapStart(yynn3832) + yynn3832 = 0 } - if yyr3841 || yy2arr3841 { + if yyr3832 || yy2arr3832 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3841[0] { - yym3843 := z.EncBinary() - _ = yym3843 + if yyq3832[0] { + yym3834 := z.EncBinary() + _ = yym3834 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -48239,19 +48157,19 @@ func (x *LocalObjectReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3841[0] { + if yyq3832[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3844 := z.EncBinary() - _ = yym3844 + yym3835 := z.EncBinary() + _ = yym3835 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } } - if yyr3841 || yy2arr3841 { + if yyr3832 || yy2arr3832 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48264,25 +48182,25 @@ func (x *LocalObjectReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3845 := z.DecBinary() - _ = yym3845 + yym3836 := z.DecBinary() + _ = yym3836 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3846 := r.ContainerType() - if yyct3846 == codecSelferValueTypeMap1234 { - yyl3846 := r.ReadMapStart() - if yyl3846 == 0 { + yyct3837 := r.ContainerType() + if yyct3837 == codecSelferValueTypeMap1234 { + yyl3837 := r.ReadMapStart() + if yyl3837 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3846, d) + x.codecDecodeSelfFromMap(yyl3837, d) } - } else if yyct3846 == codecSelferValueTypeArray1234 { - yyl3846 := r.ReadArrayStart() - if yyl3846 == 0 { + } else if yyct3837 == codecSelferValueTypeArray1234 { + yyl3837 := r.ReadArrayStart() + if yyl3837 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3846, d) + x.codecDecodeSelfFromArray(yyl3837, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48294,12 +48212,12 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3847Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3847Slc - var yyhl3847 bool = l >= 0 - for yyj3847 := 0; ; yyj3847++ { - if yyhl3847 { - if yyj3847 >= l { + var yys3838Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3838Slc + var yyhl3838 bool = l >= 0 + for yyj3838 := 0; ; yyj3838++ { + if yyhl3838 { + if yyj3838 >= l { break } } else { @@ -48308,10 +48226,10 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3847Slc = r.DecodeBytes(yys3847Slc, true, true) - yys3847 := string(yys3847Slc) + yys3838Slc = r.DecodeBytes(yys3838Slc, true, true) + yys3838 := string(yys3838Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3847 { + switch yys3838 { case "name": if r.TryDecodeAsNil() { x.Name = "" @@ -48319,9 +48237,9 @@ func (x *LocalObjectReference) codecDecodeSelfFromMap(l int, d *codec1978.Decode x.Name = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3847) - } // end switch yys3847 - } // end for yyj3847 + z.DecStructFieldNotFound(-1, yys3838) + } // end switch yys3838 + } // end for yyj3838 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48329,16 +48247,16 @@ func (x *LocalObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3849 int - var yyb3849 bool - var yyhl3849 bool = l >= 0 - yyj3849++ - if yyhl3849 { - yyb3849 = yyj3849 > l + var yyj3840 int + var yyb3840 bool + var yyhl3840 bool = l >= 0 + yyj3840++ + if yyhl3840 { + yyb3840 = yyj3840 > l } else { - yyb3849 = r.CheckBreak() + yyb3840 = r.CheckBreak() } - if yyb3849 { + if yyb3840 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48349,17 +48267,17 @@ func (x *LocalObjectReference) codecDecodeSelfFromArray(l int, d *codec1978.Deco x.Name = string(r.DecodeString()) } for { - yyj3849++ - if yyhl3849 { - yyb3849 = yyj3849 > l + yyj3840++ + if yyhl3840 { + yyb3840 = yyj3840 > l } else { - yyb3849 = r.CheckBreak() + yyb3840 = r.CheckBreak() } - if yyb3849 { + if yyb3840 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3849-1, "") + z.DecStructFieldNotFound(yyj3840-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48371,37 +48289,37 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3851 := z.EncBinary() - _ = yym3851 + yym3842 := z.EncBinary() + _ = yym3842 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3852 := !z.EncBinary() - yy2arr3852 := z.EncBasicHandle().StructToArray - var yyq3852 [3]bool - _, _, _ = yysep3852, yyq3852, yy2arr3852 - const yyr3852 bool = false - yyq3852[0] = x.Kind != "" - yyq3852[1] = x.APIVersion != "" - yyq3852[2] = true - var yynn3852 int - if yyr3852 || yy2arr3852 { + yysep3843 := !z.EncBinary() + yy2arr3843 := z.EncBasicHandle().StructToArray + var yyq3843 [3]bool + _, _, _ = yysep3843, yyq3843, yy2arr3843 + const yyr3843 bool = false + yyq3843[0] = x.Kind != "" + yyq3843[1] = x.APIVersion != "" + yyq3843[2] = true + var yynn3843 int + if yyr3843 || yy2arr3843 { r.EncodeArrayStart(3) } else { - yynn3852 = 0 - for _, b := range yyq3852 { + yynn3843 = 0 + for _, b := range yyq3843 { if b { - yynn3852++ + yynn3843++ } } - r.EncodeMapStart(yynn3852) - yynn3852 = 0 + r.EncodeMapStart(yynn3843) + yynn3843 = 0 } - if yyr3852 || yy2arr3852 { + if yyr3843 || yy2arr3843 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3852[0] { - yym3854 := z.EncBinary() - _ = yym3854 + if yyq3843[0] { + yym3845 := z.EncBinary() + _ = yym3845 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -48410,23 +48328,23 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3852[0] { + if yyq3843[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3855 := z.EncBinary() - _ = yym3855 + yym3846 := z.EncBinary() + _ = yym3846 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3852 || yy2arr3852 { + if yyr3843 || yy2arr3843 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3852[1] { - yym3857 := z.EncBinary() - _ = yym3857 + if yyq3843[1] { + yym3848 := z.EncBinary() + _ = yym3848 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -48435,36 +48353,36 @@ func (x *SerializedReference) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3852[1] { + if yyq3843[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3858 := z.EncBinary() - _ = yym3858 + yym3849 := z.EncBinary() + _ = yym3849 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3852 || yy2arr3852 { + if yyr3843 || yy2arr3843 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3852[2] { - yy3860 := &x.Reference - yy3860.CodecEncodeSelf(e) + if yyq3843[2] { + yy3851 := &x.Reference + yy3851.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3852[2] { + if yyq3843[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reference")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3861 := &x.Reference - yy3861.CodecEncodeSelf(e) + yy3852 := &x.Reference + yy3852.CodecEncodeSelf(e) } } - if yyr3852 || yy2arr3852 { + if yyr3843 || yy2arr3843 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48477,25 +48395,25 @@ func (x *SerializedReference) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3862 := z.DecBinary() - _ = yym3862 + yym3853 := z.DecBinary() + _ = yym3853 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3863 := r.ContainerType() - if yyct3863 == codecSelferValueTypeMap1234 { - yyl3863 := r.ReadMapStart() - if yyl3863 == 0 { + yyct3854 := r.ContainerType() + if yyct3854 == codecSelferValueTypeMap1234 { + yyl3854 := r.ReadMapStart() + if yyl3854 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3863, d) + x.codecDecodeSelfFromMap(yyl3854, d) } - } else if yyct3863 == codecSelferValueTypeArray1234 { - yyl3863 := r.ReadArrayStart() - if yyl3863 == 0 { + } else if yyct3854 == codecSelferValueTypeArray1234 { + yyl3854 := r.ReadArrayStart() + if yyl3854 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3863, d) + x.codecDecodeSelfFromArray(yyl3854, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48507,12 +48425,12 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3864Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3864Slc - var yyhl3864 bool = l >= 0 - for yyj3864 := 0; ; yyj3864++ { - if yyhl3864 { - if yyj3864 >= l { + var yys3855Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3855Slc + var yyhl3855 bool = l >= 0 + for yyj3855 := 0; ; yyj3855++ { + if yyhl3855 { + if yyj3855 >= l { break } } else { @@ -48521,10 +48439,10 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3864Slc = r.DecodeBytes(yys3864Slc, true, true) - yys3864 := string(yys3864Slc) + yys3855Slc = r.DecodeBytes(yys3855Slc, true, true) + yys3855 := string(yys3855Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3864 { + switch yys3855 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -48541,13 +48459,13 @@ func (x *SerializedReference) codecDecodeSelfFromMap(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Reference = ObjectReference{} } else { - yyv3867 := &x.Reference - yyv3867.CodecDecodeSelf(d) + yyv3858 := &x.Reference + yyv3858.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys3864) - } // end switch yys3864 - } // end for yyj3864 + z.DecStructFieldNotFound(-1, yys3855) + } // end switch yys3855 + } // end for yyj3855 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48555,16 +48473,16 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3868 int - var yyb3868 bool - var yyhl3868 bool = l >= 0 - yyj3868++ - if yyhl3868 { - yyb3868 = yyj3868 > l + var yyj3859 int + var yyb3859 bool + var yyhl3859 bool = l >= 0 + yyj3859++ + if yyhl3859 { + yyb3859 = yyj3859 > l } else { - yyb3868 = r.CheckBreak() + yyb3859 = r.CheckBreak() } - if yyb3868 { + if yyb3859 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48574,13 +48492,13 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj3868++ - if yyhl3868 { - yyb3868 = yyj3868 > l + yyj3859++ + if yyhl3859 { + yyb3859 = yyj3859 > l } else { - yyb3868 = r.CheckBreak() + yyb3859 = r.CheckBreak() } - if yyb3868 { + if yyb3859 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48590,13 +48508,13 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj3868++ - if yyhl3868 { - yyb3868 = yyj3868 > l + yyj3859++ + if yyhl3859 { + yyb3859 = yyj3859 > l } else { - yyb3868 = r.CheckBreak() + yyb3859 = r.CheckBreak() } - if yyb3868 { + if yyb3859 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48604,21 +48522,21 @@ func (x *SerializedReference) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Reference = ObjectReference{} } else { - yyv3871 := &x.Reference - yyv3871.CodecDecodeSelf(d) + yyv3862 := &x.Reference + yyv3862.CodecDecodeSelf(d) } for { - yyj3868++ - if yyhl3868 { - yyb3868 = yyj3868 > l + yyj3859++ + if yyhl3859 { + yyb3859 = yyj3859 > l } else { - yyb3868 = r.CheckBreak() + yyb3859 = r.CheckBreak() } - if yyb3868 { + if yyb3859 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3868-1, "") + z.DecStructFieldNotFound(yyj3859-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48630,36 +48548,36 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3872 := z.EncBinary() - _ = yym3872 + yym3863 := z.EncBinary() + _ = yym3863 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3873 := !z.EncBinary() - yy2arr3873 := z.EncBasicHandle().StructToArray - var yyq3873 [2]bool - _, _, _ = yysep3873, yyq3873, yy2arr3873 - const yyr3873 bool = false - yyq3873[0] = x.Component != "" - yyq3873[1] = x.Host != "" - var yynn3873 int - if yyr3873 || yy2arr3873 { + yysep3864 := !z.EncBinary() + yy2arr3864 := z.EncBasicHandle().StructToArray + var yyq3864 [2]bool + _, _, _ = yysep3864, yyq3864, yy2arr3864 + const yyr3864 bool = false + yyq3864[0] = x.Component != "" + yyq3864[1] = x.Host != "" + var yynn3864 int + if yyr3864 || yy2arr3864 { r.EncodeArrayStart(2) } else { - yynn3873 = 0 - for _, b := range yyq3873 { + yynn3864 = 0 + for _, b := range yyq3864 { if b { - yynn3873++ + yynn3864++ } } - r.EncodeMapStart(yynn3873) - yynn3873 = 0 + r.EncodeMapStart(yynn3864) + yynn3864 = 0 } - if yyr3873 || yy2arr3873 { + if yyr3864 || yy2arr3864 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3873[0] { - yym3875 := z.EncBinary() - _ = yym3875 + if yyq3864[0] { + yym3866 := z.EncBinary() + _ = yym3866 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Component)) @@ -48668,23 +48586,23 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3873[0] { + if yyq3864[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("component")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3876 := z.EncBinary() - _ = yym3876 + yym3867 := z.EncBinary() + _ = yym3867 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Component)) } } } - if yyr3873 || yy2arr3873 { + if yyr3864 || yy2arr3864 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3873[1] { - yym3878 := z.EncBinary() - _ = yym3878 + if yyq3864[1] { + yym3869 := z.EncBinary() + _ = yym3869 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) @@ -48693,19 +48611,19 @@ func (x *EventSource) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3873[1] { + if yyq3864[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("host")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3879 := z.EncBinary() - _ = yym3879 + yym3870 := z.EncBinary() + _ = yym3870 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) } } } - if yyr3873 || yy2arr3873 { + if yyr3864 || yy2arr3864 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -48718,25 +48636,25 @@ func (x *EventSource) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3880 := z.DecBinary() - _ = yym3880 + yym3871 := z.DecBinary() + _ = yym3871 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3881 := r.ContainerType() - if yyct3881 == codecSelferValueTypeMap1234 { - yyl3881 := r.ReadMapStart() - if yyl3881 == 0 { + yyct3872 := r.ContainerType() + if yyct3872 == codecSelferValueTypeMap1234 { + yyl3872 := r.ReadMapStart() + if yyl3872 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3881, d) + x.codecDecodeSelfFromMap(yyl3872, d) } - } else if yyct3881 == codecSelferValueTypeArray1234 { - yyl3881 := r.ReadArrayStart() - if yyl3881 == 0 { + } else if yyct3872 == codecSelferValueTypeArray1234 { + yyl3872 := r.ReadArrayStart() + if yyl3872 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3881, d) + x.codecDecodeSelfFromArray(yyl3872, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -48748,12 +48666,12 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3882Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3882Slc - var yyhl3882 bool = l >= 0 - for yyj3882 := 0; ; yyj3882++ { - if yyhl3882 { - if yyj3882 >= l { + var yys3873Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3873Slc + var yyhl3873 bool = l >= 0 + for yyj3873 := 0; ; yyj3873++ { + if yyhl3873 { + if yyj3873 >= l { break } } else { @@ -48762,10 +48680,10 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3882Slc = r.DecodeBytes(yys3882Slc, true, true) - yys3882 := string(yys3882Slc) + yys3873Slc = r.DecodeBytes(yys3873Slc, true, true) + yys3873 := string(yys3873Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3882 { + switch yys3873 { case "component": if r.TryDecodeAsNil() { x.Component = "" @@ -48779,9 +48697,9 @@ func (x *EventSource) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Host = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3882) - } // end switch yys3882 - } // end for yyj3882 + z.DecStructFieldNotFound(-1, yys3873) + } // end switch yys3873 + } // end for yyj3873 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -48789,16 +48707,16 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3885 int - var yyb3885 bool - var yyhl3885 bool = l >= 0 - yyj3885++ - if yyhl3885 { - yyb3885 = yyj3885 > l + var yyj3876 int + var yyb3876 bool + var yyhl3876 bool = l >= 0 + yyj3876++ + if yyhl3876 { + yyb3876 = yyj3876 > l } else { - yyb3885 = r.CheckBreak() + yyb3876 = r.CheckBreak() } - if yyb3885 { + if yyb3876 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48808,13 +48726,13 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Component = string(r.DecodeString()) } - yyj3885++ - if yyhl3885 { - yyb3885 = yyj3885 > l + yyj3876++ + if yyhl3876 { + yyb3876 = yyj3876 > l } else { - yyb3885 = r.CheckBreak() + yyb3876 = r.CheckBreak() } - if yyb3885 { + if yyb3876 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -48825,17 +48743,17 @@ func (x *EventSource) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Host = string(r.DecodeString()) } for { - yyj3885++ - if yyhl3885 { - yyb3885 = yyj3885 > l + yyj3876++ + if yyhl3876 { + yyb3876 = yyj3876 > l } else { - yyb3885 = r.CheckBreak() + yyb3876 = r.CheckBreak() } - if yyb3885 { + if yyb3876 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3885-1, "") + z.DecStructFieldNotFound(yyj3876-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -48847,43 +48765,43 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3888 := z.EncBinary() - _ = yym3888 + yym3879 := z.EncBinary() + _ = yym3879 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3889 := !z.EncBinary() - yy2arr3889 := z.EncBasicHandle().StructToArray - var yyq3889 [11]bool - _, _, _ = yysep3889, yyq3889, yy2arr3889 - const yyr3889 bool = false - yyq3889[0] = x.Kind != "" - yyq3889[1] = x.APIVersion != "" - yyq3889[4] = x.Reason != "" - yyq3889[5] = x.Message != "" - yyq3889[6] = true - yyq3889[7] = true - yyq3889[8] = true - yyq3889[9] = x.Count != 0 - yyq3889[10] = x.Type != "" - var yynn3889 int - if yyr3889 || yy2arr3889 { + yysep3880 := !z.EncBinary() + yy2arr3880 := z.EncBasicHandle().StructToArray + var yyq3880 [11]bool + _, _, _ = yysep3880, yyq3880, yy2arr3880 + const yyr3880 bool = false + yyq3880[0] = x.Kind != "" + yyq3880[1] = x.APIVersion != "" + yyq3880[4] = x.Reason != "" + yyq3880[5] = x.Message != "" + yyq3880[6] = true + yyq3880[7] = true + yyq3880[8] = true + yyq3880[9] = x.Count != 0 + yyq3880[10] = x.Type != "" + var yynn3880 int + if yyr3880 || yy2arr3880 { r.EncodeArrayStart(11) } else { - yynn3889 = 2 - for _, b := range yyq3889 { + yynn3880 = 2 + for _, b := range yyq3880 { if b { - yynn3889++ + yynn3880++ } } - r.EncodeMapStart(yynn3889) - yynn3889 = 0 + r.EncodeMapStart(yynn3880) + yynn3880 = 0 } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[0] { - yym3891 := z.EncBinary() - _ = yym3891 + if yyq3880[0] { + yym3882 := z.EncBinary() + _ = yym3882 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -48892,23 +48810,23 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3889[0] { + if yyq3880[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3892 := z.EncBinary() - _ = yym3892 + yym3883 := z.EncBinary() + _ = yym3883 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[1] { - yym3894 := z.EncBinary() - _ = yym3894 + if yyq3880[1] { + yym3885 := z.EncBinary() + _ = yym3885 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -48917,70 +48835,70 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3889[1] { + if yyq3880[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym3886 := z.EncBinary() + _ = yym3886 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr3880 || yy2arr3880 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy3888 := &x.ObjectMeta + yy3888.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy3889 := &x.ObjectMeta + yy3889.CodecEncodeSelf(e) + } + if yyr3880 || yy2arr3880 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy3891 := &x.InvolvedObject + yy3891.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("involvedObject")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy3892 := &x.InvolvedObject + yy3892.CodecEncodeSelf(e) + } + if yyr3880 || yy2arr3880 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq3880[4] { + yym3894 := z.EncBinary() + _ = yym3894 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq3880[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym3895 := z.EncBinary() _ = yym3895 if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr3889 || yy2arr3889 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3897 := &x.ObjectMeta - yy3897.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3898 := &x.ObjectMeta - yy3898.CodecEncodeSelf(e) - } - if yyr3889 || yy2arr3889 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy3900 := &x.InvolvedObject - yy3900.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("involvedObject")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3901 := &x.InvolvedObject - yy3901.CodecEncodeSelf(e) - } - if yyr3889 || yy2arr3889 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[4] { - yym3903 := z.EncBinary() - _ = yym3903 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq3889[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("reason")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3904 := z.EncBinary() - _ = yym3904 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[5] { - yym3906 := z.EncBinary() - _ = yym3906 + if yyq3880[5] { + yym3897 := z.EncBinary() + _ = yym3897 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -48989,114 +48907,114 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3889[5] { + if yyq3880[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3907 := z.EncBinary() - _ = yym3907 + yym3898 := z.EncBinary() + _ = yym3898 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[6] { - yy3909 := &x.Source - yy3909.CodecEncodeSelf(e) + if yyq3880[6] { + yy3900 := &x.Source + yy3900.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq3889[6] { + if yyq3880[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("source")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3910 := &x.Source - yy3910.CodecEncodeSelf(e) + yy3901 := &x.Source + yy3901.CodecEncodeSelf(e) } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[7] { - yy3912 := &x.FirstTimestamp - yym3913 := z.EncBinary() - _ = yym3913 + if yyq3880[7] { + yy3903 := &x.FirstTimestamp + yym3904 := z.EncBinary() + _ = yym3904 if false { - } else if z.HasExtensions() && z.EncExt(yy3912) { - } else if yym3913 { - z.EncBinaryMarshal(yy3912) - } else if !yym3913 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3912) + } else if z.HasExtensions() && z.EncExt(yy3903) { + } else if yym3904 { + z.EncBinaryMarshal(yy3903) + } else if !yym3904 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3903) } else { - z.EncFallback(yy3912) + z.EncFallback(yy3903) } } else { r.EncodeNil() } } else { - if yyq3889[7] { + if yyq3880[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("firstTimestamp")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3914 := &x.FirstTimestamp - yym3915 := z.EncBinary() - _ = yym3915 + yy3905 := &x.FirstTimestamp + yym3906 := z.EncBinary() + _ = yym3906 if false { - } else if z.HasExtensions() && z.EncExt(yy3914) { - } else if yym3915 { - z.EncBinaryMarshal(yy3914) - } else if !yym3915 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3914) + } else if z.HasExtensions() && z.EncExt(yy3905) { + } else if yym3906 { + z.EncBinaryMarshal(yy3905) + } else if !yym3906 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3905) } else { - z.EncFallback(yy3914) + z.EncFallback(yy3905) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[8] { - yy3917 := &x.LastTimestamp - yym3918 := z.EncBinary() - _ = yym3918 + if yyq3880[8] { + yy3908 := &x.LastTimestamp + yym3909 := z.EncBinary() + _ = yym3909 if false { - } else if z.HasExtensions() && z.EncExt(yy3917) { - } else if yym3918 { - z.EncBinaryMarshal(yy3917) - } else if !yym3918 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3917) + } else if z.HasExtensions() && z.EncExt(yy3908) { + } else if yym3909 { + z.EncBinaryMarshal(yy3908) + } else if !yym3909 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3908) } else { - z.EncFallback(yy3917) + z.EncFallback(yy3908) } } else { r.EncodeNil() } } else { - if yyq3889[8] { + if yyq3880[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTimestamp")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3919 := &x.LastTimestamp - yym3920 := z.EncBinary() - _ = yym3920 + yy3910 := &x.LastTimestamp + yym3911 := z.EncBinary() + _ = yym3911 if false { - } else if z.HasExtensions() && z.EncExt(yy3919) { - } else if yym3920 { - z.EncBinaryMarshal(yy3919) - } else if !yym3920 && z.IsJSONHandle() { - z.EncJSONMarshal(yy3919) + } else if z.HasExtensions() && z.EncExt(yy3910) { + } else if yym3911 { + z.EncBinaryMarshal(yy3910) + } else if !yym3911 && z.IsJSONHandle() { + z.EncJSONMarshal(yy3910) } else { - z.EncFallback(yy3919) + z.EncFallback(yy3910) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[9] { - yym3922 := z.EncBinary() - _ = yym3922 + if yyq3880[9] { + yym3913 := z.EncBinary() + _ = yym3913 if false { } else { r.EncodeInt(int64(x.Count)) @@ -49105,23 +49023,23 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq3889[9] { + if yyq3880[9] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("count")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3923 := z.EncBinary() - _ = yym3923 + yym3914 := z.EncBinary() + _ = yym3914 if false { } else { r.EncodeInt(int64(x.Count)) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3889[10] { - yym3925 := z.EncBinary() - _ = yym3925 + if yyq3880[10] { + yym3916 := z.EncBinary() + _ = yym3916 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Type)) @@ -49130,19 +49048,19 @@ func (x *Event) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3889[10] { + if yyq3880[10] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3926 := z.EncBinary() - _ = yym3926 + yym3917 := z.EncBinary() + _ = yym3917 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Type)) } } } - if yyr3889 || yy2arr3889 { + if yyr3880 || yy2arr3880 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -49155,25 +49073,25 @@ func (x *Event) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3927 := z.DecBinary() - _ = yym3927 + yym3918 := z.DecBinary() + _ = yym3918 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3928 := r.ContainerType() - if yyct3928 == codecSelferValueTypeMap1234 { - yyl3928 := r.ReadMapStart() - if yyl3928 == 0 { + yyct3919 := r.ContainerType() + if yyct3919 == codecSelferValueTypeMap1234 { + yyl3919 := r.ReadMapStart() + if yyl3919 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3928, d) + x.codecDecodeSelfFromMap(yyl3919, d) } - } else if yyct3928 == codecSelferValueTypeArray1234 { - yyl3928 := r.ReadArrayStart() - if yyl3928 == 0 { + } else if yyct3919 == codecSelferValueTypeArray1234 { + yyl3919 := r.ReadArrayStart() + if yyl3919 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3928, d) + x.codecDecodeSelfFromArray(yyl3919, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -49185,12 +49103,12 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3929Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3929Slc - var yyhl3929 bool = l >= 0 - for yyj3929 := 0; ; yyj3929++ { - if yyhl3929 { - if yyj3929 >= l { + var yys3920Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3920Slc + var yyhl3920 bool = l >= 0 + for yyj3920 := 0; ; yyj3920++ { + if yyhl3920 { + if yyj3920 >= l { break } } else { @@ -49199,10 +49117,10 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3929Slc = r.DecodeBytes(yys3929Slc, true, true) - yys3929 := string(yys3929Slc) + yys3920Slc = r.DecodeBytes(yys3920Slc, true, true) + yys3920 := string(yys3920Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3929 { + switch yys3920 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -49219,15 +49137,15 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3932 := &x.ObjectMeta - yyv3932.CodecDecodeSelf(d) + yyv3923 := &x.ObjectMeta + yyv3923.CodecDecodeSelf(d) } case "involvedObject": if r.TryDecodeAsNil() { x.InvolvedObject = ObjectReference{} } else { - yyv3933 := &x.InvolvedObject - yyv3933.CodecDecodeSelf(d) + yyv3924 := &x.InvolvedObject + yyv3924.CodecDecodeSelf(d) } case "reason": if r.TryDecodeAsNil() { @@ -49245,41 +49163,41 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Source = EventSource{} } else { - yyv3936 := &x.Source - yyv3936.CodecDecodeSelf(d) + yyv3927 := &x.Source + yyv3927.CodecDecodeSelf(d) } case "firstTimestamp": if r.TryDecodeAsNil() { x.FirstTimestamp = pkg2_unversioned.Time{} } else { - yyv3937 := &x.FirstTimestamp - yym3938 := z.DecBinary() - _ = yym3938 + yyv3928 := &x.FirstTimestamp + yym3929 := z.DecBinary() + _ = yym3929 if false { - } else if z.HasExtensions() && z.DecExt(yyv3937) { - } else if yym3938 { - z.DecBinaryUnmarshal(yyv3937) - } else if !yym3938 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3937) + } else if z.HasExtensions() && z.DecExt(yyv3928) { + } else if yym3929 { + z.DecBinaryUnmarshal(yyv3928) + } else if !yym3929 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3928) } else { - z.DecFallback(yyv3937, false) + z.DecFallback(yyv3928, false) } } case "lastTimestamp": if r.TryDecodeAsNil() { x.LastTimestamp = pkg2_unversioned.Time{} } else { - yyv3939 := &x.LastTimestamp - yym3940 := z.DecBinary() - _ = yym3940 + yyv3930 := &x.LastTimestamp + yym3931 := z.DecBinary() + _ = yym3931 if false { - } else if z.HasExtensions() && z.DecExt(yyv3939) { - } else if yym3940 { - z.DecBinaryUnmarshal(yyv3939) - } else if !yym3940 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3939) + } else if z.HasExtensions() && z.DecExt(yyv3930) { + } else if yym3931 { + z.DecBinaryUnmarshal(yyv3930) + } else if !yym3931 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3930) } else { - z.DecFallback(yyv3939, false) + z.DecFallback(yyv3930, false) } } case "count": @@ -49295,9 +49213,9 @@ func (x *Event) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Type = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys3929) - } // end switch yys3929 - } // end for yyj3929 + z.DecStructFieldNotFound(-1, yys3920) + } // end switch yys3920 + } // end for yyj3920 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -49305,16 +49223,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3943 int - var yyb3943 bool - var yyhl3943 bool = l >= 0 - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + var yyj3934 int + var yyb3934 bool + var yyhl3934 bool = l >= 0 + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49324,13 +49242,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49340,13 +49258,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49354,16 +49272,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv3946 := &x.ObjectMeta - yyv3946.CodecDecodeSelf(d) + yyv3937 := &x.ObjectMeta + yyv3937.CodecDecodeSelf(d) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49371,16 +49289,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.InvolvedObject = ObjectReference{} } else { - yyv3947 := &x.InvolvedObject - yyv3947.CodecDecodeSelf(d) + yyv3938 := &x.InvolvedObject + yyv3938.CodecDecodeSelf(d) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49390,13 +49308,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49406,13 +49324,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Message = string(r.DecodeString()) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49420,16 +49338,16 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Source = EventSource{} } else { - yyv3950 := &x.Source - yyv3950.CodecDecodeSelf(d) + yyv3941 := &x.Source + yyv3941.CodecDecodeSelf(d) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49437,26 +49355,26 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.FirstTimestamp = pkg2_unversioned.Time{} } else { - yyv3951 := &x.FirstTimestamp - yym3952 := z.DecBinary() - _ = yym3952 + yyv3942 := &x.FirstTimestamp + yym3943 := z.DecBinary() + _ = yym3943 if false { - } else if z.HasExtensions() && z.DecExt(yyv3951) { - } else if yym3952 { - z.DecBinaryUnmarshal(yyv3951) - } else if !yym3952 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3951) + } else if z.HasExtensions() && z.DecExt(yyv3942) { + } else if yym3943 { + z.DecBinaryUnmarshal(yyv3942) + } else if !yym3943 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3942) } else { - z.DecFallback(yyv3951, false) + z.DecFallback(yyv3942, false) } } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49464,26 +49382,26 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTimestamp = pkg2_unversioned.Time{} } else { - yyv3953 := &x.LastTimestamp - yym3954 := z.DecBinary() - _ = yym3954 + yyv3944 := &x.LastTimestamp + yym3945 := z.DecBinary() + _ = yym3945 if false { - } else if z.HasExtensions() && z.DecExt(yyv3953) { - } else if yym3954 { - z.DecBinaryUnmarshal(yyv3953) - } else if !yym3954 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv3953) + } else if z.HasExtensions() && z.DecExt(yyv3944) { + } else if yym3945 { + z.DecBinaryUnmarshal(yyv3944) + } else if !yym3945 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv3944) } else { - z.DecFallback(yyv3953, false) + z.DecFallback(yyv3944, false) } } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49493,13 +49411,13 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Count = int32(r.DecodeInt(32)) } - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49510,17 +49428,17 @@ func (x *Event) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Type = string(r.DecodeString()) } for { - yyj3943++ - if yyhl3943 { - yyb3943 = yyj3943 > l + yyj3934++ + if yyhl3934 { + yyb3934 = yyj3934 > l } else { - yyb3943 = r.CheckBreak() + yyb3934 = r.CheckBreak() } - if yyb3943 { + if yyb3934 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3943-1, "") + z.DecStructFieldNotFound(yyj3934-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -49532,37 +49450,37 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3957 := z.EncBinary() - _ = yym3957 + yym3948 := z.EncBinary() + _ = yym3948 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3958 := !z.EncBinary() - yy2arr3958 := z.EncBasicHandle().StructToArray - var yyq3958 [4]bool - _, _, _ = yysep3958, yyq3958, yy2arr3958 - const yyr3958 bool = false - yyq3958[0] = x.Kind != "" - yyq3958[1] = x.APIVersion != "" - yyq3958[2] = true - var yynn3958 int - if yyr3958 || yy2arr3958 { + yysep3949 := !z.EncBinary() + yy2arr3949 := z.EncBasicHandle().StructToArray + var yyq3949 [4]bool + _, _, _ = yysep3949, yyq3949, yy2arr3949 + const yyr3949 bool = false + yyq3949[0] = x.Kind != "" + yyq3949[1] = x.APIVersion != "" + yyq3949[2] = true + var yynn3949 int + if yyr3949 || yy2arr3949 { r.EncodeArrayStart(4) } else { - yynn3958 = 1 - for _, b := range yyq3958 { + yynn3949 = 1 + for _, b := range yyq3949 { if b { - yynn3958++ + yynn3949++ } } - r.EncodeMapStart(yynn3958) - yynn3958 = 0 + r.EncodeMapStart(yynn3949) + yynn3949 = 0 } - if yyr3958 || yy2arr3958 { + if yyr3949 || yy2arr3949 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3958[0] { - yym3960 := z.EncBinary() - _ = yym3960 + if yyq3949[0] { + yym3951 := z.EncBinary() + _ = yym3951 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -49571,23 +49489,23 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3958[0] { + if yyq3949[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3961 := z.EncBinary() - _ = yym3961 + yym3952 := z.EncBinary() + _ = yym3952 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3958 || yy2arr3958 { + if yyr3949 || yy2arr3949 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3958[1] { - yym3963 := z.EncBinary() - _ = yym3963 + if yyq3949[1] { + yym3954 := z.EncBinary() + _ = yym3954 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -49596,54 +49514,54 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3958[1] { + if yyq3949[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3964 := z.EncBinary() - _ = yym3964 + yym3955 := z.EncBinary() + _ = yym3955 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3958 || yy2arr3958 { + if yyr3949 || yy2arr3949 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3958[2] { - yy3966 := &x.ListMeta - yym3967 := z.EncBinary() - _ = yym3967 + if yyq3949[2] { + yy3957 := &x.ListMeta + yym3958 := z.EncBinary() + _ = yym3958 if false { - } else if z.HasExtensions() && z.EncExt(yy3966) { + } else if z.HasExtensions() && z.EncExt(yy3957) { } else { - z.EncFallback(yy3966) + z.EncFallback(yy3957) } } else { r.EncodeNil() } } else { - if yyq3958[2] { + if yyq3949[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy3968 := &x.ListMeta - yym3969 := z.EncBinary() - _ = yym3969 + yy3959 := &x.ListMeta + yym3960 := z.EncBinary() + _ = yym3960 if false { - } else if z.HasExtensions() && z.EncExt(yy3968) { + } else if z.HasExtensions() && z.EncExt(yy3959) { } else { - z.EncFallback(yy3968) + z.EncFallback(yy3959) } } } - if yyr3958 || yy2arr3958 { + if yyr3949 || yy2arr3949 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym3971 := z.EncBinary() - _ = yym3971 + yym3962 := z.EncBinary() + _ = yym3962 if false { } else { h.encSliceEvent(([]Event)(x.Items), e) @@ -49656,15 +49574,15 @@ func (x *EventList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym3972 := z.EncBinary() - _ = yym3972 + yym3963 := z.EncBinary() + _ = yym3963 if false { } else { h.encSliceEvent(([]Event)(x.Items), e) } } } - if yyr3958 || yy2arr3958 { + if yyr3949 || yy2arr3949 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -49677,25 +49595,25 @@ func (x *EventList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym3973 := z.DecBinary() - _ = yym3973 + yym3964 := z.DecBinary() + _ = yym3964 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct3974 := r.ContainerType() - if yyct3974 == codecSelferValueTypeMap1234 { - yyl3974 := r.ReadMapStart() - if yyl3974 == 0 { + yyct3965 := r.ContainerType() + if yyct3965 == codecSelferValueTypeMap1234 { + yyl3965 := r.ReadMapStart() + if yyl3965 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl3974, d) + x.codecDecodeSelfFromMap(yyl3965, d) } - } else if yyct3974 == codecSelferValueTypeArray1234 { - yyl3974 := r.ReadArrayStart() - if yyl3974 == 0 { + } else if yyct3965 == codecSelferValueTypeArray1234 { + yyl3965 := r.ReadArrayStart() + if yyl3965 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl3974, d) + x.codecDecodeSelfFromArray(yyl3965, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -49707,12 +49625,12 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys3975Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys3975Slc - var yyhl3975 bool = l >= 0 - for yyj3975 := 0; ; yyj3975++ { - if yyhl3975 { - if yyj3975 >= l { + var yys3966Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3966Slc + var yyhl3966 bool = l >= 0 + for yyj3966 := 0; ; yyj3966++ { + if yyhl3966 { + if yyj3966 >= l { break } } else { @@ -49721,10 +49639,10 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys3975Slc = r.DecodeBytes(yys3975Slc, true, true) - yys3975 := string(yys3975Slc) + yys3966Slc = r.DecodeBytes(yys3966Slc, true, true) + yys3966 := string(yys3966Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys3975 { + switch yys3966 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -49741,31 +49659,31 @@ func (x *EventList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3978 := &x.ListMeta - yym3979 := z.DecBinary() - _ = yym3979 + yyv3969 := &x.ListMeta + yym3970 := z.DecBinary() + _ = yym3970 if false { - } else if z.HasExtensions() && z.DecExt(yyv3978) { + } else if z.HasExtensions() && z.DecExt(yyv3969) { } else { - z.DecFallback(yyv3978, false) + z.DecFallback(yyv3969, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3980 := &x.Items - yym3981 := z.DecBinary() - _ = yym3981 + yyv3971 := &x.Items + yym3972 := z.DecBinary() + _ = yym3972 if false { } else { - h.decSliceEvent((*[]Event)(yyv3980), d) + h.decSliceEvent((*[]Event)(yyv3971), d) } } default: - z.DecStructFieldNotFound(-1, yys3975) - } // end switch yys3975 - } // end for yyj3975 + z.DecStructFieldNotFound(-1, yys3966) + } // end switch yys3966 + } // end for yyj3966 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -49773,16 +49691,16 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj3982 int - var yyb3982 bool - var yyhl3982 bool = l >= 0 - yyj3982++ - if yyhl3982 { - yyb3982 = yyj3982 > l + var yyj3973 int + var yyb3973 bool + var yyhl3973 bool = l >= 0 + yyj3973++ + if yyhl3973 { + yyb3973 = yyj3973 > l } else { - yyb3982 = r.CheckBreak() + yyb3973 = r.CheckBreak() } - if yyb3982 { + if yyb3973 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49792,13 +49710,13 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj3982++ - if yyhl3982 { - yyb3982 = yyj3982 > l + yyj3973++ + if yyhl3973 { + yyb3973 = yyj3973 > l } else { - yyb3982 = r.CheckBreak() + yyb3973 = r.CheckBreak() } - if yyb3982 { + if yyb3973 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49808,13 +49726,13 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj3982++ - if yyhl3982 { - yyb3982 = yyj3982 > l + yyj3973++ + if yyhl3973 { + yyb3973 = yyj3973 > l } else { - yyb3982 = r.CheckBreak() + yyb3973 = r.CheckBreak() } - if yyb3982 { + if yyb3973 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49822,22 +49740,22 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv3985 := &x.ListMeta - yym3986 := z.DecBinary() - _ = yym3986 + yyv3976 := &x.ListMeta + yym3977 := z.DecBinary() + _ = yym3977 if false { - } else if z.HasExtensions() && z.DecExt(yyv3985) { + } else if z.HasExtensions() && z.DecExt(yyv3976) { } else { - z.DecFallback(yyv3985, false) + z.DecFallback(yyv3976, false) } } - yyj3982++ - if yyhl3982 { - yyb3982 = yyj3982 > l + yyj3973++ + if yyhl3973 { + yyb3973 = yyj3973 > l } else { - yyb3982 = r.CheckBreak() + yyb3973 = r.CheckBreak() } - if yyb3982 { + if yyb3973 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -49845,26 +49763,26 @@ func (x *EventList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv3987 := &x.Items - yym3988 := z.DecBinary() - _ = yym3988 + yyv3978 := &x.Items + yym3979 := z.DecBinary() + _ = yym3979 if false { } else { - h.decSliceEvent((*[]Event)(yyv3987), d) + h.decSliceEvent((*[]Event)(yyv3978), d) } } for { - yyj3982++ - if yyhl3982 { - yyb3982 = yyj3982 > l + yyj3973++ + if yyhl3973 { + yyb3973 = yyj3973 > l } else { - yyb3982 = r.CheckBreak() + yyb3973 = r.CheckBreak() } - if yyb3982 { + if yyb3973 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj3982-1, "") + z.DecStructFieldNotFound(yyj3973-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -49876,37 +49794,37 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym3989 := z.EncBinary() - _ = yym3989 + yym3980 := z.EncBinary() + _ = yym3980 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep3990 := !z.EncBinary() - yy2arr3990 := z.EncBasicHandle().StructToArray - var yyq3990 [4]bool - _, _, _ = yysep3990, yyq3990, yy2arr3990 - const yyr3990 bool = false - yyq3990[0] = x.Kind != "" - yyq3990[1] = x.APIVersion != "" - yyq3990[2] = true - var yynn3990 int - if yyr3990 || yy2arr3990 { + yysep3981 := !z.EncBinary() + yy2arr3981 := z.EncBasicHandle().StructToArray + var yyq3981 [4]bool + _, _, _ = yysep3981, yyq3981, yy2arr3981 + const yyr3981 bool = false + yyq3981[0] = x.Kind != "" + yyq3981[1] = x.APIVersion != "" + yyq3981[2] = true + var yynn3981 int + if yyr3981 || yy2arr3981 { r.EncodeArrayStart(4) } else { - yynn3990 = 1 - for _, b := range yyq3990 { + yynn3981 = 1 + for _, b := range yyq3981 { if b { - yynn3990++ + yynn3981++ } } - r.EncodeMapStart(yynn3990) - yynn3990 = 0 + r.EncodeMapStart(yynn3981) + yynn3981 = 0 } - if yyr3990 || yy2arr3990 { + if yyr3981 || yy2arr3981 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3990[0] { - yym3992 := z.EncBinary() - _ = yym3992 + if yyq3981[0] { + yym3983 := z.EncBinary() + _ = yym3983 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -49915,23 +49833,23 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3990[0] { + if yyq3981[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3993 := z.EncBinary() - _ = yym3993 + yym3984 := z.EncBinary() + _ = yym3984 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr3990 || yy2arr3990 { + if yyr3981 || yy2arr3981 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3990[1] { - yym3995 := z.EncBinary() - _ = yym3995 + if yyq3981[1] { + yym3986 := z.EncBinary() + _ = yym3986 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -49940,54 +49858,54 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq3990[1] { + if yyq3981[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym3996 := z.EncBinary() - _ = yym3996 + yym3987 := z.EncBinary() + _ = yym3987 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr3990 || yy2arr3990 { + if yyr3981 || yy2arr3981 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq3990[2] { - yy3998 := &x.ListMeta - yym3999 := z.EncBinary() - _ = yym3999 + if yyq3981[2] { + yy3989 := &x.ListMeta + yym3990 := z.EncBinary() + _ = yym3990 if false { - } else if z.HasExtensions() && z.EncExt(yy3998) { + } else if z.HasExtensions() && z.EncExt(yy3989) { } else { - z.EncFallback(yy3998) + z.EncFallback(yy3989) } } else { r.EncodeNil() } } else { - if yyq3990[2] { + if yyq3981[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4000 := &x.ListMeta - yym4001 := z.EncBinary() - _ = yym4001 + yy3991 := &x.ListMeta + yym3992 := z.EncBinary() + _ = yym3992 if false { - } else if z.HasExtensions() && z.EncExt(yy4000) { + } else if z.HasExtensions() && z.EncExt(yy3991) { } else { - z.EncFallback(yy4000) + z.EncFallback(yy3991) } } } - if yyr3990 || yy2arr3990 { + if yyr3981 || yy2arr3981 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4003 := z.EncBinary() - _ = yym4003 + yym3994 := z.EncBinary() + _ = yym3994 if false { } else { h.encSliceruntime_RawExtension(([]pkg5_runtime.RawExtension)(x.Items), e) @@ -50000,15 +49918,15 @@ func (x *List) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4004 := z.EncBinary() - _ = yym4004 + yym3995 := z.EncBinary() + _ = yym3995 if false { } else { h.encSliceruntime_RawExtension(([]pkg5_runtime.RawExtension)(x.Items), e) } } } - if yyr3990 || yy2arr3990 { + if yyr3981 || yy2arr3981 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50021,25 +49939,25 @@ func (x *List) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4005 := z.DecBinary() - _ = yym4005 + yym3996 := z.DecBinary() + _ = yym3996 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4006 := r.ContainerType() - if yyct4006 == codecSelferValueTypeMap1234 { - yyl4006 := r.ReadMapStart() - if yyl4006 == 0 { + yyct3997 := r.ContainerType() + if yyct3997 == codecSelferValueTypeMap1234 { + yyl3997 := r.ReadMapStart() + if yyl3997 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4006, d) + x.codecDecodeSelfFromMap(yyl3997, d) } - } else if yyct4006 == codecSelferValueTypeArray1234 { - yyl4006 := r.ReadArrayStart() - if yyl4006 == 0 { + } else if yyct3997 == codecSelferValueTypeArray1234 { + yyl3997 := r.ReadArrayStart() + if yyl3997 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4006, d) + x.codecDecodeSelfFromArray(yyl3997, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50051,12 +49969,12 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4007Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4007Slc - var yyhl4007 bool = l >= 0 - for yyj4007 := 0; ; yyj4007++ { - if yyhl4007 { - if yyj4007 >= l { + var yys3998Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys3998Slc + var yyhl3998 bool = l >= 0 + for yyj3998 := 0; ; yyj3998++ { + if yyhl3998 { + if yyj3998 >= l { break } } else { @@ -50065,10 +49983,10 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4007Slc = r.DecodeBytes(yys4007Slc, true, true) - yys4007 := string(yys4007Slc) + yys3998Slc = r.DecodeBytes(yys3998Slc, true, true) + yys3998 := string(yys3998Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4007 { + switch yys3998 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -50085,31 +50003,31 @@ func (x *List) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4010 := &x.ListMeta - yym4011 := z.DecBinary() - _ = yym4011 + yyv4001 := &x.ListMeta + yym4002 := z.DecBinary() + _ = yym4002 if false { - } else if z.HasExtensions() && z.DecExt(yyv4010) { + } else if z.HasExtensions() && z.DecExt(yyv4001) { } else { - z.DecFallback(yyv4010, false) + z.DecFallback(yyv4001, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4012 := &x.Items - yym4013 := z.DecBinary() - _ = yym4013 + yyv4003 := &x.Items + yym4004 := z.DecBinary() + _ = yym4004 if false { } else { - h.decSliceruntime_RawExtension((*[]pkg5_runtime.RawExtension)(yyv4012), d) + h.decSliceruntime_RawExtension((*[]pkg5_runtime.RawExtension)(yyv4003), d) } } default: - z.DecStructFieldNotFound(-1, yys4007) - } // end switch yys4007 - } // end for yyj4007 + z.DecStructFieldNotFound(-1, yys3998) + } // end switch yys3998 + } // end for yyj3998 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -50117,16 +50035,16 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4014 int - var yyb4014 bool - var yyhl4014 bool = l >= 0 - yyj4014++ - if yyhl4014 { - yyb4014 = yyj4014 > l + var yyj4005 int + var yyb4005 bool + var yyhl4005 bool = l >= 0 + yyj4005++ + if yyhl4005 { + yyb4005 = yyj4005 > l } else { - yyb4014 = r.CheckBreak() + yyb4005 = r.CheckBreak() } - if yyb4014 { + if yyb4005 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50136,13 +50054,13 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4014++ - if yyhl4014 { - yyb4014 = yyj4014 > l + yyj4005++ + if yyhl4005 { + yyb4005 = yyj4005 > l } else { - yyb4014 = r.CheckBreak() + yyb4005 = r.CheckBreak() } - if yyb4014 { + if yyb4005 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50152,13 +50070,13 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4014++ - if yyhl4014 { - yyb4014 = yyj4014 > l + yyj4005++ + if yyhl4005 { + yyb4005 = yyj4005 > l } else { - yyb4014 = r.CheckBreak() + yyb4005 = r.CheckBreak() } - if yyb4014 { + if yyb4005 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50166,22 +50084,22 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4017 := &x.ListMeta - yym4018 := z.DecBinary() - _ = yym4018 + yyv4008 := &x.ListMeta + yym4009 := z.DecBinary() + _ = yym4009 if false { - } else if z.HasExtensions() && z.DecExt(yyv4017) { + } else if z.HasExtensions() && z.DecExt(yyv4008) { } else { - z.DecFallback(yyv4017, false) + z.DecFallback(yyv4008, false) } } - yyj4014++ - if yyhl4014 { - yyb4014 = yyj4014 > l + yyj4005++ + if yyhl4005 { + yyb4005 = yyj4005 > l } else { - yyb4014 = r.CheckBreak() + yyb4005 = r.CheckBreak() } - if yyb4014 { + if yyb4005 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50189,26 +50107,26 @@ func (x *List) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4019 := &x.Items - yym4020 := z.DecBinary() - _ = yym4020 + yyv4010 := &x.Items + yym4011 := z.DecBinary() + _ = yym4011 if false { } else { - h.decSliceruntime_RawExtension((*[]pkg5_runtime.RawExtension)(yyv4019), d) + h.decSliceruntime_RawExtension((*[]pkg5_runtime.RawExtension)(yyv4010), d) } } for { - yyj4014++ - if yyhl4014 { - yyb4014 = yyj4014 > l + yyj4005++ + if yyhl4005 { + yyb4005 = yyj4005 > l } else { - yyb4014 = r.CheckBreak() + yyb4005 = r.CheckBreak() } - if yyb4014 { + if yyb4005 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4014-1, "") + z.DecStructFieldNotFound(yyj4005-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50217,8 +50135,8 @@ func (x LimitType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4021 := z.EncBinary() - _ = yym4021 + yym4012 := z.EncBinary() + _ = yym4012 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -50230,8 +50148,8 @@ func (x *LimitType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4022 := z.DecBinary() - _ = yym4022 + yym4013 := z.DecBinary() + _ = yym4013 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -50246,53 +50164,53 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4023 := z.EncBinary() - _ = yym4023 + yym4014 := z.EncBinary() + _ = yym4014 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4024 := !z.EncBinary() - yy2arr4024 := z.EncBasicHandle().StructToArray - var yyq4024 [6]bool - _, _, _ = yysep4024, yyq4024, yy2arr4024 - const yyr4024 bool = false - yyq4024[0] = x.Type != "" - yyq4024[1] = len(x.Max) != 0 - yyq4024[2] = len(x.Min) != 0 - yyq4024[3] = len(x.Default) != 0 - yyq4024[4] = len(x.DefaultRequest) != 0 - yyq4024[5] = len(x.MaxLimitRequestRatio) != 0 - var yynn4024 int - if yyr4024 || yy2arr4024 { + yysep4015 := !z.EncBinary() + yy2arr4015 := z.EncBasicHandle().StructToArray + var yyq4015 [6]bool + _, _, _ = yysep4015, yyq4015, yy2arr4015 + const yyr4015 bool = false + yyq4015[0] = x.Type != "" + yyq4015[1] = len(x.Max) != 0 + yyq4015[2] = len(x.Min) != 0 + yyq4015[3] = len(x.Default) != 0 + yyq4015[4] = len(x.DefaultRequest) != 0 + yyq4015[5] = len(x.MaxLimitRequestRatio) != 0 + var yynn4015 int + if yyr4015 || yy2arr4015 { r.EncodeArrayStart(6) } else { - yynn4024 = 0 - for _, b := range yyq4024 { + yynn4015 = 0 + for _, b := range yyq4015 { if b { - yynn4024++ + yynn4015++ } } - r.EncodeMapStart(yynn4024) - yynn4024 = 0 + r.EncodeMapStart(yynn4015) + yynn4015 = 0 } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[0] { + if yyq4015[0] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4024[0] { + if yyq4015[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[1] { + if yyq4015[1] { if x.Max == nil { r.EncodeNil() } else { @@ -50302,7 +50220,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4024[1] { + if yyq4015[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("max")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50313,9 +50231,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[2] { + if yyq4015[2] { if x.Min == nil { r.EncodeNil() } else { @@ -50325,7 +50243,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4024[2] { + if yyq4015[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("min")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50336,9 +50254,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[3] { + if yyq4015[3] { if x.Default == nil { r.EncodeNil() } else { @@ -50348,7 +50266,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4024[3] { + if yyq4015[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("default")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50359,9 +50277,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[4] { + if yyq4015[4] { if x.DefaultRequest == nil { r.EncodeNil() } else { @@ -50371,7 +50289,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4024[4] { + if yyq4015[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("defaultRequest")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50382,9 +50300,9 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4024[5] { + if yyq4015[5] { if x.MaxLimitRequestRatio == nil { r.EncodeNil() } else { @@ -50394,7 +50312,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4024[5] { + if yyq4015[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxLimitRequestRatio")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -50405,7 +50323,7 @@ func (x *LimitRangeItem) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4024 || yy2arr4024 { + if yyr4015 || yy2arr4015 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50418,25 +50336,25 @@ func (x *LimitRangeItem) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4031 := z.DecBinary() - _ = yym4031 + yym4022 := z.DecBinary() + _ = yym4022 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4032 := r.ContainerType() - if yyct4032 == codecSelferValueTypeMap1234 { - yyl4032 := r.ReadMapStart() - if yyl4032 == 0 { + yyct4023 := r.ContainerType() + if yyct4023 == codecSelferValueTypeMap1234 { + yyl4023 := r.ReadMapStart() + if yyl4023 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4032, d) + x.codecDecodeSelfFromMap(yyl4023, d) } - } else if yyct4032 == codecSelferValueTypeArray1234 { - yyl4032 := r.ReadArrayStart() - if yyl4032 == 0 { + } else if yyct4023 == codecSelferValueTypeArray1234 { + yyl4023 := r.ReadArrayStart() + if yyl4023 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4032, d) + x.codecDecodeSelfFromArray(yyl4023, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50448,12 +50366,12 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4033Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4033Slc - var yyhl4033 bool = l >= 0 - for yyj4033 := 0; ; yyj4033++ { - if yyhl4033 { - if yyj4033 >= l { + var yys4024Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4024Slc + var yyhl4024 bool = l >= 0 + for yyj4024 := 0; ; yyj4024++ { + if yyhl4024 { + if yyj4024 >= l { break } } else { @@ -50462,10 +50380,10 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4033Slc = r.DecodeBytes(yys4033Slc, true, true) - yys4033 := string(yys4033Slc) + yys4024Slc = r.DecodeBytes(yys4024Slc, true, true) + yys4024 := string(yys4024Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4033 { + switch yys4024 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -50476,41 +50394,41 @@ func (x *LimitRangeItem) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Max = nil } else { - yyv4035 := &x.Max - yyv4035.CodecDecodeSelf(d) + yyv4026 := &x.Max + yyv4026.CodecDecodeSelf(d) } case "min": if r.TryDecodeAsNil() { x.Min = nil } else { - yyv4036 := &x.Min - yyv4036.CodecDecodeSelf(d) + yyv4027 := &x.Min + yyv4027.CodecDecodeSelf(d) } case "default": if r.TryDecodeAsNil() { x.Default = nil } else { - yyv4037 := &x.Default - yyv4037.CodecDecodeSelf(d) + yyv4028 := &x.Default + yyv4028.CodecDecodeSelf(d) } case "defaultRequest": if r.TryDecodeAsNil() { x.DefaultRequest = nil } else { - yyv4038 := &x.DefaultRequest - yyv4038.CodecDecodeSelf(d) + yyv4029 := &x.DefaultRequest + yyv4029.CodecDecodeSelf(d) } case "maxLimitRequestRatio": if r.TryDecodeAsNil() { x.MaxLimitRequestRatio = nil } else { - yyv4039 := &x.MaxLimitRequestRatio - yyv4039.CodecDecodeSelf(d) + yyv4030 := &x.MaxLimitRequestRatio + yyv4030.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4033) - } // end switch yys4033 - } // end for yyj4033 + z.DecStructFieldNotFound(-1, yys4024) + } // end switch yys4024 + } // end for yyj4024 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -50518,16 +50436,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4040 int - var yyb4040 bool - var yyhl4040 bool = l >= 0 - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + var yyj4031 int + var yyb4031 bool + var yyhl4031 bool = l >= 0 + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50537,13 +50455,13 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = LimitType(r.DecodeString()) } - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50551,16 +50469,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Max = nil } else { - yyv4042 := &x.Max - yyv4042.CodecDecodeSelf(d) + yyv4033 := &x.Max + yyv4033.CodecDecodeSelf(d) } - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50568,16 +50486,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Min = nil } else { - yyv4043 := &x.Min - yyv4043.CodecDecodeSelf(d) + yyv4034 := &x.Min + yyv4034.CodecDecodeSelf(d) } - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50585,16 +50503,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Default = nil } else { - yyv4044 := &x.Default - yyv4044.CodecDecodeSelf(d) + yyv4035 := &x.Default + yyv4035.CodecDecodeSelf(d) } - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50602,16 +50520,16 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.DefaultRequest = nil } else { - yyv4045 := &x.DefaultRequest - yyv4045.CodecDecodeSelf(d) + yyv4036 := &x.DefaultRequest + yyv4036.CodecDecodeSelf(d) } - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50619,21 +50537,21 @@ func (x *LimitRangeItem) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.MaxLimitRequestRatio = nil } else { - yyv4046 := &x.MaxLimitRequestRatio - yyv4046.CodecDecodeSelf(d) + yyv4037 := &x.MaxLimitRequestRatio + yyv4037.CodecDecodeSelf(d) } for { - yyj4040++ - if yyhl4040 { - yyb4040 = yyj4040 > l + yyj4031++ + if yyhl4031 { + yyb4031 = yyj4031 > l } else { - yyb4040 = r.CheckBreak() + yyb4031 = r.CheckBreak() } - if yyb4040 { + if yyb4031 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4040-1, "") + z.DecStructFieldNotFound(yyj4031-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50645,36 +50563,36 @@ func (x *LimitRangeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4047 := z.EncBinary() - _ = yym4047 + yym4038 := z.EncBinary() + _ = yym4038 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4048 := !z.EncBinary() - yy2arr4048 := z.EncBasicHandle().StructToArray - var yyq4048 [1]bool - _, _, _ = yysep4048, yyq4048, yy2arr4048 - const yyr4048 bool = false - var yynn4048 int - if yyr4048 || yy2arr4048 { + yysep4039 := !z.EncBinary() + yy2arr4039 := z.EncBasicHandle().StructToArray + var yyq4039 [1]bool + _, _, _ = yysep4039, yyq4039, yy2arr4039 + const yyr4039 bool = false + var yynn4039 int + if yyr4039 || yy2arr4039 { r.EncodeArrayStart(1) } else { - yynn4048 = 1 - for _, b := range yyq4048 { + yynn4039 = 1 + for _, b := range yyq4039 { if b { - yynn4048++ + yynn4039++ } } - r.EncodeMapStart(yynn4048) - yynn4048 = 0 + r.EncodeMapStart(yynn4039) + yynn4039 = 0 } - if yyr4048 || yy2arr4048 { + if yyr4039 || yy2arr4039 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Limits == nil { r.EncodeNil() } else { - yym4050 := z.EncBinary() - _ = yym4050 + yym4041 := z.EncBinary() + _ = yym4041 if false { } else { h.encSliceLimitRangeItem(([]LimitRangeItem)(x.Limits), e) @@ -50687,15 +50605,15 @@ func (x *LimitRangeSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Limits == nil { r.EncodeNil() } else { - yym4051 := z.EncBinary() - _ = yym4051 + yym4042 := z.EncBinary() + _ = yym4042 if false { } else { h.encSliceLimitRangeItem(([]LimitRangeItem)(x.Limits), e) } } } - if yyr4048 || yy2arr4048 { + if yyr4039 || yy2arr4039 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50708,25 +50626,25 @@ func (x *LimitRangeSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4052 := z.DecBinary() - _ = yym4052 + yym4043 := z.DecBinary() + _ = yym4043 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4053 := r.ContainerType() - if yyct4053 == codecSelferValueTypeMap1234 { - yyl4053 := r.ReadMapStart() - if yyl4053 == 0 { + yyct4044 := r.ContainerType() + if yyct4044 == codecSelferValueTypeMap1234 { + yyl4044 := r.ReadMapStart() + if yyl4044 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4053, d) + x.codecDecodeSelfFromMap(yyl4044, d) } - } else if yyct4053 == codecSelferValueTypeArray1234 { - yyl4053 := r.ReadArrayStart() - if yyl4053 == 0 { + } else if yyct4044 == codecSelferValueTypeArray1234 { + yyl4044 := r.ReadArrayStart() + if yyl4044 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4053, d) + x.codecDecodeSelfFromArray(yyl4044, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50738,12 +50656,12 @@ func (x *LimitRangeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4054Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4054Slc - var yyhl4054 bool = l >= 0 - for yyj4054 := 0; ; yyj4054++ { - if yyhl4054 { - if yyj4054 >= l { + var yys4045Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4045Slc + var yyhl4045 bool = l >= 0 + for yyj4045 := 0; ; yyj4045++ { + if yyhl4045 { + if yyj4045 >= l { break } } else { @@ -50752,26 +50670,26 @@ func (x *LimitRangeSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4054Slc = r.DecodeBytes(yys4054Slc, true, true) - yys4054 := string(yys4054Slc) + yys4045Slc = r.DecodeBytes(yys4045Slc, true, true) + yys4045 := string(yys4045Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4054 { + switch yys4045 { case "limits": if r.TryDecodeAsNil() { x.Limits = nil } else { - yyv4055 := &x.Limits - yym4056 := z.DecBinary() - _ = yym4056 + yyv4046 := &x.Limits + yym4047 := z.DecBinary() + _ = yym4047 if false { } else { - h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4055), d) + h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4046), d) } } default: - z.DecStructFieldNotFound(-1, yys4054) - } // end switch yys4054 - } // end for yyj4054 + z.DecStructFieldNotFound(-1, yys4045) + } // end switch yys4045 + } // end for yyj4045 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -50779,16 +50697,16 @@ func (x *LimitRangeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4057 int - var yyb4057 bool - var yyhl4057 bool = l >= 0 - yyj4057++ - if yyhl4057 { - yyb4057 = yyj4057 > l + var yyj4048 int + var yyb4048 bool + var yyhl4048 bool = l >= 0 + yyj4048++ + if yyhl4048 { + yyb4048 = yyj4048 > l } else { - yyb4057 = r.CheckBreak() + yyb4048 = r.CheckBreak() } - if yyb4057 { + if yyb4048 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -50796,26 +50714,26 @@ func (x *LimitRangeSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Limits = nil } else { - yyv4058 := &x.Limits - yym4059 := z.DecBinary() - _ = yym4059 + yyv4049 := &x.Limits + yym4050 := z.DecBinary() + _ = yym4050 if false { } else { - h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4058), d) + h.decSliceLimitRangeItem((*[]LimitRangeItem)(yyv4049), d) } } for { - yyj4057++ - if yyhl4057 { - yyb4057 = yyj4057 > l + yyj4048++ + if yyhl4048 { + yyb4048 = yyj4048 > l } else { - yyb4057 = r.CheckBreak() + yyb4048 = r.CheckBreak() } - if yyb4057 { + if yyb4048 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4057-1, "") + z.DecStructFieldNotFound(yyj4048-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -50827,38 +50745,38 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4060 := z.EncBinary() - _ = yym4060 + yym4051 := z.EncBinary() + _ = yym4051 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4061 := !z.EncBinary() - yy2arr4061 := z.EncBasicHandle().StructToArray - var yyq4061 [4]bool - _, _, _ = yysep4061, yyq4061, yy2arr4061 - const yyr4061 bool = false - yyq4061[0] = x.Kind != "" - yyq4061[1] = x.APIVersion != "" - yyq4061[2] = true - yyq4061[3] = true - var yynn4061 int - if yyr4061 || yy2arr4061 { + yysep4052 := !z.EncBinary() + yy2arr4052 := z.EncBasicHandle().StructToArray + var yyq4052 [4]bool + _, _, _ = yysep4052, yyq4052, yy2arr4052 + const yyr4052 bool = false + yyq4052[0] = x.Kind != "" + yyq4052[1] = x.APIVersion != "" + yyq4052[2] = true + yyq4052[3] = true + var yynn4052 int + if yyr4052 || yy2arr4052 { r.EncodeArrayStart(4) } else { - yynn4061 = 0 - for _, b := range yyq4061 { + yynn4052 = 0 + for _, b := range yyq4052 { if b { - yynn4061++ + yynn4052++ } } - r.EncodeMapStart(yynn4061) - yynn4061 = 0 + r.EncodeMapStart(yynn4052) + yynn4052 = 0 } - if yyr4061 || yy2arr4061 { + if yyr4052 || yy2arr4052 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4061[0] { - yym4063 := z.EncBinary() - _ = yym4063 + if yyq4052[0] { + yym4054 := z.EncBinary() + _ = yym4054 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -50867,23 +50785,23 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4061[0] { + if yyq4052[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4064 := z.EncBinary() - _ = yym4064 + yym4055 := z.EncBinary() + _ = yym4055 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4061 || yy2arr4061 { + if yyr4052 || yy2arr4052 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4061[1] { - yym4066 := z.EncBinary() - _ = yym4066 + if yyq4052[1] { + yym4057 := z.EncBinary() + _ = yym4057 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -50892,53 +50810,53 @@ func (x *LimitRange) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4061[1] { + if yyq4052[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4067 := z.EncBinary() - _ = yym4067 + yym4058 := z.EncBinary() + _ = yym4058 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4061 || yy2arr4061 { + if yyr4052 || yy2arr4052 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4061[2] { - yy4069 := &x.ObjectMeta - yy4069.CodecEncodeSelf(e) + if yyq4052[2] { + yy4060 := &x.ObjectMeta + yy4060.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4061[2] { + if yyq4052[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4070 := &x.ObjectMeta - yy4070.CodecEncodeSelf(e) + yy4061 := &x.ObjectMeta + yy4061.CodecEncodeSelf(e) } } - if yyr4061 || yy2arr4061 { + if yyr4052 || yy2arr4052 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4061[3] { - yy4072 := &x.Spec - yy4072.CodecEncodeSelf(e) + if yyq4052[3] { + yy4063 := &x.Spec + yy4063.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4061[3] { + if yyq4052[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4073 := &x.Spec - yy4073.CodecEncodeSelf(e) + yy4064 := &x.Spec + yy4064.CodecEncodeSelf(e) } } - if yyr4061 || yy2arr4061 { + if yyr4052 || yy2arr4052 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -50951,25 +50869,25 @@ func (x *LimitRange) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4074 := z.DecBinary() - _ = yym4074 + yym4065 := z.DecBinary() + _ = yym4065 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4075 := r.ContainerType() - if yyct4075 == codecSelferValueTypeMap1234 { - yyl4075 := r.ReadMapStart() - if yyl4075 == 0 { + yyct4066 := r.ContainerType() + if yyct4066 == codecSelferValueTypeMap1234 { + yyl4066 := r.ReadMapStart() + if yyl4066 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4075, d) + x.codecDecodeSelfFromMap(yyl4066, d) } - } else if yyct4075 == codecSelferValueTypeArray1234 { - yyl4075 := r.ReadArrayStart() - if yyl4075 == 0 { + } else if yyct4066 == codecSelferValueTypeArray1234 { + yyl4066 := r.ReadArrayStart() + if yyl4066 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4075, d) + x.codecDecodeSelfFromArray(yyl4066, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -50981,12 +50899,12 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4076Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4076Slc - var yyhl4076 bool = l >= 0 - for yyj4076 := 0; ; yyj4076++ { - if yyhl4076 { - if yyj4076 >= l { + var yys4067Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4067Slc + var yyhl4067 bool = l >= 0 + for yyj4067 := 0; ; yyj4067++ { + if yyhl4067 { + if yyj4067 >= l { break } } else { @@ -50995,10 +50913,10 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4076Slc = r.DecodeBytes(yys4076Slc, true, true) - yys4076 := string(yys4076Slc) + yys4067Slc = r.DecodeBytes(yys4067Slc, true, true) + yys4067 := string(yys4067Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4076 { + switch yys4067 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -51015,20 +50933,20 @@ func (x *LimitRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4079 := &x.ObjectMeta - yyv4079.CodecDecodeSelf(d) + yyv4070 := &x.ObjectMeta + yyv4070.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = LimitRangeSpec{} } else { - yyv4080 := &x.Spec - yyv4080.CodecDecodeSelf(d) + yyv4071 := &x.Spec + yyv4071.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4076) - } // end switch yys4076 - } // end for yyj4076 + z.DecStructFieldNotFound(-1, yys4067) + } // end switch yys4067 + } // end for yyj4067 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51036,16 +50954,16 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4081 int - var yyb4081 bool - var yyhl4081 bool = l >= 0 - yyj4081++ - if yyhl4081 { - yyb4081 = yyj4081 > l + var yyj4072 int + var yyb4072 bool + var yyhl4072 bool = l >= 0 + yyj4072++ + if yyhl4072 { + yyb4072 = yyj4072 > l } else { - yyb4081 = r.CheckBreak() + yyb4072 = r.CheckBreak() } - if yyb4081 { + if yyb4072 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51055,13 +50973,13 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4081++ - if yyhl4081 { - yyb4081 = yyj4081 > l + yyj4072++ + if yyhl4072 { + yyb4072 = yyj4072 > l } else { - yyb4081 = r.CheckBreak() + yyb4072 = r.CheckBreak() } - if yyb4081 { + if yyb4072 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51071,13 +50989,13 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4081++ - if yyhl4081 { - yyb4081 = yyj4081 > l + yyj4072++ + if yyhl4072 { + yyb4072 = yyj4072 > l } else { - yyb4081 = r.CheckBreak() + yyb4072 = r.CheckBreak() } - if yyb4081 { + if yyb4072 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51085,16 +51003,16 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4084 := &x.ObjectMeta - yyv4084.CodecDecodeSelf(d) + yyv4075 := &x.ObjectMeta + yyv4075.CodecDecodeSelf(d) } - yyj4081++ - if yyhl4081 { - yyb4081 = yyj4081 > l + yyj4072++ + if yyhl4072 { + yyb4072 = yyj4072 > l } else { - yyb4081 = r.CheckBreak() + yyb4072 = r.CheckBreak() } - if yyb4081 { + if yyb4072 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51102,21 +51020,21 @@ func (x *LimitRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = LimitRangeSpec{} } else { - yyv4085 := &x.Spec - yyv4085.CodecDecodeSelf(d) + yyv4076 := &x.Spec + yyv4076.CodecDecodeSelf(d) } for { - yyj4081++ - if yyhl4081 { - yyb4081 = yyj4081 > l + yyj4072++ + if yyhl4072 { + yyb4072 = yyj4072 > l } else { - yyb4081 = r.CheckBreak() + yyb4072 = r.CheckBreak() } - if yyb4081 { + if yyb4072 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4081-1, "") + z.DecStructFieldNotFound(yyj4072-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51128,37 +51046,37 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4086 := z.EncBinary() - _ = yym4086 + yym4077 := z.EncBinary() + _ = yym4077 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4087 := !z.EncBinary() - yy2arr4087 := z.EncBasicHandle().StructToArray - var yyq4087 [4]bool - _, _, _ = yysep4087, yyq4087, yy2arr4087 - const yyr4087 bool = false - yyq4087[0] = x.Kind != "" - yyq4087[1] = x.APIVersion != "" - yyq4087[2] = true - var yynn4087 int - if yyr4087 || yy2arr4087 { + yysep4078 := !z.EncBinary() + yy2arr4078 := z.EncBasicHandle().StructToArray + var yyq4078 [4]bool + _, _, _ = yysep4078, yyq4078, yy2arr4078 + const yyr4078 bool = false + yyq4078[0] = x.Kind != "" + yyq4078[1] = x.APIVersion != "" + yyq4078[2] = true + var yynn4078 int + if yyr4078 || yy2arr4078 { r.EncodeArrayStart(4) } else { - yynn4087 = 1 - for _, b := range yyq4087 { + yynn4078 = 1 + for _, b := range yyq4078 { if b { - yynn4087++ + yynn4078++ } } - r.EncodeMapStart(yynn4087) - yynn4087 = 0 + r.EncodeMapStart(yynn4078) + yynn4078 = 0 } - if yyr4087 || yy2arr4087 { + if yyr4078 || yy2arr4078 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4087[0] { - yym4089 := z.EncBinary() - _ = yym4089 + if yyq4078[0] { + yym4080 := z.EncBinary() + _ = yym4080 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -51167,23 +51085,23 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4087[0] { + if yyq4078[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4090 := z.EncBinary() - _ = yym4090 + yym4081 := z.EncBinary() + _ = yym4081 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4087 || yy2arr4087 { + if yyr4078 || yy2arr4078 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4087[1] { - yym4092 := z.EncBinary() - _ = yym4092 + if yyq4078[1] { + yym4083 := z.EncBinary() + _ = yym4083 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -51192,54 +51110,54 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4087[1] { + if yyq4078[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4093 := z.EncBinary() - _ = yym4093 + yym4084 := z.EncBinary() + _ = yym4084 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4087 || yy2arr4087 { + if yyr4078 || yy2arr4078 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4087[2] { - yy4095 := &x.ListMeta - yym4096 := z.EncBinary() - _ = yym4096 + if yyq4078[2] { + yy4086 := &x.ListMeta + yym4087 := z.EncBinary() + _ = yym4087 if false { - } else if z.HasExtensions() && z.EncExt(yy4095) { + } else if z.HasExtensions() && z.EncExt(yy4086) { } else { - z.EncFallback(yy4095) + z.EncFallback(yy4086) } } else { r.EncodeNil() } } else { - if yyq4087[2] { + if yyq4078[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4097 := &x.ListMeta - yym4098 := z.EncBinary() - _ = yym4098 + yy4088 := &x.ListMeta + yym4089 := z.EncBinary() + _ = yym4089 if false { - } else if z.HasExtensions() && z.EncExt(yy4097) { + } else if z.HasExtensions() && z.EncExt(yy4088) { } else { - z.EncFallback(yy4097) + z.EncFallback(yy4088) } } } - if yyr4087 || yy2arr4087 { + if yyr4078 || yy2arr4078 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4100 := z.EncBinary() - _ = yym4100 + yym4091 := z.EncBinary() + _ = yym4091 if false { } else { h.encSliceLimitRange(([]LimitRange)(x.Items), e) @@ -51252,15 +51170,15 @@ func (x *LimitRangeList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4101 := z.EncBinary() - _ = yym4101 + yym4092 := z.EncBinary() + _ = yym4092 if false { } else { h.encSliceLimitRange(([]LimitRange)(x.Items), e) } } } - if yyr4087 || yy2arr4087 { + if yyr4078 || yy2arr4078 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51273,25 +51191,25 @@ func (x *LimitRangeList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4102 := z.DecBinary() - _ = yym4102 + yym4093 := z.DecBinary() + _ = yym4093 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4103 := r.ContainerType() - if yyct4103 == codecSelferValueTypeMap1234 { - yyl4103 := r.ReadMapStart() - if yyl4103 == 0 { + yyct4094 := r.ContainerType() + if yyct4094 == codecSelferValueTypeMap1234 { + yyl4094 := r.ReadMapStart() + if yyl4094 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4103, d) + x.codecDecodeSelfFromMap(yyl4094, d) } - } else if yyct4103 == codecSelferValueTypeArray1234 { - yyl4103 := r.ReadArrayStart() - if yyl4103 == 0 { + } else if yyct4094 == codecSelferValueTypeArray1234 { + yyl4094 := r.ReadArrayStart() + if yyl4094 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4103, d) + x.codecDecodeSelfFromArray(yyl4094, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51303,12 +51221,12 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4104Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4104Slc - var yyhl4104 bool = l >= 0 - for yyj4104 := 0; ; yyj4104++ { - if yyhl4104 { - if yyj4104 >= l { + var yys4095Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4095Slc + var yyhl4095 bool = l >= 0 + for yyj4095 := 0; ; yyj4095++ { + if yyhl4095 { + if yyj4095 >= l { break } } else { @@ -51317,10 +51235,10 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4104Slc = r.DecodeBytes(yys4104Slc, true, true) - yys4104 := string(yys4104Slc) + yys4095Slc = r.DecodeBytes(yys4095Slc, true, true) + yys4095 := string(yys4095Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4104 { + switch yys4095 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -51337,31 +51255,31 @@ func (x *LimitRangeList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4107 := &x.ListMeta - yym4108 := z.DecBinary() - _ = yym4108 + yyv4098 := &x.ListMeta + yym4099 := z.DecBinary() + _ = yym4099 if false { - } else if z.HasExtensions() && z.DecExt(yyv4107) { + } else if z.HasExtensions() && z.DecExt(yyv4098) { } else { - z.DecFallback(yyv4107, false) + z.DecFallback(yyv4098, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4109 := &x.Items - yym4110 := z.DecBinary() - _ = yym4110 + yyv4100 := &x.Items + yym4101 := z.DecBinary() + _ = yym4101 if false { } else { - h.decSliceLimitRange((*[]LimitRange)(yyv4109), d) + h.decSliceLimitRange((*[]LimitRange)(yyv4100), d) } } default: - z.DecStructFieldNotFound(-1, yys4104) - } // end switch yys4104 - } // end for yyj4104 + z.DecStructFieldNotFound(-1, yys4095) + } // end switch yys4095 + } // end for yyj4095 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51369,16 +51287,16 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4111 int - var yyb4111 bool - var yyhl4111 bool = l >= 0 - yyj4111++ - if yyhl4111 { - yyb4111 = yyj4111 > l + var yyj4102 int + var yyb4102 bool + var yyhl4102 bool = l >= 0 + yyj4102++ + if yyhl4102 { + yyb4102 = yyj4102 > l } else { - yyb4111 = r.CheckBreak() + yyb4102 = r.CheckBreak() } - if yyb4111 { + if yyb4102 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51388,13 +51306,13 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4111++ - if yyhl4111 { - yyb4111 = yyj4111 > l + yyj4102++ + if yyhl4102 { + yyb4102 = yyj4102 > l } else { - yyb4111 = r.CheckBreak() + yyb4102 = r.CheckBreak() } - if yyb4111 { + if yyb4102 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51404,13 +51322,13 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4111++ - if yyhl4111 { - yyb4111 = yyj4111 > l + yyj4102++ + if yyhl4102 { + yyb4102 = yyj4102 > l } else { - yyb4111 = r.CheckBreak() + yyb4102 = r.CheckBreak() } - if yyb4111 { + if yyb4102 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51418,22 +51336,22 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4114 := &x.ListMeta - yym4115 := z.DecBinary() - _ = yym4115 + yyv4105 := &x.ListMeta + yym4106 := z.DecBinary() + _ = yym4106 if false { - } else if z.HasExtensions() && z.DecExt(yyv4114) { + } else if z.HasExtensions() && z.DecExt(yyv4105) { } else { - z.DecFallback(yyv4114, false) + z.DecFallback(yyv4105, false) } } - yyj4111++ - if yyhl4111 { - yyb4111 = yyj4111 > l + yyj4102++ + if yyhl4102 { + yyb4102 = yyj4102 > l } else { - yyb4111 = r.CheckBreak() + yyb4102 = r.CheckBreak() } - if yyb4111 { + if yyb4102 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51441,26 +51359,26 @@ func (x *LimitRangeList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4116 := &x.Items - yym4117 := z.DecBinary() - _ = yym4117 + yyv4107 := &x.Items + yym4108 := z.DecBinary() + _ = yym4108 if false { } else { - h.decSliceLimitRange((*[]LimitRange)(yyv4116), d) + h.decSliceLimitRange((*[]LimitRange)(yyv4107), d) } } for { - yyj4111++ - if yyhl4111 { - yyb4111 = yyj4111 > l + yyj4102++ + if yyhl4102 { + yyb4102 = yyj4102 > l } else { - yyb4111 = r.CheckBreak() + yyb4102 = r.CheckBreak() } - if yyb4111 { + if yyb4102 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4111-1, "") + z.DecStructFieldNotFound(yyj4102-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51469,8 +51387,8 @@ func (x ResourceQuotaScope) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4118 := z.EncBinary() - _ = yym4118 + yym4109 := z.EncBinary() + _ = yym4109 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -51482,8 +51400,8 @@ func (x *ResourceQuotaScope) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4119 := z.DecBinary() - _ = yym4119 + yym4110 := z.DecBinary() + _ = yym4110 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -51498,34 +51416,34 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4120 := z.EncBinary() - _ = yym4120 + yym4111 := z.EncBinary() + _ = yym4111 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4121 := !z.EncBinary() - yy2arr4121 := z.EncBasicHandle().StructToArray - var yyq4121 [2]bool - _, _, _ = yysep4121, yyq4121, yy2arr4121 - const yyr4121 bool = false - yyq4121[0] = len(x.Hard) != 0 - yyq4121[1] = len(x.Scopes) != 0 - var yynn4121 int - if yyr4121 || yy2arr4121 { + yysep4112 := !z.EncBinary() + yy2arr4112 := z.EncBasicHandle().StructToArray + var yyq4112 [2]bool + _, _, _ = yysep4112, yyq4112, yy2arr4112 + const yyr4112 bool = false + yyq4112[0] = len(x.Hard) != 0 + yyq4112[1] = len(x.Scopes) != 0 + var yynn4112 int + if yyr4112 || yy2arr4112 { r.EncodeArrayStart(2) } else { - yynn4121 = 0 - for _, b := range yyq4121 { + yynn4112 = 0 + for _, b := range yyq4112 { if b { - yynn4121++ + yynn4112++ } } - r.EncodeMapStart(yynn4121) - yynn4121 = 0 + r.EncodeMapStart(yynn4112) + yynn4112 = 0 } - if yyr4121 || yy2arr4121 { + if yyr4112 || yy2arr4112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4121[0] { + if yyq4112[0] { if x.Hard == nil { r.EncodeNil() } else { @@ -51535,7 +51453,7 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4121[0] { + if yyq4112[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hard")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -51546,14 +51464,14 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4121 || yy2arr4121 { + if yyr4112 || yy2arr4112 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4121[1] { + if yyq4112[1] { if x.Scopes == nil { r.EncodeNil() } else { - yym4124 := z.EncBinary() - _ = yym4124 + yym4115 := z.EncBinary() + _ = yym4115 if false { } else { h.encSliceResourceQuotaScope(([]ResourceQuotaScope)(x.Scopes), e) @@ -51563,15 +51481,15 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4121[1] { + if yyq4112[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("scopes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Scopes == nil { r.EncodeNil() } else { - yym4125 := z.EncBinary() - _ = yym4125 + yym4116 := z.EncBinary() + _ = yym4116 if false { } else { h.encSliceResourceQuotaScope(([]ResourceQuotaScope)(x.Scopes), e) @@ -51579,7 +51497,7 @@ func (x *ResourceQuotaSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4121 || yy2arr4121 { + if yyr4112 || yy2arr4112 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51592,25 +51510,25 @@ func (x *ResourceQuotaSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4126 := z.DecBinary() - _ = yym4126 + yym4117 := z.DecBinary() + _ = yym4117 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4127 := r.ContainerType() - if yyct4127 == codecSelferValueTypeMap1234 { - yyl4127 := r.ReadMapStart() - if yyl4127 == 0 { + yyct4118 := r.ContainerType() + if yyct4118 == codecSelferValueTypeMap1234 { + yyl4118 := r.ReadMapStart() + if yyl4118 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4127, d) + x.codecDecodeSelfFromMap(yyl4118, d) } - } else if yyct4127 == codecSelferValueTypeArray1234 { - yyl4127 := r.ReadArrayStart() - if yyl4127 == 0 { + } else if yyct4118 == codecSelferValueTypeArray1234 { + yyl4118 := r.ReadArrayStart() + if yyl4118 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4127, d) + x.codecDecodeSelfFromArray(yyl4118, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51622,12 +51540,12 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4128Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4128Slc - var yyhl4128 bool = l >= 0 - for yyj4128 := 0; ; yyj4128++ { - if yyhl4128 { - if yyj4128 >= l { + var yys4119Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4119Slc + var yyhl4119 bool = l >= 0 + for yyj4119 := 0; ; yyj4119++ { + if yyhl4119 { + if yyj4119 >= l { break } } else { @@ -51636,33 +51554,33 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4128Slc = r.DecodeBytes(yys4128Slc, true, true) - yys4128 := string(yys4128Slc) + yys4119Slc = r.DecodeBytes(yys4119Slc, true, true) + yys4119 := string(yys4119Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4128 { + switch yys4119 { case "hard": if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4129 := &x.Hard - yyv4129.CodecDecodeSelf(d) + yyv4120 := &x.Hard + yyv4120.CodecDecodeSelf(d) } case "scopes": if r.TryDecodeAsNil() { x.Scopes = nil } else { - yyv4130 := &x.Scopes - yym4131 := z.DecBinary() - _ = yym4131 + yyv4121 := &x.Scopes + yym4122 := z.DecBinary() + _ = yym4122 if false { } else { - h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4130), d) + h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4121), d) } } default: - z.DecStructFieldNotFound(-1, yys4128) - } // end switch yys4128 - } // end for yyj4128 + z.DecStructFieldNotFound(-1, yys4119) + } // end switch yys4119 + } // end for yyj4119 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51670,16 +51588,16 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4132 int - var yyb4132 bool - var yyhl4132 bool = l >= 0 - yyj4132++ - if yyhl4132 { - yyb4132 = yyj4132 > l + var yyj4123 int + var yyb4123 bool + var yyhl4123 bool = l >= 0 + yyj4123++ + if yyhl4123 { + yyb4123 = yyj4123 > l } else { - yyb4132 = r.CheckBreak() + yyb4123 = r.CheckBreak() } - if yyb4132 { + if yyb4123 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51687,16 +51605,16 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4133 := &x.Hard - yyv4133.CodecDecodeSelf(d) + yyv4124 := &x.Hard + yyv4124.CodecDecodeSelf(d) } - yyj4132++ - if yyhl4132 { - yyb4132 = yyj4132 > l + yyj4123++ + if yyhl4123 { + yyb4123 = yyj4123 > l } else { - yyb4132 = r.CheckBreak() + yyb4123 = r.CheckBreak() } - if yyb4132 { + if yyb4123 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51704,26 +51622,26 @@ func (x *ResourceQuotaSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Scopes = nil } else { - yyv4134 := &x.Scopes - yym4135 := z.DecBinary() - _ = yym4135 + yyv4125 := &x.Scopes + yym4126 := z.DecBinary() + _ = yym4126 if false { } else { - h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4134), d) + h.decSliceResourceQuotaScope((*[]ResourceQuotaScope)(yyv4125), d) } } for { - yyj4132++ - if yyhl4132 { - yyb4132 = yyj4132 > l + yyj4123++ + if yyhl4123 { + yyb4123 = yyj4123 > l } else { - yyb4132 = r.CheckBreak() + yyb4123 = r.CheckBreak() } - if yyb4132 { + if yyb4123 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4132-1, "") + z.DecStructFieldNotFound(yyj4123-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51735,34 +51653,34 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4136 := z.EncBinary() - _ = yym4136 + yym4127 := z.EncBinary() + _ = yym4127 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4137 := !z.EncBinary() - yy2arr4137 := z.EncBasicHandle().StructToArray - var yyq4137 [2]bool - _, _, _ = yysep4137, yyq4137, yy2arr4137 - const yyr4137 bool = false - yyq4137[0] = len(x.Hard) != 0 - yyq4137[1] = len(x.Used) != 0 - var yynn4137 int - if yyr4137 || yy2arr4137 { + yysep4128 := !z.EncBinary() + yy2arr4128 := z.EncBasicHandle().StructToArray + var yyq4128 [2]bool + _, _, _ = yysep4128, yyq4128, yy2arr4128 + const yyr4128 bool = false + yyq4128[0] = len(x.Hard) != 0 + yyq4128[1] = len(x.Used) != 0 + var yynn4128 int + if yyr4128 || yy2arr4128 { r.EncodeArrayStart(2) } else { - yynn4137 = 0 - for _, b := range yyq4137 { + yynn4128 = 0 + for _, b := range yyq4128 { if b { - yynn4137++ + yynn4128++ } } - r.EncodeMapStart(yynn4137) - yynn4137 = 0 + r.EncodeMapStart(yynn4128) + yynn4128 = 0 } - if yyr4137 || yy2arr4137 { + if yyr4128 || yy2arr4128 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4137[0] { + if yyq4128[0] { if x.Hard == nil { r.EncodeNil() } else { @@ -51772,7 +51690,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4137[0] { + if yyq4128[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hard")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -51783,9 +51701,9 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4137 || yy2arr4137 { + if yyr4128 || yy2arr4128 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4137[1] { + if yyq4128[1] { if x.Used == nil { r.EncodeNil() } else { @@ -51795,7 +51713,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4137[1] { + if yyq4128[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("used")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -51806,7 +51724,7 @@ func (x *ResourceQuotaStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4137 || yy2arr4137 { + if yyr4128 || yy2arr4128 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -51819,25 +51737,25 @@ func (x *ResourceQuotaStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4140 := z.DecBinary() - _ = yym4140 + yym4131 := z.DecBinary() + _ = yym4131 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4141 := r.ContainerType() - if yyct4141 == codecSelferValueTypeMap1234 { - yyl4141 := r.ReadMapStart() - if yyl4141 == 0 { + yyct4132 := r.ContainerType() + if yyct4132 == codecSelferValueTypeMap1234 { + yyl4132 := r.ReadMapStart() + if yyl4132 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4141, d) + x.codecDecodeSelfFromMap(yyl4132, d) } - } else if yyct4141 == codecSelferValueTypeArray1234 { - yyl4141 := r.ReadArrayStart() - if yyl4141 == 0 { + } else if yyct4132 == codecSelferValueTypeArray1234 { + yyl4132 := r.ReadArrayStart() + if yyl4132 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4141, d) + x.codecDecodeSelfFromArray(yyl4132, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -51849,12 +51767,12 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4142Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4142Slc - var yyhl4142 bool = l >= 0 - for yyj4142 := 0; ; yyj4142++ { - if yyhl4142 { - if yyj4142 >= l { + var yys4133Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4133Slc + var yyhl4133 bool = l >= 0 + for yyj4133 := 0; ; yyj4133++ { + if yyhl4133 { + if yyj4133 >= l { break } } else { @@ -51863,28 +51781,28 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4142Slc = r.DecodeBytes(yys4142Slc, true, true) - yys4142 := string(yys4142Slc) + yys4133Slc = r.DecodeBytes(yys4133Slc, true, true) + yys4133 := string(yys4133Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4142 { + switch yys4133 { case "hard": if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4143 := &x.Hard - yyv4143.CodecDecodeSelf(d) + yyv4134 := &x.Hard + yyv4134.CodecDecodeSelf(d) } case "used": if r.TryDecodeAsNil() { x.Used = nil } else { - yyv4144 := &x.Used - yyv4144.CodecDecodeSelf(d) + yyv4135 := &x.Used + yyv4135.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4142) - } // end switch yys4142 - } // end for yyj4142 + z.DecStructFieldNotFound(-1, yys4133) + } // end switch yys4133 + } // end for yyj4133 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -51892,16 +51810,16 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4145 int - var yyb4145 bool - var yyhl4145 bool = l >= 0 - yyj4145++ - if yyhl4145 { - yyb4145 = yyj4145 > l + var yyj4136 int + var yyb4136 bool + var yyhl4136 bool = l >= 0 + yyj4136++ + if yyhl4136 { + yyb4136 = yyj4136 > l } else { - yyb4145 = r.CheckBreak() + yyb4136 = r.CheckBreak() } - if yyb4145 { + if yyb4136 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51909,16 +51827,16 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Hard = nil } else { - yyv4146 := &x.Hard - yyv4146.CodecDecodeSelf(d) + yyv4137 := &x.Hard + yyv4137.CodecDecodeSelf(d) } - yyj4145++ - if yyhl4145 { - yyb4145 = yyj4145 > l + yyj4136++ + if yyhl4136 { + yyb4136 = yyj4136 > l } else { - yyb4145 = r.CheckBreak() + yyb4136 = r.CheckBreak() } - if yyb4145 { + if yyb4136 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -51926,21 +51844,21 @@ func (x *ResourceQuotaStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Used = nil } else { - yyv4147 := &x.Used - yyv4147.CodecDecodeSelf(d) + yyv4138 := &x.Used + yyv4138.CodecDecodeSelf(d) } for { - yyj4145++ - if yyhl4145 { - yyb4145 = yyj4145 > l + yyj4136++ + if yyhl4136 { + yyb4136 = yyj4136 > l } else { - yyb4145 = r.CheckBreak() + yyb4136 = r.CheckBreak() } - if yyb4145 { + if yyb4136 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4145-1, "") + z.DecStructFieldNotFound(yyj4136-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -51952,39 +51870,39 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4148 := z.EncBinary() - _ = yym4148 + yym4139 := z.EncBinary() + _ = yym4139 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4149 := !z.EncBinary() - yy2arr4149 := z.EncBasicHandle().StructToArray - var yyq4149 [5]bool - _, _, _ = yysep4149, yyq4149, yy2arr4149 - const yyr4149 bool = false - yyq4149[0] = x.Kind != "" - yyq4149[1] = x.APIVersion != "" - yyq4149[2] = true - yyq4149[3] = true - yyq4149[4] = true - var yynn4149 int - if yyr4149 || yy2arr4149 { + yysep4140 := !z.EncBinary() + yy2arr4140 := z.EncBasicHandle().StructToArray + var yyq4140 [5]bool + _, _, _ = yysep4140, yyq4140, yy2arr4140 + const yyr4140 bool = false + yyq4140[0] = x.Kind != "" + yyq4140[1] = x.APIVersion != "" + yyq4140[2] = true + yyq4140[3] = true + yyq4140[4] = true + var yynn4140 int + if yyr4140 || yy2arr4140 { r.EncodeArrayStart(5) } else { - yynn4149 = 0 - for _, b := range yyq4149 { + yynn4140 = 0 + for _, b := range yyq4140 { if b { - yynn4149++ + yynn4140++ } } - r.EncodeMapStart(yynn4149) - yynn4149 = 0 + r.EncodeMapStart(yynn4140) + yynn4140 = 0 } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4149[0] { - yym4151 := z.EncBinary() - _ = yym4151 + if yyq4140[0] { + yym4142 := z.EncBinary() + _ = yym4142 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -51993,23 +51911,23 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4149[0] { + if yyq4140[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4152 := z.EncBinary() - _ = yym4152 + yym4143 := z.EncBinary() + _ = yym4143 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4149[1] { - yym4154 := z.EncBinary() - _ = yym4154 + if yyq4140[1] { + yym4145 := z.EncBinary() + _ = yym4145 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -52018,70 +51936,70 @@ func (x *ResourceQuota) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4149[1] { + if yyq4140[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4155 := z.EncBinary() - _ = yym4155 + yym4146 := z.EncBinary() + _ = yym4146 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4149[2] { - yy4157 := &x.ObjectMeta - yy4157.CodecEncodeSelf(e) + if yyq4140[2] { + yy4148 := &x.ObjectMeta + yy4148.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4149[2] { + if yyq4140[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4158 := &x.ObjectMeta - yy4158.CodecEncodeSelf(e) + yy4149 := &x.ObjectMeta + yy4149.CodecEncodeSelf(e) } } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4149[3] { - yy4160 := &x.Spec - yy4160.CodecEncodeSelf(e) + if yyq4140[3] { + yy4151 := &x.Spec + yy4151.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4149[3] { + if yyq4140[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4161 := &x.Spec - yy4161.CodecEncodeSelf(e) + yy4152 := &x.Spec + yy4152.CodecEncodeSelf(e) } } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4149[4] { - yy4163 := &x.Status - yy4163.CodecEncodeSelf(e) + if yyq4140[4] { + yy4154 := &x.Status + yy4154.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4149[4] { + if yyq4140[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4164 := &x.Status - yy4164.CodecEncodeSelf(e) + yy4155 := &x.Status + yy4155.CodecEncodeSelf(e) } } - if yyr4149 || yy2arr4149 { + if yyr4140 || yy2arr4140 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52094,25 +52012,25 @@ func (x *ResourceQuota) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4165 := z.DecBinary() - _ = yym4165 + yym4156 := z.DecBinary() + _ = yym4156 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4166 := r.ContainerType() - if yyct4166 == codecSelferValueTypeMap1234 { - yyl4166 := r.ReadMapStart() - if yyl4166 == 0 { + yyct4157 := r.ContainerType() + if yyct4157 == codecSelferValueTypeMap1234 { + yyl4157 := r.ReadMapStart() + if yyl4157 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4166, d) + x.codecDecodeSelfFromMap(yyl4157, d) } - } else if yyct4166 == codecSelferValueTypeArray1234 { - yyl4166 := r.ReadArrayStart() - if yyl4166 == 0 { + } else if yyct4157 == codecSelferValueTypeArray1234 { + yyl4157 := r.ReadArrayStart() + if yyl4157 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4166, d) + x.codecDecodeSelfFromArray(yyl4157, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52124,12 +52042,12 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4167Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4167Slc - var yyhl4167 bool = l >= 0 - for yyj4167 := 0; ; yyj4167++ { - if yyhl4167 { - if yyj4167 >= l { + var yys4158Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4158Slc + var yyhl4158 bool = l >= 0 + for yyj4158 := 0; ; yyj4158++ { + if yyhl4158 { + if yyj4158 >= l { break } } else { @@ -52138,10 +52056,10 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4167Slc = r.DecodeBytes(yys4167Slc, true, true) - yys4167 := string(yys4167Slc) + yys4158Slc = r.DecodeBytes(yys4158Slc, true, true) + yys4158 := string(yys4158Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4167 { + switch yys4158 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -52158,27 +52076,27 @@ func (x *ResourceQuota) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4170 := &x.ObjectMeta - yyv4170.CodecDecodeSelf(d) + yyv4161 := &x.ObjectMeta + yyv4161.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ResourceQuotaSpec{} } else { - yyv4171 := &x.Spec - yyv4171.CodecDecodeSelf(d) + yyv4162 := &x.Spec + yyv4162.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ResourceQuotaStatus{} } else { - yyv4172 := &x.Status - yyv4172.CodecDecodeSelf(d) + yyv4163 := &x.Status + yyv4163.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys4167) - } // end switch yys4167 - } // end for yyj4167 + z.DecStructFieldNotFound(-1, yys4158) + } // end switch yys4158 + } // end for yyj4158 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52186,16 +52104,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4173 int - var yyb4173 bool - var yyhl4173 bool = l >= 0 - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + var yyj4164 int + var yyb4164 bool + var yyhl4164 bool = l >= 0 + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52205,13 +52123,13 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52221,13 +52139,13 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52235,16 +52153,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4176 := &x.ObjectMeta - yyv4176.CodecDecodeSelf(d) + yyv4167 := &x.ObjectMeta + yyv4167.CodecDecodeSelf(d) } - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52252,16 +52170,16 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ResourceQuotaSpec{} } else { - yyv4177 := &x.Spec - yyv4177.CodecDecodeSelf(d) + yyv4168 := &x.Spec + yyv4168.CodecDecodeSelf(d) } - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52269,21 +52187,21 @@ func (x *ResourceQuota) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ResourceQuotaStatus{} } else { - yyv4178 := &x.Status - yyv4178.CodecDecodeSelf(d) + yyv4169 := &x.Status + yyv4169.CodecDecodeSelf(d) } for { - yyj4173++ - if yyhl4173 { - yyb4173 = yyj4173 > l + yyj4164++ + if yyhl4164 { + yyb4164 = yyj4164 > l } else { - yyb4173 = r.CheckBreak() + yyb4164 = r.CheckBreak() } - if yyb4173 { + if yyb4164 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4173-1, "") + z.DecStructFieldNotFound(yyj4164-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52295,37 +52213,37 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4179 := z.EncBinary() - _ = yym4179 + yym4170 := z.EncBinary() + _ = yym4170 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4180 := !z.EncBinary() - yy2arr4180 := z.EncBasicHandle().StructToArray - var yyq4180 [4]bool - _, _, _ = yysep4180, yyq4180, yy2arr4180 - const yyr4180 bool = false - yyq4180[0] = x.Kind != "" - yyq4180[1] = x.APIVersion != "" - yyq4180[2] = true - var yynn4180 int - if yyr4180 || yy2arr4180 { + yysep4171 := !z.EncBinary() + yy2arr4171 := z.EncBasicHandle().StructToArray + var yyq4171 [4]bool + _, _, _ = yysep4171, yyq4171, yy2arr4171 + const yyr4171 bool = false + yyq4171[0] = x.Kind != "" + yyq4171[1] = x.APIVersion != "" + yyq4171[2] = true + var yynn4171 int + if yyr4171 || yy2arr4171 { r.EncodeArrayStart(4) } else { - yynn4180 = 1 - for _, b := range yyq4180 { + yynn4171 = 1 + for _, b := range yyq4171 { if b { - yynn4180++ + yynn4171++ } } - r.EncodeMapStart(yynn4180) - yynn4180 = 0 + r.EncodeMapStart(yynn4171) + yynn4171 = 0 } - if yyr4180 || yy2arr4180 { + if yyr4171 || yy2arr4171 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4180[0] { - yym4182 := z.EncBinary() - _ = yym4182 + if yyq4171[0] { + yym4173 := z.EncBinary() + _ = yym4173 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -52334,23 +52252,23 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4180[0] { + if yyq4171[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4183 := z.EncBinary() - _ = yym4183 + yym4174 := z.EncBinary() + _ = yym4174 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4180 || yy2arr4180 { + if yyr4171 || yy2arr4171 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4180[1] { - yym4185 := z.EncBinary() - _ = yym4185 + if yyq4171[1] { + yym4176 := z.EncBinary() + _ = yym4176 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -52359,54 +52277,54 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4180[1] { + if yyq4171[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4186 := z.EncBinary() - _ = yym4186 + yym4177 := z.EncBinary() + _ = yym4177 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4180 || yy2arr4180 { + if yyr4171 || yy2arr4171 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4180[2] { - yy4188 := &x.ListMeta - yym4189 := z.EncBinary() - _ = yym4189 + if yyq4171[2] { + yy4179 := &x.ListMeta + yym4180 := z.EncBinary() + _ = yym4180 if false { - } else if z.HasExtensions() && z.EncExt(yy4188) { + } else if z.HasExtensions() && z.EncExt(yy4179) { } else { - z.EncFallback(yy4188) + z.EncFallback(yy4179) } } else { r.EncodeNil() } } else { - if yyq4180[2] { + if yyq4171[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4190 := &x.ListMeta - yym4191 := z.EncBinary() - _ = yym4191 + yy4181 := &x.ListMeta + yym4182 := z.EncBinary() + _ = yym4182 if false { - } else if z.HasExtensions() && z.EncExt(yy4190) { + } else if z.HasExtensions() && z.EncExt(yy4181) { } else { - z.EncFallback(yy4190) + z.EncFallback(yy4181) } } } - if yyr4180 || yy2arr4180 { + if yyr4171 || yy2arr4171 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4193 := z.EncBinary() - _ = yym4193 + yym4184 := z.EncBinary() + _ = yym4184 if false { } else { h.encSliceResourceQuota(([]ResourceQuota)(x.Items), e) @@ -52419,15 +52337,15 @@ func (x *ResourceQuotaList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4194 := z.EncBinary() - _ = yym4194 + yym4185 := z.EncBinary() + _ = yym4185 if false { } else { h.encSliceResourceQuota(([]ResourceQuota)(x.Items), e) } } } - if yyr4180 || yy2arr4180 { + if yyr4171 || yy2arr4171 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52440,25 +52358,25 @@ func (x *ResourceQuotaList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4195 := z.DecBinary() - _ = yym4195 + yym4186 := z.DecBinary() + _ = yym4186 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4196 := r.ContainerType() - if yyct4196 == codecSelferValueTypeMap1234 { - yyl4196 := r.ReadMapStart() - if yyl4196 == 0 { + yyct4187 := r.ContainerType() + if yyct4187 == codecSelferValueTypeMap1234 { + yyl4187 := r.ReadMapStart() + if yyl4187 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4196, d) + x.codecDecodeSelfFromMap(yyl4187, d) } - } else if yyct4196 == codecSelferValueTypeArray1234 { - yyl4196 := r.ReadArrayStart() - if yyl4196 == 0 { + } else if yyct4187 == codecSelferValueTypeArray1234 { + yyl4187 := r.ReadArrayStart() + if yyl4187 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4196, d) + x.codecDecodeSelfFromArray(yyl4187, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52470,12 +52388,12 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4197Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4197Slc - var yyhl4197 bool = l >= 0 - for yyj4197 := 0; ; yyj4197++ { - if yyhl4197 { - if yyj4197 >= l { + var yys4188Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4188Slc + var yyhl4188 bool = l >= 0 + for yyj4188 := 0; ; yyj4188++ { + if yyhl4188 { + if yyj4188 >= l { break } } else { @@ -52484,10 +52402,10 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4197Slc = r.DecodeBytes(yys4197Slc, true, true) - yys4197 := string(yys4197Slc) + yys4188Slc = r.DecodeBytes(yys4188Slc, true, true) + yys4188 := string(yys4188Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4197 { + switch yys4188 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -52504,31 +52422,31 @@ func (x *ResourceQuotaList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4200 := &x.ListMeta - yym4201 := z.DecBinary() - _ = yym4201 + yyv4191 := &x.ListMeta + yym4192 := z.DecBinary() + _ = yym4192 if false { - } else if z.HasExtensions() && z.DecExt(yyv4200) { + } else if z.HasExtensions() && z.DecExt(yyv4191) { } else { - z.DecFallback(yyv4200, false) + z.DecFallback(yyv4191, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4202 := &x.Items - yym4203 := z.DecBinary() - _ = yym4203 + yyv4193 := &x.Items + yym4194 := z.DecBinary() + _ = yym4194 if false { } else { - h.decSliceResourceQuota((*[]ResourceQuota)(yyv4202), d) + h.decSliceResourceQuota((*[]ResourceQuota)(yyv4193), d) } } default: - z.DecStructFieldNotFound(-1, yys4197) - } // end switch yys4197 - } // end for yyj4197 + z.DecStructFieldNotFound(-1, yys4188) + } // end switch yys4188 + } // end for yyj4188 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52536,16 +52454,16 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4204 int - var yyb4204 bool - var yyhl4204 bool = l >= 0 - yyj4204++ - if yyhl4204 { - yyb4204 = yyj4204 > l + var yyj4195 int + var yyb4195 bool + var yyhl4195 bool = l >= 0 + yyj4195++ + if yyhl4195 { + yyb4195 = yyj4195 > l } else { - yyb4204 = r.CheckBreak() + yyb4195 = r.CheckBreak() } - if yyb4204 { + if yyb4195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52555,13 +52473,13 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj4204++ - if yyhl4204 { - yyb4204 = yyj4204 > l + yyj4195++ + if yyhl4195 { + yyb4195 = yyj4195 > l } else { - yyb4204 = r.CheckBreak() + yyb4195 = r.CheckBreak() } - if yyb4204 { + if yyb4195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52571,13 +52489,13 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj4204++ - if yyhl4204 { - yyb4204 = yyj4204 > l + yyj4195++ + if yyhl4195 { + yyb4195 = yyj4195 > l } else { - yyb4204 = r.CheckBreak() + yyb4195 = r.CheckBreak() } - if yyb4204 { + if yyb4195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52585,22 +52503,22 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4207 := &x.ListMeta - yym4208 := z.DecBinary() - _ = yym4208 + yyv4198 := &x.ListMeta + yym4199 := z.DecBinary() + _ = yym4199 if false { - } else if z.HasExtensions() && z.DecExt(yyv4207) { + } else if z.HasExtensions() && z.DecExt(yyv4198) { } else { - z.DecFallback(yyv4207, false) + z.DecFallback(yyv4198, false) } } - yyj4204++ - if yyhl4204 { - yyb4204 = yyj4204 > l + yyj4195++ + if yyhl4195 { + yyb4195 = yyj4195 > l } else { - yyb4204 = r.CheckBreak() + yyb4195 = r.CheckBreak() } - if yyb4204 { + if yyb4195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52608,26 +52526,26 @@ func (x *ResourceQuotaList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4209 := &x.Items - yym4210 := z.DecBinary() - _ = yym4210 + yyv4200 := &x.Items + yym4201 := z.DecBinary() + _ = yym4201 if false { } else { - h.decSliceResourceQuota((*[]ResourceQuota)(yyv4209), d) + h.decSliceResourceQuota((*[]ResourceQuota)(yyv4200), d) } } for { - yyj4204++ - if yyhl4204 { - yyb4204 = yyj4204 > l + yyj4195++ + if yyhl4195 { + yyb4195 = yyj4195 > l } else { - yyb4204 = r.CheckBreak() + yyb4195 = r.CheckBreak() } - if yyb4204 { + if yyb4195 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4204-1, "") + z.DecStructFieldNotFound(yyj4195-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -52639,40 +52557,40 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4211 := z.EncBinary() - _ = yym4211 + yym4202 := z.EncBinary() + _ = yym4202 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4212 := !z.EncBinary() - yy2arr4212 := z.EncBasicHandle().StructToArray - var yyq4212 [6]bool - _, _, _ = yysep4212, yyq4212, yy2arr4212 - const yyr4212 bool = false - yyq4212[0] = x.Kind != "" - yyq4212[1] = x.APIVersion != "" - yyq4212[2] = true - yyq4212[3] = len(x.Data) != 0 - yyq4212[4] = len(x.StringData) != 0 - yyq4212[5] = x.Type != "" - var yynn4212 int - if yyr4212 || yy2arr4212 { + yysep4203 := !z.EncBinary() + yy2arr4203 := z.EncBasicHandle().StructToArray + var yyq4203 [6]bool + _, _, _ = yysep4203, yyq4203, yy2arr4203 + const yyr4203 bool = false + yyq4203[0] = x.Kind != "" + yyq4203[1] = x.APIVersion != "" + yyq4203[2] = true + yyq4203[3] = len(x.Data) != 0 + yyq4203[4] = len(x.StringData) != 0 + yyq4203[5] = x.Type != "" + var yynn4203 int + if yyr4203 || yy2arr4203 { r.EncodeArrayStart(6) } else { - yynn4212 = 0 - for _, b := range yyq4212 { + yynn4203 = 0 + for _, b := range yyq4203 { if b { - yynn4212++ + yynn4203++ } } - r.EncodeMapStart(yynn4212) - yynn4212 = 0 + r.EncodeMapStart(yynn4203) + yynn4203 = 0 } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[0] { - yym4214 := z.EncBinary() - _ = yym4214 + if yyq4203[0] { + yym4205 := z.EncBinary() + _ = yym4205 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -52681,23 +52599,23 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4212[0] { + if yyq4203[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4215 := z.EncBinary() - _ = yym4215 + yym4206 := z.EncBinary() + _ = yym4206 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[1] { - yym4217 := z.EncBinary() - _ = yym4217 + if yyq4203[1] { + yym4208 := z.EncBinary() + _ = yym4208 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -52706,43 +52624,43 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4212[1] { + if yyq4203[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4218 := z.EncBinary() - _ = yym4218 + yym4209 := z.EncBinary() + _ = yym4209 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[2] { - yy4220 := &x.ObjectMeta - yy4220.CodecEncodeSelf(e) + if yyq4203[2] { + yy4211 := &x.ObjectMeta + yy4211.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4212[2] { + if yyq4203[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4221 := &x.ObjectMeta - yy4221.CodecEncodeSelf(e) + yy4212 := &x.ObjectMeta + yy4212.CodecEncodeSelf(e) } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[3] { + if yyq4203[3] { if x.Data == nil { r.EncodeNil() } else { - yym4223 := z.EncBinary() - _ = yym4223 + yym4214 := z.EncBinary() + _ = yym4214 if false { } else { h.encMapstringSliceuint8((map[string][]uint8)(x.Data), e) @@ -52752,15 +52670,15 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4212[3] { + if yyq4203[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("data")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Data == nil { r.EncodeNil() } else { - yym4224 := z.EncBinary() - _ = yym4224 + yym4215 := z.EncBinary() + _ = yym4215 if false { } else { h.encMapstringSliceuint8((map[string][]uint8)(x.Data), e) @@ -52768,14 +52686,14 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[4] { + if yyq4203[4] { if x.StringData == nil { r.EncodeNil() } else { - yym4226 := z.EncBinary() - _ = yym4226 + yym4217 := z.EncBinary() + _ = yym4217 if false { } else { z.F.EncMapStringStringV(x.StringData, false, e) @@ -52785,15 +52703,15 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4212[4] { + if yyq4203[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("stringData")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.StringData == nil { r.EncodeNil() } else { - yym4227 := z.EncBinary() - _ = yym4227 + yym4218 := z.EncBinary() + _ = yym4218 if false { } else { z.F.EncMapStringStringV(x.StringData, false, e) @@ -52801,22 +52719,22 @@ func (x *Secret) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4212[5] { + if yyq4203[5] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4212[5] { + if yyq4203[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr4212 || yy2arr4212 { + if yyr4203 || yy2arr4203 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -52829,25 +52747,25 @@ func (x *Secret) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4229 := z.DecBinary() - _ = yym4229 + yym4220 := z.DecBinary() + _ = yym4220 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4230 := r.ContainerType() - if yyct4230 == codecSelferValueTypeMap1234 { - yyl4230 := r.ReadMapStart() - if yyl4230 == 0 { + yyct4221 := r.ContainerType() + if yyct4221 == codecSelferValueTypeMap1234 { + yyl4221 := r.ReadMapStart() + if yyl4221 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4230, d) + x.codecDecodeSelfFromMap(yyl4221, d) } - } else if yyct4230 == codecSelferValueTypeArray1234 { - yyl4230 := r.ReadArrayStart() - if yyl4230 == 0 { + } else if yyct4221 == codecSelferValueTypeArray1234 { + yyl4221 := r.ReadArrayStart() + if yyl4221 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4230, d) + x.codecDecodeSelfFromArray(yyl4221, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -52859,12 +52777,12 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4231Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4231Slc - var yyhl4231 bool = l >= 0 - for yyj4231 := 0; ; yyj4231++ { - if yyhl4231 { - if yyj4231 >= l { + var yys4222Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4222Slc + var yyhl4222 bool = l >= 0 + for yyj4222 := 0; ; yyj4222++ { + if yyhl4222 { + if yyj4222 >= l { break } } else { @@ -52873,10 +52791,10 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4231Slc = r.DecodeBytes(yys4231Slc, true, true) - yys4231 := string(yys4231Slc) + yys4222Slc = r.DecodeBytes(yys4222Slc, true, true) + yys4222 := string(yys4222Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4231 { + switch yys4222 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -52893,31 +52811,31 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4234 := &x.ObjectMeta - yyv4234.CodecDecodeSelf(d) + yyv4225 := &x.ObjectMeta + yyv4225.CodecDecodeSelf(d) } case "data": if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4235 := &x.Data - yym4236 := z.DecBinary() - _ = yym4236 + yyv4226 := &x.Data + yym4227 := z.DecBinary() + _ = yym4227 if false { } else { - h.decMapstringSliceuint8((*map[string][]uint8)(yyv4235), d) + h.decMapstringSliceuint8((*map[string][]uint8)(yyv4226), d) } } case "stringData": if r.TryDecodeAsNil() { x.StringData = nil } else { - yyv4237 := &x.StringData - yym4238 := z.DecBinary() - _ = yym4238 + yyv4228 := &x.StringData + yym4229 := z.DecBinary() + _ = yym4229 if false { } else { - z.F.DecMapStringStringX(yyv4237, false, d) + z.F.DecMapStringStringX(yyv4228, false, d) } } case "type": @@ -52927,9 +52845,9 @@ func (x *Secret) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Type = SecretType(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4231) - } // end switch yys4231 - } // end for yyj4231 + z.DecStructFieldNotFound(-1, yys4222) + } // end switch yys4222 + } // end for yyj4222 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -52937,16 +52855,16 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4240 int - var yyb4240 bool - var yyhl4240 bool = l >= 0 - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + var yyj4231 int + var yyb4231 bool + var yyhl4231 bool = l >= 0 + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52956,13 +52874,13 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52972,13 +52890,13 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -52986,16 +52904,16 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4243 := &x.ObjectMeta - yyv4243.CodecDecodeSelf(d) + yyv4234 := &x.ObjectMeta + yyv4234.CodecDecodeSelf(d) } - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53003,21 +52921,21 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4244 := &x.Data - yym4245 := z.DecBinary() - _ = yym4245 + yyv4235 := &x.Data + yym4236 := z.DecBinary() + _ = yym4236 if false { } else { - h.decMapstringSliceuint8((*map[string][]uint8)(yyv4244), d) + h.decMapstringSliceuint8((*map[string][]uint8)(yyv4235), d) } } - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53025,21 +52943,21 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.StringData = nil } else { - yyv4246 := &x.StringData - yym4247 := z.DecBinary() - _ = yym4247 + yyv4237 := &x.StringData + yym4238 := z.DecBinary() + _ = yym4238 if false { } else { - z.F.DecMapStringStringX(yyv4246, false, d) + z.F.DecMapStringStringX(yyv4237, false, d) } } - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53050,17 +52968,17 @@ func (x *Secret) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Type = SecretType(r.DecodeString()) } for { - yyj4240++ - if yyhl4240 { - yyb4240 = yyj4240 > l + yyj4231++ + if yyhl4231 { + yyb4231 = yyj4231 > l } else { - yyb4240 = r.CheckBreak() + yyb4231 = r.CheckBreak() } - if yyb4240 { + if yyb4231 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4240-1, "") + z.DecStructFieldNotFound(yyj4231-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53069,8 +52987,8 @@ func (x SecretType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4249 := z.EncBinary() - _ = yym4249 + yym4240 := z.EncBinary() + _ = yym4240 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -53082,8 +53000,8 @@ func (x *SecretType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4250 := z.DecBinary() - _ = yym4250 + yym4241 := z.DecBinary() + _ = yym4241 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -53098,37 +53016,37 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4251 := z.EncBinary() - _ = yym4251 + yym4242 := z.EncBinary() + _ = yym4242 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4252 := !z.EncBinary() - yy2arr4252 := z.EncBasicHandle().StructToArray - var yyq4252 [4]bool - _, _, _ = yysep4252, yyq4252, yy2arr4252 - const yyr4252 bool = false - yyq4252[0] = x.Kind != "" - yyq4252[1] = x.APIVersion != "" - yyq4252[2] = true - var yynn4252 int - if yyr4252 || yy2arr4252 { + yysep4243 := !z.EncBinary() + yy2arr4243 := z.EncBasicHandle().StructToArray + var yyq4243 [4]bool + _, _, _ = yysep4243, yyq4243, yy2arr4243 + const yyr4243 bool = false + yyq4243[0] = x.Kind != "" + yyq4243[1] = x.APIVersion != "" + yyq4243[2] = true + var yynn4243 int + if yyr4243 || yy2arr4243 { r.EncodeArrayStart(4) } else { - yynn4252 = 1 - for _, b := range yyq4252 { + yynn4243 = 1 + for _, b := range yyq4243 { if b { - yynn4252++ + yynn4243++ } } - r.EncodeMapStart(yynn4252) - yynn4252 = 0 + r.EncodeMapStart(yynn4243) + yynn4243 = 0 } - if yyr4252 || yy2arr4252 { + if yyr4243 || yy2arr4243 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4252[0] { - yym4254 := z.EncBinary() - _ = yym4254 + if yyq4243[0] { + yym4245 := z.EncBinary() + _ = yym4245 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -53137,23 +53055,23 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4252[0] { + if yyq4243[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4255 := z.EncBinary() - _ = yym4255 + yym4246 := z.EncBinary() + _ = yym4246 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4252 || yy2arr4252 { + if yyr4243 || yy2arr4243 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4252[1] { - yym4257 := z.EncBinary() - _ = yym4257 + if yyq4243[1] { + yym4248 := z.EncBinary() + _ = yym4248 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -53162,54 +53080,54 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4252[1] { + if yyq4243[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4258 := z.EncBinary() - _ = yym4258 + yym4249 := z.EncBinary() + _ = yym4249 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4252 || yy2arr4252 { + if yyr4243 || yy2arr4243 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4252[2] { - yy4260 := &x.ListMeta - yym4261 := z.EncBinary() - _ = yym4261 + if yyq4243[2] { + yy4251 := &x.ListMeta + yym4252 := z.EncBinary() + _ = yym4252 if false { - } else if z.HasExtensions() && z.EncExt(yy4260) { + } else if z.HasExtensions() && z.EncExt(yy4251) { } else { - z.EncFallback(yy4260) + z.EncFallback(yy4251) } } else { r.EncodeNil() } } else { - if yyq4252[2] { + if yyq4243[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4262 := &x.ListMeta - yym4263 := z.EncBinary() - _ = yym4263 + yy4253 := &x.ListMeta + yym4254 := z.EncBinary() + _ = yym4254 if false { - } else if z.HasExtensions() && z.EncExt(yy4262) { + } else if z.HasExtensions() && z.EncExt(yy4253) { } else { - z.EncFallback(yy4262) + z.EncFallback(yy4253) } } } - if yyr4252 || yy2arr4252 { + if yyr4243 || yy2arr4243 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4265 := z.EncBinary() - _ = yym4265 + yym4256 := z.EncBinary() + _ = yym4256 if false { } else { h.encSliceSecret(([]Secret)(x.Items), e) @@ -53222,15 +53140,15 @@ func (x *SecretList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4266 := z.EncBinary() - _ = yym4266 + yym4257 := z.EncBinary() + _ = yym4257 if false { } else { h.encSliceSecret(([]Secret)(x.Items), e) } } } - if yyr4252 || yy2arr4252 { + if yyr4243 || yy2arr4243 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53243,25 +53161,25 @@ func (x *SecretList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4267 := z.DecBinary() - _ = yym4267 + yym4258 := z.DecBinary() + _ = yym4258 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4268 := r.ContainerType() - if yyct4268 == codecSelferValueTypeMap1234 { - yyl4268 := r.ReadMapStart() - if yyl4268 == 0 { + yyct4259 := r.ContainerType() + if yyct4259 == codecSelferValueTypeMap1234 { + yyl4259 := r.ReadMapStart() + if yyl4259 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4268, d) + x.codecDecodeSelfFromMap(yyl4259, d) } - } else if yyct4268 == codecSelferValueTypeArray1234 { - yyl4268 := r.ReadArrayStart() - if yyl4268 == 0 { + } else if yyct4259 == codecSelferValueTypeArray1234 { + yyl4259 := r.ReadArrayStart() + if yyl4259 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4268, d) + x.codecDecodeSelfFromArray(yyl4259, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53273,12 +53191,12 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4269Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4269Slc - var yyhl4269 bool = l >= 0 - for yyj4269 := 0; ; yyj4269++ { - if yyhl4269 { - if yyj4269 >= l { + var yys4260Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4260Slc + var yyhl4260 bool = l >= 0 + for yyj4260 := 0; ; yyj4260++ { + if yyhl4260 { + if yyj4260 >= l { break } } else { @@ -53287,10 +53205,10 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4269Slc = r.DecodeBytes(yys4269Slc, true, true) - yys4269 := string(yys4269Slc) + yys4260Slc = r.DecodeBytes(yys4260Slc, true, true) + yys4260 := string(yys4260Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4269 { + switch yys4260 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53307,31 +53225,31 @@ func (x *SecretList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4272 := &x.ListMeta - yym4273 := z.DecBinary() - _ = yym4273 + yyv4263 := &x.ListMeta + yym4264 := z.DecBinary() + _ = yym4264 if false { - } else if z.HasExtensions() && z.DecExt(yyv4272) { + } else if z.HasExtensions() && z.DecExt(yyv4263) { } else { - z.DecFallback(yyv4272, false) + z.DecFallback(yyv4263, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4274 := &x.Items - yym4275 := z.DecBinary() - _ = yym4275 + yyv4265 := &x.Items + yym4266 := z.DecBinary() + _ = yym4266 if false { } else { - h.decSliceSecret((*[]Secret)(yyv4274), d) + h.decSliceSecret((*[]Secret)(yyv4265), d) } } default: - z.DecStructFieldNotFound(-1, yys4269) - } // end switch yys4269 - } // end for yyj4269 + z.DecStructFieldNotFound(-1, yys4260) + } // end switch yys4260 + } // end for yyj4260 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -53339,16 +53257,16 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4276 int - var yyb4276 bool - var yyhl4276 bool = l >= 0 - yyj4276++ - if yyhl4276 { - yyb4276 = yyj4276 > l + var yyj4267 int + var yyb4267 bool + var yyhl4267 bool = l >= 0 + yyj4267++ + if yyhl4267 { + yyb4267 = yyj4267 > l } else { - yyb4276 = r.CheckBreak() + yyb4267 = r.CheckBreak() } - if yyb4276 { + if yyb4267 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53358,13 +53276,13 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4276++ - if yyhl4276 { - yyb4276 = yyj4276 > l + yyj4267++ + if yyhl4267 { + yyb4267 = yyj4267 > l } else { - yyb4276 = r.CheckBreak() + yyb4267 = r.CheckBreak() } - if yyb4276 { + if yyb4267 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53374,13 +53292,13 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4276++ - if yyhl4276 { - yyb4276 = yyj4276 > l + yyj4267++ + if yyhl4267 { + yyb4267 = yyj4267 > l } else { - yyb4276 = r.CheckBreak() + yyb4267 = r.CheckBreak() } - if yyb4276 { + if yyb4267 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53388,22 +53306,22 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4279 := &x.ListMeta - yym4280 := z.DecBinary() - _ = yym4280 + yyv4270 := &x.ListMeta + yym4271 := z.DecBinary() + _ = yym4271 if false { - } else if z.HasExtensions() && z.DecExt(yyv4279) { + } else if z.HasExtensions() && z.DecExt(yyv4270) { } else { - z.DecFallback(yyv4279, false) + z.DecFallback(yyv4270, false) } } - yyj4276++ - if yyhl4276 { - yyb4276 = yyj4276 > l + yyj4267++ + if yyhl4267 { + yyb4267 = yyj4267 > l } else { - yyb4276 = r.CheckBreak() + yyb4267 = r.CheckBreak() } - if yyb4276 { + if yyb4267 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53411,26 +53329,26 @@ func (x *SecretList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4281 := &x.Items - yym4282 := z.DecBinary() - _ = yym4282 + yyv4272 := &x.Items + yym4273 := z.DecBinary() + _ = yym4273 if false { } else { - h.decSliceSecret((*[]Secret)(yyv4281), d) + h.decSliceSecret((*[]Secret)(yyv4272), d) } } for { - yyj4276++ - if yyhl4276 { - yyb4276 = yyj4276 > l + yyj4267++ + if yyhl4267 { + yyb4267 = yyj4267 > l } else { - yyb4276 = r.CheckBreak() + yyb4267 = r.CheckBreak() } - if yyb4276 { + if yyb4267 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4276-1, "") + z.DecStructFieldNotFound(yyj4267-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53442,38 +53360,38 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4283 := z.EncBinary() - _ = yym4283 + yym4274 := z.EncBinary() + _ = yym4274 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4284 := !z.EncBinary() - yy2arr4284 := z.EncBasicHandle().StructToArray - var yyq4284 [4]bool - _, _, _ = yysep4284, yyq4284, yy2arr4284 - const yyr4284 bool = false - yyq4284[0] = x.Kind != "" - yyq4284[1] = x.APIVersion != "" - yyq4284[2] = true - yyq4284[3] = len(x.Data) != 0 - var yynn4284 int - if yyr4284 || yy2arr4284 { + yysep4275 := !z.EncBinary() + yy2arr4275 := z.EncBasicHandle().StructToArray + var yyq4275 [4]bool + _, _, _ = yysep4275, yyq4275, yy2arr4275 + const yyr4275 bool = false + yyq4275[0] = x.Kind != "" + yyq4275[1] = x.APIVersion != "" + yyq4275[2] = true + yyq4275[3] = len(x.Data) != 0 + var yynn4275 int + if yyr4275 || yy2arr4275 { r.EncodeArrayStart(4) } else { - yynn4284 = 0 - for _, b := range yyq4284 { + yynn4275 = 0 + for _, b := range yyq4275 { if b { - yynn4284++ + yynn4275++ } } - r.EncodeMapStart(yynn4284) - yynn4284 = 0 + r.EncodeMapStart(yynn4275) + yynn4275 = 0 } - if yyr4284 || yy2arr4284 { + if yyr4275 || yy2arr4275 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4284[0] { - yym4286 := z.EncBinary() - _ = yym4286 + if yyq4275[0] { + yym4277 := z.EncBinary() + _ = yym4277 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -53482,23 +53400,23 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4284[0] { + if yyq4275[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4287 := z.EncBinary() - _ = yym4287 + yym4278 := z.EncBinary() + _ = yym4278 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4284 || yy2arr4284 { + if yyr4275 || yy2arr4275 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4284[1] { - yym4289 := z.EncBinary() - _ = yym4289 + if yyq4275[1] { + yym4280 := z.EncBinary() + _ = yym4280 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -53507,43 +53425,43 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4284[1] { + if yyq4275[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4290 := z.EncBinary() - _ = yym4290 + yym4281 := z.EncBinary() + _ = yym4281 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4284 || yy2arr4284 { + if yyr4275 || yy2arr4275 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4284[2] { - yy4292 := &x.ObjectMeta - yy4292.CodecEncodeSelf(e) + if yyq4275[2] { + yy4283 := &x.ObjectMeta + yy4283.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4284[2] { + if yyq4275[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4293 := &x.ObjectMeta - yy4293.CodecEncodeSelf(e) + yy4284 := &x.ObjectMeta + yy4284.CodecEncodeSelf(e) } } - if yyr4284 || yy2arr4284 { + if yyr4275 || yy2arr4275 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4284[3] { + if yyq4275[3] { if x.Data == nil { r.EncodeNil() } else { - yym4295 := z.EncBinary() - _ = yym4295 + yym4286 := z.EncBinary() + _ = yym4286 if false { } else { z.F.EncMapStringStringV(x.Data, false, e) @@ -53553,15 +53471,15 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4284[3] { + if yyq4275[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("data")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Data == nil { r.EncodeNil() } else { - yym4296 := z.EncBinary() - _ = yym4296 + yym4287 := z.EncBinary() + _ = yym4287 if false { } else { z.F.EncMapStringStringV(x.Data, false, e) @@ -53569,7 +53487,7 @@ func (x *ConfigMap) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4284 || yy2arr4284 { + if yyr4275 || yy2arr4275 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53582,25 +53500,25 @@ func (x *ConfigMap) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4297 := z.DecBinary() - _ = yym4297 + yym4288 := z.DecBinary() + _ = yym4288 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4298 := r.ContainerType() - if yyct4298 == codecSelferValueTypeMap1234 { - yyl4298 := r.ReadMapStart() - if yyl4298 == 0 { + yyct4289 := r.ContainerType() + if yyct4289 == codecSelferValueTypeMap1234 { + yyl4289 := r.ReadMapStart() + if yyl4289 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4298, d) + x.codecDecodeSelfFromMap(yyl4289, d) } - } else if yyct4298 == codecSelferValueTypeArray1234 { - yyl4298 := r.ReadArrayStart() - if yyl4298 == 0 { + } else if yyct4289 == codecSelferValueTypeArray1234 { + yyl4289 := r.ReadArrayStart() + if yyl4289 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4298, d) + x.codecDecodeSelfFromArray(yyl4289, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53612,12 +53530,12 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4299Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4299Slc - var yyhl4299 bool = l >= 0 - for yyj4299 := 0; ; yyj4299++ { - if yyhl4299 { - if yyj4299 >= l { + var yys4290Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4290Slc + var yyhl4290 bool = l >= 0 + for yyj4290 := 0; ; yyj4290++ { + if yyhl4290 { + if yyj4290 >= l { break } } else { @@ -53626,10 +53544,10 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4299Slc = r.DecodeBytes(yys4299Slc, true, true) - yys4299 := string(yys4299Slc) + yys4290Slc = r.DecodeBytes(yys4290Slc, true, true) + yys4290 := string(yys4290Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4299 { + switch yys4290 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53646,25 +53564,25 @@ func (x *ConfigMap) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4302 := &x.ObjectMeta - yyv4302.CodecDecodeSelf(d) + yyv4293 := &x.ObjectMeta + yyv4293.CodecDecodeSelf(d) } case "data": if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4303 := &x.Data - yym4304 := z.DecBinary() - _ = yym4304 + yyv4294 := &x.Data + yym4295 := z.DecBinary() + _ = yym4295 if false { } else { - z.F.DecMapStringStringX(yyv4303, false, d) + z.F.DecMapStringStringX(yyv4294, false, d) } } default: - z.DecStructFieldNotFound(-1, yys4299) - } // end switch yys4299 - } // end for yyj4299 + z.DecStructFieldNotFound(-1, yys4290) + } // end switch yys4290 + } // end for yyj4290 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -53672,16 +53590,16 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4305 int - var yyb4305 bool - var yyhl4305 bool = l >= 0 - yyj4305++ - if yyhl4305 { - yyb4305 = yyj4305 > l + var yyj4296 int + var yyb4296 bool + var yyhl4296 bool = l >= 0 + yyj4296++ + if yyhl4296 { + yyb4296 = yyj4296 > l } else { - yyb4305 = r.CheckBreak() + yyb4296 = r.CheckBreak() } - if yyb4305 { + if yyb4296 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53691,13 +53609,13 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4305++ - if yyhl4305 { - yyb4305 = yyj4305 > l + yyj4296++ + if yyhl4296 { + yyb4296 = yyj4296 > l } else { - yyb4305 = r.CheckBreak() + yyb4296 = r.CheckBreak() } - if yyb4305 { + if yyb4296 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53707,13 +53625,13 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4305++ - if yyhl4305 { - yyb4305 = yyj4305 > l + yyj4296++ + if yyhl4296 { + yyb4296 = yyj4296 > l } else { - yyb4305 = r.CheckBreak() + yyb4296 = r.CheckBreak() } - if yyb4305 { + if yyb4296 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53721,16 +53639,16 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4308 := &x.ObjectMeta - yyv4308.CodecDecodeSelf(d) + yyv4299 := &x.ObjectMeta + yyv4299.CodecDecodeSelf(d) } - yyj4305++ - if yyhl4305 { - yyb4305 = yyj4305 > l + yyj4296++ + if yyhl4296 { + yyb4296 = yyj4296 > l } else { - yyb4305 = r.CheckBreak() + yyb4296 = r.CheckBreak() } - if yyb4305 { + if yyb4296 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -53738,26 +53656,26 @@ func (x *ConfigMap) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4309 := &x.Data - yym4310 := z.DecBinary() - _ = yym4310 + yyv4300 := &x.Data + yym4301 := z.DecBinary() + _ = yym4301 if false { } else { - z.F.DecMapStringStringX(yyv4309, false, d) + z.F.DecMapStringStringX(yyv4300, false, d) } } for { - yyj4305++ - if yyhl4305 { - yyb4305 = yyj4305 > l + yyj4296++ + if yyhl4296 { + yyb4296 = yyj4296 > l } else { - yyb4305 = r.CheckBreak() + yyb4296 = r.CheckBreak() } - if yyb4305 { + if yyb4296 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4305-1, "") + z.DecStructFieldNotFound(yyj4296-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -53769,37 +53687,37 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4311 := z.EncBinary() - _ = yym4311 + yym4302 := z.EncBinary() + _ = yym4302 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4312 := !z.EncBinary() - yy2arr4312 := z.EncBasicHandle().StructToArray - var yyq4312 [4]bool - _, _, _ = yysep4312, yyq4312, yy2arr4312 - const yyr4312 bool = false - yyq4312[0] = x.Kind != "" - yyq4312[1] = x.APIVersion != "" - yyq4312[2] = true - var yynn4312 int - if yyr4312 || yy2arr4312 { + yysep4303 := !z.EncBinary() + yy2arr4303 := z.EncBasicHandle().StructToArray + var yyq4303 [4]bool + _, _, _ = yysep4303, yyq4303, yy2arr4303 + const yyr4303 bool = false + yyq4303[0] = x.Kind != "" + yyq4303[1] = x.APIVersion != "" + yyq4303[2] = true + var yynn4303 int + if yyr4303 || yy2arr4303 { r.EncodeArrayStart(4) } else { - yynn4312 = 1 - for _, b := range yyq4312 { + yynn4303 = 1 + for _, b := range yyq4303 { if b { - yynn4312++ + yynn4303++ } } - r.EncodeMapStart(yynn4312) - yynn4312 = 0 + r.EncodeMapStart(yynn4303) + yynn4303 = 0 } - if yyr4312 || yy2arr4312 { + if yyr4303 || yy2arr4303 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4312[0] { - yym4314 := z.EncBinary() - _ = yym4314 + if yyq4303[0] { + yym4305 := z.EncBinary() + _ = yym4305 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -53808,23 +53726,23 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4312[0] { + if yyq4303[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4315 := z.EncBinary() - _ = yym4315 + yym4306 := z.EncBinary() + _ = yym4306 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4312 || yy2arr4312 { + if yyr4303 || yy2arr4303 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4312[1] { - yym4317 := z.EncBinary() - _ = yym4317 + if yyq4303[1] { + yym4308 := z.EncBinary() + _ = yym4308 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -53833,54 +53751,54 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4312[1] { + if yyq4303[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4318 := z.EncBinary() - _ = yym4318 + yym4309 := z.EncBinary() + _ = yym4309 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4312 || yy2arr4312 { + if yyr4303 || yy2arr4303 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4312[2] { - yy4320 := &x.ListMeta - yym4321 := z.EncBinary() - _ = yym4321 + if yyq4303[2] { + yy4311 := &x.ListMeta + yym4312 := z.EncBinary() + _ = yym4312 if false { - } else if z.HasExtensions() && z.EncExt(yy4320) { + } else if z.HasExtensions() && z.EncExt(yy4311) { } else { - z.EncFallback(yy4320) + z.EncFallback(yy4311) } } else { r.EncodeNil() } } else { - if yyq4312[2] { + if yyq4303[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4322 := &x.ListMeta - yym4323 := z.EncBinary() - _ = yym4323 + yy4313 := &x.ListMeta + yym4314 := z.EncBinary() + _ = yym4314 if false { - } else if z.HasExtensions() && z.EncExt(yy4322) { + } else if z.HasExtensions() && z.EncExt(yy4313) { } else { - z.EncFallback(yy4322) + z.EncFallback(yy4313) } } } - if yyr4312 || yy2arr4312 { + if yyr4303 || yy2arr4303 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4325 := z.EncBinary() - _ = yym4325 + yym4316 := z.EncBinary() + _ = yym4316 if false { } else { h.encSliceConfigMap(([]ConfigMap)(x.Items), e) @@ -53893,15 +53811,15 @@ func (x *ConfigMapList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4326 := z.EncBinary() - _ = yym4326 + yym4317 := z.EncBinary() + _ = yym4317 if false { } else { h.encSliceConfigMap(([]ConfigMap)(x.Items), e) } } } - if yyr4312 || yy2arr4312 { + if yyr4303 || yy2arr4303 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -53914,25 +53832,25 @@ func (x *ConfigMapList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4327 := z.DecBinary() - _ = yym4327 + yym4318 := z.DecBinary() + _ = yym4318 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4328 := r.ContainerType() - if yyct4328 == codecSelferValueTypeMap1234 { - yyl4328 := r.ReadMapStart() - if yyl4328 == 0 { + yyct4319 := r.ContainerType() + if yyct4319 == codecSelferValueTypeMap1234 { + yyl4319 := r.ReadMapStart() + if yyl4319 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4328, d) + x.codecDecodeSelfFromMap(yyl4319, d) } - } else if yyct4328 == codecSelferValueTypeArray1234 { - yyl4328 := r.ReadArrayStart() - if yyl4328 == 0 { + } else if yyct4319 == codecSelferValueTypeArray1234 { + yyl4319 := r.ReadArrayStart() + if yyl4319 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4328, d) + x.codecDecodeSelfFromArray(yyl4319, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -53944,12 +53862,12 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4329Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4329Slc - var yyhl4329 bool = l >= 0 - for yyj4329 := 0; ; yyj4329++ { - if yyhl4329 { - if yyj4329 >= l { + var yys4320Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4320Slc + var yyhl4320 bool = l >= 0 + for yyj4320 := 0; ; yyj4320++ { + if yyhl4320 { + if yyj4320 >= l { break } } else { @@ -53958,10 +53876,10 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4329Slc = r.DecodeBytes(yys4329Slc, true, true) - yys4329 := string(yys4329Slc) + yys4320Slc = r.DecodeBytes(yys4320Slc, true, true) + yys4320 := string(yys4320Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4329 { + switch yys4320 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -53978,31 +53896,31 @@ func (x *ConfigMapList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4332 := &x.ListMeta - yym4333 := z.DecBinary() - _ = yym4333 + yyv4323 := &x.ListMeta + yym4324 := z.DecBinary() + _ = yym4324 if false { - } else if z.HasExtensions() && z.DecExt(yyv4332) { + } else if z.HasExtensions() && z.DecExt(yyv4323) { } else { - z.DecFallback(yyv4332, false) + z.DecFallback(yyv4323, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4334 := &x.Items - yym4335 := z.DecBinary() - _ = yym4335 + yyv4325 := &x.Items + yym4326 := z.DecBinary() + _ = yym4326 if false { } else { - h.decSliceConfigMap((*[]ConfigMap)(yyv4334), d) + h.decSliceConfigMap((*[]ConfigMap)(yyv4325), d) } } default: - z.DecStructFieldNotFound(-1, yys4329) - } // end switch yys4329 - } // end for yyj4329 + z.DecStructFieldNotFound(-1, yys4320) + } // end switch yys4320 + } // end for yyj4320 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54010,16 +53928,16 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4336 int - var yyb4336 bool - var yyhl4336 bool = l >= 0 - yyj4336++ - if yyhl4336 { - yyb4336 = yyj4336 > l + var yyj4327 int + var yyb4327 bool + var yyhl4327 bool = l >= 0 + yyj4327++ + if yyhl4327 { + yyb4327 = yyj4327 > l } else { - yyb4336 = r.CheckBreak() + yyb4327 = r.CheckBreak() } - if yyb4336 { + if yyb4327 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54029,13 +53947,13 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj4336++ - if yyhl4336 { - yyb4336 = yyj4336 > l + yyj4327++ + if yyhl4327 { + yyb4327 = yyj4327 > l } else { - yyb4336 = r.CheckBreak() + yyb4327 = r.CheckBreak() } - if yyb4336 { + if yyb4327 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54045,13 +53963,13 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj4336++ - if yyhl4336 { - yyb4336 = yyj4336 > l + yyj4327++ + if yyhl4327 { + yyb4327 = yyj4327 > l } else { - yyb4336 = r.CheckBreak() + yyb4327 = r.CheckBreak() } - if yyb4336 { + if yyb4327 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54059,22 +53977,22 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4339 := &x.ListMeta - yym4340 := z.DecBinary() - _ = yym4340 + yyv4330 := &x.ListMeta + yym4331 := z.DecBinary() + _ = yym4331 if false { - } else if z.HasExtensions() && z.DecExt(yyv4339) { + } else if z.HasExtensions() && z.DecExt(yyv4330) { } else { - z.DecFallback(yyv4339, false) + z.DecFallback(yyv4330, false) } } - yyj4336++ - if yyhl4336 { - yyb4336 = yyj4336 > l + yyj4327++ + if yyhl4327 { + yyb4327 = yyj4327 > l } else { - yyb4336 = r.CheckBreak() + yyb4327 = r.CheckBreak() } - if yyb4336 { + if yyb4327 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54082,26 +54000,26 @@ func (x *ConfigMapList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4341 := &x.Items - yym4342 := z.DecBinary() - _ = yym4342 + yyv4332 := &x.Items + yym4333 := z.DecBinary() + _ = yym4333 if false { } else { - h.decSliceConfigMap((*[]ConfigMap)(yyv4341), d) + h.decSliceConfigMap((*[]ConfigMap)(yyv4332), d) } } for { - yyj4336++ - if yyhl4336 { - yyb4336 = yyj4336 > l + yyj4327++ + if yyhl4327 { + yyb4327 = yyj4327 > l } else { - yyb4336 = r.CheckBreak() + yyb4327 = r.CheckBreak() } - if yyb4336 { + if yyb4327 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4336-1, "") + z.DecStructFieldNotFound(yyj4327-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54110,8 +54028,8 @@ func (x ComponentConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym4343 := z.EncBinary() - _ = yym4343 + yym4334 := z.EncBinary() + _ = yym4334 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -54123,8 +54041,8 @@ func (x *ComponentConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4344 := z.DecBinary() - _ = yym4344 + yym4335 := z.DecBinary() + _ = yym4335 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -54139,32 +54057,32 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4345 := z.EncBinary() - _ = yym4345 + yym4336 := z.EncBinary() + _ = yym4336 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4346 := !z.EncBinary() - yy2arr4346 := z.EncBasicHandle().StructToArray - var yyq4346 [4]bool - _, _, _ = yysep4346, yyq4346, yy2arr4346 - const yyr4346 bool = false - yyq4346[2] = x.Message != "" - yyq4346[3] = x.Error != "" - var yynn4346 int - if yyr4346 || yy2arr4346 { + yysep4337 := !z.EncBinary() + yy2arr4337 := z.EncBasicHandle().StructToArray + var yyq4337 [4]bool + _, _, _ = yysep4337, yyq4337, yy2arr4337 + const yyr4337 bool = false + yyq4337[2] = x.Message != "" + yyq4337[3] = x.Error != "" + var yynn4337 int + if yyr4337 || yy2arr4337 { r.EncodeArrayStart(4) } else { - yynn4346 = 2 - for _, b := range yyq4346 { + yynn4337 = 2 + for _, b := range yyq4337 { if b { - yynn4346++ + yynn4337++ } } - r.EncodeMapStart(yynn4346) - yynn4346 = 0 + r.EncodeMapStart(yynn4337) + yynn4337 = 0 } - if yyr4346 || yy2arr4346 { + if yyr4337 || yy2arr4337 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -54173,7 +54091,7 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr4346 || yy2arr4346 { + if yyr4337 || yy2arr4337 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Status.CodecEncodeSelf(e) } else { @@ -54182,11 +54100,11 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Status.CodecEncodeSelf(e) } - if yyr4346 || yy2arr4346 { + if yyr4337 || yy2arr4337 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4346[2] { - yym4350 := z.EncBinary() - _ = yym4350 + if yyq4337[2] { + yym4341 := z.EncBinary() + _ = yym4341 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -54195,23 +54113,23 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4346[2] { + if yyq4337[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4351 := z.EncBinary() - _ = yym4351 + yym4342 := z.EncBinary() + _ = yym4342 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr4346 || yy2arr4346 { + if yyr4337 || yy2arr4337 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4346[3] { - yym4353 := z.EncBinary() - _ = yym4353 + if yyq4337[3] { + yym4344 := z.EncBinary() + _ = yym4344 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Error)) @@ -54220,19 +54138,19 @@ func (x *ComponentCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4346[3] { + if yyq4337[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("error")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4354 := z.EncBinary() - _ = yym4354 + yym4345 := z.EncBinary() + _ = yym4345 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Error)) } } } - if yyr4346 || yy2arr4346 { + if yyr4337 || yy2arr4337 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54245,25 +54163,25 @@ func (x *ComponentCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4355 := z.DecBinary() - _ = yym4355 + yym4346 := z.DecBinary() + _ = yym4346 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4356 := r.ContainerType() - if yyct4356 == codecSelferValueTypeMap1234 { - yyl4356 := r.ReadMapStart() - if yyl4356 == 0 { + yyct4347 := r.ContainerType() + if yyct4347 == codecSelferValueTypeMap1234 { + yyl4347 := r.ReadMapStart() + if yyl4347 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4356, d) + x.codecDecodeSelfFromMap(yyl4347, d) } - } else if yyct4356 == codecSelferValueTypeArray1234 { - yyl4356 := r.ReadArrayStart() - if yyl4356 == 0 { + } else if yyct4347 == codecSelferValueTypeArray1234 { + yyl4347 := r.ReadArrayStart() + if yyl4347 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4356, d) + x.codecDecodeSelfFromArray(yyl4347, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54275,12 +54193,12 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4357Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4357Slc - var yyhl4357 bool = l >= 0 - for yyj4357 := 0; ; yyj4357++ { - if yyhl4357 { - if yyj4357 >= l { + var yys4348Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4348Slc + var yyhl4348 bool = l >= 0 + for yyj4348 := 0; ; yyj4348++ { + if yyhl4348 { + if yyj4348 >= l { break } } else { @@ -54289,10 +54207,10 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4357Slc = r.DecodeBytes(yys4357Slc, true, true) - yys4357 := string(yys4357Slc) + yys4348Slc = r.DecodeBytes(yys4348Slc, true, true) + yys4348 := string(yys4348Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4357 { + switch yys4348 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -54318,9 +54236,9 @@ func (x *ComponentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) x.Error = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4357) - } // end switch yys4357 - } // end for yyj4357 + z.DecStructFieldNotFound(-1, yys4348) + } // end switch yys4348 + } // end for yyj4348 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54328,16 +54246,16 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4362 int - var yyb4362 bool - var yyhl4362 bool = l >= 0 - yyj4362++ - if yyhl4362 { - yyb4362 = yyj4362 > l + var yyj4353 int + var yyb4353 bool + var yyhl4353 bool = l >= 0 + yyj4353++ + if yyhl4353 { + yyb4353 = yyj4353 > l } else { - yyb4362 = r.CheckBreak() + yyb4353 = r.CheckBreak() } - if yyb4362 { + if yyb4353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54347,13 +54265,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Type = ComponentConditionType(r.DecodeString()) } - yyj4362++ - if yyhl4362 { - yyb4362 = yyj4362 > l + yyj4353++ + if yyhl4353 { + yyb4353 = yyj4353 > l } else { - yyb4362 = r.CheckBreak() + yyb4353 = r.CheckBreak() } - if yyb4362 { + if yyb4353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54363,13 +54281,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Status = ConditionStatus(r.DecodeString()) } - yyj4362++ - if yyhl4362 { - yyb4362 = yyj4362 > l + yyj4353++ + if yyhl4353 { + yyb4353 = yyj4353 > l } else { - yyb4362 = r.CheckBreak() + yyb4353 = r.CheckBreak() } - if yyb4362 { + if yyb4353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54379,13 +54297,13 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Message = string(r.DecodeString()) } - yyj4362++ - if yyhl4362 { - yyb4362 = yyj4362 > l + yyj4353++ + if yyhl4353 { + yyb4353 = yyj4353 > l } else { - yyb4362 = r.CheckBreak() + yyb4353 = r.CheckBreak() } - if yyb4362 { + if yyb4353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54396,17 +54314,17 @@ func (x *ComponentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decode x.Error = string(r.DecodeString()) } for { - yyj4362++ - if yyhl4362 { - yyb4362 = yyj4362 > l + yyj4353++ + if yyhl4353 { + yyb4353 = yyj4353 > l } else { - yyb4362 = r.CheckBreak() + yyb4353 = r.CheckBreak() } - if yyb4362 { + if yyb4353 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4362-1, "") + z.DecStructFieldNotFound(yyj4353-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54418,38 +54336,38 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4367 := z.EncBinary() - _ = yym4367 + yym4358 := z.EncBinary() + _ = yym4358 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4368 := !z.EncBinary() - yy2arr4368 := z.EncBasicHandle().StructToArray - var yyq4368 [4]bool - _, _, _ = yysep4368, yyq4368, yy2arr4368 - const yyr4368 bool = false - yyq4368[0] = x.Kind != "" - yyq4368[1] = x.APIVersion != "" - yyq4368[2] = true - yyq4368[3] = len(x.Conditions) != 0 - var yynn4368 int - if yyr4368 || yy2arr4368 { + yysep4359 := !z.EncBinary() + yy2arr4359 := z.EncBasicHandle().StructToArray + var yyq4359 [4]bool + _, _, _ = yysep4359, yyq4359, yy2arr4359 + const yyr4359 bool = false + yyq4359[0] = x.Kind != "" + yyq4359[1] = x.APIVersion != "" + yyq4359[2] = true + yyq4359[3] = len(x.Conditions) != 0 + var yynn4359 int + if yyr4359 || yy2arr4359 { r.EncodeArrayStart(4) } else { - yynn4368 = 0 - for _, b := range yyq4368 { + yynn4359 = 0 + for _, b := range yyq4359 { if b { - yynn4368++ + yynn4359++ } } - r.EncodeMapStart(yynn4368) - yynn4368 = 0 + r.EncodeMapStart(yynn4359) + yynn4359 = 0 } - if yyr4368 || yy2arr4368 { + if yyr4359 || yy2arr4359 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4368[0] { - yym4370 := z.EncBinary() - _ = yym4370 + if yyq4359[0] { + yym4361 := z.EncBinary() + _ = yym4361 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -54458,23 +54376,23 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4368[0] { + if yyq4359[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4371 := z.EncBinary() - _ = yym4371 + yym4362 := z.EncBinary() + _ = yym4362 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4368 || yy2arr4368 { + if yyr4359 || yy2arr4359 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4368[1] { - yym4373 := z.EncBinary() - _ = yym4373 + if yyq4359[1] { + yym4364 := z.EncBinary() + _ = yym4364 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -54483,43 +54401,43 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4368[1] { + if yyq4359[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4374 := z.EncBinary() - _ = yym4374 + yym4365 := z.EncBinary() + _ = yym4365 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4368 || yy2arr4368 { + if yyr4359 || yy2arr4359 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4368[2] { - yy4376 := &x.ObjectMeta - yy4376.CodecEncodeSelf(e) + if yyq4359[2] { + yy4367 := &x.ObjectMeta + yy4367.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4368[2] { + if yyq4359[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4377 := &x.ObjectMeta - yy4377.CodecEncodeSelf(e) + yy4368 := &x.ObjectMeta + yy4368.CodecEncodeSelf(e) } } - if yyr4368 || yy2arr4368 { + if yyr4359 || yy2arr4359 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4368[3] { + if yyq4359[3] { if x.Conditions == nil { r.EncodeNil() } else { - yym4379 := z.EncBinary() - _ = yym4379 + yym4370 := z.EncBinary() + _ = yym4370 if false { } else { h.encSliceComponentCondition(([]ComponentCondition)(x.Conditions), e) @@ -54529,15 +54447,15 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4368[3] { + if yyq4359[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym4380 := z.EncBinary() - _ = yym4380 + yym4371 := z.EncBinary() + _ = yym4371 if false { } else { h.encSliceComponentCondition(([]ComponentCondition)(x.Conditions), e) @@ -54545,7 +54463,7 @@ func (x *ComponentStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4368 || yy2arr4368 { + if yyr4359 || yy2arr4359 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54558,25 +54476,25 @@ func (x *ComponentStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4381 := z.DecBinary() - _ = yym4381 + yym4372 := z.DecBinary() + _ = yym4372 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4382 := r.ContainerType() - if yyct4382 == codecSelferValueTypeMap1234 { - yyl4382 := r.ReadMapStart() - if yyl4382 == 0 { + yyct4373 := r.ContainerType() + if yyct4373 == codecSelferValueTypeMap1234 { + yyl4373 := r.ReadMapStart() + if yyl4373 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4382, d) + x.codecDecodeSelfFromMap(yyl4373, d) } - } else if yyct4382 == codecSelferValueTypeArray1234 { - yyl4382 := r.ReadArrayStart() - if yyl4382 == 0 { + } else if yyct4373 == codecSelferValueTypeArray1234 { + yyl4373 := r.ReadArrayStart() + if yyl4373 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4382, d) + x.codecDecodeSelfFromArray(yyl4373, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54588,12 +54506,12 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4383Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4383Slc - var yyhl4383 bool = l >= 0 - for yyj4383 := 0; ; yyj4383++ { - if yyhl4383 { - if yyj4383 >= l { + var yys4374Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4374Slc + var yyhl4374 bool = l >= 0 + for yyj4374 := 0; ; yyj4374++ { + if yyhl4374 { + if yyj4374 >= l { break } } else { @@ -54602,10 +54520,10 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4383Slc = r.DecodeBytes(yys4383Slc, true, true) - yys4383 := string(yys4383Slc) + yys4374Slc = r.DecodeBytes(yys4374Slc, true, true) + yys4374 := string(yys4374Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4383 { + switch yys4374 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -54622,25 +54540,25 @@ func (x *ComponentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4386 := &x.ObjectMeta - yyv4386.CodecDecodeSelf(d) + yyv4377 := &x.ObjectMeta + yyv4377.CodecDecodeSelf(d) } case "conditions": if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv4387 := &x.Conditions - yym4388 := z.DecBinary() - _ = yym4388 + yyv4378 := &x.Conditions + yym4379 := z.DecBinary() + _ = yym4379 if false { } else { - h.decSliceComponentCondition((*[]ComponentCondition)(yyv4387), d) + h.decSliceComponentCondition((*[]ComponentCondition)(yyv4378), d) } } default: - z.DecStructFieldNotFound(-1, yys4383) - } // end switch yys4383 - } // end for yyj4383 + z.DecStructFieldNotFound(-1, yys4374) + } // end switch yys4374 + } // end for yyj4374 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54648,16 +54566,16 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4389 int - var yyb4389 bool - var yyhl4389 bool = l >= 0 - yyj4389++ - if yyhl4389 { - yyb4389 = yyj4389 > l + var yyj4380 int + var yyb4380 bool + var yyhl4380 bool = l >= 0 + yyj4380++ + if yyhl4380 { + yyb4380 = yyj4380 > l } else { - yyb4389 = r.CheckBreak() + yyb4380 = r.CheckBreak() } - if yyb4389 { + if yyb4380 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54667,13 +54585,13 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj4389++ - if yyhl4389 { - yyb4389 = yyj4389 > l + yyj4380++ + if yyhl4380 { + yyb4380 = yyj4380 > l } else { - yyb4389 = r.CheckBreak() + yyb4380 = r.CheckBreak() } - if yyb4389 { + if yyb4380 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54683,13 +54601,13 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj4389++ - if yyhl4389 { - yyb4389 = yyj4389 > l + yyj4380++ + if yyhl4380 { + yyb4380 = yyj4380 > l } else { - yyb4389 = r.CheckBreak() + yyb4380 = r.CheckBreak() } - if yyb4389 { + if yyb4380 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54697,16 +54615,16 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4392 := &x.ObjectMeta - yyv4392.CodecDecodeSelf(d) + yyv4383 := &x.ObjectMeta + yyv4383.CodecDecodeSelf(d) } - yyj4389++ - if yyhl4389 { - yyb4389 = yyj4389 > l + yyj4380++ + if yyhl4380 { + yyb4380 = yyj4380 > l } else { - yyb4389 = r.CheckBreak() + yyb4380 = r.CheckBreak() } - if yyb4389 { + if yyb4380 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -54714,26 +54632,26 @@ func (x *ComponentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv4393 := &x.Conditions - yym4394 := z.DecBinary() - _ = yym4394 + yyv4384 := &x.Conditions + yym4385 := z.DecBinary() + _ = yym4385 if false { } else { - h.decSliceComponentCondition((*[]ComponentCondition)(yyv4393), d) + h.decSliceComponentCondition((*[]ComponentCondition)(yyv4384), d) } } for { - yyj4389++ - if yyhl4389 { - yyb4389 = yyj4389 > l + yyj4380++ + if yyhl4380 { + yyb4380 = yyj4380 > l } else { - yyb4389 = r.CheckBreak() + yyb4380 = r.CheckBreak() } - if yyb4389 { + if yyb4380 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4389-1, "") + z.DecStructFieldNotFound(yyj4380-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -54745,37 +54663,37 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4395 := z.EncBinary() - _ = yym4395 + yym4386 := z.EncBinary() + _ = yym4386 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4396 := !z.EncBinary() - yy2arr4396 := z.EncBasicHandle().StructToArray - var yyq4396 [4]bool - _, _, _ = yysep4396, yyq4396, yy2arr4396 - const yyr4396 bool = false - yyq4396[0] = x.Kind != "" - yyq4396[1] = x.APIVersion != "" - yyq4396[2] = true - var yynn4396 int - if yyr4396 || yy2arr4396 { + yysep4387 := !z.EncBinary() + yy2arr4387 := z.EncBasicHandle().StructToArray + var yyq4387 [4]bool + _, _, _ = yysep4387, yyq4387, yy2arr4387 + const yyr4387 bool = false + yyq4387[0] = x.Kind != "" + yyq4387[1] = x.APIVersion != "" + yyq4387[2] = true + var yynn4387 int + if yyr4387 || yy2arr4387 { r.EncodeArrayStart(4) } else { - yynn4396 = 1 - for _, b := range yyq4396 { + yynn4387 = 1 + for _, b := range yyq4387 { if b { - yynn4396++ + yynn4387++ } } - r.EncodeMapStart(yynn4396) - yynn4396 = 0 + r.EncodeMapStart(yynn4387) + yynn4387 = 0 } - if yyr4396 || yy2arr4396 { + if yyr4387 || yy2arr4387 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4396[0] { - yym4398 := z.EncBinary() - _ = yym4398 + if yyq4387[0] { + yym4389 := z.EncBinary() + _ = yym4389 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -54784,23 +54702,23 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4396[0] { + if yyq4387[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4399 := z.EncBinary() - _ = yym4399 + yym4390 := z.EncBinary() + _ = yym4390 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4396 || yy2arr4396 { + if yyr4387 || yy2arr4387 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4396[1] { - yym4401 := z.EncBinary() - _ = yym4401 + if yyq4387[1] { + yym4392 := z.EncBinary() + _ = yym4392 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -54809,54 +54727,54 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4396[1] { + if yyq4387[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4402 := z.EncBinary() - _ = yym4402 + yym4393 := z.EncBinary() + _ = yym4393 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4396 || yy2arr4396 { + if yyr4387 || yy2arr4387 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4396[2] { - yy4404 := &x.ListMeta - yym4405 := z.EncBinary() - _ = yym4405 + if yyq4387[2] { + yy4395 := &x.ListMeta + yym4396 := z.EncBinary() + _ = yym4396 if false { - } else if z.HasExtensions() && z.EncExt(yy4404) { + } else if z.HasExtensions() && z.EncExt(yy4395) { } else { - z.EncFallback(yy4404) + z.EncFallback(yy4395) } } else { r.EncodeNil() } } else { - if yyq4396[2] { + if yyq4387[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4406 := &x.ListMeta - yym4407 := z.EncBinary() - _ = yym4407 + yy4397 := &x.ListMeta + yym4398 := z.EncBinary() + _ = yym4398 if false { - } else if z.HasExtensions() && z.EncExt(yy4406) { + } else if z.HasExtensions() && z.EncExt(yy4397) { } else { - z.EncFallback(yy4406) + z.EncFallback(yy4397) } } } - if yyr4396 || yy2arr4396 { + if yyr4387 || yy2arr4387 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym4409 := z.EncBinary() - _ = yym4409 + yym4400 := z.EncBinary() + _ = yym4400 if false { } else { h.encSliceComponentStatus(([]ComponentStatus)(x.Items), e) @@ -54869,15 +54787,15 @@ func (x *ComponentStatusList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym4410 := z.EncBinary() - _ = yym4410 + yym4401 := z.EncBinary() + _ = yym4401 if false { } else { h.encSliceComponentStatus(([]ComponentStatus)(x.Items), e) } } } - if yyr4396 || yy2arr4396 { + if yyr4387 || yy2arr4387 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -54890,25 +54808,25 @@ func (x *ComponentStatusList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4411 := z.DecBinary() - _ = yym4411 + yym4402 := z.DecBinary() + _ = yym4402 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4412 := r.ContainerType() - if yyct4412 == codecSelferValueTypeMap1234 { - yyl4412 := r.ReadMapStart() - if yyl4412 == 0 { + yyct4403 := r.ContainerType() + if yyct4403 == codecSelferValueTypeMap1234 { + yyl4403 := r.ReadMapStart() + if yyl4403 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4412, d) + x.codecDecodeSelfFromMap(yyl4403, d) } - } else if yyct4412 == codecSelferValueTypeArray1234 { - yyl4412 := r.ReadArrayStart() - if yyl4412 == 0 { + } else if yyct4403 == codecSelferValueTypeArray1234 { + yyl4403 := r.ReadArrayStart() + if yyl4403 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4412, d) + x.codecDecodeSelfFromArray(yyl4403, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -54920,12 +54838,12 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4413Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4413Slc - var yyhl4413 bool = l >= 0 - for yyj4413 := 0; ; yyj4413++ { - if yyhl4413 { - if yyj4413 >= l { + var yys4404Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4404Slc + var yyhl4404 bool = l >= 0 + for yyj4404 := 0; ; yyj4404++ { + if yyhl4404 { + if yyj4404 >= l { break } } else { @@ -54934,10 +54852,10 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4413Slc = r.DecodeBytes(yys4413Slc, true, true) - yys4413 := string(yys4413Slc) + yys4404Slc = r.DecodeBytes(yys4404Slc, true, true) + yys4404 := string(yys4404Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4413 { + switch yys4404 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -54954,31 +54872,31 @@ func (x *ComponentStatusList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4416 := &x.ListMeta - yym4417 := z.DecBinary() - _ = yym4417 + yyv4407 := &x.ListMeta + yym4408 := z.DecBinary() + _ = yym4408 if false { - } else if z.HasExtensions() && z.DecExt(yyv4416) { + } else if z.HasExtensions() && z.DecExt(yyv4407) { } else { - z.DecFallback(yyv4416, false) + z.DecFallback(yyv4407, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4418 := &x.Items - yym4419 := z.DecBinary() - _ = yym4419 + yyv4409 := &x.Items + yym4410 := z.DecBinary() + _ = yym4410 if false { } else { - h.decSliceComponentStatus((*[]ComponentStatus)(yyv4418), d) + h.decSliceComponentStatus((*[]ComponentStatus)(yyv4409), d) } } default: - z.DecStructFieldNotFound(-1, yys4413) - } // end switch yys4413 - } // end for yyj4413 + z.DecStructFieldNotFound(-1, yys4404) + } // end switch yys4404 + } // end for yyj4404 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -54986,16 +54904,16 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4420 int - var yyb4420 bool - var yyhl4420 bool = l >= 0 - yyj4420++ - if yyhl4420 { - yyb4420 = yyj4420 > l + var yyj4411 int + var yyb4411 bool + var yyhl4411 bool = l >= 0 + yyj4411++ + if yyhl4411 { + yyb4411 = yyj4411 > l } else { - yyb4420 = r.CheckBreak() + yyb4411 = r.CheckBreak() } - if yyb4420 { + if yyb4411 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55005,13 +54923,13 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Kind = string(r.DecodeString()) } - yyj4420++ - if yyhl4420 { - yyb4420 = yyj4420 > l + yyj4411++ + if yyhl4411 { + yyb4411 = yyj4411 > l } else { - yyb4420 = r.CheckBreak() + yyb4411 = r.CheckBreak() } - if yyb4420 { + if yyb4411 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55021,13 +54939,13 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.APIVersion = string(r.DecodeString()) } - yyj4420++ - if yyhl4420 { - yyb4420 = yyj4420 > l + yyj4411++ + if yyhl4411 { + yyb4411 = yyj4411 > l } else { - yyb4420 = r.CheckBreak() + yyb4411 = r.CheckBreak() } - if yyb4420 { + if yyb4411 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55035,22 +54953,22 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ListMeta = pkg2_unversioned.ListMeta{} } else { - yyv4423 := &x.ListMeta - yym4424 := z.DecBinary() - _ = yym4424 + yyv4414 := &x.ListMeta + yym4415 := z.DecBinary() + _ = yym4415 if false { - } else if z.HasExtensions() && z.DecExt(yyv4423) { + } else if z.HasExtensions() && z.DecExt(yyv4414) { } else { - z.DecFallback(yyv4423, false) + z.DecFallback(yyv4414, false) } } - yyj4420++ - if yyhl4420 { - yyb4420 = yyj4420 > l + yyj4411++ + if yyhl4411 { + yyb4411 = yyj4411 > l } else { - yyb4420 = r.CheckBreak() + yyb4411 = r.CheckBreak() } - if yyb4420 { + if yyb4411 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55058,26 +54976,26 @@ func (x *ComponentStatusList) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4425 := &x.Items - yym4426 := z.DecBinary() - _ = yym4426 + yyv4416 := &x.Items + yym4417 := z.DecBinary() + _ = yym4417 if false { } else { - h.decSliceComponentStatus((*[]ComponentStatus)(yyv4425), d) + h.decSliceComponentStatus((*[]ComponentStatus)(yyv4416), d) } } for { - yyj4420++ - if yyhl4420 { - yyb4420 = yyj4420 > l + yyj4411++ + if yyhl4411 { + yyb4411 = yyj4411 > l } else { - yyb4420 = r.CheckBreak() + yyb4411 = r.CheckBreak() } - if yyb4420 { + if yyb4411 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4420-1, "") + z.DecStructFieldNotFound(yyj4411-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -55089,39 +55007,39 @@ func (x *DownwardAPIVolumeSource) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4427 := z.EncBinary() - _ = yym4427 + yym4418 := z.EncBinary() + _ = yym4418 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4428 := !z.EncBinary() - yy2arr4428 := z.EncBasicHandle().StructToArray - var yyq4428 [2]bool - _, _, _ = yysep4428, yyq4428, yy2arr4428 - const yyr4428 bool = false - yyq4428[0] = len(x.Items) != 0 - yyq4428[1] = x.DefaultMode != nil - var yynn4428 int - if yyr4428 || yy2arr4428 { + yysep4419 := !z.EncBinary() + yy2arr4419 := z.EncBasicHandle().StructToArray + var yyq4419 [2]bool + _, _, _ = yysep4419, yyq4419, yy2arr4419 + const yyr4419 bool = false + yyq4419[0] = len(x.Items) != 0 + yyq4419[1] = x.DefaultMode != nil + var yynn4419 int + if yyr4419 || yy2arr4419 { r.EncodeArrayStart(2) } else { - yynn4428 = 0 - for _, b := range yyq4428 { + yynn4419 = 0 + for _, b := range yyq4419 { if b { - yynn4428++ + yynn4419++ } } - r.EncodeMapStart(yynn4428) - yynn4428 = 0 + r.EncodeMapStart(yynn4419) + yynn4419 = 0 } - if yyr4428 || yy2arr4428 { + if yyr4419 || yy2arr4419 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4428[0] { + if yyq4419[0] { if x.Items == nil { r.EncodeNil() } else { - yym4430 := z.EncBinary() - _ = yym4430 + yym4421 := z.EncBinary() + _ = yym4421 if false { } else { h.encSliceDownwardAPIVolumeFile(([]DownwardAPIVolumeFile)(x.Items), e) @@ -55131,15 +55049,15 @@ func (x *DownwardAPIVolumeSource) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4428[0] { + if yyq4419[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("items")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Items == nil { r.EncodeNil() } else { - yym4431 := z.EncBinary() - _ = yym4431 + yym4422 := z.EncBinary() + _ = yym4422 if false { } else { h.encSliceDownwardAPIVolumeFile(([]DownwardAPIVolumeFile)(x.Items), e) @@ -55147,42 +55065,42 @@ func (x *DownwardAPIVolumeSource) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4428 || yy2arr4428 { + if yyr4419 || yy2arr4419 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4428[1] { + if yyq4419[1] { if x.DefaultMode == nil { r.EncodeNil() } else { - yy4433 := *x.DefaultMode - yym4434 := z.EncBinary() - _ = yym4434 + yy4424 := *x.DefaultMode + yym4425 := z.EncBinary() + _ = yym4425 if false { } else { - r.EncodeInt(int64(yy4433)) + r.EncodeInt(int64(yy4424)) } } } else { r.EncodeNil() } } else { - if yyq4428[1] { + if yyq4419[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("defaultMode")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.DefaultMode == nil { r.EncodeNil() } else { - yy4435 := *x.DefaultMode - yym4436 := z.EncBinary() - _ = yym4436 + yy4426 := *x.DefaultMode + yym4427 := z.EncBinary() + _ = yym4427 if false { } else { - r.EncodeInt(int64(yy4435)) + r.EncodeInt(int64(yy4426)) } } } } - if yyr4428 || yy2arr4428 { + if yyr4419 || yy2arr4419 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55195,25 +55113,25 @@ func (x *DownwardAPIVolumeSource) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4437 := z.DecBinary() - _ = yym4437 + yym4428 := z.DecBinary() + _ = yym4428 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4438 := r.ContainerType() - if yyct4438 == codecSelferValueTypeMap1234 { - yyl4438 := r.ReadMapStart() - if yyl4438 == 0 { + yyct4429 := r.ContainerType() + if yyct4429 == codecSelferValueTypeMap1234 { + yyl4429 := r.ReadMapStart() + if yyl4429 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4438, d) + x.codecDecodeSelfFromMap(yyl4429, d) } - } else if yyct4438 == codecSelferValueTypeArray1234 { - yyl4438 := r.ReadArrayStart() - if yyl4438 == 0 { + } else if yyct4429 == codecSelferValueTypeArray1234 { + yyl4429 := r.ReadArrayStart() + if yyl4429 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4438, d) + x.codecDecodeSelfFromArray(yyl4429, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55225,12 +55143,12 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromMap(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4439Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4439Slc - var yyhl4439 bool = l >= 0 - for yyj4439 := 0; ; yyj4439++ { - if yyhl4439 { - if yyj4439 >= l { + var yys4430Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4430Slc + var yyhl4430 bool = l >= 0 + for yyj4430 := 0; ; yyj4430++ { + if yyhl4430 { + if yyj4430 >= l { break } } else { @@ -55239,20 +55157,20 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromMap(l int, d *codec1978.Dec } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4439Slc = r.DecodeBytes(yys4439Slc, true, true) - yys4439 := string(yys4439Slc) + yys4430Slc = r.DecodeBytes(yys4430Slc, true, true) + yys4430 := string(yys4430Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4439 { + switch yys4430 { case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4440 := &x.Items - yym4441 := z.DecBinary() - _ = yym4441 + yyv4431 := &x.Items + yym4432 := z.DecBinary() + _ = yym4432 if false { } else { - h.decSliceDownwardAPIVolumeFile((*[]DownwardAPIVolumeFile)(yyv4440), d) + h.decSliceDownwardAPIVolumeFile((*[]DownwardAPIVolumeFile)(yyv4431), d) } } case "defaultMode": @@ -55264,17 +55182,17 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromMap(l int, d *codec1978.Dec if x.DefaultMode == nil { x.DefaultMode = new(int32) } - yym4443 := z.DecBinary() - _ = yym4443 + yym4434 := z.DecBinary() + _ = yym4434 if false { } else { *((*int32)(x.DefaultMode)) = int32(r.DecodeInt(32)) } } default: - z.DecStructFieldNotFound(-1, yys4439) - } // end switch yys4439 - } // end for yyj4439 + z.DecStructFieldNotFound(-1, yys4430) + } // end switch yys4430 + } // end for yyj4430 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -55282,16 +55200,16 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromArray(l int, d *codec1978.D var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4444 int - var yyb4444 bool - var yyhl4444 bool = l >= 0 - yyj4444++ - if yyhl4444 { - yyb4444 = yyj4444 > l + var yyj4435 int + var yyb4435 bool + var yyhl4435 bool = l >= 0 + yyj4435++ + if yyhl4435 { + yyb4435 = yyj4435 > l } else { - yyb4444 = r.CheckBreak() + yyb4435 = r.CheckBreak() } - if yyb4444 { + if yyb4435 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55299,21 +55217,21 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromArray(l int, d *codec1978.D if r.TryDecodeAsNil() { x.Items = nil } else { - yyv4445 := &x.Items - yym4446 := z.DecBinary() - _ = yym4446 + yyv4436 := &x.Items + yym4437 := z.DecBinary() + _ = yym4437 if false { } else { - h.decSliceDownwardAPIVolumeFile((*[]DownwardAPIVolumeFile)(yyv4445), d) + h.decSliceDownwardAPIVolumeFile((*[]DownwardAPIVolumeFile)(yyv4436), d) } } - yyj4444++ - if yyhl4444 { - yyb4444 = yyj4444 > l + yyj4435++ + if yyhl4435 { + yyb4435 = yyj4435 > l } else { - yyb4444 = r.CheckBreak() + yyb4435 = r.CheckBreak() } - if yyb4444 { + if yyb4435 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55326,25 +55244,25 @@ func (x *DownwardAPIVolumeSource) codecDecodeSelfFromArray(l int, d *codec1978.D if x.DefaultMode == nil { x.DefaultMode = new(int32) } - yym4448 := z.DecBinary() - _ = yym4448 + yym4439 := z.DecBinary() + _ = yym4439 if false { } else { *((*int32)(x.DefaultMode)) = int32(r.DecodeInt(32)) } } for { - yyj4444++ - if yyhl4444 { - yyb4444 = yyj4444 > l + yyj4435++ + if yyhl4435 { + yyb4435 = yyj4435 > l } else { - yyb4444 = r.CheckBreak() + yyb4435 = r.CheckBreak() } - if yyb4444 { + if yyb4435 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4444-1, "") + z.DecStructFieldNotFound(yyj4435-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -55356,36 +55274,36 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4449 := z.EncBinary() - _ = yym4449 + yym4440 := z.EncBinary() + _ = yym4440 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4450 := !z.EncBinary() - yy2arr4450 := z.EncBasicHandle().StructToArray - var yyq4450 [4]bool - _, _, _ = yysep4450, yyq4450, yy2arr4450 - const yyr4450 bool = false - yyq4450[1] = x.FieldRef != nil - yyq4450[2] = x.ResourceFieldRef != nil - yyq4450[3] = x.Mode != nil - var yynn4450 int - if yyr4450 || yy2arr4450 { + yysep4441 := !z.EncBinary() + yy2arr4441 := z.EncBasicHandle().StructToArray + var yyq4441 [4]bool + _, _, _ = yysep4441, yyq4441, yy2arr4441 + const yyr4441 bool = false + yyq4441[1] = x.FieldRef != nil + yyq4441[2] = x.ResourceFieldRef != nil + yyq4441[3] = x.Mode != nil + var yynn4441 int + if yyr4441 || yy2arr4441 { r.EncodeArrayStart(4) } else { - yynn4450 = 1 - for _, b := range yyq4450 { + yynn4441 = 1 + for _, b := range yyq4441 { if b { - yynn4450++ + yynn4441++ } } - r.EncodeMapStart(yynn4450) - yynn4450 = 0 + r.EncodeMapStart(yynn4441) + yynn4441 = 0 } - if yyr4450 || yy2arr4450 { + if yyr4441 || yy2arr4441 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym4452 := z.EncBinary() - _ = yym4452 + yym4443 := z.EncBinary() + _ = yym4443 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -55394,16 +55312,16 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4453 := z.EncBinary() - _ = yym4453 + yym4444 := z.EncBinary() + _ = yym4444 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } - if yyr4450 || yy2arr4450 { + if yyr4441 || yy2arr4441 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4450[1] { + if yyq4441[1] { if x.FieldRef == nil { r.EncodeNil() } else { @@ -55413,7 +55331,7 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4450[1] { + if yyq4441[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("fieldRef")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55424,9 +55342,9 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4450 || yy2arr4450 { + if yyr4441 || yy2arr4441 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4450[2] { + if yyq4441[2] { if x.ResourceFieldRef == nil { r.EncodeNil() } else { @@ -55436,7 +55354,7 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4450[2] { + if yyq4441[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("resourceFieldRef")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55447,42 +55365,42 @@ func (x *DownwardAPIVolumeFile) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4450 || yy2arr4450 { + if yyr4441 || yy2arr4441 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4450[3] { + if yyq4441[3] { if x.Mode == nil { r.EncodeNil() } else { - yy4457 := *x.Mode - yym4458 := z.EncBinary() - _ = yym4458 + yy4448 := *x.Mode + yym4449 := z.EncBinary() + _ = yym4449 if false { } else { - r.EncodeInt(int64(yy4457)) + r.EncodeInt(int64(yy4448)) } } } else { r.EncodeNil() } } else { - if yyq4450[3] { + if yyq4441[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("mode")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Mode == nil { r.EncodeNil() } else { - yy4459 := *x.Mode - yym4460 := z.EncBinary() - _ = yym4460 + yy4450 := *x.Mode + yym4451 := z.EncBinary() + _ = yym4451 if false { } else { - r.EncodeInt(int64(yy4459)) + r.EncodeInt(int64(yy4450)) } } } } - if yyr4450 || yy2arr4450 { + if yyr4441 || yy2arr4441 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55495,25 +55413,25 @@ func (x *DownwardAPIVolumeFile) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4461 := z.DecBinary() - _ = yym4461 + yym4452 := z.DecBinary() + _ = yym4452 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4462 := r.ContainerType() - if yyct4462 == codecSelferValueTypeMap1234 { - yyl4462 := r.ReadMapStart() - if yyl4462 == 0 { + yyct4453 := r.ContainerType() + if yyct4453 == codecSelferValueTypeMap1234 { + yyl4453 := r.ReadMapStart() + if yyl4453 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4462, d) + x.codecDecodeSelfFromMap(yyl4453, d) } - } else if yyct4462 == codecSelferValueTypeArray1234 { - yyl4462 := r.ReadArrayStart() - if yyl4462 == 0 { + } else if yyct4453 == codecSelferValueTypeArray1234 { + yyl4453 := r.ReadArrayStart() + if yyl4453 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4462, d) + x.codecDecodeSelfFromArray(yyl4453, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55525,12 +55443,12 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4463Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4463Slc - var yyhl4463 bool = l >= 0 - for yyj4463 := 0; ; yyj4463++ { - if yyhl4463 { - if yyj4463 >= l { + var yys4454Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4454Slc + var yyhl4454 bool = l >= 0 + for yyj4454 := 0; ; yyj4454++ { + if yyhl4454 { + if yyj4454 >= l { break } } else { @@ -55539,10 +55457,10 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4463Slc = r.DecodeBytes(yys4463Slc, true, true) - yys4463 := string(yys4463Slc) + yys4454Slc = r.DecodeBytes(yys4454Slc, true, true) + yys4454 := string(yys4454Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4463 { + switch yys4454 { case "path": if r.TryDecodeAsNil() { x.Path = "" @@ -55580,17 +55498,17 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromMap(l int, d *codec1978.Decod if x.Mode == nil { x.Mode = new(int32) } - yym4468 := z.DecBinary() - _ = yym4468 + yym4459 := z.DecBinary() + _ = yym4459 if false { } else { *((*int32)(x.Mode)) = int32(r.DecodeInt(32)) } } default: - z.DecStructFieldNotFound(-1, yys4463) - } // end switch yys4463 - } // end for yyj4463 + z.DecStructFieldNotFound(-1, yys4454) + } // end switch yys4454 + } // end for yyj4454 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -55598,16 +55516,16 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4469 int - var yyb4469 bool - var yyhl4469 bool = l >= 0 - yyj4469++ - if yyhl4469 { - yyb4469 = yyj4469 > l + var yyj4460 int + var yyb4460 bool + var yyhl4460 bool = l >= 0 + yyj4460++ + if yyhl4460 { + yyb4460 = yyj4460 > l } else { - yyb4469 = r.CheckBreak() + yyb4460 = r.CheckBreak() } - if yyb4469 { + if yyb4460 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55617,13 +55535,13 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Path = string(r.DecodeString()) } - yyj4469++ - if yyhl4469 { - yyb4469 = yyj4469 > l + yyj4460++ + if yyhl4460 { + yyb4460 = yyj4460 > l } else { - yyb4469 = r.CheckBreak() + yyb4460 = r.CheckBreak() } - if yyb4469 { + if yyb4460 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55638,13 +55556,13 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromArray(l int, d *codec1978.Dec } x.FieldRef.CodecDecodeSelf(d) } - yyj4469++ - if yyhl4469 { - yyb4469 = yyj4469 > l + yyj4460++ + if yyhl4460 { + yyb4460 = yyj4460 > l } else { - yyb4469 = r.CheckBreak() + yyb4460 = r.CheckBreak() } - if yyb4469 { + if yyb4460 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55659,13 +55577,13 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromArray(l int, d *codec1978.Dec } x.ResourceFieldRef.CodecDecodeSelf(d) } - yyj4469++ - if yyhl4469 { - yyb4469 = yyj4469 > l + yyj4460++ + if yyhl4460 { + yyb4460 = yyj4460 > l } else { - yyb4469 = r.CheckBreak() + yyb4460 = r.CheckBreak() } - if yyb4469 { + if yyb4460 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -55678,25 +55596,25 @@ func (x *DownwardAPIVolumeFile) codecDecodeSelfFromArray(l int, d *codec1978.Dec if x.Mode == nil { x.Mode = new(int32) } - yym4474 := z.DecBinary() - _ = yym4474 + yym4465 := z.DecBinary() + _ = yym4465 if false { } else { *((*int32)(x.Mode)) = int32(r.DecodeInt(32)) } } for { - yyj4469++ - if yyhl4469 { - yyb4469 = yyj4469 > l + yyj4460++ + if yyhl4460 { + yyb4460 = yyj4460 > l } else { - yyb4469 = r.CheckBreak() + yyb4460 = r.CheckBreak() } - if yyb4469 { + if yyb4460 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4469-1, "") + z.DecStructFieldNotFound(yyj4460-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -55708,38 +55626,38 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4475 := z.EncBinary() - _ = yym4475 + yym4466 := z.EncBinary() + _ = yym4466 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4476 := !z.EncBinary() - yy2arr4476 := z.EncBasicHandle().StructToArray - var yyq4476 [6]bool - _, _, _ = yysep4476, yyq4476, yy2arr4476 - const yyr4476 bool = false - yyq4476[0] = x.Capabilities != nil - yyq4476[1] = x.Privileged != nil - yyq4476[2] = x.SELinuxOptions != nil - yyq4476[3] = x.RunAsUser != nil - yyq4476[4] = x.RunAsNonRoot != nil - yyq4476[5] = x.ReadOnlyRootFilesystem != nil - var yynn4476 int - if yyr4476 || yy2arr4476 { + yysep4467 := !z.EncBinary() + yy2arr4467 := z.EncBasicHandle().StructToArray + var yyq4467 [6]bool + _, _, _ = yysep4467, yyq4467, yy2arr4467 + const yyr4467 bool = false + yyq4467[0] = x.Capabilities != nil + yyq4467[1] = x.Privileged != nil + yyq4467[2] = x.SELinuxOptions != nil + yyq4467[3] = x.RunAsUser != nil + yyq4467[4] = x.RunAsNonRoot != nil + yyq4467[5] = x.ReadOnlyRootFilesystem != nil + var yynn4467 int + if yyr4467 || yy2arr4467 { r.EncodeArrayStart(6) } else { - yynn4476 = 0 - for _, b := range yyq4476 { + yynn4467 = 0 + for _, b := range yyq4467 { if b { - yynn4476++ + yynn4467++ } } - r.EncodeMapStart(yynn4476) - yynn4476 = 0 + r.EncodeMapStart(yynn4467) + yynn4467 = 0 } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[0] { + if yyq4467[0] { if x.Capabilities == nil { r.EncodeNil() } else { @@ -55749,7 +55667,7 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4476[0] { + if yyq4467[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("capabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55760,44 +55678,44 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[1] { + if yyq4467[1] { if x.Privileged == nil { r.EncodeNil() } else { - yy4479 := *x.Privileged - yym4480 := z.EncBinary() - _ = yym4480 + yy4470 := *x.Privileged + yym4471 := z.EncBinary() + _ = yym4471 if false { } else { - r.EncodeBool(bool(yy4479)) + r.EncodeBool(bool(yy4470)) } } } else { r.EncodeNil() } } else { - if yyq4476[1] { + if yyq4467[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("privileged")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Privileged == nil { r.EncodeNil() } else { - yy4481 := *x.Privileged - yym4482 := z.EncBinary() - _ = yym4482 + yy4472 := *x.Privileged + yym4473 := z.EncBinary() + _ = yym4473 if false { } else { - r.EncodeBool(bool(yy4481)) + r.EncodeBool(bool(yy4472)) } } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[2] { + if yyq4467[2] { if x.SELinuxOptions == nil { r.EncodeNil() } else { @@ -55807,7 +55725,7 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq4476[2] { + if yyq4467[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinuxOptions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -55818,112 +55736,112 @@ func (x *SecurityContext) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[3] { + if yyq4467[3] { if x.RunAsUser == nil { r.EncodeNil() } else { - yy4485 := *x.RunAsUser - yym4486 := z.EncBinary() - _ = yym4486 + yy4476 := *x.RunAsUser + yym4477 := z.EncBinary() + _ = yym4477 if false { } else { - r.EncodeInt(int64(yy4485)) + r.EncodeInt(int64(yy4476)) } } } else { r.EncodeNil() } } else { - if yyq4476[3] { + if yyq4467[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsUser")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RunAsUser == nil { r.EncodeNil() } else { - yy4487 := *x.RunAsUser - yym4488 := z.EncBinary() - _ = yym4488 + yy4478 := *x.RunAsUser + yym4479 := z.EncBinary() + _ = yym4479 if false { } else { - r.EncodeInt(int64(yy4487)) + r.EncodeInt(int64(yy4478)) } } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[4] { + if yyq4467[4] { if x.RunAsNonRoot == nil { r.EncodeNil() } else { - yy4490 := *x.RunAsNonRoot - yym4491 := z.EncBinary() - _ = yym4491 + yy4481 := *x.RunAsNonRoot + yym4482 := z.EncBinary() + _ = yym4482 if false { } else { - r.EncodeBool(bool(yy4490)) + r.EncodeBool(bool(yy4481)) } } } else { r.EncodeNil() } } else { - if yyq4476[4] { + if yyq4467[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsNonRoot")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RunAsNonRoot == nil { r.EncodeNil() } else { - yy4492 := *x.RunAsNonRoot - yym4493 := z.EncBinary() - _ = yym4493 + yy4483 := *x.RunAsNonRoot + yym4484 := z.EncBinary() + _ = yym4484 if false { } else { - r.EncodeBool(bool(yy4492)) + r.EncodeBool(bool(yy4483)) } } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4476[5] { + if yyq4467[5] { if x.ReadOnlyRootFilesystem == nil { r.EncodeNil() } else { - yy4495 := *x.ReadOnlyRootFilesystem - yym4496 := z.EncBinary() - _ = yym4496 + yy4486 := *x.ReadOnlyRootFilesystem + yym4487 := z.EncBinary() + _ = yym4487 if false { } else { - r.EncodeBool(bool(yy4495)) + r.EncodeBool(bool(yy4486)) } } } else { r.EncodeNil() } } else { - if yyq4476[5] { + if yyq4467[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readOnlyRootFilesystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ReadOnlyRootFilesystem == nil { r.EncodeNil() } else { - yy4497 := *x.ReadOnlyRootFilesystem - yym4498 := z.EncBinary() - _ = yym4498 + yy4488 := *x.ReadOnlyRootFilesystem + yym4489 := z.EncBinary() + _ = yym4489 if false { } else { - r.EncodeBool(bool(yy4497)) + r.EncodeBool(bool(yy4488)) } } } } - if yyr4476 || yy2arr4476 { + if yyr4467 || yy2arr4467 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -55936,25 +55854,25 @@ func (x *SecurityContext) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4499 := z.DecBinary() - _ = yym4499 + yym4490 := z.DecBinary() + _ = yym4490 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4500 := r.ContainerType() - if yyct4500 == codecSelferValueTypeMap1234 { - yyl4500 := r.ReadMapStart() - if yyl4500 == 0 { + yyct4491 := r.ContainerType() + if yyct4491 == codecSelferValueTypeMap1234 { + yyl4491 := r.ReadMapStart() + if yyl4491 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4500, d) + x.codecDecodeSelfFromMap(yyl4491, d) } - } else if yyct4500 == codecSelferValueTypeArray1234 { - yyl4500 := r.ReadArrayStart() - if yyl4500 == 0 { + } else if yyct4491 == codecSelferValueTypeArray1234 { + yyl4491 := r.ReadArrayStart() + if yyl4491 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4500, d) + x.codecDecodeSelfFromArray(yyl4491, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -55966,12 +55884,12 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4501Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4501Slc - var yyhl4501 bool = l >= 0 - for yyj4501 := 0; ; yyj4501++ { - if yyhl4501 { - if yyj4501 >= l { + var yys4492Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4492Slc + var yyhl4492 bool = l >= 0 + for yyj4492 := 0; ; yyj4492++ { + if yyhl4492 { + if yyj4492 >= l { break } } else { @@ -55980,10 +55898,10 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4501Slc = r.DecodeBytes(yys4501Slc, true, true) - yys4501 := string(yys4501Slc) + yys4492Slc = r.DecodeBytes(yys4492Slc, true, true) + yys4492 := string(yys4492Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4501 { + switch yys4492 { case "capabilities": if r.TryDecodeAsNil() { if x.Capabilities != nil { @@ -56004,8 +55922,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Privileged == nil { x.Privileged = new(bool) } - yym4504 := z.DecBinary() - _ = yym4504 + yym4495 := z.DecBinary() + _ = yym4495 if false { } else { *((*bool)(x.Privileged)) = r.DecodeBool() @@ -56031,8 +55949,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RunAsUser == nil { x.RunAsUser = new(int64) } - yym4507 := z.DecBinary() - _ = yym4507 + yym4498 := z.DecBinary() + _ = yym4498 if false { } else { *((*int64)(x.RunAsUser)) = int64(r.DecodeInt(64)) @@ -56047,8 +55965,8 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RunAsNonRoot == nil { x.RunAsNonRoot = new(bool) } - yym4509 := z.DecBinary() - _ = yym4509 + yym4500 := z.DecBinary() + _ = yym4500 if false { } else { *((*bool)(x.RunAsNonRoot)) = r.DecodeBool() @@ -56063,17 +55981,17 @@ func (x *SecurityContext) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ReadOnlyRootFilesystem == nil { x.ReadOnlyRootFilesystem = new(bool) } - yym4511 := z.DecBinary() - _ = yym4511 + yym4502 := z.DecBinary() + _ = yym4502 if false { } else { *((*bool)(x.ReadOnlyRootFilesystem)) = r.DecodeBool() } } default: - z.DecStructFieldNotFound(-1, yys4501) - } // end switch yys4501 - } // end for yyj4501 + z.DecStructFieldNotFound(-1, yys4492) + } // end switch yys4492 + } // end for yyj4492 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56081,16 +55999,16 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4512 int - var yyb4512 bool - var yyhl4512 bool = l >= 0 - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + var yyj4503 int + var yyb4503 bool + var yyhl4503 bool = l >= 0 + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56105,13 +56023,13 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } x.Capabilities.CodecDecodeSelf(d) } - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56124,20 +56042,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.Privileged == nil { x.Privileged = new(bool) } - yym4515 := z.DecBinary() - _ = yym4515 + yym4506 := z.DecBinary() + _ = yym4506 if false { } else { *((*bool)(x.Privileged)) = r.DecodeBool() } } - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56152,13 +56070,13 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } x.SELinuxOptions.CodecDecodeSelf(d) } - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56171,20 +56089,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.RunAsUser == nil { x.RunAsUser = new(int64) } - yym4518 := z.DecBinary() - _ = yym4518 + yym4509 := z.DecBinary() + _ = yym4509 if false { } else { *((*int64)(x.RunAsUser)) = int64(r.DecodeInt(64)) } } - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56197,20 +56115,20 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.RunAsNonRoot == nil { x.RunAsNonRoot = new(bool) } - yym4520 := z.DecBinary() - _ = yym4520 + yym4511 := z.DecBinary() + _ = yym4511 if false { } else { *((*bool)(x.RunAsNonRoot)) = r.DecodeBool() } } - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56223,25 +56141,25 @@ func (x *SecurityContext) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.ReadOnlyRootFilesystem == nil { x.ReadOnlyRootFilesystem = new(bool) } - yym4522 := z.DecBinary() - _ = yym4522 + yym4513 := z.DecBinary() + _ = yym4513 if false { } else { *((*bool)(x.ReadOnlyRootFilesystem)) = r.DecodeBool() } } for { - yyj4512++ - if yyhl4512 { - yyb4512 = yyj4512 > l + yyj4503++ + if yyhl4503 { + yyb4503 = yyj4503 > l } else { - yyb4512 = r.CheckBreak() + yyb4503 = r.CheckBreak() } - if yyb4512 { + if yyb4503 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4512-1, "") + z.DecStructFieldNotFound(yyj4503-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56253,38 +56171,38 @@ func (x *SELinuxOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4523 := z.EncBinary() - _ = yym4523 + yym4514 := z.EncBinary() + _ = yym4514 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4524 := !z.EncBinary() - yy2arr4524 := z.EncBasicHandle().StructToArray - var yyq4524 [4]bool - _, _, _ = yysep4524, yyq4524, yy2arr4524 - const yyr4524 bool = false - yyq4524[0] = x.User != "" - yyq4524[1] = x.Role != "" - yyq4524[2] = x.Type != "" - yyq4524[3] = x.Level != "" - var yynn4524 int - if yyr4524 || yy2arr4524 { + yysep4515 := !z.EncBinary() + yy2arr4515 := z.EncBasicHandle().StructToArray + var yyq4515 [4]bool + _, _, _ = yysep4515, yyq4515, yy2arr4515 + const yyr4515 bool = false + yyq4515[0] = x.User != "" + yyq4515[1] = x.Role != "" + yyq4515[2] = x.Type != "" + yyq4515[3] = x.Level != "" + var yynn4515 int + if yyr4515 || yy2arr4515 { r.EncodeArrayStart(4) } else { - yynn4524 = 0 - for _, b := range yyq4524 { + yynn4515 = 0 + for _, b := range yyq4515 { if b { - yynn4524++ + yynn4515++ } } - r.EncodeMapStart(yynn4524) - yynn4524 = 0 + r.EncodeMapStart(yynn4515) + yynn4515 = 0 } - if yyr4524 || yy2arr4524 { + if yyr4515 || yy2arr4515 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4524[0] { - yym4526 := z.EncBinary() - _ = yym4526 + if yyq4515[0] { + yym4517 := z.EncBinary() + _ = yym4517 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.User)) @@ -56293,94 +56211,94 @@ func (x *SELinuxOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4524[0] { + if yyq4515[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("user")) z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4518 := z.EncBinary() + _ = yym4518 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.User)) + } + } + } + if yyr4515 || yy2arr4515 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4515[1] { + yym4520 := z.EncBinary() + _ = yym4520 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Role)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4515[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("role")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4521 := z.EncBinary() + _ = yym4521 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Role)) + } + } + } + if yyr4515 || yy2arr4515 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4515[2] { + yym4523 := z.EncBinary() + _ = yym4523 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Type)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4515[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("type")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym4524 := z.EncBinary() + _ = yym4524 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Type)) + } + } + } + if yyr4515 || yy2arr4515 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq4515[3] { + yym4526 := z.EncBinary() + _ = yym4526 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Level)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq4515[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("level")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) yym4527 := z.EncBinary() _ = yym4527 if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.User)) - } - } - } - if yyr4524 || yy2arr4524 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4524[1] { - yym4529 := z.EncBinary() - _ = yym4529 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Role)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4524[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("role")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4530 := z.EncBinary() - _ = yym4530 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Role)) - } - } - } - if yyr4524 || yy2arr4524 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4524[2] { - yym4532 := z.EncBinary() - _ = yym4532 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Type)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4524[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("type")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4533 := z.EncBinary() - _ = yym4533 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Type)) - } - } - } - if yyr4524 || yy2arr4524 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4524[3] { - yym4535 := z.EncBinary() - _ = yym4535 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Level)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq4524[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("level")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4536 := z.EncBinary() - _ = yym4536 - if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Level)) } } } - if yyr4524 || yy2arr4524 { + if yyr4515 || yy2arr4515 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -56393,25 +56311,25 @@ func (x *SELinuxOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4537 := z.DecBinary() - _ = yym4537 + yym4528 := z.DecBinary() + _ = yym4528 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4538 := r.ContainerType() - if yyct4538 == codecSelferValueTypeMap1234 { - yyl4538 := r.ReadMapStart() - if yyl4538 == 0 { + yyct4529 := r.ContainerType() + if yyct4529 == codecSelferValueTypeMap1234 { + yyl4529 := r.ReadMapStart() + if yyl4529 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4538, d) + x.codecDecodeSelfFromMap(yyl4529, d) } - } else if yyct4538 == codecSelferValueTypeArray1234 { - yyl4538 := r.ReadArrayStart() - if yyl4538 == 0 { + } else if yyct4529 == codecSelferValueTypeArray1234 { + yyl4529 := r.ReadArrayStart() + if yyl4529 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4538, d) + x.codecDecodeSelfFromArray(yyl4529, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -56423,12 +56341,12 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4539Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4539Slc - var yyhl4539 bool = l >= 0 - for yyj4539 := 0; ; yyj4539++ { - if yyhl4539 { - if yyj4539 >= l { + var yys4530Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4530Slc + var yyhl4530 bool = l >= 0 + for yyj4530 := 0; ; yyj4530++ { + if yyhl4530 { + if yyj4530 >= l { break } } else { @@ -56437,10 +56355,10 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4539Slc = r.DecodeBytes(yys4539Slc, true, true) - yys4539 := string(yys4539Slc) + yys4530Slc = r.DecodeBytes(yys4530Slc, true, true) + yys4530 := string(yys4530Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4539 { + switch yys4530 { case "user": if r.TryDecodeAsNil() { x.User = "" @@ -56466,9 +56384,9 @@ func (x *SELinuxOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Level = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys4539) - } // end switch yys4539 - } // end for yyj4539 + z.DecStructFieldNotFound(-1, yys4530) + } // end switch yys4530 + } // end for yyj4530 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56476,16 +56394,16 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4544 int - var yyb4544 bool - var yyhl4544 bool = l >= 0 - yyj4544++ - if yyhl4544 { - yyb4544 = yyj4544 > l + var yyj4535 int + var yyb4535 bool + var yyhl4535 bool = l >= 0 + yyj4535++ + if yyhl4535 { + yyb4535 = yyj4535 > l } else { - yyb4544 = r.CheckBreak() + yyb4535 = r.CheckBreak() } - if yyb4544 { + if yyb4535 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56495,13 +56413,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.User = string(r.DecodeString()) } - yyj4544++ - if yyhl4544 { - yyb4544 = yyj4544 > l + yyj4535++ + if yyhl4535 { + yyb4535 = yyj4535 > l } else { - yyb4544 = r.CheckBreak() + yyb4535 = r.CheckBreak() } - if yyb4544 { + if yyb4535 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56511,13 +56429,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Role = string(r.DecodeString()) } - yyj4544++ - if yyhl4544 { - yyb4544 = yyj4544 > l + yyj4535++ + if yyhl4535 { + yyb4535 = yyj4535 > l } else { - yyb4544 = r.CheckBreak() + yyb4535 = r.CheckBreak() } - if yyb4544 { + if yyb4535 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56527,13 +56445,13 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = string(r.DecodeString()) } - yyj4544++ - if yyhl4544 { - yyb4544 = yyj4544 > l + yyj4535++ + if yyhl4535 { + yyb4535 = yyj4535 > l } else { - yyb4544 = r.CheckBreak() + yyb4535 = r.CheckBreak() } - if yyb4544 { + if yyb4535 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56544,17 +56462,17 @@ func (x *SELinuxOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Level = string(r.DecodeString()) } for { - yyj4544++ - if yyhl4544 { - yyb4544 = yyj4544 > l + yyj4535++ + if yyhl4535 { + yyb4535 = yyj4535 > l } else { - yyb4544 = r.CheckBreak() + yyb4535 = r.CheckBreak() } - if yyb4544 { + if yyb4535 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4544-1, "") + z.DecStructFieldNotFound(yyj4535-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56566,37 +56484,37 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym4549 := z.EncBinary() - _ = yym4549 + yym4540 := z.EncBinary() + _ = yym4540 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep4550 := !z.EncBinary() - yy2arr4550 := z.EncBasicHandle().StructToArray - var yyq4550 [5]bool - _, _, _ = yysep4550, yyq4550, yy2arr4550 - const yyr4550 bool = false - yyq4550[0] = x.Kind != "" - yyq4550[1] = x.APIVersion != "" - yyq4550[2] = true - var yynn4550 int - if yyr4550 || yy2arr4550 { + yysep4541 := !z.EncBinary() + yy2arr4541 := z.EncBasicHandle().StructToArray + var yyq4541 [5]bool + _, _, _ = yysep4541, yyq4541, yy2arr4541 + const yyr4541 bool = false + yyq4541[0] = x.Kind != "" + yyq4541[1] = x.APIVersion != "" + yyq4541[2] = true + var yynn4541 int + if yyr4541 || yy2arr4541 { r.EncodeArrayStart(5) } else { - yynn4550 = 2 - for _, b := range yyq4550 { + yynn4541 = 2 + for _, b := range yyq4541 { if b { - yynn4550++ + yynn4541++ } } - r.EncodeMapStart(yynn4550) - yynn4550 = 0 + r.EncodeMapStart(yynn4541) + yynn4541 = 0 } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4550[0] { - yym4552 := z.EncBinary() - _ = yym4552 + if yyq4541[0] { + yym4543 := z.EncBinary() + _ = yym4543 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -56605,23 +56523,23 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4550[0] { + if yyq4541[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4553 := z.EncBinary() - _ = yym4553 + yym4544 := z.EncBinary() + _ = yym4544 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4550[1] { - yym4555 := z.EncBinary() - _ = yym4555 + if yyq4541[1] { + yym4546 := z.EncBinary() + _ = yym4546 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -56630,39 +56548,39 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq4550[1] { + if yyq4541[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4556 := z.EncBinary() - _ = yym4556 + yym4547 := z.EncBinary() + _ = yym4547 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq4550[2] { - yy4558 := &x.ObjectMeta - yy4558.CodecEncodeSelf(e) + if yyq4541[2] { + yy4549 := &x.ObjectMeta + yy4549.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq4550[2] { + if yyq4541[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4559 := &x.ObjectMeta - yy4559.CodecEncodeSelf(e) + yy4550 := &x.ObjectMeta + yy4550.CodecEncodeSelf(e) } } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym4561 := z.EncBinary() - _ = yym4561 + yym4552 := z.EncBinary() + _ = yym4552 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Range)) @@ -56671,20 +56589,20 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("range")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym4562 := z.EncBinary() - _ = yym4562 + yym4553 := z.EncBinary() + _ = yym4553 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Range)) } } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Data == nil { r.EncodeNil() } else { - yym4564 := z.EncBinary() - _ = yym4564 + yym4555 := z.EncBinary() + _ = yym4555 if false { } else { r.EncodeStringBytes(codecSelferC_RAW1234, []byte(x.Data)) @@ -56697,15 +56615,15 @@ func (x *RangeAllocation) CodecEncodeSelf(e *codec1978.Encoder) { if x.Data == nil { r.EncodeNil() } else { - yym4565 := z.EncBinary() - _ = yym4565 + yym4556 := z.EncBinary() + _ = yym4556 if false { } else { r.EncodeStringBytes(codecSelferC_RAW1234, []byte(x.Data)) } } } - if yyr4550 || yy2arr4550 { + if yyr4541 || yy2arr4541 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -56718,25 +56636,25 @@ func (x *RangeAllocation) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym4566 := z.DecBinary() - _ = yym4566 + yym4557 := z.DecBinary() + _ = yym4557 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct4567 := r.ContainerType() - if yyct4567 == codecSelferValueTypeMap1234 { - yyl4567 := r.ReadMapStart() - if yyl4567 == 0 { + yyct4558 := r.ContainerType() + if yyct4558 == codecSelferValueTypeMap1234 { + yyl4558 := r.ReadMapStart() + if yyl4558 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl4567, d) + x.codecDecodeSelfFromMap(yyl4558, d) } - } else if yyct4567 == codecSelferValueTypeArray1234 { - yyl4567 := r.ReadArrayStart() - if yyl4567 == 0 { + } else if yyct4558 == codecSelferValueTypeArray1234 { + yyl4558 := r.ReadArrayStart() + if yyl4558 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl4567, d) + x.codecDecodeSelfFromArray(yyl4558, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -56748,12 +56666,12 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys4568Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys4568Slc - var yyhl4568 bool = l >= 0 - for yyj4568 := 0; ; yyj4568++ { - if yyhl4568 { - if yyj4568 >= l { + var yys4559Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys4559Slc + var yyhl4559 bool = l >= 0 + for yyj4559 := 0; ; yyj4559++ { + if yyhl4559 { + if yyj4559 >= l { break } } else { @@ -56762,10 +56680,10 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys4568Slc = r.DecodeBytes(yys4568Slc, true, true) - yys4568 := string(yys4568Slc) + yys4559Slc = r.DecodeBytes(yys4559Slc, true, true) + yys4559 := string(yys4559Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys4568 { + switch yys4559 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -56782,8 +56700,8 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4571 := &x.ObjectMeta - yyv4571.CodecDecodeSelf(d) + yyv4562 := &x.ObjectMeta + yyv4562.CodecDecodeSelf(d) } case "range": if r.TryDecodeAsNil() { @@ -56795,18 +56713,18 @@ func (x *RangeAllocation) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4573 := &x.Data - yym4574 := z.DecBinary() - _ = yym4574 + yyv4564 := &x.Data + yym4565 := z.DecBinary() + _ = yym4565 if false { } else { - *yyv4573 = r.DecodeBytes(*(*[]byte)(yyv4573), false, false) + *yyv4564 = r.DecodeBytes(*(*[]byte)(yyv4564), false, false) } } default: - z.DecStructFieldNotFound(-1, yys4568) - } // end switch yys4568 - } // end for yyj4568 + z.DecStructFieldNotFound(-1, yys4559) + } // end switch yys4559 + } // end for yyj4559 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -56814,16 +56732,16 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj4575 int - var yyb4575 bool - var yyhl4575 bool = l >= 0 - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + var yyj4566 int + var yyb4566 bool + var yyhl4566 bool = l >= 0 + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56833,13 +56751,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56849,13 +56767,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56863,16 +56781,16 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = ObjectMeta{} } else { - yyv4578 := &x.ObjectMeta - yyv4578.CodecDecodeSelf(d) + yyv4569 := &x.ObjectMeta + yyv4569.CodecDecodeSelf(d) } - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56882,13 +56800,13 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Range = string(r.DecodeString()) } - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -56896,26 +56814,26 @@ func (x *RangeAllocation) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Data = nil } else { - yyv4580 := &x.Data - yym4581 := z.DecBinary() - _ = yym4581 + yyv4571 := &x.Data + yym4572 := z.DecBinary() + _ = yym4572 if false { } else { - *yyv4580 = r.DecodeBytes(*(*[]byte)(yyv4580), false, false) + *yyv4571 = r.DecodeBytes(*(*[]byte)(yyv4571), false, false) } } for { - yyj4575++ - if yyhl4575 { - yyb4575 = yyj4575 > l + yyj4566++ + if yyhl4566 { + yyb4566 = yyj4566 > l } else { - yyb4575 = r.CheckBreak() + yyb4566 = r.CheckBreak() } - if yyb4575 { + if yyb4566 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj4575-1, "") + z.DecStructFieldNotFound(yyj4566-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56925,10 +56843,10 @@ func (x codecSelfer1234) encSliceOwnerReference(v []OwnerReference, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4582 := range v { + for _, yyv4573 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4583 := &yyv4582 - yy4583.CodecEncodeSelf(e) + yy4574 := &yyv4573 + yy4574.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -56938,83 +56856,83 @@ func (x codecSelfer1234) decSliceOwnerReference(v *[]OwnerReference, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4584 := *v - yyh4584, yyl4584 := z.DecSliceHelperStart() - var yyc4584 bool - if yyl4584 == 0 { - if yyv4584 == nil { - yyv4584 = []OwnerReference{} - yyc4584 = true - } else if len(yyv4584) != 0 { - yyv4584 = yyv4584[:0] - yyc4584 = true + yyv4575 := *v + yyh4575, yyl4575 := z.DecSliceHelperStart() + var yyc4575 bool + if yyl4575 == 0 { + if yyv4575 == nil { + yyv4575 = []OwnerReference{} + yyc4575 = true + } else if len(yyv4575) != 0 { + yyv4575 = yyv4575[:0] + yyc4575 = true } - } else if yyl4584 > 0 { - var yyrr4584, yyrl4584 int - var yyrt4584 bool - if yyl4584 > cap(yyv4584) { + } else if yyl4575 > 0 { + var yyrr4575, yyrl4575 int + var yyrt4575 bool + if yyl4575 > cap(yyv4575) { - yyrg4584 := len(yyv4584) > 0 - yyv24584 := yyv4584 - yyrl4584, yyrt4584 = z.DecInferLen(yyl4584, z.DecBasicHandle().MaxInitLen, 72) - if yyrt4584 { - if yyrl4584 <= cap(yyv4584) { - yyv4584 = yyv4584[:yyrl4584] + yyrg4575 := len(yyv4575) > 0 + yyv24575 := yyv4575 + yyrl4575, yyrt4575 = z.DecInferLen(yyl4575, z.DecBasicHandle().MaxInitLen, 72) + if yyrt4575 { + if yyrl4575 <= cap(yyv4575) { + yyv4575 = yyv4575[:yyrl4575] } else { - yyv4584 = make([]OwnerReference, yyrl4584) + yyv4575 = make([]OwnerReference, yyrl4575) } } else { - yyv4584 = make([]OwnerReference, yyrl4584) + yyv4575 = make([]OwnerReference, yyrl4575) } - yyc4584 = true - yyrr4584 = len(yyv4584) - if yyrg4584 { - copy(yyv4584, yyv24584) + yyc4575 = true + yyrr4575 = len(yyv4575) + if yyrg4575 { + copy(yyv4575, yyv24575) } - } else if yyl4584 != len(yyv4584) { - yyv4584 = yyv4584[:yyl4584] - yyc4584 = true + } else if yyl4575 != len(yyv4575) { + yyv4575 = yyv4575[:yyl4575] + yyc4575 = true } - yyj4584 := 0 - for ; yyj4584 < yyrr4584; yyj4584++ { - yyh4584.ElemContainerState(yyj4584) + yyj4575 := 0 + for ; yyj4575 < yyrr4575; yyj4575++ { + yyh4575.ElemContainerState(yyj4575) if r.TryDecodeAsNil() { - yyv4584[yyj4584] = OwnerReference{} + yyv4575[yyj4575] = OwnerReference{} } else { - yyv4585 := &yyv4584[yyj4584] - yyv4585.CodecDecodeSelf(d) + yyv4576 := &yyv4575[yyj4575] + yyv4576.CodecDecodeSelf(d) } } - if yyrt4584 { - for ; yyj4584 < yyl4584; yyj4584++ { - yyv4584 = append(yyv4584, OwnerReference{}) - yyh4584.ElemContainerState(yyj4584) + if yyrt4575 { + for ; yyj4575 < yyl4575; yyj4575++ { + yyv4575 = append(yyv4575, OwnerReference{}) + yyh4575.ElemContainerState(yyj4575) if r.TryDecodeAsNil() { - yyv4584[yyj4584] = OwnerReference{} + yyv4575[yyj4575] = OwnerReference{} } else { - yyv4586 := &yyv4584[yyj4584] - yyv4586.CodecDecodeSelf(d) + yyv4577 := &yyv4575[yyj4575] + yyv4577.CodecDecodeSelf(d) } } } } else { - yyj4584 := 0 - for ; !r.CheckBreak(); yyj4584++ { + yyj4575 := 0 + for ; !r.CheckBreak(); yyj4575++ { - if yyj4584 >= len(yyv4584) { - yyv4584 = append(yyv4584, OwnerReference{}) // var yyz4584 OwnerReference - yyc4584 = true + if yyj4575 >= len(yyv4575) { + yyv4575 = append(yyv4575, OwnerReference{}) // var yyz4575 OwnerReference + yyc4575 = true } - yyh4584.ElemContainerState(yyj4584) - if yyj4584 < len(yyv4584) { + yyh4575.ElemContainerState(yyj4575) + if yyj4575 < len(yyv4575) { if r.TryDecodeAsNil() { - yyv4584[yyj4584] = OwnerReference{} + yyv4575[yyj4575] = OwnerReference{} } else { - yyv4587 := &yyv4584[yyj4584] - yyv4587.CodecDecodeSelf(d) + yyv4578 := &yyv4575[yyj4575] + yyv4578.CodecDecodeSelf(d) } } else { @@ -57022,17 +56940,17 @@ func (x codecSelfer1234) decSliceOwnerReference(v *[]OwnerReference, d *codec197 } } - if yyj4584 < len(yyv4584) { - yyv4584 = yyv4584[:yyj4584] - yyc4584 = true - } else if yyj4584 == 0 && yyv4584 == nil { - yyv4584 = []OwnerReference{} - yyc4584 = true + if yyj4575 < len(yyv4575) { + yyv4575 = yyv4575[:yyj4575] + yyc4575 = true + } else if yyj4575 == 0 && yyv4575 == nil { + yyv4575 = []OwnerReference{} + yyc4575 = true } } - yyh4584.End() - if yyc4584 { - *v = yyv4584 + yyh4575.End() + if yyc4575 { + *v = yyv4575 } } @@ -57041,9 +56959,9 @@ func (x codecSelfer1234) encSlicePersistentVolumeAccessMode(v []PersistentVolume z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4588 := range v { + for _, yyv4579 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4588.CodecEncodeSelf(e) + yyv4579.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57053,75 +56971,75 @@ func (x codecSelfer1234) decSlicePersistentVolumeAccessMode(v *[]PersistentVolum z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4589 := *v - yyh4589, yyl4589 := z.DecSliceHelperStart() - var yyc4589 bool - if yyl4589 == 0 { - if yyv4589 == nil { - yyv4589 = []PersistentVolumeAccessMode{} - yyc4589 = true - } else if len(yyv4589) != 0 { - yyv4589 = yyv4589[:0] - yyc4589 = true + yyv4580 := *v + yyh4580, yyl4580 := z.DecSliceHelperStart() + var yyc4580 bool + if yyl4580 == 0 { + if yyv4580 == nil { + yyv4580 = []PersistentVolumeAccessMode{} + yyc4580 = true + } else if len(yyv4580) != 0 { + yyv4580 = yyv4580[:0] + yyc4580 = true } - } else if yyl4589 > 0 { - var yyrr4589, yyrl4589 int - var yyrt4589 bool - if yyl4589 > cap(yyv4589) { + } else if yyl4580 > 0 { + var yyrr4580, yyrl4580 int + var yyrt4580 bool + if yyl4580 > cap(yyv4580) { - yyrl4589, yyrt4589 = z.DecInferLen(yyl4589, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4589 { - if yyrl4589 <= cap(yyv4589) { - yyv4589 = yyv4589[:yyrl4589] + yyrl4580, yyrt4580 = z.DecInferLen(yyl4580, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4580 { + if yyrl4580 <= cap(yyv4580) { + yyv4580 = yyv4580[:yyrl4580] } else { - yyv4589 = make([]PersistentVolumeAccessMode, yyrl4589) + yyv4580 = make([]PersistentVolumeAccessMode, yyrl4580) } } else { - yyv4589 = make([]PersistentVolumeAccessMode, yyrl4589) + yyv4580 = make([]PersistentVolumeAccessMode, yyrl4580) } - yyc4589 = true - yyrr4589 = len(yyv4589) - } else if yyl4589 != len(yyv4589) { - yyv4589 = yyv4589[:yyl4589] - yyc4589 = true + yyc4580 = true + yyrr4580 = len(yyv4580) + } else if yyl4580 != len(yyv4580) { + yyv4580 = yyv4580[:yyl4580] + yyc4580 = true } - yyj4589 := 0 - for ; yyj4589 < yyrr4589; yyj4589++ { - yyh4589.ElemContainerState(yyj4589) + yyj4580 := 0 + for ; yyj4580 < yyrr4580; yyj4580++ { + yyh4580.ElemContainerState(yyj4580) if r.TryDecodeAsNil() { - yyv4589[yyj4589] = "" + yyv4580[yyj4580] = "" } else { - yyv4589[yyj4589] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4580[yyj4580] = PersistentVolumeAccessMode(r.DecodeString()) } } - if yyrt4589 { - for ; yyj4589 < yyl4589; yyj4589++ { - yyv4589 = append(yyv4589, "") - yyh4589.ElemContainerState(yyj4589) + if yyrt4580 { + for ; yyj4580 < yyl4580; yyj4580++ { + yyv4580 = append(yyv4580, "") + yyh4580.ElemContainerState(yyj4580) if r.TryDecodeAsNil() { - yyv4589[yyj4589] = "" + yyv4580[yyj4580] = "" } else { - yyv4589[yyj4589] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4580[yyj4580] = PersistentVolumeAccessMode(r.DecodeString()) } } } } else { - yyj4589 := 0 - for ; !r.CheckBreak(); yyj4589++ { + yyj4580 := 0 + for ; !r.CheckBreak(); yyj4580++ { - if yyj4589 >= len(yyv4589) { - yyv4589 = append(yyv4589, "") // var yyz4589 PersistentVolumeAccessMode - yyc4589 = true + if yyj4580 >= len(yyv4580) { + yyv4580 = append(yyv4580, "") // var yyz4580 PersistentVolumeAccessMode + yyc4580 = true } - yyh4589.ElemContainerState(yyj4589) - if yyj4589 < len(yyv4589) { + yyh4580.ElemContainerState(yyj4580) + if yyj4580 < len(yyv4580) { if r.TryDecodeAsNil() { - yyv4589[yyj4589] = "" + yyv4580[yyj4580] = "" } else { - yyv4589[yyj4589] = PersistentVolumeAccessMode(r.DecodeString()) + yyv4580[yyj4580] = PersistentVolumeAccessMode(r.DecodeString()) } } else { @@ -57129,17 +57047,17 @@ func (x codecSelfer1234) decSlicePersistentVolumeAccessMode(v *[]PersistentVolum } } - if yyj4589 < len(yyv4589) { - yyv4589 = yyv4589[:yyj4589] - yyc4589 = true - } else if yyj4589 == 0 && yyv4589 == nil { - yyv4589 = []PersistentVolumeAccessMode{} - yyc4589 = true + if yyj4580 < len(yyv4580) { + yyv4580 = yyv4580[:yyj4580] + yyc4580 = true + } else if yyj4580 == 0 && yyv4580 == nil { + yyv4580 = []PersistentVolumeAccessMode{} + yyc4580 = true } } - yyh4589.End() - if yyc4589 { - *v = yyv4589 + yyh4580.End() + if yyc4580 { + *v = yyv4580 } } @@ -57148,10 +57066,10 @@ func (x codecSelfer1234) encSlicePersistentVolume(v []PersistentVolume, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4593 := range v { + for _, yyv4584 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4594 := &yyv4593 - yy4594.CodecEncodeSelf(e) + yy4585 := &yyv4584 + yy4585.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57161,83 +57079,83 @@ func (x codecSelfer1234) decSlicePersistentVolume(v *[]PersistentVolume, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4595 := *v - yyh4595, yyl4595 := z.DecSliceHelperStart() - var yyc4595 bool - if yyl4595 == 0 { - if yyv4595 == nil { - yyv4595 = []PersistentVolume{} - yyc4595 = true - } else if len(yyv4595) != 0 { - yyv4595 = yyv4595[:0] - yyc4595 = true + yyv4586 := *v + yyh4586, yyl4586 := z.DecSliceHelperStart() + var yyc4586 bool + if yyl4586 == 0 { + if yyv4586 == nil { + yyv4586 = []PersistentVolume{} + yyc4586 = true + } else if len(yyv4586) != 0 { + yyv4586 = yyv4586[:0] + yyc4586 = true } - } else if yyl4595 > 0 { - var yyrr4595, yyrl4595 int - var yyrt4595 bool - if yyl4595 > cap(yyv4595) { + } else if yyl4586 > 0 { + var yyrr4586, yyrl4586 int + var yyrt4586 bool + if yyl4586 > cap(yyv4586) { - yyrg4595 := len(yyv4595) > 0 - yyv24595 := yyv4595 - yyrl4595, yyrt4595 = z.DecInferLen(yyl4595, z.DecBasicHandle().MaxInitLen, 488) - if yyrt4595 { - if yyrl4595 <= cap(yyv4595) { - yyv4595 = yyv4595[:yyrl4595] + yyrg4586 := len(yyv4586) > 0 + yyv24586 := yyv4586 + yyrl4586, yyrt4586 = z.DecInferLen(yyl4586, z.DecBasicHandle().MaxInitLen, 488) + if yyrt4586 { + if yyrl4586 <= cap(yyv4586) { + yyv4586 = yyv4586[:yyrl4586] } else { - yyv4595 = make([]PersistentVolume, yyrl4595) + yyv4586 = make([]PersistentVolume, yyrl4586) } } else { - yyv4595 = make([]PersistentVolume, yyrl4595) + yyv4586 = make([]PersistentVolume, yyrl4586) } - yyc4595 = true - yyrr4595 = len(yyv4595) - if yyrg4595 { - copy(yyv4595, yyv24595) + yyc4586 = true + yyrr4586 = len(yyv4586) + if yyrg4586 { + copy(yyv4586, yyv24586) } - } else if yyl4595 != len(yyv4595) { - yyv4595 = yyv4595[:yyl4595] - yyc4595 = true + } else if yyl4586 != len(yyv4586) { + yyv4586 = yyv4586[:yyl4586] + yyc4586 = true } - yyj4595 := 0 - for ; yyj4595 < yyrr4595; yyj4595++ { - yyh4595.ElemContainerState(yyj4595) + yyj4586 := 0 + for ; yyj4586 < yyrr4586; yyj4586++ { + yyh4586.ElemContainerState(yyj4586) if r.TryDecodeAsNil() { - yyv4595[yyj4595] = PersistentVolume{} + yyv4586[yyj4586] = PersistentVolume{} } else { - yyv4596 := &yyv4595[yyj4595] - yyv4596.CodecDecodeSelf(d) + yyv4587 := &yyv4586[yyj4586] + yyv4587.CodecDecodeSelf(d) } } - if yyrt4595 { - for ; yyj4595 < yyl4595; yyj4595++ { - yyv4595 = append(yyv4595, PersistentVolume{}) - yyh4595.ElemContainerState(yyj4595) + if yyrt4586 { + for ; yyj4586 < yyl4586; yyj4586++ { + yyv4586 = append(yyv4586, PersistentVolume{}) + yyh4586.ElemContainerState(yyj4586) if r.TryDecodeAsNil() { - yyv4595[yyj4595] = PersistentVolume{} + yyv4586[yyj4586] = PersistentVolume{} } else { - yyv4597 := &yyv4595[yyj4595] - yyv4597.CodecDecodeSelf(d) + yyv4588 := &yyv4586[yyj4586] + yyv4588.CodecDecodeSelf(d) } } } } else { - yyj4595 := 0 - for ; !r.CheckBreak(); yyj4595++ { + yyj4586 := 0 + for ; !r.CheckBreak(); yyj4586++ { - if yyj4595 >= len(yyv4595) { - yyv4595 = append(yyv4595, PersistentVolume{}) // var yyz4595 PersistentVolume - yyc4595 = true + if yyj4586 >= len(yyv4586) { + yyv4586 = append(yyv4586, PersistentVolume{}) // var yyz4586 PersistentVolume + yyc4586 = true } - yyh4595.ElemContainerState(yyj4595) - if yyj4595 < len(yyv4595) { + yyh4586.ElemContainerState(yyj4586) + if yyj4586 < len(yyv4586) { if r.TryDecodeAsNil() { - yyv4595[yyj4595] = PersistentVolume{} + yyv4586[yyj4586] = PersistentVolume{} } else { - yyv4598 := &yyv4595[yyj4595] - yyv4598.CodecDecodeSelf(d) + yyv4589 := &yyv4586[yyj4586] + yyv4589.CodecDecodeSelf(d) } } else { @@ -57245,17 +57163,17 @@ func (x codecSelfer1234) decSlicePersistentVolume(v *[]PersistentVolume, d *code } } - if yyj4595 < len(yyv4595) { - yyv4595 = yyv4595[:yyj4595] - yyc4595 = true - } else if yyj4595 == 0 && yyv4595 == nil { - yyv4595 = []PersistentVolume{} - yyc4595 = true + if yyj4586 < len(yyv4586) { + yyv4586 = yyv4586[:yyj4586] + yyc4586 = true + } else if yyj4586 == 0 && yyv4586 == nil { + yyv4586 = []PersistentVolume{} + yyc4586 = true } } - yyh4595.End() - if yyc4595 { - *v = yyv4595 + yyh4586.End() + if yyc4586 { + *v = yyv4586 } } @@ -57264,10 +57182,10 @@ func (x codecSelfer1234) encSlicePersistentVolumeClaim(v []PersistentVolumeClaim z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4599 := range v { + for _, yyv4590 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4600 := &yyv4599 - yy4600.CodecEncodeSelf(e) + yy4591 := &yyv4590 + yy4591.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57277,83 +57195,83 @@ func (x codecSelfer1234) decSlicePersistentVolumeClaim(v *[]PersistentVolumeClai z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4601 := *v - yyh4601, yyl4601 := z.DecSliceHelperStart() - var yyc4601 bool - if yyl4601 == 0 { - if yyv4601 == nil { - yyv4601 = []PersistentVolumeClaim{} - yyc4601 = true - } else if len(yyv4601) != 0 { - yyv4601 = yyv4601[:0] - yyc4601 = true + yyv4592 := *v + yyh4592, yyl4592 := z.DecSliceHelperStart() + var yyc4592 bool + if yyl4592 == 0 { + if yyv4592 == nil { + yyv4592 = []PersistentVolumeClaim{} + yyc4592 = true + } else if len(yyv4592) != 0 { + yyv4592 = yyv4592[:0] + yyc4592 = true } - } else if yyl4601 > 0 { - var yyrr4601, yyrl4601 int - var yyrt4601 bool - if yyl4601 > cap(yyv4601) { + } else if yyl4592 > 0 { + var yyrr4592, yyrl4592 int + var yyrt4592 bool + if yyl4592 > cap(yyv4592) { - yyrg4601 := len(yyv4601) > 0 - yyv24601 := yyv4601 - yyrl4601, yyrt4601 = z.DecInferLen(yyl4601, z.DecBasicHandle().MaxInitLen, 368) - if yyrt4601 { - if yyrl4601 <= cap(yyv4601) { - yyv4601 = yyv4601[:yyrl4601] + yyrg4592 := len(yyv4592) > 0 + yyv24592 := yyv4592 + yyrl4592, yyrt4592 = z.DecInferLen(yyl4592, z.DecBasicHandle().MaxInitLen, 368) + if yyrt4592 { + if yyrl4592 <= cap(yyv4592) { + yyv4592 = yyv4592[:yyrl4592] } else { - yyv4601 = make([]PersistentVolumeClaim, yyrl4601) + yyv4592 = make([]PersistentVolumeClaim, yyrl4592) } } else { - yyv4601 = make([]PersistentVolumeClaim, yyrl4601) + yyv4592 = make([]PersistentVolumeClaim, yyrl4592) } - yyc4601 = true - yyrr4601 = len(yyv4601) - if yyrg4601 { - copy(yyv4601, yyv24601) + yyc4592 = true + yyrr4592 = len(yyv4592) + if yyrg4592 { + copy(yyv4592, yyv24592) } - } else if yyl4601 != len(yyv4601) { - yyv4601 = yyv4601[:yyl4601] - yyc4601 = true + } else if yyl4592 != len(yyv4592) { + yyv4592 = yyv4592[:yyl4592] + yyc4592 = true } - yyj4601 := 0 - for ; yyj4601 < yyrr4601; yyj4601++ { - yyh4601.ElemContainerState(yyj4601) + yyj4592 := 0 + for ; yyj4592 < yyrr4592; yyj4592++ { + yyh4592.ElemContainerState(yyj4592) if r.TryDecodeAsNil() { - yyv4601[yyj4601] = PersistentVolumeClaim{} + yyv4592[yyj4592] = PersistentVolumeClaim{} } else { - yyv4602 := &yyv4601[yyj4601] - yyv4602.CodecDecodeSelf(d) + yyv4593 := &yyv4592[yyj4592] + yyv4593.CodecDecodeSelf(d) } } - if yyrt4601 { - for ; yyj4601 < yyl4601; yyj4601++ { - yyv4601 = append(yyv4601, PersistentVolumeClaim{}) - yyh4601.ElemContainerState(yyj4601) + if yyrt4592 { + for ; yyj4592 < yyl4592; yyj4592++ { + yyv4592 = append(yyv4592, PersistentVolumeClaim{}) + yyh4592.ElemContainerState(yyj4592) if r.TryDecodeAsNil() { - yyv4601[yyj4601] = PersistentVolumeClaim{} + yyv4592[yyj4592] = PersistentVolumeClaim{} } else { - yyv4603 := &yyv4601[yyj4601] - yyv4603.CodecDecodeSelf(d) + yyv4594 := &yyv4592[yyj4592] + yyv4594.CodecDecodeSelf(d) } } } } else { - yyj4601 := 0 - for ; !r.CheckBreak(); yyj4601++ { + yyj4592 := 0 + for ; !r.CheckBreak(); yyj4592++ { - if yyj4601 >= len(yyv4601) { - yyv4601 = append(yyv4601, PersistentVolumeClaim{}) // var yyz4601 PersistentVolumeClaim - yyc4601 = true + if yyj4592 >= len(yyv4592) { + yyv4592 = append(yyv4592, PersistentVolumeClaim{}) // var yyz4592 PersistentVolumeClaim + yyc4592 = true } - yyh4601.ElemContainerState(yyj4601) - if yyj4601 < len(yyv4601) { + yyh4592.ElemContainerState(yyj4592) + if yyj4592 < len(yyv4592) { if r.TryDecodeAsNil() { - yyv4601[yyj4601] = PersistentVolumeClaim{} + yyv4592[yyj4592] = PersistentVolumeClaim{} } else { - yyv4604 := &yyv4601[yyj4601] - yyv4604.CodecDecodeSelf(d) + yyv4595 := &yyv4592[yyj4592] + yyv4595.CodecDecodeSelf(d) } } else { @@ -57361,17 +57279,17 @@ func (x codecSelfer1234) decSlicePersistentVolumeClaim(v *[]PersistentVolumeClai } } - if yyj4601 < len(yyv4601) { - yyv4601 = yyv4601[:yyj4601] - yyc4601 = true - } else if yyj4601 == 0 && yyv4601 == nil { - yyv4601 = []PersistentVolumeClaim{} - yyc4601 = true + if yyj4592 < len(yyv4592) { + yyv4592 = yyv4592[:yyj4592] + yyc4592 = true + } else if yyj4592 == 0 && yyv4592 == nil { + yyv4592 = []PersistentVolumeClaim{} + yyc4592 = true } } - yyh4601.End() - if yyc4601 { - *v = yyv4601 + yyh4592.End() + if yyc4592 { + *v = yyv4592 } } @@ -57380,10 +57298,10 @@ func (x codecSelfer1234) encSliceKeyToPath(v []KeyToPath, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4605 := range v { + for _, yyv4596 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4606 := &yyv4605 - yy4606.CodecEncodeSelf(e) + yy4597 := &yyv4596 + yy4597.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57393,83 +57311,83 @@ func (x codecSelfer1234) decSliceKeyToPath(v *[]KeyToPath, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4607 := *v - yyh4607, yyl4607 := z.DecSliceHelperStart() - var yyc4607 bool - if yyl4607 == 0 { - if yyv4607 == nil { - yyv4607 = []KeyToPath{} - yyc4607 = true - } else if len(yyv4607) != 0 { - yyv4607 = yyv4607[:0] - yyc4607 = true + yyv4598 := *v + yyh4598, yyl4598 := z.DecSliceHelperStart() + var yyc4598 bool + if yyl4598 == 0 { + if yyv4598 == nil { + yyv4598 = []KeyToPath{} + yyc4598 = true + } else if len(yyv4598) != 0 { + yyv4598 = yyv4598[:0] + yyc4598 = true } - } else if yyl4607 > 0 { - var yyrr4607, yyrl4607 int - var yyrt4607 bool - if yyl4607 > cap(yyv4607) { + } else if yyl4598 > 0 { + var yyrr4598, yyrl4598 int + var yyrt4598 bool + if yyl4598 > cap(yyv4598) { - yyrg4607 := len(yyv4607) > 0 - yyv24607 := yyv4607 - yyrl4607, yyrt4607 = z.DecInferLen(yyl4607, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4607 { - if yyrl4607 <= cap(yyv4607) { - yyv4607 = yyv4607[:yyrl4607] + yyrg4598 := len(yyv4598) > 0 + yyv24598 := yyv4598 + yyrl4598, yyrt4598 = z.DecInferLen(yyl4598, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4598 { + if yyrl4598 <= cap(yyv4598) { + yyv4598 = yyv4598[:yyrl4598] } else { - yyv4607 = make([]KeyToPath, yyrl4607) + yyv4598 = make([]KeyToPath, yyrl4598) } } else { - yyv4607 = make([]KeyToPath, yyrl4607) + yyv4598 = make([]KeyToPath, yyrl4598) } - yyc4607 = true - yyrr4607 = len(yyv4607) - if yyrg4607 { - copy(yyv4607, yyv24607) + yyc4598 = true + yyrr4598 = len(yyv4598) + if yyrg4598 { + copy(yyv4598, yyv24598) } - } else if yyl4607 != len(yyv4607) { - yyv4607 = yyv4607[:yyl4607] - yyc4607 = true + } else if yyl4598 != len(yyv4598) { + yyv4598 = yyv4598[:yyl4598] + yyc4598 = true } - yyj4607 := 0 - for ; yyj4607 < yyrr4607; yyj4607++ { - yyh4607.ElemContainerState(yyj4607) + yyj4598 := 0 + for ; yyj4598 < yyrr4598; yyj4598++ { + yyh4598.ElemContainerState(yyj4598) if r.TryDecodeAsNil() { - yyv4607[yyj4607] = KeyToPath{} + yyv4598[yyj4598] = KeyToPath{} } else { - yyv4608 := &yyv4607[yyj4607] - yyv4608.CodecDecodeSelf(d) + yyv4599 := &yyv4598[yyj4598] + yyv4599.CodecDecodeSelf(d) } } - if yyrt4607 { - for ; yyj4607 < yyl4607; yyj4607++ { - yyv4607 = append(yyv4607, KeyToPath{}) - yyh4607.ElemContainerState(yyj4607) + if yyrt4598 { + for ; yyj4598 < yyl4598; yyj4598++ { + yyv4598 = append(yyv4598, KeyToPath{}) + yyh4598.ElemContainerState(yyj4598) if r.TryDecodeAsNil() { - yyv4607[yyj4607] = KeyToPath{} + yyv4598[yyj4598] = KeyToPath{} } else { - yyv4609 := &yyv4607[yyj4607] - yyv4609.CodecDecodeSelf(d) + yyv4600 := &yyv4598[yyj4598] + yyv4600.CodecDecodeSelf(d) } } } } else { - yyj4607 := 0 - for ; !r.CheckBreak(); yyj4607++ { + yyj4598 := 0 + for ; !r.CheckBreak(); yyj4598++ { - if yyj4607 >= len(yyv4607) { - yyv4607 = append(yyv4607, KeyToPath{}) // var yyz4607 KeyToPath - yyc4607 = true + if yyj4598 >= len(yyv4598) { + yyv4598 = append(yyv4598, KeyToPath{}) // var yyz4598 KeyToPath + yyc4598 = true } - yyh4607.ElemContainerState(yyj4607) - if yyj4607 < len(yyv4607) { + yyh4598.ElemContainerState(yyj4598) + if yyj4598 < len(yyv4598) { if r.TryDecodeAsNil() { - yyv4607[yyj4607] = KeyToPath{} + yyv4598[yyj4598] = KeyToPath{} } else { - yyv4610 := &yyv4607[yyj4607] - yyv4610.CodecDecodeSelf(d) + yyv4601 := &yyv4598[yyj4598] + yyv4601.CodecDecodeSelf(d) } } else { @@ -57477,17 +57395,17 @@ func (x codecSelfer1234) decSliceKeyToPath(v *[]KeyToPath, d *codec1978.Decoder) } } - if yyj4607 < len(yyv4607) { - yyv4607 = yyv4607[:yyj4607] - yyc4607 = true - } else if yyj4607 == 0 && yyv4607 == nil { - yyv4607 = []KeyToPath{} - yyc4607 = true + if yyj4598 < len(yyv4598) { + yyv4598 = yyv4598[:yyj4598] + yyc4598 = true + } else if yyj4598 == 0 && yyv4598 == nil { + yyv4598 = []KeyToPath{} + yyc4598 = true } } - yyh4607.End() - if yyc4607 { - *v = yyv4607 + yyh4598.End() + if yyc4598 { + *v = yyv4598 } } @@ -57496,10 +57414,10 @@ func (x codecSelfer1234) encSliceHTTPHeader(v []HTTPHeader, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4611 := range v { + for _, yyv4602 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4612 := &yyv4611 - yy4612.CodecEncodeSelf(e) + yy4603 := &yyv4602 + yy4603.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57509,83 +57427,83 @@ func (x codecSelfer1234) decSliceHTTPHeader(v *[]HTTPHeader, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4613 := *v - yyh4613, yyl4613 := z.DecSliceHelperStart() - var yyc4613 bool - if yyl4613 == 0 { - if yyv4613 == nil { - yyv4613 = []HTTPHeader{} - yyc4613 = true - } else if len(yyv4613) != 0 { - yyv4613 = yyv4613[:0] - yyc4613 = true + yyv4604 := *v + yyh4604, yyl4604 := z.DecSliceHelperStart() + var yyc4604 bool + if yyl4604 == 0 { + if yyv4604 == nil { + yyv4604 = []HTTPHeader{} + yyc4604 = true + } else if len(yyv4604) != 0 { + yyv4604 = yyv4604[:0] + yyc4604 = true } - } else if yyl4613 > 0 { - var yyrr4613, yyrl4613 int - var yyrt4613 bool - if yyl4613 > cap(yyv4613) { + } else if yyl4604 > 0 { + var yyrr4604, yyrl4604 int + var yyrt4604 bool + if yyl4604 > cap(yyv4604) { - yyrg4613 := len(yyv4613) > 0 - yyv24613 := yyv4613 - yyrl4613, yyrt4613 = z.DecInferLen(yyl4613, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4613 { - if yyrl4613 <= cap(yyv4613) { - yyv4613 = yyv4613[:yyrl4613] + yyrg4604 := len(yyv4604) > 0 + yyv24604 := yyv4604 + yyrl4604, yyrt4604 = z.DecInferLen(yyl4604, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4604 { + if yyrl4604 <= cap(yyv4604) { + yyv4604 = yyv4604[:yyrl4604] } else { - yyv4613 = make([]HTTPHeader, yyrl4613) + yyv4604 = make([]HTTPHeader, yyrl4604) } } else { - yyv4613 = make([]HTTPHeader, yyrl4613) + yyv4604 = make([]HTTPHeader, yyrl4604) } - yyc4613 = true - yyrr4613 = len(yyv4613) - if yyrg4613 { - copy(yyv4613, yyv24613) + yyc4604 = true + yyrr4604 = len(yyv4604) + if yyrg4604 { + copy(yyv4604, yyv24604) } - } else if yyl4613 != len(yyv4613) { - yyv4613 = yyv4613[:yyl4613] - yyc4613 = true + } else if yyl4604 != len(yyv4604) { + yyv4604 = yyv4604[:yyl4604] + yyc4604 = true } - yyj4613 := 0 - for ; yyj4613 < yyrr4613; yyj4613++ { - yyh4613.ElemContainerState(yyj4613) + yyj4604 := 0 + for ; yyj4604 < yyrr4604; yyj4604++ { + yyh4604.ElemContainerState(yyj4604) if r.TryDecodeAsNil() { - yyv4613[yyj4613] = HTTPHeader{} + yyv4604[yyj4604] = HTTPHeader{} } else { - yyv4614 := &yyv4613[yyj4613] - yyv4614.CodecDecodeSelf(d) + yyv4605 := &yyv4604[yyj4604] + yyv4605.CodecDecodeSelf(d) } } - if yyrt4613 { - for ; yyj4613 < yyl4613; yyj4613++ { - yyv4613 = append(yyv4613, HTTPHeader{}) - yyh4613.ElemContainerState(yyj4613) + if yyrt4604 { + for ; yyj4604 < yyl4604; yyj4604++ { + yyv4604 = append(yyv4604, HTTPHeader{}) + yyh4604.ElemContainerState(yyj4604) if r.TryDecodeAsNil() { - yyv4613[yyj4613] = HTTPHeader{} + yyv4604[yyj4604] = HTTPHeader{} } else { - yyv4615 := &yyv4613[yyj4613] - yyv4615.CodecDecodeSelf(d) + yyv4606 := &yyv4604[yyj4604] + yyv4606.CodecDecodeSelf(d) } } } } else { - yyj4613 := 0 - for ; !r.CheckBreak(); yyj4613++ { + yyj4604 := 0 + for ; !r.CheckBreak(); yyj4604++ { - if yyj4613 >= len(yyv4613) { - yyv4613 = append(yyv4613, HTTPHeader{}) // var yyz4613 HTTPHeader - yyc4613 = true + if yyj4604 >= len(yyv4604) { + yyv4604 = append(yyv4604, HTTPHeader{}) // var yyz4604 HTTPHeader + yyc4604 = true } - yyh4613.ElemContainerState(yyj4613) - if yyj4613 < len(yyv4613) { + yyh4604.ElemContainerState(yyj4604) + if yyj4604 < len(yyv4604) { if r.TryDecodeAsNil() { - yyv4613[yyj4613] = HTTPHeader{} + yyv4604[yyj4604] = HTTPHeader{} } else { - yyv4616 := &yyv4613[yyj4613] - yyv4616.CodecDecodeSelf(d) + yyv4607 := &yyv4604[yyj4604] + yyv4607.CodecDecodeSelf(d) } } else { @@ -57593,17 +57511,17 @@ func (x codecSelfer1234) decSliceHTTPHeader(v *[]HTTPHeader, d *codec1978.Decode } } - if yyj4613 < len(yyv4613) { - yyv4613 = yyv4613[:yyj4613] - yyc4613 = true - } else if yyj4613 == 0 && yyv4613 == nil { - yyv4613 = []HTTPHeader{} - yyc4613 = true + if yyj4604 < len(yyv4604) { + yyv4604 = yyv4604[:yyj4604] + yyc4604 = true + } else if yyj4604 == 0 && yyv4604 == nil { + yyv4604 = []HTTPHeader{} + yyc4604 = true } } - yyh4613.End() - if yyc4613 { - *v = yyv4613 + yyh4604.End() + if yyc4604 { + *v = yyv4604 } } @@ -57612,9 +57530,9 @@ func (x codecSelfer1234) encSliceCapability(v []Capability, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4617 := range v { + for _, yyv4608 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4617.CodecEncodeSelf(e) + yyv4608.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57624,75 +57542,75 @@ func (x codecSelfer1234) decSliceCapability(v *[]Capability, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4618 := *v - yyh4618, yyl4618 := z.DecSliceHelperStart() - var yyc4618 bool - if yyl4618 == 0 { - if yyv4618 == nil { - yyv4618 = []Capability{} - yyc4618 = true - } else if len(yyv4618) != 0 { - yyv4618 = yyv4618[:0] - yyc4618 = true + yyv4609 := *v + yyh4609, yyl4609 := z.DecSliceHelperStart() + var yyc4609 bool + if yyl4609 == 0 { + if yyv4609 == nil { + yyv4609 = []Capability{} + yyc4609 = true + } else if len(yyv4609) != 0 { + yyv4609 = yyv4609[:0] + yyc4609 = true } - } else if yyl4618 > 0 { - var yyrr4618, yyrl4618 int - var yyrt4618 bool - if yyl4618 > cap(yyv4618) { + } else if yyl4609 > 0 { + var yyrr4609, yyrl4609 int + var yyrt4609 bool + if yyl4609 > cap(yyv4609) { - yyrl4618, yyrt4618 = z.DecInferLen(yyl4618, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4618 { - if yyrl4618 <= cap(yyv4618) { - yyv4618 = yyv4618[:yyrl4618] + yyrl4609, yyrt4609 = z.DecInferLen(yyl4609, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4609 { + if yyrl4609 <= cap(yyv4609) { + yyv4609 = yyv4609[:yyrl4609] } else { - yyv4618 = make([]Capability, yyrl4618) + yyv4609 = make([]Capability, yyrl4609) } } else { - yyv4618 = make([]Capability, yyrl4618) + yyv4609 = make([]Capability, yyrl4609) } - yyc4618 = true - yyrr4618 = len(yyv4618) - } else if yyl4618 != len(yyv4618) { - yyv4618 = yyv4618[:yyl4618] - yyc4618 = true + yyc4609 = true + yyrr4609 = len(yyv4609) + } else if yyl4609 != len(yyv4609) { + yyv4609 = yyv4609[:yyl4609] + yyc4609 = true } - yyj4618 := 0 - for ; yyj4618 < yyrr4618; yyj4618++ { - yyh4618.ElemContainerState(yyj4618) + yyj4609 := 0 + for ; yyj4609 < yyrr4609; yyj4609++ { + yyh4609.ElemContainerState(yyj4609) if r.TryDecodeAsNil() { - yyv4618[yyj4618] = "" + yyv4609[yyj4609] = "" } else { - yyv4618[yyj4618] = Capability(r.DecodeString()) + yyv4609[yyj4609] = Capability(r.DecodeString()) } } - if yyrt4618 { - for ; yyj4618 < yyl4618; yyj4618++ { - yyv4618 = append(yyv4618, "") - yyh4618.ElemContainerState(yyj4618) + if yyrt4609 { + for ; yyj4609 < yyl4609; yyj4609++ { + yyv4609 = append(yyv4609, "") + yyh4609.ElemContainerState(yyj4609) if r.TryDecodeAsNil() { - yyv4618[yyj4618] = "" + yyv4609[yyj4609] = "" } else { - yyv4618[yyj4618] = Capability(r.DecodeString()) + yyv4609[yyj4609] = Capability(r.DecodeString()) } } } } else { - yyj4618 := 0 - for ; !r.CheckBreak(); yyj4618++ { + yyj4609 := 0 + for ; !r.CheckBreak(); yyj4609++ { - if yyj4618 >= len(yyv4618) { - yyv4618 = append(yyv4618, "") // var yyz4618 Capability - yyc4618 = true + if yyj4609 >= len(yyv4609) { + yyv4609 = append(yyv4609, "") // var yyz4609 Capability + yyc4609 = true } - yyh4618.ElemContainerState(yyj4618) - if yyj4618 < len(yyv4618) { + yyh4609.ElemContainerState(yyj4609) + if yyj4609 < len(yyv4609) { if r.TryDecodeAsNil() { - yyv4618[yyj4618] = "" + yyv4609[yyj4609] = "" } else { - yyv4618[yyj4618] = Capability(r.DecodeString()) + yyv4609[yyj4609] = Capability(r.DecodeString()) } } else { @@ -57700,17 +57618,17 @@ func (x codecSelfer1234) decSliceCapability(v *[]Capability, d *codec1978.Decode } } - if yyj4618 < len(yyv4618) { - yyv4618 = yyv4618[:yyj4618] - yyc4618 = true - } else if yyj4618 == 0 && yyv4618 == nil { - yyv4618 = []Capability{} - yyc4618 = true + if yyj4609 < len(yyv4609) { + yyv4609 = yyv4609[:yyj4609] + yyc4609 = true + } else if yyj4609 == 0 && yyv4609 == nil { + yyv4609 = []Capability{} + yyc4609 = true } } - yyh4618.End() - if yyc4618 { - *v = yyv4618 + yyh4609.End() + if yyc4609 { + *v = yyv4609 } } @@ -57719,10 +57637,10 @@ func (x codecSelfer1234) encSliceContainerPort(v []ContainerPort, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4622 := range v { + for _, yyv4613 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4623 := &yyv4622 - yy4623.CodecEncodeSelf(e) + yy4614 := &yyv4613 + yy4614.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57732,83 +57650,83 @@ func (x codecSelfer1234) decSliceContainerPort(v *[]ContainerPort, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4624 := *v - yyh4624, yyl4624 := z.DecSliceHelperStart() - var yyc4624 bool - if yyl4624 == 0 { - if yyv4624 == nil { - yyv4624 = []ContainerPort{} - yyc4624 = true - } else if len(yyv4624) != 0 { - yyv4624 = yyv4624[:0] - yyc4624 = true + yyv4615 := *v + yyh4615, yyl4615 := z.DecSliceHelperStart() + var yyc4615 bool + if yyl4615 == 0 { + if yyv4615 == nil { + yyv4615 = []ContainerPort{} + yyc4615 = true + } else if len(yyv4615) != 0 { + yyv4615 = yyv4615[:0] + yyc4615 = true } - } else if yyl4624 > 0 { - var yyrr4624, yyrl4624 int - var yyrt4624 bool - if yyl4624 > cap(yyv4624) { + } else if yyl4615 > 0 { + var yyrr4615, yyrl4615 int + var yyrt4615 bool + if yyl4615 > cap(yyv4615) { - yyrg4624 := len(yyv4624) > 0 - yyv24624 := yyv4624 - yyrl4624, yyrt4624 = z.DecInferLen(yyl4624, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4624 { - if yyrl4624 <= cap(yyv4624) { - yyv4624 = yyv4624[:yyrl4624] + yyrg4615 := len(yyv4615) > 0 + yyv24615 := yyv4615 + yyrl4615, yyrt4615 = z.DecInferLen(yyl4615, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4615 { + if yyrl4615 <= cap(yyv4615) { + yyv4615 = yyv4615[:yyrl4615] } else { - yyv4624 = make([]ContainerPort, yyrl4624) + yyv4615 = make([]ContainerPort, yyrl4615) } } else { - yyv4624 = make([]ContainerPort, yyrl4624) + yyv4615 = make([]ContainerPort, yyrl4615) } - yyc4624 = true - yyrr4624 = len(yyv4624) - if yyrg4624 { - copy(yyv4624, yyv24624) + yyc4615 = true + yyrr4615 = len(yyv4615) + if yyrg4615 { + copy(yyv4615, yyv24615) } - } else if yyl4624 != len(yyv4624) { - yyv4624 = yyv4624[:yyl4624] - yyc4624 = true + } else if yyl4615 != len(yyv4615) { + yyv4615 = yyv4615[:yyl4615] + yyc4615 = true } - yyj4624 := 0 - for ; yyj4624 < yyrr4624; yyj4624++ { - yyh4624.ElemContainerState(yyj4624) + yyj4615 := 0 + for ; yyj4615 < yyrr4615; yyj4615++ { + yyh4615.ElemContainerState(yyj4615) if r.TryDecodeAsNil() { - yyv4624[yyj4624] = ContainerPort{} + yyv4615[yyj4615] = ContainerPort{} } else { - yyv4625 := &yyv4624[yyj4624] - yyv4625.CodecDecodeSelf(d) + yyv4616 := &yyv4615[yyj4615] + yyv4616.CodecDecodeSelf(d) } } - if yyrt4624 { - for ; yyj4624 < yyl4624; yyj4624++ { - yyv4624 = append(yyv4624, ContainerPort{}) - yyh4624.ElemContainerState(yyj4624) + if yyrt4615 { + for ; yyj4615 < yyl4615; yyj4615++ { + yyv4615 = append(yyv4615, ContainerPort{}) + yyh4615.ElemContainerState(yyj4615) if r.TryDecodeAsNil() { - yyv4624[yyj4624] = ContainerPort{} + yyv4615[yyj4615] = ContainerPort{} } else { - yyv4626 := &yyv4624[yyj4624] - yyv4626.CodecDecodeSelf(d) + yyv4617 := &yyv4615[yyj4615] + yyv4617.CodecDecodeSelf(d) } } } } else { - yyj4624 := 0 - for ; !r.CheckBreak(); yyj4624++ { + yyj4615 := 0 + for ; !r.CheckBreak(); yyj4615++ { - if yyj4624 >= len(yyv4624) { - yyv4624 = append(yyv4624, ContainerPort{}) // var yyz4624 ContainerPort - yyc4624 = true + if yyj4615 >= len(yyv4615) { + yyv4615 = append(yyv4615, ContainerPort{}) // var yyz4615 ContainerPort + yyc4615 = true } - yyh4624.ElemContainerState(yyj4624) - if yyj4624 < len(yyv4624) { + yyh4615.ElemContainerState(yyj4615) + if yyj4615 < len(yyv4615) { if r.TryDecodeAsNil() { - yyv4624[yyj4624] = ContainerPort{} + yyv4615[yyj4615] = ContainerPort{} } else { - yyv4627 := &yyv4624[yyj4624] - yyv4627.CodecDecodeSelf(d) + yyv4618 := &yyv4615[yyj4615] + yyv4618.CodecDecodeSelf(d) } } else { @@ -57816,17 +57734,17 @@ func (x codecSelfer1234) decSliceContainerPort(v *[]ContainerPort, d *codec1978. } } - if yyj4624 < len(yyv4624) { - yyv4624 = yyv4624[:yyj4624] - yyc4624 = true - } else if yyj4624 == 0 && yyv4624 == nil { - yyv4624 = []ContainerPort{} - yyc4624 = true + if yyj4615 < len(yyv4615) { + yyv4615 = yyv4615[:yyj4615] + yyc4615 = true + } else if yyj4615 == 0 && yyv4615 == nil { + yyv4615 = []ContainerPort{} + yyc4615 = true } } - yyh4624.End() - if yyc4624 { - *v = yyv4624 + yyh4615.End() + if yyc4615 { + *v = yyv4615 } } @@ -57835,10 +57753,10 @@ func (x codecSelfer1234) encSliceEnvVar(v []EnvVar, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4628 := range v { + for _, yyv4619 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4629 := &yyv4628 - yy4629.CodecEncodeSelf(e) + yy4620 := &yyv4619 + yy4620.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57848,83 +57766,83 @@ func (x codecSelfer1234) decSliceEnvVar(v *[]EnvVar, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4630 := *v - yyh4630, yyl4630 := z.DecSliceHelperStart() - var yyc4630 bool - if yyl4630 == 0 { - if yyv4630 == nil { - yyv4630 = []EnvVar{} - yyc4630 = true - } else if len(yyv4630) != 0 { - yyv4630 = yyv4630[:0] - yyc4630 = true + yyv4621 := *v + yyh4621, yyl4621 := z.DecSliceHelperStart() + var yyc4621 bool + if yyl4621 == 0 { + if yyv4621 == nil { + yyv4621 = []EnvVar{} + yyc4621 = true + } else if len(yyv4621) != 0 { + yyv4621 = yyv4621[:0] + yyc4621 = true } - } else if yyl4630 > 0 { - var yyrr4630, yyrl4630 int - var yyrt4630 bool - if yyl4630 > cap(yyv4630) { + } else if yyl4621 > 0 { + var yyrr4621, yyrl4621 int + var yyrt4621 bool + if yyl4621 > cap(yyv4621) { - yyrg4630 := len(yyv4630) > 0 - yyv24630 := yyv4630 - yyrl4630, yyrt4630 = z.DecInferLen(yyl4630, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4630 { - if yyrl4630 <= cap(yyv4630) { - yyv4630 = yyv4630[:yyrl4630] + yyrg4621 := len(yyv4621) > 0 + yyv24621 := yyv4621 + yyrl4621, yyrt4621 = z.DecInferLen(yyl4621, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4621 { + if yyrl4621 <= cap(yyv4621) { + yyv4621 = yyv4621[:yyrl4621] } else { - yyv4630 = make([]EnvVar, yyrl4630) + yyv4621 = make([]EnvVar, yyrl4621) } } else { - yyv4630 = make([]EnvVar, yyrl4630) + yyv4621 = make([]EnvVar, yyrl4621) } - yyc4630 = true - yyrr4630 = len(yyv4630) - if yyrg4630 { - copy(yyv4630, yyv24630) + yyc4621 = true + yyrr4621 = len(yyv4621) + if yyrg4621 { + copy(yyv4621, yyv24621) } - } else if yyl4630 != len(yyv4630) { - yyv4630 = yyv4630[:yyl4630] - yyc4630 = true + } else if yyl4621 != len(yyv4621) { + yyv4621 = yyv4621[:yyl4621] + yyc4621 = true } - yyj4630 := 0 - for ; yyj4630 < yyrr4630; yyj4630++ { - yyh4630.ElemContainerState(yyj4630) + yyj4621 := 0 + for ; yyj4621 < yyrr4621; yyj4621++ { + yyh4621.ElemContainerState(yyj4621) if r.TryDecodeAsNil() { - yyv4630[yyj4630] = EnvVar{} + yyv4621[yyj4621] = EnvVar{} } else { - yyv4631 := &yyv4630[yyj4630] - yyv4631.CodecDecodeSelf(d) + yyv4622 := &yyv4621[yyj4621] + yyv4622.CodecDecodeSelf(d) } } - if yyrt4630 { - for ; yyj4630 < yyl4630; yyj4630++ { - yyv4630 = append(yyv4630, EnvVar{}) - yyh4630.ElemContainerState(yyj4630) + if yyrt4621 { + for ; yyj4621 < yyl4621; yyj4621++ { + yyv4621 = append(yyv4621, EnvVar{}) + yyh4621.ElemContainerState(yyj4621) if r.TryDecodeAsNil() { - yyv4630[yyj4630] = EnvVar{} + yyv4621[yyj4621] = EnvVar{} } else { - yyv4632 := &yyv4630[yyj4630] - yyv4632.CodecDecodeSelf(d) + yyv4623 := &yyv4621[yyj4621] + yyv4623.CodecDecodeSelf(d) } } } } else { - yyj4630 := 0 - for ; !r.CheckBreak(); yyj4630++ { + yyj4621 := 0 + for ; !r.CheckBreak(); yyj4621++ { - if yyj4630 >= len(yyv4630) { - yyv4630 = append(yyv4630, EnvVar{}) // var yyz4630 EnvVar - yyc4630 = true + if yyj4621 >= len(yyv4621) { + yyv4621 = append(yyv4621, EnvVar{}) // var yyz4621 EnvVar + yyc4621 = true } - yyh4630.ElemContainerState(yyj4630) - if yyj4630 < len(yyv4630) { + yyh4621.ElemContainerState(yyj4621) + if yyj4621 < len(yyv4621) { if r.TryDecodeAsNil() { - yyv4630[yyj4630] = EnvVar{} + yyv4621[yyj4621] = EnvVar{} } else { - yyv4633 := &yyv4630[yyj4630] - yyv4633.CodecDecodeSelf(d) + yyv4624 := &yyv4621[yyj4621] + yyv4624.CodecDecodeSelf(d) } } else { @@ -57932,17 +57850,17 @@ func (x codecSelfer1234) decSliceEnvVar(v *[]EnvVar, d *codec1978.Decoder) { } } - if yyj4630 < len(yyv4630) { - yyv4630 = yyv4630[:yyj4630] - yyc4630 = true - } else if yyj4630 == 0 && yyv4630 == nil { - yyv4630 = []EnvVar{} - yyc4630 = true + if yyj4621 < len(yyv4621) { + yyv4621 = yyv4621[:yyj4621] + yyc4621 = true + } else if yyj4621 == 0 && yyv4621 == nil { + yyv4621 = []EnvVar{} + yyc4621 = true } } - yyh4630.End() - if yyc4630 { - *v = yyv4630 + yyh4621.End() + if yyc4621 { + *v = yyv4621 } } @@ -57951,10 +57869,10 @@ func (x codecSelfer1234) encSliceVolumeMount(v []VolumeMount, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4634 := range v { + for _, yyv4625 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4635 := &yyv4634 - yy4635.CodecEncodeSelf(e) + yy4626 := &yyv4625 + yy4626.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -57964,83 +57882,83 @@ func (x codecSelfer1234) decSliceVolumeMount(v *[]VolumeMount, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4636 := *v - yyh4636, yyl4636 := z.DecSliceHelperStart() - var yyc4636 bool - if yyl4636 == 0 { - if yyv4636 == nil { - yyv4636 = []VolumeMount{} - yyc4636 = true - } else if len(yyv4636) != 0 { - yyv4636 = yyv4636[:0] - yyc4636 = true + yyv4627 := *v + yyh4627, yyl4627 := z.DecSliceHelperStart() + var yyc4627 bool + if yyl4627 == 0 { + if yyv4627 == nil { + yyv4627 = []VolumeMount{} + yyc4627 = true + } else if len(yyv4627) != 0 { + yyv4627 = yyv4627[:0] + yyc4627 = true } - } else if yyl4636 > 0 { - var yyrr4636, yyrl4636 int - var yyrt4636 bool - if yyl4636 > cap(yyv4636) { + } else if yyl4627 > 0 { + var yyrr4627, yyrl4627 int + var yyrt4627 bool + if yyl4627 > cap(yyv4627) { - yyrg4636 := len(yyv4636) > 0 - yyv24636 := yyv4636 - yyrl4636, yyrt4636 = z.DecInferLen(yyl4636, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4636 { - if yyrl4636 <= cap(yyv4636) { - yyv4636 = yyv4636[:yyrl4636] + yyrg4627 := len(yyv4627) > 0 + yyv24627 := yyv4627 + yyrl4627, yyrt4627 = z.DecInferLen(yyl4627, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4627 { + if yyrl4627 <= cap(yyv4627) { + yyv4627 = yyv4627[:yyrl4627] } else { - yyv4636 = make([]VolumeMount, yyrl4636) + yyv4627 = make([]VolumeMount, yyrl4627) } } else { - yyv4636 = make([]VolumeMount, yyrl4636) + yyv4627 = make([]VolumeMount, yyrl4627) } - yyc4636 = true - yyrr4636 = len(yyv4636) - if yyrg4636 { - copy(yyv4636, yyv24636) + yyc4627 = true + yyrr4627 = len(yyv4627) + if yyrg4627 { + copy(yyv4627, yyv24627) } - } else if yyl4636 != len(yyv4636) { - yyv4636 = yyv4636[:yyl4636] - yyc4636 = true + } else if yyl4627 != len(yyv4627) { + yyv4627 = yyv4627[:yyl4627] + yyc4627 = true } - yyj4636 := 0 - for ; yyj4636 < yyrr4636; yyj4636++ { - yyh4636.ElemContainerState(yyj4636) + yyj4627 := 0 + for ; yyj4627 < yyrr4627; yyj4627++ { + yyh4627.ElemContainerState(yyj4627) if r.TryDecodeAsNil() { - yyv4636[yyj4636] = VolumeMount{} + yyv4627[yyj4627] = VolumeMount{} } else { - yyv4637 := &yyv4636[yyj4636] - yyv4637.CodecDecodeSelf(d) + yyv4628 := &yyv4627[yyj4627] + yyv4628.CodecDecodeSelf(d) } } - if yyrt4636 { - for ; yyj4636 < yyl4636; yyj4636++ { - yyv4636 = append(yyv4636, VolumeMount{}) - yyh4636.ElemContainerState(yyj4636) + if yyrt4627 { + for ; yyj4627 < yyl4627; yyj4627++ { + yyv4627 = append(yyv4627, VolumeMount{}) + yyh4627.ElemContainerState(yyj4627) if r.TryDecodeAsNil() { - yyv4636[yyj4636] = VolumeMount{} + yyv4627[yyj4627] = VolumeMount{} } else { - yyv4638 := &yyv4636[yyj4636] - yyv4638.CodecDecodeSelf(d) + yyv4629 := &yyv4627[yyj4627] + yyv4629.CodecDecodeSelf(d) } } } } else { - yyj4636 := 0 - for ; !r.CheckBreak(); yyj4636++ { + yyj4627 := 0 + for ; !r.CheckBreak(); yyj4627++ { - if yyj4636 >= len(yyv4636) { - yyv4636 = append(yyv4636, VolumeMount{}) // var yyz4636 VolumeMount - yyc4636 = true + if yyj4627 >= len(yyv4627) { + yyv4627 = append(yyv4627, VolumeMount{}) // var yyz4627 VolumeMount + yyc4627 = true } - yyh4636.ElemContainerState(yyj4636) - if yyj4636 < len(yyv4636) { + yyh4627.ElemContainerState(yyj4627) + if yyj4627 < len(yyv4627) { if r.TryDecodeAsNil() { - yyv4636[yyj4636] = VolumeMount{} + yyv4627[yyj4627] = VolumeMount{} } else { - yyv4639 := &yyv4636[yyj4636] - yyv4639.CodecDecodeSelf(d) + yyv4630 := &yyv4627[yyj4627] + yyv4630.CodecDecodeSelf(d) } } else { @@ -58048,17 +57966,17 @@ func (x codecSelfer1234) decSliceVolumeMount(v *[]VolumeMount, d *codec1978.Deco } } - if yyj4636 < len(yyv4636) { - yyv4636 = yyv4636[:yyj4636] - yyc4636 = true - } else if yyj4636 == 0 && yyv4636 == nil { - yyv4636 = []VolumeMount{} - yyc4636 = true + if yyj4627 < len(yyv4627) { + yyv4627 = yyv4627[:yyj4627] + yyc4627 = true + } else if yyj4627 == 0 && yyv4627 == nil { + yyv4627 = []VolumeMount{} + yyc4627 = true } } - yyh4636.End() - if yyc4636 { - *v = yyv4636 + yyh4627.End() + if yyc4627 { + *v = yyv4627 } } @@ -58067,10 +57985,10 @@ func (x codecSelfer1234) encSliceNodeSelectorTerm(v []NodeSelectorTerm, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4640 := range v { + for _, yyv4631 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4641 := &yyv4640 - yy4641.CodecEncodeSelf(e) + yy4632 := &yyv4631 + yy4632.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58080,83 +57998,83 @@ func (x codecSelfer1234) decSliceNodeSelectorTerm(v *[]NodeSelectorTerm, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4642 := *v - yyh4642, yyl4642 := z.DecSliceHelperStart() - var yyc4642 bool - if yyl4642 == 0 { - if yyv4642 == nil { - yyv4642 = []NodeSelectorTerm{} - yyc4642 = true - } else if len(yyv4642) != 0 { - yyv4642 = yyv4642[:0] - yyc4642 = true + yyv4633 := *v + yyh4633, yyl4633 := z.DecSliceHelperStart() + var yyc4633 bool + if yyl4633 == 0 { + if yyv4633 == nil { + yyv4633 = []NodeSelectorTerm{} + yyc4633 = true + } else if len(yyv4633) != 0 { + yyv4633 = yyv4633[:0] + yyc4633 = true } - } else if yyl4642 > 0 { - var yyrr4642, yyrl4642 int - var yyrt4642 bool - if yyl4642 > cap(yyv4642) { + } else if yyl4633 > 0 { + var yyrr4633, yyrl4633 int + var yyrt4633 bool + if yyl4633 > cap(yyv4633) { - yyrg4642 := len(yyv4642) > 0 - yyv24642 := yyv4642 - yyrl4642, yyrt4642 = z.DecInferLen(yyl4642, z.DecBasicHandle().MaxInitLen, 24) - if yyrt4642 { - if yyrl4642 <= cap(yyv4642) { - yyv4642 = yyv4642[:yyrl4642] + yyrg4633 := len(yyv4633) > 0 + yyv24633 := yyv4633 + yyrl4633, yyrt4633 = z.DecInferLen(yyl4633, z.DecBasicHandle().MaxInitLen, 24) + if yyrt4633 { + if yyrl4633 <= cap(yyv4633) { + yyv4633 = yyv4633[:yyrl4633] } else { - yyv4642 = make([]NodeSelectorTerm, yyrl4642) + yyv4633 = make([]NodeSelectorTerm, yyrl4633) } } else { - yyv4642 = make([]NodeSelectorTerm, yyrl4642) + yyv4633 = make([]NodeSelectorTerm, yyrl4633) } - yyc4642 = true - yyrr4642 = len(yyv4642) - if yyrg4642 { - copy(yyv4642, yyv24642) + yyc4633 = true + yyrr4633 = len(yyv4633) + if yyrg4633 { + copy(yyv4633, yyv24633) } - } else if yyl4642 != len(yyv4642) { - yyv4642 = yyv4642[:yyl4642] - yyc4642 = true + } else if yyl4633 != len(yyv4633) { + yyv4633 = yyv4633[:yyl4633] + yyc4633 = true } - yyj4642 := 0 - for ; yyj4642 < yyrr4642; yyj4642++ { - yyh4642.ElemContainerState(yyj4642) + yyj4633 := 0 + for ; yyj4633 < yyrr4633; yyj4633++ { + yyh4633.ElemContainerState(yyj4633) if r.TryDecodeAsNil() { - yyv4642[yyj4642] = NodeSelectorTerm{} + yyv4633[yyj4633] = NodeSelectorTerm{} } else { - yyv4643 := &yyv4642[yyj4642] - yyv4643.CodecDecodeSelf(d) + yyv4634 := &yyv4633[yyj4633] + yyv4634.CodecDecodeSelf(d) } } - if yyrt4642 { - for ; yyj4642 < yyl4642; yyj4642++ { - yyv4642 = append(yyv4642, NodeSelectorTerm{}) - yyh4642.ElemContainerState(yyj4642) + if yyrt4633 { + for ; yyj4633 < yyl4633; yyj4633++ { + yyv4633 = append(yyv4633, NodeSelectorTerm{}) + yyh4633.ElemContainerState(yyj4633) if r.TryDecodeAsNil() { - yyv4642[yyj4642] = NodeSelectorTerm{} + yyv4633[yyj4633] = NodeSelectorTerm{} } else { - yyv4644 := &yyv4642[yyj4642] - yyv4644.CodecDecodeSelf(d) + yyv4635 := &yyv4633[yyj4633] + yyv4635.CodecDecodeSelf(d) } } } } else { - yyj4642 := 0 - for ; !r.CheckBreak(); yyj4642++ { + yyj4633 := 0 + for ; !r.CheckBreak(); yyj4633++ { - if yyj4642 >= len(yyv4642) { - yyv4642 = append(yyv4642, NodeSelectorTerm{}) // var yyz4642 NodeSelectorTerm - yyc4642 = true + if yyj4633 >= len(yyv4633) { + yyv4633 = append(yyv4633, NodeSelectorTerm{}) // var yyz4633 NodeSelectorTerm + yyc4633 = true } - yyh4642.ElemContainerState(yyj4642) - if yyj4642 < len(yyv4642) { + yyh4633.ElemContainerState(yyj4633) + if yyj4633 < len(yyv4633) { if r.TryDecodeAsNil() { - yyv4642[yyj4642] = NodeSelectorTerm{} + yyv4633[yyj4633] = NodeSelectorTerm{} } else { - yyv4645 := &yyv4642[yyj4642] - yyv4645.CodecDecodeSelf(d) + yyv4636 := &yyv4633[yyj4633] + yyv4636.CodecDecodeSelf(d) } } else { @@ -58164,17 +58082,17 @@ func (x codecSelfer1234) decSliceNodeSelectorTerm(v *[]NodeSelectorTerm, d *code } } - if yyj4642 < len(yyv4642) { - yyv4642 = yyv4642[:yyj4642] - yyc4642 = true - } else if yyj4642 == 0 && yyv4642 == nil { - yyv4642 = []NodeSelectorTerm{} - yyc4642 = true + if yyj4633 < len(yyv4633) { + yyv4633 = yyv4633[:yyj4633] + yyc4633 = true + } else if yyj4633 == 0 && yyv4633 == nil { + yyv4633 = []NodeSelectorTerm{} + yyc4633 = true } } - yyh4642.End() - if yyc4642 { - *v = yyv4642 + yyh4633.End() + if yyc4633 { + *v = yyv4633 } } @@ -58183,10 +58101,10 @@ func (x codecSelfer1234) encSliceNodeSelectorRequirement(v []NodeSelectorRequire z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4646 := range v { + for _, yyv4637 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4647 := &yyv4646 - yy4647.CodecEncodeSelf(e) + yy4638 := &yyv4637 + yy4638.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58196,83 +58114,83 @@ func (x codecSelfer1234) decSliceNodeSelectorRequirement(v *[]NodeSelectorRequir z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4648 := *v - yyh4648, yyl4648 := z.DecSliceHelperStart() - var yyc4648 bool - if yyl4648 == 0 { - if yyv4648 == nil { - yyv4648 = []NodeSelectorRequirement{} - yyc4648 = true - } else if len(yyv4648) != 0 { - yyv4648 = yyv4648[:0] - yyc4648 = true + yyv4639 := *v + yyh4639, yyl4639 := z.DecSliceHelperStart() + var yyc4639 bool + if yyl4639 == 0 { + if yyv4639 == nil { + yyv4639 = []NodeSelectorRequirement{} + yyc4639 = true + } else if len(yyv4639) != 0 { + yyv4639 = yyv4639[:0] + yyc4639 = true } - } else if yyl4648 > 0 { - var yyrr4648, yyrl4648 int - var yyrt4648 bool - if yyl4648 > cap(yyv4648) { + } else if yyl4639 > 0 { + var yyrr4639, yyrl4639 int + var yyrt4639 bool + if yyl4639 > cap(yyv4639) { - yyrg4648 := len(yyv4648) > 0 - yyv24648 := yyv4648 - yyrl4648, yyrt4648 = z.DecInferLen(yyl4648, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4648 { - if yyrl4648 <= cap(yyv4648) { - yyv4648 = yyv4648[:yyrl4648] + yyrg4639 := len(yyv4639) > 0 + yyv24639 := yyv4639 + yyrl4639, yyrt4639 = z.DecInferLen(yyl4639, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4639 { + if yyrl4639 <= cap(yyv4639) { + yyv4639 = yyv4639[:yyrl4639] } else { - yyv4648 = make([]NodeSelectorRequirement, yyrl4648) + yyv4639 = make([]NodeSelectorRequirement, yyrl4639) } } else { - yyv4648 = make([]NodeSelectorRequirement, yyrl4648) + yyv4639 = make([]NodeSelectorRequirement, yyrl4639) } - yyc4648 = true - yyrr4648 = len(yyv4648) - if yyrg4648 { - copy(yyv4648, yyv24648) + yyc4639 = true + yyrr4639 = len(yyv4639) + if yyrg4639 { + copy(yyv4639, yyv24639) } - } else if yyl4648 != len(yyv4648) { - yyv4648 = yyv4648[:yyl4648] - yyc4648 = true + } else if yyl4639 != len(yyv4639) { + yyv4639 = yyv4639[:yyl4639] + yyc4639 = true } - yyj4648 := 0 - for ; yyj4648 < yyrr4648; yyj4648++ { - yyh4648.ElemContainerState(yyj4648) + yyj4639 := 0 + for ; yyj4639 < yyrr4639; yyj4639++ { + yyh4639.ElemContainerState(yyj4639) if r.TryDecodeAsNil() { - yyv4648[yyj4648] = NodeSelectorRequirement{} + yyv4639[yyj4639] = NodeSelectorRequirement{} } else { - yyv4649 := &yyv4648[yyj4648] - yyv4649.CodecDecodeSelf(d) + yyv4640 := &yyv4639[yyj4639] + yyv4640.CodecDecodeSelf(d) } } - if yyrt4648 { - for ; yyj4648 < yyl4648; yyj4648++ { - yyv4648 = append(yyv4648, NodeSelectorRequirement{}) - yyh4648.ElemContainerState(yyj4648) + if yyrt4639 { + for ; yyj4639 < yyl4639; yyj4639++ { + yyv4639 = append(yyv4639, NodeSelectorRequirement{}) + yyh4639.ElemContainerState(yyj4639) if r.TryDecodeAsNil() { - yyv4648[yyj4648] = NodeSelectorRequirement{} + yyv4639[yyj4639] = NodeSelectorRequirement{} } else { - yyv4650 := &yyv4648[yyj4648] - yyv4650.CodecDecodeSelf(d) + yyv4641 := &yyv4639[yyj4639] + yyv4641.CodecDecodeSelf(d) } } } } else { - yyj4648 := 0 - for ; !r.CheckBreak(); yyj4648++ { + yyj4639 := 0 + for ; !r.CheckBreak(); yyj4639++ { - if yyj4648 >= len(yyv4648) { - yyv4648 = append(yyv4648, NodeSelectorRequirement{}) // var yyz4648 NodeSelectorRequirement - yyc4648 = true + if yyj4639 >= len(yyv4639) { + yyv4639 = append(yyv4639, NodeSelectorRequirement{}) // var yyz4639 NodeSelectorRequirement + yyc4639 = true } - yyh4648.ElemContainerState(yyj4648) - if yyj4648 < len(yyv4648) { + yyh4639.ElemContainerState(yyj4639) + if yyj4639 < len(yyv4639) { if r.TryDecodeAsNil() { - yyv4648[yyj4648] = NodeSelectorRequirement{} + yyv4639[yyj4639] = NodeSelectorRequirement{} } else { - yyv4651 := &yyv4648[yyj4648] - yyv4651.CodecDecodeSelf(d) + yyv4642 := &yyv4639[yyj4639] + yyv4642.CodecDecodeSelf(d) } } else { @@ -58280,17 +58198,17 @@ func (x codecSelfer1234) decSliceNodeSelectorRequirement(v *[]NodeSelectorRequir } } - if yyj4648 < len(yyv4648) { - yyv4648 = yyv4648[:yyj4648] - yyc4648 = true - } else if yyj4648 == 0 && yyv4648 == nil { - yyv4648 = []NodeSelectorRequirement{} - yyc4648 = true + if yyj4639 < len(yyv4639) { + yyv4639 = yyv4639[:yyj4639] + yyc4639 = true + } else if yyj4639 == 0 && yyv4639 == nil { + yyv4639 = []NodeSelectorRequirement{} + yyc4639 = true } } - yyh4648.End() - if yyc4648 { - *v = yyv4648 + yyh4639.End() + if yyc4639 { + *v = yyv4639 } } @@ -58299,10 +58217,10 @@ func (x codecSelfer1234) encSlicePodAffinityTerm(v []PodAffinityTerm, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4652 := range v { + for _, yyv4643 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4653 := &yyv4652 - yy4653.CodecEncodeSelf(e) + yy4644 := &yyv4643 + yy4644.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58312,83 +58230,83 @@ func (x codecSelfer1234) decSlicePodAffinityTerm(v *[]PodAffinityTerm, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4654 := *v - yyh4654, yyl4654 := z.DecSliceHelperStart() - var yyc4654 bool - if yyl4654 == 0 { - if yyv4654 == nil { - yyv4654 = []PodAffinityTerm{} - yyc4654 = true - } else if len(yyv4654) != 0 { - yyv4654 = yyv4654[:0] - yyc4654 = true + yyv4645 := *v + yyh4645, yyl4645 := z.DecSliceHelperStart() + var yyc4645 bool + if yyl4645 == 0 { + if yyv4645 == nil { + yyv4645 = []PodAffinityTerm{} + yyc4645 = true + } else if len(yyv4645) != 0 { + yyv4645 = yyv4645[:0] + yyc4645 = true } - } else if yyl4654 > 0 { - var yyrr4654, yyrl4654 int - var yyrt4654 bool - if yyl4654 > cap(yyv4654) { + } else if yyl4645 > 0 { + var yyrr4645, yyrl4645 int + var yyrt4645 bool + if yyl4645 > cap(yyv4645) { - yyrg4654 := len(yyv4654) > 0 - yyv24654 := yyv4654 - yyrl4654, yyrt4654 = z.DecInferLen(yyl4654, z.DecBasicHandle().MaxInitLen, 48) - if yyrt4654 { - if yyrl4654 <= cap(yyv4654) { - yyv4654 = yyv4654[:yyrl4654] + yyrg4645 := len(yyv4645) > 0 + yyv24645 := yyv4645 + yyrl4645, yyrt4645 = z.DecInferLen(yyl4645, z.DecBasicHandle().MaxInitLen, 48) + if yyrt4645 { + if yyrl4645 <= cap(yyv4645) { + yyv4645 = yyv4645[:yyrl4645] } else { - yyv4654 = make([]PodAffinityTerm, yyrl4654) + yyv4645 = make([]PodAffinityTerm, yyrl4645) } } else { - yyv4654 = make([]PodAffinityTerm, yyrl4654) + yyv4645 = make([]PodAffinityTerm, yyrl4645) } - yyc4654 = true - yyrr4654 = len(yyv4654) - if yyrg4654 { - copy(yyv4654, yyv24654) + yyc4645 = true + yyrr4645 = len(yyv4645) + if yyrg4645 { + copy(yyv4645, yyv24645) } - } else if yyl4654 != len(yyv4654) { - yyv4654 = yyv4654[:yyl4654] - yyc4654 = true + } else if yyl4645 != len(yyv4645) { + yyv4645 = yyv4645[:yyl4645] + yyc4645 = true } - yyj4654 := 0 - for ; yyj4654 < yyrr4654; yyj4654++ { - yyh4654.ElemContainerState(yyj4654) + yyj4645 := 0 + for ; yyj4645 < yyrr4645; yyj4645++ { + yyh4645.ElemContainerState(yyj4645) if r.TryDecodeAsNil() { - yyv4654[yyj4654] = PodAffinityTerm{} + yyv4645[yyj4645] = PodAffinityTerm{} } else { - yyv4655 := &yyv4654[yyj4654] - yyv4655.CodecDecodeSelf(d) + yyv4646 := &yyv4645[yyj4645] + yyv4646.CodecDecodeSelf(d) } } - if yyrt4654 { - for ; yyj4654 < yyl4654; yyj4654++ { - yyv4654 = append(yyv4654, PodAffinityTerm{}) - yyh4654.ElemContainerState(yyj4654) + if yyrt4645 { + for ; yyj4645 < yyl4645; yyj4645++ { + yyv4645 = append(yyv4645, PodAffinityTerm{}) + yyh4645.ElemContainerState(yyj4645) if r.TryDecodeAsNil() { - yyv4654[yyj4654] = PodAffinityTerm{} + yyv4645[yyj4645] = PodAffinityTerm{} } else { - yyv4656 := &yyv4654[yyj4654] - yyv4656.CodecDecodeSelf(d) + yyv4647 := &yyv4645[yyj4645] + yyv4647.CodecDecodeSelf(d) } } } } else { - yyj4654 := 0 - for ; !r.CheckBreak(); yyj4654++ { + yyj4645 := 0 + for ; !r.CheckBreak(); yyj4645++ { - if yyj4654 >= len(yyv4654) { - yyv4654 = append(yyv4654, PodAffinityTerm{}) // var yyz4654 PodAffinityTerm - yyc4654 = true + if yyj4645 >= len(yyv4645) { + yyv4645 = append(yyv4645, PodAffinityTerm{}) // var yyz4645 PodAffinityTerm + yyc4645 = true } - yyh4654.ElemContainerState(yyj4654) - if yyj4654 < len(yyv4654) { + yyh4645.ElemContainerState(yyj4645) + if yyj4645 < len(yyv4645) { if r.TryDecodeAsNil() { - yyv4654[yyj4654] = PodAffinityTerm{} + yyv4645[yyj4645] = PodAffinityTerm{} } else { - yyv4657 := &yyv4654[yyj4654] - yyv4657.CodecDecodeSelf(d) + yyv4648 := &yyv4645[yyj4645] + yyv4648.CodecDecodeSelf(d) } } else { @@ -58396,17 +58314,17 @@ func (x codecSelfer1234) decSlicePodAffinityTerm(v *[]PodAffinityTerm, d *codec1 } } - if yyj4654 < len(yyv4654) { - yyv4654 = yyv4654[:yyj4654] - yyc4654 = true - } else if yyj4654 == 0 && yyv4654 == nil { - yyv4654 = []PodAffinityTerm{} - yyc4654 = true + if yyj4645 < len(yyv4645) { + yyv4645 = yyv4645[:yyj4645] + yyc4645 = true + } else if yyj4645 == 0 && yyv4645 == nil { + yyv4645 = []PodAffinityTerm{} + yyc4645 = true } } - yyh4654.End() - if yyc4654 { - *v = yyv4654 + yyh4645.End() + if yyc4645 { + *v = yyv4645 } } @@ -58415,10 +58333,10 @@ func (x codecSelfer1234) encSliceWeightedPodAffinityTerm(v []WeightedPodAffinity z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4658 := range v { + for _, yyv4649 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4659 := &yyv4658 - yy4659.CodecEncodeSelf(e) + yy4650 := &yyv4649 + yy4650.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58428,83 +58346,83 @@ func (x codecSelfer1234) decSliceWeightedPodAffinityTerm(v *[]WeightedPodAffinit z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4660 := *v - yyh4660, yyl4660 := z.DecSliceHelperStart() - var yyc4660 bool - if yyl4660 == 0 { - if yyv4660 == nil { - yyv4660 = []WeightedPodAffinityTerm{} - yyc4660 = true - } else if len(yyv4660) != 0 { - yyv4660 = yyv4660[:0] - yyc4660 = true + yyv4651 := *v + yyh4651, yyl4651 := z.DecSliceHelperStart() + var yyc4651 bool + if yyl4651 == 0 { + if yyv4651 == nil { + yyv4651 = []WeightedPodAffinityTerm{} + yyc4651 = true + } else if len(yyv4651) != 0 { + yyv4651 = yyv4651[:0] + yyc4651 = true } - } else if yyl4660 > 0 { - var yyrr4660, yyrl4660 int - var yyrt4660 bool - if yyl4660 > cap(yyv4660) { + } else if yyl4651 > 0 { + var yyrr4651, yyrl4651 int + var yyrt4651 bool + if yyl4651 > cap(yyv4651) { - yyrg4660 := len(yyv4660) > 0 - yyv24660 := yyv4660 - yyrl4660, yyrt4660 = z.DecInferLen(yyl4660, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4660 { - if yyrl4660 <= cap(yyv4660) { - yyv4660 = yyv4660[:yyrl4660] + yyrg4651 := len(yyv4651) > 0 + yyv24651 := yyv4651 + yyrl4651, yyrt4651 = z.DecInferLen(yyl4651, z.DecBasicHandle().MaxInitLen, 56) + if yyrt4651 { + if yyrl4651 <= cap(yyv4651) { + yyv4651 = yyv4651[:yyrl4651] } else { - yyv4660 = make([]WeightedPodAffinityTerm, yyrl4660) + yyv4651 = make([]WeightedPodAffinityTerm, yyrl4651) } } else { - yyv4660 = make([]WeightedPodAffinityTerm, yyrl4660) + yyv4651 = make([]WeightedPodAffinityTerm, yyrl4651) } - yyc4660 = true - yyrr4660 = len(yyv4660) - if yyrg4660 { - copy(yyv4660, yyv24660) + yyc4651 = true + yyrr4651 = len(yyv4651) + if yyrg4651 { + copy(yyv4651, yyv24651) } - } else if yyl4660 != len(yyv4660) { - yyv4660 = yyv4660[:yyl4660] - yyc4660 = true + } else if yyl4651 != len(yyv4651) { + yyv4651 = yyv4651[:yyl4651] + yyc4651 = true } - yyj4660 := 0 - for ; yyj4660 < yyrr4660; yyj4660++ { - yyh4660.ElemContainerState(yyj4660) + yyj4651 := 0 + for ; yyj4651 < yyrr4651; yyj4651++ { + yyh4651.ElemContainerState(yyj4651) if r.TryDecodeAsNil() { - yyv4660[yyj4660] = WeightedPodAffinityTerm{} + yyv4651[yyj4651] = WeightedPodAffinityTerm{} } else { - yyv4661 := &yyv4660[yyj4660] - yyv4661.CodecDecodeSelf(d) + yyv4652 := &yyv4651[yyj4651] + yyv4652.CodecDecodeSelf(d) } } - if yyrt4660 { - for ; yyj4660 < yyl4660; yyj4660++ { - yyv4660 = append(yyv4660, WeightedPodAffinityTerm{}) - yyh4660.ElemContainerState(yyj4660) + if yyrt4651 { + for ; yyj4651 < yyl4651; yyj4651++ { + yyv4651 = append(yyv4651, WeightedPodAffinityTerm{}) + yyh4651.ElemContainerState(yyj4651) if r.TryDecodeAsNil() { - yyv4660[yyj4660] = WeightedPodAffinityTerm{} + yyv4651[yyj4651] = WeightedPodAffinityTerm{} } else { - yyv4662 := &yyv4660[yyj4660] - yyv4662.CodecDecodeSelf(d) + yyv4653 := &yyv4651[yyj4651] + yyv4653.CodecDecodeSelf(d) } } } } else { - yyj4660 := 0 - for ; !r.CheckBreak(); yyj4660++ { + yyj4651 := 0 + for ; !r.CheckBreak(); yyj4651++ { - if yyj4660 >= len(yyv4660) { - yyv4660 = append(yyv4660, WeightedPodAffinityTerm{}) // var yyz4660 WeightedPodAffinityTerm - yyc4660 = true + if yyj4651 >= len(yyv4651) { + yyv4651 = append(yyv4651, WeightedPodAffinityTerm{}) // var yyz4651 WeightedPodAffinityTerm + yyc4651 = true } - yyh4660.ElemContainerState(yyj4660) - if yyj4660 < len(yyv4660) { + yyh4651.ElemContainerState(yyj4651) + if yyj4651 < len(yyv4651) { if r.TryDecodeAsNil() { - yyv4660[yyj4660] = WeightedPodAffinityTerm{} + yyv4651[yyj4651] = WeightedPodAffinityTerm{} } else { - yyv4663 := &yyv4660[yyj4660] - yyv4663.CodecDecodeSelf(d) + yyv4654 := &yyv4651[yyj4651] + yyv4654.CodecDecodeSelf(d) } } else { @@ -58512,17 +58430,17 @@ func (x codecSelfer1234) decSliceWeightedPodAffinityTerm(v *[]WeightedPodAffinit } } - if yyj4660 < len(yyv4660) { - yyv4660 = yyv4660[:yyj4660] - yyc4660 = true - } else if yyj4660 == 0 && yyv4660 == nil { - yyv4660 = []WeightedPodAffinityTerm{} - yyc4660 = true + if yyj4651 < len(yyv4651) { + yyv4651 = yyv4651[:yyj4651] + yyc4651 = true + } else if yyj4651 == 0 && yyv4651 == nil { + yyv4651 = []WeightedPodAffinityTerm{} + yyc4651 = true } } - yyh4660.End() - if yyc4660 { - *v = yyv4660 + yyh4651.End() + if yyc4651 { + *v = yyv4651 } } @@ -58531,10 +58449,10 @@ func (x codecSelfer1234) encSlicePreferredSchedulingTerm(v []PreferredScheduling z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4664 := range v { + for _, yyv4655 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4665 := &yyv4664 - yy4665.CodecEncodeSelf(e) + yy4656 := &yyv4655 + yy4656.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58544,83 +58462,83 @@ func (x codecSelfer1234) decSlicePreferredSchedulingTerm(v *[]PreferredSchedulin z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4666 := *v - yyh4666, yyl4666 := z.DecSliceHelperStart() - var yyc4666 bool - if yyl4666 == 0 { - if yyv4666 == nil { - yyv4666 = []PreferredSchedulingTerm{} - yyc4666 = true - } else if len(yyv4666) != 0 { - yyv4666 = yyv4666[:0] - yyc4666 = true + yyv4657 := *v + yyh4657, yyl4657 := z.DecSliceHelperStart() + var yyc4657 bool + if yyl4657 == 0 { + if yyv4657 == nil { + yyv4657 = []PreferredSchedulingTerm{} + yyc4657 = true + } else if len(yyv4657) != 0 { + yyv4657 = yyv4657[:0] + yyc4657 = true } - } else if yyl4666 > 0 { - var yyrr4666, yyrl4666 int - var yyrt4666 bool - if yyl4666 > cap(yyv4666) { + } else if yyl4657 > 0 { + var yyrr4657, yyrl4657 int + var yyrt4657 bool + if yyl4657 > cap(yyv4657) { - yyrg4666 := len(yyv4666) > 0 - yyv24666 := yyv4666 - yyrl4666, yyrt4666 = z.DecInferLen(yyl4666, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4666 { - if yyrl4666 <= cap(yyv4666) { - yyv4666 = yyv4666[:yyrl4666] + yyrg4657 := len(yyv4657) > 0 + yyv24657 := yyv4657 + yyrl4657, yyrt4657 = z.DecInferLen(yyl4657, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4657 { + if yyrl4657 <= cap(yyv4657) { + yyv4657 = yyv4657[:yyrl4657] } else { - yyv4666 = make([]PreferredSchedulingTerm, yyrl4666) + yyv4657 = make([]PreferredSchedulingTerm, yyrl4657) } } else { - yyv4666 = make([]PreferredSchedulingTerm, yyrl4666) + yyv4657 = make([]PreferredSchedulingTerm, yyrl4657) } - yyc4666 = true - yyrr4666 = len(yyv4666) - if yyrg4666 { - copy(yyv4666, yyv24666) + yyc4657 = true + yyrr4657 = len(yyv4657) + if yyrg4657 { + copy(yyv4657, yyv24657) } - } else if yyl4666 != len(yyv4666) { - yyv4666 = yyv4666[:yyl4666] - yyc4666 = true + } else if yyl4657 != len(yyv4657) { + yyv4657 = yyv4657[:yyl4657] + yyc4657 = true } - yyj4666 := 0 - for ; yyj4666 < yyrr4666; yyj4666++ { - yyh4666.ElemContainerState(yyj4666) + yyj4657 := 0 + for ; yyj4657 < yyrr4657; yyj4657++ { + yyh4657.ElemContainerState(yyj4657) if r.TryDecodeAsNil() { - yyv4666[yyj4666] = PreferredSchedulingTerm{} + yyv4657[yyj4657] = PreferredSchedulingTerm{} } else { - yyv4667 := &yyv4666[yyj4666] - yyv4667.CodecDecodeSelf(d) + yyv4658 := &yyv4657[yyj4657] + yyv4658.CodecDecodeSelf(d) } } - if yyrt4666 { - for ; yyj4666 < yyl4666; yyj4666++ { - yyv4666 = append(yyv4666, PreferredSchedulingTerm{}) - yyh4666.ElemContainerState(yyj4666) + if yyrt4657 { + for ; yyj4657 < yyl4657; yyj4657++ { + yyv4657 = append(yyv4657, PreferredSchedulingTerm{}) + yyh4657.ElemContainerState(yyj4657) if r.TryDecodeAsNil() { - yyv4666[yyj4666] = PreferredSchedulingTerm{} + yyv4657[yyj4657] = PreferredSchedulingTerm{} } else { - yyv4668 := &yyv4666[yyj4666] - yyv4668.CodecDecodeSelf(d) + yyv4659 := &yyv4657[yyj4657] + yyv4659.CodecDecodeSelf(d) } } } } else { - yyj4666 := 0 - for ; !r.CheckBreak(); yyj4666++ { + yyj4657 := 0 + for ; !r.CheckBreak(); yyj4657++ { - if yyj4666 >= len(yyv4666) { - yyv4666 = append(yyv4666, PreferredSchedulingTerm{}) // var yyz4666 PreferredSchedulingTerm - yyc4666 = true + if yyj4657 >= len(yyv4657) { + yyv4657 = append(yyv4657, PreferredSchedulingTerm{}) // var yyz4657 PreferredSchedulingTerm + yyc4657 = true } - yyh4666.ElemContainerState(yyj4666) - if yyj4666 < len(yyv4666) { + yyh4657.ElemContainerState(yyj4657) + if yyj4657 < len(yyv4657) { if r.TryDecodeAsNil() { - yyv4666[yyj4666] = PreferredSchedulingTerm{} + yyv4657[yyj4657] = PreferredSchedulingTerm{} } else { - yyv4669 := &yyv4666[yyj4666] - yyv4669.CodecDecodeSelf(d) + yyv4660 := &yyv4657[yyj4657] + yyv4660.CodecDecodeSelf(d) } } else { @@ -58628,17 +58546,17 @@ func (x codecSelfer1234) decSlicePreferredSchedulingTerm(v *[]PreferredSchedulin } } - if yyj4666 < len(yyv4666) { - yyv4666 = yyv4666[:yyj4666] - yyc4666 = true - } else if yyj4666 == 0 && yyv4666 == nil { - yyv4666 = []PreferredSchedulingTerm{} - yyc4666 = true + if yyj4657 < len(yyv4657) { + yyv4657 = yyv4657[:yyj4657] + yyc4657 = true + } else if yyj4657 == 0 && yyv4657 == nil { + yyv4657 = []PreferredSchedulingTerm{} + yyc4657 = true } } - yyh4666.End() - if yyc4666 { - *v = yyv4666 + yyh4657.End() + if yyc4657 { + *v = yyv4657 } } @@ -58647,10 +58565,10 @@ func (x codecSelfer1234) encSliceVolume(v []Volume, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4670 := range v { + for _, yyv4661 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4671 := &yyv4670 - yy4671.CodecEncodeSelf(e) + yy4662 := &yyv4661 + yy4662.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58660,83 +58578,83 @@ func (x codecSelfer1234) decSliceVolume(v *[]Volume, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4672 := *v - yyh4672, yyl4672 := z.DecSliceHelperStart() - var yyc4672 bool - if yyl4672 == 0 { - if yyv4672 == nil { - yyv4672 = []Volume{} - yyc4672 = true - } else if len(yyv4672) != 0 { - yyv4672 = yyv4672[:0] - yyc4672 = true + yyv4663 := *v + yyh4663, yyl4663 := z.DecSliceHelperStart() + var yyc4663 bool + if yyl4663 == 0 { + if yyv4663 == nil { + yyv4663 = []Volume{} + yyc4663 = true + } else if len(yyv4663) != 0 { + yyv4663 = yyv4663[:0] + yyc4663 = true } - } else if yyl4672 > 0 { - var yyrr4672, yyrl4672 int - var yyrt4672 bool - if yyl4672 > cap(yyv4672) { + } else if yyl4663 > 0 { + var yyrr4663, yyrl4663 int + var yyrt4663 bool + if yyl4663 > cap(yyv4663) { - yyrg4672 := len(yyv4672) > 0 - yyv24672 := yyv4672 - yyrl4672, yyrt4672 = z.DecInferLen(yyl4672, z.DecBasicHandle().MaxInitLen, 192) - if yyrt4672 { - if yyrl4672 <= cap(yyv4672) { - yyv4672 = yyv4672[:yyrl4672] + yyrg4663 := len(yyv4663) > 0 + yyv24663 := yyv4663 + yyrl4663, yyrt4663 = z.DecInferLen(yyl4663, z.DecBasicHandle().MaxInitLen, 192) + if yyrt4663 { + if yyrl4663 <= cap(yyv4663) { + yyv4663 = yyv4663[:yyrl4663] } else { - yyv4672 = make([]Volume, yyrl4672) + yyv4663 = make([]Volume, yyrl4663) } } else { - yyv4672 = make([]Volume, yyrl4672) + yyv4663 = make([]Volume, yyrl4663) } - yyc4672 = true - yyrr4672 = len(yyv4672) - if yyrg4672 { - copy(yyv4672, yyv24672) + yyc4663 = true + yyrr4663 = len(yyv4663) + if yyrg4663 { + copy(yyv4663, yyv24663) } - } else if yyl4672 != len(yyv4672) { - yyv4672 = yyv4672[:yyl4672] - yyc4672 = true + } else if yyl4663 != len(yyv4663) { + yyv4663 = yyv4663[:yyl4663] + yyc4663 = true } - yyj4672 := 0 - for ; yyj4672 < yyrr4672; yyj4672++ { - yyh4672.ElemContainerState(yyj4672) + yyj4663 := 0 + for ; yyj4663 < yyrr4663; yyj4663++ { + yyh4663.ElemContainerState(yyj4663) if r.TryDecodeAsNil() { - yyv4672[yyj4672] = Volume{} + yyv4663[yyj4663] = Volume{} } else { - yyv4673 := &yyv4672[yyj4672] - yyv4673.CodecDecodeSelf(d) + yyv4664 := &yyv4663[yyj4663] + yyv4664.CodecDecodeSelf(d) } } - if yyrt4672 { - for ; yyj4672 < yyl4672; yyj4672++ { - yyv4672 = append(yyv4672, Volume{}) - yyh4672.ElemContainerState(yyj4672) + if yyrt4663 { + for ; yyj4663 < yyl4663; yyj4663++ { + yyv4663 = append(yyv4663, Volume{}) + yyh4663.ElemContainerState(yyj4663) if r.TryDecodeAsNil() { - yyv4672[yyj4672] = Volume{} + yyv4663[yyj4663] = Volume{} } else { - yyv4674 := &yyv4672[yyj4672] - yyv4674.CodecDecodeSelf(d) + yyv4665 := &yyv4663[yyj4663] + yyv4665.CodecDecodeSelf(d) } } } } else { - yyj4672 := 0 - for ; !r.CheckBreak(); yyj4672++ { + yyj4663 := 0 + for ; !r.CheckBreak(); yyj4663++ { - if yyj4672 >= len(yyv4672) { - yyv4672 = append(yyv4672, Volume{}) // var yyz4672 Volume - yyc4672 = true + if yyj4663 >= len(yyv4663) { + yyv4663 = append(yyv4663, Volume{}) // var yyz4663 Volume + yyc4663 = true } - yyh4672.ElemContainerState(yyj4672) - if yyj4672 < len(yyv4672) { + yyh4663.ElemContainerState(yyj4663) + if yyj4663 < len(yyv4663) { if r.TryDecodeAsNil() { - yyv4672[yyj4672] = Volume{} + yyv4663[yyj4663] = Volume{} } else { - yyv4675 := &yyv4672[yyj4672] - yyv4675.CodecDecodeSelf(d) + yyv4666 := &yyv4663[yyj4663] + yyv4666.CodecDecodeSelf(d) } } else { @@ -58744,17 +58662,17 @@ func (x codecSelfer1234) decSliceVolume(v *[]Volume, d *codec1978.Decoder) { } } - if yyj4672 < len(yyv4672) { - yyv4672 = yyv4672[:yyj4672] - yyc4672 = true - } else if yyj4672 == 0 && yyv4672 == nil { - yyv4672 = []Volume{} - yyc4672 = true + if yyj4663 < len(yyv4663) { + yyv4663 = yyv4663[:yyj4663] + yyc4663 = true + } else if yyj4663 == 0 && yyv4663 == nil { + yyv4663 = []Volume{} + yyc4663 = true } } - yyh4672.End() - if yyc4672 { - *v = yyv4672 + yyh4663.End() + if yyc4663 { + *v = yyv4663 } } @@ -58763,10 +58681,10 @@ func (x codecSelfer1234) encSliceContainer(v []Container, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4676 := range v { + for _, yyv4667 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4677 := &yyv4676 - yy4677.CodecEncodeSelf(e) + yy4668 := &yyv4667 + yy4668.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58776,83 +58694,83 @@ func (x codecSelfer1234) decSliceContainer(v *[]Container, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4678 := *v - yyh4678, yyl4678 := z.DecSliceHelperStart() - var yyc4678 bool - if yyl4678 == 0 { - if yyv4678 == nil { - yyv4678 = []Container{} - yyc4678 = true - } else if len(yyv4678) != 0 { - yyv4678 = yyv4678[:0] - yyc4678 = true + yyv4669 := *v + yyh4669, yyl4669 := z.DecSliceHelperStart() + var yyc4669 bool + if yyl4669 == 0 { + if yyv4669 == nil { + yyv4669 = []Container{} + yyc4669 = true + } else if len(yyv4669) != 0 { + yyv4669 = yyv4669[:0] + yyc4669 = true } - } else if yyl4678 > 0 { - var yyrr4678, yyrl4678 int - var yyrt4678 bool - if yyl4678 > cap(yyv4678) { + } else if yyl4669 > 0 { + var yyrr4669, yyrl4669 int + var yyrt4669 bool + if yyl4669 > cap(yyv4669) { - yyrg4678 := len(yyv4678) > 0 - yyv24678 := yyv4678 - yyrl4678, yyrt4678 = z.DecInferLen(yyl4678, z.DecBasicHandle().MaxInitLen, 256) - if yyrt4678 { - if yyrl4678 <= cap(yyv4678) { - yyv4678 = yyv4678[:yyrl4678] + yyrg4669 := len(yyv4669) > 0 + yyv24669 := yyv4669 + yyrl4669, yyrt4669 = z.DecInferLen(yyl4669, z.DecBasicHandle().MaxInitLen, 256) + if yyrt4669 { + if yyrl4669 <= cap(yyv4669) { + yyv4669 = yyv4669[:yyrl4669] } else { - yyv4678 = make([]Container, yyrl4678) + yyv4669 = make([]Container, yyrl4669) } } else { - yyv4678 = make([]Container, yyrl4678) + yyv4669 = make([]Container, yyrl4669) } - yyc4678 = true - yyrr4678 = len(yyv4678) - if yyrg4678 { - copy(yyv4678, yyv24678) + yyc4669 = true + yyrr4669 = len(yyv4669) + if yyrg4669 { + copy(yyv4669, yyv24669) } - } else if yyl4678 != len(yyv4678) { - yyv4678 = yyv4678[:yyl4678] - yyc4678 = true + } else if yyl4669 != len(yyv4669) { + yyv4669 = yyv4669[:yyl4669] + yyc4669 = true } - yyj4678 := 0 - for ; yyj4678 < yyrr4678; yyj4678++ { - yyh4678.ElemContainerState(yyj4678) + yyj4669 := 0 + for ; yyj4669 < yyrr4669; yyj4669++ { + yyh4669.ElemContainerState(yyj4669) if r.TryDecodeAsNil() { - yyv4678[yyj4678] = Container{} + yyv4669[yyj4669] = Container{} } else { - yyv4679 := &yyv4678[yyj4678] - yyv4679.CodecDecodeSelf(d) + yyv4670 := &yyv4669[yyj4669] + yyv4670.CodecDecodeSelf(d) } } - if yyrt4678 { - for ; yyj4678 < yyl4678; yyj4678++ { - yyv4678 = append(yyv4678, Container{}) - yyh4678.ElemContainerState(yyj4678) + if yyrt4669 { + for ; yyj4669 < yyl4669; yyj4669++ { + yyv4669 = append(yyv4669, Container{}) + yyh4669.ElemContainerState(yyj4669) if r.TryDecodeAsNil() { - yyv4678[yyj4678] = Container{} + yyv4669[yyj4669] = Container{} } else { - yyv4680 := &yyv4678[yyj4678] - yyv4680.CodecDecodeSelf(d) + yyv4671 := &yyv4669[yyj4669] + yyv4671.CodecDecodeSelf(d) } } } } else { - yyj4678 := 0 - for ; !r.CheckBreak(); yyj4678++ { + yyj4669 := 0 + for ; !r.CheckBreak(); yyj4669++ { - if yyj4678 >= len(yyv4678) { - yyv4678 = append(yyv4678, Container{}) // var yyz4678 Container - yyc4678 = true + if yyj4669 >= len(yyv4669) { + yyv4669 = append(yyv4669, Container{}) // var yyz4669 Container + yyc4669 = true } - yyh4678.ElemContainerState(yyj4678) - if yyj4678 < len(yyv4678) { + yyh4669.ElemContainerState(yyj4669) + if yyj4669 < len(yyv4669) { if r.TryDecodeAsNil() { - yyv4678[yyj4678] = Container{} + yyv4669[yyj4669] = Container{} } else { - yyv4681 := &yyv4678[yyj4678] - yyv4681.CodecDecodeSelf(d) + yyv4672 := &yyv4669[yyj4669] + yyv4672.CodecDecodeSelf(d) } } else { @@ -58860,17 +58778,17 @@ func (x codecSelfer1234) decSliceContainer(v *[]Container, d *codec1978.Decoder) } } - if yyj4678 < len(yyv4678) { - yyv4678 = yyv4678[:yyj4678] - yyc4678 = true - } else if yyj4678 == 0 && yyv4678 == nil { - yyv4678 = []Container{} - yyc4678 = true + if yyj4669 < len(yyv4669) { + yyv4669 = yyv4669[:yyj4669] + yyc4669 = true + } else if yyj4669 == 0 && yyv4669 == nil { + yyv4669 = []Container{} + yyc4669 = true } } - yyh4678.End() - if yyc4678 { - *v = yyv4678 + yyh4669.End() + if yyc4669 { + *v = yyv4669 } } @@ -58879,10 +58797,10 @@ func (x codecSelfer1234) encSliceLocalObjectReference(v []LocalObjectReference, z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4682 := range v { + for _, yyv4673 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4683 := &yyv4682 - yy4683.CodecEncodeSelf(e) + yy4674 := &yyv4673 + yy4674.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -58892,83 +58810,83 @@ func (x codecSelfer1234) decSliceLocalObjectReference(v *[]LocalObjectReference, z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4684 := *v - yyh4684, yyl4684 := z.DecSliceHelperStart() - var yyc4684 bool - if yyl4684 == 0 { - if yyv4684 == nil { - yyv4684 = []LocalObjectReference{} - yyc4684 = true - } else if len(yyv4684) != 0 { - yyv4684 = yyv4684[:0] - yyc4684 = true + yyv4675 := *v + yyh4675, yyl4675 := z.DecSliceHelperStart() + var yyc4675 bool + if yyl4675 == 0 { + if yyv4675 == nil { + yyv4675 = []LocalObjectReference{} + yyc4675 = true + } else if len(yyv4675) != 0 { + yyv4675 = yyv4675[:0] + yyc4675 = true } - } else if yyl4684 > 0 { - var yyrr4684, yyrl4684 int - var yyrt4684 bool - if yyl4684 > cap(yyv4684) { + } else if yyl4675 > 0 { + var yyrr4675, yyrl4675 int + var yyrt4675 bool + if yyl4675 > cap(yyv4675) { - yyrg4684 := len(yyv4684) > 0 - yyv24684 := yyv4684 - yyrl4684, yyrt4684 = z.DecInferLen(yyl4684, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4684 { - if yyrl4684 <= cap(yyv4684) { - yyv4684 = yyv4684[:yyrl4684] + yyrg4675 := len(yyv4675) > 0 + yyv24675 := yyv4675 + yyrl4675, yyrt4675 = z.DecInferLen(yyl4675, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4675 { + if yyrl4675 <= cap(yyv4675) { + yyv4675 = yyv4675[:yyrl4675] } else { - yyv4684 = make([]LocalObjectReference, yyrl4684) + yyv4675 = make([]LocalObjectReference, yyrl4675) } } else { - yyv4684 = make([]LocalObjectReference, yyrl4684) + yyv4675 = make([]LocalObjectReference, yyrl4675) } - yyc4684 = true - yyrr4684 = len(yyv4684) - if yyrg4684 { - copy(yyv4684, yyv24684) + yyc4675 = true + yyrr4675 = len(yyv4675) + if yyrg4675 { + copy(yyv4675, yyv24675) } - } else if yyl4684 != len(yyv4684) { - yyv4684 = yyv4684[:yyl4684] - yyc4684 = true + } else if yyl4675 != len(yyv4675) { + yyv4675 = yyv4675[:yyl4675] + yyc4675 = true } - yyj4684 := 0 - for ; yyj4684 < yyrr4684; yyj4684++ { - yyh4684.ElemContainerState(yyj4684) + yyj4675 := 0 + for ; yyj4675 < yyrr4675; yyj4675++ { + yyh4675.ElemContainerState(yyj4675) if r.TryDecodeAsNil() { - yyv4684[yyj4684] = LocalObjectReference{} + yyv4675[yyj4675] = LocalObjectReference{} } else { - yyv4685 := &yyv4684[yyj4684] - yyv4685.CodecDecodeSelf(d) + yyv4676 := &yyv4675[yyj4675] + yyv4676.CodecDecodeSelf(d) } } - if yyrt4684 { - for ; yyj4684 < yyl4684; yyj4684++ { - yyv4684 = append(yyv4684, LocalObjectReference{}) - yyh4684.ElemContainerState(yyj4684) + if yyrt4675 { + for ; yyj4675 < yyl4675; yyj4675++ { + yyv4675 = append(yyv4675, LocalObjectReference{}) + yyh4675.ElemContainerState(yyj4675) if r.TryDecodeAsNil() { - yyv4684[yyj4684] = LocalObjectReference{} + yyv4675[yyj4675] = LocalObjectReference{} } else { - yyv4686 := &yyv4684[yyj4684] - yyv4686.CodecDecodeSelf(d) + yyv4677 := &yyv4675[yyj4675] + yyv4677.CodecDecodeSelf(d) } } } } else { - yyj4684 := 0 - for ; !r.CheckBreak(); yyj4684++ { + yyj4675 := 0 + for ; !r.CheckBreak(); yyj4675++ { - if yyj4684 >= len(yyv4684) { - yyv4684 = append(yyv4684, LocalObjectReference{}) // var yyz4684 LocalObjectReference - yyc4684 = true + if yyj4675 >= len(yyv4675) { + yyv4675 = append(yyv4675, LocalObjectReference{}) // var yyz4675 LocalObjectReference + yyc4675 = true } - yyh4684.ElemContainerState(yyj4684) - if yyj4684 < len(yyv4684) { + yyh4675.ElemContainerState(yyj4675) + if yyj4675 < len(yyv4675) { if r.TryDecodeAsNil() { - yyv4684[yyj4684] = LocalObjectReference{} + yyv4675[yyj4675] = LocalObjectReference{} } else { - yyv4687 := &yyv4684[yyj4684] - yyv4687.CodecDecodeSelf(d) + yyv4678 := &yyv4675[yyj4675] + yyv4678.CodecDecodeSelf(d) } } else { @@ -58976,17 +58894,17 @@ func (x codecSelfer1234) decSliceLocalObjectReference(v *[]LocalObjectReference, } } - if yyj4684 < len(yyv4684) { - yyv4684 = yyv4684[:yyj4684] - yyc4684 = true - } else if yyj4684 == 0 && yyv4684 == nil { - yyv4684 = []LocalObjectReference{} - yyc4684 = true + if yyj4675 < len(yyv4675) { + yyv4675 = yyv4675[:yyj4675] + yyc4675 = true + } else if yyj4675 == 0 && yyv4675 == nil { + yyv4675 = []LocalObjectReference{} + yyc4675 = true } } - yyh4684.End() - if yyc4684 { - *v = yyv4684 + yyh4675.End() + if yyc4675 { + *v = yyv4675 } } @@ -58995,10 +58913,10 @@ func (x codecSelfer1234) encSlicePodCondition(v []PodCondition, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4688 := range v { + for _, yyv4679 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4689 := &yyv4688 - yy4689.CodecEncodeSelf(e) + yy4680 := &yyv4679 + yy4680.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59008,83 +58926,83 @@ func (x codecSelfer1234) decSlicePodCondition(v *[]PodCondition, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4690 := *v - yyh4690, yyl4690 := z.DecSliceHelperStart() - var yyc4690 bool - if yyl4690 == 0 { - if yyv4690 == nil { - yyv4690 = []PodCondition{} - yyc4690 = true - } else if len(yyv4690) != 0 { - yyv4690 = yyv4690[:0] - yyc4690 = true + yyv4681 := *v + yyh4681, yyl4681 := z.DecSliceHelperStart() + var yyc4681 bool + if yyl4681 == 0 { + if yyv4681 == nil { + yyv4681 = []PodCondition{} + yyc4681 = true + } else if len(yyv4681) != 0 { + yyv4681 = yyv4681[:0] + yyc4681 = true } - } else if yyl4690 > 0 { - var yyrr4690, yyrl4690 int - var yyrt4690 bool - if yyl4690 > cap(yyv4690) { + } else if yyl4681 > 0 { + var yyrr4681, yyrl4681 int + var yyrt4681 bool + if yyl4681 > cap(yyv4681) { - yyrg4690 := len(yyv4690) > 0 - yyv24690 := yyv4690 - yyrl4690, yyrt4690 = z.DecInferLen(yyl4690, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4690 { - if yyrl4690 <= cap(yyv4690) { - yyv4690 = yyv4690[:yyrl4690] + yyrg4681 := len(yyv4681) > 0 + yyv24681 := yyv4681 + yyrl4681, yyrt4681 = z.DecInferLen(yyl4681, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4681 { + if yyrl4681 <= cap(yyv4681) { + yyv4681 = yyv4681[:yyrl4681] } else { - yyv4690 = make([]PodCondition, yyrl4690) + yyv4681 = make([]PodCondition, yyrl4681) } } else { - yyv4690 = make([]PodCondition, yyrl4690) + yyv4681 = make([]PodCondition, yyrl4681) } - yyc4690 = true - yyrr4690 = len(yyv4690) - if yyrg4690 { - copy(yyv4690, yyv24690) + yyc4681 = true + yyrr4681 = len(yyv4681) + if yyrg4681 { + copy(yyv4681, yyv24681) } - } else if yyl4690 != len(yyv4690) { - yyv4690 = yyv4690[:yyl4690] - yyc4690 = true + } else if yyl4681 != len(yyv4681) { + yyv4681 = yyv4681[:yyl4681] + yyc4681 = true } - yyj4690 := 0 - for ; yyj4690 < yyrr4690; yyj4690++ { - yyh4690.ElemContainerState(yyj4690) + yyj4681 := 0 + for ; yyj4681 < yyrr4681; yyj4681++ { + yyh4681.ElemContainerState(yyj4681) if r.TryDecodeAsNil() { - yyv4690[yyj4690] = PodCondition{} + yyv4681[yyj4681] = PodCondition{} } else { - yyv4691 := &yyv4690[yyj4690] - yyv4691.CodecDecodeSelf(d) + yyv4682 := &yyv4681[yyj4681] + yyv4682.CodecDecodeSelf(d) } } - if yyrt4690 { - for ; yyj4690 < yyl4690; yyj4690++ { - yyv4690 = append(yyv4690, PodCondition{}) - yyh4690.ElemContainerState(yyj4690) + if yyrt4681 { + for ; yyj4681 < yyl4681; yyj4681++ { + yyv4681 = append(yyv4681, PodCondition{}) + yyh4681.ElemContainerState(yyj4681) if r.TryDecodeAsNil() { - yyv4690[yyj4690] = PodCondition{} + yyv4681[yyj4681] = PodCondition{} } else { - yyv4692 := &yyv4690[yyj4690] - yyv4692.CodecDecodeSelf(d) + yyv4683 := &yyv4681[yyj4681] + yyv4683.CodecDecodeSelf(d) } } } } else { - yyj4690 := 0 - for ; !r.CheckBreak(); yyj4690++ { + yyj4681 := 0 + for ; !r.CheckBreak(); yyj4681++ { - if yyj4690 >= len(yyv4690) { - yyv4690 = append(yyv4690, PodCondition{}) // var yyz4690 PodCondition - yyc4690 = true + if yyj4681 >= len(yyv4681) { + yyv4681 = append(yyv4681, PodCondition{}) // var yyz4681 PodCondition + yyc4681 = true } - yyh4690.ElemContainerState(yyj4690) - if yyj4690 < len(yyv4690) { + yyh4681.ElemContainerState(yyj4681) + if yyj4681 < len(yyv4681) { if r.TryDecodeAsNil() { - yyv4690[yyj4690] = PodCondition{} + yyv4681[yyj4681] = PodCondition{} } else { - yyv4693 := &yyv4690[yyj4690] - yyv4693.CodecDecodeSelf(d) + yyv4684 := &yyv4681[yyj4681] + yyv4684.CodecDecodeSelf(d) } } else { @@ -59092,17 +59010,17 @@ func (x codecSelfer1234) decSlicePodCondition(v *[]PodCondition, d *codec1978.De } } - if yyj4690 < len(yyv4690) { - yyv4690 = yyv4690[:yyj4690] - yyc4690 = true - } else if yyj4690 == 0 && yyv4690 == nil { - yyv4690 = []PodCondition{} - yyc4690 = true + if yyj4681 < len(yyv4681) { + yyv4681 = yyv4681[:yyj4681] + yyc4681 = true + } else if yyj4681 == 0 && yyv4681 == nil { + yyv4681 = []PodCondition{} + yyc4681 = true } } - yyh4690.End() - if yyc4690 { - *v = yyv4690 + yyh4681.End() + if yyc4681 { + *v = yyv4681 } } @@ -59111,10 +59029,10 @@ func (x codecSelfer1234) encSliceContainerStatus(v []ContainerStatus, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4694 := range v { + for _, yyv4685 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4695 := &yyv4694 - yy4695.CodecEncodeSelf(e) + yy4686 := &yyv4685 + yy4686.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59124,83 +59042,83 @@ func (x codecSelfer1234) decSliceContainerStatus(v *[]ContainerStatus, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4696 := *v - yyh4696, yyl4696 := z.DecSliceHelperStart() - var yyc4696 bool - if yyl4696 == 0 { - if yyv4696 == nil { - yyv4696 = []ContainerStatus{} - yyc4696 = true - } else if len(yyv4696) != 0 { - yyv4696 = yyv4696[:0] - yyc4696 = true + yyv4687 := *v + yyh4687, yyl4687 := z.DecSliceHelperStart() + var yyc4687 bool + if yyl4687 == 0 { + if yyv4687 == nil { + yyv4687 = []ContainerStatus{} + yyc4687 = true + } else if len(yyv4687) != 0 { + yyv4687 = yyv4687[:0] + yyc4687 = true } - } else if yyl4696 > 0 { - var yyrr4696, yyrl4696 int - var yyrt4696 bool - if yyl4696 > cap(yyv4696) { + } else if yyl4687 > 0 { + var yyrr4687, yyrl4687 int + var yyrt4687 bool + if yyl4687 > cap(yyv4687) { - yyrg4696 := len(yyv4696) > 0 - yyv24696 := yyv4696 - yyrl4696, yyrt4696 = z.DecInferLen(yyl4696, z.DecBasicHandle().MaxInitLen, 120) - if yyrt4696 { - if yyrl4696 <= cap(yyv4696) { - yyv4696 = yyv4696[:yyrl4696] + yyrg4687 := len(yyv4687) > 0 + yyv24687 := yyv4687 + yyrl4687, yyrt4687 = z.DecInferLen(yyl4687, z.DecBasicHandle().MaxInitLen, 120) + if yyrt4687 { + if yyrl4687 <= cap(yyv4687) { + yyv4687 = yyv4687[:yyrl4687] } else { - yyv4696 = make([]ContainerStatus, yyrl4696) + yyv4687 = make([]ContainerStatus, yyrl4687) } } else { - yyv4696 = make([]ContainerStatus, yyrl4696) + yyv4687 = make([]ContainerStatus, yyrl4687) } - yyc4696 = true - yyrr4696 = len(yyv4696) - if yyrg4696 { - copy(yyv4696, yyv24696) + yyc4687 = true + yyrr4687 = len(yyv4687) + if yyrg4687 { + copy(yyv4687, yyv24687) } - } else if yyl4696 != len(yyv4696) { - yyv4696 = yyv4696[:yyl4696] - yyc4696 = true + } else if yyl4687 != len(yyv4687) { + yyv4687 = yyv4687[:yyl4687] + yyc4687 = true } - yyj4696 := 0 - for ; yyj4696 < yyrr4696; yyj4696++ { - yyh4696.ElemContainerState(yyj4696) + yyj4687 := 0 + for ; yyj4687 < yyrr4687; yyj4687++ { + yyh4687.ElemContainerState(yyj4687) if r.TryDecodeAsNil() { - yyv4696[yyj4696] = ContainerStatus{} + yyv4687[yyj4687] = ContainerStatus{} } else { - yyv4697 := &yyv4696[yyj4696] - yyv4697.CodecDecodeSelf(d) + yyv4688 := &yyv4687[yyj4687] + yyv4688.CodecDecodeSelf(d) } } - if yyrt4696 { - for ; yyj4696 < yyl4696; yyj4696++ { - yyv4696 = append(yyv4696, ContainerStatus{}) - yyh4696.ElemContainerState(yyj4696) + if yyrt4687 { + for ; yyj4687 < yyl4687; yyj4687++ { + yyv4687 = append(yyv4687, ContainerStatus{}) + yyh4687.ElemContainerState(yyj4687) if r.TryDecodeAsNil() { - yyv4696[yyj4696] = ContainerStatus{} + yyv4687[yyj4687] = ContainerStatus{} } else { - yyv4698 := &yyv4696[yyj4696] - yyv4698.CodecDecodeSelf(d) + yyv4689 := &yyv4687[yyj4687] + yyv4689.CodecDecodeSelf(d) } } } } else { - yyj4696 := 0 - for ; !r.CheckBreak(); yyj4696++ { + yyj4687 := 0 + for ; !r.CheckBreak(); yyj4687++ { - if yyj4696 >= len(yyv4696) { - yyv4696 = append(yyv4696, ContainerStatus{}) // var yyz4696 ContainerStatus - yyc4696 = true + if yyj4687 >= len(yyv4687) { + yyv4687 = append(yyv4687, ContainerStatus{}) // var yyz4687 ContainerStatus + yyc4687 = true } - yyh4696.ElemContainerState(yyj4696) - if yyj4696 < len(yyv4696) { + yyh4687.ElemContainerState(yyj4687) + if yyj4687 < len(yyv4687) { if r.TryDecodeAsNil() { - yyv4696[yyj4696] = ContainerStatus{} + yyv4687[yyj4687] = ContainerStatus{} } else { - yyv4699 := &yyv4696[yyj4696] - yyv4699.CodecDecodeSelf(d) + yyv4690 := &yyv4687[yyj4687] + yyv4690.CodecDecodeSelf(d) } } else { @@ -59208,17 +59126,17 @@ func (x codecSelfer1234) decSliceContainerStatus(v *[]ContainerStatus, d *codec1 } } - if yyj4696 < len(yyv4696) { - yyv4696 = yyv4696[:yyj4696] - yyc4696 = true - } else if yyj4696 == 0 && yyv4696 == nil { - yyv4696 = []ContainerStatus{} - yyc4696 = true + if yyj4687 < len(yyv4687) { + yyv4687 = yyv4687[:yyj4687] + yyc4687 = true + } else if yyj4687 == 0 && yyv4687 == nil { + yyv4687 = []ContainerStatus{} + yyc4687 = true } } - yyh4696.End() - if yyc4696 { - *v = yyv4696 + yyh4687.End() + if yyc4687 { + *v = yyv4687 } } @@ -59227,10 +59145,10 @@ func (x codecSelfer1234) encSlicePod(v []Pod, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4700 := range v { + for _, yyv4691 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4701 := &yyv4700 - yy4701.CodecEncodeSelf(e) + yy4692 := &yyv4691 + yy4692.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59240,83 +59158,83 @@ func (x codecSelfer1234) decSlicePod(v *[]Pod, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4702 := *v - yyh4702, yyl4702 := z.DecSliceHelperStart() - var yyc4702 bool - if yyl4702 == 0 { - if yyv4702 == nil { - yyv4702 = []Pod{} - yyc4702 = true - } else if len(yyv4702) != 0 { - yyv4702 = yyv4702[:0] - yyc4702 = true + yyv4693 := *v + yyh4693, yyl4693 := z.DecSliceHelperStart() + var yyc4693 bool + if yyl4693 == 0 { + if yyv4693 == nil { + yyv4693 = []Pod{} + yyc4693 = true + } else if len(yyv4693) != 0 { + yyv4693 = yyv4693[:0] + yyc4693 = true } - } else if yyl4702 > 0 { - var yyrr4702, yyrl4702 int - var yyrt4702 bool - if yyl4702 > cap(yyv4702) { + } else if yyl4693 > 0 { + var yyrr4693, yyrl4693 int + var yyrt4693 bool + if yyl4693 > cap(yyv4693) { - yyrg4702 := len(yyv4702) > 0 - yyv24702 := yyv4702 - yyrl4702, yyrt4702 = z.DecInferLen(yyl4702, z.DecBasicHandle().MaxInitLen, 664) - if yyrt4702 { - if yyrl4702 <= cap(yyv4702) { - yyv4702 = yyv4702[:yyrl4702] + yyrg4693 := len(yyv4693) > 0 + yyv24693 := yyv4693 + yyrl4693, yyrt4693 = z.DecInferLen(yyl4693, z.DecBasicHandle().MaxInitLen, 664) + if yyrt4693 { + if yyrl4693 <= cap(yyv4693) { + yyv4693 = yyv4693[:yyrl4693] } else { - yyv4702 = make([]Pod, yyrl4702) + yyv4693 = make([]Pod, yyrl4693) } } else { - yyv4702 = make([]Pod, yyrl4702) + yyv4693 = make([]Pod, yyrl4693) } - yyc4702 = true - yyrr4702 = len(yyv4702) - if yyrg4702 { - copy(yyv4702, yyv24702) + yyc4693 = true + yyrr4693 = len(yyv4693) + if yyrg4693 { + copy(yyv4693, yyv24693) } - } else if yyl4702 != len(yyv4702) { - yyv4702 = yyv4702[:yyl4702] - yyc4702 = true + } else if yyl4693 != len(yyv4693) { + yyv4693 = yyv4693[:yyl4693] + yyc4693 = true } - yyj4702 := 0 - for ; yyj4702 < yyrr4702; yyj4702++ { - yyh4702.ElemContainerState(yyj4702) + yyj4693 := 0 + for ; yyj4693 < yyrr4693; yyj4693++ { + yyh4693.ElemContainerState(yyj4693) if r.TryDecodeAsNil() { - yyv4702[yyj4702] = Pod{} + yyv4693[yyj4693] = Pod{} } else { - yyv4703 := &yyv4702[yyj4702] - yyv4703.CodecDecodeSelf(d) + yyv4694 := &yyv4693[yyj4693] + yyv4694.CodecDecodeSelf(d) } } - if yyrt4702 { - for ; yyj4702 < yyl4702; yyj4702++ { - yyv4702 = append(yyv4702, Pod{}) - yyh4702.ElemContainerState(yyj4702) + if yyrt4693 { + for ; yyj4693 < yyl4693; yyj4693++ { + yyv4693 = append(yyv4693, Pod{}) + yyh4693.ElemContainerState(yyj4693) if r.TryDecodeAsNil() { - yyv4702[yyj4702] = Pod{} + yyv4693[yyj4693] = Pod{} } else { - yyv4704 := &yyv4702[yyj4702] - yyv4704.CodecDecodeSelf(d) + yyv4695 := &yyv4693[yyj4693] + yyv4695.CodecDecodeSelf(d) } } } } else { - yyj4702 := 0 - for ; !r.CheckBreak(); yyj4702++ { + yyj4693 := 0 + for ; !r.CheckBreak(); yyj4693++ { - if yyj4702 >= len(yyv4702) { - yyv4702 = append(yyv4702, Pod{}) // var yyz4702 Pod - yyc4702 = true + if yyj4693 >= len(yyv4693) { + yyv4693 = append(yyv4693, Pod{}) // var yyz4693 Pod + yyc4693 = true } - yyh4702.ElemContainerState(yyj4702) - if yyj4702 < len(yyv4702) { + yyh4693.ElemContainerState(yyj4693) + if yyj4693 < len(yyv4693) { if r.TryDecodeAsNil() { - yyv4702[yyj4702] = Pod{} + yyv4693[yyj4693] = Pod{} } else { - yyv4705 := &yyv4702[yyj4702] - yyv4705.CodecDecodeSelf(d) + yyv4696 := &yyv4693[yyj4693] + yyv4696.CodecDecodeSelf(d) } } else { @@ -59324,17 +59242,17 @@ func (x codecSelfer1234) decSlicePod(v *[]Pod, d *codec1978.Decoder) { } } - if yyj4702 < len(yyv4702) { - yyv4702 = yyv4702[:yyj4702] - yyc4702 = true - } else if yyj4702 == 0 && yyv4702 == nil { - yyv4702 = []Pod{} - yyc4702 = true + if yyj4693 < len(yyv4693) { + yyv4693 = yyv4693[:yyj4693] + yyc4693 = true + } else if yyj4693 == 0 && yyv4693 == nil { + yyv4693 = []Pod{} + yyc4693 = true } } - yyh4702.End() - if yyc4702 { - *v = yyv4702 + yyh4693.End() + if yyc4693 { + *v = yyv4693 } } @@ -59343,10 +59261,10 @@ func (x codecSelfer1234) encSlicePodTemplate(v []PodTemplate, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4706 := range v { + for _, yyv4697 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4707 := &yyv4706 - yy4707.CodecEncodeSelf(e) + yy4698 := &yyv4697 + yy4698.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59356,83 +59274,83 @@ func (x codecSelfer1234) decSlicePodTemplate(v *[]PodTemplate, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4708 := *v - yyh4708, yyl4708 := z.DecSliceHelperStart() - var yyc4708 bool - if yyl4708 == 0 { - if yyv4708 == nil { - yyv4708 = []PodTemplate{} - yyc4708 = true - } else if len(yyv4708) != 0 { - yyv4708 = yyv4708[:0] - yyc4708 = true + yyv4699 := *v + yyh4699, yyl4699 := z.DecSliceHelperStart() + var yyc4699 bool + if yyl4699 == 0 { + if yyv4699 == nil { + yyv4699 = []PodTemplate{} + yyc4699 = true + } else if len(yyv4699) != 0 { + yyv4699 = yyv4699[:0] + yyc4699 = true } - } else if yyl4708 > 0 { - var yyrr4708, yyrl4708 int - var yyrt4708 bool - if yyl4708 > cap(yyv4708) { + } else if yyl4699 > 0 { + var yyrr4699, yyrl4699 int + var yyrt4699 bool + if yyl4699 > cap(yyv4699) { - yyrg4708 := len(yyv4708) > 0 - yyv24708 := yyv4708 - yyrl4708, yyrt4708 = z.DecInferLen(yyl4708, z.DecBasicHandle().MaxInitLen, 728) - if yyrt4708 { - if yyrl4708 <= cap(yyv4708) { - yyv4708 = yyv4708[:yyrl4708] + yyrg4699 := len(yyv4699) > 0 + yyv24699 := yyv4699 + yyrl4699, yyrt4699 = z.DecInferLen(yyl4699, z.DecBasicHandle().MaxInitLen, 728) + if yyrt4699 { + if yyrl4699 <= cap(yyv4699) { + yyv4699 = yyv4699[:yyrl4699] } else { - yyv4708 = make([]PodTemplate, yyrl4708) + yyv4699 = make([]PodTemplate, yyrl4699) } } else { - yyv4708 = make([]PodTemplate, yyrl4708) + yyv4699 = make([]PodTemplate, yyrl4699) } - yyc4708 = true - yyrr4708 = len(yyv4708) - if yyrg4708 { - copy(yyv4708, yyv24708) + yyc4699 = true + yyrr4699 = len(yyv4699) + if yyrg4699 { + copy(yyv4699, yyv24699) } - } else if yyl4708 != len(yyv4708) { - yyv4708 = yyv4708[:yyl4708] - yyc4708 = true + } else if yyl4699 != len(yyv4699) { + yyv4699 = yyv4699[:yyl4699] + yyc4699 = true } - yyj4708 := 0 - for ; yyj4708 < yyrr4708; yyj4708++ { - yyh4708.ElemContainerState(yyj4708) + yyj4699 := 0 + for ; yyj4699 < yyrr4699; yyj4699++ { + yyh4699.ElemContainerState(yyj4699) if r.TryDecodeAsNil() { - yyv4708[yyj4708] = PodTemplate{} + yyv4699[yyj4699] = PodTemplate{} } else { - yyv4709 := &yyv4708[yyj4708] - yyv4709.CodecDecodeSelf(d) + yyv4700 := &yyv4699[yyj4699] + yyv4700.CodecDecodeSelf(d) } } - if yyrt4708 { - for ; yyj4708 < yyl4708; yyj4708++ { - yyv4708 = append(yyv4708, PodTemplate{}) - yyh4708.ElemContainerState(yyj4708) + if yyrt4699 { + for ; yyj4699 < yyl4699; yyj4699++ { + yyv4699 = append(yyv4699, PodTemplate{}) + yyh4699.ElemContainerState(yyj4699) if r.TryDecodeAsNil() { - yyv4708[yyj4708] = PodTemplate{} + yyv4699[yyj4699] = PodTemplate{} } else { - yyv4710 := &yyv4708[yyj4708] - yyv4710.CodecDecodeSelf(d) + yyv4701 := &yyv4699[yyj4699] + yyv4701.CodecDecodeSelf(d) } } } } else { - yyj4708 := 0 - for ; !r.CheckBreak(); yyj4708++ { + yyj4699 := 0 + for ; !r.CheckBreak(); yyj4699++ { - if yyj4708 >= len(yyv4708) { - yyv4708 = append(yyv4708, PodTemplate{}) // var yyz4708 PodTemplate - yyc4708 = true + if yyj4699 >= len(yyv4699) { + yyv4699 = append(yyv4699, PodTemplate{}) // var yyz4699 PodTemplate + yyc4699 = true } - yyh4708.ElemContainerState(yyj4708) - if yyj4708 < len(yyv4708) { + yyh4699.ElemContainerState(yyj4699) + if yyj4699 < len(yyv4699) { if r.TryDecodeAsNil() { - yyv4708[yyj4708] = PodTemplate{} + yyv4699[yyj4699] = PodTemplate{} } else { - yyv4711 := &yyv4708[yyj4708] - yyv4711.CodecDecodeSelf(d) + yyv4702 := &yyv4699[yyj4699] + yyv4702.CodecDecodeSelf(d) } } else { @@ -59440,17 +59358,17 @@ func (x codecSelfer1234) decSlicePodTemplate(v *[]PodTemplate, d *codec1978.Deco } } - if yyj4708 < len(yyv4708) { - yyv4708 = yyv4708[:yyj4708] - yyc4708 = true - } else if yyj4708 == 0 && yyv4708 == nil { - yyv4708 = []PodTemplate{} - yyc4708 = true + if yyj4699 < len(yyv4699) { + yyv4699 = yyv4699[:yyj4699] + yyc4699 = true + } else if yyj4699 == 0 && yyv4699 == nil { + yyv4699 = []PodTemplate{} + yyc4699 = true } } - yyh4708.End() - if yyc4708 { - *v = yyv4708 + yyh4699.End() + if yyc4699 { + *v = yyv4699 } } @@ -59459,10 +59377,10 @@ func (x codecSelfer1234) encSliceReplicationControllerCondition(v []ReplicationC z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4712 := range v { + for _, yyv4703 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4713 := &yyv4712 - yy4713.CodecEncodeSelf(e) + yy4704 := &yyv4703 + yy4704.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59472,83 +59390,83 @@ func (x codecSelfer1234) decSliceReplicationControllerCondition(v *[]Replication z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4714 := *v - yyh4714, yyl4714 := z.DecSliceHelperStart() - var yyc4714 bool - if yyl4714 == 0 { - if yyv4714 == nil { - yyv4714 = []ReplicationControllerCondition{} - yyc4714 = true - } else if len(yyv4714) != 0 { - yyv4714 = yyv4714[:0] - yyc4714 = true + yyv4705 := *v + yyh4705, yyl4705 := z.DecSliceHelperStart() + var yyc4705 bool + if yyl4705 == 0 { + if yyv4705 == nil { + yyv4705 = []ReplicationControllerCondition{} + yyc4705 = true + } else if len(yyv4705) != 0 { + yyv4705 = yyv4705[:0] + yyc4705 = true } - } else if yyl4714 > 0 { - var yyrr4714, yyrl4714 int - var yyrt4714 bool - if yyl4714 > cap(yyv4714) { + } else if yyl4705 > 0 { + var yyrr4705, yyrl4705 int + var yyrt4705 bool + if yyl4705 > cap(yyv4705) { - yyrg4714 := len(yyv4714) > 0 - yyv24714 := yyv4714 - yyrl4714, yyrt4714 = z.DecInferLen(yyl4714, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4714 { - if yyrl4714 <= cap(yyv4714) { - yyv4714 = yyv4714[:yyrl4714] + yyrg4705 := len(yyv4705) > 0 + yyv24705 := yyv4705 + yyrl4705, yyrt4705 = z.DecInferLen(yyl4705, z.DecBasicHandle().MaxInitLen, 88) + if yyrt4705 { + if yyrl4705 <= cap(yyv4705) { + yyv4705 = yyv4705[:yyrl4705] } else { - yyv4714 = make([]ReplicationControllerCondition, yyrl4714) + yyv4705 = make([]ReplicationControllerCondition, yyrl4705) } } else { - yyv4714 = make([]ReplicationControllerCondition, yyrl4714) + yyv4705 = make([]ReplicationControllerCondition, yyrl4705) } - yyc4714 = true - yyrr4714 = len(yyv4714) - if yyrg4714 { - copy(yyv4714, yyv24714) + yyc4705 = true + yyrr4705 = len(yyv4705) + if yyrg4705 { + copy(yyv4705, yyv24705) } - } else if yyl4714 != len(yyv4714) { - yyv4714 = yyv4714[:yyl4714] - yyc4714 = true + } else if yyl4705 != len(yyv4705) { + yyv4705 = yyv4705[:yyl4705] + yyc4705 = true } - yyj4714 := 0 - for ; yyj4714 < yyrr4714; yyj4714++ { - yyh4714.ElemContainerState(yyj4714) + yyj4705 := 0 + for ; yyj4705 < yyrr4705; yyj4705++ { + yyh4705.ElemContainerState(yyj4705) if r.TryDecodeAsNil() { - yyv4714[yyj4714] = ReplicationControllerCondition{} + yyv4705[yyj4705] = ReplicationControllerCondition{} } else { - yyv4715 := &yyv4714[yyj4714] - yyv4715.CodecDecodeSelf(d) + yyv4706 := &yyv4705[yyj4705] + yyv4706.CodecDecodeSelf(d) } } - if yyrt4714 { - for ; yyj4714 < yyl4714; yyj4714++ { - yyv4714 = append(yyv4714, ReplicationControllerCondition{}) - yyh4714.ElemContainerState(yyj4714) + if yyrt4705 { + for ; yyj4705 < yyl4705; yyj4705++ { + yyv4705 = append(yyv4705, ReplicationControllerCondition{}) + yyh4705.ElemContainerState(yyj4705) if r.TryDecodeAsNil() { - yyv4714[yyj4714] = ReplicationControllerCondition{} + yyv4705[yyj4705] = ReplicationControllerCondition{} } else { - yyv4716 := &yyv4714[yyj4714] - yyv4716.CodecDecodeSelf(d) + yyv4707 := &yyv4705[yyj4705] + yyv4707.CodecDecodeSelf(d) } } } } else { - yyj4714 := 0 - for ; !r.CheckBreak(); yyj4714++ { + yyj4705 := 0 + for ; !r.CheckBreak(); yyj4705++ { - if yyj4714 >= len(yyv4714) { - yyv4714 = append(yyv4714, ReplicationControllerCondition{}) // var yyz4714 ReplicationControllerCondition - yyc4714 = true + if yyj4705 >= len(yyv4705) { + yyv4705 = append(yyv4705, ReplicationControllerCondition{}) // var yyz4705 ReplicationControllerCondition + yyc4705 = true } - yyh4714.ElemContainerState(yyj4714) - if yyj4714 < len(yyv4714) { + yyh4705.ElemContainerState(yyj4705) + if yyj4705 < len(yyv4705) { if r.TryDecodeAsNil() { - yyv4714[yyj4714] = ReplicationControllerCondition{} + yyv4705[yyj4705] = ReplicationControllerCondition{} } else { - yyv4717 := &yyv4714[yyj4714] - yyv4717.CodecDecodeSelf(d) + yyv4708 := &yyv4705[yyj4705] + yyv4708.CodecDecodeSelf(d) } } else { @@ -59556,17 +59474,17 @@ func (x codecSelfer1234) decSliceReplicationControllerCondition(v *[]Replication } } - if yyj4714 < len(yyv4714) { - yyv4714 = yyv4714[:yyj4714] - yyc4714 = true - } else if yyj4714 == 0 && yyv4714 == nil { - yyv4714 = []ReplicationControllerCondition{} - yyc4714 = true + if yyj4705 < len(yyv4705) { + yyv4705 = yyv4705[:yyj4705] + yyc4705 = true + } else if yyj4705 == 0 && yyv4705 == nil { + yyv4705 = []ReplicationControllerCondition{} + yyc4705 = true } } - yyh4714.End() - if yyc4714 { - *v = yyv4714 + yyh4705.End() + if yyc4705 { + *v = yyv4705 } } @@ -59575,10 +59493,10 @@ func (x codecSelfer1234) encSliceReplicationController(v []ReplicationController z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4718 := range v { + for _, yyv4709 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4719 := &yyv4718 - yy4719.CodecEncodeSelf(e) + yy4710 := &yyv4709 + yy4710.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59588,83 +59506,83 @@ func (x codecSelfer1234) decSliceReplicationController(v *[]ReplicationControlle z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4720 := *v - yyh4720, yyl4720 := z.DecSliceHelperStart() - var yyc4720 bool - if yyl4720 == 0 { - if yyv4720 == nil { - yyv4720 = []ReplicationController{} - yyc4720 = true - } else if len(yyv4720) != 0 { - yyv4720 = yyv4720[:0] - yyc4720 = true + yyv4711 := *v + yyh4711, yyl4711 := z.DecSliceHelperStart() + var yyc4711 bool + if yyl4711 == 0 { + if yyv4711 == nil { + yyv4711 = []ReplicationController{} + yyc4711 = true + } else if len(yyv4711) != 0 { + yyv4711 = yyv4711[:0] + yyc4711 = true } - } else if yyl4720 > 0 { - var yyrr4720, yyrl4720 int - var yyrt4720 bool - if yyl4720 > cap(yyv4720) { + } else if yyl4711 > 0 { + var yyrr4711, yyrl4711 int + var yyrt4711 bool + if yyl4711 > cap(yyv4711) { - yyrg4720 := len(yyv4720) > 0 - yyv24720 := yyv4720 - yyrl4720, yyrt4720 = z.DecInferLen(yyl4720, z.DecBasicHandle().MaxInitLen, 336) - if yyrt4720 { - if yyrl4720 <= cap(yyv4720) { - yyv4720 = yyv4720[:yyrl4720] + yyrg4711 := len(yyv4711) > 0 + yyv24711 := yyv4711 + yyrl4711, yyrt4711 = z.DecInferLen(yyl4711, z.DecBasicHandle().MaxInitLen, 336) + if yyrt4711 { + if yyrl4711 <= cap(yyv4711) { + yyv4711 = yyv4711[:yyrl4711] } else { - yyv4720 = make([]ReplicationController, yyrl4720) + yyv4711 = make([]ReplicationController, yyrl4711) } } else { - yyv4720 = make([]ReplicationController, yyrl4720) + yyv4711 = make([]ReplicationController, yyrl4711) } - yyc4720 = true - yyrr4720 = len(yyv4720) - if yyrg4720 { - copy(yyv4720, yyv24720) + yyc4711 = true + yyrr4711 = len(yyv4711) + if yyrg4711 { + copy(yyv4711, yyv24711) } - } else if yyl4720 != len(yyv4720) { - yyv4720 = yyv4720[:yyl4720] - yyc4720 = true + } else if yyl4711 != len(yyv4711) { + yyv4711 = yyv4711[:yyl4711] + yyc4711 = true } - yyj4720 := 0 - for ; yyj4720 < yyrr4720; yyj4720++ { - yyh4720.ElemContainerState(yyj4720) + yyj4711 := 0 + for ; yyj4711 < yyrr4711; yyj4711++ { + yyh4711.ElemContainerState(yyj4711) if r.TryDecodeAsNil() { - yyv4720[yyj4720] = ReplicationController{} + yyv4711[yyj4711] = ReplicationController{} } else { - yyv4721 := &yyv4720[yyj4720] - yyv4721.CodecDecodeSelf(d) + yyv4712 := &yyv4711[yyj4711] + yyv4712.CodecDecodeSelf(d) } } - if yyrt4720 { - for ; yyj4720 < yyl4720; yyj4720++ { - yyv4720 = append(yyv4720, ReplicationController{}) - yyh4720.ElemContainerState(yyj4720) + if yyrt4711 { + for ; yyj4711 < yyl4711; yyj4711++ { + yyv4711 = append(yyv4711, ReplicationController{}) + yyh4711.ElemContainerState(yyj4711) if r.TryDecodeAsNil() { - yyv4720[yyj4720] = ReplicationController{} + yyv4711[yyj4711] = ReplicationController{} } else { - yyv4722 := &yyv4720[yyj4720] - yyv4722.CodecDecodeSelf(d) + yyv4713 := &yyv4711[yyj4711] + yyv4713.CodecDecodeSelf(d) } } } } else { - yyj4720 := 0 - for ; !r.CheckBreak(); yyj4720++ { + yyj4711 := 0 + for ; !r.CheckBreak(); yyj4711++ { - if yyj4720 >= len(yyv4720) { - yyv4720 = append(yyv4720, ReplicationController{}) // var yyz4720 ReplicationController - yyc4720 = true + if yyj4711 >= len(yyv4711) { + yyv4711 = append(yyv4711, ReplicationController{}) // var yyz4711 ReplicationController + yyc4711 = true } - yyh4720.ElemContainerState(yyj4720) - if yyj4720 < len(yyv4720) { + yyh4711.ElemContainerState(yyj4711) + if yyj4711 < len(yyv4711) { if r.TryDecodeAsNil() { - yyv4720[yyj4720] = ReplicationController{} + yyv4711[yyj4711] = ReplicationController{} } else { - yyv4723 := &yyv4720[yyj4720] - yyv4723.CodecDecodeSelf(d) + yyv4714 := &yyv4711[yyj4711] + yyv4714.CodecDecodeSelf(d) } } else { @@ -59672,17 +59590,17 @@ func (x codecSelfer1234) decSliceReplicationController(v *[]ReplicationControlle } } - if yyj4720 < len(yyv4720) { - yyv4720 = yyv4720[:yyj4720] - yyc4720 = true - } else if yyj4720 == 0 && yyv4720 == nil { - yyv4720 = []ReplicationController{} - yyc4720 = true + if yyj4711 < len(yyv4711) { + yyv4711 = yyv4711[:yyj4711] + yyc4711 = true + } else if yyj4711 == 0 && yyv4711 == nil { + yyv4711 = []ReplicationController{} + yyc4711 = true } } - yyh4720.End() - if yyc4720 { - *v = yyv4720 + yyh4711.End() + if yyc4711 { + *v = yyv4711 } } @@ -59691,10 +59609,10 @@ func (x codecSelfer1234) encSliceLoadBalancerIngress(v []LoadBalancerIngress, e z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4724 := range v { + for _, yyv4715 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4725 := &yyv4724 - yy4725.CodecEncodeSelf(e) + yy4716 := &yyv4715 + yy4716.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59704,83 +59622,83 @@ func (x codecSelfer1234) decSliceLoadBalancerIngress(v *[]LoadBalancerIngress, d z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4726 := *v - yyh4726, yyl4726 := z.DecSliceHelperStart() - var yyc4726 bool - if yyl4726 == 0 { - if yyv4726 == nil { - yyv4726 = []LoadBalancerIngress{} - yyc4726 = true - } else if len(yyv4726) != 0 { - yyv4726 = yyv4726[:0] - yyc4726 = true + yyv4717 := *v + yyh4717, yyl4717 := z.DecSliceHelperStart() + var yyc4717 bool + if yyl4717 == 0 { + if yyv4717 == nil { + yyv4717 = []LoadBalancerIngress{} + yyc4717 = true + } else if len(yyv4717) != 0 { + yyv4717 = yyv4717[:0] + yyc4717 = true } - } else if yyl4726 > 0 { - var yyrr4726, yyrl4726 int - var yyrt4726 bool - if yyl4726 > cap(yyv4726) { + } else if yyl4717 > 0 { + var yyrr4717, yyrl4717 int + var yyrt4717 bool + if yyl4717 > cap(yyv4717) { - yyrg4726 := len(yyv4726) > 0 - yyv24726 := yyv4726 - yyrl4726, yyrt4726 = z.DecInferLen(yyl4726, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4726 { - if yyrl4726 <= cap(yyv4726) { - yyv4726 = yyv4726[:yyrl4726] + yyrg4717 := len(yyv4717) > 0 + yyv24717 := yyv4717 + yyrl4717, yyrt4717 = z.DecInferLen(yyl4717, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4717 { + if yyrl4717 <= cap(yyv4717) { + yyv4717 = yyv4717[:yyrl4717] } else { - yyv4726 = make([]LoadBalancerIngress, yyrl4726) + yyv4717 = make([]LoadBalancerIngress, yyrl4717) } } else { - yyv4726 = make([]LoadBalancerIngress, yyrl4726) + yyv4717 = make([]LoadBalancerIngress, yyrl4717) } - yyc4726 = true - yyrr4726 = len(yyv4726) - if yyrg4726 { - copy(yyv4726, yyv24726) + yyc4717 = true + yyrr4717 = len(yyv4717) + if yyrg4717 { + copy(yyv4717, yyv24717) } - } else if yyl4726 != len(yyv4726) { - yyv4726 = yyv4726[:yyl4726] - yyc4726 = true + } else if yyl4717 != len(yyv4717) { + yyv4717 = yyv4717[:yyl4717] + yyc4717 = true } - yyj4726 := 0 - for ; yyj4726 < yyrr4726; yyj4726++ { - yyh4726.ElemContainerState(yyj4726) + yyj4717 := 0 + for ; yyj4717 < yyrr4717; yyj4717++ { + yyh4717.ElemContainerState(yyj4717) if r.TryDecodeAsNil() { - yyv4726[yyj4726] = LoadBalancerIngress{} + yyv4717[yyj4717] = LoadBalancerIngress{} } else { - yyv4727 := &yyv4726[yyj4726] - yyv4727.CodecDecodeSelf(d) + yyv4718 := &yyv4717[yyj4717] + yyv4718.CodecDecodeSelf(d) } } - if yyrt4726 { - for ; yyj4726 < yyl4726; yyj4726++ { - yyv4726 = append(yyv4726, LoadBalancerIngress{}) - yyh4726.ElemContainerState(yyj4726) + if yyrt4717 { + for ; yyj4717 < yyl4717; yyj4717++ { + yyv4717 = append(yyv4717, LoadBalancerIngress{}) + yyh4717.ElemContainerState(yyj4717) if r.TryDecodeAsNil() { - yyv4726[yyj4726] = LoadBalancerIngress{} + yyv4717[yyj4717] = LoadBalancerIngress{} } else { - yyv4728 := &yyv4726[yyj4726] - yyv4728.CodecDecodeSelf(d) + yyv4719 := &yyv4717[yyj4717] + yyv4719.CodecDecodeSelf(d) } } } } else { - yyj4726 := 0 - for ; !r.CheckBreak(); yyj4726++ { + yyj4717 := 0 + for ; !r.CheckBreak(); yyj4717++ { - if yyj4726 >= len(yyv4726) { - yyv4726 = append(yyv4726, LoadBalancerIngress{}) // var yyz4726 LoadBalancerIngress - yyc4726 = true + if yyj4717 >= len(yyv4717) { + yyv4717 = append(yyv4717, LoadBalancerIngress{}) // var yyz4717 LoadBalancerIngress + yyc4717 = true } - yyh4726.ElemContainerState(yyj4726) - if yyj4726 < len(yyv4726) { + yyh4717.ElemContainerState(yyj4717) + if yyj4717 < len(yyv4717) { if r.TryDecodeAsNil() { - yyv4726[yyj4726] = LoadBalancerIngress{} + yyv4717[yyj4717] = LoadBalancerIngress{} } else { - yyv4729 := &yyv4726[yyj4726] - yyv4729.CodecDecodeSelf(d) + yyv4720 := &yyv4717[yyj4717] + yyv4720.CodecDecodeSelf(d) } } else { @@ -59788,17 +59706,17 @@ func (x codecSelfer1234) decSliceLoadBalancerIngress(v *[]LoadBalancerIngress, d } } - if yyj4726 < len(yyv4726) { - yyv4726 = yyv4726[:yyj4726] - yyc4726 = true - } else if yyj4726 == 0 && yyv4726 == nil { - yyv4726 = []LoadBalancerIngress{} - yyc4726 = true + if yyj4717 < len(yyv4717) { + yyv4717 = yyv4717[:yyj4717] + yyc4717 = true + } else if yyj4717 == 0 && yyv4717 == nil { + yyv4717 = []LoadBalancerIngress{} + yyc4717 = true } } - yyh4726.End() - if yyc4726 { - *v = yyv4726 + yyh4717.End() + if yyc4717 { + *v = yyv4717 } } @@ -59807,10 +59725,10 @@ func (x codecSelfer1234) encSliceServicePort(v []ServicePort, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4730 := range v { + for _, yyv4721 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4731 := &yyv4730 - yy4731.CodecEncodeSelf(e) + yy4722 := &yyv4721 + yy4722.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59820,83 +59738,83 @@ func (x codecSelfer1234) decSliceServicePort(v *[]ServicePort, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4732 := *v - yyh4732, yyl4732 := z.DecSliceHelperStart() - var yyc4732 bool - if yyl4732 == 0 { - if yyv4732 == nil { - yyv4732 = []ServicePort{} - yyc4732 = true - } else if len(yyv4732) != 0 { - yyv4732 = yyv4732[:0] - yyc4732 = true + yyv4723 := *v + yyh4723, yyl4723 := z.DecSliceHelperStart() + var yyc4723 bool + if yyl4723 == 0 { + if yyv4723 == nil { + yyv4723 = []ServicePort{} + yyc4723 = true + } else if len(yyv4723) != 0 { + yyv4723 = yyv4723[:0] + yyc4723 = true } - } else if yyl4732 > 0 { - var yyrr4732, yyrl4732 int - var yyrt4732 bool - if yyl4732 > cap(yyv4732) { + } else if yyl4723 > 0 { + var yyrr4723, yyrl4723 int + var yyrt4723 bool + if yyl4723 > cap(yyv4723) { - yyrg4732 := len(yyv4732) > 0 - yyv24732 := yyv4732 - yyrl4732, yyrt4732 = z.DecInferLen(yyl4732, z.DecBasicHandle().MaxInitLen, 80) - if yyrt4732 { - if yyrl4732 <= cap(yyv4732) { - yyv4732 = yyv4732[:yyrl4732] + yyrg4723 := len(yyv4723) > 0 + yyv24723 := yyv4723 + yyrl4723, yyrt4723 = z.DecInferLen(yyl4723, z.DecBasicHandle().MaxInitLen, 80) + if yyrt4723 { + if yyrl4723 <= cap(yyv4723) { + yyv4723 = yyv4723[:yyrl4723] } else { - yyv4732 = make([]ServicePort, yyrl4732) + yyv4723 = make([]ServicePort, yyrl4723) } } else { - yyv4732 = make([]ServicePort, yyrl4732) + yyv4723 = make([]ServicePort, yyrl4723) } - yyc4732 = true - yyrr4732 = len(yyv4732) - if yyrg4732 { - copy(yyv4732, yyv24732) + yyc4723 = true + yyrr4723 = len(yyv4723) + if yyrg4723 { + copy(yyv4723, yyv24723) } - } else if yyl4732 != len(yyv4732) { - yyv4732 = yyv4732[:yyl4732] - yyc4732 = true + } else if yyl4723 != len(yyv4723) { + yyv4723 = yyv4723[:yyl4723] + yyc4723 = true } - yyj4732 := 0 - for ; yyj4732 < yyrr4732; yyj4732++ { - yyh4732.ElemContainerState(yyj4732) + yyj4723 := 0 + for ; yyj4723 < yyrr4723; yyj4723++ { + yyh4723.ElemContainerState(yyj4723) if r.TryDecodeAsNil() { - yyv4732[yyj4732] = ServicePort{} + yyv4723[yyj4723] = ServicePort{} } else { - yyv4733 := &yyv4732[yyj4732] - yyv4733.CodecDecodeSelf(d) + yyv4724 := &yyv4723[yyj4723] + yyv4724.CodecDecodeSelf(d) } } - if yyrt4732 { - for ; yyj4732 < yyl4732; yyj4732++ { - yyv4732 = append(yyv4732, ServicePort{}) - yyh4732.ElemContainerState(yyj4732) + if yyrt4723 { + for ; yyj4723 < yyl4723; yyj4723++ { + yyv4723 = append(yyv4723, ServicePort{}) + yyh4723.ElemContainerState(yyj4723) if r.TryDecodeAsNil() { - yyv4732[yyj4732] = ServicePort{} + yyv4723[yyj4723] = ServicePort{} } else { - yyv4734 := &yyv4732[yyj4732] - yyv4734.CodecDecodeSelf(d) + yyv4725 := &yyv4723[yyj4723] + yyv4725.CodecDecodeSelf(d) } } } } else { - yyj4732 := 0 - for ; !r.CheckBreak(); yyj4732++ { + yyj4723 := 0 + for ; !r.CheckBreak(); yyj4723++ { - if yyj4732 >= len(yyv4732) { - yyv4732 = append(yyv4732, ServicePort{}) // var yyz4732 ServicePort - yyc4732 = true + if yyj4723 >= len(yyv4723) { + yyv4723 = append(yyv4723, ServicePort{}) // var yyz4723 ServicePort + yyc4723 = true } - yyh4732.ElemContainerState(yyj4732) - if yyj4732 < len(yyv4732) { + yyh4723.ElemContainerState(yyj4723) + if yyj4723 < len(yyv4723) { if r.TryDecodeAsNil() { - yyv4732[yyj4732] = ServicePort{} + yyv4723[yyj4723] = ServicePort{} } else { - yyv4735 := &yyv4732[yyj4732] - yyv4735.CodecDecodeSelf(d) + yyv4726 := &yyv4723[yyj4723] + yyv4726.CodecDecodeSelf(d) } } else { @@ -59904,17 +59822,17 @@ func (x codecSelfer1234) decSliceServicePort(v *[]ServicePort, d *codec1978.Deco } } - if yyj4732 < len(yyv4732) { - yyv4732 = yyv4732[:yyj4732] - yyc4732 = true - } else if yyj4732 == 0 && yyv4732 == nil { - yyv4732 = []ServicePort{} - yyc4732 = true + if yyj4723 < len(yyv4723) { + yyv4723 = yyv4723[:yyj4723] + yyc4723 = true + } else if yyj4723 == 0 && yyv4723 == nil { + yyv4723 = []ServicePort{} + yyc4723 = true } } - yyh4732.End() - if yyc4732 { - *v = yyv4732 + yyh4723.End() + if yyc4723 { + *v = yyv4723 } } @@ -59923,10 +59841,10 @@ func (x codecSelfer1234) encSliceService(v []Service, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4736 := range v { + for _, yyv4727 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4737 := &yyv4736 - yy4737.CodecEncodeSelf(e) + yy4728 := &yyv4727 + yy4728.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -59936,83 +59854,83 @@ func (x codecSelfer1234) decSliceService(v *[]Service, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4738 := *v - yyh4738, yyl4738 := z.DecSliceHelperStart() - var yyc4738 bool - if yyl4738 == 0 { - if yyv4738 == nil { - yyv4738 = []Service{} - yyc4738 = true - } else if len(yyv4738) != 0 { - yyv4738 = yyv4738[:0] - yyc4738 = true + yyv4729 := *v + yyh4729, yyl4729 := z.DecSliceHelperStart() + var yyc4729 bool + if yyl4729 == 0 { + if yyv4729 == nil { + yyv4729 = []Service{} + yyc4729 = true + } else if len(yyv4729) != 0 { + yyv4729 = yyv4729[:0] + yyc4729 = true } - } else if yyl4738 > 0 { - var yyrr4738, yyrl4738 int - var yyrt4738 bool - if yyl4738 > cap(yyv4738) { + } else if yyl4729 > 0 { + var yyrr4729, yyrl4729 int + var yyrt4729 bool + if yyl4729 > cap(yyv4729) { - yyrg4738 := len(yyv4738) > 0 - yyv24738 := yyv4738 - yyrl4738, yyrt4738 = z.DecInferLen(yyl4738, z.DecBasicHandle().MaxInitLen, 464) - if yyrt4738 { - if yyrl4738 <= cap(yyv4738) { - yyv4738 = yyv4738[:yyrl4738] + yyrg4729 := len(yyv4729) > 0 + yyv24729 := yyv4729 + yyrl4729, yyrt4729 = z.DecInferLen(yyl4729, z.DecBasicHandle().MaxInitLen, 464) + if yyrt4729 { + if yyrl4729 <= cap(yyv4729) { + yyv4729 = yyv4729[:yyrl4729] } else { - yyv4738 = make([]Service, yyrl4738) + yyv4729 = make([]Service, yyrl4729) } } else { - yyv4738 = make([]Service, yyrl4738) + yyv4729 = make([]Service, yyrl4729) } - yyc4738 = true - yyrr4738 = len(yyv4738) - if yyrg4738 { - copy(yyv4738, yyv24738) + yyc4729 = true + yyrr4729 = len(yyv4729) + if yyrg4729 { + copy(yyv4729, yyv24729) } - } else if yyl4738 != len(yyv4738) { - yyv4738 = yyv4738[:yyl4738] - yyc4738 = true + } else if yyl4729 != len(yyv4729) { + yyv4729 = yyv4729[:yyl4729] + yyc4729 = true } - yyj4738 := 0 - for ; yyj4738 < yyrr4738; yyj4738++ { - yyh4738.ElemContainerState(yyj4738) + yyj4729 := 0 + for ; yyj4729 < yyrr4729; yyj4729++ { + yyh4729.ElemContainerState(yyj4729) if r.TryDecodeAsNil() { - yyv4738[yyj4738] = Service{} + yyv4729[yyj4729] = Service{} } else { - yyv4739 := &yyv4738[yyj4738] - yyv4739.CodecDecodeSelf(d) + yyv4730 := &yyv4729[yyj4729] + yyv4730.CodecDecodeSelf(d) } } - if yyrt4738 { - for ; yyj4738 < yyl4738; yyj4738++ { - yyv4738 = append(yyv4738, Service{}) - yyh4738.ElemContainerState(yyj4738) + if yyrt4729 { + for ; yyj4729 < yyl4729; yyj4729++ { + yyv4729 = append(yyv4729, Service{}) + yyh4729.ElemContainerState(yyj4729) if r.TryDecodeAsNil() { - yyv4738[yyj4738] = Service{} + yyv4729[yyj4729] = Service{} } else { - yyv4740 := &yyv4738[yyj4738] - yyv4740.CodecDecodeSelf(d) + yyv4731 := &yyv4729[yyj4729] + yyv4731.CodecDecodeSelf(d) } } } } else { - yyj4738 := 0 - for ; !r.CheckBreak(); yyj4738++ { + yyj4729 := 0 + for ; !r.CheckBreak(); yyj4729++ { - if yyj4738 >= len(yyv4738) { - yyv4738 = append(yyv4738, Service{}) // var yyz4738 Service - yyc4738 = true + if yyj4729 >= len(yyv4729) { + yyv4729 = append(yyv4729, Service{}) // var yyz4729 Service + yyc4729 = true } - yyh4738.ElemContainerState(yyj4738) - if yyj4738 < len(yyv4738) { + yyh4729.ElemContainerState(yyj4729) + if yyj4729 < len(yyv4729) { if r.TryDecodeAsNil() { - yyv4738[yyj4738] = Service{} + yyv4729[yyj4729] = Service{} } else { - yyv4741 := &yyv4738[yyj4738] - yyv4741.CodecDecodeSelf(d) + yyv4732 := &yyv4729[yyj4729] + yyv4732.CodecDecodeSelf(d) } } else { @@ -60020,17 +59938,17 @@ func (x codecSelfer1234) decSliceService(v *[]Service, d *codec1978.Decoder) { } } - if yyj4738 < len(yyv4738) { - yyv4738 = yyv4738[:yyj4738] - yyc4738 = true - } else if yyj4738 == 0 && yyv4738 == nil { - yyv4738 = []Service{} - yyc4738 = true + if yyj4729 < len(yyv4729) { + yyv4729 = yyv4729[:yyj4729] + yyc4729 = true + } else if yyj4729 == 0 && yyv4729 == nil { + yyv4729 = []Service{} + yyc4729 = true } } - yyh4738.End() - if yyc4738 { - *v = yyv4738 + yyh4729.End() + if yyc4729 { + *v = yyv4729 } } @@ -60039,10 +59957,10 @@ func (x codecSelfer1234) encSliceObjectReference(v []ObjectReference, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4742 := range v { + for _, yyv4733 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4743 := &yyv4742 - yy4743.CodecEncodeSelf(e) + yy4734 := &yyv4733 + yy4734.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60052,83 +59970,83 @@ func (x codecSelfer1234) decSliceObjectReference(v *[]ObjectReference, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4744 := *v - yyh4744, yyl4744 := z.DecSliceHelperStart() - var yyc4744 bool - if yyl4744 == 0 { - if yyv4744 == nil { - yyv4744 = []ObjectReference{} - yyc4744 = true - } else if len(yyv4744) != 0 { - yyv4744 = yyv4744[:0] - yyc4744 = true + yyv4735 := *v + yyh4735, yyl4735 := z.DecSliceHelperStart() + var yyc4735 bool + if yyl4735 == 0 { + if yyv4735 == nil { + yyv4735 = []ObjectReference{} + yyc4735 = true + } else if len(yyv4735) != 0 { + yyv4735 = yyv4735[:0] + yyc4735 = true } - } else if yyl4744 > 0 { - var yyrr4744, yyrl4744 int - var yyrt4744 bool - if yyl4744 > cap(yyv4744) { + } else if yyl4735 > 0 { + var yyrr4735, yyrl4735 int + var yyrt4735 bool + if yyl4735 > cap(yyv4735) { - yyrg4744 := len(yyv4744) > 0 - yyv24744 := yyv4744 - yyrl4744, yyrt4744 = z.DecInferLen(yyl4744, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4744 { - if yyrl4744 <= cap(yyv4744) { - yyv4744 = yyv4744[:yyrl4744] + yyrg4735 := len(yyv4735) > 0 + yyv24735 := yyv4735 + yyrl4735, yyrt4735 = z.DecInferLen(yyl4735, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4735 { + if yyrl4735 <= cap(yyv4735) { + yyv4735 = yyv4735[:yyrl4735] } else { - yyv4744 = make([]ObjectReference, yyrl4744) + yyv4735 = make([]ObjectReference, yyrl4735) } } else { - yyv4744 = make([]ObjectReference, yyrl4744) + yyv4735 = make([]ObjectReference, yyrl4735) } - yyc4744 = true - yyrr4744 = len(yyv4744) - if yyrg4744 { - copy(yyv4744, yyv24744) + yyc4735 = true + yyrr4735 = len(yyv4735) + if yyrg4735 { + copy(yyv4735, yyv24735) } - } else if yyl4744 != len(yyv4744) { - yyv4744 = yyv4744[:yyl4744] - yyc4744 = true + } else if yyl4735 != len(yyv4735) { + yyv4735 = yyv4735[:yyl4735] + yyc4735 = true } - yyj4744 := 0 - for ; yyj4744 < yyrr4744; yyj4744++ { - yyh4744.ElemContainerState(yyj4744) + yyj4735 := 0 + for ; yyj4735 < yyrr4735; yyj4735++ { + yyh4735.ElemContainerState(yyj4735) if r.TryDecodeAsNil() { - yyv4744[yyj4744] = ObjectReference{} + yyv4735[yyj4735] = ObjectReference{} } else { - yyv4745 := &yyv4744[yyj4744] - yyv4745.CodecDecodeSelf(d) + yyv4736 := &yyv4735[yyj4735] + yyv4736.CodecDecodeSelf(d) } } - if yyrt4744 { - for ; yyj4744 < yyl4744; yyj4744++ { - yyv4744 = append(yyv4744, ObjectReference{}) - yyh4744.ElemContainerState(yyj4744) + if yyrt4735 { + for ; yyj4735 < yyl4735; yyj4735++ { + yyv4735 = append(yyv4735, ObjectReference{}) + yyh4735.ElemContainerState(yyj4735) if r.TryDecodeAsNil() { - yyv4744[yyj4744] = ObjectReference{} + yyv4735[yyj4735] = ObjectReference{} } else { - yyv4746 := &yyv4744[yyj4744] - yyv4746.CodecDecodeSelf(d) + yyv4737 := &yyv4735[yyj4735] + yyv4737.CodecDecodeSelf(d) } } } } else { - yyj4744 := 0 - for ; !r.CheckBreak(); yyj4744++ { + yyj4735 := 0 + for ; !r.CheckBreak(); yyj4735++ { - if yyj4744 >= len(yyv4744) { - yyv4744 = append(yyv4744, ObjectReference{}) // var yyz4744 ObjectReference - yyc4744 = true + if yyj4735 >= len(yyv4735) { + yyv4735 = append(yyv4735, ObjectReference{}) // var yyz4735 ObjectReference + yyc4735 = true } - yyh4744.ElemContainerState(yyj4744) - if yyj4744 < len(yyv4744) { + yyh4735.ElemContainerState(yyj4735) + if yyj4735 < len(yyv4735) { if r.TryDecodeAsNil() { - yyv4744[yyj4744] = ObjectReference{} + yyv4735[yyj4735] = ObjectReference{} } else { - yyv4747 := &yyv4744[yyj4744] - yyv4747.CodecDecodeSelf(d) + yyv4738 := &yyv4735[yyj4735] + yyv4738.CodecDecodeSelf(d) } } else { @@ -60136,17 +60054,17 @@ func (x codecSelfer1234) decSliceObjectReference(v *[]ObjectReference, d *codec1 } } - if yyj4744 < len(yyv4744) { - yyv4744 = yyv4744[:yyj4744] - yyc4744 = true - } else if yyj4744 == 0 && yyv4744 == nil { - yyv4744 = []ObjectReference{} - yyc4744 = true + if yyj4735 < len(yyv4735) { + yyv4735 = yyv4735[:yyj4735] + yyc4735 = true + } else if yyj4735 == 0 && yyv4735 == nil { + yyv4735 = []ObjectReference{} + yyc4735 = true } } - yyh4744.End() - if yyc4744 { - *v = yyv4744 + yyh4735.End() + if yyc4735 { + *v = yyv4735 } } @@ -60155,10 +60073,10 @@ func (x codecSelfer1234) encSliceServiceAccount(v []ServiceAccount, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4748 := range v { + for _, yyv4739 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4749 := &yyv4748 - yy4749.CodecEncodeSelf(e) + yy4740 := &yyv4739 + yy4740.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60168,83 +60086,83 @@ func (x codecSelfer1234) decSliceServiceAccount(v *[]ServiceAccount, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4750 := *v - yyh4750, yyl4750 := z.DecSliceHelperStart() - var yyc4750 bool - if yyl4750 == 0 { - if yyv4750 == nil { - yyv4750 = []ServiceAccount{} - yyc4750 = true - } else if len(yyv4750) != 0 { - yyv4750 = yyv4750[:0] - yyc4750 = true + yyv4741 := *v + yyh4741, yyl4741 := z.DecSliceHelperStart() + var yyc4741 bool + if yyl4741 == 0 { + if yyv4741 == nil { + yyv4741 = []ServiceAccount{} + yyc4741 = true + } else if len(yyv4741) != 0 { + yyv4741 = yyv4741[:0] + yyc4741 = true } - } else if yyl4750 > 0 { - var yyrr4750, yyrl4750 int - var yyrt4750 bool - if yyl4750 > cap(yyv4750) { + } else if yyl4741 > 0 { + var yyrr4741, yyrl4741 int + var yyrt4741 bool + if yyl4741 > cap(yyv4741) { - yyrg4750 := len(yyv4750) > 0 - yyv24750 := yyv4750 - yyrl4750, yyrt4750 = z.DecInferLen(yyl4750, z.DecBasicHandle().MaxInitLen, 304) - if yyrt4750 { - if yyrl4750 <= cap(yyv4750) { - yyv4750 = yyv4750[:yyrl4750] + yyrg4741 := len(yyv4741) > 0 + yyv24741 := yyv4741 + yyrl4741, yyrt4741 = z.DecInferLen(yyl4741, z.DecBasicHandle().MaxInitLen, 304) + if yyrt4741 { + if yyrl4741 <= cap(yyv4741) { + yyv4741 = yyv4741[:yyrl4741] } else { - yyv4750 = make([]ServiceAccount, yyrl4750) + yyv4741 = make([]ServiceAccount, yyrl4741) } } else { - yyv4750 = make([]ServiceAccount, yyrl4750) + yyv4741 = make([]ServiceAccount, yyrl4741) } - yyc4750 = true - yyrr4750 = len(yyv4750) - if yyrg4750 { - copy(yyv4750, yyv24750) + yyc4741 = true + yyrr4741 = len(yyv4741) + if yyrg4741 { + copy(yyv4741, yyv24741) } - } else if yyl4750 != len(yyv4750) { - yyv4750 = yyv4750[:yyl4750] - yyc4750 = true + } else if yyl4741 != len(yyv4741) { + yyv4741 = yyv4741[:yyl4741] + yyc4741 = true } - yyj4750 := 0 - for ; yyj4750 < yyrr4750; yyj4750++ { - yyh4750.ElemContainerState(yyj4750) + yyj4741 := 0 + for ; yyj4741 < yyrr4741; yyj4741++ { + yyh4741.ElemContainerState(yyj4741) if r.TryDecodeAsNil() { - yyv4750[yyj4750] = ServiceAccount{} + yyv4741[yyj4741] = ServiceAccount{} } else { - yyv4751 := &yyv4750[yyj4750] - yyv4751.CodecDecodeSelf(d) + yyv4742 := &yyv4741[yyj4741] + yyv4742.CodecDecodeSelf(d) } } - if yyrt4750 { - for ; yyj4750 < yyl4750; yyj4750++ { - yyv4750 = append(yyv4750, ServiceAccount{}) - yyh4750.ElemContainerState(yyj4750) + if yyrt4741 { + for ; yyj4741 < yyl4741; yyj4741++ { + yyv4741 = append(yyv4741, ServiceAccount{}) + yyh4741.ElemContainerState(yyj4741) if r.TryDecodeAsNil() { - yyv4750[yyj4750] = ServiceAccount{} + yyv4741[yyj4741] = ServiceAccount{} } else { - yyv4752 := &yyv4750[yyj4750] - yyv4752.CodecDecodeSelf(d) + yyv4743 := &yyv4741[yyj4741] + yyv4743.CodecDecodeSelf(d) } } } } else { - yyj4750 := 0 - for ; !r.CheckBreak(); yyj4750++ { + yyj4741 := 0 + for ; !r.CheckBreak(); yyj4741++ { - if yyj4750 >= len(yyv4750) { - yyv4750 = append(yyv4750, ServiceAccount{}) // var yyz4750 ServiceAccount - yyc4750 = true + if yyj4741 >= len(yyv4741) { + yyv4741 = append(yyv4741, ServiceAccount{}) // var yyz4741 ServiceAccount + yyc4741 = true } - yyh4750.ElemContainerState(yyj4750) - if yyj4750 < len(yyv4750) { + yyh4741.ElemContainerState(yyj4741) + if yyj4741 < len(yyv4741) { if r.TryDecodeAsNil() { - yyv4750[yyj4750] = ServiceAccount{} + yyv4741[yyj4741] = ServiceAccount{} } else { - yyv4753 := &yyv4750[yyj4750] - yyv4753.CodecDecodeSelf(d) + yyv4744 := &yyv4741[yyj4741] + yyv4744.CodecDecodeSelf(d) } } else { @@ -60252,17 +60170,17 @@ func (x codecSelfer1234) decSliceServiceAccount(v *[]ServiceAccount, d *codec197 } } - if yyj4750 < len(yyv4750) { - yyv4750 = yyv4750[:yyj4750] - yyc4750 = true - } else if yyj4750 == 0 && yyv4750 == nil { - yyv4750 = []ServiceAccount{} - yyc4750 = true + if yyj4741 < len(yyv4741) { + yyv4741 = yyv4741[:yyj4741] + yyc4741 = true + } else if yyj4741 == 0 && yyv4741 == nil { + yyv4741 = []ServiceAccount{} + yyc4741 = true } } - yyh4750.End() - if yyc4750 { - *v = yyv4750 + yyh4741.End() + if yyc4741 { + *v = yyv4741 } } @@ -60271,10 +60189,10 @@ func (x codecSelfer1234) encSliceEndpointSubset(v []EndpointSubset, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4754 := range v { + for _, yyv4745 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4755 := &yyv4754 - yy4755.CodecEncodeSelf(e) + yy4746 := &yyv4745 + yy4746.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60284,83 +60202,83 @@ func (x codecSelfer1234) decSliceEndpointSubset(v *[]EndpointSubset, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4756 := *v - yyh4756, yyl4756 := z.DecSliceHelperStart() - var yyc4756 bool - if yyl4756 == 0 { - if yyv4756 == nil { - yyv4756 = []EndpointSubset{} - yyc4756 = true - } else if len(yyv4756) != 0 { - yyv4756 = yyv4756[:0] - yyc4756 = true + yyv4747 := *v + yyh4747, yyl4747 := z.DecSliceHelperStart() + var yyc4747 bool + if yyl4747 == 0 { + if yyv4747 == nil { + yyv4747 = []EndpointSubset{} + yyc4747 = true + } else if len(yyv4747) != 0 { + yyv4747 = yyv4747[:0] + yyc4747 = true } - } else if yyl4756 > 0 { - var yyrr4756, yyrl4756 int - var yyrt4756 bool - if yyl4756 > cap(yyv4756) { + } else if yyl4747 > 0 { + var yyrr4747, yyrl4747 int + var yyrt4747 bool + if yyl4747 > cap(yyv4747) { - yyrg4756 := len(yyv4756) > 0 - yyv24756 := yyv4756 - yyrl4756, yyrt4756 = z.DecInferLen(yyl4756, z.DecBasicHandle().MaxInitLen, 72) - if yyrt4756 { - if yyrl4756 <= cap(yyv4756) { - yyv4756 = yyv4756[:yyrl4756] + yyrg4747 := len(yyv4747) > 0 + yyv24747 := yyv4747 + yyrl4747, yyrt4747 = z.DecInferLen(yyl4747, z.DecBasicHandle().MaxInitLen, 72) + if yyrt4747 { + if yyrl4747 <= cap(yyv4747) { + yyv4747 = yyv4747[:yyrl4747] } else { - yyv4756 = make([]EndpointSubset, yyrl4756) + yyv4747 = make([]EndpointSubset, yyrl4747) } } else { - yyv4756 = make([]EndpointSubset, yyrl4756) + yyv4747 = make([]EndpointSubset, yyrl4747) } - yyc4756 = true - yyrr4756 = len(yyv4756) - if yyrg4756 { - copy(yyv4756, yyv24756) + yyc4747 = true + yyrr4747 = len(yyv4747) + if yyrg4747 { + copy(yyv4747, yyv24747) } - } else if yyl4756 != len(yyv4756) { - yyv4756 = yyv4756[:yyl4756] - yyc4756 = true + } else if yyl4747 != len(yyv4747) { + yyv4747 = yyv4747[:yyl4747] + yyc4747 = true } - yyj4756 := 0 - for ; yyj4756 < yyrr4756; yyj4756++ { - yyh4756.ElemContainerState(yyj4756) + yyj4747 := 0 + for ; yyj4747 < yyrr4747; yyj4747++ { + yyh4747.ElemContainerState(yyj4747) if r.TryDecodeAsNil() { - yyv4756[yyj4756] = EndpointSubset{} + yyv4747[yyj4747] = EndpointSubset{} } else { - yyv4757 := &yyv4756[yyj4756] - yyv4757.CodecDecodeSelf(d) + yyv4748 := &yyv4747[yyj4747] + yyv4748.CodecDecodeSelf(d) } } - if yyrt4756 { - for ; yyj4756 < yyl4756; yyj4756++ { - yyv4756 = append(yyv4756, EndpointSubset{}) - yyh4756.ElemContainerState(yyj4756) + if yyrt4747 { + for ; yyj4747 < yyl4747; yyj4747++ { + yyv4747 = append(yyv4747, EndpointSubset{}) + yyh4747.ElemContainerState(yyj4747) if r.TryDecodeAsNil() { - yyv4756[yyj4756] = EndpointSubset{} + yyv4747[yyj4747] = EndpointSubset{} } else { - yyv4758 := &yyv4756[yyj4756] - yyv4758.CodecDecodeSelf(d) + yyv4749 := &yyv4747[yyj4747] + yyv4749.CodecDecodeSelf(d) } } } } else { - yyj4756 := 0 - for ; !r.CheckBreak(); yyj4756++ { + yyj4747 := 0 + for ; !r.CheckBreak(); yyj4747++ { - if yyj4756 >= len(yyv4756) { - yyv4756 = append(yyv4756, EndpointSubset{}) // var yyz4756 EndpointSubset - yyc4756 = true + if yyj4747 >= len(yyv4747) { + yyv4747 = append(yyv4747, EndpointSubset{}) // var yyz4747 EndpointSubset + yyc4747 = true } - yyh4756.ElemContainerState(yyj4756) - if yyj4756 < len(yyv4756) { + yyh4747.ElemContainerState(yyj4747) + if yyj4747 < len(yyv4747) { if r.TryDecodeAsNil() { - yyv4756[yyj4756] = EndpointSubset{} + yyv4747[yyj4747] = EndpointSubset{} } else { - yyv4759 := &yyv4756[yyj4756] - yyv4759.CodecDecodeSelf(d) + yyv4750 := &yyv4747[yyj4747] + yyv4750.CodecDecodeSelf(d) } } else { @@ -60368,17 +60286,17 @@ func (x codecSelfer1234) decSliceEndpointSubset(v *[]EndpointSubset, d *codec197 } } - if yyj4756 < len(yyv4756) { - yyv4756 = yyv4756[:yyj4756] - yyc4756 = true - } else if yyj4756 == 0 && yyv4756 == nil { - yyv4756 = []EndpointSubset{} - yyc4756 = true + if yyj4747 < len(yyv4747) { + yyv4747 = yyv4747[:yyj4747] + yyc4747 = true + } else if yyj4747 == 0 && yyv4747 == nil { + yyv4747 = []EndpointSubset{} + yyc4747 = true } } - yyh4756.End() - if yyc4756 { - *v = yyv4756 + yyh4747.End() + if yyc4747 { + *v = yyv4747 } } @@ -60387,10 +60305,10 @@ func (x codecSelfer1234) encSliceEndpointAddress(v []EndpointAddress, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4760 := range v { + for _, yyv4751 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4761 := &yyv4760 - yy4761.CodecEncodeSelf(e) + yy4752 := &yyv4751 + yy4752.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60400,83 +60318,83 @@ func (x codecSelfer1234) decSliceEndpointAddress(v *[]EndpointAddress, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4762 := *v - yyh4762, yyl4762 := z.DecSliceHelperStart() - var yyc4762 bool - if yyl4762 == 0 { - if yyv4762 == nil { - yyv4762 = []EndpointAddress{} - yyc4762 = true - } else if len(yyv4762) != 0 { - yyv4762 = yyv4762[:0] - yyc4762 = true + yyv4753 := *v + yyh4753, yyl4753 := z.DecSliceHelperStart() + var yyc4753 bool + if yyl4753 == 0 { + if yyv4753 == nil { + yyv4753 = []EndpointAddress{} + yyc4753 = true + } else if len(yyv4753) != 0 { + yyv4753 = yyv4753[:0] + yyc4753 = true } - } else if yyl4762 > 0 { - var yyrr4762, yyrl4762 int - var yyrt4762 bool - if yyl4762 > cap(yyv4762) { + } else if yyl4753 > 0 { + var yyrr4753, yyrl4753 int + var yyrt4753 bool + if yyl4753 > cap(yyv4753) { - yyrg4762 := len(yyv4762) > 0 - yyv24762 := yyv4762 - yyrl4762, yyrt4762 = z.DecInferLen(yyl4762, z.DecBasicHandle().MaxInitLen, 48) - if yyrt4762 { - if yyrl4762 <= cap(yyv4762) { - yyv4762 = yyv4762[:yyrl4762] + yyrg4753 := len(yyv4753) > 0 + yyv24753 := yyv4753 + yyrl4753, yyrt4753 = z.DecInferLen(yyl4753, z.DecBasicHandle().MaxInitLen, 48) + if yyrt4753 { + if yyrl4753 <= cap(yyv4753) { + yyv4753 = yyv4753[:yyrl4753] } else { - yyv4762 = make([]EndpointAddress, yyrl4762) + yyv4753 = make([]EndpointAddress, yyrl4753) } } else { - yyv4762 = make([]EndpointAddress, yyrl4762) + yyv4753 = make([]EndpointAddress, yyrl4753) } - yyc4762 = true - yyrr4762 = len(yyv4762) - if yyrg4762 { - copy(yyv4762, yyv24762) + yyc4753 = true + yyrr4753 = len(yyv4753) + if yyrg4753 { + copy(yyv4753, yyv24753) } - } else if yyl4762 != len(yyv4762) { - yyv4762 = yyv4762[:yyl4762] - yyc4762 = true + } else if yyl4753 != len(yyv4753) { + yyv4753 = yyv4753[:yyl4753] + yyc4753 = true } - yyj4762 := 0 - for ; yyj4762 < yyrr4762; yyj4762++ { - yyh4762.ElemContainerState(yyj4762) + yyj4753 := 0 + for ; yyj4753 < yyrr4753; yyj4753++ { + yyh4753.ElemContainerState(yyj4753) if r.TryDecodeAsNil() { - yyv4762[yyj4762] = EndpointAddress{} + yyv4753[yyj4753] = EndpointAddress{} } else { - yyv4763 := &yyv4762[yyj4762] - yyv4763.CodecDecodeSelf(d) + yyv4754 := &yyv4753[yyj4753] + yyv4754.CodecDecodeSelf(d) } } - if yyrt4762 { - for ; yyj4762 < yyl4762; yyj4762++ { - yyv4762 = append(yyv4762, EndpointAddress{}) - yyh4762.ElemContainerState(yyj4762) + if yyrt4753 { + for ; yyj4753 < yyl4753; yyj4753++ { + yyv4753 = append(yyv4753, EndpointAddress{}) + yyh4753.ElemContainerState(yyj4753) if r.TryDecodeAsNil() { - yyv4762[yyj4762] = EndpointAddress{} + yyv4753[yyj4753] = EndpointAddress{} } else { - yyv4764 := &yyv4762[yyj4762] - yyv4764.CodecDecodeSelf(d) + yyv4755 := &yyv4753[yyj4753] + yyv4755.CodecDecodeSelf(d) } } } } else { - yyj4762 := 0 - for ; !r.CheckBreak(); yyj4762++ { + yyj4753 := 0 + for ; !r.CheckBreak(); yyj4753++ { - if yyj4762 >= len(yyv4762) { - yyv4762 = append(yyv4762, EndpointAddress{}) // var yyz4762 EndpointAddress - yyc4762 = true + if yyj4753 >= len(yyv4753) { + yyv4753 = append(yyv4753, EndpointAddress{}) // var yyz4753 EndpointAddress + yyc4753 = true } - yyh4762.ElemContainerState(yyj4762) - if yyj4762 < len(yyv4762) { + yyh4753.ElemContainerState(yyj4753) + if yyj4753 < len(yyv4753) { if r.TryDecodeAsNil() { - yyv4762[yyj4762] = EndpointAddress{} + yyv4753[yyj4753] = EndpointAddress{} } else { - yyv4765 := &yyv4762[yyj4762] - yyv4765.CodecDecodeSelf(d) + yyv4756 := &yyv4753[yyj4753] + yyv4756.CodecDecodeSelf(d) } } else { @@ -60484,17 +60402,17 @@ func (x codecSelfer1234) decSliceEndpointAddress(v *[]EndpointAddress, d *codec1 } } - if yyj4762 < len(yyv4762) { - yyv4762 = yyv4762[:yyj4762] - yyc4762 = true - } else if yyj4762 == 0 && yyv4762 == nil { - yyv4762 = []EndpointAddress{} - yyc4762 = true + if yyj4753 < len(yyv4753) { + yyv4753 = yyv4753[:yyj4753] + yyc4753 = true + } else if yyj4753 == 0 && yyv4753 == nil { + yyv4753 = []EndpointAddress{} + yyc4753 = true } } - yyh4762.End() - if yyc4762 { - *v = yyv4762 + yyh4753.End() + if yyc4753 { + *v = yyv4753 } } @@ -60503,10 +60421,10 @@ func (x codecSelfer1234) encSliceEndpointPort(v []EndpointPort, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4766 := range v { + for _, yyv4757 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4767 := &yyv4766 - yy4767.CodecEncodeSelf(e) + yy4758 := &yyv4757 + yy4758.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60516,83 +60434,83 @@ func (x codecSelfer1234) decSliceEndpointPort(v *[]EndpointPort, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4768 := *v - yyh4768, yyl4768 := z.DecSliceHelperStart() - var yyc4768 bool - if yyl4768 == 0 { - if yyv4768 == nil { - yyv4768 = []EndpointPort{} - yyc4768 = true - } else if len(yyv4768) != 0 { - yyv4768 = yyv4768[:0] - yyc4768 = true + yyv4759 := *v + yyh4759, yyl4759 := z.DecSliceHelperStart() + var yyc4759 bool + if yyl4759 == 0 { + if yyv4759 == nil { + yyv4759 = []EndpointPort{} + yyc4759 = true + } else if len(yyv4759) != 0 { + yyv4759 = yyv4759[:0] + yyc4759 = true } - } else if yyl4768 > 0 { - var yyrr4768, yyrl4768 int - var yyrt4768 bool - if yyl4768 > cap(yyv4768) { + } else if yyl4759 > 0 { + var yyrr4759, yyrl4759 int + var yyrt4759 bool + if yyl4759 > cap(yyv4759) { - yyrg4768 := len(yyv4768) > 0 - yyv24768 := yyv4768 - yyrl4768, yyrt4768 = z.DecInferLen(yyl4768, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4768 { - if yyrl4768 <= cap(yyv4768) { - yyv4768 = yyv4768[:yyrl4768] + yyrg4759 := len(yyv4759) > 0 + yyv24759 := yyv4759 + yyrl4759, yyrt4759 = z.DecInferLen(yyl4759, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4759 { + if yyrl4759 <= cap(yyv4759) { + yyv4759 = yyv4759[:yyrl4759] } else { - yyv4768 = make([]EndpointPort, yyrl4768) + yyv4759 = make([]EndpointPort, yyrl4759) } } else { - yyv4768 = make([]EndpointPort, yyrl4768) + yyv4759 = make([]EndpointPort, yyrl4759) } - yyc4768 = true - yyrr4768 = len(yyv4768) - if yyrg4768 { - copy(yyv4768, yyv24768) + yyc4759 = true + yyrr4759 = len(yyv4759) + if yyrg4759 { + copy(yyv4759, yyv24759) } - } else if yyl4768 != len(yyv4768) { - yyv4768 = yyv4768[:yyl4768] - yyc4768 = true + } else if yyl4759 != len(yyv4759) { + yyv4759 = yyv4759[:yyl4759] + yyc4759 = true } - yyj4768 := 0 - for ; yyj4768 < yyrr4768; yyj4768++ { - yyh4768.ElemContainerState(yyj4768) + yyj4759 := 0 + for ; yyj4759 < yyrr4759; yyj4759++ { + yyh4759.ElemContainerState(yyj4759) if r.TryDecodeAsNil() { - yyv4768[yyj4768] = EndpointPort{} + yyv4759[yyj4759] = EndpointPort{} } else { - yyv4769 := &yyv4768[yyj4768] - yyv4769.CodecDecodeSelf(d) + yyv4760 := &yyv4759[yyj4759] + yyv4760.CodecDecodeSelf(d) } } - if yyrt4768 { - for ; yyj4768 < yyl4768; yyj4768++ { - yyv4768 = append(yyv4768, EndpointPort{}) - yyh4768.ElemContainerState(yyj4768) + if yyrt4759 { + for ; yyj4759 < yyl4759; yyj4759++ { + yyv4759 = append(yyv4759, EndpointPort{}) + yyh4759.ElemContainerState(yyj4759) if r.TryDecodeAsNil() { - yyv4768[yyj4768] = EndpointPort{} + yyv4759[yyj4759] = EndpointPort{} } else { - yyv4770 := &yyv4768[yyj4768] - yyv4770.CodecDecodeSelf(d) + yyv4761 := &yyv4759[yyj4759] + yyv4761.CodecDecodeSelf(d) } } } } else { - yyj4768 := 0 - for ; !r.CheckBreak(); yyj4768++ { + yyj4759 := 0 + for ; !r.CheckBreak(); yyj4759++ { - if yyj4768 >= len(yyv4768) { - yyv4768 = append(yyv4768, EndpointPort{}) // var yyz4768 EndpointPort - yyc4768 = true + if yyj4759 >= len(yyv4759) { + yyv4759 = append(yyv4759, EndpointPort{}) // var yyz4759 EndpointPort + yyc4759 = true } - yyh4768.ElemContainerState(yyj4768) - if yyj4768 < len(yyv4768) { + yyh4759.ElemContainerState(yyj4759) + if yyj4759 < len(yyv4759) { if r.TryDecodeAsNil() { - yyv4768[yyj4768] = EndpointPort{} + yyv4759[yyj4759] = EndpointPort{} } else { - yyv4771 := &yyv4768[yyj4768] - yyv4771.CodecDecodeSelf(d) + yyv4762 := &yyv4759[yyj4759] + yyv4762.CodecDecodeSelf(d) } } else { @@ -60600,17 +60518,17 @@ func (x codecSelfer1234) decSliceEndpointPort(v *[]EndpointPort, d *codec1978.De } } - if yyj4768 < len(yyv4768) { - yyv4768 = yyv4768[:yyj4768] - yyc4768 = true - } else if yyj4768 == 0 && yyv4768 == nil { - yyv4768 = []EndpointPort{} - yyc4768 = true + if yyj4759 < len(yyv4759) { + yyv4759 = yyv4759[:yyj4759] + yyc4759 = true + } else if yyj4759 == 0 && yyv4759 == nil { + yyv4759 = []EndpointPort{} + yyc4759 = true } } - yyh4768.End() - if yyc4768 { - *v = yyv4768 + yyh4759.End() + if yyc4759 { + *v = yyv4759 } } @@ -60619,10 +60537,10 @@ func (x codecSelfer1234) encSliceEndpoints(v []Endpoints, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4772 := range v { + for _, yyv4763 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4773 := &yyv4772 - yy4773.CodecEncodeSelf(e) + yy4764 := &yyv4763 + yy4764.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60632,83 +60550,83 @@ func (x codecSelfer1234) decSliceEndpoints(v *[]Endpoints, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4774 := *v - yyh4774, yyl4774 := z.DecSliceHelperStart() - var yyc4774 bool - if yyl4774 == 0 { - if yyv4774 == nil { - yyv4774 = []Endpoints{} - yyc4774 = true - } else if len(yyv4774) != 0 { - yyv4774 = yyv4774[:0] - yyc4774 = true + yyv4765 := *v + yyh4765, yyl4765 := z.DecSliceHelperStart() + var yyc4765 bool + if yyl4765 == 0 { + if yyv4765 == nil { + yyv4765 = []Endpoints{} + yyc4765 = true + } else if len(yyv4765) != 0 { + yyv4765 = yyv4765[:0] + yyc4765 = true } - } else if yyl4774 > 0 { - var yyrr4774, yyrl4774 int - var yyrt4774 bool - if yyl4774 > cap(yyv4774) { + } else if yyl4765 > 0 { + var yyrr4765, yyrl4765 int + var yyrt4765 bool + if yyl4765 > cap(yyv4765) { - yyrg4774 := len(yyv4774) > 0 - yyv24774 := yyv4774 - yyrl4774, yyrt4774 = z.DecInferLen(yyl4774, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4774 { - if yyrl4774 <= cap(yyv4774) { - yyv4774 = yyv4774[:yyrl4774] + yyrg4765 := len(yyv4765) > 0 + yyv24765 := yyv4765 + yyrl4765, yyrt4765 = z.DecInferLen(yyl4765, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4765 { + if yyrl4765 <= cap(yyv4765) { + yyv4765 = yyv4765[:yyrl4765] } else { - yyv4774 = make([]Endpoints, yyrl4774) + yyv4765 = make([]Endpoints, yyrl4765) } } else { - yyv4774 = make([]Endpoints, yyrl4774) + yyv4765 = make([]Endpoints, yyrl4765) } - yyc4774 = true - yyrr4774 = len(yyv4774) - if yyrg4774 { - copy(yyv4774, yyv24774) + yyc4765 = true + yyrr4765 = len(yyv4765) + if yyrg4765 { + copy(yyv4765, yyv24765) } - } else if yyl4774 != len(yyv4774) { - yyv4774 = yyv4774[:yyl4774] - yyc4774 = true + } else if yyl4765 != len(yyv4765) { + yyv4765 = yyv4765[:yyl4765] + yyc4765 = true } - yyj4774 := 0 - for ; yyj4774 < yyrr4774; yyj4774++ { - yyh4774.ElemContainerState(yyj4774) + yyj4765 := 0 + for ; yyj4765 < yyrr4765; yyj4765++ { + yyh4765.ElemContainerState(yyj4765) if r.TryDecodeAsNil() { - yyv4774[yyj4774] = Endpoints{} + yyv4765[yyj4765] = Endpoints{} } else { - yyv4775 := &yyv4774[yyj4774] - yyv4775.CodecDecodeSelf(d) + yyv4766 := &yyv4765[yyj4765] + yyv4766.CodecDecodeSelf(d) } } - if yyrt4774 { - for ; yyj4774 < yyl4774; yyj4774++ { - yyv4774 = append(yyv4774, Endpoints{}) - yyh4774.ElemContainerState(yyj4774) + if yyrt4765 { + for ; yyj4765 < yyl4765; yyj4765++ { + yyv4765 = append(yyv4765, Endpoints{}) + yyh4765.ElemContainerState(yyj4765) if r.TryDecodeAsNil() { - yyv4774[yyj4774] = Endpoints{} + yyv4765[yyj4765] = Endpoints{} } else { - yyv4776 := &yyv4774[yyj4774] - yyv4776.CodecDecodeSelf(d) + yyv4767 := &yyv4765[yyj4765] + yyv4767.CodecDecodeSelf(d) } } } } else { - yyj4774 := 0 - for ; !r.CheckBreak(); yyj4774++ { + yyj4765 := 0 + for ; !r.CheckBreak(); yyj4765++ { - if yyj4774 >= len(yyv4774) { - yyv4774 = append(yyv4774, Endpoints{}) // var yyz4774 Endpoints - yyc4774 = true + if yyj4765 >= len(yyv4765) { + yyv4765 = append(yyv4765, Endpoints{}) // var yyz4765 Endpoints + yyc4765 = true } - yyh4774.ElemContainerState(yyj4774) - if yyj4774 < len(yyv4774) { + yyh4765.ElemContainerState(yyj4765) + if yyj4765 < len(yyv4765) { if r.TryDecodeAsNil() { - yyv4774[yyj4774] = Endpoints{} + yyv4765[yyj4765] = Endpoints{} } else { - yyv4777 := &yyv4774[yyj4774] - yyv4777.CodecDecodeSelf(d) + yyv4768 := &yyv4765[yyj4765] + yyv4768.CodecDecodeSelf(d) } } else { @@ -60716,17 +60634,17 @@ func (x codecSelfer1234) decSliceEndpoints(v *[]Endpoints, d *codec1978.Decoder) } } - if yyj4774 < len(yyv4774) { - yyv4774 = yyv4774[:yyj4774] - yyc4774 = true - } else if yyj4774 == 0 && yyv4774 == nil { - yyv4774 = []Endpoints{} - yyc4774 = true + if yyj4765 < len(yyv4765) { + yyv4765 = yyv4765[:yyj4765] + yyc4765 = true + } else if yyj4765 == 0 && yyv4765 == nil { + yyv4765 = []Endpoints{} + yyc4765 = true } } - yyh4774.End() - if yyc4774 { - *v = yyv4774 + yyh4765.End() + if yyc4765 { + *v = yyv4765 } } @@ -60735,10 +60653,10 @@ func (x codecSelfer1234) encSliceNodeCondition(v []NodeCondition, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4778 := range v { + for _, yyv4769 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4779 := &yyv4778 - yy4779.CodecEncodeSelf(e) + yy4770 := &yyv4769 + yy4770.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60748,83 +60666,83 @@ func (x codecSelfer1234) decSliceNodeCondition(v *[]NodeCondition, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4780 := *v - yyh4780, yyl4780 := z.DecSliceHelperStart() - var yyc4780 bool - if yyl4780 == 0 { - if yyv4780 == nil { - yyv4780 = []NodeCondition{} - yyc4780 = true - } else if len(yyv4780) != 0 { - yyv4780 = yyv4780[:0] - yyc4780 = true + yyv4771 := *v + yyh4771, yyl4771 := z.DecSliceHelperStart() + var yyc4771 bool + if yyl4771 == 0 { + if yyv4771 == nil { + yyv4771 = []NodeCondition{} + yyc4771 = true + } else if len(yyv4771) != 0 { + yyv4771 = yyv4771[:0] + yyc4771 = true } - } else if yyl4780 > 0 { - var yyrr4780, yyrl4780 int - var yyrt4780 bool - if yyl4780 > cap(yyv4780) { + } else if yyl4771 > 0 { + var yyrr4771, yyrl4771 int + var yyrt4771 bool + if yyl4771 > cap(yyv4771) { - yyrg4780 := len(yyv4780) > 0 - yyv24780 := yyv4780 - yyrl4780, yyrt4780 = z.DecInferLen(yyl4780, z.DecBasicHandle().MaxInitLen, 112) - if yyrt4780 { - if yyrl4780 <= cap(yyv4780) { - yyv4780 = yyv4780[:yyrl4780] + yyrg4771 := len(yyv4771) > 0 + yyv24771 := yyv4771 + yyrl4771, yyrt4771 = z.DecInferLen(yyl4771, z.DecBasicHandle().MaxInitLen, 112) + if yyrt4771 { + if yyrl4771 <= cap(yyv4771) { + yyv4771 = yyv4771[:yyrl4771] } else { - yyv4780 = make([]NodeCondition, yyrl4780) + yyv4771 = make([]NodeCondition, yyrl4771) } } else { - yyv4780 = make([]NodeCondition, yyrl4780) + yyv4771 = make([]NodeCondition, yyrl4771) } - yyc4780 = true - yyrr4780 = len(yyv4780) - if yyrg4780 { - copy(yyv4780, yyv24780) + yyc4771 = true + yyrr4771 = len(yyv4771) + if yyrg4771 { + copy(yyv4771, yyv24771) } - } else if yyl4780 != len(yyv4780) { - yyv4780 = yyv4780[:yyl4780] - yyc4780 = true + } else if yyl4771 != len(yyv4771) { + yyv4771 = yyv4771[:yyl4771] + yyc4771 = true } - yyj4780 := 0 - for ; yyj4780 < yyrr4780; yyj4780++ { - yyh4780.ElemContainerState(yyj4780) + yyj4771 := 0 + for ; yyj4771 < yyrr4771; yyj4771++ { + yyh4771.ElemContainerState(yyj4771) if r.TryDecodeAsNil() { - yyv4780[yyj4780] = NodeCondition{} + yyv4771[yyj4771] = NodeCondition{} } else { - yyv4781 := &yyv4780[yyj4780] - yyv4781.CodecDecodeSelf(d) + yyv4772 := &yyv4771[yyj4771] + yyv4772.CodecDecodeSelf(d) } } - if yyrt4780 { - for ; yyj4780 < yyl4780; yyj4780++ { - yyv4780 = append(yyv4780, NodeCondition{}) - yyh4780.ElemContainerState(yyj4780) + if yyrt4771 { + for ; yyj4771 < yyl4771; yyj4771++ { + yyv4771 = append(yyv4771, NodeCondition{}) + yyh4771.ElemContainerState(yyj4771) if r.TryDecodeAsNil() { - yyv4780[yyj4780] = NodeCondition{} + yyv4771[yyj4771] = NodeCondition{} } else { - yyv4782 := &yyv4780[yyj4780] - yyv4782.CodecDecodeSelf(d) + yyv4773 := &yyv4771[yyj4771] + yyv4773.CodecDecodeSelf(d) } } } } else { - yyj4780 := 0 - for ; !r.CheckBreak(); yyj4780++ { + yyj4771 := 0 + for ; !r.CheckBreak(); yyj4771++ { - if yyj4780 >= len(yyv4780) { - yyv4780 = append(yyv4780, NodeCondition{}) // var yyz4780 NodeCondition - yyc4780 = true + if yyj4771 >= len(yyv4771) { + yyv4771 = append(yyv4771, NodeCondition{}) // var yyz4771 NodeCondition + yyc4771 = true } - yyh4780.ElemContainerState(yyj4780) - if yyj4780 < len(yyv4780) { + yyh4771.ElemContainerState(yyj4771) + if yyj4771 < len(yyv4771) { if r.TryDecodeAsNil() { - yyv4780[yyj4780] = NodeCondition{} + yyv4771[yyj4771] = NodeCondition{} } else { - yyv4783 := &yyv4780[yyj4780] - yyv4783.CodecDecodeSelf(d) + yyv4774 := &yyv4771[yyj4771] + yyv4774.CodecDecodeSelf(d) } } else { @@ -60832,17 +60750,17 @@ func (x codecSelfer1234) decSliceNodeCondition(v *[]NodeCondition, d *codec1978. } } - if yyj4780 < len(yyv4780) { - yyv4780 = yyv4780[:yyj4780] - yyc4780 = true - } else if yyj4780 == 0 && yyv4780 == nil { - yyv4780 = []NodeCondition{} - yyc4780 = true + if yyj4771 < len(yyv4771) { + yyv4771 = yyv4771[:yyj4771] + yyc4771 = true + } else if yyj4771 == 0 && yyv4771 == nil { + yyv4771 = []NodeCondition{} + yyc4771 = true } } - yyh4780.End() - if yyc4780 { - *v = yyv4780 + yyh4771.End() + if yyc4771 { + *v = yyv4771 } } @@ -60851,10 +60769,10 @@ func (x codecSelfer1234) encSliceNodeAddress(v []NodeAddress, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4784 := range v { + for _, yyv4775 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4785 := &yyv4784 - yy4785.CodecEncodeSelf(e) + yy4776 := &yyv4775 + yy4776.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60864,83 +60782,83 @@ func (x codecSelfer1234) decSliceNodeAddress(v *[]NodeAddress, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4786 := *v - yyh4786, yyl4786 := z.DecSliceHelperStart() - var yyc4786 bool - if yyl4786 == 0 { - if yyv4786 == nil { - yyv4786 = []NodeAddress{} - yyc4786 = true - } else if len(yyv4786) != 0 { - yyv4786 = yyv4786[:0] - yyc4786 = true + yyv4777 := *v + yyh4777, yyl4777 := z.DecSliceHelperStart() + var yyc4777 bool + if yyl4777 == 0 { + if yyv4777 == nil { + yyv4777 = []NodeAddress{} + yyc4777 = true + } else if len(yyv4777) != 0 { + yyv4777 = yyv4777[:0] + yyc4777 = true } - } else if yyl4786 > 0 { - var yyrr4786, yyrl4786 int - var yyrt4786 bool - if yyl4786 > cap(yyv4786) { + } else if yyl4777 > 0 { + var yyrr4777, yyrl4777 int + var yyrt4777 bool + if yyl4777 > cap(yyv4777) { - yyrg4786 := len(yyv4786) > 0 - yyv24786 := yyv4786 - yyrl4786, yyrt4786 = z.DecInferLen(yyl4786, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4786 { - if yyrl4786 <= cap(yyv4786) { - yyv4786 = yyv4786[:yyrl4786] + yyrg4777 := len(yyv4777) > 0 + yyv24777 := yyv4777 + yyrl4777, yyrt4777 = z.DecInferLen(yyl4777, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4777 { + if yyrl4777 <= cap(yyv4777) { + yyv4777 = yyv4777[:yyrl4777] } else { - yyv4786 = make([]NodeAddress, yyrl4786) + yyv4777 = make([]NodeAddress, yyrl4777) } } else { - yyv4786 = make([]NodeAddress, yyrl4786) + yyv4777 = make([]NodeAddress, yyrl4777) } - yyc4786 = true - yyrr4786 = len(yyv4786) - if yyrg4786 { - copy(yyv4786, yyv24786) + yyc4777 = true + yyrr4777 = len(yyv4777) + if yyrg4777 { + copy(yyv4777, yyv24777) } - } else if yyl4786 != len(yyv4786) { - yyv4786 = yyv4786[:yyl4786] - yyc4786 = true + } else if yyl4777 != len(yyv4777) { + yyv4777 = yyv4777[:yyl4777] + yyc4777 = true } - yyj4786 := 0 - for ; yyj4786 < yyrr4786; yyj4786++ { - yyh4786.ElemContainerState(yyj4786) + yyj4777 := 0 + for ; yyj4777 < yyrr4777; yyj4777++ { + yyh4777.ElemContainerState(yyj4777) if r.TryDecodeAsNil() { - yyv4786[yyj4786] = NodeAddress{} + yyv4777[yyj4777] = NodeAddress{} } else { - yyv4787 := &yyv4786[yyj4786] - yyv4787.CodecDecodeSelf(d) + yyv4778 := &yyv4777[yyj4777] + yyv4778.CodecDecodeSelf(d) } } - if yyrt4786 { - for ; yyj4786 < yyl4786; yyj4786++ { - yyv4786 = append(yyv4786, NodeAddress{}) - yyh4786.ElemContainerState(yyj4786) + if yyrt4777 { + for ; yyj4777 < yyl4777; yyj4777++ { + yyv4777 = append(yyv4777, NodeAddress{}) + yyh4777.ElemContainerState(yyj4777) if r.TryDecodeAsNil() { - yyv4786[yyj4786] = NodeAddress{} + yyv4777[yyj4777] = NodeAddress{} } else { - yyv4788 := &yyv4786[yyj4786] - yyv4788.CodecDecodeSelf(d) + yyv4779 := &yyv4777[yyj4777] + yyv4779.CodecDecodeSelf(d) } } } } else { - yyj4786 := 0 - for ; !r.CheckBreak(); yyj4786++ { + yyj4777 := 0 + for ; !r.CheckBreak(); yyj4777++ { - if yyj4786 >= len(yyv4786) { - yyv4786 = append(yyv4786, NodeAddress{}) // var yyz4786 NodeAddress - yyc4786 = true + if yyj4777 >= len(yyv4777) { + yyv4777 = append(yyv4777, NodeAddress{}) // var yyz4777 NodeAddress + yyc4777 = true } - yyh4786.ElemContainerState(yyj4786) - if yyj4786 < len(yyv4786) { + yyh4777.ElemContainerState(yyj4777) + if yyj4777 < len(yyv4777) { if r.TryDecodeAsNil() { - yyv4786[yyj4786] = NodeAddress{} + yyv4777[yyj4777] = NodeAddress{} } else { - yyv4789 := &yyv4786[yyj4786] - yyv4789.CodecDecodeSelf(d) + yyv4780 := &yyv4777[yyj4777] + yyv4780.CodecDecodeSelf(d) } } else { @@ -60948,17 +60866,17 @@ func (x codecSelfer1234) decSliceNodeAddress(v *[]NodeAddress, d *codec1978.Deco } } - if yyj4786 < len(yyv4786) { - yyv4786 = yyv4786[:yyj4786] - yyc4786 = true - } else if yyj4786 == 0 && yyv4786 == nil { - yyv4786 = []NodeAddress{} - yyc4786 = true + if yyj4777 < len(yyv4777) { + yyv4777 = yyv4777[:yyj4777] + yyc4777 = true + } else if yyj4777 == 0 && yyv4777 == nil { + yyv4777 = []NodeAddress{} + yyc4777 = true } } - yyh4786.End() - if yyc4786 { - *v = yyv4786 + yyh4777.End() + if yyc4777 { + *v = yyv4777 } } @@ -60967,10 +60885,10 @@ func (x codecSelfer1234) encSliceContainerImage(v []ContainerImage, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4790 := range v { + for _, yyv4781 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4791 := &yyv4790 - yy4791.CodecEncodeSelf(e) + yy4782 := &yyv4781 + yy4782.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -60980,83 +60898,83 @@ func (x codecSelfer1234) decSliceContainerImage(v *[]ContainerImage, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4792 := *v - yyh4792, yyl4792 := z.DecSliceHelperStart() - var yyc4792 bool - if yyl4792 == 0 { - if yyv4792 == nil { - yyv4792 = []ContainerImage{} - yyc4792 = true - } else if len(yyv4792) != 0 { - yyv4792 = yyv4792[:0] - yyc4792 = true + yyv4783 := *v + yyh4783, yyl4783 := z.DecSliceHelperStart() + var yyc4783 bool + if yyl4783 == 0 { + if yyv4783 == nil { + yyv4783 = []ContainerImage{} + yyc4783 = true + } else if len(yyv4783) != 0 { + yyv4783 = yyv4783[:0] + yyc4783 = true } - } else if yyl4792 > 0 { - var yyrr4792, yyrl4792 int - var yyrt4792 bool - if yyl4792 > cap(yyv4792) { + } else if yyl4783 > 0 { + var yyrr4783, yyrl4783 int + var yyrt4783 bool + if yyl4783 > cap(yyv4783) { - yyrg4792 := len(yyv4792) > 0 - yyv24792 := yyv4792 - yyrl4792, yyrt4792 = z.DecInferLen(yyl4792, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4792 { - if yyrl4792 <= cap(yyv4792) { - yyv4792 = yyv4792[:yyrl4792] + yyrg4783 := len(yyv4783) > 0 + yyv24783 := yyv4783 + yyrl4783, yyrt4783 = z.DecInferLen(yyl4783, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4783 { + if yyrl4783 <= cap(yyv4783) { + yyv4783 = yyv4783[:yyrl4783] } else { - yyv4792 = make([]ContainerImage, yyrl4792) + yyv4783 = make([]ContainerImage, yyrl4783) } } else { - yyv4792 = make([]ContainerImage, yyrl4792) + yyv4783 = make([]ContainerImage, yyrl4783) } - yyc4792 = true - yyrr4792 = len(yyv4792) - if yyrg4792 { - copy(yyv4792, yyv24792) + yyc4783 = true + yyrr4783 = len(yyv4783) + if yyrg4783 { + copy(yyv4783, yyv24783) } - } else if yyl4792 != len(yyv4792) { - yyv4792 = yyv4792[:yyl4792] - yyc4792 = true + } else if yyl4783 != len(yyv4783) { + yyv4783 = yyv4783[:yyl4783] + yyc4783 = true } - yyj4792 := 0 - for ; yyj4792 < yyrr4792; yyj4792++ { - yyh4792.ElemContainerState(yyj4792) + yyj4783 := 0 + for ; yyj4783 < yyrr4783; yyj4783++ { + yyh4783.ElemContainerState(yyj4783) if r.TryDecodeAsNil() { - yyv4792[yyj4792] = ContainerImage{} + yyv4783[yyj4783] = ContainerImage{} } else { - yyv4793 := &yyv4792[yyj4792] - yyv4793.CodecDecodeSelf(d) + yyv4784 := &yyv4783[yyj4783] + yyv4784.CodecDecodeSelf(d) } } - if yyrt4792 { - for ; yyj4792 < yyl4792; yyj4792++ { - yyv4792 = append(yyv4792, ContainerImage{}) - yyh4792.ElemContainerState(yyj4792) + if yyrt4783 { + for ; yyj4783 < yyl4783; yyj4783++ { + yyv4783 = append(yyv4783, ContainerImage{}) + yyh4783.ElemContainerState(yyj4783) if r.TryDecodeAsNil() { - yyv4792[yyj4792] = ContainerImage{} + yyv4783[yyj4783] = ContainerImage{} } else { - yyv4794 := &yyv4792[yyj4792] - yyv4794.CodecDecodeSelf(d) + yyv4785 := &yyv4783[yyj4783] + yyv4785.CodecDecodeSelf(d) } } } } else { - yyj4792 := 0 - for ; !r.CheckBreak(); yyj4792++ { + yyj4783 := 0 + for ; !r.CheckBreak(); yyj4783++ { - if yyj4792 >= len(yyv4792) { - yyv4792 = append(yyv4792, ContainerImage{}) // var yyz4792 ContainerImage - yyc4792 = true + if yyj4783 >= len(yyv4783) { + yyv4783 = append(yyv4783, ContainerImage{}) // var yyz4783 ContainerImage + yyc4783 = true } - yyh4792.ElemContainerState(yyj4792) - if yyj4792 < len(yyv4792) { + yyh4783.ElemContainerState(yyj4783) + if yyj4783 < len(yyv4783) { if r.TryDecodeAsNil() { - yyv4792[yyj4792] = ContainerImage{} + yyv4783[yyj4783] = ContainerImage{} } else { - yyv4795 := &yyv4792[yyj4792] - yyv4795.CodecDecodeSelf(d) + yyv4786 := &yyv4783[yyj4783] + yyv4786.CodecDecodeSelf(d) } } else { @@ -61064,17 +60982,17 @@ func (x codecSelfer1234) decSliceContainerImage(v *[]ContainerImage, d *codec197 } } - if yyj4792 < len(yyv4792) { - yyv4792 = yyv4792[:yyj4792] - yyc4792 = true - } else if yyj4792 == 0 && yyv4792 == nil { - yyv4792 = []ContainerImage{} - yyc4792 = true + if yyj4783 < len(yyv4783) { + yyv4783 = yyv4783[:yyj4783] + yyc4783 = true + } else if yyj4783 == 0 && yyv4783 == nil { + yyv4783 = []ContainerImage{} + yyc4783 = true } } - yyh4792.End() - if yyc4792 { - *v = yyv4792 + yyh4783.End() + if yyc4783 { + *v = yyv4783 } } @@ -61083,9 +61001,9 @@ func (x codecSelfer1234) encSliceUniqueVolumeName(v []UniqueVolumeName, e *codec z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4796 := range v { + for _, yyv4787 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4796.CodecEncodeSelf(e) + yyv4787.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61095,75 +61013,75 @@ func (x codecSelfer1234) decSliceUniqueVolumeName(v *[]UniqueVolumeName, d *code z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4797 := *v - yyh4797, yyl4797 := z.DecSliceHelperStart() - var yyc4797 bool - if yyl4797 == 0 { - if yyv4797 == nil { - yyv4797 = []UniqueVolumeName{} - yyc4797 = true - } else if len(yyv4797) != 0 { - yyv4797 = yyv4797[:0] - yyc4797 = true + yyv4788 := *v + yyh4788, yyl4788 := z.DecSliceHelperStart() + var yyc4788 bool + if yyl4788 == 0 { + if yyv4788 == nil { + yyv4788 = []UniqueVolumeName{} + yyc4788 = true + } else if len(yyv4788) != 0 { + yyv4788 = yyv4788[:0] + yyc4788 = true } - } else if yyl4797 > 0 { - var yyrr4797, yyrl4797 int - var yyrt4797 bool - if yyl4797 > cap(yyv4797) { + } else if yyl4788 > 0 { + var yyrr4788, yyrl4788 int + var yyrt4788 bool + if yyl4788 > cap(yyv4788) { - yyrl4797, yyrt4797 = z.DecInferLen(yyl4797, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4797 { - if yyrl4797 <= cap(yyv4797) { - yyv4797 = yyv4797[:yyrl4797] + yyrl4788, yyrt4788 = z.DecInferLen(yyl4788, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4788 { + if yyrl4788 <= cap(yyv4788) { + yyv4788 = yyv4788[:yyrl4788] } else { - yyv4797 = make([]UniqueVolumeName, yyrl4797) + yyv4788 = make([]UniqueVolumeName, yyrl4788) } } else { - yyv4797 = make([]UniqueVolumeName, yyrl4797) + yyv4788 = make([]UniqueVolumeName, yyrl4788) } - yyc4797 = true - yyrr4797 = len(yyv4797) - } else if yyl4797 != len(yyv4797) { - yyv4797 = yyv4797[:yyl4797] - yyc4797 = true + yyc4788 = true + yyrr4788 = len(yyv4788) + } else if yyl4788 != len(yyv4788) { + yyv4788 = yyv4788[:yyl4788] + yyc4788 = true } - yyj4797 := 0 - for ; yyj4797 < yyrr4797; yyj4797++ { - yyh4797.ElemContainerState(yyj4797) + yyj4788 := 0 + for ; yyj4788 < yyrr4788; yyj4788++ { + yyh4788.ElemContainerState(yyj4788) if r.TryDecodeAsNil() { - yyv4797[yyj4797] = "" + yyv4788[yyj4788] = "" } else { - yyv4797[yyj4797] = UniqueVolumeName(r.DecodeString()) + yyv4788[yyj4788] = UniqueVolumeName(r.DecodeString()) } } - if yyrt4797 { - for ; yyj4797 < yyl4797; yyj4797++ { - yyv4797 = append(yyv4797, "") - yyh4797.ElemContainerState(yyj4797) + if yyrt4788 { + for ; yyj4788 < yyl4788; yyj4788++ { + yyv4788 = append(yyv4788, "") + yyh4788.ElemContainerState(yyj4788) if r.TryDecodeAsNil() { - yyv4797[yyj4797] = "" + yyv4788[yyj4788] = "" } else { - yyv4797[yyj4797] = UniqueVolumeName(r.DecodeString()) + yyv4788[yyj4788] = UniqueVolumeName(r.DecodeString()) } } } } else { - yyj4797 := 0 - for ; !r.CheckBreak(); yyj4797++ { + yyj4788 := 0 + for ; !r.CheckBreak(); yyj4788++ { - if yyj4797 >= len(yyv4797) { - yyv4797 = append(yyv4797, "") // var yyz4797 UniqueVolumeName - yyc4797 = true + if yyj4788 >= len(yyv4788) { + yyv4788 = append(yyv4788, "") // var yyz4788 UniqueVolumeName + yyc4788 = true } - yyh4797.ElemContainerState(yyj4797) - if yyj4797 < len(yyv4797) { + yyh4788.ElemContainerState(yyj4788) + if yyj4788 < len(yyv4788) { if r.TryDecodeAsNil() { - yyv4797[yyj4797] = "" + yyv4788[yyj4788] = "" } else { - yyv4797[yyj4797] = UniqueVolumeName(r.DecodeString()) + yyv4788[yyj4788] = UniqueVolumeName(r.DecodeString()) } } else { @@ -61171,17 +61089,17 @@ func (x codecSelfer1234) decSliceUniqueVolumeName(v *[]UniqueVolumeName, d *code } } - if yyj4797 < len(yyv4797) { - yyv4797 = yyv4797[:yyj4797] - yyc4797 = true - } else if yyj4797 == 0 && yyv4797 == nil { - yyv4797 = []UniqueVolumeName{} - yyc4797 = true + if yyj4788 < len(yyv4788) { + yyv4788 = yyv4788[:yyj4788] + yyc4788 = true + } else if yyj4788 == 0 && yyv4788 == nil { + yyv4788 = []UniqueVolumeName{} + yyc4788 = true } } - yyh4797.End() - if yyc4797 { - *v = yyv4797 + yyh4788.End() + if yyc4788 { + *v = yyv4788 } } @@ -61190,10 +61108,10 @@ func (x codecSelfer1234) encSliceAttachedVolume(v []AttachedVolume, e *codec1978 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4801 := range v { + for _, yyv4792 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4802 := &yyv4801 - yy4802.CodecEncodeSelf(e) + yy4793 := &yyv4792 + yy4793.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61203,83 +61121,83 @@ func (x codecSelfer1234) decSliceAttachedVolume(v *[]AttachedVolume, d *codec197 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4803 := *v - yyh4803, yyl4803 := z.DecSliceHelperStart() - var yyc4803 bool - if yyl4803 == 0 { - if yyv4803 == nil { - yyv4803 = []AttachedVolume{} - yyc4803 = true - } else if len(yyv4803) != 0 { - yyv4803 = yyv4803[:0] - yyc4803 = true + yyv4794 := *v + yyh4794, yyl4794 := z.DecSliceHelperStart() + var yyc4794 bool + if yyl4794 == 0 { + if yyv4794 == nil { + yyv4794 = []AttachedVolume{} + yyc4794 = true + } else if len(yyv4794) != 0 { + yyv4794 = yyv4794[:0] + yyc4794 = true } - } else if yyl4803 > 0 { - var yyrr4803, yyrl4803 int - var yyrt4803 bool - if yyl4803 > cap(yyv4803) { + } else if yyl4794 > 0 { + var yyrr4794, yyrl4794 int + var yyrt4794 bool + if yyl4794 > cap(yyv4794) { - yyrg4803 := len(yyv4803) > 0 - yyv24803 := yyv4803 - yyrl4803, yyrt4803 = z.DecInferLen(yyl4803, z.DecBasicHandle().MaxInitLen, 32) - if yyrt4803 { - if yyrl4803 <= cap(yyv4803) { - yyv4803 = yyv4803[:yyrl4803] + yyrg4794 := len(yyv4794) > 0 + yyv24794 := yyv4794 + yyrl4794, yyrt4794 = z.DecInferLen(yyl4794, z.DecBasicHandle().MaxInitLen, 32) + if yyrt4794 { + if yyrl4794 <= cap(yyv4794) { + yyv4794 = yyv4794[:yyrl4794] } else { - yyv4803 = make([]AttachedVolume, yyrl4803) + yyv4794 = make([]AttachedVolume, yyrl4794) } } else { - yyv4803 = make([]AttachedVolume, yyrl4803) + yyv4794 = make([]AttachedVolume, yyrl4794) } - yyc4803 = true - yyrr4803 = len(yyv4803) - if yyrg4803 { - copy(yyv4803, yyv24803) + yyc4794 = true + yyrr4794 = len(yyv4794) + if yyrg4794 { + copy(yyv4794, yyv24794) } - } else if yyl4803 != len(yyv4803) { - yyv4803 = yyv4803[:yyl4803] - yyc4803 = true + } else if yyl4794 != len(yyv4794) { + yyv4794 = yyv4794[:yyl4794] + yyc4794 = true } - yyj4803 := 0 - for ; yyj4803 < yyrr4803; yyj4803++ { - yyh4803.ElemContainerState(yyj4803) + yyj4794 := 0 + for ; yyj4794 < yyrr4794; yyj4794++ { + yyh4794.ElemContainerState(yyj4794) if r.TryDecodeAsNil() { - yyv4803[yyj4803] = AttachedVolume{} + yyv4794[yyj4794] = AttachedVolume{} } else { - yyv4804 := &yyv4803[yyj4803] - yyv4804.CodecDecodeSelf(d) + yyv4795 := &yyv4794[yyj4794] + yyv4795.CodecDecodeSelf(d) } } - if yyrt4803 { - for ; yyj4803 < yyl4803; yyj4803++ { - yyv4803 = append(yyv4803, AttachedVolume{}) - yyh4803.ElemContainerState(yyj4803) + if yyrt4794 { + for ; yyj4794 < yyl4794; yyj4794++ { + yyv4794 = append(yyv4794, AttachedVolume{}) + yyh4794.ElemContainerState(yyj4794) if r.TryDecodeAsNil() { - yyv4803[yyj4803] = AttachedVolume{} + yyv4794[yyj4794] = AttachedVolume{} } else { - yyv4805 := &yyv4803[yyj4803] - yyv4805.CodecDecodeSelf(d) + yyv4796 := &yyv4794[yyj4794] + yyv4796.CodecDecodeSelf(d) } } } } else { - yyj4803 := 0 - for ; !r.CheckBreak(); yyj4803++ { + yyj4794 := 0 + for ; !r.CheckBreak(); yyj4794++ { - if yyj4803 >= len(yyv4803) { - yyv4803 = append(yyv4803, AttachedVolume{}) // var yyz4803 AttachedVolume - yyc4803 = true + if yyj4794 >= len(yyv4794) { + yyv4794 = append(yyv4794, AttachedVolume{}) // var yyz4794 AttachedVolume + yyc4794 = true } - yyh4803.ElemContainerState(yyj4803) - if yyj4803 < len(yyv4803) { + yyh4794.ElemContainerState(yyj4794) + if yyj4794 < len(yyv4794) { if r.TryDecodeAsNil() { - yyv4803[yyj4803] = AttachedVolume{} + yyv4794[yyj4794] = AttachedVolume{} } else { - yyv4806 := &yyv4803[yyj4803] - yyv4806.CodecDecodeSelf(d) + yyv4797 := &yyv4794[yyj4794] + yyv4797.CodecDecodeSelf(d) } } else { @@ -61287,17 +61205,17 @@ func (x codecSelfer1234) decSliceAttachedVolume(v *[]AttachedVolume, d *codec197 } } - if yyj4803 < len(yyv4803) { - yyv4803 = yyv4803[:yyj4803] - yyc4803 = true - } else if yyj4803 == 0 && yyv4803 == nil { - yyv4803 = []AttachedVolume{} - yyc4803 = true + if yyj4794 < len(yyv4794) { + yyv4794 = yyv4794[:yyj4794] + yyc4794 = true + } else if yyj4794 == 0 && yyv4794 == nil { + yyv4794 = []AttachedVolume{} + yyc4794 = true } } - yyh4803.End() - if yyc4803 { - *v = yyv4803 + yyh4794.End() + if yyc4794 { + *v = yyv4794 } } @@ -61306,10 +61224,10 @@ func (x codecSelfer1234) encSlicePreferAvoidPodsEntry(v []PreferAvoidPodsEntry, z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4807 := range v { + for _, yyv4798 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4808 := &yyv4807 - yy4808.CodecEncodeSelf(e) + yy4799 := &yyv4798 + yy4799.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61319,83 +61237,83 @@ func (x codecSelfer1234) decSlicePreferAvoidPodsEntry(v *[]PreferAvoidPodsEntry, z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4809 := *v - yyh4809, yyl4809 := z.DecSliceHelperStart() - var yyc4809 bool - if yyl4809 == 0 { - if yyv4809 == nil { - yyv4809 = []PreferAvoidPodsEntry{} - yyc4809 = true - } else if len(yyv4809) != 0 { - yyv4809 = yyv4809[:0] - yyc4809 = true + yyv4800 := *v + yyh4800, yyl4800 := z.DecSliceHelperStart() + var yyc4800 bool + if yyl4800 == 0 { + if yyv4800 == nil { + yyv4800 = []PreferAvoidPodsEntry{} + yyc4800 = true + } else if len(yyv4800) != 0 { + yyv4800 = yyv4800[:0] + yyc4800 = true } - } else if yyl4809 > 0 { - var yyrr4809, yyrl4809 int - var yyrt4809 bool - if yyl4809 > cap(yyv4809) { + } else if yyl4800 > 0 { + var yyrr4800, yyrl4800 int + var yyrt4800 bool + if yyl4800 > cap(yyv4800) { - yyrg4809 := len(yyv4809) > 0 - yyv24809 := yyv4809 - yyrl4809, yyrt4809 = z.DecInferLen(yyl4809, z.DecBasicHandle().MaxInitLen, 64) - if yyrt4809 { - if yyrl4809 <= cap(yyv4809) { - yyv4809 = yyv4809[:yyrl4809] + yyrg4800 := len(yyv4800) > 0 + yyv24800 := yyv4800 + yyrl4800, yyrt4800 = z.DecInferLen(yyl4800, z.DecBasicHandle().MaxInitLen, 64) + if yyrt4800 { + if yyrl4800 <= cap(yyv4800) { + yyv4800 = yyv4800[:yyrl4800] } else { - yyv4809 = make([]PreferAvoidPodsEntry, yyrl4809) + yyv4800 = make([]PreferAvoidPodsEntry, yyrl4800) } } else { - yyv4809 = make([]PreferAvoidPodsEntry, yyrl4809) + yyv4800 = make([]PreferAvoidPodsEntry, yyrl4800) } - yyc4809 = true - yyrr4809 = len(yyv4809) - if yyrg4809 { - copy(yyv4809, yyv24809) + yyc4800 = true + yyrr4800 = len(yyv4800) + if yyrg4800 { + copy(yyv4800, yyv24800) } - } else if yyl4809 != len(yyv4809) { - yyv4809 = yyv4809[:yyl4809] - yyc4809 = true + } else if yyl4800 != len(yyv4800) { + yyv4800 = yyv4800[:yyl4800] + yyc4800 = true } - yyj4809 := 0 - for ; yyj4809 < yyrr4809; yyj4809++ { - yyh4809.ElemContainerState(yyj4809) + yyj4800 := 0 + for ; yyj4800 < yyrr4800; yyj4800++ { + yyh4800.ElemContainerState(yyj4800) if r.TryDecodeAsNil() { - yyv4809[yyj4809] = PreferAvoidPodsEntry{} + yyv4800[yyj4800] = PreferAvoidPodsEntry{} } else { - yyv4810 := &yyv4809[yyj4809] - yyv4810.CodecDecodeSelf(d) + yyv4801 := &yyv4800[yyj4800] + yyv4801.CodecDecodeSelf(d) } } - if yyrt4809 { - for ; yyj4809 < yyl4809; yyj4809++ { - yyv4809 = append(yyv4809, PreferAvoidPodsEntry{}) - yyh4809.ElemContainerState(yyj4809) + if yyrt4800 { + for ; yyj4800 < yyl4800; yyj4800++ { + yyv4800 = append(yyv4800, PreferAvoidPodsEntry{}) + yyh4800.ElemContainerState(yyj4800) if r.TryDecodeAsNil() { - yyv4809[yyj4809] = PreferAvoidPodsEntry{} + yyv4800[yyj4800] = PreferAvoidPodsEntry{} } else { - yyv4811 := &yyv4809[yyj4809] - yyv4811.CodecDecodeSelf(d) + yyv4802 := &yyv4800[yyj4800] + yyv4802.CodecDecodeSelf(d) } } } } else { - yyj4809 := 0 - for ; !r.CheckBreak(); yyj4809++ { + yyj4800 := 0 + for ; !r.CheckBreak(); yyj4800++ { - if yyj4809 >= len(yyv4809) { - yyv4809 = append(yyv4809, PreferAvoidPodsEntry{}) // var yyz4809 PreferAvoidPodsEntry - yyc4809 = true + if yyj4800 >= len(yyv4800) { + yyv4800 = append(yyv4800, PreferAvoidPodsEntry{}) // var yyz4800 PreferAvoidPodsEntry + yyc4800 = true } - yyh4809.ElemContainerState(yyj4809) - if yyj4809 < len(yyv4809) { + yyh4800.ElemContainerState(yyj4800) + if yyj4800 < len(yyv4800) { if r.TryDecodeAsNil() { - yyv4809[yyj4809] = PreferAvoidPodsEntry{} + yyv4800[yyj4800] = PreferAvoidPodsEntry{} } else { - yyv4812 := &yyv4809[yyj4809] - yyv4812.CodecDecodeSelf(d) + yyv4803 := &yyv4800[yyj4800] + yyv4803.CodecDecodeSelf(d) } } else { @@ -61403,17 +61321,17 @@ func (x codecSelfer1234) decSlicePreferAvoidPodsEntry(v *[]PreferAvoidPodsEntry, } } - if yyj4809 < len(yyv4809) { - yyv4809 = yyv4809[:yyj4809] - yyc4809 = true - } else if yyj4809 == 0 && yyv4809 == nil { - yyv4809 = []PreferAvoidPodsEntry{} - yyc4809 = true + if yyj4800 < len(yyv4800) { + yyv4800 = yyv4800[:yyj4800] + yyc4800 = true + } else if yyj4800 == 0 && yyv4800 == nil { + yyv4800 = []PreferAvoidPodsEntry{} + yyc4800 = true } } - yyh4809.End() - if yyc4809 { - *v = yyv4809 + yyh4800.End() + if yyc4800 { + *v = yyv4800 } } @@ -61422,19 +61340,19 @@ func (x codecSelfer1234) encResourceList(v ResourceList, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeMapStart(len(v)) - for yyk4813, yyv4813 := range v { + for yyk4804, yyv4804 := range v { z.EncSendContainerState(codecSelfer_containerMapKey1234) - yyk4813.CodecEncodeSelf(e) + yyk4804.CodecEncodeSelf(e) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy4814 := &yyv4813 - yym4815 := z.EncBinary() - _ = yym4815 + yy4805 := &yyv4804 + yym4806 := z.EncBinary() + _ = yym4806 if false { - } else if z.HasExtensions() && z.EncExt(yy4814) { - } else if !yym4815 && z.IsJSONHandle() { - z.EncJSONMarshal(yy4814) + } else if z.HasExtensions() && z.EncExt(yy4805) { + } else if !yym4806 && z.IsJSONHandle() { + z.EncJSONMarshal(yy4805) } else { - z.EncFallback(yy4814) + z.EncFallback(yy4805) } } z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -61445,86 +61363,86 @@ func (x codecSelfer1234) decResourceList(v *ResourceList, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4816 := *v - yyl4816 := r.ReadMapStart() - yybh4816 := z.DecBasicHandle() - if yyv4816 == nil { - yyrl4816, _ := z.DecInferLen(yyl4816, yybh4816.MaxInitLen, 72) - yyv4816 = make(map[ResourceName]pkg3_resource.Quantity, yyrl4816) - *v = yyv4816 + yyv4807 := *v + yyl4807 := r.ReadMapStart() + yybh4807 := z.DecBasicHandle() + if yyv4807 == nil { + yyrl4807, _ := z.DecInferLen(yyl4807, yybh4807.MaxInitLen, 72) + yyv4807 = make(map[ResourceName]pkg3_resource.Quantity, yyrl4807) + *v = yyv4807 } - var yymk4816 ResourceName - var yymv4816 pkg3_resource.Quantity - var yymg4816 bool - if yybh4816.MapValueReset { - yymg4816 = true + var yymk4807 ResourceName + var yymv4807 pkg3_resource.Quantity + var yymg4807 bool + if yybh4807.MapValueReset { + yymg4807 = true } - if yyl4816 > 0 { - for yyj4816 := 0; yyj4816 < yyl4816; yyj4816++ { + if yyl4807 > 0 { + for yyj4807 := 0; yyj4807 < yyl4807; yyj4807++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4816 = "" + yymk4807 = "" } else { - yymk4816 = ResourceName(r.DecodeString()) + yymk4807 = ResourceName(r.DecodeString()) } - if yymg4816 { - yymv4816 = yyv4816[yymk4816] + if yymg4807 { + yymv4807 = yyv4807[yymk4807] } else { - yymv4816 = pkg3_resource.Quantity{} + yymv4807 = pkg3_resource.Quantity{} } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4816 = pkg3_resource.Quantity{} + yymv4807 = pkg3_resource.Quantity{} } else { - yyv4818 := &yymv4816 - yym4819 := z.DecBinary() - _ = yym4819 + yyv4809 := &yymv4807 + yym4810 := z.DecBinary() + _ = yym4810 if false { - } else if z.HasExtensions() && z.DecExt(yyv4818) { - } else if !yym4819 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4818) + } else if z.HasExtensions() && z.DecExt(yyv4809) { + } else if !yym4810 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4809) } else { - z.DecFallback(yyv4818, false) + z.DecFallback(yyv4809, false) } } - if yyv4816 != nil { - yyv4816[yymk4816] = yymv4816 + if yyv4807 != nil { + yyv4807[yymk4807] = yymv4807 } } - } else if yyl4816 < 0 { - for yyj4816 := 0; !r.CheckBreak(); yyj4816++ { + } else if yyl4807 < 0 { + for yyj4807 := 0; !r.CheckBreak(); yyj4807++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4816 = "" + yymk4807 = "" } else { - yymk4816 = ResourceName(r.DecodeString()) + yymk4807 = ResourceName(r.DecodeString()) } - if yymg4816 { - yymv4816 = yyv4816[yymk4816] + if yymg4807 { + yymv4807 = yyv4807[yymk4807] } else { - yymv4816 = pkg3_resource.Quantity{} + yymv4807 = pkg3_resource.Quantity{} } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4816 = pkg3_resource.Quantity{} + yymv4807 = pkg3_resource.Quantity{} } else { - yyv4821 := &yymv4816 - yym4822 := z.DecBinary() - _ = yym4822 + yyv4812 := &yymv4807 + yym4813 := z.DecBinary() + _ = yym4813 if false { - } else if z.HasExtensions() && z.DecExt(yyv4821) { - } else if !yym4822 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4821) + } else if z.HasExtensions() && z.DecExt(yyv4812) { + } else if !yym4813 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4812) } else { - z.DecFallback(yyv4821, false) + z.DecFallback(yyv4812, false) } } - if yyv4816 != nil { - yyv4816[yymk4816] = yymv4816 + if yyv4807 != nil { + yyv4807[yymk4807] = yymv4807 } } } // else len==0: TODO: Should we clear map entries? @@ -61536,10 +61454,10 @@ func (x codecSelfer1234) encSliceNode(v []Node, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4823 := range v { + for _, yyv4814 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4824 := &yyv4823 - yy4824.CodecEncodeSelf(e) + yy4815 := &yyv4814 + yy4815.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61549,83 +61467,83 @@ func (x codecSelfer1234) decSliceNode(v *[]Node, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4825 := *v - yyh4825, yyl4825 := z.DecSliceHelperStart() - var yyc4825 bool - if yyl4825 == 0 { - if yyv4825 == nil { - yyv4825 = []Node{} - yyc4825 = true - } else if len(yyv4825) != 0 { - yyv4825 = yyv4825[:0] - yyc4825 = true + yyv4816 := *v + yyh4816, yyl4816 := z.DecSliceHelperStart() + var yyc4816 bool + if yyl4816 == 0 { + if yyv4816 == nil { + yyv4816 = []Node{} + yyc4816 = true + } else if len(yyv4816) != 0 { + yyv4816 = yyv4816[:0] + yyc4816 = true } - } else if yyl4825 > 0 { - var yyrr4825, yyrl4825 int - var yyrt4825 bool - if yyl4825 > cap(yyv4825) { + } else if yyl4816 > 0 { + var yyrr4816, yyrl4816 int + var yyrt4816 bool + if yyl4816 > cap(yyv4816) { - yyrg4825 := len(yyv4825) > 0 - yyv24825 := yyv4825 - yyrl4825, yyrt4825 = z.DecInferLen(yyl4825, z.DecBasicHandle().MaxInitLen, 632) - if yyrt4825 { - if yyrl4825 <= cap(yyv4825) { - yyv4825 = yyv4825[:yyrl4825] + yyrg4816 := len(yyv4816) > 0 + yyv24816 := yyv4816 + yyrl4816, yyrt4816 = z.DecInferLen(yyl4816, z.DecBasicHandle().MaxInitLen, 632) + if yyrt4816 { + if yyrl4816 <= cap(yyv4816) { + yyv4816 = yyv4816[:yyrl4816] } else { - yyv4825 = make([]Node, yyrl4825) + yyv4816 = make([]Node, yyrl4816) } } else { - yyv4825 = make([]Node, yyrl4825) + yyv4816 = make([]Node, yyrl4816) } - yyc4825 = true - yyrr4825 = len(yyv4825) - if yyrg4825 { - copy(yyv4825, yyv24825) + yyc4816 = true + yyrr4816 = len(yyv4816) + if yyrg4816 { + copy(yyv4816, yyv24816) } - } else if yyl4825 != len(yyv4825) { - yyv4825 = yyv4825[:yyl4825] - yyc4825 = true + } else if yyl4816 != len(yyv4816) { + yyv4816 = yyv4816[:yyl4816] + yyc4816 = true } - yyj4825 := 0 - for ; yyj4825 < yyrr4825; yyj4825++ { - yyh4825.ElemContainerState(yyj4825) + yyj4816 := 0 + for ; yyj4816 < yyrr4816; yyj4816++ { + yyh4816.ElemContainerState(yyj4816) if r.TryDecodeAsNil() { - yyv4825[yyj4825] = Node{} + yyv4816[yyj4816] = Node{} } else { - yyv4826 := &yyv4825[yyj4825] - yyv4826.CodecDecodeSelf(d) + yyv4817 := &yyv4816[yyj4816] + yyv4817.CodecDecodeSelf(d) } } - if yyrt4825 { - for ; yyj4825 < yyl4825; yyj4825++ { - yyv4825 = append(yyv4825, Node{}) - yyh4825.ElemContainerState(yyj4825) + if yyrt4816 { + for ; yyj4816 < yyl4816; yyj4816++ { + yyv4816 = append(yyv4816, Node{}) + yyh4816.ElemContainerState(yyj4816) if r.TryDecodeAsNil() { - yyv4825[yyj4825] = Node{} + yyv4816[yyj4816] = Node{} } else { - yyv4827 := &yyv4825[yyj4825] - yyv4827.CodecDecodeSelf(d) + yyv4818 := &yyv4816[yyj4816] + yyv4818.CodecDecodeSelf(d) } } } } else { - yyj4825 := 0 - for ; !r.CheckBreak(); yyj4825++ { + yyj4816 := 0 + for ; !r.CheckBreak(); yyj4816++ { - if yyj4825 >= len(yyv4825) { - yyv4825 = append(yyv4825, Node{}) // var yyz4825 Node - yyc4825 = true + if yyj4816 >= len(yyv4816) { + yyv4816 = append(yyv4816, Node{}) // var yyz4816 Node + yyc4816 = true } - yyh4825.ElemContainerState(yyj4825) - if yyj4825 < len(yyv4825) { + yyh4816.ElemContainerState(yyj4816) + if yyj4816 < len(yyv4816) { if r.TryDecodeAsNil() { - yyv4825[yyj4825] = Node{} + yyv4816[yyj4816] = Node{} } else { - yyv4828 := &yyv4825[yyj4825] - yyv4828.CodecDecodeSelf(d) + yyv4819 := &yyv4816[yyj4816] + yyv4819.CodecDecodeSelf(d) } } else { @@ -61633,17 +61551,17 @@ func (x codecSelfer1234) decSliceNode(v *[]Node, d *codec1978.Decoder) { } } - if yyj4825 < len(yyv4825) { - yyv4825 = yyv4825[:yyj4825] - yyc4825 = true - } else if yyj4825 == 0 && yyv4825 == nil { - yyv4825 = []Node{} - yyc4825 = true + if yyj4816 < len(yyv4816) { + yyv4816 = yyv4816[:yyj4816] + yyc4816 = true + } else if yyj4816 == 0 && yyv4816 == nil { + yyv4816 = []Node{} + yyc4816 = true } } - yyh4825.End() - if yyc4825 { - *v = yyv4825 + yyh4816.End() + if yyc4816 { + *v = yyv4816 } } @@ -61652,9 +61570,9 @@ func (x codecSelfer1234) encSliceFinalizerName(v []FinalizerName, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4829 := range v { + for _, yyv4820 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4829.CodecEncodeSelf(e) + yyv4820.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61664,75 +61582,75 @@ func (x codecSelfer1234) decSliceFinalizerName(v *[]FinalizerName, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4830 := *v - yyh4830, yyl4830 := z.DecSliceHelperStart() - var yyc4830 bool - if yyl4830 == 0 { - if yyv4830 == nil { - yyv4830 = []FinalizerName{} - yyc4830 = true - } else if len(yyv4830) != 0 { - yyv4830 = yyv4830[:0] - yyc4830 = true + yyv4821 := *v + yyh4821, yyl4821 := z.DecSliceHelperStart() + var yyc4821 bool + if yyl4821 == 0 { + if yyv4821 == nil { + yyv4821 = []FinalizerName{} + yyc4821 = true + } else if len(yyv4821) != 0 { + yyv4821 = yyv4821[:0] + yyc4821 = true } - } else if yyl4830 > 0 { - var yyrr4830, yyrl4830 int - var yyrt4830 bool - if yyl4830 > cap(yyv4830) { + } else if yyl4821 > 0 { + var yyrr4821, yyrl4821 int + var yyrt4821 bool + if yyl4821 > cap(yyv4821) { - yyrl4830, yyrt4830 = z.DecInferLen(yyl4830, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4830 { - if yyrl4830 <= cap(yyv4830) { - yyv4830 = yyv4830[:yyrl4830] + yyrl4821, yyrt4821 = z.DecInferLen(yyl4821, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4821 { + if yyrl4821 <= cap(yyv4821) { + yyv4821 = yyv4821[:yyrl4821] } else { - yyv4830 = make([]FinalizerName, yyrl4830) + yyv4821 = make([]FinalizerName, yyrl4821) } } else { - yyv4830 = make([]FinalizerName, yyrl4830) + yyv4821 = make([]FinalizerName, yyrl4821) } - yyc4830 = true - yyrr4830 = len(yyv4830) - } else if yyl4830 != len(yyv4830) { - yyv4830 = yyv4830[:yyl4830] - yyc4830 = true + yyc4821 = true + yyrr4821 = len(yyv4821) + } else if yyl4821 != len(yyv4821) { + yyv4821 = yyv4821[:yyl4821] + yyc4821 = true } - yyj4830 := 0 - for ; yyj4830 < yyrr4830; yyj4830++ { - yyh4830.ElemContainerState(yyj4830) + yyj4821 := 0 + for ; yyj4821 < yyrr4821; yyj4821++ { + yyh4821.ElemContainerState(yyj4821) if r.TryDecodeAsNil() { - yyv4830[yyj4830] = "" + yyv4821[yyj4821] = "" } else { - yyv4830[yyj4830] = FinalizerName(r.DecodeString()) + yyv4821[yyj4821] = FinalizerName(r.DecodeString()) } } - if yyrt4830 { - for ; yyj4830 < yyl4830; yyj4830++ { - yyv4830 = append(yyv4830, "") - yyh4830.ElemContainerState(yyj4830) + if yyrt4821 { + for ; yyj4821 < yyl4821; yyj4821++ { + yyv4821 = append(yyv4821, "") + yyh4821.ElemContainerState(yyj4821) if r.TryDecodeAsNil() { - yyv4830[yyj4830] = "" + yyv4821[yyj4821] = "" } else { - yyv4830[yyj4830] = FinalizerName(r.DecodeString()) + yyv4821[yyj4821] = FinalizerName(r.DecodeString()) } } } } else { - yyj4830 := 0 - for ; !r.CheckBreak(); yyj4830++ { + yyj4821 := 0 + for ; !r.CheckBreak(); yyj4821++ { - if yyj4830 >= len(yyv4830) { - yyv4830 = append(yyv4830, "") // var yyz4830 FinalizerName - yyc4830 = true + if yyj4821 >= len(yyv4821) { + yyv4821 = append(yyv4821, "") // var yyz4821 FinalizerName + yyc4821 = true } - yyh4830.ElemContainerState(yyj4830) - if yyj4830 < len(yyv4830) { + yyh4821.ElemContainerState(yyj4821) + if yyj4821 < len(yyv4821) { if r.TryDecodeAsNil() { - yyv4830[yyj4830] = "" + yyv4821[yyj4821] = "" } else { - yyv4830[yyj4830] = FinalizerName(r.DecodeString()) + yyv4821[yyj4821] = FinalizerName(r.DecodeString()) } } else { @@ -61740,17 +61658,17 @@ func (x codecSelfer1234) decSliceFinalizerName(v *[]FinalizerName, d *codec1978. } } - if yyj4830 < len(yyv4830) { - yyv4830 = yyv4830[:yyj4830] - yyc4830 = true - } else if yyj4830 == 0 && yyv4830 == nil { - yyv4830 = []FinalizerName{} - yyc4830 = true + if yyj4821 < len(yyv4821) { + yyv4821 = yyv4821[:yyj4821] + yyc4821 = true + } else if yyj4821 == 0 && yyv4821 == nil { + yyv4821 = []FinalizerName{} + yyc4821 = true } } - yyh4830.End() - if yyc4830 { - *v = yyv4830 + yyh4821.End() + if yyc4821 { + *v = yyv4821 } } @@ -61759,10 +61677,10 @@ func (x codecSelfer1234) encSliceNamespace(v []Namespace, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4834 := range v { + for _, yyv4825 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4835 := &yyv4834 - yy4835.CodecEncodeSelf(e) + yy4826 := &yyv4825 + yy4826.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61772,83 +61690,83 @@ func (x codecSelfer1234) decSliceNamespace(v *[]Namespace, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4836 := *v - yyh4836, yyl4836 := z.DecSliceHelperStart() - var yyc4836 bool - if yyl4836 == 0 { - if yyv4836 == nil { - yyv4836 = []Namespace{} - yyc4836 = true - } else if len(yyv4836) != 0 { - yyv4836 = yyv4836[:0] - yyc4836 = true + yyv4827 := *v + yyh4827, yyl4827 := z.DecSliceHelperStart() + var yyc4827 bool + if yyl4827 == 0 { + if yyv4827 == nil { + yyv4827 = []Namespace{} + yyc4827 = true + } else if len(yyv4827) != 0 { + yyv4827 = yyv4827[:0] + yyc4827 = true } - } else if yyl4836 > 0 { - var yyrr4836, yyrl4836 int - var yyrt4836 bool - if yyl4836 > cap(yyv4836) { + } else if yyl4827 > 0 { + var yyrr4827, yyrl4827 int + var yyrt4827 bool + if yyl4827 > cap(yyv4827) { - yyrg4836 := len(yyv4836) > 0 - yyv24836 := yyv4836 - yyrl4836, yyrt4836 = z.DecInferLen(yyl4836, z.DecBasicHandle().MaxInitLen, 296) - if yyrt4836 { - if yyrl4836 <= cap(yyv4836) { - yyv4836 = yyv4836[:yyrl4836] + yyrg4827 := len(yyv4827) > 0 + yyv24827 := yyv4827 + yyrl4827, yyrt4827 = z.DecInferLen(yyl4827, z.DecBasicHandle().MaxInitLen, 296) + if yyrt4827 { + if yyrl4827 <= cap(yyv4827) { + yyv4827 = yyv4827[:yyrl4827] } else { - yyv4836 = make([]Namespace, yyrl4836) + yyv4827 = make([]Namespace, yyrl4827) } } else { - yyv4836 = make([]Namespace, yyrl4836) + yyv4827 = make([]Namespace, yyrl4827) } - yyc4836 = true - yyrr4836 = len(yyv4836) - if yyrg4836 { - copy(yyv4836, yyv24836) + yyc4827 = true + yyrr4827 = len(yyv4827) + if yyrg4827 { + copy(yyv4827, yyv24827) } - } else if yyl4836 != len(yyv4836) { - yyv4836 = yyv4836[:yyl4836] - yyc4836 = true + } else if yyl4827 != len(yyv4827) { + yyv4827 = yyv4827[:yyl4827] + yyc4827 = true } - yyj4836 := 0 - for ; yyj4836 < yyrr4836; yyj4836++ { - yyh4836.ElemContainerState(yyj4836) + yyj4827 := 0 + for ; yyj4827 < yyrr4827; yyj4827++ { + yyh4827.ElemContainerState(yyj4827) if r.TryDecodeAsNil() { - yyv4836[yyj4836] = Namespace{} + yyv4827[yyj4827] = Namespace{} } else { - yyv4837 := &yyv4836[yyj4836] - yyv4837.CodecDecodeSelf(d) + yyv4828 := &yyv4827[yyj4827] + yyv4828.CodecDecodeSelf(d) } } - if yyrt4836 { - for ; yyj4836 < yyl4836; yyj4836++ { - yyv4836 = append(yyv4836, Namespace{}) - yyh4836.ElemContainerState(yyj4836) + if yyrt4827 { + for ; yyj4827 < yyl4827; yyj4827++ { + yyv4827 = append(yyv4827, Namespace{}) + yyh4827.ElemContainerState(yyj4827) if r.TryDecodeAsNil() { - yyv4836[yyj4836] = Namespace{} + yyv4827[yyj4827] = Namespace{} } else { - yyv4838 := &yyv4836[yyj4836] - yyv4838.CodecDecodeSelf(d) + yyv4829 := &yyv4827[yyj4827] + yyv4829.CodecDecodeSelf(d) } } } } else { - yyj4836 := 0 - for ; !r.CheckBreak(); yyj4836++ { + yyj4827 := 0 + for ; !r.CheckBreak(); yyj4827++ { - if yyj4836 >= len(yyv4836) { - yyv4836 = append(yyv4836, Namespace{}) // var yyz4836 Namespace - yyc4836 = true + if yyj4827 >= len(yyv4827) { + yyv4827 = append(yyv4827, Namespace{}) // var yyz4827 Namespace + yyc4827 = true } - yyh4836.ElemContainerState(yyj4836) - if yyj4836 < len(yyv4836) { + yyh4827.ElemContainerState(yyj4827) + if yyj4827 < len(yyv4827) { if r.TryDecodeAsNil() { - yyv4836[yyj4836] = Namespace{} + yyv4827[yyj4827] = Namespace{} } else { - yyv4839 := &yyv4836[yyj4836] - yyv4839.CodecDecodeSelf(d) + yyv4830 := &yyv4827[yyj4827] + yyv4830.CodecDecodeSelf(d) } } else { @@ -61856,17 +61774,17 @@ func (x codecSelfer1234) decSliceNamespace(v *[]Namespace, d *codec1978.Decoder) } } - if yyj4836 < len(yyv4836) { - yyv4836 = yyv4836[:yyj4836] - yyc4836 = true - } else if yyj4836 == 0 && yyv4836 == nil { - yyv4836 = []Namespace{} - yyc4836 = true + if yyj4827 < len(yyv4827) { + yyv4827 = yyv4827[:yyj4827] + yyc4827 = true + } else if yyj4827 == 0 && yyv4827 == nil { + yyv4827 = []Namespace{} + yyc4827 = true } } - yyh4836.End() - if yyc4836 { - *v = yyv4836 + yyh4827.End() + if yyc4827 { + *v = yyv4827 } } @@ -61875,10 +61793,10 @@ func (x codecSelfer1234) encSliceEvent(v []Event, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4840 := range v { + for _, yyv4831 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4841 := &yyv4840 - yy4841.CodecEncodeSelf(e) + yy4832 := &yyv4831 + yy4832.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -61888,83 +61806,83 @@ func (x codecSelfer1234) decSliceEvent(v *[]Event, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4842 := *v - yyh4842, yyl4842 := z.DecSliceHelperStart() - var yyc4842 bool - if yyl4842 == 0 { - if yyv4842 == nil { - yyv4842 = []Event{} - yyc4842 = true - } else if len(yyv4842) != 0 { - yyv4842 = yyv4842[:0] - yyc4842 = true + yyv4833 := *v + yyh4833, yyl4833 := z.DecSliceHelperStart() + var yyc4833 bool + if yyl4833 == 0 { + if yyv4833 == nil { + yyv4833 = []Event{} + yyc4833 = true + } else if len(yyv4833) != 0 { + yyv4833 = yyv4833[:0] + yyc4833 = true } - } else if yyl4842 > 0 { - var yyrr4842, yyrl4842 int - var yyrt4842 bool - if yyl4842 > cap(yyv4842) { + } else if yyl4833 > 0 { + var yyrr4833, yyrl4833 int + var yyrt4833 bool + if yyl4833 > cap(yyv4833) { - yyrg4842 := len(yyv4842) > 0 - yyv24842 := yyv4842 - yyrl4842, yyrt4842 = z.DecInferLen(yyl4842, z.DecBasicHandle().MaxInitLen, 504) - if yyrt4842 { - if yyrl4842 <= cap(yyv4842) { - yyv4842 = yyv4842[:yyrl4842] + yyrg4833 := len(yyv4833) > 0 + yyv24833 := yyv4833 + yyrl4833, yyrt4833 = z.DecInferLen(yyl4833, z.DecBasicHandle().MaxInitLen, 504) + if yyrt4833 { + if yyrl4833 <= cap(yyv4833) { + yyv4833 = yyv4833[:yyrl4833] } else { - yyv4842 = make([]Event, yyrl4842) + yyv4833 = make([]Event, yyrl4833) } } else { - yyv4842 = make([]Event, yyrl4842) + yyv4833 = make([]Event, yyrl4833) } - yyc4842 = true - yyrr4842 = len(yyv4842) - if yyrg4842 { - copy(yyv4842, yyv24842) + yyc4833 = true + yyrr4833 = len(yyv4833) + if yyrg4833 { + copy(yyv4833, yyv24833) } - } else if yyl4842 != len(yyv4842) { - yyv4842 = yyv4842[:yyl4842] - yyc4842 = true + } else if yyl4833 != len(yyv4833) { + yyv4833 = yyv4833[:yyl4833] + yyc4833 = true } - yyj4842 := 0 - for ; yyj4842 < yyrr4842; yyj4842++ { - yyh4842.ElemContainerState(yyj4842) + yyj4833 := 0 + for ; yyj4833 < yyrr4833; yyj4833++ { + yyh4833.ElemContainerState(yyj4833) if r.TryDecodeAsNil() { - yyv4842[yyj4842] = Event{} + yyv4833[yyj4833] = Event{} } else { - yyv4843 := &yyv4842[yyj4842] - yyv4843.CodecDecodeSelf(d) + yyv4834 := &yyv4833[yyj4833] + yyv4834.CodecDecodeSelf(d) } } - if yyrt4842 { - for ; yyj4842 < yyl4842; yyj4842++ { - yyv4842 = append(yyv4842, Event{}) - yyh4842.ElemContainerState(yyj4842) + if yyrt4833 { + for ; yyj4833 < yyl4833; yyj4833++ { + yyv4833 = append(yyv4833, Event{}) + yyh4833.ElemContainerState(yyj4833) if r.TryDecodeAsNil() { - yyv4842[yyj4842] = Event{} + yyv4833[yyj4833] = Event{} } else { - yyv4844 := &yyv4842[yyj4842] - yyv4844.CodecDecodeSelf(d) + yyv4835 := &yyv4833[yyj4833] + yyv4835.CodecDecodeSelf(d) } } } } else { - yyj4842 := 0 - for ; !r.CheckBreak(); yyj4842++ { + yyj4833 := 0 + for ; !r.CheckBreak(); yyj4833++ { - if yyj4842 >= len(yyv4842) { - yyv4842 = append(yyv4842, Event{}) // var yyz4842 Event - yyc4842 = true + if yyj4833 >= len(yyv4833) { + yyv4833 = append(yyv4833, Event{}) // var yyz4833 Event + yyc4833 = true } - yyh4842.ElemContainerState(yyj4842) - if yyj4842 < len(yyv4842) { + yyh4833.ElemContainerState(yyj4833) + if yyj4833 < len(yyv4833) { if r.TryDecodeAsNil() { - yyv4842[yyj4842] = Event{} + yyv4833[yyj4833] = Event{} } else { - yyv4845 := &yyv4842[yyj4842] - yyv4845.CodecDecodeSelf(d) + yyv4836 := &yyv4833[yyj4833] + yyv4836.CodecDecodeSelf(d) } } else { @@ -61972,17 +61890,17 @@ func (x codecSelfer1234) decSliceEvent(v *[]Event, d *codec1978.Decoder) { } } - if yyj4842 < len(yyv4842) { - yyv4842 = yyv4842[:yyj4842] - yyc4842 = true - } else if yyj4842 == 0 && yyv4842 == nil { - yyv4842 = []Event{} - yyc4842 = true + if yyj4833 < len(yyv4833) { + yyv4833 = yyv4833[:yyj4833] + yyc4833 = true + } else if yyj4833 == 0 && yyv4833 == nil { + yyv4833 = []Event{} + yyc4833 = true } } - yyh4842.End() - if yyc4842 { - *v = yyv4842 + yyh4833.End() + if yyc4833 { + *v = yyv4833 } } @@ -61991,17 +61909,17 @@ func (x codecSelfer1234) encSliceruntime_RawExtension(v []pkg5_runtime.RawExtens z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4846 := range v { + for _, yyv4837 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4847 := &yyv4846 - yym4848 := z.EncBinary() - _ = yym4848 + yy4838 := &yyv4837 + yym4839 := z.EncBinary() + _ = yym4839 if false { - } else if z.HasExtensions() && z.EncExt(yy4847) { - } else if !yym4848 && z.IsJSONHandle() { - z.EncJSONMarshal(yy4847) + } else if z.HasExtensions() && z.EncExt(yy4838) { + } else if !yym4839 && z.IsJSONHandle() { + z.EncJSONMarshal(yy4838) } else { - z.EncFallback(yy4847) + z.EncFallback(yy4838) } } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) @@ -62012,12 +61930,152 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r + yyv4840 := *v + yyh4840, yyl4840 := z.DecSliceHelperStart() + var yyc4840 bool + if yyl4840 == 0 { + if yyv4840 == nil { + yyv4840 = []pkg5_runtime.RawExtension{} + yyc4840 = true + } else if len(yyv4840) != 0 { + yyv4840 = yyv4840[:0] + yyc4840 = true + } + } else if yyl4840 > 0 { + var yyrr4840, yyrl4840 int + var yyrt4840 bool + if yyl4840 > cap(yyv4840) { + + yyrg4840 := len(yyv4840) > 0 + yyv24840 := yyv4840 + yyrl4840, yyrt4840 = z.DecInferLen(yyl4840, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4840 { + if yyrl4840 <= cap(yyv4840) { + yyv4840 = yyv4840[:yyrl4840] + } else { + yyv4840 = make([]pkg5_runtime.RawExtension, yyrl4840) + } + } else { + yyv4840 = make([]pkg5_runtime.RawExtension, yyrl4840) + } + yyc4840 = true + yyrr4840 = len(yyv4840) + if yyrg4840 { + copy(yyv4840, yyv24840) + } + } else if yyl4840 != len(yyv4840) { + yyv4840 = yyv4840[:yyl4840] + yyc4840 = true + } + yyj4840 := 0 + for ; yyj4840 < yyrr4840; yyj4840++ { + yyh4840.ElemContainerState(yyj4840) + if r.TryDecodeAsNil() { + yyv4840[yyj4840] = pkg5_runtime.RawExtension{} + } else { + yyv4841 := &yyv4840[yyj4840] + yym4842 := z.DecBinary() + _ = yym4842 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4841) { + } else if !yym4842 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4841) + } else { + z.DecFallback(yyv4841, false) + } + } + + } + if yyrt4840 { + for ; yyj4840 < yyl4840; yyj4840++ { + yyv4840 = append(yyv4840, pkg5_runtime.RawExtension{}) + yyh4840.ElemContainerState(yyj4840) + if r.TryDecodeAsNil() { + yyv4840[yyj4840] = pkg5_runtime.RawExtension{} + } else { + yyv4843 := &yyv4840[yyj4840] + yym4844 := z.DecBinary() + _ = yym4844 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4843) { + } else if !yym4844 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4843) + } else { + z.DecFallback(yyv4843, false) + } + } + + } + } + + } else { + yyj4840 := 0 + for ; !r.CheckBreak(); yyj4840++ { + + if yyj4840 >= len(yyv4840) { + yyv4840 = append(yyv4840, pkg5_runtime.RawExtension{}) // var yyz4840 pkg5_runtime.RawExtension + yyc4840 = true + } + yyh4840.ElemContainerState(yyj4840) + if yyj4840 < len(yyv4840) { + if r.TryDecodeAsNil() { + yyv4840[yyj4840] = pkg5_runtime.RawExtension{} + } else { + yyv4845 := &yyv4840[yyj4840] + yym4846 := z.DecBinary() + _ = yym4846 + if false { + } else if z.HasExtensions() && z.DecExt(yyv4845) { + } else if !yym4846 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv4845) + } else { + z.DecFallback(yyv4845, false) + } + } + + } else { + z.DecSwallow() + } + + } + if yyj4840 < len(yyv4840) { + yyv4840 = yyv4840[:yyj4840] + yyc4840 = true + } else if yyj4840 == 0 && yyv4840 == nil { + yyv4840 = []pkg5_runtime.RawExtension{} + yyc4840 = true + } + } + yyh4840.End() + if yyc4840 { + *v = yyv4840 + } +} + +func (x codecSelfer1234) encSliceLimitRangeItem(v []LimitRangeItem, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv4847 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy4848 := &yyv4847 + yy4848.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceLimitRangeItem(v *[]LimitRangeItem, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yyv4849 := *v yyh4849, yyl4849 := z.DecSliceHelperStart() var yyc4849 bool if yyl4849 == 0 { if yyv4849 == nil { - yyv4849 = []pkg5_runtime.RawExtension{} + yyv4849 = []LimitRangeItem{} yyc4849 = true } else if len(yyv4849) != 0 { yyv4849 = yyv4849[:0] @@ -62030,15 +62088,15 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten yyrg4849 := len(yyv4849) > 0 yyv24849 := yyv4849 - yyrl4849, yyrt4849 = z.DecInferLen(yyl4849, z.DecBasicHandle().MaxInitLen, 40) + yyrl4849, yyrt4849 = z.DecInferLen(yyl4849, z.DecBasicHandle().MaxInitLen, 56) if yyrt4849 { if yyrl4849 <= cap(yyv4849) { yyv4849 = yyv4849[:yyrl4849] } else { - yyv4849 = make([]pkg5_runtime.RawExtension, yyrl4849) + yyv4849 = make([]LimitRangeItem, yyrl4849) } } else { - yyv4849 = make([]pkg5_runtime.RawExtension, yyrl4849) + yyv4849 = make([]LimitRangeItem, yyrl4849) } yyc4849 = true yyrr4849 = len(yyv4849) @@ -62053,38 +62111,22 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten for ; yyj4849 < yyrr4849; yyj4849++ { yyh4849.ElemContainerState(yyj4849) if r.TryDecodeAsNil() { - yyv4849[yyj4849] = pkg5_runtime.RawExtension{} + yyv4849[yyj4849] = LimitRangeItem{} } else { yyv4850 := &yyv4849[yyj4849] - yym4851 := z.DecBinary() - _ = yym4851 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4850) { - } else if !yym4851 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4850) - } else { - z.DecFallback(yyv4850, false) - } + yyv4850.CodecDecodeSelf(d) } } if yyrt4849 { for ; yyj4849 < yyl4849; yyj4849++ { - yyv4849 = append(yyv4849, pkg5_runtime.RawExtension{}) + yyv4849 = append(yyv4849, LimitRangeItem{}) yyh4849.ElemContainerState(yyj4849) if r.TryDecodeAsNil() { - yyv4849[yyj4849] = pkg5_runtime.RawExtension{} + yyv4849[yyj4849] = LimitRangeItem{} } else { - yyv4852 := &yyv4849[yyj4849] - yym4853 := z.DecBinary() - _ = yym4853 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4852) { - } else if !yym4853 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4852) - } else { - z.DecFallback(yyv4852, false) - } + yyv4851 := &yyv4849[yyj4849] + yyv4851.CodecDecodeSelf(d) } } @@ -62095,24 +62137,16 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten for ; !r.CheckBreak(); yyj4849++ { if yyj4849 >= len(yyv4849) { - yyv4849 = append(yyv4849, pkg5_runtime.RawExtension{}) // var yyz4849 pkg5_runtime.RawExtension + yyv4849 = append(yyv4849, LimitRangeItem{}) // var yyz4849 LimitRangeItem yyc4849 = true } yyh4849.ElemContainerState(yyj4849) if yyj4849 < len(yyv4849) { if r.TryDecodeAsNil() { - yyv4849[yyj4849] = pkg5_runtime.RawExtension{} + yyv4849[yyj4849] = LimitRangeItem{} } else { - yyv4854 := &yyv4849[yyj4849] - yym4855 := z.DecBinary() - _ = yym4855 - if false { - } else if z.HasExtensions() && z.DecExt(yyv4854) { - } else if !yym4855 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv4854) - } else { - z.DecFallback(yyv4854, false) - } + yyv4852 := &yyv4849[yyj4849] + yyv4852.CodecDecodeSelf(d) } } else { @@ -62124,7 +62158,7 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten yyv4849 = yyv4849[:yyj4849] yyc4849 = true } else if yyj4849 == 0 && yyv4849 == nil { - yyv4849 = []pkg5_runtime.RawExtension{} + yyv4849 = []LimitRangeItem{} yyc4849 = true } } @@ -62134,131 +62168,15 @@ func (x codecSelfer1234) decSliceruntime_RawExtension(v *[]pkg5_runtime.RawExten } } -func (x codecSelfer1234) encSliceLimitRangeItem(v []LimitRangeItem, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv4856 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4857 := &yyv4856 - yy4857.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceLimitRangeItem(v *[]LimitRangeItem, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv4858 := *v - yyh4858, yyl4858 := z.DecSliceHelperStart() - var yyc4858 bool - if yyl4858 == 0 { - if yyv4858 == nil { - yyv4858 = []LimitRangeItem{} - yyc4858 = true - } else if len(yyv4858) != 0 { - yyv4858 = yyv4858[:0] - yyc4858 = true - } - } else if yyl4858 > 0 { - var yyrr4858, yyrl4858 int - var yyrt4858 bool - if yyl4858 > cap(yyv4858) { - - yyrg4858 := len(yyv4858) > 0 - yyv24858 := yyv4858 - yyrl4858, yyrt4858 = z.DecInferLen(yyl4858, z.DecBasicHandle().MaxInitLen, 56) - if yyrt4858 { - if yyrl4858 <= cap(yyv4858) { - yyv4858 = yyv4858[:yyrl4858] - } else { - yyv4858 = make([]LimitRangeItem, yyrl4858) - } - } else { - yyv4858 = make([]LimitRangeItem, yyrl4858) - } - yyc4858 = true - yyrr4858 = len(yyv4858) - if yyrg4858 { - copy(yyv4858, yyv24858) - } - } else if yyl4858 != len(yyv4858) { - yyv4858 = yyv4858[:yyl4858] - yyc4858 = true - } - yyj4858 := 0 - for ; yyj4858 < yyrr4858; yyj4858++ { - yyh4858.ElemContainerState(yyj4858) - if r.TryDecodeAsNil() { - yyv4858[yyj4858] = LimitRangeItem{} - } else { - yyv4859 := &yyv4858[yyj4858] - yyv4859.CodecDecodeSelf(d) - } - - } - if yyrt4858 { - for ; yyj4858 < yyl4858; yyj4858++ { - yyv4858 = append(yyv4858, LimitRangeItem{}) - yyh4858.ElemContainerState(yyj4858) - if r.TryDecodeAsNil() { - yyv4858[yyj4858] = LimitRangeItem{} - } else { - yyv4860 := &yyv4858[yyj4858] - yyv4860.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj4858 := 0 - for ; !r.CheckBreak(); yyj4858++ { - - if yyj4858 >= len(yyv4858) { - yyv4858 = append(yyv4858, LimitRangeItem{}) // var yyz4858 LimitRangeItem - yyc4858 = true - } - yyh4858.ElemContainerState(yyj4858) - if yyj4858 < len(yyv4858) { - if r.TryDecodeAsNil() { - yyv4858[yyj4858] = LimitRangeItem{} - } else { - yyv4861 := &yyv4858[yyj4858] - yyv4861.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj4858 < len(yyv4858) { - yyv4858 = yyv4858[:yyj4858] - yyc4858 = true - } else if yyj4858 == 0 && yyv4858 == nil { - yyv4858 = []LimitRangeItem{} - yyc4858 = true - } - } - yyh4858.End() - if yyc4858 { - *v = yyv4858 - } -} - func (x codecSelfer1234) encSliceLimitRange(v []LimitRange, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4862 := range v { + for _, yyv4853 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4863 := &yyv4862 - yy4863.CodecEncodeSelf(e) + yy4854 := &yyv4853 + yy4854.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62268,83 +62186,83 @@ func (x codecSelfer1234) decSliceLimitRange(v *[]LimitRange, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4864 := *v - yyh4864, yyl4864 := z.DecSliceHelperStart() - var yyc4864 bool - if yyl4864 == 0 { - if yyv4864 == nil { - yyv4864 = []LimitRange{} - yyc4864 = true - } else if len(yyv4864) != 0 { - yyv4864 = yyv4864[:0] - yyc4864 = true + yyv4855 := *v + yyh4855, yyl4855 := z.DecSliceHelperStart() + var yyc4855 bool + if yyl4855 == 0 { + if yyv4855 == nil { + yyv4855 = []LimitRange{} + yyc4855 = true + } else if len(yyv4855) != 0 { + yyv4855 = yyv4855[:0] + yyc4855 = true } - } else if yyl4864 > 0 { - var yyrr4864, yyrl4864 int - var yyrt4864 bool - if yyl4864 > cap(yyv4864) { + } else if yyl4855 > 0 { + var yyrr4855, yyrl4855 int + var yyrt4855 bool + if yyl4855 > cap(yyv4855) { - yyrg4864 := len(yyv4864) > 0 - yyv24864 := yyv4864 - yyrl4864, yyrt4864 = z.DecInferLen(yyl4864, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4864 { - if yyrl4864 <= cap(yyv4864) { - yyv4864 = yyv4864[:yyrl4864] + yyrg4855 := len(yyv4855) > 0 + yyv24855 := yyv4855 + yyrl4855, yyrt4855 = z.DecInferLen(yyl4855, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4855 { + if yyrl4855 <= cap(yyv4855) { + yyv4855 = yyv4855[:yyrl4855] } else { - yyv4864 = make([]LimitRange, yyrl4864) + yyv4855 = make([]LimitRange, yyrl4855) } } else { - yyv4864 = make([]LimitRange, yyrl4864) + yyv4855 = make([]LimitRange, yyrl4855) } - yyc4864 = true - yyrr4864 = len(yyv4864) - if yyrg4864 { - copy(yyv4864, yyv24864) + yyc4855 = true + yyrr4855 = len(yyv4855) + if yyrg4855 { + copy(yyv4855, yyv24855) } - } else if yyl4864 != len(yyv4864) { - yyv4864 = yyv4864[:yyl4864] - yyc4864 = true + } else if yyl4855 != len(yyv4855) { + yyv4855 = yyv4855[:yyl4855] + yyc4855 = true } - yyj4864 := 0 - for ; yyj4864 < yyrr4864; yyj4864++ { - yyh4864.ElemContainerState(yyj4864) + yyj4855 := 0 + for ; yyj4855 < yyrr4855; yyj4855++ { + yyh4855.ElemContainerState(yyj4855) if r.TryDecodeAsNil() { - yyv4864[yyj4864] = LimitRange{} + yyv4855[yyj4855] = LimitRange{} } else { - yyv4865 := &yyv4864[yyj4864] - yyv4865.CodecDecodeSelf(d) + yyv4856 := &yyv4855[yyj4855] + yyv4856.CodecDecodeSelf(d) } } - if yyrt4864 { - for ; yyj4864 < yyl4864; yyj4864++ { - yyv4864 = append(yyv4864, LimitRange{}) - yyh4864.ElemContainerState(yyj4864) + if yyrt4855 { + for ; yyj4855 < yyl4855; yyj4855++ { + yyv4855 = append(yyv4855, LimitRange{}) + yyh4855.ElemContainerState(yyj4855) if r.TryDecodeAsNil() { - yyv4864[yyj4864] = LimitRange{} + yyv4855[yyj4855] = LimitRange{} } else { - yyv4866 := &yyv4864[yyj4864] - yyv4866.CodecDecodeSelf(d) + yyv4857 := &yyv4855[yyj4855] + yyv4857.CodecDecodeSelf(d) } } } } else { - yyj4864 := 0 - for ; !r.CheckBreak(); yyj4864++ { + yyj4855 := 0 + for ; !r.CheckBreak(); yyj4855++ { - if yyj4864 >= len(yyv4864) { - yyv4864 = append(yyv4864, LimitRange{}) // var yyz4864 LimitRange - yyc4864 = true + if yyj4855 >= len(yyv4855) { + yyv4855 = append(yyv4855, LimitRange{}) // var yyz4855 LimitRange + yyc4855 = true } - yyh4864.ElemContainerState(yyj4864) - if yyj4864 < len(yyv4864) { + yyh4855.ElemContainerState(yyj4855) + if yyj4855 < len(yyv4855) { if r.TryDecodeAsNil() { - yyv4864[yyj4864] = LimitRange{} + yyv4855[yyj4855] = LimitRange{} } else { - yyv4867 := &yyv4864[yyj4864] - yyv4867.CodecDecodeSelf(d) + yyv4858 := &yyv4855[yyj4855] + yyv4858.CodecDecodeSelf(d) } } else { @@ -62352,17 +62270,17 @@ func (x codecSelfer1234) decSliceLimitRange(v *[]LimitRange, d *codec1978.Decode } } - if yyj4864 < len(yyv4864) { - yyv4864 = yyv4864[:yyj4864] - yyc4864 = true - } else if yyj4864 == 0 && yyv4864 == nil { - yyv4864 = []LimitRange{} - yyc4864 = true + if yyj4855 < len(yyv4855) { + yyv4855 = yyv4855[:yyj4855] + yyc4855 = true + } else if yyj4855 == 0 && yyv4855 == nil { + yyv4855 = []LimitRange{} + yyc4855 = true } } - yyh4864.End() - if yyc4864 { - *v = yyv4864 + yyh4855.End() + if yyc4855 { + *v = yyv4855 } } @@ -62371,9 +62289,9 @@ func (x codecSelfer1234) encSliceResourceQuotaScope(v []ResourceQuotaScope, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4868 := range v { + for _, yyv4859 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv4868.CodecEncodeSelf(e) + yyv4859.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62383,75 +62301,75 @@ func (x codecSelfer1234) decSliceResourceQuotaScope(v *[]ResourceQuotaScope, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4869 := *v - yyh4869, yyl4869 := z.DecSliceHelperStart() - var yyc4869 bool - if yyl4869 == 0 { - if yyv4869 == nil { - yyv4869 = []ResourceQuotaScope{} - yyc4869 = true - } else if len(yyv4869) != 0 { - yyv4869 = yyv4869[:0] - yyc4869 = true + yyv4860 := *v + yyh4860, yyl4860 := z.DecSliceHelperStart() + var yyc4860 bool + if yyl4860 == 0 { + if yyv4860 == nil { + yyv4860 = []ResourceQuotaScope{} + yyc4860 = true + } else if len(yyv4860) != 0 { + yyv4860 = yyv4860[:0] + yyc4860 = true } - } else if yyl4869 > 0 { - var yyrr4869, yyrl4869 int - var yyrt4869 bool - if yyl4869 > cap(yyv4869) { + } else if yyl4860 > 0 { + var yyrr4860, yyrl4860 int + var yyrt4860 bool + if yyl4860 > cap(yyv4860) { - yyrl4869, yyrt4869 = z.DecInferLen(yyl4869, z.DecBasicHandle().MaxInitLen, 16) - if yyrt4869 { - if yyrl4869 <= cap(yyv4869) { - yyv4869 = yyv4869[:yyrl4869] + yyrl4860, yyrt4860 = z.DecInferLen(yyl4860, z.DecBasicHandle().MaxInitLen, 16) + if yyrt4860 { + if yyrl4860 <= cap(yyv4860) { + yyv4860 = yyv4860[:yyrl4860] } else { - yyv4869 = make([]ResourceQuotaScope, yyrl4869) + yyv4860 = make([]ResourceQuotaScope, yyrl4860) } } else { - yyv4869 = make([]ResourceQuotaScope, yyrl4869) + yyv4860 = make([]ResourceQuotaScope, yyrl4860) } - yyc4869 = true - yyrr4869 = len(yyv4869) - } else if yyl4869 != len(yyv4869) { - yyv4869 = yyv4869[:yyl4869] - yyc4869 = true + yyc4860 = true + yyrr4860 = len(yyv4860) + } else if yyl4860 != len(yyv4860) { + yyv4860 = yyv4860[:yyl4860] + yyc4860 = true } - yyj4869 := 0 - for ; yyj4869 < yyrr4869; yyj4869++ { - yyh4869.ElemContainerState(yyj4869) + yyj4860 := 0 + for ; yyj4860 < yyrr4860; yyj4860++ { + yyh4860.ElemContainerState(yyj4860) if r.TryDecodeAsNil() { - yyv4869[yyj4869] = "" + yyv4860[yyj4860] = "" } else { - yyv4869[yyj4869] = ResourceQuotaScope(r.DecodeString()) + yyv4860[yyj4860] = ResourceQuotaScope(r.DecodeString()) } } - if yyrt4869 { - for ; yyj4869 < yyl4869; yyj4869++ { - yyv4869 = append(yyv4869, "") - yyh4869.ElemContainerState(yyj4869) + if yyrt4860 { + for ; yyj4860 < yyl4860; yyj4860++ { + yyv4860 = append(yyv4860, "") + yyh4860.ElemContainerState(yyj4860) if r.TryDecodeAsNil() { - yyv4869[yyj4869] = "" + yyv4860[yyj4860] = "" } else { - yyv4869[yyj4869] = ResourceQuotaScope(r.DecodeString()) + yyv4860[yyj4860] = ResourceQuotaScope(r.DecodeString()) } } } } else { - yyj4869 := 0 - for ; !r.CheckBreak(); yyj4869++ { + yyj4860 := 0 + for ; !r.CheckBreak(); yyj4860++ { - if yyj4869 >= len(yyv4869) { - yyv4869 = append(yyv4869, "") // var yyz4869 ResourceQuotaScope - yyc4869 = true + if yyj4860 >= len(yyv4860) { + yyv4860 = append(yyv4860, "") // var yyz4860 ResourceQuotaScope + yyc4860 = true } - yyh4869.ElemContainerState(yyj4869) - if yyj4869 < len(yyv4869) { + yyh4860.ElemContainerState(yyj4860) + if yyj4860 < len(yyv4860) { if r.TryDecodeAsNil() { - yyv4869[yyj4869] = "" + yyv4860[yyj4860] = "" } else { - yyv4869[yyj4869] = ResourceQuotaScope(r.DecodeString()) + yyv4860[yyj4860] = ResourceQuotaScope(r.DecodeString()) } } else { @@ -62459,17 +62377,17 @@ func (x codecSelfer1234) decSliceResourceQuotaScope(v *[]ResourceQuotaScope, d * } } - if yyj4869 < len(yyv4869) { - yyv4869 = yyv4869[:yyj4869] - yyc4869 = true - } else if yyj4869 == 0 && yyv4869 == nil { - yyv4869 = []ResourceQuotaScope{} - yyc4869 = true + if yyj4860 < len(yyv4860) { + yyv4860 = yyv4860[:yyj4860] + yyc4860 = true + } else if yyj4860 == 0 && yyv4860 == nil { + yyv4860 = []ResourceQuotaScope{} + yyc4860 = true } } - yyh4869.End() - if yyc4869 { - *v = yyv4869 + yyh4860.End() + if yyc4860 { + *v = yyv4860 } } @@ -62478,10 +62396,10 @@ func (x codecSelfer1234) encSliceResourceQuota(v []ResourceQuota, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4873 := range v { + for _, yyv4864 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4874 := &yyv4873 - yy4874.CodecEncodeSelf(e) + yy4865 := &yyv4864 + yy4865.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62491,83 +62409,83 @@ func (x codecSelfer1234) decSliceResourceQuota(v *[]ResourceQuota, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4875 := *v - yyh4875, yyl4875 := z.DecSliceHelperStart() - var yyc4875 bool - if yyl4875 == 0 { - if yyv4875 == nil { - yyv4875 = []ResourceQuota{} - yyc4875 = true - } else if len(yyv4875) != 0 { - yyv4875 = yyv4875[:0] - yyc4875 = true + yyv4866 := *v + yyh4866, yyl4866 := z.DecSliceHelperStart() + var yyc4866 bool + if yyl4866 == 0 { + if yyv4866 == nil { + yyv4866 = []ResourceQuota{} + yyc4866 = true + } else if len(yyv4866) != 0 { + yyv4866 = yyv4866[:0] + yyc4866 = true } - } else if yyl4875 > 0 { - var yyrr4875, yyrl4875 int - var yyrt4875 bool - if yyl4875 > cap(yyv4875) { + } else if yyl4866 > 0 { + var yyrr4866, yyrl4866 int + var yyrt4866 bool + if yyl4866 > cap(yyv4866) { - yyrg4875 := len(yyv4875) > 0 - yyv24875 := yyv4875 - yyrl4875, yyrt4875 = z.DecInferLen(yyl4875, z.DecBasicHandle().MaxInitLen, 304) - if yyrt4875 { - if yyrl4875 <= cap(yyv4875) { - yyv4875 = yyv4875[:yyrl4875] + yyrg4866 := len(yyv4866) > 0 + yyv24866 := yyv4866 + yyrl4866, yyrt4866 = z.DecInferLen(yyl4866, z.DecBasicHandle().MaxInitLen, 304) + if yyrt4866 { + if yyrl4866 <= cap(yyv4866) { + yyv4866 = yyv4866[:yyrl4866] } else { - yyv4875 = make([]ResourceQuota, yyrl4875) + yyv4866 = make([]ResourceQuota, yyrl4866) } } else { - yyv4875 = make([]ResourceQuota, yyrl4875) + yyv4866 = make([]ResourceQuota, yyrl4866) } - yyc4875 = true - yyrr4875 = len(yyv4875) - if yyrg4875 { - copy(yyv4875, yyv24875) + yyc4866 = true + yyrr4866 = len(yyv4866) + if yyrg4866 { + copy(yyv4866, yyv24866) } - } else if yyl4875 != len(yyv4875) { - yyv4875 = yyv4875[:yyl4875] - yyc4875 = true + } else if yyl4866 != len(yyv4866) { + yyv4866 = yyv4866[:yyl4866] + yyc4866 = true } - yyj4875 := 0 - for ; yyj4875 < yyrr4875; yyj4875++ { - yyh4875.ElemContainerState(yyj4875) + yyj4866 := 0 + for ; yyj4866 < yyrr4866; yyj4866++ { + yyh4866.ElemContainerState(yyj4866) if r.TryDecodeAsNil() { - yyv4875[yyj4875] = ResourceQuota{} + yyv4866[yyj4866] = ResourceQuota{} } else { - yyv4876 := &yyv4875[yyj4875] - yyv4876.CodecDecodeSelf(d) + yyv4867 := &yyv4866[yyj4866] + yyv4867.CodecDecodeSelf(d) } } - if yyrt4875 { - for ; yyj4875 < yyl4875; yyj4875++ { - yyv4875 = append(yyv4875, ResourceQuota{}) - yyh4875.ElemContainerState(yyj4875) + if yyrt4866 { + for ; yyj4866 < yyl4866; yyj4866++ { + yyv4866 = append(yyv4866, ResourceQuota{}) + yyh4866.ElemContainerState(yyj4866) if r.TryDecodeAsNil() { - yyv4875[yyj4875] = ResourceQuota{} + yyv4866[yyj4866] = ResourceQuota{} } else { - yyv4877 := &yyv4875[yyj4875] - yyv4877.CodecDecodeSelf(d) + yyv4868 := &yyv4866[yyj4866] + yyv4868.CodecDecodeSelf(d) } } } } else { - yyj4875 := 0 - for ; !r.CheckBreak(); yyj4875++ { + yyj4866 := 0 + for ; !r.CheckBreak(); yyj4866++ { - if yyj4875 >= len(yyv4875) { - yyv4875 = append(yyv4875, ResourceQuota{}) // var yyz4875 ResourceQuota - yyc4875 = true + if yyj4866 >= len(yyv4866) { + yyv4866 = append(yyv4866, ResourceQuota{}) // var yyz4866 ResourceQuota + yyc4866 = true } - yyh4875.ElemContainerState(yyj4875) - if yyj4875 < len(yyv4875) { + yyh4866.ElemContainerState(yyj4866) + if yyj4866 < len(yyv4866) { if r.TryDecodeAsNil() { - yyv4875[yyj4875] = ResourceQuota{} + yyv4866[yyj4866] = ResourceQuota{} } else { - yyv4878 := &yyv4875[yyj4875] - yyv4878.CodecDecodeSelf(d) + yyv4869 := &yyv4866[yyj4866] + yyv4869.CodecDecodeSelf(d) } } else { @@ -62575,17 +62493,17 @@ func (x codecSelfer1234) decSliceResourceQuota(v *[]ResourceQuota, d *codec1978. } } - if yyj4875 < len(yyv4875) { - yyv4875 = yyv4875[:yyj4875] - yyc4875 = true - } else if yyj4875 == 0 && yyv4875 == nil { - yyv4875 = []ResourceQuota{} - yyc4875 = true + if yyj4866 < len(yyv4866) { + yyv4866 = yyv4866[:yyj4866] + yyc4866 = true + } else if yyj4866 == 0 && yyv4866 == nil { + yyv4866 = []ResourceQuota{} + yyc4866 = true } } - yyh4875.End() - if yyc4875 { - *v = yyv4875 + yyh4866.End() + if yyc4866 { + *v = yyv4866 } } @@ -62594,23 +62512,23 @@ func (x codecSelfer1234) encMapstringSliceuint8(v map[string][]uint8, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeMapStart(len(v)) - for yyk4879, yyv4879 := range v { + for yyk4870, yyv4870 := range v { z.EncSendContainerState(codecSelfer_containerMapKey1234) - yym4880 := z.EncBinary() - _ = yym4880 + yym4871 := z.EncBinary() + _ = yym4871 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(yyk4879)) + r.EncodeString(codecSelferC_UTF81234, string(yyk4870)) } z.EncSendContainerState(codecSelfer_containerMapValue1234) - if yyv4879 == nil { + if yyv4870 == nil { r.EncodeNil() } else { - yym4881 := z.EncBinary() - _ = yym4881 + yym4872 := z.EncBinary() + _ = yym4872 if false { } else { - r.EncodeStringBytes(codecSelferC_RAW1234, []byte(yyv4879)) + r.EncodeStringBytes(codecSelferC_RAW1234, []byte(yyv4870)) } } } @@ -62622,80 +62540,80 @@ func (x codecSelfer1234) decMapstringSliceuint8(v *map[string][]uint8, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4882 := *v - yyl4882 := r.ReadMapStart() - yybh4882 := z.DecBasicHandle() - if yyv4882 == nil { - yyrl4882, _ := z.DecInferLen(yyl4882, yybh4882.MaxInitLen, 40) - yyv4882 = make(map[string][]uint8, yyrl4882) - *v = yyv4882 + yyv4873 := *v + yyl4873 := r.ReadMapStart() + yybh4873 := z.DecBasicHandle() + if yyv4873 == nil { + yyrl4873, _ := z.DecInferLen(yyl4873, yybh4873.MaxInitLen, 40) + yyv4873 = make(map[string][]uint8, yyrl4873) + *v = yyv4873 } - var yymk4882 string - var yymv4882 []uint8 - var yymg4882 bool - if yybh4882.MapValueReset { - yymg4882 = true + var yymk4873 string + var yymv4873 []uint8 + var yymg4873 bool + if yybh4873.MapValueReset { + yymg4873 = true } - if yyl4882 > 0 { - for yyj4882 := 0; yyj4882 < yyl4882; yyj4882++ { + if yyl4873 > 0 { + for yyj4873 := 0; yyj4873 < yyl4873; yyj4873++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4882 = "" + yymk4873 = "" } else { - yymk4882 = string(r.DecodeString()) + yymk4873 = string(r.DecodeString()) } - if yymg4882 { - yymv4882 = yyv4882[yymk4882] + if yymg4873 { + yymv4873 = yyv4873[yymk4873] } else { - yymv4882 = nil + yymv4873 = nil } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4882 = nil + yymv4873 = nil } else { - yyv4884 := &yymv4882 - yym4885 := z.DecBinary() - _ = yym4885 + yyv4875 := &yymv4873 + yym4876 := z.DecBinary() + _ = yym4876 if false { } else { - *yyv4884 = r.DecodeBytes(*(*[]byte)(yyv4884), false, false) + *yyv4875 = r.DecodeBytes(*(*[]byte)(yyv4875), false, false) } } - if yyv4882 != nil { - yyv4882[yymk4882] = yymv4882 + if yyv4873 != nil { + yyv4873[yymk4873] = yymv4873 } } - } else if yyl4882 < 0 { - for yyj4882 := 0; !r.CheckBreak(); yyj4882++ { + } else if yyl4873 < 0 { + for yyj4873 := 0; !r.CheckBreak(); yyj4873++ { z.DecSendContainerState(codecSelfer_containerMapKey1234) if r.TryDecodeAsNil() { - yymk4882 = "" + yymk4873 = "" } else { - yymk4882 = string(r.DecodeString()) + yymk4873 = string(r.DecodeString()) } - if yymg4882 { - yymv4882 = yyv4882[yymk4882] + if yymg4873 { + yymv4873 = yyv4873[yymk4873] } else { - yymv4882 = nil + yymv4873 = nil } z.DecSendContainerState(codecSelfer_containerMapValue1234) if r.TryDecodeAsNil() { - yymv4882 = nil + yymv4873 = nil } else { - yyv4887 := &yymv4882 - yym4888 := z.DecBinary() - _ = yym4888 + yyv4878 := &yymv4873 + yym4879 := z.DecBinary() + _ = yym4879 if false { } else { - *yyv4887 = r.DecodeBytes(*(*[]byte)(yyv4887), false, false) + *yyv4878 = r.DecodeBytes(*(*[]byte)(yyv4878), false, false) } } - if yyv4882 != nil { - yyv4882[yymk4882] = yymv4882 + if yyv4873 != nil { + yyv4873[yymk4873] = yymv4873 } } } // else len==0: TODO: Should we clear map entries? @@ -62707,10 +62625,10 @@ func (x codecSelfer1234) encSliceSecret(v []Secret, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4889 := range v { + for _, yyv4880 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4890 := &yyv4889 - yy4890.CodecEncodeSelf(e) + yy4881 := &yyv4880 + yy4881.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62720,83 +62638,83 @@ func (x codecSelfer1234) decSliceSecret(v *[]Secret, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4891 := *v - yyh4891, yyl4891 := z.DecSliceHelperStart() - var yyc4891 bool - if yyl4891 == 0 { - if yyv4891 == nil { - yyv4891 = []Secret{} - yyc4891 = true - } else if len(yyv4891) != 0 { - yyv4891 = yyv4891[:0] - yyc4891 = true + yyv4882 := *v + yyh4882, yyl4882 := z.DecSliceHelperStart() + var yyc4882 bool + if yyl4882 == 0 { + if yyv4882 == nil { + yyv4882 = []Secret{} + yyc4882 = true + } else if len(yyv4882) != 0 { + yyv4882 = yyv4882[:0] + yyc4882 = true } - } else if yyl4891 > 0 { - var yyrr4891, yyrl4891 int - var yyrt4891 bool - if yyl4891 > cap(yyv4891) { + } else if yyl4882 > 0 { + var yyrr4882, yyrl4882 int + var yyrt4882 bool + if yyl4882 > cap(yyv4882) { - yyrg4891 := len(yyv4891) > 0 - yyv24891 := yyv4891 - yyrl4891, yyrt4891 = z.DecInferLen(yyl4891, z.DecBasicHandle().MaxInitLen, 288) - if yyrt4891 { - if yyrl4891 <= cap(yyv4891) { - yyv4891 = yyv4891[:yyrl4891] + yyrg4882 := len(yyv4882) > 0 + yyv24882 := yyv4882 + yyrl4882, yyrt4882 = z.DecInferLen(yyl4882, z.DecBasicHandle().MaxInitLen, 288) + if yyrt4882 { + if yyrl4882 <= cap(yyv4882) { + yyv4882 = yyv4882[:yyrl4882] } else { - yyv4891 = make([]Secret, yyrl4891) + yyv4882 = make([]Secret, yyrl4882) } } else { - yyv4891 = make([]Secret, yyrl4891) + yyv4882 = make([]Secret, yyrl4882) } - yyc4891 = true - yyrr4891 = len(yyv4891) - if yyrg4891 { - copy(yyv4891, yyv24891) + yyc4882 = true + yyrr4882 = len(yyv4882) + if yyrg4882 { + copy(yyv4882, yyv24882) } - } else if yyl4891 != len(yyv4891) { - yyv4891 = yyv4891[:yyl4891] - yyc4891 = true + } else if yyl4882 != len(yyv4882) { + yyv4882 = yyv4882[:yyl4882] + yyc4882 = true } - yyj4891 := 0 - for ; yyj4891 < yyrr4891; yyj4891++ { - yyh4891.ElemContainerState(yyj4891) + yyj4882 := 0 + for ; yyj4882 < yyrr4882; yyj4882++ { + yyh4882.ElemContainerState(yyj4882) if r.TryDecodeAsNil() { - yyv4891[yyj4891] = Secret{} + yyv4882[yyj4882] = Secret{} } else { - yyv4892 := &yyv4891[yyj4891] - yyv4892.CodecDecodeSelf(d) + yyv4883 := &yyv4882[yyj4882] + yyv4883.CodecDecodeSelf(d) } } - if yyrt4891 { - for ; yyj4891 < yyl4891; yyj4891++ { - yyv4891 = append(yyv4891, Secret{}) - yyh4891.ElemContainerState(yyj4891) + if yyrt4882 { + for ; yyj4882 < yyl4882; yyj4882++ { + yyv4882 = append(yyv4882, Secret{}) + yyh4882.ElemContainerState(yyj4882) if r.TryDecodeAsNil() { - yyv4891[yyj4891] = Secret{} + yyv4882[yyj4882] = Secret{} } else { - yyv4893 := &yyv4891[yyj4891] - yyv4893.CodecDecodeSelf(d) + yyv4884 := &yyv4882[yyj4882] + yyv4884.CodecDecodeSelf(d) } } } } else { - yyj4891 := 0 - for ; !r.CheckBreak(); yyj4891++ { + yyj4882 := 0 + for ; !r.CheckBreak(); yyj4882++ { - if yyj4891 >= len(yyv4891) { - yyv4891 = append(yyv4891, Secret{}) // var yyz4891 Secret - yyc4891 = true + if yyj4882 >= len(yyv4882) { + yyv4882 = append(yyv4882, Secret{}) // var yyz4882 Secret + yyc4882 = true } - yyh4891.ElemContainerState(yyj4891) - if yyj4891 < len(yyv4891) { + yyh4882.ElemContainerState(yyj4882) + if yyj4882 < len(yyv4882) { if r.TryDecodeAsNil() { - yyv4891[yyj4891] = Secret{} + yyv4882[yyj4882] = Secret{} } else { - yyv4894 := &yyv4891[yyj4891] - yyv4894.CodecDecodeSelf(d) + yyv4885 := &yyv4882[yyj4882] + yyv4885.CodecDecodeSelf(d) } } else { @@ -62804,17 +62722,17 @@ func (x codecSelfer1234) decSliceSecret(v *[]Secret, d *codec1978.Decoder) { } } - if yyj4891 < len(yyv4891) { - yyv4891 = yyv4891[:yyj4891] - yyc4891 = true - } else if yyj4891 == 0 && yyv4891 == nil { - yyv4891 = []Secret{} - yyc4891 = true + if yyj4882 < len(yyv4882) { + yyv4882 = yyv4882[:yyj4882] + yyc4882 = true + } else if yyj4882 == 0 && yyv4882 == nil { + yyv4882 = []Secret{} + yyc4882 = true } } - yyh4891.End() - if yyc4891 { - *v = yyv4891 + yyh4882.End() + if yyc4882 { + *v = yyv4882 } } @@ -62823,10 +62741,10 @@ func (x codecSelfer1234) encSliceConfigMap(v []ConfigMap, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4895 := range v { + for _, yyv4886 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4896 := &yyv4895 - yy4896.CodecEncodeSelf(e) + yy4887 := &yyv4886 + yy4887.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62836,83 +62754,83 @@ func (x codecSelfer1234) decSliceConfigMap(v *[]ConfigMap, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4897 := *v - yyh4897, yyl4897 := z.DecSliceHelperStart() - var yyc4897 bool - if yyl4897 == 0 { - if yyv4897 == nil { - yyv4897 = []ConfigMap{} - yyc4897 = true - } else if len(yyv4897) != 0 { - yyv4897 = yyv4897[:0] - yyc4897 = true + yyv4888 := *v + yyh4888, yyl4888 := z.DecSliceHelperStart() + var yyc4888 bool + if yyl4888 == 0 { + if yyv4888 == nil { + yyv4888 = []ConfigMap{} + yyc4888 = true + } else if len(yyv4888) != 0 { + yyv4888 = yyv4888[:0] + yyc4888 = true } - } else if yyl4897 > 0 { - var yyrr4897, yyrl4897 int - var yyrt4897 bool - if yyl4897 > cap(yyv4897) { + } else if yyl4888 > 0 { + var yyrr4888, yyrl4888 int + var yyrt4888 bool + if yyl4888 > cap(yyv4888) { - yyrg4897 := len(yyv4897) > 0 - yyv24897 := yyv4897 - yyrl4897, yyrt4897 = z.DecInferLen(yyl4897, z.DecBasicHandle().MaxInitLen, 264) - if yyrt4897 { - if yyrl4897 <= cap(yyv4897) { - yyv4897 = yyv4897[:yyrl4897] + yyrg4888 := len(yyv4888) > 0 + yyv24888 := yyv4888 + yyrl4888, yyrt4888 = z.DecInferLen(yyl4888, z.DecBasicHandle().MaxInitLen, 264) + if yyrt4888 { + if yyrl4888 <= cap(yyv4888) { + yyv4888 = yyv4888[:yyrl4888] } else { - yyv4897 = make([]ConfigMap, yyrl4897) + yyv4888 = make([]ConfigMap, yyrl4888) } } else { - yyv4897 = make([]ConfigMap, yyrl4897) + yyv4888 = make([]ConfigMap, yyrl4888) } - yyc4897 = true - yyrr4897 = len(yyv4897) - if yyrg4897 { - copy(yyv4897, yyv24897) + yyc4888 = true + yyrr4888 = len(yyv4888) + if yyrg4888 { + copy(yyv4888, yyv24888) } - } else if yyl4897 != len(yyv4897) { - yyv4897 = yyv4897[:yyl4897] - yyc4897 = true + } else if yyl4888 != len(yyv4888) { + yyv4888 = yyv4888[:yyl4888] + yyc4888 = true } - yyj4897 := 0 - for ; yyj4897 < yyrr4897; yyj4897++ { - yyh4897.ElemContainerState(yyj4897) + yyj4888 := 0 + for ; yyj4888 < yyrr4888; yyj4888++ { + yyh4888.ElemContainerState(yyj4888) if r.TryDecodeAsNil() { - yyv4897[yyj4897] = ConfigMap{} + yyv4888[yyj4888] = ConfigMap{} } else { - yyv4898 := &yyv4897[yyj4897] - yyv4898.CodecDecodeSelf(d) + yyv4889 := &yyv4888[yyj4888] + yyv4889.CodecDecodeSelf(d) } } - if yyrt4897 { - for ; yyj4897 < yyl4897; yyj4897++ { - yyv4897 = append(yyv4897, ConfigMap{}) - yyh4897.ElemContainerState(yyj4897) + if yyrt4888 { + for ; yyj4888 < yyl4888; yyj4888++ { + yyv4888 = append(yyv4888, ConfigMap{}) + yyh4888.ElemContainerState(yyj4888) if r.TryDecodeAsNil() { - yyv4897[yyj4897] = ConfigMap{} + yyv4888[yyj4888] = ConfigMap{} } else { - yyv4899 := &yyv4897[yyj4897] - yyv4899.CodecDecodeSelf(d) + yyv4890 := &yyv4888[yyj4888] + yyv4890.CodecDecodeSelf(d) } } } } else { - yyj4897 := 0 - for ; !r.CheckBreak(); yyj4897++ { + yyj4888 := 0 + for ; !r.CheckBreak(); yyj4888++ { - if yyj4897 >= len(yyv4897) { - yyv4897 = append(yyv4897, ConfigMap{}) // var yyz4897 ConfigMap - yyc4897 = true + if yyj4888 >= len(yyv4888) { + yyv4888 = append(yyv4888, ConfigMap{}) // var yyz4888 ConfigMap + yyc4888 = true } - yyh4897.ElemContainerState(yyj4897) - if yyj4897 < len(yyv4897) { + yyh4888.ElemContainerState(yyj4888) + if yyj4888 < len(yyv4888) { if r.TryDecodeAsNil() { - yyv4897[yyj4897] = ConfigMap{} + yyv4888[yyj4888] = ConfigMap{} } else { - yyv4900 := &yyv4897[yyj4897] - yyv4900.CodecDecodeSelf(d) + yyv4891 := &yyv4888[yyj4888] + yyv4891.CodecDecodeSelf(d) } } else { @@ -62920,17 +62838,17 @@ func (x codecSelfer1234) decSliceConfigMap(v *[]ConfigMap, d *codec1978.Decoder) } } - if yyj4897 < len(yyv4897) { - yyv4897 = yyv4897[:yyj4897] - yyc4897 = true - } else if yyj4897 == 0 && yyv4897 == nil { - yyv4897 = []ConfigMap{} - yyc4897 = true + if yyj4888 < len(yyv4888) { + yyv4888 = yyv4888[:yyj4888] + yyc4888 = true + } else if yyj4888 == 0 && yyv4888 == nil { + yyv4888 = []ConfigMap{} + yyc4888 = true } } - yyh4897.End() - if yyc4897 { - *v = yyv4897 + yyh4888.End() + if yyc4888 { + *v = yyv4888 } } @@ -62939,10 +62857,10 @@ func (x codecSelfer1234) encSliceComponentCondition(v []ComponentCondition, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4901 := range v { + for _, yyv4892 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4902 := &yyv4901 - yy4902.CodecEncodeSelf(e) + yy4893 := &yyv4892 + yy4893.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -62952,83 +62870,83 @@ func (x codecSelfer1234) decSliceComponentCondition(v *[]ComponentCondition, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4903 := *v - yyh4903, yyl4903 := z.DecSliceHelperStart() - var yyc4903 bool - if yyl4903 == 0 { - if yyv4903 == nil { - yyv4903 = []ComponentCondition{} - yyc4903 = true - } else if len(yyv4903) != 0 { - yyv4903 = yyv4903[:0] - yyc4903 = true + yyv4894 := *v + yyh4894, yyl4894 := z.DecSliceHelperStart() + var yyc4894 bool + if yyl4894 == 0 { + if yyv4894 == nil { + yyv4894 = []ComponentCondition{} + yyc4894 = true + } else if len(yyv4894) != 0 { + yyv4894 = yyv4894[:0] + yyc4894 = true } - } else if yyl4903 > 0 { - var yyrr4903, yyrl4903 int - var yyrt4903 bool - if yyl4903 > cap(yyv4903) { + } else if yyl4894 > 0 { + var yyrr4894, yyrl4894 int + var yyrt4894 bool + if yyl4894 > cap(yyv4894) { - yyrg4903 := len(yyv4903) > 0 - yyv24903 := yyv4903 - yyrl4903, yyrt4903 = z.DecInferLen(yyl4903, z.DecBasicHandle().MaxInitLen, 64) - if yyrt4903 { - if yyrl4903 <= cap(yyv4903) { - yyv4903 = yyv4903[:yyrl4903] + yyrg4894 := len(yyv4894) > 0 + yyv24894 := yyv4894 + yyrl4894, yyrt4894 = z.DecInferLen(yyl4894, z.DecBasicHandle().MaxInitLen, 64) + if yyrt4894 { + if yyrl4894 <= cap(yyv4894) { + yyv4894 = yyv4894[:yyrl4894] } else { - yyv4903 = make([]ComponentCondition, yyrl4903) + yyv4894 = make([]ComponentCondition, yyrl4894) } } else { - yyv4903 = make([]ComponentCondition, yyrl4903) + yyv4894 = make([]ComponentCondition, yyrl4894) } - yyc4903 = true - yyrr4903 = len(yyv4903) - if yyrg4903 { - copy(yyv4903, yyv24903) + yyc4894 = true + yyrr4894 = len(yyv4894) + if yyrg4894 { + copy(yyv4894, yyv24894) } - } else if yyl4903 != len(yyv4903) { - yyv4903 = yyv4903[:yyl4903] - yyc4903 = true + } else if yyl4894 != len(yyv4894) { + yyv4894 = yyv4894[:yyl4894] + yyc4894 = true } - yyj4903 := 0 - for ; yyj4903 < yyrr4903; yyj4903++ { - yyh4903.ElemContainerState(yyj4903) + yyj4894 := 0 + for ; yyj4894 < yyrr4894; yyj4894++ { + yyh4894.ElemContainerState(yyj4894) if r.TryDecodeAsNil() { - yyv4903[yyj4903] = ComponentCondition{} + yyv4894[yyj4894] = ComponentCondition{} } else { - yyv4904 := &yyv4903[yyj4903] - yyv4904.CodecDecodeSelf(d) + yyv4895 := &yyv4894[yyj4894] + yyv4895.CodecDecodeSelf(d) } } - if yyrt4903 { - for ; yyj4903 < yyl4903; yyj4903++ { - yyv4903 = append(yyv4903, ComponentCondition{}) - yyh4903.ElemContainerState(yyj4903) + if yyrt4894 { + for ; yyj4894 < yyl4894; yyj4894++ { + yyv4894 = append(yyv4894, ComponentCondition{}) + yyh4894.ElemContainerState(yyj4894) if r.TryDecodeAsNil() { - yyv4903[yyj4903] = ComponentCondition{} + yyv4894[yyj4894] = ComponentCondition{} } else { - yyv4905 := &yyv4903[yyj4903] - yyv4905.CodecDecodeSelf(d) + yyv4896 := &yyv4894[yyj4894] + yyv4896.CodecDecodeSelf(d) } } } } else { - yyj4903 := 0 - for ; !r.CheckBreak(); yyj4903++ { + yyj4894 := 0 + for ; !r.CheckBreak(); yyj4894++ { - if yyj4903 >= len(yyv4903) { - yyv4903 = append(yyv4903, ComponentCondition{}) // var yyz4903 ComponentCondition - yyc4903 = true + if yyj4894 >= len(yyv4894) { + yyv4894 = append(yyv4894, ComponentCondition{}) // var yyz4894 ComponentCondition + yyc4894 = true } - yyh4903.ElemContainerState(yyj4903) - if yyj4903 < len(yyv4903) { + yyh4894.ElemContainerState(yyj4894) + if yyj4894 < len(yyv4894) { if r.TryDecodeAsNil() { - yyv4903[yyj4903] = ComponentCondition{} + yyv4894[yyj4894] = ComponentCondition{} } else { - yyv4906 := &yyv4903[yyj4903] - yyv4906.CodecDecodeSelf(d) + yyv4897 := &yyv4894[yyj4894] + yyv4897.CodecDecodeSelf(d) } } else { @@ -63036,17 +62954,17 @@ func (x codecSelfer1234) decSliceComponentCondition(v *[]ComponentCondition, d * } } - if yyj4903 < len(yyv4903) { - yyv4903 = yyv4903[:yyj4903] - yyc4903 = true - } else if yyj4903 == 0 && yyv4903 == nil { - yyv4903 = []ComponentCondition{} - yyc4903 = true + if yyj4894 < len(yyv4894) { + yyv4894 = yyv4894[:yyj4894] + yyc4894 = true + } else if yyj4894 == 0 && yyv4894 == nil { + yyv4894 = []ComponentCondition{} + yyc4894 = true } } - yyh4903.End() - if yyc4903 { - *v = yyv4903 + yyh4894.End() + if yyc4894 { + *v = yyv4894 } } @@ -63055,10 +62973,10 @@ func (x codecSelfer1234) encSliceComponentStatus(v []ComponentStatus, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4907 := range v { + for _, yyv4898 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4908 := &yyv4907 - yy4908.CodecEncodeSelf(e) + yy4899 := &yyv4898 + yy4899.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -63068,83 +62986,83 @@ func (x codecSelfer1234) decSliceComponentStatus(v *[]ComponentStatus, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4909 := *v - yyh4909, yyl4909 := z.DecSliceHelperStart() - var yyc4909 bool - if yyl4909 == 0 { - if yyv4909 == nil { - yyv4909 = []ComponentStatus{} - yyc4909 = true - } else if len(yyv4909) != 0 { - yyv4909 = yyv4909[:0] - yyc4909 = true + yyv4900 := *v + yyh4900, yyl4900 := z.DecSliceHelperStart() + var yyc4900 bool + if yyl4900 == 0 { + if yyv4900 == nil { + yyv4900 = []ComponentStatus{} + yyc4900 = true + } else if len(yyv4900) != 0 { + yyv4900 = yyv4900[:0] + yyc4900 = true } - } else if yyl4909 > 0 { - var yyrr4909, yyrl4909 int - var yyrt4909 bool - if yyl4909 > cap(yyv4909) { + } else if yyl4900 > 0 { + var yyrr4900, yyrl4900 int + var yyrt4900 bool + if yyl4900 > cap(yyv4900) { - yyrg4909 := len(yyv4909) > 0 - yyv24909 := yyv4909 - yyrl4909, yyrt4909 = z.DecInferLen(yyl4909, z.DecBasicHandle().MaxInitLen, 280) - if yyrt4909 { - if yyrl4909 <= cap(yyv4909) { - yyv4909 = yyv4909[:yyrl4909] + yyrg4900 := len(yyv4900) > 0 + yyv24900 := yyv4900 + yyrl4900, yyrt4900 = z.DecInferLen(yyl4900, z.DecBasicHandle().MaxInitLen, 280) + if yyrt4900 { + if yyrl4900 <= cap(yyv4900) { + yyv4900 = yyv4900[:yyrl4900] } else { - yyv4909 = make([]ComponentStatus, yyrl4909) + yyv4900 = make([]ComponentStatus, yyrl4900) } } else { - yyv4909 = make([]ComponentStatus, yyrl4909) + yyv4900 = make([]ComponentStatus, yyrl4900) } - yyc4909 = true - yyrr4909 = len(yyv4909) - if yyrg4909 { - copy(yyv4909, yyv24909) + yyc4900 = true + yyrr4900 = len(yyv4900) + if yyrg4900 { + copy(yyv4900, yyv24900) } - } else if yyl4909 != len(yyv4909) { - yyv4909 = yyv4909[:yyl4909] - yyc4909 = true + } else if yyl4900 != len(yyv4900) { + yyv4900 = yyv4900[:yyl4900] + yyc4900 = true } - yyj4909 := 0 - for ; yyj4909 < yyrr4909; yyj4909++ { - yyh4909.ElemContainerState(yyj4909) + yyj4900 := 0 + for ; yyj4900 < yyrr4900; yyj4900++ { + yyh4900.ElemContainerState(yyj4900) if r.TryDecodeAsNil() { - yyv4909[yyj4909] = ComponentStatus{} + yyv4900[yyj4900] = ComponentStatus{} } else { - yyv4910 := &yyv4909[yyj4909] - yyv4910.CodecDecodeSelf(d) + yyv4901 := &yyv4900[yyj4900] + yyv4901.CodecDecodeSelf(d) } } - if yyrt4909 { - for ; yyj4909 < yyl4909; yyj4909++ { - yyv4909 = append(yyv4909, ComponentStatus{}) - yyh4909.ElemContainerState(yyj4909) + if yyrt4900 { + for ; yyj4900 < yyl4900; yyj4900++ { + yyv4900 = append(yyv4900, ComponentStatus{}) + yyh4900.ElemContainerState(yyj4900) if r.TryDecodeAsNil() { - yyv4909[yyj4909] = ComponentStatus{} + yyv4900[yyj4900] = ComponentStatus{} } else { - yyv4911 := &yyv4909[yyj4909] - yyv4911.CodecDecodeSelf(d) + yyv4902 := &yyv4900[yyj4900] + yyv4902.CodecDecodeSelf(d) } } } } else { - yyj4909 := 0 - for ; !r.CheckBreak(); yyj4909++ { + yyj4900 := 0 + for ; !r.CheckBreak(); yyj4900++ { - if yyj4909 >= len(yyv4909) { - yyv4909 = append(yyv4909, ComponentStatus{}) // var yyz4909 ComponentStatus - yyc4909 = true + if yyj4900 >= len(yyv4900) { + yyv4900 = append(yyv4900, ComponentStatus{}) // var yyz4900 ComponentStatus + yyc4900 = true } - yyh4909.ElemContainerState(yyj4909) - if yyj4909 < len(yyv4909) { + yyh4900.ElemContainerState(yyj4900) + if yyj4900 < len(yyv4900) { if r.TryDecodeAsNil() { - yyv4909[yyj4909] = ComponentStatus{} + yyv4900[yyj4900] = ComponentStatus{} } else { - yyv4912 := &yyv4909[yyj4909] - yyv4912.CodecDecodeSelf(d) + yyv4903 := &yyv4900[yyj4900] + yyv4903.CodecDecodeSelf(d) } } else { @@ -63152,17 +63070,17 @@ func (x codecSelfer1234) decSliceComponentStatus(v *[]ComponentStatus, d *codec1 } } - if yyj4909 < len(yyv4909) { - yyv4909 = yyv4909[:yyj4909] - yyc4909 = true - } else if yyj4909 == 0 && yyv4909 == nil { - yyv4909 = []ComponentStatus{} - yyc4909 = true + if yyj4900 < len(yyv4900) { + yyv4900 = yyv4900[:yyj4900] + yyc4900 = true + } else if yyj4900 == 0 && yyv4900 == nil { + yyv4900 = []ComponentStatus{} + yyc4900 = true } } - yyh4909.End() - if yyc4909 { - *v = yyv4909 + yyh4900.End() + if yyc4900 { + *v = yyv4900 } } @@ -63171,10 +63089,10 @@ func (x codecSelfer1234) encSliceDownwardAPIVolumeFile(v []DownwardAPIVolumeFile z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv4913 := range v { + for _, yyv4904 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy4914 := &yyv4913 - yy4914.CodecEncodeSelf(e) + yy4905 := &yyv4904 + yy4905.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -63184,83 +63102,83 @@ func (x codecSelfer1234) decSliceDownwardAPIVolumeFile(v *[]DownwardAPIVolumeFil z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv4915 := *v - yyh4915, yyl4915 := z.DecSliceHelperStart() - var yyc4915 bool - if yyl4915 == 0 { - if yyv4915 == nil { - yyv4915 = []DownwardAPIVolumeFile{} - yyc4915 = true - } else if len(yyv4915) != 0 { - yyv4915 = yyv4915[:0] - yyc4915 = true + yyv4906 := *v + yyh4906, yyl4906 := z.DecSliceHelperStart() + var yyc4906 bool + if yyl4906 == 0 { + if yyv4906 == nil { + yyv4906 = []DownwardAPIVolumeFile{} + yyc4906 = true + } else if len(yyv4906) != 0 { + yyv4906 = yyv4906[:0] + yyc4906 = true } - } else if yyl4915 > 0 { - var yyrr4915, yyrl4915 int - var yyrt4915 bool - if yyl4915 > cap(yyv4915) { + } else if yyl4906 > 0 { + var yyrr4906, yyrl4906 int + var yyrt4906 bool + if yyl4906 > cap(yyv4906) { - yyrg4915 := len(yyv4915) > 0 - yyv24915 := yyv4915 - yyrl4915, yyrt4915 = z.DecInferLen(yyl4915, z.DecBasicHandle().MaxInitLen, 40) - if yyrt4915 { - if yyrl4915 <= cap(yyv4915) { - yyv4915 = yyv4915[:yyrl4915] + yyrg4906 := len(yyv4906) > 0 + yyv24906 := yyv4906 + yyrl4906, yyrt4906 = z.DecInferLen(yyl4906, z.DecBasicHandle().MaxInitLen, 40) + if yyrt4906 { + if yyrl4906 <= cap(yyv4906) { + yyv4906 = yyv4906[:yyrl4906] } else { - yyv4915 = make([]DownwardAPIVolumeFile, yyrl4915) + yyv4906 = make([]DownwardAPIVolumeFile, yyrl4906) } } else { - yyv4915 = make([]DownwardAPIVolumeFile, yyrl4915) + yyv4906 = make([]DownwardAPIVolumeFile, yyrl4906) } - yyc4915 = true - yyrr4915 = len(yyv4915) - if yyrg4915 { - copy(yyv4915, yyv24915) + yyc4906 = true + yyrr4906 = len(yyv4906) + if yyrg4906 { + copy(yyv4906, yyv24906) } - } else if yyl4915 != len(yyv4915) { - yyv4915 = yyv4915[:yyl4915] - yyc4915 = true + } else if yyl4906 != len(yyv4906) { + yyv4906 = yyv4906[:yyl4906] + yyc4906 = true } - yyj4915 := 0 - for ; yyj4915 < yyrr4915; yyj4915++ { - yyh4915.ElemContainerState(yyj4915) + yyj4906 := 0 + for ; yyj4906 < yyrr4906; yyj4906++ { + yyh4906.ElemContainerState(yyj4906) if r.TryDecodeAsNil() { - yyv4915[yyj4915] = DownwardAPIVolumeFile{} + yyv4906[yyj4906] = DownwardAPIVolumeFile{} } else { - yyv4916 := &yyv4915[yyj4915] - yyv4916.CodecDecodeSelf(d) + yyv4907 := &yyv4906[yyj4906] + yyv4907.CodecDecodeSelf(d) } } - if yyrt4915 { - for ; yyj4915 < yyl4915; yyj4915++ { - yyv4915 = append(yyv4915, DownwardAPIVolumeFile{}) - yyh4915.ElemContainerState(yyj4915) + if yyrt4906 { + for ; yyj4906 < yyl4906; yyj4906++ { + yyv4906 = append(yyv4906, DownwardAPIVolumeFile{}) + yyh4906.ElemContainerState(yyj4906) if r.TryDecodeAsNil() { - yyv4915[yyj4915] = DownwardAPIVolumeFile{} + yyv4906[yyj4906] = DownwardAPIVolumeFile{} } else { - yyv4917 := &yyv4915[yyj4915] - yyv4917.CodecDecodeSelf(d) + yyv4908 := &yyv4906[yyj4906] + yyv4908.CodecDecodeSelf(d) } } } } else { - yyj4915 := 0 - for ; !r.CheckBreak(); yyj4915++ { + yyj4906 := 0 + for ; !r.CheckBreak(); yyj4906++ { - if yyj4915 >= len(yyv4915) { - yyv4915 = append(yyv4915, DownwardAPIVolumeFile{}) // var yyz4915 DownwardAPIVolumeFile - yyc4915 = true + if yyj4906 >= len(yyv4906) { + yyv4906 = append(yyv4906, DownwardAPIVolumeFile{}) // var yyz4906 DownwardAPIVolumeFile + yyc4906 = true } - yyh4915.ElemContainerState(yyj4915) - if yyj4915 < len(yyv4915) { + yyh4906.ElemContainerState(yyj4906) + if yyj4906 < len(yyv4906) { if r.TryDecodeAsNil() { - yyv4915[yyj4915] = DownwardAPIVolumeFile{} + yyv4906[yyj4906] = DownwardAPIVolumeFile{} } else { - yyv4918 := &yyv4915[yyj4915] - yyv4918.CodecDecodeSelf(d) + yyv4909 := &yyv4906[yyj4906] + yyv4909.CodecDecodeSelf(d) } } else { @@ -63268,16 +63186,16 @@ func (x codecSelfer1234) decSliceDownwardAPIVolumeFile(v *[]DownwardAPIVolumeFil } } - if yyj4915 < len(yyv4915) { - yyv4915 = yyv4915[:yyj4915] - yyc4915 = true - } else if yyj4915 == 0 && yyv4915 == nil { - yyv4915 = []DownwardAPIVolumeFile{} - yyc4915 = true + if yyj4906 < len(yyv4906) { + yyv4906 = yyv4906[:yyj4906] + yyc4906 = true + } else if yyj4906 == 0 && yyv4906 == nil { + yyv4906 = []DownwardAPIVolumeFile{} + yyc4906 = true } } - yyh4915.End() - if yyc4915 { - *v = yyv4915 + yyh4906.End() + if yyc4906 { + *v = yyv4906 } } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/types.go b/vendor/k8s.io/client-go/pkg/api/v1/types.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/api/v1/types.go rename to vendor/k8s.io/client-go/pkg/api/v1/types.go index 0d821f2..377a770 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/types.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/types.go @@ -17,11 +17,11 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/types" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/types" + "k8s.io/client-go/pkg/util/intstr" ) // The comments for the structs and fields can be used from go-restful to @@ -72,6 +72,7 @@ type ObjectMeta struct { // definition. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` // GenerateName is an optional prefix, used by the server, to generate a unique @@ -89,6 +90,7 @@ type ObjectMeta struct { // // Applied only if Name is not specified. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#idempotency + // +optional GenerateName string `json:"generateName,omitempty" protobuf:"bytes,2,opt,name=generateName"` // Namespace defines the space within each name must be unique. An empty namespace is @@ -99,11 +101,13 @@ type ObjectMeta struct { // Must be a DNS_LABEL. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/namespaces + // +optional Namespace string `json:"namespace,omitempty" protobuf:"bytes,3,opt,name=namespace"` // SelfLink is a URL representing this object. // Populated by the system. // Read-only. + // +optional SelfLink string `json:"selfLink,omitempty" protobuf:"bytes,4,opt,name=selfLink"` // UID is the unique in time and space value for this object. It is typically generated by @@ -113,6 +117,7 @@ type ObjectMeta struct { // Populated by the system. // Read-only. // More info: http://kubernetes.io/docs/user-guide/identifiers#uids + // +optional UID types.UID `json:"uid,omitempty" protobuf:"bytes,5,opt,name=uid,casttype=k8s.io/kubernetes/pkg/types.UID"` // An opaque value that represents the internal version of this object that can @@ -125,10 +130,12 @@ type ObjectMeta struct { // Read-only. // Value must be treated as opaque by clients and . // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,6,opt,name=resourceVersion"` // A sequence number representing a specific generation of the desired state. // Populated by the system. Read-only. + // +optional Generation int64 `json:"generation,omitempty" protobuf:"varint,7,opt,name=generation"` // CreationTimestamp is a timestamp representing the server time when this object was @@ -139,6 +146,7 @@ type ObjectMeta struct { // Read-only. // Null for lists. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional CreationTimestamp unversioned.Time `json:"creationTimestamp,omitempty" protobuf:"bytes,8,opt,name=creationTimestamp"` // DeletionTimestamp is RFC 3339 date and time at which this resource will be deleted. This @@ -155,41 +163,48 @@ type ObjectMeta struct { // Populated by the system when a graceful deletion is requested. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional DeletionTimestamp *unversioned.Time `json:"deletionTimestamp,omitempty" protobuf:"bytes,9,opt,name=deletionTimestamp"` // Number of seconds allowed for this object to gracefully terminate before // it will be removed from the system. Only set when deletionTimestamp is also set. // May only be shortened. // Read-only. + // +optional DeletionGracePeriodSeconds *int64 `json:"deletionGracePeriodSeconds,omitempty" protobuf:"varint,10,opt,name=deletionGracePeriodSeconds"` // Map of string keys and values that can be used to organize and categorize // (scope and select) objects. May match selectors of replication controllers // and services. // More info: http://kubernetes.io/docs/user-guide/labels + // +optional Labels map[string]string `json:"labels,omitempty" protobuf:"bytes,11,rep,name=labels"` // Annotations is an unstructured key value map stored with a resource that may be // set by external tools to store and retrieve arbitrary metadata. They are not // queryable and should be preserved when modifying objects. // More info: http://kubernetes.io/docs/user-guide/annotations + // +optional Annotations map[string]string `json:"annotations,omitempty" protobuf:"bytes,12,rep,name=annotations"` // List of objects depended by this object. If ALL objects in the list have // been deleted, this object will be garbage collected. If this object is managed by a controller, // then an entry in this list will point to this controller, with the controller field set to true. // There cannot be more than one managing controller. + // +optional OwnerReferences []OwnerReference `json:"ownerReferences,omitempty" patchStrategy:"merge" patchMergeKey:"uid" protobuf:"bytes,13,rep,name=ownerReferences"` // Must be empty before the object is deleted from the registry. Each entry // is an identifier for the responsible component that will remove the entry // from the list. If the deletionTimestamp of the object is non-nil, entries // in this list can only be removed. + // +optional Finalizers []string `json:"finalizers,omitempty" patchStrategy:"merge" protobuf:"bytes,14,rep,name=finalizers"` // The name of the cluster which the object belongs to. // This is used to distinguish resources with same name and namespace in different clusters. // This field is not set anywhere right now and apiserver is going to ignore it if set in create or update request. + // +optional ClusterName string `json:"clusterName,omitempty" protobuf:"bytes,15,opt,name=clusterName"` } @@ -223,64 +238,86 @@ type VolumeSource struct { // --- // TODO(jonesdl) We need to restrict who can use host directory mounts and who can/can not // mount host directories as read/write. + // +optional HostPath *HostPathVolumeSource `json:"hostPath,omitempty" protobuf:"bytes,1,opt,name=hostPath"` // EmptyDir represents a temporary directory that shares a pod's lifetime. // More info: http://kubernetes.io/docs/user-guide/volumes#emptydir + // +optional EmptyDir *EmptyDirVolumeSource `json:"emptyDir,omitempty" protobuf:"bytes,2,opt,name=emptyDir"` // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional GCEPersistentDisk *GCEPersistentDiskVolumeSource `json:"gcePersistentDisk,omitempty" protobuf:"bytes,3,opt,name=gcePersistentDisk"` // AWSElasticBlockStore represents an AWS Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional AWSElasticBlockStore *AWSElasticBlockStoreVolumeSource `json:"awsElasticBlockStore,omitempty" protobuf:"bytes,4,opt,name=awsElasticBlockStore"` // GitRepo represents a git repository at a particular revision. + // +optional GitRepo *GitRepoVolumeSource `json:"gitRepo,omitempty" protobuf:"bytes,5,opt,name=gitRepo"` // Secret represents a secret that should populate this volume. // More info: http://kubernetes.io/docs/user-guide/volumes#secrets + // +optional Secret *SecretVolumeSource `json:"secret,omitempty" protobuf:"bytes,6,opt,name=secret"` // NFS represents an NFS mount on the host that shares a pod's lifetime // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional NFS *NFSVolumeSource `json:"nfs,omitempty" protobuf:"bytes,7,opt,name=nfs"` // ISCSI represents an ISCSI Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://releases.k8s.io/HEAD/examples/volumes/iscsi/README.md + // +optional ISCSI *ISCSIVolumeSource `json:"iscsi,omitempty" protobuf:"bytes,8,opt,name=iscsi"` // Glusterfs represents a Glusterfs mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md + // +optional Glusterfs *GlusterfsVolumeSource `json:"glusterfs,omitempty" protobuf:"bytes,9,opt,name=glusterfs"` // PersistentVolumeClaimVolumeSource represents a reference to a // PersistentVolumeClaim in the same namespace. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional PersistentVolumeClaim *PersistentVolumeClaimVolumeSource `json:"persistentVolumeClaim,omitempty" protobuf:"bytes,10,opt,name=persistentVolumeClaim"` // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md + // +optional RBD *RBDVolumeSource `json:"rbd,omitempty" protobuf:"bytes,11,opt,name=rbd"` // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an // alpha feature and may change in future. + // +optional FlexVolume *FlexVolumeSource `json:"flexVolume,omitempty" protobuf:"bytes,12,opt,name=flexVolume"` // Cinder represents a cinder volume attached and mounted on kubelets host machine // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional Cinder *CinderVolumeSource `json:"cinder,omitempty" protobuf:"bytes,13,opt,name=cinder"` // CephFS represents a Ceph FS mount on the host that shares a pod's lifetime + // +optional CephFS *CephFSVolumeSource `json:"cephfs,omitempty" protobuf:"bytes,14,opt,name=cephfs"` // Flocker represents a Flocker volume attached to a kubelet's host machine. This depends on the Flocker control service being running + // +optional Flocker *FlockerVolumeSource `json:"flocker,omitempty" protobuf:"bytes,15,opt,name=flocker"` // DownwardAPI represents downward API about the pod that should populate this volume + // +optional DownwardAPI *DownwardAPIVolumeSource `json:"downwardAPI,omitempty" protobuf:"bytes,16,opt,name=downwardAPI"` // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional FC *FCVolumeSource `json:"fc,omitempty" protobuf:"bytes,17,opt,name=fc"` // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional AzureFile *AzureFileVolumeSource `json:"azureFile,omitempty" protobuf:"bytes,18,opt,name=azureFile"` // ConfigMap represents a configMap that should populate this volume + // +optional ConfigMap *ConfigMapVolumeSource `json:"configMap,omitempty" protobuf:"bytes,19,opt,name=configMap"` // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional VsphereVolume *VsphereVirtualDiskVolumeSource `json:"vsphereVolume,omitempty" protobuf:"bytes,20,opt,name=vsphereVolume"` // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional Quobyte *QuobyteVolumeSource `json:"quobyte,omitempty" protobuf:"bytes,21,opt,name=quobyte"` // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional AzureDisk *AzureDiskVolumeSource `json:"azureDisk,omitempty" protobuf:"bytes,22,opt,name=azureDisk"` } @@ -294,6 +331,7 @@ type PersistentVolumeClaimVolumeSource struct { ClaimName string `json:"claimName" protobuf:"bytes,1,opt,name=claimName"` // Will force the ReadOnly setting in VolumeMounts. // Default false. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,2,opt,name=readOnly"` } @@ -303,50 +341,66 @@ type PersistentVolumeSource struct { // GCEPersistentDisk represents a GCE Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. Provisioned by an admin. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional GCEPersistentDisk *GCEPersistentDiskVolumeSource `json:"gcePersistentDisk,omitempty" protobuf:"bytes,1,opt,name=gcePersistentDisk"` // AWSElasticBlockStore represents an AWS Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional AWSElasticBlockStore *AWSElasticBlockStoreVolumeSource `json:"awsElasticBlockStore,omitempty" protobuf:"bytes,2,opt,name=awsElasticBlockStore"` // HostPath represents a directory on the host. // Provisioned by a developer or tester. // This is useful for single-node development and testing only! // On-host storage is not supported in any way and WILL NOT WORK in a multi-node cluster. // More info: http://kubernetes.io/docs/user-guide/volumes#hostpath + // +optional HostPath *HostPathVolumeSource `json:"hostPath,omitempty" protobuf:"bytes,3,opt,name=hostPath"` // Glusterfs represents a Glusterfs volume that is attached to a host and // exposed to the pod. Provisioned by an admin. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md + // +optional Glusterfs *GlusterfsVolumeSource `json:"glusterfs,omitempty" protobuf:"bytes,4,opt,name=glusterfs"` // NFS represents an NFS mount on the host. Provisioned by an admin. // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional NFS *NFSVolumeSource `json:"nfs,omitempty" protobuf:"bytes,5,opt,name=nfs"` // RBD represents a Rados Block Device mount on the host that shares a pod's lifetime. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md + // +optional RBD *RBDVolumeSource `json:"rbd,omitempty" protobuf:"bytes,6,opt,name=rbd"` // ISCSI represents an ISCSI Disk resource that is attached to a // kubelet's host machine and then exposed to the pod. Provisioned by an admin. + // +optional ISCSI *ISCSIVolumeSource `json:"iscsi,omitempty" protobuf:"bytes,7,opt,name=iscsi"` // Cinder represents a cinder volume attached and mounted on kubelets host machine // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional Cinder *CinderVolumeSource `json:"cinder,omitempty" protobuf:"bytes,8,opt,name=cinder"` // CephFS represents a Ceph FS mount on the host that shares a pod's lifetime + // +optional CephFS *CephFSVolumeSource `json:"cephfs,omitempty" protobuf:"bytes,9,opt,name=cephfs"` // FC represents a Fibre Channel resource that is attached to a kubelet's host machine and then exposed to the pod. + // +optional FC *FCVolumeSource `json:"fc,omitempty" protobuf:"bytes,10,opt,name=fc"` // Flocker represents a Flocker volume attached to a kubelet's host machine and exposed to the pod for its usage. This depends on the Flocker control service being running + // +optional Flocker *FlockerVolumeSource `json:"flocker,omitempty" protobuf:"bytes,11,opt,name=flocker"` // FlexVolume represents a generic volume resource that is // provisioned/attached using an exec based plugin. This is an // alpha feature and may change in future. + // +optional FlexVolume *FlexVolumeSource `json:"flexVolume,omitempty" protobuf:"bytes,12,opt,name=flexVolume"` // AzureFile represents an Azure File Service mount on the host and bind mount to the pod. + // +optional AzureFile *AzureFileVolumeSource `json:"azureFile,omitempty" protobuf:"bytes,13,opt,name=azureFile"` // VsphereVolume represents a vSphere volume attached and mounted on kubelets host machine + // +optional VsphereVolume *VsphereVirtualDiskVolumeSource `json:"vsphereVolume,omitempty" protobuf:"bytes,14,opt,name=vsphereVolume"` // Quobyte represents a Quobyte mount on the host that shares a pod's lifetime + // +optional Quobyte *QuobyteVolumeSource `json:"quobyte,omitempty" protobuf:"bytes,15,opt,name=quobyte"` // AzureDisk represents an Azure Data Disk mount on the host and bind mount to the pod. + // +optional AzureDisk *AzureDiskVolumeSource `json:"azureDisk,omitempty" protobuf:"bytes,16,opt,name=azureDisk"` } @@ -360,17 +414,20 @@ type PersistentVolume struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines a specification of a persistent volume owned by the cluster. // Provisioned by an administrator. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistent-volumes + // +optional Spec PersistentVolumeSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status represents the current information/status for the persistent volume. // Populated by the system. // Read-only. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistent-volumes + // +optional Status PersistentVolumeStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -378,21 +435,25 @@ type PersistentVolume struct { type PersistentVolumeSpec struct { // A description of the persistent volume's resources and capacity. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#capacity + // +optional Capacity ResourceList `json:"capacity,omitempty" protobuf:"bytes,1,rep,name=capacity,casttype=ResourceList,castkey=ResourceName"` // The actual volume backing the persistent volume. PersistentVolumeSource `json:",inline" protobuf:"bytes,2,opt,name=persistentVolumeSource"` // AccessModes contains all ways the volume can be mounted. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty" protobuf:"bytes,3,rep,name=accessModes,casttype=PersistentVolumeAccessMode"` // ClaimRef is part of a bi-directional binding between PersistentVolume and PersistentVolumeClaim. // Expected to be non-nil when bound. // claim.VolumeName is the authoritative bind between PV and PVC. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#binding + // +optional ClaimRef *ObjectReference `json:"claimRef,omitempty" protobuf:"bytes,4,opt,name=claimRef"` // What happens to a persistent volume when released from its claim. // Valid options are Retain (default) and Recycle. // Recycling must be supported by the volume plugin underlying this persistent volume. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#recycling-policy + // +optional PersistentVolumeReclaimPolicy PersistentVolumeReclaimPolicy `json:"persistentVolumeReclaimPolicy,omitempty" protobuf:"bytes,5,opt,name=persistentVolumeReclaimPolicy,casttype=PersistentVolumeReclaimPolicy"` } @@ -415,11 +476,14 @@ const ( type PersistentVolumeStatus struct { // Phase indicates if a volume is available, bound to a claim, or released by a claim. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#phase + // +optional Phase PersistentVolumePhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=PersistentVolumePhase"` // A human-readable message indicating details about why the volume is in this state. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` // Reason is a brief CamelCase string that describes any failure and is meant // for machine parsing and tidy display in the CLI. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,3,opt,name=reason"` } @@ -428,6 +492,7 @@ type PersistentVolumeList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of persistent volumes. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes @@ -441,15 +506,18 @@ type PersistentVolumeClaim struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the desired characteristics of a volume requested by a pod author. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional Spec PersistentVolumeClaimSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status represents the current information/status of a persistent volume claim. // Read-only. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims + // +optional Status PersistentVolumeClaimStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -458,6 +526,7 @@ type PersistentVolumeClaimList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // A list of persistent volume claims. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#persistentvolumeclaims @@ -469,24 +538,31 @@ type PersistentVolumeClaimList struct { type PersistentVolumeClaimSpec struct { // AccessModes contains the desired access modes the volume should have. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes-1 + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty" protobuf:"bytes,1,rep,name=accessModes,casttype=PersistentVolumeAccessMode"` // A label query over volumes to consider for binding. + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` // Resources represents the minimum resources the volume should have. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#resources + // +optional Resources ResourceRequirements `json:"resources,omitempty" protobuf:"bytes,2,opt,name=resources"` // VolumeName is the binding reference to the PersistentVolume backing this claim. + // +optional VolumeName string `json:"volumeName,omitempty" protobuf:"bytes,3,opt,name=volumeName"` } // PersistentVolumeClaimStatus is the current status of a persistent volume claim. type PersistentVolumeClaimStatus struct { // Phase represents the current phase of PersistentVolumeClaim. + // +optional Phase PersistentVolumeClaimPhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=PersistentVolumeClaimPhase"` // AccessModes contains the actual access modes the volume backing the PVC has. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#access-modes-1 + // +optional AccessModes []PersistentVolumeAccessMode `json:"accessModes,omitempty" protobuf:"bytes,2,rep,name=accessModes,casttype=PersistentVolumeAccessMode"` // Represents the actual resources of the underlying volume. + // +optional Capacity ResourceList `json:"capacity,omitempty" protobuf:"bytes,3,rep,name=capacity,casttype=ResourceList,castkey=ResourceName"` } @@ -547,6 +623,7 @@ type EmptyDirVolumeSource struct { // The default is "" which means to use the node's default medium. // Must be an empty string (default) or Memory. // More info: http://kubernetes.io/docs/user-guide/volumes#emptydir + // +optional Medium StorageMedium `json:"medium,omitempty" protobuf:"bytes,1,opt,name=medium,casttype=StorageMedium"` } @@ -564,6 +641,7 @@ type GlusterfsVolumeSource struct { // ReadOnly here will force the Glusterfs volume to be mounted with read-only permissions. // Defaults to false. // More info: http://releases.k8s.io/HEAD/examples/volumes/glusterfs/README.md#create-a-pod + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,3,opt,name=readOnly"` } @@ -581,27 +659,33 @@ type RBDVolumeSource struct { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#rbd // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,3,opt,name=fsType"` // The rados pool name. // Default is rbd. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it. + // +optional RBDPool string `json:"pool,omitempty" protobuf:"bytes,4,opt,name=pool"` // The rados user name. // Default is admin. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional RadosUser string `json:"user,omitempty" protobuf:"bytes,5,opt,name=user"` // Keyring is the path to key ring for RBDUser. // Default is /etc/ceph/keyring. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional Keyring string `json:"keyring,omitempty" protobuf:"bytes,6,opt,name=keyring"` // SecretRef is name of the authentication secret for RBDUser. If provided // overrides keyring. // Default is nil. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty" protobuf:"bytes,7,opt,name=secretRef"` // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. // More info: http://releases.k8s.io/HEAD/examples/volumes/rbd/README.md#how-to-use-it + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,8,opt,name=readOnly"` } @@ -617,10 +701,12 @@ type CinderVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,2,opt,name=fsType"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. // More info: http://releases.k8s.io/HEAD/examples/mysql-cinder-pd/README.md + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,3,opt,name=readOnly"` } @@ -631,19 +717,24 @@ type CephFSVolumeSource struct { // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it Monitors []string `json:"monitors" protobuf:"bytes,1,rep,name=monitors"` // Optional: Used as the mounted root, rather than the full Ceph tree, default is / + // +optional Path string `json:"path,omitempty" protobuf:"bytes,2,opt,name=path"` // Optional: User is the rados user name, default is admin // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional User string `json:"user,omitempty" protobuf:"bytes,3,opt,name=user"` // Optional: SecretFile is the path to key ring for User, default is /etc/ceph/user.secret // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional SecretFile string `json:"secretFile,omitempty" protobuf:"bytes,4,opt,name=secretFile"` // Optional: SecretRef is reference to the authentication secret for User, default is empty. // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty" protobuf:"bytes,5,opt,name=secretRef"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. // More info: http://releases.k8s.io/HEAD/examples/volumes/cephfs/README.md#how-to-use-it + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,6,opt,name=readOnly"` } @@ -653,8 +744,10 @@ type CephFSVolumeSource struct { type FlockerVolumeSource struct { // Name of the dataset stored as metadata -> name on the dataset for Flocker // should be considered as deprecated + // +optional DatasetName string `json:"datasetName,omitempty" protobuf:"bytes,1,opt,name=datasetName"` // UUID of the dataset. This is unique identifier of a Flocker dataset + // +optional DatasetUUID string `json:"datasetUUID,omitempty" protobuf:"bytes,2,opt,name=datasetUUID"` } @@ -691,16 +784,19 @@ type GCEPersistentDiskVolumeSource struct { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,2,opt,name=fsType"` // The partition in the volume that you want to mount. // If omitted, the default is to mount by volume name. // Examples: For volume /dev/sda1, you specify the partition as "1". // Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty). // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional Partition int32 `json:"partition,omitempty" protobuf:"varint,3,opt,name=partition"` // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. // More info: http://kubernetes.io/docs/user-guide/volumes#gcepersistentdisk + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,4,opt,name=readOnly"` } @@ -717,14 +813,17 @@ type QuobyteVolumeSource struct { // ReadOnly here will force the Quobyte volume to be mounted with read-only permissions. // Defaults to false. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,3,opt,name=readOnly"` // User to map volume access to // Defaults to serivceaccount user + // +optional User string `json:"user,omitempty" protobuf:"bytes,4,opt,name=user"` // Group to map volume access to // Default is no group + // +optional Group string `json:"group,omitempty" protobuf:"bytes,5,opt,name=group"` } @@ -736,17 +835,21 @@ type FlexVolumeSource struct { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". The default filesystem depends on FlexVolume script. + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,2,opt,name=fsType"` // Optional: SecretRef is reference to the secret object containing // sensitive information to pass to the plugin scripts. This may be // empty if no secret object is specified. If the secret object // contains more than one secret, all secrets are passed to the plugin // scripts. + // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty" protobuf:"bytes,3,opt,name=secretRef"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,4,opt,name=readOnly"` // Optional: Extra command options if any. + // +optional Options map[string]string `json:"options,omitempty" protobuf:"bytes,5,rep,name=options"` } @@ -765,15 +868,18 @@ type AWSElasticBlockStoreVolumeSource struct { // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,2,opt,name=fsType"` // The partition in the volume that you want to mount. // If omitted, the default is to mount by volume name. // Examples: For volume /dev/sda1, you specify the partition as "1". // Similarly, the volume partition for /dev/sda is "0" (or you can leave the property empty). + // +optional Partition int32 `json:"partition,omitempty" protobuf:"varint,3,opt,name=partition"` // Specify "true" to force and set the ReadOnly property in VolumeMounts to "true". // If omitted, the default is "false". // More info: http://kubernetes.io/docs/user-guide/volumes#awselasticblockstore + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,4,opt,name=readOnly"` } @@ -784,11 +890,13 @@ type GitRepoVolumeSource struct { // Repository URL Repository string `json:"repository" protobuf:"bytes,1,opt,name=repository"` // Commit hash for the specified revision. + // +optional Revision string `json:"revision,omitempty" protobuf:"bytes,2,opt,name=revision"` // Target directory name. // Must not contain or start with '..'. If '.' is supplied, the volume directory will be the // git repository. Otherwise, if specified, the volume will contain the git repository in // the subdirectory with the given name. + // +optional Directory string `json:"directory,omitempty" protobuf:"bytes,3,opt,name=directory"` } @@ -800,6 +908,7 @@ type GitRepoVolumeSource struct { type SecretVolumeSource struct { // Name of the secret in the pod's namespace to use. // More info: http://kubernetes.io/docs/user-guide/volumes#secrets + // +optional SecretName string `json:"secretName,omitempty" protobuf:"bytes,1,opt,name=secretName"` // If unspecified, each key-value pair in the Data field of the referenced // Secret will be projected into the volume as a file whose name is the @@ -808,12 +917,14 @@ type SecretVolumeSource struct { // present. If a key is specified which is not present in the Secret, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional Items []KeyToPath `json:"items,omitempty" protobuf:"bytes,2,rep,name=items"` // Optional: mode bits to use on created files by default. Must be a // value between 0 and 0777. Defaults to 0644. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty" protobuf:"bytes,3,opt,name=defaultMode"` } @@ -836,6 +947,7 @@ type NFSVolumeSource struct { // the NFS export to be mounted with read-only permissions. // Defaults to false. // More info: http://kubernetes.io/docs/user-guide/volumes#nfs + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,3,opt,name=readOnly"` } @@ -851,15 +963,18 @@ type ISCSIVolumeSource struct { // iSCSI target lun number. Lun int32 `json:"lun" protobuf:"varint,3,opt,name=lun"` // Optional: Defaults to 'default' (tcp). iSCSI interface name that uses an iSCSI transport. + // +optional ISCSIInterface string `json:"iscsiInterface,omitempty" protobuf:"bytes,4,opt,name=iscsiInterface"` // Filesystem type of the volume that you want to mount. // Tip: Ensure that the filesystem type is supported by the host operating system. // Examples: "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // More info: http://kubernetes.io/docs/user-guide/volumes#iscsi // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,5,opt,name=fsType"` // ReadOnly here will force the ReadOnly setting in VolumeMounts. // Defaults to false. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,6,opt,name=readOnly"` } @@ -875,9 +990,11 @@ type FCVolumeSource struct { // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. // TODO: how do we prevent errors in the filesystem from compromising the machine + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,3,opt,name=fsType"` // Optional: Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,4,opt,name=readOnly"` } @@ -889,6 +1006,7 @@ type AzureFileVolumeSource struct { ShareName string `json:"shareName" protobuf:"bytes,2,opt,name=shareName"` // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,3,opt,name=readOnly"` } @@ -899,6 +1017,7 @@ type VsphereVirtualDiskVolumeSource struct { // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional FSType string `json:"fsType,omitempty" protobuf:"bytes,2,opt,name=fsType"` } type AzureDataDiskCachingMode string @@ -916,13 +1035,16 @@ type AzureDiskVolumeSource struct { // The URI the data disk in the blob storage DataDiskURI string `json:"diskURI" protobuf:"bytes,2,opt,name=diskURI"` // Host Caching mode: None, Read Only, Read Write. + // +optional CachingMode *AzureDataDiskCachingMode `json:"cachingMode,omitempty" protobuf:"bytes,3,opt,name=cachingMode,casttype=AzureDataDiskCachingMode"` // Filesystem type to mount. // Must be a filesystem type supported by the host operating system. // Ex. "ext4", "xfs", "ntfs". Implicitly inferred to be "ext4" if unspecified. + // +optional FSType *string `json:"fsType,omitempty" protobuf:"bytes,4,opt,name=fsType"` // Defaults to false (read/write). ReadOnly here will force // the ReadOnly setting in VolumeMounts. + // +optional ReadOnly *bool `json:"readOnly,omitempty" protobuf:"varint,5,opt,name=readOnly"` } @@ -941,12 +1063,14 @@ type ConfigMapVolumeSource struct { // present. If a key is specified which is not present in the ConfigMap, // the volume setup will error. Paths must be relative and may not contain // the '..' path or start with '..'. + // +optional Items []KeyToPath `json:"items,omitempty" protobuf:"bytes,2,rep,name=items"` // Optional: mode bits to use on created files by default. Must be a // value between 0 and 0777. Defaults to 0644. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty" protobuf:"varint,3,opt,name=defaultMode"` } @@ -968,6 +1092,7 @@ type KeyToPath struct { // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional Mode *int32 `json:"mode,omitempty" protobuf:"varint,3,opt,name=mode"` } @@ -976,19 +1101,23 @@ type ContainerPort struct { // If specified, this must be an IANA_SVC_NAME and unique within the pod. Each // named port in a pod must have a unique name. Name for the port that can be // referred to by services. + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` // Number of port to expose on the host. // If specified, this must be a valid port number, 0 < x < 65536. // If HostNetwork is specified, this must match ContainerPort. // Most containers do not need this. + // +optional HostPort int32 `json:"hostPort,omitempty" protobuf:"varint,2,opt,name=hostPort"` // Number of port to expose on the pod's IP address. // This must be a valid port number, 0 < x < 65536. ContainerPort int32 `json:"containerPort" protobuf:"varint,3,opt,name=containerPort"` // Protocol for port. Must be UDP or TCP. // Defaults to "TCP". + // +optional Protocol Protocol `json:"protocol,omitempty" protobuf:"bytes,4,opt,name=protocol,casttype=Protocol"` // What host IP to bind the external port to. + // +optional HostIP string `json:"hostIP,omitempty" protobuf:"bytes,5,opt,name=hostIP"` } @@ -998,12 +1127,14 @@ type VolumeMount struct { Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Mounted read-only if true, read-write otherwise (false or unspecified). // Defaults to false. + // +optional ReadOnly bool `json:"readOnly,omitempty" protobuf:"varint,2,opt,name=readOnly"` // Path within the container at which the volume should be mounted. Must // not contain ':'. MountPath string `json:"mountPath" protobuf:"bytes,3,opt,name=mountPath"` // Path within the volume from which the container's volume should be mounted. // Defaults to "" (volume's root). + // +optional SubPath string `json:"subPath,omitempty" protobuf:"bytes,4,opt,name=subPath"` } @@ -1022,8 +1153,10 @@ type EnvVar struct { // references will never be expanded, regardless of whether the variable // exists or not. // Defaults to "". + // +optional Value string `json:"value,omitempty" protobuf:"bytes,2,opt,name=value"` // Source for the environment variable's value. Cannot be used if value is not empty. + // +optional ValueFrom *EnvVarSource `json:"valueFrom,omitempty" protobuf:"bytes,3,opt,name=valueFrom"` } @@ -1031,19 +1164,24 @@ type EnvVar struct { type EnvVarSource struct { // Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, // spec.nodeName, spec.serviceAccountName, status.podIP. + // +optional FieldRef *ObjectFieldSelector `json:"fieldRef,omitempty" protobuf:"bytes,1,opt,name=fieldRef"` // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional ResourceFieldRef *ResourceFieldSelector `json:"resourceFieldRef,omitempty" protobuf:"bytes,2,opt,name=resourceFieldRef"` // Selects a key of a ConfigMap. + // +optional ConfigMapKeyRef *ConfigMapKeySelector `json:"configMapKeyRef,omitempty" protobuf:"bytes,3,opt,name=configMapKeyRef"` // Selects a key of a secret in the pod's namespace + // +optional SecretKeyRef *SecretKeySelector `json:"secretKeyRef,omitempty" protobuf:"bytes,4,opt,name=secretKeyRef"` } // ObjectFieldSelector selects an APIVersioned field of an object. type ObjectFieldSelector struct { // Version of the schema the FieldPath is written in terms of, defaults to "v1". + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,1,opt,name=apiVersion"` // Path of the field to select in the specified API version. FieldPath string `json:"fieldPath" protobuf:"bytes,2,opt,name=fieldPath"` @@ -1052,10 +1190,12 @@ type ObjectFieldSelector struct { // ResourceFieldSelector represents container resources (cpu, memory) and their output format type ResourceFieldSelector struct { // Container name: required for volumes, optional for env vars + // +optional ContainerName string `json:"containerName,omitempty" protobuf:"bytes,1,opt,name=containerName"` // Required: resource to select Resource string `json:"resource" protobuf:"bytes,2,opt,name=resource"` // Specifies the output format of the exposed resources, defaults to "1" + // +optional Divisor resource.Quantity `json:"divisor,omitempty" protobuf:"bytes,3,opt,name=divisor"` } @@ -1086,6 +1226,7 @@ type HTTPHeader struct { // HTTPGetAction describes an action based on HTTP Get requests. type HTTPGetAction struct { // Path to access on the HTTP server. + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` // Name or number of the port to access on the container. // Number must be in the range 1 to 65535. @@ -1093,11 +1234,14 @@ type HTTPGetAction struct { Port intstr.IntOrString `json:"port" protobuf:"bytes,2,opt,name=port"` // Host name to connect to, defaults to the pod IP. You probably want to set // "Host" in httpHeaders instead. + // +optional Host string `json:"host,omitempty" protobuf:"bytes,3,opt,name=host"` // Scheme to use for connecting to the host. // Defaults to HTTP. + // +optional Scheme URIScheme `json:"scheme,omitempty" protobuf:"bytes,4,opt,name=scheme,casttype=URIScheme"` // Custom headers to set in the request. HTTP allows repeated headers. + // +optional HTTPHeaders []HTTPHeader `json:"httpHeaders,omitempty" protobuf:"bytes,5,rep,name=httpHeaders"` } @@ -1126,6 +1270,7 @@ type ExecAction struct { // not run inside a shell, so traditional shell instructions ('|', etc) won't work. To use // a shell, you need to explicitly call out to that shell. // Exit status of 0 is treated as live/healthy and non-zero is unhealthy. + // +optional Command []string `json:"command,omitempty" protobuf:"bytes,1,rep,name=command"` } @@ -1136,19 +1281,24 @@ type Probe struct { Handler `json:",inline" protobuf:"bytes,1,opt,name=handler"` // Number of seconds after the container has started before liveness probes are initiated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional InitialDelaySeconds int32 `json:"initialDelaySeconds,omitempty" protobuf:"varint,2,opt,name=initialDelaySeconds"` // Number of seconds after which the probe times out. // Defaults to 1 second. Minimum value is 1. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional TimeoutSeconds int32 `json:"timeoutSeconds,omitempty" protobuf:"varint,3,opt,name=timeoutSeconds"` // How often (in seconds) to perform the probe. // Default to 10 seconds. Minimum value is 1. + // +optional PeriodSeconds int32 `json:"periodSeconds,omitempty" protobuf:"varint,4,opt,name=periodSeconds"` // Minimum consecutive successes for the probe to be considered successful after having failed. // Defaults to 1. Must be 1 for liveness. Minimum value is 1. + // +optional SuccessThreshold int32 `json:"successThreshold,omitempty" protobuf:"varint,5,opt,name=successThreshold"` // Minimum consecutive failures for the probe to be considered failed after having succeeded. // Defaults to 3. Minimum value is 1. + // +optional FailureThreshold int32 `json:"failureThreshold,omitempty" protobuf:"varint,6,opt,name=failureThreshold"` } @@ -1170,8 +1320,10 @@ type Capability string // Adds and removes POSIX capabilities from running containers. type Capabilities struct { // Added capabilities + // +optional Add []Capability `json:"add,omitempty" protobuf:"bytes,1,rep,name=add,casttype=Capability"` // Removed capabilities + // +optional Drop []Capability `json:"drop,omitempty" protobuf:"bytes,2,rep,name=drop,casttype=Capability"` } @@ -1179,11 +1331,13 @@ type Capabilities struct { type ResourceRequirements struct { // Limits describes the maximum amount of compute resources allowed. // More info: http://kubernetes.io/docs/user-guide/compute-resources/ + // +optional Limits ResourceList `json:"limits,omitempty" protobuf:"bytes,1,rep,name=limits,casttype=ResourceList,castkey=ResourceName"` // Requests describes the minimum amount of compute resources required. // If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, // otherwise to an implementation-defined value. // More info: http://kubernetes.io/docs/user-guide/compute-resources/ + // +optional Requests ResourceList `json:"requests,omitempty" protobuf:"bytes,2,rep,name=requests,casttype=ResourceList,castkey=ResourceName"` } @@ -1200,6 +1354,7 @@ type Container struct { Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Docker image name. // More info: http://kubernetes.io/docs/user-guide/images + // +optional Image string `json:"image,omitempty" protobuf:"bytes,2,opt,name=image"` // Entrypoint array. Not executed within a shell. // The docker image's ENTRYPOINT is used if this is not provided. @@ -1209,6 +1364,7 @@ type Container struct { // regardless of whether the variable exists or not. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/containers#containers-and-commands + // +optional Command []string `json:"command,omitempty" protobuf:"bytes,3,rep,name=command"` // Arguments to the entrypoint. // The docker image's CMD is used if this is not provided. @@ -1218,11 +1374,13 @@ type Container struct { // regardless of whether the variable exists or not. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/containers#containers-and-commands + // +optional Args []string `json:"args,omitempty" protobuf:"bytes,4,rep,name=args"` // Container's working directory. // If not specified, the container runtime's default will be used, which // might be configured in the container image. // Cannot be updated. + // +optional WorkingDir string `json:"workingDir,omitempty" protobuf:"bytes,5,opt,name=workingDir"` // List of ports to expose from the container. Exposing a port here gives // the system additional information about the network connections a @@ -1231,44 +1389,54 @@ type Container struct { // listening on the default "0.0.0.0" address inside a container will be // accessible from the network. // Cannot be updated. + // +optional Ports []ContainerPort `json:"ports,omitempty" patchStrategy:"merge" patchMergeKey:"containerPort" protobuf:"bytes,6,rep,name=ports"` // List of environment variables to set in the container. // Cannot be updated. + // +optional Env []EnvVar `json:"env,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,7,rep,name=env"` // Compute Resources required by this container. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#resources + // +optional Resources ResourceRequirements `json:"resources,omitempty" protobuf:"bytes,8,opt,name=resources"` // Pod volumes to mount into the container's filesystem. // Cannot be updated. - VolumeMounts []VolumeMount `json:"volumeMounts,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,9,rep,name=volumeMounts"` + // +optional + VolumeMounts []VolumeMount `json:"volumeMounts,omitempty" patchStrategy:"merge" patchMergeKey:"mountPath" protobuf:"bytes,9,rep,name=volumeMounts"` // Periodic probe of container liveness. // Container will be restarted if the probe fails. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional LivenessProbe *Probe `json:"livenessProbe,omitempty" protobuf:"bytes,10,opt,name=livenessProbe"` // Periodic probe of container service readiness. // Container will be removed from service endpoints if the probe fails. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-probes + // +optional ReadinessProbe *Probe `json:"readinessProbe,omitempty" protobuf:"bytes,11,opt,name=readinessProbe"` // Actions that the management system should take in response to container lifecycle events. // Cannot be updated. + // +optional Lifecycle *Lifecycle `json:"lifecycle,omitempty" protobuf:"bytes,12,opt,name=lifecycle"` // Optional: Path at which the file to which the container's termination message // will be written is mounted into the container's filesystem. // Message written is intended to be brief final status, such as an assertion failure message. // Defaults to /dev/termination-log. // Cannot be updated. + // +optional TerminationMessagePath string `json:"terminationMessagePath,omitempty" protobuf:"bytes,13,opt,name=terminationMessagePath"` // Image pull policy. // One of Always, Never, IfNotPresent. // Defaults to Always if :latest tag is specified, or IfNotPresent otherwise. // Cannot be updated. // More info: http://kubernetes.io/docs/user-guide/images#updating-images + // +optional ImagePullPolicy PullPolicy `json:"imagePullPolicy,omitempty" protobuf:"bytes,14,opt,name=imagePullPolicy,casttype=PullPolicy"` // Security options the pod should run with. // More info: http://releases.k8s.io/HEAD/docs/design/security_context.md + // +optional SecurityContext *SecurityContext `json:"securityContext,omitempty" protobuf:"bytes,15,opt,name=securityContext"` // Variables for interactive containers, these have very specialized use-cases (e.g. debugging) @@ -1277,6 +1445,7 @@ type Container struct { // Whether this container should allocate a buffer for stdin in the container runtime. If this // is not set, reads from stdin in the container will always result in EOF. // Default is false. + // +optional Stdin bool `json:"stdin,omitempty" protobuf:"varint,16,opt,name=stdin"` // Whether the container runtime should close the stdin channel after it has been opened by // a single attach. When stdin is true the stdin stream will remain open across multiple attach @@ -1285,9 +1454,11 @@ type Container struct { // at which time stdin is closed and remains closed until the container is restarted. If this // flag is false, a container processes that reads from stdin will never receive an EOF. // Default is false + // +optional StdinOnce bool `json:"stdinOnce,omitempty" protobuf:"varint,17,opt,name=stdinOnce"` // Whether this container should allocate a TTY for itself, also requires 'stdin' to be true. // Default is false. + // +optional TTY bool `json:"tty,omitempty" protobuf:"varint,18,opt,name=tty"` } @@ -1296,12 +1467,15 @@ type Container struct { type Handler struct { // One and only one of the following should be specified. // Exec specifies the action to take. + // +optional Exec *ExecAction `json:"exec,omitempty" protobuf:"bytes,1,opt,name=exec"` // HTTPGet specifies the http request to perform. + // +optional HTTPGet *HTTPGetAction `json:"httpGet,omitempty" protobuf:"bytes,2,opt,name=httpGet"` // TCPSocket specifies an action involving a TCP port. // TCP hooks not yet supported // TODO: implement a realistic TCP lifecycle hook + // +optional TCPSocket *TCPSocketAction `json:"tcpSocket,omitempty" protobuf:"bytes,3,opt,name=tcpSocket"` } @@ -1313,6 +1487,7 @@ type Lifecycle struct { // the container is terminated and restarted according to its restart policy. // Other management of the container blocks until the hook completes. // More info: http://kubernetes.io/docs/user-guide/container-environment#hook-details + // +optional PostStart *Handler `json:"postStart,omitempty" protobuf:"bytes,1,opt,name=postStart"` // PreStop is called immediately before a container is terminated. // The container is terminated after the handler completes. @@ -1320,6 +1495,7 @@ type Lifecycle struct { // Regardless of the outcome of the handler, the container is eventually terminated. // Other management of the container blocks until the hook completes. // More info: http://kubernetes.io/docs/user-guide/container-environment#hook-details + // +optional PreStop *Handler `json:"preStop,omitempty" protobuf:"bytes,2,opt,name=preStop"` } @@ -1338,14 +1514,17 @@ const ( // ContainerStateWaiting is a waiting state of a container. type ContainerStateWaiting struct { // (brief) reason the container is not yet running. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,1,opt,name=reason"` // Message regarding why the container is not yet running. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,2,opt,name=message"` } // ContainerStateRunning is a running state of a container. type ContainerStateRunning struct { // Time at which the container was last (re-)started + // +optional StartedAt unversioned.Time `json:"startedAt,omitempty" protobuf:"bytes,1,opt,name=startedAt"` } @@ -1354,16 +1533,22 @@ type ContainerStateTerminated struct { // Exit status from the last termination of the container ExitCode int32 `json:"exitCode" protobuf:"varint,1,opt,name=exitCode"` // Signal from the last termination of the container + // +optional Signal int32 `json:"signal,omitempty" protobuf:"varint,2,opt,name=signal"` // (brief) reason from the last termination of the container + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,3,opt,name=reason"` // Message regarding the last termination of the container + // +optional Message string `json:"message,omitempty" protobuf:"bytes,4,opt,name=message"` // Time at which previous execution of the container started + // +optional StartedAt unversioned.Time `json:"startedAt,omitempty" protobuf:"bytes,5,opt,name=startedAt"` // Time at which the container last terminated + // +optional FinishedAt unversioned.Time `json:"finishedAt,omitempty" protobuf:"bytes,6,opt,name=finishedAt"` // Container's ID in the format 'docker://' + // +optional ContainerID string `json:"containerID,omitempty" protobuf:"bytes,7,opt,name=containerID"` } @@ -1372,10 +1557,13 @@ type ContainerStateTerminated struct { // If none of them is specified, the default one is ContainerStateWaiting. type ContainerState struct { // Details about a waiting container + // +optional Waiting *ContainerStateWaiting `json:"waiting,omitempty" protobuf:"bytes,1,opt,name=waiting"` // Details about a running container + // +optional Running *ContainerStateRunning `json:"running,omitempty" protobuf:"bytes,2,opt,name=running"` // Details about a terminated container + // +optional Terminated *ContainerStateTerminated `json:"terminated,omitempty" protobuf:"bytes,3,opt,name=terminated"` } @@ -1385,8 +1573,10 @@ type ContainerStatus struct { // Cannot be updated. Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // Details about the container's current condition. + // +optional State ContainerState `json:"state,omitempty" protobuf:"bytes,2,opt,name=state"` // Details about the container's last termination condition. + // +optional LastTerminationState ContainerState `json:"lastState,omitempty" protobuf:"bytes,3,opt,name=lastState"` // Specifies whether the container has passed its readiness probe. Ready bool `json:"ready" protobuf:"varint,4,opt,name=ready"` @@ -1403,6 +1593,7 @@ type ContainerStatus struct { ImageID string `json:"imageID" protobuf:"bytes,7,opt,name=imageID"` // Container's ID in the format 'docker://'. // More info: http://kubernetes.io/docs/user-guide/container-environment#container-information + // +optional ContainerID string `json:"containerID,omitempty" protobuf:"bytes,8,opt,name=containerID"` } @@ -1439,6 +1630,9 @@ const ( // PodReady means the pod is able to service requests and should be added to the // load balancing pools of all matching services. PodReady PodConditionType = "Ready" + // PodReasonUnschedulable reason in PodScheduled PodCondition means that the scheduler + // can't schedule the pod right now, for example due to insufficient resources in the cluster. + PodReasonUnschedulable = "Unschedulable" ) // PodCondition contains details for the current condition of this pod. @@ -1452,12 +1646,16 @@ type PodCondition struct { // More info: http://kubernetes.io/docs/user-guide/pod-states#pod-conditions Status ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=ConditionStatus"` // Last time we probed the condition. + // +optional LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty" protobuf:"bytes,3,opt,name=lastProbeTime"` // Last time the condition transitioned from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` // Unique, one-word, CamelCase reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` // Human-readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` } @@ -1516,6 +1714,7 @@ type NodeSelectorRequirement struct { // the values array must be empty. If the operator is Gt or Lt, the values // array must have a single element, which will be interpreted as an integer. // This array is replaced during a strategic merge patch. + // +optional Values []string `json:"values,omitempty" protobuf:"bytes,3,rep,name=values"` } @@ -1535,10 +1734,13 @@ const ( // Affinity is a group of affinity scheduling rules. type Affinity struct { // Describes node affinity scheduling rules for the pod. + // +optional NodeAffinity *NodeAffinity `json:"nodeAffinity,omitempty" protobuf:"bytes,1,opt,name=nodeAffinity"` // Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)). + // +optional PodAffinity *PodAffinity `json:"podAffinity,omitempty" protobuf:"bytes,2,opt,name=podAffinity"` // Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)). + // +optional PodAntiAffinity *PodAntiAffinity `json:"podAntiAffinity,omitempty" protobuf:"bytes,3,opt,name=podAntiAffinity"` } @@ -1552,6 +1754,7 @@ type PodAffinity struct { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1560,6 +1763,7 @@ type PodAffinity struct { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional RequiredDuringSchedulingIgnoredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,1,rep,name=requiredDuringSchedulingIgnoredDuringExecution"` // The scheduler will prefer to schedule pods to nodes that satisfy // the affinity expressions specified by this field, but it may choose @@ -1570,6 +1774,7 @@ type PodAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []WeightedPodAffinityTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,2,rep,name=preferredDuringSchedulingIgnoredDuringExecution"` } @@ -1583,6 +1788,7 @@ type PodAntiAffinity struct { // system will try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional // RequiredDuringSchedulingRequiredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the anti-affinity requirements specified by this field are not met at // scheduling time, the pod will not be scheduled onto the node. @@ -1591,6 +1797,7 @@ type PodAntiAffinity struct { // system may or may not try to eventually evict the pod from its node. // When there are multiple elements, the lists of nodes corresponding to each // podAffinityTerm are intersected, i.e. all terms must be satisfied. + // +optional RequiredDuringSchedulingIgnoredDuringExecution []PodAffinityTerm `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,1,rep,name=requiredDuringSchedulingIgnoredDuringExecution"` // The scheduler will prefer to schedule pods to nodes that satisfy // the anti-affinity expressions specified by this field, but it may choose @@ -1601,6 +1808,7 @@ type PodAntiAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []WeightedPodAffinityTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,2,rep,name=preferredDuringSchedulingIgnoredDuringExecution"` } @@ -1621,6 +1829,7 @@ type WeightedPodAffinityTerm struct { // a pod of the set of pods is running type PodAffinityTerm struct { // A label query over a set of resources, in this case pods. + // +optional LabelSelector *unversioned.LabelSelector `json:"labelSelector,omitempty" protobuf:"bytes,1,opt,name=labelSelector"` // namespaces specifies which namespaces the labelSelector applies to (matches against); // nil list means "this pod's namespace," empty list means "all namespaces" @@ -1634,6 +1843,7 @@ type PodAffinityTerm struct { // For PreferredDuringScheduling pod anti-affinity, empty topologyKey is interpreted as "all topologies" // ("all topologies" here means all the topologyKeys indicated by scheduler command-line argument --failure-domains); // for affinity and for RequiredDuringScheduling pod anti-affinity, empty topologyKey is not allowed. + // +optional TopologyKey string `json:"topologyKey,omitempty" protobuf:"bytes,3,opt,name=topologyKey"` } @@ -1645,6 +1855,7 @@ type NodeAffinity struct { // If the affinity requirements specified by this field cease to be met // at some point during pod execution (e.g. due to an update), the system // will try to eventually evict the pod from its node. + // +optional // RequiredDuringSchedulingRequiredDuringExecution *NodeSelector `json:"requiredDuringSchedulingRequiredDuringExecution,omitempty"` // If the affinity requirements specified by this field are not met at @@ -1652,6 +1863,7 @@ type NodeAffinity struct { // If the affinity requirements specified by this field cease to be met // at some point during pod execution (e.g. due to an update), the system // may or may not try to eventually evict the pod from its node. + // +optional RequiredDuringSchedulingIgnoredDuringExecution *NodeSelector `json:"requiredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,1,opt,name=requiredDuringSchedulingIgnoredDuringExecution"` // The scheduler will prefer to schedule pods to nodes that satisfy // the affinity expressions specified by this field, but it may choose @@ -1662,6 +1874,7 @@ type NodeAffinity struct { // compute a sum by iterating through the elements of this field and adding // "weight" to the sum if the node matches the corresponding matchExpressions; the // node(s) with the highest sum are the most preferred. + // +optional PreferredDuringSchedulingIgnoredDuringExecution []PreferredSchedulingTerm `json:"preferredDuringSchedulingIgnoredDuringExecution,omitempty" protobuf:"bytes,2,rep,name=preferredDuringSchedulingIgnoredDuringExecution"` } @@ -1680,6 +1893,7 @@ type Taint struct { // Required. The taint key to be applied to a node. Key string `json:"key" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,1,opt,name=key"` // Required. The taint value corresponding to the taint key. + // +optional Value string `json:"value,omitempty" protobuf:"bytes,2,opt,name=value"` // Required. The effect of the taint on pods // that do not tolerate the taint. @@ -1717,17 +1931,21 @@ const ( // the triple using the matching operator . type Toleration struct { // Required. Key is the taint key that the toleration applies to. + // +optional Key string `json:"key,omitempty" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,1,opt,name=key"` // operator represents a key's relationship to the value. // Valid operators are Exists and Equal. Defaults to Equal. // Exists is equivalent to wildcard for value, so that a pod can // tolerate all taints of a particular category. + // +optional Operator TolerationOperator `json:"operator,omitempty" protobuf:"bytes,2,opt,name=operator,casttype=TolerationOperator"` // Value is the taint value the toleration matches to. // If the operator is Exists, the value should be empty, otherwise just a regular string. + // +optional Value string `json:"value,omitempty" protobuf:"bytes,3,opt,name=value"` // Effect indicates the taint effect to match. Empty means match all taint effects. // When specified, allowed values are NoSchedule and PreferNoSchedule. + // +optional Effect TaintEffect `json:"effect,omitempty" protobuf:"bytes,4,opt,name=effect,casttype=TaintEffect"` // TODO: For forgiveness (#1574), we'd eventually add at least a grace period // here, and possibly an occurrence threshold and period. @@ -1766,6 +1984,7 @@ const ( type PodSpec struct { // List of volumes that can be mounted by containers belonging to the pod. // More info: http://kubernetes.io/docs/user-guide/volumes + // +optional Volumes []Volume `json:"volumes,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,1,rep,name=volumes"` // List of initialization containers belonging to the pod. // Init containers are executed in order prior to containers being started. If any @@ -1792,6 +2011,7 @@ type PodSpec struct { // One of Always, OnFailure, Never. // Default to Always. // More info: http://kubernetes.io/docs/user-guide/pod-states#restartpolicy + // +optional RestartPolicy RestartPolicy `json:"restartPolicy,omitempty" protobuf:"bytes,3,opt,name=restartPolicy,casttype=RestartPolicy"` // Optional duration in seconds the pod needs to terminate gracefully. May be decreased in delete request. // Value must be non-negative integer. The value zero indicates delete immediately. @@ -1800,58 +2020,72 @@ type PodSpec struct { // a termination signal and the time when the processes are forcibly halted with a kill signal. // Set this value longer than the expected cleanup time for your process. // Defaults to 30 seconds. + // +optional TerminationGracePeriodSeconds *int64 `json:"terminationGracePeriodSeconds,omitempty" protobuf:"varint,4,opt,name=terminationGracePeriodSeconds"` // Optional duration in seconds the pod may be active on the node relative to // StartTime before the system will actively try to mark it failed and kill associated containers. // Value must be a positive integer. + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty" protobuf:"varint,5,opt,name=activeDeadlineSeconds"` // Set DNS policy for containers within the pod. // One of 'ClusterFirst' or 'Default'. // Defaults to "ClusterFirst". + // +optional DNSPolicy DNSPolicy `json:"dnsPolicy,omitempty" protobuf:"bytes,6,opt,name=dnsPolicy,casttype=DNSPolicy"` // NodeSelector is a selector which must be true for the pod to fit on a node. // Selector which must match a node's labels for the pod to be scheduled on that node. // More info: http://kubernetes.io/docs/user-guide/node-selection/README + // +optional NodeSelector map[string]string `json:"nodeSelector,omitempty" protobuf:"bytes,7,rep,name=nodeSelector"` // ServiceAccountName is the name of the ServiceAccount to use to run this pod. // More info: http://releases.k8s.io/HEAD/docs/design/service_accounts.md + // +optional ServiceAccountName string `json:"serviceAccountName,omitempty" protobuf:"bytes,8,opt,name=serviceAccountName"` // DeprecatedServiceAccount is a depreciated alias for ServiceAccountName. // Deprecated: Use serviceAccountName instead. // +k8s:conversion-gen=false + // +optional DeprecatedServiceAccount string `json:"serviceAccount,omitempty" protobuf:"bytes,9,opt,name=serviceAccount"` // NodeName is a request to schedule this pod onto a specific node. If it is non-empty, // the scheduler simply schedules this pod onto that node, assuming that it fits resource // requirements. + // +optional NodeName string `json:"nodeName,omitempty" protobuf:"bytes,10,opt,name=nodeName"` // Host networking requested for this pod. Use the host's network namespace. // If this option is set, the ports that will be used must be specified. // Default to false. // +k8s:conversion-gen=false + // +optional HostNetwork bool `json:"hostNetwork,omitempty" protobuf:"varint,11,opt,name=hostNetwork"` // Use the host's pid namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional HostPID bool `json:"hostPID,omitempty" protobuf:"varint,12,opt,name=hostPID"` // Use the host's ipc namespace. // Optional: Default to false. // +k8s:conversion-gen=false + // +optional HostIPC bool `json:"hostIPC,omitempty" protobuf:"varint,13,opt,name=hostIPC"` // SecurityContext holds pod-level security attributes and common container settings. // Optional: Defaults to empty. See type description for default values of each field. + // +optional SecurityContext *PodSecurityContext `json:"securityContext,omitempty" protobuf:"bytes,14,opt,name=securityContext"` // ImagePullSecrets is an optional list of references to secrets in the same namespace to use for pulling any of the images used by this PodSpec. // If specified, these secrets will be passed to individual puller implementations for them to use. For example, // in the case of docker, only DockerConfig type secrets are honored. // More info: http://kubernetes.io/docs/user-guide/images#specifying-imagepullsecrets-on-a-pod + // +optional ImagePullSecrets []LocalObjectReference `json:"imagePullSecrets,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,15,rep,name=imagePullSecrets"` // Specifies the hostname of the Pod // If not specified, the pod's hostname will be set to a system-defined value. + // +optional Hostname string `json:"hostname,omitempty" protobuf:"bytes,16,opt,name=hostname"` // If specified, the fully qualified Pod hostname will be "...svc.". // If not specified, the pod will not have a domainname at all. + // +optional Subdomain string `json:"subdomain,omitempty" protobuf:"bytes,17,opt,name=subdomain"` } @@ -1864,12 +2098,14 @@ type PodSecurityContext struct { // container. May also be set in SecurityContext. If set in // both SecurityContext and PodSecurityContext, the value specified in SecurityContext // takes precedence for that container. + // +optional SELinuxOptions *SELinuxOptions `json:"seLinuxOptions,omitempty" protobuf:"bytes,1,opt,name=seLinuxOptions"` // The UID to run the entrypoint of the container process. // Defaults to user specified in image metadata if unspecified. // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence // for that container. + // +optional RunAsUser *int64 `json:"runAsUser,omitempty" protobuf:"varint,2,opt,name=runAsUser"` // Indicates that the container must run as a non-root user. // If true, the Kubelet will validate the image at runtime to ensure that it @@ -1877,10 +2113,12 @@ type PodSecurityContext struct { // If unset or false, no such validation will be performed. // May also be set in SecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsNonRoot *bool `json:"runAsNonRoot,omitempty" protobuf:"varint,3,opt,name=runAsNonRoot"` // A list of groups applied to the first process run in each container, in addition // to the container's primary GID. If unspecified, no groups will be added to // any container. + // +optional SupplementalGroups []int64 `json:"supplementalGroups,omitempty" protobuf:"varint,4,rep,name=supplementalGroups"` // A special supplemental group that applies to all containers in a pod. // Some volume types allow the Kubelet to change the ownership of that volume @@ -1891,6 +2129,7 @@ type PodSecurityContext struct { // 3. The permission bits are OR'd with rw-rw---- // // If unset, the Kubelet will not modify the ownership and permissions of any volume. + // +optional FSGroup *int64 `json:"fsGroup,omitempty" protobuf:"varint,5,opt,name=fsGroup"` } @@ -1899,24 +2138,31 @@ type PodSecurityContext struct { type PodStatus struct { // Current condition of the pod. // More info: http://kubernetes.io/docs/user-guide/pod-states#pod-phase + // +optional Phase PodPhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=PodPhase"` // Current service state of pod. // More info: http://kubernetes.io/docs/user-guide/pod-states#pod-conditions + // +optional Conditions []PodCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,2,rep,name=conditions"` // A human readable message indicating details about why the pod is in this condition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,3,opt,name=message"` // A brief CamelCase message indicating details about why the pod is in this state. // e.g. 'OutOfDisk' + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` // IP address of the host to which the pod is assigned. Empty if not yet scheduled. + // +optional HostIP string `json:"hostIP,omitempty" protobuf:"bytes,5,opt,name=hostIP"` // IP address allocated to the pod. Routable at least within the cluster. // Empty if not yet allocated. + // +optional PodIP string `json:"podIP,omitempty" protobuf:"bytes,6,opt,name=podIP"` // RFC 3339 date and time at which the object was acknowledged by the Kubelet. // This is before the Kubelet pulled the container image(s) for the pod. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty" protobuf:"bytes,7,opt,name=startTime"` // The list has one entry per init container in the manifest. The most recent successful @@ -1928,6 +2174,7 @@ type PodStatus struct { // The list has one entry per container in the manifest. Each entry is currently the output // of `docker inspect`. // More info: http://kubernetes.io/docs/user-guide/pod-states#container-statuses + // +optional ContainerStatuses []ContainerStatus `json:"containerStatuses,omitempty" protobuf:"bytes,8,rep,name=containerStatuses"` } @@ -1936,12 +2183,14 @@ type PodStatusResult struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Most recently observed status of the pod. // This data may not be up to date. // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status PodStatus `json:"status,omitempty" protobuf:"bytes,2,opt,name=status"` } @@ -1953,10 +2202,12 @@ type Pod struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior of the pod. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec PodSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Most recently observed status of the pod. @@ -1964,6 +2215,7 @@ type Pod struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status PodStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -1972,6 +2224,7 @@ type PodList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of pods. @@ -1983,10 +2236,12 @@ type PodList struct { type PodTemplateSpec struct { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior of the pod. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec PodSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` } @@ -1997,10 +2252,12 @@ type PodTemplate struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Template defines the pods that will be created from this pod template. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Template PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,2,opt,name=template"` } @@ -2009,6 +2266,7 @@ type PodTemplateList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of pod templates @@ -2021,11 +2279,13 @@ type ReplicationControllerSpec struct { // This is a pointer to distinguish between explicit zero and unspecified. // Defaults to 1. // More info: http://kubernetes.io/docs/user-guide/replication-controller#what-is-a-replication-controller + // +optional Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` // Selector is a label query over pods that should match the Replicas count. @@ -2033,16 +2293,19 @@ type ReplicationControllerSpec struct { // Label keys and values that must match in order to be controlled by this replication // controller, if empty defaulted to labels on Pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector map[string]string `json:"selector,omitempty" protobuf:"bytes,2,rep,name=selector"` // TemplateRef is a reference to an object that describes the pod that will be created if // insufficient replicas are detected. // Reference to an object that describes the pod that will be created if insufficient replicas are detected. + // +optional // TemplateRef *ObjectReference `json:"templateRef,omitempty"` // Template is the object that describes the pod that will be created if // insufficient replicas are detected. This takes precedence over a TemplateRef. // More info: http://kubernetes.io/docs/user-guide/replication-controller#pod-template + // +optional Template *PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,3,opt,name=template"` } @@ -2054,18 +2317,23 @@ type ReplicationControllerStatus struct { Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` // The number of pods that have labels matching the labels of the pod template of the replication controller. + // +optional FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty" protobuf:"varint,2,opt,name=fullyLabeledReplicas"` // The number of ready replicas for this replication controller. + // +optional ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,4,opt,name=readyReplicas"` // The number of available replicas (ready for at least minReadySeconds) for this replication controller. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,5,opt,name=availableReplicas"` // ObservedGeneration reflects the generation of the most recently observed replication controller. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,3,opt,name=observedGeneration"` // Represents the latest available observations of a replication controller's current state. + // +optional Conditions []ReplicationControllerCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` } @@ -2085,13 +2353,14 @@ type ReplicationControllerCondition struct { Type ReplicationControllerConditionType `json:"type"` // Status of the condition, one of True, False, Unknown. Status ConditionStatus `json:"status"` - // Last time we probed the condition. - LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` // The last time the condition transitioned from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` // The reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty"` // A human readable message indicating details about the transition. + // +optional Message string `json:"message,omitempty"` } @@ -2104,10 +2373,12 @@ type ReplicationController struct { // If the Labels of a ReplicationController are empty, they are defaulted to // be the same as the Pod(s) that the replication controller manages. // Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the specification of the desired behavior of the replication controller. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ReplicationControllerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is the most recently observed status of the replication controller. @@ -2115,6 +2386,7 @@ type ReplicationController struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ReplicationControllerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -2123,6 +2395,7 @@ type ReplicationControllerList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of replication controllers. @@ -2168,6 +2441,7 @@ const ( type ServiceStatus struct { // LoadBalancer contains the current status of the load-balancer, // if one is present. + // +optional LoadBalancer LoadBalancerStatus `json:"loadBalancer,omitempty" protobuf:"bytes,1,opt,name=loadBalancer"` } @@ -2175,6 +2449,7 @@ type ServiceStatus struct { type LoadBalancerStatus struct { // Ingress is a list containing ingress points for the load-balancer. // Traffic intended for the service should be sent to these ingress points. + // +optional Ingress []LoadBalancerIngress `json:"ingress,omitempty" protobuf:"bytes,1,rep,name=ingress"` } @@ -2183,10 +2458,12 @@ type LoadBalancerStatus struct { type LoadBalancerIngress struct { // IP is set for load-balancer ingress points that are IP based // (typically GCE or OpenStack load-balancers) + // +optional IP string `json:"ip,omitempty" protobuf:"bytes,1,opt,name=ip"` // Hostname is set for load-balancer ingress points that are DNS based // (typically AWS load-balancers) + // +optional Hostname string `json:"hostname,omitempty" protobuf:"bytes,2,opt,name=hostname"` } @@ -2202,6 +2479,7 @@ type ServiceSpec struct { // modify. Only applies to types ClusterIP, NodePort, and LoadBalancer. // Ignored if type is ExternalName. // More info: http://kubernetes.io/docs/user-guide/services#overview + // +optional Selector map[string]string `json:"selector,omitempty" protobuf:"bytes,2,rep,name=selector"` // clusterIP is the IP address of the service and is usually assigned @@ -2213,6 +2491,7 @@ type ServiceSpec struct { // Only applies to types ClusterIP, NodePort, and LoadBalancer. Ignored if // type is ExternalName. // More info: http://kubernetes.io/docs/user-guide/services#virtual-ips-and-service-proxies + // +optional ClusterIP string `json:"clusterIP,omitempty" protobuf:"bytes,3,opt,name=clusterIP"` // type determines how the Service is exposed. Defaults to ClusterIP. Valid @@ -2229,6 +2508,7 @@ type ServiceSpec struct { // external load-balancer (if supported in the current cloud) which routes // to the clusterIP. // More info: http://kubernetes.io/docs/user-guide/services#overview + // +optional Type ServiceType `json:"type,omitempty" protobuf:"bytes,4,opt,name=type,casttype=ServiceType"` // externalIPs is a list of IP addresses for which nodes in the cluster @@ -2238,6 +2518,7 @@ type ServiceSpec struct { // that are not part of the Kubernetes system. A previous form of this // functionality exists as the deprecatedPublicIPs field. When using this // field, callers should also clear the deprecatedPublicIPs field. + // +optional ExternalIPs []string `json:"externalIPs,omitempty" protobuf:"bytes,5,rep,name=externalIPs"` // deprecatedPublicIPs is deprecated and replaced by the externalIPs field @@ -2246,6 +2527,7 @@ type ServiceSpec struct { // any new API revisions. If both deprecatedPublicIPs *and* externalIPs are // set, deprecatedPublicIPs is used. // +k8s:conversion-gen=false + // +optional DeprecatedPublicIPs []string `json:"deprecatedPublicIPs,omitempty" protobuf:"bytes,6,rep,name=deprecatedPublicIPs"` // Supports "ClientIP" and "None". Used to maintain session affinity. @@ -2253,6 +2535,7 @@ type ServiceSpec struct { // Must be ClientIP or None. // Defaults to None. // More info: http://kubernetes.io/docs/user-guide/services#virtual-ips-and-service-proxies + // +optional SessionAffinity ServiceAffinity `json:"sessionAffinity,omitempty" protobuf:"bytes,7,opt,name=sessionAffinity,casttype=ServiceAffinity"` // Only applies to Service Type: LoadBalancer @@ -2260,17 +2543,20 @@ type ServiceSpec struct { // This feature depends on whether the underlying cloud-provider supports specifying // the loadBalancerIP when a load balancer is created. // This field will be ignored if the cloud-provider does not support the feature. + // +optional LoadBalancerIP string `json:"loadBalancerIP,omitempty" protobuf:"bytes,8,opt,name=loadBalancerIP"` // If specified and supported by the platform, this will restrict traffic through the cloud-provider // load-balancer will be restricted to the specified client IPs. This field will be ignored if the // cloud-provider does not support the feature." // More info: http://kubernetes.io/docs/user-guide/services-firewalls + // +optional LoadBalancerSourceRanges []string `json:"loadBalancerSourceRanges,omitempty" protobuf:"bytes,9,opt,name=loadBalancerSourceRanges"` // externalName is the external reference that kubedns or equivalent will // return as a CNAME record for this service. No proxying will be involved. // Must be a valid DNS name and requires Type to be ExternalName. + // +optional ExternalName string `json:"externalName,omitempty" protobuf:"bytes,10,opt,name=externalName"` } @@ -2280,10 +2566,12 @@ type ServicePort struct { // All ports within a ServiceSpec must have unique names. This maps to // the 'Name' field in EndpointPort objects. // Optional if only one ServicePort is defined on this service. + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` // The IP protocol for this port. Supports "TCP" and "UDP". // Default is TCP. + // +optional Protocol Protocol `json:"protocol,omitempty" protobuf:"bytes,2,opt,name=protocol,casttype=Protocol"` // The port that will be exposed by this service. @@ -2297,6 +2585,7 @@ type ServicePort struct { // This field is ignored for services with clusterIP=None, and should be // omitted or set equal to the 'port' field. // More info: http://kubernetes.io/docs/user-guide/services#defining-a-service + // +optional TargetPort intstr.IntOrString `json:"targetPort,omitempty" protobuf:"bytes,4,opt,name=targetPort"` // The port on each node on which this service is exposed when type=NodePort or LoadBalancer. @@ -2304,6 +2593,7 @@ type ServicePort struct { // if unused or else creation of the service will fail. // Default is to auto-allocate a port if the ServiceType of this Service requires one. // More info: http://kubernetes.io/docs/user-guide/services#type--nodeport + // +optional NodePort int32 `json:"nodePort,omitempty" protobuf:"varint,5,opt,name=nodePort"` } @@ -2316,16 +2606,19 @@ type Service struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the behavior of a service. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ServiceSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Most recently observed status of the service. // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ServiceStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -2340,6 +2633,7 @@ type ServiceList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of services @@ -2356,16 +2650,19 @@ type ServiceAccount struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Secrets is the list of secrets allowed to be used by pods running using this ServiceAccount. // More info: http://kubernetes.io/docs/user-guide/secrets + // +optional Secrets []ObjectReference `json:"secrets,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=secrets"` // ImagePullSecrets is a list of references to secrets in the same namespace to use for pulling any images // in pods that reference this ServiceAccount. ImagePullSecrets are distinct from Secrets because Secrets // can be mounted in the pod, but ImagePullSecrets are only accessed by the kubelet. // More info: http://kubernetes.io/docs/user-guide/secrets#manually-specifying-an-imagepullsecret + // +optional ImagePullSecrets []LocalObjectReference `json:"imagePullSecrets,omitempty" protobuf:"bytes,3,rep,name=imagePullSecrets"` } @@ -2374,6 +2671,7 @@ type ServiceAccountList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of ServiceAccounts. @@ -2399,6 +2697,7 @@ type Endpoints struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // The set of all endpoints is the union of all subsets. Addresses are placed into @@ -2424,12 +2723,15 @@ type Endpoints struct { type EndpointSubset struct { // IP addresses which offer the related ports that are marked as ready. These endpoints // should be considered safe for load balancers and clients to utilize. + // +optional Addresses []EndpointAddress `json:"addresses,omitempty" protobuf:"bytes,1,rep,name=addresses"` // IP addresses which offer the related ports but are not currently marked as ready // because they have not yet finished starting, have recently failed a readiness check, // or have recently failed a liveness check. + // +optional NotReadyAddresses []EndpointAddress `json:"notReadyAddresses,omitempty" protobuf:"bytes,2,rep,name=notReadyAddresses"` // Port numbers available on the related IP addresses. + // +optional Ports []EndpointPort `json:"ports,omitempty" protobuf:"bytes,3,rep,name=ports"` } @@ -2443,10 +2745,13 @@ type EndpointAddress struct { // TODO: This should allow hostname or IP, See #4447. IP string `json:"ip" protobuf:"bytes,1,opt,name=ip"` // The Hostname of this endpoint + // +optional Hostname string `json:"hostname,omitempty" protobuf:"bytes,3,opt,name=hostname"` // Optional: Node hosting this endpoint. This can be used to determine endpoints local to a node. + // +optional NodeName *string `json:"nodeName,omitempty" protobuf:"bytes,4,opt,name=nodeName"` // Reference to object providing the endpoint. + // +optional TargetRef *ObjectReference `json:"targetRef,omitempty" protobuf:"bytes,2,opt,name=targetRef"` } @@ -2455,6 +2760,7 @@ type EndpointPort struct { // The name of this port (corresponds to ServicePort.Name). // Must be a DNS_LABEL. // Optional only if one port is defined. + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` // The port number of the endpoint. @@ -2463,6 +2769,7 @@ type EndpointPort struct { // The IP protocol for this port. // Must be UDP or TCP. // Default is TCP. + // +optional Protocol Protocol `json:"protocol,omitempty" protobuf:"bytes,3,opt,name=protocol,casttype=Protocol"` } @@ -2471,6 +2778,7 @@ type EndpointsList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of endpoints. @@ -2480,14 +2788,18 @@ type EndpointsList struct { // NodeSpec describes the attributes that a node is created with. type NodeSpec struct { // PodCIDR represents the pod IP range assigned to the node. + // +optional PodCIDR string `json:"podCIDR,omitempty" protobuf:"bytes,1,opt,name=podCIDR"` // External ID of the node assigned by some machine database (e.g. a cloud provider). // Deprecated. + // +optional ExternalID string `json:"externalID,omitempty" protobuf:"bytes,2,opt,name=externalID"` // ID of the node assigned by the cloud provider in the format: :// + // +optional ProviderID string `json:"providerID,omitempty" protobuf:"bytes,3,opt,name=providerID"` // Unschedulable controls node schedulability of new pods. By default, node is schedulable. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#manual-node-administration"` + // +optional Unschedulable bool `json:"unschedulable,omitempty" protobuf:"varint,4,opt,name=unschedulable"` } @@ -2506,6 +2818,7 @@ type DaemonEndpoint struct { // NodeDaemonEndpoints lists ports opened by daemons running on the Node. type NodeDaemonEndpoints struct { // Endpoint on which Kubelet is listening. + // +optional KubeletEndpoint DaemonEndpoint `json:"kubeletEndpoint,omitempty" protobuf:"bytes,1,opt,name=kubeletEndpoint"` } @@ -2541,31 +2854,41 @@ type NodeSystemInfo struct { type NodeStatus struct { // Capacity represents the total resources of a node. // More info: http://kubernetes.io/docs/user-guide/persistent-volumes#capacity for more details. + // +optional Capacity ResourceList `json:"capacity,omitempty" protobuf:"bytes,1,rep,name=capacity,casttype=ResourceList,castkey=ResourceName"` // Allocatable represents the resources of a node that are available for scheduling. // Defaults to Capacity. + // +optional Allocatable ResourceList `json:"allocatable,omitempty" protobuf:"bytes,2,rep,name=allocatable,casttype=ResourceList,castkey=ResourceName"` // NodePhase is the recently observed lifecycle phase of the node. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-phase // The field is never populated, and now is deprecated. + // +optional Phase NodePhase `json:"phase,omitempty" protobuf:"bytes,3,opt,name=phase,casttype=NodePhase"` // Conditions is an array of current observed node conditions. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-condition + // +optional Conditions []NodeCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,4,rep,name=conditions"` // List of addresses reachable to the node. // Queried from cloud provider, if available. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses + // +optional Addresses []NodeAddress `json:"addresses,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,5,rep,name=addresses"` // Endpoints of daemons running on the Node. + // +optional DaemonEndpoints NodeDaemonEndpoints `json:"daemonEndpoints,omitempty" protobuf:"bytes,6,opt,name=daemonEndpoints"` // Set of ids/uuids to uniquely identify the node. // More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info + // +optional NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty" protobuf:"bytes,7,opt,name=nodeInfo"` // List of container images on this node + // +optional Images []ContainerImage `json:"images,omitempty" protobuf:"bytes,8,rep,name=images"` // List of attachable volumes in use (mounted) by the node. + // +optional VolumesInUse []UniqueVolumeName `json:"volumesInUse,omitempty" protobuf:"bytes,9,rep,name=volumesInUse"` // List of volumes that are attached to the node. + // +optional VolumesAttached []AttachedVolume `json:"volumesAttached,omitempty" protobuf:"bytes,10,rep,name=volumesAttached"` } @@ -2576,7 +2899,7 @@ type AttachedVolume struct { // Name of the attached volume Name UniqueVolumeName `json:"name" protobuf:"bytes,1,rep,name=name"` - // DevicePath represents the device path where the volume should be avilable + // DevicePath represents the device path where the volume should be available DevicePath string `json:"devicePath" protobuf:"bytes,2,rep,name=devicePath"` } @@ -2586,6 +2909,7 @@ type AttachedVolume struct { type AvoidPods struct { // Bounded-sized list of signatures of pods that should avoid this node, sorted // in timestamp order from oldest to newest. Size of the slice is unspecified. + // +optional PreferAvoidPods []PreferAvoidPodsEntry `json:"preferAvoidPods,omitempty" protobuf:"bytes,1,rep,name=preferAvoidPods"` } @@ -2594,10 +2918,13 @@ type PreferAvoidPodsEntry struct { // The class of pods. PodSignature PodSignature `json:"podSignature" protobuf:"bytes,1,opt,name=podSignature"` // Time at which this entry was added to the list. + // +optional EvictionTime unversioned.Time `json:"evictionTime,omitempty" protobuf:"bytes,2,opt,name=evictionTime"` // (brief) reason why this entry was added to the list. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,3,opt,name=reason"` // Human readable message indicating why this entry was added to the list. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,4,opt,name=message"` } @@ -2605,6 +2932,7 @@ type PreferAvoidPodsEntry struct { // Exactly one field should be set. type PodSignature struct { // Reference to controller whose pods should avoid this node. + // +optional PodController *OwnerReference `json:"podController,omitempty" protobuf:"bytes,1,opt,name=podController"` } @@ -2614,6 +2942,7 @@ type ContainerImage struct { // e.g. ["gcr.io/google_containers/hyperkube:v1.0.7", "dockerhub.io/google_containers/hyperkube:v1.0.7"] Names []string `json:"names" protobuf:"bytes,1,rep,name=names"` // The size of the image in bytes. + // +optional SizeBytes int64 `json:"sizeBytes,omitempty" protobuf:"varint,2,opt,name=sizeBytes"` } @@ -2655,12 +2984,16 @@ type NodeCondition struct { // Status of the condition, one of True, False, Unknown. Status ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=ConditionStatus"` // Last time we got an update on a given condition. + // +optional LastHeartbeatTime unversioned.Time `json:"lastHeartbeatTime,omitempty" protobuf:"bytes,3,opt,name=lastHeartbeatTime"` // Last time the condition transit from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` // (brief) reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` // Human readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` } @@ -2713,16 +3046,19 @@ type Node struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the behavior of a node. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec NodeSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Most recently observed status of the node. // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status NodeStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -2731,6 +3067,7 @@ type NodeList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of nodes @@ -2742,12 +3079,14 @@ type FinalizerName string // These are internal finalizer values to Kubernetes, must be qualified name unless defined here const ( FinalizerKubernetes FinalizerName = "kubernetes" + FinalizerOrphan string = "orphan" ) // NamespaceSpec describes the attributes on a Namespace. type NamespaceSpec struct { // Finalizers is an opaque list of values that must be empty to permanently remove object from storage. // More info: http://releases.k8s.io/HEAD/docs/design/namespaces.md#finalizers + // +optional Finalizers []FinalizerName `json:"finalizers,omitempty" protobuf:"bytes,1,rep,name=finalizers,casttype=FinalizerName"` } @@ -2755,6 +3094,7 @@ type NamespaceSpec struct { type NamespaceStatus struct { // Phase is the current lifecycle phase of the namespace. // More info: http://releases.k8s.io/HEAD/docs/design/namespaces.md#phases + // +optional Phase NamespacePhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=NamespacePhase"` } @@ -2777,14 +3117,17 @@ type Namespace struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the behavior of the Namespace. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec NamespaceSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status describes the current status of a Namespace. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status NamespaceStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -2793,6 +3136,7 @@ type NamespaceList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Namespace objects in the list. @@ -2806,6 +3150,7 @@ type Binding struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // The target object that you want to bind to the standard object. @@ -2815,6 +3160,7 @@ type Binding struct { // Preconditions must be fulfilled before an operation (update, delete, etc.) is carried out. type Preconditions struct { // Specifies the target UID. + // +optional UID *types.UID `json:"uid,omitempty" protobuf:"bytes,1,opt,name=uid,casttype=k8s.io/kubernetes/pkg/types.UID"` } @@ -2826,14 +3172,17 @@ type DeleteOptions struct { // The value zero indicates delete immediately. If this value is nil, the default grace period for the // specified type will be used. // Defaults to a per object value if not specified. zero means delete immediately. + // +optional GracePeriodSeconds *int64 `json:"gracePeriodSeconds,omitempty" protobuf:"varint,1,opt,name=gracePeriodSeconds"` // Must be fulfilled before a deletion is carried out. If not possible, a 409 Conflict status will be // returned. + // +optional Preconditions *Preconditions `json:"preconditions,omitempty" protobuf:"bytes,2,opt,name=preconditions"` // Should the dependent objects be orphaned. If true/false, the "orphan" // finalizer will be added to/removed from the object's finalizers list. + // +optional OrphanDependents *bool `json:"orphanDependents,omitempty" protobuf:"varint,3,opt,name=orphanDependents"` } @@ -2853,17 +3202,22 @@ type ListOptions struct { // A selector to restrict the list of returned objects by their labels. // Defaults to everything. + // +optional LabelSelector string `json:"labelSelector,omitempty" protobuf:"bytes,1,opt,name=labelSelector"` // A selector to restrict the list of returned objects by their fields. // Defaults to everything. + // +optional FieldSelector string `json:"fieldSelector,omitempty" protobuf:"bytes,2,opt,name=fieldSelector"` // Watch for changes to the described resources and return them as a stream of // add, update, and remove notifications. Specify resourceVersion. + // +optional Watch bool `json:"watch,omitempty" protobuf:"varint,3,opt,name=watch"` // When specified with a watch call, shows changes that occur after that particular version of a resource. // Defaults to changes from the beginning of history. + // +optional ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,4,opt,name=resourceVersion"` // Timeout for the list/watch call. + // +optional TimeoutSeconds *int64 `json:"timeoutSeconds,omitempty" protobuf:"varint,5,opt,name=timeoutSeconds"` } @@ -2872,30 +3226,38 @@ type PodLogOptions struct { unversioned.TypeMeta `json:",inline"` // The container for which to stream logs. Defaults to only container if there is one container in the pod. + // +optional Container string `json:"container,omitempty" protobuf:"bytes,1,opt,name=container"` // Follow the log stream of the pod. Defaults to false. + // +optional Follow bool `json:"follow,omitempty" protobuf:"varint,2,opt,name=follow"` // Return previous terminated container logs. Defaults to false. + // +optional Previous bool `json:"previous,omitempty" protobuf:"varint,3,opt,name=previous"` // A relative time in seconds before the current time from which to show logs. If this value // precedes the time a pod was started, only logs since the pod start will be returned. // If this value is in the future, no logs will be returned. // Only one of sinceSeconds or sinceTime may be specified. + // +optional SinceSeconds *int64 `json:"sinceSeconds,omitempty" protobuf:"varint,4,opt,name=sinceSeconds"` // An RFC3339 timestamp from which to show logs. If this value // precedes the time a pod was started, only logs since the pod start will be returned. // If this value is in the future, no logs will be returned. // Only one of sinceSeconds or sinceTime may be specified. + // +optional SinceTime *unversioned.Time `json:"sinceTime,omitempty" protobuf:"bytes,5,opt,name=sinceTime"` // If true, add an RFC3339 or RFC3339Nano timestamp at the beginning of every line // of log output. Defaults to false. + // +optional Timestamps bool `json:"timestamps,omitempty" protobuf:"varint,6,opt,name=timestamps"` // If set, the number of lines from the end of the logs to show. If not specified, // logs are shown from the creation of the container or sinceSeconds or sinceTime + // +optional TailLines *int64 `json:"tailLines,omitempty" protobuf:"varint,7,opt,name=tailLines"` // If set, the number of bytes to read from the server before terminating the // log output. This may not display a complete final line of logging, and may return // slightly more or slightly less than the specified limit. + // +optional LimitBytes *int64 `json:"limitBytes,omitempty" protobuf:"varint,8,opt,name=limitBytes"` } @@ -2908,24 +3270,29 @@ type PodAttachOptions struct { // Stdin if true, redirects the standard input stream of the pod for this call. // Defaults to false. + // +optional Stdin bool `json:"stdin,omitempty" protobuf:"varint,1,opt,name=stdin"` // Stdout if true indicates that stdout is to be redirected for the attach call. // Defaults to true. + // +optional Stdout bool `json:"stdout,omitempty" protobuf:"varint,2,opt,name=stdout"` // Stderr if true indicates that stderr is to be redirected for the attach call. // Defaults to true. + // +optional Stderr bool `json:"stderr,omitempty" protobuf:"varint,3,opt,name=stderr"` // TTY if true indicates that a tty will be allocated for the attach call. // This is passed through the container runtime so the tty // is allocated on the worker node by the container runtime. // Defaults to false. + // +optional TTY bool `json:"tty,omitempty" protobuf:"varint,4,opt,name=tty"` // The container in which to execute the command. // Defaults to only container if there is only one container in the pod. + // +optional Container string `json:"container,omitempty" protobuf:"bytes,5,opt,name=container"` } @@ -2938,22 +3305,27 @@ type PodExecOptions struct { // Redirect the standard input stream of the pod for this call. // Defaults to false. + // +optional Stdin bool `json:"stdin,omitempty" protobuf:"varint,1,opt,name=stdin"` // Redirect the standard output stream of the pod for this call. // Defaults to true. + // +optional Stdout bool `json:"stdout,omitempty" protobuf:"varint,2,opt,name=stdout"` // Redirect the standard error stream of the pod for this call. // Defaults to true. + // +optional Stderr bool `json:"stderr,omitempty" protobuf:"varint,3,opt,name=stderr"` // TTY if true indicates that a tty will be allocated for the exec call. // Defaults to false. + // +optional TTY bool `json:"tty,omitempty" protobuf:"varint,4,opt,name=tty"` // Container in which to execute the command. // Defaults to only container if there is only one container in the pod. + // +optional Container string `json:"container,omitempty" protobuf:"bytes,5,opt,name=container"` // Command is the remote command to execute. argv array. Not executed within a shell. @@ -2965,6 +3337,7 @@ type PodProxyOptions struct { unversioned.TypeMeta `json:",inline"` // Path is the URL path to use for the current proxy request to pod. + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` } @@ -2973,6 +3346,7 @@ type NodeProxyOptions struct { unversioned.TypeMeta `json:",inline"` // Path is the URL path to use for the current proxy request to node. + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` } @@ -2985,6 +3359,7 @@ type ServiceProxyOptions struct { // For example, the whole request URL is // http://localhost/api/v1/namespaces/kube-system/services/elasticsearch-logging/_search?q=user:kimchy. // Path is _search?q=user:kimchy. + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` } @@ -3004,6 +3379,7 @@ type OwnerReference struct { // More info: http://kubernetes.io/docs/user-guide/identifiers#uids UID types.UID `json:"uid" protobuf:"bytes,4,opt,name=uid,casttype=k8s.io/kubernetes/pkg/types.UID"` // If true, this reference points to the managing controller. + // +optional Controller *bool `json:"controller,omitempty" protobuf:"varint,6,opt,name=controller"` } @@ -3011,20 +3387,26 @@ type OwnerReference struct { type ObjectReference struct { // Kind of the referent. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` // Namespace of the referent. // More info: http://kubernetes.io/docs/user-guide/namespaces + // +optional Namespace string `json:"namespace,omitempty" protobuf:"bytes,2,opt,name=namespace"` // Name of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional Name string `json:"name,omitempty" protobuf:"bytes,3,opt,name=name"` // UID of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#uids + // +optional UID types.UID `json:"uid,omitempty" protobuf:"bytes,4,opt,name=uid,casttype=k8s.io/kubernetes/pkg/types.UID"` // API version of the referent. + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,5,opt,name=apiVersion"` // Specific resourceVersion to which this reference is made, if any. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#concurrency-control-and-consistency + // +optional ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,6,opt,name=resourceVersion"` // If referring to a piece of an object instead of an entire object, this string @@ -3035,6 +3417,7 @@ type ObjectReference struct { // index 2 in this pod). This syntax is chosen only to have some well-defined way of // referencing a part of an object. // TODO: this design is not final and this field is subject to change in the future. + // +optional FieldPath string `json:"fieldPath,omitempty" protobuf:"bytes,7,opt,name=fieldPath"` } @@ -3044,6 +3427,7 @@ type LocalObjectReference struct { // Name of the referent. // More info: http://kubernetes.io/docs/user-guide/identifiers#names // TODO: Add other useful fields. apiVersion, kind, uid? + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` } @@ -3051,14 +3435,17 @@ type LocalObjectReference struct { type SerializedReference struct { unversioned.TypeMeta `json:",inline"` // The reference to an object in the system. + // +optional Reference ObjectReference `json:"reference,omitempty" protobuf:"bytes,1,opt,name=reference"` } // EventSource contains information for an event. type EventSource struct { // Component from which the event is generated. + // +optional Component string `json:"component,omitempty" protobuf:"bytes,1,opt,name=component"` // Node name on which the event is generated. + // +optional Host string `json:"host,omitempty" protobuf:"bytes,2,opt,name=host"` } @@ -3086,25 +3473,32 @@ type Event struct { // This should be a short, machine understandable string that gives the reason // for the transition into the object's current status. // TODO: provide exact specification for format. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,3,opt,name=reason"` // A human-readable description of the status of this operation. // TODO: decide on maximum length. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,4,opt,name=message"` // The component reporting this event. Should be a short machine understandable string. + // +optional Source EventSource `json:"source,omitempty" protobuf:"bytes,5,opt,name=source"` // The time at which the event was first recorded. (Time of server receipt is in TypeMeta.) + // +optional FirstTimestamp unversioned.Time `json:"firstTimestamp,omitempty" protobuf:"bytes,6,opt,name=firstTimestamp"` // The time at which the most recent occurrence of this event was recorded. + // +optional LastTimestamp unversioned.Time `json:"lastTimestamp,omitempty" protobuf:"bytes,7,opt,name=lastTimestamp"` // The number of times this event has occurred. + // +optional Count int32 `json:"count,omitempty" protobuf:"varint,8,opt,name=count"` // Type of this event (Normal, Warning), new types could be added in the future + // +optional Type string `json:"type,omitempty" protobuf:"bytes,9,opt,name=type"` } @@ -3113,6 +3507,7 @@ type EventList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of events @@ -3124,6 +3519,7 @@ type List struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of objects @@ -3145,16 +3541,22 @@ const ( // LimitRangeItem defines a min/max usage limit for any resource that matches on kind. type LimitRangeItem struct { // Type of resource that this limit applies to. + // +optional Type LimitType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=LimitType"` // Max usage constraints on this kind by resource name. + // +optional Max ResourceList `json:"max,omitempty" protobuf:"bytes,2,rep,name=max,casttype=ResourceList,castkey=ResourceName"` // Min usage constraints on this kind by resource name. + // +optional Min ResourceList `json:"min,omitempty" protobuf:"bytes,3,rep,name=min,casttype=ResourceList,castkey=ResourceName"` // Default resource requirement limit value by resource name if resource limit is omitted. + // +optional Default ResourceList `json:"default,omitempty" protobuf:"bytes,4,rep,name=default,casttype=ResourceList,castkey=ResourceName"` // DefaultRequest is the default resource requirement request value by resource name if resource request is omitted. + // +optional DefaultRequest ResourceList `json:"defaultRequest,omitempty" protobuf:"bytes,5,rep,name=defaultRequest,casttype=ResourceList,castkey=ResourceName"` // MaxLimitRequestRatio if specified, the named resource must have a request and limit that are both non-zero where limit divided by request is less than or equal to the enumerated value; this represents the max burst for the named resource. + // +optional MaxLimitRequestRatio ResourceList `json:"maxLimitRequestRatio,omitempty" protobuf:"bytes,6,rep,name=maxLimitRequestRatio,casttype=ResourceList,castkey=ResourceName"` } @@ -3171,10 +3573,12 @@ type LimitRange struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the limits enforced. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec LimitRangeSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` } @@ -3183,6 +3587,7 @@ type LimitRangeList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of LimitRange objects. @@ -3240,9 +3645,11 @@ const ( type ResourceQuotaSpec struct { // Hard is the set of desired hard limits for each named resource. // More info: http://releases.k8s.io/HEAD/docs/design/admission_control_resource_quota.md#admissioncontrol-plugin-resourcequota + // +optional Hard ResourceList `json:"hard,omitempty" protobuf:"bytes,1,rep,name=hard,casttype=ResourceList,castkey=ResourceName"` // A collection of filters that must match each object tracked by a quota. // If not specified, the quota matches all objects. + // +optional Scopes []ResourceQuotaScope `json:"scopes,omitempty" protobuf:"bytes,2,rep,name=scopes,casttype=ResourceQuotaScope"` } @@ -3250,8 +3657,10 @@ type ResourceQuotaSpec struct { type ResourceQuotaStatus struct { // Hard is the set of enforced hard limits for each named resource. // More info: http://releases.k8s.io/HEAD/docs/design/admission_control_resource_quota.md#admissioncontrol-plugin-resourcequota + // +optional Hard ResourceList `json:"hard,omitempty" protobuf:"bytes,1,rep,name=hard,casttype=ResourceList,castkey=ResourceName"` // Used is the current observed total usage of the resource in the namespace. + // +optional Used ResourceList `json:"used,omitempty" protobuf:"bytes,2,rep,name=used,casttype=ResourceList,castkey=ResourceName"` } @@ -3262,14 +3671,17 @@ type ResourceQuota struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the desired quota. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ResourceQuotaSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status defines the actual enforced quota and its current usage. // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ResourceQuotaStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -3278,6 +3690,7 @@ type ResourceQuotaList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of ResourceQuota objects. @@ -3293,6 +3706,7 @@ type Secret struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Data contains the secret data. Each key must be a valid DNS_SUBDOMAIN @@ -3300,6 +3714,7 @@ type Secret struct { // The serialized form of the secret data is a base64 encoded string, // representing the arbitrary (possibly non-string) data value here. // Described in https://tools.ietf.org/html/rfc4648#section-4 + // +optional Data map[string][]byte `json:"data,omitempty" protobuf:"bytes,2,rep,name=data"` // stringData allows specifying non-binary secret data in string form. @@ -3307,9 +3722,11 @@ type Secret struct { // All keys and values are merged into the data field on write, overwriting any existing values. // It is never output when reading from the API. // +k8s:conversion-gen=false + // +optional StringData map[string]string `json:"stringData,omitempty" protobuf:"bytes,4,rep,name=stringData"` // Used to facilitate programmatic handling of secret data. + // +optional Type SecretType `json:"type,omitempty" protobuf:"bytes,3,opt,name=type,casttype=SecretType"` } @@ -3372,6 +3789,7 @@ type SecretList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of secret objects. @@ -3386,10 +3804,12 @@ type ConfigMap struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Data contains the configuration data. // Each key must be a valid DNS_SUBDOMAIN with an optional leading dot. + // +optional Data map[string]string `json:"data,omitempty" protobuf:"bytes,2,rep,name=data"` } @@ -3398,6 +3818,7 @@ type ConfigMapList struct { unversioned.TypeMeta `json:",inline"` // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of ConfigMaps. @@ -3422,9 +3843,11 @@ type ComponentCondition struct { Status ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=ConditionStatus"` // Message about the condition for a component. // For example, information about a health check. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,3,opt,name=message"` // Condition error code for a component. // For example, a health check error code. + // +optional Error string `json:"error,omitempty" protobuf:"bytes,4,opt,name=error"` } @@ -3436,9 +3859,11 @@ type ComponentStatus struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of component conditions observed + // +optional Conditions []ComponentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,2,rep,name=conditions"` } @@ -3447,6 +3872,7 @@ type ComponentStatusList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of ComponentStatus objects. @@ -3457,12 +3883,14 @@ type ComponentStatusList struct { // Downward API volumes support ownership management and SELinux relabeling. type DownwardAPIVolumeSource struct { // Items is a list of downward API volume file + // +optional Items []DownwardAPIVolumeFile `json:"items,omitempty" protobuf:"bytes,1,rep,name=items"` // Optional: mode bits to use on created files by default. Must be a // value between 0 and 0777. Defaults to 0644. // Directories within the path are not affected by this setting. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional DefaultMode *int32 `json:"defaultMode,omitempty" protobuf:"varint,2,opt,name=defaultMode"` } @@ -3475,14 +3903,17 @@ type DownwardAPIVolumeFile struct { // Required: Path is the relative path name of the file to be created. Must not be absolute or contain the '..' path. Must be utf-8 encoded. The first item of the relative path must not start with '..' Path string `json:"path" protobuf:"bytes,1,opt,name=path"` // Required: Selects a field of the pod: only annotations, labels, name and namespace are supported. + // +optional FieldRef *ObjectFieldSelector `json:"fieldRef,omitempty" protobuf:"bytes,2,opt,name=fieldRef"` // Selects a resource of the container: only resources limits and requests // (limits.cpu, limits.memory, requests.cpu and requests.memory) are currently supported. + // +optional ResourceFieldRef *ResourceFieldSelector `json:"resourceFieldRef,omitempty" protobuf:"bytes,3,opt,name=resourceFieldRef"` // Optional: mode bits to use on this file, must be a value between 0 // and 0777. If not specified, the volume defaultMode will be used. // This might be in conflict with other options that affect the file // mode, like fsGroup, and the result can be other mode bits set. + // +optional Mode *int32 `json:"mode,omitempty" protobuf:"varint,4,opt,name=mode"` } @@ -3492,20 +3923,24 @@ type DownwardAPIVolumeFile struct { type SecurityContext struct { // The capabilities to add/drop when running containers. // Defaults to the default set of capabilities granted by the container runtime. + // +optional Capabilities *Capabilities `json:"capabilities,omitempty" protobuf:"bytes,1,opt,name=capabilities"` // Run container in privileged mode. // Processes in privileged containers are essentially equivalent to root on the host. // Defaults to false. + // +optional Privileged *bool `json:"privileged,omitempty" protobuf:"varint,2,opt,name=privileged"` // The SELinux context to be applied to the container. // If unspecified, the container runtime will allocate a random SELinux context for each // container. May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional SELinuxOptions *SELinuxOptions `json:"seLinuxOptions,omitempty" protobuf:"bytes,3,opt,name=seLinuxOptions"` // The UID to run the entrypoint of the container process. // Defaults to user specified in image metadata if unspecified. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsUser *int64 `json:"runAsUser,omitempty" protobuf:"varint,4,opt,name=runAsUser"` // Indicates that the container must run as a non-root user. // If true, the Kubelet will validate the image at runtime to ensure that it @@ -3513,21 +3948,27 @@ type SecurityContext struct { // If unset or false, no such validation will be performed. // May also be set in PodSecurityContext. If set in both SecurityContext and // PodSecurityContext, the value specified in SecurityContext takes precedence. + // +optional RunAsNonRoot *bool `json:"runAsNonRoot,omitempty" protobuf:"varint,5,opt,name=runAsNonRoot"` // Whether this container has a read-only root filesystem. // Default is false. + // +optional ReadOnlyRootFilesystem *bool `json:"readOnlyRootFilesystem,omitempty" protobuf:"varint,6,opt,name=readOnlyRootFilesystem"` } // SELinuxOptions are the labels to be applied to the container type SELinuxOptions struct { // User is a SELinux user label that applies to the container. + // +optional User string `json:"user,omitempty" protobuf:"bytes,1,opt,name=user"` // Role is a SELinux role label that applies to the container. + // +optional Role string `json:"role,omitempty" protobuf:"bytes,2,opt,name=role"` // Type is a SELinux type label that applies to the container. + // +optional Type string `json:"type,omitempty" protobuf:"bytes,3,opt,name=type"` // Level is SELinux level label that applies to the container. + // +optional Level string `json:"level,omitempty" protobuf:"bytes,4,opt,name=level"` } @@ -3536,6 +3977,7 @@ type RangeAllocation struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Range is string that identifies the range represented by 'data'. diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/api/v1/types_swagger_doc_generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/v1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/api/v1/types_swagger_doc_generated.go index 2347076..6dc1767 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/types_swagger_doc_generated.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/types_swagger_doc_generated.go @@ -53,7 +53,7 @@ func (Affinity) SwaggerDoc() map[string]string { var map_AttachedVolume = map[string]string{ "": "AttachedVolume describes a volume attached to a node", "name": "Name of the attached volume", - "devicePath": "DevicePath represents the device path where the volume should be avilable", + "devicePath": "DevicePath represents the device path where the volume should be available", } func (AttachedVolume) SwaggerDoc() map[string]string { @@ -1447,7 +1447,6 @@ var map_ReplicationControllerCondition = map[string]string{ "": "ReplicationControllerCondition describes the state of a replication controller at a certain point.", "type": "Type of replication controller condition.", "status": "Status of the condition, one of True, False, Unknown.", - "lastProbeTime": "Last time we probed the condition.", "lastTransitionTime": "The last time the condition transitioned from one status to another.", "reason": "The reason for the condition's last transition.", "message": "A human readable message indicating details about the transition.", diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.conversion.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/api/v1/zz_generated.conversion.go index 24c5f82..921ebe6 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.conversion.go @@ -21,11 +21,11 @@ limitations under the License. package v1 import ( - api "k8s.io/kubernetes/pkg/api" - resource "k8s.io/kubernetes/pkg/api/resource" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - types "k8s.io/kubernetes/pkg/types" + api "k8s.io/client-go/pkg/api" + resource "k8s.io/client-go/pkg/api/resource" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" + types "k8s.io/client-go/pkg/types" ) func init() { @@ -502,7 +502,6 @@ func Convert_api_AvoidPods_To_v1_AvoidPods(in *api.AvoidPods, out *AvoidPods, s } func autoConvert_v1_AzureDiskVolumeSource_To_api_AzureDiskVolumeSource(in *AzureDiskVolumeSource, out *api.AzureDiskVolumeSource, s conversion.Scope) error { - SetDefaults_AzureDiskVolumeSource(in) out.DiskName = in.DiskName out.DataDiskURI = in.DataDiskURI if in.CachingMode != nil { @@ -563,9 +562,6 @@ func Convert_api_AzureFileVolumeSource_To_v1_AzureFileVolumeSource(in *api.Azure } func autoConvert_v1_Binding_To_api_Binding(in *Binding, out *api.Binding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -580,9 +576,6 @@ func Convert_v1_Binding_To_api_Binding(in *Binding, out *api.Binding, s conversi } func autoConvert_api_Binding_To_v1_Binding(in *api.Binding, out *Binding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -739,9 +732,6 @@ func Convert_api_ComponentCondition_To_v1_ComponentCondition(in *api.ComponentCo } func autoConvert_v1_ComponentStatus_To_api_ComponentStatus(in *ComponentStatus, out *api.ComponentStatus, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -764,9 +754,6 @@ func Convert_v1_ComponentStatus_To_api_ComponentStatus(in *ComponentStatus, out } func autoConvert_api_ComponentStatus_To_v1_ComponentStatus(in *api.ComponentStatus, out *ComponentStatus, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -789,12 +776,7 @@ func Convert_api_ComponentStatus_To_v1_ComponentStatus(in *api.ComponentStatus, } func autoConvert_v1_ComponentStatusList_To_api_ComponentStatusList(in *ComponentStatusList, out *api.ComponentStatusList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.ComponentStatus, len(*in)) @@ -814,12 +796,7 @@ func Convert_v1_ComponentStatusList_To_api_ComponentStatusList(in *ComponentStat } func autoConvert_api_ComponentStatusList_To_v1_ComponentStatusList(in *api.ComponentStatusList, out *ComponentStatusList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ComponentStatus, len(*in)) @@ -839,10 +816,6 @@ func Convert_api_ComponentStatusList_To_v1_ComponentStatusList(in *api.Component } func autoConvert_v1_ConfigMap_To_api_ConfigMap(in *ConfigMap, out *api.ConfigMap, s conversion.Scope) error { - SetDefaults_ConfigMap(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -855,9 +828,6 @@ func Convert_v1_ConfigMap_To_api_ConfigMap(in *ConfigMap, out *api.ConfigMap, s } func autoConvert_api_ConfigMap_To_v1_ConfigMap(in *api.ConfigMap, out *ConfigMap, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -894,12 +864,7 @@ func Convert_api_ConfigMapKeySelector_To_v1_ConfigMapKeySelector(in *api.ConfigM } func autoConvert_v1_ConfigMapList_To_api_ConfigMapList(in *ConfigMapList, out *api.ConfigMapList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.ConfigMap, len(*in)) @@ -919,12 +884,7 @@ func Convert_v1_ConfigMapList_To_api_ConfigMapList(in *ConfigMapList, out *api.C } func autoConvert_api_ConfigMapList_To_v1_ConfigMapList(in *api.ConfigMapList, out *ConfigMapList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ConfigMap, len(*in)) @@ -944,7 +904,6 @@ func Convert_api_ConfigMapList_To_v1_ConfigMapList(in *api.ConfigMapList, out *C } func autoConvert_v1_ConfigMapVolumeSource_To_api_ConfigMapVolumeSource(in *ConfigMapVolumeSource, out *api.ConfigMapVolumeSource, s conversion.Scope) error { - SetDefaults_ConfigMapVolumeSource(in) if err := Convert_v1_LocalObjectReference_To_api_LocalObjectReference(&in.LocalObjectReference, &out.LocalObjectReference, s); err != nil { return err } @@ -991,7 +950,6 @@ func Convert_api_ConfigMapVolumeSource_To_v1_ConfigMapVolumeSource(in *api.Confi } func autoConvert_v1_Container_To_api_Container(in *Container, out *api.Container, s conversion.Scope) error { - SetDefaults_Container(in) out.Name = in.Name out.Image = in.Image out.Command = in.Command @@ -1192,7 +1150,6 @@ func Convert_api_ContainerImage_To_v1_ContainerImage(in *api.ContainerImage, out } func autoConvert_v1_ContainerPort_To_api_ContainerPort(in *ContainerPort, out *api.ContainerPort, s conversion.Scope) error { - SetDefaults_ContainerPort(in) out.Name = in.Name out.HostPort = in.HostPort out.ContainerPort = in.ContainerPort @@ -1289,9 +1246,7 @@ func Convert_api_ContainerState_To_v1_ContainerState(in *api.ContainerState, out } func autoConvert_v1_ContainerStateRunning_To_api_ContainerStateRunning(in *ContainerStateRunning, out *api.ContainerStateRunning, s conversion.Scope) error { - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.StartedAt, &out.StartedAt, s); err != nil { - return err - } + out.StartedAt = in.StartedAt return nil } @@ -1300,9 +1255,7 @@ func Convert_v1_ContainerStateRunning_To_api_ContainerStateRunning(in *Container } func autoConvert_api_ContainerStateRunning_To_v1_ContainerStateRunning(in *api.ContainerStateRunning, out *ContainerStateRunning, s conversion.Scope) error { - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.StartedAt, &out.StartedAt, s); err != nil { - return err - } + out.StartedAt = in.StartedAt return nil } @@ -1315,12 +1268,8 @@ func autoConvert_v1_ContainerStateTerminated_To_api_ContainerStateTerminated(in out.Signal = in.Signal out.Reason = in.Reason out.Message = in.Message - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.StartedAt, &out.StartedAt, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.FinishedAt, &out.FinishedAt, s); err != nil { - return err - } + out.StartedAt = in.StartedAt + out.FinishedAt = in.FinishedAt out.ContainerID = in.ContainerID return nil } @@ -1334,12 +1283,8 @@ func autoConvert_api_ContainerStateTerminated_To_v1_ContainerStateTerminated(in out.Signal = in.Signal out.Reason = in.Reason out.Message = in.Message - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.StartedAt, &out.StartedAt, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.FinishedAt, &out.FinishedAt, s); err != nil { - return err - } + out.StartedAt = in.StartedAt + out.FinishedAt = in.FinishedAt out.ContainerID = in.ContainerID return nil } @@ -1427,9 +1372,6 @@ func Convert_api_DaemonEndpoint_To_v1_DaemonEndpoint(in *api.DaemonEndpoint, out } func autoConvert_v1_DeleteOptions_To_api_DeleteOptions(in *DeleteOptions, out *api.DeleteOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.GracePeriodSeconds = in.GracePeriodSeconds if in.Preconditions != nil { in, out := &in.Preconditions, &out.Preconditions @@ -1449,9 +1391,6 @@ func Convert_v1_DeleteOptions_To_api_DeleteOptions(in *DeleteOptions, out *api.D } func autoConvert_api_DeleteOptions_To_v1_DeleteOptions(in *api.DeleteOptions, out *DeleteOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.GracePeriodSeconds = in.GracePeriodSeconds if in.Preconditions != nil { in, out := &in.Preconditions, &out.Preconditions @@ -1527,7 +1466,6 @@ func Convert_api_DownwardAPIVolumeFile_To_v1_DownwardAPIVolumeFile(in *api.Downw } func autoConvert_v1_DownwardAPIVolumeSource_To_api_DownwardAPIVolumeSource(in *DownwardAPIVolumeSource, out *api.DownwardAPIVolumeSource, s conversion.Scope) error { - SetDefaults_DownwardAPIVolumeSource(in) if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.DownwardAPIVolumeFile, len(*in)) @@ -1730,10 +1668,6 @@ func Convert_api_EndpointSubset_To_v1_EndpointSubset(in *api.EndpointSubset, out } func autoConvert_v1_Endpoints_To_api_Endpoints(in *Endpoints, out *api.Endpoints, s conversion.Scope) error { - SetDefaults_Endpoints(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -1756,9 +1690,6 @@ func Convert_v1_Endpoints_To_api_Endpoints(in *Endpoints, out *api.Endpoints, s } func autoConvert_api_Endpoints_To_v1_Endpoints(in *api.Endpoints, out *Endpoints, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -1781,12 +1712,7 @@ func Convert_api_Endpoints_To_v1_Endpoints(in *api.Endpoints, out *Endpoints, s } func autoConvert_v1_EndpointsList_To_api_EndpointsList(in *EndpointsList, out *api.EndpointsList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Endpoints, len(*in)) @@ -1806,12 +1732,7 @@ func Convert_v1_EndpointsList_To_api_EndpointsList(in *EndpointsList, out *api.E } func autoConvert_api_EndpointsList_To_v1_EndpointsList(in *api.EndpointsList, out *EndpointsList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Endpoints, len(*in)) @@ -1957,9 +1878,6 @@ func Convert_api_EnvVarSource_To_v1_EnvVarSource(in *api.EnvVarSource, out *EnvV } func autoConvert_v1_Event_To_api_Event(in *Event, out *api.Event, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -1971,12 +1889,8 @@ func autoConvert_v1_Event_To_api_Event(in *Event, out *api.Event, s conversion.S if err := Convert_v1_EventSource_To_api_EventSource(&in.Source, &out.Source, s); err != nil { return err } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.FirstTimestamp, &out.FirstTimestamp, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTimestamp, &out.LastTimestamp, s); err != nil { - return err - } + out.FirstTimestamp = in.FirstTimestamp + out.LastTimestamp = in.LastTimestamp out.Count = in.Count out.Type = in.Type return nil @@ -1987,9 +1901,6 @@ func Convert_v1_Event_To_api_Event(in *Event, out *api.Event, s conversion.Scope } func autoConvert_api_Event_To_v1_Event(in *api.Event, out *Event, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -2001,12 +1912,8 @@ func autoConvert_api_Event_To_v1_Event(in *api.Event, out *Event, s conversion.S if err := Convert_api_EventSource_To_v1_EventSource(&in.Source, &out.Source, s); err != nil { return err } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.FirstTimestamp, &out.FirstTimestamp, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTimestamp, &out.LastTimestamp, s); err != nil { - return err - } + out.FirstTimestamp = in.FirstTimestamp + out.LastTimestamp = in.LastTimestamp out.Count = in.Count out.Type = in.Type return nil @@ -2017,12 +1924,7 @@ func Convert_api_Event_To_v1_Event(in *api.Event, out *Event, s conversion.Scope } func autoConvert_v1_EventList_To_api_EventList(in *EventList, out *api.EventList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Event, len(*in)) @@ -2042,12 +1944,7 @@ func Convert_v1_EventList_To_api_EventList(in *EventList, out *api.EventList, s } func autoConvert_api_EventList_To_v1_EventList(in *api.EventList, out *EventList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Event, len(*in)) @@ -2105,9 +2002,6 @@ func Convert_api_ExecAction_To_v1_ExecAction(in *api.ExecAction, out *ExecAction } func autoConvert_v1_ExportOptions_To_api_ExportOptions(in *ExportOptions, out *api.ExportOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Export = in.Export out.Exact = in.Exact return nil @@ -2118,9 +2012,6 @@ func Convert_v1_ExportOptions_To_api_ExportOptions(in *ExportOptions, out *api.E } func autoConvert_api_ExportOptions_To_v1_ExportOptions(in *api.ExportOptions, out *ExportOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Export = in.Export out.Exact = in.Exact return nil @@ -2285,11 +2176,8 @@ func Convert_api_GlusterfsVolumeSource_To_v1_GlusterfsVolumeSource(in *api.Glust } func autoConvert_v1_HTTPGetAction_To_api_HTTPGetAction(in *HTTPGetAction, out *api.HTTPGetAction, s conversion.Scope) error { - SetDefaults_HTTPGetAction(in) out.Path = in.Path - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.Port, &out.Port, s); err != nil { - return err - } + out.Port = in.Port out.Host = in.Host out.Scheme = api.URIScheme(in.Scheme) if in.HTTPHeaders != nil { @@ -2312,9 +2200,7 @@ func Convert_v1_HTTPGetAction_To_api_HTTPGetAction(in *HTTPGetAction, out *api.H func autoConvert_api_HTTPGetAction_To_v1_HTTPGetAction(in *api.HTTPGetAction, out *HTTPGetAction, s conversion.Scope) error { out.Path = in.Path - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.Port, &out.Port, s); err != nil { - return err - } + out.Port = in.Port out.Host = in.Host out.Scheme = URIScheme(in.Scheme) if in.HTTPHeaders != nil { @@ -2444,7 +2330,6 @@ func Convert_api_HostPathVolumeSource_To_v1_HostPathVolumeSource(in *api.HostPat } func autoConvert_v1_ISCSIVolumeSource_To_api_ISCSIVolumeSource(in *ISCSIVolumeSource, out *api.ISCSIVolumeSource, s conversion.Scope) error { - SetDefaults_ISCSIVolumeSource(in) out.TargetPortal = in.TargetPortal out.IQN = in.IQN out.Lun = in.Lun @@ -2547,9 +2432,6 @@ func Convert_api_Lifecycle_To_v1_Lifecycle(in *api.Lifecycle, out *Lifecycle, s } func autoConvert_v1_LimitRange_To_api_LimitRange(in *LimitRange, out *api.LimitRange, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -2564,9 +2446,6 @@ func Convert_v1_LimitRange_To_api_LimitRange(in *LimitRange, out *api.LimitRange } func autoConvert_api_LimitRange_To_v1_LimitRange(in *api.LimitRange, out *LimitRange, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -2581,7 +2460,6 @@ func Convert_api_LimitRange_To_v1_LimitRange(in *api.LimitRange, out *LimitRange } func autoConvert_v1_LimitRangeItem_To_api_LimitRangeItem(in *LimitRangeItem, out *api.LimitRangeItem, s conversion.Scope) error { - SetDefaults_LimitRangeItem(in) out.Type = api.LimitType(in.Type) if err := Convert_v1_ResourceList_To_api_ResourceList(&in.Max, &out.Max, s); err != nil { return err @@ -2680,12 +2558,7 @@ func Convert_api_LimitRangeItem_To_v1_LimitRangeItem(in *api.LimitRangeItem, out } func autoConvert_v1_LimitRangeList_To_api_LimitRangeList(in *LimitRangeList, out *api.LimitRangeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.LimitRange, len(*in)) @@ -2705,12 +2578,7 @@ func Convert_v1_LimitRangeList_To_api_LimitRangeList(in *LimitRangeList, out *ap } func autoConvert_api_LimitRangeList_To_v1_LimitRangeList(in *api.LimitRangeList, out *LimitRangeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]LimitRange, len(*in)) @@ -2768,12 +2636,7 @@ func Convert_api_LimitRangeSpec_To_v1_LimitRangeSpec(in *api.LimitRangeSpec, out } func autoConvert_v1_List_To_api_List(in *List, out *api.List, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]runtime.Object, len(*in)) @@ -2793,12 +2656,7 @@ func Convert_v1_List_To_api_List(in *List, out *api.List, s conversion.Scope) er } func autoConvert_api_List_To_v1_List(in *api.List, out *List, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]runtime.RawExtension, len(*in)) @@ -2818,9 +2676,6 @@ func Convert_api_List_To_v1_List(in *api.List, out *List, s conversion.Scope) er } func autoConvert_v1_ListOptions_To_api_ListOptions(in *ListOptions, out *api.ListOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := api.Convert_string_To_labels_Selector(&in.LabelSelector, &out.LabelSelector, s); err != nil { return err } @@ -2838,9 +2693,6 @@ func Convert_v1_ListOptions_To_api_ListOptions(in *ListOptions, out *api.ListOpt } func autoConvert_api_ListOptions_To_v1_ListOptions(in *api.ListOptions, out *ListOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := api.Convert_labels_Selector_To_string(&in.LabelSelector, &out.LabelSelector, s); err != nil { return err } @@ -2956,9 +2808,6 @@ func Convert_api_NFSVolumeSource_To_v1_NFSVolumeSource(in *api.NFSVolumeSource, } func autoConvert_v1_Namespace_To_api_Namespace(in *Namespace, out *api.Namespace, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -2976,9 +2825,6 @@ func Convert_v1_Namespace_To_api_Namespace(in *Namespace, out *api.Namespace, s } func autoConvert_api_Namespace_To_v1_Namespace(in *api.Namespace, out *Namespace, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -2996,12 +2842,7 @@ func Convert_api_Namespace_To_v1_Namespace(in *api.Namespace, out *Namespace, s } func autoConvert_v1_NamespaceList_To_api_NamespaceList(in *NamespaceList, out *api.NamespaceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Namespace, len(*in)) @@ -3021,12 +2862,7 @@ func Convert_v1_NamespaceList_To_api_NamespaceList(in *NamespaceList, out *api.N } func autoConvert_api_NamespaceList_To_v1_NamespaceList(in *api.NamespaceList, out *NamespaceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Namespace, len(*in)) @@ -3080,7 +2916,6 @@ func Convert_api_NamespaceSpec_To_v1_NamespaceSpec(in *api.NamespaceSpec, out *N } func autoConvert_v1_NamespaceStatus_To_api_NamespaceStatus(in *NamespaceStatus, out *api.NamespaceStatus, s conversion.Scope) error { - SetDefaults_NamespaceStatus(in) out.Phase = api.NamespacePhase(in.Phase) return nil } @@ -3099,10 +2934,6 @@ func Convert_api_NamespaceStatus_To_v1_NamespaceStatus(in *api.NamespaceStatus, } func autoConvert_v1_Node_To_api_Node(in *Node, out *api.Node, s conversion.Scope) error { - SetDefaults_Node(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3120,9 +2951,6 @@ func Convert_v1_Node_To_api_Node(in *Node, out *api.Node, s conversion.Scope) er } func autoConvert_api_Node_To_v1_Node(in *api.Node, out *Node, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3218,12 +3046,8 @@ func Convert_api_NodeAffinity_To_v1_NodeAffinity(in *api.NodeAffinity, out *Node func autoConvert_v1_NodeCondition_To_api_NodeCondition(in *NodeCondition, out *api.NodeCondition, s conversion.Scope) error { out.Type = api.NodeConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastHeartbeatTime, &out.LastHeartbeatTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastHeartbeatTime = in.LastHeartbeatTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -3236,12 +3060,8 @@ func Convert_v1_NodeCondition_To_api_NodeCondition(in *NodeCondition, out *api.N func autoConvert_api_NodeCondition_To_v1_NodeCondition(in *api.NodeCondition, out *NodeCondition, s conversion.Scope) error { out.Type = NodeConditionType(in.Type) out.Status = ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastHeartbeatTime, &out.LastHeartbeatTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastHeartbeatTime = in.LastHeartbeatTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -3274,12 +3094,7 @@ func Convert_api_NodeDaemonEndpoints_To_v1_NodeDaemonEndpoints(in *api.NodeDaemo } func autoConvert_v1_NodeList_To_api_NodeList(in *NodeList, out *api.NodeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Node, len(*in)) @@ -3299,12 +3114,7 @@ func Convert_v1_NodeList_To_api_NodeList(in *NodeList, out *api.NodeList, s conv } func autoConvert_api_NodeList_To_v1_NodeList(in *api.NodeList, out *NodeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Node, len(*in)) @@ -3324,9 +3134,6 @@ func Convert_api_NodeList_To_v1_NodeList(in *api.NodeList, out *NodeList, s conv } func autoConvert_v1_NodeProxyOptions_To_api_NodeProxyOptions(in *NodeProxyOptions, out *api.NodeProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -3336,9 +3143,6 @@ func Convert_v1_NodeProxyOptions_To_api_NodeProxyOptions(in *NodeProxyOptions, o } func autoConvert_api_NodeProxyOptions_To_v1_NodeProxyOptions(in *api.NodeProxyOptions, out *NodeProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -3470,7 +3274,6 @@ func Convert_api_NodeSpec_To_v1_NodeSpec(in *api.NodeSpec, out *NodeSpec, s conv } func autoConvert_v1_NodeStatus_To_api_NodeStatus(in *NodeStatus, out *api.NodeStatus, s conversion.Scope) error { - SetDefaults_NodeStatus(in) if err := Convert_v1_ResourceList_To_api_ResourceList(&in.Capacity, &out.Capacity, s); err != nil { return err } @@ -3675,7 +3478,6 @@ func Convert_api_NodeSystemInfo_To_v1_NodeSystemInfo(in *api.NodeSystemInfo, out } func autoConvert_v1_ObjectFieldSelector_To_api_ObjectFieldSelector(in *ObjectFieldSelector, out *api.ObjectFieldSelector, s conversion.Scope) error { - SetDefaults_ObjectFieldSelector(in) out.APIVersion = in.APIVersion out.FieldPath = in.FieldPath return nil @@ -3703,9 +3505,7 @@ func autoConvert_v1_ObjectMeta_To_api_ObjectMeta(in *ObjectMeta, out *api.Object out.UID = types.UID(in.UID) out.ResourceVersion = in.ResourceVersion out.Generation = in.Generation - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.CreationTimestamp, &out.CreationTimestamp, s); err != nil { - return err - } + out.CreationTimestamp = in.CreationTimestamp out.DeletionTimestamp = in.DeletionTimestamp out.DeletionGracePeriodSeconds = in.DeletionGracePeriodSeconds out.Labels = in.Labels @@ -3738,9 +3538,7 @@ func autoConvert_api_ObjectMeta_To_v1_ObjectMeta(in *api.ObjectMeta, out *Object out.UID = types.UID(in.UID) out.ResourceVersion = in.ResourceVersion out.Generation = in.Generation - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.CreationTimestamp, &out.CreationTimestamp, s); err != nil { - return err - } + out.CreationTimestamp = in.CreationTimestamp out.DeletionTimestamp = in.DeletionTimestamp out.DeletionGracePeriodSeconds = in.DeletionGracePeriodSeconds out.Labels = in.Labels @@ -3822,10 +3620,6 @@ func Convert_api_OwnerReference_To_v1_OwnerReference(in *api.OwnerReference, out } func autoConvert_v1_PersistentVolume_To_api_PersistentVolume(in *PersistentVolume, out *api.PersistentVolume, s conversion.Scope) error { - SetDefaults_PersistentVolume(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3843,9 +3637,6 @@ func Convert_v1_PersistentVolume_To_api_PersistentVolume(in *PersistentVolume, o } func autoConvert_api_PersistentVolume_To_v1_PersistentVolume(in *api.PersistentVolume, out *PersistentVolume, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3863,10 +3654,6 @@ func Convert_api_PersistentVolume_To_v1_PersistentVolume(in *api.PersistentVolum } func autoConvert_v1_PersistentVolumeClaim_To_api_PersistentVolumeClaim(in *PersistentVolumeClaim, out *api.PersistentVolumeClaim, s conversion.Scope) error { - SetDefaults_PersistentVolumeClaim(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3884,9 +3671,6 @@ func Convert_v1_PersistentVolumeClaim_To_api_PersistentVolumeClaim(in *Persisten } func autoConvert_api_PersistentVolumeClaim_To_v1_PersistentVolumeClaim(in *api.PersistentVolumeClaim, out *PersistentVolumeClaim, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -3904,12 +3688,7 @@ func Convert_api_PersistentVolumeClaim_To_v1_PersistentVolumeClaim(in *api.Persi } func autoConvert_v1_PersistentVolumeClaimList_To_api_PersistentVolumeClaimList(in *PersistentVolumeClaimList, out *api.PersistentVolumeClaimList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.PersistentVolumeClaim, len(*in)) @@ -3929,12 +3708,7 @@ func Convert_v1_PersistentVolumeClaimList_To_api_PersistentVolumeClaimList(in *P } func autoConvert_api_PersistentVolumeClaimList_To_v1_PersistentVolumeClaimList(in *api.PersistentVolumeClaimList, out *PersistentVolumeClaimList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]PersistentVolumeClaim, len(*in)) @@ -4070,12 +3844,7 @@ func Convert_api_PersistentVolumeClaimVolumeSource_To_v1_PersistentVolumeClaimVo } func autoConvert_v1_PersistentVolumeList_To_api_PersistentVolumeList(in *PersistentVolumeList, out *api.PersistentVolumeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.PersistentVolume, len(*in)) @@ -4095,12 +3864,7 @@ func Convert_v1_PersistentVolumeList_To_api_PersistentVolumeList(in *PersistentV } func autoConvert_api_PersistentVolumeList_To_v1_PersistentVolumeList(in *api.PersistentVolumeList, out *PersistentVolumeList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]PersistentVolume, len(*in)) @@ -4522,10 +4286,6 @@ func Convert_api_PersistentVolumeStatus_To_v1_PersistentVolumeStatus(in *api.Per } func autoConvert_v1_Pod_To_api_Pod(in *Pod, out *api.Pod, s conversion.Scope) error { - SetDefaults_Pod(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -4539,9 +4299,6 @@ func autoConvert_v1_Pod_To_api_Pod(in *Pod, out *api.Pod, s conversion.Scope) er } func autoConvert_api_Pod_To_v1_Pod(in *api.Pod, out *Pod, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -4697,10 +4454,6 @@ func Convert_api_PodAntiAffinity_To_v1_PodAntiAffinity(in *api.PodAntiAffinity, } func autoConvert_v1_PodAttachOptions_To_api_PodAttachOptions(in *PodAttachOptions, out *api.PodAttachOptions, s conversion.Scope) error { - SetDefaults_PodAttachOptions(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Stdin = in.Stdin out.Stdout = in.Stdout out.Stderr = in.Stderr @@ -4714,9 +4467,6 @@ func Convert_v1_PodAttachOptions_To_api_PodAttachOptions(in *PodAttachOptions, o } func autoConvert_api_PodAttachOptions_To_v1_PodAttachOptions(in *api.PodAttachOptions, out *PodAttachOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Stdin = in.Stdin out.Stdout = in.Stdout out.Stderr = in.Stderr @@ -4732,12 +4482,8 @@ func Convert_api_PodAttachOptions_To_v1_PodAttachOptions(in *api.PodAttachOption func autoConvert_v1_PodCondition_To_api_PodCondition(in *PodCondition, out *api.PodCondition, s conversion.Scope) error { out.Type = api.PodConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -4750,12 +4496,8 @@ func Convert_v1_PodCondition_To_api_PodCondition(in *PodCondition, out *api.PodC func autoConvert_api_PodCondition_To_v1_PodCondition(in *api.PodCondition, out *PodCondition, s conversion.Scope) error { out.Type = PodConditionType(in.Type) out.Status = ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -4766,10 +4508,6 @@ func Convert_api_PodCondition_To_v1_PodCondition(in *api.PodCondition, out *PodC } func autoConvert_v1_PodExecOptions_To_api_PodExecOptions(in *PodExecOptions, out *api.PodExecOptions, s conversion.Scope) error { - SetDefaults_PodExecOptions(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Stdin = in.Stdin out.Stdout = in.Stdout out.Stderr = in.Stderr @@ -4784,9 +4522,6 @@ func Convert_v1_PodExecOptions_To_api_PodExecOptions(in *PodExecOptions, out *ap } func autoConvert_api_PodExecOptions_To_v1_PodExecOptions(in *api.PodExecOptions, out *PodExecOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Stdin = in.Stdin out.Stdout = in.Stdout out.Stderr = in.Stderr @@ -4801,12 +4536,7 @@ func Convert_api_PodExecOptions_To_v1_PodExecOptions(in *api.PodExecOptions, out } func autoConvert_v1_PodList_To_api_PodList(in *PodList, out *api.PodList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Pod, len(*in)) @@ -4826,12 +4556,7 @@ func Convert_v1_PodList_To_api_PodList(in *PodList, out *api.PodList, s conversi } func autoConvert_api_PodList_To_v1_PodList(in *api.PodList, out *PodList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Pod, len(*in)) @@ -4851,9 +4576,6 @@ func Convert_api_PodList_To_v1_PodList(in *api.PodList, out *PodList, s conversi } func autoConvert_v1_PodLogOptions_To_api_PodLogOptions(in *PodLogOptions, out *api.PodLogOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Container = in.Container out.Follow = in.Follow out.Previous = in.Previous @@ -4870,9 +4592,6 @@ func Convert_v1_PodLogOptions_To_api_PodLogOptions(in *PodLogOptions, out *api.P } func autoConvert_api_PodLogOptions_To_v1_PodLogOptions(in *api.PodLogOptions, out *PodLogOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Container = in.Container out.Follow = in.Follow out.Previous = in.Previous @@ -4889,9 +4608,6 @@ func Convert_api_PodLogOptions_To_v1_PodLogOptions(in *api.PodLogOptions, out *P } func autoConvert_v1_PodProxyOptions_To_api_PodProxyOptions(in *PodProxyOptions, out *api.PodProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -4901,9 +4617,6 @@ func Convert_v1_PodProxyOptions_To_api_PodProxyOptions(in *PodProxyOptions, out } func autoConvert_api_PodProxyOptions_To_v1_PodProxyOptions(in *api.PodProxyOptions, out *PodProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -4984,7 +4697,6 @@ func Convert_api_PodSignature_To_v1_PodSignature(in *api.PodSignature, out *PodS } func autoConvert_v1_PodSpec_To_api_PodSpec(in *PodSpec, out *api.PodSpec, s conversion.Scope) error { - SetDefaults_PodSpec(in) if in.Volumes != nil { in, out := &in.Volumes, &out.Volumes *out = make([]api.Volume, len(*in)) @@ -5215,9 +4927,6 @@ func Convert_api_PodStatus_To_v1_PodStatus(in *api.PodStatus, out *PodStatus, s } func autoConvert_v1_PodStatusResult_To_api_PodStatusResult(in *PodStatusResult, out *api.PodStatusResult, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5228,9 +4937,6 @@ func autoConvert_v1_PodStatusResult_To_api_PodStatusResult(in *PodStatusResult, } func autoConvert_api_PodStatusResult_To_v1_PodStatusResult(in *api.PodStatusResult, out *PodStatusResult, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5241,9 +4947,6 @@ func autoConvert_api_PodStatusResult_To_v1_PodStatusResult(in *api.PodStatusResu } func autoConvert_v1_PodTemplate_To_api_PodTemplate(in *PodTemplate, out *api.PodTemplate, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5258,9 +4961,6 @@ func Convert_v1_PodTemplate_To_api_PodTemplate(in *PodTemplate, out *api.PodTemp } func autoConvert_api_PodTemplate_To_v1_PodTemplate(in *api.PodTemplate, out *PodTemplate, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5275,12 +4975,7 @@ func Convert_api_PodTemplate_To_v1_PodTemplate(in *api.PodTemplate, out *PodTemp } func autoConvert_v1_PodTemplateList_To_api_PodTemplateList(in *PodTemplateList, out *api.PodTemplateList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.PodTemplate, len(*in)) @@ -5300,12 +4995,7 @@ func Convert_v1_PodTemplateList_To_api_PodTemplateList(in *PodTemplateList, out } func autoConvert_api_PodTemplateList_To_v1_PodTemplateList(in *api.PodTemplateList, out *PodTemplateList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]PodTemplate, len(*in)) @@ -5366,9 +5056,7 @@ func autoConvert_v1_PreferAvoidPodsEntry_To_api_PreferAvoidPodsEntry(in *PreferA if err := Convert_v1_PodSignature_To_api_PodSignature(&in.PodSignature, &out.PodSignature, s); err != nil { return err } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.EvictionTime, &out.EvictionTime, s); err != nil { - return err - } + out.EvictionTime = in.EvictionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -5382,9 +5070,7 @@ func autoConvert_api_PreferAvoidPodsEntry_To_v1_PreferAvoidPodsEntry(in *api.Pre if err := Convert_api_PodSignature_To_v1_PodSignature(&in.PodSignature, &out.PodSignature, s); err != nil { return err } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.EvictionTime, &out.EvictionTime, s); err != nil { - return err - } + out.EvictionTime = in.EvictionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -5419,7 +5105,6 @@ func Convert_api_PreferredSchedulingTerm_To_v1_PreferredSchedulingTerm(in *api.P } func autoConvert_v1_Probe_To_api_Probe(in *Probe, out *api.Probe, s conversion.Scope) error { - SetDefaults_Probe(in) if err := Convert_v1_Handler_To_api_Handler(&in.Handler, &out.Handler, s); err != nil { return err } @@ -5478,7 +5163,6 @@ func Convert_api_QuobyteVolumeSource_To_v1_QuobyteVolumeSource(in *api.QuobyteVo } func autoConvert_v1_RBDVolumeSource_To_api_RBDVolumeSource(in *RBDVolumeSource, out *api.RBDVolumeSource, s conversion.Scope) error { - SetDefaults_RBDVolumeSource(in) out.CephMonitors = in.CephMonitors out.RBDImage = in.RBDImage out.FSType = in.FSType @@ -5527,9 +5211,6 @@ func Convert_api_RBDVolumeSource_To_v1_RBDVolumeSource(in *api.RBDVolumeSource, } func autoConvert_v1_RangeAllocation_To_api_RangeAllocation(in *RangeAllocation, out *api.RangeAllocation, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5545,9 +5226,6 @@ func Convert_v1_RangeAllocation_To_api_RangeAllocation(in *RangeAllocation, out } func autoConvert_api_RangeAllocation_To_v1_RangeAllocation(in *api.RangeAllocation, out *RangeAllocation, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5563,10 +5241,6 @@ func Convert_api_RangeAllocation_To_v1_RangeAllocation(in *api.RangeAllocation, } func autoConvert_v1_ReplicationController_To_api_ReplicationController(in *ReplicationController, out *api.ReplicationController, s conversion.Scope) error { - SetDefaults_ReplicationController(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5584,9 +5258,6 @@ func Convert_v1_ReplicationController_To_api_ReplicationController(in *Replicati } func autoConvert_api_ReplicationController_To_v1_ReplicationController(in *api.ReplicationController, out *ReplicationController, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5606,12 +5277,7 @@ func Convert_api_ReplicationController_To_v1_ReplicationController(in *api.Repli func autoConvert_v1_ReplicationControllerCondition_To_api_ReplicationControllerCondition(in *ReplicationControllerCondition, out *api.ReplicationControllerCondition, s conversion.Scope) error { out.Type = api.ReplicationControllerConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -5624,12 +5290,7 @@ func Convert_v1_ReplicationControllerCondition_To_api_ReplicationControllerCondi func autoConvert_api_ReplicationControllerCondition_To_v1_ReplicationControllerCondition(in *api.ReplicationControllerCondition, out *ReplicationControllerCondition, s conversion.Scope) error { out.Type = ReplicationControllerConditionType(in.Type) out.Status = ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -5640,12 +5301,7 @@ func Convert_api_ReplicationControllerCondition_To_v1_ReplicationControllerCondi } func autoConvert_v1_ReplicationControllerList_To_api_ReplicationControllerList(in *ReplicationControllerList, out *api.ReplicationControllerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.ReplicationController, len(*in)) @@ -5665,12 +5321,7 @@ func Convert_v1_ReplicationControllerList_To_api_ReplicationControllerList(in *R } func autoConvert_api_ReplicationControllerList_To_v1_ReplicationControllerList(in *api.ReplicationControllerList, out *ReplicationControllerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ReplicationController, len(*in)) @@ -5776,9 +5427,7 @@ func Convert_api_ReplicationControllerStatus_To_v1_ReplicationControllerStatus(i func autoConvert_v1_ResourceFieldSelector_To_api_ResourceFieldSelector(in *ResourceFieldSelector, out *api.ResourceFieldSelector, s conversion.Scope) error { out.ContainerName = in.ContainerName out.Resource = in.Resource - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.Divisor, &out.Divisor, s); err != nil { - return err - } + out.Divisor = in.Divisor return nil } @@ -5789,9 +5438,7 @@ func Convert_v1_ResourceFieldSelector_To_api_ResourceFieldSelector(in *ResourceF func autoConvert_api_ResourceFieldSelector_To_v1_ResourceFieldSelector(in *api.ResourceFieldSelector, out *ResourceFieldSelector, s conversion.Scope) error { out.ContainerName = in.ContainerName out.Resource = in.Resource - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.Divisor, &out.Divisor, s); err != nil { - return err - } + out.Divisor = in.Divisor return nil } @@ -5800,9 +5447,6 @@ func Convert_api_ResourceFieldSelector_To_v1_ResourceFieldSelector(in *api.Resou } func autoConvert_v1_ResourceQuota_To_api_ResourceQuota(in *ResourceQuota, out *api.ResourceQuota, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5820,9 +5464,6 @@ func Convert_v1_ResourceQuota_To_api_ResourceQuota(in *ResourceQuota, out *api.R } func autoConvert_api_ResourceQuota_To_v1_ResourceQuota(in *api.ResourceQuota, out *ResourceQuota, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -5840,12 +5481,7 @@ func Convert_api_ResourceQuota_To_v1_ResourceQuota(in *api.ResourceQuota, out *R } func autoConvert_v1_ResourceQuotaList_To_api_ResourceQuotaList(in *ResourceQuotaList, out *api.ResourceQuotaList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.ResourceQuota, len(*in)) @@ -5865,12 +5501,7 @@ func Convert_v1_ResourceQuotaList_To_api_ResourceQuotaList(in *ResourceQuotaList } func autoConvert_api_ResourceQuotaList_To_v1_ResourceQuotaList(in *api.ResourceQuotaList, out *ResourceQuotaList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ResourceQuota, len(*in)) @@ -6060,10 +5691,6 @@ func Convert_api_SELinuxOptions_To_v1_SELinuxOptions(in *api.SELinuxOptions, out } func autoConvert_v1_Secret_To_api_Secret(in *Secret, out *api.Secret, s conversion.Scope) error { - SetDefaults_Secret(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6074,9 +5701,6 @@ func autoConvert_v1_Secret_To_api_Secret(in *Secret, out *api.Secret, s conversi } func autoConvert_api_Secret_To_v1_Secret(in *api.Secret, out *Secret, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6114,12 +5738,7 @@ func Convert_api_SecretKeySelector_To_v1_SecretKeySelector(in *api.SecretKeySele } func autoConvert_v1_SecretList_To_api_SecretList(in *SecretList, out *api.SecretList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Secret, len(*in)) @@ -6139,12 +5758,7 @@ func Convert_v1_SecretList_To_api_SecretList(in *SecretList, out *api.SecretList } func autoConvert_api_SecretList_To_v1_SecretList(in *api.SecretList, out *SecretList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Secret, len(*in)) @@ -6164,7 +5778,6 @@ func Convert_api_SecretList_To_v1_SecretList(in *api.SecretList, out *SecretList } func autoConvert_v1_SecretVolumeSource_To_api_SecretVolumeSource(in *SecretVolumeSource, out *api.SecretVolumeSource, s conversion.Scope) error { - SetDefaults_SecretVolumeSource(in) out.SecretName = in.SecretName if in.Items != nil { in, out := &in.Items, &out.Items @@ -6267,9 +5880,6 @@ func Convert_api_SecurityContext_To_v1_SecurityContext(in *api.SecurityContext, } func autoConvert_v1_SerializedReference_To_api_SerializedReference(in *SerializedReference, out *api.SerializedReference, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectReference_To_api_ObjectReference(&in.Reference, &out.Reference, s); err != nil { return err } @@ -6281,9 +5891,6 @@ func Convert_v1_SerializedReference_To_api_SerializedReference(in *SerializedRef } func autoConvert_api_SerializedReference_To_v1_SerializedReference(in *api.SerializedReference, out *SerializedReference, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectReference_To_v1_ObjectReference(&in.Reference, &out.Reference, s); err != nil { return err } @@ -6295,9 +5902,6 @@ func Convert_api_SerializedReference_To_v1_SerializedReference(in *api.Serialize } func autoConvert_v1_Service_To_api_Service(in *Service, out *api.Service, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6315,9 +5919,6 @@ func Convert_v1_Service_To_api_Service(in *Service, out *api.Service, s conversi } func autoConvert_api_Service_To_v1_Service(in *api.Service, out *Service, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6335,9 +5936,6 @@ func Convert_api_Service_To_v1_Service(in *api.Service, out *Service, s conversi } func autoConvert_v1_ServiceAccount_To_api_ServiceAccount(in *ServiceAccount, out *api.ServiceAccount, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_v1_ObjectMeta_To_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6371,9 +5969,6 @@ func Convert_v1_ServiceAccount_To_api_ServiceAccount(in *ServiceAccount, out *ap } func autoConvert_api_ServiceAccount_To_v1_ServiceAccount(in *api.ServiceAccount, out *ServiceAccount, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } if err := Convert_api_ObjectMeta_To_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, s); err != nil { return err } @@ -6407,12 +6002,7 @@ func Convert_api_ServiceAccount_To_v1_ServiceAccount(in *api.ServiceAccount, out } func autoConvert_v1_ServiceAccountList_To_api_ServiceAccountList(in *ServiceAccountList, out *api.ServiceAccountList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.ServiceAccount, len(*in)) @@ -6432,12 +6022,7 @@ func Convert_v1_ServiceAccountList_To_api_ServiceAccountList(in *ServiceAccountL } func autoConvert_api_ServiceAccountList_To_v1_ServiceAccountList(in *api.ServiceAccountList, out *ServiceAccountList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ServiceAccount, len(*in)) @@ -6457,12 +6042,7 @@ func Convert_api_ServiceAccountList_To_v1_ServiceAccountList(in *api.ServiceAcco } func autoConvert_v1_ServiceList_To_api_ServiceList(in *ServiceList, out *api.ServiceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]api.Service, len(*in)) @@ -6482,12 +6062,7 @@ func Convert_v1_ServiceList_To_api_ServiceList(in *ServiceList, out *api.Service } func autoConvert_api_ServiceList_To_v1_ServiceList(in *api.ServiceList, out *ServiceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Service, len(*in)) @@ -6510,9 +6085,7 @@ func autoConvert_v1_ServicePort_To_api_ServicePort(in *ServicePort, out *api.Ser out.Name = in.Name out.Protocol = api.Protocol(in.Protocol) out.Port = in.Port - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.TargetPort, &out.TargetPort, s); err != nil { - return err - } + out.TargetPort = in.TargetPort out.NodePort = in.NodePort return nil } @@ -6525,9 +6098,7 @@ func autoConvert_api_ServicePort_To_v1_ServicePort(in *api.ServicePort, out *Ser out.Name = in.Name out.Protocol = Protocol(in.Protocol) out.Port = in.Port - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.TargetPort, &out.TargetPort, s); err != nil { - return err - } + out.TargetPort = in.TargetPort out.NodePort = in.NodePort return nil } @@ -6537,9 +6108,6 @@ func Convert_api_ServicePort_To_v1_ServicePort(in *api.ServicePort, out *Service } func autoConvert_v1_ServiceProxyOptions_To_api_ServiceProxyOptions(in *ServiceProxyOptions, out *api.ServiceProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -6549,9 +6117,6 @@ func Convert_v1_ServiceProxyOptions_To_api_ServiceProxyOptions(in *ServiceProxyO } func autoConvert_api_ServiceProxyOptions_To_v1_ServiceProxyOptions(in *api.ServiceProxyOptions, out *ServiceProxyOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Path = in.Path return nil } @@ -6561,7 +6126,6 @@ func Convert_api_ServiceProxyOptions_To_v1_ServiceProxyOptions(in *api.ServicePr } func autoConvert_v1_ServiceSpec_To_api_ServiceSpec(in *ServiceSpec, out *api.ServiceSpec, s conversion.Scope) error { - SetDefaults_ServiceSpec(in) if in.Ports != nil { in, out := &in.Ports, &out.Ports *out = make([]api.ServicePort, len(*in)) @@ -6631,9 +6195,7 @@ func Convert_api_ServiceStatus_To_v1_ServiceStatus(in *api.ServiceStatus, out *S } func autoConvert_v1_TCPSocketAction_To_api_TCPSocketAction(in *TCPSocketAction, out *api.TCPSocketAction, s conversion.Scope) error { - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.Port, &out.Port, s); err != nil { - return err - } + out.Port = in.Port return nil } @@ -6642,9 +6204,7 @@ func Convert_v1_TCPSocketAction_To_api_TCPSocketAction(in *TCPSocketAction, out } func autoConvert_api_TCPSocketAction_To_v1_TCPSocketAction(in *api.TCPSocketAction, out *TCPSocketAction, s conversion.Scope) error { - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.Port, &out.Port, s); err != nil { - return err - } + out.Port = in.Port return nil } @@ -6699,7 +6259,6 @@ func Convert_api_Toleration_To_v1_Toleration(in *api.Toleration, out *Toleration } func autoConvert_v1_Volume_To_api_Volume(in *Volume, out *api.Volume, s conversion.Scope) error { - SetDefaults_Volume(in) out.Name = in.Name if err := Convert_v1_VolumeSource_To_api_VolumeSource(&in.VolumeSource, &out.VolumeSource, s); err != nil { return err @@ -7180,7 +6739,7 @@ func Convert_api_VsphereVirtualDiskVolumeSource_To_v1_VsphereVirtualDiskVolumeSo } func autoConvert_v1_WeightedPodAffinityTerm_To_api_WeightedPodAffinityTerm(in *WeightedPodAffinityTerm, out *api.WeightedPodAffinityTerm, s conversion.Scope) error { - out.Weight = int(in.Weight) + out.Weight = in.Weight if err := Convert_v1_PodAffinityTerm_To_api_PodAffinityTerm(&in.PodAffinityTerm, &out.PodAffinityTerm, s); err != nil { return err } @@ -7192,7 +6751,7 @@ func Convert_v1_WeightedPodAffinityTerm_To_api_WeightedPodAffinityTerm(in *Weigh } func autoConvert_api_WeightedPodAffinityTerm_To_v1_WeightedPodAffinityTerm(in *api.WeightedPodAffinityTerm, out *WeightedPodAffinityTerm, s conversion.Scope) error { - out.Weight = int32(in.Weight) + out.Weight = in.Weight if err := Convert_api_PodAffinityTerm_To_v1_PodAffinityTerm(&in.PodAffinityTerm, &out.PodAffinityTerm, s); err != nil { return err } diff --git a/vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.deepcopy.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/api/v1/zz_generated.deepcopy.go index 3d9c85a..feae57d 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/v1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - types "k8s.io/kubernetes/pkg/types" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" + types "k8s.io/client-go/pkg/types" reflect "reflect" ) @@ -2919,7 +2919,6 @@ func DeepCopy_v1_ReplicationControllerCondition(in interface{}, out interface{}, out := out.(*ReplicationControllerCondition) out.Type = in.Type out.Status = in.Status - out.LastProbeTime = in.LastProbeTime.DeepCopy() out.LastTransitionTime = in.LastTransitionTime.DeepCopy() out.Reason = in.Reason out.Message = in.Message diff --git a/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.defaults.go new file mode 100644 index 0000000..3b28e67 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/api/v1/zz_generated.defaults.go @@ -0,0 +1,577 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1 + +import ( + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&ConfigMap{}, func(obj interface{}) { SetObjectDefaults_ConfigMap(obj.(*ConfigMap)) }) + scheme.AddTypeDefaultingFunc(&ConfigMapList{}, func(obj interface{}) { SetObjectDefaults_ConfigMapList(obj.(*ConfigMapList)) }) + scheme.AddTypeDefaultingFunc(&Endpoints{}, func(obj interface{}) { SetObjectDefaults_Endpoints(obj.(*Endpoints)) }) + scheme.AddTypeDefaultingFunc(&EndpointsList{}, func(obj interface{}) { SetObjectDefaults_EndpointsList(obj.(*EndpointsList)) }) + scheme.AddTypeDefaultingFunc(&LimitRange{}, func(obj interface{}) { SetObjectDefaults_LimitRange(obj.(*LimitRange)) }) + scheme.AddTypeDefaultingFunc(&LimitRangeList{}, func(obj interface{}) { SetObjectDefaults_LimitRangeList(obj.(*LimitRangeList)) }) + scheme.AddTypeDefaultingFunc(&Namespace{}, func(obj interface{}) { SetObjectDefaults_Namespace(obj.(*Namespace)) }) + scheme.AddTypeDefaultingFunc(&NamespaceList{}, func(obj interface{}) { SetObjectDefaults_NamespaceList(obj.(*NamespaceList)) }) + scheme.AddTypeDefaultingFunc(&Node{}, func(obj interface{}) { SetObjectDefaults_Node(obj.(*Node)) }) + scheme.AddTypeDefaultingFunc(&NodeList{}, func(obj interface{}) { SetObjectDefaults_NodeList(obj.(*NodeList)) }) + scheme.AddTypeDefaultingFunc(&PersistentVolume{}, func(obj interface{}) { SetObjectDefaults_PersistentVolume(obj.(*PersistentVolume)) }) + scheme.AddTypeDefaultingFunc(&PersistentVolumeClaim{}, func(obj interface{}) { SetObjectDefaults_PersistentVolumeClaim(obj.(*PersistentVolumeClaim)) }) + scheme.AddTypeDefaultingFunc(&PersistentVolumeClaimList{}, func(obj interface{}) { SetObjectDefaults_PersistentVolumeClaimList(obj.(*PersistentVolumeClaimList)) }) + scheme.AddTypeDefaultingFunc(&PersistentVolumeList{}, func(obj interface{}) { SetObjectDefaults_PersistentVolumeList(obj.(*PersistentVolumeList)) }) + scheme.AddTypeDefaultingFunc(&Pod{}, func(obj interface{}) { SetObjectDefaults_Pod(obj.(*Pod)) }) + scheme.AddTypeDefaultingFunc(&PodAttachOptions{}, func(obj interface{}) { SetObjectDefaults_PodAttachOptions(obj.(*PodAttachOptions)) }) + scheme.AddTypeDefaultingFunc(&PodExecOptions{}, func(obj interface{}) { SetObjectDefaults_PodExecOptions(obj.(*PodExecOptions)) }) + scheme.AddTypeDefaultingFunc(&PodList{}, func(obj interface{}) { SetObjectDefaults_PodList(obj.(*PodList)) }) + scheme.AddTypeDefaultingFunc(&PodTemplate{}, func(obj interface{}) { SetObjectDefaults_PodTemplate(obj.(*PodTemplate)) }) + scheme.AddTypeDefaultingFunc(&PodTemplateList{}, func(obj interface{}) { SetObjectDefaults_PodTemplateList(obj.(*PodTemplateList)) }) + scheme.AddTypeDefaultingFunc(&ReplicationController{}, func(obj interface{}) { SetObjectDefaults_ReplicationController(obj.(*ReplicationController)) }) + scheme.AddTypeDefaultingFunc(&ReplicationControllerList{}, func(obj interface{}) { SetObjectDefaults_ReplicationControllerList(obj.(*ReplicationControllerList)) }) + scheme.AddTypeDefaultingFunc(&ResourceQuota{}, func(obj interface{}) { SetObjectDefaults_ResourceQuota(obj.(*ResourceQuota)) }) + scheme.AddTypeDefaultingFunc(&ResourceQuotaList{}, func(obj interface{}) { SetObjectDefaults_ResourceQuotaList(obj.(*ResourceQuotaList)) }) + scheme.AddTypeDefaultingFunc(&Secret{}, func(obj interface{}) { SetObjectDefaults_Secret(obj.(*Secret)) }) + scheme.AddTypeDefaultingFunc(&SecretList{}, func(obj interface{}) { SetObjectDefaults_SecretList(obj.(*SecretList)) }) + scheme.AddTypeDefaultingFunc(&Service{}, func(obj interface{}) { SetObjectDefaults_Service(obj.(*Service)) }) + scheme.AddTypeDefaultingFunc(&ServiceList{}, func(obj interface{}) { SetObjectDefaults_ServiceList(obj.(*ServiceList)) }) + return nil +} + +func SetObjectDefaults_ConfigMap(in *ConfigMap) { + SetDefaults_ConfigMap(in) +} + +func SetObjectDefaults_ConfigMapList(in *ConfigMapList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ConfigMap(a) + } +} + +func SetObjectDefaults_Endpoints(in *Endpoints) { + SetDefaults_Endpoints(in) +} + +func SetObjectDefaults_EndpointsList(in *EndpointsList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Endpoints(a) + } +} + +func SetObjectDefaults_LimitRange(in *LimitRange) { + for i := range in.Spec.Limits { + a := &in.Spec.Limits[i] + SetDefaults_LimitRangeItem(a) + SetDefaults_ResourceList(&a.Max) + SetDefaults_ResourceList(&a.Min) + SetDefaults_ResourceList(&a.Default) + SetDefaults_ResourceList(&a.DefaultRequest) + SetDefaults_ResourceList(&a.MaxLimitRequestRatio) + } +} + +func SetObjectDefaults_LimitRangeList(in *LimitRangeList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_LimitRange(a) + } +} + +func SetObjectDefaults_Namespace(in *Namespace) { + SetDefaults_NamespaceStatus(&in.Status) +} + +func SetObjectDefaults_NamespaceList(in *NamespaceList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Namespace(a) + } +} + +func SetObjectDefaults_Node(in *Node) { + SetDefaults_Node(in) + SetDefaults_NodeStatus(&in.Status) + SetDefaults_ResourceList(&in.Status.Capacity) + SetDefaults_ResourceList(&in.Status.Allocatable) +} + +func SetObjectDefaults_NodeList(in *NodeList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Node(a) + } +} + +func SetObjectDefaults_PersistentVolume(in *PersistentVolume) { + SetDefaults_PersistentVolume(in) + SetDefaults_ResourceList(&in.Spec.Capacity) + if in.Spec.PersistentVolumeSource.RBD != nil { + SetDefaults_RBDVolumeSource(in.Spec.PersistentVolumeSource.RBD) + } + if in.Spec.PersistentVolumeSource.ISCSI != nil { + SetDefaults_ISCSIVolumeSource(in.Spec.PersistentVolumeSource.ISCSI) + } + if in.Spec.PersistentVolumeSource.AzureDisk != nil { + SetDefaults_AzureDiskVolumeSource(in.Spec.PersistentVolumeSource.AzureDisk) + } +} + +func SetObjectDefaults_PersistentVolumeClaim(in *PersistentVolumeClaim) { + SetDefaults_PersistentVolumeClaim(in) + SetDefaults_ResourceList(&in.Spec.Resources.Limits) + SetDefaults_ResourceList(&in.Spec.Resources.Requests) + SetDefaults_ResourceList(&in.Status.Capacity) +} + +func SetObjectDefaults_PersistentVolumeClaimList(in *PersistentVolumeClaimList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_PersistentVolumeClaim(a) + } +} + +func SetObjectDefaults_PersistentVolumeList(in *PersistentVolumeList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_PersistentVolume(a) + } +} + +func SetObjectDefaults_Pod(in *Pod) { + SetDefaults_Pod(in) + SetDefaults_PodSpec(&in.Spec) + for i := range in.Spec.Volumes { + a := &in.Spec.Volumes[i] + SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.InitContainers { + a := &in.Spec.InitContainers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Containers { + a := &in.Spec.Containers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_PodAttachOptions(in *PodAttachOptions) { + SetDefaults_PodAttachOptions(in) +} + +func SetObjectDefaults_PodExecOptions(in *PodExecOptions) { + SetDefaults_PodExecOptions(in) +} + +func SetObjectDefaults_PodList(in *PodList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Pod(a) + } +} + +func SetObjectDefaults_PodTemplate(in *PodTemplate) { + SetDefaults_PodSpec(&in.Template.Spec) + for i := range in.Template.Spec.Volumes { + a := &in.Template.Spec.Volumes[i] + SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Template.Spec.InitContainers { + a := &in.Template.Spec.InitContainers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Template.Spec.Containers { + a := &in.Template.Spec.Containers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_PodTemplateList(in *PodTemplateList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_PodTemplate(a) + } +} + +func SetObjectDefaults_ReplicationController(in *ReplicationController) { + SetDefaults_ReplicationController(in) + if in.Spec.Template != nil { + SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + SetDefaults_ResourceList(&a.Resources.Limits) + SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + } +} + +func SetObjectDefaults_ReplicationControllerList(in *ReplicationControllerList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ReplicationController(a) + } +} + +func SetObjectDefaults_ResourceQuota(in *ResourceQuota) { + SetDefaults_ResourceList(&in.Spec.Hard) + SetDefaults_ResourceList(&in.Status.Hard) + SetDefaults_ResourceList(&in.Status.Used) +} + +func SetObjectDefaults_ResourceQuotaList(in *ResourceQuotaList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ResourceQuota(a) + } +} + +func SetObjectDefaults_Secret(in *Secret) { + SetDefaults_Secret(in) +} + +func SetObjectDefaults_SecretList(in *SecretList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Secret(a) + } +} + +func SetObjectDefaults_Service(in *Service) { + SetDefaults_ServiceSpec(&in.Spec) +} + +func SetObjectDefaults_ServiceList(in *ServiceList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Service(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/api/validation/path/name.go b/vendor/k8s.io/client-go/pkg/api/validation/path/name.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/api/validation/path/name.go rename to vendor/k8s.io/client-go/pkg/api/validation/path/name.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/api/zz_generated.deepcopy.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/api/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/api/zz_generated.deepcopy.go index 03a3a9a..446da1b 100644 --- a/vendor/k8s.io/kubernetes/pkg/api/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/api/zz_generated.deepcopy.go @@ -21,12 +21,12 @@ limitations under the License. package api import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - fields "k8s.io/kubernetes/pkg/fields" - labels "k8s.io/kubernetes/pkg/labels" - runtime "k8s.io/kubernetes/pkg/runtime" - types "k8s.io/kubernetes/pkg/types" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + fields "k8s.io/client-go/pkg/fields" + labels "k8s.io/client-go/pkg/labels" + runtime "k8s.io/client-go/pkg/runtime" + types "k8s.io/client-go/pkg/types" reflect "reflect" ) @@ -2977,7 +2977,6 @@ func DeepCopy_api_ReplicationControllerCondition(in interface{}, out interface{} out := out.(*ReplicationControllerCondition) out.Type = in.Type out.Status = in.Status - out.LastProbeTime = in.LastProbeTime.DeepCopy() out.LastTransitionTime = in.LastTransitionTime.DeepCopy() out.Reason = in.Reason out.Message = in.Message diff --git a/vendor/k8s.io/kubernetes/pkg/apimachinery/announced/announced.go b/vendor/k8s.io/client-go/pkg/apimachinery/announced/announced.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apimachinery/announced/announced.go rename to vendor/k8s.io/client-go/pkg/apimachinery/announced/announced.go index bb1982a..90bc100 100644 --- a/vendor/k8s.io/kubernetes/pkg/apimachinery/announced/announced.go +++ b/vendor/k8s.io/client-go/pkg/apimachinery/announced/announced.go @@ -24,8 +24,8 @@ package announced import ( "fmt" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/apimachinery/registered" + "k8s.io/client-go/pkg/runtime" ) var ( diff --git a/vendor/k8s.io/kubernetes/pkg/apimachinery/announced/group_factory.go b/vendor/k8s.io/client-go/pkg/apimachinery/announced/group_factory.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apimachinery/announced/group_factory.go rename to vendor/k8s.io/client-go/pkg/apimachinery/announced/group_factory.go index 75b22c0..9473ee5 100644 --- a/vendor/k8s.io/kubernetes/pkg/apimachinery/announced/group_factory.go +++ b/vendor/k8s.io/client-go/pkg/apimachinery/announced/group_factory.go @@ -21,13 +21,13 @@ import ( "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apimachinery" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/apimachinery" + "k8s.io/client-go/pkg/apimachinery/registered" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/sets" ) type SchemeFunc func(*runtime.Scheme) error diff --git a/vendor/k8s.io/kubernetes/pkg/apimachinery/doc.go b/vendor/k8s.io/client-go/pkg/apimachinery/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apimachinery/doc.go rename to vendor/k8s.io/client-go/pkg/apimachinery/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apimachinery/registered/registered.go b/vendor/k8s.io/client-go/pkg/apimachinery/registered/registered.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apimachinery/registered/registered.go rename to vendor/k8s.io/client-go/pkg/apimachinery/registered/registered.go index 5b61b4b..887980e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apimachinery/registered/registered.go +++ b/vendor/k8s.io/client-go/pkg/apimachinery/registered/registered.go @@ -25,10 +25,10 @@ import ( "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apimachinery" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/apimachinery" + "k8s.io/client-go/pkg/util/sets" ) var ( diff --git a/vendor/k8s.io/kubernetes/pkg/apimachinery/types.go b/vendor/k8s.io/client-go/pkg/apimachinery/types.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apimachinery/types.go rename to vendor/k8s.io/client-go/pkg/apimachinery/types.go index c914608..f520a15 100644 --- a/vendor/k8s.io/kubernetes/pkg/apimachinery/types.go +++ b/vendor/k8s.io/client-go/pkg/apimachinery/types.go @@ -19,9 +19,9 @@ package apimachinery import ( "fmt" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupMeta stores the metadata of a group. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/doc.go b/vendor/k8s.io/client-go/pkg/apis/apps/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/doc.go rename to vendor/k8s.io/client-go/pkg/apis/apps/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/install/install.go b/vendor/k8s.io/client-go/pkg/apis/apps/install/install.go similarity index 85% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/apps/install/install.go index fe6d2a0..8e9c1db 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/install/install.go @@ -19,9 +19,9 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/apis/apps/v1alpha1" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/apps" + "k8s.io/client-go/pkg/apis/apps/v1alpha1" ) func init() { @@ -29,7 +29,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: apps.GroupName, VersionPreferenceOrder: []string{v1alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/apps", + ImportPrefix: "k8s.io/client-go/pkg/apis/apps", AddInternalObjectsToScheme: apps.AddToScheme, }, announced.VersionToSchemeFunc{ diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/register.go b/vendor/k8s.io/client-go/pkg/apis/apps/register.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/register.go rename to vendor/k8s.io/client-go/pkg/apis/apps/register.go index 9864ffa..f791022 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/register.go @@ -17,9 +17,9 @@ limitations under the License. package apps import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) var ( @@ -47,8 +47,8 @@ func Resource(resource string) unversioned.GroupResource { func addKnownTypes(scheme *runtime.Scheme) error { // TODO this will get cleaned up with the scheme types are fixed scheme.AddKnownTypes(SchemeGroupVersion, - &PetSet{}, - &PetSetList{}, + &StatefulSet{}, + &StatefulSetList{}, &api.ListOptions{}, &api.DeleteOptions{}, ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/apps/types.generated.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/apps/types.generated.go index 6f0bf29..391d234 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg2_api "k8s.io/client-go/pkg/api" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -75,7 +75,7 @@ func init() { } } -func (x *PetSet) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSet) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -220,7 +220,7 @@ func (x *PetSet) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSet) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSet) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -250,7 +250,7 @@ func (x *PetSet) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -293,14 +293,14 @@ func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } case "spec": if r.TryDecodeAsNil() { - x.Spec = PetSetSpec{} + x.Spec = StatefulSetSpec{} } else { yyv24 := &x.Spec yyv24.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { - x.Status = PetSetStatus{} + x.Status = StatefulSetStatus{} } else { yyv25 := &x.Status yyv25.CodecDecodeSelf(d) @@ -312,7 +312,7 @@ func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -380,7 +380,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Spec = PetSetSpec{} + x.Spec = StatefulSetSpec{} } else { yyv30 := &x.Spec yyv30.CodecDecodeSelf(d) @@ -397,7 +397,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Status = PetSetStatus{} + x.Status = StatefulSetStatus{} } else { yyv31 := &x.Status yyv31.CodecDecodeSelf(d) @@ -418,7 +418,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -583,7 +583,7 @@ func (x *PetSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -613,7 +613,7 @@ func (x *PetSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -690,7 +690,7 @@ func (x *PetSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -811,7 +811,7 @@ func (x *PetSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -905,7 +905,7 @@ func (x *PetSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -935,7 +935,7 @@ func (x *PetSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -986,7 +986,7 @@ func (x *PetSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1051,7 +1051,7 @@ func (x *PetSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetList) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -1172,7 +1172,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { _ = yym101 if false { } else { - h.encSlicePetSet(([]PetSet)(x.Items), e) + h.encSliceStatefulSet(([]StatefulSet)(x.Items), e) } } } else { @@ -1186,7 +1186,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { _ = yym102 if false { } else { - h.encSlicePetSet(([]PetSet)(x.Items), e) + h.encSliceStatefulSet(([]StatefulSet)(x.Items), e) } } } @@ -1199,7 +1199,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetList) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1229,7 +1229,7 @@ func (x *PetSetList) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1285,7 +1285,7 @@ func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { _ = yym111 if false { } else { - h.decSlicePetSet((*[]PetSet)(yyv110), d) + h.decSliceStatefulSet((*[]StatefulSet)(yyv110), d) } } default: @@ -1295,7 +1295,7 @@ func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1376,7 +1376,7 @@ func (x *PetSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { _ = yym118 if false { } else { - h.decSlicePetSet((*[]PetSet)(yyv117), d) + h.decSliceStatefulSet((*[]StatefulSet)(yyv117), d) } } for { @@ -1511,7 +1511,7 @@ func (x codecSelfer1234) decSliceapi_PersistentVolumeClaim(v *[]pkg2_api.Persist } } -func (x codecSelfer1234) encSlicePetSet(v []PetSet, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceStatefulSet(v []StatefulSet, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -1524,7 +1524,7 @@ func (x codecSelfer1234) encSlicePetSet(v []PetSet, e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceStatefulSet(v *[]StatefulSet, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1534,7 +1534,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { var yyc127 bool if yyl127 == 0 { if yyv127 == nil { - yyv127 = []PetSet{} + yyv127 = []StatefulSet{} yyc127 = true } else if len(yyv127) != 0 { yyv127 = yyv127[:0] @@ -1552,10 +1552,10 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { if yyrl127 <= cap(yyv127) { yyv127 = yyv127[:yyrl127] } else { - yyv127 = make([]PetSet, yyrl127) + yyv127 = make([]StatefulSet, yyrl127) } } else { - yyv127 = make([]PetSet, yyrl127) + yyv127 = make([]StatefulSet, yyrl127) } yyc127 = true yyrr127 = len(yyv127) @@ -1570,7 +1570,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { for ; yyj127 < yyrr127; yyj127++ { yyh127.ElemContainerState(yyj127) if r.TryDecodeAsNil() { - yyv127[yyj127] = PetSet{} + yyv127[yyj127] = StatefulSet{} } else { yyv128 := &yyv127[yyj127] yyv128.CodecDecodeSelf(d) @@ -1579,10 +1579,10 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { } if yyrt127 { for ; yyj127 < yyl127; yyj127++ { - yyv127 = append(yyv127, PetSet{}) + yyv127 = append(yyv127, StatefulSet{}) yyh127.ElemContainerState(yyj127) if r.TryDecodeAsNil() { - yyv127[yyj127] = PetSet{} + yyv127[yyj127] = StatefulSet{} } else { yyv129 := &yyv127[yyj127] yyv129.CodecDecodeSelf(d) @@ -1596,13 +1596,13 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { for ; !r.CheckBreak(); yyj127++ { if yyj127 >= len(yyv127) { - yyv127 = append(yyv127, PetSet{}) // var yyz127 PetSet + yyv127 = append(yyv127, StatefulSet{}) // var yyz127 StatefulSet yyc127 = true } yyh127.ElemContainerState(yyj127) if yyj127 < len(yyv127) { if r.TryDecodeAsNil() { - yyv127[yyj127] = PetSet{} + yyv127[yyj127] = StatefulSet{} } else { yyv130 := &yyv127[yyj127] yyv130.CodecDecodeSelf(d) @@ -1617,7 +1617,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { yyv127 = yyv127[:yyj127] yyc127 = true } else if yyj127 == 0 && yyv127 == nil { - yyv127 = []PetSet{} + yyv127 = []StatefulSet{} yyc127 = true } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/types.go b/vendor/k8s.io/client-go/pkg/apis/apps/types.go similarity index 60% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/types.go rename to vendor/k8s.io/client-go/pkg/apis/apps/types.go index 466273b..8e3736b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/types.go @@ -17,80 +17,88 @@ limitations under the License. package apps import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // +genclient=true -// PetSet represents a set of pods with consistent identities. +// StatefulSet represents a set of pods with consistent identities. // Identities are defined as: // - Network: A single stable DNS and hostname. // - Storage: As many VolumeClaims as requested. -// The PetSet guarantees that a given network identity will always -// map to the same storage identity. PetSet is currently in alpha and +// The StatefulSet guarantees that a given network identity will always +// map to the same storage identity. StatefulSet is currently in alpha and // and subject to change without notice. -type PetSet struct { +type StatefulSet struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` - // Spec defines the desired identities of pets in this set. - Spec PetSetSpec `json:"spec,omitempty"` + // Spec defines the desired identities of pods in this set. + // +optional + Spec StatefulSetSpec `json:"spec,omitempty"` - // Status is the current status of Pets in this PetSet. This data + // Status is the current status of Pods in this StatefulSet. This data // may be out of date by some window of time. - Status PetSetStatus `json:"status,omitempty"` + // +optional + Status StatefulSetStatus `json:"status,omitempty"` } -// A PetSetSpec is the specification of a PetSet. -type PetSetSpec struct { +// A StatefulSetSpec is the specification of a StatefulSet. +type StatefulSetSpec struct { // Replicas is the desired number of replicas of the given Template. // These are replicas in the sense that they are instantiations of the // same Template, but individual replicas also have a consistent identity. // If unspecified, defaults to 1. // TODO: Consider a rename of this field. + // +optional Replicas int32 `json:"replicas,omitempty"` // Selector is a label query over pods that should match the replica count. // If empty, defaulted to labels on the pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // Template is the object that describes the pod that will be created if - // insufficient replicas are detected. Each pod stamped out by the PetSet + // insufficient replicas are detected. Each pod stamped out by the StatefulSet // will fulfill this Template, but have a unique identity from the rest - // of the PetSet. + // of the StatefulSet. Template api.PodTemplateSpec `json:"template"` - // VolumeClaimTemplates is a list of claims that pets are allowed to reference. - // The PetSet controller is responsible for mapping network identities to - // claims in a way that maintains the identity of a pet. Every claim in + // VolumeClaimTemplates is a list of claims that pods are allowed to reference. + // The StatefulSet controller is responsible for mapping network identities to + // claims in a way that maintains the identity of a pod. Every claim in // this list must have at least one matching (by name) volumeMount in one // container in the template. A claim in this list takes precedence over // any volumes in the template, with the same name. // TODO: Define the behavior if a claim already exists with the same name. + // +optional VolumeClaimTemplates []api.PersistentVolumeClaim `json:"volumeClaimTemplates,omitempty"` - // ServiceName is the name of the service that governs this PetSet. - // This service must exist before the PetSet, and is responsible for - // the network identity of the set. Pets get DNS/hostnames that follow the - // pattern: pet-specific-string.serviceName.default.svc.cluster.local - // where "pet-specific-string" is managed by the PetSet controller. + // ServiceName is the name of the service that governs this StatefulSet. + // This service must exist before the StatefulSet, and is responsible for + // the network identity of the set. Pods get DNS/hostnames that follow the + // pattern: pod-specific-string.serviceName.default.svc.cluster.local + // where "pod-specific-string" is managed by the StatefulSet controller. ServiceName string `json:"serviceName"` } -// PetSetStatus represents the current state of a PetSet. -type PetSetStatus struct { +// StatefulSetStatus represents the current state of a StatefulSet. +type StatefulSetStatus struct { // most recent generation observed by this autoscaler. + // +optional ObservedGeneration *int64 `json:"observedGeneration,omitempty"` // Replicas is the number of actual replicas. Replicas int32 `json:"replicas"` } -// PetSetList is a collection of PetSets. -type PetSetList struct { +// StatefulSetList is a collection of StatefulSets. +type StatefulSetList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` - Items []PetSet `json:"items"` + Items []StatefulSet `json:"items"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/conversion.go similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/conversion.go index 54a70a8..269bdde 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/conversion.go @@ -19,12 +19,12 @@ package v1alpha1 import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/apis/apps" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { @@ -33,14 +33,14 @@ func addConversionFuncs(scheme *runtime.Scheme) error { // it, but a plain int32 is more convenient in the internal type. These // functions are the same as the autogenerated ones in every other way. err := scheme.AddConversionFuncs( - Convert_v1alpha1_PetSetSpec_To_apps_PetSetSpec, - Convert_apps_PetSetSpec_To_v1alpha1_PetSetSpec, + Convert_v1alpha1_StatefulSetSpec_To_apps_StatefulSetSpec, + Convert_apps_StatefulSetSpec_To_v1alpha1_StatefulSetSpec, ) if err != nil { return err } - return api.Scheme.AddFieldLabelConversionFunc("apps/v1alpha1", "PetSet", + return api.Scheme.AddFieldLabelConversionFunc("apps/v1alpha1", "StatefulSet", func(label, value string) (string, string, error) { switch label { case "metadata.name", "metadata.namespace", "status.successful": @@ -52,7 +52,7 @@ func addConversionFuncs(scheme *runtime.Scheme) error { ) } -func Convert_v1alpha1_PetSetSpec_To_apps_PetSetSpec(in *PetSetSpec, out *apps.PetSetSpec, s conversion.Scope) error { +func Convert_v1alpha1_StatefulSetSpec_To_apps_StatefulSetSpec(in *StatefulSetSpec, out *apps.StatefulSetSpec, s conversion.Scope) error { if in.Replicas != nil { out.Replicas = *in.Replicas } @@ -83,7 +83,7 @@ func Convert_v1alpha1_PetSetSpec_To_apps_PetSetSpec(in *PetSetSpec, out *apps.Pe return nil } -func Convert_apps_PetSetSpec_To_v1alpha1_PetSetSpec(in *apps.PetSetSpec, out *PetSetSpec, s conversion.Scope) error { +func Convert_apps_StatefulSetSpec_To_v1alpha1_StatefulSetSpec(in *apps.StatefulSetSpec, out *StatefulSetSpec, s conversion.Scope) error { out.Replicas = new(int32) *out.Replicas = in.Replicas if in.Selector != nil { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/defaults.go similarity index 85% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/defaults.go index 63a02c9..6c7d1c3 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/defaults.go @@ -17,17 +17,18 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( - SetDefaults_PetSet, + SetDefaults_StatefulSet, ) } -func SetDefaults_PetSet(obj *PetSet) { +func SetDefaults_StatefulSet(obj *StatefulSet) { labels := obj.Spec.Template.Labels if labels != nil { if obj.Spec.Selector == nil { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/doc.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/doc.go index 5e6926d..66a7b01 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/doc.go @@ -17,5 +17,6 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/apps // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.pb.go similarity index 73% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.pb.go index 7c8e305..1b00aa7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.pb.go @@ -25,10 +25,10 @@ limitations under the License. k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.proto It has these top-level messages: - PetSet - PetSetList - PetSetSpec - PetSetStatus + StatefulSet + StatefulSetList + StatefulSetSpec + StatefulSetStatus */ package v1alpha1 @@ -36,8 +36,8 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_api_v1 "k8s.io/kubernetes/pkg/api/v1" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_v1 "k8s.io/client-go/pkg/api/v1" import strings "strings" import reflect "reflect" @@ -53,29 +53,29 @@ var _ = math.Inf // is compatible with the proto package it is being compiled against. const _ = proto.GoGoProtoPackageIsVersion1 -func (m *PetSet) Reset() { *m = PetSet{} } -func (*PetSet) ProtoMessage() {} -func (*PetSet) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{0} } +func (m *StatefulSet) Reset() { *m = StatefulSet{} } +func (*StatefulSet) ProtoMessage() {} +func (*StatefulSet) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{0} } -func (m *PetSetList) Reset() { *m = PetSetList{} } -func (*PetSetList) ProtoMessage() {} -func (*PetSetList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{1} } +func (m *StatefulSetList) Reset() { *m = StatefulSetList{} } +func (*StatefulSetList) ProtoMessage() {} +func (*StatefulSetList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{1} } -func (m *PetSetSpec) Reset() { *m = PetSetSpec{} } -func (*PetSetSpec) ProtoMessage() {} -func (*PetSetSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{2} } +func (m *StatefulSetSpec) Reset() { *m = StatefulSetSpec{} } +func (*StatefulSetSpec) ProtoMessage() {} +func (*StatefulSetSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{2} } -func (m *PetSetStatus) Reset() { *m = PetSetStatus{} } -func (*PetSetStatus) ProtoMessage() {} -func (*PetSetStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{3} } +func (m *StatefulSetStatus) Reset() { *m = StatefulSetStatus{} } +func (*StatefulSetStatus) ProtoMessage() {} +func (*StatefulSetStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{3} } func init() { - proto.RegisterType((*PetSet)(nil), "k8s.io.kubernetes.pkg.apis.apps.v1alpha1.PetSet") - proto.RegisterType((*PetSetList)(nil), "k8s.io.kubernetes.pkg.apis.apps.v1alpha1.PetSetList") - proto.RegisterType((*PetSetSpec)(nil), "k8s.io.kubernetes.pkg.apis.apps.v1alpha1.PetSetSpec") - proto.RegisterType((*PetSetStatus)(nil), "k8s.io.kubernetes.pkg.apis.apps.v1alpha1.PetSetStatus") + proto.RegisterType((*StatefulSet)(nil), "k8s.io.client-go.pkg.apis.apps.v1alpha1.StatefulSet") + proto.RegisterType((*StatefulSetList)(nil), "k8s.io.client-go.pkg.apis.apps.v1alpha1.StatefulSetList") + proto.RegisterType((*StatefulSetSpec)(nil), "k8s.io.client-go.pkg.apis.apps.v1alpha1.StatefulSetSpec") + proto.RegisterType((*StatefulSetStatus)(nil), "k8s.io.client-go.pkg.apis.apps.v1alpha1.StatefulSetStatus") } -func (m *PetSet) Marshal() (data []byte, err error) { +func (m *StatefulSet) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) n, err := m.MarshalTo(data) @@ -85,7 +85,7 @@ func (m *PetSet) Marshal() (data []byte, err error) { return data[:n], nil } -func (m *PetSet) MarshalTo(data []byte) (int, error) { +func (m *StatefulSet) MarshalTo(data []byte) (int, error) { var i int _ = i var l int @@ -117,7 +117,7 @@ func (m *PetSet) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *PetSetList) Marshal() (data []byte, err error) { +func (m *StatefulSetList) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) n, err := m.MarshalTo(data) @@ -127,7 +127,7 @@ func (m *PetSetList) Marshal() (data []byte, err error) { return data[:n], nil } -func (m *PetSetList) MarshalTo(data []byte) (int, error) { +func (m *StatefulSetList) MarshalTo(data []byte) (int, error) { var i int _ = i var l int @@ -155,7 +155,7 @@ func (m *PetSetList) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *PetSetSpec) Marshal() (data []byte, err error) { +func (m *StatefulSetSpec) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) n, err := m.MarshalTo(data) @@ -165,7 +165,7 @@ func (m *PetSetSpec) Marshal() (data []byte, err error) { return data[:n], nil } -func (m *PetSetSpec) MarshalTo(data []byte) (int, error) { +func (m *StatefulSetSpec) MarshalTo(data []byte) (int, error) { var i int _ = i var l int @@ -212,7 +212,7 @@ func (m *PetSetSpec) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *PetSetStatus) Marshal() (data []byte, err error) { +func (m *StatefulSetStatus) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) n, err := m.MarshalTo(data) @@ -222,7 +222,7 @@ func (m *PetSetStatus) Marshal() (data []byte, err error) { return data[:n], nil } -func (m *PetSetStatus) MarshalTo(data []byte) (int, error) { +func (m *StatefulSetStatus) MarshalTo(data []byte) (int, error) { var i int _ = i var l int @@ -265,7 +265,7 @@ func encodeVarintGenerated(data []byte, offset int, v uint64) int { data[offset] = uint8(v) return offset + 1 } -func (m *PetSet) Size() (n int) { +func (m *StatefulSet) Size() (n int) { var l int _ = l l = m.ObjectMeta.Size() @@ -277,7 +277,7 @@ func (m *PetSet) Size() (n int) { return n } -func (m *PetSetList) Size() (n int) { +func (m *StatefulSetList) Size() (n int) { var l int _ = l l = m.ListMeta.Size() @@ -291,7 +291,7 @@ func (m *PetSetList) Size() (n int) { return n } -func (m *PetSetSpec) Size() (n int) { +func (m *StatefulSetSpec) Size() (n int) { var l int _ = l if m.Replicas != nil { @@ -314,7 +314,7 @@ func (m *PetSetSpec) Size() (n int) { return n } -func (m *PetSetStatus) Size() (n int) { +func (m *StatefulSetStatus) Size() (n int) { var l int _ = l if m.ObservedGeneration != nil { @@ -337,34 +337,34 @@ func sovGenerated(x uint64) (n int) { func sozGenerated(x uint64) (n int) { return sovGenerated(uint64((x << 1) ^ uint64((int64(x) >> 63)))) } -func (this *PetSet) String() string { +func (this *StatefulSet) String() string { if this == nil { return "nil" } - s := strings.Join([]string{`&PetSet{`, + s := strings.Join([]string{`&StatefulSet{`, `ObjectMeta:` + strings.Replace(strings.Replace(this.ObjectMeta.String(), "ObjectMeta", "k8s_io_kubernetes_pkg_api_v1.ObjectMeta", 1), `&`, ``, 1) + `,`, - `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "PetSetSpec", "PetSetSpec", 1), `&`, ``, 1) + `,`, - `Status:` + strings.Replace(strings.Replace(this.Status.String(), "PetSetStatus", "PetSetStatus", 1), `&`, ``, 1) + `,`, + `Spec:` + strings.Replace(strings.Replace(this.Spec.String(), "StatefulSetSpec", "StatefulSetSpec", 1), `&`, ``, 1) + `,`, + `Status:` + strings.Replace(strings.Replace(this.Status.String(), "StatefulSetStatus", "StatefulSetStatus", 1), `&`, ``, 1) + `,`, `}`, }, "") return s } -func (this *PetSetList) String() string { +func (this *StatefulSetList) String() string { if this == nil { return "nil" } - s := strings.Join([]string{`&PetSetList{`, + s := strings.Join([]string{`&StatefulSetList{`, `ListMeta:` + strings.Replace(strings.Replace(this.ListMeta.String(), "ListMeta", "k8s_io_kubernetes_pkg_api_unversioned.ListMeta", 1), `&`, ``, 1) + `,`, - `Items:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Items), "PetSet", "PetSet", 1), `&`, ``, 1) + `,`, + `Items:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Items), "StatefulSet", "StatefulSet", 1), `&`, ``, 1) + `,`, `}`, }, "") return s } -func (this *PetSetSpec) String() string { +func (this *StatefulSetSpec) String() string { if this == nil { return "nil" } - s := strings.Join([]string{`&PetSetSpec{`, + s := strings.Join([]string{`&StatefulSetSpec{`, `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, @@ -374,11 +374,11 @@ func (this *PetSetSpec) String() string { }, "") return s } -func (this *PetSetStatus) String() string { +func (this *StatefulSetStatus) String() string { if this == nil { return "nil" } - s := strings.Join([]string{`&PetSetStatus{`, + s := strings.Join([]string{`&StatefulSetStatus{`, `ObservedGeneration:` + valueToStringGenerated(this.ObservedGeneration) + `,`, `Replicas:` + fmt.Sprintf("%v", this.Replicas) + `,`, `}`, @@ -393,7 +393,7 @@ func valueToStringGenerated(v interface{}) string { pv := reflect.Indirect(rv).Interface() return fmt.Sprintf("*%v", pv) } -func (m *PetSet) Unmarshal(data []byte) error { +func (m *StatefulSet) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 for iNdEx < l { @@ -416,10 +416,10 @@ func (m *PetSet) Unmarshal(data []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: PetSet: wiretype end group for non-group") + return fmt.Errorf("proto: StatefulSet: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: PetSet: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: StatefulSet: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -533,7 +533,7 @@ func (m *PetSet) Unmarshal(data []byte) error { } return nil } -func (m *PetSetList) Unmarshal(data []byte) error { +func (m *StatefulSetList) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 for iNdEx < l { @@ -556,10 +556,10 @@ func (m *PetSetList) Unmarshal(data []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: PetSetList: wiretype end group for non-group") + return fmt.Errorf("proto: StatefulSetList: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: PetSetList: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: StatefulSetList: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -618,7 +618,7 @@ func (m *PetSetList) Unmarshal(data []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.Items = append(m.Items, PetSet{}) + m.Items = append(m.Items, StatefulSet{}) if err := m.Items[len(m.Items)-1].Unmarshal(data[iNdEx:postIndex]); err != nil { return err } @@ -644,7 +644,7 @@ func (m *PetSetList) Unmarshal(data []byte) error { } return nil } -func (m *PetSetSpec) Unmarshal(data []byte) error { +func (m *StatefulSetSpec) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 for iNdEx < l { @@ -667,10 +667,10 @@ func (m *PetSetSpec) Unmarshal(data []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: PetSetSpec: wiretype end group for non-group") + return fmt.Errorf("proto: StatefulSetSpec: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: PetSetSpec: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: StatefulSetSpec: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -837,7 +837,7 @@ func (m *PetSetSpec) Unmarshal(data []byte) error { } return nil } -func (m *PetSetStatus) Unmarshal(data []byte) error { +func (m *StatefulSetStatus) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 for iNdEx < l { @@ -860,10 +860,10 @@ func (m *PetSetStatus) Unmarshal(data []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: PetSetStatus: wiretype end group for non-group") + return fmt.Errorf("proto: StatefulSetStatus: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: PetSetStatus: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: StatefulSetStatus: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -1032,44 +1032,45 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 611 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x94, 0x93, 0x4f, 0x6f, 0xd3, 0x4c, - 0x10, 0xc6, 0xeb, 0xa6, 0xa9, 0xfc, 0x6e, 0xf3, 0x22, 0xb4, 0x54, 0x28, 0x8a, 0x50, 0x8a, 0x72, - 0x8a, 0x50, 0xb3, 0x26, 0x85, 0xa2, 0x9e, 0x8d, 0x04, 0x42, 0x02, 0x5a, 0x39, 0x10, 0x21, 0x10, - 0x48, 0x6b, 0x67, 0x48, 0x97, 0xd8, 0x5e, 0xcb, 0xbb, 0xce, 0x99, 0x03, 0xdc, 0x39, 0xf3, 0x31, - 0xf8, 0x08, 0x9c, 0x72, 0xec, 0x91, 0x53, 0x05, 0xe5, 0x8b, 0xb0, 0x5e, 0xff, 0x49, 0xa8, 0x93, - 0x96, 0x1e, 0x36, 0xca, 0xee, 0xce, 0xf3, 0xdb, 0x99, 0x67, 0xc6, 0xe8, 0x60, 0x72, 0x20, 0x08, - 0xe3, 0xd6, 0x24, 0x71, 0x21, 0x0e, 0x41, 0x82, 0xb0, 0xa2, 0xc9, 0xd8, 0xa2, 0x11, 0x13, 0xea, - 0x27, 0x12, 0xd6, 0xb4, 0x4f, 0xfd, 0xe8, 0x98, 0xf6, 0xad, 0x31, 0x84, 0x10, 0x53, 0x09, 0x23, - 0x12, 0xc5, 0x5c, 0x72, 0xdc, 0xcd, 0x94, 0x64, 0xae, 0x24, 0x4a, 0x49, 0x52, 0x25, 0x49, 0x95, - 0xa4, 0x50, 0xb6, 0x7a, 0x63, 0x26, 0x8f, 0x13, 0x97, 0x78, 0x3c, 0xb0, 0xc6, 0x7c, 0xcc, 0x2d, - 0x0d, 0x70, 0x93, 0xf7, 0x7a, 0xa7, 0x37, 0xfa, 0x5f, 0x06, 0x6e, 0xed, 0xad, 0x4c, 0xc9, 0x8a, - 0x41, 0xf0, 0x24, 0xf6, 0xe0, 0x7c, 0x32, 0xad, 0xfd, 0xd5, 0x9a, 0x24, 0x9c, 0x42, 0x2c, 0x18, - 0x0f, 0x61, 0x54, 0x91, 0xed, 0xae, 0x96, 0x4d, 0x2b, 0x15, 0xb7, 0x7a, 0xcb, 0xa3, 0xe3, 0x24, - 0x94, 0x2c, 0xa8, 0xe6, 0xd4, 0x5f, 0x1e, 0x9e, 0x48, 0xe6, 0x5b, 0x2c, 0x94, 0x42, 0xc6, 0xe7, - 0x25, 0x9d, 0xaf, 0xeb, 0x68, 0xf3, 0x08, 0xe4, 0x00, 0x24, 0x7e, 0x85, 0xcc, 0x00, 0x24, 0x1d, - 0x51, 0x49, 0x9b, 0xc6, 0x6d, 0xa3, 0xbb, 0xb5, 0xd7, 0x25, 0x2b, 0x1d, 0x57, 0x5e, 0x93, 0x43, - 0xf7, 0x03, 0x78, 0xf2, 0x99, 0xd2, 0xd8, 0x78, 0x76, 0xba, 0xb3, 0x76, 0x76, 0xba, 0x83, 0xe6, - 0x67, 0x4e, 0x49, 0xc3, 0x43, 0xb4, 0x21, 0x22, 0xf0, 0x9a, 0xeb, 0x9a, 0x7a, 0x9f, 0xfc, 0x6b, - 0x1f, 0x49, 0x96, 0xd9, 0x40, 0x69, 0xed, 0x46, 0xfe, 0xc2, 0x46, 0xba, 0x73, 0x34, 0x0f, 0xbf, - 0x43, 0x9b, 0x42, 0x52, 0x99, 0x88, 0x66, 0x4d, 0x93, 0x1f, 0x5c, 0x99, 0xac, 0xd5, 0xf6, 0xb5, - 0x9c, 0xbd, 0x99, 0xed, 0x9d, 0x9c, 0xda, 0xf9, 0x6e, 0x20, 0x94, 0x05, 0x3e, 0x65, 0x42, 0xe2, - 0xb7, 0x15, 0x83, 0xac, 0x0b, 0x0c, 0x5a, 0x98, 0x02, 0x92, 0xca, 0xb5, 0x4f, 0xd7, 0xf3, 0x97, - 0xcc, 0xe2, 0x64, 0xc1, 0xa5, 0x97, 0xa8, 0xce, 0x24, 0x04, 0x42, 0xd9, 0x54, 0x53, 0xec, 0xbb, - 0x57, 0x2d, 0xc6, 0xfe, 0x3f, 0x87, 0xd7, 0x9f, 0xa4, 0x18, 0x27, 0xa3, 0x75, 0xbe, 0xd5, 0x8a, - 0x22, 0x52, 0xe7, 0x70, 0x17, 0x99, 0x31, 0x44, 0x3e, 0xf3, 0xa8, 0xd0, 0x45, 0xd4, 0xed, 0x46, - 0x9a, 0x8f, 0x93, 0x9f, 0x39, 0xe5, 0xad, 0x72, 0xd7, 0x14, 0xe0, 0xab, 0x6e, 0xf2, 0xf8, 0xf2, - 0xce, 0xfd, 0x5d, 0x2e, 0x75, 0xc1, 0x1f, 0xe4, 0xda, 0x8c, 0x5f, 0xec, 0x9c, 0x92, 0x89, 0xdf, - 0x20, 0x53, 0x25, 0x18, 0xf9, 0x6a, 0x1a, 0xf3, 0xfe, 0xf5, 0x2e, 0x9e, 0xb7, 0x23, 0x3e, 0x7a, - 0x91, 0x0b, 0xf4, 0x48, 0x94, 0x66, 0x16, 0xa7, 0x4e, 0x09, 0xc4, 0x9f, 0x0d, 0xb4, 0x3d, 0xe5, - 0x7e, 0x12, 0xc0, 0x43, 0x9f, 0xb2, 0xa0, 0x88, 0x10, 0xcd, 0x0d, 0x6d, 0xee, 0xbd, 0x4b, 0x5e, - 0x4a, 0x4b, 0x11, 0x12, 0x42, 0x39, 0x9c, 0x33, 0xec, 0x5b, 0xf9, 0x7b, 0xdb, 0xc3, 0x25, 0x60, - 0x67, 0xe9, 0x73, 0x78, 0x1f, 0x6d, 0x09, 0x88, 0xa7, 0xcc, 0x83, 0xe7, 0x34, 0x80, 0x66, 0x5d, - 0xd5, 0xf9, 0x9f, 0x7d, 0x23, 0x07, 0x6d, 0x0d, 0xe6, 0x57, 0xce, 0x62, 0x5c, 0xe7, 0x93, 0x81, - 0x1a, 0x8b, 0x23, 0x8a, 0x1f, 0x21, 0xcc, 0xdd, 0x34, 0x02, 0x46, 0x8f, 0xb3, 0x4f, 0x58, 0x59, - 0xad, 0x1b, 0x58, 0xb3, 0x6f, 0x2a, 0x14, 0x3e, 0xac, 0xdc, 0x3a, 0x4b, 0x14, 0x78, 0x77, 0xa1, - 0xfd, 0xeb, 0xba, 0xfd, 0xa5, 0x8b, 0xd5, 0x11, 0xb0, 0xef, 0xcc, 0x7e, 0xb5, 0xd7, 0x4e, 0xd4, - 0xfa, 0xa1, 0xd6, 0xc7, 0xb3, 0xb6, 0x31, 0x53, 0xeb, 0x44, 0xad, 0x9f, 0x6a, 0x7d, 0xf9, 0xdd, - 0x5e, 0x7b, 0x6d, 0x16, 0x43, 0xf8, 0x27, 0x00, 0x00, 0xff, 0xff, 0x14, 0xcf, 0x45, 0x01, 0xd8, - 0x05, 0x00, 0x00, + // 628 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x9c, 0x93, 0xcd, 0x6e, 0xd3, 0x40, + 0x10, 0xc7, 0xe3, 0xa4, 0xa9, 0xc2, 0xa6, 0x7c, 0x2d, 0x15, 0x8a, 0x22, 0xe4, 0x56, 0x39, 0x45, + 0xa8, 0x5d, 0x2b, 0x85, 0x4a, 0x45, 0xdc, 0x8c, 0x04, 0x42, 0x02, 0x8a, 0x1c, 0x54, 0xa1, 0x56, + 0x20, 0x6d, 0x9c, 0x69, 0xba, 0xc4, 0xf6, 0x5a, 0xde, 0x71, 0xce, 0x5c, 0x38, 0x70, 0xe3, 0x35, + 0x78, 0x02, 0x5e, 0xa1, 0x07, 0x0e, 0x3d, 0x72, 0xaa, 0x48, 0x78, 0x11, 0xe4, 0xcd, 0xe6, 0x83, + 0x3a, 0x29, 0x55, 0x6f, 0x9e, 0xdd, 0xf9, 0xff, 0x66, 0xe6, 0xbf, 0x63, 0xb2, 0xd7, 0xdf, 0x53, + 0x4c, 0x48, 0xa7, 0x9f, 0x76, 0x20, 0x89, 0x00, 0x41, 0x39, 0x71, 0xbf, 0xe7, 0xf0, 0x58, 0x28, + 0x87, 0xc7, 0xb1, 0x72, 0x06, 0x2d, 0x1e, 0xc4, 0x27, 0xbc, 0xe5, 0xf4, 0x20, 0x82, 0x84, 0x23, + 0x74, 0x59, 0x9c, 0x48, 0x94, 0xb4, 0x39, 0x56, 0xb2, 0x99, 0x92, 0xc5, 0xfd, 0x1e, 0xcb, 0x94, + 0x2c, 0x53, 0xb2, 0x89, 0xb2, 0xbe, 0xdd, 0x13, 0x78, 0x92, 0x76, 0x98, 0x2f, 0x43, 0xa7, 0x27, + 0x7b, 0xd2, 0xd1, 0x80, 0x4e, 0x7a, 0xac, 0x23, 0x1d, 0xe8, 0xaf, 0x31, 0xb8, 0xbe, 0xb3, 0xb4, + 0x25, 0x27, 0x01, 0x25, 0xd3, 0xc4, 0x87, 0x8b, 0xcd, 0xd4, 0x77, 0x97, 0x6b, 0xd2, 0x68, 0x00, + 0x89, 0x12, 0x32, 0x82, 0x6e, 0x4e, 0xb6, 0xb5, 0x5c, 0x36, 0xc8, 0x4d, 0x5c, 0xdf, 0x5e, 0x9c, + 0x9d, 0xa4, 0x11, 0x8a, 0x30, 0xdf, 0x53, 0x6b, 0x71, 0x7a, 0x8a, 0x22, 0x70, 0x44, 0x84, 0x0a, + 0x93, 0x8b, 0x92, 0xc6, 0xf7, 0x22, 0xa9, 0xb6, 0x91, 0x23, 0x1c, 0xa7, 0x41, 0x1b, 0x90, 0xbe, + 0x27, 0x95, 0x10, 0x90, 0x77, 0x39, 0xf2, 0x9a, 0xb5, 0x69, 0x35, 0xab, 0x3b, 0x4d, 0xb6, 0xd4, + 0x76, 0x36, 0x68, 0xb1, 0xfd, 0xce, 0x27, 0xf0, 0xf1, 0x35, 0x20, 0x77, 0xe9, 0xe9, 0xf9, 0x46, + 0x61, 0x74, 0xbe, 0x41, 0x66, 0x67, 0xde, 0x94, 0x46, 0x8f, 0xc8, 0x8a, 0x8a, 0xc1, 0xaf, 0x15, + 0x35, 0xf5, 0x09, 0xbb, 0xea, 0x63, 0xb2, 0xb9, 0xf6, 0xda, 0x31, 0xf8, 0xee, 0x9a, 0x29, 0xb3, + 0x92, 0x45, 0x9e, 0x86, 0x52, 0x9f, 0xac, 0x2a, 0xe4, 0x98, 0xaa, 0x5a, 0x49, 0xe3, 0x9f, 0x5e, + 0x0f, 0xaf, 0x11, 0xee, 0x2d, 0x53, 0x60, 0x75, 0x1c, 0x7b, 0x06, 0xdd, 0xf8, 0x69, 0x91, 0xdb, + 0x73, 0xd9, 0xaf, 0x84, 0x42, 0xfa, 0x21, 0xe7, 0x97, 0x73, 0x89, 0x5f, 0x73, 0x9b, 0xc1, 0x32, + 0xb9, 0xb6, 0xed, 0x8e, 0x29, 0x57, 0x99, 0x9c, 0xcc, 0x99, 0x76, 0x48, 0xca, 0x02, 0x21, 0x54, + 0xb5, 0xe2, 0x66, 0xa9, 0x59, 0xdd, 0xd9, 0xbd, 0xd6, 0x58, 0xee, 0x4d, 0x53, 0xa1, 0xfc, 0x32, + 0x63, 0x79, 0x63, 0x64, 0xe3, 0x47, 0xe9, 0x9f, 0x71, 0x32, 0x37, 0x69, 0x93, 0x54, 0x12, 0x88, + 0x03, 0xe1, 0x73, 0xa5, 0xc7, 0x29, 0xbb, 0x6b, 0x59, 0x67, 0x9e, 0x39, 0xf3, 0xa6, 0xb7, 0xf4, + 0x23, 0xa9, 0x28, 0x08, 0xc0, 0x47, 0x99, 0x98, 0x27, 0x7d, 0x7c, 0xd5, 0xc1, 0x79, 0x07, 0x82, + 0xb6, 0xd1, 0x8e, 0xf9, 0x93, 0xc8, 0x9b, 0x32, 0xe9, 0x11, 0xa9, 0x20, 0x84, 0x71, 0xc0, 0x11, + 0xcc, 0x9b, 0x6e, 0x5f, 0xbe, 0x88, 0x6f, 0x65, 0xf7, 0x9d, 0x11, 0xe8, 0x35, 0x99, 0xda, 0x3a, + 0x39, 0xf5, 0xa6, 0x40, 0xfa, 0xc5, 0x22, 0xeb, 0x03, 0x19, 0xa4, 0x21, 0x3c, 0x0b, 0xb8, 0x08, + 0x27, 0x19, 0xaa, 0xb6, 0xa2, 0x6d, 0x7e, 0xf4, 0x9f, 0x4a, 0xd9, 0x28, 0x0a, 0x21, 0xc2, 0x83, + 0x19, 0xc3, 0x7d, 0x60, 0xea, 0xad, 0x1f, 0x2c, 0x00, 0x7b, 0x0b, 0xcb, 0xd1, 0x5d, 0x52, 0x55, + 0x90, 0x0c, 0x84, 0x0f, 0x6f, 0x78, 0x08, 0xb5, 0xf2, 0xa6, 0xd5, 0xbc, 0xe1, 0xde, 0x33, 0xa0, + 0x6a, 0x7b, 0x76, 0xe5, 0xcd, 0xe7, 0x35, 0xbe, 0x5a, 0xe4, 0x6e, 0x6e, 0x6d, 0xe9, 0x73, 0x42, + 0x65, 0x27, 0x4b, 0x83, 0xee, 0x8b, 0xf1, 0x5f, 0x2e, 0x64, 0xa4, 0x5f, 0xb1, 0xe4, 0xde, 0x1f, + 0x9d, 0x6f, 0xd0, 0xfd, 0xdc, 0xad, 0xb7, 0x40, 0x41, 0xb7, 0xe6, 0x76, 0xa0, 0xa8, 0x77, 0x60, + 0x6a, 0x65, 0x7e, 0x0f, 0xdc, 0x87, 0xa7, 0x43, 0xbb, 0x70, 0x36, 0xb4, 0x0b, 0xbf, 0x86, 0x76, + 0xe1, 0xf3, 0xc8, 0xb6, 0x4e, 0x47, 0xb6, 0x75, 0x36, 0xb2, 0xad, 0xdf, 0x23, 0xdb, 0xfa, 0xf6, + 0xc7, 0x2e, 0x1c, 0x56, 0x26, 0x3b, 0xf9, 0x37, 0x00, 0x00, 0xff, 0xff, 0x02, 0xea, 0x1a, 0x59, + 0xfb, 0x05, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.proto similarity index 67% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.proto index f574358..52e153f 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/generated.proto @@ -30,71 +30,79 @@ import "k8s.io/kubernetes/pkg/util/intstr/generated.proto"; // Package-wide variables from generator "generated". option go_package = "v1alpha1"; -// PetSet represents a set of pods with consistent identities. +// StatefulSet represents a set of pods with consistent identities. // Identities are defined as: // - Network: A single stable DNS and hostname. // - Storage: As many VolumeClaims as requested. -// The PetSet guarantees that a given network identity will always -// map to the same storage identity. PetSet is currently in alpha +// The StatefulSet guarantees that a given network identity will always +// map to the same storage identity. StatefulSet is currently in alpha // and subject to change without notice. -message PetSet { +message StatefulSet { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; - // Spec defines the desired identities of pets in this set. - optional PetSetSpec spec = 2; + // Spec defines the desired identities of pods in this set. + // +optional + optional StatefulSetSpec spec = 2; - // Status is the current status of Pets in this PetSet. This data + // Status is the current status of Pods in this StatefulSet. This data // may be out of date by some window of time. - optional PetSetStatus status = 3; + // +optional + optional StatefulSetStatus status = 3; } -// PetSetList is a collection of PetSets. -message PetSetList { +// StatefulSetList is a collection of StatefulSets. +message StatefulSetList { + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; - repeated PetSet items = 2; + repeated StatefulSet items = 2; } -// A PetSetSpec is the specification of a PetSet. -message PetSetSpec { +// A StatefulSetSpec is the specification of a StatefulSet. +message StatefulSetSpec { // Replicas is the desired number of replicas of the given Template. // These are replicas in the sense that they are instantiations of the // same Template, but individual replicas also have a consistent identity. // If unspecified, defaults to 1. // TODO: Consider a rename of this field. + // +optional optional int32 replicas = 1; // Selector is a label query over pods that should match the replica count. // If empty, defaulted to labels on the pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 2; // Template is the object that describes the pod that will be created if - // insufficient replicas are detected. Each pod stamped out by the PetSet + // insufficient replicas are detected. Each pod stamped out by the StatefulSet // will fulfill this Template, but have a unique identity from the rest - // of the PetSet. + // of the StatefulSet. optional k8s.io.kubernetes.pkg.api.v1.PodTemplateSpec template = 3; - // VolumeClaimTemplates is a list of claims that pets are allowed to reference. - // The PetSet controller is responsible for mapping network identities to - // claims in a way that maintains the identity of a pet. Every claim in + // VolumeClaimTemplates is a list of claims that pods are allowed to reference. + // The StatefulSet controller is responsible for mapping network identities to + // claims in a way that maintains the identity of a pod. Every claim in // this list must have at least one matching (by name) volumeMount in one // container in the template. A claim in this list takes precedence over // any volumes in the template, with the same name. // TODO: Define the behavior if a claim already exists with the same name. + // +optional repeated k8s.io.kubernetes.pkg.api.v1.PersistentVolumeClaim volumeClaimTemplates = 4; - // ServiceName is the name of the service that governs this PetSet. - // This service must exist before the PetSet, and is responsible for - // the network identity of the set. Pets get DNS/hostnames that follow the - // pattern: pet-specific-string.serviceName.default.svc.cluster.local - // where "pet-specific-string" is managed by the PetSet controller. + // ServiceName is the name of the service that governs this StatefulSet. + // This service must exist before the StatefulSet, and is responsible for + // the network identity of the set. Pods get DNS/hostnames that follow the + // pattern: pod-specific-string.serviceName.default.svc.cluster.local + // where "pod-specific-string" is managed by the StatefulSet controller. optional string serviceName = 5; } -// PetSetStatus represents the current state of a PetSet. -message PetSetStatus { +// StatefulSetStatus represents the current state of a StatefulSet. +message StatefulSetStatus { // most recent generation observed by this autoscaler. + // +optional optional int64 observedGeneration = 1; // Replicas is the number of actual replicas. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/register.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/register.go similarity index 76% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/register.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/register.go index 90f9bd1..ab771de 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package @@ -37,8 +37,8 @@ var ( // Adds the list of known types to api.Scheme. func addKnownTypes(scheme *runtime.Scheme) error { scheme.AddKnownTypes(SchemeGroupVersion, - &PetSet{}, - &PetSetList{}, + &StatefulSet{}, + &StatefulSetList{}, &v1.ListOptions{}, &v1.DeleteOptions{}, ) @@ -46,5 +46,5 @@ func addKnownTypes(scheme *runtime.Scheme) error { return nil } -func (obj *PetSet) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } -func (obj *PetSetList) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } +func (obj *StatefulSet) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } +func (obj *StatefulSetList) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.generated.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.generated.go index cddfdab..156fcfe 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -75,7 +75,7 @@ func init() { } } -func (x *PetSet) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSet) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -220,7 +220,7 @@ func (x *PetSet) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSet) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSet) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -250,7 +250,7 @@ func (x *PetSet) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -293,14 +293,14 @@ func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } case "spec": if r.TryDecodeAsNil() { - x.Spec = PetSetSpec{} + x.Spec = StatefulSetSpec{} } else { yyv24 := &x.Spec yyv24.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { - x.Status = PetSetStatus{} + x.Status = StatefulSetStatus{} } else { yyv25 := &x.Status yyv25.CodecDecodeSelf(d) @@ -312,7 +312,7 @@ func (x *PetSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -380,7 +380,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Spec = PetSetSpec{} + x.Spec = StatefulSetSpec{} } else { yyv30 := &x.Spec yyv30.CodecDecodeSelf(d) @@ -397,7 +397,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Status = PetSetStatus{} + x.Status = StatefulSetStatus{} } else { yyv31 := &x.Status yyv31.CodecDecodeSelf(d) @@ -418,7 +418,7 @@ func (x *PetSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -593,7 +593,7 @@ func (x *PetSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -623,7 +623,7 @@ func (x *PetSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -710,7 +710,7 @@ func (x *PetSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -841,7 +841,7 @@ func (x *PetSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -935,7 +935,7 @@ func (x *PetSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -965,7 +965,7 @@ func (x *PetSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1016,7 +1016,7 @@ func (x *PetSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1081,7 +1081,7 @@ func (x *PetSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *StatefulSetList) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -1202,7 +1202,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { _ = yym105 if false { } else { - h.encSlicePetSet(([]PetSet)(x.Items), e) + h.encSliceStatefulSet(([]StatefulSet)(x.Items), e) } } } else { @@ -1216,7 +1216,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { _ = yym106 if false { } else { - h.encSlicePetSet(([]PetSet)(x.Items), e) + h.encSliceStatefulSet(([]StatefulSet)(x.Items), e) } } } @@ -1229,7 +1229,7 @@ func (x *PetSetList) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *PetSetList) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *StatefulSetList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1259,7 +1259,7 @@ func (x *PetSetList) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *StatefulSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1315,7 +1315,7 @@ func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { _ = yym115 if false { } else { - h.decSlicePetSet((*[]PetSet)(yyv114), d) + h.decSliceStatefulSet((*[]StatefulSet)(yyv114), d) } } default: @@ -1325,7 +1325,7 @@ func (x *PetSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *PetSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *StatefulSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1406,7 +1406,7 @@ func (x *PetSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { _ = yym122 if false { } else { - h.decSlicePetSet((*[]PetSet)(yyv121), d) + h.decSliceStatefulSet((*[]StatefulSet)(yyv121), d) } } for { @@ -1541,7 +1541,7 @@ func (x codecSelfer1234) decSlicev1_PersistentVolumeClaim(v *[]pkg2_v1.Persisten } } -func (x codecSelfer1234) encSlicePetSet(v []PetSet, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceStatefulSet(v []StatefulSet, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -1554,7 +1554,7 @@ func (x codecSelfer1234) encSlicePetSet(v []PetSet, e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceStatefulSet(v *[]StatefulSet, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -1564,7 +1564,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { var yyc131 bool if yyl131 == 0 { if yyv131 == nil { - yyv131 = []PetSet{} + yyv131 = []StatefulSet{} yyc131 = true } else if len(yyv131) != 0 { yyv131 = yyv131[:0] @@ -1582,10 +1582,10 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { if yyrl131 <= cap(yyv131) { yyv131 = yyv131[:yyrl131] } else { - yyv131 = make([]PetSet, yyrl131) + yyv131 = make([]StatefulSet, yyrl131) } } else { - yyv131 = make([]PetSet, yyrl131) + yyv131 = make([]StatefulSet, yyrl131) } yyc131 = true yyrr131 = len(yyv131) @@ -1600,7 +1600,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { for ; yyj131 < yyrr131; yyj131++ { yyh131.ElemContainerState(yyj131) if r.TryDecodeAsNil() { - yyv131[yyj131] = PetSet{} + yyv131[yyj131] = StatefulSet{} } else { yyv132 := &yyv131[yyj131] yyv132.CodecDecodeSelf(d) @@ -1609,10 +1609,10 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { } if yyrt131 { for ; yyj131 < yyl131; yyj131++ { - yyv131 = append(yyv131, PetSet{}) + yyv131 = append(yyv131, StatefulSet{}) yyh131.ElemContainerState(yyj131) if r.TryDecodeAsNil() { - yyv131[yyj131] = PetSet{} + yyv131[yyj131] = StatefulSet{} } else { yyv133 := &yyv131[yyj131] yyv133.CodecDecodeSelf(d) @@ -1626,13 +1626,13 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { for ; !r.CheckBreak(); yyj131++ { if yyj131 >= len(yyv131) { - yyv131 = append(yyv131, PetSet{}) // var yyz131 PetSet + yyv131 = append(yyv131, StatefulSet{}) // var yyz131 StatefulSet yyc131 = true } yyh131.ElemContainerState(yyj131) if yyj131 < len(yyv131) { if r.TryDecodeAsNil() { - yyv131[yyj131] = PetSet{} + yyv131[yyj131] = StatefulSet{} } else { yyv134 := &yyv131[yyj131] yyv134.CodecDecodeSelf(d) @@ -1647,7 +1647,7 @@ func (x codecSelfer1234) decSlicePetSet(v *[]PetSet, d *codec1978.Decoder) { yyv131 = yyv131[:yyj131] yyc131 = true } else if yyj131 == 0 && yyv131 == nil { - yyv131 = []PetSet{} + yyv131 = []StatefulSet{} yyc131 = true } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.go similarity index 61% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.go index 6c6d42f..cc27518 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types.go @@ -17,80 +17,88 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true -// PetSet represents a set of pods with consistent identities. +// StatefulSet represents a set of pods with consistent identities. // Identities are defined as: // - Network: A single stable DNS and hostname. // - Storage: As many VolumeClaims as requested. -// The PetSet guarantees that a given network identity will always -// map to the same storage identity. PetSet is currently in alpha +// The StatefulSet guarantees that a given network identity will always +// map to the same storage identity. StatefulSet is currently in alpha // and subject to change without notice. -type PetSet struct { +type StatefulSet struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - // Spec defines the desired identities of pets in this set. - Spec PetSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` + // Spec defines the desired identities of pods in this set. + // +optional + Spec StatefulSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` - // Status is the current status of Pets in this PetSet. This data + // Status is the current status of Pods in this StatefulSet. This data // may be out of date by some window of time. - Status PetSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` + // +optional + Status StatefulSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } -// A PetSetSpec is the specification of a PetSet. -type PetSetSpec struct { +// A StatefulSetSpec is the specification of a StatefulSet. +type StatefulSetSpec struct { // Replicas is the desired number of replicas of the given Template. // These are replicas in the sense that they are instantiations of the // same Template, but individual replicas also have a consistent identity. // If unspecified, defaults to 1. // TODO: Consider a rename of this field. + // +optional Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` // Selector is a label query over pods that should match the replica count. // If empty, defaulted to labels on the pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` // Template is the object that describes the pod that will be created if - // insufficient replicas are detected. Each pod stamped out by the PetSet + // insufficient replicas are detected. Each pod stamped out by the StatefulSet // will fulfill this Template, but have a unique identity from the rest - // of the PetSet. + // of the StatefulSet. Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` - // VolumeClaimTemplates is a list of claims that pets are allowed to reference. - // The PetSet controller is responsible for mapping network identities to - // claims in a way that maintains the identity of a pet. Every claim in + // VolumeClaimTemplates is a list of claims that pods are allowed to reference. + // The StatefulSet controller is responsible for mapping network identities to + // claims in a way that maintains the identity of a pod. Every claim in // this list must have at least one matching (by name) volumeMount in one // container in the template. A claim in this list takes precedence over // any volumes in the template, with the same name. // TODO: Define the behavior if a claim already exists with the same name. + // +optional VolumeClaimTemplates []v1.PersistentVolumeClaim `json:"volumeClaimTemplates,omitempty" protobuf:"bytes,4,rep,name=volumeClaimTemplates"` - // ServiceName is the name of the service that governs this PetSet. - // This service must exist before the PetSet, and is responsible for - // the network identity of the set. Pets get DNS/hostnames that follow the - // pattern: pet-specific-string.serviceName.default.svc.cluster.local - // where "pet-specific-string" is managed by the PetSet controller. + // ServiceName is the name of the service that governs this StatefulSet. + // This service must exist before the StatefulSet, and is responsible for + // the network identity of the set. Pods get DNS/hostnames that follow the + // pattern: pod-specific-string.serviceName.default.svc.cluster.local + // where "pod-specific-string" is managed by the StatefulSet controller. ServiceName string `json:"serviceName" protobuf:"bytes,5,opt,name=serviceName"` } -// PetSetStatus represents the current state of a PetSet. -type PetSetStatus struct { +// StatefulSetStatus represents the current state of a StatefulSet. +type StatefulSetStatus struct { // most recent generation observed by this autoscaler. + // +optional ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` // Replicas is the number of actual replicas. Replicas int32 `json:"replicas" protobuf:"varint,2,opt,name=replicas"` } -// PetSetList is a collection of PetSets. -type PetSetList struct { +// StatefulSetList is a collection of StatefulSets. +type StatefulSetList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` - Items []PetSet `json:"items" protobuf:"bytes,2,rep,name=items"` + Items []StatefulSet `json:"items" protobuf:"bytes,2,rep,name=items"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go similarity index 50% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go index cefaf91..2be2e6b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/types_swagger_doc_generated.go @@ -27,45 +27,45 @@ package v1alpha1 // Those methods can be generated by using hack/update-generated-swagger-docs.sh // AUTO-GENERATED FUNCTIONS START HERE -var map_PetSet = map[string]string{ - "": "PetSet represents a set of pods with consistent identities. Identities are defined as:\n - Network: A single stable DNS and hostname.\n - Storage: As many VolumeClaims as requested.\nThe PetSet guarantees that a given network identity will always map to the same storage identity. PetSet is currently in alpha and subject to change without notice.", - "spec": "Spec defines the desired identities of pets in this set.", - "status": "Status is the current status of Pets in this PetSet. This data may be out of date by some window of time.", +var map_StatefulSet = map[string]string{ + "": "StatefulSet represents a set of pods with consistent identities. Identities are defined as:\n - Network: A single stable DNS and hostname.\n - Storage: As many VolumeClaims as requested.\nThe StatefulSet guarantees that a given network identity will always map to the same storage identity. StatefulSet is currently in alpha and subject to change without notice.", + "spec": "Spec defines the desired identities of pods in this set.", + "status": "Status is the current status of Pods in this StatefulSet. This data may be out of date by some window of time.", } -func (PetSet) SwaggerDoc() map[string]string { - return map_PetSet +func (StatefulSet) SwaggerDoc() map[string]string { + return map_StatefulSet } -var map_PetSetList = map[string]string{ - "": "PetSetList is a collection of PetSets.", +var map_StatefulSetList = map[string]string{ + "": "StatefulSetList is a collection of StatefulSets.", } -func (PetSetList) SwaggerDoc() map[string]string { - return map_PetSetList +func (StatefulSetList) SwaggerDoc() map[string]string { + return map_StatefulSetList } -var map_PetSetSpec = map[string]string{ - "": "A PetSetSpec is the specification of a PetSet.", +var map_StatefulSetSpec = map[string]string{ + "": "A StatefulSetSpec is the specification of a StatefulSet.", "replicas": "Replicas is the desired number of replicas of the given Template. These are replicas in the sense that they are instantiations of the same Template, but individual replicas also have a consistent identity. If unspecified, defaults to 1.", "selector": "Selector is a label query over pods that should match the replica count. If empty, defaulted to labels on the pod template. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors", - "template": "Template is the object that describes the pod that will be created if insufficient replicas are detected. Each pod stamped out by the PetSet will fulfill this Template, but have a unique identity from the rest of the PetSet.", - "volumeClaimTemplates": "VolumeClaimTemplates is a list of claims that pets are allowed to reference. The PetSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pet. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.", - "serviceName": "ServiceName is the name of the service that governs this PetSet. This service must exist before the PetSet, and is responsible for the network identity of the set. Pets get DNS/hostnames that follow the pattern: pet-specific-string.serviceName.default.svc.cluster.local where \"pet-specific-string\" is managed by the PetSet controller.", + "template": "Template is the object that describes the pod that will be created if insufficient replicas are detected. Each pod stamped out by the StatefulSet will fulfill this Template, but have a unique identity from the rest of the StatefulSet.", + "volumeClaimTemplates": "VolumeClaimTemplates is a list of claims that pods are allowed to reference. The StatefulSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pod. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.", + "serviceName": "ServiceName is the name of the service that governs this StatefulSet. This service must exist before the StatefulSet, and is responsible for the network identity of the set. Pods get DNS/hostnames that follow the pattern: pod-specific-string.serviceName.default.svc.cluster.local where \"pod-specific-string\" is managed by the StatefulSet controller.", } -func (PetSetSpec) SwaggerDoc() map[string]string { - return map_PetSetSpec +func (StatefulSetSpec) SwaggerDoc() map[string]string { + return map_StatefulSetSpec } -var map_PetSetStatus = map[string]string{ - "": "PetSetStatus represents the current state of a PetSet.", +var map_StatefulSetStatus = map[string]string{ + "": "StatefulSetStatus represents the current state of a StatefulSet.", "observedGeneration": "most recent generation observed by this autoscaler.", "replicas": "Replicas is the number of actual replicas.", } -func (PetSetStatus) SwaggerDoc() map[string]string { - return map_PetSetStatus +func (StatefulSetStatus) SwaggerDoc() map[string]string { + return map_StatefulSetStatus } // AUTO-GENERATED FUNCTIONS END HERE diff --git a/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.conversion.go new file mode 100644 index 0000000..983a083 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.conversion.go @@ -0,0 +1,192 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by conversion-gen. Do not edit it manually! + +package v1alpha1 + +import ( + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + apps "k8s.io/client-go/pkg/apis/apps" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" +) + +func init() { + SchemeBuilder.Register(RegisterConversions) +} + +// RegisterConversions adds conversion functions to the given scheme. +// Public to allow building arbitrary schemes. +func RegisterConversions(scheme *runtime.Scheme) error { + return scheme.AddGeneratedConversionFuncs( + Convert_v1alpha1_StatefulSet_To_apps_StatefulSet, + Convert_apps_StatefulSet_To_v1alpha1_StatefulSet, + Convert_v1alpha1_StatefulSetList_To_apps_StatefulSetList, + Convert_apps_StatefulSetList_To_v1alpha1_StatefulSetList, + Convert_v1alpha1_StatefulSetSpec_To_apps_StatefulSetSpec, + Convert_apps_StatefulSetSpec_To_v1alpha1_StatefulSetSpec, + Convert_v1alpha1_StatefulSetStatus_To_apps_StatefulSetStatus, + Convert_apps_StatefulSetStatus_To_v1alpha1_StatefulSetStatus, + ) +} + +func autoConvert_v1alpha1_StatefulSet_To_apps_StatefulSet(in *StatefulSet, out *apps.StatefulSet, s conversion.Scope) error { + // TODO: Inefficient conversion - can we improve it? + if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { + return err + } + if err := Convert_v1alpha1_StatefulSetSpec_To_apps_StatefulSetSpec(&in.Spec, &out.Spec, s); err != nil { + return err + } + if err := Convert_v1alpha1_StatefulSetStatus_To_apps_StatefulSetStatus(&in.Status, &out.Status, s); err != nil { + return err + } + return nil +} + +func Convert_v1alpha1_StatefulSet_To_apps_StatefulSet(in *StatefulSet, out *apps.StatefulSet, s conversion.Scope) error { + return autoConvert_v1alpha1_StatefulSet_To_apps_StatefulSet(in, out, s) +} + +func autoConvert_apps_StatefulSet_To_v1alpha1_StatefulSet(in *apps.StatefulSet, out *StatefulSet, s conversion.Scope) error { + // TODO: Inefficient conversion - can we improve it? + if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { + return err + } + if err := Convert_apps_StatefulSetSpec_To_v1alpha1_StatefulSetSpec(&in.Spec, &out.Spec, s); err != nil { + return err + } + if err := Convert_apps_StatefulSetStatus_To_v1alpha1_StatefulSetStatus(&in.Status, &out.Status, s); err != nil { + return err + } + return nil +} + +func Convert_apps_StatefulSet_To_v1alpha1_StatefulSet(in *apps.StatefulSet, out *StatefulSet, s conversion.Scope) error { + return autoConvert_apps_StatefulSet_To_v1alpha1_StatefulSet(in, out, s) +} + +func autoConvert_v1alpha1_StatefulSetList_To_apps_StatefulSetList(in *StatefulSetList, out *apps.StatefulSetList, s conversion.Scope) error { + out.ListMeta = in.ListMeta + if in.Items != nil { + in, out := &in.Items, &out.Items + *out = make([]apps.StatefulSet, len(*in)) + for i := range *in { + if err := Convert_v1alpha1_StatefulSet_To_apps_StatefulSet(&(*in)[i], &(*out)[i], s); err != nil { + return err + } + } + } else { + out.Items = nil + } + return nil +} + +func Convert_v1alpha1_StatefulSetList_To_apps_StatefulSetList(in *StatefulSetList, out *apps.StatefulSetList, s conversion.Scope) error { + return autoConvert_v1alpha1_StatefulSetList_To_apps_StatefulSetList(in, out, s) +} + +func autoConvert_apps_StatefulSetList_To_v1alpha1_StatefulSetList(in *apps.StatefulSetList, out *StatefulSetList, s conversion.Scope) error { + out.ListMeta = in.ListMeta + if in.Items != nil { + in, out := &in.Items, &out.Items + *out = make([]StatefulSet, len(*in)) + for i := range *in { + if err := Convert_apps_StatefulSet_To_v1alpha1_StatefulSet(&(*in)[i], &(*out)[i], s); err != nil { + return err + } + } + } else { + out.Items = nil + } + return nil +} + +func Convert_apps_StatefulSetList_To_v1alpha1_StatefulSetList(in *apps.StatefulSetList, out *StatefulSetList, s conversion.Scope) error { + return autoConvert_apps_StatefulSetList_To_v1alpha1_StatefulSetList(in, out, s) +} + +func autoConvert_v1alpha1_StatefulSetSpec_To_apps_StatefulSetSpec(in *StatefulSetSpec, out *apps.StatefulSetSpec, s conversion.Scope) error { + if err := api.Convert_Pointer_int32_To_int32(&in.Replicas, &out.Replicas, s); err != nil { + return err + } + out.Selector = in.Selector + if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { + return err + } + if in.VolumeClaimTemplates != nil { + in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates + *out = make([]api.PersistentVolumeClaim, len(*in)) + for i := range *in { + // TODO: Inefficient conversion - can we improve it? + if err := s.Convert(&(*in)[i], &(*out)[i], 0); err != nil { + return err + } + } + } else { + out.VolumeClaimTemplates = nil + } + out.ServiceName = in.ServiceName + return nil +} + +func autoConvert_apps_StatefulSetSpec_To_v1alpha1_StatefulSetSpec(in *apps.StatefulSetSpec, out *StatefulSetSpec, s conversion.Scope) error { + if err := api.Convert_int32_To_Pointer_int32(&in.Replicas, &out.Replicas, s); err != nil { + return err + } + out.Selector = in.Selector + if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { + return err + } + if in.VolumeClaimTemplates != nil { + in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates + *out = make([]v1.PersistentVolumeClaim, len(*in)) + for i := range *in { + // TODO: Inefficient conversion - can we improve it? + if err := s.Convert(&(*in)[i], &(*out)[i], 0); err != nil { + return err + } + } + } else { + out.VolumeClaimTemplates = nil + } + out.ServiceName = in.ServiceName + return nil +} + +func autoConvert_v1alpha1_StatefulSetStatus_To_apps_StatefulSetStatus(in *StatefulSetStatus, out *apps.StatefulSetStatus, s conversion.Scope) error { + out.ObservedGeneration = in.ObservedGeneration + out.Replicas = in.Replicas + return nil +} + +func Convert_v1alpha1_StatefulSetStatus_To_apps_StatefulSetStatus(in *StatefulSetStatus, out *apps.StatefulSetStatus, s conversion.Scope) error { + return autoConvert_v1alpha1_StatefulSetStatus_To_apps_StatefulSetStatus(in, out, s) +} + +func autoConvert_apps_StatefulSetStatus_To_v1alpha1_StatefulSetStatus(in *apps.StatefulSetStatus, out *StatefulSetStatus, s conversion.Scope) error { + out.ObservedGeneration = in.ObservedGeneration + out.Replicas = in.Replicas + return nil +} + +func Convert_apps_StatefulSetStatus_To_v1alpha1_StatefulSetStatus(in *apps.StatefulSetStatus, out *StatefulSetStatus, s conversion.Scope) error { + return autoConvert_apps_StatefulSetStatus_To_v1alpha1_StatefulSetStatus(in, out, s) +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go similarity index 61% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go index 3d80b70..c8dbb43 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v1alpha1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + unversioned "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) @@ -36,42 +36,42 @@ func init() { // to allow building arbitrary schemes. func RegisterDeepCopies(scheme *runtime.Scheme) error { return scheme.AddGeneratedDeepCopyFuncs( - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_PetSet, InType: reflect.TypeOf(&PetSet{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_PetSetList, InType: reflect.TypeOf(&PetSetList{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_PetSetSpec, InType: reflect.TypeOf(&PetSetSpec{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_PetSetStatus, InType: reflect.TypeOf(&PetSetStatus{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_StatefulSet, InType: reflect.TypeOf(&StatefulSet{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_StatefulSetList, InType: reflect.TypeOf(&StatefulSetList{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_StatefulSetSpec, InType: reflect.TypeOf(&StatefulSetSpec{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_StatefulSetStatus, InType: reflect.TypeOf(&StatefulSetStatus{})}, ) } -func DeepCopy_v1alpha1_PetSet(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_v1alpha1_StatefulSet(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSet) - out := out.(*PetSet) + in := in.(*StatefulSet) + out := out.(*StatefulSet) out.TypeMeta = in.TypeMeta if err := v1.DeepCopy_v1_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, c); err != nil { return err } - if err := DeepCopy_v1alpha1_PetSetSpec(&in.Spec, &out.Spec, c); err != nil { + if err := DeepCopy_v1alpha1_StatefulSetSpec(&in.Spec, &out.Spec, c); err != nil { return err } - if err := DeepCopy_v1alpha1_PetSetStatus(&in.Status, &out.Status, c); err != nil { + if err := DeepCopy_v1alpha1_StatefulSetStatus(&in.Status, &out.Status, c); err != nil { return err } return nil } } -func DeepCopy_v1alpha1_PetSetList(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_v1alpha1_StatefulSetList(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetList) - out := out.(*PetSetList) + in := in.(*StatefulSetList) + out := out.(*StatefulSetList) out.TypeMeta = in.TypeMeta out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items - *out = make([]PetSet, len(*in)) + *out = make([]StatefulSet, len(*in)) for i := range *in { - if err := DeepCopy_v1alpha1_PetSet(&(*in)[i], &(*out)[i], c); err != nil { + if err := DeepCopy_v1alpha1_StatefulSet(&(*in)[i], &(*out)[i], c); err != nil { return err } } @@ -82,10 +82,10 @@ func DeepCopy_v1alpha1_PetSetList(in interface{}, out interface{}, c *conversion } } -func DeepCopy_v1alpha1_PetSetSpec(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_v1alpha1_StatefulSetSpec(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetSpec) - out := out.(*PetSetSpec) + in := in.(*StatefulSetSpec) + out := out.(*StatefulSetSpec) if in.Replicas != nil { in, out := &in.Replicas, &out.Replicas *out = new(int32) @@ -121,10 +121,10 @@ func DeepCopy_v1alpha1_PetSetSpec(in interface{}, out interface{}, c *conversion } } -func DeepCopy_v1alpha1_PetSetStatus(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_v1alpha1_StatefulSetStatus(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetStatus) - out := out.(*PetSetStatus) + in := in.(*StatefulSetStatus) + out := out.(*StatefulSetStatus) if in.ObservedGeneration != nil { in, out := &in.ObservedGeneration, &out.ObservedGeneration *out = new(int64) diff --git a/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.defaults.go new file mode 100644 index 0000000..3a93522 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/apps/v1alpha1/zz_generated.defaults.go @@ -0,0 +1,166 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1alpha1 + +import ( + v1 "k8s.io/client-go/pkg/api/v1" + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&StatefulSet{}, func(obj interface{}) { SetObjectDefaults_StatefulSet(obj.(*StatefulSet)) }) + scheme.AddTypeDefaultingFunc(&StatefulSetList{}, func(obj interface{}) { SetObjectDefaults_StatefulSetList(obj.(*StatefulSetList)) }) + return nil +} + +func SetObjectDefaults_StatefulSet(in *StatefulSet) { + SetDefaults_StatefulSet(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.VolumeClaimTemplates { + a := &in.Spec.VolumeClaimTemplates[i] + v1.SetDefaults_PersistentVolumeClaim(a) + v1.SetDefaults_ResourceList(&a.Spec.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Spec.Resources.Requests) + v1.SetDefaults_ResourceList(&a.Status.Capacity) + } +} + +func SetObjectDefaults_StatefulSetList(in *StatefulSetList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_StatefulSet(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/apps/zz_generated.deepcopy.go similarity index 61% rename from vendor/k8s.io/kubernetes/pkg/apis/apps/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/apps/zz_generated.deepcopy.go index ecd6db6..4452972 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/apps/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package apps import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) @@ -36,42 +36,42 @@ func init() { // to allow building arbitrary schemes. func RegisterDeepCopies(scheme *runtime.Scheme) error { return scheme.AddGeneratedDeepCopyFuncs( - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_PetSet, InType: reflect.TypeOf(&PetSet{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_PetSetList, InType: reflect.TypeOf(&PetSetList{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_PetSetSpec, InType: reflect.TypeOf(&PetSetSpec{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_PetSetStatus, InType: reflect.TypeOf(&PetSetStatus{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_StatefulSet, InType: reflect.TypeOf(&StatefulSet{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_StatefulSetList, InType: reflect.TypeOf(&StatefulSetList{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_StatefulSetSpec, InType: reflect.TypeOf(&StatefulSetSpec{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_apps_StatefulSetStatus, InType: reflect.TypeOf(&StatefulSetStatus{})}, ) } -func DeepCopy_apps_PetSet(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_apps_StatefulSet(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSet) - out := out.(*PetSet) + in := in.(*StatefulSet) + out := out.(*StatefulSet) out.TypeMeta = in.TypeMeta if err := api.DeepCopy_api_ObjectMeta(&in.ObjectMeta, &out.ObjectMeta, c); err != nil { return err } - if err := DeepCopy_apps_PetSetSpec(&in.Spec, &out.Spec, c); err != nil { + if err := DeepCopy_apps_StatefulSetSpec(&in.Spec, &out.Spec, c); err != nil { return err } - if err := DeepCopy_apps_PetSetStatus(&in.Status, &out.Status, c); err != nil { + if err := DeepCopy_apps_StatefulSetStatus(&in.Status, &out.Status, c); err != nil { return err } return nil } } -func DeepCopy_apps_PetSetList(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_apps_StatefulSetList(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetList) - out := out.(*PetSetList) + in := in.(*StatefulSetList) + out := out.(*StatefulSetList) out.TypeMeta = in.TypeMeta out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items - *out = make([]PetSet, len(*in)) + *out = make([]StatefulSet, len(*in)) for i := range *in { - if err := DeepCopy_apps_PetSet(&(*in)[i], &(*out)[i], c); err != nil { + if err := DeepCopy_apps_StatefulSet(&(*in)[i], &(*out)[i], c); err != nil { return err } } @@ -82,10 +82,10 @@ func DeepCopy_apps_PetSetList(in interface{}, out interface{}, c *conversion.Clo } } -func DeepCopy_apps_PetSetSpec(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_apps_StatefulSetSpec(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetSpec) - out := out.(*PetSetSpec) + in := in.(*StatefulSetSpec) + out := out.(*StatefulSetSpec) out.Replicas = in.Replicas if in.Selector != nil { in, out := &in.Selector, &out.Selector @@ -115,10 +115,10 @@ func DeepCopy_apps_PetSetSpec(in interface{}, out interface{}, c *conversion.Clo } } -func DeepCopy_apps_PetSetStatus(in interface{}, out interface{}, c *conversion.Cloner) error { +func DeepCopy_apps_StatefulSetStatus(in interface{}, out interface{}, c *conversion.Cloner) error { { - in := in.(*PetSetStatus) - out := out.(*PetSetStatus) + in := in.(*StatefulSetStatus) + out := out.(*StatefulSetStatus) if in.ObservedGeneration != nil { in, out := &in.ObservedGeneration, &out.ObservedGeneration *out = new(int64) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/doc.go b/vendor/k8s.io/client-go/pkg/apis/authentication/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/doc.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/install/install.go b/vendor/k8s.io/client-go/pkg/apis/authentication/install/install.go similarity index 82% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/install/install.go index 48796b9..c045d7c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/authentication" - "k8s.io/kubernetes/pkg/apis/authentication/v1beta1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/authentication" + "k8s.io/client-go/pkg/apis/authentication/v1beta1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: authentication.GroupName, VersionPreferenceOrder: []string{v1beta1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/authentication", + ImportPrefix: "k8s.io/client-go/pkg/apis/authentication", RootScopedKinds: sets.NewString("TokenReview"), AddInternalObjectsToScheme: authentication.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/register.go b/vendor/k8s.io/client-go/pkg/apis/authentication/register.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/register.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/register.go index 09384b1..4759c01 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/register.go @@ -17,9 +17,9 @@ limitations under the License. package authentication import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/authentication/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/types.generated.go index ea0b8f0..b2c9ceb 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg2_api "k8s.io/client-go/pkg/api" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/types.go b/vendor/k8s.io/client-go/pkg/apis/authentication/types.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/types.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/types.go index 16d7e8c..84edf83 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/types.go @@ -17,8 +17,8 @@ limitations under the License. package authentication import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) const ( diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/conversion.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/conversion.go index a0b7051..93cccc5 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/conversion.go @@ -17,7 +17,7 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/defaults.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/defaults.go index bcd5e07..f3b22e9 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/defaults.go @@ -17,7 +17,7 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/doc.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/doc.go index e6530b5..528723c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/doc.go @@ -18,4 +18,5 @@ limitations under the License. // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/authentication // +groupName=authentication.k8s.io // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.pb.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.pb.go index cf235ef..f955731 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.pb.go @@ -73,11 +73,11 @@ func (*UserInfo) ProtoMessage() {} func (*UserInfo) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{4} } func init() { - proto.RegisterType((*ExtraValue)(nil), "k8s.io.kubernetes.pkg.apis.authentication.v1beta1.ExtraValue") - proto.RegisterType((*TokenReview)(nil), "k8s.io.kubernetes.pkg.apis.authentication.v1beta1.TokenReview") - proto.RegisterType((*TokenReviewSpec)(nil), "k8s.io.kubernetes.pkg.apis.authentication.v1beta1.TokenReviewSpec") - proto.RegisterType((*TokenReviewStatus)(nil), "k8s.io.kubernetes.pkg.apis.authentication.v1beta1.TokenReviewStatus") - proto.RegisterType((*UserInfo)(nil), "k8s.io.kubernetes.pkg.apis.authentication.v1beta1.UserInfo") + proto.RegisterType((*ExtraValue)(nil), "k8s.io.client-go.pkg.apis.authentication.v1beta1.ExtraValue") + proto.RegisterType((*TokenReview)(nil), "k8s.io.client-go.pkg.apis.authentication.v1beta1.TokenReview") + proto.RegisterType((*TokenReviewSpec)(nil), "k8s.io.client-go.pkg.apis.authentication.v1beta1.TokenReviewSpec") + proto.RegisterType((*TokenReviewStatus)(nil), "k8s.io.client-go.pkg.apis.authentication.v1beta1.TokenReviewStatus") + proto.RegisterType((*UserInfo)(nil), "k8s.io.client-go.pkg.apis.authentication.v1beta1.UserInfo") } func (m ExtraValue) Marshal() (data []byte, err error) { size := m.Size() @@ -1236,45 +1236,46 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 632 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xa4, 0x53, 0x4f, 0x4f, 0x13, 0x41, - 0x14, 0xef, 0x5f, 0x6c, 0xa7, 0xa2, 0x38, 0x89, 0x49, 0xd3, 0x44, 0x4a, 0xd6, 0x0b, 0x26, 0x30, - 0x9b, 0x92, 0xa8, 0x04, 0xe2, 0x81, 0x0d, 0x68, 0x38, 0x18, 0x93, 0x41, 0x8c, 0x31, 0xf1, 0xb0, - 0xed, 0x3e, 0x96, 0x75, 0xdb, 0x9d, 0x66, 0x76, 0xa6, 0xc8, 0x8d, 0x8f, 0xe0, 0xd1, 0xa3, 0xdf, - 0xc3, 0x2f, 0xd0, 0x23, 0x07, 0x0f, 0x1e, 0x0c, 0x11, 0xfc, 0x22, 0xce, 0xcc, 0x8e, 0xb4, 0xb4, - 0xf4, 0x20, 0x1c, 0x26, 0xd9, 0xf9, 0xcd, 0xfb, 0xfd, 0xde, 0xef, 0xbd, 0xb7, 0x0f, 0x6d, 0xc5, - 0xeb, 0x29, 0x89, 0x98, 0x1b, 0xcb, 0x36, 0xf0, 0x04, 0x04, 0xa4, 0x6e, 0x3f, 0x0e, 0x5d, 0xbf, - 0x1f, 0xa5, 0xae, 0x2f, 0xc5, 0x21, 0x24, 0x22, 0xea, 0xf8, 0x22, 0x62, 0x89, 0x3b, 0x68, 0xb5, - 0x41, 0xf8, 0x2d, 0x37, 0x84, 0x04, 0xb8, 0x2f, 0x20, 0x20, 0x7d, 0xce, 0x04, 0xc3, 0xad, 0x4c, - 0x82, 0x8c, 0x24, 0x88, 0x92, 0x20, 0x5a, 0x82, 0x5c, 0x95, 0x20, 0x56, 0xa2, 0xb1, 0x1a, 0x46, - 0xe2, 0x50, 0xb6, 0x49, 0x87, 0xf5, 0xdc, 0x90, 0x85, 0xcc, 0x35, 0x4a, 0x6d, 0x79, 0x60, 0x6e, - 0xe6, 0x62, 0xbe, 0xb2, 0x0c, 0x8d, 0xb5, 0x99, 0x26, 0x5d, 0x0e, 0x29, 0x93, 0xbc, 0x03, 0x93, - 0xae, 0x1a, 0x4f, 0x67, 0x73, 0x64, 0x32, 0x00, 0x9e, 0x2a, 0x3f, 0x10, 0x4c, 0xd1, 0x56, 0x66, - 0xd3, 0x06, 0x53, 0xa5, 0x37, 0x56, 0xaf, 0x8f, 0xe6, 0x52, 0x95, 0xdc, 0x9b, 0xf6, 0xd4, 0xba, - 0x3e, 0x5c, 0x8a, 0xa8, 0xeb, 0x46, 0x89, 0x48, 0x05, 0x9f, 0xa4, 0x38, 0xcf, 0x11, 0xda, 0xf9, - 0x2c, 0xb8, 0xff, 0xce, 0xef, 0x4a, 0xc0, 0x4d, 0x54, 0x8e, 0x04, 0xf4, 0xd2, 0x7a, 0x7e, 0xa9, - 0xb8, 0x5c, 0xf5, 0xaa, 0x17, 0x67, 0xcd, 0xf2, 0xae, 0x06, 0x68, 0x86, 0x6f, 0x54, 0xbe, 0x7e, - 0x6b, 0xe6, 0x4e, 0x7e, 0x2d, 0xe5, 0x9c, 0xef, 0x05, 0x54, 0x7b, 0xcb, 0x62, 0x48, 0x28, 0x0c, - 0x22, 0x38, 0xc2, 0xef, 0x51, 0xa5, 0xa7, 0x7a, 0x1f, 0xf8, 0xc2, 0x57, 0xec, 0xfc, 0x72, 0x6d, - 0x6d, 0x99, 0xcc, 0x1c, 0x9c, 0x1a, 0x14, 0x79, 0xd3, 0xfe, 0x04, 0x1d, 0xf1, 0x5a, 0x71, 0x3c, - 0x3c, 0x3c, 0x6b, 0xe6, 0x54, 0x2e, 0x34, 0xc2, 0xe8, 0xa5, 0x1a, 0x0e, 0x50, 0x29, 0xed, 0x43, - 0xa7, 0x5e, 0x30, 0xaa, 0x1e, 0xf9, 0xef, 0xdf, 0x81, 0x8c, 0xf9, 0xdc, 0x53, 0x4a, 0xde, 0x5d, - 0x9b, 0xaf, 0xa4, 0x6f, 0xd4, 0xa8, 0xe3, 0x2e, 0x9a, 0x4b, 0x85, 0x2f, 0x64, 0x5a, 0x2f, 0x9a, - 0x3c, 0xdb, 0xb7, 0xcc, 0x63, 0xb4, 0xbc, 0x7b, 0x36, 0xd3, 0x5c, 0x76, 0xa7, 0x36, 0x87, 0xf3, - 0x0c, 0xdd, 0x9f, 0x30, 0x85, 0x1f, 0xa3, 0xb2, 0xd0, 0x90, 0xe9, 0x5e, 0xd5, 0x9b, 0xb7, 0xcc, - 0x72, 0x16, 0x97, 0xbd, 0x39, 0x3f, 0xf2, 0xe8, 0xc1, 0x54, 0x16, 0xbc, 0x89, 0xe6, 0xc7, 0x1c, - 0x41, 0x60, 0x24, 0x2a, 0xde, 0x43, 0x2b, 0x31, 0xbf, 0x35, 0xfe, 0x48, 0xaf, 0xc6, 0xe2, 0x8f, - 0xa8, 0x24, 0x53, 0xe0, 0xb6, 0xbd, 0x9b, 0x37, 0x28, 0x7b, 0x5f, 0xd1, 0x77, 0x93, 0x03, 0x36, - 0xea, 0xab, 0x46, 0xa8, 0x91, 0xd5, 0x65, 0x01, 0xe7, 0x8c, 0x9b, 0xb6, 0x8e, 0x95, 0xb5, 0xa3, - 0x41, 0x9a, 0xbd, 0x39, 0xe7, 0x05, 0x54, 0xf9, 0xa7, 0x82, 0x57, 0x50, 0x45, 0x33, 0x13, 0xbf, - 0x07, 0xb6, 0x17, 0x0b, 0x96, 0x64, 0x62, 0x34, 0x4e, 0x2f, 0x23, 0xf0, 0x23, 0x54, 0x94, 0x51, - 0x60, 0xdc, 0x57, 0xbd, 0x9a, 0x0d, 0x2c, 0xee, 0xef, 0x6e, 0x53, 0x8d, 0x63, 0x07, 0xcd, 0x85, - 0x9c, 0xc9, 0xbe, 0x1e, 0xab, 0xfe, 0xa5, 0x91, 0x1e, 0xc6, 0x2b, 0x83, 0x50, 0xfb, 0x82, 0x63, - 0x65, 0x51, 0xef, 0x40, 0xbd, 0xa4, 0x42, 0x6a, 0x6b, 0x2f, 0x6f, 0xd1, 0x02, 0x62, 0x96, 0x69, - 0x27, 0x11, 0xfc, 0x78, 0xac, 0x54, 0x8d, 0xd1, 0x2c, 0x47, 0xe3, 0xc8, 0x2e, 0x9c, 0x89, 0xc1, - 0x0b, 0xa8, 0x18, 0xc3, 0x71, 0x56, 0x26, 0xd5, 0x9f, 0x78, 0x0f, 0x95, 0x07, 0x7a, 0x17, 0xed, - 0x3c, 0x5e, 0xdc, 0xc0, 0xcc, 0x68, 0xa1, 0x69, 0xa6, 0xb5, 0x51, 0x58, 0xcf, 0x7b, 0x4f, 0x86, - 0xe7, 0x8b, 0xb9, 0x53, 0x75, 0x7e, 0xaa, 0x73, 0x72, 0xb1, 0x98, 0x1f, 0xaa, 0x73, 0xaa, 0xce, - 0x6f, 0x75, 0xbe, 0xfc, 0x59, 0xcc, 0x7d, 0xb8, 0x63, 0x05, 0xfe, 0x06, 0x00, 0x00, 0xff, 0xff, - 0xca, 0xd0, 0x35, 0x8c, 0xb5, 0x05, 0x00, 0x00, + // 642 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xa4, 0x93, 0xcf, 0x6e, 0x13, 0x31, + 0x10, 0xc6, 0xb3, 0xf9, 0x53, 0x12, 0x87, 0x42, 0xb1, 0x84, 0x14, 0x45, 0x62, 0x13, 0x85, 0x4b, + 0x90, 0x5a, 0xaf, 0x52, 0x09, 0xa8, 0x5a, 0x71, 0xe8, 0xaa, 0x05, 0xf5, 0x80, 0x90, 0x5c, 0x8a, + 0x10, 0x12, 0x07, 0x27, 0x99, 0x6e, 0x97, 0x6d, 0xd6, 0x2b, 0xaf, 0x9d, 0xd2, 0x5b, 0x1f, 0x81, + 0x23, 0x47, 0xde, 0x83, 0x17, 0xe8, 0xb1, 0x07, 0x0e, 0x1c, 0x50, 0x45, 0xc2, 0x8b, 0x20, 0x7b, + 0x4d, 0x93, 0x36, 0xcd, 0x81, 0xf6, 0xb6, 0xfe, 0x3c, 0xf3, 0x9b, 0x6f, 0xc6, 0x3b, 0x68, 0x33, + 0x5a, 0x4b, 0x49, 0xc8, 0xbd, 0x48, 0x75, 0x41, 0xc4, 0x20, 0x21, 0xf5, 0x92, 0x28, 0xf0, 0x58, + 0x12, 0xa6, 0x1e, 0x53, 0xf2, 0x00, 0x62, 0x19, 0xf6, 0x98, 0x0c, 0x79, 0xec, 0x0d, 0x3b, 0x5d, + 0x90, 0xac, 0xe3, 0x05, 0x10, 0x83, 0x60, 0x12, 0xfa, 0x24, 0x11, 0x5c, 0x72, 0xdc, 0xc9, 0x10, + 0x64, 0x82, 0x20, 0x49, 0x14, 0x10, 0x8d, 0x20, 0x97, 0x11, 0xc4, 0x22, 0xea, 0x2b, 0x41, 0x28, + 0x0f, 0x54, 0x97, 0xf4, 0xf8, 0xc0, 0x0b, 0x78, 0xc0, 0x3d, 0x43, 0xea, 0xaa, 0x7d, 0x73, 0x32, + 0x07, 0xf3, 0x95, 0x55, 0xa8, 0xaf, 0xce, 0x35, 0xe9, 0x09, 0x48, 0xb9, 0x12, 0x3d, 0xb8, 0xea, + 0xaa, 0xfe, 0x74, 0x7e, 0x8e, 0x8a, 0x87, 0x20, 0xd2, 0x90, 0xc7, 0xd0, 0x9f, 0x49, 0x5b, 0x9e, + 0x9f, 0x36, 0x9c, 0x69, 0xbd, 0xbe, 0x72, 0x7d, 0xb4, 0x50, 0xb1, 0x0c, 0x07, 0xb3, 0x9e, 0x3a, + 0xd7, 0x87, 0x2b, 0x19, 0x1e, 0x7a, 0x61, 0x2c, 0x53, 0x29, 0xae, 0xa6, 0xb4, 0x9e, 0x23, 0xb4, + 0xfd, 0x59, 0x0a, 0xf6, 0x8e, 0x1d, 0x2a, 0xc0, 0x0d, 0x54, 0x0a, 0x25, 0x0c, 0xd2, 0x9a, 0xd3, + 0x2c, 0xb4, 0x2b, 0x7e, 0x65, 0x7c, 0xde, 0x28, 0xed, 0x68, 0x81, 0x66, 0xfa, 0x7a, 0xf9, 0xeb, + 0xb7, 0x46, 0xee, 0xe4, 0x57, 0x33, 0xd7, 0xfa, 0x9e, 0x47, 0xd5, 0xb7, 0x3c, 0x82, 0x98, 0xc2, + 0x30, 0x84, 0x23, 0xfc, 0x1e, 0x95, 0x07, 0x20, 0x59, 0x9f, 0x49, 0x56, 0x73, 0x9a, 0x4e, 0xbb, + 0xba, 0xda, 0x26, 0x73, 0x1f, 0x8e, 0x0c, 0x3b, 0xe4, 0x4d, 0xf7, 0x13, 0xf4, 0xe4, 0x6b, 0x90, + 0xcc, 0xc7, 0xa7, 0xe7, 0x8d, 0xdc, 0xf8, 0xbc, 0x81, 0x26, 0x1a, 0xbd, 0xa0, 0xe1, 0x3e, 0x2a, + 0xa6, 0x09, 0xf4, 0x6a, 0x79, 0x43, 0xf5, 0xc9, 0x7f, 0xff, 0x0e, 0x64, 0xca, 0xe7, 0x6e, 0x02, + 0x3d, 0xff, 0xae, 0xad, 0x57, 0xd4, 0x27, 0x6a, 0xe8, 0xf8, 0x10, 0x2d, 0xa4, 0x92, 0x49, 0x95, + 0xd6, 0x0a, 0xa6, 0xce, 0xd6, 0x2d, 0xeb, 0x18, 0x96, 0x7f, 0xcf, 0x56, 0x5a, 0xc8, 0xce, 0xd4, + 0xd6, 0x68, 0x3d, 0x43, 0xf7, 0xaf, 0x98, 0xc2, 0x8f, 0x51, 0x49, 0x6a, 0xc9, 0x4c, 0xaf, 0xe2, + 0x2f, 0xda, 0xcc, 0x52, 0x16, 0x97, 0xdd, 0xb5, 0x7e, 0x38, 0xe8, 0xc1, 0x4c, 0x15, 0xbc, 0x81, + 0x16, 0xa7, 0x1c, 0x41, 0xdf, 0x20, 0xca, 0xfe, 0x43, 0x8b, 0x58, 0xdc, 0x9c, 0xbe, 0xa4, 0x97, + 0x63, 0xf1, 0x47, 0x54, 0x54, 0x29, 0x08, 0x3b, 0xde, 0x8d, 0x1b, 0xb4, 0xbd, 0x97, 0x82, 0xd8, + 0x89, 0xf7, 0xf9, 0x64, 0xae, 0x5a, 0xa1, 0x06, 0xab, 0xdb, 0x02, 0x21, 0xb8, 0x30, 0x63, 0x9d, + 0x6a, 0x6b, 0x5b, 0x8b, 0x34, 0xbb, 0x6b, 0x8d, 0xf2, 0xa8, 0xfc, 0x8f, 0x82, 0x97, 0x51, 0x59, + 0x67, 0xc6, 0x6c, 0x00, 0x76, 0x16, 0x4b, 0x36, 0xc9, 0xc4, 0x68, 0x9d, 0x5e, 0x44, 0xe0, 0x47, + 0xa8, 0xa0, 0xc2, 0xbe, 0x71, 0x5f, 0xf1, 0xab, 0x36, 0xb0, 0xb0, 0xb7, 0xb3, 0x45, 0xb5, 0x8e, + 0x5b, 0x68, 0x21, 0x10, 0x5c, 0x25, 0xfa, 0x59, 0xf5, 0x2f, 0x8d, 0xf4, 0x63, 0xbc, 0x32, 0x0a, + 0xb5, 0x37, 0x38, 0x42, 0x25, 0xd0, 0x3b, 0x50, 0x2b, 0x36, 0x0b, 0xed, 0xea, 0xea, 0xcb, 0x5b, + 0x8c, 0x80, 0x98, 0x65, 0xda, 0x8e, 0xa5, 0x38, 0x9e, 0x6a, 0x55, 0x6b, 0x34, 0xab, 0x51, 0x3f, + 0xb2, 0x0b, 0x67, 0x62, 0xf0, 0x12, 0x2a, 0x44, 0x70, 0x9c, 0xb5, 0x49, 0xf5, 0x27, 0xde, 0x45, + 0xa5, 0xa1, 0xde, 0x45, 0xfb, 0x1e, 0x2f, 0x6e, 0x60, 0x66, 0xb2, 0xd0, 0x34, 0x63, 0xad, 0xe7, + 0xd7, 0x1c, 0xff, 0xc9, 0xe9, 0xc8, 0xcd, 0x9d, 0x8d, 0xdc, 0xdc, 0xcf, 0x91, 0x9b, 0x3b, 0x19, + 0xbb, 0xce, 0xe9, 0xd8, 0x75, 0xce, 0xc6, 0xae, 0xf3, 0x7b, 0xec, 0x3a, 0x5f, 0xfe, 0xb8, 0xb9, + 0x0f, 0x77, 0x2c, 0xe0, 0x6f, 0x00, 0x00, 0x00, 0xff, 0xff, 0xca, 0xd0, 0x35, 0x8c, 0xb5, 0x05, + 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.proto similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.proto index ac148e2..f36e281 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/generated.proto @@ -43,30 +43,36 @@ message ExtraValue { // Note: TokenReview requests may be cached by the webhook token authenticator // plugin in the kube-apiserver. message TokenReview { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec holds information about the request being evaluated optional TokenReviewSpec spec = 2; // Status is filled in by the server and indicates whether the request can be authenticated. + // +optional optional TokenReviewStatus status = 3; } // TokenReviewSpec is a description of the token authentication request. message TokenReviewSpec { // Token is the opaque bearer token. + // +optional optional string token = 1; } // TokenReviewStatus is the result of the token authentication request. message TokenReviewStatus { // Authenticated indicates that the token was associated with a known user. + // +optional optional bool authenticated = 1; // User is the UserInfo associated with the provided token. + // +optional optional UserInfo user = 2; // Error indicates that the token couldn't be checked + // +optional optional string error = 3; } @@ -74,17 +80,21 @@ message TokenReviewStatus { // user.Info interface. message UserInfo { // The name that uniquely identifies this user among all active users. + // +optional optional string username = 1; // A unique value that identifies this user across time. If this user is // deleted and another user by the same name is added, they will have // different UIDs. + // +optional optional string uid = 2; // The names of groups this user is a part of. + // +optional repeated string groups = 3; // Any additional information provided by the authenticator. + // +optional map extra = 4; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/register.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/register.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/register.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/register.go index 53488da..472e53d 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/register.go @@ -17,9 +17,9 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.generated.go index 8398283..32f15d3 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.go index fadd637..0338902 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types.go @@ -19,8 +19,8 @@ package v1beta1 import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true @@ -32,28 +32,34 @@ import ( // plugin in the kube-apiserver. type TokenReview struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec holds information about the request being evaluated Spec TokenReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` // Status is filled in by the server and indicates whether the request can be authenticated. + // +optional Status TokenReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // TokenReviewSpec is a description of the token authentication request. type TokenReviewSpec struct { // Token is the opaque bearer token. + // +optional Token string `json:"token,omitempty" protobuf:"bytes,1,opt,name=token"` } // TokenReviewStatus is the result of the token authentication request. type TokenReviewStatus struct { // Authenticated indicates that the token was associated with a known user. + // +optional Authenticated bool `json:"authenticated,omitempty" protobuf:"varint,1,opt,name=authenticated"` // User is the UserInfo associated with the provided token. + // +optional User UserInfo `json:"user,omitempty" protobuf:"bytes,2,opt,name=user"` // Error indicates that the token couldn't be checked + // +optional Error string `json:"error,omitempty" protobuf:"bytes,3,opt,name=error"` } @@ -61,14 +67,18 @@ type TokenReviewStatus struct { // user.Info interface. type UserInfo struct { // The name that uniquely identifies this user among all active users. + // +optional Username string `json:"username,omitempty" protobuf:"bytes,1,opt,name=username"` // A unique value that identifies this user across time. If this user is // deleted and another user by the same name is added, they will have // different UIDs. + // +optional UID string `json:"uid,omitempty" protobuf:"bytes,2,opt,name=uid"` // The names of groups this user is a part of. + // +optional Groups []string `json:"groups,omitempty" protobuf:"bytes,3,rep,name=groups"` // Any additional information provided by the authenticator. + // +optional Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,4,rep,name=extra"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.conversion.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.conversion.go index b3849d3..73d11ea 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - authentication "k8s.io/kubernetes/pkg/apis/authentication" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + authentication "k8s.io/client-go/pkg/apis/authentication" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -47,9 +46,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1beta1_TokenReview_To_authentication_TokenReview(in *TokenReview, out *authentication.TokenReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -68,9 +64,6 @@ func Convert_v1beta1_TokenReview_To_authentication_TokenReview(in *TokenReview, } func autoConvert_authentication_TokenReview_To_v1beta1_TokenReview(in *authentication.TokenReview, out *TokenReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go index 01cbc76..2d461d2 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/v1beta1/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package v1beta1 import ( - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authentication/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/authentication/zz_generated.deepcopy.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/authentication/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/authentication/zz_generated.deepcopy.go index 7caf7b0..b86631c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authentication/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/authentication/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package authentication import ( - api "k8s.io/kubernetes/pkg/api" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/doc.go b/vendor/k8s.io/client-go/pkg/apis/authorization/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/doc.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/install/install.go b/vendor/k8s.io/client-go/pkg/apis/authorization/install/install.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/install/install.go index c2356d3..b758df5 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/authorization" - "k8s.io/kubernetes/pkg/apis/authorization/v1beta1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/authorization" + "k8s.io/client-go/pkg/apis/authorization/v1beta1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: authorization.GroupName, VersionPreferenceOrder: []string{v1beta1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/authorization", + ImportPrefix: "k8s.io/client-go/pkg/apis/authorization", RootScopedKinds: sets.NewString("SubjectAccessReview", "SelfSubjectAccessReview"), AddInternalObjectsToScheme: authorization.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/register.go b/vendor/k8s.io/client-go/pkg/apis/authorization/register.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/register.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/register.go index 59d92fa..55ae357 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/register.go @@ -17,8 +17,8 @@ limitations under the License. package authorization import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/authorization/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/types.generated.go index c3a10de..49bd9cf 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg2_api "k8s.io/client-go/pkg/api" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/types.go b/vendor/k8s.io/client-go/pkg/apis/authorization/types.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/types.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/types.go index 545d1fa..2ac0558 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/types.go @@ -17,8 +17,8 @@ limitations under the License. package authorization import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // +genclient=true diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/conversion.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/conversion.go index fa88791..090160a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/conversion.go @@ -17,7 +17,7 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/defaults.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/defaults.go index 57dd337..bcbcbfa 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/defaults.go @@ -17,7 +17,7 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/doc.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/doc.go index 392ee49..e11cea1 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/doc.go @@ -17,6 +17,7 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/authorization // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta // +groupName=authorization.k8s.io package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.pb.go similarity index 89% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.pb.go index 180bbbd..875a98a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.pb.go @@ -99,15 +99,15 @@ func (*SubjectAccessReviewStatus) Descriptor() ([]byte, []int) { } func init() { - proto.RegisterType((*ExtraValue)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.ExtraValue") - proto.RegisterType((*LocalSubjectAccessReview)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.LocalSubjectAccessReview") - proto.RegisterType((*NonResourceAttributes)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.NonResourceAttributes") - proto.RegisterType((*ResourceAttributes)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.ResourceAttributes") - proto.RegisterType((*SelfSubjectAccessReview)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.SelfSubjectAccessReview") - proto.RegisterType((*SelfSubjectAccessReviewSpec)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.SelfSubjectAccessReviewSpec") - proto.RegisterType((*SubjectAccessReview)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.SubjectAccessReview") - proto.RegisterType((*SubjectAccessReviewSpec)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.SubjectAccessReviewSpec") - proto.RegisterType((*SubjectAccessReviewStatus)(nil), "k8s.io.kubernetes.pkg.apis.authorization.v1beta1.SubjectAccessReviewStatus") + proto.RegisterType((*ExtraValue)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.ExtraValue") + proto.RegisterType((*LocalSubjectAccessReview)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.LocalSubjectAccessReview") + proto.RegisterType((*NonResourceAttributes)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.NonResourceAttributes") + proto.RegisterType((*ResourceAttributes)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.ResourceAttributes") + proto.RegisterType((*SelfSubjectAccessReview)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.SelfSubjectAccessReview") + proto.RegisterType((*SelfSubjectAccessReviewSpec)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.SelfSubjectAccessReviewSpec") + proto.RegisterType((*SubjectAccessReview)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.SubjectAccessReview") + proto.RegisterType((*SubjectAccessReviewSpec)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.SubjectAccessReviewSpec") + proto.RegisterType((*SubjectAccessReviewStatus)(nil), "k8s.io.client-go.pkg.apis.authorization.v1beta1.SubjectAccessReviewStatus") } func (m ExtraValue) Marshal() (data []byte, err error) { size := m.Size() @@ -2283,59 +2283,60 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 864 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x56, 0x4d, 0x4f, 0x1b, 0x47, - 0x18, 0xf6, 0xf7, 0xc7, 0xd0, 0x16, 0x3a, 0x88, 0x62, 0x5c, 0x09, 0x5b, 0xae, 0x54, 0x81, 0x04, - 0xbb, 0x05, 0x09, 0x15, 0xa1, 0x1e, 0xea, 0x55, 0x2d, 0x84, 0x5a, 0x68, 0x35, 0x6e, 0x51, 0xd5, - 0x9e, 0x66, 0xd7, 0x83, 0xd9, 0xd8, 0xde, 0xb5, 0x66, 0x66, 0x4d, 0xc8, 0x89, 0x1f, 0x90, 0x43, - 0x8e, 0x1c, 0xf3, 0x17, 0xf2, 0x07, 0x72, 0x0d, 0x47, 0x72, 0x89, 0x12, 0x29, 0x42, 0x09, 0xf9, - 0x17, 0x39, 0x65, 0x76, 0x76, 0xec, 0xc5, 0x78, 0x9d, 0xc8, 0x09, 0x8a, 0x72, 0xe0, 0x30, 0xd2, - 0xce, 0xfb, 0xf1, 0xbc, 0xcf, 0xcc, 0x3c, 0xb3, 0xef, 0x80, 0x5f, 0x5b, 0x9b, 0x4c, 0xb3, 0x5d, - 0xbd, 0xe5, 0x99, 0x84, 0x3a, 0x84, 0x13, 0xa6, 0x77, 0x5b, 0x4d, 0x1d, 0x77, 0x6d, 0xa6, 0x63, - 0x8f, 0x1f, 0xba, 0xd4, 0xbe, 0x87, 0xb9, 0xed, 0x3a, 0x7a, 0x6f, 0xcd, 0x24, 0x1c, 0xaf, 0xe9, - 0x4d, 0xe2, 0x10, 0x8a, 0x39, 0x69, 0x68, 0x5d, 0xea, 0x72, 0x17, 0xfe, 0x14, 0x20, 0x68, 0x21, - 0x82, 0x26, 0x10, 0x34, 0x1f, 0x41, 0x1b, 0x42, 0xd0, 0x14, 0x42, 0x71, 0xb5, 0x69, 0xf3, 0x43, - 0xcf, 0xd4, 0x2c, 0xb7, 0xa3, 0x37, 0xdd, 0xa6, 0xab, 0x4b, 0x20, 0xd3, 0x3b, 0x90, 0x33, 0x39, - 0x91, 0x5f, 0x41, 0x81, 0xe2, 0xfa, 0x58, 0x8a, 0x3a, 0x25, 0xcc, 0xf5, 0xa8, 0x45, 0xae, 0x93, - 0x2a, 0x6e, 0x8c, 0xcf, 0xf1, 0x9c, 0x1e, 0xa1, 0x4c, 0xf0, 0x21, 0x8d, 0x91, 0xb4, 0x95, 0xf1, - 0x69, 0xbd, 0x91, 0x95, 0x17, 0x57, 0xa3, 0xa3, 0xa9, 0xe7, 0x70, 0xbb, 0x33, 0xca, 0x69, 0x2d, - 0x3a, 0xdc, 0xe3, 0x76, 0x5b, 0xb7, 0x1d, 0xce, 0x38, 0xbd, 0x9e, 0x52, 0xf9, 0x19, 0x80, 0xda, - 0x5d, 0x4e, 0xf1, 0x3e, 0x6e, 0x7b, 0x04, 0x96, 0x40, 0xda, 0xe6, 0xa4, 0xc3, 0x0a, 0xf1, 0x72, - 0x72, 0x29, 0x6f, 0xe4, 0x2f, 0x2f, 0x4a, 0xe9, 0x1d, 0xdf, 0x80, 0x02, 0xfb, 0x56, 0xee, 0xf4, - 0x61, 0x29, 0x76, 0xf2, 0xb2, 0x1c, 0xab, 0x3c, 0x4b, 0x80, 0xc2, 0x1f, 0xae, 0x85, 0xdb, 0x75, - 0xcf, 0xbc, 0x43, 0x2c, 0x5e, 0xb5, 0x2c, 0xc2, 0x18, 0x22, 0x3d, 0x9b, 0x1c, 0xc1, 0x7f, 0x41, - 0xae, 0x23, 0x0e, 0xa2, 0x81, 0x39, 0x16, 0x50, 0xf1, 0xa5, 0xa9, 0xf5, 0x25, 0x6d, 0xec, 0x21, - 0x8a, 0x53, 0xd3, 0xfe, 0x94, 0x18, 0xbb, 0x22, 0xc7, 0x80, 0x67, 0x17, 0xa5, 0x98, 0x28, 0x0c, - 0x42, 0x1b, 0x1a, 0xa0, 0xc1, 0x16, 0x48, 0xb1, 0x2e, 0xb1, 0x0a, 0x09, 0x89, 0xba, 0xa3, 0x4d, - 0x2a, 0x0d, 0x2d, 0x82, 0x6e, 0x5d, 0x00, 0x1a, 0x5f, 0xa9, 0xb2, 0x29, 0x7f, 0x86, 0x64, 0x11, - 0xc8, 0x40, 0x86, 0x71, 0xcc, 0x3d, 0x56, 0x48, 0xca, 0x72, 0xbf, 0xdf, 0x4c, 0x39, 0x09, 0x69, - 0x7c, 0xa3, 0x0a, 0x66, 0x82, 0x39, 0x52, 0xa5, 0x2a, 0xff, 0x83, 0xb9, 0x3d, 0xd7, 0x41, 0x4a, - 0x77, 0x55, 0xce, 0xa9, 0x6d, 0x7a, 0xa2, 0x12, 0x2c, 0x83, 0x54, 0x17, 0xf3, 0x43, 0xb9, 0xa1, - 0xf9, 0x90, 0xef, 0x5f, 0xc2, 0x86, 0xa4, 0xc7, 0x8f, 0x10, 0xca, 0x33, 0xe5, 0xe6, 0x5c, 0x89, - 0xd8, 0x17, 0x36, 0x24, 0x3d, 0x95, 0xc7, 0x09, 0x00, 0x23, 0xa0, 0x75, 0x90, 0x77, 0x70, 0x87, - 0xb0, 0x2e, 0xb6, 0x88, 0xc2, 0xff, 0x56, 0x65, 0xe7, 0xf7, 0xfa, 0x0e, 0x14, 0xc6, 0x7c, 0xb8, - 0x12, 0xfc, 0x01, 0xa4, 0x9b, 0xd4, 0xf5, 0xba, 0x72, 0xeb, 0xf2, 0xc6, 0xd7, 0x2a, 0x24, 0xbd, - 0xed, 0x1b, 0x51, 0xe0, 0x83, 0xcb, 0x20, 0xab, 0xae, 0x4a, 0x21, 0x25, 0xc3, 0xa6, 0x55, 0x58, - 0x76, 0x3f, 0x30, 0xa3, 0xbe, 0x1f, 0xae, 0x80, 0x5c, 0xff, 0x2e, 0x16, 0xd2, 0x32, 0x76, 0x46, - 0xc5, 0xe6, 0xfa, 0x0b, 0x42, 0x83, 0x08, 0xb8, 0x01, 0xa6, 0x98, 0x67, 0x0e, 0x12, 0x32, 0x32, - 0x61, 0x56, 0x25, 0x4c, 0xd5, 0x43, 0x17, 0xba, 0x1a, 0xe7, 0x2f, 0xcb, 0x5f, 0x63, 0x21, 0x3b, - 0xbc, 0x2c, 0x7f, 0x0b, 0x90, 0xf4, 0x54, 0x5e, 0x24, 0xc0, 0x7c, 0x9d, 0xb4, 0x0f, 0x3e, 0xaf, - 0xea, 0xdd, 0x21, 0xd5, 0xef, 0x7e, 0x84, 0x0c, 0xa3, 0x29, 0x7f, 0x59, 0xca, 0x7f, 0x92, 0x00, - 0xdf, 0xbf, 0x87, 0x28, 0xbc, 0x1f, 0x07, 0x90, 0x8e, 0x88, 0x57, 0x6d, 0xf5, 0x6f, 0x93, 0x33, - 0x1c, 0xbd, 0x08, 0xc6, 0x77, 0x82, 0x56, 0xc4, 0x05, 0x41, 0x11, 0x75, 0xe1, 0x69, 0x1c, 0xcc, - 0x39, 0x51, 0x37, 0x55, 0x1d, 0xd3, 0xf6, 0xe4, 0x8c, 0x22, 0x2f, 0xbe, 0xb1, 0x20, 0x48, 0x45, - 0xff, 0x13, 0x50, 0x34, 0x81, 0xca, 0xd3, 0x04, 0x98, 0xbd, 0xfd, 0x2f, 0xdf, 0xac, 0x3a, 0xdf, - 0xa6, 0xc4, 0xcd, 0xbf, 0x55, 0xe6, 0xa7, 0x29, 0x73, 0xd0, 0x38, 0x92, 0xc3, 0x7f, 0xd8, 0x7f, - 0x18, 0xa1, 0xaa, 0x71, 0x94, 0xfb, 0x8d, 0x23, 0x25, 0xdf, 0x20, 0xc0, 0x3f, 0x0a, 0xd9, 0x34, - 0x58, 0xbf, 0x6b, 0x1c, 0x83, 0x34, 0xf1, 0xdf, 0x2c, 0xa2, 0x0f, 0x24, 0xc5, 0x6a, 0xfe, 0xbe, - 0x31, 0xb1, 0x69, 0xf2, 0x29, 0x54, 0x73, 0x38, 0x3d, 0x0e, 0x1b, 0x96, 0xb4, 0xa1, 0xa0, 0x62, - 0xb1, 0xa7, 0x9e, 0x4b, 0x32, 0x06, 0xce, 0x80, 0x64, 0x8b, 0x1c, 0x07, 0x0d, 0x13, 0xf9, 0x9f, - 0x10, 0x81, 0x74, 0xcf, 0x7f, 0x49, 0xa9, 0x8d, 0xfe, 0x65, 0x72, 0x6a, 0xe1, 0x6b, 0x0c, 0x05, - 0x50, 0x5b, 0x89, 0xcd, 0x78, 0xe5, 0x51, 0x1c, 0x2c, 0x8c, 0x95, 0xac, 0xdf, 0x46, 0x71, 0xbb, - 0xed, 0x1e, 0x91, 0x86, 0xe4, 0x92, 0x0b, 0xdb, 0x68, 0x35, 0x30, 0xa3, 0xbe, 0x1f, 0xfe, 0x08, - 0x32, 0x94, 0x60, 0x26, 0x1a, 0x6e, 0xd0, 0xba, 0x07, 0x6a, 0x47, 0xd2, 0x8a, 0x94, 0x17, 0x56, - 0xc1, 0x34, 0xf1, 0xcb, 0x4b, 0x72, 0x35, 0x4a, 0x5d, 0xaa, 0x8e, 0x6c, 0x5e, 0x25, 0x4c, 0xd7, - 0x86, 0xdd, 0xe8, 0x7a, 0xbc, 0xb1, 0x7c, 0xf6, 0x7a, 0x31, 0x76, 0x2e, 0xc6, 0x73, 0x31, 0x4e, - 0x2e, 0x17, 0xe3, 0x67, 0x62, 0x9c, 0x8b, 0xf1, 0x4a, 0x8c, 0x07, 0x6f, 0x16, 0x63, 0xff, 0x65, - 0xd5, 0xa2, 0xdf, 0x05, 0x00, 0x00, 0xff, 0xff, 0x0c, 0xa4, 0x8c, 0xef, 0x24, 0x0c, 0x00, 0x00, + // 874 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x56, 0x41, 0x8f, 0xdb, 0x44, + 0x14, 0x8e, 0x93, 0x78, 0x37, 0x99, 0x05, 0xb6, 0x4c, 0x55, 0xd6, 0x0d, 0x92, 0x13, 0x05, 0x09, + 0x6d, 0xa5, 0xd6, 0x66, 0x57, 0xaa, 0xa8, 0x2a, 0x0e, 0xac, 0xc5, 0xaa, 0xaa, 0xa0, 0x05, 0xcd, + 0xc2, 0x0a, 0xc1, 0x69, 0xec, 0x7d, 0x4d, 0x4c, 0x12, 0x8f, 0x35, 0x33, 0x76, 0x59, 0x4e, 0xfd, + 0x01, 0x1c, 0x38, 0xf6, 0xc8, 0x5f, 0xe0, 0x0f, 0x70, 0x65, 0x8f, 0xe5, 0x82, 0x40, 0x42, 0x11, + 0x6b, 0xfe, 0x05, 0x27, 0xe4, 0xf1, 0x24, 0x6e, 0x36, 0x0e, 0x28, 0xb0, 0x42, 0x1c, 0x7a, 0xf3, + 0xbc, 0xf7, 0xbd, 0xf7, 0xbe, 0x99, 0xf9, 0xc6, 0xef, 0xa1, 0x77, 0x47, 0x77, 0x84, 0x13, 0x32, + 0x77, 0x94, 0xf8, 0xc0, 0x23, 0x90, 0x20, 0xdc, 0x78, 0x34, 0x70, 0x69, 0x1c, 0x0a, 0x97, 0x26, + 0x72, 0xc8, 0x78, 0xf8, 0x15, 0x95, 0x21, 0x8b, 0xdc, 0x74, 0xcf, 0x07, 0x49, 0xf7, 0xdc, 0x01, + 0x44, 0xc0, 0xa9, 0x84, 0x13, 0x27, 0xe6, 0x4c, 0x32, 0xfc, 0x56, 0x91, 0xc1, 0x29, 0x33, 0x38, + 0xf1, 0x68, 0xe0, 0xe4, 0x19, 0x9c, 0x85, 0x0c, 0x8e, 0xce, 0xd0, 0xb9, 0x35, 0x08, 0xe5, 0x30, + 0xf1, 0x9d, 0x80, 0x4d, 0xdc, 0x01, 0x1b, 0x30, 0x57, 0x25, 0xf2, 0x93, 0x47, 0x6a, 0xa5, 0x16, + 0xea, 0xab, 0x28, 0xd0, 0xd9, 0x5f, 0x49, 0xd1, 0xe5, 0x20, 0x58, 0xc2, 0x03, 0xb8, 0x48, 0xaa, + 0x73, 0x7b, 0x75, 0x4c, 0x12, 0xa5, 0xc0, 0x45, 0xc8, 0x22, 0x38, 0x59, 0x0a, 0xbb, 0xb9, 0x3a, + 0x2c, 0x5d, 0xda, 0x79, 0xe7, 0x56, 0x35, 0x9a, 0x27, 0x91, 0x0c, 0x27, 0xcb, 0x9c, 0xf6, 0xaa, + 0xe1, 0x89, 0x0c, 0xc7, 0x6e, 0x18, 0x49, 0x21, 0xf9, 0xc5, 0x90, 0xfe, 0xdb, 0x08, 0x1d, 0x7e, + 0x29, 0x39, 0x3d, 0xa6, 0xe3, 0x04, 0x70, 0x17, 0x99, 0xa1, 0x84, 0x89, 0xb0, 0x8c, 0x5e, 0x63, + 0xb7, 0xed, 0xb5, 0xb3, 0x69, 0xd7, 0xbc, 0x9f, 0x1b, 0x48, 0x61, 0xbf, 0xdb, 0x7a, 0xfa, 0x6d, + 0xb7, 0xf6, 0xe4, 0xd7, 0x5e, 0xad, 0xff, 0x53, 0x1d, 0x59, 0x1f, 0xb0, 0x80, 0x8e, 0x8f, 0x12, + 0xff, 0x0b, 0x08, 0xe4, 0x41, 0x10, 0x80, 0x10, 0x04, 0xd2, 0x10, 0x1e, 0xe3, 0x4f, 0x51, 0x6b, + 0x02, 0x92, 0x9e, 0x50, 0x49, 0x2d, 0xa3, 0x67, 0xec, 0x6e, 0xed, 0xef, 0x3a, 0x2b, 0x2f, 0xd1, + 0x49, 0xf7, 0x9c, 0x0f, 0x55, 0x8e, 0x07, 0x20, 0xa9, 0x87, 0xcf, 0xa6, 0xdd, 0x5a, 0x36, 0xed, + 0xa2, 0xd2, 0x46, 0xe6, 0xd9, 0xf0, 0x08, 0x35, 0x45, 0x0c, 0x81, 0x55, 0x57, 0x59, 0xef, 0x3b, + 0xeb, 0x4a, 0xc3, 0xa9, 0xa0, 0x7b, 0x14, 0x43, 0xe0, 0xbd, 0xa4, 0xcb, 0x36, 0xf3, 0x15, 0x51, + 0x45, 0xb0, 0x40, 0x1b, 0x42, 0x52, 0x99, 0x08, 0xab, 0xa1, 0xca, 0xbd, 0x7f, 0x39, 0xe5, 0x54, + 0x4a, 0xef, 0x15, 0x5d, 0x70, 0xa3, 0x58, 0x13, 0x5d, 0xaa, 0xff, 0x39, 0xba, 0xf6, 0x90, 0x45, + 0x44, 0xeb, 0xee, 0x40, 0x4a, 0x1e, 0xfa, 0x89, 0x04, 0x81, 0x7b, 0xa8, 0x19, 0x53, 0x39, 0x54, + 0x07, 0xda, 0x2e, 0xf9, 0x7e, 0x44, 0xe5, 0x90, 0x28, 0x4f, 0x8e, 0x48, 0x81, 0xfb, 0xea, 0x70, + 0x9e, 0x43, 0x1c, 0x03, 0xf7, 0x89, 0xf2, 0xf4, 0xbf, 0xaf, 0x23, 0x5c, 0x91, 0xda, 0x45, 0xed, + 0x88, 0x4e, 0x40, 0xc4, 0x34, 0x00, 0x9d, 0xff, 0x55, 0x1d, 0xdd, 0x7e, 0x38, 0x73, 0x90, 0x12, + 0xf3, 0xf7, 0x95, 0xf0, 0x1b, 0xc8, 0x1c, 0x70, 0x96, 0xc4, 0xea, 0xe8, 0xda, 0xde, 0xcb, 0x1a, + 0x62, 0xde, 0xcb, 0x8d, 0xa4, 0xf0, 0xe1, 0x1b, 0x68, 0x53, 0x3f, 0x15, 0xab, 0xa9, 0x60, 0xdb, + 0x1a, 0xb6, 0x79, 0x5c, 0x98, 0xc9, 0xcc, 0x8f, 0x6f, 0xa2, 0xd6, 0xec, 0x2d, 0x5a, 0xa6, 0xc2, + 0x5e, 0xd1, 0xd8, 0xd6, 0x6c, 0x43, 0x64, 0x8e, 0xc0, 0xb7, 0xd1, 0x96, 0x48, 0xfc, 0x79, 0xc0, + 0x86, 0x0a, 0xb8, 0xaa, 0x03, 0xb6, 0x8e, 0x4a, 0x17, 0x79, 0x1e, 0x97, 0x6f, 0x2b, 0xdf, 0xa3, + 0xb5, 0xb9, 0xb8, 0xad, 0xfc, 0x08, 0x88, 0xf2, 0xf4, 0x7f, 0xa9, 0xa3, 0x9d, 0x23, 0x18, 0x3f, + 0xfa, 0x6f, 0x55, 0xcf, 0x16, 0x54, 0xff, 0xe0, 0x1f, 0xc8, 0xb0, 0x9a, 0xf2, 0xff, 0x4b, 0xf9, + 0x3f, 0xd4, 0xd1, 0xeb, 0x7f, 0x41, 0x14, 0x7f, 0x6d, 0x20, 0xcc, 0x97, 0xc4, 0xab, 0x8f, 0xfa, + 0xbd, 0xf5, 0x19, 0x2e, 0x3f, 0x04, 0xef, 0xb5, 0x6c, 0xda, 0xad, 0x78, 0x20, 0xa4, 0xa2, 0x2e, + 0x7e, 0x6a, 0xa0, 0x6b, 0x51, 0xd5, 0x4b, 0xd5, 0xd7, 0x74, 0x6f, 0x7d, 0x46, 0x95, 0x0f, 0xdf, + 0xbb, 0x9e, 0x4d, 0xbb, 0xd5, 0xff, 0x04, 0x52, 0x4d, 0xa0, 0xff, 0x63, 0x1d, 0x5d, 0x7d, 0xf1, + 0x5f, 0xbe, 0x5c, 0x75, 0xfe, 0xd1, 0x44, 0x3b, 0x2f, 0x94, 0xf9, 0x2f, 0x95, 0x39, 0x6f, 0x1c, + 0x8d, 0xc5, 0x3f, 0xec, 0x27, 0x02, 0xb8, 0x6e, 0x1c, 0xbd, 0x59, 0xe3, 0x68, 0xaa, 0x19, 0x04, + 0xe5, 0x57, 0xa1, 0x9a, 0x86, 0x98, 0x75, 0x8d, 0x53, 0x64, 0x42, 0x3e, 0xb3, 0x58, 0x66, 0xaf, + 0xb1, 0xbb, 0xb5, 0xff, 0xf1, 0xa5, 0x89, 0xcd, 0x51, 0xa3, 0xd0, 0x61, 0x24, 0xf9, 0x69, 0xd9, + 0xb0, 0x94, 0x8d, 0x14, 0x15, 0x3b, 0xa9, 0x1e, 0x97, 0x14, 0x06, 0x5f, 0x41, 0x8d, 0x11, 0x9c, + 0x16, 0x0d, 0x93, 0xe4, 0x9f, 0x98, 0x20, 0x33, 0xcd, 0x27, 0x29, 0x7d, 0xd0, 0xef, 0xac, 0x4f, + 0xad, 0x9c, 0xc6, 0x48, 0x91, 0xea, 0x6e, 0xfd, 0x8e, 0xd1, 0xff, 0xce, 0x40, 0xd7, 0x57, 0x4a, + 0x36, 0x6f, 0xa3, 0x74, 0x3c, 0x66, 0x8f, 0xe1, 0x44, 0x71, 0x69, 0x95, 0x6d, 0xf4, 0xa0, 0x30, + 0x93, 0x99, 0x1f, 0xbf, 0x89, 0x36, 0x38, 0x50, 0xc1, 0x22, 0xdd, 0xba, 0xe7, 0x6a, 0x27, 0xca, + 0x4a, 0xb4, 0x17, 0x1f, 0xa0, 0x6d, 0xc8, 0xcb, 0x2b, 0x72, 0x87, 0x9c, 0x33, 0xae, 0xaf, 0x6c, + 0x47, 0x07, 0x6c, 0x1f, 0x2e, 0xba, 0xc9, 0x45, 0xbc, 0x77, 0xe3, 0xec, 0xdc, 0xae, 0x3d, 0x3b, + 0xb7, 0x6b, 0x3f, 0x9f, 0xdb, 0xb5, 0x27, 0x99, 0x6d, 0x9c, 0x65, 0xb6, 0xf1, 0x2c, 0xb3, 0x8d, + 0xdf, 0x32, 0xdb, 0xf8, 0xe6, 0x77, 0xbb, 0xf6, 0xd9, 0xa6, 0xde, 0xf4, 0x9f, 0x01, 0x00, 0x00, + 0xff, 0xff, 0x0c, 0xa4, 0x8c, 0xef, 0x24, 0x0c, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.proto similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.proto index bd98cee..b3df897 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/generated.proto @@ -43,6 +43,7 @@ message ExtraValue { // Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions // checking. message LocalSubjectAccessReview { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec holds information about the request being evaluated. spec.namespace must be equal to the namespace @@ -50,15 +51,18 @@ message LocalSubjectAccessReview { optional SubjectAccessReviewSpec spec = 2; // Status is filled in by the server and indicates whether the request is allowed or not + // +optional optional SubjectAccessReviewStatus status = 3; } // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface message NonResourceAttributes { // Path is the URL path of the request + // +optional optional string path = 1; // Verb is the standard HTTP verb + // +optional optional string verb = 2; } @@ -68,24 +72,31 @@ message ResourceAttributes { // "" (empty) is defaulted for LocalSubjectAccessReviews // "" (empty) is empty for cluster-scoped resources // "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview + // +optional optional string namespace = 1; // Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy. "*" means all. + // +optional optional string verb = 2; // Group is the API Group of the Resource. "*" means all. + // +optional optional string group = 3; // Version is the API Version of the Resource. "*" means all. + // +optional optional string version = 4; // Resource is one of the existing resource types. "*" means all. + // +optional optional string resource = 5; // Subresource is one of the existing resource types. "" means none. + // +optional optional string subresource = 6; // Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. + // +optional optional string name = 7; } @@ -93,12 +104,14 @@ message ResourceAttributes { // spec.namespace means "in all namespaces". Self is a special case, because users should always be able // to check whether they can perform an action message SelfSubjectAccessReview { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec holds information about the request being evaluated. user and groups must be empty optional SelfSubjectAccessReviewSpec spec = 2; // Status is filled in by the server and indicates whether the request is allowed or not + // +optional optional SubjectAccessReviewStatus status = 3; } @@ -106,20 +119,24 @@ message SelfSubjectAccessReview { // and NonResourceAuthorizationAttributes must be set message SelfSubjectAccessReviewSpec { // ResourceAuthorizationAttributes describes information for a resource access request + // +optional optional ResourceAttributes resourceAttributes = 1; // NonResourceAttributes describes information for a non-resource access request + // +optional optional NonResourceAttributes nonResourceAttributes = 2; } // SubjectAccessReview checks whether or not a user or group can perform an action. message SubjectAccessReview { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec holds information about the request being evaluated optional SubjectAccessReviewSpec spec = 2; // Status is filled in by the server and indicates whether the request is allowed or not + // +optional optional SubjectAccessReviewStatus status = 3; } @@ -127,20 +144,25 @@ message SubjectAccessReview { // and NonResourceAuthorizationAttributes must be set message SubjectAccessReviewSpec { // ResourceAuthorizationAttributes describes information for a resource access request + // +optional optional ResourceAttributes resourceAttributes = 1; // NonResourceAttributes describes information for a non-resource access request + // +optional optional NonResourceAttributes nonResourceAttributes = 2; // User is the user you're testing for. // If you specify "User" but not "Group", then is it interpreted as "What if User were not a member of any groups + // +optional optional string verb = 3; // Groups is the groups you're testing for. + // +optional repeated string group = 4; // Extra corresponds to the user.Info.GetExtra() method from the authenticator. Since that is input to the authorizer // it needs a reflection here. + // +optional map extra = 5; } @@ -150,11 +172,13 @@ message SubjectAccessReviewStatus { optional bool allowed = 1; // Reason is optional. It indicates why a request was allowed or denied. + // +optional optional string reason = 2; // EvaluationError is an indication that some error occurred during the authorization check. // It is entirely possible to get an error and be able to continue determine authorization status in spite of it. // For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. + // +optional optional string evaluationError = 3; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/register.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/register.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/register.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/register.go index 1b072d6..dec6443 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.generated.go index 0e640de..011c08f 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.go index 67a23ee..b254b3b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types.go @@ -19,8 +19,8 @@ package v1beta1 import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true @@ -30,12 +30,14 @@ import ( // SubjectAccessReview checks whether or not a user or group can perform an action. type SubjectAccessReview struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec holds information about the request being evaluated Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` // Status is filled in by the server and indicates whether the request is allowed or not + // +optional Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -48,12 +50,14 @@ type SubjectAccessReview struct { // to check whether they can perform an action type SelfSubjectAccessReview struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec holds information about the request being evaluated. user and groups must be empty Spec SelfSubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` // Status is filled in by the server and indicates whether the request is allowed or not + // +optional Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -65,13 +69,15 @@ type SelfSubjectAccessReview struct { // checking. type LocalSubjectAccessReview struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec holds information about the request being evaluated. spec.namespace must be equal to the namespace // you made the request against. If empty, it is defaulted. Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` // Status is filled in by the server and indicates whether the request is allowed or not + // +optional Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -81,26 +87,35 @@ type ResourceAttributes struct { // "" (empty) is defaulted for LocalSubjectAccessReviews // "" (empty) is empty for cluster-scoped resources // "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview + // +optional Namespace string `json:"namespace,omitempty" protobuf:"bytes,1,opt,name=namespace"` // Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy. "*" means all. + // +optional Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` // Group is the API Group of the Resource. "*" means all. + // +optional Group string `json:"group,omitempty" protobuf:"bytes,3,opt,name=group"` // Version is the API Version of the Resource. "*" means all. + // +optional Version string `json:"version,omitempty" protobuf:"bytes,4,opt,name=version"` // Resource is one of the existing resource types. "*" means all. + // +optional Resource string `json:"resource,omitempty" protobuf:"bytes,5,opt,name=resource"` // Subresource is one of the existing resource types. "" means none. + // +optional Subresource string `json:"subresource,omitempty" protobuf:"bytes,6,opt,name=subresource"` // Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. + // +optional Name string `json:"name,omitempty" protobuf:"bytes,7,opt,name=name"` } // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface type NonResourceAttributes struct { // Path is the URL path of the request + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` // Verb is the standard HTTP verb + // +optional Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` } @@ -108,17 +123,22 @@ type NonResourceAttributes struct { // and NonResourceAuthorizationAttributes must be set type SubjectAccessReviewSpec struct { // ResourceAuthorizationAttributes describes information for a resource access request + // +optional ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` // NonResourceAttributes describes information for a non-resource access request + // +optional NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` // User is the user you're testing for. // If you specify "User" but not "Group", then is it interpreted as "What if User were not a member of any groups + // +optional User string `json:"user,omitempty" protobuf:"bytes,3,opt,name=verb"` // Groups is the groups you're testing for. + // +optional Groups []string `json:"group,omitempty" protobuf:"bytes,4,rep,name=group"` // Extra corresponds to the user.Info.GetExtra() method from the authenticator. Since that is input to the authorizer // it needs a reflection here. + // +optional Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,5,rep,name=extra"` } @@ -135,8 +155,10 @@ func (t ExtraValue) String() string { // and NonResourceAuthorizationAttributes must be set type SelfSubjectAccessReviewSpec struct { // ResourceAuthorizationAttributes describes information for a resource access request + // +optional ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` // NonResourceAttributes describes information for a non-resource access request + // +optional NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` } @@ -145,9 +167,11 @@ type SubjectAccessReviewStatus struct { // Allowed is required. True if the action would be allowed, false otherwise. Allowed bool `json:"allowed" protobuf:"varint,1,opt,name=allowed"` // Reason is optional. It indicates why a request was allowed or denied. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,2,opt,name=reason"` // EvaluationError is an indication that some error occurred during the authorization check. // It is entirely possible to get an error and be able to continue determine authorization status in spite of it. // For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. + // +optional EvaluationError string `json:"evaluationError,omitempty" protobuf:"bytes,3,opt,name=evaluationError"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.conversion.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.conversion.go index 03e1963..7d9dfcc 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - authorization "k8s.io/kubernetes/pkg/apis/authorization" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + authorization "k8s.io/client-go/pkg/apis/authorization" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -55,9 +54,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1beta1_LocalSubjectAccessReview_To_authorization_LocalSubjectAccessReview(in *LocalSubjectAccessReview, out *authorization.LocalSubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -76,9 +72,6 @@ func Convert_v1beta1_LocalSubjectAccessReview_To_authorization_LocalSubjectAcces } func autoConvert_authorization_LocalSubjectAccessReview_To_v1beta1_LocalSubjectAccessReview(in *authorization.LocalSubjectAccessReview, out *LocalSubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -147,9 +140,6 @@ func Convert_authorization_ResourceAttributes_To_v1beta1_ResourceAttributes(in * } func autoConvert_v1beta1_SelfSubjectAccessReview_To_authorization_SelfSubjectAccessReview(in *SelfSubjectAccessReview, out *authorization.SelfSubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -168,9 +158,6 @@ func Convert_v1beta1_SelfSubjectAccessReview_To_authorization_SelfSubjectAccessR } func autoConvert_authorization_SelfSubjectAccessReview_To_v1beta1_SelfSubjectAccessReview(in *authorization.SelfSubjectAccessReview, out *SelfSubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -241,9 +228,6 @@ func Convert_authorization_SelfSubjectAccessReviewSpec_To_v1beta1_SelfSubjectAcc } func autoConvert_v1beta1_SubjectAccessReview_To_authorization_SubjectAccessReview(in *SubjectAccessReview, out *authorization.SubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -262,9 +246,6 @@ func Convert_v1beta1_SubjectAccessReview_To_authorization_SubjectAccessReview(in } func autoConvert_authorization_SubjectAccessReview_To_v1beta1_SubjectAccessReview(in *authorization.SubjectAccessReview, out *SubjectAccessReview, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go index c365c8d..373c279 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/v1beta1/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package v1beta1 import ( - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/authorization/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/authorization/zz_generated.deepcopy.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/authorization/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/authorization/zz_generated.deepcopy.go index bf80861..ce70373 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/authorization/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/authorization/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package authorization import ( - api "k8s.io/kubernetes/pkg/api" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/doc.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/doc.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/install/install.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/install/install.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/install/install.go index 5d498ba..060aa07 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/install/install.go @@ -19,9 +19,9 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/apis/autoscaling/v1" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/autoscaling" + "k8s.io/client-go/pkg/apis/autoscaling/v1" ) func init() { @@ -29,7 +29,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: autoscaling.GroupName, VersionPreferenceOrder: []string{v1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/autoscaling", + ImportPrefix: "k8s.io/client-go/pkg/apis/autoscaling", AddInternalObjectsToScheme: autoscaling.AddToScheme, }, announced.VersionToSchemeFunc{ diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/register.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/register.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/register.go index 0eed5d2..d4aa8ee 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/register.go @@ -17,9 +17,9 @@ limitations under the License. package autoscaling import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/types.generated.go index ecca35d..89e5ff8 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg2_api "k8s.io/client-go/pkg/api" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/types.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/types.go index 0ec8a48..438d82b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/types.go @@ -17,26 +17,30 @@ limitations under the License. package autoscaling import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // Scale represents a scaling request for a resource. type Scale struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional api.ObjectMeta `json:"metadata,omitempty"` // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec ScaleSpec `json:"spec,omitempty"` // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional Status ScaleStatus `json:"status,omitempty"` } // ScaleSpec describes the attributes of a scale subresource. type ScaleSpec struct { // desired number of instances for the scaled object. + // +optional Replicas int32 `json:"replicas,omitempty"` } @@ -49,6 +53,7 @@ type ScaleStatus struct { // as the label selector but in the string format to avoid introspection // by clients. The string will be in the same format as the query-param syntax. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector string `json:"selector,omitempty"` } @@ -59,6 +64,7 @@ type CrossVersionObjectReference struct { // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names Name string `json:"name" protobuf:"bytes,2,opt,name=name"` // API version of the referent + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` } @@ -68,21 +74,25 @@ type HorizontalPodAutoscalerSpec struct { // and will set the desired number of pods by using its Scale subresource. ScaleTargetRef CrossVersionObjectReference `json:"scaleTargetRef"` // lower limit for the number of pods that can be set by the autoscaler, default 1. + // +optional MinReplicas *int32 `json:"minReplicas,omitempty"` // upper limit for the number of pods that can be set by the autoscaler. It cannot be smaller than MinReplicas. MaxReplicas int32 `json:"maxReplicas"` // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; // if not specified the default autoscaling policy will be used. + // +optional TargetCPUUtilizationPercentage *int32 `json:"targetCPUUtilizationPercentage,omitempty"` } // current status of a horizontal pod autoscaler type HorizontalPodAutoscalerStatus struct { // most recent generation observed by this autoscaler. + // +optional ObservedGeneration *int64 `json:"observedGeneration,omitempty"` // last time the HorizontalPodAutoscaler scaled the number of pods; // used by the autoscaler to control how often the number of pods is changed. + // +optional LastScaleTime *unversioned.Time `json:"lastScaleTime,omitempty"` // current number of replicas of pods managed by this autoscaler. @@ -93,6 +103,7 @@ type HorizontalPodAutoscalerStatus struct { // current average CPU utilization over all pods, represented as a percentage of requested CPU, // e.g. 70 means that an average pod is using now 70% of its requested CPU. + // +optional CurrentCPUUtilizationPercentage *int32 `json:"currentCPUUtilizationPercentage,omitempty"` } @@ -101,18 +112,22 @@ type HorizontalPodAutoscalerStatus struct { // configuration of a horizontal pod autoscaler. type HorizontalPodAutoscaler struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // behaviour of autoscaler. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty"` // current information about the autoscaler. + // +optional Status HorizontalPodAutoscalerStatus `json:"status,omitempty"` } // list of horizontal pod autoscaler objects. type HorizontalPodAutoscalerList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // list of horizontal pod autoscaler objects. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/defaults.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/defaults.go index e374add..dc0c90c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/defaults.go @@ -17,10 +17,11 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( SetDefaults_HorizontalPodAutoscaler, ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/doc.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/doc.go index f89c5c8..105a57a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/doc.go @@ -17,5 +17,6 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/autoscaling // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.pb.go similarity index 87% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.pb.go index 769f01b..2c7c484 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.pb.go @@ -40,7 +40,7 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" import strings "strings" import reflect "reflect" @@ -97,14 +97,14 @@ func (*ScaleStatus) ProtoMessage() {} func (*ScaleStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{7} } func init() { - proto.RegisterType((*CrossVersionObjectReference)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.CrossVersionObjectReference") - proto.RegisterType((*HorizontalPodAutoscaler)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.HorizontalPodAutoscaler") - proto.RegisterType((*HorizontalPodAutoscalerList)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerList") - proto.RegisterType((*HorizontalPodAutoscalerSpec)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerSpec") - proto.RegisterType((*HorizontalPodAutoscalerStatus)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerStatus") - proto.RegisterType((*Scale)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.Scale") - proto.RegisterType((*ScaleSpec)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.ScaleSpec") - proto.RegisterType((*ScaleStatus)(nil), "k8s.io.kubernetes.pkg.apis.autoscaling.v1.ScaleStatus") + proto.RegisterType((*CrossVersionObjectReference)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.CrossVersionObjectReference") + proto.RegisterType((*HorizontalPodAutoscaler)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.HorizontalPodAutoscaler") + proto.RegisterType((*HorizontalPodAutoscalerList)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerList") + proto.RegisterType((*HorizontalPodAutoscalerSpec)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerSpec") + proto.RegisterType((*HorizontalPodAutoscalerStatus)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.HorizontalPodAutoscalerStatus") + proto.RegisterType((*Scale)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.Scale") + proto.RegisterType((*ScaleSpec)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.ScaleSpec") + proto.RegisterType((*ScaleStatus)(nil), "k8s.io.client-go.pkg.apis.autoscaling.v1.ScaleStatus") } func (m *CrossVersionObjectReference) Marshal() (data []byte, err error) { size := m.Size() @@ -1730,57 +1730,58 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 823 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xb4, 0x55, 0xcf, 0x4f, 0xe3, 0x46, - 0x14, 0x26, 0xbf, 0x10, 0x8c, 0x0b, 0xb4, 0x53, 0x09, 0xa2, 0x54, 0x4d, 0x90, 0xdb, 0x03, 0x55, - 0xc1, 0x56, 0xa2, 0x52, 0x95, 0x23, 0x4e, 0x45, 0x41, 0x85, 0x12, 0x0d, 0x3f, 0x54, 0x55, 0x6a, - 0x25, 0xc7, 0x1e, 0xcc, 0x90, 0xc4, 0x8e, 0x66, 0xc6, 0x51, 0xc5, 0xa9, 0xa7, 0x9e, 0x7b, 0xe9, - 0xa1, 0xff, 0x4e, 0x4f, 0xdc, 0xca, 0xb1, 0x27, 0xb4, 0xcb, 0x6a, 0xff, 0x8b, 0x3d, 0xec, 0x78, - 0x3c, 0x38, 0x4e, 0x82, 0x03, 0xd1, 0xee, 0x1e, 0x46, 0xca, 0xcc, 0x7c, 0xdf, 0xf7, 0xde, 0x7c, - 0xef, 0xf9, 0x05, 0xec, 0x74, 0xbe, 0x63, 0x06, 0x09, 0xcc, 0x4e, 0xd8, 0xc6, 0xd4, 0xc7, 0x1c, - 0x33, 0xb3, 0xdf, 0xf1, 0x4c, 0xbb, 0x4f, 0x98, 0x69, 0x87, 0x3c, 0x60, 0x8e, 0xdd, 0x25, 0xbe, - 0x67, 0x0e, 0xea, 0xa6, 0x87, 0x7d, 0x4c, 0x6d, 0x8e, 0x5d, 0xa3, 0x4f, 0x03, 0x1e, 0xc0, 0xaf, - 0x62, 0xaa, 0x31, 0xa4, 0x1a, 0x82, 0x6a, 0x44, 0x54, 0x23, 0x45, 0x35, 0x06, 0xf5, 0xca, 0x96, - 0x47, 0xf8, 0x65, 0xd8, 0x36, 0x9c, 0xa0, 0x67, 0x7a, 0x81, 0x17, 0x98, 0x52, 0xa1, 0x1d, 0x5e, - 0xc8, 0x9d, 0xdc, 0xc8, 0x5f, 0xb1, 0x72, 0xa5, 0x91, 0x99, 0x94, 0x49, 0x31, 0x0b, 0x42, 0xea, - 0xe0, 0xf1, 0x6c, 0x2a, 0xdb, 0xd9, 0x9c, 0xd0, 0x1f, 0x60, 0xca, 0x48, 0xe0, 0x63, 0x77, 0x82, - 0xb6, 0x99, 0x4d, 0x9b, 0x7c, 0x72, 0x65, 0xeb, 0x71, 0x34, 0x0d, 0x7d, 0x4e, 0x7a, 0x93, 0x39, - 0xd5, 0x1f, 0x87, 0x87, 0x9c, 0x74, 0x4d, 0xe2, 0x73, 0xc6, 0xe9, 0x38, 0x45, 0xff, 0x3b, 0x07, - 0x3e, 0x6b, 0xd2, 0x80, 0xb1, 0xf3, 0x38, 0xe5, 0xe3, 0xf6, 0x15, 0x76, 0x38, 0xc2, 0x17, 0x98, - 0x62, 0xdf, 0xc1, 0x70, 0x1d, 0x14, 0x3b, 0xc4, 0x77, 0xcb, 0xb9, 0xf5, 0xdc, 0xc6, 0xa2, 0xf5, - 0xd1, 0xcd, 0x5d, 0x6d, 0xee, 0xfe, 0xae, 0x56, 0xfc, 0x51, 0x9c, 0x21, 0x79, 0x13, 0x21, 0x7c, - 0xbb, 0x87, 0xcb, 0xf9, 0x51, 0xc4, 0x4f, 0xe2, 0x0c, 0xc9, 0x1b, 0xd8, 0x00, 0x40, 0xbc, 0x4f, - 0x05, 0x28, 0x17, 0x24, 0x0e, 0x2a, 0x1c, 0xd8, 0x6d, 0x1d, 0xa8, 0x1b, 0x94, 0x42, 0xe9, 0xff, - 0xe5, 0xc1, 0xda, 0x7e, 0x40, 0xc9, 0x75, 0xe0, 0x73, 0xbb, 0xdb, 0x0a, 0xdc, 0x5d, 0x55, 0x61, - 0x4c, 0xe1, 0xcf, 0x60, 0xa1, 0x87, 0xb9, 0xed, 0xda, 0xdc, 0x96, 0x79, 0x69, 0x8d, 0x0d, 0x23, - 0xb3, 0x37, 0x44, 0x3b, 0x18, 0xf1, 0xa3, 0x8e, 0x04, 0x67, 0x18, 0x77, 0x78, 0x86, 0x12, 0x35, - 0x78, 0x09, 0x8a, 0xac, 0x8f, 0x1d, 0xf9, 0x16, 0xad, 0xb1, 0x67, 0x3c, 0xbb, 0xe3, 0x8c, 0x8c, - 0x5c, 0x4f, 0x84, 0xda, 0xd0, 0x93, 0x68, 0x87, 0x64, 0x04, 0xd8, 0x07, 0xf3, 0x8c, 0xdb, 0x3c, - 0x64, 0xd2, 0x0f, 0xad, 0xb1, 0xff, 0x1e, 0x62, 0x49, 0x3d, 0x6b, 0x59, 0x45, 0x9b, 0x8f, 0xf7, - 0x48, 0xc5, 0xd1, 0x5f, 0x8b, 0x4a, 0x67, 0x30, 0x0f, 0x09, 0xe3, 0xf0, 0xd7, 0x09, 0x57, 0xcd, - 0x29, 0xae, 0xa6, 0x7a, 0xdc, 0x88, 0xe8, 0xd2, 0xdc, 0x8f, 0x55, 0xe8, 0x85, 0x87, 0x93, 0x94, - 0xb5, 0x1e, 0x28, 0x11, 0x8e, 0x7b, 0x4c, 0x78, 0x5b, 0x10, 0xda, 0xd6, 0xbb, 0xbf, 0xd7, 0x5a, - 0x52, 0xe1, 0x4a, 0x07, 0x91, 0x30, 0x8a, 0xf5, 0xf5, 0x37, 0xf9, 0xcc, 0x77, 0x46, 0xfe, 0xc3, - 0x3f, 0x73, 0x60, 0x59, 0x6e, 0x4f, 0x6d, 0xea, 0xe1, 0xa8, 0xd5, 0xd5, 0x73, 0x67, 0x29, 0xf7, - 0x94, 0x4f, 0xc6, 0x5a, 0x55, 0x69, 0x2d, 0x9f, 0x8c, 0x44, 0x41, 0x63, 0x51, 0x61, 0x1d, 0x68, - 0x3d, 0xe2, 0x23, 0xdc, 0xef, 0x12, 0xc7, 0x66, 0xb2, 0xe7, 0x4a, 0xd6, 0x8a, 0x20, 0x6a, 0x47, - 0xc3, 0x63, 0x94, 0xc6, 0xc0, 0x6d, 0x41, 0xb1, 0x7f, 0x4f, 0x28, 0x05, 0x49, 0xf9, 0x54, 0xc5, - 0xd3, 0x8e, 0x86, 0x57, 0x28, 0x8d, 0x83, 0x57, 0xa0, 0xca, 0x65, 0xd8, 0x66, 0xeb, 0xec, 0x4c, - 0x0c, 0x03, 0x72, 0x6d, 0x73, 0x91, 0x78, 0x0b, 0x8b, 0xc1, 0x26, 0x4c, 0xf2, 0x70, 0xb9, 0x28, - 0x95, 0x74, 0xa1, 0x52, 0x3d, 0x9d, 0x8a, 0x44, 0x4f, 0x28, 0xe9, 0xff, 0x16, 0xc0, 0xe7, 0x53, - 0x1b, 0x14, 0xee, 0x01, 0x18, 0xb4, 0x19, 0xa6, 0x03, 0xec, 0xfe, 0x10, 0x4f, 0xa3, 0x68, 0x2c, - 0x44, 0x35, 0x28, 0x58, 0xab, 0x22, 0x03, 0x78, 0x3c, 0x71, 0x8b, 0x1e, 0x61, 0x40, 0x17, 0x2c, - 0x75, 0x6d, 0xc6, 0x63, 0x97, 0x89, 0x9a, 0x40, 0x5a, 0xe3, 0xeb, 0x67, 0x76, 0x6d, 0x44, 0xb1, - 0x3e, 0x11, 0xf1, 0x96, 0x0e, 0xd3, 0x2a, 0x68, 0x54, 0x14, 0xee, 0x82, 0x15, 0x27, 0xa4, 0xa2, - 0xb2, 0x7c, 0xcc, 0xf6, 0x35, 0x65, 0xfb, 0x4a, 0x73, 0xf4, 0x1a, 0x8d, 0xe3, 0x23, 0x09, 0x17, - 0x33, 0x42, 0xb1, 0x9b, 0x48, 0x14, 0x47, 0x25, 0xbe, 0x1f, 0xbd, 0x46, 0xe3, 0x78, 0xd8, 0x03, - 0x35, 0xa5, 0x9a, 0x59, 0xc2, 0x92, 0x94, 0xfc, 0x42, 0xc8, 0xd5, 0x9a, 0xd3, 0xa1, 0xe8, 0x29, - 0x2d, 0xfd, 0x9f, 0x3c, 0x28, 0x49, 0x0b, 0x3e, 0xe0, 0xac, 0x3d, 0x1f, 0x99, 0xb5, 0xdf, 0xcc, - 0xf0, 0xf1, 0xc9, 0xcc, 0x32, 0x27, 0xeb, 0x6f, 0x63, 0x93, 0xf5, 0xdb, 0x99, 0x95, 0xa7, 0xcf, - 0xd1, 0x1d, 0xb0, 0x98, 0x24, 0x00, 0x37, 0xc1, 0x02, 0x7d, 0xa8, 0x69, 0x4e, 0x16, 0x20, 0x99, - 0x81, 0x49, 0x31, 0x13, 0x84, 0x4e, 0x80, 0x96, 0x8a, 0x30, 0x1b, 0x39, 0x42, 0x33, 0xdc, 0x15, - 0x3e, 0x06, 0x54, 0xfd, 0xd7, 0x26, 0xe8, 0x13, 0x75, 0x8e, 0x12, 0x84, 0xf5, 0xe5, 0xcd, 0xcb, - 0xea, 0xdc, 0xad, 0x58, 0xff, 0x8b, 0xf5, 0xc7, 0x7d, 0x35, 0x77, 0x23, 0xd6, 0xad, 0x58, 0x2f, - 0xc4, 0xfa, 0xeb, 0x55, 0x75, 0xee, 0x97, 0xfc, 0xa0, 0xfe, 0x36, 0x00, 0x00, 0xff, 0xff, 0x45, - 0xec, 0x9a, 0x15, 0x8e, 0x09, 0x00, 0x00, + // 835 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xb4, 0x55, 0xcd, 0x6f, 0xdc, 0x44, + 0x14, 0x5f, 0xef, 0x47, 0x95, 0x8e, 0x49, 0x02, 0x83, 0xd4, 0xae, 0x52, 0x61, 0x47, 0x0b, 0x87, + 0x20, 0x5a, 0x5b, 0xbb, 0xa2, 0x88, 0x1e, 0xe3, 0xa0, 0xd2, 0x8a, 0x86, 0x46, 0x93, 0xb6, 0x42, + 0x48, 0x20, 0xcd, 0xda, 0xaf, 0xee, 0x74, 0xd7, 0x1e, 0x6b, 0x66, 0xbc, 0x42, 0x3d, 0x71, 0xe2, + 0xcc, 0x85, 0x03, 0xff, 0x0e, 0xa7, 0xdc, 0xe8, 0x91, 0xd3, 0x8a, 0x18, 0xf1, 0x5f, 0x70, 0x40, + 0x9e, 0x9d, 0x7a, 0xbf, 0xe2, 0x6d, 0x23, 0xe8, 0x6d, 0x67, 0xde, 0xef, 0xe3, 0xcd, 0x7b, 0xcf, + 0x6f, 0xd1, 0x9d, 0xd1, 0xe7, 0xd2, 0x63, 0xdc, 0x1f, 0xe5, 0x43, 0x10, 0x29, 0x28, 0x90, 0x7e, + 0x36, 0x8a, 0x7d, 0x9a, 0x31, 0xe9, 0xd3, 0x5c, 0x71, 0x19, 0xd2, 0x31, 0x4b, 0x63, 0x7f, 0xd2, + 0xf7, 0x63, 0x48, 0x41, 0x50, 0x05, 0x91, 0x97, 0x09, 0xae, 0x38, 0xfe, 0x78, 0x46, 0xf5, 0xe6, + 0x54, 0x2f, 0x1b, 0xc5, 0x5e, 0x49, 0xf5, 0x16, 0xa8, 0xde, 0xa4, 0xbf, 0x77, 0x2b, 0x66, 0xea, + 0x59, 0x3e, 0xf4, 0x42, 0x9e, 0xf8, 0x31, 0x8f, 0xb9, 0xaf, 0x15, 0x86, 0xf9, 0x53, 0x7d, 0xd2, + 0x07, 0xfd, 0x6b, 0xa6, 0xbc, 0x37, 0xa8, 0x4d, 0xca, 0x17, 0x20, 0x79, 0x2e, 0x42, 0x58, 0xcd, + 0x66, 0xef, 0x76, 0x3d, 0x27, 0x4f, 0x27, 0x20, 0x24, 0xe3, 0x29, 0x44, 0x6b, 0xb4, 0x9b, 0xf5, + 0xb4, 0xf5, 0x27, 0xef, 0xdd, 0xba, 0x18, 0x2d, 0xf2, 0x54, 0xb1, 0x64, 0x3d, 0xa7, 0xfe, 0xc5, + 0xf0, 0x5c, 0xb1, 0xb1, 0xcf, 0x52, 0x25, 0x95, 0x58, 0xa5, 0xf4, 0x7e, 0xb1, 0xd0, 0x8d, 0x23, + 0xc1, 0xa5, 0x7c, 0x32, 0x4b, 0xf9, 0xe1, 0xf0, 0x39, 0x84, 0x8a, 0xc0, 0x53, 0x10, 0x90, 0x86, + 0x80, 0xf7, 0x51, 0x7b, 0xc4, 0xd2, 0xa8, 0x6b, 0xed, 0x5b, 0x07, 0x57, 0x83, 0x77, 0xce, 0xa6, + 0x6e, 0xa3, 0x98, 0xba, 0xed, 0xaf, 0x58, 0x1a, 0x11, 0x1d, 0x29, 0x11, 0x29, 0x4d, 0xa0, 0xdb, + 0x5c, 0x46, 0x7c, 0x4d, 0x13, 0x20, 0x3a, 0x82, 0x07, 0x08, 0xd1, 0x8c, 0x19, 0x83, 0x6e, 0x4b, + 0xe3, 0xb0, 0xc1, 0xa1, 0xc3, 0x93, 0xfb, 0x26, 0x42, 0x16, 0x50, 0xbd, 0xdf, 0x9b, 0xe8, 0xfa, + 0x3d, 0x2e, 0xd8, 0x0b, 0x9e, 0x2a, 0x3a, 0x3e, 0xe1, 0xd1, 0xa1, 0xe9, 0x30, 0x08, 0xfc, 0x0d, + 0xda, 0x4a, 0x40, 0xd1, 0x88, 0x2a, 0xaa, 0xf3, 0xb2, 0x07, 0x07, 0x5e, 0xed, 0x6c, 0x78, 0x93, + 0xbe, 0x37, 0x7b, 0xd4, 0x31, 0x28, 0x3a, 0xf7, 0x9d, 0xdf, 0x91, 0x4a, 0x0d, 0x3f, 0x43, 0x6d, + 0x99, 0x41, 0xa8, 0xdf, 0x62, 0x0f, 0xee, 0x7a, 0x6f, 0x3c, 0x71, 0x5e, 0x4d, 0xae, 0xa7, 0x19, + 0x84, 0xf3, 0x9a, 0x94, 0x27, 0xa2, 0x1d, 0x70, 0x86, 0xae, 0x48, 0x45, 0x55, 0x2e, 0x75, 0x3d, + 0xec, 0xc1, 0xbd, 0xff, 0xc1, 0x4b, 0xeb, 0x05, 0x3b, 0xc6, 0xed, 0xca, 0xec, 0x4c, 0x8c, 0x4f, + 0xef, 0x6f, 0x0b, 0xdd, 0xa8, 0x61, 0x3e, 0x60, 0x52, 0xe1, 0xef, 0xd6, 0xaa, 0xea, 0x6f, 0xa8, + 0xea, 0xc2, 0x8c, 0x7b, 0x25, 0x5d, 0x17, 0xf7, 0x5d, 0x63, 0xbd, 0xf5, 0xea, 0x66, 0xa1, 0xb4, + 0x31, 0xea, 0x30, 0x05, 0x89, 0xec, 0x36, 0xf7, 0x5b, 0x07, 0xf6, 0x20, 0xf8, 0xef, 0xef, 0x0d, + 0xb6, 0x8d, 0x5d, 0xe7, 0x7e, 0x29, 0x4c, 0x66, 0xfa, 0xbd, 0x7f, 0x9a, 0xb5, 0xef, 0x2c, 0xeb, + 0x8f, 0x7f, 0xb2, 0xd0, 0x8e, 0x3e, 0x3e, 0xa2, 0x22, 0x86, 0x72, 0xd4, 0xcd, 0x73, 0x2f, 0xd3, + 0xee, 0x0d, 0x9f, 0x4c, 0x70, 0xcd, 0xa4, 0xb5, 0x73, 0xba, 0xe4, 0x42, 0x56, 0x5c, 0x71, 0x1f, + 0xd9, 0x09, 0x4b, 0x09, 0x64, 0x63, 0x16, 0x52, 0xa9, 0x67, 0xae, 0x13, 0xec, 0x16, 0x53, 0xd7, + 0x3e, 0x9e, 0x5f, 0x93, 0x45, 0x0c, 0xbe, 0x8d, 0xec, 0x84, 0xfe, 0x50, 0x51, 0x5a, 0x9a, 0xf2, + 0xbe, 0xf1, 0xb3, 0x8f, 0xe7, 0x21, 0xb2, 0x88, 0xc3, 0xcf, 0x91, 0xa3, 0xb4, 0xed, 0xd1, 0xc9, + 0xe3, 0xc7, 0x8a, 0x8d, 0xd9, 0x0b, 0xaa, 0x18, 0x4f, 0x4f, 0x40, 0x84, 0x90, 0x2a, 0x1a, 0x43, + 0xb7, 0xad, 0x95, 0x7a, 0xc5, 0xd4, 0x75, 0x1e, 0x6d, 0x44, 0x92, 0xd7, 0x28, 0xf5, 0x7e, 0x6b, + 0xa1, 0x0f, 0x36, 0x0e, 0x28, 0xbe, 0x8b, 0x30, 0x1f, 0x4a, 0x10, 0x13, 0x88, 0xbe, 0x9c, 0x6d, + 0xa3, 0x72, 0x2d, 0x94, 0x3d, 0x68, 0x05, 0xd7, 0x8a, 0xa9, 0x8b, 0x1f, 0xae, 0x45, 0xc9, 0x05, + 0x0c, 0x1c, 0xa1, 0xed, 0x31, 0x95, 0x6a, 0x56, 0x65, 0x66, 0x36, 0x90, 0x3d, 0xf8, 0xe4, 0x0d, + 0xa7, 0xb6, 0xa4, 0x04, 0xef, 0x15, 0x53, 0x77, 0xfb, 0xc1, 0xa2, 0x0a, 0x59, 0x16, 0xc5, 0x87, + 0x68, 0x37, 0xcc, 0x85, 0x80, 0x54, 0xad, 0x94, 0xfd, 0xba, 0x29, 0xfb, 0xee, 0xd1, 0x72, 0x98, + 0xac, 0xe2, 0x4b, 0x89, 0x08, 0x24, 0x13, 0x10, 0x55, 0x12, 0xed, 0x65, 0x89, 0x2f, 0x96, 0xc3, + 0x64, 0x15, 0x8f, 0x13, 0xe4, 0x1a, 0xd5, 0xda, 0x16, 0x76, 0xb4, 0xe4, 0x87, 0xc5, 0xd4, 0x75, + 0x8f, 0x36, 0x43, 0xc9, 0xeb, 0xb4, 0x7a, 0xbf, 0x36, 0x51, 0x47, 0x97, 0xe0, 0x2d, 0xee, 0xda, + 0x27, 0x4b, 0xbb, 0xf6, 0xd3, 0x4b, 0x7c, 0x7c, 0x3a, 0xb3, 0xda, 0xcd, 0xfa, 0xfd, 0xca, 0x66, + 0xfd, 0xec, 0xd2, 0xca, 0x9b, 0xf7, 0xe8, 0x1d, 0x74, 0xb5, 0x4a, 0x00, 0xdf, 0x44, 0x5b, 0xe2, + 0x55, 0x4f, 0x2d, 0xdd, 0x80, 0x6a, 0x07, 0x56, 0xcd, 0xac, 0x10, 0x3d, 0x86, 0xec, 0x05, 0x87, + 0xcb, 0x91, 0x4b, 0xb4, 0x84, 0x31, 0x84, 0x8a, 0x0b, 0xf3, 0x5f, 0x5b, 0xa1, 0x4f, 0xcd, 0x3d, + 0xa9, 0x10, 0xc1, 0x47, 0x67, 0xe7, 0x4e, 0xe3, 0xe5, 0xb9, 0xd3, 0xf8, 0xe3, 0xdc, 0x69, 0xfc, + 0x58, 0x38, 0xd6, 0x59, 0xe1, 0x58, 0x2f, 0x0b, 0xc7, 0xfa, 0xb3, 0x70, 0xac, 0x9f, 0xff, 0x72, + 0x1a, 0xdf, 0x36, 0x27, 0xfd, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0x45, 0xec, 0x9a, 0x15, 0x8e, + 0x09, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.proto similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.proto index 56fb031..56d19a9 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/generated.proto @@ -39,24 +39,29 @@ message CrossVersionObjectReference { optional string name = 2; // API version of the referent + // +optional optional string apiVersion = 3; } // configuration of a horizontal pod autoscaler. message HorizontalPodAutoscaler { // Standard object metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // behaviour of autoscaler. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional optional HorizontalPodAutoscalerSpec spec = 2; // current information about the autoscaler. + // +optional optional HorizontalPodAutoscalerStatus status = 3; } // list of horizontal pod autoscaler objects. message HorizontalPodAutoscalerList { // Standard list metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // list of horizontal pod autoscaler objects. @@ -70,6 +75,7 @@ message HorizontalPodAutoscalerSpec { optional CrossVersionObjectReference scaleTargetRef = 1; // lower limit for the number of pods that can be set by the autoscaler, default 1. + // +optional optional int32 minReplicas = 2; // upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. @@ -77,16 +83,19 @@ message HorizontalPodAutoscalerSpec { // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; // if not specified the default autoscaling policy will be used. + // +optional optional int32 targetCPUUtilizationPercentage = 4; } // current status of a horizontal pod autoscaler message HorizontalPodAutoscalerStatus { // most recent generation observed by this autoscaler. + // +optional optional int64 observedGeneration = 1; // last time the HorizontalPodAutoscaler scaled the number of pods; // used by the autoscaler to control how often the number of pods is changed. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastScaleTime = 2; // current number of replicas of pods managed by this autoscaler. @@ -97,24 +106,29 @@ message HorizontalPodAutoscalerStatus { // current average CPU utilization over all pods, represented as a percentage of requested CPU, // e.g. 70 means that an average pod is using now 70% of its requested CPU. + // +optional optional int32 currentCPUUtilizationPercentage = 5; } // Scale represents a scaling request for a resource. message Scale { // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional optional ScaleSpec spec = 2; // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional optional ScaleStatus status = 3; } // ScaleSpec describes the attributes of a scale subresource. message ScaleSpec { // desired number of instances for the scaled object. + // +optional optional int32 replicas = 1; } @@ -127,6 +141,7 @@ message ScaleStatus { // as the label selector but in the string format to avoid introspection // by clients. The string will be in the same format as the query-param syntax. // More info about label selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional optional string selector = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/register.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/register.go similarity index 88% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/register.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/register.go index d7b7df9..8072e81 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.generated.go index 9b03510..9ffaf6b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.go index 6b50395..444124a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types.go @@ -17,8 +17,8 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // CrossVersionObjectReference contains enough information to let you identify the referred resource. @@ -28,6 +28,7 @@ type CrossVersionObjectReference struct { // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names Name string `json:"name" protobuf:"bytes,2,opt,name=name"` // API version of the referent + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` } @@ -37,21 +38,25 @@ type HorizontalPodAutoscalerSpec struct { // and will set the desired number of pods by using its Scale subresource. ScaleTargetRef CrossVersionObjectReference `json:"scaleTargetRef" protobuf:"bytes,1,opt,name=scaleTargetRef"` // lower limit for the number of pods that can be set by the autoscaler, default 1. + // +optional MinReplicas *int32 `json:"minReplicas,omitempty" protobuf:"varint,2,opt,name=minReplicas"` // upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. MaxReplicas int32 `json:"maxReplicas" protobuf:"varint,3,opt,name=maxReplicas"` // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; // if not specified the default autoscaling policy will be used. + // +optional TargetCPUUtilizationPercentage *int32 `json:"targetCPUUtilizationPercentage,omitempty" protobuf:"varint,4,opt,name=targetCPUUtilizationPercentage"` } // current status of a horizontal pod autoscaler type HorizontalPodAutoscalerStatus struct { // most recent generation observed by this autoscaler. + // +optional ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` // last time the HorizontalPodAutoscaler scaled the number of pods; // used by the autoscaler to control how often the number of pods is changed. + // +optional LastScaleTime *unversioned.Time `json:"lastScaleTime,omitempty" protobuf:"bytes,2,opt,name=lastScaleTime"` // current number of replicas of pods managed by this autoscaler. @@ -62,6 +67,7 @@ type HorizontalPodAutoscalerStatus struct { // current average CPU utilization over all pods, represented as a percentage of requested CPU, // e.g. 70 means that an average pod is using now 70% of its requested CPU. + // +optional CurrentCPUUtilizationPercentage *int32 `json:"currentCPUUtilizationPercentage,omitempty" protobuf:"varint,5,opt,name=currentCPUUtilizationPercentage"` } @@ -71,12 +77,15 @@ type HorizontalPodAutoscalerStatus struct { type HorizontalPodAutoscaler struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // behaviour of autoscaler. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // current information about the autoscaler. + // +optional Status HorizontalPodAutoscalerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -84,6 +93,7 @@ type HorizontalPodAutoscaler struct { type HorizontalPodAutoscalerList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // list of horizontal pod autoscaler objects. @@ -94,18 +104,22 @@ type HorizontalPodAutoscalerList struct { type Scale struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec ScaleSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional Status ScaleStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // ScaleSpec describes the attributes of a scale subresource. type ScaleSpec struct { // desired number of instances for the scaled object. + // +optional Replicas int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` } @@ -118,5 +132,6 @@ type ScaleStatus struct { // as the label selector but in the string format to avoid introspection // by clients. The string will be in the same format as the query-param syntax. // More info about label selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector string `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.conversion.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.conversion.go index 8a6c6c2..760cd31 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1 import ( - api "k8s.io/kubernetes/pkg/api" - autoscaling "k8s.io/kubernetes/pkg/apis/autoscaling" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + autoscaling "k8s.io/client-go/pkg/apis/autoscaling" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -77,10 +76,6 @@ func Convert_autoscaling_CrossVersionObjectReference_To_v1_CrossVersionObjectRef } func autoConvert_v1_HorizontalPodAutoscaler_To_autoscaling_HorizontalPodAutoscaler(in *HorizontalPodAutoscaler, out *autoscaling.HorizontalPodAutoscaler, s conversion.Scope) error { - SetDefaults_HorizontalPodAutoscaler(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -99,9 +94,6 @@ func Convert_v1_HorizontalPodAutoscaler_To_autoscaling_HorizontalPodAutoscaler(i } func autoConvert_autoscaling_HorizontalPodAutoscaler_To_v1_HorizontalPodAutoscaler(in *autoscaling.HorizontalPodAutoscaler, out *HorizontalPodAutoscaler, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -120,12 +112,7 @@ func Convert_autoscaling_HorizontalPodAutoscaler_To_v1_HorizontalPodAutoscaler(i } func autoConvert_v1_HorizontalPodAutoscalerList_To_autoscaling_HorizontalPodAutoscalerList(in *HorizontalPodAutoscalerList, out *autoscaling.HorizontalPodAutoscalerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]autoscaling.HorizontalPodAutoscaler, len(*in)) @@ -145,12 +132,7 @@ func Convert_v1_HorizontalPodAutoscalerList_To_autoscaling_HorizontalPodAutoscal } func autoConvert_autoscaling_HorizontalPodAutoscalerList_To_v1_HorizontalPodAutoscalerList(in *autoscaling.HorizontalPodAutoscalerList, out *HorizontalPodAutoscalerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]HorizontalPodAutoscaler, len(*in)) @@ -224,9 +206,6 @@ func Convert_autoscaling_HorizontalPodAutoscalerStatus_To_v1_HorizontalPodAutosc } func autoConvert_v1_Scale_To_autoscaling_Scale(in *Scale, out *autoscaling.Scale, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -245,9 +224,6 @@ func Convert_v1_Scale_To_autoscaling_Scale(in *Scale, out *autoscaling.Scale, s } func autoConvert_autoscaling_Scale_To_v1_Scale(in *autoscaling.Scale, out *Scale, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go index 70ed6d0..b4284f3 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - api_v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + unversioned "k8s.io/client-go/pkg/api/unversioned" + api_v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.defaults.go new file mode 100644 index 0000000..db483be --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/v1/zz_generated.defaults.go @@ -0,0 +1,47 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1 + +import ( + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&HorizontalPodAutoscaler{}, func(obj interface{}) { SetObjectDefaults_HorizontalPodAutoscaler(obj.(*HorizontalPodAutoscaler)) }) + scheme.AddTypeDefaultingFunc(&HorizontalPodAutoscalerList{}, func(obj interface{}) { + SetObjectDefaults_HorizontalPodAutoscalerList(obj.(*HorizontalPodAutoscalerList)) + }) + return nil +} + +func SetObjectDefaults_HorizontalPodAutoscaler(in *HorizontalPodAutoscaler) { + SetDefaults_HorizontalPodAutoscaler(in) +} + +func SetObjectDefaults_HorizontalPodAutoscalerList(in *HorizontalPodAutoscalerList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_HorizontalPodAutoscaler(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/autoscaling/zz_generated.deepcopy.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apis/autoscaling/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/autoscaling/zz_generated.deepcopy.go index dde5db7..fd3adc4 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/autoscaling/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/autoscaling/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package autoscaling import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/doc.go b/vendor/k8s.io/client-go/pkg/apis/batch/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/doc.go rename to vendor/k8s.io/client-go/pkg/apis/batch/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/install/install.go b/vendor/k8s.io/client-go/pkg/apis/batch/install/install.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/batch/install/install.go index d10932c..6d511f6 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/apis/batch/v1" - "k8s.io/kubernetes/pkg/apis/batch/v2alpha1" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/batch" + "k8s.io/client-go/pkg/apis/batch/v1" + "k8s.io/client-go/pkg/apis/batch/v2alpha1" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: batch.GroupName, VersionPreferenceOrder: []string{v1.SchemeGroupVersion.Version, v2alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/batch", + ImportPrefix: "k8s.io/client-go/pkg/apis/batch", AddInternalObjectsToScheme: batch.AddToScheme, }, announced.VersionToSchemeFunc{ diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/register.go b/vendor/k8s.io/client-go/pkg/apis/batch/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/register.go rename to vendor/k8s.io/client-go/pkg/apis/batch/register.go index 6cea2ef..9ef7587 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/register.go @@ -17,9 +17,9 @@ limitations under the License. package batch import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/batch/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/batch/types.generated.go index 081498c..2610e23 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg2_api "k8s.io/client-go/pkg/api" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/types.go b/vendor/k8s.io/client-go/pkg/apis/batch/types.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/types.go rename to vendor/k8s.io/client-go/pkg/apis/batch/types.go index 7db3057..3d3c827 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/types.go @@ -17,8 +17,8 @@ limitations under the License. package batch import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // +genclient=true @@ -28,14 +28,17 @@ type Job struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status JobStatus `json:"status,omitempty"` } @@ -44,6 +47,7 @@ type JobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of Job. @@ -55,10 +59,12 @@ type JobTemplate struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Template defines jobs that will be created from this template // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Template JobTemplateSpec `json:"template,omitempty"` } @@ -66,10 +72,12 @@ type JobTemplate struct { type JobTemplateSpec struct { // Standard object's metadata of the jobs created from this template. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Specification of the desired behavior of the job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty"` } @@ -80,6 +88,7 @@ type JobSpec struct { // run at any given time. The actual number of pods running in steady state will // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. + // +optional Parallelism *int32 `json:"parallelism,omitempty"` // Completions specifies the desired number of successfully finished pods the @@ -87,14 +96,17 @@ type JobSpec struct { // pod signals the success of all pods, and allows parallelism to have any positive // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. + // +optional Completions *int32 `json:"completions,omitempty"` // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty"` // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // ManualSelector controls generation of pod labels and pod selectors. @@ -106,6 +118,7 @@ type JobSpec struct { // and other jobs to not function correctly. However, You may see // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` // API. + // +optional ManualSelector *bool `json:"manualSelector,omitempty"` // Template is the object that describes the pod that will be created when @@ -117,25 +130,31 @@ type JobSpec struct { type JobStatus struct { // Conditions represent the latest available observations of an object's current state. + // +optional Conditions []JobCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty"` // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional CompletionTime *unversioned.Time `json:"completionTime,omitempty"` // Active is the number of actively running pods. + // +optional Active int32 `json:"active,omitempty"` // Succeeded is the number of pods which reached Phase Succeeded. + // +optional Succeeded int32 `json:"succeeded,omitempty"` // Failed is the number of pods which reached Phase Failed. + // +optional Failed int32 `json:"failed,omitempty"` } @@ -156,12 +175,16 @@ type JobCondition struct { // Status of the condition, one of True, False, Unknown. Status api.ConditionStatus `json:"status"` // Last time the condition was checked. + // +optional LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` // Last time the condition transit from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` // (brief) reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty"` // Human readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty"` } @@ -172,14 +195,17 @@ type ScheduledJob struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Spec is a structure defining the expected behavior of a job, including the schedule. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ScheduledJobSpec `json:"spec,omitempty"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ScheduledJobStatus `json:"status,omitempty"` } @@ -188,6 +214,7 @@ type ScheduledJobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of ScheduledJob. @@ -202,13 +229,16 @@ type ScheduledJobSpec struct { // Optional deadline in seconds for starting the job if it misses scheduled // time for any reason. Missed jobs executions will be counted as failed ones. + // +optional StartingDeadlineSeconds *int64 `json:"startingDeadlineSeconds,omitempty"` // ConcurrencyPolicy specifies how to treat concurrent executions of a Job. + // +optional ConcurrencyPolicy ConcurrencyPolicy `json:"concurrencyPolicy,omitempty"` // Suspend flag tells the controller to suspend subsequent executions, it does // not apply to already started executions. Defaults to false. + // +optional Suspend *bool `json:"suspend,omitempty"` // JobTemplate is the object that describes the job that will be created when @@ -237,8 +267,10 @@ const ( // ScheduledJobStatus represents the current state of a Job. type ScheduledJobStatus struct { // Active holds pointers to currently running jobs. + // +optional Active []api.ObjectReference `json:"active,omitempty"` // LastScheduleTime keeps information of when was the last time the job was successfully scheduled. + // +optional LastScheduleTime *unversioned.Time `json:"lastScheduleTime,omitempty"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/conversion.go similarity index 71% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/conversion.go index 01dfe02..1702476 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/conversion.go @@ -19,12 +19,11 @@ package v1 import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/apis/batch" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { @@ -53,15 +52,7 @@ func Convert_batch_JobSpec_To_v1_JobSpec(in *batch.JobSpec, out *JobSpec, s conv out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for unversioned.LabelSelector -> v1.LabelSelector - if in.Selector != nil { - out.Selector = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if in.ManualSelector != nil { out.ManualSelector = new(bool) *out.ManualSelector = *in.ManualSelector @@ -79,15 +70,7 @@ func Convert_v1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSpec, s conv out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for v1.LabelSelector -> unversioned.LabelSelector - if in.Selector != nil { - out.Selector = new(unversioned.LabelSelector) - if err := Convert_v1_LabelSelector_To_unversioned_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if in.ManualSelector != nil { out.ManualSelector = new(bool) *out.ManualSelector = *in.ManualSelector diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/defaults.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/defaults.go index 5b8e10a..3fcb01b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/defaults.go @@ -17,10 +17,11 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( SetDefaults_Job, ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/doc.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/doc.go index 608c03b..7ae7265 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/doc.go @@ -17,5 +17,6 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/batch // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.pb.go similarity index 64% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.pb.go index ec4755f..f062e52 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.pb.go @@ -30,8 +30,6 @@ limitations under the License. JobList JobSpec JobStatus - LabelSelector - LabelSelectorRequirement */ package v1 @@ -39,12 +37,11 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_api_v1 "k8s.io/kubernetes/pkg/api/v1" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_v1 "k8s.io/client-go/pkg/api/v1" import strings "strings" import reflect "reflect" -import github_com_gogo_protobuf_sortkeys "github.com/gogo/protobuf/sortkeys" import io "io" @@ -77,24 +74,12 @@ func (m *JobStatus) Reset() { *m = JobStatus{} } func (*JobStatus) ProtoMessage() {} func (*JobStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{4} } -func (m *LabelSelector) Reset() { *m = LabelSelector{} } -func (*LabelSelector) ProtoMessage() {} -func (*LabelSelector) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{5} } - -func (m *LabelSelectorRequirement) Reset() { *m = LabelSelectorRequirement{} } -func (*LabelSelectorRequirement) ProtoMessage() {} -func (*LabelSelectorRequirement) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{6} -} - func init() { - proto.RegisterType((*Job)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.Job") - proto.RegisterType((*JobCondition)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.JobCondition") - proto.RegisterType((*JobList)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.JobList") - proto.RegisterType((*JobSpec)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.JobSpec") - proto.RegisterType((*JobStatus)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.JobStatus") - proto.RegisterType((*LabelSelector)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.LabelSelector") - proto.RegisterType((*LabelSelectorRequirement)(nil), "k8s.io.kubernetes.pkg.apis.batch.v1.LabelSelectorRequirement") + proto.RegisterType((*Job)(nil), "k8s.io.client-go.pkg.apis.batch.v1.Job") + proto.RegisterType((*JobCondition)(nil), "k8s.io.client-go.pkg.apis.batch.v1.JobCondition") + proto.RegisterType((*JobList)(nil), "k8s.io.client-go.pkg.apis.batch.v1.JobList") + proto.RegisterType((*JobSpec)(nil), "k8s.io.client-go.pkg.apis.batch.v1.JobSpec") + proto.RegisterType((*JobStatus)(nil), "k8s.io.client-go.pkg.apis.batch.v1.JobStatus") } func (m *Job) Marshal() (data []byte, err error) { size := m.Size() @@ -346,94 +331,6 @@ func (m *JobStatus) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *LabelSelector) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelector) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k := range m.MatchLabels { - data[i] = 0xa - i++ - v := m.MatchLabels[k] - mapSize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - i = encodeVarintGenerated(data, i, uint64(mapSize)) - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(k))) - i += copy(data[i:], k) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(v))) - i += copy(data[i:], v) - } - } - if len(m.MatchExpressions) > 0 { - for _, msg := range m.MatchExpressions { - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(msg.Size())) - n, err := msg.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n - } - } - return i, nil -} - -func (m *LabelSelectorRequirement) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelectorRequirement) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Key))) - i += copy(data[i:], m.Key) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Operator))) - i += copy(data[i:], m.Operator) - if len(m.Values) > 0 { - for _, s := range m.Values { - data[i] = 0x1a - i++ - l = len(s) - for l >= 1<<7 { - data[i] = uint8(uint64(l)&0x7f | 0x80) - l >>= 7 - i++ - } - data[i] = uint8(l) - i++ - i += copy(data[i:], s) - } - } - return i, nil -} - func encodeFixed64Generated(data []byte, offset int, v uint64) int { data[offset] = uint8(v) data[offset+1] = uint8(v >> 8) @@ -552,42 +449,6 @@ func (m *JobStatus) Size() (n int) { return n } -func (m *LabelSelector) Size() (n int) { - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k, v := range m.MatchLabels { - _ = k - _ = v - mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) - } - } - if len(m.MatchExpressions) > 0 { - for _, e := range m.MatchExpressions { - l = e.Size() - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - -func (m *LabelSelectorRequirement) Size() (n int) { - var l int - _ = l - l = len(m.Key) - n += 1 + l + sovGenerated(uint64(l)) - l = len(m.Operator) - n += 1 + l + sovGenerated(uint64(l)) - if len(m.Values) > 0 { - for _, s := range m.Values { - l = len(s) - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - func sovGenerated(x uint64) (n int) { for { n++ @@ -647,7 +508,7 @@ func (this *JobSpec) String() string { `Parallelism:` + valueToStringGenerated(this.Parallelism) + `,`, `Completions:` + valueToStringGenerated(this.Completions) + `,`, `ActiveDeadlineSeconds:` + valueToStringGenerated(this.ActiveDeadlineSeconds) + `,`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `ManualSelector:` + valueToStringGenerated(this.ManualSelector) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `}`, @@ -669,39 +530,6 @@ func (this *JobStatus) String() string { }, "") return s } -func (this *LabelSelector) String() string { - if this == nil { - return "nil" - } - keysForMatchLabels := make([]string, 0, len(this.MatchLabels)) - for k := range this.MatchLabels { - keysForMatchLabels = append(keysForMatchLabels, k) - } - github_com_gogo_protobuf_sortkeys.Strings(keysForMatchLabels) - mapStringForMatchLabels := "map[string]string{" - for _, k := range keysForMatchLabels { - mapStringForMatchLabels += fmt.Sprintf("%v: %v,", k, this.MatchLabels[k]) - } - mapStringForMatchLabels += "}" - s := strings.Join([]string{`&LabelSelector{`, - `MatchLabels:` + mapStringForMatchLabels + `,`, - `MatchExpressions:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.MatchExpressions), "LabelSelectorRequirement", "LabelSelectorRequirement", 1), `&`, ``, 1) + `,`, - `}`, - }, "") - return s -} -func (this *LabelSelectorRequirement) String() string { - if this == nil { - return "nil" - } - s := strings.Join([]string{`&LabelSelectorRequirement{`, - `Key:` + fmt.Sprintf("%v", this.Key) + `,`, - `Operator:` + fmt.Sprintf("%v", this.Operator) + `,`, - `Values:` + fmt.Sprintf("%v", this.Values) + `,`, - `}`, - }, "") - return s -} func valueToStringGenerated(v interface{}) string { rv := reflect.ValueOf(v) if rv.IsNil() { @@ -1303,7 +1131,7 @@ func (m *JobSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -1585,335 +1413,6 @@ func (m *JobStatus) Unmarshal(data []byte) error { } return nil } -func (m *LabelSelector) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelector: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelector: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchLabels", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - var keykey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - keykey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapkey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapkey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapkey := int(stringLenmapkey) - if intStringLenmapkey < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapkey := iNdEx + intStringLenmapkey - if postStringIndexmapkey > l { - return io.ErrUnexpectedEOF - } - mapkey := string(data[iNdEx:postStringIndexmapkey]) - iNdEx = postStringIndexmapkey - var valuekey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - valuekey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapvalue uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapvalue |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapvalue := int(stringLenmapvalue) - if intStringLenmapvalue < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapvalue := iNdEx + intStringLenmapvalue - if postStringIndexmapvalue > l { - return io.ErrUnexpectedEOF - } - mapvalue := string(data[iNdEx:postStringIndexmapvalue]) - iNdEx = postStringIndexmapvalue - if m.MatchLabels == nil { - m.MatchLabels = make(map[string]string) - } - m.MatchLabels[mapkey] = mapvalue - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchExpressions", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.MatchExpressions = append(m.MatchExpressions, LabelSelectorRequirement{}) - if err := m.MatchExpressions[len(m.MatchExpressions)-1].Unmarshal(data[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *LabelSelectorRequirement) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelectorRequirement: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelectorRequirement: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Key = string(data[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Operator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Operator = LabelSelectorOperator(data[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Values", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Values = append(m.Values, string(data[iNdEx:postIndex])) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} func skipGenerated(data []byte) (n int, err error) { l := len(data) iNdEx := 0 @@ -2020,70 +1519,59 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 1027 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x9c, 0x56, 0xcd, 0x6e, 0x23, 0x45, - 0x10, 0x8e, 0x3d, 0xb1, 0x63, 0xb7, 0x93, 0xac, 0x69, 0x88, 0x64, 0x2c, 0x91, 0xac, 0x0c, 0x42, - 0xbb, 0x62, 0x33, 0x23, 0x07, 0x90, 0x56, 0x2b, 0xb1, 0x12, 0x13, 0x82, 0x04, 0xc4, 0x24, 0x6a, - 0x47, 0x2b, 0xc4, 0xcf, 0xa1, 0x3d, 0xae, 0x75, 0x86, 0x8c, 0x67, 0x86, 0xe9, 0x1e, 0x43, 0x38, - 0x21, 0x71, 0xe0, 0xca, 0x43, 0xf0, 0x0c, 0xec, 0x2b, 0xe4, 0xb8, 0x70, 0xe2, 0x14, 0xc1, 0xf2, - 0x16, 0x9c, 0xe8, 0xee, 0xe9, 0xf9, 0xf1, 0x5f, 0xe4, 0xec, 0xa1, 0x25, 0x77, 0x75, 0x7d, 0x5f, - 0x55, 0x77, 0x7d, 0x55, 0x63, 0xf4, 0xee, 0xc5, 0x43, 0x66, 0xba, 0x81, 0x75, 0x11, 0x0f, 0x20, - 0xf2, 0x81, 0x03, 0xb3, 0xc2, 0x8b, 0x91, 0x45, 0x43, 0x97, 0x59, 0x03, 0xca, 0x9d, 0x73, 0x6b, - 0xd2, 0xb5, 0x46, 0xe0, 0x43, 0x44, 0x39, 0x0c, 0xcd, 0x30, 0x0a, 0x78, 0x80, 0xdf, 0x4c, 0x40, - 0x66, 0x0e, 0x32, 0x05, 0xc8, 0x94, 0x20, 0x53, 0x81, 0xcc, 0x49, 0xb7, 0xbd, 0x3f, 0x72, 0xf9, - 0x79, 0x3c, 0x30, 0x9d, 0x60, 0x6c, 0x8d, 0x82, 0x51, 0x60, 0x29, 0xec, 0x20, 0x7e, 0xaa, 0x76, - 0x6a, 0xa3, 0x7e, 0x25, 0x9c, 0xed, 0x83, 0xa5, 0x89, 0x58, 0x11, 0xb0, 0x20, 0x8e, 0x1c, 0x98, - 0xcd, 0xa3, 0xfd, 0xfe, 0x72, 0x4c, 0xec, 0x4f, 0x20, 0x62, 0x6e, 0xe0, 0xc3, 0x70, 0x0e, 0xf6, - 0x60, 0x39, 0x6c, 0xfe, 0xb2, 0xed, 0xfd, 0xc5, 0xde, 0x51, 0xec, 0x73, 0x77, 0x3c, 0x9f, 0x53, - 0x77, 0xb1, 0x7b, 0xcc, 0x5d, 0xcf, 0x72, 0x7d, 0xce, 0x78, 0x34, 0x0b, 0xe9, 0xfc, 0x52, 0x46, - 0xc6, 0xa7, 0xc1, 0x00, 0x7f, 0x81, 0x6a, 0x63, 0xe0, 0x74, 0x48, 0x39, 0x6d, 0x95, 0xee, 0x96, - 0xee, 0x35, 0x0e, 0xee, 0x99, 0x4b, 0x5f, 0x5a, 0x3c, 0xb1, 0x79, 0x32, 0xf8, 0x16, 0x1c, 0xde, - 0x13, 0x18, 0x1b, 0x5f, 0x5d, 0xef, 0xad, 0xbd, 0xb8, 0xde, 0x43, 0xb9, 0x8d, 0x64, 0x6c, 0xf8, - 0x73, 0xb4, 0xce, 0x42, 0x70, 0x5a, 0x65, 0xc5, 0xfa, 0xc0, 0x5c, 0xa1, 0x7e, 0xa6, 0xc8, 0xa8, - 0x2f, 0x30, 0xf6, 0xa6, 0x66, 0x5e, 0x97, 0x3b, 0xa2, 0x78, 0xf0, 0x13, 0x54, 0x65, 0x9c, 0xf2, - 0x98, 0xb5, 0x0c, 0xc5, 0x68, 0xae, 0xcc, 0xa8, 0x50, 0xf6, 0xb6, 0xe6, 0xac, 0x26, 0x7b, 0xa2, - 0xd9, 0x3a, 0x7f, 0x1a, 0x68, 0x53, 0x78, 0x1d, 0x06, 0xfe, 0xd0, 0xe5, 0xa2, 0x78, 0xf8, 0x3d, - 0xb4, 0xce, 0x2f, 0x43, 0x50, 0xcf, 0x51, 0xb7, 0xef, 0xa6, 0xa9, 0x9c, 0x09, 0xdb, 0x7f, 0xd7, - 0x7b, 0xcd, 0xa2, 0xaf, 0xb4, 0x11, 0xe5, 0x5d, 0x48, 0xaf, 0xac, 0x70, 0x8f, 0xa7, 0xc3, 0x09, - 0xe4, 0x8d, 0x12, 0x30, 0x33, 0xce, 0xe9, 0xf4, 0xf0, 0x39, 0xda, 0xf2, 0x28, 0xe3, 0xa7, 0x51, - 0x30, 0x80, 0x33, 0x51, 0x7c, 0x7d, 0xfb, 0x77, 0x6e, 0xa8, 0x52, 0x41, 0x87, 0xa6, 0x84, 0xd8, - 0x3b, 0x3a, 0x97, 0xad, 0xe3, 0x22, 0x13, 0x99, 0x26, 0xc6, 0xdf, 0x23, 0x2c, 0x0d, 0x67, 0x11, - 0xf5, 0x59, 0x72, 0x3b, 0x19, 0x6e, 0xfd, 0xf6, 0xe1, 0xda, 0x3a, 0x1c, 0x3e, 0x9e, 0xa3, 0x23, - 0x0b, 0x42, 0xe0, 0xb7, 0x51, 0x35, 0x02, 0xca, 0x02, 0xbf, 0x55, 0x51, 0x4f, 0x97, 0x55, 0x8a, - 0x28, 0x2b, 0xd1, 0xa7, 0xf8, 0x3e, 0xda, 0x18, 0x03, 0x63, 0x74, 0x04, 0xad, 0xaa, 0x72, 0xbc, - 0xa3, 0x1d, 0x37, 0x7a, 0x89, 0x99, 0xa4, 0xe7, 0x9d, 0x67, 0x25, 0xb4, 0x21, 0x0a, 0x75, 0xec, - 0x32, 0x8e, 0xbf, 0x99, 0x93, 0xb8, 0xb5, 0xe2, 0x6d, 0x24, 0x5c, 0x29, 0xbd, 0xa9, 0x03, 0xd5, - 0x52, 0x4b, 0x41, 0xe7, 0x3d, 0x54, 0x71, 0x39, 0x8c, 0x65, 0xdd, 0x8d, 0x9b, 0xdb, 0x67, 0x5a, - 0x96, 0xf6, 0x96, 0x26, 0xad, 0x7c, 0x22, 0xe1, 0x24, 0x61, 0xe9, 0x3c, 0x33, 0x54, 0xe6, 0x52, - 0xf8, 0xb8, 0x8b, 0x1a, 0x21, 0x8d, 0xa8, 0xe7, 0x81, 0xe7, 0xb2, 0xb1, 0x4a, 0xbe, 0x62, 0xdf, - 0x11, 0x90, 0xc6, 0x69, 0x6e, 0x26, 0x45, 0x1f, 0x09, 0x11, 0xc3, 0x2f, 0xf4, 0x40, 0xbe, 0x6e, - 0xa2, 0x45, 0x0d, 0x39, 0xcc, 0xcd, 0xa4, 0xe8, 0x83, 0x4f, 0xd0, 0x0e, 0x75, 0xb8, 0x3b, 0x81, - 0x8f, 0x80, 0x0e, 0x3d, 0xd7, 0x87, 0x3e, 0x38, 0x42, 0x8c, 0x49, 0x9f, 0x19, 0xf6, 0xeb, 0x02, - 0xbc, 0xf3, 0xe1, 0x22, 0x07, 0xb2, 0x18, 0x87, 0xbf, 0x46, 0x35, 0x06, 0x9e, 0x98, 0x08, 0x41, - 0xa4, 0xe5, 0x73, 0xb0, 0xd2, 0xa3, 0x1c, 0xd3, 0x01, 0x78, 0x7d, 0x8d, 0xb4, 0x37, 0xe5, 0x7b, - 0xa7, 0x3b, 0x92, 0x31, 0xe2, 0x47, 0x68, 0x7b, 0x4c, 0xfd, 0x98, 0x66, 0x9e, 0x4a, 0x35, 0x35, - 0x1b, 0x0b, 0xff, 0xed, 0xde, 0xd4, 0x09, 0x99, 0xf1, 0xc4, 0x5f, 0xa1, 0x9a, 0x78, 0xe4, 0xd0, - 0x13, 0x83, 0x50, 0x49, 0xa8, 0x71, 0xb0, 0x7f, 0xf3, 0xb4, 0x3b, 0x0d, 0x86, 0x67, 0x1a, 0xa0, - 0x06, 0x53, 0x26, 0x84, 0xd4, 0x4a, 0x32, 0xc2, 0xce, 0xef, 0x06, 0xaa, 0x67, 0xe3, 0x06, 0x03, - 0x42, 0x4e, 0xda, 0xd2, 0x4c, 0x94, 0x4e, 0x6a, 0xa3, 0xbb, 0xaa, 0x36, 0xb2, 0x61, 0x90, 0xcf, - 0xd8, 0xcc, 0xc4, 0x48, 0x81, 0x58, 0xcc, 0xef, 0xba, 0x18, 0x14, 0x11, 0x57, 0xbd, 0x5a, 0xbe, - 0x7d, 0xaf, 0x6e, 0x09, 0xee, 0x7a, 0x3f, 0x65, 0x20, 0x39, 0x19, 0x1e, 0xa1, 0xed, 0x5c, 0x25, - 0x2f, 0x3b, 0x79, 0x54, 0x51, 0x0e, 0xa7, 0x68, 0xc8, 0x0c, 0xad, 0x6c, 0xff, 0x44, 0x47, 0x4a, - 0x2c, 0x95, 0xbc, 0xfd, 0x13, 0xd1, 0x11, 0x7d, 0x8a, 0x2d, 0x71, 0xd5, 0xd8, 0x71, 0x00, 0x86, - 0x30, 0x54, 0x35, 0xaf, 0xd8, 0xaf, 0x68, 0xd7, 0x7a, 0x3f, 0x3d, 0x20, 0xb9, 0x8f, 0x24, 0x7e, - 0x4a, 0x5d, 0x4f, 0x78, 0x57, 0xa7, 0x89, 0x3f, 0x56, 0x56, 0xa2, 0x4f, 0x3b, 0x7f, 0x94, 0xd1, - 0xd6, 0x94, 0xf6, 0xf0, 0x8f, 0xa8, 0x31, 0x96, 0xe5, 0x50, 0xd6, 0xb4, 0x7a, 0x87, 0xb7, 0x17, - 0xb1, 0xd9, 0xcb, 0x59, 0x8e, 0x7c, 0x1e, 0x5d, 0xda, 0xaf, 0xea, 0x1c, 0x1a, 0x85, 0x13, 0x52, - 0x0c, 0x86, 0x7f, 0x2e, 0xa1, 0xa6, 0xda, 0x1f, 0xfd, 0x10, 0x8a, 0x7f, 0x21, 0x4c, 0xf7, 0xb1, - 0xcc, 0xe0, 0x83, 0xdb, 0x67, 0x40, 0xe0, 0xbb, 0xd8, 0x8d, 0x60, 0x0c, 0x3e, 0xb7, 0x5b, 0x3a, - 0x76, 0xb3, 0x37, 0x43, 0x4f, 0xe6, 0x02, 0xb6, 0x1f, 0xa3, 0xe6, 0x6c, 0xee, 0xb8, 0x89, 0x8c, - 0x0b, 0xb8, 0x4c, 0xbe, 0x8b, 0x44, 0xfe, 0xc4, 0xaf, 0xa1, 0xca, 0x84, 0x7a, 0x71, 0xa2, 0xbc, - 0x3a, 0x49, 0x36, 0x8f, 0xca, 0x0f, 0x4b, 0x9d, 0xdf, 0x4a, 0xa8, 0xb5, 0x2c, 0x11, 0xfc, 0x46, - 0x81, 0xc8, 0x6e, 0xe8, 0xac, 0x8c, 0xcf, 0xe0, 0x32, 0x61, 0x3d, 0x42, 0xb5, 0x20, 0x94, 0xff, - 0x56, 0x44, 0x6f, 0x27, 0x1f, 0xd3, 0xfb, 0x69, 0xdb, 0x9d, 0x68, 0xbb, 0xf8, 0x9c, 0xee, 0x4c, - 0xd1, 0xa7, 0x07, 0x24, 0x83, 0xe2, 0x0e, 0xaa, 0xaa, 0x7c, 0xe4, 0x20, 0x33, 0x04, 0x09, 0x92, - 0xa5, 0x7f, 0xa2, 0x2c, 0x44, 0x9f, 0xd8, 0x6f, 0x5d, 0xfd, 0xb3, 0xbb, 0xf6, 0x5c, 0xac, 0xbf, - 0xc4, 0xfa, 0xe9, 0xc5, 0x6e, 0xe9, 0x4a, 0xac, 0xe7, 0x62, 0xfd, 0x2d, 0xd6, 0xaf, 0xff, 0xee, - 0xae, 0x7d, 0x59, 0x9e, 0x74, 0xff, 0x0f, 0x00, 0x00, 0xff, 0xff, 0xd1, 0x8b, 0x10, 0xf1, 0xb1, - 0x0a, 0x00, 0x00, + // 863 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x9c, 0x54, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0xce, 0x8f, 0xa6, 0x4d, 0xa6, 0x3f, 0x76, 0x19, 0xa9, 0x52, 0xc8, 0x21, 0x59, 0x05, 0x84, + 0x16, 0xb1, 0x1d, 0x2b, 0x65, 0x91, 0x10, 0x07, 0x24, 0x5c, 0x84, 0x44, 0xd5, 0xb2, 0xd5, 0xa4, + 0x42, 0x2b, 0x10, 0x48, 0x63, 0xfb, 0x6d, 0x3a, 0xd4, 0xf6, 0x58, 0x9e, 0x71, 0xd0, 0xde, 0xb8, + 0x71, 0xe5, 0xaf, 0x01, 0xf1, 0x1f, 0xf4, 0xb8, 0xe2, 0xc4, 0x29, 0xa2, 0xe6, 0xbf, 0xd8, 0x13, + 0xf2, 0x78, 0x62, 0x3b, 0x4d, 0x1a, 0xa5, 0xdc, 0x3c, 0x6f, 0xbe, 0xef, 0x7b, 0xcf, 0xef, 0x7d, + 0xf3, 0xd0, 0xc7, 0xd7, 0x9f, 0x4a, 0xc2, 0x85, 0x75, 0x9d, 0x38, 0x10, 0x87, 0xa0, 0x40, 0x5a, + 0xd1, 0xf5, 0xc4, 0x62, 0x11, 0x97, 0x96, 0xc3, 0x94, 0x7b, 0x65, 0x4d, 0x47, 0xd6, 0x04, 0x42, + 0x88, 0x99, 0x02, 0x8f, 0x44, 0xb1, 0x50, 0x02, 0xbf, 0x97, 0x93, 0x48, 0x49, 0x22, 0xd1, 0xf5, + 0x84, 0x64, 0x24, 0xa2, 0x49, 0x64, 0x3a, 0xea, 0x1d, 0x4d, 0xb8, 0xba, 0x4a, 0x1c, 0xe2, 0x8a, + 0xc0, 0x9a, 0x88, 0x89, 0xb0, 0x34, 0xd7, 0x49, 0x5e, 0xe9, 0x93, 0x3e, 0xe8, 0xaf, 0x5c, 0xb3, + 0x77, 0x7c, 0x6f, 0x21, 0x56, 0x0c, 0x52, 0x24, 0xb1, 0x0b, 0x77, 0xeb, 0xe8, 0x7d, 0x72, 0x3f, + 0x27, 0x09, 0xa7, 0x10, 0x4b, 0x2e, 0x42, 0xf0, 0x96, 0x68, 0xcf, 0xee, 0xa7, 0x2d, 0xff, 0x6c, + 0xef, 0x68, 0x35, 0x3a, 0x4e, 0x42, 0xc5, 0x83, 0xe5, 0x9a, 0x46, 0xab, 0xe1, 0x89, 0xe2, 0xbe, + 0xc5, 0x43, 0x25, 0x55, 0x7c, 0x97, 0x32, 0xfc, 0xb5, 0x81, 0x9a, 0xa7, 0xc2, 0xc1, 0x2f, 0x51, + 0x3b, 0x00, 0xc5, 0x3c, 0xa6, 0x58, 0xb7, 0xfe, 0xa4, 0xfe, 0x74, 0xf7, 0xf8, 0x29, 0xb9, 0xb7, + 0xd3, 0x64, 0x3a, 0x22, 0x2f, 0x9c, 0x9f, 0xc0, 0x55, 0xe7, 0xa0, 0x98, 0x8d, 0x6f, 0x66, 0x83, + 0x5a, 0x3a, 0x1b, 0xa0, 0x32, 0x46, 0x0b, 0x35, 0xfc, 0x0d, 0xda, 0x92, 0x11, 0xb8, 0xdd, 0x86, + 0x56, 0x7d, 0x46, 0x36, 0x98, 0x1f, 0x39, 0x15, 0xce, 0x38, 0x02, 0xd7, 0xde, 0x33, 0xca, 0x5b, + 0xd9, 0x89, 0x6a, 0x1d, 0xfc, 0x2d, 0xda, 0x96, 0x8a, 0xa9, 0x44, 0x76, 0x9b, 0x5a, 0x91, 0x6c, + 0xac, 0xa8, 0x59, 0xf6, 0x81, 0xd1, 0xdc, 0xce, 0xcf, 0xd4, 0xa8, 0x0d, 0xff, 0x6a, 0xa2, 0xbd, + 0x53, 0xe1, 0x9c, 0x88, 0xd0, 0xe3, 0x8a, 0x8b, 0x10, 0x3f, 0x47, 0x5b, 0xea, 0x75, 0x04, 0xba, + 0x1d, 0x1d, 0xfb, 0xc9, 0xbc, 0x94, 0xcb, 0xd7, 0x11, 0xbc, 0x9d, 0x0d, 0x1e, 0x57, 0xb1, 0x59, + 0x8c, 0x6a, 0x74, 0xa5, 0xbc, 0x86, 0xe6, 0x7d, 0xbe, 0x98, 0xee, 0xed, 0x6c, 0xb0, 0xd6, 0x02, + 0xa4, 0xd0, 0x5c, 0x2c, 0x0f, 0x5f, 0xa1, 0x7d, 0x9f, 0x49, 0x75, 0x11, 0x0b, 0x07, 0x2e, 0x79, + 0x00, 0xe6, 0xef, 0x3f, 0x5a, 0x33, 0xa5, 0x8a, 0x0f, 0x49, 0x46, 0xb1, 0x0f, 0x4d, 0x2d, 0xfb, + 0x67, 0x55, 0x25, 0xba, 0x28, 0x8c, 0x7f, 0x46, 0x38, 0x0b, 0x5c, 0xc6, 0x2c, 0x94, 0xf9, 0xdf, + 0x65, 0xe9, 0xb6, 0x1e, 0x9e, 0xae, 0x67, 0xd2, 0xe1, 0xb3, 0x25, 0x39, 0xba, 0x22, 0x05, 0xfe, + 0x00, 0x6d, 0xc7, 0xc0, 0xa4, 0x08, 0xbb, 0x2d, 0xdd, 0xba, 0x62, 0x52, 0x54, 0x47, 0xa9, 0xb9, + 0xc5, 0x1f, 0xa2, 0x9d, 0x00, 0xa4, 0x64, 0x13, 0xe8, 0x6e, 0x6b, 0xe0, 0x23, 0x03, 0xdc, 0x39, + 0xcf, 0xc3, 0x74, 0x7e, 0x3f, 0xfc, 0xa3, 0x8e, 0x76, 0x4e, 0x85, 0x73, 0xc6, 0xa5, 0xc2, 0x3f, + 0x2c, 0x59, 0xdc, 0xda, 0xf0, 0x6f, 0x32, 0xba, 0x76, 0xfa, 0x63, 0x93, 0xa8, 0x3d, 0x8f, 0x54, + 0x7c, 0x7e, 0x8e, 0x5a, 0x5c, 0x41, 0x90, 0xcd, 0xbd, 0xb9, 0xfe, 0xf9, 0x2c, 0xda, 0xd2, 0xde, + 0x37, 0xa2, 0xad, 0xaf, 0x33, 0x3a, 0xcd, 0x55, 0x86, 0x7f, 0x36, 0x75, 0xe5, 0x99, 0xf1, 0xf1, + 0x08, 0xed, 0x46, 0x2c, 0x66, 0xbe, 0x0f, 0x3e, 0x97, 0x81, 0x2e, 0xbe, 0x65, 0x3f, 0x4a, 0x67, + 0x83, 0xdd, 0x8b, 0x32, 0x4c, 0xab, 0x98, 0x8c, 0xe2, 0x8a, 0x20, 0xf2, 0x21, 0xeb, 0x6e, 0xee, + 0x45, 0x43, 0x39, 0x29, 0xc3, 0xb4, 0x8a, 0xc1, 0x2f, 0xd0, 0x21, 0x73, 0x15, 0x9f, 0xc2, 0x97, + 0xc0, 0x3c, 0x9f, 0x87, 0x30, 0x06, 0x57, 0x84, 0x5e, 0xfe, 0xce, 0x9a, 0xf6, 0xbb, 0xe9, 0x6c, + 0x70, 0xf8, 0xc5, 0x2a, 0x00, 0x5d, 0xcd, 0xc3, 0x3f, 0xa2, 0xb6, 0x04, 0x1f, 0x5c, 0x25, 0x62, + 0x63, 0x9f, 0xe7, 0x9b, 0x36, 0x9c, 0x39, 0xe0, 0x8f, 0x0d, 0xd7, 0xde, 0xcb, 0x3a, 0x3e, 0x3f, + 0xd1, 0x42, 0x13, 0x7f, 0x86, 0x0e, 0x02, 0x16, 0x26, 0xac, 0x40, 0x6a, 0xdf, 0xb4, 0x6d, 0x9c, + 0xce, 0x06, 0x07, 0xe7, 0x0b, 0x37, 0xf4, 0x0e, 0x12, 0x7f, 0x8f, 0xda, 0x0a, 0x82, 0xc8, 0x67, + 0x2a, 0x37, 0xd1, 0xee, 0xf1, 0xd1, 0xfa, 0x7d, 0x77, 0x21, 0xbc, 0x4b, 0x43, 0xd0, 0xab, 0xa9, + 0xb0, 0xc2, 0x3c, 0x4a, 0x0b, 0xc1, 0xe1, 0xef, 0x4d, 0xd4, 0x29, 0x16, 0x0e, 0x06, 0x84, 0xdc, + 0xf9, 0xa3, 0x96, 0xdd, 0xba, 0x76, 0xc7, 0x68, 0x53, 0x77, 0x14, 0xeb, 0xa0, 0xdc, 0xb2, 0x45, + 0x48, 0xd2, 0x8a, 0x30, 0x7e, 0x89, 0x3a, 0x52, 0xb1, 0x58, 0xe9, 0xd7, 0xda, 0x78, 0xf8, 0x6b, + 0xdd, 0x4f, 0x67, 0x83, 0xce, 0x78, 0xae, 0x40, 0x4b, 0x31, 0x3c, 0x41, 0x07, 0xa5, 0x4f, 0xfe, + 0xef, 0xee, 0xd1, 0x43, 0x39, 0x59, 0x90, 0xa1, 0x77, 0x64, 0xb3, 0x05, 0x90, 0x3b, 0x49, 0xdb, + 0xa5, 0x55, 0x2e, 0x80, 0xdc, 0x76, 0xd4, 0xdc, 0x62, 0x0b, 0x75, 0x64, 0xe2, 0xba, 0x00, 0x1e, + 0x78, 0x7a, 0xe6, 0x2d, 0xfb, 0x1d, 0x03, 0xed, 0x8c, 0xe7, 0x17, 0xb4, 0xc4, 0x64, 0xc2, 0xaf, + 0x18, 0xf7, 0xc1, 0xd3, 0xb3, 0xae, 0x08, 0x7f, 0xa5, 0xa3, 0xd4, 0xdc, 0xda, 0xef, 0xdf, 0xdc, + 0xf6, 0x6b, 0x6f, 0x6e, 0xfb, 0xb5, 0xbf, 0x6f, 0xfb, 0xb5, 0x5f, 0xd2, 0x7e, 0xfd, 0x26, 0xed, + 0xd7, 0xdf, 0xa4, 0xfd, 0xfa, 0x3f, 0x69, 0xbf, 0xfe, 0xdb, 0xbf, 0xfd, 0xda, 0x77, 0x8d, 0xe9, + 0xe8, 0xbf, 0x00, 0x00, 0x00, 0xff, 0xff, 0x9a, 0x45, 0x86, 0xd9, 0xb8, 0x08, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.proto similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.proto index bb14b7f..17a6add 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/generated.proto @@ -34,14 +34,17 @@ option go_package = "v1"; message Job { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobSpec spec = 2; // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobStatus status = 3; } @@ -54,15 +57,19 @@ message JobCondition { optional string status = 2; // Last time the condition was checked. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; // Last time the condition transit from one status to another. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; // (brief) reason for the condition's last transition. + // +optional optional string reason = 5; // Human readable message indicating details about last transition. + // +optional optional string message = 6; } @@ -70,6 +77,7 @@ message JobCondition { message JobList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Job. @@ -83,6 +91,7 @@ message JobSpec { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 parallelism = 1; // Completions specifies the desired number of successfully finished pods the @@ -91,16 +100,19 @@ message JobSpec { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 completions = 2; // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional optional int64 activeDeadlineSeconds = 3; // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - optional LabelSelector selector = 4; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 4; // ManualSelector controls generation of pod labels and pod selectors. // Leave `manualSelector` unset unless you are certain what you are doing. @@ -112,6 +124,7 @@ message JobSpec { // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` // API. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional optional bool manualSelector = 5; // Template is the object that describes the pod that will be created when @@ -124,55 +137,31 @@ message JobSpec { message JobStatus { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional repeated JobCondition conditions = 1; // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startTime = 2; // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time completionTime = 3; // Active is the number of actively running pods. + // +optional optional int32 active = 4; // Succeeded is the number of pods which reached Phase Succeeded. + // +optional optional int32 succeeded = 5; // Failed is the number of pods which reached Phase Failed. + // +optional optional int32 failed = 6; } -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -message LabelSelector { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - map matchLabels = 1; - - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - repeated LabelSelectorRequirement matchExpressions = 2; -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -message LabelSelectorRequirement { - // key is the label key that the selector applies to. - optional string key = 1; - - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - optional string operator = 2; - - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - repeated string values = 3; -} - diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/register.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/register.go similarity index 88% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/register.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/register.go index aa97b0e..b1e4a38 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types.generated.go similarity index 60% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/types.generated.go index 09ac15e..b6c6658 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -908,7 +908,13 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym82 := z.EncBinary() + _ = yym82 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } else { r.EncodeNil() @@ -921,7 +927,13 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym83 := z.EncBinary() + _ = yym83 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } } @@ -931,12 +943,12 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.ManualSelector == nil { r.EncodeNil() } else { - yy83 := *x.ManualSelector - yym84 := z.EncBinary() - _ = yym84 + yy85 := *x.ManualSelector + yym86 := z.EncBinary() + _ = yym86 if false { } else { - r.EncodeBool(bool(yy83)) + r.EncodeBool(bool(yy85)) } } } else { @@ -950,26 +962,26 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.ManualSelector == nil { r.EncodeNil() } else { - yy85 := *x.ManualSelector - yym86 := z.EncBinary() - _ = yym86 + yy87 := *x.ManualSelector + yym88 := z.EncBinary() + _ = yym88 if false { } else { - r.EncodeBool(bool(yy85)) + r.EncodeBool(bool(yy87)) } } } } if yyr65 || yy2arr65 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy88 := &x.Template - yy88.CodecEncodeSelf(e) + yy90 := &x.Template + yy90.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("template")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy89 := &x.Template - yy89.CodecEncodeSelf(e) + yy91 := &x.Template + yy91.CodecEncodeSelf(e) } if yyr65 || yy2arr65 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) @@ -984,25 +996,25 @@ func (x *JobSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym90 := z.DecBinary() - _ = yym90 + yym92 := z.DecBinary() + _ = yym92 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct91 := r.ContainerType() - if yyct91 == codecSelferValueTypeMap1234 { - yyl91 := r.ReadMapStart() - if yyl91 == 0 { + yyct93 := r.ContainerType() + if yyct93 == codecSelferValueTypeMap1234 { + yyl93 := r.ReadMapStart() + if yyl93 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl91, d) + x.codecDecodeSelfFromMap(yyl93, d) } - } else if yyct91 == codecSelferValueTypeArray1234 { - yyl91 := r.ReadArrayStart() - if yyl91 == 0 { + } else if yyct93 == codecSelferValueTypeArray1234 { + yyl93 := r.ReadArrayStart() + if yyl93 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl91, d) + x.codecDecodeSelfFromArray(yyl93, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -1014,12 +1026,12 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys92Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys92Slc - var yyhl92 bool = l >= 0 - for yyj92 := 0; ; yyj92++ { - if yyhl92 { - if yyj92 >= l { + var yys94Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys94Slc + var yyhl94 bool = l >= 0 + for yyj94 := 0; ; yyj94++ { + if yyhl94 { + if yyj94 >= l { break } } else { @@ -1028,10 +1040,10 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys92Slc = r.DecodeBytes(yys92Slc, true, true) - yys92 := string(yys92Slc) + yys94Slc = r.DecodeBytes(yys94Slc, true, true) + yys94 := string(yys94Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys92 { + switch yys94 { case "parallelism": if r.TryDecodeAsNil() { if x.Parallelism != nil { @@ -1041,8 +1053,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym94 := z.DecBinary() - _ = yym94 + yym96 := z.DecBinary() + _ = yym96 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) @@ -1057,8 +1069,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym96 := z.DecBinary() - _ = yym96 + yym98 := z.DecBinary() + _ = yym98 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) @@ -1073,8 +1085,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym98 := z.DecBinary() - _ = yym98 + yym100 := z.DecBinary() + _ = yym100 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) @@ -1087,9 +1099,15 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym102 := z.DecBinary() + _ = yym102 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } case "manualSelector": if r.TryDecodeAsNil() { @@ -1100,8 +1118,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ManualSelector == nil { x.ManualSelector = new(bool) } - yym101 := z.DecBinary() - _ = yym101 + yym104 := z.DecBinary() + _ = yym104 if false { } else { *((*bool)(x.ManualSelector)) = r.DecodeBool() @@ -1111,13 +1129,13 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv102 := &x.Template - yyv102.CodecDecodeSelf(d) + yyv105 := &x.Template + yyv105.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys92) - } // end switch yys92 - } // end for yyj92 + z.DecStructFieldNotFound(-1, yys94) + } // end switch yys94 + } // end for yyj94 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -1125,16 +1143,16 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj103 int - var yyb103 bool - var yyhl103 bool = l >= 0 - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + var yyj106 int + var yyb106 bool + var yyhl106 bool = l >= 0 + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1147,20 +1165,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym105 := z.DecBinary() - _ = yym105 + yym108 := z.DecBinary() + _ = yym108 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) } } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1173,20 +1191,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym107 := z.DecBinary() - _ = yym107 + yym110 := z.DecBinary() + _ = yym110 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) } } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1199,20 +1217,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym109 := z.DecBinary() - _ = yym109 + yym112 := z.DecBinary() + _ = yym112 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) } } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1223,17 +1241,23 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym114 := z.DecBinary() + _ = yym114 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1246,20 +1270,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.ManualSelector == nil { x.ManualSelector = new(bool) } - yym112 := z.DecBinary() - _ = yym112 + yym116 := z.DecBinary() + _ = yym116 if false { } else { *((*bool)(x.ManualSelector)) = r.DecodeBool() } } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1267,21 +1291,21 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv113 := &x.Template - yyv113.CodecDecodeSelf(d) + yyv117 := &x.Template + yyv117.CodecDecodeSelf(d) } for { - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l + yyj106++ + if yyhl106 { + yyb106 = yyj106 > l } else { - yyb103 = r.CheckBreak() + yyb106 = r.CheckBreak() } - if yyb103 { + if yyb106 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj103-1, "") + z.DecStructFieldNotFound(yyj106-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -1293,43 +1317,43 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym114 := z.EncBinary() - _ = yym114 + yym118 := z.EncBinary() + _ = yym118 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep115 := !z.EncBinary() - yy2arr115 := z.EncBasicHandle().StructToArray - var yyq115 [6]bool - _, _, _ = yysep115, yyq115, yy2arr115 - const yyr115 bool = false - yyq115[0] = len(x.Conditions) != 0 - yyq115[1] = x.StartTime != nil - yyq115[2] = x.CompletionTime != nil - yyq115[3] = x.Active != 0 - yyq115[4] = x.Succeeded != 0 - yyq115[5] = x.Failed != 0 - var yynn115 int - if yyr115 || yy2arr115 { + yysep119 := !z.EncBinary() + yy2arr119 := z.EncBasicHandle().StructToArray + var yyq119 [6]bool + _, _, _ = yysep119, yyq119, yy2arr119 + const yyr119 bool = false + yyq119[0] = len(x.Conditions) != 0 + yyq119[1] = x.StartTime != nil + yyq119[2] = x.CompletionTime != nil + yyq119[3] = x.Active != 0 + yyq119[4] = x.Succeeded != 0 + yyq119[5] = x.Failed != 0 + var yynn119 int + if yyr119 || yy2arr119 { r.EncodeArrayStart(6) } else { - yynn115 = 0 - for _, b := range yyq115 { + yynn119 = 0 + for _, b := range yyq119 { if b { - yynn115++ + yynn119++ } } - r.EncodeMapStart(yynn115) - yynn115 = 0 + r.EncodeMapStart(yynn119) + yynn119 = 0 } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[0] { + if yyq119[0] { if x.Conditions == nil { r.EncodeNil() } else { - yym117 := z.EncBinary() - _ = yym117 + yym121 := z.EncBinary() + _ = yym121 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -1339,15 +1363,15 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq115[0] { + if yyq119[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym118 := z.EncBinary() - _ = yym118 + yym122 := z.EncBinary() + _ = yym122 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -1355,19 +1379,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[1] { + if yyq119[1] { if x.StartTime == nil { r.EncodeNil() } else { - yym120 := z.EncBinary() - _ = yym120 + yym124 := z.EncBinary() + _ = yym124 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym120 { + } else if yym124 { z.EncBinaryMarshal(x.StartTime) - } else if !yym120 && z.IsJSONHandle() { + } else if !yym124 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -1377,20 +1401,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq115[1] { + if yyq119[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("startTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.StartTime == nil { r.EncodeNil() } else { - yym121 := z.EncBinary() - _ = yym121 + yym125 := z.EncBinary() + _ = yym125 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym121 { + } else if yym125 { z.EncBinaryMarshal(x.StartTime) - } else if !yym121 && z.IsJSONHandle() { + } else if !yym125 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -1398,19 +1422,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[2] { + if yyq119[2] { if x.CompletionTime == nil { r.EncodeNil() } else { - yym123 := z.EncBinary() - _ = yym123 + yym127 := z.EncBinary() + _ = yym127 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym123 { + } else if yym127 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym123 && z.IsJSONHandle() { + } else if !yym127 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -1420,20 +1444,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq115[2] { + if yyq119[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("completionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.CompletionTime == nil { r.EncodeNil() } else { - yym124 := z.EncBinary() - _ = yym124 + yym128 := z.EncBinary() + _ = yym128 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym124 { + } else if yym128 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym124 && z.IsJSONHandle() { + } else if !yym128 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -1441,61 +1465,61 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[3] { - yym126 := z.EncBinary() - _ = yym126 - if false { - } else { - r.EncodeInt(int64(x.Active)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq115[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("active")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym127 := z.EncBinary() - _ = yym127 - if false { - } else { - r.EncodeInt(int64(x.Active)) - } - } - } - if yyr115 || yy2arr115 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[4] { - yym129 := z.EncBinary() - _ = yym129 - if false { - } else { - r.EncodeInt(int64(x.Succeeded)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq115[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("succeeded")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq119[3] { yym130 := z.EncBinary() _ = yym130 if false { + } else { + r.EncodeInt(int64(x.Active)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq119[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("active")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym131 := z.EncBinary() + _ = yym131 + if false { + } else { + r.EncodeInt(int64(x.Active)) + } + } + } + if yyr119 || yy2arr119 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq119[4] { + yym133 := z.EncBinary() + _ = yym133 + if false { + } else { + r.EncodeInt(int64(x.Succeeded)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq119[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("succeeded")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym134 := z.EncBinary() + _ = yym134 + if false { } else { r.EncodeInt(int64(x.Succeeded)) } } } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq115[5] { - yym132 := z.EncBinary() - _ = yym132 + if yyq119[5] { + yym136 := z.EncBinary() + _ = yym136 if false { } else { r.EncodeInt(int64(x.Failed)) @@ -1504,19 +1528,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq115[5] { + if yyq119[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("failed")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym133 := z.EncBinary() - _ = yym133 + yym137 := z.EncBinary() + _ = yym137 if false { } else { r.EncodeInt(int64(x.Failed)) } } } - if yyr115 || yy2arr115 { + if yyr119 || yy2arr119 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -1529,25 +1553,25 @@ func (x *JobStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym134 := z.DecBinary() - _ = yym134 + yym138 := z.DecBinary() + _ = yym138 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct135 := r.ContainerType() - if yyct135 == codecSelferValueTypeMap1234 { - yyl135 := r.ReadMapStart() - if yyl135 == 0 { + yyct139 := r.ContainerType() + if yyct139 == codecSelferValueTypeMap1234 { + yyl139 := r.ReadMapStart() + if yyl139 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl135, d) + x.codecDecodeSelfFromMap(yyl139, d) } - } else if yyct135 == codecSelferValueTypeArray1234 { - yyl135 := r.ReadArrayStart() - if yyl135 == 0 { + } else if yyct139 == codecSelferValueTypeArray1234 { + yyl139 := r.ReadArrayStart() + if yyl139 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl135, d) + x.codecDecodeSelfFromArray(yyl139, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -1559,12 +1583,12 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys136Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys136Slc - var yyhl136 bool = l >= 0 - for yyj136 := 0; ; yyj136++ { - if yyhl136 { - if yyj136 >= l { + var yys140Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys140Slc + var yyhl140 bool = l >= 0 + for yyj140 := 0; ; yyj140++ { + if yyhl140 { + if yyj140 >= l { break } } else { @@ -1573,20 +1597,20 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys136Slc = r.DecodeBytes(yys136Slc, true, true) - yys136 := string(yys136Slc) + yys140Slc = r.DecodeBytes(yys140Slc, true, true) + yys140 := string(yys140Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys136 { + switch yys140 { case "conditions": if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv137 := &x.Conditions - yym138 := z.DecBinary() - _ = yym138 + yyv141 := &x.Conditions + yym142 := z.DecBinary() + _ = yym142 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv137), d) + h.decSliceJobCondition((*[]JobCondition)(yyv141), d) } } case "startTime": @@ -1598,13 +1622,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym140 := z.DecBinary() - _ = yym140 + yym144 := z.DecBinary() + _ = yym144 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym140 { + } else if yym144 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym140 && z.IsJSONHandle() { + } else if !yym144 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) @@ -1619,13 +1643,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym142 := z.DecBinary() - _ = yym142 + yym146 := z.DecBinary() + _ = yym146 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym142 { + } else if yym146 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym142 && z.IsJSONHandle() { + } else if !yym146 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) @@ -1650,9 +1674,9 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys136) - } // end switch yys136 - } // end for yyj136 + z.DecStructFieldNotFound(-1, yys140) + } // end switch yys140 + } // end for yyj140 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -1660,16 +1684,16 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj146 int - var yyb146 bool - var yyhl146 bool = l >= 0 - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + var yyj150 int + var yyb150 bool + var yyhl150 bool = l >= 0 + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1677,21 +1701,21 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv147 := &x.Conditions - yym148 := z.DecBinary() - _ = yym148 + yyv151 := &x.Conditions + yym152 := z.DecBinary() + _ = yym152 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv147), d) + h.decSliceJobCondition((*[]JobCondition)(yyv151), d) } } - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1704,25 +1728,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym150 := z.DecBinary() - _ = yym150 + yym154 := z.DecBinary() + _ = yym154 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym150 { + } else if yym154 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym150 && z.IsJSONHandle() { + } else if !yym154 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) } } - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1735,25 +1759,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym152 := z.DecBinary() - _ = yym152 + yym156 := z.DecBinary() + _ = yym156 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym152 { + } else if yym156 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym152 && z.IsJSONHandle() { + } else if !yym156 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) } } - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1763,13 +1787,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Active = int32(r.DecodeInt(32)) } - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1779,13 +1803,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Succeeded = int32(r.DecodeInt(32)) } - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1796,17 +1820,17 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } for { - yyj146++ - if yyhl146 { - yyb146 = yyj146 > l + yyj150++ + if yyhl150 { + yyb150 = yyj150 > l } else { - yyb146 = r.CheckBreak() + yyb150 = r.CheckBreak() } - if yyb146 { + if yyb150 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj146-1, "") + z.DecStructFieldNotFound(yyj150-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -1815,8 +1839,8 @@ func (x JobConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym156 := z.EncBinary() - _ = yym156 + yym160 := z.EncBinary() + _ = yym160 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -1828,8 +1852,8 @@ func (x *JobConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym157 := z.DecBinary() - _ = yym157 + yym161 := z.DecBinary() + _ = yym161 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -1844,34 +1868,34 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym158 := z.EncBinary() - _ = yym158 + yym162 := z.EncBinary() + _ = yym162 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep159 := !z.EncBinary() - yy2arr159 := z.EncBasicHandle().StructToArray - var yyq159 [6]bool - _, _, _ = yysep159, yyq159, yy2arr159 - const yyr159 bool = false - yyq159[2] = true - yyq159[3] = true - yyq159[4] = x.Reason != "" - yyq159[5] = x.Message != "" - var yynn159 int - if yyr159 || yy2arr159 { + yysep163 := !z.EncBinary() + yy2arr163 := z.EncBasicHandle().StructToArray + var yyq163 [6]bool + _, _, _ = yysep163, yyq163, yy2arr163 + const yyr163 bool = false + yyq163[2] = true + yyq163[3] = true + yyq163[4] = x.Reason != "" + yyq163[5] = x.Message != "" + var yynn163 int + if yyr163 || yy2arr163 { r.EncodeArrayStart(6) } else { - yynn159 = 2 - for _, b := range yyq159 { + yynn163 = 2 + for _, b := range yyq163 { if b { - yynn159++ + yynn163++ } } - r.EncodeMapStart(yynn159) - yynn159 = 0 + r.EncodeMapStart(yynn163) + yynn163 = 0 } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -1880,10 +1904,10 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym162 := z.EncBinary() - _ = yym162 + yym166 := z.EncBinary() + _ = yym166 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { @@ -1893,139 +1917,139 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym163 := z.EncBinary() - _ = yym163 + yym167 := z.EncBinary() + _ = yym167 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Status)) } } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq159[2] { - yy165 := &x.LastProbeTime - yym166 := z.EncBinary() - _ = yym166 + if yyq163[2] { + yy169 := &x.LastProbeTime + yym170 := z.EncBinary() + _ = yym170 if false { - } else if z.HasExtensions() && z.EncExt(yy165) { - } else if yym166 { - z.EncBinaryMarshal(yy165) - } else if !yym166 && z.IsJSONHandle() { - z.EncJSONMarshal(yy165) + } else if z.HasExtensions() && z.EncExt(yy169) { + } else if yym170 { + z.EncBinaryMarshal(yy169) + } else if !yym170 && z.IsJSONHandle() { + z.EncJSONMarshal(yy169) } else { - z.EncFallback(yy165) + z.EncFallback(yy169) } } else { r.EncodeNil() } } else { - if yyq159[2] { + if yyq163[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy167 := &x.LastProbeTime - yym168 := z.EncBinary() - _ = yym168 + yy171 := &x.LastProbeTime + yym172 := z.EncBinary() + _ = yym172 if false { - } else if z.HasExtensions() && z.EncExt(yy167) { - } else if yym168 { - z.EncBinaryMarshal(yy167) - } else if !yym168 && z.IsJSONHandle() { - z.EncJSONMarshal(yy167) + } else if z.HasExtensions() && z.EncExt(yy171) { + } else if yym172 { + z.EncBinaryMarshal(yy171) + } else if !yym172 && z.IsJSONHandle() { + z.EncJSONMarshal(yy171) } else { - z.EncFallback(yy167) + z.EncFallback(yy171) } } } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq159[3] { - yy170 := &x.LastTransitionTime - yym171 := z.EncBinary() - _ = yym171 + if yyq163[3] { + yy174 := &x.LastTransitionTime + yym175 := z.EncBinary() + _ = yym175 if false { - } else if z.HasExtensions() && z.EncExt(yy170) { - } else if yym171 { - z.EncBinaryMarshal(yy170) - } else if !yym171 && z.IsJSONHandle() { - z.EncJSONMarshal(yy170) + } else if z.HasExtensions() && z.EncExt(yy174) { + } else if yym175 { + z.EncBinaryMarshal(yy174) + } else if !yym175 && z.IsJSONHandle() { + z.EncJSONMarshal(yy174) } else { - z.EncFallback(yy170) + z.EncFallback(yy174) } } else { r.EncodeNil() } } else { - if yyq159[3] { + if yyq163[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy172 := &x.LastTransitionTime - yym173 := z.EncBinary() - _ = yym173 + yy176 := &x.LastTransitionTime + yym177 := z.EncBinary() + _ = yym177 if false { - } else if z.HasExtensions() && z.EncExt(yy172) { - } else if yym173 { - z.EncBinaryMarshal(yy172) - } else if !yym173 && z.IsJSONHandle() { - z.EncJSONMarshal(yy172) + } else if z.HasExtensions() && z.EncExt(yy176) { + } else if yym177 { + z.EncBinaryMarshal(yy176) + } else if !yym177 && z.IsJSONHandle() { + z.EncJSONMarshal(yy176) } else { - z.EncFallback(yy172) + z.EncFallback(yy176) } } } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq159[4] { - yym175 := z.EncBinary() - _ = yym175 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq159[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("reason")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym176 := z.EncBinary() - _ = yym176 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } - } - if yyr159 || yy2arr159 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq159[5] { - yym178 := z.EncBinary() - _ = yym178 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Message)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq159[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("message")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq163[4] { yym179 := z.EncBinary() _ = yym179 if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq163[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym180 := z.EncBinary() + _ = yym180 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } + } + if yyr163 || yy2arr163 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq163[5] { + yym182 := z.EncBinary() + _ = yym182 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq163[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("message")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym183 := z.EncBinary() + _ = yym183 + if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr159 || yy2arr159 { + if yyr163 || yy2arr163 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -2038,25 +2062,25 @@ func (x *JobCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym180 := z.DecBinary() - _ = yym180 + yym184 := z.DecBinary() + _ = yym184 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct181 := r.ContainerType() - if yyct181 == codecSelferValueTypeMap1234 { - yyl181 := r.ReadMapStart() - if yyl181 == 0 { + yyct185 := r.ContainerType() + if yyct185 == codecSelferValueTypeMap1234 { + yyl185 := r.ReadMapStart() + if yyl185 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl181, d) + x.codecDecodeSelfFromMap(yyl185, d) } - } else if yyct181 == codecSelferValueTypeArray1234 { - yyl181 := r.ReadArrayStart() - if yyl181 == 0 { + } else if yyct185 == codecSelferValueTypeArray1234 { + yyl185 := r.ReadArrayStart() + if yyl185 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl181, d) + x.codecDecodeSelfFromArray(yyl185, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -2068,12 +2092,12 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys182Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys182Slc - var yyhl182 bool = l >= 0 - for yyj182 := 0; ; yyj182++ { - if yyhl182 { - if yyj182 >= l { + var yys186Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys186Slc + var yyhl186 bool = l >= 0 + for yyj186 := 0; ; yyj186++ { + if yyhl186 { + if yyj186 >= l { break } } else { @@ -2082,10 +2106,10 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys182Slc = r.DecodeBytes(yys182Slc, true, true) - yys182 := string(yys182Slc) + yys186Slc = r.DecodeBytes(yys186Slc, true, true) + yys186 := string(yys186Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys182 { + switch yys186 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -2102,34 +2126,34 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv185 := &x.LastProbeTime - yym186 := z.DecBinary() - _ = yym186 + yyv189 := &x.LastProbeTime + yym190 := z.DecBinary() + _ = yym190 if false { - } else if z.HasExtensions() && z.DecExt(yyv185) { - } else if yym186 { - z.DecBinaryUnmarshal(yyv185) - } else if !yym186 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv185) + } else if z.HasExtensions() && z.DecExt(yyv189) { + } else if yym190 { + z.DecBinaryUnmarshal(yyv189) + } else if !yym190 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv189) } else { - z.DecFallback(yyv185, false) + z.DecFallback(yyv189, false) } } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv187 := &x.LastTransitionTime - yym188 := z.DecBinary() - _ = yym188 + yyv191 := &x.LastTransitionTime + yym192 := z.DecBinary() + _ = yym192 if false { - } else if z.HasExtensions() && z.DecExt(yyv187) { - } else if yym188 { - z.DecBinaryUnmarshal(yyv187) - } else if !yym188 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv187) + } else if z.HasExtensions() && z.DecExt(yyv191) { + } else if yym192 { + z.DecBinaryUnmarshal(yyv191) + } else if !yym192 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv191) } else { - z.DecFallback(yyv187, false) + z.DecFallback(yyv191, false) } } case "reason": @@ -2145,9 +2169,9 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys182) - } // end switch yys182 - } // end for yyj182 + z.DecStructFieldNotFound(-1, yys186) + } // end switch yys186 + } // end for yyj186 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -2155,16 +2179,16 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj191 int - var yyb191 bool - var yyhl191 bool = l >= 0 - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + var yyj195 int + var yyb195 bool + var yyhl195 bool = l >= 0 + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2174,13 +2198,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = JobConditionType(r.DecodeString()) } - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2190,13 +2214,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) } - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2204,26 +2228,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv194 := &x.LastProbeTime - yym195 := z.DecBinary() - _ = yym195 + yyv198 := &x.LastProbeTime + yym199 := z.DecBinary() + _ = yym199 if false { - } else if z.HasExtensions() && z.DecExt(yyv194) { - } else if yym195 { - z.DecBinaryUnmarshal(yyv194) - } else if !yym195 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv194) + } else if z.HasExtensions() && z.DecExt(yyv198) { + } else if yym199 { + z.DecBinaryUnmarshal(yyv198) + } else if !yym199 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv198) } else { - z.DecFallback(yyv194, false) + z.DecFallback(yyv198, false) } } - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2231,26 +2255,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv196 := &x.LastTransitionTime - yym197 := z.DecBinary() - _ = yym197 + yyv200 := &x.LastTransitionTime + yym201 := z.DecBinary() + _ = yym201 if false { - } else if z.HasExtensions() && z.DecExt(yyv196) { - } else if yym197 { - z.DecBinaryUnmarshal(yyv196) - } else if !yym197 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv196) + } else if z.HasExtensions() && z.DecExt(yyv200) { + } else if yym201 { + z.DecBinaryUnmarshal(yyv200) + } else if !yym201 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv200) } else { - z.DecFallback(yyv196, false) + z.DecFallback(yyv200, false) } } - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2260,13 +2284,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2277,574 +2301,30 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } for { - yyj191++ - if yyhl191 { - yyb191 = yyj191 > l + yyj195++ + if yyhl195 { + yyb195 = yyj195 > l } else { - yyb191 = r.CheckBreak() + yyb195 = r.CheckBreak() } - if yyb191 { + if yyb195 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj191-1, "") + z.DecStructFieldNotFound(yyj195-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *LabelSelector) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym200 := z.EncBinary() - _ = yym200 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep201 := !z.EncBinary() - yy2arr201 := z.EncBasicHandle().StructToArray - var yyq201 [2]bool - _, _, _ = yysep201, yyq201, yy2arr201 - const yyr201 bool = false - yyq201[0] = len(x.MatchLabels) != 0 - yyq201[1] = len(x.MatchExpressions) != 0 - var yynn201 int - if yyr201 || yy2arr201 { - r.EncodeArrayStart(2) - } else { - yynn201 = 0 - for _, b := range yyq201 { - if b { - yynn201++ - } - } - r.EncodeMapStart(yynn201) - yynn201 = 0 - } - if yyr201 || yy2arr201 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[0] { - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym203 := z.EncBinary() - _ = yym203 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq201[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchLabels")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym204 := z.EncBinary() - _ = yym204 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } - } - if yyr201 || yy2arr201 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[1] { - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym206 := z.EncBinary() - _ = yym206 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq201[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchExpressions")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym207 := z.EncBinary() - _ = yym207 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } - } - } - if yyr201 || yy2arr201 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelector) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym208 := z.DecBinary() - _ = yym208 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct209 := r.ContainerType() - if yyct209 == codecSelferValueTypeMap1234 { - yyl209 := r.ReadMapStart() - if yyl209 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl209, d) - } - } else if yyct209 == codecSelferValueTypeArray1234 { - yyl209 := r.ReadArrayStart() - if yyl209 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl209, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelector) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys210Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys210Slc - var yyhl210 bool = l >= 0 - for yyj210 := 0; ; yyj210++ { - if yyhl210 { - if yyj210 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys210Slc = r.DecodeBytes(yys210Slc, true, true) - yys210 := string(yys210Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys210 { - case "matchLabels": - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv211 := &x.MatchLabels - yym212 := z.DecBinary() - _ = yym212 - if false { - } else { - z.F.DecMapStringStringX(yyv211, false, d) - } - } - case "matchExpressions": - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv213 := &x.MatchExpressions - yym214 := z.DecBinary() - _ = yym214 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv213), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys210) - } // end switch yys210 - } // end for yyj210 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelector) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj215 int - var yyb215 bool - var yyhl215 bool = l >= 0 - yyj215++ - if yyhl215 { - yyb215 = yyj215 > l - } else { - yyb215 = r.CheckBreak() - } - if yyb215 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv216 := &x.MatchLabels - yym217 := z.DecBinary() - _ = yym217 - if false { - } else { - z.F.DecMapStringStringX(yyv216, false, d) - } - } - yyj215++ - if yyhl215 { - yyb215 = yyj215 > l - } else { - yyb215 = r.CheckBreak() - } - if yyb215 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv218 := &x.MatchExpressions - yym219 := z.DecBinary() - _ = yym219 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv218), d) - } - } - for { - yyj215++ - if yyhl215 { - yyb215 = yyj215 > l - } else { - yyb215 = r.CheckBreak() - } - if yyb215 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj215-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *LabelSelectorRequirement) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym220 := z.EncBinary() - _ = yym220 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep221 := !z.EncBinary() - yy2arr221 := z.EncBasicHandle().StructToArray - var yyq221 [3]bool - _, _, _ = yysep221, yyq221, yy2arr221 - const yyr221 bool = false - yyq221[2] = len(x.Values) != 0 - var yynn221 int - if yyr221 || yy2arr221 { - r.EncodeArrayStart(3) - } else { - yynn221 = 2 - for _, b := range yyq221 { - if b { - yynn221++ - } - } - r.EncodeMapStart(yynn221) - yynn221 = 0 - } - if yyr221 || yy2arr221 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym223 := z.EncBinary() - _ = yym223 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("key")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym224 := z.EncBinary() - _ = yym224 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } - if yyr221 || yy2arr221 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - x.Operator.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("operator")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Operator.CodecEncodeSelf(e) - } - if yyr221 || yy2arr221 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq221[2] { - if x.Values == nil { - r.EncodeNil() - } else { - yym227 := z.EncBinary() - _ = yym227 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq221[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("values")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Values == nil { - r.EncodeNil() - } else { - yym228 := z.EncBinary() - _ = yym228 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } - } - if yyr221 || yy2arr221 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelectorRequirement) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym229 := z.DecBinary() - _ = yym229 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct230 := r.ContainerType() - if yyct230 == codecSelferValueTypeMap1234 { - yyl230 := r.ReadMapStart() - if yyl230 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl230, d) - } - } else if yyct230 == codecSelferValueTypeArray1234 { - yyl230 := r.ReadArrayStart() - if yyl230 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl230, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys231Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys231Slc - var yyhl231 bool = l >= 0 - for yyj231 := 0; ; yyj231++ { - if yyhl231 { - if yyj231 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys231Slc = r.DecodeBytes(yys231Slc, true, true) - yys231 := string(yys231Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys231 { - case "key": - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - case "operator": - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - case "values": - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv234 := &x.Values - yym235 := z.DecBinary() - _ = yym235 - if false { - } else { - z.F.DecSliceStringX(yyv234, false, d) - } - } - default: - z.DecStructFieldNotFound(-1, yys231) - } // end switch yys231 - } // end for yyj231 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj236 int - var yyb236 bool - var yyhl236 bool = l >= 0 - yyj236++ - if yyhl236 { - yyb236 = yyj236 > l - } else { - yyb236 = r.CheckBreak() - } - if yyb236 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - yyj236++ - if yyhl236 { - yyb236 = yyj236 > l - } else { - yyb236 = r.CheckBreak() - } - if yyb236 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - yyj236++ - if yyhl236 { - yyb236 = yyj236 > l - } else { - yyb236 = r.CheckBreak() - } - if yyb236 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv239 := &x.Values - yym240 := z.DecBinary() - _ = yym240 - if false { - } else { - z.F.DecSliceStringX(yyv239, false, d) - } - } - for { - yyj236++ - if yyhl236 { - yyb236 = yyj236 > l - } else { - yyb236 = r.CheckBreak() - } - if yyb236 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj236-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x LabelSelectorOperator) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym241 := z.EncBinary() - _ = yym241 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *LabelSelectorOperator) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym242 := z.DecBinary() - _ = yym242 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - func (x codecSelfer1234) encSliceJob(v []Job, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv243 := range v { + for _, yyv204 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy244 := &yyv243 - yy244.CodecEncodeSelf(e) + yy205 := &yyv204 + yy205.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -2854,83 +2334,83 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv245 := *v - yyh245, yyl245 := z.DecSliceHelperStart() - var yyc245 bool - if yyl245 == 0 { - if yyv245 == nil { - yyv245 = []Job{} - yyc245 = true - } else if len(yyv245) != 0 { - yyv245 = yyv245[:0] - yyc245 = true + yyv206 := *v + yyh206, yyl206 := z.DecSliceHelperStart() + var yyc206 bool + if yyl206 == 0 { + if yyv206 == nil { + yyv206 = []Job{} + yyc206 = true + } else if len(yyv206) != 0 { + yyv206 = yyv206[:0] + yyc206 = true } - } else if yyl245 > 0 { - var yyrr245, yyrl245 int - var yyrt245 bool - if yyl245 > cap(yyv245) { + } else if yyl206 > 0 { + var yyrr206, yyrl206 int + var yyrt206 bool + if yyl206 > cap(yyv206) { - yyrg245 := len(yyv245) > 0 - yyv2245 := yyv245 - yyrl245, yyrt245 = z.DecInferLen(yyl245, z.DecBasicHandle().MaxInitLen, 824) - if yyrt245 { - if yyrl245 <= cap(yyv245) { - yyv245 = yyv245[:yyrl245] + yyrg206 := len(yyv206) > 0 + yyv2206 := yyv206 + yyrl206, yyrt206 = z.DecInferLen(yyl206, z.DecBasicHandle().MaxInitLen, 824) + if yyrt206 { + if yyrl206 <= cap(yyv206) { + yyv206 = yyv206[:yyrl206] } else { - yyv245 = make([]Job, yyrl245) + yyv206 = make([]Job, yyrl206) } } else { - yyv245 = make([]Job, yyrl245) + yyv206 = make([]Job, yyrl206) } - yyc245 = true - yyrr245 = len(yyv245) - if yyrg245 { - copy(yyv245, yyv2245) + yyc206 = true + yyrr206 = len(yyv206) + if yyrg206 { + copy(yyv206, yyv2206) } - } else if yyl245 != len(yyv245) { - yyv245 = yyv245[:yyl245] - yyc245 = true + } else if yyl206 != len(yyv206) { + yyv206 = yyv206[:yyl206] + yyc206 = true } - yyj245 := 0 - for ; yyj245 < yyrr245; yyj245++ { - yyh245.ElemContainerState(yyj245) + yyj206 := 0 + for ; yyj206 < yyrr206; yyj206++ { + yyh206.ElemContainerState(yyj206) if r.TryDecodeAsNil() { - yyv245[yyj245] = Job{} + yyv206[yyj206] = Job{} } else { - yyv246 := &yyv245[yyj245] - yyv246.CodecDecodeSelf(d) + yyv207 := &yyv206[yyj206] + yyv207.CodecDecodeSelf(d) } } - if yyrt245 { - for ; yyj245 < yyl245; yyj245++ { - yyv245 = append(yyv245, Job{}) - yyh245.ElemContainerState(yyj245) + if yyrt206 { + for ; yyj206 < yyl206; yyj206++ { + yyv206 = append(yyv206, Job{}) + yyh206.ElemContainerState(yyj206) if r.TryDecodeAsNil() { - yyv245[yyj245] = Job{} + yyv206[yyj206] = Job{} } else { - yyv247 := &yyv245[yyj245] - yyv247.CodecDecodeSelf(d) + yyv208 := &yyv206[yyj206] + yyv208.CodecDecodeSelf(d) } } } } else { - yyj245 := 0 - for ; !r.CheckBreak(); yyj245++ { + yyj206 := 0 + for ; !r.CheckBreak(); yyj206++ { - if yyj245 >= len(yyv245) { - yyv245 = append(yyv245, Job{}) // var yyz245 Job - yyc245 = true + if yyj206 >= len(yyv206) { + yyv206 = append(yyv206, Job{}) // var yyz206 Job + yyc206 = true } - yyh245.ElemContainerState(yyj245) - if yyj245 < len(yyv245) { + yyh206.ElemContainerState(yyj206) + if yyj206 < len(yyv206) { if r.TryDecodeAsNil() { - yyv245[yyj245] = Job{} + yyv206[yyj206] = Job{} } else { - yyv248 := &yyv245[yyj245] - yyv248.CodecDecodeSelf(d) + yyv209 := &yyv206[yyj206] + yyv209.CodecDecodeSelf(d) } } else { @@ -2938,17 +2418,17 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { } } - if yyj245 < len(yyv245) { - yyv245 = yyv245[:yyj245] - yyc245 = true - } else if yyj245 == 0 && yyv245 == nil { - yyv245 = []Job{} - yyc245 = true + if yyj206 < len(yyv206) { + yyv206 = yyv206[:yyj206] + yyc206 = true + } else if yyj206 == 0 && yyv206 == nil { + yyv206 = []Job{} + yyc206 = true } } - yyh245.End() - if yyc245 { - *v = yyv245 + yyh206.End() + if yyc206 { + *v = yyv206 } } @@ -2957,10 +2437,10 @@ func (x codecSelfer1234) encSliceJobCondition(v []JobCondition, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv249 := range v { + for _, yyv210 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy250 := &yyv249 - yy250.CodecEncodeSelf(e) + yy211 := &yyv210 + yy211.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -2970,83 +2450,83 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv251 := *v - yyh251, yyl251 := z.DecSliceHelperStart() - var yyc251 bool - if yyl251 == 0 { - if yyv251 == nil { - yyv251 = []JobCondition{} - yyc251 = true - } else if len(yyv251) != 0 { - yyv251 = yyv251[:0] - yyc251 = true + yyv212 := *v + yyh212, yyl212 := z.DecSliceHelperStart() + var yyc212 bool + if yyl212 == 0 { + if yyv212 == nil { + yyv212 = []JobCondition{} + yyc212 = true + } else if len(yyv212) != 0 { + yyv212 = yyv212[:0] + yyc212 = true } - } else if yyl251 > 0 { - var yyrr251, yyrl251 int - var yyrt251 bool - if yyl251 > cap(yyv251) { + } else if yyl212 > 0 { + var yyrr212, yyrl212 int + var yyrt212 bool + if yyl212 > cap(yyv212) { - yyrg251 := len(yyv251) > 0 - yyv2251 := yyv251 - yyrl251, yyrt251 = z.DecInferLen(yyl251, z.DecBasicHandle().MaxInitLen, 112) - if yyrt251 { - if yyrl251 <= cap(yyv251) { - yyv251 = yyv251[:yyrl251] + yyrg212 := len(yyv212) > 0 + yyv2212 := yyv212 + yyrl212, yyrt212 = z.DecInferLen(yyl212, z.DecBasicHandle().MaxInitLen, 112) + if yyrt212 { + if yyrl212 <= cap(yyv212) { + yyv212 = yyv212[:yyrl212] } else { - yyv251 = make([]JobCondition, yyrl251) + yyv212 = make([]JobCondition, yyrl212) } } else { - yyv251 = make([]JobCondition, yyrl251) + yyv212 = make([]JobCondition, yyrl212) } - yyc251 = true - yyrr251 = len(yyv251) - if yyrg251 { - copy(yyv251, yyv2251) + yyc212 = true + yyrr212 = len(yyv212) + if yyrg212 { + copy(yyv212, yyv2212) } - } else if yyl251 != len(yyv251) { - yyv251 = yyv251[:yyl251] - yyc251 = true + } else if yyl212 != len(yyv212) { + yyv212 = yyv212[:yyl212] + yyc212 = true } - yyj251 := 0 - for ; yyj251 < yyrr251; yyj251++ { - yyh251.ElemContainerState(yyj251) + yyj212 := 0 + for ; yyj212 < yyrr212; yyj212++ { + yyh212.ElemContainerState(yyj212) if r.TryDecodeAsNil() { - yyv251[yyj251] = JobCondition{} + yyv212[yyj212] = JobCondition{} } else { - yyv252 := &yyv251[yyj251] - yyv252.CodecDecodeSelf(d) + yyv213 := &yyv212[yyj212] + yyv213.CodecDecodeSelf(d) } } - if yyrt251 { - for ; yyj251 < yyl251; yyj251++ { - yyv251 = append(yyv251, JobCondition{}) - yyh251.ElemContainerState(yyj251) + if yyrt212 { + for ; yyj212 < yyl212; yyj212++ { + yyv212 = append(yyv212, JobCondition{}) + yyh212.ElemContainerState(yyj212) if r.TryDecodeAsNil() { - yyv251[yyj251] = JobCondition{} + yyv212[yyj212] = JobCondition{} } else { - yyv253 := &yyv251[yyj251] - yyv253.CodecDecodeSelf(d) + yyv214 := &yyv212[yyj212] + yyv214.CodecDecodeSelf(d) } } } } else { - yyj251 := 0 - for ; !r.CheckBreak(); yyj251++ { + yyj212 := 0 + for ; !r.CheckBreak(); yyj212++ { - if yyj251 >= len(yyv251) { - yyv251 = append(yyv251, JobCondition{}) // var yyz251 JobCondition - yyc251 = true + if yyj212 >= len(yyv212) { + yyv212 = append(yyv212, JobCondition{}) // var yyz212 JobCondition + yyc212 = true } - yyh251.ElemContainerState(yyj251) - if yyj251 < len(yyv251) { + yyh212.ElemContainerState(yyj212) + if yyj212 < len(yyv212) { if r.TryDecodeAsNil() { - yyv251[yyj251] = JobCondition{} + yyv212[yyj212] = JobCondition{} } else { - yyv254 := &yyv251[yyj251] - yyv254.CodecDecodeSelf(d) + yyv215 := &yyv212[yyj212] + yyv215.CodecDecodeSelf(d) } } else { @@ -3054,132 +2534,16 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De } } - if yyj251 < len(yyv251) { - yyv251 = yyv251[:yyj251] - yyc251 = true - } else if yyj251 == 0 && yyv251 == nil { - yyv251 = []JobCondition{} - yyc251 = true + if yyj212 < len(yyv212) { + yyv212 = yyv212[:yyj212] + yyc212 = true + } else if yyj212 == 0 && yyv212 == nil { + yyv212 = []JobCondition{} + yyc212 = true } } - yyh251.End() - if yyc251 { - *v = yyv251 - } -} - -func (x codecSelfer1234) encSliceLabelSelectorRequirement(v []LabelSelectorRequirement, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv255 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy256 := &yyv255 - yy256.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequirement, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv257 := *v - yyh257, yyl257 := z.DecSliceHelperStart() - var yyc257 bool - if yyl257 == 0 { - if yyv257 == nil { - yyv257 = []LabelSelectorRequirement{} - yyc257 = true - } else if len(yyv257) != 0 { - yyv257 = yyv257[:0] - yyc257 = true - } - } else if yyl257 > 0 { - var yyrr257, yyrl257 int - var yyrt257 bool - if yyl257 > cap(yyv257) { - - yyrg257 := len(yyv257) > 0 - yyv2257 := yyv257 - yyrl257, yyrt257 = z.DecInferLen(yyl257, z.DecBasicHandle().MaxInitLen, 56) - if yyrt257 { - if yyrl257 <= cap(yyv257) { - yyv257 = yyv257[:yyrl257] - } else { - yyv257 = make([]LabelSelectorRequirement, yyrl257) - } - } else { - yyv257 = make([]LabelSelectorRequirement, yyrl257) - } - yyc257 = true - yyrr257 = len(yyv257) - if yyrg257 { - copy(yyv257, yyv2257) - } - } else if yyl257 != len(yyv257) { - yyv257 = yyv257[:yyl257] - yyc257 = true - } - yyj257 := 0 - for ; yyj257 < yyrr257; yyj257++ { - yyh257.ElemContainerState(yyj257) - if r.TryDecodeAsNil() { - yyv257[yyj257] = LabelSelectorRequirement{} - } else { - yyv258 := &yyv257[yyj257] - yyv258.CodecDecodeSelf(d) - } - - } - if yyrt257 { - for ; yyj257 < yyl257; yyj257++ { - yyv257 = append(yyv257, LabelSelectorRequirement{}) - yyh257.ElemContainerState(yyj257) - if r.TryDecodeAsNil() { - yyv257[yyj257] = LabelSelectorRequirement{} - } else { - yyv259 := &yyv257[yyj257] - yyv259.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj257 := 0 - for ; !r.CheckBreak(); yyj257++ { - - if yyj257 >= len(yyv257) { - yyv257 = append(yyv257, LabelSelectorRequirement{}) // var yyz257 LabelSelectorRequirement - yyc257 = true - } - yyh257.ElemContainerState(yyj257) - if yyj257 < len(yyv257) { - if r.TryDecodeAsNil() { - yyv257[yyj257] = LabelSelectorRequirement{} - } else { - yyv260 := &yyv257[yyj257] - yyv260.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj257 < len(yyv257) { - yyv257 = yyv257[:yyj257] - yyc257 = true - } else if yyj257 == 0 && yyv257 == nil { - yyv257 = []LabelSelectorRequirement{} - yyc257 = true - } - } - yyh257.End() - if yyc257 { - *v = yyv257 + yyh212.End() + if yyc212 { + *v = yyv212 } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types.go similarity index 75% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/types.go index 34b8c3d..ec44c4e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types.go @@ -17,8 +17,8 @@ limitations under the License. package v1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true @@ -28,14 +28,17 @@ type Job struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status JobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -44,6 +47,7 @@ type JobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Job. @@ -58,6 +62,7 @@ type JobSpec struct { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Parallelism *int32 `json:"parallelism,omitempty" protobuf:"varint,1,opt,name=parallelism"` // Completions specifies the desired number of successfully finished pods the @@ -66,16 +71,19 @@ type JobSpec struct { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Completions *int32 `json:"completions,omitempty" protobuf:"varint,2,opt,name=completions"` // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty" protobuf:"varint,3,opt,name=activeDeadlineSeconds"` // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` // ManualSelector controls generation of pod labels and pod selectors. // Leave `manualSelector` unset unless you are certain what you are doing. @@ -87,6 +95,7 @@ type JobSpec struct { // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` // API. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional ManualSelector *bool `json:"manualSelector,omitempty" protobuf:"varint,5,opt,name=manualSelector"` // Template is the object that describes the pod that will be created when @@ -100,25 +109,31 @@ type JobStatus struct { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Conditions []JobCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,1,rep,name=conditions"` // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty" protobuf:"bytes,2,opt,name=startTime"` // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional CompletionTime *unversioned.Time `json:"completionTime,omitempty" protobuf:"bytes,3,opt,name=completionTime"` // Active is the number of actively running pods. + // +optional Active int32 `json:"active,omitempty" protobuf:"varint,4,opt,name=active"` // Succeeded is the number of pods which reached Phase Succeeded. + // +optional Succeeded int32 `json:"succeeded,omitempty" protobuf:"varint,5,opt,name=succeeded"` // Failed is the number of pods which reached Phase Failed. + // +optional Failed int32 `json:"failed,omitempty" protobuf:"varint,6,opt,name=failed"` } @@ -139,48 +154,15 @@ type JobCondition struct { // Status of the condition, one of True, False, Unknown. Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/kubernetes/pkg/api/v1.ConditionStatus"` // Last time the condition was checked. + // +optional LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty" protobuf:"bytes,3,opt,name=lastProbeTime"` // Last time the condition transit from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` // (brief) reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` // Human readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` } - -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -type LabelSelector struct { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - MatchLabels map[string]string `json:"matchLabels,omitempty" protobuf:"bytes,1,rep,name=matchLabels"` - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - MatchExpressions []LabelSelectorRequirement `json:"matchExpressions,omitempty" protobuf:"bytes,2,rep,name=matchExpressions"` -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -type LabelSelectorRequirement struct { - // key is the label key that the selector applies to. - Key string `json:"key" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,1,opt,name=key"` - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - Operator LabelSelectorOperator `json:"operator" protobuf:"bytes,2,opt,name=operator,casttype=LabelSelectorOperator"` - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - Values []string `json:"values,omitempty" protobuf:"bytes,3,rep,name=values"` -} - -// A label selector operator is the set of operators that can be used in a selector requirement. -type LabelSelectorOperator string - -const ( - LabelSelectorOpIn LabelSelectorOperator = "In" - LabelSelectorOpNotIn LabelSelectorOperator = "NotIn" - LabelSelectorOpExists LabelSelectorOperator = "Exists" - LabelSelectorOpDoesNotExist LabelSelectorOperator = "DoesNotExist" -) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types_swagger_doc_generated.go similarity index 80% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/types_swagger_doc_generated.go index 10d76e2..3d224e7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/types_swagger_doc_generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/types_swagger_doc_generated.go @@ -90,25 +90,4 @@ func (JobStatus) SwaggerDoc() map[string]string { return map_JobStatus } -var map_LabelSelector = map[string]string{ - "": "A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects.", - "matchLabels": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", - "matchExpressions": "matchExpressions is a list of label selector requirements. The requirements are ANDed.", -} - -func (LabelSelector) SwaggerDoc() map[string]string { - return map_LabelSelector -} - -var map_LabelSelectorRequirement = map[string]string{ - "": "A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.", - "key": "key is the label key that the selector applies to.", - "operator": "operator represents a key's relationship to a set of values. Valid operators ard In, NotIn, Exists and DoesNotExist.", - "values": "values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.", -} - -func (LabelSelectorRequirement) SwaggerDoc() map[string]string { - return map_LabelSelectorRequirement -} - // AUTO-GENERATED FUNCTIONS END HERE diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.conversion.go similarity index 57% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.conversion.go index 3dc90d0..0697026 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.conversion.go @@ -21,12 +21,11 @@ limitations under the License. package v1 import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - api_v1 "k8s.io/kubernetes/pkg/api/v1" - batch "k8s.io/kubernetes/pkg/apis/batch" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + api_v1 "k8s.io/client-go/pkg/api/v1" + batch "k8s.io/client-go/pkg/apis/batch" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -47,18 +46,10 @@ func RegisterConversions(scheme *runtime.Scheme) error { Convert_batch_JobSpec_To_v1_JobSpec, Convert_v1_JobStatus_To_batch_JobStatus, Convert_batch_JobStatus_To_v1_JobStatus, - Convert_v1_LabelSelector_To_unversioned_LabelSelector, - Convert_unversioned_LabelSelector_To_v1_LabelSelector, - Convert_v1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement, - Convert_unversioned_LabelSelectorRequirement_To_v1_LabelSelectorRequirement, ) } func autoConvert_v1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Scope) error { - SetDefaults_Job(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -77,9 +68,6 @@ func Convert_v1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Scope) er } func autoConvert_batch_Job_To_v1_Job(in *batch.Job, out *Job, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -100,12 +88,8 @@ func Convert_batch_Job_To_v1_Job(in *batch.Job, out *Job, s conversion.Scope) er func autoConvert_v1_JobCondition_To_batch_JobCondition(in *JobCondition, out *batch.JobCondition, s conversion.Scope) error { out.Type = batch.JobConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -118,12 +102,8 @@ func Convert_v1_JobCondition_To_batch_JobCondition(in *JobCondition, out *batch. func autoConvert_batch_JobCondition_To_v1_JobCondition(in *batch.JobCondition, out *JobCondition, s conversion.Scope) error { out.Type = JobConditionType(in.Type) out.Status = api_v1.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -134,12 +114,7 @@ func Convert_batch_JobCondition_To_v1_JobCondition(in *batch.JobCondition, out * } func autoConvert_v1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]batch.Job, len(*in)) @@ -159,12 +134,7 @@ func Convert_v1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, s conv } func autoConvert_batch_JobList_To_v1_JobList(in *batch.JobList, out *JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Job, len(*in)) @@ -187,15 +157,7 @@ func autoConvert_v1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSpec, s out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector out.ManualSelector = in.ManualSelector if err := api_v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -207,15 +169,7 @@ func autoConvert_batch_JobSpec_To_v1_JobSpec(in *batch.JobSpec, out *JobSpec, s out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector out.ManualSelector = in.ManualSelector if err := api_v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -270,65 +224,3 @@ func autoConvert_batch_JobStatus_To_v1_JobStatus(in *batch.JobStatus, out *JobSt func Convert_batch_JobStatus_To_v1_JobStatus(in *batch.JobStatus, out *JobStatus, s conversion.Scope) error { return autoConvert_batch_JobStatus_To_v1_JobStatus(in, out, s) } - -func autoConvert_v1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]unversioned.LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_v1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_v1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - return autoConvert_v1_LabelSelector_To_unversioned_LabelSelector(in, out, s) -} - -func autoConvert_unversioned_LabelSelector_To_v1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_unversioned_LabelSelectorRequirement_To_v1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_unversioned_LabelSelector_To_v1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelector_To_v1_LabelSelector(in, out, s) -} - -func autoConvert_v1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = unversioned.LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_v1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_v1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in, out, s) -} - -func autoConvert_unversioned_LabelSelectorRequirement_To_v1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_unversioned_LabelSelectorRequirement_To_v1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelectorRequirement_To_v1_LabelSelectorRequirement(in, out, s) -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.deepcopy.go similarity index 74% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.deepcopy.go index 9163e83..8a9e4e8 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - api_v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + unversioned "k8s.io/client-go/pkg/api/unversioned" + api_v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) @@ -41,8 +41,6 @@ func RegisterDeepCopies(scheme *runtime.Scheme) error { conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1_JobList, InType: reflect.TypeOf(&JobList{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1_JobSpec, InType: reflect.TypeOf(&JobSpec{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1_JobStatus, InType: reflect.TypeOf(&JobStatus{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1_LabelSelector, InType: reflect.TypeOf(&LabelSelector{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1_LabelSelectorRequirement, InType: reflect.TypeOf(&LabelSelectorRequirement{})}, ) } @@ -126,8 +124,8 @@ func DeepCopy_v1_JobSpec(in interface{}, out interface{}, c *conversion.Cloner) } if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -182,48 +180,3 @@ func DeepCopy_v1_JobStatus(in interface{}, out interface{}, c *conversion.Cloner return nil } } - -func DeepCopy_v1_LabelSelector(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelector) - out := out.(*LabelSelector) - if in.MatchLabels != nil { - in, out := &in.MatchLabels, &out.MatchLabels - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.MatchLabels = nil - } - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := DeepCopy_v1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], c); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil - } -} - -func DeepCopy_v1_LabelSelectorRequirement(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelectorRequirement) - out := out.(*LabelSelectorRequirement) - out.Key = in.Key - out.Operator = in.Operator - if in.Values != nil { - in, out := &in.Values, &out.Values - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.Values = nil - } - return nil - } -} diff --git a/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.defaults.go new file mode 100644 index 0000000..ef8a8b0 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v1/zz_generated.defaults.go @@ -0,0 +1,159 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1 + +import ( + api_v1 "k8s.io/client-go/pkg/api/v1" + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&Job{}, func(obj interface{}) { SetObjectDefaults_Job(obj.(*Job)) }) + scheme.AddTypeDefaultingFunc(&JobList{}, func(obj interface{}) { SetObjectDefaults_JobList(obj.(*JobList)) }) + return nil +} + +func SetObjectDefaults_Job(in *Job) { + SetDefaults_Job(in) + api_v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + api_v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + api_v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + api_v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + api_v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + api_v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + api_v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + api_v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + api_v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + api_v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + api_v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + api_v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + api_v1.SetDefaults_ResourceList(&a.Resources.Limits) + api_v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + api_v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + api_v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + api_v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + api_v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + api_v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + api_v1.SetDefaults_ResourceList(&a.Resources.Limits) + api_v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + api_v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + api_v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + api_v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_JobList(in *JobList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Job(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/conversion.go similarity index 68% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/conversion.go index 0ac589d..8878c84 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/conversion.go @@ -18,14 +18,12 @@ package v2alpha1 import ( "fmt" - "reflect" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/apis/batch" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { @@ -57,21 +55,10 @@ func addConversionFuncs(scheme *runtime.Scheme) error { } func Convert_batch_JobSpec_To_v2alpha1_JobSpec(in *batch.JobSpec, out *JobSpec, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*batch.JobSpec))(in) - } out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for unversioned.LabelSelector -> v1.LabelSelector - if in.Selector != nil { - out.Selector = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v2alpha1_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if in.ManualSelector != nil { out.ManualSelector = new(bool) *out.ManualSelector = *in.ManualSelector @@ -86,21 +73,10 @@ func Convert_batch_JobSpec_To_v2alpha1_JobSpec(in *batch.JobSpec, out *JobSpec, } func Convert_v2alpha1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSpec, s conversion.Scope) error { - if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { - defaulting.(func(*JobSpec))(in) - } out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for unversioned.LabelSelector -> v1.LabelSelector - if in.Selector != nil { - out.Selector = new(unversioned.LabelSelector) - if err := Convert_v2alpha1_LabelSelector_To_unversioned_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if in.ManualSelector != nil { out.ManualSelector = new(bool) *out.ManualSelector = *in.ManualSelector diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/defaults.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/defaults.go index 1c06e66..787505b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/defaults.go @@ -17,10 +17,11 @@ limitations under the License. package v2alpha1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( SetDefaults_Job, SetDefaults_ScheduledJob, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/doc.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/doc.go index 087b478..8fb2e2e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/doc.go @@ -17,5 +17,6 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/batch // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v2alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.pb.go similarity index 74% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.pb.go index e228055..7ff2256 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.pb.go @@ -32,8 +32,6 @@ limitations under the License. JobStatus JobTemplate JobTemplateSpec - LabelSelector - LabelSelectorRequirement ScheduledJob ScheduledJobList ScheduledJobSpec @@ -45,12 +43,11 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_api_v1 "k8s.io/kubernetes/pkg/api/v1" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_v1 "k8s.io/client-go/pkg/api/v1" import strings "strings" import reflect "reflect" -import github_com_gogo_protobuf_sortkeys "github.com/gogo/protobuf/sortkeys" import io "io" @@ -91,46 +88,34 @@ func (m *JobTemplateSpec) Reset() { *m = JobTemplateSpec{} } func (*JobTemplateSpec) ProtoMessage() {} func (*JobTemplateSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{6} } -func (m *LabelSelector) Reset() { *m = LabelSelector{} } -func (*LabelSelector) ProtoMessage() {} -func (*LabelSelector) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{7} } - -func (m *LabelSelectorRequirement) Reset() { *m = LabelSelectorRequirement{} } -func (*LabelSelectorRequirement) ProtoMessage() {} -func (*LabelSelectorRequirement) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{8} -} - func (m *ScheduledJob) Reset() { *m = ScheduledJob{} } func (*ScheduledJob) ProtoMessage() {} -func (*ScheduledJob) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{9} } +func (*ScheduledJob) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{7} } func (m *ScheduledJobList) Reset() { *m = ScheduledJobList{} } func (*ScheduledJobList) ProtoMessage() {} -func (*ScheduledJobList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{10} } +func (*ScheduledJobList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{8} } func (m *ScheduledJobSpec) Reset() { *m = ScheduledJobSpec{} } func (*ScheduledJobSpec) ProtoMessage() {} -func (*ScheduledJobSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{11} } +func (*ScheduledJobSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{9} } func (m *ScheduledJobStatus) Reset() { *m = ScheduledJobStatus{} } func (*ScheduledJobStatus) ProtoMessage() {} -func (*ScheduledJobStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{12} } +func (*ScheduledJobStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{10} } func init() { - proto.RegisterType((*Job)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.Job") - proto.RegisterType((*JobCondition)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobCondition") - proto.RegisterType((*JobList)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobList") - proto.RegisterType((*JobSpec)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobSpec") - proto.RegisterType((*JobStatus)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobStatus") - proto.RegisterType((*JobTemplate)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobTemplate") - proto.RegisterType((*JobTemplateSpec)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.JobTemplateSpec") - proto.RegisterType((*LabelSelector)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.LabelSelector") - proto.RegisterType((*LabelSelectorRequirement)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.LabelSelectorRequirement") - proto.RegisterType((*ScheduledJob)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.ScheduledJob") - proto.RegisterType((*ScheduledJobList)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.ScheduledJobList") - proto.RegisterType((*ScheduledJobSpec)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.ScheduledJobSpec") - proto.RegisterType((*ScheduledJobStatus)(nil), "k8s.io.kubernetes.pkg.apis.batch.v2alpha1.ScheduledJobStatus") + proto.RegisterType((*Job)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.Job") + proto.RegisterType((*JobCondition)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobCondition") + proto.RegisterType((*JobList)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobList") + proto.RegisterType((*JobSpec)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobSpec") + proto.RegisterType((*JobStatus)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobStatus") + proto.RegisterType((*JobTemplate)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobTemplate") + proto.RegisterType((*JobTemplateSpec)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.JobTemplateSpec") + proto.RegisterType((*ScheduledJob)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.ScheduledJob") + proto.RegisterType((*ScheduledJobList)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.ScheduledJobList") + proto.RegisterType((*ScheduledJobSpec)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.ScheduledJobSpec") + proto.RegisterType((*ScheduledJobStatus)(nil), "k8s.io.client-go.pkg.apis.batch.v2alpha1.ScheduledJobStatus") } func (m *Job) Marshal() (data []byte, err error) { size := m.Size() @@ -450,94 +435,6 @@ func (m *JobTemplateSpec) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *LabelSelector) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelector) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k := range m.MatchLabels { - data[i] = 0xa - i++ - v := m.MatchLabels[k] - mapSize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - i = encodeVarintGenerated(data, i, uint64(mapSize)) - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(k))) - i += copy(data[i:], k) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(v))) - i += copy(data[i:], v) - } - } - if len(m.MatchExpressions) > 0 { - for _, msg := range m.MatchExpressions { - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(msg.Size())) - n, err := msg.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n - } - } - return i, nil -} - -func (m *LabelSelectorRequirement) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelectorRequirement) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Key))) - i += copy(data[i:], m.Key) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Operator))) - i += copy(data[i:], m.Operator) - if len(m.Values) > 0 { - for _, s := range m.Values { - data[i] = 0x1a - i++ - l = len(s) - for l >= 1<<7 { - data[i] = uint8(uint64(l)&0x7f | 0x80) - l >>= 7 - i++ - } - data[i] = uint8(l) - i++ - i += copy(data[i:], s) - } - } - return i, nil -} - func (m *ScheduledJob) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) @@ -845,42 +742,6 @@ func (m *JobTemplateSpec) Size() (n int) { return n } -func (m *LabelSelector) Size() (n int) { - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k, v := range m.MatchLabels { - _ = k - _ = v - mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) - } - } - if len(m.MatchExpressions) > 0 { - for _, e := range m.MatchExpressions { - l = e.Size() - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - -func (m *LabelSelectorRequirement) Size() (n int) { - var l int - _ = l - l = len(m.Key) - n += 1 + l + sovGenerated(uint64(l)) - l = len(m.Operator) - n += 1 + l + sovGenerated(uint64(l)) - if len(m.Values) > 0 { - for _, s := range m.Values { - l = len(s) - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - func (m *ScheduledJob) Size() (n int) { var l int _ = l @@ -1000,7 +861,7 @@ func (this *JobSpec) String() string { `Parallelism:` + valueToStringGenerated(this.Parallelism) + `,`, `Completions:` + valueToStringGenerated(this.Completions) + `,`, `ActiveDeadlineSeconds:` + valueToStringGenerated(this.ActiveDeadlineSeconds) + `,`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `ManualSelector:` + valueToStringGenerated(this.ManualSelector) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `}`, @@ -1044,39 +905,6 @@ func (this *JobTemplateSpec) String() string { }, "") return s } -func (this *LabelSelector) String() string { - if this == nil { - return "nil" - } - keysForMatchLabels := make([]string, 0, len(this.MatchLabels)) - for k := range this.MatchLabels { - keysForMatchLabels = append(keysForMatchLabels, k) - } - github_com_gogo_protobuf_sortkeys.Strings(keysForMatchLabels) - mapStringForMatchLabels := "map[string]string{" - for _, k := range keysForMatchLabels { - mapStringForMatchLabels += fmt.Sprintf("%v: %v,", k, this.MatchLabels[k]) - } - mapStringForMatchLabels += "}" - s := strings.Join([]string{`&LabelSelector{`, - `MatchLabels:` + mapStringForMatchLabels + `,`, - `MatchExpressions:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.MatchExpressions), "LabelSelectorRequirement", "LabelSelectorRequirement", 1), `&`, ``, 1) + `,`, - `}`, - }, "") - return s -} -func (this *LabelSelectorRequirement) String() string { - if this == nil { - return "nil" - } - s := strings.Join([]string{`&LabelSelectorRequirement{`, - `Key:` + fmt.Sprintf("%v", this.Key) + `,`, - `Operator:` + fmt.Sprintf("%v", this.Operator) + `,`, - `Values:` + fmt.Sprintf("%v", this.Values) + `,`, - `}`, - }, "") - return s -} func (this *ScheduledJob) String() string { if this == nil { return "nil" @@ -1726,7 +1554,7 @@ func (m *JobSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -2228,335 +2056,6 @@ func (m *JobTemplateSpec) Unmarshal(data []byte) error { } return nil } -func (m *LabelSelector) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelector: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelector: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchLabels", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - var keykey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - keykey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapkey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapkey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapkey := int(stringLenmapkey) - if intStringLenmapkey < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapkey := iNdEx + intStringLenmapkey - if postStringIndexmapkey > l { - return io.ErrUnexpectedEOF - } - mapkey := string(data[iNdEx:postStringIndexmapkey]) - iNdEx = postStringIndexmapkey - var valuekey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - valuekey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapvalue uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapvalue |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapvalue := int(stringLenmapvalue) - if intStringLenmapvalue < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapvalue := iNdEx + intStringLenmapvalue - if postStringIndexmapvalue > l { - return io.ErrUnexpectedEOF - } - mapvalue := string(data[iNdEx:postStringIndexmapvalue]) - iNdEx = postStringIndexmapvalue - if m.MatchLabels == nil { - m.MatchLabels = make(map[string]string) - } - m.MatchLabels[mapkey] = mapvalue - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchExpressions", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.MatchExpressions = append(m.MatchExpressions, LabelSelectorRequirement{}) - if err := m.MatchExpressions[len(m.MatchExpressions)-1].Unmarshal(data[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *LabelSelectorRequirement) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelectorRequirement: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelectorRequirement: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Key = string(data[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Operator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Operator = LabelSelectorOperator(data[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Values", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Values = append(m.Values, string(data[iNdEx:postIndex])) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} func (m *ScheduledJob) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 @@ -3207,87 +2706,77 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 1300 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xd4, 0x57, 0xcf, 0x6f, 0x1b, 0xc5, - 0x17, 0xaf, 0xed, 0xd8, 0xb1, 0xc7, 0xf9, 0xe1, 0xcc, 0xb7, 0x51, 0xfd, 0x35, 0x22, 0xa9, 0x2c, - 0x81, 0x1a, 0x68, 0x76, 0x95, 0xa8, 0xa8, 0x21, 0x88, 0x4a, 0x6c, 0x08, 0x52, 0x21, 0x51, 0xa2, - 0x71, 0xa8, 0x10, 0xb4, 0x87, 0xf1, 0x7a, 0x62, 0x6f, 0xb3, 0xde, 0x75, 0x77, 0x67, 0x0d, 0xbe, - 0xf5, 0xca, 0x09, 0x24, 0xfe, 0x05, 0xce, 0xfc, 0x05, 0xf4, 0xc0, 0x2d, 0x37, 0x0a, 0x27, 0xc4, - 0x21, 0x82, 0xf2, 0x5f, 0xf4, 0xc4, 0x9b, 0xd9, 0xd9, 0xf5, 0xfa, 0x57, 0x14, 0x1b, 0x15, 0x89, - 0xc3, 0x4a, 0x9e, 0x37, 0xef, 0xf3, 0x99, 0x37, 0xf3, 0x3e, 0xf3, 0xe6, 0x19, 0xbd, 0x7b, 0xb6, - 0xe3, 0x6b, 0x96, 0xab, 0x9f, 0x05, 0x75, 0xe6, 0x39, 0x8c, 0x33, 0x5f, 0xef, 0x9c, 0x35, 0x75, - 0xda, 0xb1, 0x7c, 0xbd, 0x4e, 0xb9, 0xd9, 0xd2, 0xbb, 0xdb, 0xd4, 0xee, 0xb4, 0xe8, 0x96, 0xde, - 0x64, 0x0e, 0xf3, 0x28, 0x67, 0x0d, 0xad, 0xe3, 0xb9, 0xdc, 0xc5, 0x1b, 0x21, 0x54, 0xeb, 0x43, - 0x35, 0x80, 0x6a, 0x02, 0xaa, 0x49, 0xa8, 0x16, 0x41, 0x2b, 0x9b, 0x4d, 0x8b, 0xb7, 0x82, 0xba, - 0x66, 0xba, 0x6d, 0xbd, 0xe9, 0x36, 0x5d, 0x5d, 0x32, 0xd4, 0x83, 0x53, 0x39, 0x92, 0x03, 0xf9, - 0x2b, 0x64, 0xae, 0x6c, 0x4f, 0x0c, 0x4a, 0xf7, 0x98, 0xef, 0x06, 0x9e, 0xc9, 0x86, 0xa3, 0xa9, - 0xbc, 0x33, 0x19, 0x13, 0x38, 0x5d, 0xe6, 0xf9, 0x96, 0xeb, 0xb0, 0xc6, 0x08, 0xec, 0xf6, 0x64, - 0x58, 0x77, 0x64, 0xcb, 0x95, 0xcd, 0xf1, 0xde, 0x5e, 0xe0, 0x70, 0xab, 0x3d, 0x1a, 0xd3, 0xd6, - 0x78, 0xf7, 0x80, 0x5b, 0xb6, 0x6e, 0x39, 0xdc, 0xe7, 0xde, 0x30, 0xa4, 0xfa, 0x5d, 0x1a, 0x65, - 0x3e, 0x76, 0xeb, 0xf8, 0x33, 0x94, 0x6f, 0x33, 0x4e, 0x1b, 0x94, 0xd3, 0x72, 0xea, 0x66, 0xea, - 0x56, 0x71, 0xfb, 0x96, 0x36, 0xf1, 0xbc, 0xb5, 0xee, 0x96, 0x76, 0x54, 0x7f, 0xcc, 0x4c, 0x7e, - 0x08, 0x18, 0x03, 0x9f, 0x5f, 0xac, 0x5f, 0x7b, 0x71, 0xb1, 0x8e, 0xfa, 0x36, 0x12, 0xb3, 0xe1, - 0x13, 0x34, 0xe7, 0x77, 0x98, 0x59, 0x4e, 0x4b, 0xd6, 0x6d, 0xed, 0xca, 0x59, 0xd4, 0x20, 0xae, - 0x1a, 0x20, 0x8d, 0x05, 0xc5, 0x3f, 0x27, 0x46, 0x44, 0xb2, 0xe1, 0x87, 0x28, 0xe7, 0x73, 0xca, - 0x03, 0xbf, 0x9c, 0x91, 0xbc, 0x77, 0xa6, 0xe4, 0x95, 0x58, 0x63, 0x49, 0x31, 0xe7, 0xc2, 0x31, - 0x51, 0x9c, 0xd5, 0x5f, 0x33, 0x68, 0x01, 0xbc, 0xf6, 0x5c, 0xa7, 0x61, 0x71, 0x48, 0x24, 0xbe, - 0x83, 0xe6, 0x78, 0xaf, 0xc3, 0xe4, 0xd1, 0x14, 0x8c, 0x9b, 0x51, 0x40, 0x27, 0x60, 0x7b, 0x79, - 0xb1, 0x5e, 0x4a, 0xfa, 0x0a, 0x1b, 0x91, 0xde, 0xf8, 0x41, 0x1c, 0x64, 0x5a, 0xe2, 0xee, 0x0d, - 0x2e, 0x07, 0xc8, 0x4b, 0xe5, 0xa0, 0xc5, 0x9c, 0x83, 0xe1, 0xe1, 0x16, 0x5a, 0xb4, 0xa9, 0xcf, - 0x8f, 0x3d, 0xb7, 0xce, 0x4e, 0x40, 0x08, 0xea, 0x0c, 0xde, 0xbe, 0x24, 0x63, 0x09, 0x4d, 0x6a, - 0x02, 0x62, 0xac, 0xaa, 0x58, 0x16, 0x0f, 0x92, 0x4c, 0x64, 0x90, 0x18, 0x7f, 0x89, 0xb0, 0x30, - 0x9c, 0x78, 0xd4, 0xf1, 0xc3, 0xdd, 0x89, 0xe5, 0xe6, 0xa6, 0x5f, 0xae, 0xa2, 0x96, 0xc3, 0x07, - 0x23, 0x74, 0x64, 0xcc, 0x12, 0xf8, 0x4d, 0x94, 0xf3, 0x18, 0xf5, 0x5d, 0xa7, 0x9c, 0x95, 0x47, - 0x17, 0x67, 0x8a, 0x48, 0x2b, 0x51, 0xb3, 0x78, 0x03, 0xcd, 0xb7, 0x99, 0xef, 0xd3, 0x26, 0x2b, - 0xe7, 0xa4, 0xe3, 0xb2, 0x72, 0x9c, 0x3f, 0x0c, 0xcd, 0x24, 0x9a, 0xaf, 0x3e, 0x4b, 0xa1, 0x79, - 0x48, 0xd4, 0x81, 0xe5, 0x73, 0xfc, 0x68, 0x44, 0xee, 0xfa, 0x15, 0x77, 0x23, 0xe0, 0x52, 0xf5, - 0x25, 0xb5, 0x50, 0x3e, 0xb2, 0x24, 0x34, 0x5f, 0x43, 0x59, 0x8b, 0xb3, 0xb6, 0xc8, 0x7b, 0x06, - 0xb8, 0xb5, 0xe9, 0xc4, 0x69, 0x2c, 0x2a, 0xea, 0xec, 0x7d, 0x41, 0x42, 0x42, 0xae, 0xea, 0xb3, - 0x8c, 0x8c, 0x5f, 0x5c, 0x02, 0xbc, 0x85, 0x8a, 0x1d, 0xea, 0x51, 0xdb, 0x66, 0xb6, 0xe5, 0xb7, - 0xe5, 0x16, 0xb2, 0xc6, 0x32, 0x40, 0x8a, 0xc7, 0x7d, 0x33, 0x49, 0xfa, 0x08, 0x08, 0x94, 0xc3, - 0x8e, 0xcd, 0xc4, 0x19, 0x87, 0x8a, 0x54, 0x90, 0xbd, 0xbe, 0x99, 0x24, 0x7d, 0xf0, 0x11, 0x5a, - 0xa5, 0x26, 0xb7, 0xba, 0xec, 0x43, 0x46, 0x1b, 0xb6, 0xe5, 0xb0, 0x1a, 0x33, 0x41, 0x92, 0xe1, - 0x9d, 0xcb, 0x18, 0xff, 0x07, 0xf0, 0xea, 0x07, 0xe3, 0x1c, 0xc8, 0x78, 0x1c, 0xae, 0xa3, 0xbc, - 0xcf, 0x6c, 0xa8, 0x11, 0xae, 0xa7, 0x44, 0xb4, 0x33, 0xc5, 0xd1, 0x1c, 0xd0, 0x3a, 0xb3, 0x6b, - 0x0a, 0x6f, 0x2c, 0x88, 0xb3, 0x8f, 0x46, 0x24, 0xe6, 0xc5, 0xbb, 0x68, 0xa9, 0x4d, 0x9d, 0x80, - 0xc6, 0x9e, 0x52, 0x41, 0x79, 0x03, 0x83, 0xff, 0xd2, 0xe1, 0xc0, 0x0c, 0x19, 0xf2, 0xc4, 0x5f, - 0xa0, 0x3c, 0x1c, 0x75, 0xc7, 0x86, 0x02, 0x29, 0xe5, 0x54, 0xdc, 0xde, 0xbc, 0xbc, 0x0a, 0x1e, - 0xbb, 0x8d, 0x13, 0x05, 0x90, 0xa5, 0x2a, 0x16, 0x45, 0x64, 0x25, 0x31, 0x61, 0xf5, 0xc7, 0x0c, - 0x2a, 0xc4, 0xa5, 0x07, 0x9f, 0x21, 0x64, 0x46, 0xd7, 0xdb, 0x87, 0x04, 0x0a, 0x9d, 0xdc, 0x9d, - 0x4e, 0x27, 0x71, 0x79, 0xe8, 0x57, 0xe0, 0xd8, 0xe4, 0x93, 0x04, 0x3d, 0x54, 0xf7, 0x02, 0x94, - 0x0e, 0x8f, 0xcb, 0xdb, 0x9b, 0x9e, 0xfe, 0xf6, 0x2e, 0x02, 0x77, 0xa1, 0x16, 0x31, 0x90, 0x3e, - 0x19, 0x6e, 0xa2, 0xa5, 0xbe, 0x62, 0x66, 0xad, 0x45, 0x32, 0x35, 0x7b, 0x03, 0x34, 0x64, 0x88, - 0x56, 0x14, 0x84, 0x50, 0x53, 0x52, 0x38, 0xd9, 0x7e, 0x41, 0x08, 0x05, 0x48, 0xd4, 0x2c, 0xd6, - 0x61, 0xab, 0x81, 0x69, 0x32, 0xd6, 0x60, 0x0d, 0x99, 0xf9, 0xac, 0xb1, 0xa2, 0x5c, 0x0b, 0xb5, - 0x68, 0x82, 0xf4, 0x7d, 0x04, 0xf1, 0x29, 0xb5, 0x6c, 0xf0, 0xce, 0x0d, 0x12, 0x7f, 0x24, 0xad, - 0x44, 0xcd, 0x56, 0x7f, 0x49, 0xa1, 0x22, 0x1c, 0x7a, 0x94, 0xd8, 0x57, 0xf8, 0x62, 0xb6, 0x12, - 0x2a, 0x0c, 0x93, 0xb5, 0x3b, 0x9d, 0x30, 0xae, 0x2c, 0xc9, 0x9f, 0x52, 0x68, 0x79, 0xc8, 0xff, - 0xbf, 0xd6, 0x09, 0x54, 0x2f, 0xd2, 0x68, 0x71, 0xa0, 0x32, 0xe0, 0xa7, 0x90, 0xa9, 0xb6, 0x20, - 0x90, 0xe6, 0xe8, 0x72, 0xdd, 0x9f, 0xb5, 0xd2, 0x68, 0x87, 0x7d, 0xae, 0x7d, 0x87, 0x7b, 0x3d, - 0xe3, 0x7f, 0x2a, 0x8c, 0x62, 0x62, 0x86, 0x24, 0x97, 0xc4, 0x5f, 0xa7, 0x50, 0x49, 0x8e, 0xf7, - 0xbf, 0xea, 0x40, 0x0b, 0xe9, 0xab, 0x92, 0x2b, 0xe2, 0xd8, 0x9b, 0x35, 0x0e, 0xc2, 0x9e, 0x04, - 0x96, 0xc7, 0xda, 0xcc, 0xe1, 0x46, 0x59, 0x45, 0x50, 0x3a, 0x1c, 0x5a, 0x84, 0x8c, 0x2c, 0x5b, - 0xb9, 0x87, 0x4a, 0xc3, 0x3b, 0xc0, 0x25, 0x94, 0x39, 0x63, 0xbd, 0xb0, 0x9d, 0x21, 0xe2, 0x27, - 0xbe, 0x8e, 0xb2, 0x5d, 0x6a, 0x07, 0xa1, 0xe2, 0x0a, 0x24, 0x1c, 0xec, 0xa6, 0x77, 0x52, 0xd5, - 0xef, 0x53, 0xa8, 0x3c, 0x29, 0x10, 0xfc, 0x7a, 0x82, 0xc8, 0x28, 0xaa, 0xa8, 0x32, 0x9f, 0xb0, - 0x5e, 0xc8, 0xba, 0x8f, 0xf2, 0x6e, 0x47, 0x34, 0x9c, 0x50, 0x86, 0xc3, 0x1e, 0x68, 0x23, 0x92, - 0xe3, 0x91, 0xb2, 0x43, 0x17, 0xb4, 0x3a, 0x40, 0x1f, 0x4d, 0x90, 0x18, 0x8a, 0xab, 0x28, 0x27, - 0xe3, 0x11, 0x2f, 0x4f, 0x06, 0x48, 0x90, 0xb8, 0x9f, 0x0f, 0xa4, 0x85, 0xa8, 0x99, 0xea, 0x0f, - 0x69, 0xb4, 0x50, 0x33, 0x5b, 0xac, 0x11, 0xc0, 0x6d, 0x7d, 0xb5, 0x2d, 0xed, 0xa3, 0x01, 0x21, - 0xbf, 0x37, 0x45, 0x42, 0x93, 0x01, 0x4e, 0xec, 0x6d, 0xd9, 0x50, 0x6f, 0xfb, 0xfe, 0xac, 0x0b, - 0x5c, 0xde, 0xe4, 0xfe, 0x0c, 0x1a, 0x4d, 0xba, 0xff, 0x1b, 0x8d, 0xd1, 0xc3, 0xc1, 0xc6, 0xe8, - 0xee, 0x8c, 0x3b, 0x9b, 0xd0, 0x21, 0x7d, 0x93, 0x19, 0xdc, 0x91, 0xac, 0x67, 0xb7, 0xa1, 0xe7, - 0x50, 0x36, 0x25, 0xd3, 0x38, 0xc0, 0xc8, 0x97, 0xc4, 0x1e, 0xf8, 0x53, 0x74, 0x43, 0x3e, 0x6e, - 0x96, 0xd3, 0x1c, 0x6e, 0x7a, 0xd2, 0xb2, 0xe9, 0x79, 0x0d, 0x80, 0x37, 0x6a, 0xe3, 0x5d, 0xc8, - 0x24, 0x2c, 0xec, 0x7b, 0x05, 0x7e, 0x98, 0x81, 0xe7, 0x31, 0xc7, 0xec, 0x1d, 0xbb, 0xb6, 0x65, - 0xf6, 0x64, 0x76, 0x0b, 0x86, 0xa6, 0xa2, 0x59, 0xd9, 0x1b, 0x76, 0x78, 0x39, 0xce, 0x48, 0x46, - 0x89, 0xf0, 0x1b, 0x68, 0xde, 0x0f, 0x40, 0x3a, 0x4e, 0x43, 0x3e, 0x8e, 0x79, 0xa3, 0x28, 0x1a, - 0xe0, 0x5a, 0x68, 0x22, 0xd1, 0x1c, 0x7e, 0x82, 0x8a, 0x8f, 0xfb, 0xc5, 0x5e, 0x3e, 0x8e, 0xff, - 0xec, 0x69, 0x89, 0xeb, 0x60, 0x62, 0x82, 0x24, 0xd7, 0xa8, 0xfe, 0x9e, 0x42, 0x78, 0x54, 0x92, - 0x70, 0xca, 0xd1, 0x63, 0x1e, 0xd6, 0xe6, 0xcd, 0xab, 0x5c, 0x4c, 0xc2, 0x4e, 0x99, 0xd8, 0x35, - 0x9b, 0xf8, 0xf6, 0xb7, 0x51, 0x49, 0xfc, 0x95, 0x88, 0x16, 0x9c, 0xf5, 0xbf, 0xca, 0x75, 0x51, - 0x58, 0x0f, 0x86, 0x88, 0xc8, 0x08, 0xb5, 0xf1, 0xd6, 0xf9, 0x9f, 0x6b, 0xd7, 0x9e, 0xc3, 0xf7, - 0x1b, 0x7c, 0x4f, 0x5f, 0xac, 0xa5, 0xce, 0xe1, 0x7b, 0x0e, 0xdf, 0x1f, 0xf0, 0x7d, 0xfb, 0xd7, - 0xda, 0xb5, 0xcf, 0xf3, 0xd1, 0xd1, 0xfd, 0x1d, 0x00, 0x00, 0xff, 0xff, 0x67, 0x5d, 0xb9, 0x32, - 0xf8, 0x10, 0x00, 0x00, + // 1139 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xd4, 0x56, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0xae, 0x93, 0xa6, 0x4d, 0x26, 0x6d, 0xb7, 0x1d, 0xa8, 0x36, 0x14, 0x29, 0x59, 0x45, 0x02, + 0x75, 0x61, 0x6b, 0xab, 0x51, 0xd1, 0xc2, 0x22, 0x90, 0x70, 0x11, 0x12, 0x55, 0xab, 0xad, 0x26, + 0x5d, 0xb4, 0x82, 0x2e, 0xd2, 0xd8, 0x7e, 0x4d, 0xbc, 0x75, 0x3c, 0xc6, 0x33, 0x2e, 0xea, 0x8d, + 0xff, 0x00, 0x24, 0xfe, 0x0f, 0xee, 0x48, 0x70, 0xe0, 0xd6, 0x1b, 0x0b, 0x27, 0xc4, 0x21, 0xa2, + 0xe6, 0xbf, 0xe8, 0x09, 0x79, 0xfc, 0x23, 0xce, 0xaf, 0xaa, 0x29, 0x5a, 0x24, 0x6e, 0xf6, 0x9b, + 0xef, 0xfb, 0xe6, 0xcd, 0xbc, 0x6f, 0xde, 0x0c, 0x7a, 0xef, 0xf4, 0x5d, 0xae, 0xda, 0x4c, 0x3b, + 0x0d, 0x0c, 0xf0, 0x5d, 0x10, 0xc0, 0x35, 0xef, 0xb4, 0xa3, 0x51, 0xcf, 0xe6, 0x9a, 0x41, 0x85, + 0xd9, 0xd5, 0xce, 0x5a, 0xd4, 0xf1, 0xba, 0x74, 0x5b, 0xeb, 0x80, 0x0b, 0x3e, 0x15, 0x60, 0xa9, + 0x9e, 0xcf, 0x04, 0xc3, 0xf7, 0x63, 0xaa, 0x3a, 0xa0, 0xaa, 0xde, 0x69, 0x47, 0x8d, 0xa8, 0xaa, + 0xa4, 0xaa, 0x29, 0x75, 0x63, 0xab, 0x63, 0x8b, 0x6e, 0x60, 0xa8, 0x26, 0xeb, 0x69, 0x1d, 0xd6, + 0x61, 0x9a, 0x54, 0x30, 0x82, 0x13, 0xf9, 0x27, 0x7f, 0xe4, 0x57, 0xac, 0xbc, 0xd1, 0x9a, 0x9a, + 0x94, 0xe6, 0x03, 0x67, 0x81, 0x6f, 0xc2, 0x68, 0x36, 0x1b, 0xef, 0x4c, 0xe7, 0x04, 0xee, 0x19, + 0xf8, 0xdc, 0x66, 0x2e, 0x58, 0x63, 0xb4, 0x07, 0xd3, 0x69, 0x67, 0x63, 0x4b, 0xde, 0xd8, 0x9a, + 0x8c, 0xf6, 0x03, 0x57, 0xd8, 0xbd, 0xf1, 0x9c, 0xb6, 0x27, 0xc3, 0x03, 0x61, 0x3b, 0x9a, 0xed, + 0x0a, 0x2e, 0xfc, 0x51, 0x4a, 0xf3, 0xfb, 0x02, 0x2a, 0xee, 0x31, 0x03, 0x3f, 0x45, 0xe5, 0x1e, + 0x08, 0x6a, 0x51, 0x41, 0x6b, 0xca, 0x3d, 0x65, 0xb3, 0xda, 0xda, 0x54, 0xa7, 0xee, 0xb7, 0x7a, + 0xb6, 0xad, 0x3e, 0x36, 0x9e, 0x83, 0x29, 0x0e, 0x40, 0x50, 0x1d, 0x5f, 0xf4, 0x1b, 0x73, 0x61, + 0xbf, 0x81, 0x06, 0x31, 0x92, 0xa9, 0xe1, 0x23, 0x34, 0xcf, 0x3d, 0x30, 0x6b, 0x05, 0xa9, 0xda, + 0x52, 0x6f, 0x5c, 0x45, 0x75, 0x8f, 0x19, 0x6d, 0x0f, 0x4c, 0x7d, 0x29, 0xd1, 0x9f, 0x8f, 0xfe, + 0x88, 0x54, 0xc3, 0xc7, 0x68, 0x81, 0x0b, 0x2a, 0x02, 0x5e, 0x2b, 0x4a, 0xdd, 0x9d, 0x19, 0x75, + 0x25, 0x57, 0x5f, 0x49, 0x94, 0x17, 0xe2, 0x7f, 0x92, 0x68, 0x36, 0x7f, 0x2f, 0xa2, 0xa5, 0x3d, + 0x66, 0xec, 0x32, 0xd7, 0xb2, 0x85, 0xcd, 0x5c, 0xbc, 0x83, 0xe6, 0xc5, 0xb9, 0x07, 0x72, 0x6b, + 0x2a, 0xfa, 0xbd, 0x34, 0xa1, 0xa3, 0x73, 0x0f, 0xae, 0xfa, 0x8d, 0xd5, 0x3c, 0x36, 0x8a, 0x11, + 0x89, 0xc6, 0x9f, 0x65, 0x49, 0x16, 0x24, 0xef, 0xc3, 0xe1, 0xe9, 0xae, 0xfa, 0x8d, 0x6b, 0xed, + 0xa0, 0x66, 0x9a, 0xc3, 0xe9, 0xe1, 0x2e, 0x5a, 0x76, 0x28, 0x17, 0x87, 0x3e, 0x33, 0xe0, 0xc8, + 0xee, 0x41, 0xb2, 0x07, 0x6f, 0x5f, 0x53, 0xb1, 0x9c, 0x27, 0xd5, 0x88, 0xa2, 0xaf, 0x27, 0xb9, + 0x2c, 0xef, 0xe7, 0x95, 0xc8, 0xb0, 0x30, 0xfe, 0x1a, 0xe1, 0x28, 0x70, 0xe4, 0x53, 0x97, 0xc7, + 0xab, 0x8b, 0xa6, 0x9b, 0x9f, 0x7d, 0xba, 0x8d, 0x64, 0x3a, 0xbc, 0x3f, 0x26, 0x47, 0x26, 0x4c, + 0x81, 0xdf, 0x44, 0x0b, 0x3e, 0x50, 0xce, 0xdc, 0x5a, 0x49, 0x6e, 0x5d, 0x56, 0x29, 0x22, 0xa3, + 0x24, 0x19, 0xc5, 0xf7, 0xd1, 0x62, 0x0f, 0x38, 0xa7, 0x1d, 0xa8, 0x2d, 0x48, 0xe0, 0x9d, 0x04, + 0xb8, 0x78, 0x10, 0x87, 0x49, 0x3a, 0xde, 0xfc, 0x59, 0x41, 0x8b, 0x7b, 0xcc, 0xd8, 0xb7, 0xb9, + 0xc0, 0xcf, 0xc6, 0xec, 0xae, 0xdd, 0x70, 0x35, 0x11, 0x5d, 0xba, 0x7e, 0x35, 0x99, 0xa8, 0x9c, + 0x46, 0x72, 0x9e, 0x6f, 0xa3, 0x92, 0x2d, 0xa0, 0x17, 0xd5, 0xbd, 0xb8, 0x59, 0x6d, 0xa9, 0xb3, + 0x99, 0x53, 0x5f, 0x4e, 0xa4, 0x4b, 0x9f, 0x46, 0x22, 0x24, 0xd6, 0x6a, 0xfe, 0x58, 0x94, 0xf9, + 0x47, 0x87, 0x00, 0x6f, 0xa3, 0xaa, 0x47, 0x7d, 0xea, 0x38, 0xe0, 0xd8, 0xbc, 0x27, 0x97, 0x50, + 0xd2, 0xef, 0x84, 0xfd, 0x46, 0xf5, 0x70, 0x10, 0x26, 0x79, 0x4c, 0x44, 0x31, 0x59, 0xcf, 0x73, + 0x20, 0xda, 0xe3, 0xd8, 0x91, 0x09, 0x65, 0x77, 0x10, 0x26, 0x79, 0x0c, 0x7e, 0x8c, 0xd6, 0xa9, + 0x29, 0xec, 0x33, 0xf8, 0x18, 0xa8, 0xe5, 0xd8, 0x2e, 0xb4, 0xc1, 0x64, 0xae, 0x15, 0x9f, 0xb9, + 0xa2, 0xfe, 0x5a, 0xd8, 0x6f, 0xac, 0x7f, 0x34, 0x09, 0x40, 0x26, 0xf3, 0xf0, 0x97, 0xa8, 0xcc, + 0xc1, 0x01, 0x53, 0x30, 0x3f, 0x31, 0xd1, 0xce, 0x4d, 0xb7, 0x9d, 0x1a, 0xe0, 0xb4, 0x13, 0xae, + 0xbe, 0x14, 0xed, 0x7b, 0xfa, 0x47, 0x32, 0x4d, 0xfc, 0x08, 0xad, 0xf4, 0xa8, 0x1b, 0xd0, 0x0c, + 0x29, 0xdd, 0x53, 0xd6, 0x71, 0xd8, 0x6f, 0xac, 0x1c, 0x0c, 0x8d, 0x90, 0x11, 0x24, 0xfe, 0x02, + 0x95, 0x05, 0xf4, 0x3c, 0x87, 0x8a, 0xd8, 0x4a, 0xd5, 0xd6, 0xd6, 0xf5, 0x1d, 0xf0, 0x90, 0x59, + 0x47, 0x09, 0x41, 0xb6, 0xa9, 0xcc, 0x10, 0x69, 0x94, 0x64, 0x82, 0xcd, 0x9f, 0x8a, 0xa8, 0x92, + 0xb5, 0x1d, 0x7c, 0x8a, 0x90, 0x99, 0x1e, 0x6d, 0x5e, 0x53, 0xa4, 0x47, 0x1e, 0xce, 0xe6, 0x91, + 0xac, 0x35, 0x0c, 0xba, 0x6f, 0x16, 0xe2, 0x24, 0x27, 0x8f, 0x9f, 0xa2, 0x0a, 0x17, 0xd4, 0x17, + 0xf2, 0xe4, 0x16, 0x66, 0x3f, 0xb9, 0xcb, 0x61, 0xbf, 0x51, 0x69, 0xa7, 0x0a, 0x64, 0x20, 0x86, + 0x3b, 0x68, 0x65, 0xe0, 0x96, 0xdb, 0xf6, 0x21, 0x59, 0x9a, 0xdd, 0x21, 0x19, 0x32, 0x22, 0x1b, + 0x35, 0x83, 0xd8, 0x4f, 0xd2, 0x34, 0xa5, 0x41, 0x33, 0x88, 0xcd, 0x47, 0x92, 0x51, 0xac, 0xa1, + 0x0a, 0x0f, 0x4c, 0x13, 0xc0, 0x02, 0x4b, 0x56, 0xbe, 0xa4, 0xaf, 0x25, 0xd0, 0x4a, 0x3b, 0x1d, + 0x20, 0x03, 0x4c, 0x24, 0x7c, 0x42, 0x6d, 0x07, 0x2c, 0x59, 0xf1, 0x9c, 0xf0, 0x27, 0x32, 0x4a, + 0x92, 0xd1, 0xe6, 0x6f, 0x0a, 0xaa, 0xee, 0x31, 0x23, 0x2d, 0xec, 0x4b, 0xbc, 0x2d, 0xbb, 0x39, + 0x17, 0xc6, 0xc5, 0x7a, 0x34, 0x9b, 0x31, 0x6e, 0x6c, 0xc9, 0x5f, 0x14, 0x74, 0x67, 0x04, 0xff, + 0x7f, 0x7b, 0x05, 0x34, 0x7f, 0x28, 0xa0, 0xa5, 0xb6, 0xd9, 0x05, 0x2b, 0x70, 0xc0, 0x7a, 0xb9, + 0xcf, 0x98, 0x67, 0x43, 0x0b, 0x78, 0x7f, 0x86, 0x05, 0xe4, 0x13, 0x9c, 0xfa, 0x9e, 0x81, 0x91, + 0xf7, 0xcc, 0x07, 0xb7, 0x9d, 0xe0, 0xfa, 0x87, 0xcd, 0xaf, 0x0a, 0x5a, 0xcd, 0xc3, 0xff, 0x8b, + 0xcb, 0xf0, 0x78, 0xf8, 0x32, 0x7c, 0x78, 0xcb, 0x95, 0x4d, 0xb9, 0x15, 0xbf, 0x2d, 0x0e, 0xaf, + 0x48, 0xfa, 0xf8, 0x01, 0x2a, 0xf3, 0x24, 0x96, 0x3c, 0xd9, 0xb2, 0x04, 0x53, 0x2c, 0xc9, 0x10, + 0xf8, 0x09, 0xba, 0x2b, 0x9b, 0x9a, 0xed, 0x76, 0x46, 0x2f, 0xba, 0x82, 0xbc, 0xe8, 0x5e, 0x0f, + 0xfb, 0x8d, 0xbb, 0xed, 0xc9, 0x10, 0x32, 0x8d, 0x8b, 0x8f, 0xd1, 0x9a, 0xc9, 0x5c, 0x33, 0xf0, + 0x7d, 0x70, 0xcd, 0xf3, 0x43, 0xe6, 0xd8, 0xe6, 0xb9, 0xac, 0x6e, 0x45, 0x57, 0x93, 0x6c, 0xd6, + 0x76, 0x47, 0x01, 0x57, 0x93, 0x82, 0x64, 0x5c, 0x08, 0xbf, 0x81, 0x16, 0x79, 0xc0, 0x3d, 0x70, + 0x2d, 0xd9, 0x14, 0xcb, 0x7a, 0x35, 0x7a, 0xf4, 0xb4, 0xe3, 0x10, 0x49, 0xc7, 0xf0, 0x57, 0xa8, + 0xfa, 0x7c, 0x70, 0xc8, 0x65, 0x53, 0xfc, 0x77, 0x2d, 0xe5, 0x95, 0x24, 0xf5, 0x7c, 0x3f, 0x24, + 0xf9, 0x39, 0x9a, 0x7f, 0x2a, 0x08, 0x8f, 0x5b, 0x12, 0x3f, 0xc9, 0x9a, 0x78, 0x7c, 0xe1, 0x6d, + 0xdd, 0xe4, 0x60, 0x12, 0x38, 0x81, 0x68, 0xd5, 0x30, 0xb5, 0xe7, 0xf7, 0xd0, 0x6a, 0xf4, 0x7c, + 0x4c, 0x27, 0xbc, 0xed, 0xfb, 0xf4, 0xd5, 0xb0, 0xdf, 0x58, 0xdd, 0x1f, 0x11, 0x22, 0x63, 0xd2, + 0xfa, 0x5b, 0x17, 0x97, 0xf5, 0xb9, 0x17, 0x97, 0xf5, 0xb9, 0x3f, 0x2e, 0xeb, 0x73, 0xdf, 0x84, + 0x75, 0xe5, 0x22, 0xac, 0x2b, 0x2f, 0xc2, 0xba, 0xf2, 0x57, 0x58, 0x57, 0xbe, 0xfb, 0xbb, 0x3e, + 0xf7, 0x79, 0x39, 0xdd, 0xba, 0x7f, 0x02, 0x00, 0x00, 0xff, 0xff, 0x80, 0x6a, 0xa7, 0x35, 0xec, + 0x0e, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.proto similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.proto index 5792139..ebc58b0 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/generated.proto @@ -34,14 +34,17 @@ option go_package = "v2alpha1"; message Job { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobSpec spec = 2; // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobStatus status = 3; } @@ -54,15 +57,19 @@ message JobCondition { optional string status = 2; // Last time the condition was checked. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; // Last time the condition transit from one status to another. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; // (brief) reason for the condition's last transition. + // +optional optional string reason = 5; // Human readable message indicating details about last transition. + // +optional optional string message = 6; } @@ -70,6 +77,7 @@ message JobCondition { message JobList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Job. @@ -83,6 +91,7 @@ message JobSpec { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 parallelism = 1; // Completions specifies the desired number of successfully finished pods the @@ -91,16 +100,19 @@ message JobSpec { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 completions = 2; // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional optional int64 activeDeadlineSeconds = 3; // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - optional LabelSelector selector = 4; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 4; // ManualSelector controls generation of pod labels and pod selectors. // Leave `manualSelector` unset unless you are certain what you are doing. @@ -112,6 +124,7 @@ message JobSpec { // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` // API. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional optional bool manualSelector = 5; // Template is the object that describes the pod that will be created when @@ -124,25 +137,31 @@ message JobSpec { message JobStatus { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional repeated JobCondition conditions = 1; // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startTime = 2; // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time completionTime = 3; // Active is the number of actively running pods. + // +optional optional int32 active = 4; // Succeeded is the number of pods which reached Phase Succeeded. + // +optional optional int32 succeeded = 5; // Failed is the number of pods which reached Phase Failed. + // +optional optional int32 failed = 6; } @@ -150,10 +169,12 @@ message JobStatus { message JobTemplate { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Template defines jobs that will be created from this template // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobTemplateSpec template = 2; } @@ -161,55 +182,30 @@ message JobTemplate { message JobTemplateSpec { // Standard object's metadata of the jobs created from this template. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Specification of the desired behavior of the job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobSpec spec = 2; } -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -message LabelSelector { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - map matchLabels = 1; - - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - repeated LabelSelectorRequirement matchExpressions = 2; -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -message LabelSelectorRequirement { - // key is the label key that the selector applies to. - optional string key = 1; - - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - optional string operator = 2; - - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - repeated string values = 3; -} - // ScheduledJob represents the configuration of a single scheduled job. message ScheduledJob { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec is a structure defining the expected behavior of a job, including the schedule. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ScheduledJobSpec spec = 2; // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ScheduledJobStatus status = 3; } @@ -217,6 +213,7 @@ message ScheduledJob { message ScheduledJobList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of ScheduledJob. @@ -230,13 +227,16 @@ message ScheduledJobSpec { // Optional deadline in seconds for starting the job if it misses scheduled // time for any reason. Missed jobs executions will be counted as failed ones. + // +optional optional int64 startingDeadlineSeconds = 2; // ConcurrencyPolicy specifies how to treat concurrent executions of a Job. + // +optional optional string concurrencyPolicy = 3; // Suspend flag tells the controller to suspend subsequent executions, it does // not apply to already started executions. Defaults to false. + // +optional optional bool suspend = 4; // JobTemplate is the object that describes the job that will be created when @@ -247,9 +247,11 @@ message ScheduledJobSpec { // ScheduledJobStatus represents the current state of a Job. message ScheduledJobStatus { // Active holds pointers to currently running jobs. + // +optional repeated k8s.io.kubernetes.pkg.api.v1.ObjectReference active = 1; // LastScheduleTime keeps information of when was the last time the job was successfully scheduled. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastScheduleTime = 4; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/register.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/register.go similarity index 89% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/register.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/register.go index 07bd276..8a06751 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v2alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.generated.go similarity index 65% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.generated.go index b2d4e8f..fbdf99e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -1414,7 +1414,13 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym124 := z.EncBinary() + _ = yym124 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } else { r.EncodeNil() @@ -1427,7 +1433,13 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym125 := z.EncBinary() + _ = yym125 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } } @@ -1437,12 +1449,12 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.ManualSelector == nil { r.EncodeNil() } else { - yy125 := *x.ManualSelector - yym126 := z.EncBinary() - _ = yym126 + yy127 := *x.ManualSelector + yym128 := z.EncBinary() + _ = yym128 if false { } else { - r.EncodeBool(bool(yy125)) + r.EncodeBool(bool(yy127)) } } } else { @@ -1456,26 +1468,26 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.ManualSelector == nil { r.EncodeNil() } else { - yy127 := *x.ManualSelector - yym128 := z.EncBinary() - _ = yym128 + yy129 := *x.ManualSelector + yym130 := z.EncBinary() + _ = yym130 if false { } else { - r.EncodeBool(bool(yy127)) + r.EncodeBool(bool(yy129)) } } } } if yyr107 || yy2arr107 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy130 := &x.Template - yy130.CodecEncodeSelf(e) + yy132 := &x.Template + yy132.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("template")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy131 := &x.Template - yy131.CodecEncodeSelf(e) + yy133 := &x.Template + yy133.CodecEncodeSelf(e) } if yyr107 || yy2arr107 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) @@ -1490,25 +1502,25 @@ func (x *JobSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym132 := z.DecBinary() - _ = yym132 + yym134 := z.DecBinary() + _ = yym134 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct133 := r.ContainerType() - if yyct133 == codecSelferValueTypeMap1234 { - yyl133 := r.ReadMapStart() - if yyl133 == 0 { + yyct135 := r.ContainerType() + if yyct135 == codecSelferValueTypeMap1234 { + yyl135 := r.ReadMapStart() + if yyl135 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl133, d) + x.codecDecodeSelfFromMap(yyl135, d) } - } else if yyct133 == codecSelferValueTypeArray1234 { - yyl133 := r.ReadArrayStart() - if yyl133 == 0 { + } else if yyct135 == codecSelferValueTypeArray1234 { + yyl135 := r.ReadArrayStart() + if yyl135 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl133, d) + x.codecDecodeSelfFromArray(yyl135, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -1520,12 +1532,12 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys134Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys134Slc - var yyhl134 bool = l >= 0 - for yyj134 := 0; ; yyj134++ { - if yyhl134 { - if yyj134 >= l { + var yys136Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys136Slc + var yyhl136 bool = l >= 0 + for yyj136 := 0; ; yyj136++ { + if yyhl136 { + if yyj136 >= l { break } } else { @@ -1534,10 +1546,10 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys134Slc = r.DecodeBytes(yys134Slc, true, true) - yys134 := string(yys134Slc) + yys136Slc = r.DecodeBytes(yys136Slc, true, true) + yys136 := string(yys136Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys134 { + switch yys136 { case "parallelism": if r.TryDecodeAsNil() { if x.Parallelism != nil { @@ -1547,8 +1559,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym136 := z.DecBinary() - _ = yym136 + yym138 := z.DecBinary() + _ = yym138 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) @@ -1563,8 +1575,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym138 := z.DecBinary() - _ = yym138 + yym140 := z.DecBinary() + _ = yym140 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) @@ -1579,8 +1591,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym140 := z.DecBinary() - _ = yym140 + yym142 := z.DecBinary() + _ = yym142 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) @@ -1593,9 +1605,15 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym144 := z.DecBinary() + _ = yym144 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } case "manualSelector": if r.TryDecodeAsNil() { @@ -1606,8 +1624,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ManualSelector == nil { x.ManualSelector = new(bool) } - yym143 := z.DecBinary() - _ = yym143 + yym146 := z.DecBinary() + _ = yym146 if false { } else { *((*bool)(x.ManualSelector)) = r.DecodeBool() @@ -1617,13 +1635,13 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv144 := &x.Template - yyv144.CodecDecodeSelf(d) + yyv147 := &x.Template + yyv147.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys134) - } // end switch yys134 - } // end for yyj134 + z.DecStructFieldNotFound(-1, yys136) + } // end switch yys136 + } // end for yyj136 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -1631,16 +1649,16 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj145 int - var yyb145 bool - var yyhl145 bool = l >= 0 - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + var yyj148 int + var yyb148 bool + var yyhl148 bool = l >= 0 + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1653,20 +1671,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym147 := z.DecBinary() - _ = yym147 + yym150 := z.DecBinary() + _ = yym150 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) } } - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1679,20 +1697,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym149 := z.DecBinary() - _ = yym149 + yym152 := z.DecBinary() + _ = yym152 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) } } - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1705,20 +1723,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym151 := z.DecBinary() - _ = yym151 + yym154 := z.DecBinary() + _ = yym154 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) } } - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1729,17 +1747,23 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym156 := z.DecBinary() + _ = yym156 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1752,20 +1776,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.ManualSelector == nil { x.ManualSelector = new(bool) } - yym154 := z.DecBinary() - _ = yym154 + yym158 := z.DecBinary() + _ = yym158 if false { } else { *((*bool)(x.ManualSelector)) = r.DecodeBool() } } - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -1773,21 +1797,21 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv155 := &x.Template - yyv155.CodecDecodeSelf(d) + yyv159 := &x.Template + yyv159.CodecDecodeSelf(d) } for { - yyj145++ - if yyhl145 { - yyb145 = yyj145 > l + yyj148++ + if yyhl148 { + yyb148 = yyj148 > l } else { - yyb145 = r.CheckBreak() + yyb148 = r.CheckBreak() } - if yyb145 { + if yyb148 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj145-1, "") + z.DecStructFieldNotFound(yyj148-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -1799,43 +1823,43 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym156 := z.EncBinary() - _ = yym156 + yym160 := z.EncBinary() + _ = yym160 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep157 := !z.EncBinary() - yy2arr157 := z.EncBasicHandle().StructToArray - var yyq157 [6]bool - _, _, _ = yysep157, yyq157, yy2arr157 - const yyr157 bool = false - yyq157[0] = len(x.Conditions) != 0 - yyq157[1] = x.StartTime != nil - yyq157[2] = x.CompletionTime != nil - yyq157[3] = x.Active != 0 - yyq157[4] = x.Succeeded != 0 - yyq157[5] = x.Failed != 0 - var yynn157 int - if yyr157 || yy2arr157 { + yysep161 := !z.EncBinary() + yy2arr161 := z.EncBasicHandle().StructToArray + var yyq161 [6]bool + _, _, _ = yysep161, yyq161, yy2arr161 + const yyr161 bool = false + yyq161[0] = len(x.Conditions) != 0 + yyq161[1] = x.StartTime != nil + yyq161[2] = x.CompletionTime != nil + yyq161[3] = x.Active != 0 + yyq161[4] = x.Succeeded != 0 + yyq161[5] = x.Failed != 0 + var yynn161 int + if yyr161 || yy2arr161 { r.EncodeArrayStart(6) } else { - yynn157 = 0 - for _, b := range yyq157 { + yynn161 = 0 + for _, b := range yyq161 { if b { - yynn157++ + yynn161++ } } - r.EncodeMapStart(yynn157) - yynn157 = 0 + r.EncodeMapStart(yynn161) + yynn161 = 0 } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[0] { + if yyq161[0] { if x.Conditions == nil { r.EncodeNil() } else { - yym159 := z.EncBinary() - _ = yym159 + yym163 := z.EncBinary() + _ = yym163 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -1845,15 +1869,15 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq157[0] { + if yyq161[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym160 := z.EncBinary() - _ = yym160 + yym164 := z.EncBinary() + _ = yym164 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -1861,19 +1885,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[1] { + if yyq161[1] { if x.StartTime == nil { r.EncodeNil() } else { - yym162 := z.EncBinary() - _ = yym162 + yym166 := z.EncBinary() + _ = yym166 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym162 { + } else if yym166 { z.EncBinaryMarshal(x.StartTime) - } else if !yym162 && z.IsJSONHandle() { + } else if !yym166 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -1883,20 +1907,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq157[1] { + if yyq161[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("startTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.StartTime == nil { r.EncodeNil() } else { - yym163 := z.EncBinary() - _ = yym163 + yym167 := z.EncBinary() + _ = yym167 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym163 { + } else if yym167 { z.EncBinaryMarshal(x.StartTime) - } else if !yym163 && z.IsJSONHandle() { + } else if !yym167 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -1904,19 +1928,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[2] { + if yyq161[2] { if x.CompletionTime == nil { r.EncodeNil() } else { - yym165 := z.EncBinary() - _ = yym165 + yym169 := z.EncBinary() + _ = yym169 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym165 { + } else if yym169 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym165 && z.IsJSONHandle() { + } else if !yym169 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -1926,20 +1950,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq157[2] { + if yyq161[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("completionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.CompletionTime == nil { r.EncodeNil() } else { - yym166 := z.EncBinary() - _ = yym166 + yym170 := z.EncBinary() + _ = yym170 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym166 { + } else if yym170 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym166 && z.IsJSONHandle() { + } else if !yym170 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -1947,61 +1971,61 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[3] { - yym168 := z.EncBinary() - _ = yym168 - if false { - } else { - r.EncodeInt(int64(x.Active)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq157[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("active")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym169 := z.EncBinary() - _ = yym169 - if false { - } else { - r.EncodeInt(int64(x.Active)) - } - } - } - if yyr157 || yy2arr157 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[4] { - yym171 := z.EncBinary() - _ = yym171 - if false { - } else { - r.EncodeInt(int64(x.Succeeded)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq157[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("succeeded")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq161[3] { yym172 := z.EncBinary() _ = yym172 if false { + } else { + r.EncodeInt(int64(x.Active)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq161[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("active")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym173 := z.EncBinary() + _ = yym173 + if false { + } else { + r.EncodeInt(int64(x.Active)) + } + } + } + if yyr161 || yy2arr161 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq161[4] { + yym175 := z.EncBinary() + _ = yym175 + if false { + } else { + r.EncodeInt(int64(x.Succeeded)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq161[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("succeeded")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym176 := z.EncBinary() + _ = yym176 + if false { } else { r.EncodeInt(int64(x.Succeeded)) } } } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq157[5] { - yym174 := z.EncBinary() - _ = yym174 + if yyq161[5] { + yym178 := z.EncBinary() + _ = yym178 if false { } else { r.EncodeInt(int64(x.Failed)) @@ -2010,19 +2034,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq157[5] { + if yyq161[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("failed")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym175 := z.EncBinary() - _ = yym175 + yym179 := z.EncBinary() + _ = yym179 if false { } else { r.EncodeInt(int64(x.Failed)) } } } - if yyr157 || yy2arr157 { + if yyr161 || yy2arr161 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -2035,25 +2059,25 @@ func (x *JobStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym176 := z.DecBinary() - _ = yym176 + yym180 := z.DecBinary() + _ = yym180 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct177 := r.ContainerType() - if yyct177 == codecSelferValueTypeMap1234 { - yyl177 := r.ReadMapStart() - if yyl177 == 0 { + yyct181 := r.ContainerType() + if yyct181 == codecSelferValueTypeMap1234 { + yyl181 := r.ReadMapStart() + if yyl181 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl177, d) + x.codecDecodeSelfFromMap(yyl181, d) } - } else if yyct177 == codecSelferValueTypeArray1234 { - yyl177 := r.ReadArrayStart() - if yyl177 == 0 { + } else if yyct181 == codecSelferValueTypeArray1234 { + yyl181 := r.ReadArrayStart() + if yyl181 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl177, d) + x.codecDecodeSelfFromArray(yyl181, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -2065,12 +2089,12 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys178Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys178Slc - var yyhl178 bool = l >= 0 - for yyj178 := 0; ; yyj178++ { - if yyhl178 { - if yyj178 >= l { + var yys182Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys182Slc + var yyhl182 bool = l >= 0 + for yyj182 := 0; ; yyj182++ { + if yyhl182 { + if yyj182 >= l { break } } else { @@ -2079,20 +2103,20 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys178Slc = r.DecodeBytes(yys178Slc, true, true) - yys178 := string(yys178Slc) + yys182Slc = r.DecodeBytes(yys182Slc, true, true) + yys182 := string(yys182Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys178 { + switch yys182 { case "conditions": if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv179 := &x.Conditions - yym180 := z.DecBinary() - _ = yym180 + yyv183 := &x.Conditions + yym184 := z.DecBinary() + _ = yym184 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv179), d) + h.decSliceJobCondition((*[]JobCondition)(yyv183), d) } } case "startTime": @@ -2104,13 +2128,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym182 := z.DecBinary() - _ = yym182 + yym186 := z.DecBinary() + _ = yym186 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym182 { + } else if yym186 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym182 && z.IsJSONHandle() { + } else if !yym186 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) @@ -2125,13 +2149,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym184 := z.DecBinary() - _ = yym184 + yym188 := z.DecBinary() + _ = yym188 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym184 { + } else if yym188 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym184 && z.IsJSONHandle() { + } else if !yym188 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) @@ -2156,9 +2180,9 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys178) - } // end switch yys178 - } // end for yyj178 + z.DecStructFieldNotFound(-1, yys182) + } // end switch yys182 + } // end for yyj182 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -2166,16 +2190,16 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj188 int - var yyb188 bool - var yyhl188 bool = l >= 0 - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + var yyj192 int + var yyb192 bool + var yyhl192 bool = l >= 0 + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2183,21 +2207,21 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv189 := &x.Conditions - yym190 := z.DecBinary() - _ = yym190 + yyv193 := &x.Conditions + yym194 := z.DecBinary() + _ = yym194 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv189), d) + h.decSliceJobCondition((*[]JobCondition)(yyv193), d) } } - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2210,25 +2234,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym192 := z.DecBinary() - _ = yym192 + yym196 := z.DecBinary() + _ = yym196 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym192 { + } else if yym196 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym192 && z.IsJSONHandle() { + } else if !yym196 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) } } - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2241,25 +2265,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym194 := z.DecBinary() - _ = yym194 + yym198 := z.DecBinary() + _ = yym198 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym194 { + } else if yym198 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym194 && z.IsJSONHandle() { + } else if !yym198 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) } } - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2269,13 +2293,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Active = int32(r.DecodeInt(32)) } - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2285,13 +2309,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Succeeded = int32(r.DecodeInt(32)) } - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2302,17 +2326,17 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } for { - yyj188++ - if yyhl188 { - yyb188 = yyj188 > l + yyj192++ + if yyhl192 { + yyb192 = yyj192 > l } else { - yyb188 = r.CheckBreak() + yyb192 = r.CheckBreak() } - if yyb188 { + if yyb192 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj188-1, "") + z.DecStructFieldNotFound(yyj192-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -2321,8 +2345,8 @@ func (x JobConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym198 := z.EncBinary() - _ = yym198 + yym202 := z.EncBinary() + _ = yym202 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -2334,8 +2358,8 @@ func (x *JobConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym199 := z.DecBinary() - _ = yym199 + yym203 := z.DecBinary() + _ = yym203 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -2350,34 +2374,34 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym200 := z.EncBinary() - _ = yym200 + yym204 := z.EncBinary() + _ = yym204 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep201 := !z.EncBinary() - yy2arr201 := z.EncBasicHandle().StructToArray - var yyq201 [6]bool - _, _, _ = yysep201, yyq201, yy2arr201 - const yyr201 bool = false - yyq201[2] = true - yyq201[3] = true - yyq201[4] = x.Reason != "" - yyq201[5] = x.Message != "" - var yynn201 int - if yyr201 || yy2arr201 { + yysep205 := !z.EncBinary() + yy2arr205 := z.EncBasicHandle().StructToArray + var yyq205 [6]bool + _, _, _ = yysep205, yyq205, yy2arr205 + const yyr205 bool = false + yyq205[2] = true + yyq205[3] = true + yyq205[4] = x.Reason != "" + yyq205[5] = x.Message != "" + var yynn205 int + if yyr205 || yy2arr205 { r.EncodeArrayStart(6) } else { - yynn201 = 2 - for _, b := range yyq201 { + yynn205 = 2 + for _, b := range yyq205 { if b { - yynn201++ + yynn205++ } } - r.EncodeMapStart(yynn201) - yynn201 = 0 + r.EncodeMapStart(yynn205) + yynn205 = 0 } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -2386,10 +2410,10 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym204 := z.EncBinary() - _ = yym204 + yym208 := z.EncBinary() + _ = yym208 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { @@ -2399,139 +2423,139 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym205 := z.EncBinary() - _ = yym205 + yym209 := z.EncBinary() + _ = yym209 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Status)) } } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[2] { - yy207 := &x.LastProbeTime - yym208 := z.EncBinary() - _ = yym208 + if yyq205[2] { + yy211 := &x.LastProbeTime + yym212 := z.EncBinary() + _ = yym212 if false { - } else if z.HasExtensions() && z.EncExt(yy207) { - } else if yym208 { - z.EncBinaryMarshal(yy207) - } else if !yym208 && z.IsJSONHandle() { - z.EncJSONMarshal(yy207) + } else if z.HasExtensions() && z.EncExt(yy211) { + } else if yym212 { + z.EncBinaryMarshal(yy211) + } else if !yym212 && z.IsJSONHandle() { + z.EncJSONMarshal(yy211) } else { - z.EncFallback(yy207) + z.EncFallback(yy211) } } else { r.EncodeNil() } } else { - if yyq201[2] { + if yyq205[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy209 := &x.LastProbeTime - yym210 := z.EncBinary() - _ = yym210 + yy213 := &x.LastProbeTime + yym214 := z.EncBinary() + _ = yym214 if false { - } else if z.HasExtensions() && z.EncExt(yy209) { - } else if yym210 { - z.EncBinaryMarshal(yy209) - } else if !yym210 && z.IsJSONHandle() { - z.EncJSONMarshal(yy209) + } else if z.HasExtensions() && z.EncExt(yy213) { + } else if yym214 { + z.EncBinaryMarshal(yy213) + } else if !yym214 && z.IsJSONHandle() { + z.EncJSONMarshal(yy213) } else { - z.EncFallback(yy209) + z.EncFallback(yy213) } } } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[3] { - yy212 := &x.LastTransitionTime - yym213 := z.EncBinary() - _ = yym213 + if yyq205[3] { + yy216 := &x.LastTransitionTime + yym217 := z.EncBinary() + _ = yym217 if false { - } else if z.HasExtensions() && z.EncExt(yy212) { - } else if yym213 { - z.EncBinaryMarshal(yy212) - } else if !yym213 && z.IsJSONHandle() { - z.EncJSONMarshal(yy212) + } else if z.HasExtensions() && z.EncExt(yy216) { + } else if yym217 { + z.EncBinaryMarshal(yy216) + } else if !yym217 && z.IsJSONHandle() { + z.EncJSONMarshal(yy216) } else { - z.EncFallback(yy212) + z.EncFallback(yy216) } } else { r.EncodeNil() } } else { - if yyq201[3] { + if yyq205[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy214 := &x.LastTransitionTime - yym215 := z.EncBinary() - _ = yym215 + yy218 := &x.LastTransitionTime + yym219 := z.EncBinary() + _ = yym219 if false { - } else if z.HasExtensions() && z.EncExt(yy214) { - } else if yym215 { - z.EncBinaryMarshal(yy214) - } else if !yym215 && z.IsJSONHandle() { - z.EncJSONMarshal(yy214) + } else if z.HasExtensions() && z.EncExt(yy218) { + } else if yym219 { + z.EncBinaryMarshal(yy218) + } else if !yym219 && z.IsJSONHandle() { + z.EncJSONMarshal(yy218) } else { - z.EncFallback(yy214) + z.EncFallback(yy218) } } } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[4] { - yym217 := z.EncBinary() - _ = yym217 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq201[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("reason")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym218 := z.EncBinary() - _ = yym218 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) - } - } - } - if yyr201 || yy2arr201 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq201[5] { - yym220 := z.EncBinary() - _ = yym220 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Message)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq201[5] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("message")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq205[4] { yym221 := z.EncBinary() _ = yym221 if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq205[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym222 := z.EncBinary() + _ = yym222 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } + } + if yyr205 || yy2arr205 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq205[5] { + yym224 := z.EncBinary() + _ = yym224 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq205[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("message")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym225 := z.EncBinary() + _ = yym225 + if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr201 || yy2arr201 { + if yyr205 || yy2arr205 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -2544,25 +2568,25 @@ func (x *JobCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym222 := z.DecBinary() - _ = yym222 + yym226 := z.DecBinary() + _ = yym226 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct223 := r.ContainerType() - if yyct223 == codecSelferValueTypeMap1234 { - yyl223 := r.ReadMapStart() - if yyl223 == 0 { + yyct227 := r.ContainerType() + if yyct227 == codecSelferValueTypeMap1234 { + yyl227 := r.ReadMapStart() + if yyl227 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl223, d) + x.codecDecodeSelfFromMap(yyl227, d) } - } else if yyct223 == codecSelferValueTypeArray1234 { - yyl223 := r.ReadArrayStart() - if yyl223 == 0 { + } else if yyct227 == codecSelferValueTypeArray1234 { + yyl227 := r.ReadArrayStart() + if yyl227 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl223, d) + x.codecDecodeSelfFromArray(yyl227, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -2574,12 +2598,12 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys224Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys224Slc - var yyhl224 bool = l >= 0 - for yyj224 := 0; ; yyj224++ { - if yyhl224 { - if yyj224 >= l { + var yys228Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys228Slc + var yyhl228 bool = l >= 0 + for yyj228 := 0; ; yyj228++ { + if yyhl228 { + if yyj228 >= l { break } } else { @@ -2588,10 +2612,10 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys224Slc = r.DecodeBytes(yys224Slc, true, true) - yys224 := string(yys224Slc) + yys228Slc = r.DecodeBytes(yys228Slc, true, true) + yys228 := string(yys228Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys224 { + switch yys228 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -2608,34 +2632,34 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv227 := &x.LastProbeTime - yym228 := z.DecBinary() - _ = yym228 + yyv231 := &x.LastProbeTime + yym232 := z.DecBinary() + _ = yym232 if false { - } else if z.HasExtensions() && z.DecExt(yyv227) { - } else if yym228 { - z.DecBinaryUnmarshal(yyv227) - } else if !yym228 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv227) + } else if z.HasExtensions() && z.DecExt(yyv231) { + } else if yym232 { + z.DecBinaryUnmarshal(yyv231) + } else if !yym232 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv231) } else { - z.DecFallback(yyv227, false) + z.DecFallback(yyv231, false) } } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv229 := &x.LastTransitionTime - yym230 := z.DecBinary() - _ = yym230 + yyv233 := &x.LastTransitionTime + yym234 := z.DecBinary() + _ = yym234 if false { - } else if z.HasExtensions() && z.DecExt(yyv229) { - } else if yym230 { - z.DecBinaryUnmarshal(yyv229) - } else if !yym230 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv229) + } else if z.HasExtensions() && z.DecExt(yyv233) { + } else if yym234 { + z.DecBinaryUnmarshal(yyv233) + } else if !yym234 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv233) } else { - z.DecFallback(yyv229, false) + z.DecFallback(yyv233, false) } } case "reason": @@ -2651,9 +2675,9 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys224) - } // end switch yys224 - } // end for yyj224 + z.DecStructFieldNotFound(-1, yys228) + } // end switch yys228 + } // end for yyj228 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -2661,16 +2685,16 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj233 int - var yyb233 bool - var yyhl233 bool = l >= 0 - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + var yyj237 int + var yyb237 bool + var yyhl237 bool = l >= 0 + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2680,13 +2704,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = JobConditionType(r.DecodeString()) } - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2696,13 +2720,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) } - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2710,26 +2734,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv236 := &x.LastProbeTime - yym237 := z.DecBinary() - _ = yym237 + yyv240 := &x.LastProbeTime + yym241 := z.DecBinary() + _ = yym241 if false { - } else if z.HasExtensions() && z.DecExt(yyv236) { - } else if yym237 { - z.DecBinaryUnmarshal(yyv236) - } else if !yym237 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv236) + } else if z.HasExtensions() && z.DecExt(yyv240) { + } else if yym241 { + z.DecBinaryUnmarshal(yyv240) + } else if !yym241 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv240) } else { - z.DecFallback(yyv236, false) + z.DecFallback(yyv240, false) } } - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2737,26 +2761,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv238 := &x.LastTransitionTime - yym239 := z.DecBinary() - _ = yym239 + yyv242 := &x.LastTransitionTime + yym243 := z.DecBinary() + _ = yym243 if false { - } else if z.HasExtensions() && z.DecExt(yyv238) { - } else if yym239 { - z.DecBinaryUnmarshal(yyv238) - } else if !yym239 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv238) + } else if z.HasExtensions() && z.DecExt(yyv242) { + } else if yym243 { + z.DecBinaryUnmarshal(yyv242) + } else if !yym243 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv242) } else { - z.DecFallback(yyv238, false) + z.DecFallback(yyv242, false) } } - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2766,13 +2790,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -2783,17 +2807,17 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } for { - yyj233++ - if yyhl233 { - yyb233 = yyj233 > l + yyj237++ + if yyhl237 { + yyb237 = yyj237 > l } else { - yyb233 = r.CheckBreak() + yyb237 = r.CheckBreak() } - if yyb233 { + if yyb237 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj233-1, "") + z.DecStructFieldNotFound(yyj237-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -2805,136 +2829,136 @@ func (x *ScheduledJob) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym242 := z.EncBinary() - _ = yym242 + yym246 := z.EncBinary() + _ = yym246 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep243 := !z.EncBinary() - yy2arr243 := z.EncBasicHandle().StructToArray - var yyq243 [5]bool - _, _, _ = yysep243, yyq243, yy2arr243 - const yyr243 bool = false - yyq243[0] = x.Kind != "" - yyq243[1] = x.APIVersion != "" - yyq243[2] = true - yyq243[3] = true - yyq243[4] = true - var yynn243 int - if yyr243 || yy2arr243 { + yysep247 := !z.EncBinary() + yy2arr247 := z.EncBasicHandle().StructToArray + var yyq247 [5]bool + _, _, _ = yysep247, yyq247, yy2arr247 + const yyr247 bool = false + yyq247[0] = x.Kind != "" + yyq247[1] = x.APIVersion != "" + yyq247[2] = true + yyq247[3] = true + yyq247[4] = true + var yynn247 int + if yyr247 || yy2arr247 { r.EncodeArrayStart(5) } else { - yynn243 = 0 - for _, b := range yyq243 { + yynn247 = 0 + for _, b := range yyq247 { if b { - yynn243++ + yynn247++ } } - r.EncodeMapStart(yynn243) - yynn243 = 0 + r.EncodeMapStart(yynn247) + yynn247 = 0 } - if yyr243 || yy2arr243 { + if yyr247 || yy2arr247 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq243[0] { - yym245 := z.EncBinary() - _ = yym245 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq243[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym246 := z.EncBinary() - _ = yym246 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr243 || yy2arr243 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq243[1] { - yym248 := z.EncBinary() - _ = yym248 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq243[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq247[0] { yym249 := z.EncBinary() _ = yym249 if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq247[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("kind")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym250 := z.EncBinary() + _ = yym250 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr247 || yy2arr247 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq247[1] { + yym252 := z.EncBinary() + _ = yym252 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq247[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym253 := z.EncBinary() + _ = yym253 + if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr243 || yy2arr243 { + if yyr247 || yy2arr247 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq243[2] { - yy251 := &x.ObjectMeta - yy251.CodecEncodeSelf(e) + if yyq247[2] { + yy255 := &x.ObjectMeta + yy255.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq243[2] { + if yyq247[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy252 := &x.ObjectMeta - yy252.CodecEncodeSelf(e) + yy256 := &x.ObjectMeta + yy256.CodecEncodeSelf(e) } } - if yyr243 || yy2arr243 { + if yyr247 || yy2arr247 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq243[3] { - yy254 := &x.Spec - yy254.CodecEncodeSelf(e) + if yyq247[3] { + yy258 := &x.Spec + yy258.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq243[3] { + if yyq247[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy255 := &x.Spec - yy255.CodecEncodeSelf(e) + yy259 := &x.Spec + yy259.CodecEncodeSelf(e) } } - if yyr243 || yy2arr243 { + if yyr247 || yy2arr247 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq243[4] { - yy257 := &x.Status - yy257.CodecEncodeSelf(e) + if yyq247[4] { + yy261 := &x.Status + yy261.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq243[4] { + if yyq247[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy258 := &x.Status - yy258.CodecEncodeSelf(e) + yy262 := &x.Status + yy262.CodecEncodeSelf(e) } } - if yyr243 || yy2arr243 { + if yyr247 || yy2arr247 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -2947,25 +2971,25 @@ func (x *ScheduledJob) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym259 := z.DecBinary() - _ = yym259 + yym263 := z.DecBinary() + _ = yym263 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct260 := r.ContainerType() - if yyct260 == codecSelferValueTypeMap1234 { - yyl260 := r.ReadMapStart() - if yyl260 == 0 { + yyct264 := r.ContainerType() + if yyct264 == codecSelferValueTypeMap1234 { + yyl264 := r.ReadMapStart() + if yyl264 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl260, d) + x.codecDecodeSelfFromMap(yyl264, d) } - } else if yyct260 == codecSelferValueTypeArray1234 { - yyl260 := r.ReadArrayStart() - if yyl260 == 0 { + } else if yyct264 == codecSelferValueTypeArray1234 { + yyl264 := r.ReadArrayStart() + if yyl264 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl260, d) + x.codecDecodeSelfFromArray(yyl264, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -2977,12 +3001,12 @@ func (x *ScheduledJob) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys261Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys261Slc - var yyhl261 bool = l >= 0 - for yyj261 := 0; ; yyj261++ { - if yyhl261 { - if yyj261 >= l { + var yys265Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys265Slc + var yyhl265 bool = l >= 0 + for yyj265 := 0; ; yyj265++ { + if yyhl265 { + if yyj265 >= l { break } } else { @@ -2991,10 +3015,10 @@ func (x *ScheduledJob) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys261Slc = r.DecodeBytes(yys261Slc, true, true) - yys261 := string(yys261Slc) + yys265Slc = r.DecodeBytes(yys265Slc, true, true) + yys265 := string(yys265Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys261 { + switch yys265 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -3011,27 +3035,27 @@ func (x *ScheduledJob) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv264 := &x.ObjectMeta - yyv264.CodecDecodeSelf(d) + yyv268 := &x.ObjectMeta + yyv268.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = ScheduledJobSpec{} } else { - yyv265 := &x.Spec - yyv265.CodecDecodeSelf(d) + yyv269 := &x.Spec + yyv269.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = ScheduledJobStatus{} } else { - yyv266 := &x.Status - yyv266.CodecDecodeSelf(d) + yyv270 := &x.Status + yyv270.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys261) - } // end switch yys261 - } // end for yyj261 + z.DecStructFieldNotFound(-1, yys265) + } // end switch yys265 + } // end for yyj265 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -3039,16 +3063,16 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj267 int - var yyb267 bool - var yyhl267 bool = l >= 0 - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + var yyj271 int + var yyb271 bool + var yyhl271 bool = l >= 0 + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3058,13 +3082,13 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3074,13 +3098,13 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3088,16 +3112,16 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv270 := &x.ObjectMeta - yyv270.CodecDecodeSelf(d) + yyv274 := &x.ObjectMeta + yyv274.CodecDecodeSelf(d) } - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3105,16 +3129,16 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ScheduledJobSpec{} } else { - yyv271 := &x.Spec - yyv271.CodecDecodeSelf(d) + yyv275 := &x.Spec + yyv275.CodecDecodeSelf(d) } - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3122,21 +3146,21 @@ func (x *ScheduledJob) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ScheduledJobStatus{} } else { - yyv272 := &x.Status - yyv272.CodecDecodeSelf(d) + yyv276 := &x.Status + yyv276.CodecDecodeSelf(d) } for { - yyj267++ - if yyhl267 { - yyb267 = yyj267 > l + yyj271++ + if yyhl271 { + yyb271 = yyj271 > l } else { - yyb267 = r.CheckBreak() + yyb271 = r.CheckBreak() } - if yyb267 { + if yyb271 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj267-1, "") + z.DecStructFieldNotFound(yyj271-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -3148,118 +3172,118 @@ func (x *ScheduledJobList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym273 := z.EncBinary() - _ = yym273 + yym277 := z.EncBinary() + _ = yym277 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep274 := !z.EncBinary() - yy2arr274 := z.EncBasicHandle().StructToArray - var yyq274 [4]bool - _, _, _ = yysep274, yyq274, yy2arr274 - const yyr274 bool = false - yyq274[0] = x.Kind != "" - yyq274[1] = x.APIVersion != "" - yyq274[2] = true - var yynn274 int - if yyr274 || yy2arr274 { + yysep278 := !z.EncBinary() + yy2arr278 := z.EncBasicHandle().StructToArray + var yyq278 [4]bool + _, _, _ = yysep278, yyq278, yy2arr278 + const yyr278 bool = false + yyq278[0] = x.Kind != "" + yyq278[1] = x.APIVersion != "" + yyq278[2] = true + var yynn278 int + if yyr278 || yy2arr278 { r.EncodeArrayStart(4) } else { - yynn274 = 1 - for _, b := range yyq274 { + yynn278 = 1 + for _, b := range yyq278 { if b { - yynn274++ + yynn278++ } } - r.EncodeMapStart(yynn274) - yynn274 = 0 + r.EncodeMapStart(yynn278) + yynn278 = 0 } - if yyr274 || yy2arr274 { + if yyr278 || yy2arr278 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq274[0] { - yym276 := z.EncBinary() - _ = yym276 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq274[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym277 := z.EncBinary() - _ = yym277 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr274 || yy2arr274 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq274[1] { - yym279 := z.EncBinary() - _ = yym279 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq274[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq278[0] { yym280 := z.EncBinary() _ = yym280 if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq278[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("kind")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym281 := z.EncBinary() + _ = yym281 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr278 || yy2arr278 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq278[1] { + yym283 := z.EncBinary() + _ = yym283 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq278[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym284 := z.EncBinary() + _ = yym284 + if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr274 || yy2arr274 { + if yyr278 || yy2arr278 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq274[2] { - yy282 := &x.ListMeta - yym283 := z.EncBinary() - _ = yym283 + if yyq278[2] { + yy286 := &x.ListMeta + yym287 := z.EncBinary() + _ = yym287 if false { - } else if z.HasExtensions() && z.EncExt(yy282) { + } else if z.HasExtensions() && z.EncExt(yy286) { } else { - z.EncFallback(yy282) + z.EncFallback(yy286) } } else { r.EncodeNil() } } else { - if yyq274[2] { + if yyq278[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy284 := &x.ListMeta - yym285 := z.EncBinary() - _ = yym285 + yy288 := &x.ListMeta + yym289 := z.EncBinary() + _ = yym289 if false { - } else if z.HasExtensions() && z.EncExt(yy284) { + } else if z.HasExtensions() && z.EncExt(yy288) { } else { - z.EncFallback(yy284) + z.EncFallback(yy288) } } } - if yyr274 || yy2arr274 { + if yyr278 || yy2arr278 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym287 := z.EncBinary() - _ = yym287 + yym291 := z.EncBinary() + _ = yym291 if false { } else { h.encSliceScheduledJob(([]ScheduledJob)(x.Items), e) @@ -3272,15 +3296,15 @@ func (x *ScheduledJobList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym288 := z.EncBinary() - _ = yym288 + yym292 := z.EncBinary() + _ = yym292 if false { } else { h.encSliceScheduledJob(([]ScheduledJob)(x.Items), e) } } } - if yyr274 || yy2arr274 { + if yyr278 || yy2arr278 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -3293,25 +3317,25 @@ func (x *ScheduledJobList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym289 := z.DecBinary() - _ = yym289 + yym293 := z.DecBinary() + _ = yym293 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct290 := r.ContainerType() - if yyct290 == codecSelferValueTypeMap1234 { - yyl290 := r.ReadMapStart() - if yyl290 == 0 { + yyct294 := r.ContainerType() + if yyct294 == codecSelferValueTypeMap1234 { + yyl294 := r.ReadMapStart() + if yyl294 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl290, d) + x.codecDecodeSelfFromMap(yyl294, d) } - } else if yyct290 == codecSelferValueTypeArray1234 { - yyl290 := r.ReadArrayStart() - if yyl290 == 0 { + } else if yyct294 == codecSelferValueTypeArray1234 { + yyl294 := r.ReadArrayStart() + if yyl294 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl290, d) + x.codecDecodeSelfFromArray(yyl294, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -3323,12 +3347,12 @@ func (x *ScheduledJobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys291Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys291Slc - var yyhl291 bool = l >= 0 - for yyj291 := 0; ; yyj291++ { - if yyhl291 { - if yyj291 >= l { + var yys295Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys295Slc + var yyhl295 bool = l >= 0 + for yyj295 := 0; ; yyj295++ { + if yyhl295 { + if yyj295 >= l { break } } else { @@ -3337,10 +3361,10 @@ func (x *ScheduledJobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys291Slc = r.DecodeBytes(yys291Slc, true, true) - yys291 := string(yys291Slc) + yys295Slc = r.DecodeBytes(yys295Slc, true, true) + yys295 := string(yys295Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys291 { + switch yys295 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -3357,31 +3381,31 @@ func (x *ScheduledJobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv294 := &x.ListMeta - yym295 := z.DecBinary() - _ = yym295 + yyv298 := &x.ListMeta + yym299 := z.DecBinary() + _ = yym299 if false { - } else if z.HasExtensions() && z.DecExt(yyv294) { + } else if z.HasExtensions() && z.DecExt(yyv298) { } else { - z.DecFallback(yyv294, false) + z.DecFallback(yyv298, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv296 := &x.Items - yym297 := z.DecBinary() - _ = yym297 + yyv300 := &x.Items + yym301 := z.DecBinary() + _ = yym301 if false { } else { - h.decSliceScheduledJob((*[]ScheduledJob)(yyv296), d) + h.decSliceScheduledJob((*[]ScheduledJob)(yyv300), d) } } default: - z.DecStructFieldNotFound(-1, yys291) - } // end switch yys291 - } // end for yyj291 + z.DecStructFieldNotFound(-1, yys295) + } // end switch yys295 + } // end for yyj295 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -3389,16 +3413,16 @@ func (x *ScheduledJobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj298 int - var yyb298 bool - var yyhl298 bool = l >= 0 - yyj298++ - if yyhl298 { - yyb298 = yyj298 > l + var yyj302 int + var yyb302 bool + var yyhl302 bool = l >= 0 + yyj302++ + if yyhl302 { + yyb302 = yyj302 > l } else { - yyb298 = r.CheckBreak() + yyb302 = r.CheckBreak() } - if yyb298 { + if yyb302 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3408,13 +3432,13 @@ func (x *ScheduledJobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Kind = string(r.DecodeString()) } - yyj298++ - if yyhl298 { - yyb298 = yyj298 > l + yyj302++ + if yyhl302 { + yyb302 = yyj302 > l } else { - yyb298 = r.CheckBreak() + yyb302 = r.CheckBreak() } - if yyb298 { + if yyb302 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3424,13 +3448,13 @@ func (x *ScheduledJobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.APIVersion = string(r.DecodeString()) } - yyj298++ - if yyhl298 { - yyb298 = yyj298 > l + yyj302++ + if yyhl302 { + yyb302 = yyj302 > l } else { - yyb298 = r.CheckBreak() + yyb302 = r.CheckBreak() } - if yyb298 { + if yyb302 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3438,22 +3462,22 @@ func (x *ScheduledJobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv301 := &x.ListMeta - yym302 := z.DecBinary() - _ = yym302 + yyv305 := &x.ListMeta + yym306 := z.DecBinary() + _ = yym306 if false { - } else if z.HasExtensions() && z.DecExt(yyv301) { + } else if z.HasExtensions() && z.DecExt(yyv305) { } else { - z.DecFallback(yyv301, false) + z.DecFallback(yyv305, false) } } - yyj298++ - if yyhl298 { - yyb298 = yyj298 > l + yyj302++ + if yyhl302 { + yyb302 = yyj302 > l } else { - yyb298 = r.CheckBreak() + yyb302 = r.CheckBreak() } - if yyb298 { + if yyb302 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3461,26 +3485,26 @@ func (x *ScheduledJobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Items = nil } else { - yyv303 := &x.Items - yym304 := z.DecBinary() - _ = yym304 + yyv307 := &x.Items + yym308 := z.DecBinary() + _ = yym308 if false { } else { - h.decSliceScheduledJob((*[]ScheduledJob)(yyv303), d) + h.decSliceScheduledJob((*[]ScheduledJob)(yyv307), d) } } for { - yyj298++ - if yyhl298 { - yyb298 = yyj298 > l + yyj302++ + if yyhl302 { + yyb302 = yyj302 > l } else { - yyb298 = r.CheckBreak() + yyb302 = r.CheckBreak() } - if yyb298 { + if yyb302 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj298-1, "") + z.DecStructFieldNotFound(yyj302-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -3492,36 +3516,36 @@ func (x *ScheduledJobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym305 := z.EncBinary() - _ = yym305 + yym309 := z.EncBinary() + _ = yym309 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep306 := !z.EncBinary() - yy2arr306 := z.EncBasicHandle().StructToArray - var yyq306 [5]bool - _, _, _ = yysep306, yyq306, yy2arr306 - const yyr306 bool = false - yyq306[1] = x.StartingDeadlineSeconds != nil - yyq306[2] = x.ConcurrencyPolicy != "" - yyq306[3] = x.Suspend != nil - var yynn306 int - if yyr306 || yy2arr306 { + yysep310 := !z.EncBinary() + yy2arr310 := z.EncBasicHandle().StructToArray + var yyq310 [5]bool + _, _, _ = yysep310, yyq310, yy2arr310 + const yyr310 bool = false + yyq310[1] = x.StartingDeadlineSeconds != nil + yyq310[2] = x.ConcurrencyPolicy != "" + yyq310[3] = x.Suspend != nil + var yynn310 int + if yyr310 || yy2arr310 { r.EncodeArrayStart(5) } else { - yynn306 = 2 - for _, b := range yyq306 { + yynn310 = 2 + for _, b := range yyq310 { if b { - yynn306++ + yynn310++ } } - r.EncodeMapStart(yynn306) - yynn306 = 0 + r.EncodeMapStart(yynn310) + yynn310 = 0 } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym308 := z.EncBinary() - _ = yym308 + yym312 := z.EncBinary() + _ = yym312 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Schedule)) @@ -3530,110 +3554,110 @@ func (x *ScheduledJobSpec) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("schedule")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym309 := z.EncBinary() - _ = yym309 + yym313 := z.EncBinary() + _ = yym313 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Schedule)) } } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq306[1] { + if yyq310[1] { if x.StartingDeadlineSeconds == nil { r.EncodeNil() } else { - yy311 := *x.StartingDeadlineSeconds - yym312 := z.EncBinary() - _ = yym312 + yy315 := *x.StartingDeadlineSeconds + yym316 := z.EncBinary() + _ = yym316 if false { } else { - r.EncodeInt(int64(yy311)) + r.EncodeInt(int64(yy315)) } } } else { r.EncodeNil() } } else { - if yyq306[1] { + if yyq310[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("startingDeadlineSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.StartingDeadlineSeconds == nil { r.EncodeNil() } else { - yy313 := *x.StartingDeadlineSeconds - yym314 := z.EncBinary() - _ = yym314 + yy317 := *x.StartingDeadlineSeconds + yym318 := z.EncBinary() + _ = yym318 if false { } else { - r.EncodeInt(int64(yy313)) + r.EncodeInt(int64(yy317)) } } } } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq306[2] { + if yyq310[2] { x.ConcurrencyPolicy.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq306[2] { + if yyq310[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("concurrencyPolicy")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.ConcurrencyPolicy.CodecEncodeSelf(e) } } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq306[3] { + if yyq310[3] { if x.Suspend == nil { r.EncodeNil() } else { - yy317 := *x.Suspend - yym318 := z.EncBinary() - _ = yym318 + yy321 := *x.Suspend + yym322 := z.EncBinary() + _ = yym322 if false { } else { - r.EncodeBool(bool(yy317)) + r.EncodeBool(bool(yy321)) } } } else { r.EncodeNil() } } else { - if yyq306[3] { + if yyq310[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("suspend")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Suspend == nil { r.EncodeNil() } else { - yy319 := *x.Suspend - yym320 := z.EncBinary() - _ = yym320 + yy323 := *x.Suspend + yym324 := z.EncBinary() + _ = yym324 if false { } else { - r.EncodeBool(bool(yy319)) + r.EncodeBool(bool(yy323)) } } } } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy322 := &x.JobTemplate - yy322.CodecEncodeSelf(e) + yy326 := &x.JobTemplate + yy326.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("jobTemplate")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy323 := &x.JobTemplate - yy323.CodecEncodeSelf(e) + yy327 := &x.JobTemplate + yy327.CodecEncodeSelf(e) } - if yyr306 || yy2arr306 { + if yyr310 || yy2arr310 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -3646,25 +3670,25 @@ func (x *ScheduledJobSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym324 := z.DecBinary() - _ = yym324 + yym328 := z.DecBinary() + _ = yym328 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct325 := r.ContainerType() - if yyct325 == codecSelferValueTypeMap1234 { - yyl325 := r.ReadMapStart() - if yyl325 == 0 { + yyct329 := r.ContainerType() + if yyct329 == codecSelferValueTypeMap1234 { + yyl329 := r.ReadMapStart() + if yyl329 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl325, d) + x.codecDecodeSelfFromMap(yyl329, d) } - } else if yyct325 == codecSelferValueTypeArray1234 { - yyl325 := r.ReadArrayStart() - if yyl325 == 0 { + } else if yyct329 == codecSelferValueTypeArray1234 { + yyl329 := r.ReadArrayStart() + if yyl329 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl325, d) + x.codecDecodeSelfFromArray(yyl329, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -3676,12 +3700,12 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys326Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys326Slc - var yyhl326 bool = l >= 0 - for yyj326 := 0; ; yyj326++ { - if yyhl326 { - if yyj326 >= l { + var yys330Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys330Slc + var yyhl330 bool = l >= 0 + for yyj330 := 0; ; yyj330++ { + if yyhl330 { + if yyj330 >= l { break } } else { @@ -3690,10 +3714,10 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys326Slc = r.DecodeBytes(yys326Slc, true, true) - yys326 := string(yys326Slc) + yys330Slc = r.DecodeBytes(yys330Slc, true, true) + yys330 := string(yys330Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys326 { + switch yys330 { case "schedule": if r.TryDecodeAsNil() { x.Schedule = "" @@ -3709,8 +3733,8 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.StartingDeadlineSeconds == nil { x.StartingDeadlineSeconds = new(int64) } - yym329 := z.DecBinary() - _ = yym329 + yym333 := z.DecBinary() + _ = yym333 if false { } else { *((*int64)(x.StartingDeadlineSeconds)) = int64(r.DecodeInt(64)) @@ -3731,8 +3755,8 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Suspend == nil { x.Suspend = new(bool) } - yym332 := z.DecBinary() - _ = yym332 + yym336 := z.DecBinary() + _ = yym336 if false { } else { *((*bool)(x.Suspend)) = r.DecodeBool() @@ -3742,13 +3766,13 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.JobTemplate = JobTemplateSpec{} } else { - yyv333 := &x.JobTemplate - yyv333.CodecDecodeSelf(d) + yyv337 := &x.JobTemplate + yyv337.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys326) - } // end switch yys326 - } // end for yyj326 + z.DecStructFieldNotFound(-1, yys330) + } // end switch yys330 + } // end for yyj330 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -3756,16 +3780,16 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj334 int - var yyb334 bool - var yyhl334 bool = l >= 0 - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + var yyj338 int + var yyb338 bool + var yyhl338 bool = l >= 0 + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3775,13 +3799,13 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Schedule = string(r.DecodeString()) } - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3794,20 +3818,20 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.StartingDeadlineSeconds == nil { x.StartingDeadlineSeconds = new(int64) } - yym337 := z.DecBinary() - _ = yym337 + yym341 := z.DecBinary() + _ = yym341 if false { } else { *((*int64)(x.StartingDeadlineSeconds)) = int64(r.DecodeInt(64)) } } - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3817,13 +3841,13 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ConcurrencyPolicy = ConcurrencyPolicy(r.DecodeString()) } - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3836,20 +3860,20 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if x.Suspend == nil { x.Suspend = new(bool) } - yym340 := z.DecBinary() - _ = yym340 + yym344 := z.DecBinary() + _ = yym344 if false { } else { *((*bool)(x.Suspend)) = r.DecodeBool() } } - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3857,21 +3881,21 @@ func (x *ScheduledJobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.JobTemplate = JobTemplateSpec{} } else { - yyv341 := &x.JobTemplate - yyv341.CodecDecodeSelf(d) + yyv345 := &x.JobTemplate + yyv345.CodecDecodeSelf(d) } for { - yyj334++ - if yyhl334 { - yyb334 = yyj334 > l + yyj338++ + if yyhl338 { + yyb338 = yyj338 > l } else { - yyb334 = r.CheckBreak() + yyb338 = r.CheckBreak() } - if yyb334 { + if yyb338 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj334-1, "") + z.DecStructFieldNotFound(yyj338-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -3880,8 +3904,8 @@ func (x ConcurrencyPolicy) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym342 := z.EncBinary() - _ = yym342 + yym346 := z.EncBinary() + _ = yym346 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -3893,8 +3917,8 @@ func (x *ConcurrencyPolicy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym343 := z.DecBinary() - _ = yym343 + yym347 := z.DecBinary() + _ = yym347 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -3909,39 +3933,39 @@ func (x *ScheduledJobStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym344 := z.EncBinary() - _ = yym344 + yym348 := z.EncBinary() + _ = yym348 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep345 := !z.EncBinary() - yy2arr345 := z.EncBasicHandle().StructToArray - var yyq345 [2]bool - _, _, _ = yysep345, yyq345, yy2arr345 - const yyr345 bool = false - yyq345[0] = len(x.Active) != 0 - yyq345[1] = x.LastScheduleTime != nil - var yynn345 int - if yyr345 || yy2arr345 { + yysep349 := !z.EncBinary() + yy2arr349 := z.EncBasicHandle().StructToArray + var yyq349 [2]bool + _, _, _ = yysep349, yyq349, yy2arr349 + const yyr349 bool = false + yyq349[0] = len(x.Active) != 0 + yyq349[1] = x.LastScheduleTime != nil + var yynn349 int + if yyr349 || yy2arr349 { r.EncodeArrayStart(2) } else { - yynn345 = 0 - for _, b := range yyq345 { + yynn349 = 0 + for _, b := range yyq349 { if b { - yynn345++ + yynn349++ } } - r.EncodeMapStart(yynn345) - yynn345 = 0 + r.EncodeMapStart(yynn349) + yynn349 = 0 } - if yyr345 || yy2arr345 { + if yyr349 || yy2arr349 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq345[0] { + if yyq349[0] { if x.Active == nil { r.EncodeNil() } else { - yym347 := z.EncBinary() - _ = yym347 + yym351 := z.EncBinary() + _ = yym351 if false { } else { h.encSlicev1_ObjectReference(([]pkg2_v1.ObjectReference)(x.Active), e) @@ -3951,15 +3975,15 @@ func (x *ScheduledJobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq345[0] { + if yyq349[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("active")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Active == nil { r.EncodeNil() } else { - yym348 := z.EncBinary() - _ = yym348 + yym352 := z.EncBinary() + _ = yym352 if false { } else { h.encSlicev1_ObjectReference(([]pkg2_v1.ObjectReference)(x.Active), e) @@ -3967,19 +3991,19 @@ func (x *ScheduledJobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr345 || yy2arr345 { + if yyr349 || yy2arr349 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq345[1] { + if yyq349[1] { if x.LastScheduleTime == nil { r.EncodeNil() } else { - yym350 := z.EncBinary() - _ = yym350 + yym354 := z.EncBinary() + _ = yym354 if false { } else if z.HasExtensions() && z.EncExt(x.LastScheduleTime) { - } else if yym350 { + } else if yym354 { z.EncBinaryMarshal(x.LastScheduleTime) - } else if !yym350 && z.IsJSONHandle() { + } else if !yym354 && z.IsJSONHandle() { z.EncJSONMarshal(x.LastScheduleTime) } else { z.EncFallback(x.LastScheduleTime) @@ -3989,20 +4013,20 @@ func (x *ScheduledJobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq345[1] { + if yyq349[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastScheduleTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.LastScheduleTime == nil { r.EncodeNil() } else { - yym351 := z.EncBinary() - _ = yym351 + yym355 := z.EncBinary() + _ = yym355 if false { } else if z.HasExtensions() && z.EncExt(x.LastScheduleTime) { - } else if yym351 { + } else if yym355 { z.EncBinaryMarshal(x.LastScheduleTime) - } else if !yym351 && z.IsJSONHandle() { + } else if !yym355 && z.IsJSONHandle() { z.EncJSONMarshal(x.LastScheduleTime) } else { z.EncFallback(x.LastScheduleTime) @@ -4010,7 +4034,7 @@ func (x *ScheduledJobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr345 || yy2arr345 { + if yyr349 || yy2arr349 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -4023,25 +4047,25 @@ func (x *ScheduledJobStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym352 := z.DecBinary() - _ = yym352 + yym356 := z.DecBinary() + _ = yym356 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct353 := r.ContainerType() - if yyct353 == codecSelferValueTypeMap1234 { - yyl353 := r.ReadMapStart() - if yyl353 == 0 { + yyct357 := r.ContainerType() + if yyct357 == codecSelferValueTypeMap1234 { + yyl357 := r.ReadMapStart() + if yyl357 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl353, d) + x.codecDecodeSelfFromMap(yyl357, d) } - } else if yyct353 == codecSelferValueTypeArray1234 { - yyl353 := r.ReadArrayStart() - if yyl353 == 0 { + } else if yyct357 == codecSelferValueTypeArray1234 { + yyl357 := r.ReadArrayStart() + if yyl357 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl353, d) + x.codecDecodeSelfFromArray(yyl357, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -4053,12 +4077,12 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys354Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys354Slc - var yyhl354 bool = l >= 0 - for yyj354 := 0; ; yyj354++ { - if yyhl354 { - if yyj354 >= l { + var yys358Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys358Slc + var yyhl358 bool = l >= 0 + for yyj358 := 0; ; yyj358++ { + if yyhl358 { + if yyj358 >= l { break } } else { @@ -4067,20 +4091,20 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys354Slc = r.DecodeBytes(yys354Slc, true, true) - yys354 := string(yys354Slc) + yys358Slc = r.DecodeBytes(yys358Slc, true, true) + yys358 := string(yys358Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys354 { + switch yys358 { case "active": if r.TryDecodeAsNil() { x.Active = nil } else { - yyv355 := &x.Active - yym356 := z.DecBinary() - _ = yym356 + yyv359 := &x.Active + yym360 := z.DecBinary() + _ = yym360 if false { } else { - h.decSlicev1_ObjectReference((*[]pkg2_v1.ObjectReference)(yyv355), d) + h.decSlicev1_ObjectReference((*[]pkg2_v1.ObjectReference)(yyv359), d) } } case "lastScheduleTime": @@ -4092,22 +4116,22 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if x.LastScheduleTime == nil { x.LastScheduleTime = new(pkg1_unversioned.Time) } - yym358 := z.DecBinary() - _ = yym358 + yym362 := z.DecBinary() + _ = yym362 if false { } else if z.HasExtensions() && z.DecExt(x.LastScheduleTime) { - } else if yym358 { + } else if yym362 { z.DecBinaryUnmarshal(x.LastScheduleTime) - } else if !yym358 && z.IsJSONHandle() { + } else if !yym362 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.LastScheduleTime) } else { z.DecFallback(x.LastScheduleTime, false) } } default: - z.DecStructFieldNotFound(-1, yys354) - } // end switch yys354 - } // end for yyj354 + z.DecStructFieldNotFound(-1, yys358) + } // end switch yys358 + } // end for yyj358 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -4115,16 +4139,16 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj359 int - var yyb359 bool - var yyhl359 bool = l >= 0 - yyj359++ - if yyhl359 { - yyb359 = yyj359 > l + var yyj363 int + var yyb363 bool + var yyhl363 bool = l >= 0 + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb359 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb359 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4132,21 +4156,21 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.Active = nil } else { - yyv360 := &x.Active - yym361 := z.DecBinary() - _ = yym361 + yyv364 := &x.Active + yym365 := z.DecBinary() + _ = yym365 if false { } else { - h.decSlicev1_ObjectReference((*[]pkg2_v1.ObjectReference)(yyv360), d) + h.decSlicev1_ObjectReference((*[]pkg2_v1.ObjectReference)(yyv364), d) } } - yyj359++ - if yyhl359 { - yyb359 = yyj359 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb359 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb359 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4159,587 +4183,43 @@ func (x *ScheduledJobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decode if x.LastScheduleTime == nil { x.LastScheduleTime = new(pkg1_unversioned.Time) } - yym363 := z.DecBinary() - _ = yym363 + yym367 := z.DecBinary() + _ = yym367 if false { } else if z.HasExtensions() && z.DecExt(x.LastScheduleTime) { - } else if yym363 { + } else if yym367 { z.DecBinaryUnmarshal(x.LastScheduleTime) - } else if !yym363 && z.IsJSONHandle() { + } else if !yym367 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.LastScheduleTime) } else { z.DecFallback(x.LastScheduleTime, false) } } for { - yyj359++ - if yyhl359 { - yyb359 = yyj359 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb359 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb359 { + if yyb363 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj359-1, "") + z.DecStructFieldNotFound(yyj363-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *LabelSelector) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym364 := z.EncBinary() - _ = yym364 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep365 := !z.EncBinary() - yy2arr365 := z.EncBasicHandle().StructToArray - var yyq365 [2]bool - _, _, _ = yysep365, yyq365, yy2arr365 - const yyr365 bool = false - yyq365[0] = len(x.MatchLabels) != 0 - yyq365[1] = len(x.MatchExpressions) != 0 - var yynn365 int - if yyr365 || yy2arr365 { - r.EncodeArrayStart(2) - } else { - yynn365 = 0 - for _, b := range yyq365 { - if b { - yynn365++ - } - } - r.EncodeMapStart(yynn365) - yynn365 = 0 - } - if yyr365 || yy2arr365 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq365[0] { - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym367 := z.EncBinary() - _ = yym367 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq365[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchLabels")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym368 := z.EncBinary() - _ = yym368 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } - } - if yyr365 || yy2arr365 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq365[1] { - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym370 := z.EncBinary() - _ = yym370 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq365[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchExpressions")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym371 := z.EncBinary() - _ = yym371 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } - } - } - if yyr365 || yy2arr365 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelector) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym372 := z.DecBinary() - _ = yym372 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct373 := r.ContainerType() - if yyct373 == codecSelferValueTypeMap1234 { - yyl373 := r.ReadMapStart() - if yyl373 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl373, d) - } - } else if yyct373 == codecSelferValueTypeArray1234 { - yyl373 := r.ReadArrayStart() - if yyl373 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl373, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelector) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys374Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys374Slc - var yyhl374 bool = l >= 0 - for yyj374 := 0; ; yyj374++ { - if yyhl374 { - if yyj374 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys374Slc = r.DecodeBytes(yys374Slc, true, true) - yys374 := string(yys374Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys374 { - case "matchLabels": - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv375 := &x.MatchLabels - yym376 := z.DecBinary() - _ = yym376 - if false { - } else { - z.F.DecMapStringStringX(yyv375, false, d) - } - } - case "matchExpressions": - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv377 := &x.MatchExpressions - yym378 := z.DecBinary() - _ = yym378 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv377), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys374) - } // end switch yys374 - } // end for yyj374 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelector) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj379 int - var yyb379 bool - var yyhl379 bool = l >= 0 - yyj379++ - if yyhl379 { - yyb379 = yyj379 > l - } else { - yyb379 = r.CheckBreak() - } - if yyb379 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv380 := &x.MatchLabels - yym381 := z.DecBinary() - _ = yym381 - if false { - } else { - z.F.DecMapStringStringX(yyv380, false, d) - } - } - yyj379++ - if yyhl379 { - yyb379 = yyj379 > l - } else { - yyb379 = r.CheckBreak() - } - if yyb379 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv382 := &x.MatchExpressions - yym383 := z.DecBinary() - _ = yym383 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv382), d) - } - } - for { - yyj379++ - if yyhl379 { - yyb379 = yyj379 > l - } else { - yyb379 = r.CheckBreak() - } - if yyb379 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj379-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *LabelSelectorRequirement) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym384 := z.EncBinary() - _ = yym384 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep385 := !z.EncBinary() - yy2arr385 := z.EncBasicHandle().StructToArray - var yyq385 [3]bool - _, _, _ = yysep385, yyq385, yy2arr385 - const yyr385 bool = false - yyq385[2] = len(x.Values) != 0 - var yynn385 int - if yyr385 || yy2arr385 { - r.EncodeArrayStart(3) - } else { - yynn385 = 2 - for _, b := range yyq385 { - if b { - yynn385++ - } - } - r.EncodeMapStart(yynn385) - yynn385 = 0 - } - if yyr385 || yy2arr385 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym387 := z.EncBinary() - _ = yym387 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("key")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym388 := z.EncBinary() - _ = yym388 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } - if yyr385 || yy2arr385 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - x.Operator.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("operator")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Operator.CodecEncodeSelf(e) - } - if yyr385 || yy2arr385 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq385[2] { - if x.Values == nil { - r.EncodeNil() - } else { - yym391 := z.EncBinary() - _ = yym391 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq385[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("values")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Values == nil { - r.EncodeNil() - } else { - yym392 := z.EncBinary() - _ = yym392 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } - } - if yyr385 || yy2arr385 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelectorRequirement) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym393 := z.DecBinary() - _ = yym393 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct394 := r.ContainerType() - if yyct394 == codecSelferValueTypeMap1234 { - yyl394 := r.ReadMapStart() - if yyl394 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl394, d) - } - } else if yyct394 == codecSelferValueTypeArray1234 { - yyl394 := r.ReadArrayStart() - if yyl394 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl394, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys395Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys395Slc - var yyhl395 bool = l >= 0 - for yyj395 := 0; ; yyj395++ { - if yyhl395 { - if yyj395 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys395Slc = r.DecodeBytes(yys395Slc, true, true) - yys395 := string(yys395Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys395 { - case "key": - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - case "operator": - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - case "values": - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv398 := &x.Values - yym399 := z.DecBinary() - _ = yym399 - if false { - } else { - z.F.DecSliceStringX(yyv398, false, d) - } - } - default: - z.DecStructFieldNotFound(-1, yys395) - } // end switch yys395 - } // end for yyj395 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj400 int - var yyb400 bool - var yyhl400 bool = l >= 0 - yyj400++ - if yyhl400 { - yyb400 = yyj400 > l - } else { - yyb400 = r.CheckBreak() - } - if yyb400 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - yyj400++ - if yyhl400 { - yyb400 = yyj400 > l - } else { - yyb400 = r.CheckBreak() - } - if yyb400 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - yyj400++ - if yyhl400 { - yyb400 = yyj400 > l - } else { - yyb400 = r.CheckBreak() - } - if yyb400 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv403 := &x.Values - yym404 := z.DecBinary() - _ = yym404 - if false { - } else { - z.F.DecSliceStringX(yyv403, false, d) - } - } - for { - yyj400++ - if yyhl400 { - yyb400 = yyj400 > l - } else { - yyb400 = r.CheckBreak() - } - if yyb400 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj400-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x LabelSelectorOperator) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym405 := z.EncBinary() - _ = yym405 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *LabelSelectorOperator) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym406 := z.DecBinary() - _ = yym406 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - func (x codecSelfer1234) encSliceJob(v []Job, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv407 := range v { + for _, yyv368 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy408 := &yyv407 - yy408.CodecEncodeSelf(e) + yy369 := &yyv368 + yy369.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4749,83 +4229,83 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv409 := *v - yyh409, yyl409 := z.DecSliceHelperStart() - var yyc409 bool - if yyl409 == 0 { - if yyv409 == nil { - yyv409 = []Job{} - yyc409 = true - } else if len(yyv409) != 0 { - yyv409 = yyv409[:0] - yyc409 = true + yyv370 := *v + yyh370, yyl370 := z.DecSliceHelperStart() + var yyc370 bool + if yyl370 == 0 { + if yyv370 == nil { + yyv370 = []Job{} + yyc370 = true + } else if len(yyv370) != 0 { + yyv370 = yyv370[:0] + yyc370 = true } - } else if yyl409 > 0 { - var yyrr409, yyrl409 int - var yyrt409 bool - if yyl409 > cap(yyv409) { + } else if yyl370 > 0 { + var yyrr370, yyrl370 int + var yyrt370 bool + if yyl370 > cap(yyv370) { - yyrg409 := len(yyv409) > 0 - yyv2409 := yyv409 - yyrl409, yyrt409 = z.DecInferLen(yyl409, z.DecBasicHandle().MaxInitLen, 824) - if yyrt409 { - if yyrl409 <= cap(yyv409) { - yyv409 = yyv409[:yyrl409] + yyrg370 := len(yyv370) > 0 + yyv2370 := yyv370 + yyrl370, yyrt370 = z.DecInferLen(yyl370, z.DecBasicHandle().MaxInitLen, 824) + if yyrt370 { + if yyrl370 <= cap(yyv370) { + yyv370 = yyv370[:yyrl370] } else { - yyv409 = make([]Job, yyrl409) + yyv370 = make([]Job, yyrl370) } } else { - yyv409 = make([]Job, yyrl409) + yyv370 = make([]Job, yyrl370) } - yyc409 = true - yyrr409 = len(yyv409) - if yyrg409 { - copy(yyv409, yyv2409) + yyc370 = true + yyrr370 = len(yyv370) + if yyrg370 { + copy(yyv370, yyv2370) } - } else if yyl409 != len(yyv409) { - yyv409 = yyv409[:yyl409] - yyc409 = true + } else if yyl370 != len(yyv370) { + yyv370 = yyv370[:yyl370] + yyc370 = true } - yyj409 := 0 - for ; yyj409 < yyrr409; yyj409++ { - yyh409.ElemContainerState(yyj409) + yyj370 := 0 + for ; yyj370 < yyrr370; yyj370++ { + yyh370.ElemContainerState(yyj370) if r.TryDecodeAsNil() { - yyv409[yyj409] = Job{} + yyv370[yyj370] = Job{} } else { - yyv410 := &yyv409[yyj409] - yyv410.CodecDecodeSelf(d) + yyv371 := &yyv370[yyj370] + yyv371.CodecDecodeSelf(d) } } - if yyrt409 { - for ; yyj409 < yyl409; yyj409++ { - yyv409 = append(yyv409, Job{}) - yyh409.ElemContainerState(yyj409) + if yyrt370 { + for ; yyj370 < yyl370; yyj370++ { + yyv370 = append(yyv370, Job{}) + yyh370.ElemContainerState(yyj370) if r.TryDecodeAsNil() { - yyv409[yyj409] = Job{} + yyv370[yyj370] = Job{} } else { - yyv411 := &yyv409[yyj409] - yyv411.CodecDecodeSelf(d) + yyv372 := &yyv370[yyj370] + yyv372.CodecDecodeSelf(d) } } } } else { - yyj409 := 0 - for ; !r.CheckBreak(); yyj409++ { + yyj370 := 0 + for ; !r.CheckBreak(); yyj370++ { - if yyj409 >= len(yyv409) { - yyv409 = append(yyv409, Job{}) // var yyz409 Job - yyc409 = true + if yyj370 >= len(yyv370) { + yyv370 = append(yyv370, Job{}) // var yyz370 Job + yyc370 = true } - yyh409.ElemContainerState(yyj409) - if yyj409 < len(yyv409) { + yyh370.ElemContainerState(yyj370) + if yyj370 < len(yyv370) { if r.TryDecodeAsNil() { - yyv409[yyj409] = Job{} + yyv370[yyj370] = Job{} } else { - yyv412 := &yyv409[yyj409] - yyv412.CodecDecodeSelf(d) + yyv373 := &yyv370[yyj370] + yyv373.CodecDecodeSelf(d) } } else { @@ -4833,17 +4313,17 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { } } - if yyj409 < len(yyv409) { - yyv409 = yyv409[:yyj409] - yyc409 = true - } else if yyj409 == 0 && yyv409 == nil { - yyv409 = []Job{} - yyc409 = true + if yyj370 < len(yyv370) { + yyv370 = yyv370[:yyj370] + yyc370 = true + } else if yyj370 == 0 && yyv370 == nil { + yyv370 = []Job{} + yyc370 = true } } - yyh409.End() - if yyc409 { - *v = yyv409 + yyh370.End() + if yyc370 { + *v = yyv370 } } @@ -4852,10 +4332,10 @@ func (x codecSelfer1234) encSliceJobCondition(v []JobCondition, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv413 := range v { + for _, yyv374 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy414 := &yyv413 - yy414.CodecEncodeSelf(e) + yy375 := &yyv374 + yy375.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4865,83 +4345,83 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv415 := *v - yyh415, yyl415 := z.DecSliceHelperStart() - var yyc415 bool - if yyl415 == 0 { - if yyv415 == nil { - yyv415 = []JobCondition{} - yyc415 = true - } else if len(yyv415) != 0 { - yyv415 = yyv415[:0] - yyc415 = true + yyv376 := *v + yyh376, yyl376 := z.DecSliceHelperStart() + var yyc376 bool + if yyl376 == 0 { + if yyv376 == nil { + yyv376 = []JobCondition{} + yyc376 = true + } else if len(yyv376) != 0 { + yyv376 = yyv376[:0] + yyc376 = true } - } else if yyl415 > 0 { - var yyrr415, yyrl415 int - var yyrt415 bool - if yyl415 > cap(yyv415) { + } else if yyl376 > 0 { + var yyrr376, yyrl376 int + var yyrt376 bool + if yyl376 > cap(yyv376) { - yyrg415 := len(yyv415) > 0 - yyv2415 := yyv415 - yyrl415, yyrt415 = z.DecInferLen(yyl415, z.DecBasicHandle().MaxInitLen, 112) - if yyrt415 { - if yyrl415 <= cap(yyv415) { - yyv415 = yyv415[:yyrl415] + yyrg376 := len(yyv376) > 0 + yyv2376 := yyv376 + yyrl376, yyrt376 = z.DecInferLen(yyl376, z.DecBasicHandle().MaxInitLen, 112) + if yyrt376 { + if yyrl376 <= cap(yyv376) { + yyv376 = yyv376[:yyrl376] } else { - yyv415 = make([]JobCondition, yyrl415) + yyv376 = make([]JobCondition, yyrl376) } } else { - yyv415 = make([]JobCondition, yyrl415) + yyv376 = make([]JobCondition, yyrl376) } - yyc415 = true - yyrr415 = len(yyv415) - if yyrg415 { - copy(yyv415, yyv2415) + yyc376 = true + yyrr376 = len(yyv376) + if yyrg376 { + copy(yyv376, yyv2376) } - } else if yyl415 != len(yyv415) { - yyv415 = yyv415[:yyl415] - yyc415 = true + } else if yyl376 != len(yyv376) { + yyv376 = yyv376[:yyl376] + yyc376 = true } - yyj415 := 0 - for ; yyj415 < yyrr415; yyj415++ { - yyh415.ElemContainerState(yyj415) + yyj376 := 0 + for ; yyj376 < yyrr376; yyj376++ { + yyh376.ElemContainerState(yyj376) if r.TryDecodeAsNil() { - yyv415[yyj415] = JobCondition{} + yyv376[yyj376] = JobCondition{} } else { - yyv416 := &yyv415[yyj415] - yyv416.CodecDecodeSelf(d) + yyv377 := &yyv376[yyj376] + yyv377.CodecDecodeSelf(d) } } - if yyrt415 { - for ; yyj415 < yyl415; yyj415++ { - yyv415 = append(yyv415, JobCondition{}) - yyh415.ElemContainerState(yyj415) + if yyrt376 { + for ; yyj376 < yyl376; yyj376++ { + yyv376 = append(yyv376, JobCondition{}) + yyh376.ElemContainerState(yyj376) if r.TryDecodeAsNil() { - yyv415[yyj415] = JobCondition{} + yyv376[yyj376] = JobCondition{} } else { - yyv417 := &yyv415[yyj415] - yyv417.CodecDecodeSelf(d) + yyv378 := &yyv376[yyj376] + yyv378.CodecDecodeSelf(d) } } } } else { - yyj415 := 0 - for ; !r.CheckBreak(); yyj415++ { + yyj376 := 0 + for ; !r.CheckBreak(); yyj376++ { - if yyj415 >= len(yyv415) { - yyv415 = append(yyv415, JobCondition{}) // var yyz415 JobCondition - yyc415 = true + if yyj376 >= len(yyv376) { + yyv376 = append(yyv376, JobCondition{}) // var yyz376 JobCondition + yyc376 = true } - yyh415.ElemContainerState(yyj415) - if yyj415 < len(yyv415) { + yyh376.ElemContainerState(yyj376) + if yyj376 < len(yyv376) { if r.TryDecodeAsNil() { - yyv415[yyj415] = JobCondition{} + yyv376[yyj376] = JobCondition{} } else { - yyv418 := &yyv415[yyj415] - yyv418.CodecDecodeSelf(d) + yyv379 := &yyv376[yyj376] + yyv379.CodecDecodeSelf(d) } } else { @@ -4949,17 +4429,17 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De } } - if yyj415 < len(yyv415) { - yyv415 = yyv415[:yyj415] - yyc415 = true - } else if yyj415 == 0 && yyv415 == nil { - yyv415 = []JobCondition{} - yyc415 = true + if yyj376 < len(yyv376) { + yyv376 = yyv376[:yyj376] + yyc376 = true + } else if yyj376 == 0 && yyv376 == nil { + yyv376 = []JobCondition{} + yyc376 = true } } - yyh415.End() - if yyc415 { - *v = yyv415 + yyh376.End() + if yyc376 { + *v = yyv376 } } @@ -4968,10 +4448,10 @@ func (x codecSelfer1234) encSliceScheduledJob(v []ScheduledJob, e *codec1978.Enc z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv419 := range v { + for _, yyv380 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy420 := &yyv419 - yy420.CodecEncodeSelf(e) + yy381 := &yyv380 + yy381.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4981,83 +4461,83 @@ func (x codecSelfer1234) decSliceScheduledJob(v *[]ScheduledJob, d *codec1978.De z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv421 := *v - yyh421, yyl421 := z.DecSliceHelperStart() - var yyc421 bool - if yyl421 == 0 { - if yyv421 == nil { - yyv421 = []ScheduledJob{} - yyc421 = true - } else if len(yyv421) != 0 { - yyv421 = yyv421[:0] - yyc421 = true + yyv382 := *v + yyh382, yyl382 := z.DecSliceHelperStart() + var yyc382 bool + if yyl382 == 0 { + if yyv382 == nil { + yyv382 = []ScheduledJob{} + yyc382 = true + } else if len(yyv382) != 0 { + yyv382 = yyv382[:0] + yyc382 = true } - } else if yyl421 > 0 { - var yyrr421, yyrl421 int - var yyrt421 bool - if yyl421 > cap(yyv421) { + } else if yyl382 > 0 { + var yyrr382, yyrl382 int + var yyrt382 bool + if yyl382 > cap(yyv382) { - yyrg421 := len(yyv421) > 0 - yyv2421 := yyv421 - yyrl421, yyrt421 = z.DecInferLen(yyl421, z.DecBasicHandle().MaxInitLen, 1072) - if yyrt421 { - if yyrl421 <= cap(yyv421) { - yyv421 = yyv421[:yyrl421] + yyrg382 := len(yyv382) > 0 + yyv2382 := yyv382 + yyrl382, yyrt382 = z.DecInferLen(yyl382, z.DecBasicHandle().MaxInitLen, 1072) + if yyrt382 { + if yyrl382 <= cap(yyv382) { + yyv382 = yyv382[:yyrl382] } else { - yyv421 = make([]ScheduledJob, yyrl421) + yyv382 = make([]ScheduledJob, yyrl382) } } else { - yyv421 = make([]ScheduledJob, yyrl421) + yyv382 = make([]ScheduledJob, yyrl382) } - yyc421 = true - yyrr421 = len(yyv421) - if yyrg421 { - copy(yyv421, yyv2421) + yyc382 = true + yyrr382 = len(yyv382) + if yyrg382 { + copy(yyv382, yyv2382) } - } else if yyl421 != len(yyv421) { - yyv421 = yyv421[:yyl421] - yyc421 = true + } else if yyl382 != len(yyv382) { + yyv382 = yyv382[:yyl382] + yyc382 = true } - yyj421 := 0 - for ; yyj421 < yyrr421; yyj421++ { - yyh421.ElemContainerState(yyj421) + yyj382 := 0 + for ; yyj382 < yyrr382; yyj382++ { + yyh382.ElemContainerState(yyj382) if r.TryDecodeAsNil() { - yyv421[yyj421] = ScheduledJob{} + yyv382[yyj382] = ScheduledJob{} } else { - yyv422 := &yyv421[yyj421] - yyv422.CodecDecodeSelf(d) + yyv383 := &yyv382[yyj382] + yyv383.CodecDecodeSelf(d) } } - if yyrt421 { - for ; yyj421 < yyl421; yyj421++ { - yyv421 = append(yyv421, ScheduledJob{}) - yyh421.ElemContainerState(yyj421) + if yyrt382 { + for ; yyj382 < yyl382; yyj382++ { + yyv382 = append(yyv382, ScheduledJob{}) + yyh382.ElemContainerState(yyj382) if r.TryDecodeAsNil() { - yyv421[yyj421] = ScheduledJob{} + yyv382[yyj382] = ScheduledJob{} } else { - yyv423 := &yyv421[yyj421] - yyv423.CodecDecodeSelf(d) + yyv384 := &yyv382[yyj382] + yyv384.CodecDecodeSelf(d) } } } } else { - yyj421 := 0 - for ; !r.CheckBreak(); yyj421++ { + yyj382 := 0 + for ; !r.CheckBreak(); yyj382++ { - if yyj421 >= len(yyv421) { - yyv421 = append(yyv421, ScheduledJob{}) // var yyz421 ScheduledJob - yyc421 = true + if yyj382 >= len(yyv382) { + yyv382 = append(yyv382, ScheduledJob{}) // var yyz382 ScheduledJob + yyc382 = true } - yyh421.ElemContainerState(yyj421) - if yyj421 < len(yyv421) { + yyh382.ElemContainerState(yyj382) + if yyj382 < len(yyv382) { if r.TryDecodeAsNil() { - yyv421[yyj421] = ScheduledJob{} + yyv382[yyj382] = ScheduledJob{} } else { - yyv424 := &yyv421[yyj421] - yyv424.CodecDecodeSelf(d) + yyv385 := &yyv382[yyj382] + yyv385.CodecDecodeSelf(d) } } else { @@ -5065,17 +4545,17 @@ func (x codecSelfer1234) decSliceScheduledJob(v *[]ScheduledJob, d *codec1978.De } } - if yyj421 < len(yyv421) { - yyv421 = yyv421[:yyj421] - yyc421 = true - } else if yyj421 == 0 && yyv421 == nil { - yyv421 = []ScheduledJob{} - yyc421 = true + if yyj382 < len(yyv382) { + yyv382 = yyv382[:yyj382] + yyc382 = true + } else if yyj382 == 0 && yyv382 == nil { + yyv382 = []ScheduledJob{} + yyc382 = true } } - yyh421.End() - if yyc421 { - *v = yyv421 + yyh382.End() + if yyc382 { + *v = yyv382 } } @@ -5084,10 +4564,10 @@ func (x codecSelfer1234) encSlicev1_ObjectReference(v []pkg2_v1.ObjectReference, z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv425 := range v { + for _, yyv386 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy426 := &yyv425 - yy426.CodecEncodeSelf(e) + yy387 := &yyv386 + yy387.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -5097,83 +4577,83 @@ func (x codecSelfer1234) decSlicev1_ObjectReference(v *[]pkg2_v1.ObjectReference z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv427 := *v - yyh427, yyl427 := z.DecSliceHelperStart() - var yyc427 bool - if yyl427 == 0 { - if yyv427 == nil { - yyv427 = []pkg2_v1.ObjectReference{} - yyc427 = true - } else if len(yyv427) != 0 { - yyv427 = yyv427[:0] - yyc427 = true + yyv388 := *v + yyh388, yyl388 := z.DecSliceHelperStart() + var yyc388 bool + if yyl388 == 0 { + if yyv388 == nil { + yyv388 = []pkg2_v1.ObjectReference{} + yyc388 = true + } else if len(yyv388) != 0 { + yyv388 = yyv388[:0] + yyc388 = true } - } else if yyl427 > 0 { - var yyrr427, yyrl427 int - var yyrt427 bool - if yyl427 > cap(yyv427) { + } else if yyl388 > 0 { + var yyrr388, yyrl388 int + var yyrt388 bool + if yyl388 > cap(yyv388) { - yyrg427 := len(yyv427) > 0 - yyv2427 := yyv427 - yyrl427, yyrt427 = z.DecInferLen(yyl427, z.DecBasicHandle().MaxInitLen, 112) - if yyrt427 { - if yyrl427 <= cap(yyv427) { - yyv427 = yyv427[:yyrl427] + yyrg388 := len(yyv388) > 0 + yyv2388 := yyv388 + yyrl388, yyrt388 = z.DecInferLen(yyl388, z.DecBasicHandle().MaxInitLen, 112) + if yyrt388 { + if yyrl388 <= cap(yyv388) { + yyv388 = yyv388[:yyrl388] } else { - yyv427 = make([]pkg2_v1.ObjectReference, yyrl427) + yyv388 = make([]pkg2_v1.ObjectReference, yyrl388) } } else { - yyv427 = make([]pkg2_v1.ObjectReference, yyrl427) + yyv388 = make([]pkg2_v1.ObjectReference, yyrl388) } - yyc427 = true - yyrr427 = len(yyv427) - if yyrg427 { - copy(yyv427, yyv2427) + yyc388 = true + yyrr388 = len(yyv388) + if yyrg388 { + copy(yyv388, yyv2388) } - } else if yyl427 != len(yyv427) { - yyv427 = yyv427[:yyl427] - yyc427 = true + } else if yyl388 != len(yyv388) { + yyv388 = yyv388[:yyl388] + yyc388 = true } - yyj427 := 0 - for ; yyj427 < yyrr427; yyj427++ { - yyh427.ElemContainerState(yyj427) + yyj388 := 0 + for ; yyj388 < yyrr388; yyj388++ { + yyh388.ElemContainerState(yyj388) if r.TryDecodeAsNil() { - yyv427[yyj427] = pkg2_v1.ObjectReference{} + yyv388[yyj388] = pkg2_v1.ObjectReference{} } else { - yyv428 := &yyv427[yyj427] - yyv428.CodecDecodeSelf(d) + yyv389 := &yyv388[yyj388] + yyv389.CodecDecodeSelf(d) } } - if yyrt427 { - for ; yyj427 < yyl427; yyj427++ { - yyv427 = append(yyv427, pkg2_v1.ObjectReference{}) - yyh427.ElemContainerState(yyj427) + if yyrt388 { + for ; yyj388 < yyl388; yyj388++ { + yyv388 = append(yyv388, pkg2_v1.ObjectReference{}) + yyh388.ElemContainerState(yyj388) if r.TryDecodeAsNil() { - yyv427[yyj427] = pkg2_v1.ObjectReference{} + yyv388[yyj388] = pkg2_v1.ObjectReference{} } else { - yyv429 := &yyv427[yyj427] - yyv429.CodecDecodeSelf(d) + yyv390 := &yyv388[yyj388] + yyv390.CodecDecodeSelf(d) } } } } else { - yyj427 := 0 - for ; !r.CheckBreak(); yyj427++ { + yyj388 := 0 + for ; !r.CheckBreak(); yyj388++ { - if yyj427 >= len(yyv427) { - yyv427 = append(yyv427, pkg2_v1.ObjectReference{}) // var yyz427 pkg2_v1.ObjectReference - yyc427 = true + if yyj388 >= len(yyv388) { + yyv388 = append(yyv388, pkg2_v1.ObjectReference{}) // var yyz388 pkg2_v1.ObjectReference + yyc388 = true } - yyh427.ElemContainerState(yyj427) - if yyj427 < len(yyv427) { + yyh388.ElemContainerState(yyj388) + if yyj388 < len(yyv388) { if r.TryDecodeAsNil() { - yyv427[yyj427] = pkg2_v1.ObjectReference{} + yyv388[yyj388] = pkg2_v1.ObjectReference{} } else { - yyv430 := &yyv427[yyj427] - yyv430.CodecDecodeSelf(d) + yyv391 := &yyv388[yyj388] + yyv391.CodecDecodeSelf(d) } } else { @@ -5181,132 +4661,16 @@ func (x codecSelfer1234) decSlicev1_ObjectReference(v *[]pkg2_v1.ObjectReference } } - if yyj427 < len(yyv427) { - yyv427 = yyv427[:yyj427] - yyc427 = true - } else if yyj427 == 0 && yyv427 == nil { - yyv427 = []pkg2_v1.ObjectReference{} - yyc427 = true + if yyj388 < len(yyv388) { + yyv388 = yyv388[:yyj388] + yyc388 = true + } else if yyj388 == 0 && yyv388 == nil { + yyv388 = []pkg2_v1.ObjectReference{} + yyc388 = true } } - yyh427.End() - if yyc427 { - *v = yyv427 - } -} - -func (x codecSelfer1234) encSliceLabelSelectorRequirement(v []LabelSelectorRequirement, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv431 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy432 := &yyv431 - yy432.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequirement, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv433 := *v - yyh433, yyl433 := z.DecSliceHelperStart() - var yyc433 bool - if yyl433 == 0 { - if yyv433 == nil { - yyv433 = []LabelSelectorRequirement{} - yyc433 = true - } else if len(yyv433) != 0 { - yyv433 = yyv433[:0] - yyc433 = true - } - } else if yyl433 > 0 { - var yyrr433, yyrl433 int - var yyrt433 bool - if yyl433 > cap(yyv433) { - - yyrg433 := len(yyv433) > 0 - yyv2433 := yyv433 - yyrl433, yyrt433 = z.DecInferLen(yyl433, z.DecBasicHandle().MaxInitLen, 56) - if yyrt433 { - if yyrl433 <= cap(yyv433) { - yyv433 = yyv433[:yyrl433] - } else { - yyv433 = make([]LabelSelectorRequirement, yyrl433) - } - } else { - yyv433 = make([]LabelSelectorRequirement, yyrl433) - } - yyc433 = true - yyrr433 = len(yyv433) - if yyrg433 { - copy(yyv433, yyv2433) - } - } else if yyl433 != len(yyv433) { - yyv433 = yyv433[:yyl433] - yyc433 = true - } - yyj433 := 0 - for ; yyj433 < yyrr433; yyj433++ { - yyh433.ElemContainerState(yyj433) - if r.TryDecodeAsNil() { - yyv433[yyj433] = LabelSelectorRequirement{} - } else { - yyv434 := &yyv433[yyj433] - yyv434.CodecDecodeSelf(d) - } - - } - if yyrt433 { - for ; yyj433 < yyl433; yyj433++ { - yyv433 = append(yyv433, LabelSelectorRequirement{}) - yyh433.ElemContainerState(yyj433) - if r.TryDecodeAsNil() { - yyv433[yyj433] = LabelSelectorRequirement{} - } else { - yyv435 := &yyv433[yyj433] - yyv435.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj433 := 0 - for ; !r.CheckBreak(); yyj433++ { - - if yyj433 >= len(yyv433) { - yyv433 = append(yyv433, LabelSelectorRequirement{}) // var yyz433 LabelSelectorRequirement - yyc433 = true - } - yyh433.ElemContainerState(yyj433) - if yyj433 < len(yyv433) { - if r.TryDecodeAsNil() { - yyv433[yyj433] = LabelSelectorRequirement{} - } else { - yyv436 := &yyv433[yyj433] - yyv436.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj433 < len(yyv433) { - yyv433 = yyv433[:yyj433] - yyc433 = true - } else if yyj433 == 0 && yyv433 == nil { - yyv433 = []LabelSelectorRequirement{} - yyc433 = true - } - } - yyh433.End() - if yyc433 { - *v = yyv433 + yyh388.End() + if yyc388 { + *v = yyv388 } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.go index d5f5583..9a98867 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types.go @@ -17,8 +17,8 @@ limitations under the License. package v2alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // Job represents the configuration of a single job. @@ -26,14 +26,17 @@ type Job struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status JobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -42,6 +45,7 @@ type JobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Job. @@ -53,10 +57,12 @@ type JobTemplate struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Template defines jobs that will be created from this template // http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Template JobTemplateSpec `json:"template,omitempty" protobuf:"bytes,2,opt,name=template"` } @@ -64,10 +70,12 @@ type JobTemplate struct { type JobTemplateSpec struct { // Standard object's metadata of the jobs created from this template. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior of the job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` } @@ -79,6 +87,7 @@ type JobSpec struct { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Parallelism *int32 `json:"parallelism,omitempty" protobuf:"varint,1,opt,name=parallelism"` // Completions specifies the desired number of successfully finished pods the @@ -87,16 +96,19 @@ type JobSpec struct { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Completions *int32 `json:"completions,omitempty" protobuf:"varint,2,opt,name=completions"` // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty" protobuf:"varint,3,opt,name=activeDeadlineSeconds"` // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` // ManualSelector controls generation of pod labels and pod selectors. // Leave `manualSelector` unset unless you are certain what you are doing. @@ -108,6 +120,7 @@ type JobSpec struct { // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` // API. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional ManualSelector *bool `json:"manualSelector,omitempty" protobuf:"varint,5,opt,name=manualSelector"` // Template is the object that describes the pod that will be created when @@ -121,25 +134,31 @@ type JobStatus struct { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Conditions []JobCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,1,rep,name=conditions"` // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty" protobuf:"bytes,2,opt,name=startTime"` // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional CompletionTime *unversioned.Time `json:"completionTime,omitempty" protobuf:"bytes,3,opt,name=completionTime"` // Active is the number of actively running pods. + // +optional Active int32 `json:"active,omitempty" protobuf:"varint,4,opt,name=active"` // Succeeded is the number of pods which reached Phase Succeeded. + // +optional Succeeded int32 `json:"succeeded,omitempty" protobuf:"varint,5,opt,name=succeeded"` // Failed is the number of pods which reached Phase Failed. + // +optional Failed int32 `json:"failed,omitempty" protobuf:"varint,6,opt,name=failed"` } @@ -160,12 +179,16 @@ type JobCondition struct { // Status of the condition, one of True, False, Unknown. Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/kubernetes/pkg/api/v1.ConditionStatus"` // Last time the condition was checked. + // +optional LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty" protobuf:"bytes,3,opt,name=lastProbeTime"` // Last time the condition transit from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` // (brief) reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` // Human readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` } @@ -174,14 +197,17 @@ type ScheduledJob struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec is a structure defining the expected behavior of a job, including the schedule. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ScheduledJobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ScheduledJobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -190,6 +216,7 @@ type ScheduledJobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of ScheduledJob. @@ -204,13 +231,16 @@ type ScheduledJobSpec struct { // Optional deadline in seconds for starting the job if it misses scheduled // time for any reason. Missed jobs executions will be counted as failed ones. + // +optional StartingDeadlineSeconds *int64 `json:"startingDeadlineSeconds,omitempty" protobuf:"varint,2,opt,name=startingDeadlineSeconds"` // ConcurrencyPolicy specifies how to treat concurrent executions of a Job. + // +optional ConcurrencyPolicy ConcurrencyPolicy `json:"concurrencyPolicy,omitempty" protobuf:"bytes,3,opt,name=concurrencyPolicy,casttype=ConcurrencyPolicy"` // Suspend flag tells the controller to suspend subsequent executions, it does // not apply to already started executions. Defaults to false. + // +optional Suspend *bool `json:"suspend,omitempty" protobuf:"varint,4,opt,name=suspend"` // JobTemplate is the object that describes the job that will be created when @@ -239,45 +269,10 @@ const ( // ScheduledJobStatus represents the current state of a Job. type ScheduledJobStatus struct { // Active holds pointers to currently running jobs. + // +optional Active []v1.ObjectReference `json:"active,omitempty" protobuf:"bytes,1,rep,name=active"` // LastScheduleTime keeps information of when was the last time the job was successfully scheduled. + // +optional LastScheduleTime *unversioned.Time `json:"lastScheduleTime,omitempty" protobuf:"bytes,4,opt,name=lastScheduleTime"` } - -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -type LabelSelector struct { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - MatchLabels map[string]string `json:"matchLabels,omitempty" protobuf:"bytes,1,rep,name=matchLabels"` - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - MatchExpressions []LabelSelectorRequirement `json:"matchExpressions,omitempty" protobuf:"bytes,2,rep,name=matchExpressions"` -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -type LabelSelectorRequirement struct { - // key is the label key that the selector applies to. - Key string `json:"key" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,1,opt,name=key"` - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - Operator LabelSelectorOperator `json:"operator" protobuf:"bytes,2,opt,name=operator,casttype=LabelSelectorOperator"` - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - Values []string `json:"values,omitempty" protobuf:"bytes,3,rep,name=values"` -} - -// A label selector operator is the set of operators that can be used in a selector requirement. -type LabelSelectorOperator string - -const ( - LabelSelectorOpIn LabelSelectorOperator = "In" - LabelSelectorOpNotIn LabelSelectorOperator = "NotIn" - LabelSelectorOpExists LabelSelectorOperator = "Exists" - LabelSelectorOpDoesNotExist LabelSelectorOperator = "DoesNotExist" -) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go index 5d965f4..4eb6092 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/types_swagger_doc_generated.go @@ -110,27 +110,6 @@ func (JobTemplateSpec) SwaggerDoc() map[string]string { return map_JobTemplateSpec } -var map_LabelSelector = map[string]string{ - "": "A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects.", - "matchLabels": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", - "matchExpressions": "matchExpressions is a list of label selector requirements. The requirements are ANDed.", -} - -func (LabelSelector) SwaggerDoc() map[string]string { - return map_LabelSelector -} - -var map_LabelSelectorRequirement = map[string]string{ - "": "A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.", - "key": "key is the label key that the selector applies to.", - "operator": "operator represents a key's relationship to a set of values. Valid operators ard In, NotIn, Exists and DoesNotExist.", - "values": "values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.", -} - -func (LabelSelectorRequirement) SwaggerDoc() map[string]string { - return map_LabelSelectorRequirement -} - var map_ScheduledJob = map[string]string{ "": "ScheduledJob represents the configuration of a single scheduled job.", "metadata": "Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata", diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.conversion.go similarity index 72% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.conversion.go index 862b292..a81391d 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.conversion.go @@ -21,12 +21,11 @@ limitations under the License. package v2alpha1 import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - batch "k8s.io/kubernetes/pkg/apis/batch" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + batch "k8s.io/client-go/pkg/apis/batch" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -51,10 +50,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { Convert_batch_JobTemplate_To_v2alpha1_JobTemplate, Convert_v2alpha1_JobTemplateSpec_To_batch_JobTemplateSpec, Convert_batch_JobTemplateSpec_To_v2alpha1_JobTemplateSpec, - Convert_v2alpha1_LabelSelector_To_unversioned_LabelSelector, - Convert_unversioned_LabelSelector_To_v2alpha1_LabelSelector, - Convert_v2alpha1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement, - Convert_unversioned_LabelSelectorRequirement_To_v2alpha1_LabelSelectorRequirement, Convert_v2alpha1_ScheduledJob_To_batch_ScheduledJob, Convert_batch_ScheduledJob_To_v2alpha1_ScheduledJob, Convert_v2alpha1_ScheduledJobList_To_batch_ScheduledJobList, @@ -67,10 +62,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v2alpha1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Scope) error { - SetDefaults_Job(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -89,9 +80,6 @@ func Convert_v2alpha1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Sco } func autoConvert_batch_Job_To_v2alpha1_Job(in *batch.Job, out *Job, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -112,12 +100,8 @@ func Convert_batch_Job_To_v2alpha1_Job(in *batch.Job, out *Job, s conversion.Sco func autoConvert_v2alpha1_JobCondition_To_batch_JobCondition(in *JobCondition, out *batch.JobCondition, s conversion.Scope) error { out.Type = batch.JobConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -130,12 +114,8 @@ func Convert_v2alpha1_JobCondition_To_batch_JobCondition(in *JobCondition, out * func autoConvert_batch_JobCondition_To_v2alpha1_JobCondition(in *batch.JobCondition, out *JobCondition, s conversion.Scope) error { out.Type = JobConditionType(in.Type) out.Status = v1.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -146,12 +126,7 @@ func Convert_batch_JobCondition_To_v2alpha1_JobCondition(in *batch.JobCondition, } func autoConvert_v2alpha1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]batch.Job, len(*in)) @@ -171,12 +146,7 @@ func Convert_v2alpha1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, } func autoConvert_batch_JobList_To_v2alpha1_JobList(in *batch.JobList, out *JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Job, len(*in)) @@ -199,15 +169,7 @@ func autoConvert_v2alpha1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSp out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v2alpha1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector out.ManualSelector = in.ManualSelector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -219,15 +181,7 @@ func autoConvert_batch_JobSpec_To_v2alpha1_JobSpec(in *batch.JobSpec, out *JobSp out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v2alpha1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector out.ManualSelector = in.ManualSelector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -284,9 +238,6 @@ func Convert_batch_JobStatus_To_v2alpha1_JobStatus(in *batch.JobStatus, out *Job } func autoConvert_v2alpha1_JobTemplate_To_batch_JobTemplate(in *JobTemplate, out *batch.JobTemplate, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -302,9 +253,6 @@ func Convert_v2alpha1_JobTemplate_To_batch_JobTemplate(in *JobTemplate, out *bat } func autoConvert_batch_JobTemplate_To_v2alpha1_JobTemplate(in *batch.JobTemplate, out *JobTemplate, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -349,73 +297,7 @@ func Convert_batch_JobTemplateSpec_To_v2alpha1_JobTemplateSpec(in *batch.JobTemp return autoConvert_batch_JobTemplateSpec_To_v2alpha1_JobTemplateSpec(in, out, s) } -func autoConvert_v2alpha1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]unversioned.LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_v2alpha1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_v2alpha1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - return autoConvert_v2alpha1_LabelSelector_To_unversioned_LabelSelector(in, out, s) -} - -func autoConvert_unversioned_LabelSelector_To_v2alpha1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_unversioned_LabelSelectorRequirement_To_v2alpha1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_unversioned_LabelSelector_To_v2alpha1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelector_To_v2alpha1_LabelSelector(in, out, s) -} - -func autoConvert_v2alpha1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = unversioned.LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_v2alpha1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_v2alpha1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in, out, s) -} - -func autoConvert_unversioned_LabelSelectorRequirement_To_v2alpha1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_unversioned_LabelSelectorRequirement_To_v2alpha1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelectorRequirement_To_v2alpha1_LabelSelectorRequirement(in, out, s) -} - func autoConvert_v2alpha1_ScheduledJob_To_batch_ScheduledJob(in *ScheduledJob, out *batch.ScheduledJob, s conversion.Scope) error { - SetDefaults_ScheduledJob(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -434,9 +316,6 @@ func Convert_v2alpha1_ScheduledJob_To_batch_ScheduledJob(in *ScheduledJob, out * } func autoConvert_batch_ScheduledJob_To_v2alpha1_ScheduledJob(in *batch.ScheduledJob, out *ScheduledJob, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -455,12 +334,7 @@ func Convert_batch_ScheduledJob_To_v2alpha1_ScheduledJob(in *batch.ScheduledJob, } func autoConvert_v2alpha1_ScheduledJobList_To_batch_ScheduledJobList(in *ScheduledJobList, out *batch.ScheduledJobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]batch.ScheduledJob, len(*in)) @@ -480,12 +354,7 @@ func Convert_v2alpha1_ScheduledJobList_To_batch_ScheduledJobList(in *ScheduledJo } func autoConvert_batch_ScheduledJobList_To_v2alpha1_ScheduledJobList(in *batch.ScheduledJobList, out *ScheduledJobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ScheduledJob, len(*in)) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go index 2980bac..a6cee35 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v2alpha1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + unversioned "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) @@ -43,8 +43,6 @@ func RegisterDeepCopies(scheme *runtime.Scheme) error { conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_JobStatus, InType: reflect.TypeOf(&JobStatus{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_JobTemplate, InType: reflect.TypeOf(&JobTemplate{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_JobTemplateSpec, InType: reflect.TypeOf(&JobTemplateSpec{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_LabelSelector, InType: reflect.TypeOf(&LabelSelector{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_LabelSelectorRequirement, InType: reflect.TypeOf(&LabelSelectorRequirement{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_ScheduledJob, InType: reflect.TypeOf(&ScheduledJob{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_ScheduledJobList, InType: reflect.TypeOf(&ScheduledJobList{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v2alpha1_ScheduledJobSpec, InType: reflect.TypeOf(&ScheduledJobSpec{})}, @@ -132,8 +130,8 @@ func DeepCopy_v2alpha1_JobSpec(in interface{}, out interface{}, c *conversion.Cl } if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v2alpha1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -218,51 +216,6 @@ func DeepCopy_v2alpha1_JobTemplateSpec(in interface{}, out interface{}, c *conve } } -func DeepCopy_v2alpha1_LabelSelector(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelector) - out := out.(*LabelSelector) - if in.MatchLabels != nil { - in, out := &in.MatchLabels, &out.MatchLabels - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.MatchLabels = nil - } - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := DeepCopy_v2alpha1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], c); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil - } -} - -func DeepCopy_v2alpha1_LabelSelectorRequirement(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelectorRequirement) - out := out.(*LabelSelectorRequirement) - out.Key = in.Key - out.Operator = in.Operator - if in.Values != nil { - in, out := &in.Values, &out.Values - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.Values = nil - } - return nil - } -} - func DeepCopy_v2alpha1_ScheduledJob(in interface{}, out interface{}, c *conversion.Cloner) error { { in := in.(*ScheduledJob) diff --git a/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.defaults.go new file mode 100644 index 0000000..b024dd9 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/batch/v2alpha1/zz_generated.defaults.go @@ -0,0 +1,402 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v2alpha1 + +import ( + v1 "k8s.io/client-go/pkg/api/v1" + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&Job{}, func(obj interface{}) { SetObjectDefaults_Job(obj.(*Job)) }) + scheme.AddTypeDefaultingFunc(&JobList{}, func(obj interface{}) { SetObjectDefaults_JobList(obj.(*JobList)) }) + scheme.AddTypeDefaultingFunc(&JobTemplate{}, func(obj interface{}) { SetObjectDefaults_JobTemplate(obj.(*JobTemplate)) }) + scheme.AddTypeDefaultingFunc(&ScheduledJob{}, func(obj interface{}) { SetObjectDefaults_ScheduledJob(obj.(*ScheduledJob)) }) + scheme.AddTypeDefaultingFunc(&ScheduledJobList{}, func(obj interface{}) { SetObjectDefaults_ScheduledJobList(obj.(*ScheduledJobList)) }) + return nil +} + +func SetObjectDefaults_Job(in *Job) { + SetDefaults_Job(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_JobList(in *JobList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Job(a) + } +} + +func SetObjectDefaults_JobTemplate(in *JobTemplate) { + v1.SetDefaults_PodSpec(&in.Template.Spec.Template.Spec) + for i := range in.Template.Spec.Template.Spec.Volumes { + a := &in.Template.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Template.Spec.Template.Spec.InitContainers { + a := &in.Template.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Template.Spec.Template.Spec.Containers { + a := &in.Template.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_ScheduledJob(in *ScheduledJob) { + SetDefaults_ScheduledJob(in) + v1.SetDefaults_PodSpec(&in.Spec.JobTemplate.Spec.Template.Spec) + for i := range in.Spec.JobTemplate.Spec.Template.Spec.Volumes { + a := &in.Spec.JobTemplate.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.JobTemplate.Spec.Template.Spec.InitContainers { + a := &in.Spec.JobTemplate.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.JobTemplate.Spec.Template.Spec.Containers { + a := &in.Spec.JobTemplate.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_ScheduledJobList(in *ScheduledJobList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ScheduledJob(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/batch/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/batch/zz_generated.deepcopy.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/batch/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/batch/zz_generated.deepcopy.go index 7a83464..2014b88 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/batch/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/batch/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package batch import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/doc.go b/vendor/k8s.io/client-go/pkg/apis/certificates/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/doc.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/install/install.go b/vendor/k8s.io/client-go/pkg/apis/certificates/install/install.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/install/install.go index 0210b0d..6abe665 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/certificates" - "k8s.io/kubernetes/pkg/apis/certificates/v1alpha1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/certificates" + "k8s.io/client-go/pkg/apis/certificates/v1alpha1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: certificates.GroupName, VersionPreferenceOrder: []string{v1alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/certificates", + ImportPrefix: "k8s.io/client-go/pkg/apis/certificates", RootScopedKinds: sets.NewString("CertificateSigningRequest"), AddInternalObjectsToScheme: certificates.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/register.go b/vendor/k8s.io/client-go/pkg/apis/certificates/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/register.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/register.go index 8840441..e3f4596 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/register.go @@ -17,9 +17,9 @@ limitations under the License. package certificates import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) var ( diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/certificates/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/types.generated.go index 6f5c513..5c17d30 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg2_api "k8s.io/client-go/pkg/api" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/types.go b/vendor/k8s.io/client-go/pkg/apis/certificates/types.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/types.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/types.go index 562725f..4fb5b01 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/types.go @@ -17,8 +17,8 @@ limitations under the License. package certificates import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // +genclient=true @@ -27,12 +27,15 @@ import ( // Describes a certificate signing request type CertificateSigningRequest struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // The certificate request itself and any additional information. + // +optional Spec CertificateSigningRequestSpec `json:"spec,omitempty"` // Derived information about the request. + // +optional Status CertificateSigningRequestStatus `json:"status,omitempty"` } @@ -45,16 +48,21 @@ type CertificateSigningRequestSpec struct { // Information about the requesting user (if relevant) // See user.Info interface for details - Username string `json:"username,omitempty"` - UID string `json:"uid,omitempty"` - Groups []string `json:"groups,omitempty"` + // +optional + Username string `json:"username,omitempty"` + // +optional + UID string `json:"uid,omitempty"` + // +optional + Groups []string `json:"groups,omitempty"` } type CertificateSigningRequestStatus struct { // Conditions applied to the request, such as approval or denial. + // +optional Conditions []CertificateSigningRequestCondition `json:"conditions,omitempty"` // If request was approved, the controller will place the issued certificate here. + // +optional Certificate []byte `json:"certificate,omitempty"` } @@ -70,16 +78,21 @@ type CertificateSigningRequestCondition struct { // request approval state, currently Approved or Denied. Type RequestConditionType `json:"type"` // brief reason for the request state + // +optional Reason string `json:"reason,omitempty"` // human readable message with details about the request state + // +optional Message string `json:"message,omitempty"` // timestamp for the last update to this condition + // +optional LastUpdateTime unversioned.Time `json:"lastUpdateTime,omitempty"` } type CertificateSigningRequestList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` + // +optional Items []CertificateSigningRequest `json:"items,omitempty"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/conversion.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/conversion.go index 5275811..e8e4a29 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/conversion.go @@ -19,8 +19,8 @@ package v1alpha1 import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/runtime" ) func addConversionFuncs(scheme *runtime.Scheme) error { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/doc.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/doc.go index 08eb645..0e0b1ce 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/doc.go @@ -17,6 +17,7 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/certificates // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta // +groupName=certificates.k8s.io package v1alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.pb.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.pb.go index 866edbe..9d8377a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.pb.go @@ -82,11 +82,11 @@ func (*CertificateSigningRequestStatus) Descriptor() ([]byte, []int) { } func init() { - proto.RegisterType((*CertificateSigningRequest)(nil), "k8s.io.kubernetes.pkg.apis.certificates.v1alpha1.CertificateSigningRequest") - proto.RegisterType((*CertificateSigningRequestCondition)(nil), "k8s.io.kubernetes.pkg.apis.certificates.v1alpha1.CertificateSigningRequestCondition") - proto.RegisterType((*CertificateSigningRequestList)(nil), "k8s.io.kubernetes.pkg.apis.certificates.v1alpha1.CertificateSigningRequestList") - proto.RegisterType((*CertificateSigningRequestSpec)(nil), "k8s.io.kubernetes.pkg.apis.certificates.v1alpha1.CertificateSigningRequestSpec") - proto.RegisterType((*CertificateSigningRequestStatus)(nil), "k8s.io.kubernetes.pkg.apis.certificates.v1alpha1.CertificateSigningRequestStatus") + proto.RegisterType((*CertificateSigningRequest)(nil), "k8s.io.client-go.pkg.apis.certificates.v1alpha1.CertificateSigningRequest") + proto.RegisterType((*CertificateSigningRequestCondition)(nil), "k8s.io.client-go.pkg.apis.certificates.v1alpha1.CertificateSigningRequestCondition") + proto.RegisterType((*CertificateSigningRequestList)(nil), "k8s.io.client-go.pkg.apis.certificates.v1alpha1.CertificateSigningRequestList") + proto.RegisterType((*CertificateSigningRequestSpec)(nil), "k8s.io.client-go.pkg.apis.certificates.v1alpha1.CertificateSigningRequestSpec") + proto.RegisterType((*CertificateSigningRequestStatus)(nil), "k8s.io.client-go.pkg.apis.certificates.v1alpha1.CertificateSigningRequestStatus") } func (m *CertificateSigningRequest) Marshal() (data []byte, err error) { size := m.Size() @@ -1277,48 +1277,49 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 681 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xac, 0x54, 0x4f, 0x4f, 0x13, 0x4f, - 0x18, 0xa6, 0xb4, 0x94, 0x32, 0xe5, 0x07, 0xbf, 0x4c, 0x8c, 0xa9, 0x4d, 0xa0, 0x66, 0xa3, 0x06, - 0x15, 0x66, 0x2d, 0x89, 0x09, 0x47, 0xb3, 0x98, 0x18, 0x22, 0x84, 0x38, 0x40, 0x62, 0x4c, 0x3c, - 0x6c, 0xb7, 0xc3, 0x32, 0x96, 0xee, 0x2e, 0xf3, 0x87, 0x84, 0x9b, 0x47, 0x8f, 0x7e, 0x02, 0xbf, - 0x86, 0x5f, 0x81, 0x23, 0x47, 0x4f, 0xa8, 0xf0, 0x05, 0x3c, 0x7b, 0x72, 0x66, 0x76, 0xb6, 0x5d, - 0x5b, 0x16, 0x35, 0xe1, 0x30, 0x49, 0xe7, 0x99, 0xf7, 0x7d, 0xde, 0xf7, 0x7d, 0xde, 0x67, 0x0b, - 0x9e, 0xf5, 0xd6, 0x38, 0xa2, 0xb1, 0xdb, 0x93, 0x1d, 0xc2, 0x22, 0x22, 0x08, 0x77, 0x93, 0x5e, - 0xe8, 0xfa, 0x09, 0xe5, 0x6e, 0x40, 0x98, 0xa0, 0xfb, 0x34, 0xf0, 0x35, 0x7a, 0xdc, 0xf6, 0x0f, - 0x93, 0x03, 0xbf, 0xed, 0x86, 0x24, 0x22, 0x4c, 0x41, 0x5d, 0x94, 0xb0, 0x58, 0xc4, 0xf0, 0x49, - 0xca, 0x80, 0x86, 0x0c, 0x48, 0x31, 0x20, 0xcd, 0x80, 0xf2, 0x0c, 0x28, 0x63, 0x68, 0xae, 0x84, - 0x54, 0x1c, 0xc8, 0x0e, 0x0a, 0xe2, 0xbe, 0x1b, 0xc6, 0x61, 0xec, 0x1a, 0xa2, 0x8e, 0xdc, 0x37, - 0x37, 0x73, 0x31, 0xbf, 0xd2, 0x02, 0xcd, 0xd5, 0xc2, 0x16, 0x5d, 0x46, 0x78, 0x2c, 0x59, 0x40, - 0x46, 0x9b, 0x6a, 0x3e, 0x2d, 0xce, 0x91, 0xd1, 0x31, 0x61, 0x9c, 0xc6, 0x11, 0xe9, 0x8e, 0xa5, - 0x2d, 0x17, 0xa7, 0x1d, 0x8f, 0x4d, 0xde, 0x5c, 0xb9, 0x3a, 0x9a, 0xc9, 0x48, 0xd0, 0xfe, 0x78, - 0x4f, 0xed, 0xab, 0xc3, 0xa5, 0xa0, 0x87, 0x2e, 0x8d, 0x04, 0x17, 0x6c, 0x34, 0xc5, 0xb9, 0x9c, - 0x04, 0x77, 0xd6, 0x87, 0x1a, 0xee, 0xd0, 0x30, 0xa2, 0x51, 0x88, 0xc9, 0x91, 0x24, 0x5c, 0xc0, - 0xd7, 0xa0, 0xd6, 0x27, 0xc2, 0xef, 0xfa, 0xc2, 0x6f, 0x94, 0xee, 0x96, 0x96, 0xea, 0xab, 0x4b, - 0xa8, 0x70, 0x19, 0x4a, 0x7e, 0xb4, 0xdd, 0x79, 0x47, 0x02, 0xb1, 0xa5, 0x72, 0x3c, 0x78, 0x7a, - 0xde, 0x9a, 0xb8, 0x38, 0x6f, 0x81, 0x21, 0x86, 0x07, 0x6c, 0xf0, 0x08, 0x54, 0x78, 0x42, 0x82, - 0xc6, 0xa4, 0x61, 0xdd, 0x46, 0xff, 0xba, 0x62, 0x54, 0xd8, 0xf4, 0x8e, 0xa2, 0xf5, 0x66, 0x6d, - 0xf1, 0x8a, 0xbe, 0x61, 0x53, 0x0a, 0x9e, 0x80, 0x2a, 0x17, 0xbe, 0x90, 0xbc, 0x51, 0x36, 0x45, - 0x5f, 0xdd, 0x64, 0x51, 0x43, 0xec, 0xcd, 0xd9, 0xb2, 0xd5, 0xf4, 0x8e, 0x6d, 0x41, 0xe7, 0xd3, - 0x24, 0x70, 0x0a, 0x73, 0xd7, 0xe3, 0xa8, 0x4b, 0x85, 0xb2, 0x0b, 0x5c, 0x03, 0x15, 0x71, 0x92, - 0x10, 0x23, 0xf5, 0x8c, 0x77, 0x2f, 0x9b, 0x61, 0x57, 0x61, 0x3f, 0xcf, 0x5b, 0xb7, 0x46, 0xe3, - 0x35, 0x8e, 0x4d, 0x06, 0x7c, 0x00, 0xaa, 0x8c, 0xf8, 0x3c, 0x8e, 0x8c, 0xa0, 0x33, 0xc3, 0x46, - 0xb0, 0x41, 0xb1, 0x7d, 0x85, 0x0f, 0xc1, 0x74, 0x9f, 0x70, 0xee, 0x87, 0xc4, 0x88, 0x30, 0xe3, - 0xcd, 0xdb, 0xc0, 0xe9, 0xad, 0x14, 0xc6, 0xd9, 0x3b, 0xec, 0x81, 0xb9, 0x43, 0x9f, 0x8b, 0xbd, - 0x44, 0xed, 0x8b, 0xec, 0x2a, 0xbb, 0x35, 0x2a, 0x46, 0xb6, 0xc7, 0xd7, 0x38, 0x20, 0xe7, 0x7c, - 0xa4, 0x53, 0xbc, 0xdb, 0x96, 0x7e, 0x6e, 0xf3, 0x37, 0x2a, 0x3c, 0x42, 0xed, 0xfc, 0x28, 0x81, - 0x85, 0x42, 0x81, 0x36, 0xa9, 0xb2, 0xe2, 0xdb, 0x31, 0x2b, 0xba, 0x7f, 0xd9, 0x88, 0x4e, 0x37, - 0x8e, 0xfc, 0xdf, 0x36, 0x53, 0xcb, 0x90, 0x9c, 0x1f, 0x13, 0x30, 0x45, 0x05, 0xe9, 0x73, 0xa5, - 0x5f, 0x59, 0x71, 0xbf, 0xbc, 0x41, 0x6f, 0x78, 0xff, 0xd9, 0xba, 0x53, 0x1b, 0xba, 0x02, 0x4e, - 0x0b, 0x39, 0x9f, 0xaf, 0x1b, 0x59, 0xdb, 0x16, 0xde, 0x07, 0xd3, 0x2c, 0xbd, 0x9a, 0x89, 0x67, - 0xbd, 0xba, 0x5e, 0x94, 0x8d, 0xc0, 0xd9, 0x1b, 0x5c, 0x06, 0x35, 0xc9, 0x55, 0x93, 0xbe, 0x5a, - 0x51, 0xba, 0xfd, 0xc1, 0xa0, 0x7b, 0x16, 0xc7, 0x83, 0x08, 0xb8, 0x00, 0xca, 0x92, 0x76, 0xed, - 0xf6, 0xeb, 0x36, 0xb0, 0xbc, 0xb7, 0xf1, 0x1c, 0x6b, 0x1c, 0x3a, 0xa0, 0x1a, 0xb2, 0x58, 0x26, - 0x5c, 0x6d, 0xbb, 0xac, 0x22, 0x80, 0x36, 0xd1, 0x0b, 0x83, 0x60, 0xfb, 0xe2, 0x7c, 0x2d, 0x81, - 0xd6, 0x1f, 0xbe, 0x04, 0xf8, 0xa1, 0x04, 0x40, 0x90, 0x19, 0x95, 0xab, 0xfe, 0xb5, 0xaa, 0xbb, - 0x37, 0xa8, 0xea, 0xe0, 0x2b, 0x18, 0xfe, 0xd1, 0x0c, 0x20, 0x8e, 0x73, 0xb5, 0x61, 0x1b, 0xd4, - 0x73, 0xdc, 0x46, 0xa2, 0x59, 0x6f, 0x5e, 0x25, 0xd4, 0x73, 0xe4, 0x38, 0x1f, 0xe3, 0x3d, 0x3a, - 0xfd, 0xbe, 0x38, 0x71, 0xa6, 0xce, 0x17, 0x75, 0xde, 0x5f, 0x2c, 0x96, 0x4e, 0xd5, 0x39, 0x53, - 0xe7, 0x9b, 0x3a, 0x1f, 0x2f, 0x17, 0x27, 0xde, 0xd4, 0xb2, 0x0e, 0x7f, 0x05, 0x00, 0x00, 0xff, - 0xff, 0x29, 0x0b, 0xef, 0x6d, 0xe0, 0x06, 0x00, 0x00, + // 692 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xac, 0x54, 0xcd, 0x6e, 0xd3, 0x4a, + 0x14, 0x8e, 0x93, 0x34, 0x4d, 0x26, 0xbd, 0xed, 0xd5, 0xe8, 0xea, 0x2a, 0x37, 0x52, 0x9d, 0x2a, + 0xba, 0xa0, 0x00, 0xed, 0x98, 0x54, 0x42, 0xea, 0x12, 0xb9, 0x48, 0xa8, 0xa2, 0x55, 0xc5, 0xb4, + 0x95, 0x10, 0x12, 0x8b, 0x89, 0x73, 0xea, 0x0e, 0x69, 0x6c, 0xd7, 0x33, 0x8e, 0xd4, 0x1d, 0x4b, + 0x96, 0x3c, 0x01, 0xaf, 0xc1, 0x2b, 0x74, 0xd9, 0x25, 0xab, 0x40, 0xd3, 0x17, 0x60, 0xcd, 0x0a, + 0x79, 0x32, 0x4e, 0x4c, 0x52, 0x17, 0x90, 0xba, 0xcb, 0xf9, 0xe6, 0x9c, 0xef, 0x3b, 0x3f, 0x9f, + 0x83, 0x9e, 0xf6, 0xb6, 0x04, 0xe1, 0xbe, 0xd5, 0x8b, 0x3a, 0x10, 0x7a, 0x20, 0x41, 0x58, 0x41, + 0xcf, 0xb5, 0x58, 0xc0, 0x85, 0xe5, 0x40, 0x28, 0xf9, 0x31, 0x77, 0x58, 0x8c, 0x0e, 0xda, 0xec, + 0x34, 0x38, 0x61, 0x6d, 0xcb, 0x05, 0x0f, 0x42, 0x26, 0xa1, 0x4b, 0x82, 0xd0, 0x97, 0x3e, 0x7e, + 0x3c, 0x66, 0x20, 0x53, 0x06, 0x12, 0xf4, 0x5c, 0x12, 0x33, 0x90, 0x34, 0x03, 0x49, 0x18, 0xea, + 0x1b, 0x2e, 0x97, 0x27, 0x51, 0x87, 0x38, 0x7e, 0xdf, 0x72, 0x7d, 0xd7, 0xb7, 0x14, 0x51, 0x27, + 0x3a, 0x56, 0x91, 0x0a, 0xd4, 0xaf, 0xb1, 0x40, 0x7d, 0x33, 0xb3, 0x45, 0x2b, 0x04, 0xe1, 0x47, + 0xa1, 0x03, 0xb3, 0x4d, 0xd5, 0x9f, 0x64, 0xd7, 0x44, 0xde, 0x00, 0x42, 0xc1, 0x7d, 0x0f, 0xba, + 0x73, 0x65, 0xeb, 0xd9, 0x65, 0x83, 0xb9, 0xc9, 0xeb, 0x1b, 0x37, 0x67, 0x87, 0x91, 0x27, 0x79, + 0x7f, 0xbe, 0xa7, 0xf6, 0xcd, 0xe9, 0x91, 0xe4, 0xa7, 0x16, 0xf7, 0xa4, 0x90, 0xe1, 0x6c, 0x49, + 0xf3, 0x3a, 0x8f, 0xfe, 0xdb, 0x9e, 0xee, 0xf0, 0x80, 0xbb, 0x1e, 0xf7, 0x5c, 0x0a, 0x67, 0x11, + 0x08, 0x89, 0x5f, 0xa1, 0x72, 0x1f, 0x24, 0xeb, 0x32, 0xc9, 0x6a, 0xc6, 0x9a, 0xd1, 0xaa, 0x6e, + 0xb6, 0x48, 0xe6, 0x31, 0xc8, 0xa0, 0x4d, 0xf6, 0x3b, 0x6f, 0xc1, 0x91, 0x7b, 0x20, 0x99, 0x8d, + 0x2f, 0x86, 0x8d, 0xdc, 0x68, 0xd8, 0x40, 0x53, 0x8c, 0x4e, 0xd8, 0xf0, 0x19, 0x2a, 0x8a, 0x00, + 0x9c, 0x5a, 0x5e, 0xb1, 0xee, 0x93, 0x3f, 0x3d, 0x31, 0xc9, 0x6c, 0xfa, 0x20, 0x00, 0xc7, 0x5e, + 0xd2, 0xe2, 0xc5, 0x38, 0xa2, 0x4a, 0x0a, 0x9f, 0xa3, 0x92, 0x90, 0x4c, 0x46, 0xa2, 0x56, 0x50, + 0xa2, 0x2f, 0xef, 0x52, 0x54, 0x11, 0xdb, 0xcb, 0x5a, 0xb6, 0x34, 0x8e, 0xa9, 0x16, 0x6c, 0x7e, + 0xcc, 0xa3, 0x66, 0x66, 0xed, 0xb6, 0xef, 0x75, 0xb9, 0xe4, 0xbe, 0x87, 0xb7, 0x50, 0x51, 0x9e, + 0x07, 0xa0, 0x56, 0x5d, 0xb1, 0xff, 0x4f, 0x66, 0x38, 0x3c, 0x0f, 0xe0, 0xfb, 0xb0, 0xf1, 0xcf, + 0x6c, 0x7e, 0x8c, 0x53, 0x55, 0x81, 0xef, 0xa3, 0x52, 0x08, 0x4c, 0xf8, 0x9e, 0x5a, 0x68, 0x65, + 0xda, 0x08, 0x55, 0x28, 0xd5, 0xaf, 0xf8, 0x01, 0x5a, 0xec, 0x83, 0x10, 0xcc, 0x05, 0xb5, 0x84, + 0x8a, 0xbd, 0xa2, 0x13, 0x17, 0xf7, 0xc6, 0x30, 0x4d, 0xde, 0x71, 0x0f, 0x2d, 0x9f, 0x32, 0x21, + 0x8f, 0x82, 0x2e, 0x93, 0x70, 0xc8, 0xfb, 0x50, 0x2b, 0xaa, 0xb5, 0x3d, 0xba, 0xc5, 0x01, 0x29, + 0xe7, 0x93, 0xb8, 0xc4, 0xfe, 0x57, 0xd3, 0x2f, 0xef, 0xfe, 0x44, 0x45, 0x67, 0xa8, 0x9b, 0xdf, + 0x0c, 0xb4, 0x9a, 0xb9, 0xa0, 0x5d, 0x2e, 0x24, 0x7e, 0x33, 0x67, 0x45, 0xeb, 0x37, 0x1b, 0x89, + 0xcb, 0x95, 0x23, 0xff, 0xd6, 0xcd, 0x94, 0x13, 0x24, 0xe5, 0xc7, 0x00, 0x2d, 0x70, 0x09, 0x7d, + 0x51, 0xcb, 0xaf, 0x15, 0x5a, 0xd5, 0xcd, 0x17, 0x77, 0xe8, 0x0d, 0xfb, 0x2f, 0xad, 0xbb, 0xb0, + 0x13, 0x2b, 0xd0, 0xb1, 0x50, 0xf3, 0xd3, 0x6d, 0x23, 0xc7, 0xb6, 0xc5, 0xf7, 0xd0, 0x62, 0x38, + 0x0e, 0xd5, 0xc4, 0x4b, 0x76, 0x35, 0x3e, 0x94, 0xce, 0xa0, 0xc9, 0x1b, 0x5e, 0x47, 0xe5, 0x48, + 0x40, 0xe8, 0xb1, 0x3e, 0xe8, 0xeb, 0x4f, 0x06, 0x3d, 0xd2, 0x38, 0x9d, 0x64, 0xe0, 0x55, 0x54, + 0x88, 0x78, 0x57, 0x5f, 0xbf, 0xaa, 0x13, 0x0b, 0x47, 0x3b, 0xcf, 0x68, 0x8c, 0xe3, 0x26, 0x2a, + 0xb9, 0xa1, 0x1f, 0x05, 0xa2, 0x56, 0x5c, 0x2b, 0xb4, 0x2a, 0x36, 0x8a, 0x4d, 0xf4, 0x5c, 0x21, + 0x54, 0xbf, 0x34, 0xbf, 0x18, 0xa8, 0xf1, 0x8b, 0x2f, 0x01, 0xbf, 0x37, 0x10, 0x72, 0x12, 0xa3, + 0x8a, 0x9a, 0xa1, 0xb6, 0x7a, 0x78, 0x87, 0x5b, 0x9d, 0x7c, 0x05, 0xd3, 0x3f, 0x9a, 0x09, 0x24, + 0x68, 0x4a, 0x1b, 0xb7, 0x51, 0x35, 0xc5, 0xad, 0x56, 0xb4, 0x64, 0xaf, 0x8c, 0x86, 0x8d, 0x6a, + 0x8a, 0x9c, 0xa6, 0x73, 0xec, 0x87, 0x17, 0x57, 0x66, 0xee, 0xf2, 0xca, 0xcc, 0x7d, 0xbe, 0x32, + 0x73, 0xef, 0x46, 0xa6, 0x71, 0x31, 0x32, 0x8d, 0xcb, 0x91, 0x69, 0x7c, 0x1d, 0x99, 0xc6, 0x87, + 0x6b, 0x33, 0xf7, 0xba, 0x9c, 0x74, 0xf8, 0x23, 0x00, 0x00, 0xff, 0xff, 0x29, 0x0b, 0xef, 0x6d, + 0xe0, 0x06, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.proto similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.proto index 5638d1d..5c576a2 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/generated.proto @@ -32,12 +32,15 @@ option go_package = "v1alpha1"; // Describes a certificate signing request message CertificateSigningRequest { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // The certificate request itself and any additional information. + // +optional optional CertificateSigningRequestSpec spec = 2; // Derived information about the request. + // +optional optional CertificateSigningRequestStatus status = 3; } @@ -46,16 +49,20 @@ message CertificateSigningRequestCondition { optional string type = 1; // brief reason for the request state + // +optional optional string reason = 2; // human readable message with details about the request state + // +optional optional string message = 3; // timestamp for the last update to this condition + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastUpdateTime = 4; } message CertificateSigningRequestList { + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; repeated CertificateSigningRequest items = 2; @@ -70,18 +77,23 @@ message CertificateSigningRequestSpec { // Information about the requesting user (if relevant) // See user.Info interface for details + // +optional optional string username = 2; + // +optional optional string uid = 3; + // +optional repeated string groups = 4; } message CertificateSigningRequestStatus { // Conditions applied to the request, such as approval or denial. + // +optional repeated CertificateSigningRequestCondition conditions = 1; // If request was approved, the controller will place the issued certificate here. + // +optional optional bytes certificate = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/register.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/register.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/register.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/register.go index cc6cd3c..d5047c7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.generated.go index 5c6832b..78f2d60 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.go index 859053d..fb1a4d3 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types.go @@ -17,8 +17,8 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true @@ -27,12 +27,15 @@ import ( // Describes a certificate signing request type CertificateSigningRequest struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // The certificate request itself and any additional information. + // +optional Spec CertificateSigningRequestSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Derived information about the request. + // +optional Status CertificateSigningRequestStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -45,16 +48,21 @@ type CertificateSigningRequestSpec struct { // Information about the requesting user (if relevant) // See user.Info interface for details - Username string `json:"username,omitempty" protobuf:"bytes,2,opt,name=username"` - UID string `json:"uid,omitempty" protobuf:"bytes,3,opt,name=uid"` - Groups []string `json:"groups,omitempty" protobuf:"bytes,4,rep,name=groups"` + // +optional + Username string `json:"username,omitempty" protobuf:"bytes,2,opt,name=username"` + // +optional + UID string `json:"uid,omitempty" protobuf:"bytes,3,opt,name=uid"` + // +optional + Groups []string `json:"groups,omitempty" protobuf:"bytes,4,rep,name=groups"` } type CertificateSigningRequestStatus struct { // Conditions applied to the request, such as approval or denial. + // +optional Conditions []CertificateSigningRequestCondition `json:"conditions,omitempty" protobuf:"bytes,1,rep,name=conditions"` // If request was approved, the controller will place the issued certificate here. + // +optional Certificate []byte `json:"certificate,omitempty" protobuf:"bytes,2,opt,name=certificate"` } @@ -70,15 +78,19 @@ type CertificateSigningRequestCondition struct { // request approval state, currently Approved or Denied. Type RequestConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=RequestConditionType"` // brief reason for the request state + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,2,opt,name=reason"` // human readable message with details about the request state + // +optional Message string `json:"message,omitempty" protobuf:"bytes,3,opt,name=message"` // timestamp for the last update to this condition + // +optional LastUpdateTime unversioned.Time `json:"lastUpdateTime,omitempty" protobuf:"bytes,4,opt,name=lastUpdateTime"` } type CertificateSigningRequestList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` Items []CertificateSigningRequest `json:"items" protobuf:"bytes,2,rep,name=items"` diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go similarity index 89% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go index 76c51d5..5d6574d 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1alpha1 import ( - api "k8s.io/kubernetes/pkg/api" - certificates "k8s.io/kubernetes/pkg/apis/certificates" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + certificates "k8s.io/client-go/pkg/apis/certificates" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -49,9 +48,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1alpha1_CertificateSigningRequest_To_certificates_CertificateSigningRequest(in *CertificateSigningRequest, out *certificates.CertificateSigningRequest, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -70,9 +66,6 @@ func Convert_v1alpha1_CertificateSigningRequest_To_certificates_CertificateSigni } func autoConvert_certificates_CertificateSigningRequest_To_v1alpha1_CertificateSigningRequest(in *certificates.CertificateSigningRequest, out *CertificateSigningRequest, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -94,9 +87,7 @@ func autoConvert_v1alpha1_CertificateSigningRequestCondition_To_certificates_Cer out.Type = certificates.RequestConditionType(in.Type) out.Reason = in.Reason out.Message = in.Message - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastUpdateTime, &out.LastUpdateTime, s); err != nil { - return err - } + out.LastUpdateTime = in.LastUpdateTime return nil } @@ -108,9 +99,7 @@ func autoConvert_certificates_CertificateSigningRequestCondition_To_v1alpha1_Cer out.Type = RequestConditionType(in.Type) out.Reason = in.Reason out.Message = in.Message - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastUpdateTime, &out.LastUpdateTime, s); err != nil { - return err - } + out.LastUpdateTime = in.LastUpdateTime return nil } @@ -119,12 +108,7 @@ func Convert_certificates_CertificateSigningRequestCondition_To_v1alpha1_Certifi } func autoConvert_v1alpha1_CertificateSigningRequestList_To_certificates_CertificateSigningRequestList(in *CertificateSigningRequestList, out *certificates.CertificateSigningRequestList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]certificates.CertificateSigningRequest, len(*in)) @@ -144,12 +128,7 @@ func Convert_v1alpha1_CertificateSigningRequestList_To_certificates_CertificateS } func autoConvert_certificates_CertificateSigningRequestList_To_v1alpha1_CertificateSigningRequestList(in *certificates.CertificateSigningRequestList, out *CertificateSigningRequestList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]CertificateSigningRequest, len(*in)) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go index ce2e169..f6991df 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/v1alpha1/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package v1alpha1 import ( - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/certificates/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/certificates/zz_generated.deepcopy.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apis/certificates/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/certificates/zz_generated.deepcopy.go index 764271b..6b4580c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/certificates/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/certificates/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package certificates import ( - api "k8s.io/kubernetes/pkg/api" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/doc.go b/vendor/k8s.io/client-go/pkg/apis/extensions/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/doc.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/helpers.go b/vendor/k8s.io/client-go/pkg/apis/extensions/helpers.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/helpers.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/helpers.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/install/install.go b/vendor/k8s.io/client-go/pkg/apis/extensions/install/install.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/install/install.go index 7381d7c..f774a2b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/apis/extensions/v1beta1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/extensions" + "k8s.io/client-go/pkg/apis/extensions/v1beta1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: extensions.GroupName, VersionPreferenceOrder: []string{v1beta1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/extensions", + ImportPrefix: "k8s.io/client-go/pkg/apis/extensions", RootScopedKinds: sets.NewString("PodSecurityPolicy", "ThirdPartyResource"), AddInternalObjectsToScheme: extensions.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/register.go b/vendor/k8s.io/client-go/pkg/apis/extensions/register.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/register.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/register.go index 31fc20a..074a7f7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/register.go @@ -17,11 +17,11 @@ limitations under the License. package extensions import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/apis/autoscaling" + "k8s.io/client-go/pkg/apis/batch" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/extensions/types.generated.go similarity index 66% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/types.generated.go index e84185b..7f5ab23 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg2_api "k8s.io/client-go/pkg/api" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -3440,7 +3440,7 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { } else { yysep279 := !z.EncBinary() yy2arr279 := z.EncBasicHandle().StructToArray - var yyq279 [8]bool + var yyq279 [9]bool _, _, _ = yysep279, yyq279, yy2arr279 const yyr279 bool = false yyq279[0] = x.Replicas != 0 @@ -3450,9 +3450,10 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { yyq279[5] = x.RevisionHistoryLimit != nil yyq279[6] = x.Paused != false yyq279[7] = x.RollbackTo != nil + yyq279[8] = x.ProgressDeadlineSeconds != nil var yynn279 int if yyr279 || yy2arr279 { - r.EncodeArrayStart(8) + r.EncodeArrayStart(9) } else { yynn279 = 1 for _, b := range yyq279 { @@ -3659,6 +3660,41 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } + if yyr279 || yy2arr279 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq279[8] { + if x.ProgressDeadlineSeconds == nil { + r.EncodeNil() + } else { + yy305 := *x.ProgressDeadlineSeconds + yym306 := z.EncBinary() + _ = yym306 + if false { + } else { + r.EncodeInt(int64(yy305)) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq279[8] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("progressDeadlineSeconds")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.ProgressDeadlineSeconds == nil { + r.EncodeNil() + } else { + yy307 := *x.ProgressDeadlineSeconds + yym308 := z.EncBinary() + _ = yym308 + if false { + } else { + r.EncodeInt(int64(yy307)) + } + } + } + } if yyr279 || yy2arr279 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { @@ -3672,25 +3708,25 @@ func (x *DeploymentSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym304 := z.DecBinary() - _ = yym304 + yym309 := z.DecBinary() + _ = yym309 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct305 := r.ContainerType() - if yyct305 == codecSelferValueTypeMap1234 { - yyl305 := r.ReadMapStart() - if yyl305 == 0 { + yyct310 := r.ContainerType() + if yyct310 == codecSelferValueTypeMap1234 { + yyl310 := r.ReadMapStart() + if yyl310 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl305, d) + x.codecDecodeSelfFromMap(yyl310, d) } - } else if yyct305 == codecSelferValueTypeArray1234 { - yyl305 := r.ReadArrayStart() - if yyl305 == 0 { + } else if yyct310 == codecSelferValueTypeArray1234 { + yyl310 := r.ReadArrayStart() + if yyl310 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl305, d) + x.codecDecodeSelfFromArray(yyl310, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -3702,12 +3738,12 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys306Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys306Slc - var yyhl306 bool = l >= 0 - for yyj306 := 0; ; yyj306++ { - if yyhl306 { - if yyj306 >= l { + var yys311Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys311Slc + var yyhl311 bool = l >= 0 + for yyj311 := 0; ; yyj311++ { + if yyhl311 { + if yyj311 >= l { break } } else { @@ -3716,10 +3752,10 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys306Slc = r.DecodeBytes(yys306Slc, true, true) - yys306 := string(yys306Slc) + yys311Slc = r.DecodeBytes(yys311Slc, true, true) + yys311 := string(yys311Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys306 { + switch yys311 { case "replicas": if r.TryDecodeAsNil() { x.Replicas = 0 @@ -3735,8 +3771,8 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym309 := z.DecBinary() - _ = yym309 + yym314 := z.DecBinary() + _ = yym314 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { @@ -3747,15 +3783,15 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv310 := &x.Template - yyv310.CodecDecodeSelf(d) + yyv315 := &x.Template + yyv315.CodecDecodeSelf(d) } case "strategy": if r.TryDecodeAsNil() { x.Strategy = DeploymentStrategy{} } else { - yyv311 := &x.Strategy - yyv311.CodecDecodeSelf(d) + yyv316 := &x.Strategy + yyv316.CodecDecodeSelf(d) } case "minReadySeconds": if r.TryDecodeAsNil() { @@ -3772,8 +3808,8 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RevisionHistoryLimit == nil { x.RevisionHistoryLimit = new(int32) } - yym314 := z.DecBinary() - _ = yym314 + yym319 := z.DecBinary() + _ = yym319 if false { } else { *((*int32)(x.RevisionHistoryLimit)) = int32(r.DecodeInt(32)) @@ -3796,10 +3832,26 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } x.RollbackTo.CodecDecodeSelf(d) } + case "progressDeadlineSeconds": + if r.TryDecodeAsNil() { + if x.ProgressDeadlineSeconds != nil { + x.ProgressDeadlineSeconds = nil + } + } else { + if x.ProgressDeadlineSeconds == nil { + x.ProgressDeadlineSeconds = new(int32) + } + yym323 := z.DecBinary() + _ = yym323 + if false { + } else { + *((*int32)(x.ProgressDeadlineSeconds)) = int32(r.DecodeInt(32)) + } + } default: - z.DecStructFieldNotFound(-1, yys306) - } // end switch yys306 - } // end for yyj306 + z.DecStructFieldNotFound(-1, yys311) + } // end switch yys311 + } // end for yyj311 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -3807,16 +3859,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj317 int - var yyb317 bool - var yyhl317 bool = l >= 0 - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + var yyj324 int + var yyb324 bool + var yyhl324 bool = l >= 0 + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3826,13 +3878,13 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3845,21 +3897,21 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym320 := z.DecBinary() - _ = yym320 + yym327 := z.DecBinary() + _ = yym327 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { z.DecFallback(x.Selector, false) } } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3867,16 +3919,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv321 := &x.Template - yyv321.CodecDecodeSelf(d) + yyv328 := &x.Template + yyv328.CodecDecodeSelf(d) } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3884,16 +3936,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Strategy = DeploymentStrategy{} } else { - yyv322 := &x.Strategy - yyv322.CodecDecodeSelf(d) + yyv329 := &x.Strategy + yyv329.CodecDecodeSelf(d) } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3903,13 +3955,13 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.MinReadySeconds = int32(r.DecodeInt(32)) } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3922,20 +3974,20 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.RevisionHistoryLimit == nil { x.RevisionHistoryLimit = new(int32) } - yym325 := z.DecBinary() - _ = yym325 + yym332 := z.DecBinary() + _ = yym332 if false { } else { *((*int32)(x.RevisionHistoryLimit)) = int32(r.DecodeInt(32)) } } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3945,13 +3997,13 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Paused = bool(r.DecodeBool()) } - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l } else { - yyb317 = r.CheckBreak() + yyb324 = r.CheckBreak() } - if yyb317 { + if yyb324 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -3966,18 +4018,44 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } x.RollbackTo.CodecDecodeSelf(d) } - for { - yyj317++ - if yyhl317 { - yyb317 = yyj317 > l - } else { - yyb317 = r.CheckBreak() + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l + } else { + yyb324 = r.CheckBreak() + } + if yyb324 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.ProgressDeadlineSeconds != nil { + x.ProgressDeadlineSeconds = nil } - if yyb317 { + } else { + if x.ProgressDeadlineSeconds == nil { + x.ProgressDeadlineSeconds = new(int32) + } + yym336 := z.DecBinary() + _ = yym336 + if false { + } else { + *((*int32)(x.ProgressDeadlineSeconds)) = int32(r.DecodeInt(32)) + } + } + for { + yyj324++ + if yyhl324 { + yyb324 = yyj324 > l + } else { + yyb324 = r.CheckBreak() + } + if yyb324 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj317-1, "") + z.DecStructFieldNotFound(yyj324-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -3989,37 +4067,37 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym328 := z.EncBinary() - _ = yym328 + yym337 := z.EncBinary() + _ = yym337 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep329 := !z.EncBinary() - yy2arr329 := z.EncBasicHandle().StructToArray - var yyq329 [5]bool - _, _, _ = yysep329, yyq329, yy2arr329 - const yyr329 bool = false - yyq329[0] = x.Kind != "" - yyq329[1] = x.APIVersion != "" - yyq329[3] = len(x.UpdatedAnnotations) != 0 - var yynn329 int - if yyr329 || yy2arr329 { + yysep338 := !z.EncBinary() + yy2arr338 := z.EncBasicHandle().StructToArray + var yyq338 [5]bool + _, _, _ = yysep338, yyq338, yy2arr338 + const yyr338 bool = false + yyq338[0] = x.Kind != "" + yyq338[1] = x.APIVersion != "" + yyq338[3] = len(x.UpdatedAnnotations) != 0 + var yynn338 int + if yyr338 || yy2arr338 { r.EncodeArrayStart(5) } else { - yynn329 = 2 - for _, b := range yyq329 { + yynn338 = 2 + for _, b := range yyq338 { if b { - yynn329++ + yynn338++ } } - r.EncodeMapStart(yynn329) - yynn329 = 0 + r.EncodeMapStart(yynn338) + yynn338 = 0 } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq329[0] { - yym331 := z.EncBinary() - _ = yym331 + if yyq338[0] { + yym340 := z.EncBinary() + _ = yym340 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -4028,23 +4106,23 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq329[0] { + if yyq338[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym332 := z.EncBinary() - _ = yym332 + yym341 := z.EncBinary() + _ = yym341 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq329[1] { - yym334 := z.EncBinary() - _ = yym334 + if yyq338[1] { + yym343 := z.EncBinary() + _ = yym343 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -4053,22 +4131,22 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq329[1] { + if yyq338[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym335 := z.EncBinary() - _ = yym335 + yym344 := z.EncBinary() + _ = yym344 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym337 := z.EncBinary() - _ = yym337 + yym346 := z.EncBinary() + _ = yym346 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -4077,21 +4155,21 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym338 := z.EncBinary() - _ = yym338 + yym347 := z.EncBinary() + _ = yym347 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq329[3] { + if yyq338[3] { if x.UpdatedAnnotations == nil { r.EncodeNil() } else { - yym340 := z.EncBinary() - _ = yym340 + yym349 := z.EncBinary() + _ = yym349 if false { } else { z.F.EncMapStringStringV(x.UpdatedAnnotations, false, e) @@ -4101,15 +4179,15 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq329[3] { + if yyq338[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("updatedAnnotations")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.UpdatedAnnotations == nil { r.EncodeNil() } else { - yym341 := z.EncBinary() - _ = yym341 + yym350 := z.EncBinary() + _ = yym350 if false { } else { z.F.EncMapStringStringV(x.UpdatedAnnotations, false, e) @@ -4117,18 +4195,18 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy343 := &x.RollbackTo - yy343.CodecEncodeSelf(e) + yy352 := &x.RollbackTo + yy352.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rollbackTo")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy344 := &x.RollbackTo - yy344.CodecEncodeSelf(e) + yy353 := &x.RollbackTo + yy353.CodecEncodeSelf(e) } - if yyr329 || yy2arr329 { + if yyr338 || yy2arr338 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -4141,25 +4219,25 @@ func (x *DeploymentRollback) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym345 := z.DecBinary() - _ = yym345 + yym354 := z.DecBinary() + _ = yym354 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct346 := r.ContainerType() - if yyct346 == codecSelferValueTypeMap1234 { - yyl346 := r.ReadMapStart() - if yyl346 == 0 { + yyct355 := r.ContainerType() + if yyct355 == codecSelferValueTypeMap1234 { + yyl355 := r.ReadMapStart() + if yyl355 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl346, d) + x.codecDecodeSelfFromMap(yyl355, d) } - } else if yyct346 == codecSelferValueTypeArray1234 { - yyl346 := r.ReadArrayStart() - if yyl346 == 0 { + } else if yyct355 == codecSelferValueTypeArray1234 { + yyl355 := r.ReadArrayStart() + if yyl355 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl346, d) + x.codecDecodeSelfFromArray(yyl355, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -4171,12 +4249,12 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys347Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys347Slc - var yyhl347 bool = l >= 0 - for yyj347 := 0; ; yyj347++ { - if yyhl347 { - if yyj347 >= l { + var yys356Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys356Slc + var yyhl356 bool = l >= 0 + for yyj356 := 0; ; yyj356++ { + if yyhl356 { + if yyj356 >= l { break } } else { @@ -4185,10 +4263,10 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys347Slc = r.DecodeBytes(yys347Slc, true, true) - yys347 := string(yys347Slc) + yys356Slc = r.DecodeBytes(yys356Slc, true, true) + yys356 := string(yys356Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys347 { + switch yys356 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -4211,25 +4289,25 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.UpdatedAnnotations = nil } else { - yyv351 := &x.UpdatedAnnotations - yym352 := z.DecBinary() - _ = yym352 + yyv360 := &x.UpdatedAnnotations + yym361 := z.DecBinary() + _ = yym361 if false { } else { - z.F.DecMapStringStringX(yyv351, false, d) + z.F.DecMapStringStringX(yyv360, false, d) } } case "rollbackTo": if r.TryDecodeAsNil() { x.RollbackTo = RollbackConfig{} } else { - yyv353 := &x.RollbackTo - yyv353.CodecDecodeSelf(d) + yyv362 := &x.RollbackTo + yyv362.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys347) - } // end switch yys347 - } // end for yyj347 + z.DecStructFieldNotFound(-1, yys356) + } // end switch yys356 + } // end for yyj356 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -4237,16 +4315,16 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj354 int - var yyb354 bool - var yyhl354 bool = l >= 0 - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + var yyj363 int + var yyb363 bool + var yyhl363 bool = l >= 0 + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4256,13 +4334,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Kind = string(r.DecodeString()) } - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4272,13 +4350,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.APIVersion = string(r.DecodeString()) } - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4288,13 +4366,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Name = string(r.DecodeString()) } - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4302,21 +4380,21 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.UpdatedAnnotations = nil } else { - yyv358 := &x.UpdatedAnnotations - yym359 := z.DecBinary() - _ = yym359 + yyv367 := &x.UpdatedAnnotations + yym368 := z.DecBinary() + _ = yym368 if false { } else { - z.F.DecMapStringStringX(yyv358, false, d) + z.F.DecMapStringStringX(yyv367, false, d) } } - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4324,21 +4402,21 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.RollbackTo = RollbackConfig{} } else { - yyv360 := &x.RollbackTo - yyv360.CodecDecodeSelf(d) + yyv369 := &x.RollbackTo + yyv369.CodecDecodeSelf(d) } for { - yyj354++ - if yyhl354 { - yyb354 = yyj354 > l + yyj363++ + if yyhl363 { + yyb363 = yyj363 > l } else { - yyb354 = r.CheckBreak() + yyb363 = r.CheckBreak() } - if yyb354 { + if yyb363 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj354-1, "") + z.DecStructFieldNotFound(yyj363-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4350,35 +4428,35 @@ func (x *RollbackConfig) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym361 := z.EncBinary() - _ = yym361 + yym370 := z.EncBinary() + _ = yym370 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep362 := !z.EncBinary() - yy2arr362 := z.EncBasicHandle().StructToArray - var yyq362 [1]bool - _, _, _ = yysep362, yyq362, yy2arr362 - const yyr362 bool = false - yyq362[0] = x.Revision != 0 - var yynn362 int - if yyr362 || yy2arr362 { + yysep371 := !z.EncBinary() + yy2arr371 := z.EncBasicHandle().StructToArray + var yyq371 [1]bool + _, _, _ = yysep371, yyq371, yy2arr371 + const yyr371 bool = false + yyq371[0] = x.Revision != 0 + var yynn371 int + if yyr371 || yy2arr371 { r.EncodeArrayStart(1) } else { - yynn362 = 0 - for _, b := range yyq362 { + yynn371 = 0 + for _, b := range yyq371 { if b { - yynn362++ + yynn371++ } } - r.EncodeMapStart(yynn362) - yynn362 = 0 + r.EncodeMapStart(yynn371) + yynn371 = 0 } - if yyr362 || yy2arr362 { + if yyr371 || yy2arr371 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq362[0] { - yym364 := z.EncBinary() - _ = yym364 + if yyq371[0] { + yym373 := z.EncBinary() + _ = yym373 if false { } else { r.EncodeInt(int64(x.Revision)) @@ -4387,19 +4465,19 @@ func (x *RollbackConfig) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq362[0] { + if yyq371[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("revision")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym365 := z.EncBinary() - _ = yym365 + yym374 := z.EncBinary() + _ = yym374 if false { } else { r.EncodeInt(int64(x.Revision)) } } } - if yyr362 || yy2arr362 { + if yyr371 || yy2arr371 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -4412,25 +4490,25 @@ func (x *RollbackConfig) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym366 := z.DecBinary() - _ = yym366 + yym375 := z.DecBinary() + _ = yym375 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct367 := r.ContainerType() - if yyct367 == codecSelferValueTypeMap1234 { - yyl367 := r.ReadMapStart() - if yyl367 == 0 { + yyct376 := r.ContainerType() + if yyct376 == codecSelferValueTypeMap1234 { + yyl376 := r.ReadMapStart() + if yyl376 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl367, d) + x.codecDecodeSelfFromMap(yyl376, d) } - } else if yyct367 == codecSelferValueTypeArray1234 { - yyl367 := r.ReadArrayStart() - if yyl367 == 0 { + } else if yyct376 == codecSelferValueTypeArray1234 { + yyl376 := r.ReadArrayStart() + if yyl376 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl367, d) + x.codecDecodeSelfFromArray(yyl376, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -4442,12 +4520,12 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys368Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys368Slc - var yyhl368 bool = l >= 0 - for yyj368 := 0; ; yyj368++ { - if yyhl368 { - if yyj368 >= l { + var yys377Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys377Slc + var yyhl377 bool = l >= 0 + for yyj377 := 0; ; yyj377++ { + if yyhl377 { + if yyj377 >= l { break } } else { @@ -4456,10 +4534,10 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys368Slc = r.DecodeBytes(yys368Slc, true, true) - yys368 := string(yys368Slc) + yys377Slc = r.DecodeBytes(yys377Slc, true, true) + yys377 := string(yys377Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys368 { + switch yys377 { case "revision": if r.TryDecodeAsNil() { x.Revision = 0 @@ -4467,9 +4545,9 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Revision = int64(r.DecodeInt(64)) } default: - z.DecStructFieldNotFound(-1, yys368) - } // end switch yys368 - } // end for yyj368 + z.DecStructFieldNotFound(-1, yys377) + } // end switch yys377 + } // end for yyj377 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -4477,16 +4555,16 @@ func (x *RollbackConfig) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj370 int - var yyb370 bool - var yyhl370 bool = l >= 0 - yyj370++ - if yyhl370 { - yyb370 = yyj370 > l + var yyj379 int + var yyb379 bool + var yyhl379 bool = l >= 0 + yyj379++ + if yyhl379 { + yyb379 = yyj379 > l } else { - yyb370 = r.CheckBreak() + yyb379 = r.CheckBreak() } - if yyb370 { + if yyb379 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4497,17 +4575,17 @@ func (x *RollbackConfig) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Revision = int64(r.DecodeInt(64)) } for { - yyj370++ - if yyhl370 { - yyb370 = yyj370 > l + yyj379++ + if yyhl379 { + yyb379 = yyj379 > l } else { - yyb370 = r.CheckBreak() + yyb379 = r.CheckBreak() } - if yyb370 { + if yyb379 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj370-1, "") + z.DecStructFieldNotFound(yyj379-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4519,49 +4597,49 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym372 := z.EncBinary() - _ = yym372 + yym381 := z.EncBinary() + _ = yym381 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep373 := !z.EncBinary() - yy2arr373 := z.EncBasicHandle().StructToArray - var yyq373 [2]bool - _, _, _ = yysep373, yyq373, yy2arr373 - const yyr373 bool = false - yyq373[0] = x.Type != "" - yyq373[1] = x.RollingUpdate != nil - var yynn373 int - if yyr373 || yy2arr373 { + yysep382 := !z.EncBinary() + yy2arr382 := z.EncBasicHandle().StructToArray + var yyq382 [2]bool + _, _, _ = yysep382, yyq382, yy2arr382 + const yyr382 bool = false + yyq382[0] = x.Type != "" + yyq382[1] = x.RollingUpdate != nil + var yynn382 int + if yyr382 || yy2arr382 { r.EncodeArrayStart(2) } else { - yynn373 = 0 - for _, b := range yyq373 { + yynn382 = 0 + for _, b := range yyq382 { if b { - yynn373++ + yynn382++ } } - r.EncodeMapStart(yynn373) - yynn373 = 0 + r.EncodeMapStart(yynn382) + yynn382 = 0 } - if yyr373 || yy2arr373 { + if yyr382 || yy2arr382 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq373[0] { + if yyq382[0] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq373[0] { + if yyq382[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr373 || yy2arr373 { + if yyr382 || yy2arr382 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq373[1] { + if yyq382[1] { if x.RollingUpdate == nil { r.EncodeNil() } else { @@ -4571,7 +4649,7 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq373[1] { + if yyq382[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rollingUpdate")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -4582,7 +4660,7 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr373 || yy2arr373 { + if yyr382 || yy2arr382 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -4595,25 +4673,25 @@ func (x *DeploymentStrategy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym376 := z.DecBinary() - _ = yym376 + yym385 := z.DecBinary() + _ = yym385 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct377 := r.ContainerType() - if yyct377 == codecSelferValueTypeMap1234 { - yyl377 := r.ReadMapStart() - if yyl377 == 0 { + yyct386 := r.ContainerType() + if yyct386 == codecSelferValueTypeMap1234 { + yyl386 := r.ReadMapStart() + if yyl386 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl377, d) + x.codecDecodeSelfFromMap(yyl386, d) } - } else if yyct377 == codecSelferValueTypeArray1234 { - yyl377 := r.ReadArrayStart() - if yyl377 == 0 { + } else if yyct386 == codecSelferValueTypeArray1234 { + yyl386 := r.ReadArrayStart() + if yyl386 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl377, d) + x.codecDecodeSelfFromArray(yyl386, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -4625,12 +4703,12 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys378Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys378Slc - var yyhl378 bool = l >= 0 - for yyj378 := 0; ; yyj378++ { - if yyhl378 { - if yyj378 >= l { + var yys387Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys387Slc + var yyhl387 bool = l >= 0 + for yyj387 := 0; ; yyj387++ { + if yyhl387 { + if yyj387 >= l { break } } else { @@ -4639,10 +4717,10 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys378Slc = r.DecodeBytes(yys378Slc, true, true) - yys378 := string(yys378Slc) + yys387Slc = r.DecodeBytes(yys387Slc, true, true) + yys387 := string(yys387Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys378 { + switch yys387 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -4661,9 +4739,9 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) x.RollingUpdate.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys378) - } // end switch yys378 - } // end for yyj378 + z.DecStructFieldNotFound(-1, yys387) + } // end switch yys387 + } // end for yyj387 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -4671,16 +4749,16 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj381 int - var yyb381 bool - var yyhl381 bool = l >= 0 - yyj381++ - if yyhl381 { - yyb381 = yyj381 > l + var yyj390 int + var yyb390 bool + var yyhl390 bool = l >= 0 + yyj390++ + if yyhl390 { + yyb390 = yyj390 > l } else { - yyb381 = r.CheckBreak() + yyb390 = r.CheckBreak() } - if yyb381 { + if yyb390 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4690,13 +4768,13 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Type = DeploymentStrategyType(r.DecodeString()) } - yyj381++ - if yyhl381 { - yyb381 = yyj381 > l + yyj390++ + if yyhl390 { + yyb390 = yyj390 > l } else { - yyb381 = r.CheckBreak() + yyb390 = r.CheckBreak() } - if yyb381 { + if yyb390 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4712,17 +4790,17 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode x.RollingUpdate.CodecDecodeSelf(d) } for { - yyj381++ - if yyhl381 { - yyb381 = yyj381 > l + yyj390++ + if yyhl390 { + yyb390 = yyj390 > l } else { - yyb381 = r.CheckBreak() + yyb390 = r.CheckBreak() } - if yyb381 { + if yyb390 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj381-1, "") + z.DecStructFieldNotFound(yyj390-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -4731,8 +4809,8 @@ func (x DeploymentStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym384 := z.EncBinary() - _ = yym384 + yym393 := z.EncBinary() + _ = yym393 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -4744,8 +4822,8 @@ func (x *DeploymentStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym385 := z.DecBinary() - _ = yym385 + yym394 := z.DecBinary() + _ = yym394 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -4760,98 +4838,98 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym386 := z.EncBinary() - _ = yym386 + yym395 := z.EncBinary() + _ = yym395 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep387 := !z.EncBinary() - yy2arr387 := z.EncBasicHandle().StructToArray - var yyq387 [2]bool - _, _, _ = yysep387, yyq387, yy2arr387 - const yyr387 bool = false - yyq387[0] = true - yyq387[1] = true - var yynn387 int - if yyr387 || yy2arr387 { + yysep396 := !z.EncBinary() + yy2arr396 := z.EncBasicHandle().StructToArray + var yyq396 [2]bool + _, _, _ = yysep396, yyq396, yy2arr396 + const yyr396 bool = false + yyq396[0] = true + yyq396[1] = true + var yynn396 int + if yyr396 || yy2arr396 { r.EncodeArrayStart(2) } else { - yynn387 = 0 - for _, b := range yyq387 { + yynn396 = 0 + for _, b := range yyq396 { if b { - yynn387++ + yynn396++ } } - r.EncodeMapStart(yynn387) - yynn387 = 0 + r.EncodeMapStart(yynn396) + yynn396 = 0 } - if yyr387 || yy2arr387 { + if yyr396 || yy2arr396 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq387[0] { - yy389 := &x.MaxUnavailable - yym390 := z.EncBinary() - _ = yym390 + if yyq396[0] { + yy398 := &x.MaxUnavailable + yym399 := z.EncBinary() + _ = yym399 if false { - } else if z.HasExtensions() && z.EncExt(yy389) { - } else if !yym390 && z.IsJSONHandle() { - z.EncJSONMarshal(yy389) + } else if z.HasExtensions() && z.EncExt(yy398) { + } else if !yym399 && z.IsJSONHandle() { + z.EncJSONMarshal(yy398) } else { - z.EncFallback(yy389) + z.EncFallback(yy398) } } else { r.EncodeNil() } } else { - if yyq387[0] { + if yyq396[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxUnavailable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy391 := &x.MaxUnavailable - yym392 := z.EncBinary() - _ = yym392 + yy400 := &x.MaxUnavailable + yym401 := z.EncBinary() + _ = yym401 if false { - } else if z.HasExtensions() && z.EncExt(yy391) { - } else if !yym392 && z.IsJSONHandle() { - z.EncJSONMarshal(yy391) + } else if z.HasExtensions() && z.EncExt(yy400) { + } else if !yym401 && z.IsJSONHandle() { + z.EncJSONMarshal(yy400) } else { - z.EncFallback(yy391) + z.EncFallback(yy400) } } } - if yyr387 || yy2arr387 { + if yyr396 || yy2arr396 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq387[1] { - yy394 := &x.MaxSurge - yym395 := z.EncBinary() - _ = yym395 + if yyq396[1] { + yy403 := &x.MaxSurge + yym404 := z.EncBinary() + _ = yym404 if false { - } else if z.HasExtensions() && z.EncExt(yy394) { - } else if !yym395 && z.IsJSONHandle() { - z.EncJSONMarshal(yy394) + } else if z.HasExtensions() && z.EncExt(yy403) { + } else if !yym404 && z.IsJSONHandle() { + z.EncJSONMarshal(yy403) } else { - z.EncFallback(yy394) + z.EncFallback(yy403) } } else { r.EncodeNil() } } else { - if yyq387[1] { + if yyq396[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxSurge")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy396 := &x.MaxSurge - yym397 := z.EncBinary() - _ = yym397 + yy405 := &x.MaxSurge + yym406 := z.EncBinary() + _ = yym406 if false { - } else if z.HasExtensions() && z.EncExt(yy396) { - } else if !yym397 && z.IsJSONHandle() { - z.EncJSONMarshal(yy396) + } else if z.HasExtensions() && z.EncExt(yy405) { + } else if !yym406 && z.IsJSONHandle() { + z.EncJSONMarshal(yy405) } else { - z.EncFallback(yy396) + z.EncFallback(yy405) } } } - if yyr387 || yy2arr387 { + if yyr396 || yy2arr396 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -4864,25 +4942,25 @@ func (x *RollingUpdateDeployment) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym398 := z.DecBinary() - _ = yym398 + yym407 := z.DecBinary() + _ = yym407 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct399 := r.ContainerType() - if yyct399 == codecSelferValueTypeMap1234 { - yyl399 := r.ReadMapStart() - if yyl399 == 0 { + yyct408 := r.ContainerType() + if yyct408 == codecSelferValueTypeMap1234 { + yyl408 := r.ReadMapStart() + if yyl408 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl399, d) + x.codecDecodeSelfFromMap(yyl408, d) } - } else if yyct399 == codecSelferValueTypeArray1234 { - yyl399 := r.ReadArrayStart() - if yyl399 == 0 { + } else if yyct408 == codecSelferValueTypeArray1234 { + yyl408 := r.ReadArrayStart() + if yyl408 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl399, d) + x.codecDecodeSelfFromArray(yyl408, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -4894,12 +4972,12 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys400Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys400Slc - var yyhl400 bool = l >= 0 - for yyj400 := 0; ; yyj400++ { - if yyhl400 { - if yyj400 >= l { + var yys409Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys409Slc + var yyhl409 bool = l >= 0 + for yyj409 := 0; ; yyj409++ { + if yyhl409 { + if yyj409 >= l { break } } else { @@ -4908,44 +4986,44 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys400Slc = r.DecodeBytes(yys400Slc, true, true) - yys400 := string(yys400Slc) + yys409Slc = r.DecodeBytes(yys409Slc, true, true) + yys409 := string(yys409Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys400 { + switch yys409 { case "maxUnavailable": if r.TryDecodeAsNil() { x.MaxUnavailable = pkg5_intstr.IntOrString{} } else { - yyv401 := &x.MaxUnavailable - yym402 := z.DecBinary() - _ = yym402 + yyv410 := &x.MaxUnavailable + yym411 := z.DecBinary() + _ = yym411 if false { - } else if z.HasExtensions() && z.DecExt(yyv401) { - } else if !yym402 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv401) + } else if z.HasExtensions() && z.DecExt(yyv410) { + } else if !yym411 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv410) } else { - z.DecFallback(yyv401, false) + z.DecFallback(yyv410, false) } } case "maxSurge": if r.TryDecodeAsNil() { x.MaxSurge = pkg5_intstr.IntOrString{} } else { - yyv403 := &x.MaxSurge - yym404 := z.DecBinary() - _ = yym404 + yyv412 := &x.MaxSurge + yym413 := z.DecBinary() + _ = yym413 if false { - } else if z.HasExtensions() && z.DecExt(yyv403) { - } else if !yym404 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv403) + } else if z.HasExtensions() && z.DecExt(yyv412) { + } else if !yym413 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv412) } else { - z.DecFallback(yyv403, false) + z.DecFallback(yyv412, false) } } default: - z.DecStructFieldNotFound(-1, yys400) - } // end switch yys400 - } // end for yyj400 + z.DecStructFieldNotFound(-1, yys409) + } // end switch yys409 + } // end for yyj409 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -4953,16 +5031,16 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj405 int - var yyb405 bool - var yyhl405 bool = l >= 0 - yyj405++ - if yyhl405 { - yyb405 = yyj405 > l + var yyj414 int + var yyb414 bool + var yyhl414 bool = l >= 0 + yyj414++ + if yyhl414 { + yyb414 = yyj414 > l } else { - yyb405 = r.CheckBreak() + yyb414 = r.CheckBreak() } - if yyb405 { + if yyb414 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4970,24 +5048,24 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D if r.TryDecodeAsNil() { x.MaxUnavailable = pkg5_intstr.IntOrString{} } else { - yyv406 := &x.MaxUnavailable - yym407 := z.DecBinary() - _ = yym407 + yyv415 := &x.MaxUnavailable + yym416 := z.DecBinary() + _ = yym416 if false { - } else if z.HasExtensions() && z.DecExt(yyv406) { - } else if !yym407 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv406) + } else if z.HasExtensions() && z.DecExt(yyv415) { + } else if !yym416 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv415) } else { - z.DecFallback(yyv406, false) + z.DecFallback(yyv415, false) } } - yyj405++ - if yyhl405 { - yyb405 = yyj405 > l + yyj414++ + if yyhl414 { + yyb414 = yyj414 > l } else { - yyb405 = r.CheckBreak() + yyb414 = r.CheckBreak() } - if yyb405 { + if yyb414 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -4995,29 +5073,29 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D if r.TryDecodeAsNil() { x.MaxSurge = pkg5_intstr.IntOrString{} } else { - yyv408 := &x.MaxSurge - yym409 := z.DecBinary() - _ = yym409 + yyv417 := &x.MaxSurge + yym418 := z.DecBinary() + _ = yym418 if false { - } else if z.HasExtensions() && z.DecExt(yyv408) { - } else if !yym409 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv408) + } else if z.HasExtensions() && z.DecExt(yyv417) { + } else if !yym418 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv417) } else { - z.DecFallback(yyv408, false) + z.DecFallback(yyv417, false) } } for { - yyj405++ - if yyhl405 { - yyb405 = yyj405 > l + yyj414++ + if yyhl414 { + yyb414 = yyj414 > l } else { - yyb405 = r.CheckBreak() + yyb414 = r.CheckBreak() } - if yyb405 { + if yyb414 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj405-1, "") + z.DecStructFieldNotFound(yyj414-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -5029,139 +5107,140 @@ func (x *DeploymentStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym410 := z.EncBinary() - _ = yym410 + yym419 := z.EncBinary() + _ = yym419 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep411 := !z.EncBinary() - yy2arr411 := z.EncBasicHandle().StructToArray - var yyq411 [5]bool - _, _, _ = yysep411, yyq411, yy2arr411 - const yyr411 bool = false - yyq411[0] = x.ObservedGeneration != 0 - yyq411[1] = x.Replicas != 0 - yyq411[2] = x.UpdatedReplicas != 0 - yyq411[3] = x.AvailableReplicas != 0 - yyq411[4] = x.UnavailableReplicas != 0 - var yynn411 int - if yyr411 || yy2arr411 { - r.EncodeArrayStart(5) + yysep420 := !z.EncBinary() + yy2arr420 := z.EncBasicHandle().StructToArray + var yyq420 [6]bool + _, _, _ = yysep420, yyq420, yy2arr420 + const yyr420 bool = false + yyq420[0] = x.ObservedGeneration != 0 + yyq420[1] = x.Replicas != 0 + yyq420[2] = x.UpdatedReplicas != 0 + yyq420[3] = x.AvailableReplicas != 0 + yyq420[4] = x.UnavailableReplicas != 0 + yyq420[5] = len(x.Conditions) != 0 + var yynn420 int + if yyr420 || yy2arr420 { + r.EncodeArrayStart(6) } else { - yynn411 = 0 - for _, b := range yyq411 { + yynn420 = 0 + for _, b := range yyq420 { if b { - yynn411++ + yynn420++ } } - r.EncodeMapStart(yynn411) - yynn411 = 0 + r.EncodeMapStart(yynn420) + yynn420 = 0 } - if yyr411 || yy2arr411 { + if yyr420 || yy2arr420 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq411[0] { - yym413 := z.EncBinary() - _ = yym413 - if false { - } else { - r.EncodeInt(int64(x.ObservedGeneration)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq411[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym414 := z.EncBinary() - _ = yym414 - if false { - } else { - r.EncodeInt(int64(x.ObservedGeneration)) - } - } - } - if yyr411 || yy2arr411 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq411[1] { - yym416 := z.EncBinary() - _ = yym416 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq411[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("replicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym417 := z.EncBinary() - _ = yym417 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } - } - if yyr411 || yy2arr411 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq411[2] { - yym419 := z.EncBinary() - _ = yym419 - if false { - } else { - r.EncodeInt(int64(x.UpdatedReplicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq411[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("updatedReplicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym420 := z.EncBinary() - _ = yym420 - if false { - } else { - r.EncodeInt(int64(x.UpdatedReplicas)) - } - } - } - if yyr411 || yy2arr411 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq411[3] { + if yyq420[0] { yym422 := z.EncBinary() _ = yym422 if false { } else { - r.EncodeInt(int64(x.AvailableReplicas)) + r.EncodeInt(int64(x.ObservedGeneration)) } } else { r.EncodeInt(0) } } else { - if yyq411[3] { + if yyq420[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) + r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym423 := z.EncBinary() _ = yym423 if false { + } else { + r.EncodeInt(int64(x.ObservedGeneration)) + } + } + } + if yyr420 || yy2arr420 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq420[1] { + yym425 := z.EncBinary() + _ = yym425 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq420[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("replicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym426 := z.EncBinary() + _ = yym426 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } + } + if yyr420 || yy2arr420 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq420[2] { + yym428 := z.EncBinary() + _ = yym428 + if false { + } else { + r.EncodeInt(int64(x.UpdatedReplicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq420[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("updatedReplicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym429 := z.EncBinary() + _ = yym429 + if false { + } else { + r.EncodeInt(int64(x.UpdatedReplicas)) + } + } + } + if yyr420 || yy2arr420 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq420[3] { + yym431 := z.EncBinary() + _ = yym431 + if false { + } else { + r.EncodeInt(int64(x.AvailableReplicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq420[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym432 := z.EncBinary() + _ = yym432 + if false { } else { r.EncodeInt(int64(x.AvailableReplicas)) } } } - if yyr411 || yy2arr411 { + if yyr420 || yy2arr420 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq411[4] { - yym425 := z.EncBinary() - _ = yym425 + if yyq420[4] { + yym434 := z.EncBinary() + _ = yym434 if false { } else { r.EncodeInt(int64(x.UnavailableReplicas)) @@ -5170,19 +5249,52 @@ func (x *DeploymentStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq411[4] { + if yyq420[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("unavailableReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym426 := z.EncBinary() - _ = yym426 + yym435 := z.EncBinary() + _ = yym435 if false { } else { r.EncodeInt(int64(x.UnavailableReplicas)) } } } - if yyr411 || yy2arr411 { + if yyr420 || yy2arr420 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq420[5] { + if x.Conditions == nil { + r.EncodeNil() + } else { + yym437 := z.EncBinary() + _ = yym437 + if false { + } else { + h.encSliceDeploymentCondition(([]DeploymentCondition)(x.Conditions), e) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq420[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("conditions")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Conditions == nil { + r.EncodeNil() + } else { + yym438 := z.EncBinary() + _ = yym438 + if false { + } else { + h.encSliceDeploymentCondition(([]DeploymentCondition)(x.Conditions), e) + } + } + } + } + if yyr420 || yy2arr420 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -5195,25 +5307,25 @@ func (x *DeploymentStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym427 := z.DecBinary() - _ = yym427 + yym439 := z.DecBinary() + _ = yym439 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct428 := r.ContainerType() - if yyct428 == codecSelferValueTypeMap1234 { - yyl428 := r.ReadMapStart() - if yyl428 == 0 { + yyct440 := r.ContainerType() + if yyct440 == codecSelferValueTypeMap1234 { + yyl440 := r.ReadMapStart() + if yyl440 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl428, d) + x.codecDecodeSelfFromMap(yyl440, d) } - } else if yyct428 == codecSelferValueTypeArray1234 { - yyl428 := r.ReadArrayStart() - if yyl428 == 0 { + } else if yyct440 == codecSelferValueTypeArray1234 { + yyl440 := r.ReadArrayStart() + if yyl440 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl428, d) + x.codecDecodeSelfFromArray(yyl440, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -5225,12 +5337,12 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys429Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys429Slc - var yyhl429 bool = l >= 0 - for yyj429 := 0; ; yyj429++ { - if yyhl429 { - if yyj429 >= l { + var yys441Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys441Slc + var yyhl441 bool = l >= 0 + for yyj441 := 0; ; yyj441++ { + if yyhl441 { + if yyj441 >= l { break } } else { @@ -5239,10 +5351,10 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys429Slc = r.DecodeBytes(yys429Slc, true, true) - yys429 := string(yys429Slc) + yys441Slc = r.DecodeBytes(yys441Slc, true, true) + yys441 := string(yys441Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys429 { + switch yys441 { case "observedGeneration": if r.TryDecodeAsNil() { x.ObservedGeneration = 0 @@ -5273,10 +5385,22 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } else { x.UnavailableReplicas = int32(r.DecodeInt(32)) } + case "conditions": + if r.TryDecodeAsNil() { + x.Conditions = nil + } else { + yyv447 := &x.Conditions + yym448 := z.DecBinary() + _ = yym448 + if false { + } else { + h.decSliceDeploymentCondition((*[]DeploymentCondition)(yyv447), d) + } + } default: - z.DecStructFieldNotFound(-1, yys429) - } // end switch yys429 - } // end for yyj429 + z.DecStructFieldNotFound(-1, yys441) + } // end switch yys441 + } // end for yyj441 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -5284,16 +5408,16 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj435 int - var yyb435 bool - var yyhl435 bool = l >= 0 - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + var yyj449 int + var yyb449 bool + var yyhl449 bool = l >= 0 + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l } else { - yyb435 = r.CheckBreak() + yyb449 = r.CheckBreak() } - if yyb435 { + if yyb449 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5303,13 +5427,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ObservedGeneration = int64(r.DecodeInt(64)) } - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l } else { - yyb435 = r.CheckBreak() + yyb449 = r.CheckBreak() } - if yyb435 { + if yyb449 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5319,13 +5443,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l } else { - yyb435 = r.CheckBreak() + yyb449 = r.CheckBreak() } - if yyb435 { + if yyb449 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5335,13 +5459,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UpdatedReplicas = int32(r.DecodeInt(32)) } - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l } else { - yyb435 = r.CheckBreak() + yyb449 = r.CheckBreak() } - if yyb435 { + if yyb449 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5351,13 +5475,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.AvailableReplicas = int32(r.DecodeInt(32)) } - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l } else { - yyb435 = r.CheckBreak() + yyb449 = r.CheckBreak() } - if yyb435 { + if yyb449 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5367,444 +5491,259 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UnavailableReplicas = int32(r.DecodeInt(32)) } - for { - yyj435++ - if yyhl435 { - yyb435 = yyj435 > l + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l + } else { + yyb449 = r.CheckBreak() + } + if yyb449 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Conditions = nil + } else { + yyv455 := &x.Conditions + yym456 := z.DecBinary() + _ = yym456 + if false { } else { - yyb435 = r.CheckBreak() + h.decSliceDeploymentCondition((*[]DeploymentCondition)(yyv455), d) } - if yyb435 { + } + for { + yyj449++ + if yyhl449 { + yyb449 = yyj449 > l + } else { + yyb449 = r.CheckBreak() + } + if yyb449 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj435-1, "") + z.DecStructFieldNotFound(yyj449-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { +func (x DeploymentConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - if x == nil { - r.EncodeNil() + yym457 := z.EncBinary() + _ = yym457 + if false { + } else if z.HasExtensions() && z.EncExt(x) { } else { - yym441 := z.EncBinary() - _ = yym441 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep442 := !z.EncBinary() - yy2arr442 := z.EncBasicHandle().StructToArray - var yyq442 [4]bool - _, _, _ = yysep442, yyq442, yy2arr442 - const yyr442 bool = false - yyq442[0] = x.Kind != "" - yyq442[1] = x.APIVersion != "" - yyq442[2] = true - var yynn442 int - if yyr442 || yy2arr442 { - r.EncodeArrayStart(4) - } else { - yynn442 = 1 - for _, b := range yyq442 { - if b { - yynn442++ - } - } - r.EncodeMapStart(yynn442) - yynn442 = 0 - } - if yyr442 || yy2arr442 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq442[0] { - yym444 := z.EncBinary() - _ = yym444 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq442[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym445 := z.EncBinary() - _ = yym445 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr442 || yy2arr442 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq442[1] { - yym447 := z.EncBinary() - _ = yym447 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq442[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym448 := z.EncBinary() - _ = yym448 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr442 || yy2arr442 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq442[2] { - yy450 := &x.ListMeta - yym451 := z.EncBinary() - _ = yym451 - if false { - } else if z.HasExtensions() && z.EncExt(yy450) { - } else { - z.EncFallback(yy450) - } - } else { - r.EncodeNil() - } - } else { - if yyq442[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy452 := &x.ListMeta - yym453 := z.EncBinary() - _ = yym453 - if false { - } else if z.HasExtensions() && z.EncExt(yy452) { - } else { - z.EncFallback(yy452) - } - } - } - if yyr442 || yy2arr442 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.Items == nil { - r.EncodeNil() - } else { - yym455 := z.EncBinary() - _ = yym455 - if false { - } else { - h.encSliceDeployment(([]Deployment)(x.Items), e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("items")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Items == nil { - r.EncodeNil() - } else { - yym456 := z.EncBinary() - _ = yym456 - if false { - } else { - h.encSliceDeployment(([]Deployment)(x.Items), e) - } - } - } - if yyr442 || yy2arr442 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } + r.EncodeString(codecSelferC_UTF81234, string(x)) } } -func (x *DeploymentList) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *DeploymentConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym457 := z.DecBinary() - _ = yym457 + yym458 := z.DecBinary() + _ = yym458 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct458 := r.ContainerType() - if yyct458 == codecSelferValueTypeMap1234 { - yyl458 := r.ReadMapStart() - if yyl458 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl458, d) - } - } else if yyct458 == codecSelferValueTypeArray1234 { - yyl458 := r.ReadArrayStart() - if yyl458 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl458, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } + *((*string)(x)) = r.DecodeString() } } -func (x *DeploymentList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys459Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys459Slc - var yyhl459 bool = l >= 0 - for yyj459 := 0; ; yyj459++ { - if yyhl459 { - if yyj459 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys459Slc = r.DecodeBytes(yys459Slc, true, true) - yys459 := string(yys459Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys459 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "metadata": - if r.TryDecodeAsNil() { - x.ListMeta = pkg1_unversioned.ListMeta{} - } else { - yyv462 := &x.ListMeta - yym463 := z.DecBinary() - _ = yym463 - if false { - } else if z.HasExtensions() && z.DecExt(yyv462) { - } else { - z.DecFallback(yyv462, false) - } - } - case "items": - if r.TryDecodeAsNil() { - x.Items = nil - } else { - yyv464 := &x.Items - yym465 := z.DecBinary() - _ = yym465 - if false { - } else { - h.decSliceDeployment((*[]Deployment)(yyv464), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys459) - } // end switch yys459 - } // end for yyj459 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj466 int - var yyb466 bool - var yyhl466 bool = l >= 0 - yyj466++ - if yyhl466 { - yyb466 = yyj466 > l - } else { - yyb466 = r.CheckBreak() - } - if yyb466 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj466++ - if yyhl466 { - yyb466 = yyj466 > l - } else { - yyb466 = r.CheckBreak() - } - if yyb466 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj466++ - if yyhl466 { - yyb466 = yyj466 > l - } else { - yyb466 = r.CheckBreak() - } - if yyb466 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ListMeta = pkg1_unversioned.ListMeta{} - } else { - yyv469 := &x.ListMeta - yym470 := z.DecBinary() - _ = yym470 - if false { - } else if z.HasExtensions() && z.DecExt(yyv469) { - } else { - z.DecFallback(yyv469, false) - } - } - yyj466++ - if yyhl466 { - yyb466 = yyj466 > l - } else { - yyb466 = r.CheckBreak() - } - if yyb466 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Items = nil - } else { - yyv471 := &x.Items - yym472 := z.DecBinary() - _ = yym472 - if false { - } else { - h.decSliceDeployment((*[]Deployment)(yyv471), d) - } - } - for { - yyj466++ - if yyhl466 { - yyb466 = yyj466 > l - } else { - yyb466 = r.CheckBreak() - } - if yyb466 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj466-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *DaemonSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *DeploymentCondition) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r if x == nil { r.EncodeNil() } else { - yym473 := z.EncBinary() - _ = yym473 + yym459 := z.EncBinary() + _ = yym459 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep474 := !z.EncBinary() - yy2arr474 := z.EncBasicHandle().StructToArray - var yyq474 [2]bool - _, _, _ = yysep474, yyq474, yy2arr474 - const yyr474 bool = false - yyq474[0] = x.Selector != nil - var yynn474 int - if yyr474 || yy2arr474 { - r.EncodeArrayStart(2) + yysep460 := !z.EncBinary() + yy2arr460 := z.EncBasicHandle().StructToArray + var yyq460 [6]bool + _, _, _ = yysep460, yyq460, yy2arr460 + const yyr460 bool = false + yyq460[2] = true + yyq460[3] = true + yyq460[4] = x.Reason != "" + yyq460[5] = x.Message != "" + var yynn460 int + if yyr460 || yy2arr460 { + r.EncodeArrayStart(6) } else { - yynn474 = 1 - for _, b := range yyq474 { + yynn460 = 2 + for _, b := range yyq460 { if b { - yynn474++ + yynn460++ } } - r.EncodeMapStart(yynn474) - yynn474 = 0 + r.EncodeMapStart(yynn460) + yynn460 = 0 } - if yyr474 || yy2arr474 { + if yyr460 || yy2arr460 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq474[0] { - if x.Selector == nil { - r.EncodeNil() + x.Type.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("type")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + x.Type.CodecEncodeSelf(e) + } + if yyr460 || yy2arr460 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym463 := z.EncBinary() + _ = yym463 + if false { + } else if z.HasExtensions() && z.EncExt(x.Status) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Status)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("status")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym464 := z.EncBinary() + _ = yym464 + if false { + } else if z.HasExtensions() && z.EncExt(x.Status) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Status)) + } + } + if yyr460 || yy2arr460 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq460[2] { + yy466 := &x.LastUpdateTime + yym467 := z.EncBinary() + _ = yym467 + if false { + } else if z.HasExtensions() && z.EncExt(yy466) { + } else if yym467 { + z.EncBinaryMarshal(yy466) + } else if !yym467 && z.IsJSONHandle() { + z.EncJSONMarshal(yy466) } else { - yym476 := z.EncBinary() - _ = yym476 - if false { - } else if z.HasExtensions() && z.EncExt(x.Selector) { - } else { - z.EncFallback(x.Selector) - } + z.EncFallback(yy466) } } else { r.EncodeNil() } } else { - if yyq474[0] { + if yyq460[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("selector")) + r.EncodeString(codecSelferC_UTF81234, string("lastUpdateTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Selector == nil { - r.EncodeNil() + yy468 := &x.LastUpdateTime + yym469 := z.EncBinary() + _ = yym469 + if false { + } else if z.HasExtensions() && z.EncExt(yy468) { + } else if yym469 { + z.EncBinaryMarshal(yy468) + } else if !yym469 && z.IsJSONHandle() { + z.EncJSONMarshal(yy468) } else { - yym477 := z.EncBinary() - _ = yym477 - if false { - } else if z.HasExtensions() && z.EncExt(x.Selector) { - } else { - z.EncFallback(x.Selector) - } + z.EncFallback(yy468) } } } - if yyr474 || yy2arr474 { + if yyr460 || yy2arr460 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy479 := &x.Template - yy479.CodecEncodeSelf(e) + if yyq460[3] { + yy471 := &x.LastTransitionTime + yym472 := z.EncBinary() + _ = yym472 + if false { + } else if z.HasExtensions() && z.EncExt(yy471) { + } else if yym472 { + z.EncBinaryMarshal(yy471) + } else if !yym472 && z.IsJSONHandle() { + z.EncJSONMarshal(yy471) + } else { + z.EncFallback(yy471) + } + } else { + r.EncodeNil() + } } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("template")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy480 := &x.Template - yy480.CodecEncodeSelf(e) + if yyq460[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy473 := &x.LastTransitionTime + yym474 := z.EncBinary() + _ = yym474 + if false { + } else if z.HasExtensions() && z.EncExt(yy473) { + } else if yym474 { + z.EncBinaryMarshal(yy473) + } else if !yym474 && z.IsJSONHandle() { + z.EncJSONMarshal(yy473) + } else { + z.EncFallback(yy473) + } + } } - if yyr474 || yy2arr474 { + if yyr460 || yy2arr460 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq460[4] { + yym476 := z.EncBinary() + _ = yym476 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq460[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym477 := z.EncBinary() + _ = yym477 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } + } + if yyr460 || yy2arr460 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq460[5] { + yym479 := z.EncBinary() + _ = yym479 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq460[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("message")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym480 := z.EncBinary() + _ = yym480 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } + } + if yyr460 || yy2arr460 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -5813,7 +5752,7 @@ func (x *DaemonSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *DaemonSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *DeploymentCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -5843,7 +5782,7 @@ func (x *DaemonSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *DeploymentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -5865,6 +5804,694 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { yys483 := string(yys483Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) switch yys483 { + case "type": + if r.TryDecodeAsNil() { + x.Type = "" + } else { + x.Type = DeploymentConditionType(r.DecodeString()) + } + case "status": + if r.TryDecodeAsNil() { + x.Status = "" + } else { + x.Status = pkg2_api.ConditionStatus(r.DecodeString()) + } + case "lastUpdateTime": + if r.TryDecodeAsNil() { + x.LastUpdateTime = pkg1_unversioned.Time{} + } else { + yyv486 := &x.LastUpdateTime + yym487 := z.DecBinary() + _ = yym487 + if false { + } else if z.HasExtensions() && z.DecExt(yyv486) { + } else if yym487 { + z.DecBinaryUnmarshal(yyv486) + } else if !yym487 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv486) + } else { + z.DecFallback(yyv486, false) + } + } + case "lastTransitionTime": + if r.TryDecodeAsNil() { + x.LastTransitionTime = pkg1_unversioned.Time{} + } else { + yyv488 := &x.LastTransitionTime + yym489 := z.DecBinary() + _ = yym489 + if false { + } else if z.HasExtensions() && z.DecExt(yyv488) { + } else if yym489 { + z.DecBinaryUnmarshal(yyv488) + } else if !yym489 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv488) + } else { + z.DecFallback(yyv488, false) + } + } + case "reason": + if r.TryDecodeAsNil() { + x.Reason = "" + } else { + x.Reason = string(r.DecodeString()) + } + case "message": + if r.TryDecodeAsNil() { + x.Message = "" + } else { + x.Message = string(r.DecodeString()) + } + default: + z.DecStructFieldNotFound(-1, yys483) + } // end switch yys483 + } // end for yyj483 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *DeploymentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj492 int + var yyb492 bool + var yyhl492 bool = l >= 0 + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Type = "" + } else { + x.Type = DeploymentConditionType(r.DecodeString()) + } + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Status = "" + } else { + x.Status = pkg2_api.ConditionStatus(r.DecodeString()) + } + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.LastUpdateTime = pkg1_unversioned.Time{} + } else { + yyv495 := &x.LastUpdateTime + yym496 := z.DecBinary() + _ = yym496 + if false { + } else if z.HasExtensions() && z.DecExt(yyv495) { + } else if yym496 { + z.DecBinaryUnmarshal(yyv495) + } else if !yym496 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv495) + } else { + z.DecFallback(yyv495, false) + } + } + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.LastTransitionTime = pkg1_unversioned.Time{} + } else { + yyv497 := &x.LastTransitionTime + yym498 := z.DecBinary() + _ = yym498 + if false { + } else if z.HasExtensions() && z.DecExt(yyv497) { + } else if yym498 { + z.DecBinaryUnmarshal(yyv497) + } else if !yym498 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv497) + } else { + z.DecFallback(yyv497, false) + } + } + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Reason = "" + } else { + x.Reason = string(r.DecodeString()) + } + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Message = "" + } else { + x.Message = string(r.DecodeString()) + } + for { + yyj492++ + if yyhl492 { + yyb492 = yyj492 > l + } else { + yyb492 = r.CheckBreak() + } + if yyb492 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj492-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym501 := z.EncBinary() + _ = yym501 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep502 := !z.EncBinary() + yy2arr502 := z.EncBasicHandle().StructToArray + var yyq502 [4]bool + _, _, _ = yysep502, yyq502, yy2arr502 + const yyr502 bool = false + yyq502[0] = x.Kind != "" + yyq502[1] = x.APIVersion != "" + yyq502[2] = true + var yynn502 int + if yyr502 || yy2arr502 { + r.EncodeArrayStart(4) + } else { + yynn502 = 1 + for _, b := range yyq502 { + if b { + yynn502++ + } + } + r.EncodeMapStart(yynn502) + yynn502 = 0 + } + if yyr502 || yy2arr502 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq502[0] { + yym504 := z.EncBinary() + _ = yym504 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq502[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("kind")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym505 := z.EncBinary() + _ = yym505 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr502 || yy2arr502 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq502[1] { + yym507 := z.EncBinary() + _ = yym507 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq502[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym508 := z.EncBinary() + _ = yym508 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr502 || yy2arr502 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq502[2] { + yy510 := &x.ListMeta + yym511 := z.EncBinary() + _ = yym511 + if false { + } else if z.HasExtensions() && z.EncExt(yy510) { + } else { + z.EncFallback(yy510) + } + } else { + r.EncodeNil() + } + } else { + if yyq502[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy512 := &x.ListMeta + yym513 := z.EncBinary() + _ = yym513 + if false { + } else if z.HasExtensions() && z.EncExt(yy512) { + } else { + z.EncFallback(yy512) + } + } + } + if yyr502 || yy2arr502 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if x.Items == nil { + r.EncodeNil() + } else { + yym515 := z.EncBinary() + _ = yym515 + if false { + } else { + h.encSliceDeployment(([]Deployment)(x.Items), e) + } + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("items")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Items == nil { + r.EncodeNil() + } else { + yym516 := z.EncBinary() + _ = yym516 + if false { + } else { + h.encSliceDeployment(([]Deployment)(x.Items), e) + } + } + } + if yyr502 || yy2arr502 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *DeploymentList) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym517 := z.DecBinary() + _ = yym517 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct518 := r.ContainerType() + if yyct518 == codecSelferValueTypeMap1234 { + yyl518 := r.ReadMapStart() + if yyl518 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl518, d) + } + } else if yyct518 == codecSelferValueTypeArray1234 { + yyl518 := r.ReadArrayStart() + if yyl518 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl518, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *DeploymentList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys519Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys519Slc + var yyhl519 bool = l >= 0 + for yyj519 := 0; ; yyj519++ { + if yyhl519 { + if yyj519 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys519Slc = r.DecodeBytes(yys519Slc, true, true) + yys519 := string(yys519Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys519 { + case "kind": + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + case "apiVersion": + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + case "metadata": + if r.TryDecodeAsNil() { + x.ListMeta = pkg1_unversioned.ListMeta{} + } else { + yyv522 := &x.ListMeta + yym523 := z.DecBinary() + _ = yym523 + if false { + } else if z.HasExtensions() && z.DecExt(yyv522) { + } else { + z.DecFallback(yyv522, false) + } + } + case "items": + if r.TryDecodeAsNil() { + x.Items = nil + } else { + yyv524 := &x.Items + yym525 := z.DecBinary() + _ = yym525 + if false { + } else { + h.decSliceDeployment((*[]Deployment)(yyv524), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys519) + } // end switch yys519 + } // end for yyj519 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj526 int + var yyb526 bool + var yyhl526 bool = l >= 0 + yyj526++ + if yyhl526 { + yyb526 = yyj526 > l + } else { + yyb526 = r.CheckBreak() + } + if yyb526 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + yyj526++ + if yyhl526 { + yyb526 = yyj526 > l + } else { + yyb526 = r.CheckBreak() + } + if yyb526 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + yyj526++ + if yyhl526 { + yyb526 = yyj526 > l + } else { + yyb526 = r.CheckBreak() + } + if yyb526 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ListMeta = pkg1_unversioned.ListMeta{} + } else { + yyv529 := &x.ListMeta + yym530 := z.DecBinary() + _ = yym530 + if false { + } else if z.HasExtensions() && z.DecExt(yyv529) { + } else { + z.DecFallback(yyv529, false) + } + } + yyj526++ + if yyhl526 { + yyb526 = yyj526 > l + } else { + yyb526 = r.CheckBreak() + } + if yyb526 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Items = nil + } else { + yyv531 := &x.Items + yym532 := z.DecBinary() + _ = yym532 + if false { + } else { + h.decSliceDeployment((*[]Deployment)(yyv531), d) + } + } + for { + yyj526++ + if yyhl526 { + yyb526 = yyj526 > l + } else { + yyb526 = r.CheckBreak() + } + if yyb526 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj526-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *DaemonSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym533 := z.EncBinary() + _ = yym533 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep534 := !z.EncBinary() + yy2arr534 := z.EncBasicHandle().StructToArray + var yyq534 [2]bool + _, _, _ = yysep534, yyq534, yy2arr534 + const yyr534 bool = false + yyq534[0] = x.Selector != nil + var yynn534 int + if yyr534 || yy2arr534 { + r.EncodeArrayStart(2) + } else { + yynn534 = 1 + for _, b := range yyq534 { + if b { + yynn534++ + } + } + r.EncodeMapStart(yynn534) + yynn534 = 0 + } + if yyr534 || yy2arr534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq534[0] { + if x.Selector == nil { + r.EncodeNil() + } else { + yym536 := z.EncBinary() + _ = yym536 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq534[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("selector")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Selector == nil { + r.EncodeNil() + } else { + yym537 := z.EncBinary() + _ = yym537 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } + } + if yyr534 || yy2arr534 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy539 := &x.Template + yy539.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("template")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy540 := &x.Template + yy540.CodecEncodeSelf(e) + } + if yyr534 || yy2arr534 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *DaemonSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym541 := z.DecBinary() + _ = yym541 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct542 := r.ContainerType() + if yyct542 == codecSelferValueTypeMap1234 { + yyl542 := r.ReadMapStart() + if yyl542 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl542, d) + } + } else if yyct542 == codecSelferValueTypeArray1234 { + yyl542 := r.ReadArrayStart() + if yyl542 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl542, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys543Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys543Slc + var yyhl543 bool = l >= 0 + for yyj543 := 0; ; yyj543++ { + if yyhl543 { + if yyj543 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys543Slc = r.DecodeBytes(yys543Slc, true, true) + yys543 := string(yys543Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys543 { case "selector": if r.TryDecodeAsNil() { if x.Selector != nil { @@ -5874,8 +6501,8 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym485 := z.DecBinary() - _ = yym485 + yym545 := z.DecBinary() + _ = yym545 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { @@ -5886,13 +6513,13 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv486 := &x.Template - yyv486.CodecDecodeSelf(d) + yyv546 := &x.Template + yyv546.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys483) - } // end switch yys483 - } // end for yyj483 + z.DecStructFieldNotFound(-1, yys543) + } // end switch yys543 + } // end for yyj543 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -5900,16 +6527,16 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj487 int - var yyb487 bool - var yyhl487 bool = l >= 0 - yyj487++ - if yyhl487 { - yyb487 = yyj487 > l + var yyj547 int + var yyb547 bool + var yyhl547 bool = l >= 0 + yyj547++ + if yyhl547 { + yyb547 = yyj547 > l } else { - yyb487 = r.CheckBreak() + yyb547 = r.CheckBreak() } - if yyb487 { + if yyb547 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5922,21 +6549,21 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym489 := z.DecBinary() - _ = yym489 + yym549 := z.DecBinary() + _ = yym549 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { z.DecFallback(x.Selector, false) } } - yyj487++ - if yyhl487 { - yyb487 = yyj487 > l + yyj547++ + if yyhl547 { + yyb547 = yyj547 > l } else { - yyb487 = r.CheckBreak() + yyb547 = r.CheckBreak() } - if yyb487 { + if yyb547 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5944,21 +6571,21 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv490 := &x.Template - yyv490.CodecDecodeSelf(d) + yyv550 := &x.Template + yyv550.CodecDecodeSelf(d) } for { - yyj487++ - if yyhl487 { - yyb487 = yyj487 > l + yyj547++ + if yyhl547 { + yyb547 = yyj547 > l } else { - yyb487 = r.CheckBreak() + yyb547 = r.CheckBreak() } - if yyb487 { + if yyb547 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj487-1, "") + z.DecStructFieldNotFound(yyj547-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -5970,33 +6597,33 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym491 := z.EncBinary() - _ = yym491 + yym551 := z.EncBinary() + _ = yym551 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep492 := !z.EncBinary() - yy2arr492 := z.EncBasicHandle().StructToArray - var yyq492 [4]bool - _, _, _ = yysep492, yyq492, yy2arr492 - const yyr492 bool = false - var yynn492 int - if yyr492 || yy2arr492 { + yysep552 := !z.EncBinary() + yy2arr552 := z.EncBasicHandle().StructToArray + var yyq552 [4]bool + _, _, _ = yysep552, yyq552, yy2arr552 + const yyr552 bool = false + var yynn552 int + if yyr552 || yy2arr552 { r.EncodeArrayStart(4) } else { - yynn492 = 4 - for _, b := range yyq492 { + yynn552 = 4 + for _, b := range yyq552 { if b { - yynn492++ + yynn552++ } } - r.EncodeMapStart(yynn492) - yynn492 = 0 + r.EncodeMapStart(yynn552) + yynn552 = 0 } - if yyr492 || yy2arr492 { + if yyr552 || yy2arr552 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym494 := z.EncBinary() - _ = yym494 + yym554 := z.EncBinary() + _ = yym554 if false { } else { r.EncodeInt(int64(x.CurrentNumberScheduled)) @@ -6005,17 +6632,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("currentNumberScheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym495 := z.EncBinary() - _ = yym495 + yym555 := z.EncBinary() + _ = yym555 if false { } else { r.EncodeInt(int64(x.CurrentNumberScheduled)) } } - if yyr492 || yy2arr492 { + if yyr552 || yy2arr552 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym497 := z.EncBinary() - _ = yym497 + yym557 := z.EncBinary() + _ = yym557 if false { } else { r.EncodeInt(int64(x.NumberMisscheduled)) @@ -6024,17 +6651,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("numberMisscheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym498 := z.EncBinary() - _ = yym498 + yym558 := z.EncBinary() + _ = yym558 if false { } else { r.EncodeInt(int64(x.NumberMisscheduled)) } } - if yyr492 || yy2arr492 { + if yyr552 || yy2arr552 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym500 := z.EncBinary() - _ = yym500 + yym560 := z.EncBinary() + _ = yym560 if false { } else { r.EncodeInt(int64(x.DesiredNumberScheduled)) @@ -6043,17 +6670,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("desiredNumberScheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym501 := z.EncBinary() - _ = yym501 + yym561 := z.EncBinary() + _ = yym561 if false { } else { r.EncodeInt(int64(x.DesiredNumberScheduled)) } } - if yyr492 || yy2arr492 { + if yyr552 || yy2arr552 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym503 := z.EncBinary() - _ = yym503 + yym563 := z.EncBinary() + _ = yym563 if false { } else { r.EncodeInt(int64(x.NumberReady)) @@ -6062,14 +6689,14 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("numberReady")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym504 := z.EncBinary() - _ = yym504 + yym564 := z.EncBinary() + _ = yym564 if false { } else { r.EncodeInt(int64(x.NumberReady)) } } - if yyr492 || yy2arr492 { + if yyr552 || yy2arr552 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6082,25 +6709,25 @@ func (x *DaemonSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym505 := z.DecBinary() - _ = yym505 + yym565 := z.DecBinary() + _ = yym565 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct506 := r.ContainerType() - if yyct506 == codecSelferValueTypeMap1234 { - yyl506 := r.ReadMapStart() - if yyl506 == 0 { + yyct566 := r.ContainerType() + if yyct566 == codecSelferValueTypeMap1234 { + yyl566 := r.ReadMapStart() + if yyl566 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl506, d) + x.codecDecodeSelfFromMap(yyl566, d) } - } else if yyct506 == codecSelferValueTypeArray1234 { - yyl506 := r.ReadArrayStart() - if yyl506 == 0 { + } else if yyct566 == codecSelferValueTypeArray1234 { + yyl566 := r.ReadArrayStart() + if yyl566 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl506, d) + x.codecDecodeSelfFromArray(yyl566, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6112,12 +6739,12 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys507Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys507Slc - var yyhl507 bool = l >= 0 - for yyj507 := 0; ; yyj507++ { - if yyhl507 { - if yyj507 >= l { + var yys567Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys567Slc + var yyhl567 bool = l >= 0 + for yyj567 := 0; ; yyj567++ { + if yyhl567 { + if yyj567 >= l { break } } else { @@ -6126,10 +6753,10 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys507Slc = r.DecodeBytes(yys507Slc, true, true) - yys507 := string(yys507Slc) + yys567Slc = r.DecodeBytes(yys567Slc, true, true) + yys567 := string(yys567Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys507 { + switch yys567 { case "currentNumberScheduled": if r.TryDecodeAsNil() { x.CurrentNumberScheduled = 0 @@ -6155,9 +6782,9 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.NumberReady = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys507) - } // end switch yys507 - } // end for yyj507 + z.DecStructFieldNotFound(-1, yys567) + } // end switch yys567 + } // end for yyj567 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6165,16 +6792,16 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj512 int - var yyb512 bool - var yyhl512 bool = l >= 0 - yyj512++ - if yyhl512 { - yyb512 = yyj512 > l + var yyj572 int + var yyb572 bool + var yyhl572 bool = l >= 0 + yyj572++ + if yyhl572 { + yyb572 = yyj572 > l } else { - yyb512 = r.CheckBreak() + yyb572 = r.CheckBreak() } - if yyb512 { + if yyb572 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6184,13 +6811,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.CurrentNumberScheduled = int32(r.DecodeInt(32)) } - yyj512++ - if yyhl512 { - yyb512 = yyj512 > l + yyj572++ + if yyhl572 { + yyb572 = yyj572 > l } else { - yyb512 = r.CheckBreak() + yyb572 = r.CheckBreak() } - if yyb512 { + if yyb572 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6200,13 +6827,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.NumberMisscheduled = int32(r.DecodeInt(32)) } - yyj512++ - if yyhl512 { - yyb512 = yyj512 > l + yyj572++ + if yyhl572 { + yyb572 = yyj572 > l } else { - yyb512 = r.CheckBreak() + yyb572 = r.CheckBreak() } - if yyb512 { + if yyb572 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6216,13 +6843,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.DesiredNumberScheduled = int32(r.DecodeInt(32)) } - yyj512++ - if yyhl512 { - yyb512 = yyj512 > l + yyj572++ + if yyhl572 { + yyb572 = yyj572 > l } else { - yyb512 = r.CheckBreak() + yyb572 = r.CheckBreak() } - if yyb512 { + if yyb572 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6233,17 +6860,17 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.NumberReady = int32(r.DecodeInt(32)) } for { - yyj512++ - if yyhl512 { - yyb512 = yyj512 > l + yyj572++ + if yyhl572 { + yyb572 = yyj572 > l } else { - yyb512 = r.CheckBreak() + yyb572 = r.CheckBreak() } - if yyb512 { + if yyb572 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj512-1, "") + z.DecStructFieldNotFound(yyj572-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6255,39 +6882,39 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym517 := z.EncBinary() - _ = yym517 + yym577 := z.EncBinary() + _ = yym577 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep518 := !z.EncBinary() - yy2arr518 := z.EncBasicHandle().StructToArray - var yyq518 [5]bool - _, _, _ = yysep518, yyq518, yy2arr518 - const yyr518 bool = false - yyq518[0] = x.Kind != "" - yyq518[1] = x.APIVersion != "" - yyq518[2] = true - yyq518[3] = true - yyq518[4] = true - var yynn518 int - if yyr518 || yy2arr518 { + yysep578 := !z.EncBinary() + yy2arr578 := z.EncBasicHandle().StructToArray + var yyq578 [5]bool + _, _, _ = yysep578, yyq578, yy2arr578 + const yyr578 bool = false + yyq578[0] = x.Kind != "" + yyq578[1] = x.APIVersion != "" + yyq578[2] = true + yyq578[3] = true + yyq578[4] = true + var yynn578 int + if yyr578 || yy2arr578 { r.EncodeArrayStart(5) } else { - yynn518 = 0 - for _, b := range yyq518 { + yynn578 = 0 + for _, b := range yyq578 { if b { - yynn518++ + yynn578++ } } - r.EncodeMapStart(yynn518) - yynn518 = 0 + r.EncodeMapStart(yynn578) + yynn578 = 0 } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq518[0] { - yym520 := z.EncBinary() - _ = yym520 + if yyq578[0] { + yym580 := z.EncBinary() + _ = yym580 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -6296,23 +6923,23 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq518[0] { + if yyq578[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym521 := z.EncBinary() - _ = yym521 + yym581 := z.EncBinary() + _ = yym581 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq518[1] { - yym523 := z.EncBinary() - _ = yym523 + if yyq578[1] { + yym583 := z.EncBinary() + _ = yym583 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -6321,70 +6948,70 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq518[1] { + if yyq578[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym524 := z.EncBinary() - _ = yym524 + yym584 := z.EncBinary() + _ = yym584 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq518[2] { - yy526 := &x.ObjectMeta - yy526.CodecEncodeSelf(e) + if yyq578[2] { + yy586 := &x.ObjectMeta + yy586.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq518[2] { + if yyq578[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy527 := &x.ObjectMeta - yy527.CodecEncodeSelf(e) + yy587 := &x.ObjectMeta + yy587.CodecEncodeSelf(e) } } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq518[3] { - yy529 := &x.Spec - yy529.CodecEncodeSelf(e) + if yyq578[3] { + yy589 := &x.Spec + yy589.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq518[3] { + if yyq578[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy530 := &x.Spec - yy530.CodecEncodeSelf(e) + yy590 := &x.Spec + yy590.CodecEncodeSelf(e) } } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq518[4] { - yy532 := &x.Status - yy532.CodecEncodeSelf(e) + if yyq578[4] { + yy592 := &x.Status + yy592.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq518[4] { + if yyq578[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy533 := &x.Status - yy533.CodecEncodeSelf(e) + yy593 := &x.Status + yy593.CodecEncodeSelf(e) } } - if yyr518 || yy2arr518 { + if yyr578 || yy2arr578 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6397,25 +7024,25 @@ func (x *DaemonSet) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym534 := z.DecBinary() - _ = yym534 + yym594 := z.DecBinary() + _ = yym594 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct535 := r.ContainerType() - if yyct535 == codecSelferValueTypeMap1234 { - yyl535 := r.ReadMapStart() - if yyl535 == 0 { + yyct595 := r.ContainerType() + if yyct595 == codecSelferValueTypeMap1234 { + yyl595 := r.ReadMapStart() + if yyl595 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl535, d) + x.codecDecodeSelfFromMap(yyl595, d) } - } else if yyct535 == codecSelferValueTypeArray1234 { - yyl535 := r.ReadArrayStart() - if yyl535 == 0 { + } else if yyct595 == codecSelferValueTypeArray1234 { + yyl595 := r.ReadArrayStart() + if yyl595 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl535, d) + x.codecDecodeSelfFromArray(yyl595, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6427,12 +7054,12 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys536Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys536Slc - var yyhl536 bool = l >= 0 - for yyj536 := 0; ; yyj536++ { - if yyhl536 { - if yyj536 >= l { + var yys596Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys596Slc + var yyhl596 bool = l >= 0 + for yyj596 := 0; ; yyj596++ { + if yyhl596 { + if yyj596 >= l { break } } else { @@ -6441,10 +7068,10 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys536Slc = r.DecodeBytes(yys536Slc, true, true) - yys536 := string(yys536Slc) + yys596Slc = r.DecodeBytes(yys596Slc, true, true) + yys596 := string(yys596Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys536 { + switch yys596 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -6461,27 +7088,27 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv539 := &x.ObjectMeta - yyv539.CodecDecodeSelf(d) + yyv599 := &x.ObjectMeta + yyv599.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = DaemonSetSpec{} } else { - yyv540 := &x.Spec - yyv540.CodecDecodeSelf(d) + yyv600 := &x.Spec + yyv600.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = DaemonSetStatus{} } else { - yyv541 := &x.Status - yyv541.CodecDecodeSelf(d) + yyv601 := &x.Status + yyv601.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys536) - } // end switch yys536 - } // end for yyj536 + z.DecStructFieldNotFound(-1, yys596) + } // end switch yys596 + } // end for yyj596 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6489,16 +7116,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj542 int - var yyb542 bool - var yyhl542 bool = l >= 0 - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + var yyj602 int + var yyb602 bool + var yyhl602 bool = l >= 0 + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6508,13 +7135,13 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6524,13 +7151,13 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6538,16 +7165,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv545 := &x.ObjectMeta - yyv545.CodecDecodeSelf(d) + yyv605 := &x.ObjectMeta + yyv605.CodecDecodeSelf(d) } - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6555,16 +7182,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = DaemonSetSpec{} } else { - yyv546 := &x.Spec - yyv546.CodecDecodeSelf(d) + yyv606 := &x.Spec + yyv606.CodecDecodeSelf(d) } - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6572,21 +7199,21 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = DaemonSetStatus{} } else { - yyv547 := &x.Status - yyv547.CodecDecodeSelf(d) + yyv607 := &x.Status + yyv607.CodecDecodeSelf(d) } for { - yyj542++ - if yyhl542 { - yyb542 = yyj542 > l + yyj602++ + if yyhl602 { + yyb602 = yyj602 > l } else { - yyb542 = r.CheckBreak() + yyb602 = r.CheckBreak() } - if yyb542 { + if yyb602 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj542-1, "") + z.DecStructFieldNotFound(yyj602-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6598,37 +7225,37 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym548 := z.EncBinary() - _ = yym548 + yym608 := z.EncBinary() + _ = yym608 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep549 := !z.EncBinary() - yy2arr549 := z.EncBasicHandle().StructToArray - var yyq549 [4]bool - _, _, _ = yysep549, yyq549, yy2arr549 - const yyr549 bool = false - yyq549[0] = x.Kind != "" - yyq549[1] = x.APIVersion != "" - yyq549[2] = true - var yynn549 int - if yyr549 || yy2arr549 { + yysep609 := !z.EncBinary() + yy2arr609 := z.EncBasicHandle().StructToArray + var yyq609 [4]bool + _, _, _ = yysep609, yyq609, yy2arr609 + const yyr609 bool = false + yyq609[0] = x.Kind != "" + yyq609[1] = x.APIVersion != "" + yyq609[2] = true + var yynn609 int + if yyr609 || yy2arr609 { r.EncodeArrayStart(4) } else { - yynn549 = 1 - for _, b := range yyq549 { + yynn609 = 1 + for _, b := range yyq609 { if b { - yynn549++ + yynn609++ } } - r.EncodeMapStart(yynn549) - yynn549 = 0 + r.EncodeMapStart(yynn609) + yynn609 = 0 } - if yyr549 || yy2arr549 { + if yyr609 || yy2arr609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq549[0] { - yym551 := z.EncBinary() - _ = yym551 + if yyq609[0] { + yym611 := z.EncBinary() + _ = yym611 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -6637,23 +7264,23 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq549[0] { + if yyq609[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym552 := z.EncBinary() - _ = yym552 + yym612 := z.EncBinary() + _ = yym612 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr549 || yy2arr549 { + if yyr609 || yy2arr609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq549[1] { - yym554 := z.EncBinary() - _ = yym554 + if yyq609[1] { + yym614 := z.EncBinary() + _ = yym614 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -6662,54 +7289,54 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq549[1] { + if yyq609[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym555 := z.EncBinary() - _ = yym555 + yym615 := z.EncBinary() + _ = yym615 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr549 || yy2arr549 { + if yyr609 || yy2arr609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq549[2] { - yy557 := &x.ListMeta - yym558 := z.EncBinary() - _ = yym558 + if yyq609[2] { + yy617 := &x.ListMeta + yym618 := z.EncBinary() + _ = yym618 if false { - } else if z.HasExtensions() && z.EncExt(yy557) { + } else if z.HasExtensions() && z.EncExt(yy617) { } else { - z.EncFallback(yy557) + z.EncFallback(yy617) } } else { r.EncodeNil() } } else { - if yyq549[2] { + if yyq609[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy559 := &x.ListMeta - yym560 := z.EncBinary() - _ = yym560 + yy619 := &x.ListMeta + yym620 := z.EncBinary() + _ = yym620 if false { - } else if z.HasExtensions() && z.EncExt(yy559) { + } else if z.HasExtensions() && z.EncExt(yy619) { } else { - z.EncFallback(yy559) + z.EncFallback(yy619) } } } - if yyr549 || yy2arr549 { + if yyr609 || yy2arr609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym562 := z.EncBinary() - _ = yym562 + yym622 := z.EncBinary() + _ = yym622 if false { } else { h.encSliceDaemonSet(([]DaemonSet)(x.Items), e) @@ -6722,15 +7349,15 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym563 := z.EncBinary() - _ = yym563 + yym623 := z.EncBinary() + _ = yym623 if false { } else { h.encSliceDaemonSet(([]DaemonSet)(x.Items), e) } } } - if yyr549 || yy2arr549 { + if yyr609 || yy2arr609 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6743,25 +7370,25 @@ func (x *DaemonSetList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym564 := z.DecBinary() - _ = yym564 + yym624 := z.DecBinary() + _ = yym624 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct565 := r.ContainerType() - if yyct565 == codecSelferValueTypeMap1234 { - yyl565 := r.ReadMapStart() - if yyl565 == 0 { + yyct625 := r.ContainerType() + if yyct625 == codecSelferValueTypeMap1234 { + yyl625 := r.ReadMapStart() + if yyl625 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl565, d) + x.codecDecodeSelfFromMap(yyl625, d) } - } else if yyct565 == codecSelferValueTypeArray1234 { - yyl565 := r.ReadArrayStart() - if yyl565 == 0 { + } else if yyct625 == codecSelferValueTypeArray1234 { + yyl625 := r.ReadArrayStart() + if yyl625 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl565, d) + x.codecDecodeSelfFromArray(yyl625, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6773,12 +7400,12 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys566Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys566Slc - var yyhl566 bool = l >= 0 - for yyj566 := 0; ; yyj566++ { - if yyhl566 { - if yyj566 >= l { + var yys626Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys626Slc + var yyhl626 bool = l >= 0 + for yyj626 := 0; ; yyj626++ { + if yyhl626 { + if yyj626 >= l { break } } else { @@ -6787,10 +7414,10 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys566Slc = r.DecodeBytes(yys566Slc, true, true) - yys566 := string(yys566Slc) + yys626Slc = r.DecodeBytes(yys626Slc, true, true) + yys626 := string(yys626Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys566 { + switch yys626 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -6807,31 +7434,31 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv569 := &x.ListMeta - yym570 := z.DecBinary() - _ = yym570 + yyv629 := &x.ListMeta + yym630 := z.DecBinary() + _ = yym630 if false { - } else if z.HasExtensions() && z.DecExt(yyv569) { + } else if z.HasExtensions() && z.DecExt(yyv629) { } else { - z.DecFallback(yyv569, false) + z.DecFallback(yyv629, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv571 := &x.Items - yym572 := z.DecBinary() - _ = yym572 + yyv631 := &x.Items + yym632 := z.DecBinary() + _ = yym632 if false { } else { - h.decSliceDaemonSet((*[]DaemonSet)(yyv571), d) + h.decSliceDaemonSet((*[]DaemonSet)(yyv631), d) } } default: - z.DecStructFieldNotFound(-1, yys566) - } // end switch yys566 - } // end for yyj566 + z.DecStructFieldNotFound(-1, yys626) + } // end switch yys626 + } // end for yyj626 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6839,16 +7466,16 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj573 int - var yyb573 bool - var yyhl573 bool = l >= 0 - yyj573++ - if yyhl573 { - yyb573 = yyj573 > l + var yyj633 int + var yyb633 bool + var yyhl633 bool = l >= 0 + yyj633++ + if yyhl633 { + yyb633 = yyj633 > l } else { - yyb573 = r.CheckBreak() + yyb633 = r.CheckBreak() } - if yyb573 { + if yyb633 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6858,13 +7485,13 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj573++ - if yyhl573 { - yyb573 = yyj573 > l + yyj633++ + if yyhl633 { + yyb633 = yyj633 > l } else { - yyb573 = r.CheckBreak() + yyb633 = r.CheckBreak() } - if yyb573 { + if yyb633 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6874,13 +7501,13 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj573++ - if yyhl573 { - yyb573 = yyj573 > l + yyj633++ + if yyhl633 { + yyb633 = yyj633 > l } else { - yyb573 = r.CheckBreak() + yyb633 = r.CheckBreak() } - if yyb573 { + if yyb633 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6888,22 +7515,22 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv576 := &x.ListMeta - yym577 := z.DecBinary() - _ = yym577 + yyv636 := &x.ListMeta + yym637 := z.DecBinary() + _ = yym637 if false { - } else if z.HasExtensions() && z.DecExt(yyv576) { + } else if z.HasExtensions() && z.DecExt(yyv636) { } else { - z.DecFallback(yyv576, false) + z.DecFallback(yyv636, false) } } - yyj573++ - if yyhl573 { - yyb573 = yyj573 > l + yyj633++ + if yyhl633 { + yyb633 = yyj633 > l } else { - yyb573 = r.CheckBreak() + yyb633 = r.CheckBreak() } - if yyb573 { + if yyb633 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6911,26 +7538,26 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv578 := &x.Items - yym579 := z.DecBinary() - _ = yym579 + yyv638 := &x.Items + yym639 := z.DecBinary() + _ = yym639 if false { } else { - h.decSliceDaemonSet((*[]DaemonSet)(yyv578), d) + h.decSliceDaemonSet((*[]DaemonSet)(yyv638), d) } } for { - yyj573++ - if yyhl573 { - yyb573 = yyj573 > l + yyj633++ + if yyhl633 { + yyb633 = yyj633 > l } else { - yyb573 = r.CheckBreak() + yyb633 = r.CheckBreak() } - if yyb573 { + if yyb633 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj573-1, "") + z.DecStructFieldNotFound(yyj633-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6942,37 +7569,37 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym580 := z.EncBinary() - _ = yym580 + yym640 := z.EncBinary() + _ = yym640 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep581 := !z.EncBinary() - yy2arr581 := z.EncBasicHandle().StructToArray - var yyq581 [4]bool - _, _, _ = yysep581, yyq581, yy2arr581 - const yyr581 bool = false - yyq581[0] = x.Kind != "" - yyq581[1] = x.APIVersion != "" - yyq581[2] = true - var yynn581 int - if yyr581 || yy2arr581 { + yysep641 := !z.EncBinary() + yy2arr641 := z.EncBasicHandle().StructToArray + var yyq641 [4]bool + _, _, _ = yysep641, yyq641, yy2arr641 + const yyr641 bool = false + yyq641[0] = x.Kind != "" + yyq641[1] = x.APIVersion != "" + yyq641[2] = true + var yynn641 int + if yyr641 || yy2arr641 { r.EncodeArrayStart(4) } else { - yynn581 = 1 - for _, b := range yyq581 { + yynn641 = 1 + for _, b := range yyq641 { if b { - yynn581++ + yynn641++ } } - r.EncodeMapStart(yynn581) - yynn581 = 0 + r.EncodeMapStart(yynn641) + yynn641 = 0 } - if yyr581 || yy2arr581 { + if yyr641 || yy2arr641 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[0] { - yym583 := z.EncBinary() - _ = yym583 + if yyq641[0] { + yym643 := z.EncBinary() + _ = yym643 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -6981,23 +7608,23 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq581[0] { + if yyq641[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym584 := z.EncBinary() - _ = yym584 + yym644 := z.EncBinary() + _ = yym644 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr581 || yy2arr581 { + if yyr641 || yy2arr641 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[1] { - yym586 := z.EncBinary() - _ = yym586 + if yyq641[1] { + yym646 := z.EncBinary() + _ = yym646 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -7006,54 +7633,54 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq581[1] { + if yyq641[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym587 := z.EncBinary() - _ = yym587 + yym647 := z.EncBinary() + _ = yym647 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr581 || yy2arr581 { + if yyr641 || yy2arr641 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[2] { - yy589 := &x.ListMeta - yym590 := z.EncBinary() - _ = yym590 + if yyq641[2] { + yy649 := &x.ListMeta + yym650 := z.EncBinary() + _ = yym650 if false { - } else if z.HasExtensions() && z.EncExt(yy589) { + } else if z.HasExtensions() && z.EncExt(yy649) { } else { - z.EncFallback(yy589) + z.EncFallback(yy649) } } else { r.EncodeNil() } } else { - if yyq581[2] { + if yyq641[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy591 := &x.ListMeta - yym592 := z.EncBinary() - _ = yym592 + yy651 := &x.ListMeta + yym652 := z.EncBinary() + _ = yym652 if false { - } else if z.HasExtensions() && z.EncExt(yy591) { + } else if z.HasExtensions() && z.EncExt(yy651) { } else { - z.EncFallback(yy591) + z.EncFallback(yy651) } } } - if yyr581 || yy2arr581 { + if yyr641 || yy2arr641 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym594 := z.EncBinary() - _ = yym594 + yym654 := z.EncBinary() + _ = yym654 if false { } else { h.encSliceThirdPartyResourceData(([]ThirdPartyResourceData)(x.Items), e) @@ -7066,15 +7693,15 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym595 := z.EncBinary() - _ = yym595 + yym655 := z.EncBinary() + _ = yym655 if false { } else { h.encSliceThirdPartyResourceData(([]ThirdPartyResourceData)(x.Items), e) } } } - if yyr581 || yy2arr581 { + if yyr641 || yy2arr641 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7087,25 +7714,25 @@ func (x *ThirdPartyResourceDataList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym596 := z.DecBinary() - _ = yym596 + yym656 := z.DecBinary() + _ = yym656 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct597 := r.ContainerType() - if yyct597 == codecSelferValueTypeMap1234 { - yyl597 := r.ReadMapStart() - if yyl597 == 0 { + yyct657 := r.ContainerType() + if yyct657 == codecSelferValueTypeMap1234 { + yyl657 := r.ReadMapStart() + if yyl657 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl597, d) + x.codecDecodeSelfFromMap(yyl657, d) } - } else if yyct597 == codecSelferValueTypeArray1234 { - yyl597 := r.ReadArrayStart() - if yyl597 == 0 { + } else if yyct657 == codecSelferValueTypeArray1234 { + yyl657 := r.ReadArrayStart() + if yyl657 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl597, d) + x.codecDecodeSelfFromArray(yyl657, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7117,12 +7744,12 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys598Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys598Slc - var yyhl598 bool = l >= 0 - for yyj598 := 0; ; yyj598++ { - if yyhl598 { - if yyj598 >= l { + var yys658Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys658Slc + var yyhl658 bool = l >= 0 + for yyj658 := 0; ; yyj658++ { + if yyhl658 { + if yyj658 >= l { break } } else { @@ -7131,10 +7758,10 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys598Slc = r.DecodeBytes(yys598Slc, true, true) - yys598 := string(yys598Slc) + yys658Slc = r.DecodeBytes(yys658Slc, true, true) + yys658 := string(yys658Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys598 { + switch yys658 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -7151,31 +7778,31 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv601 := &x.ListMeta - yym602 := z.DecBinary() - _ = yym602 + yyv661 := &x.ListMeta + yym662 := z.DecBinary() + _ = yym662 if false { - } else if z.HasExtensions() && z.DecExt(yyv601) { + } else if z.HasExtensions() && z.DecExt(yyv661) { } else { - z.DecFallback(yyv601, false) + z.DecFallback(yyv661, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv603 := &x.Items - yym604 := z.DecBinary() - _ = yym604 + yyv663 := &x.Items + yym664 := z.DecBinary() + _ = yym664 if false { } else { - h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv603), d) + h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv663), d) } } default: - z.DecStructFieldNotFound(-1, yys598) - } // end switch yys598 - } // end for yyj598 + z.DecStructFieldNotFound(-1, yys658) + } // end switch yys658 + } // end for yyj658 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7183,16 +7810,16 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj605 int - var yyb605 bool - var yyhl605 bool = l >= 0 - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + var yyj665 int + var yyb665 bool + var yyhl665 bool = l >= 0 + yyj665++ + if yyhl665 { + yyb665 = yyj665 > l } else { - yyb605 = r.CheckBreak() + yyb665 = r.CheckBreak() } - if yyb605 { + if yyb665 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7202,13 +7829,13 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 } else { x.Kind = string(r.DecodeString()) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj665++ + if yyhl665 { + yyb665 = yyj665 > l } else { - yyb605 = r.CheckBreak() + yyb665 = r.CheckBreak() } - if yyb605 { + if yyb665 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7218,13 +7845,13 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 } else { x.APIVersion = string(r.DecodeString()) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj665++ + if yyhl665 { + yyb665 = yyj665 > l } else { - yyb605 = r.CheckBreak() + yyb665 = r.CheckBreak() } - if yyb605 { + if yyb665 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7232,22 +7859,22 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv608 := &x.ListMeta - yym609 := z.DecBinary() - _ = yym609 + yyv668 := &x.ListMeta + yym669 := z.DecBinary() + _ = yym669 if false { - } else if z.HasExtensions() && z.DecExt(yyv608) { + } else if z.HasExtensions() && z.DecExt(yyv668) { } else { - z.DecFallback(yyv608, false) + z.DecFallback(yyv668, false) } } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj665++ + if yyhl665 { + yyb665 = yyj665 > l } else { - yyb605 = r.CheckBreak() + yyb665 = r.CheckBreak() } - if yyb605 { + if yyb665 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7255,26 +7882,26 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 if r.TryDecodeAsNil() { x.Items = nil } else { - yyv610 := &x.Items - yym611 := z.DecBinary() - _ = yym611 + yyv670 := &x.Items + yym671 := z.DecBinary() + _ = yym671 if false { } else { - h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv610), d) + h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv670), d) } } for { - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj665++ + if yyhl665 { + yyb665 = yyj665 > l } else { - yyb605 = r.CheckBreak() + yyb665 = r.CheckBreak() } - if yyb605 { + if yyb665 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj605-1, "") + z.DecStructFieldNotFound(yyj665-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7286,39 +7913,39 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym612 := z.EncBinary() - _ = yym612 + yym672 := z.EncBinary() + _ = yym672 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep613 := !z.EncBinary() - yy2arr613 := z.EncBasicHandle().StructToArray - var yyq613 [5]bool - _, _, _ = yysep613, yyq613, yy2arr613 - const yyr613 bool = false - yyq613[0] = x.Kind != "" - yyq613[1] = x.APIVersion != "" - yyq613[2] = true - yyq613[3] = true - yyq613[4] = true - var yynn613 int - if yyr613 || yy2arr613 { + yysep673 := !z.EncBinary() + yy2arr673 := z.EncBasicHandle().StructToArray + var yyq673 [5]bool + _, _, _ = yysep673, yyq673, yy2arr673 + const yyr673 bool = false + yyq673[0] = x.Kind != "" + yyq673[1] = x.APIVersion != "" + yyq673[2] = true + yyq673[3] = true + yyq673[4] = true + var yynn673 int + if yyr673 || yy2arr673 { r.EncodeArrayStart(5) } else { - yynn613 = 0 - for _, b := range yyq613 { + yynn673 = 0 + for _, b := range yyq673 { if b { - yynn613++ + yynn673++ } } - r.EncodeMapStart(yynn613) - yynn613 = 0 + r.EncodeMapStart(yynn673) + yynn673 = 0 } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq613[0] { - yym615 := z.EncBinary() - _ = yym615 + if yyq673[0] { + yym675 := z.EncBinary() + _ = yym675 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -7327,23 +7954,23 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq613[0] { + if yyq673[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym616 := z.EncBinary() - _ = yym616 + yym676 := z.EncBinary() + _ = yym676 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq613[1] { - yym618 := z.EncBinary() - _ = yym618 + if yyq673[1] { + yym678 := z.EncBinary() + _ = yym678 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -7352,70 +7979,70 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq613[1] { + if yyq673[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym619 := z.EncBinary() - _ = yym619 + yym679 := z.EncBinary() + _ = yym679 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq613[2] { - yy621 := &x.ObjectMeta - yy621.CodecEncodeSelf(e) + if yyq673[2] { + yy681 := &x.ObjectMeta + yy681.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq613[2] { + if yyq673[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy622 := &x.ObjectMeta - yy622.CodecEncodeSelf(e) + yy682 := &x.ObjectMeta + yy682.CodecEncodeSelf(e) } } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq613[3] { - yy624 := &x.Spec - yy624.CodecEncodeSelf(e) + if yyq673[3] { + yy684 := &x.Spec + yy684.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq613[3] { + if yyq673[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy625 := &x.Spec - yy625.CodecEncodeSelf(e) + yy685 := &x.Spec + yy685.CodecEncodeSelf(e) } } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq613[4] { - yy627 := &x.Status - yy627.CodecEncodeSelf(e) + if yyq673[4] { + yy687 := &x.Status + yy687.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq613[4] { + if yyq673[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy628 := &x.Status - yy628.CodecEncodeSelf(e) + yy688 := &x.Status + yy688.CodecEncodeSelf(e) } } - if yyr613 || yy2arr613 { + if yyr673 || yy2arr673 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7428,25 +8055,25 @@ func (x *Ingress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym629 := z.DecBinary() - _ = yym629 + yym689 := z.DecBinary() + _ = yym689 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct630 := r.ContainerType() - if yyct630 == codecSelferValueTypeMap1234 { - yyl630 := r.ReadMapStart() - if yyl630 == 0 { + yyct690 := r.ContainerType() + if yyct690 == codecSelferValueTypeMap1234 { + yyl690 := r.ReadMapStart() + if yyl690 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl630, d) + x.codecDecodeSelfFromMap(yyl690, d) } - } else if yyct630 == codecSelferValueTypeArray1234 { - yyl630 := r.ReadArrayStart() - if yyl630 == 0 { + } else if yyct690 == codecSelferValueTypeArray1234 { + yyl690 := r.ReadArrayStart() + if yyl690 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl630, d) + x.codecDecodeSelfFromArray(yyl690, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7458,12 +8085,12 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys631Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys631Slc - var yyhl631 bool = l >= 0 - for yyj631 := 0; ; yyj631++ { - if yyhl631 { - if yyj631 >= l { + var yys691Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys691Slc + var yyhl691 bool = l >= 0 + for yyj691 := 0; ; yyj691++ { + if yyhl691 { + if yyj691 >= l { break } } else { @@ -7472,10 +8099,10 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys631Slc = r.DecodeBytes(yys631Slc, true, true) - yys631 := string(yys631Slc) + yys691Slc = r.DecodeBytes(yys691Slc, true, true) + yys691 := string(yys691Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys631 { + switch yys691 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -7492,27 +8119,27 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv634 := &x.ObjectMeta - yyv634.CodecDecodeSelf(d) + yyv694 := &x.ObjectMeta + yyv694.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = IngressSpec{} } else { - yyv635 := &x.Spec - yyv635.CodecDecodeSelf(d) + yyv695 := &x.Spec + yyv695.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = IngressStatus{} } else { - yyv636 := &x.Status - yyv636.CodecDecodeSelf(d) + yyv696 := &x.Status + yyv696.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys631) - } // end switch yys631 - } // end for yyj631 + z.DecStructFieldNotFound(-1, yys691) + } // end switch yys691 + } // end for yyj691 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7520,16 +8147,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj637 int - var yyb637 bool - var yyhl637 bool = l >= 0 - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + var yyj697 int + var yyb697 bool + var yyhl697 bool = l >= 0 + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7539,13 +8166,13 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7555,13 +8182,13 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7569,16 +8196,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv640 := &x.ObjectMeta - yyv640.CodecDecodeSelf(d) + yyv700 := &x.ObjectMeta + yyv700.CodecDecodeSelf(d) } - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7586,16 +8213,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = IngressSpec{} } else { - yyv641 := &x.Spec - yyv641.CodecDecodeSelf(d) + yyv701 := &x.Spec + yyv701.CodecDecodeSelf(d) } - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7603,21 +8230,21 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = IngressStatus{} } else { - yyv642 := &x.Status - yyv642.CodecDecodeSelf(d) + yyv702 := &x.Status + yyv702.CodecDecodeSelf(d) } for { - yyj637++ - if yyhl637 { - yyb637 = yyj637 > l + yyj697++ + if yyhl697 { + yyb697 = yyj697 > l } else { - yyb637 = r.CheckBreak() + yyb697 = r.CheckBreak() } - if yyb637 { + if yyb697 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj637-1, "") + z.DecStructFieldNotFound(yyj697-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7629,37 +8256,37 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym643 := z.EncBinary() - _ = yym643 + yym703 := z.EncBinary() + _ = yym703 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep644 := !z.EncBinary() - yy2arr644 := z.EncBasicHandle().StructToArray - var yyq644 [4]bool - _, _, _ = yysep644, yyq644, yy2arr644 - const yyr644 bool = false - yyq644[0] = x.Kind != "" - yyq644[1] = x.APIVersion != "" - yyq644[2] = true - var yynn644 int - if yyr644 || yy2arr644 { + yysep704 := !z.EncBinary() + yy2arr704 := z.EncBasicHandle().StructToArray + var yyq704 [4]bool + _, _, _ = yysep704, yyq704, yy2arr704 + const yyr704 bool = false + yyq704[0] = x.Kind != "" + yyq704[1] = x.APIVersion != "" + yyq704[2] = true + var yynn704 int + if yyr704 || yy2arr704 { r.EncodeArrayStart(4) } else { - yynn644 = 1 - for _, b := range yyq644 { + yynn704 = 1 + for _, b := range yyq704 { if b { - yynn644++ + yynn704++ } } - r.EncodeMapStart(yynn644) - yynn644 = 0 + r.EncodeMapStart(yynn704) + yynn704 = 0 } - if yyr644 || yy2arr644 { + if yyr704 || yy2arr704 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq644[0] { - yym646 := z.EncBinary() - _ = yym646 + if yyq704[0] { + yym706 := z.EncBinary() + _ = yym706 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -7668,23 +8295,23 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq644[0] { + if yyq704[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym647 := z.EncBinary() - _ = yym647 + yym707 := z.EncBinary() + _ = yym707 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr644 || yy2arr644 { + if yyr704 || yy2arr704 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq644[1] { - yym649 := z.EncBinary() - _ = yym649 + if yyq704[1] { + yym709 := z.EncBinary() + _ = yym709 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -7693,54 +8320,54 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq644[1] { + if yyq704[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym650 := z.EncBinary() - _ = yym650 + yym710 := z.EncBinary() + _ = yym710 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr644 || yy2arr644 { + if yyr704 || yy2arr704 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq644[2] { - yy652 := &x.ListMeta - yym653 := z.EncBinary() - _ = yym653 + if yyq704[2] { + yy712 := &x.ListMeta + yym713 := z.EncBinary() + _ = yym713 if false { - } else if z.HasExtensions() && z.EncExt(yy652) { + } else if z.HasExtensions() && z.EncExt(yy712) { } else { - z.EncFallback(yy652) + z.EncFallback(yy712) } } else { r.EncodeNil() } } else { - if yyq644[2] { + if yyq704[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy654 := &x.ListMeta - yym655 := z.EncBinary() - _ = yym655 + yy714 := &x.ListMeta + yym715 := z.EncBinary() + _ = yym715 if false { - } else if z.HasExtensions() && z.EncExt(yy654) { + } else if z.HasExtensions() && z.EncExt(yy714) { } else { - z.EncFallback(yy654) + z.EncFallback(yy714) } } } - if yyr644 || yy2arr644 { + if yyr704 || yy2arr704 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym657 := z.EncBinary() - _ = yym657 + yym717 := z.EncBinary() + _ = yym717 if false { } else { h.encSliceIngress(([]Ingress)(x.Items), e) @@ -7753,15 +8380,15 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym658 := z.EncBinary() - _ = yym658 + yym718 := z.EncBinary() + _ = yym718 if false { } else { h.encSliceIngress(([]Ingress)(x.Items), e) } } } - if yyr644 || yy2arr644 { + if yyr704 || yy2arr704 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7774,25 +8401,25 @@ func (x *IngressList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym659 := z.DecBinary() - _ = yym659 + yym719 := z.DecBinary() + _ = yym719 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct660 := r.ContainerType() - if yyct660 == codecSelferValueTypeMap1234 { - yyl660 := r.ReadMapStart() - if yyl660 == 0 { + yyct720 := r.ContainerType() + if yyct720 == codecSelferValueTypeMap1234 { + yyl720 := r.ReadMapStart() + if yyl720 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl660, d) + x.codecDecodeSelfFromMap(yyl720, d) } - } else if yyct660 == codecSelferValueTypeArray1234 { - yyl660 := r.ReadArrayStart() - if yyl660 == 0 { + } else if yyct720 == codecSelferValueTypeArray1234 { + yyl720 := r.ReadArrayStart() + if yyl720 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl660, d) + x.codecDecodeSelfFromArray(yyl720, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7804,12 +8431,12 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys661Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys661Slc - var yyhl661 bool = l >= 0 - for yyj661 := 0; ; yyj661++ { - if yyhl661 { - if yyj661 >= l { + var yys721Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys721Slc + var yyhl721 bool = l >= 0 + for yyj721 := 0; ; yyj721++ { + if yyhl721 { + if yyj721 >= l { break } } else { @@ -7818,10 +8445,10 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys661Slc = r.DecodeBytes(yys661Slc, true, true) - yys661 := string(yys661Slc) + yys721Slc = r.DecodeBytes(yys721Slc, true, true) + yys721 := string(yys721Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys661 { + switch yys721 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -7838,31 +8465,31 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv664 := &x.ListMeta - yym665 := z.DecBinary() - _ = yym665 + yyv724 := &x.ListMeta + yym725 := z.DecBinary() + _ = yym725 if false { - } else if z.HasExtensions() && z.DecExt(yyv664) { + } else if z.HasExtensions() && z.DecExt(yyv724) { } else { - z.DecFallback(yyv664, false) + z.DecFallback(yyv724, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv666 := &x.Items - yym667 := z.DecBinary() - _ = yym667 + yyv726 := &x.Items + yym727 := z.DecBinary() + _ = yym727 if false { } else { - h.decSliceIngress((*[]Ingress)(yyv666), d) + h.decSliceIngress((*[]Ingress)(yyv726), d) } } default: - z.DecStructFieldNotFound(-1, yys661) - } // end switch yys661 - } // end for yyj661 + z.DecStructFieldNotFound(-1, yys721) + } // end switch yys721 + } // end for yyj721 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7870,16 +8497,16 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj668 int - var yyb668 bool - var yyhl668 bool = l >= 0 - yyj668++ - if yyhl668 { - yyb668 = yyj668 > l + var yyj728 int + var yyb728 bool + var yyhl728 bool = l >= 0 + yyj728++ + if yyhl728 { + yyb728 = yyj728 > l } else { - yyb668 = r.CheckBreak() + yyb728 = r.CheckBreak() } - if yyb668 { + if yyb728 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7889,13 +8516,13 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj668++ - if yyhl668 { - yyb668 = yyj668 > l + yyj728++ + if yyhl728 { + yyb728 = yyj728 > l } else { - yyb668 = r.CheckBreak() + yyb728 = r.CheckBreak() } - if yyb668 { + if yyb728 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7905,13 +8532,13 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj668++ - if yyhl668 { - yyb668 = yyj668 > l + yyj728++ + if yyhl728 { + yyb728 = yyj728 > l } else { - yyb668 = r.CheckBreak() + yyb728 = r.CheckBreak() } - if yyb668 { + if yyb728 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7919,22 +8546,22 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv671 := &x.ListMeta - yym672 := z.DecBinary() - _ = yym672 + yyv731 := &x.ListMeta + yym732 := z.DecBinary() + _ = yym732 if false { - } else if z.HasExtensions() && z.DecExt(yyv671) { + } else if z.HasExtensions() && z.DecExt(yyv731) { } else { - z.DecFallback(yyv671, false) + z.DecFallback(yyv731, false) } } - yyj668++ - if yyhl668 { - yyb668 = yyj668 > l + yyj728++ + if yyhl728 { + yyb728 = yyj728 > l } else { - yyb668 = r.CheckBreak() + yyb728 = r.CheckBreak() } - if yyb668 { + if yyb728 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7942,26 +8569,26 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv673 := &x.Items - yym674 := z.DecBinary() - _ = yym674 + yyv733 := &x.Items + yym734 := z.DecBinary() + _ = yym734 if false { } else { - h.decSliceIngress((*[]Ingress)(yyv673), d) + h.decSliceIngress((*[]Ingress)(yyv733), d) } } for { - yyj668++ - if yyhl668 { - yyb668 = yyj668 > l + yyj728++ + if yyhl728 { + yyb728 = yyj728 > l } else { - yyb668 = r.CheckBreak() + yyb728 = r.CheckBreak() } - if yyb668 { + if yyb728 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj668-1, "") + z.DecStructFieldNotFound(yyj728-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7973,35 +8600,35 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym675 := z.EncBinary() - _ = yym675 + yym735 := z.EncBinary() + _ = yym735 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep676 := !z.EncBinary() - yy2arr676 := z.EncBasicHandle().StructToArray - var yyq676 [3]bool - _, _, _ = yysep676, yyq676, yy2arr676 - const yyr676 bool = false - yyq676[0] = x.Backend != nil - yyq676[1] = len(x.TLS) != 0 - yyq676[2] = len(x.Rules) != 0 - var yynn676 int - if yyr676 || yy2arr676 { + yysep736 := !z.EncBinary() + yy2arr736 := z.EncBasicHandle().StructToArray + var yyq736 [3]bool + _, _, _ = yysep736, yyq736, yy2arr736 + const yyr736 bool = false + yyq736[0] = x.Backend != nil + yyq736[1] = len(x.TLS) != 0 + yyq736[2] = len(x.Rules) != 0 + var yynn736 int + if yyr736 || yy2arr736 { r.EncodeArrayStart(3) } else { - yynn676 = 0 - for _, b := range yyq676 { + yynn736 = 0 + for _, b := range yyq736 { if b { - yynn676++ + yynn736++ } } - r.EncodeMapStart(yynn676) - yynn676 = 0 + r.EncodeMapStart(yynn736) + yynn736 = 0 } - if yyr676 || yy2arr676 { + if yyr736 || yy2arr736 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq676[0] { + if yyq736[0] { if x.Backend == nil { r.EncodeNil() } else { @@ -8011,7 +8638,7 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq676[0] { + if yyq736[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("backend")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -8022,14 +8649,14 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr676 || yy2arr676 { + if yyr736 || yy2arr736 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq676[1] { + if yyq736[1] { if x.TLS == nil { r.EncodeNil() } else { - yym679 := z.EncBinary() - _ = yym679 + yym739 := z.EncBinary() + _ = yym739 if false { } else { h.encSliceIngressTLS(([]IngressTLS)(x.TLS), e) @@ -8039,15 +8666,15 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq676[1] { + if yyq736[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("tls")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.TLS == nil { r.EncodeNil() } else { - yym680 := z.EncBinary() - _ = yym680 + yym740 := z.EncBinary() + _ = yym740 if false { } else { h.encSliceIngressTLS(([]IngressTLS)(x.TLS), e) @@ -8055,14 +8682,14 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr676 || yy2arr676 { + if yyr736 || yy2arr736 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq676[2] { + if yyq736[2] { if x.Rules == nil { r.EncodeNil() } else { - yym682 := z.EncBinary() - _ = yym682 + yym742 := z.EncBinary() + _ = yym742 if false { } else { h.encSliceIngressRule(([]IngressRule)(x.Rules), e) @@ -8072,15 +8699,15 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq676[2] { + if yyq736[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rules")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Rules == nil { r.EncodeNil() } else { - yym683 := z.EncBinary() - _ = yym683 + yym743 := z.EncBinary() + _ = yym743 if false { } else { h.encSliceIngressRule(([]IngressRule)(x.Rules), e) @@ -8088,7 +8715,7 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr676 || yy2arr676 { + if yyr736 || yy2arr736 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -8098,896 +8725,6 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } func (x *IngressSpec) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym684 := z.DecBinary() - _ = yym684 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct685 := r.ContainerType() - if yyct685 == codecSelferValueTypeMap1234 { - yyl685 := r.ReadMapStart() - if yyl685 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl685, d) - } - } else if yyct685 == codecSelferValueTypeArray1234 { - yyl685 := r.ReadArrayStart() - if yyl685 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl685, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IngressSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys686Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys686Slc - var yyhl686 bool = l >= 0 - for yyj686 := 0; ; yyj686++ { - if yyhl686 { - if yyj686 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys686Slc = r.DecodeBytes(yys686Slc, true, true) - yys686 := string(yys686Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys686 { - case "backend": - if r.TryDecodeAsNil() { - if x.Backend != nil { - x.Backend = nil - } - } else { - if x.Backend == nil { - x.Backend = new(IngressBackend) - } - x.Backend.CodecDecodeSelf(d) - } - case "tls": - if r.TryDecodeAsNil() { - x.TLS = nil - } else { - yyv688 := &x.TLS - yym689 := z.DecBinary() - _ = yym689 - if false { - } else { - h.decSliceIngressTLS((*[]IngressTLS)(yyv688), d) - } - } - case "rules": - if r.TryDecodeAsNil() { - x.Rules = nil - } else { - yyv690 := &x.Rules - yym691 := z.DecBinary() - _ = yym691 - if false { - } else { - h.decSliceIngressRule((*[]IngressRule)(yyv690), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys686) - } // end switch yys686 - } // end for yyj686 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj692 int - var yyb692 bool - var yyhl692 bool = l >= 0 - yyj692++ - if yyhl692 { - yyb692 = yyj692 > l - } else { - yyb692 = r.CheckBreak() - } - if yyb692 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.Backend != nil { - x.Backend = nil - } - } else { - if x.Backend == nil { - x.Backend = new(IngressBackend) - } - x.Backend.CodecDecodeSelf(d) - } - yyj692++ - if yyhl692 { - yyb692 = yyj692 > l - } else { - yyb692 = r.CheckBreak() - } - if yyb692 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.TLS = nil - } else { - yyv694 := &x.TLS - yym695 := z.DecBinary() - _ = yym695 - if false { - } else { - h.decSliceIngressTLS((*[]IngressTLS)(yyv694), d) - } - } - yyj692++ - if yyhl692 { - yyb692 = yyj692 > l - } else { - yyb692 = r.CheckBreak() - } - if yyb692 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Rules = nil - } else { - yyv696 := &x.Rules - yym697 := z.DecBinary() - _ = yym697 - if false { - } else { - h.decSliceIngressRule((*[]IngressRule)(yyv696), d) - } - } - for { - yyj692++ - if yyhl692 { - yyb692 = yyj692 > l - } else { - yyb692 = r.CheckBreak() - } - if yyb692 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj692-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym698 := z.EncBinary() - _ = yym698 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep699 := !z.EncBinary() - yy2arr699 := z.EncBasicHandle().StructToArray - var yyq699 [2]bool - _, _, _ = yysep699, yyq699, yy2arr699 - const yyr699 bool = false - yyq699[0] = len(x.Hosts) != 0 - yyq699[1] = x.SecretName != "" - var yynn699 int - if yyr699 || yy2arr699 { - r.EncodeArrayStart(2) - } else { - yynn699 = 0 - for _, b := range yyq699 { - if b { - yynn699++ - } - } - r.EncodeMapStart(yynn699) - yynn699 = 0 - } - if yyr699 || yy2arr699 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq699[0] { - if x.Hosts == nil { - r.EncodeNil() - } else { - yym701 := z.EncBinary() - _ = yym701 - if false { - } else { - z.F.EncSliceStringV(x.Hosts, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq699[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hosts")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Hosts == nil { - r.EncodeNil() - } else { - yym702 := z.EncBinary() - _ = yym702 - if false { - } else { - z.F.EncSliceStringV(x.Hosts, false, e) - } - } - } - } - if yyr699 || yy2arr699 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq699[1] { - yym704 := z.EncBinary() - _ = yym704 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq699[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("secretName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym705 := z.EncBinary() - _ = yym705 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) - } - } - } - if yyr699 || yy2arr699 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IngressTLS) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym706 := z.DecBinary() - _ = yym706 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct707 := r.ContainerType() - if yyct707 == codecSelferValueTypeMap1234 { - yyl707 := r.ReadMapStart() - if yyl707 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl707, d) - } - } else if yyct707 == codecSelferValueTypeArray1234 { - yyl707 := r.ReadArrayStart() - if yyl707 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl707, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IngressTLS) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys708Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys708Slc - var yyhl708 bool = l >= 0 - for yyj708 := 0; ; yyj708++ { - if yyhl708 { - if yyj708 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys708Slc = r.DecodeBytes(yys708Slc, true, true) - yys708 := string(yys708Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys708 { - case "hosts": - if r.TryDecodeAsNil() { - x.Hosts = nil - } else { - yyv709 := &x.Hosts - yym710 := z.DecBinary() - _ = yym710 - if false { - } else { - z.F.DecSliceStringX(yyv709, false, d) - } - } - case "secretName": - if r.TryDecodeAsNil() { - x.SecretName = "" - } else { - x.SecretName = string(r.DecodeString()) - } - default: - z.DecStructFieldNotFound(-1, yys708) - } // end switch yys708 - } // end for yyj708 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IngressTLS) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj712 int - var yyb712 bool - var yyhl712 bool = l >= 0 - yyj712++ - if yyhl712 { - yyb712 = yyj712 > l - } else { - yyb712 = r.CheckBreak() - } - if yyb712 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Hosts = nil - } else { - yyv713 := &x.Hosts - yym714 := z.DecBinary() - _ = yym714 - if false { - } else { - z.F.DecSliceStringX(yyv713, false, d) - } - } - yyj712++ - if yyhl712 { - yyb712 = yyj712 > l - } else { - yyb712 = r.CheckBreak() - } - if yyb712 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SecretName = "" - } else { - x.SecretName = string(r.DecodeString()) - } - for { - yyj712++ - if yyhl712 { - yyb712 = yyj712 > l - } else { - yyb712 = r.CheckBreak() - } - if yyb712 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj712-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IngressStatus) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym716 := z.EncBinary() - _ = yym716 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep717 := !z.EncBinary() - yy2arr717 := z.EncBasicHandle().StructToArray - var yyq717 [1]bool - _, _, _ = yysep717, yyq717, yy2arr717 - const yyr717 bool = false - yyq717[0] = true - var yynn717 int - if yyr717 || yy2arr717 { - r.EncodeArrayStart(1) - } else { - yynn717 = 0 - for _, b := range yyq717 { - if b { - yynn717++ - } - } - r.EncodeMapStart(yynn717) - yynn717 = 0 - } - if yyr717 || yy2arr717 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq717[0] { - yy719 := &x.LoadBalancer - yy719.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq717[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("loadBalancer")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy720 := &x.LoadBalancer - yy720.CodecEncodeSelf(e) - } - } - if yyr717 || yy2arr717 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IngressStatus) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym721 := z.DecBinary() - _ = yym721 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct722 := r.ContainerType() - if yyct722 == codecSelferValueTypeMap1234 { - yyl722 := r.ReadMapStart() - if yyl722 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl722, d) - } - } else if yyct722 == codecSelferValueTypeArray1234 { - yyl722 := r.ReadArrayStart() - if yyl722 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl722, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IngressStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys723Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys723Slc - var yyhl723 bool = l >= 0 - for yyj723 := 0; ; yyj723++ { - if yyhl723 { - if yyj723 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys723Slc = r.DecodeBytes(yys723Slc, true, true) - yys723 := string(yys723Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys723 { - case "loadBalancer": - if r.TryDecodeAsNil() { - x.LoadBalancer = pkg2_api.LoadBalancerStatus{} - } else { - yyv724 := &x.LoadBalancer - yyv724.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys723) - } // end switch yys723 - } // end for yyj723 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IngressStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj725 int - var yyb725 bool - var yyhl725 bool = l >= 0 - yyj725++ - if yyhl725 { - yyb725 = yyj725 > l - } else { - yyb725 = r.CheckBreak() - } - if yyb725 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LoadBalancer = pkg2_api.LoadBalancerStatus{} - } else { - yyv726 := &x.LoadBalancer - yyv726.CodecDecodeSelf(d) - } - for { - yyj725++ - if yyhl725 { - yyb725 = yyj725 > l - } else { - yyb725 = r.CheckBreak() - } - if yyb725 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj725-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym727 := z.EncBinary() - _ = yym727 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep728 := !z.EncBinary() - yy2arr728 := z.EncBasicHandle().StructToArray - var yyq728 [2]bool - _, _, _ = yysep728, yyq728, yy2arr728 - const yyr728 bool = false - yyq728[0] = x.Host != "" - yyq728[1] = x.IngressRuleValue.HTTP != nil && x.HTTP != nil - var yynn728 int - if yyr728 || yy2arr728 { - r.EncodeArrayStart(2) - } else { - yynn728 = 0 - for _, b := range yyq728 { - if b { - yynn728++ - } - } - r.EncodeMapStart(yynn728) - yynn728 = 0 - } - if yyr728 || yy2arr728 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq728[0] { - yym730 := z.EncBinary() - _ = yym730 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Host)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq728[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("host")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym731 := z.EncBinary() - _ = yym731 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Host)) - } - } - } - var yyn732 bool - if x.IngressRuleValue.HTTP == nil { - yyn732 = true - goto LABEL732 - } - LABEL732: - if yyr728 || yy2arr728 { - if yyn732 { - r.EncodeNil() - } else { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq728[1] { - if x.HTTP == nil { - r.EncodeNil() - } else { - x.HTTP.CodecEncodeSelf(e) - } - } else { - r.EncodeNil() - } - } - } else { - if yyq728[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("http")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if yyn732 { - r.EncodeNil() - } else { - if x.HTTP == nil { - r.EncodeNil() - } else { - x.HTTP.CodecEncodeSelf(e) - } - } - } - } - if yyr728 || yy2arr728 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IngressRule) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym733 := z.DecBinary() - _ = yym733 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct734 := r.ContainerType() - if yyct734 == codecSelferValueTypeMap1234 { - yyl734 := r.ReadMapStart() - if yyl734 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl734, d) - } - } else if yyct734 == codecSelferValueTypeArray1234 { - yyl734 := r.ReadArrayStart() - if yyl734 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl734, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IngressRule) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys735Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys735Slc - var yyhl735 bool = l >= 0 - for yyj735 := 0; ; yyj735++ { - if yyhl735 { - if yyj735 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys735Slc = r.DecodeBytes(yys735Slc, true, true) - yys735 := string(yys735Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys735 { - case "host": - if r.TryDecodeAsNil() { - x.Host = "" - } else { - x.Host = string(r.DecodeString()) - } - case "http": - if x.IngressRuleValue.HTTP == nil { - x.IngressRuleValue.HTTP = new(HTTPIngressRuleValue) - } - if r.TryDecodeAsNil() { - if x.HTTP != nil { - x.HTTP = nil - } - } else { - if x.HTTP == nil { - x.HTTP = new(HTTPIngressRuleValue) - } - x.HTTP.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys735) - } // end switch yys735 - } // end for yyj735 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IngressRule) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj738 int - var yyb738 bool - var yyhl738 bool = l >= 0 - yyj738++ - if yyhl738 { - yyb738 = yyj738 > l - } else { - yyb738 = r.CheckBreak() - } - if yyb738 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Host = "" - } else { - x.Host = string(r.DecodeString()) - } - if x.IngressRuleValue.HTTP == nil { - x.IngressRuleValue.HTTP = new(HTTPIngressRuleValue) - } - yyj738++ - if yyhl738 { - yyb738 = yyj738 > l - } else { - yyb738 = r.CheckBreak() - } - if yyb738 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.HTTP != nil { - x.HTTP = nil - } - } else { - if x.HTTP == nil { - x.HTTP = new(HTTPIngressRuleValue) - } - x.HTTP.CodecDecodeSelf(d) - } - for { - yyj738++ - if yyhl738 { - yyb738 = yyj738 > l - } else { - yyb738 = r.CheckBreak() - } - if yyb738 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj738-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym741 := z.EncBinary() - _ = yym741 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep742 := !z.EncBinary() - yy2arr742 := z.EncBasicHandle().StructToArray - var yyq742 [1]bool - _, _, _ = yysep742, yyq742, yy2arr742 - const yyr742 bool = false - yyq742[0] = x.HTTP != nil - var yynn742 int - if yyr742 || yy2arr742 { - r.EncodeArrayStart(1) - } else { - yynn742 = 0 - for _, b := range yyq742 { - if b { - yynn742++ - } - } - r.EncodeMapStart(yynn742) - yynn742 = 0 - } - if yyr742 || yy2arr742 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq742[0] { - if x.HTTP == nil { - r.EncodeNil() - } else { - x.HTTP.CodecEncodeSelf(e) - } - } else { - r.EncodeNil() - } - } else { - if yyq742[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("http")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.HTTP == nil { - r.EncodeNil() - } else { - x.HTTP.CodecEncodeSelf(e) - } - } - } - if yyr742 || yy2arr742 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -9017,7 +8754,7 @@ func (x *IngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *IngressSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -9039,7 +8776,701 @@ func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { yys746 := string(yys746Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) switch yys746 { + case "backend": + if r.TryDecodeAsNil() { + if x.Backend != nil { + x.Backend = nil + } + } else { + if x.Backend == nil { + x.Backend = new(IngressBackend) + } + x.Backend.CodecDecodeSelf(d) + } + case "tls": + if r.TryDecodeAsNil() { + x.TLS = nil + } else { + yyv748 := &x.TLS + yym749 := z.DecBinary() + _ = yym749 + if false { + } else { + h.decSliceIngressTLS((*[]IngressTLS)(yyv748), d) + } + } + case "rules": + if r.TryDecodeAsNil() { + x.Rules = nil + } else { + yyv750 := &x.Rules + yym751 := z.DecBinary() + _ = yym751 + if false { + } else { + h.decSliceIngressRule((*[]IngressRule)(yyv750), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys746) + } // end switch yys746 + } // end for yyj746 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj752 int + var yyb752 bool + var yyhl752 bool = l >= 0 + yyj752++ + if yyhl752 { + yyb752 = yyj752 > l + } else { + yyb752 = r.CheckBreak() + } + if yyb752 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.Backend != nil { + x.Backend = nil + } + } else { + if x.Backend == nil { + x.Backend = new(IngressBackend) + } + x.Backend.CodecDecodeSelf(d) + } + yyj752++ + if yyhl752 { + yyb752 = yyj752 > l + } else { + yyb752 = r.CheckBreak() + } + if yyb752 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.TLS = nil + } else { + yyv754 := &x.TLS + yym755 := z.DecBinary() + _ = yym755 + if false { + } else { + h.decSliceIngressTLS((*[]IngressTLS)(yyv754), d) + } + } + yyj752++ + if yyhl752 { + yyb752 = yyj752 > l + } else { + yyb752 = r.CheckBreak() + } + if yyb752 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Rules = nil + } else { + yyv756 := &x.Rules + yym757 := z.DecBinary() + _ = yym757 + if false { + } else { + h.decSliceIngressRule((*[]IngressRule)(yyv756), d) + } + } + for { + yyj752++ + if yyhl752 { + yyb752 = yyj752 > l + } else { + yyb752 = r.CheckBreak() + } + if yyb752 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj752-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym758 := z.EncBinary() + _ = yym758 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep759 := !z.EncBinary() + yy2arr759 := z.EncBasicHandle().StructToArray + var yyq759 [2]bool + _, _, _ = yysep759, yyq759, yy2arr759 + const yyr759 bool = false + yyq759[0] = len(x.Hosts) != 0 + yyq759[1] = x.SecretName != "" + var yynn759 int + if yyr759 || yy2arr759 { + r.EncodeArrayStart(2) + } else { + yynn759 = 0 + for _, b := range yyq759 { + if b { + yynn759++ + } + } + r.EncodeMapStart(yynn759) + yynn759 = 0 + } + if yyr759 || yy2arr759 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq759[0] { + if x.Hosts == nil { + r.EncodeNil() + } else { + yym761 := z.EncBinary() + _ = yym761 + if false { + } else { + z.F.EncSliceStringV(x.Hosts, false, e) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq759[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("hosts")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Hosts == nil { + r.EncodeNil() + } else { + yym762 := z.EncBinary() + _ = yym762 + if false { + } else { + z.F.EncSliceStringV(x.Hosts, false, e) + } + } + } + } + if yyr759 || yy2arr759 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq759[1] { + yym764 := z.EncBinary() + _ = yym764 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq759[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("secretName")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym765 := z.EncBinary() + _ = yym765 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) + } + } + } + if yyr759 || yy2arr759 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IngressTLS) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym766 := z.DecBinary() + _ = yym766 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct767 := r.ContainerType() + if yyct767 == codecSelferValueTypeMap1234 { + yyl767 := r.ReadMapStart() + if yyl767 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl767, d) + } + } else if yyct767 == codecSelferValueTypeArray1234 { + yyl767 := r.ReadArrayStart() + if yyl767 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl767, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IngressTLS) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys768Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys768Slc + var yyhl768 bool = l >= 0 + for yyj768 := 0; ; yyj768++ { + if yyhl768 { + if yyj768 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys768Slc = r.DecodeBytes(yys768Slc, true, true) + yys768 := string(yys768Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys768 { + case "hosts": + if r.TryDecodeAsNil() { + x.Hosts = nil + } else { + yyv769 := &x.Hosts + yym770 := z.DecBinary() + _ = yym770 + if false { + } else { + z.F.DecSliceStringX(yyv769, false, d) + } + } + case "secretName": + if r.TryDecodeAsNil() { + x.SecretName = "" + } else { + x.SecretName = string(r.DecodeString()) + } + default: + z.DecStructFieldNotFound(-1, yys768) + } // end switch yys768 + } // end for yyj768 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IngressTLS) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj772 int + var yyb772 bool + var yyhl772 bool = l >= 0 + yyj772++ + if yyhl772 { + yyb772 = yyj772 > l + } else { + yyb772 = r.CheckBreak() + } + if yyb772 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Hosts = nil + } else { + yyv773 := &x.Hosts + yym774 := z.DecBinary() + _ = yym774 + if false { + } else { + z.F.DecSliceStringX(yyv773, false, d) + } + } + yyj772++ + if yyhl772 { + yyb772 = yyj772 > l + } else { + yyb772 = r.CheckBreak() + } + if yyb772 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.SecretName = "" + } else { + x.SecretName = string(r.DecodeString()) + } + for { + yyj772++ + if yyhl772 { + yyb772 = yyj772 > l + } else { + yyb772 = r.CheckBreak() + } + if yyb772 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj772-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IngressStatus) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym776 := z.EncBinary() + _ = yym776 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep777 := !z.EncBinary() + yy2arr777 := z.EncBasicHandle().StructToArray + var yyq777 [1]bool + _, _, _ = yysep777, yyq777, yy2arr777 + const yyr777 bool = false + yyq777[0] = true + var yynn777 int + if yyr777 || yy2arr777 { + r.EncodeArrayStart(1) + } else { + yynn777 = 0 + for _, b := range yyq777 { + if b { + yynn777++ + } + } + r.EncodeMapStart(yynn777) + yynn777 = 0 + } + if yyr777 || yy2arr777 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq777[0] { + yy779 := &x.LoadBalancer + yy779.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq777[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("loadBalancer")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy780 := &x.LoadBalancer + yy780.CodecEncodeSelf(e) + } + } + if yyr777 || yy2arr777 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IngressStatus) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym781 := z.DecBinary() + _ = yym781 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct782 := r.ContainerType() + if yyct782 == codecSelferValueTypeMap1234 { + yyl782 := r.ReadMapStart() + if yyl782 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl782, d) + } + } else if yyct782 == codecSelferValueTypeArray1234 { + yyl782 := r.ReadArrayStart() + if yyl782 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl782, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IngressStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys783Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys783Slc + var yyhl783 bool = l >= 0 + for yyj783 := 0; ; yyj783++ { + if yyhl783 { + if yyj783 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys783Slc = r.DecodeBytes(yys783Slc, true, true) + yys783 := string(yys783Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys783 { + case "loadBalancer": + if r.TryDecodeAsNil() { + x.LoadBalancer = pkg2_api.LoadBalancerStatus{} + } else { + yyv784 := &x.LoadBalancer + yyv784.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys783) + } // end switch yys783 + } // end for yyj783 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IngressStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj785 int + var yyb785 bool + var yyhl785 bool = l >= 0 + yyj785++ + if yyhl785 { + yyb785 = yyj785 > l + } else { + yyb785 = r.CheckBreak() + } + if yyb785 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.LoadBalancer = pkg2_api.LoadBalancerStatus{} + } else { + yyv786 := &x.LoadBalancer + yyv786.CodecDecodeSelf(d) + } + for { + yyj785++ + if yyhl785 { + yyb785 = yyj785 > l + } else { + yyb785 = r.CheckBreak() + } + if yyb785 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj785-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym787 := z.EncBinary() + _ = yym787 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep788 := !z.EncBinary() + yy2arr788 := z.EncBasicHandle().StructToArray + var yyq788 [2]bool + _, _, _ = yysep788, yyq788, yy2arr788 + const yyr788 bool = false + yyq788[0] = x.Host != "" + yyq788[1] = x.IngressRuleValue.HTTP != nil && x.HTTP != nil + var yynn788 int + if yyr788 || yy2arr788 { + r.EncodeArrayStart(2) + } else { + yynn788 = 0 + for _, b := range yyq788 { + if b { + yynn788++ + } + } + r.EncodeMapStart(yynn788) + yynn788 = 0 + } + if yyr788 || yy2arr788 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq788[0] { + yym790 := z.EncBinary() + _ = yym790 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Host)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq788[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("host")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym791 := z.EncBinary() + _ = yym791 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Host)) + } + } + } + var yyn792 bool + if x.IngressRuleValue.HTTP == nil { + yyn792 = true + goto LABEL792 + } + LABEL792: + if yyr788 || yy2arr788 { + if yyn792 { + r.EncodeNil() + } else { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq788[1] { + if x.HTTP == nil { + r.EncodeNil() + } else { + x.HTTP.CodecEncodeSelf(e) + } + } else { + r.EncodeNil() + } + } + } else { + if yyq788[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("http")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyn792 { + r.EncodeNil() + } else { + if x.HTTP == nil { + r.EncodeNil() + } else { + x.HTTP.CodecEncodeSelf(e) + } + } + } + } + if yyr788 || yy2arr788 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IngressRule) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym793 := z.DecBinary() + _ = yym793 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct794 := r.ContainerType() + if yyct794 == codecSelferValueTypeMap1234 { + yyl794 := r.ReadMapStart() + if yyl794 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl794, d) + } + } else if yyct794 == codecSelferValueTypeArray1234 { + yyl794 := r.ReadArrayStart() + if yyl794 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl794, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IngressRule) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys795Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys795Slc + var yyhl795 bool = l >= 0 + for yyj795 := 0; ; yyj795++ { + if yyhl795 { + if yyj795 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys795Slc = r.DecodeBytes(yys795Slc, true, true) + yys795 := string(yys795Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys795 { + case "host": + if r.TryDecodeAsNil() { + x.Host = "" + } else { + x.Host = string(r.DecodeString()) + } case "http": + if x.IngressRuleValue.HTTP == nil { + x.IngressRuleValue.HTTP = new(HTTPIngressRuleValue) + } if r.TryDecodeAsNil() { if x.HTTP != nil { x.HTTP = nil @@ -9051,26 +9482,45 @@ func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.HTTP.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys746) - } // end switch yys746 - } // end for yyj746 + z.DecStructFieldNotFound(-1, yys795) + } // end switch yys795 + } // end for yyj795 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *IngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *IngressRule) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj748 int - var yyb748 bool - var yyhl748 bool = l >= 0 - yyj748++ - if yyhl748 { - yyb748 = yyj748 > l + var yyj798 int + var yyb798 bool + var yyhl798 bool = l >= 0 + yyj798++ + if yyhl798 { + yyb798 = yyj798 > l } else { - yyb748 = r.CheckBreak() + yyb798 = r.CheckBreak() } - if yyb748 { + if yyb798 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Host = "" + } else { + x.Host = string(r.DecodeString()) + } + if x.IngressRuleValue.HTTP == nil { + x.IngressRuleValue.HTTP = new(HTTPIngressRuleValue) + } + yyj798++ + if yyhl798 { + yyb798 = yyj798 > l + } else { + yyb798 = r.CheckBreak() + } + if yyb798 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9086,17 +9536,194 @@ func (x *IngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.HTTP.CodecDecodeSelf(d) } for { - yyj748++ - if yyhl748 { - yyb748 = yyj748 > l + yyj798++ + if yyhl798 { + yyb798 = yyj798 > l } else { - yyb748 = r.CheckBreak() + yyb798 = r.CheckBreak() } - if yyb748 { + if yyb798 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj748-1, "") + z.DecStructFieldNotFound(yyj798-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym801 := z.EncBinary() + _ = yym801 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep802 := !z.EncBinary() + yy2arr802 := z.EncBasicHandle().StructToArray + var yyq802 [1]bool + _, _, _ = yysep802, yyq802, yy2arr802 + const yyr802 bool = false + yyq802[0] = x.HTTP != nil + var yynn802 int + if yyr802 || yy2arr802 { + r.EncodeArrayStart(1) + } else { + yynn802 = 0 + for _, b := range yyq802 { + if b { + yynn802++ + } + } + r.EncodeMapStart(yynn802) + yynn802 = 0 + } + if yyr802 || yy2arr802 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq802[0] { + if x.HTTP == nil { + r.EncodeNil() + } else { + x.HTTP.CodecEncodeSelf(e) + } + } else { + r.EncodeNil() + } + } else { + if yyq802[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("http")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.HTTP == nil { + r.EncodeNil() + } else { + x.HTTP.CodecEncodeSelf(e) + } + } + } + if yyr802 || yy2arr802 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym804 := z.DecBinary() + _ = yym804 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct805 := r.ContainerType() + if yyct805 == codecSelferValueTypeMap1234 { + yyl805 := r.ReadMapStart() + if yyl805 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl805, d) + } + } else if yyct805 == codecSelferValueTypeArray1234 { + yyl805 := r.ReadArrayStart() + if yyl805 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl805, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys806Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys806Slc + var yyhl806 bool = l >= 0 + for yyj806 := 0; ; yyj806++ { + if yyhl806 { + if yyj806 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys806Slc = r.DecodeBytes(yys806Slc, true, true) + yys806 := string(yys806Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys806 { + case "http": + if r.TryDecodeAsNil() { + if x.HTTP != nil { + x.HTTP = nil + } + } else { + if x.HTTP == nil { + x.HTTP = new(HTTPIngressRuleValue) + } + x.HTTP.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys806) + } // end switch yys806 + } // end for yyj806 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj808 int + var yyb808 bool + var yyhl808 bool = l >= 0 + yyj808++ + if yyhl808 { + yyb808 = yyj808 > l + } else { + yyb808 = r.CheckBreak() + } + if yyb808 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.HTTP != nil { + x.HTTP = nil + } + } else { + if x.HTTP == nil { + x.HTTP = new(HTTPIngressRuleValue) + } + x.HTTP.CodecDecodeSelf(d) + } + for { + yyj808++ + if yyhl808 { + yyb808 = yyj808 > l + } else { + yyb808 = r.CheckBreak() + } + if yyb808 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj808-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9108,36 +9735,36 @@ func (x *HTTPIngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym750 := z.EncBinary() - _ = yym750 + yym810 := z.EncBinary() + _ = yym810 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep751 := !z.EncBinary() - yy2arr751 := z.EncBasicHandle().StructToArray - var yyq751 [1]bool - _, _, _ = yysep751, yyq751, yy2arr751 - const yyr751 bool = false - var yynn751 int - if yyr751 || yy2arr751 { + yysep811 := !z.EncBinary() + yy2arr811 := z.EncBasicHandle().StructToArray + var yyq811 [1]bool + _, _, _ = yysep811, yyq811, yy2arr811 + const yyr811 bool = false + var yynn811 int + if yyr811 || yy2arr811 { r.EncodeArrayStart(1) } else { - yynn751 = 1 - for _, b := range yyq751 { + yynn811 = 1 + for _, b := range yyq811 { if b { - yynn751++ + yynn811++ } } - r.EncodeMapStart(yynn751) - yynn751 = 0 + r.EncodeMapStart(yynn811) + yynn811 = 0 } - if yyr751 || yy2arr751 { + if yyr811 || yy2arr811 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Paths == nil { r.EncodeNil() } else { - yym753 := z.EncBinary() - _ = yym753 + yym813 := z.EncBinary() + _ = yym813 if false { } else { h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) @@ -9150,15 +9777,15 @@ func (x *HTTPIngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { if x.Paths == nil { r.EncodeNil() } else { - yym754 := z.EncBinary() - _ = yym754 + yym814 := z.EncBinary() + _ = yym814 if false { } else { h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) } } } - if yyr751 || yy2arr751 { + if yyr811 || yy2arr811 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9171,25 +9798,25 @@ func (x *HTTPIngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym755 := z.DecBinary() - _ = yym755 + yym815 := z.DecBinary() + _ = yym815 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct756 := r.ContainerType() - if yyct756 == codecSelferValueTypeMap1234 { - yyl756 := r.ReadMapStart() - if yyl756 == 0 { + yyct816 := r.ContainerType() + if yyct816 == codecSelferValueTypeMap1234 { + yyl816 := r.ReadMapStart() + if yyl816 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl756, d) + x.codecDecodeSelfFromMap(yyl816, d) } - } else if yyct756 == codecSelferValueTypeArray1234 { - yyl756 := r.ReadArrayStart() - if yyl756 == 0 { + } else if yyct816 == codecSelferValueTypeArray1234 { + yyl816 := r.ReadArrayStart() + if yyl816 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl756, d) + x.codecDecodeSelfFromArray(yyl816, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9201,12 +9828,12 @@ func (x *HTTPIngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys757Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys757Slc - var yyhl757 bool = l >= 0 - for yyj757 := 0; ; yyj757++ { - if yyhl757 { - if yyj757 >= l { + var yys817Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys817Slc + var yyhl817 bool = l >= 0 + for yyj817 := 0; ; yyj817++ { + if yyhl817 { + if yyj817 >= l { break } } else { @@ -9215,26 +9842,26 @@ func (x *HTTPIngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decode } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys757Slc = r.DecodeBytes(yys757Slc, true, true) - yys757 := string(yys757Slc) + yys817Slc = r.DecodeBytes(yys817Slc, true, true) + yys817 := string(yys817Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys757 { + switch yys817 { case "paths": if r.TryDecodeAsNil() { x.Paths = nil } else { - yyv758 := &x.Paths - yym759 := z.DecBinary() - _ = yym759 + yyv818 := &x.Paths + yym819 := z.DecBinary() + _ = yym819 if false { } else { - h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv758), d) + h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv818), d) } } default: - z.DecStructFieldNotFound(-1, yys757) - } // end switch yys757 - } // end for yyj757 + z.DecStructFieldNotFound(-1, yys817) + } // end switch yys817 + } // end for yyj817 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -9242,16 +9869,16 @@ func (x *HTTPIngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj760 int - var yyb760 bool - var yyhl760 bool = l >= 0 - yyj760++ - if yyhl760 { - yyb760 = yyj760 > l + var yyj820 int + var yyb820 bool + var yyhl820 bool = l >= 0 + yyj820++ + if yyhl820 { + yyb820 = yyj820 > l } else { - yyb760 = r.CheckBreak() + yyb820 = r.CheckBreak() } - if yyb760 { + if yyb820 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9259,26 +9886,26 @@ func (x *HTTPIngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.Paths = nil } else { - yyv761 := &x.Paths - yym762 := z.DecBinary() - _ = yym762 + yyv821 := &x.Paths + yym822 := z.DecBinary() + _ = yym822 if false { } else { - h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv761), d) + h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv821), d) } } for { - yyj760++ - if yyhl760 { - yyb760 = yyj760 > l + yyj820++ + if yyhl820 { + yyb820 = yyj820 > l } else { - yyb760 = r.CheckBreak() + yyb820 = r.CheckBreak() } - if yyb760 { + if yyb820 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj760-1, "") + z.DecStructFieldNotFound(yyj820-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9290,35 +9917,35 @@ func (x *HTTPIngressPath) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym763 := z.EncBinary() - _ = yym763 + yym823 := z.EncBinary() + _ = yym823 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep764 := !z.EncBinary() - yy2arr764 := z.EncBasicHandle().StructToArray - var yyq764 [2]bool - _, _, _ = yysep764, yyq764, yy2arr764 - const yyr764 bool = false - yyq764[0] = x.Path != "" - var yynn764 int - if yyr764 || yy2arr764 { + yysep824 := !z.EncBinary() + yy2arr824 := z.EncBasicHandle().StructToArray + var yyq824 [2]bool + _, _, _ = yysep824, yyq824, yy2arr824 + const yyr824 bool = false + yyq824[0] = x.Path != "" + var yynn824 int + if yyr824 || yy2arr824 { r.EncodeArrayStart(2) } else { - yynn764 = 1 - for _, b := range yyq764 { + yynn824 = 1 + for _, b := range yyq824 { if b { - yynn764++ + yynn824++ } } - r.EncodeMapStart(yynn764) - yynn764 = 0 + r.EncodeMapStart(yynn824) + yynn824 = 0 } - if yyr764 || yy2arr764 { + if yyr824 || yy2arr824 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq764[0] { - yym766 := z.EncBinary() - _ = yym766 + if yyq824[0] { + yym826 := z.EncBinary() + _ = yym826 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) @@ -9327,30 +9954,30 @@ func (x *HTTPIngressPath) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq764[0] { + if yyq824[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym767 := z.EncBinary() - _ = yym767 + yym827 := z.EncBinary() + _ = yym827 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } } - if yyr764 || yy2arr764 { + if yyr824 || yy2arr824 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy769 := &x.Backend - yy769.CodecEncodeSelf(e) + yy829 := &x.Backend + yy829.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("backend")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy770 := &x.Backend - yy770.CodecEncodeSelf(e) + yy830 := &x.Backend + yy830.CodecEncodeSelf(e) } - if yyr764 || yy2arr764 { + if yyr824 || yy2arr824 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9363,25 +9990,25 @@ func (x *HTTPIngressPath) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym771 := z.DecBinary() - _ = yym771 + yym831 := z.DecBinary() + _ = yym831 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct772 := r.ContainerType() - if yyct772 == codecSelferValueTypeMap1234 { - yyl772 := r.ReadMapStart() - if yyl772 == 0 { + yyct832 := r.ContainerType() + if yyct832 == codecSelferValueTypeMap1234 { + yyl832 := r.ReadMapStart() + if yyl832 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl772, d) + x.codecDecodeSelfFromMap(yyl832, d) } - } else if yyct772 == codecSelferValueTypeArray1234 { - yyl772 := r.ReadArrayStart() - if yyl772 == 0 { + } else if yyct832 == codecSelferValueTypeArray1234 { + yyl832 := r.ReadArrayStart() + if yyl832 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl772, d) + x.codecDecodeSelfFromArray(yyl832, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9393,12 +10020,12 @@ func (x *HTTPIngressPath) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys773Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys773Slc - var yyhl773 bool = l >= 0 - for yyj773 := 0; ; yyj773++ { - if yyhl773 { - if yyj773 >= l { + var yys833Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys833Slc + var yyhl833 bool = l >= 0 + for yyj833 := 0; ; yyj833++ { + if yyhl833 { + if yyj833 >= l { break } } else { @@ -9407,10 +10034,10 @@ func (x *HTTPIngressPath) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys773Slc = r.DecodeBytes(yys773Slc, true, true) - yys773 := string(yys773Slc) + yys833Slc = r.DecodeBytes(yys833Slc, true, true) + yys833 := string(yys833Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys773 { + switch yys833 { case "path": if r.TryDecodeAsNil() { x.Path = "" @@ -9421,13 +10048,13 @@ func (x *HTTPIngressPath) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Backend = IngressBackend{} } else { - yyv775 := &x.Backend - yyv775.CodecDecodeSelf(d) + yyv835 := &x.Backend + yyv835.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys773) - } // end switch yys773 - } // end for yyj773 + z.DecStructFieldNotFound(-1, yys833) + } // end switch yys833 + } // end for yyj833 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -9435,16 +10062,16 @@ func (x *HTTPIngressPath) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj776 int - var yyb776 bool - var yyhl776 bool = l >= 0 - yyj776++ - if yyhl776 { - yyb776 = yyj776 > l + var yyj836 int + var yyb836 bool + var yyhl836 bool = l >= 0 + yyj836++ + if yyhl836 { + yyb836 = yyj836 > l } else { - yyb776 = r.CheckBreak() + yyb836 = r.CheckBreak() } - if yyb776 { + if yyb836 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9454,13 +10081,13 @@ func (x *HTTPIngressPath) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Path = string(r.DecodeString()) } - yyj776++ - if yyhl776 { - yyb776 = yyj776 > l + yyj836++ + if yyhl836 { + yyb836 = yyj836 > l } else { - yyb776 = r.CheckBreak() + yyb836 = r.CheckBreak() } - if yyb776 { + if yyb836 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9468,21 +10095,21 @@ func (x *HTTPIngressPath) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Backend = IngressBackend{} } else { - yyv778 := &x.Backend - yyv778.CodecDecodeSelf(d) + yyv838 := &x.Backend + yyv838.CodecDecodeSelf(d) } for { - yyj776++ - if yyhl776 { - yyb776 = yyj776 > l + yyj836++ + if yyhl836 { + yyb836 = yyj836 > l } else { - yyb776 = r.CheckBreak() + yyb836 = r.CheckBreak() } - if yyb776 { + if yyb836 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj776-1, "") + z.DecStructFieldNotFound(yyj836-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9494,33 +10121,33 @@ func (x *IngressBackend) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym779 := z.EncBinary() - _ = yym779 + yym839 := z.EncBinary() + _ = yym839 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep780 := !z.EncBinary() - yy2arr780 := z.EncBasicHandle().StructToArray - var yyq780 [2]bool - _, _, _ = yysep780, yyq780, yy2arr780 - const yyr780 bool = false - var yynn780 int - if yyr780 || yy2arr780 { + yysep840 := !z.EncBinary() + yy2arr840 := z.EncBasicHandle().StructToArray + var yyq840 [2]bool + _, _, _ = yysep840, yyq840, yy2arr840 + const yyr840 bool = false + var yynn840 int + if yyr840 || yy2arr840 { r.EncodeArrayStart(2) } else { - yynn780 = 2 - for _, b := range yyq780 { + yynn840 = 2 + for _, b := range yyq840 { if b { - yynn780++ + yynn840++ } } - r.EncodeMapStart(yynn780) - yynn780 = 0 + r.EncodeMapStart(yynn840) + yynn840 = 0 } - if yyr780 || yy2arr780 { + if yyr840 || yy2arr840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym782 := z.EncBinary() - _ = yym782 + yym842 := z.EncBinary() + _ = yym842 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) @@ -9529,41 +10156,41 @@ func (x *IngressBackend) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("serviceName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym783 := z.EncBinary() - _ = yym783 + yym843 := z.EncBinary() + _ = yym843 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) } } - if yyr780 || yy2arr780 { + if yyr840 || yy2arr840 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy785 := &x.ServicePort - yym786 := z.EncBinary() - _ = yym786 + yy845 := &x.ServicePort + yym846 := z.EncBinary() + _ = yym846 if false { - } else if z.HasExtensions() && z.EncExt(yy785) { - } else if !yym786 && z.IsJSONHandle() { - z.EncJSONMarshal(yy785) + } else if z.HasExtensions() && z.EncExt(yy845) { + } else if !yym846 && z.IsJSONHandle() { + z.EncJSONMarshal(yy845) } else { - z.EncFallback(yy785) + z.EncFallback(yy845) } } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("servicePort")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy787 := &x.ServicePort - yym788 := z.EncBinary() - _ = yym788 + yy847 := &x.ServicePort + yym848 := z.EncBinary() + _ = yym848 if false { - } else if z.HasExtensions() && z.EncExt(yy787) { - } else if !yym788 && z.IsJSONHandle() { - z.EncJSONMarshal(yy787) + } else if z.HasExtensions() && z.EncExt(yy847) { + } else if !yym848 && z.IsJSONHandle() { + z.EncJSONMarshal(yy847) } else { - z.EncFallback(yy787) + z.EncFallback(yy847) } } - if yyr780 || yy2arr780 { + if yyr840 || yy2arr840 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9576,25 +10203,25 @@ func (x *IngressBackend) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym789 := z.DecBinary() - _ = yym789 + yym849 := z.DecBinary() + _ = yym849 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct790 := r.ContainerType() - if yyct790 == codecSelferValueTypeMap1234 { - yyl790 := r.ReadMapStart() - if yyl790 == 0 { + yyct850 := r.ContainerType() + if yyct850 == codecSelferValueTypeMap1234 { + yyl850 := r.ReadMapStart() + if yyl850 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl790, d) + x.codecDecodeSelfFromMap(yyl850, d) } - } else if yyct790 == codecSelferValueTypeArray1234 { - yyl790 := r.ReadArrayStart() - if yyl790 == 0 { + } else if yyct850 == codecSelferValueTypeArray1234 { + yyl850 := r.ReadArrayStart() + if yyl850 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl790, d) + x.codecDecodeSelfFromArray(yyl850, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9606,12 +10233,12 @@ func (x *IngressBackend) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys791Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys791Slc - var yyhl791 bool = l >= 0 - for yyj791 := 0; ; yyj791++ { - if yyhl791 { - if yyj791 >= l { + var yys851Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys851Slc + var yyhl851 bool = l >= 0 + for yyj851 := 0; ; yyj851++ { + if yyhl851 { + if yyj851 >= l { break } } else { @@ -9620,10 +10247,10 @@ func (x *IngressBackend) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys791Slc = r.DecodeBytes(yys791Slc, true, true) - yys791 := string(yys791Slc) + yys851Slc = r.DecodeBytes(yys851Slc, true, true) + yys851 := string(yys851Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys791 { + switch yys851 { case "serviceName": if r.TryDecodeAsNil() { x.ServiceName = "" @@ -9634,676 +10261,25 @@ func (x *IngressBackend) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ServicePort = pkg5_intstr.IntOrString{} } else { - yyv793 := &x.ServicePort - yym794 := z.DecBinary() - _ = yym794 + yyv853 := &x.ServicePort + yym854 := z.DecBinary() + _ = yym854 if false { - } else if z.HasExtensions() && z.DecExt(yyv793) { - } else if !yym794 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv793) + } else if z.HasExtensions() && z.DecExt(yyv853) { + } else if !yym854 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv853) } else { - z.DecFallback(yyv793, false) + z.DecFallback(yyv853, false) } } default: - z.DecStructFieldNotFound(-1, yys791) - } // end switch yys791 - } // end for yyj791 + z.DecStructFieldNotFound(-1, yys851) + } // end switch yys851 + } // end for yyj851 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } func (x *IngressBackend) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj795 int - var yyb795 bool - var yyhl795 bool = l >= 0 - yyj795++ - if yyhl795 { - yyb795 = yyj795 > l - } else { - yyb795 = r.CheckBreak() - } - if yyb795 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServiceName = "" - } else { - x.ServiceName = string(r.DecodeString()) - } - yyj795++ - if yyhl795 { - yyb795 = yyj795 > l - } else { - yyb795 = r.CheckBreak() - } - if yyb795 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServicePort = pkg5_intstr.IntOrString{} - } else { - yyv797 := &x.ServicePort - yym798 := z.DecBinary() - _ = yym798 - if false { - } else if z.HasExtensions() && z.DecExt(yyv797) { - } else if !yym798 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv797) - } else { - z.DecFallback(yyv797, false) - } - } - for { - yyj795++ - if yyhl795 { - yyb795 = yyj795 > l - } else { - yyb795 = r.CheckBreak() - } - if yyb795 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj795-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *ReplicaSet) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym799 := z.EncBinary() - _ = yym799 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep800 := !z.EncBinary() - yy2arr800 := z.EncBasicHandle().StructToArray - var yyq800 [5]bool - _, _, _ = yysep800, yyq800, yy2arr800 - const yyr800 bool = false - yyq800[0] = x.Kind != "" - yyq800[1] = x.APIVersion != "" - yyq800[2] = true - yyq800[3] = true - yyq800[4] = true - var yynn800 int - if yyr800 || yy2arr800 { - r.EncodeArrayStart(5) - } else { - yynn800 = 0 - for _, b := range yyq800 { - if b { - yynn800++ - } - } - r.EncodeMapStart(yynn800) - yynn800 = 0 - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq800[0] { - yym802 := z.EncBinary() - _ = yym802 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq800[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym803 := z.EncBinary() - _ = yym803 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq800[1] { - yym805 := z.EncBinary() - _ = yym805 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq800[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym806 := z.EncBinary() - _ = yym806 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq800[2] { - yy808 := &x.ObjectMeta - yy808.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq800[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy809 := &x.ObjectMeta - yy809.CodecEncodeSelf(e) - } - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq800[3] { - yy811 := &x.Spec - yy811.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq800[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("spec")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy812 := &x.Spec - yy812.CodecEncodeSelf(e) - } - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq800[4] { - yy814 := &x.Status - yy814.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq800[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("status")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy815 := &x.Status - yy815.CodecEncodeSelf(e) - } - } - if yyr800 || yy2arr800 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *ReplicaSet) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym816 := z.DecBinary() - _ = yym816 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct817 := r.ContainerType() - if yyct817 == codecSelferValueTypeMap1234 { - yyl817 := r.ReadMapStart() - if yyl817 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl817, d) - } - } else if yyct817 == codecSelferValueTypeArray1234 { - yyl817 := r.ReadArrayStart() - if yyl817 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl817, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys818Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys818Slc - var yyhl818 bool = l >= 0 - for yyj818 := 0; ; yyj818++ { - if yyhl818 { - if yyj818 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys818Slc = r.DecodeBytes(yys818Slc, true, true) - yys818 := string(yys818Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys818 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "metadata": - if r.TryDecodeAsNil() { - x.ObjectMeta = pkg2_api.ObjectMeta{} - } else { - yyv821 := &x.ObjectMeta - yyv821.CodecDecodeSelf(d) - } - case "spec": - if r.TryDecodeAsNil() { - x.Spec = ReplicaSetSpec{} - } else { - yyv822 := &x.Spec - yyv822.CodecDecodeSelf(d) - } - case "status": - if r.TryDecodeAsNil() { - x.Status = ReplicaSetStatus{} - } else { - yyv823 := &x.Status - yyv823.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys818) - } // end switch yys818 - } // end for yyj818 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj824 int - var yyb824 bool - var yyhl824 bool = l >= 0 - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ObjectMeta = pkg2_api.ObjectMeta{} - } else { - yyv827 := &x.ObjectMeta - yyv827.CodecDecodeSelf(d) - } - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Spec = ReplicaSetSpec{} - } else { - yyv828 := &x.Spec - yyv828.CodecDecodeSelf(d) - } - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Status = ReplicaSetStatus{} - } else { - yyv829 := &x.Status - yyv829.CodecDecodeSelf(d) - } - for { - yyj824++ - if yyhl824 { - yyb824 = yyj824 > l - } else { - yyb824 = r.CheckBreak() - } - if yyb824 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj824-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym830 := z.EncBinary() - _ = yym830 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep831 := !z.EncBinary() - yy2arr831 := z.EncBasicHandle().StructToArray - var yyq831 [4]bool - _, _, _ = yysep831, yyq831, yy2arr831 - const yyr831 bool = false - yyq831[0] = x.Kind != "" - yyq831[1] = x.APIVersion != "" - yyq831[2] = true - var yynn831 int - if yyr831 || yy2arr831 { - r.EncodeArrayStart(4) - } else { - yynn831 = 1 - for _, b := range yyq831 { - if b { - yynn831++ - } - } - r.EncodeMapStart(yynn831) - yynn831 = 0 - } - if yyr831 || yy2arr831 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq831[0] { - yym833 := z.EncBinary() - _ = yym833 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq831[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym834 := z.EncBinary() - _ = yym834 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr831 || yy2arr831 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq831[1] { - yym836 := z.EncBinary() - _ = yym836 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq831[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym837 := z.EncBinary() - _ = yym837 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr831 || yy2arr831 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq831[2] { - yy839 := &x.ListMeta - yym840 := z.EncBinary() - _ = yym840 - if false { - } else if z.HasExtensions() && z.EncExt(yy839) { - } else { - z.EncFallback(yy839) - } - } else { - r.EncodeNil() - } - } else { - if yyq831[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy841 := &x.ListMeta - yym842 := z.EncBinary() - _ = yym842 - if false { - } else if z.HasExtensions() && z.EncExt(yy841) { - } else { - z.EncFallback(yy841) - } - } - } - if yyr831 || yy2arr831 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.Items == nil { - r.EncodeNil() - } else { - yym844 := z.EncBinary() - _ = yym844 - if false { - } else { - h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("items")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Items == nil { - r.EncodeNil() - } else { - yym845 := z.EncBinary() - _ = yym845 - if false { - } else { - h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) - } - } - } - if yyr831 || yy2arr831 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *ReplicaSetList) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym846 := z.DecBinary() - _ = yym846 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct847 := r.ContainerType() - if yyct847 == codecSelferValueTypeMap1234 { - yyl847 := r.ReadMapStart() - if yyl847 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl847, d) - } - } else if yyct847 == codecSelferValueTypeArray1234 { - yyl847 := r.ReadArrayStart() - if yyl847 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl847, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *ReplicaSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys848Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys848Slc - var yyhl848 bool = l >= 0 - for yyj848 := 0; ; yyj848++ { - if yyhl848 { - if yyj848 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys848Slc = r.DecodeBytes(yys848Slc, true, true) - yys848 := string(yys848Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys848 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "metadata": - if r.TryDecodeAsNil() { - x.ListMeta = pkg1_unversioned.ListMeta{} - } else { - yyv851 := &x.ListMeta - yym852 := z.DecBinary() - _ = yym852 - if false { - } else if z.HasExtensions() && z.DecExt(yyv851) { - } else { - z.DecFallback(yyv851, false) - } - } - case "items": - if r.TryDecodeAsNil() { - x.Items = nil - } else { - yyv853 := &x.Items - yym854 := z.DecBinary() - _ = yym854 - if false { - } else { - h.decSliceReplicaSet((*[]ReplicaSet)(yyv853), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys848) - } // end switch yys848 - } // end for yyj848 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -10322,9 +10298,9 @@ func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Kind = "" + x.ServiceName = "" } else { - x.Kind = string(r.DecodeString()) + x.ServiceName = string(r.DecodeString()) } yyj855++ if yyhl855 { @@ -10338,53 +10314,17 @@ func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.APIVersion = "" + x.ServicePort = pkg5_intstr.IntOrString{} } else { - x.APIVersion = string(r.DecodeString()) - } - yyj855++ - if yyhl855 { - yyb855 = yyj855 > l - } else { - yyb855 = r.CheckBreak() - } - if yyb855 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ListMeta = pkg1_unversioned.ListMeta{} - } else { - yyv858 := &x.ListMeta - yym859 := z.DecBinary() - _ = yym859 + yyv857 := &x.ServicePort + yym858 := z.DecBinary() + _ = yym858 if false { - } else if z.HasExtensions() && z.DecExt(yyv858) { + } else if z.HasExtensions() && z.DecExt(yyv857) { + } else if !yym858 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv857) } else { - z.DecFallback(yyv858, false) - } - } - yyj855++ - if yyhl855 { - yyb855 = yyj855 > l - } else { - yyb855 = r.CheckBreak() - } - if yyb855 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Items = nil - } else { - yyv860 := &x.Items - yym861 := z.DecBinary() - _ = yym861 - if false { - } else { - h.decSliceReplicaSet((*[]ReplicaSet)(yyv860), d) + z.DecFallback(yyv857, false) } } for { @@ -10403,136 +10343,143 @@ func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *ReplicaSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *ReplicaSet) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r if x == nil { r.EncodeNil() } else { - yym862 := z.EncBinary() - _ = yym862 + yym859 := z.EncBinary() + _ = yym859 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep863 := !z.EncBinary() - yy2arr863 := z.EncBasicHandle().StructToArray - var yyq863 [4]bool - _, _, _ = yysep863, yyq863, yy2arr863 - const yyr863 bool = false - yyq863[1] = x.MinReadySeconds != 0 - yyq863[2] = x.Selector != nil - yyq863[3] = true - var yynn863 int - if yyr863 || yy2arr863 { - r.EncodeArrayStart(4) + yysep860 := !z.EncBinary() + yy2arr860 := z.EncBasicHandle().StructToArray + var yyq860 [5]bool + _, _, _ = yysep860, yyq860, yy2arr860 + const yyr860 bool = false + yyq860[0] = x.Kind != "" + yyq860[1] = x.APIVersion != "" + yyq860[2] = true + yyq860[3] = true + yyq860[4] = true + var yynn860 int + if yyr860 || yy2arr860 { + r.EncodeArrayStart(5) } else { - yynn863 = 1 - for _, b := range yyq863 { + yynn860 = 0 + for _, b := range yyq860 { if b { - yynn863++ + yynn860++ } } - r.EncodeMapStart(yynn863) - yynn863 = 0 + r.EncodeMapStart(yynn860) + yynn860 = 0 } - if yyr863 || yy2arr863 { + if yyr860 || yy2arr860 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym865 := z.EncBinary() - _ = yym865 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("replicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym866 := z.EncBinary() - _ = yym866 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } - if yyr863 || yy2arr863 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq863[1] { - yym868 := z.EncBinary() - _ = yym868 + if yyq860[0] { + yym862 := z.EncBinary() + _ = yym862 if false { } else { - r.EncodeInt(int64(x.MinReadySeconds)) + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } else { - r.EncodeInt(0) + r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq863[1] { + if yyq860[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minReadySeconds")) + r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym869 := z.EncBinary() - _ = yym869 + yym863 := z.EncBinary() + _ = yym863 if false { } else { - r.EncodeInt(int64(x.MinReadySeconds)) + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr863 || yy2arr863 { + if yyr860 || yy2arr860 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq863[2] { - if x.Selector == nil { - r.EncodeNil() + if yyq860[1] { + yym865 := z.EncBinary() + _ = yym865 + if false { } else { - yym871 := z.EncBinary() - _ = yym871 - if false { - } else if z.HasExtensions() && z.EncExt(x.Selector) { - } else { - z.EncFallback(x.Selector) - } + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq860[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym866 := z.EncBinary() + _ = yym866 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr860 || yy2arr860 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq860[2] { + yy868 := &x.ObjectMeta + yy868.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq863[2] { + if yyq860[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("selector")) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Selector == nil { - r.EncodeNil() - } else { - yym872 := z.EncBinary() - _ = yym872 - if false { - } else if z.HasExtensions() && z.EncExt(x.Selector) { - } else { - z.EncFallback(x.Selector) - } - } + yy869 := &x.ObjectMeta + yy869.CodecEncodeSelf(e) } } - if yyr863 || yy2arr863 { + if yyr860 || yy2arr860 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq863[3] { - yy874 := &x.Template + if yyq860[3] { + yy871 := &x.Spec + yy871.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq860[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("spec")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy872 := &x.Spec + yy872.CodecEncodeSelf(e) + } + } + if yyr860 || yy2arr860 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq860[4] { + yy874 := &x.Status yy874.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq863[3] { + if yyq860[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("template")) + r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy875 := &x.Template + yy875 := &x.Status yy875.CodecEncodeSelf(e) } } - if yyr863 || yy2arr863 { + if yyr860 || yy2arr860 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -10541,7 +10488,7 @@ func (x *ReplicaSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *ReplicaSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *ReplicaSet) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -10571,7 +10518,7 @@ func (x *ReplicaSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -10593,6 +10540,686 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { yys878 := string(yys878Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) switch yys878 { + case "kind": + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + case "apiVersion": + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + case "metadata": + if r.TryDecodeAsNil() { + x.ObjectMeta = pkg2_api.ObjectMeta{} + } else { + yyv881 := &x.ObjectMeta + yyv881.CodecDecodeSelf(d) + } + case "spec": + if r.TryDecodeAsNil() { + x.Spec = ReplicaSetSpec{} + } else { + yyv882 := &x.Spec + yyv882.CodecDecodeSelf(d) + } + case "status": + if r.TryDecodeAsNil() { + x.Status = ReplicaSetStatus{} + } else { + yyv883 := &x.Status + yyv883.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys878) + } // end switch yys878 + } // end for yyj878 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj884 int + var yyb884 bool + var yyhl884 bool = l >= 0 + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ObjectMeta = pkg2_api.ObjectMeta{} + } else { + yyv887 := &x.ObjectMeta + yyv887.CodecDecodeSelf(d) + } + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Spec = ReplicaSetSpec{} + } else { + yyv888 := &x.Spec + yyv888.CodecDecodeSelf(d) + } + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Status = ReplicaSetStatus{} + } else { + yyv889 := &x.Status + yyv889.CodecDecodeSelf(d) + } + for { + yyj884++ + if yyhl884 { + yyb884 = yyj884 > l + } else { + yyb884 = r.CheckBreak() + } + if yyb884 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj884-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym890 := z.EncBinary() + _ = yym890 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep891 := !z.EncBinary() + yy2arr891 := z.EncBasicHandle().StructToArray + var yyq891 [4]bool + _, _, _ = yysep891, yyq891, yy2arr891 + const yyr891 bool = false + yyq891[0] = x.Kind != "" + yyq891[1] = x.APIVersion != "" + yyq891[2] = true + var yynn891 int + if yyr891 || yy2arr891 { + r.EncodeArrayStart(4) + } else { + yynn891 = 1 + for _, b := range yyq891 { + if b { + yynn891++ + } + } + r.EncodeMapStart(yynn891) + yynn891 = 0 + } + if yyr891 || yy2arr891 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq891[0] { + yym893 := z.EncBinary() + _ = yym893 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq891[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("kind")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym894 := z.EncBinary() + _ = yym894 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr891 || yy2arr891 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq891[1] { + yym896 := z.EncBinary() + _ = yym896 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq891[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym897 := z.EncBinary() + _ = yym897 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr891 || yy2arr891 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq891[2] { + yy899 := &x.ListMeta + yym900 := z.EncBinary() + _ = yym900 + if false { + } else if z.HasExtensions() && z.EncExt(yy899) { + } else { + z.EncFallback(yy899) + } + } else { + r.EncodeNil() + } + } else { + if yyq891[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy901 := &x.ListMeta + yym902 := z.EncBinary() + _ = yym902 + if false { + } else if z.HasExtensions() && z.EncExt(yy901) { + } else { + z.EncFallback(yy901) + } + } + } + if yyr891 || yy2arr891 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if x.Items == nil { + r.EncodeNil() + } else { + yym904 := z.EncBinary() + _ = yym904 + if false { + } else { + h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) + } + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("items")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Items == nil { + r.EncodeNil() + } else { + yym905 := z.EncBinary() + _ = yym905 + if false { + } else { + h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) + } + } + } + if yyr891 || yy2arr891 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *ReplicaSetList) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym906 := z.DecBinary() + _ = yym906 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct907 := r.ContainerType() + if yyct907 == codecSelferValueTypeMap1234 { + yyl907 := r.ReadMapStart() + if yyl907 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl907, d) + } + } else if yyct907 == codecSelferValueTypeArray1234 { + yyl907 := r.ReadArrayStart() + if yyl907 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl907, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *ReplicaSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys908Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys908Slc + var yyhl908 bool = l >= 0 + for yyj908 := 0; ; yyj908++ { + if yyhl908 { + if yyj908 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys908Slc = r.DecodeBytes(yys908Slc, true, true) + yys908 := string(yys908Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys908 { + case "kind": + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + case "apiVersion": + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + case "metadata": + if r.TryDecodeAsNil() { + x.ListMeta = pkg1_unversioned.ListMeta{} + } else { + yyv911 := &x.ListMeta + yym912 := z.DecBinary() + _ = yym912 + if false { + } else if z.HasExtensions() && z.DecExt(yyv911) { + } else { + z.DecFallback(yyv911, false) + } + } + case "items": + if r.TryDecodeAsNil() { + x.Items = nil + } else { + yyv913 := &x.Items + yym914 := z.DecBinary() + _ = yym914 + if false { + } else { + h.decSliceReplicaSet((*[]ReplicaSet)(yyv913), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys908) + } // end switch yys908 + } // end for yyj908 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj915 int + var yyb915 bool + var yyhl915 bool = l >= 0 + yyj915++ + if yyhl915 { + yyb915 = yyj915 > l + } else { + yyb915 = r.CheckBreak() + } + if yyb915 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + yyj915++ + if yyhl915 { + yyb915 = yyj915 > l + } else { + yyb915 = r.CheckBreak() + } + if yyb915 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + yyj915++ + if yyhl915 { + yyb915 = yyj915 > l + } else { + yyb915 = r.CheckBreak() + } + if yyb915 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ListMeta = pkg1_unversioned.ListMeta{} + } else { + yyv918 := &x.ListMeta + yym919 := z.DecBinary() + _ = yym919 + if false { + } else if z.HasExtensions() && z.DecExt(yyv918) { + } else { + z.DecFallback(yyv918, false) + } + } + yyj915++ + if yyhl915 { + yyb915 = yyj915 > l + } else { + yyb915 = r.CheckBreak() + } + if yyb915 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Items = nil + } else { + yyv920 := &x.Items + yym921 := z.DecBinary() + _ = yym921 + if false { + } else { + h.decSliceReplicaSet((*[]ReplicaSet)(yyv920), d) + } + } + for { + yyj915++ + if yyhl915 { + yyb915 = yyj915 > l + } else { + yyb915 = r.CheckBreak() + } + if yyb915 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj915-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *ReplicaSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym922 := z.EncBinary() + _ = yym922 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep923 := !z.EncBinary() + yy2arr923 := z.EncBasicHandle().StructToArray + var yyq923 [4]bool + _, _, _ = yysep923, yyq923, yy2arr923 + const yyr923 bool = false + yyq923[1] = x.MinReadySeconds != 0 + yyq923[2] = x.Selector != nil + yyq923[3] = true + var yynn923 int + if yyr923 || yy2arr923 { + r.EncodeArrayStart(4) + } else { + yynn923 = 1 + for _, b := range yyq923 { + if b { + yynn923++ + } + } + r.EncodeMapStart(yynn923) + yynn923 = 0 + } + if yyr923 || yy2arr923 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym925 := z.EncBinary() + _ = yym925 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("replicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym926 := z.EncBinary() + _ = yym926 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } + if yyr923 || yy2arr923 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq923[1] { + yym928 := z.EncBinary() + _ = yym928 + if false { + } else { + r.EncodeInt(int64(x.MinReadySeconds)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq923[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("minReadySeconds")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym929 := z.EncBinary() + _ = yym929 + if false { + } else { + r.EncodeInt(int64(x.MinReadySeconds)) + } + } + } + if yyr923 || yy2arr923 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq923[2] { + if x.Selector == nil { + r.EncodeNil() + } else { + yym931 := z.EncBinary() + _ = yym931 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq923[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("selector")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Selector == nil { + r.EncodeNil() + } else { + yym932 := z.EncBinary() + _ = yym932 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } + } + if yyr923 || yy2arr923 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq923[3] { + yy934 := &x.Template + yy934.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq923[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("template")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy935 := &x.Template + yy935.CodecEncodeSelf(e) + } + } + if yyr923 || yy2arr923 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *ReplicaSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym936 := z.DecBinary() + _ = yym936 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct937 := r.ContainerType() + if yyct937 == codecSelferValueTypeMap1234 { + yyl937 := r.ReadMapStart() + if yyl937 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl937, d) + } + } else if yyct937 == codecSelferValueTypeArray1234 { + yyl937 := r.ReadArrayStart() + if yyl937 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl937, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys938Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys938Slc + var yyhl938 bool = l >= 0 + for yyj938 := 0; ; yyj938++ { + if yyhl938 { + if yyj938 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys938Slc = r.DecodeBytes(yys938Slc, true, true) + yys938 := string(yys938Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys938 { case "replicas": if r.TryDecodeAsNil() { x.Replicas = 0 @@ -10614,8 +11241,8 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym882 := z.DecBinary() - _ = yym882 + yym942 := z.DecBinary() + _ = yym942 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { @@ -10626,13 +11253,13 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv883 := &x.Template - yyv883.CodecDecodeSelf(d) + yyv943 := &x.Template + yyv943.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys878) - } // end switch yys878 - } // end for yyj878 + z.DecStructFieldNotFound(-1, yys938) + } // end switch yys938 + } // end for yyj938 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -10640,16 +11267,16 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj884 int - var yyb884 bool - var yyhl884 bool = l >= 0 - yyj884++ - if yyhl884 { - yyb884 = yyj884 > l + var yyj944 int + var yyb944 bool + var yyhl944 bool = l >= 0 + yyj944++ + if yyhl944 { + yyb944 = yyj944 > l } else { - yyb884 = r.CheckBreak() + yyb944 = r.CheckBreak() } - if yyb884 { + if yyb944 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10659,13 +11286,13 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj884++ - if yyhl884 { - yyb884 = yyj884 > l + yyj944++ + if yyhl944 { + yyb944 = yyj944 > l } else { - yyb884 = r.CheckBreak() + yyb944 = r.CheckBreak() } - if yyb884 { + if yyb944 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10675,13 +11302,13 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.MinReadySeconds = int32(r.DecodeInt(32)) } - yyj884++ - if yyhl884 { - yyb884 = yyj884 > l + yyj944++ + if yyhl944 { + yyb944 = yyj944 > l } else { - yyb884 = r.CheckBreak() + yyb944 = r.CheckBreak() } - if yyb884 { + if yyb944 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10694,21 +11321,21 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Selector == nil { x.Selector = new(pkg1_unversioned.LabelSelector) } - yym888 := z.DecBinary() - _ = yym888 + yym948 := z.DecBinary() + _ = yym948 if false { } else if z.HasExtensions() && z.DecExt(x.Selector) { } else { z.DecFallback(x.Selector, false) } } - yyj884++ - if yyhl884 { - yyb884 = yyj884 > l + yyj944++ + if yyhl944 { + yyb944 = yyj944 > l } else { - yyb884 = r.CheckBreak() + yyb944 = r.CheckBreak() } - if yyb884 { + if yyb944 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10716,21 +11343,21 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_api.PodTemplateSpec{} } else { - yyv889 := &x.Template - yyv889.CodecDecodeSelf(d) + yyv949 := &x.Template + yyv949.CodecDecodeSelf(d) } for { - yyj884++ - if yyhl884 { - yyb884 = yyj884 > l + yyj944++ + if yyhl944 { + yyb944 = yyj944 > l } else { - yyb884 = r.CheckBreak() + yyb944 = r.CheckBreak() } - if yyb884 { + if yyb944 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj884-1, "") + z.DecStructFieldNotFound(yyj944-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -10742,38 +11369,38 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym890 := z.EncBinary() - _ = yym890 + yym950 := z.EncBinary() + _ = yym950 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep891 := !z.EncBinary() - yy2arr891 := z.EncBasicHandle().StructToArray - var yyq891 [6]bool - _, _, _ = yysep891, yyq891, yy2arr891 - const yyr891 bool = false - yyq891[1] = x.FullyLabeledReplicas != 0 - yyq891[2] = x.ReadyReplicas != 0 - yyq891[3] = x.AvailableReplicas != 0 - yyq891[4] = x.ObservedGeneration != 0 - yyq891[5] = len(x.Conditions) != 0 - var yynn891 int - if yyr891 || yy2arr891 { + yysep951 := !z.EncBinary() + yy2arr951 := z.EncBasicHandle().StructToArray + var yyq951 [6]bool + _, _, _ = yysep951, yyq951, yy2arr951 + const yyr951 bool = false + yyq951[1] = x.FullyLabeledReplicas != 0 + yyq951[2] = x.ReadyReplicas != 0 + yyq951[3] = x.AvailableReplicas != 0 + yyq951[4] = x.ObservedGeneration != 0 + yyq951[5] = len(x.Conditions) != 0 + var yynn951 int + if yyr951 || yy2arr951 { r.EncodeArrayStart(6) } else { - yynn891 = 1 - for _, b := range yyq891 { + yynn951 = 1 + for _, b := range yyq951 { if b { - yynn891++ + yynn951++ } } - r.EncodeMapStart(yynn891) - yynn891 = 0 + r.EncodeMapStart(yynn951) + yynn951 = 0 } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym893 := z.EncBinary() - _ = yym893 + yym953 := z.EncBinary() + _ = yym953 if false { } else { r.EncodeInt(int64(x.Replicas)) @@ -10782,18 +11409,18 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("replicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym894 := z.EncBinary() - _ = yym894 + yym954 := z.EncBinary() + _ = yym954 if false { } else { r.EncodeInt(int64(x.Replicas)) } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq891[1] { - yym896 := z.EncBinary() - _ = yym896 + if yyq951[1] { + yym956 := z.EncBinary() + _ = yym956 if false { } else { r.EncodeInt(int64(x.FullyLabeledReplicas)) @@ -10802,23 +11429,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq891[1] { + if yyq951[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("fullyLabeledReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym897 := z.EncBinary() - _ = yym897 + yym957 := z.EncBinary() + _ = yym957 if false { } else { r.EncodeInt(int64(x.FullyLabeledReplicas)) } } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq891[2] { - yym899 := z.EncBinary() - _ = yym899 + if yyq951[2] { + yym959 := z.EncBinary() + _ = yym959 if false { } else { r.EncodeInt(int64(x.ReadyReplicas)) @@ -10827,23 +11454,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq891[2] { + if yyq951[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readyReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym900 := z.EncBinary() - _ = yym900 + yym960 := z.EncBinary() + _ = yym960 if false { } else { r.EncodeInt(int64(x.ReadyReplicas)) } } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq891[3] { - yym902 := z.EncBinary() - _ = yym902 + if yyq951[3] { + yym962 := z.EncBinary() + _ = yym962 if false { } else { r.EncodeInt(int64(x.AvailableReplicas)) @@ -10852,23 +11479,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq891[3] { + if yyq951[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym903 := z.EncBinary() - _ = yym903 + yym963 := z.EncBinary() + _ = yym963 if false { } else { r.EncodeInt(int64(x.AvailableReplicas)) } } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq891[4] { - yym905 := z.EncBinary() - _ = yym905 + if yyq951[4] { + yym965 := z.EncBinary() + _ = yym965 if false { } else { r.EncodeInt(int64(x.ObservedGeneration)) @@ -10877,26 +11504,26 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq891[4] { + if yyq951[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym906 := z.EncBinary() - _ = yym906 + yym966 := z.EncBinary() + _ = yym966 if false { } else { r.EncodeInt(int64(x.ObservedGeneration)) } } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq891[5] { + if yyq951[5] { if x.Conditions == nil { r.EncodeNil() } else { - yym908 := z.EncBinary() - _ = yym908 + yym968 := z.EncBinary() + _ = yym968 if false { } else { h.encSliceReplicaSetCondition(([]ReplicaSetCondition)(x.Conditions), e) @@ -10906,15 +11533,15 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq891[5] { + if yyq951[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym909 := z.EncBinary() - _ = yym909 + yym969 := z.EncBinary() + _ = yym969 if false { } else { h.encSliceReplicaSetCondition(([]ReplicaSetCondition)(x.Conditions), e) @@ -10922,7 +11549,7 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr891 || yy2arr891 { + if yyr951 || yy2arr951 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -10935,25 +11562,25 @@ func (x *ReplicaSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym910 := z.DecBinary() - _ = yym910 + yym970 := z.DecBinary() + _ = yym970 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct911 := r.ContainerType() - if yyct911 == codecSelferValueTypeMap1234 { - yyl911 := r.ReadMapStart() - if yyl911 == 0 { + yyct971 := r.ContainerType() + if yyct971 == codecSelferValueTypeMap1234 { + yyl971 := r.ReadMapStart() + if yyl971 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl911, d) + x.codecDecodeSelfFromMap(yyl971, d) } - } else if yyct911 == codecSelferValueTypeArray1234 { - yyl911 := r.ReadArrayStart() - if yyl911 == 0 { + } else if yyct971 == codecSelferValueTypeArray1234 { + yyl971 := r.ReadArrayStart() + if yyl971 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl911, d) + x.codecDecodeSelfFromArray(yyl971, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -10965,12 +11592,12 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys912Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys912Slc - var yyhl912 bool = l >= 0 - for yyj912 := 0; ; yyj912++ { - if yyhl912 { - if yyj912 >= l { + var yys972Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys972Slc + var yyhl972 bool = l >= 0 + for yyj972 := 0; ; yyj972++ { + if yyhl972 { + if yyj972 >= l { break } } else { @@ -10979,10 +11606,10 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys912Slc = r.DecodeBytes(yys912Slc, true, true) - yys912 := string(yys912Slc) + yys972Slc = r.DecodeBytes(yys972Slc, true, true) + yys972 := string(yys972Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys912 { + switch yys972 { case "replicas": if r.TryDecodeAsNil() { x.Replicas = 0 @@ -11017,18 +11644,18 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv918 := &x.Conditions - yym919 := z.DecBinary() - _ = yym919 + yyv978 := &x.Conditions + yym979 := z.DecBinary() + _ = yym979 if false { } else { - h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv918), d) + h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv978), d) } } default: - z.DecStructFieldNotFound(-1, yys912) - } // end switch yys912 - } // end for yyj912 + z.DecStructFieldNotFound(-1, yys972) + } // end switch yys972 + } // end for yyj972 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -11036,16 +11663,16 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj920 int - var yyb920 bool - var yyhl920 bool = l >= 0 - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + var yyj980 int + var yyb980 bool + var yyhl980 bool = l >= 0 + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11055,13 +11682,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11071,13 +11698,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.FullyLabeledReplicas = int32(r.DecodeInt(32)) } - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11087,13 +11714,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ReadyReplicas = int32(r.DecodeInt(32)) } - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11103,13 +11730,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.AvailableReplicas = int32(r.DecodeInt(32)) } - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11119,13 +11746,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ObservedGeneration = int64(r.DecodeInt(64)) } - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11133,26 +11760,26 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv926 := &x.Conditions - yym927 := z.DecBinary() - _ = yym927 + yyv986 := &x.Conditions + yym987 := z.DecBinary() + _ = yym987 if false { } else { - h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv926), d) + h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv986), d) } } for { - yyj920++ - if yyhl920 { - yyb920 = yyj920 > l + yyj980++ + if yyhl980 { + yyb980 = yyj980 > l } else { - yyb920 = r.CheckBreak() + yyb980 = r.CheckBreak() } - if yyb920 { + if yyb980 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj920-1, "") + z.DecStructFieldNotFound(yyj980-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11161,8 +11788,8 @@ func (x ReplicaSetConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym928 := z.EncBinary() - _ = yym928 + yym988 := z.EncBinary() + _ = yym988 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -11174,8 +11801,8 @@ func (x *ReplicaSetConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym929 := z.DecBinary() - _ = yym929 + yym989 := z.DecBinary() + _ = yym989 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -11190,34 +11817,33 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym930 := z.EncBinary() - _ = yym930 + yym990 := z.EncBinary() + _ = yym990 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep931 := !z.EncBinary() - yy2arr931 := z.EncBasicHandle().StructToArray - var yyq931 [6]bool - _, _, _ = yysep931, yyq931, yy2arr931 - const yyr931 bool = false - yyq931[2] = true - yyq931[3] = true - yyq931[4] = x.Reason != "" - yyq931[5] = x.Message != "" - var yynn931 int - if yyr931 || yy2arr931 { - r.EncodeArrayStart(6) + yysep991 := !z.EncBinary() + yy2arr991 := z.EncBasicHandle().StructToArray + var yyq991 [5]bool + _, _, _ = yysep991, yyq991, yy2arr991 + const yyr991 bool = false + yyq991[2] = true + yyq991[3] = x.Reason != "" + yyq991[4] = x.Message != "" + var yynn991 int + if yyr991 || yy2arr991 { + r.EncodeArrayStart(5) } else { - yynn931 = 2 - for _, b := range yyq931 { + yynn991 = 2 + for _, b := range yyq991 { if b { - yynn931++ + yynn991++ } } - r.EncodeMapStart(yynn931) - yynn931 = 0 + r.EncodeMapStart(yynn991) + yynn991 = 0 } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -11226,10 +11852,10 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym934 := z.EncBinary() - _ = yym934 + yym994 := z.EncBinary() + _ = yym994 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { @@ -11239,93 +11865,56 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym935 := z.EncBinary() - _ = yym935 + yym995 := z.EncBinary() + _ = yym995 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Status)) } } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq931[2] { - yy937 := &x.LastProbeTime - yym938 := z.EncBinary() - _ = yym938 + if yyq991[2] { + yy997 := &x.LastTransitionTime + yym998 := z.EncBinary() + _ = yym998 if false { - } else if z.HasExtensions() && z.EncExt(yy937) { - } else if yym938 { - z.EncBinaryMarshal(yy937) - } else if !yym938 && z.IsJSONHandle() { - z.EncJSONMarshal(yy937) + } else if z.HasExtensions() && z.EncExt(yy997) { + } else if yym998 { + z.EncBinaryMarshal(yy997) + } else if !yym998 && z.IsJSONHandle() { + z.EncJSONMarshal(yy997) } else { - z.EncFallback(yy937) + z.EncFallback(yy997) } } else { r.EncodeNil() } } else { - if yyq931[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy939 := &x.LastProbeTime - yym940 := z.EncBinary() - _ = yym940 - if false { - } else if z.HasExtensions() && z.EncExt(yy939) { - } else if yym940 { - z.EncBinaryMarshal(yy939) - } else if !yym940 && z.IsJSONHandle() { - z.EncJSONMarshal(yy939) - } else { - z.EncFallback(yy939) - } - } - } - if yyr931 || yy2arr931 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq931[3] { - yy942 := &x.LastTransitionTime - yym943 := z.EncBinary() - _ = yym943 - if false { - } else if z.HasExtensions() && z.EncExt(yy942) { - } else if yym943 { - z.EncBinaryMarshal(yy942) - } else if !yym943 && z.IsJSONHandle() { - z.EncJSONMarshal(yy942) - } else { - z.EncFallback(yy942) - } - } else { - r.EncodeNil() - } - } else { - if yyq931[3] { + if yyq991[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy944 := &x.LastTransitionTime - yym945 := z.EncBinary() - _ = yym945 + yy999 := &x.LastTransitionTime + yym1000 := z.EncBinary() + _ = yym1000 if false { - } else if z.HasExtensions() && z.EncExt(yy944) { - } else if yym945 { - z.EncBinaryMarshal(yy944) - } else if !yym945 && z.IsJSONHandle() { - z.EncJSONMarshal(yy944) + } else if z.HasExtensions() && z.EncExt(yy999) { + } else if yym1000 { + z.EncBinaryMarshal(yy999) + } else if !yym1000 && z.IsJSONHandle() { + z.EncJSONMarshal(yy999) } else { - z.EncFallback(yy944) + z.EncFallback(yy999) } } } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq931[4] { - yym947 := z.EncBinary() - _ = yym947 + if yyq991[3] { + yym1002 := z.EncBinary() + _ = yym1002 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -11334,23 +11923,23 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq931[4] { + if yyq991[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym948 := z.EncBinary() - _ = yym948 + yym1003 := z.EncBinary() + _ = yym1003 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq931[5] { - yym950 := z.EncBinary() - _ = yym950 + if yyq991[4] { + yym1005 := z.EncBinary() + _ = yym1005 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -11359,19 +11948,19 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq931[5] { + if yyq991[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym951 := z.EncBinary() - _ = yym951 + yym1006 := z.EncBinary() + _ = yym1006 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr931 || yy2arr931 { + if yyr991 || yy2arr991 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -11384,25 +11973,25 @@ func (x *ReplicaSetCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym952 := z.DecBinary() - _ = yym952 + yym1007 := z.DecBinary() + _ = yym1007 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct953 := r.ContainerType() - if yyct953 == codecSelferValueTypeMap1234 { - yyl953 := r.ReadMapStart() - if yyl953 == 0 { + yyct1008 := r.ContainerType() + if yyct1008 == codecSelferValueTypeMap1234 { + yyl1008 := r.ReadMapStart() + if yyl1008 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl953, d) + x.codecDecodeSelfFromMap(yyl1008, d) } - } else if yyct953 == codecSelferValueTypeArray1234 { - yyl953 := r.ReadArrayStart() - if yyl953 == 0 { + } else if yyct1008 == codecSelferValueTypeArray1234 { + yyl1008 := r.ReadArrayStart() + if yyl1008 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl953, d) + x.codecDecodeSelfFromArray(yyl1008, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -11414,12 +12003,12 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys954Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys954Slc - var yyhl954 bool = l >= 0 - for yyj954 := 0; ; yyj954++ { - if yyhl954 { - if yyj954 >= l { + var yys1009Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1009Slc + var yyhl1009 bool = l >= 0 + for yyj1009 := 0; ; yyj1009++ { + if yyhl1009 { + if yyj1009 >= l { break } } else { @@ -11428,10 +12017,10 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys954Slc = r.DecodeBytes(yys954Slc, true, true) - yys954 := string(yys954Slc) + yys1009Slc = r.DecodeBytes(yys1009Slc, true, true) + yys1009 := string(yys1009Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys954 { + switch yys1009 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -11444,38 +12033,21 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } else { x.Status = pkg2_api.ConditionStatus(r.DecodeString()) } - case "lastProbeTime": - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg1_unversioned.Time{} - } else { - yyv957 := &x.LastProbeTime - yym958 := z.DecBinary() - _ = yym958 - if false { - } else if z.HasExtensions() && z.DecExt(yyv957) { - } else if yym958 { - z.DecBinaryUnmarshal(yyv957) - } else if !yym958 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv957) - } else { - z.DecFallback(yyv957, false) - } - } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv959 := &x.LastTransitionTime - yym960 := z.DecBinary() - _ = yym960 + yyv1012 := &x.LastTransitionTime + yym1013 := z.DecBinary() + _ = yym1013 if false { - } else if z.HasExtensions() && z.DecExt(yyv959) { - } else if yym960 { - z.DecBinaryUnmarshal(yyv959) - } else if !yym960 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv959) + } else if z.HasExtensions() && z.DecExt(yyv1012) { + } else if yym1013 { + z.DecBinaryUnmarshal(yyv1012) + } else if !yym1013 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1012) } else { - z.DecFallback(yyv959, false) + z.DecFallback(yyv1012, false) } } case "reason": @@ -11491,9 +12063,9 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys954) - } // end switch yys954 - } // end for yyj954 + z.DecStructFieldNotFound(-1, yys1009) + } // end switch yys1009 + } // end for yyj1009 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -11501,16 +12073,16 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj963 int - var yyb963 bool - var yyhl963 bool = l >= 0 - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + var yyj1016 int + var yyb1016 bool + var yyhl1016 bool = l >= 0 + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { + if yyb1016 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11520,13 +12092,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Type = ReplicaSetConditionType(r.DecodeString()) } - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { + if yyb1016 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11536,40 +12108,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Status = pkg2_api.ConditionStatus(r.DecodeString()) } - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg1_unversioned.Time{} - } else { - yyv966 := &x.LastProbeTime - yym967 := z.DecBinary() - _ = yym967 - if false { - } else if z.HasExtensions() && z.DecExt(yyv966) { - } else if yym967 { - z.DecBinaryUnmarshal(yyv966) - } else if !yym967 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv966) - } else { - z.DecFallback(yyv966, false) - } - } - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l - } else { - yyb963 = r.CheckBreak() - } - if yyb963 { + if yyb1016 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11577,26 +12122,26 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv968 := &x.LastTransitionTime - yym969 := z.DecBinary() - _ = yym969 + yyv1019 := &x.LastTransitionTime + yym1020 := z.DecBinary() + _ = yym1020 if false { - } else if z.HasExtensions() && z.DecExt(yyv968) { - } else if yym969 { - z.DecBinaryUnmarshal(yyv968) - } else if !yym969 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv968) + } else if z.HasExtensions() && z.DecExt(yyv1019) { + } else if yym1020 { + z.DecBinaryUnmarshal(yyv1019) + } else if !yym1020 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1019) } else { - z.DecFallback(yyv968, false) + z.DecFallback(yyv1019, false) } } - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { + if yyb1016 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11606,13 +12151,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Reason = string(r.DecodeString()) } - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { + if yyb1016 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11623,17 +12168,17 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Message = string(r.DecodeString()) } for { - yyj963++ - if yyhl963 { - yyb963 = yyj963 > l + yyj1016++ + if yyhl1016 { + yyb1016 = yyj1016 > l } else { - yyb963 = r.CheckBreak() + yyb1016 = r.CheckBreak() } - if yyb963 { + if yyb1016 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj963-1, "") + z.DecStructFieldNotFound(yyj1016-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11645,38 +12190,38 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym972 := z.EncBinary() - _ = yym972 + yym1023 := z.EncBinary() + _ = yym1023 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep973 := !z.EncBinary() - yy2arr973 := z.EncBasicHandle().StructToArray - var yyq973 [4]bool - _, _, _ = yysep973, yyq973, yy2arr973 - const yyr973 bool = false - yyq973[0] = x.Kind != "" - yyq973[1] = x.APIVersion != "" - yyq973[2] = true - yyq973[3] = true - var yynn973 int - if yyr973 || yy2arr973 { + yysep1024 := !z.EncBinary() + yy2arr1024 := z.EncBasicHandle().StructToArray + var yyq1024 [4]bool + _, _, _ = yysep1024, yyq1024, yy2arr1024 + const yyr1024 bool = false + yyq1024[0] = x.Kind != "" + yyq1024[1] = x.APIVersion != "" + yyq1024[2] = true + yyq1024[3] = true + var yynn1024 int + if yyr1024 || yy2arr1024 { r.EncodeArrayStart(4) } else { - yynn973 = 0 - for _, b := range yyq973 { + yynn1024 = 0 + for _, b := range yyq1024 { if b { - yynn973++ + yynn1024++ } } - r.EncodeMapStart(yynn973) - yynn973 = 0 + r.EncodeMapStart(yynn1024) + yynn1024 = 0 } - if yyr973 || yy2arr973 { + if yyr1024 || yy2arr1024 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq973[0] { - yym975 := z.EncBinary() - _ = yym975 + if yyq1024[0] { + yym1026 := z.EncBinary() + _ = yym1026 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -11685,23 +12230,23 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq973[0] { + if yyq1024[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym976 := z.EncBinary() - _ = yym976 + yym1027 := z.EncBinary() + _ = yym1027 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr973 || yy2arr973 { + if yyr1024 || yy2arr1024 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq973[1] { - yym978 := z.EncBinary() - _ = yym978 + if yyq1024[1] { + yym1029 := z.EncBinary() + _ = yym1029 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -11710,53 +12255,53 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq973[1] { + if yyq1024[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym979 := z.EncBinary() - _ = yym979 + yym1030 := z.EncBinary() + _ = yym1030 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr973 || yy2arr973 { + if yyr1024 || yy2arr1024 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq973[2] { - yy981 := &x.ObjectMeta - yy981.CodecEncodeSelf(e) + if yyq1024[2] { + yy1032 := &x.ObjectMeta + yy1032.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq973[2] { + if yyq1024[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy982 := &x.ObjectMeta - yy982.CodecEncodeSelf(e) + yy1033 := &x.ObjectMeta + yy1033.CodecEncodeSelf(e) } } - if yyr973 || yy2arr973 { + if yyr1024 || yy2arr1024 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq973[3] { - yy984 := &x.Spec - yy984.CodecEncodeSelf(e) + if yyq1024[3] { + yy1035 := &x.Spec + yy1035.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq973[3] { + if yyq1024[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy985 := &x.Spec - yy985.CodecEncodeSelf(e) + yy1036 := &x.Spec + yy1036.CodecEncodeSelf(e) } } - if yyr973 || yy2arr973 { + if yyr1024 || yy2arr1024 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -11769,25 +12314,25 @@ func (x *PodSecurityPolicy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym986 := z.DecBinary() - _ = yym986 + yym1037 := z.DecBinary() + _ = yym1037 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct987 := r.ContainerType() - if yyct987 == codecSelferValueTypeMap1234 { - yyl987 := r.ReadMapStart() - if yyl987 == 0 { + yyct1038 := r.ContainerType() + if yyct1038 == codecSelferValueTypeMap1234 { + yyl1038 := r.ReadMapStart() + if yyl1038 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl987, d) + x.codecDecodeSelfFromMap(yyl1038, d) } - } else if yyct987 == codecSelferValueTypeArray1234 { - yyl987 := r.ReadArrayStart() - if yyl987 == 0 { + } else if yyct1038 == codecSelferValueTypeArray1234 { + yyl1038 := r.ReadArrayStart() + if yyl1038 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl987, d) + x.codecDecodeSelfFromArray(yyl1038, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -11799,12 +12344,12 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys988Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys988Slc - var yyhl988 bool = l >= 0 - for yyj988 := 0; ; yyj988++ { - if yyhl988 { - if yyj988 >= l { + var yys1039Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1039Slc + var yyhl1039 bool = l >= 0 + for yyj1039 := 0; ; yyj1039++ { + if yyhl1039 { + if yyj1039 >= l { break } } else { @@ -11813,10 +12358,10 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys988Slc = r.DecodeBytes(yys988Slc, true, true) - yys988 := string(yys988Slc) + yys1039Slc = r.DecodeBytes(yys1039Slc, true, true) + yys1039 := string(yys1039Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys988 { + switch yys1039 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -11833,20 +12378,20 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv991 := &x.ObjectMeta - yyv991.CodecDecodeSelf(d) + yyv1042 := &x.ObjectMeta + yyv1042.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = PodSecurityPolicySpec{} } else { - yyv992 := &x.Spec - yyv992.CodecDecodeSelf(d) + yyv1043 := &x.Spec + yyv1043.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys988) - } // end switch yys988 - } // end for yyj988 + z.DecStructFieldNotFound(-1, yys1039) + } // end switch yys1039 + } // end for yyj1039 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -11854,16 +12399,16 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj993 int - var yyb993 bool - var yyhl993 bool = l >= 0 - yyj993++ - if yyhl993 { - yyb993 = yyj993 > l + var yyj1044 int + var yyb1044 bool + var yyhl1044 bool = l >= 0 + yyj1044++ + if yyhl1044 { + yyb1044 = yyj1044 > l } else { - yyb993 = r.CheckBreak() + yyb1044 = r.CheckBreak() } - if yyb993 { + if yyb1044 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11873,13 +12418,13 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj993++ - if yyhl993 { - yyb993 = yyj993 > l + yyj1044++ + if yyhl1044 { + yyb1044 = yyj1044 > l } else { - yyb993 = r.CheckBreak() + yyb1044 = r.CheckBreak() } - if yyb993 { + if yyb1044 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11889,13 +12434,13 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj993++ - if yyhl993 { - yyb993 = yyj993 > l + yyj1044++ + if yyhl1044 { + yyb1044 = yyj1044 > l } else { - yyb993 = r.CheckBreak() + yyb1044 = r.CheckBreak() } - if yyb993 { + if yyb1044 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11903,16 +12448,16 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv996 := &x.ObjectMeta - yyv996.CodecDecodeSelf(d) + yyv1047 := &x.ObjectMeta + yyv1047.CodecDecodeSelf(d) } - yyj993++ - if yyhl993 { - yyb993 = yyj993 > l + yyj1044++ + if yyhl1044 { + yyb1044 = yyj1044 > l } else { - yyb993 = r.CheckBreak() + yyb1044 = r.CheckBreak() } - if yyb993 { + if yyb1044 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11920,21 +12465,21 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Spec = PodSecurityPolicySpec{} } else { - yyv997 := &x.Spec - yyv997.CodecDecodeSelf(d) + yyv1048 := &x.Spec + yyv1048.CodecDecodeSelf(d) } for { - yyj993++ - if yyhl993 { - yyb993 = yyj993 > l + yyj1044++ + if yyhl1044 { + yyb1044 = yyj1044 > l } else { - yyb993 = r.CheckBreak() + yyb1044 = r.CheckBreak() } - if yyb993 { + if yyb1044 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj993-1, "") + z.DecStructFieldNotFound(yyj1044-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11946,44 +12491,44 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym998 := z.EncBinary() - _ = yym998 + yym1049 := z.EncBinary() + _ = yym1049 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep999 := !z.EncBinary() - yy2arr999 := z.EncBasicHandle().StructToArray - var yyq999 [14]bool - _, _, _ = yysep999, yyq999, yy2arr999 - const yyr999 bool = false - yyq999[0] = x.Privileged != false - yyq999[1] = len(x.DefaultAddCapabilities) != 0 - yyq999[2] = len(x.RequiredDropCapabilities) != 0 - yyq999[3] = len(x.AllowedCapabilities) != 0 - yyq999[4] = len(x.Volumes) != 0 - yyq999[5] = x.HostNetwork != false - yyq999[6] = len(x.HostPorts) != 0 - yyq999[7] = x.HostPID != false - yyq999[8] = x.HostIPC != false - yyq999[13] = x.ReadOnlyRootFilesystem != false - var yynn999 int - if yyr999 || yy2arr999 { + yysep1050 := !z.EncBinary() + yy2arr1050 := z.EncBasicHandle().StructToArray + var yyq1050 [14]bool + _, _, _ = yysep1050, yyq1050, yy2arr1050 + const yyr1050 bool = false + yyq1050[0] = x.Privileged != false + yyq1050[1] = len(x.DefaultAddCapabilities) != 0 + yyq1050[2] = len(x.RequiredDropCapabilities) != 0 + yyq1050[3] = len(x.AllowedCapabilities) != 0 + yyq1050[4] = len(x.Volumes) != 0 + yyq1050[5] = x.HostNetwork != false + yyq1050[6] = len(x.HostPorts) != 0 + yyq1050[7] = x.HostPID != false + yyq1050[8] = x.HostIPC != false + yyq1050[13] = x.ReadOnlyRootFilesystem != false + var yynn1050 int + if yyr1050 || yy2arr1050 { r.EncodeArrayStart(14) } else { - yynn999 = 4 - for _, b := range yyq999 { + yynn1050 = 4 + for _, b := range yyq1050 { if b { - yynn999++ + yynn1050++ } } - r.EncodeMapStart(yynn999) - yynn999 = 0 + r.EncodeMapStart(yynn1050) + yynn1050 = 0 } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[0] { - yym1001 := z.EncBinary() - _ = yym1001 + if yyq1050[0] { + yym1052 := z.EncBinary() + _ = yym1052 if false { } else { r.EncodeBool(bool(x.Privileged)) @@ -11992,26 +12537,26 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq999[0] { + if yyq1050[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("privileged")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1002 := z.EncBinary() - _ = yym1002 + yym1053 := z.EncBinary() + _ = yym1053 if false { } else { r.EncodeBool(bool(x.Privileged)) } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[1] { + if yyq1050[1] { if x.DefaultAddCapabilities == nil { r.EncodeNil() } else { - yym1004 := z.EncBinary() - _ = yym1004 + yym1055 := z.EncBinary() + _ = yym1055 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.DefaultAddCapabilities), e) @@ -12021,15 +12566,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq999[1] { + if yyq1050[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("defaultAddCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.DefaultAddCapabilities == nil { r.EncodeNil() } else { - yym1005 := z.EncBinary() - _ = yym1005 + yym1056 := z.EncBinary() + _ = yym1056 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.DefaultAddCapabilities), e) @@ -12037,14 +12582,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[2] { + if yyq1050[2] { if x.RequiredDropCapabilities == nil { r.EncodeNil() } else { - yym1007 := z.EncBinary() - _ = yym1007 + yym1058 := z.EncBinary() + _ = yym1058 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.RequiredDropCapabilities), e) @@ -12054,15 +12599,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq999[2] { + if yyq1050[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("requiredDropCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RequiredDropCapabilities == nil { r.EncodeNil() } else { - yym1008 := z.EncBinary() - _ = yym1008 + yym1059 := z.EncBinary() + _ = yym1059 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.RequiredDropCapabilities), e) @@ -12070,14 +12615,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[3] { + if yyq1050[3] { if x.AllowedCapabilities == nil { r.EncodeNil() } else { - yym1010 := z.EncBinary() - _ = yym1010 + yym1061 := z.EncBinary() + _ = yym1061 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.AllowedCapabilities), e) @@ -12087,15 +12632,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq999[3] { + if yyq1050[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("allowedCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.AllowedCapabilities == nil { r.EncodeNil() } else { - yym1011 := z.EncBinary() - _ = yym1011 + yym1062 := z.EncBinary() + _ = yym1062 if false { } else { h.encSliceapi_Capability(([]pkg2_api.Capability)(x.AllowedCapabilities), e) @@ -12103,14 +12648,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[4] { + if yyq1050[4] { if x.Volumes == nil { r.EncodeNil() } else { - yym1013 := z.EncBinary() - _ = yym1013 + yym1064 := z.EncBinary() + _ = yym1064 if false { } else { h.encSliceFSType(([]FSType)(x.Volumes), e) @@ -12120,15 +12665,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq999[4] { + if yyq1050[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Volumes == nil { r.EncodeNil() } else { - yym1014 := z.EncBinary() - _ = yym1014 + yym1065 := z.EncBinary() + _ = yym1065 if false { } else { h.encSliceFSType(([]FSType)(x.Volumes), e) @@ -12136,11 +12681,11 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[5] { - yym1016 := z.EncBinary() - _ = yym1016 + if yyq1050[5] { + yym1067 := z.EncBinary() + _ = yym1067 if false { } else { r.EncodeBool(bool(x.HostNetwork)) @@ -12149,26 +12694,26 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq999[5] { + if yyq1050[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostNetwork")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1017 := z.EncBinary() - _ = yym1017 + yym1068 := z.EncBinary() + _ = yym1068 if false { } else { r.EncodeBool(bool(x.HostNetwork)) } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[6] { + if yyq1050[6] { if x.HostPorts == nil { r.EncodeNil() } else { - yym1019 := z.EncBinary() - _ = yym1019 + yym1070 := z.EncBinary() + _ = yym1070 if false { } else { h.encSliceHostPortRange(([]HostPortRange)(x.HostPorts), e) @@ -12178,15 +12723,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq999[6] { + if yyq1050[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostPorts")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.HostPorts == nil { r.EncodeNil() } else { - yym1020 := z.EncBinary() - _ = yym1020 + yym1071 := z.EncBinary() + _ = yym1071 if false { } else { h.encSliceHostPortRange(([]HostPortRange)(x.HostPorts), e) @@ -12194,11 +12739,11 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[7] { - yym1022 := z.EncBinary() - _ = yym1022 + if yyq1050[7] { + yym1073 := z.EncBinary() + _ = yym1073 if false { } else { r.EncodeBool(bool(x.HostPID)) @@ -12207,23 +12752,23 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq999[7] { + if yyq1050[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostPID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1023 := z.EncBinary() - _ = yym1023 + yym1074 := z.EncBinary() + _ = yym1074 if false { } else { r.EncodeBool(bool(x.HostPID)) } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[8] { - yym1025 := z.EncBinary() - _ = yym1025 + if yyq1050[8] { + yym1076 := z.EncBinary() + _ = yym1076 if false { } else { r.EncodeBool(bool(x.HostIPC)) @@ -12232,67 +12777,67 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq999[8] { + if yyq1050[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostIPC")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1026 := z.EncBinary() - _ = yym1026 + yym1077 := z.EncBinary() + _ = yym1077 if false { } else { r.EncodeBool(bool(x.HostIPC)) } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1028 := &x.SELinux - yy1028.CodecEncodeSelf(e) + yy1079 := &x.SELinux + yy1079.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinux")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1029 := &x.SELinux - yy1029.CodecEncodeSelf(e) + yy1080 := &x.SELinux + yy1080.CodecEncodeSelf(e) } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1031 := &x.RunAsUser - yy1031.CodecEncodeSelf(e) + yy1082 := &x.RunAsUser + yy1082.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsUser")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1032 := &x.RunAsUser - yy1032.CodecEncodeSelf(e) + yy1083 := &x.RunAsUser + yy1083.CodecEncodeSelf(e) } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1034 := &x.SupplementalGroups - yy1034.CodecEncodeSelf(e) + yy1085 := &x.SupplementalGroups + yy1085.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("supplementalGroups")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1035 := &x.SupplementalGroups - yy1035.CodecEncodeSelf(e) + yy1086 := &x.SupplementalGroups + yy1086.CodecEncodeSelf(e) } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1037 := &x.FSGroup - yy1037.CodecEncodeSelf(e) + yy1088 := &x.FSGroup + yy1088.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("fsGroup")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1038 := &x.FSGroup - yy1038.CodecEncodeSelf(e) + yy1089 := &x.FSGroup + yy1089.CodecEncodeSelf(e) } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq999[13] { - yym1040 := z.EncBinary() - _ = yym1040 + if yyq1050[13] { + yym1091 := z.EncBinary() + _ = yym1091 if false { } else { r.EncodeBool(bool(x.ReadOnlyRootFilesystem)) @@ -12301,19 +12846,19 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq999[13] { + if yyq1050[13] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readOnlyRootFilesystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1041 := z.EncBinary() - _ = yym1041 + yym1092 := z.EncBinary() + _ = yym1092 if false { } else { r.EncodeBool(bool(x.ReadOnlyRootFilesystem)) } } } - if yyr999 || yy2arr999 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12326,25 +12871,25 @@ func (x *PodSecurityPolicySpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1042 := z.DecBinary() - _ = yym1042 + yym1093 := z.DecBinary() + _ = yym1093 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1043 := r.ContainerType() - if yyct1043 == codecSelferValueTypeMap1234 { - yyl1043 := r.ReadMapStart() - if yyl1043 == 0 { + yyct1094 := r.ContainerType() + if yyct1094 == codecSelferValueTypeMap1234 { + yyl1094 := r.ReadMapStart() + if yyl1094 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1043, d) + x.codecDecodeSelfFromMap(yyl1094, d) } - } else if yyct1043 == codecSelferValueTypeArray1234 { - yyl1043 := r.ReadArrayStart() - if yyl1043 == 0 { + } else if yyct1094 == codecSelferValueTypeArray1234 { + yyl1094 := r.ReadArrayStart() + if yyl1094 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1043, d) + x.codecDecodeSelfFromArray(yyl1094, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12356,12 +12901,12 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1044Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1044Slc - var yyhl1044 bool = l >= 0 - for yyj1044 := 0; ; yyj1044++ { - if yyhl1044 { - if yyj1044 >= l { + var yys1095Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1095Slc + var yyhl1095 bool = l >= 0 + for yyj1095 := 0; ; yyj1095++ { + if yyhl1095 { + if yyj1095 >= l { break } } else { @@ -12370,10 +12915,10 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1044Slc = r.DecodeBytes(yys1044Slc, true, true) - yys1044 := string(yys1044Slc) + yys1095Slc = r.DecodeBytes(yys1095Slc, true, true) + yys1095 := string(yys1095Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1044 { + switch yys1095 { case "privileged": if r.TryDecodeAsNil() { x.Privileged = false @@ -12384,48 +12929,48 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.DefaultAddCapabilities = nil } else { - yyv1046 := &x.DefaultAddCapabilities - yym1047 := z.DecBinary() - _ = yym1047 + yyv1097 := &x.DefaultAddCapabilities + yym1098 := z.DecBinary() + _ = yym1098 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1046), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1097), d) } } case "requiredDropCapabilities": if r.TryDecodeAsNil() { x.RequiredDropCapabilities = nil } else { - yyv1048 := &x.RequiredDropCapabilities - yym1049 := z.DecBinary() - _ = yym1049 + yyv1099 := &x.RequiredDropCapabilities + yym1100 := z.DecBinary() + _ = yym1100 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1048), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1099), d) } } case "allowedCapabilities": if r.TryDecodeAsNil() { x.AllowedCapabilities = nil } else { - yyv1050 := &x.AllowedCapabilities - yym1051 := z.DecBinary() - _ = yym1051 + yyv1101 := &x.AllowedCapabilities + yym1102 := z.DecBinary() + _ = yym1102 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1050), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1101), d) } } case "volumes": if r.TryDecodeAsNil() { x.Volumes = nil } else { - yyv1052 := &x.Volumes - yym1053 := z.DecBinary() - _ = yym1053 + yyv1103 := &x.Volumes + yym1104 := z.DecBinary() + _ = yym1104 if false { } else { - h.decSliceFSType((*[]FSType)(yyv1052), d) + h.decSliceFSType((*[]FSType)(yyv1103), d) } } case "hostNetwork": @@ -12438,12 +12983,12 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.HostPorts = nil } else { - yyv1055 := &x.HostPorts - yym1056 := z.DecBinary() - _ = yym1056 + yyv1106 := &x.HostPorts + yym1107 := z.DecBinary() + _ = yym1107 if false { } else { - h.decSliceHostPortRange((*[]HostPortRange)(yyv1055), d) + h.decSliceHostPortRange((*[]HostPortRange)(yyv1106), d) } } case "hostPID": @@ -12462,29 +13007,29 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.SELinux = SELinuxStrategyOptions{} } else { - yyv1059 := &x.SELinux - yyv1059.CodecDecodeSelf(d) + yyv1110 := &x.SELinux + yyv1110.CodecDecodeSelf(d) } case "runAsUser": if r.TryDecodeAsNil() { x.RunAsUser = RunAsUserStrategyOptions{} } else { - yyv1060 := &x.RunAsUser - yyv1060.CodecDecodeSelf(d) + yyv1111 := &x.RunAsUser + yyv1111.CodecDecodeSelf(d) } case "supplementalGroups": if r.TryDecodeAsNil() { x.SupplementalGroups = SupplementalGroupsStrategyOptions{} } else { - yyv1061 := &x.SupplementalGroups - yyv1061.CodecDecodeSelf(d) + yyv1112 := &x.SupplementalGroups + yyv1112.CodecDecodeSelf(d) } case "fsGroup": if r.TryDecodeAsNil() { x.FSGroup = FSGroupStrategyOptions{} } else { - yyv1062 := &x.FSGroup - yyv1062.CodecDecodeSelf(d) + yyv1113 := &x.FSGroup + yyv1113.CodecDecodeSelf(d) } case "readOnlyRootFilesystem": if r.TryDecodeAsNil() { @@ -12493,9 +13038,9 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod x.ReadOnlyRootFilesystem = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys1044) - } // end switch yys1044 - } // end for yyj1044 + z.DecStructFieldNotFound(-1, yys1095) + } // end switch yys1095 + } // end for yyj1095 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12503,16 +13048,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1064 int - var yyb1064 bool - var yyhl1064 bool = l >= 0 - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + var yyj1115 int + var yyb1115 bool + var yyhl1115 bool = l >= 0 + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12522,13 +13067,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Privileged = bool(r.DecodeBool()) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12536,21 +13081,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.DefaultAddCapabilities = nil } else { - yyv1066 := &x.DefaultAddCapabilities - yym1067 := z.DecBinary() - _ = yym1067 + yyv1117 := &x.DefaultAddCapabilities + yym1118 := z.DecBinary() + _ = yym1118 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1066), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1117), d) } } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12558,21 +13103,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.RequiredDropCapabilities = nil } else { - yyv1068 := &x.RequiredDropCapabilities - yym1069 := z.DecBinary() - _ = yym1069 + yyv1119 := &x.RequiredDropCapabilities + yym1120 := z.DecBinary() + _ = yym1120 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1068), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1119), d) } } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12580,21 +13125,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.AllowedCapabilities = nil } else { - yyv1070 := &x.AllowedCapabilities - yym1071 := z.DecBinary() - _ = yym1071 + yyv1121 := &x.AllowedCapabilities + yym1122 := z.DecBinary() + _ = yym1122 if false { } else { - h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1070), d) + h.decSliceapi_Capability((*[]pkg2_api.Capability)(yyv1121), d) } } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12602,21 +13147,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Volumes = nil } else { - yyv1072 := &x.Volumes - yym1073 := z.DecBinary() - _ = yym1073 + yyv1123 := &x.Volumes + yym1124 := z.DecBinary() + _ = yym1124 if false { } else { - h.decSliceFSType((*[]FSType)(yyv1072), d) + h.decSliceFSType((*[]FSType)(yyv1123), d) } } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12626,13 +13171,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostNetwork = bool(r.DecodeBool()) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12640,21 +13185,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.HostPorts = nil } else { - yyv1075 := &x.HostPorts - yym1076 := z.DecBinary() - _ = yym1076 + yyv1126 := &x.HostPorts + yym1127 := z.DecBinary() + _ = yym1127 if false { } else { - h.decSliceHostPortRange((*[]HostPortRange)(yyv1075), d) + h.decSliceHostPortRange((*[]HostPortRange)(yyv1126), d) } } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12664,13 +13209,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostPID = bool(r.DecodeBool()) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12680,13 +13225,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostIPC = bool(r.DecodeBool()) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12694,16 +13239,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.SELinux = SELinuxStrategyOptions{} } else { - yyv1079 := &x.SELinux - yyv1079.CodecDecodeSelf(d) + yyv1130 := &x.SELinux + yyv1130.CodecDecodeSelf(d) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12711,16 +13256,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.RunAsUser = RunAsUserStrategyOptions{} } else { - yyv1080 := &x.RunAsUser - yyv1080.CodecDecodeSelf(d) + yyv1131 := &x.RunAsUser + yyv1131.CodecDecodeSelf(d) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12728,16 +13273,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.SupplementalGroups = SupplementalGroupsStrategyOptions{} } else { - yyv1081 := &x.SupplementalGroups - yyv1081.CodecDecodeSelf(d) + yyv1132 := &x.SupplementalGroups + yyv1132.CodecDecodeSelf(d) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12745,16 +13290,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.FSGroup = FSGroupStrategyOptions{} } else { - yyv1082 := &x.FSGroup - yyv1082.CodecDecodeSelf(d) + yyv1133 := &x.FSGroup + yyv1133.CodecDecodeSelf(d) } - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12765,17 +13310,17 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec x.ReadOnlyRootFilesystem = bool(r.DecodeBool()) } for { - yyj1064++ - if yyhl1064 { - yyb1064 = yyj1064 > l + yyj1115++ + if yyhl1115 { + yyb1115 = yyj1115 > l } else { - yyb1064 = r.CheckBreak() + yyb1115 = r.CheckBreak() } - if yyb1064 { + if yyb1115 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1064-1, "") + z.DecStructFieldNotFound(yyj1115-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12787,33 +13332,33 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1084 := z.EncBinary() - _ = yym1084 + yym1135 := z.EncBinary() + _ = yym1135 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1085 := !z.EncBinary() - yy2arr1085 := z.EncBasicHandle().StructToArray - var yyq1085 [2]bool - _, _, _ = yysep1085, yyq1085, yy2arr1085 - const yyr1085 bool = false - var yynn1085 int - if yyr1085 || yy2arr1085 { + yysep1136 := !z.EncBinary() + yy2arr1136 := z.EncBasicHandle().StructToArray + var yyq1136 [2]bool + _, _, _ = yysep1136, yyq1136, yy2arr1136 + const yyr1136 bool = false + var yynn1136 int + if yyr1136 || yy2arr1136 { r.EncodeArrayStart(2) } else { - yynn1085 = 2 - for _, b := range yyq1085 { + yynn1136 = 2 + for _, b := range yyq1136 { if b { - yynn1085++ + yynn1136++ } } - r.EncodeMapStart(yynn1085) - yynn1085 = 0 + r.EncodeMapStart(yynn1136) + yynn1136 = 0 } - if yyr1085 || yy2arr1085 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1087 := z.EncBinary() - _ = yym1087 + yym1138 := z.EncBinary() + _ = yym1138 if false { } else { r.EncodeInt(int64(x.Min)) @@ -12822,17 +13367,17 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("min")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1088 := z.EncBinary() - _ = yym1088 + yym1139 := z.EncBinary() + _ = yym1139 if false { } else { r.EncodeInt(int64(x.Min)) } } - if yyr1085 || yy2arr1085 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1090 := z.EncBinary() - _ = yym1090 + yym1141 := z.EncBinary() + _ = yym1141 if false { } else { r.EncodeInt(int64(x.Max)) @@ -12841,14 +13386,14 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("max")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1091 := z.EncBinary() - _ = yym1091 + yym1142 := z.EncBinary() + _ = yym1142 if false { } else { r.EncodeInt(int64(x.Max)) } } - if yyr1085 || yy2arr1085 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12861,25 +13406,25 @@ func (x *HostPortRange) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1092 := z.DecBinary() - _ = yym1092 + yym1143 := z.DecBinary() + _ = yym1143 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1093 := r.ContainerType() - if yyct1093 == codecSelferValueTypeMap1234 { - yyl1093 := r.ReadMapStart() - if yyl1093 == 0 { + yyct1144 := r.ContainerType() + if yyct1144 == codecSelferValueTypeMap1234 { + yyl1144 := r.ReadMapStart() + if yyl1144 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1093, d) + x.codecDecodeSelfFromMap(yyl1144, d) } - } else if yyct1093 == codecSelferValueTypeArray1234 { - yyl1093 := r.ReadArrayStart() - if yyl1093 == 0 { + } else if yyct1144 == codecSelferValueTypeArray1234 { + yyl1144 := r.ReadArrayStart() + if yyl1144 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1093, d) + x.codecDecodeSelfFromArray(yyl1144, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12891,12 +13436,12 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1094Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1094Slc - var yyhl1094 bool = l >= 0 - for yyj1094 := 0; ; yyj1094++ { - if yyhl1094 { - if yyj1094 >= l { + var yys1145Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1145Slc + var yyhl1145 bool = l >= 0 + for yyj1145 := 0; ; yyj1145++ { + if yyhl1145 { + if yyj1145 >= l { break } } else { @@ -12905,10 +13450,10 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1094Slc = r.DecodeBytes(yys1094Slc, true, true) - yys1094 := string(yys1094Slc) + yys1145Slc = r.DecodeBytes(yys1145Slc, true, true) + yys1145 := string(yys1145Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1094 { + switch yys1145 { case "min": if r.TryDecodeAsNil() { x.Min = 0 @@ -12922,9 +13467,9 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Max = int(r.DecodeInt(codecSelferBitsize1234)) } default: - z.DecStructFieldNotFound(-1, yys1094) - } // end switch yys1094 - } // end for yyj1094 + z.DecStructFieldNotFound(-1, yys1145) + } // end switch yys1145 + } // end for yyj1145 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12932,16 +13477,16 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1097 int - var yyb1097 bool - var yyhl1097 bool = l >= 0 - yyj1097++ - if yyhl1097 { - yyb1097 = yyj1097 > l + var yyj1148 int + var yyb1148 bool + var yyhl1148 bool = l >= 0 + yyj1148++ + if yyhl1148 { + yyb1148 = yyj1148 > l } else { - yyb1097 = r.CheckBreak() + yyb1148 = r.CheckBreak() } - if yyb1097 { + if yyb1148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12951,13 +13496,13 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Min = int(r.DecodeInt(codecSelferBitsize1234)) } - yyj1097++ - if yyhl1097 { - yyb1097 = yyj1097 > l + yyj1148++ + if yyhl1148 { + yyb1148 = yyj1148 > l } else { - yyb1097 = r.CheckBreak() + yyb1148 = r.CheckBreak() } - if yyb1097 { + if yyb1148 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12968,17 +13513,17 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Max = int(r.DecodeInt(codecSelferBitsize1234)) } for { - yyj1097++ - if yyhl1097 { - yyb1097 = yyj1097 > l + yyj1148++ + if yyhl1148 { + yyb1148 = yyj1148 > l } else { - yyb1097 = r.CheckBreak() + yyb1148 = r.CheckBreak() } - if yyb1097 { + if yyb1148 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1097-1, "") + z.DecStructFieldNotFound(yyj1148-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12987,8 +13532,8 @@ func (x FSType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1100 := z.EncBinary() - _ = yym1100 + yym1151 := z.EncBinary() + _ = yym1151 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -13000,8 +13545,8 @@ func (x *FSType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1101 := z.DecBinary() - _ = yym1101 + yym1152 := z.DecBinary() + _ = yym1152 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -13016,31 +13561,31 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1102 := z.EncBinary() - _ = yym1102 + yym1153 := z.EncBinary() + _ = yym1153 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1103 := !z.EncBinary() - yy2arr1103 := z.EncBasicHandle().StructToArray - var yyq1103 [2]bool - _, _, _ = yysep1103, yyq1103, yy2arr1103 - const yyr1103 bool = false - yyq1103[1] = x.SELinuxOptions != nil - var yynn1103 int - if yyr1103 || yy2arr1103 { + yysep1154 := !z.EncBinary() + yy2arr1154 := z.EncBasicHandle().StructToArray + var yyq1154 [2]bool + _, _, _ = yysep1154, yyq1154, yy2arr1154 + const yyr1154 bool = false + yyq1154[1] = x.SELinuxOptions != nil + var yynn1154 int + if yyr1154 || yy2arr1154 { r.EncodeArrayStart(2) } else { - yynn1103 = 1 - for _, b := range yyq1103 { + yynn1154 = 1 + for _, b := range yyq1154 { if b { - yynn1103++ + yynn1154++ } } - r.EncodeMapStart(yynn1103) - yynn1103 = 0 + r.EncodeMapStart(yynn1154) + yynn1154 = 0 } - if yyr1103 || yy2arr1103 { + if yyr1154 || yy2arr1154 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Rule.CodecEncodeSelf(e) } else { @@ -13049,9 +13594,9 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } - if yyr1103 || yy2arr1103 { + if yyr1154 || yy2arr1154 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1103[1] { + if yyq1154[1] { if x.SELinuxOptions == nil { r.EncodeNil() } else { @@ -13061,7 +13606,7 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1103[1] { + if yyq1154[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinuxOptions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -13072,7 +13617,7 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1103 || yy2arr1103 { + if yyr1154 || yy2arr1154 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -13085,25 +13630,25 @@ func (x *SELinuxStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1106 := z.DecBinary() - _ = yym1106 + yym1157 := z.DecBinary() + _ = yym1157 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1107 := r.ContainerType() - if yyct1107 == codecSelferValueTypeMap1234 { - yyl1107 := r.ReadMapStart() - if yyl1107 == 0 { + yyct1158 := r.ContainerType() + if yyct1158 == codecSelferValueTypeMap1234 { + yyl1158 := r.ReadMapStart() + if yyl1158 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1107, d) + x.codecDecodeSelfFromMap(yyl1158, d) } - } else if yyct1107 == codecSelferValueTypeArray1234 { - yyl1107 := r.ReadArrayStart() - if yyl1107 == 0 { + } else if yyct1158 == codecSelferValueTypeArray1234 { + yyl1158 := r.ReadArrayStart() + if yyl1158 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1107, d) + x.codecDecodeSelfFromArray(yyl1158, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -13115,12 +13660,12 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1108Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1108Slc - var yyhl1108 bool = l >= 0 - for yyj1108 := 0; ; yyj1108++ { - if yyhl1108 { - if yyj1108 >= l { + var yys1159Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1159Slc + var yyhl1159 bool = l >= 0 + for yyj1159 := 0; ; yyj1159++ { + if yyhl1159 { + if yyj1159 >= l { break } } else { @@ -13129,10 +13674,10 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1108Slc = r.DecodeBytes(yys1108Slc, true, true) - yys1108 := string(yys1108Slc) + yys1159Slc = r.DecodeBytes(yys1159Slc, true, true) + yys1159 := string(yys1159Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1108 { + switch yys1159 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -13151,714 +13696,13 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco x.SELinuxOptions.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1108) - } // end switch yys1108 - } // end for yyj1108 + z.DecStructFieldNotFound(-1, yys1159) + } // end switch yys1159 + } // end for yyj1159 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } func (x *SELinuxStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1111 int - var yyb1111 bool - var yyhl1111 bool = l >= 0 - yyj1111++ - if yyhl1111 { - yyb1111 = yyj1111 > l - } else { - yyb1111 = r.CheckBreak() - } - if yyb1111 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Rule = "" - } else { - x.Rule = SELinuxStrategy(r.DecodeString()) - } - yyj1111++ - if yyhl1111 { - yyb1111 = yyj1111 > l - } else { - yyb1111 = r.CheckBreak() - } - if yyb1111 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.SELinuxOptions != nil { - x.SELinuxOptions = nil - } - } else { - if x.SELinuxOptions == nil { - x.SELinuxOptions = new(pkg2_api.SELinuxOptions) - } - x.SELinuxOptions.CodecDecodeSelf(d) - } - for { - yyj1111++ - if yyhl1111 { - yyb1111 = yyj1111 > l - } else { - yyb1111 = r.CheckBreak() - } - if yyb1111 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1111-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x SELinuxStrategy) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym1114 := z.EncBinary() - _ = yym1114 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *SELinuxStrategy) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1115 := z.DecBinary() - _ = yym1115 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - -func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1116 := z.EncBinary() - _ = yym1116 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1117 := !z.EncBinary() - yy2arr1117 := z.EncBasicHandle().StructToArray - var yyq1117 [2]bool - _, _, _ = yysep1117, yyq1117, yy2arr1117 - const yyr1117 bool = false - yyq1117[1] = len(x.Ranges) != 0 - var yynn1117 int - if yyr1117 || yy2arr1117 { - r.EncodeArrayStart(2) - } else { - yynn1117 = 1 - for _, b := range yyq1117 { - if b { - yynn1117++ - } - } - r.EncodeMapStart(yynn1117) - yynn1117 = 0 - } - if yyr1117 || yy2arr1117 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - x.Rule.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rule")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Rule.CodecEncodeSelf(e) - } - if yyr1117 || yy2arr1117 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1117[1] { - if x.Ranges == nil { - r.EncodeNil() - } else { - yym1120 := z.EncBinary() - _ = yym1120 - if false { - } else { - h.encSliceIDRange(([]IDRange)(x.Ranges), e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq1117[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("ranges")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Ranges == nil { - r.EncodeNil() - } else { - yym1121 := z.EncBinary() - _ = yym1121 - if false { - } else { - h.encSliceIDRange(([]IDRange)(x.Ranges), e) - } - } - } - } - if yyr1117 || yy2arr1117 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *RunAsUserStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1122 := z.DecBinary() - _ = yym1122 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1123 := r.ContainerType() - if yyct1123 == codecSelferValueTypeMap1234 { - yyl1123 := r.ReadMapStart() - if yyl1123 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1123, d) - } - } else if yyct1123 == codecSelferValueTypeArray1234 { - yyl1123 := r.ReadArrayStart() - if yyl1123 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1123, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *RunAsUserStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1124Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1124Slc - var yyhl1124 bool = l >= 0 - for yyj1124 := 0; ; yyj1124++ { - if yyhl1124 { - if yyj1124 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1124Slc = r.DecodeBytes(yys1124Slc, true, true) - yys1124 := string(yys1124Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1124 { - case "rule": - if r.TryDecodeAsNil() { - x.Rule = "" - } else { - x.Rule = RunAsUserStrategy(r.DecodeString()) - } - case "ranges": - if r.TryDecodeAsNil() { - x.Ranges = nil - } else { - yyv1126 := &x.Ranges - yym1127 := z.DecBinary() - _ = yym1127 - if false { - } else { - h.decSliceIDRange((*[]IDRange)(yyv1126), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys1124) - } // end switch yys1124 - } // end for yyj1124 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *RunAsUserStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1128 int - var yyb1128 bool - var yyhl1128 bool = l >= 0 - yyj1128++ - if yyhl1128 { - yyb1128 = yyj1128 > l - } else { - yyb1128 = r.CheckBreak() - } - if yyb1128 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Rule = "" - } else { - x.Rule = RunAsUserStrategy(r.DecodeString()) - } - yyj1128++ - if yyhl1128 { - yyb1128 = yyj1128 > l - } else { - yyb1128 = r.CheckBreak() - } - if yyb1128 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Ranges = nil - } else { - yyv1130 := &x.Ranges - yym1131 := z.DecBinary() - _ = yym1131 - if false { - } else { - h.decSliceIDRange((*[]IDRange)(yyv1130), d) - } - } - for { - yyj1128++ - if yyhl1128 { - yyb1128 = yyj1128 > l - } else { - yyb1128 = r.CheckBreak() - } - if yyb1128 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1128-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IDRange) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1132 := z.EncBinary() - _ = yym1132 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1133 := !z.EncBinary() - yy2arr1133 := z.EncBasicHandle().StructToArray - var yyq1133 [2]bool - _, _, _ = yysep1133, yyq1133, yy2arr1133 - const yyr1133 bool = false - var yynn1133 int - if yyr1133 || yy2arr1133 { - r.EncodeArrayStart(2) - } else { - yynn1133 = 2 - for _, b := range yyq1133 { - if b { - yynn1133++ - } - } - r.EncodeMapStart(yynn1133) - yynn1133 = 0 - } - if yyr1133 || yy2arr1133 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1135 := z.EncBinary() - _ = yym1135 - if false { - } else { - r.EncodeInt(int64(x.Min)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("min")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1136 := z.EncBinary() - _ = yym1136 - if false { - } else { - r.EncodeInt(int64(x.Min)) - } - } - if yyr1133 || yy2arr1133 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1138 := z.EncBinary() - _ = yym1138 - if false { - } else { - r.EncodeInt(int64(x.Max)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("max")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1139 := z.EncBinary() - _ = yym1139 - if false { - } else { - r.EncodeInt(int64(x.Max)) - } - } - if yyr1133 || yy2arr1133 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IDRange) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1140 := z.DecBinary() - _ = yym1140 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1141 := r.ContainerType() - if yyct1141 == codecSelferValueTypeMap1234 { - yyl1141 := r.ReadMapStart() - if yyl1141 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1141, d) - } - } else if yyct1141 == codecSelferValueTypeArray1234 { - yyl1141 := r.ReadArrayStart() - if yyl1141 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1141, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IDRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1142Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1142Slc - var yyhl1142 bool = l >= 0 - for yyj1142 := 0; ; yyj1142++ { - if yyhl1142 { - if yyj1142 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1142Slc = r.DecodeBytes(yys1142Slc, true, true) - yys1142 := string(yys1142Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1142 { - case "min": - if r.TryDecodeAsNil() { - x.Min = 0 - } else { - x.Min = int64(r.DecodeInt(64)) - } - case "max": - if r.TryDecodeAsNil() { - x.Max = 0 - } else { - x.Max = int64(r.DecodeInt(64)) - } - default: - z.DecStructFieldNotFound(-1, yys1142) - } // end switch yys1142 - } // end for yyj1142 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IDRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1145 int - var yyb1145 bool - var yyhl1145 bool = l >= 0 - yyj1145++ - if yyhl1145 { - yyb1145 = yyj1145 > l - } else { - yyb1145 = r.CheckBreak() - } - if yyb1145 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Min = 0 - } else { - x.Min = int64(r.DecodeInt(64)) - } - yyj1145++ - if yyhl1145 { - yyb1145 = yyj1145 > l - } else { - yyb1145 = r.CheckBreak() - } - if yyb1145 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Max = 0 - } else { - x.Max = int64(r.DecodeInt(64)) - } - for { - yyj1145++ - if yyhl1145 { - yyb1145 = yyj1145 > l - } else { - yyb1145 = r.CheckBreak() - } - if yyb1145 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1145-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x RunAsUserStrategy) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym1148 := z.EncBinary() - _ = yym1148 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *RunAsUserStrategy) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1149 := z.DecBinary() - _ = yym1149 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - -func (x *FSGroupStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1150 := z.EncBinary() - _ = yym1150 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1151 := !z.EncBinary() - yy2arr1151 := z.EncBasicHandle().StructToArray - var yyq1151 [2]bool - _, _, _ = yysep1151, yyq1151, yy2arr1151 - const yyr1151 bool = false - yyq1151[0] = x.Rule != "" - yyq1151[1] = len(x.Ranges) != 0 - var yynn1151 int - if yyr1151 || yy2arr1151 { - r.EncodeArrayStart(2) - } else { - yynn1151 = 0 - for _, b := range yyq1151 { - if b { - yynn1151++ - } - } - r.EncodeMapStart(yynn1151) - yynn1151 = 0 - } - if yyr1151 || yy2arr1151 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1151[0] { - x.Rule.CodecEncodeSelf(e) - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq1151[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rule")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Rule.CodecEncodeSelf(e) - } - } - if yyr1151 || yy2arr1151 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1151[1] { - if x.Ranges == nil { - r.EncodeNil() - } else { - yym1154 := z.EncBinary() - _ = yym1154 - if false { - } else { - h.encSliceIDRange(([]IDRange)(x.Ranges), e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq1151[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("ranges")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Ranges == nil { - r.EncodeNil() - } else { - yym1155 := z.EncBinary() - _ = yym1155 - if false { - } else { - h.encSliceIDRange(([]IDRange)(x.Ranges), e) - } - } - } - } - if yyr1151 || yy2arr1151 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *FSGroupStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1156 := z.DecBinary() - _ = yym1156 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1157 := r.ContainerType() - if yyct1157 == codecSelferValueTypeMap1234 { - yyl1157 := r.ReadMapStart() - if yyl1157 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1157, d) - } - } else if yyct1157 == codecSelferValueTypeArray1234 { - yyl1157 := r.ReadArrayStart() - if yyl1157 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1157, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *FSGroupStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1158Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1158Slc - var yyhl1158 bool = l >= 0 - for yyj1158 := 0; ; yyj1158++ { - if yyhl1158 { - if yyj1158 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1158Slc = r.DecodeBytes(yys1158Slc, true, true) - yys1158 := string(yys1158Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1158 { - case "rule": - if r.TryDecodeAsNil() { - x.Rule = "" - } else { - x.Rule = FSGroupStrategyType(r.DecodeString()) - } - case "ranges": - if r.TryDecodeAsNil() { - x.Ranges = nil - } else { - yyv1160 := &x.Ranges - yym1161 := z.DecBinary() - _ = yym1161 - if false { - } else { - h.decSliceIDRange((*[]IDRange)(yyv1160), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys1158) - } // end switch yys1158 - } // end for yyj1158 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -13879,7 +13723,7 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De if r.TryDecodeAsNil() { x.Rule = "" } else { - x.Rule = FSGroupStrategyType(r.DecodeString()) + x.Rule = SELinuxStrategy(r.DecodeString()) } yyj1162++ if yyhl1162 { @@ -13893,15 +13737,14 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Ranges = nil - } else { - yyv1164 := &x.Ranges - yym1165 := z.DecBinary() - _ = yym1165 - if false { - } else { - h.decSliceIDRange((*[]IDRange)(yyv1164), d) + if x.SELinuxOptions != nil { + x.SELinuxOptions = nil } + } else { + if x.SELinuxOptions == nil { + x.SELinuxOptions = new(pkg2_api.SELinuxOptions) + } + x.SELinuxOptions.CodecDecodeSelf(d) } for { yyj1162++ @@ -13919,12 +13762,714 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } +func (x SELinuxStrategy) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + yym1165 := z.EncBinary() + _ = yym1165 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x)) + } +} + +func (x *SELinuxStrategy) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1166 := z.DecBinary() + _ = yym1166 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + *((*string)(x)) = r.DecodeString() + } +} + +func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1167 := z.EncBinary() + _ = yym1167 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1168 := !z.EncBinary() + yy2arr1168 := z.EncBasicHandle().StructToArray + var yyq1168 [2]bool + _, _, _ = yysep1168, yyq1168, yy2arr1168 + const yyr1168 bool = false + yyq1168[1] = len(x.Ranges) != 0 + var yynn1168 int + if yyr1168 || yy2arr1168 { + r.EncodeArrayStart(2) + } else { + yynn1168 = 1 + for _, b := range yyq1168 { + if b { + yynn1168++ + } + } + r.EncodeMapStart(yynn1168) + yynn1168 = 0 + } + if yyr1168 || yy2arr1168 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + x.Rule.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("rule")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + x.Rule.CodecEncodeSelf(e) + } + if yyr1168 || yy2arr1168 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1168[1] { + if x.Ranges == nil { + r.EncodeNil() + } else { + yym1171 := z.EncBinary() + _ = yym1171 + if false { + } else { + h.encSliceIDRange(([]IDRange)(x.Ranges), e) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq1168[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("ranges")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Ranges == nil { + r.EncodeNil() + } else { + yym1172 := z.EncBinary() + _ = yym1172 + if false { + } else { + h.encSliceIDRange(([]IDRange)(x.Ranges), e) + } + } + } + } + if yyr1168 || yy2arr1168 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *RunAsUserStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1173 := z.DecBinary() + _ = yym1173 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1174 := r.ContainerType() + if yyct1174 == codecSelferValueTypeMap1234 { + yyl1174 := r.ReadMapStart() + if yyl1174 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1174, d) + } + } else if yyct1174 == codecSelferValueTypeArray1234 { + yyl1174 := r.ReadArrayStart() + if yyl1174 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1174, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *RunAsUserStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1175Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1175Slc + var yyhl1175 bool = l >= 0 + for yyj1175 := 0; ; yyj1175++ { + if yyhl1175 { + if yyj1175 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1175Slc = r.DecodeBytes(yys1175Slc, true, true) + yys1175 := string(yys1175Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1175 { + case "rule": + if r.TryDecodeAsNil() { + x.Rule = "" + } else { + x.Rule = RunAsUserStrategy(r.DecodeString()) + } + case "ranges": + if r.TryDecodeAsNil() { + x.Ranges = nil + } else { + yyv1177 := &x.Ranges + yym1178 := z.DecBinary() + _ = yym1178 + if false { + } else { + h.decSliceIDRange((*[]IDRange)(yyv1177), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys1175) + } // end switch yys1175 + } // end for yyj1175 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *RunAsUserStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1179 int + var yyb1179 bool + var yyhl1179 bool = l >= 0 + yyj1179++ + if yyhl1179 { + yyb1179 = yyj1179 > l + } else { + yyb1179 = r.CheckBreak() + } + if yyb1179 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Rule = "" + } else { + x.Rule = RunAsUserStrategy(r.DecodeString()) + } + yyj1179++ + if yyhl1179 { + yyb1179 = yyj1179 > l + } else { + yyb1179 = r.CheckBreak() + } + if yyb1179 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Ranges = nil + } else { + yyv1181 := &x.Ranges + yym1182 := z.DecBinary() + _ = yym1182 + if false { + } else { + h.decSliceIDRange((*[]IDRange)(yyv1181), d) + } + } + for { + yyj1179++ + if yyhl1179 { + yyb1179 = yyj1179 > l + } else { + yyb1179 = r.CheckBreak() + } + if yyb1179 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1179-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IDRange) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1183 := z.EncBinary() + _ = yym1183 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1184 := !z.EncBinary() + yy2arr1184 := z.EncBasicHandle().StructToArray + var yyq1184 [2]bool + _, _, _ = yysep1184, yyq1184, yy2arr1184 + const yyr1184 bool = false + var yynn1184 int + if yyr1184 || yy2arr1184 { + r.EncodeArrayStart(2) + } else { + yynn1184 = 2 + for _, b := range yyq1184 { + if b { + yynn1184++ + } + } + r.EncodeMapStart(yynn1184) + yynn1184 = 0 + } + if yyr1184 || yy2arr1184 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym1186 := z.EncBinary() + _ = yym1186 + if false { + } else { + r.EncodeInt(int64(x.Min)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("min")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1187 := z.EncBinary() + _ = yym1187 + if false { + } else { + r.EncodeInt(int64(x.Min)) + } + } + if yyr1184 || yy2arr1184 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym1189 := z.EncBinary() + _ = yym1189 + if false { + } else { + r.EncodeInt(int64(x.Max)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("max")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1190 := z.EncBinary() + _ = yym1190 + if false { + } else { + r.EncodeInt(int64(x.Max)) + } + } + if yyr1184 || yy2arr1184 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IDRange) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1191 := z.DecBinary() + _ = yym1191 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1192 := r.ContainerType() + if yyct1192 == codecSelferValueTypeMap1234 { + yyl1192 := r.ReadMapStart() + if yyl1192 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1192, d) + } + } else if yyct1192 == codecSelferValueTypeArray1234 { + yyl1192 := r.ReadArrayStart() + if yyl1192 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1192, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IDRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1193Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1193Slc + var yyhl1193 bool = l >= 0 + for yyj1193 := 0; ; yyj1193++ { + if yyhl1193 { + if yyj1193 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1193Slc = r.DecodeBytes(yys1193Slc, true, true) + yys1193 := string(yys1193Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1193 { + case "min": + if r.TryDecodeAsNil() { + x.Min = 0 + } else { + x.Min = int64(r.DecodeInt(64)) + } + case "max": + if r.TryDecodeAsNil() { + x.Max = 0 + } else { + x.Max = int64(r.DecodeInt(64)) + } + default: + z.DecStructFieldNotFound(-1, yys1193) + } // end switch yys1193 + } // end for yyj1193 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IDRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1196 int + var yyb1196 bool + var yyhl1196 bool = l >= 0 + yyj1196++ + if yyhl1196 { + yyb1196 = yyj1196 > l + } else { + yyb1196 = r.CheckBreak() + } + if yyb1196 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Min = 0 + } else { + x.Min = int64(r.DecodeInt(64)) + } + yyj1196++ + if yyhl1196 { + yyb1196 = yyj1196 > l + } else { + yyb1196 = r.CheckBreak() + } + if yyb1196 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Max = 0 + } else { + x.Max = int64(r.DecodeInt(64)) + } + for { + yyj1196++ + if yyhl1196 { + yyb1196 = yyj1196 > l + } else { + yyb1196 = r.CheckBreak() + } + if yyb1196 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1196-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x RunAsUserStrategy) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + yym1199 := z.EncBinary() + _ = yym1199 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x)) + } +} + +func (x *RunAsUserStrategy) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1200 := z.DecBinary() + _ = yym1200 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + *((*string)(x)) = r.DecodeString() + } +} + +func (x *FSGroupStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1201 := z.EncBinary() + _ = yym1201 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1202 := !z.EncBinary() + yy2arr1202 := z.EncBasicHandle().StructToArray + var yyq1202 [2]bool + _, _, _ = yysep1202, yyq1202, yy2arr1202 + const yyr1202 bool = false + yyq1202[0] = x.Rule != "" + yyq1202[1] = len(x.Ranges) != 0 + var yynn1202 int + if yyr1202 || yy2arr1202 { + r.EncodeArrayStart(2) + } else { + yynn1202 = 0 + for _, b := range yyq1202 { + if b { + yynn1202++ + } + } + r.EncodeMapStart(yynn1202) + yynn1202 = 0 + } + if yyr1202 || yy2arr1202 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1202[0] { + x.Rule.CodecEncodeSelf(e) + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq1202[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("rule")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + x.Rule.CodecEncodeSelf(e) + } + } + if yyr1202 || yy2arr1202 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1202[1] { + if x.Ranges == nil { + r.EncodeNil() + } else { + yym1205 := z.EncBinary() + _ = yym1205 + if false { + } else { + h.encSliceIDRange(([]IDRange)(x.Ranges), e) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq1202[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("ranges")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Ranges == nil { + r.EncodeNil() + } else { + yym1206 := z.EncBinary() + _ = yym1206 + if false { + } else { + h.encSliceIDRange(([]IDRange)(x.Ranges), e) + } + } + } + } + if yyr1202 || yy2arr1202 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *FSGroupStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1207 := z.DecBinary() + _ = yym1207 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1208 := r.ContainerType() + if yyct1208 == codecSelferValueTypeMap1234 { + yyl1208 := r.ReadMapStart() + if yyl1208 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1208, d) + } + } else if yyct1208 == codecSelferValueTypeArray1234 { + yyl1208 := r.ReadArrayStart() + if yyl1208 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1208, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *FSGroupStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1209Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1209Slc + var yyhl1209 bool = l >= 0 + for yyj1209 := 0; ; yyj1209++ { + if yyhl1209 { + if yyj1209 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1209Slc = r.DecodeBytes(yys1209Slc, true, true) + yys1209 := string(yys1209Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1209 { + case "rule": + if r.TryDecodeAsNil() { + x.Rule = "" + } else { + x.Rule = FSGroupStrategyType(r.DecodeString()) + } + case "ranges": + if r.TryDecodeAsNil() { + x.Ranges = nil + } else { + yyv1211 := &x.Ranges + yym1212 := z.DecBinary() + _ = yym1212 + if false { + } else { + h.decSliceIDRange((*[]IDRange)(yyv1211), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys1209) + } // end switch yys1209 + } // end for yyj1209 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1213 int + var yyb1213 bool + var yyhl1213 bool = l >= 0 + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Rule = "" + } else { + x.Rule = FSGroupStrategyType(r.DecodeString()) + } + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Ranges = nil + } else { + yyv1215 := &x.Ranges + yym1216 := z.DecBinary() + _ = yym1216 + if false { + } else { + h.decSliceIDRange((*[]IDRange)(yyv1215), d) + } + } + for { + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1213-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + func (x FSGroupStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1166 := z.EncBinary() - _ = yym1166 + yym1217 := z.EncBinary() + _ = yym1217 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -13936,8 +14481,8 @@ func (x *FSGroupStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1167 := z.DecBinary() - _ = yym1167 + yym1218 := z.DecBinary() + _ = yym1218 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -13952,54 +14497,54 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder if x == nil { r.EncodeNil() } else { - yym1168 := z.EncBinary() - _ = yym1168 + yym1219 := z.EncBinary() + _ = yym1219 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1169 := !z.EncBinary() - yy2arr1169 := z.EncBasicHandle().StructToArray - var yyq1169 [2]bool - _, _, _ = yysep1169, yyq1169, yy2arr1169 - const yyr1169 bool = false - yyq1169[0] = x.Rule != "" - yyq1169[1] = len(x.Ranges) != 0 - var yynn1169 int - if yyr1169 || yy2arr1169 { + yysep1220 := !z.EncBinary() + yy2arr1220 := z.EncBasicHandle().StructToArray + var yyq1220 [2]bool + _, _, _ = yysep1220, yyq1220, yy2arr1220 + const yyr1220 bool = false + yyq1220[0] = x.Rule != "" + yyq1220[1] = len(x.Ranges) != 0 + var yynn1220 int + if yyr1220 || yy2arr1220 { r.EncodeArrayStart(2) } else { - yynn1169 = 0 - for _, b := range yyq1169 { + yynn1220 = 0 + for _, b := range yyq1220 { if b { - yynn1169++ + yynn1220++ } } - r.EncodeMapStart(yynn1169) - yynn1169 = 0 + r.EncodeMapStart(yynn1220) + yynn1220 = 0 } - if yyr1169 || yy2arr1169 { + if yyr1220 || yy2arr1220 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1169[0] { + if yyq1220[0] { x.Rule.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1169[0] { + if yyq1220[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rule")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } } - if yyr1169 || yy2arr1169 { + if yyr1220 || yy2arr1220 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1169[1] { + if yyq1220[1] { if x.Ranges == nil { r.EncodeNil() } else { - yym1172 := z.EncBinary() - _ = yym1172 + yym1223 := z.EncBinary() + _ = yym1223 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -14009,15 +14554,15 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder r.EncodeNil() } } else { - if yyq1169[1] { + if yyq1220[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ranges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ranges == nil { r.EncodeNil() } else { - yym1173 := z.EncBinary() - _ = yym1173 + yym1224 := z.EncBinary() + _ = yym1224 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -14025,7 +14570,7 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder } } } - if yyr1169 || yy2arr1169 { + if yyr1220 || yy2arr1220 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -14038,25 +14583,25 @@ func (x *SupplementalGroupsStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1174 := z.DecBinary() - _ = yym1174 + yym1225 := z.DecBinary() + _ = yym1225 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1175 := r.ContainerType() - if yyct1175 == codecSelferValueTypeMap1234 { - yyl1175 := r.ReadMapStart() - if yyl1175 == 0 { + yyct1226 := r.ContainerType() + if yyct1226 == codecSelferValueTypeMap1234 { + yyl1226 := r.ReadMapStart() + if yyl1226 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1175, d) + x.codecDecodeSelfFromMap(yyl1226, d) } - } else if yyct1175 == codecSelferValueTypeArray1234 { - yyl1175 := r.ReadArrayStart() - if yyl1175 == 0 { + } else if yyct1226 == codecSelferValueTypeArray1234 { + yyl1226 := r.ReadArrayStart() + if yyl1226 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1175, d) + x.codecDecodeSelfFromArray(yyl1226, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -14068,12 +14613,12 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1176Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1176Slc - var yyhl1176 bool = l >= 0 - for yyj1176 := 0; ; yyj1176++ { - if yyhl1176 { - if yyj1176 >= l { + var yys1227Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1227Slc + var yyhl1227 bool = l >= 0 + for yyj1227 := 0; ; yyj1227++ { + if yyhl1227 { + if yyj1227 >= l { break } } else { @@ -14082,10 +14627,10 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1176Slc = r.DecodeBytes(yys1176Slc, true, true) - yys1176 := string(yys1176Slc) + yys1227Slc = r.DecodeBytes(yys1227Slc, true, true) + yys1227 := string(yys1227Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1176 { + switch yys1227 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -14096,18 +14641,18 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1178 := &x.Ranges - yym1179 := z.DecBinary() - _ = yym1179 + yyv1229 := &x.Ranges + yym1230 := z.DecBinary() + _ = yym1230 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1178), d) + h.decSliceIDRange((*[]IDRange)(yyv1229), d) } } default: - z.DecStructFieldNotFound(-1, yys1176) - } // end switch yys1176 - } // end for yyj1176 + z.DecStructFieldNotFound(-1, yys1227) + } // end switch yys1227 + } // end for yyj1227 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -14115,16 +14660,16 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1180 int - var yyb1180 bool - var yyhl1180 bool = l >= 0 - yyj1180++ - if yyhl1180 { - yyb1180 = yyj1180 > l + var yyj1231 int + var yyb1231 bool + var yyhl1231 bool = l >= 0 + yyj1231++ + if yyhl1231 { + yyb1231 = yyj1231 > l } else { - yyb1180 = r.CheckBreak() + yyb1231 = r.CheckBreak() } - if yyb1180 { + if yyb1231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14134,13 +14679,13 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c } else { x.Rule = SupplementalGroupsStrategyType(r.DecodeString()) } - yyj1180++ - if yyhl1180 { - yyb1180 = yyj1180 > l + yyj1231++ + if yyhl1231 { + yyb1231 = yyj1231 > l } else { - yyb1180 = r.CheckBreak() + yyb1231 = r.CheckBreak() } - if yyb1180 { + if yyb1231 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14148,26 +14693,26 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1182 := &x.Ranges - yym1183 := z.DecBinary() - _ = yym1183 + yyv1233 := &x.Ranges + yym1234 := z.DecBinary() + _ = yym1234 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1182), d) + h.decSliceIDRange((*[]IDRange)(yyv1233), d) } } for { - yyj1180++ - if yyhl1180 { - yyb1180 = yyj1180 > l + yyj1231++ + if yyhl1231 { + yyb1231 = yyj1231 > l } else { - yyb1180 = r.CheckBreak() + yyb1231 = r.CheckBreak() } - if yyb1180 { + if yyb1231 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1180-1, "") + z.DecStructFieldNotFound(yyj1231-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -14176,8 +14721,8 @@ func (x SupplementalGroupsStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1184 := z.EncBinary() - _ = yym1184 + yym1235 := z.EncBinary() + _ = yym1235 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -14189,8 +14734,8 @@ func (x *SupplementalGroupsStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1185 := z.DecBinary() - _ = yym1185 + yym1236 := z.DecBinary() + _ = yym1236 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -14205,37 +14750,37 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1186 := z.EncBinary() - _ = yym1186 + yym1237 := z.EncBinary() + _ = yym1237 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1187 := !z.EncBinary() - yy2arr1187 := z.EncBasicHandle().StructToArray - var yyq1187 [4]bool - _, _, _ = yysep1187, yyq1187, yy2arr1187 - const yyr1187 bool = false - yyq1187[0] = x.Kind != "" - yyq1187[1] = x.APIVersion != "" - yyq1187[2] = true - var yynn1187 int - if yyr1187 || yy2arr1187 { + yysep1238 := !z.EncBinary() + yy2arr1238 := z.EncBasicHandle().StructToArray + var yyq1238 [4]bool + _, _, _ = yysep1238, yyq1238, yy2arr1238 + const yyr1238 bool = false + yyq1238[0] = x.Kind != "" + yyq1238[1] = x.APIVersion != "" + yyq1238[2] = true + var yynn1238 int + if yyr1238 || yy2arr1238 { r.EncodeArrayStart(4) } else { - yynn1187 = 1 - for _, b := range yyq1187 { + yynn1238 = 1 + for _, b := range yyq1238 { if b { - yynn1187++ + yynn1238++ } } - r.EncodeMapStart(yynn1187) - yynn1187 = 0 + r.EncodeMapStart(yynn1238) + yynn1238 = 0 } - if yyr1187 || yy2arr1187 { + if yyr1238 || yy2arr1238 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1187[0] { - yym1189 := z.EncBinary() - _ = yym1189 + if yyq1238[0] { + yym1240 := z.EncBinary() + _ = yym1240 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -14244,23 +14789,23 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1187[0] { + if yyq1238[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1190 := z.EncBinary() - _ = yym1190 + yym1241 := z.EncBinary() + _ = yym1241 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1187 || yy2arr1187 { + if yyr1238 || yy2arr1238 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1187[1] { - yym1192 := z.EncBinary() - _ = yym1192 + if yyq1238[1] { + yym1243 := z.EncBinary() + _ = yym1243 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -14269,54 +14814,54 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1187[1] { + if yyq1238[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1193 := z.EncBinary() - _ = yym1193 + yym1244 := z.EncBinary() + _ = yym1244 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1187 || yy2arr1187 { + if yyr1238 || yy2arr1238 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1187[2] { - yy1195 := &x.ListMeta - yym1196 := z.EncBinary() - _ = yym1196 + if yyq1238[2] { + yy1246 := &x.ListMeta + yym1247 := z.EncBinary() + _ = yym1247 if false { - } else if z.HasExtensions() && z.EncExt(yy1195) { + } else if z.HasExtensions() && z.EncExt(yy1246) { } else { - z.EncFallback(yy1195) + z.EncFallback(yy1246) } } else { r.EncodeNil() } } else { - if yyq1187[2] { + if yyq1238[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1197 := &x.ListMeta - yym1198 := z.EncBinary() - _ = yym1198 + yy1248 := &x.ListMeta + yym1249 := z.EncBinary() + _ = yym1249 if false { - } else if z.HasExtensions() && z.EncExt(yy1197) { + } else if z.HasExtensions() && z.EncExt(yy1248) { } else { - z.EncFallback(yy1197) + z.EncFallback(yy1248) } } } - if yyr1187 || yy2arr1187 { + if yyr1238 || yy2arr1238 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1200 := z.EncBinary() - _ = yym1200 + yym1251 := z.EncBinary() + _ = yym1251 if false { } else { h.encSlicePodSecurityPolicy(([]PodSecurityPolicy)(x.Items), e) @@ -14329,15 +14874,15 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1201 := z.EncBinary() - _ = yym1201 + yym1252 := z.EncBinary() + _ = yym1252 if false { } else { h.encSlicePodSecurityPolicy(([]PodSecurityPolicy)(x.Items), e) } } } - if yyr1187 || yy2arr1187 { + if yyr1238 || yy2arr1238 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -14350,25 +14895,25 @@ func (x *PodSecurityPolicyList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1202 := z.DecBinary() - _ = yym1202 + yym1253 := z.DecBinary() + _ = yym1253 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1203 := r.ContainerType() - if yyct1203 == codecSelferValueTypeMap1234 { - yyl1203 := r.ReadMapStart() - if yyl1203 == 0 { + yyct1254 := r.ContainerType() + if yyct1254 == codecSelferValueTypeMap1234 { + yyl1254 := r.ReadMapStart() + if yyl1254 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1203, d) + x.codecDecodeSelfFromMap(yyl1254, d) } - } else if yyct1203 == codecSelferValueTypeArray1234 { - yyl1203 := r.ReadArrayStart() - if yyl1203 == 0 { + } else if yyct1254 == codecSelferValueTypeArray1234 { + yyl1254 := r.ReadArrayStart() + if yyl1254 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1203, d) + x.codecDecodeSelfFromArray(yyl1254, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -14380,12 +14925,12 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1204Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1204Slc - var yyhl1204 bool = l >= 0 - for yyj1204 := 0; ; yyj1204++ { - if yyhl1204 { - if yyj1204 >= l { + var yys1255Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1255Slc + var yyhl1255 bool = l >= 0 + for yyj1255 := 0; ; yyj1255++ { + if yyhl1255 { + if yyj1255 >= l { break } } else { @@ -14394,10 +14939,10 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1204Slc = r.DecodeBytes(yys1204Slc, true, true) - yys1204 := string(yys1204Slc) + yys1255Slc = r.DecodeBytes(yys1255Slc, true, true) + yys1255 := string(yys1255Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1204 { + switch yys1255 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -14414,31 +14959,31 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1207 := &x.ListMeta - yym1208 := z.DecBinary() - _ = yym1208 + yyv1258 := &x.ListMeta + yym1259 := z.DecBinary() + _ = yym1259 if false { - } else if z.HasExtensions() && z.DecExt(yyv1207) { + } else if z.HasExtensions() && z.DecExt(yyv1258) { } else { - z.DecFallback(yyv1207, false) + z.DecFallback(yyv1258, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1209 := &x.Items - yym1210 := z.DecBinary() - _ = yym1210 + yyv1260 := &x.Items + yym1261 := z.DecBinary() + _ = yym1261 if false { } else { - h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1209), d) + h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1260), d) } } default: - z.DecStructFieldNotFound(-1, yys1204) - } // end switch yys1204 - } // end for yyj1204 + z.DecStructFieldNotFound(-1, yys1255) + } // end switch yys1255 + } // end for yyj1255 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -14446,16 +14991,16 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1211 int - var yyb1211 bool - var yyhl1211 bool = l >= 0 - yyj1211++ - if yyhl1211 { - yyb1211 = yyj1211 > l + var yyj1262 int + var yyb1262 bool + var yyhl1262 bool = l >= 0 + yyj1262++ + if yyhl1262 { + yyb1262 = yyj1262 > l } else { - yyb1211 = r.CheckBreak() + yyb1262 = r.CheckBreak() } - if yyb1211 { + if yyb1262 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14465,13 +15010,13 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Kind = string(r.DecodeString()) } - yyj1211++ - if yyhl1211 { - yyb1211 = yyj1211 > l + yyj1262++ + if yyhl1262 { + yyb1262 = yyj1262 > l } else { - yyb1211 = r.CheckBreak() + yyb1262 = r.CheckBreak() } - if yyb1211 { + if yyb1262 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14481,13 +15026,13 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.APIVersion = string(r.DecodeString()) } - yyj1211++ - if yyhl1211 { - yyb1211 = yyj1211 > l + yyj1262++ + if yyhl1262 { + yyb1262 = yyj1262 > l } else { - yyb1211 = r.CheckBreak() + yyb1262 = r.CheckBreak() } - if yyb1211 { + if yyb1262 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14495,22 +15040,22 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1214 := &x.ListMeta - yym1215 := z.DecBinary() - _ = yym1215 + yyv1265 := &x.ListMeta + yym1266 := z.DecBinary() + _ = yym1266 if false { - } else if z.HasExtensions() && z.DecExt(yyv1214) { + } else if z.HasExtensions() && z.DecExt(yyv1265) { } else { - z.DecFallback(yyv1214, false) + z.DecFallback(yyv1265, false) } } - yyj1211++ - if yyhl1211 { - yyb1211 = yyj1211 > l + yyj1262++ + if yyhl1262 { + yyb1262 = yyj1262 > l } else { - yyb1211 = r.CheckBreak() + yyb1262 = r.CheckBreak() } - if yyb1211 { + if yyb1262 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14518,26 +15063,26 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1216 := &x.Items - yym1217 := z.DecBinary() - _ = yym1217 + yyv1267 := &x.Items + yym1268 := z.DecBinary() + _ = yym1268 if false { } else { - h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1216), d) + h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1267), d) } } for { - yyj1211++ - if yyhl1211 { - yyb1211 = yyj1211 > l + yyj1262++ + if yyhl1262 { + yyb1262 = yyj1262 > l } else { - yyb1211 = r.CheckBreak() + yyb1262 = r.CheckBreak() } - if yyb1211 { + if yyb1262 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1211-1, "") + z.DecStructFieldNotFound(yyj1262-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -14549,38 +15094,38 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1218 := z.EncBinary() - _ = yym1218 + yym1269 := z.EncBinary() + _ = yym1269 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1219 := !z.EncBinary() - yy2arr1219 := z.EncBasicHandle().StructToArray - var yyq1219 [4]bool - _, _, _ = yysep1219, yyq1219, yy2arr1219 - const yyr1219 bool = false - yyq1219[0] = x.Kind != "" - yyq1219[1] = x.APIVersion != "" - yyq1219[2] = true - yyq1219[3] = true - var yynn1219 int - if yyr1219 || yy2arr1219 { + yysep1270 := !z.EncBinary() + yy2arr1270 := z.EncBasicHandle().StructToArray + var yyq1270 [4]bool + _, _, _ = yysep1270, yyq1270, yy2arr1270 + const yyr1270 bool = false + yyq1270[0] = x.Kind != "" + yyq1270[1] = x.APIVersion != "" + yyq1270[2] = true + yyq1270[3] = true + var yynn1270 int + if yyr1270 || yy2arr1270 { r.EncodeArrayStart(4) } else { - yynn1219 = 0 - for _, b := range yyq1219 { + yynn1270 = 0 + for _, b := range yyq1270 { if b { - yynn1219++ + yynn1270++ } } - r.EncodeMapStart(yynn1219) - yynn1219 = 0 + r.EncodeMapStart(yynn1270) + yynn1270 = 0 } - if yyr1219 || yy2arr1219 { + if yyr1270 || yy2arr1270 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1219[0] { - yym1221 := z.EncBinary() - _ = yym1221 + if yyq1270[0] { + yym1272 := z.EncBinary() + _ = yym1272 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -14589,23 +15134,23 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1219[0] { + if yyq1270[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1222 := z.EncBinary() - _ = yym1222 + yym1273 := z.EncBinary() + _ = yym1273 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1219 || yy2arr1219 { + if yyr1270 || yy2arr1270 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1219[1] { - yym1224 := z.EncBinary() - _ = yym1224 + if yyq1270[1] { + yym1275 := z.EncBinary() + _ = yym1275 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -14614,53 +15159,53 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1219[1] { + if yyq1270[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1225 := z.EncBinary() - _ = yym1225 + yym1276 := z.EncBinary() + _ = yym1276 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1219 || yy2arr1219 { + if yyr1270 || yy2arr1270 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1219[2] { - yy1227 := &x.ObjectMeta - yy1227.CodecEncodeSelf(e) + if yyq1270[2] { + yy1278 := &x.ObjectMeta + yy1278.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1219[2] { + if yyq1270[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1228 := &x.ObjectMeta - yy1228.CodecEncodeSelf(e) + yy1279 := &x.ObjectMeta + yy1279.CodecEncodeSelf(e) } } - if yyr1219 || yy2arr1219 { + if yyr1270 || yy2arr1270 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1219[3] { - yy1230 := &x.Spec - yy1230.CodecEncodeSelf(e) + if yyq1270[3] { + yy1281 := &x.Spec + yy1281.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1219[3] { + if yyq1270[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1231 := &x.Spec - yy1231.CodecEncodeSelf(e) + yy1282 := &x.Spec + yy1282.CodecEncodeSelf(e) } } - if yyr1219 || yy2arr1219 { + if yyr1270 || yy2arr1270 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -14673,25 +15218,25 @@ func (x *NetworkPolicy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1232 := z.DecBinary() - _ = yym1232 + yym1283 := z.DecBinary() + _ = yym1283 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1233 := r.ContainerType() - if yyct1233 == codecSelferValueTypeMap1234 { - yyl1233 := r.ReadMapStart() - if yyl1233 == 0 { + yyct1284 := r.ContainerType() + if yyct1284 == codecSelferValueTypeMap1234 { + yyl1284 := r.ReadMapStart() + if yyl1284 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1233, d) + x.codecDecodeSelfFromMap(yyl1284, d) } - } else if yyct1233 == codecSelferValueTypeArray1234 { - yyl1233 := r.ReadArrayStart() - if yyl1233 == 0 { + } else if yyct1284 == codecSelferValueTypeArray1234 { + yyl1284 := r.ReadArrayStart() + if yyl1284 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1233, d) + x.codecDecodeSelfFromArray(yyl1284, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -14703,12 +15248,12 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1234Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1234Slc - var yyhl1234 bool = l >= 0 - for yyj1234 := 0; ; yyj1234++ { - if yyhl1234 { - if yyj1234 >= l { + var yys1285Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1285Slc + var yyhl1285 bool = l >= 0 + for yyj1285 := 0; ; yyj1285++ { + if yyhl1285 { + if yyj1285 >= l { break } } else { @@ -14717,10 +15262,10 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1234Slc = r.DecodeBytes(yys1234Slc, true, true) - yys1234 := string(yys1234Slc) + yys1285Slc = r.DecodeBytes(yys1285Slc, true, true) + yys1285 := string(yys1285Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1234 { + switch yys1285 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -14737,20 +15282,20 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv1237 := &x.ObjectMeta - yyv1237.CodecDecodeSelf(d) + yyv1288 := &x.ObjectMeta + yyv1288.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NetworkPolicySpec{} } else { - yyv1238 := &x.Spec - yyv1238.CodecDecodeSelf(d) + yyv1289 := &x.Spec + yyv1289.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1234) - } // end switch yys1234 - } // end for yyj1234 + z.DecStructFieldNotFound(-1, yys1285) + } // end switch yys1285 + } // end for yyj1285 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -14758,16 +15303,16 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1239 int - var yyb1239 bool - var yyhl1239 bool = l >= 0 - yyj1239++ - if yyhl1239 { - yyb1239 = yyj1239 > l + var yyj1290 int + var yyb1290 bool + var yyhl1290 bool = l >= 0 + yyj1290++ + if yyhl1290 { + yyb1290 = yyj1290 > l } else { - yyb1239 = r.CheckBreak() + yyb1290 = r.CheckBreak() } - if yyb1239 { + if yyb1290 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14777,13 +15322,13 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj1239++ - if yyhl1239 { - yyb1239 = yyj1239 > l + yyj1290++ + if yyhl1290 { + yyb1290 = yyj1290 > l } else { - yyb1239 = r.CheckBreak() + yyb1290 = r.CheckBreak() } - if yyb1239 { + if yyb1290 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14793,13 +15338,13 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj1239++ - if yyhl1239 { - yyb1239 = yyj1239 > l + yyj1290++ + if yyhl1290 { + yyb1290 = yyj1290 > l } else { - yyb1239 = r.CheckBreak() + yyb1290 = r.CheckBreak() } - if yyb1239 { + if yyb1290 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14807,16 +15352,16 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_api.ObjectMeta{} } else { - yyv1242 := &x.ObjectMeta - yyv1242.CodecDecodeSelf(d) + yyv1293 := &x.ObjectMeta + yyv1293.CodecDecodeSelf(d) } - yyj1239++ - if yyhl1239 { - yyb1239 = yyj1239 > l + yyj1290++ + if yyhl1290 { + yyb1290 = yyj1290 > l } else { - yyb1239 = r.CheckBreak() + yyb1290 = r.CheckBreak() } - if yyb1239 { + if yyb1290 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -14824,21 +15369,21 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NetworkPolicySpec{} } else { - yyv1243 := &x.Spec - yyv1243.CodecDecodeSelf(d) + yyv1294 := &x.Spec + yyv1294.CodecDecodeSelf(d) } for { - yyj1239++ - if yyhl1239 { - yyb1239 = yyj1239 > l + yyj1290++ + if yyhl1290 { + yyb1290 = yyj1290 > l } else { - yyb1239 = r.CheckBreak() + yyb1290 = r.CheckBreak() } - if yyb1239 { + if yyb1290 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1239-1, "") + z.DecStructFieldNotFound(yyj1290-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -14850,61 +15395,61 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1244 := z.EncBinary() - _ = yym1244 + yym1295 := z.EncBinary() + _ = yym1295 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1245 := !z.EncBinary() - yy2arr1245 := z.EncBasicHandle().StructToArray - var yyq1245 [2]bool - _, _, _ = yysep1245, yyq1245, yy2arr1245 - const yyr1245 bool = false - yyq1245[1] = len(x.Ingress) != 0 - var yynn1245 int - if yyr1245 || yy2arr1245 { + yysep1296 := !z.EncBinary() + yy2arr1296 := z.EncBasicHandle().StructToArray + var yyq1296 [2]bool + _, _, _ = yysep1296, yyq1296, yy2arr1296 + const yyr1296 bool = false + yyq1296[1] = len(x.Ingress) != 0 + var yynn1296 int + if yyr1296 || yy2arr1296 { r.EncodeArrayStart(2) } else { - yynn1245 = 1 - for _, b := range yyq1245 { + yynn1296 = 1 + for _, b := range yyq1296 { if b { - yynn1245++ + yynn1296++ } } - r.EncodeMapStart(yynn1245) - yynn1245 = 0 + r.EncodeMapStart(yynn1296) + yynn1296 = 0 } - if yyr1245 || yy2arr1245 { + if yyr1296 || yy2arr1296 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1247 := &x.PodSelector - yym1248 := z.EncBinary() - _ = yym1248 + yy1298 := &x.PodSelector + yym1299 := z.EncBinary() + _ = yym1299 if false { - } else if z.HasExtensions() && z.EncExt(yy1247) { + } else if z.HasExtensions() && z.EncExt(yy1298) { } else { - z.EncFallback(yy1247) + z.EncFallback(yy1298) } } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1249 := &x.PodSelector - yym1250 := z.EncBinary() - _ = yym1250 + yy1300 := &x.PodSelector + yym1301 := z.EncBinary() + _ = yym1301 if false { - } else if z.HasExtensions() && z.EncExt(yy1249) { + } else if z.HasExtensions() && z.EncExt(yy1300) { } else { - z.EncFallback(yy1249) + z.EncFallback(yy1300) } } - if yyr1245 || yy2arr1245 { + if yyr1296 || yy2arr1296 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1245[1] { + if yyq1296[1] { if x.Ingress == nil { r.EncodeNil() } else { - yym1252 := z.EncBinary() - _ = yym1252 + yym1303 := z.EncBinary() + _ = yym1303 if false { } else { h.encSliceNetworkPolicyIngressRule(([]NetworkPolicyIngressRule)(x.Ingress), e) @@ -14914,15 +15459,15 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1245[1] { + if yyq1296[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ingress")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ingress == nil { r.EncodeNil() } else { - yym1253 := z.EncBinary() - _ = yym1253 + yym1304 := z.EncBinary() + _ = yym1304 if false { } else { h.encSliceNetworkPolicyIngressRule(([]NetworkPolicyIngressRule)(x.Ingress), e) @@ -14930,7 +15475,7 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1245 || yy2arr1245 { + if yyr1296 || yy2arr1296 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -14943,25 +15488,25 @@ func (x *NetworkPolicySpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1254 := z.DecBinary() - _ = yym1254 + yym1305 := z.DecBinary() + _ = yym1305 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1255 := r.ContainerType() - if yyct1255 == codecSelferValueTypeMap1234 { - yyl1255 := r.ReadMapStart() - if yyl1255 == 0 { + yyct1306 := r.ContainerType() + if yyct1306 == codecSelferValueTypeMap1234 { + yyl1306 := r.ReadMapStart() + if yyl1306 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1255, d) + x.codecDecodeSelfFromMap(yyl1306, d) } - } else if yyct1255 == codecSelferValueTypeArray1234 { - yyl1255 := r.ReadArrayStart() - if yyl1255 == 0 { + } else if yyct1306 == codecSelferValueTypeArray1234 { + yyl1306 := r.ReadArrayStart() + if yyl1306 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1255, d) + x.codecDecodeSelfFromArray(yyl1306, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -14973,12 +15518,12 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1256Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1256Slc - var yyhl1256 bool = l >= 0 - for yyj1256 := 0; ; yyj1256++ { - if yyhl1256 { - if yyj1256 >= l { + var yys1307Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1307Slc + var yyhl1307 bool = l >= 0 + for yyj1307 := 0; ; yyj1307++ { + if yyhl1307 { + if yyj1307 >= l { break } } else { @@ -14987,39 +15532,39 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1256Slc = r.DecodeBytes(yys1256Slc, true, true) - yys1256 := string(yys1256Slc) + yys1307Slc = r.DecodeBytes(yys1307Slc, true, true) + yys1307 := string(yys1307Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1256 { + switch yys1307 { case "podSelector": if r.TryDecodeAsNil() { x.PodSelector = pkg1_unversioned.LabelSelector{} } else { - yyv1257 := &x.PodSelector - yym1258 := z.DecBinary() - _ = yym1258 + yyv1308 := &x.PodSelector + yym1309 := z.DecBinary() + _ = yym1309 if false { - } else if z.HasExtensions() && z.DecExt(yyv1257) { + } else if z.HasExtensions() && z.DecExt(yyv1308) { } else { - z.DecFallback(yyv1257, false) + z.DecFallback(yyv1308, false) } } case "ingress": if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv1259 := &x.Ingress - yym1260 := z.DecBinary() - _ = yym1260 + yyv1310 := &x.Ingress + yym1311 := z.DecBinary() + _ = yym1311 if false { } else { - h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1259), d) + h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1310), d) } } default: - z.DecStructFieldNotFound(-1, yys1256) - } // end switch yys1256 - } // end for yyj1256 + z.DecStructFieldNotFound(-1, yys1307) + } // end switch yys1307 + } // end for yyj1307 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -15027,16 +15572,16 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1261 int - var yyb1261 bool - var yyhl1261 bool = l >= 0 - yyj1261++ - if yyhl1261 { - yyb1261 = yyj1261 > l + var yyj1312 int + var yyb1312 bool + var yyhl1312 bool = l >= 0 + yyj1312++ + if yyhl1312 { + yyb1312 = yyj1312 > l } else { - yyb1261 = r.CheckBreak() + yyb1312 = r.CheckBreak() } - if yyb1261 { + if yyb1312 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15044,22 +15589,22 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.PodSelector = pkg1_unversioned.LabelSelector{} } else { - yyv1262 := &x.PodSelector - yym1263 := z.DecBinary() - _ = yym1263 + yyv1313 := &x.PodSelector + yym1314 := z.DecBinary() + _ = yym1314 if false { - } else if z.HasExtensions() && z.DecExt(yyv1262) { + } else if z.HasExtensions() && z.DecExt(yyv1313) { } else { - z.DecFallback(yyv1262, false) + z.DecFallback(yyv1313, false) } } - yyj1261++ - if yyhl1261 { - yyb1261 = yyj1261 > l + yyj1312++ + if yyhl1312 { + yyb1312 = yyj1312 > l } else { - yyb1261 = r.CheckBreak() + yyb1312 = r.CheckBreak() } - if yyb1261 { + if yyb1312 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15067,26 +15612,26 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv1264 := &x.Ingress - yym1265 := z.DecBinary() - _ = yym1265 + yyv1315 := &x.Ingress + yym1316 := z.DecBinary() + _ = yym1316 if false { } else { - h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1264), d) + h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1315), d) } } for { - yyj1261++ - if yyhl1261 { - yyb1261 = yyj1261 > l + yyj1312++ + if yyhl1312 { + yyb1312 = yyj1312 > l } else { - yyb1261 = r.CheckBreak() + yyb1312 = r.CheckBreak() } - if yyb1261 { + if yyb1312 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1261-1, "") + z.DecStructFieldNotFound(yyj1312-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -15098,39 +15643,39 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1266 := z.EncBinary() - _ = yym1266 + yym1317 := z.EncBinary() + _ = yym1317 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1267 := !z.EncBinary() - yy2arr1267 := z.EncBasicHandle().StructToArray - var yyq1267 [2]bool - _, _, _ = yysep1267, yyq1267, yy2arr1267 - const yyr1267 bool = false - yyq1267[0] = len(x.Ports) != 0 - yyq1267[1] = len(x.From) != 0 - var yynn1267 int - if yyr1267 || yy2arr1267 { + yysep1318 := !z.EncBinary() + yy2arr1318 := z.EncBasicHandle().StructToArray + var yyq1318 [2]bool + _, _, _ = yysep1318, yyq1318, yy2arr1318 + const yyr1318 bool = false + yyq1318[0] = len(x.Ports) != 0 + yyq1318[1] = len(x.From) != 0 + var yynn1318 int + if yyr1318 || yy2arr1318 { r.EncodeArrayStart(2) } else { - yynn1267 = 0 - for _, b := range yyq1267 { + yynn1318 = 0 + for _, b := range yyq1318 { if b { - yynn1267++ + yynn1318++ } } - r.EncodeMapStart(yynn1267) - yynn1267 = 0 + r.EncodeMapStart(yynn1318) + yynn1318 = 0 } - if yyr1267 || yy2arr1267 { + if yyr1318 || yy2arr1318 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1267[0] { + if yyq1318[0] { if x.Ports == nil { r.EncodeNil() } else { - yym1269 := z.EncBinary() - _ = yym1269 + yym1320 := z.EncBinary() + _ = yym1320 if false { } else { h.encSliceNetworkPolicyPort(([]NetworkPolicyPort)(x.Ports), e) @@ -15140,15 +15685,15 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1267[0] { + if yyq1318[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ports")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ports == nil { r.EncodeNil() } else { - yym1270 := z.EncBinary() - _ = yym1270 + yym1321 := z.EncBinary() + _ = yym1321 if false { } else { h.encSliceNetworkPolicyPort(([]NetworkPolicyPort)(x.Ports), e) @@ -15156,14 +15701,14 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1267 || yy2arr1267 { + if yyr1318 || yy2arr1318 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1267[1] { + if yyq1318[1] { if x.From == nil { r.EncodeNil() } else { - yym1272 := z.EncBinary() - _ = yym1272 + yym1323 := z.EncBinary() + _ = yym1323 if false { } else { h.encSliceNetworkPolicyPeer(([]NetworkPolicyPeer)(x.From), e) @@ -15173,15 +15718,15 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1267[1] { + if yyq1318[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("from")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.From == nil { r.EncodeNil() } else { - yym1273 := z.EncBinary() - _ = yym1273 + yym1324 := z.EncBinary() + _ = yym1324 if false { } else { h.encSliceNetworkPolicyPeer(([]NetworkPolicyPeer)(x.From), e) @@ -15189,7 +15734,7 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1267 || yy2arr1267 { + if yyr1318 || yy2arr1318 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -15202,25 +15747,25 @@ func (x *NetworkPolicyIngressRule) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1274 := z.DecBinary() - _ = yym1274 + yym1325 := z.DecBinary() + _ = yym1325 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1275 := r.ContainerType() - if yyct1275 == codecSelferValueTypeMap1234 { - yyl1275 := r.ReadMapStart() - if yyl1275 == 0 { + yyct1326 := r.ContainerType() + if yyct1326 == codecSelferValueTypeMap1234 { + yyl1326 := r.ReadMapStart() + if yyl1326 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1275, d) + x.codecDecodeSelfFromMap(yyl1326, d) } - } else if yyct1275 == codecSelferValueTypeArray1234 { - yyl1275 := r.ReadArrayStart() - if yyl1275 == 0 { + } else if yyct1326 == codecSelferValueTypeArray1234 { + yyl1326 := r.ReadArrayStart() + if yyl1326 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1275, d) + x.codecDecodeSelfFromArray(yyl1326, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -15232,12 +15777,12 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromMap(l int, d *codec1978.De var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1276Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1276Slc - var yyhl1276 bool = l >= 0 - for yyj1276 := 0; ; yyj1276++ { - if yyhl1276 { - if yyj1276 >= l { + var yys1327Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1327Slc + var yyhl1327 bool = l >= 0 + for yyj1327 := 0; ; yyj1327++ { + if yyhl1327 { + if yyj1327 >= l { break } } else { @@ -15246,38 +15791,38 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromMap(l int, d *codec1978.De } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1276Slc = r.DecodeBytes(yys1276Slc, true, true) - yys1276 := string(yys1276Slc) + yys1327Slc = r.DecodeBytes(yys1327Slc, true, true) + yys1327 := string(yys1327Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1276 { + switch yys1327 { case "ports": if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv1277 := &x.Ports - yym1278 := z.DecBinary() - _ = yym1278 + yyv1328 := &x.Ports + yym1329 := z.DecBinary() + _ = yym1329 if false { } else { - h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1277), d) + h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1328), d) } } case "from": if r.TryDecodeAsNil() { x.From = nil } else { - yyv1279 := &x.From - yym1280 := z.DecBinary() - _ = yym1280 + yyv1330 := &x.From + yym1331 := z.DecBinary() + _ = yym1331 if false { } else { - h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1279), d) + h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1330), d) } } default: - z.DecStructFieldNotFound(-1, yys1276) - } // end switch yys1276 - } // end for yyj1276 + z.DecStructFieldNotFound(-1, yys1327) + } // end switch yys1327 + } // end for yyj1327 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -15285,16 +15830,16 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1281 int - var yyb1281 bool - var yyhl1281 bool = l >= 0 - yyj1281++ - if yyhl1281 { - yyb1281 = yyj1281 > l + var yyj1332 int + var yyb1332 bool + var yyhl1332 bool = l >= 0 + yyj1332++ + if yyhl1332 { + yyb1332 = yyj1332 > l } else { - yyb1281 = r.CheckBreak() + yyb1332 = r.CheckBreak() } - if yyb1281 { + if yyb1332 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15302,21 +15847,21 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv1282 := &x.Ports - yym1283 := z.DecBinary() - _ = yym1283 + yyv1333 := &x.Ports + yym1334 := z.DecBinary() + _ = yym1334 if false { } else { - h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1282), d) + h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1333), d) } } - yyj1281++ - if yyhl1281 { - yyb1281 = yyj1281 > l + yyj1332++ + if yyhl1332 { + yyb1332 = yyj1332 > l } else { - yyb1281 = r.CheckBreak() + yyb1332 = r.CheckBreak() } - if yyb1281 { + if yyb1332 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15324,26 +15869,26 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. if r.TryDecodeAsNil() { x.From = nil } else { - yyv1284 := &x.From - yym1285 := z.DecBinary() - _ = yym1285 + yyv1335 := &x.From + yym1336 := z.DecBinary() + _ = yym1336 if false { } else { - h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1284), d) + h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1335), d) } } for { - yyj1281++ - if yyhl1281 { - yyb1281 = yyj1281 > l + yyj1332++ + if yyhl1332 { + yyb1332 = yyj1332 > l } else { - yyb1281 = r.CheckBreak() + yyb1332 = r.CheckBreak() } - if yyb1281 { + if yyb1332 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1281-1, "") + z.DecStructFieldNotFound(yyj1332-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -15355,79 +15900,79 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1286 := z.EncBinary() - _ = yym1286 + yym1337 := z.EncBinary() + _ = yym1337 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1287 := !z.EncBinary() - yy2arr1287 := z.EncBasicHandle().StructToArray - var yyq1287 [2]bool - _, _, _ = yysep1287, yyq1287, yy2arr1287 - const yyr1287 bool = false - yyq1287[0] = x.Protocol != nil - yyq1287[1] = x.Port != nil - var yynn1287 int - if yyr1287 || yy2arr1287 { + yysep1338 := !z.EncBinary() + yy2arr1338 := z.EncBasicHandle().StructToArray + var yyq1338 [2]bool + _, _, _ = yysep1338, yyq1338, yy2arr1338 + const yyr1338 bool = false + yyq1338[0] = x.Protocol != nil + yyq1338[1] = x.Port != nil + var yynn1338 int + if yyr1338 || yy2arr1338 { r.EncodeArrayStart(2) } else { - yynn1287 = 0 - for _, b := range yyq1287 { + yynn1338 = 0 + for _, b := range yyq1338 { if b { - yynn1287++ + yynn1338++ } } - r.EncodeMapStart(yynn1287) - yynn1287 = 0 + r.EncodeMapStart(yynn1338) + yynn1338 = 0 } - if yyr1287 || yy2arr1287 { + if yyr1338 || yy2arr1338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1287[0] { + if yyq1338[0] { if x.Protocol == nil { r.EncodeNil() } else { - yy1289 := *x.Protocol - yym1290 := z.EncBinary() - _ = yym1290 + yy1340 := *x.Protocol + yym1341 := z.EncBinary() + _ = yym1341 if false { - } else if z.HasExtensions() && z.EncExt(yy1289) { + } else if z.HasExtensions() && z.EncExt(yy1340) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy1289)) + r.EncodeString(codecSelferC_UTF81234, string(yy1340)) } } } else { r.EncodeNil() } } else { - if yyq1287[0] { + if yyq1338[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("protocol")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Protocol == nil { r.EncodeNil() } else { - yy1291 := *x.Protocol - yym1292 := z.EncBinary() - _ = yym1292 + yy1342 := *x.Protocol + yym1343 := z.EncBinary() + _ = yym1343 if false { - } else if z.HasExtensions() && z.EncExt(yy1291) { + } else if z.HasExtensions() && z.EncExt(yy1342) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy1291)) + r.EncodeString(codecSelferC_UTF81234, string(yy1342)) } } } } - if yyr1287 || yy2arr1287 { + if yyr1338 || yy2arr1338 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1287[1] { + if yyq1338[1] { if x.Port == nil { r.EncodeNil() } else { - yym1294 := z.EncBinary() - _ = yym1294 + yym1345 := z.EncBinary() + _ = yym1345 if false { } else if z.HasExtensions() && z.EncExt(x.Port) { - } else if !yym1294 && z.IsJSONHandle() { + } else if !yym1345 && z.IsJSONHandle() { z.EncJSONMarshal(x.Port) } else { z.EncFallback(x.Port) @@ -15437,18 +15982,18 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1287[1] { + if yyq1338[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Port == nil { r.EncodeNil() } else { - yym1295 := z.EncBinary() - _ = yym1295 + yym1346 := z.EncBinary() + _ = yym1346 if false { } else if z.HasExtensions() && z.EncExt(x.Port) { - } else if !yym1295 && z.IsJSONHandle() { + } else if !yym1346 && z.IsJSONHandle() { z.EncJSONMarshal(x.Port) } else { z.EncFallback(x.Port) @@ -15456,7 +16001,7 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1287 || yy2arr1287 { + if yyr1338 || yy2arr1338 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -15469,25 +16014,25 @@ func (x *NetworkPolicyPort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1296 := z.DecBinary() - _ = yym1296 + yym1347 := z.DecBinary() + _ = yym1347 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1297 := r.ContainerType() - if yyct1297 == codecSelferValueTypeMap1234 { - yyl1297 := r.ReadMapStart() - if yyl1297 == 0 { + yyct1348 := r.ContainerType() + if yyct1348 == codecSelferValueTypeMap1234 { + yyl1348 := r.ReadMapStart() + if yyl1348 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1297, d) + x.codecDecodeSelfFromMap(yyl1348, d) } - } else if yyct1297 == codecSelferValueTypeArray1234 { - yyl1297 := r.ReadArrayStart() - if yyl1297 == 0 { + } else if yyct1348 == codecSelferValueTypeArray1234 { + yyl1348 := r.ReadArrayStart() + if yyl1348 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1297, d) + x.codecDecodeSelfFromArray(yyl1348, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -15499,12 +16044,12 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1298Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1298Slc - var yyhl1298 bool = l >= 0 - for yyj1298 := 0; ; yyj1298++ { - if yyhl1298 { - if yyj1298 >= l { + var yys1349Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1349Slc + var yyhl1349 bool = l >= 0 + for yyj1349 := 0; ; yyj1349++ { + if yyhl1349 { + if yyj1349 >= l { break } } else { @@ -15513,10 +16058,10 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1298Slc = r.DecodeBytes(yys1298Slc, true, true) - yys1298 := string(yys1298Slc) + yys1349Slc = r.DecodeBytes(yys1349Slc, true, true) + yys1349 := string(yys1349Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1298 { + switch yys1349 { case "protocol": if r.TryDecodeAsNil() { if x.Protocol != nil { @@ -15537,20 +16082,20 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if x.Port == nil { x.Port = new(pkg5_intstr.IntOrString) } - yym1301 := z.DecBinary() - _ = yym1301 + yym1352 := z.DecBinary() + _ = yym1352 if false { } else if z.HasExtensions() && z.DecExt(x.Port) { - } else if !yym1301 && z.IsJSONHandle() { + } else if !yym1352 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.Port) } else { z.DecFallback(x.Port, false) } } default: - z.DecStructFieldNotFound(-1, yys1298) - } // end switch yys1298 - } // end for yyj1298 + z.DecStructFieldNotFound(-1, yys1349) + } // end switch yys1349 + } // end for yyj1349 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -15558,16 +16103,16 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1302 int - var yyb1302 bool - var yyhl1302 bool = l >= 0 - yyj1302++ - if yyhl1302 { - yyb1302 = yyj1302 > l + var yyj1353 int + var yyb1353 bool + var yyhl1353 bool = l >= 0 + yyj1353++ + if yyhl1353 { + yyb1353 = yyj1353 > l } else { - yyb1302 = r.CheckBreak() + yyb1353 = r.CheckBreak() } - if yyb1302 { + if yyb1353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15582,13 +16127,13 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } x.Protocol.CodecDecodeSelf(d) } - yyj1302++ - if yyhl1302 { - yyb1302 = yyj1302 > l + yyj1353++ + if yyhl1353 { + yyb1353 = yyj1353 > l } else { - yyb1302 = r.CheckBreak() + yyb1353 = r.CheckBreak() } - if yyb1302 { + if yyb1353 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15601,28 +16146,28 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if x.Port == nil { x.Port = new(pkg5_intstr.IntOrString) } - yym1305 := z.DecBinary() - _ = yym1305 + yym1356 := z.DecBinary() + _ = yym1356 if false { } else if z.HasExtensions() && z.DecExt(x.Port) { - } else if !yym1305 && z.IsJSONHandle() { + } else if !yym1356 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.Port) } else { z.DecFallback(x.Port, false) } } for { - yyj1302++ - if yyhl1302 { - yyb1302 = yyj1302 > l + yyj1353++ + if yyhl1353 { + yyb1353 = yyj1353 > l } else { - yyb1302 = r.CheckBreak() + yyb1353 = r.CheckBreak() } - if yyb1302 { + if yyb1353 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1302-1, "") + z.DecStructFieldNotFound(yyj1353-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -15634,39 +16179,39 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1306 := z.EncBinary() - _ = yym1306 + yym1357 := z.EncBinary() + _ = yym1357 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1307 := !z.EncBinary() - yy2arr1307 := z.EncBasicHandle().StructToArray - var yyq1307 [2]bool - _, _, _ = yysep1307, yyq1307, yy2arr1307 - const yyr1307 bool = false - yyq1307[0] = x.PodSelector != nil - yyq1307[1] = x.NamespaceSelector != nil - var yynn1307 int - if yyr1307 || yy2arr1307 { + yysep1358 := !z.EncBinary() + yy2arr1358 := z.EncBasicHandle().StructToArray + var yyq1358 [2]bool + _, _, _ = yysep1358, yyq1358, yy2arr1358 + const yyr1358 bool = false + yyq1358[0] = x.PodSelector != nil + yyq1358[1] = x.NamespaceSelector != nil + var yynn1358 int + if yyr1358 || yy2arr1358 { r.EncodeArrayStart(2) } else { - yynn1307 = 0 - for _, b := range yyq1307 { + yynn1358 = 0 + for _, b := range yyq1358 { if b { - yynn1307++ + yynn1358++ } } - r.EncodeMapStart(yynn1307) - yynn1307 = 0 + r.EncodeMapStart(yynn1358) + yynn1358 = 0 } - if yyr1307 || yy2arr1307 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1307[0] { + if yyq1358[0] { if x.PodSelector == nil { r.EncodeNil() } else { - yym1309 := z.EncBinary() - _ = yym1309 + yym1360 := z.EncBinary() + _ = yym1360 if false { } else if z.HasExtensions() && z.EncExt(x.PodSelector) { } else { @@ -15677,15 +16222,15 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1307[0] { + if yyq1358[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.PodSelector == nil { r.EncodeNil() } else { - yym1310 := z.EncBinary() - _ = yym1310 + yym1361 := z.EncBinary() + _ = yym1361 if false { } else if z.HasExtensions() && z.EncExt(x.PodSelector) { } else { @@ -15694,14 +16239,14 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1307 || yy2arr1307 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1307[1] { + if yyq1358[1] { if x.NamespaceSelector == nil { r.EncodeNil() } else { - yym1312 := z.EncBinary() - _ = yym1312 + yym1363 := z.EncBinary() + _ = yym1363 if false { } else if z.HasExtensions() && z.EncExt(x.NamespaceSelector) { } else { @@ -15712,15 +16257,15 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1307[1] { + if yyq1358[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("namespaceSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.NamespaceSelector == nil { r.EncodeNil() } else { - yym1313 := z.EncBinary() - _ = yym1313 + yym1364 := z.EncBinary() + _ = yym1364 if false { } else if z.HasExtensions() && z.EncExt(x.NamespaceSelector) { } else { @@ -15729,7 +16274,7 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1307 || yy2arr1307 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -15742,25 +16287,25 @@ func (x *NetworkPolicyPeer) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1314 := z.DecBinary() - _ = yym1314 + yym1365 := z.DecBinary() + _ = yym1365 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1315 := r.ContainerType() - if yyct1315 == codecSelferValueTypeMap1234 { - yyl1315 := r.ReadMapStart() - if yyl1315 == 0 { + yyct1366 := r.ContainerType() + if yyct1366 == codecSelferValueTypeMap1234 { + yyl1366 := r.ReadMapStart() + if yyl1366 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1315, d) + x.codecDecodeSelfFromMap(yyl1366, d) } - } else if yyct1315 == codecSelferValueTypeArray1234 { - yyl1315 := r.ReadArrayStart() - if yyl1315 == 0 { + } else if yyct1366 == codecSelferValueTypeArray1234 { + yyl1366 := r.ReadArrayStart() + if yyl1366 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1315, d) + x.codecDecodeSelfFromArray(yyl1366, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -15772,12 +16317,12 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1316Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1316Slc - var yyhl1316 bool = l >= 0 - for yyj1316 := 0; ; yyj1316++ { - if yyhl1316 { - if yyj1316 >= l { + var yys1367Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1367Slc + var yyhl1367 bool = l >= 0 + for yyj1367 := 0; ; yyj1367++ { + if yyhl1367 { + if yyj1367 >= l { break } } else { @@ -15786,10 +16331,10 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1316Slc = r.DecodeBytes(yys1316Slc, true, true) - yys1316 := string(yys1316Slc) + yys1367Slc = r.DecodeBytes(yys1367Slc, true, true) + yys1367 := string(yys1367Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1316 { + switch yys1367 { case "podSelector": if r.TryDecodeAsNil() { if x.PodSelector != nil { @@ -15799,8 +16344,8 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if x.PodSelector == nil { x.PodSelector = new(pkg1_unversioned.LabelSelector) } - yym1318 := z.DecBinary() - _ = yym1318 + yym1369 := z.DecBinary() + _ = yym1369 if false { } else if z.HasExtensions() && z.DecExt(x.PodSelector) { } else { @@ -15816,8 +16361,8 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if x.NamespaceSelector == nil { x.NamespaceSelector = new(pkg1_unversioned.LabelSelector) } - yym1320 := z.DecBinary() - _ = yym1320 + yym1371 := z.DecBinary() + _ = yym1371 if false { } else if z.HasExtensions() && z.DecExt(x.NamespaceSelector) { } else { @@ -15825,9 +16370,9 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } default: - z.DecStructFieldNotFound(-1, yys1316) - } // end switch yys1316 - } // end for yyj1316 + z.DecStructFieldNotFound(-1, yys1367) + } // end switch yys1367 + } // end for yyj1367 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -15835,16 +16380,16 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1321 int - var yyb1321 bool - var yyhl1321 bool = l >= 0 - yyj1321++ - if yyhl1321 { - yyb1321 = yyj1321 > l + var yyj1372 int + var yyb1372 bool + var yyhl1372 bool = l >= 0 + yyj1372++ + if yyhl1372 { + yyb1372 = yyj1372 > l } else { - yyb1321 = r.CheckBreak() + yyb1372 = r.CheckBreak() } - if yyb1321 { + if yyb1372 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15857,21 +16402,21 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if x.PodSelector == nil { x.PodSelector = new(pkg1_unversioned.LabelSelector) } - yym1323 := z.DecBinary() - _ = yym1323 + yym1374 := z.DecBinary() + _ = yym1374 if false { } else if z.HasExtensions() && z.DecExt(x.PodSelector) { } else { z.DecFallback(x.PodSelector, false) } } - yyj1321++ - if yyhl1321 { - yyb1321 = yyj1321 > l + yyj1372++ + if yyhl1372 { + yyb1372 = yyj1372 > l } else { - yyb1321 = r.CheckBreak() + yyb1372 = r.CheckBreak() } - if yyb1321 { + if yyb1372 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15884,8 +16429,8 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if x.NamespaceSelector == nil { x.NamespaceSelector = new(pkg1_unversioned.LabelSelector) } - yym1325 := z.DecBinary() - _ = yym1325 + yym1376 := z.DecBinary() + _ = yym1376 if false { } else if z.HasExtensions() && z.DecExt(x.NamespaceSelector) { } else { @@ -15893,17 +16438,17 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } } for { - yyj1321++ - if yyhl1321 { - yyb1321 = yyj1321 > l + yyj1372++ + if yyhl1372 { + yyb1372 = yyj1372 > l } else { - yyb1321 = r.CheckBreak() + yyb1372 = r.CheckBreak() } - if yyb1321 { + if yyb1372 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1321-1, "") + z.DecStructFieldNotFound(yyj1372-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -15915,37 +16460,37 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1326 := z.EncBinary() - _ = yym1326 + yym1377 := z.EncBinary() + _ = yym1377 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1327 := !z.EncBinary() - yy2arr1327 := z.EncBasicHandle().StructToArray - var yyq1327 [4]bool - _, _, _ = yysep1327, yyq1327, yy2arr1327 - const yyr1327 bool = false - yyq1327[0] = x.Kind != "" - yyq1327[1] = x.APIVersion != "" - yyq1327[2] = true - var yynn1327 int - if yyr1327 || yy2arr1327 { + yysep1378 := !z.EncBinary() + yy2arr1378 := z.EncBasicHandle().StructToArray + var yyq1378 [4]bool + _, _, _ = yysep1378, yyq1378, yy2arr1378 + const yyr1378 bool = false + yyq1378[0] = x.Kind != "" + yyq1378[1] = x.APIVersion != "" + yyq1378[2] = true + var yynn1378 int + if yyr1378 || yy2arr1378 { r.EncodeArrayStart(4) } else { - yynn1327 = 1 - for _, b := range yyq1327 { + yynn1378 = 1 + for _, b := range yyq1378 { if b { - yynn1327++ + yynn1378++ } } - r.EncodeMapStart(yynn1327) - yynn1327 = 0 + r.EncodeMapStart(yynn1378) + yynn1378 = 0 } - if yyr1327 || yy2arr1327 { + if yyr1378 || yy2arr1378 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1327[0] { - yym1329 := z.EncBinary() - _ = yym1329 + if yyq1378[0] { + yym1380 := z.EncBinary() + _ = yym1380 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -15954,23 +16499,23 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1327[0] { + if yyq1378[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1330 := z.EncBinary() - _ = yym1330 + yym1381 := z.EncBinary() + _ = yym1381 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1327 || yy2arr1327 { + if yyr1378 || yy2arr1378 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1327[1] { - yym1332 := z.EncBinary() - _ = yym1332 + if yyq1378[1] { + yym1383 := z.EncBinary() + _ = yym1383 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -15979,54 +16524,54 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1327[1] { + if yyq1378[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1333 := z.EncBinary() - _ = yym1333 + yym1384 := z.EncBinary() + _ = yym1384 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1327 || yy2arr1327 { + if yyr1378 || yy2arr1378 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1327[2] { - yy1335 := &x.ListMeta - yym1336 := z.EncBinary() - _ = yym1336 + if yyq1378[2] { + yy1386 := &x.ListMeta + yym1387 := z.EncBinary() + _ = yym1387 if false { - } else if z.HasExtensions() && z.EncExt(yy1335) { + } else if z.HasExtensions() && z.EncExt(yy1386) { } else { - z.EncFallback(yy1335) + z.EncFallback(yy1386) } } else { r.EncodeNil() } } else { - if yyq1327[2] { + if yyq1378[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1337 := &x.ListMeta - yym1338 := z.EncBinary() - _ = yym1338 + yy1388 := &x.ListMeta + yym1389 := z.EncBinary() + _ = yym1389 if false { - } else if z.HasExtensions() && z.EncExt(yy1337) { + } else if z.HasExtensions() && z.EncExt(yy1388) { } else { - z.EncFallback(yy1337) + z.EncFallback(yy1388) } } } - if yyr1327 || yy2arr1327 { + if yyr1378 || yy2arr1378 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1340 := z.EncBinary() - _ = yym1340 + yym1391 := z.EncBinary() + _ = yym1391 if false { } else { h.encSliceNetworkPolicy(([]NetworkPolicy)(x.Items), e) @@ -16039,15 +16584,15 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1341 := z.EncBinary() - _ = yym1341 + yym1392 := z.EncBinary() + _ = yym1392 if false { } else { h.encSliceNetworkPolicy(([]NetworkPolicy)(x.Items), e) } } } - if yyr1327 || yy2arr1327 { + if yyr1378 || yy2arr1378 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -16060,25 +16605,25 @@ func (x *NetworkPolicyList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1342 := z.DecBinary() - _ = yym1342 + yym1393 := z.DecBinary() + _ = yym1393 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1343 := r.ContainerType() - if yyct1343 == codecSelferValueTypeMap1234 { - yyl1343 := r.ReadMapStart() - if yyl1343 == 0 { + yyct1394 := r.ContainerType() + if yyct1394 == codecSelferValueTypeMap1234 { + yyl1394 := r.ReadMapStart() + if yyl1394 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1343, d) + x.codecDecodeSelfFromMap(yyl1394, d) } - } else if yyct1343 == codecSelferValueTypeArray1234 { - yyl1343 := r.ReadArrayStart() - if yyl1343 == 0 { + } else if yyct1394 == codecSelferValueTypeArray1234 { + yyl1394 := r.ReadArrayStart() + if yyl1394 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1343, d) + x.codecDecodeSelfFromArray(yyl1394, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -16090,12 +16635,12 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1344Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1344Slc - var yyhl1344 bool = l >= 0 - for yyj1344 := 0; ; yyj1344++ { - if yyhl1344 { - if yyj1344 >= l { + var yys1395Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1395Slc + var yyhl1395 bool = l >= 0 + for yyj1395 := 0; ; yyj1395++ { + if yyhl1395 { + if yyj1395 >= l { break } } else { @@ -16104,10 +16649,10 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1344Slc = r.DecodeBytes(yys1344Slc, true, true) - yys1344 := string(yys1344Slc) + yys1395Slc = r.DecodeBytes(yys1395Slc, true, true) + yys1395 := string(yys1395Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1344 { + switch yys1395 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -16124,31 +16669,31 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1347 := &x.ListMeta - yym1348 := z.DecBinary() - _ = yym1348 + yyv1398 := &x.ListMeta + yym1399 := z.DecBinary() + _ = yym1399 if false { - } else if z.HasExtensions() && z.DecExt(yyv1347) { + } else if z.HasExtensions() && z.DecExt(yyv1398) { } else { - z.DecFallback(yyv1347, false) + z.DecFallback(yyv1398, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1349 := &x.Items - yym1350 := z.DecBinary() - _ = yym1350 + yyv1400 := &x.Items + yym1401 := z.DecBinary() + _ = yym1401 if false { } else { - h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1349), d) + h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1400), d) } } default: - z.DecStructFieldNotFound(-1, yys1344) - } // end switch yys1344 - } // end for yyj1344 + z.DecStructFieldNotFound(-1, yys1395) + } // end switch yys1395 + } // end for yyj1395 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -16156,16 +16701,16 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1351 int - var yyb1351 bool - var yyhl1351 bool = l >= 0 - yyj1351++ - if yyhl1351 { - yyb1351 = yyj1351 > l + var yyj1402 int + var yyb1402 bool + var yyhl1402 bool = l >= 0 + yyj1402++ + if yyhl1402 { + yyb1402 = yyj1402 > l } else { - yyb1351 = r.CheckBreak() + yyb1402 = r.CheckBreak() } - if yyb1351 { + if yyb1402 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16175,13 +16720,13 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj1351++ - if yyhl1351 { - yyb1351 = yyj1351 > l + yyj1402++ + if yyhl1402 { + yyb1402 = yyj1402 > l } else { - yyb1351 = r.CheckBreak() + yyb1402 = r.CheckBreak() } - if yyb1351 { + if yyb1402 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16191,13 +16736,13 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj1351++ - if yyhl1351 { - yyb1351 = yyj1351 > l + yyj1402++ + if yyhl1402 { + yyb1402 = yyj1402 > l } else { - yyb1351 = r.CheckBreak() + yyb1402 = r.CheckBreak() } - if yyb1351 { + if yyb1402 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16205,22 +16750,22 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1354 := &x.ListMeta - yym1355 := z.DecBinary() - _ = yym1355 + yyv1405 := &x.ListMeta + yym1406 := z.DecBinary() + _ = yym1406 if false { - } else if z.HasExtensions() && z.DecExt(yyv1354) { + } else if z.HasExtensions() && z.DecExt(yyv1405) { } else { - z.DecFallback(yyv1354, false) + z.DecFallback(yyv1405, false) } } - yyj1351++ - if yyhl1351 { - yyb1351 = yyj1351 > l + yyj1402++ + if yyhl1402 { + yyb1402 = yyj1402 > l } else { - yyb1351 = r.CheckBreak() + yyb1402 = r.CheckBreak() } - if yyb1351 { + if yyb1402 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16228,26 +16773,26 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1356 := &x.Items - yym1357 := z.DecBinary() - _ = yym1357 + yyv1407 := &x.Items + yym1408 := z.DecBinary() + _ = yym1408 if false { } else { - h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1356), d) + h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1407), d) } } for { - yyj1351++ - if yyhl1351 { - yyb1351 = yyj1351 > l + yyj1402++ + if yyhl1402 { + yyb1402 = yyj1402 > l } else { - yyb1351 = r.CheckBreak() + yyb1402 = r.CheckBreak() } - if yyb1351 { + if yyb1402 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1351-1, "") + z.DecStructFieldNotFound(yyj1402-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16257,10 +16802,10 @@ func (x codecSelfer1234) encSliceCustomMetricTarget(v []CustomMetricTarget, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1358 := range v { + for _, yyv1409 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1359 := &yyv1358 - yy1359.CodecEncodeSelf(e) + yy1410 := &yyv1409 + yy1410.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16270,83 +16815,83 @@ func (x codecSelfer1234) decSliceCustomMetricTarget(v *[]CustomMetricTarget, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1360 := *v - yyh1360, yyl1360 := z.DecSliceHelperStart() - var yyc1360 bool - if yyl1360 == 0 { - if yyv1360 == nil { - yyv1360 = []CustomMetricTarget{} - yyc1360 = true - } else if len(yyv1360) != 0 { - yyv1360 = yyv1360[:0] - yyc1360 = true + yyv1411 := *v + yyh1411, yyl1411 := z.DecSliceHelperStart() + var yyc1411 bool + if yyl1411 == 0 { + if yyv1411 == nil { + yyv1411 = []CustomMetricTarget{} + yyc1411 = true + } else if len(yyv1411) != 0 { + yyv1411 = yyv1411[:0] + yyc1411 = true } - } else if yyl1360 > 0 { - var yyrr1360, yyrl1360 int - var yyrt1360 bool - if yyl1360 > cap(yyv1360) { + } else if yyl1411 > 0 { + var yyrr1411, yyrl1411 int + var yyrt1411 bool + if yyl1411 > cap(yyv1411) { - yyrg1360 := len(yyv1360) > 0 - yyv21360 := yyv1360 - yyrl1360, yyrt1360 = z.DecInferLen(yyl1360, z.DecBasicHandle().MaxInitLen, 72) - if yyrt1360 { - if yyrl1360 <= cap(yyv1360) { - yyv1360 = yyv1360[:yyrl1360] + yyrg1411 := len(yyv1411) > 0 + yyv21411 := yyv1411 + yyrl1411, yyrt1411 = z.DecInferLen(yyl1411, z.DecBasicHandle().MaxInitLen, 72) + if yyrt1411 { + if yyrl1411 <= cap(yyv1411) { + yyv1411 = yyv1411[:yyrl1411] } else { - yyv1360 = make([]CustomMetricTarget, yyrl1360) + yyv1411 = make([]CustomMetricTarget, yyrl1411) } } else { - yyv1360 = make([]CustomMetricTarget, yyrl1360) + yyv1411 = make([]CustomMetricTarget, yyrl1411) } - yyc1360 = true - yyrr1360 = len(yyv1360) - if yyrg1360 { - copy(yyv1360, yyv21360) + yyc1411 = true + yyrr1411 = len(yyv1411) + if yyrg1411 { + copy(yyv1411, yyv21411) } - } else if yyl1360 != len(yyv1360) { - yyv1360 = yyv1360[:yyl1360] - yyc1360 = true + } else if yyl1411 != len(yyv1411) { + yyv1411 = yyv1411[:yyl1411] + yyc1411 = true } - yyj1360 := 0 - for ; yyj1360 < yyrr1360; yyj1360++ { - yyh1360.ElemContainerState(yyj1360) + yyj1411 := 0 + for ; yyj1411 < yyrr1411; yyj1411++ { + yyh1411.ElemContainerState(yyj1411) if r.TryDecodeAsNil() { - yyv1360[yyj1360] = CustomMetricTarget{} + yyv1411[yyj1411] = CustomMetricTarget{} } else { - yyv1361 := &yyv1360[yyj1360] - yyv1361.CodecDecodeSelf(d) + yyv1412 := &yyv1411[yyj1411] + yyv1412.CodecDecodeSelf(d) } } - if yyrt1360 { - for ; yyj1360 < yyl1360; yyj1360++ { - yyv1360 = append(yyv1360, CustomMetricTarget{}) - yyh1360.ElemContainerState(yyj1360) + if yyrt1411 { + for ; yyj1411 < yyl1411; yyj1411++ { + yyv1411 = append(yyv1411, CustomMetricTarget{}) + yyh1411.ElemContainerState(yyj1411) if r.TryDecodeAsNil() { - yyv1360[yyj1360] = CustomMetricTarget{} + yyv1411[yyj1411] = CustomMetricTarget{} } else { - yyv1362 := &yyv1360[yyj1360] - yyv1362.CodecDecodeSelf(d) + yyv1413 := &yyv1411[yyj1411] + yyv1413.CodecDecodeSelf(d) } } } } else { - yyj1360 := 0 - for ; !r.CheckBreak(); yyj1360++ { + yyj1411 := 0 + for ; !r.CheckBreak(); yyj1411++ { - if yyj1360 >= len(yyv1360) { - yyv1360 = append(yyv1360, CustomMetricTarget{}) // var yyz1360 CustomMetricTarget - yyc1360 = true + if yyj1411 >= len(yyv1411) { + yyv1411 = append(yyv1411, CustomMetricTarget{}) // var yyz1411 CustomMetricTarget + yyc1411 = true } - yyh1360.ElemContainerState(yyj1360) - if yyj1360 < len(yyv1360) { + yyh1411.ElemContainerState(yyj1411) + if yyj1411 < len(yyv1411) { if r.TryDecodeAsNil() { - yyv1360[yyj1360] = CustomMetricTarget{} + yyv1411[yyj1411] = CustomMetricTarget{} } else { - yyv1363 := &yyv1360[yyj1360] - yyv1363.CodecDecodeSelf(d) + yyv1414 := &yyv1411[yyj1411] + yyv1414.CodecDecodeSelf(d) } } else { @@ -16354,17 +16899,17 @@ func (x codecSelfer1234) decSliceCustomMetricTarget(v *[]CustomMetricTarget, d * } } - if yyj1360 < len(yyv1360) { - yyv1360 = yyv1360[:yyj1360] - yyc1360 = true - } else if yyj1360 == 0 && yyv1360 == nil { - yyv1360 = []CustomMetricTarget{} - yyc1360 = true + if yyj1411 < len(yyv1411) { + yyv1411 = yyv1411[:yyj1411] + yyc1411 = true + } else if yyj1411 == 0 && yyv1411 == nil { + yyv1411 = []CustomMetricTarget{} + yyc1411 = true } } - yyh1360.End() - if yyc1360 { - *v = yyv1360 + yyh1411.End() + if yyc1411 { + *v = yyv1411 } } @@ -16373,10 +16918,10 @@ func (x codecSelfer1234) encSliceCustomMetricCurrentStatus(v []CustomMetricCurre z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1364 := range v { + for _, yyv1415 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1365 := &yyv1364 - yy1365.CodecEncodeSelf(e) + yy1416 := &yyv1415 + yy1416.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16386,83 +16931,83 @@ func (x codecSelfer1234) decSliceCustomMetricCurrentStatus(v *[]CustomMetricCurr z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1366 := *v - yyh1366, yyl1366 := z.DecSliceHelperStart() - var yyc1366 bool - if yyl1366 == 0 { - if yyv1366 == nil { - yyv1366 = []CustomMetricCurrentStatus{} - yyc1366 = true - } else if len(yyv1366) != 0 { - yyv1366 = yyv1366[:0] - yyc1366 = true + yyv1417 := *v + yyh1417, yyl1417 := z.DecSliceHelperStart() + var yyc1417 bool + if yyl1417 == 0 { + if yyv1417 == nil { + yyv1417 = []CustomMetricCurrentStatus{} + yyc1417 = true + } else if len(yyv1417) != 0 { + yyv1417 = yyv1417[:0] + yyc1417 = true } - } else if yyl1366 > 0 { - var yyrr1366, yyrl1366 int - var yyrt1366 bool - if yyl1366 > cap(yyv1366) { + } else if yyl1417 > 0 { + var yyrr1417, yyrl1417 int + var yyrt1417 bool + if yyl1417 > cap(yyv1417) { - yyrg1366 := len(yyv1366) > 0 - yyv21366 := yyv1366 - yyrl1366, yyrt1366 = z.DecInferLen(yyl1366, z.DecBasicHandle().MaxInitLen, 72) - if yyrt1366 { - if yyrl1366 <= cap(yyv1366) { - yyv1366 = yyv1366[:yyrl1366] + yyrg1417 := len(yyv1417) > 0 + yyv21417 := yyv1417 + yyrl1417, yyrt1417 = z.DecInferLen(yyl1417, z.DecBasicHandle().MaxInitLen, 72) + if yyrt1417 { + if yyrl1417 <= cap(yyv1417) { + yyv1417 = yyv1417[:yyrl1417] } else { - yyv1366 = make([]CustomMetricCurrentStatus, yyrl1366) + yyv1417 = make([]CustomMetricCurrentStatus, yyrl1417) } } else { - yyv1366 = make([]CustomMetricCurrentStatus, yyrl1366) + yyv1417 = make([]CustomMetricCurrentStatus, yyrl1417) } - yyc1366 = true - yyrr1366 = len(yyv1366) - if yyrg1366 { - copy(yyv1366, yyv21366) + yyc1417 = true + yyrr1417 = len(yyv1417) + if yyrg1417 { + copy(yyv1417, yyv21417) } - } else if yyl1366 != len(yyv1366) { - yyv1366 = yyv1366[:yyl1366] - yyc1366 = true + } else if yyl1417 != len(yyv1417) { + yyv1417 = yyv1417[:yyl1417] + yyc1417 = true } - yyj1366 := 0 - for ; yyj1366 < yyrr1366; yyj1366++ { - yyh1366.ElemContainerState(yyj1366) + yyj1417 := 0 + for ; yyj1417 < yyrr1417; yyj1417++ { + yyh1417.ElemContainerState(yyj1417) if r.TryDecodeAsNil() { - yyv1366[yyj1366] = CustomMetricCurrentStatus{} + yyv1417[yyj1417] = CustomMetricCurrentStatus{} } else { - yyv1367 := &yyv1366[yyj1366] - yyv1367.CodecDecodeSelf(d) + yyv1418 := &yyv1417[yyj1417] + yyv1418.CodecDecodeSelf(d) } } - if yyrt1366 { - for ; yyj1366 < yyl1366; yyj1366++ { - yyv1366 = append(yyv1366, CustomMetricCurrentStatus{}) - yyh1366.ElemContainerState(yyj1366) + if yyrt1417 { + for ; yyj1417 < yyl1417; yyj1417++ { + yyv1417 = append(yyv1417, CustomMetricCurrentStatus{}) + yyh1417.ElemContainerState(yyj1417) if r.TryDecodeAsNil() { - yyv1366[yyj1366] = CustomMetricCurrentStatus{} + yyv1417[yyj1417] = CustomMetricCurrentStatus{} } else { - yyv1368 := &yyv1366[yyj1366] - yyv1368.CodecDecodeSelf(d) + yyv1419 := &yyv1417[yyj1417] + yyv1419.CodecDecodeSelf(d) } } } } else { - yyj1366 := 0 - for ; !r.CheckBreak(); yyj1366++ { + yyj1417 := 0 + for ; !r.CheckBreak(); yyj1417++ { - if yyj1366 >= len(yyv1366) { - yyv1366 = append(yyv1366, CustomMetricCurrentStatus{}) // var yyz1366 CustomMetricCurrentStatus - yyc1366 = true + if yyj1417 >= len(yyv1417) { + yyv1417 = append(yyv1417, CustomMetricCurrentStatus{}) // var yyz1417 CustomMetricCurrentStatus + yyc1417 = true } - yyh1366.ElemContainerState(yyj1366) - if yyj1366 < len(yyv1366) { + yyh1417.ElemContainerState(yyj1417) + if yyj1417 < len(yyv1417) { if r.TryDecodeAsNil() { - yyv1366[yyj1366] = CustomMetricCurrentStatus{} + yyv1417[yyj1417] = CustomMetricCurrentStatus{} } else { - yyv1369 := &yyv1366[yyj1366] - yyv1369.CodecDecodeSelf(d) + yyv1420 := &yyv1417[yyj1417] + yyv1420.CodecDecodeSelf(d) } } else { @@ -16470,17 +17015,17 @@ func (x codecSelfer1234) decSliceCustomMetricCurrentStatus(v *[]CustomMetricCurr } } - if yyj1366 < len(yyv1366) { - yyv1366 = yyv1366[:yyj1366] - yyc1366 = true - } else if yyj1366 == 0 && yyv1366 == nil { - yyv1366 = []CustomMetricCurrentStatus{} - yyc1366 = true + if yyj1417 < len(yyv1417) { + yyv1417 = yyv1417[:yyj1417] + yyc1417 = true + } else if yyj1417 == 0 && yyv1417 == nil { + yyv1417 = []CustomMetricCurrentStatus{} + yyc1417 = true } } - yyh1366.End() - if yyc1366 { - *v = yyv1366 + yyh1417.End() + if yyc1417 { + *v = yyv1417 } } @@ -16489,10 +17034,10 @@ func (x codecSelfer1234) encSliceAPIVersion(v []APIVersion, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1370 := range v { + for _, yyv1421 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1371 := &yyv1370 - yy1371.CodecEncodeSelf(e) + yy1422 := &yyv1421 + yy1422.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16502,83 +17047,83 @@ func (x codecSelfer1234) decSliceAPIVersion(v *[]APIVersion, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1372 := *v - yyh1372, yyl1372 := z.DecSliceHelperStart() - var yyc1372 bool - if yyl1372 == 0 { - if yyv1372 == nil { - yyv1372 = []APIVersion{} - yyc1372 = true - } else if len(yyv1372) != 0 { - yyv1372 = yyv1372[:0] - yyc1372 = true + yyv1423 := *v + yyh1423, yyl1423 := z.DecSliceHelperStart() + var yyc1423 bool + if yyl1423 == 0 { + if yyv1423 == nil { + yyv1423 = []APIVersion{} + yyc1423 = true + } else if len(yyv1423) != 0 { + yyv1423 = yyv1423[:0] + yyc1423 = true } - } else if yyl1372 > 0 { - var yyrr1372, yyrl1372 int - var yyrt1372 bool - if yyl1372 > cap(yyv1372) { + } else if yyl1423 > 0 { + var yyrr1423, yyrl1423 int + var yyrt1423 bool + if yyl1423 > cap(yyv1423) { - yyrg1372 := len(yyv1372) > 0 - yyv21372 := yyv1372 - yyrl1372, yyrt1372 = z.DecInferLen(yyl1372, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1372 { - if yyrl1372 <= cap(yyv1372) { - yyv1372 = yyv1372[:yyrl1372] + yyrg1423 := len(yyv1423) > 0 + yyv21423 := yyv1423 + yyrl1423, yyrt1423 = z.DecInferLen(yyl1423, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1423 { + if yyrl1423 <= cap(yyv1423) { + yyv1423 = yyv1423[:yyrl1423] } else { - yyv1372 = make([]APIVersion, yyrl1372) + yyv1423 = make([]APIVersion, yyrl1423) } } else { - yyv1372 = make([]APIVersion, yyrl1372) + yyv1423 = make([]APIVersion, yyrl1423) } - yyc1372 = true - yyrr1372 = len(yyv1372) - if yyrg1372 { - copy(yyv1372, yyv21372) + yyc1423 = true + yyrr1423 = len(yyv1423) + if yyrg1423 { + copy(yyv1423, yyv21423) } - } else if yyl1372 != len(yyv1372) { - yyv1372 = yyv1372[:yyl1372] - yyc1372 = true + } else if yyl1423 != len(yyv1423) { + yyv1423 = yyv1423[:yyl1423] + yyc1423 = true } - yyj1372 := 0 - for ; yyj1372 < yyrr1372; yyj1372++ { - yyh1372.ElemContainerState(yyj1372) + yyj1423 := 0 + for ; yyj1423 < yyrr1423; yyj1423++ { + yyh1423.ElemContainerState(yyj1423) if r.TryDecodeAsNil() { - yyv1372[yyj1372] = APIVersion{} + yyv1423[yyj1423] = APIVersion{} } else { - yyv1373 := &yyv1372[yyj1372] - yyv1373.CodecDecodeSelf(d) + yyv1424 := &yyv1423[yyj1423] + yyv1424.CodecDecodeSelf(d) } } - if yyrt1372 { - for ; yyj1372 < yyl1372; yyj1372++ { - yyv1372 = append(yyv1372, APIVersion{}) - yyh1372.ElemContainerState(yyj1372) + if yyrt1423 { + for ; yyj1423 < yyl1423; yyj1423++ { + yyv1423 = append(yyv1423, APIVersion{}) + yyh1423.ElemContainerState(yyj1423) if r.TryDecodeAsNil() { - yyv1372[yyj1372] = APIVersion{} + yyv1423[yyj1423] = APIVersion{} } else { - yyv1374 := &yyv1372[yyj1372] - yyv1374.CodecDecodeSelf(d) + yyv1425 := &yyv1423[yyj1423] + yyv1425.CodecDecodeSelf(d) } } } } else { - yyj1372 := 0 - for ; !r.CheckBreak(); yyj1372++ { + yyj1423 := 0 + for ; !r.CheckBreak(); yyj1423++ { - if yyj1372 >= len(yyv1372) { - yyv1372 = append(yyv1372, APIVersion{}) // var yyz1372 APIVersion - yyc1372 = true + if yyj1423 >= len(yyv1423) { + yyv1423 = append(yyv1423, APIVersion{}) // var yyz1423 APIVersion + yyc1423 = true } - yyh1372.ElemContainerState(yyj1372) - if yyj1372 < len(yyv1372) { + yyh1423.ElemContainerState(yyj1423) + if yyj1423 < len(yyv1423) { if r.TryDecodeAsNil() { - yyv1372[yyj1372] = APIVersion{} + yyv1423[yyj1423] = APIVersion{} } else { - yyv1375 := &yyv1372[yyj1372] - yyv1375.CodecDecodeSelf(d) + yyv1426 := &yyv1423[yyj1423] + yyv1426.CodecDecodeSelf(d) } } else { @@ -16586,17 +17131,17 @@ func (x codecSelfer1234) decSliceAPIVersion(v *[]APIVersion, d *codec1978.Decode } } - if yyj1372 < len(yyv1372) { - yyv1372 = yyv1372[:yyj1372] - yyc1372 = true - } else if yyj1372 == 0 && yyv1372 == nil { - yyv1372 = []APIVersion{} - yyc1372 = true + if yyj1423 < len(yyv1423) { + yyv1423 = yyv1423[:yyj1423] + yyc1423 = true + } else if yyj1423 == 0 && yyv1423 == nil { + yyv1423 = []APIVersion{} + yyc1423 = true } } - yyh1372.End() - if yyc1372 { - *v = yyv1372 + yyh1423.End() + if yyc1423 { + *v = yyv1423 } } @@ -16605,10 +17150,10 @@ func (x codecSelfer1234) encSliceThirdPartyResource(v []ThirdPartyResource, e *c z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1376 := range v { + for _, yyv1427 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1377 := &yyv1376 - yy1377.CodecEncodeSelf(e) + yy1428 := &yyv1427 + yy1428.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16618,83 +17163,83 @@ func (x codecSelfer1234) decSliceThirdPartyResource(v *[]ThirdPartyResource, d * z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1378 := *v - yyh1378, yyl1378 := z.DecSliceHelperStart() - var yyc1378 bool - if yyl1378 == 0 { - if yyv1378 == nil { - yyv1378 = []ThirdPartyResource{} - yyc1378 = true - } else if len(yyv1378) != 0 { - yyv1378 = yyv1378[:0] - yyc1378 = true + yyv1429 := *v + yyh1429, yyl1429 := z.DecSliceHelperStart() + var yyc1429 bool + if yyl1429 == 0 { + if yyv1429 == nil { + yyv1429 = []ThirdPartyResource{} + yyc1429 = true + } else if len(yyv1429) != 0 { + yyv1429 = yyv1429[:0] + yyc1429 = true } - } else if yyl1378 > 0 { - var yyrr1378, yyrl1378 int - var yyrt1378 bool - if yyl1378 > cap(yyv1378) { + } else if yyl1429 > 0 { + var yyrr1429, yyrl1429 int + var yyrt1429 bool + if yyl1429 > cap(yyv1429) { - yyrg1378 := len(yyv1378) > 0 - yyv21378 := yyv1378 - yyrl1378, yyrt1378 = z.DecInferLen(yyl1378, z.DecBasicHandle().MaxInitLen, 296) - if yyrt1378 { - if yyrl1378 <= cap(yyv1378) { - yyv1378 = yyv1378[:yyrl1378] + yyrg1429 := len(yyv1429) > 0 + yyv21429 := yyv1429 + yyrl1429, yyrt1429 = z.DecInferLen(yyl1429, z.DecBasicHandle().MaxInitLen, 296) + if yyrt1429 { + if yyrl1429 <= cap(yyv1429) { + yyv1429 = yyv1429[:yyrl1429] } else { - yyv1378 = make([]ThirdPartyResource, yyrl1378) + yyv1429 = make([]ThirdPartyResource, yyrl1429) } } else { - yyv1378 = make([]ThirdPartyResource, yyrl1378) + yyv1429 = make([]ThirdPartyResource, yyrl1429) } - yyc1378 = true - yyrr1378 = len(yyv1378) - if yyrg1378 { - copy(yyv1378, yyv21378) + yyc1429 = true + yyrr1429 = len(yyv1429) + if yyrg1429 { + copy(yyv1429, yyv21429) } - } else if yyl1378 != len(yyv1378) { - yyv1378 = yyv1378[:yyl1378] - yyc1378 = true + } else if yyl1429 != len(yyv1429) { + yyv1429 = yyv1429[:yyl1429] + yyc1429 = true } - yyj1378 := 0 - for ; yyj1378 < yyrr1378; yyj1378++ { - yyh1378.ElemContainerState(yyj1378) + yyj1429 := 0 + for ; yyj1429 < yyrr1429; yyj1429++ { + yyh1429.ElemContainerState(yyj1429) if r.TryDecodeAsNil() { - yyv1378[yyj1378] = ThirdPartyResource{} + yyv1429[yyj1429] = ThirdPartyResource{} } else { - yyv1379 := &yyv1378[yyj1378] - yyv1379.CodecDecodeSelf(d) + yyv1430 := &yyv1429[yyj1429] + yyv1430.CodecDecodeSelf(d) } } - if yyrt1378 { - for ; yyj1378 < yyl1378; yyj1378++ { - yyv1378 = append(yyv1378, ThirdPartyResource{}) - yyh1378.ElemContainerState(yyj1378) + if yyrt1429 { + for ; yyj1429 < yyl1429; yyj1429++ { + yyv1429 = append(yyv1429, ThirdPartyResource{}) + yyh1429.ElemContainerState(yyj1429) if r.TryDecodeAsNil() { - yyv1378[yyj1378] = ThirdPartyResource{} + yyv1429[yyj1429] = ThirdPartyResource{} } else { - yyv1380 := &yyv1378[yyj1378] - yyv1380.CodecDecodeSelf(d) + yyv1431 := &yyv1429[yyj1429] + yyv1431.CodecDecodeSelf(d) } } } } else { - yyj1378 := 0 - for ; !r.CheckBreak(); yyj1378++ { + yyj1429 := 0 + for ; !r.CheckBreak(); yyj1429++ { - if yyj1378 >= len(yyv1378) { - yyv1378 = append(yyv1378, ThirdPartyResource{}) // var yyz1378 ThirdPartyResource - yyc1378 = true + if yyj1429 >= len(yyv1429) { + yyv1429 = append(yyv1429, ThirdPartyResource{}) // var yyz1429 ThirdPartyResource + yyc1429 = true } - yyh1378.ElemContainerState(yyj1378) - if yyj1378 < len(yyv1378) { + yyh1429.ElemContainerState(yyj1429) + if yyj1429 < len(yyv1429) { if r.TryDecodeAsNil() { - yyv1378[yyj1378] = ThirdPartyResource{} + yyv1429[yyj1429] = ThirdPartyResource{} } else { - yyv1381 := &yyv1378[yyj1378] - yyv1381.CodecDecodeSelf(d) + yyv1432 := &yyv1429[yyj1429] + yyv1432.CodecDecodeSelf(d) } } else { @@ -16702,17 +17247,133 @@ func (x codecSelfer1234) decSliceThirdPartyResource(v *[]ThirdPartyResource, d * } } - if yyj1378 < len(yyv1378) { - yyv1378 = yyv1378[:yyj1378] - yyc1378 = true - } else if yyj1378 == 0 && yyv1378 == nil { - yyv1378 = []ThirdPartyResource{} - yyc1378 = true + if yyj1429 < len(yyv1429) { + yyv1429 = yyv1429[:yyj1429] + yyc1429 = true + } else if yyj1429 == 0 && yyv1429 == nil { + yyv1429 = []ThirdPartyResource{} + yyc1429 = true } } - yyh1378.End() - if yyc1378 { - *v = yyv1378 + yyh1429.End() + if yyc1429 { + *v = yyv1429 + } +} + +func (x codecSelfer1234) encSliceDeploymentCondition(v []DeploymentCondition, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1433 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1434 := &yyv1433 + yy1434.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceDeploymentCondition(v *[]DeploymentCondition, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1435 := *v + yyh1435, yyl1435 := z.DecSliceHelperStart() + var yyc1435 bool + if yyl1435 == 0 { + if yyv1435 == nil { + yyv1435 = []DeploymentCondition{} + yyc1435 = true + } else if len(yyv1435) != 0 { + yyv1435 = yyv1435[:0] + yyc1435 = true + } + } else if yyl1435 > 0 { + var yyrr1435, yyrl1435 int + var yyrt1435 bool + if yyl1435 > cap(yyv1435) { + + yyrg1435 := len(yyv1435) > 0 + yyv21435 := yyv1435 + yyrl1435, yyrt1435 = z.DecInferLen(yyl1435, z.DecBasicHandle().MaxInitLen, 112) + if yyrt1435 { + if yyrl1435 <= cap(yyv1435) { + yyv1435 = yyv1435[:yyrl1435] + } else { + yyv1435 = make([]DeploymentCondition, yyrl1435) + } + } else { + yyv1435 = make([]DeploymentCondition, yyrl1435) + } + yyc1435 = true + yyrr1435 = len(yyv1435) + if yyrg1435 { + copy(yyv1435, yyv21435) + } + } else if yyl1435 != len(yyv1435) { + yyv1435 = yyv1435[:yyl1435] + yyc1435 = true + } + yyj1435 := 0 + for ; yyj1435 < yyrr1435; yyj1435++ { + yyh1435.ElemContainerState(yyj1435) + if r.TryDecodeAsNil() { + yyv1435[yyj1435] = DeploymentCondition{} + } else { + yyv1436 := &yyv1435[yyj1435] + yyv1436.CodecDecodeSelf(d) + } + + } + if yyrt1435 { + for ; yyj1435 < yyl1435; yyj1435++ { + yyv1435 = append(yyv1435, DeploymentCondition{}) + yyh1435.ElemContainerState(yyj1435) + if r.TryDecodeAsNil() { + yyv1435[yyj1435] = DeploymentCondition{} + } else { + yyv1437 := &yyv1435[yyj1435] + yyv1437.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1435 := 0 + for ; !r.CheckBreak(); yyj1435++ { + + if yyj1435 >= len(yyv1435) { + yyv1435 = append(yyv1435, DeploymentCondition{}) // var yyz1435 DeploymentCondition + yyc1435 = true + } + yyh1435.ElemContainerState(yyj1435) + if yyj1435 < len(yyv1435) { + if r.TryDecodeAsNil() { + yyv1435[yyj1435] = DeploymentCondition{} + } else { + yyv1438 := &yyv1435[yyj1435] + yyv1438.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1435 < len(yyv1435) { + yyv1435 = yyv1435[:yyj1435] + yyc1435 = true + } else if yyj1435 == 0 && yyv1435 == nil { + yyv1435 = []DeploymentCondition{} + yyc1435 = true + } + } + yyh1435.End() + if yyc1435 { + *v = yyv1435 } } @@ -16721,10 +17382,10 @@ func (x codecSelfer1234) encSliceDeployment(v []Deployment, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1382 := range v { + for _, yyv1439 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1383 := &yyv1382 - yy1383.CodecEncodeSelf(e) + yy1440 := &yyv1439 + yy1440.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16734,83 +17395,83 @@ func (x codecSelfer1234) decSliceDeployment(v *[]Deployment, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1384 := *v - yyh1384, yyl1384 := z.DecSliceHelperStart() - var yyc1384 bool - if yyl1384 == 0 { - if yyv1384 == nil { - yyv1384 = []Deployment{} - yyc1384 = true - } else if len(yyv1384) != 0 { - yyv1384 = yyv1384[:0] - yyc1384 = true + yyv1441 := *v + yyh1441, yyl1441 := z.DecSliceHelperStart() + var yyc1441 bool + if yyl1441 == 0 { + if yyv1441 == nil { + yyv1441 = []Deployment{} + yyc1441 = true + } else if len(yyv1441) != 0 { + yyv1441 = yyv1441[:0] + yyc1441 = true } - } else if yyl1384 > 0 { - var yyrr1384, yyrl1384 int - var yyrt1384 bool - if yyl1384 > cap(yyv1384) { + } else if yyl1441 > 0 { + var yyrr1441, yyrl1441 int + var yyrt1441 bool + if yyl1441 > cap(yyv1441) { - yyrg1384 := len(yyv1384) > 0 - yyv21384 := yyv1384 - yyrl1384, yyrt1384 = z.DecInferLen(yyl1384, z.DecBasicHandle().MaxInitLen, 800) - if yyrt1384 { - if yyrl1384 <= cap(yyv1384) { - yyv1384 = yyv1384[:yyrl1384] + yyrg1441 := len(yyv1441) > 0 + yyv21441 := yyv1441 + yyrl1441, yyrt1441 = z.DecInferLen(yyl1441, z.DecBasicHandle().MaxInitLen, 832) + if yyrt1441 { + if yyrl1441 <= cap(yyv1441) { + yyv1441 = yyv1441[:yyrl1441] } else { - yyv1384 = make([]Deployment, yyrl1384) + yyv1441 = make([]Deployment, yyrl1441) } } else { - yyv1384 = make([]Deployment, yyrl1384) + yyv1441 = make([]Deployment, yyrl1441) } - yyc1384 = true - yyrr1384 = len(yyv1384) - if yyrg1384 { - copy(yyv1384, yyv21384) + yyc1441 = true + yyrr1441 = len(yyv1441) + if yyrg1441 { + copy(yyv1441, yyv21441) } - } else if yyl1384 != len(yyv1384) { - yyv1384 = yyv1384[:yyl1384] - yyc1384 = true + } else if yyl1441 != len(yyv1441) { + yyv1441 = yyv1441[:yyl1441] + yyc1441 = true } - yyj1384 := 0 - for ; yyj1384 < yyrr1384; yyj1384++ { - yyh1384.ElemContainerState(yyj1384) + yyj1441 := 0 + for ; yyj1441 < yyrr1441; yyj1441++ { + yyh1441.ElemContainerState(yyj1441) if r.TryDecodeAsNil() { - yyv1384[yyj1384] = Deployment{} + yyv1441[yyj1441] = Deployment{} } else { - yyv1385 := &yyv1384[yyj1384] - yyv1385.CodecDecodeSelf(d) + yyv1442 := &yyv1441[yyj1441] + yyv1442.CodecDecodeSelf(d) } } - if yyrt1384 { - for ; yyj1384 < yyl1384; yyj1384++ { - yyv1384 = append(yyv1384, Deployment{}) - yyh1384.ElemContainerState(yyj1384) + if yyrt1441 { + for ; yyj1441 < yyl1441; yyj1441++ { + yyv1441 = append(yyv1441, Deployment{}) + yyh1441.ElemContainerState(yyj1441) if r.TryDecodeAsNil() { - yyv1384[yyj1384] = Deployment{} + yyv1441[yyj1441] = Deployment{} } else { - yyv1386 := &yyv1384[yyj1384] - yyv1386.CodecDecodeSelf(d) + yyv1443 := &yyv1441[yyj1441] + yyv1443.CodecDecodeSelf(d) } } } } else { - yyj1384 := 0 - for ; !r.CheckBreak(); yyj1384++ { + yyj1441 := 0 + for ; !r.CheckBreak(); yyj1441++ { - if yyj1384 >= len(yyv1384) { - yyv1384 = append(yyv1384, Deployment{}) // var yyz1384 Deployment - yyc1384 = true + if yyj1441 >= len(yyv1441) { + yyv1441 = append(yyv1441, Deployment{}) // var yyz1441 Deployment + yyc1441 = true } - yyh1384.ElemContainerState(yyj1384) - if yyj1384 < len(yyv1384) { + yyh1441.ElemContainerState(yyj1441) + if yyj1441 < len(yyv1441) { if r.TryDecodeAsNil() { - yyv1384[yyj1384] = Deployment{} + yyv1441[yyj1441] = Deployment{} } else { - yyv1387 := &yyv1384[yyj1384] - yyv1387.CodecDecodeSelf(d) + yyv1444 := &yyv1441[yyj1441] + yyv1444.CodecDecodeSelf(d) } } else { @@ -16818,17 +17479,17 @@ func (x codecSelfer1234) decSliceDeployment(v *[]Deployment, d *codec1978.Decode } } - if yyj1384 < len(yyv1384) { - yyv1384 = yyv1384[:yyj1384] - yyc1384 = true - } else if yyj1384 == 0 && yyv1384 == nil { - yyv1384 = []Deployment{} - yyc1384 = true + if yyj1441 < len(yyv1441) { + yyv1441 = yyv1441[:yyj1441] + yyc1441 = true + } else if yyj1441 == 0 && yyv1441 == nil { + yyv1441 = []Deployment{} + yyc1441 = true } } - yyh1384.End() - if yyc1384 { - *v = yyv1384 + yyh1441.End() + if yyc1441 { + *v = yyv1441 } } @@ -16837,10 +17498,10 @@ func (x codecSelfer1234) encSliceDaemonSet(v []DaemonSet, e *codec1978.Encoder) z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1388 := range v { + for _, yyv1445 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1389 := &yyv1388 - yy1389.CodecEncodeSelf(e) + yy1446 := &yyv1445 + yy1446.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16850,83 +17511,83 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1390 := *v - yyh1390, yyl1390 := z.DecSliceHelperStart() - var yyc1390 bool - if yyl1390 == 0 { - if yyv1390 == nil { - yyv1390 = []DaemonSet{} - yyc1390 = true - } else if len(yyv1390) != 0 { - yyv1390 = yyv1390[:0] - yyc1390 = true + yyv1447 := *v + yyh1447, yyl1447 := z.DecSliceHelperStart() + var yyc1447 bool + if yyl1447 == 0 { + if yyv1447 == nil { + yyv1447 = []DaemonSet{} + yyc1447 = true + } else if len(yyv1447) != 0 { + yyv1447 = yyv1447[:0] + yyc1447 = true } - } else if yyl1390 > 0 { - var yyrr1390, yyrl1390 int - var yyrt1390 bool - if yyl1390 > cap(yyv1390) { + } else if yyl1447 > 0 { + var yyrr1447, yyrl1447 int + var yyrt1447 bool + if yyl1447 > cap(yyv1447) { - yyrg1390 := len(yyv1390) > 0 - yyv21390 := yyv1390 - yyrl1390, yyrt1390 = z.DecInferLen(yyl1390, z.DecBasicHandle().MaxInitLen, 728) - if yyrt1390 { - if yyrl1390 <= cap(yyv1390) { - yyv1390 = yyv1390[:yyrl1390] + yyrg1447 := len(yyv1447) > 0 + yyv21447 := yyv1447 + yyrl1447, yyrt1447 = z.DecInferLen(yyl1447, z.DecBasicHandle().MaxInitLen, 728) + if yyrt1447 { + if yyrl1447 <= cap(yyv1447) { + yyv1447 = yyv1447[:yyrl1447] } else { - yyv1390 = make([]DaemonSet, yyrl1390) + yyv1447 = make([]DaemonSet, yyrl1447) } } else { - yyv1390 = make([]DaemonSet, yyrl1390) + yyv1447 = make([]DaemonSet, yyrl1447) } - yyc1390 = true - yyrr1390 = len(yyv1390) - if yyrg1390 { - copy(yyv1390, yyv21390) + yyc1447 = true + yyrr1447 = len(yyv1447) + if yyrg1447 { + copy(yyv1447, yyv21447) } - } else if yyl1390 != len(yyv1390) { - yyv1390 = yyv1390[:yyl1390] - yyc1390 = true + } else if yyl1447 != len(yyv1447) { + yyv1447 = yyv1447[:yyl1447] + yyc1447 = true } - yyj1390 := 0 - for ; yyj1390 < yyrr1390; yyj1390++ { - yyh1390.ElemContainerState(yyj1390) + yyj1447 := 0 + for ; yyj1447 < yyrr1447; yyj1447++ { + yyh1447.ElemContainerState(yyj1447) if r.TryDecodeAsNil() { - yyv1390[yyj1390] = DaemonSet{} + yyv1447[yyj1447] = DaemonSet{} } else { - yyv1391 := &yyv1390[yyj1390] - yyv1391.CodecDecodeSelf(d) + yyv1448 := &yyv1447[yyj1447] + yyv1448.CodecDecodeSelf(d) } } - if yyrt1390 { - for ; yyj1390 < yyl1390; yyj1390++ { - yyv1390 = append(yyv1390, DaemonSet{}) - yyh1390.ElemContainerState(yyj1390) + if yyrt1447 { + for ; yyj1447 < yyl1447; yyj1447++ { + yyv1447 = append(yyv1447, DaemonSet{}) + yyh1447.ElemContainerState(yyj1447) if r.TryDecodeAsNil() { - yyv1390[yyj1390] = DaemonSet{} + yyv1447[yyj1447] = DaemonSet{} } else { - yyv1392 := &yyv1390[yyj1390] - yyv1392.CodecDecodeSelf(d) + yyv1449 := &yyv1447[yyj1447] + yyv1449.CodecDecodeSelf(d) } } } } else { - yyj1390 := 0 - for ; !r.CheckBreak(); yyj1390++ { + yyj1447 := 0 + for ; !r.CheckBreak(); yyj1447++ { - if yyj1390 >= len(yyv1390) { - yyv1390 = append(yyv1390, DaemonSet{}) // var yyz1390 DaemonSet - yyc1390 = true + if yyj1447 >= len(yyv1447) { + yyv1447 = append(yyv1447, DaemonSet{}) // var yyz1447 DaemonSet + yyc1447 = true } - yyh1390.ElemContainerState(yyj1390) - if yyj1390 < len(yyv1390) { + yyh1447.ElemContainerState(yyj1447) + if yyj1447 < len(yyv1447) { if r.TryDecodeAsNil() { - yyv1390[yyj1390] = DaemonSet{} + yyv1447[yyj1447] = DaemonSet{} } else { - yyv1393 := &yyv1390[yyj1390] - yyv1393.CodecDecodeSelf(d) + yyv1450 := &yyv1447[yyj1447] + yyv1450.CodecDecodeSelf(d) } } else { @@ -16934,17 +17595,17 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) } } - if yyj1390 < len(yyv1390) { - yyv1390 = yyv1390[:yyj1390] - yyc1390 = true - } else if yyj1390 == 0 && yyv1390 == nil { - yyv1390 = []DaemonSet{} - yyc1390 = true + if yyj1447 < len(yyv1447) { + yyv1447 = yyv1447[:yyj1447] + yyc1447 = true + } else if yyj1447 == 0 && yyv1447 == nil { + yyv1447 = []DaemonSet{} + yyc1447 = true } } - yyh1390.End() - if yyc1390 { - *v = yyv1390 + yyh1447.End() + if yyc1447 { + *v = yyv1447 } } @@ -16953,10 +17614,10 @@ func (x codecSelfer1234) encSliceThirdPartyResourceData(v []ThirdPartyResourceDa z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1394 := range v { + for _, yyv1451 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1395 := &yyv1394 - yy1395.CodecEncodeSelf(e) + yy1452 := &yyv1451 + yy1452.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16966,83 +17627,83 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1396 := *v - yyh1396, yyl1396 := z.DecSliceHelperStart() - var yyc1396 bool - if yyl1396 == 0 { - if yyv1396 == nil { - yyv1396 = []ThirdPartyResourceData{} - yyc1396 = true - } else if len(yyv1396) != 0 { - yyv1396 = yyv1396[:0] - yyc1396 = true + yyv1453 := *v + yyh1453, yyl1453 := z.DecSliceHelperStart() + var yyc1453 bool + if yyl1453 == 0 { + if yyv1453 == nil { + yyv1453 = []ThirdPartyResourceData{} + yyc1453 = true + } else if len(yyv1453) != 0 { + yyv1453 = yyv1453[:0] + yyc1453 = true } - } else if yyl1396 > 0 { - var yyrr1396, yyrl1396 int - var yyrt1396 bool - if yyl1396 > cap(yyv1396) { + } else if yyl1453 > 0 { + var yyrr1453, yyrl1453 int + var yyrt1453 bool + if yyl1453 > cap(yyv1453) { - yyrg1396 := len(yyv1396) > 0 - yyv21396 := yyv1396 - yyrl1396, yyrt1396 = z.DecInferLen(yyl1396, z.DecBasicHandle().MaxInitLen, 280) - if yyrt1396 { - if yyrl1396 <= cap(yyv1396) { - yyv1396 = yyv1396[:yyrl1396] + yyrg1453 := len(yyv1453) > 0 + yyv21453 := yyv1453 + yyrl1453, yyrt1453 = z.DecInferLen(yyl1453, z.DecBasicHandle().MaxInitLen, 280) + if yyrt1453 { + if yyrl1453 <= cap(yyv1453) { + yyv1453 = yyv1453[:yyrl1453] } else { - yyv1396 = make([]ThirdPartyResourceData, yyrl1396) + yyv1453 = make([]ThirdPartyResourceData, yyrl1453) } } else { - yyv1396 = make([]ThirdPartyResourceData, yyrl1396) + yyv1453 = make([]ThirdPartyResourceData, yyrl1453) } - yyc1396 = true - yyrr1396 = len(yyv1396) - if yyrg1396 { - copy(yyv1396, yyv21396) + yyc1453 = true + yyrr1453 = len(yyv1453) + if yyrg1453 { + copy(yyv1453, yyv21453) } - } else if yyl1396 != len(yyv1396) { - yyv1396 = yyv1396[:yyl1396] - yyc1396 = true + } else if yyl1453 != len(yyv1453) { + yyv1453 = yyv1453[:yyl1453] + yyc1453 = true } - yyj1396 := 0 - for ; yyj1396 < yyrr1396; yyj1396++ { - yyh1396.ElemContainerState(yyj1396) + yyj1453 := 0 + for ; yyj1453 < yyrr1453; yyj1453++ { + yyh1453.ElemContainerState(yyj1453) if r.TryDecodeAsNil() { - yyv1396[yyj1396] = ThirdPartyResourceData{} + yyv1453[yyj1453] = ThirdPartyResourceData{} } else { - yyv1397 := &yyv1396[yyj1396] - yyv1397.CodecDecodeSelf(d) + yyv1454 := &yyv1453[yyj1453] + yyv1454.CodecDecodeSelf(d) } } - if yyrt1396 { - for ; yyj1396 < yyl1396; yyj1396++ { - yyv1396 = append(yyv1396, ThirdPartyResourceData{}) - yyh1396.ElemContainerState(yyj1396) + if yyrt1453 { + for ; yyj1453 < yyl1453; yyj1453++ { + yyv1453 = append(yyv1453, ThirdPartyResourceData{}) + yyh1453.ElemContainerState(yyj1453) if r.TryDecodeAsNil() { - yyv1396[yyj1396] = ThirdPartyResourceData{} + yyv1453[yyj1453] = ThirdPartyResourceData{} } else { - yyv1398 := &yyv1396[yyj1396] - yyv1398.CodecDecodeSelf(d) + yyv1455 := &yyv1453[yyj1453] + yyv1455.CodecDecodeSelf(d) } } } } else { - yyj1396 := 0 - for ; !r.CheckBreak(); yyj1396++ { + yyj1453 := 0 + for ; !r.CheckBreak(); yyj1453++ { - if yyj1396 >= len(yyv1396) { - yyv1396 = append(yyv1396, ThirdPartyResourceData{}) // var yyz1396 ThirdPartyResourceData - yyc1396 = true + if yyj1453 >= len(yyv1453) { + yyv1453 = append(yyv1453, ThirdPartyResourceData{}) // var yyz1453 ThirdPartyResourceData + yyc1453 = true } - yyh1396.ElemContainerState(yyj1396) - if yyj1396 < len(yyv1396) { + yyh1453.ElemContainerState(yyj1453) + if yyj1453 < len(yyv1453) { if r.TryDecodeAsNil() { - yyv1396[yyj1396] = ThirdPartyResourceData{} + yyv1453[yyj1453] = ThirdPartyResourceData{} } else { - yyv1399 := &yyv1396[yyj1396] - yyv1399.CodecDecodeSelf(d) + yyv1456 := &yyv1453[yyj1453] + yyv1456.CodecDecodeSelf(d) } } else { @@ -17050,17 +17711,17 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD } } - if yyj1396 < len(yyv1396) { - yyv1396 = yyv1396[:yyj1396] - yyc1396 = true - } else if yyj1396 == 0 && yyv1396 == nil { - yyv1396 = []ThirdPartyResourceData{} - yyc1396 = true + if yyj1453 < len(yyv1453) { + yyv1453 = yyv1453[:yyj1453] + yyc1453 = true + } else if yyj1453 == 0 && yyv1453 == nil { + yyv1453 = []ThirdPartyResourceData{} + yyc1453 = true } } - yyh1396.End() - if yyc1396 { - *v = yyv1396 + yyh1453.End() + if yyc1453 { + *v = yyv1453 } } @@ -17069,10 +17730,10 @@ func (x codecSelfer1234) encSliceIngress(v []Ingress, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1400 := range v { + for _, yyv1457 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1401 := &yyv1400 - yy1401.CodecEncodeSelf(e) + yy1458 := &yyv1457 + yy1458.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17082,83 +17743,83 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1402 := *v - yyh1402, yyl1402 := z.DecSliceHelperStart() - var yyc1402 bool - if yyl1402 == 0 { - if yyv1402 == nil { - yyv1402 = []Ingress{} - yyc1402 = true - } else if len(yyv1402) != 0 { - yyv1402 = yyv1402[:0] - yyc1402 = true + yyv1459 := *v + yyh1459, yyl1459 := z.DecSliceHelperStart() + var yyc1459 bool + if yyl1459 == 0 { + if yyv1459 == nil { + yyv1459 = []Ingress{} + yyc1459 = true + } else if len(yyv1459) != 0 { + yyv1459 = yyv1459[:0] + yyc1459 = true } - } else if yyl1402 > 0 { - var yyrr1402, yyrl1402 int - var yyrt1402 bool - if yyl1402 > cap(yyv1402) { + } else if yyl1459 > 0 { + var yyrr1459, yyrl1459 int + var yyrt1459 bool + if yyl1459 > cap(yyv1459) { - yyrg1402 := len(yyv1402) > 0 - yyv21402 := yyv1402 - yyrl1402, yyrt1402 = z.DecInferLen(yyl1402, z.DecBasicHandle().MaxInitLen, 336) - if yyrt1402 { - if yyrl1402 <= cap(yyv1402) { - yyv1402 = yyv1402[:yyrl1402] + yyrg1459 := len(yyv1459) > 0 + yyv21459 := yyv1459 + yyrl1459, yyrt1459 = z.DecInferLen(yyl1459, z.DecBasicHandle().MaxInitLen, 336) + if yyrt1459 { + if yyrl1459 <= cap(yyv1459) { + yyv1459 = yyv1459[:yyrl1459] } else { - yyv1402 = make([]Ingress, yyrl1402) + yyv1459 = make([]Ingress, yyrl1459) } } else { - yyv1402 = make([]Ingress, yyrl1402) + yyv1459 = make([]Ingress, yyrl1459) } - yyc1402 = true - yyrr1402 = len(yyv1402) - if yyrg1402 { - copy(yyv1402, yyv21402) + yyc1459 = true + yyrr1459 = len(yyv1459) + if yyrg1459 { + copy(yyv1459, yyv21459) } - } else if yyl1402 != len(yyv1402) { - yyv1402 = yyv1402[:yyl1402] - yyc1402 = true + } else if yyl1459 != len(yyv1459) { + yyv1459 = yyv1459[:yyl1459] + yyc1459 = true } - yyj1402 := 0 - for ; yyj1402 < yyrr1402; yyj1402++ { - yyh1402.ElemContainerState(yyj1402) + yyj1459 := 0 + for ; yyj1459 < yyrr1459; yyj1459++ { + yyh1459.ElemContainerState(yyj1459) if r.TryDecodeAsNil() { - yyv1402[yyj1402] = Ingress{} + yyv1459[yyj1459] = Ingress{} } else { - yyv1403 := &yyv1402[yyj1402] - yyv1403.CodecDecodeSelf(d) + yyv1460 := &yyv1459[yyj1459] + yyv1460.CodecDecodeSelf(d) } } - if yyrt1402 { - for ; yyj1402 < yyl1402; yyj1402++ { - yyv1402 = append(yyv1402, Ingress{}) - yyh1402.ElemContainerState(yyj1402) + if yyrt1459 { + for ; yyj1459 < yyl1459; yyj1459++ { + yyv1459 = append(yyv1459, Ingress{}) + yyh1459.ElemContainerState(yyj1459) if r.TryDecodeAsNil() { - yyv1402[yyj1402] = Ingress{} + yyv1459[yyj1459] = Ingress{} } else { - yyv1404 := &yyv1402[yyj1402] - yyv1404.CodecDecodeSelf(d) + yyv1461 := &yyv1459[yyj1459] + yyv1461.CodecDecodeSelf(d) } } } } else { - yyj1402 := 0 - for ; !r.CheckBreak(); yyj1402++ { + yyj1459 := 0 + for ; !r.CheckBreak(); yyj1459++ { - if yyj1402 >= len(yyv1402) { - yyv1402 = append(yyv1402, Ingress{}) // var yyz1402 Ingress - yyc1402 = true + if yyj1459 >= len(yyv1459) { + yyv1459 = append(yyv1459, Ingress{}) // var yyz1459 Ingress + yyc1459 = true } - yyh1402.ElemContainerState(yyj1402) - if yyj1402 < len(yyv1402) { + yyh1459.ElemContainerState(yyj1459) + if yyj1459 < len(yyv1459) { if r.TryDecodeAsNil() { - yyv1402[yyj1402] = Ingress{} + yyv1459[yyj1459] = Ingress{} } else { - yyv1405 := &yyv1402[yyj1402] - yyv1405.CodecDecodeSelf(d) + yyv1462 := &yyv1459[yyj1459] + yyv1462.CodecDecodeSelf(d) } } else { @@ -17166,17 +17827,17 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { } } - if yyj1402 < len(yyv1402) { - yyv1402 = yyv1402[:yyj1402] - yyc1402 = true - } else if yyj1402 == 0 && yyv1402 == nil { - yyv1402 = []Ingress{} - yyc1402 = true + if yyj1459 < len(yyv1459) { + yyv1459 = yyv1459[:yyj1459] + yyc1459 = true + } else if yyj1459 == 0 && yyv1459 == nil { + yyv1459 = []Ingress{} + yyc1459 = true } } - yyh1402.End() - if yyc1402 { - *v = yyv1402 + yyh1459.End() + if yyc1459 { + *v = yyv1459 } } @@ -17185,10 +17846,10 @@ func (x codecSelfer1234) encSliceIngressTLS(v []IngressTLS, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1406 := range v { + for _, yyv1463 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1407 := &yyv1406 - yy1407.CodecEncodeSelf(e) + yy1464 := &yyv1463 + yy1464.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17198,83 +17859,83 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1408 := *v - yyh1408, yyl1408 := z.DecSliceHelperStart() - var yyc1408 bool - if yyl1408 == 0 { - if yyv1408 == nil { - yyv1408 = []IngressTLS{} - yyc1408 = true - } else if len(yyv1408) != 0 { - yyv1408 = yyv1408[:0] - yyc1408 = true + yyv1465 := *v + yyh1465, yyl1465 := z.DecSliceHelperStart() + var yyc1465 bool + if yyl1465 == 0 { + if yyv1465 == nil { + yyv1465 = []IngressTLS{} + yyc1465 = true + } else if len(yyv1465) != 0 { + yyv1465 = yyv1465[:0] + yyc1465 = true } - } else if yyl1408 > 0 { - var yyrr1408, yyrl1408 int - var yyrt1408 bool - if yyl1408 > cap(yyv1408) { + } else if yyl1465 > 0 { + var yyrr1465, yyrl1465 int + var yyrt1465 bool + if yyl1465 > cap(yyv1465) { - yyrg1408 := len(yyv1408) > 0 - yyv21408 := yyv1408 - yyrl1408, yyrt1408 = z.DecInferLen(yyl1408, z.DecBasicHandle().MaxInitLen, 40) - if yyrt1408 { - if yyrl1408 <= cap(yyv1408) { - yyv1408 = yyv1408[:yyrl1408] + yyrg1465 := len(yyv1465) > 0 + yyv21465 := yyv1465 + yyrl1465, yyrt1465 = z.DecInferLen(yyl1465, z.DecBasicHandle().MaxInitLen, 40) + if yyrt1465 { + if yyrl1465 <= cap(yyv1465) { + yyv1465 = yyv1465[:yyrl1465] } else { - yyv1408 = make([]IngressTLS, yyrl1408) + yyv1465 = make([]IngressTLS, yyrl1465) } } else { - yyv1408 = make([]IngressTLS, yyrl1408) + yyv1465 = make([]IngressTLS, yyrl1465) } - yyc1408 = true - yyrr1408 = len(yyv1408) - if yyrg1408 { - copy(yyv1408, yyv21408) + yyc1465 = true + yyrr1465 = len(yyv1465) + if yyrg1465 { + copy(yyv1465, yyv21465) } - } else if yyl1408 != len(yyv1408) { - yyv1408 = yyv1408[:yyl1408] - yyc1408 = true + } else if yyl1465 != len(yyv1465) { + yyv1465 = yyv1465[:yyl1465] + yyc1465 = true } - yyj1408 := 0 - for ; yyj1408 < yyrr1408; yyj1408++ { - yyh1408.ElemContainerState(yyj1408) + yyj1465 := 0 + for ; yyj1465 < yyrr1465; yyj1465++ { + yyh1465.ElemContainerState(yyj1465) if r.TryDecodeAsNil() { - yyv1408[yyj1408] = IngressTLS{} + yyv1465[yyj1465] = IngressTLS{} } else { - yyv1409 := &yyv1408[yyj1408] - yyv1409.CodecDecodeSelf(d) + yyv1466 := &yyv1465[yyj1465] + yyv1466.CodecDecodeSelf(d) } } - if yyrt1408 { - for ; yyj1408 < yyl1408; yyj1408++ { - yyv1408 = append(yyv1408, IngressTLS{}) - yyh1408.ElemContainerState(yyj1408) + if yyrt1465 { + for ; yyj1465 < yyl1465; yyj1465++ { + yyv1465 = append(yyv1465, IngressTLS{}) + yyh1465.ElemContainerState(yyj1465) if r.TryDecodeAsNil() { - yyv1408[yyj1408] = IngressTLS{} + yyv1465[yyj1465] = IngressTLS{} } else { - yyv1410 := &yyv1408[yyj1408] - yyv1410.CodecDecodeSelf(d) + yyv1467 := &yyv1465[yyj1465] + yyv1467.CodecDecodeSelf(d) } } } } else { - yyj1408 := 0 - for ; !r.CheckBreak(); yyj1408++ { + yyj1465 := 0 + for ; !r.CheckBreak(); yyj1465++ { - if yyj1408 >= len(yyv1408) { - yyv1408 = append(yyv1408, IngressTLS{}) // var yyz1408 IngressTLS - yyc1408 = true + if yyj1465 >= len(yyv1465) { + yyv1465 = append(yyv1465, IngressTLS{}) // var yyz1465 IngressTLS + yyc1465 = true } - yyh1408.ElemContainerState(yyj1408) - if yyj1408 < len(yyv1408) { + yyh1465.ElemContainerState(yyj1465) + if yyj1465 < len(yyv1465) { if r.TryDecodeAsNil() { - yyv1408[yyj1408] = IngressTLS{} + yyv1465[yyj1465] = IngressTLS{} } else { - yyv1411 := &yyv1408[yyj1408] - yyv1411.CodecDecodeSelf(d) + yyv1468 := &yyv1465[yyj1465] + yyv1468.CodecDecodeSelf(d) } } else { @@ -17282,17 +17943,17 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode } } - if yyj1408 < len(yyv1408) { - yyv1408 = yyv1408[:yyj1408] - yyc1408 = true - } else if yyj1408 == 0 && yyv1408 == nil { - yyv1408 = []IngressTLS{} - yyc1408 = true + if yyj1465 < len(yyv1465) { + yyv1465 = yyv1465[:yyj1465] + yyc1465 = true + } else if yyj1465 == 0 && yyv1465 == nil { + yyv1465 = []IngressTLS{} + yyc1465 = true } } - yyh1408.End() - if yyc1408 { - *v = yyv1408 + yyh1465.End() + if yyc1465 { + *v = yyv1465 } } @@ -17301,10 +17962,10 @@ func (x codecSelfer1234) encSliceIngressRule(v []IngressRule, e *codec1978.Encod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1412 := range v { + for _, yyv1469 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1413 := &yyv1412 - yy1413.CodecEncodeSelf(e) + yy1470 := &yyv1469 + yy1470.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17314,83 +17975,83 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1414 := *v - yyh1414, yyl1414 := z.DecSliceHelperStart() - var yyc1414 bool - if yyl1414 == 0 { - if yyv1414 == nil { - yyv1414 = []IngressRule{} - yyc1414 = true - } else if len(yyv1414) != 0 { - yyv1414 = yyv1414[:0] - yyc1414 = true + yyv1471 := *v + yyh1471, yyl1471 := z.DecSliceHelperStart() + var yyc1471 bool + if yyl1471 == 0 { + if yyv1471 == nil { + yyv1471 = []IngressRule{} + yyc1471 = true + } else if len(yyv1471) != 0 { + yyv1471 = yyv1471[:0] + yyc1471 = true } - } else if yyl1414 > 0 { - var yyrr1414, yyrl1414 int - var yyrt1414 bool - if yyl1414 > cap(yyv1414) { + } else if yyl1471 > 0 { + var yyrr1471, yyrl1471 int + var yyrt1471 bool + if yyl1471 > cap(yyv1471) { - yyrg1414 := len(yyv1414) > 0 - yyv21414 := yyv1414 - yyrl1414, yyrt1414 = z.DecInferLen(yyl1414, z.DecBasicHandle().MaxInitLen, 24) - if yyrt1414 { - if yyrl1414 <= cap(yyv1414) { - yyv1414 = yyv1414[:yyrl1414] + yyrg1471 := len(yyv1471) > 0 + yyv21471 := yyv1471 + yyrl1471, yyrt1471 = z.DecInferLen(yyl1471, z.DecBasicHandle().MaxInitLen, 24) + if yyrt1471 { + if yyrl1471 <= cap(yyv1471) { + yyv1471 = yyv1471[:yyrl1471] } else { - yyv1414 = make([]IngressRule, yyrl1414) + yyv1471 = make([]IngressRule, yyrl1471) } } else { - yyv1414 = make([]IngressRule, yyrl1414) + yyv1471 = make([]IngressRule, yyrl1471) } - yyc1414 = true - yyrr1414 = len(yyv1414) - if yyrg1414 { - copy(yyv1414, yyv21414) + yyc1471 = true + yyrr1471 = len(yyv1471) + if yyrg1471 { + copy(yyv1471, yyv21471) } - } else if yyl1414 != len(yyv1414) { - yyv1414 = yyv1414[:yyl1414] - yyc1414 = true + } else if yyl1471 != len(yyv1471) { + yyv1471 = yyv1471[:yyl1471] + yyc1471 = true } - yyj1414 := 0 - for ; yyj1414 < yyrr1414; yyj1414++ { - yyh1414.ElemContainerState(yyj1414) + yyj1471 := 0 + for ; yyj1471 < yyrr1471; yyj1471++ { + yyh1471.ElemContainerState(yyj1471) if r.TryDecodeAsNil() { - yyv1414[yyj1414] = IngressRule{} + yyv1471[yyj1471] = IngressRule{} } else { - yyv1415 := &yyv1414[yyj1414] - yyv1415.CodecDecodeSelf(d) + yyv1472 := &yyv1471[yyj1471] + yyv1472.CodecDecodeSelf(d) } } - if yyrt1414 { - for ; yyj1414 < yyl1414; yyj1414++ { - yyv1414 = append(yyv1414, IngressRule{}) - yyh1414.ElemContainerState(yyj1414) + if yyrt1471 { + for ; yyj1471 < yyl1471; yyj1471++ { + yyv1471 = append(yyv1471, IngressRule{}) + yyh1471.ElemContainerState(yyj1471) if r.TryDecodeAsNil() { - yyv1414[yyj1414] = IngressRule{} + yyv1471[yyj1471] = IngressRule{} } else { - yyv1416 := &yyv1414[yyj1414] - yyv1416.CodecDecodeSelf(d) + yyv1473 := &yyv1471[yyj1471] + yyv1473.CodecDecodeSelf(d) } } } } else { - yyj1414 := 0 - for ; !r.CheckBreak(); yyj1414++ { + yyj1471 := 0 + for ; !r.CheckBreak(); yyj1471++ { - if yyj1414 >= len(yyv1414) { - yyv1414 = append(yyv1414, IngressRule{}) // var yyz1414 IngressRule - yyc1414 = true + if yyj1471 >= len(yyv1471) { + yyv1471 = append(yyv1471, IngressRule{}) // var yyz1471 IngressRule + yyc1471 = true } - yyh1414.ElemContainerState(yyj1414) - if yyj1414 < len(yyv1414) { + yyh1471.ElemContainerState(yyj1471) + if yyj1471 < len(yyv1471) { if r.TryDecodeAsNil() { - yyv1414[yyj1414] = IngressRule{} + yyv1471[yyj1471] = IngressRule{} } else { - yyv1417 := &yyv1414[yyj1414] - yyv1417.CodecDecodeSelf(d) + yyv1474 := &yyv1471[yyj1471] + yyv1474.CodecDecodeSelf(d) } } else { @@ -17398,17 +18059,17 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco } } - if yyj1414 < len(yyv1414) { - yyv1414 = yyv1414[:yyj1414] - yyc1414 = true - } else if yyj1414 == 0 && yyv1414 == nil { - yyv1414 = []IngressRule{} - yyc1414 = true + if yyj1471 < len(yyv1471) { + yyv1471 = yyv1471[:yyj1471] + yyc1471 = true + } else if yyj1471 == 0 && yyv1471 == nil { + yyv1471 = []IngressRule{} + yyc1471 = true } } - yyh1414.End() - if yyc1414 { - *v = yyv1414 + yyh1471.End() + if yyc1471 { + *v = yyv1471 } } @@ -17417,10 +18078,10 @@ func (x codecSelfer1234) encSliceHTTPIngressPath(v []HTTPIngressPath, e *codec19 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1418 := range v { + for _, yyv1475 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1419 := &yyv1418 - yy1419.CodecEncodeSelf(e) + yy1476 := &yyv1475 + yy1476.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17430,83 +18091,83 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1420 := *v - yyh1420, yyl1420 := z.DecSliceHelperStart() - var yyc1420 bool - if yyl1420 == 0 { - if yyv1420 == nil { - yyv1420 = []HTTPIngressPath{} - yyc1420 = true - } else if len(yyv1420) != 0 { - yyv1420 = yyv1420[:0] - yyc1420 = true + yyv1477 := *v + yyh1477, yyl1477 := z.DecSliceHelperStart() + var yyc1477 bool + if yyl1477 == 0 { + if yyv1477 == nil { + yyv1477 = []HTTPIngressPath{} + yyc1477 = true + } else if len(yyv1477) != 0 { + yyv1477 = yyv1477[:0] + yyc1477 = true } - } else if yyl1420 > 0 { - var yyrr1420, yyrl1420 int - var yyrt1420 bool - if yyl1420 > cap(yyv1420) { + } else if yyl1477 > 0 { + var yyrr1477, yyrl1477 int + var yyrt1477 bool + if yyl1477 > cap(yyv1477) { - yyrg1420 := len(yyv1420) > 0 - yyv21420 := yyv1420 - yyrl1420, yyrt1420 = z.DecInferLen(yyl1420, z.DecBasicHandle().MaxInitLen, 64) - if yyrt1420 { - if yyrl1420 <= cap(yyv1420) { - yyv1420 = yyv1420[:yyrl1420] + yyrg1477 := len(yyv1477) > 0 + yyv21477 := yyv1477 + yyrl1477, yyrt1477 = z.DecInferLen(yyl1477, z.DecBasicHandle().MaxInitLen, 64) + if yyrt1477 { + if yyrl1477 <= cap(yyv1477) { + yyv1477 = yyv1477[:yyrl1477] } else { - yyv1420 = make([]HTTPIngressPath, yyrl1420) + yyv1477 = make([]HTTPIngressPath, yyrl1477) } } else { - yyv1420 = make([]HTTPIngressPath, yyrl1420) + yyv1477 = make([]HTTPIngressPath, yyrl1477) } - yyc1420 = true - yyrr1420 = len(yyv1420) - if yyrg1420 { - copy(yyv1420, yyv21420) + yyc1477 = true + yyrr1477 = len(yyv1477) + if yyrg1477 { + copy(yyv1477, yyv21477) } - } else if yyl1420 != len(yyv1420) { - yyv1420 = yyv1420[:yyl1420] - yyc1420 = true + } else if yyl1477 != len(yyv1477) { + yyv1477 = yyv1477[:yyl1477] + yyc1477 = true } - yyj1420 := 0 - for ; yyj1420 < yyrr1420; yyj1420++ { - yyh1420.ElemContainerState(yyj1420) + yyj1477 := 0 + for ; yyj1477 < yyrr1477; yyj1477++ { + yyh1477.ElemContainerState(yyj1477) if r.TryDecodeAsNil() { - yyv1420[yyj1420] = HTTPIngressPath{} + yyv1477[yyj1477] = HTTPIngressPath{} } else { - yyv1421 := &yyv1420[yyj1420] - yyv1421.CodecDecodeSelf(d) + yyv1478 := &yyv1477[yyj1477] + yyv1478.CodecDecodeSelf(d) } } - if yyrt1420 { - for ; yyj1420 < yyl1420; yyj1420++ { - yyv1420 = append(yyv1420, HTTPIngressPath{}) - yyh1420.ElemContainerState(yyj1420) + if yyrt1477 { + for ; yyj1477 < yyl1477; yyj1477++ { + yyv1477 = append(yyv1477, HTTPIngressPath{}) + yyh1477.ElemContainerState(yyj1477) if r.TryDecodeAsNil() { - yyv1420[yyj1420] = HTTPIngressPath{} + yyv1477[yyj1477] = HTTPIngressPath{} } else { - yyv1422 := &yyv1420[yyj1420] - yyv1422.CodecDecodeSelf(d) + yyv1479 := &yyv1477[yyj1477] + yyv1479.CodecDecodeSelf(d) } } } } else { - yyj1420 := 0 - for ; !r.CheckBreak(); yyj1420++ { + yyj1477 := 0 + for ; !r.CheckBreak(); yyj1477++ { - if yyj1420 >= len(yyv1420) { - yyv1420 = append(yyv1420, HTTPIngressPath{}) // var yyz1420 HTTPIngressPath - yyc1420 = true + if yyj1477 >= len(yyv1477) { + yyv1477 = append(yyv1477, HTTPIngressPath{}) // var yyz1477 HTTPIngressPath + yyc1477 = true } - yyh1420.ElemContainerState(yyj1420) - if yyj1420 < len(yyv1420) { + yyh1477.ElemContainerState(yyj1477) + if yyj1477 < len(yyv1477) { if r.TryDecodeAsNil() { - yyv1420[yyj1420] = HTTPIngressPath{} + yyv1477[yyj1477] = HTTPIngressPath{} } else { - yyv1423 := &yyv1420[yyj1420] - yyv1423.CodecDecodeSelf(d) + yyv1480 := &yyv1477[yyj1477] + yyv1480.CodecDecodeSelf(d) } } else { @@ -17514,17 +18175,17 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 } } - if yyj1420 < len(yyv1420) { - yyv1420 = yyv1420[:yyj1420] - yyc1420 = true - } else if yyj1420 == 0 && yyv1420 == nil { - yyv1420 = []HTTPIngressPath{} - yyc1420 = true + if yyj1477 < len(yyv1477) { + yyv1477 = yyv1477[:yyj1477] + yyc1477 = true + } else if yyj1477 == 0 && yyv1477 == nil { + yyv1477 = []HTTPIngressPath{} + yyc1477 = true } } - yyh1420.End() - if yyc1420 { - *v = yyv1420 + yyh1477.End() + if yyc1477 { + *v = yyv1477 } } @@ -17533,10 +18194,10 @@ func (x codecSelfer1234) encSliceReplicaSet(v []ReplicaSet, e *codec1978.Encoder z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1424 := range v { + for _, yyv1481 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1425 := &yyv1424 - yy1425.CodecEncodeSelf(e) + yy1482 := &yyv1481 + yy1482.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17546,83 +18207,83 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1426 := *v - yyh1426, yyl1426 := z.DecSliceHelperStart() - var yyc1426 bool - if yyl1426 == 0 { - if yyv1426 == nil { - yyv1426 = []ReplicaSet{} - yyc1426 = true - } else if len(yyv1426) != 0 { - yyv1426 = yyv1426[:0] - yyc1426 = true + yyv1483 := *v + yyh1483, yyl1483 := z.DecSliceHelperStart() + var yyc1483 bool + if yyl1483 == 0 { + if yyv1483 == nil { + yyv1483 = []ReplicaSet{} + yyc1483 = true + } else if len(yyv1483) != 0 { + yyv1483 = yyv1483[:0] + yyc1483 = true } - } else if yyl1426 > 0 { - var yyrr1426, yyrl1426 int - var yyrt1426 bool - if yyl1426 > cap(yyv1426) { + } else if yyl1483 > 0 { + var yyrr1483, yyrl1483 int + var yyrt1483 bool + if yyl1483 > cap(yyv1483) { - yyrg1426 := len(yyv1426) > 0 - yyv21426 := yyv1426 - yyrl1426, yyrt1426 = z.DecInferLen(yyl1426, z.DecBasicHandle().MaxInitLen, 768) - if yyrt1426 { - if yyrl1426 <= cap(yyv1426) { - yyv1426 = yyv1426[:yyrl1426] + yyrg1483 := len(yyv1483) > 0 + yyv21483 := yyv1483 + yyrl1483, yyrt1483 = z.DecInferLen(yyl1483, z.DecBasicHandle().MaxInitLen, 768) + if yyrt1483 { + if yyrl1483 <= cap(yyv1483) { + yyv1483 = yyv1483[:yyrl1483] } else { - yyv1426 = make([]ReplicaSet, yyrl1426) + yyv1483 = make([]ReplicaSet, yyrl1483) } } else { - yyv1426 = make([]ReplicaSet, yyrl1426) + yyv1483 = make([]ReplicaSet, yyrl1483) } - yyc1426 = true - yyrr1426 = len(yyv1426) - if yyrg1426 { - copy(yyv1426, yyv21426) + yyc1483 = true + yyrr1483 = len(yyv1483) + if yyrg1483 { + copy(yyv1483, yyv21483) } - } else if yyl1426 != len(yyv1426) { - yyv1426 = yyv1426[:yyl1426] - yyc1426 = true + } else if yyl1483 != len(yyv1483) { + yyv1483 = yyv1483[:yyl1483] + yyc1483 = true } - yyj1426 := 0 - for ; yyj1426 < yyrr1426; yyj1426++ { - yyh1426.ElemContainerState(yyj1426) + yyj1483 := 0 + for ; yyj1483 < yyrr1483; yyj1483++ { + yyh1483.ElemContainerState(yyj1483) if r.TryDecodeAsNil() { - yyv1426[yyj1426] = ReplicaSet{} + yyv1483[yyj1483] = ReplicaSet{} } else { - yyv1427 := &yyv1426[yyj1426] - yyv1427.CodecDecodeSelf(d) + yyv1484 := &yyv1483[yyj1483] + yyv1484.CodecDecodeSelf(d) } } - if yyrt1426 { - for ; yyj1426 < yyl1426; yyj1426++ { - yyv1426 = append(yyv1426, ReplicaSet{}) - yyh1426.ElemContainerState(yyj1426) + if yyrt1483 { + for ; yyj1483 < yyl1483; yyj1483++ { + yyv1483 = append(yyv1483, ReplicaSet{}) + yyh1483.ElemContainerState(yyj1483) if r.TryDecodeAsNil() { - yyv1426[yyj1426] = ReplicaSet{} + yyv1483[yyj1483] = ReplicaSet{} } else { - yyv1428 := &yyv1426[yyj1426] - yyv1428.CodecDecodeSelf(d) + yyv1485 := &yyv1483[yyj1483] + yyv1485.CodecDecodeSelf(d) } } } } else { - yyj1426 := 0 - for ; !r.CheckBreak(); yyj1426++ { + yyj1483 := 0 + for ; !r.CheckBreak(); yyj1483++ { - if yyj1426 >= len(yyv1426) { - yyv1426 = append(yyv1426, ReplicaSet{}) // var yyz1426 ReplicaSet - yyc1426 = true + if yyj1483 >= len(yyv1483) { + yyv1483 = append(yyv1483, ReplicaSet{}) // var yyz1483 ReplicaSet + yyc1483 = true } - yyh1426.ElemContainerState(yyj1426) - if yyj1426 < len(yyv1426) { + yyh1483.ElemContainerState(yyj1483) + if yyj1483 < len(yyv1483) { if r.TryDecodeAsNil() { - yyv1426[yyj1426] = ReplicaSet{} + yyv1483[yyj1483] = ReplicaSet{} } else { - yyv1429 := &yyv1426[yyj1426] - yyv1429.CodecDecodeSelf(d) + yyv1486 := &yyv1483[yyj1483] + yyv1486.CodecDecodeSelf(d) } } else { @@ -17630,17 +18291,17 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode } } - if yyj1426 < len(yyv1426) { - yyv1426 = yyv1426[:yyj1426] - yyc1426 = true - } else if yyj1426 == 0 && yyv1426 == nil { - yyv1426 = []ReplicaSet{} - yyc1426 = true + if yyj1483 < len(yyv1483) { + yyv1483 = yyv1483[:yyj1483] + yyc1483 = true + } else if yyj1483 == 0 && yyv1483 == nil { + yyv1483 = []ReplicaSet{} + yyc1483 = true } } - yyh1426.End() - if yyc1426 { - *v = yyv1426 + yyh1483.End() + if yyc1483 { + *v = yyv1483 } } @@ -17649,10 +18310,10 @@ func (x codecSelfer1234) encSliceReplicaSetCondition(v []ReplicaSetCondition, e z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1430 := range v { + for _, yyv1487 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1431 := &yyv1430 - yy1431.CodecEncodeSelf(e) + yy1488 := &yyv1487 + yy1488.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17662,83 +18323,83 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1432 := *v - yyh1432, yyl1432 := z.DecSliceHelperStart() - var yyc1432 bool - if yyl1432 == 0 { - if yyv1432 == nil { - yyv1432 = []ReplicaSetCondition{} - yyc1432 = true - } else if len(yyv1432) != 0 { - yyv1432 = yyv1432[:0] - yyc1432 = true + yyv1489 := *v + yyh1489, yyl1489 := z.DecSliceHelperStart() + var yyc1489 bool + if yyl1489 == 0 { + if yyv1489 == nil { + yyv1489 = []ReplicaSetCondition{} + yyc1489 = true + } else if len(yyv1489) != 0 { + yyv1489 = yyv1489[:0] + yyc1489 = true } - } else if yyl1432 > 0 { - var yyrr1432, yyrl1432 int - var yyrt1432 bool - if yyl1432 > cap(yyv1432) { + } else if yyl1489 > 0 { + var yyrr1489, yyrl1489 int + var yyrt1489 bool + if yyl1489 > cap(yyv1489) { - yyrg1432 := len(yyv1432) > 0 - yyv21432 := yyv1432 - yyrl1432, yyrt1432 = z.DecInferLen(yyl1432, z.DecBasicHandle().MaxInitLen, 112) - if yyrt1432 { - if yyrl1432 <= cap(yyv1432) { - yyv1432 = yyv1432[:yyrl1432] + yyrg1489 := len(yyv1489) > 0 + yyv21489 := yyv1489 + yyrl1489, yyrt1489 = z.DecInferLen(yyl1489, z.DecBasicHandle().MaxInitLen, 88) + if yyrt1489 { + if yyrl1489 <= cap(yyv1489) { + yyv1489 = yyv1489[:yyrl1489] } else { - yyv1432 = make([]ReplicaSetCondition, yyrl1432) + yyv1489 = make([]ReplicaSetCondition, yyrl1489) } } else { - yyv1432 = make([]ReplicaSetCondition, yyrl1432) + yyv1489 = make([]ReplicaSetCondition, yyrl1489) } - yyc1432 = true - yyrr1432 = len(yyv1432) - if yyrg1432 { - copy(yyv1432, yyv21432) + yyc1489 = true + yyrr1489 = len(yyv1489) + if yyrg1489 { + copy(yyv1489, yyv21489) } - } else if yyl1432 != len(yyv1432) { - yyv1432 = yyv1432[:yyl1432] - yyc1432 = true + } else if yyl1489 != len(yyv1489) { + yyv1489 = yyv1489[:yyl1489] + yyc1489 = true } - yyj1432 := 0 - for ; yyj1432 < yyrr1432; yyj1432++ { - yyh1432.ElemContainerState(yyj1432) + yyj1489 := 0 + for ; yyj1489 < yyrr1489; yyj1489++ { + yyh1489.ElemContainerState(yyj1489) if r.TryDecodeAsNil() { - yyv1432[yyj1432] = ReplicaSetCondition{} + yyv1489[yyj1489] = ReplicaSetCondition{} } else { - yyv1433 := &yyv1432[yyj1432] - yyv1433.CodecDecodeSelf(d) + yyv1490 := &yyv1489[yyj1489] + yyv1490.CodecDecodeSelf(d) } } - if yyrt1432 { - for ; yyj1432 < yyl1432; yyj1432++ { - yyv1432 = append(yyv1432, ReplicaSetCondition{}) - yyh1432.ElemContainerState(yyj1432) + if yyrt1489 { + for ; yyj1489 < yyl1489; yyj1489++ { + yyv1489 = append(yyv1489, ReplicaSetCondition{}) + yyh1489.ElemContainerState(yyj1489) if r.TryDecodeAsNil() { - yyv1432[yyj1432] = ReplicaSetCondition{} + yyv1489[yyj1489] = ReplicaSetCondition{} } else { - yyv1434 := &yyv1432[yyj1432] - yyv1434.CodecDecodeSelf(d) + yyv1491 := &yyv1489[yyj1489] + yyv1491.CodecDecodeSelf(d) } } } } else { - yyj1432 := 0 - for ; !r.CheckBreak(); yyj1432++ { + yyj1489 := 0 + for ; !r.CheckBreak(); yyj1489++ { - if yyj1432 >= len(yyv1432) { - yyv1432 = append(yyv1432, ReplicaSetCondition{}) // var yyz1432 ReplicaSetCondition - yyc1432 = true + if yyj1489 >= len(yyv1489) { + yyv1489 = append(yyv1489, ReplicaSetCondition{}) // var yyz1489 ReplicaSetCondition + yyc1489 = true } - yyh1432.ElemContainerState(yyj1432) - if yyj1432 < len(yyv1432) { + yyh1489.ElemContainerState(yyj1489) + if yyj1489 < len(yyv1489) { if r.TryDecodeAsNil() { - yyv1432[yyj1432] = ReplicaSetCondition{} + yyv1489[yyj1489] = ReplicaSetCondition{} } else { - yyv1435 := &yyv1432[yyj1432] - yyv1435.CodecDecodeSelf(d) + yyv1492 := &yyv1489[yyj1489] + yyv1492.CodecDecodeSelf(d) } } else { @@ -17746,17 +18407,17 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d } } - if yyj1432 < len(yyv1432) { - yyv1432 = yyv1432[:yyj1432] - yyc1432 = true - } else if yyj1432 == 0 && yyv1432 == nil { - yyv1432 = []ReplicaSetCondition{} - yyc1432 = true + if yyj1489 < len(yyv1489) { + yyv1489 = yyv1489[:yyj1489] + yyc1489 = true + } else if yyj1489 == 0 && yyv1489 == nil { + yyv1489 = []ReplicaSetCondition{} + yyc1489 = true } } - yyh1432.End() - if yyc1432 { - *v = yyv1432 + yyh1489.End() + if yyc1489 { + *v = yyv1489 } } @@ -17765,14 +18426,14 @@ func (x codecSelfer1234) encSliceapi_Capability(v []pkg2_api.Capability, e *code z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1436 := range v { + for _, yyv1493 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1437 := z.EncBinary() - _ = yym1437 + yym1494 := z.EncBinary() + _ = yym1494 if false { - } else if z.HasExtensions() && z.EncExt(yyv1436) { + } else if z.HasExtensions() && z.EncExt(yyv1493) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yyv1436)) + r.EncodeString(codecSelferC_UTF81234, string(yyv1493)) } } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) @@ -17783,75 +18444,75 @@ func (x codecSelfer1234) decSliceapi_Capability(v *[]pkg2_api.Capability, d *cod z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1438 := *v - yyh1438, yyl1438 := z.DecSliceHelperStart() - var yyc1438 bool - if yyl1438 == 0 { - if yyv1438 == nil { - yyv1438 = []pkg2_api.Capability{} - yyc1438 = true - } else if len(yyv1438) != 0 { - yyv1438 = yyv1438[:0] - yyc1438 = true + yyv1495 := *v + yyh1495, yyl1495 := z.DecSliceHelperStart() + var yyc1495 bool + if yyl1495 == 0 { + if yyv1495 == nil { + yyv1495 = []pkg2_api.Capability{} + yyc1495 = true + } else if len(yyv1495) != 0 { + yyv1495 = yyv1495[:0] + yyc1495 = true } - } else if yyl1438 > 0 { - var yyrr1438, yyrl1438 int - var yyrt1438 bool - if yyl1438 > cap(yyv1438) { + } else if yyl1495 > 0 { + var yyrr1495, yyrl1495 int + var yyrt1495 bool + if yyl1495 > cap(yyv1495) { - yyrl1438, yyrt1438 = z.DecInferLen(yyl1438, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1438 { - if yyrl1438 <= cap(yyv1438) { - yyv1438 = yyv1438[:yyrl1438] + yyrl1495, yyrt1495 = z.DecInferLen(yyl1495, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1495 { + if yyrl1495 <= cap(yyv1495) { + yyv1495 = yyv1495[:yyrl1495] } else { - yyv1438 = make([]pkg2_api.Capability, yyrl1438) + yyv1495 = make([]pkg2_api.Capability, yyrl1495) } } else { - yyv1438 = make([]pkg2_api.Capability, yyrl1438) + yyv1495 = make([]pkg2_api.Capability, yyrl1495) } - yyc1438 = true - yyrr1438 = len(yyv1438) - } else if yyl1438 != len(yyv1438) { - yyv1438 = yyv1438[:yyl1438] - yyc1438 = true + yyc1495 = true + yyrr1495 = len(yyv1495) + } else if yyl1495 != len(yyv1495) { + yyv1495 = yyv1495[:yyl1495] + yyc1495 = true } - yyj1438 := 0 - for ; yyj1438 < yyrr1438; yyj1438++ { - yyh1438.ElemContainerState(yyj1438) + yyj1495 := 0 + for ; yyj1495 < yyrr1495; yyj1495++ { + yyh1495.ElemContainerState(yyj1495) if r.TryDecodeAsNil() { - yyv1438[yyj1438] = "" + yyv1495[yyj1495] = "" } else { - yyv1438[yyj1438] = pkg2_api.Capability(r.DecodeString()) + yyv1495[yyj1495] = pkg2_api.Capability(r.DecodeString()) } } - if yyrt1438 { - for ; yyj1438 < yyl1438; yyj1438++ { - yyv1438 = append(yyv1438, "") - yyh1438.ElemContainerState(yyj1438) + if yyrt1495 { + for ; yyj1495 < yyl1495; yyj1495++ { + yyv1495 = append(yyv1495, "") + yyh1495.ElemContainerState(yyj1495) if r.TryDecodeAsNil() { - yyv1438[yyj1438] = "" + yyv1495[yyj1495] = "" } else { - yyv1438[yyj1438] = pkg2_api.Capability(r.DecodeString()) + yyv1495[yyj1495] = pkg2_api.Capability(r.DecodeString()) } } } } else { - yyj1438 := 0 - for ; !r.CheckBreak(); yyj1438++ { + yyj1495 := 0 + for ; !r.CheckBreak(); yyj1495++ { - if yyj1438 >= len(yyv1438) { - yyv1438 = append(yyv1438, "") // var yyz1438 pkg2_api.Capability - yyc1438 = true + if yyj1495 >= len(yyv1495) { + yyv1495 = append(yyv1495, "") // var yyz1495 pkg2_api.Capability + yyc1495 = true } - yyh1438.ElemContainerState(yyj1438) - if yyj1438 < len(yyv1438) { + yyh1495.ElemContainerState(yyj1495) + if yyj1495 < len(yyv1495) { if r.TryDecodeAsNil() { - yyv1438[yyj1438] = "" + yyv1495[yyj1495] = "" } else { - yyv1438[yyj1438] = pkg2_api.Capability(r.DecodeString()) + yyv1495[yyj1495] = pkg2_api.Capability(r.DecodeString()) } } else { @@ -17859,17 +18520,17 @@ func (x codecSelfer1234) decSliceapi_Capability(v *[]pkg2_api.Capability, d *cod } } - if yyj1438 < len(yyv1438) { - yyv1438 = yyv1438[:yyj1438] - yyc1438 = true - } else if yyj1438 == 0 && yyv1438 == nil { - yyv1438 = []pkg2_api.Capability{} - yyc1438 = true + if yyj1495 < len(yyv1495) { + yyv1495 = yyv1495[:yyj1495] + yyc1495 = true + } else if yyj1495 == 0 && yyv1495 == nil { + yyv1495 = []pkg2_api.Capability{} + yyc1495 = true } } - yyh1438.End() - if yyc1438 { - *v = yyv1438 + yyh1495.End() + if yyc1495 { + *v = yyv1495 } } @@ -17878,9 +18539,9 @@ func (x codecSelfer1234) encSliceFSType(v []FSType, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1442 := range v { + for _, yyv1499 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv1442.CodecEncodeSelf(e) + yyv1499.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17890,75 +18551,75 @@ func (x codecSelfer1234) decSliceFSType(v *[]FSType, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1443 := *v - yyh1443, yyl1443 := z.DecSliceHelperStart() - var yyc1443 bool - if yyl1443 == 0 { - if yyv1443 == nil { - yyv1443 = []FSType{} - yyc1443 = true - } else if len(yyv1443) != 0 { - yyv1443 = yyv1443[:0] - yyc1443 = true + yyv1500 := *v + yyh1500, yyl1500 := z.DecSliceHelperStart() + var yyc1500 bool + if yyl1500 == 0 { + if yyv1500 == nil { + yyv1500 = []FSType{} + yyc1500 = true + } else if len(yyv1500) != 0 { + yyv1500 = yyv1500[:0] + yyc1500 = true } - } else if yyl1443 > 0 { - var yyrr1443, yyrl1443 int - var yyrt1443 bool - if yyl1443 > cap(yyv1443) { + } else if yyl1500 > 0 { + var yyrr1500, yyrl1500 int + var yyrt1500 bool + if yyl1500 > cap(yyv1500) { - yyrl1443, yyrt1443 = z.DecInferLen(yyl1443, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1443 { - if yyrl1443 <= cap(yyv1443) { - yyv1443 = yyv1443[:yyrl1443] + yyrl1500, yyrt1500 = z.DecInferLen(yyl1500, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1500 { + if yyrl1500 <= cap(yyv1500) { + yyv1500 = yyv1500[:yyrl1500] } else { - yyv1443 = make([]FSType, yyrl1443) + yyv1500 = make([]FSType, yyrl1500) } } else { - yyv1443 = make([]FSType, yyrl1443) + yyv1500 = make([]FSType, yyrl1500) } - yyc1443 = true - yyrr1443 = len(yyv1443) - } else if yyl1443 != len(yyv1443) { - yyv1443 = yyv1443[:yyl1443] - yyc1443 = true + yyc1500 = true + yyrr1500 = len(yyv1500) + } else if yyl1500 != len(yyv1500) { + yyv1500 = yyv1500[:yyl1500] + yyc1500 = true } - yyj1443 := 0 - for ; yyj1443 < yyrr1443; yyj1443++ { - yyh1443.ElemContainerState(yyj1443) + yyj1500 := 0 + for ; yyj1500 < yyrr1500; yyj1500++ { + yyh1500.ElemContainerState(yyj1500) if r.TryDecodeAsNil() { - yyv1443[yyj1443] = "" + yyv1500[yyj1500] = "" } else { - yyv1443[yyj1443] = FSType(r.DecodeString()) + yyv1500[yyj1500] = FSType(r.DecodeString()) } } - if yyrt1443 { - for ; yyj1443 < yyl1443; yyj1443++ { - yyv1443 = append(yyv1443, "") - yyh1443.ElemContainerState(yyj1443) + if yyrt1500 { + for ; yyj1500 < yyl1500; yyj1500++ { + yyv1500 = append(yyv1500, "") + yyh1500.ElemContainerState(yyj1500) if r.TryDecodeAsNil() { - yyv1443[yyj1443] = "" + yyv1500[yyj1500] = "" } else { - yyv1443[yyj1443] = FSType(r.DecodeString()) + yyv1500[yyj1500] = FSType(r.DecodeString()) } } } } else { - yyj1443 := 0 - for ; !r.CheckBreak(); yyj1443++ { + yyj1500 := 0 + for ; !r.CheckBreak(); yyj1500++ { - if yyj1443 >= len(yyv1443) { - yyv1443 = append(yyv1443, "") // var yyz1443 FSType - yyc1443 = true + if yyj1500 >= len(yyv1500) { + yyv1500 = append(yyv1500, "") // var yyz1500 FSType + yyc1500 = true } - yyh1443.ElemContainerState(yyj1443) - if yyj1443 < len(yyv1443) { + yyh1500.ElemContainerState(yyj1500) + if yyj1500 < len(yyv1500) { if r.TryDecodeAsNil() { - yyv1443[yyj1443] = "" + yyv1500[yyj1500] = "" } else { - yyv1443[yyj1443] = FSType(r.DecodeString()) + yyv1500[yyj1500] = FSType(r.DecodeString()) } } else { @@ -17966,17 +18627,17 @@ func (x codecSelfer1234) decSliceFSType(v *[]FSType, d *codec1978.Decoder) { } } - if yyj1443 < len(yyv1443) { - yyv1443 = yyv1443[:yyj1443] - yyc1443 = true - } else if yyj1443 == 0 && yyv1443 == nil { - yyv1443 = []FSType{} - yyc1443 = true + if yyj1500 < len(yyv1500) { + yyv1500 = yyv1500[:yyj1500] + yyc1500 = true + } else if yyj1500 == 0 && yyv1500 == nil { + yyv1500 = []FSType{} + yyc1500 = true } } - yyh1443.End() - if yyc1443 { - *v = yyv1443 + yyh1500.End() + if yyc1500 { + *v = yyv1500 } } @@ -17985,10 +18646,10 @@ func (x codecSelfer1234) encSliceHostPortRange(v []HostPortRange, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1447 := range v { + for _, yyv1504 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1448 := &yyv1447 - yy1448.CodecEncodeSelf(e) + yy1505 := &yyv1504 + yy1505.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17998,83 +18659,83 @@ func (x codecSelfer1234) decSliceHostPortRange(v *[]HostPortRange, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1449 := *v - yyh1449, yyl1449 := z.DecSliceHelperStart() - var yyc1449 bool - if yyl1449 == 0 { - if yyv1449 == nil { - yyv1449 = []HostPortRange{} - yyc1449 = true - } else if len(yyv1449) != 0 { - yyv1449 = yyv1449[:0] - yyc1449 = true + yyv1506 := *v + yyh1506, yyl1506 := z.DecSliceHelperStart() + var yyc1506 bool + if yyl1506 == 0 { + if yyv1506 == nil { + yyv1506 = []HostPortRange{} + yyc1506 = true + } else if len(yyv1506) != 0 { + yyv1506 = yyv1506[:0] + yyc1506 = true } - } else if yyl1449 > 0 { - var yyrr1449, yyrl1449 int - var yyrt1449 bool - if yyl1449 > cap(yyv1449) { + } else if yyl1506 > 0 { + var yyrr1506, yyrl1506 int + var yyrt1506 bool + if yyl1506 > cap(yyv1506) { - yyrg1449 := len(yyv1449) > 0 - yyv21449 := yyv1449 - yyrl1449, yyrt1449 = z.DecInferLen(yyl1449, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1449 { - if yyrl1449 <= cap(yyv1449) { - yyv1449 = yyv1449[:yyrl1449] + yyrg1506 := len(yyv1506) > 0 + yyv21506 := yyv1506 + yyrl1506, yyrt1506 = z.DecInferLen(yyl1506, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1506 { + if yyrl1506 <= cap(yyv1506) { + yyv1506 = yyv1506[:yyrl1506] } else { - yyv1449 = make([]HostPortRange, yyrl1449) + yyv1506 = make([]HostPortRange, yyrl1506) } } else { - yyv1449 = make([]HostPortRange, yyrl1449) + yyv1506 = make([]HostPortRange, yyrl1506) } - yyc1449 = true - yyrr1449 = len(yyv1449) - if yyrg1449 { - copy(yyv1449, yyv21449) + yyc1506 = true + yyrr1506 = len(yyv1506) + if yyrg1506 { + copy(yyv1506, yyv21506) } - } else if yyl1449 != len(yyv1449) { - yyv1449 = yyv1449[:yyl1449] - yyc1449 = true + } else if yyl1506 != len(yyv1506) { + yyv1506 = yyv1506[:yyl1506] + yyc1506 = true } - yyj1449 := 0 - for ; yyj1449 < yyrr1449; yyj1449++ { - yyh1449.ElemContainerState(yyj1449) + yyj1506 := 0 + for ; yyj1506 < yyrr1506; yyj1506++ { + yyh1506.ElemContainerState(yyj1506) if r.TryDecodeAsNil() { - yyv1449[yyj1449] = HostPortRange{} + yyv1506[yyj1506] = HostPortRange{} } else { - yyv1450 := &yyv1449[yyj1449] - yyv1450.CodecDecodeSelf(d) + yyv1507 := &yyv1506[yyj1506] + yyv1507.CodecDecodeSelf(d) } } - if yyrt1449 { - for ; yyj1449 < yyl1449; yyj1449++ { - yyv1449 = append(yyv1449, HostPortRange{}) - yyh1449.ElemContainerState(yyj1449) + if yyrt1506 { + for ; yyj1506 < yyl1506; yyj1506++ { + yyv1506 = append(yyv1506, HostPortRange{}) + yyh1506.ElemContainerState(yyj1506) if r.TryDecodeAsNil() { - yyv1449[yyj1449] = HostPortRange{} + yyv1506[yyj1506] = HostPortRange{} } else { - yyv1451 := &yyv1449[yyj1449] - yyv1451.CodecDecodeSelf(d) + yyv1508 := &yyv1506[yyj1506] + yyv1508.CodecDecodeSelf(d) } } } } else { - yyj1449 := 0 - for ; !r.CheckBreak(); yyj1449++ { + yyj1506 := 0 + for ; !r.CheckBreak(); yyj1506++ { - if yyj1449 >= len(yyv1449) { - yyv1449 = append(yyv1449, HostPortRange{}) // var yyz1449 HostPortRange - yyc1449 = true + if yyj1506 >= len(yyv1506) { + yyv1506 = append(yyv1506, HostPortRange{}) // var yyz1506 HostPortRange + yyc1506 = true } - yyh1449.ElemContainerState(yyj1449) - if yyj1449 < len(yyv1449) { + yyh1506.ElemContainerState(yyj1506) + if yyj1506 < len(yyv1506) { if r.TryDecodeAsNil() { - yyv1449[yyj1449] = HostPortRange{} + yyv1506[yyj1506] = HostPortRange{} } else { - yyv1452 := &yyv1449[yyj1449] - yyv1452.CodecDecodeSelf(d) + yyv1509 := &yyv1506[yyj1506] + yyv1509.CodecDecodeSelf(d) } } else { @@ -18082,17 +18743,17 @@ func (x codecSelfer1234) decSliceHostPortRange(v *[]HostPortRange, d *codec1978. } } - if yyj1449 < len(yyv1449) { - yyv1449 = yyv1449[:yyj1449] - yyc1449 = true - } else if yyj1449 == 0 && yyv1449 == nil { - yyv1449 = []HostPortRange{} - yyc1449 = true + if yyj1506 < len(yyv1506) { + yyv1506 = yyv1506[:yyj1506] + yyc1506 = true + } else if yyj1506 == 0 && yyv1506 == nil { + yyv1506 = []HostPortRange{} + yyc1506 = true } } - yyh1449.End() - if yyc1449 { - *v = yyv1449 + yyh1506.End() + if yyc1506 { + *v = yyv1506 } } @@ -18101,10 +18762,10 @@ func (x codecSelfer1234) encSliceIDRange(v []IDRange, e *codec1978.Encoder) { z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1453 := range v { + for _, yyv1510 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1454 := &yyv1453 - yy1454.CodecEncodeSelf(e) + yy1511 := &yyv1510 + yy1511.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18114,83 +18775,83 @@ func (x codecSelfer1234) decSliceIDRange(v *[]IDRange, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1455 := *v - yyh1455, yyl1455 := z.DecSliceHelperStart() - var yyc1455 bool - if yyl1455 == 0 { - if yyv1455 == nil { - yyv1455 = []IDRange{} - yyc1455 = true - } else if len(yyv1455) != 0 { - yyv1455 = yyv1455[:0] - yyc1455 = true + yyv1512 := *v + yyh1512, yyl1512 := z.DecSliceHelperStart() + var yyc1512 bool + if yyl1512 == 0 { + if yyv1512 == nil { + yyv1512 = []IDRange{} + yyc1512 = true + } else if len(yyv1512) != 0 { + yyv1512 = yyv1512[:0] + yyc1512 = true } - } else if yyl1455 > 0 { - var yyrr1455, yyrl1455 int - var yyrt1455 bool - if yyl1455 > cap(yyv1455) { + } else if yyl1512 > 0 { + var yyrr1512, yyrl1512 int + var yyrt1512 bool + if yyl1512 > cap(yyv1512) { - yyrg1455 := len(yyv1455) > 0 - yyv21455 := yyv1455 - yyrl1455, yyrt1455 = z.DecInferLen(yyl1455, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1455 { - if yyrl1455 <= cap(yyv1455) { - yyv1455 = yyv1455[:yyrl1455] + yyrg1512 := len(yyv1512) > 0 + yyv21512 := yyv1512 + yyrl1512, yyrt1512 = z.DecInferLen(yyl1512, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1512 { + if yyrl1512 <= cap(yyv1512) { + yyv1512 = yyv1512[:yyrl1512] } else { - yyv1455 = make([]IDRange, yyrl1455) + yyv1512 = make([]IDRange, yyrl1512) } } else { - yyv1455 = make([]IDRange, yyrl1455) + yyv1512 = make([]IDRange, yyrl1512) } - yyc1455 = true - yyrr1455 = len(yyv1455) - if yyrg1455 { - copy(yyv1455, yyv21455) + yyc1512 = true + yyrr1512 = len(yyv1512) + if yyrg1512 { + copy(yyv1512, yyv21512) } - } else if yyl1455 != len(yyv1455) { - yyv1455 = yyv1455[:yyl1455] - yyc1455 = true + } else if yyl1512 != len(yyv1512) { + yyv1512 = yyv1512[:yyl1512] + yyc1512 = true } - yyj1455 := 0 - for ; yyj1455 < yyrr1455; yyj1455++ { - yyh1455.ElemContainerState(yyj1455) + yyj1512 := 0 + for ; yyj1512 < yyrr1512; yyj1512++ { + yyh1512.ElemContainerState(yyj1512) if r.TryDecodeAsNil() { - yyv1455[yyj1455] = IDRange{} + yyv1512[yyj1512] = IDRange{} } else { - yyv1456 := &yyv1455[yyj1455] - yyv1456.CodecDecodeSelf(d) + yyv1513 := &yyv1512[yyj1512] + yyv1513.CodecDecodeSelf(d) } } - if yyrt1455 { - for ; yyj1455 < yyl1455; yyj1455++ { - yyv1455 = append(yyv1455, IDRange{}) - yyh1455.ElemContainerState(yyj1455) + if yyrt1512 { + for ; yyj1512 < yyl1512; yyj1512++ { + yyv1512 = append(yyv1512, IDRange{}) + yyh1512.ElemContainerState(yyj1512) if r.TryDecodeAsNil() { - yyv1455[yyj1455] = IDRange{} + yyv1512[yyj1512] = IDRange{} } else { - yyv1457 := &yyv1455[yyj1455] - yyv1457.CodecDecodeSelf(d) + yyv1514 := &yyv1512[yyj1512] + yyv1514.CodecDecodeSelf(d) } } } } else { - yyj1455 := 0 - for ; !r.CheckBreak(); yyj1455++ { + yyj1512 := 0 + for ; !r.CheckBreak(); yyj1512++ { - if yyj1455 >= len(yyv1455) { - yyv1455 = append(yyv1455, IDRange{}) // var yyz1455 IDRange - yyc1455 = true + if yyj1512 >= len(yyv1512) { + yyv1512 = append(yyv1512, IDRange{}) // var yyz1512 IDRange + yyc1512 = true } - yyh1455.ElemContainerState(yyj1455) - if yyj1455 < len(yyv1455) { + yyh1512.ElemContainerState(yyj1512) + if yyj1512 < len(yyv1512) { if r.TryDecodeAsNil() { - yyv1455[yyj1455] = IDRange{} + yyv1512[yyj1512] = IDRange{} } else { - yyv1458 := &yyv1455[yyj1455] - yyv1458.CodecDecodeSelf(d) + yyv1515 := &yyv1512[yyj1512] + yyv1515.CodecDecodeSelf(d) } } else { @@ -18198,17 +18859,17 @@ func (x codecSelfer1234) decSliceIDRange(v *[]IDRange, d *codec1978.Decoder) { } } - if yyj1455 < len(yyv1455) { - yyv1455 = yyv1455[:yyj1455] - yyc1455 = true - } else if yyj1455 == 0 && yyv1455 == nil { - yyv1455 = []IDRange{} - yyc1455 = true + if yyj1512 < len(yyv1512) { + yyv1512 = yyv1512[:yyj1512] + yyc1512 = true + } else if yyj1512 == 0 && yyv1512 == nil { + yyv1512 = []IDRange{} + yyc1512 = true } } - yyh1455.End() - if yyc1455 { - *v = yyv1455 + yyh1512.End() + if yyc1512 { + *v = yyv1512 } } @@ -18217,10 +18878,10 @@ func (x codecSelfer1234) encSlicePodSecurityPolicy(v []PodSecurityPolicy, e *cod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1459 := range v { + for _, yyv1516 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1460 := &yyv1459 - yy1460.CodecEncodeSelf(e) + yy1517 := &yyv1516 + yy1517.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18230,83 +18891,83 @@ func (x codecSelfer1234) decSlicePodSecurityPolicy(v *[]PodSecurityPolicy, d *co z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1461 := *v - yyh1461, yyl1461 := z.DecSliceHelperStart() - var yyc1461 bool - if yyl1461 == 0 { - if yyv1461 == nil { - yyv1461 = []PodSecurityPolicy{} - yyc1461 = true - } else if len(yyv1461) != 0 { - yyv1461 = yyv1461[:0] - yyc1461 = true + yyv1518 := *v + yyh1518, yyl1518 := z.DecSliceHelperStart() + var yyc1518 bool + if yyl1518 == 0 { + if yyv1518 == nil { + yyv1518 = []PodSecurityPolicy{} + yyc1518 = true + } else if len(yyv1518) != 0 { + yyv1518 = yyv1518[:0] + yyc1518 = true } - } else if yyl1461 > 0 { - var yyrr1461, yyrl1461 int - var yyrt1461 bool - if yyl1461 > cap(yyv1461) { + } else if yyl1518 > 0 { + var yyrr1518, yyrl1518 int + var yyrt1518 bool + if yyl1518 > cap(yyv1518) { - yyrg1461 := len(yyv1461) > 0 - yyv21461 := yyv1461 - yyrl1461, yyrt1461 = z.DecInferLen(yyl1461, z.DecBasicHandle().MaxInitLen, 552) - if yyrt1461 { - if yyrl1461 <= cap(yyv1461) { - yyv1461 = yyv1461[:yyrl1461] + yyrg1518 := len(yyv1518) > 0 + yyv21518 := yyv1518 + yyrl1518, yyrt1518 = z.DecInferLen(yyl1518, z.DecBasicHandle().MaxInitLen, 552) + if yyrt1518 { + if yyrl1518 <= cap(yyv1518) { + yyv1518 = yyv1518[:yyrl1518] } else { - yyv1461 = make([]PodSecurityPolicy, yyrl1461) + yyv1518 = make([]PodSecurityPolicy, yyrl1518) } } else { - yyv1461 = make([]PodSecurityPolicy, yyrl1461) + yyv1518 = make([]PodSecurityPolicy, yyrl1518) } - yyc1461 = true - yyrr1461 = len(yyv1461) - if yyrg1461 { - copy(yyv1461, yyv21461) + yyc1518 = true + yyrr1518 = len(yyv1518) + if yyrg1518 { + copy(yyv1518, yyv21518) } - } else if yyl1461 != len(yyv1461) { - yyv1461 = yyv1461[:yyl1461] - yyc1461 = true + } else if yyl1518 != len(yyv1518) { + yyv1518 = yyv1518[:yyl1518] + yyc1518 = true } - yyj1461 := 0 - for ; yyj1461 < yyrr1461; yyj1461++ { - yyh1461.ElemContainerState(yyj1461) + yyj1518 := 0 + for ; yyj1518 < yyrr1518; yyj1518++ { + yyh1518.ElemContainerState(yyj1518) if r.TryDecodeAsNil() { - yyv1461[yyj1461] = PodSecurityPolicy{} + yyv1518[yyj1518] = PodSecurityPolicy{} } else { - yyv1462 := &yyv1461[yyj1461] - yyv1462.CodecDecodeSelf(d) + yyv1519 := &yyv1518[yyj1518] + yyv1519.CodecDecodeSelf(d) } } - if yyrt1461 { - for ; yyj1461 < yyl1461; yyj1461++ { - yyv1461 = append(yyv1461, PodSecurityPolicy{}) - yyh1461.ElemContainerState(yyj1461) + if yyrt1518 { + for ; yyj1518 < yyl1518; yyj1518++ { + yyv1518 = append(yyv1518, PodSecurityPolicy{}) + yyh1518.ElemContainerState(yyj1518) if r.TryDecodeAsNil() { - yyv1461[yyj1461] = PodSecurityPolicy{} + yyv1518[yyj1518] = PodSecurityPolicy{} } else { - yyv1463 := &yyv1461[yyj1461] - yyv1463.CodecDecodeSelf(d) + yyv1520 := &yyv1518[yyj1518] + yyv1520.CodecDecodeSelf(d) } } } } else { - yyj1461 := 0 - for ; !r.CheckBreak(); yyj1461++ { + yyj1518 := 0 + for ; !r.CheckBreak(); yyj1518++ { - if yyj1461 >= len(yyv1461) { - yyv1461 = append(yyv1461, PodSecurityPolicy{}) // var yyz1461 PodSecurityPolicy - yyc1461 = true + if yyj1518 >= len(yyv1518) { + yyv1518 = append(yyv1518, PodSecurityPolicy{}) // var yyz1518 PodSecurityPolicy + yyc1518 = true } - yyh1461.ElemContainerState(yyj1461) - if yyj1461 < len(yyv1461) { + yyh1518.ElemContainerState(yyj1518) + if yyj1518 < len(yyv1518) { if r.TryDecodeAsNil() { - yyv1461[yyj1461] = PodSecurityPolicy{} + yyv1518[yyj1518] = PodSecurityPolicy{} } else { - yyv1464 := &yyv1461[yyj1461] - yyv1464.CodecDecodeSelf(d) + yyv1521 := &yyv1518[yyj1518] + yyv1521.CodecDecodeSelf(d) } } else { @@ -18314,17 +18975,17 @@ func (x codecSelfer1234) decSlicePodSecurityPolicy(v *[]PodSecurityPolicy, d *co } } - if yyj1461 < len(yyv1461) { - yyv1461 = yyv1461[:yyj1461] - yyc1461 = true - } else if yyj1461 == 0 && yyv1461 == nil { - yyv1461 = []PodSecurityPolicy{} - yyc1461 = true + if yyj1518 < len(yyv1518) { + yyv1518 = yyv1518[:yyj1518] + yyc1518 = true + } else if yyj1518 == 0 && yyv1518 == nil { + yyv1518 = []PodSecurityPolicy{} + yyc1518 = true } } - yyh1461.End() - if yyc1461 { - *v = yyv1461 + yyh1518.End() + if yyc1518 { + *v = yyv1518 } } @@ -18333,10 +18994,10 @@ func (x codecSelfer1234) encSliceNetworkPolicyIngressRule(v []NetworkPolicyIngre z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1465 := range v { + for _, yyv1522 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1466 := &yyv1465 - yy1466.CodecEncodeSelf(e) + yy1523 := &yyv1522 + yy1523.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18346,83 +19007,83 @@ func (x codecSelfer1234) decSliceNetworkPolicyIngressRule(v *[]NetworkPolicyIngr z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1467 := *v - yyh1467, yyl1467 := z.DecSliceHelperStart() - var yyc1467 bool - if yyl1467 == 0 { - if yyv1467 == nil { - yyv1467 = []NetworkPolicyIngressRule{} - yyc1467 = true - } else if len(yyv1467) != 0 { - yyv1467 = yyv1467[:0] - yyc1467 = true + yyv1524 := *v + yyh1524, yyl1524 := z.DecSliceHelperStart() + var yyc1524 bool + if yyl1524 == 0 { + if yyv1524 == nil { + yyv1524 = []NetworkPolicyIngressRule{} + yyc1524 = true + } else if len(yyv1524) != 0 { + yyv1524 = yyv1524[:0] + yyc1524 = true } - } else if yyl1467 > 0 { - var yyrr1467, yyrl1467 int - var yyrt1467 bool - if yyl1467 > cap(yyv1467) { + } else if yyl1524 > 0 { + var yyrr1524, yyrl1524 int + var yyrt1524 bool + if yyl1524 > cap(yyv1524) { - yyrg1467 := len(yyv1467) > 0 - yyv21467 := yyv1467 - yyrl1467, yyrt1467 = z.DecInferLen(yyl1467, z.DecBasicHandle().MaxInitLen, 48) - if yyrt1467 { - if yyrl1467 <= cap(yyv1467) { - yyv1467 = yyv1467[:yyrl1467] + yyrg1524 := len(yyv1524) > 0 + yyv21524 := yyv1524 + yyrl1524, yyrt1524 = z.DecInferLen(yyl1524, z.DecBasicHandle().MaxInitLen, 48) + if yyrt1524 { + if yyrl1524 <= cap(yyv1524) { + yyv1524 = yyv1524[:yyrl1524] } else { - yyv1467 = make([]NetworkPolicyIngressRule, yyrl1467) + yyv1524 = make([]NetworkPolicyIngressRule, yyrl1524) } } else { - yyv1467 = make([]NetworkPolicyIngressRule, yyrl1467) + yyv1524 = make([]NetworkPolicyIngressRule, yyrl1524) } - yyc1467 = true - yyrr1467 = len(yyv1467) - if yyrg1467 { - copy(yyv1467, yyv21467) + yyc1524 = true + yyrr1524 = len(yyv1524) + if yyrg1524 { + copy(yyv1524, yyv21524) } - } else if yyl1467 != len(yyv1467) { - yyv1467 = yyv1467[:yyl1467] - yyc1467 = true + } else if yyl1524 != len(yyv1524) { + yyv1524 = yyv1524[:yyl1524] + yyc1524 = true } - yyj1467 := 0 - for ; yyj1467 < yyrr1467; yyj1467++ { - yyh1467.ElemContainerState(yyj1467) + yyj1524 := 0 + for ; yyj1524 < yyrr1524; yyj1524++ { + yyh1524.ElemContainerState(yyj1524) if r.TryDecodeAsNil() { - yyv1467[yyj1467] = NetworkPolicyIngressRule{} + yyv1524[yyj1524] = NetworkPolicyIngressRule{} } else { - yyv1468 := &yyv1467[yyj1467] - yyv1468.CodecDecodeSelf(d) + yyv1525 := &yyv1524[yyj1524] + yyv1525.CodecDecodeSelf(d) } } - if yyrt1467 { - for ; yyj1467 < yyl1467; yyj1467++ { - yyv1467 = append(yyv1467, NetworkPolicyIngressRule{}) - yyh1467.ElemContainerState(yyj1467) + if yyrt1524 { + for ; yyj1524 < yyl1524; yyj1524++ { + yyv1524 = append(yyv1524, NetworkPolicyIngressRule{}) + yyh1524.ElemContainerState(yyj1524) if r.TryDecodeAsNil() { - yyv1467[yyj1467] = NetworkPolicyIngressRule{} + yyv1524[yyj1524] = NetworkPolicyIngressRule{} } else { - yyv1469 := &yyv1467[yyj1467] - yyv1469.CodecDecodeSelf(d) + yyv1526 := &yyv1524[yyj1524] + yyv1526.CodecDecodeSelf(d) } } } } else { - yyj1467 := 0 - for ; !r.CheckBreak(); yyj1467++ { + yyj1524 := 0 + for ; !r.CheckBreak(); yyj1524++ { - if yyj1467 >= len(yyv1467) { - yyv1467 = append(yyv1467, NetworkPolicyIngressRule{}) // var yyz1467 NetworkPolicyIngressRule - yyc1467 = true + if yyj1524 >= len(yyv1524) { + yyv1524 = append(yyv1524, NetworkPolicyIngressRule{}) // var yyz1524 NetworkPolicyIngressRule + yyc1524 = true } - yyh1467.ElemContainerState(yyj1467) - if yyj1467 < len(yyv1467) { + yyh1524.ElemContainerState(yyj1524) + if yyj1524 < len(yyv1524) { if r.TryDecodeAsNil() { - yyv1467[yyj1467] = NetworkPolicyIngressRule{} + yyv1524[yyj1524] = NetworkPolicyIngressRule{} } else { - yyv1470 := &yyv1467[yyj1467] - yyv1470.CodecDecodeSelf(d) + yyv1527 := &yyv1524[yyj1524] + yyv1527.CodecDecodeSelf(d) } } else { @@ -18430,17 +19091,17 @@ func (x codecSelfer1234) decSliceNetworkPolicyIngressRule(v *[]NetworkPolicyIngr } } - if yyj1467 < len(yyv1467) { - yyv1467 = yyv1467[:yyj1467] - yyc1467 = true - } else if yyj1467 == 0 && yyv1467 == nil { - yyv1467 = []NetworkPolicyIngressRule{} - yyc1467 = true + if yyj1524 < len(yyv1524) { + yyv1524 = yyv1524[:yyj1524] + yyc1524 = true + } else if yyj1524 == 0 && yyv1524 == nil { + yyv1524 = []NetworkPolicyIngressRule{} + yyc1524 = true } } - yyh1467.End() - if yyc1467 { - *v = yyv1467 + yyh1524.End() + if yyc1524 { + *v = yyv1524 } } @@ -18449,10 +19110,10 @@ func (x codecSelfer1234) encSliceNetworkPolicyPort(v []NetworkPolicyPort, e *cod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1471 := range v { + for _, yyv1528 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1472 := &yyv1471 - yy1472.CodecEncodeSelf(e) + yy1529 := &yyv1528 + yy1529.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18462,83 +19123,83 @@ func (x codecSelfer1234) decSliceNetworkPolicyPort(v *[]NetworkPolicyPort, d *co z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1473 := *v - yyh1473, yyl1473 := z.DecSliceHelperStart() - var yyc1473 bool - if yyl1473 == 0 { - if yyv1473 == nil { - yyv1473 = []NetworkPolicyPort{} - yyc1473 = true - } else if len(yyv1473) != 0 { - yyv1473 = yyv1473[:0] - yyc1473 = true + yyv1530 := *v + yyh1530, yyl1530 := z.DecSliceHelperStart() + var yyc1530 bool + if yyl1530 == 0 { + if yyv1530 == nil { + yyv1530 = []NetworkPolicyPort{} + yyc1530 = true + } else if len(yyv1530) != 0 { + yyv1530 = yyv1530[:0] + yyc1530 = true } - } else if yyl1473 > 0 { - var yyrr1473, yyrl1473 int - var yyrt1473 bool - if yyl1473 > cap(yyv1473) { + } else if yyl1530 > 0 { + var yyrr1530, yyrl1530 int + var yyrt1530 bool + if yyl1530 > cap(yyv1530) { - yyrg1473 := len(yyv1473) > 0 - yyv21473 := yyv1473 - yyrl1473, yyrt1473 = z.DecInferLen(yyl1473, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1473 { - if yyrl1473 <= cap(yyv1473) { - yyv1473 = yyv1473[:yyrl1473] + yyrg1530 := len(yyv1530) > 0 + yyv21530 := yyv1530 + yyrl1530, yyrt1530 = z.DecInferLen(yyl1530, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1530 { + if yyrl1530 <= cap(yyv1530) { + yyv1530 = yyv1530[:yyrl1530] } else { - yyv1473 = make([]NetworkPolicyPort, yyrl1473) + yyv1530 = make([]NetworkPolicyPort, yyrl1530) } } else { - yyv1473 = make([]NetworkPolicyPort, yyrl1473) + yyv1530 = make([]NetworkPolicyPort, yyrl1530) } - yyc1473 = true - yyrr1473 = len(yyv1473) - if yyrg1473 { - copy(yyv1473, yyv21473) + yyc1530 = true + yyrr1530 = len(yyv1530) + if yyrg1530 { + copy(yyv1530, yyv21530) } - } else if yyl1473 != len(yyv1473) { - yyv1473 = yyv1473[:yyl1473] - yyc1473 = true + } else if yyl1530 != len(yyv1530) { + yyv1530 = yyv1530[:yyl1530] + yyc1530 = true } - yyj1473 := 0 - for ; yyj1473 < yyrr1473; yyj1473++ { - yyh1473.ElemContainerState(yyj1473) + yyj1530 := 0 + for ; yyj1530 < yyrr1530; yyj1530++ { + yyh1530.ElemContainerState(yyj1530) if r.TryDecodeAsNil() { - yyv1473[yyj1473] = NetworkPolicyPort{} + yyv1530[yyj1530] = NetworkPolicyPort{} } else { - yyv1474 := &yyv1473[yyj1473] - yyv1474.CodecDecodeSelf(d) + yyv1531 := &yyv1530[yyj1530] + yyv1531.CodecDecodeSelf(d) } } - if yyrt1473 { - for ; yyj1473 < yyl1473; yyj1473++ { - yyv1473 = append(yyv1473, NetworkPolicyPort{}) - yyh1473.ElemContainerState(yyj1473) + if yyrt1530 { + for ; yyj1530 < yyl1530; yyj1530++ { + yyv1530 = append(yyv1530, NetworkPolicyPort{}) + yyh1530.ElemContainerState(yyj1530) if r.TryDecodeAsNil() { - yyv1473[yyj1473] = NetworkPolicyPort{} + yyv1530[yyj1530] = NetworkPolicyPort{} } else { - yyv1475 := &yyv1473[yyj1473] - yyv1475.CodecDecodeSelf(d) + yyv1532 := &yyv1530[yyj1530] + yyv1532.CodecDecodeSelf(d) } } } } else { - yyj1473 := 0 - for ; !r.CheckBreak(); yyj1473++ { + yyj1530 := 0 + for ; !r.CheckBreak(); yyj1530++ { - if yyj1473 >= len(yyv1473) { - yyv1473 = append(yyv1473, NetworkPolicyPort{}) // var yyz1473 NetworkPolicyPort - yyc1473 = true + if yyj1530 >= len(yyv1530) { + yyv1530 = append(yyv1530, NetworkPolicyPort{}) // var yyz1530 NetworkPolicyPort + yyc1530 = true } - yyh1473.ElemContainerState(yyj1473) - if yyj1473 < len(yyv1473) { + yyh1530.ElemContainerState(yyj1530) + if yyj1530 < len(yyv1530) { if r.TryDecodeAsNil() { - yyv1473[yyj1473] = NetworkPolicyPort{} + yyv1530[yyj1530] = NetworkPolicyPort{} } else { - yyv1476 := &yyv1473[yyj1473] - yyv1476.CodecDecodeSelf(d) + yyv1533 := &yyv1530[yyj1530] + yyv1533.CodecDecodeSelf(d) } } else { @@ -18546,17 +19207,17 @@ func (x codecSelfer1234) decSliceNetworkPolicyPort(v *[]NetworkPolicyPort, d *co } } - if yyj1473 < len(yyv1473) { - yyv1473 = yyv1473[:yyj1473] - yyc1473 = true - } else if yyj1473 == 0 && yyv1473 == nil { - yyv1473 = []NetworkPolicyPort{} - yyc1473 = true + if yyj1530 < len(yyv1530) { + yyv1530 = yyv1530[:yyj1530] + yyc1530 = true + } else if yyj1530 == 0 && yyv1530 == nil { + yyv1530 = []NetworkPolicyPort{} + yyc1530 = true } } - yyh1473.End() - if yyc1473 { - *v = yyv1473 + yyh1530.End() + if yyc1530 { + *v = yyv1530 } } @@ -18565,10 +19226,10 @@ func (x codecSelfer1234) encSliceNetworkPolicyPeer(v []NetworkPolicyPeer, e *cod z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1477 := range v { + for _, yyv1534 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1478 := &yyv1477 - yy1478.CodecEncodeSelf(e) + yy1535 := &yyv1534 + yy1535.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18578,83 +19239,83 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1479 := *v - yyh1479, yyl1479 := z.DecSliceHelperStart() - var yyc1479 bool - if yyl1479 == 0 { - if yyv1479 == nil { - yyv1479 = []NetworkPolicyPeer{} - yyc1479 = true - } else if len(yyv1479) != 0 { - yyv1479 = yyv1479[:0] - yyc1479 = true + yyv1536 := *v + yyh1536, yyl1536 := z.DecSliceHelperStart() + var yyc1536 bool + if yyl1536 == 0 { + if yyv1536 == nil { + yyv1536 = []NetworkPolicyPeer{} + yyc1536 = true + } else if len(yyv1536) != 0 { + yyv1536 = yyv1536[:0] + yyc1536 = true } - } else if yyl1479 > 0 { - var yyrr1479, yyrl1479 int - var yyrt1479 bool - if yyl1479 > cap(yyv1479) { + } else if yyl1536 > 0 { + var yyrr1536, yyrl1536 int + var yyrt1536 bool + if yyl1536 > cap(yyv1536) { - yyrg1479 := len(yyv1479) > 0 - yyv21479 := yyv1479 - yyrl1479, yyrt1479 = z.DecInferLen(yyl1479, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1479 { - if yyrl1479 <= cap(yyv1479) { - yyv1479 = yyv1479[:yyrl1479] + yyrg1536 := len(yyv1536) > 0 + yyv21536 := yyv1536 + yyrl1536, yyrt1536 = z.DecInferLen(yyl1536, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1536 { + if yyrl1536 <= cap(yyv1536) { + yyv1536 = yyv1536[:yyrl1536] } else { - yyv1479 = make([]NetworkPolicyPeer, yyrl1479) + yyv1536 = make([]NetworkPolicyPeer, yyrl1536) } } else { - yyv1479 = make([]NetworkPolicyPeer, yyrl1479) + yyv1536 = make([]NetworkPolicyPeer, yyrl1536) } - yyc1479 = true - yyrr1479 = len(yyv1479) - if yyrg1479 { - copy(yyv1479, yyv21479) + yyc1536 = true + yyrr1536 = len(yyv1536) + if yyrg1536 { + copy(yyv1536, yyv21536) } - } else if yyl1479 != len(yyv1479) { - yyv1479 = yyv1479[:yyl1479] - yyc1479 = true + } else if yyl1536 != len(yyv1536) { + yyv1536 = yyv1536[:yyl1536] + yyc1536 = true } - yyj1479 := 0 - for ; yyj1479 < yyrr1479; yyj1479++ { - yyh1479.ElemContainerState(yyj1479) + yyj1536 := 0 + for ; yyj1536 < yyrr1536; yyj1536++ { + yyh1536.ElemContainerState(yyj1536) if r.TryDecodeAsNil() { - yyv1479[yyj1479] = NetworkPolicyPeer{} + yyv1536[yyj1536] = NetworkPolicyPeer{} } else { - yyv1480 := &yyv1479[yyj1479] - yyv1480.CodecDecodeSelf(d) + yyv1537 := &yyv1536[yyj1536] + yyv1537.CodecDecodeSelf(d) } } - if yyrt1479 { - for ; yyj1479 < yyl1479; yyj1479++ { - yyv1479 = append(yyv1479, NetworkPolicyPeer{}) - yyh1479.ElemContainerState(yyj1479) + if yyrt1536 { + for ; yyj1536 < yyl1536; yyj1536++ { + yyv1536 = append(yyv1536, NetworkPolicyPeer{}) + yyh1536.ElemContainerState(yyj1536) if r.TryDecodeAsNil() { - yyv1479[yyj1479] = NetworkPolicyPeer{} + yyv1536[yyj1536] = NetworkPolicyPeer{} } else { - yyv1481 := &yyv1479[yyj1479] - yyv1481.CodecDecodeSelf(d) + yyv1538 := &yyv1536[yyj1536] + yyv1538.CodecDecodeSelf(d) } } } } else { - yyj1479 := 0 - for ; !r.CheckBreak(); yyj1479++ { + yyj1536 := 0 + for ; !r.CheckBreak(); yyj1536++ { - if yyj1479 >= len(yyv1479) { - yyv1479 = append(yyv1479, NetworkPolicyPeer{}) // var yyz1479 NetworkPolicyPeer - yyc1479 = true + if yyj1536 >= len(yyv1536) { + yyv1536 = append(yyv1536, NetworkPolicyPeer{}) // var yyz1536 NetworkPolicyPeer + yyc1536 = true } - yyh1479.ElemContainerState(yyj1479) - if yyj1479 < len(yyv1479) { + yyh1536.ElemContainerState(yyj1536) + if yyj1536 < len(yyv1536) { if r.TryDecodeAsNil() { - yyv1479[yyj1479] = NetworkPolicyPeer{} + yyv1536[yyj1536] = NetworkPolicyPeer{} } else { - yyv1482 := &yyv1479[yyj1479] - yyv1482.CodecDecodeSelf(d) + yyv1539 := &yyv1536[yyj1536] + yyv1539.CodecDecodeSelf(d) } } else { @@ -18662,17 +19323,17 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co } } - if yyj1479 < len(yyv1479) { - yyv1479 = yyv1479[:yyj1479] - yyc1479 = true - } else if yyj1479 == 0 && yyv1479 == nil { - yyv1479 = []NetworkPolicyPeer{} - yyc1479 = true + if yyj1536 < len(yyv1536) { + yyv1536 = yyv1536[:yyj1536] + yyc1536 = true + } else if yyj1536 == 0 && yyv1536 == nil { + yyv1536 = []NetworkPolicyPeer{} + yyc1536 = true } } - yyh1479.End() - if yyc1479 { - *v = yyv1479 + yyh1536.End() + if yyc1536 { + *v = yyv1536 } } @@ -18681,10 +19342,10 @@ func (x codecSelfer1234) encSliceNetworkPolicy(v []NetworkPolicy, e *codec1978.E z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) - for _, yyv1483 := range v { + for _, yyv1540 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1484 := &yyv1483 - yy1484.CodecEncodeSelf(e) + yy1541 := &yyv1540 + yy1541.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18694,83 +19355,83 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1485 := *v - yyh1485, yyl1485 := z.DecSliceHelperStart() - var yyc1485 bool - if yyl1485 == 0 { - if yyv1485 == nil { - yyv1485 = []NetworkPolicy{} - yyc1485 = true - } else if len(yyv1485) != 0 { - yyv1485 = yyv1485[:0] - yyc1485 = true + yyv1542 := *v + yyh1542, yyl1542 := z.DecSliceHelperStart() + var yyc1542 bool + if yyl1542 == 0 { + if yyv1542 == nil { + yyv1542 = []NetworkPolicy{} + yyc1542 = true + } else if len(yyv1542) != 0 { + yyv1542 = yyv1542[:0] + yyc1542 = true } - } else if yyl1485 > 0 { - var yyrr1485, yyrl1485 int - var yyrt1485 bool - if yyl1485 > cap(yyv1485) { + } else if yyl1542 > 0 { + var yyrr1542, yyrl1542 int + var yyrt1542 bool + if yyl1542 > cap(yyv1542) { - yyrg1485 := len(yyv1485) > 0 - yyv21485 := yyv1485 - yyrl1485, yyrt1485 = z.DecInferLen(yyl1485, z.DecBasicHandle().MaxInitLen, 312) - if yyrt1485 { - if yyrl1485 <= cap(yyv1485) { - yyv1485 = yyv1485[:yyrl1485] + yyrg1542 := len(yyv1542) > 0 + yyv21542 := yyv1542 + yyrl1542, yyrt1542 = z.DecInferLen(yyl1542, z.DecBasicHandle().MaxInitLen, 312) + if yyrt1542 { + if yyrl1542 <= cap(yyv1542) { + yyv1542 = yyv1542[:yyrl1542] } else { - yyv1485 = make([]NetworkPolicy, yyrl1485) + yyv1542 = make([]NetworkPolicy, yyrl1542) } } else { - yyv1485 = make([]NetworkPolicy, yyrl1485) + yyv1542 = make([]NetworkPolicy, yyrl1542) } - yyc1485 = true - yyrr1485 = len(yyv1485) - if yyrg1485 { - copy(yyv1485, yyv21485) + yyc1542 = true + yyrr1542 = len(yyv1542) + if yyrg1542 { + copy(yyv1542, yyv21542) } - } else if yyl1485 != len(yyv1485) { - yyv1485 = yyv1485[:yyl1485] - yyc1485 = true + } else if yyl1542 != len(yyv1542) { + yyv1542 = yyv1542[:yyl1542] + yyc1542 = true } - yyj1485 := 0 - for ; yyj1485 < yyrr1485; yyj1485++ { - yyh1485.ElemContainerState(yyj1485) + yyj1542 := 0 + for ; yyj1542 < yyrr1542; yyj1542++ { + yyh1542.ElemContainerState(yyj1542) if r.TryDecodeAsNil() { - yyv1485[yyj1485] = NetworkPolicy{} + yyv1542[yyj1542] = NetworkPolicy{} } else { - yyv1486 := &yyv1485[yyj1485] - yyv1486.CodecDecodeSelf(d) + yyv1543 := &yyv1542[yyj1542] + yyv1543.CodecDecodeSelf(d) } } - if yyrt1485 { - for ; yyj1485 < yyl1485; yyj1485++ { - yyv1485 = append(yyv1485, NetworkPolicy{}) - yyh1485.ElemContainerState(yyj1485) + if yyrt1542 { + for ; yyj1542 < yyl1542; yyj1542++ { + yyv1542 = append(yyv1542, NetworkPolicy{}) + yyh1542.ElemContainerState(yyj1542) if r.TryDecodeAsNil() { - yyv1485[yyj1485] = NetworkPolicy{} + yyv1542[yyj1542] = NetworkPolicy{} } else { - yyv1487 := &yyv1485[yyj1485] - yyv1487.CodecDecodeSelf(d) + yyv1544 := &yyv1542[yyj1542] + yyv1544.CodecDecodeSelf(d) } } } } else { - yyj1485 := 0 - for ; !r.CheckBreak(); yyj1485++ { + yyj1542 := 0 + for ; !r.CheckBreak(); yyj1542++ { - if yyj1485 >= len(yyv1485) { - yyv1485 = append(yyv1485, NetworkPolicy{}) // var yyz1485 NetworkPolicy - yyc1485 = true + if yyj1542 >= len(yyv1542) { + yyv1542 = append(yyv1542, NetworkPolicy{}) // var yyz1542 NetworkPolicy + yyc1542 = true } - yyh1485.ElemContainerState(yyj1485) - if yyj1485 < len(yyv1485) { + yyh1542.ElemContainerState(yyj1542) + if yyj1542 < len(yyv1542) { if r.TryDecodeAsNil() { - yyv1485[yyj1485] = NetworkPolicy{} + yyv1542[yyj1542] = NetworkPolicy{} } else { - yyv1488 := &yyv1485[yyj1485] - yyv1488.CodecDecodeSelf(d) + yyv1545 := &yyv1542[yyj1542] + yyv1545.CodecDecodeSelf(d) } } else { @@ -18778,16 +19439,16 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. } } - if yyj1485 < len(yyv1485) { - yyv1485 = yyv1485[:yyj1485] - yyc1485 = true - } else if yyj1485 == 0 && yyv1485 == nil { - yyv1485 = []NetworkPolicy{} - yyc1485 = true + if yyj1542 < len(yyv1542) { + yyv1542 = yyv1542[:yyj1542] + yyc1542 = true + } else if yyj1542 == 0 && yyv1542 == nil { + yyv1542 = []NetworkPolicy{} + yyc1542 = true } } - yyh1485.End() - if yyc1485 { - *v = yyv1485 + yyh1542.End() + if yyc1542 { + *v = yyv1542 } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/types.go b/vendor/k8s.io/client-go/pkg/apis/extensions/types.go similarity index 89% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/types.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/types.go index 403331c..d66283e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/types.go @@ -29,10 +29,10 @@ support is experimental. package extensions import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/util/intstr" ) const ( @@ -45,6 +45,7 @@ const ( // describes the attributes of a scale subresource type ScaleSpec struct { // desired number of instances for the scaled object. + // +optional Replicas int32 `json:"replicas,omitempty"` } @@ -55,6 +56,7 @@ type ScaleStatus struct { // label query over pods that should match the replicas count. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` } @@ -65,12 +67,15 @@ type ScaleStatus struct { type Scale struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional api.ObjectMeta `json:"metadata,omitempty"` // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec ScaleSpec `json:"spec,omitempty"` // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional Status ScaleStatus `json:"status,omitempty"` } @@ -111,12 +116,15 @@ type ThirdPartyResource struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Description is the description of this object. + // +optional Description string `json:"description,omitempty"` // Versions are versions for this third party object + // +optional Versions []APIVersion `json:"versions,omitempty"` } @@ -124,6 +132,7 @@ type ThirdPartyResourceList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of horizontal pod autoscalers. @@ -134,6 +143,7 @@ type ThirdPartyResourceList struct { // TODO: we should consider merge this struct with GroupVersion in unversioned.go type APIVersion struct { // Name of this version (e.g. 'v1'). + // +optional Name string `json:"name,omitempty"` } @@ -141,9 +151,11 @@ type APIVersion struct { type ThirdPartyResourceData struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata. + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Data is the raw JSON data for this data. + // +optional Data []byte `json:"data,omitempty"` } @@ -151,44 +163,64 @@ type ThirdPartyResourceData struct { type Deployment struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // Specification of the desired behavior of the Deployment. + // +optional Spec DeploymentSpec `json:"spec,omitempty"` // Most recently observed status of the Deployment. + // +optional Status DeploymentStatus `json:"status,omitempty"` } type DeploymentSpec struct { // Number of desired pods. This is a pointer to distinguish between explicit // zero and not specified. Defaults to 1. + // +optional Replicas int32 `json:"replicas,omitempty"` // Label selector for pods. Existing ReplicaSets whose pods are // selected by this will be the ones affected by this deployment. + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // Template describes the pods that will be created. Template api.PodTemplateSpec `json:"template"` // The deployment strategy to use to replace existing pods with new ones. + // +optional Strategy DeploymentStrategy `json:"strategy,omitempty"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty"` // The number of old ReplicaSets to retain to allow rollback. // This is a pointer to distinguish between explicit zero and not specified. + // +optional RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty"` // Indicates that the deployment is paused and will not be processed by the // deployment controller. + // +optional Paused bool `json:"paused,omitempty"` + // The config this deployment is rolling back to. Will be cleared after rollback is done. + // +optional RollbackTo *RollbackConfig `json:"rollbackTo,omitempty"` + + // The maximum time in seconds for a deployment to make progress before it + // is considered to be failed. The deployment controller will continue to + // process failed deployments and a condition with a ProgressDeadlineExceeded + // reason will be surfaced in the deployment status. Once autoRollback is + // implemented, the deployment controller will automatically rollback failed + // deployments. Note that progress will not be estimated during the time a + // deployment is paused. This is not set by default. + ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty"` } // DeploymentRollback stores the information required to rollback a deployment. @@ -197,6 +229,7 @@ type DeploymentRollback struct { // Required: This must match the Name of a deployment. Name string `json:"name"` // The annotations to be updated to a deployment + // +optional UpdatedAnnotations map[string]string `json:"updatedAnnotations,omitempty"` // The config of this deployment rollback. RollbackTo RollbackConfig `json:"rollbackTo"` @@ -204,6 +237,7 @@ type DeploymentRollback struct { type RollbackConfig struct { // The revision to rollback to. If set to 0, rollbck to the last revision. + // +optional Revision int64 `json:"revision,omitempty"` } @@ -216,6 +250,7 @@ const ( type DeploymentStrategy struct { // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. + // +optional Type DeploymentStrategyType `json:"type,omitempty"` // Rolling update config params. Present only if DeploymentStrategyType = @@ -223,6 +258,7 @@ type DeploymentStrategy struct { //--- // TODO: Update this to follow our convention for oneOf, whatever we decide it // to be. + // +optional RollingUpdate *RollingUpdateDeployment `json:"rollingUpdate,omitempty"` } @@ -248,6 +284,7 @@ type RollingUpdateDeployment struct { // can be scaled down further, followed by scaling up the new RC, ensuring // that at least 70% of original number of pods are available at all times // during the update. + // +optional MaxUnavailable intstr.IntOrString `json:"maxUnavailable,omitempty"` // The maximum number of pods that can be scheduled above the original number of @@ -260,28 +297,71 @@ type RollingUpdateDeployment struct { // immediately when the rolling update starts. Once old pods have been killed, // new RC can be scaled up further, ensuring that total number of pods running // at any time during the update is atmost 130% of original pods. + // +optional MaxSurge intstr.IntOrString `json:"maxSurge,omitempty"` } type DeploymentStatus struct { // The generation observed by the deployment controller. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` // Total number of non-terminated pods targeted by this deployment (their labels match the selector). + // +optional Replicas int32 `json:"replicas,omitempty"` // Total number of non-terminated pods targeted by this deployment that have the desired template spec. + // +optional UpdatedReplicas int32 `json:"updatedReplicas,omitempty"` // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty"` // Total number of unavailable pods targeted by this deployment. + // +optional UnavailableReplicas int32 `json:"unavailableReplicas,omitempty"` + + // Represents the latest available observations of a deployment's current state. + Conditions []DeploymentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` +} + +type DeploymentConditionType string + +// These are valid conditions of a deployment. +const ( + // Available means the deployment is available, ie. at least the minimum available + // replicas required are up and running for at least minReadySeconds. + DeploymentAvailable DeploymentConditionType = "Available" + // Progressing means the deployment is progressing. Progress for a deployment is + // considered when a new replica set is created or adopted, and when new pods scale + // up or old pods scale down. Progress is not estimated for paused deployments or + // when progressDeadlineSeconds is not specified. + DeploymentProgressing DeploymentConditionType = "Progressing" + // ReplicaFailure is added in a deployment when one of its pods fails to be created + // or deleted. + DeploymentReplicaFailure DeploymentConditionType = "ReplicaFailure" +) + +// DeploymentCondition describes the state of a deployment at a certain point. +type DeploymentCondition struct { + // Type of deployment condition. + Type DeploymentConditionType `json:"type"` + // Status of the condition, one of True, False, Unknown. + Status api.ConditionStatus `json:"status"` + // The last time this condition was updated. + LastUpdateTime unversioned.Time `json:"lastUpdateTime,omitempty"` + // Last time the condition transitioned from one status to another. + LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` + // The reason for the condition's last transition. + Reason string `json:"reason,omitempty"` + // A human readable message indicating details about the transition. + Message string `json:"message,omitempty"` } type DeploymentList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of deployments. @@ -292,6 +372,7 @@ type DeploymentList struct { /* Commenting out for v1.2. We are planning to bring these types back with a more robust DaemonSet update implementation in v1.3, hence not deleting but just commenting the types out. type DaemonSetUpdateStrategy struct { // Type of daemon set update. Only "RollingUpdate" is supported at this time. Default is RollingUpdate. +// +optional Type DaemonSetUpdateStrategyType `json:"type,omitempty"` // Rolling update config params. Present only if DaemonSetUpdateStrategy = @@ -299,6 +380,7 @@ type DaemonSetUpdateStrategy struct { //--- // TODO: Update this to follow our convention for oneOf, whatever we decide it // to be. Same as DeploymentStrategy.RollingUpdate. +// +optional RollingUpdate *RollingUpdateDaemonSet `json:"rollingUpdate,omitempty"` } @@ -324,12 +406,14 @@ type RollingUpdateDaemonSet struct { // it then proceeds onto other DaemonSet pods, thus ensuring that at least // 70% of original number of DaemonSet pods are available at all times // during the update. +// +optional MaxUnavailable intstr.IntOrString `json:"maxUnavailable,omitempty"` // Minimum number of seconds for which a newly created DaemonSet pod should // be ready without any of its container crashing, for it to be considered // available. Defaults to 0 (pod will be considered available as soon as it // is ready). +// +optional MinReadySeconds int `json:"minReadySeconds,omitempty"` } */ @@ -340,6 +424,7 @@ type DaemonSetSpec struct { // Must match in order to be controlled. // If empty, defaulted to labels on Pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // Template is the object that describes the pod that will be created. @@ -351,17 +436,19 @@ type DaemonSetSpec struct { // TODO(madhusudancs): Uncomment while implementing DaemonSet updates. /* Commenting out for v1.2. We are planning to bring these fields back with a more robust DaemonSet update implementation in v1.3, hence not deleting but just commenting these fields out. - // Update strategy to replace existing DaemonSet pods with new pods. - UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty"` + // Update strategy to replace existing DaemonSet pods with new pods. + // +optional + UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty"` - // Label key that is added to DaemonSet pods to distinguish between old and - // new pod templates during DaemonSet update. - // Users can set this to an empty string to indicate that the system should - // not add any label. If unspecified, system uses - // DefaultDaemonSetUniqueLabelKey("daemonset.kubernetes.io/podTemplateHash"). - // Value of this key is hash of DaemonSetSpec.PodTemplateSpec. - // No label is added if this is set to empty string. - UniqueLabelKey string `json:"uniqueLabelKey,omitempty"` + // Label key that is added to DaemonSet pods to distinguish between old and + // new pod templates during DaemonSet update. + // Users can set this to an empty string to indicate that the system should + // not add any label. If unspecified, system uses + // DefaultDaemonSetUniqueLabelKey("daemonset.kubernetes.io/podTemplateHash"). + // Value of this key is hash of DaemonSetSpec.PodTemplateSpec. + // No label is added if this is set to empty string. + // +optional + UniqueLabelKey string `json:"uniqueLabelKey,omitempty"` */ } @@ -398,10 +485,12 @@ type DaemonSet struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Spec defines the desired behavior of this daemon set. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec DaemonSetSpec `json:"spec,omitempty"` // Status is the current status of this daemon set. This data may be @@ -409,6 +498,7 @@ type DaemonSet struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status DaemonSetStatus `json:"status,omitempty"` } @@ -417,6 +507,7 @@ type DaemonSetList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is a list of daemon sets. @@ -427,6 +518,7 @@ type ThirdPartyResourceDataList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is a list of third party objects Items []ThirdPartyResourceData `json:"items"` @@ -442,14 +534,17 @@ type Ingress struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional api.ObjectMeta `json:"metadata,omitempty"` // Spec is the desired state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec IngressSpec `json:"spec,omitempty"` // Status is the current state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status IngressStatus `json:"status,omitempty"` } @@ -458,6 +553,7 @@ type IngressList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of Ingress. @@ -470,6 +566,7 @@ type IngressSpec struct { // rule. At least one of 'backend' or 'rules' must be specified. This field // is optional to allow the loadbalancer controller or defaulting logic to // specify a global default. + // +optional Backend *IngressBackend `json:"backend,omitempty"` // TLS configuration. Currently the Ingress only supports a single TLS @@ -477,10 +574,12 @@ type IngressSpec struct { // will be multiplexed on the same port according to the hostname specified // through the SNI TLS extension, if the ingress controller fulfilling the // ingress supports SNI. + // +optional TLS []IngressTLS `json:"tls,omitempty"` // A list of host rules used to configure the Ingress. If unspecified, or // no rule matches, all traffic is sent to the default backend. + // +optional Rules []IngressRule `json:"rules,omitempty"` // TODO: Add the ability to specify load-balancer IP through claims } @@ -491,12 +590,14 @@ type IngressTLS struct { // this list must match the name/s used in the tlsSecret. Defaults to the // wildcard host setting for the loadbalancer controller fulfilling this // Ingress, if left unspecified. + // +optional Hosts []string `json:"hosts,omitempty"` // SecretName is the name of the secret used to terminate SSL traffic on 443. // Field is left optional to allow SSL routing based on SNI hostname alone. // If the SNI host in a listener conflicts with the "Host" header field used // by an IngressRule, the SNI host is used for termination and value of the // Host header is used for routing. + // +optional SecretName string `json:"secretName,omitempty"` // TODO: Consider specifying different modes of termination, protocols etc. } @@ -504,6 +605,7 @@ type IngressTLS struct { // IngressStatus describe the current state of the Ingress. type IngressStatus struct { // LoadBalancer contains the current status of the load-balancer. + // +optional LoadBalancer api.LoadBalancerStatus `json:"loadBalancer,omitempty"` } @@ -523,12 +625,14 @@ type IngressRule struct { // Incoming requests are matched against the host before the IngressRuleValue. // If the host is unspecified, the Ingress routes all traffic based on the // specified IngressRuleValue. + // +optional Host string `json:"host,omitempty"` // IngressRuleValue represents a rule to route requests for this IngressRule. // If unspecified, the rule defaults to a http catch-all. Whether that sends // just traffic matching the host to the default backend or all traffic to the // default backend, is left to the controller fulfilling the Ingress. Http is // currently the only supported IngressRuleValue. + // +optional IngressRuleValue `json:",inline,omitempty"` } @@ -543,6 +647,7 @@ type IngressRuleValue struct { // 2. Consider adding fields for ingress-type specific global options // usable by a loadbalancer, like http keep-alive. + // +optional HTTP *HTTPIngressRuleValue `json:"http,omitempty"` } @@ -568,6 +673,7 @@ type HTTPIngressPath struct { // part of a URL as defined by RFC 3986. Paths must begin with // a '/'. If unspecified, the path defaults to a catch all sending // traffic to the backend. + // +optional Path string `json:"path,omitempty"` // Backend defines the referenced service endpoint to which the traffic @@ -589,19 +695,23 @@ type IngressBackend struct { // ReplicaSet represents the configuration of a replica set. type ReplicaSet struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // Spec defines the desired behavior of this ReplicaSet. + // +optional Spec ReplicaSetSpec `json:"spec,omitempty"` // Status is the current status of this ReplicaSet. This data may be // out of date by some window of time. + // +optional Status ReplicaSetStatus `json:"status,omitempty"` } // ReplicaSetList is a collection of ReplicaSets. type ReplicaSetList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []ReplicaSet `json:"items"` @@ -617,16 +727,19 @@ type ReplicaSetSpec struct { // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty"` // Selector is a label query over pods that should match the replica count. // Must match in order to be controlled. // If empty, defaulted to labels on pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` // Template is the object that describes the pod that will be created if // insufficient replicas are detected. + // +optional Template api.PodTemplateSpec `json:"template,omitempty"` } @@ -636,18 +749,23 @@ type ReplicaSetStatus struct { Replicas int32 `json:"replicas"` // The number of pods that have labels matching the labels of the pod template of the replicaset. + // +optional FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty"` // The number of ready replicas for this replica set. + // +optional ReadyReplicas int32 `json:"readyReplicas,omitempty"` // The number of available replicas (ready for at least minReadySeconds) for this replica set. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty"` // ObservedGeneration is the most recent generation observed by the controller. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` // Represents the latest available observations of a replica set's current state. + // +optional Conditions []ReplicaSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` } @@ -667,13 +785,14 @@ type ReplicaSetCondition struct { Type ReplicaSetConditionType `json:"type"` // Status of the condition, one of True, False, Unknown. Status api.ConditionStatus `json:"status"` - // Last time we probed the condition. - LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` // The last time the condition transitioned from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` // The reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty"` // A human readable message indicating details about the transition. + // +optional Message string `json:"message,omitempty"` } @@ -684,37 +803,48 @@ type ReplicaSetCondition struct { // that will be applied to a pod and container. type PodSecurityPolicy struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // Spec defines the policy enforced. + // +optional Spec PodSecurityPolicySpec `json:"spec,omitempty"` } // PodSecurityPolicySpec defines the policy enforced. type PodSecurityPolicySpec struct { // Privileged determines if a pod can request to be run as privileged. + // +optional Privileged bool `json:"privileged,omitempty"` // DefaultAddCapabilities is the default set of capabilities that will be added to the container // unless the pod spec specifically drops the capability. You may not list a capability in both // DefaultAddCapabilities and RequiredDropCapabilities. + // +optional DefaultAddCapabilities []api.Capability `json:"defaultAddCapabilities,omitempty"` // RequiredDropCapabilities are the capabilities that will be dropped from the container. These // are required to be dropped and cannot be added. + // +optional RequiredDropCapabilities []api.Capability `json:"requiredDropCapabilities,omitempty"` // AllowedCapabilities is a list of capabilities that can be requested to add to the container. // Capabilities in this field may be added at the pod author's discretion. // You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities. + // +optional AllowedCapabilities []api.Capability `json:"allowedCapabilities,omitempty"` // Volumes is a white list of allowed volume plugins. Empty indicates that all plugins // may be used. + // +optional Volumes []FSType `json:"volumes,omitempty"` // HostNetwork determines if the policy allows the use of HostNetwork in the pod spec. + // +optional HostNetwork bool `json:"hostNetwork,omitempty"` // HostPorts determines which host port ranges are allowed to be exposed. + // +optional HostPorts []HostPortRange `json:"hostPorts,omitempty"` // HostPID determines if the policy allows the use of HostPID in the pod spec. + // +optional HostPID bool `json:"hostPID,omitempty"` // HostIPC determines if the policy allows the use of HostIPC in the pod spec. + // +optional HostIPC bool `json:"hostIPC,omitempty"` // SELinux is the strategy that will dictate the allowable labels that may be set. SELinux SELinuxStrategyOptions `json:"seLinux"` @@ -729,6 +859,7 @@ type PodSecurityPolicySpec struct { // the PSP should deny the pod. // If set to false the container may run with a read only root file system if it wishes but it // will not be forced to. + // +optional ReadOnlyRootFilesystem bool `json:"readOnlyRootFilesystem,omitempty"` } @@ -776,6 +907,7 @@ type SELinuxStrategyOptions struct { Rule SELinuxStrategy `json:"rule"` // seLinuxOptions required to run as; required for MustRunAs // More info: http://releases.k8s.io/HEAD/docs/design/security_context.md#security-context + // +optional SELinuxOptions *api.SELinuxOptions `json:"seLinuxOptions,omitempty"` } @@ -795,6 +927,7 @@ type RunAsUserStrategyOptions struct { // Rule is the strategy that will dictate the allowable RunAsUser values that may be set. Rule RunAsUserStrategy `json:"rule"` // Ranges are the allowed ranges of uids that may be used. + // +optional Ranges []IDRange `json:"ranges,omitempty"` } @@ -822,9 +955,11 @@ const ( // FSGroupStrategyOptions defines the strategy type and options used to create the strategy. type FSGroupStrategyOptions struct { // Rule is the strategy that will dictate what FSGroup is used in the SecurityContext. + // +optional Rule FSGroupStrategyType `json:"rule,omitempty"` // Ranges are the allowed ranges of fs groups. If you would like to force a single // fs group then supply a single range with the same start and end. + // +optional Ranges []IDRange `json:"ranges,omitempty"` } @@ -842,9 +977,11 @@ const ( // SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy. type SupplementalGroupsStrategyOptions struct { // Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext. + // +optional Rule SupplementalGroupsStrategyType `json:"rule,omitempty"` // Ranges are the allowed ranges of supplemental groups. If you would like to force a single // supplemental group then supply a single range with the same start and end. + // +optional Ranges []IDRange `json:"ranges,omitempty"` } @@ -862,6 +999,7 @@ const ( // PodSecurityPolicyList is a list of PodSecurityPolicy objects. type PodSecurityPolicyList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []PodSecurityPolicy `json:"items"` @@ -871,9 +1009,11 @@ type PodSecurityPolicyList struct { type NetworkPolicy struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // Specification of the desired behavior for this NetworkPolicy. + // +optional Spec NetworkPolicySpec `json:"spec,omitempty"` } @@ -893,6 +1033,7 @@ type NetworkPolicySpec struct { // If this field is empty then this NetworkPolicy does not affect ingress isolation. // If this field is present and contains at least one rule, this policy allows any traffic // which matches at least one of the ingress rules in this list. + // +optional Ingress []NetworkPolicyIngressRule `json:"ingress,omitempty"` } @@ -905,6 +1046,7 @@ type NetworkPolicyIngressRule struct { // If this field is present and contains at least one item, then this rule allows traffic // only if the traffic matches at least one port in the list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional Ports []NetworkPolicyPort `json:"ports,omitempty"` // List of sources which should be able to access the pods selected for this rule. @@ -914,12 +1056,14 @@ type NetworkPolicyIngressRule struct { // If this field is present and contains at least on item, this rule allows traffic only if the // traffic matches at least one item in the from list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional From []NetworkPolicyPeer `json:"from,omitempty"` } type NetworkPolicyPort struct { // Optional. The protocol (TCP or UDP) which traffic must match. // If not specified, this field defaults to TCP. + // +optional Protocol *api.Protocol `json:"protocol,omitempty"` // If specified, the port on the given protocol. This can @@ -927,6 +1071,7 @@ type NetworkPolicyPort struct { // this matches all port names and numbers. // If present, only traffic on the specified protocol AND port // will be matched. + // +optional Port *intstr.IntOrString `json:"port,omitempty"` } @@ -937,6 +1082,7 @@ type NetworkPolicyPeer struct { // This field follows standard label selector semantics. // If not provided, this selector selects no pods. // If present but empty, this selector selects all pods in this namespace. + // +optional PodSelector *unversioned.LabelSelector `json:"podSelector,omitempty"` // Selects Namespaces using cluster scoped-labels. This @@ -944,12 +1090,14 @@ type NetworkPolicyPeer struct { // This field follows standard label selector semantics. // If omitted, this selector selects no namespaces. // If present but empty, this selector selects all namespaces. + // +optional NamespaceSelector *unversioned.LabelSelector `json:"namespaceSelector,omitempty"` } // NetworkPolicyList is a list of NetworkPolicy objects. type NetworkPolicyList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []NetworkPolicy `json:"items"` diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/conversion.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/conversion.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/conversion.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/conversion.go index dddd7cf..38f7a27 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/conversion.go @@ -19,15 +19,15 @@ package v1beta1 import ( "fmt" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/apis/autoscaling" + "k8s.io/client-go/pkg/apis/batch" + "k8s.io/client-go/pkg/apis/extensions" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/intstr" ) func addConversionFuncs(scheme *runtime.Scheme) error { @@ -134,14 +134,7 @@ func Convert_v1beta1_ScaleStatus_To_extensions_ScaleStatus(in *ScaleStatus, out func Convert_extensions_DeploymentSpec_To_v1beta1_DeploymentSpec(in *extensions.DeploymentSpec, out *DeploymentSpec, s conversion.Scope) error { out.Replicas = &in.Replicas - if in.Selector != nil { - out.Selector = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -160,6 +153,10 @@ func Convert_extensions_DeploymentSpec_To_v1beta1_DeploymentSpec(in *extensions. } else { out.RollbackTo = nil } + if in.ProgressDeadlineSeconds != nil { + out.ProgressDeadlineSeconds = new(int32) + *out.ProgressDeadlineSeconds = *in.ProgressDeadlineSeconds + } return nil } @@ -167,15 +164,7 @@ func Convert_v1beta1_DeploymentSpec_To_extensions_DeploymentSpec(in *DeploymentS if in.Replicas != nil { out.Replicas = *in.Replicas } - - if in.Selector != nil { - out.Selector = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -191,6 +180,10 @@ func Convert_v1beta1_DeploymentSpec_To_extensions_DeploymentSpec(in *DeploymentS } else { out.RollbackTo = nil } + if in.ProgressDeadlineSeconds != nil { + out.ProgressDeadlineSeconds = new(int32) + *out.ProgressDeadlineSeconds = *in.ProgressDeadlineSeconds + } return nil } @@ -250,15 +243,7 @@ func Convert_extensions_ReplicaSetSpec_To_v1beta1_ReplicaSetSpec(in *extensions. out.Replicas = new(int32) *out.Replicas = int32(in.Replicas) out.MinReadySeconds = in.MinReadySeconds - if in.Selector != nil { - out.Selector = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } - + out.Selector = in.Selector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -270,14 +255,7 @@ func Convert_v1beta1_ReplicaSetSpec_To_extensions_ReplicaSetSpec(in *ReplicaSetS out.Replicas = *in.Replicas } out.MinReadySeconds = in.MinReadySeconds - if in.Selector != nil { - out.Selector = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -288,16 +266,7 @@ func Convert_batch_JobSpec_To_v1beta1_JobSpec(in *batch.JobSpec, out *JobSpec, s out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for unversioned.LabelSelector -> v1beta1.LabelSelector - if in.Selector != nil { - out.Selector = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } - + out.Selector = in.Selector // BEGIN non-standard conversion // autoSelector has opposite meaning as manualSelector. // in both cases, unset means false, and unset is always preferred to false. @@ -322,16 +291,7 @@ func Convert_v1beta1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSpec, s out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - // unable to generate simple pointer conversion for v1beta1.LabelSelector -> unversioned.LabelSelector - if in.Selector != nil { - out.Selector = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in.Selector, out.Selector, s); err != nil { - return err - } - } else { - out.Selector = nil - } - + out.Selector = in.Selector // BEGIN non-standard conversion // autoSelector has opposite meaning as manualSelector. // in both cases, unset means false, and unset is always preferred to false. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/defaults.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/defaults.go index 0708b11..2704d67 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/defaults.go @@ -17,12 +17,14 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/intstr" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( SetDefaults_DaemonSet, SetDefaults_Deployment, @@ -39,7 +41,7 @@ func SetDefaults_DaemonSet(obj *DaemonSet) { // TODO: support templates defined elsewhere when we support them in the API if labels != nil { if obj.Spec.Selector == nil { - obj.Spec.Selector = &LabelSelector{ + obj.Spec.Selector = &unversioned.LabelSelector{ MatchLabels: labels, } } @@ -55,7 +57,7 @@ func SetDefaults_Deployment(obj *Deployment) { if labels != nil { if obj.Spec.Selector == nil { - obj.Spec.Selector = &LabelSelector{MatchLabels: labels} + obj.Spec.Selector = &unversioned.LabelSelector{MatchLabels: labels} } if len(obj.Labels) == 0 { obj.Labels = labels @@ -71,7 +73,7 @@ func SetDefaults_Deployment(obj *Deployment) { if strategy.Type == "" { strategy.Type = RollingUpdateDeploymentStrategyType } - if strategy.Type == RollingUpdateDeploymentStrategyType { + if strategy.Type == RollingUpdateDeploymentStrategyType || strategy.RollingUpdate != nil { if strategy.RollingUpdate == nil { rollingUpdate := RollingUpdateDeployment{} strategy.RollingUpdate = &rollingUpdate @@ -101,7 +103,7 @@ func SetDefaults_Job(obj *Job) { // and default behavior for an unspecified manual selector is to use the pod template labels if manualSelector && obj.Spec.Selector == nil { - obj.Spec.Selector = &LabelSelector{ + obj.Spec.Selector = &unversioned.LabelSelector{ MatchLabels: labels, } } @@ -139,7 +141,7 @@ func SetDefaults_ReplicaSet(obj *ReplicaSet) { // TODO: support templates defined elsewhere when we support them in the API if labels != nil { if obj.Spec.Selector == nil { - obj.Spec.Selector = &LabelSelector{ + obj.Spec.Selector = &unversioned.LabelSelector{ MatchLabels: labels, } } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/doc.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/doc.go index a9520c2..2a7ce91 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/doc.go @@ -19,5 +19,6 @@ limitations under the License. // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/autoscaling // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/batch // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.pb.go similarity index 87% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.pb.go index e847a4b..0260da7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.pb.go @@ -36,6 +36,7 @@ limitations under the License. DaemonSetSpec DaemonSetStatus Deployment + DeploymentCondition DeploymentList DeploymentRollback DeploymentSpec @@ -64,8 +65,6 @@ limitations under the License. JobList JobSpec JobStatus - LabelSelector - LabelSelectorRequirement NetworkPolicy NetworkPolicyIngressRule NetworkPolicyList @@ -101,10 +100,10 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_api_v1 "k8s.io/kubernetes/pkg/api/v1" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_v1 "k8s.io/client-go/pkg/api/v1" -import k8s_io_kubernetes_pkg_util_intstr "k8s.io/kubernetes/pkg/util/intstr" +import k8s_io_kubernetes_pkg_util_intstr "k8s.io/client-go/pkg/util/intstr" import strings "strings" import reflect "reflect" @@ -169,330 +168,323 @@ func (m *Deployment) Reset() { *m = Deployment{} } func (*Deployment) ProtoMessage() {} func (*Deployment) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{10} } +func (m *DeploymentCondition) Reset() { *m = DeploymentCondition{} } +func (*DeploymentCondition) ProtoMessage() {} +func (*DeploymentCondition) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{11} } + func (m *DeploymentList) Reset() { *m = DeploymentList{} } func (*DeploymentList) ProtoMessage() {} -func (*DeploymentList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{11} } +func (*DeploymentList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{12} } func (m *DeploymentRollback) Reset() { *m = DeploymentRollback{} } func (*DeploymentRollback) ProtoMessage() {} -func (*DeploymentRollback) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{12} } +func (*DeploymentRollback) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{13} } func (m *DeploymentSpec) Reset() { *m = DeploymentSpec{} } func (*DeploymentSpec) ProtoMessage() {} -func (*DeploymentSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{13} } +func (*DeploymentSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{14} } func (m *DeploymentStatus) Reset() { *m = DeploymentStatus{} } func (*DeploymentStatus) ProtoMessage() {} -func (*DeploymentStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{14} } +func (*DeploymentStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{15} } func (m *DeploymentStrategy) Reset() { *m = DeploymentStrategy{} } func (*DeploymentStrategy) ProtoMessage() {} -func (*DeploymentStrategy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{15} } +func (*DeploymentStrategy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{16} } func (m *ExportOptions) Reset() { *m = ExportOptions{} } func (*ExportOptions) ProtoMessage() {} -func (*ExportOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{16} } +func (*ExportOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{17} } func (m *FSGroupStrategyOptions) Reset() { *m = FSGroupStrategyOptions{} } func (*FSGroupStrategyOptions) ProtoMessage() {} -func (*FSGroupStrategyOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{17} } +func (*FSGroupStrategyOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{18} } func (m *HTTPIngressPath) Reset() { *m = HTTPIngressPath{} } func (*HTTPIngressPath) ProtoMessage() {} -func (*HTTPIngressPath) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{18} } +func (*HTTPIngressPath) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{19} } func (m *HTTPIngressRuleValue) Reset() { *m = HTTPIngressRuleValue{} } func (*HTTPIngressRuleValue) ProtoMessage() {} -func (*HTTPIngressRuleValue) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{19} } +func (*HTTPIngressRuleValue) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{20} } func (m *HorizontalPodAutoscaler) Reset() { *m = HorizontalPodAutoscaler{} } func (*HorizontalPodAutoscaler) ProtoMessage() {} func (*HorizontalPodAutoscaler) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{20} + return fileDescriptorGenerated, []int{21} } func (m *HorizontalPodAutoscalerList) Reset() { *m = HorizontalPodAutoscalerList{} } func (*HorizontalPodAutoscalerList) ProtoMessage() {} func (*HorizontalPodAutoscalerList) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{21} + return fileDescriptorGenerated, []int{22} } func (m *HorizontalPodAutoscalerSpec) Reset() { *m = HorizontalPodAutoscalerSpec{} } func (*HorizontalPodAutoscalerSpec) ProtoMessage() {} func (*HorizontalPodAutoscalerSpec) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{22} + return fileDescriptorGenerated, []int{23} } func (m *HorizontalPodAutoscalerStatus) Reset() { *m = HorizontalPodAutoscalerStatus{} } func (*HorizontalPodAutoscalerStatus) ProtoMessage() {} func (*HorizontalPodAutoscalerStatus) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{23} + return fileDescriptorGenerated, []int{24} } func (m *HostPortRange) Reset() { *m = HostPortRange{} } func (*HostPortRange) ProtoMessage() {} -func (*HostPortRange) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{24} } +func (*HostPortRange) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{25} } func (m *IDRange) Reset() { *m = IDRange{} } func (*IDRange) ProtoMessage() {} -func (*IDRange) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{25} } +func (*IDRange) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{26} } func (m *Ingress) Reset() { *m = Ingress{} } func (*Ingress) ProtoMessage() {} -func (*Ingress) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{26} } +func (*Ingress) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{27} } func (m *IngressBackend) Reset() { *m = IngressBackend{} } func (*IngressBackend) ProtoMessage() {} -func (*IngressBackend) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{27} } +func (*IngressBackend) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{28} } func (m *IngressList) Reset() { *m = IngressList{} } func (*IngressList) ProtoMessage() {} -func (*IngressList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{28} } +func (*IngressList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{29} } func (m *IngressRule) Reset() { *m = IngressRule{} } func (*IngressRule) ProtoMessage() {} -func (*IngressRule) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{29} } +func (*IngressRule) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{30} } func (m *IngressRuleValue) Reset() { *m = IngressRuleValue{} } func (*IngressRuleValue) ProtoMessage() {} -func (*IngressRuleValue) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{30} } +func (*IngressRuleValue) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{31} } func (m *IngressSpec) Reset() { *m = IngressSpec{} } func (*IngressSpec) ProtoMessage() {} -func (*IngressSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{31} } +func (*IngressSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{32} } func (m *IngressStatus) Reset() { *m = IngressStatus{} } func (*IngressStatus) ProtoMessage() {} -func (*IngressStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{32} } +func (*IngressStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{33} } func (m *IngressTLS) Reset() { *m = IngressTLS{} } func (*IngressTLS) ProtoMessage() {} -func (*IngressTLS) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{33} } +func (*IngressTLS) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{34} } func (m *Job) Reset() { *m = Job{} } func (*Job) ProtoMessage() {} -func (*Job) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{34} } +func (*Job) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{35} } func (m *JobCondition) Reset() { *m = JobCondition{} } func (*JobCondition) ProtoMessage() {} -func (*JobCondition) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{35} } +func (*JobCondition) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{36} } func (m *JobList) Reset() { *m = JobList{} } func (*JobList) ProtoMessage() {} -func (*JobList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{36} } +func (*JobList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{37} } func (m *JobSpec) Reset() { *m = JobSpec{} } func (*JobSpec) ProtoMessage() {} -func (*JobSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{37} } +func (*JobSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{38} } func (m *JobStatus) Reset() { *m = JobStatus{} } func (*JobStatus) ProtoMessage() {} -func (*JobStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{38} } - -func (m *LabelSelector) Reset() { *m = LabelSelector{} } -func (*LabelSelector) ProtoMessage() {} -func (*LabelSelector) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{39} } - -func (m *LabelSelectorRequirement) Reset() { *m = LabelSelectorRequirement{} } -func (*LabelSelectorRequirement) ProtoMessage() {} -func (*LabelSelectorRequirement) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{40} -} +func (*JobStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{39} } func (m *NetworkPolicy) Reset() { *m = NetworkPolicy{} } func (*NetworkPolicy) ProtoMessage() {} -func (*NetworkPolicy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{41} } +func (*NetworkPolicy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{40} } func (m *NetworkPolicyIngressRule) Reset() { *m = NetworkPolicyIngressRule{} } func (*NetworkPolicyIngressRule) ProtoMessage() {} func (*NetworkPolicyIngressRule) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{42} + return fileDescriptorGenerated, []int{41} } func (m *NetworkPolicyList) Reset() { *m = NetworkPolicyList{} } func (*NetworkPolicyList) ProtoMessage() {} -func (*NetworkPolicyList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{43} } +func (*NetworkPolicyList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{42} } func (m *NetworkPolicyPeer) Reset() { *m = NetworkPolicyPeer{} } func (*NetworkPolicyPeer) ProtoMessage() {} -func (*NetworkPolicyPeer) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{44} } +func (*NetworkPolicyPeer) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{43} } func (m *NetworkPolicyPort) Reset() { *m = NetworkPolicyPort{} } func (*NetworkPolicyPort) ProtoMessage() {} -func (*NetworkPolicyPort) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{45} } +func (*NetworkPolicyPort) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{44} } func (m *NetworkPolicySpec) Reset() { *m = NetworkPolicySpec{} } func (*NetworkPolicySpec) ProtoMessage() {} -func (*NetworkPolicySpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{46} } +func (*NetworkPolicySpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{45} } func (m *PodSecurityPolicy) Reset() { *m = PodSecurityPolicy{} } func (*PodSecurityPolicy) ProtoMessage() {} -func (*PodSecurityPolicy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{47} } +func (*PodSecurityPolicy) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{46} } func (m *PodSecurityPolicyList) Reset() { *m = PodSecurityPolicyList{} } func (*PodSecurityPolicyList) ProtoMessage() {} -func (*PodSecurityPolicyList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{48} } +func (*PodSecurityPolicyList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{47} } func (m *PodSecurityPolicySpec) Reset() { *m = PodSecurityPolicySpec{} } func (*PodSecurityPolicySpec) ProtoMessage() {} -func (*PodSecurityPolicySpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{49} } +func (*PodSecurityPolicySpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{48} } func (m *ReplicaSet) Reset() { *m = ReplicaSet{} } func (*ReplicaSet) ProtoMessage() {} -func (*ReplicaSet) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{50} } +func (*ReplicaSet) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{49} } func (m *ReplicaSetCondition) Reset() { *m = ReplicaSetCondition{} } func (*ReplicaSetCondition) ProtoMessage() {} -func (*ReplicaSetCondition) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{51} } +func (*ReplicaSetCondition) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{50} } func (m *ReplicaSetList) Reset() { *m = ReplicaSetList{} } func (*ReplicaSetList) ProtoMessage() {} -func (*ReplicaSetList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{52} } +func (*ReplicaSetList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{51} } func (m *ReplicaSetSpec) Reset() { *m = ReplicaSetSpec{} } func (*ReplicaSetSpec) ProtoMessage() {} -func (*ReplicaSetSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{53} } +func (*ReplicaSetSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{52} } func (m *ReplicaSetStatus) Reset() { *m = ReplicaSetStatus{} } func (*ReplicaSetStatus) ProtoMessage() {} -func (*ReplicaSetStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{54} } +func (*ReplicaSetStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{53} } func (m *ReplicationControllerDummy) Reset() { *m = ReplicationControllerDummy{} } func (*ReplicationControllerDummy) ProtoMessage() {} func (*ReplicationControllerDummy) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{55} + return fileDescriptorGenerated, []int{54} } func (m *RollbackConfig) Reset() { *m = RollbackConfig{} } func (*RollbackConfig) ProtoMessage() {} -func (*RollbackConfig) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{56} } +func (*RollbackConfig) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{55} } func (m *RollingUpdateDeployment) Reset() { *m = RollingUpdateDeployment{} } func (*RollingUpdateDeployment) ProtoMessage() {} func (*RollingUpdateDeployment) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{57} + return fileDescriptorGenerated, []int{56} } func (m *RunAsUserStrategyOptions) Reset() { *m = RunAsUserStrategyOptions{} } func (*RunAsUserStrategyOptions) ProtoMessage() {} func (*RunAsUserStrategyOptions) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{58} + return fileDescriptorGenerated, []int{57} } func (m *SELinuxStrategyOptions) Reset() { *m = SELinuxStrategyOptions{} } func (*SELinuxStrategyOptions) ProtoMessage() {} -func (*SELinuxStrategyOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{59} } +func (*SELinuxStrategyOptions) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{58} } func (m *Scale) Reset() { *m = Scale{} } func (*Scale) ProtoMessage() {} -func (*Scale) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{60} } +func (*Scale) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{59} } func (m *ScaleSpec) Reset() { *m = ScaleSpec{} } func (*ScaleSpec) ProtoMessage() {} -func (*ScaleSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{61} } +func (*ScaleSpec) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{60} } func (m *ScaleStatus) Reset() { *m = ScaleStatus{} } func (*ScaleStatus) ProtoMessage() {} -func (*ScaleStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{62} } +func (*ScaleStatus) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{61} } func (m *SubresourceReference) Reset() { *m = SubresourceReference{} } func (*SubresourceReference) ProtoMessage() {} -func (*SubresourceReference) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{63} } +func (*SubresourceReference) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{62} } func (m *SupplementalGroupsStrategyOptions) Reset() { *m = SupplementalGroupsStrategyOptions{} } func (*SupplementalGroupsStrategyOptions) ProtoMessage() {} func (*SupplementalGroupsStrategyOptions) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{64} + return fileDescriptorGenerated, []int{63} } func (m *ThirdPartyResource) Reset() { *m = ThirdPartyResource{} } func (*ThirdPartyResource) ProtoMessage() {} -func (*ThirdPartyResource) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{65} } +func (*ThirdPartyResource) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{64} } func (m *ThirdPartyResourceData) Reset() { *m = ThirdPartyResourceData{} } func (*ThirdPartyResourceData) ProtoMessage() {} -func (*ThirdPartyResourceData) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{66} } +func (*ThirdPartyResourceData) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{65} } func (m *ThirdPartyResourceDataList) Reset() { *m = ThirdPartyResourceDataList{} } func (*ThirdPartyResourceDataList) ProtoMessage() {} func (*ThirdPartyResourceDataList) Descriptor() ([]byte, []int) { - return fileDescriptorGenerated, []int{67} + return fileDescriptorGenerated, []int{66} } func (m *ThirdPartyResourceList) Reset() { *m = ThirdPartyResourceList{} } func (*ThirdPartyResourceList) ProtoMessage() {} -func (*ThirdPartyResourceList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{68} } +func (*ThirdPartyResourceList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{67} } func init() { - proto.RegisterType((*APIVersion)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.APIVersion") - proto.RegisterType((*CPUTargetUtilization)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.CPUTargetUtilization") - proto.RegisterType((*CustomMetricCurrentStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.CustomMetricCurrentStatus") - proto.RegisterType((*CustomMetricCurrentStatusList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.CustomMetricCurrentStatusList") - proto.RegisterType((*CustomMetricTarget)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.CustomMetricTarget") - proto.RegisterType((*CustomMetricTargetList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.CustomMetricTargetList") - proto.RegisterType((*DaemonSet)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DaemonSet") - proto.RegisterType((*DaemonSetList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DaemonSetList") - proto.RegisterType((*DaemonSetSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DaemonSetSpec") - proto.RegisterType((*DaemonSetStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DaemonSetStatus") - proto.RegisterType((*Deployment)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.Deployment") - proto.RegisterType((*DeploymentList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DeploymentList") - proto.RegisterType((*DeploymentRollback)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DeploymentRollback") - proto.RegisterType((*DeploymentSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DeploymentSpec") - proto.RegisterType((*DeploymentStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DeploymentStatus") - proto.RegisterType((*DeploymentStrategy)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.DeploymentStrategy") - proto.RegisterType((*ExportOptions)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ExportOptions") - proto.RegisterType((*FSGroupStrategyOptions)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.FSGroupStrategyOptions") - proto.RegisterType((*HTTPIngressPath)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HTTPIngressPath") - proto.RegisterType((*HTTPIngressRuleValue)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HTTPIngressRuleValue") - proto.RegisterType((*HorizontalPodAutoscaler)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HorizontalPodAutoscaler") - proto.RegisterType((*HorizontalPodAutoscalerList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerList") - proto.RegisterType((*HorizontalPodAutoscalerSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerSpec") - proto.RegisterType((*HorizontalPodAutoscalerStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerStatus") - proto.RegisterType((*HostPortRange)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.HostPortRange") - proto.RegisterType((*IDRange)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IDRange") - proto.RegisterType((*Ingress)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.Ingress") - proto.RegisterType((*IngressBackend)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressBackend") - proto.RegisterType((*IngressList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressList") - proto.RegisterType((*IngressRule)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressRule") - proto.RegisterType((*IngressRuleValue)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressRuleValue") - proto.RegisterType((*IngressSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressSpec") - proto.RegisterType((*IngressStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressStatus") - proto.RegisterType((*IngressTLS)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.IngressTLS") - proto.RegisterType((*Job)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.Job") - proto.RegisterType((*JobCondition)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.JobCondition") - proto.RegisterType((*JobList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.JobList") - proto.RegisterType((*JobSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.JobSpec") - proto.RegisterType((*JobStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.JobStatus") - proto.RegisterType((*LabelSelector)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.LabelSelector") - proto.RegisterType((*LabelSelectorRequirement)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.LabelSelectorRequirement") - proto.RegisterType((*NetworkPolicy)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicy") - proto.RegisterType((*NetworkPolicyIngressRule)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicyIngressRule") - proto.RegisterType((*NetworkPolicyList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicyList") - proto.RegisterType((*NetworkPolicyPeer)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicyPeer") - proto.RegisterType((*NetworkPolicyPort)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicyPort") - proto.RegisterType((*NetworkPolicySpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.NetworkPolicySpec") - proto.RegisterType((*PodSecurityPolicy)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.PodSecurityPolicy") - proto.RegisterType((*PodSecurityPolicyList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.PodSecurityPolicyList") - proto.RegisterType((*PodSecurityPolicySpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.PodSecurityPolicySpec") - proto.RegisterType((*ReplicaSet)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicaSet") - proto.RegisterType((*ReplicaSetCondition)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicaSetCondition") - proto.RegisterType((*ReplicaSetList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicaSetList") - proto.RegisterType((*ReplicaSetSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicaSetSpec") - proto.RegisterType((*ReplicaSetStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicaSetStatus") - proto.RegisterType((*ReplicationControllerDummy)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ReplicationControllerDummy") - proto.RegisterType((*RollbackConfig)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.RollbackConfig") - proto.RegisterType((*RollingUpdateDeployment)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.RollingUpdateDeployment") - proto.RegisterType((*RunAsUserStrategyOptions)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.RunAsUserStrategyOptions") - proto.RegisterType((*SELinuxStrategyOptions)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.SELinuxStrategyOptions") - proto.RegisterType((*Scale)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.Scale") - proto.RegisterType((*ScaleSpec)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ScaleSpec") - proto.RegisterType((*ScaleStatus)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ScaleStatus") - proto.RegisterType((*SubresourceReference)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.SubresourceReference") - proto.RegisterType((*SupplementalGroupsStrategyOptions)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.SupplementalGroupsStrategyOptions") - proto.RegisterType((*ThirdPartyResource)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ThirdPartyResource") - proto.RegisterType((*ThirdPartyResourceData)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ThirdPartyResourceData") - proto.RegisterType((*ThirdPartyResourceDataList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ThirdPartyResourceDataList") - proto.RegisterType((*ThirdPartyResourceList)(nil), "k8s.io.kubernetes.pkg.apis.extensions.v1beta1.ThirdPartyResourceList") + proto.RegisterType((*APIVersion)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.APIVersion") + proto.RegisterType((*CPUTargetUtilization)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.CPUTargetUtilization") + proto.RegisterType((*CustomMetricCurrentStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.CustomMetricCurrentStatus") + proto.RegisterType((*CustomMetricCurrentStatusList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.CustomMetricCurrentStatusList") + proto.RegisterType((*CustomMetricTarget)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.CustomMetricTarget") + proto.RegisterType((*CustomMetricTargetList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.CustomMetricTargetList") + proto.RegisterType((*DaemonSet)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DaemonSet") + proto.RegisterType((*DaemonSetList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DaemonSetList") + proto.RegisterType((*DaemonSetSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DaemonSetSpec") + proto.RegisterType((*DaemonSetStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DaemonSetStatus") + proto.RegisterType((*Deployment)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.Deployment") + proto.RegisterType((*DeploymentCondition)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentCondition") + proto.RegisterType((*DeploymentList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentList") + proto.RegisterType((*DeploymentRollback)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentRollback") + proto.RegisterType((*DeploymentSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentSpec") + proto.RegisterType((*DeploymentStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentStatus") + proto.RegisterType((*DeploymentStrategy)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.DeploymentStrategy") + proto.RegisterType((*ExportOptions)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ExportOptions") + proto.RegisterType((*FSGroupStrategyOptions)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.FSGroupStrategyOptions") + proto.RegisterType((*HTTPIngressPath)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HTTPIngressPath") + proto.RegisterType((*HTTPIngressRuleValue)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HTTPIngressRuleValue") + proto.RegisterType((*HorizontalPodAutoscaler)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HorizontalPodAutoscaler") + proto.RegisterType((*HorizontalPodAutoscalerList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerList") + proto.RegisterType((*HorizontalPodAutoscalerSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerSpec") + proto.RegisterType((*HorizontalPodAutoscalerStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HorizontalPodAutoscalerStatus") + proto.RegisterType((*HostPortRange)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.HostPortRange") + proto.RegisterType((*IDRange)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IDRange") + proto.RegisterType((*Ingress)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.Ingress") + proto.RegisterType((*IngressBackend)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressBackend") + proto.RegisterType((*IngressList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressList") + proto.RegisterType((*IngressRule)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressRule") + proto.RegisterType((*IngressRuleValue)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressRuleValue") + proto.RegisterType((*IngressSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressSpec") + proto.RegisterType((*IngressStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressStatus") + proto.RegisterType((*IngressTLS)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.IngressTLS") + proto.RegisterType((*Job)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.Job") + proto.RegisterType((*JobCondition)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.JobCondition") + proto.RegisterType((*JobList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.JobList") + proto.RegisterType((*JobSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.JobSpec") + proto.RegisterType((*JobStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.JobStatus") + proto.RegisterType((*NetworkPolicy)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicy") + proto.RegisterType((*NetworkPolicyIngressRule)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicyIngressRule") + proto.RegisterType((*NetworkPolicyList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicyList") + proto.RegisterType((*NetworkPolicyPeer)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicyPeer") + proto.RegisterType((*NetworkPolicyPort)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicyPort") + proto.RegisterType((*NetworkPolicySpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.NetworkPolicySpec") + proto.RegisterType((*PodSecurityPolicy)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.PodSecurityPolicy") + proto.RegisterType((*PodSecurityPolicyList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.PodSecurityPolicyList") + proto.RegisterType((*PodSecurityPolicySpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.PodSecurityPolicySpec") + proto.RegisterType((*ReplicaSet)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicaSet") + proto.RegisterType((*ReplicaSetCondition)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicaSetCondition") + proto.RegisterType((*ReplicaSetList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicaSetList") + proto.RegisterType((*ReplicaSetSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicaSetSpec") + proto.RegisterType((*ReplicaSetStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicaSetStatus") + proto.RegisterType((*ReplicationControllerDummy)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ReplicationControllerDummy") + proto.RegisterType((*RollbackConfig)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.RollbackConfig") + proto.RegisterType((*RollingUpdateDeployment)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.RollingUpdateDeployment") + proto.RegisterType((*RunAsUserStrategyOptions)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.RunAsUserStrategyOptions") + proto.RegisterType((*SELinuxStrategyOptions)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.SELinuxStrategyOptions") + proto.RegisterType((*Scale)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.Scale") + proto.RegisterType((*ScaleSpec)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ScaleSpec") + proto.RegisterType((*ScaleStatus)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ScaleStatus") + proto.RegisterType((*SubresourceReference)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.SubresourceReference") + proto.RegisterType((*SupplementalGroupsStrategyOptions)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.SupplementalGroupsStrategyOptions") + proto.RegisterType((*ThirdPartyResource)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ThirdPartyResource") + proto.RegisterType((*ThirdPartyResourceData)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ThirdPartyResourceData") + proto.RegisterType((*ThirdPartyResourceDataList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ThirdPartyResourceDataList") + proto.RegisterType((*ThirdPartyResourceList)(nil), "k8s.io.client-go.pkg.apis.extensions.v1beta1.ThirdPartyResourceList") } func (m *APIVersion) Marshal() (data []byte, err error) { size := m.Size() @@ -845,6 +837,56 @@ func (m *Deployment) MarshalTo(data []byte) (int, error) { return i, nil } +func (m *DeploymentCondition) Marshal() (data []byte, err error) { + size := m.Size() + data = make([]byte, size) + n, err := m.MarshalTo(data) + if err != nil { + return nil, err + } + return data[:n], nil +} + +func (m *DeploymentCondition) MarshalTo(data []byte) (int, error) { + var i int + _ = i + var l int + _ = l + data[i] = 0xa + i++ + i = encodeVarintGenerated(data, i, uint64(len(m.Type))) + i += copy(data[i:], m.Type) + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(len(m.Status))) + i += copy(data[i:], m.Status) + data[i] = 0x22 + i++ + i = encodeVarintGenerated(data, i, uint64(len(m.Reason))) + i += copy(data[i:], m.Reason) + data[i] = 0x2a + i++ + i = encodeVarintGenerated(data, i, uint64(len(m.Message))) + i += copy(data[i:], m.Message) + data[i] = 0x32 + i++ + i = encodeVarintGenerated(data, i, uint64(m.LastUpdateTime.Size())) + n12, err := m.LastUpdateTime.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n12 + data[i] = 0x3a + i++ + i = encodeVarintGenerated(data, i, uint64(m.LastTransitionTime.Size())) + n13, err := m.LastTransitionTime.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n13 + return i, nil +} + func (m *DeploymentList) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) @@ -863,11 +905,11 @@ func (m *DeploymentList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n12, err := m.ListMeta.MarshalTo(data[i:]) + n14, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n12 + i += n14 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -922,11 +964,11 @@ func (m *DeploymentRollback) MarshalTo(data []byte) (int, error) { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.RollbackTo.Size())) - n13, err := m.RollbackTo.MarshalTo(data[i:]) + n15, err := m.RollbackTo.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n13 + i += n15 return i, nil } @@ -954,28 +996,28 @@ func (m *DeploymentSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Selector.Size())) - n14, err := m.Selector.MarshalTo(data[i:]) + n16, err := m.Selector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n14 + i += n16 } data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.Template.Size())) - n15, err := m.Template.MarshalTo(data[i:]) + n17, err := m.Template.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n15 + i += n17 data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.Strategy.Size())) - n16, err := m.Strategy.MarshalTo(data[i:]) + n18, err := m.Strategy.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n16 + i += n18 data[i] = 0x28 i++ i = encodeVarintGenerated(data, i, uint64(m.MinReadySeconds)) @@ -996,11 +1038,16 @@ func (m *DeploymentSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x42 i++ i = encodeVarintGenerated(data, i, uint64(m.RollbackTo.Size())) - n17, err := m.RollbackTo.MarshalTo(data[i:]) + n19, err := m.RollbackTo.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n17 + i += n19 + } + if m.ProgressDeadlineSeconds != nil { + data[i] = 0x48 + i++ + i = encodeVarintGenerated(data, i, uint64(*m.ProgressDeadlineSeconds)) } return i, nil } @@ -1035,6 +1082,18 @@ func (m *DeploymentStatus) MarshalTo(data []byte) (int, error) { data[i] = 0x28 i++ i = encodeVarintGenerated(data, i, uint64(m.UnavailableReplicas)) + if len(m.Conditions) > 0 { + for _, msg := range m.Conditions { + data[i] = 0x32 + i++ + i = encodeVarintGenerated(data, i, uint64(msg.Size())) + n, err := msg.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n + } + } return i, nil } @@ -1061,11 +1120,11 @@ func (m *DeploymentStrategy) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.RollingUpdate.Size())) - n18, err := m.RollingUpdate.MarshalTo(data[i:]) + n20, err := m.RollingUpdate.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n18 + i += n20 } return i, nil } @@ -1160,11 +1219,11 @@ func (m *HTTPIngressPath) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Backend.Size())) - n19, err := m.Backend.MarshalTo(data[i:]) + n21, err := m.Backend.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n19 + i += n21 return i, nil } @@ -1216,27 +1275,27 @@ func (m *HorizontalPodAutoscaler) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n20, err := m.ObjectMeta.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n20 - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n21, err := m.Spec.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n21 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n22, err := m.Status.MarshalTo(data[i:]) + n22, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } i += n22 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n23, err := m.Spec.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n23 + data[i] = 0x1a + i++ + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n24, err := m.Status.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n24 return i, nil } @@ -1258,11 +1317,11 @@ func (m *HorizontalPodAutoscalerList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n23, err := m.ListMeta.MarshalTo(data[i:]) + n25, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n23 + i += n25 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -1296,11 +1355,11 @@ func (m *HorizontalPodAutoscalerSpec) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ScaleRef.Size())) - n24, err := m.ScaleRef.MarshalTo(data[i:]) + n26, err := m.ScaleRef.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n24 + i += n26 if m.MinReplicas != nil { data[i] = 0x10 i++ @@ -1313,11 +1372,11 @@ func (m *HorizontalPodAutoscalerSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.CPUUtilization.Size())) - n25, err := m.CPUUtilization.MarshalTo(data[i:]) + n27, err := m.CPUUtilization.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n25 + i += n27 } return i, nil } @@ -1346,11 +1405,11 @@ func (m *HorizontalPodAutoscalerStatus) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.LastScaleTime.Size())) - n26, err := m.LastScaleTime.MarshalTo(data[i:]) + n28, err := m.LastScaleTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n26 + i += n28 } data[i] = 0x18 i++ @@ -1432,27 +1491,27 @@ func (m *Ingress) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n27, err := m.ObjectMeta.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n27 - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n28, err := m.Spec.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n28 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n29, err := m.Status.MarshalTo(data[i:]) + n29, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } i += n29 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n30, err := m.Spec.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n30 + data[i] = 0x1a + i++ + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n31, err := m.Status.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n31 return i, nil } @@ -1478,11 +1537,11 @@ func (m *IngressBackend) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.ServicePort.Size())) - n30, err := m.ServicePort.MarshalTo(data[i:]) + n32, err := m.ServicePort.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n30 + i += n32 return i, nil } @@ -1504,11 +1563,11 @@ func (m *IngressList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n31, err := m.ListMeta.MarshalTo(data[i:]) + n33, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n31 + i += n33 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -1546,11 +1605,11 @@ func (m *IngressRule) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.IngressRuleValue.Size())) - n32, err := m.IngressRuleValue.MarshalTo(data[i:]) + n34, err := m.IngressRuleValue.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n32 + i += n34 return i, nil } @@ -1573,11 +1632,11 @@ func (m *IngressRuleValue) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.HTTP.Size())) - n33, err := m.HTTP.MarshalTo(data[i:]) + n35, err := m.HTTP.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n33 + i += n35 } return i, nil } @@ -1601,11 +1660,11 @@ func (m *IngressSpec) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.Backend.Size())) - n34, err := m.Backend.MarshalTo(data[i:]) + n36, err := m.Backend.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n34 + i += n36 } if len(m.TLS) > 0 { for _, msg := range m.TLS { @@ -1652,11 +1711,11 @@ func (m *IngressStatus) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.LoadBalancer.Size())) - n35, err := m.LoadBalancer.MarshalTo(data[i:]) + n37, err := m.LoadBalancer.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n35 + i += n37 return i, nil } @@ -1715,27 +1774,27 @@ func (m *Job) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n36, err := m.ObjectMeta.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n36 - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n37, err := m.Spec.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n37 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n38, err := m.Status.MarshalTo(data[i:]) + n38, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } i += n38 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n39, err := m.Spec.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n39 + data[i] = 0x1a + i++ + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n40, err := m.Status.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n40 return i, nil } @@ -1765,19 +1824,19 @@ func (m *JobCondition) MarshalTo(data []byte) (int, error) { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.LastProbeTime.Size())) - n39, err := m.LastProbeTime.MarshalTo(data[i:]) + n41, err := m.LastProbeTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n39 + i += n41 data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.LastTransitionTime.Size())) - n40, err := m.LastTransitionTime.MarshalTo(data[i:]) + n42, err := m.LastTransitionTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n40 + i += n42 data[i] = 0x2a i++ i = encodeVarintGenerated(data, i, uint64(len(m.Reason))) @@ -1807,11 +1866,11 @@ func (m *JobList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n41, err := m.ListMeta.MarshalTo(data[i:]) + n43, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n41 + i += n43 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -1861,11 +1920,11 @@ func (m *JobSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(m.Selector.Size())) - n42, err := m.Selector.MarshalTo(data[i:]) + n44, err := m.Selector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n42 + i += n44 } if m.AutoSelector != nil { data[i] = 0x28 @@ -1880,11 +1939,11 @@ func (m *JobSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x32 i++ i = encodeVarintGenerated(data, i, uint64(m.Template.Size())) - n43, err := m.Template.MarshalTo(data[i:]) + n45, err := m.Template.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n43 + i += n45 return i, nil } @@ -1919,21 +1978,21 @@ func (m *JobStatus) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.StartTime.Size())) - n44, err := m.StartTime.MarshalTo(data[i:]) + n46, err := m.StartTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n44 + i += n46 } if m.CompletionTime != nil { data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.CompletionTime.Size())) - n45, err := m.CompletionTime.MarshalTo(data[i:]) + n47, err := m.CompletionTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n45 + i += n47 } data[i] = 0x20 i++ @@ -1947,94 +2006,6 @@ func (m *JobStatus) MarshalTo(data []byte) (int, error) { return i, nil } -func (m *LabelSelector) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelector) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k := range m.MatchLabels { - data[i] = 0xa - i++ - v := m.MatchLabels[k] - mapSize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - i = encodeVarintGenerated(data, i, uint64(mapSize)) - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(k))) - i += copy(data[i:], k) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(v))) - i += copy(data[i:], v) - } - } - if len(m.MatchExpressions) > 0 { - for _, msg := range m.MatchExpressions { - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(msg.Size())) - n, err := msg.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n - } - } - return i, nil -} - -func (m *LabelSelectorRequirement) Marshal() (data []byte, err error) { - size := m.Size() - data = make([]byte, size) - n, err := m.MarshalTo(data) - if err != nil { - return nil, err - } - return data[:n], nil -} - -func (m *LabelSelectorRequirement) MarshalTo(data []byte) (int, error) { - var i int - _ = i - var l int - _ = l - data[i] = 0xa - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Key))) - i += copy(data[i:], m.Key) - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(len(m.Operator))) - i += copy(data[i:], m.Operator) - if len(m.Values) > 0 { - for _, s := range m.Values { - data[i] = 0x1a - i++ - l = len(s) - for l >= 1<<7 { - data[i] = uint8(uint64(l)&0x7f | 0x80) - l >>= 7 - i++ - } - data[i] = uint8(l) - i++ - i += copy(data[i:], s) - } - } - return i, nil -} - func (m *NetworkPolicy) Marshal() (data []byte, err error) { size := m.Size() data = make([]byte, size) @@ -2053,19 +2024,19 @@ func (m *NetworkPolicy) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n46, err := m.ObjectMeta.MarshalTo(data[i:]) + n48, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n46 + i += n48 data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n47, err := m.Spec.MarshalTo(data[i:]) + n49, err := m.Spec.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n47 + i += n49 return i, nil } @@ -2129,11 +2100,11 @@ func (m *NetworkPolicyList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n48, err := m.ListMeta.MarshalTo(data[i:]) + n50, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n48 + i += n50 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -2168,21 +2139,21 @@ func (m *NetworkPolicyPeer) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.PodSelector.Size())) - n49, err := m.PodSelector.MarshalTo(data[i:]) + n51, err := m.PodSelector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n49 + i += n51 } if m.NamespaceSelector != nil { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.NamespaceSelector.Size())) - n50, err := m.NamespaceSelector.MarshalTo(data[i:]) + n52, err := m.NamespaceSelector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n50 + i += n52 } return i, nil } @@ -2212,11 +2183,11 @@ func (m *NetworkPolicyPort) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Port.Size())) - n51, err := m.Port.MarshalTo(data[i:]) + n53, err := m.Port.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n51 + i += n53 } return i, nil } @@ -2239,11 +2210,11 @@ func (m *NetworkPolicySpec) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.PodSelector.Size())) - n52, err := m.PodSelector.MarshalTo(data[i:]) + n54, err := m.PodSelector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n52 + i += n54 if len(m.Ingress) > 0 { for _, msg := range m.Ingress { data[i] = 0x12 @@ -2277,19 +2248,19 @@ func (m *PodSecurityPolicy) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n53, err := m.ObjectMeta.MarshalTo(data[i:]) + n55, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n53 + i += n55 data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n54, err := m.Spec.MarshalTo(data[i:]) + n56, err := m.Spec.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n54 + i += n56 return i, nil } @@ -2311,11 +2282,11 @@ func (m *PodSecurityPolicyList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n55, err := m.ListMeta.MarshalTo(data[i:]) + n57, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n55 + i += n57 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -2453,35 +2424,35 @@ func (m *PodSecurityPolicySpec) MarshalTo(data []byte) (int, error) { data[i] = 0x52 i++ i = encodeVarintGenerated(data, i, uint64(m.SELinux.Size())) - n56, err := m.SELinux.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n56 - data[i] = 0x5a - i++ - i = encodeVarintGenerated(data, i, uint64(m.RunAsUser.Size())) - n57, err := m.RunAsUser.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n57 - data[i] = 0x62 - i++ - i = encodeVarintGenerated(data, i, uint64(m.SupplementalGroups.Size())) - n58, err := m.SupplementalGroups.MarshalTo(data[i:]) + n58, err := m.SELinux.MarshalTo(data[i:]) if err != nil { return 0, err } i += n58 - data[i] = 0x6a + data[i] = 0x5a i++ - i = encodeVarintGenerated(data, i, uint64(m.FSGroup.Size())) - n59, err := m.FSGroup.MarshalTo(data[i:]) + i = encodeVarintGenerated(data, i, uint64(m.RunAsUser.Size())) + n59, err := m.RunAsUser.MarshalTo(data[i:]) if err != nil { return 0, err } i += n59 + data[i] = 0x62 + i++ + i = encodeVarintGenerated(data, i, uint64(m.SupplementalGroups.Size())) + n60, err := m.SupplementalGroups.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n60 + data[i] = 0x6a + i++ + i = encodeVarintGenerated(data, i, uint64(m.FSGroup.Size())) + n61, err := m.FSGroup.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n61 data[i] = 0x70 i++ if m.ReadOnlyRootFilesystem { @@ -2511,27 +2482,27 @@ func (m *ReplicaSet) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n60, err := m.ObjectMeta.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n60 - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n61, err := m.Spec.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n61 - data[i] = 0x1a - i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n62, err := m.Status.MarshalTo(data[i:]) + n62, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } i += n62 + data[i] = 0x12 + i++ + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n63, err := m.Spec.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n63 + data[i] = 0x1a + i++ + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n64, err := m.Status.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n64 return i, nil } @@ -2560,25 +2531,17 @@ func (m *ReplicaSetCondition) MarshalTo(data []byte) (int, error) { i += copy(data[i:], m.Status) data[i] = 0x1a i++ - i = encodeVarintGenerated(data, i, uint64(m.LastProbeTime.Size())) - n63, err := m.LastProbeTime.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n63 - data[i] = 0x22 - i++ i = encodeVarintGenerated(data, i, uint64(m.LastTransitionTime.Size())) - n64, err := m.LastTransitionTime.MarshalTo(data[i:]) + n65, err := m.LastTransitionTime.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n64 - data[i] = 0x2a + i += n65 + data[i] = 0x22 i++ i = encodeVarintGenerated(data, i, uint64(len(m.Reason))) i += copy(data[i:], m.Reason) - data[i] = 0x32 + data[i] = 0x2a i++ i = encodeVarintGenerated(data, i, uint64(len(m.Message))) i += copy(data[i:], m.Message) @@ -2603,11 +2566,11 @@ func (m *ReplicaSetList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n65, err := m.ListMeta.MarshalTo(data[i:]) + n66, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n65 + i += n66 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -2647,20 +2610,20 @@ func (m *ReplicaSetSpec) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.Selector.Size())) - n66, err := m.Selector.MarshalTo(data[i:]) + n67, err := m.Selector.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n66 + i += n67 } data[i] = 0x1a i++ i = encodeVarintGenerated(data, i, uint64(m.Template.Size())) - n67, err := m.Template.MarshalTo(data[i:]) + n68, err := m.Template.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n67 + i += n68 data[i] = 0x20 i++ i = encodeVarintGenerated(data, i, uint64(m.MinReadySeconds)) @@ -2770,21 +2733,21 @@ func (m *RollingUpdateDeployment) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.MaxUnavailable.Size())) - n68, err := m.MaxUnavailable.MarshalTo(data[i:]) + n69, err := m.MaxUnavailable.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n68 + i += n69 } if m.MaxSurge != nil { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.MaxSurge.Size())) - n69, err := m.MaxSurge.MarshalTo(data[i:]) + n70, err := m.MaxSurge.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n69 + i += n70 } return i, nil } @@ -2846,11 +2809,11 @@ func (m *SELinuxStrategyOptions) MarshalTo(data []byte) (int, error) { data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(m.SELinuxOptions.Size())) - n70, err := m.SELinuxOptions.MarshalTo(data[i:]) + n71, err := m.SELinuxOptions.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n70 + i += n71 } return i, nil } @@ -2873,27 +2836,27 @@ func (m *Scale) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n71, err := m.ObjectMeta.MarshalTo(data[i:]) - if err != nil { - return 0, err - } - i += n71 - data[i] = 0x12 - i++ - i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) - n72, err := m.Spec.MarshalTo(data[i:]) + n72, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } i += n72 - data[i] = 0x1a + data[i] = 0x12 i++ - i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) - n73, err := m.Status.MarshalTo(data[i:]) + i = encodeVarintGenerated(data, i, uint64(m.Spec.Size())) + n73, err := m.Spec.MarshalTo(data[i:]) if err != nil { return 0, err } i += n73 + data[i] = 0x1a + i++ + i = encodeVarintGenerated(data, i, uint64(m.Status.Size())) + n74, err := m.Status.MarshalTo(data[i:]) + if err != nil { + return 0, err + } + i += n74 return i, nil } @@ -3046,11 +3009,11 @@ func (m *ThirdPartyResource) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n74, err := m.ObjectMeta.MarshalTo(data[i:]) + n75, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n74 + i += n75 data[i] = 0x12 i++ i = encodeVarintGenerated(data, i, uint64(len(m.Description))) @@ -3088,11 +3051,11 @@ func (m *ThirdPartyResourceData) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ObjectMeta.Size())) - n75, err := m.ObjectMeta.MarshalTo(data[i:]) + n76, err := m.ObjectMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n75 + i += n76 if m.Data != nil { data[i] = 0x12 i++ @@ -3120,11 +3083,11 @@ func (m *ThirdPartyResourceDataList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n76, err := m.ListMeta.MarshalTo(data[i:]) + n77, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n76 + i += n77 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -3158,11 +3121,11 @@ func (m *ThirdPartyResourceList) MarshalTo(data []byte) (int, error) { data[i] = 0xa i++ i = encodeVarintGenerated(data, i, uint64(m.ListMeta.Size())) - n77, err := m.ListMeta.MarshalTo(data[i:]) + n78, err := m.ListMeta.MarshalTo(data[i:]) if err != nil { return 0, err } - i += n77 + i += n78 if len(m.Items) > 0 { for _, msg := range m.Items { data[i] = 0x12 @@ -3324,6 +3287,24 @@ func (m *Deployment) Size() (n int) { return n } +func (m *DeploymentCondition) Size() (n int) { + var l int + _ = l + l = len(m.Type) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Status) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Reason) + n += 1 + l + sovGenerated(uint64(l)) + l = len(m.Message) + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastUpdateTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + l = m.LastTransitionTime.Size() + n += 1 + l + sovGenerated(uint64(l)) + return n +} + func (m *DeploymentList) Size() (n int) { var l int _ = l @@ -3379,6 +3360,9 @@ func (m *DeploymentSpec) Size() (n int) { l = m.RollbackTo.Size() n += 1 + l + sovGenerated(uint64(l)) } + if m.ProgressDeadlineSeconds != nil { + n += 1 + sovGenerated(uint64(*m.ProgressDeadlineSeconds)) + } return n } @@ -3390,6 +3374,12 @@ func (m *DeploymentStatus) Size() (n int) { n += 1 + sovGenerated(uint64(m.UpdatedReplicas)) n += 1 + sovGenerated(uint64(m.AvailableReplicas)) n += 1 + sovGenerated(uint64(m.UnavailableReplicas)) + if len(m.Conditions) > 0 { + for _, e := range m.Conditions { + l = e.Size() + n += 1 + l + sovGenerated(uint64(l)) + } + } return n } @@ -3716,42 +3706,6 @@ func (m *JobStatus) Size() (n int) { return n } -func (m *LabelSelector) Size() (n int) { - var l int - _ = l - if len(m.MatchLabels) > 0 { - for k, v := range m.MatchLabels { - _ = k - _ = v - mapEntrySize := 1 + len(k) + sovGenerated(uint64(len(k))) + 1 + len(v) + sovGenerated(uint64(len(v))) - n += mapEntrySize + 1 + sovGenerated(uint64(mapEntrySize)) - } - } - if len(m.MatchExpressions) > 0 { - for _, e := range m.MatchExpressions { - l = e.Size() - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - -func (m *LabelSelectorRequirement) Size() (n int) { - var l int - _ = l - l = len(m.Key) - n += 1 + l + sovGenerated(uint64(l)) - l = len(m.Operator) - n += 1 + l + sovGenerated(uint64(l)) - if len(m.Values) > 0 { - for _, s := range m.Values { - l = len(s) - n += 1 + l + sovGenerated(uint64(l)) - } - } - return n -} - func (m *NetworkPolicy) Size() (n int) { var l int _ = l @@ -3928,8 +3882,6 @@ func (m *ReplicaSetCondition) Size() (n int) { n += 1 + l + sovGenerated(uint64(l)) l = len(m.Status) n += 1 + l + sovGenerated(uint64(l)) - l = m.LastProbeTime.Size() - n += 1 + l + sovGenerated(uint64(l)) l = m.LastTransitionTime.Size() n += 1 + l + sovGenerated(uint64(l)) l = len(m.Reason) @@ -4262,7 +4214,7 @@ func (this *DaemonSetSpec) String() string { return "nil" } s := strings.Join([]string{`&DaemonSetSpec{`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `}`, }, "") @@ -4293,6 +4245,21 @@ func (this *Deployment) String() string { }, "") return s } +func (this *DeploymentCondition) String() string { + if this == nil { + return "nil" + } + s := strings.Join([]string{`&DeploymentCondition{`, + `Type:` + fmt.Sprintf("%v", this.Type) + `,`, + `Status:` + fmt.Sprintf("%v", this.Status) + `,`, + `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, + `Message:` + fmt.Sprintf("%v", this.Message) + `,`, + `LastUpdateTime:` + strings.Replace(strings.Replace(this.LastUpdateTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, + `LastTransitionTime:` + strings.Replace(strings.Replace(this.LastTransitionTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, + `}`, + }, "") + return s +} func (this *DeploymentList) String() string { if this == nil { return "nil" @@ -4332,13 +4299,14 @@ func (this *DeploymentSpec) String() string { } s := strings.Join([]string{`&DeploymentSpec{`, `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `Strategy:` + strings.Replace(strings.Replace(this.Strategy.String(), "DeploymentStrategy", "DeploymentStrategy", 1), `&`, ``, 1) + `,`, `MinReadySeconds:` + fmt.Sprintf("%v", this.MinReadySeconds) + `,`, `RevisionHistoryLimit:` + valueToStringGenerated(this.RevisionHistoryLimit) + `,`, `Paused:` + fmt.Sprintf("%v", this.Paused) + `,`, `RollbackTo:` + strings.Replace(fmt.Sprintf("%v", this.RollbackTo), "RollbackConfig", "RollbackConfig", 1) + `,`, + `ProgressDeadlineSeconds:` + valueToStringGenerated(this.ProgressDeadlineSeconds) + `,`, `}`, }, "") return s @@ -4353,6 +4321,7 @@ func (this *DeploymentStatus) String() string { `UpdatedReplicas:` + fmt.Sprintf("%v", this.UpdatedReplicas) + `,`, `AvailableReplicas:` + fmt.Sprintf("%v", this.AvailableReplicas) + `,`, `UnavailableReplicas:` + fmt.Sprintf("%v", this.UnavailableReplicas) + `,`, + `Conditions:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Conditions), "DeploymentCondition", "DeploymentCondition", 1), `&`, ``, 1) + `,`, `}`, }, "") return s @@ -4617,7 +4586,7 @@ func (this *JobSpec) String() string { `Parallelism:` + valueToStringGenerated(this.Parallelism) + `,`, `Completions:` + valueToStringGenerated(this.Completions) + `,`, `ActiveDeadlineSeconds:` + valueToStringGenerated(this.ActiveDeadlineSeconds) + `,`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `AutoSelector:` + valueToStringGenerated(this.AutoSelector) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `}`, @@ -4639,39 +4608,6 @@ func (this *JobStatus) String() string { }, "") return s } -func (this *LabelSelector) String() string { - if this == nil { - return "nil" - } - keysForMatchLabels := make([]string, 0, len(this.MatchLabels)) - for k := range this.MatchLabels { - keysForMatchLabels = append(keysForMatchLabels, k) - } - github_com_gogo_protobuf_sortkeys.Strings(keysForMatchLabels) - mapStringForMatchLabels := "map[string]string{" - for _, k := range keysForMatchLabels { - mapStringForMatchLabels += fmt.Sprintf("%v: %v,", k, this.MatchLabels[k]) - } - mapStringForMatchLabels += "}" - s := strings.Join([]string{`&LabelSelector{`, - `MatchLabels:` + mapStringForMatchLabels + `,`, - `MatchExpressions:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.MatchExpressions), "LabelSelectorRequirement", "LabelSelectorRequirement", 1), `&`, ``, 1) + `,`, - `}`, - }, "") - return s -} -func (this *LabelSelectorRequirement) String() string { - if this == nil { - return "nil" - } - s := strings.Join([]string{`&LabelSelectorRequirement{`, - `Key:` + fmt.Sprintf("%v", this.Key) + `,`, - `Operator:` + fmt.Sprintf("%v", this.Operator) + `,`, - `Values:` + fmt.Sprintf("%v", this.Values) + `,`, - `}`, - }, "") - return s -} func (this *NetworkPolicy) String() string { if this == nil { return "nil" @@ -4710,8 +4646,8 @@ func (this *NetworkPolicyPeer) String() string { return "nil" } s := strings.Join([]string{`&NetworkPolicyPeer{`, - `PodSelector:` + strings.Replace(fmt.Sprintf("%v", this.PodSelector), "LabelSelector", "LabelSelector", 1) + `,`, - `NamespaceSelector:` + strings.Replace(fmt.Sprintf("%v", this.NamespaceSelector), "LabelSelector", "LabelSelector", 1) + `,`, + `PodSelector:` + strings.Replace(fmt.Sprintf("%v", this.PodSelector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, + `NamespaceSelector:` + strings.Replace(fmt.Sprintf("%v", this.NamespaceSelector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `}`, }, "") return s @@ -4732,7 +4668,7 @@ func (this *NetworkPolicySpec) String() string { return "nil" } s := strings.Join([]string{`&NetworkPolicySpec{`, - `PodSelector:` + strings.Replace(strings.Replace(this.PodSelector.String(), "LabelSelector", "LabelSelector", 1), `&`, ``, 1) + `,`, + `PodSelector:` + strings.Replace(strings.Replace(this.PodSelector.String(), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1), `&`, ``, 1) + `,`, `Ingress:` + strings.Replace(strings.Replace(fmt.Sprintf("%v", this.Ingress), "NetworkPolicyIngressRule", "NetworkPolicyIngressRule", 1), `&`, ``, 1) + `,`, `}`, }, "") @@ -4802,7 +4738,6 @@ func (this *ReplicaSetCondition) String() string { s := strings.Join([]string{`&ReplicaSetCondition{`, `Type:` + fmt.Sprintf("%v", this.Type) + `,`, `Status:` + fmt.Sprintf("%v", this.Status) + `,`, - `LastProbeTime:` + strings.Replace(strings.Replace(this.LastProbeTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, `LastTransitionTime:` + strings.Replace(strings.Replace(this.LastTransitionTime.String(), "Time", "k8s_io_kubernetes_pkg_api_unversioned.Time", 1), `&`, ``, 1) + `,`, `Reason:` + fmt.Sprintf("%v", this.Reason) + `,`, `Message:` + fmt.Sprintf("%v", this.Message) + `,`, @@ -4827,7 +4762,7 @@ func (this *ReplicaSetSpec) String() string { } s := strings.Join([]string{`&ReplicaSetSpec{`, `Replicas:` + valueToStringGenerated(this.Replicas) + `,`, - `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "LabelSelector", 1) + `,`, + `Selector:` + strings.Replace(fmt.Sprintf("%v", this.Selector), "LabelSelector", "k8s_io_kubernetes_pkg_api_unversioned.LabelSelector", 1) + `,`, `Template:` + strings.Replace(strings.Replace(this.Template.String(), "PodTemplateSpec", "k8s_io_kubernetes_pkg_api_v1.PodTemplateSpec", 1), `&`, ``, 1) + `,`, `MinReadySeconds:` + fmt.Sprintf("%v", this.MinReadySeconds) + `,`, `}`, @@ -5857,7 +5792,7 @@ func (m *DaemonSetSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -6180,6 +6115,232 @@ func (m *Deployment) Unmarshal(data []byte) error { } return nil } +func (m *DeploymentCondition) Unmarshal(data []byte) error { + l := len(data) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: DeploymentCondition: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: DeploymentCondition: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Type", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + stringLen |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Type = DeploymentConditionType(data[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + stringLen |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Status = k8s_io_kubernetes_pkg_api_v1.ConditionStatus(data[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + stringLen |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Reason = string(data[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + stringLen |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + intStringLen + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Message = string(data[iNdEx:postIndex]) + iNdEx = postIndex + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastUpdateTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastUpdateTime.Unmarshal(data[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LastTransitionTime.Unmarshal(data[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipGenerated(data[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthGenerated + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *DeploymentList) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 @@ -6587,7 +6748,7 @@ func (m *DeploymentSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -6745,6 +6906,26 @@ func (m *DeploymentSpec) Unmarshal(data []byte) error { return err } iNdEx = postIndex + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ProgressDeadlineSeconds", wireType) + } + var v int32 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + v |= (int32(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + m.ProgressDeadlineSeconds = &v default: iNdEx = preIndex skippy, err := skipGenerated(data[iNdEx:]) @@ -6890,6 +7071,37 @@ func (m *DeploymentStatus) Unmarshal(data []byte) error { break } } + case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Conditions", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenerated + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := data[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenerated + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Conditions = append(m.Conditions, DeploymentCondition{}) + if err := m.Conditions[len(m.Conditions)-1].Unmarshal(data[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipGenerated(data[iNdEx:]) @@ -9631,7 +9843,7 @@ func (m *JobSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -9913,335 +10125,6 @@ func (m *JobStatus) Unmarshal(data []byte) error { } return nil } -func (m *LabelSelector) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelector: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelector: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchLabels", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - var keykey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - keykey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapkey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapkey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapkey := int(stringLenmapkey) - if intStringLenmapkey < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapkey := iNdEx + intStringLenmapkey - if postStringIndexmapkey > l { - return io.ErrUnexpectedEOF - } - mapkey := string(data[iNdEx:postStringIndexmapkey]) - iNdEx = postStringIndexmapkey - var valuekey uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - valuekey |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - var stringLenmapvalue uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLenmapvalue |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLenmapvalue := int(stringLenmapvalue) - if intStringLenmapvalue < 0 { - return ErrInvalidLengthGenerated - } - postStringIndexmapvalue := iNdEx + intStringLenmapvalue - if postStringIndexmapvalue > l { - return io.ErrUnexpectedEOF - } - mapvalue := string(data[iNdEx:postStringIndexmapvalue]) - iNdEx = postStringIndexmapvalue - if m.MatchLabels == nil { - m.MatchLabels = make(map[string]string) - } - m.MatchLabels[mapkey] = mapvalue - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field MatchExpressions", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.MatchExpressions = append(m.MatchExpressions, LabelSelectorRequirement{}) - if err := m.MatchExpressions[len(m.MatchExpressions)-1].Unmarshal(data[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *LabelSelectorRequirement) Unmarshal(data []byte) error { - l := len(data) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LabelSelectorRequirement: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LabelSelectorRequirement: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Key = string(data[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Operator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Operator = LabelSelectorOperator(data[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Values", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - stringLen |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + intStringLen - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Values = append(m.Values, string(data[iNdEx:postIndex])) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenerated(data[iNdEx:]) - if err != nil { - return err - } - if skippy < 0 { - return ErrInvalidLengthGenerated - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} func (m *NetworkPolicy) Unmarshal(data []byte) error { l := len(data) iNdEx := 0 @@ -10631,7 +10514,7 @@ func (m *NetworkPolicyPeer) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.PodSelector == nil { - m.PodSelector = &LabelSelector{} + m.PodSelector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.PodSelector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -10664,7 +10547,7 @@ func (m *NetworkPolicyPeer) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.NamespaceSelector == nil { - m.NamespaceSelector = &LabelSelector{} + m.NamespaceSelector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.NamespaceSelector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -11781,36 +11664,6 @@ func (m *ReplicaSetCondition) Unmarshal(data []byte) error { m.Status = k8s_io_kubernetes_pkg_api_v1.ConditionStatus(data[iNdEx:postIndex]) iNdEx = postIndex case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LastProbeTime", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenerated - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := data[iNdEx] - iNdEx++ - msglen |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenerated - } - postIndex := iNdEx + msglen - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.LastProbeTime.Unmarshal(data[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field LastTransitionTime", wireType) } @@ -11840,7 +11693,7 @@ func (m *ReplicaSetCondition) Unmarshal(data []byte) error { return err } iNdEx = postIndex - case 5: + case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType) } @@ -11869,7 +11722,7 @@ func (m *ReplicaSetCondition) Unmarshal(data []byte) error { } m.Reason = string(data[iNdEx:postIndex]) iNdEx = postIndex - case 6: + case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Message", wireType) } @@ -12106,7 +11959,7 @@ func (m *ReplicaSetSpec) Unmarshal(data []byte) error { return io.ErrUnexpectedEOF } if m.Selector == nil { - m.Selector = &LabelSelector{} + m.Selector = &k8s_io_kubernetes_pkg_api_unversioned.LabelSelector{} } if err := m.Selector.Unmarshal(data[iNdEx:postIndex]); err != nil { return err @@ -14088,250 +13941,250 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 3916 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x5b, 0x5b, 0x8f, 0x1c, 0xc7, - 0x75, 0xd6, 0xcc, 0xec, 0x65, 0xa6, 0xf6, 0xc2, 0x65, 0x71, 0x49, 0x8e, 0x56, 0x12, 0x29, 0xb5, - 0x10, 0x5d, 0x10, 0x71, 0x36, 0x64, 0x24, 0x85, 0xa2, 0x24, 0x4a, 0x3b, 0x7b, 0x21, 0x29, 0xed, - 0x92, 0xa3, 0x9a, 0x25, 0xa5, 0xe8, 0x9a, 0xde, 0x99, 0xda, 0xd9, 0xe6, 0xf6, 0x4c, 0x8f, 0xfa, - 0xb2, 0xda, 0x55, 0x10, 0x44, 0x41, 0x12, 0x20, 0x2f, 0x51, 0xf4, 0x16, 0x01, 0x89, 0x1f, 0x0c, - 0xd8, 0xf0, 0x93, 0x05, 0x1b, 0x30, 0xa0, 0x07, 0xbf, 0xd8, 0x82, 0x0d, 0xd3, 0x0f, 0x86, 0x65, - 0xc3, 0x86, 0xfd, 0x60, 0x4b, 0xb2, 0x0c, 0x5b, 0xf0, 0x5f, 0x90, 0xfd, 0xe0, 0x53, 0x97, 0xbe, - 0x54, 0x4f, 0xf7, 0x90, 0x3d, 0x7b, 0x81, 0x0d, 0xfb, 0x61, 0x41, 0x76, 0xd5, 0x39, 0xdf, 0x39, - 0x75, 0xea, 0xd4, 0xa9, 0x53, 0x55, 0x67, 0xd0, 0x93, 0x9b, 0x67, 0x9d, 0x8a, 0x61, 0xcd, 0x6e, - 0x7a, 0x6b, 0xd4, 0xee, 0x50, 0x97, 0x3a, 0xb3, 0xdd, 0xcd, 0xd6, 0xac, 0xde, 0x35, 0x9c, 0x59, - 0xba, 0xed, 0xd2, 0x8e, 0x63, 0x58, 0x1d, 0x67, 0x76, 0xeb, 0xf4, 0x1a, 0x75, 0xf5, 0xd3, 0xb3, - 0x2d, 0xda, 0xa1, 0xb6, 0xee, 0xd2, 0x66, 0xa5, 0x6b, 0x5b, 0xae, 0x85, 0x4f, 0x09, 0xf6, 0x4a, - 0xc8, 0x5e, 0x01, 0xf6, 0x0a, 0x63, 0xaf, 0x84, 0xec, 0x15, 0xc9, 0x3e, 0x73, 0xaa, 0x65, 0xb8, - 0x1b, 0xde, 0x5a, 0xa5, 0x61, 0xb5, 0x67, 0x5b, 0x56, 0xcb, 0x9a, 0xe5, 0x28, 0x6b, 0xde, 0x3a, - 0xff, 0xe2, 0x1f, 0xfc, 0x7f, 0x02, 0x7d, 0xe6, 0x4c, 0xaa, 0x72, 0xb3, 0x36, 0x75, 0x2c, 0xcf, - 0x6e, 0xd0, 0xb8, 0x46, 0x33, 0x8f, 0xa4, 0xf3, 0x78, 0x9d, 0x2d, 0x6a, 0x33, 0x85, 0x68, 0xb3, - 0x87, 0xed, 0xa1, 0x74, 0xb6, 0xad, 0x9e, 0x61, 0xcf, 0x9c, 0x4a, 0xa6, 0xb6, 0xbd, 0x8e, 0x6b, - 0xb4, 0x7b, 0x75, 0x3a, 0x9d, 0x4c, 0xee, 0xb9, 0x86, 0x39, 0x6b, 0x74, 0x5c, 0xc7, 0xb5, 0xe3, - 0x2c, 0x5a, 0x05, 0xa1, 0xb9, 0xda, 0xa5, 0x6b, 0x42, 0x5f, 0x7c, 0x37, 0x1a, 0xea, 0xe8, 0x6d, - 0x5a, 0xce, 0xdd, 0x9d, 0x7b, 0xa0, 0x54, 0x1d, 0xbf, 0xf1, 0xd1, 0xc9, 0xdb, 0x3e, 0xfd, 0xe8, - 0xe4, 0xd0, 0x65, 0x68, 0x23, 0xbc, 0x47, 0x7b, 0x19, 0x4d, 0xcf, 0xd7, 0xae, 0xae, 0xea, 0x76, - 0x8b, 0xba, 0x57, 0x01, 0xd7, 0x78, 0x53, 0x77, 0x19, 0xe7, 0x02, 0x9a, 0x72, 0x79, 0x63, 0x8d, - 0x82, 0xb5, 0x3a, 0xae, 0xde, 0x12, 0x28, 0xc3, 0xd5, 0xb2, 0x44, 0x99, 0x5a, 0x8d, 0xf5, 0x93, - 0x1e, 0x0e, 0xed, 0x7f, 0x73, 0xe8, 0xf6, 0x79, 0xcf, 0x71, 0xad, 0xf6, 0x0a, 0x75, 0x6d, 0xa3, - 0x31, 0xef, 0xd9, 0x36, 0x74, 0xd5, 0x5d, 0xdd, 0xf5, 0x9c, 0x9b, 0x6b, 0x87, 0x5f, 0x40, 0xc3, - 0x5b, 0xba, 0xe9, 0xd1, 0x72, 0x1e, 0x48, 0xc6, 0xce, 0x3c, 0x54, 0x49, 0x75, 0x9b, 0x8a, 0x3f, - 0xb1, 0x95, 0xe7, 0x3c, 0x1d, 0xac, 0xe9, 0xee, 0x54, 0xa7, 0x25, 0xe0, 0xb8, 0x94, 0x7a, 0x8d, - 0x21, 0x11, 0x01, 0xa8, 0xbd, 0x9d, 0x43, 0x77, 0xa5, 0x6a, 0xb6, 0x6c, 0x38, 0x2e, 0x6e, 0xa3, - 0x61, 0xc3, 0xa5, 0x6d, 0x07, 0xd4, 0x2b, 0x80, 0xec, 0x8b, 0x95, 0x4c, 0x2e, 0x5b, 0x49, 0x05, - 0xaf, 0x4e, 0x48, 0xbd, 0x86, 0x2f, 0x31, 0x78, 0x22, 0xa4, 0x68, 0xff, 0x93, 0x43, 0x38, 0xca, - 0x23, 0xac, 0x7b, 0x0b, 0x36, 0x7a, 0x7e, 0x37, 0x36, 0x3a, 0x22, 0x01, 0xc7, 0x84, 0x38, 0xc5, - 0x44, 0x6f, 0xe5, 0xd0, 0xb1, 0x5e, 0x8d, 0xb8, 0x6d, 0xd6, 0x55, 0xdb, 0xcc, 0xed, 0xc2, 0x36, - 0x02, 0x35, 0xc5, 0x28, 0x5f, 0xcd, 0xa3, 0xd2, 0x82, 0x4e, 0xdb, 0x56, 0xa7, 0x0e, 0xb6, 0x78, - 0x01, 0x15, 0xdb, 0xc0, 0xdf, 0xd4, 0x5d, 0x9d, 0xdb, 0x63, 0xec, 0xcc, 0x03, 0x7d, 0x06, 0xbb, - 0x75, 0xba, 0x72, 0x65, 0xed, 0x3a, 0x6d, 0xb8, 0x20, 0x47, 0xaf, 0x62, 0x89, 0x8f, 0xc2, 0x36, - 0x12, 0xa0, 0xe1, 0x57, 0xd1, 0x90, 0xd3, 0xa5, 0x0d, 0x69, 0xc2, 0x27, 0x32, 0x0e, 0x27, 0xd0, - 0xb0, 0x0e, 0x18, 0xe1, 0x1c, 0xb1, 0x2f, 0xc2, 0x71, 0xc1, 0x5e, 0x23, 0x0e, 0x9f, 0xfc, 0x72, - 0x81, 0x4b, 0x38, 0x3f, 0xb0, 0x04, 0xe1, 0x42, 0x93, 0x52, 0xc6, 0x88, 0xf8, 0x26, 0x12, 0x5d, - 0xfb, 0x41, 0x0e, 0x4d, 0x04, 0xb4, 0x7c, 0xa6, 0x5e, 0xe9, 0xb1, 0xd9, 0x6c, 0x1f, 0x9b, 0x45, - 0x22, 0x5d, 0x85, 0xb1, 0x73, 0xd3, 0x4d, 0x49, 0x61, 0x45, 0xbf, 0x25, 0x62, 0xb8, 0x57, 0x7c, - 0x47, 0xc8, 0x73, 0x47, 0x38, 0x3b, 0xe8, 0xb8, 0x52, 0xe6, 0xff, 0x27, 0xd1, 0xf1, 0xd4, 0x85, - 0x25, 0x8b, 0x0e, 0x35, 0x61, 0x06, 0x2d, 0x5b, 0x8e, 0x27, 0xeb, 0x6c, 0x2d, 0xeb, 0x6b, 0xd4, - 0xac, 0x4b, 0x8c, 0xea, 0x38, 0x1b, 0x98, 0xff, 0x45, 0x02, 0x6c, 0xfc, 0x12, 0x2a, 0x82, 0x06, - 0x5d, 0x13, 0x42, 0xab, 0xf4, 0x8a, 0x53, 0xfd, 0x7d, 0xad, 0x66, 0x35, 0x57, 0x25, 0x03, 0x77, - 0x83, 0xc0, 0x6a, 0x7e, 0x2b, 0x09, 0x00, 0xb5, 0xef, 0xe4, 0xd1, 0xa1, 0xd8, 0x94, 0xe2, 0x6b, - 0xe8, 0x58, 0x43, 0x84, 0x89, 0xcb, 0x5e, 0x1b, 0x04, 0xd4, 0x1b, 0x1b, 0xb4, 0xe9, 0x99, 0xb4, - 0x29, 0xc3, 0xee, 0x09, 0x89, 0x77, 0x6c, 0x3e, 0x91, 0x8a, 0xa4, 0x70, 0xe3, 0x67, 0x10, 0xee, - 0xf0, 0xa6, 0x15, 0xc3, 0x71, 0x02, 0xcc, 0x3c, 0xc7, 0x9c, 0x91, 0x98, 0xf8, 0x72, 0x0f, 0x05, - 0x49, 0xe0, 0x62, 0x3a, 0x36, 0xa9, 0x63, 0xd8, 0xb4, 0x19, 0xd7, 0xb1, 0xa0, 0xea, 0xb8, 0x90, - 0x48, 0x45, 0x52, 0xb8, 0xf1, 0x23, 0x68, 0x4c, 0x48, 0x23, 0x54, 0x6f, 0xee, 0x94, 0x87, 0x38, - 0x58, 0x10, 0x9a, 0x2e, 0x87, 0x5d, 0x24, 0x4a, 0xa7, 0x7d, 0x2d, 0x8f, 0xd0, 0x02, 0xed, 0x9a, - 0xd6, 0x4e, 0x1b, 0x06, 0xbe, 0x8f, 0xe1, 0xe1, 0x35, 0x25, 0x3c, 0x3c, 0x99, 0xd5, 0xc9, 0x03, - 0x15, 0x53, 0xe3, 0x43, 0x2b, 0x16, 0x1f, 0x9e, 0x1a, 0x5c, 0x44, 0xff, 0x00, 0xf1, 0xc3, 0x1c, - 0x9a, 0x0c, 0x89, 0x0f, 0x22, 0x42, 0xbc, 0xaa, 0x46, 0x88, 0xc7, 0x06, 0x1e, 0x59, 0x4a, 0x88, - 0x78, 0xb7, 0x80, 0x70, 0x48, 0x44, 0x2c, 0xd3, 0x5c, 0xd3, 0x1b, 0x9b, 0xb7, 0xb0, 0x6f, 0x7e, - 0x19, 0x36, 0x5c, 0xaf, 0xdb, 0x64, 0xb9, 0xd3, 0x5c, 0xa7, 0x63, 0xb9, 0x3c, 0xef, 0xf1, 0xd5, - 0xfc, 0xc7, 0x81, 0xd5, 0xf4, 0x35, 0xa8, 0x5c, 0xed, 0xc1, 0x5e, 0xec, 0xb8, 0xf6, 0x4e, 0xb8, - 0xe8, 0x7a, 0x09, 0x48, 0x82, 0x42, 0xf8, 0x75, 0x84, 0x6c, 0x89, 0xb9, 0x6a, 0x49, 0xff, 0xc8, - 0xea, 0x82, 0xbe, 0x52, 0xf3, 0x56, 0x67, 0xdd, 0x68, 0x85, 0xde, 0x4e, 0x02, 0x60, 0x12, 0x11, - 0x32, 0xb3, 0x88, 0x8e, 0xa7, 0x68, 0x8f, 0xa7, 0x50, 0x61, 0x93, 0xee, 0x08, 0xb3, 0x12, 0xf6, - 0x5f, 0x3c, 0x1d, 0xcd, 0x3f, 0x4a, 0x32, 0x79, 0x38, 0x97, 0x3f, 0x9b, 0xd3, 0xde, 0x1d, 0x8e, - 0x3a, 0x1b, 0x0f, 0xdf, 0x0f, 0xa0, 0xa2, 0x0d, 0x2d, 0x46, 0x43, 0x77, 0x64, 0x5c, 0xe3, 0x01, - 0x98, 0xc8, 0x36, 0x12, 0xf4, 0x2a, 0x81, 0x3e, 0x7f, 0x40, 0x81, 0xbe, 0xb0, 0xc7, 0x81, 0x1e, - 0x5b, 0x30, 0x08, 0x97, 0xa5, 0xe7, 0x2d, 0x11, 0xd5, 0xb2, 0xa7, 0x4a, 0xd1, 0x95, 0x2d, 0x80, - 0x42, 0x81, 0x7e, 0x0b, 0x09, 0x84, 0xe0, 0x39, 0x74, 0xa8, 0x6d, 0x74, 0x78, 0x78, 0xac, 0xd3, - 0x86, 0xd5, 0x69, 0x3a, 0xe5, 0x61, 0x6e, 0xe6, 0xe3, 0x92, 0xe9, 0xd0, 0x8a, 0xda, 0x4d, 0xe2, - 0xf4, 0x78, 0x19, 0x4d, 0xdb, 0x74, 0xcb, 0x60, 0x6a, 0x5c, 0x84, 0xe5, 0x6c, 0xd9, 0x3b, 0xcb, - 0x46, 0xdb, 0x70, 0xcb, 0x23, 0x22, 0xfb, 0x07, 0x8c, 0x69, 0x92, 0xd0, 0x4f, 0x12, 0xb9, 0xf0, - 0x7d, 0x68, 0xa4, 0xab, 0x7b, 0x0e, 0x6c, 0x11, 0xa3, 0xc0, 0x5f, 0x0c, 0x03, 0x53, 0x8d, 0xb7, - 0x12, 0xd9, 0x0b, 0xd9, 0x76, 0xd4, 0xcb, 0x8b, 0x7b, 0xe1, 0xe5, 0x93, 0xe9, 0x1e, 0xae, 0x7d, - 0x96, 0x47, 0x53, 0xf1, 0xa0, 0xc9, 0xb6, 0x4a, 0x6b, 0xcd, 0xa1, 0xf6, 0x16, 0x6d, 0x5e, 0x10, - 0xc7, 0x2a, 0x80, 0xe7, 0x6e, 0x5a, 0x08, 0x57, 0xed, 0x95, 0x1e, 0x0a, 0x92, 0xc0, 0x85, 0x1f, - 0x8a, 0x38, 0xba, 0xd8, 0x6c, 0x83, 0x69, 0x4b, 0x70, 0x76, 0x98, 0x36, 0xb9, 0xf2, 0xfd, 0x4e, - 0xb9, 0xa3, 0x06, 0xd3, 0x76, 0x55, 0xed, 0x26, 0x71, 0x7a, 0x7c, 0x01, 0x1d, 0xd6, 0xb7, 0x74, - 0xc3, 0xd4, 0xd7, 0x4c, 0x1a, 0x80, 0x88, 0x9d, 0xf4, 0x76, 0x09, 0x72, 0x78, 0x2e, 0x4e, 0x40, - 0x7a, 0x79, 0xf0, 0x0a, 0x3a, 0xe2, 0x75, 0x7a, 0xa1, 0x84, 0x1b, 0xdd, 0x21, 0xa1, 0x8e, 0x5c, - 0xed, 0x25, 0x21, 0x49, 0x7c, 0xda, 0x8f, 0x72, 0xd1, 0xf8, 0xec, 0xbb, 0x2c, 0x3e, 0x87, 0x86, - 0xdc, 0x9d, 0xae, 0x1f, 0x9f, 0xef, 0xf3, 0xe3, 0xf3, 0x2a, 0xb4, 0x7d, 0xce, 0x13, 0x88, 0x38, - 0x07, 0xeb, 0x21, 0x9c, 0x07, 0xff, 0x2b, 0x9a, 0x60, 0x53, 0x69, 0x74, 0x5a, 0xc2, 0x2a, 0x32, - 0x3e, 0x2c, 0x0d, 0xe0, 0x2e, 0x01, 0x46, 0x64, 0x9f, 0x39, 0x0c, 0x8a, 0x4c, 0x28, 0x9d, 0x44, - 0x95, 0x07, 0x87, 0xe6, 0x89, 0xc5, 0xed, 0xae, 0x65, 0xbb, 0x57, 0xba, 0x22, 0x46, 0x83, 0x97, - 0x53, 0xde, 0xc0, 0xc7, 0x13, 0xf1, 0x72, 0x41, 0x46, 0x64, 0x2f, 0xbe, 0x17, 0x0d, 0xd3, 0x6d, - 0xbd, 0xe1, 0x72, 0x8d, 0x8b, 0xe1, 0x8e, 0xb6, 0xc8, 0x1a, 0x89, 0xe8, 0xd3, 0xbe, 0x0e, 0xe7, - 0xae, 0xa5, 0xfa, 0x05, 0xdb, 0xf2, 0xba, 0xfe, 0xe0, 0x7d, 0x39, 0xff, 0x80, 0x86, 0x6c, 0xc8, - 0x98, 0xa4, 0xd5, 0xee, 0xf5, 0xad, 0x46, 0xa0, 0x0d, 0xac, 0x76, 0x24, 0xc6, 0x25, 0x4c, 0xc6, - 0x18, 0x60, 0x17, 0x1e, 0xb1, 0xf5, 0x4e, 0x8b, 0xfa, 0xfb, 0xdb, 0xa3, 0x19, 0x6d, 0x75, 0x69, - 0x81, 0x30, 0xf6, 0x70, 0x60, 0xfc, 0x13, 0xf2, 0x0a, 0x81, 0xaa, 0x7d, 0x21, 0x87, 0x0e, 0x5d, - 0x5c, 0x5d, 0xad, 0x5d, 0xea, 0xb4, 0xe0, 0x90, 0xe9, 0xd4, 0x74, 0x77, 0x83, 0x6d, 0xc1, 0x5d, - 0xf8, 0x37, 0xbe, 0x05, 0xb3, 0x3e, 0xc2, 0x7b, 0xf0, 0x06, 0x1a, 0x65, 0xeb, 0x91, 0x76, 0x9a, - 0x03, 0xa6, 0x56, 0x52, 0x5c, 0x55, 0x80, 0x54, 0x0f, 0x49, 0x19, 0xa3, 0xb2, 0x81, 0xf8, 0xf0, - 0xda, 0x3f, 0xa3, 0xe9, 0x88, 0x7a, 0xcc, 0x5e, 0xfc, 0xa8, 0x8b, 0x1b, 0x68, 0x98, 0x69, 0xe2, - 0x1f, 0x64, 0xb3, 0x9e, 0xcb, 0x62, 0x43, 0x0e, 0x27, 0x94, 0x7d, 0x41, 0x8a, 0xc2, 0xb1, 0xb5, - 0x9f, 0xe5, 0xd1, 0xf1, 0x8b, 0x96, 0x6d, 0xbc, 0x69, 0x75, 0x5c, 0xdd, 0x84, 0xfd, 0x63, 0xce, - 0x73, 0x2d, 0xa7, 0xa1, 0x9b, 0xd4, 0xde, 0xc7, 0xa4, 0xd5, 0x54, 0x92, 0xd6, 0x67, 0xb2, 0x8e, - 0x2c, 0x59, 0xdf, 0xd4, 0x0c, 0xd6, 0x8d, 0x65, 0xb0, 0xcb, 0x7b, 0x24, 0xaf, 0x7f, 0x3a, 0xfb, - 0xbb, 0x1c, 0xba, 0x23, 0x85, 0xf3, 0x20, 0x72, 0xdb, 0x4d, 0x35, 0xb7, 0x5d, 0xda, 0x9b, 0x31, - 0xa7, 0x24, 0xba, 0xbf, 0xcf, 0xa7, 0x8e, 0x95, 0xa7, 0x56, 0xaf, 0x43, 0xae, 0xc1, 0xbe, 0x08, - 0x5d, 0x97, 0x63, 0x9d, 0xcf, 0xa8, 0x4f, 0xdd, 0x5b, 0xf3, 0x6f, 0x88, 0x00, 0x84, 0xc2, 0x69, - 0xb2, 0x41, 0x23, 0xd9, 0x86, 0x04, 0x27, 0x81, 0x18, 0x7c, 0x1a, 0x8d, 0xf1, 0xec, 0x41, 0xd9, - 0xe7, 0x0e, 0xb1, 0x33, 0xdb, 0x4a, 0xd8, 0x4c, 0xa2, 0x34, 0xec, 0xa8, 0xd7, 0xd6, 0xb7, 0x63, - 0xbb, 0x5c, 0x70, 0xd4, 0x5b, 0x09, 0xbb, 0x48, 0x94, 0x0e, 0x42, 0xfe, 0x64, 0xa3, 0xeb, 0x45, - 0x2e, 0x28, 0x65, 0x3a, 0x95, 0x75, 0x88, 0x49, 0x77, 0x9d, 0x55, 0x0c, 0xa2, 0x27, 0xa1, 0x27, - 0xd2, 0x46, 0x62, 0xe2, 0xb4, 0x0f, 0x0a, 0xe8, 0xae, 0xbe, 0x3e, 0x8a, 0x97, 0xfa, 0x64, 0x0f, - 0xc7, 0x32, 0x64, 0x0e, 0x4d, 0x34, 0x61, 0xea, 0x8e, 0xcb, 0xcd, 0xbd, 0x6a, 0xb4, 0xfd, 0xdd, - 0xed, 0x6f, 0x6f, 0xd1, 0x71, 0x19, 0x8b, 0xd8, 0xc2, 0x96, 0xa3, 0x28, 0x44, 0x05, 0x65, 0x19, - 0x87, 0xbc, 0x30, 0x48, 0xcb, 0x38, 0xe6, 0xd5, 0x6e, 0x12, 0xa7, 0x67, 0x10, 0xf2, 0x3c, 0x1f, - 0xcb, 0x37, 0x02, 0x88, 0x05, 0xb5, 0x9b, 0xc4, 0xe9, 0x21, 0xeb, 0x3b, 0x29, 0x51, 0x55, 0xf3, - 0x47, 0x2e, 0x9d, 0x45, 0xde, 0x71, 0x2f, 0xc0, 0x9d, 0x9c, 0xef, 0x4f, 0x4a, 0x6e, 0x86, 0xa5, - 0xad, 0xa0, 0x89, 0x8b, 0x96, 0xe3, 0xd6, 0xd8, 0x96, 0xcc, 0xf6, 0x2d, 0x7c, 0x17, 0x2a, 0x80, - 0x73, 0xca, 0x93, 0xc8, 0x98, 0x54, 0xbb, 0xc0, 0x9c, 0x97, 0xb5, 0xf3, 0x6e, 0x7d, 0x5b, 0xfa, - 0x75, 0xd8, 0x0d, 0x7e, 0xc9, 0xda, 0xb5, 0x0b, 0x68, 0x54, 0xee, 0x8b, 0x51, 0xa0, 0x42, 0x7f, - 0xa0, 0x42, 0x02, 0xd0, 0x57, 0xf2, 0x80, 0x24, 0xb6, 0x91, 0x7d, 0xdc, 0x10, 0x5e, 0x56, 0x36, - 0x84, 0x73, 0x83, 0x6d, 0xb5, 0xa9, 0x1b, 0x40, 0x33, 0xb6, 0x01, 0x3c, 0x31, 0x20, 0x7e, 0xff, - 0x80, 0xff, 0x5e, 0x0e, 0x4d, 0xaa, 0x9b, 0x3e, 0x8b, 0x28, 0x6c, 0x0d, 0x19, 0x0d, 0x7a, 0x39, - 0x3c, 0xf0, 0x07, 0x11, 0xa5, 0x1e, 0x76, 0x91, 0x28, 0x1d, 0xa6, 0x01, 0x1b, 0x73, 0x07, 0x69, - 0x94, 0x4a, 0x8a, 0xd2, 0xec, 0xc5, 0xa5, 0x22, 0x5e, 0x5c, 0x40, 0x51, 0xf7, 0x0a, 0xac, 0x79, - 0x1b, 0xd2, 0xc1, 0x1e, 0x31, 0xdc, 0xb3, 0xa2, 0xb8, 0xda, 0xf7, 0x73, 0x68, 0x4c, 0x2a, 0x7c, - 0x10, 0x3b, 0xd2, 0x4b, 0xea, 0x8e, 0xf4, 0xe8, 0x80, 0xf9, 0x54, 0xf2, 0x0e, 0xf4, 0x7e, 0x38, - 0x16, 0x96, 0x41, 0xb1, 0x04, 0x6f, 0x03, 0x96, 0x53, 0x3c, 0xc1, 0x63, 0x4b, 0x8c, 0xf0, 0x1e, - 0xfc, 0x9f, 0x39, 0x34, 0x65, 0xc4, 0x72, 0x2e, 0x69, 0xea, 0xa7, 0x06, 0x53, 0x2d, 0x80, 0x09, - 0xdf, 0xa1, 0xe2, 0x3d, 0xa4, 0x47, 0xa4, 0xe6, 0xa1, 0x1e, 0x2a, 0xac, 0x83, 0xf6, 0xae, 0xdb, - 0x1d, 0x70, 0xaf, 0x4c, 0xca, 0x26, 0xab, 0x45, 0x3e, 0x7c, 0xe8, 0x21, 0x1c, 0x5a, 0x7b, 0x2f, - 0x1f, 0x18, 0xac, 0x2e, 0xd6, 0x48, 0x90, 0xef, 0xe6, 0xf6, 0x22, 0xdf, 0x1d, 0x4b, 0xca, 0x75, - 0x21, 0x82, 0x14, 0x5c, 0x73, 0xd0, 0xfb, 0x36, 0x29, 0x61, 0x75, 0xb9, 0x1e, 0xc6, 0x29, 0xf8, - 0x20, 0x0c, 0x12, 0xbf, 0x86, 0x86, 0xd9, 0x69, 0x82, 0x2d, 0xf1, 0xc2, 0xe0, 0x21, 0x84, 0xd9, - 0x2b, 0xf4, 0x30, 0xf6, 0x05, 0x1e, 0xc6, 0x71, 0x21, 0x4d, 0x9f, 0x50, 0xe2, 0x00, 0xbe, 0x8e, - 0xc6, 0x4d, 0x4b, 0x6f, 0x56, 0x75, 0x53, 0x87, 0x64, 0xc4, 0xbf, 0xf2, 0xff, 0xbb, 0xfe, 0x11, - 0x71, 0x39, 0xc2, 0x21, 0xe3, 0x49, 0xf0, 0x16, 0x18, 0xed, 0x23, 0x0a, 0xb6, 0xa6, 0x23, 0x14, - 0x8e, 0x1e, 0x9f, 0x44, 0xc3, 0xcc, 0x85, 0xc5, 0xc9, 0xa0, 0x54, 0x2d, 0x31, 0x5d, 0x99, 0x67, - 0x83, 0xae, 0xbc, 0x1d, 0x9f, 0x41, 0xc8, 0xa1, 0x0d, 0x9b, 0xba, 0x3c, 0xec, 0xf0, 0xcb, 0xaf, - 0x30, 0x00, 0xd7, 0x83, 0x1e, 0x12, 0xa1, 0xd2, 0xfe, 0x2f, 0x8f, 0x0a, 0xcf, 0x58, 0x6b, 0xfb, - 0x18, 0xe4, 0x5f, 0x50, 0x82, 0x7c, 0xd6, 0xf5, 0x0f, 0xba, 0xa5, 0x06, 0xf8, 0x7f, 0x8a, 0x05, - 0xf8, 0xb3, 0x03, 0x60, 0xf7, 0x0f, 0xee, 0x3f, 0x2e, 0xa0, 0x71, 0xa0, 0x9a, 0xb7, 0x3a, 0x4d, - 0x83, 0xa7, 0x42, 0x0f, 0x2b, 0x97, 0x04, 0x77, 0xc7, 0x2e, 0x09, 0xa6, 0xa2, 0xb4, 0x91, 0xeb, - 0x81, 0x6b, 0x81, 0xa2, 0x62, 0x52, 0xce, 0xab, 0xe2, 0x80, 0xb3, 0xef, 0xa3, 0x7d, 0x25, 0xc0, - 0x54, 0xd5, 0x83, 0xd3, 0x2a, 0xcf, 0xa1, 0x6a, 0xb6, 0xb5, 0x26, 0x12, 0xb3, 0x42, 0xf6, 0xc4, - 0xec, 0xa8, 0xd4, 0x85, 0x27, 0x67, 0x01, 0x12, 0x51, 0x81, 0xf1, 0x1b, 0x08, 0xb3, 0x86, 0x55, - 0x38, 0x5c, 0x3b, 0x62, 0x74, 0x4c, 0xdc, 0x50, 0x76, 0x71, 0xc1, 0xad, 0xd5, 0x72, 0x0f, 0x1c, - 0x49, 0x10, 0xc1, 0xee, 0x31, 0x6c, 0xaa, 0x3b, 0x90, 0xb7, 0x0e, 0x73, 0xd3, 0x85, 0xc7, 0x7d, - 0xde, 0x4a, 0x64, 0x2f, 0x7e, 0x10, 0x8d, 0xb6, 0x61, 0x9d, 0xb0, 0xfc, 0x6c, 0x84, 0x13, 0x06, - 0x27, 0xef, 0x15, 0xd1, 0x4c, 0xfc, 0x7e, 0xed, 0xdb, 0x39, 0x34, 0x0a, 0x13, 0x75, 0x10, 0x9b, - 0xdf, 0xf3, 0xea, 0xe6, 0x77, 0x26, 0xbb, 0x83, 0xa6, 0x6c, 0x7c, 0xdf, 0x2c, 0xf0, 0x31, 0xf0, - 0x18, 0x0e, 0x67, 0x9e, 0xae, 0x6e, 0xeb, 0xa6, 0x49, 0x4d, 0xc3, 0x69, 0xcb, 0xd4, 0x91, 0x9f, - 0x79, 0x6a, 0x61, 0x33, 0x89, 0xd2, 0x30, 0x96, 0x86, 0xd5, 0xee, 0x9a, 0xd4, 0x7f, 0x61, 0x08, - 0x58, 0xe6, 0xc3, 0x66, 0x12, 0xa5, 0xc1, 0x57, 0xd0, 0x51, 0xbd, 0xe1, 0x1a, 0x5b, 0x74, 0x81, - 0xea, 0x4d, 0xd3, 0xe8, 0x50, 0xff, 0x36, 0xb7, 0xc0, 0x53, 0xc8, 0xdb, 0x81, 0xf9, 0xe8, 0x5c, - 0x12, 0x01, 0x49, 0xe6, 0x53, 0xae, 0xd3, 0x87, 0xf6, 0xf1, 0x3a, 0xfd, 0x61, 0x34, 0xae, 0xc3, - 0xc9, 0xc8, 0xef, 0xe1, 0x7e, 0x54, 0xac, 0x4e, 0xb1, 0xd0, 0x3b, 0x17, 0x69, 0x27, 0x0a, 0x95, - 0x72, 0x09, 0x3f, 0xb2, 0xd7, 0xaf, 0xad, 0xdf, 0x2a, 0xa0, 0x52, 0x10, 0x7c, 0xb0, 0x85, 0x50, - 0xc3, 0x5f, 0xe0, 0xfe, 0xb5, 0xcf, 0xe3, 0xd9, 0x3d, 0x25, 0x08, 0x12, 0x61, 0x3c, 0x0e, 0x9a, - 0x1c, 0x12, 0x11, 0x01, 0x11, 0xb9, 0x04, 0x01, 0xc4, 0x76, 0x07, 0x3d, 0xcb, 0x4d, 0x00, 0x76, - 0xa9, 0xee, 0x23, 0x90, 0x10, 0x0c, 0xb7, 0xe0, 0x50, 0x1c, 0xf8, 0xcc, 0xa0, 0x11, 0x49, 0x1c, - 0x7e, 0x15, 0x18, 0x12, 0x83, 0x65, 0x61, 0x41, 0x78, 0x95, 0x3c, 0xe0, 0x05, 0x61, 0x41, 0xb8, - 0x20, 0x91, 0xbd, 0x78, 0x16, 0x86, 0xea, 0x35, 0x1a, 0x94, 0x36, 0x69, 0x53, 0x1e, 0xdc, 0x0e, - 0x4b, 0xd2, 0x52, 0xdd, 0xef, 0x20, 0x21, 0x0d, 0x03, 0x5e, 0xd7, 0x0d, 0xf6, 0x80, 0x3c, 0xa2, - 0x02, 0x2f, 0xf1, 0x56, 0x22, 0x7b, 0xb5, 0xdf, 0xe6, 0xd1, 0x84, 0xe2, 0x7f, 0xf8, 0x3f, 0x72, - 0xec, 0x22, 0xc1, 0x6d, 0x6c, 0xf0, 0x66, 0x7f, 0x22, 0x57, 0x76, 0xe3, 0xd3, 0x95, 0x95, 0x10, - 0x4f, 0x3c, 0xd5, 0x45, 0xee, 0x25, 0x82, 0x1e, 0x12, 0x15, 0x8b, 0xff, 0x1b, 0x12, 0x5c, 0xfe, - 0xbd, 0xb8, 0xdd, 0x65, 0x99, 0x43, 0xe4, 0x09, 0xf1, 0xc2, 0x6e, 0x74, 0x21, 0xf4, 0x75, 0x0f, - 0x4e, 0xca, 0xfc, 0x3e, 0x3a, 0x48, 0x74, 0x57, 0x62, 0x82, 0x48, 0x8f, 0xe8, 0x99, 0xf3, 0x68, - 0x2a, 0x3e, 0x8a, 0x4c, 0x4f, 0x76, 0x5f, 0xca, 0xa1, 0x72, 0x9a, 0x22, 0xec, 0x14, 0x1b, 0x00, - 0x85, 0xd9, 0xe1, 0xb3, 0x74, 0x47, 0xa0, 0x2e, 0xa2, 0xa2, 0xd5, 0x65, 0xb7, 0x18, 0xf2, 0xc5, - 0xae, 0x54, 0x7d, 0xd0, 0x5f, 0x95, 0x57, 0x64, 0x3b, 0xec, 0xbd, 0x47, 0x15, 0x78, 0xbf, 0x83, - 0x04, 0xac, 0x58, 0x43, 0x23, 0x5c, 0x1f, 0x91, 0x65, 0x96, 0xaa, 0x88, 0xf9, 0x03, 0xcf, 0xaf, - 0x61, 0x2b, 0x16, 0x3d, 0xbc, 0xce, 0xe5, 0x32, 0x75, 0xdf, 0xb0, 0xec, 0xcd, 0x9a, 0x65, 0x1a, - 0x8d, 0x9d, 0x7d, 0xcc, 0xa8, 0xd6, 0x94, 0x8c, 0xea, 0xe9, 0x8c, 0xb3, 0xaa, 0x68, 0x99, 0x96, - 0x5b, 0x69, 0xbf, 0x01, 0xb3, 0x2b, 0x94, 0xd1, 0x63, 0x16, 0x45, 0xc3, 0xec, 0xf1, 0xc0, 0xf7, - 0xf1, 0x5d, 0x69, 0xc0, 0xce, 0xa4, 0x91, 0x5b, 0x6a, 0x06, 0x4b, 0x04, 0x3a, 0x1b, 0xe7, 0xba, - 0x6d, 0xb5, 0xa5, 0xf7, 0xee, 0x4e, 0x0a, 0xa5, 0x76, 0x38, 0xce, 0x25, 0x40, 0x25, 0x1c, 0x5b, - 0xfb, 0x69, 0x0e, 0x1d, 0x56, 0x28, 0x0f, 0x22, 0x2d, 0xd0, 0xd5, 0xb4, 0xe0, 0x89, 0xdd, 0x8c, - 0x2c, 0x25, 0x41, 0xf8, 0xaf, 0x7c, 0x6c, 0x5c, 0xcc, 0x02, 0xb0, 0xd5, 0x8c, 0x75, 0xad, 0x66, - 0x7d, 0x2f, 0xcb, 0x95, 0x44, 0xa2, 0x11, 0x82, 0x92, 0xa8, 0x04, 0xfc, 0x6f, 0x60, 0x5e, 0x56, - 0xdb, 0xe0, 0x74, 0xf5, 0x06, 0xad, 0xef, 0xe5, 0xeb, 0xf9, 0x51, 0xf6, 0x7c, 0x78, 0x39, 0x0e, - 0x4d, 0x7a, 0xa5, 0x69, 0xdf, 0x88, 0x4f, 0x31, 0x73, 0x32, 0xfc, 0x1c, 0x2a, 0xf2, 0xfa, 0xd4, - 0x86, 0x65, 0xca, 0xf8, 0xf1, 0x08, 0x9b, 0xad, 0x9a, 0x6c, 0x83, 0xb8, 0xf0, 0x37, 0x7d, 0x73, - 0x72, 0x9f, 0x90, 0x04, 0x30, 0x78, 0x19, 0x0d, 0x75, 0x07, 0xbf, 0xb9, 0xe1, 0x47, 0x75, 0x7e, - 0x5d, 0xc3, 0x51, 0xb4, 0x3f, 0xc4, 0xd5, 0xe6, 0xc9, 0x9e, 0xb3, 0xf7, 0x33, 0x18, 0xec, 0x29, - 0xa9, 0xb3, 0x68, 0xa3, 0x51, 0x79, 0x81, 0x31, 0xe0, 0x4e, 0x92, 0x16, 0x49, 0xc2, 0x2c, 0xdd, - 0x6f, 0xf4, 0x05, 0xf1, 0x85, 0xc9, 0x15, 0x6a, 0x78, 0xb6, 0xe1, 0xee, 0xec, 0x7b, 0x50, 0x5d, - 0x57, 0x82, 0xea, 0x42, 0xc6, 0x01, 0xf6, 0x68, 0x9a, 0x1a, 0x58, 0x7f, 0x99, 0x43, 0x47, 0x7b, - 0xa8, 0x0f, 0x22, 0xe8, 0x50, 0x35, 0xe8, 0x3c, 0xbd, 0xdb, 0x11, 0xa6, 0x04, 0x9e, 0x1b, 0x28, - 0x61, 0x7c, 0xdc, 0x75, 0xcf, 0x20, 0xd4, 0xb5, 0x8d, 0x2d, 0x48, 0x9f, 0x5a, 0xb2, 0x86, 0xb0, - 0x18, 0xce, 0x49, 0x2d, 0xe8, 0x21, 0x11, 0x2a, 0xfc, 0x2f, 0xac, 0xbe, 0x6f, 0x5d, 0xf7, 0x4c, - 0x77, 0xae, 0xd9, 0x9c, 0xd7, 0xbb, 0xfa, 0x9a, 0x61, 0x42, 0x16, 0x2b, 0x5f, 0x8d, 0x4b, 0xd5, - 0x45, 0x51, 0xdb, 0x97, 0x44, 0x01, 0x2b, 0xf8, 0xfe, 0xfe, 0xa7, 0x6a, 0x9f, 0x78, 0x87, 0xa4, - 0x08, 0xc1, 0xff, 0x0e, 0xbb, 0xa0, 0x2d, 0xf2, 0x8d, 0xe6, 0x82, 0x6d, 0x75, 0x15, 0x0d, 0x44, - 0x32, 0x70, 0x01, 0x34, 0x28, 0x93, 0x14, 0x9a, 0x2c, 0x3a, 0xa4, 0x0a, 0xc2, 0x2e, 0x3a, 0x02, - 0x27, 0x37, 0xeb, 0x0d, 0xaa, 0x5a, 0x60, 0x88, 0xcb, 0xaf, 0xb2, 0xda, 0x87, 0xb9, 0xde, 0xee, - 0x2c, 0xa2, 0x93, 0xe0, 0x21, 0x75, 0x1e, 0xdd, 0xb2, 0x4c, 0x0f, 0xa2, 0x29, 0x24, 0xce, 0x4c, - 0x12, 0x8b, 0xb8, 0xa3, 0xd7, 0x44, 0xd3, 0xe7, 0x2c, 0x23, 0xae, 0xf3, 0x2b, 0x0e, 0x9f, 0x8a, - 0x5d, 0x7b, 0xb3, 0x7b, 0x28, 0xb9, 0xd6, 0x79, 0xfe, 0x5c, 0x0c, 0x83, 0xcb, 0xc5, 0xb0, 0x8b, - 0x44, 0xe9, 0x70, 0x1b, 0x95, 0x36, 0xe4, 0x13, 0x88, 0x53, 0x1e, 0x1d, 0x68, 0x43, 0x54, 0x9e, - 0x50, 0xc2, 0x04, 0xdf, 0x6f, 0x76, 0x48, 0x28, 0x81, 0x5d, 0x14, 0xf0, 0x8f, 0x4b, 0x0b, 0xbc, - 0xa6, 0xa7, 0x18, 0x86, 0xa0, 0x8b, 0xa2, 0x99, 0xf8, 0xfd, 0x3e, 0xe9, 0xa5, 0xda, 0x7c, 0xb9, - 0xd4, 0x4b, 0x0a, 0xcd, 0xc4, 0xef, 0xc7, 0x5d, 0x34, 0xea, 0xd0, 0x65, 0xa3, 0xe3, 0x6d, 0x97, - 0x11, 0x5f, 0xba, 0x8b, 0x59, 0x5f, 0x3a, 0x17, 0x39, 0x77, 0xac, 0xbc, 0x22, 0x94, 0x28, 0xfb, - 0x89, 0x2f, 0x06, 0x6f, 0xa3, 0x92, 0xed, 0x75, 0xe6, 0x9c, 0xab, 0x0e, 0xb5, 0xcb, 0x63, 0x5c, - 0x66, 0xd6, 0xa8, 0x4c, 0x7c, 0xfe, 0xb8, 0xd4, 0xc0, 0x82, 0x01, 0x05, 0x09, 0x85, 0xe1, 0xff, - 0xcf, 0x21, 0xec, 0x78, 0x5d, 0x38, 0x8e, 0xb1, 0x1c, 0x5c, 0x37, 0x79, 0x85, 0x87, 0x53, 0x1e, - 0xe7, 0x3a, 0xd4, 0x32, 0xbf, 0xf0, 0xc6, 0x81, 0xe2, 0xca, 0x04, 0x37, 0x46, 0xbd, 0xa4, 0x24, - 0x41, 0x0f, 0x36, 0x15, 0xeb, 0x0e, 0xff, 0x7f, 0x79, 0x62, 0xa0, 0xa9, 0x48, 0xae, 0x74, 0x09, - 0xa7, 0x42, 0xf6, 0x13, 0x5f, 0x0c, 0x2b, 0x42, 0xb6, 0xa9, 0xde, 0xbc, 0xd2, 0x31, 0x77, 0x88, - 0x65, 0xb9, 0x4b, 0x10, 0xbb, 0x9c, 0x1d, 0x07, 0xa2, 0x61, 0x79, 0x92, 0xbb, 0x4d, 0x50, 0x84, - 0x4c, 0x12, 0xa9, 0x48, 0x0a, 0x37, 0xaf, 0x26, 0x96, 0x0f, 0x93, 0xfb, 0xfb, 0x63, 0x83, 0xdd, - 0x55, 0x13, 0x87, 0x2a, 0xee, 0x5b, 0x35, 0x71, 0x44, 0x44, 0xff, 0x0b, 0xdb, 0x4f, 0x0a, 0xe8, - 0x48, 0x48, 0x1c, 0xde, 0xdb, 0x3e, 0xae, 0xdc, 0xdb, 0xde, 0x1f, 0xbb, 0xb7, 0x3d, 0x9e, 0xc0, - 0xf2, 0xd7, 0xeb, 0xdb, 0x3f, 0xd1, 0xeb, 0x5b, 0x56, 0x30, 0x1e, 0xce, 0xd7, 0x9f, 0x41, 0xc1, - 0x78, 0xa8, 0x6c, 0x4a, 0xca, 0xf4, 0x41, 0x3e, 0x3a, 0xa2, 0xbf, 0xc4, 0xaa, 0xe4, 0x84, 0x22, - 0xe1, 0xa1, 0x6c, 0x45, 0xc2, 0xda, 0x2f, 0x0a, 0x68, 0x2a, 0x1e, 0x26, 0x94, 0x9a, 0xd7, 0xdc, - 0x4d, 0x6b, 0x5e, 0x6b, 0x68, 0x7a, 0xdd, 0x33, 0xcd, 0x1d, 0x6e, 0x90, 0x48, 0x0d, 0x89, 0xb8, - 0x1e, 0xbf, 0x53, 0x72, 0x4e, 0x2f, 0x25, 0xd0, 0x90, 0x44, 0xce, 0x94, 0xfa, 0xdd, 0xc2, 0x40, - 0xf5, 0xbb, 0x8f, 0xa3, 0x09, 0x9b, 0xff, 0xe2, 0x44, 0x2d, 0x6d, 0x09, 0x02, 0x00, 0x89, 0x76, - 0x12, 0x95, 0x36, 0xb9, 0x16, 0x77, 0x78, 0x80, 0x5a, 0xdc, 0x2d, 0xe5, 0xb2, 0x7a, 0x84, 0x2f, - 0x88, 0xea, 0xc0, 0x0b, 0xe2, 0x96, 0xef, 0xac, 0xb5, 0x3b, 0xd1, 0x8c, 0x64, 0x63, 0xdf, 0x40, - 0xe4, 0xb2, 0x02, 0x58, 0x6a, 0x2f, 0x78, 0xed, 0xf6, 0x8e, 0x76, 0x1e, 0x16, 0x90, 0x52, 0x6a, - 0x2d, 0x66, 0x5e, 0x54, 0x7f, 0xcb, 0x1a, 0x98, 0xc8, 0xcc, 0x8b, 0x76, 0x12, 0x50, 0x68, 0x1f, - 0xe7, 0xd0, 0xf1, 0x94, 0xe2, 0x5b, 0x7c, 0x1d, 0x4d, 0xb6, 0xf5, 0xed, 0x48, 0x75, 0xb1, 0x0c, - 0x31, 0x59, 0xcf, 0xf7, 0xfc, 0x5a, 0x7b, 0x45, 0x41, 0x22, 0x31, 0x64, 0xbe, 0xc5, 0xeb, 0xdb, - 0x75, 0xcf, 0x6e, 0xd1, 0x01, 0x6f, 0x11, 0xf8, 0xf2, 0x5d, 0x91, 0x18, 0x24, 0x40, 0x63, 0x25, - 0xbc, 0xe5, 0xb4, 0x7c, 0x0f, 0x32, 0xf7, 0x68, 0x11, 0xef, 0x3d, 0xb1, 0x22, 0xde, 0xc3, 0x3d, - 0x7c, 0x07, 0x54, 0xc2, 0xfb, 0x7e, 0x0e, 0x1d, 0x4b, 0xce, 0x8b, 0xf1, 0xdf, 0x2b, 0x1a, 0x9f, - 0x8c, 0x69, 0x7c, 0x28, 0xc6, 0x25, 0xf5, 0xdd, 0x40, 0x93, 0x32, 0x7b, 0x96, 0x30, 0xb7, 0xf0, - 0x03, 0xd5, 0xad, 0x20, 0x35, 0xf7, 0xf3, 0x40, 0x3e, 0x8f, 0x6a, 0x1b, 0x89, 0xe1, 0x6a, 0x5f, - 0xcc, 0xa3, 0x61, 0x5e, 0xd9, 0xb6, 0x8f, 0x49, 0xdb, 0x8b, 0x4a, 0xd2, 0x96, 0xf5, 0xed, 0x9b, - 0x6b, 0x97, 0x9a, 0xaf, 0xad, 0xc5, 0xf2, 0xb5, 0x73, 0x03, 0xa1, 0xf7, 0x4f, 0xd5, 0x1e, 0x43, - 0xa5, 0x40, 0x89, 0x6c, 0x81, 0x9a, 0x25, 0xc6, 0x63, 0x11, 0x11, 0x19, 0xc3, 0xfc, 0x96, 0xb2, - 0x63, 0x0e, 0xf2, 0x4b, 0xea, 0x88, 0xec, 0x8a, 0xbf, 0x55, 0x8a, 0xf7, 0x99, 0xb0, 0x36, 0xb5, - 0x77, 0x07, 0x85, 0x20, 0x25, 0x7e, 0x8e, 0x1e, 0xdc, 0xde, 0x15, 0xb8, 0xf7, 0x1e, 0x93, 0x3c, - 0x93, 0xab, 0x4a, 0x2f, 0x89, 0x51, 0xcf, 0xc0, 0x06, 0xa0, 0x08, 0xcb, 0xf4, 0x8c, 0xf2, 0xdd, - 0x1c, 0x9a, 0x4e, 0xaa, 0xa6, 0x65, 0x25, 0x53, 0x9b, 0x86, 0x2c, 0xff, 0x89, 0x94, 0x4c, 0x3d, - 0x0b, 0x6d, 0x84, 0xf7, 0x04, 0x3f, 0x5c, 0xcb, 0xa7, 0xfe, 0x70, 0xed, 0x0c, 0x42, 0x60, 0x2a, - 0xf9, 0x13, 0x7f, 0x39, 0xaa, 0xc0, 0x79, 0xc3, 0x1f, 0xff, 0x93, 0x08, 0x15, 0x2f, 0x92, 0x0b, - 0xf5, 0xe1, 0x9b, 0x59, 0xb4, 0x48, 0x2e, 0xa2, 0x6a, 0x94, 0x4e, 0xfb, 0x5e, 0x0e, 0xdd, 0x73, - 0xd3, 0x33, 0x23, 0xae, 0x2a, 0xe1, 0xa1, 0x12, 0x0b, 0x0f, 0x27, 0xd2, 0x01, 0x0e, 0xf0, 0x07, - 0x0a, 0x6f, 0xe7, 0x11, 0x5e, 0xdd, 0x30, 0xec, 0x66, 0x4d, 0xb7, 0x5d, 0xd8, 0xa9, 0xc5, 0x00, - 0xf7, 0x31, 0x60, 0x80, 0xc5, 0x9b, 0xd4, 0x69, 0xd8, 0x06, 0x37, 0x92, 0x9c, 0xce, 0xc0, 0xe2, - 0x0b, 0x61, 0x17, 0x89, 0xd2, 0xc1, 0xd9, 0xad, 0x28, 0xf3, 0x65, 0xbf, 0xca, 0x2a, 0x6b, 0x02, - 0x1c, 0x7a, 0x40, 0xb8, 0x3e, 0x64, 0x03, 0xac, 0x4b, 0x1f, 0x5c, 0x7b, 0x07, 0xc2, 0x7d, 0xaf, - 0x41, 0x16, 0x44, 0x0d, 0xd1, 0x7e, 0x19, 0xe5, 0x4e, 0x34, 0xc4, 0x51, 0x99, 0x35, 0xc6, 0xc5, - 0x1d, 0x3c, 0x93, 0x48, 0x78, 0xab, 0xf6, 0x59, 0x0e, 0xcd, 0x24, 0xab, 0x74, 0x10, 0xe7, 0x8e, - 0xeb, 0xea, 0xb9, 0x23, 0xeb, 0x3d, 0x46, 0xb2, 0xe2, 0x29, 0x67, 0x90, 0x8f, 0x13, 0x8d, 0x7f, - 0x10, 0xa3, 0x5c, 0x57, 0x47, 0x39, 0xb7, 0xeb, 0x51, 0x26, 0x8f, 0xb0, 0xfa, 0xe0, 0x8d, 0x5f, - 0x9d, 0xb8, 0xed, 0x43, 0xf8, 0xfb, 0x39, 0xfc, 0xbd, 0xf5, 0xe9, 0x89, 0xdc, 0x0d, 0xf8, 0xfb, - 0x10, 0xfe, 0x3e, 0x81, 0xbf, 0x77, 0x7e, 0x7d, 0xe2, 0xb6, 0x17, 0x47, 0x25, 0xe6, 0x1f, 0x03, - 0x00, 0x00, 0xff, 0xff, 0x3c, 0x85, 0xb5, 0xb9, 0x4b, 0x46, 0x00, 0x00, + // 3908 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xe4, 0x5b, 0x5d, 0x6c, 0x24, 0xd9, + 0x55, 0x9e, 0xea, 0x76, 0xdb, 0xed, 0xd3, 0x63, 0x8f, 0xe7, 0x8e, 0xc7, 0xd3, 0xeb, 0xdd, 0x75, + 0x4f, 0x6a, 0xc5, 0x66, 0x22, 0x76, 0xdb, 0xcc, 0xb0, 0x13, 0x36, 0xbb, 0x9b, 0x4d, 0xdc, 0xf6, + 0xfc, 0x62, 0xcf, 0x74, 0x6e, 0xdb, 0x93, 0x21, 0xd9, 0x6c, 0xa8, 0xee, 0xba, 0x6e, 0xd7, 0xba, + 0xfe, 0xb6, 0xea, 0x96, 0xd7, 0x9d, 0x08, 0x25, 0x12, 0xe2, 0x35, 0xe4, 0x0d, 0x24, 0xe0, 0x81, + 0x07, 0xc4, 0x13, 0x11, 0x11, 0x48, 0x91, 0x78, 0x02, 0x04, 0x62, 0x91, 0x40, 0x04, 0x24, 0x04, + 0x0f, 0xd0, 0xcb, 0x3a, 0x42, 0x11, 0xef, 0x08, 0xa4, 0xe1, 0x05, 0xdd, 0x5b, 0xb7, 0x7e, 0xbb, + 0xaa, 0xc7, 0xd5, 0xfe, 0x91, 0x10, 0x6f, 0xdd, 0xf7, 0x9e, 0xf3, 0x9d, 0x73, 0x4f, 0x9d, 0x3a, + 0xe7, 0xdc, 0x7b, 0x4f, 0xc1, 0x17, 0xf7, 0xdf, 0x74, 0x9b, 0x9a, 0xb5, 0xba, 0xef, 0x75, 0x89, + 0x63, 0x12, 0x4a, 0xdc, 0x55, 0x7b, 0xbf, 0xbf, 0xaa, 0xd8, 0x9a, 0xbb, 0x4a, 0x0e, 0x29, 0x31, + 0x5d, 0xcd, 0x32, 0xdd, 0xd5, 0x83, 0x9b, 0x5d, 0x42, 0x95, 0x9b, 0xab, 0x7d, 0x62, 0x12, 0x47, + 0xa1, 0x44, 0x6d, 0xda, 0x8e, 0x45, 0x2d, 0xf4, 0xba, 0xcf, 0xde, 0x8c, 0xd8, 0x9b, 0xf6, 0x7e, + 0xbf, 0xc9, 0xd8, 0x9b, 0x11, 0x7b, 0x53, 0xb0, 0x2f, 0xbf, 0xde, 0xd7, 0xe8, 0x9e, 0xd7, 0x6d, + 0xf6, 0x2c, 0x63, 0xb5, 0x6f, 0xf5, 0xad, 0x55, 0x8e, 0xd2, 0xf5, 0x76, 0xf9, 0x3f, 0xfe, 0x87, + 0xff, 0xf2, 0xd1, 0x97, 0x6f, 0xe5, 0x2a, 0xb7, 0xea, 0x10, 0xd7, 0xf2, 0x9c, 0x1e, 0x49, 0x6b, + 0xb4, 0x7c, 0x3b, 0x9f, 0xc7, 0x33, 0x0f, 0x88, 0xc3, 0x14, 0x22, 0xea, 0x08, 0xdb, 0x6b, 0xf9, + 0x6c, 0x07, 0x23, 0xcb, 0x5e, 0x7e, 0x3d, 0x9b, 0xda, 0xf1, 0x4c, 0xaa, 0x19, 0xa3, 0x3a, 0xdd, + 0xcc, 0x26, 0xf7, 0xa8, 0xa6, 0xaf, 0x6a, 0x26, 0x75, 0xa9, 0x93, 0x66, 0x91, 0x9b, 0x00, 0x6b, + 0xed, 0x07, 0x4f, 0x7c, 0x7d, 0xd1, 0x75, 0x98, 0x32, 0x15, 0x83, 0xd4, 0xa5, 0xeb, 0xd2, 0x8d, + 0xd9, 0xd6, 0xc5, 0x8f, 0x87, 0x8d, 0x0b, 0x47, 0xc3, 0xc6, 0xd4, 0x23, 0xc5, 0x20, 0x98, 0xcf, + 0xc8, 0xef, 0xc1, 0xe2, 0x7a, 0x7b, 0x67, 0x5b, 0x71, 0xfa, 0x84, 0xee, 0x50, 0x4d, 0xd7, 0xbe, + 0xa5, 0x50, 0xc6, 0xb9, 0x01, 0x0b, 0x94, 0x0f, 0xb6, 0x89, 0xd3, 0x23, 0x26, 0x55, 0xfa, 0x3e, + 0x4a, 0xa5, 0x55, 0x17, 0x28, 0x0b, 0xdb, 0xa9, 0x79, 0x3c, 0xc2, 0x21, 0xff, 0x86, 0x04, 0x2f, + 0xac, 0x7b, 0x2e, 0xb5, 0x8c, 0x2d, 0x42, 0x1d, 0xad, 0xb7, 0xee, 0x39, 0x0e, 0x31, 0x69, 0x87, + 0x2a, 0xd4, 0x73, 0x9f, 0xaf, 0x1d, 0x7a, 0x0a, 0x95, 0x03, 0x45, 0xf7, 0x48, 0xbd, 0x74, 0x5d, + 0xba, 0x51, 0xbb, 0xf5, 0x5a, 0x33, 0xd7, 0x6d, 0x9a, 0xc1, 0x83, 0x6d, 0x7e, 0xc5, 0x53, 0x4c, + 0xaa, 0xd1, 0x41, 0x6b, 0x51, 0x00, 0x5e, 0x14, 0x52, 0x9f, 0x30, 0x24, 0xec, 0x03, 0xca, 0xdf, + 0x93, 0xe0, 0xe5, 0x5c, 0xcd, 0x36, 0x35, 0x97, 0x22, 0x03, 0x2a, 0x1a, 0x25, 0x86, 0x5b, 0x97, + 0xae, 0x97, 0x6f, 0xd4, 0x6e, 0xdd, 0x6f, 0x16, 0x72, 0xd9, 0x66, 0x2e, 0x78, 0x6b, 0x4e, 0xe8, + 0x55, 0x79, 0xc0, 0xe0, 0xb1, 0x2f, 0x45, 0xfe, 0x75, 0x09, 0x50, 0x9c, 0xc7, 0xb7, 0xee, 0x31, + 0x6c, 0xf4, 0xd5, 0x93, 0xd8, 0xe8, 0x8a, 0x00, 0xac, 0xf9, 0xe2, 0x12, 0x26, 0xfa, 0xae, 0x04, + 0x4b, 0xa3, 0x1a, 0x71, 0xdb, 0xec, 0x26, 0x6d, 0xb3, 0x76, 0x02, 0xdb, 0xf8, 0xa8, 0x39, 0x46, + 0xf9, 0x83, 0x12, 0xcc, 0x6e, 0x28, 0xc4, 0xb0, 0xcc, 0x0e, 0xa1, 0xe8, 0x29, 0x54, 0x0d, 0x42, + 0x15, 0x55, 0xa1, 0x0a, 0xb7, 0x47, 0xed, 0xd6, 0x8d, 0x31, 0x8b, 0x3d, 0xb8, 0xd9, 0x7c, 0xdc, + 0xfd, 0x80, 0xf4, 0xe8, 0x16, 0xa1, 0x4a, 0x0b, 0x09, 0x7c, 0x88, 0xc6, 0x70, 0x88, 0x86, 0xde, + 0x87, 0x29, 0xd7, 0x26, 0x3d, 0x61, 0xc2, 0x77, 0x0a, 0x2e, 0x27, 0xd4, 0xb0, 0x63, 0x93, 0x5e, + 0xf4, 0x8c, 0xd8, 0x3f, 0xcc, 0x71, 0xd1, 0x2e, 0x4c, 0xbb, 0xfc, 0xe1, 0xd7, 0xcb, 0x5c, 0xc2, + 0xbb, 0x13, 0x4b, 0xf0, 0x5d, 0x68, 0x5e, 0xc8, 0x98, 0xf6, 0xff, 0x63, 0x81, 0x2e, 0xff, 0xad, + 0x04, 0x73, 0x21, 0x2d, 0x7f, 0x52, 0xdf, 0x18, 0xb1, 0xd9, 0xea, 0x18, 0x9b, 0xc5, 0x22, 0x5d, + 0x93, 0xb1, 0x73, 0xd3, 0x2d, 0x08, 0x61, 0xd5, 0x60, 0x24, 0x66, 0xb8, 0x6f, 0x04, 0x8e, 0x50, + 0xe2, 0x8e, 0xf0, 0xe6, 0xa4, 0xeb, 0xca, 0x79, 0xfe, 0x7f, 0x13, 0x5f, 0x0f, 0xb3, 0x27, 0x7a, + 0x1f, 0xaa, 0x2e, 0xd1, 0x49, 0x8f, 0x5a, 0x8e, 0x58, 0xcf, 0x1b, 0xc7, 0x5d, 0x8f, 0xd2, 0x25, + 0x7a, 0x47, 0xf0, 0xb6, 0x2e, 0xb2, 0x05, 0x05, 0xff, 0x70, 0x88, 0x89, 0xbe, 0x0e, 0x55, 0x4a, + 0x0c, 0x5b, 0x57, 0x68, 0xf0, 0x42, 0xbd, 0x3e, 0xde, 0xc7, 0xda, 0x96, 0xba, 0x2d, 0x18, 0xf8, + 0xe3, 0x0f, 0xad, 0x15, 0x8c, 0xe2, 0x10, 0x50, 0xfe, 0x8b, 0x12, 0x5c, 0x4a, 0x3d, 0x4a, 0xf4, + 0x04, 0x96, 0x7a, 0x7e, 0x78, 0x78, 0xe4, 0x19, 0x5d, 0xe2, 0x74, 0x7a, 0x7b, 0x44, 0xf5, 0x74, + 0xa2, 0x8a, 0x70, 0xbb, 0x22, 0xf0, 0x96, 0xd6, 0x33, 0xa9, 0x70, 0x0e, 0x37, 0x7a, 0x08, 0xc8, + 0xe4, 0x43, 0x5b, 0x9a, 0xeb, 0x86, 0x98, 0x25, 0x8e, 0xb9, 0x2c, 0x30, 0xd1, 0xa3, 0x11, 0x0a, + 0x9c, 0xc1, 0xc5, 0x74, 0x54, 0x89, 0xab, 0x39, 0x44, 0x4d, 0xeb, 0x58, 0x4e, 0xea, 0xb8, 0x91, + 0x49, 0x85, 0x73, 0xb8, 0xd1, 0x6d, 0xa8, 0xf9, 0xd2, 0x30, 0x51, 0xd4, 0x41, 0x7d, 0x8a, 0x83, + 0x85, 0x21, 0xe9, 0x51, 0x34, 0x85, 0xe3, 0x74, 0xf2, 0x1f, 0x96, 0x00, 0x36, 0x88, 0xad, 0x5b, + 0x03, 0x83, 0x98, 0x67, 0x19, 0x16, 0xbe, 0x99, 0x08, 0x0b, 0x5f, 0x2c, 0xea, 0xdc, 0xa1, 0x8a, + 0xb9, 0x71, 0xa1, 0x9f, 0x8a, 0x0b, 0x5f, 0x9a, 0x5c, 0xc4, 0xf8, 0xc0, 0xf0, 0x93, 0x32, 0x5c, + 0x89, 0x88, 0xd7, 0x2d, 0x53, 0xd5, 0x78, 0x9a, 0x7f, 0x1b, 0xa6, 0xe8, 0xc0, 0x0e, 0xd2, 0xcb, + 0x67, 0x03, 0x15, 0xb7, 0x07, 0x36, 0x79, 0x36, 0x6c, 0x5c, 0xcb, 0x60, 0x61, 0x53, 0x98, 0x33, + 0xa1, 0x27, 0xa1, 0xf6, 0x25, 0xce, 0xfe, 0x6e, 0x52, 0xf8, 0xb3, 0x61, 0x63, 0x6c, 0x75, 0xd4, + 0x0c, 0x31, 0x93, 0xca, 0xa2, 0x57, 0x61, 0xda, 0x21, 0x8a, 0x6b, 0x99, 0xdc, 0x23, 0x66, 0xa3, + 0x45, 0x61, 0x3e, 0x8a, 0xc5, 0x2c, 0xfa, 0x1c, 0xcc, 0x18, 0xc4, 0x75, 0x59, 0x69, 0x52, 0xe1, + 0x84, 0x97, 0x04, 0xe1, 0xcc, 0x96, 0x3f, 0x8c, 0x83, 0x79, 0xb4, 0x0f, 0xf3, 0xba, 0xe2, 0xd2, + 0x1d, 0x5b, 0x55, 0x28, 0xd9, 0xd6, 0x0c, 0x52, 0x9f, 0xe6, 0x06, 0xff, 0xd9, 0x63, 0x06, 0x0f, + 0xc6, 0xd2, 0x5a, 0x12, 0xf0, 0xf3, 0x9b, 0x09, 0x28, 0x9c, 0x82, 0x46, 0x1f, 0x01, 0x62, 0x23, + 0xdb, 0x8e, 0x62, 0xba, 0xbe, 0xcd, 0x98, 0xc0, 0x99, 0xe2, 0x02, 0xc3, 0xf7, 0x74, 0x73, 0x04, + 0x0e, 0x67, 0x88, 0x90, 0xff, 0x4e, 0x82, 0xf9, 0xe8, 0x91, 0x9d, 0x47, 0xfc, 0x7f, 0x3f, 0x19, + 0xff, 0xbf, 0x30, 0xb1, 0xff, 0xe6, 0x24, 0x80, 0xdf, 0x2c, 0x03, 0x8a, 0x88, 0xb0, 0xa5, 0xeb, + 0x5d, 0xa5, 0xb7, 0x7f, 0x8c, 0xaa, 0xe8, 0xf7, 0x24, 0x40, 0x1e, 0x7f, 0x24, 0xea, 0x9a, 0x69, + 0x5a, 0x94, 0x57, 0xb5, 0x81, 0x9a, 0xbf, 0x34, 0xb1, 0x9a, 0x81, 0x06, 0xcd, 0x9d, 0x11, 0xec, + 0x3b, 0x26, 0x75, 0x06, 0xd1, 0x23, 0x1b, 0x25, 0xc0, 0x19, 0x0a, 0xa1, 0x0f, 0x01, 0x1c, 0x81, + 0xb9, 0x6d, 0x89, 0x28, 0x50, 0x34, 0xd0, 0x04, 0x4a, 0xad, 0x5b, 0xe6, 0xae, 0xd6, 0x8f, 0x62, + 0x1a, 0x0e, 0x81, 0x71, 0x4c, 0xc8, 0xf2, 0x1d, 0xb8, 0x96, 0xa3, 0x3d, 0x5a, 0x80, 0xf2, 0x3e, + 0x19, 0xf8, 0x66, 0xc5, 0xec, 0x27, 0x5a, 0x8c, 0x57, 0x97, 0xb3, 0xa2, 0x34, 0x7c, 0xab, 0xf4, + 0xa6, 0x24, 0xff, 0xb4, 0x12, 0x77, 0x36, 0x9e, 0x9c, 0x6f, 0x40, 0xd5, 0x21, 0xb6, 0xae, 0xf5, + 0x14, 0x57, 0x64, 0x2f, 0x9e, 0x66, 0xb1, 0x18, 0xc3, 0xe1, 0x6c, 0x22, 0x8d, 0x97, 0xce, 0x38, + 0x8d, 0x97, 0x4f, 0x39, 0x8d, 0x23, 0x0b, 0xaa, 0x2e, 0x65, 0x9b, 0xae, 0xbe, 0x9f, 0xb3, 0x8a, + 0x17, 0xc0, 0xf1, 0xb8, 0xed, 0x03, 0x45, 0x02, 0x83, 0x11, 0x1c, 0x0a, 0x41, 0x6b, 0x70, 0xc9, + 0xd0, 0x4c, 0x9e, 0xfc, 0x3a, 0xa4, 0x67, 0x99, 0xaa, 0xcb, 0x03, 0x5e, 0xa5, 0x75, 0x4d, 0x30, + 0x5d, 0xda, 0x4a, 0x4e, 0xe3, 0x34, 0x3d, 0xda, 0x84, 0x45, 0x87, 0x1c, 0x68, 0x4c, 0x8d, 0xfb, + 0x9a, 0x4b, 0x2d, 0x67, 0xb0, 0xa9, 0x19, 0x1a, 0xe5, 0x61, 0xb0, 0xd2, 0xaa, 0x1f, 0x0d, 0x1b, + 0x8b, 0x38, 0x63, 0x1e, 0x67, 0x72, 0xb1, 0x08, 0x6d, 0x2b, 0x9e, 0x4b, 0x54, 0x1e, 0xd5, 0xaa, + 0x51, 0x84, 0x6e, 0xf3, 0x51, 0x2c, 0x66, 0x91, 0x91, 0xf0, 0xee, 0xea, 0x69, 0x78, 0xf7, 0x7c, + 0xbe, 0x67, 0xa3, 0x1d, 0xb8, 0x66, 0x3b, 0x56, 0xdf, 0x21, 0xae, 0xbb, 0x41, 0x14, 0x55, 0xd7, + 0x4c, 0x12, 0xd8, 0x6b, 0x96, 0xaf, 0xf3, 0xc5, 0xa3, 0x61, 0xe3, 0x5a, 0x3b, 0x9b, 0x04, 0xe7, + 0xf1, 0xca, 0x9f, 0x94, 0x61, 0x21, 0x9d, 0x69, 0x59, 0x7d, 0x65, 0x75, 0x5d, 0xe2, 0x1c, 0x10, + 0xf5, 0x9e, 0xbf, 0x07, 0xd7, 0x2c, 0x93, 0x7b, 0x7d, 0x39, 0x0a, 0x02, 0x8f, 0x47, 0x28, 0x70, + 0x06, 0x17, 0x7a, 0x2d, 0xf6, 0xde, 0xf8, 0x15, 0x5a, 0xe8, 0x0d, 0x19, 0xef, 0xce, 0x1a, 0x5c, + 0x12, 0x81, 0x24, 0x98, 0x14, 0x65, 0x58, 0xe8, 0x0d, 0x3b, 0xc9, 0x69, 0x9c, 0xa6, 0x47, 0xf7, + 0xe0, 0xb2, 0x72, 0xa0, 0x68, 0xba, 0xd2, 0xd5, 0x49, 0x08, 0xe2, 0x97, 0x5f, 0x2f, 0x08, 0x90, + 0xcb, 0x6b, 0x69, 0x02, 0x3c, 0xca, 0x83, 0xb6, 0xe0, 0x8a, 0x67, 0x8e, 0x42, 0xf9, 0xde, 0xf9, + 0xa2, 0x80, 0xba, 0xb2, 0x33, 0x4a, 0x82, 0xb3, 0xf8, 0xd0, 0x01, 0x40, 0x2f, 0x28, 0x0a, 0xdc, + 0xfa, 0x34, 0x0f, 0xd6, 0xad, 0x89, 0xdf, 0xad, 0xb0, 0xbe, 0x88, 0x42, 0x62, 0x38, 0xe4, 0xe2, + 0x98, 0x24, 0xf9, 0xef, 0xa5, 0x78, 0x9a, 0x09, 0xde, 0x40, 0xf4, 0x56, 0xa2, 0x3a, 0x7a, 0x35, + 0x55, 0x1d, 0x2d, 0x8d, 0x72, 0xc4, 0x8a, 0xa3, 0xef, 0xc0, 0x1c, 0xf3, 0x4c, 0xcd, 0xec, 0xfb, + 0x4f, 0x43, 0x84, 0xb9, 0xbb, 0x13, 0x78, 0x7f, 0x88, 0x11, 0x4b, 0x97, 0x97, 0x8f, 0x86, 0x8d, + 0xb9, 0xc4, 0x24, 0x4e, 0xca, 0x93, 0xdf, 0x83, 0xb9, 0x3b, 0x87, 0xb6, 0xe5, 0xd0, 0xc7, 0xb6, + 0x9f, 0x6a, 0x5e, 0x85, 0x69, 0xc2, 0x07, 0xf8, 0x7a, 0x62, 0x2f, 0xad, 0x4f, 0x86, 0xc5, 0x2c, + 0x7a, 0x05, 0x2a, 0xe4, 0x50, 0xe9, 0x51, 0xae, 0x71, 0x35, 0x4a, 0xcc, 0x77, 0xd8, 0x20, 0xf6, + 0xe7, 0xe4, 0x1f, 0x4a, 0xb0, 0x74, 0xb7, 0x73, 0xcf, 0xb1, 0x3c, 0x3b, 0x58, 0x7c, 0x20, 0xe7, + 0x17, 0x60, 0xca, 0xf1, 0xf4, 0xc0, 0x6a, 0xaf, 0x04, 0x56, 0xc3, 0x9e, 0xce, 0xac, 0x76, 0x25, + 0xc5, 0xe5, 0x9b, 0x8c, 0x31, 0xa0, 0xf7, 0x61, 0xda, 0x51, 0xcc, 0x3e, 0x09, 0xd2, 0xf4, 0xe7, + 0x0b, 0xda, 0xea, 0xc1, 0x06, 0x66, 0xec, 0xb1, 0x7a, 0x91, 0xa3, 0x61, 0x81, 0x2a, 0xff, 0x8e, + 0x04, 0x97, 0xee, 0x6f, 0x6f, 0xb7, 0x1f, 0x98, 0xfc, 0x35, 0x6f, 0x2b, 0x74, 0x8f, 0x55, 0x12, + 0xb6, 0x42, 0xf7, 0xd2, 0x95, 0x04, 0x9b, 0xc3, 0x7c, 0x06, 0xed, 0xc1, 0x0c, 0x0b, 0x2f, 0xc4, + 0x54, 0x27, 0xdc, 0x07, 0x08, 0x71, 0x2d, 0x1f, 0x24, 0x2a, 0x52, 0xc5, 0x00, 0x0e, 0xe0, 0xe5, + 0x6f, 0xc3, 0x62, 0x4c, 0x3d, 0x66, 0x2f, 0x7e, 0x1e, 0x83, 0x7a, 0x50, 0x61, 0x9a, 0x04, 0xa7, + 0x2d, 0x45, 0x0f, 0x0f, 0x52, 0x4b, 0x8e, 0x1e, 0x28, 0xfb, 0xe7, 0x62, 0x1f, 0x5b, 0xfe, 0xa7, + 0x12, 0x5c, 0xbb, 0x6f, 0x39, 0xda, 0xb7, 0x2c, 0x93, 0x2a, 0x7a, 0xdb, 0x52, 0xd7, 0x3c, 0x6a, + 0xb9, 0x3d, 0x45, 0x27, 0xce, 0x19, 0xee, 0xb0, 0xf4, 0xc4, 0x0e, 0xeb, 0x61, 0xd1, 0x95, 0x65, + 0xeb, 0x9b, 0xbb, 0xdd, 0xa2, 0xa9, 0xed, 0xd6, 0xe6, 0x29, 0xc9, 0x1b, 0xbf, 0xf7, 0xfa, 0x0f, + 0x09, 0x5e, 0xcc, 0xe1, 0x3c, 0x8f, 0x12, 0x7d, 0x3f, 0x59, 0xa2, 0xdf, 0x3d, 0x9d, 0x35, 0xe7, + 0xd4, 0xeb, 0xff, 0x53, 0xca, 0x5d, 0x2b, 0xaf, 0x10, 0x3f, 0x84, 0x2a, 0xff, 0x87, 0xc9, 0xae, + 0x58, 0xeb, 0x7a, 0x41, 0x7d, 0x3a, 0x5e, 0x37, 0x38, 0xc6, 0xc4, 0x64, 0x97, 0x38, 0xc4, 0xec, + 0x91, 0x58, 0xf1, 0x24, 0xc0, 0x71, 0x28, 0x06, 0xdd, 0x84, 0x1a, 0x2f, 0x86, 0x12, 0xf9, 0xf5, + 0xd2, 0xd1, 0xb0, 0x51, 0xdb, 0x8a, 0x86, 0x71, 0x9c, 0x06, 0xdd, 0x86, 0x9a, 0xa1, 0x1c, 0xa6, + 0xb2, 0x6b, 0x78, 0x2e, 0xb1, 0x15, 0x4d, 0xe1, 0x38, 0x1d, 0xfa, 0x0e, 0xcc, 0xf7, 0x6c, 0x2f, + 0x76, 0x8a, 0x2e, 0xaa, 0xc3, 0xa2, 0x4b, 0xcc, 0x3a, 0x90, 0x6f, 0x21, 0xb6, 0xf1, 0x5c, 0x6f, + 0xef, 0xc4, 0xc6, 0x70, 0x4a, 0x9c, 0xfc, 0xe7, 0x65, 0x78, 0x79, 0xac, 0x8f, 0xa2, 0xbb, 0x63, + 0xaa, 0x96, 0xa5, 0x02, 0x15, 0x8b, 0x0a, 0x73, 0x6c, 0xff, 0xc9, 0xcd, 0xcd, 0x77, 0xb7, 0xa5, + 0xe2, 0xbb, 0x5b, 0x9e, 0xc2, 0x36, 0xe3, 0x28, 0x38, 0x09, 0xca, 0x2a, 0x1d, 0x71, 0xba, 0x95, + 0x57, 0xe9, 0xac, 0x27, 0xa7, 0x71, 0x9a, 0x9e, 0x41, 0x88, 0xc3, 0xa7, 0x54, 0x9d, 0x13, 0x42, + 0x6c, 0x24, 0xa7, 0x71, 0x9a, 0x1e, 0x19, 0xd0, 0x10, 0xa8, 0x49, 0xf3, 0xc7, 0x6e, 0x46, 0xfc, + 0x7a, 0xe7, 0x95, 0xa3, 0x61, 0xa3, 0xb1, 0x3e, 0x9e, 0x14, 0x3f, 0x0f, 0x4b, 0xde, 0x82, 0xb9, + 0xfb, 0x96, 0x4b, 0xdb, 0x2c, 0x25, 0xb3, 0xbc, 0x85, 0x5e, 0x86, 0xb2, 0xa1, 0x99, 0x62, 0x43, + 0x55, 0x13, 0x6a, 0x97, 0x99, 0xf3, 0xb2, 0x71, 0x3e, 0xad, 0x1c, 0x0a, 0xbf, 0x8e, 0xa6, 0x95, + 0x43, 0xcc, 0xc6, 0xe5, 0x7b, 0x30, 0x23, 0xf2, 0x62, 0x1c, 0xa8, 0x3c, 0x1e, 0xa8, 0x9c, 0x01, + 0xf4, 0xfb, 0x25, 0x98, 0x11, 0x69, 0xe4, 0x0c, 0x13, 0xc2, 0x7b, 0x89, 0x84, 0xf0, 0xd6, 0x64, + 0xa9, 0x36, 0x37, 0x01, 0xa8, 0xa9, 0x04, 0xf0, 0xce, 0x84, 0xf8, 0xe3, 0x03, 0xfe, 0x0f, 0x24, + 0x98, 0x4f, 0x26, 0x7d, 0x16, 0x51, 0xd8, 0x3b, 0xa4, 0xf5, 0xc8, 0xa3, 0xe8, 0xdc, 0x22, 0x8c, + 0x28, 0x9d, 0x68, 0x0a, 0xc7, 0xe9, 0x10, 0x09, 0xd9, 0x98, 0x3b, 0x08, 0xa3, 0x34, 0x73, 0x94, + 0xf6, 0xa8, 0xa6, 0x37, 0xfd, 0x6b, 0xc1, 0xe6, 0x03, 0x93, 0x3e, 0x76, 0x3a, 0xd4, 0xd1, 0xcc, + 0xfe, 0x88, 0x18, 0xee, 0x59, 0x71, 0x5c, 0xf9, 0xaf, 0x25, 0xa8, 0x09, 0x85, 0xcf, 0x23, 0x23, + 0x7d, 0x3d, 0x99, 0x91, 0x3e, 0x3f, 0x61, 0x3d, 0x95, 0x9d, 0x81, 0x7e, 0x14, 0xad, 0x85, 0x55, + 0x50, 0xac, 0xc0, 0xdb, 0xb3, 0x5c, 0x9a, 0x2e, 0xf0, 0xd8, 0x2b, 0x86, 0xf9, 0x0c, 0xfa, 0x35, + 0x09, 0x16, 0xb4, 0x54, 0xcd, 0x25, 0x4c, 0xfd, 0xa5, 0xc9, 0x54, 0x0b, 0x61, 0xa2, 0xcb, 0xd2, + 0xf4, 0x0c, 0x1e, 0x11, 0x29, 0x7b, 0x30, 0x42, 0x85, 0x14, 0x98, 0xda, 0xa3, 0xd4, 0x9e, 0x30, + 0x57, 0x66, 0x55, 0x93, 0xad, 0x2a, 0x5f, 0xfe, 0xf6, 0x76, 0x1b, 0x73, 0x68, 0xf9, 0x07, 0xa5, + 0xd0, 0x60, 0x1d, 0xff, 0x1d, 0x09, 0xeb, 0x5d, 0xe9, 0x34, 0xea, 0xdd, 0x5a, 0x56, 0xad, 0x8b, + 0x9e, 0x42, 0x99, 0xea, 0x93, 0x1e, 0x1b, 0x0a, 0x09, 0xdb, 0x9b, 0x9d, 0x28, 0x4e, 0x6d, 0x6f, + 0x76, 0x30, 0x83, 0x44, 0xdf, 0x84, 0x0a, 0xdb, 0x4d, 0xb0, 0x57, 0xbc, 0x3c, 0x79, 0x08, 0x61, + 0xf6, 0x8a, 0x3c, 0x8c, 0xfd, 0x73, 0xb1, 0x8f, 0x2b, 0x7f, 0x1b, 0xe6, 0x12, 0x71, 0x00, 0x7d, + 0x00, 0x17, 0x75, 0x4b, 0x51, 0x5b, 0x8a, 0xae, 0x98, 0x3d, 0x12, 0xdc, 0x4b, 0xfd, 0xdc, 0xf8, + 0x88, 0xb8, 0x19, 0xe3, 0x10, 0xf1, 0x24, 0xbc, 0xb0, 0x8e, 0xcf, 0xe1, 0x04, 0xb6, 0xac, 0x00, + 0x44, 0xab, 0x47, 0x0d, 0xa8, 0x30, 0x17, 0xf6, 0x77, 0x06, 0xb3, 0xad, 0x59, 0xa6, 0x2b, 0xf3, + 0x6c, 0x17, 0xfb, 0xe3, 0xe8, 0x16, 0x80, 0x4b, 0x7a, 0x0e, 0xa1, 0x3c, 0xec, 0xf8, 0xc7, 0xf4, + 0x61, 0x00, 0xee, 0x84, 0x33, 0x38, 0x46, 0x25, 0xff, 0x56, 0x09, 0xca, 0x0f, 0xad, 0xee, 0x19, + 0x06, 0xf9, 0xa7, 0x89, 0x20, 0x5f, 0xf4, 0xfd, 0x7f, 0x68, 0x75, 0x73, 0x03, 0xfc, 0x2f, 0xa7, + 0x02, 0xfc, 0x9b, 0x13, 0x60, 0x8f, 0x0f, 0xee, 0xff, 0x50, 0x86, 0x8b, 0x0f, 0xad, 0x6e, 0x74, + 0x85, 0xf2, 0x46, 0xe2, 0x90, 0xe0, 0x7a, 0xea, 0x90, 0x60, 0x21, 0x4e, 0x7b, 0x0e, 0x77, 0x27, + 0x7b, 0x7e, 0x61, 0xd6, 0x76, 0xac, 0xae, 0x5f, 0x98, 0x95, 0x8b, 0x17, 0x66, 0x57, 0x85, 0x2e, + 0xbc, 0x38, 0x0b, 0x91, 0x70, 0x12, 0x38, 0xe7, 0x96, 0x63, 0xea, 0xcc, 0x6f, 0x39, 0x62, 0xd7, + 0x43, 0x95, 0xe3, 0x5e, 0x0f, 0x4d, 0x8f, 0xbf, 0x1e, 0x92, 0xff, 0x4c, 0x82, 0x99, 0x87, 0x56, + 0xf7, 0x3c, 0x92, 0xdf, 0x57, 0x93, 0xc9, 0xef, 0x56, 0x71, 0x07, 0xcd, 0x49, 0x7c, 0x7f, 0x54, + 0xe6, 0x6b, 0xe0, 0x31, 0xfc, 0x26, 0xd4, 0x6c, 0xc5, 0x51, 0x74, 0x9d, 0xe8, 0x9a, 0x6b, 0x88, + 0xd2, 0x91, 0xef, 0x79, 0xda, 0xd1, 0x30, 0x8e, 0xd3, 0x30, 0x96, 0x9e, 0x65, 0xd8, 0x3a, 0x09, + 0x2e, 0x4a, 0x42, 0x96, 0xf5, 0x68, 0x18, 0xc7, 0x69, 0xd0, 0x63, 0xb8, 0xaa, 0xf4, 0xa8, 0x76, + 0x40, 0xd2, 0x87, 0xad, 0x65, 0x5e, 0x42, 0xbe, 0x70, 0x34, 0x6c, 0x5c, 0x5d, 0xcb, 0x22, 0xc0, + 0xd9, 0x7c, 0x89, 0x5b, 0x81, 0xa9, 0x33, 0xb8, 0x15, 0x78, 0x03, 0x2e, 0x2a, 0x1e, 0xb5, 0x82, + 0x19, 0xee, 0x3f, 0xd5, 0xd6, 0x02, 0x0b, 0xb9, 0x6b, 0xb1, 0x71, 0x9c, 0xa0, 0x4a, 0xdc, 0x25, + 0x4c, 0x9f, 0x76, 0x4b, 0xc0, 0x9f, 0x96, 0x61, 0x36, 0x0c, 0x3a, 0xc8, 0x4a, 0x9c, 0x7f, 0xfa, + 0xc7, 0x3d, 0x6f, 0x17, 0xf7, 0x90, 0x63, 0x1f, 0x7c, 0xa2, 0xa7, 0x30, 0xeb, 0x52, 0xc5, 0xa1, + 0x93, 0xee, 0xe1, 0xe6, 0x8e, 0x86, 0x8d, 0xd9, 0x4e, 0x80, 0x80, 0x23, 0x30, 0xd4, 0x87, 0xf9, + 0xc8, 0x57, 0x26, 0x8d, 0x44, 0xfe, 0xa6, 0x37, 0x01, 0x83, 0x53, 0xb0, 0x2c, 0x1c, 0xf8, 0xde, + 0x24, 0x36, 0x76, 0x61, 0x38, 0xf0, 0x5d, 0x0f, 0x8b, 0x59, 0xb4, 0x0a, 0xb3, 0xae, 0xd7, 0xeb, + 0x11, 0xa2, 0x12, 0x55, 0x6c, 0xd8, 0x2e, 0x0b, 0xd2, 0xd9, 0x4e, 0x30, 0x81, 0x23, 0x1a, 0x06, + 0xbc, 0xab, 0x68, 0x3a, 0x51, 0xc5, 0x25, 0x49, 0x08, 0x7c, 0x97, 0x8f, 0x62, 0x31, 0xcb, 0x9b, + 0x6e, 0x1e, 0x11, 0xfa, 0x91, 0xe5, 0xec, 0xb7, 0x2d, 0x5d, 0xeb, 0x0d, 0xce, 0x30, 0x73, 0x76, + 0x13, 0x99, 0xf3, 0xcb, 0x05, 0x5d, 0x23, 0xa1, 0x65, 0x5e, 0x0e, 0x95, 0xff, 0x5d, 0x82, 0x7a, + 0x82, 0x32, 0x5e, 0x4e, 0x13, 0xa8, 0xd8, 0x96, 0x43, 0x03, 0xe7, 0x3c, 0x91, 0x06, 0x6c, 0xef, + 0x11, 0x3b, 0x8d, 0x64, 0xb0, 0xd8, 0x47, 0x67, 0xeb, 0xdc, 0x75, 0x2c, 0x43, 0x04, 0xc9, 0x93, + 0x49, 0x21, 0xc4, 0x89, 0xd6, 0x79, 0xd7, 0xb1, 0x0c, 0xcc, 0xb1, 0xe5, 0x7f, 0x94, 0xe0, 0x72, + 0x82, 0xf2, 0x3c, 0xc2, 0xbf, 0x92, 0x0c, 0xff, 0xef, 0x9c, 0x64, 0x65, 0x39, 0x89, 0xe0, 0xbf, + 0xd3, 0xeb, 0x62, 0x16, 0x40, 0x7d, 0xa8, 0xd9, 0x96, 0xda, 0x39, 0x8d, 0xde, 0x29, 0x3f, 0x91, + 0x44, 0x60, 0x38, 0x8e, 0x8c, 0x06, 0x70, 0xd9, 0x54, 0x0c, 0xe2, 0xda, 0x4a, 0x8f, 0x74, 0x4e, + 0xe3, 0x8e, 0xf7, 0xea, 0xd1, 0xb0, 0x71, 0xf9, 0x51, 0x1a, 0x12, 0x8f, 0x4a, 0x91, 0xff, 0x78, + 0x64, 0xe5, 0x96, 0x43, 0xd1, 0x57, 0xa0, 0xca, 0x7b, 0x63, 0x7b, 0x96, 0x2e, 0x8a, 0xb4, 0xdb, + 0xec, 0xe1, 0xb4, 0xc5, 0xd8, 0xb3, 0x61, 0xe3, 0x67, 0xc6, 0x96, 0x5a, 0x01, 0x21, 0x0e, 0x61, + 0xd0, 0x26, 0x4c, 0xd9, 0x93, 0x6f, 0xc8, 0xf9, 0x0e, 0x8c, 0xef, 0xc2, 0x39, 0x8a, 0xfc, 0x9f, + 0x69, 0xb5, 0x79, 0x0e, 0xdf, 0x3f, 0xbd, 0x07, 0x16, 0x9e, 0x00, 0xe4, 0x3e, 0x34, 0x07, 0x66, + 0xc4, 0x7e, 0x54, 0x38, 0xe6, 0xbd, 0x93, 0x38, 0x66, 0x7c, 0x0f, 0x15, 0x16, 0x5d, 0xc1, 0x60, + 0x20, 0x88, 0xbf, 0x7f, 0x5c, 0xa1, 0x9e, 0xe7, 0x68, 0x74, 0x70, 0xe6, 0xb1, 0x73, 0x37, 0x11, + 0x3b, 0x37, 0x0a, 0x2e, 0x70, 0x44, 0xd3, 0xdc, 0xf8, 0xf9, 0xaf, 0x12, 0x5c, 0x1d, 0xa1, 0x3e, + 0x8f, 0xd8, 0x42, 0x92, 0xb1, 0xe5, 0xcb, 0x27, 0x5d, 0x61, 0x4e, 0x7c, 0xf9, 0x18, 0x32, 0xd6, + 0xc7, 0x5d, 0xf6, 0x16, 0x80, 0xed, 0x68, 0x07, 0x9a, 0x4e, 0xfa, 0xa2, 0x7f, 0xb1, 0x1a, 0x3d, + 0x93, 0x76, 0x38, 0x83, 0x63, 0x54, 0xe8, 0x57, 0x60, 0x49, 0x25, 0xbb, 0x8a, 0xa7, 0xd3, 0x35, + 0x55, 0x5d, 0x57, 0x6c, 0xa5, 0xab, 0xe9, 0x1a, 0xd5, 0xc4, 0x25, 0xe0, 0x6c, 0xeb, 0x8e, 0xdf, + 0x57, 0x98, 0x45, 0xf1, 0x6c, 0xd8, 0xf8, 0xec, 0xf8, 0x4d, 0x52, 0x40, 0x3c, 0xc0, 0x39, 0x42, + 0xd0, 0xaf, 0x4a, 0x50, 0x77, 0xc8, 0x87, 0x9e, 0xe6, 0x10, 0x75, 0xc3, 0xb1, 0xec, 0x84, 0x06, + 0x65, 0xae, 0xc1, 0xbd, 0xa3, 0x61, 0xa3, 0x8e, 0x73, 0x68, 0x8a, 0xe8, 0x90, 0x2b, 0x08, 0x51, + 0xb8, 0xa2, 0xe8, 0xba, 0xf5, 0x11, 0x49, 0x5a, 0x60, 0x8a, 0xcb, 0x6f, 0x1d, 0x0d, 0x1b, 0x57, + 0xd6, 0x46, 0xa7, 0x8b, 0x88, 0xce, 0x82, 0x47, 0xab, 0x30, 0x73, 0x60, 0xe9, 0x9e, 0x41, 0xdc, + 0x7a, 0x85, 0x4b, 0x62, 0x91, 0x76, 0xe6, 0x89, 0x3f, 0xf4, 0x8c, 0x15, 0x3a, 0x1d, 0xbe, 0x63, + 0x0d, 0xa8, 0xd0, 0x6d, 0xa8, 0xed, 0x59, 0x2e, 0x15, 0xef, 0x3a, 0x2f, 0x8b, 0xaa, 0x51, 0x70, + 0xb9, 0x1f, 0x4d, 0xe1, 0x38, 0x1d, 0x32, 0x60, 0x76, 0x4f, 0x9c, 0x68, 0xbb, 0xf5, 0x99, 0x89, + 0xf2, 0x5e, 0xe2, 0x44, 0x3c, 0xaa, 0xdb, 0x82, 0x61, 0x17, 0x47, 0x12, 0xd8, 0xbe, 0x8f, 0xff, + 0x79, 0xb0, 0xc1, 0x3b, 0x4e, 0xaa, 0x51, 0x08, 0xba, 0xef, 0x0f, 0xe3, 0x60, 0x3e, 0x20, 0x7d, + 0xd0, 0x5e, 0xe7, 0x0d, 0x22, 0x29, 0xd2, 0x07, 0xed, 0x75, 0x1c, 0xcc, 0x23, 0x1b, 0x66, 0x5c, + 0xb2, 0xa9, 0x99, 0xde, 0x61, 0x1d, 0xf8, 0xab, 0x7b, 0xa7, 0xe8, 0xc5, 0xd5, 0x1d, 0xce, 0x9d, + 0xba, 0x2d, 0x8f, 0x24, 0x8a, 0x79, 0x1c, 0x88, 0x41, 0x87, 0x30, 0xeb, 0x78, 0xe6, 0x9a, 0xbb, + 0xe3, 0x12, 0xa7, 0x5e, 0xe3, 0x32, 0x8b, 0x46, 0x65, 0x1c, 0xf0, 0xa7, 0xa5, 0x86, 0x16, 0x0c, + 0x29, 0x70, 0x24, 0x0c, 0xfd, 0xb6, 0x04, 0xc8, 0xf5, 0x6c, 0x5b, 0x27, 0x06, 0x31, 0xa9, 0xa2, + 0xf3, 0x0b, 0x7b, 0xb7, 0x7e, 0x91, 0xeb, 0xd0, 0x2e, 0x7c, 0x61, 0x97, 0x06, 0x4a, 0x2b, 0x13, + 0x1e, 0x00, 0x8c, 0x92, 0xe2, 0x0c, 0x3d, 0xd8, 0xa3, 0xd8, 0x75, 0xf9, 0xef, 0xfa, 0xdc, 0x44, + 0x8f, 0x22, 0xbb, 0x71, 0x21, 0x7a, 0x14, 0x62, 0x1e, 0x07, 0x62, 0xd0, 0x13, 0x58, 0x72, 0x88, + 0xa2, 0x3e, 0x36, 0xf5, 0x01, 0xb6, 0x2c, 0x7a, 0x57, 0xd3, 0x89, 0x3b, 0x70, 0x29, 0x31, 0xea, + 0xf3, 0xdc, 0x6d, 0xc2, 0x06, 0x68, 0x9c, 0x49, 0x85, 0x73, 0xb8, 0x79, 0x27, 0xb3, 0xb8, 0x67, + 0x3a, 0xdb, 0x0f, 0x1c, 0x4e, 0xd6, 0xc9, 0x1c, 0xa9, 0x78, 0x66, 0x9d, 0xcc, 0x31, 0x11, 0xe3, + 0xcf, 0xdf, 0xfe, 0xab, 0x04, 0x57, 0x22, 0xe2, 0x63, 0x77, 0x32, 0x67, 0xb0, 0x9c, 0xc3, 0x69, + 0x5c, 0xf6, 0x19, 0x59, 0xf9, 0x3c, 0xcf, 0xc8, 0x4e, 0xab, 0x85, 0x9a, 0x37, 0x17, 0x47, 0x56, + 0xfc, 0x3f, 0xd0, 0x5c, 0x1c, 0x29, 0x9b, 0x53, 0xc8, 0xfc, 0x49, 0x29, 0xbe, 0xa2, 0xff, 0x4f, + 0x1d, 0xac, 0x19, 0x0d, 0xa5, 0x53, 0xc5, 0x1a, 0x4a, 0xe5, 0x7f, 0x29, 0xc3, 0x42, 0xfa, 0xa5, + 0x4d, 0x34, 0x32, 0x4a, 0xcf, 0x6d, 0x64, 0x6c, 0xc3, 0xe2, 0xae, 0xa7, 0xeb, 0x03, 0x6e, 0x90, + 0xd8, 0x05, 0xbd, 0x7f, 0xf6, 0xf8, 0x92, 0xe0, 0x5c, 0xbc, 0x9b, 0x41, 0x83, 0x33, 0x39, 0x73, + 0x9a, 0x32, 0xcb, 0x13, 0x35, 0x65, 0xbe, 0x0d, 0x73, 0x0e, 0xff, 0xf6, 0x24, 0xd9, 0x37, 0x10, + 0x1e, 0x8e, 0xe3, 0xf8, 0x24, 0x4e, 0xd2, 0x66, 0x37, 0x58, 0x56, 0x26, 0x68, 0xb0, 0x3c, 0x8d, + 0x8e, 0xc8, 0x8c, 0xd8, 0xf7, 0xdc, 0x8e, 0xc8, 0x97, 0x60, 0x59, 0xb0, 0xb1, 0xff, 0xeb, 0x96, + 0x49, 0x1d, 0x4b, 0xd7, 0x89, 0xb3, 0xe1, 0x19, 0xc6, 0x40, 0x7e, 0x17, 0xe6, 0x93, 0x6d, 0xb9, + 0xfe, 0x93, 0xf7, 0x3b, 0x85, 0x45, 0x83, 0x41, 0xec, 0xc9, 0xfb, 0xe3, 0x38, 0xa4, 0x90, 0x3f, + 0x91, 0xe0, 0x5a, 0x4e, 0x67, 0x23, 0xfa, 0x00, 0xe6, 0x0d, 0xe5, 0x30, 0xd6, 0x32, 0x2a, 0x42, + 0x4b, 0xd1, 0x5d, 0x36, 0x3f, 0x3b, 0xdc, 0x4a, 0x20, 0xe1, 0x14, 0x32, 0x4f, 0xb8, 0xca, 0x61, + 0xc7, 0x73, 0xfa, 0x64, 0xc2, 0xbd, 0x3c, 0x7f, 0x7d, 0xb7, 0x04, 0x06, 0x0e, 0xd1, 0xe4, 0x1f, + 0x4a, 0x50, 0xcf, 0xab, 0xbe, 0xd0, 0xed, 0x44, 0x87, 0xe4, 0x67, 0x52, 0x1d, 0x92, 0x97, 0x47, + 0xf8, 0xce, 0xa9, 0x3f, 0xf2, 0x47, 0x12, 0x2c, 0x65, 0x57, 0xa9, 0xe8, 0xe7, 0x13, 0x1a, 0x37, + 0x52, 0x1a, 0x5f, 0x4a, 0x71, 0x09, 0x7d, 0xf7, 0x60, 0x5e, 0xd4, 0xb2, 0x02, 0xe6, 0x18, 0x9f, + 0xa8, 0x1e, 0x84, 0x85, 0x72, 0x50, 0x95, 0xf1, 0xe7, 0x98, 0x1c, 0xc3, 0x29, 0x5c, 0xf9, 0x77, + 0x4b, 0x50, 0xe1, 0x6d, 0x43, 0x67, 0x58, 0x42, 0x7d, 0x2d, 0x51, 0x42, 0x15, 0xbd, 0x58, 0xe4, + 0xda, 0xe5, 0x56, 0x4f, 0xdd, 0x54, 0xf5, 0xf4, 0xd6, 0x44, 0xe8, 0xe3, 0x0b, 0xa7, 0x2f, 0xc0, + 0x6c, 0xa8, 0x44, 0xb1, 0x40, 0xcd, 0xca, 0xd4, 0x5a, 0x4c, 0x44, 0xc1, 0x30, 0x7f, 0x90, 0xc8, + 0x94, 0x93, 0x7c, 0x4b, 0x1d, 0x93, 0xdd, 0x0c, 0x52, 0xa5, 0xff, 0xb9, 0x4d, 0xd4, 0xf8, 0x37, + 0x9a, 0x41, 0xdf, 0x85, 0x79, 0xff, 0x83, 0xf4, 0xf0, 0x0c, 0xad, 0xcc, 0xbd, 0x37, 0xfc, 0x8c, + 0x6b, 0x3b, 0x31, 0x8b, 0x53, 0xd4, 0xcb, 0x6f, 0xc3, 0x5c, 0x42, 0x58, 0xa1, 0xaf, 0x63, 0xfe, + 0x52, 0x82, 0xc5, 0xac, 0x56, 0x45, 0x74, 0x1d, 0xa6, 0xf6, 0x35, 0xd1, 0x5b, 0x11, 0xeb, 0x47, + 0xf9, 0x45, 0xcd, 0x54, 0x31, 0x9f, 0x09, 0x3f, 0x6e, 0x2a, 0xe5, 0x7e, 0xdc, 0x74, 0x0b, 0x40, + 0xb1, 0x35, 0xf1, 0x91, 0xbf, 0x58, 0x55, 0xe8, 0xbc, 0xd1, 0xe7, 0xff, 0x38, 0x46, 0xc5, 0x3b, + 0x90, 0x22, 0x7d, 0x44, 0x59, 0x18, 0xb5, 0x06, 0xc5, 0x54, 0x8d, 0xd3, 0xc9, 0x7f, 0x25, 0xc1, + 0x67, 0x9e, 0xbb, 0x83, 0x43, 0xad, 0x44, 0x78, 0x68, 0xa6, 0xc2, 0xc3, 0x4a, 0x3e, 0xc0, 0x39, + 0x76, 0x7f, 0x7f, 0xaf, 0x04, 0x68, 0x7b, 0x4f, 0x73, 0xd4, 0xb6, 0xe2, 0xd0, 0x01, 0x16, 0x0b, + 0x3c, 0xc3, 0x80, 0x71, 0x1b, 0x6a, 0x2a, 0x71, 0x7b, 0x8e, 0xc6, 0x8d, 0x24, 0x1e, 0x67, 0x68, + 0xf1, 0x8d, 0x68, 0x0a, 0xc7, 0xe9, 0x50, 0x1f, 0xaa, 0xa2, 0x56, 0x0c, 0x5a, 0x58, 0x8a, 0x16, + 0xbe, 0x91, 0x07, 0x44, 0xef, 0x87, 0x18, 0x70, 0x71, 0x08, 0x2e, 0x7f, 0x5f, 0x82, 0xa5, 0x51, + 0x83, 0x6c, 0xf8, 0x0d, 0x1a, 0x67, 0x65, 0x94, 0x97, 0x60, 0x8a, 0xa3, 0x32, 0x6b, 0x5c, 0xf4, + 0x4f, 0xc2, 0x99, 0x44, 0xcc, 0x47, 0xe5, 0x9f, 0x4a, 0xb0, 0x9c, 0xad, 0xd2, 0x79, 0xec, 0x37, + 0x3e, 0x48, 0xee, 0x37, 0x8a, 0x9e, 0x2a, 0x64, 0x2b, 0x9e, 0xb3, 0xf7, 0xf8, 0x24, 0xd3, 0xf8, + 0xe7, 0xb1, 0xca, 0xdd, 0xe4, 0x2a, 0xd7, 0x4e, 0xbc, 0xca, 0xec, 0x15, 0xb6, 0x3e, 0xf7, 0xf1, + 0xa7, 0x2b, 0x17, 0x7e, 0xfc, 0xe9, 0xca, 0x85, 0x7f, 0xfe, 0x74, 0xe5, 0xc2, 0x77, 0x8f, 0x56, + 0xa4, 0x8f, 0x8f, 0x56, 0xa4, 0x1f, 0x1f, 0xad, 0x48, 0xff, 0x76, 0xb4, 0x22, 0x7d, 0xff, 0x27, + 0x2b, 0x17, 0xbe, 0x36, 0x23, 0x30, 0xff, 0x37, 0x00, 0x00, 0xff, 0xff, 0x18, 0x07, 0xfd, 0xe8, + 0x4d, 0x46, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.proto similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.proto index 11d0fa6..e77401a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/generated.proto @@ -33,6 +33,7 @@ option go_package = "v1beta1"; // An APIVersion represents a single concrete version of an object model. message APIVersion { // Name of this version (e.g. 'v1'). + // +optional optional string name = 1; } @@ -71,10 +72,12 @@ message CustomMetricTargetList { message DaemonSet { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec defines the desired behavior of this daemon set. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional DaemonSetSpec spec = 2; // Status is the current status of this daemon set. This data may be @@ -82,6 +85,7 @@ message DaemonSet { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional DaemonSetStatus status = 3; } @@ -89,6 +93,7 @@ message DaemonSet { message DaemonSetList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of daemon sets. @@ -101,7 +106,8 @@ message DaemonSetSpec { // Must match in order to be controlled. // If empty, defaulted to labels on Pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - optional LabelSelector selector = 1; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 1; // Template is the object that describes the pod that will be created. // The DaemonSet will create exactly one copy of this pod on every node @@ -136,18 +142,43 @@ message DaemonSetStatus { // Deployment enables declarative updates for Pods and ReplicaSets. message Deployment { // Standard object metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Specification of the desired behavior of the Deployment. + // +optional optional DeploymentSpec spec = 2; // Most recently observed status of the Deployment. + // +optional optional DeploymentStatus status = 3; } +// DeploymentCondition describes the state of a deployment at a certain point. +message DeploymentCondition { + // Type of deployment condition. + optional string type = 1; + + // Status of the condition, one of True, False, Unknown. + optional string status = 2; + + // The last time this condition was updated. + optional k8s.io.kubernetes.pkg.api.unversioned.Time lastUpdateTime = 6; + + // Last time the condition transitioned from one status to another. + optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 7; + + // The reason for the condition's last transition. + optional string reason = 4; + + // A human readable message indicating details about the transition. + optional string message = 5; +} + // DeploymentList is a list of Deployments. message DeploymentList { // Standard list metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Deployments. @@ -160,6 +191,7 @@ message DeploymentRollback { optional string name = 1; // The annotations to be updated to a deployment + // +optional map updatedAnnotations = 2; // The config of this deployment rollback. @@ -170,56 +202,81 @@ message DeploymentRollback { message DeploymentSpec { // Number of desired pods. This is a pointer to distinguish between explicit // zero and not specified. Defaults to 1. + // +optional optional int32 replicas = 1; // Label selector for pods. Existing ReplicaSets whose pods are // selected by this will be the ones affected by this deployment. - optional LabelSelector selector = 2; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 2; // Template describes the pods that will be created. optional k8s.io.kubernetes.pkg.api.v1.PodTemplateSpec template = 3; // The deployment strategy to use to replace existing pods with new ones. + // +optional optional DeploymentStrategy strategy = 4; // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional optional int32 minReadySeconds = 5; // The number of old ReplicaSets to retain to allow rollback. // This is a pointer to distinguish between explicit zero and not specified. + // +optional optional int32 revisionHistoryLimit = 6; // Indicates that the deployment is paused and will not be processed by the // deployment controller. + // +optional optional bool paused = 7; // The config this deployment is rolling back to. Will be cleared after rollback is done. + // +optional optional RollbackConfig rollbackTo = 8; + + // The maximum time in seconds for a deployment to make progress before it + // is considered to be failed. The deployment controller will continue to + // process failed deployments and a condition with a ProgressDeadlineExceeded + // reason will be surfaced in the deployment status. Once autoRollback is + // implemented, the deployment controller will automatically rollback failed + // deployments. Note that progress will not be estimated during the time a + // deployment is paused. This is not set by default. + optional int32 progressDeadlineSeconds = 9; } // DeploymentStatus is the most recently observed status of the Deployment. message DeploymentStatus { // The generation observed by the deployment controller. + // +optional optional int64 observedGeneration = 1; // Total number of non-terminated pods targeted by this deployment (their labels match the selector). + // +optional optional int32 replicas = 2; // Total number of non-terminated pods targeted by this deployment that have the desired template spec. + // +optional optional int32 updatedReplicas = 3; // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. + // +optional optional int32 availableReplicas = 4; // Total number of unavailable pods targeted by this deployment. + // +optional optional int32 unavailableReplicas = 5; + + // Represents the latest available observations of a deployment's current state. + repeated DeploymentCondition conditions = 6; } // DeploymentStrategy describes how to replace existing pods with new ones. message DeploymentStrategy { // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. + // +optional optional string type = 1; // Rolling update config params. Present only if DeploymentStrategyType = @@ -227,6 +284,7 @@ message DeploymentStrategy { // --- // TODO: Update this to follow our convention for oneOf, whatever we decide it // to be. + // +optional optional RollingUpdateDeployment rollingUpdate = 2; } @@ -242,10 +300,12 @@ message ExportOptions { // FSGroupStrategyOptions defines the strategy type and options used to create the strategy. message FSGroupStrategyOptions { // Rule is the strategy that will dictate what FSGroup is used in the SecurityContext. + // +optional optional string rule = 1; // Ranges are the allowed ranges of fs groups. If you would like to force a single // fs group then supply a single range with the same start and end. + // +optional repeated IDRange ranges = 2; } @@ -259,6 +319,7 @@ message HTTPIngressPath { // part of a URL as defined by RFC 3986. Paths must begin with // a '/'. If unspecified, the path defaults to a catch all sending // traffic to the backend. + // +optional optional string path = 1; // Backend defines the referenced service endpoint to which the traffic @@ -279,18 +340,22 @@ message HTTPIngressRuleValue { // configuration of a horizontal pod autoscaler. message HorizontalPodAutoscaler { // Standard object metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // behaviour of autoscaler. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional optional HorizontalPodAutoscalerSpec spec = 2; // current information about the autoscaler. + // +optional optional HorizontalPodAutoscalerStatus status = 3; } // list of horizontal pod autoscaler objects. message HorizontalPodAutoscalerList { // Standard list metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // list of horizontal pod autoscaler objects. @@ -304,6 +369,7 @@ message HorizontalPodAutoscalerSpec { optional SubresourceReference scaleRef = 1; // lower limit for the number of pods that can be set by the autoscaler, default 1. + // +optional optional int32 minReplicas = 2; // upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. @@ -311,16 +377,19 @@ message HorizontalPodAutoscalerSpec { // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; // if not specified it defaults to the target CPU utilization at 80% of the requested resources. + // +optional optional CPUTargetUtilization cpuUtilization = 4; } // current status of a horizontal pod autoscaler message HorizontalPodAutoscalerStatus { // most recent generation observed by this autoscaler. + // +optional optional int64 observedGeneration = 1; // last time the HorizontalPodAutoscaler scaled the number of pods; // used by the autoscaler to control how often the number of pods is changed. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastScaleTime = 2; // current number of replicas of pods managed by this autoscaler. @@ -331,6 +400,7 @@ message HorizontalPodAutoscalerStatus { // current average CPU utilization over all pods, represented as a percentage of requested CPU, // e.g. 70 means that an average pod is using now 70% of its requested CPU. + // +optional optional int32 currentCPUUtilizationPercentage = 5; } @@ -360,14 +430,17 @@ message IDRange { message Ingress { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec is the desired state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional IngressSpec spec = 2; // Status is the current state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional IngressStatus status = 3; } @@ -384,6 +457,7 @@ message IngressBackend { message IngressList { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Ingress. @@ -406,6 +480,7 @@ message IngressRule { // Incoming requests are matched against the host before the IngressRuleValue. // If the host is unspecified, the Ingress routes all traffic based on the // specified IngressRuleValue. + // +optional optional string host = 1; // IngressRuleValue represents a rule to route requests for this IngressRule. @@ -413,6 +488,7 @@ message IngressRule { // just traffic matching the host to the default backend or all traffic to the // default backend, is left to the controller fulfilling the Ingress. Http is // currently the only supported IngressRuleValue. + // +optional optional IngressRuleValue ingressRuleValue = 2; } @@ -421,6 +497,7 @@ message IngressRule { // mixing different types of rules in a single Ingress is disallowed, so exactly // one of the following must be set. message IngressRuleValue { + // +optional optional HTTPIngressRuleValue http = 1; } @@ -430,6 +507,7 @@ message IngressSpec { // rule. At least one of 'backend' or 'rules' must be specified. This field // is optional to allow the loadbalancer controller or defaulting logic to // specify a global default. + // +optional optional IngressBackend backend = 1; // TLS configuration. Currently the Ingress only supports a single TLS @@ -437,16 +515,19 @@ message IngressSpec { // will be multiplexed on the same port according to the hostname specified // through the SNI TLS extension, if the ingress controller fulfilling the // ingress supports SNI. + // +optional repeated IngressTLS tls = 2; // A list of host rules used to configure the Ingress. If unspecified, or // no rule matches, all traffic is sent to the default backend. + // +optional repeated IngressRule rules = 3; } // IngressStatus describe the current state of the Ingress. message IngressStatus { // LoadBalancer contains the current status of the load-balancer. + // +optional optional k8s.io.kubernetes.pkg.api.v1.LoadBalancerStatus loadBalancer = 1; } @@ -456,6 +537,7 @@ message IngressTLS { // this list must match the name/s used in the tlsSecret. Defaults to the // wildcard host setting for the loadbalancer controller fulfilling this // Ingress, if left unspecified. + // +optional repeated string hosts = 1; // SecretName is the name of the secret used to terminate SSL traffic on 443. @@ -463,6 +545,7 @@ message IngressTLS { // If the SNI host in a listener conflicts with the "Host" header field used // by an IngressRule, the SNI host is used for termination and value of the // Host header is used for routing. + // +optional optional string secretName = 2; } @@ -470,14 +553,17 @@ message IngressTLS { message Job { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobSpec spec = 2; // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional JobStatus status = 3; } @@ -490,15 +576,19 @@ message JobCondition { optional string status = 2; // Last time the condition was checked. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; // Last time the condition transit from one status to another. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; // (brief) reason for the condition's last transition. + // +optional optional string reason = 5; // Human readable message indicating details about last transition. + // +optional optional string message = 6; } @@ -506,6 +596,7 @@ message JobCondition { message JobList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of Job. @@ -519,6 +610,7 @@ message JobSpec { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 parallelism = 1; // Completions specifies the desired number of successfully finished pods the @@ -527,22 +619,26 @@ message JobSpec { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional optional int32 completions = 2; // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional optional int64 activeDeadlineSeconds = 3; // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - optional LabelSelector selector = 4; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 4; // AutoSelector controls generation of pod labels and pod selectors. // It was not present in the original extensions/v1beta1 Job definition, but exists // to allow conversion from batch/v1 Jobs, where it corresponds to, but has the opposite // meaning as, ManualSelector. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional optional bool autoSelector = 5; // Template is the object that describes the pod that will be created when @@ -555,64 +651,42 @@ message JobSpec { message JobStatus { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional repeated JobCondition conditions = 1; // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time startTime = 2; // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.Time completionTime = 3; // Active is the number of actively running pods. + // +optional optional int32 active = 4; // Succeeded is the number of pods which reached Phase Succeeded. + // +optional optional int32 succeeded = 5; // Failed is the number of pods which reached Phase Failed. + // +optional optional int32 failed = 6; } -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -message LabelSelector { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - map matchLabels = 1; - - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - repeated LabelSelectorRequirement matchExpressions = 2; -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -message LabelSelectorRequirement { - // key is the label key that the selector applies to. - optional string key = 1; - - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - optional string operator = 2; - - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - repeated string values = 3; -} - message NetworkPolicy { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Specification of the desired behavior for this NetworkPolicy. + // +optional optional NetworkPolicySpec spec = 2; } @@ -625,6 +699,7 @@ message NetworkPolicyIngressRule { // If this field is present and contains at least one item, then this rule allows traffic // only if the traffic matches at least one port in the list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional repeated NetworkPolicyPort ports = 1; // List of sources which should be able to access the pods selected for this rule. @@ -634,6 +709,7 @@ message NetworkPolicyIngressRule { // If this field is present and contains at least on item, this rule allows traffic only if the // traffic matches at least one item in the from list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional repeated NetworkPolicyPeer from = 2; } @@ -641,6 +717,7 @@ message NetworkPolicyIngressRule { message NetworkPolicyList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of schema objects. @@ -652,19 +729,22 @@ message NetworkPolicyPeer { // This field follows standard label selector semantics. // If not provided, this selector selects no pods. // If present but empty, this selector selects all pods in this namespace. - optional LabelSelector podSelector = 1; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector podSelector = 1; // Selects Namespaces using cluster scoped-labels. This // matches all pods in all namespaces selected by this label selector. // This field follows standard label selector semantics. // If omitted, this selector selects no namespaces. // If present but empty, this selector selects all namespaces. - optional LabelSelector namespaceSelector = 2; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector namespaceSelector = 2; } message NetworkPolicyPort { // Optional. The protocol (TCP or UDP) which traffic must match. // If not specified, this field defaults to TCP. + // +optional optional string protocol = 1; // If specified, the port on the given protocol. This can @@ -672,6 +752,7 @@ message NetworkPolicyPort { // this matches all port names and numbers. // If present, only traffic on the specified protocol AND port // will be matched. + // +optional optional k8s.io.kubernetes.pkg.util.intstr.IntOrString port = 2; } @@ -681,7 +762,7 @@ message NetworkPolicySpec { // same set of pods. In this case, the ingress rules for each are combined additively. // This field is NOT optional and follows standard label selector semantics. // An empty podSelector matches all pods in this namespace. - optional LabelSelector podSelector = 1; + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector podSelector = 1; // List of ingress rules to be applied to the selected pods. // Traffic is allowed to a pod if namespace.networkPolicy.ingress.isolation is undefined and cluster policy allows it, @@ -691,6 +772,7 @@ message NetworkPolicySpec { // If this field is empty then this NetworkPolicy does not affect ingress isolation. // If this field is present and contains at least one rule, this policy allows any traffic // which matches at least one of the ingress rules in this list. + // +optional repeated NetworkPolicyIngressRule ingress = 2; } @@ -699,9 +781,11 @@ message NetworkPolicySpec { message PodSecurityPolicy { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // spec defines the policy enforced. + // +optional optional PodSecurityPolicySpec spec = 2; } @@ -709,6 +793,7 @@ message PodSecurityPolicy { message PodSecurityPolicyList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of schema objects. @@ -718,36 +803,45 @@ message PodSecurityPolicyList { // Pod Security Policy Spec defines the policy enforced. message PodSecurityPolicySpec { // privileged determines if a pod can request to be run as privileged. + // +optional optional bool privileged = 1; // DefaultAddCapabilities is the default set of capabilities that will be added to the container // unless the pod spec specifically drops the capability. You may not list a capabiility in both // DefaultAddCapabilities and RequiredDropCapabilities. + // +optional repeated string defaultAddCapabilities = 2; // RequiredDropCapabilities are the capabilities that will be dropped from the container. These // are required to be dropped and cannot be added. + // +optional repeated string requiredDropCapabilities = 3; // AllowedCapabilities is a list of capabilities that can be requested to add to the container. // Capabilities in this field may be added at the pod author's discretion. // You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities. + // +optional repeated string allowedCapabilities = 4; // volumes is a white list of allowed volume plugins. Empty indicates that all plugins // may be used. + // +optional repeated string volumes = 5; // hostNetwork determines if the policy allows the use of HostNetwork in the pod spec. + // +optional optional bool hostNetwork = 6; // hostPorts determines which host port ranges are allowed to be exposed. + // +optional repeated HostPortRange hostPorts = 7; // hostPID determines if the policy allows the use of HostPID in the pod spec. + // +optional optional bool hostPID = 8; // hostIPC determines if the policy allows the use of HostIPC in the pod spec. + // +optional optional bool hostIPC = 9; // seLinux is the strategy that will dictate the allowable labels that may be set. @@ -767,6 +861,7 @@ message PodSecurityPolicySpec { // the PSP should deny the pod. // If set to false the container may run with a read only root file system if it wishes but it // will not be forced to. + // +optional optional bool readOnlyRootFilesystem = 14; } @@ -775,10 +870,12 @@ message ReplicaSet { // If the Labels of a ReplicaSet are empty, they are defaulted to // be the same as the Pod(s) that the ReplicaSet manages. // Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Spec defines the specification of the desired behavior of the ReplicaSet. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ReplicaSetSpec spec = 2; // Status is the most recently observed status of the ReplicaSet. @@ -786,6 +883,7 @@ message ReplicaSet { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional optional ReplicaSetStatus status = 3; } @@ -797,23 +895,24 @@ message ReplicaSetCondition { // Status of the condition, one of True, False, Unknown. optional string status = 2; - // Last time we probed the condition. - optional k8s.io.kubernetes.pkg.api.unversioned.Time lastProbeTime = 3; - // The last time the condition transitioned from one status to another. - optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 4; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.Time lastTransitionTime = 3; // The reason for the condition's last transition. - optional string reason = 5; + // +optional + optional string reason = 4; // A human readable message indicating details about the transition. - optional string message = 6; + // +optional + optional string message = 5; } // ReplicaSetList is a collection of ReplicaSets. message ReplicaSetList { // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // List of ReplicaSets. @@ -827,22 +926,26 @@ message ReplicaSetSpec { // This is a pointer to distinguish between explicit zero and unspecified. // Defaults to 1. // More info: http://kubernetes.io/docs/user-guide/replication-controller#what-is-a-replication-controller + // +optional optional int32 replicas = 1; // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional optional int32 minReadySeconds = 4; // Selector is a label query over pods that should match the replica count. // If the selector is empty, it is defaulted to the labels present on the pod template. // Label keys and values that must match in order to be controlled by this replica set. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - optional LabelSelector selector = 2; + // +optional + optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 2; // Template is the object that describes the pod that will be created if // insufficient replicas are detected. // More info: http://kubernetes.io/docs/user-guide/replication-controller#pod-template + // +optional optional k8s.io.kubernetes.pkg.api.v1.PodTemplateSpec template = 3; } @@ -853,18 +956,23 @@ message ReplicaSetStatus { optional int32 replicas = 1; // The number of pods that have labels matching the labels of the pod template of the replicaset. + // +optional optional int32 fullyLabeledReplicas = 2; // The number of ready replicas for this replica set. + // +optional optional int32 readyReplicas = 4; // The number of available replicas (ready for at least minReadySeconds) for this replica set. + // +optional optional int32 availableReplicas = 5; // ObservedGeneration reflects the generation of the most recently observed ReplicaSet. + // +optional optional int64 observedGeneration = 3; // Represents the latest available observations of a replica set's current state. + // +optional repeated ReplicaSetCondition conditions = 6; } @@ -874,6 +982,7 @@ message ReplicationControllerDummy { message RollbackConfig { // The revision to rollback to. If set to 0, rollbck to the last revision. + // +optional optional int64 revision = 1; } @@ -889,6 +998,7 @@ message RollingUpdateDeployment { // can be scaled down further, followed by scaling up the new RC, ensuring // that the total number of pods available at all times during the update is at // least 70% of desired pods. + // +optional optional k8s.io.kubernetes.pkg.util.intstr.IntOrString maxUnavailable = 1; // The maximum number of pods that can be scheduled above the desired number of @@ -902,6 +1012,7 @@ message RollingUpdateDeployment { // 130% of desired pods. Once old pods have been killed, // new RC can be scaled up further, ensuring that total number of pods running // at any time during the update is atmost 130% of desired pods. + // +optional optional k8s.io.kubernetes.pkg.util.intstr.IntOrString maxSurge = 2; } @@ -911,6 +1022,7 @@ message RunAsUserStrategyOptions { optional string rule = 1; // Ranges are the allowed ranges of uids that may be used. + // +optional repeated IDRange ranges = 2; } @@ -921,24 +1033,29 @@ message SELinuxStrategyOptions { // seLinuxOptions required to run as; required for MustRunAs // More info: http://releases.k8s.io/HEAD/docs/design/security_context.md#security-context + // +optional optional k8s.io.kubernetes.pkg.api.v1.SELinuxOptions seLinuxOptions = 2; } // represents a scaling request for a resource. message Scale { // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional optional ScaleSpec spec = 2; // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional optional ScaleStatus status = 3; } // describes the attributes of a scale subresource message ScaleSpec { // desired number of instances for the scaled object. + // +optional optional int32 replicas = 1; } @@ -948,6 +1065,7 @@ message ScaleStatus { optional int32 replicas = 1; // label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional map selector = 2; // label selector for pods that should match the replicas count. This is a serializated @@ -956,31 +1074,38 @@ message ScaleStatus { // query-param syntax. If the target type only supports map-based selectors, both this // field and map-based selector field are populated. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional optional string targetSelector = 3; } // SubresourceReference contains enough information to let you inspect or modify the referred subresource. message SubresourceReference { // Kind of the referent; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional optional string kind = 1; // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional optional string name = 2; // API version of the referent + // +optional optional string apiVersion = 3; // Subresource name of the referent + // +optional optional string subresource = 4; } // SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy. message SupplementalGroupsStrategyOptions { // Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext. + // +optional optional string rule = 1; // Ranges are the allowed ranges of supplemental groups. If you would like to force a single // supplemental group then supply a single range with the same start and end. + // +optional repeated IDRange ranges = 2; } @@ -988,21 +1113,26 @@ message SupplementalGroupsStrategyOptions { // types to the API. It consists of one or more Versions of the api. message ThirdPartyResource { // Standard object metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Description is the description of this object. + // +optional optional string description = 2; // Versions are versions for this third party object + // +optional repeated APIVersion versions = 3; } // An internal object, used for versioned storage in etcd. Not exposed to the end user. message ThirdPartyResourceData { // Standard object metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Data is the raw JSON data for this data. + // +optional optional bytes data = 2; } @@ -1010,6 +1140,7 @@ message ThirdPartyResourceData { message ThirdPartyResourceDataList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of ThirdpartyResourceData. @@ -1019,6 +1150,7 @@ message ThirdPartyResourceDataList { // ThirdPartyResourceList is a list of ThirdPartyResources. message ThirdPartyResourceList { // Standard list metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of ThirdPartyResources. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/register.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/register.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/register.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/register.go index 697918c..1f97e9c 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.generated.go similarity index 72% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.generated.go index 88f166a..752fb71 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.generated.go @@ -25,11 +25,11 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg4_resource "k8s.io/kubernetes/pkg/api/resource" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" - pkg5_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg4_resource "k8s.io/client-go/pkg/api/resource" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" + pkg5_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" @@ -5424,7 +5424,7 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { } else { yysep453 := !z.EncBinary() yy2arr453 := z.EncBasicHandle().StructToArray - var yyq453 [8]bool + var yyq453 [9]bool _, _, _ = yysep453, yyq453, yy2arr453 const yyr453 bool = false yyq453[0] = x.Replicas != nil @@ -5434,9 +5434,10 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { yyq453[5] = x.RevisionHistoryLimit != nil yyq453[6] = x.Paused != false yyq453[7] = x.RollbackTo != nil + yyq453[8] = x.ProgressDeadlineSeconds != nil var yynn453 int if yyr453 || yy2arr453 { - r.EncodeArrayStart(8) + r.EncodeArrayStart(9) } else { yynn453 = 1 for _, b := range yyq453 { @@ -5488,7 +5489,13 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym460 := z.EncBinary() + _ = yym460 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } else { r.EncodeNil() @@ -5501,26 +5508,32 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym461 := z.EncBinary() + _ = yym461 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } } if yyr453 || yy2arr453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy461 := &x.Template - yy461.CodecEncodeSelf(e) + yy463 := &x.Template + yy463.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("template")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy462 := &x.Template - yy462.CodecEncodeSelf(e) + yy464 := &x.Template + yy464.CodecEncodeSelf(e) } if yyr453 || yy2arr453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq453[3] { - yy464 := &x.Strategy - yy464.CodecEncodeSelf(e) + yy466 := &x.Strategy + yy466.CodecEncodeSelf(e) } else { r.EncodeNil() } @@ -5529,15 +5542,15 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("strategy")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy465 := &x.Strategy - yy465.CodecEncodeSelf(e) + yy467 := &x.Strategy + yy467.CodecEncodeSelf(e) } } if yyr453 || yy2arr453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq453[4] { - yym467 := z.EncBinary() - _ = yym467 + yym469 := z.EncBinary() + _ = yym469 if false { } else { r.EncodeInt(int64(x.MinReadySeconds)) @@ -5550,8 +5563,8 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("minReadySeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym468 := z.EncBinary() - _ = yym468 + yym470 := z.EncBinary() + _ = yym470 if false { } else { r.EncodeInt(int64(x.MinReadySeconds)) @@ -5564,12 +5577,12 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.RevisionHistoryLimit == nil { r.EncodeNil() } else { - yy470 := *x.RevisionHistoryLimit - yym471 := z.EncBinary() - _ = yym471 + yy472 := *x.RevisionHistoryLimit + yym473 := z.EncBinary() + _ = yym473 if false { } else { - r.EncodeInt(int64(yy470)) + r.EncodeInt(int64(yy472)) } } } else { @@ -5583,12 +5596,12 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x.RevisionHistoryLimit == nil { r.EncodeNil() } else { - yy472 := *x.RevisionHistoryLimit - yym473 := z.EncBinary() - _ = yym473 + yy474 := *x.RevisionHistoryLimit + yym475 := z.EncBinary() + _ = yym475 if false { } else { - r.EncodeInt(int64(yy472)) + r.EncodeInt(int64(yy474)) } } } @@ -5596,8 +5609,8 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { if yyr453 || yy2arr453 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if yyq453[6] { - yym475 := z.EncBinary() - _ = yym475 + yym477 := z.EncBinary() + _ = yym477 if false { } else { r.EncodeBool(bool(x.Paused)) @@ -5610,8 +5623,8 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("paused")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym476 := z.EncBinary() - _ = yym476 + yym478 := z.EncBinary() + _ = yym478 if false { } else { r.EncodeBool(bool(x.Paused)) @@ -5641,6 +5654,41 @@ func (x *DeploymentSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } + if yyr453 || yy2arr453 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq453[8] { + if x.ProgressDeadlineSeconds == nil { + r.EncodeNil() + } else { + yy481 := *x.ProgressDeadlineSeconds + yym482 := z.EncBinary() + _ = yym482 + if false { + } else { + r.EncodeInt(int64(yy481)) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq453[8] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("progressDeadlineSeconds")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.ProgressDeadlineSeconds == nil { + r.EncodeNil() + } else { + yy483 := *x.ProgressDeadlineSeconds + yym484 := z.EncBinary() + _ = yym484 + if false { + } else { + r.EncodeInt(int64(yy483)) + } + } + } + } if yyr453 || yy2arr453 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { @@ -5654,25 +5702,25 @@ func (x *DeploymentSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym478 := z.DecBinary() - _ = yym478 + yym485 := z.DecBinary() + _ = yym485 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct479 := r.ContainerType() - if yyct479 == codecSelferValueTypeMap1234 { - yyl479 := r.ReadMapStart() - if yyl479 == 0 { + yyct486 := r.ContainerType() + if yyct486 == codecSelferValueTypeMap1234 { + yyl486 := r.ReadMapStart() + if yyl486 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl479, d) + x.codecDecodeSelfFromMap(yyl486, d) } - } else if yyct479 == codecSelferValueTypeArray1234 { - yyl479 := r.ReadArrayStart() - if yyl479 == 0 { + } else if yyct486 == codecSelferValueTypeArray1234 { + yyl486 := r.ReadArrayStart() + if yyl486 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl479, d) + x.codecDecodeSelfFromArray(yyl486, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -5684,12 +5732,12 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys480Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys480Slc - var yyhl480 bool = l >= 0 - for yyj480 := 0; ; yyj480++ { - if yyhl480 { - if yyj480 >= l { + var yys487Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys487Slc + var yyhl487 bool = l >= 0 + for yyj487 := 0; ; yyj487++ { + if yyhl487 { + if yyj487 >= l { break } } else { @@ -5698,10 +5746,10 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys480Slc = r.DecodeBytes(yys480Slc, true, true) - yys480 := string(yys480Slc) + yys487Slc = r.DecodeBytes(yys487Slc, true, true) + yys487 := string(yys487Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys480 { + switch yys487 { case "replicas": if r.TryDecodeAsNil() { if x.Replicas != nil { @@ -5711,8 +5759,8 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Replicas == nil { x.Replicas = new(int32) } - yym482 := z.DecBinary() - _ = yym482 + yym489 := z.DecBinary() + _ = yym489 if false { } else { *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) @@ -5725,23 +5773,29 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym491 := z.DecBinary() + _ = yym491 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } case "template": if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv484 := &x.Template - yyv484.CodecDecodeSelf(d) + yyv492 := &x.Template + yyv492.CodecDecodeSelf(d) } case "strategy": if r.TryDecodeAsNil() { x.Strategy = DeploymentStrategy{} } else { - yyv485 := &x.Strategy - yyv485.CodecDecodeSelf(d) + yyv493 := &x.Strategy + yyv493.CodecDecodeSelf(d) } case "minReadySeconds": if r.TryDecodeAsNil() { @@ -5758,8 +5812,8 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.RevisionHistoryLimit == nil { x.RevisionHistoryLimit = new(int32) } - yym488 := z.DecBinary() - _ = yym488 + yym496 := z.DecBinary() + _ = yym496 if false { } else { *((*int32)(x.RevisionHistoryLimit)) = int32(r.DecodeInt(32)) @@ -5782,10 +5836,26 @@ func (x *DeploymentSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } x.RollbackTo.CodecDecodeSelf(d) } + case "progressDeadlineSeconds": + if r.TryDecodeAsNil() { + if x.ProgressDeadlineSeconds != nil { + x.ProgressDeadlineSeconds = nil + } + } else { + if x.ProgressDeadlineSeconds == nil { + x.ProgressDeadlineSeconds = new(int32) + } + yym500 := z.DecBinary() + _ = yym500 + if false { + } else { + *((*int32)(x.ProgressDeadlineSeconds)) = int32(r.DecodeInt(32)) + } + } default: - z.DecStructFieldNotFound(-1, yys480) - } // end switch yys480 - } // end for yyj480 + z.DecStructFieldNotFound(-1, yys487) + } // end switch yys487 + } // end for yyj487 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -5793,16 +5863,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj491 int - var yyb491 bool - var yyhl491 bool = l >= 0 - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + var yyj501 int + var yyb501 bool + var yyhl501 bool = l >= 0 + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5815,20 +5885,20 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Replicas == nil { x.Replicas = new(int32) } - yym493 := z.DecBinary() - _ = yym493 + yym503 := z.DecBinary() + _ = yym503 if false { } else { *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) } } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5839,17 +5909,23 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym505 := z.DecBinary() + _ = yym505 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5857,16 +5933,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv495 := &x.Template - yyv495.CodecDecodeSelf(d) + yyv506 := &x.Template + yyv506.CodecDecodeSelf(d) } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5874,16 +5950,16 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Strategy = DeploymentStrategy{} } else { - yyv496 := &x.Strategy - yyv496.CodecDecodeSelf(d) + yyv507 := &x.Strategy + yyv507.CodecDecodeSelf(d) } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5893,13 +5969,13 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.MinReadySeconds = int32(r.DecodeInt(32)) } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5912,20 +5988,20 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.RevisionHistoryLimit == nil { x.RevisionHistoryLimit = new(int32) } - yym499 := z.DecBinary() - _ = yym499 + yym510 := z.DecBinary() + _ = yym510 if false { } else { *((*int32)(x.RevisionHistoryLimit)) = int32(r.DecodeInt(32)) } } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5935,13 +6011,13 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Paused = bool(r.DecodeBool()) } - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l } else { - yyb491 = r.CheckBreak() + yyb501 = r.CheckBreak() } - if yyb491 { + if yyb501 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -5956,18 +6032,44 @@ func (x *DeploymentSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } x.RollbackTo.CodecDecodeSelf(d) } - for { - yyj491++ - if yyhl491 { - yyb491 = yyj491 > l - } else { - yyb491 = r.CheckBreak() + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l + } else { + yyb501 = r.CheckBreak() + } + if yyb501 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.ProgressDeadlineSeconds != nil { + x.ProgressDeadlineSeconds = nil } - if yyb491 { + } else { + if x.ProgressDeadlineSeconds == nil { + x.ProgressDeadlineSeconds = new(int32) + } + yym514 := z.DecBinary() + _ = yym514 + if false { + } else { + *((*int32)(x.ProgressDeadlineSeconds)) = int32(r.DecodeInt(32)) + } + } + for { + yyj501++ + if yyhl501 { + yyb501 = yyj501 > l + } else { + yyb501 = r.CheckBreak() + } + if yyb501 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj491-1, "") + z.DecStructFieldNotFound(yyj501-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -5979,37 +6081,37 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym502 := z.EncBinary() - _ = yym502 + yym515 := z.EncBinary() + _ = yym515 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep503 := !z.EncBinary() - yy2arr503 := z.EncBasicHandle().StructToArray - var yyq503 [5]bool - _, _, _ = yysep503, yyq503, yy2arr503 - const yyr503 bool = false - yyq503[0] = x.Kind != "" - yyq503[1] = x.APIVersion != "" - yyq503[3] = len(x.UpdatedAnnotations) != 0 - var yynn503 int - if yyr503 || yy2arr503 { + yysep516 := !z.EncBinary() + yy2arr516 := z.EncBasicHandle().StructToArray + var yyq516 [5]bool + _, _, _ = yysep516, yyq516, yy2arr516 + const yyr516 bool = false + yyq516[0] = x.Kind != "" + yyq516[1] = x.APIVersion != "" + yyq516[3] = len(x.UpdatedAnnotations) != 0 + var yynn516 int + if yyr516 || yy2arr516 { r.EncodeArrayStart(5) } else { - yynn503 = 2 - for _, b := range yyq503 { + yynn516 = 2 + for _, b := range yyq516 { if b { - yynn503++ + yynn516++ } } - r.EncodeMapStart(yynn503) - yynn503 = 0 + r.EncodeMapStart(yynn516) + yynn516 = 0 } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq503[0] { - yym505 := z.EncBinary() - _ = yym505 + if yyq516[0] { + yym518 := z.EncBinary() + _ = yym518 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -6018,23 +6120,23 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq503[0] { + if yyq516[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym506 := z.EncBinary() - _ = yym506 + yym519 := z.EncBinary() + _ = yym519 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq503[1] { - yym508 := z.EncBinary() - _ = yym508 + if yyq516[1] { + yym521 := z.EncBinary() + _ = yym521 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -6043,22 +6145,22 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq503[1] { + if yyq516[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym509 := z.EncBinary() - _ = yym509 + yym522 := z.EncBinary() + _ = yym522 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym511 := z.EncBinary() - _ = yym511 + yym524 := z.EncBinary() + _ = yym524 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) @@ -6067,21 +6169,21 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("name")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym512 := z.EncBinary() - _ = yym512 + yym525 := z.EncBinary() + _ = yym525 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Name)) } } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq503[3] { + if yyq516[3] { if x.UpdatedAnnotations == nil { r.EncodeNil() } else { - yym514 := z.EncBinary() - _ = yym514 + yym527 := z.EncBinary() + _ = yym527 if false { } else { z.F.EncMapStringStringV(x.UpdatedAnnotations, false, e) @@ -6091,15 +6193,15 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq503[3] { + if yyq516[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("updatedAnnotations")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.UpdatedAnnotations == nil { r.EncodeNil() } else { - yym515 := z.EncBinary() - _ = yym515 + yym528 := z.EncBinary() + _ = yym528 if false { } else { z.F.EncMapStringStringV(x.UpdatedAnnotations, false, e) @@ -6107,18 +6209,18 @@ func (x *DeploymentRollback) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy517 := &x.RollbackTo - yy517.CodecEncodeSelf(e) + yy530 := &x.RollbackTo + yy530.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rollbackTo")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy518 := &x.RollbackTo - yy518.CodecEncodeSelf(e) + yy531 := &x.RollbackTo + yy531.CodecEncodeSelf(e) } - if yyr503 || yy2arr503 { + if yyr516 || yy2arr516 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6131,25 +6233,25 @@ func (x *DeploymentRollback) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym519 := z.DecBinary() - _ = yym519 + yym532 := z.DecBinary() + _ = yym532 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct520 := r.ContainerType() - if yyct520 == codecSelferValueTypeMap1234 { - yyl520 := r.ReadMapStart() - if yyl520 == 0 { + yyct533 := r.ContainerType() + if yyct533 == codecSelferValueTypeMap1234 { + yyl533 := r.ReadMapStart() + if yyl533 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl520, d) + x.codecDecodeSelfFromMap(yyl533, d) } - } else if yyct520 == codecSelferValueTypeArray1234 { - yyl520 := r.ReadArrayStart() - if yyl520 == 0 { + } else if yyct533 == codecSelferValueTypeArray1234 { + yyl533 := r.ReadArrayStart() + if yyl533 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl520, d) + x.codecDecodeSelfFromArray(yyl533, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6161,12 +6263,12 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys521Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys521Slc - var yyhl521 bool = l >= 0 - for yyj521 := 0; ; yyj521++ { - if yyhl521 { - if yyj521 >= l { + var yys534Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys534Slc + var yyhl534 bool = l >= 0 + for yyj534 := 0; ; yyj534++ { + if yyhl534 { + if yyj534 >= l { break } } else { @@ -6175,10 +6277,10 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys521Slc = r.DecodeBytes(yys521Slc, true, true) - yys521 := string(yys521Slc) + yys534Slc = r.DecodeBytes(yys534Slc, true, true) + yys534 := string(yys534Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys521 { + switch yys534 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -6201,25 +6303,25 @@ func (x *DeploymentRollback) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.UpdatedAnnotations = nil } else { - yyv525 := &x.UpdatedAnnotations - yym526 := z.DecBinary() - _ = yym526 + yyv538 := &x.UpdatedAnnotations + yym539 := z.DecBinary() + _ = yym539 if false { } else { - z.F.DecMapStringStringX(yyv525, false, d) + z.F.DecMapStringStringX(yyv538, false, d) } } case "rollbackTo": if r.TryDecodeAsNil() { x.RollbackTo = RollbackConfig{} } else { - yyv527 := &x.RollbackTo - yyv527.CodecDecodeSelf(d) + yyv540 := &x.RollbackTo + yyv540.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys521) - } // end switch yys521 - } // end for yyj521 + z.DecStructFieldNotFound(-1, yys534) + } // end switch yys534 + } // end for yyj534 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6227,16 +6329,16 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj528 int - var yyb528 bool - var yyhl528 bool = l >= 0 - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + var yyj541 int + var yyb541 bool + var yyhl541 bool = l >= 0 + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6246,13 +6348,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Kind = string(r.DecodeString()) } - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6262,13 +6364,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.APIVersion = string(r.DecodeString()) } - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6278,13 +6380,13 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Name = string(r.DecodeString()) } - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6292,21 +6394,21 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.UpdatedAnnotations = nil } else { - yyv532 := &x.UpdatedAnnotations - yym533 := z.DecBinary() - _ = yym533 + yyv545 := &x.UpdatedAnnotations + yym546 := z.DecBinary() + _ = yym546 if false { } else { - z.F.DecMapStringStringX(yyv532, false, d) + z.F.DecMapStringStringX(yyv545, false, d) } } - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6314,21 +6416,21 @@ func (x *DeploymentRollback) codecDecodeSelfFromArray(l int, d *codec1978.Decode if r.TryDecodeAsNil() { x.RollbackTo = RollbackConfig{} } else { - yyv534 := &x.RollbackTo - yyv534.CodecDecodeSelf(d) + yyv547 := &x.RollbackTo + yyv547.CodecDecodeSelf(d) } for { - yyj528++ - if yyhl528 { - yyb528 = yyj528 > l + yyj541++ + if yyhl541 { + yyb541 = yyj541 > l } else { - yyb528 = r.CheckBreak() + yyb541 = r.CheckBreak() } - if yyb528 { + if yyb541 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj528-1, "") + z.DecStructFieldNotFound(yyj541-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6340,35 +6442,35 @@ func (x *RollbackConfig) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym535 := z.EncBinary() - _ = yym535 + yym548 := z.EncBinary() + _ = yym548 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep536 := !z.EncBinary() - yy2arr536 := z.EncBasicHandle().StructToArray - var yyq536 [1]bool - _, _, _ = yysep536, yyq536, yy2arr536 - const yyr536 bool = false - yyq536[0] = x.Revision != 0 - var yynn536 int - if yyr536 || yy2arr536 { + yysep549 := !z.EncBinary() + yy2arr549 := z.EncBasicHandle().StructToArray + var yyq549 [1]bool + _, _, _ = yysep549, yyq549, yy2arr549 + const yyr549 bool = false + yyq549[0] = x.Revision != 0 + var yynn549 int + if yyr549 || yy2arr549 { r.EncodeArrayStart(1) } else { - yynn536 = 0 - for _, b := range yyq536 { + yynn549 = 0 + for _, b := range yyq549 { if b { - yynn536++ + yynn549++ } } - r.EncodeMapStart(yynn536) - yynn536 = 0 + r.EncodeMapStart(yynn549) + yynn549 = 0 } - if yyr536 || yy2arr536 { + if yyr549 || yy2arr549 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq536[0] { - yym538 := z.EncBinary() - _ = yym538 + if yyq549[0] { + yym551 := z.EncBinary() + _ = yym551 if false { } else { r.EncodeInt(int64(x.Revision)) @@ -6377,19 +6479,19 @@ func (x *RollbackConfig) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq536[0] { + if yyq549[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("revision")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym539 := z.EncBinary() - _ = yym539 + yym552 := z.EncBinary() + _ = yym552 if false { } else { r.EncodeInt(int64(x.Revision)) } } } - if yyr536 || yy2arr536 { + if yyr549 || yy2arr549 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6402,25 +6504,25 @@ func (x *RollbackConfig) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym540 := z.DecBinary() - _ = yym540 + yym553 := z.DecBinary() + _ = yym553 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct541 := r.ContainerType() - if yyct541 == codecSelferValueTypeMap1234 { - yyl541 := r.ReadMapStart() - if yyl541 == 0 { + yyct554 := r.ContainerType() + if yyct554 == codecSelferValueTypeMap1234 { + yyl554 := r.ReadMapStart() + if yyl554 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl541, d) + x.codecDecodeSelfFromMap(yyl554, d) } - } else if yyct541 == codecSelferValueTypeArray1234 { - yyl541 := r.ReadArrayStart() - if yyl541 == 0 { + } else if yyct554 == codecSelferValueTypeArray1234 { + yyl554 := r.ReadArrayStart() + if yyl554 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl541, d) + x.codecDecodeSelfFromArray(yyl554, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6432,12 +6534,12 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys542Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys542Slc - var yyhl542 bool = l >= 0 - for yyj542 := 0; ; yyj542++ { - if yyhl542 { - if yyj542 >= l { + var yys555Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys555Slc + var yyhl555 bool = l >= 0 + for yyj555 := 0; ; yyj555++ { + if yyhl555 { + if yyj555 >= l { break } } else { @@ -6446,10 +6548,10 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys542Slc = r.DecodeBytes(yys542Slc, true, true) - yys542 := string(yys542Slc) + yys555Slc = r.DecodeBytes(yys555Slc, true, true) + yys555 := string(yys555Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys542 { + switch yys555 { case "revision": if r.TryDecodeAsNil() { x.Revision = 0 @@ -6457,9 +6559,9 @@ func (x *RollbackConfig) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Revision = int64(r.DecodeInt(64)) } default: - z.DecStructFieldNotFound(-1, yys542) - } // end switch yys542 - } // end for yyj542 + z.DecStructFieldNotFound(-1, yys555) + } // end switch yys555 + } // end for yyj555 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6467,16 +6569,16 @@ func (x *RollbackConfig) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj544 int - var yyb544 bool - var yyhl544 bool = l >= 0 - yyj544++ - if yyhl544 { - yyb544 = yyj544 > l + var yyj557 int + var yyb557 bool + var yyhl557 bool = l >= 0 + yyj557++ + if yyhl557 { + yyb557 = yyj557 > l } else { - yyb544 = r.CheckBreak() + yyb557 = r.CheckBreak() } - if yyb544 { + if yyb557 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6487,17 +6589,17 @@ func (x *RollbackConfig) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Revision = int64(r.DecodeInt(64)) } for { - yyj544++ - if yyhl544 { - yyb544 = yyj544 > l + yyj557++ + if yyhl557 { + yyb557 = yyj557 > l } else { - yyb544 = r.CheckBreak() + yyb557 = r.CheckBreak() } - if yyb544 { + if yyb557 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj544-1, "") + z.DecStructFieldNotFound(yyj557-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6509,49 +6611,49 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym546 := z.EncBinary() - _ = yym546 + yym559 := z.EncBinary() + _ = yym559 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep547 := !z.EncBinary() - yy2arr547 := z.EncBasicHandle().StructToArray - var yyq547 [2]bool - _, _, _ = yysep547, yyq547, yy2arr547 - const yyr547 bool = false - yyq547[0] = x.Type != "" - yyq547[1] = x.RollingUpdate != nil - var yynn547 int - if yyr547 || yy2arr547 { + yysep560 := !z.EncBinary() + yy2arr560 := z.EncBasicHandle().StructToArray + var yyq560 [2]bool + _, _, _ = yysep560, yyq560, yy2arr560 + const yyr560 bool = false + yyq560[0] = x.Type != "" + yyq560[1] = x.RollingUpdate != nil + var yynn560 int + if yyr560 || yy2arr560 { r.EncodeArrayStart(2) } else { - yynn547 = 0 - for _, b := range yyq547 { + yynn560 = 0 + for _, b := range yyq560 { if b { - yynn547++ + yynn560++ } } - r.EncodeMapStart(yynn547) - yynn547 = 0 + r.EncodeMapStart(yynn560) + yynn560 = 0 } - if yyr547 || yy2arr547 { + if yyr560 || yy2arr560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq547[0] { + if yyq560[0] { x.Type.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq547[0] { + if yyq560[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("type")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } } - if yyr547 || yy2arr547 { + if yyr560 || yy2arr560 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq547[1] { + if yyq560[1] { if x.RollingUpdate == nil { r.EncodeNil() } else { @@ -6561,7 +6663,7 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq547[1] { + if yyq560[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rollingUpdate")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -6572,7 +6674,7 @@ func (x *DeploymentStrategy) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr547 || yy2arr547 { + if yyr560 || yy2arr560 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6585,25 +6687,25 @@ func (x *DeploymentStrategy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym550 := z.DecBinary() - _ = yym550 + yym563 := z.DecBinary() + _ = yym563 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct551 := r.ContainerType() - if yyct551 == codecSelferValueTypeMap1234 { - yyl551 := r.ReadMapStart() - if yyl551 == 0 { + yyct564 := r.ContainerType() + if yyct564 == codecSelferValueTypeMap1234 { + yyl564 := r.ReadMapStart() + if yyl564 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl551, d) + x.codecDecodeSelfFromMap(yyl564, d) } - } else if yyct551 == codecSelferValueTypeArray1234 { - yyl551 := r.ReadArrayStart() - if yyl551 == 0 { + } else if yyct564 == codecSelferValueTypeArray1234 { + yyl564 := r.ReadArrayStart() + if yyl564 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl551, d) + x.codecDecodeSelfFromArray(yyl564, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6615,12 +6717,12 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys552Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys552Slc - var yyhl552 bool = l >= 0 - for yyj552 := 0; ; yyj552++ { - if yyhl552 { - if yyj552 >= l { + var yys565Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys565Slc + var yyhl565 bool = l >= 0 + for yyj565 := 0; ; yyj565++ { + if yyhl565 { + if yyj565 >= l { break } } else { @@ -6629,10 +6731,10 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys552Slc = r.DecodeBytes(yys552Slc, true, true) - yys552 := string(yys552Slc) + yys565Slc = r.DecodeBytes(yys565Slc, true, true) + yys565 := string(yys565Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys552 { + switch yys565 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -6651,9 +6753,9 @@ func (x *DeploymentStrategy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) x.RollingUpdate.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys552) - } // end switch yys552 - } // end for yyj552 + z.DecStructFieldNotFound(-1, yys565) + } // end switch yys565 + } // end for yyj565 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6661,16 +6763,16 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj555 int - var yyb555 bool - var yyhl555 bool = l >= 0 - yyj555++ - if yyhl555 { - yyb555 = yyj555 > l + var yyj568 int + var yyb568 bool + var yyhl568 bool = l >= 0 + yyj568++ + if yyhl568 { + yyb568 = yyj568 > l } else { - yyb555 = r.CheckBreak() + yyb568 = r.CheckBreak() } - if yyb555 { + if yyb568 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6680,13 +6782,13 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode } else { x.Type = DeploymentStrategyType(r.DecodeString()) } - yyj555++ - if yyhl555 { - yyb555 = yyj555 > l + yyj568++ + if yyhl568 { + yyb568 = yyj568 > l } else { - yyb555 = r.CheckBreak() + yyb568 = r.CheckBreak() } - if yyb555 { + if yyb568 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6702,17 +6804,17 @@ func (x *DeploymentStrategy) codecDecodeSelfFromArray(l int, d *codec1978.Decode x.RollingUpdate.CodecDecodeSelf(d) } for { - yyj555++ - if yyhl555 { - yyb555 = yyj555 > l + yyj568++ + if yyhl568 { + yyb568 = yyj568 > l } else { - yyb555 = r.CheckBreak() + yyb568 = r.CheckBreak() } - if yyb555 { + if yyb568 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj555-1, "") + z.DecStructFieldNotFound(yyj568-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -6721,8 +6823,8 @@ func (x DeploymentStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym558 := z.EncBinary() - _ = yym558 + yym571 := z.EncBinary() + _ = yym571 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -6734,8 +6836,8 @@ func (x *DeploymentStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym559 := z.DecBinary() - _ = yym559 + yym572 := z.DecBinary() + _ = yym572 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -6750,42 +6852,42 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym560 := z.EncBinary() - _ = yym560 + yym573 := z.EncBinary() + _ = yym573 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep561 := !z.EncBinary() - yy2arr561 := z.EncBasicHandle().StructToArray - var yyq561 [2]bool - _, _, _ = yysep561, yyq561, yy2arr561 - const yyr561 bool = false - yyq561[0] = x.MaxUnavailable != nil - yyq561[1] = x.MaxSurge != nil - var yynn561 int - if yyr561 || yy2arr561 { + yysep574 := !z.EncBinary() + yy2arr574 := z.EncBasicHandle().StructToArray + var yyq574 [2]bool + _, _, _ = yysep574, yyq574, yy2arr574 + const yyr574 bool = false + yyq574[0] = x.MaxUnavailable != nil + yyq574[1] = x.MaxSurge != nil + var yynn574 int + if yyr574 || yy2arr574 { r.EncodeArrayStart(2) } else { - yynn561 = 0 - for _, b := range yyq561 { + yynn574 = 0 + for _, b := range yyq574 { if b { - yynn561++ + yynn574++ } } - r.EncodeMapStart(yynn561) - yynn561 = 0 + r.EncodeMapStart(yynn574) + yynn574 = 0 } - if yyr561 || yy2arr561 { + if yyr574 || yy2arr574 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq561[0] { + if yyq574[0] { if x.MaxUnavailable == nil { r.EncodeNil() } else { - yym563 := z.EncBinary() - _ = yym563 + yym576 := z.EncBinary() + _ = yym576 if false { } else if z.HasExtensions() && z.EncExt(x.MaxUnavailable) { - } else if !yym563 && z.IsJSONHandle() { + } else if !yym576 && z.IsJSONHandle() { z.EncJSONMarshal(x.MaxUnavailable) } else { z.EncFallback(x.MaxUnavailable) @@ -6795,18 +6897,18 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq561[0] { + if yyq574[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxUnavailable")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.MaxUnavailable == nil { r.EncodeNil() } else { - yym564 := z.EncBinary() - _ = yym564 + yym577 := z.EncBinary() + _ = yym577 if false { } else if z.HasExtensions() && z.EncExt(x.MaxUnavailable) { - } else if !yym564 && z.IsJSONHandle() { + } else if !yym577 && z.IsJSONHandle() { z.EncJSONMarshal(x.MaxUnavailable) } else { z.EncFallback(x.MaxUnavailable) @@ -6814,17 +6916,17 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr561 || yy2arr561 { + if yyr574 || yy2arr574 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq561[1] { + if yyq574[1] { if x.MaxSurge == nil { r.EncodeNil() } else { - yym566 := z.EncBinary() - _ = yym566 + yym579 := z.EncBinary() + _ = yym579 if false { } else if z.HasExtensions() && z.EncExt(x.MaxSurge) { - } else if !yym566 && z.IsJSONHandle() { + } else if !yym579 && z.IsJSONHandle() { z.EncJSONMarshal(x.MaxSurge) } else { z.EncFallback(x.MaxSurge) @@ -6834,18 +6936,18 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq561[1] { + if yyq574[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("maxSurge")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.MaxSurge == nil { r.EncodeNil() } else { - yym567 := z.EncBinary() - _ = yym567 + yym580 := z.EncBinary() + _ = yym580 if false { } else if z.HasExtensions() && z.EncExt(x.MaxSurge) { - } else if !yym567 && z.IsJSONHandle() { + } else if !yym580 && z.IsJSONHandle() { z.EncJSONMarshal(x.MaxSurge) } else { z.EncFallback(x.MaxSurge) @@ -6853,7 +6955,7 @@ func (x *RollingUpdateDeployment) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr561 || yy2arr561 { + if yyr574 || yy2arr574 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -6866,25 +6968,25 @@ func (x *RollingUpdateDeployment) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym568 := z.DecBinary() - _ = yym568 + yym581 := z.DecBinary() + _ = yym581 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct569 := r.ContainerType() - if yyct569 == codecSelferValueTypeMap1234 { - yyl569 := r.ReadMapStart() - if yyl569 == 0 { + yyct582 := r.ContainerType() + if yyct582 == codecSelferValueTypeMap1234 { + yyl582 := r.ReadMapStart() + if yyl582 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl569, d) + x.codecDecodeSelfFromMap(yyl582, d) } - } else if yyct569 == codecSelferValueTypeArray1234 { - yyl569 := r.ReadArrayStart() - if yyl569 == 0 { + } else if yyct582 == codecSelferValueTypeArray1234 { + yyl582 := r.ReadArrayStart() + if yyl582 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl569, d) + x.codecDecodeSelfFromArray(yyl582, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -6896,12 +6998,12 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys570Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys570Slc - var yyhl570 bool = l >= 0 - for yyj570 := 0; ; yyj570++ { - if yyhl570 { - if yyj570 >= l { + var yys583Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys583Slc + var yyhl583 bool = l >= 0 + for yyj583 := 0; ; yyj583++ { + if yyhl583 { + if yyj583 >= l { break } } else { @@ -6910,10 +7012,10 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys570Slc = r.DecodeBytes(yys570Slc, true, true) - yys570 := string(yys570Slc) + yys583Slc = r.DecodeBytes(yys583Slc, true, true) + yys583 := string(yys583Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys570 { + switch yys583 { case "maxUnavailable": if r.TryDecodeAsNil() { if x.MaxUnavailable != nil { @@ -6923,11 +7025,11 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec if x.MaxUnavailable == nil { x.MaxUnavailable = new(pkg5_intstr.IntOrString) } - yym572 := z.DecBinary() - _ = yym572 + yym585 := z.DecBinary() + _ = yym585 if false { } else if z.HasExtensions() && z.DecExt(x.MaxUnavailable) { - } else if !yym572 && z.IsJSONHandle() { + } else if !yym585 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.MaxUnavailable) } else { z.DecFallback(x.MaxUnavailable, false) @@ -6942,20 +7044,20 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromMap(l int, d *codec1978.Dec if x.MaxSurge == nil { x.MaxSurge = new(pkg5_intstr.IntOrString) } - yym574 := z.DecBinary() - _ = yym574 + yym587 := z.DecBinary() + _ = yym587 if false { } else if z.HasExtensions() && z.DecExt(x.MaxSurge) { - } else if !yym574 && z.IsJSONHandle() { + } else if !yym587 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.MaxSurge) } else { z.DecFallback(x.MaxSurge, false) } } default: - z.DecStructFieldNotFound(-1, yys570) - } // end switch yys570 - } // end for yyj570 + z.DecStructFieldNotFound(-1, yys583) + } // end switch yys583 + } // end for yyj583 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -6963,16 +7065,16 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj575 int - var yyb575 bool - var yyhl575 bool = l >= 0 - yyj575++ - if yyhl575 { - yyb575 = yyj575 > l + var yyj588 int + var yyb588 bool + var yyhl588 bool = l >= 0 + yyj588++ + if yyhl588 { + yyb588 = yyj588 > l } else { - yyb575 = r.CheckBreak() + yyb588 = r.CheckBreak() } - if yyb575 { + if yyb588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -6985,23 +7087,23 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D if x.MaxUnavailable == nil { x.MaxUnavailable = new(pkg5_intstr.IntOrString) } - yym577 := z.DecBinary() - _ = yym577 + yym590 := z.DecBinary() + _ = yym590 if false { } else if z.HasExtensions() && z.DecExt(x.MaxUnavailable) { - } else if !yym577 && z.IsJSONHandle() { + } else if !yym590 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.MaxUnavailable) } else { z.DecFallback(x.MaxUnavailable, false) } } - yyj575++ - if yyhl575 { - yyb575 = yyj575 > l + yyj588++ + if yyhl588 { + yyb588 = yyj588 > l } else { - yyb575 = r.CheckBreak() + yyb588 = r.CheckBreak() } - if yyb575 { + if yyb588 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7014,28 +7116,28 @@ func (x *RollingUpdateDeployment) codecDecodeSelfFromArray(l int, d *codec1978.D if x.MaxSurge == nil { x.MaxSurge = new(pkg5_intstr.IntOrString) } - yym579 := z.DecBinary() - _ = yym579 + yym592 := z.DecBinary() + _ = yym592 if false { } else if z.HasExtensions() && z.DecExt(x.MaxSurge) { - } else if !yym579 && z.IsJSONHandle() { + } else if !yym592 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.MaxSurge) } else { z.DecFallback(x.MaxSurge, false) } } for { - yyj575++ - if yyhl575 { - yyb575 = yyj575 > l + yyj588++ + if yyhl588 { + yyb588 = yyj588 > l } else { - yyb575 = r.CheckBreak() + yyb588 = r.CheckBreak() } - if yyb575 { + if yyb588 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj575-1, "") + z.DecStructFieldNotFound(yyj588-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7047,160 +7149,194 @@ func (x *DeploymentStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym580 := z.EncBinary() - _ = yym580 + yym593 := z.EncBinary() + _ = yym593 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep581 := !z.EncBinary() - yy2arr581 := z.EncBasicHandle().StructToArray - var yyq581 [5]bool - _, _, _ = yysep581, yyq581, yy2arr581 - const yyr581 bool = false - yyq581[0] = x.ObservedGeneration != 0 - yyq581[1] = x.Replicas != 0 - yyq581[2] = x.UpdatedReplicas != 0 - yyq581[3] = x.AvailableReplicas != 0 - yyq581[4] = x.UnavailableReplicas != 0 - var yynn581 int - if yyr581 || yy2arr581 { - r.EncodeArrayStart(5) + yysep594 := !z.EncBinary() + yy2arr594 := z.EncBasicHandle().StructToArray + var yyq594 [6]bool + _, _, _ = yysep594, yyq594, yy2arr594 + const yyr594 bool = false + yyq594[0] = x.ObservedGeneration != 0 + yyq594[1] = x.Replicas != 0 + yyq594[2] = x.UpdatedReplicas != 0 + yyq594[3] = x.AvailableReplicas != 0 + yyq594[4] = x.UnavailableReplicas != 0 + yyq594[5] = len(x.Conditions) != 0 + var yynn594 int + if yyr594 || yy2arr594 { + r.EncodeArrayStart(6) } else { - yynn581 = 0 - for _, b := range yyq581 { + yynn594 = 0 + for _, b := range yyq594 { if b { - yynn581++ + yynn594++ } } - r.EncodeMapStart(yynn581) - yynn581 = 0 + r.EncodeMapStart(yynn594) + yynn594 = 0 } - if yyr581 || yy2arr581 { + if yyr594 || yy2arr594 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[0] { - yym583 := z.EncBinary() - _ = yym583 - if false { - } else { - r.EncodeInt(int64(x.ObservedGeneration)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq581[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym584 := z.EncBinary() - _ = yym584 - if false { - } else { - r.EncodeInt(int64(x.ObservedGeneration)) - } - } - } - if yyr581 || yy2arr581 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[1] { - yym586 := z.EncBinary() - _ = yym586 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq581[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("replicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym587 := z.EncBinary() - _ = yym587 - if false { - } else { - r.EncodeInt(int64(x.Replicas)) - } - } - } - if yyr581 || yy2arr581 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[2] { - yym589 := z.EncBinary() - _ = yym589 - if false { - } else { - r.EncodeInt(int64(x.UpdatedReplicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq581[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("updatedReplicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym590 := z.EncBinary() - _ = yym590 - if false { - } else { - r.EncodeInt(int64(x.UpdatedReplicas)) - } - } - } - if yyr581 || yy2arr581 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[3] { - yym592 := z.EncBinary() - _ = yym592 - if false { - } else { - r.EncodeInt(int64(x.AvailableReplicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq581[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym593 := z.EncBinary() - _ = yym593 - if false { - } else { - r.EncodeInt(int64(x.AvailableReplicas)) - } - } - } - if yyr581 || yy2arr581 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq581[4] { - yym595 := z.EncBinary() - _ = yym595 - if false { - } else { - r.EncodeInt(int64(x.UnavailableReplicas)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq581[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("unavailableReplicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) + if yyq594[0] { yym596 := z.EncBinary() _ = yym596 if false { + } else { + r.EncodeInt(int64(x.ObservedGeneration)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq594[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym597 := z.EncBinary() + _ = yym597 + if false { + } else { + r.EncodeInt(int64(x.ObservedGeneration)) + } + } + } + if yyr594 || yy2arr594 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq594[1] { + yym599 := z.EncBinary() + _ = yym599 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq594[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("replicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym600 := z.EncBinary() + _ = yym600 + if false { + } else { + r.EncodeInt(int64(x.Replicas)) + } + } + } + if yyr594 || yy2arr594 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq594[2] { + yym602 := z.EncBinary() + _ = yym602 + if false { + } else { + r.EncodeInt(int64(x.UpdatedReplicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq594[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("updatedReplicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym603 := z.EncBinary() + _ = yym603 + if false { + } else { + r.EncodeInt(int64(x.UpdatedReplicas)) + } + } + } + if yyr594 || yy2arr594 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq594[3] { + yym605 := z.EncBinary() + _ = yym605 + if false { + } else { + r.EncodeInt(int64(x.AvailableReplicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq594[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym606 := z.EncBinary() + _ = yym606 + if false { + } else { + r.EncodeInt(int64(x.AvailableReplicas)) + } + } + } + if yyr594 || yy2arr594 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq594[4] { + yym608 := z.EncBinary() + _ = yym608 + if false { + } else { + r.EncodeInt(int64(x.UnavailableReplicas)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq594[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("unavailableReplicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym609 := z.EncBinary() + _ = yym609 + if false { } else { r.EncodeInt(int64(x.UnavailableReplicas)) } } } - if yyr581 || yy2arr581 { + if yyr594 || yy2arr594 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq594[5] { + if x.Conditions == nil { + r.EncodeNil() + } else { + yym611 := z.EncBinary() + _ = yym611 + if false { + } else { + h.encSliceDeploymentCondition(([]DeploymentCondition)(x.Conditions), e) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq594[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("conditions")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Conditions == nil { + r.EncodeNil() + } else { + yym612 := z.EncBinary() + _ = yym612 + if false { + } else { + h.encSliceDeploymentCondition(([]DeploymentCondition)(x.Conditions), e) + } + } + } + } + if yyr594 || yy2arr594 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7213,25 +7349,25 @@ func (x *DeploymentStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym597 := z.DecBinary() - _ = yym597 + yym613 := z.DecBinary() + _ = yym613 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct598 := r.ContainerType() - if yyct598 == codecSelferValueTypeMap1234 { - yyl598 := r.ReadMapStart() - if yyl598 == 0 { + yyct614 := r.ContainerType() + if yyct614 == codecSelferValueTypeMap1234 { + yyl614 := r.ReadMapStart() + if yyl614 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl598, d) + x.codecDecodeSelfFromMap(yyl614, d) } - } else if yyct598 == codecSelferValueTypeArray1234 { - yyl598 := r.ReadArrayStart() - if yyl598 == 0 { + } else if yyct614 == codecSelferValueTypeArray1234 { + yyl614 := r.ReadArrayStart() + if yyl614 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl598, d) + x.codecDecodeSelfFromArray(yyl614, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7243,12 +7379,12 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys599Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys599Slc - var yyhl599 bool = l >= 0 - for yyj599 := 0; ; yyj599++ { - if yyhl599 { - if yyj599 >= l { + var yys615Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys615Slc + var yyhl615 bool = l >= 0 + for yyj615 := 0; ; yyj615++ { + if yyhl615 { + if yyj615 >= l { break } } else { @@ -7257,10 +7393,10 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys599Slc = r.DecodeBytes(yys599Slc, true, true) - yys599 := string(yys599Slc) + yys615Slc = r.DecodeBytes(yys615Slc, true, true) + yys615 := string(yys615Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys599 { + switch yys615 { case "observedGeneration": if r.TryDecodeAsNil() { x.ObservedGeneration = 0 @@ -7291,10 +7427,22 @@ func (x *DeploymentStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } else { x.UnavailableReplicas = int32(r.DecodeInt(32)) } + case "conditions": + if r.TryDecodeAsNil() { + x.Conditions = nil + } else { + yyv621 := &x.Conditions + yym622 := z.DecBinary() + _ = yym622 + if false { + } else { + h.decSliceDeploymentCondition((*[]DeploymentCondition)(yyv621), d) + } + } default: - z.DecStructFieldNotFound(-1, yys599) - } // end switch yys599 - } // end for yyj599 + z.DecStructFieldNotFound(-1, yys615) + } // end switch yys615 + } // end for yyj615 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7302,16 +7450,16 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj605 int - var yyb605 bool - var yyhl605 bool = l >= 0 - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + var yyj623 int + var yyb623 bool + var yyhl623 bool = l >= 0 + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l } else { - yyb605 = r.CheckBreak() + yyb623 = r.CheckBreak() } - if yyb605 { + if yyb623 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7321,13 +7469,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ObservedGeneration = int64(r.DecodeInt(64)) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l } else { - yyb605 = r.CheckBreak() + yyb623 = r.CheckBreak() } - if yyb605 { + if yyb623 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7337,13 +7485,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l } else { - yyb605 = r.CheckBreak() + yyb623 = r.CheckBreak() } - if yyb605 { + if yyb623 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7353,13 +7501,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UpdatedReplicas = int32(r.DecodeInt(32)) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l } else { - yyb605 = r.CheckBreak() + yyb623 = r.CheckBreak() } - if yyb605 { + if yyb623 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7369,13 +7517,13 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.AvailableReplicas = int32(r.DecodeInt(32)) } - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l } else { - yyb605 = r.CheckBreak() + yyb623 = r.CheckBreak() } - if yyb605 { + if yyb623 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7385,18 +7533,521 @@ func (x *DeploymentStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.UnavailableReplicas = int32(r.DecodeInt(32)) } - for { - yyj605++ - if yyhl605 { - yyb605 = yyj605 > l + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l + } else { + yyb623 = r.CheckBreak() + } + if yyb623 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Conditions = nil + } else { + yyv629 := &x.Conditions + yym630 := z.DecBinary() + _ = yym630 + if false { } else { - yyb605 = r.CheckBreak() + h.decSliceDeploymentCondition((*[]DeploymentCondition)(yyv629), d) } - if yyb605 { + } + for { + yyj623++ + if yyhl623 { + yyb623 = yyj623 > l + } else { + yyb623 = r.CheckBreak() + } + if yyb623 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj605-1, "") + z.DecStructFieldNotFound(yyj623-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x DeploymentConditionType) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + yym631 := z.EncBinary() + _ = yym631 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x)) + } +} + +func (x *DeploymentConditionType) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym632 := z.DecBinary() + _ = yym632 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + *((*string)(x)) = r.DecodeString() + } +} + +func (x *DeploymentCondition) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym633 := z.EncBinary() + _ = yym633 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep634 := !z.EncBinary() + yy2arr634 := z.EncBasicHandle().StructToArray + var yyq634 [6]bool + _, _, _ = yysep634, yyq634, yy2arr634 + const yyr634 bool = false + yyq634[2] = true + yyq634[3] = true + yyq634[4] = x.Reason != "" + yyq634[5] = x.Message != "" + var yynn634 int + if yyr634 || yy2arr634 { + r.EncodeArrayStart(6) + } else { + yynn634 = 2 + for _, b := range yyq634 { + if b { + yynn634++ + } + } + r.EncodeMapStart(yynn634) + yynn634 = 0 + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + x.Type.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("type")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + x.Type.CodecEncodeSelf(e) + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym637 := z.EncBinary() + _ = yym637 + if false { + } else if z.HasExtensions() && z.EncExt(x.Status) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Status)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("status")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym638 := z.EncBinary() + _ = yym638 + if false { + } else if z.HasExtensions() && z.EncExt(x.Status) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Status)) + } + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq634[2] { + yy640 := &x.LastUpdateTime + yym641 := z.EncBinary() + _ = yym641 + if false { + } else if z.HasExtensions() && z.EncExt(yy640) { + } else if yym641 { + z.EncBinaryMarshal(yy640) + } else if !yym641 && z.IsJSONHandle() { + z.EncJSONMarshal(yy640) + } else { + z.EncFallback(yy640) + } + } else { + r.EncodeNil() + } + } else { + if yyq634[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("lastUpdateTime")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy642 := &x.LastUpdateTime + yym643 := z.EncBinary() + _ = yym643 + if false { + } else if z.HasExtensions() && z.EncExt(yy642) { + } else if yym643 { + z.EncBinaryMarshal(yy642) + } else if !yym643 && z.IsJSONHandle() { + z.EncJSONMarshal(yy642) + } else { + z.EncFallback(yy642) + } + } + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq634[3] { + yy645 := &x.LastTransitionTime + yym646 := z.EncBinary() + _ = yym646 + if false { + } else if z.HasExtensions() && z.EncExt(yy645) { + } else if yym646 { + z.EncBinaryMarshal(yy645) + } else if !yym646 && z.IsJSONHandle() { + z.EncJSONMarshal(yy645) + } else { + z.EncFallback(yy645) + } + } else { + r.EncodeNil() + } + } else { + if yyq634[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy647 := &x.LastTransitionTime + yym648 := z.EncBinary() + _ = yym648 + if false { + } else if z.HasExtensions() && z.EncExt(yy647) { + } else if yym648 { + z.EncBinaryMarshal(yy647) + } else if !yym648 && z.IsJSONHandle() { + z.EncJSONMarshal(yy647) + } else { + z.EncFallback(yy647) + } + } + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq634[4] { + yym650 := z.EncBinary() + _ = yym650 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq634[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("reason")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym651 := z.EncBinary() + _ = yym651 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) + } + } + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq634[5] { + yym653 := z.EncBinary() + _ = yym653 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq634[5] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("message")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym654 := z.EncBinary() + _ = yym654 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Message)) + } + } + } + if yyr634 || yy2arr634 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *DeploymentCondition) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym655 := z.DecBinary() + _ = yym655 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct656 := r.ContainerType() + if yyct656 == codecSelferValueTypeMap1234 { + yyl656 := r.ReadMapStart() + if yyl656 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl656, d) + } + } else if yyct656 == codecSelferValueTypeArray1234 { + yyl656 := r.ReadArrayStart() + if yyl656 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl656, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *DeploymentCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys657Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys657Slc + var yyhl657 bool = l >= 0 + for yyj657 := 0; ; yyj657++ { + if yyhl657 { + if yyj657 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys657Slc = r.DecodeBytes(yys657Slc, true, true) + yys657 := string(yys657Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys657 { + case "type": + if r.TryDecodeAsNil() { + x.Type = "" + } else { + x.Type = DeploymentConditionType(r.DecodeString()) + } + case "status": + if r.TryDecodeAsNil() { + x.Status = "" + } else { + x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) + } + case "lastUpdateTime": + if r.TryDecodeAsNil() { + x.LastUpdateTime = pkg1_unversioned.Time{} + } else { + yyv660 := &x.LastUpdateTime + yym661 := z.DecBinary() + _ = yym661 + if false { + } else if z.HasExtensions() && z.DecExt(yyv660) { + } else if yym661 { + z.DecBinaryUnmarshal(yyv660) + } else if !yym661 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv660) + } else { + z.DecFallback(yyv660, false) + } + } + case "lastTransitionTime": + if r.TryDecodeAsNil() { + x.LastTransitionTime = pkg1_unversioned.Time{} + } else { + yyv662 := &x.LastTransitionTime + yym663 := z.DecBinary() + _ = yym663 + if false { + } else if z.HasExtensions() && z.DecExt(yyv662) { + } else if yym663 { + z.DecBinaryUnmarshal(yyv662) + } else if !yym663 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv662) + } else { + z.DecFallback(yyv662, false) + } + } + case "reason": + if r.TryDecodeAsNil() { + x.Reason = "" + } else { + x.Reason = string(r.DecodeString()) + } + case "message": + if r.TryDecodeAsNil() { + x.Message = "" + } else { + x.Message = string(r.DecodeString()) + } + default: + z.DecStructFieldNotFound(-1, yys657) + } // end switch yys657 + } // end for yyj657 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *DeploymentCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj666 int + var yyb666 bool + var yyhl666 bool = l >= 0 + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Type = "" + } else { + x.Type = DeploymentConditionType(r.DecodeString()) + } + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Status = "" + } else { + x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) + } + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.LastUpdateTime = pkg1_unversioned.Time{} + } else { + yyv669 := &x.LastUpdateTime + yym670 := z.DecBinary() + _ = yym670 + if false { + } else if z.HasExtensions() && z.DecExt(yyv669) { + } else if yym670 { + z.DecBinaryUnmarshal(yyv669) + } else if !yym670 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv669) + } else { + z.DecFallback(yyv669, false) + } + } + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.LastTransitionTime = pkg1_unversioned.Time{} + } else { + yyv671 := &x.LastTransitionTime + yym672 := z.DecBinary() + _ = yym672 + if false { + } else if z.HasExtensions() && z.DecExt(yyv671) { + } else if yym672 { + z.DecBinaryUnmarshal(yyv671) + } else if !yym672 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv671) + } else { + z.DecFallback(yyv671, false) + } + } + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Reason = "" + } else { + x.Reason = string(r.DecodeString()) + } + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Message = "" + } else { + x.Message = string(r.DecodeString()) + } + for { + yyj666++ + if yyhl666 { + yyb666 = yyj666 > l + } else { + yyb666 = r.CheckBreak() + } + if yyb666 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj666-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7408,37 +8059,37 @@ func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym611 := z.EncBinary() - _ = yym611 + yym675 := z.EncBinary() + _ = yym675 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep612 := !z.EncBinary() - yy2arr612 := z.EncBasicHandle().StructToArray - var yyq612 [4]bool - _, _, _ = yysep612, yyq612, yy2arr612 - const yyr612 bool = false - yyq612[0] = x.Kind != "" - yyq612[1] = x.APIVersion != "" - yyq612[2] = true - var yynn612 int - if yyr612 || yy2arr612 { + yysep676 := !z.EncBinary() + yy2arr676 := z.EncBasicHandle().StructToArray + var yyq676 [4]bool + _, _, _ = yysep676, yyq676, yy2arr676 + const yyr676 bool = false + yyq676[0] = x.Kind != "" + yyq676[1] = x.APIVersion != "" + yyq676[2] = true + var yynn676 int + if yyr676 || yy2arr676 { r.EncodeArrayStart(4) } else { - yynn612 = 1 - for _, b := range yyq612 { + yynn676 = 1 + for _, b := range yyq676 { if b { - yynn612++ + yynn676++ } } - r.EncodeMapStart(yynn612) - yynn612 = 0 + r.EncodeMapStart(yynn676) + yynn676 = 0 } - if yyr612 || yy2arr612 { + if yyr676 || yy2arr676 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq612[0] { - yym614 := z.EncBinary() - _ = yym614 + if yyq676[0] { + yym678 := z.EncBinary() + _ = yym678 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -7447,23 +8098,23 @@ func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq612[0] { + if yyq676[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym615 := z.EncBinary() - _ = yym615 + yym679 := z.EncBinary() + _ = yym679 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr612 || yy2arr612 { + if yyr676 || yy2arr676 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq612[1] { - yym617 := z.EncBinary() - _ = yym617 + if yyq676[1] { + yym681 := z.EncBinary() + _ = yym681 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -7472,54 +8123,54 @@ func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq612[1] { + if yyq676[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym618 := z.EncBinary() - _ = yym618 + yym682 := z.EncBinary() + _ = yym682 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr612 || yy2arr612 { + if yyr676 || yy2arr676 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq612[2] { - yy620 := &x.ListMeta - yym621 := z.EncBinary() - _ = yym621 + if yyq676[2] { + yy684 := &x.ListMeta + yym685 := z.EncBinary() + _ = yym685 if false { - } else if z.HasExtensions() && z.EncExt(yy620) { + } else if z.HasExtensions() && z.EncExt(yy684) { } else { - z.EncFallback(yy620) + z.EncFallback(yy684) } } else { r.EncodeNil() } } else { - if yyq612[2] { + if yyq676[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy622 := &x.ListMeta - yym623 := z.EncBinary() - _ = yym623 + yy686 := &x.ListMeta + yym687 := z.EncBinary() + _ = yym687 if false { - } else if z.HasExtensions() && z.EncExt(yy622) { + } else if z.HasExtensions() && z.EncExt(yy686) { } else { - z.EncFallback(yy622) + z.EncFallback(yy686) } } } - if yyr612 || yy2arr612 { + if yyr676 || yy2arr676 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym625 := z.EncBinary() - _ = yym625 + yym689 := z.EncBinary() + _ = yym689 if false { } else { h.encSliceDeployment(([]Deployment)(x.Items), e) @@ -7532,15 +8183,15 @@ func (x *DeploymentList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym626 := z.EncBinary() - _ = yym626 + yym690 := z.EncBinary() + _ = yym690 if false { } else { h.encSliceDeployment(([]Deployment)(x.Items), e) } } } - if yyr612 || yy2arr612 { + if yyr676 || yy2arr676 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7553,25 +8204,25 @@ func (x *DeploymentList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym627 := z.DecBinary() - _ = yym627 + yym691 := z.DecBinary() + _ = yym691 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct628 := r.ContainerType() - if yyct628 == codecSelferValueTypeMap1234 { - yyl628 := r.ReadMapStart() - if yyl628 == 0 { + yyct692 := r.ContainerType() + if yyct692 == codecSelferValueTypeMap1234 { + yyl692 := r.ReadMapStart() + if yyl692 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl628, d) + x.codecDecodeSelfFromMap(yyl692, d) } - } else if yyct628 == codecSelferValueTypeArray1234 { - yyl628 := r.ReadArrayStart() - if yyl628 == 0 { + } else if yyct692 == codecSelferValueTypeArray1234 { + yyl692 := r.ReadArrayStart() + if yyl692 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl628, d) + x.codecDecodeSelfFromArray(yyl692, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7583,12 +8234,12 @@ func (x *DeploymentList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys629Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys629Slc - var yyhl629 bool = l >= 0 - for yyj629 := 0; ; yyj629++ { - if yyhl629 { - if yyj629 >= l { + var yys693Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys693Slc + var yyhl693 bool = l >= 0 + for yyj693 := 0; ; yyj693++ { + if yyhl693 { + if yyj693 >= l { break } } else { @@ -7597,10 +8248,10 @@ func (x *DeploymentList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys629Slc = r.DecodeBytes(yys629Slc, true, true) - yys629 := string(yys629Slc) + yys693Slc = r.DecodeBytes(yys693Slc, true, true) + yys693 := string(yys693Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys629 { + switch yys693 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -7617,31 +8268,31 @@ func (x *DeploymentList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv632 := &x.ListMeta - yym633 := z.DecBinary() - _ = yym633 + yyv696 := &x.ListMeta + yym697 := z.DecBinary() + _ = yym697 if false { - } else if z.HasExtensions() && z.DecExt(yyv632) { + } else if z.HasExtensions() && z.DecExt(yyv696) { } else { - z.DecFallback(yyv632, false) + z.DecFallback(yyv696, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv634 := &x.Items - yym635 := z.DecBinary() - _ = yym635 + yyv698 := &x.Items + yym699 := z.DecBinary() + _ = yym699 if false { } else { - h.decSliceDeployment((*[]Deployment)(yyv634), d) + h.decSliceDeployment((*[]Deployment)(yyv698), d) } } default: - z.DecStructFieldNotFound(-1, yys629) - } // end switch yys629 - } // end for yyj629 + z.DecStructFieldNotFound(-1, yys693) + } // end switch yys693 + } // end for yyj693 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7649,16 +8300,16 @@ func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj636 int - var yyb636 bool - var yyhl636 bool = l >= 0 - yyj636++ - if yyhl636 { - yyb636 = yyj636 > l + var yyj700 int + var yyb700 bool + var yyhl700 bool = l >= 0 + yyj700++ + if yyhl700 { + yyb700 = yyj700 > l } else { - yyb636 = r.CheckBreak() + yyb700 = r.CheckBreak() } - if yyb636 { + if yyb700 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7668,13 +8319,13 @@ func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj636++ - if yyhl636 { - yyb636 = yyj636 > l + yyj700++ + if yyhl700 { + yyb700 = yyj700 > l } else { - yyb636 = r.CheckBreak() + yyb700 = r.CheckBreak() } - if yyb636 { + if yyb700 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7684,13 +8335,13 @@ func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj636++ - if yyhl636 { - yyb636 = yyj636 > l + yyj700++ + if yyhl700 { + yyb700 = yyj700 > l } else { - yyb636 = r.CheckBreak() + yyb700 = r.CheckBreak() } - if yyb636 { + if yyb700 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7698,22 +8349,22 @@ func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv639 := &x.ListMeta - yym640 := z.DecBinary() - _ = yym640 + yyv703 := &x.ListMeta + yym704 := z.DecBinary() + _ = yym704 if false { - } else if z.HasExtensions() && z.DecExt(yyv639) { + } else if z.HasExtensions() && z.DecExt(yyv703) { } else { - z.DecFallback(yyv639, false) + z.DecFallback(yyv703, false) } } - yyj636++ - if yyhl636 { - yyb636 = yyj636 > l + yyj700++ + if yyhl700 { + yyb700 = yyj700 > l } else { - yyb636 = r.CheckBreak() + yyb700 = r.CheckBreak() } - if yyb636 { + if yyb700 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7721,26 +8372,26 @@ func (x *DeploymentList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv641 := &x.Items - yym642 := z.DecBinary() - _ = yym642 + yyv705 := &x.Items + yym706 := z.DecBinary() + _ = yym706 if false { } else { - h.decSliceDeployment((*[]Deployment)(yyv641), d) + h.decSliceDeployment((*[]Deployment)(yyv705), d) } } for { - yyj636++ - if yyhl636 { - yyb636 = yyj636 > l + yyj700++ + if yyhl700 { + yyb700 = yyj700 > l } else { - yyb636 = r.CheckBreak() + yyb700 = r.CheckBreak() } - if yyb636 { + if yyb700 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj636-1, "") + z.DecStructFieldNotFound(yyj700-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7752,65 +8403,77 @@ func (x *DaemonSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym643 := z.EncBinary() - _ = yym643 + yym707 := z.EncBinary() + _ = yym707 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep644 := !z.EncBinary() - yy2arr644 := z.EncBasicHandle().StructToArray - var yyq644 [2]bool - _, _, _ = yysep644, yyq644, yy2arr644 - const yyr644 bool = false - yyq644[0] = x.Selector != nil - var yynn644 int - if yyr644 || yy2arr644 { + yysep708 := !z.EncBinary() + yy2arr708 := z.EncBasicHandle().StructToArray + var yyq708 [2]bool + _, _, _ = yysep708, yyq708, yy2arr708 + const yyr708 bool = false + yyq708[0] = x.Selector != nil + var yynn708 int + if yyr708 || yy2arr708 { r.EncodeArrayStart(2) } else { - yynn644 = 1 - for _, b := range yyq644 { + yynn708 = 1 + for _, b := range yyq708 { if b { - yynn644++ + yynn708++ } } - r.EncodeMapStart(yynn644) - yynn644 = 0 + r.EncodeMapStart(yynn708) + yynn708 = 0 } - if yyr644 || yy2arr644 { + if yyr708 || yy2arr708 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq644[0] { + if yyq708[0] { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym710 := z.EncBinary() + _ = yym710 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } else { r.EncodeNil() } } else { - if yyq644[0] { + if yyq708[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("selector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym711 := z.EncBinary() + _ = yym711 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } } - if yyr644 || yy2arr644 { + if yyr708 || yy2arr708 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy647 := &x.Template - yy647.CodecEncodeSelf(e) + yy713 := &x.Template + yy713.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("template")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy648 := &x.Template - yy648.CodecEncodeSelf(e) + yy714 := &x.Template + yy714.CodecEncodeSelf(e) } - if yyr644 || yy2arr644 { + if yyr708 || yy2arr708 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -7823,25 +8486,25 @@ func (x *DaemonSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym649 := z.DecBinary() - _ = yym649 + yym715 := z.DecBinary() + _ = yym715 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct650 := r.ContainerType() - if yyct650 == codecSelferValueTypeMap1234 { - yyl650 := r.ReadMapStart() - if yyl650 == 0 { + yyct716 := r.ContainerType() + if yyct716 == codecSelferValueTypeMap1234 { + yyl716 := r.ReadMapStart() + if yyl716 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl650, d) + x.codecDecodeSelfFromMap(yyl716, d) } - } else if yyct650 == codecSelferValueTypeArray1234 { - yyl650 := r.ReadArrayStart() - if yyl650 == 0 { + } else if yyct716 == codecSelferValueTypeArray1234 { + yyl716 := r.ReadArrayStart() + if yyl716 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl650, d) + x.codecDecodeSelfFromArray(yyl716, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -7853,12 +8516,12 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys651Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys651Slc - var yyhl651 bool = l >= 0 - for yyj651 := 0; ; yyj651++ { - if yyhl651 { - if yyj651 >= l { + var yys717Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys717Slc + var yyhl717 bool = l >= 0 + for yyj717 := 0; ; yyj717++ { + if yyhl717 { + if yyj717 >= l { break } } else { @@ -7867,10 +8530,10 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys651Slc = r.DecodeBytes(yys651Slc, true, true) - yys651 := string(yys651Slc) + yys717Slc = r.DecodeBytes(yys717Slc, true, true) + yys717 := string(yys717Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys651 { + switch yys717 { case "selector": if r.TryDecodeAsNil() { if x.Selector != nil { @@ -7878,21 +8541,27 @@ func (x *DaemonSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym719 := z.DecBinary() + _ = yym719 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } case "template": if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv653 := &x.Template - yyv653.CodecDecodeSelf(d) + yyv720 := &x.Template + yyv720.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys651) - } // end switch yys651 - } // end for yyj651 + z.DecStructFieldNotFound(-1, yys717) + } // end switch yys717 + } // end for yyj717 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -7900,16 +8569,16 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj654 int - var yyb654 bool - var yyhl654 bool = l >= 0 - yyj654++ - if yyhl654 { - yyb654 = yyj654 > l + var yyj721 int + var yyb721 bool + var yyhl721 bool = l >= 0 + yyj721++ + if yyhl721 { + yyb721 = yyj721 > l } else { - yyb654 = r.CheckBreak() + yyb721 = r.CheckBreak() } - if yyb654 { + if yyb721 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7920,17 +8589,23 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym723 := z.DecBinary() + _ = yym723 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } - yyj654++ - if yyhl654 { - yyb654 = yyj654 > l + yyj721++ + if yyhl721 { + yyb721 = yyj721 > l } else { - yyb654 = r.CheckBreak() + yyb721 = r.CheckBreak() } - if yyb654 { + if yyb721 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -7938,21 +8613,21 @@ func (x *DaemonSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv656 := &x.Template - yyv656.CodecDecodeSelf(d) + yyv724 := &x.Template + yyv724.CodecDecodeSelf(d) } for { - yyj654++ - if yyhl654 { - yyb654 = yyj654 > l + yyj721++ + if yyhl721 { + yyb721 = yyj721 > l } else { - yyb654 = r.CheckBreak() + yyb721 = r.CheckBreak() } - if yyb654 { + if yyb721 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj654-1, "") + z.DecStructFieldNotFound(yyj721-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -7964,33 +8639,33 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym657 := z.EncBinary() - _ = yym657 + yym725 := z.EncBinary() + _ = yym725 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep658 := !z.EncBinary() - yy2arr658 := z.EncBasicHandle().StructToArray - var yyq658 [4]bool - _, _, _ = yysep658, yyq658, yy2arr658 - const yyr658 bool = false - var yynn658 int - if yyr658 || yy2arr658 { + yysep726 := !z.EncBinary() + yy2arr726 := z.EncBasicHandle().StructToArray + var yyq726 [4]bool + _, _, _ = yysep726, yyq726, yy2arr726 + const yyr726 bool = false + var yynn726 int + if yyr726 || yy2arr726 { r.EncodeArrayStart(4) } else { - yynn658 = 4 - for _, b := range yyq658 { + yynn726 = 4 + for _, b := range yyq726 { if b { - yynn658++ + yynn726++ } } - r.EncodeMapStart(yynn658) - yynn658 = 0 + r.EncodeMapStart(yynn726) + yynn726 = 0 } - if yyr658 || yy2arr658 { + if yyr726 || yy2arr726 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym660 := z.EncBinary() - _ = yym660 + yym728 := z.EncBinary() + _ = yym728 if false { } else { r.EncodeInt(int64(x.CurrentNumberScheduled)) @@ -7999,17 +8674,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("currentNumberScheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym661 := z.EncBinary() - _ = yym661 + yym729 := z.EncBinary() + _ = yym729 if false { } else { r.EncodeInt(int64(x.CurrentNumberScheduled)) } } - if yyr658 || yy2arr658 { + if yyr726 || yy2arr726 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym663 := z.EncBinary() - _ = yym663 + yym731 := z.EncBinary() + _ = yym731 if false { } else { r.EncodeInt(int64(x.NumberMisscheduled)) @@ -8018,17 +8693,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("numberMisscheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym664 := z.EncBinary() - _ = yym664 + yym732 := z.EncBinary() + _ = yym732 if false { } else { r.EncodeInt(int64(x.NumberMisscheduled)) } } - if yyr658 || yy2arr658 { + if yyr726 || yy2arr726 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym666 := z.EncBinary() - _ = yym666 + yym734 := z.EncBinary() + _ = yym734 if false { } else { r.EncodeInt(int64(x.DesiredNumberScheduled)) @@ -8037,17 +8712,17 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("desiredNumberScheduled")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym667 := z.EncBinary() - _ = yym667 + yym735 := z.EncBinary() + _ = yym735 if false { } else { r.EncodeInt(int64(x.DesiredNumberScheduled)) } } - if yyr658 || yy2arr658 { + if yyr726 || yy2arr726 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym669 := z.EncBinary() - _ = yym669 + yym737 := z.EncBinary() + _ = yym737 if false { } else { r.EncodeInt(int64(x.NumberReady)) @@ -8056,14 +8731,14 @@ func (x *DaemonSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("numberReady")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym670 := z.EncBinary() - _ = yym670 + yym738 := z.EncBinary() + _ = yym738 if false { } else { r.EncodeInt(int64(x.NumberReady)) } } - if yyr658 || yy2arr658 { + if yyr726 || yy2arr726 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -8076,25 +8751,25 @@ func (x *DaemonSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym671 := z.DecBinary() - _ = yym671 + yym739 := z.DecBinary() + _ = yym739 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct672 := r.ContainerType() - if yyct672 == codecSelferValueTypeMap1234 { - yyl672 := r.ReadMapStart() - if yyl672 == 0 { + yyct740 := r.ContainerType() + if yyct740 == codecSelferValueTypeMap1234 { + yyl740 := r.ReadMapStart() + if yyl740 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl672, d) + x.codecDecodeSelfFromMap(yyl740, d) } - } else if yyct672 == codecSelferValueTypeArray1234 { - yyl672 := r.ReadArrayStart() - if yyl672 == 0 { + } else if yyct740 == codecSelferValueTypeArray1234 { + yyl740 := r.ReadArrayStart() + if yyl740 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl672, d) + x.codecDecodeSelfFromArray(yyl740, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -8106,12 +8781,12 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys673Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys673Slc - var yyhl673 bool = l >= 0 - for yyj673 := 0; ; yyj673++ { - if yyhl673 { - if yyj673 >= l { + var yys741Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys741Slc + var yyhl741 bool = l >= 0 + for yyj741 := 0; ; yyj741++ { + if yyhl741 { + if yyj741 >= l { break } } else { @@ -8120,10 +8795,10 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys673Slc = r.DecodeBytes(yys673Slc, true, true) - yys673 := string(yys673Slc) + yys741Slc = r.DecodeBytes(yys741Slc, true, true) + yys741 := string(yys741Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys673 { + switch yys741 { case "currentNumberScheduled": if r.TryDecodeAsNil() { x.CurrentNumberScheduled = 0 @@ -8149,9 +8824,9 @@ func (x *DaemonSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.NumberReady = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys673) - } // end switch yys673 - } // end for yyj673 + z.DecStructFieldNotFound(-1, yys741) + } // end switch yys741 + } // end for yyj741 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -8159,16 +8834,16 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj678 int - var yyb678 bool - var yyhl678 bool = l >= 0 - yyj678++ - if yyhl678 { - yyb678 = yyj678 > l + var yyj746 int + var yyb746 bool + var yyhl746 bool = l >= 0 + yyj746++ + if yyhl746 { + yyb746 = yyj746 > l } else { - yyb678 = r.CheckBreak() + yyb746 = r.CheckBreak() } - if yyb678 { + if yyb746 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8178,13 +8853,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.CurrentNumberScheduled = int32(r.DecodeInt(32)) } - yyj678++ - if yyhl678 { - yyb678 = yyj678 > l + yyj746++ + if yyhl746 { + yyb746 = yyj746 > l } else { - yyb678 = r.CheckBreak() + yyb746 = r.CheckBreak() } - if yyb678 { + if yyb746 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8194,13 +8869,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.NumberMisscheduled = int32(r.DecodeInt(32)) } - yyj678++ - if yyhl678 { - yyb678 = yyj678 > l + yyj746++ + if yyhl746 { + yyb746 = yyj746 > l } else { - yyb678 = r.CheckBreak() + yyb746 = r.CheckBreak() } - if yyb678 { + if yyb746 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8210,13 +8885,13 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.DesiredNumberScheduled = int32(r.DecodeInt(32)) } - yyj678++ - if yyhl678 { - yyb678 = yyj678 > l + yyj746++ + if yyhl746 { + yyb746 = yyj746 > l } else { - yyb678 = r.CheckBreak() + yyb746 = r.CheckBreak() } - if yyb678 { + if yyb746 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8227,17 +8902,17 @@ func (x *DaemonSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) x.NumberReady = int32(r.DecodeInt(32)) } for { - yyj678++ - if yyhl678 { - yyb678 = yyj678 > l + yyj746++ + if yyhl746 { + yyb746 = yyj746 > l } else { - yyb678 = r.CheckBreak() + yyb746 = r.CheckBreak() } - if yyb678 { + if yyb746 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj678-1, "") + z.DecStructFieldNotFound(yyj746-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -8249,39 +8924,39 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym683 := z.EncBinary() - _ = yym683 + yym751 := z.EncBinary() + _ = yym751 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep684 := !z.EncBinary() - yy2arr684 := z.EncBasicHandle().StructToArray - var yyq684 [5]bool - _, _, _ = yysep684, yyq684, yy2arr684 - const yyr684 bool = false - yyq684[0] = x.Kind != "" - yyq684[1] = x.APIVersion != "" - yyq684[2] = true - yyq684[3] = true - yyq684[4] = true - var yynn684 int - if yyr684 || yy2arr684 { + yysep752 := !z.EncBinary() + yy2arr752 := z.EncBasicHandle().StructToArray + var yyq752 [5]bool + _, _, _ = yysep752, yyq752, yy2arr752 + const yyr752 bool = false + yyq752[0] = x.Kind != "" + yyq752[1] = x.APIVersion != "" + yyq752[2] = true + yyq752[3] = true + yyq752[4] = true + var yynn752 int + if yyr752 || yy2arr752 { r.EncodeArrayStart(5) } else { - yynn684 = 0 - for _, b := range yyq684 { + yynn752 = 0 + for _, b := range yyq752 { if b { - yynn684++ + yynn752++ } } - r.EncodeMapStart(yynn684) - yynn684 = 0 + r.EncodeMapStart(yynn752) + yynn752 = 0 } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq684[0] { - yym686 := z.EncBinary() - _ = yym686 + if yyq752[0] { + yym754 := z.EncBinary() + _ = yym754 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -8290,23 +8965,23 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq684[0] { + if yyq752[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym687 := z.EncBinary() - _ = yym687 + yym755 := z.EncBinary() + _ = yym755 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq684[1] { - yym689 := z.EncBinary() - _ = yym689 + if yyq752[1] { + yym757 := z.EncBinary() + _ = yym757 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -8315,70 +8990,70 @@ func (x *DaemonSet) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq684[1] { + if yyq752[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym690 := z.EncBinary() - _ = yym690 + yym758 := z.EncBinary() + _ = yym758 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq684[2] { - yy692 := &x.ObjectMeta - yy692.CodecEncodeSelf(e) + if yyq752[2] { + yy760 := &x.ObjectMeta + yy760.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq684[2] { + if yyq752[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy693 := &x.ObjectMeta - yy693.CodecEncodeSelf(e) + yy761 := &x.ObjectMeta + yy761.CodecEncodeSelf(e) } } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq684[3] { - yy695 := &x.Spec - yy695.CodecEncodeSelf(e) + if yyq752[3] { + yy763 := &x.Spec + yy763.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq684[3] { + if yyq752[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy696 := &x.Spec - yy696.CodecEncodeSelf(e) + yy764 := &x.Spec + yy764.CodecEncodeSelf(e) } } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq684[4] { - yy698 := &x.Status - yy698.CodecEncodeSelf(e) + if yyq752[4] { + yy766 := &x.Status + yy766.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq684[4] { + if yyq752[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy699 := &x.Status - yy699.CodecEncodeSelf(e) + yy767 := &x.Status + yy767.CodecEncodeSelf(e) } } - if yyr684 || yy2arr684 { + if yyr752 || yy2arr752 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -8391,25 +9066,25 @@ func (x *DaemonSet) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym700 := z.DecBinary() - _ = yym700 + yym768 := z.DecBinary() + _ = yym768 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct701 := r.ContainerType() - if yyct701 == codecSelferValueTypeMap1234 { - yyl701 := r.ReadMapStart() - if yyl701 == 0 { + yyct769 := r.ContainerType() + if yyct769 == codecSelferValueTypeMap1234 { + yyl769 := r.ReadMapStart() + if yyl769 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl701, d) + x.codecDecodeSelfFromMap(yyl769, d) } - } else if yyct701 == codecSelferValueTypeArray1234 { - yyl701 := r.ReadArrayStart() - if yyl701 == 0 { + } else if yyct769 == codecSelferValueTypeArray1234 { + yyl769 := r.ReadArrayStart() + if yyl769 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl701, d) + x.codecDecodeSelfFromArray(yyl769, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -8421,12 +9096,12 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys702Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys702Slc - var yyhl702 bool = l >= 0 - for yyj702 := 0; ; yyj702++ { - if yyhl702 { - if yyj702 >= l { + var yys770Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys770Slc + var yyhl770 bool = l >= 0 + for yyj770 := 0; ; yyj770++ { + if yyhl770 { + if yyj770 >= l { break } } else { @@ -8435,10 +9110,10 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys702Slc = r.DecodeBytes(yys702Slc, true, true) - yys702 := string(yys702Slc) + yys770Slc = r.DecodeBytes(yys770Slc, true, true) + yys770 := string(yys770Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys702 { + switch yys770 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -8455,27 +9130,27 @@ func (x *DaemonSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv705 := &x.ObjectMeta - yyv705.CodecDecodeSelf(d) + yyv773 := &x.ObjectMeta + yyv773.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = DaemonSetSpec{} } else { - yyv706 := &x.Spec - yyv706.CodecDecodeSelf(d) + yyv774 := &x.Spec + yyv774.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = DaemonSetStatus{} } else { - yyv707 := &x.Status - yyv707.CodecDecodeSelf(d) + yyv775 := &x.Status + yyv775.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys702) - } // end switch yys702 - } // end for yyj702 + z.DecStructFieldNotFound(-1, yys770) + } // end switch yys770 + } // end for yyj770 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -8483,16 +9158,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj708 int - var yyb708 bool - var yyhl708 bool = l >= 0 - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + var yyj776 int + var yyb776 bool + var yyhl776 bool = l >= 0 + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8502,13 +9177,13 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8518,13 +9193,13 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8532,16 +9207,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv711 := &x.ObjectMeta - yyv711.CodecDecodeSelf(d) + yyv779 := &x.ObjectMeta + yyv779.CodecDecodeSelf(d) } - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8549,16 +9224,16 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = DaemonSetSpec{} } else { - yyv712 := &x.Spec - yyv712.CodecDecodeSelf(d) + yyv780 := &x.Spec + yyv780.CodecDecodeSelf(d) } - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8566,21 +9241,21 @@ func (x *DaemonSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = DaemonSetStatus{} } else { - yyv713 := &x.Status - yyv713.CodecDecodeSelf(d) + yyv781 := &x.Status + yyv781.CodecDecodeSelf(d) } for { - yyj708++ - if yyhl708 { - yyb708 = yyj708 > l + yyj776++ + if yyhl776 { + yyb776 = yyj776 > l } else { - yyb708 = r.CheckBreak() + yyb776 = r.CheckBreak() } - if yyb708 { + if yyb776 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj708-1, "") + z.DecStructFieldNotFound(yyj776-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -8592,37 +9267,37 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym714 := z.EncBinary() - _ = yym714 + yym782 := z.EncBinary() + _ = yym782 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep715 := !z.EncBinary() - yy2arr715 := z.EncBasicHandle().StructToArray - var yyq715 [4]bool - _, _, _ = yysep715, yyq715, yy2arr715 - const yyr715 bool = false - yyq715[0] = x.Kind != "" - yyq715[1] = x.APIVersion != "" - yyq715[2] = true - var yynn715 int - if yyr715 || yy2arr715 { + yysep783 := !z.EncBinary() + yy2arr783 := z.EncBasicHandle().StructToArray + var yyq783 [4]bool + _, _, _ = yysep783, yyq783, yy2arr783 + const yyr783 bool = false + yyq783[0] = x.Kind != "" + yyq783[1] = x.APIVersion != "" + yyq783[2] = true + var yynn783 int + if yyr783 || yy2arr783 { r.EncodeArrayStart(4) } else { - yynn715 = 1 - for _, b := range yyq715 { + yynn783 = 1 + for _, b := range yyq783 { if b { - yynn715++ + yynn783++ } } - r.EncodeMapStart(yynn715) - yynn715 = 0 + r.EncodeMapStart(yynn783) + yynn783 = 0 } - if yyr715 || yy2arr715 { + if yyr783 || yy2arr783 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq715[0] { - yym717 := z.EncBinary() - _ = yym717 + if yyq783[0] { + yym785 := z.EncBinary() + _ = yym785 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -8631,23 +9306,23 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq715[0] { + if yyq783[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym718 := z.EncBinary() - _ = yym718 + yym786 := z.EncBinary() + _ = yym786 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr715 || yy2arr715 { + if yyr783 || yy2arr783 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq715[1] { - yym720 := z.EncBinary() - _ = yym720 + if yyq783[1] { + yym788 := z.EncBinary() + _ = yym788 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -8656,54 +9331,54 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq715[1] { + if yyq783[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym721 := z.EncBinary() - _ = yym721 + yym789 := z.EncBinary() + _ = yym789 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr715 || yy2arr715 { + if yyr783 || yy2arr783 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq715[2] { - yy723 := &x.ListMeta - yym724 := z.EncBinary() - _ = yym724 + if yyq783[2] { + yy791 := &x.ListMeta + yym792 := z.EncBinary() + _ = yym792 if false { - } else if z.HasExtensions() && z.EncExt(yy723) { + } else if z.HasExtensions() && z.EncExt(yy791) { } else { - z.EncFallback(yy723) + z.EncFallback(yy791) } } else { r.EncodeNil() } } else { - if yyq715[2] { + if yyq783[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy725 := &x.ListMeta - yym726 := z.EncBinary() - _ = yym726 + yy793 := &x.ListMeta + yym794 := z.EncBinary() + _ = yym794 if false { - } else if z.HasExtensions() && z.EncExt(yy725) { + } else if z.HasExtensions() && z.EncExt(yy793) { } else { - z.EncFallback(yy725) + z.EncFallback(yy793) } } } - if yyr715 || yy2arr715 { + if yyr783 || yy2arr783 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym728 := z.EncBinary() - _ = yym728 + yym796 := z.EncBinary() + _ = yym796 if false { } else { h.encSliceDaemonSet(([]DaemonSet)(x.Items), e) @@ -8716,15 +9391,15 @@ func (x *DaemonSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym729 := z.EncBinary() - _ = yym729 + yym797 := z.EncBinary() + _ = yym797 if false { } else { h.encSliceDaemonSet(([]DaemonSet)(x.Items), e) } } } - if yyr715 || yy2arr715 { + if yyr783 || yy2arr783 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -8737,25 +9412,25 @@ func (x *DaemonSetList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym730 := z.DecBinary() - _ = yym730 + yym798 := z.DecBinary() + _ = yym798 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct731 := r.ContainerType() - if yyct731 == codecSelferValueTypeMap1234 { - yyl731 := r.ReadMapStart() - if yyl731 == 0 { + yyct799 := r.ContainerType() + if yyct799 == codecSelferValueTypeMap1234 { + yyl799 := r.ReadMapStart() + if yyl799 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl731, d) + x.codecDecodeSelfFromMap(yyl799, d) } - } else if yyct731 == codecSelferValueTypeArray1234 { - yyl731 := r.ReadArrayStart() - if yyl731 == 0 { + } else if yyct799 == codecSelferValueTypeArray1234 { + yyl799 := r.ReadArrayStart() + if yyl799 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl731, d) + x.codecDecodeSelfFromArray(yyl799, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -8767,12 +9442,12 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys732Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys732Slc - var yyhl732 bool = l >= 0 - for yyj732 := 0; ; yyj732++ { - if yyhl732 { - if yyj732 >= l { + var yys800Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys800Slc + var yyhl800 bool = l >= 0 + for yyj800 := 0; ; yyj800++ { + if yyhl800 { + if yyj800 >= l { break } } else { @@ -8781,10 +9456,10 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys732Slc = r.DecodeBytes(yys732Slc, true, true) - yys732 := string(yys732Slc) + yys800Slc = r.DecodeBytes(yys800Slc, true, true) + yys800 := string(yys800Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys732 { + switch yys800 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -8801,31 +9476,31 @@ func (x *DaemonSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv735 := &x.ListMeta - yym736 := z.DecBinary() - _ = yym736 + yyv803 := &x.ListMeta + yym804 := z.DecBinary() + _ = yym804 if false { - } else if z.HasExtensions() && z.DecExt(yyv735) { + } else if z.HasExtensions() && z.DecExt(yyv803) { } else { - z.DecFallback(yyv735, false) + z.DecFallback(yyv803, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv737 := &x.Items - yym738 := z.DecBinary() - _ = yym738 + yyv805 := &x.Items + yym806 := z.DecBinary() + _ = yym806 if false { } else { - h.decSliceDaemonSet((*[]DaemonSet)(yyv737), d) + h.decSliceDaemonSet((*[]DaemonSet)(yyv805), d) } } default: - z.DecStructFieldNotFound(-1, yys732) - } // end switch yys732 - } // end for yyj732 + z.DecStructFieldNotFound(-1, yys800) + } // end switch yys800 + } // end for yyj800 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -8833,16 +9508,16 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj739 int - var yyb739 bool - var yyhl739 bool = l >= 0 - yyj739++ - if yyhl739 { - yyb739 = yyj739 > l + var yyj807 int + var yyb807 bool + var yyhl807 bool = l >= 0 + yyj807++ + if yyhl807 { + yyb807 = yyj807 > l } else { - yyb739 = r.CheckBreak() + yyb807 = r.CheckBreak() } - if yyb739 { + if yyb807 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8852,13 +9527,13 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj739++ - if yyhl739 { - yyb739 = yyj739 > l + yyj807++ + if yyhl807 { + yyb807 = yyj807 > l } else { - yyb739 = r.CheckBreak() + yyb807 = r.CheckBreak() } - if yyb739 { + if yyb807 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8868,13 +9543,13 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj739++ - if yyhl739 { - yyb739 = yyj739 > l + yyj807++ + if yyhl807 { + yyb807 = yyj807 > l } else { - yyb739 = r.CheckBreak() + yyb807 = r.CheckBreak() } - if yyb739 { + if yyb807 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8882,22 +9557,22 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv742 := &x.ListMeta - yym743 := z.DecBinary() - _ = yym743 + yyv810 := &x.ListMeta + yym811 := z.DecBinary() + _ = yym811 if false { - } else if z.HasExtensions() && z.DecExt(yyv742) { + } else if z.HasExtensions() && z.DecExt(yyv810) { } else { - z.DecFallback(yyv742, false) + z.DecFallback(yyv810, false) } } - yyj739++ - if yyhl739 { - yyb739 = yyj739 > l + yyj807++ + if yyhl807 { + yyb807 = yyj807 > l } else { - yyb739 = r.CheckBreak() + yyb807 = r.CheckBreak() } - if yyb739 { + if yyb807 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -8905,26 +9580,26 @@ func (x *DaemonSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv744 := &x.Items - yym745 := z.DecBinary() - _ = yym745 + yyv812 := &x.Items + yym813 := z.DecBinary() + _ = yym813 if false { } else { - h.decSliceDaemonSet((*[]DaemonSet)(yyv744), d) + h.decSliceDaemonSet((*[]DaemonSet)(yyv812), d) } } for { - yyj739++ - if yyhl739 { - yyb739 = yyj739 > l + yyj807++ + if yyhl807 { + yyb807 = yyj807 > l } else { - yyb739 = r.CheckBreak() + yyb807 = r.CheckBreak() } - if yyb739 { + if yyb807 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj739-1, "") + z.DecStructFieldNotFound(yyj807-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -8936,37 +9611,37 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym746 := z.EncBinary() - _ = yym746 + yym814 := z.EncBinary() + _ = yym814 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep747 := !z.EncBinary() - yy2arr747 := z.EncBasicHandle().StructToArray - var yyq747 [4]bool - _, _, _ = yysep747, yyq747, yy2arr747 - const yyr747 bool = false - yyq747[0] = x.Kind != "" - yyq747[1] = x.APIVersion != "" - yyq747[2] = true - var yynn747 int - if yyr747 || yy2arr747 { + yysep815 := !z.EncBinary() + yy2arr815 := z.EncBasicHandle().StructToArray + var yyq815 [4]bool + _, _, _ = yysep815, yyq815, yy2arr815 + const yyr815 bool = false + yyq815[0] = x.Kind != "" + yyq815[1] = x.APIVersion != "" + yyq815[2] = true + var yynn815 int + if yyr815 || yy2arr815 { r.EncodeArrayStart(4) } else { - yynn747 = 1 - for _, b := range yyq747 { + yynn815 = 1 + for _, b := range yyq815 { if b { - yynn747++ + yynn815++ } } - r.EncodeMapStart(yynn747) - yynn747 = 0 + r.EncodeMapStart(yynn815) + yynn815 = 0 } - if yyr747 || yy2arr747 { + if yyr815 || yy2arr815 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq747[0] { - yym749 := z.EncBinary() - _ = yym749 + if yyq815[0] { + yym817 := z.EncBinary() + _ = yym817 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -8975,23 +9650,23 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq747[0] { + if yyq815[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym750 := z.EncBinary() - _ = yym750 + yym818 := z.EncBinary() + _ = yym818 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr747 || yy2arr747 { + if yyr815 || yy2arr815 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq747[1] { - yym752 := z.EncBinary() - _ = yym752 + if yyq815[1] { + yym820 := z.EncBinary() + _ = yym820 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -9000,54 +9675,54 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq747[1] { + if yyq815[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym753 := z.EncBinary() - _ = yym753 + yym821 := z.EncBinary() + _ = yym821 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr747 || yy2arr747 { + if yyr815 || yy2arr815 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq747[2] { - yy755 := &x.ListMeta - yym756 := z.EncBinary() - _ = yym756 + if yyq815[2] { + yy823 := &x.ListMeta + yym824 := z.EncBinary() + _ = yym824 if false { - } else if z.HasExtensions() && z.EncExt(yy755) { + } else if z.HasExtensions() && z.EncExt(yy823) { } else { - z.EncFallback(yy755) + z.EncFallback(yy823) } } else { r.EncodeNil() } } else { - if yyq747[2] { + if yyq815[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy757 := &x.ListMeta - yym758 := z.EncBinary() - _ = yym758 + yy825 := &x.ListMeta + yym826 := z.EncBinary() + _ = yym826 if false { - } else if z.HasExtensions() && z.EncExt(yy757) { + } else if z.HasExtensions() && z.EncExt(yy825) { } else { - z.EncFallback(yy757) + z.EncFallback(yy825) } } } - if yyr747 || yy2arr747 { + if yyr815 || yy2arr815 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym760 := z.EncBinary() - _ = yym760 + yym828 := z.EncBinary() + _ = yym828 if false { } else { h.encSliceThirdPartyResourceData(([]ThirdPartyResourceData)(x.Items), e) @@ -9060,15 +9735,15 @@ func (x *ThirdPartyResourceDataList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym761 := z.EncBinary() - _ = yym761 + yym829 := z.EncBinary() + _ = yym829 if false { } else { h.encSliceThirdPartyResourceData(([]ThirdPartyResourceData)(x.Items), e) } } } - if yyr747 || yy2arr747 { + if yyr815 || yy2arr815 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9081,25 +9756,25 @@ func (x *ThirdPartyResourceDataList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym762 := z.DecBinary() - _ = yym762 + yym830 := z.DecBinary() + _ = yym830 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct763 := r.ContainerType() - if yyct763 == codecSelferValueTypeMap1234 { - yyl763 := r.ReadMapStart() - if yyl763 == 0 { + yyct831 := r.ContainerType() + if yyct831 == codecSelferValueTypeMap1234 { + yyl831 := r.ReadMapStart() + if yyl831 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl763, d) + x.codecDecodeSelfFromMap(yyl831, d) } - } else if yyct763 == codecSelferValueTypeArray1234 { - yyl763 := r.ReadArrayStart() - if yyl763 == 0 { + } else if yyct831 == codecSelferValueTypeArray1234 { + yyl831 := r.ReadArrayStart() + if yyl831 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl763, d) + x.codecDecodeSelfFromArray(yyl831, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9111,12 +9786,12 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys764Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys764Slc - var yyhl764 bool = l >= 0 - for yyj764 := 0; ; yyj764++ { - if yyhl764 { - if yyj764 >= l { + var yys832Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys832Slc + var yyhl832 bool = l >= 0 + for yyj832 := 0; ; yyj832++ { + if yyhl832 { + if yyj832 >= l { break } } else { @@ -9125,10 +9800,10 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys764Slc = r.DecodeBytes(yys764Slc, true, true) - yys764 := string(yys764Slc) + yys832Slc = r.DecodeBytes(yys832Slc, true, true) + yys832 := string(yys832Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys764 { + switch yys832 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -9145,31 +9820,31 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromMap(l int, d *codec1978. if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv767 := &x.ListMeta - yym768 := z.DecBinary() - _ = yym768 + yyv835 := &x.ListMeta + yym836 := z.DecBinary() + _ = yym836 if false { - } else if z.HasExtensions() && z.DecExt(yyv767) { + } else if z.HasExtensions() && z.DecExt(yyv835) { } else { - z.DecFallback(yyv767, false) + z.DecFallback(yyv835, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv769 := &x.Items - yym770 := z.DecBinary() - _ = yym770 + yyv837 := &x.Items + yym838 := z.DecBinary() + _ = yym838 if false { } else { - h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv769), d) + h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv837), d) } } default: - z.DecStructFieldNotFound(-1, yys764) - } // end switch yys764 - } // end for yyj764 + z.DecStructFieldNotFound(-1, yys832) + } // end switch yys832 + } // end for yyj832 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -9177,16 +9852,16 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj771 int - var yyb771 bool - var yyhl771 bool = l >= 0 - yyj771++ - if yyhl771 { - yyb771 = yyj771 > l + var yyj839 int + var yyb839 bool + var yyhl839 bool = l >= 0 + yyj839++ + if yyhl839 { + yyb839 = yyj839 > l } else { - yyb771 = r.CheckBreak() + yyb839 = r.CheckBreak() } - if yyb771 { + if yyb839 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9196,13 +9871,13 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 } else { x.Kind = string(r.DecodeString()) } - yyj771++ - if yyhl771 { - yyb771 = yyj771 > l + yyj839++ + if yyhl839 { + yyb839 = yyj839 > l } else { - yyb771 = r.CheckBreak() + yyb839 = r.CheckBreak() } - if yyb771 { + if yyb839 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9212,13 +9887,13 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 } else { x.APIVersion = string(r.DecodeString()) } - yyj771++ - if yyhl771 { - yyb771 = yyj771 > l + yyj839++ + if yyhl839 { + yyb839 = yyj839 > l } else { - yyb771 = r.CheckBreak() + yyb839 = r.CheckBreak() } - if yyb771 { + if yyb839 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9226,22 +9901,22 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv774 := &x.ListMeta - yym775 := z.DecBinary() - _ = yym775 + yyv842 := &x.ListMeta + yym843 := z.DecBinary() + _ = yym843 if false { - } else if z.HasExtensions() && z.DecExt(yyv774) { + } else if z.HasExtensions() && z.DecExt(yyv842) { } else { - z.DecFallback(yyv774, false) + z.DecFallback(yyv842, false) } } - yyj771++ - if yyhl771 { - yyb771 = yyj771 > l + yyj839++ + if yyhl839 { + yyb839 = yyj839 > l } else { - yyb771 = r.CheckBreak() + yyb839 = r.CheckBreak() } - if yyb771 { + if yyb839 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9249,26 +9924,26 @@ func (x *ThirdPartyResourceDataList) codecDecodeSelfFromArray(l int, d *codec197 if r.TryDecodeAsNil() { x.Items = nil } else { - yyv776 := &x.Items - yym777 := z.DecBinary() - _ = yym777 + yyv844 := &x.Items + yym845 := z.DecBinary() + _ = yym845 if false { } else { - h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv776), d) + h.decSliceThirdPartyResourceData((*[]ThirdPartyResourceData)(yyv844), d) } } for { - yyj771++ - if yyhl771 { - yyb771 = yyj771 > l + yyj839++ + if yyhl839 { + yyb839 = yyj839 > l } else { - yyb771 = r.CheckBreak() + yyb839 = r.CheckBreak() } - if yyb771 { + if yyb839 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj771-1, "") + z.DecStructFieldNotFound(yyj839-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9280,39 +9955,39 @@ func (x *Job) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym778 := z.EncBinary() - _ = yym778 + yym846 := z.EncBinary() + _ = yym846 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep779 := !z.EncBinary() - yy2arr779 := z.EncBasicHandle().StructToArray - var yyq779 [5]bool - _, _, _ = yysep779, yyq779, yy2arr779 - const yyr779 bool = false - yyq779[0] = x.Kind != "" - yyq779[1] = x.APIVersion != "" - yyq779[2] = true - yyq779[3] = true - yyq779[4] = true - var yynn779 int - if yyr779 || yy2arr779 { + yysep847 := !z.EncBinary() + yy2arr847 := z.EncBasicHandle().StructToArray + var yyq847 [5]bool + _, _, _ = yysep847, yyq847, yy2arr847 + const yyr847 bool = false + yyq847[0] = x.Kind != "" + yyq847[1] = x.APIVersion != "" + yyq847[2] = true + yyq847[3] = true + yyq847[4] = true + var yynn847 int + if yyr847 || yy2arr847 { r.EncodeArrayStart(5) } else { - yynn779 = 0 - for _, b := range yyq779 { + yynn847 = 0 + for _, b := range yyq847 { if b { - yynn779++ + yynn847++ } } - r.EncodeMapStart(yynn779) - yynn779 = 0 + r.EncodeMapStart(yynn847) + yynn847 = 0 } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq779[0] { - yym781 := z.EncBinary() - _ = yym781 + if yyq847[0] { + yym849 := z.EncBinary() + _ = yym849 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -9321,23 +9996,23 @@ func (x *Job) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq779[0] { + if yyq847[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym782 := z.EncBinary() - _ = yym782 + yym850 := z.EncBinary() + _ = yym850 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq779[1] { - yym784 := z.EncBinary() - _ = yym784 + if yyq847[1] { + yym852 := z.EncBinary() + _ = yym852 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -9346,70 +10021,70 @@ func (x *Job) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq779[1] { + if yyq847[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym785 := z.EncBinary() - _ = yym785 + yym853 := z.EncBinary() + _ = yym853 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq779[2] { - yy787 := &x.ObjectMeta - yy787.CodecEncodeSelf(e) + if yyq847[2] { + yy855 := &x.ObjectMeta + yy855.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq779[2] { + if yyq847[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy788 := &x.ObjectMeta - yy788.CodecEncodeSelf(e) + yy856 := &x.ObjectMeta + yy856.CodecEncodeSelf(e) } } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq779[3] { - yy790 := &x.Spec - yy790.CodecEncodeSelf(e) + if yyq847[3] { + yy858 := &x.Spec + yy858.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq779[3] { + if yyq847[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy791 := &x.Spec - yy791.CodecEncodeSelf(e) + yy859 := &x.Spec + yy859.CodecEncodeSelf(e) } } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq779[4] { - yy793 := &x.Status - yy793.CodecEncodeSelf(e) + if yyq847[4] { + yy861 := &x.Status + yy861.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq779[4] { + if yyq847[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy794 := &x.Status - yy794.CodecEncodeSelf(e) + yy862 := &x.Status + yy862.CodecEncodeSelf(e) } } - if yyr779 || yy2arr779 { + if yyr847 || yy2arr847 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9422,25 +10097,25 @@ func (x *Job) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym795 := z.DecBinary() - _ = yym795 + yym863 := z.DecBinary() + _ = yym863 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct796 := r.ContainerType() - if yyct796 == codecSelferValueTypeMap1234 { - yyl796 := r.ReadMapStart() - if yyl796 == 0 { + yyct864 := r.ContainerType() + if yyct864 == codecSelferValueTypeMap1234 { + yyl864 := r.ReadMapStart() + if yyl864 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl796, d) + x.codecDecodeSelfFromMap(yyl864, d) } - } else if yyct796 == codecSelferValueTypeArray1234 { - yyl796 := r.ReadArrayStart() - if yyl796 == 0 { + } else if yyct864 == codecSelferValueTypeArray1234 { + yyl864 := r.ReadArrayStart() + if yyl864 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl796, d) + x.codecDecodeSelfFromArray(yyl864, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9452,12 +10127,12 @@ func (x *Job) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys797Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys797Slc - var yyhl797 bool = l >= 0 - for yyj797 := 0; ; yyj797++ { - if yyhl797 { - if yyj797 >= l { + var yys865Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys865Slc + var yyhl865 bool = l >= 0 + for yyj865 := 0; ; yyj865++ { + if yyhl865 { + if yyj865 >= l { break } } else { @@ -9466,10 +10141,10 @@ func (x *Job) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys797Slc = r.DecodeBytes(yys797Slc, true, true) - yys797 := string(yys797Slc) + yys865Slc = r.DecodeBytes(yys865Slc, true, true) + yys865 := string(yys865Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys797 { + switch yys865 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -9486,27 +10161,27 @@ func (x *Job) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv800 := &x.ObjectMeta - yyv800.CodecDecodeSelf(d) + yyv868 := &x.ObjectMeta + yyv868.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = JobSpec{} } else { - yyv801 := &x.Spec - yyv801.CodecDecodeSelf(d) + yyv869 := &x.Spec + yyv869.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = JobStatus{} } else { - yyv802 := &x.Status - yyv802.CodecDecodeSelf(d) + yyv870 := &x.Status + yyv870.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys797) - } // end switch yys797 - } // end for yyj797 + z.DecStructFieldNotFound(-1, yys865) + } // end switch yys865 + } // end for yyj865 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -9514,16 +10189,16 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj803 int - var yyb803 bool - var yyhl803 bool = l >= 0 - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + var yyj871 int + var yyb871 bool + var yyhl871 bool = l >= 0 + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9533,13 +10208,13 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9549,13 +10224,13 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9563,16 +10238,16 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv806 := &x.ObjectMeta - yyv806.CodecDecodeSelf(d) + yyv874 := &x.ObjectMeta + yyv874.CodecDecodeSelf(d) } - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9580,16 +10255,16 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = JobSpec{} } else { - yyv807 := &x.Spec - yyv807.CodecDecodeSelf(d) + yyv875 := &x.Spec + yyv875.CodecDecodeSelf(d) } - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9597,21 +10272,21 @@ func (x *Job) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = JobStatus{} } else { - yyv808 := &x.Status - yyv808.CodecDecodeSelf(d) + yyv876 := &x.Status + yyv876.CodecDecodeSelf(d) } for { - yyj803++ - if yyhl803 { - yyb803 = yyj803 > l + yyj871++ + if yyhl871 { + yyb871 = yyj871 > l } else { - yyb803 = r.CheckBreak() + yyb871 = r.CheckBreak() } - if yyb803 { + if yyb871 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj803-1, "") + z.DecStructFieldNotFound(yyj871-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9623,37 +10298,37 @@ func (x *JobList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym809 := z.EncBinary() - _ = yym809 + yym877 := z.EncBinary() + _ = yym877 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep810 := !z.EncBinary() - yy2arr810 := z.EncBasicHandle().StructToArray - var yyq810 [4]bool - _, _, _ = yysep810, yyq810, yy2arr810 - const yyr810 bool = false - yyq810[0] = x.Kind != "" - yyq810[1] = x.APIVersion != "" - yyq810[2] = true - var yynn810 int - if yyr810 || yy2arr810 { + yysep878 := !z.EncBinary() + yy2arr878 := z.EncBasicHandle().StructToArray + var yyq878 [4]bool + _, _, _ = yysep878, yyq878, yy2arr878 + const yyr878 bool = false + yyq878[0] = x.Kind != "" + yyq878[1] = x.APIVersion != "" + yyq878[2] = true + var yynn878 int + if yyr878 || yy2arr878 { r.EncodeArrayStart(4) } else { - yynn810 = 1 - for _, b := range yyq810 { + yynn878 = 1 + for _, b := range yyq878 { if b { - yynn810++ + yynn878++ } } - r.EncodeMapStart(yynn810) - yynn810 = 0 + r.EncodeMapStart(yynn878) + yynn878 = 0 } - if yyr810 || yy2arr810 { + if yyr878 || yy2arr878 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq810[0] { - yym812 := z.EncBinary() - _ = yym812 + if yyq878[0] { + yym880 := z.EncBinary() + _ = yym880 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -9662,23 +10337,23 @@ func (x *JobList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq810[0] { + if yyq878[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym813 := z.EncBinary() - _ = yym813 + yym881 := z.EncBinary() + _ = yym881 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr810 || yy2arr810 { + if yyr878 || yy2arr878 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq810[1] { - yym815 := z.EncBinary() - _ = yym815 + if yyq878[1] { + yym883 := z.EncBinary() + _ = yym883 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -9687,54 +10362,54 @@ func (x *JobList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq810[1] { + if yyq878[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym816 := z.EncBinary() - _ = yym816 + yym884 := z.EncBinary() + _ = yym884 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr810 || yy2arr810 { + if yyr878 || yy2arr878 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq810[2] { - yy818 := &x.ListMeta - yym819 := z.EncBinary() - _ = yym819 + if yyq878[2] { + yy886 := &x.ListMeta + yym887 := z.EncBinary() + _ = yym887 if false { - } else if z.HasExtensions() && z.EncExt(yy818) { + } else if z.HasExtensions() && z.EncExt(yy886) { } else { - z.EncFallback(yy818) + z.EncFallback(yy886) } } else { r.EncodeNil() } } else { - if yyq810[2] { + if yyq878[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy820 := &x.ListMeta - yym821 := z.EncBinary() - _ = yym821 + yy888 := &x.ListMeta + yym889 := z.EncBinary() + _ = yym889 if false { - } else if z.HasExtensions() && z.EncExt(yy820) { + } else if z.HasExtensions() && z.EncExt(yy888) { } else { - z.EncFallback(yy820) + z.EncFallback(yy888) } } } - if yyr810 || yy2arr810 { + if yyr878 || yy2arr878 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym823 := z.EncBinary() - _ = yym823 + yym891 := z.EncBinary() + _ = yym891 if false { } else { h.encSliceJob(([]Job)(x.Items), e) @@ -9747,15 +10422,15 @@ func (x *JobList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym824 := z.EncBinary() - _ = yym824 + yym892 := z.EncBinary() + _ = yym892 if false { } else { h.encSliceJob(([]Job)(x.Items), e) } } } - if yyr810 || yy2arr810 { + if yyr878 || yy2arr878 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -9768,25 +10443,25 @@ func (x *JobList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym825 := z.DecBinary() - _ = yym825 + yym893 := z.DecBinary() + _ = yym893 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct826 := r.ContainerType() - if yyct826 == codecSelferValueTypeMap1234 { - yyl826 := r.ReadMapStart() - if yyl826 == 0 { + yyct894 := r.ContainerType() + if yyct894 == codecSelferValueTypeMap1234 { + yyl894 := r.ReadMapStart() + if yyl894 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl826, d) + x.codecDecodeSelfFromMap(yyl894, d) } - } else if yyct826 == codecSelferValueTypeArray1234 { - yyl826 := r.ReadArrayStart() - if yyl826 == 0 { + } else if yyct894 == codecSelferValueTypeArray1234 { + yyl894 := r.ReadArrayStart() + if yyl894 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl826, d) + x.codecDecodeSelfFromArray(yyl894, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -9798,12 +10473,12 @@ func (x *JobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys827Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys827Slc - var yyhl827 bool = l >= 0 - for yyj827 := 0; ; yyj827++ { - if yyhl827 { - if yyj827 >= l { + var yys895Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys895Slc + var yyhl895 bool = l >= 0 + for yyj895 := 0; ; yyj895++ { + if yyhl895 { + if yyj895 >= l { break } } else { @@ -9812,10 +10487,10 @@ func (x *JobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys827Slc = r.DecodeBytes(yys827Slc, true, true) - yys827 := string(yys827Slc) + yys895Slc = r.DecodeBytes(yys895Slc, true, true) + yys895 := string(yys895Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys827 { + switch yys895 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -9832,31 +10507,31 @@ func (x *JobList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv830 := &x.ListMeta - yym831 := z.DecBinary() - _ = yym831 + yyv898 := &x.ListMeta + yym899 := z.DecBinary() + _ = yym899 if false { - } else if z.HasExtensions() && z.DecExt(yyv830) { + } else if z.HasExtensions() && z.DecExt(yyv898) { } else { - z.DecFallback(yyv830, false) + z.DecFallback(yyv898, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv832 := &x.Items - yym833 := z.DecBinary() - _ = yym833 + yyv900 := &x.Items + yym901 := z.DecBinary() + _ = yym901 if false { } else { - h.decSliceJob((*[]Job)(yyv832), d) + h.decSliceJob((*[]Job)(yyv900), d) } } default: - z.DecStructFieldNotFound(-1, yys827) - } // end switch yys827 - } // end for yyj827 + z.DecStructFieldNotFound(-1, yys895) + } // end switch yys895 + } // end for yyj895 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -9864,16 +10539,16 @@ func (x *JobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj834 int - var yyb834 bool - var yyhl834 bool = l >= 0 - yyj834++ - if yyhl834 { - yyb834 = yyj834 > l + var yyj902 int + var yyb902 bool + var yyhl902 bool = l >= 0 + yyj902++ + if yyhl902 { + yyb902 = yyj902 > l } else { - yyb834 = r.CheckBreak() + yyb902 = r.CheckBreak() } - if yyb834 { + if yyb902 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9883,13 +10558,13 @@ func (x *JobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj834++ - if yyhl834 { - yyb834 = yyj834 > l + yyj902++ + if yyhl902 { + yyb902 = yyj902 > l } else { - yyb834 = r.CheckBreak() + yyb902 = r.CheckBreak() } - if yyb834 { + if yyb902 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9899,13 +10574,13 @@ func (x *JobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj834++ - if yyhl834 { - yyb834 = yyj834 > l + yyj902++ + if yyhl902 { + yyb902 = yyj902 > l } else { - yyb834 = r.CheckBreak() + yyb902 = r.CheckBreak() } - if yyb834 { + if yyb902 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9913,22 +10588,22 @@ func (x *JobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv837 := &x.ListMeta - yym838 := z.DecBinary() - _ = yym838 + yyv905 := &x.ListMeta + yym906 := z.DecBinary() + _ = yym906 if false { - } else if z.HasExtensions() && z.DecExt(yyv837) { + } else if z.HasExtensions() && z.DecExt(yyv905) { } else { - z.DecFallback(yyv837, false) + z.DecFallback(yyv905, false) } } - yyj834++ - if yyhl834 { - yyb834 = yyj834 > l + yyj902++ + if yyhl902 { + yyb902 = yyj902 > l } else { - yyb834 = r.CheckBreak() + yyb902 = r.CheckBreak() } - if yyb834 { + if yyb902 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -9936,26 +10611,26 @@ func (x *JobList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv839 := &x.Items - yym840 := z.DecBinary() - _ = yym840 + yyv907 := &x.Items + yym908 := z.DecBinary() + _ = yym908 if false { } else { - h.decSliceJob((*[]Job)(yyv839), d) + h.decSliceJob((*[]Job)(yyv907), d) } } for { - yyj834++ - if yyhl834 { - yyb834 = yyj834 > l + yyj902++ + if yyhl902 { + yyb902 = yyj902 > l } else { - yyb834 = r.CheckBreak() + yyb902 = r.CheckBreak() } - if yyb834 { + if yyb902 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj834-1, "") + z.DecStructFieldNotFound(yyj902-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -9967,209 +10642,221 @@ func (x *JobSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym841 := z.EncBinary() - _ = yym841 + yym909 := z.EncBinary() + _ = yym909 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep842 := !z.EncBinary() - yy2arr842 := z.EncBasicHandle().StructToArray - var yyq842 [6]bool - _, _, _ = yysep842, yyq842, yy2arr842 - const yyr842 bool = false - yyq842[0] = x.Parallelism != nil - yyq842[1] = x.Completions != nil - yyq842[2] = x.ActiveDeadlineSeconds != nil - yyq842[3] = x.Selector != nil - yyq842[4] = x.AutoSelector != nil - var yynn842 int - if yyr842 || yy2arr842 { + yysep910 := !z.EncBinary() + yy2arr910 := z.EncBasicHandle().StructToArray + var yyq910 [6]bool + _, _, _ = yysep910, yyq910, yy2arr910 + const yyr910 bool = false + yyq910[0] = x.Parallelism != nil + yyq910[1] = x.Completions != nil + yyq910[2] = x.ActiveDeadlineSeconds != nil + yyq910[3] = x.Selector != nil + yyq910[4] = x.AutoSelector != nil + var yynn910 int + if yyr910 || yy2arr910 { r.EncodeArrayStart(6) } else { - yynn842 = 1 - for _, b := range yyq842 { + yynn910 = 1 + for _, b := range yyq910 { if b { - yynn842++ + yynn910++ } } - r.EncodeMapStart(yynn842) - yynn842 = 0 + r.EncodeMapStart(yynn910) + yynn910 = 0 } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq842[0] { + if yyq910[0] { if x.Parallelism == nil { r.EncodeNil() } else { - yy844 := *x.Parallelism - yym845 := z.EncBinary() - _ = yym845 + yy912 := *x.Parallelism + yym913 := z.EncBinary() + _ = yym913 if false { } else { - r.EncodeInt(int64(yy844)) + r.EncodeInt(int64(yy912)) } } } else { r.EncodeNil() } } else { - if yyq842[0] { + if yyq910[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("parallelism")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Parallelism == nil { r.EncodeNil() } else { - yy846 := *x.Parallelism - yym847 := z.EncBinary() - _ = yym847 + yy914 := *x.Parallelism + yym915 := z.EncBinary() + _ = yym915 if false { } else { - r.EncodeInt(int64(yy846)) + r.EncodeInt(int64(yy914)) } } } } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq842[1] { + if yyq910[1] { if x.Completions == nil { r.EncodeNil() } else { - yy849 := *x.Completions - yym850 := z.EncBinary() - _ = yym850 + yy917 := *x.Completions + yym918 := z.EncBinary() + _ = yym918 if false { } else { - r.EncodeInt(int64(yy849)) + r.EncodeInt(int64(yy917)) } } } else { r.EncodeNil() } } else { - if yyq842[1] { + if yyq910[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("completions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Completions == nil { r.EncodeNil() } else { - yy851 := *x.Completions - yym852 := z.EncBinary() - _ = yym852 + yy919 := *x.Completions + yym920 := z.EncBinary() + _ = yym920 if false { } else { - r.EncodeInt(int64(yy851)) + r.EncodeInt(int64(yy919)) } } } } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq842[2] { + if yyq910[2] { if x.ActiveDeadlineSeconds == nil { r.EncodeNil() } else { - yy854 := *x.ActiveDeadlineSeconds - yym855 := z.EncBinary() - _ = yym855 + yy922 := *x.ActiveDeadlineSeconds + yym923 := z.EncBinary() + _ = yym923 if false { } else { - r.EncodeInt(int64(yy854)) + r.EncodeInt(int64(yy922)) } } } else { r.EncodeNil() } } else { - if yyq842[2] { + if yyq910[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("activeDeadlineSeconds")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.ActiveDeadlineSeconds == nil { r.EncodeNil() } else { - yy856 := *x.ActiveDeadlineSeconds - yym857 := z.EncBinary() - _ = yym857 + yy924 := *x.ActiveDeadlineSeconds + yym925 := z.EncBinary() + _ = yym925 if false { } else { - r.EncodeInt(int64(yy856)) + r.EncodeInt(int64(yy924)) } } } } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq842[3] { + if yyq910[3] { if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym927 := z.EncBinary() + _ = yym927 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } else { r.EncodeNil() } } else { - if yyq842[3] { + if yyq910[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("selector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Selector == nil { r.EncodeNil() } else { - x.Selector.CodecEncodeSelf(e) + yym928 := z.EncBinary() + _ = yym928 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } } } } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq842[4] { + if yyq910[4] { if x.AutoSelector == nil { r.EncodeNil() } else { - yy860 := *x.AutoSelector - yym861 := z.EncBinary() - _ = yym861 + yy930 := *x.AutoSelector + yym931 := z.EncBinary() + _ = yym931 if false { } else { - r.EncodeBool(bool(yy860)) + r.EncodeBool(bool(yy930)) } } } else { r.EncodeNil() } } else { - if yyq842[4] { + if yyq910[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("autoSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.AutoSelector == nil { r.EncodeNil() } else { - yy862 := *x.AutoSelector - yym863 := z.EncBinary() - _ = yym863 + yy932 := *x.AutoSelector + yym933 := z.EncBinary() + _ = yym933 if false { } else { - r.EncodeBool(bool(yy862)) + r.EncodeBool(bool(yy932)) } } } } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy865 := &x.Template - yy865.CodecEncodeSelf(e) + yy935 := &x.Template + yy935.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("template")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy866 := &x.Template - yy866.CodecEncodeSelf(e) + yy936 := &x.Template + yy936.CodecEncodeSelf(e) } - if yyr842 || yy2arr842 { + if yyr910 || yy2arr910 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -10182,25 +10869,25 @@ func (x *JobSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym867 := z.DecBinary() - _ = yym867 + yym937 := z.DecBinary() + _ = yym937 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct868 := r.ContainerType() - if yyct868 == codecSelferValueTypeMap1234 { - yyl868 := r.ReadMapStart() - if yyl868 == 0 { + yyct938 := r.ContainerType() + if yyct938 == codecSelferValueTypeMap1234 { + yyl938 := r.ReadMapStart() + if yyl938 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl868, d) + x.codecDecodeSelfFromMap(yyl938, d) } - } else if yyct868 == codecSelferValueTypeArray1234 { - yyl868 := r.ReadArrayStart() - if yyl868 == 0 { + } else if yyct938 == codecSelferValueTypeArray1234 { + yyl938 := r.ReadArrayStart() + if yyl938 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl868, d) + x.codecDecodeSelfFromArray(yyl938, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -10212,12 +10899,12 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys869Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys869Slc - var yyhl869 bool = l >= 0 - for yyj869 := 0; ; yyj869++ { - if yyhl869 { - if yyj869 >= l { + var yys939Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys939Slc + var yyhl939 bool = l >= 0 + for yyj939 := 0; ; yyj939++ { + if yyhl939 { + if yyj939 >= l { break } } else { @@ -10226,10 +10913,10 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys869Slc = r.DecodeBytes(yys869Slc, true, true) - yys869 := string(yys869Slc) + yys939Slc = r.DecodeBytes(yys939Slc, true, true) + yys939 := string(yys939Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys869 { + switch yys939 { case "parallelism": if r.TryDecodeAsNil() { if x.Parallelism != nil { @@ -10239,8 +10926,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym871 := z.DecBinary() - _ = yym871 + yym941 := z.DecBinary() + _ = yym941 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) @@ -10255,8 +10942,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym873 := z.DecBinary() - _ = yym873 + yym943 := z.DecBinary() + _ = yym943 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) @@ -10271,8 +10958,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym875 := z.DecBinary() - _ = yym875 + yym945 := z.DecBinary() + _ = yym945 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) @@ -10285,9 +10972,15 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym947 := z.DecBinary() + _ = yym947 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } case "autoSelector": if r.TryDecodeAsNil() { @@ -10298,8 +10991,8 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.AutoSelector == nil { x.AutoSelector = new(bool) } - yym878 := z.DecBinary() - _ = yym878 + yym949 := z.DecBinary() + _ = yym949 if false { } else { *((*bool)(x.AutoSelector)) = r.DecodeBool() @@ -10309,13 +11002,13 @@ func (x *JobSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv879 := &x.Template - yyv879.CodecDecodeSelf(d) + yyv950 := &x.Template + yyv950.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys869) - } // end switch yys869 - } // end for yyj869 + z.DecStructFieldNotFound(-1, yys939) + } // end switch yys939 + } // end for yyj939 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -10323,16 +11016,16 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj880 int - var yyb880 bool - var yyhl880 bool = l >= 0 - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + var yyj951 int + var yyb951 bool + var yyhl951 bool = l >= 0 + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10345,20 +11038,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Parallelism == nil { x.Parallelism = new(int32) } - yym882 := z.DecBinary() - _ = yym882 + yym953 := z.DecBinary() + _ = yym953 if false { } else { *((*int32)(x.Parallelism)) = int32(r.DecodeInt(32)) } } - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10371,20 +11064,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.Completions == nil { x.Completions = new(int32) } - yym884 := z.DecBinary() - _ = yym884 + yym955 := z.DecBinary() + _ = yym955 if false { } else { *((*int32)(x.Completions)) = int32(r.DecodeInt(32)) } } - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10397,20 +11090,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.ActiveDeadlineSeconds == nil { x.ActiveDeadlineSeconds = new(int64) } - yym886 := z.DecBinary() - _ = yym886 + yym957 := z.DecBinary() + _ = yym957 if false { } else { *((*int64)(x.ActiveDeadlineSeconds)) = int64(r.DecodeInt(64)) } } - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10421,17 +11114,23 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } } else { if x.Selector == nil { - x.Selector = new(LabelSelector) + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym959 := z.DecBinary() + _ = yym959 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) } - x.Selector.CodecDecodeSelf(d) } - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10444,20 +11143,20 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.AutoSelector == nil { x.AutoSelector = new(bool) } - yym889 := z.DecBinary() - _ = yym889 + yym961 := z.DecBinary() + _ = yym961 if false { } else { *((*bool)(x.AutoSelector)) = r.DecodeBool() } } - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10465,21 +11164,21 @@ func (x *JobSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Template = pkg2_v1.PodTemplateSpec{} } else { - yyv890 := &x.Template - yyv890.CodecDecodeSelf(d) + yyv962 := &x.Template + yyv962.CodecDecodeSelf(d) } for { - yyj880++ - if yyhl880 { - yyb880 = yyj880 > l + yyj951++ + if yyhl951 { + yyb951 = yyj951 > l } else { - yyb880 = r.CheckBreak() + yyb951 = r.CheckBreak() } - if yyb880 { + if yyb951 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj880-1, "") + z.DecStructFieldNotFound(yyj951-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -10491,43 +11190,43 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym891 := z.EncBinary() - _ = yym891 + yym963 := z.EncBinary() + _ = yym963 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep892 := !z.EncBinary() - yy2arr892 := z.EncBasicHandle().StructToArray - var yyq892 [6]bool - _, _, _ = yysep892, yyq892, yy2arr892 - const yyr892 bool = false - yyq892[0] = len(x.Conditions) != 0 - yyq892[1] = x.StartTime != nil - yyq892[2] = x.CompletionTime != nil - yyq892[3] = x.Active != 0 - yyq892[4] = x.Succeeded != 0 - yyq892[5] = x.Failed != 0 - var yynn892 int - if yyr892 || yy2arr892 { + yysep964 := !z.EncBinary() + yy2arr964 := z.EncBasicHandle().StructToArray + var yyq964 [6]bool + _, _, _ = yysep964, yyq964, yy2arr964 + const yyr964 bool = false + yyq964[0] = len(x.Conditions) != 0 + yyq964[1] = x.StartTime != nil + yyq964[2] = x.CompletionTime != nil + yyq964[3] = x.Active != 0 + yyq964[4] = x.Succeeded != 0 + yyq964[5] = x.Failed != 0 + var yynn964 int + if yyr964 || yy2arr964 { r.EncodeArrayStart(6) } else { - yynn892 = 0 - for _, b := range yyq892 { + yynn964 = 0 + for _, b := range yyq964 { if b { - yynn892++ + yynn964++ } } - r.EncodeMapStart(yynn892) - yynn892 = 0 + r.EncodeMapStart(yynn964) + yynn964 = 0 } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[0] { + if yyq964[0] { if x.Conditions == nil { r.EncodeNil() } else { - yym894 := z.EncBinary() - _ = yym894 + yym966 := z.EncBinary() + _ = yym966 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -10537,15 +11236,15 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq892[0] { + if yyq964[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym895 := z.EncBinary() - _ = yym895 + yym967 := z.EncBinary() + _ = yym967 if false { } else { h.encSliceJobCondition(([]JobCondition)(x.Conditions), e) @@ -10553,19 +11252,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[1] { + if yyq964[1] { if x.StartTime == nil { r.EncodeNil() } else { - yym897 := z.EncBinary() - _ = yym897 + yym969 := z.EncBinary() + _ = yym969 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym897 { + } else if yym969 { z.EncBinaryMarshal(x.StartTime) - } else if !yym897 && z.IsJSONHandle() { + } else if !yym969 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -10575,20 +11274,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq892[1] { + if yyq964[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("startTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.StartTime == nil { r.EncodeNil() } else { - yym898 := z.EncBinary() - _ = yym898 + yym970 := z.EncBinary() + _ = yym970 if false { } else if z.HasExtensions() && z.EncExt(x.StartTime) { - } else if yym898 { + } else if yym970 { z.EncBinaryMarshal(x.StartTime) - } else if !yym898 && z.IsJSONHandle() { + } else if !yym970 && z.IsJSONHandle() { z.EncJSONMarshal(x.StartTime) } else { z.EncFallback(x.StartTime) @@ -10596,19 +11295,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[2] { + if yyq964[2] { if x.CompletionTime == nil { r.EncodeNil() } else { - yym900 := z.EncBinary() - _ = yym900 + yym972 := z.EncBinary() + _ = yym972 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym900 { + } else if yym972 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym900 && z.IsJSONHandle() { + } else if !yym972 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -10618,20 +11317,20 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq892[2] { + if yyq964[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("completionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.CompletionTime == nil { r.EncodeNil() } else { - yym901 := z.EncBinary() - _ = yym901 + yym973 := z.EncBinary() + _ = yym973 if false { } else if z.HasExtensions() && z.EncExt(x.CompletionTime) { - } else if yym901 { + } else if yym973 { z.EncBinaryMarshal(x.CompletionTime) - } else if !yym901 && z.IsJSONHandle() { + } else if !yym973 && z.IsJSONHandle() { z.EncJSONMarshal(x.CompletionTime) } else { z.EncFallback(x.CompletionTime) @@ -10639,11 +11338,11 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[3] { - yym903 := z.EncBinary() - _ = yym903 + if yyq964[3] { + yym975 := z.EncBinary() + _ = yym975 if false { } else { r.EncodeInt(int64(x.Active)) @@ -10652,23 +11351,23 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq892[3] { + if yyq964[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("active")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym904 := z.EncBinary() - _ = yym904 + yym976 := z.EncBinary() + _ = yym976 if false { } else { r.EncodeInt(int64(x.Active)) } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[4] { - yym906 := z.EncBinary() - _ = yym906 + if yyq964[4] { + yym978 := z.EncBinary() + _ = yym978 if false { } else { r.EncodeInt(int64(x.Succeeded)) @@ -10677,23 +11376,23 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq892[4] { + if yyq964[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("succeeded")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym907 := z.EncBinary() - _ = yym907 + yym979 := z.EncBinary() + _ = yym979 if false { } else { r.EncodeInt(int64(x.Succeeded)) } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq892[5] { - yym909 := z.EncBinary() - _ = yym909 + if yyq964[5] { + yym981 := z.EncBinary() + _ = yym981 if false { } else { r.EncodeInt(int64(x.Failed)) @@ -10702,19 +11401,19 @@ func (x *JobStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq892[5] { + if yyq964[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("failed")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym910 := z.EncBinary() - _ = yym910 + yym982 := z.EncBinary() + _ = yym982 if false { } else { r.EncodeInt(int64(x.Failed)) } } } - if yyr892 || yy2arr892 { + if yyr964 || yy2arr964 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -10727,25 +11426,25 @@ func (x *JobStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym911 := z.DecBinary() - _ = yym911 + yym983 := z.DecBinary() + _ = yym983 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct912 := r.ContainerType() - if yyct912 == codecSelferValueTypeMap1234 { - yyl912 := r.ReadMapStart() - if yyl912 == 0 { + yyct984 := r.ContainerType() + if yyct984 == codecSelferValueTypeMap1234 { + yyl984 := r.ReadMapStart() + if yyl984 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl912, d) + x.codecDecodeSelfFromMap(yyl984, d) } - } else if yyct912 == codecSelferValueTypeArray1234 { - yyl912 := r.ReadArrayStart() - if yyl912 == 0 { + } else if yyct984 == codecSelferValueTypeArray1234 { + yyl984 := r.ReadArrayStart() + if yyl984 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl912, d) + x.codecDecodeSelfFromArray(yyl984, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -10757,12 +11456,12 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys913Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys913Slc - var yyhl913 bool = l >= 0 - for yyj913 := 0; ; yyj913++ { - if yyhl913 { - if yyj913 >= l { + var yys985Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys985Slc + var yyhl985 bool = l >= 0 + for yyj985 := 0; ; yyj985++ { + if yyhl985 { + if yyj985 >= l { break } } else { @@ -10771,20 +11470,20 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys913Slc = r.DecodeBytes(yys913Slc, true, true) - yys913 := string(yys913Slc) + yys985Slc = r.DecodeBytes(yys985Slc, true, true) + yys985 := string(yys985Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys913 { + switch yys985 { case "conditions": if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv914 := &x.Conditions - yym915 := z.DecBinary() - _ = yym915 + yyv986 := &x.Conditions + yym987 := z.DecBinary() + _ = yym987 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv914), d) + h.decSliceJobCondition((*[]JobCondition)(yyv986), d) } } case "startTime": @@ -10796,13 +11495,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym917 := z.DecBinary() - _ = yym917 + yym989 := z.DecBinary() + _ = yym989 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym917 { + } else if yym989 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym917 && z.IsJSONHandle() { + } else if !yym989 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) @@ -10817,13 +11516,13 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym919 := z.DecBinary() - _ = yym919 + yym991 := z.DecBinary() + _ = yym991 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym919 { + } else if yym991 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym919 && z.IsJSONHandle() { + } else if !yym991 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) @@ -10848,9 +11547,9 @@ func (x *JobStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys913) - } // end switch yys913 - } // end for yyj913 + z.DecStructFieldNotFound(-1, yys985) + } // end switch yys985 + } // end for yyj985 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -10858,16 +11557,16 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj923 int - var yyb923 bool - var yyhl923 bool = l >= 0 - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + var yyj995 int + var yyb995 bool + var yyhl995 bool = l >= 0 + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10875,21 +11574,21 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv924 := &x.Conditions - yym925 := z.DecBinary() - _ = yym925 + yyv996 := &x.Conditions + yym997 := z.DecBinary() + _ = yym997 if false { } else { - h.decSliceJobCondition((*[]JobCondition)(yyv924), d) + h.decSliceJobCondition((*[]JobCondition)(yyv996), d) } } - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10902,25 +11601,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.StartTime == nil { x.StartTime = new(pkg1_unversioned.Time) } - yym927 := z.DecBinary() - _ = yym927 + yym999 := z.DecBinary() + _ = yym999 if false { } else if z.HasExtensions() && z.DecExt(x.StartTime) { - } else if yym927 { + } else if yym999 { z.DecBinaryUnmarshal(x.StartTime) - } else if !yym927 && z.IsJSONHandle() { + } else if !yym999 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.StartTime) } else { z.DecFallback(x.StartTime, false) } } - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10933,25 +11632,25 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.CompletionTime == nil { x.CompletionTime = new(pkg1_unversioned.Time) } - yym929 := z.DecBinary() - _ = yym929 + yym1001 := z.DecBinary() + _ = yym1001 if false { } else if z.HasExtensions() && z.DecExt(x.CompletionTime) { - } else if yym929 { + } else if yym1001 { z.DecBinaryUnmarshal(x.CompletionTime) - } else if !yym929 && z.IsJSONHandle() { + } else if !yym1001 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.CompletionTime) } else { z.DecFallback(x.CompletionTime, false) } } - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10961,13 +11660,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Active = int32(r.DecodeInt(32)) } - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10977,13 +11676,13 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Succeeded = int32(r.DecodeInt(32)) } - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -10994,17 +11693,17 @@ func (x *JobStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Failed = int32(r.DecodeInt(32)) } for { - yyj923++ - if yyhl923 { - yyb923 = yyj923 > l + yyj995++ + if yyhl995 { + yyb995 = yyj995 > l } else { - yyb923 = r.CheckBreak() + yyb995 = r.CheckBreak() } - if yyb923 { + if yyb995 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj923-1, "") + z.DecStructFieldNotFound(yyj995-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11013,8 +11712,8 @@ func (x JobConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym933 := z.EncBinary() - _ = yym933 + yym1005 := z.EncBinary() + _ = yym1005 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -11026,8 +11725,8 @@ func (x *JobConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym934 := z.DecBinary() - _ = yym934 + yym1006 := z.DecBinary() + _ = yym1006 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -11042,34 +11741,34 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym935 := z.EncBinary() - _ = yym935 + yym1007 := z.EncBinary() + _ = yym1007 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep936 := !z.EncBinary() - yy2arr936 := z.EncBasicHandle().StructToArray - var yyq936 [6]bool - _, _, _ = yysep936, yyq936, yy2arr936 - const yyr936 bool = false - yyq936[2] = true - yyq936[3] = true - yyq936[4] = x.Reason != "" - yyq936[5] = x.Message != "" - var yynn936 int - if yyr936 || yy2arr936 { + yysep1008 := !z.EncBinary() + yy2arr1008 := z.EncBasicHandle().StructToArray + var yyq1008 [6]bool + _, _, _ = yysep1008, yyq1008, yy2arr1008 + const yyr1008 bool = false + yyq1008[2] = true + yyq1008[3] = true + yyq1008[4] = x.Reason != "" + yyq1008[5] = x.Message != "" + var yynn1008 int + if yyr1008 || yy2arr1008 { r.EncodeArrayStart(6) } else { - yynn936 = 2 - for _, b := range yyq936 { + yynn1008 = 2 + for _, b := range yyq1008 { if b { - yynn936++ + yynn1008++ } } - r.EncodeMapStart(yynn936) - yynn936 = 0 + r.EncodeMapStart(yynn1008) + yynn1008 = 0 } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -11078,10 +11777,10 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym939 := z.EncBinary() - _ = yym939 + yym1011 := z.EncBinary() + _ = yym1011 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { @@ -11091,93 +11790,93 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym940 := z.EncBinary() - _ = yym940 + yym1012 := z.EncBinary() + _ = yym1012 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Status)) } } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq936[2] { - yy942 := &x.LastProbeTime - yym943 := z.EncBinary() - _ = yym943 + if yyq1008[2] { + yy1014 := &x.LastProbeTime + yym1015 := z.EncBinary() + _ = yym1015 if false { - } else if z.HasExtensions() && z.EncExt(yy942) { - } else if yym943 { - z.EncBinaryMarshal(yy942) - } else if !yym943 && z.IsJSONHandle() { - z.EncJSONMarshal(yy942) + } else if z.HasExtensions() && z.EncExt(yy1014) { + } else if yym1015 { + z.EncBinaryMarshal(yy1014) + } else if !yym1015 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1014) } else { - z.EncFallback(yy942) + z.EncFallback(yy1014) } } else { r.EncodeNil() } } else { - if yyq936[2] { + if yyq1008[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy944 := &x.LastProbeTime - yym945 := z.EncBinary() - _ = yym945 + yy1016 := &x.LastProbeTime + yym1017 := z.EncBinary() + _ = yym1017 if false { - } else if z.HasExtensions() && z.EncExt(yy944) { - } else if yym945 { - z.EncBinaryMarshal(yy944) - } else if !yym945 && z.IsJSONHandle() { - z.EncJSONMarshal(yy944) + } else if z.HasExtensions() && z.EncExt(yy1016) { + } else if yym1017 { + z.EncBinaryMarshal(yy1016) + } else if !yym1017 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1016) } else { - z.EncFallback(yy944) + z.EncFallback(yy1016) } } } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq936[3] { - yy947 := &x.LastTransitionTime - yym948 := z.EncBinary() - _ = yym948 + if yyq1008[3] { + yy1019 := &x.LastTransitionTime + yym1020 := z.EncBinary() + _ = yym1020 if false { - } else if z.HasExtensions() && z.EncExt(yy947) { - } else if yym948 { - z.EncBinaryMarshal(yy947) - } else if !yym948 && z.IsJSONHandle() { - z.EncJSONMarshal(yy947) + } else if z.HasExtensions() && z.EncExt(yy1019) { + } else if yym1020 { + z.EncBinaryMarshal(yy1019) + } else if !yym1020 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1019) } else { - z.EncFallback(yy947) + z.EncFallback(yy1019) } } else { r.EncodeNil() } } else { - if yyq936[3] { + if yyq1008[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy949 := &x.LastTransitionTime - yym950 := z.EncBinary() - _ = yym950 + yy1021 := &x.LastTransitionTime + yym1022 := z.EncBinary() + _ = yym1022 if false { - } else if z.HasExtensions() && z.EncExt(yy949) { - } else if yym950 { - z.EncBinaryMarshal(yy949) - } else if !yym950 && z.IsJSONHandle() { - z.EncJSONMarshal(yy949) + } else if z.HasExtensions() && z.EncExt(yy1021) { + } else if yym1022 { + z.EncBinaryMarshal(yy1021) + } else if !yym1022 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1021) } else { - z.EncFallback(yy949) + z.EncFallback(yy1021) } } } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq936[4] { - yym952 := z.EncBinary() - _ = yym952 + if yyq1008[4] { + yym1024 := z.EncBinary() + _ = yym1024 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -11186,23 +11885,23 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq936[4] { + if yyq1008[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym953 := z.EncBinary() - _ = yym953 + yym1025 := z.EncBinary() + _ = yym1025 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq936[5] { - yym955 := z.EncBinary() - _ = yym955 + if yyq1008[5] { + yym1027 := z.EncBinary() + _ = yym1027 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -11211,19 +11910,19 @@ func (x *JobCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq936[5] { + if yyq1008[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym956 := z.EncBinary() - _ = yym956 + yym1028 := z.EncBinary() + _ = yym1028 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr936 || yy2arr936 { + if yyr1008 || yy2arr1008 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -11236,25 +11935,25 @@ func (x *JobCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym957 := z.DecBinary() - _ = yym957 + yym1029 := z.DecBinary() + _ = yym1029 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct958 := r.ContainerType() - if yyct958 == codecSelferValueTypeMap1234 { - yyl958 := r.ReadMapStart() - if yyl958 == 0 { + yyct1030 := r.ContainerType() + if yyct1030 == codecSelferValueTypeMap1234 { + yyl1030 := r.ReadMapStart() + if yyl1030 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl958, d) + x.codecDecodeSelfFromMap(yyl1030, d) } - } else if yyct958 == codecSelferValueTypeArray1234 { - yyl958 := r.ReadArrayStart() - if yyl958 == 0 { + } else if yyct1030 == codecSelferValueTypeArray1234 { + yyl1030 := r.ReadArrayStart() + if yyl1030 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl958, d) + x.codecDecodeSelfFromArray(yyl1030, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -11266,12 +11965,12 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys959Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys959Slc - var yyhl959 bool = l >= 0 - for yyj959 := 0; ; yyj959++ { - if yyhl959 { - if yyj959 >= l { + var yys1031Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1031Slc + var yyhl1031 bool = l >= 0 + for yyj1031 := 0; ; yyj1031++ { + if yyhl1031 { + if yyj1031 >= l { break } } else { @@ -11280,10 +11979,10 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys959Slc = r.DecodeBytes(yys959Slc, true, true) - yys959 := string(yys959Slc) + yys1031Slc = r.DecodeBytes(yys1031Slc, true, true) + yys1031 := string(yys1031Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys959 { + switch yys1031 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -11300,34 +11999,34 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv962 := &x.LastProbeTime - yym963 := z.DecBinary() - _ = yym963 + yyv1034 := &x.LastProbeTime + yym1035 := z.DecBinary() + _ = yym1035 if false { - } else if z.HasExtensions() && z.DecExt(yyv962) { - } else if yym963 { - z.DecBinaryUnmarshal(yyv962) - } else if !yym963 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv962) + } else if z.HasExtensions() && z.DecExt(yyv1034) { + } else if yym1035 { + z.DecBinaryUnmarshal(yyv1034) + } else if !yym1035 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1034) } else { - z.DecFallback(yyv962, false) + z.DecFallback(yyv1034, false) } } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv964 := &x.LastTransitionTime - yym965 := z.DecBinary() - _ = yym965 + yyv1036 := &x.LastTransitionTime + yym1037 := z.DecBinary() + _ = yym1037 if false { - } else if z.HasExtensions() && z.DecExt(yyv964) { - } else if yym965 { - z.DecBinaryUnmarshal(yyv964) - } else if !yym965 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv964) + } else if z.HasExtensions() && z.DecExt(yyv1036) { + } else if yym1037 { + z.DecBinaryUnmarshal(yyv1036) + } else if !yym1037 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1036) } else { - z.DecFallback(yyv964, false) + z.DecFallback(yyv1036, false) } } case "reason": @@ -11343,9 +12042,9 @@ func (x *JobCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys959) - } // end switch yys959 - } // end for yyj959 + z.DecStructFieldNotFound(-1, yys1031) + } // end switch yys1031 + } // end for yyj1031 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -11353,16 +12052,16 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj968 int - var yyb968 bool - var yyhl968 bool = l >= 0 - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + var yyj1040 int + var yyb1040 bool + var yyhl1040 bool = l >= 0 + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11372,13 +12071,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Type = JobConditionType(r.DecodeString()) } - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11388,13 +12087,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) } - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11402,26 +12101,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastProbeTime = pkg1_unversioned.Time{} } else { - yyv971 := &x.LastProbeTime - yym972 := z.DecBinary() - _ = yym972 + yyv1043 := &x.LastProbeTime + yym1044 := z.DecBinary() + _ = yym1044 if false { - } else if z.HasExtensions() && z.DecExt(yyv971) { - } else if yym972 { - z.DecBinaryUnmarshal(yyv971) - } else if !yym972 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv971) + } else if z.HasExtensions() && z.DecExt(yyv1043) { + } else if yym1044 { + z.DecBinaryUnmarshal(yyv1043) + } else if !yym1044 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1043) } else { - z.DecFallback(yyv971, false) + z.DecFallback(yyv1043, false) } } - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11429,26 +12128,26 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv973 := &x.LastTransitionTime - yym974 := z.DecBinary() - _ = yym974 + yyv1045 := &x.LastTransitionTime + yym1046 := z.DecBinary() + _ = yym1046 if false { - } else if z.HasExtensions() && z.DecExt(yyv973) { - } else if yym974 { - z.DecBinaryUnmarshal(yyv973) - } else if !yym974 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv973) + } else if z.HasExtensions() && z.DecExt(yyv1045) { + } else if yym1046 { + z.DecBinaryUnmarshal(yyv1045) + } else if !yym1046 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1045) } else { - z.DecFallback(yyv973, false) + z.DecFallback(yyv1045, false) } } - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11458,13 +12157,13 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Reason = string(r.DecodeString()) } - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11475,17 +12174,17 @@ func (x *JobCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Message = string(r.DecodeString()) } for { - yyj968++ - if yyhl968 { - yyb968 = yyj968 > l + yyj1040++ + if yyhl1040 { + yyb1040 = yyj1040 > l } else { - yyb968 = r.CheckBreak() + yyb1040 = r.CheckBreak() } - if yyb968 { + if yyb1040 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj968-1, "") + z.DecStructFieldNotFound(yyj1040-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11497,39 +12196,39 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym977 := z.EncBinary() - _ = yym977 + yym1049 := z.EncBinary() + _ = yym1049 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep978 := !z.EncBinary() - yy2arr978 := z.EncBasicHandle().StructToArray - var yyq978 [5]bool - _, _, _ = yysep978, yyq978, yy2arr978 - const yyr978 bool = false - yyq978[0] = x.Kind != "" - yyq978[1] = x.APIVersion != "" - yyq978[2] = true - yyq978[3] = true - yyq978[4] = true - var yynn978 int - if yyr978 || yy2arr978 { + yysep1050 := !z.EncBinary() + yy2arr1050 := z.EncBasicHandle().StructToArray + var yyq1050 [5]bool + _, _, _ = yysep1050, yyq1050, yy2arr1050 + const yyr1050 bool = false + yyq1050[0] = x.Kind != "" + yyq1050[1] = x.APIVersion != "" + yyq1050[2] = true + yyq1050[3] = true + yyq1050[4] = true + var yynn1050 int + if yyr1050 || yy2arr1050 { r.EncodeArrayStart(5) } else { - yynn978 = 0 - for _, b := range yyq978 { + yynn1050 = 0 + for _, b := range yyq1050 { if b { - yynn978++ + yynn1050++ } } - r.EncodeMapStart(yynn978) - yynn978 = 0 + r.EncodeMapStart(yynn1050) + yynn1050 = 0 } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq978[0] { - yym980 := z.EncBinary() - _ = yym980 + if yyq1050[0] { + yym1052 := z.EncBinary() + _ = yym1052 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -11538,23 +12237,23 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq978[0] { + if yyq1050[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym981 := z.EncBinary() - _ = yym981 + yym1053 := z.EncBinary() + _ = yym1053 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq978[1] { - yym983 := z.EncBinary() - _ = yym983 + if yyq1050[1] { + yym1055 := z.EncBinary() + _ = yym1055 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -11563,70 +12262,70 @@ func (x *Ingress) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq978[1] { + if yyq1050[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym984 := z.EncBinary() - _ = yym984 + yym1056 := z.EncBinary() + _ = yym1056 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq978[2] { - yy986 := &x.ObjectMeta - yy986.CodecEncodeSelf(e) + if yyq1050[2] { + yy1058 := &x.ObjectMeta + yy1058.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq978[2] { + if yyq1050[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy987 := &x.ObjectMeta - yy987.CodecEncodeSelf(e) + yy1059 := &x.ObjectMeta + yy1059.CodecEncodeSelf(e) } } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq978[3] { - yy989 := &x.Spec - yy989.CodecEncodeSelf(e) + if yyq1050[3] { + yy1061 := &x.Spec + yy1061.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq978[3] { + if yyq1050[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy990 := &x.Spec - yy990.CodecEncodeSelf(e) + yy1062 := &x.Spec + yy1062.CodecEncodeSelf(e) } } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq978[4] { - yy992 := &x.Status - yy992.CodecEncodeSelf(e) + if yyq1050[4] { + yy1064 := &x.Status + yy1064.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq978[4] { + if yyq1050[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy993 := &x.Status - yy993.CodecEncodeSelf(e) + yy1065 := &x.Status + yy1065.CodecEncodeSelf(e) } } - if yyr978 || yy2arr978 { + if yyr1050 || yy2arr1050 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -11639,25 +12338,25 @@ func (x *Ingress) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym994 := z.DecBinary() - _ = yym994 + yym1066 := z.DecBinary() + _ = yym1066 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct995 := r.ContainerType() - if yyct995 == codecSelferValueTypeMap1234 { - yyl995 := r.ReadMapStart() - if yyl995 == 0 { + yyct1067 := r.ContainerType() + if yyct1067 == codecSelferValueTypeMap1234 { + yyl1067 := r.ReadMapStart() + if yyl1067 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl995, d) + x.codecDecodeSelfFromMap(yyl1067, d) } - } else if yyct995 == codecSelferValueTypeArray1234 { - yyl995 := r.ReadArrayStart() - if yyl995 == 0 { + } else if yyct1067 == codecSelferValueTypeArray1234 { + yyl1067 := r.ReadArrayStart() + if yyl1067 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl995, d) + x.codecDecodeSelfFromArray(yyl1067, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -11669,12 +12368,12 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys996Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys996Slc - var yyhl996 bool = l >= 0 - for yyj996 := 0; ; yyj996++ { - if yyhl996 { - if yyj996 >= l { + var yys1068Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1068Slc + var yyhl1068 bool = l >= 0 + for yyj1068 := 0; ; yyj1068++ { + if yyhl1068 { + if yyj1068 >= l { break } } else { @@ -11683,10 +12382,10 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys996Slc = r.DecodeBytes(yys996Slc, true, true) - yys996 := string(yys996Slc) + yys1068Slc = r.DecodeBytes(yys1068Slc, true, true) + yys1068 := string(yys1068Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys996 { + switch yys1068 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -11703,27 +12402,27 @@ func (x *Ingress) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv999 := &x.ObjectMeta - yyv999.CodecDecodeSelf(d) + yyv1071 := &x.ObjectMeta + yyv1071.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = IngressSpec{} } else { - yyv1000 := &x.Spec - yyv1000.CodecDecodeSelf(d) + yyv1072 := &x.Spec + yyv1072.CodecDecodeSelf(d) } case "status": if r.TryDecodeAsNil() { x.Status = IngressStatus{} } else { - yyv1001 := &x.Status - yyv1001.CodecDecodeSelf(d) + yyv1073 := &x.Status + yyv1073.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys996) - } // end switch yys996 - } // end for yyj996 + z.DecStructFieldNotFound(-1, yys1068) + } // end switch yys1068 + } // end for yyj1068 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -11731,16 +12430,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1002 int - var yyb1002 bool - var yyhl1002 bool = l >= 0 - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + var yyj1074 int + var yyb1074 bool + var yyhl1074 bool = l >= 0 + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11750,13 +12449,13 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11766,13 +12465,13 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11780,16 +12479,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1005 := &x.ObjectMeta - yyv1005.CodecDecodeSelf(d) + yyv1077 := &x.ObjectMeta + yyv1077.CodecDecodeSelf(d) } - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11797,16 +12496,16 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = IngressSpec{} } else { - yyv1006 := &x.Spec - yyv1006.CodecDecodeSelf(d) + yyv1078 := &x.Spec + yyv1078.CodecDecodeSelf(d) } - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -11814,21 +12513,21 @@ func (x *Ingress) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = IngressStatus{} } else { - yyv1007 := &x.Status - yyv1007.CodecDecodeSelf(d) + yyv1079 := &x.Status + yyv1079.CodecDecodeSelf(d) } for { - yyj1002++ - if yyhl1002 { - yyb1002 = yyj1002 > l + yyj1074++ + if yyhl1074 { + yyb1074 = yyj1074 > l } else { - yyb1002 = r.CheckBreak() + yyb1074 = r.CheckBreak() } - if yyb1002 { + if yyb1074 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1002-1, "") + z.DecStructFieldNotFound(yyj1074-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -11840,37 +12539,37 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1008 := z.EncBinary() - _ = yym1008 + yym1080 := z.EncBinary() + _ = yym1080 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1009 := !z.EncBinary() - yy2arr1009 := z.EncBasicHandle().StructToArray - var yyq1009 [4]bool - _, _, _ = yysep1009, yyq1009, yy2arr1009 - const yyr1009 bool = false - yyq1009[0] = x.Kind != "" - yyq1009[1] = x.APIVersion != "" - yyq1009[2] = true - var yynn1009 int - if yyr1009 || yy2arr1009 { + yysep1081 := !z.EncBinary() + yy2arr1081 := z.EncBasicHandle().StructToArray + var yyq1081 [4]bool + _, _, _ = yysep1081, yyq1081, yy2arr1081 + const yyr1081 bool = false + yyq1081[0] = x.Kind != "" + yyq1081[1] = x.APIVersion != "" + yyq1081[2] = true + var yynn1081 int + if yyr1081 || yy2arr1081 { r.EncodeArrayStart(4) } else { - yynn1009 = 1 - for _, b := range yyq1009 { + yynn1081 = 1 + for _, b := range yyq1081 { if b { - yynn1009++ + yynn1081++ } } - r.EncodeMapStart(yynn1009) - yynn1009 = 0 + r.EncodeMapStart(yynn1081) + yynn1081 = 0 } - if yyr1009 || yy2arr1009 { + if yyr1081 || yy2arr1081 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1009[0] { - yym1011 := z.EncBinary() - _ = yym1011 + if yyq1081[0] { + yym1083 := z.EncBinary() + _ = yym1083 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -11879,23 +12578,23 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1009[0] { + if yyq1081[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1012 := z.EncBinary() - _ = yym1012 + yym1084 := z.EncBinary() + _ = yym1084 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1009 || yy2arr1009 { + if yyr1081 || yy2arr1081 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1009[1] { - yym1014 := z.EncBinary() - _ = yym1014 + if yyq1081[1] { + yym1086 := z.EncBinary() + _ = yym1086 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -11904,54 +12603,54 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1009[1] { + if yyq1081[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1015 := z.EncBinary() - _ = yym1015 + yym1087 := z.EncBinary() + _ = yym1087 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1009 || yy2arr1009 { + if yyr1081 || yy2arr1081 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1009[2] { - yy1017 := &x.ListMeta - yym1018 := z.EncBinary() - _ = yym1018 + if yyq1081[2] { + yy1089 := &x.ListMeta + yym1090 := z.EncBinary() + _ = yym1090 if false { - } else if z.HasExtensions() && z.EncExt(yy1017) { + } else if z.HasExtensions() && z.EncExt(yy1089) { } else { - z.EncFallback(yy1017) + z.EncFallback(yy1089) } } else { r.EncodeNil() } } else { - if yyq1009[2] { + if yyq1081[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1019 := &x.ListMeta - yym1020 := z.EncBinary() - _ = yym1020 + yy1091 := &x.ListMeta + yym1092 := z.EncBinary() + _ = yym1092 if false { - } else if z.HasExtensions() && z.EncExt(yy1019) { + } else if z.HasExtensions() && z.EncExt(yy1091) { } else { - z.EncFallback(yy1019) + z.EncFallback(yy1091) } } } - if yyr1009 || yy2arr1009 { + if yyr1081 || yy2arr1081 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1022 := z.EncBinary() - _ = yym1022 + yym1094 := z.EncBinary() + _ = yym1094 if false { } else { h.encSliceIngress(([]Ingress)(x.Items), e) @@ -11964,15 +12663,15 @@ func (x *IngressList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1023 := z.EncBinary() - _ = yym1023 + yym1095 := z.EncBinary() + _ = yym1095 if false { } else { h.encSliceIngress(([]Ingress)(x.Items), e) } } } - if yyr1009 || yy2arr1009 { + if yyr1081 || yy2arr1081 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -11985,25 +12684,25 @@ func (x *IngressList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1024 := z.DecBinary() - _ = yym1024 + yym1096 := z.DecBinary() + _ = yym1096 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1025 := r.ContainerType() - if yyct1025 == codecSelferValueTypeMap1234 { - yyl1025 := r.ReadMapStart() - if yyl1025 == 0 { + yyct1097 := r.ContainerType() + if yyct1097 == codecSelferValueTypeMap1234 { + yyl1097 := r.ReadMapStart() + if yyl1097 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1025, d) + x.codecDecodeSelfFromMap(yyl1097, d) } - } else if yyct1025 == codecSelferValueTypeArray1234 { - yyl1025 := r.ReadArrayStart() - if yyl1025 == 0 { + } else if yyct1097 == codecSelferValueTypeArray1234 { + yyl1097 := r.ReadArrayStart() + if yyl1097 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1025, d) + x.codecDecodeSelfFromArray(yyl1097, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12015,12 +12714,12 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1026Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1026Slc - var yyhl1026 bool = l >= 0 - for yyj1026 := 0; ; yyj1026++ { - if yyhl1026 { - if yyj1026 >= l { + var yys1098Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1098Slc + var yyhl1098 bool = l >= 0 + for yyj1098 := 0; ; yyj1098++ { + if yyhl1098 { + if yyj1098 >= l { break } } else { @@ -12029,10 +12728,10 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1026Slc = r.DecodeBytes(yys1026Slc, true, true) - yys1026 := string(yys1026Slc) + yys1098Slc = r.DecodeBytes(yys1098Slc, true, true) + yys1098 := string(yys1098Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1026 { + switch yys1098 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -12049,31 +12748,31 @@ func (x *IngressList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1029 := &x.ListMeta - yym1030 := z.DecBinary() - _ = yym1030 + yyv1101 := &x.ListMeta + yym1102 := z.DecBinary() + _ = yym1102 if false { - } else if z.HasExtensions() && z.DecExt(yyv1029) { + } else if z.HasExtensions() && z.DecExt(yyv1101) { } else { - z.DecFallback(yyv1029, false) + z.DecFallback(yyv1101, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1031 := &x.Items - yym1032 := z.DecBinary() - _ = yym1032 + yyv1103 := &x.Items + yym1104 := z.DecBinary() + _ = yym1104 if false { } else { - h.decSliceIngress((*[]Ingress)(yyv1031), d) + h.decSliceIngress((*[]Ingress)(yyv1103), d) } } default: - z.DecStructFieldNotFound(-1, yys1026) - } // end switch yys1026 - } // end for yyj1026 + z.DecStructFieldNotFound(-1, yys1098) + } // end switch yys1098 + } // end for yyj1098 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12081,16 +12780,16 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1033 int - var yyb1033 bool - var yyhl1033 bool = l >= 0 - yyj1033++ - if yyhl1033 { - yyb1033 = yyj1033 > l + var yyj1105 int + var yyb1105 bool + var yyhl1105 bool = l >= 0 + yyj1105++ + if yyhl1105 { + yyb1105 = yyj1105 > l } else { - yyb1033 = r.CheckBreak() + yyb1105 = r.CheckBreak() } - if yyb1033 { + if yyb1105 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12100,13 +12799,13 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj1033++ - if yyhl1033 { - yyb1033 = yyj1033 > l + yyj1105++ + if yyhl1105 { + yyb1105 = yyj1105 > l } else { - yyb1033 = r.CheckBreak() + yyb1105 = r.CheckBreak() } - if yyb1033 { + if yyb1105 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12116,13 +12815,13 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj1033++ - if yyhl1033 { - yyb1033 = yyj1033 > l + yyj1105++ + if yyhl1105 { + yyb1105 = yyj1105 > l } else { - yyb1033 = r.CheckBreak() + yyb1105 = r.CheckBreak() } - if yyb1033 { + if yyb1105 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12130,22 +12829,22 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1036 := &x.ListMeta - yym1037 := z.DecBinary() - _ = yym1037 + yyv1108 := &x.ListMeta + yym1109 := z.DecBinary() + _ = yym1109 if false { - } else if z.HasExtensions() && z.DecExt(yyv1036) { + } else if z.HasExtensions() && z.DecExt(yyv1108) { } else { - z.DecFallback(yyv1036, false) + z.DecFallback(yyv1108, false) } } - yyj1033++ - if yyhl1033 { - yyb1033 = yyj1033 > l + yyj1105++ + if yyhl1105 { + yyb1105 = yyj1105 > l } else { - yyb1033 = r.CheckBreak() + yyb1105 = r.CheckBreak() } - if yyb1033 { + if yyb1105 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12153,26 +12852,26 @@ func (x *IngressList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1038 := &x.Items - yym1039 := z.DecBinary() - _ = yym1039 + yyv1110 := &x.Items + yym1111 := z.DecBinary() + _ = yym1111 if false { } else { - h.decSliceIngress((*[]Ingress)(yyv1038), d) + h.decSliceIngress((*[]Ingress)(yyv1110), d) } } for { - yyj1033++ - if yyhl1033 { - yyb1033 = yyj1033 > l + yyj1105++ + if yyhl1105 { + yyb1105 = yyj1105 > l } else { - yyb1033 = r.CheckBreak() + yyb1105 = r.CheckBreak() } - if yyb1033 { + if yyb1105 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1033-1, "") + z.DecStructFieldNotFound(yyj1105-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12184,35 +12883,35 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1040 := z.EncBinary() - _ = yym1040 + yym1112 := z.EncBinary() + _ = yym1112 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1041 := !z.EncBinary() - yy2arr1041 := z.EncBasicHandle().StructToArray - var yyq1041 [3]bool - _, _, _ = yysep1041, yyq1041, yy2arr1041 - const yyr1041 bool = false - yyq1041[0] = x.Backend != nil - yyq1041[1] = len(x.TLS) != 0 - yyq1041[2] = len(x.Rules) != 0 - var yynn1041 int - if yyr1041 || yy2arr1041 { + yysep1113 := !z.EncBinary() + yy2arr1113 := z.EncBasicHandle().StructToArray + var yyq1113 [3]bool + _, _, _ = yysep1113, yyq1113, yy2arr1113 + const yyr1113 bool = false + yyq1113[0] = x.Backend != nil + yyq1113[1] = len(x.TLS) != 0 + yyq1113[2] = len(x.Rules) != 0 + var yynn1113 int + if yyr1113 || yy2arr1113 { r.EncodeArrayStart(3) } else { - yynn1041 = 0 - for _, b := range yyq1041 { + yynn1113 = 0 + for _, b := range yyq1113 { if b { - yynn1041++ + yynn1113++ } } - r.EncodeMapStart(yynn1041) - yynn1041 = 0 + r.EncodeMapStart(yynn1113) + yynn1113 = 0 } - if yyr1041 || yy2arr1041 { + if yyr1113 || yy2arr1113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1041[0] { + if yyq1113[0] { if x.Backend == nil { r.EncodeNil() } else { @@ -12222,7 +12921,7 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1041[0] { + if yyq1113[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("backend")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -12233,14 +12932,14 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1041 || yy2arr1041 { + if yyr1113 || yy2arr1113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1041[1] { + if yyq1113[1] { if x.TLS == nil { r.EncodeNil() } else { - yym1044 := z.EncBinary() - _ = yym1044 + yym1116 := z.EncBinary() + _ = yym1116 if false { } else { h.encSliceIngressTLS(([]IngressTLS)(x.TLS), e) @@ -12250,15 +12949,15 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1041[1] { + if yyq1113[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("tls")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.TLS == nil { r.EncodeNil() } else { - yym1045 := z.EncBinary() - _ = yym1045 + yym1117 := z.EncBinary() + _ = yym1117 if false { } else { h.encSliceIngressTLS(([]IngressTLS)(x.TLS), e) @@ -12266,14 +12965,14 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1041 || yy2arr1041 { + if yyr1113 || yy2arr1113 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1041[2] { + if yyq1113[2] { if x.Rules == nil { r.EncodeNil() } else { - yym1047 := z.EncBinary() - _ = yym1047 + yym1119 := z.EncBinary() + _ = yym1119 if false { } else { h.encSliceIngressRule(([]IngressRule)(x.Rules), e) @@ -12283,15 +12982,15 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1041[2] { + if yyq1113[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rules")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Rules == nil { r.EncodeNil() } else { - yym1048 := z.EncBinary() - _ = yym1048 + yym1120 := z.EncBinary() + _ = yym1120 if false { } else { h.encSliceIngressRule(([]IngressRule)(x.Rules), e) @@ -12299,7 +12998,7 @@ func (x *IngressSpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1041 || yy2arr1041 { + if yyr1113 || yy2arr1113 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12312,25 +13011,25 @@ func (x *IngressSpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1049 := z.DecBinary() - _ = yym1049 + yym1121 := z.DecBinary() + _ = yym1121 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1050 := r.ContainerType() - if yyct1050 == codecSelferValueTypeMap1234 { - yyl1050 := r.ReadMapStart() - if yyl1050 == 0 { + yyct1122 := r.ContainerType() + if yyct1122 == codecSelferValueTypeMap1234 { + yyl1122 := r.ReadMapStart() + if yyl1122 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1050, d) + x.codecDecodeSelfFromMap(yyl1122, d) } - } else if yyct1050 == codecSelferValueTypeArray1234 { - yyl1050 := r.ReadArrayStart() - if yyl1050 == 0 { + } else if yyct1122 == codecSelferValueTypeArray1234 { + yyl1122 := r.ReadArrayStart() + if yyl1122 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1050, d) + x.codecDecodeSelfFromArray(yyl1122, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12342,12 +13041,12 @@ func (x *IngressSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1051Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1051Slc - var yyhl1051 bool = l >= 0 - for yyj1051 := 0; ; yyj1051++ { - if yyhl1051 { - if yyj1051 >= l { + var yys1123Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1123Slc + var yyhl1123 bool = l >= 0 + for yyj1123 := 0; ; yyj1123++ { + if yyhl1123 { + if yyj1123 >= l { break } } else { @@ -12356,10 +13055,10 @@ func (x *IngressSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1051Slc = r.DecodeBytes(yys1051Slc, true, true) - yys1051 := string(yys1051Slc) + yys1123Slc = r.DecodeBytes(yys1123Slc, true, true) + yys1123 := string(yys1123Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1051 { + switch yys1123 { case "backend": if r.TryDecodeAsNil() { if x.Backend != nil { @@ -12375,30 +13074,30 @@ func (x *IngressSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TLS = nil } else { - yyv1053 := &x.TLS - yym1054 := z.DecBinary() - _ = yym1054 + yyv1125 := &x.TLS + yym1126 := z.DecBinary() + _ = yym1126 if false { } else { - h.decSliceIngressTLS((*[]IngressTLS)(yyv1053), d) + h.decSliceIngressTLS((*[]IngressTLS)(yyv1125), d) } } case "rules": if r.TryDecodeAsNil() { x.Rules = nil } else { - yyv1055 := &x.Rules - yym1056 := z.DecBinary() - _ = yym1056 + yyv1127 := &x.Rules + yym1128 := z.DecBinary() + _ = yym1128 if false { } else { - h.decSliceIngressRule((*[]IngressRule)(yyv1055), d) + h.decSliceIngressRule((*[]IngressRule)(yyv1127), d) } } default: - z.DecStructFieldNotFound(-1, yys1051) - } // end switch yys1051 - } // end for yyj1051 + z.DecStructFieldNotFound(-1, yys1123) + } // end switch yys1123 + } // end for yyj1123 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12406,16 +13105,16 @@ func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1057 int - var yyb1057 bool - var yyhl1057 bool = l >= 0 - yyj1057++ - if yyhl1057 { - yyb1057 = yyj1057 > l + var yyj1129 int + var yyb1129 bool + var yyhl1129 bool = l >= 0 + yyj1129++ + if yyhl1129 { + yyb1129 = yyj1129 > l } else { - yyb1057 = r.CheckBreak() + yyb1129 = r.CheckBreak() } - if yyb1057 { + if yyb1129 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12430,13 +13129,13 @@ func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } x.Backend.CodecDecodeSelf(d) } - yyj1057++ - if yyhl1057 { - yyb1057 = yyj1057 > l + yyj1129++ + if yyhl1129 { + yyb1129 = yyj1129 > l } else { - yyb1057 = r.CheckBreak() + yyb1129 = r.CheckBreak() } - if yyb1057 { + if yyb1129 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12444,21 +13143,21 @@ func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.TLS = nil } else { - yyv1059 := &x.TLS - yym1060 := z.DecBinary() - _ = yym1060 + yyv1131 := &x.TLS + yym1132 := z.DecBinary() + _ = yym1132 if false { } else { - h.decSliceIngressTLS((*[]IngressTLS)(yyv1059), d) + h.decSliceIngressTLS((*[]IngressTLS)(yyv1131), d) } } - yyj1057++ - if yyhl1057 { - yyb1057 = yyj1057 > l + yyj1129++ + if yyhl1129 { + yyb1129 = yyj1129 > l } else { - yyb1057 = r.CheckBreak() + yyb1129 = r.CheckBreak() } - if yyb1057 { + if yyb1129 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12466,26 +13165,26 @@ func (x *IngressSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Rules = nil } else { - yyv1061 := &x.Rules - yym1062 := z.DecBinary() - _ = yym1062 + yyv1133 := &x.Rules + yym1134 := z.DecBinary() + _ = yym1134 if false { } else { - h.decSliceIngressRule((*[]IngressRule)(yyv1061), d) + h.decSliceIngressRule((*[]IngressRule)(yyv1133), d) } } for { - yyj1057++ - if yyhl1057 { - yyb1057 = yyj1057 > l + yyj1129++ + if yyhl1129 { + yyb1129 = yyj1129 > l } else { - yyb1057 = r.CheckBreak() + yyb1129 = r.CheckBreak() } - if yyb1057 { + if yyb1129 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1057-1, "") + z.DecStructFieldNotFound(yyj1129-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12497,39 +13196,39 @@ func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1063 := z.EncBinary() - _ = yym1063 + yym1135 := z.EncBinary() + _ = yym1135 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1064 := !z.EncBinary() - yy2arr1064 := z.EncBasicHandle().StructToArray - var yyq1064 [2]bool - _, _, _ = yysep1064, yyq1064, yy2arr1064 - const yyr1064 bool = false - yyq1064[0] = len(x.Hosts) != 0 - yyq1064[1] = x.SecretName != "" - var yynn1064 int - if yyr1064 || yy2arr1064 { + yysep1136 := !z.EncBinary() + yy2arr1136 := z.EncBasicHandle().StructToArray + var yyq1136 [2]bool + _, _, _ = yysep1136, yyq1136, yy2arr1136 + const yyr1136 bool = false + yyq1136[0] = len(x.Hosts) != 0 + yyq1136[1] = x.SecretName != "" + var yynn1136 int + if yyr1136 || yy2arr1136 { r.EncodeArrayStart(2) } else { - yynn1064 = 0 - for _, b := range yyq1064 { + yynn1136 = 0 + for _, b := range yyq1136 { if b { - yynn1064++ + yynn1136++ } } - r.EncodeMapStart(yynn1064) - yynn1064 = 0 + r.EncodeMapStart(yynn1136) + yynn1136 = 0 } - if yyr1064 || yy2arr1064 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1064[0] { + if yyq1136[0] { if x.Hosts == nil { r.EncodeNil() } else { - yym1066 := z.EncBinary() - _ = yym1066 + yym1138 := z.EncBinary() + _ = yym1138 if false { } else { z.F.EncSliceStringV(x.Hosts, false, e) @@ -12539,15 +13238,15 @@ func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1064[0] { + if yyq1136[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hosts")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Hosts == nil { r.EncodeNil() } else { - yym1067 := z.EncBinary() - _ = yym1067 + yym1139 := z.EncBinary() + _ = yym1139 if false { } else { z.F.EncSliceStringV(x.Hosts, false, e) @@ -12555,11 +13254,11 @@ func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1064 || yy2arr1064 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1064[1] { - yym1069 := z.EncBinary() - _ = yym1069 + if yyq1136[1] { + yym1141 := z.EncBinary() + _ = yym1141 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) @@ -12568,19 +13267,19 @@ func (x *IngressTLS) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1064[1] { + if yyq1136[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("secretName")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1070 := z.EncBinary() - _ = yym1070 + yym1142 := z.EncBinary() + _ = yym1142 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.SecretName)) } } } - if yyr1064 || yy2arr1064 { + if yyr1136 || yy2arr1136 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12593,25 +13292,25 @@ func (x *IngressTLS) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1071 := z.DecBinary() - _ = yym1071 + yym1143 := z.DecBinary() + _ = yym1143 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1072 := r.ContainerType() - if yyct1072 == codecSelferValueTypeMap1234 { - yyl1072 := r.ReadMapStart() - if yyl1072 == 0 { + yyct1144 := r.ContainerType() + if yyct1144 == codecSelferValueTypeMap1234 { + yyl1144 := r.ReadMapStart() + if yyl1144 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1072, d) + x.codecDecodeSelfFromMap(yyl1144, d) } - } else if yyct1072 == codecSelferValueTypeArray1234 { - yyl1072 := r.ReadArrayStart() - if yyl1072 == 0 { + } else if yyct1144 == codecSelferValueTypeArray1234 { + yyl1144 := r.ReadArrayStart() + if yyl1144 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1072, d) + x.codecDecodeSelfFromArray(yyl1144, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12623,12 +13322,12 @@ func (x *IngressTLS) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1073Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1073Slc - var yyhl1073 bool = l >= 0 - for yyj1073 := 0; ; yyj1073++ { - if yyhl1073 { - if yyj1073 >= l { + var yys1145Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1145Slc + var yyhl1145 bool = l >= 0 + for yyj1145 := 0; ; yyj1145++ { + if yyhl1145 { + if yyj1145 >= l { break } } else { @@ -12637,20 +13336,20 @@ func (x *IngressTLS) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1073Slc = r.DecodeBytes(yys1073Slc, true, true) - yys1073 := string(yys1073Slc) + yys1145Slc = r.DecodeBytes(yys1145Slc, true, true) + yys1145 := string(yys1145Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1073 { + switch yys1145 { case "hosts": if r.TryDecodeAsNil() { x.Hosts = nil } else { - yyv1074 := &x.Hosts - yym1075 := z.DecBinary() - _ = yym1075 + yyv1146 := &x.Hosts + yym1147 := z.DecBinary() + _ = yym1147 if false { } else { - z.F.DecSliceStringX(yyv1074, false, d) + z.F.DecSliceStringX(yyv1146, false, d) } } case "secretName": @@ -12660,9 +13359,9 @@ func (x *IngressTLS) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.SecretName = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys1073) - } // end switch yys1073 - } // end for yyj1073 + z.DecStructFieldNotFound(-1, yys1145) + } // end switch yys1145 + } // end for yyj1145 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12670,16 +13369,16 @@ func (x *IngressTLS) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1077 int - var yyb1077 bool - var yyhl1077 bool = l >= 0 - yyj1077++ - if yyhl1077 { - yyb1077 = yyj1077 > l + var yyj1149 int + var yyb1149 bool + var yyhl1149 bool = l >= 0 + yyj1149++ + if yyhl1149 { + yyb1149 = yyj1149 > l } else { - yyb1077 = r.CheckBreak() + yyb1149 = r.CheckBreak() } - if yyb1077 { + if yyb1149 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12687,21 +13386,21 @@ func (x *IngressTLS) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Hosts = nil } else { - yyv1078 := &x.Hosts - yym1079 := z.DecBinary() - _ = yym1079 + yyv1150 := &x.Hosts + yym1151 := z.DecBinary() + _ = yym1151 if false { } else { - z.F.DecSliceStringX(yyv1078, false, d) + z.F.DecSliceStringX(yyv1150, false, d) } } - yyj1077++ - if yyhl1077 { - yyb1077 = yyj1077 > l + yyj1149++ + if yyhl1149 { + yyb1149 = yyj1149 > l } else { - yyb1077 = r.CheckBreak() + yyb1149 = r.CheckBreak() } - if yyb1077 { + if yyb1149 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12712,17 +13411,17 @@ func (x *IngressTLS) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.SecretName = string(r.DecodeString()) } for { - yyj1077++ - if yyhl1077 { - yyb1077 = yyj1077 > l + yyj1149++ + if yyhl1149 { + yyb1149 = yyj1149 > l } else { - yyb1077 = r.CheckBreak() + yyb1149 = r.CheckBreak() } - if yyb1077 { + if yyb1149 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1077-1, "") + z.DecStructFieldNotFound(yyj1149-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12734,48 +13433,48 @@ func (x *IngressStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1081 := z.EncBinary() - _ = yym1081 + yym1153 := z.EncBinary() + _ = yym1153 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1082 := !z.EncBinary() - yy2arr1082 := z.EncBasicHandle().StructToArray - var yyq1082 [1]bool - _, _, _ = yysep1082, yyq1082, yy2arr1082 - const yyr1082 bool = false - yyq1082[0] = true - var yynn1082 int - if yyr1082 || yy2arr1082 { + yysep1154 := !z.EncBinary() + yy2arr1154 := z.EncBasicHandle().StructToArray + var yyq1154 [1]bool + _, _, _ = yysep1154, yyq1154, yy2arr1154 + const yyr1154 bool = false + yyq1154[0] = true + var yynn1154 int + if yyr1154 || yy2arr1154 { r.EncodeArrayStart(1) } else { - yynn1082 = 0 - for _, b := range yyq1082 { + yynn1154 = 0 + for _, b := range yyq1154 { if b { - yynn1082++ + yynn1154++ } } - r.EncodeMapStart(yynn1082) - yynn1082 = 0 + r.EncodeMapStart(yynn1154) + yynn1154 = 0 } - if yyr1082 || yy2arr1082 { + if yyr1154 || yy2arr1154 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1082[0] { - yy1084 := &x.LoadBalancer - yy1084.CodecEncodeSelf(e) + if yyq1154[0] { + yy1156 := &x.LoadBalancer + yy1156.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1082[0] { + if yyq1154[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("loadBalancer")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1085 := &x.LoadBalancer - yy1085.CodecEncodeSelf(e) + yy1157 := &x.LoadBalancer + yy1157.CodecEncodeSelf(e) } } - if yyr1082 || yy2arr1082 { + if yyr1154 || yy2arr1154 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12788,25 +13487,25 @@ func (x *IngressStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1086 := z.DecBinary() - _ = yym1086 + yym1158 := z.DecBinary() + _ = yym1158 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1087 := r.ContainerType() - if yyct1087 == codecSelferValueTypeMap1234 { - yyl1087 := r.ReadMapStart() - if yyl1087 == 0 { + yyct1159 := r.ContainerType() + if yyct1159 == codecSelferValueTypeMap1234 { + yyl1159 := r.ReadMapStart() + if yyl1159 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1087, d) + x.codecDecodeSelfFromMap(yyl1159, d) } - } else if yyct1087 == codecSelferValueTypeArray1234 { - yyl1087 := r.ReadArrayStart() - if yyl1087 == 0 { + } else if yyct1159 == codecSelferValueTypeArray1234 { + yyl1159 := r.ReadArrayStart() + if yyl1159 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1087, d) + x.codecDecodeSelfFromArray(yyl1159, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -12818,12 +13517,12 @@ func (x *IngressStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1088Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1088Slc - var yyhl1088 bool = l >= 0 - for yyj1088 := 0; ; yyj1088++ { - if yyhl1088 { - if yyj1088 >= l { + var yys1160Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1160Slc + var yyhl1160 bool = l >= 0 + for yyj1160 := 0; ; yyj1160++ { + if yyhl1160 { + if yyj1160 >= l { break } } else { @@ -12832,21 +13531,21 @@ func (x *IngressStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1088Slc = r.DecodeBytes(yys1088Slc, true, true) - yys1088 := string(yys1088Slc) + yys1160Slc = r.DecodeBytes(yys1160Slc, true, true) + yys1160 := string(yys1160Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1088 { + switch yys1160 { case "loadBalancer": if r.TryDecodeAsNil() { x.LoadBalancer = pkg2_v1.LoadBalancerStatus{} } else { - yyv1089 := &x.LoadBalancer - yyv1089.CodecDecodeSelf(d) + yyv1161 := &x.LoadBalancer + yyv1161.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1088) - } // end switch yys1088 - } // end for yyj1088 + z.DecStructFieldNotFound(-1, yys1160) + } // end switch yys1160 + } // end for yyj1160 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -12854,16 +13553,16 @@ func (x *IngressStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1090 int - var yyb1090 bool - var yyhl1090 bool = l >= 0 - yyj1090++ - if yyhl1090 { - yyb1090 = yyj1090 > l + var yyj1162 int + var yyb1162 bool + var yyhl1162 bool = l >= 0 + yyj1162++ + if yyhl1162 { + yyb1162 = yyj1162 > l } else { - yyb1090 = r.CheckBreak() + yyb1162 = r.CheckBreak() } - if yyb1090 { + if yyb1162 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -12871,21 +13570,21 @@ func (x *IngressStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.LoadBalancer = pkg2_v1.LoadBalancerStatus{} } else { - yyv1091 := &x.LoadBalancer - yyv1091.CodecDecodeSelf(d) + yyv1163 := &x.LoadBalancer + yyv1163.CodecDecodeSelf(d) } for { - yyj1090++ - if yyhl1090 { - yyb1090 = yyj1090 > l + yyj1162++ + if yyhl1162 { + yyb1162 = yyj1162 > l } else { - yyb1090 = r.CheckBreak() + yyb1162 = r.CheckBreak() } - if yyb1090 { + if yyb1162 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1090-1, "") + z.DecStructFieldNotFound(yyj1162-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -12897,36 +13596,36 @@ func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1092 := z.EncBinary() - _ = yym1092 + yym1164 := z.EncBinary() + _ = yym1164 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1093 := !z.EncBinary() - yy2arr1093 := z.EncBasicHandle().StructToArray - var yyq1093 [2]bool - _, _, _ = yysep1093, yyq1093, yy2arr1093 - const yyr1093 bool = false - yyq1093[0] = x.Host != "" - yyq1093[1] = x.IngressRuleValue.HTTP != nil && x.HTTP != nil - var yynn1093 int - if yyr1093 || yy2arr1093 { + yysep1165 := !z.EncBinary() + yy2arr1165 := z.EncBasicHandle().StructToArray + var yyq1165 [2]bool + _, _, _ = yysep1165, yyq1165, yy2arr1165 + const yyr1165 bool = false + yyq1165[0] = x.Host != "" + yyq1165[1] = x.IngressRuleValue.HTTP != nil && x.HTTP != nil + var yynn1165 int + if yyr1165 || yy2arr1165 { r.EncodeArrayStart(2) } else { - yynn1093 = 0 - for _, b := range yyq1093 { + yynn1165 = 0 + for _, b := range yyq1165 { if b { - yynn1093++ + yynn1165++ } } - r.EncodeMapStart(yynn1093) - yynn1093 = 0 + r.EncodeMapStart(yynn1165) + yynn1165 = 0 } - if yyr1093 || yy2arr1093 { + if yyr1165 || yy2arr1165 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1093[0] { - yym1095 := z.EncBinary() - _ = yym1095 + if yyq1165[0] { + yym1167 := z.EncBinary() + _ = yym1167 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) @@ -12935,30 +13634,30 @@ func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1093[0] { + if yyq1165[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("host")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1096 := z.EncBinary() - _ = yym1096 + yym1168 := z.EncBinary() + _ = yym1168 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Host)) } } } - var yyn1097 bool + var yyn1169 bool if x.IngressRuleValue.HTTP == nil { - yyn1097 = true - goto LABEL1097 + yyn1169 = true + goto LABEL1169 } - LABEL1097: - if yyr1093 || yy2arr1093 { - if yyn1097 { + LABEL1169: + if yyr1165 || yy2arr1165 { + if yyn1169 { r.EncodeNil() } else { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1093[1] { + if yyq1165[1] { if x.HTTP == nil { r.EncodeNil() } else { @@ -12969,11 +13668,11 @@ func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } else { - if yyq1093[1] { + if yyq1165[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("http")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - if yyn1097 { + if yyn1169 { r.EncodeNil() } else { if x.HTTP == nil { @@ -12984,7 +13683,7 @@ func (x *IngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1093 || yy2arr1093 { + if yyr1165 || yy2arr1165 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -12997,25 +13696,25 @@ func (x *IngressRule) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1098 := z.DecBinary() - _ = yym1098 + yym1170 := z.DecBinary() + _ = yym1170 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1099 := r.ContainerType() - if yyct1099 == codecSelferValueTypeMap1234 { - yyl1099 := r.ReadMapStart() - if yyl1099 == 0 { + yyct1171 := r.ContainerType() + if yyct1171 == codecSelferValueTypeMap1234 { + yyl1171 := r.ReadMapStart() + if yyl1171 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1099, d) + x.codecDecodeSelfFromMap(yyl1171, d) } - } else if yyct1099 == codecSelferValueTypeArray1234 { - yyl1099 := r.ReadArrayStart() - if yyl1099 == 0 { + } else if yyct1171 == codecSelferValueTypeArray1234 { + yyl1171 := r.ReadArrayStart() + if yyl1171 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1099, d) + x.codecDecodeSelfFromArray(yyl1171, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -13027,12 +13726,12 @@ func (x *IngressRule) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1100Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1100Slc - var yyhl1100 bool = l >= 0 - for yyj1100 := 0; ; yyj1100++ { - if yyhl1100 { - if yyj1100 >= l { + var yys1172Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1172Slc + var yyhl1172 bool = l >= 0 + for yyj1172 := 0; ; yyj1172++ { + if yyhl1172 { + if yyj1172 >= l { break } } else { @@ -13041,10 +13740,10 @@ func (x *IngressRule) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1100Slc = r.DecodeBytes(yys1100Slc, true, true) - yys1100 := string(yys1100Slc) + yys1172Slc = r.DecodeBytes(yys1172Slc, true, true) + yys1172 := string(yys1172Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1100 { + switch yys1172 { case "host": if r.TryDecodeAsNil() { x.Host = "" @@ -13066,9 +13765,9 @@ func (x *IngressRule) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.HTTP.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1100) - } // end switch yys1100 - } // end for yyj1100 + z.DecStructFieldNotFound(-1, yys1172) + } // end switch yys1172 + } // end for yyj1172 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -13076,16 +13775,16 @@ func (x *IngressRule) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1103 int - var yyb1103 bool - var yyhl1103 bool = l >= 0 - yyj1103++ - if yyhl1103 { - yyb1103 = yyj1103 > l + var yyj1175 int + var yyb1175 bool + var yyhl1175 bool = l >= 0 + yyj1175++ + if yyhl1175 { + yyb1175 = yyj1175 > l } else { - yyb1103 = r.CheckBreak() + yyb1175 = r.CheckBreak() } - if yyb1103 { + if yyb1175 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -13098,13 +13797,13 @@ func (x *IngressRule) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if x.IngressRuleValue.HTTP == nil { x.IngressRuleValue.HTTP = new(HTTPIngressRuleValue) } - yyj1103++ - if yyhl1103 { - yyb1103 = yyj1103 > l + yyj1175++ + if yyhl1175 { + yyb1175 = yyj1175 > l } else { - yyb1103 = r.CheckBreak() + yyb1175 = r.CheckBreak() } - if yyb1103 { + if yyb1175 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -13120,17 +13819,17 @@ func (x *IngressRule) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.HTTP.CodecDecodeSelf(d) } for { - yyj1103++ - if yyhl1103 { - yyb1103 = yyj1103 > l + yyj1175++ + if yyhl1175 { + yyb1175 = yyj1175 > l } else { - yyb1103 = r.CheckBreak() + yyb1175 = r.CheckBreak() } - if yyb1103 { + if yyb1175 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1103-1, "") + z.DecStructFieldNotFound(yyj1175-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -13142,33 +13841,33 @@ func (x *IngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1106 := z.EncBinary() - _ = yym1106 + yym1178 := z.EncBinary() + _ = yym1178 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1107 := !z.EncBinary() - yy2arr1107 := z.EncBasicHandle().StructToArray - var yyq1107 [1]bool - _, _, _ = yysep1107, yyq1107, yy2arr1107 - const yyr1107 bool = false - yyq1107[0] = x.HTTP != nil - var yynn1107 int - if yyr1107 || yy2arr1107 { + yysep1179 := !z.EncBinary() + yy2arr1179 := z.EncBasicHandle().StructToArray + var yyq1179 [1]bool + _, _, _ = yysep1179, yyq1179, yy2arr1179 + const yyr1179 bool = false + yyq1179[0] = x.HTTP != nil + var yynn1179 int + if yyr1179 || yy2arr1179 { r.EncodeArrayStart(1) } else { - yynn1107 = 0 - for _, b := range yyq1107 { + yynn1179 = 0 + for _, b := range yyq1179 { if b { - yynn1107++ + yynn1179++ } } - r.EncodeMapStart(yynn1107) - yynn1107 = 0 + r.EncodeMapStart(yynn1179) + yynn1179 = 0 } - if yyr1107 || yy2arr1107 { + if yyr1179 || yy2arr1179 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1107[0] { + if yyq1179[0] { if x.HTTP == nil { r.EncodeNil() } else { @@ -13178,7 +13877,7 @@ func (x *IngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1107[0] { + if yyq1179[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("http")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -13189,7 +13888,7 @@ func (x *IngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1107 || yy2arr1107 { + if yyr1179 || yy2arr1179 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -13202,25 +13901,25 @@ func (x *IngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1109 := z.DecBinary() - _ = yym1109 + yym1181 := z.DecBinary() + _ = yym1181 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1110 := r.ContainerType() - if yyct1110 == codecSelferValueTypeMap1234 { - yyl1110 := r.ReadMapStart() - if yyl1110 == 0 { + yyct1182 := r.ContainerType() + if yyct1182 == codecSelferValueTypeMap1234 { + yyl1182 := r.ReadMapStart() + if yyl1182 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1110, d) + x.codecDecodeSelfFromMap(yyl1182, d) } - } else if yyct1110 == codecSelferValueTypeArray1234 { - yyl1110 := r.ReadArrayStart() - if yyl1110 == 0 { + } else if yyct1182 == codecSelferValueTypeArray1234 { + yyl1182 := r.ReadArrayStart() + if yyl1182 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1110, d) + x.codecDecodeSelfFromArray(yyl1182, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -13232,12 +13931,12 @@ func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1111Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1111Slc - var yyhl1111 bool = l >= 0 - for yyj1111 := 0; ; yyj1111++ { - if yyhl1111 { - if yyj1111 >= l { + var yys1183Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1183Slc + var yyhl1183 bool = l >= 0 + for yyj1183 := 0; ; yyj1183++ { + if yyhl1183 { + if yyj1183 >= l { break } } else { @@ -13246,10 +13945,10 @@ func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1111Slc = r.DecodeBytes(yys1111Slc, true, true) - yys1111 := string(yys1111Slc) + yys1183Slc = r.DecodeBytes(yys1183Slc, true, true) + yys1183 := string(yys1183Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1111 { + switch yys1183 { case "http": if r.TryDecodeAsNil() { if x.HTTP != nil { @@ -13262,884 +13961,13 @@ func (x *IngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.HTTP.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1111) - } // end switch yys1111 - } // end for yyj1111 + z.DecStructFieldNotFound(-1, yys1183) + } // end switch yys1183 + } // end for yyj1183 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } func (x *IngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1113 int - var yyb1113 bool - var yyhl1113 bool = l >= 0 - yyj1113++ - if yyhl1113 { - yyb1113 = yyj1113 > l - } else { - yyb1113 = r.CheckBreak() - } - if yyb1113 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.HTTP != nil { - x.HTTP = nil - } - } else { - if x.HTTP == nil { - x.HTTP = new(HTTPIngressRuleValue) - } - x.HTTP.CodecDecodeSelf(d) - } - for { - yyj1113++ - if yyhl1113 { - yyb1113 = yyj1113 > l - } else { - yyb1113 = r.CheckBreak() - } - if yyb1113 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1113-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *HTTPIngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1115 := z.EncBinary() - _ = yym1115 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1116 := !z.EncBinary() - yy2arr1116 := z.EncBasicHandle().StructToArray - var yyq1116 [1]bool - _, _, _ = yysep1116, yyq1116, yy2arr1116 - const yyr1116 bool = false - var yynn1116 int - if yyr1116 || yy2arr1116 { - r.EncodeArrayStart(1) - } else { - yynn1116 = 1 - for _, b := range yyq1116 { - if b { - yynn1116++ - } - } - r.EncodeMapStart(yynn1116) - yynn1116 = 0 - } - if yyr1116 || yy2arr1116 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.Paths == nil { - r.EncodeNil() - } else { - yym1118 := z.EncBinary() - _ = yym1118 - if false { - } else { - h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("paths")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Paths == nil { - r.EncodeNil() - } else { - yym1119 := z.EncBinary() - _ = yym1119 - if false { - } else { - h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) - } - } - } - if yyr1116 || yy2arr1116 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *HTTPIngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1120 := z.DecBinary() - _ = yym1120 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1121 := r.ContainerType() - if yyct1121 == codecSelferValueTypeMap1234 { - yyl1121 := r.ReadMapStart() - if yyl1121 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1121, d) - } - } else if yyct1121 == codecSelferValueTypeArray1234 { - yyl1121 := r.ReadArrayStart() - if yyl1121 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1121, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *HTTPIngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1122Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1122Slc - var yyhl1122 bool = l >= 0 - for yyj1122 := 0; ; yyj1122++ { - if yyhl1122 { - if yyj1122 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1122Slc = r.DecodeBytes(yys1122Slc, true, true) - yys1122 := string(yys1122Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1122 { - case "paths": - if r.TryDecodeAsNil() { - x.Paths = nil - } else { - yyv1123 := &x.Paths - yym1124 := z.DecBinary() - _ = yym1124 - if false { - } else { - h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv1123), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys1122) - } // end switch yys1122 - } // end for yyj1122 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *HTTPIngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1125 int - var yyb1125 bool - var yyhl1125 bool = l >= 0 - yyj1125++ - if yyhl1125 { - yyb1125 = yyj1125 > l - } else { - yyb1125 = r.CheckBreak() - } - if yyb1125 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Paths = nil - } else { - yyv1126 := &x.Paths - yym1127 := z.DecBinary() - _ = yym1127 - if false { - } else { - h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv1126), d) - } - } - for { - yyj1125++ - if yyhl1125 { - yyb1125 = yyj1125 > l - } else { - yyb1125 = r.CheckBreak() - } - if yyb1125 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1125-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *HTTPIngressPath) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1128 := z.EncBinary() - _ = yym1128 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1129 := !z.EncBinary() - yy2arr1129 := z.EncBasicHandle().StructToArray - var yyq1129 [2]bool - _, _, _ = yysep1129, yyq1129, yy2arr1129 - const yyr1129 bool = false - yyq1129[0] = x.Path != "" - var yynn1129 int - if yyr1129 || yy2arr1129 { - r.EncodeArrayStart(2) - } else { - yynn1129 = 1 - for _, b := range yyq1129 { - if b { - yynn1129++ - } - } - r.EncodeMapStart(yynn1129) - yynn1129 = 0 - } - if yyr1129 || yy2arr1129 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1129[0] { - yym1131 := z.EncBinary() - _ = yym1131 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Path)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq1129[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("path")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1132 := z.EncBinary() - _ = yym1132 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Path)) - } - } - } - if yyr1129 || yy2arr1129 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1134 := &x.Backend - yy1134.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("backend")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1135 := &x.Backend - yy1135.CodecEncodeSelf(e) - } - if yyr1129 || yy2arr1129 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *HTTPIngressPath) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1136 := z.DecBinary() - _ = yym1136 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1137 := r.ContainerType() - if yyct1137 == codecSelferValueTypeMap1234 { - yyl1137 := r.ReadMapStart() - if yyl1137 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1137, d) - } - } else if yyct1137 == codecSelferValueTypeArray1234 { - yyl1137 := r.ReadArrayStart() - if yyl1137 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1137, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *HTTPIngressPath) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1138Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1138Slc - var yyhl1138 bool = l >= 0 - for yyj1138 := 0; ; yyj1138++ { - if yyhl1138 { - if yyj1138 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1138Slc = r.DecodeBytes(yys1138Slc, true, true) - yys1138 := string(yys1138Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1138 { - case "path": - if r.TryDecodeAsNil() { - x.Path = "" - } else { - x.Path = string(r.DecodeString()) - } - case "backend": - if r.TryDecodeAsNil() { - x.Backend = IngressBackend{} - } else { - yyv1140 := &x.Backend - yyv1140.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys1138) - } // end switch yys1138 - } // end for yyj1138 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *HTTPIngressPath) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1141 int - var yyb1141 bool - var yyhl1141 bool = l >= 0 - yyj1141++ - if yyhl1141 { - yyb1141 = yyj1141 > l - } else { - yyb1141 = r.CheckBreak() - } - if yyb1141 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Path = "" - } else { - x.Path = string(r.DecodeString()) - } - yyj1141++ - if yyhl1141 { - yyb1141 = yyj1141 > l - } else { - yyb1141 = r.CheckBreak() - } - if yyb1141 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Backend = IngressBackend{} - } else { - yyv1143 := &x.Backend - yyv1143.CodecDecodeSelf(d) - } - for { - yyj1141++ - if yyhl1141 { - yyb1141 = yyj1141 > l - } else { - yyb1141 = r.CheckBreak() - } - if yyb1141 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1141-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *IngressBackend) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1144 := z.EncBinary() - _ = yym1144 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1145 := !z.EncBinary() - yy2arr1145 := z.EncBasicHandle().StructToArray - var yyq1145 [2]bool - _, _, _ = yysep1145, yyq1145, yy2arr1145 - const yyr1145 bool = false - var yynn1145 int - if yyr1145 || yy2arr1145 { - r.EncodeArrayStart(2) - } else { - yynn1145 = 2 - for _, b := range yyq1145 { - if b { - yynn1145++ - } - } - r.EncodeMapStart(yynn1145) - yynn1145 = 0 - } - if yyr1145 || yy2arr1145 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1147 := z.EncBinary() - _ = yym1147 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("serviceName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1148 := z.EncBinary() - _ = yym1148 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) - } - } - if yyr1145 || yy2arr1145 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1150 := &x.ServicePort - yym1151 := z.EncBinary() - _ = yym1151 - if false { - } else if z.HasExtensions() && z.EncExt(yy1150) { - } else if !yym1151 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1150) - } else { - z.EncFallback(yy1150) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("servicePort")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1152 := &x.ServicePort - yym1153 := z.EncBinary() - _ = yym1153 - if false { - } else if z.HasExtensions() && z.EncExt(yy1152) { - } else if !yym1153 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1152) - } else { - z.EncFallback(yy1152) - } - } - if yyr1145 || yy2arr1145 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *IngressBackend) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1154 := z.DecBinary() - _ = yym1154 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1155 := r.ContainerType() - if yyct1155 == codecSelferValueTypeMap1234 { - yyl1155 := r.ReadMapStart() - if yyl1155 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1155, d) - } - } else if yyct1155 == codecSelferValueTypeArray1234 { - yyl1155 := r.ReadArrayStart() - if yyl1155 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1155, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *IngressBackend) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1156Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1156Slc - var yyhl1156 bool = l >= 0 - for yyj1156 := 0; ; yyj1156++ { - if yyhl1156 { - if yyj1156 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1156Slc = r.DecodeBytes(yys1156Slc, true, true) - yys1156 := string(yys1156Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1156 { - case "serviceName": - if r.TryDecodeAsNil() { - x.ServiceName = "" - } else { - x.ServiceName = string(r.DecodeString()) - } - case "servicePort": - if r.TryDecodeAsNil() { - x.ServicePort = pkg5_intstr.IntOrString{} - } else { - yyv1158 := &x.ServicePort - yym1159 := z.DecBinary() - _ = yym1159 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1158) { - } else if !yym1159 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1158) - } else { - z.DecFallback(yyv1158, false) - } - } - default: - z.DecStructFieldNotFound(-1, yys1156) - } // end switch yys1156 - } // end for yyj1156 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *IngressBackend) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1160 int - var yyb1160 bool - var yyhl1160 bool = l >= 0 - yyj1160++ - if yyhl1160 { - yyb1160 = yyj1160 > l - } else { - yyb1160 = r.CheckBreak() - } - if yyb1160 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServiceName = "" - } else { - x.ServiceName = string(r.DecodeString()) - } - yyj1160++ - if yyhl1160 { - yyb1160 = yyj1160 > l - } else { - yyb1160 = r.CheckBreak() - } - if yyb1160 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServicePort = pkg5_intstr.IntOrString{} - } else { - yyv1162 := &x.ServicePort - yym1163 := z.DecBinary() - _ = yym1163 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1162) { - } else if !yym1163 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1162) - } else { - z.DecFallback(yyv1162, false) - } - } - for { - yyj1160++ - if yyhl1160 { - yyb1160 = yyj1160 > l - } else { - yyb1160 = r.CheckBreak() - } - if yyb1160 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1160-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1164 := z.EncBinary() - _ = yym1164 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1165 := !z.EncBinary() - yy2arr1165 := z.EncBasicHandle().StructToArray - var yyq1165 [4]bool - _, _, _ = yysep1165, yyq1165, yy2arr1165 - const yyr1165 bool = false - yyq1165[0] = x.Kind != "" - yyq1165[1] = x.APIVersion != "" - var yynn1165 int - if yyr1165 || yy2arr1165 { - r.EncodeArrayStart(4) - } else { - yynn1165 = 2 - for _, b := range yyq1165 { - if b { - yynn1165++ - } - } - r.EncodeMapStart(yynn1165) - yynn1165 = 0 - } - if yyr1165 || yy2arr1165 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1165[0] { - yym1167 := z.EncBinary() - _ = yym1167 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq1165[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1168 := z.EncBinary() - _ = yym1168 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr1165 || yy2arr1165 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1165[1] { - yym1170 := z.EncBinary() - _ = yym1170 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq1165[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1171 := z.EncBinary() - _ = yym1171 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr1165 || yy2arr1165 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1173 := z.EncBinary() - _ = yym1173 - if false { - } else { - r.EncodeBool(bool(x.Export)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("export")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1174 := z.EncBinary() - _ = yym1174 - if false { - } else { - r.EncodeBool(bool(x.Export)) - } - } - if yyr1165 || yy2arr1165 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1176 := z.EncBinary() - _ = yym1176 - if false { - } else { - r.EncodeBool(bool(x.Exact)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("exact")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1177 := z.EncBinary() - _ = yym1177 - if false { - } else { - r.EncodeBool(bool(x.Exact)) - } - } - if yyr1165 || yy2arr1165 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *ExportOptions) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1178 := z.DecBinary() - _ = yym1178 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1179 := r.ContainerType() - if yyct1179 == codecSelferValueTypeMap1234 { - yyl1179 := r.ReadMapStart() - if yyl1179 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1179, d) - } - } else if yyct1179 == codecSelferValueTypeArray1234 { - yyl1179 := r.ReadArrayStart() - if yyl1179 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1179, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1180Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1180Slc - var yyhl1180 bool = l >= 0 - for yyj1180 := 0; ; yyj1180++ { - if yyhl1180 { - if yyj1180 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1180Slc = r.DecodeBytes(yys1180Slc, true, true) - yys1180 := string(yys1180Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1180 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "export": - if r.TryDecodeAsNil() { - x.Export = false - } else { - x.Export = bool(r.DecodeBool()) - } - case "exact": - if r.TryDecodeAsNil() { - x.Exact = false - } else { - x.Exact = bool(r.DecodeBool()) - } - default: - z.DecStructFieldNotFound(-1, yys1180) - } // end switch yys1180 - } // end for yyj1180 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -14158,57 +13986,14 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.Kind = "" + if x.HTTP != nil { + x.HTTP = nil + } } else { - x.Kind = string(r.DecodeString()) - } - yyj1185++ - if yyhl1185 { - yyb1185 = yyj1185 > l - } else { - yyb1185 = r.CheckBreak() - } - if yyb1185 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj1185++ - if yyhl1185 { - yyb1185 = yyj1185 > l - } else { - yyb1185 = r.CheckBreak() - } - if yyb1185 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Export = false - } else { - x.Export = bool(r.DecodeBool()) - } - yyj1185++ - if yyhl1185 { - yyb1185 = yyj1185 > l - } else { - yyb1185 = r.CheckBreak() - } - if yyb1185 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Exact = false - } else { - x.Exact = bool(r.DecodeBool()) + if x.HTTP == nil { + x.HTTP = new(HTTPIngressRuleValue) + } + x.HTTP.CodecDecodeSelf(d) } for { yyj1185++ @@ -14226,687 +14011,742 @@ func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x *LabelSelector) CodecEncodeSelf(e *codec1978.Encoder) { +func (x *HTTPIngressRuleValue) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r if x == nil { r.EncodeNil() } else { - yym1190 := z.EncBinary() - _ = yym1190 + yym1187 := z.EncBinary() + _ = yym1187 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1191 := !z.EncBinary() - yy2arr1191 := z.EncBasicHandle().StructToArray - var yyq1191 [2]bool - _, _, _ = yysep1191, yyq1191, yy2arr1191 - const yyr1191 bool = false - yyq1191[0] = len(x.MatchLabels) != 0 - yyq1191[1] = len(x.MatchExpressions) != 0 - var yynn1191 int - if yyr1191 || yy2arr1191 { - r.EncodeArrayStart(2) + yysep1188 := !z.EncBinary() + yy2arr1188 := z.EncBasicHandle().StructToArray + var yyq1188 [1]bool + _, _, _ = yysep1188, yyq1188, yy2arr1188 + const yyr1188 bool = false + var yynn1188 int + if yyr1188 || yy2arr1188 { + r.EncodeArrayStart(1) } else { - yynn1191 = 0 - for _, b := range yyq1191 { + yynn1188 = 1 + for _, b := range yyq1188 { if b { - yynn1191++ + yynn1188++ } } - r.EncodeMapStart(yynn1191) - yynn1191 = 0 + r.EncodeMapStart(yynn1188) + yynn1188 = 0 } - if yyr1191 || yy2arr1191 { + if yyr1188 || yy2arr1188 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1191[0] { - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym1193 := z.EncBinary() - _ = yym1193 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } else { + if x.Paths == nil { r.EncodeNil() - } - } else { - if yyq1191[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchLabels")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchLabels == nil { - r.EncodeNil() - } else { - yym1194 := z.EncBinary() - _ = yym1194 - if false { - } else { - z.F.EncMapStringStringV(x.MatchLabels, false, e) - } - } - } - } - if yyr1191 || yy2arr1191 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1191[1] { - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym1196 := z.EncBinary() - _ = yym1196 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } } else { - r.EncodeNil() - } - } else { - if yyq1191[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("matchExpressions")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.MatchExpressions == nil { - r.EncodeNil() - } else { - yym1197 := z.EncBinary() - _ = yym1197 - if false { - } else { - h.encSliceLabelSelectorRequirement(([]LabelSelectorRequirement)(x.MatchExpressions), e) - } - } - } - } - if yyr1191 || yy2arr1191 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelector) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1198 := z.DecBinary() - _ = yym1198 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1199 := r.ContainerType() - if yyct1199 == codecSelferValueTypeMap1234 { - yyl1199 := r.ReadMapStart() - if yyl1199 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1199, d) - } - } else if yyct1199 == codecSelferValueTypeArray1234 { - yyl1199 := r.ReadArrayStart() - if yyl1199 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1199, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelector) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1200Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1200Slc - var yyhl1200 bool = l >= 0 - for yyj1200 := 0; ; yyj1200++ { - if yyhl1200 { - if yyj1200 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1200Slc = r.DecodeBytes(yys1200Slc, true, true) - yys1200 := string(yys1200Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1200 { - case "matchLabels": - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv1201 := &x.MatchLabels - yym1202 := z.DecBinary() - _ = yym1202 - if false { - } else { - z.F.DecMapStringStringX(yyv1201, false, d) - } - } - case "matchExpressions": - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv1203 := &x.MatchExpressions - yym1204 := z.DecBinary() - _ = yym1204 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv1203), d) - } - } - default: - z.DecStructFieldNotFound(-1, yys1200) - } // end switch yys1200 - } // end for yyj1200 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelector) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1205 int - var yyb1205 bool - var yyhl1205 bool = l >= 0 - yyj1205++ - if yyhl1205 { - yyb1205 = yyj1205 > l - } else { - yyb1205 = r.CheckBreak() - } - if yyb1205 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchLabels = nil - } else { - yyv1206 := &x.MatchLabels - yym1207 := z.DecBinary() - _ = yym1207 - if false { - } else { - z.F.DecMapStringStringX(yyv1206, false, d) - } - } - yyj1205++ - if yyhl1205 { - yyb1205 = yyj1205 > l - } else { - yyb1205 = r.CheckBreak() - } - if yyb1205 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MatchExpressions = nil - } else { - yyv1208 := &x.MatchExpressions - yym1209 := z.DecBinary() - _ = yym1209 - if false { - } else { - h.decSliceLabelSelectorRequirement((*[]LabelSelectorRequirement)(yyv1208), d) - } - } - for { - yyj1205++ - if yyhl1205 { - yyb1205 = yyj1205 > l - } else { - yyb1205 = r.CheckBreak() - } - if yyb1205 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1205-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *LabelSelectorRequirement) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1210 := z.EncBinary() - _ = yym1210 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1211 := !z.EncBinary() - yy2arr1211 := z.EncBasicHandle().StructToArray - var yyq1211 [3]bool - _, _, _ = yysep1211, yyq1211, yy2arr1211 - const yyr1211 bool = false - yyq1211[2] = len(x.Values) != 0 - var yynn1211 int - if yyr1211 || yy2arr1211 { - r.EncodeArrayStart(3) - } else { - yynn1211 = 2 - for _, b := range yyq1211 { - if b { - yynn1211++ - } - } - r.EncodeMapStart(yynn1211) - yynn1211 = 0 - } - if yyr1211 || yy2arr1211 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1213 := z.EncBinary() - _ = yym1213 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("key")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1214 := z.EncBinary() - _ = yym1214 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Key)) - } - } - if yyr1211 || yy2arr1211 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - x.Operator.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("operator")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Operator.CodecEncodeSelf(e) - } - if yyr1211 || yy2arr1211 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1211[2] { - if x.Values == nil { - r.EncodeNil() - } else { - yym1217 := z.EncBinary() - _ = yym1217 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq1211[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("values")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Values == nil { - r.EncodeNil() - } else { - yym1218 := z.EncBinary() - _ = yym1218 - if false { - } else { - z.F.EncSliceStringV(x.Values, false, e) - } - } - } - } - if yyr1211 || yy2arr1211 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LabelSelectorRequirement) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1219 := z.DecBinary() - _ = yym1219 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1220 := r.ContainerType() - if yyct1220 == codecSelferValueTypeMap1234 { - yyl1220 := r.ReadMapStart() - if yyl1220 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1220, d) - } - } else if yyct1220 == codecSelferValueTypeArray1234 { - yyl1220 := r.ReadArrayStart() - if yyl1220 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1220, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1221Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1221Slc - var yyhl1221 bool = l >= 0 - for yyj1221 := 0; ; yyj1221++ { - if yyhl1221 { - if yyj1221 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1221Slc = r.DecodeBytes(yys1221Slc, true, true) - yys1221 := string(yys1221Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1221 { - case "key": - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - case "operator": - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - case "values": - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv1224 := &x.Values - yym1225 := z.DecBinary() - _ = yym1225 - if false { - } else { - z.F.DecSliceStringX(yyv1224, false, d) - } - } - default: - z.DecStructFieldNotFound(-1, yys1221) - } // end switch yys1221 - } // end for yyj1221 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LabelSelectorRequirement) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1226 int - var yyb1226 bool - var yyhl1226 bool = l >= 0 - yyj1226++ - if yyhl1226 { - yyb1226 = yyj1226 > l - } else { - yyb1226 = r.CheckBreak() - } - if yyb1226 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Key = "" - } else { - x.Key = string(r.DecodeString()) - } - yyj1226++ - if yyhl1226 { - yyb1226 = yyj1226 > l - } else { - yyb1226 = r.CheckBreak() - } - if yyb1226 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Operator = "" - } else { - x.Operator = LabelSelectorOperator(r.DecodeString()) - } - yyj1226++ - if yyhl1226 { - yyb1226 = yyj1226 > l - } else { - yyb1226 = r.CheckBreak() - } - if yyb1226 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Values = nil - } else { - yyv1229 := &x.Values - yym1230 := z.DecBinary() - _ = yym1230 - if false { - } else { - z.F.DecSliceStringX(yyv1229, false, d) - } - } - for { - yyj1226++ - if yyhl1226 { - yyb1226 = yyj1226 > l - } else { - yyb1226 = r.CheckBreak() - } - if yyb1226 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1226-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x LabelSelectorOperator) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym1231 := z.EncBinary() - _ = yym1231 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *LabelSelectorOperator) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1232 := z.DecBinary() - _ = yym1232 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - -func (x *ReplicaSet) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1233 := z.EncBinary() - _ = yym1233 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1234 := !z.EncBinary() - yy2arr1234 := z.EncBasicHandle().StructToArray - var yyq1234 [5]bool - _, _, _ = yysep1234, yyq1234, yy2arr1234 - const yyr1234 bool = false - yyq1234[0] = x.Kind != "" - yyq1234[1] = x.APIVersion != "" - yyq1234[2] = true - yyq1234[3] = true - yyq1234[4] = true - var yynn1234 int - if yyr1234 || yy2arr1234 { - r.EncodeArrayStart(5) - } else { - yynn1234 = 0 - for _, b := range yyq1234 { - if b { - yynn1234++ - } - } - r.EncodeMapStart(yynn1234) - yynn1234 = 0 - } - if yyr1234 || yy2arr1234 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1234[0] { - yym1236 := z.EncBinary() - _ = yym1236 + yym1190 := z.EncBinary() + _ = yym1190 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) + } + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("paths")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Paths == nil { + r.EncodeNil() + } else { + yym1191 := z.EncBinary() + _ = yym1191 + if false { + } else { + h.encSliceHTTPIngressPath(([]HTTPIngressPath)(x.Paths), e) + } + } + } + if yyr1188 || yy2arr1188 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *HTTPIngressRuleValue) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1192 := z.DecBinary() + _ = yym1192 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1193 := r.ContainerType() + if yyct1193 == codecSelferValueTypeMap1234 { + yyl1193 := r.ReadMapStart() + if yyl1193 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1193, d) + } + } else if yyct1193 == codecSelferValueTypeArray1234 { + yyl1193 := r.ReadArrayStart() + if yyl1193 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1193, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *HTTPIngressRuleValue) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1194Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1194Slc + var yyhl1194 bool = l >= 0 + for yyj1194 := 0; ; yyj1194++ { + if yyhl1194 { + if yyj1194 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1194Slc = r.DecodeBytes(yys1194Slc, true, true) + yys1194 := string(yys1194Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1194 { + case "paths": + if r.TryDecodeAsNil() { + x.Paths = nil + } else { + yyv1195 := &x.Paths + yym1196 := z.DecBinary() + _ = yym1196 + if false { + } else { + h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv1195), d) + } + } + default: + z.DecStructFieldNotFound(-1, yys1194) + } // end switch yys1194 + } // end for yyj1194 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *HTTPIngressRuleValue) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1197 int + var yyb1197 bool + var yyhl1197 bool = l >= 0 + yyj1197++ + if yyhl1197 { + yyb1197 = yyj1197 > l + } else { + yyb1197 = r.CheckBreak() + } + if yyb1197 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Paths = nil + } else { + yyv1198 := &x.Paths + yym1199 := z.DecBinary() + _ = yym1199 + if false { + } else { + h.decSliceHTTPIngressPath((*[]HTTPIngressPath)(yyv1198), d) + } + } + for { + yyj1197++ + if yyhl1197 { + yyb1197 = yyj1197 > l + } else { + yyb1197 = r.CheckBreak() + } + if yyb1197 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1197-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *HTTPIngressPath) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1200 := z.EncBinary() + _ = yym1200 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1201 := !z.EncBinary() + yy2arr1201 := z.EncBasicHandle().StructToArray + var yyq1201 [2]bool + _, _, _ = yysep1201, yyq1201, yy2arr1201 + const yyr1201 bool = false + yyq1201[0] = x.Path != "" + var yynn1201 int + if yyr1201 || yy2arr1201 { + r.EncodeArrayStart(2) + } else { + yynn1201 = 1 + for _, b := range yyq1201 { + if b { + yynn1201++ + } + } + r.EncodeMapStart(yynn1201) + yynn1201 = 0 + } + if yyr1201 || yy2arr1201 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1201[0] { + yym1203 := z.EncBinary() + _ = yym1203 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1234[0] { + if yyq1201[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) + r.EncodeString(codecSelferC_UTF81234, string("path")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1237 := z.EncBinary() - _ = yym1237 + yym1204 := z.EncBinary() + _ = yym1204 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + r.EncodeString(codecSelferC_UTF81234, string(x.Path)) } } } - if yyr1234 || yy2arr1234 { + if yyr1201 || yy2arr1201 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1234[1] { + yy1206 := &x.Backend + yy1206.CodecEncodeSelf(e) + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("backend")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1207 := &x.Backend + yy1207.CodecEncodeSelf(e) + } + if yyr1201 || yy2arr1201 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *HTTPIngressPath) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1208 := z.DecBinary() + _ = yym1208 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1209 := r.ContainerType() + if yyct1209 == codecSelferValueTypeMap1234 { + yyl1209 := r.ReadMapStart() + if yyl1209 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1209, d) + } + } else if yyct1209 == codecSelferValueTypeArray1234 { + yyl1209 := r.ReadArrayStart() + if yyl1209 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1209, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *HTTPIngressPath) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1210Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1210Slc + var yyhl1210 bool = l >= 0 + for yyj1210 := 0; ; yyj1210++ { + if yyhl1210 { + if yyj1210 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1210Slc = r.DecodeBytes(yys1210Slc, true, true) + yys1210 := string(yys1210Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1210 { + case "path": + if r.TryDecodeAsNil() { + x.Path = "" + } else { + x.Path = string(r.DecodeString()) + } + case "backend": + if r.TryDecodeAsNil() { + x.Backend = IngressBackend{} + } else { + yyv1212 := &x.Backend + yyv1212.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys1210) + } // end switch yys1210 + } // end for yyj1210 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *HTTPIngressPath) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1213 int + var yyb1213 bool + var yyhl1213 bool = l >= 0 + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Path = "" + } else { + x.Path = string(r.DecodeString()) + } + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Backend = IngressBackend{} + } else { + yyv1215 := &x.Backend + yyv1215.CodecDecodeSelf(d) + } + for { + yyj1213++ + if yyhl1213 { + yyb1213 = yyj1213 > l + } else { + yyb1213 = r.CheckBreak() + } + if yyb1213 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1213-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *IngressBackend) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1216 := z.EncBinary() + _ = yym1216 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1217 := !z.EncBinary() + yy2arr1217 := z.EncBasicHandle().StructToArray + var yyq1217 [2]bool + _, _, _ = yysep1217, yyq1217, yy2arr1217 + const yyr1217 bool = false + var yynn1217 int + if yyr1217 || yy2arr1217 { + r.EncodeArrayStart(2) + } else { + yynn1217 = 2 + for _, b := range yyq1217 { + if b { + yynn1217++ + } + } + r.EncodeMapStart(yynn1217) + yynn1217 = 0 + } + if yyr1217 || yy2arr1217 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym1219 := z.EncBinary() + _ = yym1219 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("serviceName")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1220 := z.EncBinary() + _ = yym1220 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.ServiceName)) + } + } + if yyr1217 || yy2arr1217 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1222 := &x.ServicePort + yym1223 := z.EncBinary() + _ = yym1223 + if false { + } else if z.HasExtensions() && z.EncExt(yy1222) { + } else if !yym1223 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1222) + } else { + z.EncFallback(yy1222) + } + } else { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("servicePort")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1224 := &x.ServicePort + yym1225 := z.EncBinary() + _ = yym1225 + if false { + } else if z.HasExtensions() && z.EncExt(yy1224) { + } else if !yym1225 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1224) + } else { + z.EncFallback(yy1224) + } + } + if yyr1217 || yy2arr1217 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *IngressBackend) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1226 := z.DecBinary() + _ = yym1226 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1227 := r.ContainerType() + if yyct1227 == codecSelferValueTypeMap1234 { + yyl1227 := r.ReadMapStart() + if yyl1227 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1227, d) + } + } else if yyct1227 == codecSelferValueTypeArray1234 { + yyl1227 := r.ReadArrayStart() + if yyl1227 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1227, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *IngressBackend) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1228Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1228Slc + var yyhl1228 bool = l >= 0 + for yyj1228 := 0; ; yyj1228++ { + if yyhl1228 { + if yyj1228 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1228Slc = r.DecodeBytes(yys1228Slc, true, true) + yys1228 := string(yys1228Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1228 { + case "serviceName": + if r.TryDecodeAsNil() { + x.ServiceName = "" + } else { + x.ServiceName = string(r.DecodeString()) + } + case "servicePort": + if r.TryDecodeAsNil() { + x.ServicePort = pkg5_intstr.IntOrString{} + } else { + yyv1230 := &x.ServicePort + yym1231 := z.DecBinary() + _ = yym1231 + if false { + } else if z.HasExtensions() && z.DecExt(yyv1230) { + } else if !yym1231 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1230) + } else { + z.DecFallback(yyv1230, false) + } + } + default: + z.DecStructFieldNotFound(-1, yys1228) + } // end switch yys1228 + } // end for yyj1228 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *IngressBackend) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1232 int + var yyb1232 bool + var yyhl1232 bool = l >= 0 + yyj1232++ + if yyhl1232 { + yyb1232 = yyj1232 > l + } else { + yyb1232 = r.CheckBreak() + } + if yyb1232 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ServiceName = "" + } else { + x.ServiceName = string(r.DecodeString()) + } + yyj1232++ + if yyhl1232 { + yyb1232 = yyj1232 > l + } else { + yyb1232 = r.CheckBreak() + } + if yyb1232 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ServicePort = pkg5_intstr.IntOrString{} + } else { + yyv1234 := &x.ServicePort + yym1235 := z.DecBinary() + _ = yym1235 + if false { + } else if z.HasExtensions() && z.DecExt(yyv1234) { + } else if !yym1235 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1234) + } else { + z.DecFallback(yyv1234, false) + } + } + for { + yyj1232++ + if yyhl1232 { + yyb1232 = yyj1232 > l + } else { + yyb1232 = r.CheckBreak() + } + if yyb1232 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1232-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *ExportOptions) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1236 := z.EncBinary() + _ = yym1236 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1237 := !z.EncBinary() + yy2arr1237 := z.EncBasicHandle().StructToArray + var yyq1237 [4]bool + _, _, _ = yysep1237, yyq1237, yy2arr1237 + const yyr1237 bool = false + yyq1237[0] = x.Kind != "" + yyq1237[1] = x.APIVersion != "" + var yynn1237 int + if yyr1237 || yy2arr1237 { + r.EncodeArrayStart(4) + } else { + yynn1237 = 2 + for _, b := range yyq1237 { + if b { + yynn1237++ + } + } + r.EncodeMapStart(yynn1237) + yynn1237 = 0 + } + if yyr1237 || yy2arr1237 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1237[0] { yym1239 := z.EncBinary() _ = yym1239 if false { } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1234[1] { + if yyq1237[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) yym1240 := z.EncBinary() _ = yym1240 if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr1237 || yy2arr1237 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1237[1] { + yym1242 := z.EncBinary() + _ = yym1242 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq1237[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1243 := z.EncBinary() + _ = yym1243 + if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1234 || yy2arr1234 { + if yyr1237 || yy2arr1237 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1234[2] { - yy1242 := &x.ObjectMeta - yy1242.CodecEncodeSelf(e) + yym1245 := z.EncBinary() + _ = yym1245 + if false { } else { - r.EncodeNil() + r.EncodeBool(bool(x.Export)) } } else { - if yyq1234[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("metadata")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1243 := &x.ObjectMeta - yy1243.CodecEncodeSelf(e) + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("export")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1246 := z.EncBinary() + _ = yym1246 + if false { + } else { + r.EncodeBool(bool(x.Export)) } } - if yyr1234 || yy2arr1234 { + if yyr1237 || yy2arr1237 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1234[3] { - yy1245 := &x.Spec - yy1245.CodecEncodeSelf(e) + yym1248 := z.EncBinary() + _ = yym1248 + if false { } else { - r.EncodeNil() + r.EncodeBool(bool(x.Exact)) } } else { - if yyq1234[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("spec")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1246 := &x.Spec - yy1246.CodecEncodeSelf(e) - } - } - if yyr1234 || yy2arr1234 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1234[4] { - yy1248 := &x.Status - yy1248.CodecEncodeSelf(e) + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("exact")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1249 := z.EncBinary() + _ = yym1249 + if false { } else { - r.EncodeNil() - } - } else { - if yyq1234[4] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("status")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1249 := &x.Status - yy1249.CodecEncodeSelf(e) + r.EncodeBool(bool(x.Exact)) } } - if yyr1234 || yy2arr1234 { + if yyr1237 || yy2arr1237 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -14915,7 +14755,7 @@ func (x *ReplicaSet) CodecEncodeSelf(e *codec1978.Encoder) { } } -func (x *ReplicaSet) CodecDecodeSelf(d *codec1978.Decoder) { +func (x *ExportOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -14945,7 +14785,7 @@ func (x *ReplicaSet) CodecDecodeSelf(d *codec1978.Decoder) { } } -func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { +func (x *ExportOptions) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -14979,26 +14819,17 @@ func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - case "metadata": + case "export": if r.TryDecodeAsNil() { - x.ObjectMeta = pkg2_v1.ObjectMeta{} + x.Export = false } else { - yyv1255 := &x.ObjectMeta - yyv1255.CodecDecodeSelf(d) + x.Export = bool(r.DecodeBool()) } - case "spec": + case "exact": if r.TryDecodeAsNil() { - x.Spec = ReplicaSetSpec{} + x.Exact = false } else { - yyv1256 := &x.Spec - yyv1256.CodecDecodeSelf(d) - } - case "status": - if r.TryDecodeAsNil() { - x.Status = ReplicaSetStatus{} - } else { - yyv1257 := &x.Status - yyv1257.CodecDecodeSelf(d) + x.Exact = bool(r.DecodeBool()) } default: z.DecStructFieldNotFound(-1, yys1252) @@ -15007,20 +14838,20 @@ func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } -func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { +func (x *ExportOptions) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1258 int - var yyb1258 bool - var yyhl1258 bool = l >= 0 - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + var yyj1257 int + var yyb1257 bool + var yyhl1257 bool = l >= 0 + yyj1257++ + if yyhl1257 { + yyb1257 = yyj1257 > l } else { - yyb1258 = r.CheckBreak() + yyb1257 = r.CheckBreak() } - if yyb1258 { + if yyb1257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15030,13 +14861,13 @@ func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + yyj1257++ + if yyhl1257 { + yyb1257 = yyj1257 > l } else { - yyb1258 = r.CheckBreak() + yyb1257 = r.CheckBreak() } - if yyb1258 { + if yyb1257 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15046,13 +14877,337 @@ func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + yyj1257++ + if yyhl1257 { + yyb1257 = yyj1257 > l } else { - yyb1258 = r.CheckBreak() + yyb1257 = r.CheckBreak() } - if yyb1258 { + if yyb1257 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Export = false + } else { + x.Export = bool(r.DecodeBool()) + } + yyj1257++ + if yyhl1257 { + yyb1257 = yyj1257 > l + } else { + yyb1257 = r.CheckBreak() + } + if yyb1257 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Exact = false + } else { + x.Exact = bool(r.DecodeBool()) + } + for { + yyj1257++ + if yyhl1257 { + yyb1257 = yyj1257 > l + } else { + yyb1257 = r.CheckBreak() + } + if yyb1257 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1257-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x *ReplicaSet) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1262 := z.EncBinary() + _ = yym1262 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1263 := !z.EncBinary() + yy2arr1263 := z.EncBasicHandle().StructToArray + var yyq1263 [5]bool + _, _, _ = yysep1263, yyq1263, yy2arr1263 + const yyr1263 bool = false + yyq1263[0] = x.Kind != "" + yyq1263[1] = x.APIVersion != "" + yyq1263[2] = true + yyq1263[3] = true + yyq1263[4] = true + var yynn1263 int + if yyr1263 || yy2arr1263 { + r.EncodeArrayStart(5) + } else { + yynn1263 = 0 + for _, b := range yyq1263 { + if b { + yynn1263++ + } + } + r.EncodeMapStart(yynn1263) + yynn1263 = 0 + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1263[0] { + yym1265 := z.EncBinary() + _ = yym1265 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq1263[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("kind")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1266 := z.EncBinary() + _ = yym1266 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) + } + } + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1263[1] { + yym1268 := z.EncBinary() + _ = yym1268 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } else { + r.EncodeString(codecSelferC_UTF81234, "") + } + } else { + if yyq1263[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1269 := z.EncBinary() + _ = yym1269 + if false { + } else { + r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) + } + } + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1263[2] { + yy1271 := &x.ObjectMeta + yy1271.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq1263[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("metadata")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1272 := &x.ObjectMeta + yy1272.CodecEncodeSelf(e) + } + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1263[3] { + yy1274 := &x.Spec + yy1274.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq1263[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("spec")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1275 := &x.Spec + yy1275.CodecEncodeSelf(e) + } + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1263[4] { + yy1277 := &x.Status + yy1277.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq1263[4] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("status")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1278 := &x.Status + yy1278.CodecEncodeSelf(e) + } + } + if yyr1263 || yy2arr1263 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *ReplicaSet) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1279 := z.DecBinary() + _ = yym1279 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1280 := r.ContainerType() + if yyct1280 == codecSelferValueTypeMap1234 { + yyl1280 := r.ReadMapStart() + if yyl1280 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1280, d) + } + } else if yyct1280 == codecSelferValueTypeArray1234 { + yyl1280 := r.ReadArrayStart() + if yyl1280 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1280, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *ReplicaSet) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1281Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1281Slc + var yyhl1281 bool = l >= 0 + for yyj1281 := 0; ; yyj1281++ { + if yyhl1281 { + if yyj1281 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1281Slc = r.DecodeBytes(yys1281Slc, true, true) + yys1281 := string(yys1281Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1281 { + case "kind": + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + case "apiVersion": + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + case "metadata": + if r.TryDecodeAsNil() { + x.ObjectMeta = pkg2_v1.ObjectMeta{} + } else { + yyv1284 := &x.ObjectMeta + yyv1284.CodecDecodeSelf(d) + } + case "spec": + if r.TryDecodeAsNil() { + x.Spec = ReplicaSetSpec{} + } else { + yyv1285 := &x.Spec + yyv1285.CodecDecodeSelf(d) + } + case "status": + if r.TryDecodeAsNil() { + x.Status = ReplicaSetStatus{} + } else { + yyv1286 := &x.Status + yyv1286.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys1281) + } // end switch yys1281 + } // end for yyj1281 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1287 int + var yyb1287 bool + var yyhl1287 bool = l >= 0 + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l + } else { + yyb1287 = r.CheckBreak() + } + if yyb1287 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Kind = "" + } else { + x.Kind = string(r.DecodeString()) + } + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l + } else { + yyb1287 = r.CheckBreak() + } + if yyb1287 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l + } else { + yyb1287 = r.CheckBreak() + } + if yyb1287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15060,16 +15215,16 @@ func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1261 := &x.ObjectMeta - yyv1261.CodecDecodeSelf(d) + yyv1290 := &x.ObjectMeta + yyv1290.CodecDecodeSelf(d) } - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l } else { - yyb1258 = r.CheckBreak() + yyb1287 = r.CheckBreak() } - if yyb1258 { + if yyb1287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15077,16 +15232,16 @@ func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = ReplicaSetSpec{} } else { - yyv1262 := &x.Spec - yyv1262.CodecDecodeSelf(d) + yyv1291 := &x.Spec + yyv1291.CodecDecodeSelf(d) } - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l } else { - yyb1258 = r.CheckBreak() + yyb1287 = r.CheckBreak() } - if yyb1258 { + if yyb1287 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -15094,21 +15249,21 @@ func (x *ReplicaSet) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Status = ReplicaSetStatus{} } else { - yyv1263 := &x.Status - yyv1263.CodecDecodeSelf(d) + yyv1292 := &x.Status + yyv1292.CodecDecodeSelf(d) } for { - yyj1258++ - if yyhl1258 { - yyb1258 = yyj1258 > l + yyj1287++ + if yyhl1287 { + yyb1287 = yyj1287 > l } else { - yyb1258 = r.CheckBreak() + yyb1287 = r.CheckBreak() } - if yyb1258 { + if yyb1287 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1258-1, "") + z.DecStructFieldNotFound(yyj1287-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -15120,37 +15275,37 @@ func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1264 := z.EncBinary() - _ = yym1264 + yym1293 := z.EncBinary() + _ = yym1293 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1265 := !z.EncBinary() - yy2arr1265 := z.EncBasicHandle().StructToArray - var yyq1265 [4]bool - _, _, _ = yysep1265, yyq1265, yy2arr1265 - const yyr1265 bool = false - yyq1265[0] = x.Kind != "" - yyq1265[1] = x.APIVersion != "" - yyq1265[2] = true - var yynn1265 int - if yyr1265 || yy2arr1265 { + yysep1294 := !z.EncBinary() + yy2arr1294 := z.EncBasicHandle().StructToArray + var yyq1294 [4]bool + _, _, _ = yysep1294, yyq1294, yy2arr1294 + const yyr1294 bool = false + yyq1294[0] = x.Kind != "" + yyq1294[1] = x.APIVersion != "" + yyq1294[2] = true + var yynn1294 int + if yyr1294 || yy2arr1294 { r.EncodeArrayStart(4) } else { - yynn1265 = 1 - for _, b := range yyq1265 { + yynn1294 = 1 + for _, b := range yyq1294 { if b { - yynn1265++ + yynn1294++ } } - r.EncodeMapStart(yynn1265) - yynn1265 = 0 + r.EncodeMapStart(yynn1294) + yynn1294 = 0 } - if yyr1265 || yy2arr1265 { + if yyr1294 || yy2arr1294 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1265[0] { - yym1267 := z.EncBinary() - _ = yym1267 + if yyq1294[0] { + yym1296 := z.EncBinary() + _ = yym1296 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -15159,23 +15314,23 @@ func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1265[0] { + if yyq1294[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1268 := z.EncBinary() - _ = yym1268 + yym1297 := z.EncBinary() + _ = yym1297 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1265 || yy2arr1265 { + if yyr1294 || yy2arr1294 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1265[1] { - yym1270 := z.EncBinary() - _ = yym1270 + if yyq1294[1] { + yym1299 := z.EncBinary() + _ = yym1299 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -15184,54 +15339,54 @@ func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1265[1] { + if yyq1294[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1271 := z.EncBinary() - _ = yym1271 + yym1300 := z.EncBinary() + _ = yym1300 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1265 || yy2arr1265 { + if yyr1294 || yy2arr1294 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1265[2] { - yy1273 := &x.ListMeta - yym1274 := z.EncBinary() - _ = yym1274 + if yyq1294[2] { + yy1302 := &x.ListMeta + yym1303 := z.EncBinary() + _ = yym1303 if false { - } else if z.HasExtensions() && z.EncExt(yy1273) { + } else if z.HasExtensions() && z.EncExt(yy1302) { } else { - z.EncFallback(yy1273) + z.EncFallback(yy1302) } } else { r.EncodeNil() } } else { - if yyq1265[2] { + if yyq1294[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1275 := &x.ListMeta - yym1276 := z.EncBinary() - _ = yym1276 + yy1304 := &x.ListMeta + yym1305 := z.EncBinary() + _ = yym1305 if false { - } else if z.HasExtensions() && z.EncExt(yy1275) { + } else if z.HasExtensions() && z.EncExt(yy1304) { } else { - z.EncFallback(yy1275) + z.EncFallback(yy1304) } } } - if yyr1265 || yy2arr1265 { + if yyr1294 || yy2arr1294 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1278 := z.EncBinary() - _ = yym1278 + yym1307 := z.EncBinary() + _ = yym1307 if false { } else { h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) @@ -15244,15 +15399,15 @@ func (x *ReplicaSetList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1279 := z.EncBinary() - _ = yym1279 + yym1308 := z.EncBinary() + _ = yym1308 if false { } else { h.encSliceReplicaSet(([]ReplicaSet)(x.Items), e) } } } - if yyr1265 || yy2arr1265 { + if yyr1294 || yy2arr1294 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -15265,25 +15420,25 @@ func (x *ReplicaSetList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1280 := z.DecBinary() - _ = yym1280 + yym1309 := z.DecBinary() + _ = yym1309 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1281 := r.ContainerType() - if yyct1281 == codecSelferValueTypeMap1234 { - yyl1281 := r.ReadMapStart() - if yyl1281 == 0 { + yyct1310 := r.ContainerType() + if yyct1310 == codecSelferValueTypeMap1234 { + yyl1310 := r.ReadMapStart() + if yyl1310 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1281, d) + x.codecDecodeSelfFromMap(yyl1310, d) } - } else if yyct1281 == codecSelferValueTypeArray1234 { - yyl1281 := r.ReadArrayStart() - if yyl1281 == 0 { + } else if yyct1310 == codecSelferValueTypeArray1234 { + yyl1310 := r.ReadArrayStart() + if yyl1310 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1281, d) + x.codecDecodeSelfFromArray(yyl1310, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -15295,12 +15450,12 @@ func (x *ReplicaSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1282Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1282Slc - var yyhl1282 bool = l >= 0 - for yyj1282 := 0; ; yyj1282++ { - if yyhl1282 { - if yyj1282 >= l { + var yys1311Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1311Slc + var yyhl1311 bool = l >= 0 + for yyj1311 := 0; ; yyj1311++ { + if yyhl1311 { + if yyj1311 >= l { break } } else { @@ -15309,10 +15464,10 @@ func (x *ReplicaSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1282Slc = r.DecodeBytes(yys1282Slc, true, true) - yys1282 := string(yys1282Slc) + yys1311Slc = r.DecodeBytes(yys1311Slc, true, true) + yys1311 := string(yys1311Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1282 { + switch yys1311 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -15329,377 +15484,35 @@ func (x *ReplicaSetList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1285 := &x.ListMeta - yym1286 := z.DecBinary() - _ = yym1286 + yyv1314 := &x.ListMeta + yym1315 := z.DecBinary() + _ = yym1315 if false { - } else if z.HasExtensions() && z.DecExt(yyv1285) { + } else if z.HasExtensions() && z.DecExt(yyv1314) { } else { - z.DecFallback(yyv1285, false) + z.DecFallback(yyv1314, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1287 := &x.Items - yym1288 := z.DecBinary() - _ = yym1288 + yyv1316 := &x.Items + yym1317 := z.DecBinary() + _ = yym1317 if false { } else { - h.decSliceReplicaSet((*[]ReplicaSet)(yyv1287), d) + h.decSliceReplicaSet((*[]ReplicaSet)(yyv1316), d) } } default: - z.DecStructFieldNotFound(-1, yys1282) - } // end switch yys1282 - } // end for yyj1282 + z.DecStructFieldNotFound(-1, yys1311) + } // end switch yys1311 + } // end for yyj1311 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } func (x *ReplicaSetList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1289 int - var yyb1289 bool - var yyhl1289 bool = l >= 0 - yyj1289++ - if yyhl1289 { - yyb1289 = yyj1289 > l - } else { - yyb1289 = r.CheckBreak() - } - if yyb1289 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj1289++ - if yyhl1289 { - yyb1289 = yyj1289 > l - } else { - yyb1289 = r.CheckBreak() - } - if yyb1289 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj1289++ - if yyhl1289 { - yyb1289 = yyj1289 > l - } else { - yyb1289 = r.CheckBreak() - } - if yyb1289 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ListMeta = pkg1_unversioned.ListMeta{} - } else { - yyv1292 := &x.ListMeta - yym1293 := z.DecBinary() - _ = yym1293 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1292) { - } else { - z.DecFallback(yyv1292, false) - } - } - yyj1289++ - if yyhl1289 { - yyb1289 = yyj1289 > l - } else { - yyb1289 = r.CheckBreak() - } - if yyb1289 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Items = nil - } else { - yyv1294 := &x.Items - yym1295 := z.DecBinary() - _ = yym1295 - if false { - } else { - h.decSliceReplicaSet((*[]ReplicaSet)(yyv1294), d) - } - } - for { - yyj1289++ - if yyhl1289 { - yyb1289 = yyj1289 > l - } else { - yyb1289 = r.CheckBreak() - } - if yyb1289 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1289-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *ReplicaSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1296 := z.EncBinary() - _ = yym1296 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1297 := !z.EncBinary() - yy2arr1297 := z.EncBasicHandle().StructToArray - var yyq1297 [4]bool - _, _, _ = yysep1297, yyq1297, yy2arr1297 - const yyr1297 bool = false - yyq1297[0] = x.Replicas != nil - yyq1297[1] = x.MinReadySeconds != 0 - yyq1297[2] = x.Selector != nil - yyq1297[3] = true - var yynn1297 int - if yyr1297 || yy2arr1297 { - r.EncodeArrayStart(4) - } else { - yynn1297 = 0 - for _, b := range yyq1297 { - if b { - yynn1297++ - } - } - r.EncodeMapStart(yynn1297) - yynn1297 = 0 - } - if yyr1297 || yy2arr1297 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1297[0] { - if x.Replicas == nil { - r.EncodeNil() - } else { - yy1299 := *x.Replicas - yym1300 := z.EncBinary() - _ = yym1300 - if false { - } else { - r.EncodeInt(int64(yy1299)) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq1297[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("replicas")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Replicas == nil { - r.EncodeNil() - } else { - yy1301 := *x.Replicas - yym1302 := z.EncBinary() - _ = yym1302 - if false { - } else { - r.EncodeInt(int64(yy1301)) - } - } - } - } - if yyr1297 || yy2arr1297 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1297[1] { - yym1304 := z.EncBinary() - _ = yym1304 - if false { - } else { - r.EncodeInt(int64(x.MinReadySeconds)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq1297[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minReadySeconds")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1305 := z.EncBinary() - _ = yym1305 - if false { - } else { - r.EncodeInt(int64(x.MinReadySeconds)) - } - } - } - if yyr1297 || yy2arr1297 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1297[2] { - if x.Selector == nil { - r.EncodeNil() - } else { - x.Selector.CodecEncodeSelf(e) - } - } else { - r.EncodeNil() - } - } else { - if yyq1297[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("selector")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.Selector == nil { - r.EncodeNil() - } else { - x.Selector.CodecEncodeSelf(e) - } - } - } - if yyr1297 || yy2arr1297 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1297[3] { - yy1308 := &x.Template - yy1308.CodecEncodeSelf(e) - } else { - r.EncodeNil() - } - } else { - if yyq1297[3] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("template")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1309 := &x.Template - yy1309.CodecEncodeSelf(e) - } - } - if yyr1297 || yy2arr1297 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *ReplicaSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1310 := z.DecBinary() - _ = yym1310 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1311 := r.ContainerType() - if yyct1311 == codecSelferValueTypeMap1234 { - yyl1311 := r.ReadMapStart() - if yyl1311 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1311, d) - } - } else if yyct1311 == codecSelferValueTypeArray1234 { - yyl1311 := r.ReadArrayStart() - if yyl1311 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1311, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1312Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1312Slc - var yyhl1312 bool = l >= 0 - for yyj1312 := 0; ; yyj1312++ { - if yyhl1312 { - if yyj1312 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1312Slc = r.DecodeBytes(yys1312Slc, true, true) - yys1312 := string(yys1312Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1312 { - case "replicas": - if r.TryDecodeAsNil() { - if x.Replicas != nil { - x.Replicas = nil - } - } else { - if x.Replicas == nil { - x.Replicas = new(int32) - } - yym1314 := z.DecBinary() - _ = yym1314 - if false { - } else { - *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) - } - } - case "minReadySeconds": - if r.TryDecodeAsNil() { - x.MinReadySeconds = 0 - } else { - x.MinReadySeconds = int32(r.DecodeInt(32)) - } - case "selector": - if r.TryDecodeAsNil() { - if x.Selector != nil { - x.Selector = nil - } - } else { - if x.Selector == nil { - x.Selector = new(LabelSelector) - } - x.Selector.CodecDecodeSelf(d) - } - case "template": - if r.TryDecodeAsNil() { - x.Template = pkg2_v1.PodTemplateSpec{} - } else { - yyv1317 := &x.Template - yyv1317.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys1312) - } // end switch yys1312 - } // end for yyj1312 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -15718,74 +15531,71 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - if x.Replicas != nil { - x.Replicas = nil - } + x.Kind = "" } else { - if x.Replicas == nil { - x.Replicas = new(int32) + x.Kind = string(r.DecodeString()) + } + yyj1318++ + if yyhl1318 { + yyb1318 = yyj1318 > l + } else { + yyb1318 = r.CheckBreak() + } + if yyb1318 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.APIVersion = "" + } else { + x.APIVersion = string(r.DecodeString()) + } + yyj1318++ + if yyhl1318 { + yyb1318 = yyj1318 > l + } else { + yyb1318 = r.CheckBreak() + } + if yyb1318 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.ListMeta = pkg1_unversioned.ListMeta{} + } else { + yyv1321 := &x.ListMeta + yym1322 := z.DecBinary() + _ = yym1322 + if false { + } else if z.HasExtensions() && z.DecExt(yyv1321) { + } else { + z.DecFallback(yyv1321, false) } - yym1320 := z.DecBinary() - _ = yym1320 + } + yyj1318++ + if yyhl1318 { + yyb1318 = yyj1318 > l + } else { + yyb1318 = r.CheckBreak() + } + if yyb1318 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Items = nil + } else { + yyv1323 := &x.Items + yym1324 := z.DecBinary() + _ = yym1324 if false { } else { - *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) + h.decSliceReplicaSet((*[]ReplicaSet)(yyv1323), d) } } - yyj1318++ - if yyhl1318 { - yyb1318 = yyj1318 > l - } else { - yyb1318 = r.CheckBreak() - } - if yyb1318 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MinReadySeconds = 0 - } else { - x.MinReadySeconds = int32(r.DecodeInt(32)) - } - yyj1318++ - if yyhl1318 { - yyb1318 = yyj1318 > l - } else { - yyb1318 = r.CheckBreak() - } - if yyb1318 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.Selector != nil { - x.Selector = nil - } - } else { - if x.Selector == nil { - x.Selector = new(LabelSelector) - } - x.Selector.CodecDecodeSelf(d) - } - yyj1318++ - if yyhl1318 { - yyb1318 = yyj1318 > l - } else { - yyb1318 = r.CheckBreak() - } - if yyb1318 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Template = pkg2_v1.PodTemplateSpec{} - } else { - yyv1323 := &x.Template - yyv1323.CodecDecodeSelf(d) - } for { yyj1318++ if yyhl1318 { @@ -15802,6 +15612,375 @@ func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } +func (x *ReplicaSetSpec) CodecEncodeSelf(e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + if x == nil { + r.EncodeNil() + } else { + yym1325 := z.EncBinary() + _ = yym1325 + if false { + } else if z.HasExtensions() && z.EncExt(x) { + } else { + yysep1326 := !z.EncBinary() + yy2arr1326 := z.EncBasicHandle().StructToArray + var yyq1326 [4]bool + _, _, _ = yysep1326, yyq1326, yy2arr1326 + const yyr1326 bool = false + yyq1326[0] = x.Replicas != nil + yyq1326[1] = x.MinReadySeconds != 0 + yyq1326[2] = x.Selector != nil + yyq1326[3] = true + var yynn1326 int + if yyr1326 || yy2arr1326 { + r.EncodeArrayStart(4) + } else { + yynn1326 = 0 + for _, b := range yyq1326 { + if b { + yynn1326++ + } + } + r.EncodeMapStart(yynn1326) + yynn1326 = 0 + } + if yyr1326 || yy2arr1326 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1326[0] { + if x.Replicas == nil { + r.EncodeNil() + } else { + yy1328 := *x.Replicas + yym1329 := z.EncBinary() + _ = yym1329 + if false { + } else { + r.EncodeInt(int64(yy1328)) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq1326[0] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("replicas")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Replicas == nil { + r.EncodeNil() + } else { + yy1330 := *x.Replicas + yym1331 := z.EncBinary() + _ = yym1331 + if false { + } else { + r.EncodeInt(int64(yy1330)) + } + } + } + } + if yyr1326 || yy2arr1326 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1326[1] { + yym1333 := z.EncBinary() + _ = yym1333 + if false { + } else { + r.EncodeInt(int64(x.MinReadySeconds)) + } + } else { + r.EncodeInt(0) + } + } else { + if yyq1326[1] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("minReadySeconds")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yym1334 := z.EncBinary() + _ = yym1334 + if false { + } else { + r.EncodeInt(int64(x.MinReadySeconds)) + } + } + } + if yyr1326 || yy2arr1326 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1326[2] { + if x.Selector == nil { + r.EncodeNil() + } else { + yym1336 := z.EncBinary() + _ = yym1336 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } else { + r.EncodeNil() + } + } else { + if yyq1326[2] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("selector")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + if x.Selector == nil { + r.EncodeNil() + } else { + yym1337 := z.EncBinary() + _ = yym1337 + if false { + } else if z.HasExtensions() && z.EncExt(x.Selector) { + } else { + z.EncFallback(x.Selector) + } + } + } + } + if yyr1326 || yy2arr1326 { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + if yyq1326[3] { + yy1339 := &x.Template + yy1339.CodecEncodeSelf(e) + } else { + r.EncodeNil() + } + } else { + if yyq1326[3] { + z.EncSendContainerState(codecSelfer_containerMapKey1234) + r.EncodeString(codecSelferC_UTF81234, string("template")) + z.EncSendContainerState(codecSelfer_containerMapValue1234) + yy1340 := &x.Template + yy1340.CodecEncodeSelf(e) + } + } + if yyr1326 || yy2arr1326 { + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + z.EncSendContainerState(codecSelfer_containerMapEnd1234) + } + } + } +} + +func (x *ReplicaSetSpec) CodecDecodeSelf(d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + yym1341 := z.DecBinary() + _ = yym1341 + if false { + } else if z.HasExtensions() && z.DecExt(x) { + } else { + yyct1342 := r.ContainerType() + if yyct1342 == codecSelferValueTypeMap1234 { + yyl1342 := r.ReadMapStart() + if yyl1342 == 0 { + z.DecSendContainerState(codecSelfer_containerMapEnd1234) + } else { + x.codecDecodeSelfFromMap(yyl1342, d) + } + } else if yyct1342 == codecSelferValueTypeArray1234 { + yyl1342 := r.ReadArrayStart() + if yyl1342 == 0 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + } else { + x.codecDecodeSelfFromArray(yyl1342, d) + } + } else { + panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) + } + } +} + +func (x *ReplicaSetSpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yys1343Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1343Slc + var yyhl1343 bool = l >= 0 + for yyj1343 := 0; ; yyj1343++ { + if yyhl1343 { + if yyj1343 >= l { + break + } + } else { + if r.CheckBreak() { + break + } + } + z.DecSendContainerState(codecSelfer_containerMapKey1234) + yys1343Slc = r.DecodeBytes(yys1343Slc, true, true) + yys1343 := string(yys1343Slc) + z.DecSendContainerState(codecSelfer_containerMapValue1234) + switch yys1343 { + case "replicas": + if r.TryDecodeAsNil() { + if x.Replicas != nil { + x.Replicas = nil + } + } else { + if x.Replicas == nil { + x.Replicas = new(int32) + } + yym1345 := z.DecBinary() + _ = yym1345 + if false { + } else { + *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) + } + } + case "minReadySeconds": + if r.TryDecodeAsNil() { + x.MinReadySeconds = 0 + } else { + x.MinReadySeconds = int32(r.DecodeInt(32)) + } + case "selector": + if r.TryDecodeAsNil() { + if x.Selector != nil { + x.Selector = nil + } + } else { + if x.Selector == nil { + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym1348 := z.DecBinary() + _ = yym1348 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) + } + } + case "template": + if r.TryDecodeAsNil() { + x.Template = pkg2_v1.PodTemplateSpec{} + } else { + yyv1349 := &x.Template + yyv1349.CodecDecodeSelf(d) + } + default: + z.DecStructFieldNotFound(-1, yys1343) + } // end switch yys1343 + } // end for yyj1343 + z.DecSendContainerState(codecSelfer_containerMapEnd1234) +} + +func (x *ReplicaSetSpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + var yyj1350 int + var yyb1350 bool + var yyhl1350 bool = l >= 0 + yyj1350++ + if yyhl1350 { + yyb1350 = yyj1350 > l + } else { + yyb1350 = r.CheckBreak() + } + if yyb1350 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.Replicas != nil { + x.Replicas = nil + } + } else { + if x.Replicas == nil { + x.Replicas = new(int32) + } + yym1352 := z.DecBinary() + _ = yym1352 + if false { + } else { + *((*int32)(x.Replicas)) = int32(r.DecodeInt(32)) + } + } + yyj1350++ + if yyhl1350 { + yyb1350 = yyj1350 > l + } else { + yyb1350 = r.CheckBreak() + } + if yyb1350 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.MinReadySeconds = 0 + } else { + x.MinReadySeconds = int32(r.DecodeInt(32)) + } + yyj1350++ + if yyhl1350 { + yyb1350 = yyj1350 > l + } else { + yyb1350 = r.CheckBreak() + } + if yyb1350 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + if x.Selector != nil { + x.Selector = nil + } + } else { + if x.Selector == nil { + x.Selector = new(pkg1_unversioned.LabelSelector) + } + yym1355 := z.DecBinary() + _ = yym1355 + if false { + } else if z.HasExtensions() && z.DecExt(x.Selector) { + } else { + z.DecFallback(x.Selector, false) + } + } + yyj1350++ + if yyhl1350 { + yyb1350 = yyj1350 > l + } else { + yyb1350 = r.CheckBreak() + } + if yyb1350 { + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) + return + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + if r.TryDecodeAsNil() { + x.Template = pkg2_v1.PodTemplateSpec{} + } else { + yyv1356 := &x.Template + yyv1356.CodecDecodeSelf(d) + } + for { + yyj1350++ + if yyhl1350 { + yyb1350 = yyj1350 > l + } else { + yyb1350 = r.CheckBreak() + } + if yyb1350 { + break + } + z.DecSendContainerState(codecSelfer_containerArrayElem1234) + z.DecStructFieldNotFound(yyj1350-1, "") + } + z.DecSendContainerState(codecSelfer_containerArrayEnd1234) +} + func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) @@ -15809,38 +15988,38 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1324 := z.EncBinary() - _ = yym1324 + yym1357 := z.EncBinary() + _ = yym1357 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1325 := !z.EncBinary() - yy2arr1325 := z.EncBasicHandle().StructToArray - var yyq1325 [6]bool - _, _, _ = yysep1325, yyq1325, yy2arr1325 - const yyr1325 bool = false - yyq1325[1] = x.FullyLabeledReplicas != 0 - yyq1325[2] = x.ReadyReplicas != 0 - yyq1325[3] = x.AvailableReplicas != 0 - yyq1325[4] = x.ObservedGeneration != 0 - yyq1325[5] = len(x.Conditions) != 0 - var yynn1325 int - if yyr1325 || yy2arr1325 { + yysep1358 := !z.EncBinary() + yy2arr1358 := z.EncBasicHandle().StructToArray + var yyq1358 [6]bool + _, _, _ = yysep1358, yyq1358, yy2arr1358 + const yyr1358 bool = false + yyq1358[1] = x.FullyLabeledReplicas != 0 + yyq1358[2] = x.ReadyReplicas != 0 + yyq1358[3] = x.AvailableReplicas != 0 + yyq1358[4] = x.ObservedGeneration != 0 + yyq1358[5] = len(x.Conditions) != 0 + var yynn1358 int + if yyr1358 || yy2arr1358 { r.EncodeArrayStart(6) } else { - yynn1325 = 1 - for _, b := range yyq1325 { + yynn1358 = 1 + for _, b := range yyq1358 { if b { - yynn1325++ + yynn1358++ } } - r.EncodeMapStart(yynn1325) - yynn1325 = 0 + r.EncodeMapStart(yynn1358) + yynn1358 = 0 } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1327 := z.EncBinary() - _ = yym1327 + yym1360 := z.EncBinary() + _ = yym1360 if false { } else { r.EncodeInt(int64(x.Replicas)) @@ -15849,18 +16028,18 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("replicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1328 := z.EncBinary() - _ = yym1328 + yym1361 := z.EncBinary() + _ = yym1361 if false { } else { r.EncodeInt(int64(x.Replicas)) } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1325[1] { - yym1330 := z.EncBinary() - _ = yym1330 + if yyq1358[1] { + yym1363 := z.EncBinary() + _ = yym1363 if false { } else { r.EncodeInt(int64(x.FullyLabeledReplicas)) @@ -15869,23 +16048,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq1325[1] { + if yyq1358[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("fullyLabeledReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1331 := z.EncBinary() - _ = yym1331 + yym1364 := z.EncBinary() + _ = yym1364 if false { } else { r.EncodeInt(int64(x.FullyLabeledReplicas)) } } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1325[2] { - yym1333 := z.EncBinary() - _ = yym1333 + if yyq1358[2] { + yym1366 := z.EncBinary() + _ = yym1366 if false { } else { r.EncodeInt(int64(x.ReadyReplicas)) @@ -15894,23 +16073,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq1325[2] { + if yyq1358[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readyReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1334 := z.EncBinary() - _ = yym1334 + yym1367 := z.EncBinary() + _ = yym1367 if false { } else { r.EncodeInt(int64(x.ReadyReplicas)) } } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1325[3] { - yym1336 := z.EncBinary() - _ = yym1336 + if yyq1358[3] { + yym1369 := z.EncBinary() + _ = yym1369 if false { } else { r.EncodeInt(int64(x.AvailableReplicas)) @@ -15919,23 +16098,23 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq1325[3] { + if yyq1358[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("availableReplicas")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1337 := z.EncBinary() - _ = yym1337 + yym1370 := z.EncBinary() + _ = yym1370 if false { } else { r.EncodeInt(int64(x.AvailableReplicas)) } } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1325[4] { - yym1339 := z.EncBinary() - _ = yym1339 + if yyq1358[4] { + yym1372 := z.EncBinary() + _ = yym1372 if false { } else { r.EncodeInt(int64(x.ObservedGeneration)) @@ -15944,26 +16123,26 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeInt(0) } } else { - if yyq1325[4] { + if yyq1358[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("observedGeneration")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1340 := z.EncBinary() - _ = yym1340 + yym1373 := z.EncBinary() + _ = yym1373 if false { } else { r.EncodeInt(int64(x.ObservedGeneration)) } } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1325[5] { + if yyq1358[5] { if x.Conditions == nil { r.EncodeNil() } else { - yym1342 := z.EncBinary() - _ = yym1342 + yym1375 := z.EncBinary() + _ = yym1375 if false { } else { h.encSliceReplicaSetCondition(([]ReplicaSetCondition)(x.Conditions), e) @@ -15973,15 +16152,15 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1325[5] { + if yyq1358[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("conditions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Conditions == nil { r.EncodeNil() } else { - yym1343 := z.EncBinary() - _ = yym1343 + yym1376 := z.EncBinary() + _ = yym1376 if false { } else { h.encSliceReplicaSetCondition(([]ReplicaSetCondition)(x.Conditions), e) @@ -15989,7 +16168,7 @@ func (x *ReplicaSetStatus) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1325 || yy2arr1325 { + if yyr1358 || yy2arr1358 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -16002,25 +16181,25 @@ func (x *ReplicaSetStatus) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1344 := z.DecBinary() - _ = yym1344 + yym1377 := z.DecBinary() + _ = yym1377 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1345 := r.ContainerType() - if yyct1345 == codecSelferValueTypeMap1234 { - yyl1345 := r.ReadMapStart() - if yyl1345 == 0 { + yyct1378 := r.ContainerType() + if yyct1378 == codecSelferValueTypeMap1234 { + yyl1378 := r.ReadMapStart() + if yyl1378 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1345, d) + x.codecDecodeSelfFromMap(yyl1378, d) } - } else if yyct1345 == codecSelferValueTypeArray1234 { - yyl1345 := r.ReadArrayStart() - if yyl1345 == 0 { + } else if yyct1378 == codecSelferValueTypeArray1234 { + yyl1378 := r.ReadArrayStart() + if yyl1378 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1345, d) + x.codecDecodeSelfFromArray(yyl1378, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -16032,12 +16211,12 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1346Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1346Slc - var yyhl1346 bool = l >= 0 - for yyj1346 := 0; ; yyj1346++ { - if yyhl1346 { - if yyj1346 >= l { + var yys1379Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1379Slc + var yyhl1379 bool = l >= 0 + for yyj1379 := 0; ; yyj1379++ { + if yyhl1379 { + if yyj1379 >= l { break } } else { @@ -16046,10 +16225,10 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1346Slc = r.DecodeBytes(yys1346Slc, true, true) - yys1346 := string(yys1346Slc) + yys1379Slc = r.DecodeBytes(yys1379Slc, true, true) + yys1379 := string(yys1379Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1346 { + switch yys1379 { case "replicas": if r.TryDecodeAsNil() { x.Replicas = 0 @@ -16084,18 +16263,18 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv1352 := &x.Conditions - yym1353 := z.DecBinary() - _ = yym1353 + yyv1385 := &x.Conditions + yym1386 := z.DecBinary() + _ = yym1386 if false { } else { - h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv1352), d) + h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv1385), d) } } default: - z.DecStructFieldNotFound(-1, yys1346) - } // end switch yys1346 - } // end for yyj1346 + z.DecStructFieldNotFound(-1, yys1379) + } // end switch yys1379 + } // end for yyj1379 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -16103,16 +16282,16 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1354 int - var yyb1354 bool - var yyhl1354 bool = l >= 0 - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + var yyj1387 int + var yyb1387 bool + var yyhl1387 bool = l >= 0 + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16122,13 +16301,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.Replicas = int32(r.DecodeInt(32)) } - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16138,13 +16317,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.FullyLabeledReplicas = int32(r.DecodeInt(32)) } - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16154,13 +16333,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ReadyReplicas = int32(r.DecodeInt(32)) } - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16170,13 +16349,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.AvailableReplicas = int32(r.DecodeInt(32)) } - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16186,13 +16365,13 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) } else { x.ObservedGeneration = int64(r.DecodeInt(64)) } - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16200,26 +16379,26 @@ func (x *ReplicaSetStatus) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.Conditions = nil } else { - yyv1360 := &x.Conditions - yym1361 := z.DecBinary() - _ = yym1361 + yyv1393 := &x.Conditions + yym1394 := z.DecBinary() + _ = yym1394 if false { } else { - h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv1360), d) + h.decSliceReplicaSetCondition((*[]ReplicaSetCondition)(yyv1393), d) } } for { - yyj1354++ - if yyhl1354 { - yyb1354 = yyj1354 > l + yyj1387++ + if yyhl1387 { + yyb1387 = yyj1387 > l } else { - yyb1354 = r.CheckBreak() + yyb1387 = r.CheckBreak() } - if yyb1354 { + if yyb1387 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1354-1, "") + z.DecStructFieldNotFound(yyj1387-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16228,8 +16407,8 @@ func (x ReplicaSetConditionType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1362 := z.EncBinary() - _ = yym1362 + yym1395 := z.EncBinary() + _ = yym1395 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -16241,8 +16420,8 @@ func (x *ReplicaSetConditionType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1363 := z.DecBinary() - _ = yym1363 + yym1396 := z.DecBinary() + _ = yym1396 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -16257,34 +16436,33 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1364 := z.EncBinary() - _ = yym1364 + yym1397 := z.EncBinary() + _ = yym1397 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1365 := !z.EncBinary() - yy2arr1365 := z.EncBasicHandle().StructToArray - var yyq1365 [6]bool - _, _, _ = yysep1365, yyq1365, yy2arr1365 - const yyr1365 bool = false - yyq1365[2] = true - yyq1365[3] = true - yyq1365[4] = x.Reason != "" - yyq1365[5] = x.Message != "" - var yynn1365 int - if yyr1365 || yy2arr1365 { - r.EncodeArrayStart(6) + yysep1398 := !z.EncBinary() + yy2arr1398 := z.EncBasicHandle().StructToArray + var yyq1398 [5]bool + _, _, _ = yysep1398, yyq1398, yy2arr1398 + const yyr1398 bool = false + yyq1398[2] = true + yyq1398[3] = x.Reason != "" + yyq1398[4] = x.Message != "" + var yynn1398 int + if yyr1398 || yy2arr1398 { + r.EncodeArrayStart(5) } else { - yynn1365 = 2 - for _, b := range yyq1365 { + yynn1398 = 2 + for _, b := range yyq1398 { if b { - yynn1365++ + yynn1398++ } } - r.EncodeMapStart(yynn1365) - yynn1365 = 0 + r.EncodeMapStart(yynn1398) + yynn1398 = 0 } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Type.CodecEncodeSelf(e) } else { @@ -16293,10 +16471,10 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Type.CodecEncodeSelf(e) } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1368 := z.EncBinary() - _ = yym1368 + yym1401 := z.EncBinary() + _ = yym1401 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { @@ -16306,93 +16484,56 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("status")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1369 := z.EncBinary() - _ = yym1369 + yym1402 := z.EncBinary() + _ = yym1402 if false { } else if z.HasExtensions() && z.EncExt(x.Status) { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Status)) } } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1365[2] { - yy1371 := &x.LastProbeTime - yym1372 := z.EncBinary() - _ = yym1372 + if yyq1398[2] { + yy1404 := &x.LastTransitionTime + yym1405 := z.EncBinary() + _ = yym1405 if false { - } else if z.HasExtensions() && z.EncExt(yy1371) { - } else if yym1372 { - z.EncBinaryMarshal(yy1371) - } else if !yym1372 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1371) + } else if z.HasExtensions() && z.EncExt(yy1404) { + } else if yym1405 { + z.EncBinaryMarshal(yy1404) + } else if !yym1405 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1404) } else { - z.EncFallback(yy1371) + z.EncFallback(yy1404) } } else { r.EncodeNil() } } else { - if yyq1365[2] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lastProbeTime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1373 := &x.LastProbeTime - yym1374 := z.EncBinary() - _ = yym1374 - if false { - } else if z.HasExtensions() && z.EncExt(yy1373) { - } else if yym1374 { - z.EncBinaryMarshal(yy1373) - } else if !yym1374 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1373) - } else { - z.EncFallback(yy1373) - } - } - } - if yyr1365 || yy2arr1365 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1365[3] { - yy1376 := &x.LastTransitionTime - yym1377 := z.EncBinary() - _ = yym1377 - if false { - } else if z.HasExtensions() && z.EncExt(yy1376) { - } else if yym1377 { - z.EncBinaryMarshal(yy1376) - } else if !yym1377 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1376) - } else { - z.EncFallback(yy1376) - } - } else { - r.EncodeNil() - } - } else { - if yyq1365[3] { + if yyq1398[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("lastTransitionTime")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1378 := &x.LastTransitionTime - yym1379 := z.EncBinary() - _ = yym1379 + yy1406 := &x.LastTransitionTime + yym1407 := z.EncBinary() + _ = yym1407 if false { - } else if z.HasExtensions() && z.EncExt(yy1378) { - } else if yym1379 { - z.EncBinaryMarshal(yy1378) - } else if !yym1379 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1378) + } else if z.HasExtensions() && z.EncExt(yy1406) { + } else if yym1407 { + z.EncBinaryMarshal(yy1406) + } else if !yym1407 && z.IsJSONHandle() { + z.EncJSONMarshal(yy1406) } else { - z.EncFallback(yy1378) + z.EncFallback(yy1406) } } } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1365[4] { - yym1381 := z.EncBinary() - _ = yym1381 + if yyq1398[3] { + yym1409 := z.EncBinary() + _ = yym1409 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) @@ -16401,23 +16542,23 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1365[4] { + if yyq1398[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("reason")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1382 := z.EncBinary() - _ = yym1382 + yym1410 := z.EncBinary() + _ = yym1410 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Reason)) } } } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1365[5] { - yym1384 := z.EncBinary() - _ = yym1384 + if yyq1398[4] { + yym1412 := z.EncBinary() + _ = yym1412 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) @@ -16426,19 +16567,19 @@ func (x *ReplicaSetCondition) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1365[5] { + if yyq1398[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("message")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1385 := z.EncBinary() - _ = yym1385 + yym1413 := z.EncBinary() + _ = yym1413 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Message)) } } } - if yyr1365 || yy2arr1365 { + if yyr1398 || yy2arr1398 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -16451,25 +16592,25 @@ func (x *ReplicaSetCondition) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1386 := z.DecBinary() - _ = yym1386 + yym1414 := z.DecBinary() + _ = yym1414 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1387 := r.ContainerType() - if yyct1387 == codecSelferValueTypeMap1234 { - yyl1387 := r.ReadMapStart() - if yyl1387 == 0 { + yyct1415 := r.ContainerType() + if yyct1415 == codecSelferValueTypeMap1234 { + yyl1415 := r.ReadMapStart() + if yyl1415 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1387, d) + x.codecDecodeSelfFromMap(yyl1415, d) } - } else if yyct1387 == codecSelferValueTypeArray1234 { - yyl1387 := r.ReadArrayStart() - if yyl1387 == 0 { + } else if yyct1415 == codecSelferValueTypeArray1234 { + yyl1415 := r.ReadArrayStart() + if yyl1415 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1387, d) + x.codecDecodeSelfFromArray(yyl1415, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -16481,12 +16622,12 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1388Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1388Slc - var yyhl1388 bool = l >= 0 - for yyj1388 := 0; ; yyj1388++ { - if yyhl1388 { - if yyj1388 >= l { + var yys1416Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1416Slc + var yyhl1416 bool = l >= 0 + for yyj1416 := 0; ; yyj1416++ { + if yyhl1416 { + if yyj1416 >= l { break } } else { @@ -16495,10 +16636,10 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1388Slc = r.DecodeBytes(yys1388Slc, true, true) - yys1388 := string(yys1388Slc) + yys1416Slc = r.DecodeBytes(yys1416Slc, true, true) + yys1416 := string(yys1416Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1388 { + switch yys1416 { case "type": if r.TryDecodeAsNil() { x.Type = "" @@ -16511,38 +16652,21 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder } else { x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) } - case "lastProbeTime": - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg1_unversioned.Time{} - } else { - yyv1391 := &x.LastProbeTime - yym1392 := z.DecBinary() - _ = yym1392 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1391) { - } else if yym1392 { - z.DecBinaryUnmarshal(yyv1391) - } else if !yym1392 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1391) - } else { - z.DecFallback(yyv1391, false) - } - } case "lastTransitionTime": if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv1393 := &x.LastTransitionTime - yym1394 := z.DecBinary() - _ = yym1394 + yyv1419 := &x.LastTransitionTime + yym1420 := z.DecBinary() + _ = yym1420 if false { - } else if z.HasExtensions() && z.DecExt(yyv1393) { - } else if yym1394 { - z.DecBinaryUnmarshal(yyv1393) - } else if !yym1394 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1393) + } else if z.HasExtensions() && z.DecExt(yyv1419) { + } else if yym1420 { + z.DecBinaryUnmarshal(yyv1419) + } else if !yym1420 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1419) } else { - z.DecFallback(yyv1393, false) + z.DecFallback(yyv1419, false) } } case "reason": @@ -16558,9 +16682,9 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromMap(l int, d *codec1978.Decoder x.Message = string(r.DecodeString()) } default: - z.DecStructFieldNotFound(-1, yys1388) - } // end switch yys1388 - } // end for yyj1388 + z.DecStructFieldNotFound(-1, yys1416) + } // end switch yys1416 + } // end for yyj1416 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -16568,16 +16692,16 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1397 int - var yyb1397 bool - var yyhl1397 bool = l >= 0 - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + var yyj1423 int + var yyb1423 bool + var yyhl1423 bool = l >= 0 + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { + if yyb1423 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16587,13 +16711,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Type = ReplicaSetConditionType(r.DecodeString()) } - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { + if yyb1423 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16603,40 +16727,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Status = pkg2_v1.ConditionStatus(r.DecodeString()) } - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LastProbeTime = pkg1_unversioned.Time{} - } else { - yyv1400 := &x.LastProbeTime - yym1401 := z.DecBinary() - _ = yym1401 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1400) { - } else if yym1401 { - z.DecBinaryUnmarshal(yyv1400) - } else if !yym1401 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1400) - } else { - z.DecFallback(yyv1400, false) - } - } - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l - } else { - yyb1397 = r.CheckBreak() - } - if yyb1397 { + if yyb1423 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16644,26 +16741,26 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.LastTransitionTime = pkg1_unversioned.Time{} } else { - yyv1402 := &x.LastTransitionTime - yym1403 := z.DecBinary() - _ = yym1403 + yyv1426 := &x.LastTransitionTime + yym1427 := z.DecBinary() + _ = yym1427 if false { - } else if z.HasExtensions() && z.DecExt(yyv1402) { - } else if yym1403 { - z.DecBinaryUnmarshal(yyv1402) - } else if !yym1403 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1402) + } else if z.HasExtensions() && z.DecExt(yyv1426) { + } else if yym1427 { + z.DecBinaryUnmarshal(yyv1426) + } else if !yym1427 && z.IsJSONHandle() { + z.DecJSONUnmarshal(yyv1426) } else { - z.DecFallback(yyv1402, false) + z.DecFallback(yyv1426, false) } } - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { + if yyb1423 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16673,13 +16770,13 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod } else { x.Reason = string(r.DecodeString()) } - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { + if yyb1423 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16690,17 +16787,17 @@ func (x *ReplicaSetCondition) codecDecodeSelfFromArray(l int, d *codec1978.Decod x.Message = string(r.DecodeString()) } for { - yyj1397++ - if yyhl1397 { - yyb1397 = yyj1397 > l + yyj1423++ + if yyhl1423 { + yyb1423 = yyj1423 > l } else { - yyb1397 = r.CheckBreak() + yyb1423 = r.CheckBreak() } - if yyb1397 { + if yyb1423 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1397-1, "") + z.DecStructFieldNotFound(yyj1423-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -16712,38 +16809,38 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1406 := z.EncBinary() - _ = yym1406 + yym1430 := z.EncBinary() + _ = yym1430 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1407 := !z.EncBinary() - yy2arr1407 := z.EncBasicHandle().StructToArray - var yyq1407 [4]bool - _, _, _ = yysep1407, yyq1407, yy2arr1407 - const yyr1407 bool = false - yyq1407[0] = x.Kind != "" - yyq1407[1] = x.APIVersion != "" - yyq1407[2] = true - yyq1407[3] = true - var yynn1407 int - if yyr1407 || yy2arr1407 { + yysep1431 := !z.EncBinary() + yy2arr1431 := z.EncBasicHandle().StructToArray + var yyq1431 [4]bool + _, _, _ = yysep1431, yyq1431, yy2arr1431 + const yyr1431 bool = false + yyq1431[0] = x.Kind != "" + yyq1431[1] = x.APIVersion != "" + yyq1431[2] = true + yyq1431[3] = true + var yynn1431 int + if yyr1431 || yy2arr1431 { r.EncodeArrayStart(4) } else { - yynn1407 = 0 - for _, b := range yyq1407 { + yynn1431 = 0 + for _, b := range yyq1431 { if b { - yynn1407++ + yynn1431++ } } - r.EncodeMapStart(yynn1407) - yynn1407 = 0 + r.EncodeMapStart(yynn1431) + yynn1431 = 0 } - if yyr1407 || yy2arr1407 { + if yyr1431 || yy2arr1431 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1407[0] { - yym1409 := z.EncBinary() - _ = yym1409 + if yyq1431[0] { + yym1433 := z.EncBinary() + _ = yym1433 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -16752,23 +16849,23 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1407[0] { + if yyq1431[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1410 := z.EncBinary() - _ = yym1410 + yym1434 := z.EncBinary() + _ = yym1434 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1407 || yy2arr1407 { + if yyr1431 || yy2arr1431 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1407[1] { - yym1412 := z.EncBinary() - _ = yym1412 + if yyq1431[1] { + yym1436 := z.EncBinary() + _ = yym1436 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -16777,53 +16874,53 @@ func (x *PodSecurityPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1407[1] { + if yyq1431[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1413 := z.EncBinary() - _ = yym1413 + yym1437 := z.EncBinary() + _ = yym1437 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1407 || yy2arr1407 { + if yyr1431 || yy2arr1431 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1407[2] { - yy1415 := &x.ObjectMeta - yy1415.CodecEncodeSelf(e) + if yyq1431[2] { + yy1439 := &x.ObjectMeta + yy1439.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1407[2] { + if yyq1431[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1416 := &x.ObjectMeta - yy1416.CodecEncodeSelf(e) + yy1440 := &x.ObjectMeta + yy1440.CodecEncodeSelf(e) } } - if yyr1407 || yy2arr1407 { + if yyr1431 || yy2arr1431 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1407[3] { - yy1418 := &x.Spec - yy1418.CodecEncodeSelf(e) + if yyq1431[3] { + yy1442 := &x.Spec + yy1442.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1407[3] { + if yyq1431[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1419 := &x.Spec - yy1419.CodecEncodeSelf(e) + yy1443 := &x.Spec + yy1443.CodecEncodeSelf(e) } } - if yyr1407 || yy2arr1407 { + if yyr1431 || yy2arr1431 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -16836,25 +16933,25 @@ func (x *PodSecurityPolicy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1420 := z.DecBinary() - _ = yym1420 + yym1444 := z.DecBinary() + _ = yym1444 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1421 := r.ContainerType() - if yyct1421 == codecSelferValueTypeMap1234 { - yyl1421 := r.ReadMapStart() - if yyl1421 == 0 { + yyct1445 := r.ContainerType() + if yyct1445 == codecSelferValueTypeMap1234 { + yyl1445 := r.ReadMapStart() + if yyl1445 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1421, d) + x.codecDecodeSelfFromMap(yyl1445, d) } - } else if yyct1421 == codecSelferValueTypeArray1234 { - yyl1421 := r.ReadArrayStart() - if yyl1421 == 0 { + } else if yyct1445 == codecSelferValueTypeArray1234 { + yyl1445 := r.ReadArrayStart() + if yyl1445 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1421, d) + x.codecDecodeSelfFromArray(yyl1445, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -16866,12 +16963,12 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1422Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1422Slc - var yyhl1422 bool = l >= 0 - for yyj1422 := 0; ; yyj1422++ { - if yyhl1422 { - if yyj1422 >= l { + var yys1446Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1446Slc + var yyhl1446 bool = l >= 0 + for yyj1446 := 0; ; yyj1446++ { + if yyhl1446 { + if yyj1446 >= l { break } } else { @@ -16880,10 +16977,10 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1422Slc = r.DecodeBytes(yys1422Slc, true, true) - yys1422 := string(yys1422Slc) + yys1446Slc = r.DecodeBytes(yys1446Slc, true, true) + yys1446 := string(yys1446Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1422 { + switch yys1446 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -16900,20 +16997,20 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1425 := &x.ObjectMeta - yyv1425.CodecDecodeSelf(d) + yyv1449 := &x.ObjectMeta + yyv1449.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = PodSecurityPolicySpec{} } else { - yyv1426 := &x.Spec - yyv1426.CodecDecodeSelf(d) + yyv1450 := &x.Spec + yyv1450.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1422) - } // end switch yys1422 - } // end for yyj1422 + z.DecStructFieldNotFound(-1, yys1446) + } // end switch yys1446 + } // end for yyj1446 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -16921,16 +17018,16 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1427 int - var yyb1427 bool - var yyhl1427 bool = l >= 0 - yyj1427++ - if yyhl1427 { - yyb1427 = yyj1427 > l + var yyj1451 int + var yyb1451 bool + var yyhl1451 bool = l >= 0 + yyj1451++ + if yyhl1451 { + yyb1451 = yyj1451 > l } else { - yyb1427 = r.CheckBreak() + yyb1451 = r.CheckBreak() } - if yyb1427 { + if yyb1451 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16940,13 +17037,13 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj1427++ - if yyhl1427 { - yyb1427 = yyj1427 > l + yyj1451++ + if yyhl1451 { + yyb1451 = yyj1451 > l } else { - yyb1427 = r.CheckBreak() + yyb1451 = r.CheckBreak() } - if yyb1427 { + if yyb1451 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16956,13 +17053,13 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj1427++ - if yyhl1427 { - yyb1427 = yyj1427 > l + yyj1451++ + if yyhl1451 { + yyb1451 = yyj1451 > l } else { - yyb1427 = r.CheckBreak() + yyb1451 = r.CheckBreak() } - if yyb1427 { + if yyb1451 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16970,16 +17067,16 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1430 := &x.ObjectMeta - yyv1430.CodecDecodeSelf(d) + yyv1454 := &x.ObjectMeta + yyv1454.CodecDecodeSelf(d) } - yyj1427++ - if yyhl1427 { - yyb1427 = yyj1427 > l + yyj1451++ + if yyhl1451 { + yyb1451 = yyj1451 > l } else { - yyb1427 = r.CheckBreak() + yyb1451 = r.CheckBreak() } - if yyb1427 { + if yyb1451 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -16987,21 +17084,21 @@ func (x *PodSecurityPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Spec = PodSecurityPolicySpec{} } else { - yyv1431 := &x.Spec - yyv1431.CodecDecodeSelf(d) + yyv1455 := &x.Spec + yyv1455.CodecDecodeSelf(d) } for { - yyj1427++ - if yyhl1427 { - yyb1427 = yyj1427 > l + yyj1451++ + if yyhl1451 { + yyb1451 = yyj1451 > l } else { - yyb1427 = r.CheckBreak() + yyb1451 = r.CheckBreak() } - if yyb1427 { + if yyb1451 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1427-1, "") + z.DecStructFieldNotFound(yyj1451-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17013,44 +17110,44 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1432 := z.EncBinary() - _ = yym1432 + yym1456 := z.EncBinary() + _ = yym1456 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1433 := !z.EncBinary() - yy2arr1433 := z.EncBasicHandle().StructToArray - var yyq1433 [14]bool - _, _, _ = yysep1433, yyq1433, yy2arr1433 - const yyr1433 bool = false - yyq1433[0] = x.Privileged != false - yyq1433[1] = len(x.DefaultAddCapabilities) != 0 - yyq1433[2] = len(x.RequiredDropCapabilities) != 0 - yyq1433[3] = len(x.AllowedCapabilities) != 0 - yyq1433[4] = len(x.Volumes) != 0 - yyq1433[5] = x.HostNetwork != false - yyq1433[6] = len(x.HostPorts) != 0 - yyq1433[7] = x.HostPID != false - yyq1433[8] = x.HostIPC != false - yyq1433[13] = x.ReadOnlyRootFilesystem != false - var yynn1433 int - if yyr1433 || yy2arr1433 { + yysep1457 := !z.EncBinary() + yy2arr1457 := z.EncBasicHandle().StructToArray + var yyq1457 [14]bool + _, _, _ = yysep1457, yyq1457, yy2arr1457 + const yyr1457 bool = false + yyq1457[0] = x.Privileged != false + yyq1457[1] = len(x.DefaultAddCapabilities) != 0 + yyq1457[2] = len(x.RequiredDropCapabilities) != 0 + yyq1457[3] = len(x.AllowedCapabilities) != 0 + yyq1457[4] = len(x.Volumes) != 0 + yyq1457[5] = x.HostNetwork != false + yyq1457[6] = len(x.HostPorts) != 0 + yyq1457[7] = x.HostPID != false + yyq1457[8] = x.HostIPC != false + yyq1457[13] = x.ReadOnlyRootFilesystem != false + var yynn1457 int + if yyr1457 || yy2arr1457 { r.EncodeArrayStart(14) } else { - yynn1433 = 4 - for _, b := range yyq1433 { + yynn1457 = 4 + for _, b := range yyq1457 { if b { - yynn1433++ + yynn1457++ } } - r.EncodeMapStart(yynn1433) - yynn1433 = 0 + r.EncodeMapStart(yynn1457) + yynn1457 = 0 } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[0] { - yym1435 := z.EncBinary() - _ = yym1435 + if yyq1457[0] { + yym1459 := z.EncBinary() + _ = yym1459 if false { } else { r.EncodeBool(bool(x.Privileged)) @@ -17059,26 +17156,26 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq1433[0] { + if yyq1457[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("privileged")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1436 := z.EncBinary() - _ = yym1436 + yym1460 := z.EncBinary() + _ = yym1460 if false { } else { r.EncodeBool(bool(x.Privileged)) } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[1] { + if yyq1457[1] { if x.DefaultAddCapabilities == nil { r.EncodeNil() } else { - yym1438 := z.EncBinary() - _ = yym1438 + yym1462 := z.EncBinary() + _ = yym1462 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.DefaultAddCapabilities), e) @@ -17088,15 +17185,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1433[1] { + if yyq1457[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("defaultAddCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.DefaultAddCapabilities == nil { r.EncodeNil() } else { - yym1439 := z.EncBinary() - _ = yym1439 + yym1463 := z.EncBinary() + _ = yym1463 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.DefaultAddCapabilities), e) @@ -17104,14 +17201,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[2] { + if yyq1457[2] { if x.RequiredDropCapabilities == nil { r.EncodeNil() } else { - yym1441 := z.EncBinary() - _ = yym1441 + yym1465 := z.EncBinary() + _ = yym1465 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.RequiredDropCapabilities), e) @@ -17121,15 +17218,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1433[2] { + if yyq1457[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("requiredDropCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.RequiredDropCapabilities == nil { r.EncodeNil() } else { - yym1442 := z.EncBinary() - _ = yym1442 + yym1466 := z.EncBinary() + _ = yym1466 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.RequiredDropCapabilities), e) @@ -17137,14 +17234,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[3] { + if yyq1457[3] { if x.AllowedCapabilities == nil { r.EncodeNil() } else { - yym1444 := z.EncBinary() - _ = yym1444 + yym1468 := z.EncBinary() + _ = yym1468 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.AllowedCapabilities), e) @@ -17154,15 +17251,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1433[3] { + if yyq1457[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("allowedCapabilities")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.AllowedCapabilities == nil { r.EncodeNil() } else { - yym1445 := z.EncBinary() - _ = yym1445 + yym1469 := z.EncBinary() + _ = yym1469 if false { } else { h.encSlicev1_Capability(([]pkg2_v1.Capability)(x.AllowedCapabilities), e) @@ -17170,14 +17267,14 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[4] { + if yyq1457[4] { if x.Volumes == nil { r.EncodeNil() } else { - yym1447 := z.EncBinary() - _ = yym1447 + yym1471 := z.EncBinary() + _ = yym1471 if false { } else { h.encSliceFSType(([]FSType)(x.Volumes), e) @@ -17187,15 +17284,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1433[4] { + if yyq1457[4] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("volumes")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Volumes == nil { r.EncodeNil() } else { - yym1448 := z.EncBinary() - _ = yym1448 + yym1472 := z.EncBinary() + _ = yym1472 if false { } else { h.encSliceFSType(([]FSType)(x.Volumes), e) @@ -17203,11 +17300,11 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[5] { - yym1450 := z.EncBinary() - _ = yym1450 + if yyq1457[5] { + yym1474 := z.EncBinary() + _ = yym1474 if false { } else { r.EncodeBool(bool(x.HostNetwork)) @@ -17216,26 +17313,26 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq1433[5] { + if yyq1457[5] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostNetwork")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1451 := z.EncBinary() - _ = yym1451 + yym1475 := z.EncBinary() + _ = yym1475 if false { } else { r.EncodeBool(bool(x.HostNetwork)) } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[6] { + if yyq1457[6] { if x.HostPorts == nil { r.EncodeNil() } else { - yym1453 := z.EncBinary() - _ = yym1453 + yym1477 := z.EncBinary() + _ = yym1477 if false { } else { h.encSliceHostPortRange(([]HostPortRange)(x.HostPorts), e) @@ -17245,15 +17342,15 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1433[6] { + if yyq1457[6] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostPorts")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.HostPorts == nil { r.EncodeNil() } else { - yym1454 := z.EncBinary() - _ = yym1454 + yym1478 := z.EncBinary() + _ = yym1478 if false { } else { h.encSliceHostPortRange(([]HostPortRange)(x.HostPorts), e) @@ -17261,11 +17358,11 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[7] { - yym1456 := z.EncBinary() - _ = yym1456 + if yyq1457[7] { + yym1480 := z.EncBinary() + _ = yym1480 if false { } else { r.EncodeBool(bool(x.HostPID)) @@ -17274,23 +17371,23 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq1433[7] { + if yyq1457[7] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostPID")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1457 := z.EncBinary() - _ = yym1457 + yym1481 := z.EncBinary() + _ = yym1481 if false { } else { r.EncodeBool(bool(x.HostPID)) } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[8] { - yym1459 := z.EncBinary() - _ = yym1459 + if yyq1457[8] { + yym1483 := z.EncBinary() + _ = yym1483 if false { } else { r.EncodeBool(bool(x.HostIPC)) @@ -17299,67 +17396,67 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq1433[8] { + if yyq1457[8] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("hostIPC")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1460 := z.EncBinary() - _ = yym1460 + yym1484 := z.EncBinary() + _ = yym1484 if false { } else { r.EncodeBool(bool(x.HostIPC)) } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1462 := &x.SELinux - yy1462.CodecEncodeSelf(e) + yy1486 := &x.SELinux + yy1486.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinux")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1463 := &x.SELinux - yy1463.CodecEncodeSelf(e) + yy1487 := &x.SELinux + yy1487.CodecEncodeSelf(e) } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1465 := &x.RunAsUser - yy1465.CodecEncodeSelf(e) + yy1489 := &x.RunAsUser + yy1489.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("runAsUser")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1466 := &x.RunAsUser - yy1466.CodecEncodeSelf(e) + yy1490 := &x.RunAsUser + yy1490.CodecEncodeSelf(e) } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1468 := &x.SupplementalGroups - yy1468.CodecEncodeSelf(e) + yy1492 := &x.SupplementalGroups + yy1492.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("supplementalGroups")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1469 := &x.SupplementalGroups - yy1469.CodecEncodeSelf(e) + yy1493 := &x.SupplementalGroups + yy1493.CodecEncodeSelf(e) } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1471 := &x.FSGroup - yy1471.CodecEncodeSelf(e) + yy1495 := &x.FSGroup + yy1495.CodecEncodeSelf(e) } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("fsGroup")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1472 := &x.FSGroup - yy1472.CodecEncodeSelf(e) + yy1496 := &x.FSGroup + yy1496.CodecEncodeSelf(e) } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1433[13] { - yym1474 := z.EncBinary() - _ = yym1474 + if yyq1457[13] { + yym1498 := z.EncBinary() + _ = yym1498 if false { } else { r.EncodeBool(bool(x.ReadOnlyRootFilesystem)) @@ -17368,19 +17465,19 @@ func (x *PodSecurityPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeBool(false) } } else { - if yyq1433[13] { + if yyq1457[13] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("readOnlyRootFilesystem")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1475 := z.EncBinary() - _ = yym1475 + yym1499 := z.EncBinary() + _ = yym1499 if false { } else { r.EncodeBool(bool(x.ReadOnlyRootFilesystem)) } } } - if yyr1433 || yy2arr1433 { + if yyr1457 || yy2arr1457 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -17393,25 +17490,25 @@ func (x *PodSecurityPolicySpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1476 := z.DecBinary() - _ = yym1476 + yym1500 := z.DecBinary() + _ = yym1500 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1477 := r.ContainerType() - if yyct1477 == codecSelferValueTypeMap1234 { - yyl1477 := r.ReadMapStart() - if yyl1477 == 0 { + yyct1501 := r.ContainerType() + if yyct1501 == codecSelferValueTypeMap1234 { + yyl1501 := r.ReadMapStart() + if yyl1501 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1477, d) + x.codecDecodeSelfFromMap(yyl1501, d) } - } else if yyct1477 == codecSelferValueTypeArray1234 { - yyl1477 := r.ReadArrayStart() - if yyl1477 == 0 { + } else if yyct1501 == codecSelferValueTypeArray1234 { + yyl1501 := r.ReadArrayStart() + if yyl1501 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1477, d) + x.codecDecodeSelfFromArray(yyl1501, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -17423,12 +17520,12 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1478Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1478Slc - var yyhl1478 bool = l >= 0 - for yyj1478 := 0; ; yyj1478++ { - if yyhl1478 { - if yyj1478 >= l { + var yys1502Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1502Slc + var yyhl1502 bool = l >= 0 + for yyj1502 := 0; ; yyj1502++ { + if yyhl1502 { + if yyj1502 >= l { break } } else { @@ -17437,10 +17534,10 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1478Slc = r.DecodeBytes(yys1478Slc, true, true) - yys1478 := string(yys1478Slc) + yys1502Slc = r.DecodeBytes(yys1502Slc, true, true) + yys1502 := string(yys1502Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1478 { + switch yys1502 { case "privileged": if r.TryDecodeAsNil() { x.Privileged = false @@ -17451,48 +17548,48 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.DefaultAddCapabilities = nil } else { - yyv1480 := &x.DefaultAddCapabilities - yym1481 := z.DecBinary() - _ = yym1481 + yyv1504 := &x.DefaultAddCapabilities + yym1505 := z.DecBinary() + _ = yym1505 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1480), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1504), d) } } case "requiredDropCapabilities": if r.TryDecodeAsNil() { x.RequiredDropCapabilities = nil } else { - yyv1482 := &x.RequiredDropCapabilities - yym1483 := z.DecBinary() - _ = yym1483 + yyv1506 := &x.RequiredDropCapabilities + yym1507 := z.DecBinary() + _ = yym1507 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1482), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1506), d) } } case "allowedCapabilities": if r.TryDecodeAsNil() { x.AllowedCapabilities = nil } else { - yyv1484 := &x.AllowedCapabilities - yym1485 := z.DecBinary() - _ = yym1485 + yyv1508 := &x.AllowedCapabilities + yym1509 := z.DecBinary() + _ = yym1509 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1484), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1508), d) } } case "volumes": if r.TryDecodeAsNil() { x.Volumes = nil } else { - yyv1486 := &x.Volumes - yym1487 := z.DecBinary() - _ = yym1487 + yyv1510 := &x.Volumes + yym1511 := z.DecBinary() + _ = yym1511 if false { } else { - h.decSliceFSType((*[]FSType)(yyv1486), d) + h.decSliceFSType((*[]FSType)(yyv1510), d) } } case "hostNetwork": @@ -17505,12 +17602,12 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.HostPorts = nil } else { - yyv1489 := &x.HostPorts - yym1490 := z.DecBinary() - _ = yym1490 + yyv1513 := &x.HostPorts + yym1514 := z.DecBinary() + _ = yym1514 if false { } else { - h.decSliceHostPortRange((*[]HostPortRange)(yyv1489), d) + h.decSliceHostPortRange((*[]HostPortRange)(yyv1513), d) } } case "hostPID": @@ -17529,29 +17626,29 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.SELinux = SELinuxStrategyOptions{} } else { - yyv1493 := &x.SELinux - yyv1493.CodecDecodeSelf(d) + yyv1517 := &x.SELinux + yyv1517.CodecDecodeSelf(d) } case "runAsUser": if r.TryDecodeAsNil() { x.RunAsUser = RunAsUserStrategyOptions{} } else { - yyv1494 := &x.RunAsUser - yyv1494.CodecDecodeSelf(d) + yyv1518 := &x.RunAsUser + yyv1518.CodecDecodeSelf(d) } case "supplementalGroups": if r.TryDecodeAsNil() { x.SupplementalGroups = SupplementalGroupsStrategyOptions{} } else { - yyv1495 := &x.SupplementalGroups - yyv1495.CodecDecodeSelf(d) + yyv1519 := &x.SupplementalGroups + yyv1519.CodecDecodeSelf(d) } case "fsGroup": if r.TryDecodeAsNil() { x.FSGroup = FSGroupStrategyOptions{} } else { - yyv1496 := &x.FSGroup - yyv1496.CodecDecodeSelf(d) + yyv1520 := &x.FSGroup + yyv1520.CodecDecodeSelf(d) } case "readOnlyRootFilesystem": if r.TryDecodeAsNil() { @@ -17560,9 +17657,9 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decod x.ReadOnlyRootFilesystem = bool(r.DecodeBool()) } default: - z.DecStructFieldNotFound(-1, yys1478) - } // end switch yys1478 - } // end for yyj1478 + z.DecStructFieldNotFound(-1, yys1502) + } // end switch yys1502 + } // end for yyj1502 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -17570,16 +17667,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1498 int - var yyb1498 bool - var yyhl1498 bool = l >= 0 - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + var yyj1522 int + var yyb1522 bool + var yyhl1522 bool = l >= 0 + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17589,13 +17686,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Privileged = bool(r.DecodeBool()) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17603,21 +17700,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.DefaultAddCapabilities = nil } else { - yyv1500 := &x.DefaultAddCapabilities - yym1501 := z.DecBinary() - _ = yym1501 + yyv1524 := &x.DefaultAddCapabilities + yym1525 := z.DecBinary() + _ = yym1525 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1500), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1524), d) } } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17625,21 +17722,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.RequiredDropCapabilities = nil } else { - yyv1502 := &x.RequiredDropCapabilities - yym1503 := z.DecBinary() - _ = yym1503 + yyv1526 := &x.RequiredDropCapabilities + yym1527 := z.DecBinary() + _ = yym1527 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1502), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1526), d) } } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17647,21 +17744,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.AllowedCapabilities = nil } else { - yyv1504 := &x.AllowedCapabilities - yym1505 := z.DecBinary() - _ = yym1505 + yyv1528 := &x.AllowedCapabilities + yym1529 := z.DecBinary() + _ = yym1529 if false { } else { - h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1504), d) + h.decSlicev1_Capability((*[]pkg2_v1.Capability)(yyv1528), d) } } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17669,21 +17766,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Volumes = nil } else { - yyv1506 := &x.Volumes - yym1507 := z.DecBinary() - _ = yym1507 + yyv1530 := &x.Volumes + yym1531 := z.DecBinary() + _ = yym1531 if false { } else { - h.decSliceFSType((*[]FSType)(yyv1506), d) + h.decSliceFSType((*[]FSType)(yyv1530), d) } } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17693,13 +17790,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostNetwork = bool(r.DecodeBool()) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17707,21 +17804,21 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.HostPorts = nil } else { - yyv1509 := &x.HostPorts - yym1510 := z.DecBinary() - _ = yym1510 + yyv1533 := &x.HostPorts + yym1534 := z.DecBinary() + _ = yym1534 if false { } else { - h.decSliceHostPortRange((*[]HostPortRange)(yyv1509), d) + h.decSliceHostPortRange((*[]HostPortRange)(yyv1533), d) } } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17731,13 +17828,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostPID = bool(r.DecodeBool()) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17747,13 +17844,13 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.HostIPC = bool(r.DecodeBool()) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17761,16 +17858,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.SELinux = SELinuxStrategyOptions{} } else { - yyv1513 := &x.SELinux - yyv1513.CodecDecodeSelf(d) + yyv1537 := &x.SELinux + yyv1537.CodecDecodeSelf(d) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17778,16 +17875,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.RunAsUser = RunAsUserStrategyOptions{} } else { - yyv1514 := &x.RunAsUser - yyv1514.CodecDecodeSelf(d) + yyv1538 := &x.RunAsUser + yyv1538.CodecDecodeSelf(d) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17795,16 +17892,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.SupplementalGroups = SupplementalGroupsStrategyOptions{} } else { - yyv1515 := &x.SupplementalGroups - yyv1515.CodecDecodeSelf(d) + yyv1539 := &x.SupplementalGroups + yyv1539.CodecDecodeSelf(d) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17812,16 +17909,16 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.FSGroup = FSGroupStrategyOptions{} } else { - yyv1516 := &x.FSGroup - yyv1516.CodecDecodeSelf(d) + yyv1540 := &x.FSGroup + yyv1540.CodecDecodeSelf(d) } - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -17832,17 +17929,17 @@ func (x *PodSecurityPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Dec x.ReadOnlyRootFilesystem = bool(r.DecodeBool()) } for { - yyj1498++ - if yyhl1498 { - yyb1498 = yyj1498 > l + yyj1522++ + if yyhl1522 { + yyb1522 = yyj1522 > l } else { - yyb1498 = r.CheckBreak() + yyb1522 = r.CheckBreak() } - if yyb1498 { + if yyb1522 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1498-1, "") + z.DecStructFieldNotFound(yyj1522-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -17851,8 +17948,8 @@ func (x FSType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1518 := z.EncBinary() - _ = yym1518 + yym1542 := z.EncBinary() + _ = yym1542 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -17864,8 +17961,8 @@ func (x *FSType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1519 := z.DecBinary() - _ = yym1519 + yym1543 := z.DecBinary() + _ = yym1543 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -17880,33 +17977,33 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1520 := z.EncBinary() - _ = yym1520 + yym1544 := z.EncBinary() + _ = yym1544 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1521 := !z.EncBinary() - yy2arr1521 := z.EncBasicHandle().StructToArray - var yyq1521 [2]bool - _, _, _ = yysep1521, yyq1521, yy2arr1521 - const yyr1521 bool = false - var yynn1521 int - if yyr1521 || yy2arr1521 { + yysep1545 := !z.EncBinary() + yy2arr1545 := z.EncBasicHandle().StructToArray + var yyq1545 [2]bool + _, _, _ = yysep1545, yyq1545, yy2arr1545 + const yyr1545 bool = false + var yynn1545 int + if yyr1545 || yy2arr1545 { r.EncodeArrayStart(2) } else { - yynn1521 = 2 - for _, b := range yyq1521 { + yynn1545 = 2 + for _, b := range yyq1545 { if b { - yynn1521++ + yynn1545++ } } - r.EncodeMapStart(yynn1521) - yynn1521 = 0 + r.EncodeMapStart(yynn1545) + yynn1545 = 0 } - if yyr1521 || yy2arr1521 { + if yyr1545 || yy2arr1545 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1523 := z.EncBinary() - _ = yym1523 + yym1547 := z.EncBinary() + _ = yym1547 if false { } else { r.EncodeInt(int64(x.Min)) @@ -17915,17 +18012,17 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("min")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1524 := z.EncBinary() - _ = yym1524 + yym1548 := z.EncBinary() + _ = yym1548 if false { } else { r.EncodeInt(int64(x.Min)) } } - if yyr1521 || yy2arr1521 { + if yyr1545 || yy2arr1545 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1526 := z.EncBinary() - _ = yym1526 + yym1550 := z.EncBinary() + _ = yym1550 if false { } else { r.EncodeInt(int64(x.Max)) @@ -17934,14 +18031,14 @@ func (x *HostPortRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("max")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1527 := z.EncBinary() - _ = yym1527 + yym1551 := z.EncBinary() + _ = yym1551 if false { } else { r.EncodeInt(int64(x.Max)) } } - if yyr1521 || yy2arr1521 { + if yyr1545 || yy2arr1545 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -17954,25 +18051,25 @@ func (x *HostPortRange) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1528 := z.DecBinary() - _ = yym1528 + yym1552 := z.DecBinary() + _ = yym1552 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1529 := r.ContainerType() - if yyct1529 == codecSelferValueTypeMap1234 { - yyl1529 := r.ReadMapStart() - if yyl1529 == 0 { + yyct1553 := r.ContainerType() + if yyct1553 == codecSelferValueTypeMap1234 { + yyl1553 := r.ReadMapStart() + if yyl1553 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1529, d) + x.codecDecodeSelfFromMap(yyl1553, d) } - } else if yyct1529 == codecSelferValueTypeArray1234 { - yyl1529 := r.ReadArrayStart() - if yyl1529 == 0 { + } else if yyct1553 == codecSelferValueTypeArray1234 { + yyl1553 := r.ReadArrayStart() + if yyl1553 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1529, d) + x.codecDecodeSelfFromArray(yyl1553, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -17984,12 +18081,12 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1530Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1530Slc - var yyhl1530 bool = l >= 0 - for yyj1530 := 0; ; yyj1530++ { - if yyhl1530 { - if yyj1530 >= l { + var yys1554Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1554Slc + var yyhl1554 bool = l >= 0 + for yyj1554 := 0; ; yyj1554++ { + if yyhl1554 { + if yyj1554 >= l { break } } else { @@ -17998,10 +18095,10 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1530Slc = r.DecodeBytes(yys1530Slc, true, true) - yys1530 := string(yys1530Slc) + yys1554Slc = r.DecodeBytes(yys1554Slc, true, true) + yys1554 := string(yys1554Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1530 { + switch yys1554 { case "min": if r.TryDecodeAsNil() { x.Min = 0 @@ -18015,9 +18112,9 @@ func (x *HostPortRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Max = int32(r.DecodeInt(32)) } default: - z.DecStructFieldNotFound(-1, yys1530) - } // end switch yys1530 - } // end for yyj1530 + z.DecStructFieldNotFound(-1, yys1554) + } // end switch yys1554 + } // end for yyj1554 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -18025,16 +18122,16 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1533 int - var yyb1533 bool - var yyhl1533 bool = l >= 0 - yyj1533++ - if yyhl1533 { - yyb1533 = yyj1533 > l + var yyj1557 int + var yyb1557 bool + var yyhl1557 bool = l >= 0 + yyj1557++ + if yyhl1557 { + yyb1557 = yyj1557 > l } else { - yyb1533 = r.CheckBreak() + yyb1557 = r.CheckBreak() } - if yyb1533 { + if yyb1557 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18044,13 +18141,13 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Min = int32(r.DecodeInt(32)) } - yyj1533++ - if yyhl1533 { - yyb1533 = yyj1533 > l + yyj1557++ + if yyhl1557 { + yyb1557 = yyj1557 > l } else { - yyb1533 = r.CheckBreak() + yyb1557 = r.CheckBreak() } - if yyb1533 { + if yyb1557 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18061,17 +18158,17 @@ func (x *HostPortRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Max = int32(r.DecodeInt(32)) } for { - yyj1533++ - if yyhl1533 { - yyb1533 = yyj1533 > l + yyj1557++ + if yyhl1557 { + yyb1557 = yyj1557 > l } else { - yyb1533 = r.CheckBreak() + yyb1557 = r.CheckBreak() } - if yyb1533 { + if yyb1557 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1533-1, "") + z.DecStructFieldNotFound(yyj1557-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18083,31 +18180,31 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1536 := z.EncBinary() - _ = yym1536 + yym1560 := z.EncBinary() + _ = yym1560 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1537 := !z.EncBinary() - yy2arr1537 := z.EncBasicHandle().StructToArray - var yyq1537 [2]bool - _, _, _ = yysep1537, yyq1537, yy2arr1537 - const yyr1537 bool = false - yyq1537[1] = x.SELinuxOptions != nil - var yynn1537 int - if yyr1537 || yy2arr1537 { + yysep1561 := !z.EncBinary() + yy2arr1561 := z.EncBasicHandle().StructToArray + var yyq1561 [2]bool + _, _, _ = yysep1561, yyq1561, yy2arr1561 + const yyr1561 bool = false + yyq1561[1] = x.SELinuxOptions != nil + var yynn1561 int + if yyr1561 || yy2arr1561 { r.EncodeArrayStart(2) } else { - yynn1537 = 1 - for _, b := range yyq1537 { + yynn1561 = 1 + for _, b := range yyq1561 { if b { - yynn1537++ + yynn1561++ } } - r.EncodeMapStart(yynn1537) - yynn1537 = 0 + r.EncodeMapStart(yynn1561) + yynn1561 = 0 } - if yyr1537 || yy2arr1537 { + if yyr1561 || yy2arr1561 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Rule.CodecEncodeSelf(e) } else { @@ -18116,9 +18213,9 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } - if yyr1537 || yy2arr1537 { + if yyr1561 || yy2arr1561 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1537[1] { + if yyq1561[1] { if x.SELinuxOptions == nil { r.EncodeNil() } else { @@ -18128,7 +18225,7 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1537[1] { + if yyq1561[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("seLinuxOptions")) z.EncSendContainerState(codecSelfer_containerMapValue1234) @@ -18139,7 +18236,7 @@ func (x *SELinuxStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1537 || yy2arr1537 { + if yyr1561 || yy2arr1561 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -18152,25 +18249,25 @@ func (x *SELinuxStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1540 := z.DecBinary() - _ = yym1540 + yym1564 := z.DecBinary() + _ = yym1564 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1541 := r.ContainerType() - if yyct1541 == codecSelferValueTypeMap1234 { - yyl1541 := r.ReadMapStart() - if yyl1541 == 0 { + yyct1565 := r.ContainerType() + if yyct1565 == codecSelferValueTypeMap1234 { + yyl1565 := r.ReadMapStart() + if yyl1565 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1541, d) + x.codecDecodeSelfFromMap(yyl1565, d) } - } else if yyct1541 == codecSelferValueTypeArray1234 { - yyl1541 := r.ReadArrayStart() - if yyl1541 == 0 { + } else if yyct1565 == codecSelferValueTypeArray1234 { + yyl1565 := r.ReadArrayStart() + if yyl1565 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1541, d) + x.codecDecodeSelfFromArray(yyl1565, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -18182,12 +18279,12 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1542Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1542Slc - var yyhl1542 bool = l >= 0 - for yyj1542 := 0; ; yyj1542++ { - if yyhl1542 { - if yyj1542 >= l { + var yys1566Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1566Slc + var yyhl1566 bool = l >= 0 + for yyj1566 := 0; ; yyj1566++ { + if yyhl1566 { + if yyj1566 >= l { break } } else { @@ -18196,10 +18293,10 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1542Slc = r.DecodeBytes(yys1542Slc, true, true) - yys1542 := string(yys1542Slc) + yys1566Slc = r.DecodeBytes(yys1566Slc, true, true) + yys1566 := string(yys1566Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1542 { + switch yys1566 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -18218,9 +18315,9 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco x.SELinuxOptions.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1542) - } // end switch yys1542 - } // end for yyj1542 + z.DecStructFieldNotFound(-1, yys1566) + } // end switch yys1566 + } // end for yyj1566 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -18228,16 +18325,16 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1545 int - var yyb1545 bool - var yyhl1545 bool = l >= 0 - yyj1545++ - if yyhl1545 { - yyb1545 = yyj1545 > l + var yyj1569 int + var yyb1569 bool + var yyhl1569 bool = l >= 0 + yyj1569++ + if yyhl1569 { + yyb1569 = yyj1569 > l } else { - yyb1545 = r.CheckBreak() + yyb1569 = r.CheckBreak() } - if yyb1545 { + if yyb1569 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18247,13 +18344,13 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De } else { x.Rule = SELinuxStrategy(r.DecodeString()) } - yyj1545++ - if yyhl1545 { - yyb1545 = yyj1545 > l + yyj1569++ + if yyhl1569 { + yyb1569 = yyj1569 > l } else { - yyb1545 = r.CheckBreak() + yyb1569 = r.CheckBreak() } - if yyb1545 { + if yyb1569 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18269,17 +18366,17 @@ func (x *SELinuxStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De x.SELinuxOptions.CodecDecodeSelf(d) } for { - yyj1545++ - if yyhl1545 { - yyb1545 = yyj1545 > l + yyj1569++ + if yyhl1569 { + yyb1569 = yyj1569 > l } else { - yyb1545 = r.CheckBreak() + yyb1569 = r.CheckBreak() } - if yyb1545 { + if yyb1569 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1545-1, "") + z.DecStructFieldNotFound(yyj1569-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18288,8 +18385,8 @@ func (x SELinuxStrategy) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1548 := z.EncBinary() - _ = yym1548 + yym1572 := z.EncBinary() + _ = yym1572 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -18301,8 +18398,8 @@ func (x *SELinuxStrategy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1549 := z.DecBinary() - _ = yym1549 + yym1573 := z.DecBinary() + _ = yym1573 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -18317,31 +18414,31 @@ func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1550 := z.EncBinary() - _ = yym1550 + yym1574 := z.EncBinary() + _ = yym1574 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1551 := !z.EncBinary() - yy2arr1551 := z.EncBasicHandle().StructToArray - var yyq1551 [2]bool - _, _, _ = yysep1551, yyq1551, yy2arr1551 - const yyr1551 bool = false - yyq1551[1] = len(x.Ranges) != 0 - var yynn1551 int - if yyr1551 || yy2arr1551 { + yysep1575 := !z.EncBinary() + yy2arr1575 := z.EncBasicHandle().StructToArray + var yyq1575 [2]bool + _, _, _ = yysep1575, yyq1575, yy2arr1575 + const yyr1575 bool = false + yyq1575[1] = len(x.Ranges) != 0 + var yynn1575 int + if yyr1575 || yy2arr1575 { r.EncodeArrayStart(2) } else { - yynn1551 = 1 - for _, b := range yyq1551 { + yynn1575 = 1 + for _, b := range yyq1575 { if b { - yynn1551++ + yynn1575++ } } - r.EncodeMapStart(yynn1551) - yynn1551 = 0 + r.EncodeMapStart(yynn1575) + yynn1575 = 0 } - if yyr1551 || yy2arr1551 { + if yyr1575 || yy2arr1575 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) x.Rule.CodecEncodeSelf(e) } else { @@ -18350,14 +18447,14 @@ func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } - if yyr1551 || yy2arr1551 { + if yyr1575 || yy2arr1575 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1551[1] { + if yyq1575[1] { if x.Ranges == nil { r.EncodeNil() } else { - yym1554 := z.EncBinary() - _ = yym1554 + yym1578 := z.EncBinary() + _ = yym1578 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -18367,15 +18464,15 @@ func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1551[1] { + if yyq1575[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ranges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ranges == nil { r.EncodeNil() } else { - yym1555 := z.EncBinary() - _ = yym1555 + yym1579 := z.EncBinary() + _ = yym1579 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -18383,7 +18480,7 @@ func (x *RunAsUserStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1551 || yy2arr1551 { + if yyr1575 || yy2arr1575 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -18396,25 +18493,25 @@ func (x *RunAsUserStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1556 := z.DecBinary() - _ = yym1556 + yym1580 := z.DecBinary() + _ = yym1580 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1557 := r.ContainerType() - if yyct1557 == codecSelferValueTypeMap1234 { - yyl1557 := r.ReadMapStart() - if yyl1557 == 0 { + yyct1581 := r.ContainerType() + if yyct1581 == codecSelferValueTypeMap1234 { + yyl1581 := r.ReadMapStart() + if yyl1581 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1557, d) + x.codecDecodeSelfFromMap(yyl1581, d) } - } else if yyct1557 == codecSelferValueTypeArray1234 { - yyl1557 := r.ReadArrayStart() - if yyl1557 == 0 { + } else if yyct1581 == codecSelferValueTypeArray1234 { + yyl1581 := r.ReadArrayStart() + if yyl1581 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1557, d) + x.codecDecodeSelfFromArray(yyl1581, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -18426,12 +18523,12 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.De var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1558Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1558Slc - var yyhl1558 bool = l >= 0 - for yyj1558 := 0; ; yyj1558++ { - if yyhl1558 { - if yyj1558 >= l { + var yys1582Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1582Slc + var yyhl1582 bool = l >= 0 + for yyj1582 := 0; ; yyj1582++ { + if yyhl1582 { + if yyj1582 >= l { break } } else { @@ -18440,10 +18537,10 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.De } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1558Slc = r.DecodeBytes(yys1558Slc, true, true) - yys1558 := string(yys1558Slc) + yys1582Slc = r.DecodeBytes(yys1582Slc, true, true) + yys1582 := string(yys1582Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1558 { + switch yys1582 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -18454,18 +18551,18 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.De if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1560 := &x.Ranges - yym1561 := z.DecBinary() - _ = yym1561 + yyv1584 := &x.Ranges + yym1585 := z.DecBinary() + _ = yym1585 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1560), d) + h.decSliceIDRange((*[]IDRange)(yyv1584), d) } } default: - z.DecStructFieldNotFound(-1, yys1558) - } // end switch yys1558 - } // end for yyj1558 + z.DecStructFieldNotFound(-1, yys1582) + } // end switch yys1582 + } // end for yyj1582 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -18473,16 +18570,16 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978. var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1562 int - var yyb1562 bool - var yyhl1562 bool = l >= 0 - yyj1562++ - if yyhl1562 { - yyb1562 = yyj1562 > l + var yyj1586 int + var yyb1586 bool + var yyhl1586 bool = l >= 0 + yyj1586++ + if yyhl1586 { + yyb1586 = yyj1586 > l } else { - yyb1562 = r.CheckBreak() + yyb1586 = r.CheckBreak() } - if yyb1562 { + if yyb1586 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18492,13 +18589,13 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978. } else { x.Rule = RunAsUserStrategy(r.DecodeString()) } - yyj1562++ - if yyhl1562 { - yyb1562 = yyj1562 > l + yyj1586++ + if yyhl1586 { + yyb1586 = yyj1586 > l } else { - yyb1562 = r.CheckBreak() + yyb1586 = r.CheckBreak() } - if yyb1562 { + if yyb1586 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18506,26 +18603,26 @@ func (x *RunAsUserStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978. if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1564 := &x.Ranges - yym1565 := z.DecBinary() - _ = yym1565 + yyv1588 := &x.Ranges + yym1589 := z.DecBinary() + _ = yym1589 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1564), d) + h.decSliceIDRange((*[]IDRange)(yyv1588), d) } } for { - yyj1562++ - if yyhl1562 { - yyb1562 = yyj1562 > l + yyj1586++ + if yyhl1586 { + yyb1586 = yyj1586 > l } else { - yyb1562 = r.CheckBreak() + yyb1586 = r.CheckBreak() } - if yyb1562 { + if yyb1586 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1562-1, "") + z.DecStructFieldNotFound(yyj1586-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18537,33 +18634,33 @@ func (x *IDRange) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1566 := z.EncBinary() - _ = yym1566 + yym1590 := z.EncBinary() + _ = yym1590 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1567 := !z.EncBinary() - yy2arr1567 := z.EncBasicHandle().StructToArray - var yyq1567 [2]bool - _, _, _ = yysep1567, yyq1567, yy2arr1567 - const yyr1567 bool = false - var yynn1567 int - if yyr1567 || yy2arr1567 { + yysep1591 := !z.EncBinary() + yy2arr1591 := z.EncBasicHandle().StructToArray + var yyq1591 [2]bool + _, _, _ = yysep1591, yyq1591, yy2arr1591 + const yyr1591 bool = false + var yynn1591 int + if yyr1591 || yy2arr1591 { r.EncodeArrayStart(2) } else { - yynn1567 = 2 - for _, b := range yyq1567 { + yynn1591 = 2 + for _, b := range yyq1591 { if b { - yynn1567++ + yynn1591++ } } - r.EncodeMapStart(yynn1567) - yynn1567 = 0 + r.EncodeMapStart(yynn1591) + yynn1591 = 0 } - if yyr1567 || yy2arr1567 { + if yyr1591 || yy2arr1591 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1569 := z.EncBinary() - _ = yym1569 + yym1593 := z.EncBinary() + _ = yym1593 if false { } else { r.EncodeInt(int64(x.Min)) @@ -18572,17 +18669,17 @@ func (x *IDRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("min")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1570 := z.EncBinary() - _ = yym1570 + yym1594 := z.EncBinary() + _ = yym1594 if false { } else { r.EncodeInt(int64(x.Min)) } } - if yyr1567 || yy2arr1567 { + if yyr1591 || yy2arr1591 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1572 := z.EncBinary() - _ = yym1572 + yym1596 := z.EncBinary() + _ = yym1596 if false { } else { r.EncodeInt(int64(x.Max)) @@ -18591,14 +18688,14 @@ func (x *IDRange) CodecEncodeSelf(e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("max")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1573 := z.EncBinary() - _ = yym1573 + yym1597 := z.EncBinary() + _ = yym1597 if false { } else { r.EncodeInt(int64(x.Max)) } } - if yyr1567 || yy2arr1567 { + if yyr1591 || yy2arr1591 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -18611,25 +18708,25 @@ func (x *IDRange) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1574 := z.DecBinary() - _ = yym1574 + yym1598 := z.DecBinary() + _ = yym1598 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1575 := r.ContainerType() - if yyct1575 == codecSelferValueTypeMap1234 { - yyl1575 := r.ReadMapStart() - if yyl1575 == 0 { + yyct1599 := r.ContainerType() + if yyct1599 == codecSelferValueTypeMap1234 { + yyl1599 := r.ReadMapStart() + if yyl1599 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1575, d) + x.codecDecodeSelfFromMap(yyl1599, d) } - } else if yyct1575 == codecSelferValueTypeArray1234 { - yyl1575 := r.ReadArrayStart() - if yyl1575 == 0 { + } else if yyct1599 == codecSelferValueTypeArray1234 { + yyl1599 := r.ReadArrayStart() + if yyl1599 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1575, d) + x.codecDecodeSelfFromArray(yyl1599, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -18641,12 +18738,12 @@ func (x *IDRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1576Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1576Slc - var yyhl1576 bool = l >= 0 - for yyj1576 := 0; ; yyj1576++ { - if yyhl1576 { - if yyj1576 >= l { + var yys1600Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1600Slc + var yyhl1600 bool = l >= 0 + for yyj1600 := 0; ; yyj1600++ { + if yyhl1600 { + if yyj1600 >= l { break } } else { @@ -18655,10 +18752,10 @@ func (x *IDRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1576Slc = r.DecodeBytes(yys1576Slc, true, true) - yys1576 := string(yys1576Slc) + yys1600Slc = r.DecodeBytes(yys1600Slc, true, true) + yys1600 := string(yys1600Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1576 { + switch yys1600 { case "min": if r.TryDecodeAsNil() { x.Min = 0 @@ -18672,9 +18769,9 @@ func (x *IDRange) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { x.Max = int64(r.DecodeInt(64)) } default: - z.DecStructFieldNotFound(-1, yys1576) - } // end switch yys1576 - } // end for yyj1576 + z.DecStructFieldNotFound(-1, yys1600) + } // end switch yys1600 + } // end for yyj1600 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -18682,16 +18779,16 @@ func (x *IDRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1579 int - var yyb1579 bool - var yyhl1579 bool = l >= 0 - yyj1579++ - if yyhl1579 { - yyb1579 = yyj1579 > l + var yyj1603 int + var yyb1603 bool + var yyhl1603 bool = l >= 0 + yyj1603++ + if yyhl1603 { + yyb1603 = yyj1603 > l } else { - yyb1579 = r.CheckBreak() + yyb1603 = r.CheckBreak() } - if yyb1579 { + if yyb1603 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18701,13 +18798,13 @@ func (x *IDRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Min = int64(r.DecodeInt(64)) } - yyj1579++ - if yyhl1579 { - yyb1579 = yyj1579 > l + yyj1603++ + if yyhl1603 { + yyb1603 = yyj1603 > l } else { - yyb1579 = r.CheckBreak() + yyb1603 = r.CheckBreak() } - if yyb1579 { + if yyb1603 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18718,17 +18815,17 @@ func (x *IDRange) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { x.Max = int64(r.DecodeInt(64)) } for { - yyj1579++ - if yyhl1579 { - yyb1579 = yyj1579 > l + yyj1603++ + if yyhl1603 { + yyb1603 = yyj1603 > l } else { - yyb1579 = r.CheckBreak() + yyb1603 = r.CheckBreak() } - if yyb1579 { + if yyb1603 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1579-1, "") + z.DecStructFieldNotFound(yyj1603-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18737,8 +18834,8 @@ func (x RunAsUserStrategy) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1582 := z.EncBinary() - _ = yym1582 + yym1606 := z.EncBinary() + _ = yym1606 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -18750,8 +18847,8 @@ func (x *RunAsUserStrategy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1583 := z.DecBinary() - _ = yym1583 + yym1607 := z.DecBinary() + _ = yym1607 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -18766,54 +18863,54 @@ func (x *FSGroupStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1584 := z.EncBinary() - _ = yym1584 + yym1608 := z.EncBinary() + _ = yym1608 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1585 := !z.EncBinary() - yy2arr1585 := z.EncBasicHandle().StructToArray - var yyq1585 [2]bool - _, _, _ = yysep1585, yyq1585, yy2arr1585 - const yyr1585 bool = false - yyq1585[0] = x.Rule != "" - yyq1585[1] = len(x.Ranges) != 0 - var yynn1585 int - if yyr1585 || yy2arr1585 { + yysep1609 := !z.EncBinary() + yy2arr1609 := z.EncBasicHandle().StructToArray + var yyq1609 [2]bool + _, _, _ = yysep1609, yyq1609, yy2arr1609 + const yyr1609 bool = false + yyq1609[0] = x.Rule != "" + yyq1609[1] = len(x.Ranges) != 0 + var yynn1609 int + if yyr1609 || yy2arr1609 { r.EncodeArrayStart(2) } else { - yynn1585 = 0 - for _, b := range yyq1585 { + yynn1609 = 0 + for _, b := range yyq1609 { if b { - yynn1585++ + yynn1609++ } } - r.EncodeMapStart(yynn1585) - yynn1585 = 0 + r.EncodeMapStart(yynn1609) + yynn1609 = 0 } - if yyr1585 || yy2arr1585 { + if yyr1609 || yy2arr1609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1585[0] { + if yyq1609[0] { x.Rule.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1585[0] { + if yyq1609[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rule")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } } - if yyr1585 || yy2arr1585 { + if yyr1609 || yy2arr1609 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1585[1] { + if yyq1609[1] { if x.Ranges == nil { r.EncodeNil() } else { - yym1588 := z.EncBinary() - _ = yym1588 + yym1612 := z.EncBinary() + _ = yym1612 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -18823,15 +18920,15 @@ func (x *FSGroupStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1585[1] { + if yyq1609[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ranges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ranges == nil { r.EncodeNil() } else { - yym1589 := z.EncBinary() - _ = yym1589 + yym1613 := z.EncBinary() + _ = yym1613 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -18839,7 +18936,7 @@ func (x *FSGroupStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1585 || yy2arr1585 { + if yyr1609 || yy2arr1609 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -18852,25 +18949,25 @@ func (x *FSGroupStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1590 := z.DecBinary() - _ = yym1590 + yym1614 := z.DecBinary() + _ = yym1614 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1591 := r.ContainerType() - if yyct1591 == codecSelferValueTypeMap1234 { - yyl1591 := r.ReadMapStart() - if yyl1591 == 0 { + yyct1615 := r.ContainerType() + if yyct1615 == codecSelferValueTypeMap1234 { + yyl1615 := r.ReadMapStart() + if yyl1615 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1591, d) + x.codecDecodeSelfFromMap(yyl1615, d) } - } else if yyct1591 == codecSelferValueTypeArray1234 { - yyl1591 := r.ReadArrayStart() - if yyl1591 == 0 { + } else if yyct1615 == codecSelferValueTypeArray1234 { + yyl1615 := r.ReadArrayStart() + if yyl1615 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1591, d) + x.codecDecodeSelfFromArray(yyl1615, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -18882,12 +18979,12 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1592Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1592Slc - var yyhl1592 bool = l >= 0 - for yyj1592 := 0; ; yyj1592++ { - if yyhl1592 { - if yyj1592 >= l { + var yys1616Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1616Slc + var yyhl1616 bool = l >= 0 + for yyj1616 := 0; ; yyj1616++ { + if yyhl1616 { + if yyj1616 >= l { break } } else { @@ -18896,10 +18993,10 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1592Slc = r.DecodeBytes(yys1592Slc, true, true) - yys1592 := string(yys1592Slc) + yys1616Slc = r.DecodeBytes(yys1616Slc, true, true) + yys1616 := string(yys1616Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1592 { + switch yys1616 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -18910,18 +19007,18 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromMap(l int, d *codec1978.Deco if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1594 := &x.Ranges - yym1595 := z.DecBinary() - _ = yym1595 + yyv1618 := &x.Ranges + yym1619 := z.DecBinary() + _ = yym1619 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1594), d) + h.decSliceIDRange((*[]IDRange)(yyv1618), d) } } default: - z.DecStructFieldNotFound(-1, yys1592) - } // end switch yys1592 - } // end for yyj1592 + z.DecStructFieldNotFound(-1, yys1616) + } // end switch yys1616 + } // end for yyj1616 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -18929,16 +19026,16 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1596 int - var yyb1596 bool - var yyhl1596 bool = l >= 0 - yyj1596++ - if yyhl1596 { - yyb1596 = yyj1596 > l + var yyj1620 int + var yyb1620 bool + var yyhl1620 bool = l >= 0 + yyj1620++ + if yyhl1620 { + yyb1620 = yyj1620 > l } else { - yyb1596 = r.CheckBreak() + yyb1620 = r.CheckBreak() } - if yyb1596 { + if yyb1620 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18948,13 +19045,13 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De } else { x.Rule = FSGroupStrategyType(r.DecodeString()) } - yyj1596++ - if yyhl1596 { - yyb1596 = yyj1596 > l + yyj1620++ + if yyhl1620 { + yyb1620 = yyj1620 > l } else { - yyb1596 = r.CheckBreak() + yyb1620 = r.CheckBreak() } - if yyb1596 { + if yyb1620 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -18962,26 +19059,26 @@ func (x *FSGroupStrategyOptions) codecDecodeSelfFromArray(l int, d *codec1978.De if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1598 := &x.Ranges - yym1599 := z.DecBinary() - _ = yym1599 + yyv1622 := &x.Ranges + yym1623 := z.DecBinary() + _ = yym1623 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1598), d) + h.decSliceIDRange((*[]IDRange)(yyv1622), d) } } for { - yyj1596++ - if yyhl1596 { - yyb1596 = yyj1596 > l + yyj1620++ + if yyhl1620 { + yyb1620 = yyj1620 > l } else { - yyb1596 = r.CheckBreak() + yyb1620 = r.CheckBreak() } - if yyb1596 { + if yyb1620 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1596-1, "") + z.DecStructFieldNotFound(yyj1620-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -18990,8 +19087,8 @@ func (x FSGroupStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1600 := z.EncBinary() - _ = yym1600 + yym1624 := z.EncBinary() + _ = yym1624 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -19003,8 +19100,8 @@ func (x *FSGroupStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1601 := z.DecBinary() - _ = yym1601 + yym1625 := z.DecBinary() + _ = yym1625 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -19019,54 +19116,54 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder if x == nil { r.EncodeNil() } else { - yym1602 := z.EncBinary() - _ = yym1602 + yym1626 := z.EncBinary() + _ = yym1626 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1603 := !z.EncBinary() - yy2arr1603 := z.EncBasicHandle().StructToArray - var yyq1603 [2]bool - _, _, _ = yysep1603, yyq1603, yy2arr1603 - const yyr1603 bool = false - yyq1603[0] = x.Rule != "" - yyq1603[1] = len(x.Ranges) != 0 - var yynn1603 int - if yyr1603 || yy2arr1603 { + yysep1627 := !z.EncBinary() + yy2arr1627 := z.EncBasicHandle().StructToArray + var yyq1627 [2]bool + _, _, _ = yysep1627, yyq1627, yy2arr1627 + const yyr1627 bool = false + yyq1627[0] = x.Rule != "" + yyq1627[1] = len(x.Ranges) != 0 + var yynn1627 int + if yyr1627 || yy2arr1627 { r.EncodeArrayStart(2) } else { - yynn1603 = 0 - for _, b := range yyq1603 { + yynn1627 = 0 + for _, b := range yyq1627 { if b { - yynn1603++ + yynn1627++ } } - r.EncodeMapStart(yynn1603) - yynn1603 = 0 + r.EncodeMapStart(yynn1627) + yynn1627 = 0 } - if yyr1603 || yy2arr1603 { + if yyr1627 || yy2arr1627 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1603[0] { + if yyq1627[0] { x.Rule.CodecEncodeSelf(e) } else { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1603[0] { + if yyq1627[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("rule")) z.EncSendContainerState(codecSelfer_containerMapValue1234) x.Rule.CodecEncodeSelf(e) } } - if yyr1603 || yy2arr1603 { + if yyr1627 || yy2arr1627 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1603[1] { + if yyq1627[1] { if x.Ranges == nil { r.EncodeNil() } else { - yym1606 := z.EncBinary() - _ = yym1606 + yym1630 := z.EncBinary() + _ = yym1630 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -19076,15 +19173,15 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder r.EncodeNil() } } else { - if yyq1603[1] { + if yyq1627[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ranges")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ranges == nil { r.EncodeNil() } else { - yym1607 := z.EncBinary() - _ = yym1607 + yym1631 := z.EncBinary() + _ = yym1631 if false { } else { h.encSliceIDRange(([]IDRange)(x.Ranges), e) @@ -19092,7 +19189,7 @@ func (x *SupplementalGroupsStrategyOptions) CodecEncodeSelf(e *codec1978.Encoder } } } - if yyr1603 || yy2arr1603 { + if yyr1627 || yy2arr1627 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -19105,25 +19202,25 @@ func (x *SupplementalGroupsStrategyOptions) CodecDecodeSelf(d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1608 := z.DecBinary() - _ = yym1608 + yym1632 := z.DecBinary() + _ = yym1632 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1609 := r.ContainerType() - if yyct1609 == codecSelferValueTypeMap1234 { - yyl1609 := r.ReadMapStart() - if yyl1609 == 0 { + yyct1633 := r.ContainerType() + if yyct1633 == codecSelferValueTypeMap1234 { + yyl1633 := r.ReadMapStart() + if yyl1633 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1609, d) + x.codecDecodeSelfFromMap(yyl1633, d) } - } else if yyct1609 == codecSelferValueTypeArray1234 { - yyl1609 := r.ReadArrayStart() - if yyl1609 == 0 { + } else if yyct1633 == codecSelferValueTypeArray1234 { + yyl1633 := r.ReadArrayStart() + if yyl1633 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1609, d) + x.codecDecodeSelfFromArray(yyl1633, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -19135,12 +19232,12 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1610Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1610Slc - var yyhl1610 bool = l >= 0 - for yyj1610 := 0; ; yyj1610++ { - if yyhl1610 { - if yyj1610 >= l { + var yys1634Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1634Slc + var yyhl1634 bool = l >= 0 + for yyj1634 := 0; ; yyj1634++ { + if yyhl1634 { + if yyj1634 >= l { break } } else { @@ -19149,10 +19246,10 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1610Slc = r.DecodeBytes(yys1610Slc, true, true) - yys1610 := string(yys1610Slc) + yys1634Slc = r.DecodeBytes(yys1634Slc, true, true) + yys1634 := string(yys1634Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1610 { + switch yys1634 { case "rule": if r.TryDecodeAsNil() { x.Rule = "" @@ -19163,18 +19260,18 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromMap(l int, d *cod if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1612 := &x.Ranges - yym1613 := z.DecBinary() - _ = yym1613 + yyv1636 := &x.Ranges + yym1637 := z.DecBinary() + _ = yym1637 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1612), d) + h.decSliceIDRange((*[]IDRange)(yyv1636), d) } } default: - z.DecStructFieldNotFound(-1, yys1610) - } // end switch yys1610 - } // end for yyj1610 + z.DecStructFieldNotFound(-1, yys1634) + } // end switch yys1634 + } // end for yyj1634 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -19182,16 +19279,16 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1614 int - var yyb1614 bool - var yyhl1614 bool = l >= 0 - yyj1614++ - if yyhl1614 { - yyb1614 = yyj1614 > l + var yyj1638 int + var yyb1638 bool + var yyhl1638 bool = l >= 0 + yyj1638++ + if yyhl1638 { + yyb1638 = yyj1638 > l } else { - yyb1614 = r.CheckBreak() + yyb1638 = r.CheckBreak() } - if yyb1614 { + if yyb1638 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19201,13 +19298,13 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c } else { x.Rule = SupplementalGroupsStrategyType(r.DecodeString()) } - yyj1614++ - if yyhl1614 { - yyb1614 = yyj1614 > l + yyj1638++ + if yyhl1638 { + yyb1638 = yyj1638 > l } else { - yyb1614 = r.CheckBreak() + yyb1638 = r.CheckBreak() } - if yyb1614 { + if yyb1638 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19215,26 +19312,26 @@ func (x *SupplementalGroupsStrategyOptions) codecDecodeSelfFromArray(l int, d *c if r.TryDecodeAsNil() { x.Ranges = nil } else { - yyv1616 := &x.Ranges - yym1617 := z.DecBinary() - _ = yym1617 + yyv1640 := &x.Ranges + yym1641 := z.DecBinary() + _ = yym1641 if false { } else { - h.decSliceIDRange((*[]IDRange)(yyv1616), d) + h.decSliceIDRange((*[]IDRange)(yyv1640), d) } } for { - yyj1614++ - if yyhl1614 { - yyb1614 = yyj1614 > l + yyj1638++ + if yyhl1638 { + yyb1638 = yyj1638 > l } else { - yyb1614 = r.CheckBreak() + yyb1638 = r.CheckBreak() } - if yyb1614 { + if yyb1638 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1614-1, "") + z.DecStructFieldNotFound(yyj1638-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -19243,8 +19340,8 @@ func (x SupplementalGroupsStrategyType) CodecEncodeSelf(e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r - yym1618 := z.EncBinary() - _ = yym1618 + yym1642 := z.EncBinary() + _ = yym1642 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { @@ -19256,8 +19353,8 @@ func (x *SupplementalGroupsStrategyType) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1619 := z.DecBinary() - _ = yym1619 + yym1643 := z.DecBinary() + _ = yym1643 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { @@ -19272,37 +19369,37 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1620 := z.EncBinary() - _ = yym1620 + yym1644 := z.EncBinary() + _ = yym1644 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1621 := !z.EncBinary() - yy2arr1621 := z.EncBasicHandle().StructToArray - var yyq1621 [4]bool - _, _, _ = yysep1621, yyq1621, yy2arr1621 - const yyr1621 bool = false - yyq1621[0] = x.Kind != "" - yyq1621[1] = x.APIVersion != "" - yyq1621[2] = true - var yynn1621 int - if yyr1621 || yy2arr1621 { + yysep1645 := !z.EncBinary() + yy2arr1645 := z.EncBasicHandle().StructToArray + var yyq1645 [4]bool + _, _, _ = yysep1645, yyq1645, yy2arr1645 + const yyr1645 bool = false + yyq1645[0] = x.Kind != "" + yyq1645[1] = x.APIVersion != "" + yyq1645[2] = true + var yynn1645 int + if yyr1645 || yy2arr1645 { r.EncodeArrayStart(4) } else { - yynn1621 = 1 - for _, b := range yyq1621 { + yynn1645 = 1 + for _, b := range yyq1645 { if b { - yynn1621++ + yynn1645++ } } - r.EncodeMapStart(yynn1621) - yynn1621 = 0 + r.EncodeMapStart(yynn1645) + yynn1645 = 0 } - if yyr1621 || yy2arr1621 { + if yyr1645 || yy2arr1645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1621[0] { - yym1623 := z.EncBinary() - _ = yym1623 + if yyq1645[0] { + yym1647 := z.EncBinary() + _ = yym1647 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -19311,23 +19408,23 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1621[0] { + if yyq1645[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1624 := z.EncBinary() - _ = yym1624 + yym1648 := z.EncBinary() + _ = yym1648 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1621 || yy2arr1621 { + if yyr1645 || yy2arr1645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1621[1] { - yym1626 := z.EncBinary() - _ = yym1626 + if yyq1645[1] { + yym1650 := z.EncBinary() + _ = yym1650 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -19336,54 +19433,54 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1621[1] { + if yyq1645[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1627 := z.EncBinary() - _ = yym1627 + yym1651 := z.EncBinary() + _ = yym1651 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1621 || yy2arr1621 { + if yyr1645 || yy2arr1645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1621[2] { - yy1629 := &x.ListMeta - yym1630 := z.EncBinary() - _ = yym1630 + if yyq1645[2] { + yy1653 := &x.ListMeta + yym1654 := z.EncBinary() + _ = yym1654 if false { - } else if z.HasExtensions() && z.EncExt(yy1629) { + } else if z.HasExtensions() && z.EncExt(yy1653) { } else { - z.EncFallback(yy1629) + z.EncFallback(yy1653) } } else { r.EncodeNil() } } else { - if yyq1621[2] { + if yyq1645[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1631 := &x.ListMeta - yym1632 := z.EncBinary() - _ = yym1632 + yy1655 := &x.ListMeta + yym1656 := z.EncBinary() + _ = yym1656 if false { - } else if z.HasExtensions() && z.EncExt(yy1631) { + } else if z.HasExtensions() && z.EncExt(yy1655) { } else { - z.EncFallback(yy1631) + z.EncFallback(yy1655) } } } - if yyr1621 || yy2arr1621 { + if yyr1645 || yy2arr1645 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1634 := z.EncBinary() - _ = yym1634 + yym1658 := z.EncBinary() + _ = yym1658 if false { } else { h.encSlicePodSecurityPolicy(([]PodSecurityPolicy)(x.Items), e) @@ -19396,15 +19493,15 @@ func (x *PodSecurityPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1635 := z.EncBinary() - _ = yym1635 + yym1659 := z.EncBinary() + _ = yym1659 if false { } else { h.encSlicePodSecurityPolicy(([]PodSecurityPolicy)(x.Items), e) } } } - if yyr1621 || yy2arr1621 { + if yyr1645 || yy2arr1645 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -19417,25 +19514,25 @@ func (x *PodSecurityPolicyList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1636 := z.DecBinary() - _ = yym1636 + yym1660 := z.DecBinary() + _ = yym1660 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1637 := r.ContainerType() - if yyct1637 == codecSelferValueTypeMap1234 { - yyl1637 := r.ReadMapStart() - if yyl1637 == 0 { + yyct1661 := r.ContainerType() + if yyct1661 == codecSelferValueTypeMap1234 { + yyl1661 := r.ReadMapStart() + if yyl1661 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1637, d) + x.codecDecodeSelfFromMap(yyl1661, d) } - } else if yyct1637 == codecSelferValueTypeArray1234 { - yyl1637 := r.ReadArrayStart() - if yyl1637 == 0 { + } else if yyct1661 == codecSelferValueTypeArray1234 { + yyl1661 := r.ReadArrayStart() + if yyl1661 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1637, d) + x.codecDecodeSelfFromArray(yyl1661, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -19447,12 +19544,12 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1638Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1638Slc - var yyhl1638 bool = l >= 0 - for yyj1638 := 0; ; yyj1638++ { - if yyhl1638 { - if yyj1638 >= l { + var yys1662Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1662Slc + var yyhl1662 bool = l >= 0 + for yyj1662 := 0; ; yyj1662++ { + if yyhl1662 { + if yyj1662 >= l { break } } else { @@ -19461,10 +19558,10 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1638Slc = r.DecodeBytes(yys1638Slc, true, true) - yys1638 := string(yys1638Slc) + yys1662Slc = r.DecodeBytes(yys1662Slc, true, true) + yys1662 := string(yys1662Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1638 { + switch yys1662 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -19481,31 +19578,31 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decod if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1641 := &x.ListMeta - yym1642 := z.DecBinary() - _ = yym1642 + yyv1665 := &x.ListMeta + yym1666 := z.DecBinary() + _ = yym1666 if false { - } else if z.HasExtensions() && z.DecExt(yyv1641) { + } else if z.HasExtensions() && z.DecExt(yyv1665) { } else { - z.DecFallback(yyv1641, false) + z.DecFallback(yyv1665, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1643 := &x.Items - yym1644 := z.DecBinary() - _ = yym1644 + yyv1667 := &x.Items + yym1668 := z.DecBinary() + _ = yym1668 if false { } else { - h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1643), d) + h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1667), d) } } default: - z.DecStructFieldNotFound(-1, yys1638) - } // end switch yys1638 - } // end for yyj1638 + z.DecStructFieldNotFound(-1, yys1662) + } // end switch yys1662 + } // end for yyj1662 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -19513,16 +19610,16 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1645 int - var yyb1645 bool - var yyhl1645 bool = l >= 0 - yyj1645++ - if yyhl1645 { - yyb1645 = yyj1645 > l + var yyj1669 int + var yyb1669 bool + var yyhl1669 bool = l >= 0 + yyj1669++ + if yyhl1669 { + yyb1669 = yyj1669 > l } else { - yyb1645 = r.CheckBreak() + yyb1669 = r.CheckBreak() } - if yyb1645 { + if yyb1669 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19532,13 +19629,13 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.Kind = string(r.DecodeString()) } - yyj1645++ - if yyhl1645 { - yyb1645 = yyj1645 > l + yyj1669++ + if yyhl1669 { + yyb1669 = yyj1669 > l } else { - yyb1645 = r.CheckBreak() + yyb1669 = r.CheckBreak() } - if yyb1645 { + if yyb1669 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19548,13 +19645,13 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec } else { x.APIVersion = string(r.DecodeString()) } - yyj1645++ - if yyhl1645 { - yyb1645 = yyj1645 > l + yyj1669++ + if yyhl1669 { + yyb1669 = yyj1669 > l } else { - yyb1645 = r.CheckBreak() + yyb1669 = r.CheckBreak() } - if yyb1645 { + if yyb1669 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19562,22 +19659,22 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1648 := &x.ListMeta - yym1649 := z.DecBinary() - _ = yym1649 + yyv1672 := &x.ListMeta + yym1673 := z.DecBinary() + _ = yym1673 if false { - } else if z.HasExtensions() && z.DecExt(yyv1648) { + } else if z.HasExtensions() && z.DecExt(yyv1672) { } else { - z.DecFallback(yyv1648, false) + z.DecFallback(yyv1672, false) } } - yyj1645++ - if yyhl1645 { - yyb1645 = yyj1645 > l + yyj1669++ + if yyhl1669 { + yyb1669 = yyj1669 > l } else { - yyb1645 = r.CheckBreak() + yyb1669 = r.CheckBreak() } - if yyb1645 { + if yyb1669 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19585,26 +19682,26 @@ func (x *PodSecurityPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Dec if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1650 := &x.Items - yym1651 := z.DecBinary() - _ = yym1651 + yyv1674 := &x.Items + yym1675 := z.DecBinary() + _ = yym1675 if false { } else { - h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1650), d) + h.decSlicePodSecurityPolicy((*[]PodSecurityPolicy)(yyv1674), d) } } for { - yyj1645++ - if yyhl1645 { - yyb1645 = yyj1645 > l + yyj1669++ + if yyhl1669 { + yyb1669 = yyj1669 > l } else { - yyb1645 = r.CheckBreak() + yyb1669 = r.CheckBreak() } - if yyb1645 { + if yyb1669 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1645-1, "") + z.DecStructFieldNotFound(yyj1669-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -19616,38 +19713,38 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1652 := z.EncBinary() - _ = yym1652 + yym1676 := z.EncBinary() + _ = yym1676 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1653 := !z.EncBinary() - yy2arr1653 := z.EncBasicHandle().StructToArray - var yyq1653 [4]bool - _, _, _ = yysep1653, yyq1653, yy2arr1653 - const yyr1653 bool = false - yyq1653[0] = x.Kind != "" - yyq1653[1] = x.APIVersion != "" - yyq1653[2] = true - yyq1653[3] = true - var yynn1653 int - if yyr1653 || yy2arr1653 { + yysep1677 := !z.EncBinary() + yy2arr1677 := z.EncBasicHandle().StructToArray + var yyq1677 [4]bool + _, _, _ = yysep1677, yyq1677, yy2arr1677 + const yyr1677 bool = false + yyq1677[0] = x.Kind != "" + yyq1677[1] = x.APIVersion != "" + yyq1677[2] = true + yyq1677[3] = true + var yynn1677 int + if yyr1677 || yy2arr1677 { r.EncodeArrayStart(4) } else { - yynn1653 = 0 - for _, b := range yyq1653 { + yynn1677 = 0 + for _, b := range yyq1677 { if b { - yynn1653++ + yynn1677++ } } - r.EncodeMapStart(yynn1653) - yynn1653 = 0 + r.EncodeMapStart(yynn1677) + yynn1677 = 0 } - if yyr1653 || yy2arr1653 { + if yyr1677 || yy2arr1677 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1653[0] { - yym1655 := z.EncBinary() - _ = yym1655 + if yyq1677[0] { + yym1679 := z.EncBinary() + _ = yym1679 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -19656,23 +19753,23 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1653[0] { + if yyq1677[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1656 := z.EncBinary() - _ = yym1656 + yym1680 := z.EncBinary() + _ = yym1680 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1653 || yy2arr1653 { + if yyr1677 || yy2arr1677 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1653[1] { - yym1658 := z.EncBinary() - _ = yym1658 + if yyq1677[1] { + yym1682 := z.EncBinary() + _ = yym1682 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -19681,53 +19778,53 @@ func (x *NetworkPolicy) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1653[1] { + if yyq1677[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1659 := z.EncBinary() - _ = yym1659 + yym1683 := z.EncBinary() + _ = yym1683 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1653 || yy2arr1653 { + if yyr1677 || yy2arr1677 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1653[2] { - yy1661 := &x.ObjectMeta - yy1661.CodecEncodeSelf(e) + if yyq1677[2] { + yy1685 := &x.ObjectMeta + yy1685.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1653[2] { + if yyq1677[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1662 := &x.ObjectMeta - yy1662.CodecEncodeSelf(e) + yy1686 := &x.ObjectMeta + yy1686.CodecEncodeSelf(e) } } - if yyr1653 || yy2arr1653 { + if yyr1677 || yy2arr1677 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1653[3] { - yy1664 := &x.Spec - yy1664.CodecEncodeSelf(e) + if yyq1677[3] { + yy1688 := &x.Spec + yy1688.CodecEncodeSelf(e) } else { r.EncodeNil() } } else { - if yyq1653[3] { + if yyq1677[3] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("spec")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1665 := &x.Spec - yy1665.CodecEncodeSelf(e) + yy1689 := &x.Spec + yy1689.CodecEncodeSelf(e) } } - if yyr1653 || yy2arr1653 { + if yyr1677 || yy2arr1677 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -19740,25 +19837,25 @@ func (x *NetworkPolicy) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1666 := z.DecBinary() - _ = yym1666 + yym1690 := z.DecBinary() + _ = yym1690 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1667 := r.ContainerType() - if yyct1667 == codecSelferValueTypeMap1234 { - yyl1667 := r.ReadMapStart() - if yyl1667 == 0 { + yyct1691 := r.ContainerType() + if yyct1691 == codecSelferValueTypeMap1234 { + yyl1691 := r.ReadMapStart() + if yyl1691 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1667, d) + x.codecDecodeSelfFromMap(yyl1691, d) } - } else if yyct1667 == codecSelferValueTypeArray1234 { - yyl1667 := r.ReadArrayStart() - if yyl1667 == 0 { + } else if yyct1691 == codecSelferValueTypeArray1234 { + yyl1691 := r.ReadArrayStart() + if yyl1691 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1667, d) + x.codecDecodeSelfFromArray(yyl1691, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -19770,12 +19867,12 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1668Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1668Slc - var yyhl1668 bool = l >= 0 - for yyj1668 := 0; ; yyj1668++ { - if yyhl1668 { - if yyj1668 >= l { + var yys1692Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1692Slc + var yyhl1692 bool = l >= 0 + for yyj1692 := 0; ; yyj1692++ { + if yyhl1692 { + if yyj1692 >= l { break } } else { @@ -19784,10 +19881,10 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1668Slc = r.DecodeBytes(yys1668Slc, true, true) - yys1668 := string(yys1668Slc) + yys1692Slc = r.DecodeBytes(yys1692Slc, true, true) + yys1692 := string(yys1692Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1668 { + switch yys1692 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -19804,20 +19901,20 @@ func (x *NetworkPolicy) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1671 := &x.ObjectMeta - yyv1671.CodecDecodeSelf(d) + yyv1695 := &x.ObjectMeta + yyv1695.CodecDecodeSelf(d) } case "spec": if r.TryDecodeAsNil() { x.Spec = NetworkPolicySpec{} } else { - yyv1672 := &x.Spec - yyv1672.CodecDecodeSelf(d) + yyv1696 := &x.Spec + yyv1696.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1668) - } // end switch yys1668 - } // end for yyj1668 + z.DecStructFieldNotFound(-1, yys1692) + } // end switch yys1692 + } // end for yyj1692 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -19825,16 +19922,16 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1673 int - var yyb1673 bool - var yyhl1673 bool = l >= 0 - yyj1673++ - if yyhl1673 { - yyb1673 = yyj1673 > l + var yyj1697 int + var yyb1697 bool + var yyhl1697 bool = l >= 0 + yyj1697++ + if yyhl1697 { + yyb1697 = yyj1697 > l } else { - yyb1673 = r.CheckBreak() + yyb1697 = r.CheckBreak() } - if yyb1673 { + if yyb1697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19844,13 +19941,13 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.Kind = string(r.DecodeString()) } - yyj1673++ - if yyhl1673 { - yyb1673 = yyj1673 > l + yyj1697++ + if yyhl1697 { + yyb1697 = yyj1697 > l } else { - yyb1673 = r.CheckBreak() + yyb1697 = r.CheckBreak() } - if yyb1673 { + if yyb1697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19860,13 +19957,13 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { } else { x.APIVersion = string(r.DecodeString()) } - yyj1673++ - if yyhl1673 { - yyb1673 = yyj1673 > l + yyj1697++ + if yyhl1697 { + yyb1697 = yyj1697 > l } else { - yyb1673 = r.CheckBreak() + yyb1697 = r.CheckBreak() } - if yyb1673 { + if yyb1697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19874,16 +19971,16 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.ObjectMeta = pkg2_v1.ObjectMeta{} } else { - yyv1676 := &x.ObjectMeta - yyv1676.CodecDecodeSelf(d) + yyv1700 := &x.ObjectMeta + yyv1700.CodecDecodeSelf(d) } - yyj1673++ - if yyhl1673 { - yyb1673 = yyj1673 > l + yyj1697++ + if yyhl1697 { + yyb1697 = yyj1697 > l } else { - yyb1673 = r.CheckBreak() + yyb1697 = r.CheckBreak() } - if yyb1673 { + if yyb1697 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -19891,21 +19988,21 @@ func (x *NetworkPolicy) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { if r.TryDecodeAsNil() { x.Spec = NetworkPolicySpec{} } else { - yyv1677 := &x.Spec - yyv1677.CodecDecodeSelf(d) + yyv1701 := &x.Spec + yyv1701.CodecDecodeSelf(d) } for { - yyj1673++ - if yyhl1673 { - yyb1673 = yyj1673 > l + yyj1697++ + if yyhl1697 { + yyb1697 = yyj1697 > l } else { - yyb1673 = r.CheckBreak() + yyb1697 = r.CheckBreak() } - if yyb1673 { + if yyb1697 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1673-1, "") + z.DecStructFieldNotFound(yyj1697-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -19917,49 +20014,61 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1678 := z.EncBinary() - _ = yym1678 + yym1702 := z.EncBinary() + _ = yym1702 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1679 := !z.EncBinary() - yy2arr1679 := z.EncBasicHandle().StructToArray - var yyq1679 [2]bool - _, _, _ = yysep1679, yyq1679, yy2arr1679 - const yyr1679 bool = false - yyq1679[1] = len(x.Ingress) != 0 - var yynn1679 int - if yyr1679 || yy2arr1679 { + yysep1703 := !z.EncBinary() + yy2arr1703 := z.EncBasicHandle().StructToArray + var yyq1703 [2]bool + _, _, _ = yysep1703, yyq1703, yy2arr1703 + const yyr1703 bool = false + yyq1703[1] = len(x.Ingress) != 0 + var yynn1703 int + if yyr1703 || yy2arr1703 { r.EncodeArrayStart(2) } else { - yynn1679 = 1 - for _, b := range yyq1679 { + yynn1703 = 1 + for _, b := range yyq1703 { if b { - yynn1679++ + yynn1703++ } } - r.EncodeMapStart(yynn1679) - yynn1679 = 0 + r.EncodeMapStart(yynn1703) + yynn1703 = 0 } - if yyr1679 || yy2arr1679 { + if yyr1703 || yy2arr1703 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1681 := &x.PodSelector - yy1681.CodecEncodeSelf(e) + yy1705 := &x.PodSelector + yym1706 := z.EncBinary() + _ = yym1706 + if false { + } else if z.HasExtensions() && z.EncExt(yy1705) { + } else { + z.EncFallback(yy1705) + } } else { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1682 := &x.PodSelector - yy1682.CodecEncodeSelf(e) + yy1707 := &x.PodSelector + yym1708 := z.EncBinary() + _ = yym1708 + if false { + } else if z.HasExtensions() && z.EncExt(yy1707) { + } else { + z.EncFallback(yy1707) + } } - if yyr1679 || yy2arr1679 { + if yyr1703 || yy2arr1703 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1679[1] { + if yyq1703[1] { if x.Ingress == nil { r.EncodeNil() } else { - yym1684 := z.EncBinary() - _ = yym1684 + yym1710 := z.EncBinary() + _ = yym1710 if false { } else { h.encSliceNetworkPolicyIngressRule(([]NetworkPolicyIngressRule)(x.Ingress), e) @@ -19969,15 +20078,15 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1679[1] { + if yyq1703[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ingress")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ingress == nil { r.EncodeNil() } else { - yym1685 := z.EncBinary() - _ = yym1685 + yym1711 := z.EncBinary() + _ = yym1711 if false { } else { h.encSliceNetworkPolicyIngressRule(([]NetworkPolicyIngressRule)(x.Ingress), e) @@ -19985,7 +20094,7 @@ func (x *NetworkPolicySpec) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1679 || yy2arr1679 { + if yyr1703 || yy2arr1703 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -19998,25 +20107,25 @@ func (x *NetworkPolicySpec) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1686 := z.DecBinary() - _ = yym1686 + yym1712 := z.DecBinary() + _ = yym1712 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1687 := r.ContainerType() - if yyct1687 == codecSelferValueTypeMap1234 { - yyl1687 := r.ReadMapStart() - if yyl1687 == 0 { + yyct1713 := r.ContainerType() + if yyct1713 == codecSelferValueTypeMap1234 { + yyl1713 := r.ReadMapStart() + if yyl1713 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1687, d) + x.codecDecodeSelfFromMap(yyl1713, d) } - } else if yyct1687 == codecSelferValueTypeArray1234 { - yyl1687 := r.ReadArrayStart() - if yyl1687 == 0 { + } else if yyct1713 == codecSelferValueTypeArray1234 { + yyl1713 := r.ReadArrayStart() + if yyl1713 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1687, d) + x.codecDecodeSelfFromArray(yyl1713, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -20028,12 +20137,12 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1688Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1688Slc - var yyhl1688 bool = l >= 0 - for yyj1688 := 0; ; yyj1688++ { - if yyhl1688 { - if yyj1688 >= l { + var yys1714Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1714Slc + var yyhl1714 bool = l >= 0 + for yyj1714 := 0; ; yyj1714++ { + if yyhl1714 { + if yyj1714 >= l { break } } else { @@ -20042,33 +20151,39 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1688Slc = r.DecodeBytes(yys1688Slc, true, true) - yys1688 := string(yys1688Slc) + yys1714Slc = r.DecodeBytes(yys1714Slc, true, true) + yys1714 := string(yys1714Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1688 { + switch yys1714 { case "podSelector": if r.TryDecodeAsNil() { - x.PodSelector = LabelSelector{} + x.PodSelector = pkg1_unversioned.LabelSelector{} } else { - yyv1689 := &x.PodSelector - yyv1689.CodecDecodeSelf(d) + yyv1715 := &x.PodSelector + yym1716 := z.DecBinary() + _ = yym1716 + if false { + } else if z.HasExtensions() && z.DecExt(yyv1715) { + } else { + z.DecFallback(yyv1715, false) + } } case "ingress": if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv1690 := &x.Ingress - yym1691 := z.DecBinary() - _ = yym1691 + yyv1717 := &x.Ingress + yym1718 := z.DecBinary() + _ = yym1718 if false { } else { - h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1690), d) + h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1717), d) } } default: - z.DecStructFieldNotFound(-1, yys1688) - } // end switch yys1688 - } // end for yyj1688 + z.DecStructFieldNotFound(-1, yys1714) + } // end switch yys1714 + } // end for yyj1714 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -20076,33 +20191,39 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1692 int - var yyb1692 bool - var yyhl1692 bool = l >= 0 - yyj1692++ - if yyhl1692 { - yyb1692 = yyj1692 > l + var yyj1719 int + var yyb1719 bool + var yyhl1719 bool = l >= 0 + yyj1719++ + if yyhl1719 { + yyb1719 = yyj1719 > l } else { - yyb1692 = r.CheckBreak() + yyb1719 = r.CheckBreak() } - if yyb1692 { + if yyb1719 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } z.DecSendContainerState(codecSelfer_containerArrayElem1234) if r.TryDecodeAsNil() { - x.PodSelector = LabelSelector{} + x.PodSelector = pkg1_unversioned.LabelSelector{} } else { - yyv1693 := &x.PodSelector - yyv1693.CodecDecodeSelf(d) + yyv1720 := &x.PodSelector + yym1721 := z.DecBinary() + _ = yym1721 + if false { + } else if z.HasExtensions() && z.DecExt(yyv1720) { + } else { + z.DecFallback(yyv1720, false) + } } - yyj1692++ - if yyhl1692 { - yyb1692 = yyj1692 > l + yyj1719++ + if yyhl1719 { + yyb1719 = yyj1719 > l } else { - yyb1692 = r.CheckBreak() + yyb1719 = r.CheckBreak() } - if yyb1692 { + if yyb1719 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20110,26 +20231,26 @@ func (x *NetworkPolicySpec) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Ingress = nil } else { - yyv1694 := &x.Ingress - yym1695 := z.DecBinary() - _ = yym1695 + yyv1722 := &x.Ingress + yym1723 := z.DecBinary() + _ = yym1723 if false { } else { - h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1694), d) + h.decSliceNetworkPolicyIngressRule((*[]NetworkPolicyIngressRule)(yyv1722), d) } } for { - yyj1692++ - if yyhl1692 { - yyb1692 = yyj1692 > l + yyj1719++ + if yyhl1719 { + yyb1719 = yyj1719 > l } else { - yyb1692 = r.CheckBreak() + yyb1719 = r.CheckBreak() } - if yyb1692 { + if yyb1719 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1692-1, "") + z.DecStructFieldNotFound(yyj1719-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -20141,39 +20262,39 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1696 := z.EncBinary() - _ = yym1696 + yym1724 := z.EncBinary() + _ = yym1724 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1697 := !z.EncBinary() - yy2arr1697 := z.EncBasicHandle().StructToArray - var yyq1697 [2]bool - _, _, _ = yysep1697, yyq1697, yy2arr1697 - const yyr1697 bool = false - yyq1697[0] = len(x.Ports) != 0 - yyq1697[1] = len(x.From) != 0 - var yynn1697 int - if yyr1697 || yy2arr1697 { + yysep1725 := !z.EncBinary() + yy2arr1725 := z.EncBasicHandle().StructToArray + var yyq1725 [2]bool + _, _, _ = yysep1725, yyq1725, yy2arr1725 + const yyr1725 bool = false + yyq1725[0] = len(x.Ports) != 0 + yyq1725[1] = len(x.From) != 0 + var yynn1725 int + if yyr1725 || yy2arr1725 { r.EncodeArrayStart(2) } else { - yynn1697 = 0 - for _, b := range yyq1697 { + yynn1725 = 0 + for _, b := range yyq1725 { if b { - yynn1697++ + yynn1725++ } } - r.EncodeMapStart(yynn1697) - yynn1697 = 0 + r.EncodeMapStart(yynn1725) + yynn1725 = 0 } - if yyr1697 || yy2arr1697 { + if yyr1725 || yy2arr1725 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1697[0] { + if yyq1725[0] { if x.Ports == nil { r.EncodeNil() } else { - yym1699 := z.EncBinary() - _ = yym1699 + yym1727 := z.EncBinary() + _ = yym1727 if false { } else { h.encSliceNetworkPolicyPort(([]NetworkPolicyPort)(x.Ports), e) @@ -20183,15 +20304,15 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1697[0] { + if yyq1725[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("ports")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Ports == nil { r.EncodeNil() } else { - yym1700 := z.EncBinary() - _ = yym1700 + yym1728 := z.EncBinary() + _ = yym1728 if false { } else { h.encSliceNetworkPolicyPort(([]NetworkPolicyPort)(x.Ports), e) @@ -20199,14 +20320,14 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1697 || yy2arr1697 { + if yyr1725 || yy2arr1725 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1697[1] { + if yyq1725[1] { if x.From == nil { r.EncodeNil() } else { - yym1702 := z.EncBinary() - _ = yym1702 + yym1730 := z.EncBinary() + _ = yym1730 if false { } else { h.encSliceNetworkPolicyPeer(([]NetworkPolicyPeer)(x.From), e) @@ -20216,15 +20337,15 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1697[1] { + if yyq1725[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("from")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.From == nil { r.EncodeNil() } else { - yym1703 := z.EncBinary() - _ = yym1703 + yym1731 := z.EncBinary() + _ = yym1731 if false { } else { h.encSliceNetworkPolicyPeer(([]NetworkPolicyPeer)(x.From), e) @@ -20232,7 +20353,7 @@ func (x *NetworkPolicyIngressRule) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1697 || yy2arr1697 { + if yyr1725 || yy2arr1725 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -20245,25 +20366,25 @@ func (x *NetworkPolicyIngressRule) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1704 := z.DecBinary() - _ = yym1704 + yym1732 := z.DecBinary() + _ = yym1732 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1705 := r.ContainerType() - if yyct1705 == codecSelferValueTypeMap1234 { - yyl1705 := r.ReadMapStart() - if yyl1705 == 0 { + yyct1733 := r.ContainerType() + if yyct1733 == codecSelferValueTypeMap1234 { + yyl1733 := r.ReadMapStart() + if yyl1733 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1705, d) + x.codecDecodeSelfFromMap(yyl1733, d) } - } else if yyct1705 == codecSelferValueTypeArray1234 { - yyl1705 := r.ReadArrayStart() - if yyl1705 == 0 { + } else if yyct1733 == codecSelferValueTypeArray1234 { + yyl1733 := r.ReadArrayStart() + if yyl1733 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1705, d) + x.codecDecodeSelfFromArray(yyl1733, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -20275,12 +20396,12 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromMap(l int, d *codec1978.De var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1706Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1706Slc - var yyhl1706 bool = l >= 0 - for yyj1706 := 0; ; yyj1706++ { - if yyhl1706 { - if yyj1706 >= l { + var yys1734Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1734Slc + var yyhl1734 bool = l >= 0 + for yyj1734 := 0; ; yyj1734++ { + if yyhl1734 { + if yyj1734 >= l { break } } else { @@ -20289,38 +20410,38 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromMap(l int, d *codec1978.De } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1706Slc = r.DecodeBytes(yys1706Slc, true, true) - yys1706 := string(yys1706Slc) + yys1734Slc = r.DecodeBytes(yys1734Slc, true, true) + yys1734 := string(yys1734Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1706 { + switch yys1734 { case "ports": if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv1707 := &x.Ports - yym1708 := z.DecBinary() - _ = yym1708 + yyv1735 := &x.Ports + yym1736 := z.DecBinary() + _ = yym1736 if false { } else { - h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1707), d) + h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1735), d) } } case "from": if r.TryDecodeAsNil() { x.From = nil } else { - yyv1709 := &x.From - yym1710 := z.DecBinary() - _ = yym1710 + yyv1737 := &x.From + yym1738 := z.DecBinary() + _ = yym1738 if false { } else { - h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1709), d) + h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1737), d) } } default: - z.DecStructFieldNotFound(-1, yys1706) - } // end switch yys1706 - } // end for yyj1706 + z.DecStructFieldNotFound(-1, yys1734) + } // end switch yys1734 + } // end for yyj1734 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -20328,16 +20449,16 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1711 int - var yyb1711 bool - var yyhl1711 bool = l >= 0 - yyj1711++ - if yyhl1711 { - yyb1711 = yyj1711 > l + var yyj1739 int + var yyb1739 bool + var yyhl1739 bool = l >= 0 + yyj1739++ + if yyhl1739 { + yyb1739 = yyj1739 > l } else { - yyb1711 = r.CheckBreak() + yyb1739 = r.CheckBreak() } - if yyb1711 { + if yyb1739 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20345,21 +20466,21 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. if r.TryDecodeAsNil() { x.Ports = nil } else { - yyv1712 := &x.Ports - yym1713 := z.DecBinary() - _ = yym1713 + yyv1740 := &x.Ports + yym1741 := z.DecBinary() + _ = yym1741 if false { } else { - h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1712), d) + h.decSliceNetworkPolicyPort((*[]NetworkPolicyPort)(yyv1740), d) } } - yyj1711++ - if yyhl1711 { - yyb1711 = yyj1711 > l + yyj1739++ + if yyhl1739 { + yyb1739 = yyj1739 > l } else { - yyb1711 = r.CheckBreak() + yyb1739 = r.CheckBreak() } - if yyb1711 { + if yyb1739 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20367,26 +20488,26 @@ func (x *NetworkPolicyIngressRule) codecDecodeSelfFromArray(l int, d *codec1978. if r.TryDecodeAsNil() { x.From = nil } else { - yyv1714 := &x.From - yym1715 := z.DecBinary() - _ = yym1715 + yyv1742 := &x.From + yym1743 := z.DecBinary() + _ = yym1743 if false { } else { - h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1714), d) + h.decSliceNetworkPolicyPeer((*[]NetworkPolicyPeer)(yyv1742), d) } } for { - yyj1711++ - if yyhl1711 { - yyb1711 = yyj1711 > l + yyj1739++ + if yyhl1739 { + yyb1739 = yyj1739 > l } else { - yyb1711 = r.CheckBreak() + yyb1739 = r.CheckBreak() } - if yyb1711 { + if yyb1739 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1711-1, "") + z.DecStructFieldNotFound(yyj1739-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -20398,79 +20519,79 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1716 := z.EncBinary() - _ = yym1716 + yym1744 := z.EncBinary() + _ = yym1744 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1717 := !z.EncBinary() - yy2arr1717 := z.EncBasicHandle().StructToArray - var yyq1717 [2]bool - _, _, _ = yysep1717, yyq1717, yy2arr1717 - const yyr1717 bool = false - yyq1717[0] = x.Protocol != nil - yyq1717[1] = x.Port != nil - var yynn1717 int - if yyr1717 || yy2arr1717 { + yysep1745 := !z.EncBinary() + yy2arr1745 := z.EncBasicHandle().StructToArray + var yyq1745 [2]bool + _, _, _ = yysep1745, yyq1745, yy2arr1745 + const yyr1745 bool = false + yyq1745[0] = x.Protocol != nil + yyq1745[1] = x.Port != nil + var yynn1745 int + if yyr1745 || yy2arr1745 { r.EncodeArrayStart(2) } else { - yynn1717 = 0 - for _, b := range yyq1717 { + yynn1745 = 0 + for _, b := range yyq1745 { if b { - yynn1717++ + yynn1745++ } } - r.EncodeMapStart(yynn1717) - yynn1717 = 0 + r.EncodeMapStart(yynn1745) + yynn1745 = 0 } - if yyr1717 || yy2arr1717 { + if yyr1745 || yy2arr1745 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1717[0] { + if yyq1745[0] { if x.Protocol == nil { r.EncodeNil() } else { - yy1719 := *x.Protocol - yym1720 := z.EncBinary() - _ = yym1720 + yy1747 := *x.Protocol + yym1748 := z.EncBinary() + _ = yym1748 if false { - } else if z.HasExtensions() && z.EncExt(yy1719) { + } else if z.HasExtensions() && z.EncExt(yy1747) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy1719)) + r.EncodeString(codecSelferC_UTF81234, string(yy1747)) } } } else { r.EncodeNil() } } else { - if yyq1717[0] { + if yyq1745[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("protocol")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Protocol == nil { r.EncodeNil() } else { - yy1721 := *x.Protocol - yym1722 := z.EncBinary() - _ = yym1722 + yy1749 := *x.Protocol + yym1750 := z.EncBinary() + _ = yym1750 if false { - } else if z.HasExtensions() && z.EncExt(yy1721) { + } else if z.HasExtensions() && z.EncExt(yy1749) { } else { - r.EncodeString(codecSelferC_UTF81234, string(yy1721)) + r.EncodeString(codecSelferC_UTF81234, string(yy1749)) } } } } - if yyr1717 || yy2arr1717 { + if yyr1745 || yy2arr1745 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1717[1] { + if yyq1745[1] { if x.Port == nil { r.EncodeNil() } else { - yym1724 := z.EncBinary() - _ = yym1724 + yym1752 := z.EncBinary() + _ = yym1752 if false { } else if z.HasExtensions() && z.EncExt(x.Port) { - } else if !yym1724 && z.IsJSONHandle() { + } else if !yym1752 && z.IsJSONHandle() { z.EncJSONMarshal(x.Port) } else { z.EncFallback(x.Port) @@ -20480,18 +20601,18 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeNil() } } else { - if yyq1717[1] { + if yyq1745[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("port")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.Port == nil { r.EncodeNil() } else { - yym1725 := z.EncBinary() - _ = yym1725 + yym1753 := z.EncBinary() + _ = yym1753 if false { } else if z.HasExtensions() && z.EncExt(x.Port) { - } else if !yym1725 && z.IsJSONHandle() { + } else if !yym1753 && z.IsJSONHandle() { z.EncJSONMarshal(x.Port) } else { z.EncFallback(x.Port) @@ -20499,7 +20620,7 @@ func (x *NetworkPolicyPort) CodecEncodeSelf(e *codec1978.Encoder) { } } } - if yyr1717 || yy2arr1717 { + if yyr1745 || yy2arr1745 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -20512,25 +20633,25 @@ func (x *NetworkPolicyPort) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1726 := z.DecBinary() - _ = yym1726 + yym1754 := z.DecBinary() + _ = yym1754 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1727 := r.ContainerType() - if yyct1727 == codecSelferValueTypeMap1234 { - yyl1727 := r.ReadMapStart() - if yyl1727 == 0 { + yyct1755 := r.ContainerType() + if yyct1755 == codecSelferValueTypeMap1234 { + yyl1755 := r.ReadMapStart() + if yyl1755 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1727, d) + x.codecDecodeSelfFromMap(yyl1755, d) } - } else if yyct1727 == codecSelferValueTypeArray1234 { - yyl1727 := r.ReadArrayStart() - if yyl1727 == 0 { + } else if yyct1755 == codecSelferValueTypeArray1234 { + yyl1755 := r.ReadArrayStart() + if yyl1755 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1727, d) + x.codecDecodeSelfFromArray(yyl1755, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -20542,12 +20663,12 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1728Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1728Slc - var yyhl1728 bool = l >= 0 - for yyj1728 := 0; ; yyj1728++ { - if yyhl1728 { - if yyj1728 >= l { + var yys1756Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1756Slc + var yyhl1756 bool = l >= 0 + for yyj1756 := 0; ; yyj1756++ { + if yyhl1756 { + if yyj1756 >= l { break } } else { @@ -20556,10 +20677,10 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1728Slc = r.DecodeBytes(yys1728Slc, true, true) - yys1728 := string(yys1728Slc) + yys1756Slc = r.DecodeBytes(yys1756Slc, true, true) + yys1756 := string(yys1756Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1728 { + switch yys1756 { case "protocol": if r.TryDecodeAsNil() { if x.Protocol != nil { @@ -20580,20 +20701,20 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if x.Port == nil { x.Port = new(pkg5_intstr.IntOrString) } - yym1731 := z.DecBinary() - _ = yym1731 + yym1759 := z.DecBinary() + _ = yym1759 if false { } else if z.HasExtensions() && z.DecExt(x.Port) { - } else if !yym1731 && z.IsJSONHandle() { + } else if !yym1759 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.Port) } else { z.DecFallback(x.Port, false) } } default: - z.DecStructFieldNotFound(-1, yys1728) - } // end switch yys1728 - } // end for yyj1728 + z.DecStructFieldNotFound(-1, yys1756) + } // end switch yys1756 + } // end for yyj1756 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -20601,16 +20722,16 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1732 int - var yyb1732 bool - var yyhl1732 bool = l >= 0 - yyj1732++ - if yyhl1732 { - yyb1732 = yyj1732 > l + var yyj1760 int + var yyb1760 bool + var yyhl1760 bool = l >= 0 + yyj1760++ + if yyhl1760 { + yyb1760 = yyj1760 > l } else { - yyb1732 = r.CheckBreak() + yyb1760 = r.CheckBreak() } - if yyb1732 { + if yyb1760 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20625,13 +20746,13 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } x.Protocol.CodecDecodeSelf(d) } - yyj1732++ - if yyhl1732 { - yyb1732 = yyj1732 > l + yyj1760++ + if yyhl1760 { + yyb1760 = yyj1760 > l } else { - yyb1732 = r.CheckBreak() + yyb1760 = r.CheckBreak() } - if yyb1732 { + if yyb1760 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20644,28 +20765,28 @@ func (x *NetworkPolicyPort) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if x.Port == nil { x.Port = new(pkg5_intstr.IntOrString) } - yym1735 := z.DecBinary() - _ = yym1735 + yym1763 := z.DecBinary() + _ = yym1763 if false { } else if z.HasExtensions() && z.DecExt(x.Port) { - } else if !yym1735 && z.IsJSONHandle() { + } else if !yym1763 && z.IsJSONHandle() { z.DecJSONUnmarshal(x.Port) } else { z.DecFallback(x.Port, false) } } for { - yyj1732++ - if yyhl1732 { - yyb1732 = yyj1732 > l + yyj1760++ + if yyhl1760 { + yyb1760 = yyj1760 > l } else { - yyb1732 = r.CheckBreak() + yyb1760 = r.CheckBreak() } - if yyb1732 { + if yyb1760 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1732-1, "") + z.DecStructFieldNotFound(yyj1760-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -20677,78 +20798,102 @@ func (x *NetworkPolicyPeer) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1736 := z.EncBinary() - _ = yym1736 + yym1764 := z.EncBinary() + _ = yym1764 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1737 := !z.EncBinary() - yy2arr1737 := z.EncBasicHandle().StructToArray - var yyq1737 [2]bool - _, _, _ = yysep1737, yyq1737, yy2arr1737 - const yyr1737 bool = false - yyq1737[0] = x.PodSelector != nil - yyq1737[1] = x.NamespaceSelector != nil - var yynn1737 int - if yyr1737 || yy2arr1737 { + yysep1765 := !z.EncBinary() + yy2arr1765 := z.EncBasicHandle().StructToArray + var yyq1765 [2]bool + _, _, _ = yysep1765, yyq1765, yy2arr1765 + const yyr1765 bool = false + yyq1765[0] = x.PodSelector != nil + yyq1765[1] = x.NamespaceSelector != nil + var yynn1765 int + if yyr1765 || yy2arr1765 { r.EncodeArrayStart(2) } else { - yynn1737 = 0 - for _, b := range yyq1737 { + yynn1765 = 0 + for _, b := range yyq1765 { if b { - yynn1737++ + yynn1765++ } } - r.EncodeMapStart(yynn1737) - yynn1737 = 0 + r.EncodeMapStart(yynn1765) + yynn1765 = 0 } - if yyr1737 || yy2arr1737 { + if yyr1765 || yy2arr1765 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1737[0] { + if yyq1765[0] { if x.PodSelector == nil { r.EncodeNil() } else { - x.PodSelector.CodecEncodeSelf(e) + yym1767 := z.EncBinary() + _ = yym1767 + if false { + } else if z.HasExtensions() && z.EncExt(x.PodSelector) { + } else { + z.EncFallback(x.PodSelector) + } } } else { r.EncodeNil() } } else { - if yyq1737[0] { + if yyq1765[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("podSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.PodSelector == nil { r.EncodeNil() } else { - x.PodSelector.CodecEncodeSelf(e) + yym1768 := z.EncBinary() + _ = yym1768 + if false { + } else if z.HasExtensions() && z.EncExt(x.PodSelector) { + } else { + z.EncFallback(x.PodSelector) + } } } } - if yyr1737 || yy2arr1737 { + if yyr1765 || yy2arr1765 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1737[1] { + if yyq1765[1] { if x.NamespaceSelector == nil { r.EncodeNil() } else { - x.NamespaceSelector.CodecEncodeSelf(e) + yym1770 := z.EncBinary() + _ = yym1770 + if false { + } else if z.HasExtensions() && z.EncExt(x.NamespaceSelector) { + } else { + z.EncFallback(x.NamespaceSelector) + } } } else { r.EncodeNil() } } else { - if yyq1737[1] { + if yyq1765[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("namespaceSelector")) z.EncSendContainerState(codecSelfer_containerMapValue1234) if x.NamespaceSelector == nil { r.EncodeNil() } else { - x.NamespaceSelector.CodecEncodeSelf(e) + yym1771 := z.EncBinary() + _ = yym1771 + if false { + } else if z.HasExtensions() && z.EncExt(x.NamespaceSelector) { + } else { + z.EncFallback(x.NamespaceSelector) + } } } } - if yyr1737 || yy2arr1737 { + if yyr1765 || yy2arr1765 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -20761,25 +20906,25 @@ func (x *NetworkPolicyPeer) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1740 := z.DecBinary() - _ = yym1740 + yym1772 := z.DecBinary() + _ = yym1772 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1741 := r.ContainerType() - if yyct1741 == codecSelferValueTypeMap1234 { - yyl1741 := r.ReadMapStart() - if yyl1741 == 0 { + yyct1773 := r.ContainerType() + if yyct1773 == codecSelferValueTypeMap1234 { + yyl1773 := r.ReadMapStart() + if yyl1773 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1741, d) + x.codecDecodeSelfFromMap(yyl1773, d) } - } else if yyct1741 == codecSelferValueTypeArray1234 { - yyl1741 := r.ReadArrayStart() - if yyl1741 == 0 { + } else if yyct1773 == codecSelferValueTypeArray1234 { + yyl1773 := r.ReadArrayStart() + if yyl1773 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1741, d) + x.codecDecodeSelfFromArray(yyl1773, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -20791,12 +20936,12 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1742Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1742Slc - var yyhl1742 bool = l >= 0 - for yyj1742 := 0; ; yyj1742++ { - if yyhl1742 { - if yyj1742 >= l { + var yys1774Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1774Slc + var yyhl1774 bool = l >= 0 + for yyj1774 := 0; ; yyj1774++ { + if yyhl1774 { + if yyj1774 >= l { break } } else { @@ -20805,10 +20950,10 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1742Slc = r.DecodeBytes(yys1742Slc, true, true) - yys1742 := string(yys1742Slc) + yys1774Slc = r.DecodeBytes(yys1774Slc, true, true) + yys1774 := string(yys1774Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1742 { + switch yys1774 { case "podSelector": if r.TryDecodeAsNil() { if x.PodSelector != nil { @@ -20816,9 +20961,15 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } else { if x.PodSelector == nil { - x.PodSelector = new(LabelSelector) + x.PodSelector = new(pkg1_unversioned.LabelSelector) + } + yym1776 := z.DecBinary() + _ = yym1776 + if false { + } else if z.HasExtensions() && z.DecExt(x.PodSelector) { + } else { + z.DecFallback(x.PodSelector, false) } - x.PodSelector.CodecDecodeSelf(d) } case "namespaceSelector": if r.TryDecodeAsNil() { @@ -20827,14 +20978,20 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } else { if x.NamespaceSelector == nil { - x.NamespaceSelector = new(LabelSelector) + x.NamespaceSelector = new(pkg1_unversioned.LabelSelector) + } + yym1778 := z.DecBinary() + _ = yym1778 + if false { + } else if z.HasExtensions() && z.DecExt(x.NamespaceSelector) { + } else { + z.DecFallback(x.NamespaceSelector, false) } - x.NamespaceSelector.CodecDecodeSelf(d) } default: - z.DecStructFieldNotFound(-1, yys1742) - } // end switch yys1742 - } // end for yyj1742 + z.DecStructFieldNotFound(-1, yys1774) + } // end switch yys1774 + } // end for yyj1774 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -20842,16 +20999,16 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1745 int - var yyb1745 bool - var yyhl1745 bool = l >= 0 - yyj1745++ - if yyhl1745 { - yyb1745 = yyj1745 > l + var yyj1779 int + var yyb1779 bool + var yyhl1779 bool = l >= 0 + yyj1779++ + if yyhl1779 { + yyb1779 = yyj1779 > l } else { - yyb1745 = r.CheckBreak() + yyb1779 = r.CheckBreak() } - if yyb1745 { + if yyb1779 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20862,17 +21019,23 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } } else { if x.PodSelector == nil { - x.PodSelector = new(LabelSelector) + x.PodSelector = new(pkg1_unversioned.LabelSelector) + } + yym1781 := z.DecBinary() + _ = yym1781 + if false { + } else if z.HasExtensions() && z.DecExt(x.PodSelector) { + } else { + z.DecFallback(x.PodSelector, false) } - x.PodSelector.CodecDecodeSelf(d) } - yyj1745++ - if yyhl1745 { - yyb1745 = yyj1745 > l + yyj1779++ + if yyhl1779 { + yyb1779 = yyj1779 > l } else { - yyb1745 = r.CheckBreak() + yyb1779 = r.CheckBreak() } - if yyb1745 { + if yyb1779 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -20883,22 +21046,28 @@ func (x *NetworkPolicyPeer) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } } else { if x.NamespaceSelector == nil { - x.NamespaceSelector = new(LabelSelector) + x.NamespaceSelector = new(pkg1_unversioned.LabelSelector) + } + yym1783 := z.DecBinary() + _ = yym1783 + if false { + } else if z.HasExtensions() && z.DecExt(x.NamespaceSelector) { + } else { + z.DecFallback(x.NamespaceSelector, false) } - x.NamespaceSelector.CodecDecodeSelf(d) } for { - yyj1745++ - if yyhl1745 { - yyb1745 = yyj1745 > l + yyj1779++ + if yyhl1779 { + yyb1779 = yyj1779 > l } else { - yyb1745 = r.CheckBreak() + yyb1779 = r.CheckBreak() } - if yyb1745 { + if yyb1779 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1745-1, "") + z.DecStructFieldNotFound(yyj1779-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -20910,37 +21079,37 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x == nil { r.EncodeNil() } else { - yym1748 := z.EncBinary() - _ = yym1748 + yym1784 := z.EncBinary() + _ = yym1784 if false { } else if z.HasExtensions() && z.EncExt(x) { } else { - yysep1749 := !z.EncBinary() - yy2arr1749 := z.EncBasicHandle().StructToArray - var yyq1749 [4]bool - _, _, _ = yysep1749, yyq1749, yy2arr1749 - const yyr1749 bool = false - yyq1749[0] = x.Kind != "" - yyq1749[1] = x.APIVersion != "" - yyq1749[2] = true - var yynn1749 int - if yyr1749 || yy2arr1749 { + yysep1785 := !z.EncBinary() + yy2arr1785 := z.EncBasicHandle().StructToArray + var yyq1785 [4]bool + _, _, _ = yysep1785, yyq1785, yy2arr1785 + const yyr1785 bool = false + yyq1785[0] = x.Kind != "" + yyq1785[1] = x.APIVersion != "" + yyq1785[2] = true + var yynn1785 int + if yyr1785 || yy2arr1785 { r.EncodeArrayStart(4) } else { - yynn1749 = 1 - for _, b := range yyq1749 { + yynn1785 = 1 + for _, b := range yyq1785 { if b { - yynn1749++ + yynn1785++ } } - r.EncodeMapStart(yynn1749) - yynn1749 = 0 + r.EncodeMapStart(yynn1785) + yynn1785 = 0 } - if yyr1749 || yy2arr1749 { + if yyr1785 || yy2arr1785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1749[0] { - yym1751 := z.EncBinary() - _ = yym1751 + if yyq1785[0] { + yym1787 := z.EncBinary() + _ = yym1787 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) @@ -20949,23 +21118,23 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1749[0] { + if yyq1785[0] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("kind")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1752 := z.EncBinary() - _ = yym1752 + yym1788 := z.EncBinary() + _ = yym1788 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) } } } - if yyr1749 || yy2arr1749 { + if yyr1785 || yy2arr1785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1749[1] { - yym1754 := z.EncBinary() - _ = yym1754 + if yyq1785[1] { + yym1790 := z.EncBinary() + _ = yym1790 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) @@ -20974,54 +21143,54 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { r.EncodeString(codecSelferC_UTF81234, "") } } else { - if yyq1749[1] { + if yyq1785[1] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1755 := z.EncBinary() - _ = yym1755 + yym1791 := z.EncBinary() + _ = yym1791 if false { } else { r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) } } } - if yyr1749 || yy2arr1749 { + if yyr1785 || yy2arr1785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq1749[2] { - yy1757 := &x.ListMeta - yym1758 := z.EncBinary() - _ = yym1758 + if yyq1785[2] { + yy1793 := &x.ListMeta + yym1794 := z.EncBinary() + _ = yym1794 if false { - } else if z.HasExtensions() && z.EncExt(yy1757) { + } else if z.HasExtensions() && z.EncExt(yy1793) { } else { - z.EncFallback(yy1757) + z.EncFallback(yy1793) } } else { r.EncodeNil() } } else { - if yyq1749[2] { + if yyq1785[2] { z.EncSendContainerState(codecSelfer_containerMapKey1234) r.EncodeString(codecSelferC_UTF81234, string("metadata")) z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1759 := &x.ListMeta - yym1760 := z.EncBinary() - _ = yym1760 + yy1795 := &x.ListMeta + yym1796 := z.EncBinary() + _ = yym1796 if false { - } else if z.HasExtensions() && z.EncExt(yy1759) { + } else if z.HasExtensions() && z.EncExt(yy1795) { } else { - z.EncFallback(yy1759) + z.EncFallback(yy1795) } } } - if yyr1749 || yy2arr1749 { + if yyr1785 || yy2arr1785 { z.EncSendContainerState(codecSelfer_containerArrayElem1234) if x.Items == nil { r.EncodeNil() } else { - yym1762 := z.EncBinary() - _ = yym1762 + yym1798 := z.EncBinary() + _ = yym1798 if false { } else { h.encSliceNetworkPolicy(([]NetworkPolicy)(x.Items), e) @@ -21034,15 +21203,15 @@ func (x *NetworkPolicyList) CodecEncodeSelf(e *codec1978.Encoder) { if x.Items == nil { r.EncodeNil() } else { - yym1763 := z.EncBinary() - _ = yym1763 + yym1799 := z.EncBinary() + _ = yym1799 if false { } else { h.encSliceNetworkPolicy(([]NetworkPolicy)(x.Items), e) } } } - if yyr1749 || yy2arr1749 { + if yyr1785 || yy2arr1785 { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } else { z.EncSendContainerState(codecSelfer_containerMapEnd1234) @@ -21055,25 +21224,25 @@ func (x *NetworkPolicyList) CodecDecodeSelf(d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yym1764 := z.DecBinary() - _ = yym1764 + yym1800 := z.DecBinary() + _ = yym1800 if false { } else if z.HasExtensions() && z.DecExt(x) { } else { - yyct1765 := r.ContainerType() - if yyct1765 == codecSelferValueTypeMap1234 { - yyl1765 := r.ReadMapStart() - if yyl1765 == 0 { + yyct1801 := r.ContainerType() + if yyct1801 == codecSelferValueTypeMap1234 { + yyl1801 := r.ReadMapStart() + if yyl1801 == 0 { z.DecSendContainerState(codecSelfer_containerMapEnd1234) } else { - x.codecDecodeSelfFromMap(yyl1765, d) + x.codecDecodeSelfFromMap(yyl1801, d) } - } else if yyct1765 == codecSelferValueTypeArray1234 { - yyl1765 := r.ReadArrayStart() - if yyl1765 == 0 { + } else if yyct1801 == codecSelferValueTypeArray1234 { + yyl1801 := r.ReadArrayStart() + if yyl1801 == 0 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } else { - x.codecDecodeSelfFromArray(yyl1765, d) + x.codecDecodeSelfFromArray(yyl1801, d) } } else { panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) @@ -21085,12 +21254,12 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yys1766Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1766Slc - var yyhl1766 bool = l >= 0 - for yyj1766 := 0; ; yyj1766++ { - if yyhl1766 { - if yyj1766 >= l { + var yys1802Slc = z.DecScratchBuffer() // default slice to decode into + _ = yys1802Slc + var yyhl1802 bool = l >= 0 + for yyj1802 := 0; ; yyj1802++ { + if yyhl1802 { + if yyj1802 >= l { break } } else { @@ -21099,10 +21268,10 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) } } z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1766Slc = r.DecodeBytes(yys1766Slc, true, true) - yys1766 := string(yys1766Slc) + yys1802Slc = r.DecodeBytes(yys1802Slc, true, true) + yys1802 := string(yys1802Slc) z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1766 { + switch yys1802 { case "kind": if r.TryDecodeAsNil() { x.Kind = "" @@ -21119,31 +21288,31 @@ func (x *NetworkPolicyList) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1769 := &x.ListMeta - yym1770 := z.DecBinary() - _ = yym1770 + yyv1805 := &x.ListMeta + yym1806 := z.DecBinary() + _ = yym1806 if false { - } else if z.HasExtensions() && z.DecExt(yyv1769) { + } else if z.HasExtensions() && z.DecExt(yyv1805) { } else { - z.DecFallback(yyv1769, false) + z.DecFallback(yyv1805, false) } } case "items": if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1771 := &x.Items - yym1772 := z.DecBinary() - _ = yym1772 + yyv1807 := &x.Items + yym1808 := z.DecBinary() + _ = yym1808 if false { } else { - h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1771), d) + h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1807), d) } } default: - z.DecStructFieldNotFound(-1, yys1766) - } // end switch yys1766 - } // end for yyj1766 + z.DecStructFieldNotFound(-1, yys1802) + } // end switch yys1802 + } // end for yyj1802 z.DecSendContainerState(codecSelfer_containerMapEnd1234) } @@ -21151,16 +21320,16 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - var yyj1773 int - var yyb1773 bool - var yyhl1773 bool = l >= 0 - yyj1773++ - if yyhl1773 { - yyb1773 = yyj1773 > l + var yyj1809 int + var yyb1809 bool + var yyhl1809 bool = l >= 0 + yyj1809++ + if yyhl1809 { + yyb1809 = yyj1809 > l } else { - yyb1773 = r.CheckBreak() + yyb1809 = r.CheckBreak() } - if yyb1773 { + if yyb1809 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -21170,13 +21339,13 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.Kind = string(r.DecodeString()) } - yyj1773++ - if yyhl1773 { - yyb1773 = yyj1773 > l + yyj1809++ + if yyhl1809 { + yyb1809 = yyj1809 > l } else { - yyb1773 = r.CheckBreak() + yyb1809 = r.CheckBreak() } - if yyb1773 { + if yyb1809 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -21186,13 +21355,13 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder } else { x.APIVersion = string(r.DecodeString()) } - yyj1773++ - if yyhl1773 { - yyb1773 = yyj1773 > l + yyj1809++ + if yyhl1809 { + yyb1809 = yyj1809 > l } else { - yyb1773 = r.CheckBreak() + yyb1809 = r.CheckBreak() } - if yyb1773 { + if yyb1809 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -21200,22 +21369,22 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.ListMeta = pkg1_unversioned.ListMeta{} } else { - yyv1776 := &x.ListMeta - yym1777 := z.DecBinary() - _ = yym1777 + yyv1812 := &x.ListMeta + yym1813 := z.DecBinary() + _ = yym1813 if false { - } else if z.HasExtensions() && z.DecExt(yyv1776) { + } else if z.HasExtensions() && z.DecExt(yyv1812) { } else { - z.DecFallback(yyv1776, false) + z.DecFallback(yyv1812, false) } } - yyj1773++ - if yyhl1773 { - yyb1773 = yyj1773 > l + yyj1809++ + if yyhl1809 { + yyb1809 = yyj1809 > l } else { - yyb1773 = r.CheckBreak() + yyb1809 = r.CheckBreak() } - if yyb1773 { + if yyb1809 { z.DecSendContainerState(codecSelfer_containerArrayEnd1234) return } @@ -21223,727 +21392,31 @@ func (x *NetworkPolicyList) codecDecodeSelfFromArray(l int, d *codec1978.Decoder if r.TryDecodeAsNil() { x.Items = nil } else { - yyv1778 := &x.Items - yym1779 := z.DecBinary() - _ = yym1779 + yyv1814 := &x.Items + yym1815 := z.DecBinary() + _ = yym1815 if false { } else { - h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1778), d) + h.decSliceNetworkPolicy((*[]NetworkPolicy)(yyv1814), d) } } for { - yyj1773++ - if yyhl1773 { - yyb1773 = yyj1773 > l + yyj1809++ + if yyhl1809 { + yyb1809 = yyj1809 > l } else { - yyb1773 = r.CheckBreak() + yyb1809 = r.CheckBreak() } - if yyb1773 { + if yyb1809 { break } z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1773-1, "") + z.DecStructFieldNotFound(yyj1809-1, "") } z.DecSendContainerState(codecSelfer_containerArrayEnd1234) } func (x codecSelfer1234) encSliceCustomMetricTarget(v []CustomMetricTarget, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1780 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1781 := &yyv1780 - yy1781.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceCustomMetricTarget(v *[]CustomMetricTarget, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1782 := *v - yyh1782, yyl1782 := z.DecSliceHelperStart() - var yyc1782 bool - if yyl1782 == 0 { - if yyv1782 == nil { - yyv1782 = []CustomMetricTarget{} - yyc1782 = true - } else if len(yyv1782) != 0 { - yyv1782 = yyv1782[:0] - yyc1782 = true - } - } else if yyl1782 > 0 { - var yyrr1782, yyrl1782 int - var yyrt1782 bool - if yyl1782 > cap(yyv1782) { - - yyrg1782 := len(yyv1782) > 0 - yyv21782 := yyv1782 - yyrl1782, yyrt1782 = z.DecInferLen(yyl1782, z.DecBasicHandle().MaxInitLen, 72) - if yyrt1782 { - if yyrl1782 <= cap(yyv1782) { - yyv1782 = yyv1782[:yyrl1782] - } else { - yyv1782 = make([]CustomMetricTarget, yyrl1782) - } - } else { - yyv1782 = make([]CustomMetricTarget, yyrl1782) - } - yyc1782 = true - yyrr1782 = len(yyv1782) - if yyrg1782 { - copy(yyv1782, yyv21782) - } - } else if yyl1782 != len(yyv1782) { - yyv1782 = yyv1782[:yyl1782] - yyc1782 = true - } - yyj1782 := 0 - for ; yyj1782 < yyrr1782; yyj1782++ { - yyh1782.ElemContainerState(yyj1782) - if r.TryDecodeAsNil() { - yyv1782[yyj1782] = CustomMetricTarget{} - } else { - yyv1783 := &yyv1782[yyj1782] - yyv1783.CodecDecodeSelf(d) - } - - } - if yyrt1782 { - for ; yyj1782 < yyl1782; yyj1782++ { - yyv1782 = append(yyv1782, CustomMetricTarget{}) - yyh1782.ElemContainerState(yyj1782) - if r.TryDecodeAsNil() { - yyv1782[yyj1782] = CustomMetricTarget{} - } else { - yyv1784 := &yyv1782[yyj1782] - yyv1784.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1782 := 0 - for ; !r.CheckBreak(); yyj1782++ { - - if yyj1782 >= len(yyv1782) { - yyv1782 = append(yyv1782, CustomMetricTarget{}) // var yyz1782 CustomMetricTarget - yyc1782 = true - } - yyh1782.ElemContainerState(yyj1782) - if yyj1782 < len(yyv1782) { - if r.TryDecodeAsNil() { - yyv1782[yyj1782] = CustomMetricTarget{} - } else { - yyv1785 := &yyv1782[yyj1782] - yyv1785.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1782 < len(yyv1782) { - yyv1782 = yyv1782[:yyj1782] - yyc1782 = true - } else if yyj1782 == 0 && yyv1782 == nil { - yyv1782 = []CustomMetricTarget{} - yyc1782 = true - } - } - yyh1782.End() - if yyc1782 { - *v = yyv1782 - } -} - -func (x codecSelfer1234) encSliceCustomMetricCurrentStatus(v []CustomMetricCurrentStatus, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1786 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1787 := &yyv1786 - yy1787.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceCustomMetricCurrentStatus(v *[]CustomMetricCurrentStatus, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1788 := *v - yyh1788, yyl1788 := z.DecSliceHelperStart() - var yyc1788 bool - if yyl1788 == 0 { - if yyv1788 == nil { - yyv1788 = []CustomMetricCurrentStatus{} - yyc1788 = true - } else if len(yyv1788) != 0 { - yyv1788 = yyv1788[:0] - yyc1788 = true - } - } else if yyl1788 > 0 { - var yyrr1788, yyrl1788 int - var yyrt1788 bool - if yyl1788 > cap(yyv1788) { - - yyrg1788 := len(yyv1788) > 0 - yyv21788 := yyv1788 - yyrl1788, yyrt1788 = z.DecInferLen(yyl1788, z.DecBasicHandle().MaxInitLen, 72) - if yyrt1788 { - if yyrl1788 <= cap(yyv1788) { - yyv1788 = yyv1788[:yyrl1788] - } else { - yyv1788 = make([]CustomMetricCurrentStatus, yyrl1788) - } - } else { - yyv1788 = make([]CustomMetricCurrentStatus, yyrl1788) - } - yyc1788 = true - yyrr1788 = len(yyv1788) - if yyrg1788 { - copy(yyv1788, yyv21788) - } - } else if yyl1788 != len(yyv1788) { - yyv1788 = yyv1788[:yyl1788] - yyc1788 = true - } - yyj1788 := 0 - for ; yyj1788 < yyrr1788; yyj1788++ { - yyh1788.ElemContainerState(yyj1788) - if r.TryDecodeAsNil() { - yyv1788[yyj1788] = CustomMetricCurrentStatus{} - } else { - yyv1789 := &yyv1788[yyj1788] - yyv1789.CodecDecodeSelf(d) - } - - } - if yyrt1788 { - for ; yyj1788 < yyl1788; yyj1788++ { - yyv1788 = append(yyv1788, CustomMetricCurrentStatus{}) - yyh1788.ElemContainerState(yyj1788) - if r.TryDecodeAsNil() { - yyv1788[yyj1788] = CustomMetricCurrentStatus{} - } else { - yyv1790 := &yyv1788[yyj1788] - yyv1790.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1788 := 0 - for ; !r.CheckBreak(); yyj1788++ { - - if yyj1788 >= len(yyv1788) { - yyv1788 = append(yyv1788, CustomMetricCurrentStatus{}) // var yyz1788 CustomMetricCurrentStatus - yyc1788 = true - } - yyh1788.ElemContainerState(yyj1788) - if yyj1788 < len(yyv1788) { - if r.TryDecodeAsNil() { - yyv1788[yyj1788] = CustomMetricCurrentStatus{} - } else { - yyv1791 := &yyv1788[yyj1788] - yyv1791.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1788 < len(yyv1788) { - yyv1788 = yyv1788[:yyj1788] - yyc1788 = true - } else if yyj1788 == 0 && yyv1788 == nil { - yyv1788 = []CustomMetricCurrentStatus{} - yyc1788 = true - } - } - yyh1788.End() - if yyc1788 { - *v = yyv1788 - } -} - -func (x codecSelfer1234) encSliceHorizontalPodAutoscaler(v []HorizontalPodAutoscaler, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1792 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1793 := &yyv1792 - yy1793.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceHorizontalPodAutoscaler(v *[]HorizontalPodAutoscaler, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1794 := *v - yyh1794, yyl1794 := z.DecSliceHelperStart() - var yyc1794 bool - if yyl1794 == 0 { - if yyv1794 == nil { - yyv1794 = []HorizontalPodAutoscaler{} - yyc1794 = true - } else if len(yyv1794) != 0 { - yyv1794 = yyv1794[:0] - yyc1794 = true - } - } else if yyl1794 > 0 { - var yyrr1794, yyrl1794 int - var yyrt1794 bool - if yyl1794 > cap(yyv1794) { - - yyrg1794 := len(yyv1794) > 0 - yyv21794 := yyv1794 - yyrl1794, yyrt1794 = z.DecInferLen(yyl1794, z.DecBasicHandle().MaxInitLen, 376) - if yyrt1794 { - if yyrl1794 <= cap(yyv1794) { - yyv1794 = yyv1794[:yyrl1794] - } else { - yyv1794 = make([]HorizontalPodAutoscaler, yyrl1794) - } - } else { - yyv1794 = make([]HorizontalPodAutoscaler, yyrl1794) - } - yyc1794 = true - yyrr1794 = len(yyv1794) - if yyrg1794 { - copy(yyv1794, yyv21794) - } - } else if yyl1794 != len(yyv1794) { - yyv1794 = yyv1794[:yyl1794] - yyc1794 = true - } - yyj1794 := 0 - for ; yyj1794 < yyrr1794; yyj1794++ { - yyh1794.ElemContainerState(yyj1794) - if r.TryDecodeAsNil() { - yyv1794[yyj1794] = HorizontalPodAutoscaler{} - } else { - yyv1795 := &yyv1794[yyj1794] - yyv1795.CodecDecodeSelf(d) - } - - } - if yyrt1794 { - for ; yyj1794 < yyl1794; yyj1794++ { - yyv1794 = append(yyv1794, HorizontalPodAutoscaler{}) - yyh1794.ElemContainerState(yyj1794) - if r.TryDecodeAsNil() { - yyv1794[yyj1794] = HorizontalPodAutoscaler{} - } else { - yyv1796 := &yyv1794[yyj1794] - yyv1796.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1794 := 0 - for ; !r.CheckBreak(); yyj1794++ { - - if yyj1794 >= len(yyv1794) { - yyv1794 = append(yyv1794, HorizontalPodAutoscaler{}) // var yyz1794 HorizontalPodAutoscaler - yyc1794 = true - } - yyh1794.ElemContainerState(yyj1794) - if yyj1794 < len(yyv1794) { - if r.TryDecodeAsNil() { - yyv1794[yyj1794] = HorizontalPodAutoscaler{} - } else { - yyv1797 := &yyv1794[yyj1794] - yyv1797.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1794 < len(yyv1794) { - yyv1794 = yyv1794[:yyj1794] - yyc1794 = true - } else if yyj1794 == 0 && yyv1794 == nil { - yyv1794 = []HorizontalPodAutoscaler{} - yyc1794 = true - } - } - yyh1794.End() - if yyc1794 { - *v = yyv1794 - } -} - -func (x codecSelfer1234) encSliceAPIVersion(v []APIVersion, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1798 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1799 := &yyv1798 - yy1799.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceAPIVersion(v *[]APIVersion, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1800 := *v - yyh1800, yyl1800 := z.DecSliceHelperStart() - var yyc1800 bool - if yyl1800 == 0 { - if yyv1800 == nil { - yyv1800 = []APIVersion{} - yyc1800 = true - } else if len(yyv1800) != 0 { - yyv1800 = yyv1800[:0] - yyc1800 = true - } - } else if yyl1800 > 0 { - var yyrr1800, yyrl1800 int - var yyrt1800 bool - if yyl1800 > cap(yyv1800) { - - yyrg1800 := len(yyv1800) > 0 - yyv21800 := yyv1800 - yyrl1800, yyrt1800 = z.DecInferLen(yyl1800, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1800 { - if yyrl1800 <= cap(yyv1800) { - yyv1800 = yyv1800[:yyrl1800] - } else { - yyv1800 = make([]APIVersion, yyrl1800) - } - } else { - yyv1800 = make([]APIVersion, yyrl1800) - } - yyc1800 = true - yyrr1800 = len(yyv1800) - if yyrg1800 { - copy(yyv1800, yyv21800) - } - } else if yyl1800 != len(yyv1800) { - yyv1800 = yyv1800[:yyl1800] - yyc1800 = true - } - yyj1800 := 0 - for ; yyj1800 < yyrr1800; yyj1800++ { - yyh1800.ElemContainerState(yyj1800) - if r.TryDecodeAsNil() { - yyv1800[yyj1800] = APIVersion{} - } else { - yyv1801 := &yyv1800[yyj1800] - yyv1801.CodecDecodeSelf(d) - } - - } - if yyrt1800 { - for ; yyj1800 < yyl1800; yyj1800++ { - yyv1800 = append(yyv1800, APIVersion{}) - yyh1800.ElemContainerState(yyj1800) - if r.TryDecodeAsNil() { - yyv1800[yyj1800] = APIVersion{} - } else { - yyv1802 := &yyv1800[yyj1800] - yyv1802.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1800 := 0 - for ; !r.CheckBreak(); yyj1800++ { - - if yyj1800 >= len(yyv1800) { - yyv1800 = append(yyv1800, APIVersion{}) // var yyz1800 APIVersion - yyc1800 = true - } - yyh1800.ElemContainerState(yyj1800) - if yyj1800 < len(yyv1800) { - if r.TryDecodeAsNil() { - yyv1800[yyj1800] = APIVersion{} - } else { - yyv1803 := &yyv1800[yyj1800] - yyv1803.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1800 < len(yyv1800) { - yyv1800 = yyv1800[:yyj1800] - yyc1800 = true - } else if yyj1800 == 0 && yyv1800 == nil { - yyv1800 = []APIVersion{} - yyc1800 = true - } - } - yyh1800.End() - if yyc1800 { - *v = yyv1800 - } -} - -func (x codecSelfer1234) encSliceThirdPartyResource(v []ThirdPartyResource, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1804 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1805 := &yyv1804 - yy1805.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceThirdPartyResource(v *[]ThirdPartyResource, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1806 := *v - yyh1806, yyl1806 := z.DecSliceHelperStart() - var yyc1806 bool - if yyl1806 == 0 { - if yyv1806 == nil { - yyv1806 = []ThirdPartyResource{} - yyc1806 = true - } else if len(yyv1806) != 0 { - yyv1806 = yyv1806[:0] - yyc1806 = true - } - } else if yyl1806 > 0 { - var yyrr1806, yyrl1806 int - var yyrt1806 bool - if yyl1806 > cap(yyv1806) { - - yyrg1806 := len(yyv1806) > 0 - yyv21806 := yyv1806 - yyrl1806, yyrt1806 = z.DecInferLen(yyl1806, z.DecBasicHandle().MaxInitLen, 296) - if yyrt1806 { - if yyrl1806 <= cap(yyv1806) { - yyv1806 = yyv1806[:yyrl1806] - } else { - yyv1806 = make([]ThirdPartyResource, yyrl1806) - } - } else { - yyv1806 = make([]ThirdPartyResource, yyrl1806) - } - yyc1806 = true - yyrr1806 = len(yyv1806) - if yyrg1806 { - copy(yyv1806, yyv21806) - } - } else if yyl1806 != len(yyv1806) { - yyv1806 = yyv1806[:yyl1806] - yyc1806 = true - } - yyj1806 := 0 - for ; yyj1806 < yyrr1806; yyj1806++ { - yyh1806.ElemContainerState(yyj1806) - if r.TryDecodeAsNil() { - yyv1806[yyj1806] = ThirdPartyResource{} - } else { - yyv1807 := &yyv1806[yyj1806] - yyv1807.CodecDecodeSelf(d) - } - - } - if yyrt1806 { - for ; yyj1806 < yyl1806; yyj1806++ { - yyv1806 = append(yyv1806, ThirdPartyResource{}) - yyh1806.ElemContainerState(yyj1806) - if r.TryDecodeAsNil() { - yyv1806[yyj1806] = ThirdPartyResource{} - } else { - yyv1808 := &yyv1806[yyj1806] - yyv1808.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1806 := 0 - for ; !r.CheckBreak(); yyj1806++ { - - if yyj1806 >= len(yyv1806) { - yyv1806 = append(yyv1806, ThirdPartyResource{}) // var yyz1806 ThirdPartyResource - yyc1806 = true - } - yyh1806.ElemContainerState(yyj1806) - if yyj1806 < len(yyv1806) { - if r.TryDecodeAsNil() { - yyv1806[yyj1806] = ThirdPartyResource{} - } else { - yyv1809 := &yyv1806[yyj1806] - yyv1809.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1806 < len(yyv1806) { - yyv1806 = yyv1806[:yyj1806] - yyc1806 = true - } else if yyj1806 == 0 && yyv1806 == nil { - yyv1806 = []ThirdPartyResource{} - yyc1806 = true - } - } - yyh1806.End() - if yyc1806 { - *v = yyv1806 - } -} - -func (x codecSelfer1234) encSliceDeployment(v []Deployment, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1810 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1811 := &yyv1810 - yy1811.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceDeployment(v *[]Deployment, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1812 := *v - yyh1812, yyl1812 := z.DecSliceHelperStart() - var yyc1812 bool - if yyl1812 == 0 { - if yyv1812 == nil { - yyv1812 = []Deployment{} - yyc1812 = true - } else if len(yyv1812) != 0 { - yyv1812 = yyv1812[:0] - yyc1812 = true - } - } else if yyl1812 > 0 { - var yyrr1812, yyrl1812 int - var yyrt1812 bool - if yyl1812 > cap(yyv1812) { - - yyrg1812 := len(yyv1812) > 0 - yyv21812 := yyv1812 - yyrl1812, yyrt1812 = z.DecInferLen(yyl1812, z.DecBasicHandle().MaxInitLen, 824) - if yyrt1812 { - if yyrl1812 <= cap(yyv1812) { - yyv1812 = yyv1812[:yyrl1812] - } else { - yyv1812 = make([]Deployment, yyrl1812) - } - } else { - yyv1812 = make([]Deployment, yyrl1812) - } - yyc1812 = true - yyrr1812 = len(yyv1812) - if yyrg1812 { - copy(yyv1812, yyv21812) - } - } else if yyl1812 != len(yyv1812) { - yyv1812 = yyv1812[:yyl1812] - yyc1812 = true - } - yyj1812 := 0 - for ; yyj1812 < yyrr1812; yyj1812++ { - yyh1812.ElemContainerState(yyj1812) - if r.TryDecodeAsNil() { - yyv1812[yyj1812] = Deployment{} - } else { - yyv1813 := &yyv1812[yyj1812] - yyv1813.CodecDecodeSelf(d) - } - - } - if yyrt1812 { - for ; yyj1812 < yyl1812; yyj1812++ { - yyv1812 = append(yyv1812, Deployment{}) - yyh1812.ElemContainerState(yyj1812) - if r.TryDecodeAsNil() { - yyv1812[yyj1812] = Deployment{} - } else { - yyv1814 := &yyv1812[yyj1812] - yyv1814.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1812 := 0 - for ; !r.CheckBreak(); yyj1812++ { - - if yyj1812 >= len(yyv1812) { - yyv1812 = append(yyv1812, Deployment{}) // var yyz1812 Deployment - yyc1812 = true - } - yyh1812.ElemContainerState(yyj1812) - if yyj1812 < len(yyv1812) { - if r.TryDecodeAsNil() { - yyv1812[yyj1812] = Deployment{} - } else { - yyv1815 := &yyv1812[yyj1812] - yyv1815.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1812 < len(yyv1812) { - yyv1812 = yyv1812[:yyj1812] - yyc1812 = true - } else if yyj1812 == 0 && yyv1812 == nil { - yyv1812 = []Deployment{} - yyc1812 = true - } - } - yyh1812.End() - if yyc1812 { - *v = yyv1812 - } -} - -func (x codecSelfer1234) encSliceDaemonSet(v []DaemonSet, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -21956,7 +21429,7 @@ func (x codecSelfer1234) encSliceDaemonSet(v []DaemonSet, e *codec1978.Encoder) z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceCustomMetricTarget(v *[]CustomMetricTarget, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -21966,7 +21439,7 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) var yyc1818 bool if yyl1818 == 0 { if yyv1818 == nil { - yyv1818 = []DaemonSet{} + yyv1818 = []CustomMetricTarget{} yyc1818 = true } else if len(yyv1818) != 0 { yyv1818 = yyv1818[:0] @@ -21979,15 +21452,15 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) yyrg1818 := len(yyv1818) > 0 yyv21818 := yyv1818 - yyrl1818, yyrt1818 = z.DecInferLen(yyl1818, z.DecBasicHandle().MaxInitLen, 752) + yyrl1818, yyrt1818 = z.DecInferLen(yyl1818, z.DecBasicHandle().MaxInitLen, 72) if yyrt1818 { if yyrl1818 <= cap(yyv1818) { yyv1818 = yyv1818[:yyrl1818] } else { - yyv1818 = make([]DaemonSet, yyrl1818) + yyv1818 = make([]CustomMetricTarget, yyrl1818) } } else { - yyv1818 = make([]DaemonSet, yyrl1818) + yyv1818 = make([]CustomMetricTarget, yyrl1818) } yyc1818 = true yyrr1818 = len(yyv1818) @@ -22002,7 +21475,7 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) for ; yyj1818 < yyrr1818; yyj1818++ { yyh1818.ElemContainerState(yyj1818) if r.TryDecodeAsNil() { - yyv1818[yyj1818] = DaemonSet{} + yyv1818[yyj1818] = CustomMetricTarget{} } else { yyv1819 := &yyv1818[yyj1818] yyv1819.CodecDecodeSelf(d) @@ -22011,10 +21484,10 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) } if yyrt1818 { for ; yyj1818 < yyl1818; yyj1818++ { - yyv1818 = append(yyv1818, DaemonSet{}) + yyv1818 = append(yyv1818, CustomMetricTarget{}) yyh1818.ElemContainerState(yyj1818) if r.TryDecodeAsNil() { - yyv1818[yyj1818] = DaemonSet{} + yyv1818[yyj1818] = CustomMetricTarget{} } else { yyv1820 := &yyv1818[yyj1818] yyv1820.CodecDecodeSelf(d) @@ -22028,13 +21501,13 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) for ; !r.CheckBreak(); yyj1818++ { if yyj1818 >= len(yyv1818) { - yyv1818 = append(yyv1818, DaemonSet{}) // var yyz1818 DaemonSet + yyv1818 = append(yyv1818, CustomMetricTarget{}) // var yyz1818 CustomMetricTarget yyc1818 = true } yyh1818.ElemContainerState(yyj1818) if yyj1818 < len(yyv1818) { if r.TryDecodeAsNil() { - yyv1818[yyj1818] = DaemonSet{} + yyv1818[yyj1818] = CustomMetricTarget{} } else { yyv1821 := &yyv1818[yyj1818] yyv1821.CodecDecodeSelf(d) @@ -22049,7 +21522,7 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) yyv1818 = yyv1818[:yyj1818] yyc1818 = true } else if yyj1818 == 0 && yyv1818 == nil { - yyv1818 = []DaemonSet{} + yyv1818 = []CustomMetricTarget{} yyc1818 = true } } @@ -22059,7 +21532,7 @@ func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) } } -func (x codecSelfer1234) encSliceThirdPartyResourceData(v []ThirdPartyResourceData, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceCustomMetricCurrentStatus(v []CustomMetricCurrentStatus, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22072,7 +21545,7 @@ func (x codecSelfer1234) encSliceThirdPartyResourceData(v []ThirdPartyResourceDa z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceData, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceCustomMetricCurrentStatus(v *[]CustomMetricCurrentStatus, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22082,7 +21555,7 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD var yyc1824 bool if yyl1824 == 0 { if yyv1824 == nil { - yyv1824 = []ThirdPartyResourceData{} + yyv1824 = []CustomMetricCurrentStatus{} yyc1824 = true } else if len(yyv1824) != 0 { yyv1824 = yyv1824[:0] @@ -22095,15 +21568,15 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD yyrg1824 := len(yyv1824) > 0 yyv21824 := yyv1824 - yyrl1824, yyrt1824 = z.DecInferLen(yyl1824, z.DecBasicHandle().MaxInitLen, 280) + yyrl1824, yyrt1824 = z.DecInferLen(yyl1824, z.DecBasicHandle().MaxInitLen, 72) if yyrt1824 { if yyrl1824 <= cap(yyv1824) { yyv1824 = yyv1824[:yyrl1824] } else { - yyv1824 = make([]ThirdPartyResourceData, yyrl1824) + yyv1824 = make([]CustomMetricCurrentStatus, yyrl1824) } } else { - yyv1824 = make([]ThirdPartyResourceData, yyrl1824) + yyv1824 = make([]CustomMetricCurrentStatus, yyrl1824) } yyc1824 = true yyrr1824 = len(yyv1824) @@ -22118,7 +21591,7 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD for ; yyj1824 < yyrr1824; yyj1824++ { yyh1824.ElemContainerState(yyj1824) if r.TryDecodeAsNil() { - yyv1824[yyj1824] = ThirdPartyResourceData{} + yyv1824[yyj1824] = CustomMetricCurrentStatus{} } else { yyv1825 := &yyv1824[yyj1824] yyv1825.CodecDecodeSelf(d) @@ -22127,10 +21600,10 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD } if yyrt1824 { for ; yyj1824 < yyl1824; yyj1824++ { - yyv1824 = append(yyv1824, ThirdPartyResourceData{}) + yyv1824 = append(yyv1824, CustomMetricCurrentStatus{}) yyh1824.ElemContainerState(yyj1824) if r.TryDecodeAsNil() { - yyv1824[yyj1824] = ThirdPartyResourceData{} + yyv1824[yyj1824] = CustomMetricCurrentStatus{} } else { yyv1826 := &yyv1824[yyj1824] yyv1826.CodecDecodeSelf(d) @@ -22144,13 +21617,13 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD for ; !r.CheckBreak(); yyj1824++ { if yyj1824 >= len(yyv1824) { - yyv1824 = append(yyv1824, ThirdPartyResourceData{}) // var yyz1824 ThirdPartyResourceData + yyv1824 = append(yyv1824, CustomMetricCurrentStatus{}) // var yyz1824 CustomMetricCurrentStatus yyc1824 = true } yyh1824.ElemContainerState(yyj1824) if yyj1824 < len(yyv1824) { if r.TryDecodeAsNil() { - yyv1824[yyj1824] = ThirdPartyResourceData{} + yyv1824[yyj1824] = CustomMetricCurrentStatus{} } else { yyv1827 := &yyv1824[yyj1824] yyv1827.CodecDecodeSelf(d) @@ -22165,7 +21638,7 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD yyv1824 = yyv1824[:yyj1824] yyc1824 = true } else if yyj1824 == 0 && yyv1824 == nil { - yyv1824 = []ThirdPartyResourceData{} + yyv1824 = []CustomMetricCurrentStatus{} yyc1824 = true } } @@ -22175,7 +21648,7 @@ func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceD } } -func (x codecSelfer1234) encSliceJob(v []Job, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceHorizontalPodAutoscaler(v []HorizontalPodAutoscaler, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22188,7 +21661,7 @@ func (x codecSelfer1234) encSliceJob(v []Job, e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceHorizontalPodAutoscaler(v *[]HorizontalPodAutoscaler, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22198,7 +21671,7 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { var yyc1830 bool if yyl1830 == 0 { if yyv1830 == nil { - yyv1830 = []Job{} + yyv1830 = []HorizontalPodAutoscaler{} yyc1830 = true } else if len(yyv1830) != 0 { yyv1830 = yyv1830[:0] @@ -22211,15 +21684,15 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { yyrg1830 := len(yyv1830) > 0 yyv21830 := yyv1830 - yyrl1830, yyrt1830 = z.DecInferLen(yyl1830, z.DecBasicHandle().MaxInitLen, 824) + yyrl1830, yyrt1830 = z.DecInferLen(yyl1830, z.DecBasicHandle().MaxInitLen, 376) if yyrt1830 { if yyrl1830 <= cap(yyv1830) { yyv1830 = yyv1830[:yyrl1830] } else { - yyv1830 = make([]Job, yyrl1830) + yyv1830 = make([]HorizontalPodAutoscaler, yyrl1830) } } else { - yyv1830 = make([]Job, yyrl1830) + yyv1830 = make([]HorizontalPodAutoscaler, yyrl1830) } yyc1830 = true yyrr1830 = len(yyv1830) @@ -22234,7 +21707,7 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { for ; yyj1830 < yyrr1830; yyj1830++ { yyh1830.ElemContainerState(yyj1830) if r.TryDecodeAsNil() { - yyv1830[yyj1830] = Job{} + yyv1830[yyj1830] = HorizontalPodAutoscaler{} } else { yyv1831 := &yyv1830[yyj1830] yyv1831.CodecDecodeSelf(d) @@ -22243,10 +21716,10 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { } if yyrt1830 { for ; yyj1830 < yyl1830; yyj1830++ { - yyv1830 = append(yyv1830, Job{}) + yyv1830 = append(yyv1830, HorizontalPodAutoscaler{}) yyh1830.ElemContainerState(yyj1830) if r.TryDecodeAsNil() { - yyv1830[yyj1830] = Job{} + yyv1830[yyj1830] = HorizontalPodAutoscaler{} } else { yyv1832 := &yyv1830[yyj1830] yyv1832.CodecDecodeSelf(d) @@ -22260,13 +21733,13 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { for ; !r.CheckBreak(); yyj1830++ { if yyj1830 >= len(yyv1830) { - yyv1830 = append(yyv1830, Job{}) // var yyz1830 Job + yyv1830 = append(yyv1830, HorizontalPodAutoscaler{}) // var yyz1830 HorizontalPodAutoscaler yyc1830 = true } yyh1830.ElemContainerState(yyj1830) if yyj1830 < len(yyv1830) { if r.TryDecodeAsNil() { - yyv1830[yyj1830] = Job{} + yyv1830[yyj1830] = HorizontalPodAutoscaler{} } else { yyv1833 := &yyv1830[yyj1830] yyv1833.CodecDecodeSelf(d) @@ -22281,7 +21754,7 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { yyv1830 = yyv1830[:yyj1830] yyc1830 = true } else if yyj1830 == 0 && yyv1830 == nil { - yyv1830 = []Job{} + yyv1830 = []HorizontalPodAutoscaler{} yyc1830 = true } } @@ -22291,7 +21764,7 @@ func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { } } -func (x codecSelfer1234) encSliceJobCondition(v []JobCondition, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceAPIVersion(v []APIVersion, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22304,7 +21777,7 @@ func (x codecSelfer1234) encSliceJobCondition(v []JobCondition, e *codec1978.Enc z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceAPIVersion(v *[]APIVersion, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22314,7 +21787,7 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De var yyc1836 bool if yyl1836 == 0 { if yyv1836 == nil { - yyv1836 = []JobCondition{} + yyv1836 = []APIVersion{} yyc1836 = true } else if len(yyv1836) != 0 { yyv1836 = yyv1836[:0] @@ -22327,15 +21800,15 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De yyrg1836 := len(yyv1836) > 0 yyv21836 := yyv1836 - yyrl1836, yyrt1836 = z.DecInferLen(yyl1836, z.DecBasicHandle().MaxInitLen, 112) + yyrl1836, yyrt1836 = z.DecInferLen(yyl1836, z.DecBasicHandle().MaxInitLen, 16) if yyrt1836 { if yyrl1836 <= cap(yyv1836) { yyv1836 = yyv1836[:yyrl1836] } else { - yyv1836 = make([]JobCondition, yyrl1836) + yyv1836 = make([]APIVersion, yyrl1836) } } else { - yyv1836 = make([]JobCondition, yyrl1836) + yyv1836 = make([]APIVersion, yyrl1836) } yyc1836 = true yyrr1836 = len(yyv1836) @@ -22350,7 +21823,7 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De for ; yyj1836 < yyrr1836; yyj1836++ { yyh1836.ElemContainerState(yyj1836) if r.TryDecodeAsNil() { - yyv1836[yyj1836] = JobCondition{} + yyv1836[yyj1836] = APIVersion{} } else { yyv1837 := &yyv1836[yyj1836] yyv1837.CodecDecodeSelf(d) @@ -22359,10 +21832,10 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De } if yyrt1836 { for ; yyj1836 < yyl1836; yyj1836++ { - yyv1836 = append(yyv1836, JobCondition{}) + yyv1836 = append(yyv1836, APIVersion{}) yyh1836.ElemContainerState(yyj1836) if r.TryDecodeAsNil() { - yyv1836[yyj1836] = JobCondition{} + yyv1836[yyj1836] = APIVersion{} } else { yyv1838 := &yyv1836[yyj1836] yyv1838.CodecDecodeSelf(d) @@ -22376,13 +21849,13 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De for ; !r.CheckBreak(); yyj1836++ { if yyj1836 >= len(yyv1836) { - yyv1836 = append(yyv1836, JobCondition{}) // var yyz1836 JobCondition + yyv1836 = append(yyv1836, APIVersion{}) // var yyz1836 APIVersion yyc1836 = true } yyh1836.ElemContainerState(yyj1836) if yyj1836 < len(yyv1836) { if r.TryDecodeAsNil() { - yyv1836[yyj1836] = JobCondition{} + yyv1836[yyj1836] = APIVersion{} } else { yyv1839 := &yyv1836[yyj1836] yyv1839.CodecDecodeSelf(d) @@ -22397,7 +21870,7 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De yyv1836 = yyv1836[:yyj1836] yyc1836 = true } else if yyj1836 == 0 && yyv1836 == nil { - yyv1836 = []JobCondition{} + yyv1836 = []APIVersion{} yyc1836 = true } } @@ -22407,7 +21880,7 @@ func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.De } } -func (x codecSelfer1234) encSliceIngress(v []Ingress, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceThirdPartyResource(v []ThirdPartyResource, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22420,7 +21893,7 @@ func (x codecSelfer1234) encSliceIngress(v []Ingress, e *codec1978.Encoder) { z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceThirdPartyResource(v *[]ThirdPartyResource, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22430,7 +21903,7 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { var yyc1842 bool if yyl1842 == 0 { if yyv1842 == nil { - yyv1842 = []Ingress{} + yyv1842 = []ThirdPartyResource{} yyc1842 = true } else if len(yyv1842) != 0 { yyv1842 = yyv1842[:0] @@ -22443,15 +21916,15 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { yyrg1842 := len(yyv1842) > 0 yyv21842 := yyv1842 - yyrl1842, yyrt1842 = z.DecInferLen(yyl1842, z.DecBasicHandle().MaxInitLen, 336) + yyrl1842, yyrt1842 = z.DecInferLen(yyl1842, z.DecBasicHandle().MaxInitLen, 296) if yyrt1842 { if yyrl1842 <= cap(yyv1842) { yyv1842 = yyv1842[:yyrl1842] } else { - yyv1842 = make([]Ingress, yyrl1842) + yyv1842 = make([]ThirdPartyResource, yyrl1842) } } else { - yyv1842 = make([]Ingress, yyrl1842) + yyv1842 = make([]ThirdPartyResource, yyrl1842) } yyc1842 = true yyrr1842 = len(yyv1842) @@ -22466,7 +21939,7 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { for ; yyj1842 < yyrr1842; yyj1842++ { yyh1842.ElemContainerState(yyj1842) if r.TryDecodeAsNil() { - yyv1842[yyj1842] = Ingress{} + yyv1842[yyj1842] = ThirdPartyResource{} } else { yyv1843 := &yyv1842[yyj1842] yyv1843.CodecDecodeSelf(d) @@ -22475,10 +21948,10 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { } if yyrt1842 { for ; yyj1842 < yyl1842; yyj1842++ { - yyv1842 = append(yyv1842, Ingress{}) + yyv1842 = append(yyv1842, ThirdPartyResource{}) yyh1842.ElemContainerState(yyj1842) if r.TryDecodeAsNil() { - yyv1842[yyj1842] = Ingress{} + yyv1842[yyj1842] = ThirdPartyResource{} } else { yyv1844 := &yyv1842[yyj1842] yyv1844.CodecDecodeSelf(d) @@ -22492,13 +21965,13 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { for ; !r.CheckBreak(); yyj1842++ { if yyj1842 >= len(yyv1842) { - yyv1842 = append(yyv1842, Ingress{}) // var yyz1842 Ingress + yyv1842 = append(yyv1842, ThirdPartyResource{}) // var yyz1842 ThirdPartyResource yyc1842 = true } yyh1842.ElemContainerState(yyj1842) if yyj1842 < len(yyv1842) { if r.TryDecodeAsNil() { - yyv1842[yyj1842] = Ingress{} + yyv1842[yyj1842] = ThirdPartyResource{} } else { yyv1845 := &yyv1842[yyj1842] yyv1845.CodecDecodeSelf(d) @@ -22513,7 +21986,7 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { yyv1842 = yyv1842[:yyj1842] yyc1842 = true } else if yyj1842 == 0 && yyv1842 == nil { - yyv1842 = []Ingress{} + yyv1842 = []ThirdPartyResource{} yyc1842 = true } } @@ -22523,7 +21996,7 @@ func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { } } -func (x codecSelfer1234) encSliceIngressTLS(v []IngressTLS, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceDeploymentCondition(v []DeploymentCondition, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22536,7 +22009,7 @@ func (x codecSelfer1234) encSliceIngressTLS(v []IngressTLS, e *codec1978.Encoder z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceDeploymentCondition(v *[]DeploymentCondition, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22546,7 +22019,7 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode var yyc1848 bool if yyl1848 == 0 { if yyv1848 == nil { - yyv1848 = []IngressTLS{} + yyv1848 = []DeploymentCondition{} yyc1848 = true } else if len(yyv1848) != 0 { yyv1848 = yyv1848[:0] @@ -22559,15 +22032,15 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode yyrg1848 := len(yyv1848) > 0 yyv21848 := yyv1848 - yyrl1848, yyrt1848 = z.DecInferLen(yyl1848, z.DecBasicHandle().MaxInitLen, 40) + yyrl1848, yyrt1848 = z.DecInferLen(yyl1848, z.DecBasicHandle().MaxInitLen, 112) if yyrt1848 { if yyrl1848 <= cap(yyv1848) { yyv1848 = yyv1848[:yyrl1848] } else { - yyv1848 = make([]IngressTLS, yyrl1848) + yyv1848 = make([]DeploymentCondition, yyrl1848) } } else { - yyv1848 = make([]IngressTLS, yyrl1848) + yyv1848 = make([]DeploymentCondition, yyrl1848) } yyc1848 = true yyrr1848 = len(yyv1848) @@ -22582,7 +22055,7 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode for ; yyj1848 < yyrr1848; yyj1848++ { yyh1848.ElemContainerState(yyj1848) if r.TryDecodeAsNil() { - yyv1848[yyj1848] = IngressTLS{} + yyv1848[yyj1848] = DeploymentCondition{} } else { yyv1849 := &yyv1848[yyj1848] yyv1849.CodecDecodeSelf(d) @@ -22591,10 +22064,10 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode } if yyrt1848 { for ; yyj1848 < yyl1848; yyj1848++ { - yyv1848 = append(yyv1848, IngressTLS{}) + yyv1848 = append(yyv1848, DeploymentCondition{}) yyh1848.ElemContainerState(yyj1848) if r.TryDecodeAsNil() { - yyv1848[yyj1848] = IngressTLS{} + yyv1848[yyj1848] = DeploymentCondition{} } else { yyv1850 := &yyv1848[yyj1848] yyv1850.CodecDecodeSelf(d) @@ -22608,13 +22081,13 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode for ; !r.CheckBreak(); yyj1848++ { if yyj1848 >= len(yyv1848) { - yyv1848 = append(yyv1848, IngressTLS{}) // var yyz1848 IngressTLS + yyv1848 = append(yyv1848, DeploymentCondition{}) // var yyz1848 DeploymentCondition yyc1848 = true } yyh1848.ElemContainerState(yyj1848) if yyj1848 < len(yyv1848) { if r.TryDecodeAsNil() { - yyv1848[yyj1848] = IngressTLS{} + yyv1848[yyj1848] = DeploymentCondition{} } else { yyv1851 := &yyv1848[yyj1848] yyv1851.CodecDecodeSelf(d) @@ -22629,7 +22102,7 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode yyv1848 = yyv1848[:yyj1848] yyc1848 = true } else if yyj1848 == 0 && yyv1848 == nil { - yyv1848 = []IngressTLS{} + yyv1848 = []DeploymentCondition{} yyc1848 = true } } @@ -22639,7 +22112,7 @@ func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decode } } -func (x codecSelfer1234) encSliceIngressRule(v []IngressRule, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceDeployment(v []Deployment, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22652,7 +22125,7 @@ func (x codecSelfer1234) encSliceIngressRule(v []IngressRule, e *codec1978.Encod z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceDeployment(v *[]Deployment, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22662,7 +22135,7 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco var yyc1854 bool if yyl1854 == 0 { if yyv1854 == nil { - yyv1854 = []IngressRule{} + yyv1854 = []Deployment{} yyc1854 = true } else if len(yyv1854) != 0 { yyv1854 = yyv1854[:0] @@ -22675,15 +22148,15 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco yyrg1854 := len(yyv1854) > 0 yyv21854 := yyv1854 - yyrl1854, yyrt1854 = z.DecInferLen(yyl1854, z.DecBasicHandle().MaxInitLen, 24) + yyrl1854, yyrt1854 = z.DecInferLen(yyl1854, z.DecBasicHandle().MaxInitLen, 856) if yyrt1854 { if yyrl1854 <= cap(yyv1854) { yyv1854 = yyv1854[:yyrl1854] } else { - yyv1854 = make([]IngressRule, yyrl1854) + yyv1854 = make([]Deployment, yyrl1854) } } else { - yyv1854 = make([]IngressRule, yyrl1854) + yyv1854 = make([]Deployment, yyrl1854) } yyc1854 = true yyrr1854 = len(yyv1854) @@ -22698,7 +22171,7 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco for ; yyj1854 < yyrr1854; yyj1854++ { yyh1854.ElemContainerState(yyj1854) if r.TryDecodeAsNil() { - yyv1854[yyj1854] = IngressRule{} + yyv1854[yyj1854] = Deployment{} } else { yyv1855 := &yyv1854[yyj1854] yyv1855.CodecDecodeSelf(d) @@ -22707,10 +22180,10 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco } if yyrt1854 { for ; yyj1854 < yyl1854; yyj1854++ { - yyv1854 = append(yyv1854, IngressRule{}) + yyv1854 = append(yyv1854, Deployment{}) yyh1854.ElemContainerState(yyj1854) if r.TryDecodeAsNil() { - yyv1854[yyj1854] = IngressRule{} + yyv1854[yyj1854] = Deployment{} } else { yyv1856 := &yyv1854[yyj1854] yyv1856.CodecDecodeSelf(d) @@ -22724,13 +22197,13 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco for ; !r.CheckBreak(); yyj1854++ { if yyj1854 >= len(yyv1854) { - yyv1854 = append(yyv1854, IngressRule{}) // var yyz1854 IngressRule + yyv1854 = append(yyv1854, Deployment{}) // var yyz1854 Deployment yyc1854 = true } yyh1854.ElemContainerState(yyj1854) if yyj1854 < len(yyv1854) { if r.TryDecodeAsNil() { - yyv1854[yyj1854] = IngressRule{} + yyv1854[yyj1854] = Deployment{} } else { yyv1857 := &yyv1854[yyj1854] yyv1857.CodecDecodeSelf(d) @@ -22745,7 +22218,7 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco yyv1854 = yyv1854[:yyj1854] yyc1854 = true } else if yyj1854 == 0 && yyv1854 == nil { - yyv1854 = []IngressRule{} + yyv1854 = []Deployment{} yyc1854 = true } } @@ -22755,7 +22228,7 @@ func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Deco } } -func (x codecSelfer1234) encSliceHTTPIngressPath(v []HTTPIngressPath, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceDaemonSet(v []DaemonSet, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22768,7 +22241,7 @@ func (x codecSelfer1234) encSliceHTTPIngressPath(v []HTTPIngressPath, e *codec19 z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceDaemonSet(v *[]DaemonSet, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22778,7 +22251,7 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 var yyc1860 bool if yyl1860 == 0 { if yyv1860 == nil { - yyv1860 = []HTTPIngressPath{} + yyv1860 = []DaemonSet{} yyc1860 = true } else if len(yyv1860) != 0 { yyv1860 = yyv1860[:0] @@ -22791,15 +22264,15 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 yyrg1860 := len(yyv1860) > 0 yyv21860 := yyv1860 - yyrl1860, yyrt1860 = z.DecInferLen(yyl1860, z.DecBasicHandle().MaxInitLen, 64) + yyrl1860, yyrt1860 = z.DecInferLen(yyl1860, z.DecBasicHandle().MaxInitLen, 752) if yyrt1860 { if yyrl1860 <= cap(yyv1860) { yyv1860 = yyv1860[:yyrl1860] } else { - yyv1860 = make([]HTTPIngressPath, yyrl1860) + yyv1860 = make([]DaemonSet, yyrl1860) } } else { - yyv1860 = make([]HTTPIngressPath, yyrl1860) + yyv1860 = make([]DaemonSet, yyrl1860) } yyc1860 = true yyrr1860 = len(yyv1860) @@ -22814,7 +22287,7 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 for ; yyj1860 < yyrr1860; yyj1860++ { yyh1860.ElemContainerState(yyj1860) if r.TryDecodeAsNil() { - yyv1860[yyj1860] = HTTPIngressPath{} + yyv1860[yyj1860] = DaemonSet{} } else { yyv1861 := &yyv1860[yyj1860] yyv1861.CodecDecodeSelf(d) @@ -22823,10 +22296,10 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 } if yyrt1860 { for ; yyj1860 < yyl1860; yyj1860++ { - yyv1860 = append(yyv1860, HTTPIngressPath{}) + yyv1860 = append(yyv1860, DaemonSet{}) yyh1860.ElemContainerState(yyj1860) if r.TryDecodeAsNil() { - yyv1860[yyj1860] = HTTPIngressPath{} + yyv1860[yyj1860] = DaemonSet{} } else { yyv1862 := &yyv1860[yyj1860] yyv1862.CodecDecodeSelf(d) @@ -22840,13 +22313,13 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 for ; !r.CheckBreak(); yyj1860++ { if yyj1860 >= len(yyv1860) { - yyv1860 = append(yyv1860, HTTPIngressPath{}) // var yyz1860 HTTPIngressPath + yyv1860 = append(yyv1860, DaemonSet{}) // var yyz1860 DaemonSet yyc1860 = true } yyh1860.ElemContainerState(yyj1860) if yyj1860 < len(yyv1860) { if r.TryDecodeAsNil() { - yyv1860[yyj1860] = HTTPIngressPath{} + yyv1860[yyj1860] = DaemonSet{} } else { yyv1863 := &yyv1860[yyj1860] yyv1863.CodecDecodeSelf(d) @@ -22861,7 +22334,7 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 yyv1860 = yyv1860[:yyj1860] yyc1860 = true } else if yyj1860 == 0 && yyv1860 == nil { - yyv1860 = []HTTPIngressPath{} + yyv1860 = []DaemonSet{} yyc1860 = true } } @@ -22871,7 +22344,7 @@ func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1 } } -func (x codecSelfer1234) encSliceLabelSelectorRequirement(v []LabelSelectorRequirement, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceThirdPartyResourceData(v []ThirdPartyResourceData, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -22884,7 +22357,7 @@ func (x codecSelfer1234) encSliceLabelSelectorRequirement(v []LabelSelectorRequi z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequirement, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceThirdPartyResourceData(v *[]ThirdPartyResourceData, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -22894,7 +22367,7 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ var yyc1866 bool if yyl1866 == 0 { if yyv1866 == nil { - yyv1866 = []LabelSelectorRequirement{} + yyv1866 = []ThirdPartyResourceData{} yyc1866 = true } else if len(yyv1866) != 0 { yyv1866 = yyv1866[:0] @@ -22907,15 +22380,15 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ yyrg1866 := len(yyv1866) > 0 yyv21866 := yyv1866 - yyrl1866, yyrt1866 = z.DecInferLen(yyl1866, z.DecBasicHandle().MaxInitLen, 56) + yyrl1866, yyrt1866 = z.DecInferLen(yyl1866, z.DecBasicHandle().MaxInitLen, 280) if yyrt1866 { if yyrl1866 <= cap(yyv1866) { yyv1866 = yyv1866[:yyrl1866] } else { - yyv1866 = make([]LabelSelectorRequirement, yyrl1866) + yyv1866 = make([]ThirdPartyResourceData, yyrl1866) } } else { - yyv1866 = make([]LabelSelectorRequirement, yyrl1866) + yyv1866 = make([]ThirdPartyResourceData, yyrl1866) } yyc1866 = true yyrr1866 = len(yyv1866) @@ -22930,7 +22403,7 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ for ; yyj1866 < yyrr1866; yyj1866++ { yyh1866.ElemContainerState(yyj1866) if r.TryDecodeAsNil() { - yyv1866[yyj1866] = LabelSelectorRequirement{} + yyv1866[yyj1866] = ThirdPartyResourceData{} } else { yyv1867 := &yyv1866[yyj1866] yyv1867.CodecDecodeSelf(d) @@ -22939,10 +22412,10 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ } if yyrt1866 { for ; yyj1866 < yyl1866; yyj1866++ { - yyv1866 = append(yyv1866, LabelSelectorRequirement{}) + yyv1866 = append(yyv1866, ThirdPartyResourceData{}) yyh1866.ElemContainerState(yyj1866) if r.TryDecodeAsNil() { - yyv1866[yyj1866] = LabelSelectorRequirement{} + yyv1866[yyj1866] = ThirdPartyResourceData{} } else { yyv1868 := &yyv1866[yyj1866] yyv1868.CodecDecodeSelf(d) @@ -22956,13 +22429,13 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ for ; !r.CheckBreak(); yyj1866++ { if yyj1866 >= len(yyv1866) { - yyv1866 = append(yyv1866, LabelSelectorRequirement{}) // var yyz1866 LabelSelectorRequirement + yyv1866 = append(yyv1866, ThirdPartyResourceData{}) // var yyz1866 ThirdPartyResourceData yyc1866 = true } yyh1866.ElemContainerState(yyj1866) if yyj1866 < len(yyv1866) { if r.TryDecodeAsNil() { - yyv1866[yyj1866] = LabelSelectorRequirement{} + yyv1866[yyj1866] = ThirdPartyResourceData{} } else { yyv1869 := &yyv1866[yyj1866] yyv1869.CodecDecodeSelf(d) @@ -22977,7 +22450,7 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ yyv1866 = yyv1866[:yyj1866] yyc1866 = true } else if yyj1866 == 0 && yyv1866 == nil { - yyv1866 = []LabelSelectorRequirement{} + yyv1866 = []ThirdPartyResourceData{} yyc1866 = true } } @@ -22987,7 +22460,7 @@ func (x codecSelfer1234) decSliceLabelSelectorRequirement(v *[]LabelSelectorRequ } } -func (x codecSelfer1234) encSliceReplicaSet(v []ReplicaSet, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceJob(v []Job, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -23000,7 +22473,7 @@ func (x codecSelfer1234) encSliceReplicaSet(v []ReplicaSet, e *codec1978.Encoder z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceJob(v *[]Job, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -23010,7 +22483,7 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode var yyc1872 bool if yyl1872 == 0 { if yyv1872 == nil { - yyv1872 = []ReplicaSet{} + yyv1872 = []Job{} yyc1872 = true } else if len(yyv1872) != 0 { yyv1872 = yyv1872[:0] @@ -23023,15 +22496,15 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode yyrg1872 := len(yyv1872) > 0 yyv21872 := yyv1872 - yyrl1872, yyrt1872 = z.DecInferLen(yyl1872, z.DecBasicHandle().MaxInitLen, 800) + yyrl1872, yyrt1872 = z.DecInferLen(yyl1872, z.DecBasicHandle().MaxInitLen, 824) if yyrt1872 { if yyrl1872 <= cap(yyv1872) { yyv1872 = yyv1872[:yyrl1872] } else { - yyv1872 = make([]ReplicaSet, yyrl1872) + yyv1872 = make([]Job, yyrl1872) } } else { - yyv1872 = make([]ReplicaSet, yyrl1872) + yyv1872 = make([]Job, yyrl1872) } yyc1872 = true yyrr1872 = len(yyv1872) @@ -23046,7 +22519,7 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode for ; yyj1872 < yyrr1872; yyj1872++ { yyh1872.ElemContainerState(yyj1872) if r.TryDecodeAsNil() { - yyv1872[yyj1872] = ReplicaSet{} + yyv1872[yyj1872] = Job{} } else { yyv1873 := &yyv1872[yyj1872] yyv1873.CodecDecodeSelf(d) @@ -23055,10 +22528,10 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode } if yyrt1872 { for ; yyj1872 < yyl1872; yyj1872++ { - yyv1872 = append(yyv1872, ReplicaSet{}) + yyv1872 = append(yyv1872, Job{}) yyh1872.ElemContainerState(yyj1872) if r.TryDecodeAsNil() { - yyv1872[yyj1872] = ReplicaSet{} + yyv1872[yyj1872] = Job{} } else { yyv1874 := &yyv1872[yyj1872] yyv1874.CodecDecodeSelf(d) @@ -23072,13 +22545,13 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode for ; !r.CheckBreak(); yyj1872++ { if yyj1872 >= len(yyv1872) { - yyv1872 = append(yyv1872, ReplicaSet{}) // var yyz1872 ReplicaSet + yyv1872 = append(yyv1872, Job{}) // var yyz1872 Job yyc1872 = true } yyh1872.ElemContainerState(yyj1872) if yyj1872 < len(yyv1872) { if r.TryDecodeAsNil() { - yyv1872[yyj1872] = ReplicaSet{} + yyv1872[yyj1872] = Job{} } else { yyv1875 := &yyv1872[yyj1872] yyv1875.CodecDecodeSelf(d) @@ -23093,7 +22566,7 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode yyv1872 = yyv1872[:yyj1872] yyc1872 = true } else if yyj1872 == 0 && yyv1872 == nil { - yyv1872 = []ReplicaSet{} + yyv1872 = []Job{} yyc1872 = true } } @@ -23103,7 +22576,7 @@ func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decode } } -func (x codecSelfer1234) encSliceReplicaSetCondition(v []ReplicaSetCondition, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceJobCondition(v []JobCondition, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -23116,7 +22589,7 @@ func (x codecSelfer1234) encSliceReplicaSetCondition(v []ReplicaSetCondition, e z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceJobCondition(v *[]JobCondition, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -23126,7 +22599,7 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d var yyc1878 bool if yyl1878 == 0 { if yyv1878 == nil { - yyv1878 = []ReplicaSetCondition{} + yyv1878 = []JobCondition{} yyc1878 = true } else if len(yyv1878) != 0 { yyv1878 = yyv1878[:0] @@ -23144,10 +22617,10 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d if yyrl1878 <= cap(yyv1878) { yyv1878 = yyv1878[:yyrl1878] } else { - yyv1878 = make([]ReplicaSetCondition, yyrl1878) + yyv1878 = make([]JobCondition, yyrl1878) } } else { - yyv1878 = make([]ReplicaSetCondition, yyrl1878) + yyv1878 = make([]JobCondition, yyrl1878) } yyc1878 = true yyrr1878 = len(yyv1878) @@ -23162,7 +22635,7 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d for ; yyj1878 < yyrr1878; yyj1878++ { yyh1878.ElemContainerState(yyj1878) if r.TryDecodeAsNil() { - yyv1878[yyj1878] = ReplicaSetCondition{} + yyv1878[yyj1878] = JobCondition{} } else { yyv1879 := &yyv1878[yyj1878] yyv1879.CodecDecodeSelf(d) @@ -23171,10 +22644,10 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d } if yyrt1878 { for ; yyj1878 < yyl1878; yyj1878++ { - yyv1878 = append(yyv1878, ReplicaSetCondition{}) + yyv1878 = append(yyv1878, JobCondition{}) yyh1878.ElemContainerState(yyj1878) if r.TryDecodeAsNil() { - yyv1878[yyj1878] = ReplicaSetCondition{} + yyv1878[yyj1878] = JobCondition{} } else { yyv1880 := &yyv1878[yyj1878] yyv1880.CodecDecodeSelf(d) @@ -23188,13 +22661,13 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d for ; !r.CheckBreak(); yyj1878++ { if yyj1878 >= len(yyv1878) { - yyv1878 = append(yyv1878, ReplicaSetCondition{}) // var yyz1878 ReplicaSetCondition + yyv1878 = append(yyv1878, JobCondition{}) // var yyz1878 JobCondition yyc1878 = true } yyh1878.ElemContainerState(yyj1878) if yyj1878 < len(yyv1878) { if r.TryDecodeAsNil() { - yyv1878[yyj1878] = ReplicaSetCondition{} + yyv1878[yyj1878] = JobCondition{} } else { yyv1881 := &yyv1878[yyj1878] yyv1881.CodecDecodeSelf(d) @@ -23209,7 +22682,7 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d yyv1878 = yyv1878[:yyj1878] yyc1878 = true } else if yyj1878 == 0 && yyv1878 == nil { - yyv1878 = []ReplicaSetCondition{} + yyv1878 = []JobCondition{} yyc1878 = true } } @@ -23219,25 +22692,20 @@ func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d } } -func (x codecSelfer1234) encSlicev1_Capability(v []pkg2_v1.Capability, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceIngress(v []Ingress, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) for _, yyv1882 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1883 := z.EncBinary() - _ = yym1883 - if false { - } else if z.HasExtensions() && z.EncExt(yyv1882) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(yyv1882)) - } + yy1883 := &yyv1882 + yy1883.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceIngress(v *[]Ingress, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -23247,7 +22715,7 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec var yyc1884 bool if yyl1884 == 0 { if yyv1884 == nil { - yyv1884 = []pkg2_v1.Capability{} + yyv1884 = []Ingress{} yyc1884 = true } else if len(yyv1884) != 0 { yyv1884 = yyv1884[:0] @@ -23258,18 +22726,23 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec var yyrt1884 bool if yyl1884 > cap(yyv1884) { - yyrl1884, yyrt1884 = z.DecInferLen(yyl1884, z.DecBasicHandle().MaxInitLen, 16) + yyrg1884 := len(yyv1884) > 0 + yyv21884 := yyv1884 + yyrl1884, yyrt1884 = z.DecInferLen(yyl1884, z.DecBasicHandle().MaxInitLen, 336) if yyrt1884 { if yyrl1884 <= cap(yyv1884) { yyv1884 = yyv1884[:yyrl1884] } else { - yyv1884 = make([]pkg2_v1.Capability, yyrl1884) + yyv1884 = make([]Ingress, yyrl1884) } } else { - yyv1884 = make([]pkg2_v1.Capability, yyrl1884) + yyv1884 = make([]Ingress, yyrl1884) } yyc1884 = true yyrr1884 = len(yyv1884) + if yyrg1884 { + copy(yyv1884, yyv21884) + } } else if yyl1884 != len(yyv1884) { yyv1884 = yyv1884[:yyl1884] yyc1884 = true @@ -23278,20 +22751,22 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec for ; yyj1884 < yyrr1884; yyj1884++ { yyh1884.ElemContainerState(yyj1884) if r.TryDecodeAsNil() { - yyv1884[yyj1884] = "" + yyv1884[yyj1884] = Ingress{} } else { - yyv1884[yyj1884] = pkg2_v1.Capability(r.DecodeString()) + yyv1885 := &yyv1884[yyj1884] + yyv1885.CodecDecodeSelf(d) } } if yyrt1884 { for ; yyj1884 < yyl1884; yyj1884++ { - yyv1884 = append(yyv1884, "") + yyv1884 = append(yyv1884, Ingress{}) yyh1884.ElemContainerState(yyj1884) if r.TryDecodeAsNil() { - yyv1884[yyj1884] = "" + yyv1884[yyj1884] = Ingress{} } else { - yyv1884[yyj1884] = pkg2_v1.Capability(r.DecodeString()) + yyv1886 := &yyv1884[yyj1884] + yyv1886.CodecDecodeSelf(d) } } @@ -23302,15 +22777,16 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec for ; !r.CheckBreak(); yyj1884++ { if yyj1884 >= len(yyv1884) { - yyv1884 = append(yyv1884, "") // var yyz1884 pkg2_v1.Capability + yyv1884 = append(yyv1884, Ingress{}) // var yyz1884 Ingress yyc1884 = true } yyh1884.ElemContainerState(yyj1884) if yyj1884 < len(yyv1884) { if r.TryDecodeAsNil() { - yyv1884[yyj1884] = "" + yyv1884[yyj1884] = Ingress{} } else { - yyv1884[yyj1884] = pkg2_v1.Capability(r.DecodeString()) + yyv1887 := &yyv1884[yyj1884] + yyv1887.CodecDecodeSelf(d) } } else { @@ -23322,7 +22798,7 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec yyv1884 = yyv1884[:yyj1884] yyc1884 = true } else if yyj1884 == 0 && yyv1884 == nil { - yyv1884 = []pkg2_v1.Capability{} + yyv1884 = []Ingress{} yyc1884 = true } } @@ -23332,14 +22808,707 @@ func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec } } -func (x codecSelfer1234) encSliceFSType(v []FSType, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceIngressTLS(v []IngressTLS, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r r.EncodeArrayStart(len(v)) for _, yyv1888 := range v { z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yyv1888.CodecEncodeSelf(e) + yy1889 := &yyv1888 + yy1889.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceIngressTLS(v *[]IngressTLS, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1890 := *v + yyh1890, yyl1890 := z.DecSliceHelperStart() + var yyc1890 bool + if yyl1890 == 0 { + if yyv1890 == nil { + yyv1890 = []IngressTLS{} + yyc1890 = true + } else if len(yyv1890) != 0 { + yyv1890 = yyv1890[:0] + yyc1890 = true + } + } else if yyl1890 > 0 { + var yyrr1890, yyrl1890 int + var yyrt1890 bool + if yyl1890 > cap(yyv1890) { + + yyrg1890 := len(yyv1890) > 0 + yyv21890 := yyv1890 + yyrl1890, yyrt1890 = z.DecInferLen(yyl1890, z.DecBasicHandle().MaxInitLen, 40) + if yyrt1890 { + if yyrl1890 <= cap(yyv1890) { + yyv1890 = yyv1890[:yyrl1890] + } else { + yyv1890 = make([]IngressTLS, yyrl1890) + } + } else { + yyv1890 = make([]IngressTLS, yyrl1890) + } + yyc1890 = true + yyrr1890 = len(yyv1890) + if yyrg1890 { + copy(yyv1890, yyv21890) + } + } else if yyl1890 != len(yyv1890) { + yyv1890 = yyv1890[:yyl1890] + yyc1890 = true + } + yyj1890 := 0 + for ; yyj1890 < yyrr1890; yyj1890++ { + yyh1890.ElemContainerState(yyj1890) + if r.TryDecodeAsNil() { + yyv1890[yyj1890] = IngressTLS{} + } else { + yyv1891 := &yyv1890[yyj1890] + yyv1891.CodecDecodeSelf(d) + } + + } + if yyrt1890 { + for ; yyj1890 < yyl1890; yyj1890++ { + yyv1890 = append(yyv1890, IngressTLS{}) + yyh1890.ElemContainerState(yyj1890) + if r.TryDecodeAsNil() { + yyv1890[yyj1890] = IngressTLS{} + } else { + yyv1892 := &yyv1890[yyj1890] + yyv1892.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1890 := 0 + for ; !r.CheckBreak(); yyj1890++ { + + if yyj1890 >= len(yyv1890) { + yyv1890 = append(yyv1890, IngressTLS{}) // var yyz1890 IngressTLS + yyc1890 = true + } + yyh1890.ElemContainerState(yyj1890) + if yyj1890 < len(yyv1890) { + if r.TryDecodeAsNil() { + yyv1890[yyj1890] = IngressTLS{} + } else { + yyv1893 := &yyv1890[yyj1890] + yyv1893.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1890 < len(yyv1890) { + yyv1890 = yyv1890[:yyj1890] + yyc1890 = true + } else if yyj1890 == 0 && yyv1890 == nil { + yyv1890 = []IngressTLS{} + yyc1890 = true + } + } + yyh1890.End() + if yyc1890 { + *v = yyv1890 + } +} + +func (x codecSelfer1234) encSliceIngressRule(v []IngressRule, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1894 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1895 := &yyv1894 + yy1895.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceIngressRule(v *[]IngressRule, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1896 := *v + yyh1896, yyl1896 := z.DecSliceHelperStart() + var yyc1896 bool + if yyl1896 == 0 { + if yyv1896 == nil { + yyv1896 = []IngressRule{} + yyc1896 = true + } else if len(yyv1896) != 0 { + yyv1896 = yyv1896[:0] + yyc1896 = true + } + } else if yyl1896 > 0 { + var yyrr1896, yyrl1896 int + var yyrt1896 bool + if yyl1896 > cap(yyv1896) { + + yyrg1896 := len(yyv1896) > 0 + yyv21896 := yyv1896 + yyrl1896, yyrt1896 = z.DecInferLen(yyl1896, z.DecBasicHandle().MaxInitLen, 24) + if yyrt1896 { + if yyrl1896 <= cap(yyv1896) { + yyv1896 = yyv1896[:yyrl1896] + } else { + yyv1896 = make([]IngressRule, yyrl1896) + } + } else { + yyv1896 = make([]IngressRule, yyrl1896) + } + yyc1896 = true + yyrr1896 = len(yyv1896) + if yyrg1896 { + copy(yyv1896, yyv21896) + } + } else if yyl1896 != len(yyv1896) { + yyv1896 = yyv1896[:yyl1896] + yyc1896 = true + } + yyj1896 := 0 + for ; yyj1896 < yyrr1896; yyj1896++ { + yyh1896.ElemContainerState(yyj1896) + if r.TryDecodeAsNil() { + yyv1896[yyj1896] = IngressRule{} + } else { + yyv1897 := &yyv1896[yyj1896] + yyv1897.CodecDecodeSelf(d) + } + + } + if yyrt1896 { + for ; yyj1896 < yyl1896; yyj1896++ { + yyv1896 = append(yyv1896, IngressRule{}) + yyh1896.ElemContainerState(yyj1896) + if r.TryDecodeAsNil() { + yyv1896[yyj1896] = IngressRule{} + } else { + yyv1898 := &yyv1896[yyj1896] + yyv1898.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1896 := 0 + for ; !r.CheckBreak(); yyj1896++ { + + if yyj1896 >= len(yyv1896) { + yyv1896 = append(yyv1896, IngressRule{}) // var yyz1896 IngressRule + yyc1896 = true + } + yyh1896.ElemContainerState(yyj1896) + if yyj1896 < len(yyv1896) { + if r.TryDecodeAsNil() { + yyv1896[yyj1896] = IngressRule{} + } else { + yyv1899 := &yyv1896[yyj1896] + yyv1899.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1896 < len(yyv1896) { + yyv1896 = yyv1896[:yyj1896] + yyc1896 = true + } else if yyj1896 == 0 && yyv1896 == nil { + yyv1896 = []IngressRule{} + yyc1896 = true + } + } + yyh1896.End() + if yyc1896 { + *v = yyv1896 + } +} + +func (x codecSelfer1234) encSliceHTTPIngressPath(v []HTTPIngressPath, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1900 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1901 := &yyv1900 + yy1901.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceHTTPIngressPath(v *[]HTTPIngressPath, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1902 := *v + yyh1902, yyl1902 := z.DecSliceHelperStart() + var yyc1902 bool + if yyl1902 == 0 { + if yyv1902 == nil { + yyv1902 = []HTTPIngressPath{} + yyc1902 = true + } else if len(yyv1902) != 0 { + yyv1902 = yyv1902[:0] + yyc1902 = true + } + } else if yyl1902 > 0 { + var yyrr1902, yyrl1902 int + var yyrt1902 bool + if yyl1902 > cap(yyv1902) { + + yyrg1902 := len(yyv1902) > 0 + yyv21902 := yyv1902 + yyrl1902, yyrt1902 = z.DecInferLen(yyl1902, z.DecBasicHandle().MaxInitLen, 64) + if yyrt1902 { + if yyrl1902 <= cap(yyv1902) { + yyv1902 = yyv1902[:yyrl1902] + } else { + yyv1902 = make([]HTTPIngressPath, yyrl1902) + } + } else { + yyv1902 = make([]HTTPIngressPath, yyrl1902) + } + yyc1902 = true + yyrr1902 = len(yyv1902) + if yyrg1902 { + copy(yyv1902, yyv21902) + } + } else if yyl1902 != len(yyv1902) { + yyv1902 = yyv1902[:yyl1902] + yyc1902 = true + } + yyj1902 := 0 + for ; yyj1902 < yyrr1902; yyj1902++ { + yyh1902.ElemContainerState(yyj1902) + if r.TryDecodeAsNil() { + yyv1902[yyj1902] = HTTPIngressPath{} + } else { + yyv1903 := &yyv1902[yyj1902] + yyv1903.CodecDecodeSelf(d) + } + + } + if yyrt1902 { + for ; yyj1902 < yyl1902; yyj1902++ { + yyv1902 = append(yyv1902, HTTPIngressPath{}) + yyh1902.ElemContainerState(yyj1902) + if r.TryDecodeAsNil() { + yyv1902[yyj1902] = HTTPIngressPath{} + } else { + yyv1904 := &yyv1902[yyj1902] + yyv1904.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1902 := 0 + for ; !r.CheckBreak(); yyj1902++ { + + if yyj1902 >= len(yyv1902) { + yyv1902 = append(yyv1902, HTTPIngressPath{}) // var yyz1902 HTTPIngressPath + yyc1902 = true + } + yyh1902.ElemContainerState(yyj1902) + if yyj1902 < len(yyv1902) { + if r.TryDecodeAsNil() { + yyv1902[yyj1902] = HTTPIngressPath{} + } else { + yyv1905 := &yyv1902[yyj1902] + yyv1905.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1902 < len(yyv1902) { + yyv1902 = yyv1902[:yyj1902] + yyc1902 = true + } else if yyj1902 == 0 && yyv1902 == nil { + yyv1902 = []HTTPIngressPath{} + yyc1902 = true + } + } + yyh1902.End() + if yyc1902 { + *v = yyv1902 + } +} + +func (x codecSelfer1234) encSliceReplicaSet(v []ReplicaSet, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1906 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1907 := &yyv1906 + yy1907.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceReplicaSet(v *[]ReplicaSet, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1908 := *v + yyh1908, yyl1908 := z.DecSliceHelperStart() + var yyc1908 bool + if yyl1908 == 0 { + if yyv1908 == nil { + yyv1908 = []ReplicaSet{} + yyc1908 = true + } else if len(yyv1908) != 0 { + yyv1908 = yyv1908[:0] + yyc1908 = true + } + } else if yyl1908 > 0 { + var yyrr1908, yyrl1908 int + var yyrt1908 bool + if yyl1908 > cap(yyv1908) { + + yyrg1908 := len(yyv1908) > 0 + yyv21908 := yyv1908 + yyrl1908, yyrt1908 = z.DecInferLen(yyl1908, z.DecBasicHandle().MaxInitLen, 800) + if yyrt1908 { + if yyrl1908 <= cap(yyv1908) { + yyv1908 = yyv1908[:yyrl1908] + } else { + yyv1908 = make([]ReplicaSet, yyrl1908) + } + } else { + yyv1908 = make([]ReplicaSet, yyrl1908) + } + yyc1908 = true + yyrr1908 = len(yyv1908) + if yyrg1908 { + copy(yyv1908, yyv21908) + } + } else if yyl1908 != len(yyv1908) { + yyv1908 = yyv1908[:yyl1908] + yyc1908 = true + } + yyj1908 := 0 + for ; yyj1908 < yyrr1908; yyj1908++ { + yyh1908.ElemContainerState(yyj1908) + if r.TryDecodeAsNil() { + yyv1908[yyj1908] = ReplicaSet{} + } else { + yyv1909 := &yyv1908[yyj1908] + yyv1909.CodecDecodeSelf(d) + } + + } + if yyrt1908 { + for ; yyj1908 < yyl1908; yyj1908++ { + yyv1908 = append(yyv1908, ReplicaSet{}) + yyh1908.ElemContainerState(yyj1908) + if r.TryDecodeAsNil() { + yyv1908[yyj1908] = ReplicaSet{} + } else { + yyv1910 := &yyv1908[yyj1908] + yyv1910.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1908 := 0 + for ; !r.CheckBreak(); yyj1908++ { + + if yyj1908 >= len(yyv1908) { + yyv1908 = append(yyv1908, ReplicaSet{}) // var yyz1908 ReplicaSet + yyc1908 = true + } + yyh1908.ElemContainerState(yyj1908) + if yyj1908 < len(yyv1908) { + if r.TryDecodeAsNil() { + yyv1908[yyj1908] = ReplicaSet{} + } else { + yyv1911 := &yyv1908[yyj1908] + yyv1911.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1908 < len(yyv1908) { + yyv1908 = yyv1908[:yyj1908] + yyc1908 = true + } else if yyj1908 == 0 && yyv1908 == nil { + yyv1908 = []ReplicaSet{} + yyc1908 = true + } + } + yyh1908.End() + if yyc1908 { + *v = yyv1908 + } +} + +func (x codecSelfer1234) encSliceReplicaSetCondition(v []ReplicaSetCondition, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1912 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1913 := &yyv1912 + yy1913.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceReplicaSetCondition(v *[]ReplicaSetCondition, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1914 := *v + yyh1914, yyl1914 := z.DecSliceHelperStart() + var yyc1914 bool + if yyl1914 == 0 { + if yyv1914 == nil { + yyv1914 = []ReplicaSetCondition{} + yyc1914 = true + } else if len(yyv1914) != 0 { + yyv1914 = yyv1914[:0] + yyc1914 = true + } + } else if yyl1914 > 0 { + var yyrr1914, yyrl1914 int + var yyrt1914 bool + if yyl1914 > cap(yyv1914) { + + yyrg1914 := len(yyv1914) > 0 + yyv21914 := yyv1914 + yyrl1914, yyrt1914 = z.DecInferLen(yyl1914, z.DecBasicHandle().MaxInitLen, 88) + if yyrt1914 { + if yyrl1914 <= cap(yyv1914) { + yyv1914 = yyv1914[:yyrl1914] + } else { + yyv1914 = make([]ReplicaSetCondition, yyrl1914) + } + } else { + yyv1914 = make([]ReplicaSetCondition, yyrl1914) + } + yyc1914 = true + yyrr1914 = len(yyv1914) + if yyrg1914 { + copy(yyv1914, yyv21914) + } + } else if yyl1914 != len(yyv1914) { + yyv1914 = yyv1914[:yyl1914] + yyc1914 = true + } + yyj1914 := 0 + for ; yyj1914 < yyrr1914; yyj1914++ { + yyh1914.ElemContainerState(yyj1914) + if r.TryDecodeAsNil() { + yyv1914[yyj1914] = ReplicaSetCondition{} + } else { + yyv1915 := &yyv1914[yyj1914] + yyv1915.CodecDecodeSelf(d) + } + + } + if yyrt1914 { + for ; yyj1914 < yyl1914; yyj1914++ { + yyv1914 = append(yyv1914, ReplicaSetCondition{}) + yyh1914.ElemContainerState(yyj1914) + if r.TryDecodeAsNil() { + yyv1914[yyj1914] = ReplicaSetCondition{} + } else { + yyv1916 := &yyv1914[yyj1914] + yyv1916.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1914 := 0 + for ; !r.CheckBreak(); yyj1914++ { + + if yyj1914 >= len(yyv1914) { + yyv1914 = append(yyv1914, ReplicaSetCondition{}) // var yyz1914 ReplicaSetCondition + yyc1914 = true + } + yyh1914.ElemContainerState(yyj1914) + if yyj1914 < len(yyv1914) { + if r.TryDecodeAsNil() { + yyv1914[yyj1914] = ReplicaSetCondition{} + } else { + yyv1917 := &yyv1914[yyj1914] + yyv1917.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1914 < len(yyv1914) { + yyv1914 = yyv1914[:yyj1914] + yyc1914 = true + } else if yyj1914 == 0 && yyv1914 == nil { + yyv1914 = []ReplicaSetCondition{} + yyc1914 = true + } + } + yyh1914.End() + if yyc1914 { + *v = yyv1914 + } +} + +func (x codecSelfer1234) encSlicev1_Capability(v []pkg2_v1.Capability, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1918 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yym1919 := z.EncBinary() + _ = yym1919 + if false { + } else if z.HasExtensions() && z.EncExt(yyv1918) { + } else { + r.EncodeString(codecSelferC_UTF81234, string(yyv1918)) + } + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSlicev1_Capability(v *[]pkg2_v1.Capability, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1920 := *v + yyh1920, yyl1920 := z.DecSliceHelperStart() + var yyc1920 bool + if yyl1920 == 0 { + if yyv1920 == nil { + yyv1920 = []pkg2_v1.Capability{} + yyc1920 = true + } else if len(yyv1920) != 0 { + yyv1920 = yyv1920[:0] + yyc1920 = true + } + } else if yyl1920 > 0 { + var yyrr1920, yyrl1920 int + var yyrt1920 bool + if yyl1920 > cap(yyv1920) { + + yyrl1920, yyrt1920 = z.DecInferLen(yyl1920, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1920 { + if yyrl1920 <= cap(yyv1920) { + yyv1920 = yyv1920[:yyrl1920] + } else { + yyv1920 = make([]pkg2_v1.Capability, yyrl1920) + } + } else { + yyv1920 = make([]pkg2_v1.Capability, yyrl1920) + } + yyc1920 = true + yyrr1920 = len(yyv1920) + } else if yyl1920 != len(yyv1920) { + yyv1920 = yyv1920[:yyl1920] + yyc1920 = true + } + yyj1920 := 0 + for ; yyj1920 < yyrr1920; yyj1920++ { + yyh1920.ElemContainerState(yyj1920) + if r.TryDecodeAsNil() { + yyv1920[yyj1920] = "" + } else { + yyv1920[yyj1920] = pkg2_v1.Capability(r.DecodeString()) + } + + } + if yyrt1920 { + for ; yyj1920 < yyl1920; yyj1920++ { + yyv1920 = append(yyv1920, "") + yyh1920.ElemContainerState(yyj1920) + if r.TryDecodeAsNil() { + yyv1920[yyj1920] = "" + } else { + yyv1920[yyj1920] = pkg2_v1.Capability(r.DecodeString()) + } + + } + } + + } else { + yyj1920 := 0 + for ; !r.CheckBreak(); yyj1920++ { + + if yyj1920 >= len(yyv1920) { + yyv1920 = append(yyv1920, "") // var yyz1920 pkg2_v1.Capability + yyc1920 = true + } + yyh1920.ElemContainerState(yyj1920) + if yyj1920 < len(yyv1920) { + if r.TryDecodeAsNil() { + yyv1920[yyj1920] = "" + } else { + yyv1920[yyj1920] = pkg2_v1.Capability(r.DecodeString()) + } + + } else { + z.DecSwallow() + } + + } + if yyj1920 < len(yyv1920) { + yyv1920 = yyv1920[:yyj1920] + yyc1920 = true + } else if yyj1920 == 0 && yyv1920 == nil { + yyv1920 = []pkg2_v1.Capability{} + yyc1920 = true + } + } + yyh1920.End() + if yyc1920 { + *v = yyv1920 + } +} + +func (x codecSelfer1234) encSliceFSType(v []FSType, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1924 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yyv1924.CodecEncodeSelf(e) } z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } @@ -23349,700 +23518,12 @@ func (x codecSelfer1234) decSliceFSType(v *[]FSType, d *codec1978.Decoder) { z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r - yyv1889 := *v - yyh1889, yyl1889 := z.DecSliceHelperStart() - var yyc1889 bool - if yyl1889 == 0 { - if yyv1889 == nil { - yyv1889 = []FSType{} - yyc1889 = true - } else if len(yyv1889) != 0 { - yyv1889 = yyv1889[:0] - yyc1889 = true - } - } else if yyl1889 > 0 { - var yyrr1889, yyrl1889 int - var yyrt1889 bool - if yyl1889 > cap(yyv1889) { - - yyrl1889, yyrt1889 = z.DecInferLen(yyl1889, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1889 { - if yyrl1889 <= cap(yyv1889) { - yyv1889 = yyv1889[:yyrl1889] - } else { - yyv1889 = make([]FSType, yyrl1889) - } - } else { - yyv1889 = make([]FSType, yyrl1889) - } - yyc1889 = true - yyrr1889 = len(yyv1889) - } else if yyl1889 != len(yyv1889) { - yyv1889 = yyv1889[:yyl1889] - yyc1889 = true - } - yyj1889 := 0 - for ; yyj1889 < yyrr1889; yyj1889++ { - yyh1889.ElemContainerState(yyj1889) - if r.TryDecodeAsNil() { - yyv1889[yyj1889] = "" - } else { - yyv1889[yyj1889] = FSType(r.DecodeString()) - } - - } - if yyrt1889 { - for ; yyj1889 < yyl1889; yyj1889++ { - yyv1889 = append(yyv1889, "") - yyh1889.ElemContainerState(yyj1889) - if r.TryDecodeAsNil() { - yyv1889[yyj1889] = "" - } else { - yyv1889[yyj1889] = FSType(r.DecodeString()) - } - - } - } - - } else { - yyj1889 := 0 - for ; !r.CheckBreak(); yyj1889++ { - - if yyj1889 >= len(yyv1889) { - yyv1889 = append(yyv1889, "") // var yyz1889 FSType - yyc1889 = true - } - yyh1889.ElemContainerState(yyj1889) - if yyj1889 < len(yyv1889) { - if r.TryDecodeAsNil() { - yyv1889[yyj1889] = "" - } else { - yyv1889[yyj1889] = FSType(r.DecodeString()) - } - - } else { - z.DecSwallow() - } - - } - if yyj1889 < len(yyv1889) { - yyv1889 = yyv1889[:yyj1889] - yyc1889 = true - } else if yyj1889 == 0 && yyv1889 == nil { - yyv1889 = []FSType{} - yyc1889 = true - } - } - yyh1889.End() - if yyc1889 { - *v = yyv1889 - } -} - -func (x codecSelfer1234) encSliceHostPortRange(v []HostPortRange, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1893 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1894 := &yyv1893 - yy1894.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceHostPortRange(v *[]HostPortRange, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1895 := *v - yyh1895, yyl1895 := z.DecSliceHelperStart() - var yyc1895 bool - if yyl1895 == 0 { - if yyv1895 == nil { - yyv1895 = []HostPortRange{} - yyc1895 = true - } else if len(yyv1895) != 0 { - yyv1895 = yyv1895[:0] - yyc1895 = true - } - } else if yyl1895 > 0 { - var yyrr1895, yyrl1895 int - var yyrt1895 bool - if yyl1895 > cap(yyv1895) { - - yyrg1895 := len(yyv1895) > 0 - yyv21895 := yyv1895 - yyrl1895, yyrt1895 = z.DecInferLen(yyl1895, z.DecBasicHandle().MaxInitLen, 8) - if yyrt1895 { - if yyrl1895 <= cap(yyv1895) { - yyv1895 = yyv1895[:yyrl1895] - } else { - yyv1895 = make([]HostPortRange, yyrl1895) - } - } else { - yyv1895 = make([]HostPortRange, yyrl1895) - } - yyc1895 = true - yyrr1895 = len(yyv1895) - if yyrg1895 { - copy(yyv1895, yyv21895) - } - } else if yyl1895 != len(yyv1895) { - yyv1895 = yyv1895[:yyl1895] - yyc1895 = true - } - yyj1895 := 0 - for ; yyj1895 < yyrr1895; yyj1895++ { - yyh1895.ElemContainerState(yyj1895) - if r.TryDecodeAsNil() { - yyv1895[yyj1895] = HostPortRange{} - } else { - yyv1896 := &yyv1895[yyj1895] - yyv1896.CodecDecodeSelf(d) - } - - } - if yyrt1895 { - for ; yyj1895 < yyl1895; yyj1895++ { - yyv1895 = append(yyv1895, HostPortRange{}) - yyh1895.ElemContainerState(yyj1895) - if r.TryDecodeAsNil() { - yyv1895[yyj1895] = HostPortRange{} - } else { - yyv1897 := &yyv1895[yyj1895] - yyv1897.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1895 := 0 - for ; !r.CheckBreak(); yyj1895++ { - - if yyj1895 >= len(yyv1895) { - yyv1895 = append(yyv1895, HostPortRange{}) // var yyz1895 HostPortRange - yyc1895 = true - } - yyh1895.ElemContainerState(yyj1895) - if yyj1895 < len(yyv1895) { - if r.TryDecodeAsNil() { - yyv1895[yyj1895] = HostPortRange{} - } else { - yyv1898 := &yyv1895[yyj1895] - yyv1898.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1895 < len(yyv1895) { - yyv1895 = yyv1895[:yyj1895] - yyc1895 = true - } else if yyj1895 == 0 && yyv1895 == nil { - yyv1895 = []HostPortRange{} - yyc1895 = true - } - } - yyh1895.End() - if yyc1895 { - *v = yyv1895 - } -} - -func (x codecSelfer1234) encSliceIDRange(v []IDRange, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1899 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1900 := &yyv1899 - yy1900.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceIDRange(v *[]IDRange, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1901 := *v - yyh1901, yyl1901 := z.DecSliceHelperStart() - var yyc1901 bool - if yyl1901 == 0 { - if yyv1901 == nil { - yyv1901 = []IDRange{} - yyc1901 = true - } else if len(yyv1901) != 0 { - yyv1901 = yyv1901[:0] - yyc1901 = true - } - } else if yyl1901 > 0 { - var yyrr1901, yyrl1901 int - var yyrt1901 bool - if yyl1901 > cap(yyv1901) { - - yyrg1901 := len(yyv1901) > 0 - yyv21901 := yyv1901 - yyrl1901, yyrt1901 = z.DecInferLen(yyl1901, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1901 { - if yyrl1901 <= cap(yyv1901) { - yyv1901 = yyv1901[:yyrl1901] - } else { - yyv1901 = make([]IDRange, yyrl1901) - } - } else { - yyv1901 = make([]IDRange, yyrl1901) - } - yyc1901 = true - yyrr1901 = len(yyv1901) - if yyrg1901 { - copy(yyv1901, yyv21901) - } - } else if yyl1901 != len(yyv1901) { - yyv1901 = yyv1901[:yyl1901] - yyc1901 = true - } - yyj1901 := 0 - for ; yyj1901 < yyrr1901; yyj1901++ { - yyh1901.ElemContainerState(yyj1901) - if r.TryDecodeAsNil() { - yyv1901[yyj1901] = IDRange{} - } else { - yyv1902 := &yyv1901[yyj1901] - yyv1902.CodecDecodeSelf(d) - } - - } - if yyrt1901 { - for ; yyj1901 < yyl1901; yyj1901++ { - yyv1901 = append(yyv1901, IDRange{}) - yyh1901.ElemContainerState(yyj1901) - if r.TryDecodeAsNil() { - yyv1901[yyj1901] = IDRange{} - } else { - yyv1903 := &yyv1901[yyj1901] - yyv1903.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1901 := 0 - for ; !r.CheckBreak(); yyj1901++ { - - if yyj1901 >= len(yyv1901) { - yyv1901 = append(yyv1901, IDRange{}) // var yyz1901 IDRange - yyc1901 = true - } - yyh1901.ElemContainerState(yyj1901) - if yyj1901 < len(yyv1901) { - if r.TryDecodeAsNil() { - yyv1901[yyj1901] = IDRange{} - } else { - yyv1904 := &yyv1901[yyj1901] - yyv1904.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1901 < len(yyv1901) { - yyv1901 = yyv1901[:yyj1901] - yyc1901 = true - } else if yyj1901 == 0 && yyv1901 == nil { - yyv1901 = []IDRange{} - yyc1901 = true - } - } - yyh1901.End() - if yyc1901 { - *v = yyv1901 - } -} - -func (x codecSelfer1234) encSlicePodSecurityPolicy(v []PodSecurityPolicy, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1905 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1906 := &yyv1905 - yy1906.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSlicePodSecurityPolicy(v *[]PodSecurityPolicy, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1907 := *v - yyh1907, yyl1907 := z.DecSliceHelperStart() - var yyc1907 bool - if yyl1907 == 0 { - if yyv1907 == nil { - yyv1907 = []PodSecurityPolicy{} - yyc1907 = true - } else if len(yyv1907) != 0 { - yyv1907 = yyv1907[:0] - yyc1907 = true - } - } else if yyl1907 > 0 { - var yyrr1907, yyrl1907 int - var yyrt1907 bool - if yyl1907 > cap(yyv1907) { - - yyrg1907 := len(yyv1907) > 0 - yyv21907 := yyv1907 - yyrl1907, yyrt1907 = z.DecInferLen(yyl1907, z.DecBasicHandle().MaxInitLen, 552) - if yyrt1907 { - if yyrl1907 <= cap(yyv1907) { - yyv1907 = yyv1907[:yyrl1907] - } else { - yyv1907 = make([]PodSecurityPolicy, yyrl1907) - } - } else { - yyv1907 = make([]PodSecurityPolicy, yyrl1907) - } - yyc1907 = true - yyrr1907 = len(yyv1907) - if yyrg1907 { - copy(yyv1907, yyv21907) - } - } else if yyl1907 != len(yyv1907) { - yyv1907 = yyv1907[:yyl1907] - yyc1907 = true - } - yyj1907 := 0 - for ; yyj1907 < yyrr1907; yyj1907++ { - yyh1907.ElemContainerState(yyj1907) - if r.TryDecodeAsNil() { - yyv1907[yyj1907] = PodSecurityPolicy{} - } else { - yyv1908 := &yyv1907[yyj1907] - yyv1908.CodecDecodeSelf(d) - } - - } - if yyrt1907 { - for ; yyj1907 < yyl1907; yyj1907++ { - yyv1907 = append(yyv1907, PodSecurityPolicy{}) - yyh1907.ElemContainerState(yyj1907) - if r.TryDecodeAsNil() { - yyv1907[yyj1907] = PodSecurityPolicy{} - } else { - yyv1909 := &yyv1907[yyj1907] - yyv1909.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1907 := 0 - for ; !r.CheckBreak(); yyj1907++ { - - if yyj1907 >= len(yyv1907) { - yyv1907 = append(yyv1907, PodSecurityPolicy{}) // var yyz1907 PodSecurityPolicy - yyc1907 = true - } - yyh1907.ElemContainerState(yyj1907) - if yyj1907 < len(yyv1907) { - if r.TryDecodeAsNil() { - yyv1907[yyj1907] = PodSecurityPolicy{} - } else { - yyv1910 := &yyv1907[yyj1907] - yyv1910.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1907 < len(yyv1907) { - yyv1907 = yyv1907[:yyj1907] - yyc1907 = true - } else if yyj1907 == 0 && yyv1907 == nil { - yyv1907 = []PodSecurityPolicy{} - yyc1907 = true - } - } - yyh1907.End() - if yyc1907 { - *v = yyv1907 - } -} - -func (x codecSelfer1234) encSliceNetworkPolicyIngressRule(v []NetworkPolicyIngressRule, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1911 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1912 := &yyv1911 - yy1912.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceNetworkPolicyIngressRule(v *[]NetworkPolicyIngressRule, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1913 := *v - yyh1913, yyl1913 := z.DecSliceHelperStart() - var yyc1913 bool - if yyl1913 == 0 { - if yyv1913 == nil { - yyv1913 = []NetworkPolicyIngressRule{} - yyc1913 = true - } else if len(yyv1913) != 0 { - yyv1913 = yyv1913[:0] - yyc1913 = true - } - } else if yyl1913 > 0 { - var yyrr1913, yyrl1913 int - var yyrt1913 bool - if yyl1913 > cap(yyv1913) { - - yyrg1913 := len(yyv1913) > 0 - yyv21913 := yyv1913 - yyrl1913, yyrt1913 = z.DecInferLen(yyl1913, z.DecBasicHandle().MaxInitLen, 48) - if yyrt1913 { - if yyrl1913 <= cap(yyv1913) { - yyv1913 = yyv1913[:yyrl1913] - } else { - yyv1913 = make([]NetworkPolicyIngressRule, yyrl1913) - } - } else { - yyv1913 = make([]NetworkPolicyIngressRule, yyrl1913) - } - yyc1913 = true - yyrr1913 = len(yyv1913) - if yyrg1913 { - copy(yyv1913, yyv21913) - } - } else if yyl1913 != len(yyv1913) { - yyv1913 = yyv1913[:yyl1913] - yyc1913 = true - } - yyj1913 := 0 - for ; yyj1913 < yyrr1913; yyj1913++ { - yyh1913.ElemContainerState(yyj1913) - if r.TryDecodeAsNil() { - yyv1913[yyj1913] = NetworkPolicyIngressRule{} - } else { - yyv1914 := &yyv1913[yyj1913] - yyv1914.CodecDecodeSelf(d) - } - - } - if yyrt1913 { - for ; yyj1913 < yyl1913; yyj1913++ { - yyv1913 = append(yyv1913, NetworkPolicyIngressRule{}) - yyh1913.ElemContainerState(yyj1913) - if r.TryDecodeAsNil() { - yyv1913[yyj1913] = NetworkPolicyIngressRule{} - } else { - yyv1915 := &yyv1913[yyj1913] - yyv1915.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1913 := 0 - for ; !r.CheckBreak(); yyj1913++ { - - if yyj1913 >= len(yyv1913) { - yyv1913 = append(yyv1913, NetworkPolicyIngressRule{}) // var yyz1913 NetworkPolicyIngressRule - yyc1913 = true - } - yyh1913.ElemContainerState(yyj1913) - if yyj1913 < len(yyv1913) { - if r.TryDecodeAsNil() { - yyv1913[yyj1913] = NetworkPolicyIngressRule{} - } else { - yyv1916 := &yyv1913[yyj1913] - yyv1916.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1913 < len(yyv1913) { - yyv1913 = yyv1913[:yyj1913] - yyc1913 = true - } else if yyj1913 == 0 && yyv1913 == nil { - yyv1913 = []NetworkPolicyIngressRule{} - yyc1913 = true - } - } - yyh1913.End() - if yyc1913 { - *v = yyv1913 - } -} - -func (x codecSelfer1234) encSliceNetworkPolicyPort(v []NetworkPolicyPort, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1917 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1918 := &yyv1917 - yy1918.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceNetworkPolicyPort(v *[]NetworkPolicyPort, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1919 := *v - yyh1919, yyl1919 := z.DecSliceHelperStart() - var yyc1919 bool - if yyl1919 == 0 { - if yyv1919 == nil { - yyv1919 = []NetworkPolicyPort{} - yyc1919 = true - } else if len(yyv1919) != 0 { - yyv1919 = yyv1919[:0] - yyc1919 = true - } - } else if yyl1919 > 0 { - var yyrr1919, yyrl1919 int - var yyrt1919 bool - if yyl1919 > cap(yyv1919) { - - yyrg1919 := len(yyv1919) > 0 - yyv21919 := yyv1919 - yyrl1919, yyrt1919 = z.DecInferLen(yyl1919, z.DecBasicHandle().MaxInitLen, 16) - if yyrt1919 { - if yyrl1919 <= cap(yyv1919) { - yyv1919 = yyv1919[:yyrl1919] - } else { - yyv1919 = make([]NetworkPolicyPort, yyrl1919) - } - } else { - yyv1919 = make([]NetworkPolicyPort, yyrl1919) - } - yyc1919 = true - yyrr1919 = len(yyv1919) - if yyrg1919 { - copy(yyv1919, yyv21919) - } - } else if yyl1919 != len(yyv1919) { - yyv1919 = yyv1919[:yyl1919] - yyc1919 = true - } - yyj1919 := 0 - for ; yyj1919 < yyrr1919; yyj1919++ { - yyh1919.ElemContainerState(yyj1919) - if r.TryDecodeAsNil() { - yyv1919[yyj1919] = NetworkPolicyPort{} - } else { - yyv1920 := &yyv1919[yyj1919] - yyv1920.CodecDecodeSelf(d) - } - - } - if yyrt1919 { - for ; yyj1919 < yyl1919; yyj1919++ { - yyv1919 = append(yyv1919, NetworkPolicyPort{}) - yyh1919.ElemContainerState(yyj1919) - if r.TryDecodeAsNil() { - yyv1919[yyj1919] = NetworkPolicyPort{} - } else { - yyv1921 := &yyv1919[yyj1919] - yyv1921.CodecDecodeSelf(d) - } - - } - } - - } else { - yyj1919 := 0 - for ; !r.CheckBreak(); yyj1919++ { - - if yyj1919 >= len(yyv1919) { - yyv1919 = append(yyv1919, NetworkPolicyPort{}) // var yyz1919 NetworkPolicyPort - yyc1919 = true - } - yyh1919.ElemContainerState(yyj1919) - if yyj1919 < len(yyv1919) { - if r.TryDecodeAsNil() { - yyv1919[yyj1919] = NetworkPolicyPort{} - } else { - yyv1922 := &yyv1919[yyj1919] - yyv1922.CodecDecodeSelf(d) - } - - } else { - z.DecSwallow() - } - - } - if yyj1919 < len(yyv1919) { - yyv1919 = yyv1919[:yyj1919] - yyc1919 = true - } else if yyj1919 == 0 && yyv1919 == nil { - yyv1919 = []NetworkPolicyPort{} - yyc1919 = true - } - } - yyh1919.End() - if yyc1919 { - *v = yyv1919 - } -} - -func (x codecSelfer1234) encSliceNetworkPolicyPeer(v []NetworkPolicyPeer, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeArrayStart(len(v)) - for _, yyv1923 := range v { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1924 := &yyv1923 - yy1924.CodecEncodeSelf(e) - } - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yyv1925 := *v yyh1925, yyl1925 := z.DecSliceHelperStart() var yyc1925 bool if yyl1925 == 0 { if yyv1925 == nil { - yyv1925 = []NetworkPolicyPeer{} + yyv1925 = []FSType{} yyc1925 = true } else if len(yyv1925) != 0 { yyv1925 = yyv1925[:0] @@ -24053,23 +23534,18 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co var yyrt1925 bool if yyl1925 > cap(yyv1925) { - yyrg1925 := len(yyv1925) > 0 - yyv21925 := yyv1925 yyrl1925, yyrt1925 = z.DecInferLen(yyl1925, z.DecBasicHandle().MaxInitLen, 16) if yyrt1925 { if yyrl1925 <= cap(yyv1925) { yyv1925 = yyv1925[:yyrl1925] } else { - yyv1925 = make([]NetworkPolicyPeer, yyrl1925) + yyv1925 = make([]FSType, yyrl1925) } } else { - yyv1925 = make([]NetworkPolicyPeer, yyrl1925) + yyv1925 = make([]FSType, yyrl1925) } yyc1925 = true yyrr1925 = len(yyv1925) - if yyrg1925 { - copy(yyv1925, yyv21925) - } } else if yyl1925 != len(yyv1925) { yyv1925 = yyv1925[:yyl1925] yyc1925 = true @@ -24078,22 +23554,20 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co for ; yyj1925 < yyrr1925; yyj1925++ { yyh1925.ElemContainerState(yyj1925) if r.TryDecodeAsNil() { - yyv1925[yyj1925] = NetworkPolicyPeer{} + yyv1925[yyj1925] = "" } else { - yyv1926 := &yyv1925[yyj1925] - yyv1926.CodecDecodeSelf(d) + yyv1925[yyj1925] = FSType(r.DecodeString()) } } if yyrt1925 { for ; yyj1925 < yyl1925; yyj1925++ { - yyv1925 = append(yyv1925, NetworkPolicyPeer{}) + yyv1925 = append(yyv1925, "") yyh1925.ElemContainerState(yyj1925) if r.TryDecodeAsNil() { - yyv1925[yyj1925] = NetworkPolicyPeer{} + yyv1925[yyj1925] = "" } else { - yyv1927 := &yyv1925[yyj1925] - yyv1927.CodecDecodeSelf(d) + yyv1925[yyj1925] = FSType(r.DecodeString()) } } @@ -24104,16 +23578,15 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co for ; !r.CheckBreak(); yyj1925++ { if yyj1925 >= len(yyv1925) { - yyv1925 = append(yyv1925, NetworkPolicyPeer{}) // var yyz1925 NetworkPolicyPeer + yyv1925 = append(yyv1925, "") // var yyz1925 FSType yyc1925 = true } yyh1925.ElemContainerState(yyj1925) if yyj1925 < len(yyv1925) { if r.TryDecodeAsNil() { - yyv1925[yyj1925] = NetworkPolicyPeer{} + yyv1925[yyj1925] = "" } else { - yyv1928 := &yyv1925[yyj1925] - yyv1928.CodecDecodeSelf(d) + yyv1925[yyj1925] = FSType(r.DecodeString()) } } else { @@ -24125,7 +23598,7 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co yyv1925 = yyv1925[:yyj1925] yyc1925 = true } else if yyj1925 == 0 && yyv1925 == nil { - yyv1925 = []NetworkPolicyPeer{} + yyv1925 = []FSType{} yyc1925 = true } } @@ -24135,7 +23608,7 @@ func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *co } } -func (x codecSelfer1234) encSliceNetworkPolicy(v []NetworkPolicy, e *codec1978.Encoder) { +func (x codecSelfer1234) encSliceHostPortRange(v []HostPortRange, e *codec1978.Encoder) { var h codecSelfer1234 z, r := codec1978.GenHelperEncoder(e) _, _, _ = h, z, r @@ -24148,7 +23621,7 @@ func (x codecSelfer1234) encSliceNetworkPolicy(v []NetworkPolicy, e *codec1978.E z.EncSendContainerState(codecSelfer_containerArrayEnd1234) } -func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978.Decoder) { +func (x codecSelfer1234) decSliceHostPortRange(v *[]HostPortRange, d *codec1978.Decoder) { var h codecSelfer1234 z, r := codec1978.GenHelperDecoder(d) _, _, _ = h, z, r @@ -24158,7 +23631,7 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. var yyc1931 bool if yyl1931 == 0 { if yyv1931 == nil { - yyv1931 = []NetworkPolicy{} + yyv1931 = []HostPortRange{} yyc1931 = true } else if len(yyv1931) != 0 { yyv1931 = yyv1931[:0] @@ -24171,15 +23644,15 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. yyrg1931 := len(yyv1931) > 0 yyv21931 := yyv1931 - yyrl1931, yyrt1931 = z.DecInferLen(yyl1931, z.DecBasicHandle().MaxInitLen, 312) + yyrl1931, yyrt1931 = z.DecInferLen(yyl1931, z.DecBasicHandle().MaxInitLen, 8) if yyrt1931 { if yyrl1931 <= cap(yyv1931) { yyv1931 = yyv1931[:yyrl1931] } else { - yyv1931 = make([]NetworkPolicy, yyrl1931) + yyv1931 = make([]HostPortRange, yyrl1931) } } else { - yyv1931 = make([]NetworkPolicy, yyrl1931) + yyv1931 = make([]HostPortRange, yyrl1931) } yyc1931 = true yyrr1931 = len(yyv1931) @@ -24194,7 +23667,7 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. for ; yyj1931 < yyrr1931; yyj1931++ { yyh1931.ElemContainerState(yyj1931) if r.TryDecodeAsNil() { - yyv1931[yyj1931] = NetworkPolicy{} + yyv1931[yyj1931] = HostPortRange{} } else { yyv1932 := &yyv1931[yyj1931] yyv1932.CodecDecodeSelf(d) @@ -24203,10 +23676,10 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. } if yyrt1931 { for ; yyj1931 < yyl1931; yyj1931++ { - yyv1931 = append(yyv1931, NetworkPolicy{}) + yyv1931 = append(yyv1931, HostPortRange{}) yyh1931.ElemContainerState(yyj1931) if r.TryDecodeAsNil() { - yyv1931[yyj1931] = NetworkPolicy{} + yyv1931[yyj1931] = HostPortRange{} } else { yyv1933 := &yyv1931[yyj1931] yyv1933.CodecDecodeSelf(d) @@ -24220,13 +23693,13 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. for ; !r.CheckBreak(); yyj1931++ { if yyj1931 >= len(yyv1931) { - yyv1931 = append(yyv1931, NetworkPolicy{}) // var yyz1931 NetworkPolicy + yyv1931 = append(yyv1931, HostPortRange{}) // var yyz1931 HostPortRange yyc1931 = true } yyh1931.ElemContainerState(yyj1931) if yyj1931 < len(yyv1931) { if r.TryDecodeAsNil() { - yyv1931[yyj1931] = NetworkPolicy{} + yyv1931[yyj1931] = HostPortRange{} } else { yyv1934 := &yyv1931[yyj1931] yyv1934.CodecDecodeSelf(d) @@ -24241,7 +23714,7 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. yyv1931 = yyv1931[:yyj1931] yyc1931 = true } else if yyj1931 == 0 && yyv1931 == nil { - yyv1931 = []NetworkPolicy{} + yyv1931 = []HostPortRange{} yyc1931 = true } } @@ -24250,3 +23723,699 @@ func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978. *v = yyv1931 } } + +func (x codecSelfer1234) encSliceIDRange(v []IDRange, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1935 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1936 := &yyv1935 + yy1936.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceIDRange(v *[]IDRange, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1937 := *v + yyh1937, yyl1937 := z.DecSliceHelperStart() + var yyc1937 bool + if yyl1937 == 0 { + if yyv1937 == nil { + yyv1937 = []IDRange{} + yyc1937 = true + } else if len(yyv1937) != 0 { + yyv1937 = yyv1937[:0] + yyc1937 = true + } + } else if yyl1937 > 0 { + var yyrr1937, yyrl1937 int + var yyrt1937 bool + if yyl1937 > cap(yyv1937) { + + yyrg1937 := len(yyv1937) > 0 + yyv21937 := yyv1937 + yyrl1937, yyrt1937 = z.DecInferLen(yyl1937, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1937 { + if yyrl1937 <= cap(yyv1937) { + yyv1937 = yyv1937[:yyrl1937] + } else { + yyv1937 = make([]IDRange, yyrl1937) + } + } else { + yyv1937 = make([]IDRange, yyrl1937) + } + yyc1937 = true + yyrr1937 = len(yyv1937) + if yyrg1937 { + copy(yyv1937, yyv21937) + } + } else if yyl1937 != len(yyv1937) { + yyv1937 = yyv1937[:yyl1937] + yyc1937 = true + } + yyj1937 := 0 + for ; yyj1937 < yyrr1937; yyj1937++ { + yyh1937.ElemContainerState(yyj1937) + if r.TryDecodeAsNil() { + yyv1937[yyj1937] = IDRange{} + } else { + yyv1938 := &yyv1937[yyj1937] + yyv1938.CodecDecodeSelf(d) + } + + } + if yyrt1937 { + for ; yyj1937 < yyl1937; yyj1937++ { + yyv1937 = append(yyv1937, IDRange{}) + yyh1937.ElemContainerState(yyj1937) + if r.TryDecodeAsNil() { + yyv1937[yyj1937] = IDRange{} + } else { + yyv1939 := &yyv1937[yyj1937] + yyv1939.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1937 := 0 + for ; !r.CheckBreak(); yyj1937++ { + + if yyj1937 >= len(yyv1937) { + yyv1937 = append(yyv1937, IDRange{}) // var yyz1937 IDRange + yyc1937 = true + } + yyh1937.ElemContainerState(yyj1937) + if yyj1937 < len(yyv1937) { + if r.TryDecodeAsNil() { + yyv1937[yyj1937] = IDRange{} + } else { + yyv1940 := &yyv1937[yyj1937] + yyv1940.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1937 < len(yyv1937) { + yyv1937 = yyv1937[:yyj1937] + yyc1937 = true + } else if yyj1937 == 0 && yyv1937 == nil { + yyv1937 = []IDRange{} + yyc1937 = true + } + } + yyh1937.End() + if yyc1937 { + *v = yyv1937 + } +} + +func (x codecSelfer1234) encSlicePodSecurityPolicy(v []PodSecurityPolicy, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1941 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1942 := &yyv1941 + yy1942.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSlicePodSecurityPolicy(v *[]PodSecurityPolicy, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1943 := *v + yyh1943, yyl1943 := z.DecSliceHelperStart() + var yyc1943 bool + if yyl1943 == 0 { + if yyv1943 == nil { + yyv1943 = []PodSecurityPolicy{} + yyc1943 = true + } else if len(yyv1943) != 0 { + yyv1943 = yyv1943[:0] + yyc1943 = true + } + } else if yyl1943 > 0 { + var yyrr1943, yyrl1943 int + var yyrt1943 bool + if yyl1943 > cap(yyv1943) { + + yyrg1943 := len(yyv1943) > 0 + yyv21943 := yyv1943 + yyrl1943, yyrt1943 = z.DecInferLen(yyl1943, z.DecBasicHandle().MaxInitLen, 552) + if yyrt1943 { + if yyrl1943 <= cap(yyv1943) { + yyv1943 = yyv1943[:yyrl1943] + } else { + yyv1943 = make([]PodSecurityPolicy, yyrl1943) + } + } else { + yyv1943 = make([]PodSecurityPolicy, yyrl1943) + } + yyc1943 = true + yyrr1943 = len(yyv1943) + if yyrg1943 { + copy(yyv1943, yyv21943) + } + } else if yyl1943 != len(yyv1943) { + yyv1943 = yyv1943[:yyl1943] + yyc1943 = true + } + yyj1943 := 0 + for ; yyj1943 < yyrr1943; yyj1943++ { + yyh1943.ElemContainerState(yyj1943) + if r.TryDecodeAsNil() { + yyv1943[yyj1943] = PodSecurityPolicy{} + } else { + yyv1944 := &yyv1943[yyj1943] + yyv1944.CodecDecodeSelf(d) + } + + } + if yyrt1943 { + for ; yyj1943 < yyl1943; yyj1943++ { + yyv1943 = append(yyv1943, PodSecurityPolicy{}) + yyh1943.ElemContainerState(yyj1943) + if r.TryDecodeAsNil() { + yyv1943[yyj1943] = PodSecurityPolicy{} + } else { + yyv1945 := &yyv1943[yyj1943] + yyv1945.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1943 := 0 + for ; !r.CheckBreak(); yyj1943++ { + + if yyj1943 >= len(yyv1943) { + yyv1943 = append(yyv1943, PodSecurityPolicy{}) // var yyz1943 PodSecurityPolicy + yyc1943 = true + } + yyh1943.ElemContainerState(yyj1943) + if yyj1943 < len(yyv1943) { + if r.TryDecodeAsNil() { + yyv1943[yyj1943] = PodSecurityPolicy{} + } else { + yyv1946 := &yyv1943[yyj1943] + yyv1946.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1943 < len(yyv1943) { + yyv1943 = yyv1943[:yyj1943] + yyc1943 = true + } else if yyj1943 == 0 && yyv1943 == nil { + yyv1943 = []PodSecurityPolicy{} + yyc1943 = true + } + } + yyh1943.End() + if yyc1943 { + *v = yyv1943 + } +} + +func (x codecSelfer1234) encSliceNetworkPolicyIngressRule(v []NetworkPolicyIngressRule, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1947 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1948 := &yyv1947 + yy1948.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceNetworkPolicyIngressRule(v *[]NetworkPolicyIngressRule, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1949 := *v + yyh1949, yyl1949 := z.DecSliceHelperStart() + var yyc1949 bool + if yyl1949 == 0 { + if yyv1949 == nil { + yyv1949 = []NetworkPolicyIngressRule{} + yyc1949 = true + } else if len(yyv1949) != 0 { + yyv1949 = yyv1949[:0] + yyc1949 = true + } + } else if yyl1949 > 0 { + var yyrr1949, yyrl1949 int + var yyrt1949 bool + if yyl1949 > cap(yyv1949) { + + yyrg1949 := len(yyv1949) > 0 + yyv21949 := yyv1949 + yyrl1949, yyrt1949 = z.DecInferLen(yyl1949, z.DecBasicHandle().MaxInitLen, 48) + if yyrt1949 { + if yyrl1949 <= cap(yyv1949) { + yyv1949 = yyv1949[:yyrl1949] + } else { + yyv1949 = make([]NetworkPolicyIngressRule, yyrl1949) + } + } else { + yyv1949 = make([]NetworkPolicyIngressRule, yyrl1949) + } + yyc1949 = true + yyrr1949 = len(yyv1949) + if yyrg1949 { + copy(yyv1949, yyv21949) + } + } else if yyl1949 != len(yyv1949) { + yyv1949 = yyv1949[:yyl1949] + yyc1949 = true + } + yyj1949 := 0 + for ; yyj1949 < yyrr1949; yyj1949++ { + yyh1949.ElemContainerState(yyj1949) + if r.TryDecodeAsNil() { + yyv1949[yyj1949] = NetworkPolicyIngressRule{} + } else { + yyv1950 := &yyv1949[yyj1949] + yyv1950.CodecDecodeSelf(d) + } + + } + if yyrt1949 { + for ; yyj1949 < yyl1949; yyj1949++ { + yyv1949 = append(yyv1949, NetworkPolicyIngressRule{}) + yyh1949.ElemContainerState(yyj1949) + if r.TryDecodeAsNil() { + yyv1949[yyj1949] = NetworkPolicyIngressRule{} + } else { + yyv1951 := &yyv1949[yyj1949] + yyv1951.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1949 := 0 + for ; !r.CheckBreak(); yyj1949++ { + + if yyj1949 >= len(yyv1949) { + yyv1949 = append(yyv1949, NetworkPolicyIngressRule{}) // var yyz1949 NetworkPolicyIngressRule + yyc1949 = true + } + yyh1949.ElemContainerState(yyj1949) + if yyj1949 < len(yyv1949) { + if r.TryDecodeAsNil() { + yyv1949[yyj1949] = NetworkPolicyIngressRule{} + } else { + yyv1952 := &yyv1949[yyj1949] + yyv1952.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1949 < len(yyv1949) { + yyv1949 = yyv1949[:yyj1949] + yyc1949 = true + } else if yyj1949 == 0 && yyv1949 == nil { + yyv1949 = []NetworkPolicyIngressRule{} + yyc1949 = true + } + } + yyh1949.End() + if yyc1949 { + *v = yyv1949 + } +} + +func (x codecSelfer1234) encSliceNetworkPolicyPort(v []NetworkPolicyPort, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1953 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1954 := &yyv1953 + yy1954.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceNetworkPolicyPort(v *[]NetworkPolicyPort, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1955 := *v + yyh1955, yyl1955 := z.DecSliceHelperStart() + var yyc1955 bool + if yyl1955 == 0 { + if yyv1955 == nil { + yyv1955 = []NetworkPolicyPort{} + yyc1955 = true + } else if len(yyv1955) != 0 { + yyv1955 = yyv1955[:0] + yyc1955 = true + } + } else if yyl1955 > 0 { + var yyrr1955, yyrl1955 int + var yyrt1955 bool + if yyl1955 > cap(yyv1955) { + + yyrg1955 := len(yyv1955) > 0 + yyv21955 := yyv1955 + yyrl1955, yyrt1955 = z.DecInferLen(yyl1955, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1955 { + if yyrl1955 <= cap(yyv1955) { + yyv1955 = yyv1955[:yyrl1955] + } else { + yyv1955 = make([]NetworkPolicyPort, yyrl1955) + } + } else { + yyv1955 = make([]NetworkPolicyPort, yyrl1955) + } + yyc1955 = true + yyrr1955 = len(yyv1955) + if yyrg1955 { + copy(yyv1955, yyv21955) + } + } else if yyl1955 != len(yyv1955) { + yyv1955 = yyv1955[:yyl1955] + yyc1955 = true + } + yyj1955 := 0 + for ; yyj1955 < yyrr1955; yyj1955++ { + yyh1955.ElemContainerState(yyj1955) + if r.TryDecodeAsNil() { + yyv1955[yyj1955] = NetworkPolicyPort{} + } else { + yyv1956 := &yyv1955[yyj1955] + yyv1956.CodecDecodeSelf(d) + } + + } + if yyrt1955 { + for ; yyj1955 < yyl1955; yyj1955++ { + yyv1955 = append(yyv1955, NetworkPolicyPort{}) + yyh1955.ElemContainerState(yyj1955) + if r.TryDecodeAsNil() { + yyv1955[yyj1955] = NetworkPolicyPort{} + } else { + yyv1957 := &yyv1955[yyj1955] + yyv1957.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1955 := 0 + for ; !r.CheckBreak(); yyj1955++ { + + if yyj1955 >= len(yyv1955) { + yyv1955 = append(yyv1955, NetworkPolicyPort{}) // var yyz1955 NetworkPolicyPort + yyc1955 = true + } + yyh1955.ElemContainerState(yyj1955) + if yyj1955 < len(yyv1955) { + if r.TryDecodeAsNil() { + yyv1955[yyj1955] = NetworkPolicyPort{} + } else { + yyv1958 := &yyv1955[yyj1955] + yyv1958.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1955 < len(yyv1955) { + yyv1955 = yyv1955[:yyj1955] + yyc1955 = true + } else if yyj1955 == 0 && yyv1955 == nil { + yyv1955 = []NetworkPolicyPort{} + yyc1955 = true + } + } + yyh1955.End() + if yyc1955 { + *v = yyv1955 + } +} + +func (x codecSelfer1234) encSliceNetworkPolicyPeer(v []NetworkPolicyPeer, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1959 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1960 := &yyv1959 + yy1960.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceNetworkPolicyPeer(v *[]NetworkPolicyPeer, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1961 := *v + yyh1961, yyl1961 := z.DecSliceHelperStart() + var yyc1961 bool + if yyl1961 == 0 { + if yyv1961 == nil { + yyv1961 = []NetworkPolicyPeer{} + yyc1961 = true + } else if len(yyv1961) != 0 { + yyv1961 = yyv1961[:0] + yyc1961 = true + } + } else if yyl1961 > 0 { + var yyrr1961, yyrl1961 int + var yyrt1961 bool + if yyl1961 > cap(yyv1961) { + + yyrg1961 := len(yyv1961) > 0 + yyv21961 := yyv1961 + yyrl1961, yyrt1961 = z.DecInferLen(yyl1961, z.DecBasicHandle().MaxInitLen, 16) + if yyrt1961 { + if yyrl1961 <= cap(yyv1961) { + yyv1961 = yyv1961[:yyrl1961] + } else { + yyv1961 = make([]NetworkPolicyPeer, yyrl1961) + } + } else { + yyv1961 = make([]NetworkPolicyPeer, yyrl1961) + } + yyc1961 = true + yyrr1961 = len(yyv1961) + if yyrg1961 { + copy(yyv1961, yyv21961) + } + } else if yyl1961 != len(yyv1961) { + yyv1961 = yyv1961[:yyl1961] + yyc1961 = true + } + yyj1961 := 0 + for ; yyj1961 < yyrr1961; yyj1961++ { + yyh1961.ElemContainerState(yyj1961) + if r.TryDecodeAsNil() { + yyv1961[yyj1961] = NetworkPolicyPeer{} + } else { + yyv1962 := &yyv1961[yyj1961] + yyv1962.CodecDecodeSelf(d) + } + + } + if yyrt1961 { + for ; yyj1961 < yyl1961; yyj1961++ { + yyv1961 = append(yyv1961, NetworkPolicyPeer{}) + yyh1961.ElemContainerState(yyj1961) + if r.TryDecodeAsNil() { + yyv1961[yyj1961] = NetworkPolicyPeer{} + } else { + yyv1963 := &yyv1961[yyj1961] + yyv1963.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1961 := 0 + for ; !r.CheckBreak(); yyj1961++ { + + if yyj1961 >= len(yyv1961) { + yyv1961 = append(yyv1961, NetworkPolicyPeer{}) // var yyz1961 NetworkPolicyPeer + yyc1961 = true + } + yyh1961.ElemContainerState(yyj1961) + if yyj1961 < len(yyv1961) { + if r.TryDecodeAsNil() { + yyv1961[yyj1961] = NetworkPolicyPeer{} + } else { + yyv1964 := &yyv1961[yyj1961] + yyv1964.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1961 < len(yyv1961) { + yyv1961 = yyv1961[:yyj1961] + yyc1961 = true + } else if yyj1961 == 0 && yyv1961 == nil { + yyv1961 = []NetworkPolicyPeer{} + yyc1961 = true + } + } + yyh1961.End() + if yyc1961 { + *v = yyv1961 + } +} + +func (x codecSelfer1234) encSliceNetworkPolicy(v []NetworkPolicy, e *codec1978.Encoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperEncoder(e) + _, _, _ = h, z, r + r.EncodeArrayStart(len(v)) + for _, yyv1965 := range v { + z.EncSendContainerState(codecSelfer_containerArrayElem1234) + yy1966 := &yyv1965 + yy1966.CodecEncodeSelf(e) + } + z.EncSendContainerState(codecSelfer_containerArrayEnd1234) +} + +func (x codecSelfer1234) decSliceNetworkPolicy(v *[]NetworkPolicy, d *codec1978.Decoder) { + var h codecSelfer1234 + z, r := codec1978.GenHelperDecoder(d) + _, _, _ = h, z, r + + yyv1967 := *v + yyh1967, yyl1967 := z.DecSliceHelperStart() + var yyc1967 bool + if yyl1967 == 0 { + if yyv1967 == nil { + yyv1967 = []NetworkPolicy{} + yyc1967 = true + } else if len(yyv1967) != 0 { + yyv1967 = yyv1967[:0] + yyc1967 = true + } + } else if yyl1967 > 0 { + var yyrr1967, yyrl1967 int + var yyrt1967 bool + if yyl1967 > cap(yyv1967) { + + yyrg1967 := len(yyv1967) > 0 + yyv21967 := yyv1967 + yyrl1967, yyrt1967 = z.DecInferLen(yyl1967, z.DecBasicHandle().MaxInitLen, 312) + if yyrt1967 { + if yyrl1967 <= cap(yyv1967) { + yyv1967 = yyv1967[:yyrl1967] + } else { + yyv1967 = make([]NetworkPolicy, yyrl1967) + } + } else { + yyv1967 = make([]NetworkPolicy, yyrl1967) + } + yyc1967 = true + yyrr1967 = len(yyv1967) + if yyrg1967 { + copy(yyv1967, yyv21967) + } + } else if yyl1967 != len(yyv1967) { + yyv1967 = yyv1967[:yyl1967] + yyc1967 = true + } + yyj1967 := 0 + for ; yyj1967 < yyrr1967; yyj1967++ { + yyh1967.ElemContainerState(yyj1967) + if r.TryDecodeAsNil() { + yyv1967[yyj1967] = NetworkPolicy{} + } else { + yyv1968 := &yyv1967[yyj1967] + yyv1968.CodecDecodeSelf(d) + } + + } + if yyrt1967 { + for ; yyj1967 < yyl1967; yyj1967++ { + yyv1967 = append(yyv1967, NetworkPolicy{}) + yyh1967.ElemContainerState(yyj1967) + if r.TryDecodeAsNil() { + yyv1967[yyj1967] = NetworkPolicy{} + } else { + yyv1969 := &yyv1967[yyj1967] + yyv1969.CodecDecodeSelf(d) + } + + } + } + + } else { + yyj1967 := 0 + for ; !r.CheckBreak(); yyj1967++ { + + if yyj1967 >= len(yyv1967) { + yyv1967 = append(yyv1967, NetworkPolicy{}) // var yyz1967 NetworkPolicy + yyc1967 = true + } + yyh1967.ElemContainerState(yyj1967) + if yyj1967 < len(yyv1967) { + if r.TryDecodeAsNil() { + yyv1967[yyj1967] = NetworkPolicy{} + } else { + yyv1970 := &yyv1967[yyj1967] + yyv1970.CodecDecodeSelf(d) + } + + } else { + z.DecSwallow() + } + + } + if yyj1967 < len(yyv1967) { + yyv1967 = yyv1967[:yyj1967] + yyc1967 = true + } else if yyj1967 == 0 && yyv1967 == nil { + yyv1967 = []NetworkPolicy{} + yyc1967 = true + } + } + yyh1967.End() + if yyc1967 { + *v = yyv1967 + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.go index da64903..5bf73da 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types.go @@ -17,15 +17,16 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api/resource" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/util/intstr" ) // describes the attributes of a scale subresource type ScaleSpec struct { // desired number of instances for the scaled object. + // +optional Replicas int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` } @@ -35,6 +36,7 @@ type ScaleStatus struct { Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` // label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional Selector map[string]string `json:"selector,omitempty" protobuf:"bytes,2,rep,name=selector"` // label selector for pods that should match the replicas count. This is a serializated @@ -43,6 +45,7 @@ type ScaleStatus struct { // query-param syntax. If the target type only supports map-based selectors, both this // field and map-based selector field are populated. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors + // +optional TargetSelector string `json:"targetSelector,omitempty" protobuf:"bytes,3,opt,name=targetSelector"` } @@ -53,12 +56,15 @@ type ScaleStatus struct { type Scale struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // defines the behavior of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec ScaleSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // current status of the scale. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. Read-only. + // +optional Status ScaleStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -70,12 +76,16 @@ type ReplicationControllerDummy struct { // SubresourceReference contains enough information to let you inspect or modify the referred subresource. type SubresourceReference struct { // Kind of the referent; More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names + // +optional Name string `json:"name,omitempty" protobuf:"bytes,2,opt,name=name"` // API version of the referent + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` // Subresource name of the referent + // +optional Subresource string `json:"subresource,omitempty" protobuf:"bytes,4,opt,name=subresource"` } @@ -114,21 +124,25 @@ type HorizontalPodAutoscalerSpec struct { // and will set the desired number of pods by modifying its spec. ScaleRef SubresourceReference `json:"scaleRef" protobuf:"bytes,1,opt,name=scaleRef"` // lower limit for the number of pods that can be set by the autoscaler, default 1. + // +optional MinReplicas *int32 `json:"minReplicas,omitempty" protobuf:"varint,2,opt,name=minReplicas"` // upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. MaxReplicas int32 `json:"maxReplicas" protobuf:"varint,3,opt,name=maxReplicas"` // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; // if not specified it defaults to the target CPU utilization at 80% of the requested resources. + // +optional CPUUtilization *CPUTargetUtilization `json:"cpuUtilization,omitempty" protobuf:"bytes,4,opt,name=cpuUtilization"` } // current status of a horizontal pod autoscaler type HorizontalPodAutoscalerStatus struct { // most recent generation observed by this autoscaler. + // +optional ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` // last time the HorizontalPodAutoscaler scaled the number of pods; // used by the autoscaler to control how often the number of pods is changed. + // +optional LastScaleTime *unversioned.Time `json:"lastScaleTime,omitempty" protobuf:"bytes,2,opt,name=lastScaleTime"` // current number of replicas of pods managed by this autoscaler. @@ -139,6 +153,7 @@ type HorizontalPodAutoscalerStatus struct { // current average CPU utilization over all pods, represented as a percentage of requested CPU, // e.g. 70 means that an average pod is using now 70% of its requested CPU. + // +optional CurrentCPUUtilizationPercentage *int32 `json:"currentCPUUtilizationPercentage,omitempty" protobuf:"varint,5,opt,name=currentCPUUtilizationPercentage"` } @@ -146,12 +161,15 @@ type HorizontalPodAutoscalerStatus struct { type HorizontalPodAutoscaler struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // behaviour of autoscaler. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status. + // +optional Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // current information about the autoscaler. + // +optional Status HorizontalPodAutoscalerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -159,6 +177,7 @@ type HorizontalPodAutoscaler struct { type HorizontalPodAutoscalerList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // list of horizontal pod autoscaler objects. @@ -174,12 +193,15 @@ type ThirdPartyResource struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Description is the description of this object. + // +optional Description string `json:"description,omitempty" protobuf:"bytes,2,opt,name=description"` // Versions are versions for this third party object + // +optional Versions []APIVersion `json:"versions,omitempty" protobuf:"bytes,3,rep,name=versions"` } @@ -188,6 +210,7 @@ type ThirdPartyResourceList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of ThirdPartyResources. @@ -197,6 +220,7 @@ type ThirdPartyResourceList struct { // An APIVersion represents a single concrete version of an object model. type APIVersion struct { // Name of this version (e.g. 'v1'). + // +optional Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` } @@ -204,9 +228,11 @@ type APIVersion struct { type ThirdPartyResourceData struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Data is the raw JSON data for this data. + // +optional Data []byte `json:"data,omitempty" protobuf:"bytes,2,opt,name=data"` } @@ -216,12 +242,15 @@ type ThirdPartyResourceData struct { type Deployment struct { unversioned.TypeMeta `json:",inline"` // Standard object metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior of the Deployment. + // +optional Spec DeploymentSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Most recently observed status of the Deployment. + // +optional Status DeploymentStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -229,32 +258,49 @@ type Deployment struct { type DeploymentSpec struct { // Number of desired pods. This is a pointer to distinguish between explicit // zero and not specified. Defaults to 1. + // +optional Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` // Label selector for pods. Existing ReplicaSets whose pods are // selected by this will be the ones affected by this deployment. - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` // Template describes the pods that will be created. Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` // The deployment strategy to use to replace existing pods with new ones. + // +optional Strategy DeploymentStrategy `json:"strategy,omitempty" protobuf:"bytes,4,opt,name=strategy"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,5,opt,name=minReadySeconds"` // The number of old ReplicaSets to retain to allow rollback. // This is a pointer to distinguish between explicit zero and not specified. + // +optional RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` // Indicates that the deployment is paused and will not be processed by the // deployment controller. + // +optional Paused bool `json:"paused,omitempty" protobuf:"varint,7,opt,name=paused"` + // The config this deployment is rolling back to. Will be cleared after rollback is done. + // +optional RollbackTo *RollbackConfig `json:"rollbackTo,omitempty" protobuf:"bytes,8,opt,name=rollbackTo"` + + // The maximum time in seconds for a deployment to make progress before it + // is considered to be failed. The deployment controller will continue to + // process failed deployments and a condition with a ProgressDeadlineExceeded + // reason will be surfaced in the deployment status. Once autoRollback is + // implemented, the deployment controller will automatically rollback failed + // deployments. Note that progress will not be estimated during the time a + // deployment is paused. This is not set by default. + ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty"` } // DeploymentRollback stores the information required to rollback a deployment. @@ -263,6 +309,7 @@ type DeploymentRollback struct { // Required: This must match the Name of a deployment. Name string `json:"name" protobuf:"bytes,1,opt,name=name"` // The annotations to be updated to a deployment + // +optional UpdatedAnnotations map[string]string `json:"updatedAnnotations,omitempty" protobuf:"bytes,2,rep,name=updatedAnnotations"` // The config of this deployment rollback. RollbackTo RollbackConfig `json:"rollbackTo" protobuf:"bytes,3,opt,name=rollbackTo"` @@ -270,6 +317,7 @@ type DeploymentRollback struct { type RollbackConfig struct { // The revision to rollback to. If set to 0, rollbck to the last revision. + // +optional Revision int64 `json:"revision,omitempty" protobuf:"varint,1,opt,name=revision"` } @@ -283,6 +331,7 @@ const ( // DeploymentStrategy describes how to replace existing pods with new ones. type DeploymentStrategy struct { // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. + // +optional Type DeploymentStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=DeploymentStrategyType"` // Rolling update config params. Present only if DeploymentStrategyType = @@ -290,6 +339,7 @@ type DeploymentStrategy struct { //--- // TODO: Update this to follow our convention for oneOf, whatever we decide it // to be. + // +optional RollingUpdate *RollingUpdateDeployment `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` } @@ -315,6 +365,7 @@ type RollingUpdateDeployment struct { // can be scaled down further, followed by scaling up the new RC, ensuring // that the total number of pods available at all times during the update is at // least 70% of desired pods. + // +optional MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` // The maximum number of pods that can be scheduled above the desired number of @@ -328,31 +379,74 @@ type RollingUpdateDeployment struct { // 130% of desired pods. Once old pods have been killed, // new RC can be scaled up further, ensuring that total number of pods running // at any time during the update is atmost 130% of desired pods. + // +optional MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty" protobuf:"bytes,2,opt,name=maxSurge"` } // DeploymentStatus is the most recently observed status of the Deployment. type DeploymentStatus struct { // The generation observed by the deployment controller. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` // Total number of non-terminated pods targeted by this deployment (their labels match the selector). + // +optional Replicas int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` // Total number of non-terminated pods targeted by this deployment that have the desired template spec. + // +optional UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,3,opt,name=updatedReplicas"` // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,4,opt,name=availableReplicas"` // Total number of unavailable pods targeted by this deployment. + // +optional UnavailableReplicas int32 `json:"unavailableReplicas,omitempty" protobuf:"varint,5,opt,name=unavailableReplicas"` + + // Represents the latest available observations of a deployment's current state. + Conditions []DeploymentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` +} + +type DeploymentConditionType string + +// These are valid conditions of a deployment. +const ( + // Available means the deployment is available, ie. at least the minimum available + // replicas required are up and running for at least minReadySeconds. + DeploymentAvailable DeploymentConditionType = "Available" + // Progressing means the deployment is progressing. Progress for a deployment is + // considered when a new replica set is created or adopted, and when new pods scale + // up or old pods scale down. Progress is not estimated for paused deployments or + // when progressDeadlineSeconds is not specified. + DeploymentProgressing DeploymentConditionType = "Progressing" + // ReplicaFailure is added in a deployment when one of its pods fails to be created + // or deleted. + DeploymentReplicaFailure DeploymentConditionType = "ReplicaFailure" +) + +// DeploymentCondition describes the state of a deployment at a certain point. +type DeploymentCondition struct { + // Type of deployment condition. + Type DeploymentConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DeploymentConditionType"` + // Status of the condition, one of True, False, Unknown. + Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/kubernetes/pkg/api/v1.ConditionStatus"` + // The last time this condition was updated. + LastUpdateTime unversioned.Time `json:"lastUpdateTime,omitempty"` + // Last time the condition transitioned from one status to another. + LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` + // The reason for the condition's last transition. + Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` + // A human readable message indicating details about the transition. + Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` } // DeploymentList is a list of Deployments. type DeploymentList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Deployments. @@ -363,6 +457,7 @@ type DeploymentList struct { /* Commenting out for v1.2. We are planning to bring these types back with a more robust DaemonSet update implementation in v1.3, hence not deleting but just commenting the types out. type DaemonSetUpdateStrategy struct { // Type of daemon set update. Only "RollingUpdate" is supported at this time. Default is RollingUpdate. +// +optional Type DaemonSetUpdateStrategyType `json:"type,omitempty"` // Rolling update config params. Present only if DaemonSetUpdateStrategy = @@ -370,6 +465,7 @@ type DaemonSetUpdateStrategy struct { //--- // TODO: Update this to follow our convention for oneOf, whatever we decide it // to be. Same as DeploymentStrategy.RollingUpdate. +// +optional RollingUpdate *RollingUpdateDaemonSet `json:"rollingUpdate,omitempty"` } @@ -395,12 +491,14 @@ type RollingUpdateDaemonSet struct { // it then proceeds onto other DaemonSet pods, thus ensuring that at least // 70% of original number of DaemonSet pods are available at all times // during the update. +// +optional MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty"` // Minimum number of seconds for which a newly created DaemonSet pod should // be ready without any of its container crashing, for it to be considered // available. Defaults to 0 (pod will be considered available as soon as it // is ready). +// +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty"` } */ @@ -411,7 +509,8 @@ type DaemonSetSpec struct { // Must match in order to be controlled. // If empty, defaulted to labels on Pod template. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,1,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,1,opt,name=selector"` // Template is the object that describes the pod that will be created. // The DaemonSet will create exactly one copy of this pod on every node @@ -422,17 +521,19 @@ type DaemonSetSpec struct { // TODO(madhusudancs): Uncomment while implementing DaemonSet updates. /* Commenting out for v1.2. We are planning to bring these fields back with a more robust DaemonSet update implementation in v1.3, hence not deleting but just commenting these fields out. - // Update strategy to replace existing DaemonSet pods with new pods. - UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty"` + // Update strategy to replace existing DaemonSet pods with new pods. + // +optional + UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty"` - // Label key that is added to DaemonSet pods to distinguish between old and - // new pod templates during DaemonSet update. - // Users can set this to an empty string to indicate that the system should - // not add any label. If unspecified, system uses - // DefaultDaemonSetUniqueLabelKey("daemonset.kubernetes.io/podTemplateHash"). - // Value of this key is hash of DaemonSetSpec.PodTemplateSpec. - // No label is added if this is set to empty string. - UniqueLabelKey *string `json:"uniqueLabelKey,omitempty"` + // Label key that is added to DaemonSet pods to distinguish between old and + // new pod templates during DaemonSet update. + // Users can set this to an empty string to indicate that the system should + // not add any label. If unspecified, system uses + // DefaultDaemonSetUniqueLabelKey("daemonset.kubernetes.io/podTemplateHash"). + // Value of this key is hash of DaemonSetSpec.PodTemplateSpec. + // No label is added if this is set to empty string. + // +optional + UniqueLabelKey *string `json:"uniqueLabelKey,omitempty"` */ } @@ -472,10 +573,12 @@ type DaemonSet struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the desired behavior of this daemon set. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec DaemonSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is the current status of this daemon set. This data may be @@ -483,6 +586,7 @@ type DaemonSet struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status DaemonSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -491,6 +595,7 @@ type DaemonSetList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of daemon sets. @@ -502,6 +607,7 @@ type ThirdPartyResourceDataList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of ThirdpartyResourceData. @@ -515,14 +621,17 @@ type Job struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec is a structure defining the expected behavior of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is a structure describing current status of a job. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status JobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -531,6 +640,7 @@ type JobList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Job. @@ -545,6 +655,7 @@ type JobSpec struct { // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), // i.e. when the work left to do is less than max parallelism. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Parallelism *int32 `json:"parallelism,omitempty" protobuf:"varint,1,opt,name=parallelism"` // Completions specifies the desired number of successfully finished pods the @@ -553,22 +664,26 @@ type JobSpec struct { // value. Setting to 1 means that parallelism is limited to 1 and the success of that // pod signals the success of the job. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Completions *int32 `json:"completions,omitempty" protobuf:"varint,2,opt,name=completions"` // Optional duration in seconds relative to the startTime that the job may be active // before the system tries to terminate it; value must be positive integer + // +optional ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty" protobuf:"varint,3,opt,name=activeDeadlineSeconds"` // Selector is a label query over pods that should match the pod count. // Normally, the system sets this field for you. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` // AutoSelector controls generation of pod labels and pod selectors. // It was not present in the original extensions/v1beta1 Job definition, but exists // to allow conversion from batch/v1 Jobs, where it corresponds to, but has the opposite // meaning as, ManualSelector. // More info: http://releases.k8s.io/HEAD/docs/design/selector-generation.md + // +optional AutoSelector *bool `json:"autoSelector,omitempty" protobuf:"varint,5,opt,name=autoSelector"` // Template is the object that describes the pod that will be created when @@ -582,25 +697,31 @@ type JobStatus struct { // Conditions represent the latest available observations of an object's current state. // More info: http://kubernetes.io/docs/user-guide/jobs + // +optional Conditions []JobCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,1,rep,name=conditions"` // StartTime represents time when the job was acknowledged by the Job Manager. // It is not guaranteed to be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional StartTime *unversioned.Time `json:"startTime,omitempty" protobuf:"bytes,2,opt,name=startTime"` // CompletionTime represents time when the job was completed. It is not guaranteed to // be set in happens-before order across separate operations. // It is represented in RFC3339 form and is in UTC. + // +optional CompletionTime *unversioned.Time `json:"completionTime,omitempty" protobuf:"bytes,3,opt,name=completionTime"` // Active is the number of actively running pods. + // +optional Active int32 `json:"active,omitempty" protobuf:"varint,4,opt,name=active"` // Succeeded is the number of pods which reached Phase Succeeded. + // +optional Succeeded int32 `json:"succeeded,omitempty" protobuf:"varint,5,opt,name=succeeded"` // Failed is the number of pods which reached Phase Failed. + // +optional Failed int32 `json:"failed,omitempty" protobuf:"varint,6,opt,name=failed"` } @@ -621,12 +742,16 @@ type JobCondition struct { // Status of the condition, one of True, False, Unknown. Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/kubernetes/pkg/api/v1.ConditionStatus"` // Last time the condition was checked. + // +optional LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty" protobuf:"bytes,3,opt,name=lastProbeTime"` // Last time the condition transit from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` // (brief) reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` // Human readable message indicating details about last transition. + // +optional Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` } @@ -640,14 +765,17 @@ type Ingress struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec is the desired state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec IngressSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is the current state of the Ingress. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status IngressStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -656,6 +784,7 @@ type IngressList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of Ingress. @@ -668,6 +797,7 @@ type IngressSpec struct { // rule. At least one of 'backend' or 'rules' must be specified. This field // is optional to allow the loadbalancer controller or defaulting logic to // specify a global default. + // +optional Backend *IngressBackend `json:"backend,omitempty" protobuf:"bytes,1,opt,name=backend"` // TLS configuration. Currently the Ingress only supports a single TLS @@ -675,10 +805,12 @@ type IngressSpec struct { // will be multiplexed on the same port according to the hostname specified // through the SNI TLS extension, if the ingress controller fulfilling the // ingress supports SNI. + // +optional TLS []IngressTLS `json:"tls,omitempty" protobuf:"bytes,2,rep,name=tls"` // A list of host rules used to configure the Ingress. If unspecified, or // no rule matches, all traffic is sent to the default backend. + // +optional Rules []IngressRule `json:"rules,omitempty" protobuf:"bytes,3,rep,name=rules"` // TODO: Add the ability to specify load-balancer IP through claims } @@ -689,12 +821,14 @@ type IngressTLS struct { // this list must match the name/s used in the tlsSecret. Defaults to the // wildcard host setting for the loadbalancer controller fulfilling this // Ingress, if left unspecified. + // +optional Hosts []string `json:"hosts,omitempty" protobuf:"bytes,1,rep,name=hosts"` // SecretName is the name of the secret used to terminate SSL traffic on 443. // Field is left optional to allow SSL routing based on SNI hostname alone. // If the SNI host in a listener conflicts with the "Host" header field used // by an IngressRule, the SNI host is used for termination and value of the // Host header is used for routing. + // +optional SecretName string `json:"secretName,omitempty" protobuf:"bytes,2,opt,name=secretName"` // TODO: Consider specifying different modes of termination, protocols etc. } @@ -702,6 +836,7 @@ type IngressTLS struct { // IngressStatus describe the current state of the Ingress. type IngressStatus struct { // LoadBalancer contains the current status of the load-balancer. + // +optional LoadBalancer v1.LoadBalancerStatus `json:"loadBalancer,omitempty" protobuf:"bytes,1,opt,name=loadBalancer"` } @@ -721,12 +856,14 @@ type IngressRule struct { // Incoming requests are matched against the host before the IngressRuleValue. // If the host is unspecified, the Ingress routes all traffic based on the // specified IngressRuleValue. + // +optional Host string `json:"host,omitempty" protobuf:"bytes,1,opt,name=host"` // IngressRuleValue represents a rule to route requests for this IngressRule. // If unspecified, the rule defaults to a http catch-all. Whether that sends // just traffic matching the host to the default backend or all traffic to the // default backend, is left to the controller fulfilling the Ingress. Http is // currently the only supported IngressRuleValue. + // +optional IngressRuleValue `json:",inline,omitempty" protobuf:"bytes,2,opt,name=ingressRuleValue"` } @@ -741,6 +878,7 @@ type IngressRuleValue struct { // 2. Consider adding fields for ingress-type specific global options // usable by a loadbalancer, like http keep-alive. + // +optional HTTP *HTTPIngressRuleValue `json:"http,omitempty" protobuf:"bytes,1,opt,name=http"` } @@ -766,6 +904,7 @@ type HTTPIngressPath struct { // part of a URL as defined by RFC 3986. Paths must begin with // a '/'. If unspecified, the path defaults to a catch all sending // traffic to the backend. + // +optional Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` // Backend defines the referenced service endpoint to which the traffic @@ -791,43 +930,6 @@ type ExportOptions struct { Exact bool `json:"exact" protobuf:"varint,2,opt,name=exact"` } -// A label selector is a label query over a set of resources. The result of matchLabels and -// matchExpressions are ANDed. An empty label selector matches all objects. A null -// label selector matches no objects. -type LabelSelector struct { - // matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels - // map is equivalent to an element of matchExpressions, whose key field is "key", the - // operator is "In", and the values array contains only "value". The requirements are ANDed. - MatchLabels map[string]string `json:"matchLabels,omitempty" protobuf:"bytes,1,rep,name=matchLabels"` - // matchExpressions is a list of label selector requirements. The requirements are ANDed. - MatchExpressions []LabelSelectorRequirement `json:"matchExpressions,omitempty" protobuf:"bytes,2,rep,name=matchExpressions"` -} - -// A label selector requirement is a selector that contains values, a key, and an operator that -// relates the key and values. -type LabelSelectorRequirement struct { - // key is the label key that the selector applies to. - Key string `json:"key" patchStrategy:"merge" patchMergeKey:"key" protobuf:"bytes,1,opt,name=key"` - // operator represents a key's relationship to a set of values. - // Valid operators ard In, NotIn, Exists and DoesNotExist. - Operator LabelSelectorOperator `json:"operator" protobuf:"bytes,2,opt,name=operator,casttype=LabelSelectorOperator"` - // values is an array of string values. If the operator is In or NotIn, - // the values array must be non-empty. If the operator is Exists or DoesNotExist, - // the values array must be empty. This array is replaced during a strategic - // merge patch. - Values []string `json:"values,omitempty" protobuf:"bytes,3,rep,name=values"` -} - -// A label selector operator is the set of operators that can be used in a selector requirement. -type LabelSelectorOperator string - -const ( - LabelSelectorOpIn LabelSelectorOperator = "In" - LabelSelectorOpNotIn LabelSelectorOperator = "NotIn" - LabelSelectorOpExists LabelSelectorOperator = "Exists" - LabelSelectorOpDoesNotExist LabelSelectorOperator = "DoesNotExist" -) - // +genclient=true // ReplicaSet represents the configuration of a ReplicaSet. @@ -837,10 +939,12 @@ type ReplicaSet struct { // If the Labels of a ReplicaSet are empty, they are defaulted to // be the same as the Pod(s) that the ReplicaSet manages. // Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Spec defines the specification of the desired behavior of the ReplicaSet. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Spec ReplicaSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Status is the most recently observed status of the ReplicaSet. @@ -848,6 +952,7 @@ type ReplicaSet struct { // Populated by the system. // Read-only. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#spec-and-status + // +optional Status ReplicaSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } @@ -856,6 +961,7 @@ type ReplicaSetList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // List of ReplicaSets. @@ -869,22 +975,26 @@ type ReplicaSetSpec struct { // This is a pointer to distinguish between explicit zero and unspecified. // Defaults to 1. // More info: http://kubernetes.io/docs/user-guide/replication-controller#what-is-a-replication-controller + // +optional Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` // Minimum number of seconds for which a newly created pod should be ready // without any of its container crashing, for it to be considered available. // Defaults to 0 (pod will be considered available as soon as it is ready) + // +optional MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` // Selector is a label query over pods that should match the replica count. // If the selector is empty, it is defaulted to the labels present on the pod template. // Label keys and values that must match in order to be controlled by this replica set. // More info: http://kubernetes.io/docs/user-guide/labels#label-selectors - Selector *LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` + // +optional + Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` // Template is the object that describes the pod that will be created if // insufficient replicas are detected. // More info: http://kubernetes.io/docs/user-guide/replication-controller#pod-template + // +optional Template v1.PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,3,opt,name=template"` } @@ -895,18 +1005,23 @@ type ReplicaSetStatus struct { Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` // The number of pods that have labels matching the labels of the pod template of the replicaset. + // +optional FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty" protobuf:"varint,2,opt,name=fullyLabeledReplicas"` // The number of ready replicas for this replica set. + // +optional ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,4,opt,name=readyReplicas"` // The number of available replicas (ready for at least minReadySeconds) for this replica set. + // +optional AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,5,opt,name=availableReplicas"` // ObservedGeneration reflects the generation of the most recently observed ReplicaSet. + // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,3,opt,name=observedGeneration"` // Represents the latest available observations of a replica set's current state. + // +optional Conditions []ReplicaSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` } @@ -926,13 +1041,14 @@ type ReplicaSetCondition struct { Type ReplicaSetConditionType `json:"type"` // Status of the condition, one of True, False, Unknown. Status v1.ConditionStatus `json:"status"` - // Last time we probed the condition. - LastProbeTime unversioned.Time `json:"lastProbeTime,omitempty"` // The last time the condition transitioned from one status to another. + // +optional LastTransitionTime unversioned.Time `json:"lastTransitionTime,omitempty"` // The reason for the condition's last transition. + // +optional Reason string `json:"reason,omitempty"` // A human readable message indicating details about the transition. + // +optional Message string `json:"message,omitempty"` } @@ -945,37 +1061,48 @@ type PodSecurityPolicy struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // spec defines the policy enforced. + // +optional Spec PodSecurityPolicySpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` } // Pod Security Policy Spec defines the policy enforced. type PodSecurityPolicySpec struct { // privileged determines if a pod can request to be run as privileged. + // +optional Privileged bool `json:"privileged,omitempty" protobuf:"varint,1,opt,name=privileged"` // DefaultAddCapabilities is the default set of capabilities that will be added to the container // unless the pod spec specifically drops the capability. You may not list a capabiility in both // DefaultAddCapabilities and RequiredDropCapabilities. + // +optional DefaultAddCapabilities []v1.Capability `json:"defaultAddCapabilities,omitempty" protobuf:"bytes,2,rep,name=defaultAddCapabilities,casttype=k8s.io/kubernetes/pkg/api/v1.Capability"` // RequiredDropCapabilities are the capabilities that will be dropped from the container. These // are required to be dropped and cannot be added. + // +optional RequiredDropCapabilities []v1.Capability `json:"requiredDropCapabilities,omitempty" protobuf:"bytes,3,rep,name=requiredDropCapabilities,casttype=k8s.io/kubernetes/pkg/api/v1.Capability"` // AllowedCapabilities is a list of capabilities that can be requested to add to the container. // Capabilities in this field may be added at the pod author's discretion. // You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities. + // +optional AllowedCapabilities []v1.Capability `json:"allowedCapabilities,omitempty" protobuf:"bytes,4,rep,name=allowedCapabilities,casttype=k8s.io/kubernetes/pkg/api/v1.Capability"` // volumes is a white list of allowed volume plugins. Empty indicates that all plugins // may be used. + // +optional Volumes []FSType `json:"volumes,omitempty" protobuf:"bytes,5,rep,name=volumes,casttype=FSType"` // hostNetwork determines if the policy allows the use of HostNetwork in the pod spec. + // +optional HostNetwork bool `json:"hostNetwork,omitempty" protobuf:"varint,6,opt,name=hostNetwork"` // hostPorts determines which host port ranges are allowed to be exposed. + // +optional HostPorts []HostPortRange `json:"hostPorts,omitempty" protobuf:"bytes,7,rep,name=hostPorts"` // hostPID determines if the policy allows the use of HostPID in the pod spec. + // +optional HostPID bool `json:"hostPID,omitempty" protobuf:"varint,8,opt,name=hostPID"` // hostIPC determines if the policy allows the use of HostIPC in the pod spec. + // +optional HostIPC bool `json:"hostIPC,omitempty" protobuf:"varint,9,opt,name=hostIPC"` // seLinux is the strategy that will dictate the allowable labels that may be set. SELinux SELinuxStrategyOptions `json:"seLinux" protobuf:"bytes,10,opt,name=seLinux"` @@ -990,6 +1117,7 @@ type PodSecurityPolicySpec struct { // the PSP should deny the pod. // If set to false the container may run with a read only root file system if it wishes but it // will not be forced to. + // +optional ReadOnlyRootFilesystem bool `json:"readOnlyRootFilesystem,omitempty" protobuf:"varint,14,opt,name=readOnlyRootFilesystem"` } @@ -1036,6 +1164,7 @@ type SELinuxStrategyOptions struct { Rule SELinuxStrategy `json:"rule" protobuf:"bytes,1,opt,name=rule,casttype=SELinuxStrategy"` // seLinuxOptions required to run as; required for MustRunAs // More info: http://releases.k8s.io/HEAD/docs/design/security_context.md#security-context + // +optional SELinuxOptions *v1.SELinuxOptions `json:"seLinuxOptions,omitempty" protobuf:"bytes,2,opt,name=seLinuxOptions"` } @@ -1055,6 +1184,7 @@ type RunAsUserStrategyOptions struct { // Rule is the strategy that will dictate the allowable RunAsUser values that may be set. Rule RunAsUserStrategy `json:"rule" protobuf:"bytes,1,opt,name=rule,casttype=RunAsUserStrategy"` // Ranges are the allowed ranges of uids that may be used. + // +optional Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` } @@ -1082,9 +1212,11 @@ const ( // FSGroupStrategyOptions defines the strategy type and options used to create the strategy. type FSGroupStrategyOptions struct { // Rule is the strategy that will dictate what FSGroup is used in the SecurityContext. + // +optional Rule FSGroupStrategyType `json:"rule,omitempty" protobuf:"bytes,1,opt,name=rule,casttype=FSGroupStrategyType"` // Ranges are the allowed ranges of fs groups. If you would like to force a single // fs group then supply a single range with the same start and end. + // +optional Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` } @@ -1102,9 +1234,11 @@ const ( // SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy. type SupplementalGroupsStrategyOptions struct { // Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext. + // +optional Rule SupplementalGroupsStrategyType `json:"rule,omitempty" protobuf:"bytes,1,opt,name=rule,casttype=SupplementalGroupsStrategyType"` // Ranges are the allowed ranges of supplemental groups. If you would like to force a single // supplemental group then supply a single range with the same start and end. + // +optional Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` } @@ -1124,6 +1258,7 @@ type PodSecurityPolicyList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of schema objects. @@ -1134,9 +1269,11 @@ type NetworkPolicy struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior for this NetworkPolicy. + // +optional Spec NetworkPolicySpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` } @@ -1146,7 +1283,7 @@ type NetworkPolicySpec struct { // same set of pods. In this case, the ingress rules for each are combined additively. // This field is NOT optional and follows standard label selector semantics. // An empty podSelector matches all pods in this namespace. - PodSelector LabelSelector `json:"podSelector" protobuf:"bytes,1,opt,name=podSelector"` + PodSelector unversioned.LabelSelector `json:"podSelector" protobuf:"bytes,1,opt,name=podSelector"` // List of ingress rules to be applied to the selected pods. // Traffic is allowed to a pod if namespace.networkPolicy.ingress.isolation is undefined and cluster policy allows it, @@ -1156,6 +1293,7 @@ type NetworkPolicySpec struct { // If this field is empty then this NetworkPolicy does not affect ingress isolation. // If this field is present and contains at least one rule, this policy allows any traffic // which matches at least one of the ingress rules in this list. + // +optional Ingress []NetworkPolicyIngressRule `json:"ingress,omitempty" protobuf:"bytes,2,rep,name=ingress"` } @@ -1168,6 +1306,7 @@ type NetworkPolicyIngressRule struct { // If this field is present and contains at least one item, then this rule allows traffic // only if the traffic matches at least one port in the list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional Ports []NetworkPolicyPort `json:"ports,omitempty" protobuf:"bytes,1,rep,name=ports"` // List of sources which should be able to access the pods selected for this rule. @@ -1177,12 +1316,14 @@ type NetworkPolicyIngressRule struct { // If this field is present and contains at least on item, this rule allows traffic only if the // traffic matches at least one item in the from list. // TODO: Update this to be a pointer to slice as soon as auto-generation supports it. + // +optional From []NetworkPolicyPeer `json:"from,omitempty" protobuf:"bytes,2,rep,name=from"` } type NetworkPolicyPort struct { // Optional. The protocol (TCP or UDP) which traffic must match. // If not specified, this field defaults to TCP. + // +optional Protocol *v1.Protocol `json:"protocol,omitempty" protobuf:"bytes,1,opt,name=protocol,casttype=k8s.io/kubernetes/pkg/api/v1.Protocol"` // If specified, the port on the given protocol. This can @@ -1190,6 +1331,7 @@ type NetworkPolicyPort struct { // this matches all port names and numbers. // If present, only traffic on the specified protocol AND port // will be matched. + // +optional Port *intstr.IntOrString `json:"port,omitempty" protobuf:"bytes,2,opt,name=port"` } @@ -1200,14 +1342,16 @@ type NetworkPolicyPeer struct { // This field follows standard label selector semantics. // If not provided, this selector selects no pods. // If present but empty, this selector selects all pods in this namespace. - PodSelector *LabelSelector `json:"podSelector,omitempty" protobuf:"bytes,1,opt,name=podSelector"` + // +optional + PodSelector *unversioned.LabelSelector `json:"podSelector,omitempty" protobuf:"bytes,1,opt,name=podSelector"` // Selects Namespaces using cluster scoped-labels. This // matches all pods in all namespaces selected by this label selector. // This field follows standard label selector semantics. // If omitted, this selector selects no namespaces. // If present but empty, this selector selects all namespaces. - NamespaceSelector *LabelSelector `json:"namespaceSelector,omitempty" protobuf:"bytes,2,opt,name=namespaceSelector"` + // +optional + NamespaceSelector *unversioned.LabelSelector `json:"namespaceSelector,omitempty" protobuf:"bytes,2,opt,name=namespaceSelector"` } // Network Policy List is a list of NetworkPolicy objects. @@ -1215,6 +1359,7 @@ type NetworkPolicyList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of schema objects. diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go index d0d1d86..67b16cc 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/types_swagger_doc_generated.go @@ -117,6 +117,20 @@ func (Deployment) SwaggerDoc() map[string]string { return map_Deployment } +var map_DeploymentCondition = map[string]string{ + "": "DeploymentCondition describes the state of a deployment at a certain point.", + "type": "Type of deployment condition.", + "status": "Status of the condition, one of True, False, Unknown.", + "lastUpdateTime": "The last time this condition was updated.", + "lastTransitionTime": "Last time the condition transitioned from one status to another.", + "reason": "The reason for the condition's last transition.", + "message": "A human readable message indicating details about the transition.", +} + +func (DeploymentCondition) SwaggerDoc() map[string]string { + return map_DeploymentCondition +} + var map_DeploymentList = map[string]string{ "": "DeploymentList is a list of Deployments.", "metadata": "Standard list metadata.", @@ -139,15 +153,16 @@ func (DeploymentRollback) SwaggerDoc() map[string]string { } var map_DeploymentSpec = map[string]string{ - "": "DeploymentSpec is the specification of the desired behavior of the Deployment.", - "replicas": "Number of desired pods. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", - "selector": "Label selector for pods. Existing ReplicaSets whose pods are selected by this will be the ones affected by this deployment.", - "template": "Template describes the pods that will be created.", - "strategy": "The deployment strategy to use to replace existing pods with new ones.", - "minReadySeconds": "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", - "revisionHistoryLimit": "The number of old ReplicaSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified.", - "paused": "Indicates that the deployment is paused and will not be processed by the deployment controller.", - "rollbackTo": "The config this deployment is rolling back to. Will be cleared after rollback is done.", + "": "DeploymentSpec is the specification of the desired behavior of the Deployment.", + "replicas": "Number of desired pods. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", + "selector": "Label selector for pods. Existing ReplicaSets whose pods are selected by this will be the ones affected by this deployment.", + "template": "Template describes the pods that will be created.", + "strategy": "The deployment strategy to use to replace existing pods with new ones.", + "minReadySeconds": "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", + "revisionHistoryLimit": "The number of old ReplicaSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified.", + "paused": "Indicates that the deployment is paused and will not be processed by the deployment controller.", + "rollbackTo": "The config this deployment is rolling back to. Will be cleared after rollback is done.", + "progressDeadlineSeconds": "The maximum time in seconds for a deployment to make progress before it is considered to be failed. The deployment controller will continue to process failed deployments and a condition with a ProgressDeadlineExceeded reason will be surfaced in the deployment status. Once autoRollback is implemented, the deployment controller will automatically rollback failed deployments. Note that progress will not be estimated during the time a deployment is paused. This is not set by default.", } func (DeploymentSpec) SwaggerDoc() map[string]string { @@ -161,6 +176,7 @@ var map_DeploymentStatus = map[string]string{ "updatedReplicas": "Total number of non-terminated pods targeted by this deployment that have the desired template spec.", "availableReplicas": "Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.", "unavailableReplicas": "Total number of unavailable pods targeted by this deployment.", + "conditions": "Represents the latest available observations of a deployment's current state.", } func (DeploymentStatus) SwaggerDoc() map[string]string { @@ -423,27 +439,6 @@ func (JobStatus) SwaggerDoc() map[string]string { return map_JobStatus } -var map_LabelSelector = map[string]string{ - "": "A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects.", - "matchLabels": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", - "matchExpressions": "matchExpressions is a list of label selector requirements. The requirements are ANDed.", -} - -func (LabelSelector) SwaggerDoc() map[string]string { - return map_LabelSelector -} - -var map_LabelSelectorRequirement = map[string]string{ - "": "A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.", - "key": "key is the label key that the selector applies to.", - "operator": "operator represents a key's relationship to a set of values. Valid operators ard In, NotIn, Exists and DoesNotExist.", - "values": "values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.", -} - -func (LabelSelectorRequirement) SwaggerDoc() map[string]string { - return map_LabelSelectorRequirement -} - var map_NetworkPolicy = map[string]string{ "metadata": "Standard object's metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata", "spec": "Specification of the desired behavior for this NetworkPolicy.", @@ -557,7 +552,6 @@ var map_ReplicaSetCondition = map[string]string{ "": "ReplicaSetCondition describes the state of a replica set at a certain point.", "type": "Type of replica set condition.", "status": "Status of the condition, one of True, False, Unknown.", - "lastProbeTime": "Last time we probed the condition.", "lastTransitionTime": "The last time the condition transitioned from one status to another.", "reason": "The reason for the condition's last transition.", "message": "A human readable message indicating details about the transition.", diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.conversion.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.conversion.go index 7043f18..aab73f0 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.conversion.go @@ -21,14 +21,13 @@ limitations under the License. package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - autoscaling "k8s.io/kubernetes/pkg/apis/autoscaling" - batch "k8s.io/kubernetes/pkg/apis/batch" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + autoscaling "k8s.io/client-go/pkg/apis/autoscaling" + batch "k8s.io/client-go/pkg/apis/batch" + extensions "k8s.io/client-go/pkg/apis/extensions" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -59,6 +58,8 @@ func RegisterConversions(scheme *runtime.Scheme) error { Convert_extensions_DaemonSetStatus_To_v1beta1_DaemonSetStatus, Convert_v1beta1_Deployment_To_extensions_Deployment, Convert_extensions_Deployment_To_v1beta1_Deployment, + Convert_v1beta1_DeploymentCondition_To_extensions_DeploymentCondition, + Convert_extensions_DeploymentCondition_To_v1beta1_DeploymentCondition, Convert_v1beta1_DeploymentList_To_extensions_DeploymentList, Convert_extensions_DeploymentList_To_v1beta1_DeploymentList, Convert_v1beta1_DeploymentRollback_To_extensions_DeploymentRollback, @@ -115,10 +116,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { Convert_batch_JobSpec_To_v1beta1_JobSpec, Convert_v1beta1_JobStatus_To_batch_JobStatus, Convert_batch_JobStatus_To_v1beta1_JobStatus, - Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector, - Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector, - Convert_v1beta1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement, - Convert_unversioned_LabelSelectorRequirement_To_v1beta1_LabelSelectorRequirement, Convert_v1beta1_NetworkPolicy_To_extensions_NetworkPolicy, Convert_extensions_NetworkPolicy_To_v1beta1_NetworkPolicy, Convert_v1beta1_NetworkPolicyIngressRule_To_extensions_NetworkPolicyIngressRule, @@ -196,9 +193,7 @@ func Convert_extensions_APIVersion_To_v1beta1_APIVersion(in *extensions.APIVersi func autoConvert_v1beta1_CustomMetricCurrentStatus_To_extensions_CustomMetricCurrentStatus(in *CustomMetricCurrentStatus, out *extensions.CustomMetricCurrentStatus, s conversion.Scope) error { out.Name = in.Name - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.CurrentValue, &out.CurrentValue, s); err != nil { - return err - } + out.CurrentValue = in.CurrentValue return nil } @@ -208,9 +203,7 @@ func Convert_v1beta1_CustomMetricCurrentStatus_To_extensions_CustomMetricCurrent func autoConvert_extensions_CustomMetricCurrentStatus_To_v1beta1_CustomMetricCurrentStatus(in *extensions.CustomMetricCurrentStatus, out *CustomMetricCurrentStatus, s conversion.Scope) error { out.Name = in.Name - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.CurrentValue, &out.CurrentValue, s); err != nil { - return err - } + out.CurrentValue = in.CurrentValue return nil } @@ -258,9 +251,7 @@ func Convert_extensions_CustomMetricCurrentStatusList_To_v1beta1_CustomMetricCur func autoConvert_v1beta1_CustomMetricTarget_To_extensions_CustomMetricTarget(in *CustomMetricTarget, out *extensions.CustomMetricTarget, s conversion.Scope) error { out.Name = in.Name - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.TargetValue, &out.TargetValue, s); err != nil { - return err - } + out.TargetValue = in.TargetValue return nil } @@ -270,9 +261,7 @@ func Convert_v1beta1_CustomMetricTarget_To_extensions_CustomMetricTarget(in *Cus func autoConvert_extensions_CustomMetricTarget_To_v1beta1_CustomMetricTarget(in *extensions.CustomMetricTarget, out *CustomMetricTarget, s conversion.Scope) error { out.Name = in.Name - if err := api.Convert_resource_Quantity_To_resource_Quantity(&in.TargetValue, &out.TargetValue, s); err != nil { - return err - } + out.TargetValue = in.TargetValue return nil } @@ -319,10 +308,6 @@ func Convert_extensions_CustomMetricTargetList_To_v1beta1_CustomMetricTargetList } func autoConvert_v1beta1_DaemonSet_To_extensions_DaemonSet(in *DaemonSet, out *extensions.DaemonSet, s conversion.Scope) error { - SetDefaults_DaemonSet(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -341,9 +326,6 @@ func Convert_v1beta1_DaemonSet_To_extensions_DaemonSet(in *DaemonSet, out *exten } func autoConvert_extensions_DaemonSet_To_v1beta1_DaemonSet(in *extensions.DaemonSet, out *DaemonSet, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -362,12 +344,7 @@ func Convert_extensions_DaemonSet_To_v1beta1_DaemonSet(in *extensions.DaemonSet, } func autoConvert_v1beta1_DaemonSetList_To_extensions_DaemonSetList(in *DaemonSetList, out *extensions.DaemonSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.DaemonSet, len(*in)) @@ -387,12 +364,7 @@ func Convert_v1beta1_DaemonSetList_To_extensions_DaemonSetList(in *DaemonSetList } func autoConvert_extensions_DaemonSetList_To_v1beta1_DaemonSetList(in *extensions.DaemonSetList, out *DaemonSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]DaemonSet, len(*in)) @@ -412,15 +384,7 @@ func Convert_extensions_DaemonSetList_To_v1beta1_DaemonSetList(in *extensions.Da } func autoConvert_v1beta1_DaemonSetSpec_To_extensions_DaemonSetSpec(in *DaemonSetSpec, out *extensions.DaemonSetSpec, s conversion.Scope) error { - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -432,15 +396,7 @@ func Convert_v1beta1_DaemonSetSpec_To_extensions_DaemonSetSpec(in *DaemonSetSpec } func autoConvert_extensions_DaemonSetSpec_To_v1beta1_DaemonSetSpec(in *extensions.DaemonSetSpec, out *DaemonSetSpec, s conversion.Scope) error { - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -476,10 +432,6 @@ func Convert_extensions_DaemonSetStatus_To_v1beta1_DaemonSetStatus(in *extension } func autoConvert_v1beta1_Deployment_To_extensions_Deployment(in *Deployment, out *extensions.Deployment, s conversion.Scope) error { - SetDefaults_Deployment(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -498,9 +450,6 @@ func Convert_v1beta1_Deployment_To_extensions_Deployment(in *Deployment, out *ex } func autoConvert_extensions_Deployment_To_v1beta1_Deployment(in *extensions.Deployment, out *Deployment, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -518,13 +467,36 @@ func Convert_extensions_Deployment_To_v1beta1_Deployment(in *extensions.Deployme return autoConvert_extensions_Deployment_To_v1beta1_Deployment(in, out, s) } +func autoConvert_v1beta1_DeploymentCondition_To_extensions_DeploymentCondition(in *DeploymentCondition, out *extensions.DeploymentCondition, s conversion.Scope) error { + out.Type = extensions.DeploymentConditionType(in.Type) + out.Status = api.ConditionStatus(in.Status) + out.LastUpdateTime = in.LastUpdateTime + out.LastTransitionTime = in.LastTransitionTime + out.Reason = in.Reason + out.Message = in.Message + return nil +} + +func Convert_v1beta1_DeploymentCondition_To_extensions_DeploymentCondition(in *DeploymentCondition, out *extensions.DeploymentCondition, s conversion.Scope) error { + return autoConvert_v1beta1_DeploymentCondition_To_extensions_DeploymentCondition(in, out, s) +} + +func autoConvert_extensions_DeploymentCondition_To_v1beta1_DeploymentCondition(in *extensions.DeploymentCondition, out *DeploymentCondition, s conversion.Scope) error { + out.Type = DeploymentConditionType(in.Type) + out.Status = v1.ConditionStatus(in.Status) + out.LastUpdateTime = in.LastUpdateTime + out.LastTransitionTime = in.LastTransitionTime + out.Reason = in.Reason + out.Message = in.Message + return nil +} + +func Convert_extensions_DeploymentCondition_To_v1beta1_DeploymentCondition(in *extensions.DeploymentCondition, out *DeploymentCondition, s conversion.Scope) error { + return autoConvert_extensions_DeploymentCondition_To_v1beta1_DeploymentCondition(in, out, s) +} + func autoConvert_v1beta1_DeploymentList_To_extensions_DeploymentList(in *DeploymentList, out *extensions.DeploymentList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.Deployment, len(*in)) @@ -544,12 +516,7 @@ func Convert_v1beta1_DeploymentList_To_extensions_DeploymentList(in *DeploymentL } func autoConvert_extensions_DeploymentList_To_v1beta1_DeploymentList(in *extensions.DeploymentList, out *DeploymentList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Deployment, len(*in)) @@ -569,9 +536,6 @@ func Convert_extensions_DeploymentList_To_v1beta1_DeploymentList(in *extensions. } func autoConvert_v1beta1_DeploymentRollback_To_extensions_DeploymentRollback(in *DeploymentRollback, out *extensions.DeploymentRollback, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Name = in.Name out.UpdatedAnnotations = in.UpdatedAnnotations if err := Convert_v1beta1_RollbackConfig_To_extensions_RollbackConfig(&in.RollbackTo, &out.RollbackTo, s); err != nil { @@ -585,9 +549,6 @@ func Convert_v1beta1_DeploymentRollback_To_extensions_DeploymentRollback(in *Dep } func autoConvert_extensions_DeploymentRollback_To_v1beta1_DeploymentRollback(in *extensions.DeploymentRollback, out *DeploymentRollback, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Name = in.Name out.UpdatedAnnotations = in.UpdatedAnnotations if err := Convert_extensions_RollbackConfig_To_v1beta1_RollbackConfig(&in.RollbackTo, &out.RollbackTo, s); err != nil { @@ -604,15 +565,7 @@ func autoConvert_v1beta1_DeploymentSpec_To_extensions_DeploymentSpec(in *Deploym if err := api.Convert_Pointer_int32_To_int32(&in.Replicas, &out.Replicas, s); err != nil { return err } - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -631,6 +584,7 @@ func autoConvert_v1beta1_DeploymentSpec_To_extensions_DeploymentSpec(in *Deploym } else { out.RollbackTo = nil } + out.ProgressDeadlineSeconds = in.ProgressDeadlineSeconds return nil } @@ -638,15 +592,7 @@ func autoConvert_extensions_DeploymentSpec_To_v1beta1_DeploymentSpec(in *extensi if err := api.Convert_int32_To_Pointer_int32(&in.Replicas, &out.Replicas, s); err != nil { return err } - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -665,6 +611,7 @@ func autoConvert_extensions_DeploymentSpec_To_v1beta1_DeploymentSpec(in *extensi } else { out.RollbackTo = nil } + out.ProgressDeadlineSeconds = in.ProgressDeadlineSeconds return nil } @@ -674,6 +621,17 @@ func autoConvert_v1beta1_DeploymentStatus_To_extensions_DeploymentStatus(in *Dep out.UpdatedReplicas = in.UpdatedReplicas out.AvailableReplicas = in.AvailableReplicas out.UnavailableReplicas = in.UnavailableReplicas + if in.Conditions != nil { + in, out := &in.Conditions, &out.Conditions + *out = make([]extensions.DeploymentCondition, len(*in)) + for i := range *in { + if err := Convert_v1beta1_DeploymentCondition_To_extensions_DeploymentCondition(&(*in)[i], &(*out)[i], s); err != nil { + return err + } + } + } else { + out.Conditions = nil + } return nil } @@ -687,6 +645,17 @@ func autoConvert_extensions_DeploymentStatus_To_v1beta1_DeploymentStatus(in *ext out.UpdatedReplicas = in.UpdatedReplicas out.AvailableReplicas = in.AvailableReplicas out.UnavailableReplicas = in.UnavailableReplicas + if in.Conditions != nil { + in, out := &in.Conditions, &out.Conditions + *out = make([]DeploymentCondition, len(*in)) + for i := range *in { + if err := Convert_extensions_DeploymentCondition_To_v1beta1_DeploymentCondition(&(*in)[i], &(*out)[i], s); err != nil { + return err + } + } + } else { + out.Conditions = nil + } return nil } @@ -723,9 +692,6 @@ func autoConvert_extensions_DeploymentStrategy_To_v1beta1_DeploymentStrategy(in } func autoConvert_v1beta1_ExportOptions_To_api_ExportOptions(in *ExportOptions, out *api.ExportOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Export = in.Export out.Exact = in.Exact return nil @@ -736,9 +702,6 @@ func Convert_v1beta1_ExportOptions_To_api_ExportOptions(in *ExportOptions, out * } func autoConvert_api_ExportOptions_To_v1beta1_ExportOptions(in *api.ExportOptions, out *ExportOptions, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } out.Export = in.Export out.Exact = in.Exact return nil @@ -851,10 +814,6 @@ func Convert_extensions_HTTPIngressRuleValue_To_v1beta1_HTTPIngressRuleValue(in } func autoConvert_v1beta1_HorizontalPodAutoscaler_To_autoscaling_HorizontalPodAutoscaler(in *HorizontalPodAutoscaler, out *autoscaling.HorizontalPodAutoscaler, s conversion.Scope) error { - SetDefaults_HorizontalPodAutoscaler(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -873,9 +832,6 @@ func Convert_v1beta1_HorizontalPodAutoscaler_To_autoscaling_HorizontalPodAutosca } func autoConvert_autoscaling_HorizontalPodAutoscaler_To_v1beta1_HorizontalPodAutoscaler(in *autoscaling.HorizontalPodAutoscaler, out *HorizontalPodAutoscaler, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -894,12 +850,7 @@ func Convert_autoscaling_HorizontalPodAutoscaler_To_v1beta1_HorizontalPodAutosca } func autoConvert_v1beta1_HorizontalPodAutoscalerList_To_autoscaling_HorizontalPodAutoscalerList(in *HorizontalPodAutoscalerList, out *autoscaling.HorizontalPodAutoscalerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]autoscaling.HorizontalPodAutoscaler, len(*in)) @@ -919,12 +870,7 @@ func Convert_v1beta1_HorizontalPodAutoscalerList_To_autoscaling_HorizontalPodAut } func autoConvert_autoscaling_HorizontalPodAutoscalerList_To_v1beta1_HorizontalPodAutoscalerList(in *autoscaling.HorizontalPodAutoscalerList, out *HorizontalPodAutoscalerList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]HorizontalPodAutoscaler, len(*in)) @@ -1026,9 +972,6 @@ func Convert_extensions_IDRange_To_v1beta1_IDRange(in *extensions.IDRange, out * } func autoConvert_v1beta1_Ingress_To_extensions_Ingress(in *Ingress, out *extensions.Ingress, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1047,9 +990,6 @@ func Convert_v1beta1_Ingress_To_extensions_Ingress(in *Ingress, out *extensions. } func autoConvert_extensions_Ingress_To_v1beta1_Ingress(in *extensions.Ingress, out *Ingress, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1069,9 +1009,7 @@ func Convert_extensions_Ingress_To_v1beta1_Ingress(in *extensions.Ingress, out * func autoConvert_v1beta1_IngressBackend_To_extensions_IngressBackend(in *IngressBackend, out *extensions.IngressBackend, s conversion.Scope) error { out.ServiceName = in.ServiceName - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.ServicePort, &out.ServicePort, s); err != nil { - return err - } + out.ServicePort = in.ServicePort return nil } @@ -1081,9 +1019,7 @@ func Convert_v1beta1_IngressBackend_To_extensions_IngressBackend(in *IngressBack func autoConvert_extensions_IngressBackend_To_v1beta1_IngressBackend(in *extensions.IngressBackend, out *IngressBackend, s conversion.Scope) error { out.ServiceName = in.ServiceName - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.ServicePort, &out.ServicePort, s); err != nil { - return err - } + out.ServicePort = in.ServicePort return nil } @@ -1092,12 +1028,7 @@ func Convert_extensions_IngressBackend_To_v1beta1_IngressBackend(in *extensions. } func autoConvert_v1beta1_IngressList_To_extensions_IngressList(in *IngressList, out *extensions.IngressList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.Ingress, len(*in)) @@ -1117,12 +1048,7 @@ func Convert_v1beta1_IngressList_To_extensions_IngressList(in *IngressList, out } func autoConvert_extensions_IngressList_To_v1beta1_IngressList(in *extensions.IngressList, out *IngressList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Ingress, len(*in)) @@ -1322,10 +1248,6 @@ func Convert_extensions_IngressTLS_To_v1beta1_IngressTLS(in *extensions.IngressT } func autoConvert_v1beta1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Scope) error { - SetDefaults_Job(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1344,9 +1266,6 @@ func Convert_v1beta1_Job_To_batch_Job(in *Job, out *batch.Job, s conversion.Scop } func autoConvert_batch_Job_To_v1beta1_Job(in *batch.Job, out *Job, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1367,12 +1286,8 @@ func Convert_batch_Job_To_v1beta1_Job(in *batch.Job, out *Job, s conversion.Scop func autoConvert_v1beta1_JobCondition_To_batch_JobCondition(in *JobCondition, out *batch.JobCondition, s conversion.Scope) error { out.Type = batch.JobConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -1385,12 +1300,8 @@ func Convert_v1beta1_JobCondition_To_batch_JobCondition(in *JobCondition, out *b func autoConvert_batch_JobCondition_To_v1beta1_JobCondition(in *batch.JobCondition, out *JobCondition, s conversion.Scope) error { out.Type = JobConditionType(in.Type) out.Status = v1.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastProbeTime = in.LastProbeTime + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -1401,12 +1312,7 @@ func Convert_batch_JobCondition_To_v1beta1_JobCondition(in *batch.JobCondition, } func autoConvert_v1beta1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]batch.Job, len(*in)) @@ -1426,12 +1332,7 @@ func Convert_v1beta1_JobList_To_batch_JobList(in *JobList, out *batch.JobList, s } func autoConvert_batch_JobList_To_v1beta1_JobList(in *batch.JobList, out *JobList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Job, len(*in)) @@ -1454,15 +1355,7 @@ func autoConvert_v1beta1_JobSpec_To_batch_JobSpec(in *JobSpec, out *batch.JobSpe out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector // WARNING: in.AutoSelector requires manual conversion: does not exist in peer-type if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -1474,15 +1367,7 @@ func autoConvert_batch_JobSpec_To_v1beta1_JobSpec(in *batch.JobSpec, out *JobSpe out.Parallelism = in.Parallelism out.Completions = in.Completions out.ActiveDeadlineSeconds = in.ActiveDeadlineSeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector // WARNING: in.ManualSelector requires manual conversion: does not exist in peer-type if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err @@ -1538,73 +1423,7 @@ func Convert_batch_JobStatus_To_v1beta1_JobStatus(in *batch.JobStatus, out *JobS return autoConvert_batch_JobStatus_To_v1beta1_JobStatus(in, out, s) } -func autoConvert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]unversioned.LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_v1beta1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in *LabelSelector, out *unversioned.LabelSelector, s conversion.Scope) error { - return autoConvert_v1beta1_LabelSelector_To_unversioned_LabelSelector(in, out, s) -} - -func autoConvert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - out.MatchLabels = in.MatchLabels - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := Convert_unversioned_LabelSelectorRequirement_To_v1beta1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil -} - -func Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in *unversioned.LabelSelector, out *LabelSelector, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelector_To_v1beta1_LabelSelector(in, out, s) -} - -func autoConvert_v1beta1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = unversioned.LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_v1beta1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in *LabelSelectorRequirement, out *unversioned.LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_v1beta1_LabelSelectorRequirement_To_unversioned_LabelSelectorRequirement(in, out, s) -} - -func autoConvert_unversioned_LabelSelectorRequirement_To_v1beta1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - out.Key = in.Key - out.Operator = LabelSelectorOperator(in.Operator) - out.Values = in.Values - return nil -} - -func Convert_unversioned_LabelSelectorRequirement_To_v1beta1_LabelSelectorRequirement(in *unversioned.LabelSelectorRequirement, out *LabelSelectorRequirement, s conversion.Scope) error { - return autoConvert_unversioned_LabelSelectorRequirement_To_v1beta1_LabelSelectorRequirement(in, out, s) -} - func autoConvert_v1beta1_NetworkPolicy_To_extensions_NetworkPolicy(in *NetworkPolicy, out *extensions.NetworkPolicy, s conversion.Scope) error { - SetDefaults_NetworkPolicy(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1620,9 +1439,6 @@ func Convert_v1beta1_NetworkPolicy_To_extensions_NetworkPolicy(in *NetworkPolicy } func autoConvert_extensions_NetworkPolicy_To_v1beta1_NetworkPolicy(in *extensions.NetworkPolicy, out *NetworkPolicy, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1698,12 +1514,7 @@ func Convert_extensions_NetworkPolicyIngressRule_To_v1beta1_NetworkPolicyIngress } func autoConvert_v1beta1_NetworkPolicyList_To_extensions_NetworkPolicyList(in *NetworkPolicyList, out *extensions.NetworkPolicyList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.NetworkPolicy, len(*in)) @@ -1723,12 +1534,7 @@ func Convert_v1beta1_NetworkPolicyList_To_extensions_NetworkPolicyList(in *Netwo } func autoConvert_extensions_NetworkPolicyList_To_v1beta1_NetworkPolicyList(in *extensions.NetworkPolicyList, out *NetworkPolicyList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]NetworkPolicy, len(*in)) @@ -1748,24 +1554,8 @@ func Convert_extensions_NetworkPolicyList_To_v1beta1_NetworkPolicyList(in *exten } func autoConvert_v1beta1_NetworkPolicyPeer_To_extensions_NetworkPolicyPeer(in *NetworkPolicyPeer, out *extensions.NetworkPolicyPeer, s conversion.Scope) error { - if in.PodSelector != nil { - in, out := &in.PodSelector, &out.PodSelector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.PodSelector = nil - } - if in.NamespaceSelector != nil { - in, out := &in.NamespaceSelector, &out.NamespaceSelector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.NamespaceSelector = nil - } + out.PodSelector = in.PodSelector + out.NamespaceSelector = in.NamespaceSelector return nil } @@ -1774,24 +1564,8 @@ func Convert_v1beta1_NetworkPolicyPeer_To_extensions_NetworkPolicyPeer(in *Netwo } func autoConvert_extensions_NetworkPolicyPeer_To_v1beta1_NetworkPolicyPeer(in *extensions.NetworkPolicyPeer, out *NetworkPolicyPeer, s conversion.Scope) error { - if in.PodSelector != nil { - in, out := &in.PodSelector, &out.PodSelector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.PodSelector = nil - } - if in.NamespaceSelector != nil { - in, out := &in.NamespaceSelector, &out.NamespaceSelector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.NamespaceSelector = nil - } + out.PodSelector = in.PodSelector + out.NamespaceSelector = in.NamespaceSelector return nil } @@ -1832,9 +1606,7 @@ func Convert_extensions_NetworkPolicyPort_To_v1beta1_NetworkPolicyPort(in *exten } func autoConvert_v1beta1_NetworkPolicySpec_To_extensions_NetworkPolicySpec(in *NetworkPolicySpec, out *extensions.NetworkPolicySpec, s conversion.Scope) error { - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(&in.PodSelector, &out.PodSelector, s); err != nil { - return err - } + out.PodSelector = in.PodSelector if in.Ingress != nil { in, out := &in.Ingress, &out.Ingress *out = make([]extensions.NetworkPolicyIngressRule, len(*in)) @@ -1854,9 +1626,7 @@ func Convert_v1beta1_NetworkPolicySpec_To_extensions_NetworkPolicySpec(in *Netwo } func autoConvert_extensions_NetworkPolicySpec_To_v1beta1_NetworkPolicySpec(in *extensions.NetworkPolicySpec, out *NetworkPolicySpec, s conversion.Scope) error { - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(&in.PodSelector, &out.PodSelector, s); err != nil { - return err - } + out.PodSelector = in.PodSelector if in.Ingress != nil { in, out := &in.Ingress, &out.Ingress *out = make([]NetworkPolicyIngressRule, len(*in)) @@ -1876,9 +1646,6 @@ func Convert_extensions_NetworkPolicySpec_To_v1beta1_NetworkPolicySpec(in *exten } func autoConvert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(in *PodSecurityPolicy, out *extensions.PodSecurityPolicy, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1894,9 +1661,6 @@ func Convert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(in *PodSe } func autoConvert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(in *extensions.PodSecurityPolicy, out *PodSecurityPolicy, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -1912,12 +1676,7 @@ func Convert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(in *exten } func autoConvert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList(in *PodSecurityPolicyList, out *extensions.PodSecurityPolicyList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.PodSecurityPolicy, len(*in)) @@ -1937,12 +1696,7 @@ func Convert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList(i } func autoConvert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList(in *extensions.PodSecurityPolicyList, out *PodSecurityPolicyList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]PodSecurityPolicy, len(*in)) @@ -2106,10 +1860,6 @@ func Convert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec(i } func autoConvert_v1beta1_ReplicaSet_To_extensions_ReplicaSet(in *ReplicaSet, out *extensions.ReplicaSet, s conversion.Scope) error { - SetDefaults_ReplicaSet(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2128,9 +1878,6 @@ func Convert_v1beta1_ReplicaSet_To_extensions_ReplicaSet(in *ReplicaSet, out *ex } func autoConvert_extensions_ReplicaSet_To_v1beta1_ReplicaSet(in *extensions.ReplicaSet, out *ReplicaSet, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2151,12 +1898,7 @@ func Convert_extensions_ReplicaSet_To_v1beta1_ReplicaSet(in *extensions.ReplicaS func autoConvert_v1beta1_ReplicaSetCondition_To_extensions_ReplicaSetCondition(in *ReplicaSetCondition, out *extensions.ReplicaSetCondition, s conversion.Scope) error { out.Type = extensions.ReplicaSetConditionType(in.Type) out.Status = api.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -2169,12 +1911,7 @@ func Convert_v1beta1_ReplicaSetCondition_To_extensions_ReplicaSetCondition(in *R func autoConvert_extensions_ReplicaSetCondition_To_v1beta1_ReplicaSetCondition(in *extensions.ReplicaSetCondition, out *ReplicaSetCondition, s conversion.Scope) error { out.Type = ReplicaSetConditionType(in.Type) out.Status = v1.ConditionStatus(in.Status) - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastProbeTime, &out.LastProbeTime, s); err != nil { - return err - } - if err := api.Convert_unversioned_Time_To_unversioned_Time(&in.LastTransitionTime, &out.LastTransitionTime, s); err != nil { - return err - } + out.LastTransitionTime = in.LastTransitionTime out.Reason = in.Reason out.Message = in.Message return nil @@ -2185,12 +1922,7 @@ func Convert_extensions_ReplicaSetCondition_To_v1beta1_ReplicaSetCondition(in *e } func autoConvert_v1beta1_ReplicaSetList_To_extensions_ReplicaSetList(in *ReplicaSetList, out *extensions.ReplicaSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.ReplicaSet, len(*in)) @@ -2210,12 +1942,7 @@ func Convert_v1beta1_ReplicaSetList_To_extensions_ReplicaSetList(in *ReplicaSetL } func autoConvert_extensions_ReplicaSetList_To_v1beta1_ReplicaSetList(in *extensions.ReplicaSetList, out *ReplicaSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ReplicaSet, len(*in)) @@ -2239,15 +1966,7 @@ func autoConvert_v1beta1_ReplicaSetSpec_To_extensions_ReplicaSetSpec(in *Replica return err } out.MinReadySeconds = in.MinReadySeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(unversioned.LabelSelector) - if err := Convert_v1beta1_LabelSelector_To_unversioned_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -2259,15 +1978,7 @@ func autoConvert_extensions_ReplicaSetSpec_To_v1beta1_ReplicaSetSpec(in *extensi return err } out.MinReadySeconds = in.MinReadySeconds - if in.Selector != nil { - in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := Convert_unversioned_LabelSelector_To_v1beta1_LabelSelector(*in, *out, s); err != nil { - return err - } - } else { - out.Selector = nil - } + out.Selector = in.Selector if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { return err } @@ -2323,9 +2034,6 @@ func Convert_extensions_ReplicaSetStatus_To_v1beta1_ReplicaSetStatus(in *extensi } func autoConvert_v1beta1_ReplicationControllerDummy_To_extensions_ReplicationControllerDummy(in *ReplicationControllerDummy, out *extensions.ReplicationControllerDummy, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } return nil } @@ -2334,9 +2042,6 @@ func Convert_v1beta1_ReplicationControllerDummy_To_extensions_ReplicationControl } func autoConvert_extensions_ReplicationControllerDummy_To_v1beta1_ReplicationControllerDummy(in *extensions.ReplicationControllerDummy, out *ReplicationControllerDummy, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } return nil } @@ -2453,9 +2158,6 @@ func Convert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions } func autoConvert_v1beta1_Scale_To_extensions_Scale(in *Scale, out *extensions.Scale, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2474,9 +2176,6 @@ func Convert_v1beta1_Scale_To_extensions_Scale(in *Scale, out *extensions.Scale, } func autoConvert_extensions_Scale_To_v1beta1_Scale(in *extensions.Scale, out *Scale, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2566,9 +2265,6 @@ func Convert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_Supplementa } func autoConvert_v1beta1_ThirdPartyResource_To_extensions_ThirdPartyResource(in *ThirdPartyResource, out *extensions.ThirdPartyResource, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2593,9 +2289,6 @@ func Convert_v1beta1_ThirdPartyResource_To_extensions_ThirdPartyResource(in *Thi } func autoConvert_extensions_ThirdPartyResource_To_v1beta1_ThirdPartyResource(in *extensions.ThirdPartyResource, out *ThirdPartyResource, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2620,9 +2313,6 @@ func Convert_extensions_ThirdPartyResource_To_v1beta1_ThirdPartyResource(in *ext } func autoConvert_v1beta1_ThirdPartyResourceData_To_extensions_ThirdPartyResourceData(in *ThirdPartyResourceData, out *extensions.ThirdPartyResourceData, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2638,9 +2328,6 @@ func Convert_v1beta1_ThirdPartyResourceData_To_extensions_ThirdPartyResourceData } func autoConvert_extensions_ThirdPartyResourceData_To_v1beta1_ThirdPartyResourceData(in *extensions.ThirdPartyResourceData, out *ThirdPartyResourceData, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -2656,12 +2343,7 @@ func Convert_extensions_ThirdPartyResourceData_To_v1beta1_ThirdPartyResourceData } func autoConvert_v1beta1_ThirdPartyResourceDataList_To_extensions_ThirdPartyResourceDataList(in *ThirdPartyResourceDataList, out *extensions.ThirdPartyResourceDataList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.ThirdPartyResourceData, len(*in)) @@ -2681,12 +2363,7 @@ func Convert_v1beta1_ThirdPartyResourceDataList_To_extensions_ThirdPartyResource } func autoConvert_extensions_ThirdPartyResourceDataList_To_v1beta1_ThirdPartyResourceDataList(in *extensions.ThirdPartyResourceDataList, out *ThirdPartyResourceDataList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ThirdPartyResourceData, len(*in)) @@ -2706,12 +2383,7 @@ func Convert_extensions_ThirdPartyResourceDataList_To_v1beta1_ThirdPartyResource } func autoConvert_v1beta1_ThirdPartyResourceList_To_extensions_ThirdPartyResourceList(in *ThirdPartyResourceList, out *extensions.ThirdPartyResourceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]extensions.ThirdPartyResource, len(*in)) @@ -2731,12 +2403,7 @@ func Convert_v1beta1_ThirdPartyResourceList_To_extensions_ThirdPartyResourceList } func autoConvert_extensions_ThirdPartyResourceList_To_v1beta1_ThirdPartyResourceList(in *extensions.ThirdPartyResourceList, out *ThirdPartyResourceList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ThirdPartyResource, len(*in)) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go index b648a1b..c7f858f 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.deepcopy.go @@ -21,11 +21,11 @@ limitations under the License. package v1beta1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - intstr "k8s.io/kubernetes/pkg/util/intstr" + unversioned "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" + intstr "k8s.io/client-go/pkg/util/intstr" reflect "reflect" ) @@ -48,6 +48,7 @@ func RegisterDeepCopies(scheme *runtime.Scheme) error { conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DaemonSetSpec, InType: reflect.TypeOf(&DaemonSetSpec{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DaemonSetStatus, InType: reflect.TypeOf(&DaemonSetStatus{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_Deployment, InType: reflect.TypeOf(&Deployment{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DeploymentCondition, InType: reflect.TypeOf(&DeploymentCondition{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DeploymentList, InType: reflect.TypeOf(&DeploymentList{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DeploymentRollback, InType: reflect.TypeOf(&DeploymentRollback{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_DeploymentSpec, InType: reflect.TypeOf(&DeploymentSpec{})}, @@ -76,8 +77,6 @@ func RegisterDeepCopies(scheme *runtime.Scheme) error { conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_JobList, InType: reflect.TypeOf(&JobList{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_JobSpec, InType: reflect.TypeOf(&JobSpec{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_JobStatus, InType: reflect.TypeOf(&JobStatus{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_LabelSelector, InType: reflect.TypeOf(&LabelSelector{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_LabelSelectorRequirement, InType: reflect.TypeOf(&LabelSelectorRequirement{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_NetworkPolicy, InType: reflect.TypeOf(&NetworkPolicy{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_NetworkPolicyIngressRule, InType: reflect.TypeOf(&NetworkPolicyIngressRule{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1beta1_NetworkPolicyList, InType: reflect.TypeOf(&NetworkPolicyList{})}, @@ -228,8 +227,8 @@ func DeepCopy_v1beta1_DaemonSetSpec(in interface{}, out interface{}, c *conversi out := out.(*DaemonSetSpec) if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -265,7 +264,23 @@ func DeepCopy_v1beta1_Deployment(in interface{}, out interface{}, c *conversion. if err := DeepCopy_v1beta1_DeploymentSpec(&in.Spec, &out.Spec, c); err != nil { return err } + if err := DeepCopy_v1beta1_DeploymentStatus(&in.Status, &out.Status, c); err != nil { + return err + } + return nil + } +} + +func DeepCopy_v1beta1_DeploymentCondition(in interface{}, out interface{}, c *conversion.Cloner) error { + { + in := in.(*DeploymentCondition) + out := out.(*DeploymentCondition) + out.Type = in.Type out.Status = in.Status + out.LastUpdateTime = in.LastUpdateTime.DeepCopy() + out.LastTransitionTime = in.LastTransitionTime.DeepCopy() + out.Reason = in.Reason + out.Message = in.Message return nil } } @@ -324,8 +339,8 @@ func DeepCopy_v1beta1_DeploymentSpec(in interface{}, out interface{}, c *convers } if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -353,6 +368,13 @@ func DeepCopy_v1beta1_DeploymentSpec(in interface{}, out interface{}, c *convers } else { out.RollbackTo = nil } + if in.ProgressDeadlineSeconds != nil { + in, out := &in.ProgressDeadlineSeconds, &out.ProgressDeadlineSeconds + *out = new(int32) + **out = **in + } else { + out.ProgressDeadlineSeconds = nil + } return nil } } @@ -366,6 +388,17 @@ func DeepCopy_v1beta1_DeploymentStatus(in interface{}, out interface{}, c *conve out.UpdatedReplicas = in.UpdatedReplicas out.AvailableReplicas = in.AvailableReplicas out.UnavailableReplicas = in.UnavailableReplicas + if in.Conditions != nil { + in, out := &in.Conditions, &out.Conditions + *out = make([]DeploymentCondition, len(*in)) + for i := range *in { + if err := DeepCopy_v1beta1_DeploymentCondition(&(*in)[i], &(*out)[i], c); err != nil { + return err + } + } + } else { + out.Conditions = nil + } return nil } } @@ -780,8 +813,8 @@ func DeepCopy_v1beta1_JobSpec(in interface{}, out interface{}, c *conversion.Clo } if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -837,51 +870,6 @@ func DeepCopy_v1beta1_JobStatus(in interface{}, out interface{}, c *conversion.C } } -func DeepCopy_v1beta1_LabelSelector(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelector) - out := out.(*LabelSelector) - if in.MatchLabels != nil { - in, out := &in.MatchLabels, &out.MatchLabels - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.MatchLabels = nil - } - if in.MatchExpressions != nil { - in, out := &in.MatchExpressions, &out.MatchExpressions - *out = make([]LabelSelectorRequirement, len(*in)) - for i := range *in { - if err := DeepCopy_v1beta1_LabelSelectorRequirement(&(*in)[i], &(*out)[i], c); err != nil { - return err - } - } - } else { - out.MatchExpressions = nil - } - return nil - } -} - -func DeepCopy_v1beta1_LabelSelectorRequirement(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LabelSelectorRequirement) - out := out.(*LabelSelectorRequirement) - out.Key = in.Key - out.Operator = in.Operator - if in.Values != nil { - in, out := &in.Values, &out.Values - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.Values = nil - } - return nil - } -} - func DeepCopy_v1beta1_NetworkPolicy(in interface{}, out interface{}, c *conversion.Cloner) error { { in := in.(*NetworkPolicy) @@ -954,8 +942,8 @@ func DeepCopy_v1beta1_NetworkPolicyPeer(in interface{}, out interface{}, c *conv out := out.(*NetworkPolicyPeer) if in.PodSelector != nil { in, out := &in.PodSelector, &out.PodSelector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -963,8 +951,8 @@ func DeepCopy_v1beta1_NetworkPolicyPeer(in interface{}, out interface{}, c *conv } if in.NamespaceSelector != nil { in, out := &in.NamespaceSelector, &out.NamespaceSelector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { @@ -1000,7 +988,7 @@ func DeepCopy_v1beta1_NetworkPolicySpec(in interface{}, out interface{}, c *conv { in := in.(*NetworkPolicySpec) out := out.(*NetworkPolicySpec) - if err := DeepCopy_v1beta1_LabelSelector(&in.PodSelector, &out.PodSelector, c); err != nil { + if err := unversioned.DeepCopy_unversioned_LabelSelector(&in.PodSelector, &out.PodSelector, c); err != nil { return err } if in.Ingress != nil { @@ -1148,7 +1136,6 @@ func DeepCopy_v1beta1_ReplicaSetCondition(in interface{}, out interface{}, c *co out := out.(*ReplicaSetCondition) out.Type = in.Type out.Status = in.Status - out.LastProbeTime = in.LastProbeTime.DeepCopy() out.LastTransitionTime = in.LastTransitionTime.DeepCopy() out.Reason = in.Reason out.Message = in.Message @@ -1191,8 +1178,8 @@ func DeepCopy_v1beta1_ReplicaSetSpec(in interface{}, out interface{}, c *convers out.MinReadySeconds = in.MinReadySeconds if in.Selector != nil { in, out := &in.Selector, &out.Selector - *out = new(LabelSelector) - if err := DeepCopy_v1beta1_LabelSelector(*in, *out, c); err != nil { + *out = new(unversioned.LabelSelector) + if err := unversioned.DeepCopy_unversioned_LabelSelector(*in, *out, c); err != nil { return err } } else { diff --git a/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.defaults.go new file mode 100644 index 0000000..000645c --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/v1beta1/zz_generated.defaults.go @@ -0,0 +1,565 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1beta1 + +import ( + v1 "k8s.io/client-go/pkg/api/v1" + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&DaemonSet{}, func(obj interface{}) { SetObjectDefaults_DaemonSet(obj.(*DaemonSet)) }) + scheme.AddTypeDefaultingFunc(&DaemonSetList{}, func(obj interface{}) { SetObjectDefaults_DaemonSetList(obj.(*DaemonSetList)) }) + scheme.AddTypeDefaultingFunc(&Deployment{}, func(obj interface{}) { SetObjectDefaults_Deployment(obj.(*Deployment)) }) + scheme.AddTypeDefaultingFunc(&DeploymentList{}, func(obj interface{}) { SetObjectDefaults_DeploymentList(obj.(*DeploymentList)) }) + scheme.AddTypeDefaultingFunc(&HorizontalPodAutoscaler{}, func(obj interface{}) { SetObjectDefaults_HorizontalPodAutoscaler(obj.(*HorizontalPodAutoscaler)) }) + scheme.AddTypeDefaultingFunc(&HorizontalPodAutoscalerList{}, func(obj interface{}) { + SetObjectDefaults_HorizontalPodAutoscalerList(obj.(*HorizontalPodAutoscalerList)) + }) + scheme.AddTypeDefaultingFunc(&Job{}, func(obj interface{}) { SetObjectDefaults_Job(obj.(*Job)) }) + scheme.AddTypeDefaultingFunc(&JobList{}, func(obj interface{}) { SetObjectDefaults_JobList(obj.(*JobList)) }) + scheme.AddTypeDefaultingFunc(&NetworkPolicy{}, func(obj interface{}) { SetObjectDefaults_NetworkPolicy(obj.(*NetworkPolicy)) }) + scheme.AddTypeDefaultingFunc(&NetworkPolicyList{}, func(obj interface{}) { SetObjectDefaults_NetworkPolicyList(obj.(*NetworkPolicyList)) }) + scheme.AddTypeDefaultingFunc(&ReplicaSet{}, func(obj interface{}) { SetObjectDefaults_ReplicaSet(obj.(*ReplicaSet)) }) + scheme.AddTypeDefaultingFunc(&ReplicaSetList{}, func(obj interface{}) { SetObjectDefaults_ReplicaSetList(obj.(*ReplicaSetList)) }) + return nil +} + +func SetObjectDefaults_DaemonSet(in *DaemonSet) { + SetDefaults_DaemonSet(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_DaemonSetList(in *DaemonSetList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_DaemonSet(a) + } +} + +func SetObjectDefaults_Deployment(in *Deployment) { + SetDefaults_Deployment(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_DeploymentList(in *DeploymentList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Deployment(a) + } +} + +func SetObjectDefaults_HorizontalPodAutoscaler(in *HorizontalPodAutoscaler) { + SetDefaults_HorizontalPodAutoscaler(in) +} + +func SetObjectDefaults_HorizontalPodAutoscalerList(in *HorizontalPodAutoscalerList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_HorizontalPodAutoscaler(a) + } +} + +func SetObjectDefaults_Job(in *Job) { + SetDefaults_Job(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_JobList(in *JobList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_Job(a) + } +} + +func SetObjectDefaults_NetworkPolicy(in *NetworkPolicy) { + SetDefaults_NetworkPolicy(in) +} + +func SetObjectDefaults_NetworkPolicyList(in *NetworkPolicyList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_NetworkPolicy(a) + } +} + +func SetObjectDefaults_ReplicaSet(in *ReplicaSet) { + SetDefaults_ReplicaSet(in) + v1.SetDefaults_PodSpec(&in.Spec.Template.Spec) + for i := range in.Spec.Template.Spec.Volumes { + a := &in.Spec.Template.Spec.Volumes[i] + v1.SetDefaults_Volume(a) + if a.VolumeSource.Secret != nil { + v1.SetDefaults_SecretVolumeSource(a.VolumeSource.Secret) + } + if a.VolumeSource.ISCSI != nil { + v1.SetDefaults_ISCSIVolumeSource(a.VolumeSource.ISCSI) + } + if a.VolumeSource.RBD != nil { + v1.SetDefaults_RBDVolumeSource(a.VolumeSource.RBD) + } + if a.VolumeSource.DownwardAPI != nil { + v1.SetDefaults_DownwardAPIVolumeSource(a.VolumeSource.DownwardAPI) + for j := range a.VolumeSource.DownwardAPI.Items { + b := &a.VolumeSource.DownwardAPI.Items[j] + if b.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.FieldRef) + } + } + } + if a.VolumeSource.ConfigMap != nil { + v1.SetDefaults_ConfigMapVolumeSource(a.VolumeSource.ConfigMap) + } + if a.VolumeSource.AzureDisk != nil { + v1.SetDefaults_AzureDiskVolumeSource(a.VolumeSource.AzureDisk) + } + } + for i := range in.Spec.Template.Spec.InitContainers { + a := &in.Spec.Template.Spec.InitContainers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } + for i := range in.Spec.Template.Spec.Containers { + a := &in.Spec.Template.Spec.Containers[i] + v1.SetDefaults_Container(a) + for j := range a.Ports { + b := &a.Ports[j] + v1.SetDefaults_ContainerPort(b) + } + for j := range a.Env { + b := &a.Env[j] + if b.ValueFrom != nil { + if b.ValueFrom.FieldRef != nil { + v1.SetDefaults_ObjectFieldSelector(b.ValueFrom.FieldRef) + } + } + } + v1.SetDefaults_ResourceList(&a.Resources.Limits) + v1.SetDefaults_ResourceList(&a.Resources.Requests) + if a.LivenessProbe != nil { + v1.SetDefaults_Probe(a.LivenessProbe) + if a.LivenessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.LivenessProbe.Handler.HTTPGet) + } + } + if a.ReadinessProbe != nil { + v1.SetDefaults_Probe(a.ReadinessProbe) + if a.ReadinessProbe.Handler.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.ReadinessProbe.Handler.HTTPGet) + } + } + if a.Lifecycle != nil { + if a.Lifecycle.PostStart != nil { + if a.Lifecycle.PostStart.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PostStart.HTTPGet) + } + } + if a.Lifecycle.PreStop != nil { + if a.Lifecycle.PreStop.HTTPGet != nil { + v1.SetDefaults_HTTPGetAction(a.Lifecycle.PreStop.HTTPGet) + } + } + } + } +} + +func SetObjectDefaults_ReplicaSetList(in *ReplicaSetList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ReplicaSet(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/extensions/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/extensions/zz_generated.deepcopy.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/extensions/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/extensions/zz_generated.deepcopy.go index 7807e3e..19003a9 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/extensions/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/extensions/zz_generated.deepcopy.go @@ -21,11 +21,11 @@ limitations under the License. package extensions import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - intstr "k8s.io/kubernetes/pkg/util/intstr" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" + intstr "k8s.io/client-go/pkg/util/intstr" reflect "reflect" ) @@ -47,6 +47,7 @@ func RegisterDeepCopies(scheme *runtime.Scheme) error { conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DaemonSetSpec, InType: reflect.TypeOf(&DaemonSetSpec{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DaemonSetStatus, InType: reflect.TypeOf(&DaemonSetStatus{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_Deployment, InType: reflect.TypeOf(&Deployment{})}, + conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DeploymentCondition, InType: reflect.TypeOf(&DeploymentCondition{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DeploymentList, InType: reflect.TypeOf(&DeploymentList{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DeploymentRollback, InType: reflect.TypeOf(&DeploymentRollback{})}, conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_extensions_DeploymentSpec, InType: reflect.TypeOf(&DeploymentSpec{})}, @@ -242,7 +243,23 @@ func DeepCopy_extensions_Deployment(in interface{}, out interface{}, c *conversi if err := DeepCopy_extensions_DeploymentSpec(&in.Spec, &out.Spec, c); err != nil { return err } + if err := DeepCopy_extensions_DeploymentStatus(&in.Status, &out.Status, c); err != nil { + return err + } + return nil + } +} + +func DeepCopy_extensions_DeploymentCondition(in interface{}, out interface{}, c *conversion.Cloner) error { + { + in := in.(*DeploymentCondition) + out := out.(*DeploymentCondition) + out.Type = in.Type out.Status = in.Status + out.LastUpdateTime = in.LastUpdateTime.DeepCopy() + out.LastTransitionTime = in.LastTransitionTime.DeepCopy() + out.Reason = in.Reason + out.Message = in.Message return nil } } @@ -324,6 +341,13 @@ func DeepCopy_extensions_DeploymentSpec(in interface{}, out interface{}, c *conv } else { out.RollbackTo = nil } + if in.ProgressDeadlineSeconds != nil { + in, out := &in.ProgressDeadlineSeconds, &out.ProgressDeadlineSeconds + *out = new(int32) + **out = **in + } else { + out.ProgressDeadlineSeconds = nil + } return nil } } @@ -337,6 +361,17 @@ func DeepCopy_extensions_DeploymentStatus(in interface{}, out interface{}, c *co out.UpdatedReplicas = in.UpdatedReplicas out.AvailableReplicas = in.AvailableReplicas out.UnavailableReplicas = in.UnavailableReplicas + if in.Conditions != nil { + in, out := &in.Conditions, &out.Conditions + *out = make([]DeploymentCondition, len(*in)) + for i := range *in { + if err := DeepCopy_extensions_DeploymentCondition(&(*in)[i], &(*out)[i], c); err != nil { + return err + } + } + } else { + out.Conditions = nil + } return nil } } @@ -830,7 +865,6 @@ func DeepCopy_extensions_ReplicaSetCondition(in interface{}, out interface{}, c out := out.(*ReplicaSetCondition) out.Type = in.Type out.Status = in.Status - out.LastProbeTime = in.LastProbeTime.DeepCopy() out.LastTransitionTime = in.LastTransitionTime.DeepCopy() out.Reason = in.Reason out.Message = in.Message diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/doc.go b/vendor/k8s.io/client-go/pkg/apis/policy/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/doc.go rename to vendor/k8s.io/client-go/pkg/apis/policy/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/install/install.go b/vendor/k8s.io/client-go/pkg/apis/policy/install/install.go similarity index 85% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/policy/install/install.go index f5e5335..76ccfdb 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/install/install.go @@ -19,9 +19,9 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/policy" - "k8s.io/kubernetes/pkg/apis/policy/v1alpha1" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/policy" + "k8s.io/client-go/pkg/apis/policy/v1alpha1" ) func init() { @@ -29,7 +29,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: policy.GroupName, VersionPreferenceOrder: []string{v1alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/policy", + ImportPrefix: "k8s.io/client-go/pkg/apis/policy", AddInternalObjectsToScheme: policy.AddToScheme, }, announced.VersionToSchemeFunc{ diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/register.go b/vendor/k8s.io/client-go/pkg/apis/policy/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/register.go rename to vendor/k8s.io/client-go/pkg/apis/policy/register.go index 40d8c08..af378cb 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/register.go @@ -17,9 +17,9 @@ limitations under the License. package policy import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/policy/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/policy/types.generated.go index 93ca803..c2a0757 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/types.generated.go @@ -25,10 +25,10 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg3_api "k8s.io/kubernetes/pkg/api" - pkg2_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg4_types "k8s.io/kubernetes/pkg/types" - pkg1_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg3_api "k8s.io/client-go/pkg/api" + pkg2_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg4_types "k8s.io/client-go/pkg/types" + pkg1_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/types.go b/vendor/k8s.io/client-go/pkg/apis/policy/types.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/types.go rename to vendor/k8s.io/client-go/pkg/apis/policy/types.go index 5b76f7e..949378a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/types.go @@ -17,9 +17,9 @@ limitations under the License. package policy import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/util/intstr" ) // PodDisruptionBudgetSpec is a description of a PodDisruptionBudget. @@ -28,10 +28,12 @@ type PodDisruptionBudgetSpec struct { // "selector" will still be available after the eviction, i.e. even in the // absence of the evicted pod. So for example you can prevent all voluntary // evictions by specifying "100%". + // +optional MinAvailable intstr.IntOrString `json:"minAvailable,omitempty"` // Label query over pods whose evictions are managed by the disruption // budget. + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty"` } @@ -56,17 +58,21 @@ type PodDisruptionBudgetStatus struct { // PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods type PodDisruptionBudget struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // Specification of the desired behavior of the PodDisruptionBudget. + // +optional Spec PodDisruptionBudgetSpec `json:"spec,omitempty"` // Most recently observed status of the PodDisruptionBudget. + // +optional Status PodDisruptionBudgetStatus `json:"status,omitempty"` } // PodDisruptionBudgetList is a collection of PodDisruptionBudgets. type PodDisruptionBudgetList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty"` Items []PodDisruptionBudget `json:"items"` } @@ -78,8 +84,10 @@ type Eviction struct { unversioned.TypeMeta `json:",inline"` // ObjectMeta describes the pod that is being evicted. + // +optional api.ObjectMeta `json:"metadata,omitempty"` // DeleteOptions may be provided + // +optional DeleteOptions *api.DeleteOptions `json:"deleteOptions,omitempty"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/doc.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/doc.go index 90fb7f9..5a24d4a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/doc.go @@ -16,6 +16,7 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/policy +// +k8s:defaulter-gen=TypeMeta // Package policy is for any kind of policy object. Suitable examples, even if // they aren't all here, are PodDisruptionBudget, PodSecurityPolicy, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.pb.go similarity index 85% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.pb.go index 3f3daf9..a762391 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.pb.go @@ -37,8 +37,8 @@ import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" -import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/kubernetes/pkg/api/unversioned" -import k8s_io_kubernetes_pkg_api_v1 "k8s.io/kubernetes/pkg/api/v1" +import k8s_io_kubernetes_pkg_api_unversioned "k8s.io/client-go/pkg/api/unversioned" +import k8s_io_kubernetes_pkg_api_v1 "k8s.io/client-go/pkg/api/v1" import strings "strings" import reflect "reflect" @@ -77,11 +77,11 @@ func (*PodDisruptionBudgetStatus) Descriptor() ([]byte, []int) { } func init() { - proto.RegisterType((*Eviction)(nil), "k8s.io.kubernetes.pkg.apis.policy.v1alpha1.Eviction") - proto.RegisterType((*PodDisruptionBudget)(nil), "k8s.io.kubernetes.pkg.apis.policy.v1alpha1.PodDisruptionBudget") - proto.RegisterType((*PodDisruptionBudgetList)(nil), "k8s.io.kubernetes.pkg.apis.policy.v1alpha1.PodDisruptionBudgetList") - proto.RegisterType((*PodDisruptionBudgetSpec)(nil), "k8s.io.kubernetes.pkg.apis.policy.v1alpha1.PodDisruptionBudgetSpec") - proto.RegisterType((*PodDisruptionBudgetStatus)(nil), "k8s.io.kubernetes.pkg.apis.policy.v1alpha1.PodDisruptionBudgetStatus") + proto.RegisterType((*Eviction)(nil), "k8s.io.client-go.pkg.apis.policy.v1alpha1.Eviction") + proto.RegisterType((*PodDisruptionBudget)(nil), "k8s.io.client-go.pkg.apis.policy.v1alpha1.PodDisruptionBudget") + proto.RegisterType((*PodDisruptionBudgetList)(nil), "k8s.io.client-go.pkg.apis.policy.v1alpha1.PodDisruptionBudgetList") + proto.RegisterType((*PodDisruptionBudgetSpec)(nil), "k8s.io.client-go.pkg.apis.policy.v1alpha1.PodDisruptionBudgetSpec") + proto.RegisterType((*PodDisruptionBudgetStatus)(nil), "k8s.io.client-go.pkg.apis.policy.v1alpha1.PodDisruptionBudgetStatus") } func (m *Eviction) Marshal() (data []byte, err error) { size := m.Size() @@ -1146,46 +1146,46 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 648 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xb4, 0x94, 0xdf, 0x6a, 0xd4, 0x4e, - 0x14, 0xc7, 0xbb, 0xfd, 0xc7, 0x32, 0xbf, 0x6d, 0xf9, 0x35, 0x16, 0x5d, 0x17, 0x69, 0x65, 0xaf, - 0x4a, 0xb5, 0x13, 0x5a, 0x14, 0x8a, 0x17, 0x4a, 0xd3, 0x16, 0xac, 0x58, 0x2a, 0xe9, 0x8d, 0x08, - 0x0a, 0x93, 0xe4, 0x98, 0x1d, 0x9b, 0x64, 0xc2, 0xcc, 0x64, 0xb5, 0x77, 0x3e, 0x82, 0xaf, 0xe0, - 0xc3, 0x08, 0xc5, 0xab, 0x5e, 0x7a, 0xb5, 0x68, 0xfb, 0x22, 0x4e, 0x26, 0xb3, 0xdb, 0xcd, 0xee, - 0xa6, 0x14, 0x8a, 0x17, 0x03, 0x39, 0x33, 0xe7, 0xf3, 0x3d, 0x7f, 0xe6, 0x4c, 0xd0, 0xb3, 0x93, - 0x6d, 0x81, 0x29, 0xb3, 0x4f, 0x32, 0x0f, 0x78, 0x02, 0x12, 0x84, 0x9d, 0x9e, 0x84, 0x36, 0x49, - 0xa9, 0xfa, 0x60, 0x11, 0xf5, 0x4f, 0xed, 0xee, 0x26, 0x89, 0xd2, 0x0e, 0xd9, 0xb4, 0x43, 0x48, - 0x80, 0x13, 0x09, 0x01, 0x4e, 0x39, 0x93, 0xcc, 0x5a, 0x2f, 0x58, 0x7c, 0xc5, 0x62, 0xc5, 0xe2, - 0x9c, 0xc5, 0x05, 0x8b, 0xfb, 0x6c, 0x6b, 0x23, 0xa4, 0xb2, 0x93, 0x79, 0xd8, 0x67, 0xb1, 0x1d, - 0xb2, 0x90, 0xd9, 0x5a, 0xc2, 0xcb, 0x3e, 0x6a, 0x4b, 0x1b, 0xfa, 0xab, 0x90, 0x6e, 0x6d, 0x55, - 0xa6, 0x65, 0x73, 0x10, 0x2c, 0xe3, 0x3e, 0x8c, 0xa6, 0xd3, 0x7a, 0x5a, 0xcd, 0x64, 0x49, 0x17, - 0xb8, 0xa0, 0x2c, 0x81, 0x60, 0x0c, 0x7b, 0x5c, 0x8d, 0x75, 0xc7, 0x6a, 0x6e, 0x6d, 0x4c, 0xf6, - 0xe6, 0x59, 0x22, 0x69, 0x3c, 0x9e, 0xd3, 0xe6, 0x64, 0xf7, 0x4c, 0xd2, 0xc8, 0xa6, 0x89, 0x14, - 0x92, 0x8f, 0x22, 0xed, 0x9f, 0x35, 0x54, 0xdf, 0xef, 0x52, 0x5f, 0xaa, 0x74, 0xad, 0xb7, 0xa8, - 0x1e, 0x83, 0x24, 0x01, 0x91, 0xa4, 0x59, 0x7b, 0x58, 0x5b, 0xfb, 0x6f, 0x6b, 0x0d, 0x57, 0x76, - 0x5d, 0x75, 0x1b, 0x1f, 0x79, 0x9f, 0xc0, 0x97, 0x87, 0x8a, 0x71, 0xac, 0xb3, 0xde, 0xea, 0xd4, - 0x45, 0x6f, 0x15, 0x5d, 0xed, 0xb9, 0x03, 0x35, 0x2b, 0x40, 0x0b, 0x01, 0x44, 0x0a, 0x3f, 0x4a, - 0xf3, 0x48, 0xa2, 0x39, 0xad, 0xe5, 0x1f, 0x5d, 0x2f, 0xbf, 0x37, 0x8c, 0x38, 0x4b, 0x4a, 0x7d, - 0xa1, 0xb4, 0xe5, 0x96, 0x45, 0xdb, 0x3f, 0xa6, 0xd1, 0x9d, 0x37, 0x2c, 0xd8, 0xa3, 0x82, 0x67, - 0x7a, 0xcb, 0xc9, 0x82, 0x10, 0xe4, 0x3f, 0xac, 0x0b, 0xd0, 0xac, 0x48, 0xc1, 0x37, 0xe5, 0xec, - 0xe2, 0x9b, 0xcf, 0x28, 0x9e, 0x90, 0xe8, 0xb1, 0x92, 0x72, 0x1a, 0x26, 0xe0, 0x6c, 0x6e, 0xb9, - 0x5a, 0xde, 0x8a, 0xd1, 0xbc, 0x90, 0x44, 0x66, 0xa2, 0x39, 0xa3, 0x03, 0xed, 0xdf, 0x36, 0x90, - 0x16, 0x73, 0x16, 0x4d, 0xa8, 0xf9, 0xc2, 0x76, 0x4d, 0x90, 0x76, 0xaf, 0x86, 0xee, 0x4d, 0xa0, - 0x5e, 0x53, 0x21, 0xad, 0xf7, 0x63, 0xbd, 0xb4, 0xaf, 0xe9, 0xe5, 0xd0, 0x53, 0xc0, 0x39, 0xae, - 0x5b, 0xfa, 0xbf, 0x09, 0x5b, 0xef, 0xef, 0x94, 0x06, 0x65, 0x8e, 0x4a, 0x88, 0xf3, 0x01, 0x99, - 0x51, 0xda, 0x2f, 0x6e, 0x59, 0xa8, 0xb3, 0x60, 0x62, 0xcd, 0x1d, 0xe4, 0xaa, 0x6e, 0x21, 0xde, - 0xbe, 0x9c, 0x5c, 0x60, 0xde, 0x71, 0xab, 0x83, 0x1a, 0x31, 0x4d, 0x76, 0xba, 0x84, 0x46, 0xc4, - 0x8b, 0xc0, 0x14, 0x89, 0x2b, 0x12, 0xc9, 0xdf, 0x16, 0x2e, 0xde, 0x16, 0x3e, 0x48, 0xe4, 0x11, - 0x3f, 0x96, 0x9c, 0x26, 0xa1, 0xb3, 0x6c, 0xe2, 0x36, 0x0e, 0x87, 0xb4, 0xdc, 0x92, 0xb2, 0xf5, - 0x01, 0xd5, 0x85, 0x9a, 0x5f, 0x5f, 0x32, 0x6e, 0x06, 0xe8, 0xc9, 0x4d, 0x5b, 0x49, 0x3c, 0x88, - 0x8e, 0x0d, 0xeb, 0x34, 0xf2, 0x5e, 0xf6, 0x2d, 0x77, 0xa0, 0xd9, 0xfe, 0x3e, 0x8d, 0xee, 0x57, - 0x5e, 0xbe, 0xf5, 0x0a, 0x2d, 0x05, 0x83, 0x93, 0x9d, 0x28, 0x62, 0x9f, 0x21, 0xd0, 0xc5, 0xd6, - 0x9d, 0x07, 0x26, 0xf9, 0xe5, 0x12, 0x6d, 0x7c, 0xdc, 0x71, 0xcc, 0x7a, 0x8e, 0x16, 0xfd, 0x8c, - 0x73, 0x48, 0xe4, 0x4b, 0x20, 0x91, 0xec, 0x9c, 0xea, 0x7a, 0xe6, 0x9c, 0xbb, 0x46, 0x68, 0x71, - 0xb7, 0x74, 0xea, 0x8e, 0x78, 0xe7, 0x7c, 0x00, 0x82, 0x72, 0x08, 0xfa, 0xfc, 0x4c, 0x99, 0xdf, - 0x2b, 0x9d, 0xba, 0x23, 0xde, 0xd6, 0x36, 0x6a, 0xc0, 0x17, 0x75, 0x79, 0xea, 0xbf, 0xa6, 0x52, - 0x16, 0xcd, 0x59, 0x4d, 0x0f, 0xee, 0x60, 0x7f, 0xe8, 0xcc, 0x2d, 0x79, 0x3a, 0xeb, 0x67, 0x7f, - 0x56, 0xa6, 0xce, 0xd5, 0xfa, 0xa5, 0xd6, 0xd7, 0x8b, 0x95, 0xda, 0x99, 0x5a, 0xe7, 0x6a, 0xfd, - 0x56, 0xeb, 0xdb, 0xe5, 0xca, 0xd4, 0xbb, 0x7a, 0x7f, 0xbe, 0xfe, 0x06, 0x00, 0x00, 0xff, 0xff, - 0x7d, 0xdd, 0x26, 0x2d, 0xbe, 0x06, 0x00, 0x00, + // 654 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xb4, 0x93, 0xdd, 0x6a, 0x13, 0x41, + 0x14, 0xc7, 0xb3, 0xfd, 0x22, 0x4c, 0xd3, 0x62, 0xd7, 0xa2, 0x31, 0xc8, 0x56, 0x72, 0x55, 0xaa, + 0x9d, 0x25, 0x45, 0xa1, 0x78, 0xa1, 0x74, 0xdb, 0x82, 0x15, 0x4b, 0xcb, 0xf6, 0x46, 0x04, 0x85, + 0xc9, 0xce, 0x71, 0x33, 0x66, 0xb3, 0xb3, 0xcc, 0xcc, 0x46, 0x7b, 0xe7, 0x23, 0xf8, 0x0a, 0x3e, + 0x8c, 0x50, 0xbc, 0xea, 0xa5, 0x57, 0xc1, 0xa4, 0x2f, 0x22, 0x3b, 0x99, 0xa4, 0xd9, 0x7c, 0x94, + 0x42, 0xf1, 0x6e, 0xcf, 0xcc, 0xf9, 0xfd, 0xff, 0xe7, 0x9c, 0x3d, 0x83, 0x5e, 0x36, 0x77, 0x25, + 0x66, 0xdc, 0x6d, 0xa6, 0x75, 0x10, 0x31, 0x28, 0x90, 0x6e, 0xd2, 0x0c, 0x5d, 0x92, 0x30, 0xe9, + 0x26, 0x3c, 0x62, 0xc1, 0xb9, 0xdb, 0xae, 0x91, 0x28, 0x69, 0x90, 0x9a, 0x1b, 0x42, 0x0c, 0x82, + 0x28, 0xa0, 0x38, 0x11, 0x5c, 0x71, 0x7b, 0xab, 0xcf, 0xe2, 0x6b, 0x16, 0x27, 0xcd, 0x10, 0x67, + 0x2c, 0xee, 0xb3, 0x78, 0xc0, 0x56, 0xb6, 0x43, 0xa6, 0x1a, 0x69, 0x1d, 0x07, 0xbc, 0xe5, 0x86, + 0x3c, 0xe4, 0xae, 0x96, 0xa8, 0xa7, 0x9f, 0x75, 0xa4, 0x03, 0xfd, 0xd5, 0x97, 0xae, 0xec, 0xcc, + 0x2c, 0xcb, 0x15, 0x20, 0x79, 0x2a, 0x02, 0x18, 0x2f, 0xa7, 0xf2, 0x62, 0x36, 0x93, 0xc6, 0x6d, + 0x10, 0x92, 0xf1, 0x18, 0xe8, 0x04, 0xf6, 0x6c, 0x36, 0xd6, 0x9e, 0xe8, 0xb9, 0xb2, 0x3d, 0x3d, + 0x5b, 0xa4, 0xb1, 0x62, 0xad, 0xc9, 0x9a, 0x6a, 0xd3, 0xd3, 0x53, 0xc5, 0x22, 0x97, 0xc5, 0x4a, + 0x2a, 0x31, 0x8e, 0x54, 0x7f, 0x5b, 0xa8, 0x78, 0xd8, 0x66, 0x81, 0x62, 0x3c, 0xb6, 0xdf, 0xa3, + 0x62, 0x0b, 0x14, 0xa1, 0x44, 0x91, 0xb2, 0xf5, 0xc4, 0xda, 0x5c, 0xde, 0xd9, 0xc4, 0x33, 0xa7, + 0x8e, 0xdb, 0x35, 0x7c, 0x52, 0xff, 0x02, 0x81, 0x3a, 0x06, 0x45, 0x3c, 0xfb, 0xa2, 0xb3, 0x51, + 0xe8, 0x75, 0x36, 0xd0, 0xf5, 0x99, 0x3f, 0x54, 0xb3, 0x29, 0x5a, 0xa1, 0x10, 0x81, 0x82, 0x93, + 0x24, 0x73, 0x92, 0xe5, 0x39, 0x2d, 0xff, 0xf4, 0x66, 0xf9, 0x83, 0x51, 0xc4, 0x5b, 0xeb, 0x75, + 0x36, 0x56, 0x72, 0x47, 0x7e, 0x5e, 0xb4, 0xfa, 0x6b, 0x0e, 0xdd, 0x3f, 0xe5, 0xf4, 0x80, 0x49, + 0x91, 0xea, 0x23, 0x2f, 0xa5, 0x21, 0xa8, 0xff, 0xd8, 0x17, 0xa0, 0x05, 0x99, 0x40, 0x60, 0xda, + 0xd9, 0xc7, 0xb7, 0xdf, 0x51, 0x3c, 0xa5, 0xd0, 0xb3, 0x04, 0x02, 0xaf, 0x64, 0x0c, 0x17, 0xb2, + 0xc8, 0xd7, 0xf2, 0x76, 0x0b, 0x2d, 0x49, 0x45, 0x54, 0x2a, 0xcb, 0xf3, 0xda, 0xe8, 0xf0, 0xae, + 0x46, 0x5a, 0xcc, 0x5b, 0x35, 0x56, 0x4b, 0xfd, 0xd8, 0x37, 0x26, 0xd5, 0x8e, 0x85, 0x1e, 0x4e, + 0xa1, 0xde, 0x31, 0xa9, 0xec, 0x8f, 0x13, 0xb3, 0x74, 0x6f, 0x98, 0xe5, 0xc8, 0x53, 0xc0, 0x19, + 0xae, 0x47, 0x7a, 0xcf, 0xd8, 0x16, 0x07, 0x27, 0xb9, 0x45, 0x59, 0x64, 0x0a, 0x5a, 0xd9, 0x82, + 0xcc, 0x6f, 0x2e, 0xef, 0xbc, 0xbe, 0x63, 0xa3, 0xde, 0x8a, 0xf1, 0x5a, 0x3c, 0xca, 0x54, 0xfd, + 0xbe, 0x78, 0xf5, 0x6a, 0x7a, 0x83, 0xd9, 0xc4, 0xed, 0x06, 0x2a, 0xb5, 0x58, 0xbc, 0xd7, 0x26, + 0x2c, 0x22, 0xf5, 0x08, 0x4c, 0x93, 0x78, 0x46, 0x21, 0xd9, 0xdb, 0xc2, 0xfd, 0xb7, 0x85, 0x8f, + 0x62, 0x75, 0x22, 0xce, 0x94, 0x60, 0x71, 0xe8, 0xad, 0x1b, 0xdf, 0xd2, 0xf1, 0x88, 0x96, 0x9f, + 0x53, 0xb6, 0x3f, 0xa1, 0xa2, 0x84, 0x08, 0x02, 0xc5, 0x85, 0x59, 0xa0, 0xe7, 0xb7, 0x1d, 0x25, + 0xa9, 0x43, 0x74, 0x66, 0x58, 0xaf, 0x94, 0xcd, 0x72, 0x10, 0xf9, 0x43, 0xcd, 0xea, 0xcf, 0x39, + 0xf4, 0x68, 0xe6, 0xcf, 0xb7, 0xdf, 0xa2, 0x35, 0x3a, 0xbc, 0xd9, 0x8b, 0x22, 0xfe, 0x15, 0xa8, + 0x6e, 0xb6, 0xe8, 0x3d, 0x36, 0xc5, 0xaf, 0xe7, 0x68, 0x93, 0xe3, 0x4f, 0x62, 0xf6, 0x2b, 0xb4, + 0x1a, 0xa4, 0x42, 0x40, 0xac, 0xde, 0x00, 0x89, 0x54, 0xe3, 0x5c, 0xf7, 0xb3, 0xe8, 0x3d, 0x30, + 0x42, 0xab, 0xfb, 0xb9, 0x5b, 0x7f, 0x2c, 0x3b, 0xe3, 0x29, 0x48, 0x26, 0x80, 0x0e, 0xf8, 0xf9, + 0x3c, 0x7f, 0x90, 0xbb, 0xf5, 0xc7, 0xb2, 0xed, 0x5d, 0x54, 0x82, 0x6f, 0x09, 0x04, 0x0a, 0xe8, + 0x29, 0xa7, 0xb2, 0xbc, 0xa0, 0xe9, 0xe1, 0x3f, 0x38, 0x1c, 0xb9, 0xf3, 0x73, 0x99, 0xde, 0xd6, + 0x45, 0xd7, 0x29, 0x5c, 0x76, 0x9d, 0xc2, 0x9f, 0xae, 0x53, 0xf8, 0xde, 0x73, 0xac, 0x8b, 0x9e, + 0x63, 0x5d, 0xf6, 0x1c, 0xeb, 0x6f, 0xcf, 0xb1, 0x7e, 0x5c, 0x39, 0x85, 0x0f, 0xc5, 0xc1, 0x7e, + 0xfd, 0x0b, 0x00, 0x00, 0xff, 0xff, 0x7d, 0xdd, 0x26, 0x2d, 0xbe, 0x06, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.proto similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.proto index 2b80480..25a4993 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/generated.proto @@ -35,25 +35,31 @@ option go_package = "v1alpha1"; // created by POSTing to .../pods//evictions. message Eviction { // ObjectMeta describes the pod that is being evicted. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // DeleteOptions may be provided + // +optional optional k8s.io.kubernetes.pkg.api.v1.DeleteOptions deleteOptions = 2; } // PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods message PodDisruptionBudget { + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Specification of the desired behavior of the PodDisruptionBudget. + // +optional optional PodDisruptionBudgetSpec spec = 2; // Most recently observed status of the PodDisruptionBudget. + // +optional optional PodDisruptionBudgetStatus status = 3; } // PodDisruptionBudgetList is a collection of PodDisruptionBudgets. message PodDisruptionBudgetList { + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; repeated PodDisruptionBudget items = 2; @@ -65,10 +71,12 @@ message PodDisruptionBudgetSpec { // "selector" will still be available after the eviction, i.e. even in the // absence of the evicted pod. So for example you can prevent all voluntary // evictions by specifying "100%". + // +optional optional k8s.io.kubernetes.pkg.util.intstr.IntOrString minAvailable = 1; // Label query over pods whose evictions are managed by the disruption // budget. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.LabelSelector selector = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/register.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/register.go similarity index 89% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/register.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/register.go index 8fcb0be..5cc55aa 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.generated.go index b131cdc..3d26017 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.generated.go @@ -25,10 +25,10 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg4_types "k8s.io/kubernetes/pkg/types" - pkg1_intstr "k8s.io/kubernetes/pkg/util/intstr" + pkg2_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_v1 "k8s.io/client-go/pkg/api/v1" + pkg4_types "k8s.io/client-go/pkg/types" + pkg1_intstr "k8s.io/client-go/pkg/util/intstr" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.go similarity index 91% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.go index 8a3bd7d..2ae77e4 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types.go @@ -17,9 +17,9 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/util/intstr" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/util/intstr" ) // PodDisruptionBudgetSpec is a description of a PodDisruptionBudget. @@ -28,10 +28,12 @@ type PodDisruptionBudgetSpec struct { // "selector" will still be available after the eviction, i.e. even in the // absence of the evicted pod. So for example you can prevent all voluntary // evictions by specifying "100%". + // +optional MinAvailable intstr.IntOrString `json:"minAvailable,omitempty" protobuf:"bytes,1,opt,name=minAvailable"` // Label query over pods whose evictions are managed by the disruption // budget. + // +optional Selector *unversioned.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` } @@ -56,17 +58,21 @@ type PodDisruptionBudgetStatus struct { // PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods type PodDisruptionBudget struct { unversioned.TypeMeta `json:",inline"` - v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` + // +optional + v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Specification of the desired behavior of the PodDisruptionBudget. + // +optional Spec PodDisruptionBudgetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` // Most recently observed status of the PodDisruptionBudget. + // +optional Status PodDisruptionBudgetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` } // PodDisruptionBudgetList is a collection of PodDisruptionBudgets. type PodDisruptionBudgetList struct { unversioned.TypeMeta `json:",inline"` + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` Items []PodDisruptionBudget `json:"items" protobuf:"bytes,2,rep,name=items"` } @@ -78,8 +84,10 @@ type Eviction struct { unversioned.TypeMeta `json:",inline"` // ObjectMeta describes the pod that is being evicted. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // DeleteOptions may be provided + // +optional DeleteOptions *v1.DeleteOptions `json:"deleteOptions,omitempty" protobuf:"bytes,2,opt,name=deleteOptions"` } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.conversion.go similarity index 85% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.conversion.go index 9a59f8e..3c3df37 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.conversion.go @@ -21,11 +21,11 @@ limitations under the License. package v1alpha1 import ( - api "k8s.io/kubernetes/pkg/api" - v1 "k8s.io/kubernetes/pkg/api/v1" - policy "k8s.io/kubernetes/pkg/apis/policy" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + v1 "k8s.io/client-go/pkg/api/v1" + policy "k8s.io/client-go/pkg/apis/policy" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -50,9 +50,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1alpha1_Eviction_To_policy_Eviction(in *Eviction, out *policy.Eviction, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -75,9 +72,6 @@ func Convert_v1alpha1_Eviction_To_policy_Eviction(in *Eviction, out *policy.Evic } func autoConvert_policy_Eviction_To_v1alpha1_Eviction(in *policy.Eviction, out *Eviction, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -100,9 +94,6 @@ func Convert_policy_Eviction_To_v1alpha1_Eviction(in *policy.Eviction, out *Evic } func autoConvert_v1alpha1_PodDisruptionBudget_To_policy_PodDisruptionBudget(in *PodDisruptionBudget, out *policy.PodDisruptionBudget, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -121,9 +112,6 @@ func Convert_v1alpha1_PodDisruptionBudget_To_policy_PodDisruptionBudget(in *PodD } func autoConvert_policy_PodDisruptionBudget_To_v1alpha1_PodDisruptionBudget(in *policy.PodDisruptionBudget, out *PodDisruptionBudget, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -142,12 +130,7 @@ func Convert_policy_PodDisruptionBudget_To_v1alpha1_PodDisruptionBudget(in *poli } func autoConvert_v1alpha1_PodDisruptionBudgetList_To_policy_PodDisruptionBudgetList(in *PodDisruptionBudgetList, out *policy.PodDisruptionBudgetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]policy.PodDisruptionBudget, len(*in)) @@ -167,12 +150,7 @@ func Convert_v1alpha1_PodDisruptionBudgetList_To_policy_PodDisruptionBudgetList( } func autoConvert_policy_PodDisruptionBudgetList_To_v1alpha1_PodDisruptionBudgetList(in *policy.PodDisruptionBudgetList, out *PodDisruptionBudgetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]PodDisruptionBudget, len(*in)) @@ -192,9 +170,7 @@ func Convert_policy_PodDisruptionBudgetList_To_v1alpha1_PodDisruptionBudgetList( } func autoConvert_v1alpha1_PodDisruptionBudgetSpec_To_policy_PodDisruptionBudgetSpec(in *PodDisruptionBudgetSpec, out *policy.PodDisruptionBudgetSpec, s conversion.Scope) error { - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.MinAvailable, &out.MinAvailable, s); err != nil { - return err - } + out.MinAvailable = in.MinAvailable out.Selector = in.Selector return nil } @@ -204,9 +180,7 @@ func Convert_v1alpha1_PodDisruptionBudgetSpec_To_policy_PodDisruptionBudgetSpec( } func autoConvert_policy_PodDisruptionBudgetSpec_To_v1alpha1_PodDisruptionBudgetSpec(in *policy.PodDisruptionBudgetSpec, out *PodDisruptionBudgetSpec, s conversion.Scope) error { - if err := api.Convert_intstr_IntOrString_To_intstr_IntOrString(&in.MinAvailable, &out.MinAvailable, s); err != nil { - return err - } + out.MinAvailable = in.MinAvailable out.Selector = in.Selector return nil } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go index c5a4ee2..94b6558 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/v1alpha1/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package v1alpha1 import ( - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + unversioned "k8s.io/client-go/pkg/api/unversioned" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/policy/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/policy/zz_generated.deepcopy.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/policy/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/policy/zz_generated.deepcopy.go index ed2db3b..bd13ae0 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/policy/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/policy/zz_generated.deepcopy.go @@ -21,10 +21,10 @@ limitations under the License. package policy import ( - api "k8s.io/kubernetes/pkg/api" - unversioned "k8s.io/kubernetes/pkg/api/unversioned" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + unversioned "k8s.io/client-go/pkg/api/unversioned" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/doc.go b/vendor/k8s.io/client-go/pkg/apis/rbac/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/doc.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/helpers.go b/vendor/k8s.io/client-go/pkg/apis/rbac/helpers.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/helpers.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/helpers.go index 93ed6f9..f9a770b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/helpers.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/helpers.go @@ -20,8 +20,8 @@ import ( "fmt" "strings" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) func RoleRefGroupKind(roleRef RoleRef) unversioned.GroupKind { diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/install/install.go b/vendor/k8s.io/client-go/pkg/apis/rbac/install/install.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/install/install.go index ce7b2a2..37e5b91 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/apis/rbac/v1alpha1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/rbac" + "k8s.io/client-go/pkg/apis/rbac/v1alpha1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: rbac.GroupName, VersionPreferenceOrder: []string{v1alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/rbac", + ImportPrefix: "k8s.io/client-go/pkg/apis/rbac", RootScopedKinds: sets.NewString("ClusterRole", "ClusterRoleBinding"), AddInternalObjectsToScheme: rbac.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/register.go b/vendor/k8s.io/client-go/pkg/apis/rbac/register.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/register.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/register.go index f854cfa..d50d557 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/register.go @@ -17,10 +17,10 @@ limitations under the License. package rbac import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/watch/versioned" ) const GroupName = "rbac.authorization.k8s.io" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/types.go b/vendor/k8s.io/client-go/pkg/apis/rbac/types.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/types.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/types.go index 361654f..0d8ec84 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/types.go @@ -17,9 +17,9 @@ limitations under the License. package rbac import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // Authorization is calculated against diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/defaults.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/defaults.go similarity index 64% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/defaults.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/defaults.go index e97f410..51f51e5 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/defaults.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/defaults.go @@ -17,20 +17,24 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) func addDefaultingFuncs(scheme *runtime.Scheme) error { + RegisterDefaults(scheme) return scheme.AddDefaultingFuncs( - func(obj *ClusterRoleBinding) { - if len(obj.RoleRef.APIGroup) == 0 { - obj.RoleRef.APIGroup = GroupName - } - }, - func(obj *RoleBinding) { - if len(obj.RoleRef.APIGroup) == 0 { - obj.RoleRef.APIGroup = GroupName - } - }, + SetDefaults_ClusterRoleBinding, + SetDefaults_RoleBinding, ) } + +func SetDefaults_ClusterRoleBinding(obj *ClusterRoleBinding) { + if len(obj.RoleRef.APIGroup) == 0 { + obj.RoleRef.APIGroup = GroupName + } +} +func SetDefaults_RoleBinding(obj *RoleBinding) { + if len(obj.RoleRef.APIGroup) == 0 { + obj.RoleRef.APIGroup = GroupName + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/doc.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/doc.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/doc.go index ab6aa6a..0540241 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/doc.go @@ -17,6 +17,7 @@ limitations under the License. // +k8s:deepcopy-gen=package,register // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/rbac // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta // +groupName=rbac.authorization.k8s.io package v1alpha1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.pb.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.pb.go index 0b2c93f..829e1d2 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.pb.go @@ -102,17 +102,17 @@ func (*Subject) ProtoMessage() {} func (*Subject) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{10} } func init() { - proto.RegisterType((*ClusterRole)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.ClusterRole") - proto.RegisterType((*ClusterRoleBinding)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.ClusterRoleBinding") - proto.RegisterType((*ClusterRoleBindingList)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.ClusterRoleBindingList") - proto.RegisterType((*ClusterRoleList)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.ClusterRoleList") - proto.RegisterType((*PolicyRule)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.PolicyRule") - proto.RegisterType((*Role)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.Role") - proto.RegisterType((*RoleBinding)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.RoleBinding") - proto.RegisterType((*RoleBindingList)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.RoleBindingList") - proto.RegisterType((*RoleList)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.RoleList") - proto.RegisterType((*RoleRef)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.RoleRef") - proto.RegisterType((*Subject)(nil), "k8s.io.kubernetes.pkg.apis.rbac.v1alpha1.Subject") + proto.RegisterType((*ClusterRole)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.ClusterRole") + proto.RegisterType((*ClusterRoleBinding)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.ClusterRoleBinding") + proto.RegisterType((*ClusterRoleBindingList)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.ClusterRoleBindingList") + proto.RegisterType((*ClusterRoleList)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.ClusterRoleList") + proto.RegisterType((*PolicyRule)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.PolicyRule") + proto.RegisterType((*Role)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.Role") + proto.RegisterType((*RoleBinding)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.RoleBinding") + proto.RegisterType((*RoleBindingList)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.RoleBindingList") + proto.RegisterType((*RoleList)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.RoleList") + proto.RegisterType((*RoleRef)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.RoleRef") + proto.RegisterType((*Subject)(nil), "k8s.io.client-go.pkg.apis.rbac.v1alpha1.Subject") } func (m *ClusterRole) Marshal() (data []byte, err error) { size := m.Size() @@ -2539,55 +2539,56 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 800 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x54, 0x41, 0x4f, 0x13, 0x4d, - 0x18, 0x66, 0x69, 0xfb, 0xd1, 0x1d, 0xbe, 0xa6, 0x1f, 0xf3, 0x85, 0x2f, 0x4d, 0x93, 0x0f, 0x48, - 0x4f, 0x8d, 0xc0, 0x6c, 0x4a, 0x24, 0x72, 0xd0, 0x03, 0x6b, 0x8c, 0x21, 0x22, 0x92, 0x21, 0x12, - 0x25, 0x1a, 0xb3, 0x6d, 0x87, 0xb2, 0xb6, 0xdd, 0x6d, 0x76, 0x66, 0x51, 0xe3, 0x85, 0xf8, 0x0b, - 0xfc, 0x15, 0xde, 0xbc, 0x78, 0x35, 0xf1, 0xe0, 0x89, 0x83, 0x07, 0x8e, 0xc6, 0x03, 0x51, 0xfc, - 0x23, 0xbe, 0xb3, 0xbb, 0xd3, 0xdd, 0xd2, 0x56, 0x0a, 0x89, 0x24, 0x26, 0x1e, 0x26, 0xed, 0xbc, - 0xef, 0xf3, 0xbc, 0xf3, 0x3e, 0xef, 0xce, 0x3c, 0x68, 0xa5, 0xb9, 0xc2, 0x89, 0xed, 0x1a, 0x4d, - 0xbf, 0xca, 0x3c, 0x87, 0x09, 0xc6, 0x8d, 0x4e, 0xb3, 0x61, 0x58, 0x1d, 0x9b, 0x1b, 0x5e, 0xd5, - 0xaa, 0x19, 0xfb, 0x15, 0xab, 0xd5, 0xd9, 0xb3, 0x2a, 0x46, 0x83, 0x39, 0xcc, 0xb3, 0x04, 0xab, - 0x93, 0x8e, 0xe7, 0x0a, 0x17, 0x97, 0x43, 0x26, 0x89, 0x99, 0x04, 0x98, 0x44, 0x32, 0x89, 0x64, - 0x12, 0xc5, 0x2c, 0x2e, 0x36, 0x6c, 0xb1, 0xe7, 0x57, 0x49, 0xcd, 0x6d, 0x1b, 0x0d, 0xb7, 0xe1, - 0x1a, 0x41, 0x81, 0xaa, 0xbf, 0x1b, 0xec, 0x82, 0x4d, 0xf0, 0x2f, 0x2c, 0x5c, 0x5c, 0x1a, 0xda, - 0x92, 0xe1, 0x31, 0xee, 0xfa, 0x5e, 0x8d, 0x9d, 0x6e, 0xa6, 0xb8, 0x3c, 0x9c, 0xe3, 0x3b, 0xfb, - 0xcc, 0xe3, 0xb6, 0xeb, 0xb0, 0x7a, 0x1f, 0x6d, 0x61, 0x38, 0x6d, 0xbf, 0x4f, 0x71, 0x71, 0x71, - 0x30, 0xda, 0xf3, 0x1d, 0x61, 0xb7, 0xfb, 0x7b, 0xaa, 0x0c, 0x86, 0xfb, 0xc2, 0x6e, 0x19, 0xb6, - 0x23, 0xb8, 0xf0, 0x4e, 0x53, 0x4a, 0x1f, 0x35, 0x34, 0x79, 0xb3, 0xe5, 0x73, 0xc1, 0x3c, 0xea, - 0xb6, 0x18, 0x7e, 0x80, 0xb2, 0x6d, 0x26, 0xac, 0xba, 0x25, 0xac, 0x82, 0x36, 0xa7, 0x95, 0x27, - 0x97, 0xca, 0x64, 0xe8, 0xd8, 0x61, 0xe0, 0xe4, 0x5e, 0xf5, 0x29, 0xab, 0x89, 0xbb, 0xc0, 0x31, - 0xf1, 0xe1, 0xf1, 0xec, 0xd8, 0xc9, 0xf1, 0x2c, 0x8a, 0x63, 0xb4, 0x5b, 0x0d, 0x3f, 0x44, 0x19, - 0xcf, 0x6f, 0x31, 0x5e, 0x18, 0x9f, 0x4b, 0x41, 0xd9, 0xab, 0x64, 0xd4, 0xaf, 0x49, 0x36, 0xdd, - 0x96, 0x5d, 0x7b, 0x41, 0x81, 0x6c, 0xe6, 0xa2, 0x23, 0x32, 0x72, 0xc7, 0x69, 0x58, 0xb1, 0xf4, - 0x76, 0x1c, 0xe1, 0x84, 0x08, 0xd3, 0x76, 0xea, 0xb6, 0xd3, 0xf8, 0x85, 0x5a, 0x9e, 0xa0, 0x2c, - 0xf7, 0x83, 0x84, 0x92, 0x53, 0x19, 0x5d, 0xce, 0x56, 0xc8, 0x34, 0xff, 0x89, 0x8e, 0xc8, 0x46, - 0x01, 0x4e, 0xbb, 0x45, 0xf1, 0x23, 0x34, 0xe1, 0x81, 0x12, 0xca, 0x76, 0x0b, 0xa9, 0xa0, 0xf3, - 0x73, 0xd4, 0xa7, 0x21, 0xd1, 0xcc, 0x47, 0xf5, 0x27, 0xa2, 0x00, 0x55, 0x25, 0x4b, 0x5f, 0x34, - 0xf4, 0x5f, 0xff, 0xbc, 0xd6, 0x6d, 0x2e, 0xf0, 0xe3, 0xbe, 0x99, 0x19, 0x3f, 0x99, 0x59, 0xe2, - 0xa6, 0x13, 0x49, 0x0f, 0x46, 0xd7, 0xd5, 0xa5, 0x22, 0x89, 0xc1, 0x59, 0x28, 0x63, 0x0b, 0xd6, - 0x56, 0x53, 0xbb, 0x3e, 0xba, 0xaa, 0xfe, 0x7e, 0xe3, 0xcb, 0xb0, 0x26, 0x4b, 0xd2, 0xb0, 0x72, - 0xe9, 0x93, 0x86, 0xf2, 0x09, 0xf0, 0x65, 0xa8, 0xda, 0xe9, 0x55, 0xb5, 0x7c, 0x31, 0x55, 0x83, - 0xe5, 0xbc, 0x4a, 0x21, 0x14, 0x3f, 0x00, 0x3c, 0x8b, 0x32, 0xd0, 0x5c, 0x95, 0x83, 0x8c, 0x54, - 0x59, 0x37, 0x75, 0x89, 0xdf, 0x96, 0x01, 0x1a, 0xc6, 0xf1, 0x81, 0x86, 0xa6, 0x2d, 0x21, 0x3c, - 0xbb, 0xea, 0x0b, 0xf8, 0xd8, 0xf0, 0xe6, 0xed, 0x9a, 0x00, 0x2d, 0xb2, 0x39, 0x29, 0x7c, 0x7e, - 0x48, 0x73, 0x91, 0xa7, 0x10, 0x6a, 0x3d, 0xbb, 0xf5, 0x5c, 0x30, 0x47, 0xea, 0x37, 0xff, 0x8f, - 0x5a, 0x9a, 0x5e, 0x1d, 0x54, 0x91, 0x0e, 0x3e, 0x08, 0xcf, 0x23, 0x1d, 0xa4, 0xde, 0xf6, 0x5c, - 0xbf, 0xc3, 0xe1, 0xfa, 0xca, 0x3e, 0x73, 0x50, 0x44, 0x5f, 0xdd, 0x5c, 0x0b, 0x83, 0x34, 0xce, - 0x4b, 0xb0, 0xf2, 0x58, 0x5e, 0x48, 0xc7, 0x60, 0xaa, 0x82, 0x34, 0xce, 0xe3, 0x6b, 0x28, 0xa7, - 0x36, 0x1b, 0x56, 0x1b, 0x08, 0x99, 0x80, 0x30, 0x05, 0x84, 0x1c, 0x4d, 0x26, 0x68, 0x2f, 0x0e, - 0xdf, 0x40, 0x79, 0xc7, 0x75, 0x14, 0xe4, 0x3e, 0x5d, 0xe7, 0x85, 0xbf, 0x02, 0xea, 0xbf, 0x40, - 0xcd, 0x6f, 0xf4, 0xa6, 0xe8, 0x69, 0x6c, 0xe9, 0xbd, 0x86, 0xd2, 0xbf, 0xaf, 0x3d, 0xbe, 0x19, - 0x47, 0x93, 0x7f, 0x7c, 0x71, 0x04, 0x5f, 0x94, 0xd6, 0x71, 0xc9, 0x86, 0x78, 0x71, 0xeb, 0x38, - 0xdb, 0x09, 0x3f, 0x68, 0x28, 0x7b, 0x59, 0x16, 0xb8, 0xd5, 0xab, 0x83, 0x9c, 0x53, 0xc7, 0x60, - 0x01, 0x2f, 0x91, 0xfa, 0x46, 0x78, 0x01, 0x65, 0x95, 0x67, 0x04, 0xed, 0xeb, 0x71, 0x37, 0xca, - 0x56, 0x68, 0x17, 0x81, 0xe7, 0x50, 0xba, 0x09, 0xa3, 0x09, 0x2c, 0x4f, 0x37, 0xff, 0x8e, 0x90, - 0xe9, 0x3b, 0x10, 0xa3, 0x41, 0x46, 0x22, 0x1c, 0x70, 0x86, 0xe0, 0x16, 0x25, 0x10, 0xd2, 0x2d, - 0x68, 0x90, 0x29, 0xbd, 0xd3, 0xd0, 0x44, 0x74, 0x03, 0xbb, 0xf5, 0xb4, 0xa1, 0xf5, 0x96, 0x10, - 0x82, 0xd3, 0xb7, 0xc3, 0xa1, 0x45, 0xe7, 0x76, 0xdf, 0x0a, 0x74, 0x18, 0x65, 0x68, 0x02, 0x75, - 0x76, 0x0f, 0xd8, 0x40, 0xba, 0xfc, 0xe5, 0x1d, 0xab, 0xc6, 0xc0, 0x1c, 0x25, 0x6c, 0x2a, 0x82, - 0xe9, 0x1b, 0x2a, 0x41, 0x63, 0x8c, 0x79, 0xe5, 0xf0, 0xdb, 0xcc, 0xd8, 0x11, 0xac, 0xcf, 0xb0, - 0x0e, 0x4e, 0x66, 0xb4, 0x43, 0x58, 0x47, 0xb0, 0xbe, 0xc2, 0x7a, 0xfd, 0x7d, 0x66, 0x6c, 0x27, - 0xab, 0x06, 0xff, 0x23, 0x00, 0x00, 0xff, 0xff, 0x62, 0x32, 0x8a, 0x1f, 0x89, 0x0b, 0x00, 0x00, + // 815 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xec, 0x54, 0x41, 0x6b, 0xe3, 0x46, + 0x18, 0xb5, 0x62, 0xbb, 0xb1, 0xc6, 0x35, 0x6e, 0x54, 0x52, 0x84, 0xa1, 0xb2, 0xf1, 0xc9, 0x34, + 0xc9, 0x08, 0x9b, 0x86, 0xe6, 0xd0, 0x1e, 0xa2, 0x52, 0x4a, 0x68, 0x9a, 0x86, 0x09, 0x0d, 0x6d, + 0x68, 0x29, 0x63, 0x7b, 0xe2, 0x4c, 0x2d, 0x4b, 0x62, 0x66, 0xe4, 0xb6, 0xf4, 0x12, 0xf6, 0x17, + 0xec, 0xaf, 0xd8, 0xdb, 0x5e, 0xf6, 0xba, 0xb0, 0x87, 0x3d, 0xe5, 0xb0, 0x87, 0x1c, 0x97, 0x3d, + 0x98, 0x8d, 0xf6, 0x8f, 0x2c, 0x1a, 0x49, 0x96, 0x1d, 0xdb, 0x1b, 0x27, 0xb0, 0x81, 0x85, 0x3d, + 0x25, 0xf3, 0x7d, 0xef, 0xbd, 0xf9, 0xde, 0xe7, 0xd1, 0x03, 0x3b, 0xfd, 0x1d, 0x0e, 0xa9, 0x6b, + 0xf6, 0xfd, 0x36, 0x61, 0x0e, 0x11, 0x84, 0x9b, 0x5e, 0xbf, 0x67, 0x62, 0x8f, 0x72, 0x93, 0xb5, + 0x71, 0xc7, 0x1c, 0x36, 0xb1, 0xed, 0x9d, 0xe1, 0xa6, 0xd9, 0x23, 0x0e, 0x61, 0x58, 0x90, 0x2e, + 0xf4, 0x98, 0x2b, 0x5c, 0xad, 0x11, 0x31, 0x61, 0xca, 0x84, 0x5e, 0xbf, 0x07, 0x43, 0x26, 0x0c, + 0x99, 0x30, 0x61, 0x56, 0xb6, 0x7a, 0x54, 0x9c, 0xf9, 0x6d, 0xd8, 0x71, 0x07, 0x66, 0xcf, 0xed, + 0xb9, 0xa6, 0x14, 0x68, 0xfb, 0xa7, 0xf2, 0x24, 0x0f, 0xf2, 0xbf, 0x48, 0xb8, 0xd2, 0x5a, 0x38, + 0x92, 0xc9, 0x08, 0x77, 0x7d, 0xd6, 0x21, 0xd7, 0x87, 0xa9, 0x6c, 0x2f, 0xe6, 0xf8, 0xce, 0x90, + 0x30, 0x4e, 0x5d, 0x87, 0x74, 0x67, 0x68, 0x9b, 0x8b, 0x69, 0xc3, 0x19, 0xc7, 0x95, 0xad, 0xf9, + 0x68, 0xe6, 0x3b, 0x82, 0x0e, 0x66, 0x67, 0x6a, 0xce, 0x87, 0xfb, 0x82, 0xda, 0x26, 0x75, 0x04, + 0x17, 0xec, 0x3a, 0xa5, 0xfe, 0x5c, 0x01, 0xc5, 0xef, 0x6d, 0x9f, 0x0b, 0xc2, 0x90, 0x6b, 0x13, + 0xed, 0x37, 0x50, 0x18, 0x10, 0x81, 0xbb, 0x58, 0x60, 0x5d, 0xa9, 0x29, 0x8d, 0x62, 0xab, 0x01, + 0x17, 0xae, 0x1d, 0x0e, 0x9b, 0xf0, 0x97, 0xf6, 0xdf, 0xa4, 0x23, 0x7e, 0x26, 0x02, 0x5b, 0xda, + 0xc5, 0xa8, 0x9a, 0x09, 0x46, 0x55, 0x90, 0xd6, 0xd0, 0x58, 0x4d, 0xfb, 0x1d, 0xe4, 0x99, 0x6f, + 0x13, 0xae, 0xaf, 0xd4, 0xb2, 0x8d, 0x62, 0xeb, 0x6b, 0xb8, 0xec, 0xaf, 0x09, 0x0f, 0x5d, 0x9b, + 0x76, 0xfe, 0x43, 0xbe, 0x4d, 0xac, 0x52, 0x7c, 0x45, 0x3e, 0x3c, 0x71, 0x14, 0x29, 0xd6, 0x1f, + 0xaf, 0x00, 0x6d, 0xc2, 0x84, 0x45, 0x9d, 0x2e, 0x75, 0x7a, 0xef, 0xd1, 0xcb, 0x5f, 0xa0, 0xc0, + 0x7d, 0xd9, 0x48, 0xec, 0x34, 0x97, 0xb7, 0x73, 0x14, 0x31, 0xad, 0xcf, 0xe2, 0x2b, 0x0a, 0x71, + 0x81, 0xa3, 0xb1, 0xa8, 0xf6, 0x07, 0x58, 0x65, 0xae, 0x4d, 0x10, 0x39, 0xd5, 0xb3, 0x72, 0xf2, + 0x5b, 0xe8, 0xa3, 0x88, 0x68, 0x95, 0x63, 0xfd, 0xd5, 0xb8, 0x80, 0x12, 0xc9, 0xfa, 0x2b, 0x05, + 0x7c, 0x31, 0xbb, 0xaf, 0x7d, 0xca, 0x85, 0xf6, 0xe7, 0xcc, 0xce, 0xcc, 0x77, 0xec, 0x6c, 0xe2, + 0xa5, 0xc3, 0x90, 0x2e, 0x57, 0x37, 0xf6, 0x95, 0x54, 0x26, 0x16, 0x87, 0x41, 0x9e, 0x0a, 0x32, + 0x48, 0xb6, 0xf6, 0xed, 0xf2, 0xae, 0x66, 0xe7, 0x4d, 0x1f, 0xc3, 0x5e, 0x28, 0x89, 0x22, 0xe5, + 0xfa, 0x0b, 0x05, 0x94, 0x27, 0xc0, 0xf7, 0xe1, 0xea, 0x64, 0xda, 0xd5, 0xf6, 0xdd, 0x5c, 0xcd, + 0xb7, 0xf3, 0x20, 0x0b, 0x40, 0xfa, 0x01, 0x68, 0x55, 0x90, 0x1f, 0x12, 0xd6, 0xe6, 0xba, 0x52, + 0xcb, 0x36, 0x54, 0x4b, 0x0d, 0xf1, 0xc7, 0x61, 0x01, 0x45, 0x75, 0xed, 0x5c, 0x01, 0xeb, 0x58, + 0x08, 0x46, 0xdb, 0xbe, 0x20, 0x88, 0x70, 0xc1, 0x68, 0x47, 0x50, 0xd7, 0x09, 0x87, 0x0b, 0x8d, + 0x6f, 0x2c, 0x18, 0x2e, 0xce, 0x14, 0x88, 0xf0, 0x3f, 0x3f, 0xfc, 0x2b, 0x88, 0x13, 0xfa, 0xb7, + 0xbe, 0x8c, 0x47, 0x5a, 0xdf, 0x9d, 0xa7, 0x88, 0xe6, 0x5f, 0xa4, 0x6d, 0x00, 0x15, 0x7b, 0xf4, + 0x47, 0xe6, 0xfa, 0x1e, 0xd7, 0xb3, 0x72, 0xce, 0x52, 0x30, 0xaa, 0xaa, 0xbb, 0x87, 0x7b, 0x51, + 0x11, 0xa5, 0xfd, 0x10, 0x9c, 0x64, 0x2c, 0xd7, 0x73, 0x29, 0x18, 0x25, 0x45, 0x94, 0xf6, 0xb5, + 0x6f, 0x40, 0x29, 0x39, 0x1c, 0xe0, 0x01, 0xe1, 0x7a, 0x5e, 0x12, 0xd6, 0x82, 0x51, 0xb5, 0x84, + 0x26, 0x1b, 0x68, 0x1a, 0xa7, 0x7d, 0x07, 0xca, 0x8e, 0xeb, 0x24, 0x90, 0x5f, 0xd1, 0x3e, 0xd7, + 0x3f, 0x91, 0xd4, 0xcf, 0x83, 0x51, 0xb5, 0x7c, 0x30, 0xdd, 0x42, 0xd7, 0xb1, 0xf5, 0xa7, 0x0a, + 0xc8, 0x7d, 0xb8, 0xf1, 0xf8, 0x68, 0x05, 0x14, 0x3f, 0xe6, 0xe2, 0x12, 0xb9, 0x18, 0x46, 0xc7, + 0x3d, 0x07, 0xe2, 0xdd, 0xa3, 0xe3, 0xe6, 0x24, 0x7c, 0xa6, 0x80, 0xc2, 0x7d, 0x45, 0xe0, 0xd1, + 0xb4, 0x0f, 0x78, 0x4b, 0x1f, 0xf3, 0x0d, 0xfc, 0x0f, 0x92, 0xdf, 0x48, 0xdb, 0x04, 0x85, 0x24, + 0x33, 0xe4, 0xf8, 0x6a, 0x3a, 0x4d, 0x12, 0x2b, 0x68, 0x8c, 0xd0, 0x6a, 0x20, 0xd7, 0xa7, 0x4e, + 0x57, 0x46, 0x9e, 0x6a, 0x7d, 0x1a, 0x23, 0x73, 0x3f, 0x51, 0xa7, 0x8b, 0x64, 0x27, 0x44, 0x38, + 0x78, 0x40, 0xe4, 0x2b, 0x9a, 0x40, 0x84, 0x69, 0x81, 0x64, 0xa7, 0xfe, 0x44, 0x01, 0xab, 0xf1, + 0x0b, 0x1c, 0xeb, 0x29, 0x0b, 0xf5, 0x5a, 0x00, 0x60, 0x8f, 0x1e, 0x47, 0x4b, 0x8b, 0xef, 0x1d, + 0x7f, 0x2b, 0xbb, 0x87, 0x7b, 0x71, 0x07, 0x4d, 0xa0, 0x6e, 0x9e, 0x41, 0x33, 0x81, 0x1a, 0xfe, + 0xe5, 0x1e, 0xee, 0x10, 0x3d, 0x27, 0x61, 0x6b, 0x31, 0x4c, 0x3d, 0x48, 0x1a, 0x28, 0xc5, 0x58, + 0x5f, 0x5d, 0x5c, 0x19, 0x99, 0xcb, 0x2b, 0x23, 0xf3, 0xf2, 0xca, 0xc8, 0x9c, 0x07, 0x86, 0x72, + 0x11, 0x18, 0xca, 0x65, 0x60, 0x28, 0xaf, 0x03, 0x43, 0x79, 0xf8, 0xc6, 0xc8, 0x9c, 0x14, 0x92, + 0xc5, 0xbf, 0x0d, 0x00, 0x00, 0xff, 0xff, 0x62, 0x32, 0x8a, 0x1f, 0x89, 0x0b, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.proto similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.proto index ebb657c..09f11e3 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/generated.proto @@ -33,6 +33,7 @@ option go_package = "v1alpha1"; // ClusterRole is a cluster level, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding or ClusterRoleBinding. message ClusterRole { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Rules holds all the PolicyRules for this ClusterRole @@ -43,6 +44,7 @@ message ClusterRole { // and adds who information via Subject. message ClusterRoleBinding { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Subjects holds references to the objects the role applies to. @@ -56,6 +58,7 @@ message ClusterRoleBinding { // ClusterRoleBindingList is a collection of ClusterRoleBindings message ClusterRoleBindingList { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of ClusterRoleBindings @@ -65,6 +68,7 @@ message ClusterRoleBindingList { // ClusterRoleList is a collection of ClusterRoles message ClusterRoleList { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of ClusterRoles @@ -79,28 +83,34 @@ message PolicyRule { // AttributeRestrictions will vary depending on what the Authorizer/AuthorizationAttributeBuilder pair supports. // If the Authorizer does not recognize how to handle the AttributeRestrictions, the Authorizer should report an error. + // +optional optional k8s.io.kubernetes.pkg.runtime.RawExtension attributeRestrictions = 2; // APIGroups is the name of the APIGroup that contains the resources. If multiple API groups are specified, any action requested against one of // the enumerated resources in any API group will be allowed. + // +optional repeated string apiGroups = 3; // Resources is a list of resources this rule applies to. ResourceAll represents all resources. + // +optional repeated string resources = 4; // ResourceNames is an optional white list of names that the rule applies to. An empty set means that everything is allowed. + // +optional repeated string resourceNames = 5; // NonResourceURLs is a set of partial urls that a user should have access to. *s are allowed, but only as the full, final step in the path // This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. // Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. // Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"), but not both. + // +optional repeated string nonResourceURLs = 6; } // Role is a namespaced, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding. message Role { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Rules holds all the PolicyRules for this Role @@ -112,6 +122,7 @@ message Role { // namespace only have effect in that namespace. message RoleBinding { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Subjects holds references to the objects the role applies to. @@ -125,6 +136,7 @@ message RoleBinding { // RoleBindingList is a collection of RoleBindings message RoleBindingList { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of RoleBindings @@ -134,6 +146,7 @@ message RoleBindingList { // RoleList is a collection of Roles message RoleList { // Standard object's metadata. + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is a list of Roles @@ -160,6 +173,7 @@ message Subject { optional string kind = 1; // APIVersion holds the API group and version of the referenced object. + // +optional optional string apiVersion = 2; // Name of the object being referenced. @@ -167,6 +181,7 @@ message Subject { // Namespace of the referenced object. If the object kind is non-namespace, such as "User" or "Group", and this value is not empty // the Authorizer should report an error. + // +optional optional string namespace = 4; } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/register.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/register.go similarity index 90% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/register.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/register.go index 5b76247..0690711 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/watch/versioned" ) const GroupName = "rbac.authorization.k8s.io" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.generated.go index 4481709..3e0824d 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.generated.go @@ -25,10 +25,10 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg1_runtime "k8s.io/kubernetes/pkg/runtime" - pkg4_types "k8s.io/kubernetes/pkg/types" + pkg2_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_v1 "k8s.io/client-go/pkg/api/v1" + pkg1_runtime "k8s.io/client-go/pkg/runtime" + pkg4_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.go index 7223d88..a8b8b22 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types.go @@ -17,9 +17,9 @@ limitations under the License. package v1alpha1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" ) // Authorization is calculated against @@ -34,20 +34,25 @@ type PolicyRule struct { Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` // AttributeRestrictions will vary depending on what the Authorizer/AuthorizationAttributeBuilder pair supports. // If the Authorizer does not recognize how to handle the AttributeRestrictions, the Authorizer should report an error. + // +optional AttributeRestrictions runtime.RawExtension `json:"attributeRestrictions,omitempty" protobuf:"bytes,2,opt,name=attributeRestrictions"` // APIGroups is the name of the APIGroup that contains the resources. If multiple API groups are specified, any action requested against one of // the enumerated resources in any API group will be allowed. + // +optional APIGroups []string `json:"apiGroups,omitempty" protobuf:"bytes,3,rep,name=apiGroups"` // Resources is a list of resources this rule applies to. ResourceAll represents all resources. + // +optional Resources []string `json:"resources,omitempty" protobuf:"bytes,4,rep,name=resources"` // ResourceNames is an optional white list of names that the rule applies to. An empty set means that everything is allowed. + // +optional ResourceNames []string `json:"resourceNames,omitempty" protobuf:"bytes,5,rep,name=resourceNames"` // NonResourceURLs is a set of partial urls that a user should have access to. *s are allowed, but only as the full, final step in the path // This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. // Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. // Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"), but not both. + // +optional NonResourceURLs []string `json:"nonResourceURLs,omitempty" protobuf:"bytes,6,rep,name=nonResourceURLs"` } @@ -58,11 +63,13 @@ type Subject struct { // If the Authorizer does not recognized the kind value, the Authorizer should report an error. Kind string `json:"kind" protobuf:"bytes,1,opt,name=kind"` // APIVersion holds the API group and version of the referenced object. + // +optional APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt.name=apiVersion"` // Name of the object being referenced. Name string `json:"name" protobuf:"bytes,3,opt,name=name"` // Namespace of the referenced object. If the object kind is non-namespace, such as "User" or "Group", and this value is not empty // the Authorizer should report an error. + // +optional Namespace string `json:"namespace,omitempty" protobuf:"bytes,4,opt,name=namespace"` } @@ -82,6 +89,7 @@ type RoleRef struct { type Role struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Rules holds all the PolicyRules for this Role @@ -96,6 +104,7 @@ type Role struct { type RoleBinding struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Subjects holds references to the objects the role applies to. @@ -110,6 +119,7 @@ type RoleBinding struct { type RoleBindingList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of RoleBindings @@ -120,6 +130,7 @@ type RoleBindingList struct { type RoleList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of Roles @@ -133,6 +144,7 @@ type RoleList struct { type ClusterRole struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Rules holds all the PolicyRules for this ClusterRole @@ -147,6 +159,7 @@ type ClusterRole struct { type ClusterRoleBinding struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Subjects holds references to the objects the role applies to. @@ -161,6 +174,7 @@ type ClusterRoleBinding struct { type ClusterRoleBindingList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of ClusterRoleBindings @@ -171,6 +185,7 @@ type ClusterRoleBindingList struct { type ClusterRoleList struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is a list of ClusterRoles diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go index 95a777e..58efb7b 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1alpha1 import ( - api "k8s.io/kubernetes/pkg/api" - rbac "k8s.io/kubernetes/pkg/apis/rbac" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + rbac "k8s.io/client-go/pkg/apis/rbac" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -61,9 +60,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1alpha1_ClusterRole_To_rbac_ClusterRole(in *ClusterRole, out *rbac.ClusterRole, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -87,9 +83,6 @@ func Convert_v1alpha1_ClusterRole_To_rbac_ClusterRole(in *ClusterRole, out *rbac } func autoConvert_rbac_ClusterRole_To_v1alpha1_ClusterRole(in *rbac.ClusterRole, out *ClusterRole, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -113,9 +106,6 @@ func Convert_rbac_ClusterRole_To_v1alpha1_ClusterRole(in *rbac.ClusterRole, out } func autoConvert_v1alpha1_ClusterRoleBinding_To_rbac_ClusterRoleBinding(in *ClusterRoleBinding, out *rbac.ClusterRoleBinding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -142,9 +132,6 @@ func Convert_v1alpha1_ClusterRoleBinding_To_rbac_ClusterRoleBinding(in *ClusterR } func autoConvert_rbac_ClusterRoleBinding_To_v1alpha1_ClusterRoleBinding(in *rbac.ClusterRoleBinding, out *ClusterRoleBinding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -171,12 +158,7 @@ func Convert_rbac_ClusterRoleBinding_To_v1alpha1_ClusterRoleBinding(in *rbac.Clu } func autoConvert_v1alpha1_ClusterRoleBindingList_To_rbac_ClusterRoleBindingList(in *ClusterRoleBindingList, out *rbac.ClusterRoleBindingList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]rbac.ClusterRoleBinding, len(*in)) @@ -196,12 +178,7 @@ func Convert_v1alpha1_ClusterRoleBindingList_To_rbac_ClusterRoleBindingList(in * } func autoConvert_rbac_ClusterRoleBindingList_To_v1alpha1_ClusterRoleBindingList(in *rbac.ClusterRoleBindingList, out *ClusterRoleBindingList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ClusterRoleBinding, len(*in)) @@ -221,12 +198,7 @@ func Convert_rbac_ClusterRoleBindingList_To_v1alpha1_ClusterRoleBindingList(in * } func autoConvert_v1alpha1_ClusterRoleList_To_rbac_ClusterRoleList(in *ClusterRoleList, out *rbac.ClusterRoleList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]rbac.ClusterRole, len(*in)) @@ -246,12 +218,7 @@ func Convert_v1alpha1_ClusterRoleList_To_rbac_ClusterRoleList(in *ClusterRoleLis } func autoConvert_rbac_ClusterRoleList_To_v1alpha1_ClusterRoleList(in *rbac.ClusterRoleList, out *ClusterRoleList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]ClusterRole, len(*in)) @@ -303,9 +270,6 @@ func Convert_rbac_PolicyRule_To_v1alpha1_PolicyRule(in *rbac.PolicyRule, out *Po } func autoConvert_v1alpha1_Role_To_rbac_Role(in *Role, out *rbac.Role, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -329,9 +293,6 @@ func Convert_v1alpha1_Role_To_rbac_Role(in *Role, out *rbac.Role, s conversion.S } func autoConvert_rbac_Role_To_v1alpha1_Role(in *rbac.Role, out *Role, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -355,9 +316,6 @@ func Convert_rbac_Role_To_v1alpha1_Role(in *rbac.Role, out *Role, s conversion.S } func autoConvert_v1alpha1_RoleBinding_To_rbac_RoleBinding(in *RoleBinding, out *rbac.RoleBinding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -384,9 +342,6 @@ func Convert_v1alpha1_RoleBinding_To_rbac_RoleBinding(in *RoleBinding, out *rbac } func autoConvert_rbac_RoleBinding_To_v1alpha1_RoleBinding(in *rbac.RoleBinding, out *RoleBinding, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -413,12 +368,7 @@ func Convert_rbac_RoleBinding_To_v1alpha1_RoleBinding(in *rbac.RoleBinding, out } func autoConvert_v1alpha1_RoleBindingList_To_rbac_RoleBindingList(in *RoleBindingList, out *rbac.RoleBindingList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]rbac.RoleBinding, len(*in)) @@ -438,12 +388,7 @@ func Convert_v1alpha1_RoleBindingList_To_rbac_RoleBindingList(in *RoleBindingLis } func autoConvert_rbac_RoleBindingList_To_v1alpha1_RoleBindingList(in *rbac.RoleBindingList, out *RoleBindingList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]RoleBinding, len(*in)) @@ -463,12 +408,7 @@ func Convert_rbac_RoleBindingList_To_v1alpha1_RoleBindingList(in *rbac.RoleBindi } func autoConvert_v1alpha1_RoleList_To_rbac_RoleList(in *RoleList, out *rbac.RoleList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]rbac.Role, len(*in)) @@ -488,12 +428,7 @@ func Convert_v1alpha1_RoleList_To_rbac_RoleList(in *RoleList, out *rbac.RoleList } func autoConvert_rbac_RoleList_To_v1alpha1_RoleList(in *rbac.RoleList, out *RoleList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]Role, len(*in)) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go index d4d2dfc..0631bb7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package v1alpha1 import ( - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.defaults.go b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.defaults.go new file mode 100644 index 0000000..c41b12d --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/v1alpha1/zz_generated.defaults.go @@ -0,0 +1,58 @@ +// +build !ignore_autogenerated + +/* +Copyright 2016 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. +*/ + +// This file was autogenerated by defaulter-gen. Do not edit it manually! + +package v1alpha1 + +import ( + runtime "k8s.io/client-go/pkg/runtime" +) + +// RegisterDefaults adds defaulters functions to the given scheme. +// Public to allow building arbitrary schemes. +// All generated defaulters are covering - they call all nested defaulters. +func RegisterDefaults(scheme *runtime.Scheme) error { + scheme.AddTypeDefaultingFunc(&ClusterRoleBinding{}, func(obj interface{}) { SetObjectDefaults_ClusterRoleBinding(obj.(*ClusterRoleBinding)) }) + scheme.AddTypeDefaultingFunc(&ClusterRoleBindingList{}, func(obj interface{}) { SetObjectDefaults_ClusterRoleBindingList(obj.(*ClusterRoleBindingList)) }) + scheme.AddTypeDefaultingFunc(&RoleBinding{}, func(obj interface{}) { SetObjectDefaults_RoleBinding(obj.(*RoleBinding)) }) + scheme.AddTypeDefaultingFunc(&RoleBindingList{}, func(obj interface{}) { SetObjectDefaults_RoleBindingList(obj.(*RoleBindingList)) }) + return nil +} + +func SetObjectDefaults_ClusterRoleBinding(in *ClusterRoleBinding) { + SetDefaults_ClusterRoleBinding(in) +} + +func SetObjectDefaults_ClusterRoleBindingList(in *ClusterRoleBindingList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_ClusterRoleBinding(a) + } +} + +func SetObjectDefaults_RoleBinding(in *RoleBinding) { + SetDefaults_RoleBinding(in) +} + +func SetObjectDefaults_RoleBindingList(in *RoleBindingList) { + for i := range in.Items { + a := &in.Items[i] + SetObjectDefaults_RoleBinding(a) + } +} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/rbac/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/rbac/zz_generated.deepcopy.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/apis/rbac/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/rbac/zz_generated.deepcopy.go index a216d2c..253c151 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/rbac/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/rbac/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package rbac import ( - api "k8s.io/kubernetes/pkg/api" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/doc.go b/vendor/k8s.io/client-go/pkg/apis/storage/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/doc.go rename to vendor/k8s.io/client-go/pkg/apis/storage/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/install/install.go b/vendor/k8s.io/client-go/pkg/apis/storage/install/install.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/install/install.go rename to vendor/k8s.io/client-go/pkg/apis/storage/install/install.go index b46c4d6..4fc5ac7 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/install/install.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/install/install.go @@ -19,10 +19,10 @@ limitations under the License. package install import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/storage" - "k8s.io/kubernetes/pkg/apis/storage/v1beta1" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/apimachinery/announced" + "k8s.io/client-go/pkg/apis/storage" + "k8s.io/client-go/pkg/apis/storage/v1beta1" + "k8s.io/client-go/pkg/util/sets" ) func init() { @@ -30,7 +30,7 @@ func init() { &announced.GroupMetaFactoryArgs{ GroupName: storage.GroupName, VersionPreferenceOrder: []string{v1beta1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/storage", + ImportPrefix: "k8s.io/client-go/pkg/apis/storage", RootScopedKinds: sets.NewString("StorageClass"), AddInternalObjectsToScheme: storage.AddToScheme, }, diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/register.go b/vendor/k8s.io/client-go/pkg/apis/storage/register.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/register.go rename to vendor/k8s.io/client-go/pkg/apis/storage/register.go index 2da8d17..a924b77 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/register.go @@ -17,9 +17,9 @@ limitations under the License. package storage import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/storage/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/storage/types.generated.go index 25c4b04..9d8d7bf 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg2_api "k8s.io/kubernetes/pkg/api" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg2_api "k8s.io/client-go/pkg/api" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/types.go b/vendor/k8s.io/client-go/pkg/apis/storage/types.go similarity index 93% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/types.go rename to vendor/k8s.io/client-go/pkg/apis/storage/types.go index be0831a..4d4a18f 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/types.go @@ -17,8 +17,8 @@ limitations under the License. package storage import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" ) // +genclient=true @@ -32,7 +32,8 @@ import ( // The name of a StorageClass object is significant, and is how users can request a particular class. type StorageClass struct { unversioned.TypeMeta `json:",inline"` - api.ObjectMeta `json:"metadata,omitempty"` + // +optional + api.ObjectMeta `json:"metadata,omitempty"` // provisioner is the driver expected to handle this StorageClass. // This is an optionally-prefixed name, like a label key. @@ -45,6 +46,7 @@ type StorageClass struct { // to the provisioner. The only validation done on keys is that they are // not empty. The maximum number of parameters is // 512, with a cumulative max size of 256K + // +optional Parameters map[string]string `json:"parameters,omitempty"` } @@ -53,6 +55,7 @@ type StorageClassList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty"` // Items is the list of StorageClasses diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/doc.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/doc.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/doc.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/doc.go index c560310..a25066e 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/doc.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/doc.go @@ -18,4 +18,5 @@ limitations under the License. // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/storage // +groupName=storage.k8s.io // +k8s:openapi-gen=true +// +k8s:defaulter-gen=TypeMeta package v1beta1 diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.pb.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.pb.go similarity index 84% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.pb.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.pb.go index ef2f23d..8ec0b14 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.pb.go @@ -58,8 +58,8 @@ func (*StorageClassList) ProtoMessage() {} func (*StorageClassList) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{1} } func init() { - proto.RegisterType((*StorageClass)(nil), "k8s.io.kubernetes.pkg.apis.storage.v1beta1.StorageClass") - proto.RegisterType((*StorageClassList)(nil), "k8s.io.kubernetes.pkg.apis.storage.v1beta1.StorageClassList") + proto.RegisterType((*StorageClass)(nil), "k8s.io.client-go.pkg.apis.storage.v1beta1.StorageClass") + proto.RegisterType((*StorageClassList)(nil), "k8s.io.client-go.pkg.apis.storage.v1beta1.StorageClassList") } func (m *StorageClass) Marshal() (data []byte, err error) { size := m.Size() @@ -696,34 +696,34 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 455 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x9c, 0x92, 0x4d, 0x6b, 0x13, 0x41, - 0x18, 0xc7, 0xb3, 0x09, 0xc1, 0x76, 0xa2, 0x18, 0x46, 0x0f, 0x61, 0x0f, 0x69, 0xe9, 0xa9, 0x8a, - 0x9d, 0x21, 0x85, 0x42, 0x28, 0x78, 0x59, 0x11, 0x14, 0x14, 0xcb, 0x7a, 0x11, 0xa1, 0x87, 0xd9, - 0xe4, 0x71, 0x1d, 0x37, 0xbb, 0xb3, 0xcc, 0xcb, 0x42, 0xc1, 0x83, 0x1f, 0xc1, 0x8f, 0x95, 0x63, - 0x8e, 0x1e, 0xa4, 0x68, 0xfd, 0x22, 0xce, 0xbe, 0xd8, 0x5d, 0xb2, 0x59, 0x11, 0x0f, 0x0f, 0xcc, - 0xdb, 0xef, 0xff, 0xfc, 0x9f, 0x3f, 0x83, 0xce, 0xa3, 0xb9, 0x22, 0x5c, 0xd0, 0xc8, 0x04, 0x20, - 0x13, 0xd0, 0xa0, 0x68, 0x1a, 0x85, 0x94, 0xa5, 0x5c, 0x51, 0xa5, 0x85, 0x64, 0x21, 0xd0, 0x6c, - 0x16, 0x80, 0x66, 0x33, 0x1a, 0x42, 0x02, 0x92, 0x69, 0x58, 0x92, 0x54, 0x0a, 0x2d, 0xf0, 0xe3, - 0x92, 0x25, 0x35, 0x4b, 0x2c, 0x4b, 0x72, 0x96, 0x54, 0x2c, 0xa9, 0x58, 0xf7, 0x24, 0xe4, 0xfa, - 0xa3, 0x09, 0xc8, 0x42, 0xc4, 0x34, 0x14, 0xa1, 0xa0, 0x85, 0x44, 0x60, 0x3e, 0x14, 0xbb, 0x62, - 0x53, 0xac, 0x4a, 0x69, 0xf7, 0xb4, 0xd3, 0x16, 0x95, 0xa0, 0x84, 0x91, 0x0b, 0xd8, 0xb6, 0xe3, - 0x9e, 0x75, 0x33, 0x26, 0xc9, 0x40, 0x2a, 0x2e, 0x12, 0x58, 0xb6, 0xb0, 0x27, 0xdd, 0x58, 0xd6, - 0x9a, 0xd9, 0x3d, 0xd9, 0xfd, 0x5a, 0x9a, 0x44, 0xf3, 0xb8, 0xed, 0x69, 0xb6, 0xfb, 0xb9, 0xd1, - 0x7c, 0x45, 0x79, 0xa2, 0x95, 0x96, 0xdb, 0xc8, 0xd1, 0xf7, 0x3e, 0xba, 0xfb, 0xb6, 0x4c, 0xef, - 0xd9, 0x8a, 0x29, 0x85, 0xdf, 0xa1, 0xbd, 0xd8, 0x66, 0xb8, 0x64, 0x9a, 0x4d, 0x9c, 0x43, 0xe7, - 0x78, 0x74, 0x7a, 0x4c, 0x3a, 0x93, 0xb7, 0x81, 0x93, 0x37, 0xc1, 0x27, 0x58, 0xe8, 0xd7, 0x96, - 0xf1, 0xf0, 0xfa, 0xfa, 0xa0, 0x77, 0x73, 0x7d, 0x80, 0xea, 0x33, 0xff, 0x56, 0x0d, 0x9f, 0xa1, - 0x91, 0xed, 0x99, 0xf1, 0x22, 0x19, 0x39, 0xe9, 0x5b, 0xf1, 0x7d, 0xef, 0x41, 0x85, 0x8c, 0x2e, - 0xea, 0x2b, 0xbf, 0xf9, 0x0e, 0x7f, 0x46, 0x28, 0x65, 0x92, 0x59, 0x19, 0x1b, 0xea, 0x64, 0x70, - 0x38, 0xb0, 0x96, 0x5e, 0x90, 0x7f, 0xff, 0x0c, 0xa4, 0x39, 0x1e, 0xb9, 0xb8, 0x95, 0x7a, 0x9e, - 0x68, 0x79, 0x55, 0x5b, 0xae, 0x2f, 0xfc, 0x46, 0x3f, 0xf7, 0x29, 0xba, 0xbf, 0x85, 0xe0, 0x31, - 0x1a, 0x44, 0x70, 0x55, 0x84, 0xb3, 0xef, 0xe7, 0x4b, 0xfc, 0x10, 0x0d, 0x33, 0xb6, 0x32, 0x50, - 0xce, 0xe4, 0x97, 0x9b, 0xf3, 0xfe, 0xdc, 0x39, 0xda, 0x38, 0x68, 0xdc, 0xec, 0xff, 0x8a, 0x2b, - 0x8d, 0x2f, 0x5b, 0x11, 0xd3, 0xbf, 0x44, 0xdc, 0xf8, 0x4d, 0x24, 0xc7, 0x8b, 0xa4, 0xc7, 0x95, - 0xed, 0xbd, 0x3f, 0x27, 0x8d, 0x9c, 0x2f, 0xd1, 0x90, 0x6b, 0x88, 0x95, 0x75, 0x93, 0x67, 0x35, - 0xff, 0xdf, 0xac, 0xbc, 0x7b, 0x55, 0x93, 0xe1, 0xcb, 0x5c, 0xce, 0x2f, 0x55, 0xbd, 0x47, 0xeb, - 0x9f, 0xd3, 0xde, 0xc6, 0xd6, 0x37, 0x5b, 0x5f, 0x6e, 0xa6, 0xce, 0xda, 0xd6, 0xc6, 0xd6, 0x0f, - 0x5b, 0x5f, 0x7f, 0x4d, 0x7b, 0xef, 0xef, 0x54, 0x6a, 0xbf, 0x03, 0x00, 0x00, 0xff, 0xff, 0x86, - 0x21, 0xa9, 0x43, 0xef, 0x03, 0x00, 0x00, + // 462 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x9c, 0x92, 0xcf, 0x8b, 0xd3, 0x40, + 0x14, 0xc7, 0x33, 0x2d, 0xc5, 0xdd, 0xa9, 0x62, 0x89, 0x1e, 0x4a, 0x0e, 0xd9, 0xb2, 0xa7, 0x2a, + 0xee, 0x0c, 0x2d, 0x2c, 0x94, 0x05, 0x2f, 0x15, 0x41, 0x41, 0x71, 0x89, 0x17, 0x11, 0xf6, 0x30, + 0x69, 0x9f, 0x71, 0x4c, 0x93, 0x09, 0x33, 0x2f, 0x81, 0x05, 0x0f, 0xfe, 0x09, 0xfe, 0x59, 0x3d, + 0xf6, 0xe8, 0x41, 0x16, 0x1b, 0xff, 0x11, 0x69, 0x12, 0x37, 0xa1, 0x3f, 0x44, 0xf6, 0x36, 0x6f, + 0xe6, 0x7d, 0xbe, 0xef, 0xfb, 0xbe, 0x0c, 0xbd, 0x08, 0x27, 0x86, 0x49, 0xc5, 0xc3, 0xd4, 0x07, + 0x1d, 0x03, 0x82, 0xe1, 0x49, 0x18, 0x70, 0x91, 0x48, 0xc3, 0x0d, 0x2a, 0x2d, 0x02, 0xe0, 0xd9, + 0xc8, 0x07, 0x14, 0x23, 0x1e, 0x40, 0x0c, 0x5a, 0x20, 0xcc, 0x59, 0xa2, 0x15, 0x2a, 0xfb, 0x69, + 0xc9, 0xb2, 0x9a, 0x65, 0x49, 0x18, 0xb0, 0x0d, 0xcb, 0x2a, 0x96, 0x55, 0xac, 0x73, 0x16, 0x48, + 0xfc, 0x9c, 0xfa, 0x6c, 0xa6, 0x22, 0x1e, 0xa8, 0x40, 0xf1, 0x42, 0xc2, 0x4f, 0x3f, 0x15, 0x55, + 0x51, 0x14, 0xa7, 0x52, 0xda, 0x19, 0x1f, 0xb4, 0xc5, 0x35, 0x18, 0x95, 0xea, 0x19, 0x6c, 0xdb, + 0x71, 0xce, 0x0f, 0x33, 0x69, 0x9c, 0x81, 0x36, 0x52, 0xc5, 0x30, 0xdf, 0xc1, 0x9e, 0x1d, 0xc6, + 0xb2, 0x9d, 0x9d, 0x9d, 0xb3, 0xfd, 0xdd, 0x3a, 0x8d, 0x51, 0x46, 0xbb, 0x9e, 0x46, 0xfb, 0xdb, + 0x53, 0x94, 0x0b, 0x2e, 0x63, 0x34, 0xa8, 0xb7, 0x91, 0xd3, 0x9f, 0x2d, 0x7a, 0xff, 0x7d, 0x99, + 0xde, 0x8b, 0x85, 0x30, 0xc6, 0xfe, 0x40, 0x8f, 0x22, 0x40, 0x31, 0x17, 0x28, 0xfa, 0x64, 0x40, + 0x86, 0xdd, 0xf1, 0x90, 0x1d, 0x4c, 0x9e, 0x65, 0x23, 0xf6, 0xce, 0xff, 0x02, 0x33, 0x7c, 0x0b, + 0x28, 0xa6, 0xf6, 0xf2, 0xe6, 0xc4, 0xca, 0x6f, 0x4e, 0x68, 0x7d, 0xe7, 0xdd, 0xaa, 0xd9, 0xe7, + 0xb4, 0x9b, 0x68, 0x95, 0xc9, 0x22, 0x19, 0xdd, 0x6f, 0x0d, 0xc8, 0xf0, 0x78, 0xfa, 0xa8, 0x42, + 0xba, 0x97, 0xf5, 0x93, 0xd7, 0xec, 0xb3, 0xbf, 0x52, 0x9a, 0x08, 0x2d, 0x22, 0x40, 0xd0, 0xa6, + 0xdf, 0x1e, 0xb4, 0x87, 0xdd, 0xf1, 0x2b, 0xf6, 0xff, 0x9f, 0x81, 0x35, 0xd7, 0x63, 0x97, 0xb7, + 0x52, 0x2f, 0x63, 0xd4, 0xd7, 0xb5, 0xe5, 0xfa, 0xc1, 0x6b, 0xcc, 0x73, 0x9e, 0xd3, 0x87, 0x5b, + 0x88, 0xdd, 0xa3, 0xed, 0x10, 0xae, 0x8b, 0x70, 0x8e, 0xbd, 0xcd, 0xd1, 0x7e, 0x4c, 0x3b, 0x99, + 0x58, 0xa4, 0x50, 0xee, 0xe4, 0x95, 0xc5, 0x45, 0x6b, 0x42, 0x4e, 0x57, 0x84, 0xf6, 0x9a, 0xf3, + 0xdf, 0x48, 0x83, 0xf6, 0xd5, 0x4e, 0xc4, 0xfc, 0x1f, 0x11, 0x37, 0x7e, 0x13, 0xdb, 0xe0, 0x45, + 0xd2, 0xbd, 0xca, 0xf6, 0xd1, 0xdf, 0x9b, 0x46, 0xce, 0x57, 0xb4, 0x23, 0x11, 0x22, 0xd3, 0x6f, + 0x15, 0x59, 0x4d, 0xee, 0x9a, 0xd5, 0xf4, 0x41, 0x35, 0xa4, 0xf3, 0x7a, 0x23, 0xe7, 0x95, 0xaa, + 0xd3, 0x27, 0xcb, 0xb5, 0x6b, 0xad, 0xd6, 0xae, 0xf5, 0x63, 0xed, 0x5a, 0xdf, 0x72, 0x97, 0x2c, + 0x73, 0x97, 0xac, 0x72, 0x97, 0xfc, 0xca, 0x5d, 0xf2, 0xfd, 0xb7, 0x6b, 0x7d, 0xbc, 0x57, 0xa9, + 0xfd, 0x09, 0x00, 0x00, 0xff, 0xff, 0x86, 0x21, 0xa9, 0x43, 0xef, 0x03, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.proto b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.proto similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.proto rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.proto index dbcdcc3..bdc0631 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/generated.proto +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/generated.proto @@ -38,6 +38,7 @@ option go_package = "v1beta1"; message StorageClass { // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.v1.ObjectMeta metadata = 1; // Provisioner indicates the type of the provisioner. @@ -45,6 +46,7 @@ message StorageClass { // Parameters holds the parameters for the provisioner that should // create volumes of this storage class. + // +optional map parameters = 3; } @@ -52,6 +54,7 @@ message StorageClass { message StorageClassList { // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional optional k8s.io.kubernetes.pkg.api.unversioned.ListMeta metadata = 1; // Items is the list of StorageClasses diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/register.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/register.go similarity index 88% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/register.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/register.go index e850a63..0408811 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/register.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/register.go @@ -17,10 +17,10 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - "k8s.io/kubernetes/pkg/runtime" - versionedwatch "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + "k8s.io/client-go/pkg/runtime" + versionedwatch "k8s.io/client-go/pkg/watch/versioned" ) // GroupName is the group name use in this package diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.generated.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.generated.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.generated.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.generated.go index 7f59ec8..39e9245 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.generated.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.generated.go @@ -25,9 +25,9 @@ import ( "errors" "fmt" codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_v1 "k8s.io/kubernetes/pkg/api/v1" - pkg3_types "k8s.io/kubernetes/pkg/types" + pkg1_unversioned "k8s.io/client-go/pkg/api/unversioned" + pkg2_v1 "k8s.io/client-go/pkg/api/v1" + pkg3_types "k8s.io/client-go/pkg/types" "reflect" "runtime" time "time" diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.go index a0c4a6d..c48bfde 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types.go @@ -17,8 +17,8 @@ limitations under the License. package v1beta1 import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" ) // +genclient=true @@ -33,6 +33,7 @@ type StorageClass struct { unversioned.TypeMeta `json:",inline"` // Standard object's metadata. // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional v1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Provisioner indicates the type of the provisioner. @@ -40,6 +41,7 @@ type StorageClass struct { // Parameters holds the parameters for the provisioner that should // create volumes of this storage class. + // +optional Parameters map[string]string `json:"parameters,omitempty" protobuf:"bytes,3,rep,name=parameters"` } @@ -48,6 +50,7 @@ type StorageClassList struct { unversioned.TypeMeta `json:",inline"` // Standard list metadata // More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#metadata + // +optional unversioned.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` // Items is the list of StorageClasses diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types_swagger_doc_generated.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types_swagger_doc_generated.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/types_swagger_doc_generated.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/types_swagger_doc_generated.go diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.conversion.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.conversion.go similarity index 79% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.conversion.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.conversion.go index 521b053..8cb5a5a 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.conversion.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.conversion.go @@ -21,10 +21,9 @@ limitations under the License. package v1beta1 import ( - api "k8s.io/kubernetes/pkg/api" - storage "k8s.io/kubernetes/pkg/apis/storage" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + storage "k8s.io/client-go/pkg/apis/storage" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" ) func init() { @@ -43,9 +42,6 @@ func RegisterConversions(scheme *runtime.Scheme) error { } func autoConvert_v1beta1_StorageClass_To_storage_StorageClass(in *StorageClass, out *storage.StorageClass, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -60,9 +56,6 @@ func Convert_v1beta1_StorageClass_To_storage_StorageClass(in *StorageClass, out } func autoConvert_storage_StorageClass_To_v1beta1_StorageClass(in *storage.StorageClass, out *StorageClass, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } // TODO: Inefficient conversion - can we improve it? if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { return err @@ -77,12 +70,7 @@ func Convert_storage_StorageClass_To_v1beta1_StorageClass(in *storage.StorageCla } func autoConvert_v1beta1_StorageClassList_To_storage_StorageClassList(in *StorageClassList, out *storage.StorageClassList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]storage.StorageClass, len(*in)) @@ -102,12 +90,7 @@ func Convert_v1beta1_StorageClassList_To_storage_StorageClassList(in *StorageCla } func autoConvert_storage_StorageClassList_To_v1beta1_StorageClassList(in *storage.StorageClassList, out *StorageClassList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } + out.ListMeta = in.ListMeta if in.Items != nil { in, out := &in.Items, &out.Items *out = make([]StorageClass, len(*in)) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go index d9e7ed0..05b9fec 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/v1beta1/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package v1beta1 import ( - v1 "k8s.io/kubernetes/pkg/api/v1" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + v1 "k8s.io/client-go/pkg/api/v1" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/storage/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/apis/storage/zz_generated.deepcopy.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/apis/storage/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/apis/storage/zz_generated.deepcopy.go index 7542669..a1c1817 100644 --- a/vendor/k8s.io/kubernetes/pkg/apis/storage/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/apis/storage/zz_generated.deepcopy.go @@ -21,9 +21,9 @@ limitations under the License. package storage import ( - api "k8s.io/kubernetes/pkg/api" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" + api "k8s.io/client-go/pkg/api" + conversion "k8s.io/client-go/pkg/conversion" + runtime "k8s.io/client-go/pkg/runtime" reflect "reflect" ) diff --git a/vendor/k8s.io/kubernetes/pkg/auth/user/doc.go b/vendor/k8s.io/client-go/pkg/auth/user/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/auth/user/doc.go rename to vendor/k8s.io/client-go/pkg/auth/user/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/auth/user/user.go b/vendor/k8s.io/client-go/pkg/auth/user/user.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/auth/user/user.go rename to vendor/k8s.io/client-go/pkg/auth/user/user.go diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/OWNERS b/vendor/k8s.io/client-go/pkg/conversion/OWNERS similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/OWNERS rename to vendor/k8s.io/client-go/pkg/conversion/OWNERS diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/cloner.go b/vendor/k8s.io/client-go/pkg/conversion/cloner.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/cloner.go rename to vendor/k8s.io/client-go/pkg/conversion/cloner.go diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/converter.go b/vendor/k8s.io/client-go/pkg/conversion/converter.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/conversion/converter.go rename to vendor/k8s.io/client-go/pkg/conversion/converter.go index 8941b18..9ab468e 100644 --- a/vendor/k8s.io/kubernetes/pkg/conversion/converter.go +++ b/vendor/k8s.io/client-go/pkg/conversion/converter.go @@ -431,10 +431,10 @@ func (c *Converter) SetStructFieldCopy(srcFieldType interface{}, srcFieldName st } // RegisterDefaultingFunc registers a value-defaulting func with the Converter. -// defaultingFunc must take one parameters: a pointer to the input type. +// defaultingFunc must take one parameter: a pointer to the input type. // // Example: -// c.RegisteDefaultingFunc( +// c.RegisterDefaultingFunc( // func(in *v1.Pod) { // // defaulting logic... // }) diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/deep_equal.go b/vendor/k8s.io/client-go/pkg/conversion/deep_equal.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/conversion/deep_equal.go rename to vendor/k8s.io/client-go/pkg/conversion/deep_equal.go index 6bfc870..d1cf931 100644 --- a/vendor/k8s.io/kubernetes/pkg/conversion/deep_equal.go +++ b/vendor/k8s.io/client-go/pkg/conversion/deep_equal.go @@ -17,7 +17,7 @@ limitations under the License. package conversion import ( - "k8s.io/kubernetes/third_party/forked/golang/reflect" + "k8s.io/client-go/pkg/third_party/forked/golang/reflect" ) // The code for this type must be located in third_party, since it forks from diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/doc.go b/vendor/k8s.io/client-go/pkg/conversion/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/doc.go rename to vendor/k8s.io/client-go/pkg/conversion/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/helper.go b/vendor/k8s.io/client-go/pkg/conversion/helper.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/helper.go rename to vendor/k8s.io/client-go/pkg/conversion/helper.go diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/queryparams/convert.go b/vendor/k8s.io/client-go/pkg/conversion/queryparams/convert.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/queryparams/convert.go rename to vendor/k8s.io/client-go/pkg/conversion/queryparams/convert.go diff --git a/vendor/k8s.io/kubernetes/pkg/conversion/queryparams/doc.go b/vendor/k8s.io/client-go/pkg/conversion/queryparams/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/conversion/queryparams/doc.go rename to vendor/k8s.io/client-go/pkg/conversion/queryparams/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/fields/doc.go b/vendor/k8s.io/client-go/pkg/fields/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/fields/doc.go rename to vendor/k8s.io/client-go/pkg/fields/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/fields/fields.go b/vendor/k8s.io/client-go/pkg/fields/fields.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/fields/fields.go rename to vendor/k8s.io/client-go/pkg/fields/fields.go diff --git a/vendor/k8s.io/kubernetes/pkg/fields/requirements.go b/vendor/k8s.io/client-go/pkg/fields/requirements.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/fields/requirements.go rename to vendor/k8s.io/client-go/pkg/fields/requirements.go index 33c6e4e..fdf81c1 100644 --- a/vendor/k8s.io/kubernetes/pkg/fields/requirements.go +++ b/vendor/k8s.io/client-go/pkg/fields/requirements.go @@ -16,7 +16,7 @@ limitations under the License. package fields -import "k8s.io/kubernetes/pkg/selection" +import "k8s.io/client-go/pkg/selection" // Requirements is AND of all requirements. type Requirements []Requirement diff --git a/vendor/k8s.io/kubernetes/pkg/fields/selector.go b/vendor/k8s.io/client-go/pkg/fields/selector.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/fields/selector.go rename to vendor/k8s.io/client-go/pkg/fields/selector.go index 75161da..836e8ba 100644 --- a/vendor/k8s.io/kubernetes/pkg/fields/selector.go +++ b/vendor/k8s.io/client-go/pkg/fields/selector.go @@ -21,7 +21,7 @@ import ( "sort" "strings" - "k8s.io/kubernetes/pkg/selection" + "k8s.io/client-go/pkg/selection" ) // Selector represents a field selector. diff --git a/vendor/k8s.io/kubernetes/pkg/genericapiserver/openapi/common/common.go b/vendor/k8s.io/client-go/pkg/genericapiserver/openapi/common/common.go similarity index 83% rename from vendor/k8s.io/kubernetes/pkg/genericapiserver/openapi/common/common.go rename to vendor/k8s.io/client-go/pkg/genericapiserver/openapi/common/common.go index 3bcc744..d2a80f2 100644 --- a/vendor/k8s.io/kubernetes/pkg/genericapiserver/openapi/common/common.go +++ b/vendor/k8s.io/client-go/pkg/genericapiserver/openapi/common/common.go @@ -45,9 +45,15 @@ type Config struct { // Info is general information about the API. Info *spec.Info + // DefaultResponse will be used if an operation does not have any responses listed. It // will show up as ... "responses" : {"default" : $DefaultResponse} in the spec. DefaultResponse *spec.Response + + // CommonResponses will be added as a response to all operation specs. This is a good place to add common + // responses such as authorization failed. + CommonResponses map[int]spec.Response + // List of webservice's path prefixes to ignore IgnorePrefixes []string @@ -55,8 +61,16 @@ type Config struct { // or any of the models will result in spec generation failure. Definitions *OpenAPIDefinitions - // GetOperationID returns operation id for a restful route. It is an optional function to customize operation IDs. - GetOperationID func(servePath string, r *restful.Route) (string, error) + // GetOperationIDAndTags returns operation id and tags for a restful route. It is an optional function to customize operation IDs. + GetOperationIDAndTags func(servePath string, r *restful.Route) (string, []string, error) + + // SecurityDefinitions is list of all security definitions for OpenAPI service. If this is not nil, the user of config + // is responsible to provide DefaultSecurity and (maybe) add unauthorized response to CommonResponses. + SecurityDefinitions *spec.SecurityDefinitions + + // DefaultSecurity for all operations. This will pass as spec.SwaggerProps.Security to OpenAPI. + // For most cases, this will be list of acceptable definitions in SecurityDefinitions. + DefaultSecurity []map[string][]string } // This function is a reference for converting go (or any custom type) to a simple open API type,format pair. There are diff --git a/vendor/k8s.io/kubernetes/pkg/genericapiserver/openapi/common/doc.go b/vendor/k8s.io/client-go/pkg/genericapiserver/openapi/common/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/genericapiserver/openapi/common/doc.go rename to vendor/k8s.io/client-go/pkg/genericapiserver/openapi/common/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/labels/doc.go b/vendor/k8s.io/client-go/pkg/labels/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/labels/doc.go rename to vendor/k8s.io/client-go/pkg/labels/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/labels/labels.go b/vendor/k8s.io/client-go/pkg/labels/labels.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/labels/labels.go rename to vendor/k8s.io/client-go/pkg/labels/labels.go diff --git a/vendor/k8s.io/kubernetes/pkg/labels/selector.go b/vendor/k8s.io/client-go/pkg/labels/selector.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/labels/selector.go rename to vendor/k8s.io/client-go/pkg/labels/selector.go index 703cf7a..d14f6f9 100644 --- a/vendor/k8s.io/kubernetes/pkg/labels/selector.go +++ b/vendor/k8s.io/client-go/pkg/labels/selector.go @@ -24,9 +24,9 @@ import ( "strings" "github.com/golang/glog" - "k8s.io/kubernetes/pkg/selection" - "k8s.io/kubernetes/pkg/util/sets" - "k8s.io/kubernetes/pkg/util/validation" + "k8s.io/client-go/pkg/selection" + "k8s.io/client-go/pkg/util/sets" + "k8s.io/client-go/pkg/util/validation" ) // Requirements is AND of all requirements. @@ -91,9 +91,12 @@ func (a ByKey) Less(i, j int) bool { return a[i].key < a[j].key } // Requirement implements both set based match and exact match // Requirement should be initialized via NewRequirement constructor for creating a valid Requirement. type Requirement struct { - key string - operator selection.Operator - strValues sets.String + key string + operator selection.Operator + // In huge majority of cases we have at most one value here. + // It is generally faster to operate on a single-element slice + // than on a single-element map, so we have a slice here. + strValues []string } // NewRequirement is the constructor for a Requirement. @@ -107,7 +110,7 @@ type Requirement struct { // of characters. See validateLabelKey for more details. // // The empty string is a valid value in the input values set. -func NewRequirement(key string, op selection.Operator, vals sets.String) (*Requirement, error) { +func NewRequirement(key string, op selection.Operator, vals []string) (*Requirement, error) { if err := validateLabelKey(key); err != nil { return nil, err } @@ -128,8 +131,8 @@ func NewRequirement(key string, op selection.Operator, vals sets.String) (*Requi if len(vals) != 1 { return nil, fmt.Errorf("for 'Gt', 'Lt' operators, exactly one value is required") } - for val := range vals { - if _, err := strconv.ParseInt(val, 10, 64); err != nil { + for i := range vals { + if _, err := strconv.ParseInt(vals[i], 10, 64); err != nil { return nil, fmt.Errorf("for 'Gt', 'Lt' operators, the value must be an integer") } } @@ -137,14 +140,24 @@ func NewRequirement(key string, op selection.Operator, vals sets.String) (*Requi return nil, fmt.Errorf("operator '%v' is not recognized", op) } - for v := range vals { - if err := validateLabelValue(v); err != nil { + for i := range vals { + if err := validateLabelValue(vals[i]); err != nil { return nil, err } } + sort.Strings(vals) return &Requirement{key: key, operator: op, strValues: vals}, nil } +func (r *Requirement) hasValue(value string) bool { + for i := range r.strValues { + if r.strValues[i] == value { + return true + } + } + return false +} + // Matches returns true if the Requirement matches the input Labels. // There is a match in the following cases: // (1) The operator is Exists and Labels has the Requirement's key. @@ -162,12 +175,12 @@ func (r *Requirement) Matches(ls Labels) bool { if !ls.Has(r.key) { return false } - return r.strValues.Has(ls.Get(r.key)) + return r.hasValue(ls.Get(r.key)) case selection.NotIn, selection.NotEquals: if !ls.Has(r.key) { return true } - return !r.strValues.Has(ls.Get(r.key)) + return !r.hasValue(ls.Get(r.key)) case selection.Exists: return ls.Has(r.key) case selection.DoesNotExist: @@ -189,10 +202,10 @@ func (r *Requirement) Matches(ls Labels) bool { } var rValue int64 - for strValue := range r.strValues { - rValue, err = strconv.ParseInt(strValue, 10, 64) + for i := range r.strValues { + rValue, err = strconv.ParseInt(r.strValues[i], 10, 64) if err != nil { - glog.V(10).Infof("ParseInt failed for value %+v in requirement %#v, for 'Gt', 'Lt' operators, the value must be an integer", strValue, r) + glog.V(10).Infof("ParseInt failed for value %+v in requirement %#v, for 'Gt', 'Lt' operators, the value must be an integer", r.strValues[i], r) return false } } @@ -210,8 +223,8 @@ func (r *Requirement) Operator() selection.Operator { } func (r *Requirement) Values() sets.String { ret := sets.String{} - for k := range r.strValues { - ret.Insert(k) + for i := range r.strValues { + ret.Insert(r.strValues[i]) } return ret } @@ -258,9 +271,9 @@ func (r *Requirement) String() string { buffer.WriteString("(") } if len(r.strValues) == 1 { - buffer.WriteString(r.strValues.List()[0]) + buffer.WriteString(r.strValues[0]) } else { // only > 1 since == 0 prohibited by NewRequirement - buffer.WriteString(strings.Join(r.strValues.List(), ",")) + buffer.WriteString(strings.Join(r.strValues, ",")) } switch r.operator { @@ -561,7 +574,7 @@ func (p *Parser) parseRequirement() (*Requirement, error) { return nil, err } if operator == selection.Exists || operator == selection.DoesNotExist { // operator found lookahead set checked - return NewRequirement(key, operator, nil) + return NewRequirement(key, operator, []string{}) } operator, err = p.parseOperator() if err != nil { @@ -577,7 +590,7 @@ func (p *Parser) parseRequirement() (*Requirement, error) { if err != nil { return nil, err } - return NewRequirement(key, operator, values) + return NewRequirement(key, operator, values.List()) } @@ -784,7 +797,7 @@ func SelectorFromSet(ls Set) Selector { } var requirements internalSelector for label, value := range ls { - if r, err := NewRequirement(label, selection.Equals, sets.NewString(value)); err != nil { + if r, err := NewRequirement(label, selection.Equals, []string{value}); err != nil { //TODO: double check errors when input comes from serialization? return internalSelector{} } else { @@ -805,7 +818,7 @@ func SelectorFromValidatedSet(ls Set) Selector { } var requirements internalSelector for label, value := range ls { - requirements = append(requirements, Requirement{key: label, operator: selection.Equals, strValues: sets.NewString(value)}) + requirements = append(requirements, Requirement{key: label, operator: selection.Equals, strValues: []string{value}}) } // sort to have deterministic string representation sort.Sort(ByKey(requirements)) diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/OWNERS b/vendor/k8s.io/client-go/pkg/runtime/OWNERS similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/OWNERS rename to vendor/k8s.io/client-go/pkg/runtime/OWNERS diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/codec.go b/vendor/k8s.io/client-go/pkg/runtime/codec.go similarity index 87% rename from vendor/k8s.io/kubernetes/pkg/runtime/codec.go rename to vendor/k8s.io/client-go/pkg/runtime/codec.go index 9077f0f..070738c 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/codec.go +++ b/vendor/k8s.io/client-go/pkg/runtime/codec.go @@ -24,8 +24,8 @@ import ( "net/url" "reflect" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion/queryparams" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion/queryparams" ) // codec binds an encoder and decoder. @@ -76,6 +76,24 @@ func EncodeOrDie(e Encoder, obj Object) string { return string(bytes) } +// DefaultingSerializer invokes defaulting after decoding. +type DefaultingSerializer struct { + Defaulter ObjectDefaulter + Decoder Decoder + // Encoder is optional to allow this type to be used as both a Decoder and an Encoder + Encoder +} + +// Decode performs a decode and then allows the defaulter to act on the provided object. +func (d DefaultingSerializer) Decode(data []byte, defaultGVK *unversioned.GroupVersionKind, into Object) (Object, *unversioned.GroupVersionKind, error) { + obj, gvk, err := d.Decoder.Decode(data, defaultGVK, into) + if err != nil { + return obj, gvk, err + } + d.Defaulter.Default(obj) + return obj, gvk, nil +} + // UseOrCreateObject returns obj if the canonical ObjectKind returned by the provided typer matches gvk, or // invokes the ObjectCreator to instantiate a new gvk. Returns an error if the typer cannot find the object. func UseOrCreateObject(t ObjectTyper, c ObjectCreater, gvk unversioned.GroupVersionKind, obj Object) (Object, error) { @@ -199,6 +217,22 @@ func (s base64Serializer) Decode(data []byte, defaults *unversioned.GroupVersion return s.Serializer.Decode(out[:n], defaults, into) } +// SerializerInfoForMediaType returns the first info in types that has a matching media type (which cannot +// include media-type parameters), or the first info with an empty media type, or false if no type matches. +func SerializerInfoForMediaType(types []SerializerInfo, mediaType string) (SerializerInfo, bool) { + for _, info := range types { + if info.MediaType == mediaType { + return info, true + } + } + for _, info := range types { + if len(info.MediaType) == 0 { + return info, true + } + } + return SerializerInfo{}, false +} + var ( // InternalGroupVersioner will always prefer the internal version for a given group version kind. InternalGroupVersioner GroupVersioner = internalGroupVersioner{} diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/codec_check.go b/vendor/k8s.io/client-go/pkg/runtime/codec_check.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/runtime/codec_check.go rename to vendor/k8s.io/client-go/pkg/runtime/codec_check.go index b012696..9a52ad2 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/codec_check.go +++ b/vendor/k8s.io/client-go/pkg/runtime/codec_check.go @@ -20,7 +20,7 @@ import ( "fmt" "reflect" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // CheckCodec makes sure that the codec can encode objects like internalType, diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/conversion.go b/vendor/k8s.io/client-go/pkg/runtime/conversion.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/conversion.go rename to vendor/k8s.io/client-go/pkg/runtime/conversion.go index dd6e26a..034bef9 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/conversion.go +++ b/vendor/k8s.io/client-go/pkg/runtime/conversion.go @@ -23,7 +23,7 @@ import ( "strconv" "strings" - "k8s.io/kubernetes/pkg/conversion" + "k8s.io/client-go/pkg/conversion" ) // JSONKeyMapper uses the struct tags on a conversion to determine the key value for diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/doc.go b/vendor/k8s.io/client-go/pkg/runtime/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/doc.go rename to vendor/k8s.io/client-go/pkg/runtime/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/embedded.go b/vendor/k8s.io/client-go/pkg/runtime/embedded.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/embedded.go rename to vendor/k8s.io/client-go/pkg/runtime/embedded.go index eb1f573..f914256 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/embedded.go +++ b/vendor/k8s.io/client-go/pkg/runtime/embedded.go @@ -19,8 +19,8 @@ package runtime import ( "errors" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" ) type encodable struct { diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/error.go b/vendor/k8s.io/client-go/pkg/runtime/error.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/error.go rename to vendor/k8s.io/client-go/pkg/runtime/error.go index 2a1262c..086507c 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/error.go +++ b/vendor/k8s.io/client-go/pkg/runtime/error.go @@ -20,7 +20,7 @@ import ( "fmt" "reflect" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) type notRegisteredErr struct { diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/extension.go b/vendor/k8s.io/client-go/pkg/runtime/extension.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/extension.go rename to vendor/k8s.io/client-go/pkg/runtime/extension.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/generated.pb.go b/vendor/k8s.io/client-go/pkg/runtime/generated.pb.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/runtime/generated.pb.go rename to vendor/k8s.io/client-go/pkg/runtime/generated.pb.go index 4aeadcf..d18d688 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/runtime/generated.pb.go @@ -62,9 +62,9 @@ func (*Unknown) ProtoMessage() {} func (*Unknown) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{2} } func init() { - proto.RegisterType((*RawExtension)(nil), "k8s.io.kubernetes.pkg.runtime.RawExtension") - proto.RegisterType((*TypeMeta)(nil), "k8s.io.kubernetes.pkg.runtime.TypeMeta") - proto.RegisterType((*Unknown)(nil), "k8s.io.kubernetes.pkg.runtime.Unknown") + proto.RegisterType((*RawExtension)(nil), "k8s.io.client-go.pkg.runtime.RawExtension") + proto.RegisterType((*TypeMeta)(nil), "k8s.io.client-go.pkg.runtime.TypeMeta") + proto.RegisterType((*Unknown)(nil), "k8s.io.client-go.pkg.runtime.Unknown") } func (m *RawExtension) Marshal() (data []byte, err error) { size := m.Size() @@ -738,29 +738,30 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 380 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x7c, 0x90, 0xcf, 0x4e, 0x2a, 0x31, - 0x14, 0xc6, 0x19, 0x20, 0x81, 0x5b, 0x48, 0xb8, 0xe9, 0x5d, 0xdc, 0x91, 0x44, 0x20, 0x6c, 0x94, - 0x05, 0x6d, 0x24, 0x31, 0x71, 0xcb, 0x10, 0x16, 0xc6, 0x98, 0x98, 0x89, 0xb8, 0x70, 0xe5, 0x30, - 0xd4, 0xb1, 0x19, 0x69, 0x27, 0x9d, 0x4e, 0xd0, 0x9d, 0x8f, 0xe0, 0x63, 0xb1, 0x64, 0xe9, 0x8a, - 0x28, 0x3e, 0x83, 0x7b, 0x4b, 0x29, 0x7f, 0x04, 0xe2, 0xe2, 0x24, 0x33, 0xe7, 0xfc, 0xbe, 0xef, - 0x7c, 0xa7, 0xa0, 0x19, 0x9e, 0xc5, 0x88, 0x72, 0x1c, 0x26, 0x7d, 0x22, 0x18, 0x91, 0x24, 0xc6, - 0x51, 0x18, 0x60, 0x91, 0x30, 0x49, 0x87, 0x04, 0x07, 0x84, 0x11, 0xe1, 0x49, 0x32, 0x40, 0x91, - 0xe0, 0x92, 0xc3, 0xc3, 0x05, 0x8e, 0xd6, 0x38, 0x52, 0x38, 0x32, 0x78, 0xb9, 0x19, 0x50, 0xf9, - 0x90, 0xf4, 0x91, 0xcf, 0x87, 0x38, 0xe0, 0x01, 0xc7, 0x5a, 0xd5, 0x4f, 0xee, 0xf5, 0x9f, 0xfe, - 0xd1, 0x5f, 0x0b, 0xb7, 0x72, 0x6b, 0xff, 0x72, 0x2f, 0xa2, 0x58, 0x90, 0x98, 0x27, 0xc2, 0xdf, - 0x49, 0x50, 0x3e, 0xd9, 0xaf, 0x49, 0x24, 0x7d, 0xc4, 0x94, 0xc9, 0x58, 0x8a, 0x6d, 0x49, 0xbd, - 0x01, 0x8a, 0xae, 0x37, 0xea, 0x3e, 0x49, 0xc2, 0x62, 0xca, 0x19, 0x3c, 0x00, 0x19, 0xe1, 0x8d, - 0x6c, 0xab, 0x66, 0x1d, 0x17, 0x9d, 0xdc, 0x6c, 0x5a, 0xcd, 0xa8, 0xb1, 0x3b, 0xef, 0xd5, 0xef, - 0x40, 0xfe, 0xfa, 0x39, 0x22, 0x97, 0x44, 0x7a, 0xb0, 0x05, 0x80, 0x4a, 0x72, 0x43, 0xc4, 0x5c, - 0xa4, 0xe9, 0x3f, 0x0e, 0x1c, 0x4f, 0xab, 0x29, 0xa5, 0x00, 0xed, 0xab, 0x73, 0x33, 0x71, 0x37, - 0x28, 0x58, 0x03, 0xd9, 0x90, 0xb2, 0x81, 0x9d, 0xd6, 0x74, 0xd1, 0xd0, 0xd9, 0x0b, 0xd5, 0x73, - 0xf5, 0xa4, 0xfe, 0x65, 0x81, 0x5c, 0x8f, 0x85, 0x8c, 0x8f, 0x18, 0xec, 0x81, 0xbc, 0x34, 0xdb, - 0xb4, 0x7f, 0xa1, 0x75, 0x84, 0x7e, 0x7d, 0x60, 0xb4, 0x0c, 0xe7, 0xfc, 0x35, 0xd6, 0xab, 0xb8, - 0xee, 0xca, 0x6a, 0x79, 0x5f, 0x7a, 0xf7, 0x3e, 0xd8, 0x06, 0x25, 0x9f, 0x33, 0xf5, 0x10, 0xb2, - 0xcb, 0x7c, 0x3e, 0xa0, 0x2c, 0xb0, 0x33, 0x3a, 0xea, 0x7f, 0xe3, 0x57, 0xea, 0xfc, 0x1c, 0xbb, - 0xdb, 0x3c, 0x3c, 0x05, 0x05, 0xd3, 0x9a, 0xaf, 0xb6, 0xb3, 0x5a, 0xfe, 0xcf, 0xc8, 0x0b, 0x9d, - 0xf5, 0xc8, 0xdd, 0xe4, 0x9c, 0xc6, 0xf8, 0xa3, 0x92, 0x9a, 0xa8, 0x7a, 0x53, 0xf5, 0x32, 0xab, - 0x58, 0x63, 0x55, 0x13, 0x55, 0xef, 0xaa, 0x5e, 0x3f, 0x2b, 0xa9, 0xdb, 0x9c, 0x39, 0xf2, 0x3b, - 0x00, 0x00, 0xff, 0xff, 0x32, 0xc1, 0x73, 0x2d, 0x94, 0x02, 0x00, 0x00, + // 388 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x7c, 0x90, 0x3f, 0x8f, 0xda, 0x30, + 0x18, 0xc6, 0x13, 0x40, 0x82, 0x1a, 0x24, 0x2a, 0x77, 0x68, 0x8a, 0x54, 0x83, 0x58, 0x5a, 0x06, + 0x6c, 0x15, 0xa9, 0x52, 0x57, 0x82, 0x18, 0xaa, 0xaa, 0x52, 0x65, 0x95, 0x0e, 0x9d, 0x1a, 0x12, + 0x37, 0xb5, 0x52, 0xec, 0xc8, 0x71, 0x94, 0x76, 0xeb, 0x47, 0xe8, 0xc7, 0x62, 0x64, 0xbc, 0x09, + 0x1d, 0xb9, 0xcf, 0x70, 0xfb, 0x09, 0x63, 0xfe, 0x1c, 0xa0, 0xdb, 0xe2, 0xf7, 0xf9, 0x3d, 0xcf, + 0xfb, 0xbc, 0x01, 0xc3, 0xe4, 0x43, 0x86, 0xb9, 0x24, 0x49, 0x3e, 0x67, 0x4a, 0x30, 0xcd, 0x32, + 0x92, 0x26, 0x31, 0x51, 0xb9, 0xd0, 0x7c, 0xc1, 0x48, 0xcc, 0x04, 0x53, 0x81, 0x66, 0x11, 0x4e, + 0x95, 0xd4, 0x12, 0xbe, 0xde, 0xe1, 0xf8, 0x88, 0xe3, 0x34, 0x89, 0xb1, 0xc5, 0x3b, 0xc3, 0x98, + 0xeb, 0x5f, 0xf9, 0x1c, 0x87, 0x72, 0x41, 0x62, 0x19, 0x4b, 0x62, 0x5c, 0xf3, 0xfc, 0xa7, 0x79, + 0x99, 0x87, 0xf9, 0xda, 0xa5, 0x75, 0x46, 0xd7, 0x97, 0x07, 0x29, 0x27, 0x8a, 0x65, 0x32, 0x57, + 0xe1, 0x45, 0x83, 0xce, 0xbb, 0xeb, 0x9e, 0x5c, 0xf3, 0xdf, 0x84, 0x0b, 0x9d, 0x69, 0x75, 0x6e, + 0xe9, 0x0f, 0x40, 0x8b, 0x06, 0xc5, 0xf4, 0x8f, 0x66, 0x22, 0xe3, 0x52, 0xc0, 0x57, 0xa0, 0xaa, + 0x82, 0xc2, 0x73, 0x7b, 0xee, 0xdb, 0x96, 0x5f, 0x2f, 0xd7, 0xdd, 0x2a, 0x0d, 0x0a, 0xba, 0x9d, + 0xf5, 0x7f, 0x80, 0xc6, 0xd7, 0xbf, 0x29, 0xfb, 0xcc, 0x74, 0x00, 0x47, 0x00, 0x04, 0x29, 0xff, + 0xc6, 0xd4, 0xd6, 0x64, 0xe8, 0x67, 0x3e, 0x5c, 0xae, 0xbb, 0x4e, 0xb9, 0xee, 0x82, 0xf1, 0x97, + 0x8f, 0x56, 0xa1, 0x27, 0x14, 0xec, 0x81, 0x5a, 0xc2, 0x45, 0xe4, 0x55, 0x0c, 0xdd, 0xb2, 0x74, + 0xed, 0x13, 0x17, 0x11, 0x35, 0x4a, 0xff, 0xde, 0x05, 0xf5, 0x99, 0x48, 0x84, 0x2c, 0x04, 0x9c, + 0x81, 0x86, 0xb6, 0xdb, 0x4c, 0x7e, 0x73, 0xf4, 0x06, 0x3f, 0xf9, 0x83, 0xf1, 0xbe, 0x9c, 0xff, + 0xdc, 0x46, 0x1f, 0xea, 0xd2, 0x43, 0xd4, 0xfe, 0xbe, 0xca, 0xe5, 0x7d, 0x70, 0x0c, 0xda, 0xa1, + 0x14, 0x9a, 0x09, 0x3d, 0x15, 0xa1, 0x8c, 0xb8, 0x88, 0xbd, 0xaa, 0xa9, 0xfa, 0xd2, 0xe6, 0xb5, + 0x27, 0x8f, 0x65, 0x7a, 0xce, 0xc3, 0xf7, 0xa0, 0x69, 0x47, 0xdb, 0xd5, 0x5e, 0xcd, 0xd8, 0x5f, + 0x58, 0x7b, 0x73, 0x72, 0x94, 0xe8, 0x29, 0xe7, 0x0f, 0x96, 0x1b, 0xe4, 0xac, 0x36, 0xc8, 0xb9, + 0xd9, 0x20, 0xe7, 0x5f, 0x89, 0xdc, 0x65, 0x89, 0xdc, 0x55, 0x89, 0xdc, 0xdb, 0x12, 0xb9, 0xff, + 0xef, 0x90, 0xf3, 0xbd, 0x6e, 0x8f, 0x7c, 0x08, 0x00, 0x00, 0xff, 0xff, 0x32, 0xc1, 0x73, 0x2d, + 0x94, 0x02, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/generated.proto b/vendor/k8s.io/client-go/pkg/runtime/generated.proto similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/runtime/generated.proto rename to vendor/k8s.io/client-go/pkg/runtime/generated.proto index 17951fd..136ab0b 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/generated.proto +++ b/vendor/k8s.io/client-go/pkg/runtime/generated.proto @@ -94,8 +94,10 @@ message RawExtension { // +protobuf=true // +k8s:openapi-gen=true message TypeMeta { + // +optional optional string apiVersion = 1; + // +optional optional string kind = 2; } diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/helper.go b/vendor/k8s.io/client-go/pkg/runtime/helper.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/helper.go rename to vendor/k8s.io/client-go/pkg/runtime/helper.go index 2f8f161..3062109 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/helper.go +++ b/vendor/k8s.io/client-go/pkg/runtime/helper.go @@ -21,9 +21,9 @@ import ( "io" "reflect" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/util/errors" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/util/errors" ) // unsafeObjectConvertor implements ObjectConvertor using the unsafe conversion path. diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/interfaces.go b/vendor/k8s.io/client-go/pkg/runtime/interfaces.go similarity index 86% rename from vendor/k8s.io/kubernetes/pkg/runtime/interfaces.go rename to vendor/k8s.io/client-go/pkg/runtime/interfaces.go index 07f77ca..0315cac 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/interfaces.go +++ b/vendor/k8s.io/client-go/pkg/runtime/interfaces.go @@ -20,7 +20,7 @@ import ( "io" "net/url" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) const ( @@ -89,20 +89,28 @@ type Framer interface { // SerializerInfo contains information about a specific serialization format type SerializerInfo struct { - Serializer - // EncodesAsText indicates this serializer can be encoded to UTF-8 safely. - EncodesAsText bool // MediaType is the value that represents this serializer over the wire. MediaType string + // EncodesAsText indicates this serializer can be encoded to UTF-8 safely. + EncodesAsText bool + // Serializer is the individual object serializer for this media type. + Serializer Serializer + // PrettySerializer, if set, can serialize this object in a form biased towards + // readability. + PrettySerializer Serializer + // StreamSerializer, if set, describes the streaming serialization format + // for this media type. + StreamSerializer *StreamSerializerInfo } // StreamSerializerInfo contains information about a specific stream serialization format type StreamSerializerInfo struct { - SerializerInfo + // EncodesAsText indicates this serializer can be encoded to UTF-8 safely. + EncodesAsText bool + // Serializer is the top level object serializer for this type when streaming + Serializer // Framer is the factory for retrieving streams that separate objects on the wire Framer - // Embedded is the type of the nested serialization that should be used. - Embedded SerializerInfo } // NegotiatedSerializer is an interface used for obtaining encoders, decoders, and serializers @@ -110,21 +118,7 @@ type StreamSerializerInfo struct { // that performs HTTP content negotiation to accept multiple formats. type NegotiatedSerializer interface { // SupportedMediaTypes is the media types supported for reading and writing single objects. - SupportedMediaTypes() []string - // SerializerForMediaType returns a serializer for the provided media type. params is the set of - // parameters applied to the media type that may modify the resulting output. ok will be false - // if no serializer matched the media type. - SerializerForMediaType(mediaType string, params map[string]string) (s SerializerInfo, ok bool) - - // SupportedStreamingMediaTypes returns the media types of the supported streaming serializers. - // Streaming serializers control how multiple objects are written to a stream output. - SupportedStreamingMediaTypes() []string - // StreamingSerializerForMediaType returns a serializer for the provided media type that supports - // reading and writing multiple objects to a stream. It returns a framer and serializer, or an - // error if no such serializer can be created. Params is the set of parameters applied to the - // media type that may modify the resulting output. ok will be false if no serializer matched - // the media type. - StreamingSerializerForMediaType(mediaType string, params map[string]string) (s StreamSerializerInfo, ok bool) + SupportedMediaTypes() []SerializerInfo // EncoderForVersion returns an encoder that ensures objects being written to the provided // serializer are in the provided group version. @@ -138,9 +132,8 @@ type NegotiatedSerializer interface { // that can read and write data at rest. This would commonly be used by client tools that must // read files, or server side storage interfaces that persist restful objects. type StorageSerializer interface { - // SerializerForMediaType returns a serializer for the provided media type. Options is a set of - // parameters applied to the media type that may modify the resulting output. - SerializerForMediaType(mediaType string, options map[string]string) (SerializerInfo, bool) + // SupportedMediaTypes are the media types supported for reading and writing objects. + SupportedMediaTypes() []SerializerInfo // UniversalDeserializer returns a Serializer that can read objects in multiple supported formats // by introspecting the data at rest. @@ -169,6 +162,12 @@ type NestedObjectDecoder interface { /////////////////////////////////////////////////////////////////////////////// // Non-codec interfaces +type ObjectDefaulter interface { + // Default takes an object (must be a pointer) and applies any default values. + // Defaulters may not error. + Default(in Object) +} + type ObjectVersioner interface { ConvertToVersion(in Object, gv GroupVersioner) (out Object, err error) } diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/register.go b/vendor/k8s.io/client-go/pkg/runtime/register.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/register.go rename to vendor/k8s.io/client-go/pkg/runtime/register.go index 39a1eb1..66f664f 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/register.go +++ b/vendor/k8s.io/client-go/pkg/runtime/register.go @@ -17,7 +17,7 @@ limitations under the License. package runtime import ( - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // SetGroupVersionKind satisfies the ObjectKind interface for all objects that embed TypeMeta diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/scheme.go b/vendor/k8s.io/client-go/pkg/runtime/scheme.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/runtime/scheme.go rename to vendor/k8s.io/client-go/pkg/runtime/scheme.go index f5d3bd0..104801e 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/scheme.go +++ b/vendor/k8s.io/client-go/pkg/runtime/scheme.go @@ -21,8 +21,8 @@ import ( "net/url" "reflect" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" ) // Scheme defines methods for serializing and deserializing API objects, a type @@ -61,6 +61,10 @@ type Scheme struct { // resource field labels in that version to internal version. fieldLabelConversionFuncs map[string]map[string]FieldLabelConversionFunc + // defaulterFuncs is an array of interfaces to be called with an object to provide defaulting + // the provided object must be a pointer. + defaulterFuncs map[reflect.Type]func(interface{}) + // converter stores all registered conversion functions. It also has // default coverting behavior. converter *conversion.Converter @@ -82,6 +86,7 @@ func NewScheme() *Scheme { unversionedKinds: map[string]reflect.Type{}, cloner: conversion.NewCloner(), fieldLabelConversionFuncs: map[string]map[string]FieldLabelConversionFunc{}, + defaulterFuncs: map[reflect.Type]func(interface{}){}, } s.converter = conversion.NewConverter(s.nameFunc) @@ -421,6 +426,22 @@ func (s *Scheme) AddDefaultingFuncs(defaultingFuncs ...interface{}) error { return nil } +// AddTypeDefaultingFuncs registers a function that is passed a pointer to an +// object and can default fields on the object. These functions will be invoked +// when Default() is called. The function will never be called unless the +// defaulted object matches srcType. If this function is invoked twice with the +// same srcType, the fn passed to the later call will be used instead. +func (s *Scheme) AddTypeDefaultingFunc(srcType Object, fn func(interface{})) { + s.defaulterFuncs[reflect.TypeOf(srcType)] = fn +} + +// Default sets defaults on the provided Object. +func (s *Scheme) Default(src Object) { + if fn, ok := s.defaulterFuncs[reflect.TypeOf(src)]; ok { + fn(src) + } +} + // Copy does a deep copy of an API object. func (s *Scheme) Copy(src Object) (Object, error) { dst, err := s.DeepCopy(src) diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/scheme_builder.go b/vendor/k8s.io/client-go/pkg/runtime/scheme_builder.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/scheme_builder.go rename to vendor/k8s.io/client-go/pkg/runtime/scheme_builder.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/codec_factory.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/codec_factory.go similarity index 56% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/codec_factory.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/codec_factory.go index afccae5..69f56bb 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/codec_factory.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/codec_factory.go @@ -17,11 +17,11 @@ limitations under the License. package serializer import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/json" - "k8s.io/kubernetes/pkg/runtime/serializer/recognizer" - "k8s.io/kubernetes/pkg/runtime/serializer/versioning" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/json" + "k8s.io/client-go/pkg/runtime/serializer/recognizer" + "k8s.io/client-go/pkg/runtime/serializer/versioning" ) // serializerExtensions are for serializers that are conditionally compiled in @@ -36,25 +36,12 @@ type serializerType struct { Serializer runtime.Serializer PrettySerializer runtime.Serializer - // RawSerializer serializes an object without adding a type wrapper. Some serializers, like JSON - // automatically include identifying type information with the JSON. Others, like Protobuf, need - // a wrapper object that includes type information. This serializer should be set if the serializer - // can serialize / deserialize objects without type info. Note that this serializer will always - // be expected to pass into or a gvk to Decode, since no type information will be available on - // the object itself. - RawSerializer runtime.Serializer - // Specialize gives the type the opportunity to return a different serializer implementation if - // the content type contains alternate operations. Here it is used to implement "pretty" as an - // option to application/json, but could also be used to allow serializers to perform type - // defaulting or alter output. - Specialize func(map[string]string) (runtime.Serializer, bool) AcceptStreamContentTypes []string StreamContentType string Framer runtime.Framer StreamSerializer runtime.Serializer - StreamSpecialize func(map[string]string) (runtime.Serializer, bool) } func newSerializersForScheme(scheme *runtime.Scheme, mf json.MetaFactory) []serializerType { @@ -71,10 +58,8 @@ func newSerializersForScheme(scheme *runtime.Scheme, mf json.MetaFactory) []seri Serializer: jsonSerializer, PrettySerializer: jsonPrettySerializer, - AcceptStreamContentTypes: []string{"application/json", "application/json;stream=watch"}, - StreamContentType: "application/json", - Framer: json.Framer, - StreamSerializer: jsonSerializer, + Framer: json.Framer, + StreamSerializer: jsonSerializer, }, { AcceptContentTypes: []string{"application/yaml"}, @@ -82,13 +67,6 @@ func newSerializersForScheme(scheme *runtime.Scheme, mf json.MetaFactory) []seri FileExtensions: []string{"yaml"}, EncodesAsText: true, Serializer: yamlSerializer, - - // TODO: requires runtime.RawExtension to properly distinguish when the nested content is - // yaml, because the yaml encoder invokes MarshalJSON first - //AcceptStreamContentTypes: []string{"application/yaml", "application/yaml;stream=watch"}, - //StreamContentType: "application/yaml;stream=watch", - //Framer: json.YAMLFramer, - //StreamSerializer: yamlSerializer, }, } @@ -103,11 +81,10 @@ func newSerializersForScheme(scheme *runtime.Scheme, mf json.MetaFactory) []seri // CodecFactory provides methods for retrieving codecs and serializers for specific // versions and content types. type CodecFactory struct { - scheme *runtime.Scheme - serializers []serializerType - universal runtime.Decoder - accepts []string - streamingAccepts []string + scheme *runtime.Scheme + serializers []serializerType + universal runtime.Decoder + accepts []runtime.SerializerInfo legacySerializer runtime.Serializer } @@ -126,7 +103,7 @@ func NewCodecFactory(scheme *runtime.Scheme) CodecFactory { // newCodecFactory is a helper for testing that allows a different metafactory to be specified. func newCodecFactory(scheme *runtime.Scheme, serializers []serializerType) CodecFactory { decoders := make([]runtime.Decoder, 0, len(serializers)) - accepts := []string{} + var accepts []runtime.SerializerInfo alreadyAccepted := make(map[string]struct{}) var legacySerializer runtime.Serializer @@ -137,8 +114,21 @@ func newCodecFactory(scheme *runtime.Scheme, serializers []serializerType) Codec continue } alreadyAccepted[mediaType] = struct{}{} - accepts = append(accepts, mediaType) - if mediaType == "application/json" { + info := runtime.SerializerInfo{ + MediaType: d.ContentType, + EncodesAsText: d.EncodesAsText, + Serializer: d.Serializer, + PrettySerializer: d.PrettySerializer, + } + if d.StreamSerializer != nil { + info.StreamSerializer = &runtime.StreamSerializerInfo{ + Serializer: d.StreamSerializer, + EncodesAsText: d.EncodesAsText, + Framer: d.Framer, + } + } + accepts = append(accepts, info) + if mediaType == runtime.ContentTypeJSON { legacySerializer = d.Serializer } } @@ -147,45 +137,22 @@ func newCodecFactory(scheme *runtime.Scheme, serializers []serializerType) Codec legacySerializer = serializers[0].Serializer } - streamAccepts := []string{} - alreadyAccepted = make(map[string]struct{}) - for _, d := range serializers { - if len(d.StreamContentType) == 0 { - continue - } - for _, mediaType := range d.AcceptStreamContentTypes { - if _, ok := alreadyAccepted[mediaType]; ok { - continue - } - alreadyAccepted[mediaType] = struct{}{} - streamAccepts = append(streamAccepts, mediaType) - } - } - return CodecFactory{ scheme: scheme, serializers: serializers, universal: recognizer.NewDecoder(decoders...), - accepts: accepts, - streamingAccepts: streamAccepts, + accepts: accepts, legacySerializer: legacySerializer, } } -var _ runtime.NegotiatedSerializer = &CodecFactory{} - // SupportedMediaTypes returns the RFC2046 media types that this factory has serializers for. -func (f CodecFactory) SupportedMediaTypes() []string { +func (f CodecFactory) SupportedMediaTypes() []runtime.SerializerInfo { return f.accepts } -// SupportedStreamingMediaTypes returns the RFC2046 media types that this factory has stream serializers for. -func (f CodecFactory) SupportedStreamingMediaTypes() []string { - return f.streamingAccepts -} - // LegacyCodec encodes output to a given API versions, and decodes output into the internal form from // any recognized source. The returned codec will always encode output to JSON. If a type is not // found in the list of versions an error will be returned. @@ -196,7 +163,7 @@ func (f CodecFactory) SupportedStreamingMediaTypes() []string { // TODO: make this call exist only in pkg/api, and initialize it with the set of default versions. // All other callers will be forced to request a Codec directly. func (f CodecFactory) LegacyCodec(version ...unversioned.GroupVersion) runtime.Codec { - return versioning.NewCodecForScheme(f.scheme, f.legacySerializer, f.universal, unversioned.GroupVersions(version), runtime.InternalGroupVersioner) + return versioning.NewDefaultingCodecForScheme(f.scheme, f.legacySerializer, f.universal, unversioned.GroupVersions(version), runtime.InternalGroupVersioner) } // UniversalDeserializer can convert any stored data recognized by this factory into a Go object that satisfies @@ -235,7 +202,7 @@ func (f CodecFactory) CodecForVersions(encoder runtime.Encoder, decoder runtime. if decode == nil { decode = runtime.InternalGroupVersioner } - return versioning.NewCodecForScheme(f.scheme, encoder, decoder, encode, decode) + return versioning.NewDefaultingCodecForScheme(f.scheme, encoder, decoder, encode, decode) } // DecoderToVersion returns a decoder that targets the provided group version. @@ -248,85 +215,6 @@ func (f CodecFactory) EncoderForVersion(encoder runtime.Encoder, gv runtime.Grou return f.CodecForVersions(encoder, nil, gv, nil) } -// SerializerForMediaType returns a serializer that matches the provided RFC2046 mediaType, or false if no such -// serializer exists -func (f CodecFactory) SerializerForMediaType(mediaType string, params map[string]string) (runtime.SerializerInfo, bool) { - for _, s := range f.serializers { - for _, accepted := range s.AcceptContentTypes { - if accepted == mediaType { - // specialization abstracts variants to the content type - if s.Specialize != nil && len(params) > 0 { - serializer, ok := s.Specialize(params) - // TODO: return formatted mediaType+params - return runtime.SerializerInfo{Serializer: serializer, MediaType: s.ContentType, EncodesAsText: s.EncodesAsText}, ok - } - - // legacy support for ?pretty=1 continues, but this is more formally defined - if v, ok := params["pretty"]; ok && v == "1" && s.PrettySerializer != nil { - return runtime.SerializerInfo{Serializer: s.PrettySerializer, MediaType: s.ContentType, EncodesAsText: s.EncodesAsText}, true - } - - // return the base variant - return runtime.SerializerInfo{Serializer: s.Serializer, MediaType: s.ContentType, EncodesAsText: s.EncodesAsText}, true - } - } - } - return runtime.SerializerInfo{}, false -} - -// StreamingSerializerForMediaType returns a serializer that matches the provided RFC2046 mediaType, or false if no such -// serializer exists -func (f CodecFactory) StreamingSerializerForMediaType(mediaType string, params map[string]string) (runtime.StreamSerializerInfo, bool) { - for _, s := range f.serializers { - for _, accepted := range s.AcceptStreamContentTypes { - if accepted == mediaType { - // TODO: accept params - nested, ok := f.SerializerForMediaType(s.ContentType, nil) - if !ok { - panic("no serializer defined for internal content type") - } - - if s.StreamSpecialize != nil && len(params) > 0 { - serializer, ok := s.StreamSpecialize(params) - // TODO: return formatted mediaType+params - return runtime.StreamSerializerInfo{ - SerializerInfo: runtime.SerializerInfo{ - Serializer: serializer, - MediaType: s.StreamContentType, - EncodesAsText: s.EncodesAsText, - }, - Framer: s.Framer, - Embedded: nested, - }, ok - } - - return runtime.StreamSerializerInfo{ - SerializerInfo: runtime.SerializerInfo{ - Serializer: s.StreamSerializer, - MediaType: s.StreamContentType, - EncodesAsText: s.EncodesAsText, - }, - Framer: s.Framer, - Embedded: nested, - }, true - } - } - } - return runtime.StreamSerializerInfo{}, false -} - -// SerializerForFileExtension returns a serializer for the provided extension, or false if no serializer matches. -func (f CodecFactory) SerializerForFileExtension(extension string) (runtime.Serializer, bool) { - for _, s := range f.serializers { - for _, ext := range s.FileExtensions { - if extension == ext { - return s.Serializer, true - } - } - } - return nil, false -} - // DirectCodecFactory provides methods for retrieving "DirectCodec"s, which do not do conversion. type DirectCodecFactory struct { CodecFactory diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/json.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/json/json.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/json.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/json/json.go index c83ed58..2f2f69f 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/json.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/json/json.go @@ -23,11 +23,11 @@ import ( "github.com/ghodss/yaml" "github.com/ugorji/go/codec" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/recognizer" - "k8s.io/kubernetes/pkg/util/framer" - utilyaml "k8s.io/kubernetes/pkg/util/yaml" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/recognizer" + "k8s.io/client-go/pkg/util/framer" + utilyaml "k8s.io/client-go/pkg/util/yaml" ) // NewSerializer creates a JSON serializer that handles encoding versioned objects into the proper JSON form. If typer diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/meta.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/json/meta.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/meta.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/json/meta.go index b9bea21..325df63 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/json/meta.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/json/meta.go @@ -20,7 +20,7 @@ import ( "encoding/json" "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // MetaFactory is used to store and retrieve the version and kind @@ -47,8 +47,10 @@ type SimpleMetaFactory struct { // encoding of an object, or an error. func (SimpleMetaFactory) Interpret(data []byte) (*unversioned.GroupVersionKind, error) { findKind := struct { + // +optional APIVersion string `json:"apiVersion,omitempty"` - Kind string `json:"kind,omitempty"` + // +optional + Kind string `json:"kind,omitempty"` }{} if err := json.Unmarshal(data, &findKind); err != nil { return nil, fmt.Errorf("couldn't get version/kind; json parse error: %v", err) diff --git a/vendor/k8s.io/client-go/pkg/runtime/serializer/negotiated_codec.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/negotiated_codec.go new file mode 100644 index 0000000..95e3dd3 --- /dev/null +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/negotiated_codec.go @@ -0,0 +1,43 @@ +/* +Copyright 2016 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. +*/ + +package serializer + +import ( + "k8s.io/client-go/pkg/runtime" +) + +// TODO: We should split negotiated serializers that we can change versions on from those we can change +// serialization formats on +type negotiatedSerializerWrapper struct { + info runtime.SerializerInfo +} + +func NegotiatedSerializerWrapper(info runtime.SerializerInfo) runtime.NegotiatedSerializer { + return &negotiatedSerializerWrapper{info} +} + +func (n *negotiatedSerializerWrapper) SupportedMediaTypes() []runtime.SerializerInfo { + return []runtime.SerializerInfo{n.info} +} + +func (n *negotiatedSerializerWrapper) EncoderForVersion(e runtime.Encoder, _ runtime.GroupVersioner) runtime.Encoder { + return e +} + +func (n *negotiatedSerializerWrapper) DecoderToVersion(d runtime.Decoder, _gv runtime.GroupVersioner) runtime.Decoder { + return d +} diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf/doc.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf/doc.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf/protobuf.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf/protobuf.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf/protobuf.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf/protobuf.go index 5a6a50d..0118828 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf/protobuf.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf/protobuf.go @@ -24,10 +24,10 @@ import ( "github.com/gogo/protobuf/proto" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/recognizer" - "k8s.io/kubernetes/pkg/util/framer" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/recognizer" + "k8s.io/client-go/pkg/util/framer" ) var ( diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf_extension.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf_extension.go similarity index 74% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf_extension.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf_extension.go index 5846d94..fa525a3 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/protobuf_extension.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/protobuf_extension.go @@ -17,8 +17,8 @@ limitations under the License. package serializer import ( - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/protobuf" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/protobuf" ) const ( @@ -26,8 +26,7 @@ const ( // depending on it unintentionally. // TODO: potentially move to pkg/api (since it's part of the Kube public API) and pass it in to the // CodecFactory on initialization. - contentTypeProtobuf = "application/vnd.kubernetes.protobuf" - contentTypeProtobufWatch = contentTypeProtobuf + ";stream=watch" + contentTypeProtobuf = "application/vnd.kubernetes.protobuf" ) func protobufSerializer(scheme *runtime.Scheme) (serializerType, bool) { @@ -38,12 +37,9 @@ func protobufSerializer(scheme *runtime.Scheme) (serializerType, bool) { ContentType: contentTypeProtobuf, FileExtensions: []string{"pb"}, Serializer: serializer, - RawSerializer: raw, - AcceptStreamContentTypes: []string{contentTypeProtobuf, contentTypeProtobufWatch}, - StreamContentType: contentTypeProtobufWatch, - Framer: protobuf.LengthDelimitedFramer, - StreamSerializer: raw, + Framer: protobuf.LengthDelimitedFramer, + StreamSerializer: raw, }, true } diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/recognizer/recognizer.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/recognizer/recognizer.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/recognizer/recognizer.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/recognizer/recognizer.go index 310002a..54d978f 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/recognizer/recognizer.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/recognizer/recognizer.go @@ -22,8 +22,8 @@ import ( "fmt" "io" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) type RecognizingDecoder interface { diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/streaming/streaming.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/streaming/streaming.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/streaming/streaming.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/streaming/streaming.go index ac17138..9b91f1b 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/streaming/streaming.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/streaming/streaming.go @@ -23,8 +23,8 @@ import ( "fmt" "io" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // Encoder is a runtime.Encoder on a stream. diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/versioning/versioning.go b/vendor/k8s.io/client-go/pkg/runtime/serializer/versioning/versioning.go similarity index 82% rename from vendor/k8s.io/kubernetes/pkg/runtime/serializer/versioning/versioning.go rename to vendor/k8s.io/client-go/pkg/runtime/serializer/versioning/versioning.go index b3a165a..386397f 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/versioning/versioning.go +++ b/vendor/k8s.io/client-go/pkg/runtime/serializer/versioning/versioning.go @@ -19,8 +19,9 @@ package versioning import ( "io" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + utilruntime "k8s.io/client-go/pkg/util/runtime" ) // NewCodecForScheme is a convenience method for callers that are using a scheme. @@ -32,7 +33,19 @@ func NewCodecForScheme( encodeVersion runtime.GroupVersioner, decodeVersion runtime.GroupVersioner, ) runtime.Codec { - return NewCodec(encoder, decoder, runtime.UnsafeObjectConvertor(scheme), scheme, scheme, scheme, encodeVersion, decodeVersion) + return NewCodec(encoder, decoder, runtime.UnsafeObjectConvertor(scheme), scheme, scheme, scheme, nil, encodeVersion, decodeVersion) +} + +// NewDefaultingCodecForScheme is a convenience method for callers that are using a scheme. +func NewDefaultingCodecForScheme( + // TODO: I should be a scheme interface? + scheme *runtime.Scheme, + encoder runtime.Encoder, + decoder runtime.Decoder, + encodeVersion runtime.GroupVersioner, + decodeVersion runtime.GroupVersioner, +) runtime.Codec { + return NewCodec(encoder, decoder, runtime.UnsafeObjectConvertor(scheme), scheme, scheme, scheme, scheme, encodeVersion, decodeVersion) } // NewCodec takes objects in their internal versions and converts them to external versions before @@ -45,6 +58,7 @@ func NewCodec( creater runtime.ObjectCreater, copier runtime.ObjectCopier, typer runtime.ObjectTyper, + defaulter runtime.ObjectDefaulter, encodeVersion runtime.GroupVersioner, decodeVersion runtime.GroupVersioner, ) runtime.Codec { @@ -55,6 +69,7 @@ func NewCodec( creater: creater, copier: copier, typer: typer, + defaulter: defaulter, encodeVersion: encodeVersion, decodeVersion: decodeVersion, @@ -69,6 +84,7 @@ type codec struct { creater runtime.ObjectCreater copier runtime.ObjectCopier typer runtime.ObjectTyper + defaulter runtime.ObjectDefaulter encodeVersion runtime.GroupVersioner decodeVersion runtime.GroupVersioner @@ -102,11 +118,31 @@ func (c *codec) Decode(data []byte, defaultGVK *unversioned.GroupVersionKind, in } return into, gvk, nil } + + // perform defaulting if requested + if c.defaulter != nil { + // create a copy to ensure defaulting is not applied to the original versioned objects + if isVersioned { + copied, err := c.copier.Copy(obj) + if err != nil { + utilruntime.HandleError(err) + copied = obj + } + versioned.Objects = []runtime.Object{copied} + } + c.defaulter.Default(obj) + } else { + if isVersioned { + versioned.Objects = []runtime.Object{obj} + } + } + if err := c.convertor.Convert(obj, into, c.decodeVersion); err != nil { return nil, gvk, err } + if isVersioned { - versioned.Objects = []runtime.Object{obj, into} + versioned.Objects = append(versioned.Objects, into) return versioned, gvk, nil } return into, gvk, nil @@ -117,10 +153,17 @@ func (c *codec) Decode(data []byte, defaultGVK *unversioned.GroupVersionKind, in // create a copy, because ConvertToVersion does not guarantee non-mutation of objects copied, err := c.copier.Copy(obj) if err != nil { + utilruntime.HandleError(err) copied = obj } versioned.Objects = []runtime.Object{copied} } + + // perform defaulting if requested + if c.defaulter != nil { + c.defaulter.Default(obj) + } + out, err := c.convertor.ConvertToVersion(obj, c.decodeVersion) if err != nil { return nil, gvk, err diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/swagger_doc_generator.go b/vendor/k8s.io/client-go/pkg/runtime/swagger_doc_generator.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/swagger_doc_generator.go rename to vendor/k8s.io/client-go/pkg/runtime/swagger_doc_generator.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/types.go b/vendor/k8s.io/client-go/pkg/runtime/types.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/runtime/types.go rename to vendor/k8s.io/client-go/pkg/runtime/types.go index 2ac265c..ceffdd9 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/types.go +++ b/vendor/k8s.io/client-go/pkg/runtime/types.go @@ -34,8 +34,10 @@ package runtime // +protobuf=true // +k8s:openapi-gen=true type TypeMeta struct { + // +optional APIVersion string `json:"apiVersion,omitempty" yaml:"apiVersion,omitempty" protobuf:"bytes,1,opt,name=apiVersion"` - Kind string `json:"kind,omitempty" yaml:"kind,omitempty" protobuf:"bytes,2,opt,name=kind"` + // +optional + Kind string `json:"kind,omitempty" yaml:"kind,omitempty" protobuf:"bytes,2,opt,name=kind"` } const ( diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/types_proto.go b/vendor/k8s.io/client-go/pkg/runtime/types_proto.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/runtime/types_proto.go rename to vendor/k8s.io/client-go/pkg/runtime/types_proto.go diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/unstructured.go b/vendor/k8s.io/client-go/pkg/runtime/unstructured.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/runtime/unstructured.go rename to vendor/k8s.io/client-go/pkg/runtime/unstructured.go index 032e235..a15208c 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/unstructured.go +++ b/vendor/k8s.io/client-go/pkg/runtime/unstructured.go @@ -26,10 +26,10 @@ import ( "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api/meta/metatypes" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/types" - "k8s.io/kubernetes/pkg/util/json" + "k8s.io/client-go/pkg/api/meta/metatypes" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/types" + "k8s.io/client-go/pkg/util/json" ) // MarshalJSON ensures that the unstructured object produces proper diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/zz_generated.deepcopy.go b/vendor/k8s.io/client-go/pkg/runtime/zz_generated.deepcopy.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/runtime/zz_generated.deepcopy.go rename to vendor/k8s.io/client-go/pkg/runtime/zz_generated.deepcopy.go index 627c22b..09bf660 100644 --- a/vendor/k8s.io/kubernetes/pkg/runtime/zz_generated.deepcopy.go +++ b/vendor/k8s.io/client-go/pkg/runtime/zz_generated.deepcopy.go @@ -21,7 +21,7 @@ limitations under the License. package runtime import ( - conversion "k8s.io/kubernetes/pkg/conversion" + conversion "k8s.io/client-go/pkg/conversion" ) func DeepCopy_runtime_RawExtension(in interface{}, out interface{}, c *conversion.Cloner) error { diff --git a/vendor/k8s.io/kubernetes/pkg/selection/operator.go b/vendor/k8s.io/client-go/pkg/selection/operator.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/selection/operator.go rename to vendor/k8s.io/client-go/pkg/selection/operator.go diff --git a/vendor/k8s.io/kubernetes/third_party/forked/golang/reflect/deep_equal.go b/vendor/k8s.io/client-go/pkg/third_party/forked/golang/reflect/deep_equal.go similarity index 100% rename from vendor/k8s.io/kubernetes/third_party/forked/golang/reflect/deep_equal.go rename to vendor/k8s.io/client-go/pkg/third_party/forked/golang/reflect/deep_equal.go diff --git a/vendor/k8s.io/kubernetes/third_party/forked/golang/reflect/type.go b/vendor/k8s.io/client-go/pkg/third_party/forked/golang/reflect/type.go similarity index 100% rename from vendor/k8s.io/kubernetes/third_party/forked/golang/reflect/type.go rename to vendor/k8s.io/client-go/pkg/third_party/forked/golang/reflect/type.go diff --git a/vendor/k8s.io/kubernetes/pkg/types/doc.go b/vendor/k8s.io/client-go/pkg/types/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/types/doc.go rename to vendor/k8s.io/client-go/pkg/types/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/types/namespacedname.go b/vendor/k8s.io/client-go/pkg/types/namespacedname.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/types/namespacedname.go rename to vendor/k8s.io/client-go/pkg/types/namespacedname.go diff --git a/vendor/k8s.io/kubernetes/pkg/types/nodename.go b/vendor/k8s.io/client-go/pkg/types/nodename.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/types/nodename.go rename to vendor/k8s.io/client-go/pkg/types/nodename.go diff --git a/vendor/k8s.io/kubernetes/pkg/types/uid.go b/vendor/k8s.io/client-go/pkg/types/uid.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/types/uid.go rename to vendor/k8s.io/client-go/pkg/types/uid.go diff --git a/vendor/k8s.io/kubernetes/pkg/types/unix_user_id.go b/vendor/k8s.io/client-go/pkg/types/unix_user_id.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/types/unix_user_id.go rename to vendor/k8s.io/client-go/pkg/types/unix_user_id.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/cert/cert.go b/vendor/k8s.io/client-go/pkg/util/cert/cert.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/cert/cert.go rename to vendor/k8s.io/client-go/pkg/util/cert/cert.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/cert/csr.go b/vendor/k8s.io/client-go/pkg/util/cert/csr.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/util/cert/csr.go rename to vendor/k8s.io/client-go/pkg/util/cert/csr.go index 91cc32f..69846df 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/cert/csr.go +++ b/vendor/k8s.io/client-go/pkg/util/cert/csr.go @@ -25,7 +25,7 @@ import ( "errors" "net" - "k8s.io/kubernetes/pkg/apis/certificates" + "k8s.io/client-go/pkg/apis/certificates" ) // ParseCSR extracts the CSR from the API object and decodes it. diff --git a/vendor/k8s.io/kubernetes/pkg/util/cert/io.go b/vendor/k8s.io/client-go/pkg/util/cert/io.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/cert/io.go rename to vendor/k8s.io/client-go/pkg/util/cert/io.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/cert/pem.go b/vendor/k8s.io/client-go/pkg/util/cert/pem.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/cert/pem.go rename to vendor/k8s.io/client-go/pkg/util/cert/pem.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/clock/clock.go b/vendor/k8s.io/client-go/pkg/util/clock/clock.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/clock/clock.go rename to vendor/k8s.io/client-go/pkg/util/clock/clock.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/doc.go b/vendor/k8s.io/client-go/pkg/util/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/doc.go rename to vendor/k8s.io/client-go/pkg/util/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/errors/doc.go b/vendor/k8s.io/client-go/pkg/util/errors/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/errors/doc.go rename to vendor/k8s.io/client-go/pkg/util/errors/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/errors/errors.go b/vendor/k8s.io/client-go/pkg/util/errors/errors.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/errors/errors.go rename to vendor/k8s.io/client-go/pkg/util/errors/errors.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/flowcontrol/backoff.go b/vendor/k8s.io/client-go/pkg/util/flowcontrol/backoff.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/util/flowcontrol/backoff.go rename to vendor/k8s.io/client-go/pkg/util/flowcontrol/backoff.go index 2d91cc5..c3bf958 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/flowcontrol/backoff.go +++ b/vendor/k8s.io/client-go/pkg/util/flowcontrol/backoff.go @@ -20,8 +20,8 @@ import ( "sync" "time" - "k8s.io/kubernetes/pkg/util/clock" - "k8s.io/kubernetes/pkg/util/integer" + "k8s.io/client-go/pkg/util/clock" + "k8s.io/client-go/pkg/util/integer" ) type backoffEntry struct { diff --git a/vendor/k8s.io/kubernetes/pkg/util/flowcontrol/throttle.go b/vendor/k8s.io/client-go/pkg/util/flowcontrol/throttle.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/flowcontrol/throttle.go rename to vendor/k8s.io/client-go/pkg/util/flowcontrol/throttle.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/framer/framer.go b/vendor/k8s.io/client-go/pkg/util/framer/framer.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/framer/framer.go rename to vendor/k8s.io/client-go/pkg/util/framer/framer.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/integer/integer.go b/vendor/k8s.io/client-go/pkg/util/integer/integer.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/integer/integer.go rename to vendor/k8s.io/client-go/pkg/util/integer/integer.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/intstr/generated.pb.go b/vendor/k8s.io/client-go/pkg/util/intstr/generated.pb.go similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/util/intstr/generated.pb.go rename to vendor/k8s.io/client-go/pkg/util/intstr/generated.pb.go index bd2d932..5165b24 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/intstr/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/util/intstr/generated.pb.go @@ -49,7 +49,7 @@ func (*IntOrString) ProtoMessage() {} func (*IntOrString) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{0} } func init() { - proto.RegisterType((*IntOrString)(nil), "k8s.io.kubernetes.pkg.util.intstr.IntOrString") + proto.RegisterType((*IntOrString)(nil), "k8s.io.client-go.pkg.util.intstr.IntOrString") } func (m *IntOrString) Marshal() (data []byte, err error) { size := m.Size() @@ -352,21 +352,22 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 256 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xe2, 0x32, 0xcc, 0xb6, 0x28, 0xd6, - 0xcb, 0xcc, 0xd7, 0xcf, 0x2e, 0x4d, 0x4a, 0x2d, 0xca, 0x4b, 0x2d, 0x49, 0x2d, 0xd6, 0x2f, 0xc8, - 0x4e, 0xd7, 0x2f, 0x2d, 0xc9, 0xcc, 0xd1, 0xcf, 0xcc, 0x2b, 0x29, 0x2e, 0x29, 0xd2, 0x4f, 0x4f, - 0xcd, 0x4b, 0x2d, 0x4a, 0x2c, 0x49, 0x4d, 0xd1, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x52, 0x84, - 0x68, 0xd1, 0x43, 0x68, 0xd1, 0x03, 0x6a, 0xd1, 0x03, 0x69, 0xd1, 0x83, 0x68, 0x91, 0xd2, 0x4d, - 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x4f, 0xcf, 0x4f, 0xcf, 0xd7, 0x07, - 0xeb, 0x4c, 0x2a, 0x4d, 0x03, 0xf3, 0xc0, 0x1c, 0x30, 0x0b, 0x62, 0xa2, 0xd2, 0x44, 0x46, 0x2e, - 0x6e, 0xcf, 0xbc, 0x12, 0xff, 0xa2, 0xe0, 0x92, 0xa2, 0xcc, 0xbc, 0x74, 0x21, 0x0d, 0x2e, 0x96, - 0x92, 0xca, 0x82, 0x54, 0x09, 0x46, 0x05, 0x46, 0x0d, 0x66, 0x27, 0x91, 0x13, 0xf7, 0xe4, 0x19, - 0x1e, 0xdd, 0x93, 0x67, 0x09, 0x01, 0x8a, 0xfd, 0x82, 0xd2, 0x41, 0x60, 0x15, 0x42, 0x6a, 0x5c, - 0x6c, 0x40, 0x2b, 0xc3, 0x12, 0x73, 0x24, 0x98, 0x80, 0x6a, 0x59, 0x9d, 0xf8, 0xa0, 0x6a, 0xd9, - 0x3c, 0xc1, 0xa2, 0x41, 0x50, 0x59, 0x90, 0x3a, 0xa0, 0xbb, 0x40, 0xea, 0x98, 0x81, 0xea, 0x38, - 0x11, 0xea, 0x82, 0xc1, 0xa2, 0x41, 0x50, 0x59, 0x2b, 0x8e, 0x19, 0x0b, 0xe4, 0x19, 0x1a, 0xee, - 0x28, 0x30, 0x38, 0x69, 0x9c, 0x78, 0x28, 0xc7, 0x70, 0x01, 0x88, 0x6f, 0x00, 0x71, 0xc3, 0x23, - 0x39, 0xc6, 0x13, 0x40, 0x7c, 0x01, 0x88, 0x1f, 0x00, 0xf1, 0x84, 0xc7, 0x72, 0x0c, 0x51, 0x6c, - 0x10, 0xcf, 0x02, 0x02, 0x00, 0x00, 0xff, 0xff, 0x68, 0x57, 0xfb, 0xfa, 0x43, 0x01, 0x00, 0x00, + // 269 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x44, 0x8f, 0x31, 0x4e, 0xc3, 0x30, + 0x18, 0x85, 0x6d, 0x5a, 0x2a, 0x08, 0x12, 0x43, 0xc4, 0x50, 0x31, 0x38, 0x81, 0x01, 0x79, 0xc1, + 0x16, 0x1b, 0x62, 0xcc, 0xd6, 0x09, 0x29, 0x45, 0x0c, 0x6c, 0x0d, 0x18, 0x63, 0xa5, 0xd8, 0x96, + 0xf3, 0x67, 0xe8, 0xd6, 0x23, 0xc0, 0xc6, 0xc8, 0x71, 0x32, 0x76, 0x64, 0x40, 0x15, 0x31, 0xb7, + 0x60, 0x42, 0x71, 0x22, 0x75, 0xb2, 0xdf, 0x7b, 0xdf, 0x67, 0xc9, 0xd1, 0x55, 0x79, 0x5d, 0x31, + 0x65, 0x78, 0x59, 0x17, 0xc2, 0x69, 0x01, 0xa2, 0xe2, 0xb6, 0x94, 0xbc, 0x06, 0xb5, 0xe4, 0x4a, + 0x43, 0x05, 0x8e, 0x4b, 0xa1, 0x85, 0x5b, 0x80, 0x78, 0x62, 0xd6, 0x19, 0x30, 0xf1, 0x59, 0xaf, + 0xb0, 0x9d, 0xc2, 0x6c, 0x29, 0x59, 0xa7, 0xb0, 0x5e, 0x39, 0xbd, 0x94, 0x0a, 0x5e, 0xea, 0x82, + 0x3d, 0x9a, 0x57, 0x2e, 0x8d, 0x34, 0x3c, 0x98, 0x45, 0xfd, 0x1c, 0x52, 0x08, 0xe1, 0xd6, 0xbf, + 0x78, 0xfe, 0x8e, 0xa3, 0xa3, 0x99, 0x86, 0x5b, 0x37, 0x07, 0xa7, 0xb4, 0x8c, 0x69, 0x34, 0x86, + 0x95, 0x15, 0x53, 0x9c, 0x62, 0x3a, 0xca, 0x4e, 0x9a, 0x6d, 0x82, 0xfc, 0x36, 0x19, 0xdf, 0xad, + 0xac, 0xf8, 0x1b, 0xce, 0x3c, 0x10, 0xf1, 0x45, 0x34, 0x51, 0x1a, 0xee, 0x17, 0xcb, 0xe9, 0x5e, + 0x8a, 0xe9, 0x7e, 0x76, 0x3c, 0xb0, 0x93, 0x59, 0x68, 0xf3, 0x61, 0xed, 0xb8, 0x0a, 0x5c, 0xc7, + 0x8d, 0x52, 0x4c, 0x0f, 0x77, 0xdc, 0x3c, 0xb4, 0xf9, 0xb0, 0xde, 0x1c, 0x7c, 0x7c, 0x26, 0x68, + 0xfd, 0x9d, 0xa2, 0x8c, 0x36, 0x2d, 0x41, 0x9b, 0x96, 0xa0, 0xaf, 0x96, 0xa0, 0xb5, 0x27, 0xb8, + 0xf1, 0x04, 0x6f, 0x3c, 0xc1, 0x3f, 0x9e, 0xe0, 0xb7, 0x5f, 0x82, 0x1e, 0x26, 0xfd, 0x67, 0xff, + 0x03, 0x00, 0x00, 0xff, 0xff, 0x68, 0x57, 0xfb, 0xfa, 0x43, 0x01, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/util/intstr/generated.proto b/vendor/k8s.io/client-go/pkg/util/intstr/generated.proto similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/intstr/generated.proto rename to vendor/k8s.io/client-go/pkg/util/intstr/generated.proto diff --git a/vendor/k8s.io/kubernetes/pkg/util/intstr/intstr.go b/vendor/k8s.io/client-go/pkg/util/intstr/intstr.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/util/intstr/intstr.go rename to vendor/k8s.io/client-go/pkg/util/intstr/intstr.go index 248a16c..a365f62 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/intstr/intstr.go +++ b/vendor/k8s.io/client-go/pkg/util/intstr/intstr.go @@ -23,7 +23,7 @@ import ( "strconv" "strings" - "k8s.io/kubernetes/pkg/genericapiserver/openapi/common" + "k8s.io/client-go/pkg/genericapiserver/openapi/common" "github.com/go-openapi/spec" "github.com/google/gofuzz" diff --git a/vendor/k8s.io/kubernetes/pkg/util/json/json.go b/vendor/k8s.io/client-go/pkg/util/json/json.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/json/json.go rename to vendor/k8s.io/client-go/pkg/util/json/json.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/labels/doc.go b/vendor/k8s.io/client-go/pkg/util/labels/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/labels/doc.go rename to vendor/k8s.io/client-go/pkg/util/labels/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/labels/labels.go b/vendor/k8s.io/client-go/pkg/util/labels/labels.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/util/labels/labels.go rename to vendor/k8s.io/client-go/pkg/util/labels/labels.go index 262f66e..3e1f623 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/labels/labels.go +++ b/vendor/k8s.io/client-go/pkg/util/labels/labels.go @@ -19,7 +19,7 @@ package labels import ( "fmt" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // Clones the given map and returns a new map with the given key and value added. diff --git a/vendor/k8s.io/kubernetes/pkg/util/net/http.go b/vendor/k8s.io/client-go/pkg/util/net/http.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/net/http.go rename to vendor/k8s.io/client-go/pkg/util/net/http.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/net/interface.go b/vendor/k8s.io/client-go/pkg/util/net/interface.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/net/interface.go rename to vendor/k8s.io/client-go/pkg/util/net/interface.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/net/port_range.go b/vendor/k8s.io/client-go/pkg/util/net/port_range.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/net/port_range.go rename to vendor/k8s.io/client-go/pkg/util/net/port_range.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/net/port_split.go b/vendor/k8s.io/client-go/pkg/util/net/port_split.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/util/net/port_split.go rename to vendor/k8s.io/client-go/pkg/util/net/port_split.go index 29c985e..a341983 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/net/port_split.go +++ b/vendor/k8s.io/client-go/pkg/util/net/port_split.go @@ -19,7 +19,7 @@ package net import ( "strings" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/util/sets" ) var validSchemes = sets.NewString("http", "https", "") diff --git a/vendor/k8s.io/kubernetes/pkg/util/net/util.go b/vendor/k8s.io/client-go/pkg/util/net/util.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/net/util.go rename to vendor/k8s.io/client-go/pkg/util/net/util.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/parsers/parsers.go b/vendor/k8s.io/client-go/pkg/util/parsers/parsers.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/parsers/parsers.go rename to vendor/k8s.io/client-go/pkg/util/parsers/parsers.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/rand/rand.go b/vendor/k8s.io/client-go/pkg/util/rand/rand.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/rand/rand.go rename to vendor/k8s.io/client-go/pkg/util/rand/rand.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/runtime/runtime.go b/vendor/k8s.io/client-go/pkg/util/runtime/runtime.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/runtime/runtime.go rename to vendor/k8s.io/client-go/pkg/util/runtime/runtime.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/byte.go b/vendor/k8s.io/client-go/pkg/util/sets/byte.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/byte.go rename to vendor/k8s.io/client-go/pkg/util/sets/byte.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/doc.go b/vendor/k8s.io/client-go/pkg/util/sets/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/doc.go rename to vendor/k8s.io/client-go/pkg/util/sets/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/empty.go b/vendor/k8s.io/client-go/pkg/util/sets/empty.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/empty.go rename to vendor/k8s.io/client-go/pkg/util/sets/empty.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/int.go b/vendor/k8s.io/client-go/pkg/util/sets/int.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/int.go rename to vendor/k8s.io/client-go/pkg/util/sets/int.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/int64.go b/vendor/k8s.io/client-go/pkg/util/sets/int64.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/int64.go rename to vendor/k8s.io/client-go/pkg/util/sets/int64.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/sets/string.go b/vendor/k8s.io/client-go/pkg/util/sets/string.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/sets/string.go rename to vendor/k8s.io/client-go/pkg/util/sets/string.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/template.go b/vendor/k8s.io/client-go/pkg/util/template.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/template.go rename to vendor/k8s.io/client-go/pkg/util/template.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/trace.go b/vendor/k8s.io/client-go/pkg/util/trace.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/trace.go rename to vendor/k8s.io/client-go/pkg/util/trace.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/trie.go b/vendor/k8s.io/client-go/pkg/util/trie.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/trie.go rename to vendor/k8s.io/client-go/pkg/util/trie.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/umask.go b/vendor/k8s.io/client-go/pkg/util/umask.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/umask.go rename to vendor/k8s.io/client-go/pkg/util/umask.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/umask_windows.go b/vendor/k8s.io/client-go/pkg/util/umask_windows.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/umask_windows.go rename to vendor/k8s.io/client-go/pkg/util/umask_windows.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/util.go b/vendor/k8s.io/client-go/pkg/util/util.go similarity index 82% rename from vendor/k8s.io/kubernetes/pkg/util/util.go rename to vendor/k8s.io/client-go/pkg/util/util.go index 7a94149..356b295 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/util.go +++ b/vendor/k8s.io/client-go/pkg/util/util.go @@ -84,36 +84,20 @@ func FileExists(filename string) (bool, error) { return true, nil } -// borrowed from ioutil.ReadDir -// ReadDir reads the directory named by dirname and returns -// a list of directory entries, minus those with lstat errors -func ReadDirNoExit(dirname string) ([]os.FileInfo, []error, error) { +// ReadDirNoStat returns a string of files/directories contained +// in dirname without calling lstat on them. +func ReadDirNoStat(dirname string) ([]string, error) { if dirname == "" { dirname = "." } f, err := os.Open(dirname) if err != nil { - return nil, nil, err + return nil, err } defer f.Close() - names, err := f.Readdirnames(-1) - list := make([]os.FileInfo, 0, len(names)) - errs := make([]error, 0, len(names)) - for _, filename := range names { - fip, lerr := os.Lstat(dirname + "/" + filename) - if os.IsNotExist(lerr) { - // File disappeared between readdir + stat. - // Just treat it as if it didn't exist. - continue - } - - list = append(list, fip) - errs = append(errs, lerr) - } - - return list, errs, nil + return f.Readdirnames(-1) } // IntPtr returns a pointer to an int diff --git a/vendor/k8s.io/kubernetes/pkg/util/uuid/uuid.go b/vendor/k8s.io/client-go/pkg/util/uuid/uuid.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/util/uuid/uuid.go rename to vendor/k8s.io/client-go/pkg/util/uuid/uuid.go index 51f2689..ad0e8a6 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/uuid/uuid.go +++ b/vendor/k8s.io/client-go/pkg/util/uuid/uuid.go @@ -20,7 +20,7 @@ import ( "sync" "github.com/pborman/uuid" - "k8s.io/kubernetes/pkg/types" + "k8s.io/client-go/pkg/types" ) var uuidLock sync.Mutex diff --git a/vendor/k8s.io/kubernetes/pkg/util/validation/field/errors.go b/vendor/k8s.io/client-go/pkg/util/validation/field/errors.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/util/validation/field/errors.go rename to vendor/k8s.io/client-go/pkg/util/validation/field/errors.go index b4a6c5c..6d11ec6 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/validation/field/errors.go +++ b/vendor/k8s.io/client-go/pkg/util/validation/field/errors.go @@ -21,7 +21,7 @@ import ( "fmt" "strings" - utilerrors "k8s.io/kubernetes/pkg/util/errors" + utilerrors "k8s.io/client-go/pkg/util/errors" ) // Error is an implementation of the 'error' interface, which represents a diff --git a/vendor/k8s.io/kubernetes/pkg/util/validation/field/path.go b/vendor/k8s.io/client-go/pkg/util/validation/field/path.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/validation/field/path.go rename to vendor/k8s.io/client-go/pkg/util/validation/field/path.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/validation/validation.go b/vendor/k8s.io/client-go/pkg/util/validation/validation.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/validation/validation.go rename to vendor/k8s.io/client-go/pkg/util/validation/validation.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/wait/doc.go b/vendor/k8s.io/client-go/pkg/util/wait/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/wait/doc.go rename to vendor/k8s.io/client-go/pkg/util/wait/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/util/wait/wait.go b/vendor/k8s.io/client-go/pkg/util/wait/wait.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/util/wait/wait.go rename to vendor/k8s.io/client-go/pkg/util/wait/wait.go index 65f2e0b..ceafded 100644 --- a/vendor/k8s.io/kubernetes/pkg/util/wait/wait.go +++ b/vendor/k8s.io/client-go/pkg/util/wait/wait.go @@ -21,7 +21,7 @@ import ( "math/rand" "time" - "k8s.io/kubernetes/pkg/util/runtime" + "k8s.io/client-go/pkg/util/runtime" ) // For any test of the style: diff --git a/vendor/k8s.io/kubernetes/pkg/util/yaml/decoder.go b/vendor/k8s.io/client-go/pkg/util/yaml/decoder.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/util/yaml/decoder.go rename to vendor/k8s.io/client-go/pkg/util/yaml/decoder.go diff --git a/vendor/k8s.io/kubernetes/pkg/version/.gitattributes b/vendor/k8s.io/client-go/pkg/version/.gitattributes similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/version/.gitattributes rename to vendor/k8s.io/client-go/pkg/version/.gitattributes diff --git a/vendor/k8s.io/kubernetes/pkg/version/base.go b/vendor/k8s.io/client-go/pkg/version/base.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/version/base.go rename to vendor/k8s.io/client-go/pkg/version/base.go index c377705..5909815 100644 --- a/vendor/k8s.io/kubernetes/pkg/version/base.go +++ b/vendor/k8s.io/client-go/pkg/version/base.go @@ -29,7 +29,7 @@ package version // works for GitHub tar downloads. // // When releasing a new Kubernetes version, this file is updated by -// build/mark_new_version.sh to reflect the new version, and then a +// build-tools/mark_new_version.sh to reflect the new version, and then a // git annotated tag (using format vX.Y where X == Major version and Y // == Minor version) is created to point to the commit that updates // pkg/version/base.go diff --git a/vendor/k8s.io/kubernetes/pkg/version/doc.go b/vendor/k8s.io/client-go/pkg/version/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/version/doc.go rename to vendor/k8s.io/client-go/pkg/version/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/version/semver.go b/vendor/k8s.io/client-go/pkg/version/semver.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/version/semver.go rename to vendor/k8s.io/client-go/pkg/version/semver.go diff --git a/vendor/k8s.io/kubernetes/pkg/version/version.go b/vendor/k8s.io/client-go/pkg/version/version.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/version/version.go rename to vendor/k8s.io/client-go/pkg/version/version.go diff --git a/vendor/k8s.io/kubernetes/pkg/watch/doc.go b/vendor/k8s.io/client-go/pkg/watch/doc.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/watch/doc.go rename to vendor/k8s.io/client-go/pkg/watch/doc.go diff --git a/vendor/k8s.io/kubernetes/pkg/watch/filter.go b/vendor/k8s.io/client-go/pkg/watch/filter.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/watch/filter.go rename to vendor/k8s.io/client-go/pkg/watch/filter.go diff --git a/vendor/k8s.io/kubernetes/pkg/watch/mux.go b/vendor/k8s.io/client-go/pkg/watch/mux.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/watch/mux.go rename to vendor/k8s.io/client-go/pkg/watch/mux.go index ec6de05..3c7cfd1 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/mux.go +++ b/vendor/k8s.io/client-go/pkg/watch/mux.go @@ -19,8 +19,8 @@ package watch import ( "sync" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // FullChannelBehavior controls how the Broadcaster reacts if a watcher's watch diff --git a/vendor/k8s.io/kubernetes/pkg/watch/streamwatcher.go b/vendor/k8s.io/client-go/pkg/watch/streamwatcher.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/watch/streamwatcher.go rename to vendor/k8s.io/client-go/pkg/watch/streamwatcher.go index 26cf61d..5b0f688 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/streamwatcher.go +++ b/vendor/k8s.io/client-go/pkg/watch/streamwatcher.go @@ -21,9 +21,9 @@ import ( "sync" "github.com/golang/glog" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/net" - utilruntime "k8s.io/kubernetes/pkg/util/runtime" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/net" + utilruntime "k8s.io/client-go/pkg/util/runtime" ) // Decoder allows StreamWatcher to watch any stream for which a Decoder can be written. diff --git a/vendor/k8s.io/kubernetes/pkg/watch/until.go b/vendor/k8s.io/client-go/pkg/watch/until.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/watch/until.go rename to vendor/k8s.io/client-go/pkg/watch/until.go index 5624d50..a388bb0 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/until.go +++ b/vendor/k8s.io/client-go/pkg/watch/until.go @@ -19,10 +19,10 @@ package watch import ( "time" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/wait" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/meta" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/wait" ) // ConditionFunc returns true if the condition has been reached, false if it has not been reached yet, diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/decoder.go b/vendor/k8s.io/client-go/pkg/watch/versioned/decoder.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/decoder.go rename to vendor/k8s.io/client-go/pkg/watch/versioned/decoder.go index e586527..25390c5 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/versioned/decoder.go +++ b/vendor/k8s.io/client-go/pkg/watch/versioned/decoder.go @@ -19,9 +19,9 @@ package versioned import ( "fmt" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/streaming" - "k8s.io/kubernetes/pkg/watch" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/streaming" + "k8s.io/client-go/pkg/watch" ) // Decoder implements the watch.Decoder interface for io.ReadClosers that diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/encoder.go b/vendor/k8s.io/client-go/pkg/watch/versioned/encoder.go similarity index 92% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/encoder.go rename to vendor/k8s.io/client-go/pkg/watch/versioned/encoder.go index df23e0b..3d7f436 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/versioned/encoder.go +++ b/vendor/k8s.io/client-go/pkg/watch/versioned/encoder.go @@ -19,9 +19,9 @@ package versioned import ( "encoding/json" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/streaming" - "k8s.io/kubernetes/pkg/watch" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/streaming" + "k8s.io/client-go/pkg/watch" ) // Encoder serializes watch.Events into io.Writer. The internal objects diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/generated.pb.go b/vendor/k8s.io/client-go/pkg/watch/versioned/generated.pb.go similarity index 81% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/generated.pb.go rename to vendor/k8s.io/client-go/pkg/watch/versioned/generated.pb.go index 108bfa5..b26080e 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/versioned/generated.pb.go +++ b/vendor/k8s.io/client-go/pkg/watch/versioned/generated.pb.go @@ -52,7 +52,7 @@ func (*Event) ProtoMessage() {} func (*Event) Descriptor() ([]byte, []int) { return fileDescriptorGenerated, []int{0} } func init() { - proto.RegisterType((*Event)(nil), "k8s.io.kubernetes.pkg.watch.versioned.Event") + proto.RegisterType((*Event)(nil), "k8s.io.client-go.pkg.watch.versioned.Event") } func (m *Event) Marshal() (data []byte, err error) { size := m.Size() @@ -368,23 +368,23 @@ var ( ) var fileDescriptorGenerated = []byte{ - // 273 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xe2, 0x32, 0xcd, 0xb6, 0x28, 0xd6, - 0xcb, 0xcc, 0xd7, 0xcf, 0x2e, 0x4d, 0x4a, 0x2d, 0xca, 0x4b, 0x2d, 0x49, 0x2d, 0xd6, 0x2f, 0xc8, - 0x4e, 0xd7, 0x2f, 0x4f, 0x2c, 0x49, 0xce, 0xd0, 0x2f, 0x4b, 0x2d, 0x2a, 0xce, 0xcc, 0xcf, 0x4b, - 0x4d, 0xd1, 0x4f, 0x4f, 0xcd, 0x4b, 0x2d, 0x4a, 0x2c, 0x49, 0x4d, 0xd1, 0x2b, 0x28, 0xca, 0x2f, - 0xc9, 0x17, 0x52, 0x85, 0x68, 0xd3, 0x43, 0x68, 0xd3, 0x03, 0x6a, 0xd3, 0x03, 0x6b, 0xd3, 0x83, - 0x6b, 0x93, 0xd2, 0x4d, 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x4f, 0xcf, - 0x4f, 0xcf, 0xd7, 0x07, 0xeb, 0x4e, 0x2a, 0x4d, 0x03, 0xf3, 0xc0, 0x1c, 0x30, 0x0b, 0x62, 0xaa, - 0x94, 0x2e, 0x76, 0xc7, 0x14, 0x95, 0xe6, 0x95, 0x64, 0xe6, 0xa6, 0xa2, 0x3b, 0x42, 0xca, 0x10, - 0xbb, 0xf2, 0xd2, 0x92, 0xcc, 0x1c, 0xfd, 0xcc, 0xbc, 0x92, 0xe2, 0x92, 0x22, 0x74, 0x2d, 0x4a, - 0x75, 0x5c, 0xac, 0xae, 0x65, 0xa9, 0x79, 0x25, 0x42, 0x0a, 0x5c, 0x2c, 0x25, 0x95, 0x05, 0xa9, - 0x12, 0x8c, 0x0a, 0x8c, 0x1a, 0x9c, 0x4e, 0x3c, 0x27, 0xee, 0xc9, 0x33, 0x3c, 0xba, 0x27, 0xcf, - 0x12, 0x02, 0x14, 0x0b, 0x02, 0xcb, 0x08, 0x05, 0x73, 0xb1, 0xe5, 0x27, 0x65, 0xa5, 0x26, 0x97, - 0x48, 0x30, 0x01, 0xd5, 0x70, 0x1b, 0x69, 0xeb, 0x61, 0xf7, 0x33, 0xd4, 0x75, 0x7a, 0x41, 0x89, - 0xe5, 0xae, 0x15, 0x25, 0xa9, 0x79, 0x20, 0xaf, 0x3b, 0xf1, 0x41, 0x0d, 0x64, 0xf3, 0x07, 0x1b, - 0x11, 0x04, 0x35, 0xca, 0x49, 0xfb, 0xc4, 0x43, 0x39, 0x86, 0x0b, 0x40, 0x7c, 0x03, 0x88, 0x1b, - 0x1e, 0xc9, 0x31, 0x9e, 0x00, 0xe2, 0x0b, 0x40, 0xfc, 0x00, 0x88, 0x27, 0x3c, 0x96, 0x63, 0x88, - 0xe2, 0x84, 0x87, 0x1e, 0x20, 0x00, 0x00, 0xff, 0xff, 0x23, 0x3d, 0x7b, 0x7e, 0x9c, 0x01, 0x00, - 0x00, + // 280 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x6c, 0x90, 0x41, 0x4b, 0xc3, 0x30, + 0x18, 0x86, 0x1b, 0x99, 0x83, 0x55, 0xf1, 0xd0, 0xd3, 0xe8, 0x21, 0x2b, 0x82, 0x30, 0x18, 0x4b, + 0x50, 0x10, 0x3c, 0x17, 0x76, 0x16, 0xaa, 0x27, 0x6f, 0x6d, 0xf7, 0x99, 0xc5, 0xba, 0xa4, 0xa4, + 0x5f, 0x37, 0x77, 0x11, 0x7f, 0x82, 0x3f, 0xab, 0xc7, 0x1d, 0x3d, 0x0d, 0x5b, 0xff, 0x88, 0x98, + 0x95, 0x09, 0xa3, 0xb7, 0xbc, 0x24, 0xcf, 0xc3, 0xfb, 0xc6, 0xbd, 0xcd, 0xee, 0x0a, 0x26, 0x35, + 0xcf, 0xca, 0x04, 0x8c, 0x02, 0x84, 0x82, 0xe7, 0x99, 0xe0, 0xeb, 0x18, 0xd3, 0x05, 0x5f, 0x81, + 0x29, 0xa4, 0x56, 0x30, 0xe7, 0x02, 0x14, 0x98, 0x18, 0x61, 0xce, 0x72, 0xa3, 0x51, 0x7b, 0x57, + 0x7b, 0x8c, 0xfd, 0x63, 0x2c, 0xcf, 0x04, 0xb3, 0x18, 0x3b, 0x60, 0xfe, 0x54, 0x48, 0x5c, 0x94, + 0x09, 0x4b, 0xf5, 0x92, 0x0b, 0x2d, 0x34, 0xb7, 0x74, 0x52, 0x3e, 0xdb, 0x64, 0x83, 0x3d, 0xed, + 0xad, 0xfe, 0xb4, 0xbb, 0x8c, 0x29, 0x15, 0xca, 0x25, 0x1c, 0x97, 0xf0, 0xaf, 0xbb, 0x9f, 0x97, + 0x28, 0x5f, 0xb9, 0x54, 0x58, 0xa0, 0x39, 0x46, 0x2e, 0xdf, 0xdd, 0xd3, 0xd9, 0x0a, 0x14, 0x7a, + 0x81, 0xdb, 0xc3, 0x4d, 0x0e, 0x43, 0x12, 0x90, 0xf1, 0x20, 0x3c, 0xaf, 0x76, 0x23, 0xa7, 0xd9, + 0x8d, 0x7a, 0x8f, 0x9b, 0x1c, 0x22, 0x7b, 0xe3, 0x3d, 0xb8, 0x7d, 0x9d, 0xbc, 0x40, 0x8a, 0xc3, + 0x93, 0x80, 0x8c, 0xcf, 0x6e, 0x26, 0xac, 0x7b, 0x73, 0xdb, 0x8e, 0x45, 0xf1, 0x7a, 0xf6, 0x86, + 0xa0, 0xfe, 0xa6, 0x87, 0x17, 0xad, 0xb0, 0x7f, 0x6f, 0x15, 0x51, 0xab, 0x0a, 0x27, 0x55, 0x4d, + 0x9d, 0x6d, 0x4d, 0x9d, 0xaf, 0x9a, 0x3a, 0x1f, 0x0d, 0x25, 0x55, 0x43, 0xc9, 0xb6, 0xa1, 0xe4, + 0xbb, 0xa1, 0xe4, 0xf3, 0x87, 0x3a, 0x4f, 0x83, 0xc3, 0xef, 0xfd, 0x06, 0x00, 0x00, 0xff, 0xff, + 0x23, 0x3d, 0x7b, 0x7e, 0x9c, 0x01, 0x00, 0x00, } diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/generated.proto b/vendor/k8s.io/client-go/pkg/watch/versioned/generated.proto similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/generated.proto rename to vendor/k8s.io/client-go/pkg/watch/versioned/generated.proto diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/register.go b/vendor/k8s.io/client-go/pkg/watch/versioned/register.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/register.go rename to vendor/k8s.io/client-go/pkg/watch/versioned/register.go index e90a021..2223a93 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/versioned/register.go +++ b/vendor/k8s.io/client-go/pkg/watch/versioned/register.go @@ -17,10 +17,10 @@ limitations under the License. package versioned import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/conversion" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/watch" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/conversion" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/watch" ) // WatchEventKind is name reserved for serializing watch events. diff --git a/vendor/k8s.io/kubernetes/pkg/watch/versioned/types.go b/vendor/k8s.io/client-go/pkg/watch/versioned/types.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/watch/versioned/types.go rename to vendor/k8s.io/client-go/pkg/watch/versioned/types.go index 430c357..16b8b02 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/versioned/types.go +++ b/vendor/k8s.io/client-go/pkg/watch/versioned/types.go @@ -19,7 +19,7 @@ limitations under the License. package versioned import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) // Event represents a single event to a watched resource. diff --git a/vendor/k8s.io/kubernetes/pkg/watch/watch.go b/vendor/k8s.io/client-go/pkg/watch/watch.go similarity index 99% rename from vendor/k8s.io/kubernetes/pkg/watch/watch.go rename to vendor/k8s.io/client-go/pkg/watch/watch.go index 550149c..0995e03 100644 --- a/vendor/k8s.io/kubernetes/pkg/watch/watch.go +++ b/vendor/k8s.io/client-go/pkg/watch/watch.go @@ -20,7 +20,7 @@ import ( "fmt" "sync" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" "github.com/golang/glog" ) diff --git a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/gcp/gcp.go b/vendor/k8s.io/client-go/plugin/pkg/client/auth/gcp/gcp.go similarity index 86% rename from vendor/k8s.io/kubernetes/plugin/pkg/client/auth/gcp/gcp.go rename to vendor/k8s.io/client-go/plugin/pkg/client/auth/gcp/gcp.go index 57fd98c..48b8d52 100644 --- a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/gcp/gcp.go +++ b/vendor/k8s.io/client-go/plugin/pkg/client/auth/gcp/gcp.go @@ -24,21 +24,21 @@ import ( "golang.org/x/net/context" "golang.org/x/oauth2" "golang.org/x/oauth2/google" - "k8s.io/kubernetes/pkg/client/restclient" + "k8s.io/client-go/rest" ) func init() { - if err := restclient.RegisterAuthProviderPlugin("gcp", newGCPAuthProvider); err != nil { + if err := rest.RegisterAuthProviderPlugin("gcp", newGCPAuthProvider); err != nil { glog.Fatalf("Failed to register gcp auth plugin: %v", err) } } type gcpAuthProvider struct { tokenSource oauth2.TokenSource - persister restclient.AuthProviderConfigPersister + persister rest.AuthProviderConfigPersister } -func newGCPAuthProvider(_ string, gcpConfig map[string]string, persister restclient.AuthProviderConfigPersister) (restclient.AuthProvider, error) { +func newGCPAuthProvider(_ string, gcpConfig map[string]string, persister rest.AuthProviderConfigPersister) (rest.AuthProvider, error) { ts, err := newCachedTokenSource(gcpConfig["access-token"], gcpConfig["expiry"], persister) if err != nil { return nil, err @@ -59,10 +59,10 @@ type cachedTokenSource struct { source oauth2.TokenSource accessToken string expiry time.Time - persister restclient.AuthProviderConfigPersister + persister rest.AuthProviderConfigPersister } -func newCachedTokenSource(accessToken, expiry string, persister restclient.AuthProviderConfigPersister) (*cachedTokenSource, error) { +func newCachedTokenSource(accessToken, expiry string, persister rest.AuthProviderConfigPersister) (*cachedTokenSource, error) { var expiryTime time.Time if parsedTime, err := time.Parse(time.RFC3339Nano, expiry); err == nil { expiryTime = parsedTime diff --git a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/oidc/OWNERS b/vendor/k8s.io/client-go/plugin/pkg/client/auth/oidc/OWNERS similarity index 100% rename from vendor/k8s.io/kubernetes/plugin/pkg/client/auth/oidc/OWNERS rename to vendor/k8s.io/client-go/plugin/pkg/client/auth/oidc/OWNERS diff --git a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/oidc/oidc.go b/vendor/k8s.io/client-go/plugin/pkg/client/auth/oidc/oidc.go similarity index 93% rename from vendor/k8s.io/kubernetes/plugin/pkg/client/auth/oidc/oidc.go rename to vendor/k8s.io/client-go/plugin/pkg/client/auth/oidc/oidc.go index 155bb48..f5da439 100644 --- a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/oidc/oidc.go +++ b/vendor/k8s.io/client-go/plugin/pkg/client/auth/oidc/oidc.go @@ -29,8 +29,8 @@ import ( "github.com/coreos/go-oidc/oidc" "github.com/golang/glog" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/util/wait" + "k8s.io/client-go/pkg/util/wait" + "k8s.io/client-go/rest" ) const ( @@ -54,12 +54,12 @@ var ( ) func init() { - if err := restclient.RegisterAuthProviderPlugin("oidc", newOIDCAuthProvider); err != nil { + if err := rest.RegisterAuthProviderPlugin("oidc", newOIDCAuthProvider); err != nil { glog.Fatalf("Failed to register oidc auth plugin: %v", err) } } -func newOIDCAuthProvider(_ string, cfg map[string]string, persister restclient.AuthProviderConfigPersister) (restclient.AuthProvider, error) { +func newOIDCAuthProvider(_ string, cfg map[string]string, persister rest.AuthProviderConfigPersister) (rest.AuthProvider, error) { issuer := cfg[cfgIssuerUrl] if issuer == "" { return nil, fmt.Errorf("Must provide %s", cfgIssuerUrl) @@ -84,14 +84,14 @@ func newOIDCAuthProvider(_ string, cfg map[string]string, persister restclient.A } } - clientConfig := restclient.Config{ - TLSClientConfig: restclient.TLSClientConfig{ + clientConfig := rest.Config{ + TLSClientConfig: rest.TLSClientConfig{ CAFile: cfg[cfgCertificateAuthority], CAData: certAuthData, }, } - trans, err := restclient.TransportFor(&clientConfig) + trans, err := rest.TransportFor(&clientConfig) if err != nil { return nil, err } @@ -200,7 +200,7 @@ func (r *roundTripper) RoundTrip(req *http.Request) (*http.Response, error) { type idTokenRefresher struct { cfg map[string]string client OIDCClient - persister restclient.AuthProviderConfigPersister + persister rest.AuthProviderConfigPersister intialIDToken jose.JWT } diff --git a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/plugins.go b/vendor/k8s.io/client-go/plugin/pkg/client/auth/plugins.go similarity index 86% rename from vendor/k8s.io/kubernetes/plugin/pkg/client/auth/plugins.go rename to vendor/k8s.io/client-go/plugin/pkg/client/auth/plugins.go index 21813b0..5cb2375 100644 --- a/vendor/k8s.io/kubernetes/plugin/pkg/client/auth/plugins.go +++ b/vendor/k8s.io/client-go/plugin/pkg/client/auth/plugins.go @@ -18,6 +18,6 @@ package auth import ( // Initialize all known client auth plugins. - _ "k8s.io/kubernetes/plugin/pkg/client/auth/gcp" - _ "k8s.io/kubernetes/plugin/pkg/client/auth/oidc" + _ "k8s.io/client-go/plugin/pkg/client/auth/gcp" + _ "k8s.io/client-go/plugin/pkg/client/auth/oidc" ) diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/client.go b/vendor/k8s.io/client-go/rest/client.go similarity index 78% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/client.go rename to vendor/k8s.io/client-go/rest/client.go index 1ebd3d9..6e392cf 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/client.go +++ b/vendor/k8s.io/client-go/rest/client.go @@ -14,10 +14,11 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "fmt" + "mime" "net/http" "net/url" "os" @@ -25,10 +26,10 @@ import ( "strings" "time" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/util/flowcontrol" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/util/flowcontrol" ) const ( @@ -38,6 +39,18 @@ const ( envBackoffDuration = "KUBE_CLIENT_BACKOFF_DURATION" ) +// Interface captures the set of operations for generically interacting with Kubernetes REST apis. +type Interface interface { + GetRateLimiter() flowcontrol.RateLimiter + Verb(verb string) *Request + Post() *Request + Put() *Request + Patch(pt api.PatchType) *Request + Get() *Request + Delete() *Request + APIVersion() unversioned.GroupVersion +} + // RESTClient imposes common Kubernetes API conventions on a set of resource paths. // The baseURL is expected to point to an HTTP or HTTPS path that is the parent // of one or more resources. The server should return a decodable API resource @@ -141,34 +154,48 @@ func readExpBackoffConfig() BackoffManager { } // createSerializers creates all necessary serializers for given contentType. +// TODO: the negotiated serializer passed to this method should probably return +// serializers that control decoding and versioning without this package +// being aware of the types. Depends on whether RESTClient must deal with +// generic infrastructure. func createSerializers(config ContentConfig) (*Serializers, error) { - negotiated := config.NegotiatedSerializer + mediaTypes := config.NegotiatedSerializer.SupportedMediaTypes() contentType := config.ContentType - info, ok := negotiated.SerializerForMediaType(contentType, nil) - if !ok { - return nil, fmt.Errorf("serializer for %s not registered", contentType) + mediaType, _, err := mime.ParseMediaType(contentType) + if err != nil { + return nil, fmt.Errorf("the content type specified in the client configuration is not recognized: %v", err) } - streamInfo, ok := negotiated.StreamingSerializerForMediaType(contentType, nil) + info, ok := runtime.SerializerInfoForMediaType(mediaTypes, mediaType) if !ok { - return nil, fmt.Errorf("streaming serializer for %s not registered", contentType) + if len(contentType) != 0 || len(mediaTypes) == 0 { + return nil, fmt.Errorf("no serializers registered for %s", contentType) + } + info = mediaTypes[0] } + internalGV := unversioned.GroupVersion{ Group: config.GroupVersion.Group, Version: runtime.APIVersionInternal, } - return &Serializers{ - Encoder: negotiated.EncoderForVersion(info.Serializer, *config.GroupVersion), - Decoder: negotiated.DecoderToVersion(info.Serializer, internalGV), - StreamingSerializer: streamInfo.Serializer, - Framer: streamInfo.Framer, + + s := &Serializers{ + Encoder: config.NegotiatedSerializer.EncoderForVersion(info.Serializer, *config.GroupVersion), + Decoder: config.NegotiatedSerializer.DecoderToVersion(info.Serializer, internalGV), + RenegotiatedDecoder: func(contentType string, params map[string]string) (runtime.Decoder, error) { - renegotiated, ok := negotiated.SerializerForMediaType(contentType, params) + info, ok := runtime.SerializerInfoForMediaType(mediaTypes, contentType) if !ok { return nil, fmt.Errorf("serializer for %s not registered", contentType) } - return negotiated.DecoderToVersion(renegotiated.Serializer, internalGV), nil + return config.NegotiatedSerializer.DecoderToVersion(info.Serializer, internalGV), nil }, - }, nil + } + if info.StreamSerializer != nil { + s.StreamingSerializer = info.StreamSerializer.Serializer + s.Framer = info.StreamSerializer.Framer + } + + return s, nil } // Verb begins a request with a verb (GET, POST, PUT, DELETE). diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/config.go b/vendor/k8s.io/client-go/rest/config.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/config.go rename to vendor/k8s.io/client-go/rest/config.go index e739d79..37d8756 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/config.go +++ b/vendor/k8s.io/client-go/rest/config.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "fmt" @@ -29,13 +29,13 @@ import ( "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - clientcmdapi "k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api" - "k8s.io/kubernetes/pkg/runtime" - certutil "k8s.io/kubernetes/pkg/util/cert" - "k8s.io/kubernetes/pkg/util/flowcontrol" - "k8s.io/kubernetes/pkg/version" + "k8s.io/client-go/pkg/api" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" + certutil "k8s.io/client-go/pkg/util/cert" + "k8s.io/client-go/pkg/util/flowcontrol" + "k8s.io/client-go/pkg/version" + clientcmdapi "k8s.io/client-go/tools/clientcmd/api" ) const ( diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/plugin.go b/vendor/k8s.io/client-go/rest/plugin.go similarity index 96% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/plugin.go rename to vendor/k8s.io/client-go/rest/plugin.go index 06ac3cc..cf8fbab 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/plugin.go +++ b/vendor/k8s.io/client-go/rest/plugin.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "fmt" @@ -23,7 +23,7 @@ import ( "github.com/golang/glog" - clientcmdapi "k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api" + clientcmdapi "k8s.io/client-go/tools/clientcmd/api" ) type AuthProvider interface { diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/request.go b/vendor/k8s.io/client-go/rest/request.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/request.go rename to vendor/k8s.io/client-go/rest/request.go index 2473a12..ef4cc6a 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/request.go +++ b/vendor/k8s.io/client-go/rest/request.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "bytes" @@ -32,20 +32,20 @@ import ( "time" "github.com/golang/glog" - "k8s.io/kubernetes/pkg/api/errors" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/api/v1" - pathvalidation "k8s.io/kubernetes/pkg/api/validation/path" - "k8s.io/kubernetes/pkg/client/metrics" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/labels" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/runtime/serializer/streaming" - "k8s.io/kubernetes/pkg/util/flowcontrol" - "k8s.io/kubernetes/pkg/util/net" - "k8s.io/kubernetes/pkg/util/sets" - "k8s.io/kubernetes/pkg/watch" - "k8s.io/kubernetes/pkg/watch/versioned" + "k8s.io/client-go/pkg/api/errors" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/v1" + pathvalidation "k8s.io/client-go/pkg/api/validation/path" + "k8s.io/client-go/pkg/fields" + "k8s.io/client-go/pkg/labels" + "k8s.io/client-go/pkg/runtime" + "k8s.io/client-go/pkg/runtime/serializer/streaming" + "k8s.io/client-go/pkg/util/flowcontrol" + "k8s.io/client-go/pkg/util/net" + "k8s.io/client-go/pkg/util/sets" + "k8s.io/client-go/pkg/watch" + "k8s.io/client-go/pkg/watch/versioned" + "k8s.io/client-go/tools/metrics" ) var ( @@ -795,6 +795,12 @@ func (r *Request) request(fn func(*http.Request, *http.Response)) error { req.Header = r.headers r.backoffMgr.Sleep(r.backoffMgr.CalculateBackoff(r.URL())) + if retries > 0 { + // We are retrying the request that we already send to apiserver + // at least once before. + // This request should also be throttled with the client-internal throttler. + r.tryThrottle() + } resp, err := client.Do(req) updateURLMetrics(r, resp, err) if err != nil { diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/transport.go b/vendor/k8s.io/client-go/rest/transport.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/transport.go rename to vendor/k8s.io/client-go/rest/transport.go index 5f3d671..0672fb4 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/transport.go +++ b/vendor/k8s.io/client-go/rest/transport.go @@ -14,13 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "crypto/tls" "net/http" - "k8s.io/kubernetes/pkg/client/transport" + "k8s.io/client-go/transport" ) // TLSConfigFor returns a tls.Config that will provide the transport level security defined diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/url_utils.go b/vendor/k8s.io/client-go/rest/url_utils.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/url_utils.go rename to vendor/k8s.io/client-go/rest/url_utils.go index 81f16d6..46da991 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/url_utils.go +++ b/vendor/k8s.io/client-go/rest/url_utils.go @@ -14,14 +14,14 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "fmt" "net/url" "path" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) // DefaultServerURL converts a host, host:port, or URL string to the default base server API path diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/urlbackoff.go b/vendor/k8s.io/client-go/rest/urlbackoff.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/urlbackoff.go rename to vendor/k8s.io/client-go/rest/urlbackoff.go index 24a89ed..1bfb61a 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/urlbackoff.go +++ b/vendor/k8s.io/client-go/rest/urlbackoff.go @@ -14,15 +14,15 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "net/url" "time" "github.com/golang/glog" - "k8s.io/kubernetes/pkg/util/flowcontrol" - "k8s.io/kubernetes/pkg/util/sets" + "k8s.io/client-go/pkg/util/flowcontrol" + "k8s.io/client-go/pkg/util/sets" ) // Set of resp. Codes that we backoff for. diff --git a/vendor/k8s.io/kubernetes/pkg/client/restclient/versions.go b/vendor/k8s.io/client-go/rest/versions.go similarity index 97% rename from vendor/k8s.io/kubernetes/pkg/client/restclient/versions.go rename to vendor/k8s.io/client-go/rest/versions.go index 3376434..12ef828 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/restclient/versions.go +++ b/vendor/k8s.io/client-go/rest/versions.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package restclient +package rest import ( "encoding/json" @@ -22,7 +22,7 @@ import ( "net/http" "path" - "k8s.io/kubernetes/pkg/api/unversioned" + "k8s.io/client-go/pkg/api/unversioned" ) const ( diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/helpers.go b/vendor/k8s.io/client-go/tools/clientcmd/api/helpers.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/helpers.go rename to vendor/k8s.io/client-go/tools/clientcmd/api/helpers.go diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/register.go b/vendor/k8s.io/client-go/tools/clientcmd/api/register.go similarity index 94% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/register.go rename to vendor/k8s.io/client-go/tools/clientcmd/api/register.go index 9c4c0f1..efca4ee 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/register.go +++ b/vendor/k8s.io/client-go/tools/clientcmd/api/register.go @@ -17,8 +17,8 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/api/unversioned" + "k8s.io/client-go/pkg/runtime" ) // SchemeGroupVersion is group version used to register these objects diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/types.go b/vendor/k8s.io/client-go/tools/clientcmd/api/types.go similarity index 95% rename from vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/types.go rename to vendor/k8s.io/client-go/tools/clientcmd/api/types.go index 9fd52e4..af4d9fe 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clientcmd/api/types.go +++ b/vendor/k8s.io/client-go/tools/clientcmd/api/types.go @@ -17,7 +17,7 @@ limitations under the License. package api import ( - "k8s.io/kubernetes/pkg/runtime" + "k8s.io/client-go/pkg/runtime" ) // Where possible, json tags match the cli argument names. @@ -28,12 +28,14 @@ import ( type Config struct { // Legacy field from pkg/api/types.go TypeMeta. // TODO(jlowdermilk): remove this after eliminating downstream dependencies. + // +optional Kind string `json:"kind,omitempty"` // DEPRECATED: APIVersion is the preferred api version for communicating with the kubernetes cluster (v1, v2, etc). // Because a cluster can run multiple API groups and potentially multiple versions of each, it no longer makes sense to specify // a single value for the cluster version. // This field isn't really needed anyway, so we are deprecating it without replacement. // It will be ignored if it is present. + // +optional APIVersion string `json:"apiVersion,omitempty"` // Preferences holds general information to be use for cli interactions Preferences Preferences `json:"preferences"` @@ -46,13 +48,16 @@ type Config struct { // CurrentContext is the name of the context that you would like to use by default CurrentContext string `json:"current-context"` // Extensions holds additional information. This is useful for extenders so that reads and writes don't clobber unknown fields + // +optional Extensions map[string]runtime.Object `json:"extensions,omitempty"` } // IMPORTANT if you add fields to this struct, please update IsConfigEmpty() type Preferences struct { + // +optional Colors bool `json:"colors,omitempty"` // Extensions holds additional information. This is useful for extenders so that reads and writes don't clobber unknown fields + // +optional Extensions map[string]runtime.Object `json:"extensions,omitempty"` } @@ -63,14 +68,19 @@ type Cluster struct { // Server is the address of the kubernetes cluster (https://hostname:port). Server string `json:"server"` // APIVersion is the preferred api version for communicating with the kubernetes cluster (v1, v2, etc). + // +optional APIVersion string `json:"api-version,omitempty"` // InsecureSkipTLSVerify skips the validity check for the server's certificate. This will make your HTTPS connections insecure. + // +optional InsecureSkipTLSVerify bool `json:"insecure-skip-tls-verify,omitempty"` // CertificateAuthority is the path to a cert file for the certificate authority. + // +optional CertificateAuthority string `json:"certificate-authority,omitempty"` // CertificateAuthorityData contains PEM-encoded certificate authority certificates. Overrides CertificateAuthority + // +optional CertificateAuthorityData []byte `json:"certificate-authority-data,omitempty"` // Extensions holds additional information. This is useful for extenders so that reads and writes don't clobber unknown fields + // +optional Extensions map[string]runtime.Object `json:"extensions,omitempty"` } @@ -79,26 +89,37 @@ type AuthInfo struct { // LocationOfOrigin indicates where this object came from. It is used for round tripping config post-merge, but never serialized. LocationOfOrigin string // ClientCertificate is the path to a client cert file for TLS. + // +optional ClientCertificate string `json:"client-certificate,omitempty"` // ClientCertificateData contains PEM-encoded data from a client cert file for TLS. Overrides ClientCertificate + // +optional ClientCertificateData []byte `json:"client-certificate-data,omitempty"` // ClientKey is the path to a client key file for TLS. + // +optional ClientKey string `json:"client-key,omitempty"` // ClientKeyData contains PEM-encoded data from a client key file for TLS. Overrides ClientKey + // +optional ClientKeyData []byte `json:"client-key-data,omitempty"` // Token is the bearer token for authentication to the kubernetes cluster. + // +optional Token string `json:"token,omitempty"` // TokenFile is a pointer to a file that contains a bearer token (as described above). If both Token and TokenFile are present, Token takes precedence. + // +optional TokenFile string `json:"tokenFile,omitempty"` // Impersonate is the username to act-as. + // +optional Impersonate string `json:"act-as,omitempty"` // Username is the username for basic authentication to the kubernetes cluster. + // +optional Username string `json:"username,omitempty"` // Password is the password for basic authentication to the kubernetes cluster. + // +optional Password string `json:"password,omitempty"` // AuthProvider specifies a custom authentication plugin for the kubernetes cluster. + // +optional AuthProvider *AuthProviderConfig `json:"auth-provider,omitempty"` // Extensions holds additional information. This is useful for extenders so that reads and writes don't clobber unknown fields + // +optional Extensions map[string]runtime.Object `json:"extensions,omitempty"` } @@ -111,14 +132,17 @@ type Context struct { // AuthInfo is the name of the authInfo for this context AuthInfo string `json:"user"` // Namespace is the default namespace to use on unspecified requests + // +optional Namespace string `json:"namespace,omitempty"` // Extensions holds additional information. This is useful for extenders so that reads and writes don't clobber unknown fields + // +optional Extensions map[string]runtime.Object `json:"extensions,omitempty"` } // AuthProviderConfig holds the configuration for a specified auth provider. type AuthProviderConfig struct { - Name string `json:"name"` + Name string `json:"name"` + // +optional Config map[string]string `json:"config,omitempty"` } diff --git a/vendor/k8s.io/kubernetes/pkg/client/metrics/metrics.go b/vendor/k8s.io/client-go/tools/metrics/metrics.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/client/metrics/metrics.go rename to vendor/k8s.io/client-go/tools/metrics/metrics.go diff --git a/vendor/k8s.io/kubernetes/pkg/client/transport/cache.go b/vendor/k8s.io/client-go/transport/cache.go similarity index 98% rename from vendor/k8s.io/kubernetes/pkg/client/transport/cache.go rename to vendor/k8s.io/client-go/transport/cache.go index eedfd3d..6e52d77 100644 --- a/vendor/k8s.io/kubernetes/pkg/client/transport/cache.go +++ b/vendor/k8s.io/client-go/transport/cache.go @@ -23,7 +23,7 @@ import ( "sync" "time" - utilnet "k8s.io/kubernetes/pkg/util/net" + utilnet "k8s.io/client-go/pkg/util/net" ) // TlsTransportCache caches TLS http.RoundTrippers different configurations. The diff --git a/vendor/k8s.io/kubernetes/pkg/client/transport/config.go b/vendor/k8s.io/client-go/transport/config.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/client/transport/config.go rename to vendor/k8s.io/client-go/transport/config.go diff --git a/vendor/k8s.io/kubernetes/pkg/client/transport/round_trippers.go b/vendor/k8s.io/client-go/transport/round_trippers.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/client/transport/round_trippers.go rename to vendor/k8s.io/client-go/transport/round_trippers.go diff --git a/vendor/k8s.io/kubernetes/pkg/client/transport/transport.go b/vendor/k8s.io/client-go/transport/transport.go similarity index 100% rename from vendor/k8s.io/kubernetes/pkg/client/transport/transport.go rename to vendor/k8s.io/client-go/transport/transport.go diff --git a/vendor/k8s.io/kubernetes/pkg/api/node_example.json b/vendor/k8s.io/kubernetes/pkg/api/node_example.json deleted file mode 100644 index ea249cb..0000000 --- a/vendor/k8s.io/kubernetes/pkg/api/node_example.json +++ /dev/null @@ -1,49 +0,0 @@ -{ - "kind": "Node", - "apiVersion": "v1", - "metadata": { - "name": "e2e-test-wojtekt-node-etd6", - "selfLink": "/api/v1/nodes/e2e-test-wojtekt-node-etd6", - "uid": "a7e89222-e8e5-11e4-8fde-42010af09327", - "resourceVersion": "379", - "creationTimestamp": "2015-04-22T11:49:39Z" - }, - "spec": { - "externalID": "15488322946290398375" - }, - "status": { - "capacity": { - "cpu": "1", - "memory": "1745152Ki" - }, - "conditions": [ - { - "type": "Ready", - "status": "True", - "lastHeartbeatTime": "2015-04-22T11:58:17Z", - "lastTransitionTime": "2015-04-22T11:49:52Z", - "reason": "kubelet is posting ready status" - } - ], - "addresses": [ - { - "type": "ExternalIP", - "address": "104.197.49.213" - }, - { - "type": "LegacyHostIP", - "address": "104.197.20.11" - } - ], - "nodeInfo": { - "machineID": "", - "systemUUID": "D59FA3FA-7B5B-7287-5E1A-1D79F13CB577", - "bootID": "44a832f3-8cfb-4de5-b7d2-d66030b6cd95", - "kernelVersion": "3.16.0-0.bpo.4-amd64", - "osImage": "Debian GNU/Linux 7 (wheezy)", - "containerRuntimeVersion": "docker://1.5.0", - "kubeletVersion": "v0.15.0-484-g0c8ee980d705a3-dirty", - "kubeProxyVersion": "v0.15.0-484-g0c8ee980d705a3-dirty" - } - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/api/replication_controller_example.json b/vendor/k8s.io/kubernetes/pkg/api/replication_controller_example.json deleted file mode 100644 index 70eef1c..0000000 --- a/vendor/k8s.io/kubernetes/pkg/api/replication_controller_example.json +++ /dev/null @@ -1,83 +0,0 @@ -{ - "kind": "ReplicationController", - "apiVersion": "v1", - "metadata": { - "name": "elasticsearch-logging-controller", - "namespace": "default", - "selfLink": "/api/v1/namespaces/default/replicationcontrollers/elasticsearch-logging-controller", - "uid": "aa76f162-e8e5-11e4-8fde-42010af09327", - "resourceVersion": "98", - "creationTimestamp": "2015-04-22T11:49:43Z", - "labels": { - "kubernetes.io/cluster-service": "true", - "name": "elasticsearch-logging" - } - }, - "spec": { - "replicas": 1, - "selector": { - "name": "elasticsearch-logging" - }, - "template": { - "metadata": { - "creationTimestamp": null, - "labels": { - "kubernetes.io/cluster-service": "true", - "name": "elasticsearch-logging" - } - }, - "spec": { - "volumes": [ - { - "name": "es-persistent-storage", - "hostPath": null, - "emptyDir": { - "medium": "" - }, - "gcePersistentDisk": null, - "awsElasticBlockStore": null, - "gitRepo": null, - "secret": null, - "nfs": null, - "iscsi": null, - "glusterfs": null, - "quobyte": null - } - ], - "containers": [ - { - "name": "elasticsearch-logging", - "image": "gcr.io/google_containers/elasticsearch:1.0", - "ports": [ - { - "name": "db", - "containerPort": 9200, - "protocol": "TCP" - }, - { - "name": "transport", - "containerPort": 9300, - "protocol": "TCP" - } - ], - "resources": {}, - "volumeMounts": [ - { - "name": "es-persistent-storage", - "mountPath": "/data" - } - ], - "terminationMessagePath": "/dev/termination-log", - "imagePullPolicy": "IfNotPresent", - "capabilities": {} - } - ], - "restartPolicy": "Always", - "dnsPolicy": "ClusterFirst" - } - } - }, - "status": { - "replicas": 1 - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.conversion.go deleted file mode 100644 index cd86c59..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/apps/v1alpha1/zz_generated.conversion.go +++ /dev/null @@ -1,209 +0,0 @@ -// +build !ignore_autogenerated - -/* -Copyright 2016 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. -*/ - -// This file was autogenerated by conversion-gen. Do not edit it manually! - -package v1alpha1 - -import ( - api "k8s.io/kubernetes/pkg/api" - v1 "k8s.io/kubernetes/pkg/api/v1" - apps "k8s.io/kubernetes/pkg/apis/apps" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" -) - -func init() { - SchemeBuilder.Register(RegisterConversions) -} - -// RegisterConversions adds conversion functions to the given scheme. -// Public to allow building arbitrary schemes. -func RegisterConversions(scheme *runtime.Scheme) error { - return scheme.AddGeneratedConversionFuncs( - Convert_v1alpha1_PetSet_To_apps_PetSet, - Convert_apps_PetSet_To_v1alpha1_PetSet, - Convert_v1alpha1_PetSetList_To_apps_PetSetList, - Convert_apps_PetSetList_To_v1alpha1_PetSetList, - Convert_v1alpha1_PetSetSpec_To_apps_PetSetSpec, - Convert_apps_PetSetSpec_To_v1alpha1_PetSetSpec, - Convert_v1alpha1_PetSetStatus_To_apps_PetSetStatus, - Convert_apps_PetSetStatus_To_v1alpha1_PetSetStatus, - ) -} - -func autoConvert_v1alpha1_PetSet_To_apps_PetSet(in *PetSet, out *apps.PetSet, s conversion.Scope) error { - SetDefaults_PetSet(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - // TODO: Inefficient conversion - can we improve it? - if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { - return err - } - if err := Convert_v1alpha1_PetSetSpec_To_apps_PetSetSpec(&in.Spec, &out.Spec, s); err != nil { - return err - } - if err := Convert_v1alpha1_PetSetStatus_To_apps_PetSetStatus(&in.Status, &out.Status, s); err != nil { - return err - } - return nil -} - -func Convert_v1alpha1_PetSet_To_apps_PetSet(in *PetSet, out *apps.PetSet, s conversion.Scope) error { - return autoConvert_v1alpha1_PetSet_To_apps_PetSet(in, out, s) -} - -func autoConvert_apps_PetSet_To_v1alpha1_PetSet(in *apps.PetSet, out *PetSet, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - // TODO: Inefficient conversion - can we improve it? - if err := s.Convert(&in.ObjectMeta, &out.ObjectMeta, 0); err != nil { - return err - } - if err := Convert_apps_PetSetSpec_To_v1alpha1_PetSetSpec(&in.Spec, &out.Spec, s); err != nil { - return err - } - if err := Convert_apps_PetSetStatus_To_v1alpha1_PetSetStatus(&in.Status, &out.Status, s); err != nil { - return err - } - return nil -} - -func Convert_apps_PetSet_To_v1alpha1_PetSet(in *apps.PetSet, out *PetSet, s conversion.Scope) error { - return autoConvert_apps_PetSet_To_v1alpha1_PetSet(in, out, s) -} - -func autoConvert_v1alpha1_PetSetList_To_apps_PetSetList(in *PetSetList, out *apps.PetSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } - if in.Items != nil { - in, out := &in.Items, &out.Items - *out = make([]apps.PetSet, len(*in)) - for i := range *in { - if err := Convert_v1alpha1_PetSet_To_apps_PetSet(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.Items = nil - } - return nil -} - -func Convert_v1alpha1_PetSetList_To_apps_PetSetList(in *PetSetList, out *apps.PetSetList, s conversion.Scope) error { - return autoConvert_v1alpha1_PetSetList_To_apps_PetSetList(in, out, s) -} - -func autoConvert_apps_PetSetList_To_v1alpha1_PetSetList(in *apps.PetSetList, out *PetSetList, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - if err := api.Convert_unversioned_ListMeta_To_unversioned_ListMeta(&in.ListMeta, &out.ListMeta, s); err != nil { - return err - } - if in.Items != nil { - in, out := &in.Items, &out.Items - *out = make([]PetSet, len(*in)) - for i := range *in { - if err := Convert_apps_PetSet_To_v1alpha1_PetSet(&(*in)[i], &(*out)[i], s); err != nil { - return err - } - } - } else { - out.Items = nil - } - return nil -} - -func Convert_apps_PetSetList_To_v1alpha1_PetSetList(in *apps.PetSetList, out *PetSetList, s conversion.Scope) error { - return autoConvert_apps_PetSetList_To_v1alpha1_PetSetList(in, out, s) -} - -func autoConvert_v1alpha1_PetSetSpec_To_apps_PetSetSpec(in *PetSetSpec, out *apps.PetSetSpec, s conversion.Scope) error { - if err := api.Convert_Pointer_int32_To_int32(&in.Replicas, &out.Replicas, s); err != nil { - return err - } - out.Selector = in.Selector - if err := v1.Convert_v1_PodTemplateSpec_To_api_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { - return err - } - if in.VolumeClaimTemplates != nil { - in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates - *out = make([]api.PersistentVolumeClaim, len(*in)) - for i := range *in { - // TODO: Inefficient conversion - can we improve it? - if err := s.Convert(&(*in)[i], &(*out)[i], 0); err != nil { - return err - } - } - } else { - out.VolumeClaimTemplates = nil - } - out.ServiceName = in.ServiceName - return nil -} - -func autoConvert_apps_PetSetSpec_To_v1alpha1_PetSetSpec(in *apps.PetSetSpec, out *PetSetSpec, s conversion.Scope) error { - if err := api.Convert_int32_To_Pointer_int32(&in.Replicas, &out.Replicas, s); err != nil { - return err - } - out.Selector = in.Selector - if err := v1.Convert_api_PodTemplateSpec_To_v1_PodTemplateSpec(&in.Template, &out.Template, s); err != nil { - return err - } - if in.VolumeClaimTemplates != nil { - in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates - *out = make([]v1.PersistentVolumeClaim, len(*in)) - for i := range *in { - // TODO: Inefficient conversion - can we improve it? - if err := s.Convert(&(*in)[i], &(*out)[i], 0); err != nil { - return err - } - } - } else { - out.VolumeClaimTemplates = nil - } - out.ServiceName = in.ServiceName - return nil -} - -func autoConvert_v1alpha1_PetSetStatus_To_apps_PetSetStatus(in *PetSetStatus, out *apps.PetSetStatus, s conversion.Scope) error { - out.ObservedGeneration = in.ObservedGeneration - out.Replicas = in.Replicas - return nil -} - -func Convert_v1alpha1_PetSetStatus_To_apps_PetSetStatus(in *PetSetStatus, out *apps.PetSetStatus, s conversion.Scope) error { - return autoConvert_v1alpha1_PetSetStatus_To_apps_PetSetStatus(in, out, s) -} - -func autoConvert_apps_PetSetStatus_To_v1alpha1_PetSetStatus(in *apps.PetSetStatus, out *PetSetStatus, s conversion.Scope) error { - out.ObservedGeneration = in.ObservedGeneration - out.Replicas = in.Replicas - return nil -} - -func Convert_apps_PetSetStatus_To_v1alpha1_PetSetStatus(in *apps.PetSetStatus, out *PetSetStatus, s conversion.Scope) error { - return autoConvert_apps_PetSetStatus_To_v1alpha1_PetSetStatus(in, out, s) -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/helpers.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/helpers.go deleted file mode 100644 index 43b625b..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/helpers.go +++ /dev/null @@ -1,97 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package componentconfig - -import ( - "fmt" - "net" - - utilnet "k8s.io/kubernetes/pkg/util/net" -) - -// used for validating command line opts -// TODO(mikedanese): remove these when we remove command line flags - -type IPVar struct { - Val *string -} - -func (v IPVar) Set(s string) error { - if net.ParseIP(s) == nil { - return fmt.Errorf("%q is not a valid IP address", s) - } - if v.Val == nil { - // it's okay to panic here since this is programmer error - panic("the string pointer passed into IPVar should not be nil") - } - *v.Val = s - return nil -} - -func (v IPVar) String() string { - if v.Val == nil { - return "" - } - return *v.Val -} - -func (v IPVar) Type() string { - return "ip" -} - -func (m *ProxyMode) Set(s string) error { - *m = ProxyMode(s) - return nil -} - -func (m *ProxyMode) String() string { - if m != nil { - return string(*m) - } - return "" -} - -func (m *ProxyMode) Type() string { - return "ProxyMode" -} - -type PortRangeVar struct { - Val *string -} - -func (v PortRangeVar) Set(s string) error { - if _, err := utilnet.ParsePortRange(s); err != nil { - return fmt.Errorf("%q is not a valid port range: %v", s, err) - } - if v.Val == nil { - // it's okay to panic here since this is programmer error - panic("the string pointer passed into PortRangeVar should not be nil") - } - *v.Val = s - return nil -} - -func (v PortRangeVar) String() string { - if v.Val == nil { - return "" - } - return *v.Val -} - -func (v PortRangeVar) Type() string { - return "port-range" -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/install/install.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/install/install.go deleted file mode 100644 index 9bd1941..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/install/install.go +++ /dev/null @@ -1,41 +0,0 @@ -/* -Copyright 2015 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. -*/ - -// Package install installs the experimental API group, making it available as -// an option to all of the API encoding/decoding machinery. -package install - -import ( - "k8s.io/kubernetes/pkg/apimachinery/announced" - "k8s.io/kubernetes/pkg/apis/componentconfig" - "k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1" -) - -func init() { - if err := announced.NewGroupMetaFactory( - &announced.GroupMetaFactoryArgs{ - GroupName: componentconfig.GroupName, - VersionPreferenceOrder: []string{v1alpha1.SchemeGroupVersion.Version}, - ImportPrefix: "k8s.io/kubernetes/pkg/apis/componentconfig", - AddInternalObjectsToScheme: componentconfig.AddToScheme, - }, - announced.VersionToSchemeFunc{ - v1alpha1.SchemeGroupVersion.Version: v1alpha1.AddToScheme, - }, - ).Announce().RegisterAndEnable(); err != nil { - panic(err) - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/register.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/register.go deleted file mode 100644 index 77dc749..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/register.go +++ /dev/null @@ -1,57 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package componentconfig - -import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" -) - -var ( - SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) - AddToScheme = SchemeBuilder.AddToScheme -) - -// GroupName is the group name use in this package -const GroupName = "componentconfig" - -// SchemeGroupVersion is group version used to register these objects -var SchemeGroupVersion = unversioned.GroupVersion{Group: GroupName, Version: runtime.APIVersionInternal} - -// Kind takes an unqualified kind and returns a Group qualified GroupKind -func Kind(kind string) unversioned.GroupKind { - return SchemeGroupVersion.WithKind(kind).GroupKind() -} - -// Resource takes an unqualified resource and returns a Group qualified GroupResource -func Resource(resource string) unversioned.GroupResource { - return SchemeGroupVersion.WithResource(resource).GroupResource() -} - -func addKnownTypes(scheme *runtime.Scheme) error { - // TODO this will get cleaned up with the scheme types are fixed - scheme.AddKnownTypes(SchemeGroupVersion, - &KubeProxyConfiguration{}, - &KubeSchedulerConfiguration{}, - &KubeletConfiguration{}, - ) - return nil -} - -func (obj *KubeProxyConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } -func (obj *KubeSchedulerConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } -func (obj *KubeletConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.generated.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.generated.go deleted file mode 100644 index f08bcbf..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.generated.go +++ /dev/null @@ -1,11189 +0,0 @@ -/* -Copyright 2016 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. -*/ - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED BY codecgen. -// ************************************************************ - -package componentconfig - -import ( - "errors" - "fmt" - codec1978 "github.com/ugorji/go/codec" - pkg1_unversioned "k8s.io/kubernetes/pkg/api/unversioned" - pkg2_config "k8s.io/kubernetes/pkg/util/config" - "reflect" - "runtime" - time "time" -) - -const ( - // ----- content types ---- - codecSelferC_UTF81234 = 1 - codecSelferC_RAW1234 = 0 - // ----- value types used ---- - codecSelferValueTypeArray1234 = 10 - codecSelferValueTypeMap1234 = 9 - // ----- containerStateValues ---- - codecSelfer_containerMapKey1234 = 2 - codecSelfer_containerMapValue1234 = 3 - codecSelfer_containerMapEnd1234 = 4 - codecSelfer_containerArrayElem1234 = 6 - codecSelfer_containerArrayEnd1234 = 7 -) - -var ( - codecSelferBitsize1234 = uint8(reflect.TypeOf(uint(0)).Bits()) - codecSelferOnlyMapOrArrayEncodeToStructErr1234 = errors.New(`only encoded map or array can be decoded into a struct`) -) - -type codecSelfer1234 struct{} - -func init() { - if codec1978.GenVersion != 5 { - _, file, _, _ := runtime.Caller(0) - err := fmt.Errorf("codecgen version mismatch: current: %v, need %v. Re-generate file: %v", - 5, codec1978.GenVersion, file) - panic(err) - } - if false { // reference the types, but skip this branch at build/run time - var v0 pkg1_unversioned.TypeMeta - var v1 pkg2_config.ConfigurationMap - var v2 time.Duration - _, _, _ = v0, v1, v2 - } -} - -func (x *KubeProxyConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1 := z.EncBinary() - _ = yym1 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep2 := !z.EncBinary() - yy2arr2 := z.EncBasicHandle().StructToArray - var yyq2 [21]bool - _, _, _ = yysep2, yyq2, yy2arr2 - const yyr2 bool = false - yyq2[0] = x.Kind != "" - yyq2[1] = x.APIVersion != "" - var yynn2 int - if yyr2 || yy2arr2 { - r.EncodeArrayStart(21) - } else { - yynn2 = 19 - for _, b := range yyq2 { - if b { - yynn2++ - } - } - r.EncodeMapStart(yynn2) - yynn2 = 0 - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2[0] { - yym4 := z.EncBinary() - _ = yym4 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq2[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym5 := z.EncBinary() - _ = yym5 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq2[1] { - yym7 := z.EncBinary() - _ = yym7 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq2[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym8 := z.EncBinary() - _ = yym8 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym10 := z.EncBinary() - _ = yym10 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.BindAddress)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("bindAddress")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym11 := z.EncBinary() - _ = yym11 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.BindAddress)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym13 := z.EncBinary() - _ = yym13 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym14 := z.EncBinary() - _ = yym14 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterCIDR)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym16 := z.EncBinary() - _ = yym16 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HealthzBindAddress)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("healthzBindAddress")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym17 := z.EncBinary() - _ = yym17 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HealthzBindAddress)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym19 := z.EncBinary() - _ = yym19 - if false { - } else { - r.EncodeInt(int64(x.HealthzPort)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("healthzPort")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym20 := z.EncBinary() - _ = yym20 - if false { - } else { - r.EncodeInt(int64(x.HealthzPort)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym22 := z.EncBinary() - _ = yym22 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HostnameOverride)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hostnameOverride")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym23 := z.EncBinary() - _ = yym23 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HostnameOverride)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.IPTablesMasqueradeBit == nil { - r.EncodeNil() - } else { - yy25 := *x.IPTablesMasqueradeBit - yym26 := z.EncBinary() - _ = yym26 - if false { - } else { - r.EncodeInt(int64(yy25)) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("iptablesMasqueradeBit")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.IPTablesMasqueradeBit == nil { - r.EncodeNil() - } else { - yy27 := *x.IPTablesMasqueradeBit - yym28 := z.EncBinary() - _ = yym28 - if false { - } else { - r.EncodeInt(int64(yy27)) - } - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy30 := &x.IPTablesSyncPeriod - yym31 := z.EncBinary() - _ = yym31 - if false { - } else if z.HasExtensions() && z.EncExt(yy30) { - } else if !yym31 && z.IsJSONHandle() { - z.EncJSONMarshal(yy30) - } else { - z.EncFallback(yy30) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("iptablesSyncPeriodSeconds")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy32 := &x.IPTablesSyncPeriod - yym33 := z.EncBinary() - _ = yym33 - if false { - } else if z.HasExtensions() && z.EncExt(yy32) { - } else if !yym33 && z.IsJSONHandle() { - z.EncJSONMarshal(yy32) - } else { - z.EncFallback(yy32) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym35 := z.EncBinary() - _ = yym35 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.KubeconfigPath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeconfigPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym36 := z.EncBinary() - _ = yym36 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.KubeconfigPath)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym38 := z.EncBinary() - _ = yym38 - if false { - } else { - r.EncodeBool(bool(x.MasqueradeAll)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("masqueradeAll")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym39 := z.EncBinary() - _ = yym39 - if false { - } else { - r.EncodeBool(bool(x.MasqueradeAll)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym41 := z.EncBinary() - _ = yym41 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Master)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("master")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym42 := z.EncBinary() - _ = yym42 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Master)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.OOMScoreAdj == nil { - r.EncodeNil() - } else { - yy44 := *x.OOMScoreAdj - yym45 := z.EncBinary() - _ = yym45 - if false { - } else { - r.EncodeInt(int64(yy44)) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("oomScoreAdj")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.OOMScoreAdj == nil { - r.EncodeNil() - } else { - yy46 := *x.OOMScoreAdj - yym47 := z.EncBinary() - _ = yym47 - if false { - } else { - r.EncodeInt(int64(yy46)) - } - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - x.Mode.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("mode")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - x.Mode.CodecEncodeSelf(e) - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym50 := z.EncBinary() - _ = yym50 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PortRange)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("portRange")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym51 := z.EncBinary() - _ = yym51 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PortRange)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym53 := z.EncBinary() - _ = yym53 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceContainer)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("resourceContainer")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym54 := z.EncBinary() - _ = yym54 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResourceContainer)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy56 := &x.UDPIdleTimeout - yym57 := z.EncBinary() - _ = yym57 - if false { - } else if z.HasExtensions() && z.EncExt(yy56) { - } else if !yym57 && z.IsJSONHandle() { - z.EncJSONMarshal(yy56) - } else { - z.EncFallback(yy56) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("udpTimeoutMilliseconds")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy58 := &x.UDPIdleTimeout - yym59 := z.EncBinary() - _ = yym59 - if false { - } else if z.HasExtensions() && z.EncExt(yy58) { - } else if !yym59 && z.IsJSONHandle() { - z.EncJSONMarshal(yy58) - } else { - z.EncFallback(yy58) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym61 := z.EncBinary() - _ = yym61 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMax)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("conntrackMax")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym62 := z.EncBinary() - _ = yym62 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMax)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym64 := z.EncBinary() - _ = yym64 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMaxPerCore)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("conntrackMaxPerCore")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym65 := z.EncBinary() - _ = yym65 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMaxPerCore)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym67 := z.EncBinary() - _ = yym67 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMin)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("conntrackMin")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym68 := z.EncBinary() - _ = yym68 - if false { - } else { - r.EncodeInt(int64(x.ConntrackMin)) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy70 := &x.ConntrackTCPEstablishedTimeout - yym71 := z.EncBinary() - _ = yym71 - if false { - } else if z.HasExtensions() && z.EncExt(yy70) { - } else if !yym71 && z.IsJSONHandle() { - z.EncJSONMarshal(yy70) - } else { - z.EncFallback(yy70) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("conntrackTCPEstablishedTimeout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy72 := &x.ConntrackTCPEstablishedTimeout - yym73 := z.EncBinary() - _ = yym73 - if false { - } else if z.HasExtensions() && z.EncExt(yy72) { - } else if !yym73 && z.IsJSONHandle() { - z.EncJSONMarshal(yy72) - } else { - z.EncFallback(yy72) - } - } - if yyr2 || yy2arr2 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *KubeProxyConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym74 := z.DecBinary() - _ = yym74 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct75 := r.ContainerType() - if yyct75 == codecSelferValueTypeMap1234 { - yyl75 := r.ReadMapStart() - if yyl75 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl75, d) - } - } else if yyct75 == codecSelferValueTypeArray1234 { - yyl75 := r.ReadArrayStart() - if yyl75 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl75, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *KubeProxyConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys76Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys76Slc - var yyhl76 bool = l >= 0 - for yyj76 := 0; ; yyj76++ { - if yyhl76 { - if yyj76 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys76Slc = r.DecodeBytes(yys76Slc, true, true) - yys76 := string(yys76Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys76 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "bindAddress": - if r.TryDecodeAsNil() { - x.BindAddress = "" - } else { - x.BindAddress = string(r.DecodeString()) - } - case "clusterCIDR": - if r.TryDecodeAsNil() { - x.ClusterCIDR = "" - } else { - x.ClusterCIDR = string(r.DecodeString()) - } - case "healthzBindAddress": - if r.TryDecodeAsNil() { - x.HealthzBindAddress = "" - } else { - x.HealthzBindAddress = string(r.DecodeString()) - } - case "healthzPort": - if r.TryDecodeAsNil() { - x.HealthzPort = 0 - } else { - x.HealthzPort = int32(r.DecodeInt(32)) - } - case "hostnameOverride": - if r.TryDecodeAsNil() { - x.HostnameOverride = "" - } else { - x.HostnameOverride = string(r.DecodeString()) - } - case "iptablesMasqueradeBit": - if r.TryDecodeAsNil() { - if x.IPTablesMasqueradeBit != nil { - x.IPTablesMasqueradeBit = nil - } - } else { - if x.IPTablesMasqueradeBit == nil { - x.IPTablesMasqueradeBit = new(int32) - } - yym85 := z.DecBinary() - _ = yym85 - if false { - } else { - *((*int32)(x.IPTablesMasqueradeBit)) = int32(r.DecodeInt(32)) - } - } - case "iptablesSyncPeriodSeconds": - if r.TryDecodeAsNil() { - x.IPTablesSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv86 := &x.IPTablesSyncPeriod - yym87 := z.DecBinary() - _ = yym87 - if false { - } else if z.HasExtensions() && z.DecExt(yyv86) { - } else if !yym87 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv86) - } else { - z.DecFallback(yyv86, false) - } - } - case "kubeconfigPath": - if r.TryDecodeAsNil() { - x.KubeconfigPath = "" - } else { - x.KubeconfigPath = string(r.DecodeString()) - } - case "masqueradeAll": - if r.TryDecodeAsNil() { - x.MasqueradeAll = false - } else { - x.MasqueradeAll = bool(r.DecodeBool()) - } - case "master": - if r.TryDecodeAsNil() { - x.Master = "" - } else { - x.Master = string(r.DecodeString()) - } - case "oomScoreAdj": - if r.TryDecodeAsNil() { - if x.OOMScoreAdj != nil { - x.OOMScoreAdj = nil - } - } else { - if x.OOMScoreAdj == nil { - x.OOMScoreAdj = new(int32) - } - yym92 := z.DecBinary() - _ = yym92 - if false { - } else { - *((*int32)(x.OOMScoreAdj)) = int32(r.DecodeInt(32)) - } - } - case "mode": - if r.TryDecodeAsNil() { - x.Mode = "" - } else { - x.Mode = ProxyMode(r.DecodeString()) - } - case "portRange": - if r.TryDecodeAsNil() { - x.PortRange = "" - } else { - x.PortRange = string(r.DecodeString()) - } - case "resourceContainer": - if r.TryDecodeAsNil() { - x.ResourceContainer = "" - } else { - x.ResourceContainer = string(r.DecodeString()) - } - case "udpTimeoutMilliseconds": - if r.TryDecodeAsNil() { - x.UDPIdleTimeout = pkg1_unversioned.Duration{} - } else { - yyv96 := &x.UDPIdleTimeout - yym97 := z.DecBinary() - _ = yym97 - if false { - } else if z.HasExtensions() && z.DecExt(yyv96) { - } else if !yym97 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv96) - } else { - z.DecFallback(yyv96, false) - } - } - case "conntrackMax": - if r.TryDecodeAsNil() { - x.ConntrackMax = 0 - } else { - x.ConntrackMax = int32(r.DecodeInt(32)) - } - case "conntrackMaxPerCore": - if r.TryDecodeAsNil() { - x.ConntrackMaxPerCore = 0 - } else { - x.ConntrackMaxPerCore = int32(r.DecodeInt(32)) - } - case "conntrackMin": - if r.TryDecodeAsNil() { - x.ConntrackMin = 0 - } else { - x.ConntrackMin = int32(r.DecodeInt(32)) - } - case "conntrackTCPEstablishedTimeout": - if r.TryDecodeAsNil() { - x.ConntrackTCPEstablishedTimeout = pkg1_unversioned.Duration{} - } else { - yyv101 := &x.ConntrackTCPEstablishedTimeout - yym102 := z.DecBinary() - _ = yym102 - if false { - } else if z.HasExtensions() && z.DecExt(yyv101) { - } else if !yym102 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv101) - } else { - z.DecFallback(yyv101, false) - } - } - default: - z.DecStructFieldNotFound(-1, yys76) - } // end switch yys76 - } // end for yyj76 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *KubeProxyConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj103 int - var yyb103 bool - var yyhl103 bool = l >= 0 - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.BindAddress = "" - } else { - x.BindAddress = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterCIDR = "" - } else { - x.ClusterCIDR = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HealthzBindAddress = "" - } else { - x.HealthzBindAddress = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HealthzPort = 0 - } else { - x.HealthzPort = int32(r.DecodeInt(32)) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HostnameOverride = "" - } else { - x.HostnameOverride = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.IPTablesMasqueradeBit != nil { - x.IPTablesMasqueradeBit = nil - } - } else { - if x.IPTablesMasqueradeBit == nil { - x.IPTablesMasqueradeBit = new(int32) - } - yym112 := z.DecBinary() - _ = yym112 - if false { - } else { - *((*int32)(x.IPTablesMasqueradeBit)) = int32(r.DecodeInt(32)) - } - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.IPTablesSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv113 := &x.IPTablesSyncPeriod - yym114 := z.DecBinary() - _ = yym114 - if false { - } else if z.HasExtensions() && z.DecExt(yyv113) { - } else if !yym114 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv113) - } else { - z.DecFallback(yyv113, false) - } - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeconfigPath = "" - } else { - x.KubeconfigPath = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MasqueradeAll = false - } else { - x.MasqueradeAll = bool(r.DecodeBool()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Master = "" - } else { - x.Master = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - if x.OOMScoreAdj != nil { - x.OOMScoreAdj = nil - } - } else { - if x.OOMScoreAdj == nil { - x.OOMScoreAdj = new(int32) - } - yym119 := z.DecBinary() - _ = yym119 - if false { - } else { - *((*int32)(x.OOMScoreAdj)) = int32(r.DecodeInt(32)) - } - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Mode = "" - } else { - x.Mode = ProxyMode(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PortRange = "" - } else { - x.PortRange = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ResourceContainer = "" - } else { - x.ResourceContainer = string(r.DecodeString()) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.UDPIdleTimeout = pkg1_unversioned.Duration{} - } else { - yyv123 := &x.UDPIdleTimeout - yym124 := z.DecBinary() - _ = yym124 - if false { - } else if z.HasExtensions() && z.DecExt(yyv123) { - } else if !yym124 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv123) - } else { - z.DecFallback(yyv123, false) - } - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConntrackMax = 0 - } else { - x.ConntrackMax = int32(r.DecodeInt(32)) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConntrackMaxPerCore = 0 - } else { - x.ConntrackMaxPerCore = int32(r.DecodeInt(32)) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConntrackMin = 0 - } else { - x.ConntrackMin = int32(r.DecodeInt(32)) - } - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConntrackTCPEstablishedTimeout = pkg1_unversioned.Duration{} - } else { - yyv128 := &x.ConntrackTCPEstablishedTimeout - yym129 := z.DecBinary() - _ = yym129 - if false { - } else if z.HasExtensions() && z.DecExt(yyv128) { - } else if !yym129 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv128) - } else { - z.DecFallback(yyv128, false) - } - } - for { - yyj103++ - if yyhl103 { - yyb103 = yyj103 > l - } else { - yyb103 = r.CheckBreak() - } - if yyb103 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj103-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x ProxyMode) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym130 := z.EncBinary() - _ = yym130 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *ProxyMode) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym131 := z.DecBinary() - _ = yym131 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - -func (x HairpinMode) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - yym132 := z.EncBinary() - _ = yym132 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x)) - } -} - -func (x *HairpinMode) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym133 := z.DecBinary() - _ = yym133 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - *((*string)(x)) = r.DecodeString() - } -} - -func (x *KubeletConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym134 := z.EncBinary() - _ = yym134 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep135 := !z.EncBinary() - yy2arr135 := z.EncBasicHandle().StructToArray - var yyq135 [108]bool - _, _, _ = yysep135, yyq135, yy2arr135 - const yyr135 bool = false - yyq135[0] = x.Kind != "" - yyq135[1] = x.APIVersion != "" - yyq135[53] = x.CloudProvider != "" - yyq135[54] = x.CloudConfigFile != "" - yyq135[55] = x.KubeletCgroups != "" - yyq135[56] = x.CgroupsPerQOS != false - yyq135[57] = x.CgroupDriver != "" - yyq135[58] = x.RuntimeCgroups != "" - yyq135[59] = x.SystemCgroups != "" - yyq135[60] = x.CgroupRoot != "" - yyq135[64] = true - yyq135[65] = x.RktPath != "" - yyq135[66] = x.RktAPIEndpoint != "" - yyq135[67] = x.RktStage1Image != "" - yyq135[87] = true - yyq135[88] = x.NodeIP != "" - yyq135[92] = x.EvictionHard != "" - yyq135[93] = x.EvictionSoft != "" - yyq135[94] = x.EvictionSoftGracePeriod != "" - yyq135[95] = true - yyq135[96] = x.EvictionMaxPodGracePeriod != 0 - yyq135[97] = x.EvictionMinimumReclaim != "" - yyq135[106] = len(x.AllowedUnsafeSysctls) != 0 - yyq135[107] = x.ExperimentalRuntimeIntegrationType != "" - var yynn135 int - if yyr135 || yy2arr135 { - r.EncodeArrayStart(108) - } else { - yynn135 = 84 - for _, b := range yyq135 { - if b { - yynn135++ - } - } - r.EncodeMapStart(yynn135) - yynn135 = 0 - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[0] { - yym137 := z.EncBinary() - _ = yym137 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym138 := z.EncBinary() - _ = yym138 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[1] { - yym140 := z.EncBinary() - _ = yym140 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym141 := z.EncBinary() - _ = yym141 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym143 := z.EncBinary() - _ = yym143 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodManifestPath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podManifestPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym144 := z.EncBinary() - _ = yym144 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodManifestPath)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy146 := &x.SyncFrequency - yym147 := z.EncBinary() - _ = yym147 - if false { - } else if z.HasExtensions() && z.EncExt(yy146) { - } else if !yym147 && z.IsJSONHandle() { - z.EncJSONMarshal(yy146) - } else { - z.EncFallback(yy146) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("syncFrequency")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy148 := &x.SyncFrequency - yym149 := z.EncBinary() - _ = yym149 - if false { - } else if z.HasExtensions() && z.EncExt(yy148) { - } else if !yym149 && z.IsJSONHandle() { - z.EncJSONMarshal(yy148) - } else { - z.EncFallback(yy148) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy151 := &x.FileCheckFrequency - yym152 := z.EncBinary() - _ = yym152 - if false { - } else if z.HasExtensions() && z.EncExt(yy151) { - } else if !yym152 && z.IsJSONHandle() { - z.EncJSONMarshal(yy151) - } else { - z.EncFallback(yy151) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("fileCheckFrequency")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy153 := &x.FileCheckFrequency - yym154 := z.EncBinary() - _ = yym154 - if false { - } else if z.HasExtensions() && z.EncExt(yy153) { - } else if !yym154 && z.IsJSONHandle() { - z.EncJSONMarshal(yy153) - } else { - z.EncFallback(yy153) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy156 := &x.HTTPCheckFrequency - yym157 := z.EncBinary() - _ = yym157 - if false { - } else if z.HasExtensions() && z.EncExt(yy156) { - } else if !yym157 && z.IsJSONHandle() { - z.EncJSONMarshal(yy156) - } else { - z.EncFallback(yy156) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("httpCheckFrequency")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy158 := &x.HTTPCheckFrequency - yym159 := z.EncBinary() - _ = yym159 - if false { - } else if z.HasExtensions() && z.EncExt(yy158) { - } else if !yym159 && z.IsJSONHandle() { - z.EncJSONMarshal(yy158) - } else { - z.EncFallback(yy158) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym161 := z.EncBinary() - _ = yym161 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ManifestURL)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("manifestURL")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym162 := z.EncBinary() - _ = yym162 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ManifestURL)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym164 := z.EncBinary() - _ = yym164 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ManifestURLHeader)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("manifestURLHeader")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym165 := z.EncBinary() - _ = yym165 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ManifestURLHeader)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym167 := z.EncBinary() - _ = yym167 - if false { - } else { - r.EncodeBool(bool(x.EnableServer)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableServer")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym168 := z.EncBinary() - _ = yym168 - if false { - } else { - r.EncodeBool(bool(x.EnableServer)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym170 := z.EncBinary() - _ = yym170 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("address")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym171 := z.EncBinary() - _ = yym171 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym173 := z.EncBinary() - _ = yym173 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("port")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym174 := z.EncBinary() - _ = yym174 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym176 := z.EncBinary() - _ = yym176 - if false { - } else { - r.EncodeInt(int64(x.ReadOnlyPort)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("readOnlyPort")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym177 := z.EncBinary() - _ = yym177 - if false { - } else { - r.EncodeInt(int64(x.ReadOnlyPort)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym179 := z.EncBinary() - _ = yym179 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.TLSCertFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("tlsCertFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym180 := z.EncBinary() - _ = yym180 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.TLSCertFile)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym182 := z.EncBinary() - _ = yym182 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.TLSPrivateKeyFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("tlsPrivateKeyFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym183 := z.EncBinary() - _ = yym183 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.TLSPrivateKeyFile)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym185 := z.EncBinary() - _ = yym185 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CertDirectory)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("certDirectory")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym186 := z.EncBinary() - _ = yym186 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CertDirectory)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym188 := z.EncBinary() - _ = yym188 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HostnameOverride)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hostnameOverride")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym189 := z.EncBinary() - _ = yym189 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HostnameOverride)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym191 := z.EncBinary() - _ = yym191 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodInfraContainerImage)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podInfraContainerImage")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym192 := z.EncBinary() - _ = yym192 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodInfraContainerImage)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym194 := z.EncBinary() - _ = yym194 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.DockerEndpoint)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("dockerEndpoint")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym195 := z.EncBinary() - _ = yym195 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.DockerEndpoint)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym197 := z.EncBinary() - _ = yym197 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RootDirectory)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rootDirectory")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym198 := z.EncBinary() - _ = yym198 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RootDirectory)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym200 := z.EncBinary() - _ = yym200 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SeccompProfileRoot)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("seccompProfileRoot")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym201 := z.EncBinary() - _ = yym201 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SeccompProfileRoot)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym203 := z.EncBinary() - _ = yym203 - if false { - } else { - r.EncodeBool(bool(x.AllowPrivileged)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("allowPrivileged")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym204 := z.EncBinary() - _ = yym204 - if false { - } else { - r.EncodeBool(bool(x.AllowPrivileged)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.HostNetworkSources == nil { - r.EncodeNil() - } else { - yym206 := z.EncBinary() - _ = yym206 - if false { - } else { - z.F.EncSliceStringV(x.HostNetworkSources, false, e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hostNetworkSources")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.HostNetworkSources == nil { - r.EncodeNil() - } else { - yym207 := z.EncBinary() - _ = yym207 - if false { - } else { - z.F.EncSliceStringV(x.HostNetworkSources, false, e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.HostPIDSources == nil { - r.EncodeNil() - } else { - yym209 := z.EncBinary() - _ = yym209 - if false { - } else { - z.F.EncSliceStringV(x.HostPIDSources, false, e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hostPIDSources")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.HostPIDSources == nil { - r.EncodeNil() - } else { - yym210 := z.EncBinary() - _ = yym210 - if false { - } else { - z.F.EncSliceStringV(x.HostPIDSources, false, e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.HostIPCSources == nil { - r.EncodeNil() - } else { - yym212 := z.EncBinary() - _ = yym212 - if false { - } else { - z.F.EncSliceStringV(x.HostIPCSources, false, e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hostIPCSources")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.HostIPCSources == nil { - r.EncodeNil() - } else { - yym213 := z.EncBinary() - _ = yym213 - if false { - } else { - z.F.EncSliceStringV(x.HostIPCSources, false, e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym215 := z.EncBinary() - _ = yym215 - if false { - } else { - r.EncodeInt(int64(x.RegistryPullQPS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("registryPullQPS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym216 := z.EncBinary() - _ = yym216 - if false { - } else { - r.EncodeInt(int64(x.RegistryPullQPS)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym218 := z.EncBinary() - _ = yym218 - if false { - } else { - r.EncodeInt(int64(x.RegistryBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("registryBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym219 := z.EncBinary() - _ = yym219 - if false { - } else { - r.EncodeInt(int64(x.RegistryBurst)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym221 := z.EncBinary() - _ = yym221 - if false { - } else { - r.EncodeInt(int64(x.EventRecordQPS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("eventRecordQPS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym222 := z.EncBinary() - _ = yym222 - if false { - } else { - r.EncodeInt(int64(x.EventRecordQPS)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym224 := z.EncBinary() - _ = yym224 - if false { - } else { - r.EncodeInt(int64(x.EventBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("eventBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym225 := z.EncBinary() - _ = yym225 - if false { - } else { - r.EncodeInt(int64(x.EventBurst)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym227 := z.EncBinary() - _ = yym227 - if false { - } else { - r.EncodeBool(bool(x.EnableDebuggingHandlers)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableDebuggingHandlers")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym228 := z.EncBinary() - _ = yym228 - if false { - } else { - r.EncodeBool(bool(x.EnableDebuggingHandlers)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy230 := &x.MinimumGCAge - yym231 := z.EncBinary() - _ = yym231 - if false { - } else if z.HasExtensions() && z.EncExt(yy230) { - } else if !yym231 && z.IsJSONHandle() { - z.EncJSONMarshal(yy230) - } else { - z.EncFallback(yy230) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minimumGCAge")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy232 := &x.MinimumGCAge - yym233 := z.EncBinary() - _ = yym233 - if false { - } else if z.HasExtensions() && z.EncExt(yy232) { - } else if !yym233 && z.IsJSONHandle() { - z.EncJSONMarshal(yy232) - } else { - z.EncFallback(yy232) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym235 := z.EncBinary() - _ = yym235 - if false { - } else { - r.EncodeInt(int64(x.MaxPerPodContainerCount)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("maxPerPodContainerCount")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym236 := z.EncBinary() - _ = yym236 - if false { - } else { - r.EncodeInt(int64(x.MaxPerPodContainerCount)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym238 := z.EncBinary() - _ = yym238 - if false { - } else { - r.EncodeInt(int64(x.MaxContainerCount)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("maxContainerCount")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym239 := z.EncBinary() - _ = yym239 - if false { - } else { - r.EncodeInt(int64(x.MaxContainerCount)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym241 := z.EncBinary() - _ = yym241 - if false { - } else { - r.EncodeInt(int64(x.CAdvisorPort)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cAdvisorPort")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym242 := z.EncBinary() - _ = yym242 - if false { - } else { - r.EncodeInt(int64(x.CAdvisorPort)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym244 := z.EncBinary() - _ = yym244 - if false { - } else { - r.EncodeInt(int64(x.HealthzPort)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("healthzPort")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym245 := z.EncBinary() - _ = yym245 - if false { - } else { - r.EncodeInt(int64(x.HealthzPort)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym247 := z.EncBinary() - _ = yym247 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HealthzBindAddress)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("healthzBindAddress")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym248 := z.EncBinary() - _ = yym248 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HealthzBindAddress)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym250 := z.EncBinary() - _ = yym250 - if false { - } else { - r.EncodeInt(int64(x.OOMScoreAdj)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("oomScoreAdj")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym251 := z.EncBinary() - _ = yym251 - if false { - } else { - r.EncodeInt(int64(x.OOMScoreAdj)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym253 := z.EncBinary() - _ = yym253 - if false { - } else { - r.EncodeBool(bool(x.RegisterNode)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("registerNode")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym254 := z.EncBinary() - _ = yym254 - if false { - } else { - r.EncodeBool(bool(x.RegisterNode)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym256 := z.EncBinary() - _ = yym256 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterDomain)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterDomain")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym257 := z.EncBinary() - _ = yym257 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterDomain)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym259 := z.EncBinary() - _ = yym259 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.MasterServiceNamespace)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("masterServiceNamespace")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym260 := z.EncBinary() - _ = yym260 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.MasterServiceNamespace)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym262 := z.EncBinary() - _ = yym262 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterDNS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterDNS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym263 := z.EncBinary() - _ = yym263 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterDNS)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy265 := &x.StreamingConnectionIdleTimeout - yym266 := z.EncBinary() - _ = yym266 - if false { - } else if z.HasExtensions() && z.EncExt(yy265) { - } else if !yym266 && z.IsJSONHandle() { - z.EncJSONMarshal(yy265) - } else { - z.EncFallback(yy265) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("streamingConnectionIdleTimeout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy267 := &x.StreamingConnectionIdleTimeout - yym268 := z.EncBinary() - _ = yym268 - if false { - } else if z.HasExtensions() && z.EncExt(yy267) { - } else if !yym268 && z.IsJSONHandle() { - z.EncJSONMarshal(yy267) - } else { - z.EncFallback(yy267) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy270 := &x.NodeStatusUpdateFrequency - yym271 := z.EncBinary() - _ = yym271 - if false { - } else if z.HasExtensions() && z.EncExt(yy270) { - } else if !yym271 && z.IsJSONHandle() { - z.EncJSONMarshal(yy270) - } else { - z.EncFallback(yy270) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeStatusUpdateFrequency")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy272 := &x.NodeStatusUpdateFrequency - yym273 := z.EncBinary() - _ = yym273 - if false { - } else if z.HasExtensions() && z.EncExt(yy272) { - } else if !yym273 && z.IsJSONHandle() { - z.EncJSONMarshal(yy272) - } else { - z.EncFallback(yy272) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy275 := &x.ImageMinimumGCAge - yym276 := z.EncBinary() - _ = yym276 - if false { - } else if z.HasExtensions() && z.EncExt(yy275) { - } else if !yym276 && z.IsJSONHandle() { - z.EncJSONMarshal(yy275) - } else { - z.EncFallback(yy275) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("imageMinimumGCAge")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy277 := &x.ImageMinimumGCAge - yym278 := z.EncBinary() - _ = yym278 - if false { - } else if z.HasExtensions() && z.EncExt(yy277) { - } else if !yym278 && z.IsJSONHandle() { - z.EncJSONMarshal(yy277) - } else { - z.EncFallback(yy277) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym280 := z.EncBinary() - _ = yym280 - if false { - } else { - r.EncodeInt(int64(x.ImageGCHighThresholdPercent)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("imageGCHighThresholdPercent")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym281 := z.EncBinary() - _ = yym281 - if false { - } else { - r.EncodeInt(int64(x.ImageGCHighThresholdPercent)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym283 := z.EncBinary() - _ = yym283 - if false { - } else { - r.EncodeInt(int64(x.ImageGCLowThresholdPercent)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("imageGCLowThresholdPercent")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym284 := z.EncBinary() - _ = yym284 - if false { - } else { - r.EncodeInt(int64(x.ImageGCLowThresholdPercent)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym286 := z.EncBinary() - _ = yym286 - if false { - } else { - r.EncodeInt(int64(x.LowDiskSpaceThresholdMB)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lowDiskSpaceThresholdMB")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym287 := z.EncBinary() - _ = yym287 - if false { - } else { - r.EncodeInt(int64(x.LowDiskSpaceThresholdMB)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy289 := &x.VolumeStatsAggPeriod - yym290 := z.EncBinary() - _ = yym290 - if false { - } else if z.HasExtensions() && z.EncExt(yy289) { - } else if !yym290 && z.IsJSONHandle() { - z.EncJSONMarshal(yy289) - } else { - z.EncFallback(yy289) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("volumeStatsAggPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy291 := &x.VolumeStatsAggPeriod - yym292 := z.EncBinary() - _ = yym292 - if false { - } else if z.HasExtensions() && z.EncExt(yy291) { - } else if !yym292 && z.IsJSONHandle() { - z.EncJSONMarshal(yy291) - } else { - z.EncFallback(yy291) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym294 := z.EncBinary() - _ = yym294 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NetworkPluginName)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("networkPluginName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym295 := z.EncBinary() - _ = yym295 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NetworkPluginName)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym297 := z.EncBinary() - _ = yym297 - if false { - } else { - r.EncodeInt(int64(x.NetworkPluginMTU)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("networkPluginMTU")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym298 := z.EncBinary() - _ = yym298 - if false { - } else { - r.EncodeInt(int64(x.NetworkPluginMTU)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym300 := z.EncBinary() - _ = yym300 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NetworkPluginDir)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("networkPluginDir")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym301 := z.EncBinary() - _ = yym301 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NetworkPluginDir)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym303 := z.EncBinary() - _ = yym303 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CNIConfDir)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cniConfDir")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym304 := z.EncBinary() - _ = yym304 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CNIConfDir)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym306 := z.EncBinary() - _ = yym306 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CNIBinDir)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cniBinDir")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym307 := z.EncBinary() - _ = yym307 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CNIBinDir)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym309 := z.EncBinary() - _ = yym309 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.VolumePluginDir)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("volumePluginDir")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym310 := z.EncBinary() - _ = yym310 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.VolumePluginDir)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[53] { - yym312 := z.EncBinary() - _ = yym312 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudProvider)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[53] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cloudProvider")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym313 := z.EncBinary() - _ = yym313 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudProvider)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[54] { - yym315 := z.EncBinary() - _ = yym315 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudConfigFile)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[54] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cloudConfigFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym316 := z.EncBinary() - _ = yym316 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudConfigFile)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[55] { - yym318 := z.EncBinary() - _ = yym318 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.KubeletCgroups)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[55] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeletCgroups")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym319 := z.EncBinary() - _ = yym319 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.KubeletCgroups)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[56] { - yym321 := z.EncBinary() - _ = yym321 - if false { - } else { - r.EncodeBool(bool(x.CgroupsPerQOS)) - } - } else { - r.EncodeBool(false) - } - } else { - if yyq135[56] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cgroupsPerQOS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym322 := z.EncBinary() - _ = yym322 - if false { - } else { - r.EncodeBool(bool(x.CgroupsPerQOS)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[57] { - yym324 := z.EncBinary() - _ = yym324 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CgroupDriver)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[57] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cgroupDriver")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym325 := z.EncBinary() - _ = yym325 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CgroupDriver)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[58] { - yym327 := z.EncBinary() - _ = yym327 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RuntimeCgroups)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[58] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("runtimeCgroups")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym328 := z.EncBinary() - _ = yym328 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RuntimeCgroups)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[59] { - yym330 := z.EncBinary() - _ = yym330 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SystemCgroups)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[59] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("systemCgroups")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym331 := z.EncBinary() - _ = yym331 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SystemCgroups)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[60] { - yym333 := z.EncBinary() - _ = yym333 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CgroupRoot)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[60] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cgroupRoot")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym334 := z.EncBinary() - _ = yym334 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CgroupRoot)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym336 := z.EncBinary() - _ = yym336 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntime)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("containerRuntime")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym337 := z.EncBinary() - _ = yym337 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContainerRuntime)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym339 := z.EncBinary() - _ = yym339 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RemoteRuntimeEndpoint)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("remoteRuntimeEndpoint")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym340 := z.EncBinary() - _ = yym340 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RemoteRuntimeEndpoint)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym342 := z.EncBinary() - _ = yym342 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RemoteImageEndpoint)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("remoteImageEndpoint")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym343 := z.EncBinary() - _ = yym343 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RemoteImageEndpoint)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[64] { - yy345 := &x.RuntimeRequestTimeout - yym346 := z.EncBinary() - _ = yym346 - if false { - } else if z.HasExtensions() && z.EncExt(yy345) { - } else if !yym346 && z.IsJSONHandle() { - z.EncJSONMarshal(yy345) - } else { - z.EncFallback(yy345) - } - } else { - r.EncodeNil() - } - } else { - if yyq135[64] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("runtimeRequestTimeout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy347 := &x.RuntimeRequestTimeout - yym348 := z.EncBinary() - _ = yym348 - if false { - } else if z.HasExtensions() && z.EncExt(yy347) { - } else if !yym348 && z.IsJSONHandle() { - z.EncJSONMarshal(yy347) - } else { - z.EncFallback(yy347) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[65] { - yym350 := z.EncBinary() - _ = yym350 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktPath)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[65] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rktPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym351 := z.EncBinary() - _ = yym351 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktPath)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[66] { - yym353 := z.EncBinary() - _ = yym353 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktAPIEndpoint)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[66] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rktAPIEndpoint")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym354 := z.EncBinary() - _ = yym354 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktAPIEndpoint)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[67] { - yym356 := z.EncBinary() - _ = yym356 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktStage1Image)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[67] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rktStage1Image")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym357 := z.EncBinary() - _ = yym357 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RktStage1Image)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym359 := z.EncBinary() - _ = yym359 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.LockFilePath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lockFilePath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym360 := z.EncBinary() - _ = yym360 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.LockFilePath)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym362 := z.EncBinary() - _ = yym362 - if false { - } else { - r.EncodeBool(bool(x.ExitOnLockContention)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("exitOnLockContention")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym363 := z.EncBinary() - _ = yym363 - if false { - } else { - r.EncodeBool(bool(x.ExitOnLockContention)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym365 := z.EncBinary() - _ = yym365 - if false { - } else { - r.EncodeBool(bool(x.ConfigureCBR0)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("configureCbr0")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym366 := z.EncBinary() - _ = yym366 - if false { - } else { - r.EncodeBool(bool(x.ConfigureCBR0)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym368 := z.EncBinary() - _ = yym368 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HairpinMode)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hairpinMode")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym369 := z.EncBinary() - _ = yym369 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.HairpinMode)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym371 := z.EncBinary() - _ = yym371 - if false { - } else { - r.EncodeBool(bool(x.BabysitDaemons)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("babysitDaemons")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym372 := z.EncBinary() - _ = yym372 - if false { - } else { - r.EncodeBool(bool(x.BabysitDaemons)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym374 := z.EncBinary() - _ = yym374 - if false { - } else { - r.EncodeInt(int64(x.MaxPods)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("maxPods")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym375 := z.EncBinary() - _ = yym375 - if false { - } else { - r.EncodeInt(int64(x.MaxPods)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym377 := z.EncBinary() - _ = yym377 - if false { - } else { - r.EncodeInt(int64(x.NvidiaGPUs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nvidiaGPUs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym378 := z.EncBinary() - _ = yym378 - if false { - } else { - r.EncodeInt(int64(x.NvidiaGPUs)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym380 := z.EncBinary() - _ = yym380 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.DockerExecHandlerName)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("dockerExecHandlerName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym381 := z.EncBinary() - _ = yym381 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.DockerExecHandlerName)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym383 := z.EncBinary() - _ = yym383 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym384 := z.EncBinary() - _ = yym384 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodCIDR)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym386 := z.EncBinary() - _ = yym386 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResolverConfig)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("resolvConf")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym387 := z.EncBinary() - _ = yym387 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ResolverConfig)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym389 := z.EncBinary() - _ = yym389 - if false { - } else { - r.EncodeBool(bool(x.CPUCFSQuota)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cpuCFSQuota")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym390 := z.EncBinary() - _ = yym390 - if false { - } else { - r.EncodeBool(bool(x.CPUCFSQuota)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym392 := z.EncBinary() - _ = yym392 - if false { - } else { - r.EncodeBool(bool(x.Containerized)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("containerized")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym393 := z.EncBinary() - _ = yym393 - if false { - } else { - r.EncodeBool(bool(x.Containerized)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym395 := z.EncBinary() - _ = yym395 - if false { - } else { - r.EncodeInt(int64(x.MaxOpenFiles)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("maxOpenFiles")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym396 := z.EncBinary() - _ = yym396 - if false { - } else { - r.EncodeInt(int64(x.MaxOpenFiles)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym398 := z.EncBinary() - _ = yym398 - if false { - } else { - r.EncodeBool(bool(x.ReconcileCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("reconcileCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym399 := z.EncBinary() - _ = yym399 - if false { - } else { - r.EncodeBool(bool(x.ReconcileCIDR)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym401 := z.EncBinary() - _ = yym401 - if false { - } else { - r.EncodeBool(bool(x.RegisterSchedulable)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("registerSchedulable")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym402 := z.EncBinary() - _ = yym402 - if false { - } else { - r.EncodeBool(bool(x.RegisterSchedulable)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym404 := z.EncBinary() - _ = yym404 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("contentType")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym405 := z.EncBinary() - _ = yym405 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym407 := z.EncBinary() - _ = yym407 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIQPS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIQPS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym408 := z.EncBinary() - _ = yym408 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIQPS)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym410 := z.EncBinary() - _ = yym410 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym411 := z.EncBinary() - _ = yym411 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym413 := z.EncBinary() - _ = yym413 - if false { - } else { - r.EncodeBool(bool(x.SerializeImagePulls)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("serializeImagePulls")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym414 := z.EncBinary() - _ = yym414 - if false { - } else { - r.EncodeBool(bool(x.SerializeImagePulls)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[87] { - yy416 := &x.OutOfDiskTransitionFrequency - yym417 := z.EncBinary() - _ = yym417 - if false { - } else if z.HasExtensions() && z.EncExt(yy416) { - } else if !yym417 && z.IsJSONHandle() { - z.EncJSONMarshal(yy416) - } else { - z.EncFallback(yy416) - } - } else { - r.EncodeNil() - } - } else { - if yyq135[87] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("outOfDiskTransitionFrequency")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy418 := &x.OutOfDiskTransitionFrequency - yym419 := z.EncBinary() - _ = yym419 - if false { - } else if z.HasExtensions() && z.EncExt(yy418) { - } else if !yym419 && z.IsJSONHandle() { - z.EncJSONMarshal(yy418) - } else { - z.EncFallback(yy418) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[88] { - yym421 := z.EncBinary() - _ = yym421 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NodeIP)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[88] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeIP")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym422 := z.EncBinary() - _ = yym422 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NodeIP)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.NodeLabels == nil { - r.EncodeNil() - } else { - yym424 := z.EncBinary() - _ = yym424 - if false { - } else { - z.F.EncMapStringStringV(x.NodeLabels, false, e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeLabels")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.NodeLabels == nil { - r.EncodeNil() - } else { - yym425 := z.EncBinary() - _ = yym425 - if false { - } else { - z.F.EncMapStringStringV(x.NodeLabels, false, e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym427 := z.EncBinary() - _ = yym427 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NonMasqueradeCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nonMasqueradeCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym428 := z.EncBinary() - _ = yym428 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.NonMasqueradeCIDR)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym430 := z.EncBinary() - _ = yym430 - if false { - } else { - r.EncodeBool(bool(x.EnableCustomMetrics)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableCustomMetrics")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym431 := z.EncBinary() - _ = yym431 - if false { - } else { - r.EncodeBool(bool(x.EnableCustomMetrics)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[92] { - yym433 := z.EncBinary() - _ = yym433 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionHard)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[92] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionHard")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym434 := z.EncBinary() - _ = yym434 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionHard)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[93] { - yym436 := z.EncBinary() - _ = yym436 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionSoft)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[93] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionSoft")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym437 := z.EncBinary() - _ = yym437 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionSoft)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[94] { - yym439 := z.EncBinary() - _ = yym439 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionSoftGracePeriod)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[94] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionSoftGracePeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym440 := z.EncBinary() - _ = yym440 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionSoftGracePeriod)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[95] { - yy442 := &x.EvictionPressureTransitionPeriod - yym443 := z.EncBinary() - _ = yym443 - if false { - } else if z.HasExtensions() && z.EncExt(yy442) { - } else if !yym443 && z.IsJSONHandle() { - z.EncJSONMarshal(yy442) - } else { - z.EncFallback(yy442) - } - } else { - r.EncodeNil() - } - } else { - if yyq135[95] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionPressureTransitionPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy444 := &x.EvictionPressureTransitionPeriod - yym445 := z.EncBinary() - _ = yym445 - if false { - } else if z.HasExtensions() && z.EncExt(yy444) { - } else if !yym445 && z.IsJSONHandle() { - z.EncJSONMarshal(yy444) - } else { - z.EncFallback(yy444) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[96] { - yym447 := z.EncBinary() - _ = yym447 - if false { - } else { - r.EncodeInt(int64(x.EvictionMaxPodGracePeriod)) - } - } else { - r.EncodeInt(0) - } - } else { - if yyq135[96] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionMaxPodGracePeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym448 := z.EncBinary() - _ = yym448 - if false { - } else { - r.EncodeInt(int64(x.EvictionMaxPodGracePeriod)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[97] { - yym450 := z.EncBinary() - _ = yym450 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionMinimumReclaim)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[97] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("evictionMinimumReclaim")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym451 := z.EncBinary() - _ = yym451 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.EvictionMinimumReclaim)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym453 := z.EncBinary() - _ = yym453 - if false { - } else { - r.EncodeInt(int64(x.PodsPerCore)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podsPerCore")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym454 := z.EncBinary() - _ = yym454 - if false { - } else { - r.EncodeInt(int64(x.PodsPerCore)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym456 := z.EncBinary() - _ = yym456 - if false { - } else { - r.EncodeBool(bool(x.EnableControllerAttachDetach)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableControllerAttachDetach")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym457 := z.EncBinary() - _ = yym457 - if false { - } else { - r.EncodeBool(bool(x.EnableControllerAttachDetach)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.SystemReserved == nil { - r.EncodeNil() - } else { - yym459 := z.EncBinary() - _ = yym459 - if false { - } else if z.HasExtensions() && z.EncExt(x.SystemReserved) { - } else { - h.encconfig_ConfigurationMap((pkg2_config.ConfigurationMap)(x.SystemReserved), e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("systemReserved")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.SystemReserved == nil { - r.EncodeNil() - } else { - yym460 := z.EncBinary() - _ = yym460 - if false { - } else if z.HasExtensions() && z.EncExt(x.SystemReserved) { - } else { - h.encconfig_ConfigurationMap((pkg2_config.ConfigurationMap)(x.SystemReserved), e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if x.KubeReserved == nil { - r.EncodeNil() - } else { - yym462 := z.EncBinary() - _ = yym462 - if false { - } else if z.HasExtensions() && z.EncExt(x.KubeReserved) { - } else { - h.encconfig_ConfigurationMap((pkg2_config.ConfigurationMap)(x.KubeReserved), e) - } - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeReserved")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.KubeReserved == nil { - r.EncodeNil() - } else { - yym463 := z.EncBinary() - _ = yym463 - if false { - } else if z.HasExtensions() && z.EncExt(x.KubeReserved) { - } else { - h.encconfig_ConfigurationMap((pkg2_config.ConfigurationMap)(x.KubeReserved), e) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym465 := z.EncBinary() - _ = yym465 - if false { - } else { - r.EncodeBool(bool(x.ProtectKernelDefaults)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("protectKernelDefaults")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym466 := z.EncBinary() - _ = yym466 - if false { - } else { - r.EncodeBool(bool(x.ProtectKernelDefaults)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym468 := z.EncBinary() - _ = yym468 - if false { - } else { - r.EncodeBool(bool(x.MakeIPTablesUtilChains)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("makeIPTablesUtilChains")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym469 := z.EncBinary() - _ = yym469 - if false { - } else { - r.EncodeBool(bool(x.MakeIPTablesUtilChains)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym471 := z.EncBinary() - _ = yym471 - if false { - } else { - r.EncodeInt(int64(x.IPTablesMasqueradeBit)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("iptablesMasqueradeBit")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym472 := z.EncBinary() - _ = yym472 - if false { - } else { - r.EncodeInt(int64(x.IPTablesMasqueradeBit)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym474 := z.EncBinary() - _ = yym474 - if false { - } else { - r.EncodeInt(int64(x.IPTablesDropBit)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("iptablesDropBit")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym475 := z.EncBinary() - _ = yym475 - if false { - } else { - r.EncodeInt(int64(x.IPTablesDropBit)) - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[106] { - if x.AllowedUnsafeSysctls == nil { - r.EncodeNil() - } else { - yym477 := z.EncBinary() - _ = yym477 - if false { - } else { - z.F.EncSliceStringV(x.AllowedUnsafeSysctls, false, e) - } - } - } else { - r.EncodeNil() - } - } else { - if yyq135[106] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("experimentalAllowedUnsafeSysctls")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - if x.AllowedUnsafeSysctls == nil { - r.EncodeNil() - } else { - yym478 := z.EncBinary() - _ = yym478 - if false { - } else { - z.F.EncSliceStringV(x.AllowedUnsafeSysctls, false, e) - } - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq135[107] { - yym480 := z.EncBinary() - _ = yym480 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ExperimentalRuntimeIntegrationType)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq135[107] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("experimentalRuntimeIntegrationType")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym481 := z.EncBinary() - _ = yym481 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ExperimentalRuntimeIntegrationType)) - } - } - } - if yyr135 || yy2arr135 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *KubeletConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym482 := z.DecBinary() - _ = yym482 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct483 := r.ContainerType() - if yyct483 == codecSelferValueTypeMap1234 { - yyl483 := r.ReadMapStart() - if yyl483 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl483, d) - } - } else if yyct483 == codecSelferValueTypeArray1234 { - yyl483 := r.ReadArrayStart() - if yyl483 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl483, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *KubeletConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys484Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys484Slc - var yyhl484 bool = l >= 0 - for yyj484 := 0; ; yyj484++ { - if yyhl484 { - if yyj484 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys484Slc = r.DecodeBytes(yys484Slc, true, true) - yys484 := string(yys484Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys484 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "podManifestPath": - if r.TryDecodeAsNil() { - x.PodManifestPath = "" - } else { - x.PodManifestPath = string(r.DecodeString()) - } - case "syncFrequency": - if r.TryDecodeAsNil() { - x.SyncFrequency = pkg1_unversioned.Duration{} - } else { - yyv488 := &x.SyncFrequency - yym489 := z.DecBinary() - _ = yym489 - if false { - } else if z.HasExtensions() && z.DecExt(yyv488) { - } else if !yym489 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv488) - } else { - z.DecFallback(yyv488, false) - } - } - case "fileCheckFrequency": - if r.TryDecodeAsNil() { - x.FileCheckFrequency = pkg1_unversioned.Duration{} - } else { - yyv490 := &x.FileCheckFrequency - yym491 := z.DecBinary() - _ = yym491 - if false { - } else if z.HasExtensions() && z.DecExt(yyv490) { - } else if !yym491 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv490) - } else { - z.DecFallback(yyv490, false) - } - } - case "httpCheckFrequency": - if r.TryDecodeAsNil() { - x.HTTPCheckFrequency = pkg1_unversioned.Duration{} - } else { - yyv492 := &x.HTTPCheckFrequency - yym493 := z.DecBinary() - _ = yym493 - if false { - } else if z.HasExtensions() && z.DecExt(yyv492) { - } else if !yym493 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv492) - } else { - z.DecFallback(yyv492, false) - } - } - case "manifestURL": - if r.TryDecodeAsNil() { - x.ManifestURL = "" - } else { - x.ManifestURL = string(r.DecodeString()) - } - case "manifestURLHeader": - if r.TryDecodeAsNil() { - x.ManifestURLHeader = "" - } else { - x.ManifestURLHeader = string(r.DecodeString()) - } - case "enableServer": - if r.TryDecodeAsNil() { - x.EnableServer = false - } else { - x.EnableServer = bool(r.DecodeBool()) - } - case "address": - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - case "port": - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - case "readOnlyPort": - if r.TryDecodeAsNil() { - x.ReadOnlyPort = 0 - } else { - x.ReadOnlyPort = int32(r.DecodeInt(32)) - } - case "tlsCertFile": - if r.TryDecodeAsNil() { - x.TLSCertFile = "" - } else { - x.TLSCertFile = string(r.DecodeString()) - } - case "tlsPrivateKeyFile": - if r.TryDecodeAsNil() { - x.TLSPrivateKeyFile = "" - } else { - x.TLSPrivateKeyFile = string(r.DecodeString()) - } - case "certDirectory": - if r.TryDecodeAsNil() { - x.CertDirectory = "" - } else { - x.CertDirectory = string(r.DecodeString()) - } - case "hostnameOverride": - if r.TryDecodeAsNil() { - x.HostnameOverride = "" - } else { - x.HostnameOverride = string(r.DecodeString()) - } - case "podInfraContainerImage": - if r.TryDecodeAsNil() { - x.PodInfraContainerImage = "" - } else { - x.PodInfraContainerImage = string(r.DecodeString()) - } - case "dockerEndpoint": - if r.TryDecodeAsNil() { - x.DockerEndpoint = "" - } else { - x.DockerEndpoint = string(r.DecodeString()) - } - case "rootDirectory": - if r.TryDecodeAsNil() { - x.RootDirectory = "" - } else { - x.RootDirectory = string(r.DecodeString()) - } - case "seccompProfileRoot": - if r.TryDecodeAsNil() { - x.SeccompProfileRoot = "" - } else { - x.SeccompProfileRoot = string(r.DecodeString()) - } - case "allowPrivileged": - if r.TryDecodeAsNil() { - x.AllowPrivileged = false - } else { - x.AllowPrivileged = bool(r.DecodeBool()) - } - case "hostNetworkSources": - if r.TryDecodeAsNil() { - x.HostNetworkSources = nil - } else { - yyv509 := &x.HostNetworkSources - yym510 := z.DecBinary() - _ = yym510 - if false { - } else { - z.F.DecSliceStringX(yyv509, false, d) - } - } - case "hostPIDSources": - if r.TryDecodeAsNil() { - x.HostPIDSources = nil - } else { - yyv511 := &x.HostPIDSources - yym512 := z.DecBinary() - _ = yym512 - if false { - } else { - z.F.DecSliceStringX(yyv511, false, d) - } - } - case "hostIPCSources": - if r.TryDecodeAsNil() { - x.HostIPCSources = nil - } else { - yyv513 := &x.HostIPCSources - yym514 := z.DecBinary() - _ = yym514 - if false { - } else { - z.F.DecSliceStringX(yyv513, false, d) - } - } - case "registryPullQPS": - if r.TryDecodeAsNil() { - x.RegistryPullQPS = 0 - } else { - x.RegistryPullQPS = int32(r.DecodeInt(32)) - } - case "registryBurst": - if r.TryDecodeAsNil() { - x.RegistryBurst = 0 - } else { - x.RegistryBurst = int32(r.DecodeInt(32)) - } - case "eventRecordQPS": - if r.TryDecodeAsNil() { - x.EventRecordQPS = 0 - } else { - x.EventRecordQPS = int32(r.DecodeInt(32)) - } - case "eventBurst": - if r.TryDecodeAsNil() { - x.EventBurst = 0 - } else { - x.EventBurst = int32(r.DecodeInt(32)) - } - case "enableDebuggingHandlers": - if r.TryDecodeAsNil() { - x.EnableDebuggingHandlers = false - } else { - x.EnableDebuggingHandlers = bool(r.DecodeBool()) - } - case "minimumGCAge": - if r.TryDecodeAsNil() { - x.MinimumGCAge = pkg1_unversioned.Duration{} - } else { - yyv520 := &x.MinimumGCAge - yym521 := z.DecBinary() - _ = yym521 - if false { - } else if z.HasExtensions() && z.DecExt(yyv520) { - } else if !yym521 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv520) - } else { - z.DecFallback(yyv520, false) - } - } - case "maxPerPodContainerCount": - if r.TryDecodeAsNil() { - x.MaxPerPodContainerCount = 0 - } else { - x.MaxPerPodContainerCount = int32(r.DecodeInt(32)) - } - case "maxContainerCount": - if r.TryDecodeAsNil() { - x.MaxContainerCount = 0 - } else { - x.MaxContainerCount = int32(r.DecodeInt(32)) - } - case "cAdvisorPort": - if r.TryDecodeAsNil() { - x.CAdvisorPort = 0 - } else { - x.CAdvisorPort = int32(r.DecodeInt(32)) - } - case "healthzPort": - if r.TryDecodeAsNil() { - x.HealthzPort = 0 - } else { - x.HealthzPort = int32(r.DecodeInt(32)) - } - case "healthzBindAddress": - if r.TryDecodeAsNil() { - x.HealthzBindAddress = "" - } else { - x.HealthzBindAddress = string(r.DecodeString()) - } - case "oomScoreAdj": - if r.TryDecodeAsNil() { - x.OOMScoreAdj = 0 - } else { - x.OOMScoreAdj = int32(r.DecodeInt(32)) - } - case "registerNode": - if r.TryDecodeAsNil() { - x.RegisterNode = false - } else { - x.RegisterNode = bool(r.DecodeBool()) - } - case "clusterDomain": - if r.TryDecodeAsNil() { - x.ClusterDomain = "" - } else { - x.ClusterDomain = string(r.DecodeString()) - } - case "masterServiceNamespace": - if r.TryDecodeAsNil() { - x.MasterServiceNamespace = "" - } else { - x.MasterServiceNamespace = string(r.DecodeString()) - } - case "clusterDNS": - if r.TryDecodeAsNil() { - x.ClusterDNS = "" - } else { - x.ClusterDNS = string(r.DecodeString()) - } - case "streamingConnectionIdleTimeout": - if r.TryDecodeAsNil() { - x.StreamingConnectionIdleTimeout = pkg1_unversioned.Duration{} - } else { - yyv532 := &x.StreamingConnectionIdleTimeout - yym533 := z.DecBinary() - _ = yym533 - if false { - } else if z.HasExtensions() && z.DecExt(yyv532) { - } else if !yym533 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv532) - } else { - z.DecFallback(yyv532, false) - } - } - case "nodeStatusUpdateFrequency": - if r.TryDecodeAsNil() { - x.NodeStatusUpdateFrequency = pkg1_unversioned.Duration{} - } else { - yyv534 := &x.NodeStatusUpdateFrequency - yym535 := z.DecBinary() - _ = yym535 - if false { - } else if z.HasExtensions() && z.DecExt(yyv534) { - } else if !yym535 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv534) - } else { - z.DecFallback(yyv534, false) - } - } - case "imageMinimumGCAge": - if r.TryDecodeAsNil() { - x.ImageMinimumGCAge = pkg1_unversioned.Duration{} - } else { - yyv536 := &x.ImageMinimumGCAge - yym537 := z.DecBinary() - _ = yym537 - if false { - } else if z.HasExtensions() && z.DecExt(yyv536) { - } else if !yym537 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv536) - } else { - z.DecFallback(yyv536, false) - } - } - case "imageGCHighThresholdPercent": - if r.TryDecodeAsNil() { - x.ImageGCHighThresholdPercent = 0 - } else { - x.ImageGCHighThresholdPercent = int32(r.DecodeInt(32)) - } - case "imageGCLowThresholdPercent": - if r.TryDecodeAsNil() { - x.ImageGCLowThresholdPercent = 0 - } else { - x.ImageGCLowThresholdPercent = int32(r.DecodeInt(32)) - } - case "lowDiskSpaceThresholdMB": - if r.TryDecodeAsNil() { - x.LowDiskSpaceThresholdMB = 0 - } else { - x.LowDiskSpaceThresholdMB = int32(r.DecodeInt(32)) - } - case "volumeStatsAggPeriod": - if r.TryDecodeAsNil() { - x.VolumeStatsAggPeriod = pkg1_unversioned.Duration{} - } else { - yyv541 := &x.VolumeStatsAggPeriod - yym542 := z.DecBinary() - _ = yym542 - if false { - } else if z.HasExtensions() && z.DecExt(yyv541) { - } else if !yym542 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv541) - } else { - z.DecFallback(yyv541, false) - } - } - case "networkPluginName": - if r.TryDecodeAsNil() { - x.NetworkPluginName = "" - } else { - x.NetworkPluginName = string(r.DecodeString()) - } - case "networkPluginMTU": - if r.TryDecodeAsNil() { - x.NetworkPluginMTU = 0 - } else { - x.NetworkPluginMTU = int32(r.DecodeInt(32)) - } - case "networkPluginDir": - if r.TryDecodeAsNil() { - x.NetworkPluginDir = "" - } else { - x.NetworkPluginDir = string(r.DecodeString()) - } - case "cniConfDir": - if r.TryDecodeAsNil() { - x.CNIConfDir = "" - } else { - x.CNIConfDir = string(r.DecodeString()) - } - case "cniBinDir": - if r.TryDecodeAsNil() { - x.CNIBinDir = "" - } else { - x.CNIBinDir = string(r.DecodeString()) - } - case "volumePluginDir": - if r.TryDecodeAsNil() { - x.VolumePluginDir = "" - } else { - x.VolumePluginDir = string(r.DecodeString()) - } - case "cloudProvider": - if r.TryDecodeAsNil() { - x.CloudProvider = "" - } else { - x.CloudProvider = string(r.DecodeString()) - } - case "cloudConfigFile": - if r.TryDecodeAsNil() { - x.CloudConfigFile = "" - } else { - x.CloudConfigFile = string(r.DecodeString()) - } - case "kubeletCgroups": - if r.TryDecodeAsNil() { - x.KubeletCgroups = "" - } else { - x.KubeletCgroups = string(r.DecodeString()) - } - case "cgroupsPerQOS": - if r.TryDecodeAsNil() { - x.CgroupsPerQOS = false - } else { - x.CgroupsPerQOS = bool(r.DecodeBool()) - } - case "cgroupDriver": - if r.TryDecodeAsNil() { - x.CgroupDriver = "" - } else { - x.CgroupDriver = string(r.DecodeString()) - } - case "runtimeCgroups": - if r.TryDecodeAsNil() { - x.RuntimeCgroups = "" - } else { - x.RuntimeCgroups = string(r.DecodeString()) - } - case "systemCgroups": - if r.TryDecodeAsNil() { - x.SystemCgroups = "" - } else { - x.SystemCgroups = string(r.DecodeString()) - } - case "cgroupRoot": - if r.TryDecodeAsNil() { - x.CgroupRoot = "" - } else { - x.CgroupRoot = string(r.DecodeString()) - } - case "containerRuntime": - if r.TryDecodeAsNil() { - x.ContainerRuntime = "" - } else { - x.ContainerRuntime = string(r.DecodeString()) - } - case "remoteRuntimeEndpoint": - if r.TryDecodeAsNil() { - x.RemoteRuntimeEndpoint = "" - } else { - x.RemoteRuntimeEndpoint = string(r.DecodeString()) - } - case "remoteImageEndpoint": - if r.TryDecodeAsNil() { - x.RemoteImageEndpoint = "" - } else { - x.RemoteImageEndpoint = string(r.DecodeString()) - } - case "runtimeRequestTimeout": - if r.TryDecodeAsNil() { - x.RuntimeRequestTimeout = pkg1_unversioned.Duration{} - } else { - yyv560 := &x.RuntimeRequestTimeout - yym561 := z.DecBinary() - _ = yym561 - if false { - } else if z.HasExtensions() && z.DecExt(yyv560) { - } else if !yym561 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv560) - } else { - z.DecFallback(yyv560, false) - } - } - case "rktPath": - if r.TryDecodeAsNil() { - x.RktPath = "" - } else { - x.RktPath = string(r.DecodeString()) - } - case "rktAPIEndpoint": - if r.TryDecodeAsNil() { - x.RktAPIEndpoint = "" - } else { - x.RktAPIEndpoint = string(r.DecodeString()) - } - case "rktStage1Image": - if r.TryDecodeAsNil() { - x.RktStage1Image = "" - } else { - x.RktStage1Image = string(r.DecodeString()) - } - case "lockFilePath": - if r.TryDecodeAsNil() { - x.LockFilePath = "" - } else { - x.LockFilePath = string(r.DecodeString()) - } - case "exitOnLockContention": - if r.TryDecodeAsNil() { - x.ExitOnLockContention = false - } else { - x.ExitOnLockContention = bool(r.DecodeBool()) - } - case "configureCbr0": - if r.TryDecodeAsNil() { - x.ConfigureCBR0 = false - } else { - x.ConfigureCBR0 = bool(r.DecodeBool()) - } - case "hairpinMode": - if r.TryDecodeAsNil() { - x.HairpinMode = "" - } else { - x.HairpinMode = string(r.DecodeString()) - } - case "babysitDaemons": - if r.TryDecodeAsNil() { - x.BabysitDaemons = false - } else { - x.BabysitDaemons = bool(r.DecodeBool()) - } - case "maxPods": - if r.TryDecodeAsNil() { - x.MaxPods = 0 - } else { - x.MaxPods = int32(r.DecodeInt(32)) - } - case "nvidiaGPUs": - if r.TryDecodeAsNil() { - x.NvidiaGPUs = 0 - } else { - x.NvidiaGPUs = int32(r.DecodeInt(32)) - } - case "dockerExecHandlerName": - if r.TryDecodeAsNil() { - x.DockerExecHandlerName = "" - } else { - x.DockerExecHandlerName = string(r.DecodeString()) - } - case "podCIDR": - if r.TryDecodeAsNil() { - x.PodCIDR = "" - } else { - x.PodCIDR = string(r.DecodeString()) - } - case "resolvConf": - if r.TryDecodeAsNil() { - x.ResolverConfig = "" - } else { - x.ResolverConfig = string(r.DecodeString()) - } - case "cpuCFSQuota": - if r.TryDecodeAsNil() { - x.CPUCFSQuota = false - } else { - x.CPUCFSQuota = bool(r.DecodeBool()) - } - case "containerized": - if r.TryDecodeAsNil() { - x.Containerized = false - } else { - x.Containerized = bool(r.DecodeBool()) - } - case "maxOpenFiles": - if r.TryDecodeAsNil() { - x.MaxOpenFiles = 0 - } else { - x.MaxOpenFiles = int64(r.DecodeInt(64)) - } - case "reconcileCIDR": - if r.TryDecodeAsNil() { - x.ReconcileCIDR = false - } else { - x.ReconcileCIDR = bool(r.DecodeBool()) - } - case "registerSchedulable": - if r.TryDecodeAsNil() { - x.RegisterSchedulable = false - } else { - x.RegisterSchedulable = bool(r.DecodeBool()) - } - case "contentType": - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - case "kubeAPIQPS": - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = int32(r.DecodeInt(32)) - } - case "kubeAPIBurst": - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - case "serializeImagePulls": - if r.TryDecodeAsNil() { - x.SerializeImagePulls = false - } else { - x.SerializeImagePulls = bool(r.DecodeBool()) - } - case "outOfDiskTransitionFrequency": - if r.TryDecodeAsNil() { - x.OutOfDiskTransitionFrequency = pkg1_unversioned.Duration{} - } else { - yyv584 := &x.OutOfDiskTransitionFrequency - yym585 := z.DecBinary() - _ = yym585 - if false { - } else if z.HasExtensions() && z.DecExt(yyv584) { - } else if !yym585 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv584) - } else { - z.DecFallback(yyv584, false) - } - } - case "nodeIP": - if r.TryDecodeAsNil() { - x.NodeIP = "" - } else { - x.NodeIP = string(r.DecodeString()) - } - case "nodeLabels": - if r.TryDecodeAsNil() { - x.NodeLabels = nil - } else { - yyv587 := &x.NodeLabels - yym588 := z.DecBinary() - _ = yym588 - if false { - } else { - z.F.DecMapStringStringX(yyv587, false, d) - } - } - case "nonMasqueradeCIDR": - if r.TryDecodeAsNil() { - x.NonMasqueradeCIDR = "" - } else { - x.NonMasqueradeCIDR = string(r.DecodeString()) - } - case "enableCustomMetrics": - if r.TryDecodeAsNil() { - x.EnableCustomMetrics = false - } else { - x.EnableCustomMetrics = bool(r.DecodeBool()) - } - case "evictionHard": - if r.TryDecodeAsNil() { - x.EvictionHard = "" - } else { - x.EvictionHard = string(r.DecodeString()) - } - case "evictionSoft": - if r.TryDecodeAsNil() { - x.EvictionSoft = "" - } else { - x.EvictionSoft = string(r.DecodeString()) - } - case "evictionSoftGracePeriod": - if r.TryDecodeAsNil() { - x.EvictionSoftGracePeriod = "" - } else { - x.EvictionSoftGracePeriod = string(r.DecodeString()) - } - case "evictionPressureTransitionPeriod": - if r.TryDecodeAsNil() { - x.EvictionPressureTransitionPeriod = pkg1_unversioned.Duration{} - } else { - yyv594 := &x.EvictionPressureTransitionPeriod - yym595 := z.DecBinary() - _ = yym595 - if false { - } else if z.HasExtensions() && z.DecExt(yyv594) { - } else if !yym595 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv594) - } else { - z.DecFallback(yyv594, false) - } - } - case "evictionMaxPodGracePeriod": - if r.TryDecodeAsNil() { - x.EvictionMaxPodGracePeriod = 0 - } else { - x.EvictionMaxPodGracePeriod = int32(r.DecodeInt(32)) - } - case "evictionMinimumReclaim": - if r.TryDecodeAsNil() { - x.EvictionMinimumReclaim = "" - } else { - x.EvictionMinimumReclaim = string(r.DecodeString()) - } - case "podsPerCore": - if r.TryDecodeAsNil() { - x.PodsPerCore = 0 - } else { - x.PodsPerCore = int32(r.DecodeInt(32)) - } - case "enableControllerAttachDetach": - if r.TryDecodeAsNil() { - x.EnableControllerAttachDetach = false - } else { - x.EnableControllerAttachDetach = bool(r.DecodeBool()) - } - case "systemReserved": - if r.TryDecodeAsNil() { - x.SystemReserved = nil - } else { - yyv600 := &x.SystemReserved - yym601 := z.DecBinary() - _ = yym601 - if false { - } else if z.HasExtensions() && z.DecExt(yyv600) { - } else { - h.decconfig_ConfigurationMap((*pkg2_config.ConfigurationMap)(yyv600), d) - } - } - case "kubeReserved": - if r.TryDecodeAsNil() { - x.KubeReserved = nil - } else { - yyv602 := &x.KubeReserved - yym603 := z.DecBinary() - _ = yym603 - if false { - } else if z.HasExtensions() && z.DecExt(yyv602) { - } else { - h.decconfig_ConfigurationMap((*pkg2_config.ConfigurationMap)(yyv602), d) - } - } - case "protectKernelDefaults": - if r.TryDecodeAsNil() { - x.ProtectKernelDefaults = false - } else { - x.ProtectKernelDefaults = bool(r.DecodeBool()) - } - case "makeIPTablesUtilChains": - if r.TryDecodeAsNil() { - x.MakeIPTablesUtilChains = false - } else { - x.MakeIPTablesUtilChains = bool(r.DecodeBool()) - } - case "iptablesMasqueradeBit": - if r.TryDecodeAsNil() { - x.IPTablesMasqueradeBit = 0 - } else { - x.IPTablesMasqueradeBit = int32(r.DecodeInt(32)) - } - case "iptablesDropBit": - if r.TryDecodeAsNil() { - x.IPTablesDropBit = 0 - } else { - x.IPTablesDropBit = int32(r.DecodeInt(32)) - } - case "experimentalAllowedUnsafeSysctls": - if r.TryDecodeAsNil() { - x.AllowedUnsafeSysctls = nil - } else { - yyv608 := &x.AllowedUnsafeSysctls - yym609 := z.DecBinary() - _ = yym609 - if false { - } else { - z.F.DecSliceStringX(yyv608, false, d) - } - } - case "experimentalRuntimeIntegrationType": - if r.TryDecodeAsNil() { - x.ExperimentalRuntimeIntegrationType = "" - } else { - x.ExperimentalRuntimeIntegrationType = string(r.DecodeString()) - } - default: - z.DecStructFieldNotFound(-1, yys484) - } // end switch yys484 - } // end for yyj484 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *KubeletConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj611 int - var yyb611 bool - var yyhl611 bool = l >= 0 - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodManifestPath = "" - } else { - x.PodManifestPath = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SyncFrequency = pkg1_unversioned.Duration{} - } else { - yyv615 := &x.SyncFrequency - yym616 := z.DecBinary() - _ = yym616 - if false { - } else if z.HasExtensions() && z.DecExt(yyv615) { - } else if !yym616 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv615) - } else { - z.DecFallback(yyv615, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.FileCheckFrequency = pkg1_unversioned.Duration{} - } else { - yyv617 := &x.FileCheckFrequency - yym618 := z.DecBinary() - _ = yym618 - if false { - } else if z.HasExtensions() && z.DecExt(yyv617) { - } else if !yym618 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv617) - } else { - z.DecFallback(yyv617, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HTTPCheckFrequency = pkg1_unversioned.Duration{} - } else { - yyv619 := &x.HTTPCheckFrequency - yym620 := z.DecBinary() - _ = yym620 - if false { - } else if z.HasExtensions() && z.DecExt(yyv619) { - } else if !yym620 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv619) - } else { - z.DecFallback(yyv619, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ManifestURL = "" - } else { - x.ManifestURL = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ManifestURLHeader = "" - } else { - x.ManifestURLHeader = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableServer = false - } else { - x.EnableServer = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ReadOnlyPort = 0 - } else { - x.ReadOnlyPort = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.TLSCertFile = "" - } else { - x.TLSCertFile = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.TLSPrivateKeyFile = "" - } else { - x.TLSPrivateKeyFile = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CertDirectory = "" - } else { - x.CertDirectory = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HostnameOverride = "" - } else { - x.HostnameOverride = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodInfraContainerImage = "" - } else { - x.PodInfraContainerImage = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.DockerEndpoint = "" - } else { - x.DockerEndpoint = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RootDirectory = "" - } else { - x.RootDirectory = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SeccompProfileRoot = "" - } else { - x.SeccompProfileRoot = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.AllowPrivileged = false - } else { - x.AllowPrivileged = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HostNetworkSources = nil - } else { - yyv636 := &x.HostNetworkSources - yym637 := z.DecBinary() - _ = yym637 - if false { - } else { - z.F.DecSliceStringX(yyv636, false, d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HostPIDSources = nil - } else { - yyv638 := &x.HostPIDSources - yym639 := z.DecBinary() - _ = yym639 - if false { - } else { - z.F.DecSliceStringX(yyv638, false, d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HostIPCSources = nil - } else { - yyv640 := &x.HostIPCSources - yym641 := z.DecBinary() - _ = yym641 - if false { - } else { - z.F.DecSliceStringX(yyv640, false, d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RegistryPullQPS = 0 - } else { - x.RegistryPullQPS = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RegistryBurst = 0 - } else { - x.RegistryBurst = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EventRecordQPS = 0 - } else { - x.EventRecordQPS = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EventBurst = 0 - } else { - x.EventBurst = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableDebuggingHandlers = false - } else { - x.EnableDebuggingHandlers = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MinimumGCAge = pkg1_unversioned.Duration{} - } else { - yyv647 := &x.MinimumGCAge - yym648 := z.DecBinary() - _ = yym648 - if false { - } else if z.HasExtensions() && z.DecExt(yyv647) { - } else if !yym648 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv647) - } else { - z.DecFallback(yyv647, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MaxPerPodContainerCount = 0 - } else { - x.MaxPerPodContainerCount = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MaxContainerCount = 0 - } else { - x.MaxContainerCount = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CAdvisorPort = 0 - } else { - x.CAdvisorPort = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HealthzPort = 0 - } else { - x.HealthzPort = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HealthzBindAddress = "" - } else { - x.HealthzBindAddress = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.OOMScoreAdj = 0 - } else { - x.OOMScoreAdj = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RegisterNode = false - } else { - x.RegisterNode = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterDomain = "" - } else { - x.ClusterDomain = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MasterServiceNamespace = "" - } else { - x.MasterServiceNamespace = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterDNS = "" - } else { - x.ClusterDNS = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.StreamingConnectionIdleTimeout = pkg1_unversioned.Duration{} - } else { - yyv659 := &x.StreamingConnectionIdleTimeout - yym660 := z.DecBinary() - _ = yym660 - if false { - } else if z.HasExtensions() && z.DecExt(yyv659) { - } else if !yym660 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv659) - } else { - z.DecFallback(yyv659, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeStatusUpdateFrequency = pkg1_unversioned.Duration{} - } else { - yyv661 := &x.NodeStatusUpdateFrequency - yym662 := z.DecBinary() - _ = yym662 - if false { - } else if z.HasExtensions() && z.DecExt(yyv661) { - } else if !yym662 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv661) - } else { - z.DecFallback(yyv661, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ImageMinimumGCAge = pkg1_unversioned.Duration{} - } else { - yyv663 := &x.ImageMinimumGCAge - yym664 := z.DecBinary() - _ = yym664 - if false { - } else if z.HasExtensions() && z.DecExt(yyv663) { - } else if !yym664 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv663) - } else { - z.DecFallback(yyv663, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ImageGCHighThresholdPercent = 0 - } else { - x.ImageGCHighThresholdPercent = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ImageGCLowThresholdPercent = 0 - } else { - x.ImageGCLowThresholdPercent = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LowDiskSpaceThresholdMB = 0 - } else { - x.LowDiskSpaceThresholdMB = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.VolumeStatsAggPeriod = pkg1_unversioned.Duration{} - } else { - yyv668 := &x.VolumeStatsAggPeriod - yym669 := z.DecBinary() - _ = yym669 - if false { - } else if z.HasExtensions() && z.DecExt(yyv668) { - } else if !yym669 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv668) - } else { - z.DecFallback(yyv668, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NetworkPluginName = "" - } else { - x.NetworkPluginName = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NetworkPluginMTU = 0 - } else { - x.NetworkPluginMTU = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NetworkPluginDir = "" - } else { - x.NetworkPluginDir = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CNIConfDir = "" - } else { - x.CNIConfDir = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CNIBinDir = "" - } else { - x.CNIBinDir = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.VolumePluginDir = "" - } else { - x.VolumePluginDir = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CloudProvider = "" - } else { - x.CloudProvider = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CloudConfigFile = "" - } else { - x.CloudConfigFile = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeletCgroups = "" - } else { - x.KubeletCgroups = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CgroupsPerQOS = false - } else { - x.CgroupsPerQOS = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CgroupDriver = "" - } else { - x.CgroupDriver = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RuntimeCgroups = "" - } else { - x.RuntimeCgroups = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SystemCgroups = "" - } else { - x.SystemCgroups = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CgroupRoot = "" - } else { - x.CgroupRoot = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ContainerRuntime = "" - } else { - x.ContainerRuntime = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RemoteRuntimeEndpoint = "" - } else { - x.RemoteRuntimeEndpoint = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RemoteImageEndpoint = "" - } else { - x.RemoteImageEndpoint = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RuntimeRequestTimeout = pkg1_unversioned.Duration{} - } else { - yyv687 := &x.RuntimeRequestTimeout - yym688 := z.DecBinary() - _ = yym688 - if false { - } else if z.HasExtensions() && z.DecExt(yyv687) { - } else if !yym688 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv687) - } else { - z.DecFallback(yyv687, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RktPath = "" - } else { - x.RktPath = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RktAPIEndpoint = "" - } else { - x.RktAPIEndpoint = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RktStage1Image = "" - } else { - x.RktStage1Image = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LockFilePath = "" - } else { - x.LockFilePath = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ExitOnLockContention = false - } else { - x.ExitOnLockContention = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConfigureCBR0 = false - } else { - x.ConfigureCBR0 = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HairpinMode = "" - } else { - x.HairpinMode = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.BabysitDaemons = false - } else { - x.BabysitDaemons = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MaxPods = 0 - } else { - x.MaxPods = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NvidiaGPUs = 0 - } else { - x.NvidiaGPUs = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.DockerExecHandlerName = "" - } else { - x.DockerExecHandlerName = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodCIDR = "" - } else { - x.PodCIDR = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ResolverConfig = "" - } else { - x.ResolverConfig = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CPUCFSQuota = false - } else { - x.CPUCFSQuota = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Containerized = false - } else { - x.Containerized = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MaxOpenFiles = 0 - } else { - x.MaxOpenFiles = int64(r.DecodeInt(64)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ReconcileCIDR = false - } else { - x.ReconcileCIDR = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RegisterSchedulable = false - } else { - x.RegisterSchedulable = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SerializeImagePulls = false - } else { - x.SerializeImagePulls = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.OutOfDiskTransitionFrequency = pkg1_unversioned.Duration{} - } else { - yyv711 := &x.OutOfDiskTransitionFrequency - yym712 := z.DecBinary() - _ = yym712 - if false { - } else if z.HasExtensions() && z.DecExt(yyv711) { - } else if !yym712 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv711) - } else { - z.DecFallback(yyv711, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeIP = "" - } else { - x.NodeIP = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeLabels = nil - } else { - yyv714 := &x.NodeLabels - yym715 := z.DecBinary() - _ = yym715 - if false { - } else { - z.F.DecMapStringStringX(yyv714, false, d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NonMasqueradeCIDR = "" - } else { - x.NonMasqueradeCIDR = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableCustomMetrics = false - } else { - x.EnableCustomMetrics = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionHard = "" - } else { - x.EvictionHard = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionSoft = "" - } else { - x.EvictionSoft = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionSoftGracePeriod = "" - } else { - x.EvictionSoftGracePeriod = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionPressureTransitionPeriod = pkg1_unversioned.Duration{} - } else { - yyv721 := &x.EvictionPressureTransitionPeriod - yym722 := z.DecBinary() - _ = yym722 - if false { - } else if z.HasExtensions() && z.DecExt(yyv721) { - } else if !yym722 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv721) - } else { - z.DecFallback(yyv721, false) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionMaxPodGracePeriod = 0 - } else { - x.EvictionMaxPodGracePeriod = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EvictionMinimumReclaim = "" - } else { - x.EvictionMinimumReclaim = string(r.DecodeString()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodsPerCore = 0 - } else { - x.PodsPerCore = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableControllerAttachDetach = false - } else { - x.EnableControllerAttachDetach = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SystemReserved = nil - } else { - yyv727 := &x.SystemReserved - yym728 := z.DecBinary() - _ = yym728 - if false { - } else if z.HasExtensions() && z.DecExt(yyv727) { - } else { - h.decconfig_ConfigurationMap((*pkg2_config.ConfigurationMap)(yyv727), d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeReserved = nil - } else { - yyv729 := &x.KubeReserved - yym730 := z.DecBinary() - _ = yym730 - if false { - } else if z.HasExtensions() && z.DecExt(yyv729) { - } else { - h.decconfig_ConfigurationMap((*pkg2_config.ConfigurationMap)(yyv729), d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ProtectKernelDefaults = false - } else { - x.ProtectKernelDefaults = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MakeIPTablesUtilChains = false - } else { - x.MakeIPTablesUtilChains = bool(r.DecodeBool()) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.IPTablesMasqueradeBit = 0 - } else { - x.IPTablesMasqueradeBit = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.IPTablesDropBit = 0 - } else { - x.IPTablesDropBit = int32(r.DecodeInt(32)) - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.AllowedUnsafeSysctls = nil - } else { - yyv735 := &x.AllowedUnsafeSysctls - yym736 := z.DecBinary() - _ = yym736 - if false { - } else { - z.F.DecSliceStringX(yyv735, false, d) - } - } - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ExperimentalRuntimeIntegrationType = "" - } else { - x.ExperimentalRuntimeIntegrationType = string(r.DecodeString()) - } - for { - yyj611++ - if yyhl611 { - yyb611 = yyj611 > l - } else { - yyb611 = r.CheckBreak() - } - if yyb611 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj611-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *KubeSchedulerConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym738 := z.EncBinary() - _ = yym738 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep739 := !z.EncBinary() - yy2arr739 := z.EncBasicHandle().StructToArray - var yyq739 [14]bool - _, _, _ = yysep739, yyq739, yy2arr739 - const yyr739 bool = false - yyq739[0] = x.Kind != "" - yyq739[1] = x.APIVersion != "" - var yynn739 int - if yyr739 || yy2arr739 { - r.EncodeArrayStart(14) - } else { - yynn739 = 12 - for _, b := range yyq739 { - if b { - yynn739++ - } - } - r.EncodeMapStart(yynn739) - yynn739 = 0 - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq739[0] { - yym741 := z.EncBinary() - _ = yym741 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq739[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym742 := z.EncBinary() - _ = yym742 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq739[1] { - yym744 := z.EncBinary() - _ = yym744 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq739[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym745 := z.EncBinary() - _ = yym745 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym747 := z.EncBinary() - _ = yym747 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("port")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym748 := z.EncBinary() - _ = yym748 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym750 := z.EncBinary() - _ = yym750 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("address")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym751 := z.EncBinary() - _ = yym751 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym753 := z.EncBinary() - _ = yym753 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.AlgorithmProvider)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("algorithmProvider")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym754 := z.EncBinary() - _ = yym754 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.AlgorithmProvider)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym756 := z.EncBinary() - _ = yym756 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PolicyConfigFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("policyConfigFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym757 := z.EncBinary() - _ = yym757 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PolicyConfigFile)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym759 := z.EncBinary() - _ = yym759 - if false { - } else { - r.EncodeBool(bool(x.EnableProfiling)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableProfiling")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym760 := z.EncBinary() - _ = yym760 - if false { - } else { - r.EncodeBool(bool(x.EnableProfiling)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym762 := z.EncBinary() - _ = yym762 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("contentType")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym763 := z.EncBinary() - _ = yym763 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym765 := z.EncBinary() - _ = yym765 - if false { - } else { - r.EncodeFloat32(float32(x.KubeAPIQPS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIQPS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym766 := z.EncBinary() - _ = yym766 - if false { - } else { - r.EncodeFloat32(float32(x.KubeAPIQPS)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym768 := z.EncBinary() - _ = yym768 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym769 := z.EncBinary() - _ = yym769 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym771 := z.EncBinary() - _ = yym771 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SchedulerName)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("schedulerName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym772 := z.EncBinary() - _ = yym772 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.SchedulerName)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym774 := z.EncBinary() - _ = yym774 - if false { - } else { - r.EncodeInt(int64(x.HardPodAffinitySymmetricWeight)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("hardPodAffinitySymmetricWeight")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym775 := z.EncBinary() - _ = yym775 - if false { - } else { - r.EncodeInt(int64(x.HardPodAffinitySymmetricWeight)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym777 := z.EncBinary() - _ = yym777 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FailureDomains)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("failureDomains")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym778 := z.EncBinary() - _ = yym778 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FailureDomains)) - } - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy780 := &x.LeaderElection - yy780.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("leaderElection")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy781 := &x.LeaderElection - yy781.CodecEncodeSelf(e) - } - if yyr739 || yy2arr739 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *KubeSchedulerConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym782 := z.DecBinary() - _ = yym782 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct783 := r.ContainerType() - if yyct783 == codecSelferValueTypeMap1234 { - yyl783 := r.ReadMapStart() - if yyl783 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl783, d) - } - } else if yyct783 == codecSelferValueTypeArray1234 { - yyl783 := r.ReadArrayStart() - if yyl783 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl783, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *KubeSchedulerConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys784Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys784Slc - var yyhl784 bool = l >= 0 - for yyj784 := 0; ; yyj784++ { - if yyhl784 { - if yyj784 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys784Slc = r.DecodeBytes(yys784Slc, true, true) - yys784 := string(yys784Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys784 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "port": - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - case "address": - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - case "algorithmProvider": - if r.TryDecodeAsNil() { - x.AlgorithmProvider = "" - } else { - x.AlgorithmProvider = string(r.DecodeString()) - } - case "policyConfigFile": - if r.TryDecodeAsNil() { - x.PolicyConfigFile = "" - } else { - x.PolicyConfigFile = string(r.DecodeString()) - } - case "enableProfiling": - if r.TryDecodeAsNil() { - x.EnableProfiling = false - } else { - x.EnableProfiling = bool(r.DecodeBool()) - } - case "contentType": - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - case "kubeAPIQPS": - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = float32(r.DecodeFloat(true)) - } - case "kubeAPIBurst": - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - case "schedulerName": - if r.TryDecodeAsNil() { - x.SchedulerName = "" - } else { - x.SchedulerName = string(r.DecodeString()) - } - case "hardPodAffinitySymmetricWeight": - if r.TryDecodeAsNil() { - x.HardPodAffinitySymmetricWeight = 0 - } else { - x.HardPodAffinitySymmetricWeight = int(r.DecodeInt(codecSelferBitsize1234)) - } - case "failureDomains": - if r.TryDecodeAsNil() { - x.FailureDomains = "" - } else { - x.FailureDomains = string(r.DecodeString()) - } - case "leaderElection": - if r.TryDecodeAsNil() { - x.LeaderElection = LeaderElectionConfiguration{} - } else { - yyv798 := &x.LeaderElection - yyv798.CodecDecodeSelf(d) - } - default: - z.DecStructFieldNotFound(-1, yys784) - } // end switch yys784 - } // end for yyj784 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *KubeSchedulerConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj799 int - var yyb799 bool - var yyhl799 bool = l >= 0 - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.AlgorithmProvider = "" - } else { - x.AlgorithmProvider = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PolicyConfigFile = "" - } else { - x.PolicyConfigFile = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableProfiling = false - } else { - x.EnableProfiling = bool(r.DecodeBool()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = float32(r.DecodeFloat(true)) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SchedulerName = "" - } else { - x.SchedulerName = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HardPodAffinitySymmetricWeight = 0 - } else { - x.HardPodAffinitySymmetricWeight = int(r.DecodeInt(codecSelferBitsize1234)) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.FailureDomains = "" - } else { - x.FailureDomains = string(r.DecodeString()) - } - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LeaderElection = LeaderElectionConfiguration{} - } else { - yyv813 := &x.LeaderElection - yyv813.CodecDecodeSelf(d) - } - for { - yyj799++ - if yyhl799 { - yyb799 = yyj799 > l - } else { - yyb799 = r.CheckBreak() - } - if yyb799 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj799-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *LeaderElectionConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym814 := z.EncBinary() - _ = yym814 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep815 := !z.EncBinary() - yy2arr815 := z.EncBasicHandle().StructToArray - var yyq815 [4]bool - _, _, _ = yysep815, yyq815, yy2arr815 - const yyr815 bool = false - var yynn815 int - if yyr815 || yy2arr815 { - r.EncodeArrayStart(4) - } else { - yynn815 = 4 - for _, b := range yyq815 { - if b { - yynn815++ - } - } - r.EncodeMapStart(yynn815) - yynn815 = 0 - } - if yyr815 || yy2arr815 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym817 := z.EncBinary() - _ = yym817 - if false { - } else { - r.EncodeBool(bool(x.LeaderElect)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("leaderElect")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym818 := z.EncBinary() - _ = yym818 - if false { - } else { - r.EncodeBool(bool(x.LeaderElect)) - } - } - if yyr815 || yy2arr815 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy820 := &x.LeaseDuration - yym821 := z.EncBinary() - _ = yym821 - if false { - } else if z.HasExtensions() && z.EncExt(yy820) { - } else if !yym821 && z.IsJSONHandle() { - z.EncJSONMarshal(yy820) - } else { - z.EncFallback(yy820) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("leaseDuration")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy822 := &x.LeaseDuration - yym823 := z.EncBinary() - _ = yym823 - if false { - } else if z.HasExtensions() && z.EncExt(yy822) { - } else if !yym823 && z.IsJSONHandle() { - z.EncJSONMarshal(yy822) - } else { - z.EncFallback(yy822) - } - } - if yyr815 || yy2arr815 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy825 := &x.RenewDeadline - yym826 := z.EncBinary() - _ = yym826 - if false { - } else if z.HasExtensions() && z.EncExt(yy825) { - } else if !yym826 && z.IsJSONHandle() { - z.EncJSONMarshal(yy825) - } else { - z.EncFallback(yy825) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("renewDeadline")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy827 := &x.RenewDeadline - yym828 := z.EncBinary() - _ = yym828 - if false { - } else if z.HasExtensions() && z.EncExt(yy827) { - } else if !yym828 && z.IsJSONHandle() { - z.EncJSONMarshal(yy827) - } else { - z.EncFallback(yy827) - } - } - if yyr815 || yy2arr815 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy830 := &x.RetryPeriod - yym831 := z.EncBinary() - _ = yym831 - if false { - } else if z.HasExtensions() && z.EncExt(yy830) { - } else if !yym831 && z.IsJSONHandle() { - z.EncJSONMarshal(yy830) - } else { - z.EncFallback(yy830) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("retryPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy832 := &x.RetryPeriod - yym833 := z.EncBinary() - _ = yym833 - if false { - } else if z.HasExtensions() && z.EncExt(yy832) { - } else if !yym833 && z.IsJSONHandle() { - z.EncJSONMarshal(yy832) - } else { - z.EncFallback(yy832) - } - } - if yyr815 || yy2arr815 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *LeaderElectionConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym834 := z.DecBinary() - _ = yym834 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct835 := r.ContainerType() - if yyct835 == codecSelferValueTypeMap1234 { - yyl835 := r.ReadMapStart() - if yyl835 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl835, d) - } - } else if yyct835 == codecSelferValueTypeArray1234 { - yyl835 := r.ReadArrayStart() - if yyl835 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl835, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *LeaderElectionConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys836Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys836Slc - var yyhl836 bool = l >= 0 - for yyj836 := 0; ; yyj836++ { - if yyhl836 { - if yyj836 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys836Slc = r.DecodeBytes(yys836Slc, true, true) - yys836 := string(yys836Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys836 { - case "leaderElect": - if r.TryDecodeAsNil() { - x.LeaderElect = false - } else { - x.LeaderElect = bool(r.DecodeBool()) - } - case "leaseDuration": - if r.TryDecodeAsNil() { - x.LeaseDuration = pkg1_unversioned.Duration{} - } else { - yyv838 := &x.LeaseDuration - yym839 := z.DecBinary() - _ = yym839 - if false { - } else if z.HasExtensions() && z.DecExt(yyv838) { - } else if !yym839 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv838) - } else { - z.DecFallback(yyv838, false) - } - } - case "renewDeadline": - if r.TryDecodeAsNil() { - x.RenewDeadline = pkg1_unversioned.Duration{} - } else { - yyv840 := &x.RenewDeadline - yym841 := z.DecBinary() - _ = yym841 - if false { - } else if z.HasExtensions() && z.DecExt(yyv840) { - } else if !yym841 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv840) - } else { - z.DecFallback(yyv840, false) - } - } - case "retryPeriod": - if r.TryDecodeAsNil() { - x.RetryPeriod = pkg1_unversioned.Duration{} - } else { - yyv842 := &x.RetryPeriod - yym843 := z.DecBinary() - _ = yym843 - if false { - } else if z.HasExtensions() && z.DecExt(yyv842) { - } else if !yym843 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv842) - } else { - z.DecFallback(yyv842, false) - } - } - default: - z.DecStructFieldNotFound(-1, yys836) - } // end switch yys836 - } // end for yyj836 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *LeaderElectionConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj844 int - var yyb844 bool - var yyhl844 bool = l >= 0 - yyj844++ - if yyhl844 { - yyb844 = yyj844 > l - } else { - yyb844 = r.CheckBreak() - } - if yyb844 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LeaderElect = false - } else { - x.LeaderElect = bool(r.DecodeBool()) - } - yyj844++ - if yyhl844 { - yyb844 = yyj844 > l - } else { - yyb844 = r.CheckBreak() - } - if yyb844 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LeaseDuration = pkg1_unversioned.Duration{} - } else { - yyv846 := &x.LeaseDuration - yym847 := z.DecBinary() - _ = yym847 - if false { - } else if z.HasExtensions() && z.DecExt(yyv846) { - } else if !yym847 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv846) - } else { - z.DecFallback(yyv846, false) - } - } - yyj844++ - if yyhl844 { - yyb844 = yyj844 > l - } else { - yyb844 = r.CheckBreak() - } - if yyb844 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RenewDeadline = pkg1_unversioned.Duration{} - } else { - yyv848 := &x.RenewDeadline - yym849 := z.DecBinary() - _ = yym849 - if false { - } else if z.HasExtensions() && z.DecExt(yyv848) { - } else if !yym849 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv848) - } else { - z.DecFallback(yyv848, false) - } - } - yyj844++ - if yyhl844 { - yyb844 = yyj844 > l - } else { - yyb844 = r.CheckBreak() - } - if yyb844 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RetryPeriod = pkg1_unversioned.Duration{} - } else { - yyv850 := &x.RetryPeriod - yym851 := z.DecBinary() - _ = yym851 - if false { - } else if z.HasExtensions() && z.DecExt(yyv850) { - } else if !yym851 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv850) - } else { - z.DecFallback(yyv850, false) - } - } - for { - yyj844++ - if yyhl844 { - yyb844 = yyj844 > l - } else { - yyb844 = r.CheckBreak() - } - if yyb844 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj844-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *KubeControllerManagerConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym852 := z.EncBinary() - _ = yym852 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep853 := !z.EncBinary() - yy2arr853 := z.EncBasicHandle().StructToArray - var yyq853 [60]bool - _, _, _ = yysep853, yyq853, yy2arr853 - const yyr853 bool = false - yyq853[0] = x.Kind != "" - yyq853[1] = x.APIVersion != "" - var yynn853 int - if yyr853 || yy2arr853 { - r.EncodeArrayStart(60) - } else { - yynn853 = 58 - for _, b := range yyq853 { - if b { - yynn853++ - } - } - r.EncodeMapStart(yynn853) - yynn853 = 0 - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq853[0] { - yym855 := z.EncBinary() - _ = yym855 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq853[0] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kind")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym856 := z.EncBinary() - _ = yym856 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Kind)) - } - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - if yyq853[1] { - yym858 := z.EncBinary() - _ = yym858 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } else { - r.EncodeString(codecSelferC_UTF81234, "") - } - } else { - if yyq853[1] { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("apiVersion")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym859 := z.EncBinary() - _ = yym859 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.APIVersion)) - } - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym861 := z.EncBinary() - _ = yym861 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("port")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym862 := z.EncBinary() - _ = yym862 - if false { - } else { - r.EncodeInt(int64(x.Port)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym864 := z.EncBinary() - _ = yym864 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("address")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym865 := z.EncBinary() - _ = yym865 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.Address)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym867 := z.EncBinary() - _ = yym867 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudProvider)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cloudProvider")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym868 := z.EncBinary() - _ = yym868 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudProvider)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym870 := z.EncBinary() - _ = yym870 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudConfigFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("cloudConfigFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym871 := z.EncBinary() - _ = yym871 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.CloudConfigFile)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym873 := z.EncBinary() - _ = yym873 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentEndpointSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentEndpointSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym874 := z.EncBinary() - _ = yym874 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentEndpointSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym876 := z.EncBinary() - _ = yym876 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentRSSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentRSSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym877 := z.EncBinary() - _ = yym877 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentRSSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym879 := z.EncBinary() - _ = yym879 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentRCSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentRCSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym880 := z.EncBinary() - _ = yym880 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentRCSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym882 := z.EncBinary() - _ = yym882 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentServiceSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentServiceSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym883 := z.EncBinary() - _ = yym883 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentServiceSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym885 := z.EncBinary() - _ = yym885 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentResourceQuotaSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentResourceQuotaSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym886 := z.EncBinary() - _ = yym886 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentResourceQuotaSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym888 := z.EncBinary() - _ = yym888 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentDeploymentSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentDeploymentSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym889 := z.EncBinary() - _ = yym889 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentDeploymentSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym891 := z.EncBinary() - _ = yym891 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentDaemonSetSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentDaemonSetSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym892 := z.EncBinary() - _ = yym892 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentDaemonSetSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym894 := z.EncBinary() - _ = yym894 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentJobSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentJobSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym895 := z.EncBinary() - _ = yym895 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentJobSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym897 := z.EncBinary() - _ = yym897 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentNamespaceSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentNamespaceSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym898 := z.EncBinary() - _ = yym898 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentNamespaceSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym900 := z.EncBinary() - _ = yym900 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentSATokenSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentSATokenSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym901 := z.EncBinary() - _ = yym901 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentSATokenSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym903 := z.EncBinary() - _ = yym903 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForRC)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lookupCacheSizeForRC")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym904 := z.EncBinary() - _ = yym904 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForRC)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym906 := z.EncBinary() - _ = yym906 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForRS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lookupCacheSizeForRS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym907 := z.EncBinary() - _ = yym907 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForRS)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym909 := z.EncBinary() - _ = yym909 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForDaemonSet)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("lookupCacheSizeForDaemonSet")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym910 := z.EncBinary() - _ = yym910 - if false { - } else { - r.EncodeInt(int64(x.LookupCacheSizeForDaemonSet)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy912 := &x.ServiceSyncPeriod - yym913 := z.EncBinary() - _ = yym913 - if false { - } else if z.HasExtensions() && z.EncExt(yy912) { - } else if !yym913 && z.IsJSONHandle() { - z.EncJSONMarshal(yy912) - } else { - z.EncFallback(yy912) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("serviceSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy914 := &x.ServiceSyncPeriod - yym915 := z.EncBinary() - _ = yym915 - if false { - } else if z.HasExtensions() && z.EncExt(yy914) { - } else if !yym915 && z.IsJSONHandle() { - z.EncJSONMarshal(yy914) - } else { - z.EncFallback(yy914) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy917 := &x.NodeSyncPeriod - yym918 := z.EncBinary() - _ = yym918 - if false { - } else if z.HasExtensions() && z.EncExt(yy917) { - } else if !yym918 && z.IsJSONHandle() { - z.EncJSONMarshal(yy917) - } else { - z.EncFallback(yy917) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy919 := &x.NodeSyncPeriod - yym920 := z.EncBinary() - _ = yym920 - if false { - } else if z.HasExtensions() && z.EncExt(yy919) { - } else if !yym920 && z.IsJSONHandle() { - z.EncJSONMarshal(yy919) - } else { - z.EncFallback(yy919) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy922 := &x.RouteReconciliationPeriod - yym923 := z.EncBinary() - _ = yym923 - if false { - } else if z.HasExtensions() && z.EncExt(yy922) { - } else if !yym923 && z.IsJSONHandle() { - z.EncJSONMarshal(yy922) - } else { - z.EncFallback(yy922) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("routeReconciliationPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy924 := &x.RouteReconciliationPeriod - yym925 := z.EncBinary() - _ = yym925 - if false { - } else if z.HasExtensions() && z.EncExt(yy924) { - } else if !yym925 && z.IsJSONHandle() { - z.EncJSONMarshal(yy924) - } else { - z.EncFallback(yy924) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy927 := &x.ResourceQuotaSyncPeriod - yym928 := z.EncBinary() - _ = yym928 - if false { - } else if z.HasExtensions() && z.EncExt(yy927) { - } else if !yym928 && z.IsJSONHandle() { - z.EncJSONMarshal(yy927) - } else { - z.EncFallback(yy927) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("resourceQuotaSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy929 := &x.ResourceQuotaSyncPeriod - yym930 := z.EncBinary() - _ = yym930 - if false { - } else if z.HasExtensions() && z.EncExt(yy929) { - } else if !yym930 && z.IsJSONHandle() { - z.EncJSONMarshal(yy929) - } else { - z.EncFallback(yy929) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy932 := &x.NamespaceSyncPeriod - yym933 := z.EncBinary() - _ = yym933 - if false { - } else if z.HasExtensions() && z.EncExt(yy932) { - } else if !yym933 && z.IsJSONHandle() { - z.EncJSONMarshal(yy932) - } else { - z.EncFallback(yy932) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("namespaceSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy934 := &x.NamespaceSyncPeriod - yym935 := z.EncBinary() - _ = yym935 - if false { - } else if z.HasExtensions() && z.EncExt(yy934) { - } else if !yym935 && z.IsJSONHandle() { - z.EncJSONMarshal(yy934) - } else { - z.EncFallback(yy934) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy937 := &x.PVClaimBinderSyncPeriod - yym938 := z.EncBinary() - _ = yym938 - if false { - } else if z.HasExtensions() && z.EncExt(yy937) { - } else if !yym938 && z.IsJSONHandle() { - z.EncJSONMarshal(yy937) - } else { - z.EncFallback(yy937) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("pvClaimBinderSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy939 := &x.PVClaimBinderSyncPeriod - yym940 := z.EncBinary() - _ = yym940 - if false { - } else if z.HasExtensions() && z.EncExt(yy939) { - } else if !yym940 && z.IsJSONHandle() { - z.EncJSONMarshal(yy939) - } else { - z.EncFallback(yy939) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy942 := &x.MinResyncPeriod - yym943 := z.EncBinary() - _ = yym943 - if false { - } else if z.HasExtensions() && z.EncExt(yy942) { - } else if !yym943 && z.IsJSONHandle() { - z.EncJSONMarshal(yy942) - } else { - z.EncFallback(yy942) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minResyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy944 := &x.MinResyncPeriod - yym945 := z.EncBinary() - _ = yym945 - if false { - } else if z.HasExtensions() && z.EncExt(yy944) { - } else if !yym945 && z.IsJSONHandle() { - z.EncJSONMarshal(yy944) - } else { - z.EncFallback(yy944) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym947 := z.EncBinary() - _ = yym947 - if false { - } else { - r.EncodeInt(int64(x.TerminatedPodGCThreshold)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("terminatedPodGCThreshold")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym948 := z.EncBinary() - _ = yym948 - if false { - } else { - r.EncodeInt(int64(x.TerminatedPodGCThreshold)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy950 := &x.HorizontalPodAutoscalerSyncPeriod - yym951 := z.EncBinary() - _ = yym951 - if false { - } else if z.HasExtensions() && z.EncExt(yy950) { - } else if !yym951 && z.IsJSONHandle() { - z.EncJSONMarshal(yy950) - } else { - z.EncFallback(yy950) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("horizontalPodAutoscalerSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy952 := &x.HorizontalPodAutoscalerSyncPeriod - yym953 := z.EncBinary() - _ = yym953 - if false { - } else if z.HasExtensions() && z.EncExt(yy952) { - } else if !yym953 && z.IsJSONHandle() { - z.EncJSONMarshal(yy952) - } else { - z.EncFallback(yy952) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy955 := &x.DeploymentControllerSyncPeriod - yym956 := z.EncBinary() - _ = yym956 - if false { - } else if z.HasExtensions() && z.EncExt(yy955) { - } else if !yym956 && z.IsJSONHandle() { - z.EncJSONMarshal(yy955) - } else { - z.EncFallback(yy955) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("deploymentControllerSyncPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy957 := &x.DeploymentControllerSyncPeriod - yym958 := z.EncBinary() - _ = yym958 - if false { - } else if z.HasExtensions() && z.EncExt(yy957) { - } else if !yym958 && z.IsJSONHandle() { - z.EncJSONMarshal(yy957) - } else { - z.EncFallback(yy957) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy960 := &x.PodEvictionTimeout - yym961 := z.EncBinary() - _ = yym961 - if false { - } else if z.HasExtensions() && z.EncExt(yy960) { - } else if !yym961 && z.IsJSONHandle() { - z.EncJSONMarshal(yy960) - } else { - z.EncFallback(yy960) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podEvictionTimeout")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy962 := &x.PodEvictionTimeout - yym963 := z.EncBinary() - _ = yym963 - if false { - } else if z.HasExtensions() && z.EncExt(yy962) { - } else if !yym963 && z.IsJSONHandle() { - z.EncJSONMarshal(yy962) - } else { - z.EncFallback(yy962) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym965 := z.EncBinary() - _ = yym965 - if false { - } else { - r.EncodeFloat32(float32(x.DeletingPodsQps)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("deletingPodsQps")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym966 := z.EncBinary() - _ = yym966 - if false { - } else { - r.EncodeFloat32(float32(x.DeletingPodsQps)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym968 := z.EncBinary() - _ = yym968 - if false { - } else { - r.EncodeInt(int64(x.DeletingPodsBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("deletingPodsBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym969 := z.EncBinary() - _ = yym969 - if false { - } else { - r.EncodeInt(int64(x.DeletingPodsBurst)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy971 := &x.NodeMonitorGracePeriod - yym972 := z.EncBinary() - _ = yym972 - if false { - } else if z.HasExtensions() && z.EncExt(yy971) { - } else if !yym972 && z.IsJSONHandle() { - z.EncJSONMarshal(yy971) - } else { - z.EncFallback(yy971) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeMonitorGracePeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy973 := &x.NodeMonitorGracePeriod - yym974 := z.EncBinary() - _ = yym974 - if false { - } else if z.HasExtensions() && z.EncExt(yy973) { - } else if !yym974 && z.IsJSONHandle() { - z.EncJSONMarshal(yy973) - } else { - z.EncFallback(yy973) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym976 := z.EncBinary() - _ = yym976 - if false { - } else { - r.EncodeInt(int64(x.RegisterRetryCount)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("registerRetryCount")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym977 := z.EncBinary() - _ = yym977 - if false { - } else { - r.EncodeInt(int64(x.RegisterRetryCount)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy979 := &x.NodeStartupGracePeriod - yym980 := z.EncBinary() - _ = yym980 - if false { - } else if z.HasExtensions() && z.EncExt(yy979) { - } else if !yym980 && z.IsJSONHandle() { - z.EncJSONMarshal(yy979) - } else { - z.EncFallback(yy979) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeStartupGracePeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy981 := &x.NodeStartupGracePeriod - yym982 := z.EncBinary() - _ = yym982 - if false { - } else if z.HasExtensions() && z.EncExt(yy981) { - } else if !yym982 && z.IsJSONHandle() { - z.EncJSONMarshal(yy981) - } else { - z.EncFallback(yy981) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy984 := &x.NodeMonitorPeriod - yym985 := z.EncBinary() - _ = yym985 - if false { - } else if z.HasExtensions() && z.EncExt(yy984) { - } else if !yym985 && z.IsJSONHandle() { - z.EncJSONMarshal(yy984) - } else { - z.EncFallback(yy984) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeMonitorPeriod")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy986 := &x.NodeMonitorPeriod - yym987 := z.EncBinary() - _ = yym987 - if false { - } else if z.HasExtensions() && z.EncExt(yy986) { - } else if !yym987 && z.IsJSONHandle() { - z.EncJSONMarshal(yy986) - } else { - z.EncFallback(yy986) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym989 := z.EncBinary() - _ = yym989 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceAccountKeyFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("serviceAccountKeyFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym990 := z.EncBinary() - _ = yym990 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceAccountKeyFile)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym992 := z.EncBinary() - _ = yym992 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterSigningCertFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterSigningCertFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym993 := z.EncBinary() - _ = yym993 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterSigningCertFile)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym995 := z.EncBinary() - _ = yym995 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterSigningKeyFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterSigningKeyFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym996 := z.EncBinary() - _ = yym996 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterSigningKeyFile)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym998 := z.EncBinary() - _ = yym998 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ApproveAllKubeletCSRsForGroup)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("approveAllKubeletCSRsForGroup")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym999 := z.EncBinary() - _ = yym999 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ApproveAllKubeletCSRsForGroup)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1001 := z.EncBinary() - _ = yym1001 - if false { - } else { - r.EncodeBool(bool(x.EnableProfiling)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableProfiling")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1002 := z.EncBinary() - _ = yym1002 - if false { - } else { - r.EncodeBool(bool(x.EnableProfiling)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1004 := z.EncBinary() - _ = yym1004 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterName)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterName")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1005 := z.EncBinary() - _ = yym1005 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterName)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1007 := z.EncBinary() - _ = yym1007 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("clusterCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1008 := z.EncBinary() - _ = yym1008 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ClusterCIDR)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1010 := z.EncBinary() - _ = yym1010 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceCIDR)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("serviceCIDR")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1011 := z.EncBinary() - _ = yym1011 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ServiceCIDR)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1013 := z.EncBinary() - _ = yym1013 - if false { - } else { - r.EncodeInt(int64(x.NodeCIDRMaskSize)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeCIDRMaskSize")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1014 := z.EncBinary() - _ = yym1014 - if false { - } else { - r.EncodeInt(int64(x.NodeCIDRMaskSize)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1016 := z.EncBinary() - _ = yym1016 - if false { - } else { - r.EncodeBool(bool(x.AllocateNodeCIDRs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("allocateNodeCIDRs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1017 := z.EncBinary() - _ = yym1017 - if false { - } else { - r.EncodeBool(bool(x.AllocateNodeCIDRs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1019 := z.EncBinary() - _ = yym1019 - if false { - } else { - r.EncodeBool(bool(x.ConfigureCloudRoutes)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("configureCloudRoutes")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1020 := z.EncBinary() - _ = yym1020 - if false { - } else { - r.EncodeBool(bool(x.ConfigureCloudRoutes)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1022 := z.EncBinary() - _ = yym1022 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RootCAFile)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("rootCAFile")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1023 := z.EncBinary() - _ = yym1023 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.RootCAFile)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1025 := z.EncBinary() - _ = yym1025 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("contentType")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1026 := z.EncBinary() - _ = yym1026 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.ContentType)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1028 := z.EncBinary() - _ = yym1028 - if false { - } else { - r.EncodeFloat32(float32(x.KubeAPIQPS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIQPS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1029 := z.EncBinary() - _ = yym1029 - if false { - } else { - r.EncodeFloat32(float32(x.KubeAPIQPS)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1031 := z.EncBinary() - _ = yym1031 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("kubeAPIBurst")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1032 := z.EncBinary() - _ = yym1032 - if false { - } else { - r.EncodeInt(int64(x.KubeAPIBurst)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1034 := &x.LeaderElection - yy1034.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("leaderElection")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1035 := &x.LeaderElection - yy1035.CodecEncodeSelf(e) - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1037 := &x.VolumeConfiguration - yy1037.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("volumeConfiguration")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1038 := &x.VolumeConfiguration - yy1038.CodecEncodeSelf(e) - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1040 := &x.ControllerStartInterval - yym1041 := z.EncBinary() - _ = yym1041 - if false { - } else if z.HasExtensions() && z.EncExt(yy1040) { - } else if !yym1041 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1040) - } else { - z.EncFallback(yy1040) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("controllerStartInterval")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1042 := &x.ControllerStartInterval - yym1043 := z.EncBinary() - _ = yym1043 - if false { - } else if z.HasExtensions() && z.EncExt(yy1042) { - } else if !yym1043 && z.IsJSONHandle() { - z.EncJSONMarshal(yy1042) - } else { - z.EncFallback(yy1042) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1045 := z.EncBinary() - _ = yym1045 - if false { - } else { - r.EncodeBool(bool(x.EnableGarbageCollector)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableGarbageCollector")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1046 := z.EncBinary() - _ = yym1046 - if false { - } else { - r.EncodeBool(bool(x.EnableGarbageCollector)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1048 := z.EncBinary() - _ = yym1048 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentGCSyncs)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("concurrentGCSyncs")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1049 := z.EncBinary() - _ = yym1049 - if false { - } else { - r.EncodeInt(int64(x.ConcurrentGCSyncs)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1051 := z.EncBinary() - _ = yym1051 - if false { - } else { - r.EncodeFloat32(float32(x.NodeEvictionRate)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("nodeEvictionRate")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1052 := z.EncBinary() - _ = yym1052 - if false { - } else { - r.EncodeFloat32(float32(x.NodeEvictionRate)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1054 := z.EncBinary() - _ = yym1054 - if false { - } else { - r.EncodeFloat32(float32(x.SecondaryNodeEvictionRate)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("secondaryNodeEvictionRate")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1055 := z.EncBinary() - _ = yym1055 - if false { - } else { - r.EncodeFloat32(float32(x.SecondaryNodeEvictionRate)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1057 := z.EncBinary() - _ = yym1057 - if false { - } else { - r.EncodeInt(int64(x.LargeClusterSizeThreshold)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("largeClusterSizeThreshold")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1058 := z.EncBinary() - _ = yym1058 - if false { - } else { - r.EncodeInt(int64(x.LargeClusterSizeThreshold)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1060 := z.EncBinary() - _ = yym1060 - if false { - } else { - r.EncodeFloat32(float32(x.UnhealthyZoneThreshold)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("unhealthyZoneThreshold")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1061 := z.EncBinary() - _ = yym1061 - if false { - } else { - r.EncodeFloat32(float32(x.UnhealthyZoneThreshold)) - } - } - if yyr853 || yy2arr853 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *KubeControllerManagerConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1062 := z.DecBinary() - _ = yym1062 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1063 := r.ContainerType() - if yyct1063 == codecSelferValueTypeMap1234 { - yyl1063 := r.ReadMapStart() - if yyl1063 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1063, d) - } - } else if yyct1063 == codecSelferValueTypeArray1234 { - yyl1063 := r.ReadArrayStart() - if yyl1063 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1063, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *KubeControllerManagerConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1064Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1064Slc - var yyhl1064 bool = l >= 0 - for yyj1064 := 0; ; yyj1064++ { - if yyhl1064 { - if yyj1064 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1064Slc = r.DecodeBytes(yys1064Slc, true, true) - yys1064 := string(yys1064Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1064 { - case "kind": - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - case "apiVersion": - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - case "port": - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - case "address": - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - case "cloudProvider": - if r.TryDecodeAsNil() { - x.CloudProvider = "" - } else { - x.CloudProvider = string(r.DecodeString()) - } - case "cloudConfigFile": - if r.TryDecodeAsNil() { - x.CloudConfigFile = "" - } else { - x.CloudConfigFile = string(r.DecodeString()) - } - case "concurrentEndpointSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentEndpointSyncs = 0 - } else { - x.ConcurrentEndpointSyncs = int32(r.DecodeInt(32)) - } - case "concurrentRSSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentRSSyncs = 0 - } else { - x.ConcurrentRSSyncs = int32(r.DecodeInt(32)) - } - case "concurrentRCSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentRCSyncs = 0 - } else { - x.ConcurrentRCSyncs = int32(r.DecodeInt(32)) - } - case "concurrentServiceSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentServiceSyncs = 0 - } else { - x.ConcurrentServiceSyncs = int32(r.DecodeInt(32)) - } - case "concurrentResourceQuotaSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentResourceQuotaSyncs = 0 - } else { - x.ConcurrentResourceQuotaSyncs = int32(r.DecodeInt(32)) - } - case "concurrentDeploymentSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentDeploymentSyncs = 0 - } else { - x.ConcurrentDeploymentSyncs = int32(r.DecodeInt(32)) - } - case "concurrentDaemonSetSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentDaemonSetSyncs = 0 - } else { - x.ConcurrentDaemonSetSyncs = int32(r.DecodeInt(32)) - } - case "concurrentJobSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentJobSyncs = 0 - } else { - x.ConcurrentJobSyncs = int32(r.DecodeInt(32)) - } - case "concurrentNamespaceSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentNamespaceSyncs = 0 - } else { - x.ConcurrentNamespaceSyncs = int32(r.DecodeInt(32)) - } - case "concurrentSATokenSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentSATokenSyncs = 0 - } else { - x.ConcurrentSATokenSyncs = int32(r.DecodeInt(32)) - } - case "lookupCacheSizeForRC": - if r.TryDecodeAsNil() { - x.LookupCacheSizeForRC = 0 - } else { - x.LookupCacheSizeForRC = int32(r.DecodeInt(32)) - } - case "lookupCacheSizeForRS": - if r.TryDecodeAsNil() { - x.LookupCacheSizeForRS = 0 - } else { - x.LookupCacheSizeForRS = int32(r.DecodeInt(32)) - } - case "lookupCacheSizeForDaemonSet": - if r.TryDecodeAsNil() { - x.LookupCacheSizeForDaemonSet = 0 - } else { - x.LookupCacheSizeForDaemonSet = int32(r.DecodeInt(32)) - } - case "serviceSyncPeriod": - if r.TryDecodeAsNil() { - x.ServiceSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1084 := &x.ServiceSyncPeriod - yym1085 := z.DecBinary() - _ = yym1085 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1084) { - } else if !yym1085 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1084) - } else { - z.DecFallback(yyv1084, false) - } - } - case "nodeSyncPeriod": - if r.TryDecodeAsNil() { - x.NodeSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1086 := &x.NodeSyncPeriod - yym1087 := z.DecBinary() - _ = yym1087 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1086) { - } else if !yym1087 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1086) - } else { - z.DecFallback(yyv1086, false) - } - } - case "routeReconciliationPeriod": - if r.TryDecodeAsNil() { - x.RouteReconciliationPeriod = pkg1_unversioned.Duration{} - } else { - yyv1088 := &x.RouteReconciliationPeriod - yym1089 := z.DecBinary() - _ = yym1089 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1088) { - } else if !yym1089 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1088) - } else { - z.DecFallback(yyv1088, false) - } - } - case "resourceQuotaSyncPeriod": - if r.TryDecodeAsNil() { - x.ResourceQuotaSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1090 := &x.ResourceQuotaSyncPeriod - yym1091 := z.DecBinary() - _ = yym1091 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1090) { - } else if !yym1091 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1090) - } else { - z.DecFallback(yyv1090, false) - } - } - case "namespaceSyncPeriod": - if r.TryDecodeAsNil() { - x.NamespaceSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1092 := &x.NamespaceSyncPeriod - yym1093 := z.DecBinary() - _ = yym1093 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1092) { - } else if !yym1093 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1092) - } else { - z.DecFallback(yyv1092, false) - } - } - case "pvClaimBinderSyncPeriod": - if r.TryDecodeAsNil() { - x.PVClaimBinderSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1094 := &x.PVClaimBinderSyncPeriod - yym1095 := z.DecBinary() - _ = yym1095 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1094) { - } else if !yym1095 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1094) - } else { - z.DecFallback(yyv1094, false) - } - } - case "minResyncPeriod": - if r.TryDecodeAsNil() { - x.MinResyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1096 := &x.MinResyncPeriod - yym1097 := z.DecBinary() - _ = yym1097 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1096) { - } else if !yym1097 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1096) - } else { - z.DecFallback(yyv1096, false) - } - } - case "terminatedPodGCThreshold": - if r.TryDecodeAsNil() { - x.TerminatedPodGCThreshold = 0 - } else { - x.TerminatedPodGCThreshold = int32(r.DecodeInt(32)) - } - case "horizontalPodAutoscalerSyncPeriod": - if r.TryDecodeAsNil() { - x.HorizontalPodAutoscalerSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1099 := &x.HorizontalPodAutoscalerSyncPeriod - yym1100 := z.DecBinary() - _ = yym1100 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1099) { - } else if !yym1100 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1099) - } else { - z.DecFallback(yyv1099, false) - } - } - case "deploymentControllerSyncPeriod": - if r.TryDecodeAsNil() { - x.DeploymentControllerSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1101 := &x.DeploymentControllerSyncPeriod - yym1102 := z.DecBinary() - _ = yym1102 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1101) { - } else if !yym1102 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1101) - } else { - z.DecFallback(yyv1101, false) - } - } - case "podEvictionTimeout": - if r.TryDecodeAsNil() { - x.PodEvictionTimeout = pkg1_unversioned.Duration{} - } else { - yyv1103 := &x.PodEvictionTimeout - yym1104 := z.DecBinary() - _ = yym1104 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1103) { - } else if !yym1104 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1103) - } else { - z.DecFallback(yyv1103, false) - } - } - case "deletingPodsQps": - if r.TryDecodeAsNil() { - x.DeletingPodsQps = 0 - } else { - x.DeletingPodsQps = float32(r.DecodeFloat(true)) - } - case "deletingPodsBurst": - if r.TryDecodeAsNil() { - x.DeletingPodsBurst = 0 - } else { - x.DeletingPodsBurst = int32(r.DecodeInt(32)) - } - case "nodeMonitorGracePeriod": - if r.TryDecodeAsNil() { - x.NodeMonitorGracePeriod = pkg1_unversioned.Duration{} - } else { - yyv1107 := &x.NodeMonitorGracePeriod - yym1108 := z.DecBinary() - _ = yym1108 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1107) { - } else if !yym1108 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1107) - } else { - z.DecFallback(yyv1107, false) - } - } - case "registerRetryCount": - if r.TryDecodeAsNil() { - x.RegisterRetryCount = 0 - } else { - x.RegisterRetryCount = int32(r.DecodeInt(32)) - } - case "nodeStartupGracePeriod": - if r.TryDecodeAsNil() { - x.NodeStartupGracePeriod = pkg1_unversioned.Duration{} - } else { - yyv1110 := &x.NodeStartupGracePeriod - yym1111 := z.DecBinary() - _ = yym1111 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1110) { - } else if !yym1111 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1110) - } else { - z.DecFallback(yyv1110, false) - } - } - case "nodeMonitorPeriod": - if r.TryDecodeAsNil() { - x.NodeMonitorPeriod = pkg1_unversioned.Duration{} - } else { - yyv1112 := &x.NodeMonitorPeriod - yym1113 := z.DecBinary() - _ = yym1113 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1112) { - } else if !yym1113 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1112) - } else { - z.DecFallback(yyv1112, false) - } - } - case "serviceAccountKeyFile": - if r.TryDecodeAsNil() { - x.ServiceAccountKeyFile = "" - } else { - x.ServiceAccountKeyFile = string(r.DecodeString()) - } - case "clusterSigningCertFile": - if r.TryDecodeAsNil() { - x.ClusterSigningCertFile = "" - } else { - x.ClusterSigningCertFile = string(r.DecodeString()) - } - case "clusterSigningKeyFile": - if r.TryDecodeAsNil() { - x.ClusterSigningKeyFile = "" - } else { - x.ClusterSigningKeyFile = string(r.DecodeString()) - } - case "approveAllKubeletCSRsForGroup": - if r.TryDecodeAsNil() { - x.ApproveAllKubeletCSRsForGroup = "" - } else { - x.ApproveAllKubeletCSRsForGroup = string(r.DecodeString()) - } - case "enableProfiling": - if r.TryDecodeAsNil() { - x.EnableProfiling = false - } else { - x.EnableProfiling = bool(r.DecodeBool()) - } - case "clusterName": - if r.TryDecodeAsNil() { - x.ClusterName = "" - } else { - x.ClusterName = string(r.DecodeString()) - } - case "clusterCIDR": - if r.TryDecodeAsNil() { - x.ClusterCIDR = "" - } else { - x.ClusterCIDR = string(r.DecodeString()) - } - case "serviceCIDR": - if r.TryDecodeAsNil() { - x.ServiceCIDR = "" - } else { - x.ServiceCIDR = string(r.DecodeString()) - } - case "nodeCIDRMaskSize": - if r.TryDecodeAsNil() { - x.NodeCIDRMaskSize = 0 - } else { - x.NodeCIDRMaskSize = int32(r.DecodeInt(32)) - } - case "allocateNodeCIDRs": - if r.TryDecodeAsNil() { - x.AllocateNodeCIDRs = false - } else { - x.AllocateNodeCIDRs = bool(r.DecodeBool()) - } - case "configureCloudRoutes": - if r.TryDecodeAsNil() { - x.ConfigureCloudRoutes = false - } else { - x.ConfigureCloudRoutes = bool(r.DecodeBool()) - } - case "rootCAFile": - if r.TryDecodeAsNil() { - x.RootCAFile = "" - } else { - x.RootCAFile = string(r.DecodeString()) - } - case "contentType": - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - case "kubeAPIQPS": - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = float32(r.DecodeFloat(true)) - } - case "kubeAPIBurst": - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - case "leaderElection": - if r.TryDecodeAsNil() { - x.LeaderElection = LeaderElectionConfiguration{} - } else { - yyv1129 := &x.LeaderElection - yyv1129.CodecDecodeSelf(d) - } - case "volumeConfiguration": - if r.TryDecodeAsNil() { - x.VolumeConfiguration = VolumeConfiguration{} - } else { - yyv1130 := &x.VolumeConfiguration - yyv1130.CodecDecodeSelf(d) - } - case "controllerStartInterval": - if r.TryDecodeAsNil() { - x.ControllerStartInterval = pkg1_unversioned.Duration{} - } else { - yyv1131 := &x.ControllerStartInterval - yym1132 := z.DecBinary() - _ = yym1132 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1131) { - } else if !yym1132 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1131) - } else { - z.DecFallback(yyv1131, false) - } - } - case "enableGarbageCollector": - if r.TryDecodeAsNil() { - x.EnableGarbageCollector = false - } else { - x.EnableGarbageCollector = bool(r.DecodeBool()) - } - case "concurrentGCSyncs": - if r.TryDecodeAsNil() { - x.ConcurrentGCSyncs = 0 - } else { - x.ConcurrentGCSyncs = int32(r.DecodeInt(32)) - } - case "nodeEvictionRate": - if r.TryDecodeAsNil() { - x.NodeEvictionRate = 0 - } else { - x.NodeEvictionRate = float32(r.DecodeFloat(true)) - } - case "secondaryNodeEvictionRate": - if r.TryDecodeAsNil() { - x.SecondaryNodeEvictionRate = 0 - } else { - x.SecondaryNodeEvictionRate = float32(r.DecodeFloat(true)) - } - case "largeClusterSizeThreshold": - if r.TryDecodeAsNil() { - x.LargeClusterSizeThreshold = 0 - } else { - x.LargeClusterSizeThreshold = int32(r.DecodeInt(32)) - } - case "unhealthyZoneThreshold": - if r.TryDecodeAsNil() { - x.UnhealthyZoneThreshold = 0 - } else { - x.UnhealthyZoneThreshold = float32(r.DecodeFloat(true)) - } - default: - z.DecStructFieldNotFound(-1, yys1064) - } // end switch yys1064 - } // end for yyj1064 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *KubeControllerManagerConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1139 int - var yyb1139 bool - var yyhl1139 bool = l >= 0 - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Kind = "" - } else { - x.Kind = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.APIVersion = "" - } else { - x.APIVersion = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Port = 0 - } else { - x.Port = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.Address = "" - } else { - x.Address = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CloudProvider = "" - } else { - x.CloudProvider = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.CloudConfigFile = "" - } else { - x.CloudConfigFile = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentEndpointSyncs = 0 - } else { - x.ConcurrentEndpointSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentRSSyncs = 0 - } else { - x.ConcurrentRSSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentRCSyncs = 0 - } else { - x.ConcurrentRCSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentServiceSyncs = 0 - } else { - x.ConcurrentServiceSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentResourceQuotaSyncs = 0 - } else { - x.ConcurrentResourceQuotaSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentDeploymentSyncs = 0 - } else { - x.ConcurrentDeploymentSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentDaemonSetSyncs = 0 - } else { - x.ConcurrentDaemonSetSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentJobSyncs = 0 - } else { - x.ConcurrentJobSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentNamespaceSyncs = 0 - } else { - x.ConcurrentNamespaceSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentSATokenSyncs = 0 - } else { - x.ConcurrentSATokenSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LookupCacheSizeForRC = 0 - } else { - x.LookupCacheSizeForRC = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LookupCacheSizeForRS = 0 - } else { - x.LookupCacheSizeForRS = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LookupCacheSizeForDaemonSet = 0 - } else { - x.LookupCacheSizeForDaemonSet = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServiceSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1159 := &x.ServiceSyncPeriod - yym1160 := z.DecBinary() - _ = yym1160 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1159) { - } else if !yym1160 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1159) - } else { - z.DecFallback(yyv1159, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1161 := &x.NodeSyncPeriod - yym1162 := z.DecBinary() - _ = yym1162 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1161) { - } else if !yym1162 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1161) - } else { - z.DecFallback(yyv1161, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RouteReconciliationPeriod = pkg1_unversioned.Duration{} - } else { - yyv1163 := &x.RouteReconciliationPeriod - yym1164 := z.DecBinary() - _ = yym1164 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1163) { - } else if !yym1164 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1163) - } else { - z.DecFallback(yyv1163, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ResourceQuotaSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1165 := &x.ResourceQuotaSyncPeriod - yym1166 := z.DecBinary() - _ = yym1166 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1165) { - } else if !yym1166 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1165) - } else { - z.DecFallback(yyv1165, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NamespaceSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1167 := &x.NamespaceSyncPeriod - yym1168 := z.DecBinary() - _ = yym1168 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1167) { - } else if !yym1168 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1167) - } else { - z.DecFallback(yyv1167, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PVClaimBinderSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1169 := &x.PVClaimBinderSyncPeriod - yym1170 := z.DecBinary() - _ = yym1170 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1169) { - } else if !yym1170 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1169) - } else { - z.DecFallback(yyv1169, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MinResyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1171 := &x.MinResyncPeriod - yym1172 := z.DecBinary() - _ = yym1172 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1171) { - } else if !yym1172 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1171) - } else { - z.DecFallback(yyv1171, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.TerminatedPodGCThreshold = 0 - } else { - x.TerminatedPodGCThreshold = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.HorizontalPodAutoscalerSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1174 := &x.HorizontalPodAutoscalerSyncPeriod - yym1175 := z.DecBinary() - _ = yym1175 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1174) { - } else if !yym1175 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1174) - } else { - z.DecFallback(yyv1174, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.DeploymentControllerSyncPeriod = pkg1_unversioned.Duration{} - } else { - yyv1176 := &x.DeploymentControllerSyncPeriod - yym1177 := z.DecBinary() - _ = yym1177 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1176) { - } else if !yym1177 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1176) - } else { - z.DecFallback(yyv1176, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodEvictionTimeout = pkg1_unversioned.Duration{} - } else { - yyv1178 := &x.PodEvictionTimeout - yym1179 := z.DecBinary() - _ = yym1179 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1178) { - } else if !yym1179 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1178) - } else { - z.DecFallback(yyv1178, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.DeletingPodsQps = 0 - } else { - x.DeletingPodsQps = float32(r.DecodeFloat(true)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.DeletingPodsBurst = 0 - } else { - x.DeletingPodsBurst = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeMonitorGracePeriod = pkg1_unversioned.Duration{} - } else { - yyv1182 := &x.NodeMonitorGracePeriod - yym1183 := z.DecBinary() - _ = yym1183 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1182) { - } else if !yym1183 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1182) - } else { - z.DecFallback(yyv1182, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RegisterRetryCount = 0 - } else { - x.RegisterRetryCount = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeStartupGracePeriod = pkg1_unversioned.Duration{} - } else { - yyv1185 := &x.NodeStartupGracePeriod - yym1186 := z.DecBinary() - _ = yym1186 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1185) { - } else if !yym1186 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1185) - } else { - z.DecFallback(yyv1185, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeMonitorPeriod = pkg1_unversioned.Duration{} - } else { - yyv1187 := &x.NodeMonitorPeriod - yym1188 := z.DecBinary() - _ = yym1188 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1187) { - } else if !yym1188 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1187) - } else { - z.DecFallback(yyv1187, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServiceAccountKeyFile = "" - } else { - x.ServiceAccountKeyFile = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterSigningCertFile = "" - } else { - x.ClusterSigningCertFile = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterSigningKeyFile = "" - } else { - x.ClusterSigningKeyFile = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ApproveAllKubeletCSRsForGroup = "" - } else { - x.ApproveAllKubeletCSRsForGroup = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableProfiling = false - } else { - x.EnableProfiling = bool(r.DecodeBool()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterName = "" - } else { - x.ClusterName = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ClusterCIDR = "" - } else { - x.ClusterCIDR = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ServiceCIDR = "" - } else { - x.ServiceCIDR = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeCIDRMaskSize = 0 - } else { - x.NodeCIDRMaskSize = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.AllocateNodeCIDRs = false - } else { - x.AllocateNodeCIDRs = bool(r.DecodeBool()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConfigureCloudRoutes = false - } else { - x.ConfigureCloudRoutes = bool(r.DecodeBool()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.RootCAFile = "" - } else { - x.RootCAFile = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ContentType = "" - } else { - x.ContentType = string(r.DecodeString()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIQPS = 0 - } else { - x.KubeAPIQPS = float32(r.DecodeFloat(true)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.KubeAPIBurst = 0 - } else { - x.KubeAPIBurst = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LeaderElection = LeaderElectionConfiguration{} - } else { - yyv1204 := &x.LeaderElection - yyv1204.CodecDecodeSelf(d) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.VolumeConfiguration = VolumeConfiguration{} - } else { - yyv1205 := &x.VolumeConfiguration - yyv1205.CodecDecodeSelf(d) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ControllerStartInterval = pkg1_unversioned.Duration{} - } else { - yyv1206 := &x.ControllerStartInterval - yym1207 := z.DecBinary() - _ = yym1207 - if false { - } else if z.HasExtensions() && z.DecExt(yyv1206) { - } else if !yym1207 && z.IsJSONHandle() { - z.DecJSONUnmarshal(yyv1206) - } else { - z.DecFallback(yyv1206, false) - } - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableGarbageCollector = false - } else { - x.EnableGarbageCollector = bool(r.DecodeBool()) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.ConcurrentGCSyncs = 0 - } else { - x.ConcurrentGCSyncs = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.NodeEvictionRate = 0 - } else { - x.NodeEvictionRate = float32(r.DecodeFloat(true)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.SecondaryNodeEvictionRate = 0 - } else { - x.SecondaryNodeEvictionRate = float32(r.DecodeFloat(true)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.LargeClusterSizeThreshold = 0 - } else { - x.LargeClusterSizeThreshold = int32(r.DecodeInt(32)) - } - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.UnhealthyZoneThreshold = 0 - } else { - x.UnhealthyZoneThreshold = float32(r.DecodeFloat(true)) - } - for { - yyj1139++ - if yyhl1139 { - yyb1139 = yyj1139 > l - } else { - yyb1139 = r.CheckBreak() - } - if yyb1139 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1139-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *VolumeConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1214 := z.EncBinary() - _ = yym1214 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1215 := !z.EncBinary() - yy2arr1215 := z.EncBasicHandle().StructToArray - var yyq1215 [4]bool - _, _, _ = yysep1215, yyq1215, yy2arr1215 - const yyr1215 bool = false - var yynn1215 int - if yyr1215 || yy2arr1215 { - r.EncodeArrayStart(4) - } else { - yynn1215 = 4 - for _, b := range yyq1215 { - if b { - yynn1215++ - } - } - r.EncodeMapStart(yynn1215) - yynn1215 = 0 - } - if yyr1215 || yy2arr1215 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1217 := z.EncBinary() - _ = yym1217 - if false { - } else { - r.EncodeBool(bool(x.EnableHostPathProvisioning)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableHostPathProvisioning")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1218 := z.EncBinary() - _ = yym1218 - if false { - } else { - r.EncodeBool(bool(x.EnableHostPathProvisioning)) - } - } - if yyr1215 || yy2arr1215 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1220 := z.EncBinary() - _ = yym1220 - if false { - } else { - r.EncodeBool(bool(x.EnableDynamicProvisioning)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("enableDynamicProvisioning")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1221 := z.EncBinary() - _ = yym1221 - if false { - } else { - r.EncodeBool(bool(x.EnableDynamicProvisioning)) - } - } - if yyr1215 || yy2arr1215 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yy1223 := &x.PersistentVolumeRecyclerConfiguration - yy1223.CodecEncodeSelf(e) - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("persitentVolumeRecyclerConfiguration")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yy1224 := &x.PersistentVolumeRecyclerConfiguration - yy1224.CodecEncodeSelf(e) - } - if yyr1215 || yy2arr1215 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1226 := z.EncBinary() - _ = yym1226 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FlexVolumePluginDir)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("flexVolumePluginDir")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1227 := z.EncBinary() - _ = yym1227 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.FlexVolumePluginDir)) - } - } - if yyr1215 || yy2arr1215 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *VolumeConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1228 := z.DecBinary() - _ = yym1228 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1229 := r.ContainerType() - if yyct1229 == codecSelferValueTypeMap1234 { - yyl1229 := r.ReadMapStart() - if yyl1229 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1229, d) - } - } else if yyct1229 == codecSelferValueTypeArray1234 { - yyl1229 := r.ReadArrayStart() - if yyl1229 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1229, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *VolumeConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1230Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1230Slc - var yyhl1230 bool = l >= 0 - for yyj1230 := 0; ; yyj1230++ { - if yyhl1230 { - if yyj1230 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1230Slc = r.DecodeBytes(yys1230Slc, true, true) - yys1230 := string(yys1230Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1230 { - case "enableHostPathProvisioning": - if r.TryDecodeAsNil() { - x.EnableHostPathProvisioning = false - } else { - x.EnableHostPathProvisioning = bool(r.DecodeBool()) - } - case "enableDynamicProvisioning": - if r.TryDecodeAsNil() { - x.EnableDynamicProvisioning = false - } else { - x.EnableDynamicProvisioning = bool(r.DecodeBool()) - } - case "persitentVolumeRecyclerConfiguration": - if r.TryDecodeAsNil() { - x.PersistentVolumeRecyclerConfiguration = PersistentVolumeRecyclerConfiguration{} - } else { - yyv1233 := &x.PersistentVolumeRecyclerConfiguration - yyv1233.CodecDecodeSelf(d) - } - case "flexVolumePluginDir": - if r.TryDecodeAsNil() { - x.FlexVolumePluginDir = "" - } else { - x.FlexVolumePluginDir = string(r.DecodeString()) - } - default: - z.DecStructFieldNotFound(-1, yys1230) - } // end switch yys1230 - } // end for yyj1230 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *VolumeConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1235 int - var yyb1235 bool - var yyhl1235 bool = l >= 0 - yyj1235++ - if yyhl1235 { - yyb1235 = yyj1235 > l - } else { - yyb1235 = r.CheckBreak() - } - if yyb1235 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableHostPathProvisioning = false - } else { - x.EnableHostPathProvisioning = bool(r.DecodeBool()) - } - yyj1235++ - if yyhl1235 { - yyb1235 = yyj1235 > l - } else { - yyb1235 = r.CheckBreak() - } - if yyb1235 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.EnableDynamicProvisioning = false - } else { - x.EnableDynamicProvisioning = bool(r.DecodeBool()) - } - yyj1235++ - if yyhl1235 { - yyb1235 = yyj1235 > l - } else { - yyb1235 = r.CheckBreak() - } - if yyb1235 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PersistentVolumeRecyclerConfiguration = PersistentVolumeRecyclerConfiguration{} - } else { - yyv1238 := &x.PersistentVolumeRecyclerConfiguration - yyv1238.CodecDecodeSelf(d) - } - yyj1235++ - if yyhl1235 { - yyb1235 = yyj1235 > l - } else { - yyb1235 = r.CheckBreak() - } - if yyb1235 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.FlexVolumePluginDir = "" - } else { - x.FlexVolumePluginDir = string(r.DecodeString()) - } - for { - yyj1235++ - if yyhl1235 { - yyb1235 = yyj1235 > l - } else { - yyb1235 = r.CheckBreak() - } - if yyb1235 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1235-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x *PersistentVolumeRecyclerConfiguration) CodecEncodeSelf(e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - if x == nil { - r.EncodeNil() - } else { - yym1240 := z.EncBinary() - _ = yym1240 - if false { - } else if z.HasExtensions() && z.EncExt(x) { - } else { - yysep1241 := !z.EncBinary() - yy2arr1241 := z.EncBasicHandle().StructToArray - var yyq1241 [7]bool - _, _, _ = yysep1241, yyq1241, yy2arr1241 - const yyr1241 bool = false - var yynn1241 int - if yyr1241 || yy2arr1241 { - r.EncodeArrayStart(7) - } else { - yynn1241 = 7 - for _, b := range yyq1241 { - if b { - yynn1241++ - } - } - r.EncodeMapStart(yynn1241) - yynn1241 = 0 - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1243 := z.EncBinary() - _ = yym1243 - if false { - } else { - r.EncodeInt(int64(x.MaximumRetry)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("maximumRetry")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1244 := z.EncBinary() - _ = yym1244 - if false { - } else { - r.EncodeInt(int64(x.MaximumRetry)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1246 := z.EncBinary() - _ = yym1246 - if false { - } else { - r.EncodeInt(int64(x.MinimumTimeoutNFS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minimumTimeoutNFS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1247 := z.EncBinary() - _ = yym1247 - if false { - } else { - r.EncodeInt(int64(x.MinimumTimeoutNFS)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1249 := z.EncBinary() - _ = yym1249 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodTemplateFilePathNFS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podTemplateFilePathNFS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1250 := z.EncBinary() - _ = yym1250 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodTemplateFilePathNFS)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1252 := z.EncBinary() - _ = yym1252 - if false { - } else { - r.EncodeInt(int64(x.IncrementTimeoutNFS)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("incrementTimeoutNFS")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1253 := z.EncBinary() - _ = yym1253 - if false { - } else { - r.EncodeInt(int64(x.IncrementTimeoutNFS)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1255 := z.EncBinary() - _ = yym1255 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodTemplateFilePathHostPath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("podTemplateFilePathHostPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1256 := z.EncBinary() - _ = yym1256 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(x.PodTemplateFilePathHostPath)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1258 := z.EncBinary() - _ = yym1258 - if false { - } else { - r.EncodeInt(int64(x.MinimumTimeoutHostPath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("minimumTimeoutHostPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1259 := z.EncBinary() - _ = yym1259 - if false { - } else { - r.EncodeInt(int64(x.MinimumTimeoutHostPath)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayElem1234) - yym1261 := z.EncBinary() - _ = yym1261 - if false { - } else { - r.EncodeInt(int64(x.IncrementTimeoutHostPath)) - } - } else { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - r.EncodeString(codecSelferC_UTF81234, string("incrementTimeoutHostPath")) - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1262 := z.EncBinary() - _ = yym1262 - if false { - } else { - r.EncodeInt(int64(x.IncrementTimeoutHostPath)) - } - } - if yyr1241 || yy2arr1241 { - z.EncSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - z.EncSendContainerState(codecSelfer_containerMapEnd1234) - } - } - } -} - -func (x *PersistentVolumeRecyclerConfiguration) CodecDecodeSelf(d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - yym1263 := z.DecBinary() - _ = yym1263 - if false { - } else if z.HasExtensions() && z.DecExt(x) { - } else { - yyct1264 := r.ContainerType() - if yyct1264 == codecSelferValueTypeMap1234 { - yyl1264 := r.ReadMapStart() - if yyl1264 == 0 { - z.DecSendContainerState(codecSelfer_containerMapEnd1234) - } else { - x.codecDecodeSelfFromMap(yyl1264, d) - } - } else if yyct1264 == codecSelferValueTypeArray1234 { - yyl1264 := r.ReadArrayStart() - if yyl1264 == 0 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - } else { - x.codecDecodeSelfFromArray(yyl1264, d) - } - } else { - panic(codecSelferOnlyMapOrArrayEncodeToStructErr1234) - } - } -} - -func (x *PersistentVolumeRecyclerConfiguration) codecDecodeSelfFromMap(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yys1265Slc = z.DecScratchBuffer() // default slice to decode into - _ = yys1265Slc - var yyhl1265 bool = l >= 0 - for yyj1265 := 0; ; yyj1265++ { - if yyhl1265 { - if yyj1265 >= l { - break - } - } else { - if r.CheckBreak() { - break - } - } - z.DecSendContainerState(codecSelfer_containerMapKey1234) - yys1265Slc = r.DecodeBytes(yys1265Slc, true, true) - yys1265 := string(yys1265Slc) - z.DecSendContainerState(codecSelfer_containerMapValue1234) - switch yys1265 { - case "maximumRetry": - if r.TryDecodeAsNil() { - x.MaximumRetry = 0 - } else { - x.MaximumRetry = int32(r.DecodeInt(32)) - } - case "minimumTimeoutNFS": - if r.TryDecodeAsNil() { - x.MinimumTimeoutNFS = 0 - } else { - x.MinimumTimeoutNFS = int32(r.DecodeInt(32)) - } - case "podTemplateFilePathNFS": - if r.TryDecodeAsNil() { - x.PodTemplateFilePathNFS = "" - } else { - x.PodTemplateFilePathNFS = string(r.DecodeString()) - } - case "incrementTimeoutNFS": - if r.TryDecodeAsNil() { - x.IncrementTimeoutNFS = 0 - } else { - x.IncrementTimeoutNFS = int32(r.DecodeInt(32)) - } - case "podTemplateFilePathHostPath": - if r.TryDecodeAsNil() { - x.PodTemplateFilePathHostPath = "" - } else { - x.PodTemplateFilePathHostPath = string(r.DecodeString()) - } - case "minimumTimeoutHostPath": - if r.TryDecodeAsNil() { - x.MinimumTimeoutHostPath = 0 - } else { - x.MinimumTimeoutHostPath = int32(r.DecodeInt(32)) - } - case "incrementTimeoutHostPath": - if r.TryDecodeAsNil() { - x.IncrementTimeoutHostPath = 0 - } else { - x.IncrementTimeoutHostPath = int32(r.DecodeInt(32)) - } - default: - z.DecStructFieldNotFound(-1, yys1265) - } // end switch yys1265 - } // end for yyj1265 - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x *PersistentVolumeRecyclerConfiguration) codecDecodeSelfFromArray(l int, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - var yyj1273 int - var yyb1273 bool - var yyhl1273 bool = l >= 0 - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MaximumRetry = 0 - } else { - x.MaximumRetry = int32(r.DecodeInt(32)) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MinimumTimeoutNFS = 0 - } else { - x.MinimumTimeoutNFS = int32(r.DecodeInt(32)) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodTemplateFilePathNFS = "" - } else { - x.PodTemplateFilePathNFS = string(r.DecodeString()) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.IncrementTimeoutNFS = 0 - } else { - x.IncrementTimeoutNFS = int32(r.DecodeInt(32)) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.PodTemplateFilePathHostPath = "" - } else { - x.PodTemplateFilePathHostPath = string(r.DecodeString()) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.MinimumTimeoutHostPath = 0 - } else { - x.MinimumTimeoutHostPath = int32(r.DecodeInt(32)) - } - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) - return - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - if r.TryDecodeAsNil() { - x.IncrementTimeoutHostPath = 0 - } else { - x.IncrementTimeoutHostPath = int32(r.DecodeInt(32)) - } - for { - yyj1273++ - if yyhl1273 { - yyb1273 = yyj1273 > l - } else { - yyb1273 = r.CheckBreak() - } - if yyb1273 { - break - } - z.DecSendContainerState(codecSelfer_containerArrayElem1234) - z.DecStructFieldNotFound(yyj1273-1, "") - } - z.DecSendContainerState(codecSelfer_containerArrayEnd1234) -} - -func (x codecSelfer1234) encconfig_ConfigurationMap(v pkg2_config.ConfigurationMap, e *codec1978.Encoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperEncoder(e) - _, _, _ = h, z, r - r.EncodeMapStart(len(v)) - for yyk1281, yyv1281 := range v { - z.EncSendContainerState(codecSelfer_containerMapKey1234) - yym1282 := z.EncBinary() - _ = yym1282 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(yyk1281)) - } - z.EncSendContainerState(codecSelfer_containerMapValue1234) - yym1283 := z.EncBinary() - _ = yym1283 - if false { - } else { - r.EncodeString(codecSelferC_UTF81234, string(yyv1281)) - } - } - z.EncSendContainerState(codecSelfer_containerMapEnd1234) -} - -func (x codecSelfer1234) decconfig_ConfigurationMap(v *pkg2_config.ConfigurationMap, d *codec1978.Decoder) { - var h codecSelfer1234 - z, r := codec1978.GenHelperDecoder(d) - _, _, _ = h, z, r - - yyv1284 := *v - yyl1284 := r.ReadMapStart() - yybh1284 := z.DecBasicHandle() - if yyv1284 == nil { - yyrl1284, _ := z.DecInferLen(yyl1284, yybh1284.MaxInitLen, 32) - yyv1284 = make(map[string]string, yyrl1284) - *v = yyv1284 - } - var yymk1284 string - var yymv1284 string - var yymg1284 bool - if yybh1284.MapValueReset { - } - if yyl1284 > 0 { - for yyj1284 := 0; yyj1284 < yyl1284; yyj1284++ { - z.DecSendContainerState(codecSelfer_containerMapKey1234) - if r.TryDecodeAsNil() { - yymk1284 = "" - } else { - yymk1284 = string(r.DecodeString()) - } - - if yymg1284 { - yymv1284 = yyv1284[yymk1284] - } - z.DecSendContainerState(codecSelfer_containerMapValue1234) - if r.TryDecodeAsNil() { - yymv1284 = "" - } else { - yymv1284 = string(r.DecodeString()) - } - - if yyv1284 != nil { - yyv1284[yymk1284] = yymv1284 - } - } - } else if yyl1284 < 0 { - for yyj1284 := 0; !r.CheckBreak(); yyj1284++ { - z.DecSendContainerState(codecSelfer_containerMapKey1234) - if r.TryDecodeAsNil() { - yymk1284 = "" - } else { - yymk1284 = string(r.DecodeString()) - } - - if yymg1284 { - yymv1284 = yyv1284[yymk1284] - } - z.DecSendContainerState(codecSelfer_containerMapValue1234) - if r.TryDecodeAsNil() { - yymv1284 = "" - } else { - yymv1284 = string(r.DecodeString()) - } - - if yyv1284 != nil { - yyv1284[yymk1284] = yymv1284 - } - } - } // else len==0: TODO: Should we clear map entries? - z.DecSendContainerState(codecSelfer_containerMapEnd1234) -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.go deleted file mode 100644 index 7f64049..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/types.go +++ /dev/null @@ -1,712 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package componentconfig - -import ( - "k8s.io/kubernetes/pkg/api/unversioned" - utilconfig "k8s.io/kubernetes/pkg/util/config" -) - -type KubeProxyConfiguration struct { - unversioned.TypeMeta - - // bindAddress is the IP address for the proxy server to serve on (set to 0.0.0.0 - // for all interfaces) - BindAddress string `json:"bindAddress"` - // clusterCIDR is the CIDR range of the pods in the cluster. It is used to - // bridge traffic coming from outside of the cluster. If not provided, - // no off-cluster bridging will be performed. - ClusterCIDR string `json:"clusterCIDR"` - // healthzBindAddress is the IP address for the health check server to serve on, - // defaulting to 127.0.0.1 (set to 0.0.0.0 for all interfaces) - HealthzBindAddress string `json:"healthzBindAddress"` - // healthzPort is the port to bind the health check server. Use 0 to disable. - HealthzPort int32 `json:"healthzPort"` - // hostnameOverride, if non-empty, will be used as the identity instead of the actual hostname. - HostnameOverride string `json:"hostnameOverride"` - // iptablesMasqueradeBit is the bit of the iptables fwmark space to use for SNAT if using - // the pure iptables proxy mode. Values must be within the range [0, 31]. - IPTablesMasqueradeBit *int32 `json:"iptablesMasqueradeBit"` - // iptablesSyncPeriod is the period that iptables rules are refreshed (e.g. '5s', '1m', - // '2h22m'). Must be greater than 0. - IPTablesSyncPeriod unversioned.Duration `json:"iptablesSyncPeriodSeconds"` - // kubeconfigPath is the path to the kubeconfig file with authorization information (the - // master location is set by the master flag). - KubeconfigPath string `json:"kubeconfigPath"` - // masqueradeAll tells kube-proxy to SNAT everything if using the pure iptables proxy mode. - MasqueradeAll bool `json:"masqueradeAll"` - // master is the address of the Kubernetes API server (overrides any value in kubeconfig) - Master string `json:"master"` - // oomScoreAdj is the oom-score-adj value for kube-proxy process. Values must be within - // the range [-1000, 1000] - OOMScoreAdj *int32 `json:"oomScoreAdj"` - // mode specifies which proxy mode to use. - Mode ProxyMode `json:"mode"` - // portRange is the range of host ports (beginPort-endPort, inclusive) that may be consumed - // in order to proxy service traffic. If unspecified (0-0) then ports will be randomly chosen. - PortRange string `json:"portRange"` - // resourceContainer is the absolute name of the resource-only container to create and run - // the Kube-proxy in (Default: /kube-proxy). - ResourceContainer string `json:"resourceContainer"` - // udpIdleTimeout is how long an idle UDP connection will be kept open (e.g. '250ms', '2s'). - // Must be greater than 0. Only applicable for proxyMode=userspace. - UDPIdleTimeout unversioned.Duration `json:"udpTimeoutMilliseconds"` - // conntrackMax is the maximum number of NAT connections to track (0 to - // leave as-is). This takes precedence over conntrackMaxPerCore and conntrackMin. - ConntrackMax int32 `json:"conntrackMax"` - // conntrackMaxPerCore is the maximum number of NAT connections to track - // per CPU core (0 to leave the limit as-is and ignore conntrackMin). - ConntrackMaxPerCore int32 `json:"conntrackMaxPerCore"` - // conntrackMin is the minimum value of connect-tracking records to allocate, - // regardless of conntrackMaxPerCore (set conntrackMaxPerCore=0 to leave the limit as-is). - ConntrackMin int32 `json:"conntrackMin"` - // conntrackTCPEstablishedTimeout is how long an idle TCP connection will be kept open - // (e.g. '250ms', '2s'). Must be greater than 0. - ConntrackTCPEstablishedTimeout unversioned.Duration `json:"conntrackTCPEstablishedTimeout"` -} - -// Currently two modes of proxying are available: 'userspace' (older, stable) or 'iptables' -// (newer, faster). If blank, look at the Node object on the Kubernetes API and respect the -// 'net.experimental.kubernetes.io/proxy-mode' annotation if provided. Otherwise use the -// best-available proxy (currently iptables, but may change in future versions). If the -// iptables proxy is selected, regardless of how, but the system's kernel or iptables -// versions are insufficient, this always falls back to the userspace proxy. -type ProxyMode string - -const ( - ProxyModeUserspace ProxyMode = "userspace" - ProxyModeIPTables ProxyMode = "iptables" -) - -// HairpinMode denotes how the kubelet should configure networking to handle -// hairpin packets. -type HairpinMode string - -// Enum settings for different ways to handle hairpin packets. -const ( - // Set the hairpin flag on the veth of containers in the respective - // container runtime. - HairpinVeth = "hairpin-veth" - // Make the container bridge promiscuous. This will force it to accept - // hairpin packets, even if the flag isn't set on ports of the bridge. - PromiscuousBridge = "promiscuous-bridge" - // Neither of the above. If the kubelet is started in this hairpin mode - // and kube-proxy is running in iptables mode, hairpin packets will be - // dropped by the container bridge. - HairpinNone = "none" -) - -// TODO: curate the ordering and structure of this config object -type KubeletConfiguration struct { - unversioned.TypeMeta - - // podManifestPath is the path to the directory containing pod manifests to - // run, or the path to a single manifest file - PodManifestPath string `json:"podManifestPath"` - // syncFrequency is the max period between synchronizing running - // containers and config - SyncFrequency unversioned.Duration `json:"syncFrequency"` - // fileCheckFrequency is the duration between checking config files for - // new data - FileCheckFrequency unversioned.Duration `json:"fileCheckFrequency"` - // httpCheckFrequency is the duration between checking http for new data - HTTPCheckFrequency unversioned.Duration `json:"httpCheckFrequency"` - // manifestURL is the URL for accessing the container manifest - ManifestURL string `json:"manifestURL"` - // manifestURLHeader is the HTTP header to use when accessing the manifest - // URL, with the key separated from the value with a ':', as in 'key:value' - ManifestURLHeader string `json:"manifestURLHeader"` - // enableServer enables the Kubelet's server - EnableServer bool `json:"enableServer"` - // address is the IP address for the Kubelet to serve on (set to 0.0.0.0 - // for all interfaces) - Address string `json:"address"` - // port is the port for the Kubelet to serve on. - Port int32 `json:"port"` - // readOnlyPort is the read-only port for the Kubelet to serve on with - // no authentication/authorization (set to 0 to disable) - ReadOnlyPort int32 `json:"readOnlyPort"` - // tlsCertFile is the file containing x509 Certificate for HTTPS. (CA cert, - // if any, concatenated after server cert). If tlsCertFile and - // tlsPrivateKeyFile are not provided, a self-signed certificate - // and key are generated for the public address and saved to the directory - // passed to certDir. - TLSCertFile string `json:"tlsCertFile"` - // tlsPrivateKeyFile is the ile containing x509 private key matching - // tlsCertFile. - TLSPrivateKeyFile string `json:"tlsPrivateKeyFile"` - // certDirectory is the directory where the TLS certs are located (by - // default /var/run/kubernetes). If tlsCertFile and tlsPrivateKeyFile - // are provided, this flag will be ignored. - CertDirectory string `json:"certDirectory"` - // hostnameOverride is the hostname used to identify the kubelet instead - // of the actual hostname. - HostnameOverride string `json:"hostnameOverride"` - // podInfraContainerImage is the image whose network/ipc namespaces - // containers in each pod will use. - PodInfraContainerImage string `json:"podInfraContainerImage"` - // dockerEndpoint is the path to the docker endpoint to communicate with. - DockerEndpoint string `json:"dockerEndpoint"` - // rootDirectory is the directory path to place kubelet files (volume - // mounts,etc). - RootDirectory string `json:"rootDirectory"` - // seccompProfileRoot is the directory path for seccomp profiles. - SeccompProfileRoot string `json:"seccompProfileRoot"` - // allowPrivileged enables containers to request privileged mode. - // Defaults to false. - AllowPrivileged bool `json:"allowPrivileged"` - // hostNetworkSources is a comma-separated list of sources from which the - // Kubelet allows pods to use of host network. Defaults to "*". Valid - // options are "file", "http", "api", and "*" (all sources). - HostNetworkSources []string `json:"hostNetworkSources"` - // hostPIDSources is a comma-separated list of sources from which the - // Kubelet allows pods to use the host pid namespace. Defaults to "*". - HostPIDSources []string `json:"hostPIDSources"` - // hostIPCSources is a comma-separated list of sources from which the - // Kubelet allows pods to use the host ipc namespace. Defaults to "*". - HostIPCSources []string `json:"hostIPCSources"` - // registryPullQPS is the limit of registry pulls per second. If 0, - // unlimited. Set to 0 for no limit. Defaults to 5.0. - RegistryPullQPS int32 `json:"registryPullQPS"` - // registryBurst is the maximum size of a bursty pulls, temporarily allows - // pulls to burst to this number, while still not exceeding registryQps. - // Only used if registryQPS > 0. - RegistryBurst int32 `json:"registryBurst"` - // eventRecordQPS is the maximum event creations per second. If 0, there - // is no limit enforced. - EventRecordQPS int32 `json:"eventRecordQPS"` - // eventBurst is the maximum size of a bursty event records, temporarily - // allows event records to burst to this number, while still not exceeding - // event-qps. Only used if eventQps > 0 - EventBurst int32 `json:"eventBurst"` - // enableDebuggingHandlers enables server endpoints for log collection - // and local running of containers and commands - EnableDebuggingHandlers bool `json:"enableDebuggingHandlers"` - // minimumGCAge is the minimum age for a finished container before it is - // garbage collected. - MinimumGCAge unversioned.Duration `json:"minimumGCAge"` - // maxPerPodContainerCount is the maximum number of old instances to - // retain per container. Each container takes up some disk space. - MaxPerPodContainerCount int32 `json:"maxPerPodContainerCount"` - // maxContainerCount is the maximum number of old instances of containers - // to retain globally. Each container takes up some disk space. - MaxContainerCount int32 `json:"maxContainerCount"` - // cAdvisorPort is the port of the localhost cAdvisor endpoint - CAdvisorPort int32 `json:"cAdvisorPort"` - // healthzPort is the port of the localhost healthz endpoint - HealthzPort int32 `json:"healthzPort"` - // healthzBindAddress is the IP address for the healthz server to serve - // on. - HealthzBindAddress string `json:"healthzBindAddress"` - // oomScoreAdj is The oom-score-adj value for kubelet process. Values - // must be within the range [-1000, 1000]. - OOMScoreAdj int32 `json:"oomScoreAdj"` - // registerNode enables automatic registration with the apiserver. - RegisterNode bool `json:"registerNode"` - // clusterDomain is the DNS domain for this cluster. If set, kubelet will - // configure all containers to search this domain in addition to the - // host's search domains. - ClusterDomain string `json:"clusterDomain"` - // masterServiceNamespace is The namespace from which the kubernetes - // master services should be injected into pods. - MasterServiceNamespace string `json:"masterServiceNamespace"` - // clusterDNS is the IP address for a cluster DNS server. If set, kubelet - // will configure all containers to use this for DNS resolution in - // addition to the host's DNS servers - ClusterDNS string `json:"clusterDNS"` - // streamingConnectionIdleTimeout is the maximum time a streaming connection - // can be idle before the connection is automatically closed. - StreamingConnectionIdleTimeout unversioned.Duration `json:"streamingConnectionIdleTimeout"` - // nodeStatusUpdateFrequency is the frequency that kubelet posts node - // status to master. Note: be cautious when changing the constant, it - // must work with nodeMonitorGracePeriod in nodecontroller. - NodeStatusUpdateFrequency unversioned.Duration `json:"nodeStatusUpdateFrequency"` - // imageMinimumGCAge is the minimum age for an unused image before it is - // garbage collected. - ImageMinimumGCAge unversioned.Duration `json:"imageMinimumGCAge"` - // imageGCHighThresholdPercent is the percent of disk usage after which - // image garbage collection is always run. - ImageGCHighThresholdPercent int32 `json:"imageGCHighThresholdPercent"` - // imageGCLowThresholdPercent is the percent of disk usage before which - // image garbage collection is never run. Lowest disk usage to garbage - // collect to. - ImageGCLowThresholdPercent int32 `json:"imageGCLowThresholdPercent"` - // lowDiskSpaceThresholdMB is the absolute free disk space, in MB, to - // maintain. When disk space falls below this threshold, new pods would - // be rejected. - LowDiskSpaceThresholdMB int32 `json:"lowDiskSpaceThresholdMB"` - // How frequently to calculate and cache volume disk usage for all pods - VolumeStatsAggPeriod unversioned.Duration `json:"volumeStatsAggPeriod"` - // networkPluginName is the name of the network plugin to be invoked for - // various events in kubelet/pod lifecycle - NetworkPluginName string `json:"networkPluginName"` - // networkPluginMTU is the MTU to be passed to the network plugin, - // and overrides the default MTU for cases where it cannot be automatically - // computed (such as IPSEC). - NetworkPluginMTU int32 `json:"networkPluginMTU"` - // networkPluginDir is the full path of the directory in which to search - // for network plugins (and, for backwards-compat, CNI config files) - NetworkPluginDir string `json:"networkPluginDir"` - // CNIConfDir is the full path of the directory in which to search for - // CNI config files - CNIConfDir string `json:"cniConfDir"` - // CNIBinDir is the full path of the directory in which to search for - // CNI plugin binaries - CNIBinDir string `json:"cniBinDir"` - // volumePluginDir is the full path of the directory in which to search - // for additional third party volume plugins - VolumePluginDir string `json:"volumePluginDir"` - // cloudProvider is the provider for cloud services. - CloudProvider string `json:"cloudProvider,omitempty"` - // cloudConfigFile is the path to the cloud provider configuration file. - CloudConfigFile string `json:"cloudConfigFile,omitempty"` - // KubeletCgroups is the absolute name of cgroups to isolate the kubelet in. - KubeletCgroups string `json:"kubeletCgroups,omitempty"` - // Enable QoS based Cgroup hierarchy: top level cgroups for QoS Classes - // And all Burstable and BestEffort pods are brought up under their - // specific top level QoS cgroup. - CgroupsPerQOS bool `json:"cgroupsPerQOS,omitempty"` - // driver that the kubelet uses to manipulate cgroups on the host (cgroupfs or systemd) - CgroupDriver string `json:"cgroupDriver,omitempty"` - // Cgroups that container runtime is expected to be isolated in. - RuntimeCgroups string `json:"runtimeCgroups,omitempty"` - // SystemCgroups is absolute name of cgroups in which to place - // all non-kernel processes that are not already in a container. Empty - // for no container. Rolling back the flag requires a reboot. - SystemCgroups string `json:"systemCgroups,omitempty"` - // CgroupRoot is the root cgroup to use for pods. - // If CgroupsPerQOS is enabled, this is the root of the QoS cgroup hierarchy. - CgroupRoot string `json:"cgroupRoot,omitempty"` - // containerRuntime is the container runtime to use. - ContainerRuntime string `json:"containerRuntime"` - // remoteRuntimeEndpoint is the endpoint of remote runtime service - RemoteRuntimeEndpoint string `json:"remoteRuntimeEndpoint"` - // remoteImageEndpoint is the endpoint of remote image service - RemoteImageEndpoint string `json:"remoteImageEndpoint"` - // runtimeRequestTimeout is the timeout for all runtime requests except long running - // requests - pull, logs, exec and attach. - RuntimeRequestTimeout unversioned.Duration `json:"runtimeRequestTimeout,omitempty"` - // rktPath is the path of rkt binary. Leave empty to use the first rkt in - // $PATH. - RktPath string `json:"rktPath,omitempty"` - // rktApiEndpoint is the endpoint of the rkt API service to communicate with. - RktAPIEndpoint string `json:"rktAPIEndpoint,omitempty"` - // rktStage1Image is the image to use as stage1. Local paths and - // http/https URLs are supported. - RktStage1Image string `json:"rktStage1Image,omitempty"` - // lockFilePath is the path that kubelet will use to as a lock file. - // It uses this file as a lock to synchronize with other kubelet processes - // that may be running. - LockFilePath string `json:"lockFilePath"` - // ExitOnLockContention is a flag that signifies to the kubelet that it is running - // in "bootstrap" mode. This requires that 'LockFilePath' has been set. - // This will cause the kubelet to listen to inotify events on the lock file, - // releasing it and exiting when another process tries to open that file. - ExitOnLockContention bool `json:"exitOnLockContention"` - // configureCBR0 enables the kublet to configure cbr0 based on - // Node.Spec.PodCIDR. - ConfigureCBR0 bool `json:"configureCbr0"` - // How should the kubelet configure the container bridge for hairpin packets. - // Setting this flag allows endpoints in a Service to loadbalance back to - // themselves if they should try to access their own Service. Values: - // "promiscuous-bridge": make the container bridge promiscuous. - // "hairpin-veth": set the hairpin flag on container veth interfaces. - // "none": do nothing. - // Setting --configure-cbr0 to false implies that to achieve hairpin NAT - // one must set --hairpin-mode=veth-flag, because bridge assumes the - // existence of a container bridge named cbr0. - HairpinMode string `json:"hairpinMode"` - // The node has babysitter process monitoring docker and kubelet. - BabysitDaemons bool `json:"babysitDaemons"` - // maxPods is the number of pods that can run on this Kubelet. - MaxPods int32 `json:"maxPods"` - // nvidiaGPUs is the number of NVIDIA GPU devices on this node. - NvidiaGPUs int32 `json:"nvidiaGPUs"` - // dockerExecHandlerName is the handler to use when executing a command - // in a container. Valid values are 'native' and 'nsenter'. Defaults to - // 'native'. - DockerExecHandlerName string `json:"dockerExecHandlerName"` - // The CIDR to use for pod IP addresses, only used in standalone mode. - // In cluster mode, this is obtained from the master. - PodCIDR string `json:"podCIDR"` - // ResolverConfig is the resolver configuration file used as the basis - // for the container DNS resolution configuration."), [] - ResolverConfig string `json:"resolvConf"` - // cpuCFSQuota is Enable CPU CFS quota enforcement for containers that - // specify CPU limits - CPUCFSQuota bool `json:"cpuCFSQuota"` - // containerized should be set to true if kubelet is running in a container. - Containerized bool `json:"containerized"` - // maxOpenFiles is Number of files that can be opened by Kubelet process. - MaxOpenFiles int64 `json:"maxOpenFiles"` - // reconcileCIDR is Reconcile node CIDR with the CIDR specified by the - // API server. No-op if register-node or configure-cbr0 is false. - ReconcileCIDR bool `json:"reconcileCIDR"` - // registerSchedulable tells the kubelet to register the node as - // schedulable. No-op if register-node is false. - RegisterSchedulable bool `json:"registerSchedulable"` - // contentType is contentType of requests sent to apiserver. - ContentType string `json:"contentType"` - // kubeAPIQPS is the QPS to use while talking with kubernetes apiserver - KubeAPIQPS int32 `json:"kubeAPIQPS"` - // kubeAPIBurst is the burst to allow while talking with kubernetes - // apiserver - KubeAPIBurst int32 `json:"kubeAPIBurst"` - // serializeImagePulls when enabled, tells the Kubelet to pull images one - // at a time. We recommend *not* changing the default value on nodes that - // run docker daemon with version < 1.9 or an Aufs storage backend. - // Issue #10959 has more details. - SerializeImagePulls bool `json:"serializeImagePulls"` - // outOfDiskTransitionFrequency is duration for which the kubelet has to - // wait before transitioning out of out-of-disk node condition status. - OutOfDiskTransitionFrequency unversioned.Duration `json:"outOfDiskTransitionFrequency,omitempty"` - // nodeIP is IP address of the node. If set, kubelet will use this IP - // address for the node. - NodeIP string `json:"nodeIP,omitempty"` - // nodeLabels to add when registering the node in the cluster. - NodeLabels map[string]string `json:"nodeLabels"` - // nonMasqueradeCIDR configures masquerading: traffic to IPs outside this range will use IP masquerade. - NonMasqueradeCIDR string `json:"nonMasqueradeCIDR"` - // enable gathering custom metrics. - EnableCustomMetrics bool `json:"enableCustomMetrics"` - // Comma-delimited list of hard eviction expressions. For example, 'memory.available<300Mi'. - EvictionHard string `json:"evictionHard,omitempty"` - // Comma-delimited list of soft eviction expressions. For example, 'memory.available<300Mi'. - EvictionSoft string `json:"evictionSoft,omitempty"` - // Comma-delimeted list of grace periods for each soft eviction signal. For example, 'memory.available=30s'. - EvictionSoftGracePeriod string `json:"evictionSoftGracePeriod,omitempty"` - // Duration for which the kubelet has to wait before transitioning out of an eviction pressure condition. - EvictionPressureTransitionPeriod unversioned.Duration `json:"evictionPressureTransitionPeriod,omitempty"` - // Maximum allowed grace period (in seconds) to use when terminating pods in response to a soft eviction threshold being met. - EvictionMaxPodGracePeriod int32 `json:"evictionMaxPodGracePeriod,omitempty"` - // Comma-delimited list of minimum reclaims (e.g. imagefs.available=2Gi) that describes the minimum amount of resource the kubelet will reclaim when performing a pod eviction if that resource is under pressure. - EvictionMinimumReclaim string `json:"evictionMinimumReclaim,omitempty"` - // Maximum number of pods per core. Cannot exceed MaxPods - PodsPerCore int32 `json:"podsPerCore"` - // enableControllerAttachDetach enables the Attach/Detach controller to - // manage attachment/detachment of volumes scheduled to this node, and - // disables kubelet from executing any attach/detach operations - EnableControllerAttachDetach bool `json:"enableControllerAttachDetach"` - // A set of ResourceName=ResourceQuantity (e.g. cpu=200m,memory=150G) pairs - // that describe resources reserved for non-kubernetes components. - // Currently only cpu and memory are supported. [default=none] - // See http://kubernetes.io/docs/user-guide/compute-resources for more detail. - SystemReserved utilconfig.ConfigurationMap `json:"systemReserved"` - // A set of ResourceName=ResourceQuantity (e.g. cpu=200m,memory=150G) pairs - // that describe resources reserved for kubernetes system components. - // Currently only cpu and memory are supported. [default=none] - // See http://kubernetes.io/docs/user-guide/compute-resources for more detail. - KubeReserved utilconfig.ConfigurationMap `json:"kubeReserved"` - // Default behaviour for kernel tuning - ProtectKernelDefaults bool `json:"protectKernelDefaults"` - // If true, Kubelet ensures a set of iptables rules are present on host. - // These rules will serve as utility for various components, e.g. kube-proxy. - // The rules will be created based on IPTablesMasqueradeBit and IPTablesDropBit. - MakeIPTablesUtilChains bool `json:"makeIPTablesUtilChains"` - // iptablesMasqueradeBit is the bit of the iptables fwmark space to use for SNAT - // Values must be within the range [0, 31]. - // Warning: Please match the value of corresponding parameter in kube-proxy - // TODO: clean up IPTablesMasqueradeBit in kube-proxy - IPTablesMasqueradeBit int32 `json:"iptablesMasqueradeBit"` - // iptablesDropBit is the bit of the iptables fwmark space to use for dropping packets. Kubelet will ensure iptables mark and drop rules. - // Values must be within the range [0, 31]. Must be different from IPTablesMasqueradeBit - IPTablesDropBit int32 `json:"iptablesDropBit"` - // Whitelist of unsafe sysctls or sysctl patterns (ending in *). - AllowedUnsafeSysctls []string `json:"experimentalAllowedUnsafeSysctls,omitempty"` - // How to integrate with runtime. If set to cri, kubelet will switch to - // using the new Container Runtine Interface. - ExperimentalRuntimeIntegrationType string `json:"experimentalRuntimeIntegrationType,omitempty"` -} - -type KubeSchedulerConfiguration struct { - unversioned.TypeMeta - - // port is the port that the scheduler's http service runs on. - Port int32 `json:"port"` - // address is the IP address to serve on. - Address string `json:"address"` - // algorithmProvider is the scheduling algorithm provider to use. - AlgorithmProvider string `json:"algorithmProvider"` - // policyConfigFile is the filepath to the scheduler policy configuration. - PolicyConfigFile string `json:"policyConfigFile"` - // enableProfiling enables profiling via web interface. - EnableProfiling bool `json:"enableProfiling"` - // contentType is contentType of requests sent to apiserver. - ContentType string `json:"contentType"` - // kubeAPIQPS is the QPS to use while talking with kubernetes apiserver. - KubeAPIQPS float32 `json:"kubeAPIQPS"` - // kubeAPIBurst is the QPS burst to use while talking with kubernetes apiserver. - KubeAPIBurst int32 `json:"kubeAPIBurst"` - // schedulerName is name of the scheduler, used to select which pods - // will be processed by this scheduler, based on pod's annotation with - // key 'scheduler.alpha.kubernetes.io/name'. - SchedulerName string `json:"schedulerName"` - // RequiredDuringScheduling affinity is not symmetric, but there is an implicit PreferredDuringScheduling affinity rule - // corresponding to every RequiredDuringScheduling affinity rule. - // HardPodAffinitySymmetricWeight represents the weight of implicit PreferredDuringScheduling affinity rule, in the range 0-100. - HardPodAffinitySymmetricWeight int `json:"hardPodAffinitySymmetricWeight"` - // Indicate the "all topologies" set for empty topologyKey when it's used for PreferredDuringScheduling pod anti-affinity. - FailureDomains string `json:"failureDomains"` - // leaderElection defines the configuration of leader election client. - LeaderElection LeaderElectionConfiguration `json:"leaderElection"` -} - -// LeaderElectionConfiguration defines the configuration of leader election -// clients for components that can run with leader election enabled. -type LeaderElectionConfiguration struct { - // leaderElect enables a leader election client to gain leadership - // before executing the main loop. Enable this when running replicated - // components for high availability. - LeaderElect bool `json:"leaderElect"` - // leaseDuration is the duration that non-leader candidates will wait - // after observing a leadership renewal until attempting to acquire - // leadership of a led but unrenewed leader slot. This is effectively the - // maximum duration that a leader can be stopped before it is replaced - // by another candidate. This is only applicable if leader election is - // enabled. - LeaseDuration unversioned.Duration `json:"leaseDuration"` - // renewDeadline is the interval between attempts by the acting master to - // renew a leadership slot before it stops leading. This must be less - // than or equal to the lease duration. This is only applicable if leader - // election is enabled. - RenewDeadline unversioned.Duration `json:"renewDeadline"` - // retryPeriod is the duration the clients should wait between attempting - // acquisition and renewal of a leadership. This is only applicable if - // leader election is enabled. - RetryPeriod unversioned.Duration `json:"retryPeriod"` -} - -type KubeControllerManagerConfiguration struct { - unversioned.TypeMeta - - // port is the port that the controller-manager's http service runs on. - Port int32 `json:"port"` - // address is the IP address to serve on (set to 0.0.0.0 for all interfaces). - Address string `json:"address"` - // cloudProvider is the provider for cloud services. - CloudProvider string `json:"cloudProvider"` - // cloudConfigFile is the path to the cloud provider configuration file. - CloudConfigFile string `json:"cloudConfigFile"` - // concurrentEndpointSyncs is the number of endpoint syncing operations - // that will be done concurrently. Larger number = faster endpoint updating, - // but more CPU (and network) load. - ConcurrentEndpointSyncs int32 `json:"concurrentEndpointSyncs"` - // concurrentRSSyncs is the number of replica sets that are allowed to sync - // concurrently. Larger number = more responsive replica management, but more - // CPU (and network) load. - ConcurrentRSSyncs int32 `json:"concurrentRSSyncs"` - // concurrentRCSyncs is the number of replication controllers that are - // allowed to sync concurrently. Larger number = more responsive replica - // management, but more CPU (and network) load. - ConcurrentRCSyncs int32 `json:"concurrentRCSyncs"` - // concurrentServiceSyncs is the number of services that are - // allowed to sync concurrently. Larger number = more responsive service - // management, but more CPU (and network) load. - ConcurrentServiceSyncs int32 `json:"concurrentServiceSyncs"` - // concurrentResourceQuotaSyncs is the number of resource quotas that are - // allowed to sync concurrently. Larger number = more responsive quota - // management, but more CPU (and network) load. - ConcurrentResourceQuotaSyncs int32 `json:"concurrentResourceQuotaSyncs"` - // concurrentDeploymentSyncs is the number of deployment objects that are - // allowed to sync concurrently. Larger number = more responsive deployments, - // but more CPU (and network) load. - ConcurrentDeploymentSyncs int32 `json:"concurrentDeploymentSyncs"` - // concurrentDaemonSetSyncs is the number of daemonset objects that are - // allowed to sync concurrently. Larger number = more responsive daemonset, - // but more CPU (and network) load. - ConcurrentDaemonSetSyncs int32 `json:"concurrentDaemonSetSyncs"` - // concurrentJobSyncs is the number of job objects that are - // allowed to sync concurrently. Larger number = more responsive jobs, - // but more CPU (and network) load. - ConcurrentJobSyncs int32 `json:"concurrentJobSyncs"` - // concurrentNamespaceSyncs is the number of namespace objects that are - // allowed to sync concurrently. - ConcurrentNamespaceSyncs int32 `json:"concurrentNamespaceSyncs"` - // concurrentSATokenSyncs is the number of service account token syncing operations - // that will be done concurrently. - ConcurrentSATokenSyncs int32 `json:"concurrentSATokenSyncs"` - // lookupCacheSizeForRC is the size of lookup cache for replication controllers. - // Larger number = more responsive replica management, but more MEM load. - LookupCacheSizeForRC int32 `json:"lookupCacheSizeForRC"` - // lookupCacheSizeForRS is the size of lookup cache for replicatsets. - // Larger number = more responsive replica management, but more MEM load. - LookupCacheSizeForRS int32 `json:"lookupCacheSizeForRS"` - // lookupCacheSizeForDaemonSet is the size of lookup cache for daemonsets. - // Larger number = more responsive daemonset, but more MEM load. - LookupCacheSizeForDaemonSet int32 `json:"lookupCacheSizeForDaemonSet"` - // serviceSyncPeriod is the period for syncing services with their external - // load balancers. - ServiceSyncPeriod unversioned.Duration `json:"serviceSyncPeriod"` - // nodeSyncPeriod is the period for syncing nodes from cloudprovider. Longer - // periods will result in fewer calls to cloud provider, but may delay addition - // of new nodes to cluster. - NodeSyncPeriod unversioned.Duration `json:"nodeSyncPeriod"` - // routeReconciliationPeriod is the period for reconciling routes created for Nodes by cloud provider.. - RouteReconciliationPeriod unversioned.Duration `json:"routeReconciliationPeriod"` - // resourceQuotaSyncPeriod is the period for syncing quota usage status - // in the system. - ResourceQuotaSyncPeriod unversioned.Duration `json:"resourceQuotaSyncPeriod"` - // namespaceSyncPeriod is the period for syncing namespace life-cycle - // updates. - NamespaceSyncPeriod unversioned.Duration `json:"namespaceSyncPeriod"` - // pvClaimBinderSyncPeriod is the period for syncing persistent volumes - // and persistent volume claims. - PVClaimBinderSyncPeriod unversioned.Duration `json:"pvClaimBinderSyncPeriod"` - // minResyncPeriod is the resync period in reflectors; will be random between - // minResyncPeriod and 2*minResyncPeriod. - MinResyncPeriod unversioned.Duration `json:"minResyncPeriod"` - // terminatedPodGCThreshold is the number of terminated pods that can exist - // before the terminated pod garbage collector starts deleting terminated pods. - // If <= 0, the terminated pod garbage collector is disabled. - TerminatedPodGCThreshold int32 `json:"terminatedPodGCThreshold"` - // horizontalPodAutoscalerSyncPeriod is the period for syncing the number of - // pods in horizontal pod autoscaler. - HorizontalPodAutoscalerSyncPeriod unversioned.Duration `json:"horizontalPodAutoscalerSyncPeriod"` - // deploymentControllerSyncPeriod is the period for syncing the deployments. - DeploymentControllerSyncPeriod unversioned.Duration `json:"deploymentControllerSyncPeriod"` - // podEvictionTimeout is the grace period for deleting pods on failed nodes. - PodEvictionTimeout unversioned.Duration `json:"podEvictionTimeout"` - // DEPRECATED: deletingPodsQps is the number of nodes per second on which pods are deleted in - // case of node failure. - DeletingPodsQps float32 `json:"deletingPodsQps"` - // DEPRECATED: deletingPodsBurst is the number of nodes on which pods are bursty deleted in - // case of node failure. For more details look into RateLimiter. - DeletingPodsBurst int32 `json:"deletingPodsBurst"` - // nodeMontiorGracePeriod is the amount of time which we allow a running node to be - // unresponsive before marking it unhealthy. Must be N times more than kubelet's - // nodeStatusUpdateFrequency, where N means number of retries allowed for kubelet - // to post node status. - NodeMonitorGracePeriod unversioned.Duration `json:"nodeMonitorGracePeriod"` - // registerRetryCount is the number of retries for initial node registration. - // Retry interval equals node-sync-period. - RegisterRetryCount int32 `json:"registerRetryCount"` - // nodeStartupGracePeriod is the amount of time which we allow starting a node to - // be unresponsive before marking it unhealthy. - NodeStartupGracePeriod unversioned.Duration `json:"nodeStartupGracePeriod"` - // nodeMonitorPeriod is the period for syncing NodeStatus in NodeController. - NodeMonitorPeriod unversioned.Duration `json:"nodeMonitorPeriod"` - // serviceAccountKeyFile is the filename containing a PEM-encoded private RSA key - // used to sign service account tokens. - ServiceAccountKeyFile string `json:"serviceAccountKeyFile"` - // clusterSigningCertFile is the filename containing a PEM-encoded - // X509 CA certificate used to issue cluster-scoped certificates - ClusterSigningCertFile string `json:"clusterSigningCertFile"` - // clusterSigningCertFile is the filename containing a PEM-encoded - // RSA or ECDSA private key used to issue cluster-scoped certificates - ClusterSigningKeyFile string `json:"clusterSigningKeyFile"` - // approveAllKubeletCSRs tells the CSR controller to approve all CSRs originating - // from the kubelet bootstrapping group automatically. - // WARNING: this grants all users with access to the certificates API group - // the ability to create credentials for any user that has access to the boostrapping - // user's credentials. - ApproveAllKubeletCSRsForGroup string `json:"approveAllKubeletCSRsForGroup"` - // enableProfiling enables profiling via web interface host:port/debug/pprof/ - EnableProfiling bool `json:"enableProfiling"` - // clusterName is the instance prefix for the cluster. - ClusterName string `json:"clusterName"` - // clusterCIDR is CIDR Range for Pods in cluster. - ClusterCIDR string `json:"clusterCIDR"` - // serviceCIDR is CIDR Range for Services in cluster. - ServiceCIDR string `json:"serviceCIDR"` - // NodeCIDRMaskSize is the mask size for node cidr in cluster. - NodeCIDRMaskSize int32 `json:"nodeCIDRMaskSize"` - // allocateNodeCIDRs enables CIDRs for Pods to be allocated and, if - // ConfigureCloudRoutes is true, to be set on the cloud provider. - AllocateNodeCIDRs bool `json:"allocateNodeCIDRs"` - // configureCloudRoutes enables CIDRs allocated with allocateNodeCIDRs - // to be configured on the cloud provider. - ConfigureCloudRoutes bool `json:"configureCloudRoutes"` - // rootCAFile is the root certificate authority will be included in service - // account's token secret. This must be a valid PEM-encoded CA bundle. - RootCAFile string `json:"rootCAFile"` - // contentType is contentType of requests sent to apiserver. - ContentType string `json:"contentType"` - // kubeAPIQPS is the QPS to use while talking with kubernetes apiserver. - KubeAPIQPS float32 `json:"kubeAPIQPS"` - // kubeAPIBurst is the burst to use while talking with kubernetes apiserver. - KubeAPIBurst int32 `json:"kubeAPIBurst"` - // leaderElection defines the configuration of leader election client. - LeaderElection LeaderElectionConfiguration `json:"leaderElection"` - // volumeConfiguration holds configuration for volume related features. - VolumeConfiguration VolumeConfiguration `json:"volumeConfiguration"` - // How long to wait between starting controller managers - ControllerStartInterval unversioned.Duration `json:"controllerStartInterval"` - // enables the generic garbage collector. MUST be synced with the - // corresponding flag of the kube-apiserver. WARNING: the generic garbage - // collector is an alpha feature. - EnableGarbageCollector bool `json:"enableGarbageCollector"` - // concurrentGCSyncs is the number of garbage collector workers that are - // allowed to sync concurrently. - ConcurrentGCSyncs int32 `json:"concurrentGCSyncs"` - // nodeEvictionRate is the number of nodes per second on which pods are deleted in case of node failure when a zone is healthy - NodeEvictionRate float32 `json:"nodeEvictionRate"` - // secondaryNodeEvictionRate is the number of nodes per second on which pods are deleted in case of node failure when a zone is unhealty - SecondaryNodeEvictionRate float32 `json:"secondaryNodeEvictionRate"` - // secondaryNodeEvictionRate is implicitly overridden to 0 for clusters smaller than or equal to largeClusterSizeThreshold - LargeClusterSizeThreshold int32 `json:"largeClusterSizeThreshold"` - // Zone is treated as unhealthy in nodeEvictionRate and secondaryNodeEvictionRate when at least - // unhealthyZoneThreshold (no less than 3) of Nodes in the zone are NotReady - UnhealthyZoneThreshold float32 `json:"unhealthyZoneThreshold"` -} - -// VolumeConfiguration contains *all* enumerated flags meant to configure all volume -// plugins. From this config, the controller-manager binary will create many instances of -// volume.VolumeConfig, each containing only the configuration needed for that plugin which -// are then passed to the appropriate plugin. The ControllerManager binary is the only part -// of the code which knows what plugins are supported and which flags correspond to each plugin. -type VolumeConfiguration struct { - // enableHostPathProvisioning enables HostPath PV provisioning when running without a - // cloud provider. This allows testing and development of provisioning features. HostPath - // provisioning is not supported in any way, won't work in a multi-node cluster, and - // should not be used for anything other than testing or development. - EnableHostPathProvisioning bool `json:"enableHostPathProvisioning"` - // enableDynamicProvisioning enables the provisioning of volumes when running within an environment - // that supports dynamic provisioning. Defaults to true. - EnableDynamicProvisioning bool `json:"enableDynamicProvisioning"` - // persistentVolumeRecyclerConfiguration holds configuration for persistent volume plugins. - PersistentVolumeRecyclerConfiguration PersistentVolumeRecyclerConfiguration `json:"persitentVolumeRecyclerConfiguration"` - // volumePluginDir is the full path of the directory in which the flex - // volume plugin should search for additional third party volume plugins - FlexVolumePluginDir string `json:"flexVolumePluginDir"` -} - -type PersistentVolumeRecyclerConfiguration struct { - // maximumRetry is number of retries the PV recycler will execute on failure to recycle - // PV. - MaximumRetry int32 `json:"maximumRetry"` - // minimumTimeoutNFS is the minimum ActiveDeadlineSeconds to use for an NFS Recycler - // pod. - MinimumTimeoutNFS int32 `json:"minimumTimeoutNFS"` - // podTemplateFilePathNFS is the file path to a pod definition used as a template for - // NFS persistent volume recycling - PodTemplateFilePathNFS string `json:"podTemplateFilePathNFS"` - // incrementTimeoutNFS is the increment of time added per Gi to ActiveDeadlineSeconds - // for an NFS scrubber pod. - IncrementTimeoutNFS int32 `json:"incrementTimeoutNFS"` - // podTemplateFilePathHostPath is the file path to a pod definition used as a template for - // HostPath persistent volume recycling. This is for development and testing only and - // will not work in a multi-node cluster. - PodTemplateFilePathHostPath string `json:"podTemplateFilePathHostPath"` - // minimumTimeoutHostPath is the minimum ActiveDeadlineSeconds to use for a HostPath - // Recycler pod. This is for development and testing only and will not work in a multi-node - // cluster. - MinimumTimeoutHostPath int32 `json:"minimumTimeoutHostPath"` - // incrementTimeoutHostPath is the increment of time added per Gi to ActiveDeadlineSeconds - // for a HostPath scrubber pod. This is for development and testing only and will not work - // in a multi-node cluster. - IncrementTimeoutHostPath int32 `json:"incrementTimeoutHostPath"` -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/defaults.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/defaults.go deleted file mode 100644 index 164ac8f..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/defaults.go +++ /dev/null @@ -1,369 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package v1alpha1 - -import ( - "path/filepath" - "runtime" - "time" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/kubelet/qos" - kubetypes "k8s.io/kubernetes/pkg/kubelet/types" - "k8s.io/kubernetes/pkg/master/ports" - kruntime "k8s.io/kubernetes/pkg/runtime" -) - -const ( - defaultRootDir = "/var/lib/kubelet" - - // When these values are updated, also update test/e2e/framework/util.go - defaultPodInfraContainerImageName = "gcr.io/google_containers/pause" - defaultPodInfraContainerImageVersion = "3.0" - defaultPodInfraContainerImage = defaultPodInfraContainerImageName + - "-" + runtime.GOARCH + ":" + - defaultPodInfraContainerImageVersion - - // From pkg/kubelet/rkt/rkt.go to avoid circular import - defaultRktAPIServiceEndpoint = "localhost:15441" - - AutoDetectCloudProvider = "auto-detect" - - defaultIPTablesMasqueradeBit = 14 - defaultIPTablesDropBit = 15 -) - -var zeroDuration = unversioned.Duration{} - -func addDefaultingFuncs(scheme *kruntime.Scheme) error { - return scheme.AddDefaultingFuncs( - SetDefaults_KubeProxyConfiguration, - SetDefaults_KubeSchedulerConfiguration, - SetDefaults_LeaderElectionConfiguration, - SetDefaults_KubeletConfiguration, - ) -} - -func SetDefaults_KubeProxyConfiguration(obj *KubeProxyConfiguration) { - if obj.BindAddress == "" { - obj.BindAddress = "0.0.0.0" - } - if obj.HealthzPort == 0 { - obj.HealthzPort = 10249 - } - if obj.HealthzBindAddress == "" { - obj.HealthzBindAddress = "127.0.0.1" - } - if obj.OOMScoreAdj == nil { - temp := int32(qos.KubeProxyOOMScoreAdj) - obj.OOMScoreAdj = &temp - } - if obj.ResourceContainer == "" { - obj.ResourceContainer = "/kube-proxy" - } - if obj.IPTablesSyncPeriod.Duration == 0 { - obj.IPTablesSyncPeriod = unversioned.Duration{Duration: 30 * time.Second} - } - zero := unversioned.Duration{} - if obj.UDPIdleTimeout == zero { - obj.UDPIdleTimeout = unversioned.Duration{Duration: 250 * time.Millisecond} - } - // If ConntrackMax is set, respect it. - if obj.ConntrackMax == 0 { - // If ConntrackMax is *not* set, use per-core scaling. - if obj.ConntrackMaxPerCore == 0 { - obj.ConntrackMaxPerCore = 32 * 1024 - } - if obj.ConntrackMin == 0 { - obj.ConntrackMin = 128 * 1024 - } - } - if obj.IPTablesMasqueradeBit == nil { - temp := int32(14) - obj.IPTablesMasqueradeBit = &temp - } - if obj.ConntrackTCPEstablishedTimeout == zero { - obj.ConntrackTCPEstablishedTimeout = unversioned.Duration{Duration: 24 * time.Hour} // 1 day (1/5 default) - } -} - -func SetDefaults_KubeSchedulerConfiguration(obj *KubeSchedulerConfiguration) { - if obj.Port == 0 { - obj.Port = ports.SchedulerPort - } - if obj.Address == "" { - obj.Address = "0.0.0.0" - } - if obj.AlgorithmProvider == "" { - obj.AlgorithmProvider = "DefaultProvider" - } - if obj.ContentType == "" { - obj.ContentType = "application/vnd.kubernetes.protobuf" - } - if obj.KubeAPIQPS == 0 { - obj.KubeAPIQPS = 50.0 - } - if obj.KubeAPIBurst == 0 { - obj.KubeAPIBurst = 100 - } - if obj.SchedulerName == "" { - obj.SchedulerName = api.DefaultSchedulerName - } - if obj.HardPodAffinitySymmetricWeight == 0 { - obj.HardPodAffinitySymmetricWeight = api.DefaultHardPodAffinitySymmetricWeight - } - if obj.FailureDomains == "" { - obj.FailureDomains = api.DefaultFailureDomains - } -} - -func SetDefaults_LeaderElectionConfiguration(obj *LeaderElectionConfiguration) { - zero := unversioned.Duration{} - if obj.LeaseDuration == zero { - obj.LeaseDuration = unversioned.Duration{Duration: 15 * time.Second} - } - if obj.RenewDeadline == zero { - obj.RenewDeadline = unversioned.Duration{Duration: 10 * time.Second} - } - if obj.RetryPeriod == zero { - obj.RetryPeriod = unversioned.Duration{Duration: 2 * time.Second} - } -} - -func SetDefaults_KubeletConfiguration(obj *KubeletConfiguration) { - if obj.Address == "" { - obj.Address = "0.0.0.0" - } - if obj.CloudProvider == "" { - obj.CloudProvider = AutoDetectCloudProvider - } - if obj.CAdvisorPort == 0 { - obj.CAdvisorPort = 4194 - } - if obj.VolumeStatsAggPeriod == zeroDuration { - obj.VolumeStatsAggPeriod = unversioned.Duration{Duration: time.Minute} - } - if obj.CertDirectory == "" { - obj.CertDirectory = "/var/run/kubernetes" - } - if obj.ConfigureCBR0 == nil { - obj.ConfigureCBR0 = boolVar(false) - } - if obj.CgroupsPerQOS == nil { - obj.CgroupsPerQOS = boolVar(false) - } - if obj.ContainerRuntime == "" { - obj.ContainerRuntime = "docker" - } - if obj.RuntimeRequestTimeout == zeroDuration { - obj.RuntimeRequestTimeout = unversioned.Duration{Duration: 2 * time.Minute} - } - if obj.CPUCFSQuota == nil { - obj.CPUCFSQuota = boolVar(true) - } - if obj.DockerExecHandlerName == "" { - obj.DockerExecHandlerName = "native" - } - if obj.DockerEndpoint == "" { - obj.DockerEndpoint = "unix:///var/run/docker.sock" - } - if obj.EventBurst == 0 { - obj.EventBurst = 10 - } - if obj.EventRecordQPS == nil { - temp := int32(5) - obj.EventRecordQPS = &temp - } - if obj.EnableControllerAttachDetach == nil { - obj.EnableControllerAttachDetach = boolVar(true) - } - if obj.EnableDebuggingHandlers == nil { - obj.EnableDebuggingHandlers = boolVar(true) - } - if obj.EnableServer == nil { - obj.EnableServer = boolVar(true) - } - if obj.FileCheckFrequency == zeroDuration { - obj.FileCheckFrequency = unversioned.Duration{Duration: 20 * time.Second} - } - if obj.HealthzBindAddress == "" { - obj.HealthzBindAddress = "127.0.0.1" - } - if obj.HealthzPort == 0 { - obj.HealthzPort = 10248 - } - if obj.HostNetworkSources == nil { - obj.HostNetworkSources = []string{kubetypes.AllSource} - } - if obj.HostPIDSources == nil { - obj.HostPIDSources = []string{kubetypes.AllSource} - } - if obj.HostIPCSources == nil { - obj.HostIPCSources = []string{kubetypes.AllSource} - } - if obj.HTTPCheckFrequency == zeroDuration { - obj.HTTPCheckFrequency = unversioned.Duration{Duration: 20 * time.Second} - } - if obj.ImageMinimumGCAge == zeroDuration { - obj.ImageMinimumGCAge = unversioned.Duration{Duration: 2 * time.Minute} - } - if obj.ImageGCHighThresholdPercent == nil { - temp := int32(90) - obj.ImageGCHighThresholdPercent = &temp - } - if obj.ImageGCLowThresholdPercent == nil { - temp := int32(80) - obj.ImageGCLowThresholdPercent = &temp - } - if obj.LowDiskSpaceThresholdMB == 0 { - obj.LowDiskSpaceThresholdMB = 256 - } - if obj.MasterServiceNamespace == "" { - obj.MasterServiceNamespace = api.NamespaceDefault - } - if obj.MaxContainerCount == nil { - temp := int32(-1) - obj.MaxContainerCount = &temp - } - if obj.MaxPerPodContainerCount == 0 { - obj.MaxPerPodContainerCount = 1 - } - if obj.MaxOpenFiles == 0 { - obj.MaxOpenFiles = 1000000 - } - if obj.MaxPods == 0 { - obj.MaxPods = 110 - } - if obj.MinimumGCAge == zeroDuration { - obj.MinimumGCAge = unversioned.Duration{Duration: 0} - } - if obj.NonMasqueradeCIDR == "" { - obj.NonMasqueradeCIDR = "10.0.0.0/8" - } - if obj.VolumePluginDir == "" { - obj.VolumePluginDir = "/usr/libexec/kubernetes/kubelet-plugins/volume/exec/" - } - if obj.NodeStatusUpdateFrequency == zeroDuration { - obj.NodeStatusUpdateFrequency = unversioned.Duration{Duration: 10 * time.Second} - } - if obj.OOMScoreAdj == nil { - temp := int32(qos.KubeletOOMScoreAdj) - obj.OOMScoreAdj = &temp - } - if obj.PodInfraContainerImage == "" { - obj.PodInfraContainerImage = defaultPodInfraContainerImage - } - if obj.Port == 0 { - obj.Port = ports.KubeletPort - } - if obj.ReadOnlyPort == 0 { - obj.ReadOnlyPort = ports.KubeletReadOnlyPort - } - if obj.RegisterNode == nil { - obj.RegisterNode = boolVar(true) - } - if obj.RegisterSchedulable == nil { - obj.RegisterSchedulable = boolVar(true) - } - if obj.RegistryBurst == 0 { - obj.RegistryBurst = 10 - } - if obj.RegistryPullQPS == nil { - temp := int32(5) - obj.RegistryPullQPS = &temp - } - if obj.ResolverConfig == "" { - obj.ResolverConfig = kubetypes.ResolvConfDefault - } - if obj.RktAPIEndpoint == "" { - obj.RktAPIEndpoint = defaultRktAPIServiceEndpoint - } - if obj.RootDirectory == "" { - obj.RootDirectory = defaultRootDir - } - if obj.SerializeImagePulls == nil { - obj.SerializeImagePulls = boolVar(true) - } - if obj.SeccompProfileRoot == "" { - filepath.Join(defaultRootDir, "seccomp") - } - if obj.StreamingConnectionIdleTimeout == zeroDuration { - obj.StreamingConnectionIdleTimeout = unversioned.Duration{Duration: 4 * time.Hour} - } - if obj.SyncFrequency == zeroDuration { - obj.SyncFrequency = unversioned.Duration{Duration: 1 * time.Minute} - } - if obj.ReconcileCIDR == nil { - obj.ReconcileCIDR = boolVar(true) - } - if obj.ContentType == "" { - obj.ContentType = "application/vnd.kubernetes.protobuf" - } - if obj.KubeAPIQPS == nil { - temp := int32(5) - obj.KubeAPIQPS = &temp - } - if obj.KubeAPIBurst == 0 { - obj.KubeAPIBurst = 10 - } - if obj.OutOfDiskTransitionFrequency == zeroDuration { - obj.OutOfDiskTransitionFrequency = unversioned.Duration{Duration: 5 * time.Minute} - } - if string(obj.HairpinMode) == "" { - obj.HairpinMode = PromiscuousBridge - } - if obj.EvictionHard == nil { - temp := "memory.available<100Mi" - obj.EvictionHard = &temp - } - if obj.EvictionPressureTransitionPeriod == zeroDuration { - obj.EvictionPressureTransitionPeriod = unversioned.Duration{Duration: 5 * time.Minute} - } - if obj.SystemReserved == nil { - obj.SystemReserved = make(map[string]string) - } - if obj.KubeReserved == nil { - obj.KubeReserved = make(map[string]string) - } - if obj.MakeIPTablesUtilChains == nil { - obj.MakeIPTablesUtilChains = boolVar(true) - } - if obj.IPTablesMasqueradeBit == nil { - temp := int32(defaultIPTablesMasqueradeBit) - obj.IPTablesMasqueradeBit = &temp - } - if obj.IPTablesDropBit == nil { - temp := int32(defaultIPTablesDropBit) - obj.IPTablesDropBit = &temp - } - if obj.CgroupDriver == "" { - obj.CgroupDriver = "cgroupfs" - } - if obj.CgroupsPerQOS == nil { - temp := false - obj.CgroupsPerQOS = &temp - } -} - -func boolVar(b bool) *bool { - return &b -} - -var ( - defaultCfg = KubeletConfiguration{} -) diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/register.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/register.go deleted file mode 100644 index 7017d9e..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/register.go +++ /dev/null @@ -1,46 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package v1alpha1 - -import ( - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/runtime" -) - -// GroupName is the group name use in this package -const GroupName = "componentconfig" - -// SchemeGroupVersion is group version used to register these objects -var SchemeGroupVersion = unversioned.GroupVersion{Group: GroupName, Version: "v1alpha1"} - -var ( - SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes, addDefaultingFuncs) - AddToScheme = SchemeBuilder.AddToScheme -) - -func addKnownTypes(scheme *runtime.Scheme) error { - scheme.AddKnownTypes(SchemeGroupVersion, - &KubeProxyConfiguration{}, - &KubeSchedulerConfiguration{}, - &KubeletConfiguration{}, - ) - return nil -} - -func (obj *KubeProxyConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } -func (obj *KubeSchedulerConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } -func (obj *KubeletConfiguration) GetObjectKind() unversioned.ObjectKind { return &obj.TypeMeta } diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/types.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/types.go deleted file mode 100644 index 4538fdf..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/types.go +++ /dev/null @@ -1,489 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package v1alpha1 - -import "k8s.io/kubernetes/pkg/api/unversioned" - -type KubeProxyConfiguration struct { - unversioned.TypeMeta - - // bindAddress is the IP address for the proxy server to serve on (set to 0.0.0.0 - // for all interfaces) - BindAddress string `json:"bindAddress"` - // clusterCIDR is the CIDR range of the pods in the cluster. It is used to - // bridge traffic coming from outside of the cluster. If not provided, - // no off-cluster bridging will be performed. - ClusterCIDR string `json:"clusterCIDR"` - // healthzBindAddress is the IP address for the health check server to serve on, - // defaulting to 127.0.0.1 (set to 0.0.0.0 for all interfaces) - HealthzBindAddress string `json:"healthzBindAddress"` - // healthzPort is the port to bind the health check server. Use 0 to disable. - HealthzPort int32 `json:"healthzPort"` - // hostnameOverride, if non-empty, will be used as the identity instead of the actual hostname. - HostnameOverride string `json:"hostnameOverride"` - // iptablesMasqueradeBit is the bit of the iptables fwmark space to use for SNAT if using - // the pure iptables proxy mode. Values must be within the range [0, 31]. - IPTablesMasqueradeBit *int32 `json:"iptablesMasqueradeBit"` - // iptablesSyncPeriod is the period that iptables rules are refreshed (e.g. '5s', '1m', - // '2h22m'). Must be greater than 0. - IPTablesSyncPeriod unversioned.Duration `json:"iptablesSyncPeriodSeconds"` - // kubeconfigPath is the path to the kubeconfig file with authorization information (the - // master location is set by the master flag). - KubeconfigPath string `json:"kubeconfigPath"` - // masqueradeAll tells kube-proxy to SNAT everything if using the pure iptables proxy mode. - MasqueradeAll bool `json:"masqueradeAll"` - // master is the address of the Kubernetes API server (overrides any value in kubeconfig) - Master string `json:"master"` - // oomScoreAdj is the oom-score-adj value for kube-proxy process. Values must be within - // the range [-1000, 1000] - OOMScoreAdj *int32 `json:"oomScoreAdj"` - // mode specifies which proxy mode to use. - Mode ProxyMode `json:"mode"` - // portRange is the range of host ports (beginPort-endPort, inclusive) that may be consumed - // in order to proxy service traffic. If unspecified (0-0) then ports will be randomly chosen. - PortRange string `json:"portRange"` - // resourceContainer is the bsolute name of the resource-only container to create and run - // the Kube-proxy in (Default: /kube-proxy). - ResourceContainer string `json:"resourceContainer"` - // udpIdleTimeout is how long an idle UDP connection will be kept open (e.g. '250ms', '2s'). - // Must be greater than 0. Only applicable for proxyMode=userspace. - UDPIdleTimeout unversioned.Duration `json:"udpTimeoutMilliseconds"` - // conntrackMax is the maximum number of NAT connections to track (0 to - // leave as-is). This takes precedence over conntrackMaxPerCore and conntrackMin. - ConntrackMax int32 `json:"conntrackMax"` - // conntrackMaxPerCore is the maximum number of NAT connections to track - // per CPU core (0 to leave the limit as-is and ignore conntrackMin). - ConntrackMaxPerCore int32 `json:"conntrackMaxPerCore"` - // conntrackMin is the minimum value of connect-tracking records to allocate, - // regardless of conntrackMaxPerCore (set conntrackMaxPerCore=0 to leave the limit as-is). - ConntrackMin int32 `json:"conntrackMin"` - // conntrackTCPEstablishedTimeout is how long an idle TCP connection will be kept open - // (e.g. '250ms', '2s'). Must be greater than 0. - ConntrackTCPEstablishedTimeout unversioned.Duration `json:"conntrackTCPEstablishedTimeout"` -} - -// Currently two modes of proxying are available: 'userspace' (older, stable) or 'iptables' -// (experimental). If blank, look at the Node object on the Kubernetes API and respect the -// 'net.experimental.kubernetes.io/proxy-mode' annotation if provided. Otherwise use the -// best-available proxy (currently userspace, but may change in future versions). If the -// iptables proxy is selected, regardless of how, but the system's kernel or iptables -// versions are insufficient, this always falls back to the userspace proxy. -type ProxyMode string - -const ( - ProxyModeUserspace ProxyMode = "userspace" - ProxyModeIPTables ProxyMode = "iptables" -) - -type KubeSchedulerConfiguration struct { - unversioned.TypeMeta - - // port is the port that the scheduler's http service runs on. - Port int `json:"port"` - // address is the IP address to serve on. - Address string `json:"address"` - // algorithmProvider is the scheduling algorithm provider to use. - AlgorithmProvider string `json:"algorithmProvider"` - // policyConfigFile is the filepath to the scheduler policy configuration. - PolicyConfigFile string `json:"policyConfigFile"` - // enableProfiling enables profiling via web interface. - EnableProfiling *bool `json:"enableProfiling"` - // contentType is contentType of requests sent to apiserver. - ContentType string `json:"contentType"` - // kubeAPIQPS is the QPS to use while talking with kubernetes apiserver. - KubeAPIQPS float32 `json:"kubeAPIQPS"` - // kubeAPIBurst is the QPS burst to use while talking with kubernetes apiserver. - KubeAPIBurst int `json:"kubeAPIBurst"` - // schedulerName is name of the scheduler, used to select which pods - // will be processed by this scheduler, based on pod's annotation with - // key 'scheduler.alpha.kubernetes.io/name'. - SchedulerName string `json:"schedulerName"` - // RequiredDuringScheduling affinity is not symmetric, but there is an implicit PreferredDuringScheduling affinity rule - // corresponding to every RequiredDuringScheduling affinity rule. - // HardPodAffinitySymmetricWeight represents the weight of implicit PreferredDuringScheduling affinity rule, in the range 0-100. - HardPodAffinitySymmetricWeight int `json:"hardPodAffinitySymmetricWeight"` - // Indicate the "all topologies" set for empty topologyKey when it's used for PreferredDuringScheduling pod anti-affinity. - FailureDomains string `json:"failureDomains"` - // leaderElection defines the configuration of leader election client. - LeaderElection LeaderElectionConfiguration `json:"leaderElection"` -} - -// HairpinMode denotes how the kubelet should configure networking to handle -// hairpin packets. -type HairpinMode string - -// Enum settings for different ways to handle hairpin packets. -const ( - // Set the hairpin flag on the veth of containers in the respective - // container runtime. - HairpinVeth = "hairpin-veth" - // Make the container bridge promiscuous. This will force it to accept - // hairpin packets, even if the flag isn't set on ports of the bridge. - PromiscuousBridge = "promiscuous-bridge" - // Neither of the above. If the kubelet is started in this hairpin mode - // and kube-proxy is running in iptables mode, hairpin packets will be - // dropped by the container bridge. - HairpinNone = "none" -) - -// LeaderElectionConfiguration defines the configuration of leader election -// clients for components that can run with leader election enabled. -type LeaderElectionConfiguration struct { - // leaderElect enables a leader election client to gain leadership - // before executing the main loop. Enable this when running replicated - // components for high availability. - LeaderElect *bool `json:"leaderElect"` - // leaseDuration is the duration that non-leader candidates will wait - // after observing a leadership renewal until attempting to acquire - // leadership of a led but unrenewed leader slot. This is effectively the - // maximum duration that a leader can be stopped before it is replaced - // by another candidate. This is only applicable if leader election is - // enabled. - LeaseDuration unversioned.Duration `json:"leaseDuration"` - // renewDeadline is the interval between attempts by the acting master to - // renew a leadership slot before it stops leading. This must be less - // than or equal to the lease duration. This is only applicable if leader - // election is enabled. - RenewDeadline unversioned.Duration `json:"renewDeadline"` - // retryPeriod is the duration the clients should wait between attempting - // acquisition and renewal of a leadership. This is only applicable if - // leader election is enabled. - RetryPeriod unversioned.Duration `json:"retryPeriod"` -} - -type KubeletConfiguration struct { - unversioned.TypeMeta - - // podManifestPath is the path to the directory containing pod manifests to - // run, or the path to a single manifest file - PodManifestPath string `json:"podManifestPath"` - // syncFrequency is the max period between synchronizing running - // containers and config - SyncFrequency unversioned.Duration `json:"syncFrequency"` - // fileCheckFrequency is the duration between checking config files for - // new data - FileCheckFrequency unversioned.Duration `json:"fileCheckFrequency"` - // httpCheckFrequency is the duration between checking http for new data - HTTPCheckFrequency unversioned.Duration `json:"httpCheckFrequency"` - // manifestURL is the URL for accessing the container manifest - ManifestURL string `json:"manifestURL"` - // manifestURLHeader is the HTTP header to use when accessing the manifest - // URL, with the key separated from the value with a ':', as in 'key:value' - ManifestURLHeader string `json:"manifestURLHeader"` - // enableServer enables the Kubelet's server - EnableServer *bool `json:"enableServer"` - // address is the IP address for the Kubelet to serve on (set to 0.0.0.0 - // for all interfaces) - Address string `json:"address"` - // port is the port for the Kubelet to serve on. - Port int32 `json:"port"` - // readOnlyPort is the read-only port for the Kubelet to serve on with - // no authentication/authorization (set to 0 to disable) - ReadOnlyPort int32 `json:"readOnlyPort"` - // tlsCertFile is the file containing x509 Certificate for HTTPS. (CA cert, - // if any, concatenated after server cert). If tlsCertFile and - // tlsPrivateKeyFile are not provided, a self-signed certificate - // and key are generated for the public address and saved to the directory - // passed to certDir. - TLSCertFile string `json:"tlsCertFile"` - // tlsPrivateKeyFile is the ile containing x509 private key matching - // tlsCertFile. - TLSPrivateKeyFile string `json:"tlsPrivateKeyFile"` - // certDirectory is the directory where the TLS certs are located (by - // default /var/run/kubernetes). If tlsCertFile and tlsPrivateKeyFile - // are provided, this flag will be ignored. - CertDirectory string `json:"certDirectory"` - // hostnameOverride is the hostname used to identify the kubelet instead - // of the actual hostname. - HostnameOverride string `json:"hostnameOverride"` - // podInfraContainerImage is the image whose network/ipc namespaces - // containers in each pod will use. - PodInfraContainerImage string `json:"podInfraContainerImage"` - // dockerEndpoint is the path to the docker endpoint to communicate with. - DockerEndpoint string `json:"dockerEndpoint"` - // rootDirectory is the directory path to place kubelet files (volume - // mounts,etc). - RootDirectory string `json:"rootDirectory"` - // seccompProfileRoot is the directory path for seccomp profiles. - SeccompProfileRoot string `json:"seccompProfileRoot"` - // allowPrivileged enables containers to request privileged mode. - // Defaults to false. - AllowPrivileged *bool `json:"allowPrivileged"` - // hostNetworkSources is a comma-separated list of sources from which the - // Kubelet allows pods to use of host network. Defaults to "*". Valid - // options are "file", "http", "api", and "*" (all sources). - HostNetworkSources []string `json:"hostNetworkSources"` - // hostPIDSources is a comma-separated list of sources from which the - // Kubelet allows pods to use the host pid namespace. Defaults to "*". - HostPIDSources []string `json:"hostPIDSources"` - // hostIPCSources is a comma-separated list of sources from which the - // Kubelet allows pods to use the host ipc namespace. Defaults to "*". - HostIPCSources []string `json:"hostIPCSources"` - // registryPullQPS is the limit of registry pulls per second. If 0, - // unlimited. Set to 0 for no limit. Defaults to 5.0. - RegistryPullQPS *int32 `json:"registryPullQPS"` - // registryBurst is the maximum size of a bursty pulls, temporarily allows - // pulls to burst to this number, while still not exceeding registryQps. - // Only used if registryQPS > 0. - RegistryBurst int32 `json:"registryBurst"` - // eventRecordQPS is the maximum event creations per second. If 0, there - // is no limit enforced. - EventRecordQPS *int32 `json:"eventRecordQPS"` - // eventBurst is the maximum size of a bursty event records, temporarily - // allows event records to burst to this number, while still not exceeding - // event-qps. Only used if eventQps > 0 - EventBurst int32 `json:"eventBurst"` - // enableDebuggingHandlers enables server endpoints for log collection - // and local running of containers and commands - EnableDebuggingHandlers *bool `json:"enableDebuggingHandlers"` - // minimumGCAge is the minimum age for a finished container before it is - // garbage collected. - MinimumGCAge unversioned.Duration `json:"minimumGCAge"` - // maxPerPodContainerCount is the maximum number of old instances to - // retain per container. Each container takes up some disk space. - MaxPerPodContainerCount int32 `json:"maxPerPodContainerCount"` - // maxContainerCount is the maximum number of old instances of containers - // to retain globally. Each container takes up some disk space. - MaxContainerCount *int32 `json:"maxContainerCount"` - // cAdvisorPort is the port of the localhost cAdvisor endpoint - CAdvisorPort int32 `json:"cAdvisorPort"` - // healthzPort is the port of the localhost healthz endpoint - HealthzPort int32 `json:"healthzPort"` - // healthzBindAddress is the IP address for the healthz server to serve - // on. - HealthzBindAddress string `json:"healthzBindAddress"` - // oomScoreAdj is The oom-score-adj value for kubelet process. Values - // must be within the range [-1000, 1000]. - OOMScoreAdj *int32 `json:"oomScoreAdj"` - // registerNode enables automatic registration with the apiserver. - RegisterNode *bool `json:"registerNode"` - // clusterDomain is the DNS domain for this cluster. If set, kubelet will - // configure all containers to search this domain in addition to the - // host's search domains. - ClusterDomain string `json:"clusterDomain"` - // masterServiceNamespace is The namespace from which the kubernetes - // master services should be injected into pods. - MasterServiceNamespace string `json:"masterServiceNamespace"` - // clusterDNS is the IP address for a cluster DNS server. If set, kubelet - // will configure all containers to use this for DNS resolution in - // addition to the host's DNS servers - ClusterDNS string `json:"clusterDNS"` - // streamingConnectionIdleTimeout is the maximum time a streaming connection - // can be idle before the connection is automatically closed. - StreamingConnectionIdleTimeout unversioned.Duration `json:"streamingConnectionIdleTimeout"` - // nodeStatusUpdateFrequency is the frequency that kubelet posts node - // status to master. Note: be cautious when changing the constant, it - // must work with nodeMonitorGracePeriod in nodecontroller. - NodeStatusUpdateFrequency unversioned.Duration `json:"nodeStatusUpdateFrequency"` - // imageMinimumGCAge is the minimum age for an unused image before it is - // garbage collected. - ImageMinimumGCAge unversioned.Duration `json:"imageMinimumGCAge"` - // imageGCHighThresholdPercent is the percent of disk usage after which - // image garbage collection is always run. The percent is calculated as - // this field value out of 100. - ImageGCHighThresholdPercent *int32 `json:"imageGCHighThresholdPercent"` - // imageGCLowThresholdPercent is the percent of disk usage before which - // image garbage collection is never run. Lowest disk usage to garbage - // collect to. The percent is calculated as this field value out of 100. - ImageGCLowThresholdPercent *int32 `json:"imageGCLowThresholdPercent"` - // lowDiskSpaceThresholdMB is the absolute free disk space, in MB, to - // maintain. When disk space falls below this threshold, new pods would - // be rejected. - LowDiskSpaceThresholdMB int32 `json:"lowDiskSpaceThresholdMB"` - // How frequently to calculate and cache volume disk usage for all pods - VolumeStatsAggPeriod unversioned.Duration `json:"volumeStatsAggPeriod"` - // networkPluginName is the name of the network plugin to be invoked for - // various events in kubelet/pod lifecycle - NetworkPluginName string `json:"networkPluginName"` - // networkPluginDir is the full path of the directory in which to search - // for network plugins (and, for backwards-compat, CNI config files) - NetworkPluginDir string `json:"networkPluginDir"` - // CNIConfDir is the full path of the directory in which to search for - // CNI config files - CNIConfDir string `json:"cniConfDir"` - // CNIBinDir is the full path of the directory in which to search for - // CNI plugin binaries - CNIBinDir string `json:"cniBinDir"` - // networkPluginMTU is the MTU to be passed to the network plugin, - // and overrides the default MTU for cases where it cannot be automatically - // computed (such as IPSEC). - NetworkPluginMTU int32 `json:"networkPluginMTU"` - // volumePluginDir is the full path of the directory in which to search - // for additional third party volume plugins - VolumePluginDir string `json:"volumePluginDir"` - // cloudProvider is the provider for cloud services. - CloudProvider string `json:"cloudProvider"` - // cloudConfigFile is the path to the cloud provider configuration file. - CloudConfigFile string `json:"cloudConfigFile"` - // kubeletCgroups is the absolute name of cgroups to isolate the kubelet in. - KubeletCgroups string `json:"kubeletCgroups"` - // runtimeCgroups are cgroups that container runtime is expected to be isolated in. - RuntimeCgroups string `json:"runtimeCgroups"` - // systemCgroups is absolute name of cgroups in which to place - // all non-kernel processes that are not already in a container. Empty - // for no container. Rolling back the flag requires a reboot. - SystemCgroups string `json:"systemCgroups"` - // cgroupRoot is the root cgroup to use for pods. This is handled by the - // container runtime on a best effort basis. - CgroupRoot string `json:"cgroupRoot"` - // Enable QoS based Cgroup hierarchy: top level cgroups for QoS Classes - // And all Burstable and BestEffort pods are brought up under their - // specific top level QoS cgroup. - CgroupsPerQOS *bool `json:"cgroupsPerQOS,omitempty"` - // driver that the kubelet uses to manipulate cgroups on the host (cgroupfs or systemd) - CgroupDriver string `json:"cgroupDriver,omitempty"` - // containerRuntime is the container runtime to use. - ContainerRuntime string `json:"containerRuntime"` - // remoteRuntimeEndpoint is the endpoint of remote runtime service - RemoteRuntimeEndpoint string `json:"remoteRuntimeEndpoint"` - // remoteImageEndpoint is the endpoint of remote image service - RemoteImageEndpoint string `json:"remoteImageEndpoint"` - // runtimeRequestTimeout is the timeout for all runtime requests except long running - // requests - pull, logs, exec and attach. - RuntimeRequestTimeout unversioned.Duration `json:"runtimeRequestTimeout"` - // rktPath is the path of rkt binary. Leave empty to use the first rkt in - // $PATH. - RktPath string `json:"rktPath"` - // rktApiEndpoint is the endpoint of the rkt API service to communicate with. - RktAPIEndpoint string `json:"rktAPIEndpoint"` - // rktStage1Image is the image to use as stage1. Local paths and - // http/https URLs are supported. - RktStage1Image string `json:"rktStage1Image"` - // lockFilePath is the path that kubelet will use to as a lock file. - // It uses this file as a lock to synchronize with other kubelet processes - // that may be running. - LockFilePath *string `json:"lockFilePath"` - // ExitOnLockContention is a flag that signifies to the kubelet that it is running - // in "bootstrap" mode. This requires that 'LockFilePath' has been set. - // This will cause the kubelet to listen to inotify events on the lock file, - // releasing it and exiting when another process tries to open that file. - ExitOnLockContention bool `json:"exitOnLockContention"` - // configureCBR0 enables the kublet to configure cbr0 based on - // Node.Spec.PodCIDR. - ConfigureCBR0 *bool `json:"configureCbr0"` - // How should the kubelet configure the container bridge for hairpin packets. - // Setting this flag allows endpoints in a Service to loadbalance back to - // themselves if they should try to access their own Service. Values: - // "promiscuous-bridge": make the container bridge promiscuous. - // "hairpin-veth": set the hairpin flag on container veth interfaces. - // "none": do nothing. - // Setting --configure-cbr0 to false implies that to achieve hairpin NAT - // one must set --hairpin-mode=veth-flag, because bridge assumes the - // existence of a container bridge named cbr0. - HairpinMode string `json:"hairpinMode"` - // The node has babysitter process monitoring docker and kubelet. - BabysitDaemons bool `json:"babysitDaemons"` - // maxPods is the number of pods that can run on this Kubelet. - MaxPods int32 `json:"maxPods"` - // nvidiaGPUs is the number of NVIDIA GPU devices on this node. - NvidiaGPUs int32 `json:"nvidiaGPUs"` - // dockerExecHandlerName is the handler to use when executing a command - // in a container. Valid values are 'native' and 'nsenter'. Defaults to - // 'native'. - DockerExecHandlerName string `json:"dockerExecHandlerName"` - // The CIDR to use for pod IP addresses, only used in standalone mode. - // In cluster mode, this is obtained from the master. - PodCIDR string `json:"podCIDR"` - // ResolverConfig is the resolver configuration file used as the basis - // for the container DNS resolution configuration."), [] - ResolverConfig string `json:"resolvConf"` - // cpuCFSQuota is Enable CPU CFS quota enforcement for containers that - // specify CPU limits - CPUCFSQuota *bool `json:"cpuCFSQuota"` - // containerized should be set to true if kubelet is running in a container. - Containerized *bool `json:"containerized"` - // maxOpenFiles is Number of files that can be opened by Kubelet process. - MaxOpenFiles int64 `json:"maxOpenFiles"` - // reconcileCIDR is Reconcile node CIDR with the CIDR specified by the - // API server. No-op if register-node or configure-cbr0 is false. - ReconcileCIDR *bool `json:"reconcileCIDR"` - // registerSchedulable tells the kubelet to register the node as - // schedulable. No-op if register-node is false. - RegisterSchedulable *bool `json:"registerSchedulable"` - // contentType is contentType of requests sent to apiserver. - ContentType string `json:"contentType"` - // kubeAPIQPS is the QPS to use while talking with kubernetes apiserver - KubeAPIQPS *int32 `json:"kubeAPIQPS"` - // kubeAPIBurst is the burst to allow while talking with kubernetes - // apiserver - KubeAPIBurst int32 `json:"kubeAPIBurst"` - // serializeImagePulls when enabled, tells the Kubelet to pull images one - // at a time. We recommend *not* changing the default value on nodes that - // run docker daemon with version < 1.9 or an Aufs storage backend. - // Issue #10959 has more details. - SerializeImagePulls *bool `json:"serializeImagePulls"` - // outOfDiskTransitionFrequency is duration for which the kubelet has to - // wait before transitioning out of out-of-disk node condition status. - OutOfDiskTransitionFrequency unversioned.Duration `json:"outOfDiskTransitionFrequency"` - // nodeIP is IP address of the node. If set, kubelet will use this IP - // address for the node. - NodeIP string `json:"nodeIP"` - // nodeLabels to add when registering the node in the cluster. - NodeLabels map[string]string `json:"nodeLabels"` - // nonMasqueradeCIDR configures masquerading: traffic to IPs outside this range will use IP masquerade. - NonMasqueradeCIDR string `json:"nonMasqueradeCIDR"` - // enable gathering custom metrics. - EnableCustomMetrics bool `json:"enableCustomMetrics"` - // Comma-delimited list of hard eviction expressions. For example, 'memory.available<300Mi'. - EvictionHard *string `json:"evictionHard"` - // Comma-delimited list of soft eviction expressions. For example, 'memory.available<300Mi'. - EvictionSoft string `json:"evictionSoft"` - // Comma-delimeted list of grace periods for each soft eviction signal. For example, 'memory.available=30s'. - EvictionSoftGracePeriod string `json:"evictionSoftGracePeriod"` - // Duration for which the kubelet has to wait before transitioning out of an eviction pressure condition. - EvictionPressureTransitionPeriod unversioned.Duration `json:"evictionPressureTransitionPeriod"` - // Maximum allowed grace period (in seconds) to use when terminating pods in response to a soft eviction threshold being met. - EvictionMaxPodGracePeriod int32 `json:"evictionMaxPodGracePeriod"` - // Comma-delimited list of minimum reclaims (e.g. imagefs.available=2Gi) that describes the minimum amount of resource the kubelet will reclaim when performing a pod eviction if that resource is under pressure. - EvictionMinimumReclaim string `json:"evictionMinimumReclaim"` - // Maximum number of pods per core. Cannot exceed MaxPods - PodsPerCore int32 `json:"podsPerCore"` - // enableControllerAttachDetach enables the Attach/Detach controller to - // manage attachment/detachment of volumes scheduled to this node, and - // disables kubelet from executing any attach/detach operations - EnableControllerAttachDetach *bool `json:"enableControllerAttachDetach"` - // A set of ResourceName=ResourceQuantity (e.g. cpu=200m,memory=150G) pairs - // that describe resources reserved for non-kubernetes components. - // Currently only cpu and memory are supported. [default=none] - // See http://kubernetes.io/docs/user-guide/compute-resources for more detail. - SystemReserved map[string]string `json:"systemReserved"` - // A set of ResourceName=ResourceQuantity (e.g. cpu=200m,memory=150G) pairs - // that describe resources reserved for kubernetes system components. - // Currently only cpu and memory are supported. [default=none] - // See http://kubernetes.io/docs/user-guide/compute-resources for more detail. - KubeReserved map[string]string `json:"kubeReserved"` - // Default behaviour for kernel tuning - ProtectKernelDefaults bool `json:"protectKernelDefaults"` - // If true, Kubelet ensures a set of iptables rules are present on host. - // These rules will serve as utility rules for various components, e.g. KubeProxy. - // The rules will be created based on IPTablesMasqueradeBit and IPTablesDropBit. - MakeIPTablesUtilChains *bool `json:"makeIPTablesUtilChains"` - // iptablesMasqueradeBit is the bit of the iptables fwmark space to mark for SNAT - // Values must be within the range [0, 31]. Must be different from other mark bits. - // Warning: Please match the value of corresponding parameter in kube-proxy - // TODO: clean up IPTablesMasqueradeBit in kube-proxy - IPTablesMasqueradeBit *int32 `json:"iptablesMasqueradeBit"` - // iptablesDropBit is the bit of the iptables fwmark space to mark for dropping packets. - // Values must be within the range [0, 31]. Must be different from other mark bits. - IPTablesDropBit *int32 `json:"iptablesDropBit"` - // Whitelist of unsafe sysctls or sysctl patterns (ending in *). Use these at your own risk. - // Resource isolation might be lacking and pod might influence each other on the same node. - AllowedUnsafeSysctls []string `json:"allowedUnsafeSysctls,omitempty"` - // How to integrate with runtime. If set to CRI, kubelet will switch to - // using the new Container Runtine Interface. - ExperimentalRuntimeIntegrationType string `json:"experimentalRuntimeIntegrationType,omitempty"` -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.conversion.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.conversion.go deleted file mode 100644 index ea00f46..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.conversion.go +++ /dev/null @@ -1,556 +0,0 @@ -// +build !ignore_autogenerated - -/* -Copyright 2016 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. -*/ - -// This file was autogenerated by conversion-gen. Do not edit it manually! - -package v1alpha1 - -import ( - api "k8s.io/kubernetes/pkg/api" - componentconfig "k8s.io/kubernetes/pkg/apis/componentconfig" - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - config "k8s.io/kubernetes/pkg/util/config" -) - -func init() { - SchemeBuilder.Register(RegisterConversions) -} - -// RegisterConversions adds conversion functions to the given scheme. -// Public to allow building arbitrary schemes. -func RegisterConversions(scheme *runtime.Scheme) error { - return scheme.AddGeneratedConversionFuncs( - Convert_v1alpha1_KubeProxyConfiguration_To_componentconfig_KubeProxyConfiguration, - Convert_componentconfig_KubeProxyConfiguration_To_v1alpha1_KubeProxyConfiguration, - Convert_v1alpha1_KubeSchedulerConfiguration_To_componentconfig_KubeSchedulerConfiguration, - Convert_componentconfig_KubeSchedulerConfiguration_To_v1alpha1_KubeSchedulerConfiguration, - Convert_v1alpha1_KubeletConfiguration_To_componentconfig_KubeletConfiguration, - Convert_componentconfig_KubeletConfiguration_To_v1alpha1_KubeletConfiguration, - Convert_v1alpha1_LeaderElectionConfiguration_To_componentconfig_LeaderElectionConfiguration, - Convert_componentconfig_LeaderElectionConfiguration_To_v1alpha1_LeaderElectionConfiguration, - ) -} - -func autoConvert_v1alpha1_KubeProxyConfiguration_To_componentconfig_KubeProxyConfiguration(in *KubeProxyConfiguration, out *componentconfig.KubeProxyConfiguration, s conversion.Scope) error { - SetDefaults_KubeProxyConfiguration(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.BindAddress = in.BindAddress - out.ClusterCIDR = in.ClusterCIDR - out.HealthzBindAddress = in.HealthzBindAddress - out.HealthzPort = in.HealthzPort - out.HostnameOverride = in.HostnameOverride - out.IPTablesMasqueradeBit = in.IPTablesMasqueradeBit - out.IPTablesSyncPeriod = in.IPTablesSyncPeriod - out.KubeconfigPath = in.KubeconfigPath - out.MasqueradeAll = in.MasqueradeAll - out.Master = in.Master - out.OOMScoreAdj = in.OOMScoreAdj - out.Mode = componentconfig.ProxyMode(in.Mode) - out.PortRange = in.PortRange - out.ResourceContainer = in.ResourceContainer - out.UDPIdleTimeout = in.UDPIdleTimeout - out.ConntrackMax = in.ConntrackMax - out.ConntrackMaxPerCore = in.ConntrackMaxPerCore - out.ConntrackMin = in.ConntrackMin - out.ConntrackTCPEstablishedTimeout = in.ConntrackTCPEstablishedTimeout - return nil -} - -func Convert_v1alpha1_KubeProxyConfiguration_To_componentconfig_KubeProxyConfiguration(in *KubeProxyConfiguration, out *componentconfig.KubeProxyConfiguration, s conversion.Scope) error { - return autoConvert_v1alpha1_KubeProxyConfiguration_To_componentconfig_KubeProxyConfiguration(in, out, s) -} - -func autoConvert_componentconfig_KubeProxyConfiguration_To_v1alpha1_KubeProxyConfiguration(in *componentconfig.KubeProxyConfiguration, out *KubeProxyConfiguration, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.BindAddress = in.BindAddress - out.ClusterCIDR = in.ClusterCIDR - out.HealthzBindAddress = in.HealthzBindAddress - out.HealthzPort = in.HealthzPort - out.HostnameOverride = in.HostnameOverride - out.IPTablesMasqueradeBit = in.IPTablesMasqueradeBit - out.IPTablesSyncPeriod = in.IPTablesSyncPeriod - out.KubeconfigPath = in.KubeconfigPath - out.MasqueradeAll = in.MasqueradeAll - out.Master = in.Master - out.OOMScoreAdj = in.OOMScoreAdj - out.Mode = ProxyMode(in.Mode) - out.PortRange = in.PortRange - out.ResourceContainer = in.ResourceContainer - out.UDPIdleTimeout = in.UDPIdleTimeout - out.ConntrackMax = in.ConntrackMax - out.ConntrackMaxPerCore = in.ConntrackMaxPerCore - out.ConntrackMin = in.ConntrackMin - out.ConntrackTCPEstablishedTimeout = in.ConntrackTCPEstablishedTimeout - return nil -} - -func Convert_componentconfig_KubeProxyConfiguration_To_v1alpha1_KubeProxyConfiguration(in *componentconfig.KubeProxyConfiguration, out *KubeProxyConfiguration, s conversion.Scope) error { - return autoConvert_componentconfig_KubeProxyConfiguration_To_v1alpha1_KubeProxyConfiguration(in, out, s) -} - -func autoConvert_v1alpha1_KubeSchedulerConfiguration_To_componentconfig_KubeSchedulerConfiguration(in *KubeSchedulerConfiguration, out *componentconfig.KubeSchedulerConfiguration, s conversion.Scope) error { - SetDefaults_KubeSchedulerConfiguration(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.Port = int32(in.Port) - out.Address = in.Address - out.AlgorithmProvider = in.AlgorithmProvider - out.PolicyConfigFile = in.PolicyConfigFile - if err := api.Convert_Pointer_bool_To_bool(&in.EnableProfiling, &out.EnableProfiling, s); err != nil { - return err - } - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = int32(in.KubeAPIBurst) - out.SchedulerName = in.SchedulerName - out.HardPodAffinitySymmetricWeight = in.HardPodAffinitySymmetricWeight - out.FailureDomains = in.FailureDomains - if err := Convert_v1alpha1_LeaderElectionConfiguration_To_componentconfig_LeaderElectionConfiguration(&in.LeaderElection, &out.LeaderElection, s); err != nil { - return err - } - return nil -} - -func Convert_v1alpha1_KubeSchedulerConfiguration_To_componentconfig_KubeSchedulerConfiguration(in *KubeSchedulerConfiguration, out *componentconfig.KubeSchedulerConfiguration, s conversion.Scope) error { - return autoConvert_v1alpha1_KubeSchedulerConfiguration_To_componentconfig_KubeSchedulerConfiguration(in, out, s) -} - -func autoConvert_componentconfig_KubeSchedulerConfiguration_To_v1alpha1_KubeSchedulerConfiguration(in *componentconfig.KubeSchedulerConfiguration, out *KubeSchedulerConfiguration, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.Port = int(in.Port) - out.Address = in.Address - out.AlgorithmProvider = in.AlgorithmProvider - out.PolicyConfigFile = in.PolicyConfigFile - if err := api.Convert_bool_To_Pointer_bool(&in.EnableProfiling, &out.EnableProfiling, s); err != nil { - return err - } - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = int(in.KubeAPIBurst) - out.SchedulerName = in.SchedulerName - out.HardPodAffinitySymmetricWeight = in.HardPodAffinitySymmetricWeight - out.FailureDomains = in.FailureDomains - if err := Convert_componentconfig_LeaderElectionConfiguration_To_v1alpha1_LeaderElectionConfiguration(&in.LeaderElection, &out.LeaderElection, s); err != nil { - return err - } - return nil -} - -func Convert_componentconfig_KubeSchedulerConfiguration_To_v1alpha1_KubeSchedulerConfiguration(in *componentconfig.KubeSchedulerConfiguration, out *KubeSchedulerConfiguration, s conversion.Scope) error { - return autoConvert_componentconfig_KubeSchedulerConfiguration_To_v1alpha1_KubeSchedulerConfiguration(in, out, s) -} - -func autoConvert_v1alpha1_KubeletConfiguration_To_componentconfig_KubeletConfiguration(in *KubeletConfiguration, out *componentconfig.KubeletConfiguration, s conversion.Scope) error { - SetDefaults_KubeletConfiguration(in) - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.PodManifestPath = in.PodManifestPath - out.SyncFrequency = in.SyncFrequency - out.FileCheckFrequency = in.FileCheckFrequency - out.HTTPCheckFrequency = in.HTTPCheckFrequency - out.ManifestURL = in.ManifestURL - out.ManifestURLHeader = in.ManifestURLHeader - if err := api.Convert_Pointer_bool_To_bool(&in.EnableServer, &out.EnableServer, s); err != nil { - return err - } - out.Address = in.Address - out.Port = in.Port - out.ReadOnlyPort = in.ReadOnlyPort - out.TLSCertFile = in.TLSCertFile - out.TLSPrivateKeyFile = in.TLSPrivateKeyFile - out.CertDirectory = in.CertDirectory - out.HostnameOverride = in.HostnameOverride - out.PodInfraContainerImage = in.PodInfraContainerImage - out.DockerEndpoint = in.DockerEndpoint - out.RootDirectory = in.RootDirectory - out.SeccompProfileRoot = in.SeccompProfileRoot - if err := api.Convert_Pointer_bool_To_bool(&in.AllowPrivileged, &out.AllowPrivileged, s); err != nil { - return err - } - out.HostNetworkSources = in.HostNetworkSources - out.HostPIDSources = in.HostPIDSources - out.HostIPCSources = in.HostIPCSources - if err := api.Convert_Pointer_int32_To_int32(&in.RegistryPullQPS, &out.RegistryPullQPS, s); err != nil { - return err - } - out.RegistryBurst = in.RegistryBurst - if err := api.Convert_Pointer_int32_To_int32(&in.EventRecordQPS, &out.EventRecordQPS, s); err != nil { - return err - } - out.EventBurst = in.EventBurst - if err := api.Convert_Pointer_bool_To_bool(&in.EnableDebuggingHandlers, &out.EnableDebuggingHandlers, s); err != nil { - return err - } - out.MinimumGCAge = in.MinimumGCAge - out.MaxPerPodContainerCount = in.MaxPerPodContainerCount - if err := api.Convert_Pointer_int32_To_int32(&in.MaxContainerCount, &out.MaxContainerCount, s); err != nil { - return err - } - out.CAdvisorPort = in.CAdvisorPort - out.HealthzPort = in.HealthzPort - out.HealthzBindAddress = in.HealthzBindAddress - if err := api.Convert_Pointer_int32_To_int32(&in.OOMScoreAdj, &out.OOMScoreAdj, s); err != nil { - return err - } - if err := api.Convert_Pointer_bool_To_bool(&in.RegisterNode, &out.RegisterNode, s); err != nil { - return err - } - out.ClusterDomain = in.ClusterDomain - out.MasterServiceNamespace = in.MasterServiceNamespace - out.ClusterDNS = in.ClusterDNS - out.StreamingConnectionIdleTimeout = in.StreamingConnectionIdleTimeout - out.NodeStatusUpdateFrequency = in.NodeStatusUpdateFrequency - out.ImageMinimumGCAge = in.ImageMinimumGCAge - if err := api.Convert_Pointer_int32_To_int32(&in.ImageGCHighThresholdPercent, &out.ImageGCHighThresholdPercent, s); err != nil { - return err - } - if err := api.Convert_Pointer_int32_To_int32(&in.ImageGCLowThresholdPercent, &out.ImageGCLowThresholdPercent, s); err != nil { - return err - } - out.LowDiskSpaceThresholdMB = in.LowDiskSpaceThresholdMB - out.VolumeStatsAggPeriod = in.VolumeStatsAggPeriod - out.NetworkPluginName = in.NetworkPluginName - out.NetworkPluginDir = in.NetworkPluginDir - out.CNIConfDir = in.CNIConfDir - out.CNIBinDir = in.CNIBinDir - out.NetworkPluginMTU = in.NetworkPluginMTU - out.VolumePluginDir = in.VolumePluginDir - out.CloudProvider = in.CloudProvider - out.CloudConfigFile = in.CloudConfigFile - out.KubeletCgroups = in.KubeletCgroups - out.RuntimeCgroups = in.RuntimeCgroups - out.SystemCgroups = in.SystemCgroups - out.CgroupRoot = in.CgroupRoot - if err := api.Convert_Pointer_bool_To_bool(&in.CgroupsPerQOS, &out.CgroupsPerQOS, s); err != nil { - return err - } - out.CgroupDriver = in.CgroupDriver - out.ContainerRuntime = in.ContainerRuntime - out.RemoteRuntimeEndpoint = in.RemoteRuntimeEndpoint - out.RemoteImageEndpoint = in.RemoteImageEndpoint - out.RuntimeRequestTimeout = in.RuntimeRequestTimeout - out.RktPath = in.RktPath - out.RktAPIEndpoint = in.RktAPIEndpoint - out.RktStage1Image = in.RktStage1Image - if err := api.Convert_Pointer_string_To_string(&in.LockFilePath, &out.LockFilePath, s); err != nil { - return err - } - out.ExitOnLockContention = in.ExitOnLockContention - if err := api.Convert_Pointer_bool_To_bool(&in.ConfigureCBR0, &out.ConfigureCBR0, s); err != nil { - return err - } - out.HairpinMode = in.HairpinMode - out.BabysitDaemons = in.BabysitDaemons - out.MaxPods = in.MaxPods - out.NvidiaGPUs = in.NvidiaGPUs - out.DockerExecHandlerName = in.DockerExecHandlerName - out.PodCIDR = in.PodCIDR - out.ResolverConfig = in.ResolverConfig - if err := api.Convert_Pointer_bool_To_bool(&in.CPUCFSQuota, &out.CPUCFSQuota, s); err != nil { - return err - } - if err := api.Convert_Pointer_bool_To_bool(&in.Containerized, &out.Containerized, s); err != nil { - return err - } - out.MaxOpenFiles = in.MaxOpenFiles - if err := api.Convert_Pointer_bool_To_bool(&in.ReconcileCIDR, &out.ReconcileCIDR, s); err != nil { - return err - } - if err := api.Convert_Pointer_bool_To_bool(&in.RegisterSchedulable, &out.RegisterSchedulable, s); err != nil { - return err - } - out.ContentType = in.ContentType - if err := api.Convert_Pointer_int32_To_int32(&in.KubeAPIQPS, &out.KubeAPIQPS, s); err != nil { - return err - } - out.KubeAPIBurst = in.KubeAPIBurst - if err := api.Convert_Pointer_bool_To_bool(&in.SerializeImagePulls, &out.SerializeImagePulls, s); err != nil { - return err - } - out.OutOfDiskTransitionFrequency = in.OutOfDiskTransitionFrequency - out.NodeIP = in.NodeIP - out.NodeLabels = in.NodeLabels - out.NonMasqueradeCIDR = in.NonMasqueradeCIDR - out.EnableCustomMetrics = in.EnableCustomMetrics - if err := api.Convert_Pointer_string_To_string(&in.EvictionHard, &out.EvictionHard, s); err != nil { - return err - } - out.EvictionSoft = in.EvictionSoft - out.EvictionSoftGracePeriod = in.EvictionSoftGracePeriod - out.EvictionPressureTransitionPeriod = in.EvictionPressureTransitionPeriod - out.EvictionMaxPodGracePeriod = in.EvictionMaxPodGracePeriod - out.EvictionMinimumReclaim = in.EvictionMinimumReclaim - out.PodsPerCore = in.PodsPerCore - if err := api.Convert_Pointer_bool_To_bool(&in.EnableControllerAttachDetach, &out.EnableControllerAttachDetach, s); err != nil { - return err - } - if in.SystemReserved != nil { - in, out := &in.SystemReserved, &out.SystemReserved - *out = make(config.ConfigurationMap, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.SystemReserved = nil - } - if in.KubeReserved != nil { - in, out := &in.KubeReserved, &out.KubeReserved - *out = make(config.ConfigurationMap, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.KubeReserved = nil - } - out.ProtectKernelDefaults = in.ProtectKernelDefaults - if err := api.Convert_Pointer_bool_To_bool(&in.MakeIPTablesUtilChains, &out.MakeIPTablesUtilChains, s); err != nil { - return err - } - if err := api.Convert_Pointer_int32_To_int32(&in.IPTablesMasqueradeBit, &out.IPTablesMasqueradeBit, s); err != nil { - return err - } - if err := api.Convert_Pointer_int32_To_int32(&in.IPTablesDropBit, &out.IPTablesDropBit, s); err != nil { - return err - } - out.AllowedUnsafeSysctls = in.AllowedUnsafeSysctls - out.ExperimentalRuntimeIntegrationType = in.ExperimentalRuntimeIntegrationType - return nil -} - -func Convert_v1alpha1_KubeletConfiguration_To_componentconfig_KubeletConfiguration(in *KubeletConfiguration, out *componentconfig.KubeletConfiguration, s conversion.Scope) error { - return autoConvert_v1alpha1_KubeletConfiguration_To_componentconfig_KubeletConfiguration(in, out, s) -} - -func autoConvert_componentconfig_KubeletConfiguration_To_v1alpha1_KubeletConfiguration(in *componentconfig.KubeletConfiguration, out *KubeletConfiguration, s conversion.Scope) error { - if err := api.Convert_unversioned_TypeMeta_To_unversioned_TypeMeta(&in.TypeMeta, &out.TypeMeta, s); err != nil { - return err - } - out.PodManifestPath = in.PodManifestPath - out.SyncFrequency = in.SyncFrequency - out.FileCheckFrequency = in.FileCheckFrequency - out.HTTPCheckFrequency = in.HTTPCheckFrequency - out.ManifestURL = in.ManifestURL - out.ManifestURLHeader = in.ManifestURLHeader - if err := api.Convert_bool_To_Pointer_bool(&in.EnableServer, &out.EnableServer, s); err != nil { - return err - } - out.Address = in.Address - out.Port = in.Port - out.ReadOnlyPort = in.ReadOnlyPort - out.TLSCertFile = in.TLSCertFile - out.TLSPrivateKeyFile = in.TLSPrivateKeyFile - out.CertDirectory = in.CertDirectory - out.HostnameOverride = in.HostnameOverride - out.PodInfraContainerImage = in.PodInfraContainerImage - out.DockerEndpoint = in.DockerEndpoint - out.RootDirectory = in.RootDirectory - out.SeccompProfileRoot = in.SeccompProfileRoot - if err := api.Convert_bool_To_Pointer_bool(&in.AllowPrivileged, &out.AllowPrivileged, s); err != nil { - return err - } - out.HostNetworkSources = in.HostNetworkSources - out.HostPIDSources = in.HostPIDSources - out.HostIPCSources = in.HostIPCSources - if err := api.Convert_int32_To_Pointer_int32(&in.RegistryPullQPS, &out.RegistryPullQPS, s); err != nil { - return err - } - out.RegistryBurst = in.RegistryBurst - if err := api.Convert_int32_To_Pointer_int32(&in.EventRecordQPS, &out.EventRecordQPS, s); err != nil { - return err - } - out.EventBurst = in.EventBurst - if err := api.Convert_bool_To_Pointer_bool(&in.EnableDebuggingHandlers, &out.EnableDebuggingHandlers, s); err != nil { - return err - } - out.MinimumGCAge = in.MinimumGCAge - out.MaxPerPodContainerCount = in.MaxPerPodContainerCount - if err := api.Convert_int32_To_Pointer_int32(&in.MaxContainerCount, &out.MaxContainerCount, s); err != nil { - return err - } - out.CAdvisorPort = in.CAdvisorPort - out.HealthzPort = in.HealthzPort - out.HealthzBindAddress = in.HealthzBindAddress - if err := api.Convert_int32_To_Pointer_int32(&in.OOMScoreAdj, &out.OOMScoreAdj, s); err != nil { - return err - } - if err := api.Convert_bool_To_Pointer_bool(&in.RegisterNode, &out.RegisterNode, s); err != nil { - return err - } - out.ClusterDomain = in.ClusterDomain - out.MasterServiceNamespace = in.MasterServiceNamespace - out.ClusterDNS = in.ClusterDNS - out.StreamingConnectionIdleTimeout = in.StreamingConnectionIdleTimeout - out.NodeStatusUpdateFrequency = in.NodeStatusUpdateFrequency - out.ImageMinimumGCAge = in.ImageMinimumGCAge - if err := api.Convert_int32_To_Pointer_int32(&in.ImageGCHighThresholdPercent, &out.ImageGCHighThresholdPercent, s); err != nil { - return err - } - if err := api.Convert_int32_To_Pointer_int32(&in.ImageGCLowThresholdPercent, &out.ImageGCLowThresholdPercent, s); err != nil { - return err - } - out.LowDiskSpaceThresholdMB = in.LowDiskSpaceThresholdMB - out.VolumeStatsAggPeriod = in.VolumeStatsAggPeriod - out.NetworkPluginName = in.NetworkPluginName - out.NetworkPluginMTU = in.NetworkPluginMTU - out.NetworkPluginDir = in.NetworkPluginDir - out.CNIConfDir = in.CNIConfDir - out.CNIBinDir = in.CNIBinDir - out.VolumePluginDir = in.VolumePluginDir - out.CloudProvider = in.CloudProvider - out.CloudConfigFile = in.CloudConfigFile - out.KubeletCgroups = in.KubeletCgroups - if err := api.Convert_bool_To_Pointer_bool(&in.CgroupsPerQOS, &out.CgroupsPerQOS, s); err != nil { - return err - } - out.CgroupDriver = in.CgroupDriver - out.RuntimeCgroups = in.RuntimeCgroups - out.SystemCgroups = in.SystemCgroups - out.CgroupRoot = in.CgroupRoot - out.ContainerRuntime = in.ContainerRuntime - out.RemoteRuntimeEndpoint = in.RemoteRuntimeEndpoint - out.RemoteImageEndpoint = in.RemoteImageEndpoint - out.RuntimeRequestTimeout = in.RuntimeRequestTimeout - out.RktPath = in.RktPath - out.RktAPIEndpoint = in.RktAPIEndpoint - out.RktStage1Image = in.RktStage1Image - if err := api.Convert_string_To_Pointer_string(&in.LockFilePath, &out.LockFilePath, s); err != nil { - return err - } - out.ExitOnLockContention = in.ExitOnLockContention - if err := api.Convert_bool_To_Pointer_bool(&in.ConfigureCBR0, &out.ConfigureCBR0, s); err != nil { - return err - } - out.HairpinMode = in.HairpinMode - out.BabysitDaemons = in.BabysitDaemons - out.MaxPods = in.MaxPods - out.NvidiaGPUs = in.NvidiaGPUs - out.DockerExecHandlerName = in.DockerExecHandlerName - out.PodCIDR = in.PodCIDR - out.ResolverConfig = in.ResolverConfig - if err := api.Convert_bool_To_Pointer_bool(&in.CPUCFSQuota, &out.CPUCFSQuota, s); err != nil { - return err - } - if err := api.Convert_bool_To_Pointer_bool(&in.Containerized, &out.Containerized, s); err != nil { - return err - } - out.MaxOpenFiles = in.MaxOpenFiles - if err := api.Convert_bool_To_Pointer_bool(&in.ReconcileCIDR, &out.ReconcileCIDR, s); err != nil { - return err - } - if err := api.Convert_bool_To_Pointer_bool(&in.RegisterSchedulable, &out.RegisterSchedulable, s); err != nil { - return err - } - out.ContentType = in.ContentType - if err := api.Convert_int32_To_Pointer_int32(&in.KubeAPIQPS, &out.KubeAPIQPS, s); err != nil { - return err - } - out.KubeAPIBurst = in.KubeAPIBurst - if err := api.Convert_bool_To_Pointer_bool(&in.SerializeImagePulls, &out.SerializeImagePulls, s); err != nil { - return err - } - out.OutOfDiskTransitionFrequency = in.OutOfDiskTransitionFrequency - out.NodeIP = in.NodeIP - out.NodeLabels = in.NodeLabels - out.NonMasqueradeCIDR = in.NonMasqueradeCIDR - out.EnableCustomMetrics = in.EnableCustomMetrics - if err := api.Convert_string_To_Pointer_string(&in.EvictionHard, &out.EvictionHard, s); err != nil { - return err - } - out.EvictionSoft = in.EvictionSoft - out.EvictionSoftGracePeriod = in.EvictionSoftGracePeriod - out.EvictionPressureTransitionPeriod = in.EvictionPressureTransitionPeriod - out.EvictionMaxPodGracePeriod = in.EvictionMaxPodGracePeriod - out.EvictionMinimumReclaim = in.EvictionMinimumReclaim - out.PodsPerCore = in.PodsPerCore - if err := api.Convert_bool_To_Pointer_bool(&in.EnableControllerAttachDetach, &out.EnableControllerAttachDetach, s); err != nil { - return err - } - if in.SystemReserved != nil { - in, out := &in.SystemReserved, &out.SystemReserved - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.SystemReserved = nil - } - if in.KubeReserved != nil { - in, out := &in.KubeReserved, &out.KubeReserved - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.KubeReserved = nil - } - out.ProtectKernelDefaults = in.ProtectKernelDefaults - if err := api.Convert_bool_To_Pointer_bool(&in.MakeIPTablesUtilChains, &out.MakeIPTablesUtilChains, s); err != nil { - return err - } - if err := api.Convert_int32_To_Pointer_int32(&in.IPTablesMasqueradeBit, &out.IPTablesMasqueradeBit, s); err != nil { - return err - } - if err := api.Convert_int32_To_Pointer_int32(&in.IPTablesDropBit, &out.IPTablesDropBit, s); err != nil { - return err - } - out.AllowedUnsafeSysctls = in.AllowedUnsafeSysctls - out.ExperimentalRuntimeIntegrationType = in.ExperimentalRuntimeIntegrationType - return nil -} - -func Convert_componentconfig_KubeletConfiguration_To_v1alpha1_KubeletConfiguration(in *componentconfig.KubeletConfiguration, out *KubeletConfiguration, s conversion.Scope) error { - return autoConvert_componentconfig_KubeletConfiguration_To_v1alpha1_KubeletConfiguration(in, out, s) -} - -func autoConvert_v1alpha1_LeaderElectionConfiguration_To_componentconfig_LeaderElectionConfiguration(in *LeaderElectionConfiguration, out *componentconfig.LeaderElectionConfiguration, s conversion.Scope) error { - SetDefaults_LeaderElectionConfiguration(in) - if err := api.Convert_Pointer_bool_To_bool(&in.LeaderElect, &out.LeaderElect, s); err != nil { - return err - } - out.LeaseDuration = in.LeaseDuration - out.RenewDeadline = in.RenewDeadline - out.RetryPeriod = in.RetryPeriod - return nil -} - -func Convert_v1alpha1_LeaderElectionConfiguration_To_componentconfig_LeaderElectionConfiguration(in *LeaderElectionConfiguration, out *componentconfig.LeaderElectionConfiguration, s conversion.Scope) error { - return autoConvert_v1alpha1_LeaderElectionConfiguration_To_componentconfig_LeaderElectionConfiguration(in, out, s) -} - -func autoConvert_componentconfig_LeaderElectionConfiguration_To_v1alpha1_LeaderElectionConfiguration(in *componentconfig.LeaderElectionConfiguration, out *LeaderElectionConfiguration, s conversion.Scope) error { - if err := api.Convert_bool_To_Pointer_bool(&in.LeaderElect, &out.LeaderElect, s); err != nil { - return err - } - out.LeaseDuration = in.LeaseDuration - out.RenewDeadline = in.RenewDeadline - out.RetryPeriod = in.RetryPeriod - return nil -} - -func Convert_componentconfig_LeaderElectionConfiguration_To_v1alpha1_LeaderElectionConfiguration(in *componentconfig.LeaderElectionConfiguration, out *LeaderElectionConfiguration, s conversion.Scope) error { - return autoConvert_componentconfig_LeaderElectionConfiguration_To_v1alpha1_LeaderElectionConfiguration(in, out, s) -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.deepcopy.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.deepcopy.go deleted file mode 100644 index 091f175..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/v1alpha1/zz_generated.deepcopy.go +++ /dev/null @@ -1,436 +0,0 @@ -// +build !ignore_autogenerated - -/* -Copyright 2016 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. -*/ - -// This file was autogenerated by deepcopy-gen. Do not edit it manually! - -package v1alpha1 - -import ( - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - reflect "reflect" -) - -func init() { - SchemeBuilder.Register(RegisterDeepCopies) -} - -// RegisterDeepCopies adds deep-copy functions to the given scheme. Public -// to allow building arbitrary schemes. -func RegisterDeepCopies(scheme *runtime.Scheme) error { - return scheme.AddGeneratedDeepCopyFuncs( - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_KubeProxyConfiguration, InType: reflect.TypeOf(&KubeProxyConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_KubeSchedulerConfiguration, InType: reflect.TypeOf(&KubeSchedulerConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_KubeletConfiguration, InType: reflect.TypeOf(&KubeletConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_v1alpha1_LeaderElectionConfiguration, InType: reflect.TypeOf(&LeaderElectionConfiguration{})}, - ) -} - -func DeepCopy_v1alpha1_KubeProxyConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeProxyConfiguration) - out := out.(*KubeProxyConfiguration) - out.TypeMeta = in.TypeMeta - out.BindAddress = in.BindAddress - out.ClusterCIDR = in.ClusterCIDR - out.HealthzBindAddress = in.HealthzBindAddress - out.HealthzPort = in.HealthzPort - out.HostnameOverride = in.HostnameOverride - if in.IPTablesMasqueradeBit != nil { - in, out := &in.IPTablesMasqueradeBit, &out.IPTablesMasqueradeBit - *out = new(int32) - **out = **in - } else { - out.IPTablesMasqueradeBit = nil - } - out.IPTablesSyncPeriod = in.IPTablesSyncPeriod - out.KubeconfigPath = in.KubeconfigPath - out.MasqueradeAll = in.MasqueradeAll - out.Master = in.Master - if in.OOMScoreAdj != nil { - in, out := &in.OOMScoreAdj, &out.OOMScoreAdj - *out = new(int32) - **out = **in - } else { - out.OOMScoreAdj = nil - } - out.Mode = in.Mode - out.PortRange = in.PortRange - out.ResourceContainer = in.ResourceContainer - out.UDPIdleTimeout = in.UDPIdleTimeout - out.ConntrackMax = in.ConntrackMax - out.ConntrackMaxPerCore = in.ConntrackMaxPerCore - out.ConntrackMin = in.ConntrackMin - out.ConntrackTCPEstablishedTimeout = in.ConntrackTCPEstablishedTimeout - return nil - } -} - -func DeepCopy_v1alpha1_KubeSchedulerConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeSchedulerConfiguration) - out := out.(*KubeSchedulerConfiguration) - out.TypeMeta = in.TypeMeta - out.Port = in.Port - out.Address = in.Address - out.AlgorithmProvider = in.AlgorithmProvider - out.PolicyConfigFile = in.PolicyConfigFile - if in.EnableProfiling != nil { - in, out := &in.EnableProfiling, &out.EnableProfiling - *out = new(bool) - **out = **in - } else { - out.EnableProfiling = nil - } - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = in.KubeAPIBurst - out.SchedulerName = in.SchedulerName - out.HardPodAffinitySymmetricWeight = in.HardPodAffinitySymmetricWeight - out.FailureDomains = in.FailureDomains - if err := DeepCopy_v1alpha1_LeaderElectionConfiguration(&in.LeaderElection, &out.LeaderElection, c); err != nil { - return err - } - return nil - } -} - -func DeepCopy_v1alpha1_KubeletConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeletConfiguration) - out := out.(*KubeletConfiguration) - out.TypeMeta = in.TypeMeta - out.PodManifestPath = in.PodManifestPath - out.SyncFrequency = in.SyncFrequency - out.FileCheckFrequency = in.FileCheckFrequency - out.HTTPCheckFrequency = in.HTTPCheckFrequency - out.ManifestURL = in.ManifestURL - out.ManifestURLHeader = in.ManifestURLHeader - if in.EnableServer != nil { - in, out := &in.EnableServer, &out.EnableServer - *out = new(bool) - **out = **in - } else { - out.EnableServer = nil - } - out.Address = in.Address - out.Port = in.Port - out.ReadOnlyPort = in.ReadOnlyPort - out.TLSCertFile = in.TLSCertFile - out.TLSPrivateKeyFile = in.TLSPrivateKeyFile - out.CertDirectory = in.CertDirectory - out.HostnameOverride = in.HostnameOverride - out.PodInfraContainerImage = in.PodInfraContainerImage - out.DockerEndpoint = in.DockerEndpoint - out.RootDirectory = in.RootDirectory - out.SeccompProfileRoot = in.SeccompProfileRoot - if in.AllowPrivileged != nil { - in, out := &in.AllowPrivileged, &out.AllowPrivileged - *out = new(bool) - **out = **in - } else { - out.AllowPrivileged = nil - } - if in.HostNetworkSources != nil { - in, out := &in.HostNetworkSources, &out.HostNetworkSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostNetworkSources = nil - } - if in.HostPIDSources != nil { - in, out := &in.HostPIDSources, &out.HostPIDSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostPIDSources = nil - } - if in.HostIPCSources != nil { - in, out := &in.HostIPCSources, &out.HostIPCSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostIPCSources = nil - } - if in.RegistryPullQPS != nil { - in, out := &in.RegistryPullQPS, &out.RegistryPullQPS - *out = new(int32) - **out = **in - } else { - out.RegistryPullQPS = nil - } - out.RegistryBurst = in.RegistryBurst - if in.EventRecordQPS != nil { - in, out := &in.EventRecordQPS, &out.EventRecordQPS - *out = new(int32) - **out = **in - } else { - out.EventRecordQPS = nil - } - out.EventBurst = in.EventBurst - if in.EnableDebuggingHandlers != nil { - in, out := &in.EnableDebuggingHandlers, &out.EnableDebuggingHandlers - *out = new(bool) - **out = **in - } else { - out.EnableDebuggingHandlers = nil - } - out.MinimumGCAge = in.MinimumGCAge - out.MaxPerPodContainerCount = in.MaxPerPodContainerCount - if in.MaxContainerCount != nil { - in, out := &in.MaxContainerCount, &out.MaxContainerCount - *out = new(int32) - **out = **in - } else { - out.MaxContainerCount = nil - } - out.CAdvisorPort = in.CAdvisorPort - out.HealthzPort = in.HealthzPort - out.HealthzBindAddress = in.HealthzBindAddress - if in.OOMScoreAdj != nil { - in, out := &in.OOMScoreAdj, &out.OOMScoreAdj - *out = new(int32) - **out = **in - } else { - out.OOMScoreAdj = nil - } - if in.RegisterNode != nil { - in, out := &in.RegisterNode, &out.RegisterNode - *out = new(bool) - **out = **in - } else { - out.RegisterNode = nil - } - out.ClusterDomain = in.ClusterDomain - out.MasterServiceNamespace = in.MasterServiceNamespace - out.ClusterDNS = in.ClusterDNS - out.StreamingConnectionIdleTimeout = in.StreamingConnectionIdleTimeout - out.NodeStatusUpdateFrequency = in.NodeStatusUpdateFrequency - out.ImageMinimumGCAge = in.ImageMinimumGCAge - if in.ImageGCHighThresholdPercent != nil { - in, out := &in.ImageGCHighThresholdPercent, &out.ImageGCHighThresholdPercent - *out = new(int32) - **out = **in - } else { - out.ImageGCHighThresholdPercent = nil - } - if in.ImageGCLowThresholdPercent != nil { - in, out := &in.ImageGCLowThresholdPercent, &out.ImageGCLowThresholdPercent - *out = new(int32) - **out = **in - } else { - out.ImageGCLowThresholdPercent = nil - } - out.LowDiskSpaceThresholdMB = in.LowDiskSpaceThresholdMB - out.VolumeStatsAggPeriod = in.VolumeStatsAggPeriod - out.NetworkPluginName = in.NetworkPluginName - out.NetworkPluginDir = in.NetworkPluginDir - out.CNIConfDir = in.CNIConfDir - out.CNIBinDir = in.CNIBinDir - out.NetworkPluginMTU = in.NetworkPluginMTU - out.VolumePluginDir = in.VolumePluginDir - out.CloudProvider = in.CloudProvider - out.CloudConfigFile = in.CloudConfigFile - out.KubeletCgroups = in.KubeletCgroups - out.RuntimeCgroups = in.RuntimeCgroups - out.SystemCgroups = in.SystemCgroups - out.CgroupRoot = in.CgroupRoot - if in.CgroupsPerQOS != nil { - in, out := &in.CgroupsPerQOS, &out.CgroupsPerQOS - *out = new(bool) - **out = **in - } else { - out.CgroupsPerQOS = nil - } - out.CgroupDriver = in.CgroupDriver - out.ContainerRuntime = in.ContainerRuntime - out.RemoteRuntimeEndpoint = in.RemoteRuntimeEndpoint - out.RemoteImageEndpoint = in.RemoteImageEndpoint - out.RuntimeRequestTimeout = in.RuntimeRequestTimeout - out.RktPath = in.RktPath - out.RktAPIEndpoint = in.RktAPIEndpoint - out.RktStage1Image = in.RktStage1Image - if in.LockFilePath != nil { - in, out := &in.LockFilePath, &out.LockFilePath - *out = new(string) - **out = **in - } else { - out.LockFilePath = nil - } - out.ExitOnLockContention = in.ExitOnLockContention - if in.ConfigureCBR0 != nil { - in, out := &in.ConfigureCBR0, &out.ConfigureCBR0 - *out = new(bool) - **out = **in - } else { - out.ConfigureCBR0 = nil - } - out.HairpinMode = in.HairpinMode - out.BabysitDaemons = in.BabysitDaemons - out.MaxPods = in.MaxPods - out.NvidiaGPUs = in.NvidiaGPUs - out.DockerExecHandlerName = in.DockerExecHandlerName - out.PodCIDR = in.PodCIDR - out.ResolverConfig = in.ResolverConfig - if in.CPUCFSQuota != nil { - in, out := &in.CPUCFSQuota, &out.CPUCFSQuota - *out = new(bool) - **out = **in - } else { - out.CPUCFSQuota = nil - } - if in.Containerized != nil { - in, out := &in.Containerized, &out.Containerized - *out = new(bool) - **out = **in - } else { - out.Containerized = nil - } - out.MaxOpenFiles = in.MaxOpenFiles - if in.ReconcileCIDR != nil { - in, out := &in.ReconcileCIDR, &out.ReconcileCIDR - *out = new(bool) - **out = **in - } else { - out.ReconcileCIDR = nil - } - if in.RegisterSchedulable != nil { - in, out := &in.RegisterSchedulable, &out.RegisterSchedulable - *out = new(bool) - **out = **in - } else { - out.RegisterSchedulable = nil - } - out.ContentType = in.ContentType - if in.KubeAPIQPS != nil { - in, out := &in.KubeAPIQPS, &out.KubeAPIQPS - *out = new(int32) - **out = **in - } else { - out.KubeAPIQPS = nil - } - out.KubeAPIBurst = in.KubeAPIBurst - if in.SerializeImagePulls != nil { - in, out := &in.SerializeImagePulls, &out.SerializeImagePulls - *out = new(bool) - **out = **in - } else { - out.SerializeImagePulls = nil - } - out.OutOfDiskTransitionFrequency = in.OutOfDiskTransitionFrequency - out.NodeIP = in.NodeIP - if in.NodeLabels != nil { - in, out := &in.NodeLabels, &out.NodeLabels - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.NodeLabels = nil - } - out.NonMasqueradeCIDR = in.NonMasqueradeCIDR - out.EnableCustomMetrics = in.EnableCustomMetrics - if in.EvictionHard != nil { - in, out := &in.EvictionHard, &out.EvictionHard - *out = new(string) - **out = **in - } else { - out.EvictionHard = nil - } - out.EvictionSoft = in.EvictionSoft - out.EvictionSoftGracePeriod = in.EvictionSoftGracePeriod - out.EvictionPressureTransitionPeriod = in.EvictionPressureTransitionPeriod - out.EvictionMaxPodGracePeriod = in.EvictionMaxPodGracePeriod - out.EvictionMinimumReclaim = in.EvictionMinimumReclaim - out.PodsPerCore = in.PodsPerCore - if in.EnableControllerAttachDetach != nil { - in, out := &in.EnableControllerAttachDetach, &out.EnableControllerAttachDetach - *out = new(bool) - **out = **in - } else { - out.EnableControllerAttachDetach = nil - } - if in.SystemReserved != nil { - in, out := &in.SystemReserved, &out.SystemReserved - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.SystemReserved = nil - } - if in.KubeReserved != nil { - in, out := &in.KubeReserved, &out.KubeReserved - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.KubeReserved = nil - } - out.ProtectKernelDefaults = in.ProtectKernelDefaults - if in.MakeIPTablesUtilChains != nil { - in, out := &in.MakeIPTablesUtilChains, &out.MakeIPTablesUtilChains - *out = new(bool) - **out = **in - } else { - out.MakeIPTablesUtilChains = nil - } - if in.IPTablesMasqueradeBit != nil { - in, out := &in.IPTablesMasqueradeBit, &out.IPTablesMasqueradeBit - *out = new(int32) - **out = **in - } else { - out.IPTablesMasqueradeBit = nil - } - if in.IPTablesDropBit != nil { - in, out := &in.IPTablesDropBit, &out.IPTablesDropBit - *out = new(int32) - **out = **in - } else { - out.IPTablesDropBit = nil - } - if in.AllowedUnsafeSysctls != nil { - in, out := &in.AllowedUnsafeSysctls, &out.AllowedUnsafeSysctls - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.AllowedUnsafeSysctls = nil - } - out.ExperimentalRuntimeIntegrationType = in.ExperimentalRuntimeIntegrationType - return nil - } -} - -func DeepCopy_v1alpha1_LeaderElectionConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LeaderElectionConfiguration) - out := out.(*LeaderElectionConfiguration) - if in.LeaderElect != nil { - in, out := &in.LeaderElect, &out.LeaderElect - *out = new(bool) - **out = **in - } else { - out.LeaderElect = nil - } - out.LeaseDuration = in.LeaseDuration - out.RenewDeadline = in.RenewDeadline - out.RetryPeriod = in.RetryPeriod - return nil - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/zz_generated.deepcopy.go b/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/zz_generated.deepcopy.go deleted file mode 100644 index 083696f..0000000 --- a/vendor/k8s.io/kubernetes/pkg/apis/componentconfig/zz_generated.deepcopy.go +++ /dev/null @@ -1,408 +0,0 @@ -// +build !ignore_autogenerated - -/* -Copyright 2016 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. -*/ - -// This file was autogenerated by deepcopy-gen. Do not edit it manually! - -package componentconfig - -import ( - conversion "k8s.io/kubernetes/pkg/conversion" - runtime "k8s.io/kubernetes/pkg/runtime" - config "k8s.io/kubernetes/pkg/util/config" - reflect "reflect" -) - -func init() { - SchemeBuilder.Register(RegisterDeepCopies) -} - -// RegisterDeepCopies adds deep-copy functions to the given scheme. Public -// to allow building arbitrary schemes. -func RegisterDeepCopies(scheme *runtime.Scheme) error { - return scheme.AddGeneratedDeepCopyFuncs( - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_IPVar, InType: reflect.TypeOf(&IPVar{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_KubeControllerManagerConfiguration, InType: reflect.TypeOf(&KubeControllerManagerConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_KubeProxyConfiguration, InType: reflect.TypeOf(&KubeProxyConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_KubeSchedulerConfiguration, InType: reflect.TypeOf(&KubeSchedulerConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_KubeletConfiguration, InType: reflect.TypeOf(&KubeletConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_LeaderElectionConfiguration, InType: reflect.TypeOf(&LeaderElectionConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_PersistentVolumeRecyclerConfiguration, InType: reflect.TypeOf(&PersistentVolumeRecyclerConfiguration{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_PortRangeVar, InType: reflect.TypeOf(&PortRangeVar{})}, - conversion.GeneratedDeepCopyFunc{Fn: DeepCopy_componentconfig_VolumeConfiguration, InType: reflect.TypeOf(&VolumeConfiguration{})}, - ) -} - -func DeepCopy_componentconfig_IPVar(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*IPVar) - out := out.(*IPVar) - if in.Val != nil { - in, out := &in.Val, &out.Val - *out = new(string) - **out = **in - } else { - out.Val = nil - } - return nil - } -} - -func DeepCopy_componentconfig_KubeControllerManagerConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeControllerManagerConfiguration) - out := out.(*KubeControllerManagerConfiguration) - out.TypeMeta = in.TypeMeta - out.Port = in.Port - out.Address = in.Address - out.CloudProvider = in.CloudProvider - out.CloudConfigFile = in.CloudConfigFile - out.ConcurrentEndpointSyncs = in.ConcurrentEndpointSyncs - out.ConcurrentRSSyncs = in.ConcurrentRSSyncs - out.ConcurrentRCSyncs = in.ConcurrentRCSyncs - out.ConcurrentServiceSyncs = in.ConcurrentServiceSyncs - out.ConcurrentResourceQuotaSyncs = in.ConcurrentResourceQuotaSyncs - out.ConcurrentDeploymentSyncs = in.ConcurrentDeploymentSyncs - out.ConcurrentDaemonSetSyncs = in.ConcurrentDaemonSetSyncs - out.ConcurrentJobSyncs = in.ConcurrentJobSyncs - out.ConcurrentNamespaceSyncs = in.ConcurrentNamespaceSyncs - out.ConcurrentSATokenSyncs = in.ConcurrentSATokenSyncs - out.LookupCacheSizeForRC = in.LookupCacheSizeForRC - out.LookupCacheSizeForRS = in.LookupCacheSizeForRS - out.LookupCacheSizeForDaemonSet = in.LookupCacheSizeForDaemonSet - out.ServiceSyncPeriod = in.ServiceSyncPeriod - out.NodeSyncPeriod = in.NodeSyncPeriod - out.RouteReconciliationPeriod = in.RouteReconciliationPeriod - out.ResourceQuotaSyncPeriod = in.ResourceQuotaSyncPeriod - out.NamespaceSyncPeriod = in.NamespaceSyncPeriod - out.PVClaimBinderSyncPeriod = in.PVClaimBinderSyncPeriod - out.MinResyncPeriod = in.MinResyncPeriod - out.TerminatedPodGCThreshold = in.TerminatedPodGCThreshold - out.HorizontalPodAutoscalerSyncPeriod = in.HorizontalPodAutoscalerSyncPeriod - out.DeploymentControllerSyncPeriod = in.DeploymentControllerSyncPeriod - out.PodEvictionTimeout = in.PodEvictionTimeout - out.DeletingPodsQps = in.DeletingPodsQps - out.DeletingPodsBurst = in.DeletingPodsBurst - out.NodeMonitorGracePeriod = in.NodeMonitorGracePeriod - out.RegisterRetryCount = in.RegisterRetryCount - out.NodeStartupGracePeriod = in.NodeStartupGracePeriod - out.NodeMonitorPeriod = in.NodeMonitorPeriod - out.ServiceAccountKeyFile = in.ServiceAccountKeyFile - out.ClusterSigningCertFile = in.ClusterSigningCertFile - out.ClusterSigningKeyFile = in.ClusterSigningKeyFile - out.ApproveAllKubeletCSRsForGroup = in.ApproveAllKubeletCSRsForGroup - out.EnableProfiling = in.EnableProfiling - out.ClusterName = in.ClusterName - out.ClusterCIDR = in.ClusterCIDR - out.ServiceCIDR = in.ServiceCIDR - out.NodeCIDRMaskSize = in.NodeCIDRMaskSize - out.AllocateNodeCIDRs = in.AllocateNodeCIDRs - out.ConfigureCloudRoutes = in.ConfigureCloudRoutes - out.RootCAFile = in.RootCAFile - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = in.KubeAPIBurst - out.LeaderElection = in.LeaderElection - out.VolumeConfiguration = in.VolumeConfiguration - out.ControllerStartInterval = in.ControllerStartInterval - out.EnableGarbageCollector = in.EnableGarbageCollector - out.ConcurrentGCSyncs = in.ConcurrentGCSyncs - out.NodeEvictionRate = in.NodeEvictionRate - out.SecondaryNodeEvictionRate = in.SecondaryNodeEvictionRate - out.LargeClusterSizeThreshold = in.LargeClusterSizeThreshold - out.UnhealthyZoneThreshold = in.UnhealthyZoneThreshold - return nil - } -} - -func DeepCopy_componentconfig_KubeProxyConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeProxyConfiguration) - out := out.(*KubeProxyConfiguration) - out.TypeMeta = in.TypeMeta - out.BindAddress = in.BindAddress - out.ClusterCIDR = in.ClusterCIDR - out.HealthzBindAddress = in.HealthzBindAddress - out.HealthzPort = in.HealthzPort - out.HostnameOverride = in.HostnameOverride - if in.IPTablesMasqueradeBit != nil { - in, out := &in.IPTablesMasqueradeBit, &out.IPTablesMasqueradeBit - *out = new(int32) - **out = **in - } else { - out.IPTablesMasqueradeBit = nil - } - out.IPTablesSyncPeriod = in.IPTablesSyncPeriod - out.KubeconfigPath = in.KubeconfigPath - out.MasqueradeAll = in.MasqueradeAll - out.Master = in.Master - if in.OOMScoreAdj != nil { - in, out := &in.OOMScoreAdj, &out.OOMScoreAdj - *out = new(int32) - **out = **in - } else { - out.OOMScoreAdj = nil - } - out.Mode = in.Mode - out.PortRange = in.PortRange - out.ResourceContainer = in.ResourceContainer - out.UDPIdleTimeout = in.UDPIdleTimeout - out.ConntrackMax = in.ConntrackMax - out.ConntrackMaxPerCore = in.ConntrackMaxPerCore - out.ConntrackMin = in.ConntrackMin - out.ConntrackTCPEstablishedTimeout = in.ConntrackTCPEstablishedTimeout - return nil - } -} - -func DeepCopy_componentconfig_KubeSchedulerConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeSchedulerConfiguration) - out := out.(*KubeSchedulerConfiguration) - out.TypeMeta = in.TypeMeta - out.Port = in.Port - out.Address = in.Address - out.AlgorithmProvider = in.AlgorithmProvider - out.PolicyConfigFile = in.PolicyConfigFile - out.EnableProfiling = in.EnableProfiling - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = in.KubeAPIBurst - out.SchedulerName = in.SchedulerName - out.HardPodAffinitySymmetricWeight = in.HardPodAffinitySymmetricWeight - out.FailureDomains = in.FailureDomains - out.LeaderElection = in.LeaderElection - return nil - } -} - -func DeepCopy_componentconfig_KubeletConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*KubeletConfiguration) - out := out.(*KubeletConfiguration) - out.TypeMeta = in.TypeMeta - out.PodManifestPath = in.PodManifestPath - out.SyncFrequency = in.SyncFrequency - out.FileCheckFrequency = in.FileCheckFrequency - out.HTTPCheckFrequency = in.HTTPCheckFrequency - out.ManifestURL = in.ManifestURL - out.ManifestURLHeader = in.ManifestURLHeader - out.EnableServer = in.EnableServer - out.Address = in.Address - out.Port = in.Port - out.ReadOnlyPort = in.ReadOnlyPort - out.TLSCertFile = in.TLSCertFile - out.TLSPrivateKeyFile = in.TLSPrivateKeyFile - out.CertDirectory = in.CertDirectory - out.HostnameOverride = in.HostnameOverride - out.PodInfraContainerImage = in.PodInfraContainerImage - out.DockerEndpoint = in.DockerEndpoint - out.RootDirectory = in.RootDirectory - out.SeccompProfileRoot = in.SeccompProfileRoot - out.AllowPrivileged = in.AllowPrivileged - if in.HostNetworkSources != nil { - in, out := &in.HostNetworkSources, &out.HostNetworkSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostNetworkSources = nil - } - if in.HostPIDSources != nil { - in, out := &in.HostPIDSources, &out.HostPIDSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostPIDSources = nil - } - if in.HostIPCSources != nil { - in, out := &in.HostIPCSources, &out.HostIPCSources - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.HostIPCSources = nil - } - out.RegistryPullQPS = in.RegistryPullQPS - out.RegistryBurst = in.RegistryBurst - out.EventRecordQPS = in.EventRecordQPS - out.EventBurst = in.EventBurst - out.EnableDebuggingHandlers = in.EnableDebuggingHandlers - out.MinimumGCAge = in.MinimumGCAge - out.MaxPerPodContainerCount = in.MaxPerPodContainerCount - out.MaxContainerCount = in.MaxContainerCount - out.CAdvisorPort = in.CAdvisorPort - out.HealthzPort = in.HealthzPort - out.HealthzBindAddress = in.HealthzBindAddress - out.OOMScoreAdj = in.OOMScoreAdj - out.RegisterNode = in.RegisterNode - out.ClusterDomain = in.ClusterDomain - out.MasterServiceNamespace = in.MasterServiceNamespace - out.ClusterDNS = in.ClusterDNS - out.StreamingConnectionIdleTimeout = in.StreamingConnectionIdleTimeout - out.NodeStatusUpdateFrequency = in.NodeStatusUpdateFrequency - out.ImageMinimumGCAge = in.ImageMinimumGCAge - out.ImageGCHighThresholdPercent = in.ImageGCHighThresholdPercent - out.ImageGCLowThresholdPercent = in.ImageGCLowThresholdPercent - out.LowDiskSpaceThresholdMB = in.LowDiskSpaceThresholdMB - out.VolumeStatsAggPeriod = in.VolumeStatsAggPeriod - out.NetworkPluginName = in.NetworkPluginName - out.NetworkPluginMTU = in.NetworkPluginMTU - out.NetworkPluginDir = in.NetworkPluginDir - out.CNIConfDir = in.CNIConfDir - out.CNIBinDir = in.CNIBinDir - out.VolumePluginDir = in.VolumePluginDir - out.CloudProvider = in.CloudProvider - out.CloudConfigFile = in.CloudConfigFile - out.KubeletCgroups = in.KubeletCgroups - out.CgroupsPerQOS = in.CgroupsPerQOS - out.CgroupDriver = in.CgroupDriver - out.RuntimeCgroups = in.RuntimeCgroups - out.SystemCgroups = in.SystemCgroups - out.CgroupRoot = in.CgroupRoot - out.ContainerRuntime = in.ContainerRuntime - out.RemoteRuntimeEndpoint = in.RemoteRuntimeEndpoint - out.RemoteImageEndpoint = in.RemoteImageEndpoint - out.RuntimeRequestTimeout = in.RuntimeRequestTimeout - out.RktPath = in.RktPath - out.RktAPIEndpoint = in.RktAPIEndpoint - out.RktStage1Image = in.RktStage1Image - out.LockFilePath = in.LockFilePath - out.ExitOnLockContention = in.ExitOnLockContention - out.ConfigureCBR0 = in.ConfigureCBR0 - out.HairpinMode = in.HairpinMode - out.BabysitDaemons = in.BabysitDaemons - out.MaxPods = in.MaxPods - out.NvidiaGPUs = in.NvidiaGPUs - out.DockerExecHandlerName = in.DockerExecHandlerName - out.PodCIDR = in.PodCIDR - out.ResolverConfig = in.ResolverConfig - out.CPUCFSQuota = in.CPUCFSQuota - out.Containerized = in.Containerized - out.MaxOpenFiles = in.MaxOpenFiles - out.ReconcileCIDR = in.ReconcileCIDR - out.RegisterSchedulable = in.RegisterSchedulable - out.ContentType = in.ContentType - out.KubeAPIQPS = in.KubeAPIQPS - out.KubeAPIBurst = in.KubeAPIBurst - out.SerializeImagePulls = in.SerializeImagePulls - out.OutOfDiskTransitionFrequency = in.OutOfDiskTransitionFrequency - out.NodeIP = in.NodeIP - if in.NodeLabels != nil { - in, out := &in.NodeLabels, &out.NodeLabels - *out = make(map[string]string) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.NodeLabels = nil - } - out.NonMasqueradeCIDR = in.NonMasqueradeCIDR - out.EnableCustomMetrics = in.EnableCustomMetrics - out.EvictionHard = in.EvictionHard - out.EvictionSoft = in.EvictionSoft - out.EvictionSoftGracePeriod = in.EvictionSoftGracePeriod - out.EvictionPressureTransitionPeriod = in.EvictionPressureTransitionPeriod - out.EvictionMaxPodGracePeriod = in.EvictionMaxPodGracePeriod - out.EvictionMinimumReclaim = in.EvictionMinimumReclaim - out.PodsPerCore = in.PodsPerCore - out.EnableControllerAttachDetach = in.EnableControllerAttachDetach - if in.SystemReserved != nil { - in, out := &in.SystemReserved, &out.SystemReserved - *out = make(config.ConfigurationMap) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.SystemReserved = nil - } - if in.KubeReserved != nil { - in, out := &in.KubeReserved, &out.KubeReserved - *out = make(config.ConfigurationMap) - for key, val := range *in { - (*out)[key] = val - } - } else { - out.KubeReserved = nil - } - out.ProtectKernelDefaults = in.ProtectKernelDefaults - out.MakeIPTablesUtilChains = in.MakeIPTablesUtilChains - out.IPTablesMasqueradeBit = in.IPTablesMasqueradeBit - out.IPTablesDropBit = in.IPTablesDropBit - if in.AllowedUnsafeSysctls != nil { - in, out := &in.AllowedUnsafeSysctls, &out.AllowedUnsafeSysctls - *out = make([]string, len(*in)) - copy(*out, *in) - } else { - out.AllowedUnsafeSysctls = nil - } - out.ExperimentalRuntimeIntegrationType = in.ExperimentalRuntimeIntegrationType - return nil - } -} - -func DeepCopy_componentconfig_LeaderElectionConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*LeaderElectionConfiguration) - out := out.(*LeaderElectionConfiguration) - out.LeaderElect = in.LeaderElect - out.LeaseDuration = in.LeaseDuration - out.RenewDeadline = in.RenewDeadline - out.RetryPeriod = in.RetryPeriod - return nil - } -} - -func DeepCopy_componentconfig_PersistentVolumeRecyclerConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*PersistentVolumeRecyclerConfiguration) - out := out.(*PersistentVolumeRecyclerConfiguration) - out.MaximumRetry = in.MaximumRetry - out.MinimumTimeoutNFS = in.MinimumTimeoutNFS - out.PodTemplateFilePathNFS = in.PodTemplateFilePathNFS - out.IncrementTimeoutNFS = in.IncrementTimeoutNFS - out.PodTemplateFilePathHostPath = in.PodTemplateFilePathHostPath - out.MinimumTimeoutHostPath = in.MinimumTimeoutHostPath - out.IncrementTimeoutHostPath = in.IncrementTimeoutHostPath - return nil - } -} - -func DeepCopy_componentconfig_PortRangeVar(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*PortRangeVar) - out := out.(*PortRangeVar) - if in.Val != nil { - in, out := &in.Val, &out.Val - *out = new(string) - **out = **in - } else { - out.Val = nil - } - return nil - } -} - -func DeepCopy_componentconfig_VolumeConfiguration(in interface{}, out interface{}, c *conversion.Cloner) error { - { - in := in.(*VolumeConfiguration) - out := out.(*VolumeConfiguration) - out.EnableHostPathProvisioning = in.EnableHostPathProvisioning - out.EnableDynamicProvisioning = in.EnableDynamicProvisioning - out.PersistentVolumeRecyclerConfiguration = in.PersistentVolumeRecyclerConfiguration - out.FlexVolumePluginDir = in.FlexVolumePluginDir - return nil - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/petset.go b/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/petset.go deleted file mode 100644 index d88f075..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned/petset.go +++ /dev/null @@ -1,165 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - api "k8s.io/kubernetes/pkg/api" - apps "k8s.io/kubernetes/pkg/apis/apps" - watch "k8s.io/kubernetes/pkg/watch" -) - -// PetSetsGetter has a method to return a PetSetInterface. -// A group's client should implement this interface. -type PetSetsGetter interface { - PetSets(namespace string) PetSetInterface -} - -// PetSetInterface has methods to work with PetSet resources. -type PetSetInterface interface { - Create(*apps.PetSet) (*apps.PetSet, error) - Update(*apps.PetSet) (*apps.PetSet, error) - UpdateStatus(*apps.PetSet) (*apps.PetSet, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*apps.PetSet, error) - List(opts api.ListOptions) (*apps.PetSetList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *apps.PetSet, err error) - PetSetExpansion -} - -// petSets implements PetSetInterface -type petSets struct { - client *AppsClient - ns string -} - -// newPetSets returns a PetSets -func newPetSets(c *AppsClient, namespace string) *petSets { - return &petSets{ - client: c, - ns: namespace, - } -} - -// Create takes the representation of a petSet and creates it. Returns the server's representation of the petSet, and an error, if there is any. -func (c *petSets) Create(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.client.Post(). - Namespace(c.ns). - Resource("petsets"). - Body(petSet). - Do(). - Into(result) - return -} - -// Update takes the representation of a petSet and updates it. Returns the server's representation of the petSet, and an error, if there is any. -func (c *petSets) Update(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.client.Put(). - Namespace(c.ns). - Resource("petsets"). - Name(petSet.Name). - Body(petSet). - Do(). - Into(result) - return -} - -func (c *petSets) UpdateStatus(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.client.Put(). - Namespace(c.ns). - Resource("petsets"). - Name(petSet.Name). - SubResource("status"). - Body(petSet). - Do(). - Into(result) - return -} - -// Delete takes name of the petSet and deletes it. Returns an error if one occurs. -func (c *petSets) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("petsets"). - Name(name). - Body(options). - Do(). - Error() -} - -// DeleteCollection deletes a collection of objects. -func (c *petSets) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("petsets"). - VersionedParams(&listOptions, api.ParameterCodec). - Body(options). - Do(). - Error() -} - -// Get takes name of the petSet, and returns the corresponding petSet object, and an error if there is any. -func (c *petSets) Get(name string) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.client.Get(). - Namespace(c.ns). - Resource("petsets"). - Name(name). - Do(). - Into(result) - return -} - -// List takes label and field selectors, and returns the list of PetSets that match those selectors. -func (c *petSets) List(opts api.ListOptions) (result *apps.PetSetList, err error) { - result = &apps.PetSetList{} - err = c.client.Get(). - Namespace(c.ns). - Resource("petsets"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested petSets. -func (c *petSets) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("petsets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Patch applies the patch and returns the patched petSet. -func (c *petSets) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.client.Patch(pt). - Namespace(c.ns). - Resource("petsets"). - SubResource(subresources...). - Name(name). - Body(data). - Do(). - Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/scheduledjob.go b/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/scheduledjob.go deleted file mode 100644 index 3c3f32e..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned/scheduledjob.go +++ /dev/null @@ -1,165 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - api "k8s.io/kubernetes/pkg/api" - batch "k8s.io/kubernetes/pkg/apis/batch" - watch "k8s.io/kubernetes/pkg/watch" -) - -// ScheduledJobsGetter has a method to return a ScheduledJobInterface. -// A group's client should implement this interface. -type ScheduledJobsGetter interface { - ScheduledJobs(namespace string) ScheduledJobInterface -} - -// ScheduledJobInterface has methods to work with ScheduledJob resources. -type ScheduledJobInterface interface { - Create(*batch.ScheduledJob) (*batch.ScheduledJob, error) - Update(*batch.ScheduledJob) (*batch.ScheduledJob, error) - UpdateStatus(*batch.ScheduledJob) (*batch.ScheduledJob, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*batch.ScheduledJob, error) - List(opts api.ListOptions) (*batch.ScheduledJobList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *batch.ScheduledJob, err error) - ScheduledJobExpansion -} - -// scheduledJobs implements ScheduledJobInterface -type scheduledJobs struct { - client *BatchClient - ns string -} - -// newScheduledJobs returns a ScheduledJobs -func newScheduledJobs(c *BatchClient, namespace string) *scheduledJobs { - return &scheduledJobs{ - client: c, - ns: namespace, - } -} - -// Create takes the representation of a scheduledJob and creates it. Returns the server's representation of the scheduledJob, and an error, if there is any. -func (c *scheduledJobs) Create(scheduledJob *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.client.Post(). - Namespace(c.ns). - Resource("scheduledjobs"). - Body(scheduledJob). - Do(). - Into(result) - return -} - -// Update takes the representation of a scheduledJob and updates it. Returns the server's representation of the scheduledJob, and an error, if there is any. -func (c *scheduledJobs) Update(scheduledJob *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.client.Put(). - Namespace(c.ns). - Resource("scheduledjobs"). - Name(scheduledJob.Name). - Body(scheduledJob). - Do(). - Into(result) - return -} - -func (c *scheduledJobs) UpdateStatus(scheduledJob *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.client.Put(). - Namespace(c.ns). - Resource("scheduledjobs"). - Name(scheduledJob.Name). - SubResource("status"). - Body(scheduledJob). - Do(). - Into(result) - return -} - -// Delete takes name of the scheduledJob and deletes it. Returns an error if one occurs. -func (c *scheduledJobs) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("scheduledjobs"). - Name(name). - Body(options). - Do(). - Error() -} - -// DeleteCollection deletes a collection of objects. -func (c *scheduledJobs) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("scheduledjobs"). - VersionedParams(&listOptions, api.ParameterCodec). - Body(options). - Do(). - Error() -} - -// Get takes name of the scheduledJob, and returns the corresponding scheduledJob object, and an error if there is any. -func (c *scheduledJobs) Get(name string) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.client.Get(). - Namespace(c.ns). - Resource("scheduledjobs"). - Name(name). - Do(). - Into(result) - return -} - -// List takes label and field selectors, and returns the list of ScheduledJobs that match those selectors. -func (c *scheduledJobs) List(opts api.ListOptions) (result *batch.ScheduledJobList, err error) { - result = &batch.ScheduledJobList{} - err = c.client.Get(). - Namespace(c.ns). - Resource("scheduledjobs"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested scheduledJobs. -func (c *scheduledJobs) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("scheduledjobs"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Patch applies the patch and returns the patched scheduledJob. -func (c *scheduledJobs) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.client.Patch(pt). - Namespace(c.ns). - Resource("scheduledjobs"). - SubResource(subresources...). - Name(name). - Body(data). - Do(). - Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node_expansion.go b/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node_expansion.go deleted file mode 100644 index 767f157..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned/node_expansion.go +++ /dev/null @@ -1,40 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import "k8s.io/kubernetes/pkg/api" - -// The NodeExpansion interface allows manually adding extra methods to the NodeInterface. -type NodeExpansion interface { - // PatchStatus modifies the status of an existing node. It returns the copy - // of the node that the server returns, or an error. - PatchStatus(nodeName string, data []byte) (*api.Node, error) -} - -// PatchStatus modifies the status of an existing node. It returns the copy of -// the node that the server returns, or an error. -func (c *nodes) PatchStatus(nodeName string, data []byte) (*api.Node, error) { - result := &api.Node{} - err := c.client.Patch(api.StrategicMergePatchType). - Resource("nodes"). - Name(nodeName). - SubResource("status"). - Body(data). - Do(). - Into(result) - return result, err -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/networkpolicy.go b/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/networkpolicy.go deleted file mode 100644 index a46d398..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned/networkpolicy.go +++ /dev/null @@ -1,151 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - api "k8s.io/kubernetes/pkg/api" - extensions "k8s.io/kubernetes/pkg/apis/extensions" - watch "k8s.io/kubernetes/pkg/watch" -) - -// NetworkPoliciesGetter has a method to return a NetworkPolicyInterface. -// A group's client should implement this interface. -type NetworkPoliciesGetter interface { - NetworkPolicies(namespace string) NetworkPolicyInterface -} - -// NetworkPolicyInterface has methods to work with NetworkPolicy resources. -type NetworkPolicyInterface interface { - Create(*extensions.NetworkPolicy) (*extensions.NetworkPolicy, error) - Update(*extensions.NetworkPolicy) (*extensions.NetworkPolicy, error) - Delete(name string, options *api.DeleteOptions) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Get(name string) (*extensions.NetworkPolicy, error) - List(opts api.ListOptions) (*extensions.NetworkPolicyList, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.NetworkPolicy, err error) - NetworkPolicyExpansion -} - -// networkPolicies implements NetworkPolicyInterface -type networkPolicies struct { - client *ExtensionsClient - ns string -} - -// newNetworkPolicies returns a NetworkPolicies -func newNetworkPolicies(c *ExtensionsClient, namespace string) *networkPolicies { - return &networkPolicies{ - client: c, - ns: namespace, - } -} - -// Create takes the representation of a networkPolicy and creates it. Returns the server's representation of the networkPolicy, and an error, if there is any. -func (c *networkPolicies) Create(networkPolicy *extensions.NetworkPolicy) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.client.Post(). - Namespace(c.ns). - Resource("networkpolicies"). - Body(networkPolicy). - Do(). - Into(result) - return -} - -// Update takes the representation of a networkPolicy and updates it. Returns the server's representation of the networkPolicy, and an error, if there is any. -func (c *networkPolicies) Update(networkPolicy *extensions.NetworkPolicy) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.client.Put(). - Namespace(c.ns). - Resource("networkpolicies"). - Name(networkPolicy.Name). - Body(networkPolicy). - Do(). - Into(result) - return -} - -// Delete takes name of the networkPolicy and deletes it. Returns an error if one occurs. -func (c *networkPolicies) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("networkpolicies"). - Name(name). - Body(options). - Do(). - Error() -} - -// DeleteCollection deletes a collection of objects. -func (c *networkPolicies) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { - return c.client.Delete(). - Namespace(c.ns). - Resource("networkpolicies"). - VersionedParams(&listOptions, api.ParameterCodec). - Body(options). - Do(). - Error() -} - -// Get takes name of the networkPolicy, and returns the corresponding networkPolicy object, and an error if there is any. -func (c *networkPolicies) Get(name string) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.client.Get(). - Namespace(c.ns). - Resource("networkpolicies"). - Name(name). - Do(). - Into(result) - return -} - -// List takes label and field selectors, and returns the list of NetworkPolicies that match those selectors. -func (c *networkPolicies) List(opts api.ListOptions) (result *extensions.NetworkPolicyList, err error) { - result = &extensions.NetworkPolicyList{} - err = c.client.Get(). - Namespace(c.ns). - Resource("networkpolicies"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested networkPolicies. -func (c *networkPolicies) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("networkpolicies"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Patch applies the patch and returns the patched networkPolicy. -func (c *networkPolicies) Patch(name string, pt api.PatchType, data []byte, subresources ...string) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.client.Patch(pt). - Namespace(c.ns). - Resource("networkpolicies"). - SubResource(subresources...). - Name(name). - Body(data). - Do(). - Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/apps.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/apps.go deleted file mode 100644 index 413c2a4..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/apps.go +++ /dev/null @@ -1,55 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type AppsInterface interface { - PetSetNamespacer -} - -// AppsClient is used to interact with Kubernetes batch features. -type AppsClient struct { - *restclient.RESTClient -} - -func (c *AppsClient) PetSets(namespace string) PetSetInterface { - return newPetSet(c, namespace) -} - -func NewApps(c *restclient.Config) (*AppsClient, error) { - config := *c - if err := setGroupDefaults(apps.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &AppsClient{client}, nil -} - -func NewAppsOrDie(c *restclient.Config) *AppsClient { - client, err := NewApps(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/authentication.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/authentication.go deleted file mode 100644 index 6ac7f94..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/authentication.go +++ /dev/null @@ -1,77 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/apis/authentication" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type AuthenticationInterface interface { - TokenReviewsInterface -} - -// AuthenticationClient is used to interact with Kubernetes authentication features. -type AuthenticationClient struct { - *restclient.RESTClient -} - -func (c *AuthenticationClient) TokenReviews() TokenReviewInterface { - return newTokenReviews(c) -} - -func NewAuthentication(c *restclient.Config) (*AuthenticationClient, error) { - config := *c - if err := setAuthenticationDefaults(&config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &AuthenticationClient{client}, nil -} - -func NewAuthenticationOrDie(c *restclient.Config) *AuthenticationClient { - client, err := NewAuthentication(c) - if err != nil { - panic(err) - } - return client -} - -func setAuthenticationDefaults(config *restclient.Config) error { - // if authentication group is not registered, return an error - g, err := registered.Group(authentication.GroupName) - if err != nil { - return err - } - config.APIPath = defaultAPIPath - if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() - } - // TODO: Unconditionally set the config.Version, until we fix the config. - //if config.Version == "" { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - //} - - config.NegotiatedSerializer = api.Codecs - return nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/authorization.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/authorization.go deleted file mode 100644 index beba40d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/authorization.go +++ /dev/null @@ -1,77 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/apis/authorization" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type AuthorizationInterface interface { - SubjectAccessReviewsInterface -} - -// AuthorizationClient is used to interact with Kubernetes authorization features. -type AuthorizationClient struct { - *restclient.RESTClient -} - -func (c *AuthorizationClient) SubjectAccessReviews() SubjectAccessReviewInterface { - return newSubjectAccessReviews(c) -} - -func NewAuthorization(c *restclient.Config) (*AuthorizationClient, error) { - config := *c - if err := setAuthorizationDefaults(&config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &AuthorizationClient{client}, nil -} - -func NewAuthorizationOrDie(c *restclient.Config) *AuthorizationClient { - client, err := NewAuthorization(c) - if err != nil { - panic(err) - } - return client -} - -func setAuthorizationDefaults(config *restclient.Config) error { - // if authorization group is not registered, return an error - g, err := registered.Group(authorization.GroupName) - if err != nil { - return err - } - config.APIPath = defaultAPIPath - if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() - } - // TODO: Unconditionally set the config.Version, until we fix the config. - //if config.Version == "" { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - //} - - config.NegotiatedSerializer = api.Codecs - return nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/autoscaling.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/autoscaling.go deleted file mode 100644 index e53d23d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/autoscaling.go +++ /dev/null @@ -1,55 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type AutoscalingInterface interface { - HorizontalPodAutoscalersNamespacer -} - -// AutoscalingClient is used to interact with Kubernetes autoscaling features. -type AutoscalingClient struct { - *restclient.RESTClient -} - -func (c *AutoscalingClient) HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface { - return newHorizontalPodAutoscalers(c, namespace) -} - -func NewAutoscaling(c *restclient.Config) (*AutoscalingClient, error) { - config := *c - if err := setGroupDefaults(autoscaling.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &AutoscalingClient{client}, nil -} - -func NewAutoscalingOrDie(c *restclient.Config) *AutoscalingClient { - client, err := NewAutoscaling(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/batch.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/batch.go deleted file mode 100644 index 0957424..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/batch.go +++ /dev/null @@ -1,60 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type BatchInterface interface { - JobsNamespacer - ScheduledJobsNamespacer -} - -// BatchClient is used to interact with Kubernetes batch features. -type BatchClient struct { - *restclient.RESTClient -} - -func (c *BatchClient) Jobs(namespace string) JobInterface { - return newJobsV1(c, namespace) -} - -func (c *BatchClient) ScheduledJobs(namespace string) ScheduledJobInterface { - return newScheduledJobs(c, namespace) -} - -func NewBatch(c *restclient.Config) (*BatchClient, error) { - config := *c - if err := setGroupDefaults(batch.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &BatchClient{client}, nil -} - -func NewBatchOrDie(c *restclient.Config) *BatchClient { - client, err := NewBatch(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificates.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificates.go deleted file mode 100644 index 273b957..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificates.go +++ /dev/null @@ -1,69 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/certificates" - "k8s.io/kubernetes/pkg/client/restclient" -) - -// Interface holds the methods for clients of Kubernetes to allow mock testing. -type CertificatesInterface interface { - CertificateSigningRequests() CertificateSigningRequestInterface -} - -type CertificatesClient struct { - *restclient.RESTClient -} - -func (c *CertificatesClient) CertificateSigningRequests() CertificateSigningRequestInterface { - return newCertificateSigningRequests(c) -} - -// NewCertificates creates a new CertificatesClient for the given config. -func NewCertificates(c *restclient.Config) (*CertificatesClient, error) { - config := *c - if err := setCertificatesDefaults(&config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &CertificatesClient{client}, nil -} - -// NewCertificatesOrDie creates a new CertificatesClient for the given config and -// panics if there is an error in the config. -func NewCertificatesOrDie(c *restclient.Config) *CertificatesClient { - client, err := NewCertificates(c) - if err != nil { - panic(err) - } - return client -} - -func setCertificatesDefaults(config *restclient.Config) error { - setGroupDefaults(certificates.GroupName, config) - if config.QPS == 0 { - config.QPS = 5 - } - if config.Burst == 0 { - config.Burst = 10 - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificatesigningrequests.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificatesigningrequests.go deleted file mode 100644 index f3ce09f..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/certificatesigningrequests.go +++ /dev/null @@ -1,104 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/certificates" - "k8s.io/kubernetes/pkg/watch" -) - -// CertificateSigningRequestInterface has methods to work with CertificateSigningRequest resources. -type CertificateSigningRequestInterface interface { - List(opts api.ListOptions) (*certificates.CertificateSigningRequestList, error) - Get(name string) (*certificates.CertificateSigningRequest, error) - Delete(name string, options *api.DeleteOptions) error - Create(certificateSigningRequest *certificates.CertificateSigningRequest) (*certificates.CertificateSigningRequest, error) - Update(certificateSigningRequest *certificates.CertificateSigningRequest) (*certificates.CertificateSigningRequest, error) - UpdateStatus(certificateSigningRequest *certificates.CertificateSigningRequest) (*certificates.CertificateSigningRequest, error) - UpdateApproval(certificateSigningRequest *certificates.CertificateSigningRequest) (*certificates.CertificateSigningRequest, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// certificateSigningRequests implements CertificateSigningRequestsNamespacer interface -type certificateSigningRequests struct { - client *CertificatesClient -} - -// newCertificateSigningRequests returns a certificateSigningRequests -func newCertificateSigningRequests(c *CertificatesClient) *certificateSigningRequests { - return &certificateSigningRequests{ - client: c, - } -} - -// List takes label and field selectors, and returns the list of certificateSigningRequests that match those selectors. -func (c *certificateSigningRequests) List(opts api.ListOptions) (result *certificates.CertificateSigningRequestList, err error) { - result = &certificates.CertificateSigningRequestList{} - err = c.client.Get().Resource("certificatesigningrequests").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the certificateSigningRequest, and returns the corresponding CertificateSigningRequest object, and an error if it occurs -func (c *certificateSigningRequests) Get(name string) (result *certificates.CertificateSigningRequest, err error) { - result = &certificates.CertificateSigningRequest{} - err = c.client.Get().Resource("certificatesigningrequests").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the certificateSigningRequest and deletes it. Returns an error if one occurs. -func (c *certificateSigningRequests) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Resource("certificatesigningrequests").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a certificateSigningRequest and creates it. Returns the server's representation of the certificateSigningRequest, and an error, if it occurs. -func (c *certificateSigningRequests) Create(certificateSigningRequest *certificates.CertificateSigningRequest) (result *certificates.CertificateSigningRequest, err error) { - result = &certificates.CertificateSigningRequest{} - err = c.client.Post().Resource("certificatesigningrequests").Body(certificateSigningRequest).Do().Into(result) - return -} - -// Update takes the representation of a certificateSigningRequest and updates it. Returns the server's representation of the certificateSigningRequest, and an error, if it occurs. -func (c *certificateSigningRequests) Update(certificateSigningRequest *certificates.CertificateSigningRequest) (result *certificates.CertificateSigningRequest, err error) { - result = &certificates.CertificateSigningRequest{} - err = c.client.Put().Resource("certificatesigningrequests").Name(certificateSigningRequest.Name).Body(certificateSigningRequest).Do().Into(result) - return -} - -// UpdateStatus takes the representation of a certificateSigningRequest and updates it. Returns the server's representation of the certificateSigningRequest, and an error, if it occurs. -func (c *certificateSigningRequests) UpdateStatus(certificateSigningRequest *certificates.CertificateSigningRequest) (result *certificates.CertificateSigningRequest, err error) { - result = &certificates.CertificateSigningRequest{} - err = c.client.Put().Resource("certificatesigningrequests").Name(certificateSigningRequest.Name).SubResource("status").Body(certificateSigningRequest).Do().Into(result) - return -} - -// UpdateApproval takes the representation of a certificateSigningRequest and updates it. Returns the server's representation of the certificateSigningRequest, and an error, if it occurs. -func (c *certificateSigningRequests) UpdateApproval(certificateSigningRequest *certificates.CertificateSigningRequest) (result *certificates.CertificateSigningRequest, err error) { - result = &certificates.CertificateSigningRequest{} - err = c.client.Put().Resource("certificatesigningrequests").Name(certificateSigningRequest.Name).SubResource("approval").Body(certificateSigningRequest).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested certificateSigningRequests. -func (c *certificateSigningRequests) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(api.NamespaceAll). - Resource("certificatesigningrequests"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/client.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/client.go deleted file mode 100644 index 0e23248..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/client.go +++ /dev/null @@ -1,202 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "net" - "net/url" - "strings" - - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/typed/discovery" -) - -// Interface holds the methods for clients of Kubernetes, -// an interface to allow mock testing. -type Interface interface { - PodsNamespacer - PodTemplatesNamespacer - ReplicationControllersNamespacer - ServicesNamespacer - EndpointsNamespacer - NodesInterface - EventNamespacer - LimitRangesNamespacer - ResourceQuotasNamespacer - ServiceAccountsNamespacer - SecretsNamespacer - NamespacesInterface - PersistentVolumesInterface - PersistentVolumeClaimsNamespacer - ComponentStatusesInterface - ConfigMapsNamespacer - Apps() AppsInterface - Authorization() AuthorizationInterface - Autoscaling() AutoscalingInterface - Authentication() AuthenticationInterface - Batch() BatchInterface - Extensions() ExtensionsInterface - Rbac() RbacInterface - Discovery() discovery.DiscoveryInterface - Certificates() CertificatesInterface - Storage() StorageInterface -} - -func (c *Client) ReplicationControllers(namespace string) ReplicationControllerInterface { - return newReplicationControllers(c, namespace) -} - -func (c *Client) Nodes() NodeInterface { - return newNodes(c) -} - -func (c *Client) Events(namespace string) EventInterface { - return newEvents(c, namespace) -} - -func (c *Client) Endpoints(namespace string) EndpointsInterface { - return newEndpoints(c, namespace) -} - -func (c *Client) Pods(namespace string) PodInterface { - return newPods(c, namespace) -} - -func (c *Client) PodTemplates(namespace string) PodTemplateInterface { - return newPodTemplates(c, namespace) -} - -func (c *Client) Services(namespace string) ServiceInterface { - return newServices(c, namespace) -} -func (c *Client) LimitRanges(namespace string) LimitRangeInterface { - return newLimitRanges(c, namespace) -} - -func (c *Client) ResourceQuotas(namespace string) ResourceQuotaInterface { - return newResourceQuotas(c, namespace) -} - -func (c *Client) ServiceAccounts(namespace string) ServiceAccountsInterface { - return newServiceAccounts(c, namespace) -} - -func (c *Client) Secrets(namespace string) SecretsInterface { - return newSecrets(c, namespace) -} - -func (c *Client) Namespaces() NamespaceInterface { - return newNamespaces(c) -} - -func (c *Client) PersistentVolumes() PersistentVolumeInterface { - return newPersistentVolumes(c) -} - -func (c *Client) PersistentVolumeClaims(namespace string) PersistentVolumeClaimInterface { - return newPersistentVolumeClaims(c, namespace) -} - -func (c *Client) ComponentStatuses() ComponentStatusInterface { - return newComponentStatuses(c) -} - -func (c *Client) ConfigMaps(namespace string) ConfigMapsInterface { - return newConfigMaps(c, namespace) -} - -// Client is the implementation of a Kubernetes client. -type Client struct { - *restclient.RESTClient - *AuthorizationClient - *AutoscalingClient - *AuthenticationClient - *BatchClient - *ExtensionsClient - *AppsClient - *PolicyClient - *RbacClient - *discovery.DiscoveryClient - *CertificatesClient - *StorageClient -} - -// IsTimeout tests if this is a timeout error in the underlying transport. -// This is unbelievably ugly. -// See: http://stackoverflow.com/questions/23494950/specifically-check-for-timeout-error for details -func IsTimeout(err error) bool { - if err == nil { - return false - } - switch err := err.(type) { - case *url.Error: - if err, ok := err.Err.(net.Error); ok { - return err.Timeout() - } - case net.Error: - return err.Timeout() - } - - if strings.Contains(err.Error(), "use of closed network connection") { - return true - } - return false -} - -func (c *Client) Authorization() AuthorizationInterface { - return c.AuthorizationClient -} - -func (c *Client) Autoscaling() AutoscalingInterface { - return c.AutoscalingClient -} - -func (c *Client) Authentication() AuthenticationInterface { - return c.AuthenticationClient -} - -func (c *Client) Batch() BatchInterface { - return c.BatchClient -} - -func (c *Client) Extensions() ExtensionsInterface { - return c.ExtensionsClient -} - -func (c *Client) Apps() AppsInterface { - return c.AppsClient -} - -func (c *Client) Rbac() RbacInterface { - return c.RbacClient -} - -func (c *Client) Policy() PolicyInterface { - return c.PolicyClient -} - -func (c *Client) Discovery() discovery.DiscoveryInterface { - return c.DiscoveryClient -} - -func (c *Client) Certificates() CertificatesInterface { - return c.CertificatesClient -} - -func (c *Client) Storage() StorageInterface { - return c.StorageClient -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterrolebindings.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterrolebindings.go deleted file mode 100644 index fa9cad9..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterrolebindings.go +++ /dev/null @@ -1,92 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/watch" -) - -// ClusterRoleBindings has methods to work with ClusterRoleBinding resources in a namespace -type ClusterRoleBindings interface { - ClusterRoleBindings() ClusterRoleBindingInterface -} - -// ClusterRoleBindingInterface has methods to work with ClusterRoleBinding resources. -type ClusterRoleBindingInterface interface { - List(opts api.ListOptions) (*rbac.ClusterRoleBindingList, error) - Get(name string) (*rbac.ClusterRoleBinding, error) - Delete(name string, options *api.DeleteOptions) error - Create(clusterRoleBinding *rbac.ClusterRoleBinding) (*rbac.ClusterRoleBinding, error) - Update(clusterRoleBinding *rbac.ClusterRoleBinding) (*rbac.ClusterRoleBinding, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// clusterRoleBindings implements ClusterRoleBindingsNamespacer interface -type clusterRoleBindings struct { - client *RbacClient -} - -// newClusterRoleBindings returns a clusterRoleBindings -func newClusterRoleBindings(c *RbacClient) *clusterRoleBindings { - return &clusterRoleBindings{ - client: c, - } -} - -// List takes label and field selectors, and returns the list of clusterRoleBindings that match those selectors. -func (c *clusterRoleBindings) List(opts api.ListOptions) (result *rbac.ClusterRoleBindingList, err error) { - result = &rbac.ClusterRoleBindingList{} - err = c.client.Get().Resource("clusterrolebindings").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the clusterRoleBinding, and returns the corresponding ClusterRoleBinding object, and an error if it occurs -func (c *clusterRoleBindings) Get(name string) (result *rbac.ClusterRoleBinding, err error) { - result = &rbac.ClusterRoleBinding{} - err = c.client.Get().Resource("clusterrolebindings").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the clusterRoleBinding and deletes it. Returns an error if one occurs. -func (c *clusterRoleBindings) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Resource("clusterrolebindings").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a clusterRoleBinding and creates it. Returns the server's representation of the clusterRoleBinding, and an error, if it occurs. -func (c *clusterRoleBindings) Create(clusterRoleBinding *rbac.ClusterRoleBinding) (result *rbac.ClusterRoleBinding, err error) { - result = &rbac.ClusterRoleBinding{} - err = c.client.Post().Resource("clusterrolebindings").Body(clusterRoleBinding).Do().Into(result) - return -} - -// Update takes the representation of a clusterRoleBinding and updates it. Returns the server's representation of the clusterRoleBinding, and an error, if it occurs. -func (c *clusterRoleBindings) Update(clusterRoleBinding *rbac.ClusterRoleBinding) (result *rbac.ClusterRoleBinding, err error) { - result = &rbac.ClusterRoleBinding{} - err = c.client.Put().Resource("clusterrolebindings").Name(clusterRoleBinding.Name).Body(clusterRoleBinding).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested clusterRoleBindings. -func (c *clusterRoleBindings) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Resource("clusterrolebindings"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterroles.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterroles.go deleted file mode 100644 index 165271a..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/clusterroles.go +++ /dev/null @@ -1,92 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/watch" -) - -// ClusterRoles has methods to work with ClusterRole resources in a namespace -type ClusterRoles interface { - ClusterRoles() ClusterRoleInterface -} - -// ClusterRoleInterface has methods to work with ClusterRole resources. -type ClusterRoleInterface interface { - List(opts api.ListOptions) (*rbac.ClusterRoleList, error) - Get(name string) (*rbac.ClusterRole, error) - Delete(name string, options *api.DeleteOptions) error - Create(clusterRole *rbac.ClusterRole) (*rbac.ClusterRole, error) - Update(clusterRole *rbac.ClusterRole) (*rbac.ClusterRole, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// clusterRoles implements ClusterRolesNamespacer interface -type clusterRoles struct { - client *RbacClient -} - -// newClusterRoles returns a clusterRoles -func newClusterRoles(c *RbacClient) *clusterRoles { - return &clusterRoles{ - client: c, - } -} - -// List takes label and field selectors, and returns the list of clusterRoles that match those selectors. -func (c *clusterRoles) List(opts api.ListOptions) (result *rbac.ClusterRoleList, err error) { - result = &rbac.ClusterRoleList{} - err = c.client.Get().Resource("clusterroles").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the clusterRole, and returns the corresponding ClusterRole object, and an error if it occurs -func (c *clusterRoles) Get(name string) (result *rbac.ClusterRole, err error) { - result = &rbac.ClusterRole{} - err = c.client.Get().Resource("clusterroles").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the clusterRole and deletes it. Returns an error if one occurs. -func (c *clusterRoles) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Resource("clusterroles").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a clusterRole and creates it. Returns the server's representation of the clusterRole, and an error, if it occurs. -func (c *clusterRoles) Create(clusterRole *rbac.ClusterRole) (result *rbac.ClusterRole, err error) { - result = &rbac.ClusterRole{} - err = c.client.Post().Resource("clusterroles").Body(clusterRole).Do().Into(result) - return -} - -// Update takes the representation of a clusterRole and updates it. Returns the server's representation of the clusterRole, and an error, if it occurs. -func (c *clusterRoles) Update(clusterRole *rbac.ClusterRole) (result *rbac.ClusterRole, err error) { - result = &rbac.ClusterRole{} - err = c.client.Put().Resource("clusterroles").Name(clusterRole.Name).Body(clusterRole).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested clusterRoles. -func (c *clusterRoles) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Resource("clusterroles"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/componentstatuses.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/componentstatuses.go deleted file mode 100644 index aca996b..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/componentstatuses.go +++ /dev/null @@ -1,60 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" -) - -type ComponentStatusesInterface interface { - ComponentStatuses() ComponentStatusInterface -} - -// ComponentStatusInterface contains methods to retrieve ComponentStatus -type ComponentStatusInterface interface { - List(opts api.ListOptions) (*api.ComponentStatusList, error) - Get(name string) (*api.ComponentStatus, error) - - // TODO: It'd be nice to have watch support at some point - //Watch(opts api.ListOptions) (watch.Interface, error) -} - -// componentStatuses implements ComponentStatusesInterface -type componentStatuses struct { - client *Client -} - -func newComponentStatuses(c *Client) *componentStatuses { - return &componentStatuses{c} -} - -func (c *componentStatuses) List(opts api.ListOptions) (result *api.ComponentStatusList, err error) { - result = &api.ComponentStatusList{} - err = c.client.Get(). - Resource("componentStatuses"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -func (c *componentStatuses) Get(name string) (result *api.ComponentStatus, err error) { - result = &api.ComponentStatus{} - err = c.client.Get().Resource("componentStatuses").Name(name).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/conditions.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/conditions.go deleted file mode 100644 index 36401e8..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/conditions.go +++ /dev/null @@ -1,271 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/errors" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/apis/extensions" - appsclient "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/apps/unversioned" - batchclient "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/batch/unversioned" - coreclient "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/core/unversioned" - extensionsclient "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/unversioned" - "k8s.io/kubernetes/pkg/util/wait" - "k8s.io/kubernetes/pkg/watch" -) - -// ControllerHasDesiredReplicas returns a condition that will be true if and only if -// the desired replica count for a controller's ReplicaSelector equals the Replicas count. -func ControllerHasDesiredReplicas(rcClient coreclient.ReplicationControllersGetter, controller *api.ReplicationController) wait.ConditionFunc { - - // If we're given a controller where the status lags the spec, it either means that the controller is stale, - // or that the rc manager hasn't noticed the update yet. Polling status.Replicas is not safe in the latter case. - desiredGeneration := controller.Generation - - return func() (bool, error) { - ctrl, err := rcClient.ReplicationControllers(controller.Namespace).Get(controller.Name) - if err != nil { - return false, err - } - // There's a chance a concurrent update modifies the Spec.Replicas causing this check to pass, - // or, after this check has passed, a modification causes the rc manager to create more pods. - // This will not be an issue once we've implemented graceful delete for rcs, but till then - // concurrent stop operations on the same rc might have unintended side effects. - return ctrl.Status.ObservedGeneration >= desiredGeneration && ctrl.Status.Replicas == ctrl.Spec.Replicas, nil - } -} - -// ReplicaSetHasDesiredReplicas returns a condition that will be true if and only if -// the desired replica count for a ReplicaSet's ReplicaSelector equals the Replicas count. -func ReplicaSetHasDesiredReplicas(rsClient extensionsclient.ReplicaSetsGetter, replicaSet *extensions.ReplicaSet) wait.ConditionFunc { - - // If we're given a ReplicaSet where the status lags the spec, it either means that the - // ReplicaSet is stale, or that the ReplicaSet manager hasn't noticed the update yet. - // Polling status.Replicas is not safe in the latter case. - desiredGeneration := replicaSet.Generation - - return func() (bool, error) { - rs, err := rsClient.ReplicaSets(replicaSet.Namespace).Get(replicaSet.Name) - if err != nil { - return false, err - } - // There's a chance a concurrent update modifies the Spec.Replicas causing this check to - // pass, or, after this check has passed, a modification causes the ReplicaSet manager to - // create more pods. This will not be an issue once we've implemented graceful delete for - // ReplicaSets, but till then concurrent stop operations on the same ReplicaSet might have - // unintended side effects. - return rs.Status.ObservedGeneration >= desiredGeneration && rs.Status.Replicas == rs.Spec.Replicas, nil - } -} - -func PetSetHasDesiredPets(psClient appsclient.PetSetsGetter, petset *apps.PetSet) wait.ConditionFunc { - // TODO: Differentiate between 0 pets and a really quick scale down using generation. - return func() (bool, error) { - ps, err := psClient.PetSets(petset.Namespace).Get(petset.Name) - if err != nil { - return false, err - } - return ps.Status.Replicas == ps.Spec.Replicas, nil - } -} - -// JobHasDesiredParallelism returns a condition that will be true if the desired parallelism count -// for a job equals the current active counts or is less by an appropriate successful/unsuccessful count. -func JobHasDesiredParallelism(jobClient batchclient.JobsGetter, job *batch.Job) wait.ConditionFunc { - return func() (bool, error) { - job, err := jobClient.Jobs(job.Namespace).Get(job.Name) - if err != nil { - return false, err - } - - // desired parallelism can be either the exact number, in which case return immediately - if job.Status.Active == *job.Spec.Parallelism { - return true, nil - } - if job.Spec.Completions == nil { - // A job without specified completions needs to wait for Active to reach Parallelism. - return false, nil - } else { - // otherwise count successful - progress := *job.Spec.Completions - job.Status.Active - job.Status.Succeeded - return progress == 0, nil - } - } -} - -// DeploymentHasDesiredReplicas returns a condition that will be true if and only if -// the desired replica count for a deployment equals its updated replicas count. -// (non-terminated pods that have the desired template spec). -func DeploymentHasDesiredReplicas(dClient extensionsclient.DeploymentsGetter, deployment *extensions.Deployment) wait.ConditionFunc { - // If we're given a deployment where the status lags the spec, it either - // means that the deployment is stale, or that the deployment manager hasn't - // noticed the update yet. Polling status.Replicas is not safe in the latter - // case. - desiredGeneration := deployment.Generation - - return func() (bool, error) { - deployment, err := dClient.Deployments(deployment.Namespace).Get(deployment.Name) - if err != nil { - return false, err - } - return deployment.Status.ObservedGeneration >= desiredGeneration && - deployment.Status.UpdatedReplicas == deployment.Spec.Replicas, nil - } -} - -// ErrPodCompleted is returned by PodRunning or PodContainerRunning to indicate that -// the pod has already reached completed state. -var ErrPodCompleted = fmt.Errorf("pod ran to completion") - -// ErrContainerTerminated is returned by PodContainerRunning in the intermediate -// state where the pod indicates it's still running, but its container is already terminated -var ErrContainerTerminated = fmt.Errorf("container terminated") - -// PodRunning returns true if the pod is running, false if the pod has not yet reached running state, -// returns ErrPodCompleted if the pod has run to completion, or an error in any other case. -func PodRunning(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "pods"}, "") - } - switch t := event.Object.(type) { - case *api.Pod: - switch t.Status.Phase { - case api.PodRunning: - return true, nil - case api.PodFailed, api.PodSucceeded: - return false, ErrPodCompleted - } - } - return false, nil -} - -// PodCompleted returns true if the pod has run to completion, false if the pod has not yet -// reached running state, or an error in any other case. -func PodCompleted(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "pods"}, "") - } - switch t := event.Object.(type) { - case *api.Pod: - switch t.Status.Phase { - case api.PodFailed, api.PodSucceeded: - return true, nil - } - } - return false, nil -} - -// PodRunningAndReady returns true if the pod is running and ready, false if the pod has not -// yet reached those states, returns ErrPodCompleted if the pod has run to completion, or -// an error in any other case. -func PodRunningAndReady(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "pods"}, "") - } - switch t := event.Object.(type) { - case *api.Pod: - switch t.Status.Phase { - case api.PodFailed, api.PodSucceeded: - return false, ErrPodCompleted - case api.PodRunning: - return api.IsPodReady(t), nil - } - } - return false, nil -} - -// PodNotPending returns true if the pod has left the pending state, false if it has not, -// or an error in any other case (such as if the pod was deleted). -func PodNotPending(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "pods"}, "") - } - switch t := event.Object.(type) { - case *api.Pod: - switch t.Status.Phase { - case api.PodPending: - return false, nil - default: - return true, nil - } - } - return false, nil -} - -// PodContainerRunning returns false until the named container has ContainerStatus running (at least once), -// and will return an error if the pod is deleted, runs to completion, or the container pod is not available. -func PodContainerRunning(containerName string) watch.ConditionFunc { - return func(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "pods"}, "") - } - switch t := event.Object.(type) { - case *api.Pod: - switch t.Status.Phase { - case api.PodRunning, api.PodPending: - case api.PodFailed, api.PodSucceeded: - return false, ErrPodCompleted - default: - return false, nil - } - for _, s := range t.Status.ContainerStatuses { - if s.Name != containerName { - continue - } - if s.State.Terminated != nil { - return false, ErrContainerTerminated - } - return s.State.Running != nil, nil - } - for _, s := range t.Status.InitContainerStatuses { - if s.Name != containerName { - continue - } - if s.State.Terminated != nil { - return false, ErrContainerTerminated - } - return s.State.Running != nil, nil - } - return false, nil - } - return false, nil - } -} - -// ServiceAccountHasSecrets returns true if the service account has at least one secret, -// false if it does not, or an error. -func ServiceAccountHasSecrets(event watch.Event) (bool, error) { - switch event.Type { - case watch.Deleted: - return false, errors.NewNotFound(unversioned.GroupResource{Resource: "serviceaccounts"}, "") - } - switch t := event.Object.(type) { - case *api.ServiceAccount: - return len(t.Secrets) > 0, nil - } - return false, nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/configmap.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/configmap.go deleted file mode 100644 index c2f2035..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/configmap.go +++ /dev/null @@ -1,122 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -const ( - ConfigMapResourceName string = "configmaps" -) - -type ConfigMapsNamespacer interface { - ConfigMaps(namespace string) ConfigMapsInterface -} - -type ConfigMapsInterface interface { - Get(string) (*api.ConfigMap, error) - List(opts api.ListOptions) (*api.ConfigMapList, error) - Create(*api.ConfigMap) (*api.ConfigMap, error) - Delete(string) error - Update(*api.ConfigMap) (*api.ConfigMap, error) - Watch(api.ListOptions) (watch.Interface, error) -} - -type ConfigMaps struct { - client *Client - namespace string -} - -// ConfigMaps should implement ConfigMapsInterface -var _ ConfigMapsInterface = &ConfigMaps{} - -func newConfigMaps(c *Client, ns string) *ConfigMaps { - return &ConfigMaps{ - client: c, - namespace: ns, - } -} - -func (c *ConfigMaps) Get(name string) (*api.ConfigMap, error) { - result := &api.ConfigMap{} - err := c.client.Get(). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - Name(name). - Do(). - Into(result) - - return result, err -} - -func (c *ConfigMaps) List(opts api.ListOptions) (*api.ConfigMapList, error) { - result := &api.ConfigMapList{} - err := c.client.Get(). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -func (c *ConfigMaps) Create(cfg *api.ConfigMap) (*api.ConfigMap, error) { - result := &api.ConfigMap{} - err := c.client.Post(). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - Body(cfg). - Do(). - Into(result) - - return result, err -} - -func (c *ConfigMaps) Delete(name string) error { - return c.client.Delete(). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - Name(name). - Do(). - Error() -} - -func (c *ConfigMaps) Update(cfg *api.ConfigMap) (*api.ConfigMap, error) { - result := &api.ConfigMap{} - - err := c.client.Put(). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - Name(cfg.Name). - Body(cfg). - Do(). - Into(result) - - return result, err -} - -func (c *ConfigMaps) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.namespace). - Resource(ConfigMapResourceName). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/containerinfo.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/containerinfo.go deleted file mode 100644 index 2f9aae8..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/containerinfo.go +++ /dev/null @@ -1,123 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "bytes" - "encoding/json" - "fmt" - "io" - "net" - "net/http" - "strconv" - - cadvisorapi "github.com/google/cadvisor/info/v1" -) - -type ContainerInfoGetter interface { - // GetContainerInfo returns information about a container. - GetContainerInfo(host, podID, containerID string, req *cadvisorapi.ContainerInfoRequest) (*cadvisorapi.ContainerInfo, error) - // GetRootInfo returns information about the root container on a machine. - GetRootInfo(host string, req *cadvisorapi.ContainerInfoRequest) (*cadvisorapi.ContainerInfo, error) - // GetMachineInfo returns the machine's information like number of cores, memory capacity. - GetMachineInfo(host string) (*cadvisorapi.MachineInfo, error) -} - -type HTTPContainerInfoGetter struct { - Client *http.Client - Port int -} - -func (self *HTTPContainerInfoGetter) GetMachineInfo(host string) (*cadvisorapi.MachineInfo, error) { - request, err := http.NewRequest( - "GET", - fmt.Sprintf("http://%v/spec", - net.JoinHostPort(host, strconv.Itoa(self.Port)), - ), - nil, - ) - if err != nil { - return nil, err - } - - response, err := self.Client.Do(request) - if err != nil { - return nil, err - } - defer response.Body.Close() - if response.StatusCode != http.StatusOK { - return nil, fmt.Errorf("trying to get machine spec from %v; received status %v", - host, response.Status) - } - var minfo cadvisorapi.MachineInfo - err = json.NewDecoder(response.Body).Decode(&minfo) - if err != nil { - return nil, err - } - return &minfo, nil -} - -func (self *HTTPContainerInfoGetter) getContainerInfo(host, path string, req *cadvisorapi.ContainerInfoRequest) (*cadvisorapi.ContainerInfo, error) { - var body io.Reader - if req != nil { - content, err := json.Marshal(req) - if err != nil { - return nil, err - } - body = bytes.NewBuffer(content) - } - - request, err := http.NewRequest( - "GET", - fmt.Sprintf("http://%v/stats/%v", - net.JoinHostPort(host, strconv.Itoa(self.Port)), - path, - ), - body, - ) - if err != nil { - return nil, err - } - - response, err := self.Client.Do(request) - if err != nil { - return nil, err - } - defer response.Body.Close() - if response.StatusCode != http.StatusOK { - return nil, fmt.Errorf("trying to get info for %v from %v; received status %v", - path, host, response.Status) - } - var cinfo cadvisorapi.ContainerInfo - err = json.NewDecoder(response.Body).Decode(&cinfo) - if err != nil { - return nil, err - } - return &cinfo, nil -} - -func (self *HTTPContainerInfoGetter) GetContainerInfo(host, podID, containerID string, req *cadvisorapi.ContainerInfoRequest) (*cadvisorapi.ContainerInfo, error) { - return self.getContainerInfo( - host, - fmt.Sprintf("%v/%v", podID, containerID), - req, - ) -} - -func (self *HTTPContainerInfoGetter) GetRootInfo(host string, req *cadvisorapi.ContainerInfoRequest) (*cadvisorapi.ContainerInfo, error) { - return self.getContainerInfo(host, "", req) -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/daemon_sets.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/daemon_sets.go deleted file mode 100644 index 7ec9182..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/daemon_sets.go +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// DaemonsSetsNamespacer has methods to work with DaemonSet resources in a namespace -type DaemonSetsNamespacer interface { - DaemonSets(namespace string) DaemonSetInterface -} - -type DaemonSetInterface interface { - List(opts api.ListOptions) (*extensions.DaemonSetList, error) - Get(name string) (*extensions.DaemonSet, error) - Create(ctrl *extensions.DaemonSet) (*extensions.DaemonSet, error) - Update(ctrl *extensions.DaemonSet) (*extensions.DaemonSet, error) - UpdateStatus(ctrl *extensions.DaemonSet) (*extensions.DaemonSet, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// daemonSets implements DaemonsSetsNamespacer interface -type daemonSets struct { - r *ExtensionsClient - ns string -} - -func newDaemonSets(c *ExtensionsClient, namespace string) *daemonSets { - return &daemonSets{c, namespace} -} - -// Ensure statically that daemonSets implements DaemonSetsInterface. -var _ DaemonSetInterface = &daemonSets{} - -func (c *daemonSets) List(opts api.ListOptions) (result *extensions.DaemonSetList, err error) { - result = &extensions.DaemonSetList{} - err = c.r.Get().Namespace(c.ns).Resource("daemonsets").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular daemon set. -func (c *daemonSets) Get(name string) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} - err = c.r.Get().Namespace(c.ns).Resource("daemonsets").Name(name).Do().Into(result) - return -} - -// Create creates a new daemon set. -func (c *daemonSets) Create(daemon *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} - err = c.r.Post().Namespace(c.ns).Resource("daemonsets").Body(daemon).Do().Into(result) - return -} - -// Update updates an existing daemon set. -func (c *daemonSets) Update(daemon *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} - err = c.r.Put().Namespace(c.ns).Resource("daemonsets").Name(daemon.Name).Body(daemon).Do().Into(result) - return -} - -// UpdateStatus updates an existing daemon set status -func (c *daemonSets) UpdateStatus(daemon *extensions.DaemonSet) (result *extensions.DaemonSet, err error) { - result = &extensions.DaemonSet{} - err = c.r.Put().Namespace(c.ns).Resource("daemonsets").Name(daemon.Name).SubResource("status").Body(daemon).Do().Into(result) - return -} - -// Delete deletes an existing daemon set. -func (c *daemonSets) Delete(name string) error { - return c.r.Delete().Namespace(c.ns).Resource("daemonsets").Name(name).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested daemon sets. -func (c *daemonSets) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("daemonsets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/deployment.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/deployment.go deleted file mode 100644 index a5e8afe..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/deployment.go +++ /dev/null @@ -1,111 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// DeploymentsNamespacer has methods to work with Deployment resources in a namespace -type DeploymentsNamespacer interface { - Deployments(namespace string) DeploymentInterface -} - -// DeploymentInterface has methods to work with Deployment resources. -type DeploymentInterface interface { - List(opts api.ListOptions) (*extensions.DeploymentList, error) - Get(name string) (*extensions.Deployment, error) - Delete(name string, options *api.DeleteOptions) error - Create(*extensions.Deployment) (*extensions.Deployment, error) - Update(*extensions.Deployment) (*extensions.Deployment, error) - UpdateStatus(*extensions.Deployment) (*extensions.Deployment, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Rollback(*extensions.DeploymentRollback) error -} - -// deployments implements DeploymentInterface -type deployments struct { - client *ExtensionsClient - ns string -} - -// Ensure statically that deployments implements DeploymentInterface. -var _ DeploymentInterface = &deployments{} - -// newDeployments returns a Deployments -func newDeployments(c *ExtensionsClient, namespace string) *deployments { - return &deployments{ - client: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of Deployments that match those selectors. -func (c *deployments) List(opts api.ListOptions) (result *extensions.DeploymentList, err error) { - result = &extensions.DeploymentList{} - err = c.client.Get().Namespace(c.ns).Resource("deployments").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes name of the deployment, and returns the corresponding deployment object, and an error if there is any. -func (c *deployments) Get(name string) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} - err = c.client.Get().Namespace(c.ns).Resource("deployments").Name(name).Do().Into(result) - return -} - -// Delete takes name of the deployment and deletes it. Returns an error if one occurs. -func (c *deployments) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Namespace(c.ns).Resource("deployments").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a deployment and creates it. Returns the server's representation of the deployment, and an error, if there is any. -func (c *deployments) Create(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} - err = c.client.Post().Namespace(c.ns).Resource("deployments").Body(deployment).Do().Into(result) - return -} - -// Update takes the representation of a deployment and updates it. Returns the server's representation of the deployment, and an error, if there is any. -func (c *deployments) Update(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} - err = c.client.Put().Namespace(c.ns).Resource("deployments").Name(deployment.Name).Body(deployment).Do().Into(result) - return -} - -func (c *deployments) UpdateStatus(deployment *extensions.Deployment) (result *extensions.Deployment, err error) { - result = &extensions.Deployment{} - err = c.client.Put().Namespace(c.ns).Resource("deployments").Name(deployment.Name).SubResource("status").Body(deployment).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested deployments. -func (c *deployments) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("deployments"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Rollback applied the provided DeploymentRollback to the named deployment in the current namespace. -func (c *deployments) Rollback(deploymentRollback *extensions.DeploymentRollback) error { - return c.client.Post().Namespace(c.ns).Resource("deployments").Name(deploymentRollback.Name).SubResource("rollback").Body(deploymentRollback).Do().Error() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/doc.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/doc.go deleted file mode 100644 index fac0f9e..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/doc.go +++ /dev/null @@ -1,58 +0,0 @@ -/* -Copyright 2014 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. -*/ - -/* -Package unversioned contains the implementation of the client side communication with the -Kubernetes master. The Client class provides methods for reading, creating, updating, -and deleting pods, replication controllers, daemons, services, and nodes. - -Most consumers should use the Config object to create a Client: - - import ( - client "k8s.io/kubernetes/pkg/client/unversioned" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/api" - ) - - [...] - - config := &restclient.Config{ - Host: "http://localhost:8080", - Username: "test", - Password: "password", - } - c, err := client.New(config) - if err != nil { - // handle error - } - pods, err := c.Pods(api.NamespaceDefault).List(api.ListOptions{}) - if err != nil { - // handle error - } - -More advanced consumers may wish to provide their own transport via a http.RoundTripper: - - config := &restclient.Config{ - Host: "https://localhost:8080", - Transport: oauthclient.Transport(), - } - c, err := client.New(config) - -The RESTClient type implements the Kubernetes API conventions (see `docs/devel/api-conventions.md`) -for a given API path and is intended for use by consumers implementing their own Kubernetes -compatible APIs. -*/ -package unversioned diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/endpoints.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/endpoints.go deleted file mode 100644 index 6e20a34..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/endpoints.go +++ /dev/null @@ -1,101 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// EndpointsNamespacer has methods to work with Endpoints resources in a namespace -type EndpointsNamespacer interface { - Endpoints(namespace string) EndpointsInterface -} - -// EndpointsInterface has methods to work with Endpoints resources -type EndpointsInterface interface { - Create(endpoints *api.Endpoints) (*api.Endpoints, error) - List(opts api.ListOptions) (*api.EndpointsList, error) - Get(name string) (*api.Endpoints, error) - Delete(name string) error - Update(endpoints *api.Endpoints) (*api.Endpoints, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// endpoints implements EndpointsInterface -type endpoints struct { - r *Client - ns string -} - -// newEndpoints returns a endpoints -func newEndpoints(c *Client, namespace string) *endpoints { - return &endpoints{c, namespace} -} - -// Create creates a new endpoint. -func (c *endpoints) Create(endpoints *api.Endpoints) (*api.Endpoints, error) { - result := &api.Endpoints{} - err := c.r.Post().Namespace(c.ns).Resource("endpoints").Body(endpoints).Do().Into(result) - return result, err -} - -// List takes a selector, and returns the list of endpoints that match that selector -func (c *endpoints) List(opts api.ListOptions) (result *api.EndpointsList, err error) { - result = &api.EndpointsList{} - err = c.r.Get(). - Namespace(c.ns). - Resource("endpoints"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return -} - -// Get returns information about the endpoints for a particular service. -func (c *endpoints) Get(name string) (result *api.Endpoints, err error) { - result = &api.Endpoints{} - err = c.r.Get().Namespace(c.ns).Resource("endpoints").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the endpoint, and returns an error if one occurs -func (c *endpoints) Delete(name string) error { - return c.r.Delete().Namespace(c.ns).Resource("endpoints").Name(name).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested endpoints for a service. -func (c *endpoints) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("endpoints"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -func (c *endpoints) Update(endpoints *api.Endpoints) (*api.Endpoints, error) { - result := &api.Endpoints{} - err := c.r.Put(). - Namespace(c.ns). - Resource("endpoints"). - Name(endpoints.Name). - Body(endpoints). - Do(). - Into(result) - return result, err -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/events.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/events.go deleted file mode 100644 index 3421bd8..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/events.go +++ /dev/null @@ -1,219 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/fields" - "k8s.io/kubernetes/pkg/runtime" - "k8s.io/kubernetes/pkg/watch" -) - -// EventNamespacer can return an EventInterface for the given namespace. -type EventNamespacer interface { - Events(namespace string) EventInterface -} - -// EventInterface has methods to work with Event resources -type EventInterface interface { - Create(event *api.Event) (*api.Event, error) - Update(event *api.Event) (*api.Event, error) - Patch(event *api.Event, data []byte) (*api.Event, error) - List(opts api.ListOptions) (*api.EventList, error) - Get(name string) (*api.Event, error) - Watch(opts api.ListOptions) (watch.Interface, error) - // Search finds events about the specified object - Search(objOrRef runtime.Object) (*api.EventList, error) - Delete(name string) error - // DeleteCollection deletes a collection of events. - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - // Returns the appropriate field selector based on the API version being used to communicate with the server. - // The returned field selector can be used with List and Watch to filter desired events. - GetFieldSelector(involvedObjectName, involvedObjectNamespace, involvedObjectKind, involvedObjectUID *string) fields.Selector -} - -// events implements Events interface -type events struct { - client *Client - namespace string -} - -// newEvents returns a new events object. -func newEvents(c *Client, ns string) *events { - return &events{ - client: c, - namespace: ns, - } -} - -// Create makes a new event. Returns the copy of the event the server returns, -// or an error. The namespace to create the event within is deduced from the -// event; it must either match this event client's namespace, or this event -// client must have been created with the "" namespace. -func (e *events) Create(event *api.Event) (*api.Event, error) { - if e.namespace != "" && event.Namespace != e.namespace { - return nil, fmt.Errorf("can't create an event with namespace '%v' in namespace '%v'", event.Namespace, e.namespace) - } - result := &api.Event{} - err := e.client.Post(). - Namespace(event.Namespace). - Resource("events"). - Body(event). - Do(). - Into(result) - return result, err -} - -// Update modifies an existing event. It returns the copy of the event that the server returns, -// or an error. The namespace and key to update the event within is deduced from the event. The -// namespace must either match this event client's namespace, or this event client must have been -// created with the "" namespace. Update also requires the ResourceVersion to be set in the event -// object. -func (e *events) Update(event *api.Event) (*api.Event, error) { - result := &api.Event{} - err := e.client.Put(). - Namespace(event.Namespace). - Resource("events"). - Name(event.Name). - Body(event). - Do(). - Into(result) - return result, err -} - -// Patch modifies an existing event. It returns the copy of the event that the server returns, or an -// error. The namespace and name of the target event is deduced from the incompleteEvent. The -// namespace must either match this event client's namespace, or this event client must have been -// created with the "" namespace. -func (e *events) Patch(incompleteEvent *api.Event, data []byte) (*api.Event, error) { - result := &api.Event{} - err := e.client.Patch(api.StrategicMergePatchType). - Namespace(incompleteEvent.Namespace). - Resource("events"). - Name(incompleteEvent.Name). - Body(data). - Do(). - Into(result) - return result, err -} - -// List returns a list of events matching the selectors. -func (e *events) List(opts api.ListOptions) (*api.EventList, error) { - result := &api.EventList{} - err := e.client.Get(). - Namespace(e.namespace). - Resource("events"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return result, err -} - -// Get returns the given event, or an error. -func (e *events) Get(name string) (*api.Event, error) { - result := &api.Event{} - err := e.client.Get(). - Namespace(e.namespace). - Resource("events"). - Name(name). - Do(). - Into(result) - return result, err -} - -// Watch starts watching for events matching the given selectors. -func (e *events) Watch(opts api.ListOptions) (watch.Interface, error) { - return e.client.Get(). - Prefix("watch"). - Namespace(e.namespace). - Resource("events"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Search finds events about the specified object. The namespace of the -// object must match this event's client namespace unless the event client -// was made with the "" namespace. -func (e *events) Search(objOrRef runtime.Object) (*api.EventList, error) { - ref, err := api.GetReference(objOrRef) - if err != nil { - return nil, err - } - if e.namespace != "" && ref.Namespace != e.namespace { - return nil, fmt.Errorf("won't be able to find any events of namespace '%v' in namespace '%v'", ref.Namespace, e.namespace) - } - stringRefKind := string(ref.Kind) - var refKind *string - if stringRefKind != "" { - refKind = &stringRefKind - } - stringRefUID := string(ref.UID) - var refUID *string - if stringRefUID != "" { - refUID = &stringRefUID - } - fieldSelector := e.GetFieldSelector(&ref.Name, &ref.Namespace, refKind, refUID) - return e.List(api.ListOptions{FieldSelector: fieldSelector}) -} - -// Delete deletes an existing event. -func (e *events) Delete(name string) error { - return e.client.Delete(). - Namespace(e.namespace). - Resource("events"). - Name(name). - Do(). - Error() -} - -// DeleteCollection deletes a collection of objects. -func (e *events) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { - return e.client.Delete(). - Namespace(e.namespace). - Resource("events"). - VersionedParams(&listOptions, api.ParameterCodec). - Body(options). - Do(). - Error() -} - -// Returns the appropriate field selector based on the API version being used to communicate with the server. -// The returned field selector can be used with List and Watch to filter desired events. -func (e *events) GetFieldSelector(involvedObjectName, involvedObjectNamespace, involvedObjectKind, involvedObjectUID *string) fields.Selector { - apiVersion := e.client.APIVersion().String() - field := fields.Set{} - if involvedObjectName != nil { - field[GetInvolvedObjectNameFieldLabel(apiVersion)] = *involvedObjectName - } - if involvedObjectNamespace != nil { - field["involvedObject.namespace"] = *involvedObjectNamespace - } - if involvedObjectKind != nil { - field["involvedObject.kind"] = *involvedObjectKind - } - if involvedObjectUID != nil { - field["involvedObject.uid"] = *involvedObjectUID - } - return field.AsSelector() -} - -// Returns the appropriate field label to use for name of the involved object as per the given API version. -func GetInvolvedObjectNameFieldLabel(version string) string { - return "involvedObject.name" -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/extensions.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/extensions.go deleted file mode 100644 index f538055..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/extensions.go +++ /dev/null @@ -1,109 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/client/restclient" -) - -// Interface holds the experimental methods for clients of Kubernetes -// to allow mock testing. -// Features of Extensions group are not supported and may be changed or removed in -// incompatible ways at any time. -type ExtensionsInterface interface { - ScaleNamespacer - DaemonSetsNamespacer - DeploymentsNamespacer - JobsNamespacer - IngressNamespacer - NetworkPolicyNamespacer - ThirdPartyResourceNamespacer - ReplicaSetsNamespacer - PodSecurityPoliciesInterface -} - -// ExtensionsClient is used to interact with experimental Kubernetes features. -// Features of Extensions group are not supported and may be changed or removed in -// incompatible ways at any time. -type ExtensionsClient struct { - *restclient.RESTClient -} - -func (c *ExtensionsClient) PodSecurityPolicies() PodSecurityPolicyInterface { - return newPodSecurityPolicy(c) -} - -func (c *ExtensionsClient) Scales(namespace string) ScaleInterface { - return newScales(c, namespace) -} - -func (c *ExtensionsClient) DaemonSets(namespace string) DaemonSetInterface { - return newDaemonSets(c, namespace) -} - -func (c *ExtensionsClient) Deployments(namespace string) DeploymentInterface { - return newDeployments(c, namespace) -} - -func (c *ExtensionsClient) Jobs(namespace string) JobInterface { - return newJobs(c, namespace) -} - -func (c *ExtensionsClient) Ingress(namespace string) IngressInterface { - return newIngress(c, namespace) -} - -func (c *ExtensionsClient) NetworkPolicies(namespace string) NetworkPolicyInterface { - return newNetworkPolicies(c, namespace) -} - -func (c *ExtensionsClient) ThirdPartyResources() ThirdPartyResourceInterface { - return newThirdPartyResources(c) -} - -func (c *ExtensionsClient) ReplicaSets(namespace string) ReplicaSetInterface { - return newReplicaSets(c, namespace) -} - -// NewExtensions creates a new ExtensionsClient for the given config. This client -// provides access to experimental Kubernetes features. -// Features of Extensions group are not supported and may be changed or removed in -// incompatible ways at any time. -func NewExtensions(c *restclient.Config) (*ExtensionsClient, error) { - config := *c - if err := setGroupDefaults(extensions.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &ExtensionsClient{client}, nil -} - -// NewExtensionsOrDie creates a new ExtensionsClient for the given config and -// panics if there is an error in the config. -// Features of Extensions group are not supported and may be changed or removed in -// incompatible ways at any time. -func NewExtensionsOrDie(c *restclient.Config) *ExtensionsClient { - client, err := NewExtensions(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/flags.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/flags.go deleted file mode 100644 index 7d32a25..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/flags.go +++ /dev/null @@ -1,31 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "time" -) - -// FlagSet abstracts the flag interface for compatibility with both Golang "flag" -// and cobra pflags (Posix style). -type FlagSet interface { - StringVar(p *string, name, value, usage string) - BoolVar(p *bool, name string, value bool, usage string) - UintVar(p *uint, name string, value uint, usage string) - DurationVar(p *time.Duration, name string, value time.Duration, usage string) - IntVar(p *int, name string, value int, usage string) -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/helper.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/helper.go deleted file mode 100644 index b157e10..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/helper.go +++ /dev/null @@ -1,335 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/apis/authentication" - "k8s.io/kubernetes/pkg/apis/authorization" - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/apis/certificates" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/apis/policy" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/apis/storage" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/client/typed/discovery" - "k8s.io/kubernetes/pkg/util/sets" - "k8s.io/kubernetes/pkg/version" - // Import solely to initialize client auth plugins. - _ "k8s.io/kubernetes/plugin/pkg/client/auth" -) - -const ( - legacyAPIPath = "/api" - defaultAPIPath = "/apis" -) - -// New creates a Kubernetes client for the given config. This client works with pods, -// replication controllers, daemons, and services. It allows operations such as list, get, update -// and delete on these objects. An error is returned if the provided configuration -// is not valid. -func New(c *restclient.Config) (*Client, error) { - config := *c - if err := SetKubernetesDefaults(&config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - - discoveryConfig := *c - discoveryClient, err := discovery.NewDiscoveryClientForConfig(&discoveryConfig) - if err != nil { - return nil, err - } - - var authorizationClient *AuthorizationClient - if registered.IsRegistered(authorization.GroupName) { - authorizationConfig := *c - authorizationClient, err = NewAuthorization(&authorizationConfig) - if err != nil { - return nil, err - } - } - - var autoscalingClient *AutoscalingClient - if registered.IsRegistered(autoscaling.GroupName) { - autoscalingConfig := *c - autoscalingClient, err = NewAutoscaling(&autoscalingConfig) - if err != nil { - return nil, err - } - } - - var authenticationClient *AuthenticationClient - if registered.IsRegistered(authentication.GroupName) { - authenticationConfig := *c - authenticationClient, err = NewAuthentication(&authenticationConfig) - if err != nil { - return nil, err - } - } - - var batchClient *BatchClient - if registered.IsRegistered(batch.GroupName) { - batchConfig := *c - batchClient, err = NewBatch(&batchConfig) - if err != nil { - return nil, err - } - } - - var extensionsClient *ExtensionsClient - if registered.IsRegistered(extensions.GroupName) { - extensionsConfig := *c - extensionsClient, err = NewExtensions(&extensionsConfig) - if err != nil { - return nil, err - } - } - var policyClient *PolicyClient - if registered.IsRegistered(policy.GroupName) { - policyConfig := *c - policyClient, err = NewPolicy(&policyConfig) - if err != nil { - return nil, err - } - } - var certsClient *CertificatesClient - if registered.IsRegistered(certificates.GroupName) { - certsConfig := *c - certsClient, err = NewCertificates(&certsConfig) - if err != nil { - return nil, err - } - } - - var appsClient *AppsClient - if registered.IsRegistered(apps.GroupName) { - appsConfig := *c - appsClient, err = NewApps(&appsConfig) - if err != nil { - return nil, err - } - } - - var rbacClient *RbacClient - if registered.IsRegistered(rbac.GroupName) { - rbacConfig := *c - rbacClient, err = NewRbac(&rbacConfig) - if err != nil { - return nil, err - } - } - - var storageClient *StorageClient - if registered.IsRegistered(storage.GroupName) { - storageConfig := *c - storageClient, err = NewStorage(&storageConfig) - if err != nil { - return nil, err - } - } - - return &Client{ - RESTClient: client, - AppsClient: appsClient, - AuthenticationClient: authenticationClient, - AuthorizationClient: authorizationClient, - AutoscalingClient: autoscalingClient, - BatchClient: batchClient, - CertificatesClient: certsClient, - DiscoveryClient: discoveryClient, - ExtensionsClient: extensionsClient, - PolicyClient: policyClient, - RbacClient: rbacClient, - StorageClient: storageClient, - }, nil -} - -// MatchesServerVersion queries the server to compares the build version -// (git hash) of the client with the server's build version. It returns an error -// if it failed to contact the server or if the versions are not an exact match. -func MatchesServerVersion(client *Client, c *restclient.Config) error { - var err error - if client == nil { - client, err = New(c) - if err != nil { - return err - } - } - cVer := version.Get() - sVer, err := client.Discovery().ServerVersion() - if err != nil { - return fmt.Errorf("couldn't read version from server: %v\n", err) - } - // GitVersion includes GitCommit and GitTreeState, but best to be safe? - if cVer.GitVersion != sVer.GitVersion || cVer.GitCommit != sVer.GitCommit || cVer.GitTreeState != sVer.GitTreeState { - return fmt.Errorf("server version (%#v) differs from client version (%#v)!\n", sVer, cVer) - } - - return nil -} - -// NegotiateVersion queries the server's supported api versions to find -// a version that both client and server support. -// - If no version is provided, try registered client versions in order of -// preference. -// - If version is provided, but not default config (explicitly requested via -// commandline flag), and is unsupported by the server, print a warning to -// stderr and try client's registered versions in order of preference. -// - If version is config default, and the server does not support it, -// return an error. -func NegotiateVersion(client *Client, c *restclient.Config, requestedGV *unversioned.GroupVersion, clientRegisteredGVs []unversioned.GroupVersion) (*unversioned.GroupVersion, error) { - var err error - if client == nil { - client, err = New(c) - if err != nil { - return nil, err - } - } - clientVersions := sets.String{} - for _, gv := range clientRegisteredGVs { - clientVersions.Insert(gv.String()) - } - groups, err := client.ServerGroups() - if err != nil { - // This is almost always a connection error, and higher level code should treat this as a generic error, - // not a negotiation specific error. - return nil, err - } - versions := unversioned.ExtractGroupVersions(groups) - serverVersions := sets.String{} - for _, v := range versions { - serverVersions.Insert(v) - } - - // If no version requested, use config version (may also be empty). - // make a copy of the original so we don't risk mutating input here or in the returned value - var preferredGV *unversioned.GroupVersion - switch { - case requestedGV != nil: - t := *requestedGV - preferredGV = &t - case c.GroupVersion != nil: - t := *c.GroupVersion - preferredGV = &t - } - - // If version explicitly requested verify that both client and server support it. - // If server does not support warn, but try to negotiate a lower version. - if preferredGV != nil { - if !clientVersions.Has(preferredGV.String()) { - return nil, fmt.Errorf("client does not support API version %q; client supported API versions: %v", preferredGV, clientVersions) - - } - // If the server supports no versions, then we should just use the preferredGV - // This can happen because discovery fails due to 403 Forbidden errors - if len(serverVersions) == 0 { - return preferredGV, nil - } - if serverVersions.Has(preferredGV.String()) { - return preferredGV, nil - } - // If we are using an explicit config version the server does not support, fail. - if (c.GroupVersion != nil) && (*preferredGV == *c.GroupVersion) { - return nil, fmt.Errorf("server does not support API version %q", preferredGV) - } - } - - for _, clientGV := range clientRegisteredGVs { - if serverVersions.Has(clientGV.String()) { - // Version was not explicitly requested in command config (--api-version). - // Ok to fall back to a supported version with a warning. - // TODO: caesarxuchao: enable the warning message when we have - // proper fix. Please refer to issue #14895. - // if len(version) != 0 { - // glog.Warningf("Server does not support API version '%s'. Falling back to '%s'.", version, clientVersion) - // } - t := clientGV - return &t, nil - } - } - return nil, fmt.Errorf("failed to negotiate an api version; server supports: %v, client supports: %v", - serverVersions, clientVersions) -} - -// NewOrDie creates a Kubernetes client and panics if the provided API version is not recognized. -func NewOrDie(c *restclient.Config) *Client { - client, err := New(c) - if err != nil { - panic(err) - } - return client -} - -// NewInCluster is a shortcut for calling InClusterConfig() and then New(). -func NewInCluster() (*Client, error) { - cc, err := restclient.InClusterConfig() - if err != nil { - return nil, err - } - return New(cc) -} - -// SetKubernetesDefaults sets default values on the provided client config for accessing the -// Kubernetes API or returns an error if any of the defaults are impossible or invalid. -// TODO: this method needs to be split into one that sets defaults per group, expected to be fix in PR "Refactoring clientcache.go and helper.go #14592" -func SetKubernetesDefaults(config *restclient.Config) error { - if config.APIPath == "" { - config.APIPath = legacyAPIPath - } - if config.GroupVersion == nil || config.GroupVersion.Group != api.GroupName { - g, err := registered.Group(api.GroupName) - if err != nil { - return err - } - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - if config.NegotiatedSerializer == nil { - config.NegotiatedSerializer = api.Codecs - } - return restclient.SetKubernetesDefaults(config) -} - -func setGroupDefaults(groupName string, config *restclient.Config) error { - config.APIPath = defaultAPIPath - if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() - } - if config.GroupVersion == nil || config.GroupVersion.Group != groupName { - g, err := registered.Group(groupName) - if err != nil { - return err - } - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - } - if config.NegotiatedSerializer == nil { - config.NegotiatedSerializer = api.Codecs - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/horizontalpodautoscaler.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/horizontalpodautoscaler.go deleted file mode 100644 index 76c6a9c..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/horizontalpodautoscaler.go +++ /dev/null @@ -1,103 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/autoscaling" - "k8s.io/kubernetes/pkg/watch" -) - -// HorizontalPodAutoscalersNamespacer has methods to work with HorizontalPodAutoscaler resources in a namespace -type HorizontalPodAutoscalersNamespacer interface { - HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface -} - -// HorizontalPodAutoscalerInterface has methods to work with HorizontalPodAutoscaler resources. -type HorizontalPodAutoscalerInterface interface { - List(opts api.ListOptions) (*autoscaling.HorizontalPodAutoscalerList, error) - Get(name string) (*autoscaling.HorizontalPodAutoscaler, error) - Delete(name string, options *api.DeleteOptions) error - Create(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (*autoscaling.HorizontalPodAutoscaler, error) - Update(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (*autoscaling.HorizontalPodAutoscaler, error) - UpdateStatus(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (*autoscaling.HorizontalPodAutoscaler, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// horizontalPodAutoscalers implements HorizontalPodAutoscalersNamespacer interface using AutoscalingClient internally -type horizontalPodAutoscalers struct { - client *AutoscalingClient - ns string -} - -// newHorizontalPodAutoscalers returns a horizontalPodAutoscalers -func newHorizontalPodAutoscalers(c *AutoscalingClient, namespace string) *horizontalPodAutoscalers { - return &horizontalPodAutoscalers{ - client: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of horizontalPodAutoscalers that match those selectors. -func (c *horizontalPodAutoscalers) List(opts api.ListOptions) (result *autoscaling.HorizontalPodAutoscalerList, err error) { - result = &autoscaling.HorizontalPodAutoscalerList{} - err = c.client.Get().Namespace(c.ns).Resource("horizontalPodAutoscalers").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the horizontalPodAutoscaler, and returns the corresponding HorizontalPodAutoscaler object, and an error if it occurs -func (c *horizontalPodAutoscalers) Get(name string) (result *autoscaling.HorizontalPodAutoscaler, err error) { - result = &autoscaling.HorizontalPodAutoscaler{} - err = c.client.Get().Namespace(c.ns).Resource("horizontalPodAutoscalers").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the horizontalPodAutoscaler and deletes it. Returns an error if one occurs. -func (c *horizontalPodAutoscalers) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Namespace(c.ns).Resource("horizontalPodAutoscalers").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a horizontalPodAutoscaler and creates it. Returns the server's representation of the horizontalPodAutoscaler, and an error, if it occurs. -func (c *horizontalPodAutoscalers) Create(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (result *autoscaling.HorizontalPodAutoscaler, err error) { - result = &autoscaling.HorizontalPodAutoscaler{} - err = c.client.Post().Namespace(c.ns).Resource("horizontalPodAutoscalers").Body(horizontalPodAutoscaler).Do().Into(result) - return -} - -// Update takes the representation of a horizontalPodAutoscaler and updates it. Returns the server's representation of the horizontalPodAutoscaler, and an error, if it occurs. -func (c *horizontalPodAutoscalers) Update(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (result *autoscaling.HorizontalPodAutoscaler, err error) { - result = &autoscaling.HorizontalPodAutoscaler{} - err = c.client.Put().Namespace(c.ns).Resource("horizontalPodAutoscalers").Name(horizontalPodAutoscaler.Name).Body(horizontalPodAutoscaler).Do().Into(result) - return -} - -// UpdateStatus takes the representation of a horizontalPodAutoscaler and updates it. Returns the server's representation of the horizontalPodAutoscaler, and an error, if it occurs. -func (c *horizontalPodAutoscalers) UpdateStatus(horizontalPodAutoscaler *autoscaling.HorizontalPodAutoscaler) (result *autoscaling.HorizontalPodAutoscaler, err error) { - result = &autoscaling.HorizontalPodAutoscaler{} - err = c.client.Put().Namespace(c.ns).Resource("horizontalPodAutoscalers").Name(horizontalPodAutoscaler.Name).SubResource("status").Body(horizontalPodAutoscaler).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested horizontalPodAutoscalers. -func (c *horizontalPodAutoscalers) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("horizontalPodAutoscalers"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/ingress.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/ingress.go deleted file mode 100644 index 59c6a6d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/ingress.go +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// IngressNamespacer has methods to work with Ingress resources in a namespace -type IngressNamespacer interface { - Ingress(namespace string) IngressInterface -} - -// IngressInterface exposes methods to work on Ingress resources. -type IngressInterface interface { - List(opts api.ListOptions) (*extensions.IngressList, error) - Get(name string) (*extensions.Ingress, error) - Create(ingress *extensions.Ingress) (*extensions.Ingress, error) - Update(ingress *extensions.Ingress) (*extensions.Ingress, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) - UpdateStatus(ingress *extensions.Ingress) (*extensions.Ingress, error) -} - -// ingress implements IngressNamespacer interface -type ingress struct { - r *ExtensionsClient - ns string -} - -// newIngress returns a ingress -func newIngress(c *ExtensionsClient, namespace string) *ingress { - return &ingress{c, namespace} -} - -// List returns a list of ingress that match the label and field selectors. -func (c *ingress) List(opts api.ListOptions) (result *extensions.IngressList, err error) { - result = &extensions.IngressList{} - err = c.r.Get().Namespace(c.ns).Resource("ingresses").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular ingress. -func (c *ingress) Get(name string) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} - err = c.r.Get().Namespace(c.ns).Resource("ingresses").Name(name).Do().Into(result) - return -} - -// Create creates a new ingress. -func (c *ingress) Create(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} - err = c.r.Post().Namespace(c.ns).Resource("ingresses").Body(ingress).Do().Into(result) - return -} - -// Update updates an existing ingress. -func (c *ingress) Update(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} - err = c.r.Put().Namespace(c.ns).Resource("ingresses").Name(ingress.Name).Body(ingress).Do().Into(result) - return -} - -// Delete deletes a ingress, returns error if one occurs. -func (c *ingress) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("ingresses").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested ingress. -func (c *ingress) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("ingresses"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the ingress and the new status. Returns the server's representation of the ingress, and an error, if it occurs. -func (c *ingress) UpdateStatus(ingress *extensions.Ingress) (result *extensions.Ingress, err error) { - result = &extensions.Ingress{} - err = c.r.Put().Namespace(c.ns).Resource("ingresses").Name(ingress.Name).SubResource("status").Body(ingress).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/jobs.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/jobs.go deleted file mode 100644 index 14cfa3a..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/jobs.go +++ /dev/null @@ -1,167 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/watch" -) - -// JobsNamespacer has methods to work with Job resources in a namespace -type JobsNamespacer interface { - Jobs(namespace string) JobInterface -} - -// JobInterface exposes methods to work on Job resources. -type JobInterface interface { - List(opts api.ListOptions) (*batch.JobList, error) - Get(name string) (*batch.Job, error) - Create(job *batch.Job) (*batch.Job, error) - Update(job *batch.Job) (*batch.Job, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) - UpdateStatus(job *batch.Job) (*batch.Job, error) -} - -// jobs implements JobsNamespacer interface -type jobs struct { - r *ExtensionsClient - ns string -} - -// newJobs returns a jobs -func newJobs(c *ExtensionsClient, namespace string) *jobs { - return &jobs{c, namespace} -} - -// Ensure statically that jobs implements JobInterface. -var _ JobInterface = &jobs{} - -// List returns a list of jobs that match the label and field selectors. -func (c *jobs) List(opts api.ListOptions) (result *batch.JobList, err error) { - result = &batch.JobList{} - err = c.r.Get().Namespace(c.ns).Resource("jobs").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular job. -func (c *jobs) Get(name string) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Get().Namespace(c.ns).Resource("jobs").Name(name).Do().Into(result) - return -} - -// Create creates a new job. -func (c *jobs) Create(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Post().Namespace(c.ns).Resource("jobs").Body(job).Do().Into(result) - return -} - -// Update updates an existing job. -func (c *jobs) Update(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Put().Namespace(c.ns).Resource("jobs").Name(job.Name).Body(job).Do().Into(result) - return -} - -// Delete deletes a job, returns error if one occurs. -func (c *jobs) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("jobs").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested jobs. -func (c *jobs) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("jobs"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the job and the new status. Returns the server's representation of the job, and an error, if it occurs. -func (c *jobs) UpdateStatus(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Put().Namespace(c.ns).Resource("jobs").Name(job.Name).SubResource("status").Body(job).Do().Into(result) - return -} - -// jobsV1 implements JobsNamespacer interface using BatchClient internally -type jobsV1 struct { - r *BatchClient - ns string -} - -// newJobsV1 returns a jobsV1 -func newJobsV1(c *BatchClient, namespace string) *jobsV1 { - return &jobsV1{c, namespace} -} - -// Ensure statically that jobsV1 implements JobInterface. -var _ JobInterface = &jobsV1{} - -// List returns a list of jobs that match the label and field selectors. -func (c *jobsV1) List(opts api.ListOptions) (result *batch.JobList, err error) { - result = &batch.JobList{} - err = c.r.Get().Namespace(c.ns).Resource("jobs").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular job. -func (c *jobsV1) Get(name string) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Get().Namespace(c.ns).Resource("jobs").Name(name).Do().Into(result) - return -} - -// Create creates a new job. -func (c *jobsV1) Create(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Post().Namespace(c.ns).Resource("jobs").Body(job).Do().Into(result) - return -} - -// Update updates an existing job. -func (c *jobsV1) Update(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Put().Namespace(c.ns).Resource("jobs").Name(job.Name).Body(job).Do().Into(result) - return -} - -// Delete deletes a job, returns error if one occurs. -func (c *jobsV1) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("jobs").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested jobs. -func (c *jobsV1) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("jobs"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the job and the new status. Returns the server's representation of the job, and an error, if it occurs. -func (c *jobsV1) UpdateStatus(job *batch.Job) (result *batch.Job, err error) { - result = &batch.Job{} - err = c.r.Put().Namespace(c.ns).Resource("jobs").Name(job.Name).SubResource("status").Body(job).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/limit_ranges.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/limit_ranges.go deleted file mode 100644 index 914a049..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/limit_ranges.go +++ /dev/null @@ -1,94 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// LimitRangesNamespacer has methods to work with LimitRange resources in a namespace -type LimitRangesNamespacer interface { - LimitRanges(namespace string) LimitRangeInterface -} - -// LimitRangeInterface has methods to work with LimitRange resources. -type LimitRangeInterface interface { - List(opts api.ListOptions) (*api.LimitRangeList, error) - Get(name string) (*api.LimitRange, error) - Delete(name string) error - Create(limitRange *api.LimitRange) (*api.LimitRange, error) - Update(limitRange *api.LimitRange) (*api.LimitRange, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// limitRanges implements LimitRangesNamespacer interface -type limitRanges struct { - r *Client - ns string -} - -// newLimitRanges returns a limitRanges -func newLimitRanges(c *Client, namespace string) *limitRanges { - return &limitRanges{ - r: c, - ns: namespace, - } -} - -// List takes a selector, and returns the list of limitRanges that match that selector. -func (c *limitRanges) List(opts api.ListOptions) (result *api.LimitRangeList, err error) { - result = &api.LimitRangeList{} - err = c.r.Get().Namespace(c.ns).Resource("limitRanges").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the limitRange, and returns the corresponding Pod object, and an error if it occurs -func (c *limitRanges) Get(name string) (result *api.LimitRange, err error) { - result = &api.LimitRange{} - err = c.r.Get().Namespace(c.ns).Resource("limitRanges").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the limitRange, and returns an error if one occurs -func (c *limitRanges) Delete(name string) error { - return c.r.Delete().Namespace(c.ns).Resource("limitRanges").Name(name).Do().Error() -} - -// Create takes the representation of a limitRange. Returns the server's representation of the limitRange, and an error, if it occurs. -func (c *limitRanges) Create(limitRange *api.LimitRange) (result *api.LimitRange, err error) { - result = &api.LimitRange{} - err = c.r.Post().Namespace(c.ns).Resource("limitRanges").Body(limitRange).Do().Into(result) - return -} - -// Update takes the representation of a limitRange to update. Returns the server's representation of the limitRange, and an error, if it occurs. -func (c *limitRanges) Update(limitRange *api.LimitRange) (result *api.LimitRange, err error) { - result = &api.LimitRange{} - err = c.r.Put().Namespace(c.ns).Resource("limitRanges").Name(limitRange.Name).Body(limitRange).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested resource -func (c *limitRanges) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("limitRanges"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/namespaces.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/namespaces.go deleted file mode 100644 index b4a3836..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/namespaces.go +++ /dev/null @@ -1,116 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "fmt" - - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -type NamespacesInterface interface { - Namespaces() NamespaceInterface -} - -type NamespaceInterface interface { - Create(item *api.Namespace) (*api.Namespace, error) - Get(name string) (result *api.Namespace, err error) - List(opts api.ListOptions) (*api.NamespaceList, error) - Delete(name string) error - Update(item *api.Namespace) (*api.Namespace, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Finalize(item *api.Namespace) (*api.Namespace, error) - Status(item *api.Namespace) (*api.Namespace, error) -} - -// namespaces implements NamespacesInterface -type namespaces struct { - r *Client -} - -// newNamespaces returns a namespaces object. -func newNamespaces(c *Client) *namespaces { - return &namespaces{r: c} -} - -// Create creates a new namespace. -func (c *namespaces) Create(namespace *api.Namespace) (*api.Namespace, error) { - result := &api.Namespace{} - err := c.r.Post().Resource("namespaces").Body(namespace).Do().Into(result) - return result, err -} - -// List lists all the namespaces in the cluster. -func (c *namespaces) List(opts api.ListOptions) (*api.NamespaceList, error) { - result := &api.NamespaceList{} - err := c.r.Get(). - Resource("namespaces"). - VersionedParams(&opts, api.ParameterCodec). - Do().Into(result) - return result, err -} - -// Update takes the representation of a namespace to update. Returns the server's representation of the namespace, and an error, if it occurs. -func (c *namespaces) Update(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} - err = c.r.Put().Resource("namespaces").Name(namespace.Name).Body(namespace).Do().Into(result) - return -} - -// Finalize takes the representation of a namespace to update. Returns the server's representation of the namespace, and an error, if it occurs. -func (c *namespaces) Finalize(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} - if len(namespace.ResourceVersion) == 0 { - err = fmt.Errorf("invalid update object, missing resource version: %v", namespace) - return - } - err = c.r.Put().Resource("namespaces").Name(namespace.Name).SubResource("finalize").Body(namespace).Do().Into(result) - return -} - -// Status takes the representation of a namespace to update. Returns the server's representation of the namespace, and an error, if it occurs. -func (c *namespaces) Status(namespace *api.Namespace) (result *api.Namespace, err error) { - result = &api.Namespace{} - if len(namespace.ResourceVersion) == 0 { - err = fmt.Errorf("invalid update object, missing resource version: %v", namespace) - return - } - err = c.r.Put().Resource("namespaces").Name(namespace.Name).SubResource("status").Body(namespace).Do().Into(result) - return -} - -// Get gets an existing namespace -func (c *namespaces) Get(name string) (*api.Namespace, error) { - result := &api.Namespace{} - err := c.r.Get().Resource("namespaces").Name(name).Do().Into(result) - return result, err -} - -// Delete deletes an existing namespace. -func (c *namespaces) Delete(name string) error { - return c.r.Delete().Resource("namespaces").Name(name).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested namespaces. -func (c *namespaces) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Resource("namespaces"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/network_policys.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/network_policys.go deleted file mode 100644 index 3e3f610..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/network_policys.go +++ /dev/null @@ -1,92 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// NetworkPolicyNamespacer has methods to work with NetworkPolicy resources in a namespace -type NetworkPolicyNamespacer interface { - NetworkPolicies(namespace string) NetworkPolicyInterface -} - -// NetworkPolicyInterface exposes methods to work on NetworkPolicy resources. -type NetworkPolicyInterface interface { - List(opts api.ListOptions) (*extensions.NetworkPolicyList, error) - Get(name string) (*extensions.NetworkPolicy, error) - Create(networkPolicy *extensions.NetworkPolicy) (*extensions.NetworkPolicy, error) - Update(networkPolicy *extensions.NetworkPolicy) (*extensions.NetworkPolicy, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// NetworkPolicies implements NetworkPolicyNamespacer interface -type NetworkPolicies struct { - r *ExtensionsClient - ns string -} - -// newNetworkPolicies returns a NetworkPolicies -func newNetworkPolicies(c *ExtensionsClient, namespace string) *NetworkPolicies { - return &NetworkPolicies{c, namespace} -} - -// List returns a list of networkPolicy that match the label and field selectors. -func (c *NetworkPolicies) List(opts api.ListOptions) (result *extensions.NetworkPolicyList, err error) { - result = &extensions.NetworkPolicyList{} - err = c.r.Get().Namespace(c.ns).Resource("networkpolicies").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular networkPolicy. -func (c *NetworkPolicies) Get(name string) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.r.Get().Namespace(c.ns).Resource("networkpolicies").Name(name).Do().Into(result) - return -} - -// Create creates a new networkPolicy. -func (c *NetworkPolicies) Create(networkPolicy *extensions.NetworkPolicy) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.r.Post().Namespace(c.ns).Resource("networkpolicies").Body(networkPolicy).Do().Into(result) - return -} - -// Update updates an existing networkPolicy. -func (c *NetworkPolicies) Update(networkPolicy *extensions.NetworkPolicy) (result *extensions.NetworkPolicy, err error) { - result = &extensions.NetworkPolicy{} - err = c.r.Put().Namespace(c.ns).Resource("networkpolicies").Name(networkPolicy.Name).Body(networkPolicy).Do().Into(result) - return -} - -// Delete deletes a networkPolicy, returns error if one occurs. -func (c *NetworkPolicies) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("networkpolicies").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested networkPolicy. -func (c *NetworkPolicies) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("networkpolicies"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/nodes.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/nodes.go deleted file mode 100644 index 15a7db2..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/nodes.go +++ /dev/null @@ -1,111 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -type NodesInterface interface { - Nodes() NodeInterface -} - -type NodeInterface interface { - Get(name string) (result *api.Node, err error) - Create(node *api.Node) (*api.Node, error) - List(opts api.ListOptions) (*api.NodeList, error) - Delete(name string) error - DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error - Update(*api.Node) (*api.Node, error) - UpdateStatus(*api.Node) (*api.Node, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// nodes implements NodesInterface -type nodes struct { - r *Client -} - -// newNodes returns a nodes object. -func newNodes(c *Client) *nodes { - return &nodes{c} -} - -// resourceName returns node's URL resource name. -func (c *nodes) resourceName() string { - return "nodes" -} - -// Create creates a new node. -func (c *nodes) Create(node *api.Node) (*api.Node, error) { - result := &api.Node{} - err := c.r.Post().Resource(c.resourceName()).Body(node).Do().Into(result) - return result, err -} - -// List takes a selector, and returns the list of nodes that match that selector in the cluster. -func (c *nodes) List(opts api.ListOptions) (*api.NodeList, error) { - result := &api.NodeList{} - err := c.r.Get().Resource(c.resourceName()).VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return result, err -} - -// Get gets an existing node. -func (c *nodes) Get(name string) (*api.Node, error) { - result := &api.Node{} - err := c.r.Get().Resource(c.resourceName()).Name(name).Do().Into(result) - return result, err -} - -// Delete deletes an existing node. -func (c *nodes) Delete(name string) error { - return c.r.Delete().Resource(c.resourceName()).Name(name).Do().Error() -} - -// DeleteCollection deletes a collection of nodes. -func (c *nodes) DeleteCollection(options *api.DeleteOptions, listOptions api.ListOptions) error { - return c.r.Delete(). - Resource(c.resourceName()). - VersionedParams(&listOptions, api.ParameterCodec). - Body(options). - Do(). - Error() -} - -// Update updates an existing node. -func (c *nodes) Update(node *api.Node) (*api.Node, error) { - result := &api.Node{} - err := c.r.Put().Resource(c.resourceName()).Name(node.Name).Body(node).Do().Into(result) - return result, err -} - -func (c *nodes) UpdateStatus(node *api.Node) (*api.Node, error) { - result := &api.Node{} - err := c.r.Put().Resource(c.resourceName()).Name(node.Name).SubResource("status").Body(node).Do().Into(result) - return result, err -} - -// Watch returns a watch.Interface that watches the requested nodes. -func (c *nodes) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(api.NamespaceAll). - Resource(c.resourceName()). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumeclaim.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumeclaim.go deleted file mode 100644 index 4ea3a95..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumeclaim.go +++ /dev/null @@ -1,99 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// PersistentVolumeClaimsNamespacer has methods to work with PersistentVolumeClaim resources in a namespace -type PersistentVolumeClaimsNamespacer interface { - PersistentVolumeClaims(namespace string) PersistentVolumeClaimInterface -} - -// PersistentVolumeClaimInterface has methods to work with PersistentVolumeClaim resources. -type PersistentVolumeClaimInterface interface { - List(opts api.ListOptions) (*api.PersistentVolumeClaimList, error) - Get(name string) (*api.PersistentVolumeClaim, error) - Create(claim *api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - Update(claim *api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - UpdateStatus(claim *api.PersistentVolumeClaim) (*api.PersistentVolumeClaim, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// persistentVolumeClaims implements PersistentVolumeClaimsNamespacer interface -type persistentVolumeClaims struct { - client *Client - namespace string -} - -// newPersistentVolumeClaims returns a PodsClient -func newPersistentVolumeClaims(c *Client, namespace string) *persistentVolumeClaims { - return &persistentVolumeClaims{c, namespace} -} - -func (c *persistentVolumeClaims) List(opts api.ListOptions) (result *api.PersistentVolumeClaimList, err error) { - result = &api.PersistentVolumeClaimList{} - - err = c.client.Get(). - Namespace(c.namespace). - Resource("persistentVolumeClaims"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -func (c *persistentVolumeClaims) Get(name string) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} - err = c.client.Get().Namespace(c.namespace).Resource("persistentVolumeClaims").Name(name).Do().Into(result) - return -} - -func (c *persistentVolumeClaims) Create(claim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} - err = c.client.Post().Namespace(c.namespace).Resource("persistentVolumeClaims").Body(claim).Do().Into(result) - return -} - -func (c *persistentVolumeClaims) Update(claim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} - err = c.client.Put().Namespace(c.namespace).Resource("persistentVolumeClaims").Name(claim.Name).Body(claim).Do().Into(result) - return -} - -func (c *persistentVolumeClaims) UpdateStatus(claim *api.PersistentVolumeClaim) (result *api.PersistentVolumeClaim, err error) { - result = &api.PersistentVolumeClaim{} - err = c.client.Put().Namespace(c.namespace).Resource("persistentVolumeClaims").Name(claim.Name).SubResource("status").Body(claim).Do().Into(result) - return -} - -func (c *persistentVolumeClaims) Delete(name string) error { - return c.client.Delete().Namespace(c.namespace).Resource("persistentVolumeClaims").Name(name).Do().Error() -} - -func (c *persistentVolumeClaims) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.namespace). - Resource("persistentVolumeClaims"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumes.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumes.go deleted file mode 100644 index 5fce1f0..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/persistentvolumes.go +++ /dev/null @@ -1,93 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -type PersistentVolumesInterface interface { - PersistentVolumes() PersistentVolumeInterface -} - -// PersistentVolumeInterface has methods to work with PersistentVolume resources. -type PersistentVolumeInterface interface { - List(opts api.ListOptions) (*api.PersistentVolumeList, error) - Get(name string) (*api.PersistentVolume, error) - Create(volume *api.PersistentVolume) (*api.PersistentVolume, error) - Update(volume *api.PersistentVolume) (*api.PersistentVolume, error) - UpdateStatus(persistentVolume *api.PersistentVolume) (*api.PersistentVolume, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// persistentVolumes implements PersistentVolumesInterface -type persistentVolumes struct { - client *Client -} - -func newPersistentVolumes(c *Client) *persistentVolumes { - return &persistentVolumes{c} -} - -func (c *persistentVolumes) List(opts api.ListOptions) (result *api.PersistentVolumeList, err error) { - result = &api.PersistentVolumeList{} - err = c.client.Get(). - Resource("persistentVolumes"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -func (c *persistentVolumes) Get(name string) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} - err = c.client.Get().Resource("persistentVolumes").Name(name).Do().Into(result) - return -} - -func (c *persistentVolumes) Create(volume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} - err = c.client.Post().Resource("persistentVolumes").Body(volume).Do().Into(result) - return -} - -func (c *persistentVolumes) Update(volume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} - err = c.client.Put().Resource("persistentVolumes").Name(volume.Name).Body(volume).Do().Into(result) - return -} - -func (c *persistentVolumes) UpdateStatus(volume *api.PersistentVolume) (result *api.PersistentVolume, err error) { - result = &api.PersistentVolume{} - err = c.client.Put().Resource("persistentVolumes").Name(volume.Name).SubResource("status").Body(volume).Do().Into(result) - return -} - -func (c *persistentVolumes) Delete(name string) error { - return c.client.Delete().Resource("persistentVolumes").Name(name).Do().Error() -} - -func (c *persistentVolumes) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Resource("persistentVolumes"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pet_sets.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/pet_sets.go deleted file mode 100644 index 954efcd..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pet_sets.go +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/apps" - "k8s.io/kubernetes/pkg/watch" -) - -// PetSetNamespacer has methods to work with PetSet resources in a namespace -type PetSetNamespacer interface { - PetSets(namespace string) PetSetInterface -} - -// PetSetInterface exposes methods to work on PetSet resources. -type PetSetInterface interface { - List(opts api.ListOptions) (*apps.PetSetList, error) - Get(name string) (*apps.PetSet, error) - Create(petSet *apps.PetSet) (*apps.PetSet, error) - Update(petSet *apps.PetSet) (*apps.PetSet, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) - UpdateStatus(petSet *apps.PetSet) (*apps.PetSet, error) -} - -// petSet implements PetSetNamespacer interface -type petSet struct { - r *AppsClient - ns string -} - -// newPetSet returns a petSet -func newPetSet(c *AppsClient, namespace string) *petSet { - return &petSet{c, namespace} -} - -// List returns a list of petSet that match the label and field selectors. -func (c *petSet) List(opts api.ListOptions) (result *apps.PetSetList, err error) { - result = &apps.PetSetList{} - err = c.r.Get().Namespace(c.ns).Resource("petsets").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular petSet. -func (c *petSet) Get(name string) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.r.Get().Namespace(c.ns).Resource("petsets").Name(name).Do().Into(result) - return -} - -// Create creates a new petSet. -func (c *petSet) Create(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.r.Post().Namespace(c.ns).Resource("petsets").Body(petSet).Do().Into(result) - return -} - -// Update updates an existing petSet. -func (c *petSet) Update(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.r.Put().Namespace(c.ns).Resource("petsets").Name(petSet.Name).Body(petSet).Do().Into(result) - return -} - -// Delete deletes a petSet, returns error if one occurs. -func (c *petSet) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("petsets").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested petSet. -func (c *petSet) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("petsets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the petSet and the new status. Returns the server's representation of the petSet, and an error, if it occurs. -func (c *petSet) UpdateStatus(petSet *apps.PetSet) (result *apps.PetSet, err error) { - result = &apps.PetSet{} - err = c.r.Put().Namespace(c.ns).Resource("petsets").Name(petSet.Name).SubResource("status").Body(petSet).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_disruption_budgets.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_disruption_budgets.go deleted file mode 100644 index 0239623..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_disruption_budgets.go +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/policy" - "k8s.io/kubernetes/pkg/watch" -) - -// PodDisruptionBudgetNamespacer has methods to work with PodDisruptionBudget resources in a namespace -type PodDisruptionBudgetNamespacer interface { - PodDisruptionBudgets(namespace string) PodDisruptionBudgetInterface -} - -// PodDisruptionBudgetInterface exposes methods to work on PodDisruptionBudget resources. -type PodDisruptionBudgetInterface interface { - List(opts api.ListOptions) (*policy.PodDisruptionBudgetList, error) - Get(name string) (*policy.PodDisruptionBudget, error) - Create(podDisruptionBudget *policy.PodDisruptionBudget) (*policy.PodDisruptionBudget, error) - Update(podDisruptionBudget *policy.PodDisruptionBudget) (*policy.PodDisruptionBudget, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) - UpdateStatus(podDisruptionBudget *policy.PodDisruptionBudget) (*policy.PodDisruptionBudget, error) -} - -// podDisruptionBudget implements PodDisruptionBudgetNamespacer interface -type podDisruptionBudget struct { - r *PolicyClient - ns string -} - -// newPodDisruptionBudget returns a podDisruptionBudget -func newPodDisruptionBudget(c *PolicyClient, namespace string) *podDisruptionBudget { - return &podDisruptionBudget{c, namespace} -} - -// List returns a list of podDisruptionBudget that match the label and field selectors. -func (c *podDisruptionBudget) List(opts api.ListOptions) (result *policy.PodDisruptionBudgetList, err error) { - result = &policy.PodDisruptionBudgetList{} - err = c.r.Get().Namespace(c.ns).Resource("poddisruptionbudgets").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular podDisruptionBudget. -func (c *podDisruptionBudget) Get(name string) (result *policy.PodDisruptionBudget, err error) { - result = &policy.PodDisruptionBudget{} - err = c.r.Get().Namespace(c.ns).Resource("poddisruptionbudgets").Name(name).Do().Into(result) - return -} - -// Create creates a new podDisruptionBudget. -func (c *podDisruptionBudget) Create(podDisruptionBudget *policy.PodDisruptionBudget) (result *policy.PodDisruptionBudget, err error) { - result = &policy.PodDisruptionBudget{} - err = c.r.Post().Namespace(c.ns).Resource("poddisruptionbudgets").Body(podDisruptionBudget).Do().Into(result) - return -} - -// Update updates an existing podDisruptionBudget. -func (c *podDisruptionBudget) Update(podDisruptionBudget *policy.PodDisruptionBudget) (result *policy.PodDisruptionBudget, err error) { - result = &policy.PodDisruptionBudget{} - err = c.r.Put().Namespace(c.ns).Resource("poddisruptionbudgets").Name(podDisruptionBudget.Name).Body(podDisruptionBudget).Do().Into(result) - return -} - -// Delete deletes a podDisruptionBudget, returns error if one occurs. -func (c *podDisruptionBudget) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("poddisruptionbudgets").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested podDisruptionBudget. -func (c *podDisruptionBudget) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("poddisruptionbudgets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the podDisruptionBudget and the new status. Returns the server's representation of the podDisruptionBudget, and an error, if it occurs. -func (c *podDisruptionBudget) UpdateStatus(podDisruptionBudget *policy.PodDisruptionBudget) (result *policy.PodDisruptionBudget, err error) { - result = &policy.PodDisruptionBudget{} - err = c.r.Put().Namespace(c.ns).Resource("poddisruptionbudgets").Name(podDisruptionBudget.Name).SubResource("status").Body(podDisruptionBudget).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_templates.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_templates.go deleted file mode 100644 index 7627d73..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pod_templates.go +++ /dev/null @@ -1,94 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// PodTemplatesNamespacer has methods to work with PodTemplate resources in a namespace -type PodTemplatesNamespacer interface { - PodTemplates(namespace string) PodTemplateInterface -} - -// PodTemplateInterface has methods to work with PodTemplate resources. -type PodTemplateInterface interface { - List(opts api.ListOptions) (*api.PodTemplateList, error) - Get(name string) (*api.PodTemplate, error) - Delete(name string, options *api.DeleteOptions) error - Create(podTemplate *api.PodTemplate) (*api.PodTemplate, error) - Update(podTemplate *api.PodTemplate) (*api.PodTemplate, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// podTemplates implements PodTemplatesNamespacer interface -type podTemplates struct { - r *Client - ns string -} - -// newPodTemplates returns a podTemplates -func newPodTemplates(c *Client, namespace string) *podTemplates { - return &podTemplates{ - r: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of podTemplates that match those selectors. -func (c *podTemplates) List(opts api.ListOptions) (result *api.PodTemplateList, err error) { - result = &api.PodTemplateList{} - err = c.r.Get().Namespace(c.ns).Resource("podTemplates").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the podTemplate, and returns the corresponding PodTemplate object, and an error if it occurs -func (c *podTemplates) Get(name string) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} - err = c.r.Get().Namespace(c.ns).Resource("podTemplates").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the podTemplate, and returns an error if one occurs -func (c *podTemplates) Delete(name string, options *api.DeleteOptions) error { - return c.r.Delete().Namespace(c.ns).Resource("podTemplates").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a podTemplate. Returns the server's representation of the podTemplate, and an error, if it occurs. -func (c *podTemplates) Create(podTemplate *api.PodTemplate) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} - err = c.r.Post().Namespace(c.ns).Resource("podTemplates").Body(podTemplate).Do().Into(result) - return -} - -// Update takes the representation of a podTemplate to update. Returns the server's representation of the podTemplate, and an error, if it occurs. -func (c *podTemplates) Update(podTemplate *api.PodTemplate) (result *api.PodTemplate, err error) { - result = &api.PodTemplate{} - err = c.r.Put().Namespace(c.ns).Resource("podTemplates").Name(podTemplate.Name).Body(podTemplate).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested podTemplates. -func (c *podTemplates) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("podTemplates"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pods.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/pods.go deleted file mode 100644 index ea16fb8..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/pods.go +++ /dev/null @@ -1,115 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/watch" -) - -// PodsNamespacer has methods to work with Pod resources in a namespace -type PodsNamespacer interface { - Pods(namespace string) PodInterface -} - -// PodInterface has methods to work with Pod resources. -type PodInterface interface { - List(opts api.ListOptions) (*api.PodList, error) - Get(name string) (*api.Pod, error) - Delete(name string, options *api.DeleteOptions) error - Create(pod *api.Pod) (*api.Pod, error) - Update(pod *api.Pod) (*api.Pod, error) - Watch(opts api.ListOptions) (watch.Interface, error) - Bind(binding *api.Binding) error - UpdateStatus(pod *api.Pod) (*api.Pod, error) - GetLogs(name string, opts *api.PodLogOptions) *restclient.Request -} - -// pods implements PodsNamespacer interface -type pods struct { - r *Client - ns string -} - -// newPods returns a pods -func newPods(c *Client, namespace string) *pods { - return &pods{ - r: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of pods that match those selectors. -func (c *pods) List(opts api.ListOptions) (result *api.PodList, err error) { - result = &api.PodList{} - err = c.r.Get().Namespace(c.ns).Resource("pods").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the pod, and returns the corresponding Pod object, and an error if it occurs -func (c *pods) Get(name string) (result *api.Pod, err error) { - result = &api.Pod{} - err = c.r.Get().Namespace(c.ns).Resource("pods").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the pod, and returns an error if one occurs -func (c *pods) Delete(name string, options *api.DeleteOptions) error { - return c.r.Delete().Namespace(c.ns).Resource("pods").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a pod. Returns the server's representation of the pod, and an error, if it occurs. -func (c *pods) Create(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} - err = c.r.Post().Namespace(c.ns).Resource("pods").Body(pod).Do().Into(result) - return -} - -// Update takes the representation of a pod to update. Returns the server's representation of the pod, and an error, if it occurs. -func (c *pods) Update(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} - err = c.r.Put().Namespace(c.ns).Resource("pods").Name(pod.Name).Body(pod).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested pods. -func (c *pods) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("pods"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// Bind applies the provided binding to the named pod in the current namespace (binding.Namespace is ignored). -func (c *pods) Bind(binding *api.Binding) error { - return c.r.Post().Namespace(c.ns).Resource("pods").Name(binding.Name).SubResource("binding").Body(binding).Do().Error() -} - -// UpdateStatus takes the name of the pod and the new status. Returns the server's representation of the pod, and an error, if it occurs. -func (c *pods) UpdateStatus(pod *api.Pod) (result *api.Pod, err error) { - result = &api.Pod{} - err = c.r.Put().Namespace(c.ns).Resource("pods").Name(pod.Name).SubResource("status").Body(pod).Do().Into(result) - return -} - -// Get constructs a request for getting the logs for a pod -func (c *pods) GetLogs(name string, opts *api.PodLogOptions) *restclient.Request { - return c.r.Get().Namespace(c.ns).Name(name).Resource("pods").SubResource("log").VersionedParams(opts, api.ParameterCodec) -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/podsecuritypolicy.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/podsecuritypolicy.go deleted file mode 100644 index f03e643..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/podsecuritypolicy.go +++ /dev/null @@ -1,111 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -type PodSecurityPoliciesInterface interface { - PodSecurityPolicies() PodSecurityPolicyInterface -} - -type PodSecurityPolicyInterface interface { - Get(name string) (result *extensions.PodSecurityPolicy, err error) - Create(psp *extensions.PodSecurityPolicy) (*extensions.PodSecurityPolicy, error) - List(opts api.ListOptions) (*extensions.PodSecurityPolicyList, error) - Delete(name string) error - Update(*extensions.PodSecurityPolicy) (*extensions.PodSecurityPolicy, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// podSecurityPolicy implements PodSecurityPolicyInterface -type podSecurityPolicy struct { - client *ExtensionsClient -} - -// newPodSecurityPolicy returns a podSecurityPolicy object. -func newPodSecurityPolicy(c *ExtensionsClient) *podSecurityPolicy { - return &podSecurityPolicy{c} -} - -func (s *podSecurityPolicy) Create(psp *extensions.PodSecurityPolicy) (*extensions.PodSecurityPolicy, error) { - result := &extensions.PodSecurityPolicy{} - err := s.client.Post(). - Resource("podsecuritypolicies"). - Body(psp). - Do(). - Into(result) - - return result, err -} - -// List returns a list of PodSecurityPolicies matching the selectors. -func (s *podSecurityPolicy) List(opts api.ListOptions) (*extensions.PodSecurityPolicyList, error) { - result := &extensions.PodSecurityPolicyList{} - - err := s.client.Get(). - Resource("podsecuritypolicies"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -// Get returns the given PodSecurityPolicy, or an error. -func (s *podSecurityPolicy) Get(name string) (*extensions.PodSecurityPolicy, error) { - result := &extensions.PodSecurityPolicy{} - err := s.client.Get(). - Resource("podsecuritypolicies"). - Name(name). - Do(). - Into(result) - - return result, err -} - -// Watch starts watching for PodSecurityPolicies matching the given selectors. -func (s *podSecurityPolicy) Watch(opts api.ListOptions) (watch.Interface, error) { - return s.client.Get(). - Prefix("watch"). - Resource("podsecuritypolicies"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -func (s *podSecurityPolicy) Delete(name string) error { - return s.client.Delete(). - Resource("podsecuritypolicies"). - Name(name). - Do(). - Error() -} - -func (s *podSecurityPolicy) Update(psp *extensions.PodSecurityPolicy) (result *extensions.PodSecurityPolicy, err error) { - result = &extensions.PodSecurityPolicy{} - err = s.client.Put(). - Resource("podsecuritypolicies"). - Name(psp.Name). - Body(psp). - Do(). - Into(result) - - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/policy.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/policy.go deleted file mode 100644 index e602795..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/policy.go +++ /dev/null @@ -1,55 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/policy" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type PolicyInterface interface { - PodDisruptionBudgetNamespacer -} - -// PolicyClient is used to interact with Kubernetes batch features. -type PolicyClient struct { - *restclient.RESTClient -} - -func (c *PolicyClient) PodDisruptionBudgets(namespace string) PodDisruptionBudgetInterface { - return newPodDisruptionBudget(c, namespace) -} - -func NewPolicy(c *restclient.Config) (*PolicyClient, error) { - config := *c - if err := setGroupDefaults(policy.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &PolicyClient{client}, nil -} - -func NewPolicyOrDie(c *restclient.Config) *PolicyClient { - client, err := NewPolicy(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/rbac.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/rbac.go deleted file mode 100644 index c95887d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/rbac.go +++ /dev/null @@ -1,73 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/client/restclient" -) - -// Interface holds the methods for clients of Kubernetes to allow mock testing. -type RbacInterface interface { - RoleBindingsNamespacer - RolesNamespacer - ClusterRoleBindings - ClusterRoles -} - -type RbacClient struct { - *restclient.RESTClient -} - -func (c *RbacClient) RoleBindings(namespace string) RoleBindingInterface { - return newRoleBindings(c, namespace) -} - -func (c *RbacClient) Roles(namespace string) RoleInterface { - return newRoles(c, namespace) -} - -func (c *RbacClient) ClusterRoleBindings() ClusterRoleBindingInterface { - return newClusterRoleBindings(c) -} - -func (c *RbacClient) ClusterRoles() ClusterRoleInterface { - return newClusterRoles(c) -} - -// NewRbac creates a new RbacClient for the given config. -func NewRbac(c *restclient.Config) (*RbacClient, error) { - config := *c - if err := setGroupDefaults(rbac.GroupName, &config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &RbacClient{client}, nil -} - -// NewRbacOrDie creates a new RbacClient for the given config and -// panics if there is an error in the config. -func NewRbacOrDie(c *restclient.Config) *RbacClient { - client, err := NewRbac(c) - if err != nil { - panic(err) - } - return client -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/replica_sets.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/replica_sets.go deleted file mode 100644 index 191a006..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/replica_sets.go +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// ReplicaSetsNamespacer has methods to work with ReplicaSet resources in a namespace -type ReplicaSetsNamespacer interface { - ReplicaSets(namespace string) ReplicaSetInterface -} - -// ReplicaSetInterface has methods to work with ReplicaSet resources. -type ReplicaSetInterface interface { - List(opts api.ListOptions) (*extensions.ReplicaSetList, error) - Get(name string) (*extensions.ReplicaSet, error) - Create(ctrl *extensions.ReplicaSet) (*extensions.ReplicaSet, error) - Update(ctrl *extensions.ReplicaSet) (*extensions.ReplicaSet, error) - UpdateStatus(ctrl *extensions.ReplicaSet) (*extensions.ReplicaSet, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// replicaSets implements ReplicaSetsNamespacer interface -type replicaSets struct { - client *ExtensionsClient - ns string -} - -// newReplicaSets returns a ReplicaSetClient -func newReplicaSets(c *ExtensionsClient, namespace string) *replicaSets { - return &replicaSets{c, namespace} -} - -// List takes a selector, and returns the list of ReplicaSets that match that selector. -func (c *replicaSets) List(opts api.ListOptions) (result *extensions.ReplicaSetList, err error) { - result = &extensions.ReplicaSetList{} - err = c.client.Get().Namespace(c.ns).Resource("replicasets").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular ReplicaSet. -func (c *replicaSets) Get(name string) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} - err = c.client.Get().Namespace(c.ns).Resource("replicasets").Name(name).Do().Into(result) - return -} - -// Create creates a new ReplicaSet. -func (c *replicaSets) Create(rs *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} - err = c.client.Post().Namespace(c.ns).Resource("replicasets").Body(rs).Do().Into(result) - return -} - -// Update updates an existing ReplicaSet. -func (c *replicaSets) Update(rs *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} - err = c.client.Put().Namespace(c.ns).Resource("replicasets").Name(rs.Name).Body(rs).Do().Into(result) - return -} - -// UpdateStatus updates an existing ReplicaSet status -func (c *replicaSets) UpdateStatus(rs *extensions.ReplicaSet) (result *extensions.ReplicaSet, err error) { - result = &extensions.ReplicaSet{} - err = c.client.Put().Namespace(c.ns).Resource("replicasets").Name(rs.Name).SubResource("status").Body(rs).Do().Into(result) - return -} - -// Delete deletes an existing ReplicaSet. -func (c *replicaSets) Delete(name string, options *api.DeleteOptions) (err error) { - return c.client.Delete().Namespace(c.ns).Resource("replicasets").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested ReplicaSets. -func (c *replicaSets) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("replicasets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/replication_controllers.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/replication_controllers.go deleted file mode 100644 index 5c3b2c3..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/replication_controllers.go +++ /dev/null @@ -1,99 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// ReplicationControllersNamespacer has methods to work with ReplicationController resources in a namespace -type ReplicationControllersNamespacer interface { - ReplicationControllers(namespace string) ReplicationControllerInterface -} - -// ReplicationControllerInterface has methods to work with ReplicationController resources. -type ReplicationControllerInterface interface { - List(opts api.ListOptions) (*api.ReplicationControllerList, error) - Get(name string) (*api.ReplicationController, error) - Create(ctrl *api.ReplicationController) (*api.ReplicationController, error) - Update(ctrl *api.ReplicationController) (*api.ReplicationController, error) - UpdateStatus(ctrl *api.ReplicationController) (*api.ReplicationController, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// replicationControllers implements ReplicationControllersNamespacer interface -type replicationControllers struct { - r *Client - ns string -} - -// newReplicationControllers returns a PodsClient -func newReplicationControllers(c *Client, namespace string) *replicationControllers { - return &replicationControllers{c, namespace} -} - -// List takes a selector, and returns the list of replication controllers that match that selector. -func (c *replicationControllers) List(opts api.ListOptions) (result *api.ReplicationControllerList, err error) { - result = &api.ReplicationControllerList{} - err = c.r.Get().Namespace(c.ns).Resource("replicationControllers").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular replication controller. -func (c *replicationControllers) Get(name string) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} - err = c.r.Get().Namespace(c.ns).Resource("replicationControllers").Name(name).Do().Into(result) - return -} - -// Create creates a new replication controller. -func (c *replicationControllers) Create(controller *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} - err = c.r.Post().Namespace(c.ns).Resource("replicationControllers").Body(controller).Do().Into(result) - return -} - -// Update updates an existing replication controller. -func (c *replicationControllers) Update(controller *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} - err = c.r.Put().Namespace(c.ns).Resource("replicationControllers").Name(controller.Name).Body(controller).Do().Into(result) - return -} - -// UpdateStatus updates an existing replication controller status -func (c *replicationControllers) UpdateStatus(controller *api.ReplicationController) (result *api.ReplicationController, err error) { - result = &api.ReplicationController{} - err = c.r.Put().Namespace(c.ns).Resource("replicationControllers").Name(controller.Name).SubResource("status").Body(controller).Do().Into(result) - return -} - -// Delete deletes an existing replication controller. -func (c *replicationControllers) Delete(name string, options *api.DeleteOptions) error { - return c.r.Delete().Namespace(c.ns).Resource("replicationControllers").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested controllers. -func (c *replicationControllers) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("replicationControllers"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/resource_quotas.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/resource_quotas.go deleted file mode 100644 index 9944cef..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/resource_quotas.go +++ /dev/null @@ -1,102 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -// ResourceQuotasNamespacer has methods to work with ResourceQuota resources in a namespace -type ResourceQuotasNamespacer interface { - ResourceQuotas(namespace string) ResourceQuotaInterface -} - -// ResourceQuotaInterface has methods to work with ResourceQuota resources. -type ResourceQuotaInterface interface { - List(opts api.ListOptions) (*api.ResourceQuotaList, error) - Get(name string) (*api.ResourceQuota, error) - Delete(name string) error - Create(resourceQuota *api.ResourceQuota) (*api.ResourceQuota, error) - Update(resourceQuota *api.ResourceQuota) (*api.ResourceQuota, error) - UpdateStatus(resourceQuota *api.ResourceQuota) (*api.ResourceQuota, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// resourceQuotas implements ResourceQuotasNamespacer interface -type resourceQuotas struct { - r *Client - ns string -} - -// newResourceQuotas returns a resourceQuotas -func newResourceQuotas(c *Client, namespace string) *resourceQuotas { - return &resourceQuotas{ - r: c, - ns: namespace, - } -} - -// List takes a selector, and returns the list of resourceQuotas that match that selector. -func (c *resourceQuotas) List(opts api.ListOptions) (result *api.ResourceQuotaList, err error) { - result = &api.ResourceQuotaList{} - err = c.r.Get().Namespace(c.ns).Resource("resourceQuotas").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the resourceQuota, and returns the corresponding ResourceQuota object, and an error if it occurs -func (c *resourceQuotas) Get(name string) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} - err = c.r.Get().Namespace(c.ns).Resource("resourceQuotas").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the resourceQuota, and returns an error if one occurs -func (c *resourceQuotas) Delete(name string) error { - return c.r.Delete().Namespace(c.ns).Resource("resourceQuotas").Name(name).Do().Error() -} - -// Create takes the representation of a resourceQuota. Returns the server's representation of the resourceQuota, and an error, if it occurs. -func (c *resourceQuotas) Create(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} - err = c.r.Post().Namespace(c.ns).Resource("resourceQuotas").Body(resourceQuota).Do().Into(result) - return -} - -// Update takes the representation of a resourceQuota to update spec. Returns the server's representation of the resourceQuota, and an error, if it occurs. -func (c *resourceQuotas) Update(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} - err = c.r.Put().Namespace(c.ns).Resource("resourceQuotas").Name(resourceQuota.Name).Body(resourceQuota).Do().Into(result) - return -} - -// Status takes the representation of a resourceQuota to update status. Returns the server's representation of the resourceQuota, and an error, if it occurs. -func (c *resourceQuotas) UpdateStatus(resourceQuota *api.ResourceQuota) (result *api.ResourceQuota, err error) { - result = &api.ResourceQuota{} - err = c.r.Put().Namespace(c.ns).Resource("resourceQuotas").Name(resourceQuota.Name).SubResource("status").Body(resourceQuota).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested resource -func (c *resourceQuotas) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("resourceQuotas"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/rolebindings.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/rolebindings.go deleted file mode 100644 index b798380..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/rolebindings.go +++ /dev/null @@ -1,95 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/watch" -) - -// RoleBindingsNamespacer has methods to work with RoleBinding resources in a namespace -type RoleBindingsNamespacer interface { - RoleBindings(namespace string) RoleBindingInterface -} - -// RoleBindingInterface has methods to work with RoleBinding resources. -type RoleBindingInterface interface { - List(opts api.ListOptions) (*rbac.RoleBindingList, error) - Get(name string) (*rbac.RoleBinding, error) - Delete(name string, options *api.DeleteOptions) error - Create(roleBinding *rbac.RoleBinding) (*rbac.RoleBinding, error) - Update(roleBinding *rbac.RoleBinding) (*rbac.RoleBinding, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// roleBindings implements RoleBindingsNamespacer interface -type roleBindings struct { - client *RbacClient - ns string -} - -// newRoleBindings returns a roleBindings -func newRoleBindings(c *RbacClient, namespace string) *roleBindings { - return &roleBindings{ - client: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of roleBindings that match those selectors. -func (c *roleBindings) List(opts api.ListOptions) (result *rbac.RoleBindingList, err error) { - result = &rbac.RoleBindingList{} - err = c.client.Get().Namespace(c.ns).Resource("rolebindings").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the roleBinding, and returns the corresponding RoleBinding object, and an error if it occurs -func (c *roleBindings) Get(name string) (result *rbac.RoleBinding, err error) { - result = &rbac.RoleBinding{} - err = c.client.Get().Namespace(c.ns).Resource("rolebindings").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the roleBinding and deletes it. Returns an error if one occurs. -func (c *roleBindings) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Namespace(c.ns).Resource("rolebindings").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a roleBinding and creates it. Returns the server's representation of the roleBinding, and an error, if it occurs. -func (c *roleBindings) Create(roleBinding *rbac.RoleBinding) (result *rbac.RoleBinding, err error) { - result = &rbac.RoleBinding{} - err = c.client.Post().Namespace(c.ns).Resource("rolebindings").Body(roleBinding).Do().Into(result) - return -} - -// Update takes the representation of a roleBinding and updates it. Returns the server's representation of the roleBinding, and an error, if it occurs. -func (c *roleBindings) Update(roleBinding *rbac.RoleBinding) (result *rbac.RoleBinding, err error) { - result = &rbac.RoleBinding{} - err = c.client.Put().Namespace(c.ns).Resource("rolebindings").Name(roleBinding.Name).Body(roleBinding).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested roleBindings. -func (c *roleBindings) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("rolebindings"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/roles.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/roles.go deleted file mode 100644 index b265e78..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/roles.go +++ /dev/null @@ -1,95 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/rbac" - "k8s.io/kubernetes/pkg/watch" -) - -// RolesNamespacer has methods to work with Role resources in a namespace -type RolesNamespacer interface { - Roles(namespace string) RoleInterface -} - -// RoleInterface has methods to work with Role resources. -type RoleInterface interface { - List(opts api.ListOptions) (*rbac.RoleList, error) - Get(name string) (*rbac.Role, error) - Delete(name string, options *api.DeleteOptions) error - Create(role *rbac.Role) (*rbac.Role, error) - Update(role *rbac.Role) (*rbac.Role, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// roles implements RolesNamespacer interface -type roles struct { - client *RbacClient - ns string -} - -// newRoles returns a roles -func newRoles(c *RbacClient, namespace string) *roles { - return &roles{ - client: c, - ns: namespace, - } -} - -// List takes label and field selectors, and returns the list of roles that match those selectors. -func (c *roles) List(opts api.ListOptions) (result *rbac.RoleList, err error) { - result = &rbac.RoleList{} - err = c.client.Get().Namespace(c.ns).Resource("roles").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get takes the name of the role, and returns the corresponding Role object, and an error if it occurs -func (c *roles) Get(name string) (result *rbac.Role, err error) { - result = &rbac.Role{} - err = c.client.Get().Namespace(c.ns).Resource("roles").Name(name).Do().Into(result) - return -} - -// Delete takes the name of the role and deletes it. Returns an error if one occurs. -func (c *roles) Delete(name string, options *api.DeleteOptions) error { - return c.client.Delete().Namespace(c.ns).Resource("roles").Name(name).Body(options).Do().Error() -} - -// Create takes the representation of a role and creates it. Returns the server's representation of the role, and an error, if it occurs. -func (c *roles) Create(role *rbac.Role) (result *rbac.Role, err error) { - result = &rbac.Role{} - err = c.client.Post().Namespace(c.ns).Resource("roles").Body(role).Do().Into(result) - return -} - -// Update takes the representation of a role and updates it. Returns the server's representation of the role, and an error, if it occurs. -func (c *roles) Update(role *rbac.Role) (result *rbac.Role, err error) { - result = &rbac.Role{} - err = c.client.Put().Namespace(c.ns).Resource("roles").Name(role.Name).Body(role).Do().Into(result) - return -} - -// Watch returns a watch.Interface that watches the requested roles. -func (c *roles) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("roles"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/scale.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/scale.go deleted file mode 100644 index a55b077..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/scale.go +++ /dev/null @@ -1,77 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api/meta" - "k8s.io/kubernetes/pkg/api/unversioned" - "k8s.io/kubernetes/pkg/apis/extensions" -) - -type ScaleNamespacer interface { - Scales(namespace string) ScaleInterface -} - -// ScaleInterface has methods to work with Scale (sub)resources. -type ScaleInterface interface { - Get(string, string) (*extensions.Scale, error) - Update(string, *extensions.Scale) (*extensions.Scale, error) -} - -// horizontalPodAutoscalers implements HorizontalPodAutoscalersNamespacer interface -type scales struct { - client *ExtensionsClient - ns string -} - -// newHorizontalPodAutoscalers returns a horizontalPodAutoscalers -func newScales(c *ExtensionsClient, namespace string) *scales { - return &scales{ - client: c, - ns: namespace, - } -} - -// Get takes the reference to scale subresource and returns the subresource or error, if one occurs. -func (c *scales) Get(kind string, name string) (result *extensions.Scale, err error) { - result = &extensions.Scale{} - - // TODO this method needs to take a proper unambiguous kind - fullyQualifiedKind := unversioned.GroupVersionKind{Kind: kind} - resource, _ := meta.KindToResource(fullyQualifiedKind) - - err = c.client.Get().Namespace(c.ns).Resource(resource.Resource).Name(name).SubResource("scale").Do().Into(result) - return -} - -func (c *scales) Update(kind string, scale *extensions.Scale) (result *extensions.Scale, err error) { - result = &extensions.Scale{} - - // TODO this method needs to take a proper unambiguous kind - fullyQualifiedKind := unversioned.GroupVersionKind{Kind: kind} - resource, _ := meta.KindToResource(fullyQualifiedKind) - - err = c.client.Put(). - Namespace(scale.Namespace). - Resource(resource.Resource). - Name(scale.Name). - SubResource("scale"). - Body(scale). - Do(). - Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/scheduledjobs.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/scheduledjobs.go deleted file mode 100644 index 5c9222c..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/scheduledjobs.go +++ /dev/null @@ -1,103 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/batch" - "k8s.io/kubernetes/pkg/watch" -) - -// ScheduledJobsNamespacer has methods to work with ScheduledJob resources in a namespace -type ScheduledJobsNamespacer interface { - ScheduledJobs(namespace string) ScheduledJobInterface -} - -// ScheduledJobInterface exposes methods to work on ScheduledJob resources. -type ScheduledJobInterface interface { - List(opts api.ListOptions) (*batch.ScheduledJobList, error) - Get(name string) (*batch.ScheduledJob, error) - Create(scheduledJob *batch.ScheduledJob) (*batch.ScheduledJob, error) - Update(scheduledJob *batch.ScheduledJob) (*batch.ScheduledJob, error) - Delete(name string, options *api.DeleteOptions) error - Watch(opts api.ListOptions) (watch.Interface, error) - UpdateStatus(scheduledJob *batch.ScheduledJob) (*batch.ScheduledJob, error) -} - -// scheduledJobs implements ScheduledJobsNamespacer interface -type scheduledJobs struct { - r *BatchClient - ns string -} - -// newScheduledJobs returns a scheduledJobs -func newScheduledJobs(c *BatchClient, namespace string) *scheduledJobs { - return &scheduledJobs{c, namespace} -} - -// Ensure statically that scheduledJobs implements ScheduledJobInterface. -var _ ScheduledJobInterface = &scheduledJobs{} - -// List returns a list of scheduled jobs that match the label and field selectors. -func (c *scheduledJobs) List(opts api.ListOptions) (result *batch.ScheduledJobList, err error) { - result = &batch.ScheduledJobList{} - err = c.r.Get().Namespace(c.ns).Resource("scheduledjobs").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular scheduled job. -func (c *scheduledJobs) Get(name string) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.r.Get().Namespace(c.ns).Resource("scheduledjobs").Name(name).Do().Into(result) - return -} - -// Create creates a new scheduled job. -func (c *scheduledJobs) Create(job *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.r.Post().Namespace(c.ns).Resource("scheduledjobs").Body(job).Do().Into(result) - return -} - -// Update updates an existing scheduled job. -func (c *scheduledJobs) Update(job *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.r.Put().Namespace(c.ns).Resource("scheduledjobs").Name(job.Name).Body(job).Do().Into(result) - return -} - -// Delete deletes a scheduled job, returns error if one occurs. -func (c *scheduledJobs) Delete(name string, options *api.DeleteOptions) (err error) { - return c.r.Delete().Namespace(c.ns).Resource("scheduledjobs").Name(name).Body(options).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested scheduled jobs. -func (c *scheduledJobs) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("scheduledjobs"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// UpdateStatus takes the name of the scheduled job and the new status. Returns the server's representation of the scheduled job, and an error, if it occurs. -func (c *scheduledJobs) UpdateStatus(job *batch.ScheduledJob) (result *batch.ScheduledJob, err error) { - result = &batch.ScheduledJob{} - err = c.r.Put().Namespace(c.ns).Resource("scheduledjobs").Name(job.Name).SubResource("status").Body(job).Do().Into(result) - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/secrets.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/secrets.go deleted file mode 100644 index bba3fd9..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/secrets.go +++ /dev/null @@ -1,120 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -type SecretsNamespacer interface { - Secrets(namespace string) SecretsInterface -} - -type SecretsInterface interface { - Create(secret *api.Secret) (*api.Secret, error) - Update(secret *api.Secret) (*api.Secret, error) - Delete(name string) error - List(opts api.ListOptions) (*api.SecretList, error) - Get(name string) (*api.Secret, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// events implements Secrets interface -type secrets struct { - client *Client - namespace string -} - -// newSecrets returns a new secrets object. -func newSecrets(c *Client, ns string) *secrets { - return &secrets{ - client: c, - namespace: ns, - } -} - -func (s *secrets) Create(secret *api.Secret) (*api.Secret, error) { - result := &api.Secret{} - err := s.client.Post(). - Namespace(s.namespace). - Resource("secrets"). - Body(secret). - Do(). - Into(result) - - return result, err -} - -// List returns a list of secrets matching the selectors. -func (s *secrets) List(opts api.ListOptions) (*api.SecretList, error) { - result := &api.SecretList{} - - err := s.client.Get(). - Namespace(s.namespace). - Resource("secrets"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -// Get returns the given secret, or an error. -func (s *secrets) Get(name string) (*api.Secret, error) { - result := &api.Secret{} - err := s.client.Get(). - Namespace(s.namespace). - Resource("secrets"). - Name(name). - Do(). - Into(result) - - return result, err -} - -// Watch starts watching for secrets matching the given selectors. -func (s *secrets) Watch(opts api.ListOptions) (watch.Interface, error) { - return s.client.Get(). - Prefix("watch"). - Namespace(s.namespace). - Resource("secrets"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -func (s *secrets) Delete(name string) error { - return s.client.Delete(). - Namespace(s.namespace). - Resource("secrets"). - Name(name). - Do(). - Error() -} - -func (s *secrets) Update(secret *api.Secret) (result *api.Secret, err error) { - result = &api.Secret{} - err = s.client.Put(). - Namespace(s.namespace). - Resource("secrets"). - Name(secret.Name). - Body(secret). - Do(). - Into(result) - - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/service_accounts.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/service_accounts.go deleted file mode 100644 index 68d1b21..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/service_accounts.go +++ /dev/null @@ -1,120 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/watch" -) - -type ServiceAccountsNamespacer interface { - ServiceAccounts(namespace string) ServiceAccountsInterface -} - -type ServiceAccountsInterface interface { - Create(serviceAccount *api.ServiceAccount) (*api.ServiceAccount, error) - Update(serviceAccount *api.ServiceAccount) (*api.ServiceAccount, error) - Delete(name string) error - List(opts api.ListOptions) (*api.ServiceAccountList, error) - Get(name string) (*api.ServiceAccount, error) - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// serviceAccounts implements ServiceAccounts interface -type serviceAccounts struct { - client *Client - namespace string -} - -// newServiceAccounts returns a new serviceAccounts object. -func newServiceAccounts(c *Client, ns string) ServiceAccountsInterface { - return &serviceAccounts{ - client: c, - namespace: ns, - } -} - -func (s *serviceAccounts) Create(serviceAccount *api.ServiceAccount) (*api.ServiceAccount, error) { - result := &api.ServiceAccount{} - err := s.client.Post(). - Namespace(s.namespace). - Resource("serviceAccounts"). - Body(serviceAccount). - Do(). - Into(result) - - return result, err -} - -// List returns a list of serviceAccounts matching the selectors. -func (s *serviceAccounts) List(opts api.ListOptions) (*api.ServiceAccountList, error) { - result := &api.ServiceAccountList{} - - err := s.client.Get(). - Namespace(s.namespace). - Resource("serviceAccounts"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -// Get returns the given serviceAccount, or an error. -func (s *serviceAccounts) Get(name string) (*api.ServiceAccount, error) { - result := &api.ServiceAccount{} - err := s.client.Get(). - Namespace(s.namespace). - Resource("serviceAccounts"). - Name(name). - Do(). - Into(result) - - return result, err -} - -// Watch starts watching for serviceAccounts matching the given selectors. -func (s *serviceAccounts) Watch(opts api.ListOptions) (watch.Interface, error) { - return s.client.Get(). - Prefix("watch"). - Namespace(s.namespace). - Resource("serviceAccounts"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -func (s *serviceAccounts) Delete(name string) error { - return s.client.Delete(). - Namespace(s.namespace). - Resource("serviceAccounts"). - Name(name). - Do(). - Error() -} - -func (s *serviceAccounts) Update(serviceAccount *api.ServiceAccount) (result *api.ServiceAccount, err error) { - result = &api.ServiceAccount{} - err = s.client.Put(). - Namespace(s.namespace). - Resource("serviceAccounts"). - Name(serviceAccount.Name). - Body(serviceAccount). - Do(). - Into(result) - - return -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/services.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/services.go deleted file mode 100644 index aada5c1..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/services.go +++ /dev/null @@ -1,121 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/client/restclient" - "k8s.io/kubernetes/pkg/util/net" - "k8s.io/kubernetes/pkg/watch" -) - -// ServicesNamespacer has methods to work with Service resources in a namespace -type ServicesNamespacer interface { - Services(namespace string) ServiceInterface -} - -// ServiceInterface has methods to work with Service resources. -type ServiceInterface interface { - List(opts api.ListOptions) (*api.ServiceList, error) - Get(name string) (*api.Service, error) - Create(srv *api.Service) (*api.Service, error) - Update(srv *api.Service) (*api.Service, error) - UpdateStatus(srv *api.Service) (*api.Service, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) - ProxyGet(scheme, name, port, path string, params map[string]string) restclient.ResponseWrapper -} - -// services implements ServicesNamespacer interface -type services struct { - r *Client - ns string -} - -// newServices returns a services -func newServices(c *Client, namespace string) *services { - return &services{c, namespace} -} - -// List takes a selector, and returns the list of services that match that selector -func (c *services) List(opts api.ListOptions) (result *api.ServiceList, err error) { - result = &api.ServiceList{} - err = c.r.Get(). - Namespace(c.ns). - Resource("services"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - return -} - -// Get returns information about a particular service. -func (c *services) Get(name string) (result *api.Service, err error) { - result = &api.Service{} - err = c.r.Get().Namespace(c.ns).Resource("services").Name(name).Do().Into(result) - return -} - -// Create creates a new service. -func (c *services) Create(svc *api.Service) (result *api.Service, err error) { - result = &api.Service{} - err = c.r.Post().Namespace(c.ns).Resource("services").Body(svc).Do().Into(result) - return -} - -// Update updates an existing service. -func (c *services) Update(svc *api.Service) (result *api.Service, err error) { - result = &api.Service{} - err = c.r.Put().Namespace(c.ns).Resource("services").Name(svc.Name).Body(svc).Do().Into(result) - return -} - -// UpdateStatus takes a Service object with the new status and applies it as an update to the existing Service. -func (c *services) UpdateStatus(service *api.Service) (result *api.Service, err error) { - result = &api.Service{} - err = c.r.Put().Namespace(c.ns).Resource("services").Name(service.Name).SubResource("status").Body(service).Do().Into(result) - return -} - -// Delete deletes an existing service. -func (c *services) Delete(name string) error { - return c.r.Delete().Namespace(c.ns).Resource("services").Name(name).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested services. -func (c *services) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Namespace(c.ns). - Resource("services"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} - -// ProxyGet returns a response of the service by calling it through the proxy. -func (c *services) ProxyGet(scheme, name, port, path string, params map[string]string) restclient.ResponseWrapper { - request := c.r.Get(). - Namespace(c.ns). - Resource("services"). - SubResource("proxy"). - Name(net.JoinSchemeNamePort(scheme, name, port)). - Suffix(path) - for k, v := range params { - request = request.Param(k, v) - } - return request -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/storage.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/storage.go deleted file mode 100644 index 3b8d2b7..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/storage.go +++ /dev/null @@ -1,77 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apimachinery/registered" - "k8s.io/kubernetes/pkg/apis/storage" - "k8s.io/kubernetes/pkg/client/restclient" -) - -type StorageInterface interface { - StorageClassesInterface -} - -// StorageClient is used to interact with Kubernetes storage features. -type StorageClient struct { - *restclient.RESTClient -} - -func (c *StorageClient) StorageClasses() StorageClassInterface { - return newStorageClasses(c) -} - -func NewStorage(c *restclient.Config) (*StorageClient, error) { - config := *c - if err := setStorageDefaults(&config); err != nil { - return nil, err - } - client, err := restclient.RESTClientFor(&config) - if err != nil { - return nil, err - } - return &StorageClient{client}, nil -} - -func NewStorageOrDie(c *restclient.Config) *StorageClient { - client, err := NewStorage(c) - if err != nil { - panic(err) - } - return client -} - -func setStorageDefaults(config *restclient.Config) error { - // if storage group is not registered, return an error - g, err := registered.Group(storage.GroupName) - if err != nil { - return err - } - config.APIPath = defaultAPIPath - if config.UserAgent == "" { - config.UserAgent = restclient.DefaultKubernetesUserAgent() - } - // TODO: Unconditionally set the config.Version, until we fix the config. - //if config.Version == "" { - copyGroupVersion := g.GroupVersion - config.GroupVersion = ©GroupVersion - //} - - config.NegotiatedSerializer = api.Codecs - return nil -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/storageclasses.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/storageclasses.go deleted file mode 100644 index 509e540..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/storageclasses.go +++ /dev/null @@ -1,87 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/storage" - "k8s.io/kubernetes/pkg/watch" -) - -type StorageClassesInterface interface { - StorageClasses() StorageClassInterface -} - -// StorageClassInterface has methods to work with StorageClass resources. -type StorageClassInterface interface { - List(opts api.ListOptions) (*storage.StorageClassList, error) - Get(name string) (*storage.StorageClass, error) - Create(storageClass *storage.StorageClass) (*storage.StorageClass, error) - Update(storageClass *storage.StorageClass) (*storage.StorageClass, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// storageClasses implements StorageClassInterface -type storageClasses struct { - client *StorageClient -} - -func newStorageClasses(c *StorageClient) *storageClasses { - return &storageClasses{c} -} - -func (c *storageClasses) List(opts api.ListOptions) (result *storage.StorageClassList, err error) { - result = &storage.StorageClassList{} - err = c.client.Get(). - Resource("storageclasses"). - VersionedParams(&opts, api.ParameterCodec). - Do(). - Into(result) - - return result, err -} - -func (c *storageClasses) Get(name string) (result *storage.StorageClass, err error) { - result = &storage.StorageClass{} - err = c.client.Get().Resource("storageClasses").Name(name).Do().Into(result) - return -} - -func (c *storageClasses) Create(storageClass *storage.StorageClass) (result *storage.StorageClass, err error) { - result = &storage.StorageClass{} - err = c.client.Post().Resource("storageClasses").Body(storageClass).Do().Into(result) - return -} - -func (c *storageClasses) Update(storageClass *storage.StorageClass) (result *storage.StorageClass, err error) { - result = &storage.StorageClass{} - err = c.client.Put().Resource("storageClasses").Name(storageClass.Name).Body(storageClass).Do().Into(result) - return -} - -func (c *storageClasses) Delete(name string) error { - return c.client.Delete().Resource("storageClasses").Name(name).Do().Error() -} - -func (c *storageClasses) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.client.Get(). - Prefix("watch"). - Resource("storageClasses"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/client/unversioned/thirdpartyresources.go b/vendor/k8s.io/kubernetes/pkg/client/unversioned/thirdpartyresources.go deleted file mode 100644 index 68adddb..0000000 --- a/vendor/k8s.io/kubernetes/pkg/client/unversioned/thirdpartyresources.go +++ /dev/null @@ -1,98 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package unversioned - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/apis/extensions" - "k8s.io/kubernetes/pkg/watch" -) - -// ThirdPartyResourceNamespacer has methods to work with ThirdPartyResource resources in a namespace -type ThirdPartyResourceNamespacer interface { - ThirdPartyResources() ThirdPartyResourceInterface -} - -type ThirdPartyResourceInterface interface { - List(opts api.ListOptions) (*extensions.ThirdPartyResourceList, error) - Get(name string) (*extensions.ThirdPartyResource, error) - Create(ctrl *extensions.ThirdPartyResource) (*extensions.ThirdPartyResource, error) - Update(ctrl *extensions.ThirdPartyResource) (*extensions.ThirdPartyResource, error) - UpdateStatus(ctrl *extensions.ThirdPartyResource) (*extensions.ThirdPartyResource, error) - Delete(name string) error - Watch(opts api.ListOptions) (watch.Interface, error) -} - -// thirdPartyResources implements DaemonsSetsNamespacer interface -type thirdPartyResources struct { - r *ExtensionsClient -} - -func newThirdPartyResources(c *ExtensionsClient) *thirdPartyResources { - return &thirdPartyResources{c} -} - -// Ensure statically that thirdPartyResources implements ThirdPartyResourcesInterface. -var _ ThirdPartyResourceInterface = &thirdPartyResources{} - -func (c *thirdPartyResources) List(opts api.ListOptions) (result *extensions.ThirdPartyResourceList, err error) { - result = &extensions.ThirdPartyResourceList{} - err = c.r.Get().Resource("thirdpartyresources").VersionedParams(&opts, api.ParameterCodec).Do().Into(result) - return -} - -// Get returns information about a particular third party resource. -func (c *thirdPartyResources) Get(name string) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} - err = c.r.Get().Resource("thirdpartyresources").Name(name).Do().Into(result) - return -} - -// Create creates a new third party resource. -func (c *thirdPartyResources) Create(resource *extensions.ThirdPartyResource) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} - err = c.r.Post().Resource("thirdpartyresources").Body(resource).Do().Into(result) - return -} - -// Update updates an existing third party resource. -func (c *thirdPartyResources) Update(resource *extensions.ThirdPartyResource) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} - err = c.r.Put().Resource("thirdpartyresources").Name(resource.Name).Body(resource).Do().Into(result) - return -} - -// UpdateStatus updates an existing third party resource status -func (c *thirdPartyResources) UpdateStatus(resource *extensions.ThirdPartyResource) (result *extensions.ThirdPartyResource, err error) { - result = &extensions.ThirdPartyResource{} - err = c.r.Put().Resource("thirdpartyresources").Name(resource.Name).SubResource("status").Body(resource).Do().Into(result) - return -} - -// Delete deletes an existing third party resource. -func (c *thirdPartyResources) Delete(name string) error { - return c.r.Delete().Resource("thirdpartyresources").Name(name).Do().Error() -} - -// Watch returns a watch.Interface that watches the requested third party resources. -func (c *thirdPartyResources) Watch(opts api.ListOptions) (watch.Interface, error) { - return c.r.Get(). - Prefix("watch"). - Resource("thirdpartyresources"). - VersionedParams(&opts, api.ParameterCodec). - Watch() -} diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/doc.go b/vendor/k8s.io/kubernetes/pkg/kubelet/qos/doc.go deleted file mode 100644 index ebc1cc5..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/doc.go +++ /dev/null @@ -1,25 +0,0 @@ -/* -Copyright 2015 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. -*/ - -// package qos contains helper functions for quality of service. -// For each resource (memory, CPU) Kubelet supports three classes of containers. -// Memory guaranteed containers will receive the highest priority and will get all the resources -// they need. -// Burstable containers will be guaranteed their request and can “burst” and use more resources -// when available. -// Best-Effort containers, which don’t specify a request, can use resources only if not being used -// by other pods. -package qos diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/policy.go b/vendor/k8s.io/kubernetes/pkg/kubelet/qos/policy.go deleted file mode 100644 index 7c142f5..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/policy.go +++ /dev/null @@ -1,71 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package qos - -import ( - "k8s.io/kubernetes/pkg/api" -) - -const ( - // PodInfraOOMAdj is very docker specific. For arbitrary runtime, it may not make - // sense to set sandbox level oom score, e.g. a sandbox could only be a namespace - // without a process. - // TODO: Handle infra container oom score adj in a runtime agnostic way. - PodInfraOOMAdj int = -998 - KubeletOOMScoreAdj int = -999 - DockerOOMScoreAdj int = -999 - KubeProxyOOMScoreAdj int = -999 - guaranteedOOMScoreAdj int = -998 - besteffortOOMScoreAdj int = 1000 -) - -// GetContainerOOMAdjust returns the amount by which the OOM score of all processes in the -// container should be adjusted. -// The OOM score of a process is the percentage of memory it consumes -// multiplied by 10 (barring exceptional cases) + a configurable quantity which is between -1000 -// and 1000. Containers with higher OOM scores are killed if the system runs out of memory. -// See https://lwn.net/Articles/391222/ for more information. -func GetContainerOOMScoreAdjust(pod *api.Pod, container *api.Container, memoryCapacity int64) int { - switch GetPodQOS(pod) { - case Guaranteed: - // Guaranteed containers should be the last to get killed. - return guaranteedOOMScoreAdj - case BestEffort: - return besteffortOOMScoreAdj - } - - // Burstable containers are a middle tier, between Guaranteed and Best-Effort. Ideally, - // we want to protect Burstable containers that consume less memory than requested. - // The formula below is a heuristic. A container requesting for 10% of a system's - // memory will have an OOM score adjust of 900. If a process in container Y - // uses over 10% of memory, its OOM score will be 1000. The idea is that containers - // which use more than their request will have an OOM score of 1000 and will be prime - // targets for OOM kills. - // Note that this is a heuristic, it won't work if a container has many small processes. - memoryRequest := container.Resources.Requests.Memory().Value() - oomScoreAdjust := 1000 - (1000*memoryRequest)/memoryCapacity - // A guaranteed pod using 100% of memory can have an OOM score of 10. Ensure - // that burstable pods have a higher OOM score adjustment. - if int(oomScoreAdjust) < (1000 + guaranteedOOMScoreAdj) { - return (1000 + guaranteedOOMScoreAdj) - } - // Give burstable pods a higher chance of survival over besteffort pods. - if int(oomScoreAdjust) == besteffortOOMScoreAdj { - return int(oomScoreAdjust - 1) - } - return int(oomScoreAdjust) -} diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/qos.go b/vendor/k8s.io/kubernetes/pkg/kubelet/qos/qos.go deleted file mode 100644 index 00e347f..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/qos.go +++ /dev/null @@ -1,146 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package qos - -import ( - "k8s.io/kubernetes/pkg/api" - "k8s.io/kubernetes/pkg/api/resource" - "k8s.io/kubernetes/pkg/util/sets" -) - -// isResourceGuaranteed returns true if the container's resource requirements are Guaranteed. -func isResourceGuaranteed(container *api.Container, resource api.ResourceName) bool { - // A container resource is guaranteed if its request == limit. - // If request == limit, the user is very confident of resource consumption. - req, hasReq := container.Resources.Requests[resource] - limit, hasLimit := container.Resources.Limits[resource] - if !hasReq || !hasLimit { - return false - } - return req.Cmp(limit) == 0 && req.Value() != 0 -} - -// isResourceBestEffort returns true if the container's resource requirements are best-effort. -func isResourceBestEffort(container *api.Container, resource api.ResourceName) bool { - // A container resource is best-effort if its request is unspecified or 0. - // If a request is specified, then the user expects some kind of resource guarantee. - req, hasReq := container.Resources.Requests[resource] - return !hasReq || req.Value() == 0 -} - -// GetPodQOS returns the QoS class of a pod. -// A pod is besteffort if none of its containers have specified any requests or limits. -// A pod is guaranteed only when requests and limits are specified for all the containers and they are equal. -// A pod is burstable if limits and requests do not match across all containers. -func GetPodQOS(pod *api.Pod) QOSClass { - requests := api.ResourceList{} - limits := api.ResourceList{} - zeroQuantity := resource.MustParse("0") - isGuaranteed := true - for _, container := range pod.Spec.Containers { - // process requests - for name, quantity := range container.Resources.Requests { - if !supportedQoSComputeResources.Has(string(name)) { - continue - } - if quantity.Cmp(zeroQuantity) == 1 { - delta := quantity.Copy() - if _, exists := requests[name]; !exists { - requests[name] = *delta - } else { - delta.Add(requests[name]) - requests[name] = *delta - } - } - } - // process limits - qosLimitsFound := sets.NewString() - for name, quantity := range container.Resources.Limits { - if !supportedQoSComputeResources.Has(string(name)) { - continue - } - if quantity.Cmp(zeroQuantity) == 1 { - qosLimitsFound.Insert(string(name)) - delta := quantity.Copy() - if _, exists := limits[name]; !exists { - limits[name] = *delta - } else { - delta.Add(limits[name]) - limits[name] = *delta - } - } - } - - if len(qosLimitsFound) != len(supportedQoSComputeResources) { - isGuaranteed = false - } - } - if len(requests) == 0 && len(limits) == 0 { - return BestEffort - } - // Check is requests match limits for all resources. - if isGuaranteed { - for name, req := range requests { - if lim, exists := limits[name]; !exists || lim.Cmp(req) != 0 { - isGuaranteed = false - break - } - } - } - if isGuaranteed && - len(requests) == len(limits) { - return Guaranteed - } - return Burstable -} - -// QOSList is a set of (resource name, QoS class) pairs. -type QOSList map[api.ResourceName]QOSClass - -// GetQOS returns a mapping of resource name to QoS class of a container -func GetQOS(container *api.Container) QOSList { - resourceToQOS := QOSList{} - for resource := range allResources(container) { - switch { - case isResourceGuaranteed(container, resource): - resourceToQOS[resource] = Guaranteed - case isResourceBestEffort(container, resource): - resourceToQOS[resource] = BestEffort - default: - resourceToQOS[resource] = Burstable - } - } - return resourceToQOS -} - -// supportedComputeResources is the list of compute resources for with QoS is supported. -var supportedQoSComputeResources = sets.NewString(string(api.ResourceCPU), string(api.ResourceMemory)) - -// allResources returns a set of all possible resources whose mapped key value is true if present on the container -func allResources(container *api.Container) map[api.ResourceName]bool { - resources := map[api.ResourceName]bool{} - for _, resource := range supportedQoSComputeResources.List() { - resources[api.ResourceName(resource)] = false - } - for resource := range container.Resources.Requests { - resources[resource] = true - } - for resource := range container.Resources.Limits { - resources[resource] = true - } - return resources -} diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/types.go b/vendor/k8s.io/kubernetes/pkg/kubelet/qos/types.go deleted file mode 100644 index e52dece..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/qos/types.go +++ /dev/null @@ -1,29 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package qos - -// QOSClass defines the supported qos classes of Pods/Containers. -type QOSClass string - -const ( - // Guaranteed is the Guaranteed qos class. - Guaranteed QOSClass = "Guaranteed" - // Burstable is the Burstable qos class. - Burstable QOSClass = "Burstable" - // BestEffort is the BestEffort qos class. - BestEffort QOSClass = "BestEffort" -) diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/types/constants.go b/vendor/k8s.io/kubernetes/pkg/kubelet/types/constants.go deleted file mode 100644 index eeabba0..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/types/constants.go +++ /dev/null @@ -1,22 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package types - -const ( - // system default DNS resolver configuration - ResolvConfDefault = "/etc/resolv.conf" -) diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/types/doc.go b/vendor/k8s.io/kubernetes/pkg/kubelet/types/doc.go deleted file mode 100644 index 0d9efe5..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/types/doc.go +++ /dev/null @@ -1,18 +0,0 @@ -/* -Copyright 2015 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. -*/ - -// Common types in the Kubelet. -package types diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/types/labels.go b/vendor/k8s.io/kubernetes/pkg/kubelet/types/labels.go deleted file mode 100644 index c4dad63..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/types/labels.go +++ /dev/null @@ -1,40 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package types - -const ( - KubernetesPodNameLabel = "io.kubernetes.pod.name" - KubernetesPodNamespaceLabel = "io.kubernetes.pod.namespace" - KubernetesPodUIDLabel = "io.kubernetes.pod.uid" - KubernetesContainerNameLabel = "io.kubernetes.container.name" -) - -func GetContainerName(labels map[string]string) string { - return labels[KubernetesContainerNameLabel] -} - -func GetPodName(labels map[string]string) string { - return labels[KubernetesPodNameLabel] -} - -func GetPodUID(labels map[string]string) string { - return labels[KubernetesPodUIDLabel] -} - -func GetPodNamespace(labels map[string]string) string { - return labels[KubernetesPodNamespaceLabel] -} diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/types/pod_update.go b/vendor/k8s.io/kubernetes/pkg/kubelet/types/pod_update.go deleted file mode 100644 index e98489d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/types/pod_update.go +++ /dev/null @@ -1,133 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package types - -import ( - "fmt" - - "k8s.io/kubernetes/pkg/api" -) - -const ConfigSourceAnnotationKey = "kubernetes.io/config.source" -const ConfigMirrorAnnotationKey = "kubernetes.io/config.mirror" -const ConfigFirstSeenAnnotationKey = "kubernetes.io/config.seen" -const ConfigHashAnnotationKey = "kubernetes.io/config.hash" - -// PodOperation defines what changes will be made on a pod configuration. -type PodOperation int - -const ( - // This is the current pod configuration - SET PodOperation = iota - // Pods with the given ids are new to this source - ADD - // Pods with the given ids are gracefully deleted from this source - DELETE - // Pods with the given ids have been removed from this source - REMOVE - // Pods with the given ids have been updated in this source - UPDATE - // Pods with the given ids have unexpected status in this source, - // kubelet should reconcile status with this source - RECONCILE - - // These constants identify the sources of pods - // Updates from a file - FileSource = "file" - // Updates from querying a web page - HTTPSource = "http" - // Updates from Kubernetes API Server - ApiserverSource = "api" - // Updates from all sources - AllSource = "*" - - NamespaceDefault = api.NamespaceDefault -) - -// PodUpdate defines an operation sent on the channel. You can add or remove single services by -// sending an array of size one and Op == ADD|REMOVE (with REMOVE, only the ID is required). -// For setting the state of the system to a given state for this source configuration, set -// Pods as desired and Op to SET, which will reset the system state to that specified in this -// operation for this source channel. To remove all pods, set Pods to empty object and Op to SET. -// -// Additionally, Pods should never be nil - it should always point to an empty slice. While -// functionally similar, this helps our unit tests properly check that the correct PodUpdates -// are generated. -type PodUpdate struct { - Pods []*api.Pod - Op PodOperation - Source string -} - -// Gets all validated sources from the specified sources. -func GetValidatedSources(sources []string) ([]string, error) { - validated := make([]string, 0, len(sources)) - for _, source := range sources { - switch source { - case AllSource: - return []string{FileSource, HTTPSource, ApiserverSource}, nil - case FileSource, HTTPSource, ApiserverSource: - validated = append(validated, source) - break - case "": - break - default: - return []string{}, fmt.Errorf("unknown pod source %q", source) - } - } - return validated, nil -} - -// GetPodSource returns the source of the pod based on the annotation. -func GetPodSource(pod *api.Pod) (string, error) { - if pod.Annotations != nil { - if source, ok := pod.Annotations[ConfigSourceAnnotationKey]; ok { - return source, nil - } - } - return "", fmt.Errorf("cannot get source of pod %q", pod.UID) -} - -// SyncPodType classifies pod updates, eg: create, update. -type SyncPodType int - -const ( - // SyncPodSync is when the pod is synced to ensure desired state - SyncPodSync SyncPodType = iota - // SyncPodUpdate is when the pod is updated from source - SyncPodUpdate - // SyncPodCreate is when the pod is created from source - SyncPodCreate - // SyncPodKill is when the pod is killed based on a trigger internal to the kubelet for eviction. - // If a SyncPodKill request is made to pod workers, the request is never dropped, and will always be processed. - SyncPodKill -) - -func (sp SyncPodType) String() string { - switch sp { - case SyncPodCreate: - return "create" - case SyncPodUpdate: - return "update" - case SyncPodSync: - return "sync" - case SyncPodKill: - return "kill" - default: - return "unknown" - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/kubelet/types/types.go b/vendor/k8s.io/kubernetes/pkg/kubelet/types/types.go deleted file mode 100644 index 017c3c8..0000000 --- a/vendor/k8s.io/kubernetes/pkg/kubelet/types/types.go +++ /dev/null @@ -1,93 +0,0 @@ -/* -Copyright 2015 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. -*/ - -package types - -import ( - "net/http" - "time" - - "k8s.io/kubernetes/pkg/api" -) - -// TODO: Reconcile custom types in kubelet/types and this subpackage - -type HttpGetter interface { - Get(url string) (*http.Response, error) -} - -// Timestamp wraps around time.Time and offers utilities to format and parse -// the time using RFC3339Nano -type Timestamp struct { - time time.Time -} - -// NewTimestamp returns a Timestamp object using the current time. -func NewTimestamp() *Timestamp { - return &Timestamp{time.Now()} -} - -// ConvertToTimestamp takes a string, parses it using the RFC3339Nano layout, -// and converts it to a Timestamp object. -func ConvertToTimestamp(timeString string) *Timestamp { - parsed, _ := time.Parse(time.RFC3339Nano, timeString) - return &Timestamp{parsed} -} - -// Get returns the time as time.Time. -func (t *Timestamp) Get() time.Time { - return t.time -} - -// GetString returns the time in the string format using the RFC3339Nano -// layout. -func (t *Timestamp) GetString() string { - return t.time.Format(time.RFC3339Nano) -} - -// A type to help sort container statuses based on container names. -type SortedContainerStatuses []api.ContainerStatus - -func (s SortedContainerStatuses) Len() int { return len(s) } -func (s SortedContainerStatuses) Swap(i, j int) { s[i], s[j] = s[j], s[i] } - -func (s SortedContainerStatuses) Less(i, j int) bool { - return s[i].Name < s[j].Name -} - -// SortInitContainerStatuses ensures that statuses are in the order that their -// init container appears in the pod spec -func SortInitContainerStatuses(p *api.Pod, statuses []api.ContainerStatus) { - containers := p.Spec.InitContainers - current := 0 - for _, container := range containers { - for j := current; j < len(statuses); j++ { - if container.Name == statuses[j].Name { - statuses[current], statuses[j] = statuses[j], statuses[current] - current++ - break - } - } - } -} - -// Reservation represents reserved resources for non-pod components. -type Reservation struct { - // System represents resources reserved for non-kubernetes components. - System api.ResourceList - // Kubernetes represents resources reserved for kubernetes system components. - Kubernetes api.ResourceList -} diff --git a/vendor/k8s.io/kubernetes/pkg/master/ports/doc.go b/vendor/k8s.io/kubernetes/pkg/master/ports/doc.go deleted file mode 100644 index a2a0021..0000000 --- a/vendor/k8s.io/kubernetes/pkg/master/ports/doc.go +++ /dev/null @@ -1,19 +0,0 @@ -/* -Copyright 2014 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. -*/ - -// Package ports defines ports used by various pieces of the kubernetes -// infrastructure. -package ports diff --git a/vendor/k8s.io/kubernetes/pkg/master/ports/ports.go b/vendor/k8s.io/kubernetes/pkg/master/ports/ports.go deleted file mode 100644 index 6aa9796..0000000 --- a/vendor/k8s.io/kubernetes/pkg/master/ports/ports.go +++ /dev/null @@ -1,38 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package ports - -const ( - // ProxyPort is the default port for the proxy healthz server. - // May be overridden by a flag at startup. - ProxyStatusPort = 10249 - // KubeletPort is the default port for the kubelet server on each host machine. - // May be overridden by a flag at startup. - KubeletPort = 10250 - // SchedulerPort is the default port for the scheduler status server. - // May be overridden by a flag at startup. - SchedulerPort = 10251 - // ControllerManagerPort is the default port for the controller manager status server. - // May be overridden by a flag at startup. - ControllerManagerPort = 10252 - // KubeletReadOnlyPort exposes basic read-only services from the kubelet. - // May be overridden by a flag at startup. - // This is necessary for heapster to collect monitoring stats from the kubelet - // until heapster can transition to using the SSL endpoint. - // TODO(roberthbailey): Remove this once we have a better solution for heapster. - KubeletReadOnlyPort = 10255 -) diff --git a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/negotiated_codec.go b/vendor/k8s.io/kubernetes/pkg/runtime/serializer/negotiated_codec.go deleted file mode 100644 index d891772..0000000 --- a/vendor/k8s.io/kubernetes/pkg/runtime/serializer/negotiated_codec.go +++ /dev/null @@ -1,56 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package serializer - -import ( - "k8s.io/kubernetes/pkg/runtime" -) - -// TODO: We should figure out what happens when someone asks -// encoder for version and it conflicts with the raw serializer. -type negotiatedSerializerWrapper struct { - info runtime.SerializerInfo - streamInfo runtime.StreamSerializerInfo -} - -func NegotiatedSerializerWrapper(info runtime.SerializerInfo, streamInfo runtime.StreamSerializerInfo) runtime.NegotiatedSerializer { - return &negotiatedSerializerWrapper{info, streamInfo} -} - -func (n *negotiatedSerializerWrapper) SupportedMediaTypes() []string { - return []string{} -} - -func (n *negotiatedSerializerWrapper) SerializerForMediaType(mediaType string, options map[string]string) (runtime.SerializerInfo, bool) { - return n.info, true -} - -func (n *negotiatedSerializerWrapper) SupportedStreamingMediaTypes() []string { - return []string{} -} - -func (n *negotiatedSerializerWrapper) StreamingSerializerForMediaType(mediaType string, options map[string]string) (runtime.StreamSerializerInfo, bool) { - return n.streamInfo, true -} - -func (n *negotiatedSerializerWrapper) EncoderForVersion(e runtime.Encoder, _ runtime.GroupVersioner) runtime.Encoder { - return e -} - -func (n *negotiatedSerializerWrapper) DecoderToVersion(d runtime.Decoder, _gv runtime.GroupVersioner) runtime.Decoder { - return d -} diff --git a/vendor/k8s.io/kubernetes/pkg/util/config/config.go b/vendor/k8s.io/kubernetes/pkg/util/config/config.go deleted file mode 100644 index 30defee..0000000 --- a/vendor/k8s.io/kubernetes/pkg/util/config/config.go +++ /dev/null @@ -1,140 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package config - -import ( - "sync" - - "k8s.io/kubernetes/pkg/util/wait" -) - -type Merger interface { - // Invoked when a change from a source is received. May also function as an incremental - // merger if you wish to consume changes incrementally. Must be reentrant when more than - // one source is defined. - Merge(source string, update interface{}) error -} - -// MergeFunc implements the Merger interface -type MergeFunc func(source string, update interface{}) error - -func (f MergeFunc) Merge(source string, update interface{}) error { - return f(source, update) -} - -// Mux is a class for merging configuration from multiple sources. Changes are -// pushed via channels and sent to the merge function. -type Mux struct { - // Invoked when an update is sent to a source. - merger Merger - - // Sources and their lock. - sourceLock sync.RWMutex - // Maps source names to channels - sources map[string]chan interface{} -} - -// NewMux creates a new mux that can merge changes from multiple sources. -func NewMux(merger Merger) *Mux { - mux := &Mux{ - sources: make(map[string]chan interface{}), - merger: merger, - } - return mux -} - -// Channel returns a channel where a configuration source -// can send updates of new configurations. Multiple calls with the same -// source will return the same channel. This allows change and state based sources -// to use the same channel. Different source names however will be treated as a -// union. -func (m *Mux) Channel(source string) chan interface{} { - if len(source) == 0 { - panic("Channel given an empty name") - } - m.sourceLock.Lock() - defer m.sourceLock.Unlock() - channel, exists := m.sources[source] - if exists { - return channel - } - newChannel := make(chan interface{}) - m.sources[source] = newChannel - go wait.Until(func() { m.listen(source, newChannel) }, 0, wait.NeverStop) - return newChannel -} - -func (m *Mux) listen(source string, listenChannel <-chan interface{}) { - for update := range listenChannel { - m.merger.Merge(source, update) - } -} - -// Accessor is an interface for retrieving the current merge state. -type Accessor interface { - // MergedState returns a representation of the current merge state. - // Must be reentrant when more than one source is defined. - MergedState() interface{} -} - -// AccessorFunc implements the Accessor interface. -type AccessorFunc func() interface{} - -func (f AccessorFunc) MergedState() interface{} { - return f() -} - -type Listener interface { - // OnUpdate is invoked when a change is made to an object. - OnUpdate(instance interface{}) -} - -// ListenerFunc receives a representation of the change or object. -type ListenerFunc func(instance interface{}) - -func (f ListenerFunc) OnUpdate(instance interface{}) { - f(instance) -} - -type Broadcaster struct { - // Listeners for changes and their lock. - listenerLock sync.RWMutex - listeners []Listener -} - -// NewBroadcaster registers a set of listeners that support the Listener interface -// and notifies them all on changes. -func NewBroadcaster() *Broadcaster { - return &Broadcaster{} -} - -// Add registers listener to receive updates of changes. -func (b *Broadcaster) Add(listener Listener) { - b.listenerLock.Lock() - defer b.listenerLock.Unlock() - b.listeners = append(b.listeners, listener) -} - -// Notify notifies all listeners. -func (b *Broadcaster) Notify(instance interface{}) { - b.listenerLock.RLock() - listeners := b.listeners - b.listenerLock.RUnlock() - for _, listener := range listeners { - listener.OnUpdate(instance) - } -} diff --git a/vendor/k8s.io/kubernetes/pkg/util/config/configuration_map.go b/vendor/k8s.io/kubernetes/pkg/util/config/configuration_map.go deleted file mode 100644 index 0acbde5..0000000 --- a/vendor/k8s.io/kubernetes/pkg/util/config/configuration_map.go +++ /dev/null @@ -1,53 +0,0 @@ -/* -Copyright 2014 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. -*/ - -package config - -import ( - "fmt" - "sort" - "strings" -) - -type ConfigurationMap map[string]string - -func (m *ConfigurationMap) String() string { - pairs := []string{} - for k, v := range *m { - pairs = append(pairs, fmt.Sprintf("%s=%s", k, v)) - } - sort.Strings(pairs) - return strings.Join(pairs, ",") -} - -func (m *ConfigurationMap) Set(value string) error { - for _, s := range strings.Split(value, ",") { - if len(s) == 0 { - continue - } - arr := strings.SplitN(s, "=", 2) - if len(arr) == 2 { - (*m)[strings.TrimSpace(arr[0])] = strings.TrimSpace(arr[1]) - } else { - (*m)[strings.TrimSpace(arr[0])] = "" - } - } - return nil -} - -func (*ConfigurationMap) Type() string { - return "mapStringString" -} diff --git a/vendor/k8s.io/kubernetes/pkg/util/config/doc.go b/vendor/k8s.io/kubernetes/pkg/util/config/doc.go deleted file mode 100644 index 5dbb37d..0000000 --- a/vendor/k8s.io/kubernetes/pkg/util/config/doc.go +++ /dev/null @@ -1,20 +0,0 @@ -/* -Copyright 2014 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. -*/ - -// Package config provides utility objects for decoupling sources of configuration and the -// actual configuration state. Consumers must implement the Merger interface to unify -// the sources of change into an object. -package config diff --git a/vendor/k8s.io/kubernetes/pkg/util/config/feature_gate.go b/vendor/k8s.io/kubernetes/pkg/util/config/feature_gate.go deleted file mode 100644 index c8782c4..0000000 --- a/vendor/k8s.io/kubernetes/pkg/util/config/feature_gate.go +++ /dev/null @@ -1,223 +0,0 @@ -/* -Copyright 2016 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. -*/ - -package config - -import ( - "fmt" - "sort" - "strconv" - "strings" - - "github.com/golang/glog" - "github.com/spf13/pflag" -) - -const ( - flagName = "feature-gates" - - // All known feature keys - // To add a new feature, define a key for it below and add - // a featureSpec entry to knownFeatures. - - // allAlphaGate is a global toggle for alpha features. Per-feature key - // values override the default set by allAlphaGate. Examples: - // AllAlpha=false,NewFeature=true will result in newFeature=true - // AllAlpha=true,NewFeature=false will result in newFeature=false - allAlphaGate = "AllAlpha" - externalTrafficLocalOnly = "AllowExtTrafficLocalEndpoints" - appArmor = "AppArmor" - dynamicKubeletConfig = "DynamicKubeletConfig" - dynamicVolumeProvisioning = "DynamicVolumeProvisioning" -) - -var ( - // Default values for recorded features. Every new feature gate should be - // represented here. - knownFeatures = map[string]featureSpec{ - allAlphaGate: {false, alpha}, - externalTrafficLocalOnly: {false, alpha}, - appArmor: {true, beta}, - dynamicKubeletConfig: {false, alpha}, - dynamicVolumeProvisioning: {true, alpha}, - } - - // Special handling for a few gates. - specialFeatures = map[string]func(f *featureGate, val bool){ - allAlphaGate: setUnsetAlphaGates, - } - - // DefaultFeatureGate is a shared global FeatureGate. - DefaultFeatureGate = &featureGate{ - known: knownFeatures, - special: specialFeatures, - } -) - -type featureSpec struct { - enabled bool - prerelease prerelease -} - -type prerelease string - -const ( - // Values for prerelease. - alpha = prerelease("ALPHA") - beta = prerelease("BETA") - ga = prerelease("") -) - -// FeatureGate parses and stores flag gates for known features from -// a string like feature1=true,feature2=false,... -type FeatureGate interface { - AddFlag(fs *pflag.FlagSet) - - // Every feature gate should add method here following this template: - // - // // owner: @username - // // alpha: v1.4 - // MyFeature() bool - - // owner: @timstclair - // beta: v1.4 - AppArmor() bool - - // owner: @girishkalele - // alpha: v1.4 - ExternalTrafficLocalOnly() bool - - // owner: @saad-ali - // alpha: v1.3 - DynamicVolumeProvisioning() bool - - // owner: mtaufen - // alpha: v1.4 - DynamicKubeletConfig() bool -} - -// featureGate implements FeatureGate as well as pflag.Value for flag parsing. -type featureGate struct { - known map[string]featureSpec - special map[string]func(*featureGate, bool) - enabled map[string]bool -} - -func setUnsetAlphaGates(f *featureGate, val bool) { - for k, v := range f.known { - if v.prerelease == alpha { - if _, found := f.enabled[k]; !found { - f.enabled[k] = val - } - } - } -} - -// Set, String, and Type implement pflag.Value - -// Set Parses a string of the form // "key1=value1,key2=value2,..." into a -// map[string]bool of known keys or returns an error. -func (f *featureGate) Set(value string) error { - f.enabled = make(map[string]bool) - for _, s := range strings.Split(value, ",") { - if len(s) == 0 { - continue - } - arr := strings.SplitN(s, "=", 2) - k := strings.TrimSpace(arr[0]) - _, ok := f.known[k] - if !ok { - return fmt.Errorf("unrecognized key: %s", k) - } - if len(arr) != 2 { - return fmt.Errorf("missing bool value for %s", k) - } - v := strings.TrimSpace(arr[1]) - boolValue, err := strconv.ParseBool(v) - if err != nil { - return fmt.Errorf("invalid value of %s: %s, err: %v", k, v, err) - } - f.enabled[k] = boolValue - - // Handle "special" features like "all alpha gates" - if fn, found := f.special[k]; found { - fn(f, boolValue) - } - } - - glog.Infof("feature gates: %v", f.enabled) - return nil -} - -func (f *featureGate) String() string { - pairs := []string{} - for k, v := range f.enabled { - pairs = append(pairs, fmt.Sprintf("%s=%t", k, v)) - } - sort.Strings(pairs) - return strings.Join(pairs, ",") -} - -func (f *featureGate) Type() string { - return "mapStringBool" -} - -// ExternalTrafficLocalOnly returns value for AllowExtTrafficLocalEndpoints -func (f *featureGate) ExternalTrafficLocalOnly() bool { - return f.lookup(externalTrafficLocalOnly) -} - -// AppArmor returns the value for the AppArmor feature gate. -func (f *featureGate) AppArmor() bool { - return f.lookup(appArmor) -} - -// DynamicKubeletConfig returns value for dynamicKubeletConfig -func (f *featureGate) DynamicKubeletConfig() bool { - return f.lookup(dynamicKubeletConfig) -} - -// DynamicVolumeProvisioning returns value for dynamicVolumeProvisioning -func (f *featureGate) DynamicVolumeProvisioning() bool { - return f.lookup(dynamicVolumeProvisioning) -} - -func (f *featureGate) lookup(key string) bool { - defaultValue := f.known[key].enabled - if f.enabled != nil { - if v, ok := f.enabled[key]; ok { - return v - } - } - return defaultValue - -} - -// AddFlag adds a flag for setting global feature gates to the specified FlagSet. -func (f *featureGate) AddFlag(fs *pflag.FlagSet) { - var known []string - for k, v := range f.known { - pre := "" - if v.prerelease != ga { - pre = fmt.Sprintf("%s - ", v.prerelease) - } - known = append(known, fmt.Sprintf("%s=true|false (%sdefault=%t)", k, pre, v.enabled)) - } - sort.Strings(known) - fs.Var(f, flagName, ""+ - "A set of key=value pairs that describe feature gates for alpha/experimental features. "+ - "Options are:\n"+strings.Join(known, "\n")) -} diff --git a/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/compute/metadata/metadata.go b/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/compute/metadata/metadata.go deleted file mode 100644 index 5c6f3bf..0000000 --- a/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/compute/metadata/metadata.go +++ /dev/null @@ -1,438 +0,0 @@ -// Copyright 2014 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 metadata provides access to Google Compute Engine (GCE) -// metadata and API service accounts. -// -// This package is a wrapper around the GCE metadata service, -// as documented at https://developers.google.com/compute/docs/metadata. -package metadata - -import ( - "encoding/json" - "fmt" - "io/ioutil" - "net" - "net/http" - "net/url" - "os" - "runtime" - "strings" - "sync" - "time" - - "golang.org/x/net/context" - "golang.org/x/net/context/ctxhttp" - - "cloud.google.com/go/internal" -) - -const ( - // metadataIP is the documented metadata server IP address. - metadataIP = "169.254.169.254" - - // metadataHostEnv is the environment variable specifying the - // GCE metadata hostname. If empty, the default value of - // metadataIP ("169.254.169.254") is used instead. - // This is variable name is not defined by any spec, as far as - // I know; it was made up for the Go package. - metadataHostEnv = "GCE_METADATA_HOST" -) - -type cachedValue struct { - k string - trim bool - mu sync.Mutex - v string -} - -var ( - projID = &cachedValue{k: "project/project-id", trim: true} - projNum = &cachedValue{k: "project/numeric-project-id", trim: true} - instID = &cachedValue{k: "instance/id", trim: true} -) - -var ( - metaClient = &http.Client{ - Transport: &internal.Transport{ - Base: &http.Transport{ - Dial: (&net.Dialer{ - Timeout: 2 * time.Second, - KeepAlive: 30 * time.Second, - }).Dial, - ResponseHeaderTimeout: 2 * time.Second, - }, - }, - } - subscribeClient = &http.Client{ - Transport: &internal.Transport{ - Base: &http.Transport{ - Dial: (&net.Dialer{ - Timeout: 2 * time.Second, - KeepAlive: 30 * time.Second, - }).Dial, - }, - }, - } -) - -// NotDefinedError is returned when requested metadata is not defined. -// -// The underlying string is the suffix after "/computeMetadata/v1/". -// -// This error is not returned if the value is defined to be the empty -// string. -type NotDefinedError string - -func (suffix NotDefinedError) Error() string { - return fmt.Sprintf("metadata: GCE metadata %q not defined", string(suffix)) -} - -// Get returns a value from the metadata service. -// The suffix is appended to "http://${GCE_METADATA_HOST}/computeMetadata/v1/". -// -// If the GCE_METADATA_HOST environment variable is not defined, a default of -// 169.254.169.254 will be used instead. -// -// If the requested metadata is not defined, the returned error will -// be of type NotDefinedError. -func Get(suffix string) (string, error) { - val, _, err := getETag(metaClient, suffix) - return val, err -} - -// getETag returns a value from the metadata service as well as the associated -// ETag using the provided client. This func is otherwise equivalent to Get. -func getETag(client *http.Client, suffix string) (value, etag string, err error) { - // Using a fixed IP makes it very difficult to spoof the metadata service in - // a container, which is an important use-case for local testing of cloud - // deployments. To enable spoofing of the metadata service, the environment - // variable GCE_METADATA_HOST is first inspected to decide where metadata - // requests shall go. - host := os.Getenv(metadataHostEnv) - if host == "" { - // Using 169.254.169.254 instead of "metadata" here because Go - // binaries built with the "netgo" tag and without cgo won't - // know the search suffix for "metadata" is - // ".google.internal", and this IP address is documented as - // being stable anyway. - host = metadataIP - } - url := "http://" + host + "/computeMetadata/v1/" + suffix - req, _ := http.NewRequest("GET", url, nil) - req.Header.Set("Metadata-Flavor", "Google") - res, err := client.Do(req) - if err != nil { - return "", "", err - } - defer res.Body.Close() - if res.StatusCode == http.StatusNotFound { - return "", "", NotDefinedError(suffix) - } - if res.StatusCode != 200 { - return "", "", fmt.Errorf("status code %d trying to fetch %s", res.StatusCode, url) - } - all, err := ioutil.ReadAll(res.Body) - if err != nil { - return "", "", err - } - return string(all), res.Header.Get("Etag"), nil -} - -func getTrimmed(suffix string) (s string, err error) { - s, err = Get(suffix) - s = strings.TrimSpace(s) - return -} - -func (c *cachedValue) get() (v string, err error) { - defer c.mu.Unlock() - c.mu.Lock() - if c.v != "" { - return c.v, nil - } - if c.trim { - v, err = getTrimmed(c.k) - } else { - v, err = Get(c.k) - } - if err == nil { - c.v = v - } - return -} - -var ( - onGCEOnce sync.Once - onGCE bool -) - -// OnGCE reports whether this process is running on Google Compute Engine. -func OnGCE() bool { - onGCEOnce.Do(initOnGCE) - return onGCE -} - -func initOnGCE() { - onGCE = testOnGCE() -} - -func testOnGCE() bool { - // The user explicitly said they're on GCE, so trust them. - if os.Getenv(metadataHostEnv) != "" { - return true - } - - ctx, cancel := context.WithCancel(context.Background()) - defer cancel() - - resc := make(chan bool, 2) - - // Try two strategies in parallel. - // See https://github.com/GoogleCloudPlatform/google-cloud-go/issues/194 - go func() { - res, err := ctxhttp.Get(ctx, metaClient, "http://"+metadataIP) - if err != nil { - resc <- false - return - } - defer res.Body.Close() - resc <- res.Header.Get("Metadata-Flavor") == "Google" - }() - - go func() { - addrs, err := net.LookupHost("metadata.google.internal") - if err != nil || len(addrs) == 0 { - resc <- false - return - } - resc <- strsContains(addrs, metadataIP) - }() - - tryHarder := systemInfoSuggestsGCE() - if tryHarder { - res := <-resc - if res { - // The first strategy succeeded, so let's use it. - return true - } - // Wait for either the DNS or metadata server probe to - // contradict the other one and say we are running on - // GCE. Give it a lot of time to do so, since the system - // info already suggests we're running on a GCE BIOS. - timer := time.NewTimer(5 * time.Second) - defer timer.Stop() - select { - case res = <-resc: - return res - case <-timer.C: - // Too slow. Who knows what this system is. - return false - } - } - - // There's no hint from the system info that we're running on - // GCE, so use the first probe's result as truth, whether it's - // true or false. The goal here is to optimize for speed for - // users who are NOT running on GCE. We can't assume that - // either a DNS lookup or an HTTP request to a blackholed IP - // address is fast. Worst case this should return when the - // metaClient's Transport.ResponseHeaderTimeout or - // Transport.Dial.Timeout fires (in two seconds). - return <-resc -} - -// systemInfoSuggestsGCE reports whether the local system (without -// doing network requests) suggests that we're running on GCE. If this -// returns true, testOnGCE tries a bit harder to reach its metadata -// server. -func systemInfoSuggestsGCE() bool { - if runtime.GOOS != "linux" { - // We don't have any non-Linux clues available, at least yet. - return false - } - slurp, _ := ioutil.ReadFile("/sys/class/dmi/id/product_name") - name := strings.TrimSpace(string(slurp)) - return name == "Google" || name == "Google Compute Engine" -} - -// Subscribe subscribes to a value from the metadata service. -// The suffix is appended to "http://${GCE_METADATA_HOST}/computeMetadata/v1/". -// The suffix may contain query parameters. -// -// Subscribe calls fn with the latest metadata value indicated by the provided -// suffix. If the metadata value is deleted, fn is called with the empty string -// and ok false. Subscribe blocks until fn returns a non-nil error or the value -// is deleted. Subscribe returns the error value returned from the last call to -// fn, which may be nil when ok == false. -func Subscribe(suffix string, fn func(v string, ok bool) error) error { - const failedSubscribeSleep = time.Second * 5 - - // First check to see if the metadata value exists at all. - val, lastETag, err := getETag(subscribeClient, suffix) - if err != nil { - return err - } - - if err := fn(val, true); err != nil { - return err - } - - ok := true - if strings.ContainsRune(suffix, '?') { - suffix += "&wait_for_change=true&last_etag=" - } else { - suffix += "?wait_for_change=true&last_etag=" - } - for { - val, etag, err := getETag(subscribeClient, suffix+url.QueryEscape(lastETag)) - if err != nil { - if _, deleted := err.(NotDefinedError); !deleted { - time.Sleep(failedSubscribeSleep) - continue // Retry on other errors. - } - ok = false - } - lastETag = etag - - if err := fn(val, ok); err != nil || !ok { - return err - } - } -} - -// ProjectID returns the current instance's project ID string. -func ProjectID() (string, error) { return projID.get() } - -// NumericProjectID returns the current instance's numeric project ID. -func NumericProjectID() (string, error) { return projNum.get() } - -// InternalIP returns the instance's primary internal IP address. -func InternalIP() (string, error) { - return getTrimmed("instance/network-interfaces/0/ip") -} - -// ExternalIP returns the instance's primary external (public) IP address. -func ExternalIP() (string, error) { - return getTrimmed("instance/network-interfaces/0/access-configs/0/external-ip") -} - -// Hostname returns the instance's hostname. This will be of the form -// ".c..internal". -func Hostname() (string, error) { - return getTrimmed("instance/hostname") -} - -// InstanceTags returns the list of user-defined instance tags, -// assigned when initially creating a GCE instance. -func InstanceTags() ([]string, error) { - var s []string - j, err := Get("instance/tags") - if err != nil { - return nil, err - } - if err := json.NewDecoder(strings.NewReader(j)).Decode(&s); err != nil { - return nil, err - } - return s, nil -} - -// InstanceID returns the current VM's numeric instance ID. -func InstanceID() (string, error) { - return instID.get() -} - -// InstanceName returns the current VM's instance ID string. -func InstanceName() (string, error) { - host, err := Hostname() - if err != nil { - return "", err - } - return strings.Split(host, ".")[0], nil -} - -// Zone returns the current VM's zone, such as "us-central1-b". -func Zone() (string, error) { - zone, err := getTrimmed("instance/zone") - // zone is of the form "projects//zones/". - if err != nil { - return "", err - } - return zone[strings.LastIndex(zone, "/")+1:], nil -} - -// InstanceAttributes returns the list of user-defined attributes, -// assigned when initially creating a GCE VM instance. The value of an -// attribute can be obtained with InstanceAttributeValue. -func InstanceAttributes() ([]string, error) { return lines("instance/attributes/") } - -// ProjectAttributes returns the list of user-defined attributes -// applying to the project as a whole, not just this VM. The value of -// an attribute can be obtained with ProjectAttributeValue. -func ProjectAttributes() ([]string, error) { return lines("project/attributes/") } - -func lines(suffix string) ([]string, error) { - j, err := Get(suffix) - if err != nil { - return nil, err - } - s := strings.Split(strings.TrimSpace(j), "\n") - for i := range s { - s[i] = strings.TrimSpace(s[i]) - } - return s, nil -} - -// InstanceAttributeValue returns the value of the provided VM -// instance attribute. -// -// If the requested attribute is not defined, the returned error will -// be of type NotDefinedError. -// -// InstanceAttributeValue may return ("", nil) if the attribute was -// defined to be the empty string. -func InstanceAttributeValue(attr string) (string, error) { - return Get("instance/attributes/" + attr) -} - -// ProjectAttributeValue returns the value of the provided -// project attribute. -// -// If the requested attribute is not defined, the returned error will -// be of type NotDefinedError. -// -// ProjectAttributeValue may return ("", nil) if the attribute was -// defined to be the empty string. -func ProjectAttributeValue(attr string) (string, error) { - return Get("project/attributes/" + attr) -} - -// Scopes returns the service account scopes for the given account. -// The account may be empty or the string "default" to use the instance's -// main account. -func Scopes(serviceAccount string) ([]string, error) { - if serviceAccount == "" { - serviceAccount = "default" - } - return lines("instance/service-accounts/" + serviceAccount + "/scopes") -} - -func strsContains(ss []string, s string) bool { - for _, v := range ss { - if v == s { - return true - } - } - return false -} diff --git a/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/internal/cloud.go b/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/internal/cloud.go deleted file mode 100644 index 8e0c8f8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/cloud.google.com/go/internal/cloud.go +++ /dev/null @@ -1,64 +0,0 @@ -// Copyright 2014 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 internal provides support for the cloud packages. -// -// Users should not import this package directly. -package internal - -import ( - "fmt" - "net/http" -) - -const userAgent = "gcloud-golang/0.1" - -// Transport is an http.RoundTripper that appends Google Cloud client's -// user-agent to the original request's user-agent header. -type Transport struct { - // TODO(bradfitz): delete internal.Transport. It's too wrappy for what it does. - // Do User-Agent some other way. - - // Base is the actual http.RoundTripper - // requests will use. It must not be nil. - Base http.RoundTripper -} - -// RoundTrip appends a user-agent to the existing user-agent -// header and delegates the request to the base http.RoundTripper. -func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { - req = cloneRequest(req) - ua := req.Header.Get("User-Agent") - if ua == "" { - ua = userAgent - } else { - ua = fmt.Sprintf("%s %s", ua, userAgent) - } - req.Header.Set("User-Agent", ua) - return t.Base.RoundTrip(req) -} - -// cloneRequest returns a clone of the provided *http.Request. -// The clone is a shallow copy of the struct and its Header map. -func cloneRequest(r *http.Request) *http.Request { - // shallow copy of the struct - r2 := new(http.Request) - *r2 = *r - // deep copy of the Header - r2.Header = make(http.Header) - for k, s := range r.Header { - r2.Header[k] = s - } - return r2 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.gitignore deleted file mode 100644 index 748e4c8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -*.sublime-* -.DS_Store -*.swp -*.swo -tags diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.travis.yml b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.travis.yml deleted file mode 100644 index facfc91..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/.travis.yml +++ /dev/null @@ -1,7 +0,0 @@ -language: go - -go: - - 1.4 - - 1.5 - - 1.6 - - tip diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/LICENSE deleted file mode 100644 index 4b9986d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/LICENSE +++ /dev/null @@ -1,12 +0,0 @@ -Copyright (c) 2012, Martin Angers -All rights reserved. - -Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: - -* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. - -* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. - -* Neither the name of the author nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/README.md deleted file mode 100644 index a78a3df..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/README.md +++ /dev/null @@ -1,185 +0,0 @@ -# Purell - -Purell is a tiny Go library to normalize URLs. It returns a pure URL. Pure-ell. Sanitizer and all. Yeah, I know... - -Based on the [wikipedia paper][wiki] and the [RFC 3986 document][rfc]. - -[![build status](https://secure.travis-ci.org/PuerkitoBio/purell.png)](http://travis-ci.org/PuerkitoBio/purell) - -## Install - -`go get github.com/PuerkitoBio/purell` - -## Changelog - -* **2016-07-27 (v1.0.0)** : Normalize IDN to ASCII (thanks to @zenovich). -* **2015-02-08** : Add fix for relative paths issue ([PR #5][pr5]) and add fix for unnecessary encoding of reserved characters ([see issue #7][iss7]). -* **v0.2.0** : Add benchmarks, Attempt IDN support. -* **v0.1.0** : Initial release. - -## Examples - -From `example_test.go` (note that in your code, you would import "github.com/PuerkitoBio/purell", and would prefix references to its methods and constants with "purell."): - -```go -package purell - -import ( - "fmt" - "net/url" -) - -func ExampleNormalizeURLString() { - if normalized, err := NormalizeURLString("hTTp://someWEBsite.com:80/Amazing%3f/url/", - FlagLowercaseScheme|FlagLowercaseHost|FlagUppercaseEscapes); err != nil { - panic(err) - } else { - fmt.Print(normalized) - } - // Output: http://somewebsite.com:80/Amazing%3F/url/ -} - -func ExampleMustNormalizeURLString() { - normalized := MustNormalizeURLString("hTTpS://someWEBsite.com:443/Amazing%fa/url/", - FlagsUnsafeGreedy) - fmt.Print(normalized) - - // Output: http://somewebsite.com/Amazing%FA/url -} - -func ExampleNormalizeURL() { - if u, err := url.Parse("Http://SomeUrl.com:8080/a/b/.././c///g?c=3&a=1&b=9&c=0#target"); err != nil { - panic(err) - } else { - normalized := NormalizeURL(u, FlagsUsuallySafeGreedy|FlagRemoveDuplicateSlashes|FlagRemoveFragment) - fmt.Print(normalized) - } - - // Output: http://someurl.com:8080/a/c/g?c=3&a=1&b=9&c=0 -} -``` - -## API - -As seen in the examples above, purell offers three methods, `NormalizeURLString(string, NormalizationFlags) (string, error)`, `MustNormalizeURLString(string, NormalizationFlags) (string)` and `NormalizeURL(*url.URL, NormalizationFlags) (string)`. They all normalize the provided URL based on the specified flags. Here are the available flags: - -```go -const ( - // Safe normalizations - FlagLowercaseScheme NormalizationFlags = 1 << iota // HTTP://host -> http://host, applied by default in Go1.1 - FlagLowercaseHost // http://HOST -> http://host - FlagUppercaseEscapes // http://host/t%ef -> http://host/t%EF - FlagDecodeUnnecessaryEscapes // http://host/t%41 -> http://host/tA - FlagEncodeNecessaryEscapes // http://host/!"#$ -> http://host/%21%22#$ - FlagRemoveDefaultPort // http://host:80 -> http://host - FlagRemoveEmptyQuerySeparator // http://host/path? -> http://host/path - - // Usually safe normalizations - FlagRemoveTrailingSlash // http://host/path/ -> http://host/path - FlagAddTrailingSlash // http://host/path -> http://host/path/ (should choose only one of these add/remove trailing slash flags) - FlagRemoveDotSegments // http://host/path/./a/b/../c -> http://host/path/a/c - - // Unsafe normalizations - FlagRemoveDirectoryIndex // http://host/path/index.html -> http://host/path/ - FlagRemoveFragment // http://host/path#fragment -> http://host/path - FlagForceHTTP // https://host -> http://host - FlagRemoveDuplicateSlashes // http://host/path//a///b -> http://host/path/a/b - FlagRemoveWWW // http://www.host/ -> http://host/ - FlagAddWWW // http://host/ -> http://www.host/ (should choose only one of these add/remove WWW flags) - FlagSortQuery // http://host/path?c=3&b=2&a=1&b=1 -> http://host/path?a=1&b=1&b=2&c=3 - - // Normalizations not in the wikipedia article, required to cover tests cases - // submitted by jehiah - FlagDecodeDWORDHost // http://1113982867 -> http://66.102.7.147 - FlagDecodeOctalHost // http://0102.0146.07.0223 -> http://66.102.7.147 - FlagDecodeHexHost // http://0x42660793 -> http://66.102.7.147 - FlagRemoveUnnecessaryHostDots // http://.host../path -> http://host/path - FlagRemoveEmptyPortSeparator // http://host:/path -> http://host/path - - // Convenience set of safe normalizations - FlagsSafe NormalizationFlags = FlagLowercaseHost | FlagLowercaseScheme | FlagUppercaseEscapes | FlagDecodeUnnecessaryEscapes | FlagEncodeNecessaryEscapes | FlagRemoveDefaultPort | FlagRemoveEmptyQuerySeparator - - // For convenience sets, "greedy" uses the "remove trailing slash" and "remove www. prefix" flags, - // while "non-greedy" uses the "add (or keep) the trailing slash" and "add www. prefix". - - // Convenience set of usually safe normalizations (includes FlagsSafe) - FlagsUsuallySafeGreedy NormalizationFlags = FlagsSafe | FlagRemoveTrailingSlash | FlagRemoveDotSegments - FlagsUsuallySafeNonGreedy NormalizationFlags = FlagsSafe | FlagAddTrailingSlash | FlagRemoveDotSegments - - // Convenience set of unsafe normalizations (includes FlagsUsuallySafe) - FlagsUnsafeGreedy NormalizationFlags = FlagsUsuallySafeGreedy | FlagRemoveDirectoryIndex | FlagRemoveFragment | FlagForceHTTP | FlagRemoveDuplicateSlashes | FlagRemoveWWW | FlagSortQuery - FlagsUnsafeNonGreedy NormalizationFlags = FlagsUsuallySafeNonGreedy | FlagRemoveDirectoryIndex | FlagRemoveFragment | FlagForceHTTP | FlagRemoveDuplicateSlashes | FlagAddWWW | FlagSortQuery - - // Convenience set of all available flags - FlagsAllGreedy = FlagsUnsafeGreedy | FlagDecodeDWORDHost | FlagDecodeOctalHost | FlagDecodeHexHost | FlagRemoveUnnecessaryHostDots | FlagRemoveEmptyPortSeparator - FlagsAllNonGreedy = FlagsUnsafeNonGreedy | FlagDecodeDWORDHost | FlagDecodeOctalHost | FlagDecodeHexHost | FlagRemoveUnnecessaryHostDots | FlagRemoveEmptyPortSeparator -) -``` - -For convenience, the set of flags `FlagsSafe`, `FlagsUsuallySafe[Greedy|NonGreedy]`, `FlagsUnsafe[Greedy|NonGreedy]` and `FlagsAll[Greedy|NonGreedy]` are provided for the similarly grouped normalizations on [wikipedia's URL normalization page][wiki]. You can add (using the bitwise OR `|` operator) or remove (using the bitwise AND NOT `&^` operator) individual flags from the sets if required, to build your own custom set. - -The [full godoc reference is available on gopkgdoc][godoc]. - -Some things to note: - -* `FlagDecodeUnnecessaryEscapes`, `FlagEncodeNecessaryEscapes`, `FlagUppercaseEscapes` and `FlagRemoveEmptyQuerySeparator` are always implicitly set, because internally, the URL string is parsed as an URL object, which automatically decodes unnecessary escapes, uppercases and encodes necessary ones, and removes empty query separators (an unnecessary `?` at the end of the url). So this operation cannot **not** be done. For this reason, `FlagRemoveEmptyQuerySeparator` (as well as the other three) has been included in the `FlagsSafe` convenience set, instead of `FlagsUnsafe`, where Wikipedia puts it. - -* The `FlagDecodeUnnecessaryEscapes` decodes the following escapes (*from -> to*): - - %24 -> $ - - %26 -> & - - %2B-%3B -> +,-./0123456789:; - - %3D -> = - - %40-%5A -> @ABCDEFGHIJKLMNOPQRSTUVWXYZ - - %5F -> _ - - %61-%7A -> abcdefghijklmnopqrstuvwxyz - - %7E -> ~ - - -* When the `NormalizeURL` function is used (passing an URL object), this source URL object is modified (that is, after the call, the URL object will be modified to reflect the normalization). - -* The *replace IP with domain name* normalization (`http://208.77.188.166/ → http://www.example.com/`) is obviously not possible for a library without making some network requests. This is not implemented in purell. - -* The *remove unused query string parameters* and *remove default query parameters* are also not implemented, since this is a very case-specific normalization, and it is quite trivial to do with an URL object. - -### Safe vs Usually Safe vs Unsafe - -Purell allows you to control the level of risk you take while normalizing an URL. You can aggressively normalize, play it totally safe, or anything in between. - -Consider the following URL: - -`HTTPS://www.RooT.com/toto/t%45%1f///a/./b/../c/?z=3&w=2&a=4&w=1#invalid` - -Normalizing with the `FlagsSafe` gives: - -`https://www.root.com/toto/tE%1F///a/./b/../c/?z=3&w=2&a=4&w=1#invalid` - -With the `FlagsUsuallySafeGreedy`: - -`https://www.root.com/toto/tE%1F///a/c?z=3&w=2&a=4&w=1#invalid` - -And with `FlagsUnsafeGreedy`: - -`http://root.com/toto/tE%1F/a/c?a=4&w=1&w=2&z=3` - -## TODOs - -* Add a class/default instance to allow specifying custom directory index names? At the moment, removing directory index removes `(^|/)((?:default|index)\.\w{1,4})$`. - -## Thanks / Contributions - -@rogpeppe -@jehiah -@opennota -@pchristopher1275 -@zenovich - -## License - -The [BSD 3-Clause license][bsd]. - -[bsd]: http://opensource.org/licenses/BSD-3-Clause -[wiki]: http://en.wikipedia.org/wiki/URL_normalization -[rfc]: http://tools.ietf.org/html/rfc3986#section-6 -[godoc]: http://go.pkgdoc.org/github.com/PuerkitoBio/purell -[pr5]: https://github.com/PuerkitoBio/purell/pull/5 -[iss7]: https://github.com/PuerkitoBio/purell/issues/7 diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/purell.go b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/purell.go deleted file mode 100644 index b79da64..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/purell/purell.go +++ /dev/null @@ -1,375 +0,0 @@ -/* -Package purell offers URL normalization as described on the wikipedia page: -http://en.wikipedia.org/wiki/URL_normalization -*/ -package purell - -import ( - "bytes" - "fmt" - "net/url" - "regexp" - "sort" - "strconv" - "strings" - - "github.com/PuerkitoBio/urlesc" - "golang.org/x/net/idna" - "golang.org/x/text/secure/precis" - "golang.org/x/text/unicode/norm" -) - -// A set of normalization flags determines how a URL will -// be normalized. -type NormalizationFlags uint - -const ( - // Safe normalizations - FlagLowercaseScheme NormalizationFlags = 1 << iota // HTTP://host -> http://host, applied by default in Go1.1 - FlagLowercaseHost // http://HOST -> http://host - FlagUppercaseEscapes // http://host/t%ef -> http://host/t%EF - FlagDecodeUnnecessaryEscapes // http://host/t%41 -> http://host/tA - FlagEncodeNecessaryEscapes // http://host/!"#$ -> http://host/%21%22#$ - FlagRemoveDefaultPort // http://host:80 -> http://host - FlagRemoveEmptyQuerySeparator // http://host/path? -> http://host/path - - // Usually safe normalizations - FlagRemoveTrailingSlash // http://host/path/ -> http://host/path - FlagAddTrailingSlash // http://host/path -> http://host/path/ (should choose only one of these add/remove trailing slash flags) - FlagRemoveDotSegments // http://host/path/./a/b/../c -> http://host/path/a/c - - // Unsafe normalizations - FlagRemoveDirectoryIndex // http://host/path/index.html -> http://host/path/ - FlagRemoveFragment // http://host/path#fragment -> http://host/path - FlagForceHTTP // https://host -> http://host - FlagRemoveDuplicateSlashes // http://host/path//a///b -> http://host/path/a/b - FlagRemoveWWW // http://www.host/ -> http://host/ - FlagAddWWW // http://host/ -> http://www.host/ (should choose only one of these add/remove WWW flags) - FlagSortQuery // http://host/path?c=3&b=2&a=1&b=1 -> http://host/path?a=1&b=1&b=2&c=3 - - // Normalizations not in the wikipedia article, required to cover tests cases - // submitted by jehiah - FlagDecodeDWORDHost // http://1113982867 -> http://66.102.7.147 - FlagDecodeOctalHost // http://0102.0146.07.0223 -> http://66.102.7.147 - FlagDecodeHexHost // http://0x42660793 -> http://66.102.7.147 - FlagRemoveUnnecessaryHostDots // http://.host../path -> http://host/path - FlagRemoveEmptyPortSeparator // http://host:/path -> http://host/path - - // Convenience set of safe normalizations - FlagsSafe NormalizationFlags = FlagLowercaseHost | FlagLowercaseScheme | FlagUppercaseEscapes | FlagDecodeUnnecessaryEscapes | FlagEncodeNecessaryEscapes | FlagRemoveDefaultPort | FlagRemoveEmptyQuerySeparator - - // For convenience sets, "greedy" uses the "remove trailing slash" and "remove www. prefix" flags, - // while "non-greedy" uses the "add (or keep) the trailing slash" and "add www. prefix". - - // Convenience set of usually safe normalizations (includes FlagsSafe) - FlagsUsuallySafeGreedy NormalizationFlags = FlagsSafe | FlagRemoveTrailingSlash | FlagRemoveDotSegments - FlagsUsuallySafeNonGreedy NormalizationFlags = FlagsSafe | FlagAddTrailingSlash | FlagRemoveDotSegments - - // Convenience set of unsafe normalizations (includes FlagsUsuallySafe) - FlagsUnsafeGreedy NormalizationFlags = FlagsUsuallySafeGreedy | FlagRemoveDirectoryIndex | FlagRemoveFragment | FlagForceHTTP | FlagRemoveDuplicateSlashes | FlagRemoveWWW | FlagSortQuery - FlagsUnsafeNonGreedy NormalizationFlags = FlagsUsuallySafeNonGreedy | FlagRemoveDirectoryIndex | FlagRemoveFragment | FlagForceHTTP | FlagRemoveDuplicateSlashes | FlagAddWWW | FlagSortQuery - - // Convenience set of all available flags - FlagsAllGreedy = FlagsUnsafeGreedy | FlagDecodeDWORDHost | FlagDecodeOctalHost | FlagDecodeHexHost | FlagRemoveUnnecessaryHostDots | FlagRemoveEmptyPortSeparator - FlagsAllNonGreedy = FlagsUnsafeNonGreedy | FlagDecodeDWORDHost | FlagDecodeOctalHost | FlagDecodeHexHost | FlagRemoveUnnecessaryHostDots | FlagRemoveEmptyPortSeparator -) - -const ( - defaultHttpPort = ":80" - defaultHttpsPort = ":443" -) - -// Regular expressions used by the normalizations -var rxPort = regexp.MustCompile(`(:\d+)/?$`) -var rxDirIndex = regexp.MustCompile(`(^|/)((?:default|index)\.\w{1,4})$`) -var rxDupSlashes = regexp.MustCompile(`/{2,}`) -var rxDWORDHost = regexp.MustCompile(`^(\d+)((?:\.+)?(?:\:\d*)?)$`) -var rxOctalHost = regexp.MustCompile(`^(0\d*)\.(0\d*)\.(0\d*)\.(0\d*)((?:\.+)?(?:\:\d*)?)$`) -var rxHexHost = regexp.MustCompile(`^0x([0-9A-Fa-f]+)((?:\.+)?(?:\:\d*)?)$`) -var rxHostDots = regexp.MustCompile(`^(.+?)(:\d+)?$`) -var rxEmptyPort = regexp.MustCompile(`:+$`) - -// Map of flags to implementation function. -// FlagDecodeUnnecessaryEscapes has no action, since it is done automatically -// by parsing the string as an URL. Same for FlagUppercaseEscapes and FlagRemoveEmptyQuerySeparator. - -// Since maps have undefined traversing order, make a slice of ordered keys -var flagsOrder = []NormalizationFlags{ - FlagLowercaseScheme, - FlagLowercaseHost, - FlagRemoveDefaultPort, - FlagRemoveDirectoryIndex, - FlagRemoveDotSegments, - FlagRemoveFragment, - FlagForceHTTP, // Must be after remove default port (because https=443/http=80) - FlagRemoveDuplicateSlashes, - FlagRemoveWWW, - FlagAddWWW, - FlagSortQuery, - FlagDecodeDWORDHost, - FlagDecodeOctalHost, - FlagDecodeHexHost, - FlagRemoveUnnecessaryHostDots, - FlagRemoveEmptyPortSeparator, - FlagRemoveTrailingSlash, // These two (add/remove trailing slash) must be last - FlagAddTrailingSlash, -} - -// ... and then the map, where order is unimportant -var flags = map[NormalizationFlags]func(*url.URL){ - FlagLowercaseScheme: lowercaseScheme, - FlagLowercaseHost: lowercaseHost, - FlagRemoveDefaultPort: removeDefaultPort, - FlagRemoveDirectoryIndex: removeDirectoryIndex, - FlagRemoveDotSegments: removeDotSegments, - FlagRemoveFragment: removeFragment, - FlagForceHTTP: forceHTTP, - FlagRemoveDuplicateSlashes: removeDuplicateSlashes, - FlagRemoveWWW: removeWWW, - FlagAddWWW: addWWW, - FlagSortQuery: sortQuery, - FlagDecodeDWORDHost: decodeDWORDHost, - FlagDecodeOctalHost: decodeOctalHost, - FlagDecodeHexHost: decodeHexHost, - FlagRemoveUnnecessaryHostDots: removeUnncessaryHostDots, - FlagRemoveEmptyPortSeparator: removeEmptyPortSeparator, - FlagRemoveTrailingSlash: removeTrailingSlash, - FlagAddTrailingSlash: addTrailingSlash, -} - -// MustNormalizeURLString returns the normalized string, and panics if an error occurs. -// It takes an URL string as input, as well as the normalization flags. -func MustNormalizeURLString(u string, f NormalizationFlags) string { - result, e := NormalizeURLString(u, f) - if e != nil { - panic(e) - } - return result -} - -// NormalizeURLString returns the normalized string, or an error if it can't be parsed into an URL object. -// It takes an URL string as input, as well as the normalization flags. -func NormalizeURLString(u string, f NormalizationFlags) (string, error) { - if parsed, e := url.Parse(u); e != nil { - return "", e - } else { - options := make([]precis.Option, 1, 3) - options[0] = precis.IgnoreCase - if f&FlagLowercaseHost == FlagLowercaseHost { - options = append(options, precis.FoldCase()) - } - options = append(options, precis.Norm(norm.NFC)) - profile := precis.NewFreeform(options...) - if parsed.Host, e = idna.ToASCII(profile.NewTransformer().String(parsed.Host)); e != nil { - return "", e - } - return NormalizeURL(parsed, f), nil - } - panic("Unreachable code.") -} - -// NormalizeURL returns the normalized string. -// It takes a parsed URL object as input, as well as the normalization flags. -func NormalizeURL(u *url.URL, f NormalizationFlags) string { - for _, k := range flagsOrder { - if f&k == k { - flags[k](u) - } - } - return urlesc.Escape(u) -} - -func lowercaseScheme(u *url.URL) { - if len(u.Scheme) > 0 { - u.Scheme = strings.ToLower(u.Scheme) - } -} - -func lowercaseHost(u *url.URL) { - if len(u.Host) > 0 { - u.Host = strings.ToLower(u.Host) - } -} - -func removeDefaultPort(u *url.URL) { - if len(u.Host) > 0 { - scheme := strings.ToLower(u.Scheme) - u.Host = rxPort.ReplaceAllStringFunc(u.Host, func(val string) string { - if (scheme == "http" && val == defaultHttpPort) || (scheme == "https" && val == defaultHttpsPort) { - return "" - } - return val - }) - } -} - -func removeTrailingSlash(u *url.URL) { - if l := len(u.Path); l > 0 { - if strings.HasSuffix(u.Path, "/") { - u.Path = u.Path[:l-1] - } - } else if l = len(u.Host); l > 0 { - if strings.HasSuffix(u.Host, "/") { - u.Host = u.Host[:l-1] - } - } -} - -func addTrailingSlash(u *url.URL) { - if l := len(u.Path); l > 0 { - if !strings.HasSuffix(u.Path, "/") { - u.Path += "/" - } - } else if l = len(u.Host); l > 0 { - if !strings.HasSuffix(u.Host, "/") { - u.Host += "/" - } - } -} - -func removeDotSegments(u *url.URL) { - if len(u.Path) > 0 { - var dotFree []string - var lastIsDot bool - - sections := strings.Split(u.Path, "/") - for _, s := range sections { - if s == ".." { - if len(dotFree) > 0 { - dotFree = dotFree[:len(dotFree)-1] - } - } else if s != "." { - dotFree = append(dotFree, s) - } - lastIsDot = (s == "." || s == "..") - } - // Special case if host does not end with / and new path does not begin with / - u.Path = strings.Join(dotFree, "/") - if u.Host != "" && !strings.HasSuffix(u.Host, "/") && !strings.HasPrefix(u.Path, "/") { - u.Path = "/" + u.Path - } - // Special case if the last segment was a dot, make sure the path ends with a slash - if lastIsDot && !strings.HasSuffix(u.Path, "/") { - u.Path += "/" - } - } -} - -func removeDirectoryIndex(u *url.URL) { - if len(u.Path) > 0 { - u.Path = rxDirIndex.ReplaceAllString(u.Path, "$1") - } -} - -func removeFragment(u *url.URL) { - u.Fragment = "" -} - -func forceHTTP(u *url.URL) { - if strings.ToLower(u.Scheme) == "https" { - u.Scheme = "http" - } -} - -func removeDuplicateSlashes(u *url.URL) { - if len(u.Path) > 0 { - u.Path = rxDupSlashes.ReplaceAllString(u.Path, "/") - } -} - -func removeWWW(u *url.URL) { - if len(u.Host) > 0 && strings.HasPrefix(strings.ToLower(u.Host), "www.") { - u.Host = u.Host[4:] - } -} - -func addWWW(u *url.URL) { - if len(u.Host) > 0 && !strings.HasPrefix(strings.ToLower(u.Host), "www.") { - u.Host = "www." + u.Host - } -} - -func sortQuery(u *url.URL) { - q := u.Query() - - if len(q) > 0 { - arKeys := make([]string, len(q)) - i := 0 - for k, _ := range q { - arKeys[i] = k - i++ - } - sort.Strings(arKeys) - buf := new(bytes.Buffer) - for _, k := range arKeys { - sort.Strings(q[k]) - for _, v := range q[k] { - if buf.Len() > 0 { - buf.WriteRune('&') - } - buf.WriteString(fmt.Sprintf("%s=%s", k, urlesc.QueryEscape(v))) - } - } - - // Rebuild the raw query string - u.RawQuery = buf.String() - } -} - -func decodeDWORDHost(u *url.URL) { - if len(u.Host) > 0 { - if matches := rxDWORDHost.FindStringSubmatch(u.Host); len(matches) > 2 { - var parts [4]int64 - - dword, _ := strconv.ParseInt(matches[1], 10, 0) - for i, shift := range []uint{24, 16, 8, 0} { - parts[i] = dword >> shift & 0xFF - } - u.Host = fmt.Sprintf("%d.%d.%d.%d%s", parts[0], parts[1], parts[2], parts[3], matches[2]) - } - } -} - -func decodeOctalHost(u *url.URL) { - if len(u.Host) > 0 { - if matches := rxOctalHost.FindStringSubmatch(u.Host); len(matches) > 5 { - var parts [4]int64 - - for i := 1; i <= 4; i++ { - parts[i-1], _ = strconv.ParseInt(matches[i], 8, 0) - } - u.Host = fmt.Sprintf("%d.%d.%d.%d%s", parts[0], parts[1], parts[2], parts[3], matches[5]) - } - } -} - -func decodeHexHost(u *url.URL) { - if len(u.Host) > 0 { - if matches := rxHexHost.FindStringSubmatch(u.Host); len(matches) > 2 { - // Conversion is safe because of regex validation - parsed, _ := strconv.ParseInt(matches[1], 16, 0) - // Set host as DWORD (base 10) encoded host - u.Host = fmt.Sprintf("%d%s", parsed, matches[2]) - // The rest is the same as decoding a DWORD host - decodeDWORDHost(u) - } - } -} - -func removeUnncessaryHostDots(u *url.URL) { - if len(u.Host) > 0 { - if matches := rxHostDots.FindStringSubmatch(u.Host); len(matches) > 1 { - // Trim the leading and trailing dots - u.Host = strings.Trim(matches[1], ".") - if len(matches) > 2 { - u.Host += matches[2] - } - } - } -} - -func removeEmptyPortSeparator(u *url.URL) { - if len(u.Host) > 0 { - u.Host = rxEmptyPort.ReplaceAllString(u.Host, "") - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/.travis.yml b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/.travis.yml deleted file mode 100644 index 478630e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/.travis.yml +++ /dev/null @@ -1,11 +0,0 @@ -language: go - -go: - - 1.4 - - tip - -install: - - go build . - -script: - - go test -v diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/LICENSE deleted file mode 100644 index 7448756..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/LICENSE +++ /dev/null @@ -1,27 +0,0 @@ -Copyright (c) 2012 The Go Authors. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/README.md deleted file mode 100644 index bebe305..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/README.md +++ /dev/null @@ -1,16 +0,0 @@ -urlesc [![Build Status](https://travis-ci.org/PuerkitoBio/urlesc.png?branch=master)](https://travis-ci.org/PuerkitoBio/urlesc) [![GoDoc](http://godoc.org/github.com/PuerkitoBio/urlesc?status.svg)](http://godoc.org/github.com/PuerkitoBio/urlesc) -====== - -Package urlesc implements query escaping as per RFC 3986. - -It contains some parts of the net/url package, modified so as to allow -some reserved characters incorrectly escaped by net/url (see [issue 5684](https://github.com/golang/go/issues/5684)). - -## Install - - go get github.com/PuerkitoBio/urlesc - -## License - -Go license (BSD-3-Clause) - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/urlesc.go b/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/urlesc.go deleted file mode 100644 index 1b84624..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/PuerkitoBio/urlesc/urlesc.go +++ /dev/null @@ -1,180 +0,0 @@ -// Copyright 2009 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package urlesc implements query escaping as per RFC 3986. -// It contains some parts of the net/url package, modified so as to allow -// some reserved characters incorrectly escaped by net/url. -// See https://github.com/golang/go/issues/5684 -package urlesc - -import ( - "bytes" - "net/url" - "strings" -) - -type encoding int - -const ( - encodePath encoding = 1 + iota - encodeUserPassword - encodeQueryComponent - encodeFragment -) - -// Return true if the specified character should be escaped when -// appearing in a URL string, according to RFC 3986. -func shouldEscape(c byte, mode encoding) bool { - // §2.3 Unreserved characters (alphanum) - if 'A' <= c && c <= 'Z' || 'a' <= c && c <= 'z' || '0' <= c && c <= '9' { - return false - } - - switch c { - case '-', '.', '_', '~': // §2.3 Unreserved characters (mark) - return false - - // §2.2 Reserved characters (reserved) - case ':', '/', '?', '#', '[', ']', '@', // gen-delims - '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '=': // sub-delims - // Different sections of the URL allow a few of - // the reserved characters to appear unescaped. - switch mode { - case encodePath: // §3.3 - // The RFC allows sub-delims and : @. - // '/', '[' and ']' can be used to assign meaning to individual path - // segments. This package only manipulates the path as a whole, - // so we allow those as well. That leaves only ? and # to escape. - return c == '?' || c == '#' - - case encodeUserPassword: // §3.2.1 - // The RFC allows : and sub-delims in - // userinfo. The parsing of userinfo treats ':' as special so we must escape - // all the gen-delims. - return c == ':' || c == '/' || c == '?' || c == '#' || c == '[' || c == ']' || c == '@' - - case encodeQueryComponent: // §3.4 - // The RFC allows / and ?. - return c != '/' && c != '?' - - case encodeFragment: // §4.1 - // The RFC text is silent but the grammar allows - // everything, so escape nothing but # - return c == '#' - } - } - - // Everything else must be escaped. - return true -} - -// QueryEscape escapes the string so it can be safely placed -// inside a URL query. -func QueryEscape(s string) string { - return escape(s, encodeQueryComponent) -} - -func escape(s string, mode encoding) string { - spaceCount, hexCount := 0, 0 - for i := 0; i < len(s); i++ { - c := s[i] - if shouldEscape(c, mode) { - if c == ' ' && mode == encodeQueryComponent { - spaceCount++ - } else { - hexCount++ - } - } - } - - if spaceCount == 0 && hexCount == 0 { - return s - } - - t := make([]byte, len(s)+2*hexCount) - j := 0 - for i := 0; i < len(s); i++ { - switch c := s[i]; { - case c == ' ' && mode == encodeQueryComponent: - t[j] = '+' - j++ - case shouldEscape(c, mode): - t[j] = '%' - t[j+1] = "0123456789ABCDEF"[c>>4] - t[j+2] = "0123456789ABCDEF"[c&15] - j += 3 - default: - t[j] = s[i] - j++ - } - } - return string(t) -} - -var uiReplacer = strings.NewReplacer( - "%21", "!", - "%27", "'", - "%28", "(", - "%29", ")", - "%2A", "*", -) - -// unescapeUserinfo unescapes some characters that need not to be escaped as per RFC3986. -func unescapeUserinfo(s string) string { - return uiReplacer.Replace(s) -} - -// Escape reassembles the URL into a valid URL string. -// The general form of the result is one of: -// -// scheme:opaque -// scheme://userinfo@host/path?query#fragment -// -// If u.Opaque is non-empty, String uses the first form; -// otherwise it uses the second form. -// -// In the second form, the following rules apply: -// - if u.Scheme is empty, scheme: is omitted. -// - if u.User is nil, userinfo@ is omitted. -// - if u.Host is empty, host/ is omitted. -// - if u.Scheme and u.Host are empty and u.User is nil, -// the entire scheme://userinfo@host/ is omitted. -// - if u.Host is non-empty and u.Path begins with a /, -// the form host/path does not add its own /. -// - if u.RawQuery is empty, ?query is omitted. -// - if u.Fragment is empty, #fragment is omitted. -func Escape(u *url.URL) string { - var buf bytes.Buffer - if u.Scheme != "" { - buf.WriteString(u.Scheme) - buf.WriteByte(':') - } - if u.Opaque != "" { - buf.WriteString(u.Opaque) - } else { - if u.Scheme != "" || u.Host != "" || u.User != nil { - buf.WriteString("//") - if ui := u.User; ui != nil { - buf.WriteString(unescapeUserinfo(ui.String())) - buf.WriteByte('@') - } - if h := u.Host; h != "" { - buf.WriteString(h) - } - } - if u.Path != "" && u.Path[0] != '/' && u.Host != "" { - buf.WriteByte('/') - } - buf.WriteString(escape(u.Path, encodePath)) - } - if u.RawQuery != "" { - buf.WriteByte('?') - buf.WriteString(u.RawQuery) - } - if u.Fragment != "" { - buf.WriteByte('#') - buf.WriteString(escape(u.Fragment, encodeFragment)) - } - return buf.String() -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/LICENSE deleted file mode 100644 index 5ba5c86..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/LICENSE +++ /dev/null @@ -1,22 +0,0 @@ -The MIT License - -Copyright (c) 2014 Benedikt Lang - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/README.md deleted file mode 100644 index 5171c5c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/README.md +++ /dev/null @@ -1,142 +0,0 @@ -semver for golang [![Build Status](https://drone.io/github.com/blang/semver/status.png)](https://drone.io/github.com/blang/semver/latest) [![GoDoc](https://godoc.org/github.com/blang/semver?status.png)](https://godoc.org/github.com/blang/semver) [![Coverage Status](https://img.shields.io/coveralls/blang/semver.svg)](https://coveralls.io/r/blang/semver?branch=master) -====== - -semver is a [Semantic Versioning](http://semver.org/) library written in golang. It fully covers spec version `2.0.0`. - -Usage ------ -```bash -$ go get github.com/blang/semver -``` -Note: Always vendor your dependencies or fix on a specific version tag. - -```go -import github.com/blang/semver -v1, err := semver.Make("1.0.0-beta") -v2, err := semver.Make("2.0.0-beta") -v1.Compare(v2) -``` - -Also check the [GoDocs](http://godoc.org/github.com/blang/semver). - -Why should I use this lib? ------ - -- Fully spec compatible -- No reflection -- No regex -- Fully tested (Coverage >99%) -- Readable parsing/validation errors -- Fast (See [Benchmarks](#benchmarks)) -- Only Stdlib -- Uses values instead of pointers -- Many features, see below - - -Features ------ - -- Parsing and validation at all levels -- Comparator-like comparisons -- Compare Helper Methods -- InPlace manipulation -- Sortable (implements sort.Interface) -- database/sql compatible (sql.Scanner/Valuer) -- encoding/json compatible (json.Marshaler/Unmarshaler) - - -Example ------ - -Have a look at full examples in [examples/main.go](examples/main.go) - -```go -import github.com/blang/semver - -v, err := semver.Make("0.0.1-alpha.preview+123.github") -fmt.Printf("Major: %d\n", v.Major) -fmt.Printf("Minor: %d\n", v.Minor) -fmt.Printf("Patch: %d\n", v.Patch) -fmt.Printf("Pre: %s\n", v.Pre) -fmt.Printf("Build: %s\n", v.Build) - -// Prerelease versions array -if len(v.Pre) > 0 { - fmt.Println("Prerelease versions:") - for i, pre := range v.Pre { - fmt.Printf("%d: %q\n", i, pre) - } -} - -// Build meta data array -if len(v.Build) > 0 { - fmt.Println("Build meta data:") - for i, build := range v.Build { - fmt.Printf("%d: %q\n", i, build) - } -} - -v001, err := semver.Make("0.0.1") -// Compare using helpers: v.GT(v2), v.LT, v.GTE, v.LTE -v001.GT(v) == true -v.LT(v001) == true -v.GTE(v) == true -v.LTE(v) == true - -// Or use v.Compare(v2) for comparisons (-1, 0, 1): -v001.Compare(v) == 1 -v.Compare(v001) == -1 -v.Compare(v) == 0 - -// Manipulate Version in place: -v.Pre[0], err = semver.NewPRVersion("beta") -if err != nil { - fmt.Printf("Error parsing pre release version: %q", err) -} - -fmt.Println("\nValidate versions:") -v.Build[0] = "?" - -err = v.Validate() -if err != nil { - fmt.Printf("Validation failed: %s\n", err) -} -``` - -Benchmarks ------ - - BenchmarkParseSimple 5000000 328 ns/op 49 B/op 1 allocs/op - BenchmarkParseComplex 1000000 2105 ns/op 263 B/op 7 allocs/op - BenchmarkParseAverage 1000000 1301 ns/op 168 B/op 4 allocs/op - BenchmarkStringSimple 10000000 130 ns/op 5 B/op 1 allocs/op - BenchmarkStringLarger 5000000 280 ns/op 32 B/op 2 allocs/op - BenchmarkStringComplex 3000000 512 ns/op 80 B/op 3 allocs/op - BenchmarkStringAverage 5000000 387 ns/op 47 B/op 2 allocs/op - BenchmarkValidateSimple 500000000 7.92 ns/op 0 B/op 0 allocs/op - BenchmarkValidateComplex 2000000 923 ns/op 0 B/op 0 allocs/op - BenchmarkValidateAverage 5000000 452 ns/op 0 B/op 0 allocs/op - BenchmarkCompareSimple 100000000 11.2 ns/op 0 B/op 0 allocs/op - BenchmarkCompareComplex 50000000 40.9 ns/op 0 B/op 0 allocs/op - BenchmarkCompareAverage 50000000 43.8 ns/op 0 B/op 0 allocs/op - BenchmarkSort 5000000 436 ns/op 259 B/op 2 allocs/op - -See benchmark cases at [semver_test.go](semver_test.go) - - -Motivation ------ - -I simply couldn't find any lib supporting the full spec. Others were just wrong or used reflection and regex which i don't like. - - -Contribution ------ - -Feel free to make a pull request. For bigger changes create a issue first to discuss about it. - - -License ------ - -See [LICENSE](LICENSE) file. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/json.go b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/json.go deleted file mode 100644 index a74bf7c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/json.go +++ /dev/null @@ -1,23 +0,0 @@ -package semver - -import ( - "encoding/json" -) - -// MarshalJSON implements the encoding/json.Marshaler interface. -func (v Version) MarshalJSON() ([]byte, error) { - return json.Marshal(v.String()) -} - -// UnmarshalJSON implements the encoding/json.Unmarshaler interface. -func (v *Version) UnmarshalJSON(data []byte) (err error) { - var versionString string - - if err = json.Unmarshal(data, &versionString); err != nil { - return - } - - *v, err = Parse(versionString) - - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/semver.go b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/semver.go deleted file mode 100644 index bbf85ce..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/semver.go +++ /dev/null @@ -1,395 +0,0 @@ -package semver - -import ( - "errors" - "fmt" - "strconv" - "strings" -) - -const ( - numbers string = "0123456789" - alphas = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-" - alphanum = alphas + numbers -) - -// SpecVersion is the latest fully supported spec version of semver -var SpecVersion = Version{ - Major: 2, - Minor: 0, - Patch: 0, -} - -// Version represents a semver compatible version -type Version struct { - Major uint64 - Minor uint64 - Patch uint64 - Pre []PRVersion - Build []string //No Precendence -} - -// Version to string -func (v Version) String() string { - b := make([]byte, 0, 5) - b = strconv.AppendUint(b, v.Major, 10) - b = append(b, '.') - b = strconv.AppendUint(b, v.Minor, 10) - b = append(b, '.') - b = strconv.AppendUint(b, v.Patch, 10) - - if len(v.Pre) > 0 { - b = append(b, '-') - b = append(b, v.Pre[0].String()...) - - for _, pre := range v.Pre[1:] { - b = append(b, '.') - b = append(b, pre.String()...) - } - } - - if len(v.Build) > 0 { - b = append(b, '+') - b = append(b, v.Build[0]...) - - for _, build := range v.Build[1:] { - b = append(b, '.') - b = append(b, build...) - } - } - - return string(b) -} - -// Equals checks if v is equal to o. -func (v Version) Equals(o Version) bool { - return (v.Compare(o) == 0) -} - -// EQ checks if v is equal to o. -func (v Version) EQ(o Version) bool { - return (v.Compare(o) == 0) -} - -// NE checks if v is not equal to o. -func (v Version) NE(o Version) bool { - return (v.Compare(o) != 0) -} - -// GT checks if v is greater than o. -func (v Version) GT(o Version) bool { - return (v.Compare(o) == 1) -} - -// GTE checks if v is greater than or equal to o. -func (v Version) GTE(o Version) bool { - return (v.Compare(o) >= 0) -} - -// GE checks if v is greater than or equal to o. -func (v Version) GE(o Version) bool { - return (v.Compare(o) >= 0) -} - -// LT checks if v is less than o. -func (v Version) LT(o Version) bool { - return (v.Compare(o) == -1) -} - -// LTE checks if v is less than or equal to o. -func (v Version) LTE(o Version) bool { - return (v.Compare(o) <= 0) -} - -// LE checks if v is less than or equal to o. -func (v Version) LE(o Version) bool { - return (v.Compare(o) <= 0) -} - -// Compare compares Versions v to o: -// -1 == v is less than o -// 0 == v is equal to o -// 1 == v is greater than o -func (v Version) Compare(o Version) int { - if v.Major != o.Major { - if v.Major > o.Major { - return 1 - } - return -1 - } - if v.Minor != o.Minor { - if v.Minor > o.Minor { - return 1 - } - return -1 - } - if v.Patch != o.Patch { - if v.Patch > o.Patch { - return 1 - } - return -1 - } - - // Quick comparison if a version has no prerelease versions - if len(v.Pre) == 0 && len(o.Pre) == 0 { - return 0 - } else if len(v.Pre) == 0 && len(o.Pre) > 0 { - return 1 - } else if len(v.Pre) > 0 && len(o.Pre) == 0 { - return -1 - } - - i := 0 - for ; i < len(v.Pre) && i < len(o.Pre); i++ { - if comp := v.Pre[i].Compare(o.Pre[i]); comp == 0 { - continue - } else if comp == 1 { - return 1 - } else { - return -1 - } - } - - // If all pr versions are the equal but one has further prversion, this one greater - if i == len(v.Pre) && i == len(o.Pre) { - return 0 - } else if i == len(v.Pre) && i < len(o.Pre) { - return -1 - } else { - return 1 - } - -} - -// Validate validates v and returns error in case -func (v Version) Validate() error { - // Major, Minor, Patch already validated using uint64 - - for _, pre := range v.Pre { - if !pre.IsNum { //Numeric prerelease versions already uint64 - if len(pre.VersionStr) == 0 { - return fmt.Errorf("Prerelease can not be empty %q", pre.VersionStr) - } - if !containsOnly(pre.VersionStr, alphanum) { - return fmt.Errorf("Invalid character(s) found in prerelease %q", pre.VersionStr) - } - } - } - - for _, build := range v.Build { - if len(build) == 0 { - return fmt.Errorf("Build meta data can not be empty %q", build) - } - if !containsOnly(build, alphanum) { - return fmt.Errorf("Invalid character(s) found in build meta data %q", build) - } - } - - return nil -} - -// New is an alias for Parse and returns a pointer, parses version string and returns a validated Version or error -func New(s string) (vp *Version, err error) { - v, err := Parse(s) - vp = &v - return -} - -// Make is an alias for Parse, parses version string and returns a validated Version or error -func Make(s string) (Version, error) { - return Parse(s) -} - -// Parse parses version string and returns a validated Version or error -func Parse(s string) (Version, error) { - if len(s) == 0 { - return Version{}, errors.New("Version string empty") - } - - // Split into major.minor.(patch+pr+meta) - parts := strings.SplitN(s, ".", 3) - if len(parts) != 3 { - return Version{}, errors.New("No Major.Minor.Patch elements found") - } - - // Major - if !containsOnly(parts[0], numbers) { - return Version{}, fmt.Errorf("Invalid character(s) found in major number %q", parts[0]) - } - if hasLeadingZeroes(parts[0]) { - return Version{}, fmt.Errorf("Major number must not contain leading zeroes %q", parts[0]) - } - major, err := strconv.ParseUint(parts[0], 10, 64) - if err != nil { - return Version{}, err - } - - // Minor - if !containsOnly(parts[1], numbers) { - return Version{}, fmt.Errorf("Invalid character(s) found in minor number %q", parts[1]) - } - if hasLeadingZeroes(parts[1]) { - return Version{}, fmt.Errorf("Minor number must not contain leading zeroes %q", parts[1]) - } - minor, err := strconv.ParseUint(parts[1], 10, 64) - if err != nil { - return Version{}, err - } - - v := Version{} - v.Major = major - v.Minor = minor - - var build, prerelease []string - patchStr := parts[2] - - if buildIndex := strings.IndexRune(patchStr, '+'); buildIndex != -1 { - build = strings.Split(patchStr[buildIndex+1:], ".") - patchStr = patchStr[:buildIndex] - } - - if preIndex := strings.IndexRune(patchStr, '-'); preIndex != -1 { - prerelease = strings.Split(patchStr[preIndex+1:], ".") - patchStr = patchStr[:preIndex] - } - - if !containsOnly(patchStr, numbers) { - return Version{}, fmt.Errorf("Invalid character(s) found in patch number %q", patchStr) - } - if hasLeadingZeroes(patchStr) { - return Version{}, fmt.Errorf("Patch number must not contain leading zeroes %q", patchStr) - } - patch, err := strconv.ParseUint(patchStr, 10, 64) - if err != nil { - return Version{}, err - } - - v.Patch = patch - - // Prerelease - for _, prstr := range prerelease { - parsedPR, err := NewPRVersion(prstr) - if err != nil { - return Version{}, err - } - v.Pre = append(v.Pre, parsedPR) - } - - // Build meta data - for _, str := range build { - if len(str) == 0 { - return Version{}, errors.New("Build meta data is empty") - } - if !containsOnly(str, alphanum) { - return Version{}, fmt.Errorf("Invalid character(s) found in build meta data %q", str) - } - v.Build = append(v.Build, str) - } - - return v, nil -} - -// MustParse is like Parse but panics if the version cannot be parsed. -func MustParse(s string) Version { - v, err := Parse(s) - if err != nil { - panic(`semver: Parse(` + s + `): ` + err.Error()) - } - return v -} - -// PRVersion represents a PreRelease Version -type PRVersion struct { - VersionStr string - VersionNum uint64 - IsNum bool -} - -// NewPRVersion creates a new valid prerelease version -func NewPRVersion(s string) (PRVersion, error) { - if len(s) == 0 { - return PRVersion{}, errors.New("Prerelease is empty") - } - v := PRVersion{} - if containsOnly(s, numbers) { - if hasLeadingZeroes(s) { - return PRVersion{}, fmt.Errorf("Numeric PreRelease version must not contain leading zeroes %q", s) - } - num, err := strconv.ParseUint(s, 10, 64) - - // Might never be hit, but just in case - if err != nil { - return PRVersion{}, err - } - v.VersionNum = num - v.IsNum = true - } else if containsOnly(s, alphanum) { - v.VersionStr = s - v.IsNum = false - } else { - return PRVersion{}, fmt.Errorf("Invalid character(s) found in prerelease %q", s) - } - return v, nil -} - -// IsNumeric checks if prerelease-version is numeric -func (v PRVersion) IsNumeric() bool { - return v.IsNum -} - -// Compare compares two PreRelease Versions v and o: -// -1 == v is less than o -// 0 == v is equal to o -// 1 == v is greater than o -func (v PRVersion) Compare(o PRVersion) int { - if v.IsNum && !o.IsNum { - return -1 - } else if !v.IsNum && o.IsNum { - return 1 - } else if v.IsNum && o.IsNum { - if v.VersionNum == o.VersionNum { - return 0 - } else if v.VersionNum > o.VersionNum { - return 1 - } else { - return -1 - } - } else { // both are Alphas - if v.VersionStr == o.VersionStr { - return 0 - } else if v.VersionStr > o.VersionStr { - return 1 - } else { - return -1 - } - } -} - -// PreRelease version to string -func (v PRVersion) String() string { - if v.IsNum { - return strconv.FormatUint(v.VersionNum, 10) - } - return v.VersionStr -} - -func containsOnly(s string, set string) bool { - return strings.IndexFunc(s, func(r rune) bool { - return !strings.ContainsRune(set, r) - }) == -1 -} - -func hasLeadingZeroes(s string) bool { - return len(s) > 1 && s[0] == '0' -} - -// NewBuildVersion creates a new valid build version -func NewBuildVersion(s string) (string, error) { - if len(s) == 0 { - return "", errors.New("Buildversion is empty") - } - if !containsOnly(s, alphanum) { - return "", fmt.Errorf("Invalid character(s) found in build meta data %q", s) - } - return s, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sort.go b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sort.go deleted file mode 100644 index e18f880..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sort.go +++ /dev/null @@ -1,28 +0,0 @@ -package semver - -import ( - "sort" -) - -// Versions represents multiple versions. -type Versions []Version - -// Len returns length of version collection -func (s Versions) Len() int { - return len(s) -} - -// Swap swaps two versions inside the collection by its indices -func (s Versions) Swap(i, j int) { - s[i], s[j] = s[j], s[i] -} - -// Less checks if version at index i is less than version at index j -func (s Versions) Less(i, j int) bool { - return s[i].LT(s[j]) -} - -// Sort sorts a slice of versions -func Sort(versions []Version) { - sort.Sort(Versions(versions)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sql.go b/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sql.go deleted file mode 100644 index eb4d802..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/blang/semver/sql.go +++ /dev/null @@ -1,30 +0,0 @@ -package semver - -import ( - "database/sql/driver" - "fmt" -) - -// Scan implements the database/sql.Scanner interface. -func (v *Version) Scan(src interface{}) (err error) { - var str string - switch src := src.(type) { - case string: - str = src - case []byte: - str = string(src) - default: - return fmt.Errorf("Version.Scan: cannot convert %T to string.", src) - } - - if t, err := Parse(str); err == nil { - *v = t - } - - return -} - -// Value implements the database/sql/driver.Valuer interface. -func (v Version) Value() (driver.Value, error) { - return v.String(), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/client.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/client.go deleted file mode 100644 index fd079b4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/client.go +++ /dev/null @@ -1,7 +0,0 @@ -package http - -import "net/http" - -type Client interface { - Do(*http.Request) (*http.Response, error) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/http.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/http.go deleted file mode 100644 index c3f5121..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/http.go +++ /dev/null @@ -1,156 +0,0 @@ -package http - -import ( - "encoding/base64" - "encoding/json" - "errors" - "log" - "net/http" - "net/url" - "path" - "strconv" - "strings" - "time" -) - -func WriteError(w http.ResponseWriter, code int, msg string) { - e := struct { - Error string `json:"error"` - }{ - Error: msg, - } - b, err := json.Marshal(e) - if err != nil { - log.Printf("go-oidc: failed to marshal %#v: %v", e, err) - code = http.StatusInternalServerError - b = []byte(`{"error":"server_error"}`) - } - w.Header().Set("Content-Type", "application/json") - w.WriteHeader(code) - w.Write(b) -} - -// BasicAuth parses a username and password from the request's -// Authorization header. This was pulled from golang master: -// https://codereview.appspot.com/76540043 -func BasicAuth(r *http.Request) (username, password string, ok bool) { - auth := r.Header.Get("Authorization") - if auth == "" { - return - } - - if !strings.HasPrefix(auth, "Basic ") { - return - } - c, err := base64.StdEncoding.DecodeString(strings.TrimPrefix(auth, "Basic ")) - if err != nil { - return - } - cs := string(c) - s := strings.IndexByte(cs, ':') - if s < 0 { - return - } - return cs[:s], cs[s+1:], true -} - -func cacheControlMaxAge(hdr string) (time.Duration, bool, error) { - for _, field := range strings.Split(hdr, ",") { - parts := strings.SplitN(strings.TrimSpace(field), "=", 2) - k := strings.ToLower(strings.TrimSpace(parts[0])) - if k != "max-age" { - continue - } - - if len(parts) == 1 { - return 0, false, errors.New("max-age has no value") - } - - v := strings.TrimSpace(parts[1]) - if v == "" { - return 0, false, errors.New("max-age has empty value") - } - - age, err := strconv.Atoi(v) - if err != nil { - return 0, false, err - } - - if age <= 0 { - return 0, false, nil - } - - return time.Duration(age) * time.Second, true, nil - } - - return 0, false, nil -} - -func expires(date, expires string) (time.Duration, bool, error) { - if date == "" || expires == "" { - return 0, false, nil - } - - te, err := time.Parse(time.RFC1123, expires) - if err != nil { - return 0, false, err - } - - td, err := time.Parse(time.RFC1123, date) - if err != nil { - return 0, false, err - } - - ttl := te.Sub(td) - - // headers indicate data already expired, caller should not - // have to care about this case - if ttl <= 0 { - return 0, false, nil - } - - return ttl, true, nil -} - -func Cacheable(hdr http.Header) (time.Duration, bool, error) { - ttl, ok, err := cacheControlMaxAge(hdr.Get("Cache-Control")) - if err != nil || ok { - return ttl, ok, err - } - - return expires(hdr.Get("Date"), hdr.Get("Expires")) -} - -// MergeQuery appends additional query values to an existing URL. -func MergeQuery(u url.URL, q url.Values) url.URL { - uv := u.Query() - for k, vs := range q { - for _, v := range vs { - uv.Add(k, v) - } - } - u.RawQuery = uv.Encode() - return u -} - -// NewResourceLocation appends a resource id to the end of the requested URL path. -func NewResourceLocation(reqURL *url.URL, id string) string { - var u url.URL - u = *reqURL - u.Path = path.Join(u.Path, id) - u.RawQuery = "" - u.Fragment = "" - return u.String() -} - -// CopyRequest returns a clone of the provided *http.Request. -// The returned object is a shallow copy of the struct and a -// deep copy of its Header field. -func CopyRequest(r *http.Request) *http.Request { - r2 := *r - r2.Header = make(http.Header) - for k, s := range r.Header { - r2.Header[k] = s - } - return &r2 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/url.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/url.go deleted file mode 100644 index df60eb1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/http/url.go +++ /dev/null @@ -1,29 +0,0 @@ -package http - -import ( - "errors" - "net/url" -) - -// ParseNonEmptyURL checks that a string is a parsable URL which is also not empty -// since `url.Parse("")` does not return an error. Must contian a scheme and a host. -func ParseNonEmptyURL(u string) (*url.URL, error) { - if u == "" { - return nil, errors.New("url is empty") - } - - ur, err := url.Parse(u) - if err != nil { - return nil, err - } - - if ur.Scheme == "" { - return nil, errors.New("url scheme is empty") - } - - if ur.Host == "" { - return nil, errors.New("url host is empty") - } - - return ur, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/claims.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/claims.go deleted file mode 100644 index 8b48bfd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/claims.go +++ /dev/null @@ -1,126 +0,0 @@ -package jose - -import ( - "encoding/json" - "fmt" - "math" - "time" -) - -type Claims map[string]interface{} - -func (c Claims) Add(name string, value interface{}) { - c[name] = value -} - -func (c Claims) StringClaim(name string) (string, bool, error) { - cl, ok := c[name] - if !ok { - return "", false, nil - } - - v, ok := cl.(string) - if !ok { - return "", false, fmt.Errorf("unable to parse claim as string: %v", name) - } - - return v, true, nil -} - -func (c Claims) StringsClaim(name string) ([]string, bool, error) { - cl, ok := c[name] - if !ok { - return nil, false, nil - } - - if v, ok := cl.([]string); ok { - return v, true, nil - } - - // When unmarshaled, []string will become []interface{}. - if v, ok := cl.([]interface{}); ok { - var ret []string - for _, vv := range v { - str, ok := vv.(string) - if !ok { - return nil, false, fmt.Errorf("unable to parse claim as string array: %v", name) - } - ret = append(ret, str) - } - return ret, true, nil - } - - return nil, false, fmt.Errorf("unable to parse claim as string array: %v", name) -} - -func (c Claims) Int64Claim(name string) (int64, bool, error) { - cl, ok := c[name] - if !ok { - return 0, false, nil - } - - v, ok := cl.(int64) - if !ok { - vf, ok := cl.(float64) - if !ok { - return 0, false, fmt.Errorf("unable to parse claim as int64: %v", name) - } - v = int64(vf) - } - - return v, true, nil -} - -func (c Claims) Float64Claim(name string) (float64, bool, error) { - cl, ok := c[name] - if !ok { - return 0, false, nil - } - - v, ok := cl.(float64) - if !ok { - vi, ok := cl.(int64) - if !ok { - return 0, false, fmt.Errorf("unable to parse claim as float64: %v", name) - } - v = float64(vi) - } - - return v, true, nil -} - -func (c Claims) TimeClaim(name string) (time.Time, bool, error) { - v, ok, err := c.Float64Claim(name) - if !ok || err != nil { - return time.Time{}, ok, err - } - - s := math.Trunc(v) - ns := (v - s) * math.Pow(10, 9) - return time.Unix(int64(s), int64(ns)).UTC(), true, nil -} - -func decodeClaims(payload []byte) (Claims, error) { - var c Claims - if err := json.Unmarshal(payload, &c); err != nil { - return nil, fmt.Errorf("malformed JWT claims, unable to decode: %v", err) - } - return c, nil -} - -func marshalClaims(c Claims) ([]byte, error) { - b, err := json.Marshal(c) - if err != nil { - return nil, err - } - return b, nil -} - -func encodeClaims(c Claims) (string, error) { - b, err := marshalClaims(c) - if err != nil { - return "", err - } - - return encodeSegment(b), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jose.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jose.go deleted file mode 100644 index 6209926..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jose.go +++ /dev/null @@ -1,112 +0,0 @@ -package jose - -import ( - "encoding/base64" - "encoding/json" - "fmt" - "strings" -) - -const ( - HeaderMediaType = "typ" - HeaderKeyAlgorithm = "alg" - HeaderKeyID = "kid" -) - -const ( - // Encryption Algorithm Header Parameter Values for JWS - // See: https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40#page-6 - AlgHS256 = "HS256" - AlgHS384 = "HS384" - AlgHS512 = "HS512" - AlgRS256 = "RS256" - AlgRS384 = "RS384" - AlgRS512 = "RS512" - AlgES256 = "ES256" - AlgES384 = "ES384" - AlgES512 = "ES512" - AlgPS256 = "PS256" - AlgPS384 = "PS384" - AlgPS512 = "PS512" - AlgNone = "none" -) - -const ( - // Algorithm Header Parameter Values for JWE - // See: https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40#section-4.1 - AlgRSA15 = "RSA1_5" - AlgRSAOAEP = "RSA-OAEP" - AlgRSAOAEP256 = "RSA-OAEP-256" - AlgA128KW = "A128KW" - AlgA192KW = "A192KW" - AlgA256KW = "A256KW" - AlgDir = "dir" - AlgECDHES = "ECDH-ES" - AlgECDHESA128KW = "ECDH-ES+A128KW" - AlgECDHESA192KW = "ECDH-ES+A192KW" - AlgECDHESA256KW = "ECDH-ES+A256KW" - AlgA128GCMKW = "A128GCMKW" - AlgA192GCMKW = "A192GCMKW" - AlgA256GCMKW = "A256GCMKW" - AlgPBES2HS256A128KW = "PBES2-HS256+A128KW" - AlgPBES2HS384A192KW = "PBES2-HS384+A192KW" - AlgPBES2HS512A256KW = "PBES2-HS512+A256KW" -) - -const ( - // Encryption Algorithm Header Parameter Values for JWE - // See: https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40#page-22 - EncA128CBCHS256 = "A128CBC-HS256" - EncA128CBCHS384 = "A128CBC-HS384" - EncA256CBCHS512 = "A256CBC-HS512" - EncA128GCM = "A128GCM" - EncA192GCM = "A192GCM" - EncA256GCM = "A256GCM" -) - -type JOSEHeader map[string]string - -func (j JOSEHeader) Validate() error { - if _, exists := j[HeaderKeyAlgorithm]; !exists { - return fmt.Errorf("header missing %q parameter", HeaderKeyAlgorithm) - } - - return nil -} - -func decodeHeader(seg string) (JOSEHeader, error) { - b, err := decodeSegment(seg) - if err != nil { - return nil, err - } - - var h JOSEHeader - err = json.Unmarshal(b, &h) - if err != nil { - return nil, err - } - - return h, nil -} - -func encodeHeader(h JOSEHeader) (string, error) { - b, err := json.Marshal(h) - if err != nil { - return "", err - } - - return encodeSegment(b), nil -} - -// Decode JWT specific base64url encoding with padding stripped -func decodeSegment(seg string) ([]byte, error) { - if l := len(seg) % 4; l != 0 { - seg += strings.Repeat("=", 4-l) - } - return base64.URLEncoding.DecodeString(seg) -} - -// Encode JWT specific base64url encoding with padding stripped -func encodeSegment(seg []byte) string { - return strings.TrimRight(base64.URLEncoding.EncodeToString(seg), "=") -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwk.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwk.go deleted file mode 100644 index b7a8e23..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwk.go +++ /dev/null @@ -1,135 +0,0 @@ -package jose - -import ( - "bytes" - "encoding/base64" - "encoding/binary" - "encoding/json" - "math/big" - "strings" -) - -// JSON Web Key -// https://tools.ietf.org/html/draft-ietf-jose-json-web-key-36#page-5 -type JWK struct { - ID string - Type string - Alg string - Use string - Exponent int - Modulus *big.Int - Secret []byte -} - -type jwkJSON struct { - ID string `json:"kid"` - Type string `json:"kty"` - Alg string `json:"alg"` - Use string `json:"use"` - Exponent string `json:"e"` - Modulus string `json:"n"` -} - -func (j *JWK) MarshalJSON() ([]byte, error) { - t := jwkJSON{ - ID: j.ID, - Type: j.Type, - Alg: j.Alg, - Use: j.Use, - Exponent: encodeExponent(j.Exponent), - Modulus: encodeModulus(j.Modulus), - } - - return json.Marshal(&t) -} - -func (j *JWK) UnmarshalJSON(data []byte) error { - var t jwkJSON - err := json.Unmarshal(data, &t) - if err != nil { - return err - } - - e, err := decodeExponent(t.Exponent) - if err != nil { - return err - } - - n, err := decodeModulus(t.Modulus) - if err != nil { - return err - } - - j.ID = t.ID - j.Type = t.Type - j.Alg = t.Alg - j.Use = t.Use - j.Exponent = e - j.Modulus = n - - return nil -} - -type JWKSet struct { - Keys []JWK `json:"keys"` -} - -func decodeExponent(e string) (int, error) { - decE, err := decodeBase64URLPaddingOptional(e) - if err != nil { - return 0, err - } - var eBytes []byte - if len(decE) < 8 { - eBytes = make([]byte, 8-len(decE), 8) - eBytes = append(eBytes, decE...) - } else { - eBytes = decE - } - eReader := bytes.NewReader(eBytes) - var E uint64 - err = binary.Read(eReader, binary.BigEndian, &E) - if err != nil { - return 0, err - } - return int(E), nil -} - -func encodeExponent(e int) string { - b := make([]byte, 8) - binary.BigEndian.PutUint64(b, uint64(e)) - var idx int - for ; idx < 8; idx++ { - if b[idx] != 0x0 { - break - } - } - return base64.URLEncoding.EncodeToString(b[idx:]) -} - -// Turns a URL encoded modulus of a key into a big int. -func decodeModulus(n string) (*big.Int, error) { - decN, err := decodeBase64URLPaddingOptional(n) - if err != nil { - return nil, err - } - N := big.NewInt(0) - N.SetBytes(decN) - return N, nil -} - -func encodeModulus(n *big.Int) string { - return base64.URLEncoding.EncodeToString(n.Bytes()) -} - -// decodeBase64URLPaddingOptional decodes Base64 whether there is padding or not. -// The stdlib version currently doesn't handle this. -// We can get rid of this is if this bug: -// https://github.com/golang/go/issues/4237 -// ever closes. -func decodeBase64URLPaddingOptional(e string) ([]byte, error) { - if m := len(e) % 4; m != 0 { - e += strings.Repeat("=", 4-m) - } - return base64.URLEncoding.DecodeString(e) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jws.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jws.go deleted file mode 100644 index 1049ece..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jws.go +++ /dev/null @@ -1,51 +0,0 @@ -package jose - -import ( - "fmt" - "strings" -) - -type JWS struct { - RawHeader string - Header JOSEHeader - RawPayload string - Payload []byte - Signature []byte -} - -// Given a raw encoded JWS token parses it and verifies the structure. -func ParseJWS(raw string) (JWS, error) { - parts := strings.Split(raw, ".") - if len(parts) != 3 { - return JWS{}, fmt.Errorf("malformed JWS, only %d segments", len(parts)) - } - - rawSig := parts[2] - jws := JWS{ - RawHeader: parts[0], - RawPayload: parts[1], - } - - header, err := decodeHeader(jws.RawHeader) - if err != nil { - return JWS{}, fmt.Errorf("malformed JWS, unable to decode header, %s", err) - } - if err = header.Validate(); err != nil { - return JWS{}, fmt.Errorf("malformed JWS, %s", err) - } - jws.Header = header - - payload, err := decodeSegment(jws.RawPayload) - if err != nil { - return JWS{}, fmt.Errorf("malformed JWS, unable to decode payload: %s", err) - } - jws.Payload = payload - - sig, err := decodeSegment(rawSig) - if err != nil { - return JWS{}, fmt.Errorf("malformed JWS, unable to decode signature: %s", err) - } - jws.Signature = sig - - return jws, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwt.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwt.go deleted file mode 100644 index 3b3e963..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/jwt.go +++ /dev/null @@ -1,82 +0,0 @@ -package jose - -import "strings" - -type JWT JWS - -func ParseJWT(token string) (jwt JWT, err error) { - jws, err := ParseJWS(token) - if err != nil { - return - } - - return JWT(jws), nil -} - -func NewJWT(header JOSEHeader, claims Claims) (jwt JWT, err error) { - jwt = JWT{} - - jwt.Header = header - jwt.Header[HeaderMediaType] = "JWT" - - claimBytes, err := marshalClaims(claims) - if err != nil { - return - } - jwt.Payload = claimBytes - - eh, err := encodeHeader(header) - if err != nil { - return - } - jwt.RawHeader = eh - - ec, err := encodeClaims(claims) - if err != nil { - return - } - jwt.RawPayload = ec - - return -} - -func (j *JWT) KeyID() (string, bool) { - kID, ok := j.Header[HeaderKeyID] - return kID, ok -} - -func (j *JWT) Claims() (Claims, error) { - return decodeClaims(j.Payload) -} - -// Encoded data part of the token which may be signed. -func (j *JWT) Data() string { - return strings.Join([]string{j.RawHeader, j.RawPayload}, ".") -} - -// Full encoded JWT token string in format: header.claims.signature -func (j *JWT) Encode() string { - d := j.Data() - s := encodeSegment(j.Signature) - return strings.Join([]string{d, s}, ".") -} - -func NewSignedJWT(claims Claims, s Signer) (*JWT, error) { - header := JOSEHeader{ - HeaderKeyAlgorithm: s.Alg(), - HeaderKeyID: s.ID(), - } - - jwt, err := NewJWT(header, claims) - if err != nil { - return nil, err - } - - sig, err := s.Sign([]byte(jwt.Data())) - if err != nil { - return nil, err - } - jwt.Signature = sig - - return &jwt, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig.go deleted file mode 100755 index 7b2b253..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig.go +++ /dev/null @@ -1,24 +0,0 @@ -package jose - -import ( - "fmt" -) - -type Verifier interface { - ID() string - Alg() string - Verify(sig []byte, data []byte) error -} - -type Signer interface { - Verifier - Sign(data []byte) (sig []byte, err error) -} - -func NewVerifier(jwk JWK) (Verifier, error) { - if jwk.Type != "RSA" { - return nil, fmt.Errorf("unsupported key type %q", jwk.Type) - } - - return NewVerifierRSA(jwk) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_rsa.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_rsa.go deleted file mode 100755 index 004e45d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/jose/sig_rsa.go +++ /dev/null @@ -1,67 +0,0 @@ -package jose - -import ( - "crypto" - "crypto/rand" - "crypto/rsa" - "fmt" -) - -type VerifierRSA struct { - KeyID string - Hash crypto.Hash - PublicKey rsa.PublicKey -} - -type SignerRSA struct { - PrivateKey rsa.PrivateKey - VerifierRSA -} - -func NewVerifierRSA(jwk JWK) (*VerifierRSA, error) { - if jwk.Alg != "" && jwk.Alg != "RS256" { - return nil, fmt.Errorf("unsupported key algorithm %q", jwk.Alg) - } - - v := VerifierRSA{ - KeyID: jwk.ID, - PublicKey: rsa.PublicKey{ - N: jwk.Modulus, - E: jwk.Exponent, - }, - Hash: crypto.SHA256, - } - - return &v, nil -} - -func NewSignerRSA(kid string, key rsa.PrivateKey) *SignerRSA { - return &SignerRSA{ - PrivateKey: key, - VerifierRSA: VerifierRSA{ - KeyID: kid, - PublicKey: key.PublicKey, - Hash: crypto.SHA256, - }, - } -} - -func (v *VerifierRSA) ID() string { - return v.KeyID -} - -func (v *VerifierRSA) Alg() string { - return "RS256" -} - -func (v *VerifierRSA) Verify(sig []byte, data []byte) error { - h := v.Hash.New() - h.Write(data) - return rsa.VerifyPKCS1v15(&v.PublicKey, v.Hash, h.Sum(nil), sig) -} - -func (s *SignerRSA) Sign(data []byte) ([]byte, error) { - h := s.Hash.New() - h.Write(data) - return rsa.SignPKCS1v15(rand.Reader, &s.PrivateKey, s.Hash, h.Sum(nil)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/key.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/key.go deleted file mode 100644 index 208c1fc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/key.go +++ /dev/null @@ -1,153 +0,0 @@ -package key - -import ( - "crypto/rand" - "crypto/rsa" - "encoding/hex" - "encoding/json" - "io" - "time" - - "github.com/coreos/go-oidc/jose" -) - -func NewPublicKey(jwk jose.JWK) *PublicKey { - return &PublicKey{jwk: jwk} -} - -type PublicKey struct { - jwk jose.JWK -} - -func (k *PublicKey) MarshalJSON() ([]byte, error) { - return json.Marshal(&k.jwk) -} - -func (k *PublicKey) UnmarshalJSON(data []byte) error { - var jwk jose.JWK - if err := json.Unmarshal(data, &jwk); err != nil { - return err - } - k.jwk = jwk - return nil -} - -func (k *PublicKey) ID() string { - return k.jwk.ID -} - -func (k *PublicKey) Verifier() (jose.Verifier, error) { - return jose.NewVerifierRSA(k.jwk) -} - -type PrivateKey struct { - KeyID string - PrivateKey *rsa.PrivateKey -} - -func (k *PrivateKey) ID() string { - return k.KeyID -} - -func (k *PrivateKey) Signer() jose.Signer { - return jose.NewSignerRSA(k.ID(), *k.PrivateKey) -} - -func (k *PrivateKey) JWK() jose.JWK { - return jose.JWK{ - ID: k.KeyID, - Type: "RSA", - Alg: "RS256", - Use: "sig", - Exponent: k.PrivateKey.PublicKey.E, - Modulus: k.PrivateKey.PublicKey.N, - } -} - -type KeySet interface { - ExpiresAt() time.Time -} - -type PublicKeySet struct { - keys []PublicKey - index map[string]*PublicKey - expiresAt time.Time -} - -func NewPublicKeySet(jwks []jose.JWK, exp time.Time) *PublicKeySet { - keys := make([]PublicKey, len(jwks)) - index := make(map[string]*PublicKey) - for i, jwk := range jwks { - keys[i] = *NewPublicKey(jwk) - index[keys[i].ID()] = &keys[i] - } - return &PublicKeySet{ - keys: keys, - index: index, - expiresAt: exp, - } -} - -func (s *PublicKeySet) ExpiresAt() time.Time { - return s.expiresAt -} - -func (s *PublicKeySet) Keys() []PublicKey { - return s.keys -} - -func (s *PublicKeySet) Key(id string) *PublicKey { - return s.index[id] -} - -type PrivateKeySet struct { - keys []*PrivateKey - ActiveKeyID string - expiresAt time.Time -} - -func NewPrivateKeySet(keys []*PrivateKey, exp time.Time) *PrivateKeySet { - return &PrivateKeySet{ - keys: keys, - ActiveKeyID: keys[0].ID(), - expiresAt: exp.UTC(), - } -} - -func (s *PrivateKeySet) Keys() []*PrivateKey { - return s.keys -} - -func (s *PrivateKeySet) ExpiresAt() time.Time { - return s.expiresAt -} - -func (s *PrivateKeySet) Active() *PrivateKey { - for i, k := range s.keys { - if k.ID() == s.ActiveKeyID { - return s.keys[i] - } - } - - return nil -} - -type GeneratePrivateKeyFunc func() (*PrivateKey, error) - -func GeneratePrivateKey() (*PrivateKey, error) { - pk, err := rsa.GenerateKey(rand.Reader, 2048) - if err != nil { - return nil, err - } - keyID := make([]byte, 20) - if _, err := io.ReadFull(rand.Reader, keyID); err != nil { - return nil, err - } - - k := PrivateKey{ - KeyID: hex.EncodeToString(keyID), - PrivateKey: pk, - } - - return &k, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/manager.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/manager.go deleted file mode 100644 index 476ab6a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/manager.go +++ /dev/null @@ -1,99 +0,0 @@ -package key - -import ( - "errors" - "time" - - "github.com/jonboulle/clockwork" - - "github.com/coreos/go-oidc/jose" - "github.com/coreos/pkg/health" -) - -type PrivateKeyManager interface { - ExpiresAt() time.Time - Signer() (jose.Signer, error) - JWKs() ([]jose.JWK, error) - PublicKeys() ([]PublicKey, error) - - WritableKeySetRepo - health.Checkable -} - -func NewPrivateKeyManager() PrivateKeyManager { - return &privateKeyManager{ - clock: clockwork.NewRealClock(), - } -} - -type privateKeyManager struct { - keySet *PrivateKeySet - clock clockwork.Clock -} - -func (m *privateKeyManager) ExpiresAt() time.Time { - if m.keySet == nil { - return m.clock.Now().UTC() - } - - return m.keySet.ExpiresAt() -} - -func (m *privateKeyManager) Signer() (jose.Signer, error) { - if err := m.Healthy(); err != nil { - return nil, err - } - - return m.keySet.Active().Signer(), nil -} - -func (m *privateKeyManager) JWKs() ([]jose.JWK, error) { - if err := m.Healthy(); err != nil { - return nil, err - } - - keys := m.keySet.Keys() - jwks := make([]jose.JWK, len(keys)) - for i, k := range keys { - jwks[i] = k.JWK() - } - return jwks, nil -} - -func (m *privateKeyManager) PublicKeys() ([]PublicKey, error) { - jwks, err := m.JWKs() - if err != nil { - return nil, err - } - keys := make([]PublicKey, len(jwks)) - for i, jwk := range jwks { - keys[i] = *NewPublicKey(jwk) - } - return keys, nil -} - -func (m *privateKeyManager) Healthy() error { - if m.keySet == nil { - return errors.New("private key manager uninitialized") - } - - if len(m.keySet.Keys()) == 0 { - return errors.New("private key manager zero keys") - } - - if m.keySet.ExpiresAt().Before(m.clock.Now().UTC()) { - return errors.New("private key manager keys expired") - } - - return nil -} - -func (m *privateKeyManager) Set(keySet KeySet) error { - privKeySet, ok := keySet.(*PrivateKeySet) - if !ok { - return errors.New("unable to cast to PrivateKeySet") - } - - m.keySet = privKeySet - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/repo.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/repo.go deleted file mode 100644 index 1acdeb3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/repo.go +++ /dev/null @@ -1,55 +0,0 @@ -package key - -import ( - "errors" - "sync" -) - -var ErrorNoKeys = errors.New("no keys found") - -type WritableKeySetRepo interface { - Set(KeySet) error -} - -type ReadableKeySetRepo interface { - Get() (KeySet, error) -} - -type PrivateKeySetRepo interface { - WritableKeySetRepo - ReadableKeySetRepo -} - -func NewPrivateKeySetRepo() PrivateKeySetRepo { - return &memPrivateKeySetRepo{} -} - -type memPrivateKeySetRepo struct { - mu sync.RWMutex - pks PrivateKeySet -} - -func (r *memPrivateKeySetRepo) Set(ks KeySet) error { - pks, ok := ks.(*PrivateKeySet) - if !ok { - return errors.New("unable to cast to PrivateKeySet") - } else if pks == nil { - return errors.New("nil KeySet") - } - - r.mu.Lock() - defer r.mu.Unlock() - - r.pks = *pks - return nil -} - -func (r *memPrivateKeySetRepo) Get() (KeySet, error) { - r.mu.RLock() - defer r.mu.RUnlock() - - if r.pks.keys == nil { - return nil, ErrorNoKeys - } - return KeySet(&r.pks), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/rotate.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/rotate.go deleted file mode 100644 index bc6cdfb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/rotate.go +++ /dev/null @@ -1,159 +0,0 @@ -package key - -import ( - "errors" - "log" - "time" - - ptime "github.com/coreos/pkg/timeutil" - "github.com/jonboulle/clockwork" -) - -var ( - ErrorPrivateKeysExpired = errors.New("private keys have expired") -) - -func NewPrivateKeyRotator(repo PrivateKeySetRepo, ttl time.Duration) *PrivateKeyRotator { - return &PrivateKeyRotator{ - repo: repo, - ttl: ttl, - - keep: 2, - generateKey: GeneratePrivateKey, - clock: clockwork.NewRealClock(), - } -} - -type PrivateKeyRotator struct { - repo PrivateKeySetRepo - generateKey GeneratePrivateKeyFunc - clock clockwork.Clock - keep int - ttl time.Duration -} - -func (r *PrivateKeyRotator) expiresAt() time.Time { - return r.clock.Now().UTC().Add(r.ttl) -} - -func (r *PrivateKeyRotator) Healthy() error { - pks, err := r.privateKeySet() - if err != nil { - return err - } - - if r.clock.Now().After(pks.ExpiresAt()) { - return ErrorPrivateKeysExpired - } - - return nil -} - -func (r *PrivateKeyRotator) privateKeySet() (*PrivateKeySet, error) { - ks, err := r.repo.Get() - if err != nil { - return nil, err - } - - pks, ok := ks.(*PrivateKeySet) - if !ok { - return nil, errors.New("unable to cast to PrivateKeySet") - } - return pks, nil -} - -func (r *PrivateKeyRotator) nextRotation() (time.Duration, error) { - pks, err := r.privateKeySet() - if err == ErrorNoKeys { - return 0, nil - } - if err != nil { - return 0, err - } - - now := r.clock.Now() - - // Ideally, we want to rotate after half the TTL has elapsed. - idealRotationTime := pks.ExpiresAt().Add(-r.ttl / 2) - - // If we are past the ideal rotation time, rotate immediatly. - return max(0, idealRotationTime.Sub(now)), nil -} - -func max(a, b time.Duration) time.Duration { - if a > b { - return a - } - return b -} - -func (r *PrivateKeyRotator) Run() chan struct{} { - attempt := func() { - k, err := r.generateKey() - if err != nil { - log.Printf("go-oidc: failed generating signing key: %v", err) - return - } - - exp := r.expiresAt() - if err := rotatePrivateKeys(r.repo, k, r.keep, exp); err != nil { - log.Printf("go-oidc: key rotation failed: %v", err) - return - } - } - - stop := make(chan struct{}) - go func() { - for { - var nextRotation time.Duration - var sleep time.Duration - var err error - for { - if nextRotation, err = r.nextRotation(); err == nil { - break - } - sleep = ptime.ExpBackoff(sleep, time.Minute) - log.Printf("go-oidc: error getting nextRotation, retrying in %v: %v", sleep, err) - time.Sleep(sleep) - } - - select { - case <-r.clock.After(nextRotation): - attempt() - case <-stop: - return - } - } - }() - - return stop -} - -func rotatePrivateKeys(repo PrivateKeySetRepo, k *PrivateKey, keep int, exp time.Time) error { - ks, err := repo.Get() - if err != nil && err != ErrorNoKeys { - return err - } - - var keys []*PrivateKey - if ks != nil { - pks, ok := ks.(*PrivateKeySet) - if !ok { - return errors.New("unable to cast to PrivateKeySet") - } - keys = pks.Keys() - } - - keys = append([]*PrivateKey{k}, keys...) - if l := len(keys); l > keep { - keys = keys[0:keep] - } - - nks := PrivateKeySet{ - keys: keys, - ActiveKeyID: k.ID(), - expiresAt: exp, - } - - return repo.Set(KeySet(&nks)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/sync.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/sync.go deleted file mode 100644 index b887f7b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/key/sync.go +++ /dev/null @@ -1,91 +0,0 @@ -package key - -import ( - "errors" - "log" - "time" - - "github.com/jonboulle/clockwork" - - "github.com/coreos/pkg/timeutil" -) - -func NewKeySetSyncer(r ReadableKeySetRepo, w WritableKeySetRepo) *KeySetSyncer { - return &KeySetSyncer{ - readable: r, - writable: w, - clock: clockwork.NewRealClock(), - } -} - -type KeySetSyncer struct { - readable ReadableKeySetRepo - writable WritableKeySetRepo - clock clockwork.Clock -} - -func (s *KeySetSyncer) Run() chan struct{} { - stop := make(chan struct{}) - go func() { - var failing bool - var next time.Duration - for { - exp, err := syncKeySet(s.readable, s.writable, s.clock) - if err != nil || exp == 0 { - if !failing { - failing = true - next = time.Second - } else { - next = timeutil.ExpBackoff(next, time.Minute) - } - if exp == 0 { - log.Printf("Synced to already expired key set, retrying in %v: %v", next, err) - - } else { - log.Printf("Failed syncing key set, retrying in %v: %v", next, err) - } - } else { - failing = false - next = exp / 2 - } - - select { - case <-s.clock.After(next): - continue - case <-stop: - return - } - } - }() - - return stop -} - -func Sync(r ReadableKeySetRepo, w WritableKeySetRepo) (time.Duration, error) { - return syncKeySet(r, w, clockwork.NewRealClock()) -} - -// syncKeySet copies the keyset from r to the KeySet at w and returns the duration in which the KeySet will expire. -// If keyset has already expired, returns a zero duration. -func syncKeySet(r ReadableKeySetRepo, w WritableKeySetRepo, clock clockwork.Clock) (exp time.Duration, err error) { - var ks KeySet - ks, err = r.Get() - if err != nil { - return - } - - if ks == nil { - err = errors.New("no source KeySet") - return - } - - if err = w.Set(ks); err != nil { - return - } - - now := clock.Now() - if ks.ExpiresAt().After(now) { - exp = ks.ExpiresAt().Sub(now) - } - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/error.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/error.go deleted file mode 100644 index 50d8909..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/error.go +++ /dev/null @@ -1,29 +0,0 @@ -package oauth2 - -const ( - ErrorAccessDenied = "access_denied" - ErrorInvalidClient = "invalid_client" - ErrorInvalidGrant = "invalid_grant" - ErrorInvalidRequest = "invalid_request" - ErrorServerError = "server_error" - ErrorUnauthorizedClient = "unauthorized_client" - ErrorUnsupportedGrantType = "unsupported_grant_type" - ErrorUnsupportedResponseType = "unsupported_response_type" -) - -type Error struct { - Type string `json:"error"` - Description string `json:"error_description,omitempty"` - State string `json:"state,omitempty"` -} - -func (e *Error) Error() string { - if e.Description != "" { - return e.Type + ": " + e.Description - } - return e.Type -} - -func NewError(typ string) *Error { - return &Error{Type: typ} -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/oauth2.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/oauth2.go deleted file mode 100644 index 72d1d67..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oauth2/oauth2.go +++ /dev/null @@ -1,416 +0,0 @@ -package oauth2 - -import ( - "encoding/json" - "errors" - "fmt" - "io/ioutil" - "mime" - "net/http" - "net/url" - "sort" - "strconv" - "strings" - - phttp "github.com/coreos/go-oidc/http" -) - -// ResponseTypesEqual compares two response_type values. If either -// contains a space, it is treated as an unordered list. For example, -// comparing "code id_token" and "id_token code" would evaluate to true. -func ResponseTypesEqual(r1, r2 string) bool { - if !strings.Contains(r1, " ") || !strings.Contains(r2, " ") { - // fast route, no split needed - return r1 == r2 - } - - // split, sort, and compare - r1Fields := strings.Fields(r1) - r2Fields := strings.Fields(r2) - if len(r1Fields) != len(r2Fields) { - return false - } - sort.Strings(r1Fields) - sort.Strings(r2Fields) - for i, r1Field := range r1Fields { - if r1Field != r2Fields[i] { - return false - } - } - return true -} - -const ( - // OAuth2.0 response types registered by OIDC. - // - // See: https://openid.net/specs/oauth-v2-multiple-response-types-1_0.html#RegistryContents - ResponseTypeCode = "code" - ResponseTypeCodeIDToken = "code id_token" - ResponseTypeCodeIDTokenToken = "code id_token token" - ResponseTypeIDToken = "id_token" - ResponseTypeIDTokenToken = "id_token token" - ResponseTypeToken = "token" - ResponseTypeNone = "none" -) - -const ( - GrantTypeAuthCode = "authorization_code" - GrantTypeClientCreds = "client_credentials" - GrantTypeUserCreds = "password" - GrantTypeImplicit = "implicit" - GrantTypeRefreshToken = "refresh_token" - - AuthMethodClientSecretPost = "client_secret_post" - AuthMethodClientSecretBasic = "client_secret_basic" - AuthMethodClientSecretJWT = "client_secret_jwt" - AuthMethodPrivateKeyJWT = "private_key_jwt" -) - -type Config struct { - Credentials ClientCredentials - Scope []string - RedirectURL string - AuthURL string - TokenURL string - - // Must be one of the AuthMethodXXX methods above. Right now, only - // AuthMethodClientSecretPost and AuthMethodClientSecretBasic are supported. - AuthMethod string -} - -type Client struct { - hc phttp.Client - creds ClientCredentials - scope []string - authURL *url.URL - redirectURL *url.URL - tokenURL *url.URL - authMethod string -} - -type ClientCredentials struct { - ID string - Secret string -} - -func NewClient(hc phttp.Client, cfg Config) (c *Client, err error) { - if len(cfg.Credentials.ID) == 0 { - err = errors.New("missing client id") - return - } - - if len(cfg.Credentials.Secret) == 0 { - err = errors.New("missing client secret") - return - } - - if cfg.AuthMethod == "" { - cfg.AuthMethod = AuthMethodClientSecretBasic - } else if cfg.AuthMethod != AuthMethodClientSecretPost && cfg.AuthMethod != AuthMethodClientSecretBasic { - err = fmt.Errorf("auth method %q is not supported", cfg.AuthMethod) - return - } - - au, err := phttp.ParseNonEmptyURL(cfg.AuthURL) - if err != nil { - return - } - - tu, err := phttp.ParseNonEmptyURL(cfg.TokenURL) - if err != nil { - return - } - - // Allow empty redirect URL in the case where the client - // only needs to verify a given token. - ru, err := url.Parse(cfg.RedirectURL) - if err != nil { - return - } - - c = &Client{ - creds: cfg.Credentials, - scope: cfg.Scope, - redirectURL: ru, - authURL: au, - tokenURL: tu, - hc: hc, - authMethod: cfg.AuthMethod, - } - - return -} - -// Return the embedded HTTP client -func (c *Client) HttpClient() phttp.Client { - return c.hc -} - -// Generate the url for initial redirect to oauth provider. -func (c *Client) AuthCodeURL(state, accessType, prompt string) string { - v := c.commonURLValues() - v.Set("state", state) - if strings.ToLower(accessType) == "offline" { - v.Set("access_type", "offline") - } - - if prompt != "" { - v.Set("prompt", prompt) - } - v.Set("response_type", "code") - - q := v.Encode() - u := *c.authURL - if u.RawQuery == "" { - u.RawQuery = q - } else { - u.RawQuery += "&" + q - } - return u.String() -} - -func (c *Client) commonURLValues() url.Values { - return url.Values{ - "redirect_uri": {c.redirectURL.String()}, - "scope": {strings.Join(c.scope, " ")}, - "client_id": {c.creds.ID}, - } -} - -func (c *Client) newAuthenticatedRequest(urlToken string, values url.Values) (*http.Request, error) { - var req *http.Request - var err error - switch c.authMethod { - case AuthMethodClientSecretPost: - values.Set("client_secret", c.creds.Secret) - req, err = http.NewRequest("POST", urlToken, strings.NewReader(values.Encode())) - if err != nil { - return nil, err - } - case AuthMethodClientSecretBasic: - req, err = http.NewRequest("POST", urlToken, strings.NewReader(values.Encode())) - if err != nil { - return nil, err - } - encodedID := url.QueryEscape(c.creds.ID) - encodedSecret := url.QueryEscape(c.creds.Secret) - req.SetBasicAuth(encodedID, encodedSecret) - default: - panic("misconfigured client: auth method not supported") - } - - req.Header.Set("Content-Type", "application/x-www-form-urlencoded") - return req, nil - -} - -// ClientCredsToken posts the client id and secret to obtain a token scoped to the OAuth2 client via the "client_credentials" grant type. -// May not be supported by all OAuth2 servers. -func (c *Client) ClientCredsToken(scope []string) (result TokenResponse, err error) { - v := url.Values{ - "scope": {strings.Join(scope, " ")}, - "grant_type": {GrantTypeClientCreds}, - } - - req, err := c.newAuthenticatedRequest(c.tokenURL.String(), v) - if err != nil { - return - } - - resp, err := c.hc.Do(req) - if err != nil { - return - } - defer resp.Body.Close() - - return parseTokenResponse(resp) -} - -// UserCredsToken posts the username and password to obtain a token scoped to the OAuth2 client via the "password" grant_type -// May not be supported by all OAuth2 servers. -func (c *Client) UserCredsToken(username, password string) (result TokenResponse, err error) { - v := url.Values{ - "scope": {strings.Join(c.scope, " ")}, - "grant_type": {GrantTypeUserCreds}, - "username": {username}, - "password": {password}, - } - - req, err := c.newAuthenticatedRequest(c.tokenURL.String(), v) - if err != nil { - return - } - - resp, err := c.hc.Do(req) - if err != nil { - return - } - defer resp.Body.Close() - - return parseTokenResponse(resp) -} - -// RequestToken requests a token from the Token Endpoint with the specified grantType. -// If 'grantType' == GrantTypeAuthCode, then 'value' should be the authorization code. -// If 'grantType' == GrantTypeRefreshToken, then 'value' should be the refresh token. -func (c *Client) RequestToken(grantType, value string) (result TokenResponse, err error) { - v := c.commonURLValues() - - v.Set("grant_type", grantType) - v.Set("client_secret", c.creds.Secret) - switch grantType { - case GrantTypeAuthCode: - v.Set("code", value) - case GrantTypeRefreshToken: - v.Set("refresh_token", value) - default: - err = fmt.Errorf("unsupported grant_type: %v", grantType) - return - } - - req, err := c.newAuthenticatedRequest(c.tokenURL.String(), v) - if err != nil { - return - } - - resp, err := c.hc.Do(req) - if err != nil { - return - } - defer resp.Body.Close() - - return parseTokenResponse(resp) -} - -func parseTokenResponse(resp *http.Response) (result TokenResponse, err error) { - body, err := ioutil.ReadAll(resp.Body) - if err != nil { - return - } - badStatusCode := resp.StatusCode < 200 || resp.StatusCode > 299 - - contentType, _, err := mime.ParseMediaType(resp.Header.Get("Content-Type")) - if err != nil { - return - } - - result = TokenResponse{ - RawBody: body, - } - - newError := func(typ, desc, state string) error { - if typ == "" { - return fmt.Errorf("unrecognized error %s", body) - } - return &Error{typ, desc, state} - } - - if contentType == "application/x-www-form-urlencoded" || contentType == "text/plain" { - var vals url.Values - vals, err = url.ParseQuery(string(body)) - if err != nil { - return - } - if error := vals.Get("error"); error != "" || badStatusCode { - err = newError(error, vals.Get("error_description"), vals.Get("state")) - return - } - e := vals.Get("expires_in") - if e == "" { - e = vals.Get("expires") - } - if e != "" { - result.Expires, err = strconv.Atoi(e) - if err != nil { - return - } - } - result.AccessToken = vals.Get("access_token") - result.TokenType = vals.Get("token_type") - result.IDToken = vals.Get("id_token") - result.RefreshToken = vals.Get("refresh_token") - result.Scope = vals.Get("scope") - } else { - var r struct { - AccessToken string `json:"access_token"` - TokenType string `json:"token_type"` - IDToken string `json:"id_token"` - RefreshToken string `json:"refresh_token"` - Scope string `json:"scope"` - State string `json:"state"` - ExpiresIn json.Number `json:"expires_in"` // Azure AD returns string - Expires int `json:"expires"` - Error string `json:"error"` - Desc string `json:"error_description"` - } - if err = json.Unmarshal(body, &r); err != nil { - return - } - if r.Error != "" || badStatusCode { - err = newError(r.Error, r.Desc, r.State) - return - } - result.AccessToken = r.AccessToken - result.TokenType = r.TokenType - result.IDToken = r.IDToken - result.RefreshToken = r.RefreshToken - result.Scope = r.Scope - if expiresIn, err := r.ExpiresIn.Int64(); err != nil { - result.Expires = r.Expires - } else { - result.Expires = int(expiresIn) - } - } - return -} - -type TokenResponse struct { - AccessToken string - TokenType string - Expires int - IDToken string - RefreshToken string // OPTIONAL. - Scope string // OPTIONAL, if identical to the scope requested by the client, otherwise, REQUIRED. - RawBody []byte // In case callers need some other non-standard info from the token response -} - -type AuthCodeRequest struct { - ResponseType string - ClientID string - RedirectURL *url.URL - Scope []string - State string -} - -func ParseAuthCodeRequest(q url.Values) (AuthCodeRequest, error) { - acr := AuthCodeRequest{ - ResponseType: q.Get("response_type"), - ClientID: q.Get("client_id"), - State: q.Get("state"), - Scope: make([]string, 0), - } - - qs := strings.TrimSpace(q.Get("scope")) - if qs != "" { - acr.Scope = strings.Split(qs, " ") - } - - err := func() error { - if acr.ClientID == "" { - return NewError(ErrorInvalidRequest) - } - - redirectURL := q.Get("redirect_uri") - if redirectURL != "" { - ru, err := url.Parse(redirectURL) - if err != nil { - return NewError(ErrorInvalidRequest) - } - acr.RedirectURL = ru - } - - return nil - }() - - return acr, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/client.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/client.go deleted file mode 100644 index 7a3cb40..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/client.go +++ /dev/null @@ -1,846 +0,0 @@ -package oidc - -import ( - "encoding/json" - "errors" - "fmt" - "net/http" - "net/mail" - "net/url" - "sync" - "time" - - phttp "github.com/coreos/go-oidc/http" - "github.com/coreos/go-oidc/jose" - "github.com/coreos/go-oidc/key" - "github.com/coreos/go-oidc/oauth2" -) - -const ( - // amount of time that must pass after the last key sync - // completes before another attempt may begin - keySyncWindow = 5 * time.Second -) - -var ( - DefaultScope = []string{"openid", "email", "profile"} - - supportedAuthMethods = map[string]struct{}{ - oauth2.AuthMethodClientSecretBasic: struct{}{}, - oauth2.AuthMethodClientSecretPost: struct{}{}, - } -) - -type ClientCredentials oauth2.ClientCredentials - -type ClientIdentity struct { - Credentials ClientCredentials - Metadata ClientMetadata -} - -type JWAOptions struct { - // SigningAlg specifies an JWA alg for signing JWTs. - // - // Specifying this field implies different actions depending on the context. It may - // require objects be serialized and signed as a JWT instead of plain JSON, or - // require an existing JWT object use the specified alg. - // - // See: http://openid.net/specs/openid-connect-registration-1_0.html#ClientMetadata - SigningAlg string - // EncryptionAlg, if provided, specifies that the returned or sent object be stored - // (or nested) within a JWT object and encrypted with the provided JWA alg. - EncryptionAlg string - // EncryptionEnc specifies the JWA enc algorithm to use with EncryptionAlg. If - // EncryptionAlg is provided and EncryptionEnc is omitted, this field defaults - // to A128CBC-HS256. - // - // If EncryptionEnc is provided EncryptionAlg must also be specified. - EncryptionEnc string -} - -func (opt JWAOptions) valid() error { - if opt.EncryptionEnc != "" && opt.EncryptionAlg == "" { - return errors.New("encryption encoding provided with no encryption algorithm") - } - return nil -} - -func (opt JWAOptions) defaults() JWAOptions { - if opt.EncryptionAlg != "" && opt.EncryptionEnc == "" { - opt.EncryptionEnc = jose.EncA128CBCHS256 - } - return opt -} - -var ( - // Ensure ClientMetadata satisfies these interfaces. - _ json.Marshaler = &ClientMetadata{} - _ json.Unmarshaler = &ClientMetadata{} -) - -// ClientMetadata holds metadata that the authorization server associates -// with a client identifier. The fields range from human-facing display -// strings such as client name, to items that impact the security of the -// protocol, such as the list of valid redirect URIs. -// -// See http://openid.net/specs/openid-connect-registration-1_0.html#ClientMetadata -// -// TODO: support language specific claim representations -// http://openid.net/specs/openid-connect-registration-1_0.html#LanguagesAndScripts -type ClientMetadata struct { - RedirectURIs []url.URL // Required - - // A list of OAuth 2.0 "response_type" values that the client wishes to restrict - // itself to. Either "code", "token", or another registered extension. - // - // If omitted, only "code" will be used. - ResponseTypes []string - // A list of OAuth 2.0 grant types the client wishes to restrict itself to. - // The grant type values used by OIDC are "authorization_code", "implicit", - // and "refresh_token". - // - // If ommitted, only "authorization_code" will be used. - GrantTypes []string - // "native" or "web". If omitted, "web". - ApplicationType string - - // List of email addresses. - Contacts []mail.Address - // Name of client to be presented to the end-user. - ClientName string - // URL that references a logo for the Client application. - LogoURI *url.URL - // URL of the home page of the Client. - ClientURI *url.URL - // Profile data policies and terms of use to be provided to the end user. - PolicyURI *url.URL - TermsOfServiceURI *url.URL - - // URL to or the value of the client's JSON Web Key Set document. - JWKSURI *url.URL - JWKS *jose.JWKSet - - // URL referencing a flie with a single JSON array of redirect URIs. - SectorIdentifierURI *url.URL - - SubjectType string - - // Options to restrict the JWS alg and enc values used for server responses and requests. - IDTokenResponseOptions JWAOptions - UserInfoResponseOptions JWAOptions - RequestObjectOptions JWAOptions - - // Client requested authorization method and signing options for the token endpoint. - // - // Defaults to "client_secret_basic" - TokenEndpointAuthMethod string - TokenEndpointAuthSigningAlg string - - // DefaultMaxAge specifies the maximum amount of time in seconds before an authorized - // user must reauthroize. - // - // If 0, no limitation is placed on the maximum. - DefaultMaxAge int64 - // RequireAuthTime specifies if the auth_time claim in the ID token is required. - RequireAuthTime bool - - // Default Authentication Context Class Reference values for authentication requests. - DefaultACRValues []string - - // URI that a third party can use to initiate a login by the relaying party. - // - // See: http://openid.net/specs/openid-connect-core-1_0.html#ThirdPartyInitiatedLogin - InitiateLoginURI *url.URL - // Pre-registered request_uri values that may be cached by the server. - RequestURIs []url.URL -} - -// Defaults returns a shallow copy of ClientMetadata with default -// values replacing omitted fields. -func (m ClientMetadata) Defaults() ClientMetadata { - if len(m.ResponseTypes) == 0 { - m.ResponseTypes = []string{oauth2.ResponseTypeCode} - } - if len(m.GrantTypes) == 0 { - m.GrantTypes = []string{oauth2.GrantTypeAuthCode} - } - if m.ApplicationType == "" { - m.ApplicationType = "web" - } - if m.TokenEndpointAuthMethod == "" { - m.TokenEndpointAuthMethod = oauth2.AuthMethodClientSecretBasic - } - m.IDTokenResponseOptions = m.IDTokenResponseOptions.defaults() - m.UserInfoResponseOptions = m.UserInfoResponseOptions.defaults() - m.RequestObjectOptions = m.RequestObjectOptions.defaults() - return m -} - -func (m *ClientMetadata) MarshalJSON() ([]byte, error) { - e := m.toEncodableStruct() - return json.Marshal(&e) -} - -func (m *ClientMetadata) UnmarshalJSON(data []byte) error { - var e encodableClientMetadata - if err := json.Unmarshal(data, &e); err != nil { - return err - } - meta, err := e.toStruct() - if err != nil { - return err - } - if err := meta.Valid(); err != nil { - return err - } - *m = meta - return nil -} - -type encodableClientMetadata struct { - RedirectURIs []string `json:"redirect_uris"` // Required - ResponseTypes []string `json:"response_types,omitempty"` - GrantTypes []string `json:"grant_types,omitempty"` - ApplicationType string `json:"application_type,omitempty"` - Contacts []string `json:"contacts,omitempty"` - ClientName string `json:"client_name,omitempty"` - LogoURI string `json:"logo_uri,omitempty"` - ClientURI string `json:"client_uri,omitempty"` - PolicyURI string `json:"policy_uri,omitempty"` - TermsOfServiceURI string `json:"tos_uri,omitempty"` - JWKSURI string `json:"jwks_uri,omitempty"` - JWKS *jose.JWKSet `json:"jwks,omitempty"` - SectorIdentifierURI string `json:"sector_identifier_uri,omitempty"` - SubjectType string `json:"subject_type,omitempty"` - IDTokenSignedResponseAlg string `json:"id_token_signed_response_alg,omitempty"` - IDTokenEncryptedResponseAlg string `json:"id_token_encrypted_response_alg,omitempty"` - IDTokenEncryptedResponseEnc string `json:"id_token_encrypted_response_enc,omitempty"` - UserInfoSignedResponseAlg string `json:"userinfo_signed_response_alg,omitempty"` - UserInfoEncryptedResponseAlg string `json:"userinfo_encrypted_response_alg,omitempty"` - UserInfoEncryptedResponseEnc string `json:"userinfo_encrypted_response_enc,omitempty"` - RequestObjectSigningAlg string `json:"request_object_signing_alg,omitempty"` - RequestObjectEncryptionAlg string `json:"request_object_encryption_alg,omitempty"` - RequestObjectEncryptionEnc string `json:"request_object_encryption_enc,omitempty"` - TokenEndpointAuthMethod string `json:"token_endpoint_auth_method,omitempty"` - TokenEndpointAuthSigningAlg string `json:"token_endpoint_auth_signing_alg,omitempty"` - DefaultMaxAge int64 `json:"default_max_age,omitempty"` - RequireAuthTime bool `json:"require_auth_time,omitempty"` - DefaultACRValues []string `json:"default_acr_values,omitempty"` - InitiateLoginURI string `json:"initiate_login_uri,omitempty"` - RequestURIs []string `json:"request_uris,omitempty"` -} - -func (c *encodableClientMetadata) toStruct() (ClientMetadata, error) { - p := stickyErrParser{} - m := ClientMetadata{ - RedirectURIs: p.parseURIs(c.RedirectURIs, "redirect_uris"), - ResponseTypes: c.ResponseTypes, - GrantTypes: c.GrantTypes, - ApplicationType: c.ApplicationType, - Contacts: p.parseEmails(c.Contacts, "contacts"), - ClientName: c.ClientName, - LogoURI: p.parseURI(c.LogoURI, "logo_uri"), - ClientURI: p.parseURI(c.ClientURI, "client_uri"), - PolicyURI: p.parseURI(c.PolicyURI, "policy_uri"), - TermsOfServiceURI: p.parseURI(c.TermsOfServiceURI, "tos_uri"), - JWKSURI: p.parseURI(c.JWKSURI, "jwks_uri"), - JWKS: c.JWKS, - SectorIdentifierURI: p.parseURI(c.SectorIdentifierURI, "sector_identifier_uri"), - SubjectType: c.SubjectType, - TokenEndpointAuthMethod: c.TokenEndpointAuthMethod, - TokenEndpointAuthSigningAlg: c.TokenEndpointAuthSigningAlg, - DefaultMaxAge: c.DefaultMaxAge, - RequireAuthTime: c.RequireAuthTime, - DefaultACRValues: c.DefaultACRValues, - InitiateLoginURI: p.parseURI(c.InitiateLoginURI, "initiate_login_uri"), - RequestURIs: p.parseURIs(c.RequestURIs, "request_uris"), - IDTokenResponseOptions: JWAOptions{ - c.IDTokenSignedResponseAlg, - c.IDTokenEncryptedResponseAlg, - c.IDTokenEncryptedResponseEnc, - }, - UserInfoResponseOptions: JWAOptions{ - c.UserInfoSignedResponseAlg, - c.UserInfoEncryptedResponseAlg, - c.UserInfoEncryptedResponseEnc, - }, - RequestObjectOptions: JWAOptions{ - c.RequestObjectSigningAlg, - c.RequestObjectEncryptionAlg, - c.RequestObjectEncryptionEnc, - }, - } - if p.firstErr != nil { - return ClientMetadata{}, p.firstErr - } - return m, nil -} - -// stickyErrParser parses URIs and email addresses. Once it encounters -// a parse error, subsequent calls become no-op. -type stickyErrParser struct { - firstErr error -} - -func (p *stickyErrParser) parseURI(s, field string) *url.URL { - if p.firstErr != nil || s == "" { - return nil - } - u, err := url.Parse(s) - if err == nil { - if u.Host == "" { - err = errors.New("no host in URI") - } else if u.Scheme != "http" && u.Scheme != "https" { - err = errors.New("invalid URI scheme") - } - } - if err != nil { - p.firstErr = fmt.Errorf("failed to parse %s: %v", field, err) - return nil - } - return u -} - -func (p *stickyErrParser) parseURIs(s []string, field string) []url.URL { - if p.firstErr != nil || len(s) == 0 { - return nil - } - uris := make([]url.URL, len(s)) - for i, val := range s { - if val == "" { - p.firstErr = fmt.Errorf("invalid URI in field %s", field) - return nil - } - if u := p.parseURI(val, field); u != nil { - uris[i] = *u - } - } - return uris -} - -func (p *stickyErrParser) parseEmails(s []string, field string) []mail.Address { - if p.firstErr != nil || len(s) == 0 { - return nil - } - addrs := make([]mail.Address, len(s)) - for i, addr := range s { - if addr == "" { - p.firstErr = fmt.Errorf("invalid email in field %s", field) - return nil - } - a, err := mail.ParseAddress(addr) - if err != nil { - p.firstErr = fmt.Errorf("invalid email in field %s: %v", field, err) - return nil - } - addrs[i] = *a - } - return addrs -} - -func (m *ClientMetadata) toEncodableStruct() encodableClientMetadata { - return encodableClientMetadata{ - RedirectURIs: urisToStrings(m.RedirectURIs), - ResponseTypes: m.ResponseTypes, - GrantTypes: m.GrantTypes, - ApplicationType: m.ApplicationType, - Contacts: emailsToStrings(m.Contacts), - ClientName: m.ClientName, - LogoURI: uriToString(m.LogoURI), - ClientURI: uriToString(m.ClientURI), - PolicyURI: uriToString(m.PolicyURI), - TermsOfServiceURI: uriToString(m.TermsOfServiceURI), - JWKSURI: uriToString(m.JWKSURI), - JWKS: m.JWKS, - SectorIdentifierURI: uriToString(m.SectorIdentifierURI), - SubjectType: m.SubjectType, - IDTokenSignedResponseAlg: m.IDTokenResponseOptions.SigningAlg, - IDTokenEncryptedResponseAlg: m.IDTokenResponseOptions.EncryptionAlg, - IDTokenEncryptedResponseEnc: m.IDTokenResponseOptions.EncryptionEnc, - UserInfoSignedResponseAlg: m.UserInfoResponseOptions.SigningAlg, - UserInfoEncryptedResponseAlg: m.UserInfoResponseOptions.EncryptionAlg, - UserInfoEncryptedResponseEnc: m.UserInfoResponseOptions.EncryptionEnc, - RequestObjectSigningAlg: m.RequestObjectOptions.SigningAlg, - RequestObjectEncryptionAlg: m.RequestObjectOptions.EncryptionAlg, - RequestObjectEncryptionEnc: m.RequestObjectOptions.EncryptionEnc, - TokenEndpointAuthMethod: m.TokenEndpointAuthMethod, - TokenEndpointAuthSigningAlg: m.TokenEndpointAuthSigningAlg, - DefaultMaxAge: m.DefaultMaxAge, - RequireAuthTime: m.RequireAuthTime, - DefaultACRValues: m.DefaultACRValues, - InitiateLoginURI: uriToString(m.InitiateLoginURI), - RequestURIs: urisToStrings(m.RequestURIs), - } -} - -func uriToString(u *url.URL) string { - if u == nil { - return "" - } - return u.String() -} - -func urisToStrings(urls []url.URL) []string { - if len(urls) == 0 { - return nil - } - sli := make([]string, len(urls)) - for i, u := range urls { - sli[i] = u.String() - } - return sli -} - -func emailsToStrings(addrs []mail.Address) []string { - if len(addrs) == 0 { - return nil - } - sli := make([]string, len(addrs)) - for i, addr := range addrs { - sli[i] = addr.String() - } - return sli -} - -// Valid determines if a ClientMetadata conforms with the OIDC specification. -// -// Valid is called by UnmarshalJSON. -// -// NOTE(ericchiang): For development purposes Valid does not mandate 'https' for -// URLs fields where the OIDC spec requires it. This may change in future releases -// of this package. See: https://github.com/coreos/go-oidc/issues/34 -func (m *ClientMetadata) Valid() error { - if len(m.RedirectURIs) == 0 { - return errors.New("zero redirect URLs") - } - - validURI := func(u *url.URL, fieldName string) error { - if u.Host == "" { - return fmt.Errorf("no host for uri field %s", fieldName) - } - if u.Scheme != "http" && u.Scheme != "https" { - return fmt.Errorf("uri field %s scheme is not http or https", fieldName) - } - return nil - } - - uris := []struct { - val *url.URL - name string - }{ - {m.LogoURI, "logo_uri"}, - {m.ClientURI, "client_uri"}, - {m.PolicyURI, "policy_uri"}, - {m.TermsOfServiceURI, "tos_uri"}, - {m.JWKSURI, "jwks_uri"}, - {m.SectorIdentifierURI, "sector_identifier_uri"}, - {m.InitiateLoginURI, "initiate_login_uri"}, - } - - for _, uri := range uris { - if uri.val == nil { - continue - } - if err := validURI(uri.val, uri.name); err != nil { - return err - } - } - - uriLists := []struct { - vals []url.URL - name string - }{ - {m.RedirectURIs, "redirect_uris"}, - {m.RequestURIs, "request_uris"}, - } - for _, list := range uriLists { - for _, uri := range list.vals { - if err := validURI(&uri, list.name); err != nil { - return err - } - } - } - - options := []struct { - option JWAOptions - name string - }{ - {m.IDTokenResponseOptions, "id_token response"}, - {m.UserInfoResponseOptions, "userinfo response"}, - {m.RequestObjectOptions, "request_object"}, - } - for _, option := range options { - if err := option.option.valid(); err != nil { - return fmt.Errorf("invalid JWA values for %s: %v", option.name, err) - } - } - return nil -} - -type ClientRegistrationResponse struct { - ClientID string // Required - ClientSecret string - RegistrationAccessToken string - RegistrationClientURI string - // If IsZero is true, unspecified. - ClientIDIssuedAt time.Time - // Time at which the client_secret will expire. - // If IsZero is true, it will not expire. - ClientSecretExpiresAt time.Time - - ClientMetadata -} - -type encodableClientRegistrationResponse struct { - ClientID string `json:"client_id"` // Required - ClientSecret string `json:"client_secret,omitempty"` - RegistrationAccessToken string `json:"registration_access_token,omitempty"` - RegistrationClientURI string `json:"registration_client_uri,omitempty"` - ClientIDIssuedAt int64 `json:"client_id_issued_at,omitempty"` - // Time at which the client_secret will expire, in seconds since the epoch. - // If 0 it will not expire. - ClientSecretExpiresAt int64 `json:"client_secret_expires_at"` // Required - - encodableClientMetadata -} - -func unixToSec(t time.Time) int64 { - if t.IsZero() { - return 0 - } - return t.Unix() -} - -func (c *ClientRegistrationResponse) MarshalJSON() ([]byte, error) { - e := encodableClientRegistrationResponse{ - ClientID: c.ClientID, - ClientSecret: c.ClientSecret, - RegistrationAccessToken: c.RegistrationAccessToken, - RegistrationClientURI: c.RegistrationClientURI, - ClientIDIssuedAt: unixToSec(c.ClientIDIssuedAt), - ClientSecretExpiresAt: unixToSec(c.ClientSecretExpiresAt), - encodableClientMetadata: c.ClientMetadata.toEncodableStruct(), - } - return json.Marshal(&e) -} - -func secToUnix(sec int64) time.Time { - if sec == 0 { - return time.Time{} - } - return time.Unix(sec, 0) -} - -func (c *ClientRegistrationResponse) UnmarshalJSON(data []byte) error { - var e encodableClientRegistrationResponse - if err := json.Unmarshal(data, &e); err != nil { - return err - } - if e.ClientID == "" { - return errors.New("no client_id in client registration response") - } - metadata, err := e.encodableClientMetadata.toStruct() - if err != nil { - return err - } - *c = ClientRegistrationResponse{ - ClientID: e.ClientID, - ClientSecret: e.ClientSecret, - RegistrationAccessToken: e.RegistrationAccessToken, - RegistrationClientURI: e.RegistrationClientURI, - ClientIDIssuedAt: secToUnix(e.ClientIDIssuedAt), - ClientSecretExpiresAt: secToUnix(e.ClientSecretExpiresAt), - ClientMetadata: metadata, - } - return nil -} - -type ClientConfig struct { - HTTPClient phttp.Client - Credentials ClientCredentials - Scope []string - RedirectURL string - ProviderConfig ProviderConfig - KeySet key.PublicKeySet -} - -func NewClient(cfg ClientConfig) (*Client, error) { - // Allow empty redirect URL in the case where the client - // only needs to verify a given token. - ru, err := url.Parse(cfg.RedirectURL) - if err != nil { - return nil, fmt.Errorf("invalid redirect URL: %v", err) - } - - c := Client{ - credentials: cfg.Credentials, - httpClient: cfg.HTTPClient, - scope: cfg.Scope, - redirectURL: ru.String(), - providerConfig: newProviderConfigRepo(cfg.ProviderConfig), - keySet: cfg.KeySet, - } - - if c.httpClient == nil { - c.httpClient = http.DefaultClient - } - - if c.scope == nil { - c.scope = make([]string, len(DefaultScope)) - copy(c.scope, DefaultScope) - } - - return &c, nil -} - -type Client struct { - httpClient phttp.Client - providerConfig *providerConfigRepo - credentials ClientCredentials - redirectURL string - scope []string - keySet key.PublicKeySet - providerSyncer *ProviderConfigSyncer - - keySetSyncMutex sync.RWMutex - lastKeySetSync time.Time -} - -func (c *Client) Healthy() error { - now := time.Now().UTC() - - cfg := c.providerConfig.Get() - - if cfg.Empty() { - return errors.New("oidc client provider config empty") - } - - if !cfg.ExpiresAt.IsZero() && cfg.ExpiresAt.Before(now) { - return errors.New("oidc client provider config expired") - } - - return nil -} - -func (c *Client) OAuthClient() (*oauth2.Client, error) { - cfg := c.providerConfig.Get() - authMethod, err := chooseAuthMethod(cfg) - if err != nil { - return nil, err - } - - ocfg := oauth2.Config{ - Credentials: oauth2.ClientCredentials(c.credentials), - RedirectURL: c.redirectURL, - AuthURL: cfg.AuthEndpoint.String(), - TokenURL: cfg.TokenEndpoint.String(), - Scope: c.scope, - AuthMethod: authMethod, - } - - return oauth2.NewClient(c.httpClient, ocfg) -} - -func chooseAuthMethod(cfg ProviderConfig) (string, error) { - if len(cfg.TokenEndpointAuthMethodsSupported) == 0 { - return oauth2.AuthMethodClientSecretBasic, nil - } - - for _, authMethod := range cfg.TokenEndpointAuthMethodsSupported { - if _, ok := supportedAuthMethods[authMethod]; ok { - return authMethod, nil - } - } - - return "", errors.New("no supported auth methods") -} - -// SyncProviderConfig starts the provider config syncer -func (c *Client) SyncProviderConfig(discoveryURL string) chan struct{} { - r := NewHTTPProviderConfigGetter(c.httpClient, discoveryURL) - s := NewProviderConfigSyncer(r, c.providerConfig) - stop := s.Run() - s.WaitUntilInitialSync() - return stop -} - -func (c *Client) maybeSyncKeys() error { - tooSoon := func() bool { - return time.Now().UTC().Before(c.lastKeySetSync.Add(keySyncWindow)) - } - - // ignore request to sync keys if a sync operation has been - // attempted too recently - if tooSoon() { - return nil - } - - c.keySetSyncMutex.Lock() - defer c.keySetSyncMutex.Unlock() - - // check again, as another goroutine may have been holding - // the lock while updating the keys - if tooSoon() { - return nil - } - - cfg := c.providerConfig.Get() - r := NewRemotePublicKeyRepo(c.httpClient, cfg.KeysEndpoint.String()) - w := &clientKeyRepo{client: c} - _, err := key.Sync(r, w) - c.lastKeySetSync = time.Now().UTC() - - return err -} - -type clientKeyRepo struct { - client *Client -} - -func (r *clientKeyRepo) Set(ks key.KeySet) error { - pks, ok := ks.(*key.PublicKeySet) - if !ok { - return errors.New("unable to cast to PublicKey") - } - r.client.keySet = *pks - return nil -} - -func (c *Client) ClientCredsToken(scope []string) (jose.JWT, error) { - cfg := c.providerConfig.Get() - - if !cfg.SupportsGrantType(oauth2.GrantTypeClientCreds) { - return jose.JWT{}, fmt.Errorf("%v grant type is not supported", oauth2.GrantTypeClientCreds) - } - - oac, err := c.OAuthClient() - if err != nil { - return jose.JWT{}, err - } - - t, err := oac.ClientCredsToken(scope) - if err != nil { - return jose.JWT{}, err - } - - jwt, err := jose.ParseJWT(t.IDToken) - if err != nil { - return jose.JWT{}, err - } - - return jwt, c.VerifyJWT(jwt) -} - -// ExchangeAuthCode exchanges an OAuth2 auth code for an OIDC JWT ID token. -func (c *Client) ExchangeAuthCode(code string) (jose.JWT, error) { - oac, err := c.OAuthClient() - if err != nil { - return jose.JWT{}, err - } - - t, err := oac.RequestToken(oauth2.GrantTypeAuthCode, code) - if err != nil { - return jose.JWT{}, err - } - - jwt, err := jose.ParseJWT(t.IDToken) - if err != nil { - return jose.JWT{}, err - } - - return jwt, c.VerifyJWT(jwt) -} - -// RefreshToken uses a refresh token to exchange for a new OIDC JWT ID Token. -func (c *Client) RefreshToken(refreshToken string) (jose.JWT, error) { - oac, err := c.OAuthClient() - if err != nil { - return jose.JWT{}, err - } - - t, err := oac.RequestToken(oauth2.GrantTypeRefreshToken, refreshToken) - if err != nil { - return jose.JWT{}, err - } - - jwt, err := jose.ParseJWT(t.IDToken) - if err != nil { - return jose.JWT{}, err - } - - return jwt, c.VerifyJWT(jwt) -} - -func (c *Client) VerifyJWT(jwt jose.JWT) error { - var keysFunc func() []key.PublicKey - if kID, ok := jwt.KeyID(); ok { - keysFunc = c.keysFuncWithID(kID) - } else { - keysFunc = c.keysFuncAll() - } - - v := NewJWTVerifier( - c.providerConfig.Get().Issuer.String(), - c.credentials.ID, - c.maybeSyncKeys, keysFunc) - - return v.Verify(jwt) -} - -// keysFuncWithID returns a function that retrieves at most unexpired -// public key from the Client that matches the provided ID -func (c *Client) keysFuncWithID(kID string) func() []key.PublicKey { - return func() []key.PublicKey { - c.keySetSyncMutex.RLock() - defer c.keySetSyncMutex.RUnlock() - - if c.keySet.ExpiresAt().Before(time.Now()) { - return []key.PublicKey{} - } - - k := c.keySet.Key(kID) - if k == nil { - return []key.PublicKey{} - } - - return []key.PublicKey{*k} - } -} - -// keysFuncAll returns a function that retrieves all unexpired public -// keys from the Client -func (c *Client) keysFuncAll() func() []key.PublicKey { - return func() []key.PublicKey { - c.keySetSyncMutex.RLock() - defer c.keySetSyncMutex.RUnlock() - - if c.keySet.ExpiresAt().Before(time.Now()) { - return []key.PublicKey{} - } - - return c.keySet.Keys() - } -} - -type providerConfigRepo struct { - mu sync.RWMutex - config ProviderConfig // do not access directly, use Get() -} - -func newProviderConfigRepo(pc ProviderConfig) *providerConfigRepo { - return &providerConfigRepo{sync.RWMutex{}, pc} -} - -// returns an error to implement ProviderConfigSetter -func (r *providerConfigRepo) Set(cfg ProviderConfig) error { - r.mu.Lock() - defer r.mu.Unlock() - r.config = cfg - return nil -} - -func (r *providerConfigRepo) Get() ProviderConfig { - r.mu.RLock() - defer r.mu.RUnlock() - return r.config -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/identity.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/identity.go deleted file mode 100644 index 9bfa8e3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/identity.go +++ /dev/null @@ -1,44 +0,0 @@ -package oidc - -import ( - "errors" - "time" - - "github.com/coreos/go-oidc/jose" -) - -type Identity struct { - ID string - Name string - Email string - ExpiresAt time.Time -} - -func IdentityFromClaims(claims jose.Claims) (*Identity, error) { - if claims == nil { - return nil, errors.New("nil claim set") - } - - var ident Identity - var err error - var ok bool - - if ident.ID, ok, err = claims.StringClaim("sub"); err != nil { - return nil, err - } else if !ok { - return nil, errors.New("missing required claim: sub") - } - - if ident.Email, _, err = claims.StringClaim("email"); err != nil { - return nil, err - } - - exp, ok, err := claims.TimeClaim("exp") - if err != nil { - return nil, err - } else if ok { - ident.ExpiresAt = exp - } - - return &ident, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/interface.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/interface.go deleted file mode 100644 index 248cac0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/interface.go +++ /dev/null @@ -1,3 +0,0 @@ -package oidc - -type LoginFunc func(ident Identity, sessionKey string) (redirectURL string, err error) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/key.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/key.go deleted file mode 100755 index 82a0f56..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/key.go +++ /dev/null @@ -1,67 +0,0 @@ -package oidc - -import ( - "encoding/json" - "errors" - "net/http" - "time" - - phttp "github.com/coreos/go-oidc/http" - "github.com/coreos/go-oidc/jose" - "github.com/coreos/go-oidc/key" -) - -// DefaultPublicKeySetTTL is the default TTL set on the PublicKeySet if no -// Cache-Control header is provided by the JWK Set document endpoint. -const DefaultPublicKeySetTTL = 24 * time.Hour - -// NewRemotePublicKeyRepo is responsible for fetching the JWK Set document. -func NewRemotePublicKeyRepo(hc phttp.Client, ep string) *remotePublicKeyRepo { - return &remotePublicKeyRepo{hc: hc, ep: ep} -} - -type remotePublicKeyRepo struct { - hc phttp.Client - ep string -} - -// Get returns a PublicKeySet fetched from the JWK Set document endpoint. A TTL -// is set on the Key Set to avoid it having to be re-retrieved for every -// encryption event. This TTL is typically controlled by the endpoint returning -// a Cache-Control header, but defaults to 24 hours if no Cache-Control header -// is found. -func (r *remotePublicKeyRepo) Get() (key.KeySet, error) { - req, err := http.NewRequest("GET", r.ep, nil) - if err != nil { - return nil, err - } - - resp, err := r.hc.Do(req) - if err != nil { - return nil, err - } - defer resp.Body.Close() - - var d struct { - Keys []jose.JWK `json:"keys"` - } - if err := json.NewDecoder(resp.Body).Decode(&d); err != nil { - return nil, err - } - - if len(d.Keys) == 0 { - return nil, errors.New("zero keys in response") - } - - ttl, ok, err := phttp.Cacheable(resp.Header) - if err != nil { - return nil, err - } - if !ok { - ttl = DefaultPublicKeySetTTL - } - - exp := time.Now().UTC().Add(ttl) - ks := key.NewPublicKeySet(d.Keys, exp) - return ks, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/provider.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/provider.go deleted file mode 100644 index ca28384..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/provider.go +++ /dev/null @@ -1,690 +0,0 @@ -package oidc - -import ( - "encoding/json" - "errors" - "fmt" - "log" - "net/http" - "net/url" - "strings" - "sync" - "time" - - "github.com/coreos/pkg/timeutil" - "github.com/jonboulle/clockwork" - - phttp "github.com/coreos/go-oidc/http" - "github.com/coreos/go-oidc/oauth2" -) - -const ( - // Subject Identifier types defined by the OIDC spec. Specifies if the provider - // should provide the same sub claim value to all clients (public) or a unique - // value for each client (pairwise). - // - // See: http://openid.net/specs/openid-connect-core-1_0.html#SubjectIDTypes - SubjectTypePublic = "public" - SubjectTypePairwise = "pairwise" -) - -var ( - // Default values for omitted provider config fields. - // - // Use ProviderConfig's Defaults method to fill a provider config with these values. - DefaultGrantTypesSupported = []string{oauth2.GrantTypeAuthCode, oauth2.GrantTypeImplicit} - DefaultResponseModesSupported = []string{"query", "fragment"} - DefaultTokenEndpointAuthMethodsSupported = []string{oauth2.AuthMethodClientSecretBasic} - DefaultClaimTypesSupported = []string{"normal"} -) - -const ( - MaximumProviderConfigSyncInterval = 24 * time.Hour - MinimumProviderConfigSyncInterval = time.Minute - - discoveryConfigPath = "/.well-known/openid-configuration" -) - -// internally configurable for tests -var minimumProviderConfigSyncInterval = MinimumProviderConfigSyncInterval - -var ( - // Ensure ProviderConfig satisfies these interfaces. - _ json.Marshaler = &ProviderConfig{} - _ json.Unmarshaler = &ProviderConfig{} -) - -// ProviderConfig represents the OpenID Provider Metadata specifying what -// configurations a provider supports. -// -// See: http://openid.net/specs/openid-connect-discovery-1_0.html#ProviderMetadata -type ProviderConfig struct { - Issuer *url.URL // Required - AuthEndpoint *url.URL // Required - TokenEndpoint *url.URL // Required if grant types other than "implicit" are supported - UserInfoEndpoint *url.URL - KeysEndpoint *url.URL // Required - RegistrationEndpoint *url.URL - EndSessionEndpoint *url.URL - CheckSessionIFrame *url.URL - - // Servers MAY choose not to advertise some supported scope values even when this - // parameter is used, although those defined in OpenID Core SHOULD be listed, if supported. - ScopesSupported []string - // OAuth2.0 response types supported. - ResponseTypesSupported []string // Required - // OAuth2.0 response modes supported. - // - // If omitted, defaults to DefaultResponseModesSupported. - ResponseModesSupported []string - // OAuth2.0 grant types supported. - // - // If omitted, defaults to DefaultGrantTypesSupported. - GrantTypesSupported []string - ACRValuesSupported []string - // SubjectTypesSupported specifies strategies for providing values for the sub claim. - SubjectTypesSupported []string // Required - - // JWA signing and encryption algorith values supported for ID tokens. - IDTokenSigningAlgValues []string // Required - IDTokenEncryptionAlgValues []string - IDTokenEncryptionEncValues []string - - // JWA signing and encryption algorith values supported for user info responses. - UserInfoSigningAlgValues []string - UserInfoEncryptionAlgValues []string - UserInfoEncryptionEncValues []string - - // JWA signing and encryption algorith values supported for request objects. - ReqObjSigningAlgValues []string - ReqObjEncryptionAlgValues []string - ReqObjEncryptionEncValues []string - - TokenEndpointAuthMethodsSupported []string - TokenEndpointAuthSigningAlgValuesSupported []string - DisplayValuesSupported []string - ClaimTypesSupported []string - ClaimsSupported []string - ServiceDocs *url.URL - ClaimsLocalsSupported []string - UILocalsSupported []string - ClaimsParameterSupported bool - RequestParameterSupported bool - RequestURIParamaterSupported bool - RequireRequestURIRegistration bool - - Policy *url.URL - TermsOfService *url.URL - - // Not part of the OpenID Provider Metadata - ExpiresAt time.Time -} - -// Defaults returns a shallow copy of ProviderConfig with default -// values replacing omitted fields. -// -// var cfg oidc.ProviderConfig -// // Fill provider config with default values for omitted fields. -// cfg = cfg.Defaults() -// -func (p ProviderConfig) Defaults() ProviderConfig { - setDefault := func(val *[]string, defaultVal []string) { - if len(*val) == 0 { - *val = defaultVal - } - } - setDefault(&p.GrantTypesSupported, DefaultGrantTypesSupported) - setDefault(&p.ResponseModesSupported, DefaultResponseModesSupported) - setDefault(&p.TokenEndpointAuthMethodsSupported, DefaultTokenEndpointAuthMethodsSupported) - setDefault(&p.ClaimTypesSupported, DefaultClaimTypesSupported) - return p -} - -func (p *ProviderConfig) MarshalJSON() ([]byte, error) { - e := p.toEncodableStruct() - return json.Marshal(&e) -} - -func (p *ProviderConfig) UnmarshalJSON(data []byte) error { - var e encodableProviderConfig - if err := json.Unmarshal(data, &e); err != nil { - return err - } - conf, err := e.toStruct() - if err != nil { - return err - } - if err := conf.Valid(); err != nil { - return err - } - *p = conf - return nil -} - -type encodableProviderConfig struct { - Issuer string `json:"issuer"` - AuthEndpoint string `json:"authorization_endpoint"` - TokenEndpoint string `json:"token_endpoint"` - UserInfoEndpoint string `json:"userinfo_endpoint,omitempty"` - KeysEndpoint string `json:"jwks_uri"` - RegistrationEndpoint string `json:"registration_endpoint,omitempty"` - EndSessionEndpoint string `json:"end_session_endpoint,omitempty"` - CheckSessionIFrame string `json:"check_session_iframe,omitempty"` - - // Use 'omitempty' for all slices as per OIDC spec: - // "Claims that return multiple values are represented as JSON arrays. - // Claims with zero elements MUST be omitted from the response." - // http://openid.net/specs/openid-connect-discovery-1_0.html#ProviderConfigurationResponse - - ScopesSupported []string `json:"scopes_supported,omitempty"` - ResponseTypesSupported []string `json:"response_types_supported,omitempty"` - ResponseModesSupported []string `json:"response_modes_supported,omitempty"` - GrantTypesSupported []string `json:"grant_types_supported,omitempty"` - ACRValuesSupported []string `json:"acr_values_supported,omitempty"` - SubjectTypesSupported []string `json:"subject_types_supported,omitempty"` - - IDTokenSigningAlgValues []string `json:"id_token_signing_alg_values_supported,omitempty"` - IDTokenEncryptionAlgValues []string `json:"id_token_encryption_alg_values_supported,omitempty"` - IDTokenEncryptionEncValues []string `json:"id_token_encryption_enc_values_supported,omitempty"` - UserInfoSigningAlgValues []string `json:"userinfo_signing_alg_values_supported,omitempty"` - UserInfoEncryptionAlgValues []string `json:"userinfo_encryption_alg_values_supported,omitempty"` - UserInfoEncryptionEncValues []string `json:"userinfo_encryption_enc_values_supported,omitempty"` - ReqObjSigningAlgValues []string `json:"request_object_signing_alg_values_supported,omitempty"` - ReqObjEncryptionAlgValues []string `json:"request_object_encryption_alg_values_supported,omitempty"` - ReqObjEncryptionEncValues []string `json:"request_object_encryption_enc_values_supported,omitempty"` - - TokenEndpointAuthMethodsSupported []string `json:"token_endpoint_auth_methods_supported,omitempty"` - TokenEndpointAuthSigningAlgValuesSupported []string `json:"token_endpoint_auth_signing_alg_values_supported,omitempty"` - - DisplayValuesSupported []string `json:"display_values_supported,omitempty"` - ClaimTypesSupported []string `json:"claim_types_supported,omitempty"` - ClaimsSupported []string `json:"claims_supported,omitempty"` - ServiceDocs string `json:"service_documentation,omitempty"` - ClaimsLocalsSupported []string `json:"claims_locales_supported,omitempty"` - UILocalsSupported []string `json:"ui_locales_supported,omitempty"` - ClaimsParameterSupported bool `json:"claims_parameter_supported,omitempty"` - RequestParameterSupported bool `json:"request_parameter_supported,omitempty"` - RequestURIParamaterSupported bool `json:"request_uri_parameter_supported,omitempty"` - RequireRequestURIRegistration bool `json:"require_request_uri_registration,omitempty"` - - Policy string `json:"op_policy_uri,omitempty"` - TermsOfService string `json:"op_tos_uri,omitempty"` -} - -func (cfg ProviderConfig) toEncodableStruct() encodableProviderConfig { - return encodableProviderConfig{ - Issuer: uriToString(cfg.Issuer), - AuthEndpoint: uriToString(cfg.AuthEndpoint), - TokenEndpoint: uriToString(cfg.TokenEndpoint), - UserInfoEndpoint: uriToString(cfg.UserInfoEndpoint), - KeysEndpoint: uriToString(cfg.KeysEndpoint), - RegistrationEndpoint: uriToString(cfg.RegistrationEndpoint), - EndSessionEndpoint: uriToString(cfg.EndSessionEndpoint), - CheckSessionIFrame: uriToString(cfg.CheckSessionIFrame), - ScopesSupported: cfg.ScopesSupported, - ResponseTypesSupported: cfg.ResponseTypesSupported, - ResponseModesSupported: cfg.ResponseModesSupported, - GrantTypesSupported: cfg.GrantTypesSupported, - ACRValuesSupported: cfg.ACRValuesSupported, - SubjectTypesSupported: cfg.SubjectTypesSupported, - IDTokenSigningAlgValues: cfg.IDTokenSigningAlgValues, - IDTokenEncryptionAlgValues: cfg.IDTokenEncryptionAlgValues, - IDTokenEncryptionEncValues: cfg.IDTokenEncryptionEncValues, - UserInfoSigningAlgValues: cfg.UserInfoSigningAlgValues, - UserInfoEncryptionAlgValues: cfg.UserInfoEncryptionAlgValues, - UserInfoEncryptionEncValues: cfg.UserInfoEncryptionEncValues, - ReqObjSigningAlgValues: cfg.ReqObjSigningAlgValues, - ReqObjEncryptionAlgValues: cfg.ReqObjEncryptionAlgValues, - ReqObjEncryptionEncValues: cfg.ReqObjEncryptionEncValues, - TokenEndpointAuthMethodsSupported: cfg.TokenEndpointAuthMethodsSupported, - TokenEndpointAuthSigningAlgValuesSupported: cfg.TokenEndpointAuthSigningAlgValuesSupported, - DisplayValuesSupported: cfg.DisplayValuesSupported, - ClaimTypesSupported: cfg.ClaimTypesSupported, - ClaimsSupported: cfg.ClaimsSupported, - ServiceDocs: uriToString(cfg.ServiceDocs), - ClaimsLocalsSupported: cfg.ClaimsLocalsSupported, - UILocalsSupported: cfg.UILocalsSupported, - ClaimsParameterSupported: cfg.ClaimsParameterSupported, - RequestParameterSupported: cfg.RequestParameterSupported, - RequestURIParamaterSupported: cfg.RequestURIParamaterSupported, - RequireRequestURIRegistration: cfg.RequireRequestURIRegistration, - Policy: uriToString(cfg.Policy), - TermsOfService: uriToString(cfg.TermsOfService), - } -} - -func (e encodableProviderConfig) toStruct() (ProviderConfig, error) { - p := stickyErrParser{} - conf := ProviderConfig{ - Issuer: p.parseURI(e.Issuer, "issuer"), - AuthEndpoint: p.parseURI(e.AuthEndpoint, "authorization_endpoint"), - TokenEndpoint: p.parseURI(e.TokenEndpoint, "token_endpoint"), - UserInfoEndpoint: p.parseURI(e.UserInfoEndpoint, "userinfo_endpoint"), - KeysEndpoint: p.parseURI(e.KeysEndpoint, "jwks_uri"), - RegistrationEndpoint: p.parseURI(e.RegistrationEndpoint, "registration_endpoint"), - EndSessionEndpoint: p.parseURI(e.EndSessionEndpoint, "end_session_endpoint"), - CheckSessionIFrame: p.parseURI(e.CheckSessionIFrame, "check_session_iframe"), - ScopesSupported: e.ScopesSupported, - ResponseTypesSupported: e.ResponseTypesSupported, - ResponseModesSupported: e.ResponseModesSupported, - GrantTypesSupported: e.GrantTypesSupported, - ACRValuesSupported: e.ACRValuesSupported, - SubjectTypesSupported: e.SubjectTypesSupported, - IDTokenSigningAlgValues: e.IDTokenSigningAlgValues, - IDTokenEncryptionAlgValues: e.IDTokenEncryptionAlgValues, - IDTokenEncryptionEncValues: e.IDTokenEncryptionEncValues, - UserInfoSigningAlgValues: e.UserInfoSigningAlgValues, - UserInfoEncryptionAlgValues: e.UserInfoEncryptionAlgValues, - UserInfoEncryptionEncValues: e.UserInfoEncryptionEncValues, - ReqObjSigningAlgValues: e.ReqObjSigningAlgValues, - ReqObjEncryptionAlgValues: e.ReqObjEncryptionAlgValues, - ReqObjEncryptionEncValues: e.ReqObjEncryptionEncValues, - TokenEndpointAuthMethodsSupported: e.TokenEndpointAuthMethodsSupported, - TokenEndpointAuthSigningAlgValuesSupported: e.TokenEndpointAuthSigningAlgValuesSupported, - DisplayValuesSupported: e.DisplayValuesSupported, - ClaimTypesSupported: e.ClaimTypesSupported, - ClaimsSupported: e.ClaimsSupported, - ServiceDocs: p.parseURI(e.ServiceDocs, "service_documentation"), - ClaimsLocalsSupported: e.ClaimsLocalsSupported, - UILocalsSupported: e.UILocalsSupported, - ClaimsParameterSupported: e.ClaimsParameterSupported, - RequestParameterSupported: e.RequestParameterSupported, - RequestURIParamaterSupported: e.RequestURIParamaterSupported, - RequireRequestURIRegistration: e.RequireRequestURIRegistration, - Policy: p.parseURI(e.Policy, "op_policy-uri"), - TermsOfService: p.parseURI(e.TermsOfService, "op_tos_uri"), - } - if p.firstErr != nil { - return ProviderConfig{}, p.firstErr - } - return conf, nil -} - -// Empty returns if a ProviderConfig holds no information. -// -// This case generally indicates a ProviderConfigGetter has experienced an error -// and has nothing to report. -func (p ProviderConfig) Empty() bool { - return p.Issuer == nil -} - -func contains(sli []string, ele string) bool { - for _, s := range sli { - if s == ele { - return true - } - } - return false -} - -// Valid determines if a ProviderConfig conforms with the OIDC specification. -// If Valid returns successfully it guarantees required field are non-nil and -// URLs are well formed. -// -// Valid is called by UnmarshalJSON. -// -// NOTE(ericchiang): For development purposes Valid does not mandate 'https' for -// URLs fields where the OIDC spec requires it. This may change in future releases -// of this package. See: https://github.com/coreos/go-oidc/issues/34 -func (p ProviderConfig) Valid() error { - grantTypes := p.GrantTypesSupported - if len(grantTypes) == 0 { - grantTypes = DefaultGrantTypesSupported - } - implicitOnly := true - for _, grantType := range grantTypes { - if grantType != oauth2.GrantTypeImplicit { - implicitOnly = false - break - } - } - - if len(p.SubjectTypesSupported) == 0 { - return errors.New("missing required field subject_types_supported") - } - if len(p.IDTokenSigningAlgValues) == 0 { - return errors.New("missing required field id_token_signing_alg_values_supported") - } - - if len(p.ScopesSupported) != 0 && !contains(p.ScopesSupported, "openid") { - return errors.New("scoped_supported must be unspecified or include 'openid'") - } - - if !contains(p.IDTokenSigningAlgValues, "RS256") { - return errors.New("id_token_signing_alg_values_supported must include 'RS256'") - } - if contains(p.TokenEndpointAuthMethodsSupported, "none") { - return errors.New("token_endpoint_auth_signing_alg_values_supported cannot include 'none'") - } - - uris := []struct { - val *url.URL - name string - required bool - }{ - {p.Issuer, "issuer", true}, - {p.AuthEndpoint, "authorization_endpoint", true}, - {p.TokenEndpoint, "token_endpoint", !implicitOnly}, - {p.UserInfoEndpoint, "userinfo_endpoint", false}, - {p.KeysEndpoint, "jwks_uri", true}, - {p.RegistrationEndpoint, "registration_endpoint", false}, - {p.EndSessionEndpoint, "end_session_endpoint", false}, - {p.CheckSessionIFrame, "check_session_iframe", false}, - {p.ServiceDocs, "service_documentation", false}, - {p.Policy, "op_policy_uri", false}, - {p.TermsOfService, "op_tos_uri", false}, - } - - for _, uri := range uris { - if uri.val == nil { - if !uri.required { - continue - } - return fmt.Errorf("empty value for required uri field %s", uri.name) - } - if uri.val.Host == "" { - return fmt.Errorf("no host for uri field %s", uri.name) - } - if uri.val.Scheme != "http" && uri.val.Scheme != "https" { - return fmt.Errorf("uri field %s schemeis not http or https", uri.name) - } - } - return nil -} - -// Supports determines if provider supports a client given their respective metadata. -func (p ProviderConfig) Supports(c ClientMetadata) error { - if err := p.Valid(); err != nil { - return fmt.Errorf("invalid provider config: %v", err) - } - if err := c.Valid(); err != nil { - return fmt.Errorf("invalid client config: %v", err) - } - - // Fill default values for omitted fields - c = c.Defaults() - p = p.Defaults() - - // Do the supported values list the requested one? - supports := []struct { - supported []string - requested string - name string - }{ - {p.IDTokenSigningAlgValues, c.IDTokenResponseOptions.SigningAlg, "id_token_signed_response_alg"}, - {p.IDTokenEncryptionAlgValues, c.IDTokenResponseOptions.EncryptionAlg, "id_token_encryption_response_alg"}, - {p.IDTokenEncryptionEncValues, c.IDTokenResponseOptions.EncryptionEnc, "id_token_encryption_response_enc"}, - {p.UserInfoSigningAlgValues, c.UserInfoResponseOptions.SigningAlg, "userinfo_signed_response_alg"}, - {p.UserInfoEncryptionAlgValues, c.UserInfoResponseOptions.EncryptionAlg, "userinfo_encryption_response_alg"}, - {p.UserInfoEncryptionEncValues, c.UserInfoResponseOptions.EncryptionEnc, "userinfo_encryption_response_enc"}, - {p.ReqObjSigningAlgValues, c.RequestObjectOptions.SigningAlg, "request_object_signing_alg"}, - {p.ReqObjEncryptionAlgValues, c.RequestObjectOptions.EncryptionAlg, "request_object_encryption_alg"}, - {p.ReqObjEncryptionEncValues, c.RequestObjectOptions.EncryptionEnc, "request_object_encryption_enc"}, - } - for _, field := range supports { - if field.requested == "" { - continue - } - if !contains(field.supported, field.requested) { - return fmt.Errorf("provider does not support requested value for field %s", field.name) - } - } - - stringsEqual := func(s1, s2 string) bool { return s1 == s2 } - - // For lists, are the list of requested values a subset of the supported ones? - supportsAll := []struct { - supported []string - requested []string - name string - // OAuth2.0 response_type can be space separated lists where order doesn't matter. - // For example "id_token token" is the same as "token id_token" - // Support a custom compare method. - comp func(s1, s2 string) bool - }{ - {p.GrantTypesSupported, c.GrantTypes, "grant_types", stringsEqual}, - {p.ResponseTypesSupported, c.ResponseTypes, "response_type", oauth2.ResponseTypesEqual}, - } - for _, field := range supportsAll { - requestLoop: - for _, req := range field.requested { - for _, sup := range field.supported { - if field.comp(req, sup) { - continue requestLoop - } - } - return fmt.Errorf("provider does not support requested value for field %s", field.name) - } - } - - // TODO(ericchiang): Are there more checks we feel comfortable with begin strict about? - - return nil -} - -func (p ProviderConfig) SupportsGrantType(grantType string) bool { - var supported []string - if len(p.GrantTypesSupported) == 0 { - supported = DefaultGrantTypesSupported - } else { - supported = p.GrantTypesSupported - } - - for _, t := range supported { - if t == grantType { - return true - } - } - return false -} - -type ProviderConfigGetter interface { - Get() (ProviderConfig, error) -} - -type ProviderConfigSetter interface { - Set(ProviderConfig) error -} - -type ProviderConfigSyncer struct { - from ProviderConfigGetter - to ProviderConfigSetter - clock clockwork.Clock - - initialSyncDone bool - initialSyncWait sync.WaitGroup -} - -func NewProviderConfigSyncer(from ProviderConfigGetter, to ProviderConfigSetter) *ProviderConfigSyncer { - return &ProviderConfigSyncer{ - from: from, - to: to, - clock: clockwork.NewRealClock(), - } -} - -func (s *ProviderConfigSyncer) Run() chan struct{} { - stop := make(chan struct{}) - - var next pcsStepper - next = &pcsStepNext{aft: time.Duration(0)} - - s.initialSyncWait.Add(1) - go func() { - for { - select { - case <-s.clock.After(next.after()): - next = next.step(s.sync) - case <-stop: - return - } - } - }() - - return stop -} - -func (s *ProviderConfigSyncer) WaitUntilInitialSync() { - s.initialSyncWait.Wait() -} - -func (s *ProviderConfigSyncer) sync() (time.Duration, error) { - cfg, err := s.from.Get() - if err != nil { - return 0, err - } - - if err = s.to.Set(cfg); err != nil { - return 0, fmt.Errorf("error setting provider config: %v", err) - } - - if !s.initialSyncDone { - s.initialSyncWait.Done() - s.initialSyncDone = true - } - - return nextSyncAfter(cfg.ExpiresAt, s.clock), nil -} - -type pcsStepFunc func() (time.Duration, error) - -type pcsStepper interface { - after() time.Duration - step(pcsStepFunc) pcsStepper -} - -type pcsStepNext struct { - aft time.Duration -} - -func (n *pcsStepNext) after() time.Duration { - return n.aft -} - -func (n *pcsStepNext) step(fn pcsStepFunc) (next pcsStepper) { - ttl, err := fn() - if err == nil { - next = &pcsStepNext{aft: ttl} - } else { - next = &pcsStepRetry{aft: time.Second} - log.Printf("go-oidc: provider config sync falied, retyring in %v: %v", next.after(), err) - } - return -} - -type pcsStepRetry struct { - aft time.Duration -} - -func (r *pcsStepRetry) after() time.Duration { - return r.aft -} - -func (r *pcsStepRetry) step(fn pcsStepFunc) (next pcsStepper) { - ttl, err := fn() - if err == nil { - next = &pcsStepNext{aft: ttl} - } else { - next = &pcsStepRetry{aft: timeutil.ExpBackoff(r.aft, time.Minute)} - log.Printf("go-oidc: provider config sync falied, retyring in %v: %v", next.after(), err) - } - return -} - -func nextSyncAfter(exp time.Time, clock clockwork.Clock) time.Duration { - if exp.IsZero() { - return MaximumProviderConfigSyncInterval - } - - t := exp.Sub(clock.Now()) / 2 - if t > MaximumProviderConfigSyncInterval { - t = MaximumProviderConfigSyncInterval - } else if t < minimumProviderConfigSyncInterval { - t = minimumProviderConfigSyncInterval - } - - return t -} - -type httpProviderConfigGetter struct { - hc phttp.Client - issuerURL string - clock clockwork.Clock -} - -func NewHTTPProviderConfigGetter(hc phttp.Client, issuerURL string) *httpProviderConfigGetter { - return &httpProviderConfigGetter{ - hc: hc, - issuerURL: issuerURL, - clock: clockwork.NewRealClock(), - } -} - -func (r *httpProviderConfigGetter) Get() (cfg ProviderConfig, err error) { - // If the Issuer value contains a path component, any terminating / MUST be removed before - // appending /.well-known/openid-configuration. - // https://openid.net/specs/openid-connect-discovery-1_0.html#ProviderConfigurationRequest - discoveryURL := strings.TrimSuffix(r.issuerURL, "/") + discoveryConfigPath - req, err := http.NewRequest("GET", discoveryURL, nil) - if err != nil { - return - } - - resp, err := r.hc.Do(req) - if err != nil { - return - } - defer resp.Body.Close() - - if err = json.NewDecoder(resp.Body).Decode(&cfg); err != nil { - return - } - - var ttl time.Duration - var ok bool - ttl, ok, err = phttp.Cacheable(resp.Header) - if err != nil { - return - } else if ok { - cfg.ExpiresAt = r.clock.Now().UTC().Add(ttl) - } - - // The issuer value returned MUST be identical to the Issuer URL that was directly used to retrieve the configuration information. - // http://openid.net/specs/openid-connect-discovery-1_0.html#ProviderConfigurationValidation - if !urlEqual(cfg.Issuer.String(), r.issuerURL) { - err = fmt.Errorf(`"issuer" in config (%v) does not match provided issuer URL (%v)`, cfg.Issuer, r.issuerURL) - return - } - - return -} - -func FetchProviderConfig(hc phttp.Client, issuerURL string) (ProviderConfig, error) { - if hc == nil { - hc = http.DefaultClient - } - - g := NewHTTPProviderConfigGetter(hc, issuerURL) - return g.Get() -} - -func WaitForProviderConfig(hc phttp.Client, issuerURL string) (pcfg ProviderConfig) { - return waitForProviderConfig(hc, issuerURL, clockwork.NewRealClock()) -} - -func waitForProviderConfig(hc phttp.Client, issuerURL string, clock clockwork.Clock) (pcfg ProviderConfig) { - var sleep time.Duration - var err error - for { - pcfg, err = FetchProviderConfig(hc, issuerURL) - if err == nil { - break - } - - sleep = timeutil.ExpBackoff(sleep, time.Minute) - fmt.Printf("Failed fetching provider config, trying again in %v: %v\n", sleep, err) - time.Sleep(sleep) - } - - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/transport.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/transport.go deleted file mode 100644 index 61c926d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/transport.go +++ /dev/null @@ -1,88 +0,0 @@ -package oidc - -import ( - "fmt" - "net/http" - "sync" - - phttp "github.com/coreos/go-oidc/http" - "github.com/coreos/go-oidc/jose" -) - -type TokenRefresher interface { - // Verify checks if the provided token is currently valid or not. - Verify(jose.JWT) error - - // Refresh attempts to authenticate and retrieve a new token. - Refresh() (jose.JWT, error) -} - -type ClientCredsTokenRefresher struct { - Issuer string - OIDCClient *Client -} - -func (c *ClientCredsTokenRefresher) Verify(jwt jose.JWT) (err error) { - _, err = VerifyClientClaims(jwt, c.Issuer) - return -} - -func (c *ClientCredsTokenRefresher) Refresh() (jwt jose.JWT, err error) { - if err = c.OIDCClient.Healthy(); err != nil { - err = fmt.Errorf("unable to authenticate, unhealthy OIDC client: %v", err) - return - } - - jwt, err = c.OIDCClient.ClientCredsToken([]string{"openid"}) - if err != nil { - err = fmt.Errorf("unable to verify auth code with issuer: %v", err) - return - } - - return -} - -type AuthenticatedTransport struct { - TokenRefresher - http.RoundTripper - - mu sync.Mutex - jwt jose.JWT -} - -func (t *AuthenticatedTransport) verifiedJWT() (jose.JWT, error) { - t.mu.Lock() - defer t.mu.Unlock() - - if t.TokenRefresher.Verify(t.jwt) == nil { - return t.jwt, nil - } - - jwt, err := t.TokenRefresher.Refresh() - if err != nil { - return jose.JWT{}, fmt.Errorf("unable to acquire valid JWT: %v", err) - } - - t.jwt = jwt - return t.jwt, nil -} - -// SetJWT sets the JWT held by the Transport. -// This is useful for cases in which you want to set an initial JWT. -func (t *AuthenticatedTransport) SetJWT(jwt jose.JWT) { - t.mu.Lock() - defer t.mu.Unlock() - - t.jwt = jwt -} - -func (t *AuthenticatedTransport) RoundTrip(r *http.Request) (*http.Response, error) { - jwt, err := t.verifiedJWT() - if err != nil { - return nil, err - } - - req := phttp.CopyRequest(r) - req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", jwt.Encode())) - return t.RoundTripper.RoundTrip(req) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/util.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/util.go deleted file mode 100644 index f2a5a19..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/util.go +++ /dev/null @@ -1,109 +0,0 @@ -package oidc - -import ( - "crypto/rand" - "encoding/base64" - "errors" - "fmt" - "net" - "net/http" - "net/url" - "strings" - "time" - - "github.com/coreos/go-oidc/jose" -) - -// RequestTokenExtractor funcs extract a raw encoded token from a request. -type RequestTokenExtractor func(r *http.Request) (string, error) - -// ExtractBearerToken is a RequestTokenExtractor which extracts a bearer token from a request's -// Authorization header. -func ExtractBearerToken(r *http.Request) (string, error) { - ah := r.Header.Get("Authorization") - if ah == "" { - return "", errors.New("missing Authorization header") - } - - if len(ah) <= 6 || strings.ToUpper(ah[0:6]) != "BEARER" { - return "", errors.New("should be a bearer token") - } - - val := ah[7:] - if len(val) == 0 { - return "", errors.New("bearer token is empty") - } - - return val, nil -} - -// CookieTokenExtractor returns a RequestTokenExtractor which extracts a token from the named cookie in a request. -func CookieTokenExtractor(cookieName string) RequestTokenExtractor { - return func(r *http.Request) (string, error) { - ck, err := r.Cookie(cookieName) - if err != nil { - return "", fmt.Errorf("token cookie not found in request: %v", err) - } - - if ck.Value == "" { - return "", errors.New("token cookie found but is empty") - } - - return ck.Value, nil - } -} - -func NewClaims(iss, sub string, aud interface{}, iat, exp time.Time) jose.Claims { - return jose.Claims{ - // required - "iss": iss, - "sub": sub, - "aud": aud, - "iat": iat.Unix(), - "exp": exp.Unix(), - } -} - -func GenClientID(hostport string) (string, error) { - b, err := randBytes(32) - if err != nil { - return "", err - } - - var host string - if strings.Contains(hostport, ":") { - host, _, err = net.SplitHostPort(hostport) - if err != nil { - return "", err - } - } else { - host = hostport - } - - return fmt.Sprintf("%s@%s", base64.URLEncoding.EncodeToString(b), host), nil -} - -func randBytes(n int) ([]byte, error) { - b := make([]byte, n) - got, err := rand.Read(b) - if err != nil { - return nil, err - } else if n != got { - return nil, errors.New("unable to generate enough random data") - } - return b, nil -} - -// urlEqual checks two urls for equality using only the host and path portions. -func urlEqual(url1, url2 string) bool { - u1, err := url.Parse(url1) - if err != nil { - return false - } - u2, err := url.Parse(url2) - if err != nil { - return false - } - - return strings.ToLower(u1.Host+u1.Path) == strings.ToLower(u2.Host+u2.Path) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/verification.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/verification.go deleted file mode 100644 index d9c6afa..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/go-oidc/oidc/verification.go +++ /dev/null @@ -1,190 +0,0 @@ -package oidc - -import ( - "errors" - "fmt" - "time" - - "github.com/jonboulle/clockwork" - - "github.com/coreos/go-oidc/jose" - "github.com/coreos/go-oidc/key" -) - -func VerifySignature(jwt jose.JWT, keys []key.PublicKey) (bool, error) { - jwtBytes := []byte(jwt.Data()) - for _, k := range keys { - v, err := k.Verifier() - if err != nil { - return false, err - } - if v.Verify(jwt.Signature, jwtBytes) == nil { - return true, nil - } - } - return false, nil -} - -// containsString returns true if the given string(needle) is found -// in the string array(haystack). -func containsString(needle string, haystack []string) bool { - for _, v := range haystack { - if v == needle { - return true - } - } - return false -} - -// Verify claims in accordance with OIDC spec -// http://openid.net/specs/openid-connect-basic-1_0.html#IDTokenValidation -func VerifyClaims(jwt jose.JWT, issuer, clientID string) error { - now := time.Now().UTC() - - claims, err := jwt.Claims() - if err != nil { - return err - } - - ident, err := IdentityFromClaims(claims) - if err != nil { - return err - } - - if ident.ExpiresAt.Before(now) { - return errors.New("token is expired") - } - - // iss REQUIRED. Issuer Identifier for the Issuer of the response. - // The iss value is a case sensitive URL using the https scheme that contains scheme, - // host, and optionally, port number and path components and no query or fragment components. - if iss, exists := claims["iss"].(string); exists { - if !urlEqual(iss, issuer) { - return fmt.Errorf("invalid claim value: 'iss'. expected=%s, found=%s.", issuer, iss) - } - } else { - return errors.New("missing claim: 'iss'") - } - - // iat REQUIRED. Time at which the JWT was issued. - // Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z - // as measured in UTC until the date/time. - if _, exists := claims["iat"].(float64); !exists { - return errors.New("missing claim: 'iat'") - } - - // aud REQUIRED. Audience(s) that this ID Token is intended for. - // It MUST contain the OAuth 2.0 client_id of the Relying Party as an audience value. - // It MAY also contain identifiers for other audiences. In the general case, the aud - // value is an array of case sensitive strings. In the common special case when there - // is one audience, the aud value MAY be a single case sensitive string. - if aud, ok, err := claims.StringClaim("aud"); err == nil && ok { - if aud != clientID { - return fmt.Errorf("invalid claims, 'aud' claim and 'client_id' do not match, aud=%s, client_id=%s", aud, clientID) - } - } else if aud, ok, err := claims.StringsClaim("aud"); err == nil && ok { - if !containsString(clientID, aud) { - return fmt.Errorf("invalid claims, cannot find 'client_id' in 'aud' claim, aud=%v, client_id=%s", aud, clientID) - } - } else { - return errors.New("invalid claim value: 'aud' is required, and should be either string or string array") - } - - return nil -} - -// VerifyClientClaims verifies all the required claims are valid for a "client credentials" JWT. -// Returns the client ID if valid, or an error if invalid. -func VerifyClientClaims(jwt jose.JWT, issuer string) (string, error) { - claims, err := jwt.Claims() - if err != nil { - return "", fmt.Errorf("failed to parse JWT claims: %v", err) - } - - iss, ok, err := claims.StringClaim("iss") - if err != nil { - return "", fmt.Errorf("failed to parse 'iss' claim: %v", err) - } else if !ok { - return "", errors.New("missing required 'iss' claim") - } else if !urlEqual(iss, issuer) { - return "", fmt.Errorf("'iss' claim does not match expected issuer, iss=%s", iss) - } - - sub, ok, err := claims.StringClaim("sub") - if err != nil { - return "", fmt.Errorf("failed to parse 'sub' claim: %v", err) - } else if !ok { - return "", errors.New("missing required 'sub' claim") - } - - if aud, ok, err := claims.StringClaim("aud"); err == nil && ok { - if aud != sub { - return "", fmt.Errorf("invalid claims, 'aud' claim and 'sub' claim do not match, aud=%s, sub=%s", aud, sub) - } - } else if aud, ok, err := claims.StringsClaim("aud"); err == nil && ok { - if !containsString(sub, aud) { - return "", fmt.Errorf("invalid claims, cannot find 'sud' in 'aud' claim, aud=%v, sub=%s", aud, sub) - } - } else { - return "", errors.New("invalid claim value: 'aud' is required, and should be either string or string array") - } - - now := time.Now().UTC() - exp, ok, err := claims.TimeClaim("exp") - if err != nil { - return "", fmt.Errorf("failed to parse 'exp' claim: %v", err) - } else if !ok { - return "", errors.New("missing required 'exp' claim") - } else if exp.Before(now) { - return "", fmt.Errorf("token already expired at: %v", exp) - } - - return sub, nil -} - -type JWTVerifier struct { - issuer string - clientID string - syncFunc func() error - keysFunc func() []key.PublicKey - clock clockwork.Clock -} - -func NewJWTVerifier(issuer, clientID string, syncFunc func() error, keysFunc func() []key.PublicKey) JWTVerifier { - return JWTVerifier{ - issuer: issuer, - clientID: clientID, - syncFunc: syncFunc, - keysFunc: keysFunc, - clock: clockwork.NewRealClock(), - } -} - -func (v *JWTVerifier) Verify(jwt jose.JWT) error { - // Verify claims before verifying the signature. This is an optimization to throw out - // tokens we know are invalid without undergoing an expensive signature check and - // possibly a re-sync event. - if err := VerifyClaims(jwt, v.issuer, v.clientID); err != nil { - return fmt.Errorf("oidc: JWT claims invalid: %v", err) - } - - ok, err := VerifySignature(jwt, v.keysFunc()) - if err != nil { - return fmt.Errorf("oidc: JWT signature verification failed: %v", err) - } else if ok { - return nil - } - - if err = v.syncFunc(); err != nil { - return fmt.Errorf("oidc: failed syncing KeySet: %v", err) - } - - ok, err = VerifySignature(jwt, v.keysFunc()) - if err != nil { - return fmt.Errorf("oidc: JWT signature verification failed: %v", err) - } else if !ok { - return errors.New("oidc: unable to verify JWT signature: no matching keys") - } - - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/README.md deleted file mode 100644 index 5ec34c2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/README.md +++ /dev/null @@ -1,11 +0,0 @@ -health -==== - -A simple framework for implementing an HTTP health check endpoint on servers. - -Users implement their `health.Checkable` types, and create a `health.Checker`, from which they can get an `http.HandlerFunc` using `health.Checker.MakeHealthHandlerFunc`. - -### Documentation - -For more details, visit the docs on [gopkgdoc](http://godoc.org/github.com/coreos/pkg/health) - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/health.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/health.go deleted file mode 100644 index a1c3610..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/health/health.go +++ /dev/null @@ -1,127 +0,0 @@ -package health - -import ( - "expvar" - "fmt" - "log" - "net/http" - - "github.com/coreos/pkg/httputil" -) - -// Checkables should return nil when the thing they are checking is healthy, and an error otherwise. -type Checkable interface { - Healthy() error -} - -// Checker provides a way to make an endpoint which can be probed for system health. -type Checker struct { - // Checks are the Checkables to be checked when probing. - Checks []Checkable - - // Unhealthyhandler is called when one or more of the checks are unhealthy. - // If not provided DefaultUnhealthyHandler is called. - UnhealthyHandler UnhealthyHandler - - // HealthyHandler is called when all checks are healthy. - // If not provided, DefaultHealthyHandler is called. - HealthyHandler http.HandlerFunc -} - -func (c Checker) ServeHTTP(w http.ResponseWriter, r *http.Request) { - unhealthyHandler := c.UnhealthyHandler - if unhealthyHandler == nil { - unhealthyHandler = DefaultUnhealthyHandler - } - - successHandler := c.HealthyHandler - if successHandler == nil { - successHandler = DefaultHealthyHandler - } - - if r.Method != "GET" { - w.Header().Set("Allow", "GET") - w.WriteHeader(http.StatusMethodNotAllowed) - return - } - - if err := Check(c.Checks); err != nil { - unhealthyHandler(w, r, err) - return - } - - successHandler(w, r) -} - -type UnhealthyHandler func(w http.ResponseWriter, r *http.Request, err error) - -type StatusResponse struct { - Status string `json:"status"` - Details *StatusResponseDetails `json:"details,omitempty"` -} - -type StatusResponseDetails struct { - Code int `json:"code,omitempty"` - Message string `json:"message,omitempty"` -} - -func Check(checks []Checkable) (err error) { - errs := []error{} - for _, c := range checks { - if e := c.Healthy(); e != nil { - errs = append(errs, e) - } - } - - switch len(errs) { - case 0: - err = nil - case 1: - err = errs[0] - default: - err = fmt.Errorf("multiple health check failure: %v", errs) - } - - return -} - -func DefaultHealthyHandler(w http.ResponseWriter, r *http.Request) { - err := httputil.WriteJSONResponse(w, http.StatusOK, StatusResponse{ - Status: "ok", - }) - if err != nil { - // TODO(bobbyrullo): replace with logging from new logging pkg, - // once it lands. - log.Printf("Failed to write JSON response: %v", err) - } -} - -func DefaultUnhealthyHandler(w http.ResponseWriter, r *http.Request, err error) { - writeErr := httputil.WriteJSONResponse(w, http.StatusInternalServerError, StatusResponse{ - Status: "error", - Details: &StatusResponseDetails{ - Code: http.StatusInternalServerError, - Message: err.Error(), - }, - }) - if writeErr != nil { - // TODO(bobbyrullo): replace with logging from new logging pkg, - // once it lands. - log.Printf("Failed to write JSON response: %v", err) - } -} - -// ExpvarHandler is copied from https://golang.org/src/expvar/expvar.go, where it's sadly unexported. -func ExpvarHandler(w http.ResponseWriter, r *http.Request) { - w.Header().Set("Content-Type", "application/json; charset=utf-8") - fmt.Fprintf(w, "{\n") - first := true - expvar.Do(func(kv expvar.KeyValue) { - if !first { - fmt.Fprintf(w, ",\n") - } - first = false - fmt.Fprintf(w, "%q: %s", kv.Key, kv.Value) - }) - fmt.Fprintf(w, "\n}\n") -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/README.md deleted file mode 100644 index 44fa751..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/README.md +++ /dev/null @@ -1,13 +0,0 @@ -httputil -==== - -Common code for dealing with HTTP. - -Includes: - -* Code for returning JSON responses. - -### Documentation - -Visit the docs on [gopkgdoc](http://godoc.org/github.com/coreos/pkg/httputil) - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/cookie.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/cookie.go deleted file mode 100644 index c37a37b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/cookie.go +++ /dev/null @@ -1,21 +0,0 @@ -package httputil - -import ( - "net/http" - "time" -) - -// DeleteCookies effectively deletes all named cookies -// by wiping all data and setting to expire immediately. -func DeleteCookies(w http.ResponseWriter, cookieNames ...string) { - for _, n := range cookieNames { - c := &http.Cookie{ - Name: n, - Value: "", - Path: "/", - MaxAge: -1, - Expires: time.Time{}, - } - http.SetCookie(w, c) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/json.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/json.go deleted file mode 100644 index 0b09235..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/httputil/json.go +++ /dev/null @@ -1,27 +0,0 @@ -package httputil - -import ( - "encoding/json" - "net/http" -) - -const ( - JSONContentType = "application/json" -) - -func WriteJSONResponse(w http.ResponseWriter, code int, resp interface{}) error { - enc, err := json.Marshal(resp) - if err != nil { - w.WriteHeader(http.StatusInternalServerError) - return err - } - - w.Header().Set("Content-Type", JSONContentType) - w.WriteHeader(code) - - _, err = w.Write(enc) - if err != nil { - return err - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/timeutil/backoff.go b/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/timeutil/backoff.go deleted file mode 100644 index b34fb49..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/coreos/pkg/timeutil/backoff.go +++ /dev/null @@ -1,15 +0,0 @@ -package timeutil - -import ( - "time" -) - -func ExpBackoff(prev, max time.Duration) time.Duration { - if prev == 0 { - return time.Second - } - if prev > max/2 { - return max - } - return 2 * prev -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypass.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypass.go deleted file mode 100644 index 565bf58..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypass.go +++ /dev/null @@ -1,151 +0,0 @@ -// Copyright (c) 2015 Dave Collins -// -// Permission to use, copy, modify, and distribute this software for any -// purpose with or without fee is hereby granted, provided that the above -// copyright notice and this permission notice appear in all copies. -// -// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -// NOTE: Due to the following build constraints, this file will only be compiled -// when the code is not running on Google App Engine and "-tags disableunsafe" -// is not added to the go build command line. -// +build !appengine,!disableunsafe - -package spew - -import ( - "reflect" - "unsafe" -) - -const ( - // UnsafeDisabled is a build-time constant which specifies whether or - // not access to the unsafe package is available. - UnsafeDisabled = false - - // ptrSize is the size of a pointer on the current arch. - ptrSize = unsafe.Sizeof((*byte)(nil)) -) - -var ( - // offsetPtr, offsetScalar, and offsetFlag are the offsets for the - // internal reflect.Value fields. These values are valid before golang - // commit ecccf07e7f9d which changed the format. The are also valid - // after commit 82f48826c6c7 which changed the format again to mirror - // the original format. Code in the init function updates these offsets - // as necessary. - offsetPtr = uintptr(ptrSize) - offsetScalar = uintptr(0) - offsetFlag = uintptr(ptrSize * 2) - - // flagKindWidth and flagKindShift indicate various bits that the - // reflect package uses internally to track kind information. - // - // flagRO indicates whether or not the value field of a reflect.Value is - // read-only. - // - // flagIndir indicates whether the value field of a reflect.Value is - // the actual data or a pointer to the data. - // - // These values are valid before golang commit 90a7c3c86944 which - // changed their positions. Code in the init function updates these - // flags as necessary. - flagKindWidth = uintptr(5) - flagKindShift = uintptr(flagKindWidth - 1) - flagRO = uintptr(1 << 0) - flagIndir = uintptr(1 << 1) -) - -func init() { - // Older versions of reflect.Value stored small integers directly in the - // ptr field (which is named val in the older versions). Versions - // between commits ecccf07e7f9d and 82f48826c6c7 added a new field named - // scalar for this purpose which unfortunately came before the flag - // field, so the offset of the flag field is different for those - // versions. - // - // This code constructs a new reflect.Value from a known small integer - // and checks if the size of the reflect.Value struct indicates it has - // the scalar field. When it does, the offsets are updated accordingly. - vv := reflect.ValueOf(0xf00) - if unsafe.Sizeof(vv) == (ptrSize * 4) { - offsetScalar = ptrSize * 2 - offsetFlag = ptrSize * 3 - } - - // Commit 90a7c3c86944 changed the flag positions such that the low - // order bits are the kind. This code extracts the kind from the flags - // field and ensures it's the correct type. When it's not, the flag - // order has been changed to the newer format, so the flags are updated - // accordingly. - upf := unsafe.Pointer(uintptr(unsafe.Pointer(&vv)) + offsetFlag) - upfv := *(*uintptr)(upf) - flagKindMask := uintptr((1<>flagKindShift != uintptr(reflect.Int) { - flagKindShift = 0 - flagRO = 1 << 5 - flagIndir = 1 << 6 - - // Commit adf9b30e5594 modified the flags to separate the - // flagRO flag into two bits which specifies whether or not the - // field is embedded. This causes flagIndir to move over a bit - // and means that flagRO is the combination of either of the - // original flagRO bit and the new bit. - // - // This code detects the change by extracting what used to be - // the indirect bit to ensure it's set. When it's not, the flag - // order has been changed to the newer format, so the flags are - // updated accordingly. - if upfv&flagIndir == 0 { - flagRO = 3 << 5 - flagIndir = 1 << 7 - } - } -} - -// unsafeReflectValue converts the passed reflect.Value into a one that bypasses -// the typical safety restrictions preventing access to unaddressable and -// unexported data. It works by digging the raw pointer to the underlying -// value out of the protected value and generating a new unprotected (unsafe) -// reflect.Value to it. -// -// This allows us to check for implementations of the Stringer and error -// interfaces to be used for pretty printing ordinarily unaddressable and -// inaccessible values such as unexported struct fields. -func unsafeReflectValue(v reflect.Value) (rv reflect.Value) { - indirects := 1 - vt := v.Type() - upv := unsafe.Pointer(uintptr(unsafe.Pointer(&v)) + offsetPtr) - rvf := *(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&v)) + offsetFlag)) - if rvf&flagIndir != 0 { - vt = reflect.PtrTo(v.Type()) - indirects++ - } else if offsetScalar != 0 { - // The value is in the scalar field when it's not one of the - // reference types. - switch vt.Kind() { - case reflect.Uintptr: - case reflect.Chan: - case reflect.Func: - case reflect.Map: - case reflect.Ptr: - case reflect.UnsafePointer: - default: - upv = unsafe.Pointer(uintptr(unsafe.Pointer(&v)) + - offsetScalar) - } - } - - pv := reflect.NewAt(vt, upv) - rv = pv - for i := 0; i < indirects; i++ { - rv = rv.Elem() - } - return rv -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go deleted file mode 100644 index 457e412..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/bypasssafe.go +++ /dev/null @@ -1,37 +0,0 @@ -// Copyright (c) 2015 Dave Collins -// -// Permission to use, copy, modify, and distribute this software for any -// purpose with or without fee is hereby granted, provided that the above -// copyright notice and this permission notice appear in all copies. -// -// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -// NOTE: Due to the following build constraints, this file will only be compiled -// when either the code is running on Google App Engine or "-tags disableunsafe" -// is added to the go build command line. -// +build appengine disableunsafe - -package spew - -import "reflect" - -const ( - // UnsafeDisabled is a build-time constant which specifies whether or - // not access to the unsafe package is available. - UnsafeDisabled = true -) - -// unsafeReflectValue typically converts the passed reflect.Value into a one -// that bypasses the typical safety restrictions preventing access to -// unaddressable and unexported data. However, doing this relies on access to -// the unsafe package. This is a stub version which simply returns the passed -// reflect.Value when the unsafe package is not available. -func unsafeReflectValue(v reflect.Value) reflect.Value { - return v -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/common.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/common.go deleted file mode 100644 index 14f02dc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/common.go +++ /dev/null @@ -1,341 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -package spew - -import ( - "bytes" - "fmt" - "io" - "reflect" - "sort" - "strconv" -) - -// Some constants in the form of bytes to avoid string overhead. This mirrors -// the technique used in the fmt package. -var ( - panicBytes = []byte("(PANIC=") - plusBytes = []byte("+") - iBytes = []byte("i") - trueBytes = []byte("true") - falseBytes = []byte("false") - interfaceBytes = []byte("(interface {})") - commaNewlineBytes = []byte(",\n") - newlineBytes = []byte("\n") - openBraceBytes = []byte("{") - openBraceNewlineBytes = []byte("{\n") - closeBraceBytes = []byte("}") - asteriskBytes = []byte("*") - colonBytes = []byte(":") - colonSpaceBytes = []byte(": ") - openParenBytes = []byte("(") - closeParenBytes = []byte(")") - spaceBytes = []byte(" ") - pointerChainBytes = []byte("->") - nilAngleBytes = []byte("") - maxNewlineBytes = []byte("\n") - maxShortBytes = []byte("") - circularBytes = []byte("") - circularShortBytes = []byte("") - invalidAngleBytes = []byte("") - openBracketBytes = []byte("[") - closeBracketBytes = []byte("]") - percentBytes = []byte("%") - precisionBytes = []byte(".") - openAngleBytes = []byte("<") - closeAngleBytes = []byte(">") - openMapBytes = []byte("map[") - closeMapBytes = []byte("]") - lenEqualsBytes = []byte("len=") - capEqualsBytes = []byte("cap=") -) - -// hexDigits is used to map a decimal value to a hex digit. -var hexDigits = "0123456789abcdef" - -// catchPanic handles any panics that might occur during the handleMethods -// calls. -func catchPanic(w io.Writer, v reflect.Value) { - if err := recover(); err != nil { - w.Write(panicBytes) - fmt.Fprintf(w, "%v", err) - w.Write(closeParenBytes) - } -} - -// handleMethods attempts to call the Error and String methods on the underlying -// type the passed reflect.Value represents and outputes the result to Writer w. -// -// It handles panics in any called methods by catching and displaying the error -// as the formatted value. -func handleMethods(cs *ConfigState, w io.Writer, v reflect.Value) (handled bool) { - // We need an interface to check if the type implements the error or - // Stringer interface. However, the reflect package won't give us an - // interface on certain things like unexported struct fields in order - // to enforce visibility rules. We use unsafe, when it's available, - // to bypass these restrictions since this package does not mutate the - // values. - if !v.CanInterface() { - if UnsafeDisabled { - return false - } - - v = unsafeReflectValue(v) - } - - // Choose whether or not to do error and Stringer interface lookups against - // the base type or a pointer to the base type depending on settings. - // Technically calling one of these methods with a pointer receiver can - // mutate the value, however, types which choose to satisify an error or - // Stringer interface with a pointer receiver should not be mutating their - // state inside these interface methods. - if !cs.DisablePointerMethods && !UnsafeDisabled && !v.CanAddr() { - v = unsafeReflectValue(v) - } - if v.CanAddr() { - v = v.Addr() - } - - // Is it an error or Stringer? - switch iface := v.Interface().(type) { - case error: - defer catchPanic(w, v) - if cs.ContinueOnMethod { - w.Write(openParenBytes) - w.Write([]byte(iface.Error())) - w.Write(closeParenBytes) - w.Write(spaceBytes) - return false - } - - w.Write([]byte(iface.Error())) - return true - - case fmt.Stringer: - defer catchPanic(w, v) - if cs.ContinueOnMethod { - w.Write(openParenBytes) - w.Write([]byte(iface.String())) - w.Write(closeParenBytes) - w.Write(spaceBytes) - return false - } - w.Write([]byte(iface.String())) - return true - } - return false -} - -// printBool outputs a boolean value as true or false to Writer w. -func printBool(w io.Writer, val bool) { - if val { - w.Write(trueBytes) - } else { - w.Write(falseBytes) - } -} - -// printInt outputs a signed integer value to Writer w. -func printInt(w io.Writer, val int64, base int) { - w.Write([]byte(strconv.FormatInt(val, base))) -} - -// printUint outputs an unsigned integer value to Writer w. -func printUint(w io.Writer, val uint64, base int) { - w.Write([]byte(strconv.FormatUint(val, base))) -} - -// printFloat outputs a floating point value using the specified precision, -// which is expected to be 32 or 64bit, to Writer w. -func printFloat(w io.Writer, val float64, precision int) { - w.Write([]byte(strconv.FormatFloat(val, 'g', -1, precision))) -} - -// printComplex outputs a complex value using the specified float precision -// for the real and imaginary parts to Writer w. -func printComplex(w io.Writer, c complex128, floatPrecision int) { - r := real(c) - w.Write(openParenBytes) - w.Write([]byte(strconv.FormatFloat(r, 'g', -1, floatPrecision))) - i := imag(c) - if i >= 0 { - w.Write(plusBytes) - } - w.Write([]byte(strconv.FormatFloat(i, 'g', -1, floatPrecision))) - w.Write(iBytes) - w.Write(closeParenBytes) -} - -// printHexPtr outputs a uintptr formatted as hexidecimal with a leading '0x' -// prefix to Writer w. -func printHexPtr(w io.Writer, p uintptr) { - // Null pointer. - num := uint64(p) - if num == 0 { - w.Write(nilAngleBytes) - return - } - - // Max uint64 is 16 bytes in hex + 2 bytes for '0x' prefix - buf := make([]byte, 18) - - // It's simpler to construct the hex string right to left. - base := uint64(16) - i := len(buf) - 1 - for num >= base { - buf[i] = hexDigits[num%base] - num /= base - i-- - } - buf[i] = hexDigits[num] - - // Add '0x' prefix. - i-- - buf[i] = 'x' - i-- - buf[i] = '0' - - // Strip unused leading bytes. - buf = buf[i:] - w.Write(buf) -} - -// valuesSorter implements sort.Interface to allow a slice of reflect.Value -// elements to be sorted. -type valuesSorter struct { - values []reflect.Value - strings []string // either nil or same len and values - cs *ConfigState -} - -// newValuesSorter initializes a valuesSorter instance, which holds a set of -// surrogate keys on which the data should be sorted. It uses flags in -// ConfigState to decide if and how to populate those surrogate keys. -func newValuesSorter(values []reflect.Value, cs *ConfigState) sort.Interface { - vs := &valuesSorter{values: values, cs: cs} - if canSortSimply(vs.values[0].Kind()) { - return vs - } - if !cs.DisableMethods { - vs.strings = make([]string, len(values)) - for i := range vs.values { - b := bytes.Buffer{} - if !handleMethods(cs, &b, vs.values[i]) { - vs.strings = nil - break - } - vs.strings[i] = b.String() - } - } - if vs.strings == nil && cs.SpewKeys { - vs.strings = make([]string, len(values)) - for i := range vs.values { - vs.strings[i] = Sprintf("%#v", vs.values[i].Interface()) - } - } - return vs -} - -// canSortSimply tests whether a reflect.Kind is a primitive that can be sorted -// directly, or whether it should be considered for sorting by surrogate keys -// (if the ConfigState allows it). -func canSortSimply(kind reflect.Kind) bool { - // This switch parallels valueSortLess, except for the default case. - switch kind { - case reflect.Bool: - return true - case reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64, reflect.Int: - return true - case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint: - return true - case reflect.Float32, reflect.Float64: - return true - case reflect.String: - return true - case reflect.Uintptr: - return true - case reflect.Array: - return true - } - return false -} - -// Len returns the number of values in the slice. It is part of the -// sort.Interface implementation. -func (s *valuesSorter) Len() int { - return len(s.values) -} - -// Swap swaps the values at the passed indices. It is part of the -// sort.Interface implementation. -func (s *valuesSorter) Swap(i, j int) { - s.values[i], s.values[j] = s.values[j], s.values[i] - if s.strings != nil { - s.strings[i], s.strings[j] = s.strings[j], s.strings[i] - } -} - -// valueSortLess returns whether the first value should sort before the second -// value. It is used by valueSorter.Less as part of the sort.Interface -// implementation. -func valueSortLess(a, b reflect.Value) bool { - switch a.Kind() { - case reflect.Bool: - return !a.Bool() && b.Bool() - case reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64, reflect.Int: - return a.Int() < b.Int() - case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint: - return a.Uint() < b.Uint() - case reflect.Float32, reflect.Float64: - return a.Float() < b.Float() - case reflect.String: - return a.String() < b.String() - case reflect.Uintptr: - return a.Uint() < b.Uint() - case reflect.Array: - // Compare the contents of both arrays. - l := a.Len() - for i := 0; i < l; i++ { - av := a.Index(i) - bv := b.Index(i) - if av.Interface() == bv.Interface() { - continue - } - return valueSortLess(av, bv) - } - } - return a.String() < b.String() -} - -// Less returns whether the value at index i should sort before the -// value at index j. It is part of the sort.Interface implementation. -func (s *valuesSorter) Less(i, j int) bool { - if s.strings == nil { - return valueSortLess(s.values[i], s.values[j]) - } - return s.strings[i] < s.strings[j] -} - -// sortValues is a sort function that handles both native types and any type that -// can be converted to error or Stringer. Other inputs are sorted according to -// their Value.String() value to ensure display stability. -func sortValues(values []reflect.Value, cs *ConfigState) { - if len(values) == 0 { - return - } - sort.Sort(newValuesSorter(values, cs)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/config.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/config.go deleted file mode 100644 index ee1ab07..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/config.go +++ /dev/null @@ -1,297 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -package spew - -import ( - "bytes" - "fmt" - "io" - "os" -) - -// ConfigState houses the configuration options used by spew to format and -// display values. There is a global instance, Config, that is used to control -// all top-level Formatter and Dump functionality. Each ConfigState instance -// provides methods equivalent to the top-level functions. -// -// The zero value for ConfigState provides no indentation. You would typically -// want to set it to a space or a tab. -// -// Alternatively, you can use NewDefaultConfig to get a ConfigState instance -// with default settings. See the documentation of NewDefaultConfig for default -// values. -type ConfigState struct { - // Indent specifies the string to use for each indentation level. The - // global config instance that all top-level functions use set this to a - // single space by default. If you would like more indentation, you might - // set this to a tab with "\t" or perhaps two spaces with " ". - Indent string - - // MaxDepth controls the maximum number of levels to descend into nested - // data structures. The default, 0, means there is no limit. - // - // NOTE: Circular data structures are properly detected, so it is not - // necessary to set this value unless you specifically want to limit deeply - // nested data structures. - MaxDepth int - - // DisableMethods specifies whether or not error and Stringer interfaces are - // invoked for types that implement them. - DisableMethods bool - - // DisablePointerMethods specifies whether or not to check for and invoke - // error and Stringer interfaces on types which only accept a pointer - // receiver when the current type is not a pointer. - // - // NOTE: This might be an unsafe action since calling one of these methods - // with a pointer receiver could technically mutate the value, however, - // in practice, types which choose to satisify an error or Stringer - // interface with a pointer receiver should not be mutating their state - // inside these interface methods. As a result, this option relies on - // access to the unsafe package, so it will not have any effect when - // running in environments without access to the unsafe package such as - // Google App Engine or with the "disableunsafe" build tag specified. - DisablePointerMethods bool - - // ContinueOnMethod specifies whether or not recursion should continue once - // a custom error or Stringer interface is invoked. The default, false, - // means it will print the results of invoking the custom error or Stringer - // interface and return immediately instead of continuing to recurse into - // the internals of the data type. - // - // NOTE: This flag does not have any effect if method invocation is disabled - // via the DisableMethods or DisablePointerMethods options. - ContinueOnMethod bool - - // SortKeys specifies map keys should be sorted before being printed. Use - // this to have a more deterministic, diffable output. Note that only - // native types (bool, int, uint, floats, uintptr and string) and types - // that support the error or Stringer interfaces (if methods are - // enabled) are supported, with other types sorted according to the - // reflect.Value.String() output which guarantees display stability. - SortKeys bool - - // SpewKeys specifies that, as a last resort attempt, map keys should - // be spewed to strings and sorted by those strings. This is only - // considered if SortKeys is true. - SpewKeys bool -} - -// Config is the active configuration of the top-level functions. -// The configuration can be changed by modifying the contents of spew.Config. -var Config = ConfigState{Indent: " "} - -// Errorf is a wrapper for fmt.Errorf that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the formatted string as a value that satisfies error. See NewFormatter -// for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Errorf(format, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Errorf(format string, a ...interface{}) (err error) { - return fmt.Errorf(format, c.convertArgs(a)...) -} - -// Fprint is a wrapper for fmt.Fprint that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprint(w, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Fprint(w io.Writer, a ...interface{}) (n int, err error) { - return fmt.Fprint(w, c.convertArgs(a)...) -} - -// Fprintf is a wrapper for fmt.Fprintf that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprintf(w, format, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Fprintf(w io.Writer, format string, a ...interface{}) (n int, err error) { - return fmt.Fprintf(w, format, c.convertArgs(a)...) -} - -// Fprintln is a wrapper for fmt.Fprintln that treats each argument as if it -// passed with a Formatter interface returned by c.NewFormatter. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprintln(w, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Fprintln(w io.Writer, a ...interface{}) (n int, err error) { - return fmt.Fprintln(w, c.convertArgs(a)...) -} - -// Print is a wrapper for fmt.Print that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Print(c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Print(a ...interface{}) (n int, err error) { - return fmt.Print(c.convertArgs(a)...) -} - -// Printf is a wrapper for fmt.Printf that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Printf(format, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Printf(format string, a ...interface{}) (n int, err error) { - return fmt.Printf(format, c.convertArgs(a)...) -} - -// Println is a wrapper for fmt.Println that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Println(c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Println(a ...interface{}) (n int, err error) { - return fmt.Println(c.convertArgs(a)...) -} - -// Sprint is a wrapper for fmt.Sprint that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprint(c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Sprint(a ...interface{}) string { - return fmt.Sprint(c.convertArgs(a)...) -} - -// Sprintf is a wrapper for fmt.Sprintf that treats each argument as if it were -// passed with a Formatter interface returned by c.NewFormatter. It returns -// the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprintf(format, c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Sprintf(format string, a ...interface{}) string { - return fmt.Sprintf(format, c.convertArgs(a)...) -} - -// Sprintln is a wrapper for fmt.Sprintln that treats each argument as if it -// were passed with a Formatter interface returned by c.NewFormatter. It -// returns the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprintln(c.NewFormatter(a), c.NewFormatter(b)) -func (c *ConfigState) Sprintln(a ...interface{}) string { - return fmt.Sprintln(c.convertArgs(a)...) -} - -/* -NewFormatter returns a custom formatter that satisfies the fmt.Formatter -interface. As a result, it integrates cleanly with standard fmt package -printing functions. The formatter is useful for inline printing of smaller data -types similar to the standard %v format specifier. - -The custom formatter only responds to the %v (most compact), %+v (adds pointer -addresses), %#v (adds types), and %#+v (adds types and pointer addresses) verb -combinations. Any other verbs such as %x and %q will be sent to the the -standard fmt package for formatting. In addition, the custom formatter ignores -the width and precision arguments (however they will still work on the format -specifiers not handled by the custom formatter). - -Typically this function shouldn't be called directly. It is much easier to make -use of the custom formatter by calling one of the convenience functions such as -c.Printf, c.Println, or c.Printf. -*/ -func (c *ConfigState) NewFormatter(v interface{}) fmt.Formatter { - return newFormatter(c, v) -} - -// Fdump formats and displays the passed arguments to io.Writer w. It formats -// exactly the same as Dump. -func (c *ConfigState) Fdump(w io.Writer, a ...interface{}) { - fdump(c, w, a...) -} - -/* -Dump displays the passed parameters to standard out with newlines, customizable -indentation, and additional debug information such as complete types and all -pointer addresses used to indirect to the final value. It provides the -following features over the built-in printing facilities provided by the fmt -package: - - * Pointers are dereferenced and followed - * Circular data structures are detected and handled properly - * Custom Stringer/error interfaces are optionally invoked, including - on unexported types - * Custom types which only implement the Stringer/error interfaces via - a pointer receiver are optionally invoked when passing non-pointer - variables - * Byte arrays and slices are dumped like the hexdump -C command which - includes offsets, byte values in hex, and ASCII output - -The configuration options are controlled by modifying the public members -of c. See ConfigState for options documentation. - -See Fdump if you would prefer dumping to an arbitrary io.Writer or Sdump to -get the formatted result as a string. -*/ -func (c *ConfigState) Dump(a ...interface{}) { - fdump(c, os.Stdout, a...) -} - -// Sdump returns a string with the passed arguments formatted exactly the same -// as Dump. -func (c *ConfigState) Sdump(a ...interface{}) string { - var buf bytes.Buffer - fdump(c, &buf, a...) - return buf.String() -} - -// convertArgs accepts a slice of arguments and returns a slice of the same -// length with each argument converted to a spew Formatter interface using -// the ConfigState associated with s. -func (c *ConfigState) convertArgs(args []interface{}) (formatters []interface{}) { - formatters = make([]interface{}, len(args)) - for index, arg := range args { - formatters[index] = newFormatter(c, arg) - } - return formatters -} - -// NewDefaultConfig returns a ConfigState with the following default settings. -// -// Indent: " " -// MaxDepth: 0 -// DisableMethods: false -// DisablePointerMethods: false -// ContinueOnMethod: false -// SortKeys: false -func NewDefaultConfig() *ConfigState { - return &ConfigState{Indent: " "} -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/doc.go deleted file mode 100644 index 5be0c40..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/doc.go +++ /dev/null @@ -1,202 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -/* -Package spew implements a deep pretty printer for Go data structures to aid in -debugging. - -A quick overview of the additional features spew provides over the built-in -printing facilities for Go data types are as follows: - - * Pointers are dereferenced and followed - * Circular data structures are detected and handled properly - * Custom Stringer/error interfaces are optionally invoked, including - on unexported types - * Custom types which only implement the Stringer/error interfaces via - a pointer receiver are optionally invoked when passing non-pointer - variables - * Byte arrays and slices are dumped like the hexdump -C command which - includes offsets, byte values in hex, and ASCII output (only when using - Dump style) - -There are two different approaches spew allows for dumping Go data structures: - - * Dump style which prints with newlines, customizable indentation, - and additional debug information such as types and all pointer addresses - used to indirect to the final value - * A custom Formatter interface that integrates cleanly with the standard fmt - package and replaces %v, %+v, %#v, and %#+v to provide inline printing - similar to the default %v while providing the additional functionality - outlined above and passing unsupported format verbs such as %x and %q - along to fmt - -Quick Start - -This section demonstrates how to quickly get started with spew. See the -sections below for further details on formatting and configuration options. - -To dump a variable with full newlines, indentation, type, and pointer -information use Dump, Fdump, or Sdump: - spew.Dump(myVar1, myVar2, ...) - spew.Fdump(someWriter, myVar1, myVar2, ...) - str := spew.Sdump(myVar1, myVar2, ...) - -Alternatively, if you would prefer to use format strings with a compacted inline -printing style, use the convenience wrappers Printf, Fprintf, etc with -%v (most compact), %+v (adds pointer addresses), %#v (adds types), or -%#+v (adds types and pointer addresses): - spew.Printf("myVar1: %v -- myVar2: %+v", myVar1, myVar2) - spew.Printf("myVar3: %#v -- myVar4: %#+v", myVar3, myVar4) - spew.Fprintf(someWriter, "myVar1: %v -- myVar2: %+v", myVar1, myVar2) - spew.Fprintf(someWriter, "myVar3: %#v -- myVar4: %#+v", myVar3, myVar4) - -Configuration Options - -Configuration of spew is handled by fields in the ConfigState type. For -convenience, all of the top-level functions use a global state available -via the spew.Config global. - -It is also possible to create a ConfigState instance that provides methods -equivalent to the top-level functions. This allows concurrent configuration -options. See the ConfigState documentation for more details. - -The following configuration options are available: - * Indent - String to use for each indentation level for Dump functions. - It is a single space by default. A popular alternative is "\t". - - * MaxDepth - Maximum number of levels to descend into nested data structures. - There is no limit by default. - - * DisableMethods - Disables invocation of error and Stringer interface methods. - Method invocation is enabled by default. - - * DisablePointerMethods - Disables invocation of error and Stringer interface methods on types - which only accept pointer receivers from non-pointer variables. - Pointer method invocation is enabled by default. - - * ContinueOnMethod - Enables recursion into types after invoking error and Stringer interface - methods. Recursion after method invocation is disabled by default. - - * SortKeys - Specifies map keys should be sorted before being printed. Use - this to have a more deterministic, diffable output. Note that - only native types (bool, int, uint, floats, uintptr and string) - and types which implement error or Stringer interfaces are - supported with other types sorted according to the - reflect.Value.String() output which guarantees display - stability. Natural map order is used by default. - - * SpewKeys - Specifies that, as a last resort attempt, map keys should be - spewed to strings and sorted by those strings. This is only - considered if SortKeys is true. - -Dump Usage - -Simply call spew.Dump with a list of variables you want to dump: - - spew.Dump(myVar1, myVar2, ...) - -You may also call spew.Fdump if you would prefer to output to an arbitrary -io.Writer. For example, to dump to standard error: - - spew.Fdump(os.Stderr, myVar1, myVar2, ...) - -A third option is to call spew.Sdump to get the formatted output as a string: - - str := spew.Sdump(myVar1, myVar2, ...) - -Sample Dump Output - -See the Dump example for details on the setup of the types and variables being -shown here. - - (main.Foo) { - unexportedField: (*main.Bar)(0xf84002e210)({ - flag: (main.Flag) flagTwo, - data: (uintptr) - }), - ExportedField: (map[interface {}]interface {}) (len=1) { - (string) (len=3) "one": (bool) true - } - } - -Byte (and uint8) arrays and slices are displayed uniquely like the hexdump -C -command as shown. - ([]uint8) (len=32 cap=32) { - 00000000 11 12 13 14 15 16 17 18 19 1a 1b 1c 1d 1e 1f 20 |............... | - 00000010 21 22 23 24 25 26 27 28 29 2a 2b 2c 2d 2e 2f 30 |!"#$%&'()*+,-./0| - 00000020 31 32 |12| - } - -Custom Formatter - -Spew provides a custom formatter that implements the fmt.Formatter interface -so that it integrates cleanly with standard fmt package printing functions. The -formatter is useful for inline printing of smaller data types similar to the -standard %v format specifier. - -The custom formatter only responds to the %v (most compact), %+v (adds pointer -addresses), %#v (adds types), or %#+v (adds types and pointer addresses) verb -combinations. Any other verbs such as %x and %q will be sent to the the -standard fmt package for formatting. In addition, the custom formatter ignores -the width and precision arguments (however they will still work on the format -specifiers not handled by the custom formatter). - -Custom Formatter Usage - -The simplest way to make use of the spew custom formatter is to call one of the -convenience functions such as spew.Printf, spew.Println, or spew.Printf. The -functions have syntax you are most likely already familiar with: - - spew.Printf("myVar1: %v -- myVar2: %+v", myVar1, myVar2) - spew.Printf("myVar3: %#v -- myVar4: %#+v", myVar3, myVar4) - spew.Println(myVar, myVar2) - spew.Fprintf(os.Stderr, "myVar1: %v -- myVar2: %+v", myVar1, myVar2) - spew.Fprintf(os.Stderr, "myVar3: %#v -- myVar4: %#+v", myVar3, myVar4) - -See the Index for the full list convenience functions. - -Sample Formatter Output - -Double pointer to a uint8: - %v: <**>5 - %+v: <**>(0xf8400420d0->0xf8400420c8)5 - %#v: (**uint8)5 - %#+v: (**uint8)(0xf8400420d0->0xf8400420c8)5 - -Pointer to circular struct with a uint8 field and a pointer to itself: - %v: <*>{1 <*>} - %+v: <*>(0xf84003e260){ui8:1 c:<*>(0xf84003e260)} - %#v: (*main.circular){ui8:(uint8)1 c:(*main.circular)} - %#+v: (*main.circular)(0xf84003e260){ui8:(uint8)1 c:(*main.circular)(0xf84003e260)} - -See the Printf example for details on the setup of variables being shown -here. - -Errors - -Since it is possible for custom Stringer/error interfaces to panic, spew -detects them and handles them internally by printing the panic information -inline with the output. Since spew is intended to provide deep pretty printing -capabilities on structures, it intentionally does not return any errors. -*/ -package spew diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/dump.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/dump.go deleted file mode 100644 index a0ff95e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/dump.go +++ /dev/null @@ -1,509 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -package spew - -import ( - "bytes" - "encoding/hex" - "fmt" - "io" - "os" - "reflect" - "regexp" - "strconv" - "strings" -) - -var ( - // uint8Type is a reflect.Type representing a uint8. It is used to - // convert cgo types to uint8 slices for hexdumping. - uint8Type = reflect.TypeOf(uint8(0)) - - // cCharRE is a regular expression that matches a cgo char. - // It is used to detect character arrays to hexdump them. - cCharRE = regexp.MustCompile("^.*\\._Ctype_char$") - - // cUnsignedCharRE is a regular expression that matches a cgo unsigned - // char. It is used to detect unsigned character arrays to hexdump - // them. - cUnsignedCharRE = regexp.MustCompile("^.*\\._Ctype_unsignedchar$") - - // cUint8tCharRE is a regular expression that matches a cgo uint8_t. - // It is used to detect uint8_t arrays to hexdump them. - cUint8tCharRE = regexp.MustCompile("^.*\\._Ctype_uint8_t$") -) - -// dumpState contains information about the state of a dump operation. -type dumpState struct { - w io.Writer - depth int - pointers map[uintptr]int - ignoreNextType bool - ignoreNextIndent bool - cs *ConfigState -} - -// indent performs indentation according to the depth level and cs.Indent -// option. -func (d *dumpState) indent() { - if d.ignoreNextIndent { - d.ignoreNextIndent = false - return - } - d.w.Write(bytes.Repeat([]byte(d.cs.Indent), d.depth)) -} - -// unpackValue returns values inside of non-nil interfaces when possible. -// This is useful for data types like structs, arrays, slices, and maps which -// can contain varying types packed inside an interface. -func (d *dumpState) unpackValue(v reflect.Value) reflect.Value { - if v.Kind() == reflect.Interface && !v.IsNil() { - v = v.Elem() - } - return v -} - -// dumpPtr handles formatting of pointers by indirecting them as necessary. -func (d *dumpState) dumpPtr(v reflect.Value) { - // Remove pointers at or below the current depth from map used to detect - // circular refs. - for k, depth := range d.pointers { - if depth >= d.depth { - delete(d.pointers, k) - } - } - - // Keep list of all dereferenced pointers to show later. - pointerChain := make([]uintptr, 0) - - // Figure out how many levels of indirection there are by dereferencing - // pointers and unpacking interfaces down the chain while detecting circular - // references. - nilFound := false - cycleFound := false - indirects := 0 - ve := v - for ve.Kind() == reflect.Ptr { - if ve.IsNil() { - nilFound = true - break - } - indirects++ - addr := ve.Pointer() - pointerChain = append(pointerChain, addr) - if pd, ok := d.pointers[addr]; ok && pd < d.depth { - cycleFound = true - indirects-- - break - } - d.pointers[addr] = d.depth - - ve = ve.Elem() - if ve.Kind() == reflect.Interface { - if ve.IsNil() { - nilFound = true - break - } - ve = ve.Elem() - } - } - - // Display type information. - d.w.Write(openParenBytes) - d.w.Write(bytes.Repeat(asteriskBytes, indirects)) - d.w.Write([]byte(ve.Type().String())) - d.w.Write(closeParenBytes) - - // Display pointer information. - if len(pointerChain) > 0 { - d.w.Write(openParenBytes) - for i, addr := range pointerChain { - if i > 0 { - d.w.Write(pointerChainBytes) - } - printHexPtr(d.w, addr) - } - d.w.Write(closeParenBytes) - } - - // Display dereferenced value. - d.w.Write(openParenBytes) - switch { - case nilFound == true: - d.w.Write(nilAngleBytes) - - case cycleFound == true: - d.w.Write(circularBytes) - - default: - d.ignoreNextType = true - d.dump(ve) - } - d.w.Write(closeParenBytes) -} - -// dumpSlice handles formatting of arrays and slices. Byte (uint8 under -// reflection) arrays and slices are dumped in hexdump -C fashion. -func (d *dumpState) dumpSlice(v reflect.Value) { - // Determine whether this type should be hex dumped or not. Also, - // for types which should be hexdumped, try to use the underlying data - // first, then fall back to trying to convert them to a uint8 slice. - var buf []uint8 - doConvert := false - doHexDump := false - numEntries := v.Len() - if numEntries > 0 { - vt := v.Index(0).Type() - vts := vt.String() - switch { - // C types that need to be converted. - case cCharRE.MatchString(vts): - fallthrough - case cUnsignedCharRE.MatchString(vts): - fallthrough - case cUint8tCharRE.MatchString(vts): - doConvert = true - - // Try to use existing uint8 slices and fall back to converting - // and copying if that fails. - case vt.Kind() == reflect.Uint8: - // We need an addressable interface to convert the type - // to a byte slice. However, the reflect package won't - // give us an interface on certain things like - // unexported struct fields in order to enforce - // visibility rules. We use unsafe, when available, to - // bypass these restrictions since this package does not - // mutate the values. - vs := v - if !vs.CanInterface() || !vs.CanAddr() { - vs = unsafeReflectValue(vs) - } - if !UnsafeDisabled { - vs = vs.Slice(0, numEntries) - - // Use the existing uint8 slice if it can be - // type asserted. - iface := vs.Interface() - if slice, ok := iface.([]uint8); ok { - buf = slice - doHexDump = true - break - } - } - - // The underlying data needs to be converted if it can't - // be type asserted to a uint8 slice. - doConvert = true - } - - // Copy and convert the underlying type if needed. - if doConvert && vt.ConvertibleTo(uint8Type) { - // Convert and copy each element into a uint8 byte - // slice. - buf = make([]uint8, numEntries) - for i := 0; i < numEntries; i++ { - vv := v.Index(i) - buf[i] = uint8(vv.Convert(uint8Type).Uint()) - } - doHexDump = true - } - } - - // Hexdump the entire slice as needed. - if doHexDump { - indent := strings.Repeat(d.cs.Indent, d.depth) - str := indent + hex.Dump(buf) - str = strings.Replace(str, "\n", "\n"+indent, -1) - str = strings.TrimRight(str, d.cs.Indent) - d.w.Write([]byte(str)) - return - } - - // Recursively call dump for each item. - for i := 0; i < numEntries; i++ { - d.dump(d.unpackValue(v.Index(i))) - if i < (numEntries - 1) { - d.w.Write(commaNewlineBytes) - } else { - d.w.Write(newlineBytes) - } - } -} - -// dump is the main workhorse for dumping a value. It uses the passed reflect -// value to figure out what kind of object we are dealing with and formats it -// appropriately. It is a recursive function, however circular data structures -// are detected and handled properly. -func (d *dumpState) dump(v reflect.Value) { - // Handle invalid reflect values immediately. - kind := v.Kind() - if kind == reflect.Invalid { - d.w.Write(invalidAngleBytes) - return - } - - // Handle pointers specially. - if kind == reflect.Ptr { - d.indent() - d.dumpPtr(v) - return - } - - // Print type information unless already handled elsewhere. - if !d.ignoreNextType { - d.indent() - d.w.Write(openParenBytes) - d.w.Write([]byte(v.Type().String())) - d.w.Write(closeParenBytes) - d.w.Write(spaceBytes) - } - d.ignoreNextType = false - - // Display length and capacity if the built-in len and cap functions - // work with the value's kind and the len/cap itself is non-zero. - valueLen, valueCap := 0, 0 - switch v.Kind() { - case reflect.Array, reflect.Slice, reflect.Chan: - valueLen, valueCap = v.Len(), v.Cap() - case reflect.Map, reflect.String: - valueLen = v.Len() - } - if valueLen != 0 || valueCap != 0 { - d.w.Write(openParenBytes) - if valueLen != 0 { - d.w.Write(lenEqualsBytes) - printInt(d.w, int64(valueLen), 10) - } - if valueCap != 0 { - if valueLen != 0 { - d.w.Write(spaceBytes) - } - d.w.Write(capEqualsBytes) - printInt(d.w, int64(valueCap), 10) - } - d.w.Write(closeParenBytes) - d.w.Write(spaceBytes) - } - - // Call Stringer/error interfaces if they exist and the handle methods flag - // is enabled - if !d.cs.DisableMethods { - if (kind != reflect.Invalid) && (kind != reflect.Interface) { - if handled := handleMethods(d.cs, d.w, v); handled { - return - } - } - } - - switch kind { - case reflect.Invalid: - // Do nothing. We should never get here since invalid has already - // been handled above. - - case reflect.Bool: - printBool(d.w, v.Bool()) - - case reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64, reflect.Int: - printInt(d.w, v.Int(), 10) - - case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint: - printUint(d.w, v.Uint(), 10) - - case reflect.Float32: - printFloat(d.w, v.Float(), 32) - - case reflect.Float64: - printFloat(d.w, v.Float(), 64) - - case reflect.Complex64: - printComplex(d.w, v.Complex(), 32) - - case reflect.Complex128: - printComplex(d.w, v.Complex(), 64) - - case reflect.Slice: - if v.IsNil() { - d.w.Write(nilAngleBytes) - break - } - fallthrough - - case reflect.Array: - d.w.Write(openBraceNewlineBytes) - d.depth++ - if (d.cs.MaxDepth != 0) && (d.depth > d.cs.MaxDepth) { - d.indent() - d.w.Write(maxNewlineBytes) - } else { - d.dumpSlice(v) - } - d.depth-- - d.indent() - d.w.Write(closeBraceBytes) - - case reflect.String: - d.w.Write([]byte(strconv.Quote(v.String()))) - - case reflect.Interface: - // The only time we should get here is for nil interfaces due to - // unpackValue calls. - if v.IsNil() { - d.w.Write(nilAngleBytes) - } - - case reflect.Ptr: - // Do nothing. We should never get here since pointers have already - // been handled above. - - case reflect.Map: - // nil maps should be indicated as different than empty maps - if v.IsNil() { - d.w.Write(nilAngleBytes) - break - } - - d.w.Write(openBraceNewlineBytes) - d.depth++ - if (d.cs.MaxDepth != 0) && (d.depth > d.cs.MaxDepth) { - d.indent() - d.w.Write(maxNewlineBytes) - } else { - numEntries := v.Len() - keys := v.MapKeys() - if d.cs.SortKeys { - sortValues(keys, d.cs) - } - for i, key := range keys { - d.dump(d.unpackValue(key)) - d.w.Write(colonSpaceBytes) - d.ignoreNextIndent = true - d.dump(d.unpackValue(v.MapIndex(key))) - if i < (numEntries - 1) { - d.w.Write(commaNewlineBytes) - } else { - d.w.Write(newlineBytes) - } - } - } - d.depth-- - d.indent() - d.w.Write(closeBraceBytes) - - case reflect.Struct: - d.w.Write(openBraceNewlineBytes) - d.depth++ - if (d.cs.MaxDepth != 0) && (d.depth > d.cs.MaxDepth) { - d.indent() - d.w.Write(maxNewlineBytes) - } else { - vt := v.Type() - numFields := v.NumField() - for i := 0; i < numFields; i++ { - d.indent() - vtf := vt.Field(i) - d.w.Write([]byte(vtf.Name)) - d.w.Write(colonSpaceBytes) - d.ignoreNextIndent = true - d.dump(d.unpackValue(v.Field(i))) - if i < (numFields - 1) { - d.w.Write(commaNewlineBytes) - } else { - d.w.Write(newlineBytes) - } - } - } - d.depth-- - d.indent() - d.w.Write(closeBraceBytes) - - case reflect.Uintptr: - printHexPtr(d.w, uintptr(v.Uint())) - - case reflect.UnsafePointer, reflect.Chan, reflect.Func: - printHexPtr(d.w, v.Pointer()) - - // There were not any other types at the time this code was written, but - // fall back to letting the default fmt package handle it in case any new - // types are added. - default: - if v.CanInterface() { - fmt.Fprintf(d.w, "%v", v.Interface()) - } else { - fmt.Fprintf(d.w, "%v", v.String()) - } - } -} - -// fdump is a helper function to consolidate the logic from the various public -// methods which take varying writers and config states. -func fdump(cs *ConfigState, w io.Writer, a ...interface{}) { - for _, arg := range a { - if arg == nil { - w.Write(interfaceBytes) - w.Write(spaceBytes) - w.Write(nilAngleBytes) - w.Write(newlineBytes) - continue - } - - d := dumpState{w: w, cs: cs} - d.pointers = make(map[uintptr]int) - d.dump(reflect.ValueOf(arg)) - d.w.Write(newlineBytes) - } -} - -// Fdump formats and displays the passed arguments to io.Writer w. It formats -// exactly the same as Dump. -func Fdump(w io.Writer, a ...interface{}) { - fdump(&Config, w, a...) -} - -// Sdump returns a string with the passed arguments formatted exactly the same -// as Dump. -func Sdump(a ...interface{}) string { - var buf bytes.Buffer - fdump(&Config, &buf, a...) - return buf.String() -} - -/* -Dump displays the passed parameters to standard out with newlines, customizable -indentation, and additional debug information such as complete types and all -pointer addresses used to indirect to the final value. It provides the -following features over the built-in printing facilities provided by the fmt -package: - - * Pointers are dereferenced and followed - * Circular data structures are detected and handled properly - * Custom Stringer/error interfaces are optionally invoked, including - on unexported types - * Custom types which only implement the Stringer/error interfaces via - a pointer receiver are optionally invoked when passing non-pointer - variables - * Byte arrays and slices are dumped like the hexdump -C command which - includes offsets, byte values in hex, and ASCII output - -The configuration options are controlled by an exported package global, -spew.Config. See ConfigState for options documentation. - -See Fdump if you would prefer dumping to an arbitrary io.Writer or Sdump to -get the formatted result as a string. -*/ -func Dump(a ...interface{}) { - fdump(&Config, os.Stdout, a...) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/format.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/format.go deleted file mode 100644 index ecf3b80..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/format.go +++ /dev/null @@ -1,419 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -package spew - -import ( - "bytes" - "fmt" - "reflect" - "strconv" - "strings" -) - -// supportedFlags is a list of all the character flags supported by fmt package. -const supportedFlags = "0-+# " - -// formatState implements the fmt.Formatter interface and contains information -// about the state of a formatting operation. The NewFormatter function can -// be used to get a new Formatter which can be used directly as arguments -// in standard fmt package printing calls. -type formatState struct { - value interface{} - fs fmt.State - depth int - pointers map[uintptr]int - ignoreNextType bool - cs *ConfigState -} - -// buildDefaultFormat recreates the original format string without precision -// and width information to pass in to fmt.Sprintf in the case of an -// unrecognized type. Unless new types are added to the language, this -// function won't ever be called. -func (f *formatState) buildDefaultFormat() (format string) { - buf := bytes.NewBuffer(percentBytes) - - for _, flag := range supportedFlags { - if f.fs.Flag(int(flag)) { - buf.WriteRune(flag) - } - } - - buf.WriteRune('v') - - format = buf.String() - return format -} - -// constructOrigFormat recreates the original format string including precision -// and width information to pass along to the standard fmt package. This allows -// automatic deferral of all format strings this package doesn't support. -func (f *formatState) constructOrigFormat(verb rune) (format string) { - buf := bytes.NewBuffer(percentBytes) - - for _, flag := range supportedFlags { - if f.fs.Flag(int(flag)) { - buf.WriteRune(flag) - } - } - - if width, ok := f.fs.Width(); ok { - buf.WriteString(strconv.Itoa(width)) - } - - if precision, ok := f.fs.Precision(); ok { - buf.Write(precisionBytes) - buf.WriteString(strconv.Itoa(precision)) - } - - buf.WriteRune(verb) - - format = buf.String() - return format -} - -// unpackValue returns values inside of non-nil interfaces when possible and -// ensures that types for values which have been unpacked from an interface -// are displayed when the show types flag is also set. -// This is useful for data types like structs, arrays, slices, and maps which -// can contain varying types packed inside an interface. -func (f *formatState) unpackValue(v reflect.Value) reflect.Value { - if v.Kind() == reflect.Interface { - f.ignoreNextType = false - if !v.IsNil() { - v = v.Elem() - } - } - return v -} - -// formatPtr handles formatting of pointers by indirecting them as necessary. -func (f *formatState) formatPtr(v reflect.Value) { - // Display nil if top level pointer is nil. - showTypes := f.fs.Flag('#') - if v.IsNil() && (!showTypes || f.ignoreNextType) { - f.fs.Write(nilAngleBytes) - return - } - - // Remove pointers at or below the current depth from map used to detect - // circular refs. - for k, depth := range f.pointers { - if depth >= f.depth { - delete(f.pointers, k) - } - } - - // Keep list of all dereferenced pointers to possibly show later. - pointerChain := make([]uintptr, 0) - - // Figure out how many levels of indirection there are by derferencing - // pointers and unpacking interfaces down the chain while detecting circular - // references. - nilFound := false - cycleFound := false - indirects := 0 - ve := v - for ve.Kind() == reflect.Ptr { - if ve.IsNil() { - nilFound = true - break - } - indirects++ - addr := ve.Pointer() - pointerChain = append(pointerChain, addr) - if pd, ok := f.pointers[addr]; ok && pd < f.depth { - cycleFound = true - indirects-- - break - } - f.pointers[addr] = f.depth - - ve = ve.Elem() - if ve.Kind() == reflect.Interface { - if ve.IsNil() { - nilFound = true - break - } - ve = ve.Elem() - } - } - - // Display type or indirection level depending on flags. - if showTypes && !f.ignoreNextType { - f.fs.Write(openParenBytes) - f.fs.Write(bytes.Repeat(asteriskBytes, indirects)) - f.fs.Write([]byte(ve.Type().String())) - f.fs.Write(closeParenBytes) - } else { - if nilFound || cycleFound { - indirects += strings.Count(ve.Type().String(), "*") - } - f.fs.Write(openAngleBytes) - f.fs.Write([]byte(strings.Repeat("*", indirects))) - f.fs.Write(closeAngleBytes) - } - - // Display pointer information depending on flags. - if f.fs.Flag('+') && (len(pointerChain) > 0) { - f.fs.Write(openParenBytes) - for i, addr := range pointerChain { - if i > 0 { - f.fs.Write(pointerChainBytes) - } - printHexPtr(f.fs, addr) - } - f.fs.Write(closeParenBytes) - } - - // Display dereferenced value. - switch { - case nilFound == true: - f.fs.Write(nilAngleBytes) - - case cycleFound == true: - f.fs.Write(circularShortBytes) - - default: - f.ignoreNextType = true - f.format(ve) - } -} - -// format is the main workhorse for providing the Formatter interface. It -// uses the passed reflect value to figure out what kind of object we are -// dealing with and formats it appropriately. It is a recursive function, -// however circular data structures are detected and handled properly. -func (f *formatState) format(v reflect.Value) { - // Handle invalid reflect values immediately. - kind := v.Kind() - if kind == reflect.Invalid { - f.fs.Write(invalidAngleBytes) - return - } - - // Handle pointers specially. - if kind == reflect.Ptr { - f.formatPtr(v) - return - } - - // Print type information unless already handled elsewhere. - if !f.ignoreNextType && f.fs.Flag('#') { - f.fs.Write(openParenBytes) - f.fs.Write([]byte(v.Type().String())) - f.fs.Write(closeParenBytes) - } - f.ignoreNextType = false - - // Call Stringer/error interfaces if they exist and the handle methods - // flag is enabled. - if !f.cs.DisableMethods { - if (kind != reflect.Invalid) && (kind != reflect.Interface) { - if handled := handleMethods(f.cs, f.fs, v); handled { - return - } - } - } - - switch kind { - case reflect.Invalid: - // Do nothing. We should never get here since invalid has already - // been handled above. - - case reflect.Bool: - printBool(f.fs, v.Bool()) - - case reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64, reflect.Int: - printInt(f.fs, v.Int(), 10) - - case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint: - printUint(f.fs, v.Uint(), 10) - - case reflect.Float32: - printFloat(f.fs, v.Float(), 32) - - case reflect.Float64: - printFloat(f.fs, v.Float(), 64) - - case reflect.Complex64: - printComplex(f.fs, v.Complex(), 32) - - case reflect.Complex128: - printComplex(f.fs, v.Complex(), 64) - - case reflect.Slice: - if v.IsNil() { - f.fs.Write(nilAngleBytes) - break - } - fallthrough - - case reflect.Array: - f.fs.Write(openBracketBytes) - f.depth++ - if (f.cs.MaxDepth != 0) && (f.depth > f.cs.MaxDepth) { - f.fs.Write(maxShortBytes) - } else { - numEntries := v.Len() - for i := 0; i < numEntries; i++ { - if i > 0 { - f.fs.Write(spaceBytes) - } - f.ignoreNextType = true - f.format(f.unpackValue(v.Index(i))) - } - } - f.depth-- - f.fs.Write(closeBracketBytes) - - case reflect.String: - f.fs.Write([]byte(v.String())) - - case reflect.Interface: - // The only time we should get here is for nil interfaces due to - // unpackValue calls. - if v.IsNil() { - f.fs.Write(nilAngleBytes) - } - - case reflect.Ptr: - // Do nothing. We should never get here since pointers have already - // been handled above. - - case reflect.Map: - // nil maps should be indicated as different than empty maps - if v.IsNil() { - f.fs.Write(nilAngleBytes) - break - } - - f.fs.Write(openMapBytes) - f.depth++ - if (f.cs.MaxDepth != 0) && (f.depth > f.cs.MaxDepth) { - f.fs.Write(maxShortBytes) - } else { - keys := v.MapKeys() - if f.cs.SortKeys { - sortValues(keys, f.cs) - } - for i, key := range keys { - if i > 0 { - f.fs.Write(spaceBytes) - } - f.ignoreNextType = true - f.format(f.unpackValue(key)) - f.fs.Write(colonBytes) - f.ignoreNextType = true - f.format(f.unpackValue(v.MapIndex(key))) - } - } - f.depth-- - f.fs.Write(closeMapBytes) - - case reflect.Struct: - numFields := v.NumField() - f.fs.Write(openBraceBytes) - f.depth++ - if (f.cs.MaxDepth != 0) && (f.depth > f.cs.MaxDepth) { - f.fs.Write(maxShortBytes) - } else { - vt := v.Type() - for i := 0; i < numFields; i++ { - if i > 0 { - f.fs.Write(spaceBytes) - } - vtf := vt.Field(i) - if f.fs.Flag('+') || f.fs.Flag('#') { - f.fs.Write([]byte(vtf.Name)) - f.fs.Write(colonBytes) - } - f.format(f.unpackValue(v.Field(i))) - } - } - f.depth-- - f.fs.Write(closeBraceBytes) - - case reflect.Uintptr: - printHexPtr(f.fs, uintptr(v.Uint())) - - case reflect.UnsafePointer, reflect.Chan, reflect.Func: - printHexPtr(f.fs, v.Pointer()) - - // There were not any other types at the time this code was written, but - // fall back to letting the default fmt package handle it if any get added. - default: - format := f.buildDefaultFormat() - if v.CanInterface() { - fmt.Fprintf(f.fs, format, v.Interface()) - } else { - fmt.Fprintf(f.fs, format, v.String()) - } - } -} - -// Format satisfies the fmt.Formatter interface. See NewFormatter for usage -// details. -func (f *formatState) Format(fs fmt.State, verb rune) { - f.fs = fs - - // Use standard formatting for verbs that are not v. - if verb != 'v' { - format := f.constructOrigFormat(verb) - fmt.Fprintf(fs, format, f.value) - return - } - - if f.value == nil { - if fs.Flag('#') { - fs.Write(interfaceBytes) - } - fs.Write(nilAngleBytes) - return - } - - f.format(reflect.ValueOf(f.value)) -} - -// newFormatter is a helper function to consolidate the logic from the various -// public methods which take varying config states. -func newFormatter(cs *ConfigState, v interface{}) fmt.Formatter { - fs := &formatState{value: v, cs: cs} - fs.pointers = make(map[uintptr]int) - return fs -} - -/* -NewFormatter returns a custom formatter that satisfies the fmt.Formatter -interface. As a result, it integrates cleanly with standard fmt package -printing functions. The formatter is useful for inline printing of smaller data -types similar to the standard %v format specifier. - -The custom formatter only responds to the %v (most compact), %+v (adds pointer -addresses), %#v (adds types), or %#+v (adds types and pointer addresses) verb -combinations. Any other verbs such as %x and %q will be sent to the the -standard fmt package for formatting. In addition, the custom formatter ignores -the width and precision arguments (however they will still work on the format -specifiers not handled by the custom formatter). - -Typically this function shouldn't be called directly. It is much easier to make -use of the custom formatter by calling one of the convenience functions such as -Printf, Println, or Fprintf. -*/ -func NewFormatter(v interface{}) fmt.Formatter { - return newFormatter(&Config, v) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/spew.go b/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/spew.go deleted file mode 100644 index d8233f5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/davecgh/go-spew/spew/spew.go +++ /dev/null @@ -1,148 +0,0 @@ -/* - * Copyright (c) 2013 Dave Collins - * - * Permission to use, copy, modify, and distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. - * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - */ - -package spew - -import ( - "fmt" - "io" -) - -// Errorf is a wrapper for fmt.Errorf that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the formatted string as a value that satisfies error. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Errorf(format, spew.NewFormatter(a), spew.NewFormatter(b)) -func Errorf(format string, a ...interface{}) (err error) { - return fmt.Errorf(format, convertArgs(a)...) -} - -// Fprint is a wrapper for fmt.Fprint that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprint(w, spew.NewFormatter(a), spew.NewFormatter(b)) -func Fprint(w io.Writer, a ...interface{}) (n int, err error) { - return fmt.Fprint(w, convertArgs(a)...) -} - -// Fprintf is a wrapper for fmt.Fprintf that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprintf(w, format, spew.NewFormatter(a), spew.NewFormatter(b)) -func Fprintf(w io.Writer, format string, a ...interface{}) (n int, err error) { - return fmt.Fprintf(w, format, convertArgs(a)...) -} - -// Fprintln is a wrapper for fmt.Fprintln that treats each argument as if it -// passed with a default Formatter interface returned by NewFormatter. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Fprintln(w, spew.NewFormatter(a), spew.NewFormatter(b)) -func Fprintln(w io.Writer, a ...interface{}) (n int, err error) { - return fmt.Fprintln(w, convertArgs(a)...) -} - -// Print is a wrapper for fmt.Print that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Print(spew.NewFormatter(a), spew.NewFormatter(b)) -func Print(a ...interface{}) (n int, err error) { - return fmt.Print(convertArgs(a)...) -} - -// Printf is a wrapper for fmt.Printf that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Printf(format, spew.NewFormatter(a), spew.NewFormatter(b)) -func Printf(format string, a ...interface{}) (n int, err error) { - return fmt.Printf(format, convertArgs(a)...) -} - -// Println is a wrapper for fmt.Println that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the number of bytes written and any write error encountered. See -// NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Println(spew.NewFormatter(a), spew.NewFormatter(b)) -func Println(a ...interface{}) (n int, err error) { - return fmt.Println(convertArgs(a)...) -} - -// Sprint is a wrapper for fmt.Sprint that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprint(spew.NewFormatter(a), spew.NewFormatter(b)) -func Sprint(a ...interface{}) string { - return fmt.Sprint(convertArgs(a)...) -} - -// Sprintf is a wrapper for fmt.Sprintf that treats each argument as if it were -// passed with a default Formatter interface returned by NewFormatter. It -// returns the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprintf(format, spew.NewFormatter(a), spew.NewFormatter(b)) -func Sprintf(format string, a ...interface{}) string { - return fmt.Sprintf(format, convertArgs(a)...) -} - -// Sprintln is a wrapper for fmt.Sprintln that treats each argument as if it -// were passed with a default Formatter interface returned by NewFormatter. It -// returns the resulting string. See NewFormatter for formatting details. -// -// This function is shorthand for the following syntax: -// -// fmt.Sprintln(spew.NewFormatter(a), spew.NewFormatter(b)) -func Sprintln(a ...interface{}) string { - return fmt.Sprintln(convertArgs(a)...) -} - -// convertArgs accepts a slice of arguments and returns a slice of the same -// length with each argument converted to a default spew Formatter interface. -func convertArgs(args []interface{}) (formatters []interface{}) { - formatters = make([]interface{}, len(args)) - for index, arg := range args { - formatters[index] = NewFormatter(arg) - } - return formatters -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digest.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digest.go deleted file mode 100644 index 31d821b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digest.go +++ /dev/null @@ -1,139 +0,0 @@ -package digest - -import ( - "fmt" - "hash" - "io" - "regexp" - "strings" -) - -const ( - // DigestSha256EmptyTar is the canonical sha256 digest of empty data - DigestSha256EmptyTar = "sha256:e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855" -) - -// Digest allows simple protection of hex formatted digest strings, prefixed -// by their algorithm. Strings of type Digest have some guarantee of being in -// the correct format and it provides quick access to the components of a -// digest string. -// -// The following is an example of the contents of Digest types: -// -// sha256:7173b809ca12ec5dee4506cd86be934c4596dd234ee82c0662eac04a8c2c71dc -// -// This allows to abstract the digest behind this type and work only in those -// terms. -type Digest string - -// NewDigest returns a Digest from alg and a hash.Hash object. -func NewDigest(alg Algorithm, h hash.Hash) Digest { - return NewDigestFromBytes(alg, h.Sum(nil)) -} - -// NewDigestFromBytes returns a new digest from the byte contents of p. -// Typically, this can come from hash.Hash.Sum(...) or xxx.SumXXX(...) -// functions. This is also useful for rebuilding digests from binary -// serializations. -func NewDigestFromBytes(alg Algorithm, p []byte) Digest { - return Digest(fmt.Sprintf("%s:%x", alg, p)) -} - -// NewDigestFromHex returns a Digest from alg and a the hex encoded digest. -func NewDigestFromHex(alg, hex string) Digest { - return Digest(fmt.Sprintf("%s:%s", alg, hex)) -} - -// DigestRegexp matches valid digest types. -var DigestRegexp = regexp.MustCompile(`[a-zA-Z0-9-_+.]+:[a-fA-F0-9]+`) - -// DigestRegexpAnchored matches valid digest types, anchored to the start and end of the match. -var DigestRegexpAnchored = regexp.MustCompile(`^` + DigestRegexp.String() + `$`) - -var ( - // ErrDigestInvalidFormat returned when digest format invalid. - ErrDigestInvalidFormat = fmt.Errorf("invalid checksum digest format") - - // ErrDigestInvalidLength returned when digest has invalid length. - ErrDigestInvalidLength = fmt.Errorf("invalid checksum digest length") - - // ErrDigestUnsupported returned when the digest algorithm is unsupported. - ErrDigestUnsupported = fmt.Errorf("unsupported digest algorithm") -) - -// ParseDigest parses s and returns the validated digest object. An error will -// be returned if the format is invalid. -func ParseDigest(s string) (Digest, error) { - d := Digest(s) - - return d, d.Validate() -} - -// FromReader returns the most valid digest for the underlying content using -// the canonical digest algorithm. -func FromReader(rd io.Reader) (Digest, error) { - return Canonical.FromReader(rd) -} - -// FromBytes digests the input and returns a Digest. -func FromBytes(p []byte) Digest { - return Canonical.FromBytes(p) -} - -// Validate checks that the contents of d is a valid digest, returning an -// error if not. -func (d Digest) Validate() error { - s := string(d) - - if !DigestRegexpAnchored.MatchString(s) { - return ErrDigestInvalidFormat - } - - i := strings.Index(s, ":") - if i < 0 { - return ErrDigestInvalidFormat - } - - // case: "sha256:" with no hex. - if i+1 == len(s) { - return ErrDigestInvalidFormat - } - - switch algorithm := Algorithm(s[:i]); algorithm { - case SHA256, SHA384, SHA512: - if algorithm.Size()*2 != len(s[i+1:]) { - return ErrDigestInvalidLength - } - break - default: - return ErrDigestUnsupported - } - - return nil -} - -// Algorithm returns the algorithm portion of the digest. This will panic if -// the underlying digest is not in a valid format. -func (d Digest) Algorithm() Algorithm { - return Algorithm(d[:d.sepIndex()]) -} - -// Hex returns the hex digest portion of the digest. This will panic if the -// underlying digest is not in a valid format. -func (d Digest) Hex() string { - return string(d[d.sepIndex()+1:]) -} - -func (d Digest) String() string { - return string(d) -} - -func (d Digest) sepIndex() int { - i := strings.Index(string(d), ":") - - if i < 0 { - panic("could not find ':' in digest: " + d) - } - - return i -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digester.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digester.go deleted file mode 100644 index f3105a4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/digester.go +++ /dev/null @@ -1,155 +0,0 @@ -package digest - -import ( - "crypto" - "fmt" - "hash" - "io" -) - -// Algorithm identifies and implementation of a digester by an identifier. -// Note the that this defines both the hash algorithm used and the string -// encoding. -type Algorithm string - -// supported digest types -const ( - SHA256 Algorithm = "sha256" // sha256 with hex encoding - SHA384 Algorithm = "sha384" // sha384 with hex encoding - SHA512 Algorithm = "sha512" // sha512 with hex encoding - - // Canonical is the primary digest algorithm used with the distribution - // project. Other digests may be used but this one is the primary storage - // digest. - Canonical = SHA256 -) - -var ( - // TODO(stevvooe): Follow the pattern of the standard crypto package for - // registration of digests. Effectively, we are a registerable set and - // common symbol access. - - // algorithms maps values to hash.Hash implementations. Other algorithms - // may be available but they cannot be calculated by the digest package. - algorithms = map[Algorithm]crypto.Hash{ - SHA256: crypto.SHA256, - SHA384: crypto.SHA384, - SHA512: crypto.SHA512, - } -) - -// Available returns true if the digest type is available for use. If this -// returns false, New and Hash will return nil. -func (a Algorithm) Available() bool { - h, ok := algorithms[a] - if !ok { - return false - } - - // check availability of the hash, as well - return h.Available() -} - -func (a Algorithm) String() string { - return string(a) -} - -// Size returns number of bytes returned by the hash. -func (a Algorithm) Size() int { - h, ok := algorithms[a] - if !ok { - return 0 - } - return h.Size() -} - -// Set implemented to allow use of Algorithm as a command line flag. -func (a *Algorithm) Set(value string) error { - if value == "" { - *a = Canonical - } else { - // just do a type conversion, support is queried with Available. - *a = Algorithm(value) - } - - return nil -} - -// New returns a new digester for the specified algorithm. If the algorithm -// does not have a digester implementation, nil will be returned. This can be -// checked by calling Available before calling New. -func (a Algorithm) New() Digester { - return &digester{ - alg: a, - hash: a.Hash(), - } -} - -// Hash returns a new hash as used by the algorithm. If not available, the -// method will panic. Check Algorithm.Available() before calling. -func (a Algorithm) Hash() hash.Hash { - if !a.Available() { - // NOTE(stevvooe): A missing hash is usually a programming error that - // must be resolved at compile time. We don't import in the digest - // package to allow users to choose their hash implementation (such as - // when using stevvooe/resumable or a hardware accelerated package). - // - // Applications that may want to resolve the hash at runtime should - // call Algorithm.Available before call Algorithm.Hash(). - panic(fmt.Sprintf("%v not available (make sure it is imported)", a)) - } - - return algorithms[a].New() -} - -// FromReader returns the digest of the reader using the algorithm. -func (a Algorithm) FromReader(rd io.Reader) (Digest, error) { - digester := a.New() - - if _, err := io.Copy(digester.Hash(), rd); err != nil { - return "", err - } - - return digester.Digest(), nil -} - -// FromBytes digests the input and returns a Digest. -func (a Algorithm) FromBytes(p []byte) Digest { - digester := a.New() - - if _, err := digester.Hash().Write(p); err != nil { - // Writes to a Hash should never fail. None of the existing - // hash implementations in the stdlib or hashes vendored - // here can return errors from Write. Having a panic in this - // condition instead of having FromBytes return an error value - // avoids unnecessary error handling paths in all callers. - panic("write to hash function returned error: " + err.Error()) - } - - return digester.Digest() -} - -// TODO(stevvooe): Allow resolution of verifiers using the digest type and -// this registration system. - -// Digester calculates the digest of written data. Writes should go directly -// to the return value of Hash, while calling Digest will return the current -// value of the digest. -type Digester interface { - Hash() hash.Hash // provides direct access to underlying hash instance. - Digest() Digest -} - -// digester provides a simple digester definition that embeds a hasher. -type digester struct { - alg Algorithm - hash hash.Hash -} - -func (d *digester) Hash() hash.Hash { - return d.hash -} - -func (d *digester) Digest() Digest { - return NewDigest(d.alg, d.hash) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/doc.go deleted file mode 100644 index f64b0db..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/doc.go +++ /dev/null @@ -1,42 +0,0 @@ -// Package digest provides a generalized type to opaquely represent message -// digests and their operations within the registry. The Digest type is -// designed to serve as a flexible identifier in a content-addressable system. -// More importantly, it provides tools and wrappers to work with -// hash.Hash-based digests with little effort. -// -// Basics -// -// The format of a digest is simply a string with two parts, dubbed the -// "algorithm" and the "digest", separated by a colon: -// -// : -// -// An example of a sha256 digest representation follows: -// -// sha256:7173b809ca12ec5dee4506cd86be934c4596dd234ee82c0662eac04a8c2c71dc -// -// In this case, the string "sha256" is the algorithm and the hex bytes are -// the "digest". -// -// Because the Digest type is simply a string, once a valid Digest is -// obtained, comparisons are cheap, quick and simple to express with the -// standard equality operator. -// -// Verification -// -// The main benefit of using the Digest type is simple verification against a -// given digest. The Verifier interface, modeled after the stdlib hash.Hash -// interface, provides a common write sink for digest verification. After -// writing is complete, calling the Verifier.Verified method will indicate -// whether or not the stream of bytes matches the target digest. -// -// Missing Features -// -// In addition to the above, we intend to add the following features to this -// package: -// -// 1. A Digester type that supports write sink digest calculation. -// -// 2. Suspend and resume of ongoing digest calculations to support efficient digest verification in the registry. -// -package digest diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/set.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/set.go deleted file mode 100644 index 4b9313c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/set.go +++ /dev/null @@ -1,245 +0,0 @@ -package digest - -import ( - "errors" - "sort" - "strings" - "sync" -) - -var ( - // ErrDigestNotFound is used when a matching digest - // could not be found in a set. - ErrDigestNotFound = errors.New("digest not found") - - // ErrDigestAmbiguous is used when multiple digests - // are found in a set. None of the matching digests - // should be considered valid matches. - ErrDigestAmbiguous = errors.New("ambiguous digest string") -) - -// Set is used to hold a unique set of digests which -// may be easily referenced by easily referenced by a string -// representation of the digest as well as short representation. -// The uniqueness of the short representation is based on other -// digests in the set. If digests are omitted from this set, -// collisions in a larger set may not be detected, therefore it -// is important to always do short representation lookups on -// the complete set of digests. To mitigate collisions, an -// appropriately long short code should be used. -type Set struct { - mutex sync.RWMutex - entries digestEntries -} - -// NewSet creates an empty set of digests -// which may have digests added. -func NewSet() *Set { - return &Set{ - entries: digestEntries{}, - } -} - -// checkShortMatch checks whether two digests match as either whole -// values or short values. This function does not test equality, -// rather whether the second value could match against the first -// value. -func checkShortMatch(alg Algorithm, hex, shortAlg, shortHex string) bool { - if len(hex) == len(shortHex) { - if hex != shortHex { - return false - } - if len(shortAlg) > 0 && string(alg) != shortAlg { - return false - } - } else if !strings.HasPrefix(hex, shortHex) { - return false - } else if len(shortAlg) > 0 && string(alg) != shortAlg { - return false - } - return true -} - -// Lookup looks for a digest matching the given string representation. -// If no digests could be found ErrDigestNotFound will be returned -// with an empty digest value. If multiple matches are found -// ErrDigestAmbiguous will be returned with an empty digest value. -func (dst *Set) Lookup(d string) (Digest, error) { - dst.mutex.RLock() - defer dst.mutex.RUnlock() - if len(dst.entries) == 0 { - return "", ErrDigestNotFound - } - var ( - searchFunc func(int) bool - alg Algorithm - hex string - ) - dgst, err := ParseDigest(d) - if err == ErrDigestInvalidFormat { - hex = d - searchFunc = func(i int) bool { - return dst.entries[i].val >= d - } - } else { - hex = dgst.Hex() - alg = dgst.Algorithm() - searchFunc = func(i int) bool { - if dst.entries[i].val == hex { - return dst.entries[i].alg >= alg - } - return dst.entries[i].val >= hex - } - } - idx := sort.Search(len(dst.entries), searchFunc) - if idx == len(dst.entries) || !checkShortMatch(dst.entries[idx].alg, dst.entries[idx].val, string(alg), hex) { - return "", ErrDigestNotFound - } - if dst.entries[idx].alg == alg && dst.entries[idx].val == hex { - return dst.entries[idx].digest, nil - } - if idx+1 < len(dst.entries) && checkShortMatch(dst.entries[idx+1].alg, dst.entries[idx+1].val, string(alg), hex) { - return "", ErrDigestAmbiguous - } - - return dst.entries[idx].digest, nil -} - -// Add adds the given digest to the set. An error will be returned -// if the given digest is invalid. If the digest already exists in the -// set, this operation will be a no-op. -func (dst *Set) Add(d Digest) error { - if err := d.Validate(); err != nil { - return err - } - dst.mutex.Lock() - defer dst.mutex.Unlock() - entry := &digestEntry{alg: d.Algorithm(), val: d.Hex(), digest: d} - searchFunc := func(i int) bool { - if dst.entries[i].val == entry.val { - return dst.entries[i].alg >= entry.alg - } - return dst.entries[i].val >= entry.val - } - idx := sort.Search(len(dst.entries), searchFunc) - if idx == len(dst.entries) { - dst.entries = append(dst.entries, entry) - return nil - } else if dst.entries[idx].digest == d { - return nil - } - - entries := append(dst.entries, nil) - copy(entries[idx+1:], entries[idx:len(entries)-1]) - entries[idx] = entry - dst.entries = entries - return nil -} - -// Remove removes the given digest from the set. An err will be -// returned if the given digest is invalid. If the digest does -// not exist in the set, this operation will be a no-op. -func (dst *Set) Remove(d Digest) error { - if err := d.Validate(); err != nil { - return err - } - dst.mutex.Lock() - defer dst.mutex.Unlock() - entry := &digestEntry{alg: d.Algorithm(), val: d.Hex(), digest: d} - searchFunc := func(i int) bool { - if dst.entries[i].val == entry.val { - return dst.entries[i].alg >= entry.alg - } - return dst.entries[i].val >= entry.val - } - idx := sort.Search(len(dst.entries), searchFunc) - // Not found if idx is after or value at idx is not digest - if idx == len(dst.entries) || dst.entries[idx].digest != d { - return nil - } - - entries := dst.entries - copy(entries[idx:], entries[idx+1:]) - entries = entries[:len(entries)-1] - dst.entries = entries - - return nil -} - -// All returns all the digests in the set -func (dst *Set) All() []Digest { - dst.mutex.RLock() - defer dst.mutex.RUnlock() - retValues := make([]Digest, len(dst.entries)) - for i := range dst.entries { - retValues[i] = dst.entries[i].digest - } - - return retValues -} - -// ShortCodeTable returns a map of Digest to unique short codes. The -// length represents the minimum value, the maximum length may be the -// entire value of digest if uniqueness cannot be achieved without the -// full value. This function will attempt to make short codes as short -// as possible to be unique. -func ShortCodeTable(dst *Set, length int) map[Digest]string { - dst.mutex.RLock() - defer dst.mutex.RUnlock() - m := make(map[Digest]string, len(dst.entries)) - l := length - resetIdx := 0 - for i := 0; i < len(dst.entries); i++ { - var short string - extended := true - for extended { - extended = false - if len(dst.entries[i].val) <= l { - short = dst.entries[i].digest.String() - } else { - short = dst.entries[i].val[:l] - for j := i + 1; j < len(dst.entries); j++ { - if checkShortMatch(dst.entries[j].alg, dst.entries[j].val, "", short) { - if j > resetIdx { - resetIdx = j - } - extended = true - } else { - break - } - } - if extended { - l++ - } - } - } - m[dst.entries[i].digest] = short - if i >= resetIdx { - l = length - } - } - return m -} - -type digestEntry struct { - alg Algorithm - val string - digest Digest -} - -type digestEntries []*digestEntry - -func (d digestEntries) Len() int { - return len(d) -} - -func (d digestEntries) Less(i, j int) bool { - if d[i].val != d[j].val { - return d[i].val < d[j].val - } - return d[i].alg < d[j].alg -} - -func (d digestEntries) Swap(i, j int) { - d[i], d[j] = d[j], d[i] -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/verifiers.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/verifiers.go deleted file mode 100644 index 9af3be1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/digest/verifiers.go +++ /dev/null @@ -1,44 +0,0 @@ -package digest - -import ( - "hash" - "io" -) - -// Verifier presents a general verification interface to be used with message -// digests and other byte stream verifications. Users instantiate a Verifier -// from one of the various methods, write the data under test to it then check -// the result with the Verified method. -type Verifier interface { - io.Writer - - // Verified will return true if the content written to Verifier matches - // the digest. - Verified() bool -} - -// NewDigestVerifier returns a verifier that compares the written bytes -// against a passed in digest. -func NewDigestVerifier(d Digest) (Verifier, error) { - if err := d.Validate(); err != nil { - return nil, err - } - - return hashVerifier{ - hash: d.Algorithm().Hash(), - digest: d, - }, nil -} - -type hashVerifier struct { - digest Digest - hash hash.Hash -} - -func (hv hashVerifier) Write(p []byte) (n int, err error) { - return hv.hash.Write(p) -} - -func (hv hashVerifier) Verified() bool { - return hv.digest == NewDigest(hv.digest.Algorithm(), hv.hash) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/reference.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/reference.go deleted file mode 100644 index bb09fa2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/reference.go +++ /dev/null @@ -1,334 +0,0 @@ -// Package reference provides a general type to represent any way of referencing images within the registry. -// Its main purpose is to abstract tags and digests (content-addressable hash). -// -// Grammar -// -// reference := name [ ":" tag ] [ "@" digest ] -// name := [hostname '/'] component ['/' component]* -// hostname := hostcomponent ['.' hostcomponent]* [':' port-number] -// hostcomponent := /([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9-]*[a-zA-Z0-9])/ -// port-number := /[0-9]+/ -// component := alpha-numeric [separator alpha-numeric]* -// alpha-numeric := /[a-z0-9]+/ -// separator := /[_.]|__|[-]*/ -// -// tag := /[\w][\w.-]{0,127}/ -// -// digest := digest-algorithm ":" digest-hex -// digest-algorithm := digest-algorithm-component [ digest-algorithm-separator digest-algorithm-component ] -// digest-algorithm-separator := /[+.-_]/ -// digest-algorithm-component := /[A-Za-z][A-Za-z0-9]*/ -// digest-hex := /[0-9a-fA-F]{32,}/ ; At least 128 bit digest value -package reference - -import ( - "errors" - "fmt" - - "github.com/docker/distribution/digest" -) - -const ( - // NameTotalLengthMax is the maximum total number of characters in a repository name. - NameTotalLengthMax = 255 -) - -var ( - // ErrReferenceInvalidFormat represents an error while trying to parse a string as a reference. - ErrReferenceInvalidFormat = errors.New("invalid reference format") - - // ErrTagInvalidFormat represents an error while trying to parse a string as a tag. - ErrTagInvalidFormat = errors.New("invalid tag format") - - // ErrDigestInvalidFormat represents an error while trying to parse a string as a tag. - ErrDigestInvalidFormat = errors.New("invalid digest format") - - // ErrNameEmpty is returned for empty, invalid repository names. - ErrNameEmpty = errors.New("repository name must have at least one component") - - // ErrNameTooLong is returned when a repository name is longer than NameTotalLengthMax. - ErrNameTooLong = fmt.Errorf("repository name must not be more than %v characters", NameTotalLengthMax) -) - -// Reference is an opaque object reference identifier that may include -// modifiers such as a hostname, name, tag, and digest. -type Reference interface { - // String returns the full reference - String() string -} - -// Field provides a wrapper type for resolving correct reference types when -// working with encoding. -type Field struct { - reference Reference -} - -// AsField wraps a reference in a Field for encoding. -func AsField(reference Reference) Field { - return Field{reference} -} - -// Reference unwraps the reference type from the field to -// return the Reference object. This object should be -// of the appropriate type to further check for different -// reference types. -func (f Field) Reference() Reference { - return f.reference -} - -// MarshalText serializes the field to byte text which -// is the string of the reference. -func (f Field) MarshalText() (p []byte, err error) { - return []byte(f.reference.String()), nil -} - -// UnmarshalText parses text bytes by invoking the -// reference parser to ensure the appropriately -// typed reference object is wrapped by field. -func (f *Field) UnmarshalText(p []byte) error { - r, err := Parse(string(p)) - if err != nil { - return err - } - - f.reference = r - return nil -} - -// Named is an object with a full name -type Named interface { - Reference - Name() string -} - -// Tagged is an object which has a tag -type Tagged interface { - Reference - Tag() string -} - -// NamedTagged is an object including a name and tag. -type NamedTagged interface { - Named - Tag() string -} - -// Digested is an object which has a digest -// in which it can be referenced by -type Digested interface { - Reference - Digest() digest.Digest -} - -// Canonical reference is an object with a fully unique -// name including a name with hostname and digest -type Canonical interface { - Named - Digest() digest.Digest -} - -// SplitHostname splits a named reference into a -// hostname and name string. If no valid hostname is -// found, the hostname is empty and the full value -// is returned as name -func SplitHostname(named Named) (string, string) { - name := named.Name() - match := anchoredNameRegexp.FindStringSubmatch(name) - if match == nil || len(match) != 3 { - return "", name - } - return match[1], match[2] -} - -// Parse parses s and returns a syntactically valid Reference. -// If an error was encountered it is returned, along with a nil Reference. -// NOTE: Parse will not handle short digests. -func Parse(s string) (Reference, error) { - matches := ReferenceRegexp.FindStringSubmatch(s) - if matches == nil { - if s == "" { - return nil, ErrNameEmpty - } - // TODO(dmcgowan): Provide more specific and helpful error - return nil, ErrReferenceInvalidFormat - } - - if len(matches[1]) > NameTotalLengthMax { - return nil, ErrNameTooLong - } - - ref := reference{ - name: matches[1], - tag: matches[2], - } - if matches[3] != "" { - var err error - ref.digest, err = digest.ParseDigest(matches[3]) - if err != nil { - return nil, err - } - } - - r := getBestReferenceType(ref) - if r == nil { - return nil, ErrNameEmpty - } - - return r, nil -} - -// ParseNamed parses s and returns a syntactically valid reference implementing -// the Named interface. The reference must have a name, otherwise an error is -// returned. -// If an error was encountered it is returned, along with a nil Reference. -// NOTE: ParseNamed will not handle short digests. -func ParseNamed(s string) (Named, error) { - ref, err := Parse(s) - if err != nil { - return nil, err - } - named, isNamed := ref.(Named) - if !isNamed { - return nil, fmt.Errorf("reference %s has no name", ref.String()) - } - return named, nil -} - -// WithName returns a named object representing the given string. If the input -// is invalid ErrReferenceInvalidFormat will be returned. -func WithName(name string) (Named, error) { - if len(name) > NameTotalLengthMax { - return nil, ErrNameTooLong - } - if !anchoredNameRegexp.MatchString(name) { - return nil, ErrReferenceInvalidFormat - } - return repository(name), nil -} - -// WithTag combines the name from "name" and the tag from "tag" to form a -// reference incorporating both the name and the tag. -func WithTag(name Named, tag string) (NamedTagged, error) { - if !anchoredTagRegexp.MatchString(tag) { - return nil, ErrTagInvalidFormat - } - return taggedReference{ - name: name.Name(), - tag: tag, - }, nil -} - -// WithDigest combines the name from "name" and the digest from "digest" to form -// a reference incorporating both the name and the digest. -func WithDigest(name Named, digest digest.Digest) (Canonical, error) { - if !anchoredDigestRegexp.MatchString(digest.String()) { - return nil, ErrDigestInvalidFormat - } - return canonicalReference{ - name: name.Name(), - digest: digest, - }, nil -} - -func getBestReferenceType(ref reference) Reference { - if ref.name == "" { - // Allow digest only references - if ref.digest != "" { - return digestReference(ref.digest) - } - return nil - } - if ref.tag == "" { - if ref.digest != "" { - return canonicalReference{ - name: ref.name, - digest: ref.digest, - } - } - return repository(ref.name) - } - if ref.digest == "" { - return taggedReference{ - name: ref.name, - tag: ref.tag, - } - } - - return ref -} - -type reference struct { - name string - tag string - digest digest.Digest -} - -func (r reference) String() string { - return r.name + ":" + r.tag + "@" + r.digest.String() -} - -func (r reference) Name() string { - return r.name -} - -func (r reference) Tag() string { - return r.tag -} - -func (r reference) Digest() digest.Digest { - return r.digest -} - -type repository string - -func (r repository) String() string { - return string(r) -} - -func (r repository) Name() string { - return string(r) -} - -type digestReference digest.Digest - -func (d digestReference) String() string { - return d.String() -} - -func (d digestReference) Digest() digest.Digest { - return digest.Digest(d) -} - -type taggedReference struct { - name string - tag string -} - -func (t taggedReference) String() string { - return t.name + ":" + t.tag -} - -func (t taggedReference) Name() string { - return t.name -} - -func (t taggedReference) Tag() string { - return t.tag -} - -type canonicalReference struct { - name string - digest digest.Digest -} - -func (c canonicalReference) String() string { - return c.name + "@" + c.digest.String() -} - -func (c canonicalReference) Name() string { - return c.name -} - -func (c canonicalReference) Digest() digest.Digest { - return c.digest -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/regexp.go b/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/regexp.go deleted file mode 100644 index 9a7d366..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/docker/distribution/reference/regexp.go +++ /dev/null @@ -1,124 +0,0 @@ -package reference - -import "regexp" - -var ( - // alphaNumericRegexp defines the alpha numeric atom, typically a - // component of names. This only allows lower case characters and digits. - alphaNumericRegexp = match(`[a-z0-9]+`) - - // separatorRegexp defines the separators allowed to be embedded in name - // components. This allow one period, one or two underscore and multiple - // dashes. - separatorRegexp = match(`(?:[._]|__|[-]*)`) - - // nameComponentRegexp restricts registry path component names to start - // with at least one letter or number, with following parts able to be - // separated by one period, one or two underscore and multiple dashes. - nameComponentRegexp = expression( - alphaNumericRegexp, - optional(repeated(separatorRegexp, alphaNumericRegexp))) - - // hostnameComponentRegexp restricts the registry hostname component of a - // repository name to start with a component as defined by hostnameRegexp - // and followed by an optional port. - hostnameComponentRegexp = match(`(?:[a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9-]*[a-zA-Z0-9])`) - - // hostnameRegexp defines the structure of potential hostname components - // that may be part of image names. This is purposely a subset of what is - // allowed by DNS to ensure backwards compatibility with Docker image - // names. - hostnameRegexp = expression( - hostnameComponentRegexp, - optional(repeated(literal(`.`), hostnameComponentRegexp)), - optional(literal(`:`), match(`[0-9]+`))) - - // TagRegexp matches valid tag names. From docker/docker:graph/tags.go. - TagRegexp = match(`[\w][\w.-]{0,127}`) - - // anchoredTagRegexp matches valid tag names, anchored at the start and - // end of the matched string. - anchoredTagRegexp = anchored(TagRegexp) - - // DigestRegexp matches valid digests. - DigestRegexp = match(`[A-Za-z][A-Za-z0-9]*(?:[-_+.][A-Za-z][A-Za-z0-9]*)*[:][[:xdigit:]]{32,}`) - - // anchoredDigestRegexp matches valid digests, anchored at the start and - // end of the matched string. - anchoredDigestRegexp = anchored(DigestRegexp) - - // NameRegexp is the format for the name component of references. The - // regexp has capturing groups for the hostname and name part omitting - // the separating forward slash from either. - NameRegexp = expression( - optional(hostnameRegexp, literal(`/`)), - nameComponentRegexp, - optional(repeated(literal(`/`), nameComponentRegexp))) - - // anchoredNameRegexp is used to parse a name value, capturing the - // hostname and trailing components. - anchoredNameRegexp = anchored( - optional(capture(hostnameRegexp), literal(`/`)), - capture(nameComponentRegexp, - optional(repeated(literal(`/`), nameComponentRegexp)))) - - // ReferenceRegexp is the full supported format of a reference. The regexp - // is anchored and has capturing groups for name, tag, and digest - // components. - ReferenceRegexp = anchored(capture(NameRegexp), - optional(literal(":"), capture(TagRegexp)), - optional(literal("@"), capture(DigestRegexp))) -) - -// match compiles the string to a regular expression. -var match = regexp.MustCompile - -// literal compiles s into a literal regular expression, escaping any regexp -// reserved characters. -func literal(s string) *regexp.Regexp { - re := match(regexp.QuoteMeta(s)) - - if _, complete := re.LiteralPrefix(); !complete { - panic("must be a literal") - } - - return re -} - -// expression defines a full expression, where each regular expression must -// follow the previous. -func expression(res ...*regexp.Regexp) *regexp.Regexp { - var s string - for _, re := range res { - s += re.String() - } - - return match(s) -} - -// optional wraps the expression in a non-capturing group and makes the -// production optional. -func optional(res ...*regexp.Regexp) *regexp.Regexp { - return match(group(expression(res...)).String() + `?`) -} - -// repeated wraps the regexp in a non-capturing group to get one or more -// matches. -func repeated(res ...*regexp.Regexp) *regexp.Regexp { - return match(group(expression(res...)).String() + `+`) -} - -// group wraps the regexp in a non-capturing group. -func group(res ...*regexp.Regexp) *regexp.Regexp { - return match(`(?:` + expression(res...).String() + `)`) -} - -// capture wraps the expression in a capturing group. -func capture(res ...*regexp.Regexp) *regexp.Regexp { - return match(`(` + expression(res...).String() + `)`) -} - -// anchored anchors the regular expression by adding start and end delimiters. -func anchored(res ...*regexp.Regexp) *regexp.Regexp { - return match(`^` + expression(res...).String() + `$`) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/.gitignore deleted file mode 100644 index cece7be..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/.gitignore +++ /dev/null @@ -1,70 +0,0 @@ -# Compiled Object files, Static and Dynamic libs (Shared Objects) -*.o -*.a -*.so - -# Folders -_obj -_test - -# Architecture specific extensions/prefixes -*.[568vq] -[568vq].out - -*.cgo1.go -*.cgo2.c -_cgo_defun.c -_cgo_gotypes.go -_cgo_export.* - -_testmain.go - -*.exe - -restful.html - -*.out - -tmp.prof - -go-restful.test - -examples/restful-basic-authentication - -examples/restful-encoding-filter - -examples/restful-filters - -examples/restful-hello-world - -examples/restful-resource-functions - -examples/restful-serve-static - -examples/restful-user-service - -*.DS_Store -examples/restful-user-resource - -examples/restful-multi-containers - -examples/restful-form-handling - -examples/restful-CORS-filter - -examples/restful-options-filter - -examples/restful-curly-router - -examples/restful-cpuprofiler-service - -examples/restful-pre-post-filters - -curly.prof - -examples/restful-NCSA-logging - -examples/restful-html-template - -s.html -restful-path-tail diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/CHANGES.md b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/CHANGES.md deleted file mode 100644 index 070bca7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/CHANGES.md +++ /dev/null @@ -1,163 +0,0 @@ -Change history of go-restful -= -2016-02-14 -- take the qualify factor of the Accept header mediatype into account when deciding the contentype of the response -- add constructors for custom entity accessors for xml and json - -2015-09-27 -- rename new WriteStatusAnd... to WriteHeaderAnd... for consistency - -2015-09-25 -- fixed problem with changing Header after WriteHeader (issue 235) - -2015-09-14 -- changed behavior of WriteHeader (immediate write) and WriteEntity (no status write) -- added support for custom EntityReaderWriters. - -2015-08-06 -- add support for reading entities from compressed request content -- use sync.Pool for compressors of http response and request body -- add Description to Parameter for documentation in Swagger UI - -2015-03-20 -- add configurable logging - -2015-03-18 -- if not specified, the Operation is derived from the Route function - -2015-03-17 -- expose Parameter creation functions -- make trace logger an interface -- fix OPTIONSFilter -- customize rendering of ServiceError -- JSR311 router now handles wildcards -- add Notes to Route - -2014-11-27 -- (api add) PrettyPrint per response. (as proposed in #167) - -2014-11-12 -- (api add) ApiVersion(.) for documentation in Swagger UI - -2014-11-10 -- (api change) struct fields tagged with "description" show up in Swagger UI - -2014-10-31 -- (api change) ReturnsError -> Returns -- (api add) RouteBuilder.Do(aBuilder) for DRY use of RouteBuilder -- fix swagger nested structs -- sort Swagger response messages by code - -2014-10-23 -- (api add) ReturnsError allows you to document Http codes in swagger -- fixed problem with greedy CurlyRouter -- (api add) Access-Control-Max-Age in CORS -- add tracing functionality (injectable) for debugging purposes -- support JSON parse 64bit int -- fix empty parameters for swagger -- WebServicesUrl is now optional for swagger -- fixed duplicate AccessControlAllowOrigin in CORS -- (api change) expose ServeMux in container -- (api add) added AllowedDomains in CORS -- (api add) ParameterNamed for detailed documentation - -2014-04-16 -- (api add) expose constructor of Request for testing. - -2014-06-27 -- (api add) ParameterNamed gives access to a Parameter definition and its data (for further specification). -- (api add) SetCacheReadEntity allow scontrol over whether or not the request body is being cached (default true for compatibility reasons). - -2014-07-03 -- (api add) CORS can be configured with a list of allowed domains - -2014-03-12 -- (api add) Route path parameters can use wildcard or regular expressions. (requires CurlyRouter) - -2014-02-26 -- (api add) Request now provides information about the matched Route, see method SelectedRoutePath - -2014-02-17 -- (api change) renamed parameter constants (go-lint checks) - -2014-01-10 - - (api add) support for CloseNotify, see http://golang.org/pkg/net/http/#CloseNotifier - -2014-01-07 - - (api change) Write* methods in Response now return the error or nil. - - added example of serving HTML from a Go template. - - fixed comparing Allowed headers in CORS (is now case-insensitive) - -2013-11-13 - - (api add) Response knows how many bytes are written to the response body. - -2013-10-29 - - (api add) RecoverHandler(handler RecoverHandleFunction) to change how panic recovery is handled. Default behavior is to log and return a stacktrace. This may be a security issue as it exposes sourcecode information. - -2013-10-04 - - (api add) Response knows what HTTP status has been written - - (api add) Request can have attributes (map of string->interface, also called request-scoped variables - -2013-09-12 - - (api change) Router interface simplified - - Implemented CurlyRouter, a Router that does not use|allow regular expressions in paths - -2013-08-05 - - add OPTIONS support - - add CORS support - -2013-08-27 - - fixed some reported issues (see github) - - (api change) deprecated use of WriteError; use WriteErrorString instead - -2014-04-15 - - (fix) v1.0.1 tag: fix Issue 111: WriteErrorString - -2013-08-08 - - (api add) Added implementation Container: a WebServices collection with its own http.ServeMux allowing multiple endpoints per program. Existing uses of go-restful will register their services to the DefaultContainer. - - (api add) the swagger package has be extended to have a UI per container. - - if panic is detected then a small stack trace is printed (thanks to runner-mei) - - (api add) WriteErrorString to Response - -Important API changes: - - - (api remove) package variable DoNotRecover no longer works ; use restful.DefaultContainer.DoNotRecover(true) instead. - - (api remove) package variable EnableContentEncoding no longer works ; use restful.DefaultContainer.EnableContentEncoding(true) instead. - - -2013-07-06 - - - (api add) Added support for response encoding (gzip and deflate(zlib)). This feature is disabled on default (for backwards compatibility). Use restful.EnableContentEncoding = true in your initialization to enable this feature. - -2013-06-19 - - - (improve) DoNotRecover option, moved request body closer, improved ReadEntity - -2013-06-03 - - - (api change) removed Dispatcher interface, hide PathExpression - - changed receiver names of type functions to be more idiomatic Go - -2013-06-02 - - - (optimize) Cache the RegExp compilation of Paths. - -2013-05-22 - - - (api add) Added support for request/response filter functions - -2013-05-18 - - - - (api add) Added feature to change the default Http Request Dispatch function (travis cline) - - (api change) Moved Swagger Webservice to swagger package (see example restful-user) - -[2012-11-14 .. 2013-05-18> - - - See https://github.com/emicklei/go-restful/commits - -2012-11-14 - - - Initial commit - - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/LICENSE deleted file mode 100644 index ece7ec6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/LICENSE +++ /dev/null @@ -1,22 +0,0 @@ -Copyright (c) 2012,2013 Ernest Micklei - -MIT License - -Permission is hereby granted, free of charge, to any person obtaining -a copy of this software and associated documentation files (the -"Software"), to deal in the Software without restriction, including -without limitation the rights to use, copy, modify, merge, publish, -distribute, sublicense, and/or sell copies of the Software, and to -permit persons to whom the Software is furnished to do so, subject to -the following conditions: - -The above copyright notice and this permission notice shall be -included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE -LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION -OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION -WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/README.md deleted file mode 100644 index cfe6d0a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/README.md +++ /dev/null @@ -1,74 +0,0 @@ -go-restful -========== - -package for building REST-style Web Services using Google Go - -REST asks developers to use HTTP methods explicitly and in a way that's consistent with the protocol definition. This basic REST design principle establishes a one-to-one mapping between create, read, update, and delete (CRUD) operations and HTTP methods. According to this mapping: - -- GET = Retrieve a representation of a resource -- POST = Create if you are sending content to the server to create a subordinate of the specified resource collection, using some server-side algorithm. -- PUT = Create if you are sending the full content of the specified resource (URI). -- PUT = Update if you are updating the full content of the specified resource. -- DELETE = Delete if you are requesting the server to delete the resource -- PATCH = Update partial content of a resource -- OPTIONS = Get information about the communication options for the request URI - -### Example - -```Go -ws := new(restful.WebService) -ws. - Path("/users"). - Consumes(restful.MIME_XML, restful.MIME_JSON). - Produces(restful.MIME_JSON, restful.MIME_XML) - -ws.Route(ws.GET("/{user-id}").To(u.findUser). - Doc("get a user"). - Param(ws.PathParameter("user-id", "identifier of the user").DataType("string")). - Writes(User{})) -... - -func (u UserResource) findUser(request *restful.Request, response *restful.Response) { - id := request.PathParameter("user-id") - ... -} -``` - -[Full API of a UserResource](https://github.com/emicklei/go-restful/tree/master/examples/restful-user-resource.go) - -### Features - -- Routes for request → function mapping with path parameter (e.g. {id}) support -- Configurable router: - - Routing algorithm after [JSR311](http://jsr311.java.net/nonav/releases/1.1/spec/spec.html) that is implemented using (but does **not** accept) regular expressions (See RouterJSR311 which is used by default) - - Fast routing algorithm that allows static elements, regular expressions and dynamic parameters in the URL path (e.g. /meetings/{id} or /static/{subpath:*}, See CurlyRouter) -- Request API for reading structs from JSON/XML and accesing parameters (path,query,header) -- Response API for writing structs to JSON/XML and setting headers -- Filters for intercepting the request → response flow on Service or Route level -- Request-scoped variables using attributes -- Containers for WebServices on different HTTP endpoints -- Content encoding (gzip,deflate) of request and response payloads -- Automatic responses on OPTIONS (using a filter) -- Automatic CORS request handling (using a filter) -- API declaration for Swagger UI (see swagger package) -- Panic recovery to produce HTTP 500, customizable using RecoverHandler(...) -- Route errors produce HTTP 404/405/406/415 errors, customizable using ServiceErrorHandler(...) -- Configurable (trace) logging -- Customizable encoding using EntityReaderWriter registration -- Customizable gzip/deflate readers and writers using CompressorProvider registration - -### Resources - -- [Documentation on godoc.org](http://godoc.org/github.com/emicklei/go-restful) -- [Code examples](https://github.com/emicklei/go-restful/tree/master/examples) -- [Example posted on blog](http://ernestmicklei.com/2012/11/go-restful-first-working-example/) -- [Design explained on blog](http://ernestmicklei.com/2012/11/go-restful-api-design/) -- [sourcegraph](https://sourcegraph.com/github.com/emicklei/go-restful) -- [gopkg.in](https://gopkg.in/emicklei/go-restful.v1) -- [showcase: Mora - MongoDB REST Api server](https://github.com/emicklei/mora) - -[![Build Status](https://drone.io/github.com/emicklei/go-restful/status.png)](https://drone.io/github.com/emicklei/go-restful/latest) - -(c) 2012 - 2015, http://ernestmicklei.com. MIT License - -Type ```git shortlog -s``` for a full list of contributors. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/Srcfile b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/Srcfile deleted file mode 100644 index 16fd186..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/Srcfile +++ /dev/null @@ -1 +0,0 @@ -{"SkipDirs": ["examples"]} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/bench_test.sh b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/bench_test.sh deleted file mode 100644 index 47ffbe4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/bench_test.sh +++ /dev/null @@ -1,10 +0,0 @@ -#go test -run=none -file bench_test.go -test.bench . -cpuprofile=bench_test.out - -go test -c -./go-restful.test -test.run=none -test.cpuprofile=tmp.prof -test.bench=BenchmarkMany -./go-restful.test -test.run=none -test.cpuprofile=curly.prof -test.bench=BenchmarkManyCurly - -#go tool pprof go-restful.test tmp.prof -go tool pprof go-restful.test curly.prof - - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compress.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compress.go deleted file mode 100644 index 220b377..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compress.go +++ /dev/null @@ -1,123 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bufio" - "compress/gzip" - "compress/zlib" - "errors" - "io" - "net" - "net/http" - "strings" -) - -// OBSOLETE : use restful.DefaultContainer.EnableContentEncoding(true) to change this setting. -var EnableContentEncoding = false - -// CompressingResponseWriter is a http.ResponseWriter that can perform content encoding (gzip and zlib) -type CompressingResponseWriter struct { - writer http.ResponseWriter - compressor io.WriteCloser - encoding string -} - -// Header is part of http.ResponseWriter interface -func (c *CompressingResponseWriter) Header() http.Header { - return c.writer.Header() -} - -// WriteHeader is part of http.ResponseWriter interface -func (c *CompressingResponseWriter) WriteHeader(status int) { - c.writer.WriteHeader(status) -} - -// Write is part of http.ResponseWriter interface -// It is passed through the compressor -func (c *CompressingResponseWriter) Write(bytes []byte) (int, error) { - if c.isCompressorClosed() { - return -1, errors.New("Compressing error: tried to write data using closed compressor") - } - return c.compressor.Write(bytes) -} - -// CloseNotify is part of http.CloseNotifier interface -func (c *CompressingResponseWriter) CloseNotify() <-chan bool { - return c.writer.(http.CloseNotifier).CloseNotify() -} - -// Close the underlying compressor -func (c *CompressingResponseWriter) Close() error { - if c.isCompressorClosed() { - return errors.New("Compressing error: tried to close already closed compressor") - } - - c.compressor.Close() - if ENCODING_GZIP == c.encoding { - currentCompressorProvider.ReleaseGzipWriter(c.compressor.(*gzip.Writer)) - } - if ENCODING_DEFLATE == c.encoding { - currentCompressorProvider.ReleaseZlibWriter(c.compressor.(*zlib.Writer)) - } - // gc hint needed? - c.compressor = nil - return nil -} - -func (c *CompressingResponseWriter) isCompressorClosed() bool { - return nil == c.compressor -} - -// Hijack implements the Hijacker interface -// This is especially useful when combining Container.EnabledContentEncoding -// in combination with websockets (for instance gorilla/websocket) -func (c *CompressingResponseWriter) Hijack() (net.Conn, *bufio.ReadWriter, error) { - hijacker, ok := c.writer.(http.Hijacker) - if !ok { - return nil, nil, errors.New("ResponseWriter doesn't support Hijacker interface") - } - return hijacker.Hijack() -} - -// WantsCompressedResponse reads the Accept-Encoding header to see if and which encoding is requested. -func wantsCompressedResponse(httpRequest *http.Request) (bool, string) { - header := httpRequest.Header.Get(HEADER_AcceptEncoding) - gi := strings.Index(header, ENCODING_GZIP) - zi := strings.Index(header, ENCODING_DEFLATE) - // use in order of appearance - if gi == -1 { - return zi != -1, ENCODING_DEFLATE - } else if zi == -1 { - return gi != -1, ENCODING_GZIP - } else { - if gi < zi { - return true, ENCODING_GZIP - } - return true, ENCODING_DEFLATE - } -} - -// NewCompressingResponseWriter create a CompressingResponseWriter for a known encoding = {gzip,deflate} -func NewCompressingResponseWriter(httpWriter http.ResponseWriter, encoding string) (*CompressingResponseWriter, error) { - httpWriter.Header().Set(HEADER_ContentEncoding, encoding) - c := new(CompressingResponseWriter) - c.writer = httpWriter - var err error - if ENCODING_GZIP == encoding { - w := currentCompressorProvider.AcquireGzipWriter() - w.Reset(httpWriter) - c.compressor = w - c.encoding = ENCODING_GZIP - } else if ENCODING_DEFLATE == encoding { - w := currentCompressorProvider.AcquireZlibWriter() - w.Reset(httpWriter) - c.compressor = w - c.encoding = ENCODING_DEFLATE - } else { - return nil, errors.New("Unknown encoding:" + encoding) - } - return c, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_cache.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_cache.go deleted file mode 100644 index ee42601..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_cache.go +++ /dev/null @@ -1,103 +0,0 @@ -package restful - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "compress/gzip" - "compress/zlib" -) - -// BoundedCachedCompressors is a CompressorProvider that uses a cache with a fixed amount -// of writers and readers (resources). -// If a new resource is acquired and all are in use, it will return a new unmanaged resource. -type BoundedCachedCompressors struct { - gzipWriters chan *gzip.Writer - gzipReaders chan *gzip.Reader - zlibWriters chan *zlib.Writer - writersCapacity int - readersCapacity int -} - -// NewBoundedCachedCompressors returns a new, with filled cache, BoundedCachedCompressors. -func NewBoundedCachedCompressors(writersCapacity, readersCapacity int) *BoundedCachedCompressors { - b := &BoundedCachedCompressors{ - gzipWriters: make(chan *gzip.Writer, writersCapacity), - gzipReaders: make(chan *gzip.Reader, readersCapacity), - zlibWriters: make(chan *zlib.Writer, writersCapacity), - writersCapacity: writersCapacity, - readersCapacity: readersCapacity, - } - for ix := 0; ix < writersCapacity; ix++ { - b.gzipWriters <- newGzipWriter() - b.zlibWriters <- newZlibWriter() - } - for ix := 0; ix < readersCapacity; ix++ { - b.gzipReaders <- newGzipReader() - } - return b -} - -// AcquireGzipWriter returns an resettable *gzip.Writer. Needs to be released. -func (b *BoundedCachedCompressors) AcquireGzipWriter() *gzip.Writer { - var writer *gzip.Writer - select { - case writer, _ = <-b.gzipWriters: - default: - // return a new unmanaged one - writer = newGzipWriter() - } - return writer -} - -// ReleaseGzipWriter accepts a writer (does not have to be one that was cached) -// only when the cache has room for it. It will ignore it otherwise. -func (b *BoundedCachedCompressors) ReleaseGzipWriter(w *gzip.Writer) { - // forget the unmanaged ones - if len(b.gzipWriters) < b.writersCapacity { - b.gzipWriters <- w - } -} - -// AcquireGzipReader returns a *gzip.Reader. Needs to be released. -func (b *BoundedCachedCompressors) AcquireGzipReader() *gzip.Reader { - var reader *gzip.Reader - select { - case reader, _ = <-b.gzipReaders: - default: - // return a new unmanaged one - reader = newGzipReader() - } - return reader -} - -// ReleaseGzipReader accepts a reader (does not have to be one that was cached) -// only when the cache has room for it. It will ignore it otherwise. -func (b *BoundedCachedCompressors) ReleaseGzipReader(r *gzip.Reader) { - // forget the unmanaged ones - if len(b.gzipReaders) < b.readersCapacity { - b.gzipReaders <- r - } -} - -// AcquireZlibWriter returns an resettable *zlib.Writer. Needs to be released. -func (b *BoundedCachedCompressors) AcquireZlibWriter() *zlib.Writer { - var writer *zlib.Writer - select { - case writer, _ = <-b.zlibWriters: - default: - // return a new unmanaged one - writer = newZlibWriter() - } - return writer -} - -// ReleaseZlibWriter accepts a writer (does not have to be one that was cached) -// only when the cache has room for it. It will ignore it otherwise. -func (b *BoundedCachedCompressors) ReleaseZlibWriter(w *zlib.Writer) { - // forget the unmanaged ones - if len(b.zlibWriters) < b.writersCapacity { - b.zlibWriters <- w - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_pools.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_pools.go deleted file mode 100644 index d866ce6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressor_pools.go +++ /dev/null @@ -1,91 +0,0 @@ -package restful - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "compress/gzip" - "compress/zlib" - "sync" -) - -// SyncPoolCompessors is a CompressorProvider that use the standard sync.Pool. -type SyncPoolCompessors struct { - GzipWriterPool *sync.Pool - GzipReaderPool *sync.Pool - ZlibWriterPool *sync.Pool -} - -// NewSyncPoolCompessors returns a new ("empty") SyncPoolCompessors. -func NewSyncPoolCompessors() *SyncPoolCompessors { - return &SyncPoolCompessors{ - GzipWriterPool: &sync.Pool{ - New: func() interface{} { return newGzipWriter() }, - }, - GzipReaderPool: &sync.Pool{ - New: func() interface{} { return newGzipReader() }, - }, - ZlibWriterPool: &sync.Pool{ - New: func() interface{} { return newZlibWriter() }, - }, - } -} - -func (s *SyncPoolCompessors) AcquireGzipWriter() *gzip.Writer { - return s.GzipWriterPool.Get().(*gzip.Writer) -} - -func (s *SyncPoolCompessors) ReleaseGzipWriter(w *gzip.Writer) { - s.GzipWriterPool.Put(w) -} - -func (s *SyncPoolCompessors) AcquireGzipReader() *gzip.Reader { - return s.GzipReaderPool.Get().(*gzip.Reader) -} - -func (s *SyncPoolCompessors) ReleaseGzipReader(r *gzip.Reader) { - s.GzipReaderPool.Put(r) -} - -func (s *SyncPoolCompessors) AcquireZlibWriter() *zlib.Writer { - return s.ZlibWriterPool.Get().(*zlib.Writer) -} - -func (s *SyncPoolCompessors) ReleaseZlibWriter(w *zlib.Writer) { - s.ZlibWriterPool.Put(w) -} - -func newGzipWriter() *gzip.Writer { - // create with an empty bytes writer; it will be replaced before using the gzipWriter - writer, err := gzip.NewWriterLevel(new(bytes.Buffer), gzip.BestSpeed) - if err != nil { - panic(err.Error()) - } - return writer -} - -func newGzipReader() *gzip.Reader { - // create with an empty reader (but with GZIP header); it will be replaced before using the gzipReader - // we can safely use currentCompressProvider because it is set on package initialization. - w := currentCompressorProvider.AcquireGzipWriter() - defer currentCompressorProvider.ReleaseGzipWriter(w) - b := new(bytes.Buffer) - w.Reset(b) - w.Flush() - w.Close() - reader, err := gzip.NewReader(bytes.NewReader(b.Bytes())) - if err != nil { - panic(err.Error()) - } - return reader -} - -func newZlibWriter() *zlib.Writer { - writer, err := zlib.NewWriterLevel(new(bytes.Buffer), gzip.BestSpeed) - if err != nil { - panic(err.Error()) - } - return writer -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressors.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressors.go deleted file mode 100644 index f028456..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/compressors.go +++ /dev/null @@ -1,53 +0,0 @@ -package restful - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "compress/gzip" - "compress/zlib" -) - -type CompressorProvider interface { - // Returns a *gzip.Writer which needs to be released later. - // Before using it, call Reset(). - AcquireGzipWriter() *gzip.Writer - - // Releases an aqcuired *gzip.Writer. - ReleaseGzipWriter(w *gzip.Writer) - - // Returns a *gzip.Reader which needs to be released later. - AcquireGzipReader() *gzip.Reader - - // Releases an aqcuired *gzip.Reader. - ReleaseGzipReader(w *gzip.Reader) - - // Returns a *zlib.Writer which needs to be released later. - // Before using it, call Reset(). - AcquireZlibWriter() *zlib.Writer - - // Releases an aqcuired *zlib.Writer. - ReleaseZlibWriter(w *zlib.Writer) -} - -// DefaultCompressorProvider is the actual provider of compressors (zlib or gzip). -var currentCompressorProvider CompressorProvider - -func init() { - currentCompressorProvider = NewSyncPoolCompessors() -} - -// CurrentCompressorProvider returns the current CompressorProvider. -// It is initialized using a SyncPoolCompessors. -func CurrentCompressorProvider() CompressorProvider { - return currentCompressorProvider -} - -// CompressorProvider sets the actual provider of compressors (zlib or gzip). -func SetCompressorProvider(p CompressorProvider) { - if p == nil { - panic("cannot set compressor provider to nil") - } - currentCompressorProvider = p -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/constants.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/constants.go deleted file mode 100644 index 203439c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/constants.go +++ /dev/null @@ -1,30 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -const ( - MIME_XML = "application/xml" // Accept or Content-Type used in Consumes() and/or Produces() - MIME_JSON = "application/json" // Accept or Content-Type used in Consumes() and/or Produces() - MIME_OCTET = "application/octet-stream" // If Content-Type is not present in request, use the default - - HEADER_Allow = "Allow" - HEADER_Accept = "Accept" - HEADER_Origin = "Origin" - HEADER_ContentType = "Content-Type" - HEADER_LastModified = "Last-Modified" - HEADER_AcceptEncoding = "Accept-Encoding" - HEADER_ContentEncoding = "Content-Encoding" - HEADER_AccessControlExposeHeaders = "Access-Control-Expose-Headers" - HEADER_AccessControlRequestMethod = "Access-Control-Request-Method" - HEADER_AccessControlRequestHeaders = "Access-Control-Request-Headers" - HEADER_AccessControlAllowMethods = "Access-Control-Allow-Methods" - HEADER_AccessControlAllowOrigin = "Access-Control-Allow-Origin" - HEADER_AccessControlAllowCredentials = "Access-Control-Allow-Credentials" - HEADER_AccessControlAllowHeaders = "Access-Control-Allow-Headers" - HEADER_AccessControlMaxAge = "Access-Control-Max-Age" - - ENCODING_GZIP = "gzip" - ENCODING_DEFLATE = "deflate" -) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/container.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/container.go deleted file mode 100644 index 4e53ccc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/container.go +++ /dev/null @@ -1,361 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "errors" - "fmt" - "net/http" - "os" - "runtime" - "strings" - "sync" - - "github.com/emicklei/go-restful/log" -) - -// Container holds a collection of WebServices and a http.ServeMux to dispatch http requests. -// The requests are further dispatched to routes of WebServices using a RouteSelector -type Container struct { - webServicesLock sync.RWMutex - webServices []*WebService - ServeMux *http.ServeMux - isRegisteredOnRoot bool - containerFilters []FilterFunction - doNotRecover bool // default is false - recoverHandleFunc RecoverHandleFunction - serviceErrorHandleFunc ServiceErrorHandleFunction - router RouteSelector // default is a RouterJSR311, CurlyRouter is the faster alternative - contentEncodingEnabled bool // default is false -} - -// NewContainer creates a new Container using a new ServeMux and default router (RouterJSR311) -func NewContainer() *Container { - return &Container{ - webServices: []*WebService{}, - ServeMux: http.NewServeMux(), - isRegisteredOnRoot: false, - containerFilters: []FilterFunction{}, - doNotRecover: false, - recoverHandleFunc: logStackOnRecover, - serviceErrorHandleFunc: writeServiceError, - router: RouterJSR311{}, - contentEncodingEnabled: false} -} - -// RecoverHandleFunction declares functions that can be used to handle a panic situation. -// The first argument is what recover() returns. The second must be used to communicate an error response. -type RecoverHandleFunction func(interface{}, http.ResponseWriter) - -// RecoverHandler changes the default function (logStackOnRecover) to be called -// when a panic is detected. DoNotRecover must be have its default value (=false). -func (c *Container) RecoverHandler(handler RecoverHandleFunction) { - c.recoverHandleFunc = handler -} - -// ServiceErrorHandleFunction declares functions that can be used to handle a service error situation. -// The first argument is the service error, the second is the request that resulted in the error and -// the third must be used to communicate an error response. -type ServiceErrorHandleFunction func(ServiceError, *Request, *Response) - -// ServiceErrorHandler changes the default function (writeServiceError) to be called -// when a ServiceError is detected. -func (c *Container) ServiceErrorHandler(handler ServiceErrorHandleFunction) { - c.serviceErrorHandleFunc = handler -} - -// DoNotRecover controls whether panics will be caught to return HTTP 500. -// If set to true, Route functions are responsible for handling any error situation. -// Default value is false = recover from panics. This has performance implications. -func (c *Container) DoNotRecover(doNot bool) { - c.doNotRecover = doNot -} - -// Router changes the default Router (currently RouterJSR311) -func (c *Container) Router(aRouter RouteSelector) { - c.router = aRouter -} - -// EnableContentEncoding (default=false) allows for GZIP or DEFLATE encoding of responses. -func (c *Container) EnableContentEncoding(enabled bool) { - c.contentEncodingEnabled = enabled -} - -// Add a WebService to the Container. It will detect duplicate root paths and exit in that case. -func (c *Container) Add(service *WebService) *Container { - c.webServicesLock.Lock() - defer c.webServicesLock.Unlock() - - // if rootPath was not set then lazy initialize it - if len(service.rootPath) == 0 { - service.Path("/") - } - - // cannot have duplicate root paths - for _, each := range c.webServices { - if each.RootPath() == service.RootPath() { - log.Printf("[restful] WebService with duplicate root path detected:['%v']", each) - os.Exit(1) - } - } - - // If not registered on root then add specific mapping - if !c.isRegisteredOnRoot { - c.isRegisteredOnRoot = c.addHandler(service, c.ServeMux) - } - c.webServices = append(c.webServices, service) - return c -} - -// addHandler may set a new HandleFunc for the serveMux -// this function must run inside the critical region protected by the webServicesLock. -// returns true if the function was registered on root ("/") -func (c *Container) addHandler(service *WebService, serveMux *http.ServeMux) bool { - pattern := fixedPrefixPath(service.RootPath()) - // check if root path registration is needed - if "/" == pattern || "" == pattern { - serveMux.HandleFunc("/", c.dispatch) - return true - } - // detect if registration already exists - alreadyMapped := false - for _, each := range c.webServices { - if each.RootPath() == service.RootPath() { - alreadyMapped = true - break - } - } - if !alreadyMapped { - serveMux.HandleFunc(pattern, c.dispatch) - if !strings.HasSuffix(pattern, "/") { - serveMux.HandleFunc(pattern+"/", c.dispatch) - } - } - return false -} - -func (c *Container) Remove(ws *WebService) error { - if c.ServeMux == http.DefaultServeMux { - errMsg := fmt.Sprintf("[restful] cannot remove a WebService from a Container using the DefaultServeMux: ['%v']", ws) - log.Printf(errMsg) - return errors.New(errMsg) - } - c.webServicesLock.Lock() - defer c.webServicesLock.Unlock() - // build a new ServeMux and re-register all WebServices - newServeMux := http.NewServeMux() - newServices := []*WebService{} - newIsRegisteredOnRoot := false - for _, each := range c.webServices { - if each.rootPath != ws.rootPath { - // If not registered on root then add specific mapping - if !newIsRegisteredOnRoot { - newIsRegisteredOnRoot = c.addHandler(each, newServeMux) - } - newServices = append(newServices, each) - } - } - c.webServices, c.ServeMux, c.isRegisteredOnRoot = newServices, newServeMux, newIsRegisteredOnRoot - return nil -} - -// logStackOnRecover is the default RecoverHandleFunction and is called -// when DoNotRecover is false and the recoverHandleFunc is not set for the container. -// Default implementation logs the stacktrace and writes the stacktrace on the response. -// This may be a security issue as it exposes sourcecode information. -func logStackOnRecover(panicReason interface{}, httpWriter http.ResponseWriter) { - var buffer bytes.Buffer - buffer.WriteString(fmt.Sprintf("[restful] recover from panic situation: - %v\r\n", panicReason)) - for i := 2; ; i += 1 { - _, file, line, ok := runtime.Caller(i) - if !ok { - break - } - buffer.WriteString(fmt.Sprintf(" %s:%d\r\n", file, line)) - } - log.Print(buffer.String()) - httpWriter.WriteHeader(http.StatusInternalServerError) - httpWriter.Write(buffer.Bytes()) -} - -// writeServiceError is the default ServiceErrorHandleFunction and is called -// when a ServiceError is returned during route selection. Default implementation -// calls resp.WriteErrorString(err.Code, err.Message) -func writeServiceError(err ServiceError, req *Request, resp *Response) { - resp.WriteErrorString(err.Code, err.Message) -} - -// Dispatch the incoming Http Request to a matching WebService. -func (c *Container) dispatch(httpWriter http.ResponseWriter, httpRequest *http.Request) { - writer := httpWriter - - // CompressingResponseWriter should be closed after all operations are done - defer func() { - if compressWriter, ok := writer.(*CompressingResponseWriter); ok { - compressWriter.Close() - } - }() - - // Instal panic recovery unless told otherwise - if !c.doNotRecover { // catch all for 500 response - defer func() { - if r := recover(); r != nil { - c.recoverHandleFunc(r, writer) - return - } - }() - } - // Install closing the request body (if any) - defer func() { - if nil != httpRequest.Body { - httpRequest.Body.Close() - } - }() - - // Detect if compression is needed - // assume without compression, test for override - if c.contentEncodingEnabled { - doCompress, encoding := wantsCompressedResponse(httpRequest) - if doCompress { - var err error - writer, err = NewCompressingResponseWriter(httpWriter, encoding) - if err != nil { - log.Print("[restful] unable to install compressor: ", err) - httpWriter.WriteHeader(http.StatusInternalServerError) - return - } - } - } - // Find best match Route ; err is non nil if no match was found - var webService *WebService - var route *Route - var err error - func() { - c.webServicesLock.RLock() - defer c.webServicesLock.RUnlock() - webService, route, err = c.router.SelectRoute( - c.webServices, - httpRequest) - }() - if err != nil { - // a non-200 response has already been written - // run container filters anyway ; they should not touch the response... - chain := FilterChain{Filters: c.containerFilters, Target: func(req *Request, resp *Response) { - switch err.(type) { - case ServiceError: - ser := err.(ServiceError) - c.serviceErrorHandleFunc(ser, req, resp) - } - // TODO - }} - chain.ProcessFilter(NewRequest(httpRequest), NewResponse(writer)) - return - } - wrappedRequest, wrappedResponse := route.wrapRequestResponse(writer, httpRequest) - // pass through filters (if any) - if len(c.containerFilters)+len(webService.filters)+len(route.Filters) > 0 { - // compose filter chain - allFilters := []FilterFunction{} - allFilters = append(allFilters, c.containerFilters...) - allFilters = append(allFilters, webService.filters...) - allFilters = append(allFilters, route.Filters...) - chain := FilterChain{Filters: allFilters, Target: func(req *Request, resp *Response) { - // handle request by route after passing all filters - route.Function(wrappedRequest, wrappedResponse) - }} - chain.ProcessFilter(wrappedRequest, wrappedResponse) - } else { - // no filters, handle request by route - route.Function(wrappedRequest, wrappedResponse) - } -} - -// fixedPrefixPath returns the fixed part of the partspec ; it may include template vars {} -func fixedPrefixPath(pathspec string) string { - varBegin := strings.Index(pathspec, "{") - if -1 == varBegin { - return pathspec - } - return pathspec[:varBegin] -} - -// ServeHTTP implements net/http.Handler therefore a Container can be a Handler in a http.Server -func (c *Container) ServeHTTP(httpwriter http.ResponseWriter, httpRequest *http.Request) { - c.ServeMux.ServeHTTP(httpwriter, httpRequest) -} - -// Handle registers the handler for the given pattern. If a handler already exists for pattern, Handle panics. -func (c *Container) Handle(pattern string, handler http.Handler) { - c.ServeMux.Handle(pattern, handler) -} - -// HandleWithFilter registers the handler for the given pattern. -// Container's filter chain is applied for handler. -// If a handler already exists for pattern, HandleWithFilter panics. -func (c *Container) HandleWithFilter(pattern string, handler http.Handler) { - f := func(httpResponse http.ResponseWriter, httpRequest *http.Request) { - if len(c.containerFilters) == 0 { - handler.ServeHTTP(httpResponse, httpRequest) - return - } - - chain := FilterChain{Filters: c.containerFilters, Target: func(req *Request, resp *Response) { - handler.ServeHTTP(httpResponse, httpRequest) - }} - chain.ProcessFilter(NewRequest(httpRequest), NewResponse(httpResponse)) - } - - c.Handle(pattern, http.HandlerFunc(f)) -} - -// Filter appends a container FilterFunction. These are called before dispatching -// a http.Request to a WebService from the container -func (c *Container) Filter(filter FilterFunction) { - c.containerFilters = append(c.containerFilters, filter) -} - -// RegisteredWebServices returns the collections of added WebServices -func (c *Container) RegisteredWebServices() []*WebService { - c.webServicesLock.RLock() - defer c.webServicesLock.RUnlock() - result := make([]*WebService, len(c.webServices)) - for ix := range c.webServices { - result[ix] = c.webServices[ix] - } - return result -} - -// computeAllowedMethods returns a list of HTTP methods that are valid for a Request -func (c *Container) computeAllowedMethods(req *Request) []string { - // Go through all RegisteredWebServices() and all its Routes to collect the options - methods := []string{} - requestPath := req.Request.URL.Path - for _, ws := range c.RegisteredWebServices() { - matches := ws.pathExpr.Matcher.FindStringSubmatch(requestPath) - if matches != nil { - finalMatch := matches[len(matches)-1] - for _, rt := range ws.Routes() { - matches := rt.pathExpr.Matcher.FindStringSubmatch(finalMatch) - if matches != nil { - lastMatch := matches[len(matches)-1] - if lastMatch == "" || lastMatch == "/" { // do not include if value is neither empty nor ‘/’. - methods = append(methods, rt.Method) - } - } - } - } - } - // methods = append(methods, "OPTIONS") not sure about this - return methods -} - -// newBasicRequestResponse creates a pair of Request,Response from its http versions. -// It is basic because no parameter or (produces) content-type information is given. -func newBasicRequestResponse(httpWriter http.ResponseWriter, httpRequest *http.Request) (*Request, *Response) { - resp := NewResponse(httpWriter) - resp.requestAccept = httpRequest.Header.Get(HEADER_Accept) - return NewRequest(httpRequest), resp -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/cors_filter.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/cors_filter.go deleted file mode 100644 index 1efeef0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/cors_filter.go +++ /dev/null @@ -1,202 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "regexp" - "strconv" - "strings" -) - -// CrossOriginResourceSharing is used to create a Container Filter that implements CORS. -// Cross-origin resource sharing (CORS) is a mechanism that allows JavaScript on a web page -// to make XMLHttpRequests to another domain, not the domain the JavaScript originated from. -// -// http://en.wikipedia.org/wiki/Cross-origin_resource_sharing -// http://enable-cors.org/server.html -// http://www.html5rocks.com/en/tutorials/cors/#toc-handling-a-not-so-simple-request -type CrossOriginResourceSharing struct { - ExposeHeaders []string // list of Header names - AllowedHeaders []string // list of Header names - AllowedDomains []string // list of allowed values for Http Origin. An allowed value can be a regular expression to support subdomain matching. If empty all are allowed. - AllowedMethods []string - MaxAge int // number of seconds before requiring new Options request - CookiesAllowed bool - Container *Container - - allowedOriginPatterns []*regexp.Regexp // internal field for origin regexp check. -} - -// Filter is a filter function that implements the CORS flow as documented on http://enable-cors.org/server.html -// and http://www.html5rocks.com/static/images/cors_server_flowchart.png -func (c CrossOriginResourceSharing) Filter(req *Request, resp *Response, chain *FilterChain) { - origin := req.Request.Header.Get(HEADER_Origin) - if len(origin) == 0 { - if trace { - traceLogger.Print("no Http header Origin set") - } - chain.ProcessFilter(req, resp) - return - } - if !c.isOriginAllowed(origin) { // check whether this origin is allowed - if trace { - traceLogger.Printf("HTTP Origin:%s is not part of %v, neither matches any part of %v", origin, c.AllowedDomains, c.allowedOriginPatterns) - } - chain.ProcessFilter(req, resp) - return - } - if req.Request.Method != "OPTIONS" { - c.doActualRequest(req, resp) - chain.ProcessFilter(req, resp) - return - } - if acrm := req.Request.Header.Get(HEADER_AccessControlRequestMethod); acrm != "" { - c.doPreflightRequest(req, resp) - } else { - c.doActualRequest(req, resp) - chain.ProcessFilter(req, resp) - return - } -} - -func (c CrossOriginResourceSharing) doActualRequest(req *Request, resp *Response) { - c.setOptionsHeaders(req, resp) - // continue processing the response -} - -func (c *CrossOriginResourceSharing) doPreflightRequest(req *Request, resp *Response) { - if len(c.AllowedMethods) == 0 { - if c.Container == nil { - c.AllowedMethods = DefaultContainer.computeAllowedMethods(req) - } else { - c.AllowedMethods = c.Container.computeAllowedMethods(req) - } - } - - acrm := req.Request.Header.Get(HEADER_AccessControlRequestMethod) - if !c.isValidAccessControlRequestMethod(acrm, c.AllowedMethods) { - if trace { - traceLogger.Printf("Http header %s:%s is not in %v", - HEADER_AccessControlRequestMethod, - acrm, - c.AllowedMethods) - } - return - } - acrhs := req.Request.Header.Get(HEADER_AccessControlRequestHeaders) - if len(acrhs) > 0 { - for _, each := range strings.Split(acrhs, ",") { - if !c.isValidAccessControlRequestHeader(strings.Trim(each, " ")) { - if trace { - traceLogger.Printf("Http header %s:%s is not in %v", - HEADER_AccessControlRequestHeaders, - acrhs, - c.AllowedHeaders) - } - return - } - } - } - resp.AddHeader(HEADER_AccessControlAllowMethods, strings.Join(c.AllowedMethods, ",")) - resp.AddHeader(HEADER_AccessControlAllowHeaders, acrhs) - c.setOptionsHeaders(req, resp) - - // return http 200 response, no body -} - -func (c CrossOriginResourceSharing) setOptionsHeaders(req *Request, resp *Response) { - c.checkAndSetExposeHeaders(resp) - c.setAllowOriginHeader(req, resp) - c.checkAndSetAllowCredentials(resp) - if c.MaxAge > 0 { - resp.AddHeader(HEADER_AccessControlMaxAge, strconv.Itoa(c.MaxAge)) - } -} - -func (c CrossOriginResourceSharing) isOriginAllowed(origin string) bool { - if len(origin) == 0 { - return false - } - if len(c.AllowedDomains) == 0 { - return true - } - - allowed := false - for _, domain := range c.AllowedDomains { - if domain == origin { - allowed = true - break - } - } - - if !allowed { - if len(c.allowedOriginPatterns) == 0 { - // compile allowed domains to allowed origin patterns - allowedOriginRegexps, err := compileRegexps(c.AllowedDomains) - if err != nil { - return false - } - c.allowedOriginPatterns = allowedOriginRegexps - } - - for _, pattern := range c.allowedOriginPatterns { - if allowed = pattern.MatchString(origin); allowed { - break - } - } - } - - return allowed -} - -func (c CrossOriginResourceSharing) setAllowOriginHeader(req *Request, resp *Response) { - origin := req.Request.Header.Get(HEADER_Origin) - if c.isOriginAllowed(origin) { - resp.AddHeader(HEADER_AccessControlAllowOrigin, origin) - } -} - -func (c CrossOriginResourceSharing) checkAndSetExposeHeaders(resp *Response) { - if len(c.ExposeHeaders) > 0 { - resp.AddHeader(HEADER_AccessControlExposeHeaders, strings.Join(c.ExposeHeaders, ",")) - } -} - -func (c CrossOriginResourceSharing) checkAndSetAllowCredentials(resp *Response) { - if c.CookiesAllowed { - resp.AddHeader(HEADER_AccessControlAllowCredentials, "true") - } -} - -func (c CrossOriginResourceSharing) isValidAccessControlRequestMethod(method string, allowedMethods []string) bool { - for _, each := range allowedMethods { - if each == method { - return true - } - } - return false -} - -func (c CrossOriginResourceSharing) isValidAccessControlRequestHeader(header string) bool { - for _, each := range c.AllowedHeaders { - if strings.ToLower(each) == strings.ToLower(header) { - return true - } - } - return false -} - -// Take a list of strings and compile them into a list of regular expressions. -func compileRegexps(regexpStrings []string) ([]*regexp.Regexp, error) { - regexps := []*regexp.Regexp{} - for _, regexpStr := range regexpStrings { - r, err := regexp.Compile(regexpStr) - if err != nil { - return regexps, err - } - regexps = append(regexps, r) - } - return regexps, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/coverage.sh b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/coverage.sh deleted file mode 100644 index e27dbf1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/coverage.sh +++ /dev/null @@ -1,2 +0,0 @@ -go test -coverprofile=coverage.out -go tool cover -html=coverage.out \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly.go deleted file mode 100644 index 185300d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly.go +++ /dev/null @@ -1,162 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "net/http" - "regexp" - "sort" - "strings" -) - -// CurlyRouter expects Routes with paths that contain zero or more parameters in curly brackets. -type CurlyRouter struct{} - -// SelectRoute is part of the Router interface and returns the best match -// for the WebService and its Route for the given Request. -func (c CurlyRouter) SelectRoute( - webServices []*WebService, - httpRequest *http.Request) (selectedService *WebService, selected *Route, err error) { - - requestTokens := tokenizePath(httpRequest.URL.Path) - - detectedService := c.detectWebService(requestTokens, webServices) - if detectedService == nil { - if trace { - traceLogger.Printf("no WebService was found to match URL path:%s\n", httpRequest.URL.Path) - } - return nil, nil, NewError(http.StatusNotFound, "404: Page Not Found") - } - candidateRoutes := c.selectRoutes(detectedService, requestTokens) - if len(candidateRoutes) == 0 { - if trace { - traceLogger.Printf("no Route in WebService with path %s was found to match URL path:%s\n", detectedService.rootPath, httpRequest.URL.Path) - } - return detectedService, nil, NewError(http.StatusNotFound, "404: Page Not Found") - } - selectedRoute, err := c.detectRoute(candidateRoutes, httpRequest) - if selectedRoute == nil { - return detectedService, nil, err - } - return detectedService, selectedRoute, nil -} - -// selectRoutes return a collection of Route from a WebService that matches the path tokens from the request. -func (c CurlyRouter) selectRoutes(ws *WebService, requestTokens []string) sortableCurlyRoutes { - candidates := sortableCurlyRoutes{} - for _, each := range ws.routes { - matches, paramCount, staticCount := c.matchesRouteByPathTokens(each.pathParts, requestTokens) - if matches { - candidates.add(curlyRoute{each, paramCount, staticCount}) // TODO make sure Routes() return pointers? - } - } - sort.Sort(sort.Reverse(candidates)) - return candidates -} - -// matchesRouteByPathTokens computes whether it matches, howmany parameters do match and what the number of static path elements are. -func (c CurlyRouter) matchesRouteByPathTokens(routeTokens, requestTokens []string) (matches bool, paramCount int, staticCount int) { - if len(routeTokens) < len(requestTokens) { - // proceed in matching only if last routeToken is wildcard - count := len(routeTokens) - if count == 0 || !strings.HasSuffix(routeTokens[count-1], "*}") { - return false, 0, 0 - } - // proceed - } - for i, routeToken := range routeTokens { - if i == len(requestTokens) { - // reached end of request path - return false, 0, 0 - } - requestToken := requestTokens[i] - if strings.HasPrefix(routeToken, "{") { - paramCount++ - if colon := strings.Index(routeToken, ":"); colon != -1 { - // match by regex - matchesToken, matchesRemainder := c.regularMatchesPathToken(routeToken, colon, requestToken) - if !matchesToken { - return false, 0, 0 - } - if matchesRemainder { - break - } - } - } else { // no { prefix - if requestToken != routeToken { - return false, 0, 0 - } - staticCount++ - } - } - return true, paramCount, staticCount -} - -// regularMatchesPathToken tests whether the regular expression part of routeToken matches the requestToken or all remaining tokens -// format routeToken is {someVar:someExpression}, e.g. {zipcode:[\d][\d][\d][\d][A-Z][A-Z]} -func (c CurlyRouter) regularMatchesPathToken(routeToken string, colon int, requestToken string) (matchesToken bool, matchesRemainder bool) { - regPart := routeToken[colon+1 : len(routeToken)-1] - if regPart == "*" { - if trace { - traceLogger.Printf("wildcard parameter detected in route token %s that matches %s\n", routeToken, requestToken) - } - return true, true - } - matched, err := regexp.MatchString(regPart, requestToken) - return (matched && err == nil), false -} - -// detectRoute selectes from a list of Route the first match by inspecting both the Accept and Content-Type -// headers of the Request. See also RouterJSR311 in jsr311.go -func (c CurlyRouter) detectRoute(candidateRoutes sortableCurlyRoutes, httpRequest *http.Request) (*Route, error) { - // tracing is done inside detectRoute - return RouterJSR311{}.detectRoute(candidateRoutes.routes(), httpRequest) -} - -// detectWebService returns the best matching webService given the list of path tokens. -// see also computeWebserviceScore -func (c CurlyRouter) detectWebService(requestTokens []string, webServices []*WebService) *WebService { - var best *WebService - score := -1 - for _, each := range webServices { - matches, eachScore := c.computeWebserviceScore(requestTokens, each.pathExpr.tokens) - if matches && (eachScore > score) { - best = each - score = eachScore - } - } - return best -} - -// computeWebserviceScore returns whether tokens match and -// the weighted score of the longest matching consecutive tokens from the beginning. -func (c CurlyRouter) computeWebserviceScore(requestTokens []string, tokens []string) (bool, int) { - if len(tokens) > len(requestTokens) { - return false, 0 - } - score := 0 - for i := 0; i < len(tokens); i++ { - each := requestTokens[i] - other := tokens[i] - if len(each) == 0 && len(other) == 0 { - score++ - continue - } - if len(other) > 0 && strings.HasPrefix(other, "{") { - // no empty match - if len(each) == 0 { - return false, score - } - score += 1 - } else { - // not a parameter - if each != other { - return false, score - } - score += (len(tokens) - i) * 10 //fuzzy - } - } - return true, score -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly_route.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly_route.go deleted file mode 100644 index 296f946..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/curly_route.go +++ /dev/null @@ -1,52 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -// curlyRoute exits for sorting Routes by the CurlyRouter based on number of parameters and number of static path elements. -type curlyRoute struct { - route Route - paramCount int - staticCount int -} - -type sortableCurlyRoutes []curlyRoute - -func (s *sortableCurlyRoutes) add(route curlyRoute) { - *s = append(*s, route) -} - -func (s sortableCurlyRoutes) routes() (routes []Route) { - for _, each := range s { - routes = append(routes, each.route) // TODO change return type - } - return routes -} - -func (s sortableCurlyRoutes) Len() int { - return len(s) -} -func (s sortableCurlyRoutes) Swap(i, j int) { - s[i], s[j] = s[j], s[i] -} -func (s sortableCurlyRoutes) Less(i, j int) bool { - ci := s[i] - cj := s[j] - - // primary key - if ci.staticCount < cj.staticCount { - return true - } - if ci.staticCount > cj.staticCount { - return false - } - // secundary key - if ci.paramCount < cj.paramCount { - return true - } - if ci.paramCount > cj.paramCount { - return false - } - return ci.route.Path < cj.route.Path -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/doc.go deleted file mode 100644 index d40405b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/doc.go +++ /dev/null @@ -1,196 +0,0 @@ -/* -Package restful, a lean package for creating REST-style WebServices without magic. - -WebServices and Routes - -A WebService has a collection of Route objects that dispatch incoming Http Requests to a function calls. -Typically, a WebService has a root path (e.g. /users) and defines common MIME types for its routes. -WebServices must be added to a container (see below) in order to handler Http requests from a server. - -A Route is defined by a HTTP method, an URL path and (optionally) the MIME types it consumes (Content-Type) and produces (Accept). -This package has the logic to find the best matching Route and if found, call its Function. - - ws := new(restful.WebService) - ws. - Path("/users"). - Consumes(restful.MIME_JSON, restful.MIME_XML). - Produces(restful.MIME_JSON, restful.MIME_XML) - - ws.Route(ws.GET("/{user-id}").To(u.findUser)) // u is a UserResource - - ... - - // GET http://localhost:8080/users/1 - func (u UserResource) findUser(request *restful.Request, response *restful.Response) { - id := request.PathParameter("user-id") - ... - } - -The (*Request, *Response) arguments provide functions for reading information from the request and writing information back to the response. - -See the example https://github.com/emicklei/go-restful/blob/master/examples/restful-user-resource.go with a full implementation. - -Regular expression matching Routes - -A Route parameter can be specified using the format "uri/{var[:regexp]}" or the special version "uri/{var:*}" for matching the tail of the path. -For example, /persons/{name:[A-Z][A-Z]} can be used to restrict values for the parameter "name" to only contain capital alphabetic characters. -Regular expressions must use the standard Go syntax as described in the regexp package. (https://code.google.com/p/re2/wiki/Syntax) -This feature requires the use of a CurlyRouter. - -Containers - -A Container holds a collection of WebServices, Filters and a http.ServeMux for multiplexing http requests. -Using the statements "restful.Add(...) and restful.Filter(...)" will register WebServices and Filters to the Default Container. -The Default container of go-restful uses the http.DefaultServeMux. -You can create your own Container and create a new http.Server for that particular container. - - container := restful.NewContainer() - server := &http.Server{Addr: ":8081", Handler: container} - -Filters - -A filter dynamically intercepts requests and responses to transform or use the information contained in the requests or responses. -You can use filters to perform generic logging, measurement, authentication, redirect, set response headers etc. -In the restful package there are three hooks into the request,response flow where filters can be added. -Each filter must define a FilterFunction: - - func (req *restful.Request, resp *restful.Response, chain *restful.FilterChain) - -Use the following statement to pass the request,response pair to the next filter or RouteFunction - - chain.ProcessFilter(req, resp) - -Container Filters - -These are processed before any registered WebService. - - // install a (global) filter for the default container (processed before any webservice) - restful.Filter(globalLogging) - -WebService Filters - -These are processed before any Route of a WebService. - - // install a webservice filter (processed before any route) - ws.Filter(webserviceLogging).Filter(measureTime) - - -Route Filters - -These are processed before calling the function associated with the Route. - - // install 2 chained route filters (processed before calling findUser) - ws.Route(ws.GET("/{user-id}").Filter(routeLogging).Filter(NewCountFilter().routeCounter).To(findUser)) - -See the example https://github.com/emicklei/go-restful/blob/master/examples/restful-filters.go with full implementations. - -Response Encoding - -Two encodings are supported: gzip and deflate. To enable this for all responses: - - restful.DefaultContainer.EnableContentEncoding(true) - -If a Http request includes the Accept-Encoding header then the response content will be compressed using the specified encoding. -Alternatively, you can create a Filter that performs the encoding and install it per WebService or Route. - -See the example https://github.com/emicklei/go-restful/blob/master/examples/restful-encoding-filter.go - -OPTIONS support - -By installing a pre-defined container filter, your Webservice(s) can respond to the OPTIONS Http request. - - Filter(OPTIONSFilter()) - -CORS - -By installing the filter of a CrossOriginResourceSharing (CORS), your WebService(s) can handle CORS requests. - - cors := CrossOriginResourceSharing{ExposeHeaders: []string{"X-My-Header"}, CookiesAllowed: false, Container: DefaultContainer} - Filter(cors.Filter) - -Error Handling - -Unexpected things happen. If a request cannot be processed because of a failure, your service needs to tell via the response what happened and why. -For this reason HTTP status codes exist and it is important to use the correct code in every exceptional situation. - - 400: Bad Request - -If path or query parameters are not valid (content or type) then use http.StatusBadRequest. - - 404: Not Found - -Despite a valid URI, the resource requested may not be available - - 500: Internal Server Error - -If the application logic could not process the request (or write the response) then use http.StatusInternalServerError. - - 405: Method Not Allowed - -The request has a valid URL but the method (GET,PUT,POST,...) is not allowed. - - 406: Not Acceptable - -The request does not have or has an unknown Accept Header set for this operation. - - 415: Unsupported Media Type - -The request does not have or has an unknown Content-Type Header set for this operation. - -ServiceError - -In addition to setting the correct (error) Http status code, you can choose to write a ServiceError message on the response. - -Performance options - -This package has several options that affect the performance of your service. It is important to understand them and how you can change it. - - restful.DefaultContainer.Router(CurlyRouter{}) - -The default router is the RouterJSR311 which is an implementation of its spec (http://jsr311.java.net/nonav/releases/1.1/spec/spec.html). -However, it uses regular expressions for all its routes which, depending on your usecase, may consume a significant amount of time. -The CurlyRouter implementation is more lightweight that also allows you to use wildcards and expressions, but only if needed. - - restful.DefaultContainer.DoNotRecover(true) - -DoNotRecover controls whether panics will be caught to return HTTP 500. -If set to true, Route functions are responsible for handling any error situation. -Default value is false; it will recover from panics. This has performance implications. - - restful.SetCacheReadEntity(false) - -SetCacheReadEntity controls whether the response data ([]byte) is cached such that ReadEntity is repeatable. -If you expect to read large amounts of payload data, and you do not use this feature, you should set it to false. - - restful.SetCompressorProvider(NewBoundedCachedCompressors(20, 20)) - -If content encoding is enabled then the default strategy for getting new gzip/zlib writers and readers is to use a sync.Pool. -Because writers are expensive structures, performance is even more improved when using a preloaded cache. You can also inject your own implementation. - -Trouble shooting - -This package has the means to produce detail logging of the complete Http request matching process and filter invocation. -Enabling this feature requires you to set an implementation of restful.StdLogger (e.g. log.Logger) instance such as: - - restful.TraceLogger(log.New(os.Stdout, "[restful] ", log.LstdFlags|log.Lshortfile)) - -Logging - -The restful.SetLogger() method allows you to override the logger used by the package. By default restful -uses the standard library `log` package and logs to stdout. Different logging packages are supported as -long as they conform to `StdLogger` interface defined in the `log` sub-package, writing an adapter for your -preferred package is simple. - -Resources - -[project]: https://github.com/emicklei/go-restful - -[examples]: https://github.com/emicklei/go-restful/blob/master/examples - -[design]: http://ernestmicklei.com/2012/11/11/go-restful-api-design/ - -[showcases]: https://github.com/emicklei/mora, https://github.com/emicklei/landskape - -(c) 2012-2015, http://ernestmicklei.com. MIT License -*/ -package restful diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/entity_accessors.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/entity_accessors.go deleted file mode 100644 index 6ecf6c7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/entity_accessors.go +++ /dev/null @@ -1,163 +0,0 @@ -package restful - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "encoding/json" - "encoding/xml" - "strings" - "sync" -) - -// EntityReaderWriter can read and write values using an encoding such as JSON,XML. -type EntityReaderWriter interface { - // Read a serialized version of the value from the request. - // The Request may have a decompressing reader. Depends on Content-Encoding. - Read(req *Request, v interface{}) error - - // Write a serialized version of the value on the response. - // The Response may have a compressing writer. Depends on Accept-Encoding. - // status should be a valid Http Status code - Write(resp *Response, status int, v interface{}) error -} - -// entityAccessRegistry is a singleton -var entityAccessRegistry = &entityReaderWriters{ - protection: new(sync.RWMutex), - accessors: map[string]EntityReaderWriter{}, -} - -// entityReaderWriters associates MIME to an EntityReaderWriter -type entityReaderWriters struct { - protection *sync.RWMutex - accessors map[string]EntityReaderWriter -} - -func init() { - RegisterEntityAccessor(MIME_JSON, NewEntityAccessorJSON(MIME_JSON)) - RegisterEntityAccessor(MIME_XML, NewEntityAccessorXML(MIME_XML)) -} - -// RegisterEntityAccessor add/overrides the ReaderWriter for encoding content with this MIME type. -func RegisterEntityAccessor(mime string, erw EntityReaderWriter) { - entityAccessRegistry.protection.Lock() - defer entityAccessRegistry.protection.Unlock() - entityAccessRegistry.accessors[mime] = erw -} - -// NewEntityAccessorJSON returns a new EntityReaderWriter for accessing JSON content. -// This package is already initialized with such an accessor using the MIME_JSON contentType. -func NewEntityAccessorJSON(contentType string) EntityReaderWriter { - return entityJSONAccess{ContentType: contentType} -} - -// NewEntityAccessorXML returns a new EntityReaderWriter for accessing XML content. -// This package is already initialized with such an accessor using the MIME_XML contentType. -func NewEntityAccessorXML(contentType string) EntityReaderWriter { - return entityXMLAccess{ContentType: contentType} -} - -// accessorAt returns the registered ReaderWriter for this MIME type. -func (r *entityReaderWriters) accessorAt(mime string) (EntityReaderWriter, bool) { - r.protection.RLock() - defer r.protection.RUnlock() - er, ok := r.accessors[mime] - if !ok { - // retry with reverse lookup - // more expensive but we are in an exceptional situation anyway - for k, v := range r.accessors { - if strings.Contains(mime, k) { - return v, true - } - } - } - return er, ok -} - -// entityXMLAccess is a EntityReaderWriter for XML encoding -type entityXMLAccess struct { - // This is used for setting the Content-Type header when writing - ContentType string -} - -// Read unmarshalls the value from XML -func (e entityXMLAccess) Read(req *Request, v interface{}) error { - return xml.NewDecoder(req.Request.Body).Decode(v) -} - -// Write marshalls the value to JSON and set the Content-Type Header. -func (e entityXMLAccess) Write(resp *Response, status int, v interface{}) error { - return writeXML(resp, status, e.ContentType, v) -} - -// writeXML marshalls the value to JSON and set the Content-Type Header. -func writeXML(resp *Response, status int, contentType string, v interface{}) error { - if v == nil { - resp.WriteHeader(status) - // do not write a nil representation - return nil - } - if resp.prettyPrint { - // pretty output must be created and written explicitly - output, err := xml.MarshalIndent(v, " ", " ") - if err != nil { - return err - } - resp.Header().Set(HEADER_ContentType, contentType) - resp.WriteHeader(status) - _, err = resp.Write([]byte(xml.Header)) - if err != nil { - return err - } - _, err = resp.Write(output) - return err - } - // not-so-pretty - resp.Header().Set(HEADER_ContentType, contentType) - resp.WriteHeader(status) - return xml.NewEncoder(resp).Encode(v) -} - -// entityJSONAccess is a EntityReaderWriter for JSON encoding -type entityJSONAccess struct { - // This is used for setting the Content-Type header when writing - ContentType string -} - -// Read unmarshalls the value from JSON -func (e entityJSONAccess) Read(req *Request, v interface{}) error { - decoder := json.NewDecoder(req.Request.Body) - decoder.UseNumber() - return decoder.Decode(v) -} - -// Write marshalls the value to JSON and set the Content-Type Header. -func (e entityJSONAccess) Write(resp *Response, status int, v interface{}) error { - return writeJSON(resp, status, e.ContentType, v) -} - -// write marshalls the value to JSON and set the Content-Type Header. -func writeJSON(resp *Response, status int, contentType string, v interface{}) error { - if v == nil { - resp.WriteHeader(status) - // do not write a nil representation - return nil - } - if resp.prettyPrint { - // pretty output must be created and written explicitly - output, err := json.MarshalIndent(v, " ", " ") - if err != nil { - return err - } - resp.Header().Set(HEADER_ContentType, contentType) - resp.WriteHeader(status) - _, err = resp.Write(output) - return err - } - // not-so-pretty - resp.Header().Set(HEADER_ContentType, contentType) - resp.WriteHeader(status) - return json.NewEncoder(resp).Encode(v) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/filter.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/filter.go deleted file mode 100644 index 4b86656..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/filter.go +++ /dev/null @@ -1,26 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -// FilterChain is a request scoped object to process one or more filters before calling the target RouteFunction. -type FilterChain struct { - Filters []FilterFunction // ordered list of FilterFunction - Index int // index into filters that is currently in progress - Target RouteFunction // function to call after passing all filters -} - -// ProcessFilter passes the request,response pair through the next of Filters. -// Each filter can decide to proceed to the next Filter or handle the Response itself. -func (f *FilterChain) ProcessFilter(request *Request, response *Response) { - if f.Index < len(f.Filters) { - f.Index++ - f.Filters[f.Index-1](request, response, f) - } else { - f.Target(request, response) - } -} - -// FilterFunction definitions must call ProcessFilter on the FilterChain to pass on the control and eventually call the RouteFunction -type FilterFunction func(*Request, *Response, *FilterChain) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/install.sh b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/install.sh deleted file mode 100644 index 36cbf25..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/install.sh +++ /dev/null @@ -1,10 +0,0 @@ -go test -test.v ...restful && \ -go test -test.v ...swagger && \ -go vet ...restful && \ -go fmt ...swagger && \ -go install ...swagger && \ -go fmt ...restful && \ -go install ...restful -cd examples - ls *.go | xargs -I {} go build -o /tmp/ignore {} - cd .. \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/jsr311.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/jsr311.go deleted file mode 100644 index 511444a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/jsr311.go +++ /dev/null @@ -1,248 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "errors" - "fmt" - "net/http" - "sort" -) - -// RouterJSR311 implements the flow for matching Requests to Routes (and consequently Resource Functions) -// as specified by the JSR311 http://jsr311.java.net/nonav/releases/1.1/spec/spec.html. -// RouterJSR311 implements the Router interface. -// Concept of locators is not implemented. -type RouterJSR311 struct{} - -// SelectRoute is part of the Router interface and returns the best match -// for the WebService and its Route for the given Request. -func (r RouterJSR311) SelectRoute( - webServices []*WebService, - httpRequest *http.Request) (selectedService *WebService, selectedRoute *Route, err error) { - - // Identify the root resource class (WebService) - dispatcher, finalMatch, err := r.detectDispatcher(httpRequest.URL.Path, webServices) - if err != nil { - return nil, nil, NewError(http.StatusNotFound, "") - } - // Obtain the set of candidate methods (Routes) - routes := r.selectRoutes(dispatcher, finalMatch) - if len(routes) == 0 { - return dispatcher, nil, NewError(http.StatusNotFound, "404: Page Not Found") - } - - // Identify the method (Route) that will handle the request - route, ok := r.detectRoute(routes, httpRequest) - return dispatcher, route, ok -} - -// http://jsr311.java.net/nonav/releases/1.1/spec/spec3.html#x3-360003.7.2 -func (r RouterJSR311) detectRoute(routes []Route, httpRequest *http.Request) (*Route, error) { - // http method - methodOk := []Route{} - for _, each := range routes { - if httpRequest.Method == each.Method { - methodOk = append(methodOk, each) - } - } - if len(methodOk) == 0 { - if trace { - traceLogger.Printf("no Route found (in %d routes) that matches HTTP method %s\n", len(routes), httpRequest.Method) - } - return nil, NewError(http.StatusMethodNotAllowed, "405: Method Not Allowed") - } - inputMediaOk := methodOk - - // content-type - contentType := httpRequest.Header.Get(HEADER_ContentType) - inputMediaOk = []Route{} - for _, each := range methodOk { - if each.matchesContentType(contentType) { - inputMediaOk = append(inputMediaOk, each) - } - } - if len(inputMediaOk) == 0 { - if trace { - traceLogger.Printf("no Route found (from %d) that matches HTTP Content-Type: %s\n", len(methodOk), contentType) - } - return nil, NewError(http.StatusUnsupportedMediaType, "415: Unsupported Media Type") - } - - // accept - outputMediaOk := []Route{} - accept := httpRequest.Header.Get(HEADER_Accept) - if len(accept) == 0 { - accept = "*/*" - } - for _, each := range inputMediaOk { - if each.matchesAccept(accept) { - outputMediaOk = append(outputMediaOk, each) - } - } - if len(outputMediaOk) == 0 { - if trace { - traceLogger.Printf("no Route found (from %d) that matches HTTP Accept: %s\n", len(inputMediaOk), accept) - } - return nil, NewError(http.StatusNotAcceptable, "406: Not Acceptable") - } - // return r.bestMatchByMedia(outputMediaOk, contentType, accept), nil - return &outputMediaOk[0], nil -} - -// http://jsr311.java.net/nonav/releases/1.1/spec/spec3.html#x3-360003.7.2 -// n/m > n/* > */* -func (r RouterJSR311) bestMatchByMedia(routes []Route, contentType string, accept string) *Route { - // TODO - return &routes[0] -} - -// http://jsr311.java.net/nonav/releases/1.1/spec/spec3.html#x3-360003.7.2 (step 2) -func (r RouterJSR311) selectRoutes(dispatcher *WebService, pathRemainder string) []Route { - filtered := &sortableRouteCandidates{} - for _, each := range dispatcher.Routes() { - pathExpr := each.pathExpr - matches := pathExpr.Matcher.FindStringSubmatch(pathRemainder) - if matches != nil { - lastMatch := matches[len(matches)-1] - if len(lastMatch) == 0 || lastMatch == "/" { // do not include if value is neither empty nor ‘/’. - filtered.candidates = append(filtered.candidates, - routeCandidate{each, len(matches) - 1, pathExpr.LiteralCount, pathExpr.VarCount}) - } - } - } - if len(filtered.candidates) == 0 { - if trace { - traceLogger.Printf("WebService on path %s has no routes that match URL path remainder:%s\n", dispatcher.rootPath, pathRemainder) - } - return []Route{} - } - sort.Sort(sort.Reverse(filtered)) - - // select other routes from candidates whoes expression matches rmatch - matchingRoutes := []Route{filtered.candidates[0].route} - for c := 1; c < len(filtered.candidates); c++ { - each := filtered.candidates[c] - if each.route.pathExpr.Matcher.MatchString(pathRemainder) { - matchingRoutes = append(matchingRoutes, each.route) - } - } - return matchingRoutes -} - -// http://jsr311.java.net/nonav/releases/1.1/spec/spec3.html#x3-360003.7.2 (step 1) -func (r RouterJSR311) detectDispatcher(requestPath string, dispatchers []*WebService) (*WebService, string, error) { - filtered := &sortableDispatcherCandidates{} - for _, each := range dispatchers { - matches := each.pathExpr.Matcher.FindStringSubmatch(requestPath) - if matches != nil { - filtered.candidates = append(filtered.candidates, - dispatcherCandidate{each, matches[len(matches)-1], len(matches), each.pathExpr.LiteralCount, each.pathExpr.VarCount}) - } - } - if len(filtered.candidates) == 0 { - if trace { - traceLogger.Printf("no WebService was found to match URL path:%s\n", requestPath) - } - return nil, "", errors.New("not found") - } - sort.Sort(sort.Reverse(filtered)) - return filtered.candidates[0].dispatcher, filtered.candidates[0].finalMatch, nil -} - -// Types and functions to support the sorting of Routes - -type routeCandidate struct { - route Route - matchesCount int // the number of capturing groups - literalCount int // the number of literal characters (means those not resulting from template variable substitution) - nonDefaultCount int // the number of capturing groups with non-default regular expressions (i.e. not ‘([^ /]+?)’) -} - -func (r routeCandidate) expressionToMatch() string { - return r.route.pathExpr.Source -} - -func (r routeCandidate) String() string { - return fmt.Sprintf("(m=%d,l=%d,n=%d)", r.matchesCount, r.literalCount, r.nonDefaultCount) -} - -type sortableRouteCandidates struct { - candidates []routeCandidate -} - -func (rcs *sortableRouteCandidates) Len() int { - return len(rcs.candidates) -} -func (rcs *sortableRouteCandidates) Swap(i, j int) { - rcs.candidates[i], rcs.candidates[j] = rcs.candidates[j], rcs.candidates[i] -} -func (rcs *sortableRouteCandidates) Less(i, j int) bool { - ci := rcs.candidates[i] - cj := rcs.candidates[j] - // primary key - if ci.literalCount < cj.literalCount { - return true - } - if ci.literalCount > cj.literalCount { - return false - } - // secundary key - if ci.matchesCount < cj.matchesCount { - return true - } - if ci.matchesCount > cj.matchesCount { - return false - } - // tertiary key - if ci.nonDefaultCount < cj.nonDefaultCount { - return true - } - if ci.nonDefaultCount > cj.nonDefaultCount { - return false - } - // quaternary key ("source" is interpreted as Path) - return ci.route.Path < cj.route.Path -} - -// Types and functions to support the sorting of Dispatchers - -type dispatcherCandidate struct { - dispatcher *WebService - finalMatch string - matchesCount int // the number of capturing groups - literalCount int // the number of literal characters (means those not resulting from template variable substitution) - nonDefaultCount int // the number of capturing groups with non-default regular expressions (i.e. not ‘([^ /]+?)’) -} -type sortableDispatcherCandidates struct { - candidates []dispatcherCandidate -} - -func (dc *sortableDispatcherCandidates) Len() int { - return len(dc.candidates) -} -func (dc *sortableDispatcherCandidates) Swap(i, j int) { - dc.candidates[i], dc.candidates[j] = dc.candidates[j], dc.candidates[i] -} -func (dc *sortableDispatcherCandidates) Less(i, j int) bool { - ci := dc.candidates[i] - cj := dc.candidates[j] - // primary key - if ci.matchesCount < cj.matchesCount { - return true - } - if ci.matchesCount > cj.matchesCount { - return false - } - // secundary key - if ci.literalCount < cj.literalCount { - return true - } - if ci.literalCount > cj.literalCount { - return false - } - // tertiary key - return ci.nonDefaultCount < cj.nonDefaultCount -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/log/log.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/log/log.go deleted file mode 100644 index f70d895..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/log/log.go +++ /dev/null @@ -1,31 +0,0 @@ -package log - -import ( - stdlog "log" - "os" -) - -// Logger corresponds to a minimal subset of the interface satisfied by stdlib log.Logger -type StdLogger interface { - Print(v ...interface{}) - Printf(format string, v ...interface{}) -} - -var Logger StdLogger - -func init() { - // default Logger - SetLogger(stdlog.New(os.Stderr, "[restful] ", stdlog.LstdFlags|stdlog.Lshortfile)) -} - -func SetLogger(customLogger StdLogger) { - Logger = customLogger -} - -func Print(v ...interface{}) { - Logger.Print(v...) -} - -func Printf(format string, v ...interface{}) { - Logger.Printf(format, v...) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/logger.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/logger.go deleted file mode 100644 index 3f1c4db..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/logger.go +++ /dev/null @@ -1,32 +0,0 @@ -package restful - -// Copyright 2014 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. -import ( - "github.com/emicklei/go-restful/log" -) - -var trace bool = false -var traceLogger log.StdLogger - -func init() { - traceLogger = log.Logger // use the package logger by default -} - -// TraceLogger enables detailed logging of Http request matching and filter invocation. Default no logger is set. -// You may call EnableTracing() directly to enable trace logging to the package-wide logger. -func TraceLogger(logger log.StdLogger) { - traceLogger = logger - EnableTracing(logger != nil) -} - -// expose the setter for the global logger on the top-level package -func SetLogger(customLogger log.StdLogger) { - log.SetLogger(customLogger) -} - -// EnableTracing can be used to Trace logging on and off. -func EnableTracing(enabled bool) { - trace = enabled -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/mime.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/mime.go deleted file mode 100644 index d7ea2b6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/mime.go +++ /dev/null @@ -1,45 +0,0 @@ -package restful - -import ( - "strconv" - "strings" -) - -type mime struct { - media string - quality float64 -} - -// insertMime adds a mime to a list and keeps it sorted by quality. -func insertMime(l []mime, e mime) []mime { - for i, each := range l { - // if current mime has lower quality then insert before - if e.quality > each.quality { - left := append([]mime{}, l[0:i]...) - return append(append(left, e), l[i:]...) - } - } - return append(l, e) -} - -// sortedMimes returns a list of mime sorted (desc) by its specified quality. -func sortedMimes(accept string) (sorted []mime) { - for _, each := range strings.Split(accept, ",") { - typeAndQuality := strings.Split(strings.Trim(each, " "), ";") - if len(typeAndQuality) == 1 { - sorted = insertMime(sorted, mime{typeAndQuality[0], 1.0}) - } else { - // take factor - parts := strings.Split(typeAndQuality[1], "=") - if len(parts) == 2 { - f, err := strconv.ParseFloat(parts[1], 64) - if err != nil { - traceLogger.Printf("unable to parse quality in %s, %v", each, err) - } else { - sorted = insertMime(sorted, mime{typeAndQuality[0], f}) - } - } - } - } - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/options_filter.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/options_filter.go deleted file mode 100644 index 4514ead..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/options_filter.go +++ /dev/null @@ -1,26 +0,0 @@ -package restful - -import "strings" - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -// OPTIONSFilter is a filter function that inspects the Http Request for the OPTIONS method -// and provides the response with a set of allowed methods for the request URL Path. -// As for any filter, you can also install it for a particular WebService within a Container. -// Note: this filter is not needed when using CrossOriginResourceSharing (for CORS). -func (c *Container) OPTIONSFilter(req *Request, resp *Response, chain *FilterChain) { - if "OPTIONS" != req.Request.Method { - chain.ProcessFilter(req, resp) - return - } - resp.AddHeader(HEADER_Allow, strings.Join(c.computeAllowedMethods(req), ",")) -} - -// OPTIONSFilter is a filter function that inspects the Http Request for the OPTIONS method -// and provides the response with a set of allowed methods for the request URL Path. -// Note: this filter is not needed when using CrossOriginResourceSharing (for CORS). -func OPTIONSFilter() FilterFunction { - return DefaultContainer.OPTIONSFilter -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/parameter.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/parameter.go deleted file mode 100644 index e11c816..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/parameter.go +++ /dev/null @@ -1,114 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -const ( - // PathParameterKind = indicator of Request parameter type "path" - PathParameterKind = iota - - // QueryParameterKind = indicator of Request parameter type "query" - QueryParameterKind - - // BodyParameterKind = indicator of Request parameter type "body" - BodyParameterKind - - // HeaderParameterKind = indicator of Request parameter type "header" - HeaderParameterKind - - // FormParameterKind = indicator of Request parameter type "form" - FormParameterKind -) - -// Parameter is for documententing the parameter used in a Http Request -// ParameterData kinds are Path,Query and Body -type Parameter struct { - data *ParameterData -} - -// ParameterData represents the state of a Parameter. -// It is made public to make it accessible to e.g. the Swagger package. -type ParameterData struct { - Name, Description, DataType, DataFormat string - Kind int - Required bool - AllowableValues map[string]string - AllowMultiple bool - DefaultValue string -} - -// Data returns the state of the Parameter -func (p *Parameter) Data() ParameterData { - return *p.data -} - -// Kind returns the parameter type indicator (see const for valid values) -func (p *Parameter) Kind() int { - return p.data.Kind -} - -func (p *Parameter) bePath() *Parameter { - p.data.Kind = PathParameterKind - return p -} -func (p *Parameter) beQuery() *Parameter { - p.data.Kind = QueryParameterKind - return p -} -func (p *Parameter) beBody() *Parameter { - p.data.Kind = BodyParameterKind - return p -} - -func (p *Parameter) beHeader() *Parameter { - p.data.Kind = HeaderParameterKind - return p -} - -func (p *Parameter) beForm() *Parameter { - p.data.Kind = FormParameterKind - return p -} - -// Required sets the required field and returns the receiver -func (p *Parameter) Required(required bool) *Parameter { - p.data.Required = required - return p -} - -// AllowMultiple sets the allowMultiple field and returns the receiver -func (p *Parameter) AllowMultiple(multiple bool) *Parameter { - p.data.AllowMultiple = multiple - return p -} - -// AllowableValues sets the allowableValues field and returns the receiver -func (p *Parameter) AllowableValues(values map[string]string) *Parameter { - p.data.AllowableValues = values - return p -} - -// DataType sets the dataType field and returns the receiver -func (p *Parameter) DataType(typeName string) *Parameter { - p.data.DataType = typeName - return p -} - -// DataFormat sets the dataFormat field for Swagger UI -func (p *Parameter) DataFormat(formatName string) *Parameter { - p.data.DataFormat = formatName - return p -} - -// DefaultValue sets the default value field and returns the receiver -func (p *Parameter) DefaultValue(stringRepresentation string) *Parameter { - p.data.DefaultValue = stringRepresentation - return p -} - -// Description sets the description value field and returns the receiver -func (p *Parameter) Description(doc string) *Parameter { - p.data.Description = doc - return p -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/path_expression.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/path_expression.go deleted file mode 100644 index a921e6f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/path_expression.go +++ /dev/null @@ -1,69 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "fmt" - "regexp" - "strings" -) - -// PathExpression holds a compiled path expression (RegExp) needed to match against -// Http request paths and to extract path parameter values. -type pathExpression struct { - LiteralCount int // the number of literal characters (means those not resulting from template variable substitution) - VarCount int // the number of named parameters (enclosed by {}) in the path - Matcher *regexp.Regexp - Source string // Path as defined by the RouteBuilder - tokens []string -} - -// NewPathExpression creates a PathExpression from the input URL path. -// Returns an error if the path is invalid. -func newPathExpression(path string) (*pathExpression, error) { - expression, literalCount, varCount, tokens := templateToRegularExpression(path) - compiled, err := regexp.Compile(expression) - if err != nil { - return nil, err - } - return &pathExpression{literalCount, varCount, compiled, expression, tokens}, nil -} - -// http://jsr311.java.net/nonav/releases/1.1/spec/spec3.html#x3-370003.7.3 -func templateToRegularExpression(template string) (expression string, literalCount int, varCount int, tokens []string) { - var buffer bytes.Buffer - buffer.WriteString("^") - //tokens = strings.Split(template, "/") - tokens = tokenizePath(template) - for _, each := range tokens { - if each == "" { - continue - } - buffer.WriteString("/") - if strings.HasPrefix(each, "{") { - // check for regular expression in variable - colon := strings.Index(each, ":") - if colon != -1 { - // extract expression - paramExpr := strings.TrimSpace(each[colon+1 : len(each)-1]) - if paramExpr == "*" { // special case - buffer.WriteString("(.*)") - } else { - buffer.WriteString(fmt.Sprintf("(%s)", paramExpr)) // between colon and closing moustache - } - } else { - // plain var - buffer.WriteString("([^/]+?)") - } - varCount += 1 - } else { - literalCount += len(each) - encoded := each // TODO URI encode - buffer.WriteString(regexp.QuoteMeta(encoded)) - } - } - return strings.TrimRight(buffer.String(), "/") + "(/.*)?$", literalCount, varCount, tokens -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/request.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/request.go deleted file mode 100644 index 3e42346..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/request.go +++ /dev/null @@ -1,131 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "compress/zlib" - "io/ioutil" - "net/http" -) - -var defaultRequestContentType string - -var doCacheReadEntityBytes = true - -// Request is a wrapper for a http Request that provides convenience methods -type Request struct { - Request *http.Request - bodyContent *[]byte // to cache the request body for multiple reads of ReadEntity - pathParameters map[string]string - attributes map[string]interface{} // for storing request-scoped values - selectedRoutePath string // root path + route path that matched the request, e.g. /meetings/{id}/attendees -} - -func NewRequest(httpRequest *http.Request) *Request { - return &Request{ - Request: httpRequest, - pathParameters: map[string]string{}, - attributes: map[string]interface{}{}, - } // empty parameters, attributes -} - -// If ContentType is missing or */* is given then fall back to this type, otherwise -// a "Unable to unmarshal content of type:" response is returned. -// Valid values are restful.MIME_JSON and restful.MIME_XML -// Example: -// restful.DefaultRequestContentType(restful.MIME_JSON) -func DefaultRequestContentType(mime string) { - defaultRequestContentType = mime -} - -// SetCacheReadEntity controls whether the response data ([]byte) is cached such that ReadEntity is repeatable. -// Default is true (due to backwardcompatibility). For better performance, you should set it to false if you don't need it. -func SetCacheReadEntity(doCache bool) { - doCacheReadEntityBytes = doCache -} - -// PathParameter accesses the Path parameter value by its name -func (r *Request) PathParameter(name string) string { - return r.pathParameters[name] -} - -// PathParameters accesses the Path parameter values -func (r *Request) PathParameters() map[string]string { - return r.pathParameters -} - -// QueryParameter returns the (first) Query parameter value by its name -func (r *Request) QueryParameter(name string) string { - return r.Request.FormValue(name) -} - -// BodyParameter parses the body of the request (once for typically a POST or a PUT) and returns the value of the given name or an error. -func (r *Request) BodyParameter(name string) (string, error) { - err := r.Request.ParseForm() - if err != nil { - return "", err - } - return r.Request.PostFormValue(name), nil -} - -// HeaderParameter returns the HTTP Header value of a Header name or empty if missing -func (r *Request) HeaderParameter(name string) string { - return r.Request.Header.Get(name) -} - -// ReadEntity checks the Accept header and reads the content into the entityPointer. -func (r *Request) ReadEntity(entityPointer interface{}) (err error) { - contentType := r.Request.Header.Get(HEADER_ContentType) - contentEncoding := r.Request.Header.Get(HEADER_ContentEncoding) - - // OLD feature, cache the body for reads - if doCacheReadEntityBytes { - if r.bodyContent == nil { - data, err := ioutil.ReadAll(r.Request.Body) - if err != nil { - return err - } - r.bodyContent = &data - } - r.Request.Body = ioutil.NopCloser(bytes.NewReader(*r.bodyContent)) - } - - // check if the request body needs decompression - if ENCODING_GZIP == contentEncoding { - gzipReader := currentCompressorProvider.AcquireGzipReader() - defer currentCompressorProvider.ReleaseGzipReader(gzipReader) - gzipReader.Reset(r.Request.Body) - r.Request.Body = gzipReader - } else if ENCODING_DEFLATE == contentEncoding { - zlibReader, err := zlib.NewReader(r.Request.Body) - if err != nil { - return err - } - r.Request.Body = zlibReader - } - - // lookup the EntityReader - entityReader, ok := entityAccessRegistry.accessorAt(contentType) - if !ok { - return NewError(http.StatusBadRequest, "Unable to unmarshal content of type:"+contentType) - } - return entityReader.Read(r, entityPointer) -} - -// SetAttribute adds or replaces the attribute with the given value. -func (r *Request) SetAttribute(name string, value interface{}) { - r.attributes[name] = value -} - -// Attribute returns the value associated to the given name. Returns nil if absent. -func (r Request) Attribute(name string) interface{} { - return r.attributes[name] -} - -// SelectedRoutePath root path + route path that matched the request, e.g. /meetings/{id}/attendees -func (r Request) SelectedRoutePath() string { - return r.selectedRoutePath -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/response.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/response.go deleted file mode 100644 index 971cd0b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/response.go +++ /dev/null @@ -1,235 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "errors" - "net/http" -) - -// DEPRECATED, use DefaultResponseContentType(mime) -var DefaultResponseMimeType string - -//PrettyPrintResponses controls the indentation feature of XML and JSON serialization -var PrettyPrintResponses = true - -// Response is a wrapper on the actual http ResponseWriter -// It provides several convenience methods to prepare and write response content. -type Response struct { - http.ResponseWriter - requestAccept string // mime-type what the Http Request says it wants to receive - routeProduces []string // mime-types what the Route says it can produce - statusCode int // HTTP status code that has been written explicity (if zero then net/http has written 200) - contentLength int // number of bytes written for the response body - prettyPrint bool // controls the indentation feature of XML and JSON serialization. It is initialized using var PrettyPrintResponses. - err error // err property is kept when WriteError is called -} - -// Creates a new response based on a http ResponseWriter. -func NewResponse(httpWriter http.ResponseWriter) *Response { - return &Response{httpWriter, "", []string{}, http.StatusOK, 0, PrettyPrintResponses, nil} // empty content-types -} - -// If Accept header matching fails, fall back to this type. -// Valid values are restful.MIME_JSON and restful.MIME_XML -// Example: -// restful.DefaultResponseContentType(restful.MIME_JSON) -func DefaultResponseContentType(mime string) { - DefaultResponseMimeType = mime -} - -// InternalServerError writes the StatusInternalServerError header. -// DEPRECATED, use WriteErrorString(http.StatusInternalServerError,reason) -func (r Response) InternalServerError() Response { - r.WriteHeader(http.StatusInternalServerError) - return r -} - -// PrettyPrint changes whether this response must produce pretty (line-by-line, indented) JSON or XML output. -func (r *Response) PrettyPrint(bePretty bool) { - r.prettyPrint = bePretty -} - -// AddHeader is a shortcut for .Header().Add(header,value) -func (r Response) AddHeader(header string, value string) Response { - r.Header().Add(header, value) - return r -} - -// SetRequestAccepts tells the response what Mime-type(s) the HTTP request said it wants to accept. Exposed for testing. -func (r *Response) SetRequestAccepts(mime string) { - r.requestAccept = mime -} - -// EntityWriter returns the registered EntityWriter that the entity (requested resource) -// can write according to what the request wants (Accept) and what the Route can produce or what the restful defaults say. -// If called before WriteEntity and WriteHeader then a false return value can be used to write a 406: Not Acceptable. -func (r *Response) EntityWriter() (EntityReaderWriter, bool) { - sorted := sortedMimes(r.requestAccept) - for _, eachAccept := range sorted { - for _, eachProduce := range r.routeProduces { - if eachProduce == eachAccept.media { - if w, ok := entityAccessRegistry.accessorAt(eachAccept.media); ok { - return w, true - } - } - } - if eachAccept.media == "*/*" { - for _, each := range r.routeProduces { - if w, ok := entityAccessRegistry.accessorAt(each); ok { - return w, true - } - } - } - } - // if requestAccept is empty - writer, ok := entityAccessRegistry.accessorAt(r.requestAccept) - if !ok { - // if not registered then fallback to the defaults (if set) - if DefaultResponseMimeType == MIME_JSON { - return entityAccessRegistry.accessorAt(MIME_JSON) - } - if DefaultResponseMimeType == MIME_XML { - return entityAccessRegistry.accessorAt(MIME_XML) - } - // Fallback to whatever the route says it can produce. - // https://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html - for _, each := range r.routeProduces { - if w, ok := entityAccessRegistry.accessorAt(each); ok { - return w, true - } - } - if trace { - traceLogger.Printf("no registered EntityReaderWriter found for %s", r.requestAccept) - } - } - return writer, ok -} - -// WriteEntity calls WriteHeaderAndEntity with Http Status OK (200) -func (r *Response) WriteEntity(value interface{}) error { - return r.WriteHeaderAndEntity(http.StatusOK, value) -} - -// WriteHeaderAndEntity marshals the value using the representation denoted by the Accept Header and the registered EntityWriters. -// If no Accept header is specified (or */*) then respond with the Content-Type as specified by the first in the Route.Produces. -// If an Accept header is specified then respond with the Content-Type as specified by the first in the Route.Produces that is matched with the Accept header. -// If the value is nil then no response is send except for the Http status. You may want to call WriteHeader(http.StatusNotFound) instead. -// If there is no writer available that can represent the value in the requested MIME type then Http Status NotAcceptable is written. -// Current implementation ignores any q-parameters in the Accept Header. -// Returns an error if the value could not be written on the response. -func (r *Response) WriteHeaderAndEntity(status int, value interface{}) error { - writer, ok := r.EntityWriter() - if !ok { - r.WriteHeader(http.StatusNotAcceptable) - return nil - } - return writer.Write(r, status, value) -} - -// WriteAsXml is a convenience method for writing a value in xml (requires Xml tags on the value) -// It uses the standard encoding/xml package for marshalling the value ; not using a registered EntityReaderWriter. -func (r *Response) WriteAsXml(value interface{}) error { - return writeXML(r, http.StatusOK, MIME_XML, value) -} - -// WriteHeaderAndXml is a convenience method for writing a status and value in xml (requires Xml tags on the value) -// It uses the standard encoding/xml package for marshalling the value ; not using a registered EntityReaderWriter. -func (r *Response) WriteHeaderAndXml(status int, value interface{}) error { - return writeXML(r, status, MIME_XML, value) -} - -// WriteAsJson is a convenience method for writing a value in json. -// It uses the standard encoding/json package for marshalling the value ; not using a registered EntityReaderWriter. -func (r *Response) WriteAsJson(value interface{}) error { - return writeJSON(r, http.StatusOK, MIME_JSON, value) -} - -// WriteJson is a convenience method for writing a value in Json with a given Content-Type. -// It uses the standard encoding/json package for marshalling the value ; not using a registered EntityReaderWriter. -func (r *Response) WriteJson(value interface{}, contentType string) error { - return writeJSON(r, http.StatusOK, contentType, value) -} - -// WriteHeaderAndJson is a convenience method for writing the status and a value in Json with a given Content-Type. -// It uses the standard encoding/json package for marshalling the value ; not using a registered EntityReaderWriter. -func (r *Response) WriteHeaderAndJson(status int, value interface{}, contentType string) error { - return writeJSON(r, status, contentType, value) -} - -// WriteError write the http status and the error string on the response. -func (r *Response) WriteError(httpStatus int, err error) error { - r.err = err - return r.WriteErrorString(httpStatus, err.Error()) -} - -// WriteServiceError is a convenience method for a responding with a status and a ServiceError -func (r *Response) WriteServiceError(httpStatus int, err ServiceError) error { - r.err = err - return r.WriteHeaderAndEntity(httpStatus, err) -} - -// WriteErrorString is a convenience method for an error status with the actual error -func (r *Response) WriteErrorString(httpStatus int, errorReason string) error { - if r.err == nil { - // if not called from WriteError - r.err = errors.New(errorReason) - } - r.WriteHeader(httpStatus) - if _, err := r.Write([]byte(errorReason)); err != nil { - return err - } - return nil -} - -// Flush implements http.Flusher interface, which sends any buffered data to the client. -func (r *Response) Flush() { - if f, ok := r.ResponseWriter.(http.Flusher); ok { - f.Flush() - } else if trace { - traceLogger.Printf("ResponseWriter %v doesn't support Flush", r) - } -} - -// WriteHeader is overridden to remember the Status Code that has been written. -// Changes to the Header of the response have no effect after this. -func (r *Response) WriteHeader(httpStatus int) { - r.statusCode = httpStatus - r.ResponseWriter.WriteHeader(httpStatus) -} - -// StatusCode returns the code that has been written using WriteHeader. -func (r Response) StatusCode() int { - if 0 == r.statusCode { - // no status code has been written yet; assume OK - return http.StatusOK - } - return r.statusCode -} - -// Write writes the data to the connection as part of an HTTP reply. -// Write is part of http.ResponseWriter interface. -func (r *Response) Write(bytes []byte) (int, error) { - written, err := r.ResponseWriter.Write(bytes) - r.contentLength += written - return written, err -} - -// ContentLength returns the number of bytes written for the response content. -// Note that this value is only correct if all data is written through the Response using its Write* methods. -// Data written directly using the underlying http.ResponseWriter is not accounted for. -func (r Response) ContentLength() int { - return r.contentLength -} - -// CloseNotify is part of http.CloseNotifier interface -func (r Response) CloseNotify() <-chan bool { - return r.ResponseWriter.(http.CloseNotifier).CloseNotify() -} - -// Error returns the err created by WriteError -func (r Response) Error() error { - return r.err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route.go deleted file mode 100644 index f54e862..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route.go +++ /dev/null @@ -1,183 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "net/http" - "strings" -) - -// RouteFunction declares the signature of a function that can be bound to a Route. -type RouteFunction func(*Request, *Response) - -// Route binds a HTTP Method,Path,Consumes combination to a RouteFunction. -type Route struct { - Method string - Produces []string - Consumes []string - Path string // webservice root path + described path - Function RouteFunction - Filters []FilterFunction - - // cached values for dispatching - relativePath string - pathParts []string - pathExpr *pathExpression // cached compilation of relativePath as RegExp - - // documentation - Doc string - Notes string - Operation string - ParameterDocs []*Parameter - ResponseErrors map[int]ResponseError - ReadSample, WriteSample interface{} // structs that model an example request or response payload -} - -// Initialize for Route -func (r *Route) postBuild() { - r.pathParts = tokenizePath(r.Path) -} - -// Create Request and Response from their http versions -func (r *Route) wrapRequestResponse(httpWriter http.ResponseWriter, httpRequest *http.Request) (*Request, *Response) { - params := r.extractParameters(httpRequest.URL.Path) - wrappedRequest := NewRequest(httpRequest) - wrappedRequest.pathParameters = params - wrappedRequest.selectedRoutePath = r.Path - wrappedResponse := NewResponse(httpWriter) - wrappedResponse.requestAccept = httpRequest.Header.Get(HEADER_Accept) - wrappedResponse.routeProduces = r.Produces - return wrappedRequest, wrappedResponse -} - -// dispatchWithFilters call the function after passing through its own filters -func (r *Route) dispatchWithFilters(wrappedRequest *Request, wrappedResponse *Response) { - if len(r.Filters) > 0 { - chain := FilterChain{Filters: r.Filters, Target: r.Function} - chain.ProcessFilter(wrappedRequest, wrappedResponse) - } else { - // unfiltered - r.Function(wrappedRequest, wrappedResponse) - } -} - -// Return whether the mimeType matches to what this Route can produce. -func (r Route) matchesAccept(mimeTypesWithQuality string) bool { - parts := strings.Split(mimeTypesWithQuality, ",") - for _, each := range parts { - var withoutQuality string - if strings.Contains(each, ";") { - withoutQuality = strings.Split(each, ";")[0] - } else { - withoutQuality = each - } - // trim before compare - withoutQuality = strings.Trim(withoutQuality, " ") - if withoutQuality == "*/*" { - return true - } - for _, producibleType := range r.Produces { - if producibleType == "*/*" || producibleType == withoutQuality { - return true - } - } - } - return false -} - -// Return whether this Route can consume content with a type specified by mimeTypes (can be empty). -func (r Route) matchesContentType(mimeTypes string) bool { - - if len(r.Consumes) == 0 { - // did not specify what it can consume ; any media type (“*/*”) is assumed - return true - } - - if len(mimeTypes) == 0 { - // idempotent methods with (most-likely or garanteed) empty content match missing Content-Type - m := r.Method - if m == "GET" || m == "HEAD" || m == "OPTIONS" || m == "DELETE" || m == "TRACE" { - return true - } - // proceed with default - mimeTypes = MIME_OCTET - } - - parts := strings.Split(mimeTypes, ",") - for _, each := range parts { - var contentType string - if strings.Contains(each, ";") { - contentType = strings.Split(each, ";")[0] - } else { - contentType = each - } - // trim before compare - contentType = strings.Trim(contentType, " ") - for _, consumeableType := range r.Consumes { - if consumeableType == "*/*" || consumeableType == contentType { - return true - } - } - } - return false -} - -// Extract the parameters from the request url path -func (r Route) extractParameters(urlPath string) map[string]string { - urlParts := tokenizePath(urlPath) - pathParameters := map[string]string{} - for i, key := range r.pathParts { - var value string - if i >= len(urlParts) { - value = "" - } else { - value = urlParts[i] - } - if strings.HasPrefix(key, "{") { // path-parameter - if colon := strings.Index(key, ":"); colon != -1 { - // extract by regex - regPart := key[colon+1 : len(key)-1] - keyPart := key[1:colon] - if regPart == "*" { - pathParameters[keyPart] = untokenizePath(i, urlParts) - break - } else { - pathParameters[keyPart] = value - } - } else { - // without enclosing {} - pathParameters[key[1:len(key)-1]] = value - } - } - } - return pathParameters -} - -// Untokenize back into an URL path using the slash separator -func untokenizePath(offset int, parts []string) string { - var buffer bytes.Buffer - for p := offset; p < len(parts); p++ { - buffer.WriteString(parts[p]) - // do not end - if p < len(parts)-1 { - buffer.WriteString("/") - } - } - return buffer.String() -} - -// Tokenize an URL path using the slash separator ; the result does not have empty tokens -func tokenizePath(path string) []string { - if "/" == path { - return []string{} - } - return strings.Split(strings.Trim(path, "/"), "/") -} - -// for debugging -func (r Route) String() string { - return r.Method + " " + r.Path -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route_builder.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route_builder.go deleted file mode 100644 index 8bc1ab6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/route_builder.go +++ /dev/null @@ -1,240 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "os" - "reflect" - "runtime" - "strings" - - "github.com/emicklei/go-restful/log" -) - -// RouteBuilder is a helper to construct Routes. -type RouteBuilder struct { - rootPath string - currentPath string - produces []string - consumes []string - httpMethod string // required - function RouteFunction // required - filters []FilterFunction - // documentation - doc string - notes string - operation string - readSample, writeSample interface{} - parameters []*Parameter - errorMap map[int]ResponseError -} - -// Do evaluates each argument with the RouteBuilder itself. -// This allows you to follow DRY principles without breaking the fluent programming style. -// Example: -// ws.Route(ws.DELETE("/{name}").To(t.deletePerson).Do(Returns200, Returns500)) -// -// func Returns500(b *RouteBuilder) { -// b.Returns(500, "Internal Server Error", restful.ServiceError{}) -// } -func (b *RouteBuilder) Do(oneArgBlocks ...func(*RouteBuilder)) *RouteBuilder { - for _, each := range oneArgBlocks { - each(b) - } - return b -} - -// To bind the route to a function. -// If this route is matched with the incoming Http Request then call this function with the *Request,*Response pair. Required. -func (b *RouteBuilder) To(function RouteFunction) *RouteBuilder { - b.function = function - return b -} - -// Method specifies what HTTP method to match. Required. -func (b *RouteBuilder) Method(method string) *RouteBuilder { - b.httpMethod = method - return b -} - -// Produces specifies what MIME types can be produced ; the matched one will appear in the Content-Type Http header. -func (b *RouteBuilder) Produces(mimeTypes ...string) *RouteBuilder { - b.produces = mimeTypes - return b -} - -// Consumes specifies what MIME types can be consumes ; the Accept Http header must matched any of these -func (b *RouteBuilder) Consumes(mimeTypes ...string) *RouteBuilder { - b.consumes = mimeTypes - return b -} - -// Path specifies the relative (w.r.t WebService root path) URL path to match. Default is "/". -func (b *RouteBuilder) Path(subPath string) *RouteBuilder { - b.currentPath = subPath - return b -} - -// Doc tells what this route is all about. Optional. -func (b *RouteBuilder) Doc(documentation string) *RouteBuilder { - b.doc = documentation - return b -} - -// A verbose explanation of the operation behavior. Optional. -func (b *RouteBuilder) Notes(notes string) *RouteBuilder { - b.notes = notes - return b -} - -// Reads tells what resource type will be read from the request payload. Optional. -// A parameter of type "body" is added ,required is set to true and the dataType is set to the qualified name of the sample's type. -func (b *RouteBuilder) Reads(sample interface{}) *RouteBuilder { - b.readSample = sample - typeAsName := reflect.TypeOf(sample).String() - bodyParameter := &Parameter{&ParameterData{Name: "body"}} - bodyParameter.beBody() - bodyParameter.Required(true) - bodyParameter.DataType(typeAsName) - b.Param(bodyParameter) - return b -} - -// ParameterNamed returns a Parameter already known to the RouteBuilder. Returns nil if not. -// Use this to modify or extend information for the Parameter (through its Data()). -func (b RouteBuilder) ParameterNamed(name string) (p *Parameter) { - for _, each := range b.parameters { - if each.Data().Name == name { - return each - } - } - return p -} - -// Writes tells what resource type will be written as the response payload. Optional. -func (b *RouteBuilder) Writes(sample interface{}) *RouteBuilder { - b.writeSample = sample - return b -} - -// Param allows you to document the parameters of the Route. It adds a new Parameter (does not check for duplicates). -func (b *RouteBuilder) Param(parameter *Parameter) *RouteBuilder { - if b.parameters == nil { - b.parameters = []*Parameter{} - } - b.parameters = append(b.parameters, parameter) - return b -} - -// Operation allows you to document what the actual method/function call is of the Route. -// Unless called, the operation name is derived from the RouteFunction set using To(..). -func (b *RouteBuilder) Operation(name string) *RouteBuilder { - b.operation = name - return b -} - -// ReturnsError is deprecated, use Returns instead. -func (b *RouteBuilder) ReturnsError(code int, message string, model interface{}) *RouteBuilder { - log.Print("ReturnsError is deprecated, use Returns instead.") - return b.Returns(code, message, model) -} - -// Returns allows you to document what responses (errors or regular) can be expected. -// The model parameter is optional ; either pass a struct instance or use nil if not applicable. -func (b *RouteBuilder) Returns(code int, message string, model interface{}) *RouteBuilder { - err := ResponseError{ - Code: code, - Message: message, - Model: model, - } - // lazy init because there is no NewRouteBuilder (yet) - if b.errorMap == nil { - b.errorMap = map[int]ResponseError{} - } - b.errorMap[code] = err - return b -} - -type ResponseError struct { - Code int - Message string - Model interface{} -} - -func (b *RouteBuilder) servicePath(path string) *RouteBuilder { - b.rootPath = path - return b -} - -// Filter appends a FilterFunction to the end of filters for this Route to build. -func (b *RouteBuilder) Filter(filter FilterFunction) *RouteBuilder { - b.filters = append(b.filters, filter) - return b -} - -// If no specific Route path then set to rootPath -// If no specific Produces then set to rootProduces -// If no specific Consumes then set to rootConsumes -func (b *RouteBuilder) copyDefaults(rootProduces, rootConsumes []string) { - if len(b.produces) == 0 { - b.produces = rootProduces - } - if len(b.consumes) == 0 { - b.consumes = rootConsumes - } -} - -// Build creates a new Route using the specification details collected by the RouteBuilder -func (b *RouteBuilder) Build() Route { - pathExpr, err := newPathExpression(b.currentPath) - if err != nil { - log.Printf("[restful] Invalid path:%s because:%v", b.currentPath, err) - os.Exit(1) - } - if b.function == nil { - log.Printf("[restful] No function specified for route:" + b.currentPath) - os.Exit(1) - } - operationName := b.operation - if len(operationName) == 0 && b.function != nil { - // extract from definition - operationName = nameOfFunction(b.function) - } - route := Route{ - Method: b.httpMethod, - Path: concatPath(b.rootPath, b.currentPath), - Produces: b.produces, - Consumes: b.consumes, - Function: b.function, - Filters: b.filters, - relativePath: b.currentPath, - pathExpr: pathExpr, - Doc: b.doc, - Notes: b.notes, - Operation: operationName, - ParameterDocs: b.parameters, - ResponseErrors: b.errorMap, - ReadSample: b.readSample, - WriteSample: b.writeSample} - route.postBuild() - return route -} - -func concatPath(path1, path2 string) string { - return strings.TrimRight(path1, "/") + "/" + strings.TrimLeft(path2, "/") -} - -// nameOfFunction returns the short name of the function f for documentation. -// It uses a runtime feature for debugging ; its value may change for later Go versions. -func nameOfFunction(f interface{}) string { - fun := runtime.FuncForPC(reflect.ValueOf(f).Pointer()) - tokenized := strings.Split(fun.Name(), ".") - last := tokenized[len(tokenized)-1] - last = strings.TrimSuffix(last, ")·fm") // < Go 1.5 - last = strings.TrimSuffix(last, ")-fm") // Go 1.5 - last = strings.TrimSuffix(last, "·fm") // < Go 1.5 - last = strings.TrimSuffix(last, "-fm") // Go 1.5 - return last -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/router.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/router.go deleted file mode 100644 index 9b32fb6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/router.go +++ /dev/null @@ -1,18 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import "net/http" - -// A RouteSelector finds the best matching Route given the input HTTP Request -type RouteSelector interface { - - // SelectRoute finds a Route given the input HTTP Request and a list of WebServices. - // It returns a selected Route and its containing WebService or an error indicating - // a problem. - SelectRoute( - webServices []*WebService, - httpRequest *http.Request) (selectedService *WebService, selected *Route, err error) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/service_error.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/service_error.go deleted file mode 100644 index 62d1108..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/service_error.go +++ /dev/null @@ -1,23 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import "fmt" - -// ServiceError is a transport object to pass information about a non-Http error occurred in a WebService while processing a request. -type ServiceError struct { - Code int - Message string -} - -// NewError returns a ServiceError using the code and reason -func NewError(code int, message string) ServiceError { - return ServiceError{Code: code, Message: message} -} - -// Error returns a text representation of the service error -func (s ServiceError) Error() string { - return fmt.Sprintf("[ServiceError:%v] %v", s.Code, s.Message) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/CHANGES.md b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/CHANGES.md deleted file mode 100644 index 736f6f3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/CHANGES.md +++ /dev/null @@ -1,43 +0,0 @@ -Change history of swagger -= -2015-10-16 -- add type override mechanism for swagger models (MR 254, nathanejohnson) -- replace uses of wildcard in generated apidocs (issue 251) - -2015-05-25 -- (api break) changed the type of Properties in Model -- (api break) changed the type of Models in ApiDeclaration -- (api break) changed the parameter type of PostBuildDeclarationMapFunc - -2015-04-09 -- add ModelBuildable interface for customization of Model - -2015-03-17 -- preserve order of Routes per WebService in Swagger listing -- fix use of $ref and type in Swagger models -- add api version to listing - -2014-11-14 -- operation parameters are now sorted using ordering path,query,form,header,body - -2014-11-12 -- respect omitempty tag value for embedded structs -- expose ApiVersion of WebService to Swagger ApiDeclaration - -2014-05-29 -- (api add) Ability to define custom http.Handler to serve swagger-ui static files - -2014-05-04 -- (fix) include model for array element type of response - -2014-01-03 -- (fix) do not add primitive type to the Api models - -2013-11-27 -- (fix) make Swagger work for WebServices with root ("/" or "") paths - -2013-10-29 -- (api add) package variable LogInfo to customize logging function - -2013-10-15 -- upgraded to spec version 1.2 (https://github.com/wordnik/swagger-core/wiki/1.2-transition) \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/README.md deleted file mode 100644 index 6c27c30..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/README.md +++ /dev/null @@ -1,76 +0,0 @@ -How to use Swagger UI with go-restful -= - -Get the Swagger UI sources (version 1.2 only) - - git clone https://github.com/wordnik/swagger-ui.git - -The project contains a "dist" folder. -Its contents has all the Swagger UI files you need. - -The `index.html` has an `url` set to `http://petstore.swagger.wordnik.com/api/api-docs`. -You need to change that to match your WebService JSON endpoint e.g. `http://localhost:8080/apidocs.json` - -Now, you can install the Swagger WebService for serving the Swagger specification in JSON. - - config := swagger.Config{ - WebServices: restful.RegisteredWebServices(), - ApiPath: "/apidocs.json", - SwaggerPath: "/apidocs/", - SwaggerFilePath: "/Users/emicklei/Projects/swagger-ui/dist"} - swagger.InstallSwaggerService(config) - - -Documenting Structs --- - -Currently there are 2 ways to document your structs in the go-restful Swagger. - -###### By using struct tags -- Use tag "description" to annotate a struct field with a description to show in the UI -- Use tag "modelDescription" to annotate the struct itself with a description to show in the UI. The tag can be added in an field of the struct and in case that there are multiple definition, they will be appended with an empty line. - -###### By using the SwaggerDoc method -Here is an example with an `Address` struct and the documentation for each of the fields. The `""` is a special entry for **documenting the struct itself**. - - type Address struct { - Country string `json:"country,omitempty"` - PostCode int `json:"postcode,omitempty"` - } - - func (Address) SwaggerDoc() map[string]string { - return map[string]string{ - "": "Address doc", - "country": "Country doc", - "postcode": "PostCode doc", - } - } - -This example will generate a JSON like this - - { - "Address": { - "id": "Address", - "description": "Address doc", - "properties": { - "country": { - "type": "string", - "description": "Country doc" - }, - "postcode": { - "type": "integer", - "format": "int32", - "description": "PostCode doc" - } - } - } - } - -**Very Important Notes:** -- `SwaggerDoc()` is using a **NON-Pointer** receiver (e.g. func (Address) and not func (*Address)) -- The returned map should use as key the name of the field as defined in the JSON parameter (e.g. `"postcode"` and not `"PostCode"`) - -Notes --- -- The Nickname of an Operation is automatically set by finding the name of the function. You can override it using RouteBuilder.Operation(..) -- The WebServices field of swagger.Config can be used to control which service you want to expose and document ; you can have multiple configs and therefore multiple endpoints. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/api_declaration_list.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/api_declaration_list.go deleted file mode 100644 index 9f4c369..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/api_declaration_list.go +++ /dev/null @@ -1,64 +0,0 @@ -package swagger - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "encoding/json" -) - -// ApiDeclarationList maintains an ordered list of ApiDeclaration. -type ApiDeclarationList struct { - List []ApiDeclaration -} - -// At returns the ApiDeclaration by its path unless absent, then ok is false -func (l *ApiDeclarationList) At(path string) (a ApiDeclaration, ok bool) { - for _, each := range l.List { - if each.ResourcePath == path { - return each, true - } - } - return a, false -} - -// Put adds or replaces a ApiDeclaration with this name -func (l *ApiDeclarationList) Put(path string, a ApiDeclaration) { - // maybe replace existing - for i, each := range l.List { - if each.ResourcePath == path { - // replace - l.List[i] = a - return - } - } - // add - l.List = append(l.List, a) -} - -// Do enumerates all the properties, each with its assigned name -func (l *ApiDeclarationList) Do(block func(path string, decl ApiDeclaration)) { - for _, each := range l.List { - block(each.ResourcePath, each) - } -} - -// MarshalJSON writes the ModelPropertyList as if it was a map[string]ModelProperty -func (l ApiDeclarationList) MarshalJSON() ([]byte, error) { - var buf bytes.Buffer - encoder := json.NewEncoder(&buf) - buf.WriteString("{\n") - for i, each := range l.List { - buf.WriteString("\"") - buf.WriteString(each.ResourcePath) - buf.WriteString("\": ") - encoder.Encode(each) - if i < len(l.List)-1 { - buf.WriteString(",\n") - } - } - buf.WriteString("}") - return buf.Bytes(), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/config.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/config.go deleted file mode 100644 index 510d6fc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/config.go +++ /dev/null @@ -1,38 +0,0 @@ -package swagger - -import ( - "net/http" - - "github.com/emicklei/go-restful" -) - -// PostBuildDeclarationMapFunc can be used to modify the api declaration map. -type PostBuildDeclarationMapFunc func(apiDeclarationMap *ApiDeclarationList) - -type MapSchemaFormatFunc func(typeName string) string - -type Config struct { - // url where the services are available, e.g. http://localhost:8080 - // if left empty then the basePath of Swagger is taken from the actual request - WebServicesUrl string - // path where the JSON api is avaiable , e.g. /apidocs - ApiPath string - // [optional] path where the swagger UI will be served, e.g. /swagger - SwaggerPath string - // [optional] location of folder containing Swagger HTML5 application index.html - SwaggerFilePath string - // api listing is constructed from this list of restful WebServices. - WebServices []*restful.WebService - // will serve all static content (scripts,pages,images) - StaticHandler http.Handler - // [optional] on default CORS (Cross-Origin-Resource-Sharing) is enabled. - DisableCORS bool - // Top-level API version. Is reflected in the resource listing. - ApiVersion string - // If set then call this handler after building the complete ApiDeclaration Map - PostBuildHandler PostBuildDeclarationMapFunc - // Swagger global info struct - Info Info - // [optional] If set, model builder should call this handler to get addition typename-to-swagger-format-field convertion. - SchemaFormatHandler MapSchemaFormatFunc -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_builder.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_builder.go deleted file mode 100644 index 398e830..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_builder.go +++ /dev/null @@ -1,449 +0,0 @@ -package swagger - -import ( - "encoding/json" - "reflect" - "strings" -) - -// ModelBuildable is used for extending Structs that need more control over -// how the Model appears in the Swagger api declaration. -type ModelBuildable interface { - PostBuildModel(m *Model) *Model -} - -type modelBuilder struct { - Models *ModelList - Config *Config -} - -type documentable interface { - SwaggerDoc() map[string]string -} - -// Check if this structure has a method with signature func () SwaggerDoc() map[string]string -// If it exists, retrive the documentation and overwrite all struct tag descriptions -func getDocFromMethodSwaggerDoc2(model reflect.Type) map[string]string { - if docable, ok := reflect.New(model).Elem().Interface().(documentable); ok { - return docable.SwaggerDoc() - } - return make(map[string]string) -} - -// addModelFrom creates and adds a Model to the builder and detects and calls -// the post build hook for customizations -func (b modelBuilder) addModelFrom(sample interface{}) { - if modelOrNil := b.addModel(reflect.TypeOf(sample), ""); modelOrNil != nil { - // allow customizations - if buildable, ok := sample.(ModelBuildable); ok { - modelOrNil = buildable.PostBuildModel(modelOrNil) - b.Models.Put(modelOrNil.Id, *modelOrNil) - } - } -} - -func (b modelBuilder) addModel(st reflect.Type, nameOverride string) *Model { - modelName := b.keyFrom(st) - if nameOverride != "" { - modelName = nameOverride - } - // no models needed for primitive types - if b.isPrimitiveType(modelName) { - return nil - } - // golang encoding/json packages says array and slice values encode as - // JSON arrays, except that []byte encodes as a base64-encoded string. - // If we see a []byte here, treat it at as a primitive type (string) - // and deal with it in buildArrayTypeProperty. - if (st.Kind() == reflect.Slice || st.Kind() == reflect.Array) && - st.Elem().Kind() == reflect.Uint8 { - return nil - } - // see if we already have visited this model - if _, ok := b.Models.At(modelName); ok { - return nil - } - sm := Model{ - Id: modelName, - Required: []string{}, - Properties: ModelPropertyList{}} - - // reference the model before further initializing (enables recursive structs) - b.Models.Put(modelName, sm) - - // check for slice or array - if st.Kind() == reflect.Slice || st.Kind() == reflect.Array { - b.addModel(st.Elem(), "") - return &sm - } - // check for structure or primitive type - if st.Kind() != reflect.Struct { - return &sm - } - - fullDoc := getDocFromMethodSwaggerDoc2(st) - modelDescriptions := []string{} - - for i := 0; i < st.NumField(); i++ { - field := st.Field(i) - jsonName, modelDescription, prop := b.buildProperty(field, &sm, modelName) - if len(modelDescription) > 0 { - modelDescriptions = append(modelDescriptions, modelDescription) - } - - // add if not omitted - if len(jsonName) != 0 { - // update description - if fieldDoc, ok := fullDoc[jsonName]; ok { - prop.Description = fieldDoc - } - // update Required - if b.isPropertyRequired(field) { - sm.Required = append(sm.Required, jsonName) - } - sm.Properties.Put(jsonName, prop) - } - } - - // We always overwrite documentation if SwaggerDoc method exists - // "" is special for documenting the struct itself - if modelDoc, ok := fullDoc[""]; ok { - sm.Description = modelDoc - } else if len(modelDescriptions) != 0 { - sm.Description = strings.Join(modelDescriptions, "\n") - } - - // update model builder with completed model - b.Models.Put(modelName, sm) - - return &sm -} - -func (b modelBuilder) isPropertyRequired(field reflect.StructField) bool { - required := true - if jsonTag := field.Tag.Get("json"); jsonTag != "" { - s := strings.Split(jsonTag, ",") - if len(s) > 1 && s[1] == "omitempty" { - return false - } - } - return required -} - -func (b modelBuilder) buildProperty(field reflect.StructField, model *Model, modelName string) (jsonName, modelDescription string, prop ModelProperty) { - jsonName = b.jsonNameOfField(field) - if len(jsonName) == 0 { - // empty name signals skip property - return "", "", prop - } - - if tag := field.Tag.Get("modelDescription"); tag != "" { - modelDescription = tag - } - - prop.setPropertyMetadata(field) - if prop.Type != nil { - return jsonName, modelDescription, prop - } - fieldType := field.Type - - // check if type is doing its own marshalling - marshalerType := reflect.TypeOf((*json.Marshaler)(nil)).Elem() - if fieldType.Implements(marshalerType) { - var pType = "string" - if prop.Type == nil { - prop.Type = &pType - } - if prop.Format == "" { - prop.Format = b.jsonSchemaFormat(fieldType.String()) - } - return jsonName, modelDescription, prop - } - - // check if annotation says it is a string - if jsonTag := field.Tag.Get("json"); jsonTag != "" { - s := strings.Split(jsonTag, ",") - if len(s) > 1 && s[1] == "string" { - stringt := "string" - prop.Type = &stringt - return jsonName, modelDescription, prop - } - } - - fieldKind := fieldType.Kind() - switch { - case fieldKind == reflect.Struct: - jsonName, prop := b.buildStructTypeProperty(field, jsonName, model) - return jsonName, modelDescription, prop - case fieldKind == reflect.Slice || fieldKind == reflect.Array: - jsonName, prop := b.buildArrayTypeProperty(field, jsonName, modelName) - return jsonName, modelDescription, prop - case fieldKind == reflect.Ptr: - jsonName, prop := b.buildPointerTypeProperty(field, jsonName, modelName) - return jsonName, modelDescription, prop - case fieldKind == reflect.String: - stringt := "string" - prop.Type = &stringt - return jsonName, modelDescription, prop - case fieldKind == reflect.Map: - // if it's a map, it's unstructured, and swagger 1.2 can't handle it - objectType := "object" - prop.Type = &objectType - return jsonName, modelDescription, prop - } - - if b.isPrimitiveType(fieldType.String()) { - mapped := b.jsonSchemaType(fieldType.String()) - prop.Type = &mapped - prop.Format = b.jsonSchemaFormat(fieldType.String()) - return jsonName, modelDescription, prop - } - modelType := fieldType.String() - prop.Ref = &modelType - - if fieldType.Name() == "" { // override type of anonymous structs - nestedTypeName := modelName + "." + jsonName - prop.Ref = &nestedTypeName - b.addModel(fieldType, nestedTypeName) - } - return jsonName, modelDescription, prop -} - -func hasNamedJSONTag(field reflect.StructField) bool { - parts := strings.Split(field.Tag.Get("json"), ",") - if len(parts) == 0 { - return false - } - for _, s := range parts[1:] { - if s == "inline" { - return false - } - } - return len(parts[0]) > 0 -} - -func (b modelBuilder) buildStructTypeProperty(field reflect.StructField, jsonName string, model *Model) (nameJson string, prop ModelProperty) { - prop.setPropertyMetadata(field) - // Check for type override in tag - if prop.Type != nil { - return jsonName, prop - } - fieldType := field.Type - // check for anonymous - if len(fieldType.Name()) == 0 { - // anonymous - anonType := model.Id + "." + jsonName - b.addModel(fieldType, anonType) - prop.Ref = &anonType - return jsonName, prop - } - - if field.Name == fieldType.Name() && field.Anonymous && !hasNamedJSONTag(field) { - // embedded struct - sub := modelBuilder{new(ModelList), b.Config} - sub.addModel(fieldType, "") - subKey := sub.keyFrom(fieldType) - // merge properties from sub - subModel, _ := sub.Models.At(subKey) - subModel.Properties.Do(func(k string, v ModelProperty) { - model.Properties.Put(k, v) - // if subModel says this property is required then include it - required := false - for _, each := range subModel.Required { - if k == each { - required = true - break - } - } - if required { - model.Required = append(model.Required, k) - } - }) - // add all new referenced models - sub.Models.Do(func(key string, sub Model) { - if key != subKey { - if _, ok := b.Models.At(key); !ok { - b.Models.Put(key, sub) - } - } - }) - // empty name signals skip property - return "", prop - } - // simple struct - b.addModel(fieldType, "") - var pType = fieldType.String() - prop.Ref = &pType - return jsonName, prop -} - -func (b modelBuilder) buildArrayTypeProperty(field reflect.StructField, jsonName, modelName string) (nameJson string, prop ModelProperty) { - // check for type override in tags - prop.setPropertyMetadata(field) - if prop.Type != nil { - return jsonName, prop - } - fieldType := field.Type - if fieldType.Elem().Kind() == reflect.Uint8 { - stringt := "string" - prop.Type = &stringt - return jsonName, prop - } - var pType = "array" - prop.Type = &pType - isPrimitive := b.isPrimitiveType(fieldType.Elem().Name()) - elemTypeName := b.getElementTypeName(modelName, jsonName, fieldType.Elem()) - prop.Items = new(Item) - if isPrimitive { - mapped := b.jsonSchemaType(elemTypeName) - prop.Items.Type = &mapped - } else { - prop.Items.Ref = &elemTypeName - } - // add|overwrite model for element type - if fieldType.Elem().Kind() == reflect.Ptr { - fieldType = fieldType.Elem() - } - if !isPrimitive { - b.addModel(fieldType.Elem(), elemTypeName) - } - return jsonName, prop -} - -func (b modelBuilder) buildPointerTypeProperty(field reflect.StructField, jsonName, modelName string) (nameJson string, prop ModelProperty) { - prop.setPropertyMetadata(field) - // Check for type override in tags - if prop.Type != nil { - return jsonName, prop - } - fieldType := field.Type - - // override type of pointer to list-likes - if fieldType.Elem().Kind() == reflect.Slice || fieldType.Elem().Kind() == reflect.Array { - var pType = "array" - prop.Type = &pType - isPrimitive := b.isPrimitiveType(fieldType.Elem().Elem().Name()) - elemName := b.getElementTypeName(modelName, jsonName, fieldType.Elem().Elem()) - if isPrimitive { - primName := b.jsonSchemaType(elemName) - prop.Items = &Item{Ref: &primName} - } else { - prop.Items = &Item{Ref: &elemName} - } - if !isPrimitive { - // add|overwrite model for element type - b.addModel(fieldType.Elem().Elem(), elemName) - } - } else { - // non-array, pointer type - var pType = b.jsonSchemaType(fieldType.String()[1:]) // no star, include pkg path - if b.isPrimitiveType(fieldType.String()[1:]) { - prop.Type = &pType - prop.Format = b.jsonSchemaFormat(fieldType.String()[1:]) - return jsonName, prop - } - prop.Ref = &pType - elemName := "" - if fieldType.Elem().Name() == "" { - elemName = modelName + "." + jsonName - prop.Ref = &elemName - } - b.addModel(fieldType.Elem(), elemName) - } - return jsonName, prop -} - -func (b modelBuilder) getElementTypeName(modelName, jsonName string, t reflect.Type) string { - if t.Kind() == reflect.Ptr { - return t.String()[1:] - } - if t.Name() == "" { - return modelName + "." + jsonName - } - return b.keyFrom(t) -} - -func (b modelBuilder) keyFrom(st reflect.Type) string { - key := st.String() - if len(st.Name()) == 0 { // unnamed type - // Swagger UI has special meaning for [ - key = strings.Replace(key, "[]", "||", -1) - } - return key -} - -// see also https://golang.org/ref/spec#Numeric_types -func (b modelBuilder) isPrimitiveType(modelName string) bool { - if len(modelName) == 0 { - return false - } - return strings.Contains("uint uint8 uint16 uint32 uint64 int int8 int16 int32 int64 float32 float64 bool string byte rune time.Time", modelName) -} - -// jsonNameOfField returns the name of the field as it should appear in JSON format -// An empty string indicates that this field is not part of the JSON representation -func (b modelBuilder) jsonNameOfField(field reflect.StructField) string { - if jsonTag := field.Tag.Get("json"); jsonTag != "" { - s := strings.Split(jsonTag, ",") - if s[0] == "-" { - // empty name signals skip property - return "" - } else if s[0] != "" { - return s[0] - } - } - return field.Name -} - -// see also http://json-schema.org/latest/json-schema-core.html#anchor8 -func (b modelBuilder) jsonSchemaType(modelName string) string { - schemaMap := map[string]string{ - "uint": "integer", - "uint8": "integer", - "uint16": "integer", - "uint32": "integer", - "uint64": "integer", - - "int": "integer", - "int8": "integer", - "int16": "integer", - "int32": "integer", - "int64": "integer", - - "byte": "integer", - "float64": "number", - "float32": "number", - "bool": "boolean", - "time.Time": "string", - } - mapped, ok := schemaMap[modelName] - if !ok { - return modelName // use as is (custom or struct) - } - return mapped -} - -func (b modelBuilder) jsonSchemaFormat(modelName string) string { - if b.Config != nil && b.Config.SchemaFormatHandler != nil { - if mapped := b.Config.SchemaFormatHandler(modelName); mapped != "" { - return mapped - } - } - schemaMap := map[string]string{ - "int": "int32", - "int32": "int32", - "int64": "int64", - "byte": "byte", - "uint": "integer", - "uint8": "byte", - "float64": "double", - "float32": "float", - "time.Time": "date-time", - "*time.Time": "date-time", - } - mapped, ok := schemaMap[modelName] - if !ok { - return "" // no format - } - return mapped -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_list.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_list.go deleted file mode 100644 index 9bb6cb6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_list.go +++ /dev/null @@ -1,86 +0,0 @@ -package swagger - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "encoding/json" -) - -// NamedModel associates a name with a Model (not using its Id) -type NamedModel struct { - Name string - Model Model -} - -// ModelList encapsulates a list of NamedModel (association) -type ModelList struct { - List []NamedModel -} - -// Put adds or replaces a Model by its name -func (l *ModelList) Put(name string, model Model) { - for i, each := range l.List { - if each.Name == name { - // replace - l.List[i] = NamedModel{name, model} - return - } - } - // add - l.List = append(l.List, NamedModel{name, model}) -} - -// At returns a Model by its name, ok is false if absent -func (l *ModelList) At(name string) (m Model, ok bool) { - for _, each := range l.List { - if each.Name == name { - return each.Model, true - } - } - return m, false -} - -// Do enumerates all the models, each with its assigned name -func (l *ModelList) Do(block func(name string, value Model)) { - for _, each := range l.List { - block(each.Name, each.Model) - } -} - -// MarshalJSON writes the ModelList as if it was a map[string]Model -func (l ModelList) MarshalJSON() ([]byte, error) { - var buf bytes.Buffer - encoder := json.NewEncoder(&buf) - buf.WriteString("{\n") - for i, each := range l.List { - buf.WriteString("\"") - buf.WriteString(each.Name) - buf.WriteString("\": ") - encoder.Encode(each.Model) - if i < len(l.List)-1 { - buf.WriteString(",\n") - } - } - buf.WriteString("}") - return buf.Bytes(), nil -} - -// UnmarshalJSON reads back a ModelList. This is an expensive operation. -func (l *ModelList) UnmarshalJSON(data []byte) error { - raw := map[string]interface{}{} - json.NewDecoder(bytes.NewReader(data)).Decode(&raw) - for k, v := range raw { - // produces JSON bytes for each value - data, err := json.Marshal(v) - if err != nil { - return err - } - var m Model - json.NewDecoder(bytes.NewReader(data)).Decode(&m) - l.Put(k, m) - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go deleted file mode 100644 index 04fff2c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_ext.go +++ /dev/null @@ -1,66 +0,0 @@ -package swagger - -import ( - "reflect" - "strings" -) - -func (prop *ModelProperty) setDescription(field reflect.StructField) { - if tag := field.Tag.Get("description"); tag != "" { - prop.Description = tag - } -} - -func (prop *ModelProperty) setDefaultValue(field reflect.StructField) { - if tag := field.Tag.Get("default"); tag != "" { - prop.DefaultValue = Special(tag) - } -} - -func (prop *ModelProperty) setEnumValues(field reflect.StructField) { - // We use | to separate the enum values. This value is chosen - // since its unlikely to be useful in actual enumeration values. - if tag := field.Tag.Get("enum"); tag != "" { - prop.Enum = strings.Split(tag, "|") - } -} - -func (prop *ModelProperty) setMaximum(field reflect.StructField) { - if tag := field.Tag.Get("maximum"); tag != "" { - prop.Maximum = tag - } -} - -func (prop *ModelProperty) setType(field reflect.StructField) { - if tag := field.Tag.Get("type"); tag != "" { - prop.Type = &tag - } -} - -func (prop *ModelProperty) setMinimum(field reflect.StructField) { - if tag := field.Tag.Get("minimum"); tag != "" { - prop.Minimum = tag - } -} - -func (prop *ModelProperty) setUniqueItems(field reflect.StructField) { - tag := field.Tag.Get("unique") - switch tag { - case "true": - v := true - prop.UniqueItems = &v - case "false": - v := false - prop.UniqueItems = &v - } -} - -func (prop *ModelProperty) setPropertyMetadata(field reflect.StructField) { - prop.setDescription(field) - prop.setEnumValues(field) - prop.setMinimum(field) - prop.setMaximum(field) - prop.setUniqueItems(field) - prop.setDefaultValue(field) - prop.setType(field) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_list.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_list.go deleted file mode 100644 index 3babb19..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/model_property_list.go +++ /dev/null @@ -1,87 +0,0 @@ -package swagger - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "bytes" - "encoding/json" -) - -// NamedModelProperty associates a name to a ModelProperty -type NamedModelProperty struct { - Name string - Property ModelProperty -} - -// ModelPropertyList encapsulates a list of NamedModelProperty (association) -type ModelPropertyList struct { - List []NamedModelProperty -} - -// At returns the ModelPropety by its name unless absent, then ok is false -func (l *ModelPropertyList) At(name string) (p ModelProperty, ok bool) { - for _, each := range l.List { - if each.Name == name { - return each.Property, true - } - } - return p, false -} - -// Put adds or replaces a ModelProperty with this name -func (l *ModelPropertyList) Put(name string, prop ModelProperty) { - // maybe replace existing - for i, each := range l.List { - if each.Name == name { - // replace - l.List[i] = NamedModelProperty{Name: name, Property: prop} - return - } - } - // add - l.List = append(l.List, NamedModelProperty{Name: name, Property: prop}) -} - -// Do enumerates all the properties, each with its assigned name -func (l *ModelPropertyList) Do(block func(name string, value ModelProperty)) { - for _, each := range l.List { - block(each.Name, each.Property) - } -} - -// MarshalJSON writes the ModelPropertyList as if it was a map[string]ModelProperty -func (l ModelPropertyList) MarshalJSON() ([]byte, error) { - var buf bytes.Buffer - encoder := json.NewEncoder(&buf) - buf.WriteString("{\n") - for i, each := range l.List { - buf.WriteString("\"") - buf.WriteString(each.Name) - buf.WriteString("\": ") - encoder.Encode(each.Property) - if i < len(l.List)-1 { - buf.WriteString(",\n") - } - } - buf.WriteString("}") - return buf.Bytes(), nil -} - -// UnmarshalJSON reads back a ModelPropertyList. This is an expensive operation. -func (l *ModelPropertyList) UnmarshalJSON(data []byte) error { - raw := map[string]interface{}{} - json.NewDecoder(bytes.NewReader(data)).Decode(&raw) - for k, v := range raw { - // produces JSON bytes for each value - data, err := json.Marshal(v) - if err != nil { - return err - } - var m ModelProperty - json.NewDecoder(bytes.NewReader(data)).Decode(&m) - l.Put(k, m) - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/ordered_route_map.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/ordered_route_map.go deleted file mode 100644 index b33ccfb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/ordered_route_map.go +++ /dev/null @@ -1,36 +0,0 @@ -package swagger - -// Copyright 2015 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import "github.com/emicklei/go-restful" - -type orderedRouteMap struct { - elements map[string][]restful.Route - keys []string -} - -func newOrderedRouteMap() *orderedRouteMap { - return &orderedRouteMap{ - elements: map[string][]restful.Route{}, - keys: []string{}, - } -} - -func (o *orderedRouteMap) Add(key string, route restful.Route) { - routes, ok := o.elements[key] - if ok { - routes = append(routes, route) - o.elements[key] = routes - return - } - o.elements[key] = []restful.Route{route} - o.keys = append(o.keys, key) -} - -func (o *orderedRouteMap) Do(block func(key string, routes []restful.Route)) { - for _, k := range o.keys { - block(k, o.elements[k]) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger.go deleted file mode 100644 index 9c40833..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger.go +++ /dev/null @@ -1,185 +0,0 @@ -// Package swagger implements the structures of the Swagger -// https://github.com/wordnik/swagger-spec/blob/master/versions/1.2.md -package swagger - -const swaggerVersion = "1.2" - -// 4.3.3 Data Type Fields -type DataTypeFields struct { - Type *string `json:"type,omitempty"` // if Ref not used - Ref *string `json:"$ref,omitempty"` // if Type not used - Format string `json:"format,omitempty"` - DefaultValue Special `json:"defaultValue,omitempty"` - Enum []string `json:"enum,omitempty"` - Minimum string `json:"minimum,omitempty"` - Maximum string `json:"maximum,omitempty"` - Items *Item `json:"items,omitempty"` - UniqueItems *bool `json:"uniqueItems,omitempty"` -} - -type Special string - -// 4.3.4 Items Object -type Item struct { - Type *string `json:"type,omitempty"` - Ref *string `json:"$ref,omitempty"` - Format string `json:"format,omitempty"` -} - -// 5.1 Resource Listing -type ResourceListing struct { - SwaggerVersion string `json:"swaggerVersion"` // e.g 1.2 - Apis []Resource `json:"apis"` - ApiVersion string `json:"apiVersion"` - Info Info `json:"info"` - Authorizations []Authorization `json:"authorizations,omitempty"` -} - -// 5.1.2 Resource Object -type Resource struct { - Path string `json:"path"` // relative or absolute, must start with / - Description string `json:"description"` -} - -// 5.1.3 Info Object -type Info struct { - Title string `json:"title"` - Description string `json:"description"` - TermsOfServiceUrl string `json:"termsOfServiceUrl,omitempty"` - Contact string `json:"contact,omitempty"` - License string `json:"license,omitempty"` - LicenseUrl string `json:"licenseUrl,omitempty"` -} - -// 5.1.5 -type Authorization struct { - Type string `json:"type"` - PassAs string `json:"passAs"` - Keyname string `json:"keyname"` - Scopes []Scope `json:"scopes"` - GrantTypes []GrantType `json:"grandTypes"` -} - -// 5.1.6, 5.2.11 -type Scope struct { - // Required. The name of the scope. - Scope string `json:"scope"` - // Recommended. A short description of the scope. - Description string `json:"description"` -} - -// 5.1.7 -type GrantType struct { - Implicit Implicit `json:"implicit"` - AuthorizationCode AuthorizationCode `json:"authorization_code"` -} - -// 5.1.8 Implicit Object -type Implicit struct { - // Required. The login endpoint definition. - loginEndpoint LoginEndpoint `json:"loginEndpoint"` - // An optional alternative name to standard "access_token" OAuth2 parameter. - TokenName string `json:"tokenName"` -} - -// 5.1.9 Authorization Code Object -type AuthorizationCode struct { - TokenRequestEndpoint TokenRequestEndpoint `json:"tokenRequestEndpoint"` - TokenEndpoint TokenEndpoint `json:"tokenEndpoint"` -} - -// 5.1.10 Login Endpoint Object -type LoginEndpoint struct { - // Required. The URL of the authorization endpoint for the implicit grant flow. The value SHOULD be in a URL format. - Url string `json:"url"` -} - -// 5.1.11 Token Request Endpoint Object -type TokenRequestEndpoint struct { - // Required. The URL of the authorization endpoint for the authentication code grant flow. The value SHOULD be in a URL format. - Url string `json:"url"` - // An optional alternative name to standard "client_id" OAuth2 parameter. - ClientIdName string `json:"clientIdName"` - // An optional alternative name to the standard "client_secret" OAuth2 parameter. - ClientSecretName string `json:"clientSecretName"` -} - -// 5.1.12 Token Endpoint Object -type TokenEndpoint struct { - // Required. The URL of the token endpoint for the authentication code grant flow. The value SHOULD be in a URL format. - Url string `json:"url"` - // An optional alternative name to standard "access_token" OAuth2 parameter. - TokenName string `json:"tokenName"` -} - -// 5.2 API Declaration -type ApiDeclaration struct { - SwaggerVersion string `json:"swaggerVersion"` - ApiVersion string `json:"apiVersion"` - BasePath string `json:"basePath"` - ResourcePath string `json:"resourcePath"` // must start with / - Info Info `json:"info"` - Apis []Api `json:"apis,omitempty"` - Models ModelList `json:"models,omitempty"` - Produces []string `json:"produces,omitempty"` - Consumes []string `json:"consumes,omitempty"` - Authorizations []Authorization `json:"authorizations,omitempty"` -} - -// 5.2.2 API Object -type Api struct { - Path string `json:"path"` // relative or absolute, must start with / - Description string `json:"description"` - Operations []Operation `json:"operations,omitempty"` -} - -// 5.2.3 Operation Object -type Operation struct { - DataTypeFields - Method string `json:"method"` - Summary string `json:"summary,omitempty"` - Notes string `json:"notes,omitempty"` - Nickname string `json:"nickname"` - Authorizations []Authorization `json:"authorizations,omitempty"` - Parameters []Parameter `json:"parameters"` - ResponseMessages []ResponseMessage `json:"responseMessages,omitempty"` // optional - Produces []string `json:"produces,omitempty"` - Consumes []string `json:"consumes,omitempty"` - Deprecated string `json:"deprecated,omitempty"` -} - -// 5.2.4 Parameter Object -type Parameter struct { - DataTypeFields - ParamType string `json:"paramType"` // path,query,body,header,form - Name string `json:"name"` - Description string `json:"description"` - Required bool `json:"required"` - AllowMultiple bool `json:"allowMultiple"` -} - -// 5.2.5 Response Message Object -type ResponseMessage struct { - Code int `json:"code"` - Message string `json:"message"` - ResponseModel string `json:"responseModel,omitempty"` -} - -// 5.2.6, 5.2.7 Models Object -type Model struct { - Id string `json:"id"` - Description string `json:"description,omitempty"` - Required []string `json:"required,omitempty"` - Properties ModelPropertyList `json:"properties"` - SubTypes []string `json:"subTypes,omitempty"` - Discriminator string `json:"discriminator,omitempty"` -} - -// 5.2.8 Properties Object -type ModelProperty struct { - DataTypeFields - Description string `json:"description,omitempty"` -} - -// 5.2.10 -type Authorizations map[string]Authorization diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_builder.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_builder.go deleted file mode 100644 index 05a3c7e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_builder.go +++ /dev/null @@ -1,21 +0,0 @@ -package swagger - -type SwaggerBuilder struct { - SwaggerService -} - -func NewSwaggerBuilder(config Config) *SwaggerBuilder { - return &SwaggerBuilder{*newSwaggerService(config)} -} - -func (sb SwaggerBuilder) ProduceListing() ResourceListing { - return sb.SwaggerService.produceListing() -} - -func (sb SwaggerBuilder) ProduceAllDeclarations() map[string]ApiDeclaration { - return sb.SwaggerService.produceAllDeclarations() -} - -func (sb SwaggerBuilder) ProduceDeclarations(route string) (*ApiDeclaration, bool) { - return sb.SwaggerService.produceDeclarations(route) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go deleted file mode 100644 index 58dd625..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/swagger/swagger_webservice.go +++ /dev/null @@ -1,440 +0,0 @@ -package swagger - -import ( - "fmt" - - "github.com/emicklei/go-restful" - // "github.com/emicklei/hopwatch" - "net/http" - "reflect" - "sort" - "strings" - - "github.com/emicklei/go-restful/log" -) - -type SwaggerService struct { - config Config - apiDeclarationMap *ApiDeclarationList -} - -func newSwaggerService(config Config) *SwaggerService { - sws := &SwaggerService{ - config: config, - apiDeclarationMap: new(ApiDeclarationList)} - - // Build all ApiDeclarations - for _, each := range config.WebServices { - rootPath := each.RootPath() - // skip the api service itself - if rootPath != config.ApiPath { - if rootPath == "" || rootPath == "/" { - // use routes - for _, route := range each.Routes() { - entry := staticPathFromRoute(route) - _, exists := sws.apiDeclarationMap.At(entry) - if !exists { - sws.apiDeclarationMap.Put(entry, sws.composeDeclaration(each, entry)) - } - } - } else { // use root path - sws.apiDeclarationMap.Put(each.RootPath(), sws.composeDeclaration(each, each.RootPath())) - } - } - } - - // if specified then call the PostBuilderHandler - if config.PostBuildHandler != nil { - config.PostBuildHandler(sws.apiDeclarationMap) - } - return sws -} - -// LogInfo is the function that is called when this package needs to log. It defaults to log.Printf -var LogInfo = func(format string, v ...interface{}) { - // use the restful package-wide logger - log.Printf(format, v...) -} - -// InstallSwaggerService add the WebService that provides the API documentation of all services -// conform the Swagger documentation specifcation. (https://github.com/wordnik/swagger-core/wiki). -func InstallSwaggerService(aSwaggerConfig Config) { - RegisterSwaggerService(aSwaggerConfig, restful.DefaultContainer) -} - -// RegisterSwaggerService add the WebService that provides the API documentation of all services -// conform the Swagger documentation specifcation. (https://github.com/wordnik/swagger-core/wiki). -func RegisterSwaggerService(config Config, wsContainer *restful.Container) { - sws := newSwaggerService(config) - ws := new(restful.WebService) - ws.Path(config.ApiPath) - ws.Produces(restful.MIME_JSON) - if config.DisableCORS { - ws.Filter(enableCORS) - } - ws.Route(ws.GET("/").To(sws.getListing)) - ws.Route(ws.GET("/{a}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}/{c}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}/{c}/{d}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}/{c}/{d}/{e}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}/{c}/{d}/{e}/{f}").To(sws.getDeclarations)) - ws.Route(ws.GET("/{a}/{b}/{c}/{d}/{e}/{f}/{g}").To(sws.getDeclarations)) - LogInfo("[restful/swagger] listing is available at %v%v", config.WebServicesUrl, config.ApiPath) - wsContainer.Add(ws) - - // Check paths for UI serving - if config.StaticHandler == nil && config.SwaggerFilePath != "" && config.SwaggerPath != "" { - swaggerPathSlash := config.SwaggerPath - // path must end with slash / - if "/" != config.SwaggerPath[len(config.SwaggerPath)-1:] { - LogInfo("[restful/swagger] use corrected SwaggerPath ; must end with slash (/)") - swaggerPathSlash += "/" - } - - LogInfo("[restful/swagger] %v%v is mapped to folder %v", config.WebServicesUrl, swaggerPathSlash, config.SwaggerFilePath) - wsContainer.Handle(swaggerPathSlash, http.StripPrefix(swaggerPathSlash, http.FileServer(http.Dir(config.SwaggerFilePath)))) - - //if we define a custom static handler use it - } else if config.StaticHandler != nil && config.SwaggerPath != "" { - swaggerPathSlash := config.SwaggerPath - // path must end with slash / - if "/" != config.SwaggerPath[len(config.SwaggerPath)-1:] { - LogInfo("[restful/swagger] use corrected SwaggerFilePath ; must end with slash (/)") - swaggerPathSlash += "/" - - } - LogInfo("[restful/swagger] %v%v is mapped to custom Handler %T", config.WebServicesUrl, swaggerPathSlash, config.StaticHandler) - wsContainer.Handle(swaggerPathSlash, config.StaticHandler) - - } else { - LogInfo("[restful/swagger] Swagger(File)Path is empty ; no UI is served") - } -} - -func staticPathFromRoute(r restful.Route) string { - static := r.Path - bracket := strings.Index(static, "{") - if bracket <= 1 { // result cannot be empty - return static - } - if bracket != -1 { - static = r.Path[:bracket] - } - if strings.HasSuffix(static, "/") { - return static[:len(static)-1] - } else { - return static - } -} - -func enableCORS(req *restful.Request, resp *restful.Response, chain *restful.FilterChain) { - if origin := req.HeaderParameter(restful.HEADER_Origin); origin != "" { - // prevent duplicate header - if len(resp.Header().Get(restful.HEADER_AccessControlAllowOrigin)) == 0 { - resp.AddHeader(restful.HEADER_AccessControlAllowOrigin, origin) - } - } - chain.ProcessFilter(req, resp) -} - -func (sws SwaggerService) getListing(req *restful.Request, resp *restful.Response) { - listing := sws.produceListing() - resp.WriteAsJson(listing) -} - -func (sws SwaggerService) produceListing() ResourceListing { - listing := ResourceListing{SwaggerVersion: swaggerVersion, ApiVersion: sws.config.ApiVersion, Info: sws.config.Info} - sws.apiDeclarationMap.Do(func(k string, v ApiDeclaration) { - ref := Resource{Path: k} - if len(v.Apis) > 0 { // use description of first (could still be empty) - ref.Description = v.Apis[0].Description - } - listing.Apis = append(listing.Apis, ref) - }) - return listing -} - -func (sws SwaggerService) getDeclarations(req *restful.Request, resp *restful.Response) { - decl, ok := sws.produceDeclarations(composeRootPath(req)) - if !ok { - resp.WriteErrorString(http.StatusNotFound, "ApiDeclaration not found") - return - } - // unless WebServicesUrl is given - if len(sws.config.WebServicesUrl) == 0 { - // update base path from the actual request - // TODO how to detect https? assume http for now - var host string - // X-Forwarded-Host or Host or Request.Host - hostvalues, ok := req.Request.Header["X-Forwarded-Host"] // apache specific? - if !ok || len(hostvalues) == 0 { - forwarded, ok := req.Request.Header["Host"] // without reverse-proxy - if !ok || len(forwarded) == 0 { - // fallback to Host field - host = req.Request.Host - } else { - host = forwarded[0] - } - } else { - host = hostvalues[0] - } - // inspect Referer for the scheme (http vs https) - scheme := "http" - if referer := req.Request.Header["Referer"]; len(referer) > 0 { - if strings.HasPrefix(referer[0], "https") { - scheme = "https" - } - } - decl.BasePath = fmt.Sprintf("%s://%s", scheme, host) - } - resp.WriteAsJson(decl) -} - -func (sws SwaggerService) produceAllDeclarations() map[string]ApiDeclaration { - decls := map[string]ApiDeclaration{} - sws.apiDeclarationMap.Do(func(k string, v ApiDeclaration) { - decls[k] = v - }) - return decls -} - -func (sws SwaggerService) produceDeclarations(route string) (*ApiDeclaration, bool) { - decl, ok := sws.apiDeclarationMap.At(route) - if !ok { - return nil, false - } - decl.BasePath = sws.config.WebServicesUrl - return &decl, true -} - -// composeDeclaration uses all routes and parameters to create a ApiDeclaration -func (sws SwaggerService) composeDeclaration(ws *restful.WebService, pathPrefix string) ApiDeclaration { - decl := ApiDeclaration{ - SwaggerVersion: swaggerVersion, - BasePath: sws.config.WebServicesUrl, - ResourcePath: pathPrefix, - Models: ModelList{}, - ApiVersion: ws.Version()} - - // collect any path parameters - rootParams := []Parameter{} - for _, param := range ws.PathParameters() { - rootParams = append(rootParams, asSwaggerParameter(param.Data())) - } - // aggregate by path - pathToRoutes := newOrderedRouteMap() - for _, other := range ws.Routes() { - if strings.HasPrefix(other.Path, pathPrefix) { - pathToRoutes.Add(other.Path, other) - } - } - pathToRoutes.Do(func(path string, routes []restful.Route) { - api := Api{Path: strings.TrimSuffix(withoutWildcard(path), "/"), Description: ws.Documentation()} - voidString := "void" - for _, route := range routes { - operation := Operation{ - Method: route.Method, - Summary: route.Doc, - Notes: route.Notes, - // Type gets overwritten if there is a write sample - DataTypeFields: DataTypeFields{Type: &voidString}, - Parameters: []Parameter{}, - Nickname: route.Operation, - ResponseMessages: composeResponseMessages(route, &decl, &sws.config)} - - operation.Consumes = route.Consumes - operation.Produces = route.Produces - - // share root params if any - for _, swparam := range rootParams { - operation.Parameters = append(operation.Parameters, swparam) - } - // route specific params - for _, param := range route.ParameterDocs { - operation.Parameters = append(operation.Parameters, asSwaggerParameter(param.Data())) - } - - sws.addModelsFromRouteTo(&operation, route, &decl) - api.Operations = append(api.Operations, operation) - } - decl.Apis = append(decl.Apis, api) - }) - return decl -} - -func withoutWildcard(path string) string { - if strings.HasSuffix(path, ":*}") { - return path[0:len(path)-3] + "}" - } - return path -} - -// composeResponseMessages takes the ResponseErrors (if any) and creates ResponseMessages from them. -func composeResponseMessages(route restful.Route, decl *ApiDeclaration, config *Config) (messages []ResponseMessage) { - if route.ResponseErrors == nil { - return messages - } - // sort by code - codes := sort.IntSlice{} - for code, _ := range route.ResponseErrors { - codes = append(codes, code) - } - codes.Sort() - for _, code := range codes { - each := route.ResponseErrors[code] - message := ResponseMessage{ - Code: code, - Message: each.Message, - } - if each.Model != nil { - st := reflect.TypeOf(each.Model) - isCollection, st := detectCollectionType(st) - modelName := modelBuilder{}.keyFrom(st) - if isCollection { - modelName = "array[" + modelName + "]" - } - modelBuilder{Models: &decl.Models, Config: config}.addModel(st, "") - // reference the model - message.ResponseModel = modelName - } - messages = append(messages, message) - } - return -} - -// addModelsFromRoute takes any read or write sample from the Route and creates a Swagger model from it. -func (sws SwaggerService) addModelsFromRouteTo(operation *Operation, route restful.Route, decl *ApiDeclaration) { - if route.ReadSample != nil { - sws.addModelFromSampleTo(operation, false, route.ReadSample, &decl.Models) - } - if route.WriteSample != nil { - sws.addModelFromSampleTo(operation, true, route.WriteSample, &decl.Models) - } -} - -func detectCollectionType(st reflect.Type) (bool, reflect.Type) { - isCollection := false - if st.Kind() == reflect.Slice || st.Kind() == reflect.Array { - st = st.Elem() - isCollection = true - } else { - if st.Kind() == reflect.Ptr { - if st.Elem().Kind() == reflect.Slice || st.Elem().Kind() == reflect.Array { - st = st.Elem().Elem() - isCollection = true - } - } - } - return isCollection, st -} - -// addModelFromSample creates and adds (or overwrites) a Model from a sample resource -func (sws SwaggerService) addModelFromSampleTo(operation *Operation, isResponse bool, sample interface{}, models *ModelList) { - if isResponse { - type_, items := asDataType(sample, &sws.config) - operation.Type = type_ - operation.Items = items - } - modelBuilder{Models: models, Config: &sws.config}.addModelFrom(sample) -} - -func asSwaggerParameter(param restful.ParameterData) Parameter { - return Parameter{ - DataTypeFields: DataTypeFields{ - Type: ¶m.DataType, - Format: asFormat(param.DataType, param.DataFormat), - DefaultValue: Special(param.DefaultValue), - }, - Name: param.Name, - Description: param.Description, - ParamType: asParamType(param.Kind), - - Required: param.Required} -} - -// Between 1..7 path parameters is supported -func composeRootPath(req *restful.Request) string { - path := "/" + req.PathParameter("a") - b := req.PathParameter("b") - if b == "" { - return path - } - path = path + "/" + b - c := req.PathParameter("c") - if c == "" { - return path - } - path = path + "/" + c - d := req.PathParameter("d") - if d == "" { - return path - } - path = path + "/" + d - e := req.PathParameter("e") - if e == "" { - return path - } - path = path + "/" + e - f := req.PathParameter("f") - if f == "" { - return path - } - path = path + "/" + f - g := req.PathParameter("g") - if g == "" { - return path - } - return path + "/" + g -} - -func asFormat(dataType string, dataFormat string) string { - if dataFormat != "" { - return dataFormat - } - return "" // TODO -} - -func asParamType(kind int) string { - switch { - case kind == restful.PathParameterKind: - return "path" - case kind == restful.QueryParameterKind: - return "query" - case kind == restful.BodyParameterKind: - return "body" - case kind == restful.HeaderParameterKind: - return "header" - case kind == restful.FormParameterKind: - return "form" - } - return "" -} - -func asDataType(any interface{}, config *Config) (*string, *Item) { - // If it's not a collection, return the suggested model name - st := reflect.TypeOf(any) - isCollection, st := detectCollectionType(st) - modelName := modelBuilder{}.keyFrom(st) - // if it's not a collection we are done - if !isCollection { - return &modelName, nil - } - - // XXX: This is not very elegant - // We create an Item object referring to the given model - models := ModelList{} - mb := modelBuilder{Models: &models, Config: config} - mb.addModelFrom(any) - - elemTypeName := mb.getElementTypeName(modelName, "", st) - item := new(Item) - if mb.isPrimitiveType(elemTypeName) { - mapped := mb.jsonSchemaType(elemTypeName) - item.Type = &mapped - } else { - item.Ref = &elemTypeName - } - tmp := "array" - return &tmp, item -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service.go deleted file mode 100644 index 2a51004..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service.go +++ /dev/null @@ -1,268 +0,0 @@ -package restful - -import ( - "errors" - "os" - "sync" - - "github.com/emicklei/go-restful/log" -) - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -// WebService holds a collection of Route values that bind a Http Method + URL Path to a function. -type WebService struct { - rootPath string - pathExpr *pathExpression // cached compilation of rootPath as RegExp - routes []Route - produces []string - consumes []string - pathParameters []*Parameter - filters []FilterFunction - documentation string - apiVersion string - - dynamicRoutes bool - - // protects 'routes' if dynamic routes are enabled - routesLock sync.RWMutex -} - -func (w *WebService) SetDynamicRoutes(enable bool) { - w.dynamicRoutes = enable -} - -// compilePathExpression ensures that the path is compiled into a RegEx for those routers that need it. -func (w *WebService) compilePathExpression() { - compiled, err := newPathExpression(w.rootPath) - if err != nil { - log.Printf("[restful] invalid path:%s because:%v", w.rootPath, err) - os.Exit(1) - } - w.pathExpr = compiled -} - -// ApiVersion sets the API version for documentation purposes. -func (w *WebService) ApiVersion(apiVersion string) *WebService { - w.apiVersion = apiVersion - return w -} - -// Version returns the API version for documentation purposes. -func (w *WebService) Version() string { return w.apiVersion } - -// Path specifies the root URL template path of the WebService. -// All Routes will be relative to this path. -func (w *WebService) Path(root string) *WebService { - w.rootPath = root - if len(w.rootPath) == 0 { - w.rootPath = "/" - } - w.compilePathExpression() - return w -} - -// Param adds a PathParameter to document parameters used in the root path. -func (w *WebService) Param(parameter *Parameter) *WebService { - if w.pathParameters == nil { - w.pathParameters = []*Parameter{} - } - w.pathParameters = append(w.pathParameters, parameter) - return w -} - -// PathParameter creates a new Parameter of kind Path for documentation purposes. -// It is initialized as required with string as its DataType. -func (w *WebService) PathParameter(name, description string) *Parameter { - return PathParameter(name, description) -} - -// PathParameter creates a new Parameter of kind Path for documentation purposes. -// It is initialized as required with string as its DataType. -func PathParameter(name, description string) *Parameter { - p := &Parameter{&ParameterData{Name: name, Description: description, Required: true, DataType: "string"}} - p.bePath() - return p -} - -// QueryParameter creates a new Parameter of kind Query for documentation purposes. -// It is initialized as not required with string as its DataType. -func (w *WebService) QueryParameter(name, description string) *Parameter { - return QueryParameter(name, description) -} - -// QueryParameter creates a new Parameter of kind Query for documentation purposes. -// It is initialized as not required with string as its DataType. -func QueryParameter(name, description string) *Parameter { - p := &Parameter{&ParameterData{Name: name, Description: description, Required: false, DataType: "string"}} - p.beQuery() - return p -} - -// BodyParameter creates a new Parameter of kind Body for documentation purposes. -// It is initialized as required without a DataType. -func (w *WebService) BodyParameter(name, description string) *Parameter { - return BodyParameter(name, description) -} - -// BodyParameter creates a new Parameter of kind Body for documentation purposes. -// It is initialized as required without a DataType. -func BodyParameter(name, description string) *Parameter { - p := &Parameter{&ParameterData{Name: name, Description: description, Required: true}} - p.beBody() - return p -} - -// HeaderParameter creates a new Parameter of kind (Http) Header for documentation purposes. -// It is initialized as not required with string as its DataType. -func (w *WebService) HeaderParameter(name, description string) *Parameter { - return HeaderParameter(name, description) -} - -// HeaderParameter creates a new Parameter of kind (Http) Header for documentation purposes. -// It is initialized as not required with string as its DataType. -func HeaderParameter(name, description string) *Parameter { - p := &Parameter{&ParameterData{Name: name, Description: description, Required: false, DataType: "string"}} - p.beHeader() - return p -} - -// FormParameter creates a new Parameter of kind Form (using application/x-www-form-urlencoded) for documentation purposes. -// It is initialized as required with string as its DataType. -func (w *WebService) FormParameter(name, description string) *Parameter { - return FormParameter(name, description) -} - -// FormParameter creates a new Parameter of kind Form (using application/x-www-form-urlencoded) for documentation purposes. -// It is initialized as required with string as its DataType. -func FormParameter(name, description string) *Parameter { - p := &Parameter{&ParameterData{Name: name, Description: description, Required: false, DataType: "string"}} - p.beForm() - return p -} - -// Route creates a new Route using the RouteBuilder and add to the ordered list of Routes. -func (w *WebService) Route(builder *RouteBuilder) *WebService { - w.routesLock.Lock() - defer w.routesLock.Unlock() - builder.copyDefaults(w.produces, w.consumes) - w.routes = append(w.routes, builder.Build()) - return w -} - -// RemoveRoute removes the specified route, looks for something that matches 'path' and 'method' -func (w *WebService) RemoveRoute(path, method string) error { - if !w.dynamicRoutes { - return errors.New("dynamic routes are not enabled.") - } - w.routesLock.Lock() - defer w.routesLock.Unlock() - newRoutes := make([]Route, (len(w.routes) - 1)) - current := 0 - for ix := range w.routes { - if w.routes[ix].Method == method && w.routes[ix].Path == path { - continue - } - newRoutes[current] = w.routes[ix] - current = current + 1 - } - w.routes = newRoutes - return nil -} - -// Method creates a new RouteBuilder and initialize its http method -func (w *WebService) Method(httpMethod string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method(httpMethod) -} - -// Produces specifies that this WebService can produce one or more MIME types. -// Http requests must have one of these values set for the Accept header. -func (w *WebService) Produces(contentTypes ...string) *WebService { - w.produces = contentTypes - return w -} - -// Consumes specifies that this WebService can consume one or more MIME types. -// Http requests must have one of these values set for the Content-Type header. -func (w *WebService) Consumes(accepts ...string) *WebService { - w.consumes = accepts - return w -} - -// Routes returns the Routes associated with this WebService -func (w *WebService) Routes() []Route { - if !w.dynamicRoutes { - return w.routes - } - // Make a copy of the array to prevent concurrency problems - w.routesLock.RLock() - defer w.routesLock.RUnlock() - result := make([]Route, len(w.routes)) - for ix := range w.routes { - result[ix] = w.routes[ix] - } - return result -} - -// RootPath returns the RootPath associated with this WebService. Default "/" -func (w *WebService) RootPath() string { - return w.rootPath -} - -// PathParameters return the path parameter names for (shared amoung its Routes) -func (w *WebService) PathParameters() []*Parameter { - return w.pathParameters -} - -// Filter adds a filter function to the chain of filters applicable to all its Routes -func (w *WebService) Filter(filter FilterFunction) *WebService { - w.filters = append(w.filters, filter) - return w -} - -// Doc is used to set the documentation of this service. -func (w *WebService) Doc(plainText string) *WebService { - w.documentation = plainText - return w -} - -// Documentation returns it. -func (w *WebService) Documentation() string { - return w.documentation -} - -/* - Convenience methods -*/ - -// HEAD is a shortcut for .Method("HEAD").Path(subPath) -func (w *WebService) HEAD(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("HEAD").Path(subPath) -} - -// GET is a shortcut for .Method("GET").Path(subPath) -func (w *WebService) GET(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("GET").Path(subPath) -} - -// POST is a shortcut for .Method("POST").Path(subPath) -func (w *WebService) POST(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("POST").Path(subPath) -} - -// PUT is a shortcut for .Method("PUT").Path(subPath) -func (w *WebService) PUT(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("PUT").Path(subPath) -} - -// PATCH is a shortcut for .Method("PATCH").Path(subPath) -func (w *WebService) PATCH(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("PATCH").Path(subPath) -} - -// DELETE is a shortcut for .Method("DELETE").Path(subPath) -func (w *WebService) DELETE(subPath string) *RouteBuilder { - return new(RouteBuilder).servicePath(w.rootPath).Method("DELETE").Path(subPath) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service_container.go b/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service_container.go deleted file mode 100644 index c9d31b0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/emicklei/go-restful/web_service_container.go +++ /dev/null @@ -1,39 +0,0 @@ -package restful - -// Copyright 2013 Ernest Micklei. All rights reserved. -// Use of this source code is governed by a license -// that can be found in the LICENSE file. - -import ( - "net/http" -) - -// DefaultContainer is a restful.Container that uses http.DefaultServeMux -var DefaultContainer *Container - -func init() { - DefaultContainer = NewContainer() - DefaultContainer.ServeMux = http.DefaultServeMux -} - -// If set the true then panics will not be caught to return HTTP 500. -// In that case, Route functions are responsible for handling any error situation. -// Default value is false = recover from panics. This has performance implications. -// OBSOLETE ; use restful.DefaultContainer.DoNotRecover(true) -var DoNotRecover = false - -// Add registers a new WebService add it to the DefaultContainer. -func Add(service *WebService) { - DefaultContainer.Add(service) -} - -// Filter appends a container FilterFunction from the DefaultContainer. -// These are called before dispatching a http.Request to a WebService. -func Filter(filter FilterFunction) { - DefaultContainer.Filter(filter) -} - -// RegisteredWebServices returns the collections of WebServices from the DefaultContainer -func RegisteredWebServices() []*WebService { - return DefaultContainer.RegisteredWebServices() -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.gitignore deleted file mode 100644 index e256a31..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.gitignore +++ /dev/null @@ -1,20 +0,0 @@ -# OSX leaves these everywhere on SMB shares -._* - -# Eclipse files -.classpath -.project -.settings/** - -# Emacs save files -*~ - -# Vim-related files -[._]*.s[a-w][a-z] -[._]s[a-w][a-z] -*.un~ -Session.vim -.netrwhist - -# Go test binaries -*.test diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.travis.yml b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.travis.yml deleted file mode 100644 index 0e9d6ed..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/.travis.yml +++ /dev/null @@ -1,7 +0,0 @@ -language: go -go: - - 1.3 - - 1.4 -script: - - go test - - go build diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/LICENSE deleted file mode 100644 index 7805d36..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/LICENSE +++ /dev/null @@ -1,50 +0,0 @@ -The MIT License (MIT) - -Copyright (c) 2014 Sam Ghods - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. - - -Copyright (c) 2012 The Go Authors. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/README.md deleted file mode 100644 index f8f7e36..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/README.md +++ /dev/null @@ -1,116 +0,0 @@ -# YAML marshaling and unmarshaling support for Go - -[![Build Status](https://travis-ci.org/ghodss/yaml.svg)](https://travis-ci.org/ghodss/yaml) - -## Introduction - -A wrapper around [go-yaml](https://github.com/go-yaml/yaml) designed to enable a better way of handling YAML when marshaling to and from structs. - -In short, this library first converts YAML to JSON using go-yaml and then uses `json.Marshal` and `json.Unmarshal` to convert to or from the struct. This means that it effectively reuses the JSON struct tags as well as the custom JSON methods `MarshalJSON` and `UnmarshalJSON` unlike go-yaml. For a detailed overview of the rationale behind this method, [see this blog post](http://ghodss.com/2014/the-right-way-to-handle-yaml-in-golang/). - -## Compatibility - -This package uses [go-yaml v2](https://github.com/go-yaml/yaml) and therefore supports [everything go-yaml supports](https://github.com/go-yaml/yaml#compatibility). - -## Caveats - -**Caveat #1:** When using `yaml.Marshal` and `yaml.Unmarshal`, binary data should NOT be preceded with the `!!binary` YAML tag. If you do, go-yaml will convert the binary data from base64 to native binary data, which is not compatible with JSON. You can still use binary in your YAML files though - just store them without the `!!binary` tag and decode the base64 in your code (e.g. in the custom JSON methods `MarshalJSON` and `UnmarshalJSON`). This also has the benefit that your YAML and your JSON binary data will be decoded exactly the same way. As an example: - -``` -BAD: - exampleKey: !!binary gIGC - -GOOD: - exampleKey: gIGC -... and decode the base64 data in your code. -``` - -**Caveat #2:** When using `YAMLToJSON` directly, maps with keys that are maps will result in an error since this is not supported by JSON. This error will occur in `Unmarshal` as well since you can't unmarshal map keys anyways since struct fields can't be keys. - -## Installation and usage - -To install, run: - -``` -$ go get github.com/ghodss/yaml -``` - -And import using: - -``` -import "github.com/ghodss/yaml" -``` - -Usage is very similar to the JSON library: - -```go -import ( - "fmt" - - "github.com/ghodss/yaml" -) - -type Person struct { - Name string `json:"name"` // Affects YAML field names too. - Age int `json:"name"` -} - -func main() { - // Marshal a Person struct to YAML. - p := Person{"John", 30} - y, err := yaml.Marshal(p) - if err != nil { - fmt.Printf("err: %v\n", err) - return - } - fmt.Println(string(y)) - /* Output: - name: John - age: 30 - */ - - // Unmarshal the YAML back into a Person struct. - var p2 Person - err := yaml.Unmarshal(y, &p2) - if err != nil { - fmt.Printf("err: %v\n", err) - return - } - fmt.Println(p2) - /* Output: - {John 30} - */ -} -``` - -`yaml.YAMLToJSON` and `yaml.JSONToYAML` methods are also available: - -```go -import ( - "fmt" - - "github.com/ghodss/yaml" -) -func main() { - j := []byte(`{"name": "John", "age": 30}`) - y, err := yaml.JSONToYAML(j) - if err != nil { - fmt.Printf("err: %v\n", err) - return - } - fmt.Println(string(y)) - /* Output: - name: John - age: 30 - */ - j2, err := yaml.YAMLToJSON(y) - if err != nil { - fmt.Printf("err: %v\n", err) - return - } - fmt.Println(string(j2)) - /* Output: - {"age":30,"name":"John"} - */ -} -``` diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/fields.go b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/fields.go deleted file mode 100644 index 0bd3c2b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/fields.go +++ /dev/null @@ -1,497 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. -package yaml - -import ( - "bytes" - "encoding" - "encoding/json" - "reflect" - "sort" - "strings" - "sync" - "unicode" - "unicode/utf8" -) - -// indirect walks down v allocating pointers as needed, -// until it gets to a non-pointer. -// if it encounters an Unmarshaler, indirect stops and returns that. -// if decodingNull is true, indirect stops at the last pointer so it can be set to nil. -func indirect(v reflect.Value, decodingNull bool) (json.Unmarshaler, encoding.TextUnmarshaler, reflect.Value) { - // If v is a named type and is addressable, - // start with its address, so that if the type has pointer methods, - // we find them. - if v.Kind() != reflect.Ptr && v.Type().Name() != "" && v.CanAddr() { - v = v.Addr() - } - for { - // Load value from interface, but only if the result will be - // usefully addressable. - if v.Kind() == reflect.Interface && !v.IsNil() { - e := v.Elem() - if e.Kind() == reflect.Ptr && !e.IsNil() && (!decodingNull || e.Elem().Kind() == reflect.Ptr) { - v = e - continue - } - } - - if v.Kind() != reflect.Ptr { - break - } - - if v.Elem().Kind() != reflect.Ptr && decodingNull && v.CanSet() { - break - } - if v.IsNil() { - v.Set(reflect.New(v.Type().Elem())) - } - if v.Type().NumMethod() > 0 { - if u, ok := v.Interface().(json.Unmarshaler); ok { - return u, nil, reflect.Value{} - } - if u, ok := v.Interface().(encoding.TextUnmarshaler); ok { - return nil, u, reflect.Value{} - } - } - v = v.Elem() - } - return nil, nil, v -} - -// A field represents a single field found in a struct. -type field struct { - name string - nameBytes []byte // []byte(name) - equalFold func(s, t []byte) bool // bytes.EqualFold or equivalent - - tag bool - index []int - typ reflect.Type - omitEmpty bool - quoted bool -} - -func fillField(f field) field { - f.nameBytes = []byte(f.name) - f.equalFold = foldFunc(f.nameBytes) - return f -} - -// byName sorts field by name, breaking ties with depth, -// then breaking ties with "name came from json tag", then -// breaking ties with index sequence. -type byName []field - -func (x byName) Len() int { return len(x) } - -func (x byName) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -func (x byName) Less(i, j int) bool { - if x[i].name != x[j].name { - return x[i].name < x[j].name - } - if len(x[i].index) != len(x[j].index) { - return len(x[i].index) < len(x[j].index) - } - if x[i].tag != x[j].tag { - return x[i].tag - } - return byIndex(x).Less(i, j) -} - -// byIndex sorts field by index sequence. -type byIndex []field - -func (x byIndex) Len() int { return len(x) } - -func (x byIndex) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -func (x byIndex) Less(i, j int) bool { - for k, xik := range x[i].index { - if k >= len(x[j].index) { - return false - } - if xik != x[j].index[k] { - return xik < x[j].index[k] - } - } - return len(x[i].index) < len(x[j].index) -} - -// typeFields returns a list of fields that JSON should recognize for the given type. -// The algorithm is breadth-first search over the set of structs to include - the top struct -// and then any reachable anonymous structs. -func typeFields(t reflect.Type) []field { - // Anonymous fields to explore at the current level and the next. - current := []field{} - next := []field{{typ: t}} - - // Count of queued names for current level and the next. - count := map[reflect.Type]int{} - nextCount := map[reflect.Type]int{} - - // Types already visited at an earlier level. - visited := map[reflect.Type]bool{} - - // Fields found. - var fields []field - - for len(next) > 0 { - current, next = next, current[:0] - count, nextCount = nextCount, map[reflect.Type]int{} - - for _, f := range current { - if visited[f.typ] { - continue - } - visited[f.typ] = true - - // Scan f.typ for fields to include. - for i := 0; i < f.typ.NumField(); i++ { - sf := f.typ.Field(i) - if sf.PkgPath != "" { // unexported - continue - } - tag := sf.Tag.Get("json") - if tag == "-" { - continue - } - name, opts := parseTag(tag) - if !isValidTag(name) { - name = "" - } - index := make([]int, len(f.index)+1) - copy(index, f.index) - index[len(f.index)] = i - - ft := sf.Type - if ft.Name() == "" && ft.Kind() == reflect.Ptr { - // Follow pointer. - ft = ft.Elem() - } - - // Record found field and index sequence. - if name != "" || !sf.Anonymous || ft.Kind() != reflect.Struct { - tagged := name != "" - if name == "" { - name = sf.Name - } - fields = append(fields, fillField(field{ - name: name, - tag: tagged, - index: index, - typ: ft, - omitEmpty: opts.Contains("omitempty"), - quoted: opts.Contains("string"), - })) - if count[f.typ] > 1 { - // If there were multiple instances, add a second, - // so that the annihilation code will see a duplicate. - // It only cares about the distinction between 1 or 2, - // so don't bother generating any more copies. - fields = append(fields, fields[len(fields)-1]) - } - continue - } - - // Record new anonymous struct to explore in next round. - nextCount[ft]++ - if nextCount[ft] == 1 { - next = append(next, fillField(field{name: ft.Name(), index: index, typ: ft})) - } - } - } - } - - sort.Sort(byName(fields)) - - // Delete all fields that are hidden by the Go rules for embedded fields, - // except that fields with JSON tags are promoted. - - // The fields are sorted in primary order of name, secondary order - // of field index length. Loop over names; for each name, delete - // hidden fields by choosing the one dominant field that survives. - out := fields[:0] - for advance, i := 0, 0; i < len(fields); i += advance { - // One iteration per name. - // Find the sequence of fields with the name of this first field. - fi := fields[i] - name := fi.name - for advance = 1; i+advance < len(fields); advance++ { - fj := fields[i+advance] - if fj.name != name { - break - } - } - if advance == 1 { // Only one field with this name - out = append(out, fi) - continue - } - dominant, ok := dominantField(fields[i : i+advance]) - if ok { - out = append(out, dominant) - } - } - - fields = out - sort.Sort(byIndex(fields)) - - return fields -} - -// dominantField looks through the fields, all of which are known to -// have the same name, to find the single field that dominates the -// others using Go's embedding rules, modified by the presence of -// JSON tags. If there are multiple top-level fields, the boolean -// will be false: This condition is an error in Go and we skip all -// the fields. -func dominantField(fields []field) (field, bool) { - // The fields are sorted in increasing index-length order. The winner - // must therefore be one with the shortest index length. Drop all - // longer entries, which is easy: just truncate the slice. - length := len(fields[0].index) - tagged := -1 // Index of first tagged field. - for i, f := range fields { - if len(f.index) > length { - fields = fields[:i] - break - } - if f.tag { - if tagged >= 0 { - // Multiple tagged fields at the same level: conflict. - // Return no field. - return field{}, false - } - tagged = i - } - } - if tagged >= 0 { - return fields[tagged], true - } - // All remaining fields have the same length. If there's more than one, - // we have a conflict (two fields named "X" at the same level) and we - // return no field. - if len(fields) > 1 { - return field{}, false - } - return fields[0], true -} - -var fieldCache struct { - sync.RWMutex - m map[reflect.Type][]field -} - -// cachedTypeFields is like typeFields but uses a cache to avoid repeated work. -func cachedTypeFields(t reflect.Type) []field { - fieldCache.RLock() - f := fieldCache.m[t] - fieldCache.RUnlock() - if f != nil { - return f - } - - // Compute fields without lock. - // Might duplicate effort but won't hold other computations back. - f = typeFields(t) - if f == nil { - f = []field{} - } - - fieldCache.Lock() - if fieldCache.m == nil { - fieldCache.m = map[reflect.Type][]field{} - } - fieldCache.m[t] = f - fieldCache.Unlock() - return f -} - -func isValidTag(s string) bool { - if s == "" { - return false - } - for _, c := range s { - switch { - case strings.ContainsRune("!#$%&()*+-./:<=>?@[]^_{|}~ ", c): - // Backslash and quote chars are reserved, but - // otherwise any punctuation chars are allowed - // in a tag name. - default: - if !unicode.IsLetter(c) && !unicode.IsDigit(c) { - return false - } - } - } - return true -} - -const ( - caseMask = ^byte(0x20) // Mask to ignore case in ASCII. - kelvin = '\u212a' - smallLongEss = '\u017f' -) - -// foldFunc returns one of four different case folding equivalence -// functions, from most general (and slow) to fastest: -// -// 1) bytes.EqualFold, if the key s contains any non-ASCII UTF-8 -// 2) equalFoldRight, if s contains special folding ASCII ('k', 'K', 's', 'S') -// 3) asciiEqualFold, no special, but includes non-letters (including _) -// 4) simpleLetterEqualFold, no specials, no non-letters. -// -// The letters S and K are special because they map to 3 runes, not just 2: -// * S maps to s and to U+017F 'ſ' Latin small letter long s -// * k maps to K and to U+212A 'K' Kelvin sign -// See http://play.golang.org/p/tTxjOc0OGo -// -// The returned function is specialized for matching against s and -// should only be given s. It's not curried for performance reasons. -func foldFunc(s []byte) func(s, t []byte) bool { - nonLetter := false - special := false // special letter - for _, b := range s { - if b >= utf8.RuneSelf { - return bytes.EqualFold - } - upper := b & caseMask - if upper < 'A' || upper > 'Z' { - nonLetter = true - } else if upper == 'K' || upper == 'S' { - // See above for why these letters are special. - special = true - } - } - if special { - return equalFoldRight - } - if nonLetter { - return asciiEqualFold - } - return simpleLetterEqualFold -} - -// equalFoldRight is a specialization of bytes.EqualFold when s is -// known to be all ASCII (including punctuation), but contains an 's', -// 'S', 'k', or 'K', requiring a Unicode fold on the bytes in t. -// See comments on foldFunc. -func equalFoldRight(s, t []byte) bool { - for _, sb := range s { - if len(t) == 0 { - return false - } - tb := t[0] - if tb < utf8.RuneSelf { - if sb != tb { - sbUpper := sb & caseMask - if 'A' <= sbUpper && sbUpper <= 'Z' { - if sbUpper != tb&caseMask { - return false - } - } else { - return false - } - } - t = t[1:] - continue - } - // sb is ASCII and t is not. t must be either kelvin - // sign or long s; sb must be s, S, k, or K. - tr, size := utf8.DecodeRune(t) - switch sb { - case 's', 'S': - if tr != smallLongEss { - return false - } - case 'k', 'K': - if tr != kelvin { - return false - } - default: - return false - } - t = t[size:] - - } - if len(t) > 0 { - return false - } - return true -} - -// asciiEqualFold is a specialization of bytes.EqualFold for use when -// s is all ASCII (but may contain non-letters) and contains no -// special-folding letters. -// See comments on foldFunc. -func asciiEqualFold(s, t []byte) bool { - if len(s) != len(t) { - return false - } - for i, sb := range s { - tb := t[i] - if sb == tb { - continue - } - if ('a' <= sb && sb <= 'z') || ('A' <= sb && sb <= 'Z') { - if sb&caseMask != tb&caseMask { - return false - } - } else { - return false - } - } - return true -} - -// simpleLetterEqualFold is a specialization of bytes.EqualFold for -// use when s is all ASCII letters (no underscores, etc) and also -// doesn't contain 'k', 'K', 's', or 'S'. -// See comments on foldFunc. -func simpleLetterEqualFold(s, t []byte) bool { - if len(s) != len(t) { - return false - } - for i, b := range s { - if b&caseMask != t[i]&caseMask { - return false - } - } - return true -} - -// tagOptions is the string following a comma in a struct field's "json" -// tag, or the empty string. It does not include the leading comma. -type tagOptions string - -// parseTag splits a struct field's json tag into its name and -// comma-separated options. -func parseTag(tag string) (string, tagOptions) { - if idx := strings.Index(tag, ","); idx != -1 { - return tag[:idx], tagOptions(tag[idx+1:]) - } - return tag, tagOptions("") -} - -// Contains reports whether a comma-separated list of options -// contains a particular substr flag. substr must be surrounded by a -// string boundary or commas. -func (o tagOptions) Contains(optionName string) bool { - if len(o) == 0 { - return false - } - s := string(o) - for s != "" { - var next string - i := strings.Index(s, ",") - if i >= 0 { - s, next = s[:i], s[i+1:] - } - if s == optionName { - return true - } - s = next - } - return false -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/yaml.go b/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/yaml.go deleted file mode 100644 index c02beac..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ghodss/yaml/yaml.go +++ /dev/null @@ -1,277 +0,0 @@ -package yaml - -import ( - "bytes" - "encoding/json" - "fmt" - "reflect" - "strconv" - - "gopkg.in/yaml.v2" -) - -// Marshals the object into JSON then converts JSON to YAML and returns the -// YAML. -func Marshal(o interface{}) ([]byte, error) { - j, err := json.Marshal(o) - if err != nil { - return nil, fmt.Errorf("error marshaling into JSON: ", err) - } - - y, err := JSONToYAML(j) - if err != nil { - return nil, fmt.Errorf("error converting JSON to YAML: ", err) - } - - return y, nil -} - -// Converts YAML to JSON then uses JSON to unmarshal into an object. -func Unmarshal(y []byte, o interface{}) error { - vo := reflect.ValueOf(o) - j, err := yamlToJSON(y, &vo) - if err != nil { - return fmt.Errorf("error converting YAML to JSON: %v", err) - } - - err = json.Unmarshal(j, o) - if err != nil { - return fmt.Errorf("error unmarshaling JSON: %v", err) - } - - return nil -} - -// Convert JSON to YAML. -func JSONToYAML(j []byte) ([]byte, error) { - // Convert the JSON to an object. - var jsonObj interface{} - // We are using yaml.Unmarshal here (instead of json.Unmarshal) because the - // Go JSON library doesn't try to pick the right number type (int, float, - // etc.) when unmarshling to interface{}, it just picks float64 - // universally. go-yaml does go through the effort of picking the right - // number type, so we can preserve number type throughout this process. - err := yaml.Unmarshal(j, &jsonObj) - if err != nil { - return nil, err - } - - // Marshal this object into YAML. - return yaml.Marshal(jsonObj) -} - -// Convert YAML to JSON. Since JSON is a subset of YAML, passing JSON through -// this method should be a no-op. -// -// Things YAML can do that are not supported by JSON: -// * In YAML you can have binary and null keys in your maps. These are invalid -// in JSON. (int and float keys are converted to strings.) -// * Binary data in YAML with the !!binary tag is not supported. If you want to -// use binary data with this library, encode the data as base64 as usual but do -// not use the !!binary tag in your YAML. This will ensure the original base64 -// encoded data makes it all the way through to the JSON. -func YAMLToJSON(y []byte) ([]byte, error) { - return yamlToJSON(y, nil) -} - -func yamlToJSON(y []byte, jsonTarget *reflect.Value) ([]byte, error) { - // Convert the YAML to an object. - var yamlObj interface{} - err := yaml.Unmarshal(y, &yamlObj) - if err != nil { - return nil, err - } - - // YAML objects are not completely compatible with JSON objects (e.g. you - // can have non-string keys in YAML). So, convert the YAML-compatible object - // to a JSON-compatible object, failing with an error if irrecoverable - // incompatibilties happen along the way. - jsonObj, err := convertToJSONableObject(yamlObj, jsonTarget) - if err != nil { - return nil, err - } - - // Convert this object to JSON and return the data. - return json.Marshal(jsonObj) -} - -func convertToJSONableObject(yamlObj interface{}, jsonTarget *reflect.Value) (interface{}, error) { - var err error - - // Resolve jsonTarget to a concrete value (i.e. not a pointer or an - // interface). We pass decodingNull as false because we're not actually - // decoding into the value, we're just checking if the ultimate target is a - // string. - if jsonTarget != nil { - ju, tu, pv := indirect(*jsonTarget, false) - // We have a JSON or Text Umarshaler at this level, so we can't be trying - // to decode into a string. - if ju != nil || tu != nil { - jsonTarget = nil - } else { - jsonTarget = &pv - } - } - - // If yamlObj is a number or a boolean, check if jsonTarget is a string - - // if so, coerce. Else return normal. - // If yamlObj is a map or array, find the field that each key is - // unmarshaling to, and when you recurse pass the reflect.Value for that - // field back into this function. - switch typedYAMLObj := yamlObj.(type) { - case map[interface{}]interface{}: - // JSON does not support arbitrary keys in a map, so we must convert - // these keys to strings. - // - // From my reading of go-yaml v2 (specifically the resolve function), - // keys can only have the types string, int, int64, float64, binary - // (unsupported), or null (unsupported). - strMap := make(map[string]interface{}) - for k, v := range typedYAMLObj { - // Resolve the key to a string first. - var keyString string - switch typedKey := k.(type) { - case string: - keyString = typedKey - case int: - keyString = strconv.Itoa(typedKey) - case int64: - // go-yaml will only return an int64 as a key if the system - // architecture is 32-bit and the key's value is between 32-bit - // and 64-bit. Otherwise the key type will simply be int. - keyString = strconv.FormatInt(typedKey, 10) - case float64: - // Stolen from go-yaml to use the same conversion to string as - // the go-yaml library uses to convert float to string when - // Marshaling. - s := strconv.FormatFloat(typedKey, 'g', -1, 32) - switch s { - case "+Inf": - s = ".inf" - case "-Inf": - s = "-.inf" - case "NaN": - s = ".nan" - } - keyString = s - case bool: - if typedKey { - keyString = "true" - } else { - keyString = "false" - } - default: - return nil, fmt.Errorf("Unsupported map key of type: %s, key: %+#v, value: %+#v", - reflect.TypeOf(k), k, v) - } - - // jsonTarget should be a struct or a map. If it's a struct, find - // the field it's going to map to and pass its reflect.Value. If - // it's a map, find the element type of the map and pass the - // reflect.Value created from that type. If it's neither, just pass - // nil - JSON conversion will error for us if it's a real issue. - if jsonTarget != nil { - t := *jsonTarget - if t.Kind() == reflect.Struct { - keyBytes := []byte(keyString) - // Find the field that the JSON library would use. - var f *field - fields := cachedTypeFields(t.Type()) - for i := range fields { - ff := &fields[i] - if bytes.Equal(ff.nameBytes, keyBytes) { - f = ff - break - } - // Do case-insensitive comparison. - if f == nil && ff.equalFold(ff.nameBytes, keyBytes) { - f = ff - } - } - if f != nil { - // Find the reflect.Value of the most preferential - // struct field. - jtf := t.Field(f.index[0]) - strMap[keyString], err = convertToJSONableObject(v, &jtf) - if err != nil { - return nil, err - } - continue - } - } else if t.Kind() == reflect.Map { - // Create a zero value of the map's element type to use as - // the JSON target. - jtv := reflect.Zero(t.Type().Elem()) - strMap[keyString], err = convertToJSONableObject(v, &jtv) - if err != nil { - return nil, err - } - continue - } - } - strMap[keyString], err = convertToJSONableObject(v, nil) - if err != nil { - return nil, err - } - } - return strMap, nil - case []interface{}: - // We need to recurse into arrays in case there are any - // map[interface{}]interface{}'s inside and to convert any - // numbers to strings. - - // If jsonTarget is a slice (which it really should be), find the - // thing it's going to map to. If it's not a slice, just pass nil - // - JSON conversion will error for us if it's a real issue. - var jsonSliceElemValue *reflect.Value - if jsonTarget != nil { - t := *jsonTarget - if t.Kind() == reflect.Slice { - // By default slices point to nil, but we need a reflect.Value - // pointing to a value of the slice type, so we create one here. - ev := reflect.Indirect(reflect.New(t.Type().Elem())) - jsonSliceElemValue = &ev - } - } - - // Make and use a new array. - arr := make([]interface{}, len(typedYAMLObj)) - for i, v := range typedYAMLObj { - arr[i], err = convertToJSONableObject(v, jsonSliceElemValue) - if err != nil { - return nil, err - } - } - return arr, nil - default: - // If the target type is a string and the YAML type is a number, - // convert the YAML type to a string. - if jsonTarget != nil && (*jsonTarget).Kind() == reflect.String { - // Based on my reading of go-yaml, it may return int, int64, - // float64, or uint64. - var s string - switch typedVal := typedYAMLObj.(type) { - case int: - s = strconv.FormatInt(int64(typedVal), 10) - case int64: - s = strconv.FormatInt(typedVal, 10) - case float64: - s = strconv.FormatFloat(typedVal, 'g', -1, 32) - case uint64: - s = strconv.FormatUint(typedVal, 10) - case bool: - if typedVal { - s = "true" - } else { - s = "false" - } - } - if len(s) > 0 { - yamlObj = interface{}(s) - } - } - return yamlObj, nil - } - - return nil, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.sec b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.sec deleted file mode 100644 index a1d7bbe..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.sec +++ /dev/null @@ -1 +0,0 @@ -eyJhbGciOiJSU0EtT0FFUCIsImVuYyI6IkExMjhHQ00ifQ.pDqezepze0YqRx4u6M8GFaWtnVR-utTWZic-GX-RvMATAoYpG4H2sc9tlnGNCxa44dbRY0vY10qfBU7Sno8vkp21fsK42ofGLfen_suum_0ilm0sFS0X-kAwk7TIq5L5lPPKiChPMUiGp5oJW-g5MqMFX1jNiI-4fP-vSM3B3-eyZtJD_O517TgfIRLnblCzqwIkyRmAfPNopi-Fe8Y31TmO2Vd0nFc1Aqro_VaJSACzEVxOHTNpjETcMjlYzwgMXLeiAfLV-5hM0f6DXgHMlLSuMkB_Ndnw25dkB7hreGk4x0tHQ3X9mUfTgLq1hIDoyeeKDIM83Tqw4LBRph20BQ.qd_pNuyi23B0PlWz.JtpO7kqOm0SWOGzWDalkWheHuNd-eDpVbqI9WPAEFDOIBvz7TbsYMBlIYVWEGWbat4mkx_ejxnMn1L1l996NJnyP7eY-QE82cfPJbjx94d0Ob70KZ4DCm_UxcY2t-OKFiPJqxW7MA5jKyDuGD16bdxpjLEoe_cMSEr8FNu-MVG6wcchPcyYyRkqTQSl4mb09KikkAzHjwjo-DcO0f8ps4Uzsoc0aqAAWdE-ocG0YqierLoemjusYMiLH-eLF6MvaLRvHSte-cLzPuYCeZURnBDgxu3i3UApgddnX7g1c7tdGGBGvgCl-tEEDW58Vxgdjksim2S7y3lfoJ8FFzSWeRH2y7Kq04hgew3b2J_RiDB9ejzIopzG8ZGjJa3EO1-i9ORTl12nXK1RdlLGqu604ENaeVOPCIHL-0C8e6_wHdUGHydLZImSxKYSrNvy8resP1D_9t4B-3q2mkS9mhnMONrXbPDVw5QY5mvXlWs0Db99ARwzsl-Qlu0A_tsZwMjWT2I1QMvWPyTRScmMm0FJSv9zStjzxWa_q2GL7Naz1fI4Dd6ZgNJWYYq-mHN5chEeBdIcwb_zMPHczMQXXNL5nmfRGM1aPffkToFWCDpIlI8IXec83ZC6_POxZegS6n9Drrvc.6Nz8EXxs1lWX3ASaCeNElA \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.yml b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.yml deleted file mode 100644 index cb8c7b5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.drone.yml +++ /dev/null @@ -1,32 +0,0 @@ -clone: - path: github.com/go-openapi/jsonpointer - -matrix: - GO_VERSION: - - "1.6" - -build: - integration: - image: golang:$$GO_VERSION - pull: true - commands: - - go get -u github.com/stretchr/testify/assert - - go get -u github.com/go-openapi/swag - - go test -race - - go test -v -cover -coverprofile=coverage.out -covermode=count ./... - -notify: - slack: - channel: bots - webhook_url: $$SLACK_URL - username: drone - -publish: - coverage: - server: https://coverage.vmware.run - token: $$GITHUB_TOKEN - # threshold: 70 - # must_increase: true - when: - matrix: - GO_VERSION: "1.6" diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.gitignore deleted file mode 100644 index 769c244..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/.gitignore +++ /dev/null @@ -1 +0,0 @@ -secrets.yml diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/CODE_OF_CONDUCT.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/CODE_OF_CONDUCT.md deleted file mode 100644 index 9322b06..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/CODE_OF_CONDUCT.md +++ /dev/null @@ -1,74 +0,0 @@ -# Contributor Covenant Code of Conduct - -## Our Pledge - -In the interest of fostering an open and welcoming environment, we as -contributors and maintainers pledge to making participation in our project and -our community a harassment-free experience for everyone, regardless of age, body -size, disability, ethnicity, gender identity and expression, level of experience, -nationality, personal appearance, race, religion, or sexual identity and -orientation. - -## Our Standards - -Examples of behavior that contributes to creating a positive environment -include: - -* Using welcoming and inclusive language -* Being respectful of differing viewpoints and experiences -* Gracefully accepting constructive criticism -* Focusing on what is best for the community -* Showing empathy towards other community members - -Examples of unacceptable behavior by participants include: - -* The use of sexualized language or imagery and unwelcome sexual attention or -advances -* Trolling, insulting/derogatory comments, and personal or political attacks -* Public or private harassment -* Publishing others' private information, such as a physical or electronic - address, without explicit permission -* Other conduct which could reasonably be considered inappropriate in a - professional setting - -## Our Responsibilities - -Project maintainers are responsible for clarifying the standards of acceptable -behavior and are expected to take appropriate and fair corrective action in -response to any instances of unacceptable behavior. - -Project maintainers have the right and responsibility to remove, edit, or -reject comments, commits, code, wiki edits, issues, and other contributions -that are not aligned to this Code of Conduct, or to ban temporarily or -permanently any contributor for other behaviors that they deem inappropriate, -threatening, offensive, or harmful. - -## Scope - -This Code of Conduct applies both within project spaces and in public spaces -when an individual is representing the project or its community. Examples of -representing a project or community include using an official project e-mail -address, posting via an official social media account, or acting as an appointed -representative at an online or offline event. Representation of a project may be -further defined and clarified by project maintainers. - -## Enforcement - -Instances of abusive, harassing, or otherwise unacceptable behavior may be -reported by contacting the project team at ivan+abuse@flanders.co.nz. All -complaints will be reviewed and investigated and will result in a response that -is deemed necessary and appropriate to the circumstances. The project team is -obligated to maintain confidentiality with regard to the reporter of an incident. -Further details of specific enforcement policies may be posted separately. - -Project maintainers who do not follow or enforce the Code of Conduct in good -faith may face temporary or permanent repercussions as determined by other -members of the project's leadership. - -## Attribution - -This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, -available at [http://contributor-covenant.org/version/1/4][version] - -[homepage]: http://contributor-covenant.org -[version]: http://contributor-covenant.org/version/1/4/ diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/README.md deleted file mode 100644 index 9c9b1fd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/README.md +++ /dev/null @@ -1,15 +0,0 @@ -# gojsonpointer [![Build Status](https://ci.vmware.run/api/badges/go-openapi/jsonpointer/status.svg)](https://ci.vmware.run/go-openapi/jsonpointer) [![Coverage](https://coverage.vmware.run/badges/go-openapi/jsonpointer/coverage.svg)](https://coverage.vmware.run/go-openapi/jsonpointer) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) - -[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/jsonpointer/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/jsonpointer?status.svg)](http://godoc.org/github.com/go-openapi/jsonpointer) -An implementation of JSON Pointer - Go language - -## Status -Completed YES - -Tested YES - -## References -http://tools.ietf.org/html/draft-ietf-appsawg-json-pointer-07 - -### Note -The 4.Evaluation part of the previous reference, starting with 'If the currently referenced value is a JSON array, the reference token MUST contain either...' is not implemented. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/pointer.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/pointer.go deleted file mode 100644 index 39dd012..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonpointer/pointer.go +++ /dev/null @@ -1,238 +0,0 @@ -// Copyright 2013 sigu-399 ( https://github.com/sigu-399 ) -// -// 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. - -// author sigu-399 -// author-github https://github.com/sigu-399 -// author-mail sigu.399@gmail.com -// -// repository-name jsonpointer -// repository-desc An implementation of JSON Pointer - Go language -// -// description Main and unique file. -// -// created 25-02-2013 - -package jsonpointer - -import ( - "errors" - "fmt" - "reflect" - "strconv" - "strings" - - "github.com/go-openapi/swag" -) - -const ( - emptyPointer = `` - pointerSeparator = `/` - - invalidStart = `JSON pointer must be empty or start with a "` + pointerSeparator -) - -var jsonPointableType = reflect.TypeOf(new(JSONPointable)).Elem() - -// JSONPointable is an interface for structs to implement when they need to customize the -// json pointer process -type JSONPointable interface { - JSONLookup(string) (interface{}, error) -} - -type implStruct struct { - mode string // "SET" or "GET" - - inDocument interface{} - - setInValue interface{} - - getOutNode interface{} - getOutKind reflect.Kind - outError error -} - -// New creates a new json pointer for the given string -func New(jsonPointerString string) (Pointer, error) { - - var p Pointer - err := p.parse(jsonPointerString) - return p, err - -} - -// Pointer the json pointer reprsentation -type Pointer struct { - referenceTokens []string -} - -// "Constructor", parses the given string JSON pointer -func (p *Pointer) parse(jsonPointerString string) error { - - var err error - - if jsonPointerString != emptyPointer { - if !strings.HasPrefix(jsonPointerString, pointerSeparator) { - err = errors.New(invalidStart) - } else { - referenceTokens := strings.Split(jsonPointerString, pointerSeparator) - for _, referenceToken := range referenceTokens[1:] { - p.referenceTokens = append(p.referenceTokens, referenceToken) - } - } - } - - return err -} - -// Get uses the pointer to retrieve a value from a JSON document -func (p *Pointer) Get(document interface{}) (interface{}, reflect.Kind, error) { - return p.get(document, swag.DefaultJSONNameProvider) -} - -// GetForToken gets a value for a json pointer token 1 level deep -func GetForToken(document interface{}, decodedToken string) (interface{}, reflect.Kind, error) { - return getSingleImpl(document, decodedToken, swag.DefaultJSONNameProvider) -} - -func getSingleImpl(node interface{}, decodedToken string, nameProvider *swag.NameProvider) (interface{}, reflect.Kind, error) { - kind := reflect.Invalid - rValue := reflect.Indirect(reflect.ValueOf(node)) - kind = rValue.Kind() - switch kind { - - case reflect.Struct: - if rValue.Type().Implements(jsonPointableType) { - r, err := node.(JSONPointable).JSONLookup(decodedToken) - if err != nil { - return nil, kind, err - } - return r, kind, nil - } - nm, ok := nameProvider.GetGoNameForType(rValue.Type(), decodedToken) - if !ok { - return nil, kind, fmt.Errorf("object has no field %q", decodedToken) - } - fld := rValue.FieldByName(nm) - return fld.Interface(), kind, nil - - case reflect.Map: - kv := reflect.ValueOf(decodedToken) - mv := rValue.MapIndex(kv) - if mv.IsValid() && !swag.IsZero(mv) { - return mv.Interface(), kind, nil - } - return nil, kind, fmt.Errorf("object has no key %q", decodedToken) - - case reflect.Slice: - tokenIndex, err := strconv.Atoi(decodedToken) - if err != nil { - return nil, kind, err - } - sLength := rValue.Len() - if tokenIndex < 0 || tokenIndex >= sLength { - return nil, kind, fmt.Errorf("index out of bounds array[0,%d] index '%d'", sLength, tokenIndex) - } - - elem := rValue.Index(tokenIndex) - return elem.Interface(), kind, nil - - default: - return nil, kind, fmt.Errorf("invalid token reference %q", decodedToken) - } - -} - -func (p *Pointer) get(node interface{}, nameProvider *swag.NameProvider) (interface{}, reflect.Kind, error) { - - if nameProvider == nil { - nameProvider = swag.DefaultJSONNameProvider - } - - kind := reflect.Invalid - - // Full document when empty - if len(p.referenceTokens) == 0 { - return node, kind, nil - } - - for _, token := range p.referenceTokens { - - decodedToken := Unescape(token) - - r, knd, err := getSingleImpl(node, decodedToken, nameProvider) - if err != nil { - return nil, knd, err - } - node, kind = r, knd - - } - - rValue := reflect.ValueOf(node) - kind = rValue.Kind() - - return node, kind, nil -} - -// DecodedTokens returns the decoded tokens -func (p *Pointer) DecodedTokens() []string { - result := make([]string, 0, len(p.referenceTokens)) - for _, t := range p.referenceTokens { - result = append(result, Unescape(t)) - } - return result -} - -// IsEmpty returns true if this is an empty json pointer -// this indicates that it points to the root document -func (p *Pointer) IsEmpty() bool { - return len(p.referenceTokens) == 0 -} - -// Pointer to string representation function -func (p *Pointer) String() string { - - if len(p.referenceTokens) == 0 { - return emptyPointer - } - - pointerString := pointerSeparator + strings.Join(p.referenceTokens, pointerSeparator) - - return pointerString -} - -// Specific JSON pointer encoding here -// ~0 => ~ -// ~1 => / -// ... and vice versa - -const ( - encRefTok0 = `~0` - encRefTok1 = `~1` - decRefTok0 = `~` - decRefTok1 = `/` -) - -// Unescape unescapes a json pointer reference token string to the original representation -func Unescape(token string) string { - step1 := strings.Replace(token, encRefTok1, decRefTok1, -1) - step2 := strings.Replace(step1, encRefTok0, decRefTok0, -1) - return step2 -} - -// Escape escapes a pointer reference token string -func Escape(token string) string { - step1 := strings.Replace(token, decRefTok0, encRefTok0, -1) - step2 := strings.Replace(step1, decRefTok1, encRefTok1, -1) - return step2 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.sec b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.sec deleted file mode 100644 index 5ff54fb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.sec +++ /dev/null @@ -1 +0,0 @@ -eyJhbGciOiJSU0EtT0FFUCIsImVuYyI6IkExMjhHQ00ifQ.Xe40Wx6g5Y-iN0JVMhKyFfubtOId3zAVE564szw_yYGzFNhc_cGZO9F3BtAcJ55CfHG9C_ozn9dpnUDl_zYZoy_6cPCq13Ekb95z8NAC3ekDtbAATsc9HZwRNwI7UfkhstdwxljEouGB01qoLcUn6lFutrou-Ho21COHeDb2caemnPSA-rEAnXkOiBFu0RQ1MIwMygzvHXIHHYNpNwAtXqmiggM10miSjqBM3JmRPxCi7VK6_Rxij5p6LlhmK1BDi8Y6oBh-9BX3--5GAJeWZ6Vof5TnP-Enioia18j8c8KFtfY4q0y6Ednjb-AarLZ12gj695ppkBNJUdTJQmwGwA.fVcz_RiLrUB5fgMS.rjWllDYC6m_NB-ket_LizNEy9mlJ27odBTZQcMKaUqqXZBtWUCmPrOoMXGq-_cc-c7chg7D-WMh9SPQ23pV0P-DY-jsDpbOqHG2STOMEfW9ZREoaOLJXQaWcuBldLjRyWFcq0HGj97LgE6szD1Zlou3bmdHS_Q-U9Up9YQ_8_YnDcESD_cj1w5FZom7HjchKJFeGjQjfDQpoCKCQNMJaavUqy9jHQEeQ_uVocSrETg3GpewDcUF2tuv8uGq7ZZWu7Vl8zmnY1MFTynaGBWzTCSRmCkAXjcsaUheDP_NT5D7k-xUS6LwtqEUiXAXV07SNFraorFj5lnBQZRDlZMYcA3NWR6zHiOxekR9LBYPofst6w1rIqUchj_5m1tDpVTBMPir1eAaFcnJtPgo4ch17OF-kmcmQGLhJI3U7n8wv4sTrmP1dewtRRKrvlJe5r3_6eDiK4xZ8K0rnK1D4g6zuQqU1gA8KaU7pmZkKpFx3Bew4v-6DH32YwQBvAI7Lbb8afou9WsCNB_iswz5XGimP4bifiJRwpWBEz9VGhZFdiw-hZpYWgbxzVb5gtqfTDLIvpbLDmFz1vge16uUQHHVFpo1pSozyr7A60X8qsh9pmmO3RcJ-ZGZBWqiRC-Kl5ejz7WQ.LFoK4Ibi11B2lWQ5WcPSag \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.yml b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.yml deleted file mode 100644 index 157ffe5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.drone.yml +++ /dev/null @@ -1,33 +0,0 @@ -clone: - path: github.com/go-openapi/jsonreference - -matrix: - GO_VERSION: - - "1.6" - -build: - integration: - image: golang:$$GO_VERSION - pull: true - commands: - - go get -u github.com/stretchr/testify/assert - - go get -u github.com/PuerkitoBio/purell - - go get -u github.com/go-openapi/jsonpointer - - go test -race - - go test -v -cover -coverprofile=coverage.out -covermode=count ./... - -notify: - slack: - channel: bots - webhook_url: $$SLACK_URL - username: drone - -publish: - coverage: - server: https://coverage.vmware.run - token: $$GITHUB_TOKEN - # threshold: 70 - # must_increase: true - when: - matrix: - GO_VERSION: "1.6" diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.gitignore deleted file mode 100644 index 769c244..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/.gitignore +++ /dev/null @@ -1 +0,0 @@ -secrets.yml diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/CODE_OF_CONDUCT.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/CODE_OF_CONDUCT.md deleted file mode 100644 index 9322b06..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/CODE_OF_CONDUCT.md +++ /dev/null @@ -1,74 +0,0 @@ -# Contributor Covenant Code of Conduct - -## Our Pledge - -In the interest of fostering an open and welcoming environment, we as -contributors and maintainers pledge to making participation in our project and -our community a harassment-free experience for everyone, regardless of age, body -size, disability, ethnicity, gender identity and expression, level of experience, -nationality, personal appearance, race, religion, or sexual identity and -orientation. - -## Our Standards - -Examples of behavior that contributes to creating a positive environment -include: - -* Using welcoming and inclusive language -* Being respectful of differing viewpoints and experiences -* Gracefully accepting constructive criticism -* Focusing on what is best for the community -* Showing empathy towards other community members - -Examples of unacceptable behavior by participants include: - -* The use of sexualized language or imagery and unwelcome sexual attention or -advances -* Trolling, insulting/derogatory comments, and personal or political attacks -* Public or private harassment -* Publishing others' private information, such as a physical or electronic - address, without explicit permission -* Other conduct which could reasonably be considered inappropriate in a - professional setting - -## Our Responsibilities - -Project maintainers are responsible for clarifying the standards of acceptable -behavior and are expected to take appropriate and fair corrective action in -response to any instances of unacceptable behavior. - -Project maintainers have the right and responsibility to remove, edit, or -reject comments, commits, code, wiki edits, issues, and other contributions -that are not aligned to this Code of Conduct, or to ban temporarily or -permanently any contributor for other behaviors that they deem inappropriate, -threatening, offensive, or harmful. - -## Scope - -This Code of Conduct applies both within project spaces and in public spaces -when an individual is representing the project or its community. Examples of -representing a project or community include using an official project e-mail -address, posting via an official social media account, or acting as an appointed -representative at an online or offline event. Representation of a project may be -further defined and clarified by project maintainers. - -## Enforcement - -Instances of abusive, harassing, or otherwise unacceptable behavior may be -reported by contacting the project team at ivan+abuse@flanders.co.nz. All -complaints will be reviewed and investigated and will result in a response that -is deemed necessary and appropriate to the circumstances. The project team is -obligated to maintain confidentiality with regard to the reporter of an incident. -Further details of specific enforcement policies may be posted separately. - -Project maintainers who do not follow or enforce the Code of Conduct in good -faith may face temporary or permanent repercussions as determined by other -members of the project's leadership. - -## Attribution - -This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, -available at [http://contributor-covenant.org/version/1/4][version] - -[homepage]: http://contributor-covenant.org -[version]: http://contributor-covenant.org/version/1/4/ diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/README.md deleted file mode 100644 index 5f78812..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/README.md +++ /dev/null @@ -1,15 +0,0 @@ -# gojsonreference [![Build Status](https://ci.vmware.run/api/badges/go-openapi/jsonreference/status.svg)](https://ci.vmware.run/go-openapi/jsonreference) [![Coverage](https://coverage.vmware.run/badges/go-openapi/jsonreference/coverage.svg)](https://coverage.vmware.run/go-openapi/jsonreference) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) - -[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/jsonreference/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/jsonreference?status.svg)](http://godoc.org/github.com/go-openapi/jsonreference) -An implementation of JSON Reference - Go language - -## Status -Work in progress ( 90% done ) - -## Dependencies -https://github.com/xeipuuv/gojsonpointer - -## References -http://tools.ietf.org/html/draft-ietf-appsawg-json-pointer-07 - -http://tools.ietf.org/html/draft-pbryan-zyp-json-ref-03 diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/reference.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/reference.go deleted file mode 100644 index 3bc0a6e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/jsonreference/reference.go +++ /dev/null @@ -1,156 +0,0 @@ -// Copyright 2013 sigu-399 ( https://github.com/sigu-399 ) -// -// 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. - -// author sigu-399 -// author-github https://github.com/sigu-399 -// author-mail sigu.399@gmail.com -// -// repository-name jsonreference -// repository-desc An implementation of JSON Reference - Go language -// -// description Main and unique file. -// -// created 26-02-2013 - -package jsonreference - -import ( - "errors" - "net/url" - "strings" - - "github.com/PuerkitoBio/purell" - "github.com/go-openapi/jsonpointer" -) - -const ( - fragmentRune = `#` -) - -// New creates a new reference for the given string -func New(jsonReferenceString string) (Ref, error) { - - var r Ref - err := r.parse(jsonReferenceString) - return r, err - -} - -// MustCreateRef parses the ref string and panics when it's invalid. -// Use the New method for a version that returns an error -func MustCreateRef(ref string) Ref { - r, err := New(ref) - if err != nil { - panic(err) - } - return r -} - -// Ref represents a json reference object -type Ref struct { - referenceURL *url.URL - referencePointer jsonpointer.Pointer - - HasFullURL bool - HasURLPathOnly bool - HasFragmentOnly bool - HasFileScheme bool - HasFullFilePath bool -} - -// GetURL gets the URL for this reference -func (r *Ref) GetURL() *url.URL { - return r.referenceURL -} - -// GetPointer gets the json pointer for this reference -func (r *Ref) GetPointer() *jsonpointer.Pointer { - return &r.referencePointer -} - -// String returns the best version of the url for this reference -func (r *Ref) String() string { - - if r.referenceURL != nil { - return r.referenceURL.String() - } - - if r.HasFragmentOnly { - return fragmentRune + r.referencePointer.String() - } - - return r.referencePointer.String() -} - -// IsRoot returns true if this reference is a root document -func (r *Ref) IsRoot() bool { - return r.referenceURL != nil && - !r.IsCanonical() && - !r.HasURLPathOnly && - r.referenceURL.Fragment == "" -} - -// IsCanonical returns true when this pointer starts with http(s):// or file:// -func (r *Ref) IsCanonical() bool { - return (r.HasFileScheme && r.HasFullFilePath) || (!r.HasFileScheme && r.HasFullURL) -} - -// "Constructor", parses the given string JSON reference -func (r *Ref) parse(jsonReferenceString string) error { - - parsed, err := url.Parse(jsonReferenceString) - if err != nil { - return err - } - - r.referenceURL, _ = url.Parse(purell.NormalizeURL(parsed, purell.FlagsSafe|purell.FlagRemoveDuplicateSlashes)) - refURL := r.referenceURL - - if refURL.Scheme != "" && refURL.Host != "" { - r.HasFullURL = true - } else { - if refURL.Path != "" { - r.HasURLPathOnly = true - } else if refURL.RawQuery == "" && refURL.Fragment != "" { - r.HasFragmentOnly = true - } - } - - r.HasFileScheme = refURL.Scheme == "file" - r.HasFullFilePath = strings.HasPrefix(refURL.Path, "/") - - // invalid json-pointer error means url has no json-pointer fragment. simply ignore error - r.referencePointer, _ = jsonpointer.New(refURL.Fragment) - - return nil -} - -// Inherits creates a new reference from a parent and a child -// If the child cannot inherit from the parent, an error is returned -func (r *Ref) Inherits(child Ref) (*Ref, error) { - childURL := child.GetURL() - parentURL := r.GetURL() - if childURL == nil { - return nil, errors.New("child url is nil") - } - if parentURL == nil { - return &child, nil - } - - ref, err := New(parentURL.ResolveReference(childURL).String()) - if err != nil { - return nil, err - } - return &ref, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.gitignore deleted file mode 100644 index dd91ed6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.gitignore +++ /dev/null @@ -1,2 +0,0 @@ -secrets.yml -coverage.out diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.pullapprove.yml b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.pullapprove.yml deleted file mode 100644 index 5ec183e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/.pullapprove.yml +++ /dev/null @@ -1,13 +0,0 @@ -approve_by_comment: true -approve_regex: '^(:shipit:|:\+1:|\+1|LGTM|lgtm|Approved)' -reject_regex: ^[Rr]ejected -reset_on_push: false -reviewers: - members: - - casualjim - - chancez - - frapposelli - - vburenin - - pytlesk4 - name: pullapprove - required: 1 diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/CODE_OF_CONDUCT.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/CODE_OF_CONDUCT.md deleted file mode 100644 index 9322b06..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/CODE_OF_CONDUCT.md +++ /dev/null @@ -1,74 +0,0 @@ -# Contributor Covenant Code of Conduct - -## Our Pledge - -In the interest of fostering an open and welcoming environment, we as -contributors and maintainers pledge to making participation in our project and -our community a harassment-free experience for everyone, regardless of age, body -size, disability, ethnicity, gender identity and expression, level of experience, -nationality, personal appearance, race, religion, or sexual identity and -orientation. - -## Our Standards - -Examples of behavior that contributes to creating a positive environment -include: - -* Using welcoming and inclusive language -* Being respectful of differing viewpoints and experiences -* Gracefully accepting constructive criticism -* Focusing on what is best for the community -* Showing empathy towards other community members - -Examples of unacceptable behavior by participants include: - -* The use of sexualized language or imagery and unwelcome sexual attention or -advances -* Trolling, insulting/derogatory comments, and personal or political attacks -* Public or private harassment -* Publishing others' private information, such as a physical or electronic - address, without explicit permission -* Other conduct which could reasonably be considered inappropriate in a - professional setting - -## Our Responsibilities - -Project maintainers are responsible for clarifying the standards of acceptable -behavior and are expected to take appropriate and fair corrective action in -response to any instances of unacceptable behavior. - -Project maintainers have the right and responsibility to remove, edit, or -reject comments, commits, code, wiki edits, issues, and other contributions -that are not aligned to this Code of Conduct, or to ban temporarily or -permanently any contributor for other behaviors that they deem inappropriate, -threatening, offensive, or harmful. - -## Scope - -This Code of Conduct applies both within project spaces and in public spaces -when an individual is representing the project or its community. Examples of -representing a project or community include using an official project e-mail -address, posting via an official social media account, or acting as an appointed -representative at an online or offline event. Representation of a project may be -further defined and clarified by project maintainers. - -## Enforcement - -Instances of abusive, harassing, or otherwise unacceptable behavior may be -reported by contacting the project team at ivan+abuse@flanders.co.nz. All -complaints will be reviewed and investigated and will result in a response that -is deemed necessary and appropriate to the circumstances. The project team is -obligated to maintain confidentiality with regard to the reporter of an incident. -Further details of specific enforcement policies may be posted separately. - -Project maintainers who do not follow or enforce the Code of Conduct in good -faith may face temporary or permanent repercussions as determined by other -members of the project's leadership. - -## Attribution - -This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, -available at [http://contributor-covenant.org/version/1/4][version] - -[homepage]: http://contributor-covenant.org -[version]: http://contributor-covenant.org/version/1/4/ diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/README.md deleted file mode 100644 index 4b2af12..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/README.md +++ /dev/null @@ -1,5 +0,0 @@ -# OAI object model [![Build Status](https://ci.vmware.run/api/badges/go-openapi/spec/status.svg)](https://ci.vmware.run/go-openapi/spec) [![Coverage](https://coverage.vmware.run/badges/go-openapi/spec/coverage.svg)](https://coverage.vmware.run/go-openapi/spec) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) - -[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/spec/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/spec?status.svg)](http://godoc.org/github.com/go-openapi/spec) - -The object model for OpenAPI specification documents \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/bindata.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/bindata.go deleted file mode 100644 index 294cbcc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/bindata.go +++ /dev/null @@ -1,274 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 go-bindata. -// sources: -// schemas/jsonschema-draft-04.json -// schemas/v2/schema.json -// DO NOT EDIT! - -package spec - -import ( - "bytes" - "compress/gzip" - "fmt" - "io" - "io/ioutil" - "os" - "path/filepath" - "strings" - "time" -) - -func bindataRead(data []byte, name string) ([]byte, error) { - gz, err := gzip.NewReader(bytes.NewBuffer(data)) - if err != nil { - return nil, fmt.Errorf("Read %q: %v", name, err) - } - - var buf bytes.Buffer - _, err = io.Copy(&buf, gz) - clErr := gz.Close() - - if err != nil { - return nil, fmt.Errorf("Read %q: %v", name, err) - } - if clErr != nil { - return nil, err - } - - return buf.Bytes(), nil -} - -type asset struct { - bytes []byte - info os.FileInfo -} - -type bindataFileInfo struct { - name string - size int64 - mode os.FileMode - modTime time.Time -} - -func (fi bindataFileInfo) Name() string { - return fi.name -} -func (fi bindataFileInfo) Size() int64 { - return fi.size -} -func (fi bindataFileInfo) Mode() os.FileMode { - return fi.mode -} -func (fi bindataFileInfo) ModTime() time.Time { - return fi.modTime -} -func (fi bindataFileInfo) IsDir() bool { - return false -} -func (fi bindataFileInfo) Sys() interface{} { - return nil -} - -var _jsonschemaDraft04JSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xcc\x57\x3b\x6f\xdb\x30\x10\xde\xfd\x2b\x04\xa5\x63\x52\xb9\x40\xa7\x6c\x45\xbb\x18\x68\xd1\x0c\xdd\x0c\x0f\xb4\x75\xb2\x19\x50\xa4\x42\x51\x85\x0d\x43\xff\xbd\xa4\xa8\x07\x29\x91\x92\x2d\xbb\x48\xb4\xc4\xe1\xbd\xbe\x3b\xde\x8b\xe7\x45\x20\xbf\x10\xc7\xe1\x73\x10\x1e\x84\xc8\x9e\xa3\xe8\x35\x67\xf4\x29\xdf\x1d\x20\x45\x9f\x19\xdf\x47\x31\x47\x89\x78\x5a\x7e\x8d\xf4\xd9\x43\xf8\xa8\x85\x3e\xe9\xff\x67\x48\xc6\x90\xef\x38\xce\x04\x66\x54\x49\x7f\x67\x1c\x02\xcd\x12\xa4\x20\x50\xad\xa2\xe3\x4e\x30\xc5\x8a\x39\x97\xdc\x1a\x71\x45\xd0\x6c\xdf\x38\x47\x27\x8b\x50\x11\xc5\x29\x03\xa5\x1c\x55\xe4\x47\x9b\x98\x62\xba\x12\x90\x2a\x7d\x5f\x7a\x24\x5c\x9f\x9f\xa5\x83\x1c\x12\xa5\xe2\x21\x0c\xca\x96\xa9\xec\xf8\xc3\x8c\xe5\x12\xd7\x5f\x58\x51\x01\x7b\xe0\x7e\x10\xb8\x66\x18\xc2\xc0\x69\x91\x4a\x8e\xe5\x25\xfa\x7f\x40\x82\x0a\x22\x96\x43\x3b\x88\x90\xdf\x0a\xea\xda\x82\x1d\x19\x91\x8b\xfa\x58\xa5\x21\xc5\x1c\x6b\x9d\x0a\x42\x50\x06\x1b\x27\x8c\x1c\xa7\x19\x81\x3f\xd2\x97\x7c\x68\x1a\x68\xe5\xc0\xba\x8d\x74\x10\x6e\x19\x23\x80\xa8\xfa\xd9\x3a\x1e\x84\xb4\x20\x44\xff\x4d\xb7\xfa\x84\x6d\x5f\x61\x27\xd4\xaf\x5c\x70\x4c\xf7\xa1\xcf\x7e\x45\x9d\x73\xcf\xc6\x65\x36\x7c\x8d\xa9\xf2\xf2\x94\x28\x28\x7e\x2b\xa0\xa1\x0a\x5e\x40\x07\x73\x61\x80\x6d\x6d\x34\x8e\xe9\xd3\x8c\xb3\x0c\xb8\xc0\xbd\xe8\xe9\xa2\xf3\x78\x53\xa3\xec\x01\x49\x18\x4f\x91\xba\xab\xb0\xe0\x38\x74\xc6\xaa\x2b\xca\x7b\x6b\x16\x58\x10\x98\xd4\xeb\x14\xb5\xeb\x7d\x96\x82\x26\x4b\xcf\xe6\x71\x2a\xcf\xb0\x4c\xcd\x2a\xf7\x3d\x6a\x9b\x74\xf3\x56\x5e\x8f\x02\xc7\x1d\x29\x72\x59\x28\xbf\x5a\x16\xfb\xc6\x4d\xfb\xe8\x58\xb3\x8c\x1b\x77\x0a\x77\x86\xa6\xb4\xb4\xf5\x64\x93\xbb\xa0\x24\x88\xe4\x1e\x84\xad\x13\x37\x21\x9c\xd2\x72\x0b\x42\x74\xfc\x09\x74\x2f\x0e\xbd\x9e\x3b\xd5\xbc\x2c\x1f\xaf\xd6\xd0\xb6\x52\xbb\xdf\x22\x21\x80\x4f\xe7\xa8\xb7\x78\xb8\xd4\x7d\x74\x07\x13\xc5\x71\x05\x05\x91\xa6\x91\xf4\x7b\x38\x3d\xe9\x1e\x6e\x1d\xab\xef\x3c\x0c\x74\xbf\x7d\xd5\x6c\xce\x89\xa5\xbe\x8d\xf7\x66\xce\xee\xd1\x86\x67\x80\x34\xad\x8f\xc3\xb3\xae\xc6\x1c\xe3\xb7\xc2\x96\xd9\xb4\x72\x0c\xf0\xab\x92\xe9\x5a\x05\xee\x5c\xb2\x87\xc6\x7f\xa9\x9b\x17\x6b\xb0\xcc\x75\x77\x96\x16\xb7\xcf\x1c\xde\x0a\xcc\x21\x1e\x53\x64\x0e\x73\x4f\x81\xbc\xb8\x07\xa6\xe6\xfa\x50\x55\xe2\x5b\x4d\xad\x4b\xb6\xb6\x81\x49\x77\xc7\xca\x68\x1a\x90\x67\xd7\x78\x3f\x3c\xba\xa3\x8e\xdd\xe8\x7b\xc0\x8a\x21\x03\x1a\x03\xdd\xdd\x11\xd1\x20\xd3\x46\x72\x55\x7d\x93\x0d\xb3\xcf\x34\x52\x46\x03\xd9\x8d\x75\xe2\x0e\x42\xbd\xb9\xdf\xe9\xdd\x34\xb6\x24\x9b\x5b\xa4\x56\x3f\x6b\xac\xd8\x01\x30\x1e\x25\xce\x3a\x77\xc6\x73\xd4\xbd\x96\xc9\xf5\x06\xbc\xca\xf8\x44\xb0\x2e\x09\x5a\xf3\xf5\x3a\x94\x7b\xb7\xa8\x9f\x7f\x17\x8e\x58\x53\xb2\x0e\xfc\xf5\x92\x8c\xc2\x4c\x49\xca\x84\xe7\x7d\x5d\xb6\x2f\x7e\x4f\x79\xba\x96\xe6\x75\xb7\x87\x9b\x0d\xdc\xb5\xbd\xae\xbb\x85\xb8\x8e\x64\x67\xd1\xe8\x18\xe5\xe2\x5f\x00\x00\x00\xff\xff\x4e\x9b\x8d\xdf\x17\x11\x00\x00") - -func jsonschemaDraft04JSONBytes() ([]byte, error) { - return bindataRead( - _jsonschemaDraft04JSON, - "jsonschema-draft-04.json", - ) -} - -func jsonschemaDraft04JSON() (*asset, error) { - bytes, err := jsonschemaDraft04JSONBytes() - if err != nil { - return nil, err - } - - info := bindataFileInfo{name: "jsonschema-draft-04.json", size: 4375, mode: os.FileMode(420), modTime: time.Unix(1441640690, 0)} - a := &asset{bytes: bytes, info: info} - return a, nil -} - -var _v2SchemaJSON = []byte("\x1f\x8b\x08\x00\x00\x09\x6e\x88\x00\xff\xec\x5d\xdf\x73\xdc\xb6\xf1\x7f\xcf\x5f\x81\xb9\x78\x46\xf6\x24\xd6\x39\xfe\x7e\x5f\xea\x97\x8c\x1a\x39\x89\x5a\xbb\xd2\xf8\x9c\xf6\xc1\x95\x67\x70\x24\x4e\x87\x84\x3f\x2e\x04\x29\xe9\xea\xea\x7f\xef\x02\xfc\x71\x04\x01\x90\x20\x89\x3b\x9d\x6d\x7a\xa6\x8d\x8e\x04\x16\x8b\xc5\x62\xf7\xb3\x0b\x10\xf8\xf4\x0d\x42\xb3\x94\xa6\x01\x99\xbd\x42\xb3\x33\xf4\xb7\xc5\xe5\x3f\xd0\xc2\x5b\x93\x10\xa3\x55\x9c\xa0\xc5\x1d\xbe\xb9\x21\x09\x7a\x79\xfa\x02\x9d\x5d\x5d\x9c\xce\xbe\xe7\x15\xa8\xcf\x4b\xaf\xd3\x74\xf3\x6a\x3e\x67\x79\x91\x53\x1a\xcf\x6f\x5f\xce\x99\xa8\x7b\xfa\x3b\x8b\xa3\x6f\xf3\xc2\x4f\xf2\x47\xb5\x1a\xfc\xe5\xf3\xa2\x60\x9c\xdc\xcc\xfd\x04\xaf\xd2\xe7\x2f\xfe\xbf\xa8\x5c\xd4\x4b\xb7\x1b\xc1\x54\xbc\xfc\x9d\x78\x69\xfe\x2c\x21\x7f\x66\x34\x21\xbc\xf9\x0f\xf0\x1b\x9e\x14\xad\x8b\xd7\x9c\xb3\x68\x15\x97\x7f\x6f\x70\xba\x66\x33\xf8\xfb\x5a\xd4\xc5\xbe\x4f\x53\x1a\x47\x38\xb8\x4a\xe2\x0d\x49\x52\x4a\x18\xd0\x59\xe1\x80\x11\x51\x00\xca\xa7\x24\x89\xa4\xb7\x9f\x72\x52\x1f\xef\x9f\x57\x3f\x78\x97\x12\xb2\xe2\xac\x7d\x3b\xf7\xc9\x8a\x46\x82\x2c\x9b\xdf\x92\xc8\x8f\x93\xd7\xf7\x29\x89\x18\x3c\x98\x89\xd2\x0f\xf0\xff\x0f\x39\x79\x0d\xdd\x92\xfb\x1a\xed\xb2\xdb\x2c\x4d\x68\x74\x53\xf4\x05\x9e\x93\x28\x0b\xab\x6e\x8b\x27\x30\x26\xb3\xe2\xd7\x75\x55\xcc\x27\xcc\x4b\xe8\x86\x73\xc4\xa9\xbc\x5f\x93\x6a\x0c\x6f\x49\xc2\xf9\x42\xf1\x0a\xa5\x6b\xca\x90\x1f\x7b\x59\x48\xa2\xf4\xb4\xe0\xb4\x2e\xc2\xce\xce\x8a\x52\x52\xbd\x75\xcc\x52\x9b\x8e\x14\x62\xe6\xaf\x3e\x7e\xf8\xf8\xe9\x61\x8e\x5e\xfd\x1b\xfe\x5d\x7f\xf7\xf4\xc7\x57\xf0\x97\xff\xdd\xb3\x1f\x9f\xcc\xda\xfa\xc3\x1b\x42\x4f\x23\x1c\x12\x04\x1a\x4a\x37\xcf\xf2\x1e\x11\xa1\xa0\xe8\xf5\x3d\x0e\x37\x01\x79\x85\x4e\x76\x8a\x79\x22\x73\xba\xc4\x8c\x5c\x81\x72\xf4\xe5\x76\xde\xca\x16\xa7\x8a\xb8\xce\xa1\x34\xd6\xb1\x33\xc7\x1b\x7a\xd2\x90\xb5\x50\xf8\x9a\x42\x18\xc5\x5d\x14\x7c\x43\x41\xc6\x12\x05\x0f\xde\x66\x0d\x12\x0d\xe6\xce\x50\x00\xd5\xb8\x90\xde\x5e\xbc\x7d\x8d\x78\x4f\x19\xc2\x9e\x47\x36\x29\xf1\xd1\x72\x5b\x31\xbb\xeb\x9e\x9e\x89\x90\xf8\x14\xbf\x87\xea\x2a\x1b\xa0\xdc\x7e\xe6\xf5\x67\xa3\x68\x1a\x79\x38\x42\x05\x8d\x51\x6c\x88\x29\xdf\x29\xcd\xca\x32\xec\x6a\xd6\x5e\x77\xd7\xaf\x17\x6e\xb4\x9f\x80\x5a\x82\xc2\x58\x31\x51\x94\x3d\x37\x51\x4b\x08\xdb\xc0\x43\x1b\xfd\x28\x8b\x1a\x69\x31\xe2\x65\x09\x4d\xb7\x16\xaa\x56\x96\xd4\xd6\x3f\xef\x23\x27\x5d\x25\x89\x6a\x8a\x6f\x98\x6e\x16\xe2\x24\xc1\xdb\x9d\x1e\xd0\x94\x84\xf5\x72\xc6\x06\x81\x5e\x69\x12\x1f\xaa\xda\x59\x44\xff\xcc\xc8\x45\x41\x23\x4d\x32\x22\xf1\x40\xee\xf9\x04\xc7\xc1\x79\xec\x59\x74\x49\x2a\xdd\xb0\xf0\x3a\x1d\x52\xcc\xa9\xc6\xad\xe9\x66\xcb\x2f\x24\x22\x09\x0e\x10\xaf\x9e\x84\x98\x3f\x46\x78\x19\x67\xa9\x66\xb6\x2a\x5e\x51\x3c\x2d\xcc\x7d\x55\xac\x72\xf4\x8a\xcf\xe8\xf2\x8c\xe5\xd4\x32\x78\x47\xf1\x5a\xf6\x90\x2d\x02\xd4\x7a\xc9\x52\x8e\xf2\xc0\x69\x3c\x66\xad\x1b\x8d\xd6\x0c\x06\x5c\x27\xdb\x33\x94\xab\x04\xc2\x91\x0f\x56\x87\x78\x14\x2c\xb7\x20\x5a\xf7\x24\x35\xce\xbe\x57\xa5\x3a\xa6\x75\x06\x20\x27\x4a\xa9\x57\x79\x64\x70\xed\x4b\x70\xd0\x9d\x8d\xcb\x94\x86\x33\x10\xc4\x11\x07\x04\xb5\xe7\x92\x0b\x5d\xac\xe3\x2c\x00\xcf\x40\x90\x4f\x57\x2b\x92\x00\x46\x40\xab\x24\x0e\x45\x09\x21\xa7\x53\x84\x7e\xa1\xe9\xaf\xd9\x12\xfd\x1c\xe0\xdb\x18\x74\x0f\xbd\xc5\xc9\x1f\x7e\x7c\x17\x21\x40\x16\x38\x08\xe2\x3b\xe2\x1b\x7a\x01\x6a\x14\xb2\xcb\xd5\x82\x24\xb7\xd4\x1b\x33\x8e\xdc\xeb\x0a\x62\x9c\x7b\x96\x93\x13\xa8\xb5\x5d\x8a\xe0\x32\x53\xec\xa5\x76\xea\x5a\x16\xd6\x52\x0a\xa0\x41\x30\xba\x76\x94\xca\xc2\xaa\xc2\x37\x1d\x7a\x83\x3b\x5b\x93\xf1\x53\x5e\x53\x32\x19\xa5\x34\x60\x60\x40\xd7\x24\x0d\xeb\x39\xfd\x0d\x73\x91\xc3\xb0\x91\x43\x48\x7d\x50\x30\xba\xda\x42\x59\x94\xa3\xba\x9c\xcb\x42\x12\x08\xda\x85\x80\x61\x0e\x91\x02\x8e\xe8\x7f\x44\xbf\x0c\x23\x9b\x25\xc1\x48\x5e\x7e\x7b\xf7\x06\x6d\x62\x0a\xfc\x00\x33\x05\x8e\xf3\x54\xb9\x9e\xca\x84\xf2\xe7\x9c\x06\xb8\x3b\x3d\x6b\x30\xe5\xe9\x58\xe6\x04\x0d\x04\xc3\x05\xde\x9e\x59\x49\xc9\xc0\x65\xce\x4c\x9b\xe5\x3d\x98\xb1\x97\x74\x5f\x9d\x4f\x46\xdd\xd7\xfb\x3c\xa1\x8d\x03\xfd\xdb\xfe\x14\xbc\xae\xd4\x45\x17\x05\xfc\x3d\x45\x17\xe9\x09\x43\x24\xf2\xe2\x2c\xc1\x37\x60\x44\x41\xe3\x32\xc6\xfd\x12\xba\x5c\x00\x28\x8e\x43\x18\x08\xba\x0c\xaa\x6a\x07\xd5\xfb\xaa\x4d\x2b\x5d\x3f\x16\x1d\x52\x42\x00\x4b\xeb\xf9\x8e\x04\x20\xeb\xdb\x3c\x84\x63\xa5\x0c\x68\xe4\xd3\x5b\xea\x67\x80\xc4\x80\x0d\x21\x21\x76\x8a\x40\x62\x5b\x14\x66\x10\xcd\x80\x8f\x4c\xca\x8a\x45\x95\x93\x32\xbc\x3c\x39\x55\xc2\xc8\x3d\x0a\xa3\xa6\x0e\x10\xa8\x5a\x11\xe3\x3d\xe5\xb0\xb8\x6d\x14\xdb\xe6\x8e\x4d\x00\x65\x92\xbe\x81\x6e\x27\xc2\x2f\x92\x49\x0a\x9f\x8d\xd1\xbc\x8c\x44\x72\x20\x04\x68\x92\xe7\xb4\xf2\xf6\x59\x81\x79\x96\x42\xcd\x61\xb0\x72\x72\x0c\xc6\x91\x3f\x29\x82\x69\xbf\x00\x86\x22\x1c\x95\x23\xe4\x86\xaa\x69\x22\xb8\x3d\xf6\xbd\x6a\xaf\x7f\xf7\x13\x02\x38\x97\x81\x9f\x15\x8e\x81\x09\x5c\x50\x0b\x56\xa5\x6e\xe9\x62\xc9\x3d\xf6\xaa\x6c\x6e\xbf\x9d\x32\x45\x79\x3d\x7b\x23\xfb\x8c\x06\x83\x6a\xac\x56\xb6\x5a\xe5\xda\xc4\xcb\x2e\x2f\xc6\xcd\xb9\xe2\xc4\x4c\xfe\xc9\x3e\x26\x70\xe1\x3a\x8e\xdd\xfa\x93\x3c\xdd\x36\x66\x88\x95\x04\x41\x48\x43\xf2\x3e\xa7\xd1\x99\x2e\xd4\xb8\xd6\x2a\xdb\x55\x42\x80\x5f\xdf\xbf\xbf\x42\x21\x40\x38\x70\xf9\x0d\x8b\xc2\xd9\xc0\x8d\xa1\xec\x09\x81\x76\x49\xa3\x81\x38\xe8\x88\xe2\x7c\x39\x3b\x24\x09\x43\xce\x10\x89\x57\x6a\x96\x48\x37\x54\xb5\x97\x0f\x52\x75\x43\x9a\xa8\x51\x70\x06\x0e\x22\xc4\xc9\x76\x54\xfc\xbd\x4c\x28\x81\x88\x35\xa7\x54\xaa\x45\x35\xf6\x8f\x16\xfc\x57\x1c\x7c\x3f\x22\xba\x37\x18\x5a\xf1\xce\x36\xa5\xd6\xa4\x59\x31\x76\xe1\xbb\x48\xfb\x14\x01\x27\xdd\xa5\x5c\xba\x64\xaf\x49\x6f\x1b\x84\xdb\x33\xc5\xdd\x22\x16\x4d\x9a\xbb\xc9\x96\x26\xf9\x3f\x88\xad\x82\x8e\x2b\xb6\xb4\x59\xf0\x16\x92\xbb\xf2\x66\x9a\xba\x5c\x78\x0b\x49\xc5\x0a\x36\x26\xb1\xb2\xee\xd2\x42\x4b\x59\x7b\x69\x52\xf3\x39\x0e\xf1\x70\x4a\x8c\xda\xb9\x8c\xe3\x80\xe0\xa8\xa9\x9e\x2b\x9c\x05\xa9\x84\xa6\x15\x46\xd5\xb4\x7d\x1b\xa7\x52\xea\x5e\xd0\x32\xc6\x48\x02\xf8\xbb\x02\x42\x47\xe4\x34\x0a\xc2\xbd\x81\xd0\x0d\xb1\xcc\x08\xee\x7c\xb4\x5e\xf9\x33\x47\x74\xe4\xe5\xd4\xe1\x84\x7c\x12\xc0\xdc\x72\x42\x2a\xde\x34\xa3\x81\xe1\xb4\xd6\x04\x2b\xd3\x65\x98\xa0\x70\xea\xad\x1d\x51\x72\x64\xb7\xb4\x93\x4e\xbb\x9a\x67\x9d\x9c\xc8\xeb\x56\x61\x2c\x4f\x29\x31\x61\xbb\x09\x05\x4b\x9e\xf0\x44\x04\x8e\xb6\xe8\x16\x07\xd4\xcf\x11\x26\x83\x60\x23\x83\x32\xb1\x2f\xc2\xa6\x93\xc2\xdc\xd4\xb3\x12\x21\x95\xa7\xec\x0f\x6e\x67\xfd\xd3\x0f\x2f\x9e\xff\xe5\xfa\xd3\xff\x3d\x3c\x7b\xf2\xdf\x8f\x4f\x8b\xf6\x9f\x3d\xe9\x67\xc1\xff\x89\x83\x8c\x18\xf2\x1c\x7b\x30\x2b\x51\x9c\x36\x40\xa8\x7e\x84\x2c\x65\xd4\x29\x25\x6d\x37\xfa\x77\x64\xd7\x95\x2e\xf5\xcb\xe5\x59\x53\xc1\x38\x22\x97\x2b\x29\x86\xe8\x31\x3a\xda\x81\xb1\xa8\xcf\xb7\x00\xbd\x23\x62\x6d\xc9\xd3\x2c\x89\x5c\x6b\x59\x1f\x1e\x14\xd5\xa7\x53\xd9\xc4\xbe\x23\xeb\x6a\xdb\x93\x54\x53\x95\x76\x53\x62\x2d\x52\x93\x93\x5f\x4a\x93\x3d\x28\xad\x68\x40\x16\x3a\x6a\xb5\x5f\xd7\x46\xbb\x6d\x6d\x21\xcb\xc2\x86\x48\x41\x89\xd5\x5b\x48\x55\xa5\x5b\x26\xef\x91\x61\x15\x49\x89\x55\xb9\x39\xcf\xa4\xe5\x4d\xcc\x5a\x9a\x77\x06\xf8\xf4\xd3\x4c\x90\xb4\x9e\x5f\xa9\x9c\x53\x91\x98\xd2\x85\x73\xca\x0e\x38\xf1\x54\x53\x92\x9b\x71\xb1\xa2\xde\x7c\x4a\xa3\x94\xdc\xa8\x8f\x75\xe8\x1c\x95\x29\x86\xce\x09\x51\xa5\xc4\x7a\x5b\x08\x5d\xc2\xc2\x04\x35\x12\x1a\x52\xbe\xca\xc0\xf2\x04\x85\x96\x9e\x17\x07\x01\x0c\x25\x54\xf8\x59\xcb\x93\x69\x85\xbb\x51\xcb\x80\x22\xcb\x60\xc5\x82\x64\x59\x58\x4b\x29\xc4\xf7\x34\xcc\x42\x3b\x4a\x65\x61\x83\x01\xf1\x82\x8c\x81\x50\xde\xf6\x21\xa9\xd4\xd2\x73\x09\xe5\xed\xb9\x2c\x0a\x77\x70\xd9\x87\xa4\x52\xcb\x24\xcb\x37\x24\xba\x49\x2d\xf1\xef\xae\xb8\xa9\xcf\xbd\xa8\x55\xc5\x4d\xb8\xbc\xd8\x39\x69\xb7\x14\x25\x0a\x9b\x7a\x79\x61\x3f\x55\xaa\xd2\xa6\x3e\xf6\xa1\x55\x96\xd6\xd2\x92\x33\x86\x16\xe4\xea\x15\xf4\xba\x12\x59\xeb\x47\x64\xd4\x09\x98\x79\x14\x3c\xe5\xa5\x12\x06\x1b\xfa\xb8\x2b\x6f\x98\xf9\xfd\x61\x90\xe2\x99\x1f\xc9\xe9\x36\x8b\xb7\xec\x4e\x85\xe0\xa9\x70\x54\x5b\x1e\x3a\x25\x62\x25\xfc\x0e\x82\x2b\x74\xff\x9c\x67\x3d\x45\x64\xd5\xbd\x6b\x86\xe7\x8d\x35\x65\x8c\xbb\x0f\x97\xb1\xbf\xbd\xaa\xd6\xf5\xc6\x6d\x7c\xa8\xbb\x16\x69\xdf\x9f\x8c\x1b\xaf\x8f\x31\x6d\xe3\x2a\xbb\x9d\xa7\xd6\x35\xc9\xed\x2a\x58\xe7\xcb\xf7\x94\xc7\xc5\x7c\x8f\x9b\xd8\x3d\x43\x21\x8a\x2e\xd0\x25\x2f\x9d\xb1\x71\xfb\xdb\x1c\xef\x18\xd9\x31\x6e\x40\x11\x63\x04\x76\xce\x09\x83\x95\x2b\x12\xc2\x41\xec\x61\xbd\xd0\x6c\xa0\x18\xd7\xe5\x6e\xbc\x54\x53\xe0\x3e\xb9\x52\x13\xdb\x77\x6b\x22\x12\x20\x71\x82\x20\x76\xcf\xbf\x6c\xa8\xd8\xe6\x83\x55\xb6\xc7\x4b\xe4\x09\x2c\x1c\x9c\x0e\xc8\xc4\x6a\xc3\x39\xbb\x38\x6d\xc4\xb6\x8a\x1c\xb7\x57\x16\x62\x91\x2d\x17\x4d\x46\x8e\x2d\xec\xe9\x9c\xeb\x9f\xa9\x06\x1c\xcf\x44\x93\x03\x3d\xfe\x4f\x3f\xd5\x26\xa3\x3a\xd4\xa8\x1e\x3e\x36\x35\x04\xa1\x86\x90\x75\x8a\x4d\xa7\xd8\x74\x8a\x4d\x5b\x7b\x3d\xc5\xa6\x5f\x68\x6c\xfa\x4d\xfd\xbf\x25\x4e\x02\xde\x93\xed\x04\x93\x26\x98\x54\x7b\x2a\x74\x62\x42\x49\xfb\x43\x49\x82\x99\xd7\xe1\x26\xdd\x36\x57\x15\xa5\x96\x6d\x76\xbf\xb4\xb1\x25\x9a\x61\x88\xc1\x94\xe2\x49\x19\x5c\x53\xdb\xe5\xb6\x60\x38\x0a\xb6\x5c\x6f\x45\xc2\x86\xaf\x8a\x73\xa6\x78\xce\x26\x33\x7d\x33\x31\x21\xbc\xa3\x44\x78\xff\x82\x01\x7c\xcb\xad\xfe\x04\xf5\xd0\x04\xf5\x26\xa8\x37\x41\x3d\xd4\x84\x7a\xdc\xe4\x9d\xe3\x14\x4f\x68\x6f\x42\x7b\xb5\xa7\xa5\x5a\x4c\x80\x6f\x02\x7c\x3a\xde\x3f\x0f\xc0\xd7\x78\xc8\xf7\x69\x4d\x20\x10\x4d\x20\x70\x02\x81\x5d\xbd\x9e\x40\xe0\xd7\x04\x02\xf9\x27\x2c\x9f\x27\x00\x34\x7d\xb6\x59\x3c\x2d\x1e\x75\x6f\x9f\x1c\x04\x18\xb5\x4e\x4d\xfa\xd6\xb1\xd6\xb4\xa8\xe1\x1c\x62\x1e\x39\x8c\xe4\x8a\x35\x41\xc8\x69\x65\xb5\xfa\xf7\x75\x40\xae\x09\x69\xa1\x09\x69\x4d\x48\x6b\x42\x5a\xa8\x89\xb4\xa2\x38\xfa\xeb\x21\x36\xa9\xea\x3f\x1e\x19\xf4\x75\x9a\x71\xd3\x9c\x4e\x74\x16\xf4\x5a\x32\x8e\x03\x29\x9a\x96\xab\x07\x92\x33\xa0\x61\x65\x64\xaf\x1b\x18\x5a\x33\xa4\x83\x04\x2e\xef\x62\x1e\xd8\x09\x45\xd1\x3a\xd8\x57\x76\x64\xda\x7e\x4d\x7b\x06\x80\x2b\x47\x8c\x94\xd5\x8f\xe1\x04\x04\x83\xa5\x13\xd0\x73\x3a\x07\x3d\xc6\x4b\x09\x17\x5c\x7f\xe7\x3e\x1c\xb8\x68\x8f\x5d\x2d\xfb\x67\x79\xb4\xfb\x7c\xd7\x9d\xb9\x74\x1a\xad\x35\xbc\x1e\xd1\xa0\xe6\x2b\xd0\x5e\x70\x67\x50\x93\x6d\x98\xa8\xd3\x66\x0f\x68\xb1\xeb\x73\x8e\x0e\x20\x36\xa4\x45\x17\x68\x6d\x40\xbb\x4e\x20\xdd\x90\xfe\xba\xc0\x7d\xa3\xfa\x3b\x0a\x1c\xda\xb6\x2c\xf9\x97\x98\x89\x38\xe4\xa2\x88\x99\x86\x01\x49\x07\x2d\x9f\xe7\xf3\xe9\xc5\x20\xf0\x39\x40\xe6\xa3\x10\xea\x3e\x25\xbd\xef\x86\xdb\x05\x6d\x81\x81\x07\x08\xbb\x13\x28\x83\xc0\xcd\xc7\x28\x1c\x42\xea\x07\x69\xbd\x5d\xf4\xa6\xb4\xdf\x18\x06\x72\xaf\x7f\x26\x67\x3e\x6c\x23\x94\x21\x96\xcc\x18\xc6\x74\x7e\xfa\xce\xcb\x44\xdb\xc3\x1e\xa1\xd0\xcc\xa8\xca\x95\x6b\xbf\x9a\x99\xd3\x0a\x4d\x3c\xe8\x01\x95\x26\x15\x36\x06\x4f\xd5\x02\x28\x8b\x94\xd3\xa3\x89\x51\xb7\xd0\x29\x1b\xb5\x1f\x94\x97\xfa\xb3\xfd\x7a\x32\x28\x0f\xd6\xa8\xa1\xc3\x41\xa0\xa2\xb6\x96\xb3\x09\x4d\x9d\x33\x1d\x5a\x68\xdb\x29\x3d\x77\x86\x98\xc1\x1c\x21\xe5\x7d\xea\x9e\x7b\x7d\x38\xeb\x27\x50\x9f\x72\x6c\x0e\x62\xc2\x69\x9c\x0c\x89\x4e\x12\x88\xf9\x2f\xa3\xc0\x78\x30\xe3\xe0\x23\xd8\xee\x43\xe5\x84\x54\xbd\x0c\x78\x41\x03\x26\x74\x7f\x24\x62\xb1\x02\x50\x17\xe8\x2e\x66\xb4\xfe\xba\xb0\x76\x0c\xcc\x17\x1e\x46\xbb\x38\xb0\x64\x0a\x9d\x8f\x26\x74\x7e\x14\x14\xe4\x66\xe9\xca\x6e\x4b\xcf\xde\xcc\xd9\xf1\x1a\xa3\xe6\x6a\x97\x85\x45\x1a\x75\xb3\xc3\x74\xfe\xd0\xb4\x12\xd9\x45\x69\x5a\x89\x9c\x56\x22\xa7\x95\xc8\xc7\x5b\x89\x7c\x04\xc8\x28\xf9\x24\xdd\xb5\x89\x63\x2f\x29\x2c\x69\xbe\xcb\x31\x0c\xbf\x16\x62\xa6\xf4\xb7\xe3\xd2\x42\x1d\x8d\xe1\xfe\x52\x75\x8a\x4a\x0c\xab\x77\x16\x56\x37\x4c\x98\xce\xd5\x97\x25\x2d\x87\x59\xfb\xf1\xf8\x16\x5b\x9d\xb4\x5d\x10\xa7\xed\x6e\x70\xe7\x65\x75\x7a\x3b\x04\x4a\x40\xef\x87\xd4\x04\x95\x4f\xe8\x32\x53\x0f\x6f\x1e\x0d\x02\xef\x12\xbc\xd9\xb8\x3a\xae\xfc\x58\xe6\x2a\xbf\xfc\xd3\x95\x06\xf5\xb9\x5e\xcc\xb5\xb6\x8d\x3c\x77\xd6\x19\xc0\x3f\x96\x71\xed\xb8\x7a\x76\xb8\xad\xd3\x9d\xc5\x6b\x95\xed\x5a\x62\x46\xbd\xb3\x2c\x5d\xf3\x7b\x24\xf2\xcd\xa6\x0b\xe5\xe8\xfd\x46\x0a\xcc\x8a\x30\xde\xd0\xbf\x93\xad\x1b\x5a\x31\x06\x06\x5f\x5e\x40\x60\x46\x3d\x9a\xba\xa4\x79\x85\x19\xbb\x8b\x13\xdf\x25\xcd\xb3\x0d\xe7\xd3\xa1\x28\x0b\xb2\x9e\x47\x18\xfb\x29\xf6\x89\x96\x6a\xf5\xf7\xb5\x56\xf3\xda\xc6\x79\xbf\x96\xe6\x31\x4e\xd2\x15\xbd\x75\xb9\xf5\xf9\xf8\x4c\x49\x63\x7e\x1d\x60\x0c\x1b\x28\xa2\xb1\xfd\xed\xc0\x23\x9c\x77\xbf\x7b\x88\x87\x7a\xae\x7e\xbb\xf8\x5b\xcf\x36\x6b\xe4\x42\x9c\x1f\xe5\x71\x7c\xba\x69\xb0\xd7\x87\xd5\xd1\x55\x10\xdf\x49\x77\x1c\x00\x4f\x71\x52\xdc\x27\xfb\x5b\x9f\x7b\xe9\xdc\x68\x6c\x2e\x14\x8b\x24\x18\xe7\x7b\x74\x6b\xb4\x10\x7e\x77\x7b\xcc\x83\x5e\xdb\x5e\x84\x22\xfa\xb0\xc8\x6b\x68\xa9\x29\x52\xee\xd1\x13\x8b\xbb\x87\x3f\xff\x59\xa1\x20\x8e\xc7\x9d\x15\x69\xfc\x07\xf9\xf2\x67\xc3\xa6\x10\xfa\xa1\x67\x43\x25\xdd\x69\x16\xc8\xb3\x40\x87\x91\xa7\x89\x50\xb4\xbc\xc7\x89\x80\x77\x72\x9f\xe6\xc2\xb1\xcc\x05\x35\xb0\x3b\x32\xa4\xf4\xf5\x4d\x93\x6a\x48\xbe\x30\xfc\x34\x4d\x42\xa4\x9f\x84\x8b\xe6\x28\x3a\x58\x78\x90\xbb\x2c\xb7\x2a\xdf\x3d\xea\x70\x49\xa6\xba\xe2\x59\x91\x6f\xc7\x3a\x4c\xe3\x0a\xc0\x6e\x96\x34\x5f\x4f\xef\x68\xa0\x88\x10\x9f\xf8\x28\x8d\xc5\xd9\x37\x08\x17\xf7\xf9\xe5\xf7\xb4\x06\x81\xf6\xfa\x89\x92\x37\xd9\x88\x69\xba\x3e\x38\xdd\xa9\xdc\x3b\x2f\x89\xc8\x9a\x8c\xe1\xce\x37\x6d\x1a\xce\x7a\x1d\xac\x76\x37\xeb\x20\xe1\xa7\x09\x8e\x18\xf0\xc4\x2f\xff\x48\x63\x2f\x0e\xca\xef\xd8\xc5\x75\xff\x6d\xe2\x34\xce\x7e\x9d\x79\x14\x1b\x92\x64\x0b\xc1\x9f\x30\xf9\xd1\x9d\xf2\xbb\x66\xf0\x7a\xcb\xa6\x65\x3b\x86\x89\x79\x95\xf5\x99\xc7\x6e\xa5\xab\x44\xe4\x9f\xa9\xfc\x73\x43\x37\xba\x8b\xc7\x77\x4b\x47\x82\x5c\x2b\x97\xbb\xb3\x7f\x0e\xc5\x6e\xed\x41\x58\x3f\x74\xc8\x8e\xff\xe6\xd6\x3e\x47\xdb\xfa\x4a\xf2\x7a\x27\xe1\x74\x2b\xdf\xae\xa9\xe6\x16\x1b\x67\xdb\xf7\x2a\x03\xae\xdb\x1b\xe0\xf2\x6b\xb7\xaa\x21\x65\x47\x8e\xb3\x2f\xdc\xca\x26\x5a\x76\xff\xb8\xff\xaa\xad\xea\x97\xb2\x87\xc7\xd9\x97\x6c\x6a\xbf\x9c\xb6\xa5\xdf\x50\x54\x1b\x2f\x65\xeb\x8f\xfb\x2f\x7a\x6a\x52\xdc\x6b\x6b\xf2\x17\x3c\x3b\xac\xd0\xdc\x90\xe4\xec\xcb\xb4\x9a\x18\x95\xbd\x93\xfb\x94\xe2\x3e\x1b\xd3\x0b\x51\xbf\xe7\xc9\xe9\x57\x67\xd5\x44\x88\xdc\x29\x7f\xd4\x54\x78\x19\x0c\x59\x20\x68\x7d\x54\x2a\x78\x52\xfc\xd5\xa8\x4d\x32\xbd\x3e\x2c\x97\x61\xfa\x37\xfc\x7f\x0f\xff\x0b\x00\x00\xff\xff\x31\x8b\xeb\xb6\x54\x9c\x00\x00") - -func v2SchemaJSONBytes() ([]byte, error) { - return bindataRead( - _v2SchemaJSON, - "v2/schema.json", - ) -} - -func v2SchemaJSON() (*asset, error) { - bytes, err := v2SchemaJSONBytes() - if err != nil { - return nil, err - } - - info := bindataFileInfo{name: "v2/schema.json", size: 40020, mode: os.FileMode(420), modTime: time.Unix(1446147817, 0)} - a := &asset{bytes: bytes, info: info} - return a, nil -} - -// Asset loads and returns the asset for the given name. -// It returns an error if the asset could not be found or -// could not be loaded. -func Asset(name string) ([]byte, error) { - cannonicalName := strings.Replace(name, "\\", "/", -1) - if f, ok := _bindata[cannonicalName]; ok { - a, err := f() - if err != nil { - return nil, fmt.Errorf("Asset %s can't read by error: %v", name, err) - } - return a.bytes, nil - } - return nil, fmt.Errorf("Asset %s not found", name) -} - -// MustAsset is like Asset but panics when Asset would return an error. -// It simplifies safe initialization of global variables. -func MustAsset(name string) []byte { - a, err := Asset(name) - if err != nil { - panic("asset: Asset(" + name + "): " + err.Error()) - } - - return a -} - -// AssetInfo loads and returns the asset info for the given name. -// It returns an error if the asset could not be found or -// could not be loaded. -func AssetInfo(name string) (os.FileInfo, error) { - cannonicalName := strings.Replace(name, "\\", "/", -1) - if f, ok := _bindata[cannonicalName]; ok { - a, err := f() - if err != nil { - return nil, fmt.Errorf("AssetInfo %s can't read by error: %v", name, err) - } - return a.info, nil - } - return nil, fmt.Errorf("AssetInfo %s not found", name) -} - -// AssetNames returns the names of the assets. -func AssetNames() []string { - names := make([]string, 0, len(_bindata)) - for name := range _bindata { - names = append(names, name) - } - return names -} - -// _bindata is a table, holding each asset generator, mapped to its name. -var _bindata = map[string]func() (*asset, error){ - "jsonschema-draft-04.json": jsonschemaDraft04JSON, - "v2/schema.json": v2SchemaJSON, -} - -// AssetDir returns the file names below a certain -// directory embedded in the file by go-bindata. -// For example if you run go-bindata on data/... and data contains the -// following hierarchy: -// data/ -// foo.txt -// img/ -// a.png -// b.png -// then AssetDir("data") would return []string{"foo.txt", "img"} -// AssetDir("data/img") would return []string{"a.png", "b.png"} -// AssetDir("foo.txt") and AssetDir("notexist") would return an error -// AssetDir("") will return []string{"data"}. -func AssetDir(name string) ([]string, error) { - node := _bintree - if len(name) != 0 { - cannonicalName := strings.Replace(name, "\\", "/", -1) - pathList := strings.Split(cannonicalName, "/") - for _, p := range pathList { - node = node.Children[p] - if node == nil { - return nil, fmt.Errorf("Asset %s not found", name) - } - } - } - if node.Func != nil { - return nil, fmt.Errorf("Asset %s not found", name) - } - rv := make([]string, 0, len(node.Children)) - for childName := range node.Children { - rv = append(rv, childName) - } - return rv, nil -} - -type bintree struct { - Func func() (*asset, error) - Children map[string]*bintree -} - -var _bintree = &bintree{nil, map[string]*bintree{ - "jsonschema-draft-04.json": &bintree{jsonschemaDraft04JSON, map[string]*bintree{}}, - "v2": &bintree{nil, map[string]*bintree{ - "schema.json": &bintree{v2SchemaJSON, map[string]*bintree{}}, - }}, -}} - -// RestoreAsset restores an asset under the given directory -func RestoreAsset(dir, name string) error { - data, err := Asset(name) - if err != nil { - return err - } - info, err := AssetInfo(name) - if err != nil { - return err - } - err = os.MkdirAll(_filePath(dir, filepath.Dir(name)), os.FileMode(0755)) - if err != nil { - return err - } - err = ioutil.WriteFile(_filePath(dir, name), data, info.Mode()) - if err != nil { - return err - } - err = os.Chtimes(_filePath(dir, name), info.ModTime(), info.ModTime()) - if err != nil { - return err - } - return nil -} - -// RestoreAssets restores an asset under the given directory recursively -func RestoreAssets(dir, name string) error { - children, err := AssetDir(name) - // File - if err != nil { - return RestoreAsset(dir, name) - } - // Dir - for _, child := range children { - err = RestoreAssets(dir, filepath.Join(name, child)) - if err != nil { - return err - } - } - return nil -} - -func _filePath(dir, name string) string { - cannonicalName := strings.Replace(name, "\\", "/", -1) - return filepath.Join(append([]string{dir}, strings.Split(cannonicalName, "/")...)...) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/contact_info.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/contact_info.go deleted file mode 100644 index f285970..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/contact_info.go +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -// ContactInfo contact information for the exposed API. -// -// For more information: http://goo.gl/8us55a#contactObject -type ContactInfo struct { - Name string `json:"name,omitempty"` - URL string `json:"url,omitempty"` - Email string `json:"email,omitempty"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/expander.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/expander.go deleted file mode 100644 index eb1490b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/expander.go +++ /dev/null @@ -1,626 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "fmt" - "net/url" - "reflect" - "strings" - "sync" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// ResolutionCache a cache for resolving urls -type ResolutionCache interface { - Get(string) (interface{}, bool) - Set(string, interface{}) -} - -type simpleCache struct { - lock sync.Mutex - store map[string]interface{} -} - -var resCache = initResolutionCache() - -func initResolutionCache() ResolutionCache { - return &simpleCache{store: map[string]interface{}{ - "http://swagger.io/v2/schema.json": MustLoadSwagger20Schema(), - "http://json-schema.org/draft-04/schema": MustLoadJSONSchemaDraft04(), - }} -} - -func (s *simpleCache) Get(uri string) (interface{}, bool) { - s.lock.Lock() - v, ok := s.store[uri] - s.lock.Unlock() - return v, ok -} - -func (s *simpleCache) Set(uri string, data interface{}) { - s.lock.Lock() - s.store[uri] = data - s.lock.Unlock() -} - -// ResolveRef resolves a reference against a context root -func ResolveRef(root interface{}, ref *Ref) (*Schema, error) { - resolver, err := defaultSchemaLoader(root, nil, nil) - if err != nil { - return nil, err - } - - result := new(Schema) - if err := resolver.Resolve(ref, result); err != nil { - return nil, err - } - return result, nil -} - -// ResolveParameter resolves a paramter reference against a context root -func ResolveParameter(root interface{}, ref Ref) (*Parameter, error) { - resolver, err := defaultSchemaLoader(root, nil, nil) - if err != nil { - return nil, err - } - - result := new(Parameter) - if err := resolver.Resolve(&ref, result); err != nil { - return nil, err - } - return result, nil -} - -// ResolveResponse resolves response a reference against a context root -func ResolveResponse(root interface{}, ref Ref) (*Response, error) { - resolver, err := defaultSchemaLoader(root, nil, nil) - if err != nil { - return nil, err - } - - result := new(Response) - if err := resolver.Resolve(&ref, result); err != nil { - return nil, err - } - return result, nil -} - -type schemaLoader struct { - loadingRef *Ref - startingRef *Ref - currentRef *Ref - root interface{} - cache ResolutionCache - loadDoc func(string) (json.RawMessage, error) -} - -var idPtr, _ = jsonpointer.New("/id") -var schemaPtr, _ = jsonpointer.New("/$schema") -var refPtr, _ = jsonpointer.New("/$ref") - -func defaultSchemaLoader(root interface{}, ref *Ref, cache ResolutionCache) (*schemaLoader, error) { - if cache == nil { - cache = resCache - } - - var ptr *jsonpointer.Pointer - if ref != nil { - ptr = ref.GetPointer() - } - - currentRef := nextRef(root, ref, ptr) - - return &schemaLoader{ - root: root, - loadingRef: ref, - startingRef: ref, - cache: cache, - loadDoc: func(path string) (json.RawMessage, error) { - data, err := swag.LoadFromFileOrHTTP(path) - if err != nil { - return nil, err - } - return json.RawMessage(data), nil - }, - currentRef: currentRef, - }, nil -} - -func idFromNode(node interface{}) (*Ref, error) { - if idValue, _, err := idPtr.Get(node); err == nil { - if refStr, ok := idValue.(string); ok && refStr != "" { - idRef, err := NewRef(refStr) - if err != nil { - return nil, err - } - return &idRef, nil - } - } - return nil, nil -} - -func nextRef(startingNode interface{}, startingRef *Ref, ptr *jsonpointer.Pointer) *Ref { - if startingRef == nil { - return nil - } - if ptr == nil { - return startingRef - } - - ret := startingRef - var idRef *Ref - node := startingNode - - for _, tok := range ptr.DecodedTokens() { - node, _, _ = jsonpointer.GetForToken(node, tok) - if node == nil { - break - } - - idRef, _ = idFromNode(node) - if idRef != nil { - nw, err := ret.Inherits(*idRef) - if err != nil { - break - } - ret = nw - } - - refRef, _, _ := refPtr.Get(node) - if refRef != nil { - rf, _ := NewRef(refRef.(string)) - nw, err := ret.Inherits(rf) - if err != nil { - break - } - ret = nw - } - - } - return ret -} - -func (r *schemaLoader) resolveRef(currentRef, ref *Ref, node, target interface{}) error { - tgt := reflect.ValueOf(target) - if tgt.Kind() != reflect.Ptr { - return fmt.Errorf("resolve ref: target needs to be a pointer") - } - - oldRef := currentRef - if currentRef != nil { - var err error - currentRef, err = currentRef.Inherits(*nextRef(node, ref, currentRef.GetPointer())) - if err != nil { - return err - } - } - if currentRef == nil { - currentRef = ref - } - - refURL := currentRef.GetURL() - if refURL == nil { - return nil - } - if currentRef.IsRoot() { - nv := reflect.ValueOf(node) - reflect.Indirect(tgt).Set(reflect.Indirect(nv)) - return nil - } - - if strings.HasPrefix(refURL.String(), "#") { - res, _, err := ref.GetPointer().Get(node) - if err != nil { - res, _, err = ref.GetPointer().Get(r.root) - if err != nil { - return err - } - } - rv := reflect.Indirect(reflect.ValueOf(res)) - tgtType := reflect.Indirect(tgt).Type() - if rv.Type().AssignableTo(tgtType) { - reflect.Indirect(tgt).Set(reflect.Indirect(reflect.ValueOf(res))) - } else { - if err := swag.DynamicJSONToStruct(rv.Interface(), target); err != nil { - return err - } - } - - return nil - } - - if refURL.Scheme != "" && refURL.Host != "" { - // most definitely take the red pill - data, _, _, err := r.load(refURL) - if err != nil { - return err - } - - if ((oldRef == nil && currentRef != nil) || - (oldRef != nil && currentRef == nil) || - oldRef.String() != currentRef.String()) && - ((oldRef == nil && ref != nil) || - (oldRef != nil && ref == nil) || - (oldRef.String() != ref.String())) { - - return r.resolveRef(currentRef, ref, data, target) - } - - var res interface{} - if currentRef.String() != "" { - res, _, err = currentRef.GetPointer().Get(data) - if err != nil { - return err - } - } else { - res = data - } - - if err := swag.DynamicJSONToStruct(res, target); err != nil { - return err - } - - } - return nil -} - -func (r *schemaLoader) load(refURL *url.URL) (interface{}, url.URL, bool, error) { - toFetch := *refURL - toFetch.Fragment = "" - - data, fromCache := r.cache.Get(toFetch.String()) - if !fromCache { - b, err := r.loadDoc(toFetch.String()) - if err != nil { - return nil, url.URL{}, false, err - } - - if err := json.Unmarshal(b, &data); err != nil { - return nil, url.URL{}, false, err - } - r.cache.Set(toFetch.String(), data) - } - - return data, toFetch, fromCache, nil -} -func (r *schemaLoader) Resolve(ref *Ref, target interface{}) error { - if err := r.resolveRef(r.currentRef, ref, r.root, target); err != nil { - return err - } - - return nil -} - -type specExpander struct { - spec *Swagger - resolver *schemaLoader -} - -// ExpandSpec expands the references in a swagger spec -func ExpandSpec(spec *Swagger) error { - resolver, err := defaultSchemaLoader(spec, nil, nil) - if err != nil { - return err - } - - for key, defintition := range spec.Definitions { - var def *Schema - var err error - if def, err = expandSchema(defintition, []string{"#/definitions/" + key}, resolver); err != nil { - return err - } - spec.Definitions[key] = *def - } - - for key, parameter := range spec.Parameters { - if err := expandParameter(¶meter, resolver); err != nil { - return err - } - spec.Parameters[key] = parameter - } - - for key, response := range spec.Responses { - if err := expandResponse(&response, resolver); err != nil { - return err - } - spec.Responses[key] = response - } - - if spec.Paths != nil { - for key, path := range spec.Paths.Paths { - if err := expandPathItem(&path, resolver); err != nil { - return err - } - spec.Paths.Paths[key] = path - } - } - - return nil -} - -// ExpandSchema expands the refs in the schema object -func ExpandSchema(schema *Schema, root interface{}, cache ResolutionCache) error { - - if schema == nil { - return nil - } - if root == nil { - root = schema - } - - nrr, _ := NewRef(schema.ID) - var rrr *Ref - if nrr.String() != "" { - switch root.(type) { - case *Schema: - rid, _ := NewRef(root.(*Schema).ID) - rrr, _ = rid.Inherits(nrr) - case *Swagger: - rid, _ := NewRef(root.(*Swagger).ID) - rrr, _ = rid.Inherits(nrr) - } - - } - - resolver, err := defaultSchemaLoader(root, rrr, cache) - if err != nil { - return err - } - - refs := []string{""} - if rrr != nil { - refs[0] = rrr.String() - } - var s *Schema - if s, err = expandSchema(*schema, refs, resolver); err != nil { - return nil - } - *schema = *s - return nil -} - -func expandItems(target Schema, parentRefs []string, resolver *schemaLoader) (*Schema, error) { - if target.Items != nil { - if target.Items.Schema != nil { - t, err := expandSchema(*target.Items.Schema, parentRefs, resolver) - if err != nil { - return nil, err - } - *target.Items.Schema = *t - } - for i := range target.Items.Schemas { - t, err := expandSchema(target.Items.Schemas[i], parentRefs, resolver) - if err != nil { - return nil, err - } - target.Items.Schemas[i] = *t - } - } - return &target, nil -} - -func expandSchema(target Schema, parentRefs []string, resolver *schemaLoader) (schema *Schema, err error) { - defer func() { - schema = &target - }() - if target.Ref.String() == "" && target.Ref.IsRoot() { - target = *resolver.root.(*Schema) - return - } - - // t is the new expanded schema - var t *Schema - for target.Ref.String() != "" { - // var newTarget Schema - pRefs := strings.Join(parentRefs, ",") - pRefs += "," - if strings.Contains(pRefs, target.Ref.String()+",") { - err = nil - return - } - - if err = resolver.Resolve(&target.Ref, &t); err != nil { - return - } - parentRefs = append(parentRefs, target.Ref.String()) - target = *t - } - - if t, err = expandItems(target, parentRefs, resolver); err != nil { - return - } - target = *t - - for i := range target.AllOf { - if t, err = expandSchema(target.AllOf[i], parentRefs, resolver); err != nil { - return - } - target.AllOf[i] = *t - } - for i := range target.AnyOf { - if t, err = expandSchema(target.AnyOf[i], parentRefs, resolver); err != nil { - return - } - target.AnyOf[i] = *t - } - for i := range target.OneOf { - if t, err = expandSchema(target.OneOf[i], parentRefs, resolver); err != nil { - return - } - target.OneOf[i] = *t - } - if target.Not != nil { - if t, err = expandSchema(*target.Not, parentRefs, resolver); err != nil { - return - } - *target.Not = *t - } - for k, _ := range target.Properties { - if t, err = expandSchema(target.Properties[k], parentRefs, resolver); err != nil { - return - } - target.Properties[k] = *t - } - if target.AdditionalProperties != nil && target.AdditionalProperties.Schema != nil { - if t, err = expandSchema(*target.AdditionalProperties.Schema, parentRefs, resolver); err != nil { - return - } - *target.AdditionalProperties.Schema = *t - } - for k, _ := range target.PatternProperties { - if t, err = expandSchema(target.PatternProperties[k], parentRefs, resolver); err != nil { - return - } - target.PatternProperties[k] = *t - } - for k, _ := range target.Dependencies { - if target.Dependencies[k].Schema != nil { - if t, err = expandSchema(*target.Dependencies[k].Schema, parentRefs, resolver); err != nil { - return - } - *target.Dependencies[k].Schema = *t - } - } - if target.AdditionalItems != nil && target.AdditionalItems.Schema != nil { - if t, err = expandSchema(*target.AdditionalItems.Schema, parentRefs, resolver); err != nil { - return - } - *target.AdditionalItems.Schema = *t - } - for k, _ := range target.Definitions { - if t, err = expandSchema(target.Definitions[k], parentRefs, resolver); err != nil { - return - } - target.Definitions[k] = *t - } - return -} - -func expandPathItem(pathItem *PathItem, resolver *schemaLoader) error { - if pathItem == nil { - return nil - } - if pathItem.Ref.String() != "" { - if err := resolver.Resolve(&pathItem.Ref, &pathItem); err != nil { - return err - } - } - - for idx := range pathItem.Parameters { - if err := expandParameter(&(pathItem.Parameters[idx]), resolver); err != nil { - return err - } - } - if err := expandOperation(pathItem.Get, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Head, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Options, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Put, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Post, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Patch, resolver); err != nil { - return err - } - if err := expandOperation(pathItem.Delete, resolver); err != nil { - return err - } - return nil -} - -func expandOperation(op *Operation, resolver *schemaLoader) error { - if op == nil { - return nil - } - for i, param := range op.Parameters { - if err := expandParameter(¶m, resolver); err != nil { - return err - } - op.Parameters[i] = param - } - - if op.Responses != nil { - responses := op.Responses - if err := expandResponse(responses.Default, resolver); err != nil { - return err - } - for code, response := range responses.StatusCodeResponses { - if err := expandResponse(&response, resolver); err != nil { - return err - } - responses.StatusCodeResponses[code] = response - } - } - return nil -} - -func expandResponse(response *Response, resolver *schemaLoader) error { - if response == nil { - return nil - } - - if response.Ref.String() != "" { - if err := resolver.Resolve(&response.Ref, response); err != nil { - return err - } - } - - if response.Schema != nil { - parentRefs := []string{response.Schema.Ref.String()} - if err := resolver.Resolve(&response.Schema.Ref, &response.Schema); err != nil { - return err - } - if s, err := expandSchema(*response.Schema, parentRefs, resolver); err != nil { - return err - } else { - *response.Schema = *s - } - } - return nil -} - -func expandParameter(parameter *Parameter, resolver *schemaLoader) error { - if parameter == nil { - return nil - } - if parameter.Ref.String() != "" { - if err := resolver.Resolve(¶meter.Ref, parameter); err != nil { - return err - } - } - if parameter.Schema != nil { - parentRefs := []string{parameter.Schema.Ref.String()} - if err := resolver.Resolve(¶meter.Schema.Ref, ¶meter.Schema); err != nil { - return err - } - if s, err := expandSchema(*parameter.Schema, parentRefs, resolver); err != nil { - return err - } else { - *parameter.Schema = *s - } - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/external_docs.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/external_docs.go deleted file mode 100644 index 88add91..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/external_docs.go +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -// ExternalDocumentation allows referencing an external resource for -// extended documentation. -// -// For more information: http://goo.gl/8us55a#externalDocumentationObject -type ExternalDocumentation struct { - Description string `json:"description,omitempty"` - URL string `json:"url,omitempty"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/header.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/header.go deleted file mode 100644 index 758b845..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/header.go +++ /dev/null @@ -1,165 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/swag" -) - -type HeaderProps struct { - Description string `json:"description,omitempty"` -} - -// Header describes a header for a response of the API -// -// For more information: http://goo.gl/8us55a#headerObject -type Header struct { - CommonValidations - SimpleSchema - HeaderProps -} - -// ResponseHeader creates a new header instance for use in a response -func ResponseHeader() *Header { - return new(Header) -} - -// WithDescription sets the description on this response, allows for chaining -func (h *Header) WithDescription(description string) *Header { - h.Description = description - return h -} - -// Typed a fluent builder method for the type of parameter -func (h *Header) Typed(tpe, format string) *Header { - h.Type = tpe - h.Format = format - return h -} - -// CollectionOf a fluent builder method for an array item -func (h *Header) CollectionOf(items *Items, format string) *Header { - h.Type = "array" - h.Items = items - h.CollectionFormat = format - return h -} - -// WithDefault sets the default value on this item -func (h *Header) WithDefault(defaultValue interface{}) *Header { - h.Default = defaultValue - return h -} - -// WithMaxLength sets a max length value -func (h *Header) WithMaxLength(max int64) *Header { - h.MaxLength = &max - return h -} - -// WithMinLength sets a min length value -func (h *Header) WithMinLength(min int64) *Header { - h.MinLength = &min - return h -} - -// WithPattern sets a pattern value -func (h *Header) WithPattern(pattern string) *Header { - h.Pattern = pattern - return h -} - -// WithMultipleOf sets a multiple of value -func (h *Header) WithMultipleOf(number float64) *Header { - h.MultipleOf = &number - return h -} - -// WithMaximum sets a maximum number value -func (h *Header) WithMaximum(max float64, exclusive bool) *Header { - h.Maximum = &max - h.ExclusiveMaximum = exclusive - return h -} - -// WithMinimum sets a minimum number value -func (h *Header) WithMinimum(min float64, exclusive bool) *Header { - h.Minimum = &min - h.ExclusiveMinimum = exclusive - return h -} - -// WithEnum sets a the enum values (replace) -func (h *Header) WithEnum(values ...interface{}) *Header { - h.Enum = append([]interface{}{}, values...) - return h -} - -// WithMaxItems sets the max items -func (h *Header) WithMaxItems(size int64) *Header { - h.MaxItems = &size - return h -} - -// WithMinItems sets the min items -func (h *Header) WithMinItems(size int64) *Header { - h.MinItems = &size - return h -} - -// UniqueValues dictates that this array can only have unique items -func (h *Header) UniqueValues() *Header { - h.UniqueItems = true - return h -} - -// AllowDuplicates this array can have duplicates -func (h *Header) AllowDuplicates() *Header { - h.UniqueItems = false - return h -} - -// MarshalJSON marshal this to JSON -func (h Header) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(h.CommonValidations) - if err != nil { - return nil, err - } - b2, err := json.Marshal(h.SimpleSchema) - if err != nil { - return nil, err - } - b3, err := json.Marshal(h.HeaderProps) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2, b3), nil -} - -// UnmarshalJSON marshal this from JSON -func (h *Header) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &h.CommonValidations); err != nil { - return err - } - if err := json.Unmarshal(data, &h.SimpleSchema); err != nil { - return err - } - if err := json.Unmarshal(data, &h.HeaderProps); err != nil { - return err - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/info.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/info.go deleted file mode 100644 index fb8b7c4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/info.go +++ /dev/null @@ -1,168 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "strings" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// Extensions vendor specific extensions -type Extensions map[string]interface{} - -// Add adds a value to these extensions -func (e Extensions) Add(key string, value interface{}) { - realKey := strings.ToLower(key) - e[realKey] = value -} - -// GetString gets a string value from the extensions -func (e Extensions) GetString(key string) (string, bool) { - if v, ok := e[strings.ToLower(key)]; ok { - str, ok := v.(string) - return str, ok - } - return "", false -} - -// GetBool gets a string value from the extensions -func (e Extensions) GetBool(key string) (bool, bool) { - if v, ok := e[strings.ToLower(key)]; ok { - str, ok := v.(bool) - return str, ok - } - return false, false -} - -// GetStringSlice gets a string value from the extensions -func (e Extensions) GetStringSlice(key string) ([]string, bool) { - if v, ok := e[strings.ToLower(key)]; ok { - arr, ok := v.([]interface{}) - if !ok { - return nil, false - } - var strs []string - for _, iface := range arr { - str, ok := iface.(string) - if !ok { - return nil, false - } - strs = append(strs, str) - } - return strs, ok - } - return nil, false -} - -// VendorExtensible composition block. -type VendorExtensible struct { - Extensions Extensions -} - -// AddExtension adds an extension to this extensible object -func (v *VendorExtensible) AddExtension(key string, value interface{}) { - if value == nil { - return - } - if v.Extensions == nil { - v.Extensions = make(map[string]interface{}) - } - v.Extensions.Add(key, value) -} - -// MarshalJSON marshals the extensions to json -func (v VendorExtensible) MarshalJSON() ([]byte, error) { - toser := make(map[string]interface{}) - for k, v := range v.Extensions { - lk := strings.ToLower(k) - if strings.HasPrefix(lk, "x-") { - toser[k] = v - } - } - return json.Marshal(toser) -} - -// UnmarshalJSON for this extensible object -func (v *VendorExtensible) UnmarshalJSON(data []byte) error { - var d map[string]interface{} - if err := json.Unmarshal(data, &d); err != nil { - return err - } - for k, vv := range d { - lk := strings.ToLower(k) - if strings.HasPrefix(lk, "x-") { - if v.Extensions == nil { - v.Extensions = map[string]interface{}{} - } - v.Extensions[k] = vv - } - } - return nil -} - -// InfoProps the properties for an info definition -type InfoProps struct { - Description string `json:"description,omitempty"` - Title string `json:"title,omitempty"` - TermsOfService string `json:"termsOfService,omitempty"` - Contact *ContactInfo `json:"contact,omitempty"` - License *License `json:"license,omitempty"` - Version string `json:"version,omitempty"` -} - -// Info object provides metadata about the API. -// The metadata can be used by the clients if needed, and can be presented in the Swagger-UI for convenience. -// -// For more information: http://goo.gl/8us55a#infoObject -type Info struct { - VendorExtensible - InfoProps -} - -// JSONLookup look up a value by the json property name -func (i Info) JSONLookup(token string) (interface{}, error) { - if ex, ok := i.Extensions[token]; ok { - return &ex, nil - } - r, _, err := jsonpointer.GetForToken(i.InfoProps, token) - return r, err -} - -// MarshalJSON marshal this to JSON -func (i Info) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(i.InfoProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(i.VendorExtensible) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2), nil -} - -// UnmarshalJSON marshal this from JSON -func (i *Info) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &i.InfoProps); err != nil { - return err - } - if err := json.Unmarshal(data, &i.VendorExtensible); err != nil { - return err - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/items.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/items.go deleted file mode 100644 index 4d57ea5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/items.go +++ /dev/null @@ -1,199 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/swag" -) - -type SimpleSchema struct { - Type string `json:"type,omitempty"` - Format string `json:"format,omitempty"` - Items *Items `json:"items,omitempty"` - CollectionFormat string `json:"collectionFormat,omitempty"` - Default interface{} `json:"default,omitempty"` -} - -func (s *SimpleSchema) TypeName() string { - if s.Format != "" { - return s.Format - } - return s.Type -} - -func (s *SimpleSchema) ItemsTypeName() string { - if s.Items == nil { - return "" - } - return s.Items.TypeName() -} - -type CommonValidations struct { - Maximum *float64 `json:"maximum,omitempty"` - ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` - Minimum *float64 `json:"minimum,omitempty"` - ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` - MaxLength *int64 `json:"maxLength,omitempty"` - MinLength *int64 `json:"minLength,omitempty"` - Pattern string `json:"pattern,omitempty"` - MaxItems *int64 `json:"maxItems,omitempty"` - MinItems *int64 `json:"minItems,omitempty"` - UniqueItems bool `json:"uniqueItems,omitempty"` - MultipleOf *float64 `json:"multipleOf,omitempty"` - Enum []interface{} `json:"enum,omitempty"` -} - -// Items a limited subset of JSON-Schema's items object. -// It is used by parameter definitions that are not located in "body". -// -// For more information: http://goo.gl/8us55a#items-object- -type Items struct { - Refable - CommonValidations - SimpleSchema -} - -// NewItems creates a new instance of items -func NewItems() *Items { - return &Items{} -} - -// Typed a fluent builder method for the type of item -func (i *Items) Typed(tpe, format string) *Items { - i.Type = tpe - i.Format = format - return i -} - -// CollectionOf a fluent builder method for an array item -func (i *Items) CollectionOf(items *Items, format string) *Items { - i.Type = "array" - i.Items = items - i.CollectionFormat = format - return i -} - -// WithDefault sets the default value on this item -func (i *Items) WithDefault(defaultValue interface{}) *Items { - i.Default = defaultValue - return i -} - -// WithMaxLength sets a max length value -func (i *Items) WithMaxLength(max int64) *Items { - i.MaxLength = &max - return i -} - -// WithMinLength sets a min length value -func (i *Items) WithMinLength(min int64) *Items { - i.MinLength = &min - return i -} - -// WithPattern sets a pattern value -func (i *Items) WithPattern(pattern string) *Items { - i.Pattern = pattern - return i -} - -// WithMultipleOf sets a multiple of value -func (i *Items) WithMultipleOf(number float64) *Items { - i.MultipleOf = &number - return i -} - -// WithMaximum sets a maximum number value -func (i *Items) WithMaximum(max float64, exclusive bool) *Items { - i.Maximum = &max - i.ExclusiveMaximum = exclusive - return i -} - -// WithMinimum sets a minimum number value -func (i *Items) WithMinimum(min float64, exclusive bool) *Items { - i.Minimum = &min - i.ExclusiveMinimum = exclusive - return i -} - -// WithEnum sets a the enum values (replace) -func (i *Items) WithEnum(values ...interface{}) *Items { - i.Enum = append([]interface{}{}, values...) - return i -} - -// WithMaxItems sets the max items -func (i *Items) WithMaxItems(size int64) *Items { - i.MaxItems = &size - return i -} - -// WithMinItems sets the min items -func (i *Items) WithMinItems(size int64) *Items { - i.MinItems = &size - return i -} - -// UniqueValues dictates that this array can only have unique items -func (i *Items) UniqueValues() *Items { - i.UniqueItems = true - return i -} - -// AllowDuplicates this array can have duplicates -func (i *Items) AllowDuplicates() *Items { - i.UniqueItems = false - return i -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (i *Items) UnmarshalJSON(data []byte) error { - var validations CommonValidations - if err := json.Unmarshal(data, &validations); err != nil { - return err - } - var ref Refable - if err := json.Unmarshal(data, &ref); err != nil { - return err - } - var simpleSchema SimpleSchema - if err := json.Unmarshal(data, &simpleSchema); err != nil { - return err - } - i.Refable = ref - i.CommonValidations = validations - i.SimpleSchema = simpleSchema - return nil -} - -// MarshalJSON converts this items object to JSON -func (i Items) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(i.CommonValidations) - if err != nil { - return nil, err - } - b2, err := json.Marshal(i.SimpleSchema) - if err != nil { - return nil, err - } - b3, err := json.Marshal(i.Refable) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b3, b1, b2), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/license.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/license.go deleted file mode 100644 index f20961b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/license.go +++ /dev/null @@ -1,23 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -// License information for the exposed API. -// -// For more information: http://goo.gl/8us55a#licenseObject -type License struct { - Name string `json:"name,omitempty"` - URL string `json:"url,omitempty"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/operation.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/operation.go deleted file mode 100644 index de1db6f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/operation.go +++ /dev/null @@ -1,233 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -type OperationProps struct { - Description string `json:"description,omitempty"` - Consumes []string `json:"consumes,omitempty"` - Produces []string `json:"produces,omitempty"` - Schemes []string `json:"schemes,omitempty"` // the scheme, when present must be from [http, https, ws, wss] - Tags []string `json:"tags,omitempty"` - Summary string `json:"summary,omitempty"` - ExternalDocs *ExternalDocumentation `json:"externalDocs,omitempty"` - ID string `json:"operationId,omitempty"` - Deprecated bool `json:"deprecated,omitempty"` - Security []map[string][]string `json:"security,omitempty"` - Parameters []Parameter `json:"parameters,omitempty"` - Responses *Responses `json:"responses,omitempty"` -} - -// Operation describes a single API operation on a path. -// -// For more information: http://goo.gl/8us55a#operationObject -type Operation struct { - VendorExtensible - OperationProps -} - -// SuccessResponse gets a success response model -func (o *Operation) SuccessResponse() (*Response, int, bool) { - if o.Responses == nil { - return nil, 0, false - } - - for k, v := range o.Responses.StatusCodeResponses { - if k/100 == 2 { - return &v, k, true - } - } - - return o.Responses.Default, 0, false -} - -// JSONLookup look up a value by the json property name -func (o Operation) JSONLookup(token string) (interface{}, error) { - if ex, ok := o.Extensions[token]; ok { - return &ex, nil - } - r, _, err := jsonpointer.GetForToken(o.OperationProps, token) - return r, err -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (o *Operation) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &o.OperationProps); err != nil { - return err - } - if err := json.Unmarshal(data, &o.VendorExtensible); err != nil { - return err - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (o Operation) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(o.OperationProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(o.VendorExtensible) - if err != nil { - return nil, err - } - concated := swag.ConcatJSON(b1, b2) - return concated, nil -} - -// NewOperation creates a new operation instance. -// It expects an ID as parameter but not passing an ID is also valid. -func NewOperation(id string) *Operation { - op := new(Operation) - op.ID = id - return op -} - -// WithID sets the ID property on this operation, allows for chaining. -func (o *Operation) WithID(id string) *Operation { - o.ID = id - return o -} - -// WithDescription sets the description on this operation, allows for chaining -func (o *Operation) WithDescription(description string) *Operation { - o.Description = description - return o -} - -// WithSummary sets the summary on this operation, allows for chaining -func (o *Operation) WithSummary(summary string) *Operation { - o.Summary = summary - return o -} - -// WithExternalDocs sets/removes the external docs for/from this operation. -// When you pass empty strings as params the external documents will be removed. -// When you pass non-empty string as one value then those values will be used on the external docs object. -// So when you pass a non-empty description, you should also pass the url and vice versa. -func (o *Operation) WithExternalDocs(description, url string) *Operation { - if description == "" && url == "" { - o.ExternalDocs = nil - return o - } - - if o.ExternalDocs == nil { - o.ExternalDocs = &ExternalDocumentation{} - } - o.ExternalDocs.Description = description - o.ExternalDocs.URL = url - return o -} - -// Deprecate marks the operation as deprecated -func (o *Operation) Deprecate() *Operation { - o.Deprecated = true - return o -} - -// Undeprecate marks the operation as not deprected -func (o *Operation) Undeprecate() *Operation { - o.Deprecated = false - return o -} - -// WithConsumes adds media types for incoming body values -func (o *Operation) WithConsumes(mediaTypes ...string) *Operation { - o.Consumes = append(o.Consumes, mediaTypes...) - return o -} - -// WithProduces adds media types for outgoing body values -func (o *Operation) WithProduces(mediaTypes ...string) *Operation { - o.Produces = append(o.Produces, mediaTypes...) - return o -} - -// WithTags adds tags for this operation -func (o *Operation) WithTags(tags ...string) *Operation { - o.Tags = append(o.Tags, tags...) - return o -} - -// AddParam adds a parameter to this operation, when a parameter for that location -// and with that name already exists it will be replaced -func (o *Operation) AddParam(param *Parameter) *Operation { - if param == nil { - return o - } - - for i, p := range o.Parameters { - if p.Name == param.Name && p.In == param.In { - params := append(o.Parameters[:i], *param) - params = append(params, o.Parameters[i+1:]...) - o.Parameters = params - return o - } - } - - o.Parameters = append(o.Parameters, *param) - return o -} - -// RemoveParam removes a parameter from the operation -func (o *Operation) RemoveParam(name, in string) *Operation { - for i, p := range o.Parameters { - if p.Name == name && p.In == name { - o.Parameters = append(o.Parameters[:i], o.Parameters[i+1:]...) - return o - } - } - return o -} - -// SecuredWith adds a security scope to this operation. -func (o *Operation) SecuredWith(name string, scopes ...string) *Operation { - o.Security = append(o.Security, map[string][]string{name: scopes}) - return o -} - -// WithDefaultResponse adds a default response to the operation. -// Passing a nil value will remove the response -func (o *Operation) WithDefaultResponse(response *Response) *Operation { - return o.RespondsWith(0, response) -} - -// RespondsWith adds a status code response to the operation. -// When the code is 0 the value of the response will be used as default response value. -// When the value of the response is nil it will be removed from the operation -func (o *Operation) RespondsWith(code int, response *Response) *Operation { - if o.Responses == nil { - o.Responses = new(Responses) - } - if code == 0 { - o.Responses.Default = response - return o - } - if response == nil { - delete(o.Responses.StatusCodeResponses, code) - return o - } - if o.Responses.StatusCodeResponses == nil { - o.Responses.StatusCodeResponses = make(map[int]Response) - } - o.Responses.StatusCodeResponses[code] = *response - return o -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/parameter.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/parameter.go deleted file mode 100644 index 8fb66d1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/parameter.go +++ /dev/null @@ -1,299 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// QueryParam creates a query parameter -func QueryParam(name string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "query"}} -} - -// HeaderParam creates a header parameter, this is always required by default -func HeaderParam(name string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "header", Required: true}} -} - -// PathParam creates a path parameter, this is always required -func PathParam(name string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "path", Required: true}} -} - -// BodyParam creates a body parameter -func BodyParam(name string, schema *Schema) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "body", Schema: schema}, SimpleSchema: SimpleSchema{Type: "object"}} -} - -// FormDataParam creates a body parameter -func FormDataParam(name string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "formData"}} -} - -// FileParam creates a body parameter -func FileParam(name string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name, In: "formData"}, SimpleSchema: SimpleSchema{Type: "file"}} -} - -// SimpleArrayParam creates a param for a simple array (string, int, date etc) -func SimpleArrayParam(name, tpe, fmt string) *Parameter { - return &Parameter{ParamProps: ParamProps{Name: name}, SimpleSchema: SimpleSchema{Type: "array", CollectionFormat: "csv", Items: &Items{SimpleSchema: SimpleSchema{Type: "string", Format: fmt}}}} -} - -// ParamRef creates a parameter that's a json reference -func ParamRef(uri string) *Parameter { - p := new(Parameter) - p.Ref = MustCreateRef(uri) - return p -} - -type ParamProps struct { - Description string `json:"description,omitempty"` - Name string `json:"name,omitempty"` - In string `json:"in,omitempty"` - Required bool `json:"required,omitempty"` - Schema *Schema `json:"schema,omitempty"` // when in == "body" - AllowEmptyValue bool `json:"allowEmptyValue,omitempty"` // when in == "query" || "formData" -} - -// Parameter a unique parameter is defined by a combination of a [name](#parameterName) and [location](#parameterIn). -// -// There are five possible parameter types. -// * Path - Used together with [Path Templating](#pathTemplating), where the parameter value is actually part of the operation's URL. This does not include the host or base path of the API. For example, in `/items/{itemId}`, the path parameter is `itemId`. -// * Query - Parameters that are appended to the URL. For example, in `/items?id=###`, the query parameter is `id`. -// * Header - Custom headers that are expected as part of the request. -// * Body - The payload that's appended to the HTTP request. Since there can only be one payload, there can only be *one* body parameter. The name of the body parameter has no effect on the parameter itself and is used for documentation purposes only. Since Form parameters are also in the payload, body and form parameters cannot exist together for the same operation. -// * Form - Used to describe the payload of an HTTP request when either `application/x-www-form-urlencoded` or `multipart/form-data` are used as the content type of the request (in Swagger's definition, the [`consumes`](#operationConsumes) property of an operation). This is the only parameter type that can be used to send files, thus supporting the `file` type. Since form parameters are sent in the payload, they cannot be declared together with a body parameter for the same operation. Form parameters have a different format based on the content-type used (for further details, consult http://www.w3.org/TR/html401/interact/forms.html#h-17.13.4): -// * `application/x-www-form-urlencoded` - Similar to the format of Query parameters but as a payload. For example, `foo=1&bar=swagger` - both `foo` and `bar` are form parameters. This is normally used for simple parameters that are being transferred. -// * `multipart/form-data` - each parameter takes a section in the payload with an internal header. For example, for the header `Content-Disposition: form-data; name="submit-name"` the name of the parameter is `submit-name`. This type of form parameters is more commonly used for file transfers. -// -// For more information: http://goo.gl/8us55a#parameterObject -type Parameter struct { - Refable - CommonValidations - SimpleSchema - VendorExtensible - ParamProps -} - -// JSONLookup look up a value by the json property name -func (p Parameter) JSONLookup(token string) (interface{}, error) { - if ex, ok := p.Extensions[token]; ok { - return &ex, nil - } - if token == "$ref" { - return &p.Ref, nil - } - r, _, err := jsonpointer.GetForToken(p.CommonValidations, token) - if err != nil { - return nil, err - } - if r != nil { - return r, nil - } - r, _, err = jsonpointer.GetForToken(p.SimpleSchema, token) - if err != nil { - return nil, err - } - if r != nil { - return r, nil - } - r, _, err = jsonpointer.GetForToken(p.ParamProps, token) - return r, err -} - -// WithDescription a fluent builder method for the description of the parameter -func (p *Parameter) WithDescription(description string) *Parameter { - p.Description = description - return p -} - -// Named a fluent builder method to override the name of the parameter -func (p *Parameter) Named(name string) *Parameter { - p.Name = name - return p -} - -// WithLocation a fluent builder method to override the location of the parameter -func (p *Parameter) WithLocation(in string) *Parameter { - p.In = in - return p -} - -// Typed a fluent builder method for the type of the parameter value -func (p *Parameter) Typed(tpe, format string) *Parameter { - p.Type = tpe - p.Format = format - return p -} - -// CollectionOf a fluent builder method for an array parameter -func (p *Parameter) CollectionOf(items *Items, format string) *Parameter { - p.Type = "array" - p.Items = items - p.CollectionFormat = format - return p -} - -// WithDefault sets the default value on this parameter -func (p *Parameter) WithDefault(defaultValue interface{}) *Parameter { - p.AsOptional() // with default implies optional - p.Default = defaultValue - return p -} - -// AllowsEmptyValues flags this parameter as being ok with empty values -func (p *Parameter) AllowsEmptyValues() *Parameter { - p.AllowEmptyValue = true - return p -} - -// NoEmptyValues flags this parameter as not liking empty values -func (p *Parameter) NoEmptyValues() *Parameter { - p.AllowEmptyValue = false - return p -} - -// AsOptional flags this parameter as optional -func (p *Parameter) AsOptional() *Parameter { - p.Required = false - return p -} - -// AsRequired flags this parameter as required -func (p *Parameter) AsRequired() *Parameter { - if p.Default != nil { // with a default required makes no sense - return p - } - p.Required = true - return p -} - -// WithMaxLength sets a max length value -func (p *Parameter) WithMaxLength(max int64) *Parameter { - p.MaxLength = &max - return p -} - -// WithMinLength sets a min length value -func (p *Parameter) WithMinLength(min int64) *Parameter { - p.MinLength = &min - return p -} - -// WithPattern sets a pattern value -func (p *Parameter) WithPattern(pattern string) *Parameter { - p.Pattern = pattern - return p -} - -// WithMultipleOf sets a multiple of value -func (p *Parameter) WithMultipleOf(number float64) *Parameter { - p.MultipleOf = &number - return p -} - -// WithMaximum sets a maximum number value -func (p *Parameter) WithMaximum(max float64, exclusive bool) *Parameter { - p.Maximum = &max - p.ExclusiveMaximum = exclusive - return p -} - -// WithMinimum sets a minimum number value -func (p *Parameter) WithMinimum(min float64, exclusive bool) *Parameter { - p.Minimum = &min - p.ExclusiveMinimum = exclusive - return p -} - -// WithEnum sets a the enum values (replace) -func (p *Parameter) WithEnum(values ...interface{}) *Parameter { - p.Enum = append([]interface{}{}, values...) - return p -} - -// WithMaxItems sets the max items -func (p *Parameter) WithMaxItems(size int64) *Parameter { - p.MaxItems = &size - return p -} - -// WithMinItems sets the min items -func (p *Parameter) WithMinItems(size int64) *Parameter { - p.MinItems = &size - return p -} - -// UniqueValues dictates that this array can only have unique items -func (p *Parameter) UniqueValues() *Parameter { - p.UniqueItems = true - return p -} - -// AllowDuplicates this array can have duplicates -func (p *Parameter) AllowDuplicates() *Parameter { - p.UniqueItems = false - return p -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (p *Parameter) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &p.CommonValidations); err != nil { - return err - } - if err := json.Unmarshal(data, &p.Refable); err != nil { - return err - } - if err := json.Unmarshal(data, &p.SimpleSchema); err != nil { - return err - } - if err := json.Unmarshal(data, &p.VendorExtensible); err != nil { - return err - } - if err := json.Unmarshal(data, &p.ParamProps); err != nil { - return err - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (p Parameter) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(p.CommonValidations) - if err != nil { - return nil, err - } - b2, err := json.Marshal(p.SimpleSchema) - if err != nil { - return nil, err - } - b3, err := json.Marshal(p.Refable) - if err != nil { - return nil, err - } - b4, err := json.Marshal(p.VendorExtensible) - if err != nil { - return nil, err - } - b5, err := json.Marshal(p.ParamProps) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b3, b1, b2, b4, b5), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/path_item.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/path_item.go deleted file mode 100644 index 9ab3ec5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/path_item.go +++ /dev/null @@ -1,90 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// pathItemProps the path item specific properties -type PathItemProps struct { - Get *Operation `json:"get,omitempty"` - Put *Operation `json:"put,omitempty"` - Post *Operation `json:"post,omitempty"` - Delete *Operation `json:"delete,omitempty"` - Options *Operation `json:"options,omitempty"` - Head *Operation `json:"head,omitempty"` - Patch *Operation `json:"patch,omitempty"` - Parameters []Parameter `json:"parameters,omitempty"` -} - -// PathItem describes the operations available on a single path. -// A Path Item may be empty, due to [ACL constraints](http://goo.gl/8us55a#securityFiltering). -// The path itself is still exposed to the documentation viewer but they will -// not know which operations and parameters are available. -// -// For more information: http://goo.gl/8us55a#pathItemObject -type PathItem struct { - Refable - VendorExtensible - PathItemProps -} - -// JSONLookup look up a value by the json property name -func (p PathItem) JSONLookup(token string) (interface{}, error) { - if ex, ok := p.Extensions[token]; ok { - return &ex, nil - } - if token == "$ref" { - return &p.Ref, nil - } - r, _, err := jsonpointer.GetForToken(p.PathItemProps, token) - return r, err -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (p *PathItem) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &p.Refable); err != nil { - return err - } - if err := json.Unmarshal(data, &p.VendorExtensible); err != nil { - return err - } - if err := json.Unmarshal(data, &p.PathItemProps); err != nil { - return err - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (p PathItem) MarshalJSON() ([]byte, error) { - b3, err := json.Marshal(p.Refable) - if err != nil { - return nil, err - } - b4, err := json.Marshal(p.VendorExtensible) - if err != nil { - return nil, err - } - b5, err := json.Marshal(p.PathItemProps) - if err != nil { - return nil, err - } - concated := swag.ConcatJSON(b3, b4, b5) - return concated, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/paths.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/paths.go deleted file mode 100644 index 9dc82a2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/paths.go +++ /dev/null @@ -1,97 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "fmt" - "strings" - - "github.com/go-openapi/swag" -) - -// Paths holds the relative paths to the individual endpoints. -// The path is appended to the [`basePath`](http://goo.gl/8us55a#swaggerBasePath) in order -// to construct the full URL. -// The Paths may be empty, due to [ACL constraints](http://goo.gl/8us55a#securityFiltering). -// -// For more information: http://goo.gl/8us55a#pathsObject -type Paths struct { - VendorExtensible - Paths map[string]PathItem `json:"-"` // custom serializer to flatten this, each entry must start with "/" -} - -// JSONLookup look up a value by the json property name -func (p Paths) JSONLookup(token string) (interface{}, error) { - if pi, ok := p.Paths[token]; ok { - return &pi, nil - } - if ex, ok := p.Extensions[token]; ok { - return &ex, nil - } - return nil, fmt.Errorf("object has no field %q", token) -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (p *Paths) UnmarshalJSON(data []byte) error { - var res map[string]json.RawMessage - if err := json.Unmarshal(data, &res); err != nil { - return err - } - for k, v := range res { - if strings.HasPrefix(strings.ToLower(k), "x-") { - if p.Extensions == nil { - p.Extensions = make(map[string]interface{}) - } - var d interface{} - if err := json.Unmarshal(v, &d); err != nil { - return err - } - p.Extensions[k] = d - } - if strings.HasPrefix(k, "/") { - if p.Paths == nil { - p.Paths = make(map[string]PathItem) - } - var pi PathItem - if err := json.Unmarshal(v, &pi); err != nil { - return err - } - p.Paths[k] = pi - } - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (p Paths) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(p.VendorExtensible) - if err != nil { - return nil, err - } - - pths := make(map[string]PathItem) - for k, v := range p.Paths { - if strings.HasPrefix(k, "/") { - pths[k] = v - } - } - b2, err := json.Marshal(pths) - if err != nil { - return nil, err - } - concated := swag.ConcatJSON(b1, b2) - return concated, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/ref.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/ref.go deleted file mode 100644 index 68631df..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/ref.go +++ /dev/null @@ -1,167 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "net/http" - "os" - "path/filepath" - - "github.com/go-openapi/jsonreference" -) - -// Refable is a struct for things that accept a $ref property -type Refable struct { - Ref Ref -} - -// MarshalJSON marshals the ref to json -func (r Refable) MarshalJSON() ([]byte, error) { - return r.Ref.MarshalJSON() -} - -// UnmarshalJSON unmarshalss the ref from json -func (r *Refable) UnmarshalJSON(d []byte) error { - return json.Unmarshal(d, &r.Ref) -} - -// Ref represents a json reference that is potentially resolved -type Ref struct { - jsonreference.Ref -} - -// RemoteURI gets the remote uri part of the ref -func (r *Ref) RemoteURI() string { - if r.String() == "" { - return r.String() - } - - u := *r.GetURL() - u.Fragment = "" - return u.String() -} - -// IsValidURI returns true when the url the ref points to can be found -func (r *Ref) IsValidURI() bool { - if r.String() == "" { - return true - } - - v := r.RemoteURI() - if v == "" { - return true - } - - if r.HasFullURL { - rr, err := http.Get(v) - if err != nil { - return false - } - - return rr.StatusCode/100 == 2 - } - - if !(r.HasFileScheme || r.HasFullFilePath || r.HasURLPathOnly) { - return false - } - - // check for local file - pth := v - if r.HasURLPathOnly { - p, e := filepath.Abs(pth) - if e != nil { - return false - } - pth = p - } - - fi, err := os.Stat(pth) - if err != nil { - return false - } - - return !fi.IsDir() -} - -// Inherits creates a new reference from a parent and a child -// If the child cannot inherit from the parent, an error is returned -func (r *Ref) Inherits(child Ref) (*Ref, error) { - ref, err := r.Ref.Inherits(child.Ref) - if err != nil { - return nil, err - } - return &Ref{Ref: *ref}, nil -} - -// NewRef creates a new instance of a ref object -// returns an error when the reference uri is an invalid uri -func NewRef(refURI string) (Ref, error) { - ref, err := jsonreference.New(refURI) - if err != nil { - return Ref{}, err - } - return Ref{Ref: ref}, nil -} - -// MustCreateRef creates a ref object but -func MustCreateRef(refURI string) Ref { - return Ref{Ref: jsonreference.MustCreateRef(refURI)} -} - -// // NewResolvedRef creates a resolved ref -// func NewResolvedRef(refURI string, data interface{}) Ref { -// return Ref{ -// Ref: jsonreference.MustCreateRef(refURI), -// Resolved: data, -// } -// } - -// MarshalJSON marshals this ref into a JSON object -func (r Ref) MarshalJSON() ([]byte, error) { - str := r.String() - if str == "" { - if r.IsRoot() { - return []byte(`{"$ref":"#"}`), nil - } - return []byte("{}"), nil - } - v := map[string]interface{}{"$ref": str} - return json.Marshal(v) -} - -// UnmarshalJSON unmarshals this ref from a JSON object -func (r *Ref) UnmarshalJSON(d []byte) error { - var v map[string]interface{} - if err := json.Unmarshal(d, &v); err != nil { - return err - } - - if v == nil { - return nil - } - - if vv, ok := v["$ref"]; ok { - if str, ok := vv.(string); ok { - ref, err := jsonreference.New(str) - if err != nil { - return err - } - *r = Ref{Ref: ref} - } - } - - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/response.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/response.go deleted file mode 100644 index 308cc84..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/response.go +++ /dev/null @@ -1,113 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/swag" -) - -// ResponseProps properties specific to a response -type ResponseProps struct { - Description string `json:"description,omitempty"` - Schema *Schema `json:"schema,omitempty"` - Headers map[string]Header `json:"headers,omitempty"` - Examples map[string]interface{} `json:"examples,omitempty"` -} - -// Response describes a single response from an API Operation. -// -// For more information: http://goo.gl/8us55a#responseObject -type Response struct { - Refable - ResponseProps -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (r *Response) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &r.ResponseProps); err != nil { - return err - } - if err := json.Unmarshal(data, &r.Refable); err != nil { - return err - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (r Response) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(r.ResponseProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(r.Refable) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2), nil -} - -// NewResponse creates a new response instance -func NewResponse() *Response { - return new(Response) -} - -// ResponseRef creates a response as a json reference -func ResponseRef(url string) *Response { - resp := NewResponse() - resp.Ref = MustCreateRef(url) - return resp -} - -// WithDescription sets the description on this response, allows for chaining -func (r *Response) WithDescription(description string) *Response { - r.Description = description - return r -} - -// WithSchema sets the schema on this response, allows for chaining. -// Passing a nil argument removes the schema from this response -func (r *Response) WithSchema(schema *Schema) *Response { - r.Schema = schema - return r -} - -// AddHeader adds a header to this response -func (r *Response) AddHeader(name string, header *Header) *Response { - if header == nil { - return r.RemoveHeader(name) - } - if r.Headers == nil { - r.Headers = make(map[string]Header) - } - r.Headers[name] = *header - return r -} - -// RemoveHeader removes a header from this response -func (r *Response) RemoveHeader(name string) *Response { - delete(r.Headers, name) - return r -} - -// AddExample adds an example to this response -func (r *Response) AddExample(mediaType string, example interface{}) *Response { - if r.Examples == nil { - r.Examples = make(map[string]interface{}) - } - r.Examples[mediaType] = example - return r -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/responses.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/responses.go deleted file mode 100644 index ea071ca..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/responses.go +++ /dev/null @@ -1,122 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "fmt" - "reflect" - "strconv" - - "github.com/go-openapi/swag" -) - -// Responses is a container for the expected responses of an operation. -// The container maps a HTTP response code to the expected response. -// It is not expected from the documentation to necessarily cover all possible HTTP response codes, -// since they may not be known in advance. However, it is expected from the documentation to cover -// a successful operation response and any known errors. -// -// The `default` can be used a default response object for all HTTP codes that are not covered -// individually by the specification. -// -// The `Responses Object` MUST contain at least one response code, and it SHOULD be the response -// for a successful operation call. -// -// For more information: http://goo.gl/8us55a#responsesObject -type Responses struct { - VendorExtensible - ResponsesProps -} - -// JSONLookup implements an interface to customize json pointer lookup -func (r Responses) JSONLookup(token string) (interface{}, error) { - if token == "default" { - return r.Default, nil - } - if ex, ok := r.Extensions[token]; ok { - return &ex, nil - } - if i, err := strconv.Atoi(token); err == nil { - if scr, ok := r.StatusCodeResponses[i]; ok { - return &scr, nil - } - } - return nil, fmt.Errorf("object has no field %q", token) -} - -// UnmarshalJSON hydrates this items instance with the data from JSON -func (r *Responses) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &r.ResponsesProps); err != nil { - return err - } - if err := json.Unmarshal(data, &r.VendorExtensible); err != nil { - return err - } - if reflect.DeepEqual(ResponsesProps{}, r.ResponsesProps) { - r.ResponsesProps = ResponsesProps{} - } - return nil -} - -// MarshalJSON converts this items object to JSON -func (r Responses) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(r.ResponsesProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(r.VendorExtensible) - if err != nil { - return nil, err - } - concated := swag.ConcatJSON(b1, b2) - return concated, nil -} - -type ResponsesProps struct { - Default *Response - StatusCodeResponses map[int]Response -} - -func (r ResponsesProps) MarshalJSON() ([]byte, error) { - toser := map[string]Response{} - if r.Default != nil { - toser["default"] = *r.Default - } - for k, v := range r.StatusCodeResponses { - toser[strconv.Itoa(k)] = v - } - return json.Marshal(toser) -} - -func (r *ResponsesProps) UnmarshalJSON(data []byte) error { - var res map[string]Response - if err := json.Unmarshal(data, &res); err != nil { - return nil - } - if v, ok := res["default"]; ok { - r.Default = &v - delete(res, "default") - } - for k, v := range res { - if nk, err := strconv.Atoi(k); err == nil { - if r.StatusCodeResponses == nil { - r.StatusCodeResponses = map[int]Response{} - } - r.StatusCodeResponses[nk] = v - } - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/schema.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/schema.go deleted file mode 100644 index eb88f00..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/schema.go +++ /dev/null @@ -1,628 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "fmt" - "net/url" - "strings" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// BooleanProperty creates a boolean property -func BooleanProperty() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"boolean"}}} -} - -// BoolProperty creates a boolean property -func BoolProperty() *Schema { return BooleanProperty() } - -// StringProperty creates a string property -func StringProperty() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"string"}}} -} - -// CharProperty creates a string property -func CharProperty() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"string"}}} -} - -// Float64Property creates a float64/double property -func Float64Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"number"}, Format: "double"}} -} - -// Float32Property creates a float32/float property -func Float32Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"number"}, Format: "float"}} -} - -// Int8Property creates an int8 property -func Int8Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"integer"}, Format: "int8"}} -} - -// Int16Property creates an int16 property -func Int16Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"integer"}, Format: "int16"}} -} - -// Int32Property creates an int32 property -func Int32Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"integer"}, Format: "int32"}} -} - -// Int64Property creates an int64 property -func Int64Property() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"integer"}, Format: "int64"}} -} - -// StrFmtProperty creates a property for the named string format -func StrFmtProperty(format string) *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"string"}, Format: format}} -} - -// DateProperty creates a date property -func DateProperty() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"string"}, Format: "date"}} -} - -// DateTimeProperty creates a date time property -func DateTimeProperty() *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"string"}, Format: "date-time"}} -} - -// MapProperty creates a map property -func MapProperty(property *Schema) *Schema { - return &Schema{SchemaProps: SchemaProps{Type: []string{"object"}, AdditionalProperties: &SchemaOrBool{Allows: true, Schema: property}}} -} - -// RefProperty creates a ref property -func RefProperty(name string) *Schema { - return &Schema{SchemaProps: SchemaProps{Ref: MustCreateRef(name)}} -} - -// RefSchema creates a ref property -func RefSchema(name string) *Schema { - return &Schema{SchemaProps: SchemaProps{Ref: MustCreateRef(name)}} -} - -// ArrayProperty creates an array property -func ArrayProperty(items *Schema) *Schema { - if items == nil { - return &Schema{SchemaProps: SchemaProps{Type: []string{"array"}}} - } - return &Schema{SchemaProps: SchemaProps{Items: &SchemaOrArray{Schema: items}, Type: []string{"array"}}} -} - -// ComposedSchema creates a schema with allOf -func ComposedSchema(schemas ...Schema) *Schema { - s := new(Schema) - s.AllOf = schemas - return s -} - -// SchemaURL represents a schema url -type SchemaURL string - -// MarshalJSON marshal this to JSON -func (r SchemaURL) MarshalJSON() ([]byte, error) { - if r == "" { - return []byte("{}"), nil - } - v := map[string]interface{}{"$schema": string(r)} - return json.Marshal(v) -} - -// UnmarshalJSON unmarshal this from JSON -func (r *SchemaURL) UnmarshalJSON(data []byte) error { - var v map[string]interface{} - if err := json.Unmarshal(data, &v); err != nil { - return err - } - if v == nil { - return nil - } - if vv, ok := v["$schema"]; ok { - if str, ok := vv.(string); ok { - u, err := url.Parse(str) - if err != nil { - return err - } - - *r = SchemaURL(u.String()) - } - } - return nil -} - -// type ExtraSchemaProps map[string]interface{} - -// // JSONSchema represents a structure that is a json schema draft 04 -// type JSONSchema struct { -// SchemaProps -// ExtraSchemaProps -// } - -// // MarshalJSON marshal this to JSON -// func (s JSONSchema) MarshalJSON() ([]byte, error) { -// b1, err := json.Marshal(s.SchemaProps) -// if err != nil { -// return nil, err -// } -// b2, err := s.Ref.MarshalJSON() -// if err != nil { -// return nil, err -// } -// b3, err := s.Schema.MarshalJSON() -// if err != nil { -// return nil, err -// } -// b4, err := json.Marshal(s.ExtraSchemaProps) -// if err != nil { -// return nil, err -// } -// return swag.ConcatJSON(b1, b2, b3, b4), nil -// } - -// // UnmarshalJSON marshal this from JSON -// func (s *JSONSchema) UnmarshalJSON(data []byte) error { -// var sch JSONSchema -// if err := json.Unmarshal(data, &sch.SchemaProps); err != nil { -// return err -// } -// if err := json.Unmarshal(data, &sch.Ref); err != nil { -// return err -// } -// if err := json.Unmarshal(data, &sch.Schema); err != nil { -// return err -// } -// if err := json.Unmarshal(data, &sch.ExtraSchemaProps); err != nil { -// return err -// } -// *s = sch -// return nil -// } - -type SchemaProps struct { - ID string `json:"id,omitempty"` - Ref Ref `json:"-,omitempty"` - Schema SchemaURL `json:"-,omitempty"` - Description string `json:"description,omitempty"` - Type StringOrArray `json:"type,omitempty"` - Format string `json:"format,omitempty"` - Title string `json:"title,omitempty"` - Default interface{} `json:"default,omitempty"` - Maximum *float64 `json:"maximum,omitempty"` - ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` - Minimum *float64 `json:"minimum,omitempty"` - ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` - MaxLength *int64 `json:"maxLength,omitempty"` - MinLength *int64 `json:"minLength,omitempty"` - Pattern string `json:"pattern,omitempty"` - MaxItems *int64 `json:"maxItems,omitempty"` - MinItems *int64 `json:"minItems,omitempty"` - UniqueItems bool `json:"uniqueItems,omitempty"` - MultipleOf *float64 `json:"multipleOf,omitempty"` - Enum []interface{} `json:"enum,omitempty"` - MaxProperties *int64 `json:"maxProperties,omitempty"` - MinProperties *int64 `json:"minProperties,omitempty"` - Required []string `json:"required,omitempty"` - Items *SchemaOrArray `json:"items,omitempty"` - AllOf []Schema `json:"allOf,omitempty"` - OneOf []Schema `json:"oneOf,omitempty"` - AnyOf []Schema `json:"anyOf,omitempty"` - Not *Schema `json:"not,omitempty"` - Properties map[string]Schema `json:"properties,omitempty"` - AdditionalProperties *SchemaOrBool `json:"additionalProperties,omitempty"` - PatternProperties map[string]Schema `json:"patternProperties,omitempty"` - Dependencies Dependencies `json:"dependencies,omitempty"` - AdditionalItems *SchemaOrBool `json:"additionalItems,omitempty"` - Definitions Definitions `json:"definitions,omitempty"` -} - -type SwaggerSchemaProps struct { - Discriminator string `json:"discriminator,omitempty"` - ReadOnly bool `json:"readOnly,omitempty"` - XML *XMLObject `json:"xml,omitempty"` - ExternalDocs *ExternalDocumentation `json:"externalDocs,omitempty"` - Example interface{} `json:"example,omitempty"` -} - -// Schema the schema object allows the definition of input and output data types. -// These types can be objects, but also primitives and arrays. -// This object is based on the [JSON Schema Specification Draft 4](http://json-schema.org/) -// and uses a predefined subset of it. -// On top of this subset, there are extensions provided by this specification to allow for more complete documentation. -// -// For more information: http://goo.gl/8us55a#schemaObject -type Schema struct { - VendorExtensible - SchemaProps - SwaggerSchemaProps - ExtraProps map[string]interface{} `json:"-"` -} - -// JSONLookup implements an interface to customize json pointer lookup -func (s Schema) JSONLookup(token string) (interface{}, error) { - if ex, ok := s.Extensions[token]; ok { - return &ex, nil - } - - if ex, ok := s.ExtraProps[token]; ok { - return &ex, nil - } - - r, _, err := jsonpointer.GetForToken(s.SchemaProps, token) - if r != nil || err != nil { - return r, err - } - r, _, err = jsonpointer.GetForToken(s.SwaggerSchemaProps, token) - return r, err -} - -// WithID sets the id for this schema, allows for chaining -func (s *Schema) WithID(id string) *Schema { - s.ID = id - return s -} - -// WithTitle sets the title for this schema, allows for chaining -func (s *Schema) WithTitle(title string) *Schema { - s.Title = title - return s -} - -// WithDescription sets the description for this schema, allows for chaining -func (s *Schema) WithDescription(description string) *Schema { - s.Description = description - return s -} - -// WithProperties sets the properties for this schema -func (s *Schema) WithProperties(schemas map[string]Schema) *Schema { - s.Properties = schemas - return s -} - -// SetProperty sets a property on this schema -func (s *Schema) SetProperty(name string, schema Schema) *Schema { - if s.Properties == nil { - s.Properties = make(map[string]Schema) - } - s.Properties[name] = schema - return s -} - -// WithAllOf sets the all of property -func (s *Schema) WithAllOf(schemas ...Schema) *Schema { - s.AllOf = schemas - return s -} - -// WithMaxProperties sets the max number of properties an object can have -func (s *Schema) WithMaxProperties(max int64) *Schema { - s.MaxProperties = &max - return s -} - -// WithMinProperties sets the min number of properties an object must have -func (s *Schema) WithMinProperties(min int64) *Schema { - s.MinProperties = &min - return s -} - -// Typed sets the type of this schema for a single value item -func (s *Schema) Typed(tpe, format string) *Schema { - s.Type = []string{tpe} - s.Format = format - return s -} - -// AddType adds a type with potential format to the types for this schema -func (s *Schema) AddType(tpe, format string) *Schema { - s.Type = append(s.Type, tpe) - if format != "" { - s.Format = format - } - return s -} - -// CollectionOf a fluent builder method for an array parameter -func (s *Schema) CollectionOf(items Schema) *Schema { - s.Type = []string{"array"} - s.Items = &SchemaOrArray{Schema: &items} - return s -} - -// WithDefault sets the default value on this parameter -func (s *Schema) WithDefault(defaultValue interface{}) *Schema { - s.Default = defaultValue - return s -} - -// WithRequired flags this parameter as required -func (s *Schema) WithRequired(items ...string) *Schema { - s.Required = items - return s -} - -// AddRequired adds field names to the required properties array -func (s *Schema) AddRequired(items ...string) *Schema { - s.Required = append(s.Required, items...) - return s -} - -// WithMaxLength sets a max length value -func (s *Schema) WithMaxLength(max int64) *Schema { - s.MaxLength = &max - return s -} - -// WithMinLength sets a min length value -func (s *Schema) WithMinLength(min int64) *Schema { - s.MinLength = &min - return s -} - -// WithPattern sets a pattern value -func (s *Schema) WithPattern(pattern string) *Schema { - s.Pattern = pattern - return s -} - -// WithMultipleOf sets a multiple of value -func (s *Schema) WithMultipleOf(number float64) *Schema { - s.MultipleOf = &number - return s -} - -// WithMaximum sets a maximum number value -func (s *Schema) WithMaximum(max float64, exclusive bool) *Schema { - s.Maximum = &max - s.ExclusiveMaximum = exclusive - return s -} - -// WithMinimum sets a minimum number value -func (s *Schema) WithMinimum(min float64, exclusive bool) *Schema { - s.Minimum = &min - s.ExclusiveMinimum = exclusive - return s -} - -// WithEnum sets a the enum values (replace) -func (s *Schema) WithEnum(values ...interface{}) *Schema { - s.Enum = append([]interface{}{}, values...) - return s -} - -// WithMaxItems sets the max items -func (s *Schema) WithMaxItems(size int64) *Schema { - s.MaxItems = &size - return s -} - -// WithMinItems sets the min items -func (s *Schema) WithMinItems(size int64) *Schema { - s.MinItems = &size - return s -} - -// UniqueValues dictates that this array can only have unique items -func (s *Schema) UniqueValues() *Schema { - s.UniqueItems = true - return s -} - -// AllowDuplicates this array can have duplicates -func (s *Schema) AllowDuplicates() *Schema { - s.UniqueItems = false - return s -} - -// AddToAllOf adds a schema to the allOf property -func (s *Schema) AddToAllOf(schemas ...Schema) *Schema { - s.AllOf = append(s.AllOf, schemas...) - return s -} - -// WithDiscriminator sets the name of the discriminator field -func (s *Schema) WithDiscriminator(discriminator string) *Schema { - s.Discriminator = discriminator - return s -} - -// AsReadOnly flags this schema as readonly -func (s *Schema) AsReadOnly() *Schema { - s.ReadOnly = true - return s -} - -// AsWritable flags this schema as writeable (not read-only) -func (s *Schema) AsWritable() *Schema { - s.ReadOnly = false - return s -} - -// WithExample sets the example for this schema -func (s *Schema) WithExample(example interface{}) *Schema { - s.Example = example - return s -} - -// WithExternalDocs sets/removes the external docs for/from this schema. -// When you pass empty strings as params the external documents will be removed. -// When you pass non-empty string as one value then those values will be used on the external docs object. -// So when you pass a non-empty description, you should also pass the url and vice versa. -func (s *Schema) WithExternalDocs(description, url string) *Schema { - if description == "" && url == "" { - s.ExternalDocs = nil - return s - } - - if s.ExternalDocs == nil { - s.ExternalDocs = &ExternalDocumentation{} - } - s.ExternalDocs.Description = description - s.ExternalDocs.URL = url - return s -} - -// WithXMLName sets the xml name for the object -func (s *Schema) WithXMLName(name string) *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Name = name - return s -} - -// WithXMLNamespace sets the xml namespace for the object -func (s *Schema) WithXMLNamespace(namespace string) *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Namespace = namespace - return s -} - -// WithXMLPrefix sets the xml prefix for the object -func (s *Schema) WithXMLPrefix(prefix string) *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Prefix = prefix - return s -} - -// AsXMLAttribute flags this object as xml attribute -func (s *Schema) AsXMLAttribute() *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Attribute = true - return s -} - -// AsXMLElement flags this object as an xml node -func (s *Schema) AsXMLElement() *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Attribute = false - return s -} - -// AsWrappedXML flags this object as wrapped, this is mostly useful for array types -func (s *Schema) AsWrappedXML() *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Wrapped = true - return s -} - -// AsUnwrappedXML flags this object as an xml node -func (s *Schema) AsUnwrappedXML() *Schema { - if s.XML == nil { - s.XML = new(XMLObject) - } - s.XML.Wrapped = false - return s -} - -// MarshalJSON marshal this to JSON -func (s Schema) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(s.SchemaProps) - if err != nil { - return nil, fmt.Errorf("schema props %v", err) - } - b2, err := json.Marshal(s.VendorExtensible) - if err != nil { - return nil, fmt.Errorf("vendor props %v", err) - } - b3, err := s.Ref.MarshalJSON() - if err != nil { - return nil, fmt.Errorf("ref prop %v", err) - } - b4, err := s.Schema.MarshalJSON() - if err != nil { - return nil, fmt.Errorf("schema prop %v", err) - } - b5, err := json.Marshal(s.SwaggerSchemaProps) - if err != nil { - return nil, fmt.Errorf("common validations %v", err) - } - var b6 []byte - if s.ExtraProps != nil { - jj, err := json.Marshal(s.ExtraProps) - if err != nil { - return nil, fmt.Errorf("extra props %v", err) - } - b6 = jj - } - return swag.ConcatJSON(b1, b2, b3, b4, b5, b6), nil -} - -// UnmarshalJSON marshal this from JSON -func (s *Schema) UnmarshalJSON(data []byte) error { - var sch Schema - if err := json.Unmarshal(data, &sch.SchemaProps); err != nil { - return err - } - if err := json.Unmarshal(data, &sch.Ref); err != nil { - return err - } - if err := json.Unmarshal(data, &sch.Schema); err != nil { - return err - } - if err := json.Unmarshal(data, &sch.SwaggerSchemaProps); err != nil { - return err - } - - var d map[string]interface{} - if err := json.Unmarshal(data, &d); err != nil { - return err - } - - delete(d, "$ref") - delete(d, "$schema") - for _, pn := range swag.DefaultJSONNameProvider.GetJSONNames(s) { - delete(d, pn) - } - - for k, vv := range d { - lk := strings.ToLower(k) - if strings.HasPrefix(lk, "x-") { - if sch.Extensions == nil { - sch.Extensions = map[string]interface{}{} - } - sch.Extensions[k] = vv - continue - } - if sch.ExtraProps == nil { - sch.ExtraProps = map[string]interface{}{} - } - sch.ExtraProps[k] = vv - } - - *s = sch - - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/security_scheme.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/security_scheme.go deleted file mode 100644 index 22d4f10..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/security_scheme.go +++ /dev/null @@ -1,142 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -const ( - basic = "basic" - apiKey = "apiKey" - oauth2 = "oauth2" - implicit = "implicit" - password = "password" - application = "application" - accessCode = "accessCode" -) - -// BasicAuth creates a basic auth security scheme -func BasicAuth() *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{Type: basic}} -} - -// APIKeyAuth creates an api key auth security scheme -func APIKeyAuth(fieldName, valueSource string) *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{Type: apiKey, Name: fieldName, In: valueSource}} -} - -// OAuth2Implicit creates an implicit flow oauth2 security scheme -func OAuth2Implicit(authorizationURL string) *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{ - Type: oauth2, - Flow: implicit, - AuthorizationURL: authorizationURL, - }} -} - -// OAuth2Password creates a password flow oauth2 security scheme -func OAuth2Password(tokenURL string) *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{ - Type: oauth2, - Flow: password, - TokenURL: tokenURL, - }} -} - -// OAuth2Application creates an application flow oauth2 security scheme -func OAuth2Application(tokenURL string) *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{ - Type: oauth2, - Flow: application, - TokenURL: tokenURL, - }} -} - -// OAuth2AccessToken creates an access token flow oauth2 security scheme -func OAuth2AccessToken(authorizationURL, tokenURL string) *SecurityScheme { - return &SecurityScheme{SecuritySchemeProps: SecuritySchemeProps{ - Type: oauth2, - Flow: accessCode, - AuthorizationURL: authorizationURL, - TokenURL: tokenURL, - }} -} - -type SecuritySchemeProps struct { - Description string `json:"description,omitempty"` - Type string `json:"type"` - Name string `json:"name,omitempty"` // api key - In string `json:"in,omitempty"` // api key - Flow string `json:"flow,omitempty"` // oauth2 - AuthorizationURL string `json:"authorizationUrl,omitempty"` // oauth2 - TokenURL string `json:"tokenUrl,omitempty"` // oauth2 - Scopes map[string]string `json:"scopes,omitempty"` // oauth2 -} - -// AddScope adds a scope to this security scheme -func (s *SecuritySchemeProps) AddScope(scope, description string) { - if s.Scopes == nil { - s.Scopes = make(map[string]string) - } - s.Scopes[scope] = description -} - -// SecurityScheme allows the definition of a security scheme that can be used by the operations. -// Supported schemes are basic authentication, an API key (either as a header or as a query parameter) -// and OAuth2's common flows (implicit, password, application and access code). -// -// For more information: http://goo.gl/8us55a#securitySchemeObject -type SecurityScheme struct { - VendorExtensible - SecuritySchemeProps -} - -// JSONLookup implements an interface to customize json pointer lookup -func (s SecurityScheme) JSONLookup(token string) (interface{}, error) { - if ex, ok := s.Extensions[token]; ok { - return &ex, nil - } - - r, _, err := jsonpointer.GetForToken(s.SecuritySchemeProps, token) - return r, err -} - -// MarshalJSON marshal this to JSON -func (s SecurityScheme) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(s.SecuritySchemeProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(s.VendorExtensible) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2), nil -} - -// UnmarshalJSON marshal this from JSON -func (s *SecurityScheme) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &s.SecuritySchemeProps); err != nil { - return err - } - if err := json.Unmarshal(data, &s.VendorExtensible); err != nil { - return err - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/spec.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/spec.go deleted file mode 100644 index cc2ae56..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/spec.go +++ /dev/null @@ -1,79 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import "encoding/json" - -//go:generate go-bindata -pkg=spec -prefix=./schemas -ignore=.*\.md ./schemas/... -//go:generate perl -pi -e s,Json,JSON,g bindata.go - -const ( - // SwaggerSchemaURL the url for the swagger 2.0 schema to validate specs - SwaggerSchemaURL = "http://swagger.io/v2/schema.json#" - // JSONSchemaURL the url for the json schema schema - JSONSchemaURL = "http://json-schema.org/draft-04/schema#" -) - -var ( - jsonSchema = MustLoadJSONSchemaDraft04() - swaggerSchema = MustLoadSwagger20Schema() -) - -// MustLoadJSONSchemaDraft04 panics when Swagger20Schema returns an error -func MustLoadJSONSchemaDraft04() *Schema { - d, e := JSONSchemaDraft04() - if e != nil { - panic(e) - } - return d -} - -// JSONSchemaDraft04 loads the json schema document for json shema draft04 -func JSONSchemaDraft04() (*Schema, error) { - b, err := Asset("jsonschema-draft-04.json") - if err != nil { - return nil, err - } - - schema := new(Schema) - if err := json.Unmarshal(b, schema); err != nil { - return nil, err - } - return schema, nil -} - -// MustLoadSwagger20Schema panics when Swagger20Schema returns an error -func MustLoadSwagger20Schema() *Schema { - d, e := Swagger20Schema() - if e != nil { - panic(e) - } - return d -} - -// Swagger20Schema loads the swagger 2.0 schema from the embedded assets -func Swagger20Schema() (*Schema, error) { - - b, err := Asset("v2/schema.json") - if err != nil { - return nil, err - } - - schema := new(Schema) - if err := json.Unmarshal(b, schema); err != nil { - return nil, err - } - return schema, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/swagger.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/swagger.go deleted file mode 100644 index ff3ef87..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/swagger.go +++ /dev/null @@ -1,317 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - "fmt" - "strconv" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -// Swagger this is the root document object for the API specification. -// It combines what previously was the Resource Listing and API Declaration (version 1.2 and earlier) together into one document. -// -// For more information: http://goo.gl/8us55a#swagger-object- -type Swagger struct { - VendorExtensible - SwaggerProps -} - -// JSONLookup look up a value by the json property name -func (s Swagger) JSONLookup(token string) (interface{}, error) { - if ex, ok := s.Extensions[token]; ok { - return &ex, nil - } - r, _, err := jsonpointer.GetForToken(s.SwaggerProps, token) - return r, err -} - -// MarshalJSON marshals this swagger structure to json -func (s Swagger) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(s.SwaggerProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(s.VendorExtensible) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2), nil -} - -// UnmarshalJSON unmarshals a swagger spec from json -func (s *Swagger) UnmarshalJSON(data []byte) error { - var sw Swagger - if err := json.Unmarshal(data, &sw.SwaggerProps); err != nil { - return err - } - if err := json.Unmarshal(data, &sw.VendorExtensible); err != nil { - return err - } - *s = sw - return nil -} - -type SwaggerProps struct { - ID string `json:"id,omitempty"` - Consumes []string `json:"consumes,omitempty"` - Produces []string `json:"produces,omitempty"` - Schemes []string `json:"schemes,omitempty"` // the scheme, when present must be from [http, https, ws, wss] - Swagger string `json:"swagger,omitempty"` - Info *Info `json:"info,omitempty"` - Host string `json:"host,omitempty"` - BasePath string `json:"basePath,omitempty"` // must start with a leading "/" - Paths *Paths `json:"paths"` // required - Definitions Definitions `json:"definitions"` - Parameters map[string]Parameter `json:"parameters,omitempty"` - Responses map[string]Response `json:"responses,omitempty"` - SecurityDefinitions SecurityDefinitions `json:"securityDefinitions,omitempty"` - Security []map[string][]string `json:"security,omitempty"` - Tags []Tag `json:"tags,omitempty"` - ExternalDocs *ExternalDocumentation `json:"externalDocs,omitempty"` -} - -// Dependencies represent a dependencies property -type Dependencies map[string]SchemaOrStringArray - -// SchemaOrBool represents a schema or boolean value, is biased towards true for the boolean property -type SchemaOrBool struct { - Allows bool - Schema *Schema -} - -// JSONLookup implements an interface to customize json pointer lookup -func (s SchemaOrBool) JSONLookup(token string) (interface{}, error) { - if token == "allows" { - return s.Allows, nil - } - r, _, err := jsonpointer.GetForToken(s.Schema, token) - return r, err -} - -var jsTrue = []byte("true") -var jsFalse = []byte("false") - -// MarshalJSON convert this object to JSON -func (s SchemaOrBool) MarshalJSON() ([]byte, error) { - if s.Schema != nil { - return json.Marshal(s.Schema) - } - - if s.Schema == nil && !s.Allows { - return jsFalse, nil - } - return jsTrue, nil -} - -// UnmarshalJSON converts this bool or schema object from a JSON structure -func (s *SchemaOrBool) UnmarshalJSON(data []byte) error { - var nw SchemaOrBool - if len(data) >= 4 { - if data[0] == '{' { - var sch Schema - if err := json.Unmarshal(data, &sch); err != nil { - return err - } - nw.Schema = &sch - } - nw.Allows = !(data[0] == 'f' && data[1] == 'a' && data[2] == 'l' && data[3] == 's' && data[4] == 'e') - } - *s = nw - return nil -} - -// SchemaOrStringArray represents a schema or a string array -type SchemaOrStringArray struct { - Schema *Schema - Property []string -} - -// JSONLookup implements an interface to customize json pointer lookup -func (s SchemaOrStringArray) JSONLookup(token string) (interface{}, error) { - r, _, err := jsonpointer.GetForToken(s.Schema, token) - return r, err -} - -// MarshalJSON converts this schema object or array into JSON structure -func (s SchemaOrStringArray) MarshalJSON() ([]byte, error) { - if len(s.Property) > 0 { - return json.Marshal(s.Property) - } - if s.Schema != nil { - return json.Marshal(s.Schema) - } - return nil, nil -} - -// UnmarshalJSON converts this schema object or array from a JSON structure -func (s *SchemaOrStringArray) UnmarshalJSON(data []byte) error { - var first byte - if len(data) > 1 { - first = data[0] - } - var nw SchemaOrStringArray - if first == '{' { - var sch Schema - if err := json.Unmarshal(data, &sch); err != nil { - return err - } - nw.Schema = &sch - } - if first == '[' { - if err := json.Unmarshal(data, &nw.Property); err != nil { - return err - } - } - *s = nw - return nil -} - -// Definitions contains the models explicitly defined in this spec -// An object to hold data types that can be consumed and produced by operations. -// These data types can be primitives, arrays or models. -// -// For more information: http://goo.gl/8us55a#definitionsObject -type Definitions map[string]Schema - -// SecurityDefinitions a declaration of the security schemes available to be used in the specification. -// This does not enforce the security schemes on the operations and only serves to provide -// the relevant details for each scheme. -// -// For more information: http://goo.gl/8us55a#securityDefinitionsObject -type SecurityDefinitions map[string]*SecurityScheme - -// StringOrArray represents a value that can either be a string -// or an array of strings. Mainly here for serialization purposes -type StringOrArray []string - -// Contains returns true when the value is contained in the slice -func (s StringOrArray) Contains(value string) bool { - for _, str := range s { - if str == value { - return true - } - } - return false -} - -// JSONLookup implements an interface to customize json pointer lookup -func (s SchemaOrArray) JSONLookup(token string) (interface{}, error) { - if _, err := strconv.Atoi(token); err == nil { - r, _, err := jsonpointer.GetForToken(s.Schemas, token) - return r, err - } - r, _, err := jsonpointer.GetForToken(s.Schema, token) - return r, err -} - -// UnmarshalJSON unmarshals this string or array object from a JSON array or JSON string -func (s *StringOrArray) UnmarshalJSON(data []byte) error { - var first byte - if len(data) > 1 { - first = data[0] - } - - if first == '[' { - var parsed []string - if err := json.Unmarshal(data, &parsed); err != nil { - return err - } - *s = StringOrArray(parsed) - return nil - } - - var single interface{} - if err := json.Unmarshal(data, &single); err != nil { - return err - } - if single == nil { - return nil - } - switch single.(type) { - case string: - *s = StringOrArray([]string{single.(string)}) - return nil - default: - return fmt.Errorf("only string or array is allowed, not %T", single) - } -} - -// MarshalJSON converts this string or array to a JSON array or JSON string -func (s StringOrArray) MarshalJSON() ([]byte, error) { - if len(s) == 1 { - return json.Marshal([]string(s)[0]) - } - return json.Marshal([]string(s)) -} - -// SchemaOrArray represents a value that can either be a Schema -// or an array of Schema. Mainly here for serialization purposes -type SchemaOrArray struct { - Schema *Schema - Schemas []Schema -} - -// Len returns the number of schemas in this property -func (s SchemaOrArray) Len() int { - if s.Schema != nil { - return 1 - } - return len(s.Schemas) -} - -// ContainsType returns true when one of the schemas is of the specified type -func (s *SchemaOrArray) ContainsType(name string) bool { - if s.Schema != nil { - return s.Schema.Type != nil && s.Schema.Type.Contains(name) - } - return false -} - -// MarshalJSON converts this schema object or array into JSON structure -func (s SchemaOrArray) MarshalJSON() ([]byte, error) { - if len(s.Schemas) > 0 { - return json.Marshal(s.Schemas) - } - return json.Marshal(s.Schema) -} - -// UnmarshalJSON converts this schema object or array from a JSON structure -func (s *SchemaOrArray) UnmarshalJSON(data []byte) error { - var nw SchemaOrArray - var first byte - if len(data) > 1 { - first = data[0] - } - if first == '{' { - var sch Schema - if err := json.Unmarshal(data, &sch); err != nil { - return err - } - nw.Schema = &sch - } - if first == '[' { - if err := json.Unmarshal(data, &nw.Schemas); err != nil { - return err - } - } - *s = nw - return nil -} - -// vim:set ft=go noet sts=2 sw=2 ts=2: diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/tag.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/tag.go deleted file mode 100644 index 97f5558..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/tag.go +++ /dev/null @@ -1,73 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -import ( - "encoding/json" - - "github.com/go-openapi/jsonpointer" - "github.com/go-openapi/swag" -) - -type TagProps struct { - Description string `json:"description,omitempty"` - Name string `json:"name,omitempty"` - ExternalDocs *ExternalDocumentation `json:"externalDocs,omitempty"` -} - -// NewTag creates a new tag -func NewTag(name, description string, externalDocs *ExternalDocumentation) Tag { - return Tag{TagProps: TagProps{description, name, externalDocs}} -} - -// Tag allows adding meta data to a single tag that is used by the [Operation Object](http://goo.gl/8us55a#operationObject). -// It is not mandatory to have a Tag Object per tag used there. -// -// For more information: http://goo.gl/8us55a#tagObject -type Tag struct { - VendorExtensible - TagProps -} - -// JSONLookup implements an interface to customize json pointer lookup -func (t Tag) JSONLookup(token string) (interface{}, error) { - if ex, ok := t.Extensions[token]; ok { - return &ex, nil - } - - r, _, err := jsonpointer.GetForToken(t.TagProps, token) - return r, err -} - -// MarshalJSON marshal this to JSON -func (t Tag) MarshalJSON() ([]byte, error) { - b1, err := json.Marshal(t.TagProps) - if err != nil { - return nil, err - } - b2, err := json.Marshal(t.VendorExtensible) - if err != nil { - return nil, err - } - return swag.ConcatJSON(b1, b2), nil -} - -// UnmarshalJSON marshal this from JSON -func (t *Tag) UnmarshalJSON(data []byte) error { - if err := json.Unmarshal(data, &t.TagProps); err != nil { - return err - } - return json.Unmarshal(data, &t.VendorExtensible) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/xml_object.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/xml_object.go deleted file mode 100644 index 945a467..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/spec/xml_object.go +++ /dev/null @@ -1,68 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 spec - -// XMLObject a metadata object that allows for more fine-tuned XML model definitions. -// -// For more information: http://goo.gl/8us55a#xmlObject -type XMLObject struct { - Name string `json:"name,omitempty"` - Namespace string `json:"namespace,omitempty"` - Prefix string `json:"prefix,omitempty"` - Attribute bool `json:"attribute,omitempty"` - Wrapped bool `json:"wrapped,omitempty"` -} - -// WithName sets the xml name for the object -func (x *XMLObject) WithName(name string) *XMLObject { - x.Name = name - return x -} - -// WithNamespace sets the xml namespace for the object -func (x *XMLObject) WithNamespace(namespace string) *XMLObject { - x.Namespace = namespace - return x -} - -// WithPrefix sets the xml prefix for the object -func (x *XMLObject) WithPrefix(prefix string) *XMLObject { - x.Prefix = prefix - return x -} - -// AsAttribute flags this object as xml attribute -func (x *XMLObject) AsAttribute() *XMLObject { - x.Attribute = true - return x -} - -// AsElement flags this object as an xml node -func (x *XMLObject) AsElement() *XMLObject { - x.Attribute = false - return x -} - -// AsWrapped flags this object as wrapped, this is mostly useful for array types -func (x *XMLObject) AsWrapped() *XMLObject { - x.Wrapped = true - return x -} - -// AsUnwrapped flags this object as an xml node -func (x *XMLObject) AsUnwrapped() *XMLObject { - x.Wrapped = false - return x -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.gitignore deleted file mode 100644 index 769c244..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.gitignore +++ /dev/null @@ -1 +0,0 @@ -secrets.yml diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.pullapprove.yml b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.pullapprove.yml deleted file mode 100644 index 5ec183e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/.pullapprove.yml +++ /dev/null @@ -1,13 +0,0 @@ -approve_by_comment: true -approve_regex: '^(:shipit:|:\+1:|\+1|LGTM|lgtm|Approved)' -reject_regex: ^[Rr]ejected -reset_on_push: false -reviewers: - members: - - casualjim - - chancez - - frapposelli - - vburenin - - pytlesk4 - name: pullapprove - required: 1 diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/CODE_OF_CONDUCT.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/CODE_OF_CONDUCT.md deleted file mode 100644 index 9322b06..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/CODE_OF_CONDUCT.md +++ /dev/null @@ -1,74 +0,0 @@ -# Contributor Covenant Code of Conduct - -## Our Pledge - -In the interest of fostering an open and welcoming environment, we as -contributors and maintainers pledge to making participation in our project and -our community a harassment-free experience for everyone, regardless of age, body -size, disability, ethnicity, gender identity and expression, level of experience, -nationality, personal appearance, race, religion, or sexual identity and -orientation. - -## Our Standards - -Examples of behavior that contributes to creating a positive environment -include: - -* Using welcoming and inclusive language -* Being respectful of differing viewpoints and experiences -* Gracefully accepting constructive criticism -* Focusing on what is best for the community -* Showing empathy towards other community members - -Examples of unacceptable behavior by participants include: - -* The use of sexualized language or imagery and unwelcome sexual attention or -advances -* Trolling, insulting/derogatory comments, and personal or political attacks -* Public or private harassment -* Publishing others' private information, such as a physical or electronic - address, without explicit permission -* Other conduct which could reasonably be considered inappropriate in a - professional setting - -## Our Responsibilities - -Project maintainers are responsible for clarifying the standards of acceptable -behavior and are expected to take appropriate and fair corrective action in -response to any instances of unacceptable behavior. - -Project maintainers have the right and responsibility to remove, edit, or -reject comments, commits, code, wiki edits, issues, and other contributions -that are not aligned to this Code of Conduct, or to ban temporarily or -permanently any contributor for other behaviors that they deem inappropriate, -threatening, offensive, or harmful. - -## Scope - -This Code of Conduct applies both within project spaces and in public spaces -when an individual is representing the project or its community. Examples of -representing a project or community include using an official project e-mail -address, posting via an official social media account, or acting as an appointed -representative at an online or offline event. Representation of a project may be -further defined and clarified by project maintainers. - -## Enforcement - -Instances of abusive, harassing, or otherwise unacceptable behavior may be -reported by contacting the project team at ivan+abuse@flanders.co.nz. All -complaints will be reviewed and investigated and will result in a response that -is deemed necessary and appropriate to the circumstances. The project team is -obligated to maintain confidentiality with regard to the reporter of an incident. -Further details of specific enforcement policies may be posted separately. - -Project maintainers who do not follow or enforce the Code of Conduct in good -faith may face temporary or permanent repercussions as determined by other -members of the project's leadership. - -## Attribution - -This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, -available at [http://contributor-covenant.org/version/1/4][version] - -[homepage]: http://contributor-covenant.org -[version]: http://contributor-covenant.org/version/1/4/ diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/README.md deleted file mode 100644 index c1d3c19..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/README.md +++ /dev/null @@ -1,12 +0,0 @@ -# Swag [![Build Status](https://ci.vmware.run/api/badges/go-openapi/swag/status.svg)](https://ci.vmware.run/go-openapi/swag) [![Coverage](https://coverage.vmware.run/badges/go-openapi/swag/coverage.svg)](https://coverage.vmware.run/go-openapi/swag) [![Slack Status](https://slackin.goswagger.io/badge.svg)](https://slackin.goswagger.io) - -[![license](http://img.shields.io/badge/license-Apache%20v2-orange.svg)](https://raw.githubusercontent.com/go-openapi/swag/master/LICENSE) [![GoDoc](https://godoc.org/github.com/go-openapi/swag?status.svg)](http://godoc.org/github.com/go-openapi/swag) - -Contains a bunch of helper functions: - -* convert between value and pointers for builtins -* convert from string to builtin -* fast json concatenation -* search in path -* load from file or http -* name manglin \ No newline at end of file diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert.go deleted file mode 100644 index 28d9124..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert.go +++ /dev/null @@ -1,188 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 swag - -import ( - "math" - "strconv" - "strings" -) - -// same as ECMA Number.MAX_SAFE_INTEGER and Number.MIN_SAFE_INTEGER -const ( - maxJSONFloat = float64(1<<53 - 1) // 9007199254740991.0 2^53 - 1 - minJSONFloat = -float64(1<<53 - 1) //-9007199254740991.0 -2^53 - 1 -) - -// IsFloat64AJSONInteger allow for integers [-2^53, 2^53-1] inclusive -func IsFloat64AJSONInteger(f float64) bool { - if math.IsNaN(f) || math.IsInf(f, 0) || f < minJSONFloat || f > maxJSONFloat { - return false - } - - return f == float64(int64(f)) || f == float64(uint64(f)) -} - -var evaluatesAsTrue = map[string]struct{}{ - "true": struct{}{}, - "1": struct{}{}, - "yes": struct{}{}, - "ok": struct{}{}, - "y": struct{}{}, - "on": struct{}{}, - "selected": struct{}{}, - "checked": struct{}{}, - "t": struct{}{}, - "enabled": struct{}{}, -} - -// ConvertBool turn a string into a boolean -func ConvertBool(str string) (bool, error) { - _, ok := evaluatesAsTrue[strings.ToLower(str)] - return ok, nil -} - -// ConvertFloat32 turn a string into a float32 -func ConvertFloat32(str string) (float32, error) { - f, err := strconv.ParseFloat(str, 32) - if err != nil { - return 0, err - } - return float32(f), nil -} - -// ConvertFloat64 turn a string into a float64 -func ConvertFloat64(str string) (float64, error) { - return strconv.ParseFloat(str, 64) -} - -// ConvertInt8 turn a string into int8 boolean -func ConvertInt8(str string) (int8, error) { - i, err := strconv.ParseInt(str, 10, 8) - if err != nil { - return 0, err - } - return int8(i), nil -} - -// ConvertInt16 turn a string into a int16 -func ConvertInt16(str string) (int16, error) { - i, err := strconv.ParseInt(str, 10, 16) - if err != nil { - return 0, err - } - return int16(i), nil -} - -// ConvertInt32 turn a string into a int32 -func ConvertInt32(str string) (int32, error) { - i, err := strconv.ParseInt(str, 10, 32) - if err != nil { - return 0, err - } - return int32(i), nil -} - -// ConvertInt64 turn a string into a int64 -func ConvertInt64(str string) (int64, error) { - return strconv.ParseInt(str, 10, 64) -} - -// ConvertUint8 turn a string into a uint8 -func ConvertUint8(str string) (uint8, error) { - i, err := strconv.ParseUint(str, 10, 8) - if err != nil { - return 0, err - } - return uint8(i), nil -} - -// ConvertUint16 turn a string into a uint16 -func ConvertUint16(str string) (uint16, error) { - i, err := strconv.ParseUint(str, 10, 16) - if err != nil { - return 0, err - } - return uint16(i), nil -} - -// ConvertUint32 turn a string into a uint32 -func ConvertUint32(str string) (uint32, error) { - i, err := strconv.ParseUint(str, 10, 32) - if err != nil { - return 0, err - } - return uint32(i), nil -} - -// ConvertUint64 turn a string into a uint64 -func ConvertUint64(str string) (uint64, error) { - return strconv.ParseUint(str, 10, 64) -} - -// FormatBool turns a boolean into a string -func FormatBool(value bool) string { - return strconv.FormatBool(value) -} - -// FormatFloat32 turns a float32 into a string -func FormatFloat32(value float32) string { - return strconv.FormatFloat(float64(value), 'f', -1, 32) -} - -// FormatFloat64 turns a float64 into a string -func FormatFloat64(value float64) string { - return strconv.FormatFloat(value, 'f', -1, 64) -} - -// FormatInt8 turns an int8 into a string -func FormatInt8(value int8) string { - return strconv.FormatInt(int64(value), 10) -} - -// FormatInt16 turns an int16 into a string -func FormatInt16(value int16) string { - return strconv.FormatInt(int64(value), 10) -} - -// FormatInt32 turns an int32 into a string -func FormatInt32(value int32) string { - return strconv.FormatInt(int64(value), 10) -} - -// FormatInt64 turns an int64 into a string -func FormatInt64(value int64) string { - return strconv.FormatInt(value, 10) -} - -// FormatUint8 turns an uint8 into a string -func FormatUint8(value uint8) string { - return strconv.FormatUint(uint64(value), 10) -} - -// FormatUint16 turns an uint16 into a string -func FormatUint16(value uint16) string { - return strconv.FormatUint(uint64(value), 10) -} - -// FormatUint32 turns an uint32 into a string -func FormatUint32(value uint32) string { - return strconv.FormatUint(uint64(value), 10) -} - -// FormatUint64 turns an uint64 into a string -func FormatUint64(value uint64) string { - return strconv.FormatUint(value, 10) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert_types.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert_types.go deleted file mode 100644 index c95e4e7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/convert_types.go +++ /dev/null @@ -1,595 +0,0 @@ -package swag - -import "time" - -// This file was taken from the aws go sdk - -// String returns a pointer to of the string value passed in. -func String(v string) *string { - return &v -} - -// StringValue returns the value of the string pointer passed in or -// "" if the pointer is nil. -func StringValue(v *string) string { - if v != nil { - return *v - } - return "" -} - -// StringSlice converts a slice of string values into a slice of -// string pointers -func StringSlice(src []string) []*string { - dst := make([]*string, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// StringValueSlice converts a slice of string pointers into a slice of -// string values -func StringValueSlice(src []*string) []string { - dst := make([]string, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// StringMap converts a string map of string values into a string -// map of string pointers -func StringMap(src map[string]string) map[string]*string { - dst := make(map[string]*string) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// StringValueMap converts a string map of string pointers into a string -// map of string values -func StringValueMap(src map[string]*string) map[string]string { - dst := make(map[string]string) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Bool returns a pointer to of the bool value passed in. -func Bool(v bool) *bool { - return &v -} - -// BoolValue returns the value of the bool pointer passed in or -// false if the pointer is nil. -func BoolValue(v *bool) bool { - if v != nil { - return *v - } - return false -} - -// BoolSlice converts a slice of bool values into a slice of -// bool pointers -func BoolSlice(src []bool) []*bool { - dst := make([]*bool, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// BoolValueSlice converts a slice of bool pointers into a slice of -// bool values -func BoolValueSlice(src []*bool) []bool { - dst := make([]bool, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// BoolMap converts a string map of bool values into a string -// map of bool pointers -func BoolMap(src map[string]bool) map[string]*bool { - dst := make(map[string]*bool) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// BoolValueMap converts a string map of bool pointers into a string -// map of bool values -func BoolValueMap(src map[string]*bool) map[string]bool { - dst := make(map[string]bool) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Int returns a pointer to of the int value passed in. -func Int(v int) *int { - return &v -} - -// IntValue returns the value of the int pointer passed in or -// 0 if the pointer is nil. -func IntValue(v *int) int { - if v != nil { - return *v - } - return 0 -} - -// IntSlice converts a slice of int values into a slice of -// int pointers -func IntSlice(src []int) []*int { - dst := make([]*int, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// IntValueSlice converts a slice of int pointers into a slice of -// int values -func IntValueSlice(src []*int) []int { - dst := make([]int, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// IntMap converts a string map of int values into a string -// map of int pointers -func IntMap(src map[string]int) map[string]*int { - dst := make(map[string]*int) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// IntValueMap converts a string map of int pointers into a string -// map of int values -func IntValueMap(src map[string]*int) map[string]int { - dst := make(map[string]int) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Int32 returns a pointer to of the int64 value passed in. -func Int32(v int32) *int32 { - return &v -} - -// Int32Value returns the value of the int64 pointer passed in or -// 0 if the pointer is nil. -func Int32Value(v *int32) int32 { - if v != nil { - return *v - } - return 0 -} - -// Int32Slice converts a slice of int64 values into a slice of -// int32 pointers -func Int32Slice(src []int32) []*int32 { - dst := make([]*int32, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// Int32ValueSlice converts a slice of int32 pointers into a slice of -// int32 values -func Int32ValueSlice(src []*int32) []int32 { - dst := make([]int32, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// Int32Map converts a string map of int32 values into a string -// map of int32 pointers -func Int32Map(src map[string]int32) map[string]*int32 { - dst := make(map[string]*int32) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// Int32ValueMap converts a string map of int32 pointers into a string -// map of int32 values -func Int32ValueMap(src map[string]*int32) map[string]int32 { - dst := make(map[string]int32) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Int64 returns a pointer to of the int64 value passed in. -func Int64(v int64) *int64 { - return &v -} - -// Int64Value returns the value of the int64 pointer passed in or -// 0 if the pointer is nil. -func Int64Value(v *int64) int64 { - if v != nil { - return *v - } - return 0 -} - -// Int64Slice converts a slice of int64 values into a slice of -// int64 pointers -func Int64Slice(src []int64) []*int64 { - dst := make([]*int64, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// Int64ValueSlice converts a slice of int64 pointers into a slice of -// int64 values -func Int64ValueSlice(src []*int64) []int64 { - dst := make([]int64, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// Int64Map converts a string map of int64 values into a string -// map of int64 pointers -func Int64Map(src map[string]int64) map[string]*int64 { - dst := make(map[string]*int64) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// Int64ValueMap converts a string map of int64 pointers into a string -// map of int64 values -func Int64ValueMap(src map[string]*int64) map[string]int64 { - dst := make(map[string]int64) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Uint returns a pouinter to of the uint value passed in. -func Uint(v uint) *uint { - return &v -} - -// UintValue returns the value of the uint pouinter passed in or -// 0 if the pouinter is nil. -func UintValue(v *uint) uint { - if v != nil { - return *v - } - return 0 -} - -// UintSlice converts a slice of uint values uinto a slice of -// uint pouinters -func UintSlice(src []uint) []*uint { - dst := make([]*uint, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// UintValueSlice converts a slice of uint pouinters uinto a slice of -// uint values -func UintValueSlice(src []*uint) []uint { - dst := make([]uint, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// UintMap converts a string map of uint values uinto a string -// map of uint pouinters -func UintMap(src map[string]uint) map[string]*uint { - dst := make(map[string]*uint) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// UintValueMap converts a string map of uint pouinters uinto a string -// map of uint values -func UintValueMap(src map[string]*uint) map[string]uint { - dst := make(map[string]uint) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Uint32 returns a pouinter to of the uint64 value passed in. -func Uint32(v uint32) *uint32 { - return &v -} - -// Uint32Value returns the value of the uint64 pouinter passed in or -// 0 if the pouinter is nil. -func Uint32Value(v *uint32) uint32 { - if v != nil { - return *v - } - return 0 -} - -// Uint32Slice converts a slice of uint64 values uinto a slice of -// uint32 pouinters -func Uint32Slice(src []uint32) []*uint32 { - dst := make([]*uint32, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// Uint32ValueSlice converts a slice of uint32 pouinters uinto a slice of -// uint32 values -func Uint32ValueSlice(src []*uint32) []uint32 { - dst := make([]uint32, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// Uint32Map converts a string map of uint32 values uinto a string -// map of uint32 pouinters -func Uint32Map(src map[string]uint32) map[string]*uint32 { - dst := make(map[string]*uint32) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// Uint32ValueMap converts a string map of uint32 pouinters uinto a string -// map of uint32 values -func Uint32ValueMap(src map[string]*uint32) map[string]uint32 { - dst := make(map[string]uint32) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Uint64 returns a pouinter to of the uint64 value passed in. -func Uint64(v uint64) *uint64 { - return &v -} - -// Uint64Value returns the value of the uint64 pouinter passed in or -// 0 if the pouinter is nil. -func Uint64Value(v *uint64) uint64 { - if v != nil { - return *v - } - return 0 -} - -// Uint64Slice converts a slice of uint64 values uinto a slice of -// uint64 pouinters -func Uint64Slice(src []uint64) []*uint64 { - dst := make([]*uint64, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// Uint64ValueSlice converts a slice of uint64 pouinters uinto a slice of -// uint64 values -func Uint64ValueSlice(src []*uint64) []uint64 { - dst := make([]uint64, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// Uint64Map converts a string map of uint64 values uinto a string -// map of uint64 pouinters -func Uint64Map(src map[string]uint64) map[string]*uint64 { - dst := make(map[string]*uint64) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// Uint64ValueMap converts a string map of uint64 pouinters uinto a string -// map of uint64 values -func Uint64ValueMap(src map[string]*uint64) map[string]uint64 { - dst := make(map[string]uint64) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Float64 returns a pointer to of the float64 value passed in. -func Float64(v float64) *float64 { - return &v -} - -// Float64Value returns the value of the float64 pointer passed in or -// 0 if the pointer is nil. -func Float64Value(v *float64) float64 { - if v != nil { - return *v - } - return 0 -} - -// Float64Slice converts a slice of float64 values into a slice of -// float64 pointers -func Float64Slice(src []float64) []*float64 { - dst := make([]*float64, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// Float64ValueSlice converts a slice of float64 pointers into a slice of -// float64 values -func Float64ValueSlice(src []*float64) []float64 { - dst := make([]float64, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// Float64Map converts a string map of float64 values into a string -// map of float64 pointers -func Float64Map(src map[string]float64) map[string]*float64 { - dst := make(map[string]*float64) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// Float64ValueMap converts a string map of float64 pointers into a string -// map of float64 values -func Float64ValueMap(src map[string]*float64) map[string]float64 { - dst := make(map[string]float64) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} - -// Time returns a pointer to of the time.Time value passed in. -func Time(v time.Time) *time.Time { - return &v -} - -// TimeValue returns the value of the time.Time pointer passed in or -// time.Time{} if the pointer is nil. -func TimeValue(v *time.Time) time.Time { - if v != nil { - return *v - } - return time.Time{} -} - -// TimeSlice converts a slice of time.Time values into a slice of -// time.Time pointers -func TimeSlice(src []time.Time) []*time.Time { - dst := make([]*time.Time, len(src)) - for i := 0; i < len(src); i++ { - dst[i] = &(src[i]) - } - return dst -} - -// TimeValueSlice converts a slice of time.Time pointers into a slice of -// time.Time values -func TimeValueSlice(src []*time.Time) []time.Time { - dst := make([]time.Time, len(src)) - for i := 0; i < len(src); i++ { - if src[i] != nil { - dst[i] = *(src[i]) - } - } - return dst -} - -// TimeMap converts a string map of time.Time values into a string -// map of time.Time pointers -func TimeMap(src map[string]time.Time) map[string]*time.Time { - dst := make(map[string]*time.Time) - for k, val := range src { - v := val - dst[k] = &v - } - return dst -} - -// TimeValueMap converts a string map of time.Time pointers into a string -// map of time.Time values -func TimeValueMap(src map[string]*time.Time) map[string]time.Time { - dst := make(map[string]time.Time) - for k, val := range src { - if val != nil { - dst[k] = *val - } - } - return dst -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/json.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/json.go deleted file mode 100644 index 6e9ec20..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/json.go +++ /dev/null @@ -1,270 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 swag - -import ( - "bytes" - "encoding/json" - "reflect" - "strings" - "sync" - - "github.com/mailru/easyjson/jlexer" - "github.com/mailru/easyjson/jwriter" -) - -// DefaultJSONNameProvider the default cache for types -var DefaultJSONNameProvider = NewNameProvider() - -const comma = byte(',') - -var closers = map[byte]byte{ - '{': '}', - '[': ']', -} - -type ejMarshaler interface { - MarshalEasyJSON(w *jwriter.Writer) -} - -type ejUnmarshaler interface { - UnmarshalEasyJSON(w *jlexer.Lexer) -} - -// WriteJSON writes json data, prefers finding an appropriate interface to short-circuit the marshaller -// so it takes the fastest option available. -func WriteJSON(data interface{}) ([]byte, error) { - if d, ok := data.(ejMarshaler); ok { - jw := new(jwriter.Writer) - d.MarshalEasyJSON(jw) - return jw.BuildBytes() - } - if d, ok := data.(json.Marshaler); ok { - return d.MarshalJSON() - } - return json.Marshal(data) -} - -// ReadJSON reads json data, prefers finding an appropriate interface to short-circuit the unmarshaller -// so it takes the fastes option available -func ReadJSON(data []byte, value interface{}) error { - if d, ok := value.(ejUnmarshaler); ok { - jl := &jlexer.Lexer{Data: data} - d.UnmarshalEasyJSON(jl) - return jl.Error() - } - if d, ok := value.(json.Unmarshaler); ok { - return d.UnmarshalJSON(data) - } - return json.Unmarshal(data, value) -} - -// DynamicJSONToStruct converts an untyped json structure into a struct -func DynamicJSONToStruct(data interface{}, target interface{}) error { - // TODO: convert straight to a json typed map (mergo + iterate?) - b, err := WriteJSON(data) - if err != nil { - return err - } - if err := ReadJSON(b, target); err != nil { - return err - } - return nil -} - -// ConcatJSON concatenates multiple json objects efficiently -func ConcatJSON(blobs ...[]byte) []byte { - if len(blobs) == 0 { - return nil - } - if len(blobs) == 1 { - return blobs[0] - } - - last := len(blobs) - 1 - var opening, closing byte - a := 0 - idx := 0 - buf := bytes.NewBuffer(nil) - - for i, b := range blobs { - if len(b) > 0 && opening == 0 { // is this an array or an object? - opening, closing = b[0], closers[b[0]] - } - - if opening != '{' && opening != '[' { - continue // don't know how to concatenate non container objects - } - - if len(b) < 3 { // yep empty but also the last one, so closing this thing - if i == last && a > 0 { - buf.WriteByte(closing) - } - continue - } - - idx = 0 - if a > 0 { // we need to join with a comma for everything beyond the first non-empty item - buf.WriteByte(comma) - idx = 1 // this is not the first or the last so we want to drop the leading bracket - } - - if i != last { // not the last one, strip brackets - buf.Write(b[idx : len(b)-1]) - } else { // last one, strip only the leading bracket - buf.Write(b[idx:]) - } - a++ - } - // somehow it ended up being empty, so provide a default value - if buf.Len() == 0 { - buf.WriteByte(opening) - buf.WriteByte(closing) - } - return buf.Bytes() -} - -// ToDynamicJSON turns an object into a properly JSON typed structure -func ToDynamicJSON(data interface{}) interface{} { - // TODO: convert straight to a json typed map (mergo + iterate?) - b, _ := json.Marshal(data) - var res interface{} - json.Unmarshal(b, &res) - return res -} - -// FromDynamicJSON turns an object into a properly JSON typed structure -func FromDynamicJSON(data, target interface{}) error { - b, _ := json.Marshal(data) - return json.Unmarshal(b, target) -} - -// NameProvider represents an object capabale of translating from go property names -// to json property names -// This type is thread-safe. -type NameProvider struct { - lock *sync.Mutex - index map[reflect.Type]nameIndex -} - -type nameIndex struct { - jsonNames map[string]string - goNames map[string]string -} - -// NewNameProvider creates a new name provider -func NewNameProvider() *NameProvider { - return &NameProvider{ - lock: &sync.Mutex{}, - index: make(map[reflect.Type]nameIndex), - } -} - -func buildnameIndex(tpe reflect.Type, idx, reverseIdx map[string]string) { - for i := 0; i < tpe.NumField(); i++ { - targetDes := tpe.Field(i) - - if targetDes.PkgPath != "" { // unexported - continue - } - - if targetDes.Anonymous { // walk embedded structures tree down first - buildnameIndex(targetDes.Type, idx, reverseIdx) - continue - } - - if tag := targetDes.Tag.Get("json"); tag != "" { - - parts := strings.Split(tag, ",") - if len(parts) == 0 { - continue - } - - nm := parts[0] - if nm == "-" { - continue - } - if nm == "" { // empty string means we want to use the Go name - nm = targetDes.Name - } - - idx[nm] = targetDes.Name - reverseIdx[targetDes.Name] = nm - } - } -} - -func newNameIndex(tpe reflect.Type) nameIndex { - var idx = make(map[string]string, tpe.NumField()) - var reverseIdx = make(map[string]string, tpe.NumField()) - - buildnameIndex(tpe, idx, reverseIdx) - return nameIndex{jsonNames: idx, goNames: reverseIdx} -} - -// GetJSONNames gets all the json property names for a type -func (n *NameProvider) GetJSONNames(subject interface{}) []string { - tpe := reflect.Indirect(reflect.ValueOf(subject)).Type() - names, ok := n.index[tpe] - if !ok { - names = n.makeNameIndex(tpe) - } - - var res []string - for k := range names.jsonNames { - res = append(res, k) - } - return res -} - -// GetJSONName gets the json name for a go property name -func (n *NameProvider) GetJSONName(subject interface{}, name string) (string, bool) { - tpe := reflect.Indirect(reflect.ValueOf(subject)).Type() - return n.GetJSONNameForType(tpe, name) -} - -// GetJSONNameForType gets the json name for a go property name on a given type -func (n *NameProvider) GetJSONNameForType(tpe reflect.Type, name string) (string, bool) { - names, ok := n.index[tpe] - if !ok { - names = n.makeNameIndex(tpe) - } - nme, ok := names.goNames[name] - return nme, ok -} - -func (n *NameProvider) makeNameIndex(tpe reflect.Type) nameIndex { - n.lock.Lock() - defer n.lock.Unlock() - names := newNameIndex(tpe) - n.index[tpe] = names - return names -} - -// GetGoName gets the go name for a json property name -func (n *NameProvider) GetGoName(subject interface{}, name string) (string, bool) { - tpe := reflect.Indirect(reflect.ValueOf(subject)).Type() - return n.GetGoNameForType(tpe, name) -} - -// GetGoNameForType gets the go name for a given type for a json property name -func (n *NameProvider) GetGoNameForType(tpe reflect.Type, name string) (string, bool) { - names, ok := n.index[tpe] - if !ok { - names = n.makeNameIndex(tpe) - } - nme, ok := names.jsonNames[name] - return nme, ok -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/loading.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/loading.go deleted file mode 100644 index 6dbc313..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/loading.go +++ /dev/null @@ -1,49 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 swag - -import ( - "fmt" - "io/ioutil" - "net/http" - "strings" -) - -// LoadFromFileOrHTTP loads the bytes from a file or a remote http server based on the path passed in -func LoadFromFileOrHTTP(path string) ([]byte, error) { - return LoadStrategy(path, ioutil.ReadFile, loadHTTPBytes)(path) -} - -// LoadStrategy returns a loader function for a given path or uri -func LoadStrategy(path string, local, remote func(string) ([]byte, error)) func(string) ([]byte, error) { - if strings.HasPrefix(path, "http") { - return remote - } - return local -} - -func loadHTTPBytes(path string) ([]byte, error) { - resp, err := http.Get(path) - if err != nil { - return nil, err - } - defer resp.Body.Close() - - if resp.StatusCode != http.StatusOK { - return nil, fmt.Errorf("could not access document at %q [%s] ", path, resp.Status) - } - - return ioutil.ReadAll(resp.Body) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/net.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/net.go deleted file mode 100644 index 8323fa3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/net.go +++ /dev/null @@ -1,24 +0,0 @@ -package swag - -import ( - "net" - "strconv" -) - -// SplitHostPort splits a network address into a host and a port. -// The port is -1 when there is no port to be found -func SplitHostPort(addr string) (host string, port int, err error) { - h, p, err := net.SplitHostPort(addr) - if err != nil { - return "", -1, err - } - if p == "" { - return "", -1, &net.AddrError{Err: "missing port in address", Addr: addr} - } - - pi, err := strconv.Atoi(p) - if err != nil { - return "", -1, err - } - return h, pi, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/path.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/path.go deleted file mode 100644 index 273e9fb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/path.go +++ /dev/null @@ -1,56 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 swag - -import ( - "os" - "path/filepath" - "runtime" - "strings" -) - -const ( - // GOPATHKey represents the env key for gopath - GOPATHKey = "GOPATH" -) - -// FindInSearchPath finds a package in a provided lists of paths -func FindInSearchPath(searchPath, pkg string) string { - pathsList := filepath.SplitList(searchPath) - for _, path := range pathsList { - if evaluatedPath, err := filepath.EvalSymlinks(filepath.Join(path, "src", pkg)); err == nil { - if _, err := os.Stat(evaluatedPath); err == nil { - return evaluatedPath - } - } - } - return "" -} - -// FindInGoSearchPath finds a package in the $GOPATH:$GOROOT -func FindInGoSearchPath(pkg string) string { - return FindInSearchPath(FullGoSearchPath(), pkg) -} - -// FullGoSearchPath gets the search paths for finding packages -func FullGoSearchPath() string { - allPaths := os.Getenv(GOPATHKey) - if allPaths != "" { - allPaths = strings.Join([]string{allPaths, runtime.GOROOT()}, ":") - } else { - allPaths = runtime.GOROOT() - } - return allPaths -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/util.go b/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/util.go deleted file mode 100644 index d8b54ee..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/go-openapi/swag/util.go +++ /dev/null @@ -1,318 +0,0 @@ -// Copyright 2015 go-swagger maintainers -// -// 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 swag - -import ( - "math" - "reflect" - "regexp" - "sort" - "strings" -) - -// Taken from https://github.com/golang/lint/blob/1fab560e16097e5b69afb66eb93aab843ef77845/lint.go#L663-L698 -var commonInitialisms = map[string]bool{ - "API": true, - "ASCII": true, - "CPU": true, - "CSS": true, - "DNS": true, - "EOF": true, - "GUID": true, - "HTML": true, - "HTTPS": true, - "HTTP": true, - "ID": true, - "IP": true, - "JSON": true, - "LHS": true, - "QPS": true, - "RAM": true, - "RHS": true, - "RPC": true, - "SLA": true, - "SMTP": true, - "SSH": true, - "TCP": true, - "TLS": true, - "TTL": true, - "UDP": true, - "UUID": true, - "UID": true, - "UI": true, - "URI": true, - "URL": true, - "UTF8": true, - "VM": true, - "XML": true, - "XSRF": true, - "XSS": true, -} -var initialisms []string - -func init() { - for k := range commonInitialisms { - initialisms = append(initialisms, k) - } - sort.Sort(sort.Reverse(byLength(initialisms))) -} - -// JoinByFormat joins a string array by a known format: -// ssv: space separated value -// tsv: tab separated value -// pipes: pipe (|) separated value -// csv: comma separated value (default) -func JoinByFormat(data []string, format string) []string { - if len(data) == 0 { - return data - } - var sep string - switch format { - case "ssv": - sep = " " - case "tsv": - sep = "\t" - case "pipes": - sep = "|" - case "multi": - return data - default: - sep = "," - } - return []string{strings.Join(data, sep)} -} - -// SplitByFormat splits a string by a known format: -// ssv: space separated value -// tsv: tab separated value -// pipes: pipe (|) separated value -// csv: comma separated value (default) -func SplitByFormat(data, format string) []string { - if data == "" { - return nil - } - var sep string - switch format { - case "ssv": - sep = " " - case "tsv": - sep = "\t" - case "pipes": - sep = "|" - case "multi": - return nil - default: - sep = "," - } - var result []string - for _, s := range strings.Split(data, sep) { - if ts := strings.TrimSpace(s); ts != "" { - result = append(result, ts) - } - } - return result -} - -type byLength []string - -func (s byLength) Len() int { - return len(s) -} -func (s byLength) Swap(i, j int) { - s[i], s[j] = s[j], s[i] -} -func (s byLength) Less(i, j int) bool { - return len(s[i]) < len(s[j]) -} - -// Prepares strings by splitting by caps, spaces, dashes, and underscore -func split(str string) (words []string) { - repl := strings.NewReplacer( - "@", "At ", - "&", "And ", - "|", "Pipe ", - "$", "Dollar ", - "!", "Bang ", - "-", " ", - "_", " ", - ) - - rex1 := regexp.MustCompile(`(\p{Lu})`) - rex2 := regexp.MustCompile(`(\pL|\pM|\pN|\p{Pc})+`) - - str = trim(str) - - // Convert dash and underscore to spaces - str = repl.Replace(str) - - // Split when uppercase is found (needed for Snake) - str = rex1.ReplaceAllString(str, " $1") - // check if consecutive single char things make up an initialism - - for _, k := range initialisms { - str = strings.Replace(str, rex1.ReplaceAllString(k, " $1"), " "+k, -1) - } - // Get the final list of words - words = rex2.FindAllString(str, -1) - - return -} - -// Removes leading whitespaces -func trim(str string) string { - return strings.Trim(str, " ") -} - -// Shortcut to strings.ToUpper() -func upper(str string) string { - return strings.ToUpper(trim(str)) -} - -// Shortcut to strings.ToLower() -func lower(str string) string { - return strings.ToLower(trim(str)) -} - -// ToFileName lowercases and underscores a go type name -func ToFileName(name string) string { - var out []string - for _, w := range split(name) { - out = append(out, lower(w)) - } - return strings.Join(out, "_") -} - -// ToCommandName lowercases and underscores a go type name -func ToCommandName(name string) string { - var out []string - for _, w := range split(name) { - out = append(out, lower(w)) - } - return strings.Join(out, "-") -} - -// ToHumanNameLower represents a code name as a human series of words -func ToHumanNameLower(name string) string { - var out []string - for _, w := range split(name) { - if !commonInitialisms[upper(w)] { - out = append(out, lower(w)) - } else { - out = append(out, w) - } - } - return strings.Join(out, " ") -} - -// ToHumanNameTitle represents a code name as a human series of words with the first letters titleized -func ToHumanNameTitle(name string) string { - var out []string - for _, w := range split(name) { - uw := upper(w) - if !commonInitialisms[uw] { - out = append(out, upper(w[:1])+lower(w[1:])) - } else { - out = append(out, w) - } - } - return strings.Join(out, " ") -} - -// ToJSONName camelcases a name which can be underscored or pascal cased -func ToJSONName(name string) string { - var out []string - for i, w := range split(name) { - if i == 0 { - out = append(out, lower(w)) - continue - } - out = append(out, upper(w[:1])+lower(w[1:])) - } - return strings.Join(out, "") -} - -// ToVarName camelcases a name which can be underscored or pascal cased -func ToVarName(name string) string { - res := ToGoName(name) - if len(res) <= 1 { - return lower(res) - } - return lower(res[:1]) + res[1:] -} - -// ToGoName translates a swagger name which can be underscored or camel cased to a name that golint likes -func ToGoName(name string) string { - var out []string - for _, w := range split(name) { - uw := upper(w) - mod := int(math.Min(float64(len(uw)), 2)) - if !commonInitialisms[uw] && !commonInitialisms[uw[:len(uw)-mod]] { - uw = upper(w[:1]) + lower(w[1:]) - } - out = append(out, uw) - } - return strings.Join(out, "") -} - -// ContainsStringsCI searches a slice of strings for a case-insensitive match -func ContainsStringsCI(coll []string, item string) bool { - for _, a := range coll { - if strings.EqualFold(a, item) { - return true - } - } - return false -} - -type zeroable interface { - IsZero() bool -} - -// IsZero returns true when the value passed into the function is a zero value. -// This allows for safer checking of interface values. -func IsZero(data interface{}) bool { - // check for things that have an IsZero method instead - if vv, ok := data.(zeroable); ok { - return vv.IsZero() - } - // continue with slightly more complex reflection - v := reflect.ValueOf(data) - switch v.Kind() { - case reflect.String: - return v.Len() == 0 - case reflect.Bool: - return !v.Bool() - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return v.Uint() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.Interface, reflect.Map, reflect.Ptr, reflect.Slice: - return v.IsNil() - case reflect.Struct, reflect.Array: - return reflect.DeepEqual(data, reflect.Zero(v.Type()).Interface()) - case reflect.Invalid: - return true - } - return false -} - -// CommandLineOptionsGroup represents a group of user-defined command line options -type CommandLineOptionsGroup struct { - ShortDescription string - LongDescription string - Options interface{} -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/Makefile b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/Makefile deleted file mode 100644 index 23a6b17..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/Makefile +++ /dev/null @@ -1,43 +0,0 @@ -# Go support for Protocol Buffers - Google's data interchange format -# -# Copyright 2010 The Go Authors. All rights reserved. -# https://github.com/golang/protobuf -# -# Redistribution and use in source and binary forms, with or without -# modification, are permitted provided that the following conditions are -# met: -# -# * Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. -# * Redistributions in binary form must reproduce the above -# copyright notice, this list of conditions and the following disclaimer -# in the documentation and/or other materials provided with the -# distribution. -# * Neither the name of Google Inc. nor the names of its -# contributors may be used to endorse or promote products derived from -# this software without specific prior written permission. -# -# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -install: - go install - -test: install generate-test-pbs - go test - - -generate-test-pbs: - make install - make -C testdata - protoc-min-version --version="3.0.0" --proto_path=.:../../../../ --gogo_out=. proto3_proto/proto3.proto - make diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/clone.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/clone.go deleted file mode 100644 index 79edb86..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/clone.go +++ /dev/null @@ -1,228 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2011 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// Protocol buffer deep copy and merge. -// TODO: RawMessage. - -package proto - -import ( - "log" - "reflect" - "strings" -) - -// Clone returns a deep copy of a protocol buffer. -func Clone(pb Message) Message { - in := reflect.ValueOf(pb) - if in.IsNil() { - return pb - } - - out := reflect.New(in.Type().Elem()) - // out is empty so a merge is a deep copy. - mergeStruct(out.Elem(), in.Elem()) - return out.Interface().(Message) -} - -// Merge merges src into dst. -// Required and optional fields that are set in src will be set to that value in dst. -// Elements of repeated fields will be appended. -// Merge panics if src and dst are not the same type, or if dst is nil. -func Merge(dst, src Message) { - in := reflect.ValueOf(src) - out := reflect.ValueOf(dst) - if out.IsNil() { - panic("proto: nil destination") - } - if in.Type() != out.Type() { - // Explicit test prior to mergeStruct so that mistyped nils will fail - panic("proto: type mismatch") - } - if in.IsNil() { - // Merging nil into non-nil is a quiet no-op - return - } - mergeStruct(out.Elem(), in.Elem()) -} - -func mergeStruct(out, in reflect.Value) { - sprop := GetProperties(in.Type()) - for i := 0; i < in.NumField(); i++ { - f := in.Type().Field(i) - if strings.HasPrefix(f.Name, "XXX_") { - continue - } - mergeAny(out.Field(i), in.Field(i), false, sprop.Prop[i]) - } - - if emIn, ok := in.Addr().Interface().(extensionsMap); ok { - emOut := out.Addr().Interface().(extensionsMap) - mergeExtension(emOut.ExtensionMap(), emIn.ExtensionMap()) - } else if emIn, ok := in.Addr().Interface().(extensionsBytes); ok { - emOut := out.Addr().Interface().(extensionsBytes) - bIn := emIn.GetExtensions() - bOut := emOut.GetExtensions() - *bOut = append(*bOut, *bIn...) - } - - uf := in.FieldByName("XXX_unrecognized") - if !uf.IsValid() { - return - } - uin := uf.Bytes() - if len(uin) > 0 { - out.FieldByName("XXX_unrecognized").SetBytes(append([]byte(nil), uin...)) - } -} - -// mergeAny performs a merge between two values of the same type. -// viaPtr indicates whether the values were indirected through a pointer (implying proto2). -// prop is set if this is a struct field (it may be nil). -func mergeAny(out, in reflect.Value, viaPtr bool, prop *Properties) { - if in.Type() == protoMessageType { - if !in.IsNil() { - if out.IsNil() { - out.Set(reflect.ValueOf(Clone(in.Interface().(Message)))) - } else { - Merge(out.Interface().(Message), in.Interface().(Message)) - } - } - return - } - switch in.Kind() { - case reflect.Bool, reflect.Float32, reflect.Float64, reflect.Int32, reflect.Int64, - reflect.String, reflect.Uint32, reflect.Uint64: - if !viaPtr && isProto3Zero(in) { - return - } - out.Set(in) - case reflect.Interface: - // Probably a oneof field; copy non-nil values. - if in.IsNil() { - return - } - // Allocate destination if it is not set, or set to a different type. - // Otherwise we will merge as normal. - if out.IsNil() || out.Elem().Type() != in.Elem().Type() { - out.Set(reflect.New(in.Elem().Elem().Type())) // interface -> *T -> T -> new(T) - } - mergeAny(out.Elem(), in.Elem(), false, nil) - case reflect.Map: - if in.Len() == 0 { - return - } - if out.IsNil() { - out.Set(reflect.MakeMap(in.Type())) - } - // For maps with value types of *T or []byte we need to deep copy each value. - elemKind := in.Type().Elem().Kind() - for _, key := range in.MapKeys() { - var val reflect.Value - switch elemKind { - case reflect.Ptr: - val = reflect.New(in.Type().Elem().Elem()) - mergeAny(val, in.MapIndex(key), false, nil) - case reflect.Slice: - val = in.MapIndex(key) - val = reflect.ValueOf(append([]byte{}, val.Bytes()...)) - default: - val = in.MapIndex(key) - } - out.SetMapIndex(key, val) - } - case reflect.Ptr: - if in.IsNil() { - return - } - if out.IsNil() { - out.Set(reflect.New(in.Elem().Type())) - } - mergeAny(out.Elem(), in.Elem(), true, nil) - case reflect.Slice: - if in.IsNil() { - return - } - if in.Type().Elem().Kind() == reflect.Uint8 { - // []byte is a scalar bytes field, not a repeated field. - - // Edge case: if this is in a proto3 message, a zero length - // bytes field is considered the zero value, and should not - // be merged. - if prop != nil && prop.proto3 && in.Len() == 0 { - return - } - - // Make a deep copy. - // Append to []byte{} instead of []byte(nil) so that we never end up - // with a nil result. - out.SetBytes(append([]byte{}, in.Bytes()...)) - return - } - n := in.Len() - if out.IsNil() { - out.Set(reflect.MakeSlice(in.Type(), 0, n)) - } - switch in.Type().Elem().Kind() { - case reflect.Bool, reflect.Float32, reflect.Float64, reflect.Int32, reflect.Int64, - reflect.String, reflect.Uint32, reflect.Uint64: - out.Set(reflect.AppendSlice(out, in)) - default: - for i := 0; i < n; i++ { - x := reflect.Indirect(reflect.New(in.Type().Elem())) - mergeAny(x, in.Index(i), false, nil) - out.Set(reflect.Append(out, x)) - } - } - case reflect.Struct: - mergeStruct(out, in) - default: - // unknown type, so not a protocol buffer - log.Printf("proto: don't know how to copy %v", in) - } -} - -func mergeExtension(out, in map[int32]Extension) { - for extNum, eIn := range in { - eOut := Extension{desc: eIn.desc} - if eIn.value != nil { - v := reflect.New(reflect.TypeOf(eIn.value)).Elem() - mergeAny(v, reflect.ValueOf(eIn.value), false, nil) - eOut.value = v.Interface() - } - if eIn.enc != nil { - eOut.enc = make([]byte, len(eIn.enc)) - copy(eOut.enc, eIn.enc) - } - - out[extNum] = eOut - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode.go deleted file mode 100644 index 7b06266..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode.go +++ /dev/null @@ -1,873 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for decoding protocol buffer data to construct in-memory representations. - */ - -import ( - "errors" - "fmt" - "io" - "os" - "reflect" -) - -// errOverflow is returned when an integer is too large to be represented. -var errOverflow = errors.New("proto: integer overflow") - -// ErrInternalBadWireType is returned by generated code when an incorrect -// wire type is encountered. It does not get returned to user code. -var ErrInternalBadWireType = errors.New("proto: internal error: bad wiretype for oneof") - -// The fundamental decoders that interpret bytes on the wire. -// Those that take integer types all return uint64 and are -// therefore of type valueDecoder. - -// DecodeVarint reads a varint-encoded integer from the slice. -// It returns the integer and the number of bytes consumed, or -// zero if there is not enough. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func DecodeVarint(buf []byte) (x uint64, n int) { - // x, n already 0 - for shift := uint(0); shift < 64; shift += 7 { - if n >= len(buf) { - return 0, 0 - } - b := uint64(buf[n]) - n++ - x |= (b & 0x7F) << shift - if (b & 0x80) == 0 { - return x, n - } - } - - // The number is too large to represent in a 64-bit value. - return 0, 0 -} - -// DecodeVarint reads a varint-encoded integer from the Buffer. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func (p *Buffer) DecodeVarint() (x uint64, err error) { - // x, err already 0 - - i := p.index - l := len(p.buf) - - for shift := uint(0); shift < 64; shift += 7 { - if i >= l { - err = io.ErrUnexpectedEOF - return - } - b := p.buf[i] - i++ - x |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - p.index = i - return - } - } - - // The number is too large to represent in a 64-bit value. - err = errOverflow - return -} - -// DecodeFixed64 reads a 64-bit integer from the Buffer. -// This is the format for the -// fixed64, sfixed64, and double protocol buffer types. -func (p *Buffer) DecodeFixed64() (x uint64, err error) { - // x, err already 0 - i := p.index + 8 - if i < 0 || i > len(p.buf) { - err = io.ErrUnexpectedEOF - return - } - p.index = i - - x = uint64(p.buf[i-8]) - x |= uint64(p.buf[i-7]) << 8 - x |= uint64(p.buf[i-6]) << 16 - x |= uint64(p.buf[i-5]) << 24 - x |= uint64(p.buf[i-4]) << 32 - x |= uint64(p.buf[i-3]) << 40 - x |= uint64(p.buf[i-2]) << 48 - x |= uint64(p.buf[i-1]) << 56 - return -} - -// DecodeFixed32 reads a 32-bit integer from the Buffer. -// This is the format for the -// fixed32, sfixed32, and float protocol buffer types. -func (p *Buffer) DecodeFixed32() (x uint64, err error) { - // x, err already 0 - i := p.index + 4 - if i < 0 || i > len(p.buf) { - err = io.ErrUnexpectedEOF - return - } - p.index = i - - x = uint64(p.buf[i-4]) - x |= uint64(p.buf[i-3]) << 8 - x |= uint64(p.buf[i-2]) << 16 - x |= uint64(p.buf[i-1]) << 24 - return -} - -// DecodeZigzag64 reads a zigzag-encoded 64-bit integer -// from the Buffer. -// This is the format used for the sint64 protocol buffer type. -func (p *Buffer) DecodeZigzag64() (x uint64, err error) { - x, err = p.DecodeVarint() - if err != nil { - return - } - x = (x >> 1) ^ uint64((int64(x&1)<<63)>>63) - return -} - -// DecodeZigzag32 reads a zigzag-encoded 32-bit integer -// from the Buffer. -// This is the format used for the sint32 protocol buffer type. -func (p *Buffer) DecodeZigzag32() (x uint64, err error) { - x, err = p.DecodeVarint() - if err != nil { - return - } - x = uint64((uint32(x) >> 1) ^ uint32((int32(x&1)<<31)>>31)) - return -} - -// These are not ValueDecoders: they produce an array of bytes or a string. -// bytes, embedded messages - -// DecodeRawBytes reads a count-delimited byte buffer from the Buffer. -// This is the format used for the bytes protocol buffer -// type and for embedded messages. -func (p *Buffer) DecodeRawBytes(alloc bool) (buf []byte, err error) { - n, err := p.DecodeVarint() - if err != nil { - return nil, err - } - - nb := int(n) - if nb < 0 { - return nil, fmt.Errorf("proto: bad byte length %d", nb) - } - end := p.index + nb - if end < p.index || end > len(p.buf) { - return nil, io.ErrUnexpectedEOF - } - - if !alloc { - // todo: check if can get more uses of alloc=false - buf = p.buf[p.index:end] - p.index += nb - return - } - - buf = make([]byte, nb) - copy(buf, p.buf[p.index:]) - p.index += nb - return -} - -// DecodeStringBytes reads an encoded string from the Buffer. -// This is the format used for the proto2 string type. -func (p *Buffer) DecodeStringBytes() (s string, err error) { - buf, err := p.DecodeRawBytes(false) - if err != nil { - return - } - return string(buf), nil -} - -// Skip the next item in the buffer. Its wire type is decoded and presented as an argument. -// If the protocol buffer has extensions, and the field matches, add it as an extension. -// Otherwise, if the XXX_unrecognized field exists, append the skipped data there. -func (o *Buffer) skipAndSave(t reflect.Type, tag, wire int, base structPointer, unrecField field) error { - oi := o.index - - err := o.skip(t, tag, wire) - if err != nil { - return err - } - - if !unrecField.IsValid() { - return nil - } - - ptr := structPointer_Bytes(base, unrecField) - - // Add the skipped field to struct field - obuf := o.buf - - o.buf = *ptr - o.EncodeVarint(uint64(tag<<3 | wire)) - *ptr = append(o.buf, obuf[oi:o.index]...) - - o.buf = obuf - - return nil -} - -// Skip the next item in the buffer. Its wire type is decoded and presented as an argument. -func (o *Buffer) skip(t reflect.Type, tag, wire int) error { - - var u uint64 - var err error - - switch wire { - case WireVarint: - _, err = o.DecodeVarint() - case WireFixed64: - _, err = o.DecodeFixed64() - case WireBytes: - _, err = o.DecodeRawBytes(false) - case WireFixed32: - _, err = o.DecodeFixed32() - case WireStartGroup: - for { - u, err = o.DecodeVarint() - if err != nil { - break - } - fwire := int(u & 0x7) - if fwire == WireEndGroup { - break - } - ftag := int(u >> 3) - err = o.skip(t, ftag, fwire) - if err != nil { - break - } - } - default: - err = fmt.Errorf("proto: can't skip unknown wire type %d for %s", wire, t) - } - return err -} - -// Unmarshaler is the interface representing objects that can -// unmarshal themselves. The method should reset the receiver before -// decoding starts. The argument points to data that may be -// overwritten, so implementations should not keep references to the -// buffer. -type Unmarshaler interface { - Unmarshal([]byte) error -} - -// Unmarshal parses the protocol buffer representation in buf and places the -// decoded result in pb. If the struct underlying pb does not match -// the data in buf, the results can be unpredictable. -// -// Unmarshal resets pb before starting to unmarshal, so any -// existing data in pb is always removed. Use UnmarshalMerge -// to preserve and append to existing data. -func Unmarshal(buf []byte, pb Message) error { - pb.Reset() - return UnmarshalMerge(buf, pb) -} - -// UnmarshalMerge parses the protocol buffer representation in buf and -// writes the decoded result to pb. If the struct underlying pb does not match -// the data in buf, the results can be unpredictable. -// -// UnmarshalMerge merges into existing data in pb. -// Most code should use Unmarshal instead. -func UnmarshalMerge(buf []byte, pb Message) error { - // If the object can unmarshal itself, let it. - if u, ok := pb.(Unmarshaler); ok { - return u.Unmarshal(buf) - } - return NewBuffer(buf).Unmarshal(pb) -} - -// DecodeMessage reads a count-delimited message from the Buffer. -func (p *Buffer) DecodeMessage(pb Message) error { - enc, err := p.DecodeRawBytes(false) - if err != nil { - return err - } - return NewBuffer(enc).Unmarshal(pb) -} - -// DecodeGroup reads a tag-delimited group from the Buffer. -func (p *Buffer) DecodeGroup(pb Message) error { - typ, base, err := getbase(pb) - if err != nil { - return err - } - return p.unmarshalType(typ.Elem(), GetProperties(typ.Elem()), true, base) -} - -// Unmarshal parses the protocol buffer representation in the -// Buffer and places the decoded result in pb. If the struct -// underlying pb does not match the data in the buffer, the results can be -// unpredictable. -func (p *Buffer) Unmarshal(pb Message) error { - // If the object can unmarshal itself, let it. - if u, ok := pb.(Unmarshaler); ok { - err := u.Unmarshal(p.buf[p.index:]) - p.index = len(p.buf) - return err - } - - typ, base, err := getbase(pb) - if err != nil { - return err - } - - err = p.unmarshalType(typ.Elem(), GetProperties(typ.Elem()), false, base) - - if collectStats { - stats.Decode++ - } - - return err -} - -// unmarshalType does the work of unmarshaling a structure. -func (o *Buffer) unmarshalType(st reflect.Type, prop *StructProperties, is_group bool, base structPointer) error { - var state errorState - required, reqFields := prop.reqCount, uint64(0) - - var err error - for err == nil && o.index < len(o.buf) { - oi := o.index - var u uint64 - u, err = o.DecodeVarint() - if err != nil { - break - } - wire := int(u & 0x7) - if wire == WireEndGroup { - if is_group { - return nil // input is satisfied - } - return fmt.Errorf("proto: %s: wiretype end group for non-group", st) - } - tag := int(u >> 3) - if tag <= 0 { - return fmt.Errorf("proto: %s: illegal tag %d (wire type %d)", st, tag, wire) - } - fieldnum, ok := prop.decoderTags.get(tag) - if !ok { - // Maybe it's an extension? - if prop.extendable { - if e := structPointer_Interface(base, st).(extendableProto); isExtensionField(e, int32(tag)) { - if err = o.skip(st, tag, wire); err == nil { - if ee, eok := e.(extensionsMap); eok { - ext := ee.ExtensionMap()[int32(tag)] // may be missing - ext.enc = append(ext.enc, o.buf[oi:o.index]...) - ee.ExtensionMap()[int32(tag)] = ext - } else if ee, eok := e.(extensionsBytes); eok { - ext := ee.GetExtensions() - *ext = append(*ext, o.buf[oi:o.index]...) - } - } - continue - } - } - // Maybe it's a oneof? - if prop.oneofUnmarshaler != nil { - m := structPointer_Interface(base, st).(Message) - // First return value indicates whether tag is a oneof field. - ok, err = prop.oneofUnmarshaler(m, tag, wire, o) - if err == ErrInternalBadWireType { - // Map the error to something more descriptive. - // Do the formatting here to save generated code space. - err = fmt.Errorf("bad wiretype for oneof field in %T", m) - } - if ok { - continue - } - } - err = o.skipAndSave(st, tag, wire, base, prop.unrecField) - continue - } - p := prop.Prop[fieldnum] - - if p.dec == nil { - fmt.Fprintf(os.Stderr, "proto: no protobuf decoder for %s.%s\n", st, st.Field(fieldnum).Name) - continue - } - dec := p.dec - if wire != WireStartGroup && wire != p.WireType { - if wire == WireBytes && p.packedDec != nil { - // a packable field - dec = p.packedDec - } else { - err = fmt.Errorf("proto: bad wiretype for field %s.%s: got wiretype %d, want %d", st, st.Field(fieldnum).Name, wire, p.WireType) - continue - } - } - decErr := dec(o, p, base) - if decErr != nil && !state.shouldContinue(decErr, p) { - err = decErr - } - if err == nil && p.Required { - // Successfully decoded a required field. - if tag <= 64 { - // use bitmap for fields 1-64 to catch field reuse. - var mask uint64 = 1 << uint64(tag-1) - if reqFields&mask == 0 { - // new required field - reqFields |= mask - required-- - } - } else { - // This is imprecise. It can be fooled by a required field - // with a tag > 64 that is encoded twice; that's very rare. - // A fully correct implementation would require allocating - // a data structure, which we would like to avoid. - required-- - } - } - } - if err == nil { - if is_group { - return io.ErrUnexpectedEOF - } - if state.err != nil { - return state.err - } - if required > 0 { - // Not enough information to determine the exact field. If we use extra - // CPU, we could determine the field only if the missing required field - // has a tag <= 64 and we check reqFields. - return &RequiredNotSetError{"{Unknown}"} - } - } - return err -} - -// Individual type decoders -// For each, -// u is the decoded value, -// v is a pointer to the field (pointer) in the struct - -// Sizes of the pools to allocate inside the Buffer. -// The goal is modest amortization and allocation -// on at least 16-byte boundaries. -const ( - boolPoolSize = 16 - uint32PoolSize = 8 - uint64PoolSize = 4 -) - -// Decode a bool. -func (o *Buffer) dec_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - if len(o.bools) == 0 { - o.bools = make([]bool, boolPoolSize) - } - o.bools[0] = u != 0 - *structPointer_Bool(base, p.field) = &o.bools[0] - o.bools = o.bools[1:] - return nil -} - -func (o *Buffer) dec_proto3_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - *structPointer_BoolVal(base, p.field) = u != 0 - return nil -} - -// Decode an int32. -func (o *Buffer) dec_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word32_Set(structPointer_Word32(base, p.field), o, uint32(u)) - return nil -} - -func (o *Buffer) dec_proto3_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word32Val_Set(structPointer_Word32Val(base, p.field), uint32(u)) - return nil -} - -// Decode an int64. -func (o *Buffer) dec_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word64_Set(structPointer_Word64(base, p.field), o, u) - return nil -} - -func (o *Buffer) dec_proto3_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word64Val_Set(structPointer_Word64Val(base, p.field), o, u) - return nil -} - -// Decode a string. -func (o *Buffer) dec_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - *structPointer_String(base, p.field) = &s - return nil -} - -func (o *Buffer) dec_proto3_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - *structPointer_StringVal(base, p.field) = s - return nil -} - -// Decode a slice of bytes ([]byte). -func (o *Buffer) dec_slice_byte(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - *structPointer_Bytes(base, p.field) = b - return nil -} - -// Decode a slice of bools ([]bool). -func (o *Buffer) dec_slice_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - v := structPointer_BoolSlice(base, p.field) - *v = append(*v, u != 0) - return nil -} - -// Decode a slice of bools ([]bool) in packed format. -func (o *Buffer) dec_slice_packed_bool(p *Properties, base structPointer) error { - v := structPointer_BoolSlice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded bools - fin := o.index + nb - if fin < o.index { - return errOverflow - } - - y := *v - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - y = append(y, u != 0) - } - - *v = y - return nil -} - -// Decode a slice of int32s ([]int32). -func (o *Buffer) dec_slice_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - structPointer_Word32Slice(base, p.field).Append(uint32(u)) - return nil -} - -// Decode a slice of int32s ([]int32) in packed format. -func (o *Buffer) dec_slice_packed_int32(p *Properties, base structPointer) error { - v := structPointer_Word32Slice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded int32s - - fin := o.index + nb - if fin < o.index { - return errOverflow - } - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - v.Append(uint32(u)) - } - return nil -} - -// Decode a slice of int64s ([]int64). -func (o *Buffer) dec_slice_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - - structPointer_Word64Slice(base, p.field).Append(u) - return nil -} - -// Decode a slice of int64s ([]int64) in packed format. -func (o *Buffer) dec_slice_packed_int64(p *Properties, base structPointer) error { - v := structPointer_Word64Slice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded int64s - - fin := o.index + nb - if fin < o.index { - return errOverflow - } - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - v.Append(u) - } - return nil -} - -// Decode a slice of strings ([]string). -func (o *Buffer) dec_slice_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - v := structPointer_StringSlice(base, p.field) - *v = append(*v, s) - return nil -} - -// Decode a slice of slice of bytes ([][]byte). -func (o *Buffer) dec_slice_slice_byte(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - v := structPointer_BytesSlice(base, p.field) - *v = append(*v, b) - return nil -} - -// Decode a map field. -func (o *Buffer) dec_new_map(p *Properties, base structPointer) error { - raw, err := o.DecodeRawBytes(false) - if err != nil { - return err - } - oi := o.index // index at the end of this map entry - o.index -= len(raw) // move buffer back to start of map entry - - mptr := structPointer_NewAt(base, p.field, p.mtype) // *map[K]V - if mptr.Elem().IsNil() { - mptr.Elem().Set(reflect.MakeMap(mptr.Type().Elem())) - } - v := mptr.Elem() // map[K]V - - // Prepare addressable doubly-indirect placeholders for the key and value types. - // See enc_new_map for why. - keyptr := reflect.New(reflect.PtrTo(p.mtype.Key())).Elem() // addressable *K - keybase := toStructPointer(keyptr.Addr()) // **K - - var valbase structPointer - var valptr reflect.Value - switch p.mtype.Elem().Kind() { - case reflect.Slice: - // []byte - var dummy []byte - valptr = reflect.ValueOf(&dummy) // *[]byte - valbase = toStructPointer(valptr) // *[]byte - case reflect.Ptr: - // message; valptr is **Msg; need to allocate the intermediate pointer - valptr = reflect.New(reflect.PtrTo(p.mtype.Elem())).Elem() // addressable *V - valptr.Set(reflect.New(valptr.Type().Elem())) - valbase = toStructPointer(valptr) - default: - // everything else - valptr = reflect.New(reflect.PtrTo(p.mtype.Elem())).Elem() // addressable *V - valbase = toStructPointer(valptr.Addr()) // **V - } - - // Decode. - // This parses a restricted wire format, namely the encoding of a message - // with two fields. See enc_new_map for the format. - for o.index < oi { - // tagcode for key and value properties are always a single byte - // because they have tags 1 and 2. - tagcode := o.buf[o.index] - o.index++ - switch tagcode { - case p.mkeyprop.tagcode[0]: - if err := p.mkeyprop.dec(o, p.mkeyprop, keybase); err != nil { - return err - } - case p.mvalprop.tagcode[0]: - if err := p.mvalprop.dec(o, p.mvalprop, valbase); err != nil { - return err - } - default: - // TODO: Should we silently skip this instead? - return fmt.Errorf("proto: bad map data tag %d", raw[0]) - } - } - keyelem, valelem := keyptr.Elem(), valptr.Elem() - if !keyelem.IsValid() { - keyelem = reflect.Zero(p.mtype.Key()) - } - if !valelem.IsValid() { - valelem = reflect.Zero(p.mtype.Elem()) - } - - v.SetMapIndex(keyelem, valelem) - return nil -} - -// Decode a group. -func (o *Buffer) dec_struct_group(p *Properties, base structPointer) error { - bas := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(bas) { - // allocate new nested message - bas = toStructPointer(reflect.New(p.stype)) - structPointer_SetStructPointer(base, p.field, bas) - } - return o.unmarshalType(p.stype, p.sprop, true, bas) -} - -// Decode an embedded message. -func (o *Buffer) dec_struct_message(p *Properties, base structPointer) (err error) { - raw, e := o.DecodeRawBytes(false) - if e != nil { - return e - } - - bas := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(bas) { - // allocate new nested message - bas = toStructPointer(reflect.New(p.stype)) - structPointer_SetStructPointer(base, p.field, bas) - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - iv := structPointer_Interface(bas, p.stype) - return iv.(Unmarshaler).Unmarshal(raw) - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - err = o.unmarshalType(p.stype, p.sprop, false, bas) - o.buf = obuf - o.index = oi - - return err -} - -// Decode a slice of embedded messages. -func (o *Buffer) dec_slice_struct_message(p *Properties, base structPointer) error { - return o.dec_slice_struct(p, false, base) -} - -// Decode a slice of embedded groups. -func (o *Buffer) dec_slice_struct_group(p *Properties, base structPointer) error { - return o.dec_slice_struct(p, true, base) -} - -// Decode a slice of structs ([]*struct). -func (o *Buffer) dec_slice_struct(p *Properties, is_group bool, base structPointer) error { - v := reflect.New(p.stype) - bas := toStructPointer(v) - structPointer_StructPointerSlice(base, p.field).Append(bas) - - if is_group { - err := o.unmarshalType(p.stype, p.sprop, is_group, bas) - return err - } - - raw, err := o.DecodeRawBytes(false) - if err != nil { - return err - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - iv := v.Interface() - return iv.(Unmarshaler).Unmarshal(raw) - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - err = o.unmarshalType(p.stype, p.sprop, is_group, bas) - - o.buf = obuf - o.index = oi - - return err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode_gogo.go deleted file mode 100644 index 603dabe..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/decode_gogo.go +++ /dev/null @@ -1,169 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "reflect" -) - -// Decode a reference to a struct pointer. -func (o *Buffer) dec_ref_struct_message(p *Properties, base structPointer) (err error) { - raw, e := o.DecodeRawBytes(false) - if e != nil { - return e - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - panic("not supported, since this is a pointer receiver") - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - bas := structPointer_FieldPointer(base, p.field) - - err = o.unmarshalType(p.stype, p.sprop, false, bas) - o.buf = obuf - o.index = oi - - return err -} - -// Decode a slice of references to struct pointers ([]struct). -func (o *Buffer) dec_slice_ref_struct(p *Properties, is_group bool, base structPointer) error { - newBas := appendStructPointer(base, p.field, p.sstype) - - if is_group { - panic("not supported, maybe in future, if requested.") - } - - raw, err := o.DecodeRawBytes(false) - if err != nil { - return err - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - panic("not supported, since this is not a pointer receiver.") - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - err = o.unmarshalType(p.stype, p.sprop, is_group, newBas) - - o.buf = obuf - o.index = oi - - return err -} - -// Decode a slice of references to struct pointers. -func (o *Buffer) dec_slice_ref_struct_message(p *Properties, base structPointer) error { - return o.dec_slice_ref_struct(p, false, base) -} - -func setPtrCustomType(base structPointer, f field, v interface{}) { - if v == nil { - return - } - structPointer_SetStructPointer(base, f, structPointer(reflect.ValueOf(v).Pointer())) -} - -func setCustomType(base structPointer, f field, value interface{}) { - if value == nil { - return - } - v := reflect.ValueOf(value).Elem() - t := reflect.TypeOf(value).Elem() - kind := t.Kind() - switch kind { - case reflect.Slice: - slice := reflect.MakeSlice(t, v.Len(), v.Cap()) - reflect.Copy(slice, v) - oldHeader := structPointer_GetSliceHeader(base, f) - oldHeader.Data = slice.Pointer() - oldHeader.Len = v.Len() - oldHeader.Cap = v.Cap() - default: - size := reflect.TypeOf(value).Elem().Size() - structPointer_Copy(toStructPointer(reflect.ValueOf(value)), structPointer_Add(base, f), int(size)) - } -} - -func (o *Buffer) dec_custom_bytes(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - i := reflect.New(p.ctype.Elem()).Interface() - custom := (i).(Unmarshaler) - if err := custom.Unmarshal(b); err != nil { - return err - } - setPtrCustomType(base, p.field, custom) - return nil -} - -func (o *Buffer) dec_custom_ref_bytes(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - i := reflect.New(p.ctype).Interface() - custom := (i).(Unmarshaler) - if err := custom.Unmarshal(b); err != nil { - return err - } - if custom != nil { - setCustomType(base, p.field, custom) - } - return nil -} - -// Decode a slice of bytes ([]byte) into a slice of custom types. -func (o *Buffer) dec_custom_slice_bytes(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - i := reflect.New(p.ctype.Elem()).Interface() - custom := (i).(Unmarshaler) - if err := custom.Unmarshal(b); err != nil { - return err - } - newBas := appendStructPointer(base, p.field, p.ctype) - - setCustomType(newBas, 0, custom) - - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode.go deleted file mode 100644 index eb7e047..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode.go +++ /dev/null @@ -1,1331 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for encoding data into the wire format for protocol buffers. - */ - -import ( - "errors" - "fmt" - "reflect" - "sort" -) - -// RequiredNotSetError is the error returned if Marshal is called with -// a protocol buffer struct whose required fields have not -// all been initialized. It is also the error returned if Unmarshal is -// called with an encoded protocol buffer that does not include all the -// required fields. -// -// When printed, RequiredNotSetError reports the first unset required field in a -// message. If the field cannot be precisely determined, it is reported as -// "{Unknown}". -type RequiredNotSetError struct { - field string -} - -func (e *RequiredNotSetError) Error() string { - return fmt.Sprintf("proto: required field %q not set", e.field) -} - -var ( - // errRepeatedHasNil is the error returned if Marshal is called with - // a struct with a repeated field containing a nil element. - errRepeatedHasNil = errors.New("proto: repeated field has nil element") - - // errOneofHasNil is the error returned if Marshal is called with - // a struct with a oneof field containing a nil element. - errOneofHasNil = errors.New("proto: oneof field has nil value") - - // ErrNil is the error returned if Marshal is called with nil. - ErrNil = errors.New("proto: Marshal called with nil") -) - -// The fundamental encoders that put bytes on the wire. -// Those that take integer types all accept uint64 and are -// therefore of type valueEncoder. - -const maxVarintBytes = 10 // maximum length of a varint - -// EncodeVarint returns the varint encoding of x. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -// Not used by the package itself, but helpful to clients -// wishing to use the same encoding. -func EncodeVarint(x uint64) []byte { - var buf [maxVarintBytes]byte - var n int - for n = 0; x > 127; n++ { - buf[n] = 0x80 | uint8(x&0x7F) - x >>= 7 - } - buf[n] = uint8(x) - n++ - return buf[0:n] -} - -// EncodeVarint writes a varint-encoded integer to the Buffer. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func (p *Buffer) EncodeVarint(x uint64) error { - for x >= 1<<7 { - p.buf = append(p.buf, uint8(x&0x7f|0x80)) - x >>= 7 - } - p.buf = append(p.buf, uint8(x)) - return nil -} - -// SizeVarint returns the varint encoding size of an integer. -func SizeVarint(x uint64) int { - return sizeVarint(x) -} - -func sizeVarint(x uint64) (n int) { - for { - n++ - x >>= 7 - if x == 0 { - break - } - } - return n -} - -// EncodeFixed64 writes a 64-bit integer to the Buffer. -// This is the format for the -// fixed64, sfixed64, and double protocol buffer types. -func (p *Buffer) EncodeFixed64(x uint64) error { - p.buf = append(p.buf, - uint8(x), - uint8(x>>8), - uint8(x>>16), - uint8(x>>24), - uint8(x>>32), - uint8(x>>40), - uint8(x>>48), - uint8(x>>56)) - return nil -} - -func sizeFixed64(x uint64) int { - return 8 -} - -// EncodeFixed32 writes a 32-bit integer to the Buffer. -// This is the format for the -// fixed32, sfixed32, and float protocol buffer types. -func (p *Buffer) EncodeFixed32(x uint64) error { - p.buf = append(p.buf, - uint8(x), - uint8(x>>8), - uint8(x>>16), - uint8(x>>24)) - return nil -} - -func sizeFixed32(x uint64) int { - return 4 -} - -// EncodeZigzag64 writes a zigzag-encoded 64-bit integer -// to the Buffer. -// This is the format used for the sint64 protocol buffer type. -func (p *Buffer) EncodeZigzag64(x uint64) error { - // use signed number to get arithmetic right shift. - return p.EncodeVarint(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} - -func sizeZigzag64(x uint64) int { - return sizeVarint(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} - -// EncodeZigzag32 writes a zigzag-encoded 32-bit integer -// to the Buffer. -// This is the format used for the sint32 protocol buffer type. -func (p *Buffer) EncodeZigzag32(x uint64) error { - // use signed number to get arithmetic right shift. - return p.EncodeVarint(uint64((uint32(x) << 1) ^ uint32((int32(x) >> 31)))) -} - -func sizeZigzag32(x uint64) int { - return sizeVarint(uint64((uint32(x) << 1) ^ uint32((int32(x) >> 31)))) -} - -// EncodeRawBytes writes a count-delimited byte buffer to the Buffer. -// This is the format used for the bytes protocol buffer -// type and for embedded messages. -func (p *Buffer) EncodeRawBytes(b []byte) error { - p.EncodeVarint(uint64(len(b))) - p.buf = append(p.buf, b...) - return nil -} - -func sizeRawBytes(b []byte) int { - return sizeVarint(uint64(len(b))) + - len(b) -} - -// EncodeStringBytes writes an encoded string to the Buffer. -// This is the format used for the proto2 string type. -func (p *Buffer) EncodeStringBytes(s string) error { - p.EncodeVarint(uint64(len(s))) - p.buf = append(p.buf, s...) - return nil -} - -func sizeStringBytes(s string) int { - return sizeVarint(uint64(len(s))) + - len(s) -} - -// Marshaler is the interface representing objects that can marshal themselves. -type Marshaler interface { - Marshal() ([]byte, error) -} - -// Marshal takes the protocol buffer -// and encodes it into the wire format, returning the data. -func Marshal(pb Message) ([]byte, error) { - // Can the object marshal itself? - if m, ok := pb.(Marshaler); ok { - return m.Marshal() - } - p := NewBuffer(nil) - err := p.Marshal(pb) - var state errorState - if err != nil && !state.shouldContinue(err, nil) { - return nil, err - } - if p.buf == nil && err == nil { - // Return a non-nil slice on success. - return []byte{}, nil - } - return p.buf, err -} - -// EncodeMessage writes the protocol buffer to the Buffer, -// prefixed by a varint-encoded length. -func (p *Buffer) EncodeMessage(pb Message) error { - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return ErrNil - } - if err == nil { - var state errorState - err = p.enc_len_struct(GetProperties(t.Elem()), base, &state) - } - return err -} - -// Marshal takes the protocol buffer -// and encodes it into the wire format, writing the result to the -// Buffer. -func (p *Buffer) Marshal(pb Message) error { - // Can the object marshal itself? - if m, ok := pb.(Marshaler); ok { - data, err := m.Marshal() - if err != nil { - return err - } - p.buf = append(p.buf, data...) - return nil - } - - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return ErrNil - } - if err == nil { - err = p.enc_struct(GetProperties(t.Elem()), base) - } - - if collectStats { - stats.Encode++ - } - - return err -} - -// Size returns the encoded size of a protocol buffer. -func Size(pb Message) (n int) { - // Can the object marshal itself? If so, Size is slow. - // TODO: add Size to Marshaler, or add a Sizer interface. - if m, ok := pb.(Marshaler); ok { - b, _ := m.Marshal() - return len(b) - } - - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return 0 - } - if err == nil { - n = size_struct(GetProperties(t.Elem()), base) - } - - if collectStats { - stats.Size++ - } - - return -} - -// Individual type encoders. - -// Encode a bool. -func (o *Buffer) enc_bool(p *Properties, base structPointer) error { - v := *structPointer_Bool(base, p.field) - if v == nil { - return ErrNil - } - x := 0 - if *v { - x = 1 - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_bool(p *Properties, base structPointer) error { - v := *structPointer_BoolVal(base, p.field) - if !v { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, 1) - return nil -} - -func size_bool(p *Properties, base structPointer) int { - v := *structPointer_Bool(base, p.field) - if v == nil { - return 0 - } - return len(p.tagcode) + 1 // each bool takes exactly one byte -} - -func size_proto3_bool(p *Properties, base structPointer) int { - v := *structPointer_BoolVal(base, p.field) - if !v && !p.oneof { - return 0 - } - return len(p.tagcode) + 1 // each bool takes exactly one byte -} - -// Encode an int32. -func (o *Buffer) enc_int32(p *Properties, base structPointer) error { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return ErrNil - } - x := int32(word32_Get(v)) // permit sign extension to use full 64-bit range - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_int32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) // permit sign extension to use full 64-bit range - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_int32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return 0 - } - x := int32(word32_Get(v)) // permit sign extension to use full 64-bit range - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -func size_proto3_int32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) // permit sign extension to use full 64-bit range - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -// Encode a uint32. -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_uint32(p *Properties, base structPointer) error { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return ErrNil - } - x := word32_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_uint32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_uint32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return 0 - } - x := word32_Get(v) - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -func size_proto3_uint32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -// Encode an int64. -func (o *Buffer) enc_int64(p *Properties, base structPointer) error { - v := structPointer_Word64(base, p.field) - if word64_IsNil(v) { - return ErrNil - } - x := word64_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, x) - return nil -} - -func (o *Buffer) enc_proto3_int64(p *Properties, base structPointer) error { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, x) - return nil -} - -func size_int64(p *Properties, base structPointer) (n int) { - v := structPointer_Word64(base, p.field) - if word64_IsNil(v) { - return 0 - } - x := word64_Get(v) - n += len(p.tagcode) - n += p.valSize(x) - return -} - -func size_proto3_int64(p *Properties, base structPointer) (n int) { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(x) - return -} - -// Encode a string. -func (o *Buffer) enc_string(p *Properties, base structPointer) error { - v := *structPointer_String(base, p.field) - if v == nil { - return ErrNil - } - x := *v - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(x) - return nil -} - -func (o *Buffer) enc_proto3_string(p *Properties, base structPointer) error { - v := *structPointer_StringVal(base, p.field) - if v == "" { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(v) - return nil -} - -func size_string(p *Properties, base structPointer) (n int) { - v := *structPointer_String(base, p.field) - if v == nil { - return 0 - } - x := *v - n += len(p.tagcode) - n += sizeStringBytes(x) - return -} - -func size_proto3_string(p *Properties, base structPointer) (n int) { - v := *structPointer_StringVal(base, p.field) - if v == "" && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeStringBytes(v) - return -} - -// All protocol buffer fields are nillable, but be careful. -func isNil(v reflect.Value) bool { - switch v.Kind() { - case reflect.Interface, reflect.Map, reflect.Ptr, reflect.Slice: - return v.IsNil() - } - return false -} - -// Encode a message struct. -func (o *Buffer) enc_struct_message(p *Properties, base structPointer) error { - var state errorState - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return ErrNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return state.err - } - - o.buf = append(o.buf, p.tagcode...) - return o.enc_len_struct(p.sprop, structp, &state) -} - -func size_struct_message(p *Properties, base structPointer) int { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return 0 - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n0 := len(p.tagcode) - n1 := sizeRawBytes(data) - return n0 + n1 - } - - n0 := len(p.tagcode) - n1 := size_struct(p.sprop, structp) - n2 := sizeVarint(uint64(n1)) // size of encoded length - return n0 + n1 + n2 -} - -// Encode a group struct. -func (o *Buffer) enc_struct_group(p *Properties, base structPointer) error { - var state errorState - b := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(b) { - return ErrNil - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireStartGroup)) - err := o.enc_struct(p.sprop, b) - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.EncodeVarint(uint64((p.Tag << 3) | WireEndGroup)) - return state.err -} - -func size_struct_group(p *Properties, base structPointer) (n int) { - b := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(b) { - return 0 - } - - n += sizeVarint(uint64((p.Tag << 3) | WireStartGroup)) - n += size_struct(p.sprop, b) - n += sizeVarint(uint64((p.Tag << 3) | WireEndGroup)) - return -} - -// Encode a slice of bools ([]bool). -func (o *Buffer) enc_slice_bool(p *Properties, base structPointer) error { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return ErrNil - } - for _, x := range s { - o.buf = append(o.buf, p.tagcode...) - v := uint64(0) - if x { - v = 1 - } - p.valEnc(o, v) - } - return nil -} - -func size_slice_bool(p *Properties, base structPointer) int { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return 0 - } - return l * (len(p.tagcode) + 1) // each bool takes exactly one byte -} - -// Encode a slice of bools ([]bool) in packed format. -func (o *Buffer) enc_slice_packed_bool(p *Properties, base structPointer) error { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(l)) // each bool takes exactly one byte - for _, x := range s { - v := uint64(0) - if x { - v = 1 - } - p.valEnc(o, v) - } - return nil -} - -func size_slice_packed_bool(p *Properties, base structPointer) (n int) { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return 0 - } - n += len(p.tagcode) - n += sizeVarint(uint64(l)) - n += l // each bool takes exactly one byte - return -} - -// Encode a slice of bytes ([]byte). -func (o *Buffer) enc_slice_byte(p *Properties, base structPointer) error { - s := *structPointer_Bytes(base, p.field) - if s == nil { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(s) - return nil -} - -func (o *Buffer) enc_proto3_slice_byte(p *Properties, base structPointer) error { - s := *structPointer_Bytes(base, p.field) - if len(s) == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(s) - return nil -} - -func size_slice_byte(p *Properties, base structPointer) (n int) { - s := *structPointer_Bytes(base, p.field) - if s == nil && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeRawBytes(s) - return -} - -func size_proto3_slice_byte(p *Properties, base structPointer) (n int) { - s := *structPointer_Bytes(base, p.field) - if len(s) == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeRawBytes(s) - return -} - -// Encode a slice of int32s ([]int32). -func (o *Buffer) enc_slice_int32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - p.valEnc(o, uint64(x)) - } - return nil -} - -func size_slice_int32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - n += p.valSize(uint64(x)) - } - return -} - -// Encode a slice of int32s ([]int32) in packed format. -func (o *Buffer) enc_slice_packed_int32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - p.valEnc(buf, uint64(x)) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_int32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - bufSize += p.valSize(uint64(x)) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of uint32s ([]uint32). -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_slice_uint32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - x := s.Index(i) - p.valEnc(o, uint64(x)) - } - return nil -} - -func size_slice_uint32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - x := s.Index(i) - n += p.valSize(uint64(x)) - } - return -} - -// Encode a slice of uint32s ([]uint32) in packed format. -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_slice_packed_uint32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - p.valEnc(buf, uint64(s.Index(i))) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_uint32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - bufSize += p.valSize(uint64(s.Index(i))) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of int64s ([]int64). -func (o *Buffer) enc_slice_int64(p *Properties, base structPointer) error { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, s.Index(i)) - } - return nil -} - -func size_slice_int64(p *Properties, base structPointer) (n int) { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - n += p.valSize(s.Index(i)) - } - return -} - -// Encode a slice of int64s ([]int64) in packed format. -func (o *Buffer) enc_slice_packed_int64(p *Properties, base structPointer) error { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - p.valEnc(buf, s.Index(i)) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_int64(p *Properties, base structPointer) (n int) { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - bufSize += p.valSize(s.Index(i)) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of slice of bytes ([][]byte). -func (o *Buffer) enc_slice_slice_byte(p *Properties, base structPointer) error { - ss := *structPointer_BytesSlice(base, p.field) - l := len(ss) - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(ss[i]) - } - return nil -} - -func size_slice_slice_byte(p *Properties, base structPointer) (n int) { - ss := *structPointer_BytesSlice(base, p.field) - l := len(ss) - if l == 0 { - return 0 - } - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - n += sizeRawBytes(ss[i]) - } - return -} - -// Encode a slice of strings ([]string). -func (o *Buffer) enc_slice_string(p *Properties, base structPointer) error { - ss := *structPointer_StringSlice(base, p.field) - l := len(ss) - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(ss[i]) - } - return nil -} - -func size_slice_string(p *Properties, base structPointer) (n int) { - ss := *structPointer_StringSlice(base, p.field) - l := len(ss) - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - n += sizeStringBytes(ss[i]) - } - return -} - -// Encode a slice of message structs ([]*struct). -func (o *Buffer) enc_slice_struct_message(p *Properties, base structPointer) error { - var state errorState - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - for i := 0; i < l; i++ { - structp := s.Index(i) - if structPointer_IsNil(structp) { - return errRepeatedHasNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - continue - } - - o.buf = append(o.buf, p.tagcode...) - err := o.enc_len_struct(p.sprop, structp, &state) - if err != nil && !state.shouldContinue(err, nil) { - if err == ErrNil { - return errRepeatedHasNil - } - return err - } - } - return state.err -} - -func size_slice_struct_message(p *Properties, base structPointer) (n int) { - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - structp := s.Index(i) - if structPointer_IsNil(structp) { - return // return the size up to this point - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n += len(p.tagcode) - n += sizeRawBytes(data) - continue - } - - n0 := size_struct(p.sprop, structp) - n1 := sizeVarint(uint64(n0)) // size of encoded length - n += n0 + n1 - } - return -} - -// Encode a slice of group structs ([]*struct). -func (o *Buffer) enc_slice_struct_group(p *Properties, base structPointer) error { - var state errorState - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - for i := 0; i < l; i++ { - b := s.Index(i) - if structPointer_IsNil(b) { - return errRepeatedHasNil - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireStartGroup)) - - err := o.enc_struct(p.sprop, b) - - if err != nil && !state.shouldContinue(err, nil) { - if err == ErrNil { - return errRepeatedHasNil - } - return err - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireEndGroup)) - } - return state.err -} - -func size_slice_struct_group(p *Properties, base structPointer) (n int) { - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - n += l * sizeVarint(uint64((p.Tag<<3)|WireStartGroup)) - n += l * sizeVarint(uint64((p.Tag<<3)|WireEndGroup)) - for i := 0; i < l; i++ { - b := s.Index(i) - if structPointer_IsNil(b) { - return // return size up to this point - } - - n += size_struct(p.sprop, b) - } - return -} - -// Encode an extension map. -func (o *Buffer) enc_map(p *Properties, base structPointer) error { - v := *structPointer_ExtMap(base, p.field) - if err := encodeExtensionMap(v); err != nil { - return err - } - // Fast-path for common cases: zero or one extensions. - if len(v) <= 1 { - for _, e := range v { - o.buf = append(o.buf, e.enc...) - } - return nil - } - - // Sort keys to provide a deterministic encoding. - keys := make([]int, 0, len(v)) - for k := range v { - keys = append(keys, int(k)) - } - sort.Ints(keys) - - for _, k := range keys { - o.buf = append(o.buf, v[int32(k)].enc...) - } - return nil -} - -func size_map(p *Properties, base structPointer) int { - v := *structPointer_ExtMap(base, p.field) - return sizeExtensionMap(v) -} - -// Encode a map field. -func (o *Buffer) enc_new_map(p *Properties, base structPointer) error { - var state errorState // XXX: or do we need to plumb this through? - - /* - A map defined as - map map_field = N; - is encoded in the same way as - message MapFieldEntry { - key_type key = 1; - value_type value = 2; - } - repeated MapFieldEntry map_field = N; - */ - - v := structPointer_NewAt(base, p.field, p.mtype).Elem() // map[K]V - if v.Len() == 0 { - return nil - } - - keycopy, valcopy, keybase, valbase := mapEncodeScratch(p.mtype) - - enc := func() error { - if err := p.mkeyprop.enc(o, p.mkeyprop, keybase); err != nil { - return err - } - if err := p.mvalprop.enc(o, p.mvalprop, valbase); err != nil { - return err - } - return nil - } - - // Don't sort map keys. It is not required by the spec, and C++ doesn't do it. - for _, key := range v.MapKeys() { - val := v.MapIndex(key) - - // The only illegal map entry values are nil message pointers. - if val.Kind() == reflect.Ptr && val.IsNil() { - return errors.New("proto: map has nil element") - } - - keycopy.Set(key) - valcopy.Set(val) - - o.buf = append(o.buf, p.tagcode...) - if err := o.enc_len_thing(enc, &state); err != nil { - return err - } - } - return nil -} - -func size_new_map(p *Properties, base structPointer) int { - v := structPointer_NewAt(base, p.field, p.mtype).Elem() // map[K]V - - keycopy, valcopy, keybase, valbase := mapEncodeScratch(p.mtype) - - n := 0 - for _, key := range v.MapKeys() { - val := v.MapIndex(key) - keycopy.Set(key) - valcopy.Set(val) - - // Tag codes for key and val are the responsibility of the sub-sizer. - keysize := p.mkeyprop.size(p.mkeyprop, keybase) - valsize := p.mvalprop.size(p.mvalprop, valbase) - entry := keysize + valsize - // Add on tag code and length of map entry itself. - n += len(p.tagcode) + sizeVarint(uint64(entry)) + entry - } - return n -} - -// mapEncodeScratch returns a new reflect.Value matching the map's value type, -// and a structPointer suitable for passing to an encoder or sizer. -func mapEncodeScratch(mapType reflect.Type) (keycopy, valcopy reflect.Value, keybase, valbase structPointer) { - // Prepare addressable doubly-indirect placeholders for the key and value types. - // This is needed because the element-type encoders expect **T, but the map iteration produces T. - - keycopy = reflect.New(mapType.Key()).Elem() // addressable K - keyptr := reflect.New(reflect.PtrTo(keycopy.Type())).Elem() // addressable *K - keyptr.Set(keycopy.Addr()) // - keybase = toStructPointer(keyptr.Addr()) // **K - - // Value types are more varied and require special handling. - switch mapType.Elem().Kind() { - case reflect.Slice: - // []byte - var dummy []byte - valcopy = reflect.ValueOf(&dummy).Elem() // addressable []byte - valbase = toStructPointer(valcopy.Addr()) - case reflect.Ptr: - // message; the generated field type is map[K]*Msg (so V is *Msg), - // so we only need one level of indirection. - valcopy = reflect.New(mapType.Elem()).Elem() // addressable V - valbase = toStructPointer(valcopy.Addr()) - default: - // everything else - valcopy = reflect.New(mapType.Elem()).Elem() // addressable V - valptr := reflect.New(reflect.PtrTo(valcopy.Type())).Elem() // addressable *V - valptr.Set(valcopy.Addr()) // - valbase = toStructPointer(valptr.Addr()) // **V - } - return -} - -// Encode a struct. -func (o *Buffer) enc_struct(prop *StructProperties, base structPointer) error { - var state errorState - // Encode fields in tag order so that decoders may use optimizations - // that depend on the ordering. - // https://developers.google.com/protocol-buffers/docs/encoding#order - for _, i := range prop.order { - p := prop.Prop[i] - if p.enc != nil { - err := p.enc(o, p, base) - if err != nil { - if err == ErrNil { - if p.Required && state.err == nil { - state.err = &RequiredNotSetError{p.Name} - } - } else if err == errRepeatedHasNil { - // Give more context to nil values in repeated fields. - return errors.New("repeated field " + p.OrigName + " has nil element") - } else if !state.shouldContinue(err, p) { - return err - } - } - } - } - - // Do oneof fields. - if prop.oneofMarshaler != nil { - m := structPointer_Interface(base, prop.stype).(Message) - if err := prop.oneofMarshaler(m, o); err == ErrNil { - return errOneofHasNil - } else if err != nil { - return err - } - } - - // Add unrecognized fields at the end. - if prop.unrecField.IsValid() { - v := *structPointer_Bytes(base, prop.unrecField) - if len(v) > 0 { - o.buf = append(o.buf, v...) - } - } - - return state.err -} - -func size_struct(prop *StructProperties, base structPointer) (n int) { - for _, i := range prop.order { - p := prop.Prop[i] - if p.size != nil { - n += p.size(p, base) - } - } - - // Add unrecognized fields at the end. - if prop.unrecField.IsValid() { - v := *structPointer_Bytes(base, prop.unrecField) - n += len(v) - } - - // Factor in any oneof fields. - if prop.oneofSizer != nil { - m := structPointer_Interface(base, prop.stype).(Message) - n += prop.oneofSizer(m) - } - - return -} - -var zeroes [20]byte // longer than any conceivable sizeVarint - -// Encode a struct, preceded by its encoded length (as a varint). -func (o *Buffer) enc_len_struct(prop *StructProperties, base structPointer, state *errorState) error { - return o.enc_len_thing(func() error { return o.enc_struct(prop, base) }, state) -} - -// Encode something, preceded by its encoded length (as a varint). -func (o *Buffer) enc_len_thing(enc func() error, state *errorState) error { - iLen := len(o.buf) - o.buf = append(o.buf, 0, 0, 0, 0) // reserve four bytes for length - iMsg := len(o.buf) - err := enc() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - lMsg := len(o.buf) - iMsg - lLen := sizeVarint(uint64(lMsg)) - switch x := lLen - (iMsg - iLen); { - case x > 0: // actual length is x bytes larger than the space we reserved - // Move msg x bytes right. - o.buf = append(o.buf, zeroes[:x]...) - copy(o.buf[iMsg+x:], o.buf[iMsg:iMsg+lMsg]) - case x < 0: // actual length is x bytes smaller than the space we reserved - // Move msg x bytes left. - copy(o.buf[iMsg+x:], o.buf[iMsg:iMsg+lMsg]) - o.buf = o.buf[:len(o.buf)+x] // x is negative - } - // Encode the length in the reserved space. - o.buf = o.buf[:iLen] - o.EncodeVarint(uint64(lMsg)) - o.buf = o.buf[:len(o.buf)+lMsg] - return state.err -} - -// errorState maintains the first error that occurs and updates that error -// with additional context. -type errorState struct { - err error -} - -// shouldContinue reports whether encoding should continue upon encountering the -// given error. If the error is RequiredNotSetError, shouldContinue returns true -// and, if this is the first appearance of that error, remembers it for future -// reporting. -// -// If prop is not nil, it may update any error with additional context about the -// field with the error. -func (s *errorState) shouldContinue(err error, prop *Properties) bool { - // Ignore unset required fields. - reqNotSet, ok := err.(*RequiredNotSetError) - if !ok { - return false - } - if s.err == nil { - if prop != nil { - err = &RequiredNotSetError{prop.Name + "." + reqNotSet.field} - } - s.err = err - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode_gogo.go deleted file mode 100644 index f77cfb1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/encode_gogo.go +++ /dev/null @@ -1,354 +0,0 @@ -// Extensions for Protocol Buffers to create more go like structures. -// -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// http://github.com/golang/protobuf/ -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "reflect" -) - -func NewRequiredNotSetError(field string) *RequiredNotSetError { - return &RequiredNotSetError{field} -} - -type Sizer interface { - Size() int -} - -func (o *Buffer) enc_ext_slice_byte(p *Properties, base structPointer) error { - s := *structPointer_Bytes(base, p.field) - if s == nil { - return ErrNil - } - o.buf = append(o.buf, s...) - return nil -} - -func size_ext_slice_byte(p *Properties, base structPointer) (n int) { - s := *structPointer_Bytes(base, p.field) - if s == nil { - return 0 - } - n += len(s) - return -} - -// Encode a reference to bool pointer. -func (o *Buffer) enc_ref_bool(p *Properties, base structPointer) error { - v := *structPointer_BoolVal(base, p.field) - x := 0 - if v { - x = 1 - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_ref_bool(p *Properties, base structPointer) int { - return len(p.tagcode) + 1 // each bool takes exactly one byte -} - -// Encode a reference to int32 pointer. -func (o *Buffer) enc_ref_int32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_ref_int32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -func (o *Buffer) enc_ref_uint32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_ref_uint32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -// Encode a reference to an int64 pointer. -func (o *Buffer) enc_ref_int64(p *Properties, base structPointer) error { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, x) - return nil -} - -func size_ref_int64(p *Properties, base structPointer) (n int) { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - n += len(p.tagcode) - n += p.valSize(x) - return -} - -// Encode a reference to a string pointer. -func (o *Buffer) enc_ref_string(p *Properties, base structPointer) error { - v := *structPointer_StringVal(base, p.field) - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(v) - return nil -} - -func size_ref_string(p *Properties, base structPointer) (n int) { - v := *structPointer_StringVal(base, p.field) - n += len(p.tagcode) - n += sizeStringBytes(v) - return -} - -// Encode a reference to a message struct. -func (o *Buffer) enc_ref_struct_message(p *Properties, base structPointer) error { - var state errorState - structp := structPointer_GetRefStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return ErrNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil - } - - o.buf = append(o.buf, p.tagcode...) - return o.enc_len_struct(p.sprop, structp, &state) -} - -//TODO this is only copied, please fix this -func size_ref_struct_message(p *Properties, base structPointer) int { - structp := structPointer_GetRefStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return 0 - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n0 := len(p.tagcode) - n1 := sizeRawBytes(data) - return n0 + n1 - } - - n0 := len(p.tagcode) - n1 := size_struct(p.sprop, structp) - n2 := sizeVarint(uint64(n1)) // size of encoded length - return n0 + n1 + n2 -} - -// Encode a slice of references to message struct pointers ([]struct). -func (o *Buffer) enc_slice_ref_struct_message(p *Properties, base structPointer) error { - var state errorState - ss := structPointer_GetStructPointer(base, p.field) - ss1 := structPointer_GetRefStructPointer(ss, field(0)) - size := p.stype.Size() - l := structPointer_Len(base, p.field) - for i := 0; i < l; i++ { - structp := structPointer_Add(ss1, field(uintptr(i)*size)) - if structPointer_IsNil(structp) { - return errRepeatedHasNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - continue - } - - o.buf = append(o.buf, p.tagcode...) - err := o.enc_len_struct(p.sprop, structp, &state) - if err != nil && !state.shouldContinue(err, nil) { - if err == ErrNil { - return errRepeatedHasNil - } - return err - } - - } - return state.err -} - -//TODO this is only copied, please fix this -func size_slice_ref_struct_message(p *Properties, base structPointer) (n int) { - ss := structPointer_GetStructPointer(base, p.field) - ss1 := structPointer_GetRefStructPointer(ss, field(0)) - size := p.stype.Size() - l := structPointer_Len(base, p.field) - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - structp := structPointer_Add(ss1, field(uintptr(i)*size)) - if structPointer_IsNil(structp) { - return // return the size up to this point - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n += len(p.tagcode) - n += sizeRawBytes(data) - continue - } - - n0 := size_struct(p.sprop, structp) - n1 := sizeVarint(uint64(n0)) // size of encoded length - n += n0 + n1 - } - return -} - -func (o *Buffer) enc_custom_bytes(p *Properties, base structPointer) error { - i := structPointer_InterfaceRef(base, p.field, p.ctype) - if i == nil { - return ErrNil - } - custom := i.(Marshaler) - data, err := custom.Marshal() - if err != nil { - return err - } - if data == nil { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_custom_bytes(p *Properties, base structPointer) (n int) { - n += len(p.tagcode) - i := structPointer_InterfaceRef(base, p.field, p.ctype) - if i == nil { - return 0 - } - custom := i.(Marshaler) - data, _ := custom.Marshal() - n += sizeRawBytes(data) - return -} - -func (o *Buffer) enc_custom_ref_bytes(p *Properties, base structPointer) error { - custom := structPointer_InterfaceAt(base, p.field, p.ctype).(Marshaler) - data, err := custom.Marshal() - if err != nil { - return err - } - if data == nil { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return nil -} - -func size_custom_ref_bytes(p *Properties, base structPointer) (n int) { - n += len(p.tagcode) - i := structPointer_InterfaceAt(base, p.field, p.ctype) - if i == nil { - return 0 - } - custom := i.(Marshaler) - data, _ := custom.Marshal() - n += sizeRawBytes(data) - return -} - -func (o *Buffer) enc_custom_slice_bytes(p *Properties, base structPointer) error { - inter := structPointer_InterfaceRef(base, p.field, p.ctype) - if inter == nil { - return ErrNil - } - slice := reflect.ValueOf(inter) - l := slice.Len() - for i := 0; i < l; i++ { - v := slice.Index(i) - custom := v.Interface().(Marshaler) - data, err := custom.Marshal() - if err != nil { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - } - return nil -} - -func size_custom_slice_bytes(p *Properties, base structPointer) (n int) { - inter := structPointer_InterfaceRef(base, p.field, p.ctype) - if inter == nil { - return 0 - } - slice := reflect.ValueOf(inter) - l := slice.Len() - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - v := slice.Index(i) - custom := v.Interface().(Marshaler) - data, _ := custom.Marshal() - n += sizeRawBytes(data) - } - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/equal.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/equal.go deleted file mode 100644 index f5db1de..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/equal.go +++ /dev/null @@ -1,276 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2011 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// Protocol buffer comparison. - -package proto - -import ( - "bytes" - "log" - "reflect" - "strings" -) - -/* -Equal returns true iff protocol buffers a and b are equal. -The arguments must both be pointers to protocol buffer structs. - -Equality is defined in this way: - - Two messages are equal iff they are the same type, - corresponding fields are equal, unknown field sets - are equal, and extensions sets are equal. - - Two set scalar fields are equal iff their values are equal. - If the fields are of a floating-point type, remember that - NaN != x for all x, including NaN. If the message is defined - in a proto3 .proto file, fields are not "set"; specifically, - zero length proto3 "bytes" fields are equal (nil == {}). - - Two repeated fields are equal iff their lengths are the same, - and their corresponding elements are equal (a "bytes" field, - although represented by []byte, is not a repeated field) - - Two unset fields are equal. - - Two unknown field sets are equal if their current - encoded state is equal. - - Two extension sets are equal iff they have corresponding - elements that are pairwise equal. - - Every other combination of things are not equal. - -The return value is undefined if a and b are not protocol buffers. -*/ -func Equal(a, b Message) bool { - if a == nil || b == nil { - return a == b - } - v1, v2 := reflect.ValueOf(a), reflect.ValueOf(b) - if v1.Type() != v2.Type() { - return false - } - if v1.Kind() == reflect.Ptr { - if v1.IsNil() { - return v2.IsNil() - } - if v2.IsNil() { - return false - } - v1, v2 = v1.Elem(), v2.Elem() - } - if v1.Kind() != reflect.Struct { - return false - } - return equalStruct(v1, v2) -} - -// v1 and v2 are known to have the same type. -func equalStruct(v1, v2 reflect.Value) bool { - sprop := GetProperties(v1.Type()) - for i := 0; i < v1.NumField(); i++ { - f := v1.Type().Field(i) - if strings.HasPrefix(f.Name, "XXX_") { - continue - } - f1, f2 := v1.Field(i), v2.Field(i) - if f.Type.Kind() == reflect.Ptr { - if n1, n2 := f1.IsNil(), f2.IsNil(); n1 && n2 { - // both unset - continue - } else if n1 != n2 { - // set/unset mismatch - return false - } - b1, ok := f1.Interface().(raw) - if ok { - b2 := f2.Interface().(raw) - // RawMessage - if !bytes.Equal(b1.Bytes(), b2.Bytes()) { - return false - } - continue - } - f1, f2 = f1.Elem(), f2.Elem() - } - if !equalAny(f1, f2, sprop.Prop[i]) { - return false - } - } - - if em1 := v1.FieldByName("XXX_extensions"); em1.IsValid() { - em2 := v2.FieldByName("XXX_extensions") - if !equalExtensions(v1.Type(), em1.Interface().(map[int32]Extension), em2.Interface().(map[int32]Extension)) { - return false - } - } - - uf := v1.FieldByName("XXX_unrecognized") - if !uf.IsValid() { - return true - } - - u1 := uf.Bytes() - u2 := v2.FieldByName("XXX_unrecognized").Bytes() - if !bytes.Equal(u1, u2) { - return false - } - - return true -} - -// v1 and v2 are known to have the same type. -// prop may be nil. -func equalAny(v1, v2 reflect.Value, prop *Properties) bool { - if v1.Type() == protoMessageType { - m1, _ := v1.Interface().(Message) - m2, _ := v2.Interface().(Message) - return Equal(m1, m2) - } - switch v1.Kind() { - case reflect.Bool: - return v1.Bool() == v2.Bool() - case reflect.Float32, reflect.Float64: - return v1.Float() == v2.Float() - case reflect.Int32, reflect.Int64: - return v1.Int() == v2.Int() - case reflect.Interface: - // Probably a oneof field; compare the inner values. - n1, n2 := v1.IsNil(), v2.IsNil() - if n1 || n2 { - return n1 == n2 - } - e1, e2 := v1.Elem(), v2.Elem() - if e1.Type() != e2.Type() { - return false - } - return equalAny(e1, e2, nil) - case reflect.Map: - if v1.Len() != v2.Len() { - return false - } - for _, key := range v1.MapKeys() { - val2 := v2.MapIndex(key) - if !val2.IsValid() { - // This key was not found in the second map. - return false - } - if !equalAny(v1.MapIndex(key), val2, nil) { - return false - } - } - return true - case reflect.Ptr: - return equalAny(v1.Elem(), v2.Elem(), prop) - case reflect.Slice: - if v1.Type().Elem().Kind() == reflect.Uint8 { - // short circuit: []byte - - // Edge case: if this is in a proto3 message, a zero length - // bytes field is considered the zero value. - if prop != nil && prop.proto3 && v1.Len() == 0 && v2.Len() == 0 { - return true - } - if v1.IsNil() != v2.IsNil() { - return false - } - return bytes.Equal(v1.Interface().([]byte), v2.Interface().([]byte)) - } - - if v1.Len() != v2.Len() { - return false - } - for i := 0; i < v1.Len(); i++ { - if !equalAny(v1.Index(i), v2.Index(i), prop) { - return false - } - } - return true - case reflect.String: - return v1.Interface().(string) == v2.Interface().(string) - case reflect.Struct: - return equalStruct(v1, v2) - case reflect.Uint32, reflect.Uint64: - return v1.Uint() == v2.Uint() - } - - // unknown type, so not a protocol buffer - log.Printf("proto: don't know how to compare %v", v1) - return false -} - -// base is the struct type that the extensions are based on. -// em1 and em2 are extension maps. -func equalExtensions(base reflect.Type, em1, em2 map[int32]Extension) bool { - if len(em1) != len(em2) { - return false - } - - for extNum, e1 := range em1 { - e2, ok := em2[extNum] - if !ok { - return false - } - - m1, m2 := e1.value, e2.value - - if m1 != nil && m2 != nil { - // Both are unencoded. - if !equalAny(reflect.ValueOf(m1), reflect.ValueOf(m2), nil) { - return false - } - continue - } - - // At least one is encoded. To do a semantically correct comparison - // we need to unmarshal them first. - var desc *ExtensionDesc - if m := extensionMaps[base]; m != nil { - desc = m[extNum] - } - if desc == nil { - log.Printf("proto: don't know how to compare extension %d of %v", extNum, base) - continue - } - var err error - if m1 == nil { - m1, err = decodeExtension(e1.enc, desc) - } - if m2 == nil && err == nil { - m2, err = decodeExtension(e2.enc, desc) - } - if err != nil { - // The encoded form is invalid. - log.Printf("proto: badly encoded extension %d of %v: %v", extNum, base, err) - return false - } - if !equalAny(reflect.ValueOf(m1), reflect.ValueOf(m2), nil) { - return false - } - } - - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions.go deleted file mode 100644 index 6180347..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions.go +++ /dev/null @@ -1,518 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Types and routines for supporting protocol buffer extensions. - */ - -import ( - "errors" - "fmt" - "reflect" - "strconv" - "sync" -) - -// ErrMissingExtension is the error returned by GetExtension if the named extension is not in the message. -var ErrMissingExtension = errors.New("proto: missing extension") - -// ExtensionRange represents a range of message extensions for a protocol buffer. -// Used in code generated by the protocol compiler. -type ExtensionRange struct { - Start, End int32 // both inclusive -} - -// extendableProto is an interface implemented by any protocol buffer that may be extended. -type extendableProto interface { - Message - ExtensionRangeArray() []ExtensionRange -} - -type extensionsMap interface { - extendableProto - ExtensionMap() map[int32]Extension -} - -type extensionsBytes interface { - extendableProto - GetExtensions() *[]byte -} - -var extendableProtoType = reflect.TypeOf((*extendableProto)(nil)).Elem() - -// ExtensionDesc represents an extension specification. -// Used in generated code from the protocol compiler. -type ExtensionDesc struct { - ExtendedType Message // nil pointer to the type that is being extended - ExtensionType interface{} // nil pointer to the extension type - Field int32 // field number - Name string // fully-qualified name of extension, for text formatting - Tag string // protobuf tag style -} - -func (ed *ExtensionDesc) repeated() bool { - t := reflect.TypeOf(ed.ExtensionType) - return t.Kind() == reflect.Slice && t.Elem().Kind() != reflect.Uint8 -} - -// Extension represents an extension in a message. -type Extension struct { - // When an extension is stored in a message using SetExtension - // only desc and value are set. When the message is marshaled - // enc will be set to the encoded form of the message. - // - // When a message is unmarshaled and contains extensions, each - // extension will have only enc set. When such an extension is - // accessed using GetExtension (or GetExtensions) desc and value - // will be set. - desc *ExtensionDesc - value interface{} - enc []byte -} - -// SetRawExtension is for testing only. -func SetRawExtension(base extendableProto, id int32, b []byte) { - if ebase, ok := base.(extensionsMap); ok { - ebase.ExtensionMap()[id] = Extension{enc: b} - } else if ebase, ok := base.(extensionsBytes); ok { - clearExtension(base, id) - ext := ebase.GetExtensions() - *ext = append(*ext, b...) - } else { - panic("unreachable") - } -} - -// isExtensionField returns true iff the given field number is in an extension range. -func isExtensionField(pb extendableProto, field int32) bool { - for _, er := range pb.ExtensionRangeArray() { - if er.Start <= field && field <= er.End { - return true - } - } - return false -} - -// checkExtensionTypes checks that the given extension is valid for pb. -func checkExtensionTypes(pb extendableProto, extension *ExtensionDesc) error { - // Check the extended type. - if a, b := reflect.TypeOf(pb), reflect.TypeOf(extension.ExtendedType); a != b { - return errors.New("proto: bad extended type; " + b.String() + " does not extend " + a.String()) - } - // Check the range. - if !isExtensionField(pb, extension.Field) { - return errors.New("proto: bad extension number; not in declared ranges") - } - return nil -} - -// extPropKey is sufficient to uniquely identify an extension. -type extPropKey struct { - base reflect.Type - field int32 -} - -var extProp = struct { - sync.RWMutex - m map[extPropKey]*Properties -}{ - m: make(map[extPropKey]*Properties), -} - -func extensionProperties(ed *ExtensionDesc) *Properties { - key := extPropKey{base: reflect.TypeOf(ed.ExtendedType), field: ed.Field} - - extProp.RLock() - if prop, ok := extProp.m[key]; ok { - extProp.RUnlock() - return prop - } - extProp.RUnlock() - - extProp.Lock() - defer extProp.Unlock() - // Check again. - if prop, ok := extProp.m[key]; ok { - return prop - } - - prop := new(Properties) - prop.Init(reflect.TypeOf(ed.ExtensionType), "unknown_name", ed.Tag, nil) - extProp.m[key] = prop - return prop -} - -// encodeExtensionMap encodes any unmarshaled (unencoded) extensions in m. -func encodeExtensionMap(m map[int32]Extension) error { - for k, e := range m { - err := encodeExtension(&e) - if err != nil { - return err - } - m[k] = e - } - return nil -} - -func encodeExtension(e *Extension) error { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - return nil - } - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - p := NewBuffer(nil) - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { - return err - } - e.enc = p.buf - return nil -} - -func sizeExtensionMap(m map[int32]Extension) (n int) { - for _, e := range m { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - n += len(e.enc) - continue - } - - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - n += props.size(props, toStructPointer(x)) - } - return -} - -// HasExtension returns whether the given extension is present in pb. -func HasExtension(pb extendableProto, extension *ExtensionDesc) bool { - // TODO: Check types, field numbers, etc.? - if epb, doki := pb.(extensionsMap); doki { - _, ok := epb.ExtensionMap()[extension.Field] - return ok - } else if epb, doki := pb.(extensionsBytes); doki { - ext := epb.GetExtensions() - buf := *ext - o := 0 - for o < len(buf) { - tag, n := DecodeVarint(buf[o:]) - fieldNum := int32(tag >> 3) - if int32(fieldNum) == extension.Field { - return true - } - wireType := int(tag & 0x7) - o += n - l, err := size(buf[o:], wireType) - if err != nil { - return false - } - o += l - } - return false - } - panic("unreachable") -} - -func deleteExtension(pb extensionsBytes, theFieldNum int32, offset int) int { - ext := pb.GetExtensions() - for offset < len(*ext) { - tag, n1 := DecodeVarint((*ext)[offset:]) - fieldNum := int32(tag >> 3) - wireType := int(tag & 0x7) - n2, err := size((*ext)[offset+n1:], wireType) - if err != nil { - panic(err) - } - newOffset := offset + n1 + n2 - if fieldNum == theFieldNum { - *ext = append((*ext)[:offset], (*ext)[newOffset:]...) - return offset - } - offset = newOffset - } - return -1 -} - -func clearExtension(pb extendableProto, fieldNum int32) { - if epb, doki := pb.(extensionsMap); doki { - delete(epb.ExtensionMap(), fieldNum) - } else if epb, doki := pb.(extensionsBytes); doki { - offset := 0 - for offset != -1 { - offset = deleteExtension(epb, fieldNum, offset) - } - } else { - panic("unreachable") - } -} - -// ClearExtension removes the given extension from pb. -func ClearExtension(pb extendableProto, extension *ExtensionDesc) { - // TODO: Check types, field numbers, etc.? - clearExtension(pb, extension.Field) -} - -// GetExtension parses and returns the given extension of pb. -// If the extension is not present it returns ErrMissingExtension. -func GetExtension(pb extendableProto, extension *ExtensionDesc) (interface{}, error) { - if err := checkExtensionTypes(pb, extension); err != nil { - return nil, err - } - - if epb, doki := pb.(extensionsMap); doki { - emap := epb.ExtensionMap() - e, ok := emap[extension.Field] - if !ok { - // defaultExtensionValue returns the default value or - // ErrMissingExtension if there is no default. - return defaultExtensionValue(extension) - } - if e.value != nil { - // Already decoded. Check the descriptor, though. - if e.desc != extension { - // This shouldn't happen. If it does, it means that - // GetExtension was called twice with two different - // descriptors with the same field number. - return nil, errors.New("proto: descriptor conflict") - } - return e.value, nil - } - - v, err := decodeExtension(e.enc, extension) - if err != nil { - return nil, err - } - - // Remember the decoded version and drop the encoded version. - // That way it is safe to mutate what we return. - e.value = v - e.desc = extension - e.enc = nil - emap[extension.Field] = e - return e.value, nil - } else if epb, doki := pb.(extensionsBytes); doki { - ext := epb.GetExtensions() - o := 0 - for o < len(*ext) { - tag, n := DecodeVarint((*ext)[o:]) - fieldNum := int32(tag >> 3) - wireType := int(tag & 0x7) - l, err := size((*ext)[o+n:], wireType) - if err != nil { - return nil, err - } - if int32(fieldNum) == extension.Field { - v, err := decodeExtension((*ext)[o:o+n+l], extension) - if err != nil { - return nil, err - } - return v, nil - } - o += n + l - } - return defaultExtensionValue(extension) - } - panic("unreachable") -} - -// defaultExtensionValue returns the default value for extension. -// If no default for an extension is defined ErrMissingExtension is returned. -func defaultExtensionValue(extension *ExtensionDesc) (interface{}, error) { - t := reflect.TypeOf(extension.ExtensionType) - props := extensionProperties(extension) - - sf, _, err := fieldDefault(t, props) - if err != nil { - return nil, err - } - - if sf == nil || sf.value == nil { - // There is no default value. - return nil, ErrMissingExtension - } - - if t.Kind() != reflect.Ptr { - // We do not need to return a Ptr, we can directly return sf.value. - return sf.value, nil - } - - // We need to return an interface{} that is a pointer to sf.value. - value := reflect.New(t).Elem() - value.Set(reflect.New(value.Type().Elem())) - if sf.kind == reflect.Int32 { - // We may have an int32 or an enum, but the underlying data is int32. - // Since we can't set an int32 into a non int32 reflect.value directly - // set it as a int32. - value.Elem().SetInt(int64(sf.value.(int32))) - } else { - value.Elem().Set(reflect.ValueOf(sf.value)) - } - return value.Interface(), nil -} - -// decodeExtension decodes an extension encoded in b. -func decodeExtension(b []byte, extension *ExtensionDesc) (interface{}, error) { - o := NewBuffer(b) - - t := reflect.TypeOf(extension.ExtensionType) - - props := extensionProperties(extension) - - // t is a pointer to a struct, pointer to basic type or a slice. - // Allocate a "field" to store the pointer/slice itself; the - // pointer/slice will be stored here. We pass - // the address of this field to props.dec. - // This passes a zero field and a *t and lets props.dec - // interpret it as a *struct{ x t }. - value := reflect.New(t).Elem() - - for { - // Discard wire type and field number varint. It isn't needed. - if _, err := o.DecodeVarint(); err != nil { - return nil, err - } - - if err := props.dec(o, props, toStructPointer(value.Addr())); err != nil { - return nil, err - } - - if o.index >= len(o.buf) { - break - } - } - return value.Interface(), nil -} - -// GetExtensions returns a slice of the extensions present in pb that are also listed in es. -// The returned slice has the same length as es; missing extensions will appear as nil elements. -func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, err error) { - epb, ok := pb.(extendableProto) - if !ok { - err = errors.New("proto: not an extendable proto") - return - } - extensions = make([]interface{}, len(es)) - for i, e := range es { - extensions[i], err = GetExtension(epb, e) - if err == ErrMissingExtension { - err = nil - } - if err != nil { - return - } - } - return -} - -// SetExtension sets the specified extension of pb to the specified value. -func SetExtension(pb extendableProto, extension *ExtensionDesc, value interface{}) error { - if err := checkExtensionTypes(pb, extension); err != nil { - return err - } - typ := reflect.TypeOf(extension.ExtensionType) - if typ != reflect.TypeOf(value) { - return errors.New("proto: bad extension value type") - } - // nil extension values need to be caught early, because the - // encoder can't distinguish an ErrNil due to a nil extension - // from an ErrNil due to a missing field. Extensions are - // always optional, so the encoder would just swallow the error - // and drop all the extensions from the encoded message. - if reflect.ValueOf(value).IsNil() { - return fmt.Errorf("proto: SetExtension called with nil value of type %T", value) - } - return setExtension(pb, extension, value) -} - -func setExtension(pb extendableProto, extension *ExtensionDesc, value interface{}) error { - if epb, doki := pb.(extensionsMap); doki { - epb.ExtensionMap()[extension.Field] = Extension{desc: extension, value: value} - } else if epb, doki := pb.(extensionsBytes); doki { - ClearExtension(pb, extension) - ext := epb.GetExtensions() - et := reflect.TypeOf(extension.ExtensionType) - props := extensionProperties(extension) - p := NewBuffer(nil) - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { - return err - } - *ext = append(*ext, p.buf...) - } - return nil -} - -// A global registry of extensions. -// The generated code will register the generated descriptors by calling RegisterExtension. - -var extensionMaps = make(map[reflect.Type]map[int32]*ExtensionDesc) - -// RegisterExtension is called from the generated code. -func RegisterExtension(desc *ExtensionDesc) { - st := reflect.TypeOf(desc.ExtendedType).Elem() - m := extensionMaps[st] - if m == nil { - m = make(map[int32]*ExtensionDesc) - extensionMaps[st] = m - } - if _, ok := m[desc.Field]; ok { - panic("proto: duplicate extension registered: " + st.String() + " " + strconv.Itoa(int(desc.Field))) - } - m[desc.Field] = desc -} - -// RegisteredExtensions returns a map of the registered extensions of a -// protocol buffer struct, indexed by the extension number. -// The argument pb should be a nil pointer to the struct type. -func RegisteredExtensions(pb Message) map[int32]*ExtensionDesc { - return extensionMaps[reflect.TypeOf(pb).Elem()] -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go deleted file mode 100644 index 86b1fa2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/extensions_gogo.go +++ /dev/null @@ -1,236 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "bytes" - "errors" - "fmt" - "reflect" - "sort" - "strings" -) - -func GetBoolExtension(pb extendableProto, extension *ExtensionDesc, ifnotset bool) bool { - if reflect.ValueOf(pb).IsNil() { - return ifnotset - } - value, err := GetExtension(pb, extension) - if err != nil { - return ifnotset - } - if value == nil { - return ifnotset - } - if value.(*bool) == nil { - return ifnotset - } - return *(value.(*bool)) -} - -func (this *Extension) Equal(that *Extension) bool { - return bytes.Equal(this.enc, that.enc) -} - -func (this *Extension) Compare(that *Extension) int { - return bytes.Compare(this.enc, that.enc) -} - -func SizeOfExtensionMap(m map[int32]Extension) (n int) { - return sizeExtensionMap(m) -} - -type sortableMapElem struct { - field int32 - ext Extension -} - -func newSortableExtensionsFromMap(m map[int32]Extension) sortableExtensions { - s := make(sortableExtensions, 0, len(m)) - for k, v := range m { - s = append(s, &sortableMapElem{field: k, ext: v}) - } - return s -} - -type sortableExtensions []*sortableMapElem - -func (this sortableExtensions) Len() int { return len(this) } - -func (this sortableExtensions) Swap(i, j int) { this[i], this[j] = this[j], this[i] } - -func (this sortableExtensions) Less(i, j int) bool { return this[i].field < this[j].field } - -func (this sortableExtensions) String() string { - sort.Sort(this) - ss := make([]string, len(this)) - for i := range this { - ss[i] = fmt.Sprintf("%d: %v", this[i].field, this[i].ext) - } - return "map[" + strings.Join(ss, ",") + "]" -} - -func StringFromExtensionsMap(m map[int32]Extension) string { - return newSortableExtensionsFromMap(m).String() -} - -func StringFromExtensionsBytes(ext []byte) string { - m, err := BytesToExtensionsMap(ext) - if err != nil { - panic(err) - } - return StringFromExtensionsMap(m) -} - -func EncodeExtensionMap(m map[int32]Extension, data []byte) (n int, err error) { - if err := encodeExtensionMap(m); err != nil { - return 0, err - } - keys := make([]int, 0, len(m)) - for k := range m { - keys = append(keys, int(k)) - } - sort.Ints(keys) - for _, k := range keys { - n += copy(data[n:], m[int32(k)].enc) - } - return n, nil -} - -func GetRawExtension(m map[int32]Extension, id int32) ([]byte, error) { - if m[id].value == nil || m[id].desc == nil { - return m[id].enc, nil - } - if err := encodeExtensionMap(m); err != nil { - return nil, err - } - return m[id].enc, nil -} - -func size(buf []byte, wire int) (int, error) { - switch wire { - case WireVarint: - _, n := DecodeVarint(buf) - return n, nil - case WireFixed64: - return 8, nil - case WireBytes: - v, n := DecodeVarint(buf) - return int(v) + n, nil - case WireFixed32: - return 4, nil - case WireStartGroup: - offset := 0 - for { - u, n := DecodeVarint(buf[offset:]) - fwire := int(u & 0x7) - offset += n - if fwire == WireEndGroup { - return offset, nil - } - s, err := size(buf[offset:], wire) - if err != nil { - return 0, err - } - offset += s - } - } - return 0, fmt.Errorf("proto: can't get size for unknown wire type %d", wire) -} - -func BytesToExtensionsMap(buf []byte) (map[int32]Extension, error) { - m := make(map[int32]Extension) - i := 0 - for i < len(buf) { - tag, n := DecodeVarint(buf[i:]) - if n <= 0 { - return nil, fmt.Errorf("unable to decode varint") - } - fieldNum := int32(tag >> 3) - wireType := int(tag & 0x7) - l, err := size(buf[i+n:], wireType) - if err != nil { - return nil, err - } - end := i + int(l) + n - m[int32(fieldNum)] = Extension{enc: buf[i:end]} - i = end - } - return m, nil -} - -func NewExtension(e []byte) Extension { - ee := Extension{enc: make([]byte, len(e))} - copy(ee.enc, e) - return ee -} - -func AppendExtension(e extendableProto, tag int32, buf []byte) { - if ee, eok := e.(extensionsMap); eok { - ext := ee.ExtensionMap()[int32(tag)] // may be missing - ext.enc = append(ext.enc, buf...) - ee.ExtensionMap()[int32(tag)] = ext - } else if ee, eok := e.(extensionsBytes); eok { - ext := ee.GetExtensions() - *ext = append(*ext, buf...) - } -} - -func (this Extension) GoString() string { - if this.enc == nil { - if err := encodeExtension(&this); err != nil { - panic(err) - } - } - return fmt.Sprintf("proto.NewExtension(%#v)", this.enc) -} - -func SetUnsafeExtension(pb extendableProto, fieldNum int32, value interface{}) error { - typ := reflect.TypeOf(pb).Elem() - ext, ok := extensionMaps[typ] - if !ok { - return fmt.Errorf("proto: bad extended type; %s is not extendable", typ.String()) - } - desc, ok := ext[fieldNum] - if !ok { - return errors.New("proto: bad extension number; not in declared ranges") - } - return setExtension(pb, desc, value) -} - -func GetUnsafeExtension(pb extendableProto, fieldNum int32) (interface{}, error) { - typ := reflect.TypeOf(pb).Elem() - ext, ok := extensionMaps[typ] - if !ok { - return nil, fmt.Errorf("proto: bad extended type; %s is not extendable", typ.String()) - } - desc, ok := ext[fieldNum] - if !ok { - return nil, fmt.Errorf("unregistered field number %d", fieldNum) - } - return GetExtension(pb, desc) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib.go deleted file mode 100644 index 2e35ae2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib.go +++ /dev/null @@ -1,894 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -/* -Package proto converts data structures to and from the wire format of -protocol buffers. It works in concert with the Go source code generated -for .proto files by the protocol compiler. - -A summary of the properties of the protocol buffer interface -for a protocol buffer variable v: - - - Names are turned from camel_case to CamelCase for export. - - There are no methods on v to set fields; just treat - them as structure fields. - - There are getters that return a field's value if set, - and return the field's default value if unset. - The getters work even if the receiver is a nil message. - - The zero value for a struct is its correct initialization state. - All desired fields must be set before marshaling. - - A Reset() method will restore a protobuf struct to its zero state. - - Non-repeated fields are pointers to the values; nil means unset. - That is, optional or required field int32 f becomes F *int32. - - Repeated fields are slices. - - Helper functions are available to aid the setting of fields. - msg.Foo = proto.String("hello") // set field - - Constants are defined to hold the default values of all fields that - have them. They have the form Default_StructName_FieldName. - Because the getter methods handle defaulted values, - direct use of these constants should be rare. - - Enums are given type names and maps from names to values. - Enum values are prefixed by the enclosing message's name, or by the - enum's type name if it is a top-level enum. Enum types have a String - method, and a Enum method to assist in message construction. - - Nested messages, groups and enums have type names prefixed with the name of - the surrounding message type. - - Extensions are given descriptor names that start with E_, - followed by an underscore-delimited list of the nested messages - that contain it (if any) followed by the CamelCased name of the - extension field itself. HasExtension, ClearExtension, GetExtension - and SetExtension are functions for manipulating extensions. - - Oneof field sets are given a single field in their message, - with distinguished wrapper types for each possible field value. - - Marshal and Unmarshal are functions to encode and decode the wire format. - -When the .proto file specifies `syntax="proto3"`, there are some differences: - - - Non-repeated fields of non-message type are values instead of pointers. - - Getters are only generated for message and oneof fields. - - Enum types do not get an Enum method. - -The simplest way to describe this is to see an example. -Given file test.proto, containing - - package example; - - enum FOO { X = 17; } - - message Test { - required string label = 1; - optional int32 type = 2 [default=77]; - repeated int64 reps = 3; - optional group OptionalGroup = 4 { - required string RequiredField = 5; - } - oneof union { - int32 number = 6; - string name = 7; - } - } - -The resulting file, test.pb.go, is: - - package example - - import proto "github.com/gogo/protobuf/proto" - import math "math" - - type FOO int32 - const ( - FOO_X FOO = 17 - ) - var FOO_name = map[int32]string{ - 17: "X", - } - var FOO_value = map[string]int32{ - "X": 17, - } - - func (x FOO) Enum() *FOO { - p := new(FOO) - *p = x - return p - } - func (x FOO) String() string { - return proto.EnumName(FOO_name, int32(x)) - } - func (x *FOO) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(FOO_value, data) - if err != nil { - return err - } - *x = FOO(value) - return nil - } - - type Test struct { - Label *string `protobuf:"bytes,1,req,name=label" json:"label,omitempty"` - Type *int32 `protobuf:"varint,2,opt,name=type,def=77" json:"type,omitempty"` - Reps []int64 `protobuf:"varint,3,rep,name=reps" json:"reps,omitempty"` - Optionalgroup *Test_OptionalGroup `protobuf:"group,4,opt,name=OptionalGroup" json:"optionalgroup,omitempty"` - // Types that are valid to be assigned to Union: - // *Test_Number - // *Test_Name - Union isTest_Union `protobuf_oneof:"union"` - XXX_unrecognized []byte `json:"-"` - } - func (m *Test) Reset() { *m = Test{} } - func (m *Test) String() string { return proto.CompactTextString(m) } - func (*Test) ProtoMessage() {} - - type isTest_Union interface { - isTest_Union() - } - - type Test_Number struct { - Number int32 `protobuf:"varint,6,opt,name=number"` - } - type Test_Name struct { - Name string `protobuf:"bytes,7,opt,name=name"` - } - - func (*Test_Number) isTest_Union() {} - func (*Test_Name) isTest_Union() {} - - func (m *Test) GetUnion() isTest_Union { - if m != nil { - return m.Union - } - return nil - } - const Default_Test_Type int32 = 77 - - func (m *Test) GetLabel() string { - if m != nil && m.Label != nil { - return *m.Label - } - return "" - } - - func (m *Test) GetType() int32 { - if m != nil && m.Type != nil { - return *m.Type - } - return Default_Test_Type - } - - func (m *Test) GetOptionalgroup() *Test_OptionalGroup { - if m != nil { - return m.Optionalgroup - } - return nil - } - - type Test_OptionalGroup struct { - RequiredField *string `protobuf:"bytes,5,req" json:"RequiredField,omitempty"` - } - func (m *Test_OptionalGroup) Reset() { *m = Test_OptionalGroup{} } - func (m *Test_OptionalGroup) String() string { return proto.CompactTextString(m) } - - func (m *Test_OptionalGroup) GetRequiredField() string { - if m != nil && m.RequiredField != nil { - return *m.RequiredField - } - return "" - } - - func (m *Test) GetNumber() int32 { - if x, ok := m.GetUnion().(*Test_Number); ok { - return x.Number - } - return 0 - } - - func (m *Test) GetName() string { - if x, ok := m.GetUnion().(*Test_Name); ok { - return x.Name - } - return "" - } - - func init() { - proto.RegisterEnum("example.FOO", FOO_name, FOO_value) - } - -To create and play with a Test object: - - package main - - import ( - "log" - - "github.com/gogo/protobuf/proto" - pb "./example.pb" - ) - - func main() { - test := &pb.Test{ - Label: proto.String("hello"), - Type: proto.Int32(17), - Reps: []int64{1, 2, 3}, - Optionalgroup: &pb.Test_OptionalGroup{ - RequiredField: proto.String("good bye"), - }, - Union: &pb.Test_Name{"fred"}, - } - data, err := proto.Marshal(test) - if err != nil { - log.Fatal("marshaling error: ", err) - } - newTest := &pb.Test{} - err = proto.Unmarshal(data, newTest) - if err != nil { - log.Fatal("unmarshaling error: ", err) - } - // Now test and newTest contain the same data. - if test.GetLabel() != newTest.GetLabel() { - log.Fatalf("data mismatch %q != %q", test.GetLabel(), newTest.GetLabel()) - } - // Use a type switch to determine which oneof was set. - switch u := test.Union.(type) { - case *pb.Test_Number: // u.Number contains the number. - case *pb.Test_Name: // u.Name contains the string. - } - // etc. - } -*/ -package proto - -import ( - "encoding/json" - "fmt" - "log" - "reflect" - "sort" - "strconv" - "sync" -) - -// Message is implemented by generated protocol buffer messages. -type Message interface { - Reset() - String() string - ProtoMessage() -} - -// Stats records allocation details about the protocol buffer encoders -// and decoders. Useful for tuning the library itself. -type Stats struct { - Emalloc uint64 // mallocs in encode - Dmalloc uint64 // mallocs in decode - Encode uint64 // number of encodes - Decode uint64 // number of decodes - Chit uint64 // number of cache hits - Cmiss uint64 // number of cache misses - Size uint64 // number of sizes -} - -// Set to true to enable stats collection. -const collectStats = false - -var stats Stats - -// GetStats returns a copy of the global Stats structure. -func GetStats() Stats { return stats } - -// A Buffer is a buffer manager for marshaling and unmarshaling -// protocol buffers. It may be reused between invocations to -// reduce memory usage. It is not necessary to use a Buffer; -// the global functions Marshal and Unmarshal create a -// temporary Buffer and are fine for most applications. -type Buffer struct { - buf []byte // encode/decode byte stream - index int // write point - - // pools of basic types to amortize allocation. - bools []bool - uint32s []uint32 - uint64s []uint64 - - // extra pools, only used with pointer_reflect.go - int32s []int32 - int64s []int64 - float32s []float32 - float64s []float64 -} - -// NewBuffer allocates a new Buffer and initializes its internal data to -// the contents of the argument slice. -func NewBuffer(e []byte) *Buffer { - return &Buffer{buf: e} -} - -// Reset resets the Buffer, ready for marshaling a new protocol buffer. -func (p *Buffer) Reset() { - p.buf = p.buf[0:0] // for reading/writing - p.index = 0 // for reading -} - -// SetBuf replaces the internal buffer with the slice, -// ready for unmarshaling the contents of the slice. -func (p *Buffer) SetBuf(s []byte) { - p.buf = s - p.index = 0 -} - -// Bytes returns the contents of the Buffer. -func (p *Buffer) Bytes() []byte { return p.buf } - -/* - * Helper routines for simplifying the creation of optional fields of basic type. - */ - -// Bool is a helper routine that allocates a new bool value -// to store v and returns a pointer to it. -func Bool(v bool) *bool { - return &v -} - -// Int32 is a helper routine that allocates a new int32 value -// to store v and returns a pointer to it. -func Int32(v int32) *int32 { - return &v -} - -// Int is a helper routine that allocates a new int32 value -// to store v and returns a pointer to it, but unlike Int32 -// its argument value is an int. -func Int(v int) *int32 { - p := new(int32) - *p = int32(v) - return p -} - -// Int64 is a helper routine that allocates a new int64 value -// to store v and returns a pointer to it. -func Int64(v int64) *int64 { - return &v -} - -// Float32 is a helper routine that allocates a new float32 value -// to store v and returns a pointer to it. -func Float32(v float32) *float32 { - return &v -} - -// Float64 is a helper routine that allocates a new float64 value -// to store v and returns a pointer to it. -func Float64(v float64) *float64 { - return &v -} - -// Uint32 is a helper routine that allocates a new uint32 value -// to store v and returns a pointer to it. -func Uint32(v uint32) *uint32 { - return &v -} - -// Uint64 is a helper routine that allocates a new uint64 value -// to store v and returns a pointer to it. -func Uint64(v uint64) *uint64 { - return &v -} - -// String is a helper routine that allocates a new string value -// to store v and returns a pointer to it. -func String(v string) *string { - return &v -} - -// EnumName is a helper function to simplify printing protocol buffer enums -// by name. Given an enum map and a value, it returns a useful string. -func EnumName(m map[int32]string, v int32) string { - s, ok := m[v] - if ok { - return s - } - return strconv.Itoa(int(v)) -} - -// UnmarshalJSONEnum is a helper function to simplify recovering enum int values -// from their JSON-encoded representation. Given a map from the enum's symbolic -// names to its int values, and a byte buffer containing the JSON-encoded -// value, it returns an int32 that can be cast to the enum type by the caller. -// -// The function can deal with both JSON representations, numeric and symbolic. -func UnmarshalJSONEnum(m map[string]int32, data []byte, enumName string) (int32, error) { - if data[0] == '"' { - // New style: enums are strings. - var repr string - if err := json.Unmarshal(data, &repr); err != nil { - return -1, err - } - val, ok := m[repr] - if !ok { - return 0, fmt.Errorf("unrecognized enum %s value %q", enumName, repr) - } - return val, nil - } - // Old style: enums are ints. - var val int32 - if err := json.Unmarshal(data, &val); err != nil { - return 0, fmt.Errorf("cannot unmarshal %#q into enum %s", data, enumName) - } - return val, nil -} - -// DebugPrint dumps the encoded data in b in a debugging format with a header -// including the string s. Used in testing but made available for general debugging. -func (p *Buffer) DebugPrint(s string, b []byte) { - var u uint64 - - obuf := p.buf - sindex := p.index - p.buf = b - p.index = 0 - depth := 0 - - fmt.Printf("\n--- %s ---\n", s) - -out: - for { - for i := 0; i < depth; i++ { - fmt.Print(" ") - } - - index := p.index - if index == len(p.buf) { - break - } - - op, err := p.DecodeVarint() - if err != nil { - fmt.Printf("%3d: fetching op err %v\n", index, err) - break out - } - tag := op >> 3 - wire := op & 7 - - switch wire { - default: - fmt.Printf("%3d: t=%3d unknown wire=%d\n", - index, tag, wire) - break out - - case WireBytes: - var r []byte - - r, err = p.DecodeRawBytes(false) - if err != nil { - break out - } - fmt.Printf("%3d: t=%3d bytes [%d]", index, tag, len(r)) - if len(r) <= 6 { - for i := 0; i < len(r); i++ { - fmt.Printf(" %.2x", r[i]) - } - } else { - for i := 0; i < 3; i++ { - fmt.Printf(" %.2x", r[i]) - } - fmt.Printf(" ..") - for i := len(r) - 3; i < len(r); i++ { - fmt.Printf(" %.2x", r[i]) - } - } - fmt.Printf("\n") - - case WireFixed32: - u, err = p.DecodeFixed32() - if err != nil { - fmt.Printf("%3d: t=%3d fix32 err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d fix32 %d\n", index, tag, u) - - case WireFixed64: - u, err = p.DecodeFixed64() - if err != nil { - fmt.Printf("%3d: t=%3d fix64 err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d fix64 %d\n", index, tag, u) - - case WireVarint: - u, err = p.DecodeVarint() - if err != nil { - fmt.Printf("%3d: t=%3d varint err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d varint %d\n", index, tag, u) - - case WireStartGroup: - fmt.Printf("%3d: t=%3d start\n", index, tag) - depth++ - - case WireEndGroup: - depth-- - fmt.Printf("%3d: t=%3d end\n", index, tag) - } - } - - if depth != 0 { - fmt.Printf("%3d: start-end not balanced %d\n", p.index, depth) - } - fmt.Printf("\n") - - p.buf = obuf - p.index = sindex -} - -// SetDefaults sets unset protocol buffer fields to their default values. -// It only modifies fields that are both unset and have defined defaults. -// It recursively sets default values in any non-nil sub-messages. -func SetDefaults(pb Message) { - setDefaults(reflect.ValueOf(pb), true, false) -} - -// v is a pointer to a struct. -func setDefaults(v reflect.Value, recur, zeros bool) { - v = v.Elem() - - defaultMu.RLock() - dm, ok := defaults[v.Type()] - defaultMu.RUnlock() - if !ok { - dm = buildDefaultMessage(v.Type()) - defaultMu.Lock() - defaults[v.Type()] = dm - defaultMu.Unlock() - } - - for _, sf := range dm.scalars { - f := v.Field(sf.index) - if !f.IsNil() { - // field already set - continue - } - dv := sf.value - if dv == nil && !zeros { - // no explicit default, and don't want to set zeros - continue - } - fptr := f.Addr().Interface() // **T - // TODO: Consider batching the allocations we do here. - switch sf.kind { - case reflect.Bool: - b := new(bool) - if dv != nil { - *b = dv.(bool) - } - *(fptr.(**bool)) = b - case reflect.Float32: - f := new(float32) - if dv != nil { - *f = dv.(float32) - } - *(fptr.(**float32)) = f - case reflect.Float64: - f := new(float64) - if dv != nil { - *f = dv.(float64) - } - *(fptr.(**float64)) = f - case reflect.Int32: - // might be an enum - if ft := f.Type(); ft != int32PtrType { - // enum - f.Set(reflect.New(ft.Elem())) - if dv != nil { - f.Elem().SetInt(int64(dv.(int32))) - } - } else { - // int32 field - i := new(int32) - if dv != nil { - *i = dv.(int32) - } - *(fptr.(**int32)) = i - } - case reflect.Int64: - i := new(int64) - if dv != nil { - *i = dv.(int64) - } - *(fptr.(**int64)) = i - case reflect.String: - s := new(string) - if dv != nil { - *s = dv.(string) - } - *(fptr.(**string)) = s - case reflect.Uint8: - // exceptional case: []byte - var b []byte - if dv != nil { - db := dv.([]byte) - b = make([]byte, len(db)) - copy(b, db) - } else { - b = []byte{} - } - *(fptr.(*[]byte)) = b - case reflect.Uint32: - u := new(uint32) - if dv != nil { - *u = dv.(uint32) - } - *(fptr.(**uint32)) = u - case reflect.Uint64: - u := new(uint64) - if dv != nil { - *u = dv.(uint64) - } - *(fptr.(**uint64)) = u - default: - log.Printf("proto: can't set default for field %v (sf.kind=%v)", f, sf.kind) - } - } - - for _, ni := range dm.nested { - f := v.Field(ni) - // f is *T or []*T or map[T]*T - switch f.Kind() { - case reflect.Ptr: - if f.IsNil() { - continue - } - setDefaults(f, recur, zeros) - - case reflect.Slice: - for i := 0; i < f.Len(); i++ { - e := f.Index(i) - if e.IsNil() { - continue - } - setDefaults(e, recur, zeros) - } - - case reflect.Map: - for _, k := range f.MapKeys() { - e := f.MapIndex(k) - if e.IsNil() { - continue - } - setDefaults(e, recur, zeros) - } - } - } -} - -var ( - // defaults maps a protocol buffer struct type to a slice of the fields, - // with its scalar fields set to their proto-declared non-zero default values. - defaultMu sync.RWMutex - defaults = make(map[reflect.Type]defaultMessage) - - int32PtrType = reflect.TypeOf((*int32)(nil)) -) - -// defaultMessage represents information about the default values of a message. -type defaultMessage struct { - scalars []scalarField - nested []int // struct field index of nested messages -} - -type scalarField struct { - index int // struct field index - kind reflect.Kind // element type (the T in *T or []T) - value interface{} // the proto-declared default value, or nil -} - -// t is a struct type. -func buildDefaultMessage(t reflect.Type) (dm defaultMessage) { - sprop := GetProperties(t) - for _, prop := range sprop.Prop { - fi, ok := sprop.decoderTags.get(prop.Tag) - if !ok { - // XXX_unrecognized - continue - } - ft := t.Field(fi).Type - - sf, nested, err := fieldDefault(ft, prop) - switch { - case err != nil: - log.Print(err) - case nested: - dm.nested = append(dm.nested, fi) - case sf != nil: - sf.index = fi - dm.scalars = append(dm.scalars, *sf) - } - } - - return dm -} - -// fieldDefault returns the scalarField for field type ft. -// sf will be nil if the field can not have a default. -// nestedMessage will be true if this is a nested message. -// Note that sf.index is not set on return. -func fieldDefault(ft reflect.Type, prop *Properties) (sf *scalarField, nestedMessage bool, err error) { - var canHaveDefault bool - switch ft.Kind() { - case reflect.Ptr: - if ft.Elem().Kind() == reflect.Struct { - nestedMessage = true - } else { - canHaveDefault = true // proto2 scalar field - } - - case reflect.Slice: - switch ft.Elem().Kind() { - case reflect.Ptr: - nestedMessage = true // repeated message - case reflect.Uint8: - canHaveDefault = true // bytes field - } - - case reflect.Map: - if ft.Elem().Kind() == reflect.Ptr { - nestedMessage = true // map with message values - } - } - - if !canHaveDefault { - if nestedMessage { - return nil, true, nil - } - return nil, false, nil - } - - // We now know that ft is a pointer or slice. - sf = &scalarField{kind: ft.Elem().Kind()} - - // scalar fields without defaults - if !prop.HasDefault { - return sf, false, nil - } - - // a scalar field: either *T or []byte - switch ft.Elem().Kind() { - case reflect.Bool: - x, err := strconv.ParseBool(prop.Default) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default bool %q: %v", prop.Default, err) - } - sf.value = x - case reflect.Float32: - x, err := strconv.ParseFloat(prop.Default, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default float32 %q: %v", prop.Default, err) - } - sf.value = float32(x) - case reflect.Float64: - x, err := strconv.ParseFloat(prop.Default, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default float64 %q: %v", prop.Default, err) - } - sf.value = x - case reflect.Int32: - x, err := strconv.ParseInt(prop.Default, 10, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default int32 %q: %v", prop.Default, err) - } - sf.value = int32(x) - case reflect.Int64: - x, err := strconv.ParseInt(prop.Default, 10, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default int64 %q: %v", prop.Default, err) - } - sf.value = x - case reflect.String: - sf.value = prop.Default - case reflect.Uint8: - // []byte (not *uint8) - sf.value = []byte(prop.Default) - case reflect.Uint32: - x, err := strconv.ParseUint(prop.Default, 10, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default uint32 %q: %v", prop.Default, err) - } - sf.value = uint32(x) - case reflect.Uint64: - x, err := strconv.ParseUint(prop.Default, 10, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default uint64 %q: %v", prop.Default, err) - } - sf.value = x - default: - return nil, false, fmt.Errorf("proto: unhandled def kind %v", ft.Elem().Kind()) - } - - return sf, false, nil -} - -// Map fields may have key types of non-float scalars, strings and enums. -// The easiest way to sort them in some deterministic order is to use fmt. -// If this turns out to be inefficient we can always consider other options, -// such as doing a Schwartzian transform. - -func mapKeys(vs []reflect.Value) sort.Interface { - s := mapKeySorter{ - vs: vs, - // default Less function: textual comparison - less: func(a, b reflect.Value) bool { - return fmt.Sprint(a.Interface()) < fmt.Sprint(b.Interface()) - }, - } - - // Type specialization per https://developers.google.com/protocol-buffers/docs/proto#maps; - // numeric keys are sorted numerically. - if len(vs) == 0 { - return s - } - switch vs[0].Kind() { - case reflect.Int32, reflect.Int64: - s.less = func(a, b reflect.Value) bool { return a.Int() < b.Int() } - case reflect.Uint32, reflect.Uint64: - s.less = func(a, b reflect.Value) bool { return a.Uint() < b.Uint() } - } - - return s -} - -type mapKeySorter struct { - vs []reflect.Value - less func(a, b reflect.Value) bool -} - -func (s mapKeySorter) Len() int { return len(s.vs) } -func (s mapKeySorter) Swap(i, j int) { s.vs[i], s.vs[j] = s.vs[j], s.vs[i] } -func (s mapKeySorter) Less(i, j int) bool { - return s.less(s.vs[i], s.vs[j]) -} - -// isProto3Zero reports whether v is a zero proto3 value. -func isProto3Zero(v reflect.Value) bool { - switch v.Kind() { - case reflect.Bool: - return !v.Bool() - case reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Uint32, reflect.Uint64: - return v.Uint() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.String: - return v.String() == "" - } - return false -} - -// ProtoPackageIsVersion1 is referenced from generated protocol buffer files -// to assert that that code is compatible with this version of the proto package. -const GoGoProtoPackageIsVersion1 = true diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib_gogo.go deleted file mode 100644 index a6c2c06..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/lib_gogo.go +++ /dev/null @@ -1,40 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "encoding/json" - "strconv" -) - -func MarshalJSONEnum(m map[int32]string, value int32) ([]byte, error) { - s, ok := m[value] - if !ok { - s = strconv.Itoa(int(value)) - } - return json.Marshal(s) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/message_set.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/message_set.go deleted file mode 100644 index e25e01e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/message_set.go +++ /dev/null @@ -1,280 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Support for message sets. - */ - -import ( - "bytes" - "encoding/json" - "errors" - "fmt" - "reflect" - "sort" -) - -// errNoMessageTypeID occurs when a protocol buffer does not have a message type ID. -// A message type ID is required for storing a protocol buffer in a message set. -var errNoMessageTypeID = errors.New("proto does not have a message type ID") - -// The first two types (_MessageSet_Item and messageSet) -// model what the protocol compiler produces for the following protocol message: -// message MessageSet { -// repeated group Item = 1 { -// required int32 type_id = 2; -// required string message = 3; -// }; -// } -// That is the MessageSet wire format. We can't use a proto to generate these -// because that would introduce a circular dependency between it and this package. - -type _MessageSet_Item struct { - TypeId *int32 `protobuf:"varint,2,req,name=type_id"` - Message []byte `protobuf:"bytes,3,req,name=message"` -} - -type messageSet struct { - Item []*_MessageSet_Item `protobuf:"group,1,rep"` - XXX_unrecognized []byte - // TODO: caching? -} - -// Make sure messageSet is a Message. -var _ Message = (*messageSet)(nil) - -// messageTypeIder is an interface satisfied by a protocol buffer type -// that may be stored in a MessageSet. -type messageTypeIder interface { - MessageTypeId() int32 -} - -func (ms *messageSet) find(pb Message) *_MessageSet_Item { - mti, ok := pb.(messageTypeIder) - if !ok { - return nil - } - id := mti.MessageTypeId() - for _, item := range ms.Item { - if *item.TypeId == id { - return item - } - } - return nil -} - -func (ms *messageSet) Has(pb Message) bool { - if ms.find(pb) != nil { - return true - } - return false -} - -func (ms *messageSet) Unmarshal(pb Message) error { - if item := ms.find(pb); item != nil { - return Unmarshal(item.Message, pb) - } - if _, ok := pb.(messageTypeIder); !ok { - return errNoMessageTypeID - } - return nil // TODO: return error instead? -} - -func (ms *messageSet) Marshal(pb Message) error { - msg, err := Marshal(pb) - if err != nil { - return err - } - if item := ms.find(pb); item != nil { - // reuse existing item - item.Message = msg - return nil - } - - mti, ok := pb.(messageTypeIder) - if !ok { - return errNoMessageTypeID - } - - mtid := mti.MessageTypeId() - ms.Item = append(ms.Item, &_MessageSet_Item{ - TypeId: &mtid, - Message: msg, - }) - return nil -} - -func (ms *messageSet) Reset() { *ms = messageSet{} } -func (ms *messageSet) String() string { return CompactTextString(ms) } -func (*messageSet) ProtoMessage() {} - -// Support for the message_set_wire_format message option. - -func skipVarint(buf []byte) []byte { - i := 0 - for ; buf[i]&0x80 != 0; i++ { - } - return buf[i+1:] -} - -// MarshalMessageSet encodes the extension map represented by m in the message set wire format. -// It is called by generated Marshal methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSet(m map[int32]Extension) ([]byte, error) { - if err := encodeExtensionMap(m); err != nil { - return nil, err - } - - // Sort extension IDs to provide a deterministic encoding. - // See also enc_map in encode.go. - ids := make([]int, 0, len(m)) - for id := range m { - ids = append(ids, int(id)) - } - sort.Ints(ids) - - ms := &messageSet{Item: make([]*_MessageSet_Item, 0, len(m))} - for _, id := range ids { - e := m[int32(id)] - // Remove the wire type and field number varint, as well as the length varint. - msg := skipVarint(skipVarint(e.enc)) - - ms.Item = append(ms.Item, &_MessageSet_Item{ - TypeId: Int32(int32(id)), - Message: msg, - }) - } - return Marshal(ms) -} - -// UnmarshalMessageSet decodes the extension map encoded in buf in the message set wire format. -// It is called by generated Unmarshal methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSet(buf []byte, m map[int32]Extension) error { - ms := new(messageSet) - if err := Unmarshal(buf, ms); err != nil { - return err - } - for _, item := range ms.Item { - id := *item.TypeId - msg := item.Message - - // Restore wire type and field number varint, plus length varint. - // Be careful to preserve duplicate items. - b := EncodeVarint(uint64(id)<<3 | WireBytes) - if ext, ok := m[id]; ok { - // Existing data; rip off the tag and length varint - // so we join the new data correctly. - // We can assume that ext.enc is set because we are unmarshaling. - o := ext.enc[len(b):] // skip wire type and field number - _, n := DecodeVarint(o) // calculate length of length varint - o = o[n:] // skip length varint - msg = append(o, msg...) // join old data and new data - } - b = append(b, EncodeVarint(uint64(len(msg)))...) - b = append(b, msg...) - - m[id] = Extension{enc: b} - } - return nil -} - -// MarshalMessageSetJSON encodes the extension map represented by m in JSON format. -// It is called by generated MarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSetJSON(m map[int32]Extension) ([]byte, error) { - var b bytes.Buffer - b.WriteByte('{') - - // Process the map in key order for deterministic output. - ids := make([]int32, 0, len(m)) - for id := range m { - ids = append(ids, id) - } - sort.Sort(int32Slice(ids)) // int32Slice defined in text.go - - for i, id := range ids { - ext := m[id] - if i > 0 { - b.WriteByte(',') - } - - msd, ok := messageSetMap[id] - if !ok { - // Unknown type; we can't render it, so skip it. - continue - } - fmt.Fprintf(&b, `"[%s]":`, msd.name) - - x := ext.value - if x == nil { - x = reflect.New(msd.t.Elem()).Interface() - if err := Unmarshal(ext.enc, x.(Message)); err != nil { - return nil, err - } - } - d, err := json.Marshal(x) - if err != nil { - return nil, err - } - b.Write(d) - } - b.WriteByte('}') - return b.Bytes(), nil -} - -// UnmarshalMessageSetJSON decodes the extension map encoded in buf in JSON format. -// It is called by generated UnmarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSetJSON(buf []byte, m map[int32]Extension) error { - // Common-case fast path. - if len(buf) == 0 || bytes.Equal(buf, []byte("{}")) { - return nil - } - - // This is fairly tricky, and it's not clear that it is needed. - return errors.New("TODO: UnmarshalMessageSetJSON not yet implemented") -} - -// A global registry of types that can be used in a MessageSet. - -var messageSetMap = make(map[int32]messageSetDesc) - -type messageSetDesc struct { - t reflect.Type // pointer to struct - name string -} - -// RegisterMessageSetType is called from the generated code. -func RegisterMessageSetType(m Message, fieldNum int32, name string) { - messageSetMap[fieldNum] = messageSetDesc{ - t: reflect.TypeOf(m), - name: name, - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go deleted file mode 100644 index 749919d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_reflect.go +++ /dev/null @@ -1,479 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2012 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// +build appengine - -// This file contains an implementation of proto field accesses using package reflect. -// It is slower than the code in pointer_unsafe.go but it avoids package unsafe and can -// be used on App Engine. - -package proto - -import ( - "math" - "reflect" -) - -// A structPointer is a pointer to a struct. -type structPointer struct { - v reflect.Value -} - -// toStructPointer returns a structPointer equivalent to the given reflect value. -// The reflect value must itself be a pointer to a struct. -func toStructPointer(v reflect.Value) structPointer { - return structPointer{v} -} - -// IsNil reports whether p is nil. -func structPointer_IsNil(p structPointer) bool { - return p.v.IsNil() -} - -// Interface returns the struct pointer as an interface value. -func structPointer_Interface(p structPointer, _ reflect.Type) interface{} { - return p.v.Interface() -} - -// A field identifies a field in a struct, accessible from a structPointer. -// In this implementation, a field is identified by the sequence of field indices -// passed to reflect's FieldByIndex. -type field []int - -// toField returns a field equivalent to the given reflect field. -func toField(f *reflect.StructField) field { - return f.Index -} - -// invalidField is an invalid field identifier. -var invalidField = field(nil) - -// IsValid reports whether the field identifier is valid. -func (f field) IsValid() bool { return f != nil } - -// field returns the given field in the struct as a reflect value. -func structPointer_field(p structPointer, f field) reflect.Value { - // Special case: an extension map entry with a value of type T - // passes a *T to the struct-handling code with a zero field, - // expecting that it will be treated as equivalent to *struct{ X T }, - // which has the same memory layout. We have to handle that case - // specially, because reflect will panic if we call FieldByIndex on a - // non-struct. - if f == nil { - return p.v.Elem() - } - - return p.v.Elem().FieldByIndex(f) -} - -// ifield returns the given field in the struct as an interface value. -func structPointer_ifield(p structPointer, f field) interface{} { - return structPointer_field(p, f).Addr().Interface() -} - -// Bytes returns the address of a []byte field in the struct. -func structPointer_Bytes(p structPointer, f field) *[]byte { - return structPointer_ifield(p, f).(*[]byte) -} - -// BytesSlice returns the address of a [][]byte field in the struct. -func structPointer_BytesSlice(p structPointer, f field) *[][]byte { - return structPointer_ifield(p, f).(*[][]byte) -} - -// Bool returns the address of a *bool field in the struct. -func structPointer_Bool(p structPointer, f field) **bool { - return structPointer_ifield(p, f).(**bool) -} - -// BoolVal returns the address of a bool field in the struct. -func structPointer_BoolVal(p structPointer, f field) *bool { - return structPointer_ifield(p, f).(*bool) -} - -// BoolSlice returns the address of a []bool field in the struct. -func structPointer_BoolSlice(p structPointer, f field) *[]bool { - return structPointer_ifield(p, f).(*[]bool) -} - -// String returns the address of a *string field in the struct. -func structPointer_String(p structPointer, f field) **string { - return structPointer_ifield(p, f).(**string) -} - -// StringVal returns the address of a string field in the struct. -func structPointer_StringVal(p structPointer, f field) *string { - return structPointer_ifield(p, f).(*string) -} - -// StringSlice returns the address of a []string field in the struct. -func structPointer_StringSlice(p structPointer, f field) *[]string { - return structPointer_ifield(p, f).(*[]string) -} - -// ExtMap returns the address of an extension map field in the struct. -func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { - return structPointer_ifield(p, f).(*map[int32]Extension) -} - -// NewAt returns the reflect.Value for a pointer to a field in the struct. -func structPointer_NewAt(p structPointer, f field, typ reflect.Type) reflect.Value { - return structPointer_field(p, f).Addr() -} - -// SetStructPointer writes a *struct field in the struct. -func structPointer_SetStructPointer(p structPointer, f field, q structPointer) { - structPointer_field(p, f).Set(q.v) -} - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return structPointer{structPointer_field(p, f)} -} - -// StructPointerSlice the address of a []*struct field in the struct. -func structPointer_StructPointerSlice(p structPointer, f field) structPointerSlice { - return structPointerSlice{structPointer_field(p, f)} -} - -// A structPointerSlice represents the address of a slice of pointers to structs -// (themselves messages or groups). That is, v.Type() is *[]*struct{...}. -type structPointerSlice struct { - v reflect.Value -} - -func (p structPointerSlice) Len() int { return p.v.Len() } -func (p structPointerSlice) Index(i int) structPointer { return structPointer{p.v.Index(i)} } -func (p structPointerSlice) Append(q structPointer) { - p.v.Set(reflect.Append(p.v, q.v)) -} - -var ( - int32Type = reflect.TypeOf(int32(0)) - uint32Type = reflect.TypeOf(uint32(0)) - float32Type = reflect.TypeOf(float32(0)) - int64Type = reflect.TypeOf(int64(0)) - uint64Type = reflect.TypeOf(uint64(0)) - float64Type = reflect.TypeOf(float64(0)) -) - -// A word32 represents a field of type *int32, *uint32, *float32, or *enum. -// That is, v.Type() is *int32, *uint32, *float32, or *enum and v is assignable. -type word32 struct { - v reflect.Value -} - -// IsNil reports whether p is nil. -func word32_IsNil(p word32) bool { - return p.v.IsNil() -} - -// Set sets p to point at a newly allocated word with bits set to x. -func word32_Set(p word32, o *Buffer, x uint32) { - t := p.v.Type().Elem() - switch t { - case int32Type: - if len(o.int32s) == 0 { - o.int32s = make([]int32, uint32PoolSize) - } - o.int32s[0] = int32(x) - p.v.Set(reflect.ValueOf(&o.int32s[0])) - o.int32s = o.int32s[1:] - return - case uint32Type: - if len(o.uint32s) == 0 { - o.uint32s = make([]uint32, uint32PoolSize) - } - o.uint32s[0] = x - p.v.Set(reflect.ValueOf(&o.uint32s[0])) - o.uint32s = o.uint32s[1:] - return - case float32Type: - if len(o.float32s) == 0 { - o.float32s = make([]float32, uint32PoolSize) - } - o.float32s[0] = math.Float32frombits(x) - p.v.Set(reflect.ValueOf(&o.float32s[0])) - o.float32s = o.float32s[1:] - return - } - - // must be enum - p.v.Set(reflect.New(t)) - p.v.Elem().SetInt(int64(int32(x))) -} - -// Get gets the bits pointed at by p, as a uint32. -func word32_Get(p word32) uint32 { - elem := p.v.Elem() - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32 returns a reference to a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32(p structPointer, f field) word32 { - return word32{structPointer_field(p, f)} -} - -// A word32Val represents a field of type int32, uint32, float32, or enum. -// That is, v.Type() is int32, uint32, float32, or enum and v is assignable. -type word32Val struct { - v reflect.Value -} - -// Set sets *p to x. -func word32Val_Set(p word32Val, x uint32) { - switch p.v.Type() { - case int32Type: - p.v.SetInt(int64(x)) - return - case uint32Type: - p.v.SetUint(uint64(x)) - return - case float32Type: - p.v.SetFloat(float64(math.Float32frombits(x))) - return - } - - // must be enum - p.v.SetInt(int64(int32(x))) -} - -// Get gets the bits pointed at by p, as a uint32. -func word32Val_Get(p word32Val) uint32 { - elem := p.v - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32Val returns a reference to a int32, uint32, float32, or enum field in the struct. -func structPointer_Word32Val(p structPointer, f field) word32Val { - return word32Val{structPointer_field(p, f)} -} - -// A word32Slice is a slice of 32-bit values. -// That is, v.Type() is []int32, []uint32, []float32, or []enum. -type word32Slice struct { - v reflect.Value -} - -func (p word32Slice) Append(x uint32) { - n, m := p.v.Len(), p.v.Cap() - if n < m { - p.v.SetLen(n + 1) - } else { - t := p.v.Type().Elem() - p.v.Set(reflect.Append(p.v, reflect.Zero(t))) - } - elem := p.v.Index(n) - switch elem.Kind() { - case reflect.Int32: - elem.SetInt(int64(int32(x))) - case reflect.Uint32: - elem.SetUint(uint64(x)) - case reflect.Float32: - elem.SetFloat(float64(math.Float32frombits(x))) - } -} - -func (p word32Slice) Len() int { - return p.v.Len() -} - -func (p word32Slice) Index(i int) uint32 { - elem := p.v.Index(i) - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32Slice returns a reference to a []int32, []uint32, []float32, or []enum field in the struct. -func structPointer_Word32Slice(p structPointer, f field) word32Slice { - return word32Slice{structPointer_field(p, f)} -} - -// word64 is like word32 but for 64-bit values. -type word64 struct { - v reflect.Value -} - -func word64_Set(p word64, o *Buffer, x uint64) { - t := p.v.Type().Elem() - switch t { - case int64Type: - if len(o.int64s) == 0 { - o.int64s = make([]int64, uint64PoolSize) - } - o.int64s[0] = int64(x) - p.v.Set(reflect.ValueOf(&o.int64s[0])) - o.int64s = o.int64s[1:] - return - case uint64Type: - if len(o.uint64s) == 0 { - o.uint64s = make([]uint64, uint64PoolSize) - } - o.uint64s[0] = x - p.v.Set(reflect.ValueOf(&o.uint64s[0])) - o.uint64s = o.uint64s[1:] - return - case float64Type: - if len(o.float64s) == 0 { - o.float64s = make([]float64, uint64PoolSize) - } - o.float64s[0] = math.Float64frombits(x) - p.v.Set(reflect.ValueOf(&o.float64s[0])) - o.float64s = o.float64s[1:] - return - } - panic("unreachable") -} - -func word64_IsNil(p word64) bool { - return p.v.IsNil() -} - -func word64_Get(p word64) uint64 { - elem := p.v.Elem() - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return elem.Uint() - case reflect.Float64: - return math.Float64bits(elem.Float()) - } - panic("unreachable") -} - -func structPointer_Word64(p structPointer, f field) word64 { - return word64{structPointer_field(p, f)} -} - -// word64Val is like word32Val but for 64-bit values. -type word64Val struct { - v reflect.Value -} - -func word64Val_Set(p word64Val, o *Buffer, x uint64) { - switch p.v.Type() { - case int64Type: - p.v.SetInt(int64(x)) - return - case uint64Type: - p.v.SetUint(x) - return - case float64Type: - p.v.SetFloat(math.Float64frombits(x)) - return - } - panic("unreachable") -} - -func word64Val_Get(p word64Val) uint64 { - elem := p.v - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return elem.Uint() - case reflect.Float64: - return math.Float64bits(elem.Float()) - } - panic("unreachable") -} - -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val{structPointer_field(p, f)} -} - -type word64Slice struct { - v reflect.Value -} - -func (p word64Slice) Append(x uint64) { - n, m := p.v.Len(), p.v.Cap() - if n < m { - p.v.SetLen(n + 1) - } else { - t := p.v.Type().Elem() - p.v.Set(reflect.Append(p.v, reflect.Zero(t))) - } - elem := p.v.Index(n) - switch elem.Kind() { - case reflect.Int64: - elem.SetInt(int64(int64(x))) - case reflect.Uint64: - elem.SetUint(uint64(x)) - case reflect.Float64: - elem.SetFloat(float64(math.Float64frombits(x))) - } -} - -func (p word64Slice) Len() int { - return p.v.Len() -} - -func (p word64Slice) Index(i int) uint64 { - elem := p.v.Index(i) - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return uint64(elem.Uint()) - case reflect.Float64: - return math.Float64bits(float64(elem.Float())) - } - panic("unreachable") -} - -func structPointer_Word64Slice(p structPointer, f field) word64Slice { - return word64Slice{structPointer_field(p, f)} -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go deleted file mode 100644 index e9be0fe..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe.go +++ /dev/null @@ -1,266 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2012 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// +build !appengine - -// This file contains the implementation of the proto field accesses using package unsafe. - -package proto - -import ( - "reflect" - "unsafe" -) - -// NOTE: These type_Foo functions would more idiomatically be methods, -// but Go does not allow methods on pointer types, and we must preserve -// some pointer type for the garbage collector. We use these -// funcs with clunky names as our poor approximation to methods. -// -// An alternative would be -// type structPointer struct { p unsafe.Pointer } -// but that does not registerize as well. - -// A structPointer is a pointer to a struct. -type structPointer unsafe.Pointer - -// toStructPointer returns a structPointer equivalent to the given reflect value. -func toStructPointer(v reflect.Value) structPointer { - return structPointer(unsafe.Pointer(v.Pointer())) -} - -// IsNil reports whether p is nil. -func structPointer_IsNil(p structPointer) bool { - return p == nil -} - -// Interface returns the struct pointer, assumed to have element type t, -// as an interface value. -func structPointer_Interface(p structPointer, t reflect.Type) interface{} { - return reflect.NewAt(t, unsafe.Pointer(p)).Interface() -} - -// A field identifies a field in a struct, accessible from a structPointer. -// In this implementation, a field is identified by its byte offset from the start of the struct. -type field uintptr - -// toField returns a field equivalent to the given reflect field. -func toField(f *reflect.StructField) field { - return field(f.Offset) -} - -// invalidField is an invalid field identifier. -const invalidField = ^field(0) - -// IsValid reports whether the field identifier is valid. -func (f field) IsValid() bool { - return f != ^field(0) -} - -// Bytes returns the address of a []byte field in the struct. -func structPointer_Bytes(p structPointer, f field) *[]byte { - return (*[]byte)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BytesSlice returns the address of a [][]byte field in the struct. -func structPointer_BytesSlice(p structPointer, f field) *[][]byte { - return (*[][]byte)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// Bool returns the address of a *bool field in the struct. -func structPointer_Bool(p structPointer, f field) **bool { - return (**bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BoolVal returns the address of a bool field in the struct. -func structPointer_BoolVal(p structPointer, f field) *bool { - return (*bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BoolSlice returns the address of a []bool field in the struct. -func structPointer_BoolSlice(p structPointer, f field) *[]bool { - return (*[]bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// String returns the address of a *string field in the struct. -func structPointer_String(p structPointer, f field) **string { - return (**string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StringVal returns the address of a string field in the struct. -func structPointer_StringVal(p structPointer, f field) *string { - return (*string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StringSlice returns the address of a []string field in the struct. -func structPointer_StringSlice(p structPointer, f field) *[]string { - return (*[]string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// ExtMap returns the address of an extension map field in the struct. -func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { - return (*map[int32]Extension)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// NewAt returns the reflect.Value for a pointer to a field in the struct. -func structPointer_NewAt(p structPointer, f field, typ reflect.Type) reflect.Value { - return reflect.NewAt(typ, unsafe.Pointer(uintptr(p)+uintptr(f))) -} - -// SetStructPointer writes a *struct field in the struct. -func structPointer_SetStructPointer(p structPointer, f field, q structPointer) { - *(*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f))) = q -} - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return *(*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StructPointerSlice the address of a []*struct field in the struct. -func structPointer_StructPointerSlice(p structPointer, f field) *structPointerSlice { - return (*structPointerSlice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// A structPointerSlice represents a slice of pointers to structs (themselves submessages or groups). -type structPointerSlice []structPointer - -func (v *structPointerSlice) Len() int { return len(*v) } -func (v *structPointerSlice) Index(i int) structPointer { return (*v)[i] } -func (v *structPointerSlice) Append(p structPointer) { *v = append(*v, p) } - -// A word32 is the address of a "pointer to 32-bit value" field. -type word32 **uint32 - -// IsNil reports whether *v is nil. -func word32_IsNil(p word32) bool { - return *p == nil -} - -// Set sets *v to point at a newly allocated word set to x. -func word32_Set(p word32, o *Buffer, x uint32) { - if len(o.uint32s) == 0 { - o.uint32s = make([]uint32, uint32PoolSize) - } - o.uint32s[0] = x - *p = &o.uint32s[0] - o.uint32s = o.uint32s[1:] -} - -// Get gets the value pointed at by *v. -func word32_Get(p word32) uint32 { - return **p -} - -// Word32 returns the address of a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32(p structPointer, f field) word32 { - return word32((**uint32)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// A word32Val is the address of a 32-bit value field. -type word32Val *uint32 - -// Set sets *p to x. -func word32Val_Set(p word32Val, x uint32) { - *p = x -} - -// Get gets the value pointed at by p. -func word32Val_Get(p word32Val) uint32 { - return *p -} - -// Word32Val returns the address of a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32Val(p structPointer, f field) word32Val { - return word32Val((*uint32)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// A word32Slice is a slice of 32-bit values. -type word32Slice []uint32 - -func (v *word32Slice) Append(x uint32) { *v = append(*v, x) } -func (v *word32Slice) Len() int { return len(*v) } -func (v *word32Slice) Index(i int) uint32 { return (*v)[i] } - -// Word32Slice returns the address of a []int32, []uint32, []float32, or []enum field in the struct. -func structPointer_Word32Slice(p structPointer, f field) *word32Slice { - return (*word32Slice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// word64 is like word32 but for 64-bit values. -type word64 **uint64 - -func word64_Set(p word64, o *Buffer, x uint64) { - if len(o.uint64s) == 0 { - o.uint64s = make([]uint64, uint64PoolSize) - } - o.uint64s[0] = x - *p = &o.uint64s[0] - o.uint64s = o.uint64s[1:] -} - -func word64_IsNil(p word64) bool { - return *p == nil -} - -func word64_Get(p word64) uint64 { - return **p -} - -func structPointer_Word64(p structPointer, f field) word64 { - return word64((**uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// word64Val is like word32Val but for 64-bit values. -type word64Val *uint64 - -func word64Val_Set(p word64Val, o *Buffer, x uint64) { - *p = x -} - -func word64Val_Get(p word64Val) uint64 { - return *p -} - -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val((*uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// word64Slice is like word32Slice but for 64-bit values. -type word64Slice []uint64 - -func (v *word64Slice) Append(x uint64) { *v = append(*v, x) } -func (v *word64Slice) Len() int { return len(*v) } -func (v *word64Slice) Index(i int) uint64 { return (*v)[i] } - -func structPointer_Word64Slice(p structPointer, f field) *word64Slice { - return (*word64Slice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go deleted file mode 100644 index 6bc85fa..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/pointer_unsafe_gogo.go +++ /dev/null @@ -1,108 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// +build !appengine - -// This file contains the implementation of the proto field accesses using package unsafe. - -package proto - -import ( - "reflect" - "unsafe" -) - -func structPointer_InterfaceAt(p structPointer, f field, t reflect.Type) interface{} { - point := unsafe.Pointer(uintptr(p) + uintptr(f)) - r := reflect.NewAt(t, point) - return r.Interface() -} - -func structPointer_InterfaceRef(p structPointer, f field, t reflect.Type) interface{} { - point := unsafe.Pointer(uintptr(p) + uintptr(f)) - r := reflect.NewAt(t, point) - if r.Elem().IsNil() { - return nil - } - return r.Elem().Interface() -} - -func copyUintPtr(oldptr, newptr uintptr, size int) { - oldbytes := make([]byte, 0) - oldslice := (*reflect.SliceHeader)(unsafe.Pointer(&oldbytes)) - oldslice.Data = oldptr - oldslice.Len = size - oldslice.Cap = size - newbytes := make([]byte, 0) - newslice := (*reflect.SliceHeader)(unsafe.Pointer(&newbytes)) - newslice.Data = newptr - newslice.Len = size - newslice.Cap = size - copy(newbytes, oldbytes) -} - -func structPointer_Copy(oldptr structPointer, newptr structPointer, size int) { - copyUintPtr(uintptr(oldptr), uintptr(newptr), size) -} - -func appendStructPointer(base structPointer, f field, typ reflect.Type) structPointer { - size := typ.Elem().Size() - oldHeader := structPointer_GetSliceHeader(base, f) - newLen := oldHeader.Len + 1 - slice := reflect.MakeSlice(typ, newLen, newLen) - bas := toStructPointer(slice) - for i := 0; i < oldHeader.Len; i++ { - newElemptr := uintptr(bas) + uintptr(i)*size - oldElemptr := oldHeader.Data + uintptr(i)*size - copyUintPtr(oldElemptr, newElemptr, int(size)) - } - - oldHeader.Data = uintptr(bas) - oldHeader.Len = newLen - oldHeader.Cap = newLen - - return structPointer(unsafe.Pointer(uintptr(unsafe.Pointer(bas)) + uintptr(uintptr(newLen-1)*size))) -} - -func structPointer_FieldPointer(p structPointer, f field) structPointer { - return structPointer(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -func structPointer_GetRefStructPointer(p structPointer, f field) structPointer { - return structPointer((*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -func structPointer_GetSliceHeader(p structPointer, f field) *reflect.SliceHeader { - return (*reflect.SliceHeader)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -func structPointer_Add(p structPointer, size field) structPointer { - return structPointer(unsafe.Pointer(uintptr(p) + uintptr(size))) -} - -func structPointer_Len(p structPointer, f field) int { - return len(*(*[]interface{})(unsafe.Pointer(structPointer_GetRefStructPointer(p, f)))) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties.go deleted file mode 100644 index 5e6a0b3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties.go +++ /dev/null @@ -1,923 +0,0 @@ -// Extensions for Protocol Buffers to create more go like structures. -// -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for encoding data into the wire format for protocol buffers. - */ - -import ( - "fmt" - "log" - "os" - "reflect" - "sort" - "strconv" - "strings" - "sync" -) - -const debug bool = false - -// Constants that identify the encoding of a value on the wire. -const ( - WireVarint = 0 - WireFixed64 = 1 - WireBytes = 2 - WireStartGroup = 3 - WireEndGroup = 4 - WireFixed32 = 5 -) - -const startSize = 10 // initial slice/string sizes - -// Encoders are defined in encode.go -// An encoder outputs the full representation of a field, including its -// tag and encoder type. -type encoder func(p *Buffer, prop *Properties, base structPointer) error - -// A valueEncoder encodes a single integer in a particular encoding. -type valueEncoder func(o *Buffer, x uint64) error - -// Sizers are defined in encode.go -// A sizer returns the encoded size of a field, including its tag and encoder -// type. -type sizer func(prop *Properties, base structPointer) int - -// A valueSizer returns the encoded size of a single integer in a particular -// encoding. -type valueSizer func(x uint64) int - -// Decoders are defined in decode.go -// A decoder creates a value from its wire representation. -// Unrecognized subelements are saved in unrec. -type decoder func(p *Buffer, prop *Properties, base structPointer) error - -// A valueDecoder decodes a single integer in a particular encoding. -type valueDecoder func(o *Buffer) (x uint64, err error) - -// A oneofMarshaler does the marshaling for all oneof fields in a message. -type oneofMarshaler func(Message, *Buffer) error - -// A oneofUnmarshaler does the unmarshaling for a oneof field in a message. -type oneofUnmarshaler func(Message, int, int, *Buffer) (bool, error) - -// A oneofSizer does the sizing for all oneof fields in a message. -type oneofSizer func(Message) int - -// tagMap is an optimization over map[int]int for typical protocol buffer -// use-cases. Encoded protocol buffers are often in tag order with small tag -// numbers. -type tagMap struct { - fastTags []int - slowTags map[int]int -} - -// tagMapFastLimit is the upper bound on the tag number that will be stored in -// the tagMap slice rather than its map. -const tagMapFastLimit = 1024 - -func (p *tagMap) get(t int) (int, bool) { - if t > 0 && t < tagMapFastLimit { - if t >= len(p.fastTags) { - return 0, false - } - fi := p.fastTags[t] - return fi, fi >= 0 - } - fi, ok := p.slowTags[t] - return fi, ok -} - -func (p *tagMap) put(t int, fi int) { - if t > 0 && t < tagMapFastLimit { - for len(p.fastTags) < t+1 { - p.fastTags = append(p.fastTags, -1) - } - p.fastTags[t] = fi - return - } - if p.slowTags == nil { - p.slowTags = make(map[int]int) - } - p.slowTags[t] = fi -} - -// StructProperties represents properties for all the fields of a struct. -// decoderTags and decoderOrigNames should only be used by the decoder. -type StructProperties struct { - Prop []*Properties // properties for each field - reqCount int // required count - decoderTags tagMap // map from proto tag to struct field number - decoderOrigNames map[string]int // map from original name to struct field number - order []int // list of struct field numbers in tag order - unrecField field // field id of the XXX_unrecognized []byte field - extendable bool // is this an extendable proto - - oneofMarshaler oneofMarshaler - oneofUnmarshaler oneofUnmarshaler - oneofSizer oneofSizer - stype reflect.Type - - // OneofTypes contains information about the oneof fields in this message. - // It is keyed by the original name of a field. - OneofTypes map[string]*OneofProperties -} - -// OneofProperties represents information about a specific field in a oneof. -type OneofProperties struct { - Type reflect.Type // pointer to generated struct type for this oneof field - Field int // struct field number of the containing oneof in the message - Prop *Properties -} - -// Implement the sorting interface so we can sort the fields in tag order, as recommended by the spec. -// See encode.go, (*Buffer).enc_struct. - -func (sp *StructProperties) Len() int { return len(sp.order) } -func (sp *StructProperties) Less(i, j int) bool { - return sp.Prop[sp.order[i]].Tag < sp.Prop[sp.order[j]].Tag -} -func (sp *StructProperties) Swap(i, j int) { sp.order[i], sp.order[j] = sp.order[j], sp.order[i] } - -// Properties represents the protocol-specific behavior of a single struct field. -type Properties struct { - Name string // name of the field, for error messages - OrigName string // original name before protocol compiler (always set) - JSONName string // name to use for JSON; determined by protoc - Wire string - WireType int - Tag int - Required bool - Optional bool - Repeated bool - Packed bool // relevant for repeated primitives only - Enum string // set for enum types only - proto3 bool // whether this is known to be a proto3 field; set for []byte only - oneof bool // whether this is a oneof field - - Default string // default value - HasDefault bool // whether an explicit default was provided - CustomType string - def_uint64 uint64 - - enc encoder - valEnc valueEncoder // set for bool and numeric types only - field field - tagcode []byte // encoding of EncodeVarint((Tag<<3)|WireType) - tagbuf [8]byte - stype reflect.Type // set for struct types only - sstype reflect.Type // set for slices of structs types only - ctype reflect.Type // set for custom types only - sprop *StructProperties // set for struct types only - isMarshaler bool - isUnmarshaler bool - - mtype reflect.Type // set for map types only - mkeyprop *Properties // set for map types only - mvalprop *Properties // set for map types only - - size sizer - valSize valueSizer // set for bool and numeric types only - - dec decoder - valDec valueDecoder // set for bool and numeric types only - - // If this is a packable field, this will be the decoder for the packed version of the field. - packedDec decoder -} - -// String formats the properties in the protobuf struct field tag style. -func (p *Properties) String() string { - s := p.Wire - s = "," - s += strconv.Itoa(p.Tag) - if p.Required { - s += ",req" - } - if p.Optional { - s += ",opt" - } - if p.Repeated { - s += ",rep" - } - if p.Packed { - s += ",packed" - } - s += ",name=" + p.OrigName - if p.JSONName != p.OrigName { - s += ",json=" + p.JSONName - } - if p.proto3 { - s += ",proto3" - } - if p.oneof { - s += ",oneof" - } - if len(p.Enum) > 0 { - s += ",enum=" + p.Enum - } - if p.HasDefault { - s += ",def=" + p.Default - } - return s -} - -// Parse populates p by parsing a string in the protobuf struct field tag style. -func (p *Properties) Parse(s string) { - // "bytes,49,opt,name=foo,def=hello!" - fields := strings.Split(s, ",") // breaks def=, but handled below. - if len(fields) < 2 { - fmt.Fprintf(os.Stderr, "proto: tag has too few fields: %q\n", s) - return - } - - p.Wire = fields[0] - switch p.Wire { - case "varint": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeVarint - p.valDec = (*Buffer).DecodeVarint - p.valSize = sizeVarint - case "fixed32": - p.WireType = WireFixed32 - p.valEnc = (*Buffer).EncodeFixed32 - p.valDec = (*Buffer).DecodeFixed32 - p.valSize = sizeFixed32 - case "fixed64": - p.WireType = WireFixed64 - p.valEnc = (*Buffer).EncodeFixed64 - p.valDec = (*Buffer).DecodeFixed64 - p.valSize = sizeFixed64 - case "zigzag32": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeZigzag32 - p.valDec = (*Buffer).DecodeZigzag32 - p.valSize = sizeZigzag32 - case "zigzag64": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeZigzag64 - p.valDec = (*Buffer).DecodeZigzag64 - p.valSize = sizeZigzag64 - case "bytes", "group": - p.WireType = WireBytes - // no numeric converter for non-numeric types - default: - fmt.Fprintf(os.Stderr, "proto: tag has unknown wire type: %q\n", s) - return - } - - var err error - p.Tag, err = strconv.Atoi(fields[1]) - if err != nil { - return - } - - for i := 2; i < len(fields); i++ { - f := fields[i] - switch { - case f == "req": - p.Required = true - case f == "opt": - p.Optional = true - case f == "rep": - p.Repeated = true - case f == "packed": - p.Packed = true - case strings.HasPrefix(f, "name="): - p.OrigName = f[5:] - case strings.HasPrefix(f, "json="): - p.JSONName = f[5:] - case strings.HasPrefix(f, "enum="): - p.Enum = f[5:] - case f == "proto3": - p.proto3 = true - case f == "oneof": - p.oneof = true - case strings.HasPrefix(f, "def="): - p.HasDefault = true - p.Default = f[4:] // rest of string - if i+1 < len(fields) { - // Commas aren't escaped, and def is always last. - p.Default += "," + strings.Join(fields[i+1:], ",") - break - } - case strings.HasPrefix(f, "embedded="): - p.OrigName = strings.Split(f, "=")[1] - case strings.HasPrefix(f, "customtype="): - p.CustomType = strings.Split(f, "=")[1] - } - } -} - -func logNoSliceEnc(t1, t2 reflect.Type) { - fmt.Fprintf(os.Stderr, "proto: no slice oenc for %T = []%T\n", t1, t2) -} - -var protoMessageType = reflect.TypeOf((*Message)(nil)).Elem() - -// Initialize the fields for encoding and decoding. -func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lockGetProp bool) { - p.enc = nil - p.dec = nil - p.size = nil - if len(p.CustomType) > 0 { - p.setCustomEncAndDec(typ) - p.setTag(lockGetProp) - return - } - switch t1 := typ; t1.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no coders for %v\n", t1) - - // proto3 scalar types - - case reflect.Bool: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_bool - p.dec = (*Buffer).dec_proto3_bool - p.size = size_proto3_bool - } else { - p.enc = (*Buffer).enc_ref_bool - p.dec = (*Buffer).dec_proto3_bool - p.size = size_ref_bool - } - case reflect.Int32: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_int32 - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_proto3_int32 - } else { - p.enc = (*Buffer).enc_ref_int32 - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_ref_int32 - } - case reflect.Uint32: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_uint32 - p.dec = (*Buffer).dec_proto3_int32 // can reuse - p.size = size_proto3_uint32 - } else { - p.enc = (*Buffer).enc_ref_uint32 - p.dec = (*Buffer).dec_proto3_int32 // can reuse - p.size = size_ref_uint32 - } - case reflect.Int64, reflect.Uint64: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_int64 - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_proto3_int64 - } else { - p.enc = (*Buffer).enc_ref_int64 - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_ref_int64 - } - case reflect.Float32: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_uint32 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_proto3_uint32 - } else { - p.enc = (*Buffer).enc_ref_uint32 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_ref_uint32 - } - case reflect.Float64: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_int64 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_proto3_int64 - } else { - p.enc = (*Buffer).enc_ref_int64 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_ref_int64 - } - case reflect.String: - if p.proto3 { - p.enc = (*Buffer).enc_proto3_string - p.dec = (*Buffer).dec_proto3_string - p.size = size_proto3_string - } else { - p.enc = (*Buffer).enc_ref_string - p.dec = (*Buffer).dec_proto3_string - p.size = size_ref_string - } - case reflect.Struct: - p.stype = typ - p.isMarshaler = isMarshaler(typ) - p.isUnmarshaler = isUnmarshaler(typ) - if p.Wire == "bytes" { - p.enc = (*Buffer).enc_ref_struct_message - p.dec = (*Buffer).dec_ref_struct_message - p.size = size_ref_struct_message - } else { - fmt.Fprintf(os.Stderr, "proto: no coders for struct %T\n", typ) - } - - case reflect.Ptr: - switch t2 := t1.Elem(); t2.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no encoder function for %v -> %v\n", t1, t2) - break - case reflect.Bool: - p.enc = (*Buffer).enc_bool - p.dec = (*Buffer).dec_bool - p.size = size_bool - case reflect.Int32: - p.enc = (*Buffer).enc_int32 - p.dec = (*Buffer).dec_int32 - p.size = size_int32 - case reflect.Uint32: - p.enc = (*Buffer).enc_uint32 - p.dec = (*Buffer).dec_int32 // can reuse - p.size = size_uint32 - case reflect.Int64, reflect.Uint64: - p.enc = (*Buffer).enc_int64 - p.dec = (*Buffer).dec_int64 - p.size = size_int64 - case reflect.Float32: - p.enc = (*Buffer).enc_uint32 // can just treat them as bits - p.dec = (*Buffer).dec_int32 - p.size = size_uint32 - case reflect.Float64: - p.enc = (*Buffer).enc_int64 // can just treat them as bits - p.dec = (*Buffer).dec_int64 - p.size = size_int64 - case reflect.String: - p.enc = (*Buffer).enc_string - p.dec = (*Buffer).dec_string - p.size = size_string - case reflect.Struct: - p.stype = t1.Elem() - p.isMarshaler = isMarshaler(t1) - p.isUnmarshaler = isUnmarshaler(t1) - if p.Wire == "bytes" { - p.enc = (*Buffer).enc_struct_message - p.dec = (*Buffer).dec_struct_message - p.size = size_struct_message - } else { - p.enc = (*Buffer).enc_struct_group - p.dec = (*Buffer).dec_struct_group - p.size = size_struct_group - } - } - - case reflect.Slice: - switch t2 := t1.Elem(); t2.Kind() { - default: - logNoSliceEnc(t1, t2) - break - case reflect.Bool: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_bool - p.size = size_slice_packed_bool - } else { - p.enc = (*Buffer).enc_slice_bool - p.size = size_slice_bool - } - p.dec = (*Buffer).dec_slice_bool - p.packedDec = (*Buffer).dec_slice_packed_bool - case reflect.Int32: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int32 - p.size = size_slice_packed_int32 - } else { - p.enc = (*Buffer).enc_slice_int32 - p.size = size_slice_int32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case reflect.Uint32: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_uint32 - p.size = size_slice_packed_uint32 - } else { - p.enc = (*Buffer).enc_slice_uint32 - p.size = size_slice_uint32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case reflect.Int64, reflect.Uint64: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int64 - p.size = size_slice_packed_int64 - } else { - p.enc = (*Buffer).enc_slice_int64 - p.size = size_slice_int64 - } - p.dec = (*Buffer).dec_slice_int64 - p.packedDec = (*Buffer).dec_slice_packed_int64 - case reflect.Uint8: - p.enc = (*Buffer).enc_slice_byte - p.dec = (*Buffer).dec_slice_byte - p.size = size_slice_byte - // This is a []byte, which is either a bytes field, - // or the value of a map field. In the latter case, - // we always encode an empty []byte, so we should not - // use the proto3 enc/size funcs. - // f == nil iff this is the key/value of a map field. - if p.proto3 && f != nil { - p.enc = (*Buffer).enc_proto3_slice_byte - p.size = size_proto3_slice_byte - } - case reflect.Float32, reflect.Float64: - switch t2.Bits() { - case 32: - // can just treat them as bits - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_uint32 - p.size = size_slice_packed_uint32 - } else { - p.enc = (*Buffer).enc_slice_uint32 - p.size = size_slice_uint32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case 64: - // can just treat them as bits - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int64 - p.size = size_slice_packed_int64 - } else { - p.enc = (*Buffer).enc_slice_int64 - p.size = size_slice_int64 - } - p.dec = (*Buffer).dec_slice_int64 - p.packedDec = (*Buffer).dec_slice_packed_int64 - default: - logNoSliceEnc(t1, t2) - break - } - case reflect.String: - p.enc = (*Buffer).enc_slice_string - p.dec = (*Buffer).dec_slice_string - p.size = size_slice_string - case reflect.Ptr: - switch t3 := t2.Elem(); t3.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no ptr oenc for %T -> %T -> %T\n", t1, t2, t3) - break - case reflect.Struct: - p.stype = t2.Elem() - p.isMarshaler = isMarshaler(t2) - p.isUnmarshaler = isUnmarshaler(t2) - if p.Wire == "bytes" { - p.enc = (*Buffer).enc_slice_struct_message - p.dec = (*Buffer).dec_slice_struct_message - p.size = size_slice_struct_message - } else { - p.enc = (*Buffer).enc_slice_struct_group - p.dec = (*Buffer).dec_slice_struct_group - p.size = size_slice_struct_group - } - } - case reflect.Slice: - switch t2.Elem().Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no slice elem oenc for %T -> %T -> %T\n", t1, t2, t2.Elem()) - break - case reflect.Uint8: - p.enc = (*Buffer).enc_slice_slice_byte - p.dec = (*Buffer).dec_slice_slice_byte - p.size = size_slice_slice_byte - } - case reflect.Struct: - p.setSliceOfNonPointerStructs(t1) - } - - case reflect.Map: - p.enc = (*Buffer).enc_new_map - p.dec = (*Buffer).dec_new_map - p.size = size_new_map - - p.mtype = t1 - p.mkeyprop = &Properties{} - p.mkeyprop.init(reflect.PtrTo(p.mtype.Key()), "Key", f.Tag.Get("protobuf_key"), nil, lockGetProp) - p.mvalprop = &Properties{} - vtype := p.mtype.Elem() - if vtype.Kind() != reflect.Ptr && vtype.Kind() != reflect.Slice { - // The value type is not a message (*T) or bytes ([]byte), - // so we need encoders for the pointer to this type. - vtype = reflect.PtrTo(vtype) - } - p.mvalprop.init(vtype, "Value", f.Tag.Get("protobuf_val"), nil, lockGetProp) - } - p.setTag(lockGetProp) -} - -func (p *Properties) setTag(lockGetProp bool) { - // precalculate tag code - wire := p.WireType - if p.Packed { - wire = WireBytes - } - x := uint32(p.Tag)<<3 | uint32(wire) - i := 0 - for i = 0; x > 127; i++ { - p.tagbuf[i] = 0x80 | uint8(x&0x7F) - x >>= 7 - } - p.tagbuf[i] = uint8(x) - p.tagcode = p.tagbuf[0 : i+1] - - if p.stype != nil { - if lockGetProp { - p.sprop = GetProperties(p.stype) - } else { - p.sprop = getPropertiesLocked(p.stype) - } - } -} - -var ( - marshalerType = reflect.TypeOf((*Marshaler)(nil)).Elem() - unmarshalerType = reflect.TypeOf((*Unmarshaler)(nil)).Elem() -) - -// isMarshaler reports whether type t implements Marshaler. -func isMarshaler(t reflect.Type) bool { - return t.Implements(marshalerType) -} - -// isUnmarshaler reports whether type t implements Unmarshaler. -func isUnmarshaler(t reflect.Type) bool { - return t.Implements(unmarshalerType) -} - -// Init populates the properties from a protocol buffer struct tag. -func (p *Properties) Init(typ reflect.Type, name, tag string, f *reflect.StructField) { - p.init(typ, name, tag, f, true) -} - -func (p *Properties) init(typ reflect.Type, name, tag string, f *reflect.StructField, lockGetProp bool) { - // "bytes,49,opt,def=hello!" - p.Name = name - p.OrigName = name - if f != nil { - p.field = toField(f) - } - if tag == "" { - return - } - p.Parse(tag) - p.setEncAndDec(typ, f, lockGetProp) -} - -var ( - propertiesMu sync.RWMutex - propertiesMap = make(map[reflect.Type]*StructProperties) -) - -// GetProperties returns the list of properties for the type represented by t. -// t must represent a generated struct type of a protocol message. -func GetProperties(t reflect.Type) *StructProperties { - if t.Kind() != reflect.Struct { - panic("proto: type must have kind struct") - } - - // Most calls to GetProperties in a long-running program will be - // retrieving details for types we have seen before. - propertiesMu.RLock() - sprop, ok := propertiesMap[t] - propertiesMu.RUnlock() - if ok { - if collectStats { - stats.Chit++ - } - return sprop - } - - propertiesMu.Lock() - sprop = getPropertiesLocked(t) - propertiesMu.Unlock() - return sprop -} - -// getPropertiesLocked requires that propertiesMu is held. -func getPropertiesLocked(t reflect.Type) *StructProperties { - if prop, ok := propertiesMap[t]; ok { - if collectStats { - stats.Chit++ - } - return prop - } - if collectStats { - stats.Cmiss++ - } - - prop := new(StructProperties) - // in case of recursive protos, fill this in now. - propertiesMap[t] = prop - - // build properties - prop.extendable = reflect.PtrTo(t).Implements(extendableProtoType) - prop.unrecField = invalidField - prop.Prop = make([]*Properties, t.NumField()) - prop.order = make([]int, t.NumField()) - - isOneofMessage := false - for i := 0; i < t.NumField(); i++ { - f := t.Field(i) - p := new(Properties) - name := f.Name - p.init(f.Type, name, f.Tag.Get("protobuf"), &f, false) - - if f.Name == "XXX_extensions" { // special case - if len(f.Tag.Get("protobuf")) > 0 { - p.enc = (*Buffer).enc_ext_slice_byte - p.dec = nil // not needed - p.size = size_ext_slice_byte - } else { - p.enc = (*Buffer).enc_map - p.dec = nil // not needed - p.size = size_map - } - } - if f.Name == "XXX_unrecognized" { // special case - prop.unrecField = toField(&f) - } - oneof := f.Tag.Get("protobuf_oneof") != "" // special case - if oneof { - isOneofMessage = true - } - prop.Prop[i] = p - prop.order[i] = i - if debug { - print(i, " ", f.Name, " ", t.String(), " ") - if p.Tag > 0 { - print(p.String()) - } - print("\n") - } - if p.enc == nil && !strings.HasPrefix(f.Name, "XXX_") && !oneof { - fmt.Fprintln(os.Stderr, "proto: no encoder for", f.Name, f.Type.String(), "[GetProperties]") - } - } - - // Re-order prop.order. - sort.Sort(prop) - - type oneofMessage interface { - XXX_OneofFuncs() (func(Message, *Buffer) error, func(Message, int, int, *Buffer) (bool, error), func(Message) int, []interface{}) - } - if om, ok := reflect.Zero(reflect.PtrTo(t)).Interface().(oneofMessage); isOneofMessage && ok { - var oots []interface{} - prop.oneofMarshaler, prop.oneofUnmarshaler, prop.oneofSizer, oots = om.XXX_OneofFuncs() - prop.stype = t - - // Interpret oneof metadata. - prop.OneofTypes = make(map[string]*OneofProperties) - for _, oot := range oots { - oop := &OneofProperties{ - Type: reflect.ValueOf(oot).Type(), // *T - Prop: new(Properties), - } - sft := oop.Type.Elem().Field(0) - oop.Prop.Name = sft.Name - oop.Prop.Parse(sft.Tag.Get("protobuf")) - // There will be exactly one interface field that - // this new value is assignable to. - for i := 0; i < t.NumField(); i++ { - f := t.Field(i) - if f.Type.Kind() != reflect.Interface { - continue - } - if !oop.Type.AssignableTo(f.Type) { - continue - } - oop.Field = i - break - } - prop.OneofTypes[oop.Prop.OrigName] = oop - } - } - - // build required counts - // build tags - reqCount := 0 - prop.decoderOrigNames = make(map[string]int) - for i, p := range prop.Prop { - if strings.HasPrefix(p.Name, "XXX_") { - // Internal fields should not appear in tags/origNames maps. - // They are handled specially when encoding and decoding. - continue - } - if p.Required { - reqCount++ - } - prop.decoderTags.put(p.Tag, i) - prop.decoderOrigNames[p.OrigName] = i - } - prop.reqCount = reqCount - - return prop -} - -// Return the Properties object for the x[0]'th field of the structure. -func propByIndex(t reflect.Type, x []int) *Properties { - if len(x) != 1 { - fmt.Fprintf(os.Stderr, "proto: field index dimension %d (not 1) for type %s\n", len(x), t) - return nil - } - prop := GetProperties(t) - return prop.Prop[x[0]] -} - -// Get the address and type of a pointer to a struct from an interface. -func getbase(pb Message) (t reflect.Type, b structPointer, err error) { - if pb == nil { - err = ErrNil - return - } - // get the reflect type of the pointer to the struct. - t = reflect.TypeOf(pb) - // get the address of the struct. - value := reflect.ValueOf(pb) - b = toStructPointer(value) - return -} - -// A global registry of enum types. -// The generated code will register the generated maps by calling RegisterEnum. - -var enumValueMaps = make(map[string]map[string]int32) -var enumStringMaps = make(map[string]map[int32]string) - -// RegisterEnum is called from the generated code to install the enum descriptor -// maps into the global table to aid parsing text format protocol buffers. -func RegisterEnum(typeName string, unusedNameMap map[int32]string, valueMap map[string]int32) { - if _, ok := enumValueMaps[typeName]; ok { - panic("proto: duplicate enum registered: " + typeName) - } - enumValueMaps[typeName] = valueMap - if _, ok := enumStringMaps[typeName]; ok { - panic("proto: duplicate enum registered: " + typeName) - } - enumStringMaps[typeName] = unusedNameMap -} - -// EnumValueMap returns the mapping from names to integers of the -// enum type enumType, or a nil if not found. -func EnumValueMap(enumType string) map[string]int32 { - return enumValueMaps[enumType] -} - -// A registry of all linked message types. -// The string is a fully-qualified proto name ("pkg.Message"). -var ( - protoTypes = make(map[string]reflect.Type) - revProtoTypes = make(map[reflect.Type]string) -) - -// RegisterType is called from generated code and maps from the fully qualified -// proto name to the type (pointer to struct) of the protocol buffer. -func RegisterType(x Message, name string) { - if _, ok := protoTypes[name]; ok { - // TODO: Some day, make this a panic. - log.Printf("proto: duplicate proto type registered: %s", name) - return - } - t := reflect.TypeOf(x) - protoTypes[name] = t - revProtoTypes[t] = name -} - -// MessageName returns the fully-qualified proto name for the given message type. -func MessageName(x Message) string { return revProtoTypes[reflect.TypeOf(x)] } - -// MessageType returns the message type (pointer to struct) for a named message. -func MessageType(name string) reflect.Type { return protoTypes[name] } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties_gogo.go deleted file mode 100644 index 8daf9f7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/properties_gogo.go +++ /dev/null @@ -1,64 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "fmt" - "os" - "reflect" -) - -func (p *Properties) setCustomEncAndDec(typ reflect.Type) { - p.ctype = typ - if p.Repeated { - p.enc = (*Buffer).enc_custom_slice_bytes - p.dec = (*Buffer).dec_custom_slice_bytes - p.size = size_custom_slice_bytes - } else if typ.Kind() == reflect.Ptr { - p.enc = (*Buffer).enc_custom_bytes - p.dec = (*Buffer).dec_custom_bytes - p.size = size_custom_bytes - } else { - p.enc = (*Buffer).enc_custom_ref_bytes - p.dec = (*Buffer).dec_custom_ref_bytes - p.size = size_custom_ref_bytes - } -} - -func (p *Properties) setSliceOfNonPointerStructs(typ reflect.Type) { - t2 := typ.Elem() - p.sstype = typ - p.stype = t2 - p.isMarshaler = isMarshaler(t2) - p.isUnmarshaler = isUnmarshaler(t2) - p.enc = (*Buffer).enc_slice_ref_struct_message - p.dec = (*Buffer).dec_slice_ref_struct_message - p.size = size_slice_ref_struct_message - if p.Wire != "bytes" { - fmt.Fprintf(os.Stderr, "proto: no ptr oenc for %T -> %T \n", typ, t2) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/skip_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/skip_gogo.go deleted file mode 100644 index 4fe7e08..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/skip_gogo.go +++ /dev/null @@ -1,117 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "fmt" - "io" -) - -func Skip(data []byte) (n int, err error) { - l := len(data) - index := 0 - for index < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if index >= l { - return 0, io.ErrUnexpectedEOF - } - b := data[index] - index++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for { - if index >= l { - return 0, io.ErrUnexpectedEOF - } - index++ - if data[index-1] < 0x80 { - break - } - } - return index, nil - case 1: - index += 8 - return index, nil - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if index >= l { - return 0, io.ErrUnexpectedEOF - } - b := data[index] - index++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - index += length - return index, nil - case 3: - for { - var innerWire uint64 - var start int = index - for shift := uint(0); ; shift += 7 { - if index >= l { - return 0, io.ErrUnexpectedEOF - } - b := data[index] - index++ - innerWire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - innerWireType := int(innerWire & 0x7) - if innerWireType == 4 { - break - } - next, err := Skip(data[start:]) - if err != nil { - return 0, err - } - index = start + next - } - return index, nil - case 4: - return index, nil - case 5: - index += 4 - return index, nil - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - } - panic("unreachable") -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text.go deleted file mode 100644 index b60be28..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text.go +++ /dev/null @@ -1,805 +0,0 @@ -// Extensions for Protocol Buffers to create more go like structures. -// -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// Functions for writing the text protocol buffer format. - -import ( - "bufio" - "bytes" - "encoding" - "errors" - "fmt" - "io" - "log" - "math" - "reflect" - "sort" - "strings" -) - -var ( - newline = []byte("\n") - spaces = []byte(" ") - gtNewline = []byte(">\n") - endBraceNewline = []byte("}\n") - backslashN = []byte{'\\', 'n'} - backslashR = []byte{'\\', 'r'} - backslashT = []byte{'\\', 't'} - backslashDQ = []byte{'\\', '"'} - backslashBS = []byte{'\\', '\\'} - posInf = []byte("inf") - negInf = []byte("-inf") - nan = []byte("nan") -) - -type writer interface { - io.Writer - WriteByte(byte) error -} - -// textWriter is an io.Writer that tracks its indentation level. -type textWriter struct { - ind int - complete bool // if the current position is a complete line - compact bool // whether to write out as a one-liner - w writer -} - -func (w *textWriter) WriteString(s string) (n int, err error) { - if !strings.Contains(s, "\n") { - if !w.compact && w.complete { - w.writeIndent() - } - w.complete = false - return io.WriteString(w.w, s) - } - // WriteString is typically called without newlines, so this - // codepath and its copy are rare. We copy to avoid - // duplicating all of Write's logic here. - return w.Write([]byte(s)) -} - -func (w *textWriter) Write(p []byte) (n int, err error) { - newlines := bytes.Count(p, newline) - if newlines == 0 { - if !w.compact && w.complete { - w.writeIndent() - } - n, err = w.w.Write(p) - w.complete = false - return n, err - } - - frags := bytes.SplitN(p, newline, newlines+1) - if w.compact { - for i, frag := range frags { - if i > 0 { - if err := w.w.WriteByte(' '); err != nil { - return n, err - } - n++ - } - nn, err := w.w.Write(frag) - n += nn - if err != nil { - return n, err - } - } - return n, nil - } - - for i, frag := range frags { - if w.complete { - w.writeIndent() - } - nn, err := w.w.Write(frag) - n += nn - if err != nil { - return n, err - } - if i+1 < len(frags) { - if err := w.w.WriteByte('\n'); err != nil { - return n, err - } - n++ - } - } - w.complete = len(frags[len(frags)-1]) == 0 - return n, nil -} - -func (w *textWriter) WriteByte(c byte) error { - if w.compact && c == '\n' { - c = ' ' - } - if !w.compact && w.complete { - w.writeIndent() - } - err := w.w.WriteByte(c) - w.complete = c == '\n' - return err -} - -func (w *textWriter) indent() { w.ind++ } - -func (w *textWriter) unindent() { - if w.ind == 0 { - log.Printf("proto: textWriter unindented too far") - return - } - w.ind-- -} - -func writeName(w *textWriter, props *Properties) error { - if _, err := w.WriteString(props.OrigName); err != nil { - return err - } - if props.Wire != "group" { - return w.WriteByte(':') - } - return nil -} - -// raw is the interface satisfied by RawMessage. -type raw interface { - Bytes() []byte -} - -func writeStruct(w *textWriter, sv reflect.Value) error { - st := sv.Type() - sprops := GetProperties(st) - for i := 0; i < sv.NumField(); i++ { - fv := sv.Field(i) - props := sprops.Prop[i] - name := st.Field(i).Name - - if strings.HasPrefix(name, "XXX_") { - // There are two XXX_ fields: - // XXX_unrecognized []byte - // XXX_extensions map[int32]proto.Extension - // The first is handled here; - // the second is handled at the bottom of this function. - if name == "XXX_unrecognized" && !fv.IsNil() { - if err := writeUnknownStruct(w, fv.Interface().([]byte)); err != nil { - return err - } - } - continue - } - if fv.Kind() == reflect.Ptr && fv.IsNil() { - // Field not filled in. This could be an optional field or - // a required field that wasn't filled in. Either way, there - // isn't anything we can show for it. - continue - } - if fv.Kind() == reflect.Slice && fv.IsNil() { - // Repeated field that is empty, or a bytes field that is unused. - continue - } - - if props.Repeated && fv.Kind() == reflect.Slice { - // Repeated field. - for j := 0; j < fv.Len(); j++ { - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - v := fv.Index(j) - if v.Kind() == reflect.Ptr && v.IsNil() { - // A nil message in a repeated field is not valid, - // but we can handle that more gracefully than panicking. - if _, err := w.Write([]byte("\n")); err != nil { - return err - } - continue - } - if len(props.Enum) > 0 { - if err := writeEnum(w, v, props); err != nil { - return err - } - } else if err := writeAny(w, v, props); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - continue - } - if fv.Kind() == reflect.Map { - // Map fields are rendered as a repeated struct with key/value fields. - keys := fv.MapKeys() - sort.Sort(mapKeys(keys)) - for _, key := range keys { - val := fv.MapIndex(key) - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - // open struct - if err := w.WriteByte('<'); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - // key - if _, err := w.WriteString("key:"); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := writeAny(w, key, props.mkeyprop); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - // nil values aren't legal, but we can avoid panicking because of them. - if val.Kind() != reflect.Ptr || !val.IsNil() { - // value - if _, err := w.WriteString("value:"); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := writeAny(w, val, props.mvalprop); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - // close struct - w.unindent() - if err := w.WriteByte('>'); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - continue - } - if props.proto3 && fv.Kind() == reflect.Slice && fv.Len() == 0 { - // empty bytes field - continue - } - if props.proto3 && fv.Kind() != reflect.Ptr && fv.Kind() != reflect.Slice { - // proto3 non-repeated scalar field; skip if zero value - if isProto3Zero(fv) { - continue - } - } - - if fv.Kind() == reflect.Interface { - // Check if it is a oneof. - if st.Field(i).Tag.Get("protobuf_oneof") != "" { - // fv is nil, or holds a pointer to generated struct. - // That generated struct has exactly one field, - // which has a protobuf struct tag. - if fv.IsNil() { - continue - } - inner := fv.Elem().Elem() // interface -> *T -> T - tag := inner.Type().Field(0).Tag.Get("protobuf") - props = new(Properties) // Overwrite the outer props var, but not its pointee. - props.Parse(tag) - // Write the value in the oneof, not the oneof itself. - fv = inner.Field(0) - - // Special case to cope with malformed messages gracefully: - // If the value in the oneof is a nil pointer, don't panic - // in writeAny. - if fv.Kind() == reflect.Ptr && fv.IsNil() { - // Use errors.New so writeAny won't render quotes. - msg := errors.New("/* nil */") - fv = reflect.ValueOf(&msg).Elem() - } - } - } - - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if b, ok := fv.Interface().(raw); ok { - if err := writeRaw(w, b.Bytes()); err != nil { - return err - } - continue - } - - if len(props.Enum) > 0 { - if err := writeEnum(w, fv, props); err != nil { - return err - } - } else if err := writeAny(w, fv, props); err != nil { - return err - } - - if err := w.WriteByte('\n'); err != nil { - return err - } - } - - // Extensions (the XXX_extensions field). - pv := sv - if pv.CanAddr() { - pv = sv.Addr() - } else { - pv = reflect.New(sv.Type()) - pv.Elem().Set(sv) - } - if pv.Type().Implements(extendableProtoType) { - if err := writeExtensions(w, pv); err != nil { - return err - } - } - - return nil -} - -// writeRaw writes an uninterpreted raw message. -func writeRaw(w *textWriter, b []byte) error { - if err := w.WriteByte('<'); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - if err := writeUnknownStruct(w, b); err != nil { - return err - } - w.unindent() - if err := w.WriteByte('>'); err != nil { - return err - } - return nil -} - -// writeAny writes an arbitrary field. -func writeAny(w *textWriter, v reflect.Value, props *Properties) error { - v = reflect.Indirect(v) - - if props != nil && len(props.CustomType) > 0 { - custom, ok := v.Interface().(Marshaler) - if ok { - data, err := custom.Marshal() - if err != nil { - return err - } - if err := writeString(w, string(data)); err != nil { - return err - } - return nil - } - } - - // Floats have special cases. - if v.Kind() == reflect.Float32 || v.Kind() == reflect.Float64 { - x := v.Float() - var b []byte - switch { - case math.IsInf(x, 1): - b = posInf - case math.IsInf(x, -1): - b = negInf - case math.IsNaN(x): - b = nan - } - if b != nil { - _, err := w.Write(b) - return err - } - // Other values are handled below. - } - - // We don't attempt to serialise every possible value type; only those - // that can occur in protocol buffers. - switch v.Kind() { - case reflect.Slice: - // Should only be a []byte; repeated fields are handled in writeStruct. - if err := writeString(w, string(v.Bytes())); err != nil { - return err - } - case reflect.String: - if err := writeString(w, v.String()); err != nil { - return err - } - case reflect.Struct: - // Required/optional group/message. - var bra, ket byte = '<', '>' - if props != nil && props.Wire == "group" { - bra, ket = '{', '}' - } - if err := w.WriteByte(bra); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - if tm, ok := v.Interface().(encoding.TextMarshaler); ok { - text, err := tm.MarshalText() - if err != nil { - return err - } - if _, err = w.Write(text); err != nil { - return err - } - } else if err := writeStruct(w, v); err != nil { - return err - } - w.unindent() - if err := w.WriteByte(ket); err != nil { - return err - } - default: - _, err := fmt.Fprint(w, v.Interface()) - return err - } - return nil -} - -// equivalent to C's isprint. -func isprint(c byte) bool { - return c >= 0x20 && c < 0x7f -} - -// writeString writes a string in the protocol buffer text format. -// It is similar to strconv.Quote except we don't use Go escape sequences, -// we treat the string as a byte sequence, and we use octal escapes. -// These differences are to maintain interoperability with the other -// languages' implementations of the text format. -func writeString(w *textWriter, s string) error { - // use WriteByte here to get any needed indent - if err := w.WriteByte('"'); err != nil { - return err - } - // Loop over the bytes, not the runes. - for i := 0; i < len(s); i++ { - var err error - // Divergence from C++: we don't escape apostrophes. - // There's no need to escape them, and the C++ parser - // copes with a naked apostrophe. - switch c := s[i]; c { - case '\n': - _, err = w.w.Write(backslashN) - case '\r': - _, err = w.w.Write(backslashR) - case '\t': - _, err = w.w.Write(backslashT) - case '"': - _, err = w.w.Write(backslashDQ) - case '\\': - _, err = w.w.Write(backslashBS) - default: - if isprint(c) { - err = w.w.WriteByte(c) - } else { - _, err = fmt.Fprintf(w.w, "\\%03o", c) - } - } - if err != nil { - return err - } - } - return w.WriteByte('"') -} - -func writeUnknownStruct(w *textWriter, data []byte) (err error) { - if !w.compact { - if _, err := fmt.Fprintf(w, "/* %d unknown bytes */\n", len(data)); err != nil { - return err - } - } - b := NewBuffer(data) - for b.index < len(b.buf) { - x, err := b.DecodeVarint() - if err != nil { - _, ferr := fmt.Fprintf(w, "/* %v */\n", err) - return ferr - } - wire, tag := x&7, x>>3 - if wire == WireEndGroup { - w.unindent() - if _, werr := w.Write(endBraceNewline); werr != nil { - return werr - } - continue - } - if _, ferr := fmt.Fprint(w, tag); ferr != nil { - return ferr - } - if wire != WireStartGroup { - if err = w.WriteByte(':'); err != nil { - return err - } - } - if !w.compact || wire == WireStartGroup { - if err = w.WriteByte(' '); err != nil { - return err - } - } - switch wire { - case WireBytes: - buf, e := b.DecodeRawBytes(false) - if e == nil { - _, err = fmt.Fprintf(w, "%q", buf) - } else { - _, err = fmt.Fprintf(w, "/* %v */", e) - } - case WireFixed32: - x, err = b.DecodeFixed32() - err = writeUnknownInt(w, x, err) - case WireFixed64: - x, err = b.DecodeFixed64() - err = writeUnknownInt(w, x, err) - case WireStartGroup: - err = w.WriteByte('{') - w.indent() - case WireVarint: - x, err = b.DecodeVarint() - err = writeUnknownInt(w, x, err) - default: - _, err = fmt.Fprintf(w, "/* unknown wire type %d */", wire) - } - if err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - return nil -} - -func writeUnknownInt(w *textWriter, x uint64, err error) error { - if err == nil { - _, err = fmt.Fprint(w, x) - } else { - _, err = fmt.Fprintf(w, "/* %v */", err) - } - return err -} - -type int32Slice []int32 - -func (s int32Slice) Len() int { return len(s) } -func (s int32Slice) Less(i, j int) bool { return s[i] < s[j] } -func (s int32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] } - -// writeExtensions writes all the extensions in pv. -// pv is assumed to be a pointer to a protocol message struct that is extendable. -func writeExtensions(w *textWriter, pv reflect.Value) error { - emap := extensionMaps[pv.Type().Elem()] - ep := pv.Interface().(extendableProto) - - // Order the extensions by ID. - // This isn't strictly necessary, but it will give us - // canonical output, which will also make testing easier. - var m map[int32]Extension - if em, ok := ep.(extensionsMap); ok { - m = em.ExtensionMap() - } else if em, ok := ep.(extensionsBytes); ok { - eb := em.GetExtensions() - var err error - m, err = BytesToExtensionsMap(*eb) - if err != nil { - return err - } - } - - ids := make([]int32, 0, len(m)) - for id := range m { - ids = append(ids, id) - } - sort.Sort(int32Slice(ids)) - - for _, extNum := range ids { - ext := m[extNum] - var desc *ExtensionDesc - if emap != nil { - desc = emap[extNum] - } - if desc == nil { - // Unknown extension. - if err := writeUnknownStruct(w, ext.enc); err != nil { - return err - } - continue - } - - pb, err := GetExtension(ep, desc) - if err != nil { - return fmt.Errorf("failed getting extension: %v", err) - } - - // Repeated extensions will appear as a slice. - if !desc.repeated() { - if err := writeExtension(w, desc.Name, pb); err != nil { - return err - } - } else { - v := reflect.ValueOf(pb) - for i := 0; i < v.Len(); i++ { - if err := writeExtension(w, desc.Name, v.Index(i).Interface()); err != nil { - return err - } - } - } - } - return nil -} - -func writeExtension(w *textWriter, name string, pb interface{}) error { - if _, err := fmt.Fprintf(w, "[%s]:", name); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := writeAny(w, reflect.ValueOf(pb), nil); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - return nil -} - -func (w *textWriter) writeIndent() { - if !w.complete { - return - } - remain := w.ind * 2 - for remain > 0 { - n := remain - if n > len(spaces) { - n = len(spaces) - } - w.w.Write(spaces[:n]) - remain -= n - } - w.complete = false -} - -// TextMarshaler is a configurable text format marshaler. -type TextMarshaler struct { - Compact bool // use compact text format (one line). -} - -// Marshal writes a given protocol buffer in text format. -// The only errors returned are from w. -func (m *TextMarshaler) Marshal(w io.Writer, pb Message) error { - val := reflect.ValueOf(pb) - if pb == nil || val.IsNil() { - w.Write([]byte("")) - return nil - } - var bw *bufio.Writer - ww, ok := w.(writer) - if !ok { - bw = bufio.NewWriter(w) - ww = bw - } - aw := &textWriter{ - w: ww, - complete: true, - compact: m.Compact, - } - - if tm, ok := pb.(encoding.TextMarshaler); ok { - text, err := tm.MarshalText() - if err != nil { - return err - } - if _, err = aw.Write(text); err != nil { - return err - } - if bw != nil { - return bw.Flush() - } - return nil - } - // Dereference the received pointer so we don't have outer < and >. - v := reflect.Indirect(val) - if err := writeStruct(aw, v); err != nil { - return err - } - if bw != nil { - return bw.Flush() - } - return nil -} - -// Text is the same as Marshal, but returns the string directly. -func (m *TextMarshaler) Text(pb Message) string { - var buf bytes.Buffer - m.Marshal(&buf, pb) - return buf.String() -} - -var ( - defaultTextMarshaler = TextMarshaler{} - compactTextMarshaler = TextMarshaler{Compact: true} -) - -// TODO: consider removing some of the Marshal functions below. - -// MarshalText writes a given protocol buffer in text format. -// The only errors returned are from w. -func MarshalText(w io.Writer, pb Message) error { return defaultTextMarshaler.Marshal(w, pb) } - -// MarshalTextString is the same as MarshalText, but returns the string directly. -func MarshalTextString(pb Message) string { return defaultTextMarshaler.Text(pb) } - -// CompactText writes a given protocol buffer in compact text format (one line). -func CompactText(w io.Writer, pb Message) error { return compactTextMarshaler.Marshal(w, pb) } - -// CompactTextString is the same as CompactText, but returns the string directly. -func CompactTextString(pb Message) string { return compactTextMarshaler.Text(pb) } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_gogo.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_gogo.go deleted file mode 100644 index cdb2337..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_gogo.go +++ /dev/null @@ -1,55 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -import ( - "fmt" - "reflect" -) - -func writeEnum(w *textWriter, v reflect.Value, props *Properties) error { - m, ok := enumStringMaps[props.Enum] - if !ok { - if err := writeAny(w, v, props); err != nil { - return err - } - } - key := int32(0) - if v.Kind() == reflect.Ptr { - key = int32(v.Elem().Int()) - } else { - key = int32(v.Int()) - } - s, ok := m[key] - if !ok { - if err := writeAny(w, v, props); err != nil { - return err - } - } - _, err := fmt.Fprint(w, s) - return err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_parser.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_parser.go deleted file mode 100644 index 61b4bc8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/proto/text_parser.go +++ /dev/null @@ -1,849 +0,0 @@ -// Extensions for Protocol Buffers to create more go like structures. -// -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf/gogoproto -// -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// Functions for parsing the Text protocol buffer format. -// TODO: message sets. - -import ( - "encoding" - "errors" - "fmt" - "reflect" - "strconv" - "strings" - "unicode/utf8" -) - -type ParseError struct { - Message string - Line int // 1-based line number - Offset int // 0-based byte offset from start of input -} - -func (p *ParseError) Error() string { - if p.Line == 1 { - // show offset only for first line - return fmt.Sprintf("line 1.%d: %v", p.Offset, p.Message) - } - return fmt.Sprintf("line %d: %v", p.Line, p.Message) -} - -type token struct { - value string - err *ParseError - line int // line number - offset int // byte number from start of input, not start of line - unquoted string // the unquoted version of value, if it was a quoted string -} - -func (t *token) String() string { - if t.err == nil { - return fmt.Sprintf("%q (line=%d, offset=%d)", t.value, t.line, t.offset) - } - return fmt.Sprintf("parse error: %v", t.err) -} - -type textParser struct { - s string // remaining input - done bool // whether the parsing is finished (success or error) - backed bool // whether back() was called - offset, line int - cur token -} - -func newTextParser(s string) *textParser { - p := new(textParser) - p.s = s - p.line = 1 - p.cur.line = 1 - return p -} - -func (p *textParser) errorf(format string, a ...interface{}) *ParseError { - pe := &ParseError{fmt.Sprintf(format, a...), p.cur.line, p.cur.offset} - p.cur.err = pe - p.done = true - return pe -} - -// Numbers and identifiers are matched by [-+._A-Za-z0-9] -func isIdentOrNumberChar(c byte) bool { - switch { - case 'A' <= c && c <= 'Z', 'a' <= c && c <= 'z': - return true - case '0' <= c && c <= '9': - return true - } - switch c { - case '-', '+', '.', '_': - return true - } - return false -} - -func isWhitespace(c byte) bool { - switch c { - case ' ', '\t', '\n', '\r': - return true - } - return false -} - -func isQuote(c byte) bool { - switch c { - case '"', '\'': - return true - } - return false -} - -func (p *textParser) skipWhitespace() { - i := 0 - for i < len(p.s) && (isWhitespace(p.s[i]) || p.s[i] == '#') { - if p.s[i] == '#' { - // comment; skip to end of line or input - for i < len(p.s) && p.s[i] != '\n' { - i++ - } - if i == len(p.s) { - break - } - } - if p.s[i] == '\n' { - p.line++ - } - i++ - } - p.offset += i - p.s = p.s[i:len(p.s)] - if len(p.s) == 0 { - p.done = true - } -} - -func (p *textParser) advance() { - // Skip whitespace - p.skipWhitespace() - if p.done { - return - } - - // Start of non-whitespace - p.cur.err = nil - p.cur.offset, p.cur.line = p.offset, p.line - p.cur.unquoted = "" - switch p.s[0] { - case '<', '>', '{', '}', ':', '[', ']', ';', ',': - // Single symbol - p.cur.value, p.s = p.s[0:1], p.s[1:len(p.s)] - case '"', '\'': - // Quoted string - i := 1 - for i < len(p.s) && p.s[i] != p.s[0] && p.s[i] != '\n' { - if p.s[i] == '\\' && i+1 < len(p.s) { - // skip escaped char - i++ - } - i++ - } - if i >= len(p.s) || p.s[i] != p.s[0] { - p.errorf("unmatched quote") - return - } - unq, err := unquoteC(p.s[1:i], rune(p.s[0])) - if err != nil { - p.errorf("invalid quoted string %s: %v", p.s[0:i+1], err) - return - } - p.cur.value, p.s = p.s[0:i+1], p.s[i+1:len(p.s)] - p.cur.unquoted = unq - default: - i := 0 - for i < len(p.s) && isIdentOrNumberChar(p.s[i]) { - i++ - } - if i == 0 { - p.errorf("unexpected byte %#x", p.s[0]) - return - } - p.cur.value, p.s = p.s[0:i], p.s[i:len(p.s)] - } - p.offset += len(p.cur.value) -} - -var ( - errBadUTF8 = errors.New("proto: bad UTF-8") - errBadHex = errors.New("proto: bad hexadecimal") -) - -func unquoteC(s string, quote rune) (string, error) { - // This is based on C++'s tokenizer.cc. - // Despite its name, this is *not* parsing C syntax. - // For instance, "\0" is an invalid quoted string. - - // Avoid allocation in trivial cases. - simple := true - for _, r := range s { - if r == '\\' || r == quote { - simple = false - break - } - } - if simple { - return s, nil - } - - buf := make([]byte, 0, 3*len(s)/2) - for len(s) > 0 { - r, n := utf8.DecodeRuneInString(s) - if r == utf8.RuneError && n == 1 { - return "", errBadUTF8 - } - s = s[n:] - if r != '\\' { - if r < utf8.RuneSelf { - buf = append(buf, byte(r)) - } else { - buf = append(buf, string(r)...) - } - continue - } - - ch, tail, err := unescape(s) - if err != nil { - return "", err - } - buf = append(buf, ch...) - s = tail - } - return string(buf), nil -} - -func unescape(s string) (ch string, tail string, err error) { - r, n := utf8.DecodeRuneInString(s) - if r == utf8.RuneError && n == 1 { - return "", "", errBadUTF8 - } - s = s[n:] - switch r { - case 'a': - return "\a", s, nil - case 'b': - return "\b", s, nil - case 'f': - return "\f", s, nil - case 'n': - return "\n", s, nil - case 'r': - return "\r", s, nil - case 't': - return "\t", s, nil - case 'v': - return "\v", s, nil - case '?': - return "?", s, nil // trigraph workaround - case '\'', '"', '\\': - return string(r), s, nil - case '0', '1', '2', '3', '4', '5', '6', '7', 'x', 'X': - if len(s) < 2 { - return "", "", fmt.Errorf(`\%c requires 2 following digits`, r) - } - base := 8 - ss := s[:2] - s = s[2:] - if r == 'x' || r == 'X' { - base = 16 - } else { - ss = string(r) + ss - } - i, err := strconv.ParseUint(ss, base, 8) - if err != nil { - return "", "", err - } - return string([]byte{byte(i)}), s, nil - case 'u', 'U': - n := 4 - if r == 'U' { - n = 8 - } - if len(s) < n { - return "", "", fmt.Errorf(`\%c requires %d digits`, r, n) - } - - bs := make([]byte, n/2) - for i := 0; i < n; i += 2 { - a, ok1 := unhex(s[i]) - b, ok2 := unhex(s[i+1]) - if !ok1 || !ok2 { - return "", "", errBadHex - } - bs[i/2] = a<<4 | b - } - s = s[n:] - return string(bs), s, nil - } - return "", "", fmt.Errorf(`unknown escape \%c`, r) -} - -// Adapted from src/pkg/strconv/quote.go. -func unhex(b byte) (v byte, ok bool) { - switch { - case '0' <= b && b <= '9': - return b - '0', true - case 'a' <= b && b <= 'f': - return b - 'a' + 10, true - case 'A' <= b && b <= 'F': - return b - 'A' + 10, true - } - return 0, false -} - -// Back off the parser by one token. Can only be done between calls to next(). -// It makes the next advance() a no-op. -func (p *textParser) back() { p.backed = true } - -// Advances the parser and returns the new current token. -func (p *textParser) next() *token { - if p.backed || p.done { - p.backed = false - return &p.cur - } - p.advance() - if p.done { - p.cur.value = "" - } else if len(p.cur.value) > 0 && isQuote(p.cur.value[0]) { - // Look for multiple quoted strings separated by whitespace, - // and concatenate them. - cat := p.cur - for { - p.skipWhitespace() - if p.done || !isQuote(p.s[0]) { - break - } - p.advance() - if p.cur.err != nil { - return &p.cur - } - cat.value += " " + p.cur.value - cat.unquoted += p.cur.unquoted - } - p.done = false // parser may have seen EOF, but we want to return cat - p.cur = cat - } - return &p.cur -} - -func (p *textParser) consumeToken(s string) error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != s { - p.back() - return p.errorf("expected %q, found %q", s, tok.value) - } - return nil -} - -// Return a RequiredNotSetError indicating which required field was not set. -func (p *textParser) missingRequiredFieldError(sv reflect.Value) *RequiredNotSetError { - st := sv.Type() - sprops := GetProperties(st) - for i := 0; i < st.NumField(); i++ { - if !isNil(sv.Field(i)) { - continue - } - - props := sprops.Prop[i] - if props.Required { - return &RequiredNotSetError{fmt.Sprintf("%v.%v", st, props.OrigName)} - } - } - return &RequiredNotSetError{fmt.Sprintf("%v.", st)} // should not happen -} - -// Returns the index in the struct for the named field, as well as the parsed tag properties. -func structFieldByName(sprops *StructProperties, name string) (int, *Properties, bool) { - i, ok := sprops.decoderOrigNames[name] - if ok { - return i, sprops.Prop[i], true - } - return -1, nil, false -} - -// Consume a ':' from the input stream (if the next token is a colon), -// returning an error if a colon is needed but not present. -func (p *textParser) checkForColon(props *Properties, typ reflect.Type) *ParseError { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != ":" { - // Colon is optional when the field is a group or message. - needColon := true - switch props.Wire { - case "group": - needColon = false - case "bytes": - // A "bytes" field is either a message, a string, or a repeated field; - // those three become *T, *string and []T respectively, so we can check for - // this field being a pointer to a non-string. - if typ.Kind() == reflect.Ptr { - // *T or *string - if typ.Elem().Kind() == reflect.String { - break - } - } else if typ.Kind() == reflect.Slice { - // []T or []*T - if typ.Elem().Kind() != reflect.Ptr { - break - } - } else if typ.Kind() == reflect.String { - // The proto3 exception is for a string field, - // which requires a colon. - break - } - needColon = false - } - if needColon { - return p.errorf("expected ':', found %q", tok.value) - } - p.back() - } - return nil -} - -func (p *textParser) readStruct(sv reflect.Value, terminator string) error { - st := sv.Type() - sprops := GetProperties(st) - reqCount := sprops.reqCount - var reqFieldErr error - fieldSet := make(map[string]bool) - // A struct is a sequence of "name: value", terminated by one of - // '>' or '}', or the end of the input. A name may also be - // "[extension]". - for { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == terminator { - break - } - if tok.value == "[" { - // Looks like an extension. - // - // TODO: Check whether we need to handle - // namespace rooted names (e.g. ".something.Foo"). - tok = p.next() - if tok.err != nil { - return tok.err - } - var desc *ExtensionDesc - // This could be faster, but it's functional. - // TODO: Do something smarter than a linear scan. - for _, d := range RegisteredExtensions(reflect.New(st).Interface().(Message)) { - if d.Name == tok.value { - desc = d - break - } - } - if desc == nil { - return p.errorf("unrecognized extension %q", tok.value) - } - // Check the extension terminator. - tok = p.next() - if tok.err != nil { - return tok.err - } - if tok.value != "]" { - return p.errorf("unrecognized extension terminator %q", tok.value) - } - - props := &Properties{} - props.Parse(desc.Tag) - - typ := reflect.TypeOf(desc.ExtensionType) - if err := p.checkForColon(props, typ); err != nil { - return err - } - - rep := desc.repeated() - - // Read the extension structure, and set it in - // the value we're constructing. - var ext reflect.Value - if !rep { - ext = reflect.New(typ).Elem() - } else { - ext = reflect.New(typ.Elem()).Elem() - } - if err := p.readAny(ext, props); err != nil { - if _, ok := err.(*RequiredNotSetError); !ok { - return err - } - reqFieldErr = err - } - ep := sv.Addr().Interface().(extendableProto) - if !rep { - SetExtension(ep, desc, ext.Interface()) - } else { - old, err := GetExtension(ep, desc) - var sl reflect.Value - if err == nil { - sl = reflect.ValueOf(old) // existing slice - } else { - sl = reflect.MakeSlice(typ, 0, 1) - } - sl = reflect.Append(sl, ext) - SetExtension(ep, desc, sl.Interface()) - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - continue - } - - // This is a normal, non-extension field. - name := tok.value - var dst reflect.Value - fi, props, ok := structFieldByName(sprops, name) - if ok { - dst = sv.Field(fi) - } else if oop, ok := sprops.OneofTypes[name]; ok { - // It is a oneof. - props = oop.Prop - nv := reflect.New(oop.Type.Elem()) - dst = nv.Elem().Field(0) - sv.Field(oop.Field).Set(nv) - } - if !dst.IsValid() { - return p.errorf("unknown field name %q in %v", name, st) - } - - if dst.Kind() == reflect.Map { - // Consume any colon. - if err := p.checkForColon(props, dst.Type()); err != nil { - return err - } - - // Construct the map if it doesn't already exist. - if dst.IsNil() { - dst.Set(reflect.MakeMap(dst.Type())) - } - key := reflect.New(dst.Type().Key()).Elem() - val := reflect.New(dst.Type().Elem()).Elem() - - // The map entry should be this sequence of tokens: - // < key : KEY value : VALUE > - // Technically the "key" and "value" could come in any order, - // but in practice they won't. - - tok := p.next() - var terminator string - switch tok.value { - case "<": - terminator = ">" - case "{": - terminator = "}" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - if err := p.consumeToken("key"); err != nil { - return err - } - if err := p.consumeToken(":"); err != nil { - return err - } - if err := p.readAny(key, props.mkeyprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - if err := p.consumeToken("value"); err != nil { - return err - } - if err := p.checkForColon(props.mvalprop, dst.Type().Elem()); err != nil { - return err - } - if err := p.readAny(val, props.mvalprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - if err := p.consumeToken(terminator); err != nil { - return err - } - - dst.SetMapIndex(key, val) - continue - } - - // Check that it's not already set if it's not a repeated field. - if !props.Repeated && fieldSet[name] { - return p.errorf("non-repeated field %q was repeated", name) - } - - if err := p.checkForColon(props, dst.Type()); err != nil { - return err - } - - // Parse into the field. - fieldSet[name] = true - if err := p.readAny(dst, props); err != nil { - if _, ok := err.(*RequiredNotSetError); !ok { - return err - } - reqFieldErr = err - } else if props.Required { - reqCount-- - } - - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - - } - - if reqCount > 0 { - return p.missingRequiredFieldError(sv) - } - return reqFieldErr -} - -// consumeOptionalSeparator consumes an optional semicolon or comma. -// It is used in readStruct to provide backward compatibility. -func (p *textParser) consumeOptionalSeparator() error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != ";" && tok.value != "," { - p.back() - } - return nil -} - -func (p *textParser) readAny(v reflect.Value, props *Properties) error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == "" { - return p.errorf("unexpected EOF") - } - if len(props.CustomType) > 0 { - if props.Repeated { - t := reflect.TypeOf(v.Interface()) - if t.Kind() == reflect.Slice { - tc := reflect.TypeOf(new(Marshaler)) - ok := t.Elem().Implements(tc.Elem()) - if ok { - fv := v - flen := fv.Len() - if flen == fv.Cap() { - nav := reflect.MakeSlice(v.Type(), flen, 2*flen+1) - reflect.Copy(nav, fv) - fv.Set(nav) - } - fv.SetLen(flen + 1) - - // Read one. - p.back() - return p.readAny(fv.Index(flen), props) - } - } - } - if reflect.TypeOf(v.Interface()).Kind() == reflect.Ptr { - custom := reflect.New(props.ctype.Elem()).Interface().(Unmarshaler) - err := custom.Unmarshal([]byte(tok.unquoted)) - if err != nil { - return p.errorf("%v %v: %v", err, v.Type(), tok.value) - } - v.Set(reflect.ValueOf(custom)) - } else { - custom := reflect.New(reflect.TypeOf(v.Interface())).Interface().(Unmarshaler) - err := custom.Unmarshal([]byte(tok.unquoted)) - if err != nil { - return p.errorf("%v %v: %v", err, v.Type(), tok.value) - } - v.Set(reflect.Indirect(reflect.ValueOf(custom))) - } - return nil - } - switch fv := v; fv.Kind() { - case reflect.Slice: - at := v.Type() - if at.Elem().Kind() == reflect.Uint8 { - // Special case for []byte - if tok.value[0] != '"' && tok.value[0] != '\'' { - // Deliberately written out here, as the error after - // this switch statement would write "invalid []byte: ...", - // which is not as user-friendly. - return p.errorf("invalid string: %v", tok.value) - } - bytes := []byte(tok.unquoted) - fv.Set(reflect.ValueOf(bytes)) - return nil - } - // Repeated field. - if tok.value == "[" { - // Repeated field with list notation, like [1,2,3]. - for { - fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) - err := p.readAny(fv.Index(fv.Len()-1), props) - if err != nil { - return err - } - ntok := p.next() - if ntok.err != nil { - return ntok.err - } - if ntok.value == "]" { - break - } - if ntok.value != "," { - return p.errorf("Expected ']' or ',' found %q", ntok.value) - } - } - return nil - } - // One value of the repeated field. - p.back() - fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) - return p.readAny(fv.Index(fv.Len()-1), props) - case reflect.Bool: - // Either "true", "false", 1 or 0. - switch tok.value { - case "true", "1": - fv.SetBool(true) - return nil - case "false", "0": - fv.SetBool(false) - return nil - } - case reflect.Float32, reflect.Float64: - v := tok.value - // Ignore 'f' for compatibility with output generated by C++, but don't - // remove 'f' when the value is "-inf" or "inf". - if strings.HasSuffix(v, "f") && tok.value != "-inf" && tok.value != "inf" { - v = v[:len(v)-1] - } - if f, err := strconv.ParseFloat(v, fv.Type().Bits()); err == nil { - fv.SetFloat(f) - return nil - } - case reflect.Int32: - if x, err := strconv.ParseInt(tok.value, 0, 32); err == nil { - fv.SetInt(x) - return nil - } - - if len(props.Enum) == 0 { - break - } - m, ok := enumValueMaps[props.Enum] - if !ok { - break - } - x, ok := m[tok.value] - if !ok { - break - } - fv.SetInt(int64(x)) - return nil - case reflect.Int64: - if x, err := strconv.ParseInt(tok.value, 0, 64); err == nil { - fv.SetInt(x) - return nil - } - - case reflect.Ptr: - // A basic field (indirected through pointer), or a repeated message/group - p.back() - fv.Set(reflect.New(fv.Type().Elem())) - return p.readAny(fv.Elem(), props) - case reflect.String: - if tok.value[0] == '"' || tok.value[0] == '\'' { - fv.SetString(tok.unquoted) - return nil - } - case reflect.Struct: - var terminator string - switch tok.value { - case "{": - terminator = "}" - case "<": - terminator = ">" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - // TODO: Handle nested messages which implement encoding.TextUnmarshaler. - return p.readStruct(fv, terminator) - case reflect.Uint32: - if x, err := strconv.ParseUint(tok.value, 0, 32); err == nil { - fv.SetUint(uint64(x)) - return nil - } - case reflect.Uint64: - if x, err := strconv.ParseUint(tok.value, 0, 64); err == nil { - fv.SetUint(x) - return nil - } - } - return p.errorf("invalid %v: %v", v.Type(), tok.value) -} - -// UnmarshalText reads a protocol buffer in Text format. UnmarshalText resets pb -// before starting to unmarshal, so any existing data in pb is always removed. -// If a required field is not set and no other error occurs, -// UnmarshalText returns *RequiredNotSetError. -func UnmarshalText(s string, pb Message) error { - if um, ok := pb.(encoding.TextUnmarshaler); ok { - err := um.UnmarshalText([]byte(s)) - return err - } - pb.Reset() - v := reflect.ValueOf(pb) - if pe := newTextParser(s).readStruct(v.Elem(), ""); pe != nil { - return pe - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go b/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go deleted file mode 100644 index c52878d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/gogo/protobuf/sortkeys/sortkeys.go +++ /dev/null @@ -1,99 +0,0 @@ -// Copyright (c) 2013, Vastech SA (PTY) LTD. All rights reserved. -// http://github.com/gogo/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package sortkeys - -import ( - "sort" -) - -func Strings(l []string) { - sort.Strings(l) -} - -func Float64s(l []float64) { - sort.Float64s(l) -} - -func Float32s(l []float32) { - sort.Sort(Float32Slice(l)) -} - -func Int64s(l []int64) { - sort.Sort(Int64Slice(l)) -} - -func Int32s(l []int32) { - sort.Sort(Int32Slice(l)) -} - -func Uint64s(l []uint64) { - sort.Sort(Uint64Slice(l)) -} - -func Uint32s(l []uint32) { - sort.Sort(Uint32Slice(l)) -} - -func Bools(l []bool) { - sort.Sort(BoolSlice(l)) -} - -type BoolSlice []bool - -func (p BoolSlice) Len() int { return len(p) } -func (p BoolSlice) Less(i, j int) bool { return p[j] } -func (p BoolSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -type Int64Slice []int64 - -func (p Int64Slice) Len() int { return len(p) } -func (p Int64Slice) Less(i, j int) bool { return p[i] < p[j] } -func (p Int64Slice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -type Int32Slice []int32 - -func (p Int32Slice) Len() int { return len(p) } -func (p Int32Slice) Less(i, j int) bool { return p[i] < p[j] } -func (p Int32Slice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -type Uint64Slice []uint64 - -func (p Uint64Slice) Len() int { return len(p) } -func (p Uint64Slice) Less(i, j int) bool { return p[i] < p[j] } -func (p Uint64Slice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -type Uint32Slice []uint32 - -func (p Uint32Slice) Len() int { return len(p) } -func (p Uint32Slice) Less(i, j int) bool { return p[i] < p[j] } -func (p Uint32Slice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -type Float32Slice []float32 - -func (p Float32Slice) Len() int { return len(p) } -func (p Float32Slice) Less(i, j int) bool { return p[i] < p[j] } -func (p Float32Slice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/LICENSE deleted file mode 100644 index 37ec93a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/LICENSE +++ /dev/null @@ -1,191 +0,0 @@ -Apache License -Version 2.0, January 2004 -http://www.apache.org/licenses/ - -TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - -1. Definitions. - -"License" shall mean the terms and conditions for use, reproduction, and -distribution as defined by Sections 1 through 9 of this document. - -"Licensor" shall mean the copyright owner or entity authorized by the copyright -owner that is granting the License. - -"Legal Entity" shall mean the union of the acting entity and all other entities -that control, are controlled by, or are under common control with that entity. -For the purposes of this definition, "control" means (i) the power, direct or -indirect, to cause the direction or management of such entity, whether by -contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the -outstanding shares, or (iii) beneficial ownership of such entity. - -"You" (or "Your") shall mean an individual or Legal Entity exercising -permissions granted by this License. - -"Source" form shall mean the preferred form for making modifications, including -but not limited to software source code, documentation source, and configuration -files. - -"Object" form shall mean any form resulting from mechanical transformation or -translation of a Source form, including but not limited to compiled object code, -generated documentation, and conversions to other media types. - -"Work" shall mean the work of authorship, whether in Source or Object form, made -available under the License, as indicated by a copyright notice that is included -in or attached to the work (an example is provided in the Appendix below). - -"Derivative Works" shall mean any work, whether in Source or Object form, that -is based on (or derived from) the Work and for which the editorial revisions, -annotations, elaborations, or other modifications represent, as a whole, an -original work of authorship. For the purposes of this License, Derivative Works -shall not include works that remain separable from, or merely link (or bind by -name) to the interfaces of, the Work and Derivative Works thereof. - -"Contribution" shall mean any work of authorship, including the original version -of the Work and any modifications or additions to that Work or Derivative Works -thereof, that is intentionally submitted to Licensor for inclusion in the Work -by the copyright owner or by an individual or Legal Entity authorized to submit -on behalf of the copyright owner. For the purposes of this definition, -"submitted" means any form of electronic, verbal, or written communication sent -to the Licensor or its representatives, including but not limited to -communication on electronic mailing lists, source code control systems, and -issue tracking systems that are managed by, or on behalf of, the Licensor for -the purpose of discussing and improving the Work, but excluding communication -that is conspicuously marked or otherwise designated in writing by the copyright -owner as "Not a Contribution." - -"Contributor" shall mean Licensor and any individual or Legal Entity on behalf -of whom a Contribution has been received by Licensor and subsequently -incorporated within the Work. - -2. Grant of Copyright License. - -Subject to the terms and conditions of this License, each Contributor hereby -grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, -irrevocable copyright license to reproduce, prepare Derivative Works of, -publicly display, publicly perform, sublicense, and distribute the Work and such -Derivative Works in Source or Object form. - -3. Grant of Patent License. - -Subject to the terms and conditions of this License, each Contributor hereby -grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, -irrevocable (except as stated in this section) patent license to make, have -made, use, offer to sell, sell, import, and otherwise transfer the Work, where -such license applies only to those patent claims licensable by such Contributor -that are necessarily infringed by their Contribution(s) alone or by combination -of their Contribution(s) with the Work to which such Contribution(s) was -submitted. If You institute patent litigation against any entity (including a -cross-claim or counterclaim in a lawsuit) alleging that the Work or a -Contribution incorporated within the Work constitutes direct or contributory -patent infringement, then any patent licenses granted to You under this License -for that Work shall terminate as of the date such litigation is filed. - -4. Redistribution. - -You may reproduce and distribute copies of the Work or Derivative Works thereof -in any medium, with or without modifications, and in Source or Object form, -provided that You meet the following conditions: - -You must give any other recipients of the Work or Derivative Works a copy of -this License; and -You must cause any modified files to carry prominent notices stating that You -changed the files; and -You must retain, in the Source form of any Derivative Works that You distribute, -all copyright, patent, trademark, and attribution notices from the Source form -of the Work, excluding those notices that do not pertain to any part of the -Derivative Works; and -If the Work includes a "NOTICE" text file as part of its distribution, then any -Derivative Works that You distribute must include a readable copy of the -attribution notices contained within such NOTICE file, excluding those notices -that do not pertain to any part of the Derivative Works, in at least one of the -following places: within a NOTICE text file distributed as part of the -Derivative Works; within the Source form or documentation, if provided along -with the Derivative Works; or, within a display generated by the Derivative -Works, if and wherever such third-party notices normally appear. The contents of -the NOTICE file are for informational purposes only and do not modify the -License. You may add Your own attribution notices within Derivative Works that -You distribute, alongside or as an addendum to the NOTICE text from the Work, -provided that such additional attribution notices cannot be construed as -modifying the License. -You may add Your own copyright statement to Your modifications and may provide -additional or different license terms and conditions for use, reproduction, or -distribution of Your modifications, or for any such Derivative Works as a whole, -provided Your use, reproduction, and distribution of the Work otherwise complies -with the conditions stated in this License. - -5. Submission of Contributions. - -Unless You explicitly state otherwise, any Contribution intentionally submitted -for inclusion in the Work by You to the Licensor shall be under the terms and -conditions of this License, without any additional terms or conditions. -Notwithstanding the above, nothing herein shall supersede or modify the terms of -any separate license agreement you may have executed with Licensor regarding -such Contributions. - -6. Trademarks. - -This License does not grant permission to use the trade names, trademarks, -service marks, or product names of the Licensor, except as required for -reasonable and customary use in describing the origin of the Work and -reproducing the content of the NOTICE file. - -7. Disclaimer of Warranty. - -Unless required by applicable law or agreed to in writing, Licensor provides the -Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, -including, without limitation, any warranties or conditions of TITLE, -NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are -solely responsible for determining the appropriateness of using or -redistributing the Work and assume any risks associated with Your exercise of -permissions under this License. - -8. Limitation of Liability. - -In no event and under no legal theory, whether in tort (including negligence), -contract, or otherwise, unless required by applicable law (such as deliberate -and grossly negligent acts) or agreed to in writing, shall any Contributor be -liable to You for damages, including any direct, indirect, special, incidental, -or consequential damages of any character arising as a result of this License or -out of the use or inability to use the Work (including but not limited to -damages for loss of goodwill, work stoppage, computer failure or malfunction, or -any and all other commercial damages or losses), even if such Contributor has -been advised of the possibility of such damages. - -9. Accepting Warranty or Additional Liability. - -While redistributing the Work or Derivative Works thereof, You may choose to -offer, and charge a fee for, acceptance of support, warranty, indemnity, or -other liability obligations and/or rights consistent with this License. However, -in accepting such obligations, You may act only on Your own behalf and on Your -sole responsibility, not on behalf of any other Contributor, and only if You -agree to indemnify, defend, and hold each Contributor harmless for any liability -incurred by, or claims asserted against, such Contributor by reason of your -accepting any such warranty or additional liability. - -END OF TERMS AND CONDITIONS - -APPENDIX: How to apply the Apache License to your work - -To apply the Apache License to your work, attach the following boilerplate -notice, with the fields enclosed by brackets "[]" replaced with your own -identifying information. (Don't include the brackets!) The text should be -enclosed in the appropriate comment syntax for the file format. We also -recommend that a file or class name and description of purpose be included on -the same "printed page" as the copyright notice for easier identification within -third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/README b/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/README deleted file mode 100644 index 5f9c114..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/README +++ /dev/null @@ -1,44 +0,0 @@ -glog -==== - -Leveled execution logs for Go. - -This is an efficient pure Go implementation of leveled logs in the -manner of the open source C++ package - http://code.google.com/p/google-glog - -By binding methods to booleans it is possible to use the log package -without paying the expense of evaluating the arguments to the log. -Through the -vmodule flag, the package also provides fine-grained -control over logging at the file level. - -The comment from glog.go introduces the ideas: - - Package glog implements logging analogous to the Google-internal - C++ INFO/ERROR/V setup. It provides functions Info, Warning, - Error, Fatal, plus formatting variants such as Infof. It - also provides V-style logging controlled by the -v and - -vmodule=file=2 flags. - - Basic examples: - - glog.Info("Prepare to repel boarders") - - glog.Fatalf("Initialization failed: %s", err) - - See the documentation for the V function for an explanation - of these examples: - - if glog.V(2) { - glog.Info("Starting transaction...") - } - - glog.V(2).Infoln("Processed", nItems, "elements") - - -The repository contains an open source version of the log package -used inside Google. The master copy of the source lives inside -Google, not here. The code in this repo is for export only and is not itself -under development. Feature requests will be ignored. - -Send bug reports to golang-nuts@googlegroups.com. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog.go deleted file mode 100644 index 3e63fff..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog.go +++ /dev/null @@ -1,1177 +0,0 @@ -// Go support for leveled logs, analogous to https://code.google.com/p/google-glog/ -// -// Copyright 2013 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 glog implements logging analogous to the Google-internal C++ INFO/ERROR/V setup. -// It provides functions Info, Warning, Error, Fatal, plus formatting variants such as -// Infof. It also provides V-style logging controlled by the -v and -vmodule=file=2 flags. -// -// Basic examples: -// -// glog.Info("Prepare to repel boarders") -// -// glog.Fatalf("Initialization failed: %s", err) -// -// See the documentation for the V function for an explanation of these examples: -// -// if glog.V(2) { -// glog.Info("Starting transaction...") -// } -// -// glog.V(2).Infoln("Processed", nItems, "elements") -// -// Log output is buffered and written periodically using Flush. Programs -// should call Flush before exiting to guarantee all log output is written. -// -// By default, all log statements write to files in a temporary directory. -// This package provides several flags that modify this behavior. -// As a result, flag.Parse must be called before any logging is done. -// -// -logtostderr=false -// Logs are written to standard error instead of to files. -// -alsologtostderr=false -// Logs are written to standard error as well as to files. -// -stderrthreshold=ERROR -// Log events at or above this severity are logged to standard -// error as well as to files. -// -log_dir="" -// Log files will be written to this directory instead of the -// default temporary directory. -// -// Other flags provide aids to debugging. -// -// -log_backtrace_at="" -// When set to a file and line number holding a logging statement, -// such as -// -log_backtrace_at=gopherflakes.go:234 -// a stack trace will be written to the Info log whenever execution -// hits that statement. (Unlike with -vmodule, the ".go" must be -// present.) -// -v=0 -// Enable V-leveled logging at the specified level. -// -vmodule="" -// The syntax of the argument is a comma-separated list of pattern=N, -// where pattern is a literal file name (minus the ".go" suffix) or -// "glob" pattern and N is a V level. For instance, -// -vmodule=gopher*=3 -// sets the V level to 3 in all Go files whose names begin "gopher". -// -package glog - -import ( - "bufio" - "bytes" - "errors" - "flag" - "fmt" - "io" - stdLog "log" - "os" - "path/filepath" - "runtime" - "strconv" - "strings" - "sync" - "sync/atomic" - "time" -) - -// severity identifies the sort of log: info, warning etc. It also implements -// the flag.Value interface. The -stderrthreshold flag is of type severity and -// should be modified only through the flag.Value interface. The values match -// the corresponding constants in C++. -type severity int32 // sync/atomic int32 - -// These constants identify the log levels in order of increasing severity. -// A message written to a high-severity log file is also written to each -// lower-severity log file. -const ( - infoLog severity = iota - warningLog - errorLog - fatalLog - numSeverity = 4 -) - -const severityChar = "IWEF" - -var severityName = []string{ - infoLog: "INFO", - warningLog: "WARNING", - errorLog: "ERROR", - fatalLog: "FATAL", -} - -// get returns the value of the severity. -func (s *severity) get() severity { - return severity(atomic.LoadInt32((*int32)(s))) -} - -// set sets the value of the severity. -func (s *severity) set(val severity) { - atomic.StoreInt32((*int32)(s), int32(val)) -} - -// String is part of the flag.Value interface. -func (s *severity) String() string { - return strconv.FormatInt(int64(*s), 10) -} - -// Get is part of the flag.Value interface. -func (s *severity) Get() interface{} { - return *s -} - -// Set is part of the flag.Value interface. -func (s *severity) Set(value string) error { - var threshold severity - // Is it a known name? - if v, ok := severityByName(value); ok { - threshold = v - } else { - v, err := strconv.Atoi(value) - if err != nil { - return err - } - threshold = severity(v) - } - logging.stderrThreshold.set(threshold) - return nil -} - -func severityByName(s string) (severity, bool) { - s = strings.ToUpper(s) - for i, name := range severityName { - if name == s { - return severity(i), true - } - } - return 0, false -} - -// OutputStats tracks the number of output lines and bytes written. -type OutputStats struct { - lines int64 - bytes int64 -} - -// Lines returns the number of lines written. -func (s *OutputStats) Lines() int64 { - return atomic.LoadInt64(&s.lines) -} - -// Bytes returns the number of bytes written. -func (s *OutputStats) Bytes() int64 { - return atomic.LoadInt64(&s.bytes) -} - -// Stats tracks the number of lines of output and number of bytes -// per severity level. Values must be read with atomic.LoadInt64. -var Stats struct { - Info, Warning, Error OutputStats -} - -var severityStats = [numSeverity]*OutputStats{ - infoLog: &Stats.Info, - warningLog: &Stats.Warning, - errorLog: &Stats.Error, -} - -// Level is exported because it appears in the arguments to V and is -// the type of the v flag, which can be set programmatically. -// It's a distinct type because we want to discriminate it from logType. -// Variables of type level are only changed under logging.mu. -// The -v flag is read only with atomic ops, so the state of the logging -// module is consistent. - -// Level is treated as a sync/atomic int32. - -// Level specifies a level of verbosity for V logs. *Level implements -// flag.Value; the -v flag is of type Level and should be modified -// only through the flag.Value interface. -type Level int32 - -// get returns the value of the Level. -func (l *Level) get() Level { - return Level(atomic.LoadInt32((*int32)(l))) -} - -// set sets the value of the Level. -func (l *Level) set(val Level) { - atomic.StoreInt32((*int32)(l), int32(val)) -} - -// String is part of the flag.Value interface. -func (l *Level) String() string { - return strconv.FormatInt(int64(*l), 10) -} - -// Get is part of the flag.Value interface. -func (l *Level) Get() interface{} { - return *l -} - -// Set is part of the flag.Value interface. -func (l *Level) Set(value string) error { - v, err := strconv.Atoi(value) - if err != nil { - return err - } - logging.mu.Lock() - defer logging.mu.Unlock() - logging.setVState(Level(v), logging.vmodule.filter, false) - return nil -} - -// moduleSpec represents the setting of the -vmodule flag. -type moduleSpec struct { - filter []modulePat -} - -// modulePat contains a filter for the -vmodule flag. -// It holds a verbosity level and a file pattern to match. -type modulePat struct { - pattern string - literal bool // The pattern is a literal string - level Level -} - -// match reports whether the file matches the pattern. It uses a string -// comparison if the pattern contains no metacharacters. -func (m *modulePat) match(file string) bool { - if m.literal { - return file == m.pattern - } - match, _ := filepath.Match(m.pattern, file) - return match -} - -func (m *moduleSpec) String() string { - // Lock because the type is not atomic. TODO: clean this up. - logging.mu.Lock() - defer logging.mu.Unlock() - var b bytes.Buffer - for i, f := range m.filter { - if i > 0 { - b.WriteRune(',') - } - fmt.Fprintf(&b, "%s=%d", f.pattern, f.level) - } - return b.String() -} - -// Get is part of the (Go 1.2) flag.Getter interface. It always returns nil for this flag type since the -// struct is not exported. -func (m *moduleSpec) Get() interface{} { - return nil -} - -var errVmoduleSyntax = errors.New("syntax error: expect comma-separated list of filename=N") - -// Syntax: -vmodule=recordio=2,file=1,gfs*=3 -func (m *moduleSpec) Set(value string) error { - var filter []modulePat - for _, pat := range strings.Split(value, ",") { - if len(pat) == 0 { - // Empty strings such as from a trailing comma can be ignored. - continue - } - patLev := strings.Split(pat, "=") - if len(patLev) != 2 || len(patLev[0]) == 0 || len(patLev[1]) == 0 { - return errVmoduleSyntax - } - pattern := patLev[0] - v, err := strconv.Atoi(patLev[1]) - if err != nil { - return errors.New("syntax error: expect comma-separated list of filename=N") - } - if v < 0 { - return errors.New("negative value for vmodule level") - } - if v == 0 { - continue // Ignore. It's harmless but no point in paying the overhead. - } - // TODO: check syntax of filter? - filter = append(filter, modulePat{pattern, isLiteral(pattern), Level(v)}) - } - logging.mu.Lock() - defer logging.mu.Unlock() - logging.setVState(logging.verbosity, filter, true) - return nil -} - -// isLiteral reports whether the pattern is a literal string, that is, has no metacharacters -// that require filepath.Match to be called to match the pattern. -func isLiteral(pattern string) bool { - return !strings.ContainsAny(pattern, `\*?[]`) -} - -// traceLocation represents the setting of the -log_backtrace_at flag. -type traceLocation struct { - file string - line int -} - -// isSet reports whether the trace location has been specified. -// logging.mu is held. -func (t *traceLocation) isSet() bool { - return t.line > 0 -} - -// match reports whether the specified file and line matches the trace location. -// The argument file name is the full path, not the basename specified in the flag. -// logging.mu is held. -func (t *traceLocation) match(file string, line int) bool { - if t.line != line { - return false - } - if i := strings.LastIndex(file, "/"); i >= 0 { - file = file[i+1:] - } - return t.file == file -} - -func (t *traceLocation) String() string { - // Lock because the type is not atomic. TODO: clean this up. - logging.mu.Lock() - defer logging.mu.Unlock() - return fmt.Sprintf("%s:%d", t.file, t.line) -} - -// Get is part of the (Go 1.2) flag.Getter interface. It always returns nil for this flag type since the -// struct is not exported -func (t *traceLocation) Get() interface{} { - return nil -} - -var errTraceSyntax = errors.New("syntax error: expect file.go:234") - -// Syntax: -log_backtrace_at=gopherflakes.go:234 -// Note that unlike vmodule the file extension is included here. -func (t *traceLocation) Set(value string) error { - if value == "" { - // Unset. - t.line = 0 - t.file = "" - } - fields := strings.Split(value, ":") - if len(fields) != 2 { - return errTraceSyntax - } - file, line := fields[0], fields[1] - if !strings.Contains(file, ".") { - return errTraceSyntax - } - v, err := strconv.Atoi(line) - if err != nil { - return errTraceSyntax - } - if v <= 0 { - return errors.New("negative or zero value for level") - } - logging.mu.Lock() - defer logging.mu.Unlock() - t.line = v - t.file = file - return nil -} - -// flushSyncWriter is the interface satisfied by logging destinations. -type flushSyncWriter interface { - Flush() error - Sync() error - io.Writer -} - -func init() { - flag.BoolVar(&logging.toStderr, "logtostderr", false, "log to standard error instead of files") - flag.BoolVar(&logging.alsoToStderr, "alsologtostderr", false, "log to standard error as well as files") - flag.Var(&logging.verbosity, "v", "log level for V logs") - flag.Var(&logging.stderrThreshold, "stderrthreshold", "logs at or above this threshold go to stderr") - flag.Var(&logging.vmodule, "vmodule", "comma-separated list of pattern=N settings for file-filtered logging") - flag.Var(&logging.traceLocation, "log_backtrace_at", "when logging hits line file:N, emit a stack trace") - - // Default stderrThreshold is ERROR. - logging.stderrThreshold = errorLog - - logging.setVState(0, nil, false) - go logging.flushDaemon() -} - -// Flush flushes all pending log I/O. -func Flush() { - logging.lockAndFlushAll() -} - -// loggingT collects all the global state of the logging setup. -type loggingT struct { - // Boolean flags. Not handled atomically because the flag.Value interface - // does not let us avoid the =true, and that shorthand is necessary for - // compatibility. TODO: does this matter enough to fix? Seems unlikely. - toStderr bool // The -logtostderr flag. - alsoToStderr bool // The -alsologtostderr flag. - - // Level flag. Handled atomically. - stderrThreshold severity // The -stderrthreshold flag. - - // freeList is a list of byte buffers, maintained under freeListMu. - freeList *buffer - // freeListMu maintains the free list. It is separate from the main mutex - // so buffers can be grabbed and printed to without holding the main lock, - // for better parallelization. - freeListMu sync.Mutex - - // mu protects the remaining elements of this structure and is - // used to synchronize logging. - mu sync.Mutex - // file holds writer for each of the log types. - file [numSeverity]flushSyncWriter - // pcs is used in V to avoid an allocation when computing the caller's PC. - pcs [1]uintptr - // vmap is a cache of the V Level for each V() call site, identified by PC. - // It is wiped whenever the vmodule flag changes state. - vmap map[uintptr]Level - // filterLength stores the length of the vmodule filter chain. If greater - // than zero, it means vmodule is enabled. It may be read safely - // using sync.LoadInt32, but is only modified under mu. - filterLength int32 - // traceLocation is the state of the -log_backtrace_at flag. - traceLocation traceLocation - // These flags are modified only under lock, although verbosity may be fetched - // safely using atomic.LoadInt32. - vmodule moduleSpec // The state of the -vmodule flag. - verbosity Level // V logging level, the value of the -v flag/ -} - -// buffer holds a byte Buffer for reuse. The zero value is ready for use. -type buffer struct { - bytes.Buffer - tmp [64]byte // temporary byte array for creating headers. - next *buffer -} - -var logging loggingT - -// setVState sets a consistent state for V logging. -// l.mu is held. -func (l *loggingT) setVState(verbosity Level, filter []modulePat, setFilter bool) { - // Turn verbosity off so V will not fire while we are in transition. - logging.verbosity.set(0) - // Ditto for filter length. - atomic.StoreInt32(&logging.filterLength, 0) - - // Set the new filters and wipe the pc->Level map if the filter has changed. - if setFilter { - logging.vmodule.filter = filter - logging.vmap = make(map[uintptr]Level) - } - - // Things are consistent now, so enable filtering and verbosity. - // They are enabled in order opposite to that in V. - atomic.StoreInt32(&logging.filterLength, int32(len(filter))) - logging.verbosity.set(verbosity) -} - -// getBuffer returns a new, ready-to-use buffer. -func (l *loggingT) getBuffer() *buffer { - l.freeListMu.Lock() - b := l.freeList - if b != nil { - l.freeList = b.next - } - l.freeListMu.Unlock() - if b == nil { - b = new(buffer) - } else { - b.next = nil - b.Reset() - } - return b -} - -// putBuffer returns a buffer to the free list. -func (l *loggingT) putBuffer(b *buffer) { - if b.Len() >= 256 { - // Let big buffers die a natural death. - return - } - l.freeListMu.Lock() - b.next = l.freeList - l.freeList = b - l.freeListMu.Unlock() -} - -var timeNow = time.Now // Stubbed out for testing. - -/* -header formats a log header as defined by the C++ implementation. -It returns a buffer containing the formatted header and the user's file and line number. -The depth specifies how many stack frames above lives the source line to be identified in the log message. - -Log lines have this form: - Lmmdd hh:mm:ss.uuuuuu threadid file:line] msg... -where the fields are defined as follows: - L A single character, representing the log level (eg 'I' for INFO) - mm The month (zero padded; ie May is '05') - dd The day (zero padded) - hh:mm:ss.uuuuuu Time in hours, minutes and fractional seconds - threadid The space-padded thread ID as returned by GetTID() - file The file name - line The line number - msg The user-supplied message -*/ -func (l *loggingT) header(s severity, depth int) (*buffer, string, int) { - _, file, line, ok := runtime.Caller(3 + depth) - if !ok { - file = "???" - line = 1 - } else { - slash := strings.LastIndex(file, "/") - if slash >= 0 { - file = file[slash+1:] - } - } - return l.formatHeader(s, file, line), file, line -} - -// formatHeader formats a log header using the provided file name and line number. -func (l *loggingT) formatHeader(s severity, file string, line int) *buffer { - now := timeNow() - if line < 0 { - line = 0 // not a real line number, but acceptable to someDigits - } - if s > fatalLog { - s = infoLog // for safety. - } - buf := l.getBuffer() - - // Avoid Fprintf, for speed. The format is so simple that we can do it quickly by hand. - // It's worth about 3X. Fprintf is hard. - _, month, day := now.Date() - hour, minute, second := now.Clock() - // Lmmdd hh:mm:ss.uuuuuu threadid file:line] - buf.tmp[0] = severityChar[s] - buf.twoDigits(1, int(month)) - buf.twoDigits(3, day) - buf.tmp[5] = ' ' - buf.twoDigits(6, hour) - buf.tmp[8] = ':' - buf.twoDigits(9, minute) - buf.tmp[11] = ':' - buf.twoDigits(12, second) - buf.tmp[14] = '.' - buf.nDigits(6, 15, now.Nanosecond()/1000, '0') - buf.tmp[21] = ' ' - buf.nDigits(7, 22, pid, ' ') // TODO: should be TID - buf.tmp[29] = ' ' - buf.Write(buf.tmp[:30]) - buf.WriteString(file) - buf.tmp[0] = ':' - n := buf.someDigits(1, line) - buf.tmp[n+1] = ']' - buf.tmp[n+2] = ' ' - buf.Write(buf.tmp[:n+3]) - return buf -} - -// Some custom tiny helper functions to print the log header efficiently. - -const digits = "0123456789" - -// twoDigits formats a zero-prefixed two-digit integer at buf.tmp[i]. -func (buf *buffer) twoDigits(i, d int) { - buf.tmp[i+1] = digits[d%10] - d /= 10 - buf.tmp[i] = digits[d%10] -} - -// nDigits formats an n-digit integer at buf.tmp[i], -// padding with pad on the left. -// It assumes d >= 0. -func (buf *buffer) nDigits(n, i, d int, pad byte) { - j := n - 1 - for ; j >= 0 && d > 0; j-- { - buf.tmp[i+j] = digits[d%10] - d /= 10 - } - for ; j >= 0; j-- { - buf.tmp[i+j] = pad - } -} - -// someDigits formats a zero-prefixed variable-width integer at buf.tmp[i]. -func (buf *buffer) someDigits(i, d int) int { - // Print into the top, then copy down. We know there's space for at least - // a 10-digit number. - j := len(buf.tmp) - for { - j-- - buf.tmp[j] = digits[d%10] - d /= 10 - if d == 0 { - break - } - } - return copy(buf.tmp[i:], buf.tmp[j:]) -} - -func (l *loggingT) println(s severity, args ...interface{}) { - buf, file, line := l.header(s, 0) - fmt.Fprintln(buf, args...) - l.output(s, buf, file, line, false) -} - -func (l *loggingT) print(s severity, args ...interface{}) { - l.printDepth(s, 1, args...) -} - -func (l *loggingT) printDepth(s severity, depth int, args ...interface{}) { - buf, file, line := l.header(s, depth) - fmt.Fprint(buf, args...) - if buf.Bytes()[buf.Len()-1] != '\n' { - buf.WriteByte('\n') - } - l.output(s, buf, file, line, false) -} - -func (l *loggingT) printf(s severity, format string, args ...interface{}) { - buf, file, line := l.header(s, 0) - fmt.Fprintf(buf, format, args...) - if buf.Bytes()[buf.Len()-1] != '\n' { - buf.WriteByte('\n') - } - l.output(s, buf, file, line, false) -} - -// printWithFileLine behaves like print but uses the provided file and line number. If -// alsoLogToStderr is true, the log message always appears on standard error; it -// will also appear in the log file unless --logtostderr is set. -func (l *loggingT) printWithFileLine(s severity, file string, line int, alsoToStderr bool, args ...interface{}) { - buf := l.formatHeader(s, file, line) - fmt.Fprint(buf, args...) - if buf.Bytes()[buf.Len()-1] != '\n' { - buf.WriteByte('\n') - } - l.output(s, buf, file, line, alsoToStderr) -} - -// output writes the data to the log files and releases the buffer. -func (l *loggingT) output(s severity, buf *buffer, file string, line int, alsoToStderr bool) { - l.mu.Lock() - if l.traceLocation.isSet() { - if l.traceLocation.match(file, line) { - buf.Write(stacks(false)) - } - } - data := buf.Bytes() - if l.toStderr { - os.Stderr.Write(data) - } else { - if alsoToStderr || l.alsoToStderr || s >= l.stderrThreshold.get() { - os.Stderr.Write(data) - } - if l.file[s] == nil { - if err := l.createFiles(s); err != nil { - os.Stderr.Write(data) // Make sure the message appears somewhere. - l.exit(err) - } - } - switch s { - case fatalLog: - l.file[fatalLog].Write(data) - fallthrough - case errorLog: - l.file[errorLog].Write(data) - fallthrough - case warningLog: - l.file[warningLog].Write(data) - fallthrough - case infoLog: - l.file[infoLog].Write(data) - } - } - if s == fatalLog { - // If we got here via Exit rather than Fatal, print no stacks. - if atomic.LoadUint32(&fatalNoStacks) > 0 { - l.mu.Unlock() - timeoutFlush(10 * time.Second) - os.Exit(1) - } - // Dump all goroutine stacks before exiting. - // First, make sure we see the trace for the current goroutine on standard error. - // If -logtostderr has been specified, the loop below will do that anyway - // as the first stack in the full dump. - if !l.toStderr { - os.Stderr.Write(stacks(false)) - } - // Write the stack trace for all goroutines to the files. - trace := stacks(true) - logExitFunc = func(error) {} // If we get a write error, we'll still exit below. - for log := fatalLog; log >= infoLog; log-- { - if f := l.file[log]; f != nil { // Can be nil if -logtostderr is set. - f.Write(trace) - } - } - l.mu.Unlock() - timeoutFlush(10 * time.Second) - os.Exit(255) // C++ uses -1, which is silly because it's anded with 255 anyway. - } - l.putBuffer(buf) - l.mu.Unlock() - if stats := severityStats[s]; stats != nil { - atomic.AddInt64(&stats.lines, 1) - atomic.AddInt64(&stats.bytes, int64(len(data))) - } -} - -// timeoutFlush calls Flush and returns when it completes or after timeout -// elapses, whichever happens first. This is needed because the hooks invoked -// by Flush may deadlock when glog.Fatal is called from a hook that holds -// a lock. -func timeoutFlush(timeout time.Duration) { - done := make(chan bool, 1) - go func() { - Flush() // calls logging.lockAndFlushAll() - done <- true - }() - select { - case <-done: - case <-time.After(timeout): - fmt.Fprintln(os.Stderr, "glog: Flush took longer than", timeout) - } -} - -// stacks is a wrapper for runtime.Stack that attempts to recover the data for all goroutines. -func stacks(all bool) []byte { - // We don't know how big the traces are, so grow a few times if they don't fit. Start large, though. - n := 10000 - if all { - n = 100000 - } - var trace []byte - for i := 0; i < 5; i++ { - trace = make([]byte, n) - nbytes := runtime.Stack(trace, all) - if nbytes < len(trace) { - return trace[:nbytes] - } - n *= 2 - } - return trace -} - -// logExitFunc provides a simple mechanism to override the default behavior -// of exiting on error. Used in testing and to guarantee we reach a required exit -// for fatal logs. Instead, exit could be a function rather than a method but that -// would make its use clumsier. -var logExitFunc func(error) - -// exit is called if there is trouble creating or writing log files. -// It flushes the logs and exits the program; there's no point in hanging around. -// l.mu is held. -func (l *loggingT) exit(err error) { - fmt.Fprintf(os.Stderr, "log: exiting because of error: %s\n", err) - // If logExitFunc is set, we do that instead of exiting. - if logExitFunc != nil { - logExitFunc(err) - return - } - l.flushAll() - os.Exit(2) -} - -// syncBuffer joins a bufio.Writer to its underlying file, providing access to the -// file's Sync method and providing a wrapper for the Write method that provides log -// file rotation. There are conflicting methods, so the file cannot be embedded. -// l.mu is held for all its methods. -type syncBuffer struct { - logger *loggingT - *bufio.Writer - file *os.File - sev severity - nbytes uint64 // The number of bytes written to this file -} - -func (sb *syncBuffer) Sync() error { - return sb.file.Sync() -} - -func (sb *syncBuffer) Write(p []byte) (n int, err error) { - if sb.nbytes+uint64(len(p)) >= MaxSize { - if err := sb.rotateFile(time.Now()); err != nil { - sb.logger.exit(err) - } - } - n, err = sb.Writer.Write(p) - sb.nbytes += uint64(n) - if err != nil { - sb.logger.exit(err) - } - return -} - -// rotateFile closes the syncBuffer's file and starts a new one. -func (sb *syncBuffer) rotateFile(now time.Time) error { - if sb.file != nil { - sb.Flush() - sb.file.Close() - } - var err error - sb.file, _, err = create(severityName[sb.sev], now) - sb.nbytes = 0 - if err != nil { - return err - } - - sb.Writer = bufio.NewWriterSize(sb.file, bufferSize) - - // Write header. - var buf bytes.Buffer - fmt.Fprintf(&buf, "Log file created at: %s\n", now.Format("2006/01/02 15:04:05")) - fmt.Fprintf(&buf, "Running on machine: %s\n", host) - fmt.Fprintf(&buf, "Binary: Built with %s %s for %s/%s\n", runtime.Compiler, runtime.Version(), runtime.GOOS, runtime.GOARCH) - fmt.Fprintf(&buf, "Log line format: [IWEF]mmdd hh:mm:ss.uuuuuu threadid file:line] msg\n") - n, err := sb.file.Write(buf.Bytes()) - sb.nbytes += uint64(n) - return err -} - -// bufferSize sizes the buffer associated with each log file. It's large -// so that log records can accumulate without the logging thread blocking -// on disk I/O. The flushDaemon will block instead. -const bufferSize = 256 * 1024 - -// createFiles creates all the log files for severity from sev down to infoLog. -// l.mu is held. -func (l *loggingT) createFiles(sev severity) error { - now := time.Now() - // Files are created in decreasing severity order, so as soon as we find one - // has already been created, we can stop. - for s := sev; s >= infoLog && l.file[s] == nil; s-- { - sb := &syncBuffer{ - logger: l, - sev: s, - } - if err := sb.rotateFile(now); err != nil { - return err - } - l.file[s] = sb - } - return nil -} - -const flushInterval = 30 * time.Second - -// flushDaemon periodically flushes the log file buffers. -func (l *loggingT) flushDaemon() { - for _ = range time.NewTicker(flushInterval).C { - l.lockAndFlushAll() - } -} - -// lockAndFlushAll is like flushAll but locks l.mu first. -func (l *loggingT) lockAndFlushAll() { - l.mu.Lock() - l.flushAll() - l.mu.Unlock() -} - -// flushAll flushes all the logs and attempts to "sync" their data to disk. -// l.mu is held. -func (l *loggingT) flushAll() { - // Flush from fatal down, in case there's trouble flushing. - for s := fatalLog; s >= infoLog; s-- { - file := l.file[s] - if file != nil { - file.Flush() // ignore error - file.Sync() // ignore error - } - } -} - -// CopyStandardLogTo arranges for messages written to the Go "log" package's -// default logs to also appear in the Google logs for the named and lower -// severities. Subsequent changes to the standard log's default output location -// or format may break this behavior. -// -// Valid names are "INFO", "WARNING", "ERROR", and "FATAL". If the name is not -// recognized, CopyStandardLogTo panics. -func CopyStandardLogTo(name string) { - sev, ok := severityByName(name) - if !ok { - panic(fmt.Sprintf("log.CopyStandardLogTo(%q): unrecognized severity name", name)) - } - // Set a log format that captures the user's file and line: - // d.go:23: message - stdLog.SetFlags(stdLog.Lshortfile) - stdLog.SetOutput(logBridge(sev)) -} - -// logBridge provides the Write method that enables CopyStandardLogTo to connect -// Go's standard logs to the logs provided by this package. -type logBridge severity - -// Write parses the standard logging line and passes its components to the -// logger for severity(lb). -func (lb logBridge) Write(b []byte) (n int, err error) { - var ( - file = "???" - line = 1 - text string - ) - // Split "d.go:23: message" into "d.go", "23", and "message". - if parts := bytes.SplitN(b, []byte{':'}, 3); len(parts) != 3 || len(parts[0]) < 1 || len(parts[2]) < 1 { - text = fmt.Sprintf("bad log format: %s", b) - } else { - file = string(parts[0]) - text = string(parts[2][1:]) // skip leading space - line, err = strconv.Atoi(string(parts[1])) - if err != nil { - text = fmt.Sprintf("bad line number: %s", b) - line = 1 - } - } - // printWithFileLine with alsoToStderr=true, so standard log messages - // always appear on standard error. - logging.printWithFileLine(severity(lb), file, line, true, text) - return len(b), nil -} - -// setV computes and remembers the V level for a given PC -// when vmodule is enabled. -// File pattern matching takes the basename of the file, stripped -// of its .go suffix, and uses filepath.Match, which is a little more -// general than the *? matching used in C++. -// l.mu is held. -func (l *loggingT) setV(pc uintptr) Level { - fn := runtime.FuncForPC(pc) - file, _ := fn.FileLine(pc) - // The file is something like /a/b/c/d.go. We want just the d. - if strings.HasSuffix(file, ".go") { - file = file[:len(file)-3] - } - if slash := strings.LastIndex(file, "/"); slash >= 0 { - file = file[slash+1:] - } - for _, filter := range l.vmodule.filter { - if filter.match(file) { - l.vmap[pc] = filter.level - return filter.level - } - } - l.vmap[pc] = 0 - return 0 -} - -// Verbose is a boolean type that implements Infof (like Printf) etc. -// See the documentation of V for more information. -type Verbose bool - -// V reports whether verbosity at the call site is at least the requested level. -// The returned value is a boolean of type Verbose, which implements Info, Infoln -// and Infof. These methods will write to the Info log if called. -// Thus, one may write either -// if glog.V(2) { glog.Info("log this") } -// or -// glog.V(2).Info("log this") -// The second form is shorter but the first is cheaper if logging is off because it does -// not evaluate its arguments. -// -// Whether an individual call to V generates a log record depends on the setting of -// the -v and --vmodule flags; both are off by default. If the level in the call to -// V is at least the value of -v, or of -vmodule for the source file containing the -// call, the V call will log. -func V(level Level) Verbose { - // This function tries hard to be cheap unless there's work to do. - // The fast path is two atomic loads and compares. - - // Here is a cheap but safe test to see if V logging is enabled globally. - if logging.verbosity.get() >= level { - return Verbose(true) - } - - // It's off globally but it vmodule may still be set. - // Here is another cheap but safe test to see if vmodule is enabled. - if atomic.LoadInt32(&logging.filterLength) > 0 { - // Now we need a proper lock to use the logging structure. The pcs field - // is shared so we must lock before accessing it. This is fairly expensive, - // but if V logging is enabled we're slow anyway. - logging.mu.Lock() - defer logging.mu.Unlock() - if runtime.Callers(2, logging.pcs[:]) == 0 { - return Verbose(false) - } - v, ok := logging.vmap[logging.pcs[0]] - if !ok { - v = logging.setV(logging.pcs[0]) - } - return Verbose(v >= level) - } - return Verbose(false) -} - -// Info is equivalent to the global Info function, guarded by the value of v. -// See the documentation of V for usage. -func (v Verbose) Info(args ...interface{}) { - if v { - logging.print(infoLog, args...) - } -} - -// Infoln is equivalent to the global Infoln function, guarded by the value of v. -// See the documentation of V for usage. -func (v Verbose) Infoln(args ...interface{}) { - if v { - logging.println(infoLog, args...) - } -} - -// Infof is equivalent to the global Infof function, guarded by the value of v. -// See the documentation of V for usage. -func (v Verbose) Infof(format string, args ...interface{}) { - if v { - logging.printf(infoLog, format, args...) - } -} - -// Info logs to the INFO log. -// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. -func Info(args ...interface{}) { - logging.print(infoLog, args...) -} - -// InfoDepth acts as Info but uses depth to determine which call frame to log. -// InfoDepth(0, "msg") is the same as Info("msg"). -func InfoDepth(depth int, args ...interface{}) { - logging.printDepth(infoLog, depth, args...) -} - -// Infoln logs to the INFO log. -// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. -func Infoln(args ...interface{}) { - logging.println(infoLog, args...) -} - -// Infof logs to the INFO log. -// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. -func Infof(format string, args ...interface{}) { - logging.printf(infoLog, format, args...) -} - -// Warning logs to the WARNING and INFO logs. -// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. -func Warning(args ...interface{}) { - logging.print(warningLog, args...) -} - -// WarningDepth acts as Warning but uses depth to determine which call frame to log. -// WarningDepth(0, "msg") is the same as Warning("msg"). -func WarningDepth(depth int, args ...interface{}) { - logging.printDepth(warningLog, depth, args...) -} - -// Warningln logs to the WARNING and INFO logs. -// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. -func Warningln(args ...interface{}) { - logging.println(warningLog, args...) -} - -// Warningf logs to the WARNING and INFO logs. -// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. -func Warningf(format string, args ...interface{}) { - logging.printf(warningLog, format, args...) -} - -// Error logs to the ERROR, WARNING, and INFO logs. -// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. -func Error(args ...interface{}) { - logging.print(errorLog, args...) -} - -// ErrorDepth acts as Error but uses depth to determine which call frame to log. -// ErrorDepth(0, "msg") is the same as Error("msg"). -func ErrorDepth(depth int, args ...interface{}) { - logging.printDepth(errorLog, depth, args...) -} - -// Errorln logs to the ERROR, WARNING, and INFO logs. -// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. -func Errorln(args ...interface{}) { - logging.println(errorLog, args...) -} - -// Errorf logs to the ERROR, WARNING, and INFO logs. -// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. -func Errorf(format string, args ...interface{}) { - logging.printf(errorLog, format, args...) -} - -// Fatal logs to the FATAL, ERROR, WARNING, and INFO logs, -// including a stack trace of all running goroutines, then calls os.Exit(255). -// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. -func Fatal(args ...interface{}) { - logging.print(fatalLog, args...) -} - -// FatalDepth acts as Fatal but uses depth to determine which call frame to log. -// FatalDepth(0, "msg") is the same as Fatal("msg"). -func FatalDepth(depth int, args ...interface{}) { - logging.printDepth(fatalLog, depth, args...) -} - -// Fatalln logs to the FATAL, ERROR, WARNING, and INFO logs, -// including a stack trace of all running goroutines, then calls os.Exit(255). -// Arguments are handled in the manner of fmt.Println; a newline is appended if missing. -func Fatalln(args ...interface{}) { - logging.println(fatalLog, args...) -} - -// Fatalf logs to the FATAL, ERROR, WARNING, and INFO logs, -// including a stack trace of all running goroutines, then calls os.Exit(255). -// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. -func Fatalf(format string, args ...interface{}) { - logging.printf(fatalLog, format, args...) -} - -// fatalNoStacks is non-zero if we are to exit without dumping goroutine stacks. -// It allows Exit and relatives to use the Fatal logs. -var fatalNoStacks uint32 - -// Exit logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). -// Arguments are handled in the manner of fmt.Print; a newline is appended if missing. -func Exit(args ...interface{}) { - atomic.StoreUint32(&fatalNoStacks, 1) - logging.print(fatalLog, args...) -} - -// ExitDepth acts as Exit but uses depth to determine which call frame to log. -// ExitDepth(0, "msg") is the same as Exit("msg"). -func ExitDepth(depth int, args ...interface{}) { - atomic.StoreUint32(&fatalNoStacks, 1) - logging.printDepth(fatalLog, depth, args...) -} - -// Exitln logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). -func Exitln(args ...interface{}) { - atomic.StoreUint32(&fatalNoStacks, 1) - logging.println(fatalLog, args...) -} - -// Exitf logs to the FATAL, ERROR, WARNING, and INFO logs, then calls os.Exit(1). -// Arguments are handled in the manner of fmt.Printf; a newline is appended if missing. -func Exitf(format string, args ...interface{}) { - atomic.StoreUint32(&fatalNoStacks, 1) - logging.printf(fatalLog, format, args...) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog_file.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog_file.go deleted file mode 100644 index 65075d2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/glog/glog_file.go +++ /dev/null @@ -1,124 +0,0 @@ -// Go support for leveled logs, analogous to https://code.google.com/p/google-glog/ -// -// Copyright 2013 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. - -// File I/O for logs. - -package glog - -import ( - "errors" - "flag" - "fmt" - "os" - "os/user" - "path/filepath" - "strings" - "sync" - "time" -) - -// MaxSize is the maximum size of a log file in bytes. -var MaxSize uint64 = 1024 * 1024 * 1800 - -// logDirs lists the candidate directories for new log files. -var logDirs []string - -// If non-empty, overrides the choice of directory in which to write logs. -// See createLogDirs for the full list of possible destinations. -var logDir = flag.String("log_dir", "", "If non-empty, write log files in this directory") - -func createLogDirs() { - if *logDir != "" { - logDirs = append(logDirs, *logDir) - } - logDirs = append(logDirs, os.TempDir()) -} - -var ( - pid = os.Getpid() - program = filepath.Base(os.Args[0]) - host = "unknownhost" - userName = "unknownuser" -) - -func init() { - h, err := os.Hostname() - if err == nil { - host = shortHostname(h) - } - - current, err := user.Current() - if err == nil { - userName = current.Username - } - - // Sanitize userName since it may contain filepath separators on Windows. - userName = strings.Replace(userName, `\`, "_", -1) -} - -// shortHostname returns its argument, truncating at the first period. -// For instance, given "www.google.com" it returns "www". -func shortHostname(hostname string) string { - if i := strings.Index(hostname, "."); i >= 0 { - return hostname[:i] - } - return hostname -} - -// logName returns a new log file name containing tag, with start time t, and -// the name for the symlink for tag. -func logName(tag string, t time.Time) (name, link string) { - name = fmt.Sprintf("%s.%s.%s.log.%s.%04d%02d%02d-%02d%02d%02d.%d", - program, - host, - userName, - tag, - t.Year(), - t.Month(), - t.Day(), - t.Hour(), - t.Minute(), - t.Second(), - pid) - return name, program + "." + tag -} - -var onceLogDirs sync.Once - -// create creates a new log file and returns the file and its filename, which -// contains tag ("INFO", "FATAL", etc.) and t. If the file is created -// successfully, create also attempts to update the symlink for that tag, ignoring -// errors. -func create(tag string, t time.Time) (f *os.File, filename string, err error) { - onceLogDirs.Do(createLogDirs) - if len(logDirs) == 0 { - return nil, "", errors.New("log: no log dirs") - } - name, link := logName(tag, t) - var lastErr error - for _, dir := range logDirs { - fname := filepath.Join(dir, name) - f, err := os.Create(fname) - if err == nil { - symlink := filepath.Join(dir, link) - os.Remove(symlink) // ignore err - os.Symlink(name, symlink) // ignore err - return f, fname, nil - } - lastErr = err - } - return nil, "", fmt.Errorf("log: cannot create log: %v", lastErr) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/Makefile b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/Makefile deleted file mode 100644 index e2e0651..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/Makefile +++ /dev/null @@ -1,43 +0,0 @@ -# Go support for Protocol Buffers - Google's data interchange format -# -# Copyright 2010 The Go Authors. All rights reserved. -# https://github.com/golang/protobuf -# -# Redistribution and use in source and binary forms, with or without -# modification, are permitted provided that the following conditions are -# met: -# -# * Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. -# * Redistributions in binary form must reproduce the above -# copyright notice, this list of conditions and the following disclaimer -# in the documentation and/or other materials provided with the -# distribution. -# * Neither the name of Google Inc. nor the names of its -# contributors may be used to endorse or promote products derived from -# this software without specific prior written permission. -# -# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -install: - go install - -test: install generate-test-pbs - go test - - -generate-test-pbs: - make install - make -C testdata - protoc --go_out=Mtestdata/test.proto=github.com/golang/protobuf/proto/testdata,Mgoogle/protobuf/any.proto=github.com/golang/protobuf/ptypes/any:. proto3_proto/proto3.proto - make diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/clone.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/clone.go deleted file mode 100644 index e392575..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/clone.go +++ /dev/null @@ -1,229 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2011 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// Protocol buffer deep copy and merge. -// TODO: RawMessage. - -package proto - -import ( - "log" - "reflect" - "strings" -) - -// Clone returns a deep copy of a protocol buffer. -func Clone(pb Message) Message { - in := reflect.ValueOf(pb) - if in.IsNil() { - return pb - } - - out := reflect.New(in.Type().Elem()) - // out is empty so a merge is a deep copy. - mergeStruct(out.Elem(), in.Elem()) - return out.Interface().(Message) -} - -// Merge merges src into dst. -// Required and optional fields that are set in src will be set to that value in dst. -// Elements of repeated fields will be appended. -// Merge panics if src and dst are not the same type, or if dst is nil. -func Merge(dst, src Message) { - in := reflect.ValueOf(src) - out := reflect.ValueOf(dst) - if out.IsNil() { - panic("proto: nil destination") - } - if in.Type() != out.Type() { - // Explicit test prior to mergeStruct so that mistyped nils will fail - panic("proto: type mismatch") - } - if in.IsNil() { - // Merging nil into non-nil is a quiet no-op - return - } - mergeStruct(out.Elem(), in.Elem()) -} - -func mergeStruct(out, in reflect.Value) { - sprop := GetProperties(in.Type()) - for i := 0; i < in.NumField(); i++ { - f := in.Type().Field(i) - if strings.HasPrefix(f.Name, "XXX_") { - continue - } - mergeAny(out.Field(i), in.Field(i), false, sprop.Prop[i]) - } - - if emIn, ok := extendable(in.Addr().Interface()); ok { - emOut, _ := extendable(out.Addr().Interface()) - mIn, muIn := emIn.extensionsRead() - if mIn != nil { - mOut := emOut.extensionsWrite() - muIn.Lock() - mergeExtension(mOut, mIn) - muIn.Unlock() - } - } - - uf := in.FieldByName("XXX_unrecognized") - if !uf.IsValid() { - return - } - uin := uf.Bytes() - if len(uin) > 0 { - out.FieldByName("XXX_unrecognized").SetBytes(append([]byte(nil), uin...)) - } -} - -// mergeAny performs a merge between two values of the same type. -// viaPtr indicates whether the values were indirected through a pointer (implying proto2). -// prop is set if this is a struct field (it may be nil). -func mergeAny(out, in reflect.Value, viaPtr bool, prop *Properties) { - if in.Type() == protoMessageType { - if !in.IsNil() { - if out.IsNil() { - out.Set(reflect.ValueOf(Clone(in.Interface().(Message)))) - } else { - Merge(out.Interface().(Message), in.Interface().(Message)) - } - } - return - } - switch in.Kind() { - case reflect.Bool, reflect.Float32, reflect.Float64, reflect.Int32, reflect.Int64, - reflect.String, reflect.Uint32, reflect.Uint64: - if !viaPtr && isProto3Zero(in) { - return - } - out.Set(in) - case reflect.Interface: - // Probably a oneof field; copy non-nil values. - if in.IsNil() { - return - } - // Allocate destination if it is not set, or set to a different type. - // Otherwise we will merge as normal. - if out.IsNil() || out.Elem().Type() != in.Elem().Type() { - out.Set(reflect.New(in.Elem().Elem().Type())) // interface -> *T -> T -> new(T) - } - mergeAny(out.Elem(), in.Elem(), false, nil) - case reflect.Map: - if in.Len() == 0 { - return - } - if out.IsNil() { - out.Set(reflect.MakeMap(in.Type())) - } - // For maps with value types of *T or []byte we need to deep copy each value. - elemKind := in.Type().Elem().Kind() - for _, key := range in.MapKeys() { - var val reflect.Value - switch elemKind { - case reflect.Ptr: - val = reflect.New(in.Type().Elem().Elem()) - mergeAny(val, in.MapIndex(key), false, nil) - case reflect.Slice: - val = in.MapIndex(key) - val = reflect.ValueOf(append([]byte{}, val.Bytes()...)) - default: - val = in.MapIndex(key) - } - out.SetMapIndex(key, val) - } - case reflect.Ptr: - if in.IsNil() { - return - } - if out.IsNil() { - out.Set(reflect.New(in.Elem().Type())) - } - mergeAny(out.Elem(), in.Elem(), true, nil) - case reflect.Slice: - if in.IsNil() { - return - } - if in.Type().Elem().Kind() == reflect.Uint8 { - // []byte is a scalar bytes field, not a repeated field. - - // Edge case: if this is in a proto3 message, a zero length - // bytes field is considered the zero value, and should not - // be merged. - if prop != nil && prop.proto3 && in.Len() == 0 { - return - } - - // Make a deep copy. - // Append to []byte{} instead of []byte(nil) so that we never end up - // with a nil result. - out.SetBytes(append([]byte{}, in.Bytes()...)) - return - } - n := in.Len() - if out.IsNil() { - out.Set(reflect.MakeSlice(in.Type(), 0, n)) - } - switch in.Type().Elem().Kind() { - case reflect.Bool, reflect.Float32, reflect.Float64, reflect.Int32, reflect.Int64, - reflect.String, reflect.Uint32, reflect.Uint64: - out.Set(reflect.AppendSlice(out, in)) - default: - for i := 0; i < n; i++ { - x := reflect.Indirect(reflect.New(in.Type().Elem())) - mergeAny(x, in.Index(i), false, nil) - out.Set(reflect.Append(out, x)) - } - } - case reflect.Struct: - mergeStruct(out, in) - default: - // unknown type, so not a protocol buffer - log.Printf("proto: don't know how to copy %v", in) - } -} - -func mergeExtension(out, in map[int32]Extension) { - for extNum, eIn := range in { - eOut := Extension{desc: eIn.desc} - if eIn.value != nil { - v := reflect.New(reflect.TypeOf(eIn.value)).Elem() - mergeAny(v, reflect.ValueOf(eIn.value), false, nil) - eOut.value = v.Interface() - } - if eIn.enc != nil { - eOut.enc = make([]byte, len(eIn.enc)) - copy(eOut.enc, eIn.enc) - } - - out[extNum] = eOut - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/decode.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/decode.go deleted file mode 100644 index 07288a2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/decode.go +++ /dev/null @@ -1,869 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for decoding protocol buffer data to construct in-memory representations. - */ - -import ( - "errors" - "fmt" - "io" - "os" - "reflect" -) - -// errOverflow is returned when an integer is too large to be represented. -var errOverflow = errors.New("proto: integer overflow") - -// ErrInternalBadWireType is returned by generated code when an incorrect -// wire type is encountered. It does not get returned to user code. -var ErrInternalBadWireType = errors.New("proto: internal error: bad wiretype for oneof") - -// The fundamental decoders that interpret bytes on the wire. -// Those that take integer types all return uint64 and are -// therefore of type valueDecoder. - -// DecodeVarint reads a varint-encoded integer from the slice. -// It returns the integer and the number of bytes consumed, or -// zero if there is not enough. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func DecodeVarint(buf []byte) (x uint64, n int) { - // x, n already 0 - for shift := uint(0); shift < 64; shift += 7 { - if n >= len(buf) { - return 0, 0 - } - b := uint64(buf[n]) - n++ - x |= (b & 0x7F) << shift - if (b & 0x80) == 0 { - return x, n - } - } - - // The number is too large to represent in a 64-bit value. - return 0, 0 -} - -// DecodeVarint reads a varint-encoded integer from the Buffer. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func (p *Buffer) DecodeVarint() (x uint64, err error) { - // x, err already 0 - - i := p.index - l := len(p.buf) - - for shift := uint(0); shift < 64; shift += 7 { - if i >= l { - err = io.ErrUnexpectedEOF - return - } - b := p.buf[i] - i++ - x |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - p.index = i - return - } - } - - // The number is too large to represent in a 64-bit value. - err = errOverflow - return -} - -// DecodeFixed64 reads a 64-bit integer from the Buffer. -// This is the format for the -// fixed64, sfixed64, and double protocol buffer types. -func (p *Buffer) DecodeFixed64() (x uint64, err error) { - // x, err already 0 - i := p.index + 8 - if i < 0 || i > len(p.buf) { - err = io.ErrUnexpectedEOF - return - } - p.index = i - - x = uint64(p.buf[i-8]) - x |= uint64(p.buf[i-7]) << 8 - x |= uint64(p.buf[i-6]) << 16 - x |= uint64(p.buf[i-5]) << 24 - x |= uint64(p.buf[i-4]) << 32 - x |= uint64(p.buf[i-3]) << 40 - x |= uint64(p.buf[i-2]) << 48 - x |= uint64(p.buf[i-1]) << 56 - return -} - -// DecodeFixed32 reads a 32-bit integer from the Buffer. -// This is the format for the -// fixed32, sfixed32, and float protocol buffer types. -func (p *Buffer) DecodeFixed32() (x uint64, err error) { - // x, err already 0 - i := p.index + 4 - if i < 0 || i > len(p.buf) { - err = io.ErrUnexpectedEOF - return - } - p.index = i - - x = uint64(p.buf[i-4]) - x |= uint64(p.buf[i-3]) << 8 - x |= uint64(p.buf[i-2]) << 16 - x |= uint64(p.buf[i-1]) << 24 - return -} - -// DecodeZigzag64 reads a zigzag-encoded 64-bit integer -// from the Buffer. -// This is the format used for the sint64 protocol buffer type. -func (p *Buffer) DecodeZigzag64() (x uint64, err error) { - x, err = p.DecodeVarint() - if err != nil { - return - } - x = (x >> 1) ^ uint64((int64(x&1)<<63)>>63) - return -} - -// DecodeZigzag32 reads a zigzag-encoded 32-bit integer -// from the Buffer. -// This is the format used for the sint32 protocol buffer type. -func (p *Buffer) DecodeZigzag32() (x uint64, err error) { - x, err = p.DecodeVarint() - if err != nil { - return - } - x = uint64((uint32(x) >> 1) ^ uint32((int32(x&1)<<31)>>31)) - return -} - -// These are not ValueDecoders: they produce an array of bytes or a string. -// bytes, embedded messages - -// DecodeRawBytes reads a count-delimited byte buffer from the Buffer. -// This is the format used for the bytes protocol buffer -// type and for embedded messages. -func (p *Buffer) DecodeRawBytes(alloc bool) (buf []byte, err error) { - n, err := p.DecodeVarint() - if err != nil { - return nil, err - } - - nb := int(n) - if nb < 0 { - return nil, fmt.Errorf("proto: bad byte length %d", nb) - } - end := p.index + nb - if end < p.index || end > len(p.buf) { - return nil, io.ErrUnexpectedEOF - } - - if !alloc { - // todo: check if can get more uses of alloc=false - buf = p.buf[p.index:end] - p.index += nb - return - } - - buf = make([]byte, nb) - copy(buf, p.buf[p.index:]) - p.index += nb - return -} - -// DecodeStringBytes reads an encoded string from the Buffer. -// This is the format used for the proto2 string type. -func (p *Buffer) DecodeStringBytes() (s string, err error) { - buf, err := p.DecodeRawBytes(false) - if err != nil { - return - } - return string(buf), nil -} - -// Skip the next item in the buffer. Its wire type is decoded and presented as an argument. -// If the protocol buffer has extensions, and the field matches, add it as an extension. -// Otherwise, if the XXX_unrecognized field exists, append the skipped data there. -func (o *Buffer) skipAndSave(t reflect.Type, tag, wire int, base structPointer, unrecField field) error { - oi := o.index - - err := o.skip(t, tag, wire) - if err != nil { - return err - } - - if !unrecField.IsValid() { - return nil - } - - ptr := structPointer_Bytes(base, unrecField) - - // Add the skipped field to struct field - obuf := o.buf - - o.buf = *ptr - o.EncodeVarint(uint64(tag<<3 | wire)) - *ptr = append(o.buf, obuf[oi:o.index]...) - - o.buf = obuf - - return nil -} - -// Skip the next item in the buffer. Its wire type is decoded and presented as an argument. -func (o *Buffer) skip(t reflect.Type, tag, wire int) error { - - var u uint64 - var err error - - switch wire { - case WireVarint: - _, err = o.DecodeVarint() - case WireFixed64: - _, err = o.DecodeFixed64() - case WireBytes: - _, err = o.DecodeRawBytes(false) - case WireFixed32: - _, err = o.DecodeFixed32() - case WireStartGroup: - for { - u, err = o.DecodeVarint() - if err != nil { - break - } - fwire := int(u & 0x7) - if fwire == WireEndGroup { - break - } - ftag := int(u >> 3) - err = o.skip(t, ftag, fwire) - if err != nil { - break - } - } - default: - err = fmt.Errorf("proto: can't skip unknown wire type %d for %s", wire, t) - } - return err -} - -// Unmarshaler is the interface representing objects that can -// unmarshal themselves. The method should reset the receiver before -// decoding starts. The argument points to data that may be -// overwritten, so implementations should not keep references to the -// buffer. -type Unmarshaler interface { - Unmarshal([]byte) error -} - -// Unmarshal parses the protocol buffer representation in buf and places the -// decoded result in pb. If the struct underlying pb does not match -// the data in buf, the results can be unpredictable. -// -// Unmarshal resets pb before starting to unmarshal, so any -// existing data in pb is always removed. Use UnmarshalMerge -// to preserve and append to existing data. -func Unmarshal(buf []byte, pb Message) error { - pb.Reset() - return UnmarshalMerge(buf, pb) -} - -// UnmarshalMerge parses the protocol buffer representation in buf and -// writes the decoded result to pb. If the struct underlying pb does not match -// the data in buf, the results can be unpredictable. -// -// UnmarshalMerge merges into existing data in pb. -// Most code should use Unmarshal instead. -func UnmarshalMerge(buf []byte, pb Message) error { - // If the object can unmarshal itself, let it. - if u, ok := pb.(Unmarshaler); ok { - return u.Unmarshal(buf) - } - return NewBuffer(buf).Unmarshal(pb) -} - -// DecodeMessage reads a count-delimited message from the Buffer. -func (p *Buffer) DecodeMessage(pb Message) error { - enc, err := p.DecodeRawBytes(false) - if err != nil { - return err - } - return NewBuffer(enc).Unmarshal(pb) -} - -// DecodeGroup reads a tag-delimited group from the Buffer. -func (p *Buffer) DecodeGroup(pb Message) error { - typ, base, err := getbase(pb) - if err != nil { - return err - } - return p.unmarshalType(typ.Elem(), GetProperties(typ.Elem()), true, base) -} - -// Unmarshal parses the protocol buffer representation in the -// Buffer and places the decoded result in pb. If the struct -// underlying pb does not match the data in the buffer, the results can be -// unpredictable. -func (p *Buffer) Unmarshal(pb Message) error { - // If the object can unmarshal itself, let it. - if u, ok := pb.(Unmarshaler); ok { - err := u.Unmarshal(p.buf[p.index:]) - p.index = len(p.buf) - return err - } - - typ, base, err := getbase(pb) - if err != nil { - return err - } - - err = p.unmarshalType(typ.Elem(), GetProperties(typ.Elem()), false, base) - - if collectStats { - stats.Decode++ - } - - return err -} - -// unmarshalType does the work of unmarshaling a structure. -func (o *Buffer) unmarshalType(st reflect.Type, prop *StructProperties, is_group bool, base structPointer) error { - var state errorState - required, reqFields := prop.reqCount, uint64(0) - - var err error - for err == nil && o.index < len(o.buf) { - oi := o.index - var u uint64 - u, err = o.DecodeVarint() - if err != nil { - break - } - wire := int(u & 0x7) - if wire == WireEndGroup { - if is_group { - return nil // input is satisfied - } - return fmt.Errorf("proto: %s: wiretype end group for non-group", st) - } - tag := int(u >> 3) - if tag <= 0 { - return fmt.Errorf("proto: %s: illegal tag %d (wire type %d)", st, tag, wire) - } - fieldnum, ok := prop.decoderTags.get(tag) - if !ok { - // Maybe it's an extension? - if prop.extendable { - if e, _ := extendable(structPointer_Interface(base, st)); isExtensionField(e, int32(tag)) { - if err = o.skip(st, tag, wire); err == nil { - extmap := e.extensionsWrite() - ext := extmap[int32(tag)] // may be missing - ext.enc = append(ext.enc, o.buf[oi:o.index]...) - extmap[int32(tag)] = ext - } - continue - } - } - // Maybe it's a oneof? - if prop.oneofUnmarshaler != nil { - m := structPointer_Interface(base, st).(Message) - // First return value indicates whether tag is a oneof field. - ok, err = prop.oneofUnmarshaler(m, tag, wire, o) - if err == ErrInternalBadWireType { - // Map the error to something more descriptive. - // Do the formatting here to save generated code space. - err = fmt.Errorf("bad wiretype for oneof field in %T", m) - } - if ok { - continue - } - } - err = o.skipAndSave(st, tag, wire, base, prop.unrecField) - continue - } - p := prop.Prop[fieldnum] - - if p.dec == nil { - fmt.Fprintf(os.Stderr, "proto: no protobuf decoder for %s.%s\n", st, st.Field(fieldnum).Name) - continue - } - dec := p.dec - if wire != WireStartGroup && wire != p.WireType { - if wire == WireBytes && p.packedDec != nil { - // a packable field - dec = p.packedDec - } else { - err = fmt.Errorf("proto: bad wiretype for field %s.%s: got wiretype %d, want %d", st, st.Field(fieldnum).Name, wire, p.WireType) - continue - } - } - decErr := dec(o, p, base) - if decErr != nil && !state.shouldContinue(decErr, p) { - err = decErr - } - if err == nil && p.Required { - // Successfully decoded a required field. - if tag <= 64 { - // use bitmap for fields 1-64 to catch field reuse. - var mask uint64 = 1 << uint64(tag-1) - if reqFields&mask == 0 { - // new required field - reqFields |= mask - required-- - } - } else { - // This is imprecise. It can be fooled by a required field - // with a tag > 64 that is encoded twice; that's very rare. - // A fully correct implementation would require allocating - // a data structure, which we would like to avoid. - required-- - } - } - } - if err == nil { - if is_group { - return io.ErrUnexpectedEOF - } - if state.err != nil { - return state.err - } - if required > 0 { - // Not enough information to determine the exact field. If we use extra - // CPU, we could determine the field only if the missing required field - // has a tag <= 64 and we check reqFields. - return &RequiredNotSetError{"{Unknown}"} - } - } - return err -} - -// Individual type decoders -// For each, -// u is the decoded value, -// v is a pointer to the field (pointer) in the struct - -// Sizes of the pools to allocate inside the Buffer. -// The goal is modest amortization and allocation -// on at least 16-byte boundaries. -const ( - boolPoolSize = 16 - uint32PoolSize = 8 - uint64PoolSize = 4 -) - -// Decode a bool. -func (o *Buffer) dec_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - if len(o.bools) == 0 { - o.bools = make([]bool, boolPoolSize) - } - o.bools[0] = u != 0 - *structPointer_Bool(base, p.field) = &o.bools[0] - o.bools = o.bools[1:] - return nil -} - -func (o *Buffer) dec_proto3_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - *structPointer_BoolVal(base, p.field) = u != 0 - return nil -} - -// Decode an int32. -func (o *Buffer) dec_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word32_Set(structPointer_Word32(base, p.field), o, uint32(u)) - return nil -} - -func (o *Buffer) dec_proto3_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word32Val_Set(structPointer_Word32Val(base, p.field), uint32(u)) - return nil -} - -// Decode an int64. -func (o *Buffer) dec_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word64_Set(structPointer_Word64(base, p.field), o, u) - return nil -} - -func (o *Buffer) dec_proto3_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - word64Val_Set(structPointer_Word64Val(base, p.field), o, u) - return nil -} - -// Decode a string. -func (o *Buffer) dec_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - *structPointer_String(base, p.field) = &s - return nil -} - -func (o *Buffer) dec_proto3_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - *structPointer_StringVal(base, p.field) = s - return nil -} - -// Decode a slice of bytes ([]byte). -func (o *Buffer) dec_slice_byte(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - *structPointer_Bytes(base, p.field) = b - return nil -} - -// Decode a slice of bools ([]bool). -func (o *Buffer) dec_slice_bool(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - v := structPointer_BoolSlice(base, p.field) - *v = append(*v, u != 0) - return nil -} - -// Decode a slice of bools ([]bool) in packed format. -func (o *Buffer) dec_slice_packed_bool(p *Properties, base structPointer) error { - v := structPointer_BoolSlice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded bools - fin := o.index + nb - if fin < o.index { - return errOverflow - } - - y := *v - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - y = append(y, u != 0) - } - - *v = y - return nil -} - -// Decode a slice of int32s ([]int32). -func (o *Buffer) dec_slice_int32(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - structPointer_Word32Slice(base, p.field).Append(uint32(u)) - return nil -} - -// Decode a slice of int32s ([]int32) in packed format. -func (o *Buffer) dec_slice_packed_int32(p *Properties, base structPointer) error { - v := structPointer_Word32Slice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded int32s - - fin := o.index + nb - if fin < o.index { - return errOverflow - } - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - v.Append(uint32(u)) - } - return nil -} - -// Decode a slice of int64s ([]int64). -func (o *Buffer) dec_slice_int64(p *Properties, base structPointer) error { - u, err := p.valDec(o) - if err != nil { - return err - } - - structPointer_Word64Slice(base, p.field).Append(u) - return nil -} - -// Decode a slice of int64s ([]int64) in packed format. -func (o *Buffer) dec_slice_packed_int64(p *Properties, base structPointer) error { - v := structPointer_Word64Slice(base, p.field) - - nn, err := o.DecodeVarint() - if err != nil { - return err - } - nb := int(nn) // number of bytes of encoded int64s - - fin := o.index + nb - if fin < o.index { - return errOverflow - } - for o.index < fin { - u, err := p.valDec(o) - if err != nil { - return err - } - v.Append(u) - } - return nil -} - -// Decode a slice of strings ([]string). -func (o *Buffer) dec_slice_string(p *Properties, base structPointer) error { - s, err := o.DecodeStringBytes() - if err != nil { - return err - } - v := structPointer_StringSlice(base, p.field) - *v = append(*v, s) - return nil -} - -// Decode a slice of slice of bytes ([][]byte). -func (o *Buffer) dec_slice_slice_byte(p *Properties, base structPointer) error { - b, err := o.DecodeRawBytes(true) - if err != nil { - return err - } - v := structPointer_BytesSlice(base, p.field) - *v = append(*v, b) - return nil -} - -// Decode a map field. -func (o *Buffer) dec_new_map(p *Properties, base structPointer) error { - raw, err := o.DecodeRawBytes(false) - if err != nil { - return err - } - oi := o.index // index at the end of this map entry - o.index -= len(raw) // move buffer back to start of map entry - - mptr := structPointer_NewAt(base, p.field, p.mtype) // *map[K]V - if mptr.Elem().IsNil() { - mptr.Elem().Set(reflect.MakeMap(mptr.Type().Elem())) - } - v := mptr.Elem() // map[K]V - - // Prepare addressable doubly-indirect placeholders for the key and value types. - // See enc_new_map for why. - keyptr := reflect.New(reflect.PtrTo(p.mtype.Key())).Elem() // addressable *K - keybase := toStructPointer(keyptr.Addr()) // **K - - var valbase structPointer - var valptr reflect.Value - switch p.mtype.Elem().Kind() { - case reflect.Slice: - // []byte - var dummy []byte - valptr = reflect.ValueOf(&dummy) // *[]byte - valbase = toStructPointer(valptr) // *[]byte - case reflect.Ptr: - // message; valptr is **Msg; need to allocate the intermediate pointer - valptr = reflect.New(reflect.PtrTo(p.mtype.Elem())).Elem() // addressable *V - valptr.Set(reflect.New(valptr.Type().Elem())) - valbase = toStructPointer(valptr) - default: - // everything else - valptr = reflect.New(reflect.PtrTo(p.mtype.Elem())).Elem() // addressable *V - valbase = toStructPointer(valptr.Addr()) // **V - } - - // Decode. - // This parses a restricted wire format, namely the encoding of a message - // with two fields. See enc_new_map for the format. - for o.index < oi { - // tagcode for key and value properties are always a single byte - // because they have tags 1 and 2. - tagcode := o.buf[o.index] - o.index++ - switch tagcode { - case p.mkeyprop.tagcode[0]: - if err := p.mkeyprop.dec(o, p.mkeyprop, keybase); err != nil { - return err - } - case p.mvalprop.tagcode[0]: - if err := p.mvalprop.dec(o, p.mvalprop, valbase); err != nil { - return err - } - default: - // TODO: Should we silently skip this instead? - return fmt.Errorf("proto: bad map data tag %d", raw[0]) - } - } - keyelem, valelem := keyptr.Elem(), valptr.Elem() - if !keyelem.IsValid() { - keyelem = reflect.Zero(p.mtype.Key()) - } - if !valelem.IsValid() { - valelem = reflect.Zero(p.mtype.Elem()) - } - - v.SetMapIndex(keyelem, valelem) - return nil -} - -// Decode a group. -func (o *Buffer) dec_struct_group(p *Properties, base structPointer) error { - bas := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(bas) { - // allocate new nested message - bas = toStructPointer(reflect.New(p.stype)) - structPointer_SetStructPointer(base, p.field, bas) - } - return o.unmarshalType(p.stype, p.sprop, true, bas) -} - -// Decode an embedded message. -func (o *Buffer) dec_struct_message(p *Properties, base structPointer) (err error) { - raw, e := o.DecodeRawBytes(false) - if e != nil { - return e - } - - bas := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(bas) { - // allocate new nested message - bas = toStructPointer(reflect.New(p.stype)) - structPointer_SetStructPointer(base, p.field, bas) - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - iv := structPointer_Interface(bas, p.stype) - return iv.(Unmarshaler).Unmarshal(raw) - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - err = o.unmarshalType(p.stype, p.sprop, false, bas) - o.buf = obuf - o.index = oi - - return err -} - -// Decode a slice of embedded messages. -func (o *Buffer) dec_slice_struct_message(p *Properties, base structPointer) error { - return o.dec_slice_struct(p, false, base) -} - -// Decode a slice of embedded groups. -func (o *Buffer) dec_slice_struct_group(p *Properties, base structPointer) error { - return o.dec_slice_struct(p, true, base) -} - -// Decode a slice of structs ([]*struct). -func (o *Buffer) dec_slice_struct(p *Properties, is_group bool, base structPointer) error { - v := reflect.New(p.stype) - bas := toStructPointer(v) - structPointer_StructPointerSlice(base, p.field).Append(bas) - - if is_group { - err := o.unmarshalType(p.stype, p.sprop, is_group, bas) - return err - } - - raw, err := o.DecodeRawBytes(false) - if err != nil { - return err - } - - // If the object can unmarshal itself, let it. - if p.isUnmarshaler { - iv := v.Interface() - return iv.(Unmarshaler).Unmarshal(raw) - } - - obuf := o.buf - oi := o.index - o.buf = raw - o.index = 0 - - err = o.unmarshalType(p.stype, p.sprop, is_group, bas) - - o.buf = obuf - o.index = oi - - return err -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/encode.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/encode.go deleted file mode 100644 index 8c1b8fd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/encode.go +++ /dev/null @@ -1,1363 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for encoding data into the wire format for protocol buffers. - */ - -import ( - "errors" - "fmt" - "reflect" - "sort" -) - -// RequiredNotSetError is the error returned if Marshal is called with -// a protocol buffer struct whose required fields have not -// all been initialized. It is also the error returned if Unmarshal is -// called with an encoded protocol buffer that does not include all the -// required fields. -// -// When printed, RequiredNotSetError reports the first unset required field in a -// message. If the field cannot be precisely determined, it is reported as -// "{Unknown}". -type RequiredNotSetError struct { - field string -} - -func (e *RequiredNotSetError) Error() string { - return fmt.Sprintf("proto: required field %q not set", e.field) -} - -var ( - // errRepeatedHasNil is the error returned if Marshal is called with - // a struct with a repeated field containing a nil element. - errRepeatedHasNil = errors.New("proto: repeated field has nil element") - - // errOneofHasNil is the error returned if Marshal is called with - // a struct with a oneof field containing a nil element. - errOneofHasNil = errors.New("proto: oneof field has nil value") - - // ErrNil is the error returned if Marshal is called with nil. - ErrNil = errors.New("proto: Marshal called with nil") - - // ErrTooLarge is the error returned if Marshal is called with a - // message that encodes to >2GB. - ErrTooLarge = errors.New("proto: message encodes to over 2 GB") -) - -// The fundamental encoders that put bytes on the wire. -// Those that take integer types all accept uint64 and are -// therefore of type valueEncoder. - -const maxVarintBytes = 10 // maximum length of a varint - -// maxMarshalSize is the largest allowed size of an encoded protobuf, -// since C++ and Java use signed int32s for the size. -const maxMarshalSize = 1<<31 - 1 - -// EncodeVarint returns the varint encoding of x. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -// Not used by the package itself, but helpful to clients -// wishing to use the same encoding. -func EncodeVarint(x uint64) []byte { - var buf [maxVarintBytes]byte - var n int - for n = 0; x > 127; n++ { - buf[n] = 0x80 | uint8(x&0x7F) - x >>= 7 - } - buf[n] = uint8(x) - n++ - return buf[0:n] -} - -// EncodeVarint writes a varint-encoded integer to the Buffer. -// This is the format for the -// int32, int64, uint32, uint64, bool, and enum -// protocol buffer types. -func (p *Buffer) EncodeVarint(x uint64) error { - for x >= 1<<7 { - p.buf = append(p.buf, uint8(x&0x7f|0x80)) - x >>= 7 - } - p.buf = append(p.buf, uint8(x)) - return nil -} - -// SizeVarint returns the varint encoding size of an integer. -func SizeVarint(x uint64) int { - return sizeVarint(x) -} - -func sizeVarint(x uint64) (n int) { - for { - n++ - x >>= 7 - if x == 0 { - break - } - } - return n -} - -// EncodeFixed64 writes a 64-bit integer to the Buffer. -// This is the format for the -// fixed64, sfixed64, and double protocol buffer types. -func (p *Buffer) EncodeFixed64(x uint64) error { - p.buf = append(p.buf, - uint8(x), - uint8(x>>8), - uint8(x>>16), - uint8(x>>24), - uint8(x>>32), - uint8(x>>40), - uint8(x>>48), - uint8(x>>56)) - return nil -} - -func sizeFixed64(x uint64) int { - return 8 -} - -// EncodeFixed32 writes a 32-bit integer to the Buffer. -// This is the format for the -// fixed32, sfixed32, and float protocol buffer types. -func (p *Buffer) EncodeFixed32(x uint64) error { - p.buf = append(p.buf, - uint8(x), - uint8(x>>8), - uint8(x>>16), - uint8(x>>24)) - return nil -} - -func sizeFixed32(x uint64) int { - return 4 -} - -// EncodeZigzag64 writes a zigzag-encoded 64-bit integer -// to the Buffer. -// This is the format used for the sint64 protocol buffer type. -func (p *Buffer) EncodeZigzag64(x uint64) error { - // use signed number to get arithmetic right shift. - return p.EncodeVarint(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} - -func sizeZigzag64(x uint64) int { - return sizeVarint(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} - -// EncodeZigzag32 writes a zigzag-encoded 32-bit integer -// to the Buffer. -// This is the format used for the sint32 protocol buffer type. -func (p *Buffer) EncodeZigzag32(x uint64) error { - // use signed number to get arithmetic right shift. - return p.EncodeVarint(uint64((uint32(x) << 1) ^ uint32((int32(x) >> 31)))) -} - -func sizeZigzag32(x uint64) int { - return sizeVarint(uint64((uint32(x) << 1) ^ uint32((int32(x) >> 31)))) -} - -// EncodeRawBytes writes a count-delimited byte buffer to the Buffer. -// This is the format used for the bytes protocol buffer -// type and for embedded messages. -func (p *Buffer) EncodeRawBytes(b []byte) error { - p.EncodeVarint(uint64(len(b))) - p.buf = append(p.buf, b...) - return nil -} - -func sizeRawBytes(b []byte) int { - return sizeVarint(uint64(len(b))) + - len(b) -} - -// EncodeStringBytes writes an encoded string to the Buffer. -// This is the format used for the proto2 string type. -func (p *Buffer) EncodeStringBytes(s string) error { - p.EncodeVarint(uint64(len(s))) - p.buf = append(p.buf, s...) - return nil -} - -func sizeStringBytes(s string) int { - return sizeVarint(uint64(len(s))) + - len(s) -} - -// Marshaler is the interface representing objects that can marshal themselves. -type Marshaler interface { - Marshal() ([]byte, error) -} - -// Marshal takes the protocol buffer -// and encodes it into the wire format, returning the data. -func Marshal(pb Message) ([]byte, error) { - // Can the object marshal itself? - if m, ok := pb.(Marshaler); ok { - return m.Marshal() - } - p := NewBuffer(nil) - err := p.Marshal(pb) - var state errorState - if err != nil && !state.shouldContinue(err, nil) { - return nil, err - } - if p.buf == nil && err == nil { - // Return a non-nil slice on success. - return []byte{}, nil - } - return p.buf, err -} - -// EncodeMessage writes the protocol buffer to the Buffer, -// prefixed by a varint-encoded length. -func (p *Buffer) EncodeMessage(pb Message) error { - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return ErrNil - } - if err == nil { - var state errorState - err = p.enc_len_struct(GetProperties(t.Elem()), base, &state) - } - return err -} - -// Marshal takes the protocol buffer -// and encodes it into the wire format, writing the result to the -// Buffer. -func (p *Buffer) Marshal(pb Message) error { - // Can the object marshal itself? - if m, ok := pb.(Marshaler); ok { - data, err := m.Marshal() - if err != nil { - return err - } - p.buf = append(p.buf, data...) - return nil - } - - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return ErrNil - } - if err == nil { - err = p.enc_struct(GetProperties(t.Elem()), base) - } - - if collectStats { - stats.Encode++ - } - - if len(p.buf) > maxMarshalSize { - return ErrTooLarge - } - return err -} - -// Size returns the encoded size of a protocol buffer. -func Size(pb Message) (n int) { - // Can the object marshal itself? If so, Size is slow. - // TODO: add Size to Marshaler, or add a Sizer interface. - if m, ok := pb.(Marshaler); ok { - b, _ := m.Marshal() - return len(b) - } - - t, base, err := getbase(pb) - if structPointer_IsNil(base) { - return 0 - } - if err == nil { - n = size_struct(GetProperties(t.Elem()), base) - } - - if collectStats { - stats.Size++ - } - - return -} - -// Individual type encoders. - -// Encode a bool. -func (o *Buffer) enc_bool(p *Properties, base structPointer) error { - v := *structPointer_Bool(base, p.field) - if v == nil { - return ErrNil - } - x := 0 - if *v { - x = 1 - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_bool(p *Properties, base structPointer) error { - v := *structPointer_BoolVal(base, p.field) - if !v { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, 1) - return nil -} - -func size_bool(p *Properties, base structPointer) int { - v := *structPointer_Bool(base, p.field) - if v == nil { - return 0 - } - return len(p.tagcode) + 1 // each bool takes exactly one byte -} - -func size_proto3_bool(p *Properties, base structPointer) int { - v := *structPointer_BoolVal(base, p.field) - if !v && !p.oneof { - return 0 - } - return len(p.tagcode) + 1 // each bool takes exactly one byte -} - -// Encode an int32. -func (o *Buffer) enc_int32(p *Properties, base structPointer) error { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return ErrNil - } - x := int32(word32_Get(v)) // permit sign extension to use full 64-bit range - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_int32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) // permit sign extension to use full 64-bit range - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_int32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return 0 - } - x := int32(word32_Get(v)) // permit sign extension to use full 64-bit range - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -func size_proto3_int32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := int32(word32Val_Get(v)) // permit sign extension to use full 64-bit range - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -// Encode a uint32. -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_uint32(p *Properties, base structPointer) error { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return ErrNil - } - x := word32_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func (o *Buffer) enc_proto3_uint32(p *Properties, base structPointer) error { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, uint64(x)) - return nil -} - -func size_uint32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32(base, p.field) - if word32_IsNil(v) { - return 0 - } - x := word32_Get(v) - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -func size_proto3_uint32(p *Properties, base structPointer) (n int) { - v := structPointer_Word32Val(base, p.field) - x := word32Val_Get(v) - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(uint64(x)) - return -} - -// Encode an int64. -func (o *Buffer) enc_int64(p *Properties, base structPointer) error { - v := structPointer_Word64(base, p.field) - if word64_IsNil(v) { - return ErrNil - } - x := word64_Get(v) - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, x) - return nil -} - -func (o *Buffer) enc_proto3_int64(p *Properties, base structPointer) error { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - if x == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, x) - return nil -} - -func size_int64(p *Properties, base structPointer) (n int) { - v := structPointer_Word64(base, p.field) - if word64_IsNil(v) { - return 0 - } - x := word64_Get(v) - n += len(p.tagcode) - n += p.valSize(x) - return -} - -func size_proto3_int64(p *Properties, base structPointer) (n int) { - v := structPointer_Word64Val(base, p.field) - x := word64Val_Get(v) - if x == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += p.valSize(x) - return -} - -// Encode a string. -func (o *Buffer) enc_string(p *Properties, base structPointer) error { - v := *structPointer_String(base, p.field) - if v == nil { - return ErrNil - } - x := *v - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(x) - return nil -} - -func (o *Buffer) enc_proto3_string(p *Properties, base structPointer) error { - v := *structPointer_StringVal(base, p.field) - if v == "" { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(v) - return nil -} - -func size_string(p *Properties, base structPointer) (n int) { - v := *structPointer_String(base, p.field) - if v == nil { - return 0 - } - x := *v - n += len(p.tagcode) - n += sizeStringBytes(x) - return -} - -func size_proto3_string(p *Properties, base structPointer) (n int) { - v := *structPointer_StringVal(base, p.field) - if v == "" && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeStringBytes(v) - return -} - -// All protocol buffer fields are nillable, but be careful. -func isNil(v reflect.Value) bool { - switch v.Kind() { - case reflect.Interface, reflect.Map, reflect.Ptr, reflect.Slice: - return v.IsNil() - } - return false -} - -// Encode a message struct. -func (o *Buffer) enc_struct_message(p *Properties, base structPointer) error { - var state errorState - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return ErrNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - return state.err - } - - o.buf = append(o.buf, p.tagcode...) - return o.enc_len_struct(p.sprop, structp, &state) -} - -func size_struct_message(p *Properties, base structPointer) int { - structp := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(structp) { - return 0 - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n0 := len(p.tagcode) - n1 := sizeRawBytes(data) - return n0 + n1 - } - - n0 := len(p.tagcode) - n1 := size_struct(p.sprop, structp) - n2 := sizeVarint(uint64(n1)) // size of encoded length - return n0 + n1 + n2 -} - -// Encode a group struct. -func (o *Buffer) enc_struct_group(p *Properties, base structPointer) error { - var state errorState - b := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(b) { - return ErrNil - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireStartGroup)) - err := o.enc_struct(p.sprop, b) - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.EncodeVarint(uint64((p.Tag << 3) | WireEndGroup)) - return state.err -} - -func size_struct_group(p *Properties, base structPointer) (n int) { - b := structPointer_GetStructPointer(base, p.field) - if structPointer_IsNil(b) { - return 0 - } - - n += sizeVarint(uint64((p.Tag << 3) | WireStartGroup)) - n += size_struct(p.sprop, b) - n += sizeVarint(uint64((p.Tag << 3) | WireEndGroup)) - return -} - -// Encode a slice of bools ([]bool). -func (o *Buffer) enc_slice_bool(p *Properties, base structPointer) error { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return ErrNil - } - for _, x := range s { - o.buf = append(o.buf, p.tagcode...) - v := uint64(0) - if x { - v = 1 - } - p.valEnc(o, v) - } - return nil -} - -func size_slice_bool(p *Properties, base structPointer) int { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return 0 - } - return l * (len(p.tagcode) + 1) // each bool takes exactly one byte -} - -// Encode a slice of bools ([]bool) in packed format. -func (o *Buffer) enc_slice_packed_bool(p *Properties, base structPointer) error { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(l)) // each bool takes exactly one byte - for _, x := range s { - v := uint64(0) - if x { - v = 1 - } - p.valEnc(o, v) - } - return nil -} - -func size_slice_packed_bool(p *Properties, base structPointer) (n int) { - s := *structPointer_BoolSlice(base, p.field) - l := len(s) - if l == 0 { - return 0 - } - n += len(p.tagcode) - n += sizeVarint(uint64(l)) - n += l // each bool takes exactly one byte - return -} - -// Encode a slice of bytes ([]byte). -func (o *Buffer) enc_slice_byte(p *Properties, base structPointer) error { - s := *structPointer_Bytes(base, p.field) - if s == nil { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(s) - return nil -} - -func (o *Buffer) enc_proto3_slice_byte(p *Properties, base structPointer) error { - s := *structPointer_Bytes(base, p.field) - if len(s) == 0 { - return ErrNil - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(s) - return nil -} - -func size_slice_byte(p *Properties, base structPointer) (n int) { - s := *structPointer_Bytes(base, p.field) - if s == nil && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeRawBytes(s) - return -} - -func size_proto3_slice_byte(p *Properties, base structPointer) (n int) { - s := *structPointer_Bytes(base, p.field) - if len(s) == 0 && !p.oneof { - return 0 - } - n += len(p.tagcode) - n += sizeRawBytes(s) - return -} - -// Encode a slice of int32s ([]int32). -func (o *Buffer) enc_slice_int32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - p.valEnc(o, uint64(x)) - } - return nil -} - -func size_slice_int32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - n += p.valSize(uint64(x)) - } - return -} - -// Encode a slice of int32s ([]int32) in packed format. -func (o *Buffer) enc_slice_packed_int32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - p.valEnc(buf, uint64(x)) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_int32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - x := int32(s.Index(i)) // permit sign extension to use full 64-bit range - bufSize += p.valSize(uint64(x)) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of uint32s ([]uint32). -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_slice_uint32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - x := s.Index(i) - p.valEnc(o, uint64(x)) - } - return nil -} - -func size_slice_uint32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - x := s.Index(i) - n += p.valSize(uint64(x)) - } - return -} - -// Encode a slice of uint32s ([]uint32) in packed format. -// Exactly the same as int32, except for no sign extension. -func (o *Buffer) enc_slice_packed_uint32(p *Properties, base structPointer) error { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - p.valEnc(buf, uint64(s.Index(i))) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_uint32(p *Properties, base structPointer) (n int) { - s := structPointer_Word32Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - bufSize += p.valSize(uint64(s.Index(i))) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of int64s ([]int64). -func (o *Buffer) enc_slice_int64(p *Properties, base structPointer) error { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - p.valEnc(o, s.Index(i)) - } - return nil -} - -func size_slice_int64(p *Properties, base structPointer) (n int) { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - for i := 0; i < l; i++ { - n += len(p.tagcode) - n += p.valSize(s.Index(i)) - } - return -} - -// Encode a slice of int64s ([]int64) in packed format. -func (o *Buffer) enc_slice_packed_int64(p *Properties, base structPointer) error { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return ErrNil - } - // TODO: Reuse a Buffer. - buf := NewBuffer(nil) - for i := 0; i < l; i++ { - p.valEnc(buf, s.Index(i)) - } - - o.buf = append(o.buf, p.tagcode...) - o.EncodeVarint(uint64(len(buf.buf))) - o.buf = append(o.buf, buf.buf...) - return nil -} - -func size_slice_packed_int64(p *Properties, base structPointer) (n int) { - s := structPointer_Word64Slice(base, p.field) - l := s.Len() - if l == 0 { - return 0 - } - var bufSize int - for i := 0; i < l; i++ { - bufSize += p.valSize(s.Index(i)) - } - - n += len(p.tagcode) - n += sizeVarint(uint64(bufSize)) - n += bufSize - return -} - -// Encode a slice of slice of bytes ([][]byte). -func (o *Buffer) enc_slice_slice_byte(p *Properties, base structPointer) error { - ss := *structPointer_BytesSlice(base, p.field) - l := len(ss) - if l == 0 { - return ErrNil - } - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(ss[i]) - } - return nil -} - -func size_slice_slice_byte(p *Properties, base structPointer) (n int) { - ss := *structPointer_BytesSlice(base, p.field) - l := len(ss) - if l == 0 { - return 0 - } - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - n += sizeRawBytes(ss[i]) - } - return -} - -// Encode a slice of strings ([]string). -func (o *Buffer) enc_slice_string(p *Properties, base structPointer) error { - ss := *structPointer_StringSlice(base, p.field) - l := len(ss) - for i := 0; i < l; i++ { - o.buf = append(o.buf, p.tagcode...) - o.EncodeStringBytes(ss[i]) - } - return nil -} - -func size_slice_string(p *Properties, base structPointer) (n int) { - ss := *structPointer_StringSlice(base, p.field) - l := len(ss) - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - n += sizeStringBytes(ss[i]) - } - return -} - -// Encode a slice of message structs ([]*struct). -func (o *Buffer) enc_slice_struct_message(p *Properties, base structPointer) error { - var state errorState - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - for i := 0; i < l; i++ { - structp := s.Index(i) - if structPointer_IsNil(structp) { - return errRepeatedHasNil - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, err := m.Marshal() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - o.buf = append(o.buf, p.tagcode...) - o.EncodeRawBytes(data) - continue - } - - o.buf = append(o.buf, p.tagcode...) - err := o.enc_len_struct(p.sprop, structp, &state) - if err != nil && !state.shouldContinue(err, nil) { - if err == ErrNil { - return errRepeatedHasNil - } - return err - } - } - return state.err -} - -func size_slice_struct_message(p *Properties, base structPointer) (n int) { - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - n += l * len(p.tagcode) - for i := 0; i < l; i++ { - structp := s.Index(i) - if structPointer_IsNil(structp) { - return // return the size up to this point - } - - // Can the object marshal itself? - if p.isMarshaler { - m := structPointer_Interface(structp, p.stype).(Marshaler) - data, _ := m.Marshal() - n += len(p.tagcode) - n += sizeRawBytes(data) - continue - } - - n0 := size_struct(p.sprop, structp) - n1 := sizeVarint(uint64(n0)) // size of encoded length - n += n0 + n1 - } - return -} - -// Encode a slice of group structs ([]*struct). -func (o *Buffer) enc_slice_struct_group(p *Properties, base structPointer) error { - var state errorState - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - for i := 0; i < l; i++ { - b := s.Index(i) - if structPointer_IsNil(b) { - return errRepeatedHasNil - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireStartGroup)) - - err := o.enc_struct(p.sprop, b) - - if err != nil && !state.shouldContinue(err, nil) { - if err == ErrNil { - return errRepeatedHasNil - } - return err - } - - o.EncodeVarint(uint64((p.Tag << 3) | WireEndGroup)) - } - return state.err -} - -func size_slice_struct_group(p *Properties, base structPointer) (n int) { - s := structPointer_StructPointerSlice(base, p.field) - l := s.Len() - - n += l * sizeVarint(uint64((p.Tag<<3)|WireStartGroup)) - n += l * sizeVarint(uint64((p.Tag<<3)|WireEndGroup)) - for i := 0; i < l; i++ { - b := s.Index(i) - if structPointer_IsNil(b) { - return // return size up to this point - } - - n += size_struct(p.sprop, b) - } - return -} - -// Encode an extension map. -func (o *Buffer) enc_map(p *Properties, base structPointer) error { - exts := structPointer_ExtMap(base, p.field) - if err := encodeExtensionsMap(*exts); err != nil { - return err - } - - return o.enc_map_body(*exts) -} - -func (o *Buffer) enc_exts(p *Properties, base structPointer) error { - exts := structPointer_Extensions(base, p.field) - if err := encodeExtensions(exts); err != nil { - return err - } - v, _ := exts.extensionsRead() - - return o.enc_map_body(v) -} - -func (o *Buffer) enc_map_body(v map[int32]Extension) error { - // Fast-path for common cases: zero or one extensions. - if len(v) <= 1 { - for _, e := range v { - o.buf = append(o.buf, e.enc...) - } - return nil - } - - // Sort keys to provide a deterministic encoding. - keys := make([]int, 0, len(v)) - for k := range v { - keys = append(keys, int(k)) - } - sort.Ints(keys) - - for _, k := range keys { - o.buf = append(o.buf, v[int32(k)].enc...) - } - return nil -} - -func size_map(p *Properties, base structPointer) int { - v := structPointer_ExtMap(base, p.field) - return extensionsMapSize(*v) -} - -func size_exts(p *Properties, base structPointer) int { - v := structPointer_Extensions(base, p.field) - return extensionsSize(v) -} - -// Encode a map field. -func (o *Buffer) enc_new_map(p *Properties, base structPointer) error { - var state errorState // XXX: or do we need to plumb this through? - - /* - A map defined as - map map_field = N; - is encoded in the same way as - message MapFieldEntry { - key_type key = 1; - value_type value = 2; - } - repeated MapFieldEntry map_field = N; - */ - - v := structPointer_NewAt(base, p.field, p.mtype).Elem() // map[K]V - if v.Len() == 0 { - return nil - } - - keycopy, valcopy, keybase, valbase := mapEncodeScratch(p.mtype) - - enc := func() error { - if err := p.mkeyprop.enc(o, p.mkeyprop, keybase); err != nil { - return err - } - if err := p.mvalprop.enc(o, p.mvalprop, valbase); err != nil && err != ErrNil { - return err - } - return nil - } - - // Don't sort map keys. It is not required by the spec, and C++ doesn't do it. - for _, key := range v.MapKeys() { - val := v.MapIndex(key) - - keycopy.Set(key) - valcopy.Set(val) - - o.buf = append(o.buf, p.tagcode...) - if err := o.enc_len_thing(enc, &state); err != nil { - return err - } - } - return nil -} - -func size_new_map(p *Properties, base structPointer) int { - v := structPointer_NewAt(base, p.field, p.mtype).Elem() // map[K]V - - keycopy, valcopy, keybase, valbase := mapEncodeScratch(p.mtype) - - n := 0 - for _, key := range v.MapKeys() { - val := v.MapIndex(key) - keycopy.Set(key) - valcopy.Set(val) - - // Tag codes for key and val are the responsibility of the sub-sizer. - keysize := p.mkeyprop.size(p.mkeyprop, keybase) - valsize := p.mvalprop.size(p.mvalprop, valbase) - entry := keysize + valsize - // Add on tag code and length of map entry itself. - n += len(p.tagcode) + sizeVarint(uint64(entry)) + entry - } - return n -} - -// mapEncodeScratch returns a new reflect.Value matching the map's value type, -// and a structPointer suitable for passing to an encoder or sizer. -func mapEncodeScratch(mapType reflect.Type) (keycopy, valcopy reflect.Value, keybase, valbase structPointer) { - // Prepare addressable doubly-indirect placeholders for the key and value types. - // This is needed because the element-type encoders expect **T, but the map iteration produces T. - - keycopy = reflect.New(mapType.Key()).Elem() // addressable K - keyptr := reflect.New(reflect.PtrTo(keycopy.Type())).Elem() // addressable *K - keyptr.Set(keycopy.Addr()) // - keybase = toStructPointer(keyptr.Addr()) // **K - - // Value types are more varied and require special handling. - switch mapType.Elem().Kind() { - case reflect.Slice: - // []byte - var dummy []byte - valcopy = reflect.ValueOf(&dummy).Elem() // addressable []byte - valbase = toStructPointer(valcopy.Addr()) - case reflect.Ptr: - // message; the generated field type is map[K]*Msg (so V is *Msg), - // so we only need one level of indirection. - valcopy = reflect.New(mapType.Elem()).Elem() // addressable V - valbase = toStructPointer(valcopy.Addr()) - default: - // everything else - valcopy = reflect.New(mapType.Elem()).Elem() // addressable V - valptr := reflect.New(reflect.PtrTo(valcopy.Type())).Elem() // addressable *V - valptr.Set(valcopy.Addr()) // - valbase = toStructPointer(valptr.Addr()) // **V - } - return -} - -// Encode a struct. -func (o *Buffer) enc_struct(prop *StructProperties, base structPointer) error { - var state errorState - // Encode fields in tag order so that decoders may use optimizations - // that depend on the ordering. - // https://developers.google.com/protocol-buffers/docs/encoding#order - for _, i := range prop.order { - p := prop.Prop[i] - if p.enc != nil { - err := p.enc(o, p, base) - if err != nil { - if err == ErrNil { - if p.Required && state.err == nil { - state.err = &RequiredNotSetError{p.Name} - } - } else if err == errRepeatedHasNil { - // Give more context to nil values in repeated fields. - return errors.New("repeated field " + p.OrigName + " has nil element") - } else if !state.shouldContinue(err, p) { - return err - } - } - if len(o.buf) > maxMarshalSize { - return ErrTooLarge - } - } - } - - // Do oneof fields. - if prop.oneofMarshaler != nil { - m := structPointer_Interface(base, prop.stype).(Message) - if err := prop.oneofMarshaler(m, o); err == ErrNil { - return errOneofHasNil - } else if err != nil { - return err - } - } - - // Add unrecognized fields at the end. - if prop.unrecField.IsValid() { - v := *structPointer_Bytes(base, prop.unrecField) - if len(o.buf)+len(v) > maxMarshalSize { - return ErrTooLarge - } - if len(v) > 0 { - o.buf = append(o.buf, v...) - } - } - - return state.err -} - -func size_struct(prop *StructProperties, base structPointer) (n int) { - for _, i := range prop.order { - p := prop.Prop[i] - if p.size != nil { - n += p.size(p, base) - } - } - - // Add unrecognized fields at the end. - if prop.unrecField.IsValid() { - v := *structPointer_Bytes(base, prop.unrecField) - n += len(v) - } - - // Factor in any oneof fields. - if prop.oneofSizer != nil { - m := structPointer_Interface(base, prop.stype).(Message) - n += prop.oneofSizer(m) - } - - return -} - -var zeroes [20]byte // longer than any conceivable sizeVarint - -// Encode a struct, preceded by its encoded length (as a varint). -func (o *Buffer) enc_len_struct(prop *StructProperties, base structPointer, state *errorState) error { - return o.enc_len_thing(func() error { return o.enc_struct(prop, base) }, state) -} - -// Encode something, preceded by its encoded length (as a varint). -func (o *Buffer) enc_len_thing(enc func() error, state *errorState) error { - iLen := len(o.buf) - o.buf = append(o.buf, 0, 0, 0, 0) // reserve four bytes for length - iMsg := len(o.buf) - err := enc() - if err != nil && !state.shouldContinue(err, nil) { - return err - } - lMsg := len(o.buf) - iMsg - lLen := sizeVarint(uint64(lMsg)) - switch x := lLen - (iMsg - iLen); { - case x > 0: // actual length is x bytes larger than the space we reserved - // Move msg x bytes right. - o.buf = append(o.buf, zeroes[:x]...) - copy(o.buf[iMsg+x:], o.buf[iMsg:iMsg+lMsg]) - case x < 0: // actual length is x bytes smaller than the space we reserved - // Move msg x bytes left. - copy(o.buf[iMsg+x:], o.buf[iMsg:iMsg+lMsg]) - o.buf = o.buf[:len(o.buf)+x] // x is negative - } - // Encode the length in the reserved space. - o.buf = o.buf[:iLen] - o.EncodeVarint(uint64(lMsg)) - o.buf = o.buf[:len(o.buf)+lMsg] - return state.err -} - -// errorState maintains the first error that occurs and updates that error -// with additional context. -type errorState struct { - err error -} - -// shouldContinue reports whether encoding should continue upon encountering the -// given error. If the error is RequiredNotSetError, shouldContinue returns true -// and, if this is the first appearance of that error, remembers it for future -// reporting. -// -// If prop is not nil, it may update any error with additional context about the -// field with the error. -func (s *errorState) shouldContinue(err error, prop *Properties) bool { - // Ignore unset required fields. - reqNotSet, ok := err.(*RequiredNotSetError) - if !ok { - return false - } - if s.err == nil { - if prop != nil { - err = &RequiredNotSetError{prop.Name + "." + reqNotSet.field} - } - s.err = err - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/equal.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/equal.go deleted file mode 100644 index 8b16f95..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/equal.go +++ /dev/null @@ -1,296 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2011 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// Protocol buffer comparison. - -package proto - -import ( - "bytes" - "log" - "reflect" - "strings" -) - -/* -Equal returns true iff protocol buffers a and b are equal. -The arguments must both be pointers to protocol buffer structs. - -Equality is defined in this way: - - Two messages are equal iff they are the same type, - corresponding fields are equal, unknown field sets - are equal, and extensions sets are equal. - - Two set scalar fields are equal iff their values are equal. - If the fields are of a floating-point type, remember that - NaN != x for all x, including NaN. If the message is defined - in a proto3 .proto file, fields are not "set"; specifically, - zero length proto3 "bytes" fields are equal (nil == {}). - - Two repeated fields are equal iff their lengths are the same, - and their corresponding elements are equal (a "bytes" field, - although represented by []byte, is not a repeated field) - - Two unset fields are equal. - - Two unknown field sets are equal if their current - encoded state is equal. - - Two extension sets are equal iff they have corresponding - elements that are pairwise equal. - - Every other combination of things are not equal. - -The return value is undefined if a and b are not protocol buffers. -*/ -func Equal(a, b Message) bool { - if a == nil || b == nil { - return a == b - } - v1, v2 := reflect.ValueOf(a), reflect.ValueOf(b) - if v1.Type() != v2.Type() { - return false - } - if v1.Kind() == reflect.Ptr { - if v1.IsNil() { - return v2.IsNil() - } - if v2.IsNil() { - return false - } - v1, v2 = v1.Elem(), v2.Elem() - } - if v1.Kind() != reflect.Struct { - return false - } - return equalStruct(v1, v2) -} - -// v1 and v2 are known to have the same type. -func equalStruct(v1, v2 reflect.Value) bool { - sprop := GetProperties(v1.Type()) - for i := 0; i < v1.NumField(); i++ { - f := v1.Type().Field(i) - if strings.HasPrefix(f.Name, "XXX_") { - continue - } - f1, f2 := v1.Field(i), v2.Field(i) - if f.Type.Kind() == reflect.Ptr { - if n1, n2 := f1.IsNil(), f2.IsNil(); n1 && n2 { - // both unset - continue - } else if n1 != n2 { - // set/unset mismatch - return false - } - b1, ok := f1.Interface().(raw) - if ok { - b2 := f2.Interface().(raw) - // RawMessage - if !bytes.Equal(b1.Bytes(), b2.Bytes()) { - return false - } - continue - } - f1, f2 = f1.Elem(), f2.Elem() - } - if !equalAny(f1, f2, sprop.Prop[i]) { - return false - } - } - - if em1 := v1.FieldByName("XXX_InternalExtensions"); em1.IsValid() { - em2 := v2.FieldByName("XXX_InternalExtensions") - if !equalExtensions(v1.Type(), em1.Interface().(XXX_InternalExtensions), em2.Interface().(XXX_InternalExtensions)) { - return false - } - } - - if em1 := v1.FieldByName("XXX_extensions"); em1.IsValid() { - em2 := v2.FieldByName("XXX_extensions") - if !equalExtMap(v1.Type(), em1.Interface().(map[int32]Extension), em2.Interface().(map[int32]Extension)) { - return false - } - } - - uf := v1.FieldByName("XXX_unrecognized") - if !uf.IsValid() { - return true - } - - u1 := uf.Bytes() - u2 := v2.FieldByName("XXX_unrecognized").Bytes() - if !bytes.Equal(u1, u2) { - return false - } - - return true -} - -// v1 and v2 are known to have the same type. -// prop may be nil. -func equalAny(v1, v2 reflect.Value, prop *Properties) bool { - if v1.Type() == protoMessageType { - m1, _ := v1.Interface().(Message) - m2, _ := v2.Interface().(Message) - return Equal(m1, m2) - } - switch v1.Kind() { - case reflect.Bool: - return v1.Bool() == v2.Bool() - case reflect.Float32, reflect.Float64: - return v1.Float() == v2.Float() - case reflect.Int32, reflect.Int64: - return v1.Int() == v2.Int() - case reflect.Interface: - // Probably a oneof field; compare the inner values. - n1, n2 := v1.IsNil(), v2.IsNil() - if n1 || n2 { - return n1 == n2 - } - e1, e2 := v1.Elem(), v2.Elem() - if e1.Type() != e2.Type() { - return false - } - return equalAny(e1, e2, nil) - case reflect.Map: - if v1.Len() != v2.Len() { - return false - } - for _, key := range v1.MapKeys() { - val2 := v2.MapIndex(key) - if !val2.IsValid() { - // This key was not found in the second map. - return false - } - if !equalAny(v1.MapIndex(key), val2, nil) { - return false - } - } - return true - case reflect.Ptr: - // Maps may have nil values in them, so check for nil. - if v1.IsNil() && v2.IsNil() { - return true - } - if v1.IsNil() != v2.IsNil() { - return false - } - return equalAny(v1.Elem(), v2.Elem(), prop) - case reflect.Slice: - if v1.Type().Elem().Kind() == reflect.Uint8 { - // short circuit: []byte - - // Edge case: if this is in a proto3 message, a zero length - // bytes field is considered the zero value. - if prop != nil && prop.proto3 && v1.Len() == 0 && v2.Len() == 0 { - return true - } - if v1.IsNil() != v2.IsNil() { - return false - } - return bytes.Equal(v1.Interface().([]byte), v2.Interface().([]byte)) - } - - if v1.Len() != v2.Len() { - return false - } - for i := 0; i < v1.Len(); i++ { - if !equalAny(v1.Index(i), v2.Index(i), prop) { - return false - } - } - return true - case reflect.String: - return v1.Interface().(string) == v2.Interface().(string) - case reflect.Struct: - return equalStruct(v1, v2) - case reflect.Uint32, reflect.Uint64: - return v1.Uint() == v2.Uint() - } - - // unknown type, so not a protocol buffer - log.Printf("proto: don't know how to compare %v", v1) - return false -} - -// base is the struct type that the extensions are based on. -// x1 and x2 are InternalExtensions. -func equalExtensions(base reflect.Type, x1, x2 XXX_InternalExtensions) bool { - em1, _ := x1.extensionsRead() - em2, _ := x2.extensionsRead() - return equalExtMap(base, em1, em2) -} - -func equalExtMap(base reflect.Type, em1, em2 map[int32]Extension) bool { - if len(em1) != len(em2) { - return false - } - - for extNum, e1 := range em1 { - e2, ok := em2[extNum] - if !ok { - return false - } - - m1, m2 := e1.value, e2.value - - if m1 != nil && m2 != nil { - // Both are unencoded. - if !equalAny(reflect.ValueOf(m1), reflect.ValueOf(m2), nil) { - return false - } - continue - } - - // At least one is encoded. To do a semantically correct comparison - // we need to unmarshal them first. - var desc *ExtensionDesc - if m := extensionMaps[base]; m != nil { - desc = m[extNum] - } - if desc == nil { - log.Printf("proto: don't know how to compare extension %d of %v", extNum, base) - continue - } - var err error - if m1 == nil { - m1, err = decodeExtension(e1.enc, desc) - } - if m2 == nil && err == nil { - m2, err = decodeExtension(e2.enc, desc) - } - if err != nil { - // The encoded form is invalid. - log.Printf("proto: badly encoded extension %d of %v: %v", extNum, base, err) - return false - } - if !equalAny(reflect.ValueOf(m1), reflect.ValueOf(m2), nil) { - return false - } - } - - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/extensions.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/extensions.go deleted file mode 100644 index 9f484f5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/extensions.go +++ /dev/null @@ -1,555 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Types and routines for supporting protocol buffer extensions. - */ - -import ( - "errors" - "fmt" - "reflect" - "strconv" - "sync" -) - -// ErrMissingExtension is the error returned by GetExtension if the named extension is not in the message. -var ErrMissingExtension = errors.New("proto: missing extension") - -// ExtensionRange represents a range of message extensions for a protocol buffer. -// Used in code generated by the protocol compiler. -type ExtensionRange struct { - Start, End int32 // both inclusive -} - -// extendableProto is an interface implemented by any protocol buffer generated by the current -// proto compiler that may be extended. -type extendableProto interface { - Message - ExtensionRangeArray() []ExtensionRange - extensionsWrite() map[int32]Extension - extensionsRead() (map[int32]Extension, sync.Locker) -} - -// extendableProtoV1 is an interface implemented by a protocol buffer generated by the previous -// version of the proto compiler that may be extended. -type extendableProtoV1 interface { - Message - ExtensionRangeArray() []ExtensionRange - ExtensionMap() map[int32]Extension -} - -// extensionAdapter is a wrapper around extendableProtoV1 that implements extendableProto. -type extensionAdapter struct { - extendableProtoV1 -} - -func (e extensionAdapter) extensionsWrite() map[int32]Extension { - return e.ExtensionMap() -} - -func (e extensionAdapter) extensionsRead() (map[int32]Extension, sync.Locker) { - return e.ExtensionMap(), notLocker{} -} - -// notLocker is a sync.Locker whose Lock and Unlock methods are nops. -type notLocker struct{} - -func (n notLocker) Lock() {} -func (n notLocker) Unlock() {} - -// extendable returns the extendableProto interface for the given generated proto message. -// If the proto message has the old extension format, it returns a wrapper that implements -// the extendableProto interface. -func extendable(p interface{}) (extendableProto, bool) { - if ep, ok := p.(extendableProto); ok { - return ep, ok - } - if ep, ok := p.(extendableProtoV1); ok { - return extensionAdapter{ep}, ok - } - return nil, false -} - -// XXX_InternalExtensions is an internal representation of proto extensions. -// -// Each generated message struct type embeds an anonymous XXX_InternalExtensions field, -// thus gaining the unexported 'extensions' method, which can be called only from the proto package. -// -// The methods of XXX_InternalExtensions are not concurrency safe in general, -// but calls to logically read-only methods such as has and get may be executed concurrently. -type XXX_InternalExtensions struct { - // The struct must be indirect so that if a user inadvertently copies a - // generated message and its embedded XXX_InternalExtensions, they - // avoid the mayhem of a copied mutex. - // - // The mutex serializes all logically read-only operations to p.extensionMap. - // It is up to the client to ensure that write operations to p.extensionMap are - // mutually exclusive with other accesses. - p *struct { - mu sync.Mutex - extensionMap map[int32]Extension - } -} - -// extensionsWrite returns the extension map, creating it on first use. -func (e *XXX_InternalExtensions) extensionsWrite() map[int32]Extension { - if e.p == nil { - e.p = new(struct { - mu sync.Mutex - extensionMap map[int32]Extension - }) - e.p.extensionMap = make(map[int32]Extension) - } - return e.p.extensionMap -} - -// extensionsRead returns the extensions map for read-only use. It may be nil. -// The caller must hold the returned mutex's lock when accessing Elements within the map. -func (e *XXX_InternalExtensions) extensionsRead() (map[int32]Extension, sync.Locker) { - if e.p == nil { - return nil, nil - } - return e.p.extensionMap, &e.p.mu -} - -var extendableProtoType = reflect.TypeOf((*extendableProto)(nil)).Elem() -var extendableProtoV1Type = reflect.TypeOf((*extendableProtoV1)(nil)).Elem() - -// ExtensionDesc represents an extension specification. -// Used in generated code from the protocol compiler. -type ExtensionDesc struct { - ExtendedType Message // nil pointer to the type that is being extended - ExtensionType interface{} // nil pointer to the extension type - Field int32 // field number - Name string // fully-qualified name of extension, for text formatting - Tag string // protobuf tag style -} - -func (ed *ExtensionDesc) repeated() bool { - t := reflect.TypeOf(ed.ExtensionType) - return t.Kind() == reflect.Slice && t.Elem().Kind() != reflect.Uint8 -} - -// Extension represents an extension in a message. -type Extension struct { - // When an extension is stored in a message using SetExtension - // only desc and value are set. When the message is marshaled - // enc will be set to the encoded form of the message. - // - // When a message is unmarshaled and contains extensions, each - // extension will have only enc set. When such an extension is - // accessed using GetExtension (or GetExtensions) desc and value - // will be set. - desc *ExtensionDesc - value interface{} - enc []byte -} - -// SetRawExtension is for testing only. -func SetRawExtension(base Message, id int32, b []byte) { - epb, ok := extendable(base) - if !ok { - return - } - extmap := epb.extensionsWrite() - extmap[id] = Extension{enc: b} -} - -// isExtensionField returns true iff the given field number is in an extension range. -func isExtensionField(pb extendableProto, field int32) bool { - for _, er := range pb.ExtensionRangeArray() { - if er.Start <= field && field <= er.End { - return true - } - } - return false -} - -// checkExtensionTypes checks that the given extension is valid for pb. -func checkExtensionTypes(pb extendableProto, extension *ExtensionDesc) error { - var pbi interface{} = pb - // Check the extended type. - if ea, ok := pbi.(extensionAdapter); ok { - pbi = ea.extendableProtoV1 - } - if a, b := reflect.TypeOf(pbi), reflect.TypeOf(extension.ExtendedType); a != b { - return errors.New("proto: bad extended type; " + b.String() + " does not extend " + a.String()) - } - // Check the range. - if !isExtensionField(pb, extension.Field) { - return errors.New("proto: bad extension number; not in declared ranges") - } - return nil -} - -// extPropKey is sufficient to uniquely identify an extension. -type extPropKey struct { - base reflect.Type - field int32 -} - -var extProp = struct { - sync.RWMutex - m map[extPropKey]*Properties -}{ - m: make(map[extPropKey]*Properties), -} - -func extensionProperties(ed *ExtensionDesc) *Properties { - key := extPropKey{base: reflect.TypeOf(ed.ExtendedType), field: ed.Field} - - extProp.RLock() - if prop, ok := extProp.m[key]; ok { - extProp.RUnlock() - return prop - } - extProp.RUnlock() - - extProp.Lock() - defer extProp.Unlock() - // Check again. - if prop, ok := extProp.m[key]; ok { - return prop - } - - prop := new(Properties) - prop.Init(reflect.TypeOf(ed.ExtensionType), "unknown_name", ed.Tag, nil) - extProp.m[key] = prop - return prop -} - -// encode encodes any unmarshaled (unencoded) extensions in e. -func encodeExtensions(e *XXX_InternalExtensions) error { - m, mu := e.extensionsRead() - if m == nil { - return nil // fast path - } - mu.Lock() - defer mu.Unlock() - return encodeExtensionsMap(m) -} - -// encode encodes any unmarshaled (unencoded) extensions in e. -func encodeExtensionsMap(m map[int32]Extension) error { - for k, e := range m { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - continue - } - - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - p := NewBuffer(nil) - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - if err := props.enc(p, props, toStructPointer(x)); err != nil { - return err - } - e.enc = p.buf - m[k] = e - } - return nil -} - -func extensionsSize(e *XXX_InternalExtensions) (n int) { - m, mu := e.extensionsRead() - if m == nil { - return 0 - } - mu.Lock() - defer mu.Unlock() - return extensionsMapSize(m) -} - -func extensionsMapSize(m map[int32]Extension) (n int) { - for _, e := range m { - if e.value == nil || e.desc == nil { - // Extension is only in its encoded form. - n += len(e.enc) - continue - } - - // We don't skip extensions that have an encoded form set, - // because the extension value may have been mutated after - // the last time this function was called. - - et := reflect.TypeOf(e.desc.ExtensionType) - props := extensionProperties(e.desc) - - // If e.value has type T, the encoder expects a *struct{ X T }. - // Pass a *T with a zero field and hope it all works out. - x := reflect.New(et) - x.Elem().Set(reflect.ValueOf(e.value)) - n += props.size(props, toStructPointer(x)) - } - return -} - -// HasExtension returns whether the given extension is present in pb. -func HasExtension(pb Message, extension *ExtensionDesc) bool { - // TODO: Check types, field numbers, etc.? - epb, ok := extendable(pb) - if !ok { - return false - } - extmap, mu := epb.extensionsRead() - if extmap == nil { - return false - } - mu.Lock() - _, ok = extmap[extension.Field] - mu.Unlock() - return ok -} - -// ClearExtension removes the given extension from pb. -func ClearExtension(pb Message, extension *ExtensionDesc) { - epb, ok := extendable(pb) - if !ok { - return - } - // TODO: Check types, field numbers, etc.? - extmap := epb.extensionsWrite() - delete(extmap, extension.Field) -} - -// GetExtension parses and returns the given extension of pb. -// If the extension is not present and has no default value it returns ErrMissingExtension. -func GetExtension(pb Message, extension *ExtensionDesc) (interface{}, error) { - epb, ok := extendable(pb) - if !ok { - return nil, errors.New("proto: not an extendable proto") - } - - if err := checkExtensionTypes(epb, extension); err != nil { - return nil, err - } - - emap, mu := epb.extensionsRead() - if emap == nil { - return defaultExtensionValue(extension) - } - mu.Lock() - defer mu.Unlock() - e, ok := emap[extension.Field] - if !ok { - // defaultExtensionValue returns the default value or - // ErrMissingExtension if there is no default. - return defaultExtensionValue(extension) - } - - if e.value != nil { - // Already decoded. Check the descriptor, though. - if e.desc != extension { - // This shouldn't happen. If it does, it means that - // GetExtension was called twice with two different - // descriptors with the same field number. - return nil, errors.New("proto: descriptor conflict") - } - return e.value, nil - } - - v, err := decodeExtension(e.enc, extension) - if err != nil { - return nil, err - } - - // Remember the decoded version and drop the encoded version. - // That way it is safe to mutate what we return. - e.value = v - e.desc = extension - e.enc = nil - emap[extension.Field] = e - return e.value, nil -} - -// defaultExtensionValue returns the default value for extension. -// If no default for an extension is defined ErrMissingExtension is returned. -func defaultExtensionValue(extension *ExtensionDesc) (interface{}, error) { - t := reflect.TypeOf(extension.ExtensionType) - props := extensionProperties(extension) - - sf, _, err := fieldDefault(t, props) - if err != nil { - return nil, err - } - - if sf == nil || sf.value == nil { - // There is no default value. - return nil, ErrMissingExtension - } - - if t.Kind() != reflect.Ptr { - // We do not need to return a Ptr, we can directly return sf.value. - return sf.value, nil - } - - // We need to return an interface{} that is a pointer to sf.value. - value := reflect.New(t).Elem() - value.Set(reflect.New(value.Type().Elem())) - if sf.kind == reflect.Int32 { - // We may have an int32 or an enum, but the underlying data is int32. - // Since we can't set an int32 into a non int32 reflect.value directly - // set it as a int32. - value.Elem().SetInt(int64(sf.value.(int32))) - } else { - value.Elem().Set(reflect.ValueOf(sf.value)) - } - return value.Interface(), nil -} - -// decodeExtension decodes an extension encoded in b. -func decodeExtension(b []byte, extension *ExtensionDesc) (interface{}, error) { - o := NewBuffer(b) - - t := reflect.TypeOf(extension.ExtensionType) - - props := extensionProperties(extension) - - // t is a pointer to a struct, pointer to basic type or a slice. - // Allocate a "field" to store the pointer/slice itself; the - // pointer/slice will be stored here. We pass - // the address of this field to props.dec. - // This passes a zero field and a *t and lets props.dec - // interpret it as a *struct{ x t }. - value := reflect.New(t).Elem() - - for { - // Discard wire type and field number varint. It isn't needed. - if _, err := o.DecodeVarint(); err != nil { - return nil, err - } - - if err := props.dec(o, props, toStructPointer(value.Addr())); err != nil { - return nil, err - } - - if o.index >= len(o.buf) { - break - } - } - return value.Interface(), nil -} - -// GetExtensions returns a slice of the extensions present in pb that are also listed in es. -// The returned slice has the same length as es; missing extensions will appear as nil elements. -func GetExtensions(pb Message, es []*ExtensionDesc) (extensions []interface{}, err error) { - epb, ok := extendable(pb) - if !ok { - return nil, errors.New("proto: not an extendable proto") - } - extensions = make([]interface{}, len(es)) - for i, e := range es { - extensions[i], err = GetExtension(epb, e) - if err == ErrMissingExtension { - err = nil - } - if err != nil { - return - } - } - return -} - -// SetExtension sets the specified extension of pb to the specified value. -func SetExtension(pb Message, extension *ExtensionDesc, value interface{}) error { - epb, ok := extendable(pb) - if !ok { - return errors.New("proto: not an extendable proto") - } - if err := checkExtensionTypes(epb, extension); err != nil { - return err - } - typ := reflect.TypeOf(extension.ExtensionType) - if typ != reflect.TypeOf(value) { - return errors.New("proto: bad extension value type") - } - // nil extension values need to be caught early, because the - // encoder can't distinguish an ErrNil due to a nil extension - // from an ErrNil due to a missing field. Extensions are - // always optional, so the encoder would just swallow the error - // and drop all the extensions from the encoded message. - if reflect.ValueOf(value).IsNil() { - return fmt.Errorf("proto: SetExtension called with nil value of type %T", value) - } - - extmap := epb.extensionsWrite() - extmap[extension.Field] = Extension{desc: extension, value: value} - return nil -} - -// ClearAllExtensions clears all extensions from pb. -func ClearAllExtensions(pb Message) { - epb, ok := extendable(pb) - if !ok { - return - } - m := epb.extensionsWrite() - for k := range m { - delete(m, k) - } -} - -// A global registry of extensions. -// The generated code will register the generated descriptors by calling RegisterExtension. - -var extensionMaps = make(map[reflect.Type]map[int32]*ExtensionDesc) - -// RegisterExtension is called from the generated code. -func RegisterExtension(desc *ExtensionDesc) { - st := reflect.TypeOf(desc.ExtendedType).Elem() - m := extensionMaps[st] - if m == nil { - m = make(map[int32]*ExtensionDesc) - extensionMaps[st] = m - } - if _, ok := m[desc.Field]; ok { - panic("proto: duplicate extension registered: " + st.String() + " " + strconv.Itoa(int(desc.Field))) - } - m[desc.Field] = desc -} - -// RegisteredExtensions returns a map of the registered extensions of a -// protocol buffer struct, indexed by the extension number. -// The argument pb should be a nil pointer to the struct type. -func RegisteredExtensions(pb Message) map[int32]*ExtensionDesc { - return extensionMaps[reflect.TypeOf(pb).Elem()] -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/lib.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/lib.go deleted file mode 100644 index 170b8e8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/lib.go +++ /dev/null @@ -1,898 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -/* -Package proto converts data structures to and from the wire format of -protocol buffers. It works in concert with the Go source code generated -for .proto files by the protocol compiler. - -A summary of the properties of the protocol buffer interface -for a protocol buffer variable v: - - - Names are turned from camel_case to CamelCase for export. - - There are no methods on v to set fields; just treat - them as structure fields. - - There are getters that return a field's value if set, - and return the field's default value if unset. - The getters work even if the receiver is a nil message. - - The zero value for a struct is its correct initialization state. - All desired fields must be set before marshaling. - - A Reset() method will restore a protobuf struct to its zero state. - - Non-repeated fields are pointers to the values; nil means unset. - That is, optional or required field int32 f becomes F *int32. - - Repeated fields are slices. - - Helper functions are available to aid the setting of fields. - msg.Foo = proto.String("hello") // set field - - Constants are defined to hold the default values of all fields that - have them. They have the form Default_StructName_FieldName. - Because the getter methods handle defaulted values, - direct use of these constants should be rare. - - Enums are given type names and maps from names to values. - Enum values are prefixed by the enclosing message's name, or by the - enum's type name if it is a top-level enum. Enum types have a String - method, and a Enum method to assist in message construction. - - Nested messages, groups and enums have type names prefixed with the name of - the surrounding message type. - - Extensions are given descriptor names that start with E_, - followed by an underscore-delimited list of the nested messages - that contain it (if any) followed by the CamelCased name of the - extension field itself. HasExtension, ClearExtension, GetExtension - and SetExtension are functions for manipulating extensions. - - Oneof field sets are given a single field in their message, - with distinguished wrapper types for each possible field value. - - Marshal and Unmarshal are functions to encode and decode the wire format. - -When the .proto file specifies `syntax="proto3"`, there are some differences: - - - Non-repeated fields of non-message type are values instead of pointers. - - Getters are only generated for message and oneof fields. - - Enum types do not get an Enum method. - -The simplest way to describe this is to see an example. -Given file test.proto, containing - - package example; - - enum FOO { X = 17; } - - message Test { - required string label = 1; - optional int32 type = 2 [default=77]; - repeated int64 reps = 3; - optional group OptionalGroup = 4 { - required string RequiredField = 5; - } - oneof union { - int32 number = 6; - string name = 7; - } - } - -The resulting file, test.pb.go, is: - - package example - - import proto "github.com/golang/protobuf/proto" - import math "math" - - type FOO int32 - const ( - FOO_X FOO = 17 - ) - var FOO_name = map[int32]string{ - 17: "X", - } - var FOO_value = map[string]int32{ - "X": 17, - } - - func (x FOO) Enum() *FOO { - p := new(FOO) - *p = x - return p - } - func (x FOO) String() string { - return proto.EnumName(FOO_name, int32(x)) - } - func (x *FOO) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(FOO_value, data) - if err != nil { - return err - } - *x = FOO(value) - return nil - } - - type Test struct { - Label *string `protobuf:"bytes,1,req,name=label" json:"label,omitempty"` - Type *int32 `protobuf:"varint,2,opt,name=type,def=77" json:"type,omitempty"` - Reps []int64 `protobuf:"varint,3,rep,name=reps" json:"reps,omitempty"` - Optionalgroup *Test_OptionalGroup `protobuf:"group,4,opt,name=OptionalGroup" json:"optionalgroup,omitempty"` - // Types that are valid to be assigned to Union: - // *Test_Number - // *Test_Name - Union isTest_Union `protobuf_oneof:"union"` - XXX_unrecognized []byte `json:"-"` - } - func (m *Test) Reset() { *m = Test{} } - func (m *Test) String() string { return proto.CompactTextString(m) } - func (*Test) ProtoMessage() {} - - type isTest_Union interface { - isTest_Union() - } - - type Test_Number struct { - Number int32 `protobuf:"varint,6,opt,name=number"` - } - type Test_Name struct { - Name string `protobuf:"bytes,7,opt,name=name"` - } - - func (*Test_Number) isTest_Union() {} - func (*Test_Name) isTest_Union() {} - - func (m *Test) GetUnion() isTest_Union { - if m != nil { - return m.Union - } - return nil - } - const Default_Test_Type int32 = 77 - - func (m *Test) GetLabel() string { - if m != nil && m.Label != nil { - return *m.Label - } - return "" - } - - func (m *Test) GetType() int32 { - if m != nil && m.Type != nil { - return *m.Type - } - return Default_Test_Type - } - - func (m *Test) GetOptionalgroup() *Test_OptionalGroup { - if m != nil { - return m.Optionalgroup - } - return nil - } - - type Test_OptionalGroup struct { - RequiredField *string `protobuf:"bytes,5,req" json:"RequiredField,omitempty"` - } - func (m *Test_OptionalGroup) Reset() { *m = Test_OptionalGroup{} } - func (m *Test_OptionalGroup) String() string { return proto.CompactTextString(m) } - - func (m *Test_OptionalGroup) GetRequiredField() string { - if m != nil && m.RequiredField != nil { - return *m.RequiredField - } - return "" - } - - func (m *Test) GetNumber() int32 { - if x, ok := m.GetUnion().(*Test_Number); ok { - return x.Number - } - return 0 - } - - func (m *Test) GetName() string { - if x, ok := m.GetUnion().(*Test_Name); ok { - return x.Name - } - return "" - } - - func init() { - proto.RegisterEnum("example.FOO", FOO_name, FOO_value) - } - -To create and play with a Test object: - - package main - - import ( - "log" - - "github.com/golang/protobuf/proto" - pb "./example.pb" - ) - - func main() { - test := &pb.Test{ - Label: proto.String("hello"), - Type: proto.Int32(17), - Reps: []int64{1, 2, 3}, - Optionalgroup: &pb.Test_OptionalGroup{ - RequiredField: proto.String("good bye"), - }, - Union: &pb.Test_Name{"fred"}, - } - data, err := proto.Marshal(test) - if err != nil { - log.Fatal("marshaling error: ", err) - } - newTest := &pb.Test{} - err = proto.Unmarshal(data, newTest) - if err != nil { - log.Fatal("unmarshaling error: ", err) - } - // Now test and newTest contain the same data. - if test.GetLabel() != newTest.GetLabel() { - log.Fatalf("data mismatch %q != %q", test.GetLabel(), newTest.GetLabel()) - } - // Use a type switch to determine which oneof was set. - switch u := test.Union.(type) { - case *pb.Test_Number: // u.Number contains the number. - case *pb.Test_Name: // u.Name contains the string. - } - // etc. - } -*/ -package proto - -import ( - "encoding/json" - "fmt" - "log" - "reflect" - "sort" - "strconv" - "sync" -) - -// Message is implemented by generated protocol buffer messages. -type Message interface { - Reset() - String() string - ProtoMessage() -} - -// Stats records allocation details about the protocol buffer encoders -// and decoders. Useful for tuning the library itself. -type Stats struct { - Emalloc uint64 // mallocs in encode - Dmalloc uint64 // mallocs in decode - Encode uint64 // number of encodes - Decode uint64 // number of decodes - Chit uint64 // number of cache hits - Cmiss uint64 // number of cache misses - Size uint64 // number of sizes -} - -// Set to true to enable stats collection. -const collectStats = false - -var stats Stats - -// GetStats returns a copy of the global Stats structure. -func GetStats() Stats { return stats } - -// A Buffer is a buffer manager for marshaling and unmarshaling -// protocol buffers. It may be reused between invocations to -// reduce memory usage. It is not necessary to use a Buffer; -// the global functions Marshal and Unmarshal create a -// temporary Buffer and are fine for most applications. -type Buffer struct { - buf []byte // encode/decode byte stream - index int // write point - - // pools of basic types to amortize allocation. - bools []bool - uint32s []uint32 - uint64s []uint64 - - // extra pools, only used with pointer_reflect.go - int32s []int32 - int64s []int64 - float32s []float32 - float64s []float64 -} - -// NewBuffer allocates a new Buffer and initializes its internal data to -// the contents of the argument slice. -func NewBuffer(e []byte) *Buffer { - return &Buffer{buf: e} -} - -// Reset resets the Buffer, ready for marshaling a new protocol buffer. -func (p *Buffer) Reset() { - p.buf = p.buf[0:0] // for reading/writing - p.index = 0 // for reading -} - -// SetBuf replaces the internal buffer with the slice, -// ready for unmarshaling the contents of the slice. -func (p *Buffer) SetBuf(s []byte) { - p.buf = s - p.index = 0 -} - -// Bytes returns the contents of the Buffer. -func (p *Buffer) Bytes() []byte { return p.buf } - -/* - * Helper routines for simplifying the creation of optional fields of basic type. - */ - -// Bool is a helper routine that allocates a new bool value -// to store v and returns a pointer to it. -func Bool(v bool) *bool { - return &v -} - -// Int32 is a helper routine that allocates a new int32 value -// to store v and returns a pointer to it. -func Int32(v int32) *int32 { - return &v -} - -// Int is a helper routine that allocates a new int32 value -// to store v and returns a pointer to it, but unlike Int32 -// its argument value is an int. -func Int(v int) *int32 { - p := new(int32) - *p = int32(v) - return p -} - -// Int64 is a helper routine that allocates a new int64 value -// to store v and returns a pointer to it. -func Int64(v int64) *int64 { - return &v -} - -// Float32 is a helper routine that allocates a new float32 value -// to store v and returns a pointer to it. -func Float32(v float32) *float32 { - return &v -} - -// Float64 is a helper routine that allocates a new float64 value -// to store v and returns a pointer to it. -func Float64(v float64) *float64 { - return &v -} - -// Uint32 is a helper routine that allocates a new uint32 value -// to store v and returns a pointer to it. -func Uint32(v uint32) *uint32 { - return &v -} - -// Uint64 is a helper routine that allocates a new uint64 value -// to store v and returns a pointer to it. -func Uint64(v uint64) *uint64 { - return &v -} - -// String is a helper routine that allocates a new string value -// to store v and returns a pointer to it. -func String(v string) *string { - return &v -} - -// EnumName is a helper function to simplify printing protocol buffer enums -// by name. Given an enum map and a value, it returns a useful string. -func EnumName(m map[int32]string, v int32) string { - s, ok := m[v] - if ok { - return s - } - return strconv.Itoa(int(v)) -} - -// UnmarshalJSONEnum is a helper function to simplify recovering enum int values -// from their JSON-encoded representation. Given a map from the enum's symbolic -// names to its int values, and a byte buffer containing the JSON-encoded -// value, it returns an int32 that can be cast to the enum type by the caller. -// -// The function can deal with both JSON representations, numeric and symbolic. -func UnmarshalJSONEnum(m map[string]int32, data []byte, enumName string) (int32, error) { - if data[0] == '"' { - // New style: enums are strings. - var repr string - if err := json.Unmarshal(data, &repr); err != nil { - return -1, err - } - val, ok := m[repr] - if !ok { - return 0, fmt.Errorf("unrecognized enum %s value %q", enumName, repr) - } - return val, nil - } - // Old style: enums are ints. - var val int32 - if err := json.Unmarshal(data, &val); err != nil { - return 0, fmt.Errorf("cannot unmarshal %#q into enum %s", data, enumName) - } - return val, nil -} - -// DebugPrint dumps the encoded data in b in a debugging format with a header -// including the string s. Used in testing but made available for general debugging. -func (p *Buffer) DebugPrint(s string, b []byte) { - var u uint64 - - obuf := p.buf - index := p.index - p.buf = b - p.index = 0 - depth := 0 - - fmt.Printf("\n--- %s ---\n", s) - -out: - for { - for i := 0; i < depth; i++ { - fmt.Print(" ") - } - - index := p.index - if index == len(p.buf) { - break - } - - op, err := p.DecodeVarint() - if err != nil { - fmt.Printf("%3d: fetching op err %v\n", index, err) - break out - } - tag := op >> 3 - wire := op & 7 - - switch wire { - default: - fmt.Printf("%3d: t=%3d unknown wire=%d\n", - index, tag, wire) - break out - - case WireBytes: - var r []byte - - r, err = p.DecodeRawBytes(false) - if err != nil { - break out - } - fmt.Printf("%3d: t=%3d bytes [%d]", index, tag, len(r)) - if len(r) <= 6 { - for i := 0; i < len(r); i++ { - fmt.Printf(" %.2x", r[i]) - } - } else { - for i := 0; i < 3; i++ { - fmt.Printf(" %.2x", r[i]) - } - fmt.Printf(" ..") - for i := len(r) - 3; i < len(r); i++ { - fmt.Printf(" %.2x", r[i]) - } - } - fmt.Printf("\n") - - case WireFixed32: - u, err = p.DecodeFixed32() - if err != nil { - fmt.Printf("%3d: t=%3d fix32 err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d fix32 %d\n", index, tag, u) - - case WireFixed64: - u, err = p.DecodeFixed64() - if err != nil { - fmt.Printf("%3d: t=%3d fix64 err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d fix64 %d\n", index, tag, u) - - case WireVarint: - u, err = p.DecodeVarint() - if err != nil { - fmt.Printf("%3d: t=%3d varint err %v\n", index, tag, err) - break out - } - fmt.Printf("%3d: t=%3d varint %d\n", index, tag, u) - - case WireStartGroup: - fmt.Printf("%3d: t=%3d start\n", index, tag) - depth++ - - case WireEndGroup: - depth-- - fmt.Printf("%3d: t=%3d end\n", index, tag) - } - } - - if depth != 0 { - fmt.Printf("%3d: start-end not balanced %d\n", p.index, depth) - } - fmt.Printf("\n") - - p.buf = obuf - p.index = index -} - -// SetDefaults sets unset protocol buffer fields to their default values. -// It only modifies fields that are both unset and have defined defaults. -// It recursively sets default values in any non-nil sub-messages. -func SetDefaults(pb Message) { - setDefaults(reflect.ValueOf(pb), true, false) -} - -// v is a pointer to a struct. -func setDefaults(v reflect.Value, recur, zeros bool) { - v = v.Elem() - - defaultMu.RLock() - dm, ok := defaults[v.Type()] - defaultMu.RUnlock() - if !ok { - dm = buildDefaultMessage(v.Type()) - defaultMu.Lock() - defaults[v.Type()] = dm - defaultMu.Unlock() - } - - for _, sf := range dm.scalars { - f := v.Field(sf.index) - if !f.IsNil() { - // field already set - continue - } - dv := sf.value - if dv == nil && !zeros { - // no explicit default, and don't want to set zeros - continue - } - fptr := f.Addr().Interface() // **T - // TODO: Consider batching the allocations we do here. - switch sf.kind { - case reflect.Bool: - b := new(bool) - if dv != nil { - *b = dv.(bool) - } - *(fptr.(**bool)) = b - case reflect.Float32: - f := new(float32) - if dv != nil { - *f = dv.(float32) - } - *(fptr.(**float32)) = f - case reflect.Float64: - f := new(float64) - if dv != nil { - *f = dv.(float64) - } - *(fptr.(**float64)) = f - case reflect.Int32: - // might be an enum - if ft := f.Type(); ft != int32PtrType { - // enum - f.Set(reflect.New(ft.Elem())) - if dv != nil { - f.Elem().SetInt(int64(dv.(int32))) - } - } else { - // int32 field - i := new(int32) - if dv != nil { - *i = dv.(int32) - } - *(fptr.(**int32)) = i - } - case reflect.Int64: - i := new(int64) - if dv != nil { - *i = dv.(int64) - } - *(fptr.(**int64)) = i - case reflect.String: - s := new(string) - if dv != nil { - *s = dv.(string) - } - *(fptr.(**string)) = s - case reflect.Uint8: - // exceptional case: []byte - var b []byte - if dv != nil { - db := dv.([]byte) - b = make([]byte, len(db)) - copy(b, db) - } else { - b = []byte{} - } - *(fptr.(*[]byte)) = b - case reflect.Uint32: - u := new(uint32) - if dv != nil { - *u = dv.(uint32) - } - *(fptr.(**uint32)) = u - case reflect.Uint64: - u := new(uint64) - if dv != nil { - *u = dv.(uint64) - } - *(fptr.(**uint64)) = u - default: - log.Printf("proto: can't set default for field %v (sf.kind=%v)", f, sf.kind) - } - } - - for _, ni := range dm.nested { - f := v.Field(ni) - // f is *T or []*T or map[T]*T - switch f.Kind() { - case reflect.Ptr: - if f.IsNil() { - continue - } - setDefaults(f, recur, zeros) - - case reflect.Slice: - for i := 0; i < f.Len(); i++ { - e := f.Index(i) - if e.IsNil() { - continue - } - setDefaults(e, recur, zeros) - } - - case reflect.Map: - for _, k := range f.MapKeys() { - e := f.MapIndex(k) - if e.IsNil() { - continue - } - setDefaults(e, recur, zeros) - } - } - } -} - -var ( - // defaults maps a protocol buffer struct type to a slice of the fields, - // with its scalar fields set to their proto-declared non-zero default values. - defaultMu sync.RWMutex - defaults = make(map[reflect.Type]defaultMessage) - - int32PtrType = reflect.TypeOf((*int32)(nil)) -) - -// defaultMessage represents information about the default values of a message. -type defaultMessage struct { - scalars []scalarField - nested []int // struct field index of nested messages -} - -type scalarField struct { - index int // struct field index - kind reflect.Kind // element type (the T in *T or []T) - value interface{} // the proto-declared default value, or nil -} - -// t is a struct type. -func buildDefaultMessage(t reflect.Type) (dm defaultMessage) { - sprop := GetProperties(t) - for _, prop := range sprop.Prop { - fi, ok := sprop.decoderTags.get(prop.Tag) - if !ok { - // XXX_unrecognized - continue - } - ft := t.Field(fi).Type - - sf, nested, err := fieldDefault(ft, prop) - switch { - case err != nil: - log.Print(err) - case nested: - dm.nested = append(dm.nested, fi) - case sf != nil: - sf.index = fi - dm.scalars = append(dm.scalars, *sf) - } - } - - return dm -} - -// fieldDefault returns the scalarField for field type ft. -// sf will be nil if the field can not have a default. -// nestedMessage will be true if this is a nested message. -// Note that sf.index is not set on return. -func fieldDefault(ft reflect.Type, prop *Properties) (sf *scalarField, nestedMessage bool, err error) { - var canHaveDefault bool - switch ft.Kind() { - case reflect.Ptr: - if ft.Elem().Kind() == reflect.Struct { - nestedMessage = true - } else { - canHaveDefault = true // proto2 scalar field - } - - case reflect.Slice: - switch ft.Elem().Kind() { - case reflect.Ptr: - nestedMessage = true // repeated message - case reflect.Uint8: - canHaveDefault = true // bytes field - } - - case reflect.Map: - if ft.Elem().Kind() == reflect.Ptr { - nestedMessage = true // map with message values - } - } - - if !canHaveDefault { - if nestedMessage { - return nil, true, nil - } - return nil, false, nil - } - - // We now know that ft is a pointer or slice. - sf = &scalarField{kind: ft.Elem().Kind()} - - // scalar fields without defaults - if !prop.HasDefault { - return sf, false, nil - } - - // a scalar field: either *T or []byte - switch ft.Elem().Kind() { - case reflect.Bool: - x, err := strconv.ParseBool(prop.Default) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default bool %q: %v", prop.Default, err) - } - sf.value = x - case reflect.Float32: - x, err := strconv.ParseFloat(prop.Default, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default float32 %q: %v", prop.Default, err) - } - sf.value = float32(x) - case reflect.Float64: - x, err := strconv.ParseFloat(prop.Default, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default float64 %q: %v", prop.Default, err) - } - sf.value = x - case reflect.Int32: - x, err := strconv.ParseInt(prop.Default, 10, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default int32 %q: %v", prop.Default, err) - } - sf.value = int32(x) - case reflect.Int64: - x, err := strconv.ParseInt(prop.Default, 10, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default int64 %q: %v", prop.Default, err) - } - sf.value = x - case reflect.String: - sf.value = prop.Default - case reflect.Uint8: - // []byte (not *uint8) - sf.value = []byte(prop.Default) - case reflect.Uint32: - x, err := strconv.ParseUint(prop.Default, 10, 32) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default uint32 %q: %v", prop.Default, err) - } - sf.value = uint32(x) - case reflect.Uint64: - x, err := strconv.ParseUint(prop.Default, 10, 64) - if err != nil { - return nil, false, fmt.Errorf("proto: bad default uint64 %q: %v", prop.Default, err) - } - sf.value = x - default: - return nil, false, fmt.Errorf("proto: unhandled def kind %v", ft.Elem().Kind()) - } - - return sf, false, nil -} - -// Map fields may have key types of non-float scalars, strings and enums. -// The easiest way to sort them in some deterministic order is to use fmt. -// If this turns out to be inefficient we can always consider other options, -// such as doing a Schwartzian transform. - -func mapKeys(vs []reflect.Value) sort.Interface { - s := mapKeySorter{ - vs: vs, - // default Less function: textual comparison - less: func(a, b reflect.Value) bool { - return fmt.Sprint(a.Interface()) < fmt.Sprint(b.Interface()) - }, - } - - // Type specialization per https://developers.google.com/protocol-buffers/docs/proto#maps; - // numeric keys are sorted numerically. - if len(vs) == 0 { - return s - } - switch vs[0].Kind() { - case reflect.Int32, reflect.Int64: - s.less = func(a, b reflect.Value) bool { return a.Int() < b.Int() } - case reflect.Uint32, reflect.Uint64: - s.less = func(a, b reflect.Value) bool { return a.Uint() < b.Uint() } - } - - return s -} - -type mapKeySorter struct { - vs []reflect.Value - less func(a, b reflect.Value) bool -} - -func (s mapKeySorter) Len() int { return len(s.vs) } -func (s mapKeySorter) Swap(i, j int) { s.vs[i], s.vs[j] = s.vs[j], s.vs[i] } -func (s mapKeySorter) Less(i, j int) bool { - return s.less(s.vs[i], s.vs[j]) -} - -// isProto3Zero reports whether v is a zero proto3 value. -func isProto3Zero(v reflect.Value) bool { - switch v.Kind() { - case reflect.Bool: - return !v.Bool() - case reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Uint32, reflect.Uint64: - return v.Uint() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.String: - return v.String() == "" - } - return false -} - -// ProtoPackageIsVersion2 is referenced from generated protocol buffer files -// to assert that that code is compatible with this version of the proto package. -const ProtoPackageIsVersion2 = true - -// ProtoPackageIsVersion1 is referenced from generated protocol buffer files -// to assert that that code is compatible with this version of the proto package. -const ProtoPackageIsVersion1 = true diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/message_set.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/message_set.go deleted file mode 100644 index fd982de..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/message_set.go +++ /dev/null @@ -1,311 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Support for message sets. - */ - -import ( - "bytes" - "encoding/json" - "errors" - "fmt" - "reflect" - "sort" -) - -// errNoMessageTypeID occurs when a protocol buffer does not have a message type ID. -// A message type ID is required for storing a protocol buffer in a message set. -var errNoMessageTypeID = errors.New("proto does not have a message type ID") - -// The first two types (_MessageSet_Item and messageSet) -// model what the protocol compiler produces for the following protocol message: -// message MessageSet { -// repeated group Item = 1 { -// required int32 type_id = 2; -// required string message = 3; -// }; -// } -// That is the MessageSet wire format. We can't use a proto to generate these -// because that would introduce a circular dependency between it and this package. - -type _MessageSet_Item struct { - TypeId *int32 `protobuf:"varint,2,req,name=type_id"` - Message []byte `protobuf:"bytes,3,req,name=message"` -} - -type messageSet struct { - Item []*_MessageSet_Item `protobuf:"group,1,rep"` - XXX_unrecognized []byte - // TODO: caching? -} - -// Make sure messageSet is a Message. -var _ Message = (*messageSet)(nil) - -// messageTypeIder is an interface satisfied by a protocol buffer type -// that may be stored in a MessageSet. -type messageTypeIder interface { - MessageTypeId() int32 -} - -func (ms *messageSet) find(pb Message) *_MessageSet_Item { - mti, ok := pb.(messageTypeIder) - if !ok { - return nil - } - id := mti.MessageTypeId() - for _, item := range ms.Item { - if *item.TypeId == id { - return item - } - } - return nil -} - -func (ms *messageSet) Has(pb Message) bool { - if ms.find(pb) != nil { - return true - } - return false -} - -func (ms *messageSet) Unmarshal(pb Message) error { - if item := ms.find(pb); item != nil { - return Unmarshal(item.Message, pb) - } - if _, ok := pb.(messageTypeIder); !ok { - return errNoMessageTypeID - } - return nil // TODO: return error instead? -} - -func (ms *messageSet) Marshal(pb Message) error { - msg, err := Marshal(pb) - if err != nil { - return err - } - if item := ms.find(pb); item != nil { - // reuse existing item - item.Message = msg - return nil - } - - mti, ok := pb.(messageTypeIder) - if !ok { - return errNoMessageTypeID - } - - mtid := mti.MessageTypeId() - ms.Item = append(ms.Item, &_MessageSet_Item{ - TypeId: &mtid, - Message: msg, - }) - return nil -} - -func (ms *messageSet) Reset() { *ms = messageSet{} } -func (ms *messageSet) String() string { return CompactTextString(ms) } -func (*messageSet) ProtoMessage() {} - -// Support for the message_set_wire_format message option. - -func skipVarint(buf []byte) []byte { - i := 0 - for ; buf[i]&0x80 != 0; i++ { - } - return buf[i+1:] -} - -// MarshalMessageSet encodes the extension map represented by m in the message set wire format. -// It is called by generated Marshal methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSet(exts interface{}) ([]byte, error) { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - if err := encodeExtensions(exts); err != nil { - return nil, err - } - m, _ = exts.extensionsRead() - case map[int32]Extension: - if err := encodeExtensionsMap(exts); err != nil { - return nil, err - } - m = exts - default: - return nil, errors.New("proto: not an extension map") - } - - // Sort extension IDs to provide a deterministic encoding. - // See also enc_map in encode.go. - ids := make([]int, 0, len(m)) - for id := range m { - ids = append(ids, int(id)) - } - sort.Ints(ids) - - ms := &messageSet{Item: make([]*_MessageSet_Item, 0, len(m))} - for _, id := range ids { - e := m[int32(id)] - // Remove the wire type and field number varint, as well as the length varint. - msg := skipVarint(skipVarint(e.enc)) - - ms.Item = append(ms.Item, &_MessageSet_Item{ - TypeId: Int32(int32(id)), - Message: msg, - }) - } - return Marshal(ms) -} - -// UnmarshalMessageSet decodes the extension map encoded in buf in the message set wire format. -// It is called by generated Unmarshal methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSet(buf []byte, exts interface{}) error { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - m = exts.extensionsWrite() - case map[int32]Extension: - m = exts - default: - return errors.New("proto: not an extension map") - } - - ms := new(messageSet) - if err := Unmarshal(buf, ms); err != nil { - return err - } - for _, item := range ms.Item { - id := *item.TypeId - msg := item.Message - - // Restore wire type and field number varint, plus length varint. - // Be careful to preserve duplicate items. - b := EncodeVarint(uint64(id)<<3 | WireBytes) - if ext, ok := m[id]; ok { - // Existing data; rip off the tag and length varint - // so we join the new data correctly. - // We can assume that ext.enc is set because we are unmarshaling. - o := ext.enc[len(b):] // skip wire type and field number - _, n := DecodeVarint(o) // calculate length of length varint - o = o[n:] // skip length varint - msg = append(o, msg...) // join old data and new data - } - b = append(b, EncodeVarint(uint64(len(msg)))...) - b = append(b, msg...) - - m[id] = Extension{enc: b} - } - return nil -} - -// MarshalMessageSetJSON encodes the extension map represented by m in JSON format. -// It is called by generated MarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func MarshalMessageSetJSON(exts interface{}) ([]byte, error) { - var m map[int32]Extension - switch exts := exts.(type) { - case *XXX_InternalExtensions: - m, _ = exts.extensionsRead() - case map[int32]Extension: - m = exts - default: - return nil, errors.New("proto: not an extension map") - } - var b bytes.Buffer - b.WriteByte('{') - - // Process the map in key order for deterministic output. - ids := make([]int32, 0, len(m)) - for id := range m { - ids = append(ids, id) - } - sort.Sort(int32Slice(ids)) // int32Slice defined in text.go - - for i, id := range ids { - ext := m[id] - if i > 0 { - b.WriteByte(',') - } - - msd, ok := messageSetMap[id] - if !ok { - // Unknown type; we can't render it, so skip it. - continue - } - fmt.Fprintf(&b, `"[%s]":`, msd.name) - - x := ext.value - if x == nil { - x = reflect.New(msd.t.Elem()).Interface() - if err := Unmarshal(ext.enc, x.(Message)); err != nil { - return nil, err - } - } - d, err := json.Marshal(x) - if err != nil { - return nil, err - } - b.Write(d) - } - b.WriteByte('}') - return b.Bytes(), nil -} - -// UnmarshalMessageSetJSON decodes the extension map encoded in buf in JSON format. -// It is called by generated UnmarshalJSON methods on protocol buffer messages with the message_set_wire_format option. -func UnmarshalMessageSetJSON(buf []byte, exts interface{}) error { - // Common-case fast path. - if len(buf) == 0 || bytes.Equal(buf, []byte("{}")) { - return nil - } - - // This is fairly tricky, and it's not clear that it is needed. - return errors.New("TODO: UnmarshalMessageSetJSON not yet implemented") -} - -// A global registry of types that can be used in a MessageSet. - -var messageSetMap = make(map[int32]messageSetDesc) - -type messageSetDesc struct { - t reflect.Type // pointer to struct - name string -} - -// RegisterMessageSetType is called from the generated code. -func RegisterMessageSetType(m Message, fieldNum int32, name string) { - messageSetMap[fieldNum] = messageSetDesc{ - t: reflect.TypeOf(m), - name: name, - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_reflect.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_reflect.go deleted file mode 100644 index fb512e2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_reflect.go +++ /dev/null @@ -1,484 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2012 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// +build appengine js - -// This file contains an implementation of proto field accesses using package reflect. -// It is slower than the code in pointer_unsafe.go but it avoids package unsafe and can -// be used on App Engine. - -package proto - -import ( - "math" - "reflect" -) - -// A structPointer is a pointer to a struct. -type structPointer struct { - v reflect.Value -} - -// toStructPointer returns a structPointer equivalent to the given reflect value. -// The reflect value must itself be a pointer to a struct. -func toStructPointer(v reflect.Value) structPointer { - return structPointer{v} -} - -// IsNil reports whether p is nil. -func structPointer_IsNil(p structPointer) bool { - return p.v.IsNil() -} - -// Interface returns the struct pointer as an interface value. -func structPointer_Interface(p structPointer, _ reflect.Type) interface{} { - return p.v.Interface() -} - -// A field identifies a field in a struct, accessible from a structPointer. -// In this implementation, a field is identified by the sequence of field indices -// passed to reflect's FieldByIndex. -type field []int - -// toField returns a field equivalent to the given reflect field. -func toField(f *reflect.StructField) field { - return f.Index -} - -// invalidField is an invalid field identifier. -var invalidField = field(nil) - -// IsValid reports whether the field identifier is valid. -func (f field) IsValid() bool { return f != nil } - -// field returns the given field in the struct as a reflect value. -func structPointer_field(p structPointer, f field) reflect.Value { - // Special case: an extension map entry with a value of type T - // passes a *T to the struct-handling code with a zero field, - // expecting that it will be treated as equivalent to *struct{ X T }, - // which has the same memory layout. We have to handle that case - // specially, because reflect will panic if we call FieldByIndex on a - // non-struct. - if f == nil { - return p.v.Elem() - } - - return p.v.Elem().FieldByIndex(f) -} - -// ifield returns the given field in the struct as an interface value. -func structPointer_ifield(p structPointer, f field) interface{} { - return structPointer_field(p, f).Addr().Interface() -} - -// Bytes returns the address of a []byte field in the struct. -func structPointer_Bytes(p structPointer, f field) *[]byte { - return structPointer_ifield(p, f).(*[]byte) -} - -// BytesSlice returns the address of a [][]byte field in the struct. -func structPointer_BytesSlice(p structPointer, f field) *[][]byte { - return structPointer_ifield(p, f).(*[][]byte) -} - -// Bool returns the address of a *bool field in the struct. -func structPointer_Bool(p structPointer, f field) **bool { - return structPointer_ifield(p, f).(**bool) -} - -// BoolVal returns the address of a bool field in the struct. -func structPointer_BoolVal(p structPointer, f field) *bool { - return structPointer_ifield(p, f).(*bool) -} - -// BoolSlice returns the address of a []bool field in the struct. -func structPointer_BoolSlice(p structPointer, f field) *[]bool { - return structPointer_ifield(p, f).(*[]bool) -} - -// String returns the address of a *string field in the struct. -func structPointer_String(p structPointer, f field) **string { - return structPointer_ifield(p, f).(**string) -} - -// StringVal returns the address of a string field in the struct. -func structPointer_StringVal(p structPointer, f field) *string { - return structPointer_ifield(p, f).(*string) -} - -// StringSlice returns the address of a []string field in the struct. -func structPointer_StringSlice(p structPointer, f field) *[]string { - return structPointer_ifield(p, f).(*[]string) -} - -// Extensions returns the address of an extension map field in the struct. -func structPointer_Extensions(p structPointer, f field) *XXX_InternalExtensions { - return structPointer_ifield(p, f).(*XXX_InternalExtensions) -} - -// ExtMap returns the address of an extension map field in the struct. -func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { - return structPointer_ifield(p, f).(*map[int32]Extension) -} - -// NewAt returns the reflect.Value for a pointer to a field in the struct. -func structPointer_NewAt(p structPointer, f field, typ reflect.Type) reflect.Value { - return structPointer_field(p, f).Addr() -} - -// SetStructPointer writes a *struct field in the struct. -func structPointer_SetStructPointer(p structPointer, f field, q structPointer) { - structPointer_field(p, f).Set(q.v) -} - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return structPointer{structPointer_field(p, f)} -} - -// StructPointerSlice the address of a []*struct field in the struct. -func structPointer_StructPointerSlice(p structPointer, f field) structPointerSlice { - return structPointerSlice{structPointer_field(p, f)} -} - -// A structPointerSlice represents the address of a slice of pointers to structs -// (themselves messages or groups). That is, v.Type() is *[]*struct{...}. -type structPointerSlice struct { - v reflect.Value -} - -func (p structPointerSlice) Len() int { return p.v.Len() } -func (p structPointerSlice) Index(i int) structPointer { return structPointer{p.v.Index(i)} } -func (p structPointerSlice) Append(q structPointer) { - p.v.Set(reflect.Append(p.v, q.v)) -} - -var ( - int32Type = reflect.TypeOf(int32(0)) - uint32Type = reflect.TypeOf(uint32(0)) - float32Type = reflect.TypeOf(float32(0)) - int64Type = reflect.TypeOf(int64(0)) - uint64Type = reflect.TypeOf(uint64(0)) - float64Type = reflect.TypeOf(float64(0)) -) - -// A word32 represents a field of type *int32, *uint32, *float32, or *enum. -// That is, v.Type() is *int32, *uint32, *float32, or *enum and v is assignable. -type word32 struct { - v reflect.Value -} - -// IsNil reports whether p is nil. -func word32_IsNil(p word32) bool { - return p.v.IsNil() -} - -// Set sets p to point at a newly allocated word with bits set to x. -func word32_Set(p word32, o *Buffer, x uint32) { - t := p.v.Type().Elem() - switch t { - case int32Type: - if len(o.int32s) == 0 { - o.int32s = make([]int32, uint32PoolSize) - } - o.int32s[0] = int32(x) - p.v.Set(reflect.ValueOf(&o.int32s[0])) - o.int32s = o.int32s[1:] - return - case uint32Type: - if len(o.uint32s) == 0 { - o.uint32s = make([]uint32, uint32PoolSize) - } - o.uint32s[0] = x - p.v.Set(reflect.ValueOf(&o.uint32s[0])) - o.uint32s = o.uint32s[1:] - return - case float32Type: - if len(o.float32s) == 0 { - o.float32s = make([]float32, uint32PoolSize) - } - o.float32s[0] = math.Float32frombits(x) - p.v.Set(reflect.ValueOf(&o.float32s[0])) - o.float32s = o.float32s[1:] - return - } - - // must be enum - p.v.Set(reflect.New(t)) - p.v.Elem().SetInt(int64(int32(x))) -} - -// Get gets the bits pointed at by p, as a uint32. -func word32_Get(p word32) uint32 { - elem := p.v.Elem() - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32 returns a reference to a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32(p structPointer, f field) word32 { - return word32{structPointer_field(p, f)} -} - -// A word32Val represents a field of type int32, uint32, float32, or enum. -// That is, v.Type() is int32, uint32, float32, or enum and v is assignable. -type word32Val struct { - v reflect.Value -} - -// Set sets *p to x. -func word32Val_Set(p word32Val, x uint32) { - switch p.v.Type() { - case int32Type: - p.v.SetInt(int64(x)) - return - case uint32Type: - p.v.SetUint(uint64(x)) - return - case float32Type: - p.v.SetFloat(float64(math.Float32frombits(x))) - return - } - - // must be enum - p.v.SetInt(int64(int32(x))) -} - -// Get gets the bits pointed at by p, as a uint32. -func word32Val_Get(p word32Val) uint32 { - elem := p.v - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32Val returns a reference to a int32, uint32, float32, or enum field in the struct. -func structPointer_Word32Val(p structPointer, f field) word32Val { - return word32Val{structPointer_field(p, f)} -} - -// A word32Slice is a slice of 32-bit values. -// That is, v.Type() is []int32, []uint32, []float32, or []enum. -type word32Slice struct { - v reflect.Value -} - -func (p word32Slice) Append(x uint32) { - n, m := p.v.Len(), p.v.Cap() - if n < m { - p.v.SetLen(n + 1) - } else { - t := p.v.Type().Elem() - p.v.Set(reflect.Append(p.v, reflect.Zero(t))) - } - elem := p.v.Index(n) - switch elem.Kind() { - case reflect.Int32: - elem.SetInt(int64(int32(x))) - case reflect.Uint32: - elem.SetUint(uint64(x)) - case reflect.Float32: - elem.SetFloat(float64(math.Float32frombits(x))) - } -} - -func (p word32Slice) Len() int { - return p.v.Len() -} - -func (p word32Slice) Index(i int) uint32 { - elem := p.v.Index(i) - switch elem.Kind() { - case reflect.Int32: - return uint32(elem.Int()) - case reflect.Uint32: - return uint32(elem.Uint()) - case reflect.Float32: - return math.Float32bits(float32(elem.Float())) - } - panic("unreachable") -} - -// Word32Slice returns a reference to a []int32, []uint32, []float32, or []enum field in the struct. -func structPointer_Word32Slice(p structPointer, f field) word32Slice { - return word32Slice{structPointer_field(p, f)} -} - -// word64 is like word32 but for 64-bit values. -type word64 struct { - v reflect.Value -} - -func word64_Set(p word64, o *Buffer, x uint64) { - t := p.v.Type().Elem() - switch t { - case int64Type: - if len(o.int64s) == 0 { - o.int64s = make([]int64, uint64PoolSize) - } - o.int64s[0] = int64(x) - p.v.Set(reflect.ValueOf(&o.int64s[0])) - o.int64s = o.int64s[1:] - return - case uint64Type: - if len(o.uint64s) == 0 { - o.uint64s = make([]uint64, uint64PoolSize) - } - o.uint64s[0] = x - p.v.Set(reflect.ValueOf(&o.uint64s[0])) - o.uint64s = o.uint64s[1:] - return - case float64Type: - if len(o.float64s) == 0 { - o.float64s = make([]float64, uint64PoolSize) - } - o.float64s[0] = math.Float64frombits(x) - p.v.Set(reflect.ValueOf(&o.float64s[0])) - o.float64s = o.float64s[1:] - return - } - panic("unreachable") -} - -func word64_IsNil(p word64) bool { - return p.v.IsNil() -} - -func word64_Get(p word64) uint64 { - elem := p.v.Elem() - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return elem.Uint() - case reflect.Float64: - return math.Float64bits(elem.Float()) - } - panic("unreachable") -} - -func structPointer_Word64(p structPointer, f field) word64 { - return word64{structPointer_field(p, f)} -} - -// word64Val is like word32Val but for 64-bit values. -type word64Val struct { - v reflect.Value -} - -func word64Val_Set(p word64Val, o *Buffer, x uint64) { - switch p.v.Type() { - case int64Type: - p.v.SetInt(int64(x)) - return - case uint64Type: - p.v.SetUint(x) - return - case float64Type: - p.v.SetFloat(math.Float64frombits(x)) - return - } - panic("unreachable") -} - -func word64Val_Get(p word64Val) uint64 { - elem := p.v - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return elem.Uint() - case reflect.Float64: - return math.Float64bits(elem.Float()) - } - panic("unreachable") -} - -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val{structPointer_field(p, f)} -} - -type word64Slice struct { - v reflect.Value -} - -func (p word64Slice) Append(x uint64) { - n, m := p.v.Len(), p.v.Cap() - if n < m { - p.v.SetLen(n + 1) - } else { - t := p.v.Type().Elem() - p.v.Set(reflect.Append(p.v, reflect.Zero(t))) - } - elem := p.v.Index(n) - switch elem.Kind() { - case reflect.Int64: - elem.SetInt(int64(int64(x))) - case reflect.Uint64: - elem.SetUint(uint64(x)) - case reflect.Float64: - elem.SetFloat(float64(math.Float64frombits(x))) - } -} - -func (p word64Slice) Len() int { - return p.v.Len() -} - -func (p word64Slice) Index(i int) uint64 { - elem := p.v.Index(i) - switch elem.Kind() { - case reflect.Int64: - return uint64(elem.Int()) - case reflect.Uint64: - return uint64(elem.Uint()) - case reflect.Float64: - return math.Float64bits(float64(elem.Float())) - } - panic("unreachable") -} - -func structPointer_Word64Slice(p structPointer, f field) word64Slice { - return word64Slice{structPointer_field(p, f)} -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go deleted file mode 100644 index 6b5567d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/pointer_unsafe.go +++ /dev/null @@ -1,270 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2012 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -// +build !appengine,!js - -// This file contains the implementation of the proto field accesses using package unsafe. - -package proto - -import ( - "reflect" - "unsafe" -) - -// NOTE: These type_Foo functions would more idiomatically be methods, -// but Go does not allow methods on pointer types, and we must preserve -// some pointer type for the garbage collector. We use these -// funcs with clunky names as our poor approximation to methods. -// -// An alternative would be -// type structPointer struct { p unsafe.Pointer } -// but that does not registerize as well. - -// A structPointer is a pointer to a struct. -type structPointer unsafe.Pointer - -// toStructPointer returns a structPointer equivalent to the given reflect value. -func toStructPointer(v reflect.Value) structPointer { - return structPointer(unsafe.Pointer(v.Pointer())) -} - -// IsNil reports whether p is nil. -func structPointer_IsNil(p structPointer) bool { - return p == nil -} - -// Interface returns the struct pointer, assumed to have element type t, -// as an interface value. -func structPointer_Interface(p structPointer, t reflect.Type) interface{} { - return reflect.NewAt(t, unsafe.Pointer(p)).Interface() -} - -// A field identifies a field in a struct, accessible from a structPointer. -// In this implementation, a field is identified by its byte offset from the start of the struct. -type field uintptr - -// toField returns a field equivalent to the given reflect field. -func toField(f *reflect.StructField) field { - return field(f.Offset) -} - -// invalidField is an invalid field identifier. -const invalidField = ^field(0) - -// IsValid reports whether the field identifier is valid. -func (f field) IsValid() bool { - return f != ^field(0) -} - -// Bytes returns the address of a []byte field in the struct. -func structPointer_Bytes(p structPointer, f field) *[]byte { - return (*[]byte)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BytesSlice returns the address of a [][]byte field in the struct. -func structPointer_BytesSlice(p structPointer, f field) *[][]byte { - return (*[][]byte)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// Bool returns the address of a *bool field in the struct. -func structPointer_Bool(p structPointer, f field) **bool { - return (**bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BoolVal returns the address of a bool field in the struct. -func structPointer_BoolVal(p structPointer, f field) *bool { - return (*bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// BoolSlice returns the address of a []bool field in the struct. -func structPointer_BoolSlice(p structPointer, f field) *[]bool { - return (*[]bool)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// String returns the address of a *string field in the struct. -func structPointer_String(p structPointer, f field) **string { - return (**string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StringVal returns the address of a string field in the struct. -func structPointer_StringVal(p structPointer, f field) *string { - return (*string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StringSlice returns the address of a []string field in the struct. -func structPointer_StringSlice(p structPointer, f field) *[]string { - return (*[]string)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// ExtMap returns the address of an extension map field in the struct. -func structPointer_Extensions(p structPointer, f field) *XXX_InternalExtensions { - return (*XXX_InternalExtensions)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -func structPointer_ExtMap(p structPointer, f field) *map[int32]Extension { - return (*map[int32]Extension)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// NewAt returns the reflect.Value for a pointer to a field in the struct. -func structPointer_NewAt(p structPointer, f field, typ reflect.Type) reflect.Value { - return reflect.NewAt(typ, unsafe.Pointer(uintptr(p)+uintptr(f))) -} - -// SetStructPointer writes a *struct field in the struct. -func structPointer_SetStructPointer(p structPointer, f field, q structPointer) { - *(*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f))) = q -} - -// GetStructPointer reads a *struct field in the struct. -func structPointer_GetStructPointer(p structPointer, f field) structPointer { - return *(*structPointer)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// StructPointerSlice the address of a []*struct field in the struct. -func structPointer_StructPointerSlice(p structPointer, f field) *structPointerSlice { - return (*structPointerSlice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// A structPointerSlice represents a slice of pointers to structs (themselves submessages or groups). -type structPointerSlice []structPointer - -func (v *structPointerSlice) Len() int { return len(*v) } -func (v *structPointerSlice) Index(i int) structPointer { return (*v)[i] } -func (v *structPointerSlice) Append(p structPointer) { *v = append(*v, p) } - -// A word32 is the address of a "pointer to 32-bit value" field. -type word32 **uint32 - -// IsNil reports whether *v is nil. -func word32_IsNil(p word32) bool { - return *p == nil -} - -// Set sets *v to point at a newly allocated word set to x. -func word32_Set(p word32, o *Buffer, x uint32) { - if len(o.uint32s) == 0 { - o.uint32s = make([]uint32, uint32PoolSize) - } - o.uint32s[0] = x - *p = &o.uint32s[0] - o.uint32s = o.uint32s[1:] -} - -// Get gets the value pointed at by *v. -func word32_Get(p word32) uint32 { - return **p -} - -// Word32 returns the address of a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32(p structPointer, f field) word32 { - return word32((**uint32)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// A word32Val is the address of a 32-bit value field. -type word32Val *uint32 - -// Set sets *p to x. -func word32Val_Set(p word32Val, x uint32) { - *p = x -} - -// Get gets the value pointed at by p. -func word32Val_Get(p word32Val) uint32 { - return *p -} - -// Word32Val returns the address of a *int32, *uint32, *float32, or *enum field in the struct. -func structPointer_Word32Val(p structPointer, f field) word32Val { - return word32Val((*uint32)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// A word32Slice is a slice of 32-bit values. -type word32Slice []uint32 - -func (v *word32Slice) Append(x uint32) { *v = append(*v, x) } -func (v *word32Slice) Len() int { return len(*v) } -func (v *word32Slice) Index(i int) uint32 { return (*v)[i] } - -// Word32Slice returns the address of a []int32, []uint32, []float32, or []enum field in the struct. -func structPointer_Word32Slice(p structPointer, f field) *word32Slice { - return (*word32Slice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} - -// word64 is like word32 but for 64-bit values. -type word64 **uint64 - -func word64_Set(p word64, o *Buffer, x uint64) { - if len(o.uint64s) == 0 { - o.uint64s = make([]uint64, uint64PoolSize) - } - o.uint64s[0] = x - *p = &o.uint64s[0] - o.uint64s = o.uint64s[1:] -} - -func word64_IsNil(p word64) bool { - return *p == nil -} - -func word64_Get(p word64) uint64 { - return **p -} - -func structPointer_Word64(p structPointer, f field) word64 { - return word64((**uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// word64Val is like word32Val but for 64-bit values. -type word64Val *uint64 - -func word64Val_Set(p word64Val, o *Buffer, x uint64) { - *p = x -} - -func word64Val_Get(p word64Val) uint64 { - return *p -} - -func structPointer_Word64Val(p structPointer, f field) word64Val { - return word64Val((*uint64)(unsafe.Pointer(uintptr(p) + uintptr(f)))) -} - -// word64Slice is like word32Slice but for 64-bit values. -type word64Slice []uint64 - -func (v *word64Slice) Append(x uint64) { *v = append(*v, x) } -func (v *word64Slice) Len() int { return len(*v) } -func (v *word64Slice) Index(i int) uint64 { return (*v)[i] } - -func structPointer_Word64Slice(p structPointer, f field) *word64Slice { - return (*word64Slice)(unsafe.Pointer(uintptr(p) + uintptr(f))) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/properties.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/properties.go deleted file mode 100644 index 69ddda8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/properties.go +++ /dev/null @@ -1,864 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -/* - * Routines for encoding data into the wire format for protocol buffers. - */ - -import ( - "fmt" - "log" - "os" - "reflect" - "sort" - "strconv" - "strings" - "sync" -) - -const debug bool = false - -// Constants that identify the encoding of a value on the wire. -const ( - WireVarint = 0 - WireFixed64 = 1 - WireBytes = 2 - WireStartGroup = 3 - WireEndGroup = 4 - WireFixed32 = 5 -) - -const startSize = 10 // initial slice/string sizes - -// Encoders are defined in encode.go -// An encoder outputs the full representation of a field, including its -// tag and encoder type. -type encoder func(p *Buffer, prop *Properties, base structPointer) error - -// A valueEncoder encodes a single integer in a particular encoding. -type valueEncoder func(o *Buffer, x uint64) error - -// Sizers are defined in encode.go -// A sizer returns the encoded size of a field, including its tag and encoder -// type. -type sizer func(prop *Properties, base structPointer) int - -// A valueSizer returns the encoded size of a single integer in a particular -// encoding. -type valueSizer func(x uint64) int - -// Decoders are defined in decode.go -// A decoder creates a value from its wire representation. -// Unrecognized subelements are saved in unrec. -type decoder func(p *Buffer, prop *Properties, base structPointer) error - -// A valueDecoder decodes a single integer in a particular encoding. -type valueDecoder func(o *Buffer) (x uint64, err error) - -// A oneofMarshaler does the marshaling for all oneof fields in a message. -type oneofMarshaler func(Message, *Buffer) error - -// A oneofUnmarshaler does the unmarshaling for a oneof field in a message. -type oneofUnmarshaler func(Message, int, int, *Buffer) (bool, error) - -// A oneofSizer does the sizing for all oneof fields in a message. -type oneofSizer func(Message) int - -// tagMap is an optimization over map[int]int for typical protocol buffer -// use-cases. Encoded protocol buffers are often in tag order with small tag -// numbers. -type tagMap struct { - fastTags []int - slowTags map[int]int -} - -// tagMapFastLimit is the upper bound on the tag number that will be stored in -// the tagMap slice rather than its map. -const tagMapFastLimit = 1024 - -func (p *tagMap) get(t int) (int, bool) { - if t > 0 && t < tagMapFastLimit { - if t >= len(p.fastTags) { - return 0, false - } - fi := p.fastTags[t] - return fi, fi >= 0 - } - fi, ok := p.slowTags[t] - return fi, ok -} - -func (p *tagMap) put(t int, fi int) { - if t > 0 && t < tagMapFastLimit { - for len(p.fastTags) < t+1 { - p.fastTags = append(p.fastTags, -1) - } - p.fastTags[t] = fi - return - } - if p.slowTags == nil { - p.slowTags = make(map[int]int) - } - p.slowTags[t] = fi -} - -// StructProperties represents properties for all the fields of a struct. -// decoderTags and decoderOrigNames should only be used by the decoder. -type StructProperties struct { - Prop []*Properties // properties for each field - reqCount int // required count - decoderTags tagMap // map from proto tag to struct field number - decoderOrigNames map[string]int // map from original name to struct field number - order []int // list of struct field numbers in tag order - unrecField field // field id of the XXX_unrecognized []byte field - extendable bool // is this an extendable proto - - oneofMarshaler oneofMarshaler - oneofUnmarshaler oneofUnmarshaler - oneofSizer oneofSizer - stype reflect.Type - - // OneofTypes contains information about the oneof fields in this message. - // It is keyed by the original name of a field. - OneofTypes map[string]*OneofProperties -} - -// OneofProperties represents information about a specific field in a oneof. -type OneofProperties struct { - Type reflect.Type // pointer to generated struct type for this oneof field - Field int // struct field number of the containing oneof in the message - Prop *Properties -} - -// Implement the sorting interface so we can sort the fields in tag order, as recommended by the spec. -// See encode.go, (*Buffer).enc_struct. - -func (sp *StructProperties) Len() int { return len(sp.order) } -func (sp *StructProperties) Less(i, j int) bool { - return sp.Prop[sp.order[i]].Tag < sp.Prop[sp.order[j]].Tag -} -func (sp *StructProperties) Swap(i, j int) { sp.order[i], sp.order[j] = sp.order[j], sp.order[i] } - -// Properties represents the protocol-specific behavior of a single struct field. -type Properties struct { - Name string // name of the field, for error messages - OrigName string // original name before protocol compiler (always set) - JSONName string // name to use for JSON; determined by protoc - Wire string - WireType int - Tag int - Required bool - Optional bool - Repeated bool - Packed bool // relevant for repeated primitives only - Enum string // set for enum types only - proto3 bool // whether this is known to be a proto3 field; set for []byte only - oneof bool // whether this is a oneof field - - Default string // default value - HasDefault bool // whether an explicit default was provided - def_uint64 uint64 - - enc encoder - valEnc valueEncoder // set for bool and numeric types only - field field - tagcode []byte // encoding of EncodeVarint((Tag<<3)|WireType) - tagbuf [8]byte - stype reflect.Type // set for struct types only - sprop *StructProperties // set for struct types only - isMarshaler bool - isUnmarshaler bool - - mtype reflect.Type // set for map types only - mkeyprop *Properties // set for map types only - mvalprop *Properties // set for map types only - - size sizer - valSize valueSizer // set for bool and numeric types only - - dec decoder - valDec valueDecoder // set for bool and numeric types only - - // If this is a packable field, this will be the decoder for the packed version of the field. - packedDec decoder -} - -// String formats the properties in the protobuf struct field tag style. -func (p *Properties) String() string { - s := p.Wire - s = "," - s += strconv.Itoa(p.Tag) - if p.Required { - s += ",req" - } - if p.Optional { - s += ",opt" - } - if p.Repeated { - s += ",rep" - } - if p.Packed { - s += ",packed" - } - s += ",name=" + p.OrigName - if p.JSONName != p.OrigName { - s += ",json=" + p.JSONName - } - if p.proto3 { - s += ",proto3" - } - if p.oneof { - s += ",oneof" - } - if len(p.Enum) > 0 { - s += ",enum=" + p.Enum - } - if p.HasDefault { - s += ",def=" + p.Default - } - return s -} - -// Parse populates p by parsing a string in the protobuf struct field tag style. -func (p *Properties) Parse(s string) { - // "bytes,49,opt,name=foo,def=hello!" - fields := strings.Split(s, ",") // breaks def=, but handled below. - if len(fields) < 2 { - fmt.Fprintf(os.Stderr, "proto: tag has too few fields: %q\n", s) - return - } - - p.Wire = fields[0] - switch p.Wire { - case "varint": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeVarint - p.valDec = (*Buffer).DecodeVarint - p.valSize = sizeVarint - case "fixed32": - p.WireType = WireFixed32 - p.valEnc = (*Buffer).EncodeFixed32 - p.valDec = (*Buffer).DecodeFixed32 - p.valSize = sizeFixed32 - case "fixed64": - p.WireType = WireFixed64 - p.valEnc = (*Buffer).EncodeFixed64 - p.valDec = (*Buffer).DecodeFixed64 - p.valSize = sizeFixed64 - case "zigzag32": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeZigzag32 - p.valDec = (*Buffer).DecodeZigzag32 - p.valSize = sizeZigzag32 - case "zigzag64": - p.WireType = WireVarint - p.valEnc = (*Buffer).EncodeZigzag64 - p.valDec = (*Buffer).DecodeZigzag64 - p.valSize = sizeZigzag64 - case "bytes", "group": - p.WireType = WireBytes - // no numeric converter for non-numeric types - default: - fmt.Fprintf(os.Stderr, "proto: tag has unknown wire type: %q\n", s) - return - } - - var err error - p.Tag, err = strconv.Atoi(fields[1]) - if err != nil { - return - } - - for i := 2; i < len(fields); i++ { - f := fields[i] - switch { - case f == "req": - p.Required = true - case f == "opt": - p.Optional = true - case f == "rep": - p.Repeated = true - case f == "packed": - p.Packed = true - case strings.HasPrefix(f, "name="): - p.OrigName = f[5:] - case strings.HasPrefix(f, "json="): - p.JSONName = f[5:] - case strings.HasPrefix(f, "enum="): - p.Enum = f[5:] - case f == "proto3": - p.proto3 = true - case f == "oneof": - p.oneof = true - case strings.HasPrefix(f, "def="): - p.HasDefault = true - p.Default = f[4:] // rest of string - if i+1 < len(fields) { - // Commas aren't escaped, and def is always last. - p.Default += "," + strings.Join(fields[i+1:], ",") - break - } - } - } -} - -func logNoSliceEnc(t1, t2 reflect.Type) { - fmt.Fprintf(os.Stderr, "proto: no slice oenc for %T = []%T\n", t1, t2) -} - -var protoMessageType = reflect.TypeOf((*Message)(nil)).Elem() - -// Initialize the fields for encoding and decoding. -func (p *Properties) setEncAndDec(typ reflect.Type, f *reflect.StructField, lockGetProp bool) { - p.enc = nil - p.dec = nil - p.size = nil - - switch t1 := typ; t1.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no coders for %v\n", t1) - - // proto3 scalar types - - case reflect.Bool: - p.enc = (*Buffer).enc_proto3_bool - p.dec = (*Buffer).dec_proto3_bool - p.size = size_proto3_bool - case reflect.Int32: - p.enc = (*Buffer).enc_proto3_int32 - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_proto3_int32 - case reflect.Uint32: - p.enc = (*Buffer).enc_proto3_uint32 - p.dec = (*Buffer).dec_proto3_int32 // can reuse - p.size = size_proto3_uint32 - case reflect.Int64, reflect.Uint64: - p.enc = (*Buffer).enc_proto3_int64 - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_proto3_int64 - case reflect.Float32: - p.enc = (*Buffer).enc_proto3_uint32 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int32 - p.size = size_proto3_uint32 - case reflect.Float64: - p.enc = (*Buffer).enc_proto3_int64 // can just treat them as bits - p.dec = (*Buffer).dec_proto3_int64 - p.size = size_proto3_int64 - case reflect.String: - p.enc = (*Buffer).enc_proto3_string - p.dec = (*Buffer).dec_proto3_string - p.size = size_proto3_string - - case reflect.Ptr: - switch t2 := t1.Elem(); t2.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no encoder function for %v -> %v\n", t1, t2) - break - case reflect.Bool: - p.enc = (*Buffer).enc_bool - p.dec = (*Buffer).dec_bool - p.size = size_bool - case reflect.Int32: - p.enc = (*Buffer).enc_int32 - p.dec = (*Buffer).dec_int32 - p.size = size_int32 - case reflect.Uint32: - p.enc = (*Buffer).enc_uint32 - p.dec = (*Buffer).dec_int32 // can reuse - p.size = size_uint32 - case reflect.Int64, reflect.Uint64: - p.enc = (*Buffer).enc_int64 - p.dec = (*Buffer).dec_int64 - p.size = size_int64 - case reflect.Float32: - p.enc = (*Buffer).enc_uint32 // can just treat them as bits - p.dec = (*Buffer).dec_int32 - p.size = size_uint32 - case reflect.Float64: - p.enc = (*Buffer).enc_int64 // can just treat them as bits - p.dec = (*Buffer).dec_int64 - p.size = size_int64 - case reflect.String: - p.enc = (*Buffer).enc_string - p.dec = (*Buffer).dec_string - p.size = size_string - case reflect.Struct: - p.stype = t1.Elem() - p.isMarshaler = isMarshaler(t1) - p.isUnmarshaler = isUnmarshaler(t1) - if p.Wire == "bytes" { - p.enc = (*Buffer).enc_struct_message - p.dec = (*Buffer).dec_struct_message - p.size = size_struct_message - } else { - p.enc = (*Buffer).enc_struct_group - p.dec = (*Buffer).dec_struct_group - p.size = size_struct_group - } - } - - case reflect.Slice: - switch t2 := t1.Elem(); t2.Kind() { - default: - logNoSliceEnc(t1, t2) - break - case reflect.Bool: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_bool - p.size = size_slice_packed_bool - } else { - p.enc = (*Buffer).enc_slice_bool - p.size = size_slice_bool - } - p.dec = (*Buffer).dec_slice_bool - p.packedDec = (*Buffer).dec_slice_packed_bool - case reflect.Int32: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int32 - p.size = size_slice_packed_int32 - } else { - p.enc = (*Buffer).enc_slice_int32 - p.size = size_slice_int32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case reflect.Uint32: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_uint32 - p.size = size_slice_packed_uint32 - } else { - p.enc = (*Buffer).enc_slice_uint32 - p.size = size_slice_uint32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case reflect.Int64, reflect.Uint64: - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int64 - p.size = size_slice_packed_int64 - } else { - p.enc = (*Buffer).enc_slice_int64 - p.size = size_slice_int64 - } - p.dec = (*Buffer).dec_slice_int64 - p.packedDec = (*Buffer).dec_slice_packed_int64 - case reflect.Uint8: - p.dec = (*Buffer).dec_slice_byte - if p.proto3 { - p.enc = (*Buffer).enc_proto3_slice_byte - p.size = size_proto3_slice_byte - } else { - p.enc = (*Buffer).enc_slice_byte - p.size = size_slice_byte - } - case reflect.Float32, reflect.Float64: - switch t2.Bits() { - case 32: - // can just treat them as bits - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_uint32 - p.size = size_slice_packed_uint32 - } else { - p.enc = (*Buffer).enc_slice_uint32 - p.size = size_slice_uint32 - } - p.dec = (*Buffer).dec_slice_int32 - p.packedDec = (*Buffer).dec_slice_packed_int32 - case 64: - // can just treat them as bits - if p.Packed { - p.enc = (*Buffer).enc_slice_packed_int64 - p.size = size_slice_packed_int64 - } else { - p.enc = (*Buffer).enc_slice_int64 - p.size = size_slice_int64 - } - p.dec = (*Buffer).dec_slice_int64 - p.packedDec = (*Buffer).dec_slice_packed_int64 - default: - logNoSliceEnc(t1, t2) - break - } - case reflect.String: - p.enc = (*Buffer).enc_slice_string - p.dec = (*Buffer).dec_slice_string - p.size = size_slice_string - case reflect.Ptr: - switch t3 := t2.Elem(); t3.Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no ptr oenc for %T -> %T -> %T\n", t1, t2, t3) - break - case reflect.Struct: - p.stype = t2.Elem() - p.isMarshaler = isMarshaler(t2) - p.isUnmarshaler = isUnmarshaler(t2) - if p.Wire == "bytes" { - p.enc = (*Buffer).enc_slice_struct_message - p.dec = (*Buffer).dec_slice_struct_message - p.size = size_slice_struct_message - } else { - p.enc = (*Buffer).enc_slice_struct_group - p.dec = (*Buffer).dec_slice_struct_group - p.size = size_slice_struct_group - } - } - case reflect.Slice: - switch t2.Elem().Kind() { - default: - fmt.Fprintf(os.Stderr, "proto: no slice elem oenc for %T -> %T -> %T\n", t1, t2, t2.Elem()) - break - case reflect.Uint8: - p.enc = (*Buffer).enc_slice_slice_byte - p.dec = (*Buffer).dec_slice_slice_byte - p.size = size_slice_slice_byte - } - } - - case reflect.Map: - p.enc = (*Buffer).enc_new_map - p.dec = (*Buffer).dec_new_map - p.size = size_new_map - - p.mtype = t1 - p.mkeyprop = &Properties{} - p.mkeyprop.init(reflect.PtrTo(p.mtype.Key()), "Key", f.Tag.Get("protobuf_key"), nil, lockGetProp) - p.mvalprop = &Properties{} - vtype := p.mtype.Elem() - if vtype.Kind() != reflect.Ptr && vtype.Kind() != reflect.Slice { - // The value type is not a message (*T) or bytes ([]byte), - // so we need encoders for the pointer to this type. - vtype = reflect.PtrTo(vtype) - } - p.mvalprop.init(vtype, "Value", f.Tag.Get("protobuf_val"), nil, lockGetProp) - } - - // precalculate tag code - wire := p.WireType - if p.Packed { - wire = WireBytes - } - x := uint32(p.Tag)<<3 | uint32(wire) - i := 0 - for i = 0; x > 127; i++ { - p.tagbuf[i] = 0x80 | uint8(x&0x7F) - x >>= 7 - } - p.tagbuf[i] = uint8(x) - p.tagcode = p.tagbuf[0 : i+1] - - if p.stype != nil { - if lockGetProp { - p.sprop = GetProperties(p.stype) - } else { - p.sprop = getPropertiesLocked(p.stype) - } - } -} - -var ( - marshalerType = reflect.TypeOf((*Marshaler)(nil)).Elem() - unmarshalerType = reflect.TypeOf((*Unmarshaler)(nil)).Elem() -) - -// isMarshaler reports whether type t implements Marshaler. -func isMarshaler(t reflect.Type) bool { - // We're checking for (likely) pointer-receiver methods - // so if t is not a pointer, something is very wrong. - // The calls above only invoke isMarshaler on pointer types. - if t.Kind() != reflect.Ptr { - panic("proto: misuse of isMarshaler") - } - return t.Implements(marshalerType) -} - -// isUnmarshaler reports whether type t implements Unmarshaler. -func isUnmarshaler(t reflect.Type) bool { - // We're checking for (likely) pointer-receiver methods - // so if t is not a pointer, something is very wrong. - // The calls above only invoke isUnmarshaler on pointer types. - if t.Kind() != reflect.Ptr { - panic("proto: misuse of isUnmarshaler") - } - return t.Implements(unmarshalerType) -} - -// Init populates the properties from a protocol buffer struct tag. -func (p *Properties) Init(typ reflect.Type, name, tag string, f *reflect.StructField) { - p.init(typ, name, tag, f, true) -} - -func (p *Properties) init(typ reflect.Type, name, tag string, f *reflect.StructField, lockGetProp bool) { - // "bytes,49,opt,def=hello!" - p.Name = name - p.OrigName = name - if f != nil { - p.field = toField(f) - } - if tag == "" { - return - } - p.Parse(tag) - p.setEncAndDec(typ, f, lockGetProp) -} - -var ( - propertiesMu sync.RWMutex - propertiesMap = make(map[reflect.Type]*StructProperties) -) - -// GetProperties returns the list of properties for the type represented by t. -// t must represent a generated struct type of a protocol message. -func GetProperties(t reflect.Type) *StructProperties { - if t.Kind() != reflect.Struct { - panic("proto: type must have kind struct") - } - - // Most calls to GetProperties in a long-running program will be - // retrieving details for types we have seen before. - propertiesMu.RLock() - sprop, ok := propertiesMap[t] - propertiesMu.RUnlock() - if ok { - if collectStats { - stats.Chit++ - } - return sprop - } - - propertiesMu.Lock() - sprop = getPropertiesLocked(t) - propertiesMu.Unlock() - return sprop -} - -// getPropertiesLocked requires that propertiesMu is held. -func getPropertiesLocked(t reflect.Type) *StructProperties { - if prop, ok := propertiesMap[t]; ok { - if collectStats { - stats.Chit++ - } - return prop - } - if collectStats { - stats.Cmiss++ - } - - prop := new(StructProperties) - // in case of recursive protos, fill this in now. - propertiesMap[t] = prop - - // build properties - prop.extendable = reflect.PtrTo(t).Implements(extendableProtoType) || - reflect.PtrTo(t).Implements(extendableProtoV1Type) - prop.unrecField = invalidField - prop.Prop = make([]*Properties, t.NumField()) - prop.order = make([]int, t.NumField()) - - for i := 0; i < t.NumField(); i++ { - f := t.Field(i) - p := new(Properties) - name := f.Name - p.init(f.Type, name, f.Tag.Get("protobuf"), &f, false) - - if f.Name == "XXX_InternalExtensions" { // special case - p.enc = (*Buffer).enc_exts - p.dec = nil // not needed - p.size = size_exts - } else if f.Name == "XXX_extensions" { // special case - p.enc = (*Buffer).enc_map - p.dec = nil // not needed - p.size = size_map - } else if f.Name == "XXX_unrecognized" { // special case - prop.unrecField = toField(&f) - } - oneof := f.Tag.Get("protobuf_oneof") // special case - if oneof != "" { - // Oneof fields don't use the traditional protobuf tag. - p.OrigName = oneof - } - prop.Prop[i] = p - prop.order[i] = i - if debug { - print(i, " ", f.Name, " ", t.String(), " ") - if p.Tag > 0 { - print(p.String()) - } - print("\n") - } - if p.enc == nil && !strings.HasPrefix(f.Name, "XXX_") && oneof == "" { - fmt.Fprintln(os.Stderr, "proto: no encoder for", f.Name, f.Type.String(), "[GetProperties]") - } - } - - // Re-order prop.order. - sort.Sort(prop) - - type oneofMessage interface { - XXX_OneofFuncs() (func(Message, *Buffer) error, func(Message, int, int, *Buffer) (bool, error), func(Message) int, []interface{}) - } - if om, ok := reflect.Zero(reflect.PtrTo(t)).Interface().(oneofMessage); ok { - var oots []interface{} - prop.oneofMarshaler, prop.oneofUnmarshaler, prop.oneofSizer, oots = om.XXX_OneofFuncs() - prop.stype = t - - // Interpret oneof metadata. - prop.OneofTypes = make(map[string]*OneofProperties) - for _, oot := range oots { - oop := &OneofProperties{ - Type: reflect.ValueOf(oot).Type(), // *T - Prop: new(Properties), - } - sft := oop.Type.Elem().Field(0) - oop.Prop.Name = sft.Name - oop.Prop.Parse(sft.Tag.Get("protobuf")) - // There will be exactly one interface field that - // this new value is assignable to. - for i := 0; i < t.NumField(); i++ { - f := t.Field(i) - if f.Type.Kind() != reflect.Interface { - continue - } - if !oop.Type.AssignableTo(f.Type) { - continue - } - oop.Field = i - break - } - prop.OneofTypes[oop.Prop.OrigName] = oop - } - } - - // build required counts - // build tags - reqCount := 0 - prop.decoderOrigNames = make(map[string]int) - for i, p := range prop.Prop { - if strings.HasPrefix(p.Name, "XXX_") { - // Internal fields should not appear in tags/origNames maps. - // They are handled specially when encoding and decoding. - continue - } - if p.Required { - reqCount++ - } - prop.decoderTags.put(p.Tag, i) - prop.decoderOrigNames[p.OrigName] = i - } - prop.reqCount = reqCount - - return prop -} - -// Return the Properties object for the x[0]'th field of the structure. -func propByIndex(t reflect.Type, x []int) *Properties { - if len(x) != 1 { - fmt.Fprintf(os.Stderr, "proto: field index dimension %d (not 1) for type %s\n", len(x), t) - return nil - } - prop := GetProperties(t) - return prop.Prop[x[0]] -} - -// Get the address and type of a pointer to a struct from an interface. -func getbase(pb Message) (t reflect.Type, b structPointer, err error) { - if pb == nil { - err = ErrNil - return - } - // get the reflect type of the pointer to the struct. - t = reflect.TypeOf(pb) - // get the address of the struct. - value := reflect.ValueOf(pb) - b = toStructPointer(value) - return -} - -// A global registry of enum types. -// The generated code will register the generated maps by calling RegisterEnum. - -var enumValueMaps = make(map[string]map[string]int32) - -// RegisterEnum is called from the generated code to install the enum descriptor -// maps into the global table to aid parsing text format protocol buffers. -func RegisterEnum(typeName string, unusedNameMap map[int32]string, valueMap map[string]int32) { - if _, ok := enumValueMaps[typeName]; ok { - panic("proto: duplicate enum registered: " + typeName) - } - enumValueMaps[typeName] = valueMap -} - -// EnumValueMap returns the mapping from names to integers of the -// enum type enumType, or a nil if not found. -func EnumValueMap(enumType string) map[string]int32 { - return enumValueMaps[enumType] -} - -// A registry of all linked message types. -// The string is a fully-qualified proto name ("pkg.Message"). -var ( - protoTypes = make(map[string]reflect.Type) - revProtoTypes = make(map[reflect.Type]string) -) - -// RegisterType is called from generated code and maps from the fully qualified -// proto name to the type (pointer to struct) of the protocol buffer. -func RegisterType(x Message, name string) { - if _, ok := protoTypes[name]; ok { - // TODO: Some day, make this a panic. - log.Printf("proto: duplicate proto type registered: %s", name) - return - } - t := reflect.TypeOf(x) - protoTypes[name] = t - revProtoTypes[t] = name -} - -// MessageName returns the fully-qualified proto name for the given message type. -func MessageName(x Message) string { return revProtoTypes[reflect.TypeOf(x)] } - -// MessageType returns the message type (pointer to struct) for a named message. -func MessageType(name string) reflect.Type { return protoTypes[name] } - -// A registry of all linked proto files. -var ( - protoFiles = make(map[string][]byte) // file name => fileDescriptor -) - -// RegisterFile is called from generated code and maps from the -// full file name of a .proto file to its compressed FileDescriptorProto. -func RegisterFile(filename string, fileDescriptor []byte) { - protoFiles[filename] = fileDescriptor -} - -// FileDescriptor returns the compressed FileDescriptorProto for a .proto file. -func FileDescriptor(filename string) []byte { return protoFiles[filename] } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text.go deleted file mode 100644 index 8214ce3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text.go +++ /dev/null @@ -1,854 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// Functions for writing the text protocol buffer format. - -import ( - "bufio" - "bytes" - "encoding" - "errors" - "fmt" - "io" - "log" - "math" - "reflect" - "sort" - "strings" -) - -var ( - newline = []byte("\n") - spaces = []byte(" ") - gtNewline = []byte(">\n") - endBraceNewline = []byte("}\n") - backslashN = []byte{'\\', 'n'} - backslashR = []byte{'\\', 'r'} - backslashT = []byte{'\\', 't'} - backslashDQ = []byte{'\\', '"'} - backslashBS = []byte{'\\', '\\'} - posInf = []byte("inf") - negInf = []byte("-inf") - nan = []byte("nan") -) - -type writer interface { - io.Writer - WriteByte(byte) error -} - -// textWriter is an io.Writer that tracks its indentation level. -type textWriter struct { - ind int - complete bool // if the current position is a complete line - compact bool // whether to write out as a one-liner - w writer -} - -func (w *textWriter) WriteString(s string) (n int, err error) { - if !strings.Contains(s, "\n") { - if !w.compact && w.complete { - w.writeIndent() - } - w.complete = false - return io.WriteString(w.w, s) - } - // WriteString is typically called without newlines, so this - // codepath and its copy are rare. We copy to avoid - // duplicating all of Write's logic here. - return w.Write([]byte(s)) -} - -func (w *textWriter) Write(p []byte) (n int, err error) { - newlines := bytes.Count(p, newline) - if newlines == 0 { - if !w.compact && w.complete { - w.writeIndent() - } - n, err = w.w.Write(p) - w.complete = false - return n, err - } - - frags := bytes.SplitN(p, newline, newlines+1) - if w.compact { - for i, frag := range frags { - if i > 0 { - if err := w.w.WriteByte(' '); err != nil { - return n, err - } - n++ - } - nn, err := w.w.Write(frag) - n += nn - if err != nil { - return n, err - } - } - return n, nil - } - - for i, frag := range frags { - if w.complete { - w.writeIndent() - } - nn, err := w.w.Write(frag) - n += nn - if err != nil { - return n, err - } - if i+1 < len(frags) { - if err := w.w.WriteByte('\n'); err != nil { - return n, err - } - n++ - } - } - w.complete = len(frags[len(frags)-1]) == 0 - return n, nil -} - -func (w *textWriter) WriteByte(c byte) error { - if w.compact && c == '\n' { - c = ' ' - } - if !w.compact && w.complete { - w.writeIndent() - } - err := w.w.WriteByte(c) - w.complete = c == '\n' - return err -} - -func (w *textWriter) indent() { w.ind++ } - -func (w *textWriter) unindent() { - if w.ind == 0 { - log.Printf("proto: textWriter unindented too far") - return - } - w.ind-- -} - -func writeName(w *textWriter, props *Properties) error { - if _, err := w.WriteString(props.OrigName); err != nil { - return err - } - if props.Wire != "group" { - return w.WriteByte(':') - } - return nil -} - -// raw is the interface satisfied by RawMessage. -type raw interface { - Bytes() []byte -} - -func requiresQuotes(u string) bool { - // When type URL contains any characters except [0-9A-Za-z./\-]*, it must be quoted. - for _, ch := range u { - switch { - case ch == '.' || ch == '/' || ch == '_': - continue - case '0' <= ch && ch <= '9': - continue - case 'A' <= ch && ch <= 'Z': - continue - case 'a' <= ch && ch <= 'z': - continue - default: - return true - } - } - return false -} - -// isAny reports whether sv is a google.protobuf.Any message -func isAny(sv reflect.Value) bool { - type wkt interface { - XXX_WellKnownType() string - } - t, ok := sv.Addr().Interface().(wkt) - return ok && t.XXX_WellKnownType() == "Any" -} - -// writeProto3Any writes an expanded google.protobuf.Any message. -// -// It returns (false, nil) if sv value can't be unmarshaled (e.g. because -// required messages are not linked in). -// -// It returns (true, error) when sv was written in expanded format or an error -// was encountered. -func (tm *TextMarshaler) writeProto3Any(w *textWriter, sv reflect.Value) (bool, error) { - turl := sv.FieldByName("TypeUrl") - val := sv.FieldByName("Value") - if !turl.IsValid() || !val.IsValid() { - return true, errors.New("proto: invalid google.protobuf.Any message") - } - - b, ok := val.Interface().([]byte) - if !ok { - return true, errors.New("proto: invalid google.protobuf.Any message") - } - - parts := strings.Split(turl.String(), "/") - mt := MessageType(parts[len(parts)-1]) - if mt == nil { - return false, nil - } - m := reflect.New(mt.Elem()) - if err := Unmarshal(b, m.Interface().(Message)); err != nil { - return false, nil - } - w.Write([]byte("[")) - u := turl.String() - if requiresQuotes(u) { - writeString(w, u) - } else { - w.Write([]byte(u)) - } - if w.compact { - w.Write([]byte("]:<")) - } else { - w.Write([]byte("]: <\n")) - w.ind++ - } - if err := tm.writeStruct(w, m.Elem()); err != nil { - return true, err - } - if w.compact { - w.Write([]byte("> ")) - } else { - w.ind-- - w.Write([]byte(">\n")) - } - return true, nil -} - -func (tm *TextMarshaler) writeStruct(w *textWriter, sv reflect.Value) error { - if tm.ExpandAny && isAny(sv) { - if canExpand, err := tm.writeProto3Any(w, sv); canExpand { - return err - } - } - st := sv.Type() - sprops := GetProperties(st) - for i := 0; i < sv.NumField(); i++ { - fv := sv.Field(i) - props := sprops.Prop[i] - name := st.Field(i).Name - - if strings.HasPrefix(name, "XXX_") { - // There are two XXX_ fields: - // XXX_unrecognized []byte - // XXX_extensions map[int32]proto.Extension - // The first is handled here; - // the second is handled at the bottom of this function. - if name == "XXX_unrecognized" && !fv.IsNil() { - if err := writeUnknownStruct(w, fv.Interface().([]byte)); err != nil { - return err - } - } - continue - } - if fv.Kind() == reflect.Ptr && fv.IsNil() { - // Field not filled in. This could be an optional field or - // a required field that wasn't filled in. Either way, there - // isn't anything we can show for it. - continue - } - if fv.Kind() == reflect.Slice && fv.IsNil() { - // Repeated field that is empty, or a bytes field that is unused. - continue - } - - if props.Repeated && fv.Kind() == reflect.Slice { - // Repeated field. - for j := 0; j < fv.Len(); j++ { - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - v := fv.Index(j) - if v.Kind() == reflect.Ptr && v.IsNil() { - // A nil message in a repeated field is not valid, - // but we can handle that more gracefully than panicking. - if _, err := w.Write([]byte("\n")); err != nil { - return err - } - continue - } - if err := tm.writeAny(w, v, props); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - continue - } - if fv.Kind() == reflect.Map { - // Map fields are rendered as a repeated struct with key/value fields. - keys := fv.MapKeys() - sort.Sort(mapKeys(keys)) - for _, key := range keys { - val := fv.MapIndex(key) - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - // open struct - if err := w.WriteByte('<'); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - // key - if _, err := w.WriteString("key:"); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := tm.writeAny(w, key, props.mkeyprop); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - // nil values aren't legal, but we can avoid panicking because of them. - if val.Kind() != reflect.Ptr || !val.IsNil() { - // value - if _, err := w.WriteString("value:"); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := tm.writeAny(w, val, props.mvalprop); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - // close struct - w.unindent() - if err := w.WriteByte('>'); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - } - continue - } - if props.proto3 && fv.Kind() == reflect.Slice && fv.Len() == 0 { - // empty bytes field - continue - } - if fv.Kind() != reflect.Ptr && fv.Kind() != reflect.Slice { - // proto3 non-repeated scalar field; skip if zero value - if isProto3Zero(fv) { - continue - } - } - - if fv.Kind() == reflect.Interface { - // Check if it is a oneof. - if st.Field(i).Tag.Get("protobuf_oneof") != "" { - // fv is nil, or holds a pointer to generated struct. - // That generated struct has exactly one field, - // which has a protobuf struct tag. - if fv.IsNil() { - continue - } - inner := fv.Elem().Elem() // interface -> *T -> T - tag := inner.Type().Field(0).Tag.Get("protobuf") - props = new(Properties) // Overwrite the outer props var, but not its pointee. - props.Parse(tag) - // Write the value in the oneof, not the oneof itself. - fv = inner.Field(0) - - // Special case to cope with malformed messages gracefully: - // If the value in the oneof is a nil pointer, don't panic - // in writeAny. - if fv.Kind() == reflect.Ptr && fv.IsNil() { - // Use errors.New so writeAny won't render quotes. - msg := errors.New("/* nil */") - fv = reflect.ValueOf(&msg).Elem() - } - } - } - - if err := writeName(w, props); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if b, ok := fv.Interface().(raw); ok { - if err := writeRaw(w, b.Bytes()); err != nil { - return err - } - continue - } - - // Enums have a String method, so writeAny will work fine. - if err := tm.writeAny(w, fv, props); err != nil { - return err - } - - if err := w.WriteByte('\n'); err != nil { - return err - } - } - - // Extensions (the XXX_extensions field). - pv := sv.Addr() - if _, ok := extendable(pv.Interface()); ok { - if err := tm.writeExtensions(w, pv); err != nil { - return err - } - } - - return nil -} - -// writeRaw writes an uninterpreted raw message. -func writeRaw(w *textWriter, b []byte) error { - if err := w.WriteByte('<'); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - if err := writeUnknownStruct(w, b); err != nil { - return err - } - w.unindent() - if err := w.WriteByte('>'); err != nil { - return err - } - return nil -} - -// writeAny writes an arbitrary field. -func (tm *TextMarshaler) writeAny(w *textWriter, v reflect.Value, props *Properties) error { - v = reflect.Indirect(v) - - // Floats have special cases. - if v.Kind() == reflect.Float32 || v.Kind() == reflect.Float64 { - x := v.Float() - var b []byte - switch { - case math.IsInf(x, 1): - b = posInf - case math.IsInf(x, -1): - b = negInf - case math.IsNaN(x): - b = nan - } - if b != nil { - _, err := w.Write(b) - return err - } - // Other values are handled below. - } - - // We don't attempt to serialise every possible value type; only those - // that can occur in protocol buffers. - switch v.Kind() { - case reflect.Slice: - // Should only be a []byte; repeated fields are handled in writeStruct. - if err := writeString(w, string(v.Bytes())); err != nil { - return err - } - case reflect.String: - if err := writeString(w, v.String()); err != nil { - return err - } - case reflect.Struct: - // Required/optional group/message. - var bra, ket byte = '<', '>' - if props != nil && props.Wire == "group" { - bra, ket = '{', '}' - } - if err := w.WriteByte(bra); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte('\n'); err != nil { - return err - } - } - w.indent() - if etm, ok := v.Interface().(encoding.TextMarshaler); ok { - text, err := etm.MarshalText() - if err != nil { - return err - } - if _, err = w.Write(text); err != nil { - return err - } - } else if err := tm.writeStruct(w, v); err != nil { - return err - } - w.unindent() - if err := w.WriteByte(ket); err != nil { - return err - } - default: - _, err := fmt.Fprint(w, v.Interface()) - return err - } - return nil -} - -// equivalent to C's isprint. -func isprint(c byte) bool { - return c >= 0x20 && c < 0x7f -} - -// writeString writes a string in the protocol buffer text format. -// It is similar to strconv.Quote except we don't use Go escape sequences, -// we treat the string as a byte sequence, and we use octal escapes. -// These differences are to maintain interoperability with the other -// languages' implementations of the text format. -func writeString(w *textWriter, s string) error { - // use WriteByte here to get any needed indent - if err := w.WriteByte('"'); err != nil { - return err - } - // Loop over the bytes, not the runes. - for i := 0; i < len(s); i++ { - var err error - // Divergence from C++: we don't escape apostrophes. - // There's no need to escape them, and the C++ parser - // copes with a naked apostrophe. - switch c := s[i]; c { - case '\n': - _, err = w.w.Write(backslashN) - case '\r': - _, err = w.w.Write(backslashR) - case '\t': - _, err = w.w.Write(backslashT) - case '"': - _, err = w.w.Write(backslashDQ) - case '\\': - _, err = w.w.Write(backslashBS) - default: - if isprint(c) { - err = w.w.WriteByte(c) - } else { - _, err = fmt.Fprintf(w.w, "\\%03o", c) - } - } - if err != nil { - return err - } - } - return w.WriteByte('"') -} - -func writeUnknownStruct(w *textWriter, data []byte) (err error) { - if !w.compact { - if _, err := fmt.Fprintf(w, "/* %d unknown bytes */\n", len(data)); err != nil { - return err - } - } - b := NewBuffer(data) - for b.index < len(b.buf) { - x, err := b.DecodeVarint() - if err != nil { - _, err := fmt.Fprintf(w, "/* %v */\n", err) - return err - } - wire, tag := x&7, x>>3 - if wire == WireEndGroup { - w.unindent() - if _, err := w.Write(endBraceNewline); err != nil { - return err - } - continue - } - if _, err := fmt.Fprint(w, tag); err != nil { - return err - } - if wire != WireStartGroup { - if err := w.WriteByte(':'); err != nil { - return err - } - } - if !w.compact || wire == WireStartGroup { - if err := w.WriteByte(' '); err != nil { - return err - } - } - switch wire { - case WireBytes: - buf, e := b.DecodeRawBytes(false) - if e == nil { - _, err = fmt.Fprintf(w, "%q", buf) - } else { - _, err = fmt.Fprintf(w, "/* %v */", e) - } - case WireFixed32: - x, err = b.DecodeFixed32() - err = writeUnknownInt(w, x, err) - case WireFixed64: - x, err = b.DecodeFixed64() - err = writeUnknownInt(w, x, err) - case WireStartGroup: - err = w.WriteByte('{') - w.indent() - case WireVarint: - x, err = b.DecodeVarint() - err = writeUnknownInt(w, x, err) - default: - _, err = fmt.Fprintf(w, "/* unknown wire type %d */", wire) - } - if err != nil { - return err - } - if err = w.WriteByte('\n'); err != nil { - return err - } - } - return nil -} - -func writeUnknownInt(w *textWriter, x uint64, err error) error { - if err == nil { - _, err = fmt.Fprint(w, x) - } else { - _, err = fmt.Fprintf(w, "/* %v */", err) - } - return err -} - -type int32Slice []int32 - -func (s int32Slice) Len() int { return len(s) } -func (s int32Slice) Less(i, j int) bool { return s[i] < s[j] } -func (s int32Slice) Swap(i, j int) { s[i], s[j] = s[j], s[i] } - -// writeExtensions writes all the extensions in pv. -// pv is assumed to be a pointer to a protocol message struct that is extendable. -func (tm *TextMarshaler) writeExtensions(w *textWriter, pv reflect.Value) error { - emap := extensionMaps[pv.Type().Elem()] - ep, _ := extendable(pv.Interface()) - - // Order the extensions by ID. - // This isn't strictly necessary, but it will give us - // canonical output, which will also make testing easier. - m, mu := ep.extensionsRead() - if m == nil { - return nil - } - mu.Lock() - ids := make([]int32, 0, len(m)) - for id := range m { - ids = append(ids, id) - } - sort.Sort(int32Slice(ids)) - mu.Unlock() - - for _, extNum := range ids { - ext := m[extNum] - var desc *ExtensionDesc - if emap != nil { - desc = emap[extNum] - } - if desc == nil { - // Unknown extension. - if err := writeUnknownStruct(w, ext.enc); err != nil { - return err - } - continue - } - - pb, err := GetExtension(ep, desc) - if err != nil { - return fmt.Errorf("failed getting extension: %v", err) - } - - // Repeated extensions will appear as a slice. - if !desc.repeated() { - if err := tm.writeExtension(w, desc.Name, pb); err != nil { - return err - } - } else { - v := reflect.ValueOf(pb) - for i := 0; i < v.Len(); i++ { - if err := tm.writeExtension(w, desc.Name, v.Index(i).Interface()); err != nil { - return err - } - } - } - } - return nil -} - -func (tm *TextMarshaler) writeExtension(w *textWriter, name string, pb interface{}) error { - if _, err := fmt.Fprintf(w, "[%s]:", name); err != nil { - return err - } - if !w.compact { - if err := w.WriteByte(' '); err != nil { - return err - } - } - if err := tm.writeAny(w, reflect.ValueOf(pb), nil); err != nil { - return err - } - if err := w.WriteByte('\n'); err != nil { - return err - } - return nil -} - -func (w *textWriter) writeIndent() { - if !w.complete { - return - } - remain := w.ind * 2 - for remain > 0 { - n := remain - if n > len(spaces) { - n = len(spaces) - } - w.w.Write(spaces[:n]) - remain -= n - } - w.complete = false -} - -// TextMarshaler is a configurable text format marshaler. -type TextMarshaler struct { - Compact bool // use compact text format (one line). - ExpandAny bool // expand google.protobuf.Any messages of known types -} - -// Marshal writes a given protocol buffer in text format. -// The only errors returned are from w. -func (tm *TextMarshaler) Marshal(w io.Writer, pb Message) error { - val := reflect.ValueOf(pb) - if pb == nil || val.IsNil() { - w.Write([]byte("")) - return nil - } - var bw *bufio.Writer - ww, ok := w.(writer) - if !ok { - bw = bufio.NewWriter(w) - ww = bw - } - aw := &textWriter{ - w: ww, - complete: true, - compact: tm.Compact, - } - - if etm, ok := pb.(encoding.TextMarshaler); ok { - text, err := etm.MarshalText() - if err != nil { - return err - } - if _, err = aw.Write(text); err != nil { - return err - } - if bw != nil { - return bw.Flush() - } - return nil - } - // Dereference the received pointer so we don't have outer < and >. - v := reflect.Indirect(val) - if err := tm.writeStruct(aw, v); err != nil { - return err - } - if bw != nil { - return bw.Flush() - } - return nil -} - -// Text is the same as Marshal, but returns the string directly. -func (tm *TextMarshaler) Text(pb Message) string { - var buf bytes.Buffer - tm.Marshal(&buf, pb) - return buf.String() -} - -var ( - defaultTextMarshaler = TextMarshaler{} - compactTextMarshaler = TextMarshaler{Compact: true} -) - -// TODO: consider removing some of the Marshal functions below. - -// MarshalText writes a given protocol buffer in text format. -// The only errors returned are from w. -func MarshalText(w io.Writer, pb Message) error { return defaultTextMarshaler.Marshal(w, pb) } - -// MarshalTextString is the same as MarshalText, but returns the string directly. -func MarshalTextString(pb Message) string { return defaultTextMarshaler.Text(pb) } - -// CompactText writes a given protocol buffer in compact text format (one line). -func CompactText(w io.Writer, pb Message) error { return compactTextMarshaler.Marshal(w, pb) } - -// CompactTextString is the same as CompactText, but returns the string directly. -func CompactTextString(pb Message) string { return compactTextMarshaler.Text(pb) } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text_parser.go b/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text_parser.go deleted file mode 100644 index 0b8c59f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/golang/protobuf/proto/text_parser.go +++ /dev/null @@ -1,880 +0,0 @@ -// Go support for Protocol Buffers - Google's data interchange format -// -// Copyright 2010 The Go Authors. All rights reserved. -// https://github.com/golang/protobuf -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * Redistributions of source code must retain the above copyright -// notice, this list of conditions and the following disclaimer. -// * Redistributions in binary form must reproduce the above -// copyright notice, this list of conditions and the following disclaimer -// in the documentation and/or other materials provided with the -// distribution. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -package proto - -// Functions for parsing the Text protocol buffer format. -// TODO: message sets. - -import ( - "encoding" - "errors" - "fmt" - "reflect" - "strconv" - "strings" - "unicode/utf8" -) - -type ParseError struct { - Message string - Line int // 1-based line number - Offset int // 0-based byte offset from start of input -} - -func (p *ParseError) Error() string { - if p.Line == 1 { - // show offset only for first line - return fmt.Sprintf("line 1.%d: %v", p.Offset, p.Message) - } - return fmt.Sprintf("line %d: %v", p.Line, p.Message) -} - -type token struct { - value string - err *ParseError - line int // line number - offset int // byte number from start of input, not start of line - unquoted string // the unquoted version of value, if it was a quoted string -} - -func (t *token) String() string { - if t.err == nil { - return fmt.Sprintf("%q (line=%d, offset=%d)", t.value, t.line, t.offset) - } - return fmt.Sprintf("parse error: %v", t.err) -} - -type textParser struct { - s string // remaining input - done bool // whether the parsing is finished (success or error) - backed bool // whether back() was called - offset, line int - cur token -} - -func newTextParser(s string) *textParser { - p := new(textParser) - p.s = s - p.line = 1 - p.cur.line = 1 - return p -} - -func (p *textParser) errorf(format string, a ...interface{}) *ParseError { - pe := &ParseError{fmt.Sprintf(format, a...), p.cur.line, p.cur.offset} - p.cur.err = pe - p.done = true - return pe -} - -// Numbers and identifiers are matched by [-+._A-Za-z0-9] -func isIdentOrNumberChar(c byte) bool { - switch { - case 'A' <= c && c <= 'Z', 'a' <= c && c <= 'z': - return true - case '0' <= c && c <= '9': - return true - } - switch c { - case '-', '+', '.', '_': - return true - } - return false -} - -func isWhitespace(c byte) bool { - switch c { - case ' ', '\t', '\n', '\r': - return true - } - return false -} - -func isQuote(c byte) bool { - switch c { - case '"', '\'': - return true - } - return false -} - -func (p *textParser) skipWhitespace() { - i := 0 - for i < len(p.s) && (isWhitespace(p.s[i]) || p.s[i] == '#') { - if p.s[i] == '#' { - // comment; skip to end of line or input - for i < len(p.s) && p.s[i] != '\n' { - i++ - } - if i == len(p.s) { - break - } - } - if p.s[i] == '\n' { - p.line++ - } - i++ - } - p.offset += i - p.s = p.s[i:len(p.s)] - if len(p.s) == 0 { - p.done = true - } -} - -func (p *textParser) advance() { - // Skip whitespace - p.skipWhitespace() - if p.done { - return - } - - // Start of non-whitespace - p.cur.err = nil - p.cur.offset, p.cur.line = p.offset, p.line - p.cur.unquoted = "" - switch p.s[0] { - case '<', '>', '{', '}', ':', '[', ']', ';', ',', '/': - // Single symbol - p.cur.value, p.s = p.s[0:1], p.s[1:len(p.s)] - case '"', '\'': - // Quoted string - i := 1 - for i < len(p.s) && p.s[i] != p.s[0] && p.s[i] != '\n' { - if p.s[i] == '\\' && i+1 < len(p.s) { - // skip escaped char - i++ - } - i++ - } - if i >= len(p.s) || p.s[i] != p.s[0] { - p.errorf("unmatched quote") - return - } - unq, err := unquoteC(p.s[1:i], rune(p.s[0])) - if err != nil { - p.errorf("invalid quoted string %s: %v", p.s[0:i+1], err) - return - } - p.cur.value, p.s = p.s[0:i+1], p.s[i+1:len(p.s)] - p.cur.unquoted = unq - default: - i := 0 - for i < len(p.s) && isIdentOrNumberChar(p.s[i]) { - i++ - } - if i == 0 { - p.errorf("unexpected byte %#x", p.s[0]) - return - } - p.cur.value, p.s = p.s[0:i], p.s[i:len(p.s)] - } - p.offset += len(p.cur.value) -} - -var ( - errBadUTF8 = errors.New("proto: bad UTF-8") - errBadHex = errors.New("proto: bad hexadecimal") -) - -func unquoteC(s string, quote rune) (string, error) { - // This is based on C++'s tokenizer.cc. - // Despite its name, this is *not* parsing C syntax. - // For instance, "\0" is an invalid quoted string. - - // Avoid allocation in trivial cases. - simple := true - for _, r := range s { - if r == '\\' || r == quote { - simple = false - break - } - } - if simple { - return s, nil - } - - buf := make([]byte, 0, 3*len(s)/2) - for len(s) > 0 { - r, n := utf8.DecodeRuneInString(s) - if r == utf8.RuneError && n == 1 { - return "", errBadUTF8 - } - s = s[n:] - if r != '\\' { - if r < utf8.RuneSelf { - buf = append(buf, byte(r)) - } else { - buf = append(buf, string(r)...) - } - continue - } - - ch, tail, err := unescape(s) - if err != nil { - return "", err - } - buf = append(buf, ch...) - s = tail - } - return string(buf), nil -} - -func unescape(s string) (ch string, tail string, err error) { - r, n := utf8.DecodeRuneInString(s) - if r == utf8.RuneError && n == 1 { - return "", "", errBadUTF8 - } - s = s[n:] - switch r { - case 'a': - return "\a", s, nil - case 'b': - return "\b", s, nil - case 'f': - return "\f", s, nil - case 'n': - return "\n", s, nil - case 'r': - return "\r", s, nil - case 't': - return "\t", s, nil - case 'v': - return "\v", s, nil - case '?': - return "?", s, nil // trigraph workaround - case '\'', '"', '\\': - return string(r), s, nil - case '0', '1', '2', '3', '4', '5', '6', '7', 'x', 'X': - if len(s) < 2 { - return "", "", fmt.Errorf(`\%c requires 2 following digits`, r) - } - base := 8 - ss := s[:2] - s = s[2:] - if r == 'x' || r == 'X' { - base = 16 - } else { - ss = string(r) + ss - } - i, err := strconv.ParseUint(ss, base, 8) - if err != nil { - return "", "", err - } - return string([]byte{byte(i)}), s, nil - case 'u', 'U': - n := 4 - if r == 'U' { - n = 8 - } - if len(s) < n { - return "", "", fmt.Errorf(`\%c requires %d digits`, r, n) - } - - bs := make([]byte, n/2) - for i := 0; i < n; i += 2 { - a, ok1 := unhex(s[i]) - b, ok2 := unhex(s[i+1]) - if !ok1 || !ok2 { - return "", "", errBadHex - } - bs[i/2] = a<<4 | b - } - s = s[n:] - return string(bs), s, nil - } - return "", "", fmt.Errorf(`unknown escape \%c`, r) -} - -// Adapted from src/pkg/strconv/quote.go. -func unhex(b byte) (v byte, ok bool) { - switch { - case '0' <= b && b <= '9': - return b - '0', true - case 'a' <= b && b <= 'f': - return b - 'a' + 10, true - case 'A' <= b && b <= 'F': - return b - 'A' + 10, true - } - return 0, false -} - -// Back off the parser by one token. Can only be done between calls to next(). -// It makes the next advance() a no-op. -func (p *textParser) back() { p.backed = true } - -// Advances the parser and returns the new current token. -func (p *textParser) next() *token { - if p.backed || p.done { - p.backed = false - return &p.cur - } - p.advance() - if p.done { - p.cur.value = "" - } else if len(p.cur.value) > 0 && isQuote(p.cur.value[0]) { - // Look for multiple quoted strings separated by whitespace, - // and concatenate them. - cat := p.cur - for { - p.skipWhitespace() - if p.done || !isQuote(p.s[0]) { - break - } - p.advance() - if p.cur.err != nil { - return &p.cur - } - cat.value += " " + p.cur.value - cat.unquoted += p.cur.unquoted - } - p.done = false // parser may have seen EOF, but we want to return cat - p.cur = cat - } - return &p.cur -} - -func (p *textParser) consumeToken(s string) error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != s { - p.back() - return p.errorf("expected %q, found %q", s, tok.value) - } - return nil -} - -// Return a RequiredNotSetError indicating which required field was not set. -func (p *textParser) missingRequiredFieldError(sv reflect.Value) *RequiredNotSetError { - st := sv.Type() - sprops := GetProperties(st) - for i := 0; i < st.NumField(); i++ { - if !isNil(sv.Field(i)) { - continue - } - - props := sprops.Prop[i] - if props.Required { - return &RequiredNotSetError{fmt.Sprintf("%v.%v", st, props.OrigName)} - } - } - return &RequiredNotSetError{fmt.Sprintf("%v.", st)} // should not happen -} - -// Returns the index in the struct for the named field, as well as the parsed tag properties. -func structFieldByName(sprops *StructProperties, name string) (int, *Properties, bool) { - i, ok := sprops.decoderOrigNames[name] - if ok { - return i, sprops.Prop[i], true - } - return -1, nil, false -} - -// Consume a ':' from the input stream (if the next token is a colon), -// returning an error if a colon is needed but not present. -func (p *textParser) checkForColon(props *Properties, typ reflect.Type) *ParseError { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != ":" { - // Colon is optional when the field is a group or message. - needColon := true - switch props.Wire { - case "group": - needColon = false - case "bytes": - // A "bytes" field is either a message, a string, or a repeated field; - // those three become *T, *string and []T respectively, so we can check for - // this field being a pointer to a non-string. - if typ.Kind() == reflect.Ptr { - // *T or *string - if typ.Elem().Kind() == reflect.String { - break - } - } else if typ.Kind() == reflect.Slice { - // []T or []*T - if typ.Elem().Kind() != reflect.Ptr { - break - } - } else if typ.Kind() == reflect.String { - // The proto3 exception is for a string field, - // which requires a colon. - break - } - needColon = false - } - if needColon { - return p.errorf("expected ':', found %q", tok.value) - } - p.back() - } - return nil -} - -func (p *textParser) readStruct(sv reflect.Value, terminator string) error { - st := sv.Type() - sprops := GetProperties(st) - reqCount := sprops.reqCount - var reqFieldErr error - fieldSet := make(map[string]bool) - // A struct is a sequence of "name: value", terminated by one of - // '>' or '}', or the end of the input. A name may also be - // "[extension]" or "[type/url]". - // - // The whole struct can also be an expanded Any message, like: - // [type/url] < ... struct contents ... > - for { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == terminator { - break - } - if tok.value == "[" { - // Looks like an extension or an Any. - // - // TODO: Check whether we need to handle - // namespace rooted names (e.g. ".something.Foo"). - extName, err := p.consumeExtName() - if err != nil { - return err - } - - if s := strings.LastIndex(extName, "/"); s >= 0 { - // If it contains a slash, it's an Any type URL. - messageName := extName[s+1:] - mt := MessageType(messageName) - if mt == nil { - return p.errorf("unrecognized message %q in google.protobuf.Any", messageName) - } - tok = p.next() - if tok.err != nil { - return tok.err - } - // consume an optional colon - if tok.value == ":" { - tok = p.next() - if tok.err != nil { - return tok.err - } - } - var terminator string - switch tok.value { - case "<": - terminator = ">" - case "{": - terminator = "}" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - v := reflect.New(mt.Elem()) - if pe := p.readStruct(v.Elem(), terminator); pe != nil { - return pe - } - b, err := Marshal(v.Interface().(Message)) - if err != nil { - return p.errorf("failed to marshal message of type %q: %v", messageName, err) - } - sv.FieldByName("TypeUrl").SetString(extName) - sv.FieldByName("Value").SetBytes(b) - continue - } - - var desc *ExtensionDesc - // This could be faster, but it's functional. - // TODO: Do something smarter than a linear scan. - for _, d := range RegisteredExtensions(reflect.New(st).Interface().(Message)) { - if d.Name == extName { - desc = d - break - } - } - if desc == nil { - return p.errorf("unrecognized extension %q", extName) - } - - props := &Properties{} - props.Parse(desc.Tag) - - typ := reflect.TypeOf(desc.ExtensionType) - if err := p.checkForColon(props, typ); err != nil { - return err - } - - rep := desc.repeated() - - // Read the extension structure, and set it in - // the value we're constructing. - var ext reflect.Value - if !rep { - ext = reflect.New(typ).Elem() - } else { - ext = reflect.New(typ.Elem()).Elem() - } - if err := p.readAny(ext, props); err != nil { - if _, ok := err.(*RequiredNotSetError); !ok { - return err - } - reqFieldErr = err - } - ep := sv.Addr().Interface().(Message) - if !rep { - SetExtension(ep, desc, ext.Interface()) - } else { - old, err := GetExtension(ep, desc) - var sl reflect.Value - if err == nil { - sl = reflect.ValueOf(old) // existing slice - } else { - sl = reflect.MakeSlice(typ, 0, 1) - } - sl = reflect.Append(sl, ext) - SetExtension(ep, desc, sl.Interface()) - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - continue - } - - // This is a normal, non-extension field. - name := tok.value - var dst reflect.Value - fi, props, ok := structFieldByName(sprops, name) - if ok { - dst = sv.Field(fi) - } else if oop, ok := sprops.OneofTypes[name]; ok { - // It is a oneof. - props = oop.Prop - nv := reflect.New(oop.Type.Elem()) - dst = nv.Elem().Field(0) - sv.Field(oop.Field).Set(nv) - } - if !dst.IsValid() { - return p.errorf("unknown field name %q in %v", name, st) - } - - if dst.Kind() == reflect.Map { - // Consume any colon. - if err := p.checkForColon(props, dst.Type()); err != nil { - return err - } - - // Construct the map if it doesn't already exist. - if dst.IsNil() { - dst.Set(reflect.MakeMap(dst.Type())) - } - key := reflect.New(dst.Type().Key()).Elem() - val := reflect.New(dst.Type().Elem()).Elem() - - // The map entry should be this sequence of tokens: - // < key : KEY value : VALUE > - // However, implementations may omit key or value, and technically - // we should support them in any order. See b/28924776 for a time - // this went wrong. - - tok := p.next() - var terminator string - switch tok.value { - case "<": - terminator = ">" - case "{": - terminator = "}" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - for { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == terminator { - break - } - switch tok.value { - case "key": - if err := p.consumeToken(":"); err != nil { - return err - } - if err := p.readAny(key, props.mkeyprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - case "value": - if err := p.checkForColon(props.mvalprop, dst.Type().Elem()); err != nil { - return err - } - if err := p.readAny(val, props.mvalprop); err != nil { - return err - } - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - default: - p.back() - return p.errorf(`expected "key", "value", or %q, found %q`, terminator, tok.value) - } - } - - dst.SetMapIndex(key, val) - continue - } - - // Check that it's not already set if it's not a repeated field. - if !props.Repeated && fieldSet[name] { - return p.errorf("non-repeated field %q was repeated", name) - } - - if err := p.checkForColon(props, dst.Type()); err != nil { - return err - } - - // Parse into the field. - fieldSet[name] = true - if err := p.readAny(dst, props); err != nil { - if _, ok := err.(*RequiredNotSetError); !ok { - return err - } - reqFieldErr = err - } - if props.Required { - reqCount-- - } - - if err := p.consumeOptionalSeparator(); err != nil { - return err - } - - } - - if reqCount > 0 { - return p.missingRequiredFieldError(sv) - } - return reqFieldErr -} - -// consumeExtName consumes extension name or expanded Any type URL and the -// following ']'. It returns the name or URL consumed. -func (p *textParser) consumeExtName() (string, error) { - tok := p.next() - if tok.err != nil { - return "", tok.err - } - - // If extension name or type url is quoted, it's a single token. - if len(tok.value) > 2 && isQuote(tok.value[0]) && tok.value[len(tok.value)-1] == tok.value[0] { - name, err := unquoteC(tok.value[1:len(tok.value)-1], rune(tok.value[0])) - if err != nil { - return "", err - } - return name, p.consumeToken("]") - } - - // Consume everything up to "]" - var parts []string - for tok.value != "]" { - parts = append(parts, tok.value) - tok = p.next() - if tok.err != nil { - return "", p.errorf("unrecognized type_url or extension name: %s", tok.err) - } - } - return strings.Join(parts, ""), nil -} - -// consumeOptionalSeparator consumes an optional semicolon or comma. -// It is used in readStruct to provide backward compatibility. -func (p *textParser) consumeOptionalSeparator() error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value != ";" && tok.value != "," { - p.back() - } - return nil -} - -func (p *textParser) readAny(v reflect.Value, props *Properties) error { - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == "" { - return p.errorf("unexpected EOF") - } - - switch fv := v; fv.Kind() { - case reflect.Slice: - at := v.Type() - if at.Elem().Kind() == reflect.Uint8 { - // Special case for []byte - if tok.value[0] != '"' && tok.value[0] != '\'' { - // Deliberately written out here, as the error after - // this switch statement would write "invalid []byte: ...", - // which is not as user-friendly. - return p.errorf("invalid string: %v", tok.value) - } - bytes := []byte(tok.unquoted) - fv.Set(reflect.ValueOf(bytes)) - return nil - } - // Repeated field. - if tok.value == "[" { - // Repeated field with list notation, like [1,2,3]. - for { - fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) - err := p.readAny(fv.Index(fv.Len()-1), props) - if err != nil { - return err - } - tok := p.next() - if tok.err != nil { - return tok.err - } - if tok.value == "]" { - break - } - if tok.value != "," { - return p.errorf("Expected ']' or ',' found %q", tok.value) - } - } - return nil - } - // One value of the repeated field. - p.back() - fv.Set(reflect.Append(fv, reflect.New(at.Elem()).Elem())) - return p.readAny(fv.Index(fv.Len()-1), props) - case reflect.Bool: - // Either "true", "false", 1 or 0. - switch tok.value { - case "true", "1": - fv.SetBool(true) - return nil - case "false", "0": - fv.SetBool(false) - return nil - } - case reflect.Float32, reflect.Float64: - v := tok.value - // Ignore 'f' for compatibility with output generated by C++, but don't - // remove 'f' when the value is "-inf" or "inf". - if strings.HasSuffix(v, "f") && tok.value != "-inf" && tok.value != "inf" { - v = v[:len(v)-1] - } - if f, err := strconv.ParseFloat(v, fv.Type().Bits()); err == nil { - fv.SetFloat(f) - return nil - } - case reflect.Int32: - if x, err := strconv.ParseInt(tok.value, 0, 32); err == nil { - fv.SetInt(x) - return nil - } - - if len(props.Enum) == 0 { - break - } - m, ok := enumValueMaps[props.Enum] - if !ok { - break - } - x, ok := m[tok.value] - if !ok { - break - } - fv.SetInt(int64(x)) - return nil - case reflect.Int64: - if x, err := strconv.ParseInt(tok.value, 0, 64); err == nil { - fv.SetInt(x) - return nil - } - - case reflect.Ptr: - // A basic field (indirected through pointer), or a repeated message/group - p.back() - fv.Set(reflect.New(fv.Type().Elem())) - return p.readAny(fv.Elem(), props) - case reflect.String: - if tok.value[0] == '"' || tok.value[0] == '\'' { - fv.SetString(tok.unquoted) - return nil - } - case reflect.Struct: - var terminator string - switch tok.value { - case "{": - terminator = "}" - case "<": - terminator = ">" - default: - return p.errorf("expected '{' or '<', found %q", tok.value) - } - // TODO: Handle nested messages which implement encoding.TextUnmarshaler. - return p.readStruct(fv, terminator) - case reflect.Uint32: - if x, err := strconv.ParseUint(tok.value, 0, 32); err == nil { - fv.SetUint(uint64(x)) - return nil - } - case reflect.Uint64: - if x, err := strconv.ParseUint(tok.value, 0, 64); err == nil { - fv.SetUint(x) - return nil - } - } - return p.errorf("invalid %v: %v", v.Type(), tok.value) -} - -// UnmarshalText reads a protocol buffer in Text format. UnmarshalText resets pb -// before starting to unmarshal, so any existing data in pb is always removed. -// If a required field is not set and no other error occurs, -// UnmarshalText returns *RequiredNotSetError. -func UnmarshalText(s string, pb Message) error { - if um, ok := pb.(encoding.TextUnmarshaler); ok { - err := um.UnmarshalText([]byte(s)) - return err - } - pb.Reset() - v := reflect.ValueOf(pb) - if pe := newTextParser(s).readStruct(v.Elem(), ""); pe != nil { - return pe - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/container.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/container.go deleted file mode 100644 index 6c9be7c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/container.go +++ /dev/null @@ -1,607 +0,0 @@ -// Copyright 2014 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 v1 - -import ( - "reflect" - "time" -) - -type CpuSpec struct { - Limit uint64 `json:"limit"` - MaxLimit uint64 `json:"max_limit"` - Mask string `json:"mask,omitempty"` - Quota uint64 `json:"quota,omitempty"` - Period uint64 `json:"period,omitempty"` -} - -type MemorySpec struct { - // The amount of memory requested. Default is unlimited (-1). - // Units: bytes. - Limit uint64 `json:"limit,omitempty"` - - // The amount of guaranteed memory. Default is 0. - // Units: bytes. - Reservation uint64 `json:"reservation,omitempty"` - - // The amount of swap space requested. Default is unlimited (-1). - // Units: bytes. - SwapLimit uint64 `json:"swap_limit,omitempty"` -} - -type ContainerSpec struct { - // Time at which the container was created. - CreationTime time.Time `json:"creation_time,omitempty"` - - // Metadata labels associated with this container. - Labels map[string]string `json:"labels,omitempty"` - // Metadata envs associated with this container. Only whitelisted envs are added. - Envs map[string]string `json:"envs,omitempty"` - - HasCpu bool `json:"has_cpu"` - Cpu CpuSpec `json:"cpu,omitempty"` - - HasMemory bool `json:"has_memory"` - Memory MemorySpec `json:"memory,omitempty"` - - HasNetwork bool `json:"has_network"` - - HasFilesystem bool `json:"has_filesystem"` - - // HasDiskIo when true, indicates that DiskIo stats will be available. - HasDiskIo bool `json:"has_diskio"` - - HasCustomMetrics bool `json:"has_custom_metrics"` - CustomMetrics []MetricSpec `json:"custom_metrics,omitempty"` - - // Image name used for this container. - Image string `json:"image,omitempty"` -} - -// Container reference contains enough information to uniquely identify a container -type ContainerReference struct { - // The container id - Id string `json:"id,omitempty"` - - // The absolute name of the container. This is unique on the machine. - Name string `json:"name"` - - // Other names by which the container is known within a certain namespace. - // This is unique within that namespace. - Aliases []string `json:"aliases,omitempty"` - - // Namespace under which the aliases of a container are unique. - // An example of a namespace is "docker" for Docker containers. - Namespace string `json:"namespace,omitempty"` - - Labels map[string]string `json:"labels,omitempty"` -} - -// Sorts by container name. -type ContainerReferenceSlice []ContainerReference - -func (self ContainerReferenceSlice) Len() int { return len(self) } -func (self ContainerReferenceSlice) Swap(i, j int) { self[i], self[j] = self[j], self[i] } -func (self ContainerReferenceSlice) Less(i, j int) bool { return self[i].Name < self[j].Name } - -// ContainerInfoRequest is used when users check a container info from the REST API. -// It specifies how much data users want to get about a container -type ContainerInfoRequest struct { - // Max number of stats to return. Specify -1 for all stats currently available. - // Default: 60 - NumStats int `json:"num_stats,omitempty"` - - // Start time for which to query information. - // If ommitted, the beginning of time is assumed. - Start time.Time `json:"start,omitempty"` - - // End time for which to query information. - // If ommitted, current time is assumed. - End time.Time `json:"end,omitempty"` -} - -// Returns a ContainerInfoRequest with all default values specified. -func DefaultContainerInfoRequest() ContainerInfoRequest { - return ContainerInfoRequest{ - NumStats: 60, - } -} - -func (self *ContainerInfoRequest) Equals(other ContainerInfoRequest) bool { - return self.NumStats == other.NumStats && - self.Start.Equal(other.Start) && - self.End.Equal(other.End) -} - -type ContainerInfo struct { - ContainerReference - - // The direct subcontainers of the current container. - Subcontainers []ContainerReference `json:"subcontainers,omitempty"` - - // The isolation used in the container. - Spec ContainerSpec `json:"spec,omitempty"` - - // Historical statistics gathered from the container. - Stats []*ContainerStats `json:"stats,omitempty"` -} - -// TODO(vmarmol): Refactor to not need this equality comparison. -// ContainerInfo may be (un)marshaled by json or other en/decoder. In that -// case, the Timestamp field in each stats/sample may not be precisely -// en/decoded. This will lead to small but acceptable differences between a -// ContainerInfo and its encode-then-decode version. Eq() is used to compare -// two ContainerInfo accepting small difference (<10ms) of Time fields. -func (self *ContainerInfo) Eq(b *ContainerInfo) bool { - - // If both self and b are nil, then Eq() returns true - if self == nil { - return b == nil - } - if b == nil { - return self == nil - } - - // For fields other than time.Time, we will compare them precisely. - // This would require that any slice should have same order. - if !reflect.DeepEqual(self.ContainerReference, b.ContainerReference) { - return false - } - if !reflect.DeepEqual(self.Subcontainers, b.Subcontainers) { - return false - } - if !self.Spec.Eq(&b.Spec) { - return false - } - - for i, expectedStats := range b.Stats { - selfStats := self.Stats[i] - if !expectedStats.Eq(selfStats) { - return false - } - } - - return true -} - -func (self *ContainerSpec) Eq(b *ContainerSpec) bool { - // Creation within 1s of each other. - diff := self.CreationTime.Sub(b.CreationTime) - if (diff > time.Second) || (diff < -time.Second) { - return false - } - - if self.HasCpu != b.HasCpu { - return false - } - if !reflect.DeepEqual(self.Cpu, b.Cpu) { - return false - } - if self.HasMemory != b.HasMemory { - return false - } - if !reflect.DeepEqual(self.Memory, b.Memory) { - return false - } - if self.HasNetwork != b.HasNetwork { - return false - } - if self.HasFilesystem != b.HasFilesystem { - return false - } - if self.HasDiskIo != b.HasDiskIo { - return false - } - if self.HasCustomMetrics != b.HasCustomMetrics { - return false - } - return true -} - -func (self *ContainerInfo) StatsAfter(ref time.Time) []*ContainerStats { - n := len(self.Stats) + 1 - for i, s := range self.Stats { - if s.Timestamp.After(ref) { - n = i - break - } - } - if n > len(self.Stats) { - return nil - } - return self.Stats[n:] -} - -func (self *ContainerInfo) StatsStartTime() time.Time { - var ret time.Time - for _, s := range self.Stats { - if s.Timestamp.Before(ret) || ret.IsZero() { - ret = s.Timestamp - } - } - return ret -} - -func (self *ContainerInfo) StatsEndTime() time.Time { - var ret time.Time - for i := len(self.Stats) - 1; i >= 0; i-- { - s := self.Stats[i] - if s.Timestamp.After(ret) { - ret = s.Timestamp - } - } - return ret -} - -// This mirrors kernel internal structure. -type LoadStats struct { - // Number of sleeping tasks. - NrSleeping uint64 `json:"nr_sleeping"` - - // Number of running tasks. - NrRunning uint64 `json:"nr_running"` - - // Number of tasks in stopped state - NrStopped uint64 `json:"nr_stopped"` - - // Number of tasks in uninterruptible state - NrUninterruptible uint64 `json:"nr_uninterruptible"` - - // Number of tasks waiting on IO - NrIoWait uint64 `json:"nr_io_wait"` -} - -// CPU usage time statistics. -type CpuUsage struct { - // Total CPU usage. - // Unit: nanoseconds. - Total uint64 `json:"total"` - - // Per CPU/core usage of the container. - // Unit: nanoseconds. - PerCpu []uint64 `json:"per_cpu_usage,omitempty"` - - // Time spent in user space. - // Unit: nanoseconds. - User uint64 `json:"user"` - - // Time spent in kernel space. - // Unit: nanoseconds. - System uint64 `json:"system"` -} - -// Cpu Completely Fair Scheduler statistics. -type CpuCFS struct { - // Total number of elapsed enforcement intervals. - Periods uint64 `json:"periods"` - - // Total number of times tasks in the cgroup have been throttled. - ThrottledPeriods uint64 `json:"throttled_periods"` - - // Total time duration for which tasks in the cgroup have been throttled. - // Unit: nanoseconds. - ThrottledTime uint64 `json:"throttled_time"` -} - -// All CPU usage metrics are cumulative from the creation of the container -type CpuStats struct { - Usage CpuUsage `json:"usage"` - CFS CpuCFS `json:"cfs"` - // Smoothed average of number of runnable threads x 1000. - // We multiply by thousand to avoid using floats, but preserving precision. - // Load is smoothed over the last 10 seconds. Instantaneous value can be read - // from LoadStats.NrRunning. - LoadAverage int32 `json:"load_average"` -} - -type PerDiskStats struct { - Major uint64 `json:"major"` - Minor uint64 `json:"minor"` - Stats map[string]uint64 `json:"stats"` -} - -type DiskIoStats struct { - IoServiceBytes []PerDiskStats `json:"io_service_bytes,omitempty"` - IoServiced []PerDiskStats `json:"io_serviced,omitempty"` - IoQueued []PerDiskStats `json:"io_queued,omitempty"` - Sectors []PerDiskStats `json:"sectors,omitempty"` - IoServiceTime []PerDiskStats `json:"io_service_time,omitempty"` - IoWaitTime []PerDiskStats `json:"io_wait_time,omitempty"` - IoMerged []PerDiskStats `json:"io_merged,omitempty"` - IoTime []PerDiskStats `json:"io_time,omitempty"` -} - -type MemoryStats struct { - // Current memory usage, this includes all memory regardless of when it was - // accessed. - // Units: Bytes. - Usage uint64 `json:"usage"` - - // Number of bytes of page cache memory. - // Units: Bytes. - Cache uint64 `json:"cache"` - - // The amount of anonymous and swap cache memory (includes transparent - // hugepages). - // Units: Bytes. - RSS uint64 `json:"rss"` - - // The amount of swap currently used by the processes in this cgroup - // Units: Bytes. - Swap uint64 `json:"swap"` - - // The amount of working set memory, this includes recently accessed memory, - // dirty memory, and kernel memory. Working set is <= "usage". - // Units: Bytes. - WorkingSet uint64 `json:"working_set"` - - Failcnt uint64 `json:"failcnt"` - - ContainerData MemoryStatsMemoryData `json:"container_data,omitempty"` - HierarchicalData MemoryStatsMemoryData `json:"hierarchical_data,omitempty"` -} - -type MemoryStatsMemoryData struct { - Pgfault uint64 `json:"pgfault"` - Pgmajfault uint64 `json:"pgmajfault"` -} - -type InterfaceStats struct { - // The name of the interface. - Name string `json:"name"` - // Cumulative count of bytes received. - RxBytes uint64 `json:"rx_bytes"` - // Cumulative count of packets received. - RxPackets uint64 `json:"rx_packets"` - // Cumulative count of receive errors encountered. - RxErrors uint64 `json:"rx_errors"` - // Cumulative count of packets dropped while receiving. - RxDropped uint64 `json:"rx_dropped"` - // Cumulative count of bytes transmitted. - TxBytes uint64 `json:"tx_bytes"` - // Cumulative count of packets transmitted. - TxPackets uint64 `json:"tx_packets"` - // Cumulative count of transmit errors encountered. - TxErrors uint64 `json:"tx_errors"` - // Cumulative count of packets dropped while transmitting. - TxDropped uint64 `json:"tx_dropped"` -} - -type NetworkStats struct { - InterfaceStats `json:",inline"` - Interfaces []InterfaceStats `json:"interfaces,omitempty"` - // TCP connection stats (Established, Listen...) - Tcp TcpStat `json:"tcp"` - // TCP6 connection stats (Established, Listen...) - Tcp6 TcpStat `json:"tcp6"` -} - -type TcpStat struct { - // Count of TCP connections in state "Established" - Established uint64 - // Count of TCP connections in state "Syn_Sent" - SynSent uint64 - // Count of TCP connections in state "Syn_Recv" - SynRecv uint64 - // Count of TCP connections in state "Fin_Wait1" - FinWait1 uint64 - // Count of TCP connections in state "Fin_Wait2" - FinWait2 uint64 - // Count of TCP connections in state "Time_Wait - TimeWait uint64 - // Count of TCP connections in state "Close" - Close uint64 - // Count of TCP connections in state "Close_Wait" - CloseWait uint64 - // Count of TCP connections in state "Listen_Ack" - LastAck uint64 - // Count of TCP connections in state "Listen" - Listen uint64 - // Count of TCP connections in state "Closing" - Closing uint64 -} - -type FsStats struct { - // The block device name associated with the filesystem. - Device string `json:"device,omitempty"` - - // Type of the filesytem. - Type string `json:"type"` - - // Number of bytes that can be consumed by the container on this filesystem. - Limit uint64 `json:"capacity"` - - // Number of bytes that is consumed by the container on this filesystem. - Usage uint64 `json:"usage"` - - // Base Usage that is consumed by the container's writable layer. - // This field is only applicable for docker container's as of now. - BaseUsage uint64 `json:"base_usage"` - - // Number of bytes available for non-root user. - Available uint64 `json:"available"` - - // HasInodes when true, indicates that Inodes info will be available. - HasInodes bool `json:"has_inodes"` - - // Number of Inodes - Inodes uint64 `json:"inodes"` - - // Number of available Inodes - InodesFree uint64 `json:"inodes_free"` - - // Number of reads completed - // This is the total number of reads completed successfully. - ReadsCompleted uint64 `json:"reads_completed"` - - // Number of reads merged - // Reads and writes which are adjacent to each other may be merged for - // efficiency. Thus two 4K reads may become one 8K read before it is - // ultimately handed to the disk, and so it will be counted (and queued) - // as only one I/O. This field lets you know how often this was done. - ReadsMerged uint64 `json:"reads_merged"` - - // Number of sectors read - // This is the total number of sectors read successfully. - SectorsRead uint64 `json:"sectors_read"` - - // Number of milliseconds spent reading - // This is the total number of milliseconds spent by all reads (as - // measured from __make_request() to end_that_request_last()). - ReadTime uint64 `json:"read_time"` - - // Number of writes completed - // This is the total number of writes completed successfully. - WritesCompleted uint64 `json:"writes_completed"` - - // Number of writes merged - // See the description of reads merged. - WritesMerged uint64 `json:"writes_merged"` - - // Number of sectors written - // This is the total number of sectors written successfully. - SectorsWritten uint64 `json:"sectors_written"` - - // Number of milliseconds spent writing - // This is the total number of milliseconds spent by all writes (as - // measured from __make_request() to end_that_request_last()). - WriteTime uint64 `json:"write_time"` - - // Number of I/Os currently in progress - // The only field that should go to zero. Incremented as requests are - // given to appropriate struct request_queue and decremented as they finish. - IoInProgress uint64 `json:"io_in_progress"` - - // Number of milliseconds spent doing I/Os - // This field increases so long as field 9 is nonzero. - IoTime uint64 `json:"io_time"` - - // weighted number of milliseconds spent doing I/Os - // This field is incremented at each I/O start, I/O completion, I/O - // merge, or read of these stats by the number of I/Os in progress - // (field 9) times the number of milliseconds spent doing I/O since the - // last update of this field. This can provide an easy measure of both - // I/O completion time and the backlog that may be accumulating. - WeightedIoTime uint64 `json:"weighted_io_time"` -} - -type ContainerStats struct { - // The time of this stat point. - Timestamp time.Time `json:"timestamp"` - Cpu CpuStats `json:"cpu,omitempty"` - DiskIo DiskIoStats `json:"diskio,omitempty"` - Memory MemoryStats `json:"memory,omitempty"` - Network NetworkStats `json:"network,omitempty"` - - // Filesystem statistics - Filesystem []FsStats `json:"filesystem,omitempty"` - - // Task load stats - TaskStats LoadStats `json:"task_stats,omitempty"` - - // Custom metrics from all collectors - CustomMetrics map[string][]MetricVal `json:"custom_metrics,omitempty"` -} - -func timeEq(t1, t2 time.Time, tolerance time.Duration) bool { - // t1 should not be later than t2 - if t1.After(t2) { - t1, t2 = t2, t1 - } - diff := t2.Sub(t1) - if diff <= tolerance { - return true - } - return false -} - -const ( - // 10ms, i.e. 0.01s - timePrecision time.Duration = 10 * time.Millisecond -) - -// This function is useful because we do not require precise time -// representation. -func (a *ContainerStats) Eq(b *ContainerStats) bool { - if !timeEq(a.Timestamp, b.Timestamp, timePrecision) { - return false - } - return a.StatsEq(b) -} - -// Checks equality of the stats values. -func (a *ContainerStats) StatsEq(b *ContainerStats) bool { - // TODO(vmarmol): Consider using this through reflection. - if !reflect.DeepEqual(a.Cpu, b.Cpu) { - return false - } - if !reflect.DeepEqual(a.Memory, b.Memory) { - return false - } - if !reflect.DeepEqual(a.DiskIo, b.DiskIo) { - return false - } - if !reflect.DeepEqual(a.Network, b.Network) { - return false - } - if !reflect.DeepEqual(a.Filesystem, b.Filesystem) { - return false - } - return true -} - -// Event contains information general to events such as the time at which they -// occurred, their specific type, and the actual event. Event types are -// differentiated by the EventType field of Event. -type Event struct { - // the absolute container name for which the event occurred - ContainerName string `json:"container_name"` - - // the time at which the event occurred - Timestamp time.Time `json:"timestamp"` - - // the type of event. EventType is an enumerated type - EventType EventType `json:"event_type"` - - // the original event object and all of its extraneous data, ex. an - // OomInstance - EventData EventData `json:"event_data,omitempty"` -} - -// EventType is an enumerated type which lists the categories under which -// events may fall. The Event field EventType is populated by this enum. -type EventType string - -const ( - EventOom EventType = "oom" - EventOomKill = "oomKill" - EventContainerCreation = "containerCreation" - EventContainerDeletion = "containerDeletion" -) - -// Extra information about an event. Only one type will be set. -type EventData struct { - // Information about an OOM kill event. - OomKill *OomKillEventData `json:"oom,omitempty"` -} - -// Information related to an OOM kill instance -type OomKillEventData struct { - // process id of the killed process - Pid int `json:"pid"` - - // The name of the killed process - ProcessName string `json:"process_name"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/docker.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/docker.go deleted file mode 100644 index 2703c53..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/docker.go +++ /dev/null @@ -1,37 +0,0 @@ -// 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. - -// Types used for docker containers. -package v1 - -type DockerStatus struct { - Version string `json:"version"` - KernelVersion string `json:"kernel_version"` - OS string `json:"os"` - Hostname string `json:"hostname"` - RootDir string `json:"root_dir"` - Driver string `json:"driver"` - DriverStatus map[string]string `json:"driver_status"` - ExecDriver string `json:"exec_driver"` - NumImages int `json:"num_images"` - NumContainers int `json:"num_containers"` -} - -type DockerImage struct { - ID string `json:"id"` - RepoTags []string `json:"repo_tags"` // repository name and tags. - Created int64 `json:"created"` // unix time since creation. - VirtualSize int64 `json:"virtual_size"` - Size int64 `json:"size"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/machine.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/machine.go deleted file mode 100644 index 933b6f3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/machine.go +++ /dev/null @@ -1,208 +0,0 @@ -// Copyright 2014 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 v1 - -type FsInfo struct { - // Block device associated with the filesystem. - Device string `json:"device"` - - // Total number of bytes available on the filesystem. - Capacity uint64 `json:"capacity"` - - // Type of device. - Type string `json:"type"` - - // Total number of inodes available on the filesystem. - Inodes uint64 `json:"inodes"` - - // HasInodes when true, indicates that Inodes info will be available. - HasInodes bool `json:"has_inodes"` -} - -type Node struct { - Id int `json:"node_id"` - // Per-node memory - Memory uint64 `json:"memory"` - Cores []Core `json:"cores"` - Caches []Cache `json:"caches"` -} - -type Core struct { - Id int `json:"core_id"` - Threads []int `json:"thread_ids"` - Caches []Cache `json:"caches"` -} - -type Cache struct { - // Size of memory cache in bytes. - Size uint64 `json:"size"` - // Type of memory cache: data, instruction, or unified. - Type string `json:"type"` - // Level (distance from cpus) in a multi-level cache hierarchy. - Level int `json:"level"` -} - -func (self *Node) FindCore(id int) (bool, int) { - for i, n := range self.Cores { - if n.Id == id { - return true, i - } - } - return false, -1 -} - -func (self *Node) AddThread(thread int, core int) { - var coreIdx int - if core == -1 { - // Assume one hyperthread per core when topology data is missing. - core = thread - } - ok, coreIdx := self.FindCore(core) - - if !ok { - // New core - core := Core{Id: core} - self.Cores = append(self.Cores, core) - coreIdx = len(self.Cores) - 1 - } - self.Cores[coreIdx].Threads = append(self.Cores[coreIdx].Threads, thread) -} - -func (self *Node) AddNodeCache(c Cache) { - self.Caches = append(self.Caches, c) -} - -func (self *Node) AddPerCoreCache(c Cache) { - for idx := range self.Cores { - self.Cores[idx].Caches = append(self.Cores[idx].Caches, c) - } -} - -type DiskInfo struct { - // device name - Name string `json:"name"` - - // Major number - Major uint64 `json:"major"` - - // Minor number - Minor uint64 `json:"minor"` - - // Size in bytes - Size uint64 `json:"size"` - - // I/O Scheduler - one of "none", "noop", "cfq", "deadline" - Scheduler string `json:"scheduler"` -} - -type NetInfo struct { - // Device name - Name string `json:"name"` - - // Mac Address - MacAddress string `json:"mac_address"` - - // Speed in MBits/s - Speed int64 `json:"speed"` - - // Maximum Transmission Unit - Mtu int64 `json:"mtu"` -} - -type CloudProvider string - -const ( - GCE CloudProvider = "GCE" - AWS = "AWS" - Azure = "Azure" - Baremetal = "Baremetal" - UnknownProvider = "Unknown" -) - -type InstanceType string - -const ( - NoInstance InstanceType = "None" - UnknownInstance = "Unknown" -) - -type InstanceID string - -const ( - UnNamedInstance InstanceID = "None" -) - -type MachineInfo struct { - // The number of cores in this machine. - NumCores int `json:"num_cores"` - - // Maximum clock speed for the cores, in KHz. - CpuFrequency uint64 `json:"cpu_frequency_khz"` - - // The amount of memory (in bytes) in this machine - MemoryCapacity uint64 `json:"memory_capacity"` - - // The machine id - MachineID string `json:"machine_id"` - - // The system uuid - SystemUUID string `json:"system_uuid"` - - // The boot id - BootID string `json:"boot_id"` - - // Filesystems on this machine. - Filesystems []FsInfo `json:"filesystems"` - - // Disk map - DiskMap map[string]DiskInfo `json:"disk_map"` - - // Network devices - NetworkDevices []NetInfo `json:"network_devices"` - - // Machine Topology - // Describes cpu/memory layout and hierarchy. - Topology []Node `json:"topology"` - - // Cloud provider the machine belongs to. - CloudProvider CloudProvider `json:"cloud_provider"` - - // Type of cloud instance (e.g. GCE standard) the machine is. - InstanceType InstanceType `json:"instance_type"` - - // ID of cloud instance (e.g. instance-1) given to it by the cloud provider. - InstanceID InstanceID `json:"instance_id"` -} - -type VersionInfo struct { - // Kernel version. - KernelVersion string `json:"kernel_version"` - - // OS image being used for cadvisor container, or host image if running on host directly. - ContainerOsVersion string `json:"container_os_version"` - - // Docker version. - DockerVersion string `json:"docker_version"` - - // cAdvisor version. - CadvisorVersion string `json:"cadvisor_version"` - // cAdvisor git revision. - CadvisorRevision string `json:"cadvisor_revision"` -} - -type MachineInfoFactory interface { - GetMachineInfo() (*MachineInfo, error) - GetVersionInfo() (*VersionInfo, error) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/metric.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/metric.go deleted file mode 100644 index 30c23ed..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/cadvisor/info/v1/metric.go +++ /dev/null @@ -1,79 +0,0 @@ -// Copyright 2015 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 v1 - -import ( - "time" -) - -// Type of metric being exported. -type MetricType string - -const ( - // Instantaneous value. May increase or decrease. - MetricGauge MetricType = "gauge" - - // A counter-like value that is only expected to increase. - MetricCumulative MetricType = "cumulative" - - // Rate over a time period. - MetricDelta MetricType = "delta" -) - -// DataType for metric being exported. -type DataType string - -const ( - IntType DataType = "int" - FloatType DataType = "float" -) - -// Spec for custom metric. -type MetricSpec struct { - // The name of the metric. - Name string `json:"name"` - - // Type of the metric. - Type MetricType `json:"type"` - - // Data Type for the stats. - Format DataType `json:"format"` - - // Display Units for the stats. - Units string `json:"units"` -} - -// An exported metric. -type MetricValBasic struct { - // Time at which the metric was queried - Timestamp time.Time `json:"timestamp"` - - // The value of the metric at this point. - IntValue int64 `json:"int_value,omitempty"` - FloatValue float64 `json:"float_value,omitempty"` -} - -// An exported metric. -type MetricVal struct { - // Label associated with a metric - Label string `json:"label,omitempty"` - - // Time at which the metric was queried - Timestamp time.Time `json:"timestamp"` - - // The value of the metric at this point. - IntValue int64 `json:"int_value,omitempty"` - FloatValue float64 `json:"float_value,omitempty"` -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/.travis.yml b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/.travis.yml deleted file mode 100644 index f8684d9..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/.travis.yml +++ /dev/null @@ -1,13 +0,0 @@ -language: go - -go: - - 1.4 - - 1.3 - - 1.2 - - tip - -install: - - if ! go get code.google.com/p/go.tools/cmd/cover; then go get golang.org/x/tools/cmd/cover; fi - -script: - - go test -cover diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/CONTRIBUTING.md b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/CONTRIBUTING.md deleted file mode 100644 index 51cf5cd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/CONTRIBUTING.md +++ /dev/null @@ -1,67 +0,0 @@ -# How to contribute # - -We'd love to accept your patches and contributions to this project. There are -a just a few small guidelines you need to follow. - - -## Contributor License Agreement ## - -Contributions to any Google project must be accompanied by a Contributor -License Agreement. This is not a copyright **assignment**, it simply gives -Google permission to use and redistribute your contributions as part of the -project. - - * If you are an individual writing original source code and you're sure you - own the intellectual property, then you'll need to sign an [individual - CLA][]. - - * If you work for a company that wants to allow you to contribute your work, - then you'll need to sign a [corporate CLA][]. - -You generally only need to submit a CLA once, so if you've already submitted -one (even if it was for a different project), you probably don't need to do it -again. - -[individual CLA]: https://developers.google.com/open-source/cla/individual -[corporate CLA]: https://developers.google.com/open-source/cla/corporate - - -## Submitting a patch ## - - 1. It's generally best to start by opening a new issue describing the bug or - feature you're intending to fix. Even if you think it's relatively minor, - it's helpful to know what people are working on. Mention in the initial - issue that you are planning to work on that bug or feature so that it can - be assigned to you. - - 1. Follow the normal process of [forking][] the project, and setup a new - branch to work in. It's important that each group of changes be done in - separate branches in order to ensure that a pull request only includes the - commits related to that bug or feature. - - 1. Go makes it very simple to ensure properly formatted code, so always run - `go fmt` on your code before committing it. You should also run - [golint][] over your code. As noted in the [golint readme][], it's not - strictly necessary that your code be completely "lint-free", but this will - help you find common style issues. - - 1. Any significant changes should almost always be accompanied by tests. The - project already has good test coverage, so look at some of the existing - tests if you're unsure how to go about it. [gocov][] and [gocov-html][] - are invaluable tools for seeing which parts of your code aren't being - exercised by your tests. - - 1. Do your best to have [well-formed commit messages][] for each change. - This provides consistency throughout the project, and ensures that commit - messages are able to be formatted properly by various git tools. - - 1. Finally, push the commits to your fork and submit a [pull request][]. - -[forking]: https://help.github.com/articles/fork-a-repo -[golint]: https://github.com/golang/lint -[golint readme]: https://github.com/golang/lint/blob/master/README -[gocov]: https://github.com/axw/gocov -[gocov-html]: https://github.com/matm/gocov-html -[well-formed commit messages]: http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html -[squash]: http://git-scm.com/book/en/Git-Tools-Rewriting-History#Squashing-Commits -[pull request]: https://help.github.com/articles/creating-a-pull-request diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/README.md deleted file mode 100644 index 68fcf2c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/README.md +++ /dev/null @@ -1,71 +0,0 @@ -gofuzz -====== - -gofuzz is a library for populating go objects with random values. - -[![GoDoc](https://godoc.org/github.com/google/gofuzz?status.png)](https://godoc.org/github.com/google/gofuzz) -[![Travis](https://travis-ci.org/google/gofuzz.svg?branch=master)](https://travis-ci.org/google/gofuzz) - -This is useful for testing: - -* Do your project's objects really serialize/unserialize correctly in all cases? -* Is there an incorrectly formatted object that will cause your project to panic? - -Import with ```import "github.com/google/gofuzz"``` - -You can use it on single variables: -``` -f := fuzz.New() -var myInt int -f.Fuzz(&myInt) // myInt gets a random value. -``` - -You can use it on maps: -``` -f := fuzz.New().NilChance(0).NumElements(1, 1) -var myMap map[ComplexKeyType]string -f.Fuzz(&myMap) // myMap will have exactly one element. -``` - -Customize the chance of getting a nil pointer: -``` -f := fuzz.New().NilChance(.5) -var fancyStruct struct { - A, B, C, D *string -} -f.Fuzz(&fancyStruct) // About half the pointers should be set. -``` - -You can even customize the randomization completely if needed: -``` -type MyEnum string -const ( - A MyEnum = "A" - B MyEnum = "B" -) -type MyInfo struct { - Type MyEnum - AInfo *string - BInfo *string -} - -f := fuzz.New().NilChance(0).Funcs( - func(e *MyInfo, c fuzz.Continue) { - switch c.Intn(2) { - case 0: - e.Type = A - c.Fuzz(&e.AInfo) - case 1: - e.Type = B - c.Fuzz(&e.BInfo) - } - }, -) - -var myObject MyInfo -f.Fuzz(&myObject) // Type will correspond to whether A or B info is set. -``` - -See more examples in ```example_test.go```. - -Happy testing! diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/doc.go deleted file mode 100644 index 9f9956d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/doc.go +++ /dev/null @@ -1,18 +0,0 @@ -/* -Copyright 2014 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 fuzz is a library for populating go objects with random values. -package fuzz diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/fuzz.go b/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/fuzz.go deleted file mode 100644 index 42d9a48..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/google/gofuzz/fuzz.go +++ /dev/null @@ -1,446 +0,0 @@ -/* -Copyright 2014 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 fuzz - -import ( - "fmt" - "math/rand" - "reflect" - "time" -) - -// fuzzFuncMap is a map from a type to a fuzzFunc that handles that type. -type fuzzFuncMap map[reflect.Type]reflect.Value - -// Fuzzer knows how to fill any object with random fields. -type Fuzzer struct { - fuzzFuncs fuzzFuncMap - defaultFuzzFuncs fuzzFuncMap - r *rand.Rand - nilChance float64 - minElements int - maxElements int -} - -// New returns a new Fuzzer. Customize your Fuzzer further by calling Funcs, -// RandSource, NilChance, or NumElements in any order. -func New() *Fuzzer { - f := &Fuzzer{ - defaultFuzzFuncs: fuzzFuncMap{ - reflect.TypeOf(&time.Time{}): reflect.ValueOf(fuzzTime), - }, - - fuzzFuncs: fuzzFuncMap{}, - r: rand.New(rand.NewSource(time.Now().UnixNano())), - nilChance: .2, - minElements: 1, - maxElements: 10, - } - return f -} - -// Funcs adds each entry in fuzzFuncs as a custom fuzzing function. -// -// Each entry in fuzzFuncs must be a function taking two parameters. -// The first parameter must be a pointer or map. It is the variable that -// function will fill with random data. The second parameter must be a -// fuzz.Continue, which will provide a source of randomness and a way -// to automatically continue fuzzing smaller pieces of the first parameter. -// -// These functions are called sensibly, e.g., if you wanted custom string -// fuzzing, the function `func(s *string, c fuzz.Continue)` would get -// called and passed the address of strings. Maps and pointers will always -// be made/new'd for you, ignoring the NilChange option. For slices, it -// doesn't make much sense to pre-create them--Fuzzer doesn't know how -// long you want your slice--so take a pointer to a slice, and make it -// yourself. (If you don't want your map/pointer type pre-made, take a -// pointer to it, and make it yourself.) See the examples for a range of -// custom functions. -func (f *Fuzzer) Funcs(fuzzFuncs ...interface{}) *Fuzzer { - for i := range fuzzFuncs { - v := reflect.ValueOf(fuzzFuncs[i]) - if v.Kind() != reflect.Func { - panic("Need only funcs!") - } - t := v.Type() - if t.NumIn() != 2 || t.NumOut() != 0 { - panic("Need 2 in and 0 out params!") - } - argT := t.In(0) - switch argT.Kind() { - case reflect.Ptr, reflect.Map: - default: - panic("fuzzFunc must take pointer or map type") - } - if t.In(1) != reflect.TypeOf(Continue{}) { - panic("fuzzFunc's second parameter must be type fuzz.Continue") - } - f.fuzzFuncs[argT] = v - } - return f -} - -// RandSource causes f to get values from the given source of randomness. -// Use if you want deterministic fuzzing. -func (f *Fuzzer) RandSource(s rand.Source) *Fuzzer { - f.r = rand.New(s) - return f -} - -// NilChance sets the probability of creating a nil pointer, map, or slice to -// 'p'. 'p' should be between 0 (no nils) and 1 (all nils), inclusive. -func (f *Fuzzer) NilChance(p float64) *Fuzzer { - if p < 0 || p > 1 { - panic("p should be between 0 and 1, inclusive.") - } - f.nilChance = p - return f -} - -// NumElements sets the minimum and maximum number of elements that will be -// added to a non-nil map or slice. -func (f *Fuzzer) NumElements(atLeast, atMost int) *Fuzzer { - if atLeast > atMost { - panic("atLeast must be <= atMost") - } - if atLeast < 0 { - panic("atLeast must be >= 0") - } - f.minElements = atLeast - f.maxElements = atMost - return f -} - -func (f *Fuzzer) genElementCount() int { - if f.minElements == f.maxElements { - return f.minElements - } - return f.minElements + f.r.Intn(f.maxElements-f.minElements) -} - -func (f *Fuzzer) genShouldFill() bool { - return f.r.Float64() > f.nilChance -} - -// Fuzz recursively fills all of obj's fields with something random. First -// this tries to find a custom fuzz function (see Funcs). If there is no -// custom function this tests whether the object implements fuzz.Interface and, -// if so, calls Fuzz on it to fuzz itself. If that fails, this will see if -// there is a default fuzz function provided by this package. If all of that -// fails, this will generate random values for all primitive fields and then -// recurse for all non-primitives. -// -// Not safe for cyclic or tree-like structs! -// -// obj must be a pointer. Only exported (public) fields can be set (thanks, golang :/ ) -// Intended for tests, so will panic on bad input or unimplemented fields. -func (f *Fuzzer) Fuzz(obj interface{}) { - v := reflect.ValueOf(obj) - if v.Kind() != reflect.Ptr { - panic("needed ptr!") - } - v = v.Elem() - f.doFuzz(v, 0) -} - -// FuzzNoCustom is just like Fuzz, except that any custom fuzz function for -// obj's type will not be called and obj will not be tested for fuzz.Interface -// conformance. This applies only to obj and not other instances of obj's -// type. -// Not safe for cyclic or tree-like structs! -// obj must be a pointer. Only exported (public) fields can be set (thanks, golang :/ ) -// Intended for tests, so will panic on bad input or unimplemented fields. -func (f *Fuzzer) FuzzNoCustom(obj interface{}) { - v := reflect.ValueOf(obj) - if v.Kind() != reflect.Ptr { - panic("needed ptr!") - } - v = v.Elem() - f.doFuzz(v, flagNoCustomFuzz) -} - -const ( - // Do not try to find a custom fuzz function. Does not apply recursively. - flagNoCustomFuzz uint64 = 1 << iota -) - -func (f *Fuzzer) doFuzz(v reflect.Value, flags uint64) { - if !v.CanSet() { - return - } - - if flags&flagNoCustomFuzz == 0 { - // Check for both pointer and non-pointer custom functions. - if v.CanAddr() && f.tryCustom(v.Addr()) { - return - } - if f.tryCustom(v) { - return - } - } - - if fn, ok := fillFuncMap[v.Kind()]; ok { - fn(v, f.r) - return - } - switch v.Kind() { - case reflect.Map: - if f.genShouldFill() { - v.Set(reflect.MakeMap(v.Type())) - n := f.genElementCount() - for i := 0; i < n; i++ { - key := reflect.New(v.Type().Key()).Elem() - f.doFuzz(key, 0) - val := reflect.New(v.Type().Elem()).Elem() - f.doFuzz(val, 0) - v.SetMapIndex(key, val) - } - return - } - v.Set(reflect.Zero(v.Type())) - case reflect.Ptr: - if f.genShouldFill() { - v.Set(reflect.New(v.Type().Elem())) - f.doFuzz(v.Elem(), 0) - return - } - v.Set(reflect.Zero(v.Type())) - case reflect.Slice: - if f.genShouldFill() { - n := f.genElementCount() - v.Set(reflect.MakeSlice(v.Type(), n, n)) - for i := 0; i < n; i++ { - f.doFuzz(v.Index(i), 0) - } - return - } - v.Set(reflect.Zero(v.Type())) - case reflect.Struct: - for i := 0; i < v.NumField(); i++ { - f.doFuzz(v.Field(i), 0) - } - case reflect.Array: - fallthrough - case reflect.Chan: - fallthrough - case reflect.Func: - fallthrough - case reflect.Interface: - fallthrough - default: - panic(fmt.Sprintf("Can't handle %#v", v.Interface())) - } -} - -// tryCustom searches for custom handlers, and returns true iff it finds a match -// and successfully randomizes v. -func (f *Fuzzer) tryCustom(v reflect.Value) bool { - // First: see if we have a fuzz function for it. - doCustom, ok := f.fuzzFuncs[v.Type()] - if !ok { - // Second: see if it can fuzz itself. - if v.CanInterface() { - intf := v.Interface() - if fuzzable, ok := intf.(Interface); ok { - fuzzable.Fuzz(Continue{f: f, Rand: f.r}) - return true - } - } - // Finally: see if there is a default fuzz function. - doCustom, ok = f.defaultFuzzFuncs[v.Type()] - if !ok { - return false - } - } - - switch v.Kind() { - case reflect.Ptr: - if v.IsNil() { - if !v.CanSet() { - return false - } - v.Set(reflect.New(v.Type().Elem())) - } - case reflect.Map: - if v.IsNil() { - if !v.CanSet() { - return false - } - v.Set(reflect.MakeMap(v.Type())) - } - default: - return false - } - - doCustom.Call([]reflect.Value{v, reflect.ValueOf(Continue{ - f: f, - Rand: f.r, - })}) - return true -} - -// Interface represents an object that knows how to fuzz itself. Any time we -// find a type that implements this interface we will delegate the act of -// fuzzing itself. -type Interface interface { - Fuzz(c Continue) -} - -// Continue can be passed to custom fuzzing functions to allow them to use -// the correct source of randomness and to continue fuzzing their members. -type Continue struct { - f *Fuzzer - - // For convenience, Continue implements rand.Rand via embedding. - // Use this for generating any randomness if you want your fuzzing - // to be repeatable for a given seed. - *rand.Rand -} - -// Fuzz continues fuzzing obj. obj must be a pointer. -func (c Continue) Fuzz(obj interface{}) { - v := reflect.ValueOf(obj) - if v.Kind() != reflect.Ptr { - panic("needed ptr!") - } - v = v.Elem() - c.f.doFuzz(v, 0) -} - -// FuzzNoCustom continues fuzzing obj, except that any custom fuzz function for -// obj's type will not be called and obj will not be tested for fuzz.Interface -// conformance. This applies only to obj and not other instances of obj's -// type. -func (c Continue) FuzzNoCustom(obj interface{}) { - v := reflect.ValueOf(obj) - if v.Kind() != reflect.Ptr { - panic("needed ptr!") - } - v = v.Elem() - c.f.doFuzz(v, flagNoCustomFuzz) -} - -// RandString makes a random string up to 20 characters long. The returned string -// may include a variety of (valid) UTF-8 encodings. -func (c Continue) RandString() string { - return randString(c.Rand) -} - -// RandUint64 makes random 64 bit numbers. -// Weirdly, rand doesn't have a function that gives you 64 random bits. -func (c Continue) RandUint64() uint64 { - return randUint64(c.Rand) -} - -// RandBool returns true or false randomly. -func (c Continue) RandBool() bool { - return randBool(c.Rand) -} - -func fuzzInt(v reflect.Value, r *rand.Rand) { - v.SetInt(int64(randUint64(r))) -} - -func fuzzUint(v reflect.Value, r *rand.Rand) { - v.SetUint(randUint64(r)) -} - -func fuzzTime(t *time.Time, c Continue) { - var sec, nsec int64 - // Allow for about 1000 years of random time values, which keeps things - // like JSON parsing reasonably happy. - sec = c.Rand.Int63n(1000 * 365 * 24 * 60 * 60) - c.Fuzz(&nsec) - *t = time.Unix(sec, nsec) -} - -var fillFuncMap = map[reflect.Kind]func(reflect.Value, *rand.Rand){ - reflect.Bool: func(v reflect.Value, r *rand.Rand) { - v.SetBool(randBool(r)) - }, - reflect.Int: fuzzInt, - reflect.Int8: fuzzInt, - reflect.Int16: fuzzInt, - reflect.Int32: fuzzInt, - reflect.Int64: fuzzInt, - reflect.Uint: fuzzUint, - reflect.Uint8: fuzzUint, - reflect.Uint16: fuzzUint, - reflect.Uint32: fuzzUint, - reflect.Uint64: fuzzUint, - reflect.Uintptr: fuzzUint, - reflect.Float32: func(v reflect.Value, r *rand.Rand) { - v.SetFloat(float64(r.Float32())) - }, - reflect.Float64: func(v reflect.Value, r *rand.Rand) { - v.SetFloat(r.Float64()) - }, - reflect.Complex64: func(v reflect.Value, r *rand.Rand) { - panic("unimplemented") - }, - reflect.Complex128: func(v reflect.Value, r *rand.Rand) { - panic("unimplemented") - }, - reflect.String: func(v reflect.Value, r *rand.Rand) { - v.SetString(randString(r)) - }, - reflect.UnsafePointer: func(v reflect.Value, r *rand.Rand) { - panic("unimplemented") - }, -} - -// randBool returns true or false randomly. -func randBool(r *rand.Rand) bool { - if r.Int()&1 == 1 { - return true - } - return false -} - -type charRange struct { - first, last rune -} - -// choose returns a random unicode character from the given range, using the -// given randomness source. -func (r *charRange) choose(rand *rand.Rand) rune { - count := int64(r.last - r.first) - return r.first + rune(rand.Int63n(count)) -} - -var unicodeRanges = []charRange{ - {' ', '~'}, // ASCII characters - {'\u00a0', '\u02af'}, // Multi-byte encoded characters - {'\u4e00', '\u9fff'}, // Common CJK (even longer encodings) -} - -// randString makes a random string up to 20 characters long. The returned string -// may include a variety of (valid) UTF-8 encodings. -func randString(r *rand.Rand) string { - n := r.Intn(20) - runes := make([]rune, n) - for i := range runes { - runes[i] = unicodeRanges[r.Intn(len(unicodeRanges))].choose(r) - } - return string(runes) -} - -// randUint64 makes random 64 bit numbers. -// Weirdly, rand doesn't have a function that gives you 64 random bits. -func randUint64(r *rand.Rand) uint64 { - return uint64(r.Uint32())<<32 | uint64(r.Uint32()) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/.gitignore b/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/.gitignore deleted file mode 100644 index 010c242..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/.gitignore +++ /dev/null @@ -1,25 +0,0 @@ -# Compiled Object files, Static and Dynamic libs (Shared Objects) -*.o -*.a -*.so - -# Folders -_obj -_test - -# Architecture specific extensions/prefixes -*.[568vq] -[568vq].out - -*.cgo1.go -*.cgo2.c -_cgo_defun.c -_cgo_gotypes.go -_cgo_export.* - -_testmain.go - -*.exe -*.test - -*.swp diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/LICENSE deleted file mode 100644 index 5c304d1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/LICENSE +++ /dev/null @@ -1,201 +0,0 @@ -Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "{}" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright {yyyy} {name of copyright owner} - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/README.md deleted file mode 100644 index 236c86a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/README.md +++ /dev/null @@ -1,58 +0,0 @@ -clockwork -========= - -a simple fake clock for golang - -# Usage - -Replace uses of the `time` package with the `clockwork.Clock` interface instead. - -For example, instead of using `time.Sleep` directly: - -``` -func my_func() { - time.Sleep(3 * time.Second) - do_something() -} -``` - -inject a clock and use its `Sleep` method instead: - -``` -func my_func(clock clockwork.Clock) { - clock.Sleep(3 * time.Second) - do_something() -} -``` - -Now you can easily test `my_func` with a `FakeClock`: - -``` -func TestMyFunc(t *testing.T) { - c := clockwork.NewFakeClock() - - // Start our sleepy function - my_func(c) - - // Ensure we wait until my_func is sleeping - c.BlockUntil(1) - - assert_state() - - // Advance the FakeClock forward in time - c.Advance(3) - - assert_state() -} -``` - -and in production builds, simply inject the real clock instead: -``` -my_func(clockwork.NewRealClock()) -``` - -See [example_test.go](example_test.go) for a full example. - -# Credits - -Inspired by @wickman's [threaded fake clock](https://gist.github.com/wickman/3840816), and the [Golang playground](http://blog.golang.org/playground#Faking time) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/clockwork.go b/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/clockwork.go deleted file mode 100644 index 4b6918b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/jonboulle/clockwork/clockwork.go +++ /dev/null @@ -1,161 +0,0 @@ -package clockwork - -import ( - "sync" - "time" -) - -// Clock provides an interface that packages can use instead of directly -// using the time module, so that chronology-related behavior can be tested -type Clock interface { - After(d time.Duration) <-chan time.Time - Sleep(d time.Duration) - Now() time.Time -} - -// FakeClock provides an interface for a clock which can be -// manually advanced through time -type FakeClock interface { - Clock - // Advance advances the FakeClock to a new point in time, ensuring any existing - // sleepers are notified appropriately before returning - Advance(d time.Duration) - // BlockUntil will block until the FakeClock has the given number of - // sleepers (callers of Sleep or After) - BlockUntil(n int) -} - -// NewRealClock returns a Clock which simply delegates calls to the actual time -// package; it should be used by packages in production. -func NewRealClock() Clock { - return &realClock{} -} - -// NewFakeClock returns a FakeClock implementation which can be -// manually advanced through time for testing. -func NewFakeClock() FakeClock { - return &fakeClock{ - l: sync.RWMutex{}, - } -} - -type realClock struct{} - -func (rc *realClock) After(d time.Duration) <-chan time.Time { - return time.After(d) -} - -func (rc *realClock) Sleep(d time.Duration) { - time.Sleep(d) -} - -func (rc *realClock) Now() time.Time { - return time.Now() -} - -type fakeClock struct { - sleepers []*sleeper - blockers []*blocker - time time.Time - - l sync.RWMutex -} - -// sleeper represents a caller of After or Sleep -type sleeper struct { - until time.Time - done chan time.Time -} - -// blocker represents a caller of BlockUntil -type blocker struct { - count int - ch chan struct{} -} - -// After mimics time.After; it waits for the given duration to elapse on the -// fakeClock, then sends the current time on the returned channel. -func (fc *fakeClock) After(d time.Duration) <-chan time.Time { - fc.l.Lock() - defer fc.l.Unlock() - now := fc.time - done := make(chan time.Time, 1) - if d.Nanoseconds() == 0 { - // special case - trigger immediately - done <- now - } else { - // otherwise, add to the set of sleepers - s := &sleeper{ - until: now.Add(d), - done: done, - } - fc.sleepers = append(fc.sleepers, s) - // and notify any blockers - fc.blockers = notifyBlockers(fc.blockers, len(fc.sleepers)) - } - return done -} - -// notifyBlockers notifies all the blockers waiting until the -// given number of sleepers are waiting on the fakeClock. It -// returns an updated slice of blockers (i.e. those still waiting) -func notifyBlockers(blockers []*blocker, count int) (newBlockers []*blocker) { - for _, b := range blockers { - if b.count == count { - close(b.ch) - } else { - newBlockers = append(newBlockers, b) - } - } - return -} - -// Sleep blocks until the given duration has passed on the fakeClock -func (fc *fakeClock) Sleep(d time.Duration) { - <-fc.After(d) -} - -// Time returns the current time of the fakeClock -func (fc *fakeClock) Now() time.Time { - fc.l.Lock() - defer fc.l.Unlock() - return fc.time -} - -// Advance advances fakeClock to a new point in time, ensuring channels from any -// previous invocations of After are notified appropriately before returning -func (fc *fakeClock) Advance(d time.Duration) { - fc.l.Lock() - defer fc.l.Unlock() - end := fc.time.Add(d) - var newSleepers []*sleeper - for _, s := range fc.sleepers { - if end.Sub(s.until) >= 0 { - s.done <- end - } else { - newSleepers = append(newSleepers, s) - } - } - fc.sleepers = newSleepers - fc.blockers = notifyBlockers(fc.blockers, len(fc.sleepers)) - fc.time = end -} - -// BlockUntil will block until the fakeClock has the given number of sleepers -// (callers of Sleep or After) -func (fc *fakeClock) BlockUntil(n int) { - fc.l.Lock() - // Fast path: current number of sleepers is what we're looking for - if len(fc.sleepers) == n { - fc.l.Unlock() - return - } - // Otherwise, set up a new blocker - b := &blocker{ - count: n, - ch: make(chan struct{}), - } - fc.blockers = append(fc.blockers, b) - fc.l.Unlock() - <-b.ch -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/LICENSE deleted file mode 100644 index ade9307..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/LICENSE +++ /dev/null @@ -1,191 +0,0 @@ -All files in this repository are licensed as follows. If you contribute -to this repository, it is assumed that you license your contribution -under the same license unless you state otherwise. - -All files Copyright (C) 2015 Canonical Ltd. unless otherwise specified in the file. - -This software is licensed under the LGPLv3, included below. - -As a special exception to the GNU Lesser General Public License version 3 -("LGPL3"), the copyright holders of this Library give you permission to -convey to a third party a Combined Work that links statically or dynamically -to this Library without providing any Minimal Corresponding Source or -Minimal Application Code as set out in 4d or providing the installation -information set out in section 4e, provided that you comply with the other -provisions of LGPL3 and provided that you meet, for the Application the -terms and conditions of the license(s) which apply to the Application. - -Except as stated in this special exception, the provisions of LGPL3 will -continue to comply in full to this Library. If you modify this Library, you -may apply this exception to your version of this Library, but you are not -obliged to do so. If you do not wish to do so, delete this exception -statement from your version. This exception does not (and cannot) modify any -license terms which apply to the Application, with which you must still -comply. - - - GNU LESSER GENERAL PUBLIC LICENSE - Version 3, 29 June 2007 - - Copyright (C) 2007 Free Software Foundation, Inc. - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - - This version of the GNU Lesser General Public License incorporates -the terms and conditions of version 3 of the GNU General Public -License, supplemented by the additional permissions listed below. - - 0. Additional Definitions. - - As used herein, "this License" refers to version 3 of the GNU Lesser -General Public License, and the "GNU GPL" refers to version 3 of the GNU -General Public License. - - "The Library" refers to a covered work governed by this License, -other than an Application or a Combined Work as defined below. - - An "Application" is any work that makes use of an interface provided -by the Library, but which is not otherwise based on the Library. -Defining a subclass of a class defined by the Library is deemed a mode -of using an interface provided by the Library. - - A "Combined Work" is a work produced by combining or linking an -Application with the Library. The particular version of the Library -with which the Combined Work was made is also called the "Linked -Version". - - The "Minimal Corresponding Source" for a Combined Work means the -Corresponding Source for the Combined Work, excluding any source code -for portions of the Combined Work that, considered in isolation, are -based on the Application, and not on the Linked Version. - - The "Corresponding Application Code" for a Combined Work means the -object code and/or source code for the Application, including any data -and utility programs needed for reproducing the Combined Work from the -Application, but excluding the System Libraries of the Combined Work. - - 1. Exception to Section 3 of the GNU GPL. - - You may convey a covered work under sections 3 and 4 of this License -without being bound by section 3 of the GNU GPL. - - 2. Conveying Modified Versions. - - If you modify a copy of the Library, and, in your modifications, a -facility refers to a function or data to be supplied by an Application -that uses the facility (other than as an argument passed when the -facility is invoked), then you may convey a copy of the modified -version: - - a) under this License, provided that you make a good faith effort to - ensure that, in the event an Application does not supply the - function or data, the facility still operates, and performs - whatever part of its purpose remains meaningful, or - - b) under the GNU GPL, with none of the additional permissions of - this License applicable to that copy. - - 3. Object Code Incorporating Material from Library Header Files. - - The object code form of an Application may incorporate material from -a header file that is part of the Library. You may convey such object -code under terms of your choice, provided that, if the incorporated -material is not limited to numerical parameters, data structure -layouts and accessors, or small macros, inline functions and templates -(ten or fewer lines in length), you do both of the following: - - a) Give prominent notice with each copy of the object code that the - Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the object code with a copy of the GNU GPL and this license - document. - - 4. Combined Works. - - You may convey a Combined Work under terms of your choice that, -taken together, effectively do not restrict modification of the -portions of the Library contained in the Combined Work and reverse -engineering for debugging such modifications, if you also do each of -the following: - - a) Give prominent notice with each copy of the Combined Work that - the Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the Combined Work with a copy of the GNU GPL and this license - document. - - c) For a Combined Work that displays copyright notices during - execution, include the copyright notice for the Library among - these notices, as well as a reference directing the user to the - copies of the GNU GPL and this license document. - - d) Do one of the following: - - 0) Convey the Minimal Corresponding Source under the terms of this - License, and the Corresponding Application Code in a form - suitable for, and under terms that permit, the user to - recombine or relink the Application with a modified version of - the Linked Version to produce a modified Combined Work, in the - manner specified by section 6 of the GNU GPL for conveying - Corresponding Source. - - 1) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (a) uses at run time - a copy of the Library already present on the user's computer - system, and (b) will operate properly with a modified version - of the Library that is interface-compatible with the Linked - Version. - - e) Provide Installation Information, but only if you would otherwise - be required to provide such information under section 6 of the - GNU GPL, and only to the extent that such information is - necessary to install and execute a modified version of the - Combined Work produced by recombining or relinking the - Application with a modified version of the Linked Version. (If - you use option 4d0, the Installation Information must accompany - the Minimal Corresponding Source and Corresponding Application - Code. If you use option 4d1, you must provide the Installation - Information in the manner specified by section 6 of the GNU GPL - for conveying Corresponding Source.) - - 5. Combined Libraries. - - You may place library facilities that are a work based on the -Library side by side in a single library together with other library -facilities that are not Applications and are not covered by this -License, and convey such a combined library under terms of your -choice, if you do both of the following: - - a) Accompany the combined library with a copy of the same work based - on the Library, uncombined with any other library facilities, - conveyed under the terms of this License. - - b) Give prominent notice with the combined library that part of it - is a work based on the Library, and explaining where to find the - accompanying uncombined form of the same work. - - 6. Revised Versions of the GNU Lesser General Public License. - - The Free Software Foundation may publish revised and/or new versions -of the GNU Lesser General Public License from time to time. Such new -versions will be similar in spirit to the present version, but may -differ in detail to address new problems or concerns. - - Each version is given a distinguishing version number. If the -Library as you received it specifies that a certain numbered version -of the GNU Lesser General Public License "or any later version" -applies to it, you have the option of following the terms and -conditions either of that published version or of any later version -published by the Free Software Foundation. If the Library as you -received it does not specify a version number of the GNU Lesser -General Public License, you may choose any version of the GNU Lesser -General Public License ever published by the Free Software Foundation. - - If the Library as you received it specifies that a proxy can decide -whether future versions of the GNU Lesser General Public License shall -apply, that proxy's public statement of acceptance of any version is -permanent authorization for you to choose that version for the -Library. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/README.md deleted file mode 100644 index a0fdfe2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/README.md +++ /dev/null @@ -1,117 +0,0 @@ -# ratelimit --- - import "github.com/juju/ratelimit" - -The ratelimit package provides an efficient token bucket implementation. See -http://en.wikipedia.org/wiki/Token_bucket. - -## Usage - -#### func Reader - -```go -func Reader(r io.Reader, bucket *Bucket) io.Reader -``` -Reader returns a reader that is rate limited by the given token bucket. Each -token in the bucket represents one byte. - -#### func Writer - -```go -func Writer(w io.Writer, bucket *Bucket) io.Writer -``` -Writer returns a writer that is rate limited by the given token bucket. Each -token in the bucket represents one byte. - -#### type Bucket - -```go -type Bucket struct { -} -``` - -Bucket represents a token bucket that fills at a predetermined rate. Methods on -Bucket may be called concurrently. - -#### func NewBucket - -```go -func NewBucket(fillInterval time.Duration, capacity int64) *Bucket -``` -NewBucket returns a new token bucket that fills at the rate of one token every -fillInterval, up to the given maximum capacity. Both arguments must be positive. -The bucket is initially full. - -#### func NewBucketWithQuantum - -```go -func NewBucketWithQuantum(fillInterval time.Duration, capacity, quantum int64) *Bucket -``` -NewBucketWithQuantum is similar to NewBucket, but allows the specification of -the quantum size - quantum tokens are added every fillInterval. - -#### func NewBucketWithRate - -```go -func NewBucketWithRate(rate float64, capacity int64) *Bucket -``` -NewBucketWithRate returns a token bucket that fills the bucket at the rate of -rate tokens per second up to the given maximum capacity. Because of limited -clock resolution, at high rates, the actual rate may be up to 1% different from -the specified rate. - -#### func (*Bucket) Rate - -```go -func (tb *Bucket) Rate() float64 -``` -Rate returns the fill rate of the bucket, in tokens per second. - -#### func (*Bucket) Take - -```go -func (tb *Bucket) Take(count int64) time.Duration -``` -Take takes count tokens from the bucket without blocking. It returns the time -that the caller should wait until the tokens are actually available. - -Note that if the request is irrevocable - there is no way to return tokens to -the bucket once this method commits us to taking them. - -#### func (*Bucket) TakeAvailable - -```go -func (tb *Bucket) TakeAvailable(count int64) int64 -``` -TakeAvailable takes up to count immediately available tokens from the bucket. It -returns the number of tokens removed, or zero if there are no available tokens. -It does not block. - -#### func (*Bucket) TakeMaxDuration - -```go -func (tb *Bucket) TakeMaxDuration(count int64, maxWait time.Duration) (time.Duration, bool) -``` -TakeMaxDuration is like Take, except that it will only take tokens from the -bucket if the wait time for the tokens is no greater than maxWait. - -If it would take longer than maxWait for the tokens to become available, it does -nothing and reports false, otherwise it returns the time that the caller should -wait until the tokens are actually available, and reports true. - -#### func (*Bucket) Wait - -```go -func (tb *Bucket) Wait(count int64) -``` -Wait takes count tokens from the bucket, waiting until they are available. - -#### func (*Bucket) WaitMaxDuration - -```go -func (tb *Bucket) WaitMaxDuration(count int64, maxWait time.Duration) bool -``` -WaitMaxDuration is like Wait except that it will only take tokens from the -bucket if it needs to wait for no greater than maxWait. It reports whether any -tokens have been removed from the bucket If no tokens have been removed, it -returns immediately. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/ratelimit.go b/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/ratelimit.go deleted file mode 100644 index 3ef32fb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/ratelimit.go +++ /dev/null @@ -1,245 +0,0 @@ -// Copyright 2014 Canonical Ltd. -// Licensed under the LGPLv3 with static-linking exception. -// See LICENCE file for details. - -// The ratelimit package provides an efficient token bucket implementation -// that can be used to limit the rate of arbitrary things. -// See http://en.wikipedia.org/wiki/Token_bucket. -package ratelimit - -import ( - "math" - "strconv" - "sync" - "time" -) - -// Bucket represents a token bucket that fills at a predetermined rate. -// Methods on Bucket may be called concurrently. -type Bucket struct { - startTime time.Time - capacity int64 - quantum int64 - fillInterval time.Duration - - // The mutex guards the fields following it. - mu sync.Mutex - - // avail holds the number of available tokens - // in the bucket, as of availTick ticks from startTime. - // It will be negative when there are consumers - // waiting for tokens. - avail int64 - availTick int64 -} - -// NewBucket returns a new token bucket that fills at the -// rate of one token every fillInterval, up to the given -// maximum capacity. Both arguments must be -// positive. The bucket is initially full. -func NewBucket(fillInterval time.Duration, capacity int64) *Bucket { - return NewBucketWithQuantum(fillInterval, capacity, 1) -} - -// rateMargin specifes the allowed variance of actual -// rate from specified rate. 1% seems reasonable. -const rateMargin = 0.01 - -// NewBucketWithRate returns a token bucket that fills the bucket -// at the rate of rate tokens per second up to the given -// maximum capacity. Because of limited clock resolution, -// at high rates, the actual rate may be up to 1% different from the -// specified rate. -func NewBucketWithRate(rate float64, capacity int64) *Bucket { - for quantum := int64(1); quantum < 1<<50; quantum = nextQuantum(quantum) { - fillInterval := time.Duration(1e9 * float64(quantum) / rate) - if fillInterval <= 0 { - continue - } - tb := NewBucketWithQuantum(fillInterval, capacity, quantum) - if diff := math.Abs(tb.Rate() - rate); diff/rate <= rateMargin { - return tb - } - } - panic("cannot find suitable quantum for " + strconv.FormatFloat(rate, 'g', -1, 64)) -} - -// nextQuantum returns the next quantum to try after q. -// We grow the quantum exponentially, but slowly, so we -// get a good fit in the lower numbers. -func nextQuantum(q int64) int64 { - q1 := q * 11 / 10 - if q1 == q { - q1++ - } - return q1 -} - -// NewBucketWithQuantum is similar to NewBucket, but allows -// the specification of the quantum size - quantum tokens -// are added every fillInterval. -func NewBucketWithQuantum(fillInterval time.Duration, capacity, quantum int64) *Bucket { - if fillInterval <= 0 { - panic("token bucket fill interval is not > 0") - } - if capacity <= 0 { - panic("token bucket capacity is not > 0") - } - if quantum <= 0 { - panic("token bucket quantum is not > 0") - } - return &Bucket{ - startTime: time.Now(), - capacity: capacity, - quantum: quantum, - avail: capacity, - fillInterval: fillInterval, - } -} - -// Wait takes count tokens from the bucket, waiting until they are -// available. -func (tb *Bucket) Wait(count int64) { - if d := tb.Take(count); d > 0 { - time.Sleep(d) - } -} - -// WaitMaxDuration is like Wait except that it will -// only take tokens from the bucket if it needs to wait -// for no greater than maxWait. It reports whether -// any tokens have been removed from the bucket -// If no tokens have been removed, it returns immediately. -func (tb *Bucket) WaitMaxDuration(count int64, maxWait time.Duration) bool { - d, ok := tb.TakeMaxDuration(count, maxWait) - if d > 0 { - time.Sleep(d) - } - return ok -} - -const infinityDuration time.Duration = 0x7fffffffffffffff - -// Take takes count tokens from the bucket without blocking. It returns -// the time that the caller should wait until the tokens are actually -// available. -// -// Note that if the request is irrevocable - there is no way to return -// tokens to the bucket once this method commits us to taking them. -func (tb *Bucket) Take(count int64) time.Duration { - d, _ := tb.take(time.Now(), count, infinityDuration) - return d -} - -// TakeMaxDuration is like Take, except that -// it will only take tokens from the bucket if the wait -// time for the tokens is no greater than maxWait. -// -// If it would take longer than maxWait for the tokens -// to become available, it does nothing and reports false, -// otherwise it returns the time that the caller should -// wait until the tokens are actually available, and reports -// true. -func (tb *Bucket) TakeMaxDuration(count int64, maxWait time.Duration) (time.Duration, bool) { - return tb.take(time.Now(), count, maxWait) -} - -// TakeAvailable takes up to count immediately available tokens from the -// bucket. It returns the number of tokens removed, or zero if there are -// no available tokens. It does not block. -func (tb *Bucket) TakeAvailable(count int64) int64 { - return tb.takeAvailable(time.Now(), count) -} - -// takeAvailable is the internal version of TakeAvailable - it takes the -// current time as an argument to enable easy testing. -func (tb *Bucket) takeAvailable(now time.Time, count int64) int64 { - if count <= 0 { - return 0 - } - tb.mu.Lock() - defer tb.mu.Unlock() - - tb.adjust(now) - if tb.avail <= 0 { - return 0 - } - if count > tb.avail { - count = tb.avail - } - tb.avail -= count - return count -} - -// Available returns the number of available tokens. It will be negative -// when there are consumers waiting for tokens. Note that if this -// returns greater than zero, it does not guarantee that calls that take -// tokens from the buffer will succeed, as the number of available -// tokens could have changed in the meantime. This method is intended -// primarily for metrics reporting and debugging. -func (tb *Bucket) Available() int64 { - return tb.available(time.Now()) -} - -// available is the internal version of available - it takes the current time as -// an argument to enable easy testing. -func (tb *Bucket) available(now time.Time) int64 { - tb.mu.Lock() - defer tb.mu.Unlock() - tb.adjust(now) - return tb.avail -} - -// Capacity returns the capacity that the bucket was created with. -func (tb *Bucket) Capacity() int64 { - return tb.capacity -} - -// Rate returns the fill rate of the bucket, in tokens per second. -func (tb *Bucket) Rate() float64 { - return 1e9 * float64(tb.quantum) / float64(tb.fillInterval) -} - -// take is the internal version of Take - it takes the current time as -// an argument to enable easy testing. -func (tb *Bucket) take(now time.Time, count int64, maxWait time.Duration) (time.Duration, bool) { - if count <= 0 { - return 0, true - } - tb.mu.Lock() - defer tb.mu.Unlock() - - currentTick := tb.adjust(now) - avail := tb.avail - count - if avail >= 0 { - tb.avail = avail - return 0, true - } - // Round up the missing tokens to the nearest multiple - // of quantum - the tokens won't be available until - // that tick. - endTick := currentTick + (-avail+tb.quantum-1)/tb.quantum - endTime := tb.startTime.Add(time.Duration(endTick) * tb.fillInterval) - waitTime := endTime.Sub(now) - if waitTime > maxWait { - return 0, false - } - tb.avail = avail - return waitTime, true -} - -// adjust adjusts the current bucket capacity based on the current time. -// It returns the current tick. -func (tb *Bucket) adjust(now time.Time) (currentTick int64) { - currentTick = int64(now.Sub(tb.startTime) / tb.fillInterval) - - if tb.avail >= tb.capacity { - return - } - tb.avail += (currentTick - tb.availTick) * tb.quantum - if tb.avail > tb.capacity { - tb.avail = tb.capacity - } - tb.availTick = currentTick - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/reader.go b/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/reader.go deleted file mode 100644 index 6403bf7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/juju/ratelimit/reader.go +++ /dev/null @@ -1,51 +0,0 @@ -// Copyright 2014 Canonical Ltd. -// Licensed under the LGPLv3 with static-linking exception. -// See LICENCE file for details. - -package ratelimit - -import "io" - -type reader struct { - r io.Reader - bucket *Bucket -} - -// Reader returns a reader that is rate limited by -// the given token bucket. Each token in the bucket -// represents one byte. -func Reader(r io.Reader, bucket *Bucket) io.Reader { - return &reader{ - r: r, - bucket: bucket, - } -} - -func (r *reader) Read(buf []byte) (int, error) { - n, err := r.r.Read(buf) - if n <= 0 { - return n, err - } - r.bucket.Wait(int64(n)) - return n, err -} - -type writer struct { - w io.Writer - bucket *Bucket -} - -// Writer returns a reader that is rate limited by -// the given token bucket. Each token in the bucket -// represents one byte. -func Writer(w io.Writer, bucket *Bucket) io.Writer { - return &writer{ - w: w, - bucket: bucket, - } -} - -func (w *writer) Write(buf []byte) (int, error) { - w.bucket.Wait(int64(len(buf))) - return w.w.Write(buf) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/buffer/pool.go b/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/buffer/pool.go deleted file mode 100644 index 4de4a51..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/buffer/pool.go +++ /dev/null @@ -1,207 +0,0 @@ -// Package buffer implements a buffer for serialization, consisting of a chain of []byte-s to -// reduce copying and to allow reuse of individual chunks. -package buffer - -import ( - "io" - "sync" -) - -// PoolConfig contains configuration for the allocation and reuse strategy. -type PoolConfig struct { - StartSize int // Minimum chunk size that is allocated. - PooledSize int // Minimum chunk size that is reused, reusing chunks too small will result in overhead. - MaxSize int // Maximum chunk size that will be allocated. -} - -var config = PoolConfig{ - StartSize: 128, - PooledSize: 512, - MaxSize: 32768, -} - -// Reuse pool: chunk size -> pool. -var buffers = map[int]*sync.Pool{} - -func initBuffers() { - for l := config.PooledSize; l <= config.MaxSize; l *= 2 { - buffers[l] = new(sync.Pool) - } -} - -func init() { - initBuffers() -} - -// Init sets up a non-default pooling and allocation strategy. Should be run before serialization is done. -func Init(cfg PoolConfig) { - config = cfg - initBuffers() -} - -// putBuf puts a chunk to reuse pool if it can be reused. -func putBuf(buf []byte) { - size := cap(buf) - if size < config.PooledSize { - return - } - if c := buffers[size]; c != nil { - c.Put(buf[:0]) - } -} - -// getBuf gets a chunk from reuse pool or creates a new one if reuse failed. -func getBuf(size int) []byte { - if size < config.PooledSize { - return make([]byte, 0, size) - } - - if c := buffers[size]; c != nil { - v := c.Get() - if v != nil { - return v.([]byte) - } - } - return make([]byte, 0, size) -} - -// Buffer is a buffer optimized for serialization without extra copying. -type Buffer struct { - - // Buf is the current chunk that can be used for serialization. - Buf []byte - - toPool []byte - bufs [][]byte -} - -// EnsureSpace makes sure that the current chunk contains at least s free bytes, -// possibly creating a new chunk. -func (b *Buffer) EnsureSpace(s int) { - if cap(b.Buf)-len(b.Buf) >= s { - return - } - l := len(b.Buf) - if l > 0 { - if cap(b.toPool) != cap(b.Buf) { - // Chunk was reallocated, toPool can be pooled. - putBuf(b.toPool) - } - if cap(b.bufs) == 0 { - b.bufs = make([][]byte, 0, 8) - } - b.bufs = append(b.bufs, b.Buf) - l = cap(b.toPool) * 2 - } else { - l = config.StartSize - } - - if l > config.MaxSize { - l = config.MaxSize - } - b.Buf = getBuf(l) - b.toPool = b.Buf -} - -// AppendByte appends a single byte to buffer. -func (b *Buffer) AppendByte(data byte) { - if cap(b.Buf) == len(b.Buf) { // EnsureSpace won't be inlined. - b.EnsureSpace(1) - } - b.Buf = append(b.Buf, data) -} - -// AppendBytes appends a byte slice to buffer. -func (b *Buffer) AppendBytes(data []byte) { - for len(data) > 0 { - if cap(b.Buf) == len(b.Buf) { // EnsureSpace won't be inlined. - b.EnsureSpace(1) - } - - sz := cap(b.Buf) - len(b.Buf) - if sz > len(data) { - sz = len(data) - } - - b.Buf = append(b.Buf, data[:sz]...) - data = data[sz:] - } -} - -// AppendBytes appends a string to buffer. -func (b *Buffer) AppendString(data string) { - for len(data) > 0 { - if cap(b.Buf) == len(b.Buf) { // EnsureSpace won't be inlined. - b.EnsureSpace(1) - } - - sz := cap(b.Buf) - len(b.Buf) - if sz > len(data) { - sz = len(data) - } - - b.Buf = append(b.Buf, data[:sz]...) - data = data[sz:] - } -} - -// Size computes the size of a buffer by adding sizes of every chunk. -func (b *Buffer) Size() int { - size := len(b.Buf) - for _, buf := range b.bufs { - size += len(buf) - } - return size -} - -// DumpTo outputs the contents of a buffer to a writer and resets the buffer. -func (b *Buffer) DumpTo(w io.Writer) (written int, err error) { - var n int - for _, buf := range b.bufs { - if err == nil { - n, err = w.Write(buf) - written += n - } - putBuf(buf) - } - - if err == nil { - n, err = w.Write(b.Buf) - written += n - } - putBuf(b.toPool) - - b.bufs = nil - b.Buf = nil - b.toPool = nil - - return -} - -// BuildBytes creates a single byte slice with all the contents of the buffer. Data is -// copied if it does not fit in a single chunk. -func (b *Buffer) BuildBytes() []byte { - if len(b.bufs) == 0 { - - ret := b.Buf - b.toPool = nil - b.Buf = nil - - return ret - } - - ret := make([]byte, 0, b.Size()) - for _, buf := range b.bufs { - ret = append(ret, buf...) - putBuf(buf) - } - - ret = append(ret, b.Buf...) - putBuf(b.toPool) - - b.bufs = nil - b.toPool = nil - b.Buf = nil - - return ret -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/error.go b/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/error.go deleted file mode 100644 index e90ec40..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/error.go +++ /dev/null @@ -1,15 +0,0 @@ -package jlexer - -import "fmt" - -// LexerError implements the error interface and represents all possible errors that can be -// generated during parsing the JSON data. -type LexerError struct { - Reason string - Offset int - Data string -} - -func (l *LexerError) Error() string { - return fmt.Sprintf("parse error: %s near offset %d of '%s'", l.Reason, l.Offset, l.Data) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/lexer.go b/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/lexer.go deleted file mode 100644 index d700c0a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jlexer/lexer.go +++ /dev/null @@ -1,956 +0,0 @@ -// Package jlexer contains a JSON lexer implementation. -// -// It is expected that it is mostly used with generated parser code, so the interface is tuned -// for a parser that knows what kind of data is expected. -package jlexer - -import ( - "fmt" - "io" - "reflect" - "strconv" - "unicode/utf8" - "unsafe" -) - -// tokenKind determines type of a token. -type tokenKind byte - -const ( - tokenUndef tokenKind = iota // No token. - tokenDelim // Delimiter: one of '{', '}', '[' or ']'. - tokenString // A string literal, e.g. "abc\u1234" - tokenNumber // Number literal, e.g. 1.5e5 - tokenBool // Boolean literal: true or false. - tokenNull // null keyword. -) - -// token describes a single token: type, position in the input and value. -type token struct { - kind tokenKind // Type of a token. - - boolValue bool // Value if a boolean literal token. - byteValue []byte // Raw value of a token. - delimValue byte -} - -// Lexer is a JSON lexer: it iterates over JSON tokens in a byte slice. -type Lexer struct { - Data []byte // Input data given to the lexer. - - start int // Start of the current token. - pos int // Current unscanned position in the input stream. - token token // Last scanned token, if token.kind != tokenUndef. - - firstElement bool // Whether current element is the first in array or an object. - wantSep byte // A comma or a colon character, which need to occur before a token. - - err error // Error encountered during lexing, if any. -} - -// fetchToken scans the input for the next token. -func (r *Lexer) fetchToken() { - r.token.kind = tokenUndef - r.start = r.pos - - // Check if r.Data has r.pos element - // If it doesn't, it mean corrupted input data - if len(r.Data) < r.pos { - r.errParse("Unexpected end of data") - return - } - // Determine the type of a token by skipping whitespace and reading the - // first character. - for _, c := range r.Data[r.pos:] { - switch c { - case ':', ',': - if r.wantSep == c { - r.pos++ - r.start++ - r.wantSep = 0 - } else { - r.errSyntax() - } - - case ' ', '\t', '\r', '\n': - r.pos++ - r.start++ - - case '"': - if r.wantSep != 0 { - r.errSyntax() - } - - r.token.kind = tokenString - r.fetchString() - return - - case '{', '[': - if r.wantSep != 0 { - r.errSyntax() - } - r.firstElement = true - r.token.kind = tokenDelim - r.token.delimValue = r.Data[r.pos] - r.pos++ - return - - case '}', ']': - if !r.firstElement && (r.wantSep != ',') { - r.errSyntax() - } - r.wantSep = 0 - r.token.kind = tokenDelim - r.token.delimValue = r.Data[r.pos] - r.pos++ - return - - case '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '-': - if r.wantSep != 0 { - r.errSyntax() - } - r.token.kind = tokenNumber - r.fetchNumber() - return - - case 'n': - if r.wantSep != 0 { - r.errSyntax() - } - - r.token.kind = tokenNull - r.fetchNull() - return - - case 't': - if r.wantSep != 0 { - r.errSyntax() - } - - r.token.kind = tokenBool - r.token.boolValue = true - r.fetchTrue() - return - - case 'f': - if r.wantSep != 0 { - r.errSyntax() - } - - r.token.kind = tokenBool - r.token.boolValue = false - r.fetchFalse() - return - - default: - r.errSyntax() - return - } - } - r.err = io.EOF - return -} - -// isTokenEnd returns true if the char can follow a non-delimiter token -func isTokenEnd(c byte) bool { - return c == ' ' || c == '\t' || c == '\r' || c == '\n' || c == '[' || c == ']' || c == '{' || c == '}' || c == ',' || c == ':' -} - -// fetchNull fetches and checks remaining bytes of null keyword. -func (r *Lexer) fetchNull() { - r.pos += 4 - if r.pos > len(r.Data) || - r.Data[r.pos-3] != 'u' || - r.Data[r.pos-2] != 'l' || - r.Data[r.pos-1] != 'l' || - (r.pos != len(r.Data) && !isTokenEnd(r.Data[r.pos])) { - - r.pos -= 4 - r.errSyntax() - } -} - -// fetchTrue fetches and checks remaining bytes of true keyword. -func (r *Lexer) fetchTrue() { - r.pos += 4 - if r.pos > len(r.Data) || - r.Data[r.pos-3] != 'r' || - r.Data[r.pos-2] != 'u' || - r.Data[r.pos-1] != 'e' || - (r.pos != len(r.Data) && !isTokenEnd(r.Data[r.pos])) { - - r.pos -= 4 - r.errSyntax() - } -} - -// fetchFalse fetches and checks remaining bytes of false keyword. -func (r *Lexer) fetchFalse() { - r.pos += 5 - if r.pos > len(r.Data) || - r.Data[r.pos-4] != 'a' || - r.Data[r.pos-3] != 'l' || - r.Data[r.pos-2] != 's' || - r.Data[r.pos-1] != 'e' || - (r.pos != len(r.Data) && !isTokenEnd(r.Data[r.pos])) { - - r.pos -= 5 - r.errSyntax() - } -} - -// bytesToStr creates a string pointing at the slice to avoid copying. -// -// Warning: the string returned by the function should be used with care, as the whole input data -// chunk may be either blocked from being freed by GC because of a single string or the buffer.Data -// may be garbage-collected even when the string exists. -func bytesToStr(data []byte) string { - h := (*reflect.SliceHeader)(unsafe.Pointer(&data)) - shdr := reflect.StringHeader{h.Data, h.Len} - return *(*string)(unsafe.Pointer(&shdr)) -} - -// fetchNumber scans a number literal token. -func (r *Lexer) fetchNumber() { - hasE := false - afterE := false - hasDot := false - - r.pos++ - for i, c := range r.Data[r.pos:] { - switch { - case c >= '0' && c <= '9': - afterE = false - case c == '.' && !hasDot: - hasDot = true - case (c == 'e' || c == 'E') && !hasE: - hasE = true - hasDot = true - afterE = true - case (c == '+' || c == '-') && afterE: - afterE = false - default: - r.pos += i - if !isTokenEnd(c) { - r.errSyntax() - } else { - r.token.byteValue = r.Data[r.start:r.pos] - } - return - } - } - - r.pos = len(r.Data) - r.token.byteValue = r.Data[r.start:] -} - -// findStringLen tries to scan into the string literal for ending quote char to determine required size. -// The size will be exact if no escapes are present and may be inexact if there are escaped chars. -func findStringLen(data []byte) (hasEscapes bool, length int) { - delta := 0 - - for i := 0; i < len(data); i++ { - switch data[i] { - case '\\': - i++ - delta++ - if i < len(data) && data[i] == 'u' { - delta++ - } - case '"': - return (delta > 0), (i - delta) - } - } - - return false, len(data) -} - -// processEscape processes a single escape sequence and returns number of bytes processed. -func (r *Lexer) processEscape(data []byte) (int, error) { - if len(data) < 2 { - return 0, fmt.Errorf("syntax error at %v", string(data)) - } - - c := data[1] - switch c { - case '"', '/', '\\': - r.token.byteValue = append(r.token.byteValue, c) - return 2, nil - case 'b': - r.token.byteValue = append(r.token.byteValue, '\b') - return 2, nil - case 'f': - r.token.byteValue = append(r.token.byteValue, '\f') - return 2, nil - case 'n': - r.token.byteValue = append(r.token.byteValue, '\n') - return 2, nil - case 'r': - r.token.byteValue = append(r.token.byteValue, '\r') - return 2, nil - case 't': - r.token.byteValue = append(r.token.byteValue, '\t') - return 2, nil - case 'u': - default: - return 0, fmt.Errorf("syntax error") - } - - var val rune - - for i := 2; i < len(data) && i < 6; i++ { - var v byte - c = data[i] - switch c { - case '0', '1', '2', '3', '4', '5', '6', '7', '8', '9': - v = c - '0' - case 'a', 'b', 'c', 'd', 'e', 'f': - v = c - 'a' + 10 - case 'A', 'B', 'C', 'D', 'E', 'F': - v = c - 'A' + 10 - default: - return 0, fmt.Errorf("syntax error") - } - - val <<= 4 - val |= rune(v) - } - - l := utf8.RuneLen(val) - if l == -1 { - return 0, fmt.Errorf("invalid unicode escape") - } - - var d [4]byte - utf8.EncodeRune(d[:], val) - r.token.byteValue = append(r.token.byteValue, d[:l]...) - return 6, nil -} - -// fetchString scans a string literal token. -func (r *Lexer) fetchString() { - r.pos++ - data := r.Data[r.pos:] - - hasEscapes, length := findStringLen(data) - if !hasEscapes { - r.token.byteValue = data[:length] - r.pos += length + 1 - return - } - - r.token.byteValue = make([]byte, 0, length) - p := 0 - for i := 0; i < len(data); { - switch data[i] { - case '"': - r.pos += i + 1 - r.token.byteValue = append(r.token.byteValue, data[p:i]...) - i++ - return - - case '\\': - r.token.byteValue = append(r.token.byteValue, data[p:i]...) - off, err := r.processEscape(data[i:]) - if err != nil { - r.errParse(err.Error()) - return - } - i += off - p = i - - default: - i++ - } - } - r.errParse("unterminated string literal") -} - -// scanToken scans the next token if no token is currently available in the lexer. -func (r *Lexer) scanToken() { - if r.token.kind != tokenUndef || r.err != nil { - return - } - - r.fetchToken() -} - -// consume resets the current token to allow scanning the next one. -func (r *Lexer) consume() { - r.token.kind = tokenUndef - r.token.delimValue = 0 -} - -// Ok returns true if no error (including io.EOF) was encountered during scanning. -func (r *Lexer) Ok() bool { - return r.err == nil -} - -const maxErrorContextLen = 13 - -func (r *Lexer) errParse(what string) { - if r.err == nil { - var str string - if len(r.Data)-r.pos <= maxErrorContextLen { - str = string(r.Data) - } else { - str = string(r.Data[r.pos:r.pos+maxErrorContextLen-3]) + "..." - } - r.err = &LexerError{ - Reason: what, - Offset: r.pos, - Data: str, - } - } -} - -func (r *Lexer) errSyntax() { - r.errParse("syntax error") -} - -func (r *Lexer) errInvalidToken(expected string) { - if r.err == nil { - var str string - if len(r.token.byteValue) <= maxErrorContextLen { - str = string(r.token.byteValue) - } else { - str = string(r.token.byteValue[:maxErrorContextLen-3]) + "..." - } - r.err = &LexerError{ - Reason: fmt.Sprintf("expected %s", expected), - Offset: r.pos, - Data: str, - } - } -} - -// Delim consumes a token and verifies that it is the given delimiter. -func (r *Lexer) Delim(c byte) { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.delimValue != c { - r.errInvalidToken(string([]byte{c})) - } - r.consume() -} - -// IsDelim returns true if there was no scanning error and next token is the given delimiter. -func (r *Lexer) IsDelim(c byte) bool { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - return !r.Ok() || r.token.delimValue == c -} - -// Null verifies that the next token is null and consumes it. -func (r *Lexer) Null() { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenNull { - r.errInvalidToken("null") - } - r.consume() -} - -// IsNull returns true if the next token is a null keyword. -func (r *Lexer) IsNull() bool { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - return r.Ok() && r.token.kind == tokenNull -} - -// Skip skips a single token. -func (r *Lexer) Skip() { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - r.consume() -} - -// SkipRecursive skips next array or object completely, or just skips a single token if not -// an array/object. -// -// Note: no syntax validation is performed on the skipped data. -func (r *Lexer) SkipRecursive() { - r.scanToken() - - var start, end byte - - if r.token.delimValue == '{' { - start, end = '{', '}' - } else if r.token.delimValue == '[' { - start, end = '[', ']' - } else { - r.consume() - return - } - - r.consume() - - level := 1 - inQuotes := false - wasEscape := false - - for i, c := range r.Data[r.pos:] { - switch { - case c == start && !inQuotes: - level++ - case c == end && !inQuotes: - level-- - if level == 0 { - r.pos += i + 1 - return - } - case c == '\\' && inQuotes: - wasEscape = true - continue - case c == '"' && inQuotes: - inQuotes = wasEscape - case c == '"': - inQuotes = true - } - wasEscape = false - } - r.pos = len(r.Data) - r.err = io.EOF -} - -// Raw fetches the next item recursively as a data slice -func (r *Lexer) Raw() []byte { - r.SkipRecursive() - if !r.Ok() { - return nil - } - return r.Data[r.start:r.pos] -} - -// UnsafeString returns the string value if the token is a string literal. -// -// Warning: returned string may point to the input buffer, so the string should not outlive -// the input buffer. Intended pattern of usage is as an argument to a switch statement. -func (r *Lexer) UnsafeString() string { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenString { - r.errInvalidToken("string") - return "" - } - - ret := bytesToStr(r.token.byteValue) - r.consume() - return ret -} - -// String reads a string literal. -func (r *Lexer) String() string { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenString { - r.errInvalidToken("string") - return "" - - } - ret := string(r.token.byteValue) - r.consume() - return ret -} - -// Bool reads a true or false boolean keyword. -func (r *Lexer) Bool() bool { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenBool { - r.errInvalidToken("bool") - return false - - } - ret := r.token.boolValue - r.consume() - return ret -} - -func (r *Lexer) number() string { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - if !r.Ok() || r.token.kind != tokenNumber { - r.errInvalidToken("number") - return "" - - } - ret := bytesToStr(r.token.byteValue) - r.consume() - return ret -} - -func (r *Lexer) Uint8() uint8 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 8) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint8(n) -} - -func (r *Lexer) Uint16() uint16 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 16) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint16(n) -} - -func (r *Lexer) Uint32() uint32 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 32) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint32(n) -} - -func (r *Lexer) Uint64() uint64 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 64) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return n -} - -func (r *Lexer) Uint() uint { - return uint(r.Uint64()) -} - -func (r *Lexer) Int8() int8 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 8) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int8(n) -} - -func (r *Lexer) Int16() int16 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 16) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int16(n) -} - -func (r *Lexer) Int32() int32 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 32) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int32(n) -} - -func (r *Lexer) Int64() int64 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 64) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return n -} - -func (r *Lexer) Int() int { - return int(r.Int64()) -} - -func (r *Lexer) Uint8Str() uint8 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 8) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint8(n) -} - -func (r *Lexer) Uint16Str() uint16 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 16) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint16(n) -} - -func (r *Lexer) Uint32Str() uint32 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 32) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return uint32(n) -} - -func (r *Lexer) Uint64Str() uint64 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseUint(s, 10, 64) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return n -} - -func (r *Lexer) UintStr() uint { - return uint(r.Uint64Str()) -} - -func (r *Lexer) Int8Str() int8 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 8) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int8(n) -} - -func (r *Lexer) Int16Str() int16 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 16) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int16(n) -} - -func (r *Lexer) Int32Str() int32 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 32) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return int32(n) -} - -func (r *Lexer) Int64Str() int64 { - s := r.UnsafeString() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseInt(s, 10, 64) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return n -} - -func (r *Lexer) IntStr() int { - return int(r.Int64Str()) -} - -func (r *Lexer) Float32() float32 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseFloat(s, 32) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return float32(n) -} - -func (r *Lexer) Float64() float64 { - s := r.number() - if !r.Ok() { - return 0 - } - - n, err := strconv.ParseFloat(s, 64) - if err != nil { - r.err = &LexerError{ - Reason: err.Error(), - } - } - return n -} - -func (r *Lexer) Error() error { - return r.err -} - -func (r *Lexer) AddError(e error) { - if r.err == nil { - r.err = e - } -} - -// Interface fetches an interface{} analogous to the 'encoding/json' package. -func (r *Lexer) Interface() interface{} { - if r.token.kind == tokenUndef && r.Ok() { - r.fetchToken() - } - - if !r.Ok() { - return nil - } - switch r.token.kind { - case tokenString: - return r.String() - case tokenNumber: - return r.Float64() - case tokenBool: - return r.Bool() - case tokenNull: - r.Null() - return nil - } - - if r.token.delimValue == '{' { - r.consume() - - ret := map[string]interface{}{} - for !r.IsDelim('}') { - key := r.String() - r.WantColon() - ret[key] = r.Interface() - r.WantComma() - } - r.Delim('}') - - if r.Ok() { - return ret - } else { - return nil - } - } else if r.token.delimValue == '[' { - r.consume() - - var ret []interface{} - for !r.IsDelim(']') { - ret = append(ret, r.Interface()) - r.WantComma() - } - r.Delim(']') - - if r.Ok() { - return ret - } else { - return nil - } - } - r.errSyntax() - return nil -} - -// WantComma requires a comma to be present before fetching next token. -func (r *Lexer) WantComma() { - r.wantSep = ',' - r.firstElement = false -} - -// WantColon requires a colon to be present before fetching next token. -func (r *Lexer) WantColon() { - r.wantSep = ':' - r.firstElement = false -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jwriter/writer.go b/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jwriter/writer.go deleted file mode 100644 index 907675f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/mailru/easyjson/jwriter/writer.go +++ /dev/null @@ -1,273 +0,0 @@ -// Package jwriter contains a JSON writer. -package jwriter - -import ( - "io" - "strconv" - "unicode/utf8" - - "github.com/mailru/easyjson/buffer" -) - -// Writer is a JSON writer. -type Writer struct { - Error error - Buffer buffer.Buffer -} - -// Size returns the size of the data that was written out. -func (w *Writer) Size() int { - return w.Buffer.Size() -} - -// DumpTo outputs the data to given io.Writer, resetting the buffer. -func (w *Writer) DumpTo(out io.Writer) (written int, err error) { - return w.Buffer.DumpTo(out) -} - -// BuildBytes returns writer data as a single byte slice. -func (w *Writer) BuildBytes() ([]byte, error) { - if w.Error != nil { - return nil, w.Error - } - - return w.Buffer.BuildBytes(), nil -} - -// RawByte appends raw binary data to the buffer. -func (w *Writer) RawByte(c byte) { - w.Buffer.AppendByte(c) -} - -// RawByte appends raw binary data to the buffer. -func (w *Writer) RawString(s string) { - w.Buffer.AppendString(s) -} - -// RawByte appends raw binary data to the buffer or sets the error if it is given. Useful for -// calling with results of MarshalJSON-like functions. -func (w *Writer) Raw(data []byte, err error) { - switch { - case w.Error != nil: - return - case err != nil: - w.Error = err - case len(data) > 0: - w.Buffer.AppendBytes(data) - default: - w.RawString("null") - } -} - -func (w *Writer) Uint8(n uint8) { - w.Buffer.EnsureSpace(3) - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) -} - -func (w *Writer) Uint16(n uint16) { - w.Buffer.EnsureSpace(5) - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) -} - -func (w *Writer) Uint32(n uint32) { - w.Buffer.EnsureSpace(10) - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) -} - -func (w *Writer) Uint(n uint) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) -} - -func (w *Writer) Uint64(n uint64) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, n, 10) -} - -func (w *Writer) Int8(n int8) { - w.Buffer.EnsureSpace(4) - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) -} - -func (w *Writer) Int16(n int16) { - w.Buffer.EnsureSpace(6) - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) -} - -func (w *Writer) Int32(n int32) { - w.Buffer.EnsureSpace(11) - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) -} - -func (w *Writer) Int(n int) { - w.Buffer.EnsureSpace(21) - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) -} - -func (w *Writer) Int64(n int64) { - w.Buffer.EnsureSpace(21) - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, n, 10) -} - -func (w *Writer) Uint8Str(n uint8) { - w.Buffer.EnsureSpace(3) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Uint16Str(n uint16) { - w.Buffer.EnsureSpace(5) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Uint32Str(n uint32) { - w.Buffer.EnsureSpace(10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) UintStr(n uint) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, uint64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Uint64Str(n uint64) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendUint(w.Buffer.Buf, n, 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Int8Str(n int8) { - w.Buffer.EnsureSpace(4) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Int16Str(n int16) { - w.Buffer.EnsureSpace(6) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Int32Str(n int32) { - w.Buffer.EnsureSpace(11) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) IntStr(n int) { - w.Buffer.EnsureSpace(21) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, int64(n), 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Int64Str(n int64) { - w.Buffer.EnsureSpace(21) - w.Buffer.Buf = append(w.Buffer.Buf, '"') - w.Buffer.Buf = strconv.AppendInt(w.Buffer.Buf, n, 10) - w.Buffer.Buf = append(w.Buffer.Buf, '"') -} - -func (w *Writer) Float32(n float32) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = strconv.AppendFloat(w.Buffer.Buf, float64(n), 'g', -1, 32) -} - -func (w *Writer) Float64(n float64) { - w.Buffer.EnsureSpace(20) - w.Buffer.Buf = strconv.AppendFloat(w.Buffer.Buf, n, 'g', -1, 64) -} - -func (w *Writer) Bool(v bool) { - w.Buffer.EnsureSpace(5) - if v { - w.Buffer.Buf = append(w.Buffer.Buf, "true"...) - } else { - w.Buffer.Buf = append(w.Buffer.Buf, "false"...) - } -} - -const chars = "0123456789abcdef" - -func (w *Writer) String(s string) { - w.Buffer.AppendByte('"') - - // Portions of the string that contain no escapes are appended as - // byte slices. - - p := 0 // last non-escape symbol - - for i := 0; i < len(s); { - // single-with character - if c := s[i]; c < utf8.RuneSelf { - var escape byte - switch c { - case '\t': - escape = 't' - case '\r': - escape = 'r' - case '\n': - escape = 'n' - case '\\': - escape = '\\' - case '"': - escape = '"' - case '<', '>': - // do nothing - default: - if c >= 0x20 { - // no escaping is required - i++ - continue - } - } - if escape != 0 { - w.Buffer.AppendString(s[p:i]) - w.Buffer.AppendByte('\\') - w.Buffer.AppendByte(escape) - } else { - w.Buffer.AppendString(s[p:i]) - w.Buffer.AppendString(`\u00`) - w.Buffer.AppendByte(chars[c>>4]) - w.Buffer.AppendByte(chars[c&0xf]) - } - i++ - p = i - continue - } - - // broken utf - runeValue, runeWidth := utf8.DecodeRuneInString(s[i:]) - if runeValue == utf8.RuneError && runeWidth == 1 { - w.Buffer.AppendString(s[p:i]) - w.Buffer.AppendString(`\ufffd`) - i++ - p = i - continue - } - - // jsonp stuff - tab separator and line separator - if runeValue == '\u2028' || runeValue == '\u2029' { - w.Buffer.AppendString(s[p:i]) - w.Buffer.AppendString(`\u202`) - w.Buffer.AppendByte(chars[runeValue&0xf]) - i += runeWidth - p = i - continue - } - i += runeWidth - } - w.Buffer.AppendString(s[p:]) - w.Buffer.AppendByte('"') -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/CONTRIBUTORS b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/CONTRIBUTORS deleted file mode 100644 index b382a04..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/CONTRIBUTORS +++ /dev/null @@ -1 +0,0 @@ -Paul Borman diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/LICENSE deleted file mode 100644 index 5dc6826..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/LICENSE +++ /dev/null @@ -1,27 +0,0 @@ -Copyright (c) 2009,2014 Google Inc. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/dce.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/dce.go deleted file mode 100755 index 50a0f2d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/dce.go +++ /dev/null @@ -1,84 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "encoding/binary" - "fmt" - "os" -) - -// A Domain represents a Version 2 domain -type Domain byte - -// Domain constants for DCE Security (Version 2) UUIDs. -const ( - Person = Domain(0) - Group = Domain(1) - Org = Domain(2) -) - -// NewDCESecurity returns a DCE Security (Version 2) UUID. -// -// The domain should be one of Person, Group or Org. -// On a POSIX system the id should be the users UID for the Person -// domain and the users GID for the Group. The meaning of id for -// the domain Org or on non-POSIX systems is site defined. -// -// For a given domain/id pair the same token may be returned for up to -// 7 minutes and 10 seconds. -func NewDCESecurity(domain Domain, id uint32) UUID { - uuid := NewUUID() - if uuid != nil { - uuid[6] = (uuid[6] & 0x0f) | 0x20 // Version 2 - uuid[9] = byte(domain) - binary.BigEndian.PutUint32(uuid[0:], id) - } - return uuid -} - -// NewDCEPerson returns a DCE Security (Version 2) UUID in the person -// domain with the id returned by os.Getuid. -// -// NewDCEPerson(Person, uint32(os.Getuid())) -func NewDCEPerson() UUID { - return NewDCESecurity(Person, uint32(os.Getuid())) -} - -// NewDCEGroup returns a DCE Security (Version 2) UUID in the group -// domain with the id returned by os.Getgid. -// -// NewDCEGroup(Group, uint32(os.Getgid())) -func NewDCEGroup() UUID { - return NewDCESecurity(Group, uint32(os.Getgid())) -} - -// Domain returns the domain for a Version 2 UUID or false. -func (uuid UUID) Domain() (Domain, bool) { - if v, _ := uuid.Version(); v != 2 { - return 0, false - } - return Domain(uuid[9]), true -} - -// Id returns the id for a Version 2 UUID or false. -func (uuid UUID) Id() (uint32, bool) { - if v, _ := uuid.Version(); v != 2 { - return 0, false - } - return binary.BigEndian.Uint32(uuid[0:4]), true -} - -func (d Domain) String() string { - switch d { - case Person: - return "Person" - case Group: - return "Group" - case Org: - return "Org" - } - return fmt.Sprintf("Domain%d", int(d)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/doc.go deleted file mode 100755 index d8bd013..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/doc.go +++ /dev/null @@ -1,8 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// The uuid package generates and inspects UUIDs. -// -// UUIDs are based on RFC 4122 and DCE 1.1: Authentication and Security Services. -package uuid diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/hash.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/hash.go deleted file mode 100644 index cdd4192..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/hash.go +++ /dev/null @@ -1,53 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "crypto/md5" - "crypto/sha1" - "hash" -) - -// Well known Name Space IDs and UUIDs -var ( - NameSpace_DNS = Parse("6ba7b810-9dad-11d1-80b4-00c04fd430c8") - NameSpace_URL = Parse("6ba7b811-9dad-11d1-80b4-00c04fd430c8") - NameSpace_OID = Parse("6ba7b812-9dad-11d1-80b4-00c04fd430c8") - NameSpace_X500 = Parse("6ba7b814-9dad-11d1-80b4-00c04fd430c8") - NIL = Parse("00000000-0000-0000-0000-000000000000") -) - -// NewHash returns a new UUID dervied from the hash of space concatenated with -// data generated by h. The hash should be at least 16 byte in length. The -// first 16 bytes of the hash are used to form the UUID. The version of the -// UUID will be the lower 4 bits of version. NewHash is used to implement -// NewMD5 and NewSHA1. -func NewHash(h hash.Hash, space UUID, data []byte, version int) UUID { - h.Reset() - h.Write(space) - h.Write([]byte(data)) - s := h.Sum(nil) - uuid := make([]byte, 16) - copy(uuid, s) - uuid[6] = (uuid[6] & 0x0f) | uint8((version&0xf)<<4) - uuid[8] = (uuid[8] & 0x3f) | 0x80 // RFC 4122 variant - return uuid -} - -// NewMD5 returns a new MD5 (Version 3) UUID based on the -// supplied name space and data. -// -// NewHash(md5.New(), space, data, 3) -func NewMD5(space UUID, data []byte) UUID { - return NewHash(md5.New(), space, data, 3) -} - -// NewSHA1 returns a new SHA1 (Version 5) UUID based on the -// supplied name space and data. -// -// NewHash(sha1.New(), space, data, 5) -func NewSHA1(space UUID, data []byte) UUID { - return NewHash(sha1.New(), space, data, 5) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/json.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/json.go deleted file mode 100644 index 760580a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/json.go +++ /dev/null @@ -1,30 +0,0 @@ -// Copyright 2014 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import "errors" - -func (u UUID) MarshalJSON() ([]byte, error) { - if len(u) == 0 { - return []byte(`""`), nil - } - return []byte(`"` + u.String() + `"`), nil -} - -func (u *UUID) UnmarshalJSON(data []byte) error { - if len(data) == 0 || string(data) == `""` { - return nil - } - if len(data) < 2 || data[0] != '"' || data[len(data)-1] != '"' { - return errors.New("invalid UUID format") - } - data = data[1 : len(data)-1] - uu := Parse(string(data)) - if uu == nil { - return errors.New("invalid UUID format") - } - *u = uu - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/node.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/node.go deleted file mode 100755 index dd0a8ac..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/node.go +++ /dev/null @@ -1,101 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import "net" - -var ( - interfaces []net.Interface // cached list of interfaces - ifname string // name of interface being used - nodeID []byte // hardware for version 1 UUIDs -) - -// NodeInterface returns the name of the interface from which the NodeID was -// derived. The interface "user" is returned if the NodeID was set by -// SetNodeID. -func NodeInterface() string { - return ifname -} - -// SetNodeInterface selects the hardware address to be used for Version 1 UUIDs. -// If name is "" then the first usable interface found will be used or a random -// Node ID will be generated. If a named interface cannot be found then false -// is returned. -// -// SetNodeInterface never fails when name is "". -func SetNodeInterface(name string) bool { - if interfaces == nil { - var err error - interfaces, err = net.Interfaces() - if err != nil && name != "" { - return false - } - } - - for _, ifs := range interfaces { - if len(ifs.HardwareAddr) >= 6 && (name == "" || name == ifs.Name) { - if setNodeID(ifs.HardwareAddr) { - ifname = ifs.Name - return true - } - } - } - - // We found no interfaces with a valid hardware address. If name - // does not specify a specific interface generate a random Node ID - // (section 4.1.6) - if name == "" { - if nodeID == nil { - nodeID = make([]byte, 6) - } - randomBits(nodeID) - return true - } - return false -} - -// NodeID returns a slice of a copy of the current Node ID, setting the Node ID -// if not already set. -func NodeID() []byte { - if nodeID == nil { - SetNodeInterface("") - } - nid := make([]byte, 6) - copy(nid, nodeID) - return nid -} - -// SetNodeID sets the Node ID to be used for Version 1 UUIDs. The first 6 bytes -// of id are used. If id is less than 6 bytes then false is returned and the -// Node ID is not set. -func SetNodeID(id []byte) bool { - if setNodeID(id) { - ifname = "user" - return true - } - return false -} - -func setNodeID(id []byte) bool { - if len(id) < 6 { - return false - } - if nodeID == nil { - nodeID = make([]byte, 6) - } - copy(nodeID, id) - return true -} - -// NodeID returns the 6 byte node id encoded in uuid. It returns nil if uuid is -// not valid. The NodeID is only well defined for version 1 and 2 UUIDs. -func (uuid UUID) NodeID() []byte { - if len(uuid) != 16 { - return nil - } - node := make([]byte, 6) - copy(node, uuid[10:]) - return node -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/time.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/time.go deleted file mode 100755 index 7ebc9be..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/time.go +++ /dev/null @@ -1,132 +0,0 @@ -// Copyright 2014 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "encoding/binary" - "sync" - "time" -) - -// A Time represents a time as the number of 100's of nanoseconds since 15 Oct -// 1582. -type Time int64 - -const ( - lillian = 2299160 // Julian day of 15 Oct 1582 - unix = 2440587 // Julian day of 1 Jan 1970 - epoch = unix - lillian // Days between epochs - g1582 = epoch * 86400 // seconds between epochs - g1582ns100 = g1582 * 10000000 // 100s of a nanoseconds between epochs -) - -var ( - mu sync.Mutex - lasttime uint64 // last time we returned - clock_seq uint16 // clock sequence for this run - - timeNow = time.Now // for testing -) - -// UnixTime converts t the number of seconds and nanoseconds using the Unix -// epoch of 1 Jan 1970. -func (t Time) UnixTime() (sec, nsec int64) { - sec = int64(t - g1582ns100) - nsec = (sec % 10000000) * 100 - sec /= 10000000 - return sec, nsec -} - -// GetTime returns the current Time (100s of nanoseconds since 15 Oct 1582) and -// clock sequence as well as adjusting the clock sequence as needed. An error -// is returned if the current time cannot be determined. -func GetTime() (Time, uint16, error) { - defer mu.Unlock() - mu.Lock() - return getTime() -} - -func getTime() (Time, uint16, error) { - t := timeNow() - - // If we don't have a clock sequence already, set one. - if clock_seq == 0 { - setClockSequence(-1) - } - now := uint64(t.UnixNano()/100) + g1582ns100 - - // If time has gone backwards with this clock sequence then we - // increment the clock sequence - if now <= lasttime { - clock_seq = ((clock_seq + 1) & 0x3fff) | 0x8000 - } - lasttime = now - return Time(now), clock_seq, nil -} - -// ClockSequence returns the current clock sequence, generating one if not -// already set. The clock sequence is only used for Version 1 UUIDs. -// -// The uuid package does not use global static storage for the clock sequence or -// the last time a UUID was generated. Unless SetClockSequence a new random -// clock sequence is generated the first time a clock sequence is requested by -// ClockSequence, GetTime, or NewUUID. (section 4.2.1.1) sequence is generated -// for -func ClockSequence() int { - defer mu.Unlock() - mu.Lock() - return clockSequence() -} - -func clockSequence() int { - if clock_seq == 0 { - setClockSequence(-1) - } - return int(clock_seq & 0x3fff) -} - -// SetClockSeq sets the clock sequence to the lower 14 bits of seq. Setting to -// -1 causes a new sequence to be generated. -func SetClockSequence(seq int) { - defer mu.Unlock() - mu.Lock() - setClockSequence(seq) -} - -func setClockSequence(seq int) { - if seq == -1 { - var b [2]byte - randomBits(b[:]) // clock sequence - seq = int(b[0])<<8 | int(b[1]) - } - old_seq := clock_seq - clock_seq = uint16(seq&0x3fff) | 0x8000 // Set our variant - if old_seq != clock_seq { - lasttime = 0 - } -} - -// Time returns the time in 100s of nanoseconds since 15 Oct 1582 encoded in -// uuid. It returns false if uuid is not valid. The time is only well defined -// for version 1 and 2 UUIDs. -func (uuid UUID) Time() (Time, bool) { - if len(uuid) != 16 { - return 0, false - } - time := int64(binary.BigEndian.Uint32(uuid[0:4])) - time |= int64(binary.BigEndian.Uint16(uuid[4:6])) << 32 - time |= int64(binary.BigEndian.Uint16(uuid[6:8])&0xfff) << 48 - return Time(time), true -} - -// ClockSequence returns the clock sequence encoded in uuid. It returns false -// if uuid is not valid. The clock sequence is only well defined for version 1 -// and 2 UUIDs. -func (uuid UUID) ClockSequence() (int, bool) { - if len(uuid) != 16 { - return 0, false - } - return int(binary.BigEndian.Uint16(uuid[8:10])) & 0x3fff, true -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/util.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/util.go deleted file mode 100644 index de40b10..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/util.go +++ /dev/null @@ -1,43 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "io" -) - -// randomBits completely fills slice b with random data. -func randomBits(b []byte) { - if _, err := io.ReadFull(rander, b); err != nil { - panic(err.Error()) // rand should never fail - } -} - -// xvalues returns the value of a byte as a hexadecimal digit or 255. -var xvalues = []byte{ - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 255, 255, 255, 255, 255, 255, - 255, 10, 11, 12, 13, 14, 15, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 10, 11, 12, 13, 14, 15, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, - 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, -} - -// xtob converts the the first two hex bytes of x into a byte. -func xtob(x string) (byte, bool) { - b1 := xvalues[x[0]] - b2 := xvalues[x[1]] - return (b1 << 4) | b2, b1 != 255 && b2 != 255 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/uuid.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/uuid.go deleted file mode 100755 index 2920fae..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/uuid.go +++ /dev/null @@ -1,163 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "bytes" - "crypto/rand" - "fmt" - "io" - "strings" -) - -// A UUID is a 128 bit (16 byte) Universal Unique IDentifier as defined in RFC -// 4122. -type UUID []byte - -// A Version represents a UUIDs version. -type Version byte - -// A Variant represents a UUIDs variant. -type Variant byte - -// Constants returned by Variant. -const ( - Invalid = Variant(iota) // Invalid UUID - RFC4122 // The variant specified in RFC4122 - Reserved // Reserved, NCS backward compatibility. - Microsoft // Reserved, Microsoft Corporation backward compatibility. - Future // Reserved for future definition. -) - -var rander = rand.Reader // random function - -// New returns a new random (version 4) UUID as a string. It is a convenience -// function for NewRandom().String(). -func New() string { - return NewRandom().String() -} - -// Parse decodes s into a UUID or returns nil. Both the UUID form of -// xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx and -// urn:uuid:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx are decoded. -func Parse(s string) UUID { - if len(s) == 36+9 { - if strings.ToLower(s[:9]) != "urn:uuid:" { - return nil - } - s = s[9:] - } else if len(s) != 36 { - return nil - } - if s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-' { - return nil - } - uuid := make([]byte, 16) - for i, x := range []int{ - 0, 2, 4, 6, - 9, 11, - 14, 16, - 19, 21, - 24, 26, 28, 30, 32, 34} { - if v, ok := xtob(s[x:]); !ok { - return nil - } else { - uuid[i] = v - } - } - return uuid -} - -// Equal returns true if uuid1 and uuid2 are equal. -func Equal(uuid1, uuid2 UUID) bool { - return bytes.Equal(uuid1, uuid2) -} - -// String returns the string form of uuid, xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx -// , or "" if uuid is invalid. -func (uuid UUID) String() string { - if uuid == nil || len(uuid) != 16 { - return "" - } - b := []byte(uuid) - return fmt.Sprintf("%08x-%04x-%04x-%04x-%012x", - b[:4], b[4:6], b[6:8], b[8:10], b[10:]) -} - -// URN returns the RFC 2141 URN form of uuid, -// urn:uuid:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx, or "" if uuid is invalid. -func (uuid UUID) URN() string { - if uuid == nil || len(uuid) != 16 { - return "" - } - b := []byte(uuid) - return fmt.Sprintf("urn:uuid:%08x-%04x-%04x-%04x-%012x", - b[:4], b[4:6], b[6:8], b[8:10], b[10:]) -} - -// Variant returns the variant encoded in uuid. It returns Invalid if -// uuid is invalid. -func (uuid UUID) Variant() Variant { - if len(uuid) != 16 { - return Invalid - } - switch { - case (uuid[8] & 0xc0) == 0x80: - return RFC4122 - case (uuid[8] & 0xe0) == 0xc0: - return Microsoft - case (uuid[8] & 0xe0) == 0xe0: - return Future - default: - return Reserved - } - panic("unreachable") -} - -// Version returns the verison of uuid. It returns false if uuid is not -// valid. -func (uuid UUID) Version() (Version, bool) { - if len(uuid) != 16 { - return 0, false - } - return Version(uuid[6] >> 4), true -} - -func (v Version) String() string { - if v > 15 { - return fmt.Sprintf("BAD_VERSION_%d", v) - } - return fmt.Sprintf("VERSION_%d", v) -} - -func (v Variant) String() string { - switch v { - case RFC4122: - return "RFC4122" - case Reserved: - return "Reserved" - case Microsoft: - return "Microsoft" - case Future: - return "Future" - case Invalid: - return "Invalid" - } - return fmt.Sprintf("BadVariant%d", int(v)) -} - -// SetRand sets the random number generator to r, which implents io.Reader. -// If r.Read returns an error when the package requests random data then -// a panic will be issued. -// -// Calling SetRand with nil sets the random number generator to the default -// generator. -func SetRand(r io.Reader) { - if r == nil { - rander = rand.Reader - return - } - rander = r -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version1.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version1.go deleted file mode 100644 index 0127eac..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version1.go +++ /dev/null @@ -1,41 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -import ( - "encoding/binary" -) - -// NewUUID returns a Version 1 UUID based on the current NodeID and clock -// sequence, and the current time. If the NodeID has not been set by SetNodeID -// or SetNodeInterface then it will be set automatically. If the NodeID cannot -// be set NewUUID returns nil. If clock sequence has not been set by -// SetClockSequence then it will be set automatically. If GetTime fails to -// return the current NewUUID returns nil. -func NewUUID() UUID { - if nodeID == nil { - SetNodeInterface("") - } - - now, seq, err := GetTime() - if err != nil { - return nil - } - - uuid := make([]byte, 16) - - time_low := uint32(now & 0xffffffff) - time_mid := uint16((now >> 32) & 0xffff) - time_hi := uint16((now >> 48) & 0x0fff) - time_hi |= 0x1000 // Version 1 - - binary.BigEndian.PutUint32(uuid[0:], time_low) - binary.BigEndian.PutUint16(uuid[4:], time_mid) - binary.BigEndian.PutUint16(uuid[6:], time_hi) - binary.BigEndian.PutUint16(uuid[8:], seq) - copy(uuid[10:], nodeID) - - return uuid -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version4.go b/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version4.go deleted file mode 100644 index b3d4a36..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/pborman/uuid/version4.go +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package uuid - -// Random returns a Random (Version 4) UUID or panics. -// -// The strength of the UUIDs is based on the strength of the crypto/rand -// package. -// -// A note about uniqueness derived from from the UUID Wikipedia entry: -// -// Randomly generated UUIDs have 122 random bits. One's annual risk of being -// hit by a meteorite is estimated to be one chance in 17 billion, that -// means the probability is about 0.00000000006 (6 × 10−11), -// equivalent to the odds of creating a few tens of trillions of UUIDs in a -// year and having one duplicate. -func NewRandom() UUID { - uuid := make([]byte, 16) - randomBits([]byte(uuid)) - uuid[6] = (uuid[6] & 0x0f) | 0x40 // Version 4 - uuid[8] = (uuid[8] & 0x3f) | 0x80 // Variant is 10 - return uuid -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/.travis.yml b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/.travis.yml deleted file mode 100644 index 0a7c136..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/.travis.yml +++ /dev/null @@ -1,21 +0,0 @@ -sudo: false - -language: go - -go: - - 1.5.4 - - 1.6.3 - - 1.7 - - tip - -matrix: - allow_failures: - - go: tip -install: - - go get github.com/golang/lint/golint - - export PATH=$GOPATH/bin:$PATH - - go install ./... - -script: - - verify/all.sh -v - - go test ./... diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/LICENSE b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/LICENSE deleted file mode 100644 index 63ed1cf..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/LICENSE +++ /dev/null @@ -1,28 +0,0 @@ -Copyright (c) 2012 Alex Ogier. All rights reserved. -Copyright (c) 2012 The Go Authors. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/README.md deleted file mode 100644 index 08ad945..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/README.md +++ /dev/null @@ -1,275 +0,0 @@ -[![Build Status](https://travis-ci.org/spf13/pflag.svg?branch=master)](https://travis-ci.org/spf13/pflag) - -## Description - -pflag is a drop-in replacement for Go's flag package, implementing -POSIX/GNU-style --flags. - -pflag is compatible with the [GNU extensions to the POSIX recommendations -for command-line options][1]. For a more precise description, see the -"Command-line flag syntax" section below. - -[1]: http://www.gnu.org/software/libc/manual/html_node/Argument-Syntax.html - -pflag is available under the same style of BSD license as the Go language, -which can be found in the LICENSE file. - -## Installation - -pflag is available using the standard `go get` command. - -Install by running: - - go get github.com/spf13/pflag - -Run tests by running: - - go test github.com/spf13/pflag - -## Usage - -pflag is a drop-in replacement of Go's native flag package. If you import -pflag under the name "flag" then all code should continue to function -with no changes. - -``` go -import flag "github.com/spf13/pflag" -``` - -There is one exception to this: if you directly instantiate the Flag struct -there is one more field "Shorthand" that you will need to set. -Most code never instantiates this struct directly, and instead uses -functions such as String(), BoolVar(), and Var(), and is therefore -unaffected. - -Define flags using flag.String(), Bool(), Int(), etc. - -This declares an integer flag, -flagname, stored in the pointer ip, with type *int. - -``` go -var ip *int = flag.Int("flagname", 1234, "help message for flagname") -``` - -If you like, you can bind the flag to a variable using the Var() functions. - -``` go -var flagvar int -func init() { - flag.IntVar(&flagvar, "flagname", 1234, "help message for flagname") -} -``` - -Or you can create custom flags that satisfy the Value interface (with -pointer receivers) and couple them to flag parsing by - -``` go -flag.Var(&flagVal, "name", "help message for flagname") -``` - -For such flags, the default value is just the initial value of the variable. - -After all flags are defined, call - -``` go -flag.Parse() -``` - -to parse the command line into the defined flags. - -Flags may then be used directly. If you're using the flags themselves, -they are all pointers; if you bind to variables, they're values. - -``` go -fmt.Println("ip has value ", *ip) -fmt.Println("flagvar has value ", flagvar) -``` - -There are helpers function to get values later if you have the FlagSet but -it was difficult to keep up with all of the flag pointers in your code. -If you have a pflag.FlagSet with a flag called 'flagname' of type int you -can use GetInt() to get the int value. But notice that 'flagname' must exist -and it must be an int. GetString("flagname") will fail. - -``` go -i, err := flagset.GetInt("flagname") -``` - -After parsing, the arguments after the flag are available as the -slice flag.Args() or individually as flag.Arg(i). -The arguments are indexed from 0 through flag.NArg()-1. - -The pflag package also defines some new functions that are not in flag, -that give one-letter shorthands for flags. You can use these by appending -'P' to the name of any function that defines a flag. - -``` go -var ip = flag.IntP("flagname", "f", 1234, "help message") -var flagvar bool -func init() { - flag.BoolVarP("boolname", "b", true, "help message") -} -flag.VarP(&flagVar, "varname", "v", 1234, "help message") -``` - -Shorthand letters can be used with single dashes on the command line. -Boolean shorthand flags can be combined with other shorthand flags. - -The default set of command-line flags is controlled by -top-level functions. The FlagSet type allows one to define -independent sets of flags, such as to implement subcommands -in a command-line interface. The methods of FlagSet are -analogous to the top-level functions for the command-line -flag set. - -## Setting no option default values for flags - -After you create a flag it is possible to set the pflag.NoOptDefVal for -the given flag. Doing this changes the meaning of the flag slightly. If -a flag has a NoOptDefVal and the flag is set on the command line without -an option the flag will be set to the NoOptDefVal. For example given: - -``` go -var ip = flag.IntP("flagname", "f", 1234, "help message") -flag.Lookup("flagname").NoOptDefVal = "4321" -``` - -Would result in something like - -| Parsed Arguments | Resulting Value | -| ------------- | ------------- | -| --flagname=1357 | ip=1357 | -| --flagname | ip=4321 | -| [nothing] | ip=1234 | - -## Command line flag syntax - -``` ---flag // boolean flags, or flags with no option default values ---flag x // only on flags without a default value ---flag=x -``` - -Unlike the flag package, a single dash before an option means something -different than a double dash. Single dashes signify a series of shorthand -letters for flags. All but the last shorthand letter must be boolean flags -or a flag with a default value - -``` -// boolean or flags where the 'no option default value' is set --f --f=true --abc -but --b true is INVALID - -// non-boolean and flags without a 'no option default value' --n 1234 --n=1234 --n1234 - -// mixed --abcs "hello" --absd="hello" --abcs1234 -``` - -Flag parsing stops after the terminator "--". Unlike the flag package, -flags can be interspersed with arguments anywhere on the command line -before this terminator. - -Integer flags accept 1234, 0664, 0x1234 and may be negative. -Boolean flags (in their long form) accept 1, 0, t, f, true, false, -TRUE, FALSE, True, False. -Duration flags accept any input valid for time.ParseDuration. - -## Mutating or "Normalizing" Flag names - -It is possible to set a custom flag name 'normalization function.' It allows flag names to be mutated both when created in the code and when used on the command line to some 'normalized' form. The 'normalized' form is used for comparison. Two examples of using the custom normalization func follow. - -**Example #1**: You want -, _, and . in flags to compare the same. aka --my-flag == --my_flag == --my.flag - -``` go -func wordSepNormalizeFunc(f *pflag.FlagSet, name string) pflag.NormalizedName { - from := []string{"-", "_"} - to := "." - for _, sep := range from { - name = strings.Replace(name, sep, to, -1) - } - return pflag.NormalizedName(name) -} - -myFlagSet.SetNormalizeFunc(wordSepNormalizeFunc) -``` - -**Example #2**: You want to alias two flags. aka --old-flag-name == --new-flag-name - -``` go -func aliasNormalizeFunc(f *pflag.FlagSet, name string) pflag.NormalizedName { - switch name { - case "old-flag-name": - name = "new-flag-name" - break - } - return pflag.NormalizedName(name) -} - -myFlagSet.SetNormalizeFunc(aliasNormalizeFunc) -``` - -## Deprecating a flag or its shorthand -It is possible to deprecate a flag, or just its shorthand. Deprecating a flag/shorthand hides it from help text and prints a usage message when the deprecated flag/shorthand is used. - -**Example #1**: You want to deprecate a flag named "badflag" as well as inform the users what flag they should use instead. -```go -// deprecate a flag by specifying its name and a usage message -flags.MarkDeprecated("badflag", "please use --good-flag instead") -``` -This hides "badflag" from help text, and prints `Flag --badflag has been deprecated, please use --good-flag instead` when "badflag" is used. - -**Example #2**: You want to keep a flag name "noshorthandflag" but deprecate its shortname "n". -```go -// deprecate a flag shorthand by specifying its flag name and a usage message -flags.MarkShorthandDeprecated("noshorthandflag", "please use --noshorthandflag only") -``` -This hides the shortname "n" from help text, and prints `Flag shorthand -n has been deprecated, please use --noshorthandflag only` when the shorthand "n" is used. - -Note that usage message is essential here, and it should not be empty. - -## Hidden flags -It is possible to mark a flag as hidden, meaning it will still function as normal, however will not show up in usage/help text. - -**Example**: You have a flag named "secretFlag" that you need for internal use only and don't want it showing up in help text, or for its usage text to be available. -```go -// hide a flag by specifying its name -flags.MarkHidden("secretFlag") -``` - -## Supporting Go flags when using pflag -In order to support flags defined using Go's `flag` package, they must be added to the `pflag` flagset. This is usually necessary -to support flags defined by third-party dependencies (e.g. `golang/glog`). - -**Example**: You want to add the Go flags to the `CommandLine` flagset -```go -import ( - goflag "flag" - flag "github.com/spf13/pflag" -) - -var ip *int = flag.Int("flagname", 1234, "help message for flagname") - -func main() { - flag.CommandLine.AddGoFlagSet(goflag.CommandLine) - flag.Parse() -} -``` - -## More info - -You can see the full reference documentation of the pflag package -[at godoc.org][3], or through go's standard documentation system by -running `godoc -http=:6060` and browsing to -[http://localhost:6060/pkg/github.com/ogier/pflag][2] after -installation. - -[2]: http://localhost:6060/pkg/github.com/ogier/pflag -[3]: http://godoc.org/github.com/ogier/pflag diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/bool.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/bool.go deleted file mode 100644 index c4c5c0b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/bool.go +++ /dev/null @@ -1,94 +0,0 @@ -package pflag - -import "strconv" - -// optional interface to indicate boolean flags that can be -// supplied without "=value" text -type boolFlag interface { - Value - IsBoolFlag() bool -} - -// -- bool Value -type boolValue bool - -func newBoolValue(val bool, p *bool) *boolValue { - *p = val - return (*boolValue)(p) -} - -func (b *boolValue) Set(s string) error { - v, err := strconv.ParseBool(s) - *b = boolValue(v) - return err -} - -func (b *boolValue) Type() string { - return "bool" -} - -func (b *boolValue) String() string { return strconv.FormatBool(bool(*b)) } - -func (b *boolValue) IsBoolFlag() bool { return true } - -func boolConv(sval string) (interface{}, error) { - return strconv.ParseBool(sval) -} - -// GetBool return the bool value of a flag with the given name -func (f *FlagSet) GetBool(name string) (bool, error) { - val, err := f.getFlagType(name, "bool", boolConv) - if err != nil { - return false, err - } - return val.(bool), nil -} - -// BoolVar defines a bool flag with specified name, default value, and usage string. -// The argument p points to a bool variable in which to store the value of the flag. -func (f *FlagSet) BoolVar(p *bool, name string, value bool, usage string) { - f.BoolVarP(p, name, "", value, usage) -} - -// BoolVarP is like BoolVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) BoolVarP(p *bool, name, shorthand string, value bool, usage string) { - flag := f.VarPF(newBoolValue(value, p), name, shorthand, usage) - flag.NoOptDefVal = "true" -} - -// BoolVar defines a bool flag with specified name, default value, and usage string. -// The argument p points to a bool variable in which to store the value of the flag. -func BoolVar(p *bool, name string, value bool, usage string) { - BoolVarP(p, name, "", value, usage) -} - -// BoolVarP is like BoolVar, but accepts a shorthand letter that can be used after a single dash. -func BoolVarP(p *bool, name, shorthand string, value bool, usage string) { - flag := CommandLine.VarPF(newBoolValue(value, p), name, shorthand, usage) - flag.NoOptDefVal = "true" -} - -// Bool defines a bool flag with specified name, default value, and usage string. -// The return value is the address of a bool variable that stores the value of the flag. -func (f *FlagSet) Bool(name string, value bool, usage string) *bool { - return f.BoolP(name, "", value, usage) -} - -// BoolP is like Bool, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) BoolP(name, shorthand string, value bool, usage string) *bool { - p := new(bool) - f.BoolVarP(p, name, shorthand, value, usage) - return p -} - -// Bool defines a bool flag with specified name, default value, and usage string. -// The return value is the address of a bool variable that stores the value of the flag. -func Bool(name string, value bool, usage string) *bool { - return BoolP(name, "", value, usage) -} - -// BoolP is like Bool, but accepts a shorthand letter that can be used after a single dash. -func BoolP(name, shorthand string, value bool, usage string) *bool { - b := CommandLine.BoolP(name, shorthand, value, usage) - return b -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/count.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/count.go deleted file mode 100644 index d22be41..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/count.go +++ /dev/null @@ -1,94 +0,0 @@ -package pflag - -import "strconv" - -// -- count Value -type countValue int - -func newCountValue(val int, p *int) *countValue { - *p = val - return (*countValue)(p) -} - -func (i *countValue) Set(s string) error { - v, err := strconv.ParseInt(s, 0, 64) - // -1 means that no specific value was passed, so increment - if v == -1 { - *i = countValue(*i + 1) - } else { - *i = countValue(v) - } - return err -} - -func (i *countValue) Type() string { - return "count" -} - -func (i *countValue) String() string { return strconv.Itoa(int(*i)) } - -func countConv(sval string) (interface{}, error) { - i, err := strconv.Atoi(sval) - if err != nil { - return nil, err - } - return i, nil -} - -// GetCount return the int value of a flag with the given name -func (f *FlagSet) GetCount(name string) (int, error) { - val, err := f.getFlagType(name, "count", countConv) - if err != nil { - return 0, err - } - return val.(int), nil -} - -// CountVar defines a count flag with specified name, default value, and usage string. -// The argument p points to an int variable in which to store the value of the flag. -// A count flag will add 1 to its value evey time it is found on the command line -func (f *FlagSet) CountVar(p *int, name string, usage string) { - f.CountVarP(p, name, "", usage) -} - -// CountVarP is like CountVar only take a shorthand for the flag name. -func (f *FlagSet) CountVarP(p *int, name, shorthand string, usage string) { - flag := f.VarPF(newCountValue(0, p), name, shorthand, usage) - flag.NoOptDefVal = "-1" -} - -// CountVar like CountVar only the flag is placed on the CommandLine instead of a given flag set -func CountVar(p *int, name string, usage string) { - CommandLine.CountVar(p, name, usage) -} - -// CountVarP is like CountVar only take a shorthand for the flag name. -func CountVarP(p *int, name, shorthand string, usage string) { - CommandLine.CountVarP(p, name, shorthand, usage) -} - -// Count defines a count flag with specified name, default value, and usage string. -// The return value is the address of an int variable that stores the value of the flag. -// A count flag will add 1 to its value evey time it is found on the command line -func (f *FlagSet) Count(name string, usage string) *int { - p := new(int) - f.CountVarP(p, name, "", usage) - return p -} - -// CountP is like Count only takes a shorthand for the flag name. -func (f *FlagSet) CountP(name, shorthand string, usage string) *int { - p := new(int) - f.CountVarP(p, name, shorthand, usage) - return p -} - -// Count like Count only the flag is placed on the CommandLine isntead of a given flag set -func Count(name string, usage string) *int { - return CommandLine.CountP(name, "", usage) -} - -// CountP is like Count only takes a shorthand for the flag name. -func CountP(name, shorthand string, usage string) *int { - return CommandLine.CountP(name, shorthand, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/duration.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/duration.go deleted file mode 100644 index e9debef..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/duration.go +++ /dev/null @@ -1,86 +0,0 @@ -package pflag - -import ( - "time" -) - -// -- time.Duration Value -type durationValue time.Duration - -func newDurationValue(val time.Duration, p *time.Duration) *durationValue { - *p = val - return (*durationValue)(p) -} - -func (d *durationValue) Set(s string) error { - v, err := time.ParseDuration(s) - *d = durationValue(v) - return err -} - -func (d *durationValue) Type() string { - return "duration" -} - -func (d *durationValue) String() string { return (*time.Duration)(d).String() } - -func durationConv(sval string) (interface{}, error) { - return time.ParseDuration(sval) -} - -// GetDuration return the duration value of a flag with the given name -func (f *FlagSet) GetDuration(name string) (time.Duration, error) { - val, err := f.getFlagType(name, "duration", durationConv) - if err != nil { - return 0, err - } - return val.(time.Duration), nil -} - -// DurationVar defines a time.Duration flag with specified name, default value, and usage string. -// The argument p points to a time.Duration variable in which to store the value of the flag. -func (f *FlagSet) DurationVar(p *time.Duration, name string, value time.Duration, usage string) { - f.VarP(newDurationValue(value, p), name, "", usage) -} - -// DurationVarP is like DurationVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) DurationVarP(p *time.Duration, name, shorthand string, value time.Duration, usage string) { - f.VarP(newDurationValue(value, p), name, shorthand, usage) -} - -// DurationVar defines a time.Duration flag with specified name, default value, and usage string. -// The argument p points to a time.Duration variable in which to store the value of the flag. -func DurationVar(p *time.Duration, name string, value time.Duration, usage string) { - CommandLine.VarP(newDurationValue(value, p), name, "", usage) -} - -// DurationVarP is like DurationVar, but accepts a shorthand letter that can be used after a single dash. -func DurationVarP(p *time.Duration, name, shorthand string, value time.Duration, usage string) { - CommandLine.VarP(newDurationValue(value, p), name, shorthand, usage) -} - -// Duration defines a time.Duration flag with specified name, default value, and usage string. -// The return value is the address of a time.Duration variable that stores the value of the flag. -func (f *FlagSet) Duration(name string, value time.Duration, usage string) *time.Duration { - p := new(time.Duration) - f.DurationVarP(p, name, "", value, usage) - return p -} - -// DurationP is like Duration, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) DurationP(name, shorthand string, value time.Duration, usage string) *time.Duration { - p := new(time.Duration) - f.DurationVarP(p, name, shorthand, value, usage) - return p -} - -// Duration defines a time.Duration flag with specified name, default value, and usage string. -// The return value is the address of a time.Duration variable that stores the value of the flag. -func Duration(name string, value time.Duration, usage string) *time.Duration { - return CommandLine.DurationP(name, "", value, usage) -} - -// DurationP is like Duration, but accepts a shorthand letter that can be used after a single dash. -func DurationP(name, shorthand string, value time.Duration, usage string) *time.Duration { - return CommandLine.DurationP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/flag.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/flag.go deleted file mode 100644 index b0b0d46..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/flag.go +++ /dev/null @@ -1,947 +0,0 @@ -// Copyright 2009 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -/* -Package pflag is a drop-in replacement for Go's flag package, implementing -POSIX/GNU-style --flags. - -pflag is compatible with the GNU extensions to the POSIX recommendations -for command-line options. See -http://www.gnu.org/software/libc/manual/html_node/Argument-Syntax.html - -Usage: - -pflag is a drop-in replacement of Go's native flag package. If you import -pflag under the name "flag" then all code should continue to function -with no changes. - - import flag "github.com/ogier/pflag" - - There is one exception to this: if you directly instantiate the Flag struct -there is one more field "Shorthand" that you will need to set. -Most code never instantiates this struct directly, and instead uses -functions such as String(), BoolVar(), and Var(), and is therefore -unaffected. - -Define flags using flag.String(), Bool(), Int(), etc. - -This declares an integer flag, -flagname, stored in the pointer ip, with type *int. - var ip = flag.Int("flagname", 1234, "help message for flagname") -If you like, you can bind the flag to a variable using the Var() functions. - var flagvar int - func init() { - flag.IntVar(&flagvar, "flagname", 1234, "help message for flagname") - } -Or you can create custom flags that satisfy the Value interface (with -pointer receivers) and couple them to flag parsing by - flag.Var(&flagVal, "name", "help message for flagname") -For such flags, the default value is just the initial value of the variable. - -After all flags are defined, call - flag.Parse() -to parse the command line into the defined flags. - -Flags may then be used directly. If you're using the flags themselves, -they are all pointers; if you bind to variables, they're values. - fmt.Println("ip has value ", *ip) - fmt.Println("flagvar has value ", flagvar) - -After parsing, the arguments after the flag are available as the -slice flag.Args() or individually as flag.Arg(i). -The arguments are indexed from 0 through flag.NArg()-1. - -The pflag package also defines some new functions that are not in flag, -that give one-letter shorthands for flags. You can use these by appending -'P' to the name of any function that defines a flag. - var ip = flag.IntP("flagname", "f", 1234, "help message") - var flagvar bool - func init() { - flag.BoolVarP("boolname", "b", true, "help message") - } - flag.VarP(&flagVar, "varname", "v", 1234, "help message") -Shorthand letters can be used with single dashes on the command line. -Boolean shorthand flags can be combined with other shorthand flags. - -Command line flag syntax: - --flag // boolean flags only - --flag=x - -Unlike the flag package, a single dash before an option means something -different than a double dash. Single dashes signify a series of shorthand -letters for flags. All but the last shorthand letter must be boolean flags. - // boolean flags - -f - -abc - // non-boolean flags - -n 1234 - -Ifile - // mixed - -abcs "hello" - -abcn1234 - -Flag parsing stops after the terminator "--". Unlike the flag package, -flags can be interspersed with arguments anywhere on the command line -before this terminator. - -Integer flags accept 1234, 0664, 0x1234 and may be negative. -Boolean flags (in their long form) accept 1, 0, t, f, true, false, -TRUE, FALSE, True, False. -Duration flags accept any input valid for time.ParseDuration. - -The default set of command-line flags is controlled by -top-level functions. The FlagSet type allows one to define -independent sets of flags, such as to implement subcommands -in a command-line interface. The methods of FlagSet are -analogous to the top-level functions for the command-line -flag set. -*/ -package pflag - -import ( - "bytes" - "errors" - "fmt" - "io" - "os" - "sort" - "strings" -) - -// ErrHelp is the error returned if the flag -help is invoked but no such flag is defined. -var ErrHelp = errors.New("pflag: help requested") - -// ErrorHandling defines how to handle flag parsing errors. -type ErrorHandling int - -const ( - // ContinueOnError will return an err from Parse() if an error is found - ContinueOnError ErrorHandling = iota - // ExitOnError will call os.Exit(2) if an error is found when parsing - ExitOnError - // PanicOnError will panic() if an error is found when parsing flags - PanicOnError -) - -// NormalizedName is a flag name that has been normalized according to rules -// for the FlagSet (e.g. making '-' and '_' equivalent). -type NormalizedName string - -// A FlagSet represents a set of defined flags. -type FlagSet struct { - // Usage is the function called when an error occurs while parsing flags. - // The field is a function (not a method) that may be changed to point to - // a custom error handler. - Usage func() - - name string - parsed bool - actual map[NormalizedName]*Flag - formal map[NormalizedName]*Flag - shorthands map[byte]*Flag - args []string // arguments after flags - argsLenAtDash int // len(args) when a '--' was located when parsing, or -1 if no -- - exitOnError bool // does the program exit if there's an error? - errorHandling ErrorHandling - output io.Writer // nil means stderr; use out() accessor - interspersed bool // allow interspersed option/non-option args - normalizeNameFunc func(f *FlagSet, name string) NormalizedName -} - -// A Flag represents the state of a flag. -type Flag struct { - Name string // name as it appears on command line - Shorthand string // one-letter abbreviated flag - Usage string // help message - Value Value // value as set - DefValue string // default value (as text); for usage message - Changed bool // If the user set the value (or if left to default) - NoOptDefVal string //default value (as text); if the flag is on the command line without any options - Deprecated string // If this flag is deprecated, this string is the new or now thing to use - Hidden bool // used by cobra.Command to allow flags to be hidden from help/usage text - ShorthandDeprecated string // If the shorthand of this flag is deprecated, this string is the new or now thing to use - Annotations map[string][]string // used by cobra.Command bash autocomple code -} - -// Value is the interface to the dynamic value stored in a flag. -// (The default value is represented as a string.) -type Value interface { - String() string - Set(string) error - Type() string -} - -// sortFlags returns the flags as a slice in lexicographical sorted order. -func sortFlags(flags map[NormalizedName]*Flag) []*Flag { - list := make(sort.StringSlice, len(flags)) - i := 0 - for k := range flags { - list[i] = string(k) - i++ - } - list.Sort() - result := make([]*Flag, len(list)) - for i, name := range list { - result[i] = flags[NormalizedName(name)] - } - return result -} - -// SetNormalizeFunc allows you to add a function which can translate flag names. -// Flags added to the FlagSet will be translated and then when anything tries to -// look up the flag that will also be translated. So it would be possible to create -// a flag named "getURL" and have it translated to "geturl". A user could then pass -// "--getUrl" which may also be translated to "geturl" and everything will work. -func (f *FlagSet) SetNormalizeFunc(n func(f *FlagSet, name string) NormalizedName) { - f.normalizeNameFunc = n - for k, v := range f.formal { - delete(f.formal, k) - nname := f.normalizeFlagName(string(k)) - f.formal[nname] = v - v.Name = string(nname) - } -} - -// GetNormalizeFunc returns the previously set NormalizeFunc of a function which -// does no translation, if not set previously. -func (f *FlagSet) GetNormalizeFunc() func(f *FlagSet, name string) NormalizedName { - if f.normalizeNameFunc != nil { - return f.normalizeNameFunc - } - return func(f *FlagSet, name string) NormalizedName { return NormalizedName(name) } -} - -func (f *FlagSet) normalizeFlagName(name string) NormalizedName { - n := f.GetNormalizeFunc() - return n(f, name) -} - -func (f *FlagSet) out() io.Writer { - if f.output == nil { - return os.Stderr - } - return f.output -} - -// SetOutput sets the destination for usage and error messages. -// If output is nil, os.Stderr is used. -func (f *FlagSet) SetOutput(output io.Writer) { - f.output = output -} - -// VisitAll visits the flags in lexicographical order, calling fn for each. -// It visits all flags, even those not set. -func (f *FlagSet) VisitAll(fn func(*Flag)) { - for _, flag := range sortFlags(f.formal) { - fn(flag) - } -} - -// HasFlags returns a bool to indicate if the FlagSet has any flags definied. -func (f *FlagSet) HasFlags() bool { - return len(f.formal) > 0 -} - -// HasAvailableFlags returns a bool to indicate if the FlagSet has any flags -// definied that are not hidden or deprecated. -func (f *FlagSet) HasAvailableFlags() bool { - for _, flag := range f.formal { - if !flag.Hidden && len(flag.Deprecated) == 0 { - return true - } - } - return false -} - -// VisitAll visits the command-line flags in lexicographical order, calling -// fn for each. It visits all flags, even those not set. -func VisitAll(fn func(*Flag)) { - CommandLine.VisitAll(fn) -} - -// Visit visits the flags in lexicographical order, calling fn for each. -// It visits only those flags that have been set. -func (f *FlagSet) Visit(fn func(*Flag)) { - for _, flag := range sortFlags(f.actual) { - fn(flag) - } -} - -// Visit visits the command-line flags in lexicographical order, calling fn -// for each. It visits only those flags that have been set. -func Visit(fn func(*Flag)) { - CommandLine.Visit(fn) -} - -// Lookup returns the Flag structure of the named flag, returning nil if none exists. -func (f *FlagSet) Lookup(name string) *Flag { - return f.lookup(f.normalizeFlagName(name)) -} - -// lookup returns the Flag structure of the named flag, returning nil if none exists. -func (f *FlagSet) lookup(name NormalizedName) *Flag { - return f.formal[name] -} - -// func to return a given type for a given flag name -func (f *FlagSet) getFlagType(name string, ftype string, convFunc func(sval string) (interface{}, error)) (interface{}, error) { - flag := f.Lookup(name) - if flag == nil { - err := fmt.Errorf("flag accessed but not defined: %s", name) - return nil, err - } - - if flag.Value.Type() != ftype { - err := fmt.Errorf("trying to get %s value of flag of type %s", ftype, flag.Value.Type()) - return nil, err - } - - sval := flag.Value.String() - result, err := convFunc(sval) - if err != nil { - return nil, err - } - return result, nil -} - -// ArgsLenAtDash will return the length of f.Args at the moment when a -- was -// found during arg parsing. This allows your program to know which args were -// before the -- and which came after. -func (f *FlagSet) ArgsLenAtDash() int { - return f.argsLenAtDash -} - -// MarkDeprecated indicated that a flag is deprecated in your program. It will -// continue to function but will not show up in help or usage messages. Using -// this flag will also print the given usageMessage. -func (f *FlagSet) MarkDeprecated(name string, usageMessage string) error { - flag := f.Lookup(name) - if flag == nil { - return fmt.Errorf("flag %q does not exist", name) - } - if len(usageMessage) == 0 { - return fmt.Errorf("deprecated message for flag %q must be set", name) - } - flag.Deprecated = usageMessage - return nil -} - -// MarkShorthandDeprecated will mark the shorthand of a flag deprecated in your -// program. It will continue to function but will not show up in help or usage -// messages. Using this flag will also print the given usageMessage. -func (f *FlagSet) MarkShorthandDeprecated(name string, usageMessage string) error { - flag := f.Lookup(name) - if flag == nil { - return fmt.Errorf("flag %q does not exist", name) - } - if len(usageMessage) == 0 { - return fmt.Errorf("deprecated message for flag %q must be set", name) - } - flag.ShorthandDeprecated = usageMessage - return nil -} - -// MarkHidden sets a flag to 'hidden' in your program. It will continue to -// function but will not show up in help or usage messages. -func (f *FlagSet) MarkHidden(name string) error { - flag := f.Lookup(name) - if flag == nil { - return fmt.Errorf("flag %q does not exist", name) - } - flag.Hidden = true - return nil -} - -// Lookup returns the Flag structure of the named command-line flag, -// returning nil if none exists. -func Lookup(name string) *Flag { - return CommandLine.Lookup(name) -} - -// Set sets the value of the named flag. -func (f *FlagSet) Set(name, value string) error { - normalName := f.normalizeFlagName(name) - flag, ok := f.formal[normalName] - if !ok { - return fmt.Errorf("no such flag -%v", name) - } - err := flag.Value.Set(value) - if err != nil { - return err - } - if f.actual == nil { - f.actual = make(map[NormalizedName]*Flag) - } - f.actual[normalName] = flag - flag.Changed = true - if len(flag.Deprecated) > 0 { - fmt.Fprintf(os.Stderr, "Flag --%s has been deprecated, %s\n", flag.Name, flag.Deprecated) - } - return nil -} - -// SetAnnotation allows one to set arbitrary annotations on a flag in the FlagSet. -// This is sometimes used by spf13/cobra programs which want to generate additional -// bash completion information. -func (f *FlagSet) SetAnnotation(name, key string, values []string) error { - normalName := f.normalizeFlagName(name) - flag, ok := f.formal[normalName] - if !ok { - return fmt.Errorf("no such flag -%v", name) - } - if flag.Annotations == nil { - flag.Annotations = map[string][]string{} - } - flag.Annotations[key] = values - return nil -} - -// Changed returns true if the flag was explicitly set during Parse() and false -// otherwise -func (f *FlagSet) Changed(name string) bool { - flag := f.Lookup(name) - // If a flag doesn't exist, it wasn't changed.... - if flag == nil { - return false - } - return flag.Changed -} - -// Set sets the value of the named command-line flag. -func Set(name, value string) error { - return CommandLine.Set(name, value) -} - -// PrintDefaults prints, to standard error unless configured -// otherwise, the default values of all defined flags in the set. -func (f *FlagSet) PrintDefaults() { - usages := f.FlagUsages() - fmt.Fprintf(f.out(), "%s", usages) -} - -// defaultIsZeroValue returns true if the default value for this flag represents -// a zero value. -func (f *Flag) defaultIsZeroValue() bool { - switch f.Value.(type) { - case boolFlag: - return f.DefValue == "false" - case *durationValue: - // Beginning in Go 1.7, duration zero values are "0s" - return f.DefValue == "0" || f.DefValue == "0s" - case *intValue, *int8Value, *int32Value, *int64Value, *uintValue, *uint8Value, *uint16Value, *uint32Value, *uint64Value, *countValue, *float32Value, *float64Value: - return f.DefValue == "0" - case *stringValue: - return f.DefValue == "" - case *ipValue, *ipMaskValue, *ipNetValue: - return f.DefValue == "" - case *intSliceValue, *stringSliceValue, *stringArrayValue: - return f.DefValue == "[]" - default: - switch f.Value.String() { - case "false": - return true - case "": - return true - case "": - return true - case "0": - return true - } - return false - } -} - -// UnquoteUsage extracts a back-quoted name from the usage -// string for a flag and returns it and the un-quoted usage. -// Given "a `name` to show" it returns ("name", "a name to show"). -// If there are no back quotes, the name is an educated guess of the -// type of the flag's value, or the empty string if the flag is boolean. -func UnquoteUsage(flag *Flag) (name string, usage string) { - // Look for a back-quoted name, but avoid the strings package. - usage = flag.Usage - for i := 0; i < len(usage); i++ { - if usage[i] == '`' { - for j := i + 1; j < len(usage); j++ { - if usage[j] == '`' { - name = usage[i+1 : j] - usage = usage[:i] + name + usage[j+1:] - return name, usage - } - } - break // Only one back quote; use type name. - } - } - - name = flag.Value.Type() - switch name { - case "bool": - name = "" - case "float64": - name = "float" - case "int64": - name = "int" - case "uint64": - name = "uint" - } - - return -} - -// FlagUsages Returns a string containing the usage information for all flags in -// the FlagSet -func (f *FlagSet) FlagUsages() string { - x := new(bytes.Buffer) - - lines := make([]string, 0, len(f.formal)) - - maxlen := 0 - f.VisitAll(func(flag *Flag) { - if len(flag.Deprecated) > 0 || flag.Hidden { - return - } - - line := "" - if len(flag.Shorthand) > 0 && len(flag.ShorthandDeprecated) == 0 { - line = fmt.Sprintf(" -%s, --%s", flag.Shorthand, flag.Name) - } else { - line = fmt.Sprintf(" --%s", flag.Name) - } - - varname, usage := UnquoteUsage(flag) - if len(varname) > 0 { - line += " " + varname - } - if len(flag.NoOptDefVal) > 0 { - switch flag.Value.Type() { - case "string": - line += fmt.Sprintf("[=%q]", flag.NoOptDefVal) - case "bool": - if flag.NoOptDefVal != "true" { - line += fmt.Sprintf("[=%s]", flag.NoOptDefVal) - } - default: - line += fmt.Sprintf("[=%s]", flag.NoOptDefVal) - } - } - - // This special character will be replaced with spacing once the - // correct alignment is calculated - line += "\x00" - if len(line) > maxlen { - maxlen = len(line) - } - - line += usage - if !flag.defaultIsZeroValue() { - if flag.Value.Type() == "string" { - line += fmt.Sprintf(" (default %q)", flag.DefValue) - } else { - line += fmt.Sprintf(" (default %s)", flag.DefValue) - } - } - - lines = append(lines, line) - }) - - for _, line := range lines { - sidx := strings.Index(line, "\x00") - spacing := strings.Repeat(" ", maxlen-sidx) - fmt.Fprintln(x, line[:sidx], spacing, line[sidx+1:]) - } - - return x.String() -} - -// PrintDefaults prints to standard error the default values of all defined command-line flags. -func PrintDefaults() { - CommandLine.PrintDefaults() -} - -// defaultUsage is the default function to print a usage message. -func defaultUsage(f *FlagSet) { - fmt.Fprintf(f.out(), "Usage of %s:\n", f.name) - f.PrintDefaults() -} - -// NOTE: Usage is not just defaultUsage(CommandLine) -// because it serves (via godoc flag Usage) as the example -// for how to write your own usage function. - -// Usage prints to standard error a usage message documenting all defined command-line flags. -// The function is a variable that may be changed to point to a custom function. -// By default it prints a simple header and calls PrintDefaults; for details about the -// format of the output and how to control it, see the documentation for PrintDefaults. -var Usage = func() { - fmt.Fprintf(os.Stderr, "Usage of %s:\n", os.Args[0]) - PrintDefaults() -} - -// NFlag returns the number of flags that have been set. -func (f *FlagSet) NFlag() int { return len(f.actual) } - -// NFlag returns the number of command-line flags that have been set. -func NFlag() int { return len(CommandLine.actual) } - -// Arg returns the i'th argument. Arg(0) is the first remaining argument -// after flags have been processed. -func (f *FlagSet) Arg(i int) string { - if i < 0 || i >= len(f.args) { - return "" - } - return f.args[i] -} - -// Arg returns the i'th command-line argument. Arg(0) is the first remaining argument -// after flags have been processed. -func Arg(i int) string { - return CommandLine.Arg(i) -} - -// NArg is the number of arguments remaining after flags have been processed. -func (f *FlagSet) NArg() int { return len(f.args) } - -// NArg is the number of arguments remaining after flags have been processed. -func NArg() int { return len(CommandLine.args) } - -// Args returns the non-flag arguments. -func (f *FlagSet) Args() []string { return f.args } - -// Args returns the non-flag command-line arguments. -func Args() []string { return CommandLine.args } - -// Var defines a flag with the specified name and usage string. The type and -// value of the flag are represented by the first argument, of type Value, which -// typically holds a user-defined implementation of Value. For instance, the -// caller could create a flag that turns a comma-separated string into a slice -// of strings by giving the slice the methods of Value; in particular, Set would -// decompose the comma-separated string into the slice. -func (f *FlagSet) Var(value Value, name string, usage string) { - f.VarP(value, name, "", usage) -} - -// VarPF is like VarP, but returns the flag created -func (f *FlagSet) VarPF(value Value, name, shorthand, usage string) *Flag { - // Remember the default value as a string; it won't change. - flag := &Flag{ - Name: name, - Shorthand: shorthand, - Usage: usage, - Value: value, - DefValue: value.String(), - } - f.AddFlag(flag) - return flag -} - -// VarP is like Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) VarP(value Value, name, shorthand, usage string) { - _ = f.VarPF(value, name, shorthand, usage) -} - -// AddFlag will add the flag to the FlagSet -func (f *FlagSet) AddFlag(flag *Flag) { - // Call normalizeFlagName function only once - normalizedFlagName := f.normalizeFlagName(flag.Name) - - _, alreadythere := f.formal[normalizedFlagName] - if alreadythere { - msg := fmt.Sprintf("%s flag redefined: %s", f.name, flag.Name) - fmt.Fprintln(f.out(), msg) - panic(msg) // Happens only if flags are declared with identical names - } - if f.formal == nil { - f.formal = make(map[NormalizedName]*Flag) - } - - flag.Name = string(normalizedFlagName) - f.formal[normalizedFlagName] = flag - - if len(flag.Shorthand) == 0 { - return - } - if len(flag.Shorthand) > 1 { - fmt.Fprintf(f.out(), "%s shorthand more than ASCII character: %s\n", f.name, flag.Shorthand) - panic("shorthand is more than one character") - } - if f.shorthands == nil { - f.shorthands = make(map[byte]*Flag) - } - c := flag.Shorthand[0] - old, alreadythere := f.shorthands[c] - if alreadythere { - fmt.Fprintf(f.out(), "%s shorthand reused: %q for %s already used for %s\n", f.name, c, flag.Name, old.Name) - panic("shorthand redefinition") - } - f.shorthands[c] = flag -} - -// AddFlagSet adds one FlagSet to another. If a flag is already present in f -// the flag from newSet will be ignored -func (f *FlagSet) AddFlagSet(newSet *FlagSet) { - if newSet == nil { - return - } - newSet.VisitAll(func(flag *Flag) { - if f.Lookup(flag.Name) == nil { - f.AddFlag(flag) - } - }) -} - -// Var defines a flag with the specified name and usage string. The type and -// value of the flag are represented by the first argument, of type Value, which -// typically holds a user-defined implementation of Value. For instance, the -// caller could create a flag that turns a comma-separated string into a slice -// of strings by giving the slice the methods of Value; in particular, Set would -// decompose the comma-separated string into the slice. -func Var(value Value, name string, usage string) { - CommandLine.VarP(value, name, "", usage) -} - -// VarP is like Var, but accepts a shorthand letter that can be used after a single dash. -func VarP(value Value, name, shorthand, usage string) { - CommandLine.VarP(value, name, shorthand, usage) -} - -// failf prints to standard error a formatted error and usage message and -// returns the error. -func (f *FlagSet) failf(format string, a ...interface{}) error { - err := fmt.Errorf(format, a...) - fmt.Fprintln(f.out(), err) - f.usage() - return err -} - -// usage calls the Usage method for the flag set, or the usage function if -// the flag set is CommandLine. -func (f *FlagSet) usage() { - if f == CommandLine { - Usage() - } else if f.Usage == nil { - defaultUsage(f) - } else { - f.Usage() - } -} - -func (f *FlagSet) setFlag(flag *Flag, value string, origArg string) error { - if err := flag.Value.Set(value); err != nil { - return f.failf("invalid argument %q for %s: %v", value, origArg, err) - } - // mark as visited for Visit() - if f.actual == nil { - f.actual = make(map[NormalizedName]*Flag) - } - f.actual[f.normalizeFlagName(flag.Name)] = flag - flag.Changed = true - if len(flag.Deprecated) > 0 { - fmt.Fprintf(os.Stderr, "Flag --%s has been deprecated, %s\n", flag.Name, flag.Deprecated) - } - if len(flag.ShorthandDeprecated) > 0 && containsShorthand(origArg, flag.Shorthand) { - fmt.Fprintf(os.Stderr, "Flag shorthand -%s has been deprecated, %s\n", flag.Shorthand, flag.ShorthandDeprecated) - } - return nil -} - -func containsShorthand(arg, shorthand string) bool { - // filter out flags -- - if strings.HasPrefix(arg, "-") { - return false - } - arg = strings.SplitN(arg, "=", 2)[0] - return strings.Contains(arg, shorthand) -} - -func (f *FlagSet) parseLongArg(s string, args []string) (a []string, err error) { - a = args - name := s[2:] - if len(name) == 0 || name[0] == '-' || name[0] == '=' { - err = f.failf("bad flag syntax: %s", s) - return - } - split := strings.SplitN(name, "=", 2) - name = split[0] - flag, alreadythere := f.formal[f.normalizeFlagName(name)] - if !alreadythere { - if name == "help" { // special case for nice help message. - f.usage() - return a, ErrHelp - } - err = f.failf("unknown flag: --%s", name) - return - } - var value string - if len(split) == 2 { - // '--flag=arg' - value = split[1] - } else if len(flag.NoOptDefVal) > 0 { - // '--flag' (arg was optional) - value = flag.NoOptDefVal - } else if len(a) > 0 { - // '--flag arg' - value = a[0] - a = a[1:] - } else { - // '--flag' (arg was required) - err = f.failf("flag needs an argument: %s", s) - return - } - err = f.setFlag(flag, value, s) - return -} - -func (f *FlagSet) parseSingleShortArg(shorthands string, args []string) (outShorts string, outArgs []string, err error) { - if strings.HasPrefix(shorthands, "test.") { - return - } - outArgs = args - outShorts = shorthands[1:] - c := shorthands[0] - - flag, alreadythere := f.shorthands[c] - if !alreadythere { - if c == 'h' { // special case for nice help message. - f.usage() - err = ErrHelp - return - } - //TODO continue on error - err = f.failf("unknown shorthand flag: %q in -%s", c, shorthands) - return - } - var value string - if len(shorthands) > 2 && shorthands[1] == '=' { - value = shorthands[2:] - outShorts = "" - } else if len(flag.NoOptDefVal) > 0 { - value = flag.NoOptDefVal - } else if len(shorthands) > 1 { - value = shorthands[1:] - outShorts = "" - } else if len(args) > 0 { - value = args[0] - outArgs = args[1:] - } else { - err = f.failf("flag needs an argument: %q in -%s", c, shorthands) - return - } - err = f.setFlag(flag, value, shorthands) - return -} - -func (f *FlagSet) parseShortArg(s string, args []string) (a []string, err error) { - a = args - shorthands := s[1:] - - for len(shorthands) > 0 { - shorthands, a, err = f.parseSingleShortArg(shorthands, args) - if err != nil { - return - } - } - - return -} - -func (f *FlagSet) parseArgs(args []string) (err error) { - for len(args) > 0 { - s := args[0] - args = args[1:] - if len(s) == 0 || s[0] != '-' || len(s) == 1 { - if !f.interspersed { - f.args = append(f.args, s) - f.args = append(f.args, args...) - return nil - } - f.args = append(f.args, s) - continue - } - - if s[1] == '-' { - if len(s) == 2 { // "--" terminates the flags - f.argsLenAtDash = len(f.args) - f.args = append(f.args, args...) - break - } - args, err = f.parseLongArg(s, args) - } else { - args, err = f.parseShortArg(s, args) - } - if err != nil { - return - } - } - return -} - -// Parse parses flag definitions from the argument list, which should not -// include the command name. Must be called after all flags in the FlagSet -// are defined and before flags are accessed by the program. -// The return value will be ErrHelp if -help was set but not defined. -func (f *FlagSet) Parse(arguments []string) error { - f.parsed = true - f.args = make([]string, 0, len(arguments)) - err := f.parseArgs(arguments) - if err != nil { - switch f.errorHandling { - case ContinueOnError: - return err - case ExitOnError: - os.Exit(2) - case PanicOnError: - panic(err) - } - } - return nil -} - -// Parsed reports whether f.Parse has been called. -func (f *FlagSet) Parsed() bool { - return f.parsed -} - -// Parse parses the command-line flags from os.Args[1:]. Must be called -// after all flags are defined and before flags are accessed by the program. -func Parse() { - // Ignore errors; CommandLine is set for ExitOnError. - CommandLine.Parse(os.Args[1:]) -} - -// SetInterspersed sets whether to support interspersed option/non-option arguments. -func SetInterspersed(interspersed bool) { - CommandLine.SetInterspersed(interspersed) -} - -// Parsed returns true if the command-line flags have been parsed. -func Parsed() bool { - return CommandLine.Parsed() -} - -// CommandLine is the default set of command-line flags, parsed from os.Args. -var CommandLine = NewFlagSet(os.Args[0], ExitOnError) - -// NewFlagSet returns a new, empty flag set with the specified name and -// error handling property. -func NewFlagSet(name string, errorHandling ErrorHandling) *FlagSet { - f := &FlagSet{ - name: name, - errorHandling: errorHandling, - argsLenAtDash: -1, - interspersed: true, - } - return f -} - -// SetInterspersed sets whether to support interspersed option/non-option arguments. -func (f *FlagSet) SetInterspersed(interspersed bool) { - f.interspersed = interspersed -} - -// Init sets the name and error handling property for a flag set. -// By default, the zero FlagSet uses an empty name and the -// ContinueOnError error handling policy. -func (f *FlagSet) Init(name string, errorHandling ErrorHandling) { - f.name = name - f.errorHandling = errorHandling - f.argsLenAtDash = -1 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float32.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float32.go deleted file mode 100644 index a243f81..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float32.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- float32 Value -type float32Value float32 - -func newFloat32Value(val float32, p *float32) *float32Value { - *p = val - return (*float32Value)(p) -} - -func (f *float32Value) Set(s string) error { - v, err := strconv.ParseFloat(s, 32) - *f = float32Value(v) - return err -} - -func (f *float32Value) Type() string { - return "float32" -} - -func (f *float32Value) String() string { return strconv.FormatFloat(float64(*f), 'g', -1, 32) } - -func float32Conv(sval string) (interface{}, error) { - v, err := strconv.ParseFloat(sval, 32) - if err != nil { - return 0, err - } - return float32(v), nil -} - -// GetFloat32 return the float32 value of a flag with the given name -func (f *FlagSet) GetFloat32(name string) (float32, error) { - val, err := f.getFlagType(name, "float32", float32Conv) - if err != nil { - return 0, err - } - return val.(float32), nil -} - -// Float32Var defines a float32 flag with specified name, default value, and usage string. -// The argument p points to a float32 variable in which to store the value of the flag. -func (f *FlagSet) Float32Var(p *float32, name string, value float32, usage string) { - f.VarP(newFloat32Value(value, p), name, "", usage) -} - -// Float32VarP is like Float32Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Float32VarP(p *float32, name, shorthand string, value float32, usage string) { - f.VarP(newFloat32Value(value, p), name, shorthand, usage) -} - -// Float32Var defines a float32 flag with specified name, default value, and usage string. -// The argument p points to a float32 variable in which to store the value of the flag. -func Float32Var(p *float32, name string, value float32, usage string) { - CommandLine.VarP(newFloat32Value(value, p), name, "", usage) -} - -// Float32VarP is like Float32Var, but accepts a shorthand letter that can be used after a single dash. -func Float32VarP(p *float32, name, shorthand string, value float32, usage string) { - CommandLine.VarP(newFloat32Value(value, p), name, shorthand, usage) -} - -// Float32 defines a float32 flag with specified name, default value, and usage string. -// The return value is the address of a float32 variable that stores the value of the flag. -func (f *FlagSet) Float32(name string, value float32, usage string) *float32 { - p := new(float32) - f.Float32VarP(p, name, "", value, usage) - return p -} - -// Float32P is like Float32, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Float32P(name, shorthand string, value float32, usage string) *float32 { - p := new(float32) - f.Float32VarP(p, name, shorthand, value, usage) - return p -} - -// Float32 defines a float32 flag with specified name, default value, and usage string. -// The return value is the address of a float32 variable that stores the value of the flag. -func Float32(name string, value float32, usage string) *float32 { - return CommandLine.Float32P(name, "", value, usage) -} - -// Float32P is like Float32, but accepts a shorthand letter that can be used after a single dash. -func Float32P(name, shorthand string, value float32, usage string) *float32 { - return CommandLine.Float32P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float64.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float64.go deleted file mode 100644 index 04b5492..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/float64.go +++ /dev/null @@ -1,84 +0,0 @@ -package pflag - -import "strconv" - -// -- float64 Value -type float64Value float64 - -func newFloat64Value(val float64, p *float64) *float64Value { - *p = val - return (*float64Value)(p) -} - -func (f *float64Value) Set(s string) error { - v, err := strconv.ParseFloat(s, 64) - *f = float64Value(v) - return err -} - -func (f *float64Value) Type() string { - return "float64" -} - -func (f *float64Value) String() string { return strconv.FormatFloat(float64(*f), 'g', -1, 64) } - -func float64Conv(sval string) (interface{}, error) { - return strconv.ParseFloat(sval, 64) -} - -// GetFloat64 return the float64 value of a flag with the given name -func (f *FlagSet) GetFloat64(name string) (float64, error) { - val, err := f.getFlagType(name, "float64", float64Conv) - if err != nil { - return 0, err - } - return val.(float64), nil -} - -// Float64Var defines a float64 flag with specified name, default value, and usage string. -// The argument p points to a float64 variable in which to store the value of the flag. -func (f *FlagSet) Float64Var(p *float64, name string, value float64, usage string) { - f.VarP(newFloat64Value(value, p), name, "", usage) -} - -// Float64VarP is like Float64Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Float64VarP(p *float64, name, shorthand string, value float64, usage string) { - f.VarP(newFloat64Value(value, p), name, shorthand, usage) -} - -// Float64Var defines a float64 flag with specified name, default value, and usage string. -// The argument p points to a float64 variable in which to store the value of the flag. -func Float64Var(p *float64, name string, value float64, usage string) { - CommandLine.VarP(newFloat64Value(value, p), name, "", usage) -} - -// Float64VarP is like Float64Var, but accepts a shorthand letter that can be used after a single dash. -func Float64VarP(p *float64, name, shorthand string, value float64, usage string) { - CommandLine.VarP(newFloat64Value(value, p), name, shorthand, usage) -} - -// Float64 defines a float64 flag with specified name, default value, and usage string. -// The return value is the address of a float64 variable that stores the value of the flag. -func (f *FlagSet) Float64(name string, value float64, usage string) *float64 { - p := new(float64) - f.Float64VarP(p, name, "", value, usage) - return p -} - -// Float64P is like Float64, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Float64P(name, shorthand string, value float64, usage string) *float64 { - p := new(float64) - f.Float64VarP(p, name, shorthand, value, usage) - return p -} - -// Float64 defines a float64 flag with specified name, default value, and usage string. -// The return value is the address of a float64 variable that stores the value of the flag. -func Float64(name string, value float64, usage string) *float64 { - return CommandLine.Float64P(name, "", value, usage) -} - -// Float64P is like Float64, but accepts a shorthand letter that can be used after a single dash. -func Float64P(name, shorthand string, value float64, usage string) *float64 { - return CommandLine.Float64P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/golangflag.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/golangflag.go deleted file mode 100644 index b056147..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/golangflag.go +++ /dev/null @@ -1,104 +0,0 @@ -// Copyright 2009 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package pflag - -import ( - goflag "flag" - "fmt" - "reflect" - "strings" -) - -var _ = fmt.Print - -// flagValueWrapper implements pflag.Value around a flag.Value. The main -// difference here is the addition of the Type method that returns a string -// name of the type. As this is generally unknown, we approximate that with -// reflection. -type flagValueWrapper struct { - inner goflag.Value - flagType string -} - -// We are just copying the boolFlag interface out of goflag as that is what -// they use to decide if a flag should get "true" when no arg is given. -type goBoolFlag interface { - goflag.Value - IsBoolFlag() bool -} - -func wrapFlagValue(v goflag.Value) Value { - // If the flag.Value happens to also be a pflag.Value, just use it directly. - if pv, ok := v.(Value); ok { - return pv - } - - pv := &flagValueWrapper{ - inner: v, - } - - t := reflect.TypeOf(v) - if t.Kind() == reflect.Interface || t.Kind() == reflect.Ptr { - t = t.Elem() - } - - pv.flagType = strings.TrimSuffix(t.Name(), "Value") - return pv -} - -func (v *flagValueWrapper) String() string { - return v.inner.String() -} - -func (v *flagValueWrapper) Set(s string) error { - return v.inner.Set(s) -} - -func (v *flagValueWrapper) Type() string { - return v.flagType -} - -// PFlagFromGoFlag will return a *pflag.Flag given a *flag.Flag -// If the *flag.Flag.Name was a single character (ex: `v`) it will be accessiblei -// with both `-v` and `--v` in flags. If the golang flag was more than a single -// character (ex: `verbose`) it will only be accessible via `--verbose` -func PFlagFromGoFlag(goflag *goflag.Flag) *Flag { - // Remember the default value as a string; it won't change. - flag := &Flag{ - Name: goflag.Name, - Usage: goflag.Usage, - Value: wrapFlagValue(goflag.Value), - // Looks like golang flags don't set DefValue correctly :-( - //DefValue: goflag.DefValue, - DefValue: goflag.Value.String(), - } - // Ex: if the golang flag was -v, allow both -v and --v to work - if len(flag.Name) == 1 { - flag.Shorthand = flag.Name - } - if fv, ok := goflag.Value.(goBoolFlag); ok && fv.IsBoolFlag() { - flag.NoOptDefVal = "true" - } - return flag -} - -// AddGoFlag will add the given *flag.Flag to the pflag.FlagSet -func (f *FlagSet) AddGoFlag(goflag *goflag.Flag) { - if f.Lookup(goflag.Name) != nil { - return - } - newflag := PFlagFromGoFlag(goflag) - f.AddFlag(newflag) -} - -// AddGoFlagSet will add the given *flag.FlagSet to the pflag.FlagSet -func (f *FlagSet) AddGoFlagSet(newSet *goflag.FlagSet) { - if newSet == nil { - return - } - newSet.VisitAll(func(goflag *goflag.Flag) { - f.AddGoFlag(goflag) - }) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int.go deleted file mode 100644 index 1474b89..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int.go +++ /dev/null @@ -1,84 +0,0 @@ -package pflag - -import "strconv" - -// -- int Value -type intValue int - -func newIntValue(val int, p *int) *intValue { - *p = val - return (*intValue)(p) -} - -func (i *intValue) Set(s string) error { - v, err := strconv.ParseInt(s, 0, 64) - *i = intValue(v) - return err -} - -func (i *intValue) Type() string { - return "int" -} - -func (i *intValue) String() string { return strconv.Itoa(int(*i)) } - -func intConv(sval string) (interface{}, error) { - return strconv.Atoi(sval) -} - -// GetInt return the int value of a flag with the given name -func (f *FlagSet) GetInt(name string) (int, error) { - val, err := f.getFlagType(name, "int", intConv) - if err != nil { - return 0, err - } - return val.(int), nil -} - -// IntVar defines an int flag with specified name, default value, and usage string. -// The argument p points to an int variable in which to store the value of the flag. -func (f *FlagSet) IntVar(p *int, name string, value int, usage string) { - f.VarP(newIntValue(value, p), name, "", usage) -} - -// IntVarP is like IntVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IntVarP(p *int, name, shorthand string, value int, usage string) { - f.VarP(newIntValue(value, p), name, shorthand, usage) -} - -// IntVar defines an int flag with specified name, default value, and usage string. -// The argument p points to an int variable in which to store the value of the flag. -func IntVar(p *int, name string, value int, usage string) { - CommandLine.VarP(newIntValue(value, p), name, "", usage) -} - -// IntVarP is like IntVar, but accepts a shorthand letter that can be used after a single dash. -func IntVarP(p *int, name, shorthand string, value int, usage string) { - CommandLine.VarP(newIntValue(value, p), name, shorthand, usage) -} - -// Int defines an int flag with specified name, default value, and usage string. -// The return value is the address of an int variable that stores the value of the flag. -func (f *FlagSet) Int(name string, value int, usage string) *int { - p := new(int) - f.IntVarP(p, name, "", value, usage) - return p -} - -// IntP is like Int, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IntP(name, shorthand string, value int, usage string) *int { - p := new(int) - f.IntVarP(p, name, shorthand, value, usage) - return p -} - -// Int defines an int flag with specified name, default value, and usage string. -// The return value is the address of an int variable that stores the value of the flag. -func Int(name string, value int, usage string) *int { - return CommandLine.IntP(name, "", value, usage) -} - -// IntP is like Int, but accepts a shorthand letter that can be used after a single dash. -func IntP(name, shorthand string, value int, usage string) *int { - return CommandLine.IntP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int32.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int32.go deleted file mode 100644 index 9b95944..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int32.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- int32 Value -type int32Value int32 - -func newInt32Value(val int32, p *int32) *int32Value { - *p = val - return (*int32Value)(p) -} - -func (i *int32Value) Set(s string) error { - v, err := strconv.ParseInt(s, 0, 32) - *i = int32Value(v) - return err -} - -func (i *int32Value) Type() string { - return "int32" -} - -func (i *int32Value) String() string { return strconv.FormatInt(int64(*i), 10) } - -func int32Conv(sval string) (interface{}, error) { - v, err := strconv.ParseInt(sval, 0, 32) - if err != nil { - return 0, err - } - return int32(v), nil -} - -// GetInt32 return the int32 value of a flag with the given name -func (f *FlagSet) GetInt32(name string) (int32, error) { - val, err := f.getFlagType(name, "int32", int32Conv) - if err != nil { - return 0, err - } - return val.(int32), nil -} - -// Int32Var defines an int32 flag with specified name, default value, and usage string. -// The argument p points to an int32 variable in which to store the value of the flag. -func (f *FlagSet) Int32Var(p *int32, name string, value int32, usage string) { - f.VarP(newInt32Value(value, p), name, "", usage) -} - -// Int32VarP is like Int32Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int32VarP(p *int32, name, shorthand string, value int32, usage string) { - f.VarP(newInt32Value(value, p), name, shorthand, usage) -} - -// Int32Var defines an int32 flag with specified name, default value, and usage string. -// The argument p points to an int32 variable in which to store the value of the flag. -func Int32Var(p *int32, name string, value int32, usage string) { - CommandLine.VarP(newInt32Value(value, p), name, "", usage) -} - -// Int32VarP is like Int32Var, but accepts a shorthand letter that can be used after a single dash. -func Int32VarP(p *int32, name, shorthand string, value int32, usage string) { - CommandLine.VarP(newInt32Value(value, p), name, shorthand, usage) -} - -// Int32 defines an int32 flag with specified name, default value, and usage string. -// The return value is the address of an int32 variable that stores the value of the flag. -func (f *FlagSet) Int32(name string, value int32, usage string) *int32 { - p := new(int32) - f.Int32VarP(p, name, "", value, usage) - return p -} - -// Int32P is like Int32, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int32P(name, shorthand string, value int32, usage string) *int32 { - p := new(int32) - f.Int32VarP(p, name, shorthand, value, usage) - return p -} - -// Int32 defines an int32 flag with specified name, default value, and usage string. -// The return value is the address of an int32 variable that stores the value of the flag. -func Int32(name string, value int32, usage string) *int32 { - return CommandLine.Int32P(name, "", value, usage) -} - -// Int32P is like Int32, but accepts a shorthand letter that can be used after a single dash. -func Int32P(name, shorthand string, value int32, usage string) *int32 { - return CommandLine.Int32P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int64.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int64.go deleted file mode 100644 index 0026d78..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int64.go +++ /dev/null @@ -1,84 +0,0 @@ -package pflag - -import "strconv" - -// -- int64 Value -type int64Value int64 - -func newInt64Value(val int64, p *int64) *int64Value { - *p = val - return (*int64Value)(p) -} - -func (i *int64Value) Set(s string) error { - v, err := strconv.ParseInt(s, 0, 64) - *i = int64Value(v) - return err -} - -func (i *int64Value) Type() string { - return "int64" -} - -func (i *int64Value) String() string { return strconv.FormatInt(int64(*i), 10) } - -func int64Conv(sval string) (interface{}, error) { - return strconv.ParseInt(sval, 0, 64) -} - -// GetInt64 return the int64 value of a flag with the given name -func (f *FlagSet) GetInt64(name string) (int64, error) { - val, err := f.getFlagType(name, "int64", int64Conv) - if err != nil { - return 0, err - } - return val.(int64), nil -} - -// Int64Var defines an int64 flag with specified name, default value, and usage string. -// The argument p points to an int64 variable in which to store the value of the flag. -func (f *FlagSet) Int64Var(p *int64, name string, value int64, usage string) { - f.VarP(newInt64Value(value, p), name, "", usage) -} - -// Int64VarP is like Int64Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int64VarP(p *int64, name, shorthand string, value int64, usage string) { - f.VarP(newInt64Value(value, p), name, shorthand, usage) -} - -// Int64Var defines an int64 flag with specified name, default value, and usage string. -// The argument p points to an int64 variable in which to store the value of the flag. -func Int64Var(p *int64, name string, value int64, usage string) { - CommandLine.VarP(newInt64Value(value, p), name, "", usage) -} - -// Int64VarP is like Int64Var, but accepts a shorthand letter that can be used after a single dash. -func Int64VarP(p *int64, name, shorthand string, value int64, usage string) { - CommandLine.VarP(newInt64Value(value, p), name, shorthand, usage) -} - -// Int64 defines an int64 flag with specified name, default value, and usage string. -// The return value is the address of an int64 variable that stores the value of the flag. -func (f *FlagSet) Int64(name string, value int64, usage string) *int64 { - p := new(int64) - f.Int64VarP(p, name, "", value, usage) - return p -} - -// Int64P is like Int64, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int64P(name, shorthand string, value int64, usage string) *int64 { - p := new(int64) - f.Int64VarP(p, name, shorthand, value, usage) - return p -} - -// Int64 defines an int64 flag with specified name, default value, and usage string. -// The return value is the address of an int64 variable that stores the value of the flag. -func Int64(name string, value int64, usage string) *int64 { - return CommandLine.Int64P(name, "", value, usage) -} - -// Int64P is like Int64, but accepts a shorthand letter that can be used after a single dash. -func Int64P(name, shorthand string, value int64, usage string) *int64 { - return CommandLine.Int64P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int8.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int8.go deleted file mode 100644 index 4da9222..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int8.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- int8 Value -type int8Value int8 - -func newInt8Value(val int8, p *int8) *int8Value { - *p = val - return (*int8Value)(p) -} - -func (i *int8Value) Set(s string) error { - v, err := strconv.ParseInt(s, 0, 8) - *i = int8Value(v) - return err -} - -func (i *int8Value) Type() string { - return "int8" -} - -func (i *int8Value) String() string { return strconv.FormatInt(int64(*i), 10) } - -func int8Conv(sval string) (interface{}, error) { - v, err := strconv.ParseInt(sval, 0, 8) - if err != nil { - return 0, err - } - return int8(v), nil -} - -// GetInt8 return the int8 value of a flag with the given name -func (f *FlagSet) GetInt8(name string) (int8, error) { - val, err := f.getFlagType(name, "int8", int8Conv) - if err != nil { - return 0, err - } - return val.(int8), nil -} - -// Int8Var defines an int8 flag with specified name, default value, and usage string. -// The argument p points to an int8 variable in which to store the value of the flag. -func (f *FlagSet) Int8Var(p *int8, name string, value int8, usage string) { - f.VarP(newInt8Value(value, p), name, "", usage) -} - -// Int8VarP is like Int8Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int8VarP(p *int8, name, shorthand string, value int8, usage string) { - f.VarP(newInt8Value(value, p), name, shorthand, usage) -} - -// Int8Var defines an int8 flag with specified name, default value, and usage string. -// The argument p points to an int8 variable in which to store the value of the flag. -func Int8Var(p *int8, name string, value int8, usage string) { - CommandLine.VarP(newInt8Value(value, p), name, "", usage) -} - -// Int8VarP is like Int8Var, but accepts a shorthand letter that can be used after a single dash. -func Int8VarP(p *int8, name, shorthand string, value int8, usage string) { - CommandLine.VarP(newInt8Value(value, p), name, shorthand, usage) -} - -// Int8 defines an int8 flag with specified name, default value, and usage string. -// The return value is the address of an int8 variable that stores the value of the flag. -func (f *FlagSet) Int8(name string, value int8, usage string) *int8 { - p := new(int8) - f.Int8VarP(p, name, "", value, usage) - return p -} - -// Int8P is like Int8, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Int8P(name, shorthand string, value int8, usage string) *int8 { - p := new(int8) - f.Int8VarP(p, name, shorthand, value, usage) - return p -} - -// Int8 defines an int8 flag with specified name, default value, and usage string. -// The return value is the address of an int8 variable that stores the value of the flag. -func Int8(name string, value int8, usage string) *int8 { - return CommandLine.Int8P(name, "", value, usage) -} - -// Int8P is like Int8, but accepts a shorthand letter that can be used after a single dash. -func Int8P(name, shorthand string, value int8, usage string) *int8 { - return CommandLine.Int8P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int_slice.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int_slice.go deleted file mode 100644 index 1e7c9ed..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/int_slice.go +++ /dev/null @@ -1,128 +0,0 @@ -package pflag - -import ( - "fmt" - "strconv" - "strings" -) - -// -- intSlice Value -type intSliceValue struct { - value *[]int - changed bool -} - -func newIntSliceValue(val []int, p *[]int) *intSliceValue { - isv := new(intSliceValue) - isv.value = p - *isv.value = val - return isv -} - -func (s *intSliceValue) Set(val string) error { - ss := strings.Split(val, ",") - out := make([]int, len(ss)) - for i, d := range ss { - var err error - out[i], err = strconv.Atoi(d) - if err != nil { - return err - } - - } - if !s.changed { - *s.value = out - } else { - *s.value = append(*s.value, out...) - } - s.changed = true - return nil -} - -func (s *intSliceValue) Type() string { - return "intSlice" -} - -func (s *intSliceValue) String() string { - out := make([]string, len(*s.value)) - for i, d := range *s.value { - out[i] = fmt.Sprintf("%d", d) - } - return "[" + strings.Join(out, ",") + "]" -} - -func intSliceConv(val string) (interface{}, error) { - val = strings.Trim(val, "[]") - // Empty string would cause a slice with one (empty) entry - if len(val) == 0 { - return []int{}, nil - } - ss := strings.Split(val, ",") - out := make([]int, len(ss)) - for i, d := range ss { - var err error - out[i], err = strconv.Atoi(d) - if err != nil { - return nil, err - } - - } - return out, nil -} - -// GetIntSlice return the []int value of a flag with the given name -func (f *FlagSet) GetIntSlice(name string) ([]int, error) { - val, err := f.getFlagType(name, "intSlice", intSliceConv) - if err != nil { - return []int{}, err - } - return val.([]int), nil -} - -// IntSliceVar defines a intSlice flag with specified name, default value, and usage string. -// The argument p points to a []int variable in which to store the value of the flag. -func (f *FlagSet) IntSliceVar(p *[]int, name string, value []int, usage string) { - f.VarP(newIntSliceValue(value, p), name, "", usage) -} - -// IntSliceVarP is like IntSliceVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IntSliceVarP(p *[]int, name, shorthand string, value []int, usage string) { - f.VarP(newIntSliceValue(value, p), name, shorthand, usage) -} - -// IntSliceVar defines a int[] flag with specified name, default value, and usage string. -// The argument p points to a int[] variable in which to store the value of the flag. -func IntSliceVar(p *[]int, name string, value []int, usage string) { - CommandLine.VarP(newIntSliceValue(value, p), name, "", usage) -} - -// IntSliceVarP is like IntSliceVar, but accepts a shorthand letter that can be used after a single dash. -func IntSliceVarP(p *[]int, name, shorthand string, value []int, usage string) { - CommandLine.VarP(newIntSliceValue(value, p), name, shorthand, usage) -} - -// IntSlice defines a []int flag with specified name, default value, and usage string. -// The return value is the address of a []int variable that stores the value of the flag. -func (f *FlagSet) IntSlice(name string, value []int, usage string) *[]int { - p := []int{} - f.IntSliceVarP(&p, name, "", value, usage) - return &p -} - -// IntSliceP is like IntSlice, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IntSliceP(name, shorthand string, value []int, usage string) *[]int { - p := []int{} - f.IntSliceVarP(&p, name, shorthand, value, usage) - return &p -} - -// IntSlice defines a []int flag with specified name, default value, and usage string. -// The return value is the address of a []int variable that stores the value of the flag. -func IntSlice(name string, value []int, usage string) *[]int { - return CommandLine.IntSliceP(name, "", value, usage) -} - -// IntSliceP is like IntSlice, but accepts a shorthand letter that can be used after a single dash. -func IntSliceP(name, shorthand string, value []int, usage string) *[]int { - return CommandLine.IntSliceP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ip.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ip.go deleted file mode 100644 index 88a1743..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ip.go +++ /dev/null @@ -1,96 +0,0 @@ -package pflag - -import ( - "fmt" - "net" - "strings" -) - -var _ = strings.TrimSpace - -// -- net.IP value -type ipValue net.IP - -func newIPValue(val net.IP, p *net.IP) *ipValue { - *p = val - return (*ipValue)(p) -} - -func (i *ipValue) String() string { return net.IP(*i).String() } -func (i *ipValue) Set(s string) error { - ip := net.ParseIP(strings.TrimSpace(s)) - if ip == nil { - return fmt.Errorf("failed to parse IP: %q", s) - } - *i = ipValue(ip) - return nil -} - -func (i *ipValue) Type() string { - return "ip" -} - -func ipConv(sval string) (interface{}, error) { - ip := net.ParseIP(sval) - if ip != nil { - return ip, nil - } - return nil, fmt.Errorf("invalid string being converted to IP address: %s", sval) -} - -// GetIP return the net.IP value of a flag with the given name -func (f *FlagSet) GetIP(name string) (net.IP, error) { - val, err := f.getFlagType(name, "ip", ipConv) - if err != nil { - return nil, err - } - return val.(net.IP), nil -} - -// IPVar defines an net.IP flag with specified name, default value, and usage string. -// The argument p points to an net.IP variable in which to store the value of the flag. -func (f *FlagSet) IPVar(p *net.IP, name string, value net.IP, usage string) { - f.VarP(newIPValue(value, p), name, "", usage) -} - -// IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) { - f.VarP(newIPValue(value, p), name, shorthand, usage) -} - -// IPVar defines an net.IP flag with specified name, default value, and usage string. -// The argument p points to an net.IP variable in which to store the value of the flag. -func IPVar(p *net.IP, name string, value net.IP, usage string) { - CommandLine.VarP(newIPValue(value, p), name, "", usage) -} - -// IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash. -func IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) { - CommandLine.VarP(newIPValue(value, p), name, shorthand, usage) -} - -// IP defines an net.IP flag with specified name, default value, and usage string. -// The return value is the address of an net.IP variable that stores the value of the flag. -func (f *FlagSet) IP(name string, value net.IP, usage string) *net.IP { - p := new(net.IP) - f.IPVarP(p, name, "", value, usage) - return p -} - -// IPP is like IP, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPP(name, shorthand string, value net.IP, usage string) *net.IP { - p := new(net.IP) - f.IPVarP(p, name, shorthand, value, usage) - return p -} - -// IP defines an net.IP flag with specified name, default value, and usage string. -// The return value is the address of an net.IP variable that stores the value of the flag. -func IP(name string, value net.IP, usage string) *net.IP { - return CommandLine.IPP(name, "", value, usage) -} - -// IPP is like IP, but accepts a shorthand letter that can be used after a single dash. -func IPP(name, shorthand string, value net.IP, usage string) *net.IP { - return CommandLine.IPP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipmask.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipmask.go deleted file mode 100644 index 5bd44bd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipmask.go +++ /dev/null @@ -1,122 +0,0 @@ -package pflag - -import ( - "fmt" - "net" - "strconv" -) - -// -- net.IPMask value -type ipMaskValue net.IPMask - -func newIPMaskValue(val net.IPMask, p *net.IPMask) *ipMaskValue { - *p = val - return (*ipMaskValue)(p) -} - -func (i *ipMaskValue) String() string { return net.IPMask(*i).String() } -func (i *ipMaskValue) Set(s string) error { - ip := ParseIPv4Mask(s) - if ip == nil { - return fmt.Errorf("failed to parse IP mask: %q", s) - } - *i = ipMaskValue(ip) - return nil -} - -func (i *ipMaskValue) Type() string { - return "ipMask" -} - -// ParseIPv4Mask written in IP form (e.g. 255.255.255.0). -// This function should really belong to the net package. -func ParseIPv4Mask(s string) net.IPMask { - mask := net.ParseIP(s) - if mask == nil { - if len(s) != 8 { - return nil - } - // net.IPMask.String() actually outputs things like ffffff00 - // so write a horrible parser for that as well :-( - m := []int{} - for i := 0; i < 4; i++ { - b := "0x" + s[2*i:2*i+2] - d, err := strconv.ParseInt(b, 0, 0) - if err != nil { - return nil - } - m = append(m, int(d)) - } - s := fmt.Sprintf("%d.%d.%d.%d", m[0], m[1], m[2], m[3]) - mask = net.ParseIP(s) - if mask == nil { - return nil - } - } - return net.IPv4Mask(mask[12], mask[13], mask[14], mask[15]) -} - -func parseIPv4Mask(sval string) (interface{}, error) { - mask := ParseIPv4Mask(sval) - if mask == nil { - return nil, fmt.Errorf("unable to parse %s as net.IPMask", sval) - } - return mask, nil -} - -// GetIPv4Mask return the net.IPv4Mask value of a flag with the given name -func (f *FlagSet) GetIPv4Mask(name string) (net.IPMask, error) { - val, err := f.getFlagType(name, "ipMask", parseIPv4Mask) - if err != nil { - return nil, err - } - return val.(net.IPMask), nil -} - -// IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string. -// The argument p points to an net.IPMask variable in which to store the value of the flag. -func (f *FlagSet) IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) { - f.VarP(newIPMaskValue(value, p), name, "", usage) -} - -// IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) { - f.VarP(newIPMaskValue(value, p), name, shorthand, usage) -} - -// IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string. -// The argument p points to an net.IPMask variable in which to store the value of the flag. -func IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) { - CommandLine.VarP(newIPMaskValue(value, p), name, "", usage) -} - -// IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash. -func IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) { - CommandLine.VarP(newIPMaskValue(value, p), name, shorthand, usage) -} - -// IPMask defines an net.IPMask flag with specified name, default value, and usage string. -// The return value is the address of an net.IPMask variable that stores the value of the flag. -func (f *FlagSet) IPMask(name string, value net.IPMask, usage string) *net.IPMask { - p := new(net.IPMask) - f.IPMaskVarP(p, name, "", value, usage) - return p -} - -// IPMaskP is like IPMask, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask { - p := new(net.IPMask) - f.IPMaskVarP(p, name, shorthand, value, usage) - return p -} - -// IPMask defines an net.IPMask flag with specified name, default value, and usage string. -// The return value is the address of an net.IPMask variable that stores the value of the flag. -func IPMask(name string, value net.IPMask, usage string) *net.IPMask { - return CommandLine.IPMaskP(name, "", value, usage) -} - -// IPMaskP is like IP, but accepts a shorthand letter that can be used after a single dash. -func IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask { - return CommandLine.IPMaskP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipnet.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipnet.go deleted file mode 100644 index 149b764..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/ipnet.go +++ /dev/null @@ -1,100 +0,0 @@ -package pflag - -import ( - "fmt" - "net" - "strings" -) - -// IPNet adapts net.IPNet for use as a flag. -type ipNetValue net.IPNet - -func (ipnet ipNetValue) String() string { - n := net.IPNet(ipnet) - return n.String() -} - -func (ipnet *ipNetValue) Set(value string) error { - _, n, err := net.ParseCIDR(strings.TrimSpace(value)) - if err != nil { - return err - } - *ipnet = ipNetValue(*n) - return nil -} - -func (*ipNetValue) Type() string { - return "ipNet" -} - -var _ = strings.TrimSpace - -func newIPNetValue(val net.IPNet, p *net.IPNet) *ipNetValue { - *p = val - return (*ipNetValue)(p) -} - -func ipNetConv(sval string) (interface{}, error) { - _, n, err := net.ParseCIDR(strings.TrimSpace(sval)) - if err == nil { - return *n, nil - } - return nil, fmt.Errorf("invalid string being converted to IPNet: %s", sval) -} - -// GetIPNet return the net.IPNet value of a flag with the given name -func (f *FlagSet) GetIPNet(name string) (net.IPNet, error) { - val, err := f.getFlagType(name, "ipNet", ipNetConv) - if err != nil { - return net.IPNet{}, err - } - return val.(net.IPNet), nil -} - -// IPNetVar defines an net.IPNet flag with specified name, default value, and usage string. -// The argument p points to an net.IPNet variable in which to store the value of the flag. -func (f *FlagSet) IPNetVar(p *net.IPNet, name string, value net.IPNet, usage string) { - f.VarP(newIPNetValue(value, p), name, "", usage) -} - -// IPNetVarP is like IPNetVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPNetVarP(p *net.IPNet, name, shorthand string, value net.IPNet, usage string) { - f.VarP(newIPNetValue(value, p), name, shorthand, usage) -} - -// IPNetVar defines an net.IPNet flag with specified name, default value, and usage string. -// The argument p points to an net.IPNet variable in which to store the value of the flag. -func IPNetVar(p *net.IPNet, name string, value net.IPNet, usage string) { - CommandLine.VarP(newIPNetValue(value, p), name, "", usage) -} - -// IPNetVarP is like IPNetVar, but accepts a shorthand letter that can be used after a single dash. -func IPNetVarP(p *net.IPNet, name, shorthand string, value net.IPNet, usage string) { - CommandLine.VarP(newIPNetValue(value, p), name, shorthand, usage) -} - -// IPNet defines an net.IPNet flag with specified name, default value, and usage string. -// The return value is the address of an net.IPNet variable that stores the value of the flag. -func (f *FlagSet) IPNet(name string, value net.IPNet, usage string) *net.IPNet { - p := new(net.IPNet) - f.IPNetVarP(p, name, "", value, usage) - return p -} - -// IPNetP is like IPNet, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) IPNetP(name, shorthand string, value net.IPNet, usage string) *net.IPNet { - p := new(net.IPNet) - f.IPNetVarP(p, name, shorthand, value, usage) - return p -} - -// IPNet defines an net.IPNet flag with specified name, default value, and usage string. -// The return value is the address of an net.IPNet variable that stores the value of the flag. -func IPNet(name string, value net.IPNet, usage string) *net.IPNet { - return CommandLine.IPNetP(name, "", value, usage) -} - -// IPNetP is like IPNet, but accepts a shorthand letter that can be used after a single dash. -func IPNetP(name, shorthand string, value net.IPNet, usage string) *net.IPNet { - return CommandLine.IPNetP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string.go deleted file mode 100644 index 04e0a26..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string.go +++ /dev/null @@ -1,80 +0,0 @@ -package pflag - -// -- string Value -type stringValue string - -func newStringValue(val string, p *string) *stringValue { - *p = val - return (*stringValue)(p) -} - -func (s *stringValue) Set(val string) error { - *s = stringValue(val) - return nil -} -func (s *stringValue) Type() string { - return "string" -} - -func (s *stringValue) String() string { return string(*s) } - -func stringConv(sval string) (interface{}, error) { - return sval, nil -} - -// GetString return the string value of a flag with the given name -func (f *FlagSet) GetString(name string) (string, error) { - val, err := f.getFlagType(name, "string", stringConv) - if err != nil { - return "", err - } - return val.(string), nil -} - -// StringVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a string variable in which to store the value of the flag. -func (f *FlagSet) StringVar(p *string, name string, value string, usage string) { - f.VarP(newStringValue(value, p), name, "", usage) -} - -// StringVarP is like StringVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringVarP(p *string, name, shorthand string, value string, usage string) { - f.VarP(newStringValue(value, p), name, shorthand, usage) -} - -// StringVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a string variable in which to store the value of the flag. -func StringVar(p *string, name string, value string, usage string) { - CommandLine.VarP(newStringValue(value, p), name, "", usage) -} - -// StringVarP is like StringVar, but accepts a shorthand letter that can be used after a single dash. -func StringVarP(p *string, name, shorthand string, value string, usage string) { - CommandLine.VarP(newStringValue(value, p), name, shorthand, usage) -} - -// String defines a string flag with specified name, default value, and usage string. -// The return value is the address of a string variable that stores the value of the flag. -func (f *FlagSet) String(name string, value string, usage string) *string { - p := new(string) - f.StringVarP(p, name, "", value, usage) - return p -} - -// StringP is like String, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringP(name, shorthand string, value string, usage string) *string { - p := new(string) - f.StringVarP(p, name, shorthand, value, usage) - return p -} - -// String defines a string flag with specified name, default value, and usage string. -// The return value is the address of a string variable that stores the value of the flag. -func String(name string, value string, usage string) *string { - return CommandLine.StringP(name, "", value, usage) -} - -// StringP is like String, but accepts a shorthand letter that can be used after a single dash. -func StringP(name, shorthand string, value string, usage string) *string { - return CommandLine.StringP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_array.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_array.go deleted file mode 100644 index f320f2e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_array.go +++ /dev/null @@ -1,110 +0,0 @@ -package pflag - -import ( - "fmt" - "strings" -) - -var _ = fmt.Fprint - -// -- stringArray Value -type stringArrayValue struct { - value *[]string - changed bool -} - -func newStringArrayValue(val []string, p *[]string) *stringArrayValue { - ssv := new(stringArrayValue) - ssv.value = p - *ssv.value = val - return ssv -} - -func (s *stringArrayValue) Set(val string) error { - if !s.changed { - *s.value = []string{val} - s.changed = true - } else { - *s.value = append(*s.value, val) - } - return nil -} - -func (s *stringArrayValue) Type() string { - return "stringArray" -} - -func (s *stringArrayValue) String() string { - str, _ := writeAsCSV(*s.value) - return "[" + str + "]" -} - -func stringArrayConv(sval string) (interface{}, error) { - sval = strings.Trim(sval, "[]") - // An empty string would cause a array with one (empty) string - if len(sval) == 0 { - return []string{}, nil - } - return readAsCSV(sval) -} - -// GetStringArray return the []string value of a flag with the given name -func (f *FlagSet) GetStringArray(name string) ([]string, error) { - val, err := f.getFlagType(name, "stringArray", stringArrayConv) - if err != nil { - return []string{}, err - } - return val.([]string), nil -} - -// StringArrayVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a []string variable in which to store the values of the multiple flags. -// The value of each argument will not try to be separated by comma -func (f *FlagSet) StringArrayVar(p *[]string, name string, value []string, usage string) { - f.VarP(newStringArrayValue(value, p), name, "", usage) -} - -// StringArrayVarP is like StringArrayVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringArrayVarP(p *[]string, name, shorthand string, value []string, usage string) { - f.VarP(newStringArrayValue(value, p), name, shorthand, usage) -} - -// StringArrayVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a []string variable in which to store the value of the flag. -// The value of each argument will not try to be separated by comma -func StringArrayVar(p *[]string, name string, value []string, usage string) { - CommandLine.VarP(newStringArrayValue(value, p), name, "", usage) -} - -// StringArrayVarP is like StringArrayVar, but accepts a shorthand letter that can be used after a single dash. -func StringArrayVarP(p *[]string, name, shorthand string, value []string, usage string) { - CommandLine.VarP(newStringArrayValue(value, p), name, shorthand, usage) -} - -// StringArray defines a string flag with specified name, default value, and usage string. -// The return value is the address of a []string variable that stores the value of the flag. -// The value of each argument will not try to be separated by comma -func (f *FlagSet) StringArray(name string, value []string, usage string) *[]string { - p := []string{} - f.StringArrayVarP(&p, name, "", value, usage) - return &p -} - -// StringArrayP is like StringArray, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringArrayP(name, shorthand string, value []string, usage string) *[]string { - p := []string{} - f.StringArrayVarP(&p, name, shorthand, value, usage) - return &p -} - -// StringArray defines a string flag with specified name, default value, and usage string. -// The return value is the address of a []string variable that stores the value of the flag. -// The value of each argument will not try to be separated by comma -func StringArray(name string, value []string, usage string) *[]string { - return CommandLine.StringArrayP(name, "", value, usage) -} - -// StringArrayP is like StringArray, but accepts a shorthand letter that can be used after a single dash. -func StringArrayP(name, shorthand string, value []string, usage string) *[]string { - return CommandLine.StringArrayP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_slice.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_slice.go deleted file mode 100644 index 51e3c5d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/string_slice.go +++ /dev/null @@ -1,132 +0,0 @@ -package pflag - -import ( - "bytes" - "encoding/csv" - "fmt" - "strings" -) - -var _ = fmt.Fprint - -// -- stringSlice Value -type stringSliceValue struct { - value *[]string - changed bool -} - -func newStringSliceValue(val []string, p *[]string) *stringSliceValue { - ssv := new(stringSliceValue) - ssv.value = p - *ssv.value = val - return ssv -} - -func readAsCSV(val string) ([]string, error) { - if val == "" { - return []string{}, nil - } - stringReader := strings.NewReader(val) - csvReader := csv.NewReader(stringReader) - return csvReader.Read() -} - -func writeAsCSV(vals []string) (string, error) { - b := &bytes.Buffer{} - w := csv.NewWriter(b) - err := w.Write(vals) - if err != nil { - return "", err - } - w.Flush() - return strings.TrimSuffix(b.String(), fmt.Sprintln()), nil -} - -func (s *stringSliceValue) Set(val string) error { - v, err := readAsCSV(val) - if err != nil { - return err - } - if !s.changed { - *s.value = v - } else { - *s.value = append(*s.value, v...) - } - s.changed = true - return nil -} - -func (s *stringSliceValue) Type() string { - return "stringSlice" -} - -func (s *stringSliceValue) String() string { - str, _ := writeAsCSV(*s.value) - return "[" + str + "]" -} - -func stringSliceConv(sval string) (interface{}, error) { - sval = strings.Trim(sval, "[]") - // An empty string would cause a slice with one (empty) string - if len(sval) == 0 { - return []string{}, nil - } - return readAsCSV(sval) -} - -// GetStringSlice return the []string value of a flag with the given name -func (f *FlagSet) GetStringSlice(name string) ([]string, error) { - val, err := f.getFlagType(name, "stringSlice", stringSliceConv) - if err != nil { - return []string{}, err - } - return val.([]string), nil -} - -// StringSliceVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a []string variable in which to store the value of the flag. -func (f *FlagSet) StringSliceVar(p *[]string, name string, value []string, usage string) { - f.VarP(newStringSliceValue(value, p), name, "", usage) -} - -// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) { - f.VarP(newStringSliceValue(value, p), name, shorthand, usage) -} - -// StringSliceVar defines a string flag with specified name, default value, and usage string. -// The argument p points to a []string variable in which to store the value of the flag. -func StringSliceVar(p *[]string, name string, value []string, usage string) { - CommandLine.VarP(newStringSliceValue(value, p), name, "", usage) -} - -// StringSliceVarP is like StringSliceVar, but accepts a shorthand letter that can be used after a single dash. -func StringSliceVarP(p *[]string, name, shorthand string, value []string, usage string) { - CommandLine.VarP(newStringSliceValue(value, p), name, shorthand, usage) -} - -// StringSlice defines a string flag with specified name, default value, and usage string. -// The return value is the address of a []string variable that stores the value of the flag. -func (f *FlagSet) StringSlice(name string, value []string, usage string) *[]string { - p := []string{} - f.StringSliceVarP(&p, name, "", value, usage) - return &p -} - -// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) StringSliceP(name, shorthand string, value []string, usage string) *[]string { - p := []string{} - f.StringSliceVarP(&p, name, shorthand, value, usage) - return &p -} - -// StringSlice defines a string flag with specified name, default value, and usage string. -// The return value is the address of a []string variable that stores the value of the flag. -func StringSlice(name string, value []string, usage string) *[]string { - return CommandLine.StringSliceP(name, "", value, usage) -} - -// StringSliceP is like StringSlice, but accepts a shorthand letter that can be used after a single dash. -func StringSliceP(name, shorthand string, value []string, usage string) *[]string { - return CommandLine.StringSliceP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint.go deleted file mode 100644 index dcbc2b7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- uint Value -type uintValue uint - -func newUintValue(val uint, p *uint) *uintValue { - *p = val - return (*uintValue)(p) -} - -func (i *uintValue) Set(s string) error { - v, err := strconv.ParseUint(s, 0, 64) - *i = uintValue(v) - return err -} - -func (i *uintValue) Type() string { - return "uint" -} - -func (i *uintValue) String() string { return strconv.FormatUint(uint64(*i), 10) } - -func uintConv(sval string) (interface{}, error) { - v, err := strconv.ParseUint(sval, 0, 0) - if err != nil { - return 0, err - } - return uint(v), nil -} - -// GetUint return the uint value of a flag with the given name -func (f *FlagSet) GetUint(name string) (uint, error) { - val, err := f.getFlagType(name, "uint", uintConv) - if err != nil { - return 0, err - } - return val.(uint), nil -} - -// UintVar defines a uint flag with specified name, default value, and usage string. -// The argument p points to a uint variable in which to store the value of the flag. -func (f *FlagSet) UintVar(p *uint, name string, value uint, usage string) { - f.VarP(newUintValue(value, p), name, "", usage) -} - -// UintVarP is like UintVar, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) UintVarP(p *uint, name, shorthand string, value uint, usage string) { - f.VarP(newUintValue(value, p), name, shorthand, usage) -} - -// UintVar defines a uint flag with specified name, default value, and usage string. -// The argument p points to a uint variable in which to store the value of the flag. -func UintVar(p *uint, name string, value uint, usage string) { - CommandLine.VarP(newUintValue(value, p), name, "", usage) -} - -// UintVarP is like UintVar, but accepts a shorthand letter that can be used after a single dash. -func UintVarP(p *uint, name, shorthand string, value uint, usage string) { - CommandLine.VarP(newUintValue(value, p), name, shorthand, usage) -} - -// Uint defines a uint flag with specified name, default value, and usage string. -// The return value is the address of a uint variable that stores the value of the flag. -func (f *FlagSet) Uint(name string, value uint, usage string) *uint { - p := new(uint) - f.UintVarP(p, name, "", value, usage) - return p -} - -// UintP is like Uint, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) UintP(name, shorthand string, value uint, usage string) *uint { - p := new(uint) - f.UintVarP(p, name, shorthand, value, usage) - return p -} - -// Uint defines a uint flag with specified name, default value, and usage string. -// The return value is the address of a uint variable that stores the value of the flag. -func Uint(name string, value uint, usage string) *uint { - return CommandLine.UintP(name, "", value, usage) -} - -// UintP is like Uint, but accepts a shorthand letter that can be used after a single dash. -func UintP(name, shorthand string, value uint, usage string) *uint { - return CommandLine.UintP(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint16.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint16.go deleted file mode 100644 index 7e9914e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint16.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- uint16 value -type uint16Value uint16 - -func newUint16Value(val uint16, p *uint16) *uint16Value { - *p = val - return (*uint16Value)(p) -} - -func (i *uint16Value) Set(s string) error { - v, err := strconv.ParseUint(s, 0, 16) - *i = uint16Value(v) - return err -} - -func (i *uint16Value) Type() string { - return "uint16" -} - -func (i *uint16Value) String() string { return strconv.FormatUint(uint64(*i), 10) } - -func uint16Conv(sval string) (interface{}, error) { - v, err := strconv.ParseUint(sval, 0, 16) - if err != nil { - return 0, err - } - return uint16(v), nil -} - -// GetUint16 return the uint16 value of a flag with the given name -func (f *FlagSet) GetUint16(name string) (uint16, error) { - val, err := f.getFlagType(name, "uint16", uint16Conv) - if err != nil { - return 0, err - } - return val.(uint16), nil -} - -// Uint16Var defines a uint flag with specified name, default value, and usage string. -// The argument p points to a uint variable in which to store the value of the flag. -func (f *FlagSet) Uint16Var(p *uint16, name string, value uint16, usage string) { - f.VarP(newUint16Value(value, p), name, "", usage) -} - -// Uint16VarP is like Uint16Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint16VarP(p *uint16, name, shorthand string, value uint16, usage string) { - f.VarP(newUint16Value(value, p), name, shorthand, usage) -} - -// Uint16Var defines a uint flag with specified name, default value, and usage string. -// The argument p points to a uint variable in which to store the value of the flag. -func Uint16Var(p *uint16, name string, value uint16, usage string) { - CommandLine.VarP(newUint16Value(value, p), name, "", usage) -} - -// Uint16VarP is like Uint16Var, but accepts a shorthand letter that can be used after a single dash. -func Uint16VarP(p *uint16, name, shorthand string, value uint16, usage string) { - CommandLine.VarP(newUint16Value(value, p), name, shorthand, usage) -} - -// Uint16 defines a uint flag with specified name, default value, and usage string. -// The return value is the address of a uint variable that stores the value of the flag. -func (f *FlagSet) Uint16(name string, value uint16, usage string) *uint16 { - p := new(uint16) - f.Uint16VarP(p, name, "", value, usage) - return p -} - -// Uint16P is like Uint16, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint16P(name, shorthand string, value uint16, usage string) *uint16 { - p := new(uint16) - f.Uint16VarP(p, name, shorthand, value, usage) - return p -} - -// Uint16 defines a uint flag with specified name, default value, and usage string. -// The return value is the address of a uint variable that stores the value of the flag. -func Uint16(name string, value uint16, usage string) *uint16 { - return CommandLine.Uint16P(name, "", value, usage) -} - -// Uint16P is like Uint16, but accepts a shorthand letter that can be used after a single dash. -func Uint16P(name, shorthand string, value uint16, usage string) *uint16 { - return CommandLine.Uint16P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint32.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint32.go deleted file mode 100644 index d802453..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint32.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- uint32 value -type uint32Value uint32 - -func newUint32Value(val uint32, p *uint32) *uint32Value { - *p = val - return (*uint32Value)(p) -} - -func (i *uint32Value) Set(s string) error { - v, err := strconv.ParseUint(s, 0, 32) - *i = uint32Value(v) - return err -} - -func (i *uint32Value) Type() string { - return "uint32" -} - -func (i *uint32Value) String() string { return strconv.FormatUint(uint64(*i), 10) } - -func uint32Conv(sval string) (interface{}, error) { - v, err := strconv.ParseUint(sval, 0, 32) - if err != nil { - return 0, err - } - return uint32(v), nil -} - -// GetUint32 return the uint32 value of a flag with the given name -func (f *FlagSet) GetUint32(name string) (uint32, error) { - val, err := f.getFlagType(name, "uint32", uint32Conv) - if err != nil { - return 0, err - } - return val.(uint32), nil -} - -// Uint32Var defines a uint32 flag with specified name, default value, and usage string. -// The argument p points to a uint32 variable in which to store the value of the flag. -func (f *FlagSet) Uint32Var(p *uint32, name string, value uint32, usage string) { - f.VarP(newUint32Value(value, p), name, "", usage) -} - -// Uint32VarP is like Uint32Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint32VarP(p *uint32, name, shorthand string, value uint32, usage string) { - f.VarP(newUint32Value(value, p), name, shorthand, usage) -} - -// Uint32Var defines a uint32 flag with specified name, default value, and usage string. -// The argument p points to a uint32 variable in which to store the value of the flag. -func Uint32Var(p *uint32, name string, value uint32, usage string) { - CommandLine.VarP(newUint32Value(value, p), name, "", usage) -} - -// Uint32VarP is like Uint32Var, but accepts a shorthand letter that can be used after a single dash. -func Uint32VarP(p *uint32, name, shorthand string, value uint32, usage string) { - CommandLine.VarP(newUint32Value(value, p), name, shorthand, usage) -} - -// Uint32 defines a uint32 flag with specified name, default value, and usage string. -// The return value is the address of a uint32 variable that stores the value of the flag. -func (f *FlagSet) Uint32(name string, value uint32, usage string) *uint32 { - p := new(uint32) - f.Uint32VarP(p, name, "", value, usage) - return p -} - -// Uint32P is like Uint32, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint32P(name, shorthand string, value uint32, usage string) *uint32 { - p := new(uint32) - f.Uint32VarP(p, name, shorthand, value, usage) - return p -} - -// Uint32 defines a uint32 flag with specified name, default value, and usage string. -// The return value is the address of a uint32 variable that stores the value of the flag. -func Uint32(name string, value uint32, usage string) *uint32 { - return CommandLine.Uint32P(name, "", value, usage) -} - -// Uint32P is like Uint32, but accepts a shorthand letter that can be used after a single dash. -func Uint32P(name, shorthand string, value uint32, usage string) *uint32 { - return CommandLine.Uint32P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint64.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint64.go deleted file mode 100644 index f62240f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint64.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- uint64 Value -type uint64Value uint64 - -func newUint64Value(val uint64, p *uint64) *uint64Value { - *p = val - return (*uint64Value)(p) -} - -func (i *uint64Value) Set(s string) error { - v, err := strconv.ParseUint(s, 0, 64) - *i = uint64Value(v) - return err -} - -func (i *uint64Value) Type() string { - return "uint64" -} - -func (i *uint64Value) String() string { return strconv.FormatUint(uint64(*i), 10) } - -func uint64Conv(sval string) (interface{}, error) { - v, err := strconv.ParseUint(sval, 0, 64) - if err != nil { - return 0, err - } - return uint64(v), nil -} - -// GetUint64 return the uint64 value of a flag with the given name -func (f *FlagSet) GetUint64(name string) (uint64, error) { - val, err := f.getFlagType(name, "uint64", uint64Conv) - if err != nil { - return 0, err - } - return val.(uint64), nil -} - -// Uint64Var defines a uint64 flag with specified name, default value, and usage string. -// The argument p points to a uint64 variable in which to store the value of the flag. -func (f *FlagSet) Uint64Var(p *uint64, name string, value uint64, usage string) { - f.VarP(newUint64Value(value, p), name, "", usage) -} - -// Uint64VarP is like Uint64Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint64VarP(p *uint64, name, shorthand string, value uint64, usage string) { - f.VarP(newUint64Value(value, p), name, shorthand, usage) -} - -// Uint64Var defines a uint64 flag with specified name, default value, and usage string. -// The argument p points to a uint64 variable in which to store the value of the flag. -func Uint64Var(p *uint64, name string, value uint64, usage string) { - CommandLine.VarP(newUint64Value(value, p), name, "", usage) -} - -// Uint64VarP is like Uint64Var, but accepts a shorthand letter that can be used after a single dash. -func Uint64VarP(p *uint64, name, shorthand string, value uint64, usage string) { - CommandLine.VarP(newUint64Value(value, p), name, shorthand, usage) -} - -// Uint64 defines a uint64 flag with specified name, default value, and usage string. -// The return value is the address of a uint64 variable that stores the value of the flag. -func (f *FlagSet) Uint64(name string, value uint64, usage string) *uint64 { - p := new(uint64) - f.Uint64VarP(p, name, "", value, usage) - return p -} - -// Uint64P is like Uint64, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint64P(name, shorthand string, value uint64, usage string) *uint64 { - p := new(uint64) - f.Uint64VarP(p, name, shorthand, value, usage) - return p -} - -// Uint64 defines a uint64 flag with specified name, default value, and usage string. -// The return value is the address of a uint64 variable that stores the value of the flag. -func Uint64(name string, value uint64, usage string) *uint64 { - return CommandLine.Uint64P(name, "", value, usage) -} - -// Uint64P is like Uint64, but accepts a shorthand letter that can be used after a single dash. -func Uint64P(name, shorthand string, value uint64, usage string) *uint64 { - return CommandLine.Uint64P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint8.go b/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint8.go deleted file mode 100644 index bb0e83c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/spf13/pflag/uint8.go +++ /dev/null @@ -1,88 +0,0 @@ -package pflag - -import "strconv" - -// -- uint8 Value -type uint8Value uint8 - -func newUint8Value(val uint8, p *uint8) *uint8Value { - *p = val - return (*uint8Value)(p) -} - -func (i *uint8Value) Set(s string) error { - v, err := strconv.ParseUint(s, 0, 8) - *i = uint8Value(v) - return err -} - -func (i *uint8Value) Type() string { - return "uint8" -} - -func (i *uint8Value) String() string { return strconv.FormatUint(uint64(*i), 10) } - -func uint8Conv(sval string) (interface{}, error) { - v, err := strconv.ParseUint(sval, 0, 8) - if err != nil { - return 0, err - } - return uint8(v), nil -} - -// GetUint8 return the uint8 value of a flag with the given name -func (f *FlagSet) GetUint8(name string) (uint8, error) { - val, err := f.getFlagType(name, "uint8", uint8Conv) - if err != nil { - return 0, err - } - return val.(uint8), nil -} - -// Uint8Var defines a uint8 flag with specified name, default value, and usage string. -// The argument p points to a uint8 variable in which to store the value of the flag. -func (f *FlagSet) Uint8Var(p *uint8, name string, value uint8, usage string) { - f.VarP(newUint8Value(value, p), name, "", usage) -} - -// Uint8VarP is like Uint8Var, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint8VarP(p *uint8, name, shorthand string, value uint8, usage string) { - f.VarP(newUint8Value(value, p), name, shorthand, usage) -} - -// Uint8Var defines a uint8 flag with specified name, default value, and usage string. -// The argument p points to a uint8 variable in which to store the value of the flag. -func Uint8Var(p *uint8, name string, value uint8, usage string) { - CommandLine.VarP(newUint8Value(value, p), name, "", usage) -} - -// Uint8VarP is like Uint8Var, but accepts a shorthand letter that can be used after a single dash. -func Uint8VarP(p *uint8, name, shorthand string, value uint8, usage string) { - CommandLine.VarP(newUint8Value(value, p), name, shorthand, usage) -} - -// Uint8 defines a uint8 flag with specified name, default value, and usage string. -// The return value is the address of a uint8 variable that stores the value of the flag. -func (f *FlagSet) Uint8(name string, value uint8, usage string) *uint8 { - p := new(uint8) - f.Uint8VarP(p, name, "", value, usage) - return p -} - -// Uint8P is like Uint8, but accepts a shorthand letter that can be used after a single dash. -func (f *FlagSet) Uint8P(name, shorthand string, value uint8, usage string) *uint8 { - p := new(uint8) - f.Uint8VarP(p, name, shorthand, value, usage) - return p -} - -// Uint8 defines a uint8 flag with specified name, default value, and usage string. -// The return value is the address of a uint8 variable that stores the value of the flag. -func Uint8(name string, value uint8, usage string) *uint8 { - return CommandLine.Uint8P(name, "", value, usage) -} - -// Uint8P is like Uint8, but accepts a shorthand letter that can be used after a single dash. -func Uint8P(name, shorthand string, value uint8, usage string) *uint8 { - return CommandLine.Uint8P(name, shorthand, value, usage) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/0doc.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/0doc.go deleted file mode 100644 index caa7e0a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/0doc.go +++ /dev/null @@ -1,193 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -/* -High Performance, Feature-Rich Idiomatic Go codec/encoding library for -binc, msgpack, cbor, json. - -Supported Serialization formats are: - - - msgpack: https://github.com/msgpack/msgpack - - binc: http://github.com/ugorji/binc - - cbor: http://cbor.io http://tools.ietf.org/html/rfc7049 - - json: http://json.org http://tools.ietf.org/html/rfc7159 - - simple: - -To install: - - go get github.com/ugorji/go/codec - -This package understands the 'unsafe' tag, to allow using unsafe semantics: - - - When decoding into a struct, you need to read the field name as a string - so you can find the struct field it is mapped to. - Using `unsafe` will bypass the allocation and copying overhead of []byte->string conversion. - -To install using unsafe, pass the 'unsafe' tag: - - go get -tags=unsafe github.com/ugorji/go/codec - -For detailed usage information, read the primer at http://ugorji.net/blog/go-codec-primer . - -The idiomatic Go support is as seen in other encoding packages in -the standard library (ie json, xml, gob, etc). - -Rich Feature Set includes: - - - Simple but extremely powerful and feature-rich API - - Very High Performance. - Our extensive benchmarks show us outperforming Gob, Json, Bson, etc by 2-4X. - - Multiple conversions: - Package coerces types where appropriate - e.g. decode an int in the stream into a float, etc. - - Corner Cases: - Overflows, nil maps/slices, nil values in streams are handled correctly - - Standard field renaming via tags - - Support for omitting empty fields during an encoding - - Encoding from any value and decoding into pointer to any value - (struct, slice, map, primitives, pointers, interface{}, etc) - - Extensions to support efficient encoding/decoding of any named types - - Support encoding.(Binary|Text)(M|Unm)arshaler interfaces - - Decoding without a schema (into a interface{}). - Includes Options to configure what specific map or slice type to use - when decoding an encoded list or map into a nil interface{} - - Encode a struct as an array, and decode struct from an array in the data stream - - Comprehensive support for anonymous fields - - Fast (no-reflection) encoding/decoding of common maps and slices - - Code-generation for faster performance. - - Support binary (e.g. messagepack, cbor) and text (e.g. json) formats - - Support indefinite-length formats to enable true streaming - (for formats which support it e.g. json, cbor) - - Support canonical encoding, where a value is ALWAYS encoded as same sequence of bytes. - This mostly applies to maps, where iteration order is non-deterministic. - - NIL in data stream decoded as zero value - - Never silently skip data when decoding. - User decides whether to return an error or silently skip data when keys or indexes - in the data stream do not map to fields in the struct. - - Encode/Decode from/to chan types (for iterative streaming support) - - Drop-in replacement for encoding/json. `json:` key in struct tag supported. - - Provides a RPC Server and Client Codec for net/rpc communication protocol. - - Handle unique idiosynchracies of codecs e.g. - - For messagepack, configure how ambiguities in handling raw bytes are resolved - - For messagepack, provide rpc server/client codec to support - msgpack-rpc protocol defined at: - https://github.com/msgpack-rpc/msgpack-rpc/blob/master/spec.md - -Extension Support - -Users can register a function to handle the encoding or decoding of -their custom types. - -There are no restrictions on what the custom type can be. Some examples: - - type BisSet []int - type BitSet64 uint64 - type UUID string - type MyStructWithUnexportedFields struct { a int; b bool; c []int; } - type GifImage struct { ... } - -As an illustration, MyStructWithUnexportedFields would normally be -encoded as an empty map because it has no exported fields, while UUID -would be encoded as a string. However, with extension support, you can -encode any of these however you like. - -RPC - -RPC Client and Server Codecs are implemented, so the codecs can be used -with the standard net/rpc package. - -Usage - -The Handle is SAFE for concurrent READ, but NOT SAFE for concurrent modification. - -The Encoder and Decoder are NOT safe for concurrent use. - -Consequently, the usage model is basically: - - - Create and initialize the Handle before any use. - Once created, DO NOT modify it. - - Multiple Encoders or Decoders can now use the Handle concurrently. - They only read information off the Handle (never write). - - However, each Encoder or Decoder MUST not be used concurrently - - To re-use an Encoder/Decoder, call Reset(...) on it first. - This allows you use state maintained on the Encoder/Decoder. - -Sample usage model: - - // create and configure Handle - var ( - bh codec.BincHandle - mh codec.MsgpackHandle - ch codec.CborHandle - ) - - mh.MapType = reflect.TypeOf(map[string]interface{}(nil)) - - // configure extensions - // e.g. for msgpack, define functions and enable Time support for tag 1 - // mh.SetExt(reflect.TypeOf(time.Time{}), 1, myExt) - - // create and use decoder/encoder - var ( - r io.Reader - w io.Writer - b []byte - h = &bh // or mh to use msgpack - ) - - dec = codec.NewDecoder(r, h) - dec = codec.NewDecoderBytes(b, h) - err = dec.Decode(&v) - - enc = codec.NewEncoder(w, h) - enc = codec.NewEncoderBytes(&b, h) - err = enc.Encode(v) - - //RPC Server - go func() { - for { - conn, err := listener.Accept() - rpcCodec := codec.GoRpc.ServerCodec(conn, h) - //OR rpcCodec := codec.MsgpackSpecRpc.ServerCodec(conn, h) - rpc.ServeCodec(rpcCodec) - } - }() - - //RPC Communication (client side) - conn, err = net.Dial("tcp", "localhost:5555") - rpcCodec := codec.GoRpc.ClientCodec(conn, h) - //OR rpcCodec := codec.MsgpackSpecRpc.ClientCodec(conn, h) - client := rpc.NewClientWithCodec(rpcCodec) - -*/ -package codec - -// Benefits of go-codec: -// -// - encoding/json always reads whole file into memory first. -// This makes it unsuitable for parsing very large files. -// - encoding/xml cannot parse into a map[string]interface{} -// I found this out on reading https://github.com/clbanning/mxj - -// TODO: -// -// - (En|De)coder should store an error when it occurs. -// Until reset, subsequent calls return that error that was stored. -// This means that free panics must go away. -// All errors must be raised through errorf method. -// - Decoding using a chan is good, but incurs concurrency costs. -// This is because there's no fast way to use a channel without it -// having to switch goroutines constantly. -// Callback pattern is still the best. Maybe cnsider supporting something like: -// type X struct { -// Name string -// Ys []Y -// Ys chan <- Y -// Ys func(interface{}) -> call this interface for each entry in there. -// } -// - Consider adding a isZeroer interface { isZero() bool } -// It is used within isEmpty, for omitEmpty support. -// - Consider making Handle used AS-IS within the encoding/decoding session. -// This means that we don't cache Handle information within the (En|De)coder, -// except we really need it at Reset(...) -// - Handle recursive types during encoding/decoding? diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/README.md b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/README.md deleted file mode 100644 index a790a52..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/README.md +++ /dev/null @@ -1,148 +0,0 @@ -# Codec - -High Performance, Feature-Rich Idiomatic Go codec/encoding library for -binc, msgpack, cbor, json. - -Supported Serialization formats are: - - - msgpack: https://github.com/msgpack/msgpack - - binc: http://github.com/ugorji/binc - - cbor: http://cbor.io http://tools.ietf.org/html/rfc7049 - - json: http://json.org http://tools.ietf.org/html/rfc7159 - - simple: - -To install: - - go get github.com/ugorji/go/codec - -This package understands the `unsafe` tag, to allow using unsafe semantics: - - - When decoding into a struct, you need to read the field name as a string - so you can find the struct field it is mapped to. - Using `unsafe` will bypass the allocation and copying overhead of `[]byte->string` conversion. - -To use it, you must pass the `unsafe` tag during install: - -``` -go install -tags=unsafe github.com/ugorji/go/codec -``` - -Online documentation: http://godoc.org/github.com/ugorji/go/codec -Detailed Usage/How-to Primer: http://ugorji.net/blog/go-codec-primer - -The idiomatic Go support is as seen in other encoding packages in -the standard library (ie json, xml, gob, etc). - -Rich Feature Set includes: - - - Simple but extremely powerful and feature-rich API - - Very High Performance. - Our extensive benchmarks show us outperforming Gob, Json, Bson, etc by 2-4X. - - Multiple conversions: - Package coerces types where appropriate - e.g. decode an int in the stream into a float, etc. - - Corner Cases: - Overflows, nil maps/slices, nil values in streams are handled correctly - - Standard field renaming via tags - - Support for omitting empty fields during an encoding - - Encoding from any value and decoding into pointer to any value - (struct, slice, map, primitives, pointers, interface{}, etc) - - Extensions to support efficient encoding/decoding of any named types - - Support encoding.(Binary|Text)(M|Unm)arshaler interfaces - - Decoding without a schema (into a interface{}). - Includes Options to configure what specific map or slice type to use - when decoding an encoded list or map into a nil interface{} - - Encode a struct as an array, and decode struct from an array in the data stream - - Comprehensive support for anonymous fields - - Fast (no-reflection) encoding/decoding of common maps and slices - - Code-generation for faster performance. - - Support binary (e.g. messagepack, cbor) and text (e.g. json) formats - - Support indefinite-length formats to enable true streaming - (for formats which support it e.g. json, cbor) - - Support canonical encoding, where a value is ALWAYS encoded as same sequence of bytes. - This mostly applies to maps, where iteration order is non-deterministic. - - NIL in data stream decoded as zero value - - Never silently skip data when decoding. - User decides whether to return an error or silently skip data when keys or indexes - in the data stream do not map to fields in the struct. - - Encode/Decode from/to chan types (for iterative streaming support) - - Drop-in replacement for encoding/json. `json:` key in struct tag supported. - - Provides a RPC Server and Client Codec for net/rpc communication protocol. - - Handle unique idiosynchracies of codecs e.g. - - For messagepack, configure how ambiguities in handling raw bytes are resolved - - For messagepack, provide rpc server/client codec to support - msgpack-rpc protocol defined at: - https://github.com/msgpack-rpc/msgpack-rpc/blob/master/spec.md - -## Extension Support - -Users can register a function to handle the encoding or decoding of -their custom types. - -There are no restrictions on what the custom type can be. Some examples: - - type BisSet []int - type BitSet64 uint64 - type UUID string - type MyStructWithUnexportedFields struct { a int; b bool; c []int; } - type GifImage struct { ... } - -As an illustration, MyStructWithUnexportedFields would normally be -encoded as an empty map because it has no exported fields, while UUID -would be encoded as a string. However, with extension support, you can -encode any of these however you like. - -## RPC - -RPC Client and Server Codecs are implemented, so the codecs can be used -with the standard net/rpc package. - -## Usage - -Typical usage model: - - // create and configure Handle - var ( - bh codec.BincHandle - mh codec.MsgpackHandle - ch codec.CborHandle - ) - - mh.MapType = reflect.TypeOf(map[string]interface{}(nil)) - - // configure extensions - // e.g. for msgpack, define functions and enable Time support for tag 1 - // mh.SetExt(reflect.TypeOf(time.Time{}), 1, myExt) - - // create and use decoder/encoder - var ( - r io.Reader - w io.Writer - b []byte - h = &bh // or mh to use msgpack - ) - - dec = codec.NewDecoder(r, h) - dec = codec.NewDecoderBytes(b, h) - err = dec.Decode(&v) - - enc = codec.NewEncoder(w, h) - enc = codec.NewEncoderBytes(&b, h) - err = enc.Encode(v) - - //RPC Server - go func() { - for { - conn, err := listener.Accept() - rpcCodec := codec.GoRpc.ServerCodec(conn, h) - //OR rpcCodec := codec.MsgpackSpecRpc.ServerCodec(conn, h) - rpc.ServeCodec(rpcCodec) - } - }() - - //RPC Communication (client side) - conn, err = net.Dial("tcp", "localhost:5555") - rpcCodec := codec.GoRpc.ClientCodec(conn, h) - //OR rpcCodec := codec.MsgpackSpecRpc.ClientCodec(conn, h) - client := rpc.NewClientWithCodec(rpcCodec) - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/binc.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/binc.go deleted file mode 100644 index c884d14..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/binc.go +++ /dev/null @@ -1,918 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "math" - "reflect" - "time" -) - -const bincDoPrune = true // No longer needed. Needed before as C lib did not support pruning. - -// vd as low 4 bits (there are 16 slots) -const ( - bincVdSpecial byte = iota - bincVdPosInt - bincVdNegInt - bincVdFloat - - bincVdString - bincVdByteArray - bincVdArray - bincVdMap - - bincVdTimestamp - bincVdSmallInt - bincVdUnicodeOther - bincVdSymbol - - bincVdDecimal - _ // open slot - _ // open slot - bincVdCustomExt = 0x0f -) - -const ( - bincSpNil byte = iota - bincSpFalse - bincSpTrue - bincSpNan - bincSpPosInf - bincSpNegInf - bincSpZeroFloat - bincSpZero - bincSpNegOne -) - -const ( - bincFlBin16 byte = iota - bincFlBin32 - _ // bincFlBin32e - bincFlBin64 - _ // bincFlBin64e - // others not currently supported -) - -type bincEncDriver struct { - e *Encoder - w encWriter - m map[string]uint16 // symbols - b [scratchByteArrayLen]byte - s uint16 // symbols sequencer - encNoSeparator -} - -func (e *bincEncDriver) IsBuiltinType(rt uintptr) bool { - return rt == timeTypId -} - -func (e *bincEncDriver) EncodeBuiltin(rt uintptr, v interface{}) { - if rt == timeTypId { - var bs []byte - switch x := v.(type) { - case time.Time: - bs = encodeTime(x) - case *time.Time: - bs = encodeTime(*x) - default: - e.e.errorf("binc error encoding builtin: expect time.Time, received %T", v) - } - e.w.writen1(bincVdTimestamp<<4 | uint8(len(bs))) - e.w.writeb(bs) - } -} - -func (e *bincEncDriver) EncodeNil() { - e.w.writen1(bincVdSpecial<<4 | bincSpNil) -} - -func (e *bincEncDriver) EncodeBool(b bool) { - if b { - e.w.writen1(bincVdSpecial<<4 | bincSpTrue) - } else { - e.w.writen1(bincVdSpecial<<4 | bincSpFalse) - } -} - -func (e *bincEncDriver) EncodeFloat32(f float32) { - if f == 0 { - e.w.writen1(bincVdSpecial<<4 | bincSpZeroFloat) - return - } - e.w.writen1(bincVdFloat<<4 | bincFlBin32) - bigenHelper{e.b[:4], e.w}.writeUint32(math.Float32bits(f)) -} - -func (e *bincEncDriver) EncodeFloat64(f float64) { - if f == 0 { - e.w.writen1(bincVdSpecial<<4 | bincSpZeroFloat) - return - } - bigen.PutUint64(e.b[:8], math.Float64bits(f)) - if bincDoPrune { - i := 7 - for ; i >= 0 && (e.b[i] == 0); i-- { - } - i++ - if i <= 6 { - e.w.writen1(bincVdFloat<<4 | 0x8 | bincFlBin64) - e.w.writen1(byte(i)) - e.w.writeb(e.b[:i]) - return - } - } - e.w.writen1(bincVdFloat<<4 | bincFlBin64) - e.w.writeb(e.b[:8]) -} - -func (e *bincEncDriver) encIntegerPrune(bd byte, pos bool, v uint64, lim uint8) { - if lim == 4 { - bigen.PutUint32(e.b[:lim], uint32(v)) - } else { - bigen.PutUint64(e.b[:lim], v) - } - if bincDoPrune { - i := pruneSignExt(e.b[:lim], pos) - e.w.writen1(bd | lim - 1 - byte(i)) - e.w.writeb(e.b[i:lim]) - } else { - e.w.writen1(bd | lim - 1) - e.w.writeb(e.b[:lim]) - } -} - -func (e *bincEncDriver) EncodeInt(v int64) { - const nbd byte = bincVdNegInt << 4 - if v >= 0 { - e.encUint(bincVdPosInt<<4, true, uint64(v)) - } else if v == -1 { - e.w.writen1(bincVdSpecial<<4 | bincSpNegOne) - } else { - e.encUint(bincVdNegInt<<4, false, uint64(-v)) - } -} - -func (e *bincEncDriver) EncodeUint(v uint64) { - e.encUint(bincVdPosInt<<4, true, v) -} - -func (e *bincEncDriver) encUint(bd byte, pos bool, v uint64) { - if v == 0 { - e.w.writen1(bincVdSpecial<<4 | bincSpZero) - } else if pos && v >= 1 && v <= 16 { - e.w.writen1(bincVdSmallInt<<4 | byte(v-1)) - } else if v <= math.MaxUint8 { - e.w.writen2(bd|0x0, byte(v)) - } else if v <= math.MaxUint16 { - e.w.writen1(bd | 0x01) - bigenHelper{e.b[:2], e.w}.writeUint16(uint16(v)) - } else if v <= math.MaxUint32 { - e.encIntegerPrune(bd, pos, v, 4) - } else { - e.encIntegerPrune(bd, pos, v, 8) - } -} - -func (e *bincEncDriver) EncodeExt(rv interface{}, xtag uint64, ext Ext, _ *Encoder) { - bs := ext.WriteExt(rv) - if bs == nil { - e.EncodeNil() - return - } - e.encodeExtPreamble(uint8(xtag), len(bs)) - e.w.writeb(bs) -} - -func (e *bincEncDriver) EncodeRawExt(re *RawExt, _ *Encoder) { - e.encodeExtPreamble(uint8(re.Tag), len(re.Data)) - e.w.writeb(re.Data) -} - -func (e *bincEncDriver) encodeExtPreamble(xtag byte, length int) { - e.encLen(bincVdCustomExt<<4, uint64(length)) - e.w.writen1(xtag) -} - -func (e *bincEncDriver) EncodeArrayStart(length int) { - e.encLen(bincVdArray<<4, uint64(length)) -} - -func (e *bincEncDriver) EncodeMapStart(length int) { - e.encLen(bincVdMap<<4, uint64(length)) -} - -func (e *bincEncDriver) EncodeString(c charEncoding, v string) { - l := uint64(len(v)) - e.encBytesLen(c, l) - if l > 0 { - e.w.writestr(v) - } -} - -func (e *bincEncDriver) EncodeSymbol(v string) { - // if WriteSymbolsNoRefs { - // e.encodeString(c_UTF8, v) - // return - // } - - //symbols only offer benefit when string length > 1. - //This is because strings with length 1 take only 2 bytes to store - //(bd with embedded length, and single byte for string val). - - l := len(v) - if l == 0 { - e.encBytesLen(c_UTF8, 0) - return - } else if l == 1 { - e.encBytesLen(c_UTF8, 1) - e.w.writen1(v[0]) - return - } - if e.m == nil { - e.m = make(map[string]uint16, 16) - } - ui, ok := e.m[v] - if ok { - if ui <= math.MaxUint8 { - e.w.writen2(bincVdSymbol<<4, byte(ui)) - } else { - e.w.writen1(bincVdSymbol<<4 | 0x8) - bigenHelper{e.b[:2], e.w}.writeUint16(ui) - } - } else { - e.s++ - ui = e.s - //ui = uint16(atomic.AddUint32(&e.s, 1)) - e.m[v] = ui - var lenprec uint8 - if l <= math.MaxUint8 { - // lenprec = 0 - } else if l <= math.MaxUint16 { - lenprec = 1 - } else if int64(l) <= math.MaxUint32 { - lenprec = 2 - } else { - lenprec = 3 - } - if ui <= math.MaxUint8 { - e.w.writen2(bincVdSymbol<<4|0x0|0x4|lenprec, byte(ui)) - } else { - e.w.writen1(bincVdSymbol<<4 | 0x8 | 0x4 | lenprec) - bigenHelper{e.b[:2], e.w}.writeUint16(ui) - } - if lenprec == 0 { - e.w.writen1(byte(l)) - } else if lenprec == 1 { - bigenHelper{e.b[:2], e.w}.writeUint16(uint16(l)) - } else if lenprec == 2 { - bigenHelper{e.b[:4], e.w}.writeUint32(uint32(l)) - } else { - bigenHelper{e.b[:8], e.w}.writeUint64(uint64(l)) - } - e.w.writestr(v) - } -} - -func (e *bincEncDriver) EncodeStringBytes(c charEncoding, v []byte) { - l := uint64(len(v)) - e.encBytesLen(c, l) - if l > 0 { - e.w.writeb(v) - } -} - -func (e *bincEncDriver) encBytesLen(c charEncoding, length uint64) { - //TODO: support bincUnicodeOther (for now, just use string or bytearray) - if c == c_RAW { - e.encLen(bincVdByteArray<<4, length) - } else { - e.encLen(bincVdString<<4, length) - } -} - -func (e *bincEncDriver) encLen(bd byte, l uint64) { - if l < 12 { - e.w.writen1(bd | uint8(l+4)) - } else { - e.encLenNumber(bd, l) - } -} - -func (e *bincEncDriver) encLenNumber(bd byte, v uint64) { - if v <= math.MaxUint8 { - e.w.writen2(bd, byte(v)) - } else if v <= math.MaxUint16 { - e.w.writen1(bd | 0x01) - bigenHelper{e.b[:2], e.w}.writeUint16(uint16(v)) - } else if v <= math.MaxUint32 { - e.w.writen1(bd | 0x02) - bigenHelper{e.b[:4], e.w}.writeUint32(uint32(v)) - } else { - e.w.writen1(bd | 0x03) - bigenHelper{e.b[:8], e.w}.writeUint64(uint64(v)) - } -} - -//------------------------------------ - -type bincDecSymbol struct { - s string - b []byte - i uint16 -} - -type bincDecDriver struct { - d *Decoder - h *BincHandle - r decReader - br bool // bytes reader - bdRead bool - bd byte - vd byte - vs byte - noStreamingCodec - decNoSeparator - b [scratchByteArrayLen]byte - - // linear searching on this slice is ok, - // because we typically expect < 32 symbols in each stream. - s []bincDecSymbol -} - -func (d *bincDecDriver) readNextBd() { - d.bd = d.r.readn1() - d.vd = d.bd >> 4 - d.vs = d.bd & 0x0f - d.bdRead = true -} - -func (d *bincDecDriver) ContainerType() (vt valueType) { - if d.vd == bincVdSpecial && d.vs == bincSpNil { - return valueTypeNil - } else if d.vd == bincVdByteArray { - return valueTypeBytes - } else if d.vd == bincVdString { - return valueTypeString - } else if d.vd == bincVdArray { - return valueTypeArray - } else if d.vd == bincVdMap { - return valueTypeMap - } else { - // d.d.errorf("isContainerType: unsupported parameter: %v", vt) - } - return valueTypeUnset -} - -func (d *bincDecDriver) TryDecodeAsNil() bool { - if !d.bdRead { - d.readNextBd() - } - if d.bd == bincVdSpecial<<4|bincSpNil { - d.bdRead = false - return true - } - return false -} - -func (d *bincDecDriver) IsBuiltinType(rt uintptr) bool { - return rt == timeTypId -} - -func (d *bincDecDriver) DecodeBuiltin(rt uintptr, v interface{}) { - if !d.bdRead { - d.readNextBd() - } - if rt == timeTypId { - if d.vd != bincVdTimestamp { - d.d.errorf("Invalid d.vd. Expecting 0x%x. Received: 0x%x", bincVdTimestamp, d.vd) - return - } - tt, err := decodeTime(d.r.readx(int(d.vs))) - if err != nil { - panic(err) - } - var vt *time.Time = v.(*time.Time) - *vt = tt - d.bdRead = false - } -} - -func (d *bincDecDriver) decFloatPre(vs, defaultLen byte) { - if vs&0x8 == 0 { - d.r.readb(d.b[0:defaultLen]) - } else { - l := d.r.readn1() - if l > 8 { - d.d.errorf("At most 8 bytes used to represent float. Received: %v bytes", l) - return - } - for i := l; i < 8; i++ { - d.b[i] = 0 - } - d.r.readb(d.b[0:l]) - } -} - -func (d *bincDecDriver) decFloat() (f float64) { - //if true { f = math.Float64frombits(bigen.Uint64(d.r.readx(8))); break; } - if x := d.vs & 0x7; x == bincFlBin32 { - d.decFloatPre(d.vs, 4) - f = float64(math.Float32frombits(bigen.Uint32(d.b[0:4]))) - } else if x == bincFlBin64 { - d.decFloatPre(d.vs, 8) - f = math.Float64frombits(bigen.Uint64(d.b[0:8])) - } else { - d.d.errorf("only float32 and float64 are supported. d.vd: 0x%x, d.vs: 0x%x", d.vd, d.vs) - return - } - return -} - -func (d *bincDecDriver) decUint() (v uint64) { - // need to inline the code (interface conversion and type assertion expensive) - switch d.vs { - case 0: - v = uint64(d.r.readn1()) - case 1: - d.r.readb(d.b[6:8]) - v = uint64(bigen.Uint16(d.b[6:8])) - case 2: - d.b[4] = 0 - d.r.readb(d.b[5:8]) - v = uint64(bigen.Uint32(d.b[4:8])) - case 3: - d.r.readb(d.b[4:8]) - v = uint64(bigen.Uint32(d.b[4:8])) - case 4, 5, 6: - lim := int(7 - d.vs) - d.r.readb(d.b[lim:8]) - for i := 0; i < lim; i++ { - d.b[i] = 0 - } - v = uint64(bigen.Uint64(d.b[:8])) - case 7: - d.r.readb(d.b[:8]) - v = uint64(bigen.Uint64(d.b[:8])) - default: - d.d.errorf("unsigned integers with greater than 64 bits of precision not supported") - return - } - return -} - -func (d *bincDecDriver) decCheckInteger() (ui uint64, neg bool) { - if !d.bdRead { - d.readNextBd() - } - vd, vs := d.vd, d.vs - if vd == bincVdPosInt { - ui = d.decUint() - } else if vd == bincVdNegInt { - ui = d.decUint() - neg = true - } else if vd == bincVdSmallInt { - ui = uint64(d.vs) + 1 - } else if vd == bincVdSpecial { - if vs == bincSpZero { - //i = 0 - } else if vs == bincSpNegOne { - neg = true - ui = 1 - } else { - d.d.errorf("numeric decode fails for special value: d.vs: 0x%x", d.vs) - return - } - } else { - d.d.errorf("number can only be decoded from uint or int values. d.bd: 0x%x, d.vd: 0x%x", d.bd, d.vd) - return - } - return -} - -func (d *bincDecDriver) DecodeInt(bitsize uint8) (i int64) { - ui, neg := d.decCheckInteger() - i, overflow := chkOvf.SignedInt(ui) - if overflow { - d.d.errorf("simple: overflow converting %v to signed integer", ui) - return - } - if neg { - i = -i - } - if chkOvf.Int(i, bitsize) { - d.d.errorf("binc: overflow integer: %v", i) - return - } - d.bdRead = false - return -} - -func (d *bincDecDriver) DecodeUint(bitsize uint8) (ui uint64) { - ui, neg := d.decCheckInteger() - if neg { - d.d.errorf("Assigning negative signed value to unsigned type") - return - } - if chkOvf.Uint(ui, bitsize) { - d.d.errorf("binc: overflow integer: %v", ui) - return - } - d.bdRead = false - return -} - -func (d *bincDecDriver) DecodeFloat(chkOverflow32 bool) (f float64) { - if !d.bdRead { - d.readNextBd() - } - vd, vs := d.vd, d.vs - if vd == bincVdSpecial { - d.bdRead = false - if vs == bincSpNan { - return math.NaN() - } else if vs == bincSpPosInf { - return math.Inf(1) - } else if vs == bincSpZeroFloat || vs == bincSpZero { - return - } else if vs == bincSpNegInf { - return math.Inf(-1) - } else { - d.d.errorf("Invalid d.vs decoding float where d.vd=bincVdSpecial: %v", d.vs) - return - } - } else if vd == bincVdFloat { - f = d.decFloat() - } else { - f = float64(d.DecodeInt(64)) - } - if chkOverflow32 && chkOvf.Float32(f) { - d.d.errorf("binc: float32 overflow: %v", f) - return - } - d.bdRead = false - return -} - -// bool can be decoded from bool only (single byte). -func (d *bincDecDriver) DecodeBool() (b bool) { - if !d.bdRead { - d.readNextBd() - } - if bd := d.bd; bd == (bincVdSpecial | bincSpFalse) { - // b = false - } else if bd == (bincVdSpecial | bincSpTrue) { - b = true - } else { - d.d.errorf("Invalid single-byte value for bool: %s: %x", msgBadDesc, d.bd) - return - } - d.bdRead = false - return -} - -func (d *bincDecDriver) ReadMapStart() (length int) { - if d.vd != bincVdMap { - d.d.errorf("Invalid d.vd for map. Expecting 0x%x. Got: 0x%x", bincVdMap, d.vd) - return - } - length = d.decLen() - d.bdRead = false - return -} - -func (d *bincDecDriver) ReadArrayStart() (length int) { - if d.vd != bincVdArray { - d.d.errorf("Invalid d.vd for array. Expecting 0x%x. Got: 0x%x", bincVdArray, d.vd) - return - } - length = d.decLen() - d.bdRead = false - return -} - -func (d *bincDecDriver) decLen() int { - if d.vs > 3 { - return int(d.vs - 4) - } - return int(d.decLenNumber()) -} - -func (d *bincDecDriver) decLenNumber() (v uint64) { - if x := d.vs; x == 0 { - v = uint64(d.r.readn1()) - } else if x == 1 { - d.r.readb(d.b[6:8]) - v = uint64(bigen.Uint16(d.b[6:8])) - } else if x == 2 { - d.r.readb(d.b[4:8]) - v = uint64(bigen.Uint32(d.b[4:8])) - } else { - d.r.readb(d.b[:8]) - v = bigen.Uint64(d.b[:8]) - } - return -} - -func (d *bincDecDriver) decStringAndBytes(bs []byte, withString, zerocopy bool) (bs2 []byte, s string) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == bincVdSpecial<<4|bincSpNil { - d.bdRead = false - return - } - var slen int = -1 - // var ok bool - switch d.vd { - case bincVdString, bincVdByteArray: - slen = d.decLen() - if zerocopy { - if d.br { - bs2 = d.r.readx(slen) - } else if len(bs) == 0 { - bs2 = decByteSlice(d.r, slen, d.b[:]) - } else { - bs2 = decByteSlice(d.r, slen, bs) - } - } else { - bs2 = decByteSlice(d.r, slen, bs) - } - if withString { - s = string(bs2) - } - case bincVdSymbol: - // zerocopy doesn't apply for symbols, - // as the values must be stored in a table for later use. - // - //from vs: extract numSymbolBytes, containsStringVal, strLenPrecision, - //extract symbol - //if containsStringVal, read it and put in map - //else look in map for string value - var symbol uint16 - vs := d.vs - if vs&0x8 == 0 { - symbol = uint16(d.r.readn1()) - } else { - symbol = uint16(bigen.Uint16(d.r.readx(2))) - } - if d.s == nil { - d.s = make([]bincDecSymbol, 0, 16) - } - - if vs&0x4 == 0 { - for i := range d.s { - j := &d.s[i] - if j.i == symbol { - bs2 = j.b - if withString { - if j.s == "" && bs2 != nil { - j.s = string(bs2) - } - s = j.s - } - break - } - } - } else { - switch vs & 0x3 { - case 0: - slen = int(d.r.readn1()) - case 1: - slen = int(bigen.Uint16(d.r.readx(2))) - case 2: - slen = int(bigen.Uint32(d.r.readx(4))) - case 3: - slen = int(bigen.Uint64(d.r.readx(8))) - } - // since using symbols, do not store any part of - // the parameter bs in the map, as it might be a shared buffer. - // bs2 = decByteSlice(d.r, slen, bs) - bs2 = decByteSlice(d.r, slen, nil) - if withString { - s = string(bs2) - } - d.s = append(d.s, bincDecSymbol{i: symbol, s: s, b: bs2}) - } - default: - d.d.errorf("Invalid d.vd. Expecting string:0x%x, bytearray:0x%x or symbol: 0x%x. Got: 0x%x", - bincVdString, bincVdByteArray, bincVdSymbol, d.vd) - return - } - d.bdRead = false - return -} - -func (d *bincDecDriver) DecodeString() (s string) { - // DecodeBytes does not accomodate symbols, whose impl stores string version in map. - // Use decStringAndBytes directly. - // return string(d.DecodeBytes(d.b[:], true, true)) - _, s = d.decStringAndBytes(d.b[:], true, true) - return -} - -func (d *bincDecDriver) DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) { - if isstring { - bsOut, _ = d.decStringAndBytes(bs, false, zerocopy) - return - } - if !d.bdRead { - d.readNextBd() - } - if d.bd == bincVdSpecial<<4|bincSpNil { - d.bdRead = false - return nil - } - var clen int - if d.vd == bincVdString || d.vd == bincVdByteArray { - clen = d.decLen() - } else { - d.d.errorf("Invalid d.vd for bytes. Expecting string:0x%x or bytearray:0x%x. Got: 0x%x", - bincVdString, bincVdByteArray, d.vd) - return - } - d.bdRead = false - if zerocopy { - if d.br { - return d.r.readx(clen) - } else if len(bs) == 0 { - bs = d.b[:] - } - } - return decByteSlice(d.r, clen, bs) -} - -func (d *bincDecDriver) DecodeExt(rv interface{}, xtag uint64, ext Ext) (realxtag uint64) { - if xtag > 0xff { - d.d.errorf("decodeExt: tag must be <= 0xff; got: %v", xtag) - return - } - realxtag1, xbs := d.decodeExtV(ext != nil, uint8(xtag)) - realxtag = uint64(realxtag1) - if ext == nil { - re := rv.(*RawExt) - re.Tag = realxtag - re.Data = detachZeroCopyBytes(d.br, re.Data, xbs) - } else { - ext.ReadExt(rv, xbs) - } - return -} - -func (d *bincDecDriver) decodeExtV(verifyTag bool, tag byte) (xtag byte, xbs []byte) { - if !d.bdRead { - d.readNextBd() - } - if d.vd == bincVdCustomExt { - l := d.decLen() - xtag = d.r.readn1() - if verifyTag && xtag != tag { - d.d.errorf("Wrong extension tag. Got %b. Expecting: %v", xtag, tag) - return - } - xbs = d.r.readx(l) - } else if d.vd == bincVdByteArray { - xbs = d.DecodeBytes(nil, false, true) - } else { - d.d.errorf("Invalid d.vd for extensions (Expecting extensions or byte array). Got: 0x%x", d.vd) - return - } - d.bdRead = false - return -} - -func (d *bincDecDriver) DecodeNaked() { - if !d.bdRead { - d.readNextBd() - } - - n := &d.d.n - var decodeFurther bool - - switch d.vd { - case bincVdSpecial: - switch d.vs { - case bincSpNil: - n.v = valueTypeNil - case bincSpFalse: - n.v = valueTypeBool - n.b = false - case bincSpTrue: - n.v = valueTypeBool - n.b = true - case bincSpNan: - n.v = valueTypeFloat - n.f = math.NaN() - case bincSpPosInf: - n.v = valueTypeFloat - n.f = math.Inf(1) - case bincSpNegInf: - n.v = valueTypeFloat - n.f = math.Inf(-1) - case bincSpZeroFloat: - n.v = valueTypeFloat - n.f = float64(0) - case bincSpZero: - n.v = valueTypeUint - n.u = uint64(0) // int8(0) - case bincSpNegOne: - n.v = valueTypeInt - n.i = int64(-1) // int8(-1) - default: - d.d.errorf("decodeNaked: Unrecognized special value 0x%x", d.vs) - } - case bincVdSmallInt: - n.v = valueTypeUint - n.u = uint64(int8(d.vs)) + 1 // int8(d.vs) + 1 - case bincVdPosInt: - n.v = valueTypeUint - n.u = d.decUint() - case bincVdNegInt: - n.v = valueTypeInt - n.i = -(int64(d.decUint())) - case bincVdFloat: - n.v = valueTypeFloat - n.f = d.decFloat() - case bincVdSymbol: - n.v = valueTypeSymbol - n.s = d.DecodeString() - case bincVdString: - n.v = valueTypeString - n.s = d.DecodeString() - case bincVdByteArray: - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - case bincVdTimestamp: - n.v = valueTypeTimestamp - tt, err := decodeTime(d.r.readx(int(d.vs))) - if err != nil { - panic(err) - } - n.t = tt - case bincVdCustomExt: - n.v = valueTypeExt - l := d.decLen() - n.u = uint64(d.r.readn1()) - n.l = d.r.readx(l) - case bincVdArray: - n.v = valueTypeArray - decodeFurther = true - case bincVdMap: - n.v = valueTypeMap - decodeFurther = true - default: - d.d.errorf("decodeNaked: Unrecognized d.vd: 0x%x", d.vd) - } - - if !decodeFurther { - d.bdRead = false - } - if n.v == valueTypeUint && d.h.SignedInteger { - n.v = valueTypeInt - n.i = int64(n.u) - } - return -} - -//------------------------------------ - -//BincHandle is a Handle for the Binc Schema-Free Encoding Format -//defined at https://github.com/ugorji/binc . -// -//BincHandle currently supports all Binc features with the following EXCEPTIONS: -// - only integers up to 64 bits of precision are supported. -// big integers are unsupported. -// - Only IEEE 754 binary32 and binary64 floats are supported (ie Go float32 and float64 types). -// extended precision and decimal IEEE 754 floats are unsupported. -// - Only UTF-8 strings supported. -// Unicode_Other Binc types (UTF16, UTF32) are currently unsupported. -// -//Note that these EXCEPTIONS are temporary and full support is possible and may happen soon. -type BincHandle struct { - BasicHandle - binaryEncodingType -} - -func (h *BincHandle) SetBytesExt(rt reflect.Type, tag uint64, ext BytesExt) (err error) { - return h.SetExt(rt, tag, &setExtWrapper{b: ext}) -} - -func (h *BincHandle) newEncDriver(e *Encoder) encDriver { - return &bincEncDriver{e: e, w: e.w} -} - -func (h *BincHandle) newDecDriver(d *Decoder) decDriver { - return &bincDecDriver{d: d, r: d.r, h: h, br: d.bytes} -} - -func (e *bincEncDriver) reset() { - e.w = e.e.w -} - -func (d *bincDecDriver) reset() { - d.r = d.d.r -} - -var _ decDriver = (*bincDecDriver)(nil) -var _ encDriver = (*bincEncDriver)(nil) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/cbor.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/cbor.go deleted file mode 100644 index 0e5d32b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/cbor.go +++ /dev/null @@ -1,584 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "math" - "reflect" -) - -const ( - cborMajorUint byte = iota - cborMajorNegInt - cborMajorBytes - cborMajorText - cborMajorArray - cborMajorMap - cborMajorTag - cborMajorOther -) - -const ( - cborBdFalse byte = 0xf4 + iota - cborBdTrue - cborBdNil - cborBdUndefined - cborBdExt - cborBdFloat16 - cborBdFloat32 - cborBdFloat64 -) - -const ( - cborBdIndefiniteBytes byte = 0x5f - cborBdIndefiniteString = 0x7f - cborBdIndefiniteArray = 0x9f - cborBdIndefiniteMap = 0xbf - cborBdBreak = 0xff -) - -const ( - CborStreamBytes byte = 0x5f - CborStreamString = 0x7f - CborStreamArray = 0x9f - CborStreamMap = 0xbf - CborStreamBreak = 0xff -) - -const ( - cborBaseUint byte = 0x00 - cborBaseNegInt = 0x20 - cborBaseBytes = 0x40 - cborBaseString = 0x60 - cborBaseArray = 0x80 - cborBaseMap = 0xa0 - cborBaseTag = 0xc0 - cborBaseSimple = 0xe0 -) - -// ------------------- - -type cborEncDriver struct { - noBuiltInTypes - encNoSeparator - e *Encoder - w encWriter - h *CborHandle - x [8]byte -} - -func (e *cborEncDriver) EncodeNil() { - e.w.writen1(cborBdNil) -} - -func (e *cborEncDriver) EncodeBool(b bool) { - if b { - e.w.writen1(cborBdTrue) - } else { - e.w.writen1(cborBdFalse) - } -} - -func (e *cborEncDriver) EncodeFloat32(f float32) { - e.w.writen1(cborBdFloat32) - bigenHelper{e.x[:4], e.w}.writeUint32(math.Float32bits(f)) -} - -func (e *cborEncDriver) EncodeFloat64(f float64) { - e.w.writen1(cborBdFloat64) - bigenHelper{e.x[:8], e.w}.writeUint64(math.Float64bits(f)) -} - -func (e *cborEncDriver) encUint(v uint64, bd byte) { - if v <= 0x17 { - e.w.writen1(byte(v) + bd) - } else if v <= math.MaxUint8 { - e.w.writen2(bd+0x18, uint8(v)) - } else if v <= math.MaxUint16 { - e.w.writen1(bd + 0x19) - bigenHelper{e.x[:2], e.w}.writeUint16(uint16(v)) - } else if v <= math.MaxUint32 { - e.w.writen1(bd + 0x1a) - bigenHelper{e.x[:4], e.w}.writeUint32(uint32(v)) - } else { // if v <= math.MaxUint64 { - e.w.writen1(bd + 0x1b) - bigenHelper{e.x[:8], e.w}.writeUint64(v) - } -} - -func (e *cborEncDriver) EncodeInt(v int64) { - if v < 0 { - e.encUint(uint64(-1-v), cborBaseNegInt) - } else { - e.encUint(uint64(v), cborBaseUint) - } -} - -func (e *cborEncDriver) EncodeUint(v uint64) { - e.encUint(v, cborBaseUint) -} - -func (e *cborEncDriver) encLen(bd byte, length int) { - e.encUint(uint64(length), bd) -} - -func (e *cborEncDriver) EncodeExt(rv interface{}, xtag uint64, ext Ext, en *Encoder) { - e.encUint(uint64(xtag), cborBaseTag) - if v := ext.ConvertExt(rv); v == nil { - e.EncodeNil() - } else { - en.encode(v) - } -} - -func (e *cborEncDriver) EncodeRawExt(re *RawExt, en *Encoder) { - e.encUint(uint64(re.Tag), cborBaseTag) - if re.Data != nil { - en.encode(re.Data) - } else if re.Value == nil { - e.EncodeNil() - } else { - en.encode(re.Value) - } -} - -func (e *cborEncDriver) EncodeArrayStart(length int) { - e.encLen(cborBaseArray, length) -} - -func (e *cborEncDriver) EncodeMapStart(length int) { - e.encLen(cborBaseMap, length) -} - -func (e *cborEncDriver) EncodeString(c charEncoding, v string) { - e.encLen(cborBaseString, len(v)) - e.w.writestr(v) -} - -func (e *cborEncDriver) EncodeSymbol(v string) { - e.EncodeString(c_UTF8, v) -} - -func (e *cborEncDriver) EncodeStringBytes(c charEncoding, v []byte) { - if c == c_RAW { - e.encLen(cborBaseBytes, len(v)) - } else { - e.encLen(cborBaseString, len(v)) - } - e.w.writeb(v) -} - -// ---------------------- - -type cborDecDriver struct { - d *Decoder - h *CborHandle - r decReader - b [scratchByteArrayLen]byte - br bool // bytes reader - bdRead bool - bd byte - noBuiltInTypes - decNoSeparator -} - -func (d *cborDecDriver) readNextBd() { - d.bd = d.r.readn1() - d.bdRead = true -} - -func (d *cborDecDriver) ContainerType() (vt valueType) { - if d.bd == cborBdNil { - return valueTypeNil - } else if d.bd == cborBdIndefiniteBytes || (d.bd >= cborBaseBytes && d.bd < cborBaseString) { - return valueTypeBytes - } else if d.bd == cborBdIndefiniteString || (d.bd >= cborBaseString && d.bd < cborBaseArray) { - return valueTypeString - } else if d.bd == cborBdIndefiniteArray || (d.bd >= cborBaseArray && d.bd < cborBaseMap) { - return valueTypeArray - } else if d.bd == cborBdIndefiniteMap || (d.bd >= cborBaseMap && d.bd < cborBaseTag) { - return valueTypeMap - } else { - // d.d.errorf("isContainerType: unsupported parameter: %v", vt) - } - return valueTypeUnset -} - -func (d *cborDecDriver) TryDecodeAsNil() bool { - if !d.bdRead { - d.readNextBd() - } - // treat Nil and Undefined as nil values - if d.bd == cborBdNil || d.bd == cborBdUndefined { - d.bdRead = false - return true - } - return false -} - -func (d *cborDecDriver) CheckBreak() bool { - if !d.bdRead { - d.readNextBd() - } - if d.bd == cborBdBreak { - d.bdRead = false - return true - } - return false -} - -func (d *cborDecDriver) decUint() (ui uint64) { - v := d.bd & 0x1f - if v <= 0x17 { - ui = uint64(v) - } else { - if v == 0x18 { - ui = uint64(d.r.readn1()) - } else if v == 0x19 { - ui = uint64(bigen.Uint16(d.r.readx(2))) - } else if v == 0x1a { - ui = uint64(bigen.Uint32(d.r.readx(4))) - } else if v == 0x1b { - ui = uint64(bigen.Uint64(d.r.readx(8))) - } else { - d.d.errorf("decUint: Invalid descriptor: %v", d.bd) - return - } - } - return -} - -func (d *cborDecDriver) decCheckInteger() (neg bool) { - if !d.bdRead { - d.readNextBd() - } - major := d.bd >> 5 - if major == cborMajorUint { - } else if major == cborMajorNegInt { - neg = true - } else { - d.d.errorf("invalid major: %v (bd: %v)", major, d.bd) - return - } - return -} - -func (d *cborDecDriver) DecodeInt(bitsize uint8) (i int64) { - neg := d.decCheckInteger() - ui := d.decUint() - // check if this number can be converted to an int without overflow - var overflow bool - if neg { - if i, overflow = chkOvf.SignedInt(ui + 1); overflow { - d.d.errorf("cbor: overflow converting %v to signed integer", ui+1) - return - } - i = -i - } else { - if i, overflow = chkOvf.SignedInt(ui); overflow { - d.d.errorf("cbor: overflow converting %v to signed integer", ui) - return - } - } - if chkOvf.Int(i, bitsize) { - d.d.errorf("cbor: overflow integer: %v", i) - return - } - d.bdRead = false - return -} - -func (d *cborDecDriver) DecodeUint(bitsize uint8) (ui uint64) { - if d.decCheckInteger() { - d.d.errorf("Assigning negative signed value to unsigned type") - return - } - ui = d.decUint() - if chkOvf.Uint(ui, bitsize) { - d.d.errorf("cbor: overflow integer: %v", ui) - return - } - d.bdRead = false - return -} - -func (d *cborDecDriver) DecodeFloat(chkOverflow32 bool) (f float64) { - if !d.bdRead { - d.readNextBd() - } - if bd := d.bd; bd == cborBdFloat16 { - f = float64(math.Float32frombits(halfFloatToFloatBits(bigen.Uint16(d.r.readx(2))))) - } else if bd == cborBdFloat32 { - f = float64(math.Float32frombits(bigen.Uint32(d.r.readx(4)))) - } else if bd == cborBdFloat64 { - f = math.Float64frombits(bigen.Uint64(d.r.readx(8))) - } else if bd >= cborBaseUint && bd < cborBaseBytes { - f = float64(d.DecodeInt(64)) - } else { - d.d.errorf("Float only valid from float16/32/64: Invalid descriptor: %v", bd) - return - } - if chkOverflow32 && chkOvf.Float32(f) { - d.d.errorf("cbor: float32 overflow: %v", f) - return - } - d.bdRead = false - return -} - -// bool can be decoded from bool only (single byte). -func (d *cborDecDriver) DecodeBool() (b bool) { - if !d.bdRead { - d.readNextBd() - } - if bd := d.bd; bd == cborBdTrue { - b = true - } else if bd == cborBdFalse { - } else { - d.d.errorf("Invalid single-byte value for bool: %s: %x", msgBadDesc, d.bd) - return - } - d.bdRead = false - return -} - -func (d *cborDecDriver) ReadMapStart() (length int) { - d.bdRead = false - if d.bd == cborBdIndefiniteMap { - return -1 - } - return d.decLen() -} - -func (d *cborDecDriver) ReadArrayStart() (length int) { - d.bdRead = false - if d.bd == cborBdIndefiniteArray { - return -1 - } - return d.decLen() -} - -func (d *cborDecDriver) decLen() int { - return int(d.decUint()) -} - -func (d *cborDecDriver) decAppendIndefiniteBytes(bs []byte) []byte { - d.bdRead = false - for { - if d.CheckBreak() { - break - } - if major := d.bd >> 5; major != cborMajorBytes && major != cborMajorText { - d.d.errorf("cbor: expect bytes or string major type in indefinite string/bytes; got: %v, byte: %v", major, d.bd) - return nil - } - n := d.decLen() - oldLen := len(bs) - newLen := oldLen + n - if newLen > cap(bs) { - bs2 := make([]byte, newLen, 2*cap(bs)+n) - copy(bs2, bs) - bs = bs2 - } else { - bs = bs[:newLen] - } - d.r.readb(bs[oldLen:newLen]) - // bs = append(bs, d.r.readn()...) - d.bdRead = false - } - d.bdRead = false - return bs -} - -func (d *cborDecDriver) DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == cborBdNil || d.bd == cborBdUndefined { - d.bdRead = false - return nil - } - if d.bd == cborBdIndefiniteBytes || d.bd == cborBdIndefiniteString { - if bs == nil { - return d.decAppendIndefiniteBytes(nil) - } - return d.decAppendIndefiniteBytes(bs[:0]) - } - clen := d.decLen() - d.bdRead = false - if zerocopy { - if d.br { - return d.r.readx(clen) - } else if len(bs) == 0 { - bs = d.b[:] - } - } - return decByteSlice(d.r, clen, bs) -} - -func (d *cborDecDriver) DecodeString() (s string) { - return string(d.DecodeBytes(d.b[:], true, true)) -} - -func (d *cborDecDriver) DecodeExt(rv interface{}, xtag uint64, ext Ext) (realxtag uint64) { - if !d.bdRead { - d.readNextBd() - } - u := d.decUint() - d.bdRead = false - realxtag = u - if ext == nil { - re := rv.(*RawExt) - re.Tag = realxtag - d.d.decode(&re.Value) - } else if xtag != realxtag { - d.d.errorf("Wrong extension tag. Got %b. Expecting: %v", realxtag, xtag) - return - } else { - var v interface{} - d.d.decode(&v) - ext.UpdateExt(rv, v) - } - d.bdRead = false - return -} - -func (d *cborDecDriver) DecodeNaked() { - if !d.bdRead { - d.readNextBd() - } - - n := &d.d.n - var decodeFurther bool - - switch d.bd { - case cborBdNil: - n.v = valueTypeNil - case cborBdFalse: - n.v = valueTypeBool - n.b = false - case cborBdTrue: - n.v = valueTypeBool - n.b = true - case cborBdFloat16, cborBdFloat32: - n.v = valueTypeFloat - n.f = d.DecodeFloat(true) - case cborBdFloat64: - n.v = valueTypeFloat - n.f = d.DecodeFloat(false) - case cborBdIndefiniteBytes: - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - case cborBdIndefiniteString: - n.v = valueTypeString - n.s = d.DecodeString() - case cborBdIndefiniteArray: - n.v = valueTypeArray - decodeFurther = true - case cborBdIndefiniteMap: - n.v = valueTypeMap - decodeFurther = true - default: - switch { - case d.bd >= cborBaseUint && d.bd < cborBaseNegInt: - if d.h.SignedInteger { - n.v = valueTypeInt - n.i = d.DecodeInt(64) - } else { - n.v = valueTypeUint - n.u = d.DecodeUint(64) - } - case d.bd >= cborBaseNegInt && d.bd < cborBaseBytes: - n.v = valueTypeInt - n.i = d.DecodeInt(64) - case d.bd >= cborBaseBytes && d.bd < cborBaseString: - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - case d.bd >= cborBaseString && d.bd < cborBaseArray: - n.v = valueTypeString - n.s = d.DecodeString() - case d.bd >= cborBaseArray && d.bd < cborBaseMap: - n.v = valueTypeArray - decodeFurther = true - case d.bd >= cborBaseMap && d.bd < cborBaseTag: - n.v = valueTypeMap - decodeFurther = true - case d.bd >= cborBaseTag && d.bd < cborBaseSimple: - n.v = valueTypeExt - n.u = d.decUint() - n.l = nil - d.bdRead = false - // d.d.decode(&re.Value) // handled by decode itself. - // decodeFurther = true - default: - d.d.errorf("decodeNaked: Unrecognized d.bd: 0x%x", d.bd) - return - } - } - - if !decodeFurther { - d.bdRead = false - } - return -} - -// ------------------------- - -// CborHandle is a Handle for the CBOR encoding format, -// defined at http://tools.ietf.org/html/rfc7049 and documented further at http://cbor.io . -// -// CBOR is comprehensively supported, including support for: -// - indefinite-length arrays/maps/bytes/strings -// - (extension) tags in range 0..0xffff (0 .. 65535) -// - half, single and double-precision floats -// - all numbers (1, 2, 4 and 8-byte signed and unsigned integers) -// - nil, true, false, ... -// - arrays and maps, bytes and text strings -// -// None of the optional extensions (with tags) defined in the spec are supported out-of-the-box. -// Users can implement them as needed (using SetExt), including spec-documented ones: -// - timestamp, BigNum, BigFloat, Decimals, Encoded Text (e.g. URL, regexp, base64, MIME Message), etc. -// -// To encode with indefinite lengths (streaming), users will use -// (Must)Encode methods of *Encoder, along with writing CborStreamXXX constants. -// -// For example, to encode "one-byte" as an indefinite length string: -// var buf bytes.Buffer -// e := NewEncoder(&buf, new(CborHandle)) -// buf.WriteByte(CborStreamString) -// e.MustEncode("one-") -// e.MustEncode("byte") -// buf.WriteByte(CborStreamBreak) -// encodedBytes := buf.Bytes() -// var vv interface{} -// NewDecoderBytes(buf.Bytes(), new(CborHandle)).MustDecode(&vv) -// // Now, vv contains the same string "one-byte" -// -type CborHandle struct { - binaryEncodingType - BasicHandle -} - -func (h *CborHandle) SetInterfaceExt(rt reflect.Type, tag uint64, ext InterfaceExt) (err error) { - return h.SetExt(rt, tag, &setExtWrapper{i: ext}) -} - -func (h *CborHandle) newEncDriver(e *Encoder) encDriver { - return &cborEncDriver{e: e, w: e.w, h: h} -} - -func (h *CborHandle) newDecDriver(d *Decoder) decDriver { - return &cborDecDriver{d: d, r: d.r, h: h, br: d.bytes} -} - -func (e *cborEncDriver) reset() { - e.w = e.e.w -} - -func (d *cborDecDriver) reset() { - d.r = d.d.r -} - -var _ decDriver = (*cborDecDriver)(nil) -var _ encDriver = (*cborEncDriver)(nil) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/decode.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/decode.go deleted file mode 100644 index b3b99f0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/decode.go +++ /dev/null @@ -1,2015 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "encoding" - "errors" - "fmt" - "io" - "reflect" - "time" -) - -// Some tagging information for error messages. -const ( - msgBadDesc = "Unrecognized descriptor byte" - msgDecCannotExpandArr = "cannot expand go array from %v to stream length: %v" -) - -var ( - onlyMapOrArrayCanDecodeIntoStructErr = errors.New("only encoded map or array can be decoded into a struct") - cannotDecodeIntoNilErr = errors.New("cannot decode into nil") -) - -// decReader abstracts the reading source, allowing implementations that can -// read from an io.Reader or directly off a byte slice with zero-copying. -type decReader interface { - unreadn1() - - // readx will use the implementation scratch buffer if possible i.e. n < len(scratchbuf), OR - // just return a view of the []byte being decoded from. - // Ensure you call detachZeroCopyBytes later if this needs to be sent outside codec control. - readx(n int) []byte - readb([]byte) - readn1() uint8 - readn1eof() (v uint8, eof bool) - numread() int // number of bytes read - track() - stopTrack() []byte -} - -type decReaderByteScanner interface { - io.Reader - io.ByteScanner -} - -type decDriver interface { - // this will check if the next token is a break. - CheckBreak() bool - TryDecodeAsNil() bool - // vt is one of: Bytes, String, Nil, Slice or Map. Return unSet if not known. - ContainerType() (vt valueType) - IsBuiltinType(rt uintptr) bool - DecodeBuiltin(rt uintptr, v interface{}) - - // DecodeNaked will decode primitives (number, bool, string, []byte) and RawExt. - // For maps and arrays, it will not do the decoding in-band, but will signal - // the decoder, so that is done later, by setting the decNaked.valueType field. - // - // Note: Numbers are decoded as int64, uint64, float64 only (no smaller sized number types). - // for extensions, DecodeNaked must read the tag and the []byte if it exists. - // if the []byte is not read, then kInterfaceNaked will treat it as a Handle - // that stores the subsequent value in-band, and complete reading the RawExt. - // - // extensions should also use readx to decode them, for efficiency. - // kInterface will extract the detached byte slice if it has to pass it outside its realm. - DecodeNaked() - DecodeInt(bitsize uint8) (i int64) - DecodeUint(bitsize uint8) (ui uint64) - DecodeFloat(chkOverflow32 bool) (f float64) - DecodeBool() (b bool) - // DecodeString can also decode symbols. - // It looks redundant as DecodeBytes is available. - // However, some codecs (e.g. binc) support symbols and can - // return a pre-stored string value, meaning that it can bypass - // the cost of []byte->string conversion. - DecodeString() (s string) - - // DecodeBytes may be called directly, without going through reflection. - // Consequently, it must be designed to handle possible nil. - DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) - - // decodeExt will decode into a *RawExt or into an extension. - DecodeExt(v interface{}, xtag uint64, ext Ext) (realxtag uint64) - // decodeExt(verifyTag bool, tag byte) (xtag byte, xbs []byte) - ReadMapStart() int - ReadArrayStart() int - - reset() - uncacheRead() -} - -type decNoSeparator struct{} - -func (_ decNoSeparator) ReadEnd() {} -func (_ decNoSeparator) uncacheRead() {} - -type DecodeOptions struct { - // MapType specifies type to use during schema-less decoding of a map in the stream. - // If nil, we use map[interface{}]interface{} - MapType reflect.Type - - // SliceType specifies type to use during schema-less decoding of an array in the stream. - // If nil, we use []interface{} - SliceType reflect.Type - - // MaxInitLen defines the initial length that we "make" a collection (slice, chan or map) with. - // If 0 or negative, we default to a sensible value based on the size of an element in the collection. - // - // For example, when decoding, a stream may say that it has MAX_UINT elements. - // We should not auto-matically provision a slice of that length, to prevent Out-Of-Memory crash. - // Instead, we provision up to MaxInitLen, fill that up, and start appending after that. - MaxInitLen int - - // If ErrorIfNoField, return an error when decoding a map - // from a codec stream into a struct, and no matching struct field is found. - ErrorIfNoField bool - - // If ErrorIfNoArrayExpand, return an error when decoding a slice/array that cannot be expanded. - // For example, the stream contains an array of 8 items, but you are decoding into a [4]T array, - // or you are decoding into a slice of length 4 which is non-addressable (and so cannot be set). - ErrorIfNoArrayExpand bool - - // If SignedInteger, use the int64 during schema-less decoding of unsigned values (not uint64). - SignedInteger bool - - // MapValueReset controls how we decode into a map value. - // - // By default, we MAY retrieve the mapping for a key, and then decode into that. - // However, especially with big maps, that retrieval may be expensive and unnecessary - // if the stream already contains all that is necessary to recreate the value. - // - // If true, we will never retrieve the previous mapping, - // but rather decode into a new value and set that in the map. - // - // If false, we will retrieve the previous mapping if necessary e.g. - // the previous mapping is a pointer, or is a struct or array with pre-set state, - // or is an interface. - MapValueReset bool - - // InterfaceReset controls how we decode into an interface. - // - // By default, when we see a field that is an interface{...}, - // or a map with interface{...} value, we will attempt decoding into the - // "contained" value. - // - // However, this prevents us from reading a string into an interface{} - // that formerly contained a number. - // - // If true, we will decode into a new "blank" value, and set that in the interface. - // If false, we will decode into whatever is contained in the interface. - InterfaceReset bool - - // InternString controls interning of strings during decoding. - // - // Some handles, e.g. json, typically will read map keys as strings. - // If the set of keys are finite, it may help reduce allocation to - // look them up from a map (than to allocate them afresh). - // - // Note: Handles will be smart when using the intern functionality. - // So everything will not be interned. - InternString bool -} - -// ------------------------------------ - -// ioDecByteScanner implements Read(), ReadByte(...), UnreadByte(...) methods -// of io.Reader, io.ByteScanner. -type ioDecByteScanner struct { - r io.Reader - l byte // last byte - ls byte // last byte status. 0: init-canDoNothing, 1: canRead, 2: canUnread - b [1]byte // tiny buffer for reading single bytes -} - -func (z *ioDecByteScanner) Read(p []byte) (n int, err error) { - var firstByte bool - if z.ls == 1 { - z.ls = 2 - p[0] = z.l - if len(p) == 1 { - n = 1 - return - } - firstByte = true - p = p[1:] - } - n, err = z.r.Read(p) - if n > 0 { - if err == io.EOF && n == len(p) { - err = nil // read was successful, so postpone EOF (till next time) - } - z.l = p[n-1] - z.ls = 2 - } - if firstByte { - n++ - } - return -} - -func (z *ioDecByteScanner) ReadByte() (c byte, err error) { - n, err := z.Read(z.b[:]) - if n == 1 { - c = z.b[0] - if err == io.EOF { - err = nil // read was successful, so postpone EOF (till next time) - } - } - return -} - -func (z *ioDecByteScanner) UnreadByte() (err error) { - x := z.ls - if x == 0 { - err = errors.New("cannot unread - nothing has been read") - } else if x == 1 { - err = errors.New("cannot unread - last byte has not been read") - } else if x == 2 { - z.ls = 1 - } - return -} - -// ioDecReader is a decReader that reads off an io.Reader -type ioDecReader struct { - br decReaderByteScanner - // temp byte array re-used internally for efficiency during read. - // shares buffer with Decoder, so we keep size of struct within 8 words. - x *[scratchByteArrayLen]byte - bs ioDecByteScanner - n int // num read - tr []byte // tracking bytes read - trb bool -} - -func (z *ioDecReader) numread() int { - return z.n -} - -func (z *ioDecReader) readx(n int) (bs []byte) { - if n <= 0 { - return - } - if n < len(z.x) { - bs = z.x[:n] - } else { - bs = make([]byte, n) - } - if _, err := io.ReadAtLeast(z.br, bs, n); err != nil { - panic(err) - } - z.n += len(bs) - if z.trb { - z.tr = append(z.tr, bs...) - } - return -} - -func (z *ioDecReader) readb(bs []byte) { - if len(bs) == 0 { - return - } - n, err := io.ReadAtLeast(z.br, bs, len(bs)) - z.n += n - if err != nil { - panic(err) - } - if z.trb { - z.tr = append(z.tr, bs...) - } -} - -func (z *ioDecReader) readn1() (b uint8) { - b, err := z.br.ReadByte() - if err != nil { - panic(err) - } - z.n++ - if z.trb { - z.tr = append(z.tr, b) - } - return b -} - -func (z *ioDecReader) readn1eof() (b uint8, eof bool) { - b, err := z.br.ReadByte() - if err == nil { - z.n++ - if z.trb { - z.tr = append(z.tr, b) - } - } else if err == io.EOF { - eof = true - } else { - panic(err) - } - return -} - -func (z *ioDecReader) unreadn1() { - err := z.br.UnreadByte() - if err != nil { - panic(err) - } - z.n-- - if z.trb { - if l := len(z.tr) - 1; l >= 0 { - z.tr = z.tr[:l] - } - } -} - -func (z *ioDecReader) track() { - if z.tr != nil { - z.tr = z.tr[:0] - } - z.trb = true -} - -func (z *ioDecReader) stopTrack() (bs []byte) { - z.trb = false - return z.tr -} - -// ------------------------------------ - -var bytesDecReaderCannotUnreadErr = errors.New("cannot unread last byte read") - -// bytesDecReader is a decReader that reads off a byte slice with zero copying -type bytesDecReader struct { - b []byte // data - c int // cursor - a int // available - t int // track start -} - -func (z *bytesDecReader) reset(in []byte) { - z.b = in - z.a = len(in) - z.c = 0 - z.t = 0 -} - -func (z *bytesDecReader) numread() int { - return z.c -} - -func (z *bytesDecReader) unreadn1() { - if z.c == 0 || len(z.b) == 0 { - panic(bytesDecReaderCannotUnreadErr) - } - z.c-- - z.a++ - return -} - -func (z *bytesDecReader) readx(n int) (bs []byte) { - // slicing from a non-constant start position is more expensive, - // as more computation is required to decipher the pointer start position. - // However, we do it only once, and it's better than reslicing both z.b and return value. - - if n <= 0 { - } else if z.a == 0 { - panic(io.EOF) - } else if n > z.a { - panic(io.ErrUnexpectedEOF) - } else { - c0 := z.c - z.c = c0 + n - z.a = z.a - n - bs = z.b[c0:z.c] - } - return -} - -func (z *bytesDecReader) readn1() (v uint8) { - if z.a == 0 { - panic(io.EOF) - } - v = z.b[z.c] - z.c++ - z.a-- - return -} - -func (z *bytesDecReader) readn1eof() (v uint8, eof bool) { - if z.a == 0 { - eof = true - return - } - v = z.b[z.c] - z.c++ - z.a-- - return -} - -func (z *bytesDecReader) readb(bs []byte) { - copy(bs, z.readx(len(bs))) -} - -func (z *bytesDecReader) track() { - z.t = z.c -} - -func (z *bytesDecReader) stopTrack() (bs []byte) { - return z.b[z.t:z.c] -} - -// ------------------------------------ - -type decFnInfo struct { - d *Decoder - ti *typeInfo - xfFn Ext - xfTag uint64 - seq seqType -} - -// ---------------------------------------- - -type decFn struct { - i decFnInfo - f func(*decFnInfo, reflect.Value) -} - -func (f *decFnInfo) builtin(rv reflect.Value) { - f.d.d.DecodeBuiltin(f.ti.rtid, rv.Addr().Interface()) -} - -func (f *decFnInfo) rawExt(rv reflect.Value) { - f.d.d.DecodeExt(rv.Addr().Interface(), 0, nil) -} - -func (f *decFnInfo) ext(rv reflect.Value) { - f.d.d.DecodeExt(rv.Addr().Interface(), f.xfTag, f.xfFn) -} - -func (f *decFnInfo) getValueForUnmarshalInterface(rv reflect.Value, indir int8) (v interface{}) { - if indir == -1 { - v = rv.Addr().Interface() - } else if indir == 0 { - v = rv.Interface() - } else { - for j := int8(0); j < indir; j++ { - if rv.IsNil() { - rv.Set(reflect.New(rv.Type().Elem())) - } - rv = rv.Elem() - } - v = rv.Interface() - } - return -} - -func (f *decFnInfo) selferUnmarshal(rv reflect.Value) { - f.getValueForUnmarshalInterface(rv, f.ti.csIndir).(Selfer).CodecDecodeSelf(f.d) -} - -func (f *decFnInfo) binaryUnmarshal(rv reflect.Value) { - bm := f.getValueForUnmarshalInterface(rv, f.ti.bunmIndir).(encoding.BinaryUnmarshaler) - xbs := f.d.d.DecodeBytes(nil, false, true) - if fnerr := bm.UnmarshalBinary(xbs); fnerr != nil { - panic(fnerr) - } -} - -func (f *decFnInfo) textUnmarshal(rv reflect.Value) { - tm := f.getValueForUnmarshalInterface(rv, f.ti.tunmIndir).(encoding.TextUnmarshaler) - fnerr := tm.UnmarshalText(f.d.d.DecodeBytes(f.d.b[:], true, true)) - if fnerr != nil { - panic(fnerr) - } -} - -func (f *decFnInfo) jsonUnmarshal(rv reflect.Value) { - tm := f.getValueForUnmarshalInterface(rv, f.ti.junmIndir).(jsonUnmarshaler) - // bs := f.d.d.DecodeBytes(f.d.b[:], true, true) - // grab the bytes to be read, as UnmarshalJSON needs the full JSON so as to unmarshal it itself. - fnerr := tm.UnmarshalJSON(f.d.nextValueBytes()) - if fnerr != nil { - panic(fnerr) - } -} - -func (f *decFnInfo) kErr(rv reflect.Value) { - f.d.errorf("no decoding function defined for kind %v", rv.Kind()) -} - -func (f *decFnInfo) kString(rv reflect.Value) { - rv.SetString(f.d.d.DecodeString()) -} - -func (f *decFnInfo) kBool(rv reflect.Value) { - rv.SetBool(f.d.d.DecodeBool()) -} - -func (f *decFnInfo) kInt(rv reflect.Value) { - rv.SetInt(f.d.d.DecodeInt(intBitsize)) -} - -func (f *decFnInfo) kInt64(rv reflect.Value) { - rv.SetInt(f.d.d.DecodeInt(64)) -} - -func (f *decFnInfo) kInt32(rv reflect.Value) { - rv.SetInt(f.d.d.DecodeInt(32)) -} - -func (f *decFnInfo) kInt8(rv reflect.Value) { - rv.SetInt(f.d.d.DecodeInt(8)) -} - -func (f *decFnInfo) kInt16(rv reflect.Value) { - rv.SetInt(f.d.d.DecodeInt(16)) -} - -func (f *decFnInfo) kFloat32(rv reflect.Value) { - rv.SetFloat(f.d.d.DecodeFloat(true)) -} - -func (f *decFnInfo) kFloat64(rv reflect.Value) { - rv.SetFloat(f.d.d.DecodeFloat(false)) -} - -func (f *decFnInfo) kUint8(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(8)) -} - -func (f *decFnInfo) kUint64(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(64)) -} - -func (f *decFnInfo) kUint(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(uintBitsize)) -} - -func (f *decFnInfo) kUintptr(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(uintBitsize)) -} - -func (f *decFnInfo) kUint32(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(32)) -} - -func (f *decFnInfo) kUint16(rv reflect.Value) { - rv.SetUint(f.d.d.DecodeUint(16)) -} - -// func (f *decFnInfo) kPtr(rv reflect.Value) { -// debugf(">>>>>>> ??? decode kPtr called - shouldn't get called") -// if rv.IsNil() { -// rv.Set(reflect.New(rv.Type().Elem())) -// } -// f.d.decodeValue(rv.Elem()) -// } - -// var kIntfCtr uint64 - -func (f *decFnInfo) kInterfaceNaked() (rvn reflect.Value) { - // nil interface: - // use some hieristics to decode it appropriately - // based on the detected next value in the stream. - d := f.d - d.d.DecodeNaked() - n := &d.n - if n.v == valueTypeNil { - return - } - // We cannot decode non-nil stream value into nil interface with methods (e.g. io.Reader). - // if num := f.ti.rt.NumMethod(); num > 0 { - if f.ti.numMeth > 0 { - d.errorf("cannot decode non-nil codec value into nil %v (%v methods)", f.ti.rt, f.ti.numMeth) - return - } - // var useRvn bool - switch n.v { - case valueTypeMap: - // if d.h.MapType == nil || d.h.MapType == mapIntfIntfTyp { - // } else if d.h.MapType == mapStrIntfTyp { // for json performance - // } - if d.mtid == 0 || d.mtid == mapIntfIntfTypId { - l := len(n.ms) - n.ms = append(n.ms, nil) - d.decode(&n.ms[l]) - rvn = reflect.ValueOf(&n.ms[l]).Elem() - n.ms = n.ms[:l] - } else if d.mtid == mapStrIntfTypId { // for json performance - l := len(n.ns) - n.ns = append(n.ns, nil) - d.decode(&n.ns[l]) - rvn = reflect.ValueOf(&n.ns[l]).Elem() - n.ns = n.ns[:l] - } else { - rvn = reflect.New(d.h.MapType).Elem() - d.decodeValue(rvn, nil) - } - case valueTypeArray: - // if d.h.SliceType == nil || d.h.SliceType == intfSliceTyp { - if d.stid == 0 || d.stid == intfSliceTypId { - l := len(n.ss) - n.ss = append(n.ss, nil) - d.decode(&n.ss[l]) - rvn = reflect.ValueOf(&n.ss[l]).Elem() - n.ss = n.ss[:l] - } else { - rvn = reflect.New(d.h.SliceType).Elem() - d.decodeValue(rvn, nil) - } - case valueTypeExt: - var v interface{} - tag, bytes := n.u, n.l // calling decode below might taint the values - if bytes == nil { - l := len(n.is) - n.is = append(n.is, nil) - v2 := &n.is[l] - n.is = n.is[:l] - d.decode(v2) - v = *v2 - } - bfn := d.h.getExtForTag(tag) - if bfn == nil { - var re RawExt - re.Tag = tag - re.Data = detachZeroCopyBytes(d.bytes, nil, bytes) - rvn = reflect.ValueOf(re) - } else { - rvnA := reflect.New(bfn.rt) - rvn = rvnA.Elem() - if bytes != nil { - bfn.ext.ReadExt(rvnA.Interface(), bytes) - } else { - bfn.ext.UpdateExt(rvnA.Interface(), v) - } - } - case valueTypeNil: - // no-op - case valueTypeInt: - rvn = reflect.ValueOf(&n.i).Elem() - case valueTypeUint: - rvn = reflect.ValueOf(&n.u).Elem() - case valueTypeFloat: - rvn = reflect.ValueOf(&n.f).Elem() - case valueTypeBool: - rvn = reflect.ValueOf(&n.b).Elem() - case valueTypeString, valueTypeSymbol: - rvn = reflect.ValueOf(&n.s).Elem() - case valueTypeBytes: - rvn = reflect.ValueOf(&n.l).Elem() - case valueTypeTimestamp: - rvn = reflect.ValueOf(&n.t).Elem() - default: - panic(fmt.Errorf("kInterfaceNaked: unexpected valueType: %d", n.v)) - } - return -} - -func (f *decFnInfo) kInterface(rv reflect.Value) { - // debugf("\t===> kInterface") - - // Note: - // A consequence of how kInterface works, is that - // if an interface already contains something, we try - // to decode into what was there before. - // We do not replace with a generic value (as got from decodeNaked). - - var rvn reflect.Value - if rv.IsNil() { - rvn = f.kInterfaceNaked() - if rvn.IsValid() { - rv.Set(rvn) - } - } else if f.d.h.InterfaceReset { - rvn = f.kInterfaceNaked() - if rvn.IsValid() { - rv.Set(rvn) - } else { - // reset to zero value based on current type in there. - rv.Set(reflect.Zero(rv.Elem().Type())) - } - } else { - rvn = rv.Elem() - // Note: interface{} is settable, but underlying type may not be. - // Consequently, we have to set the reflect.Value directly. - // if underlying type is settable (e.g. ptr or interface), - // we just decode into it. - // Else we create a settable value, decode into it, and set on the interface. - if rvn.CanSet() { - f.d.decodeValue(rvn, nil) - } else { - rvn2 := reflect.New(rvn.Type()).Elem() - rvn2.Set(rvn) - f.d.decodeValue(rvn2, nil) - rv.Set(rvn2) - } - } -} - -func (f *decFnInfo) kStruct(rv reflect.Value) { - fti := f.ti - d := f.d - dd := d.d - cr := d.cr - ctyp := dd.ContainerType() - if ctyp == valueTypeMap { - containerLen := dd.ReadMapStart() - if containerLen == 0 { - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return - } - tisfi := fti.sfi - hasLen := containerLen >= 0 - if hasLen { - for j := 0; j < containerLen; j++ { - // rvkencname := dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapKey) - } - rvkencname := stringView(dd.DecodeBytes(f.d.b[:], true, true)) - // rvksi := ti.getForEncName(rvkencname) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if k := fti.indexForEncName(rvkencname); k > -1 { - si := tisfi[k] - if dd.TryDecodeAsNil() { - si.setToZeroValue(rv) - } else { - d.decodeValue(si.field(rv, true), nil) - } - } else { - d.structFieldNotFound(-1, rvkencname) - } - } - } else { - for j := 0; !dd.CheckBreak(); j++ { - // rvkencname := dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapKey) - } - rvkencname := stringView(dd.DecodeBytes(f.d.b[:], true, true)) - // rvksi := ti.getForEncName(rvkencname) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if k := fti.indexForEncName(rvkencname); k > -1 { - si := tisfi[k] - if dd.TryDecodeAsNil() { - si.setToZeroValue(rv) - } else { - d.decodeValue(si.field(rv, true), nil) - } - } else { - d.structFieldNotFound(-1, rvkencname) - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - } else if ctyp == valueTypeArray { - containerLen := dd.ReadArrayStart() - if containerLen == 0 { - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } - return - } - // Not much gain from doing it two ways for array. - // Arrays are not used as much for structs. - hasLen := containerLen >= 0 - for j, si := range fti.sfip { - if hasLen { - if j == containerLen { - break - } - } else if dd.CheckBreak() { - break - } - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - if dd.TryDecodeAsNil() { - si.setToZeroValue(rv) - } else { - d.decodeValue(si.field(rv, true), nil) - } - } - if containerLen > len(fti.sfip) { - // read remaining values and throw away - for j := len(fti.sfip); j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - d.structFieldNotFound(j, "") - } - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } - } else { - f.d.error(onlyMapOrArrayCanDecodeIntoStructErr) - return - } -} - -func (f *decFnInfo) kSlice(rv reflect.Value) { - // A slice can be set from a map or array in stream. - // This way, the order can be kept (as order is lost with map). - ti := f.ti - d := f.d - dd := d.d - rtelem0 := ti.rt.Elem() - ctyp := dd.ContainerType() - if ctyp == valueTypeBytes || ctyp == valueTypeString { - // you can only decode bytes or string in the stream into a slice or array of bytes - if !(ti.rtid == uint8SliceTypId || rtelem0.Kind() == reflect.Uint8) { - f.d.errorf("bytes or string in the stream must be decoded into a slice or array of bytes, not %v", ti.rt) - } - if f.seq == seqTypeChan { - bs2 := dd.DecodeBytes(nil, false, true) - ch := rv.Interface().(chan<- byte) - for _, b := range bs2 { - ch <- b - } - } else { - rvbs := rv.Bytes() - bs2 := dd.DecodeBytes(rvbs, false, false) - if rvbs == nil && bs2 != nil || rvbs != nil && bs2 == nil || len(bs2) != len(rvbs) { - if rv.CanSet() { - rv.SetBytes(bs2) - } else { - copy(rvbs, bs2) - } - } - } - return - } - - // array := f.seq == seqTypeChan - - slh, containerLenS := d.decSliceHelperStart() // only expects valueType(Array|Map) - - // // an array can never return a nil slice. so no need to check f.array here. - if containerLenS == 0 { - if f.seq == seqTypeSlice { - if rv.IsNil() { - rv.Set(reflect.MakeSlice(ti.rt, 0, 0)) - } else { - rv.SetLen(0) - } - } else if f.seq == seqTypeChan { - if rv.IsNil() { - rv.Set(reflect.MakeChan(ti.rt, 0)) - } - } - slh.End() - return - } - - rtelem := rtelem0 - for rtelem.Kind() == reflect.Ptr { - rtelem = rtelem.Elem() - } - fn := d.getDecFn(rtelem, true, true) - - var rv0, rv9 reflect.Value - rv0 = rv - rvChanged := false - - // for j := 0; j < containerLenS; j++ { - var rvlen int - if containerLenS > 0 { // hasLen - if f.seq == seqTypeChan { - if rv.IsNil() { - rvlen, _ = decInferLen(containerLenS, f.d.h.MaxInitLen, int(rtelem0.Size())) - rv.Set(reflect.MakeChan(ti.rt, rvlen)) - } - // handle chan specially: - for j := 0; j < containerLenS; j++ { - rv9 = reflect.New(rtelem0).Elem() - slh.ElemContainerState(j) - d.decodeValue(rv9, fn) - rv.Send(rv9) - } - } else { // slice or array - var truncated bool // says len of sequence is not same as expected number of elements - numToRead := containerLenS // if truncated, reset numToRead - - rvcap := rv.Cap() - rvlen = rv.Len() - if containerLenS > rvcap { - if f.seq == seqTypeArray { - d.arrayCannotExpand(rvlen, containerLenS) - } else { - oldRvlenGtZero := rvlen > 0 - rvlen, truncated = decInferLen(containerLenS, f.d.h.MaxInitLen, int(rtelem0.Size())) - if truncated { - if rvlen <= rvcap { - rv.SetLen(rvlen) - } else { - rv = reflect.MakeSlice(ti.rt, rvlen, rvlen) - rvChanged = true - } - } else { - rv = reflect.MakeSlice(ti.rt, rvlen, rvlen) - rvChanged = true - } - if rvChanged && oldRvlenGtZero && !isImmutableKind(rtelem0.Kind()) { - reflect.Copy(rv, rv0) // only copy up to length NOT cap i.e. rv0.Slice(0, rvcap) - } - rvcap = rvlen - } - numToRead = rvlen - } else if containerLenS != rvlen { - if f.seq == seqTypeSlice { - rv.SetLen(containerLenS) - rvlen = containerLenS - } - } - j := 0 - // we read up to the numToRead - for ; j < numToRead; j++ { - slh.ElemContainerState(j) - d.decodeValue(rv.Index(j), fn) - } - - // if slice, expand and read up to containerLenS (or EOF) iff truncated - // if array, swallow all the rest. - - if f.seq == seqTypeArray { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } else if truncated { // slice was truncated, as chan NOT in this block - for ; j < containerLenS; j++ { - rv = expandSliceValue(rv, 1) - rv9 = rv.Index(j) - if resetSliceElemToZeroValue { - rv9.Set(reflect.Zero(rtelem0)) - } - slh.ElemContainerState(j) - d.decodeValue(rv9, fn) - } - } - } - } else { - rvlen = rv.Len() - j := 0 - for ; !dd.CheckBreak(); j++ { - if f.seq == seqTypeChan { - slh.ElemContainerState(j) - rv9 = reflect.New(rtelem0).Elem() - d.decodeValue(rv9, fn) - rv.Send(rv9) - } else { - // if indefinite, etc, then expand the slice if necessary - var decodeIntoBlank bool - if j >= rvlen { - if f.seq == seqTypeArray { - d.arrayCannotExpand(rvlen, j+1) - decodeIntoBlank = true - } else { // if f.seq == seqTypeSlice - // rv = reflect.Append(rv, reflect.Zero(rtelem0)) // uses append logic, plus varargs - rv = expandSliceValue(rv, 1) - rv9 = rv.Index(j) - // rv.Index(rv.Len() - 1).Set(reflect.Zero(rtelem0)) - if resetSliceElemToZeroValue { - rv9.Set(reflect.Zero(rtelem0)) - } - rvlen++ - rvChanged = true - } - } else { // slice or array - rv9 = rv.Index(j) - } - slh.ElemContainerState(j) - if decodeIntoBlank { - d.swallow() - } else { // seqTypeSlice - d.decodeValue(rv9, fn) - } - } - } - if f.seq == seqTypeSlice { - if j < rvlen { - rv.SetLen(j) - } else if j == 0 && rv.IsNil() { - rv = reflect.MakeSlice(ti.rt, 0, 0) - rvChanged = true - } - } - } - slh.End() - - if rvChanged { - rv0.Set(rv) - } -} - -func (f *decFnInfo) kArray(rv reflect.Value) { - // f.d.decodeValue(rv.Slice(0, rv.Len())) - f.kSlice(rv.Slice(0, rv.Len())) -} - -func (f *decFnInfo) kMap(rv reflect.Value) { - d := f.d - dd := d.d - containerLen := dd.ReadMapStart() - cr := d.cr - ti := f.ti - if rv.IsNil() { - rv.Set(reflect.MakeMap(ti.rt)) - } - - if containerLen == 0 { - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return - } - - ktype, vtype := ti.rt.Key(), ti.rt.Elem() - ktypeId := reflect.ValueOf(ktype).Pointer() - vtypeKind := vtype.Kind() - var keyFn, valFn *decFn - var xtyp reflect.Type - for xtyp = ktype; xtyp.Kind() == reflect.Ptr; xtyp = xtyp.Elem() { - } - keyFn = d.getDecFn(xtyp, true, true) - for xtyp = vtype; xtyp.Kind() == reflect.Ptr; xtyp = xtyp.Elem() { - } - valFn = d.getDecFn(xtyp, true, true) - var mapGet, mapSet bool - if !f.d.h.MapValueReset { - // if pointer, mapGet = true - // if interface, mapGet = true if !DecodeNakedAlways (else false) - // if builtin, mapGet = false - // else mapGet = true - if vtypeKind == reflect.Ptr { - mapGet = true - } else if vtypeKind == reflect.Interface { - if !f.d.h.InterfaceReset { - mapGet = true - } - } else if !isImmutableKind(vtypeKind) { - mapGet = true - } - } - - var rvk, rvv, rvz reflect.Value - - // for j := 0; j < containerLen; j++ { - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - rvk = reflect.New(ktype).Elem() - if cr != nil { - cr.sendContainerState(containerMapKey) - } - d.decodeValue(rvk, keyFn) - - // special case if a byte array. - if ktypeId == intfTypId { - rvk = rvk.Elem() - if rvk.Type() == uint8SliceTyp { - rvk = reflect.ValueOf(d.string(rvk.Bytes())) - } - } - mapSet = true // set to false if u do a get, and its a pointer, and exists - if mapGet { - rvv = rv.MapIndex(rvk) - if rvv.IsValid() { - if vtypeKind == reflect.Ptr { - mapSet = false - } - } else { - if rvz.IsValid() { - rvz.Set(reflect.Zero(vtype)) - } else { - rvz = reflect.New(vtype).Elem() - } - rvv = rvz - } - } else { - if rvz.IsValid() { - rvz.Set(reflect.Zero(vtype)) - } else { - rvz = reflect.New(vtype).Elem() - } - rvv = rvz - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - d.decodeValue(rvv, valFn) - if mapSet { - rv.SetMapIndex(rvk, rvv) - } - } - } else { - for j := 0; !dd.CheckBreak(); j++ { - rvk = reflect.New(ktype).Elem() - if cr != nil { - cr.sendContainerState(containerMapKey) - } - d.decodeValue(rvk, keyFn) - - // special case if a byte array. - if ktypeId == intfTypId { - rvk = rvk.Elem() - if rvk.Type() == uint8SliceTyp { - rvk = reflect.ValueOf(d.string(rvk.Bytes())) - } - } - mapSet = true // set to false if u do a get, and its a pointer, and exists - if mapGet { - rvv = rv.MapIndex(rvk) - if rvv.IsValid() { - if vtypeKind == reflect.Ptr { - mapSet = false - } - } else { - if rvz.IsValid() { - rvz.Set(reflect.Zero(vtype)) - } else { - rvz = reflect.New(vtype).Elem() - } - rvv = rvz - } - } else { - if rvz.IsValid() { - rvz.Set(reflect.Zero(vtype)) - } else { - rvz = reflect.New(vtype).Elem() - } - rvv = rvz - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - d.decodeValue(rvv, valFn) - if mapSet { - rv.SetMapIndex(rvk, rvv) - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -type decRtidFn struct { - rtid uintptr - fn decFn -} - -// decNaked is used to keep track of the primitives decoded. -// Without it, we would have to decode each primitive and wrap it -// in an interface{}, causing an allocation. -// In this model, the primitives are decoded in a "pseudo-atomic" fashion, -// so we can rest assured that no other decoding happens while these -// primitives are being decoded. -// -// maps and arrays are not handled by this mechanism. -// However, RawExt is, and we accomodate for extensions that decode -// RawExt from DecodeNaked, but need to decode the value subsequently. -// kInterfaceNaked and swallow, which call DecodeNaked, handle this caveat. -// -// However, decNaked also keeps some arrays of default maps and slices -// used in DecodeNaked. This way, we can get a pointer to it -// without causing a new heap allocation. -// -// kInterfaceNaked will ensure that there is no allocation for the common -// uses. -type decNaked struct { - // r RawExt // used for RawExt, uint, []byte. - u uint64 - i int64 - f float64 - l []byte - s string - t time.Time - b bool - v valueType - - // stacks for reducing allocation - is []interface{} - ms []map[interface{}]interface{} - ns []map[string]interface{} - ss [][]interface{} - // rs []RawExt - - // keep arrays at the bottom? Chance is that they are not used much. - ia [4]interface{} - ma [4]map[interface{}]interface{} - na [4]map[string]interface{} - sa [4][]interface{} - // ra [2]RawExt -} - -func (n *decNaked) reset() { - if n.ss != nil { - n.ss = n.ss[:0] - } - if n.is != nil { - n.is = n.is[:0] - } - if n.ms != nil { - n.ms = n.ms[:0] - } - if n.ns != nil { - n.ns = n.ns[:0] - } -} - -// A Decoder reads and decodes an object from an input stream in the codec format. -type Decoder struct { - // hopefully, reduce derefencing cost by laying the decReader inside the Decoder. - // Try to put things that go together to fit within a cache line (8 words). - - d decDriver - // NOTE: Decoder shouldn't call it's read methods, - // as the handler MAY need to do some coordination. - r decReader - // sa [initCollectionCap]decRtidFn - h *BasicHandle - hh Handle - - be bool // is binary encoding - bytes bool // is bytes reader - js bool // is json handle - - rb bytesDecReader - ri ioDecReader - cr containerStateRecv - - s []decRtidFn - f map[uintptr]*decFn - - // _ uintptr // for alignment purposes, so next one starts from a cache line - - // cache the mapTypeId and sliceTypeId for faster comparisons - mtid uintptr - stid uintptr - - n decNaked - b [scratchByteArrayLen]byte - is map[string]string // used for interning strings -} - -// NewDecoder returns a Decoder for decoding a stream of bytes from an io.Reader. -// -// For efficiency, Users are encouraged to pass in a memory buffered reader -// (eg bufio.Reader, bytes.Buffer). -func NewDecoder(r io.Reader, h Handle) *Decoder { - d := newDecoder(h) - d.Reset(r) - return d -} - -// NewDecoderBytes returns a Decoder which efficiently decodes directly -// from a byte slice with zero copying. -func NewDecoderBytes(in []byte, h Handle) *Decoder { - d := newDecoder(h) - d.ResetBytes(in) - return d -} - -func newDecoder(h Handle) *Decoder { - d := &Decoder{hh: h, h: h.getBasicHandle(), be: h.isBinary()} - n := &d.n - // n.rs = n.ra[:0] - n.ms = n.ma[:0] - n.is = n.ia[:0] - n.ns = n.na[:0] - n.ss = n.sa[:0] - _, d.js = h.(*JsonHandle) - if d.h.InternString { - d.is = make(map[string]string, 32) - } - d.d = h.newDecDriver(d) - d.cr, _ = d.d.(containerStateRecv) - // d.d = h.newDecDriver(decReaderT{true, &d.rb, &d.ri}) - return d -} - -func (d *Decoder) resetCommon() { - d.n.reset() - d.d.reset() - // reset all things which were cached from the Handle, - // but could be changed. - d.mtid, d.stid = 0, 0 - if d.h.MapType != nil { - d.mtid = reflect.ValueOf(d.h.MapType).Pointer() - } - if d.h.SliceType != nil { - d.stid = reflect.ValueOf(d.h.SliceType).Pointer() - } -} - -func (d *Decoder) Reset(r io.Reader) { - d.ri.x = &d.b - // d.s = d.sa[:0] - d.ri.bs.r = r - var ok bool - d.ri.br, ok = r.(decReaderByteScanner) - if !ok { - d.ri.br = &d.ri.bs - } - d.r = &d.ri - d.resetCommon() -} - -func (d *Decoder) ResetBytes(in []byte) { - // d.s = d.sa[:0] - d.rb.reset(in) - d.r = &d.rb - d.resetCommon() -} - -// func (d *Decoder) sendContainerState(c containerState) { -// if d.cr != nil { -// d.cr.sendContainerState(c) -// } -// } - -// Decode decodes the stream from reader and stores the result in the -// value pointed to by v. v cannot be a nil pointer. v can also be -// a reflect.Value of a pointer. -// -// Note that a pointer to a nil interface is not a nil pointer. -// If you do not know what type of stream it is, pass in a pointer to a nil interface. -// We will decode and store a value in that nil interface. -// -// Sample usages: -// // Decoding into a non-nil typed value -// var f float32 -// err = codec.NewDecoder(r, handle).Decode(&f) -// -// // Decoding into nil interface -// var v interface{} -// dec := codec.NewDecoder(r, handle) -// err = dec.Decode(&v) -// -// When decoding into a nil interface{}, we will decode into an appropriate value based -// on the contents of the stream: -// - Numbers are decoded as float64, int64 or uint64. -// - Other values are decoded appropriately depending on the type: -// bool, string, []byte, time.Time, etc -// - Extensions are decoded as RawExt (if no ext function registered for the tag) -// Configurations exist on the Handle to override defaults -// (e.g. for MapType, SliceType and how to decode raw bytes). -// -// When decoding into a non-nil interface{} value, the mode of encoding is based on the -// type of the value. When a value is seen: -// - If an extension is registered for it, call that extension function -// - If it implements BinaryUnmarshaler, call its UnmarshalBinary(data []byte) error -// - Else decode it based on its reflect.Kind -// -// There are some special rules when decoding into containers (slice/array/map/struct). -// Decode will typically use the stream contents to UPDATE the container. -// - A map can be decoded from a stream map, by updating matching keys. -// - A slice can be decoded from a stream array, -// by updating the first n elements, where n is length of the stream. -// - A slice can be decoded from a stream map, by decoding as if -// it contains a sequence of key-value pairs. -// - A struct can be decoded from a stream map, by updating matching fields. -// - A struct can be decoded from a stream array, -// by updating fields as they occur in the struct (by index). -// -// When decoding a stream map or array with length of 0 into a nil map or slice, -// we reset the destination map or slice to a zero-length value. -// -// However, when decoding a stream nil, we reset the destination container -// to its "zero" value (e.g. nil for slice/map, etc). -// -func (d *Decoder) Decode(v interface{}) (err error) { - defer panicToErr(&err) - d.decode(v) - return -} - -// this is not a smart swallow, as it allocates objects and does unnecessary work. -func (d *Decoder) swallowViaHammer() { - var blank interface{} - d.decodeValue(reflect.ValueOf(&blank).Elem(), nil) -} - -func (d *Decoder) swallow() { - // smarter decode that just swallows the content - dd := d.d - if dd.TryDecodeAsNil() { - return - } - cr := d.cr - switch dd.ContainerType() { - case valueTypeMap: - containerLen := dd.ReadMapStart() - clenGtEqualZero := containerLen >= 0 - for j := 0; ; j++ { - if clenGtEqualZero { - if j >= containerLen { - break - } - } else if dd.CheckBreak() { - break - } - if cr != nil { - cr.sendContainerState(containerMapKey) - } - d.swallow() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - d.swallow() - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - case valueTypeArray: - containerLenS := dd.ReadArrayStart() - clenGtEqualZero := containerLenS >= 0 - for j := 0; ; j++ { - if clenGtEqualZero { - if j >= containerLenS { - break - } - } else if dd.CheckBreak() { - break - } - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - d.swallow() - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } - case valueTypeBytes: - dd.DecodeBytes(d.b[:], false, true) - case valueTypeString: - dd.DecodeBytes(d.b[:], true, true) - // dd.DecodeStringAsBytes(d.b[:]) - default: - // these are all primitives, which we can get from decodeNaked - // if RawExt using Value, complete the processing. - dd.DecodeNaked() - if n := &d.n; n.v == valueTypeExt && n.l == nil { - l := len(n.is) - n.is = append(n.is, nil) - v2 := &n.is[l] - n.is = n.is[:l] - d.decode(v2) - } - } -} - -// MustDecode is like Decode, but panics if unable to Decode. -// This provides insight to the code location that triggered the error. -func (d *Decoder) MustDecode(v interface{}) { - d.decode(v) -} - -func (d *Decoder) decode(iv interface{}) { - // if ics, ok := iv.(Selfer); ok { - // ics.CodecDecodeSelf(d) - // return - // } - - if d.d.TryDecodeAsNil() { - switch v := iv.(type) { - case nil: - case *string: - *v = "" - case *bool: - *v = false - case *int: - *v = 0 - case *int8: - *v = 0 - case *int16: - *v = 0 - case *int32: - *v = 0 - case *int64: - *v = 0 - case *uint: - *v = 0 - case *uint8: - *v = 0 - case *uint16: - *v = 0 - case *uint32: - *v = 0 - case *uint64: - *v = 0 - case *float32: - *v = 0 - case *float64: - *v = 0 - case *[]uint8: - *v = nil - case reflect.Value: - if v.Kind() != reflect.Ptr || v.IsNil() { - d.errNotValidPtrValue(v) - } - // d.chkPtrValue(v) - v = v.Elem() - if v.IsValid() { - v.Set(reflect.Zero(v.Type())) - } - default: - rv := reflect.ValueOf(iv) - if rv.Kind() != reflect.Ptr || rv.IsNil() { - d.errNotValidPtrValue(rv) - } - // d.chkPtrValue(rv) - rv = rv.Elem() - if rv.IsValid() { - rv.Set(reflect.Zero(rv.Type())) - } - } - return - } - - switch v := iv.(type) { - case nil: - d.error(cannotDecodeIntoNilErr) - return - - case Selfer: - v.CodecDecodeSelf(d) - - case reflect.Value: - if v.Kind() != reflect.Ptr || v.IsNil() { - d.errNotValidPtrValue(v) - } - // d.chkPtrValue(v) - d.decodeValueNotNil(v.Elem(), nil) - - case *string: - - *v = d.d.DecodeString() - case *bool: - *v = d.d.DecodeBool() - case *int: - *v = int(d.d.DecodeInt(intBitsize)) - case *int8: - *v = int8(d.d.DecodeInt(8)) - case *int16: - *v = int16(d.d.DecodeInt(16)) - case *int32: - *v = int32(d.d.DecodeInt(32)) - case *int64: - *v = d.d.DecodeInt(64) - case *uint: - *v = uint(d.d.DecodeUint(uintBitsize)) - case *uint8: - *v = uint8(d.d.DecodeUint(8)) - case *uint16: - *v = uint16(d.d.DecodeUint(16)) - case *uint32: - *v = uint32(d.d.DecodeUint(32)) - case *uint64: - *v = d.d.DecodeUint(64) - case *float32: - *v = float32(d.d.DecodeFloat(true)) - case *float64: - *v = d.d.DecodeFloat(false) - case *[]uint8: - *v = d.d.DecodeBytes(*v, false, false) - - case *interface{}: - d.decodeValueNotNil(reflect.ValueOf(iv).Elem(), nil) - - default: - if !fastpathDecodeTypeSwitch(iv, d) { - d.decodeI(iv, true, false, false, false) - } - } -} - -func (d *Decoder) preDecodeValue(rv reflect.Value, tryNil bool) (rv2 reflect.Value, proceed bool) { - if tryNil && d.d.TryDecodeAsNil() { - // No need to check if a ptr, recursively, to determine - // whether to set value to nil. - // Just always set value to its zero type. - if rv.IsValid() { // rv.CanSet() // always settable, except it's invalid - rv.Set(reflect.Zero(rv.Type())) - } - return - } - - // If stream is not containing a nil value, then we can deref to the base - // non-pointer value, and decode into that. - for rv.Kind() == reflect.Ptr { - if rv.IsNil() { - rv.Set(reflect.New(rv.Type().Elem())) - } - rv = rv.Elem() - } - return rv, true -} - -func (d *Decoder) decodeI(iv interface{}, checkPtr, tryNil, checkFastpath, checkCodecSelfer bool) { - rv := reflect.ValueOf(iv) - if checkPtr { - if rv.Kind() != reflect.Ptr || rv.IsNil() { - d.errNotValidPtrValue(rv) - } - // d.chkPtrValue(rv) - } - rv, proceed := d.preDecodeValue(rv, tryNil) - if proceed { - fn := d.getDecFn(rv.Type(), checkFastpath, checkCodecSelfer) - fn.f(&fn.i, rv) - } -} - -func (d *Decoder) decodeValue(rv reflect.Value, fn *decFn) { - if rv, proceed := d.preDecodeValue(rv, true); proceed { - if fn == nil { - fn = d.getDecFn(rv.Type(), true, true) - } - fn.f(&fn.i, rv) - } -} - -func (d *Decoder) decodeValueNotNil(rv reflect.Value, fn *decFn) { - if rv, proceed := d.preDecodeValue(rv, false); proceed { - if fn == nil { - fn = d.getDecFn(rv.Type(), true, true) - } - fn.f(&fn.i, rv) - } -} - -func (d *Decoder) getDecFn(rt reflect.Type, checkFastpath, checkCodecSelfer bool) (fn *decFn) { - rtid := reflect.ValueOf(rt).Pointer() - - // retrieve or register a focus'ed function for this type - // to eliminate need to do the retrieval multiple times - - // if d.f == nil && d.s == nil { debugf("---->Creating new dec f map for type: %v\n", rt) } - var ok bool - if useMapForCodecCache { - fn, ok = d.f[rtid] - } else { - for i := range d.s { - v := &(d.s[i]) - if v.rtid == rtid { - fn, ok = &(v.fn), true - break - } - } - } - if ok { - return - } - - if useMapForCodecCache { - if d.f == nil { - d.f = make(map[uintptr]*decFn, initCollectionCap) - } - fn = new(decFn) - d.f[rtid] = fn - } else { - if d.s == nil { - d.s = make([]decRtidFn, 0, initCollectionCap) - } - d.s = append(d.s, decRtidFn{rtid: rtid}) - fn = &(d.s[len(d.s)-1]).fn - } - - // debugf("\tCreating new dec fn for type: %v\n", rt) - ti := d.h.getTypeInfo(rtid, rt) - fi := &(fn.i) - fi.d = d - fi.ti = ti - - // An extension can be registered for any type, regardless of the Kind - // (e.g. type BitSet int64, type MyStruct { / * unexported fields * / }, type X []int, etc. - // - // We can't check if it's an extension byte here first, because the user may have - // registered a pointer or non-pointer type, meaning we may have to recurse first - // before matching a mapped type, even though the extension byte is already detected. - // - // NOTE: if decoding into a nil interface{}, we return a non-nil - // value except even if the container registers a length of 0. - if checkCodecSelfer && ti.cs { - fn.f = (*decFnInfo).selferUnmarshal - } else if rtid == rawExtTypId { - fn.f = (*decFnInfo).rawExt - } else if d.d.IsBuiltinType(rtid) { - fn.f = (*decFnInfo).builtin - } else if xfFn := d.h.getExt(rtid); xfFn != nil { - fi.xfTag, fi.xfFn = xfFn.tag, xfFn.ext - fn.f = (*decFnInfo).ext - } else if supportMarshalInterfaces && d.be && ti.bunm { - fn.f = (*decFnInfo).binaryUnmarshal - } else if supportMarshalInterfaces && !d.be && d.js && ti.junm { - //If JSON, we should check JSONUnmarshal before textUnmarshal - fn.f = (*decFnInfo).jsonUnmarshal - } else if supportMarshalInterfaces && !d.be && ti.tunm { - fn.f = (*decFnInfo).textUnmarshal - } else { - rk := rt.Kind() - if fastpathEnabled && checkFastpath && (rk == reflect.Map || rk == reflect.Slice) { - if rt.PkgPath() == "" { - if idx := fastpathAV.index(rtid); idx != -1 { - fn.f = fastpathAV[idx].decfn - } - } else { - // use mapping for underlying type if there - ok = false - var rtu reflect.Type - if rk == reflect.Map { - rtu = reflect.MapOf(rt.Key(), rt.Elem()) - } else { - rtu = reflect.SliceOf(rt.Elem()) - } - rtuid := reflect.ValueOf(rtu).Pointer() - if idx := fastpathAV.index(rtuid); idx != -1 { - xfnf := fastpathAV[idx].decfn - xrt := fastpathAV[idx].rt - fn.f = func(xf *decFnInfo, xrv reflect.Value) { - // xfnf(xf, xrv.Convert(xrt)) - xfnf(xf, xrv.Addr().Convert(reflect.PtrTo(xrt)).Elem()) - } - } - } - } - if fn.f == nil { - switch rk { - case reflect.String: - fn.f = (*decFnInfo).kString - case reflect.Bool: - fn.f = (*decFnInfo).kBool - case reflect.Int: - fn.f = (*decFnInfo).kInt - case reflect.Int64: - fn.f = (*decFnInfo).kInt64 - case reflect.Int32: - fn.f = (*decFnInfo).kInt32 - case reflect.Int8: - fn.f = (*decFnInfo).kInt8 - case reflect.Int16: - fn.f = (*decFnInfo).kInt16 - case reflect.Float32: - fn.f = (*decFnInfo).kFloat32 - case reflect.Float64: - fn.f = (*decFnInfo).kFloat64 - case reflect.Uint8: - fn.f = (*decFnInfo).kUint8 - case reflect.Uint64: - fn.f = (*decFnInfo).kUint64 - case reflect.Uint: - fn.f = (*decFnInfo).kUint - case reflect.Uint32: - fn.f = (*decFnInfo).kUint32 - case reflect.Uint16: - fn.f = (*decFnInfo).kUint16 - // case reflect.Ptr: - // fn.f = (*decFnInfo).kPtr - case reflect.Uintptr: - fn.f = (*decFnInfo).kUintptr - case reflect.Interface: - fn.f = (*decFnInfo).kInterface - case reflect.Struct: - fn.f = (*decFnInfo).kStruct - case reflect.Chan: - fi.seq = seqTypeChan - fn.f = (*decFnInfo).kSlice - case reflect.Slice: - fi.seq = seqTypeSlice - fn.f = (*decFnInfo).kSlice - case reflect.Array: - fi.seq = seqTypeArray - fn.f = (*decFnInfo).kArray - case reflect.Map: - fn.f = (*decFnInfo).kMap - default: - fn.f = (*decFnInfo).kErr - } - } - } - - return -} - -func (d *Decoder) structFieldNotFound(index int, rvkencname string) { - if d.h.ErrorIfNoField { - if index >= 0 { - d.errorf("no matching struct field found when decoding stream array at index %v", index) - return - } else if rvkencname != "" { - d.errorf("no matching struct field found when decoding stream map with key %s", rvkencname) - return - } - } - d.swallow() -} - -func (d *Decoder) arrayCannotExpand(sliceLen, streamLen int) { - if d.h.ErrorIfNoArrayExpand { - d.errorf("cannot expand array len during decode from %v to %v", sliceLen, streamLen) - } -} - -func (d *Decoder) chkPtrValue(rv reflect.Value) { - // We can only decode into a non-nil pointer - if rv.Kind() == reflect.Ptr && !rv.IsNil() { - return - } - d.errNotValidPtrValue(rv) -} - -func (d *Decoder) errNotValidPtrValue(rv reflect.Value) { - if !rv.IsValid() { - d.error(cannotDecodeIntoNilErr) - return - } - if !rv.CanInterface() { - d.errorf("cannot decode into a value without an interface: %v", rv) - return - } - rvi := rv.Interface() - d.errorf("cannot decode into non-pointer or nil pointer. Got: %v, %T, %v", rv.Kind(), rvi, rvi) -} - -func (d *Decoder) error(err error) { - panic(err) -} - -func (d *Decoder) errorf(format string, params ...interface{}) { - params2 := make([]interface{}, len(params)+1) - params2[0] = d.r.numread() - copy(params2[1:], params) - err := fmt.Errorf("[pos %d]: "+format, params2...) - panic(err) -} - -func (d *Decoder) string(v []byte) (s string) { - if d.is != nil { - s, ok := d.is[string(v)] // no allocation here. - if !ok { - s = string(v) - d.is[s] = s - } - return s - } - return string(v) // don't return stringView, as we need a real string here. -} - -func (d *Decoder) intern(s string) { - if d.is != nil { - d.is[s] = s - } -} - -func (d *Decoder) nextValueBytes() []byte { - d.d.uncacheRead() - d.r.track() - d.swallow() - return d.r.stopTrack() -} - -// -------------------------------------------------- - -// decSliceHelper assists when decoding into a slice, from a map or an array in the stream. -// A slice can be set from a map or array in stream. This supports the MapBySlice interface. -type decSliceHelper struct { - d *Decoder - // ct valueType - array bool -} - -func (d *Decoder) decSliceHelperStart() (x decSliceHelper, clen int) { - dd := d.d - ctyp := dd.ContainerType() - if ctyp == valueTypeArray { - x.array = true - clen = dd.ReadArrayStart() - } else if ctyp == valueTypeMap { - clen = dd.ReadMapStart() * 2 - } else { - d.errorf("only encoded map or array can be decoded into a slice (%d)", ctyp) - } - // x.ct = ctyp - x.d = d - return -} - -func (x decSliceHelper) End() { - cr := x.d.cr - if cr == nil { - return - } - if x.array { - cr.sendContainerState(containerArrayEnd) - } else { - cr.sendContainerState(containerMapEnd) - } -} - -func (x decSliceHelper) ElemContainerState(index int) { - cr := x.d.cr - if cr == nil { - return - } - if x.array { - cr.sendContainerState(containerArrayElem) - } else { - if index%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } -} - -func decByteSlice(r decReader, clen int, bs []byte) (bsOut []byte) { - if clen == 0 { - return zeroByteSlice - } - if len(bs) == clen { - bsOut = bs - } else if cap(bs) >= clen { - bsOut = bs[:clen] - } else { - bsOut = make([]byte, clen) - } - r.readb(bsOut) - return -} - -func detachZeroCopyBytes(isBytesReader bool, dest []byte, in []byte) (out []byte) { - if xlen := len(in); xlen > 0 { - if isBytesReader || xlen <= scratchByteArrayLen { - if cap(dest) >= xlen { - out = dest[:xlen] - } else { - out = make([]byte, xlen) - } - copy(out, in) - return - } - } - return in -} - -// decInferLen will infer a sensible length, given the following: -// - clen: length wanted. -// - maxlen: max length to be returned. -// if <= 0, it is unset, and we infer it based on the unit size -// - unit: number of bytes for each element of the collection -func decInferLen(clen, maxlen, unit int) (rvlen int, truncated bool) { - // handle when maxlen is not set i.e. <= 0 - if clen <= 0 { - return - } - if maxlen <= 0 { - // no maxlen defined. Use maximum of 256K memory, with a floor of 4K items. - // maxlen = 256 * 1024 / unit - // if maxlen < (4 * 1024) { - // maxlen = 4 * 1024 - // } - if unit < (256 / 4) { - maxlen = 256 * 1024 / unit - } else { - maxlen = 4 * 1024 - } - } - if clen > maxlen { - rvlen = maxlen - truncated = true - } else { - rvlen = clen - } - return - // if clen <= 0 { - // rvlen = 0 - // } else if maxlen > 0 && clen > maxlen { - // rvlen = maxlen - // truncated = true - // } else { - // rvlen = clen - // } - // return -} - -// // implement overall decReader wrapping both, for possible use inline: -// type decReaderT struct { -// bytes bool -// rb *bytesDecReader -// ri *ioDecReader -// } -// -// // implement *Decoder as a decReader. -// // Using decReaderT (defined just above) caused performance degradation -// // possibly because of constant copying the value, -// // and some value->interface conversion causing allocation. -// func (d *Decoder) unreadn1() { -// if d.bytes { -// d.rb.unreadn1() -// } else { -// d.ri.unreadn1() -// } -// } -// ... for other methods of decReader. -// Testing showed that performance improvement was negligible. diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/encode.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/encode.go deleted file mode 100644 index 99af6fa..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/encode.go +++ /dev/null @@ -1,1405 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "encoding" - "fmt" - "io" - "reflect" - "sort" - "sync" -) - -const ( - defEncByteBufSize = 1 << 6 // 4:16, 6:64, 8:256, 10:1024 -) - -// AsSymbolFlag defines what should be encoded as symbols. -type AsSymbolFlag uint8 - -const ( - // AsSymbolDefault is default. - // Currently, this means only encode struct field names as symbols. - // The default is subject to change. - AsSymbolDefault AsSymbolFlag = iota - - // AsSymbolAll means encode anything which could be a symbol as a symbol. - AsSymbolAll = 0xfe - - // AsSymbolNone means do not encode anything as a symbol. - AsSymbolNone = 1 << iota - - // AsSymbolMapStringKeys means encode keys in map[string]XXX as symbols. - AsSymbolMapStringKeysFlag - - // AsSymbolStructFieldName means encode struct field names as symbols. - AsSymbolStructFieldNameFlag -) - -// encWriter abstracts writing to a byte array or to an io.Writer. -type encWriter interface { - writeb([]byte) - writestr(string) - writen1(byte) - writen2(byte, byte) - atEndOfEncode() -} - -// encDriver abstracts the actual codec (binc vs msgpack, etc) -type encDriver interface { - IsBuiltinType(rt uintptr) bool - EncodeBuiltin(rt uintptr, v interface{}) - EncodeNil() - EncodeInt(i int64) - EncodeUint(i uint64) - EncodeBool(b bool) - EncodeFloat32(f float32) - EncodeFloat64(f float64) - // encodeExtPreamble(xtag byte, length int) - EncodeRawExt(re *RawExt, e *Encoder) - EncodeExt(v interface{}, xtag uint64, ext Ext, e *Encoder) - EncodeArrayStart(length int) - EncodeMapStart(length int) - EncodeString(c charEncoding, v string) - EncodeSymbol(v string) - EncodeStringBytes(c charEncoding, v []byte) - //TODO - //encBignum(f *big.Int) - //encStringRunes(c charEncoding, v []rune) - - reset() -} - -type encDriverAsis interface { - EncodeAsis(v []byte) -} - -type encNoSeparator struct{} - -func (_ encNoSeparator) EncodeEnd() {} - -type ioEncWriterWriter interface { - WriteByte(c byte) error - WriteString(s string) (n int, err error) - Write(p []byte) (n int, err error) -} - -type ioEncStringWriter interface { - WriteString(s string) (n int, err error) -} - -type EncodeOptions struct { - // Encode a struct as an array, and not as a map - StructToArray bool - - // Canonical representation means that encoding a value will always result in the same - // sequence of bytes. - // - // This only affects maps, as the iteration order for maps is random. - // - // The implementation MAY use the natural sort order for the map keys if possible: - // - // - If there is a natural sort order (ie for number, bool, string or []byte keys), - // then the map keys are first sorted in natural order and then written - // with corresponding map values to the strema. - // - If there is no natural sort order, then the map keys will first be - // encoded into []byte, and then sorted, - // before writing the sorted keys and the corresponding map values to the stream. - // - Canonical bool - - // AsSymbols defines what should be encoded as symbols. - // - // Encoding as symbols can reduce the encoded size significantly. - // - // However, during decoding, each string to be encoded as a symbol must - // be checked to see if it has been seen before. Consequently, encoding time - // will increase if using symbols, because string comparisons has a clear cost. - // - // Sample values: - // AsSymbolNone - // AsSymbolAll - // AsSymbolMapStringKeys - // AsSymbolMapStringKeysFlag | AsSymbolStructFieldNameFlag - AsSymbols AsSymbolFlag -} - -// --------------------------------------------- - -type simpleIoEncWriterWriter struct { - w io.Writer - bw io.ByteWriter - sw ioEncStringWriter -} - -func (o *simpleIoEncWriterWriter) WriteByte(c byte) (err error) { - if o.bw != nil { - return o.bw.WriteByte(c) - } - _, err = o.w.Write([]byte{c}) - return -} - -func (o *simpleIoEncWriterWriter) WriteString(s string) (n int, err error) { - if o.sw != nil { - return o.sw.WriteString(s) - } - // return o.w.Write([]byte(s)) - return o.w.Write(bytesView(s)) -} - -func (o *simpleIoEncWriterWriter) Write(p []byte) (n int, err error) { - return o.w.Write(p) -} - -// ---------------------------------------- - -// ioEncWriter implements encWriter and can write to an io.Writer implementation -type ioEncWriter struct { - w ioEncWriterWriter - s simpleIoEncWriterWriter - // x [8]byte // temp byte array re-used internally for efficiency -} - -func (z *ioEncWriter) writeb(bs []byte) { - if len(bs) == 0 { - return - } - n, err := z.w.Write(bs) - if err != nil { - panic(err) - } - if n != len(bs) { - panic(fmt.Errorf("incorrect num bytes written. Expecting: %v, Wrote: %v", len(bs), n)) - } -} - -func (z *ioEncWriter) writestr(s string) { - n, err := z.w.WriteString(s) - if err != nil { - panic(err) - } - if n != len(s) { - panic(fmt.Errorf("incorrect num bytes written. Expecting: %v, Wrote: %v", len(s), n)) - } -} - -func (z *ioEncWriter) writen1(b byte) { - if err := z.w.WriteByte(b); err != nil { - panic(err) - } -} - -func (z *ioEncWriter) writen2(b1 byte, b2 byte) { - z.writen1(b1) - z.writen1(b2) -} - -func (z *ioEncWriter) atEndOfEncode() {} - -// ---------------------------------------- - -// bytesEncWriter implements encWriter and can write to an byte slice. -// It is used by Marshal function. -type bytesEncWriter struct { - b []byte - c int // cursor - out *[]byte // write out on atEndOfEncode -} - -func (z *bytesEncWriter) writeb(s []byte) { - if len(s) > 0 { - c := z.grow(len(s)) - copy(z.b[c:], s) - } -} - -func (z *bytesEncWriter) writestr(s string) { - if len(s) > 0 { - c := z.grow(len(s)) - copy(z.b[c:], s) - } -} - -func (z *bytesEncWriter) writen1(b1 byte) { - c := z.grow(1) - z.b[c] = b1 -} - -func (z *bytesEncWriter) writen2(b1 byte, b2 byte) { - c := z.grow(2) - z.b[c] = b1 - z.b[c+1] = b2 -} - -func (z *bytesEncWriter) atEndOfEncode() { - *(z.out) = z.b[:z.c] -} - -func (z *bytesEncWriter) grow(n int) (oldcursor int) { - oldcursor = z.c - z.c = oldcursor + n - if z.c > len(z.b) { - if z.c > cap(z.b) { - // appendslice logic (if cap < 1024, *2, else *1.25): more expensive. many copy calls. - // bytes.Buffer model (2*cap + n): much better - // bs := make([]byte, 2*cap(z.b)+n) - bs := make([]byte, growCap(cap(z.b), 1, n)) - copy(bs, z.b[:oldcursor]) - z.b = bs - } else { - z.b = z.b[:cap(z.b)] - } - } - return -} - -// --------------------------------------------- - -type encFnInfo struct { - e *Encoder - ti *typeInfo - xfFn Ext - xfTag uint64 - seq seqType -} - -func (f *encFnInfo) builtin(rv reflect.Value) { - f.e.e.EncodeBuiltin(f.ti.rtid, rv.Interface()) -} - -func (f *encFnInfo) rawExt(rv reflect.Value) { - // rev := rv.Interface().(RawExt) - // f.e.e.EncodeRawExt(&rev, f.e) - var re *RawExt - if rv.CanAddr() { - re = rv.Addr().Interface().(*RawExt) - } else { - rev := rv.Interface().(RawExt) - re = &rev - } - f.e.e.EncodeRawExt(re, f.e) -} - -func (f *encFnInfo) ext(rv reflect.Value) { - // if this is a struct|array and it was addressable, then pass the address directly (not the value) - if k := rv.Kind(); (k == reflect.Struct || k == reflect.Array) && rv.CanAddr() { - rv = rv.Addr() - } - f.e.e.EncodeExt(rv.Interface(), f.xfTag, f.xfFn, f.e) -} - -func (f *encFnInfo) getValueForMarshalInterface(rv reflect.Value, indir int8) (v interface{}, proceed bool) { - if indir == 0 { - v = rv.Interface() - } else if indir == -1 { - // If a non-pointer was passed to Encode(), then that value is not addressable. - // Take addr if addresable, else copy value to an addressable value. - if rv.CanAddr() { - v = rv.Addr().Interface() - } else { - rv2 := reflect.New(rv.Type()) - rv2.Elem().Set(rv) - v = rv2.Interface() - // fmt.Printf("rv.Type: %v, rv2.Type: %v, v: %v\n", rv.Type(), rv2.Type(), v) - } - } else { - for j := int8(0); j < indir; j++ { - if rv.IsNil() { - f.e.e.EncodeNil() - return - } - rv = rv.Elem() - } - v = rv.Interface() - } - return v, true -} - -func (f *encFnInfo) selferMarshal(rv reflect.Value) { - if v, proceed := f.getValueForMarshalInterface(rv, f.ti.csIndir); proceed { - v.(Selfer).CodecEncodeSelf(f.e) - } -} - -func (f *encFnInfo) binaryMarshal(rv reflect.Value) { - if v, proceed := f.getValueForMarshalInterface(rv, f.ti.bmIndir); proceed { - bs, fnerr := v.(encoding.BinaryMarshaler).MarshalBinary() - f.e.marshal(bs, fnerr, false, c_RAW) - } -} - -func (f *encFnInfo) textMarshal(rv reflect.Value) { - if v, proceed := f.getValueForMarshalInterface(rv, f.ti.tmIndir); proceed { - // debugf(">>>> encoding.TextMarshaler: %T", rv.Interface()) - bs, fnerr := v.(encoding.TextMarshaler).MarshalText() - f.e.marshal(bs, fnerr, false, c_UTF8) - } -} - -func (f *encFnInfo) jsonMarshal(rv reflect.Value) { - if v, proceed := f.getValueForMarshalInterface(rv, f.ti.jmIndir); proceed { - bs, fnerr := v.(jsonMarshaler).MarshalJSON() - f.e.marshal(bs, fnerr, true, c_UTF8) - } -} - -func (f *encFnInfo) kBool(rv reflect.Value) { - f.e.e.EncodeBool(rv.Bool()) -} - -func (f *encFnInfo) kString(rv reflect.Value) { - f.e.e.EncodeString(c_UTF8, rv.String()) -} - -func (f *encFnInfo) kFloat64(rv reflect.Value) { - f.e.e.EncodeFloat64(rv.Float()) -} - -func (f *encFnInfo) kFloat32(rv reflect.Value) { - f.e.e.EncodeFloat32(float32(rv.Float())) -} - -func (f *encFnInfo) kInt(rv reflect.Value) { - f.e.e.EncodeInt(rv.Int()) -} - -func (f *encFnInfo) kUint(rv reflect.Value) { - f.e.e.EncodeUint(rv.Uint()) -} - -func (f *encFnInfo) kInvalid(rv reflect.Value) { - f.e.e.EncodeNil() -} - -func (f *encFnInfo) kErr(rv reflect.Value) { - f.e.errorf("unsupported kind %s, for %#v", rv.Kind(), rv) -} - -func (f *encFnInfo) kSlice(rv reflect.Value) { - ti := f.ti - // array may be non-addressable, so we have to manage with care - // (don't call rv.Bytes, rv.Slice, etc). - // E.g. type struct S{B [2]byte}; - // Encode(S{}) will bomb on "panic: slice of unaddressable array". - e := f.e - if f.seq != seqTypeArray { - if rv.IsNil() { - e.e.EncodeNil() - return - } - // If in this method, then there was no extension function defined. - // So it's okay to treat as []byte. - if ti.rtid == uint8SliceTypId { - e.e.EncodeStringBytes(c_RAW, rv.Bytes()) - return - } - } - cr := e.cr - rtelem := ti.rt.Elem() - l := rv.Len() - if ti.rtid == uint8SliceTypId || rtelem.Kind() == reflect.Uint8 { - switch f.seq { - case seqTypeArray: - // if l == 0 { e.e.encodeStringBytes(c_RAW, nil) } else - if rv.CanAddr() { - e.e.EncodeStringBytes(c_RAW, rv.Slice(0, l).Bytes()) - } else { - var bs []byte - if l <= cap(e.b) { - bs = e.b[:l] - } else { - bs = make([]byte, l) - } - reflect.Copy(reflect.ValueOf(bs), rv) - // TODO: Test that reflect.Copy works instead of manual one-by-one - // for i := 0; i < l; i++ { - // bs[i] = byte(rv.Index(i).Uint()) - // } - e.e.EncodeStringBytes(c_RAW, bs) - } - case seqTypeSlice: - e.e.EncodeStringBytes(c_RAW, rv.Bytes()) - case seqTypeChan: - bs := e.b[:0] - // do not use range, so that the number of elements encoded - // does not change, and encoding does not hang waiting on someone to close chan. - // for b := range rv.Interface().(<-chan byte) { - // bs = append(bs, b) - // } - ch := rv.Interface().(<-chan byte) - for i := 0; i < l; i++ { - bs = append(bs, <-ch) - } - e.e.EncodeStringBytes(c_RAW, bs) - } - return - } - - if ti.mbs { - if l%2 == 1 { - e.errorf("mapBySlice requires even slice length, but got %v", l) - return - } - e.e.EncodeMapStart(l / 2) - } else { - e.e.EncodeArrayStart(l) - } - - if l > 0 { - for rtelem.Kind() == reflect.Ptr { - rtelem = rtelem.Elem() - } - // if kind is reflect.Interface, do not pre-determine the - // encoding type, because preEncodeValue may break it down to - // a concrete type and kInterface will bomb. - var fn *encFn - if rtelem.Kind() != reflect.Interface { - rtelemid := reflect.ValueOf(rtelem).Pointer() - fn = e.getEncFn(rtelemid, rtelem, true, true) - } - // TODO: Consider perf implication of encoding odd index values as symbols if type is string - for j := 0; j < l; j++ { - if cr != nil { - if ti.mbs { - if l%2 == 0 { - cr.sendContainerState(containerMapKey) - } else { - cr.sendContainerState(containerMapValue) - } - } else { - cr.sendContainerState(containerArrayElem) - } - } - if f.seq == seqTypeChan { - if rv2, ok2 := rv.Recv(); ok2 { - e.encodeValue(rv2, fn) - } else { - e.encode(nil) // WE HAVE TO DO SOMETHING, so nil if nothing received. - } - } else { - e.encodeValue(rv.Index(j), fn) - } - } - } - - if cr != nil { - if ti.mbs { - cr.sendContainerState(containerMapEnd) - } else { - cr.sendContainerState(containerArrayEnd) - } - } -} - -func (f *encFnInfo) kStruct(rv reflect.Value) { - fti := f.ti - e := f.e - cr := e.cr - tisfi := fti.sfip - toMap := !(fti.toArray || e.h.StructToArray) - newlen := len(fti.sfi) - - // Use sync.Pool to reduce allocating slices unnecessarily. - // The cost of the occasional locking is less than the cost of new allocation. - pool, poolv, fkvs := encStructPoolGet(newlen) - - // if toMap, use the sorted array. If toArray, use unsorted array (to match sequence in struct) - if toMap { - tisfi = fti.sfi - } - newlen = 0 - var kv stringRv - for _, si := range tisfi { - kv.r = si.field(rv, false) - // if si.i != -1 { - // rvals[newlen] = rv.Field(int(si.i)) - // } else { - // rvals[newlen] = rv.FieldByIndex(si.is) - // } - if toMap { - if si.omitEmpty && isEmptyValue(kv.r) { - continue - } - kv.v = si.encName - } else { - // use the zero value. - // if a reference or struct, set to nil (so you do not output too much) - if si.omitEmpty && isEmptyValue(kv.r) { - switch kv.r.Kind() { - case reflect.Struct, reflect.Interface, reflect.Ptr, reflect.Array, - reflect.Map, reflect.Slice: - kv.r = reflect.Value{} //encode as nil - } - } - } - fkvs[newlen] = kv - newlen++ - } - - // debugf(">>>> kStruct: newlen: %v", newlen) - // sep := !e.be - ee := e.e //don't dereference everytime - - if toMap { - ee.EncodeMapStart(newlen) - // asSymbols := e.h.AsSymbols&AsSymbolStructFieldNameFlag != 0 - asSymbols := e.h.AsSymbols == AsSymbolDefault || e.h.AsSymbols&AsSymbolStructFieldNameFlag != 0 - for j := 0; j < newlen; j++ { - kv = fkvs[j] - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(kv.v) - } else { - ee.EncodeString(c_UTF8, kv.v) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(kv.r, nil) - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - } else { - ee.EncodeArrayStart(newlen) - for j := 0; j < newlen; j++ { - kv = fkvs[j] - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - e.encodeValue(kv.r, nil) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } - } - - // do not use defer. Instead, use explicit pool return at end of function. - // defer has a cost we are trying to avoid. - // If there is a panic and these slices are not returned, it is ok. - if pool != nil { - pool.Put(poolv) - } -} - -// func (f *encFnInfo) kPtr(rv reflect.Value) { -// debugf(">>>>>>> ??? encode kPtr called - shouldn't get called") -// if rv.IsNil() { -// f.e.e.encodeNil() -// return -// } -// f.e.encodeValue(rv.Elem()) -// } - -func (f *encFnInfo) kInterface(rv reflect.Value) { - if rv.IsNil() { - f.e.e.EncodeNil() - return - } - f.e.encodeValue(rv.Elem(), nil) -} - -func (f *encFnInfo) kMap(rv reflect.Value) { - ee := f.e.e - if rv.IsNil() { - ee.EncodeNil() - return - } - - l := rv.Len() - ee.EncodeMapStart(l) - e := f.e - cr := e.cr - if l == 0 { - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return - } - var asSymbols bool - // determine the underlying key and val encFn's for the map. - // This eliminates some work which is done for each loop iteration i.e. - // rv.Type(), ref.ValueOf(rt).Pointer(), then check map/list for fn. - // - // However, if kind is reflect.Interface, do not pre-determine the - // encoding type, because preEncodeValue may break it down to - // a concrete type and kInterface will bomb. - var keyFn, valFn *encFn - ti := f.ti - rtkey := ti.rt.Key() - rtval := ti.rt.Elem() - rtkeyid := reflect.ValueOf(rtkey).Pointer() - // keyTypeIsString := f.ti.rt.Key().Kind() == reflect.String - var keyTypeIsString = rtkeyid == stringTypId - if keyTypeIsString { - asSymbols = e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - } else { - for rtkey.Kind() == reflect.Ptr { - rtkey = rtkey.Elem() - } - if rtkey.Kind() != reflect.Interface { - rtkeyid = reflect.ValueOf(rtkey).Pointer() - keyFn = e.getEncFn(rtkeyid, rtkey, true, true) - } - } - for rtval.Kind() == reflect.Ptr { - rtval = rtval.Elem() - } - if rtval.Kind() != reflect.Interface { - rtvalid := reflect.ValueOf(rtval).Pointer() - valFn = e.getEncFn(rtvalid, rtval, true, true) - } - mks := rv.MapKeys() - // for j, lmks := 0, len(mks); j < lmks; j++ { - - if e.h.Canonical { - e.kMapCanonical(rtkeyid, rtkey, rv, mks, valFn, asSymbols) - } else { - for j := range mks { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if keyTypeIsString { - if asSymbols { - ee.EncodeSymbol(mks[j].String()) - } else { - ee.EncodeString(c_UTF8, mks[j].String()) - } - } else { - e.encodeValue(mks[j], keyFn) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mks[j]), valFn) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (e *Encoder) kMapCanonical(rtkeyid uintptr, rtkey reflect.Type, rv reflect.Value, mks []reflect.Value, valFn *encFn, asSymbols bool) { - ee := e.e - cr := e.cr - // we previously did out-of-band if an extension was registered. - // This is not necessary, as the natural kind is sufficient for ordering. - - if rtkeyid == uint8SliceTypId { - mksv := make([]bytesRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Bytes() - } - sort.Sort(bytesRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeStringBytes(c_RAW, mksv[i].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - } else { - switch rtkey.Kind() { - case reflect.Bool: - mksv := make([]boolRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Bool() - } - sort.Sort(boolRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(mksv[i].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - case reflect.String: - mksv := make([]stringRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.String() - } - sort.Sort(stringRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(mksv[i].v) - } else { - ee.EncodeString(c_UTF8, mksv[i].v) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uint, reflect.Uintptr: - mksv := make([]uintRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Uint() - } - sort.Sort(uintRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(mksv[i].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - case reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64, reflect.Int: - mksv := make([]intRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Int() - } - sort.Sort(intRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(mksv[i].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - case reflect.Float32: - mksv := make([]floatRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Float() - } - sort.Sort(floatRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(mksv[i].v)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - case reflect.Float64: - mksv := make([]floatRv, len(mks)) - for i, k := range mks { - v := &mksv[i] - v.r = k - v.v = k.Float() - } - sort.Sort(floatRvSlice(mksv)) - for i := range mksv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(mksv[i].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksv[i].r), valFn) - } - default: - // out-of-band - // first encode each key to a []byte first, then sort them, then record - var mksv []byte = make([]byte, 0, len(mks)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - mksbv := make([]bytesRv, len(mks)) - for i, k := range mks { - v := &mksbv[i] - l := len(mksv) - e2.MustEncode(k) - v.r = k - v.v = mksv[l:] - // fmt.Printf(">>>>> %s\n", mksv[l:]) - } - sort.Sort(bytesRvSlice(mksbv)) - for j := range mksbv { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(mksbv[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encodeValue(rv.MapIndex(mksbv[j].r), valFn) - } - } - } -} - -// -------------------------------------------------- - -// encFn encapsulates the captured variables and the encode function. -// This way, we only do some calculations one times, and pass to the -// code block that should be called (encapsulated in a function) -// instead of executing the checks every time. -type encFn struct { - i encFnInfo - f func(*encFnInfo, reflect.Value) -} - -// -------------------------------------------------- - -type encRtidFn struct { - rtid uintptr - fn encFn -} - -// An Encoder writes an object to an output stream in the codec format. -type Encoder struct { - // hopefully, reduce derefencing cost by laying the encWriter inside the Encoder - e encDriver - // NOTE: Encoder shouldn't call it's write methods, - // as the handler MAY need to do some coordination. - w encWriter - s []encRtidFn - be bool // is binary encoding - js bool // is json handle - - wi ioEncWriter - wb bytesEncWriter - - h *BasicHandle - hh Handle - - cr containerStateRecv - as encDriverAsis - - f map[uintptr]*encFn - b [scratchByteArrayLen]byte -} - -// NewEncoder returns an Encoder for encoding into an io.Writer. -// -// For efficiency, Users are encouraged to pass in a memory buffered writer -// (eg bufio.Writer, bytes.Buffer). -func NewEncoder(w io.Writer, h Handle) *Encoder { - e := newEncoder(h) - e.Reset(w) - return e -} - -// NewEncoderBytes returns an encoder for encoding directly and efficiently -// into a byte slice, using zero-copying to temporary slices. -// -// It will potentially replace the output byte slice pointed to. -// After encoding, the out parameter contains the encoded contents. -func NewEncoderBytes(out *[]byte, h Handle) *Encoder { - e := newEncoder(h) - e.ResetBytes(out) - return e -} - -func newEncoder(h Handle) *Encoder { - e := &Encoder{hh: h, h: h.getBasicHandle(), be: h.isBinary()} - _, e.js = h.(*JsonHandle) - e.e = h.newEncDriver(e) - e.as, _ = e.e.(encDriverAsis) - e.cr, _ = e.e.(containerStateRecv) - return e -} - -// Reset the Encoder with a new output stream. -// -// This accomodates using the state of the Encoder, -// where it has "cached" information about sub-engines. -func (e *Encoder) Reset(w io.Writer) { - ww, ok := w.(ioEncWriterWriter) - if ok { - e.wi.w = ww - } else { - sww := &e.wi.s - sww.w = w - sww.bw, _ = w.(io.ByteWriter) - sww.sw, _ = w.(ioEncStringWriter) - e.wi.w = sww - //ww = bufio.NewWriterSize(w, defEncByteBufSize) - } - e.w = &e.wi - e.e.reset() -} - -func (e *Encoder) ResetBytes(out *[]byte) { - in := *out - if in == nil { - in = make([]byte, defEncByteBufSize) - } - e.wb.b, e.wb.out, e.wb.c = in, out, 0 - e.w = &e.wb - e.e.reset() -} - -// func (e *Encoder) sendContainerState(c containerState) { -// if e.cr != nil { -// e.cr.sendContainerState(c) -// } -// } - -// Encode writes an object into a stream. -// -// Encoding can be configured via the struct tag for the fields. -// The "codec" key in struct field's tag value is the key name, -// followed by an optional comma and options. -// Note that the "json" key is used in the absence of the "codec" key. -// -// To set an option on all fields (e.g. omitempty on all fields), you -// can create a field called _struct, and set flags on it. -// -// Struct values "usually" encode as maps. Each exported struct field is encoded unless: -// - the field's tag is "-", OR -// - the field is empty (empty or the zero value) and its tag specifies the "omitempty" option. -// -// When encoding as a map, the first string in the tag (before the comma) -// is the map key string to use when encoding. -// -// However, struct values may encode as arrays. This happens when: -// - StructToArray Encode option is set, OR -// - the tag on the _struct field sets the "toarray" option -// -// Values with types that implement MapBySlice are encoded as stream maps. -// -// The empty values (for omitempty option) are false, 0, any nil pointer -// or interface value, and any array, slice, map, or string of length zero. -// -// Anonymous fields are encoded inline except: -// - the struct tag specifies a replacement name (first value) -// - the field is of an interface type -// -// Examples: -// -// // NOTE: 'json:' can be used as struct tag key, in place 'codec:' below. -// type MyStruct struct { -// _struct bool `codec:",omitempty"` //set omitempty for every field -// Field1 string `codec:"-"` //skip this field -// Field2 int `codec:"myName"` //Use key "myName" in encode stream -// Field3 int32 `codec:",omitempty"` //use key "Field3". Omit if empty. -// Field4 bool `codec:"f4,omitempty"` //use key "f4". Omit if empty. -// io.Reader //use key "Reader". -// MyStruct `codec:"my1" //use key "my1". -// MyStruct //inline it -// ... -// } -// -// type MyStruct struct { -// _struct bool `codec:",omitempty,toarray"` //set omitempty for every field -// //and encode struct as an array -// } -// -// The mode of encoding is based on the type of the value. When a value is seen: -// - If a Selfer, call its CodecEncodeSelf method -// - If an extension is registered for it, call that extension function -// - If it implements encoding.(Binary|Text|JSON)Marshaler, call its Marshal(Binary|Text|JSON) method -// - Else encode it based on its reflect.Kind -// -// Note that struct field names and keys in map[string]XXX will be treated as symbols. -// Some formats support symbols (e.g. binc) and will properly encode the string -// only once in the stream, and use a tag to refer to it thereafter. -func (e *Encoder) Encode(v interface{}) (err error) { - defer panicToErr(&err) - e.encode(v) - e.w.atEndOfEncode() - return -} - -// MustEncode is like Encode, but panics if unable to Encode. -// This provides insight to the code location that triggered the error. -func (e *Encoder) MustEncode(v interface{}) { - e.encode(v) - e.w.atEndOfEncode() -} - -// comment out these (Must)Write methods. They were only put there to support cbor. -// However, users already have access to the streams, and can write directly. -// -// // Write allows users write to the Encoder stream directly. -// func (e *Encoder) Write(bs []byte) (err error) { -// defer panicToErr(&err) -// e.w.writeb(bs) -// return -// } -// // MustWrite is like write, but panics if unable to Write. -// func (e *Encoder) MustWrite(bs []byte) { -// e.w.writeb(bs) -// } - -func (e *Encoder) encode(iv interface{}) { - // if ics, ok := iv.(Selfer); ok { - // ics.CodecEncodeSelf(e) - // return - // } - - switch v := iv.(type) { - case nil: - e.e.EncodeNil() - case Selfer: - v.CodecEncodeSelf(e) - - case reflect.Value: - e.encodeValue(v, nil) - - case string: - e.e.EncodeString(c_UTF8, v) - case bool: - e.e.EncodeBool(v) - case int: - e.e.EncodeInt(int64(v)) - case int8: - e.e.EncodeInt(int64(v)) - case int16: - e.e.EncodeInt(int64(v)) - case int32: - e.e.EncodeInt(int64(v)) - case int64: - e.e.EncodeInt(v) - case uint: - e.e.EncodeUint(uint64(v)) - case uint8: - e.e.EncodeUint(uint64(v)) - case uint16: - e.e.EncodeUint(uint64(v)) - case uint32: - e.e.EncodeUint(uint64(v)) - case uint64: - e.e.EncodeUint(v) - case float32: - e.e.EncodeFloat32(v) - case float64: - e.e.EncodeFloat64(v) - - case []uint8: - e.e.EncodeStringBytes(c_RAW, v) - - case *string: - e.e.EncodeString(c_UTF8, *v) - case *bool: - e.e.EncodeBool(*v) - case *int: - e.e.EncodeInt(int64(*v)) - case *int8: - e.e.EncodeInt(int64(*v)) - case *int16: - e.e.EncodeInt(int64(*v)) - case *int32: - e.e.EncodeInt(int64(*v)) - case *int64: - e.e.EncodeInt(*v) - case *uint: - e.e.EncodeUint(uint64(*v)) - case *uint8: - e.e.EncodeUint(uint64(*v)) - case *uint16: - e.e.EncodeUint(uint64(*v)) - case *uint32: - e.e.EncodeUint(uint64(*v)) - case *uint64: - e.e.EncodeUint(*v) - case *float32: - e.e.EncodeFloat32(*v) - case *float64: - e.e.EncodeFloat64(*v) - - case *[]uint8: - e.e.EncodeStringBytes(c_RAW, *v) - - default: - const checkCodecSelfer1 = true // in case T is passed, where *T is a Selfer, still checkCodecSelfer - if !fastpathEncodeTypeSwitch(iv, e) { - e.encodeI(iv, false, checkCodecSelfer1) - } - } -} - -func (e *Encoder) encodeI(iv interface{}, checkFastpath, checkCodecSelfer bool) { - if rv, proceed := e.preEncodeValue(reflect.ValueOf(iv)); proceed { - rt := rv.Type() - rtid := reflect.ValueOf(rt).Pointer() - fn := e.getEncFn(rtid, rt, checkFastpath, checkCodecSelfer) - fn.f(&fn.i, rv) - } -} - -func (e *Encoder) preEncodeValue(rv reflect.Value) (rv2 reflect.Value, proceed bool) { - // use a goto statement instead of a recursive function for ptr/interface. -TOP: - switch rv.Kind() { - case reflect.Ptr, reflect.Interface: - if rv.IsNil() { - e.e.EncodeNil() - return - } - rv = rv.Elem() - goto TOP - case reflect.Slice, reflect.Map: - if rv.IsNil() { - e.e.EncodeNil() - return - } - case reflect.Invalid, reflect.Func: - e.e.EncodeNil() - return - } - - return rv, true -} - -func (e *Encoder) encodeValue(rv reflect.Value, fn *encFn) { - // if a valid fn is passed, it MUST BE for the dereferenced type of rv - if rv, proceed := e.preEncodeValue(rv); proceed { - if fn == nil { - rt := rv.Type() - rtid := reflect.ValueOf(rt).Pointer() - fn = e.getEncFn(rtid, rt, true, true) - } - fn.f(&fn.i, rv) - } -} - -func (e *Encoder) getEncFn(rtid uintptr, rt reflect.Type, checkFastpath, checkCodecSelfer bool) (fn *encFn) { - // rtid := reflect.ValueOf(rt).Pointer() - var ok bool - if useMapForCodecCache { - fn, ok = e.f[rtid] - } else { - for i := range e.s { - v := &(e.s[i]) - if v.rtid == rtid { - fn, ok = &(v.fn), true - break - } - } - } - if ok { - return - } - - if useMapForCodecCache { - if e.f == nil { - e.f = make(map[uintptr]*encFn, initCollectionCap) - } - fn = new(encFn) - e.f[rtid] = fn - } else { - if e.s == nil { - e.s = make([]encRtidFn, 0, initCollectionCap) - } - e.s = append(e.s, encRtidFn{rtid: rtid}) - fn = &(e.s[len(e.s)-1]).fn - } - - ti := e.h.getTypeInfo(rtid, rt) - fi := &(fn.i) - fi.e = e - fi.ti = ti - - if checkCodecSelfer && ti.cs { - fn.f = (*encFnInfo).selferMarshal - } else if rtid == rawExtTypId { - fn.f = (*encFnInfo).rawExt - } else if e.e.IsBuiltinType(rtid) { - fn.f = (*encFnInfo).builtin - } else if xfFn := e.h.getExt(rtid); xfFn != nil { - fi.xfTag, fi.xfFn = xfFn.tag, xfFn.ext - fn.f = (*encFnInfo).ext - } else if supportMarshalInterfaces && e.be && ti.bm { - fn.f = (*encFnInfo).binaryMarshal - } else if supportMarshalInterfaces && !e.be && e.js && ti.jm { - //If JSON, we should check JSONMarshal before textMarshal - fn.f = (*encFnInfo).jsonMarshal - } else if supportMarshalInterfaces && !e.be && ti.tm { - fn.f = (*encFnInfo).textMarshal - } else { - rk := rt.Kind() - if fastpathEnabled && checkFastpath && (rk == reflect.Map || rk == reflect.Slice) { - if rt.PkgPath() == "" { - if idx := fastpathAV.index(rtid); idx != -1 { - fn.f = fastpathAV[idx].encfn - } - } else { - ok = false - // use mapping for underlying type if there - var rtu reflect.Type - if rk == reflect.Map { - rtu = reflect.MapOf(rt.Key(), rt.Elem()) - } else { - rtu = reflect.SliceOf(rt.Elem()) - } - rtuid := reflect.ValueOf(rtu).Pointer() - if idx := fastpathAV.index(rtuid); idx != -1 { - xfnf := fastpathAV[idx].encfn - xrt := fastpathAV[idx].rt - fn.f = func(xf *encFnInfo, xrv reflect.Value) { - xfnf(xf, xrv.Convert(xrt)) - } - } - } - } - if fn.f == nil { - switch rk { - case reflect.Bool: - fn.f = (*encFnInfo).kBool - case reflect.String: - fn.f = (*encFnInfo).kString - case reflect.Float64: - fn.f = (*encFnInfo).kFloat64 - case reflect.Float32: - fn.f = (*encFnInfo).kFloat32 - case reflect.Int, reflect.Int8, reflect.Int64, reflect.Int32, reflect.Int16: - fn.f = (*encFnInfo).kInt - case reflect.Uint8, reflect.Uint64, reflect.Uint, reflect.Uint32, reflect.Uint16, reflect.Uintptr: - fn.f = (*encFnInfo).kUint - case reflect.Invalid: - fn.f = (*encFnInfo).kInvalid - case reflect.Chan: - fi.seq = seqTypeChan - fn.f = (*encFnInfo).kSlice - case reflect.Slice: - fi.seq = seqTypeSlice - fn.f = (*encFnInfo).kSlice - case reflect.Array: - fi.seq = seqTypeArray - fn.f = (*encFnInfo).kSlice - case reflect.Struct: - fn.f = (*encFnInfo).kStruct - // case reflect.Ptr: - // fn.f = (*encFnInfo).kPtr - case reflect.Interface: - fn.f = (*encFnInfo).kInterface - case reflect.Map: - fn.f = (*encFnInfo).kMap - default: - fn.f = (*encFnInfo).kErr - } - } - } - - return -} - -func (e *Encoder) marshal(bs []byte, fnerr error, asis bool, c charEncoding) { - if fnerr != nil { - panic(fnerr) - } - if bs == nil { - e.e.EncodeNil() - } else if asis { - e.asis(bs) - } else { - e.e.EncodeStringBytes(c, bs) - } -} - -func (e *Encoder) asis(v []byte) { - if e.as == nil { - e.w.writeb(v) - } else { - e.as.EncodeAsis(v) - } -} - -func (e *Encoder) errorf(format string, params ...interface{}) { - err := fmt.Errorf(format, params...) - panic(err) -} - -// ---------------------------------------- - -const encStructPoolLen = 5 - -// encStructPool is an array of sync.Pool. -// Each element of the array pools one of encStructPool(8|16|32|64). -// It allows the re-use of slices up to 64 in length. -// A performance cost of encoding structs was collecting -// which values were empty and should be omitted. -// We needed slices of reflect.Value and string to collect them. -// This shared pool reduces the amount of unnecessary creation we do. -// The cost is that of locking sometimes, but sync.Pool is efficient -// enough to reduce thread contention. -var encStructPool [encStructPoolLen]sync.Pool - -func init() { - encStructPool[0].New = func() interface{} { return new([8]stringRv) } - encStructPool[1].New = func() interface{} { return new([16]stringRv) } - encStructPool[2].New = func() interface{} { return new([32]stringRv) } - encStructPool[3].New = func() interface{} { return new([64]stringRv) } - encStructPool[4].New = func() interface{} { return new([128]stringRv) } -} - -func encStructPoolGet(newlen int) (p *sync.Pool, v interface{}, s []stringRv) { - // if encStructPoolLen != 5 { // constant chec, so removed at build time. - // panic(errors.New("encStructPoolLen must be equal to 4")) // defensive, in case it is changed - // } - // idxpool := newlen / 8 - - // if pool == nil { - // fkvs = make([]stringRv, newlen) - // } else { - // poolv = pool.Get() - // switch vv := poolv.(type) { - // case *[8]stringRv: - // fkvs = vv[:newlen] - // case *[16]stringRv: - // fkvs = vv[:newlen] - // case *[32]stringRv: - // fkvs = vv[:newlen] - // case *[64]stringRv: - // fkvs = vv[:newlen] - // case *[128]stringRv: - // fkvs = vv[:newlen] - // } - // } - - if newlen <= 8 { - p = &encStructPool[0] - v = p.Get() - s = v.(*[8]stringRv)[:newlen] - } else if newlen <= 16 { - p = &encStructPool[1] - v = p.Get() - s = v.(*[16]stringRv)[:newlen] - } else if newlen <= 32 { - p = &encStructPool[2] - v = p.Get() - s = v.(*[32]stringRv)[:newlen] - } else if newlen <= 64 { - p = &encStructPool[3] - v = p.Get() - s = v.(*[64]stringRv)[:newlen] - } else if newlen <= 128 { - p = &encStructPool[4] - v = p.Get() - s = v.(*[128]stringRv)[:newlen] - } else { - s = make([]stringRv, newlen) - } - return -} - -// ---------------------------------------- - -// func encErr(format string, params ...interface{}) { -// doPanic(msgTagEnc, format, params...) -// } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.generated.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.generated.go deleted file mode 100644 index d968a50..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.generated.go +++ /dev/null @@ -1,38900 +0,0 @@ -// +build !notfastpath - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED from fast-path.go.tmpl -// ************************************************************ - -package codec - -// Fast path functions try to create a fast path encode or decode implementation -// for common maps and slices. -// -// We define the functions and register then in this single file -// so as not to pollute the encode.go and decode.go, and create a dependency in there. -// This file can be omitted without causing a build failure. -// -// The advantage of fast paths is: -// - Many calls bypass reflection altogether -// -// Currently support -// - slice of all builtin types, -// - map of all builtin types to string or interface value -// - symetrical maps of all builtin types (e.g. str-str, uint8-uint8) -// This should provide adequate "typical" implementations. -// -// Note that fast track decode functions must handle values for which an address cannot be obtained. -// For example: -// m2 := map[string]int{} -// p2 := []interface{}{m2} -// // decoding into p2 will bomb if fast track functions do not treat like unaddressable. -// - -import ( - "reflect" - "sort" -) - -const fastpathCheckNilFalse = false // for reflect -const fastpathCheckNilTrue = true // for type switch - -type fastpathT struct{} - -var fastpathTV fastpathT - -type fastpathE struct { - rtid uintptr - rt reflect.Type - encfn func(*encFnInfo, reflect.Value) - decfn func(*decFnInfo, reflect.Value) -} - -type fastpathA [271]fastpathE - -func (x *fastpathA) index(rtid uintptr) int { - // use binary search to grab the index (adapted from sort/search.go) - h, i, j := 0, 0, 271 // len(x) - for i < j { - h = i + (j-i)/2 - if x[h].rtid < rtid { - i = h + 1 - } else { - j = h - } - } - if i < 271 && x[i].rtid == rtid { - return i - } - return -1 -} - -type fastpathAslice []fastpathE - -func (x fastpathAslice) Len() int { return len(x) } -func (x fastpathAslice) Less(i, j int) bool { return x[i].rtid < x[j].rtid } -func (x fastpathAslice) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -var fastpathAV fastpathA - -// due to possible initialization loop error, make fastpath in an init() -func init() { - if !fastpathEnabled { - return - } - i := 0 - fn := func(v interface{}, fe func(*encFnInfo, reflect.Value), fd func(*decFnInfo, reflect.Value)) (f fastpathE) { - xrt := reflect.TypeOf(v) - xptr := reflect.ValueOf(xrt).Pointer() - fastpathAV[i] = fastpathE{xptr, xrt, fe, fd} - i++ - return - } - - fn([]interface{}(nil), (*encFnInfo).fastpathEncSliceIntfR, (*decFnInfo).fastpathDecSliceIntfR) - fn([]string(nil), (*encFnInfo).fastpathEncSliceStringR, (*decFnInfo).fastpathDecSliceStringR) - fn([]float32(nil), (*encFnInfo).fastpathEncSliceFloat32R, (*decFnInfo).fastpathDecSliceFloat32R) - fn([]float64(nil), (*encFnInfo).fastpathEncSliceFloat64R, (*decFnInfo).fastpathDecSliceFloat64R) - fn([]uint(nil), (*encFnInfo).fastpathEncSliceUintR, (*decFnInfo).fastpathDecSliceUintR) - fn([]uint16(nil), (*encFnInfo).fastpathEncSliceUint16R, (*decFnInfo).fastpathDecSliceUint16R) - fn([]uint32(nil), (*encFnInfo).fastpathEncSliceUint32R, (*decFnInfo).fastpathDecSliceUint32R) - fn([]uint64(nil), (*encFnInfo).fastpathEncSliceUint64R, (*decFnInfo).fastpathDecSliceUint64R) - fn([]uintptr(nil), (*encFnInfo).fastpathEncSliceUintptrR, (*decFnInfo).fastpathDecSliceUintptrR) - fn([]int(nil), (*encFnInfo).fastpathEncSliceIntR, (*decFnInfo).fastpathDecSliceIntR) - fn([]int8(nil), (*encFnInfo).fastpathEncSliceInt8R, (*decFnInfo).fastpathDecSliceInt8R) - fn([]int16(nil), (*encFnInfo).fastpathEncSliceInt16R, (*decFnInfo).fastpathDecSliceInt16R) - fn([]int32(nil), (*encFnInfo).fastpathEncSliceInt32R, (*decFnInfo).fastpathDecSliceInt32R) - fn([]int64(nil), (*encFnInfo).fastpathEncSliceInt64R, (*decFnInfo).fastpathDecSliceInt64R) - fn([]bool(nil), (*encFnInfo).fastpathEncSliceBoolR, (*decFnInfo).fastpathDecSliceBoolR) - - fn(map[interface{}]interface{}(nil), (*encFnInfo).fastpathEncMapIntfIntfR, (*decFnInfo).fastpathDecMapIntfIntfR) - fn(map[interface{}]string(nil), (*encFnInfo).fastpathEncMapIntfStringR, (*decFnInfo).fastpathDecMapIntfStringR) - fn(map[interface{}]uint(nil), (*encFnInfo).fastpathEncMapIntfUintR, (*decFnInfo).fastpathDecMapIntfUintR) - fn(map[interface{}]uint8(nil), (*encFnInfo).fastpathEncMapIntfUint8R, (*decFnInfo).fastpathDecMapIntfUint8R) - fn(map[interface{}]uint16(nil), (*encFnInfo).fastpathEncMapIntfUint16R, (*decFnInfo).fastpathDecMapIntfUint16R) - fn(map[interface{}]uint32(nil), (*encFnInfo).fastpathEncMapIntfUint32R, (*decFnInfo).fastpathDecMapIntfUint32R) - fn(map[interface{}]uint64(nil), (*encFnInfo).fastpathEncMapIntfUint64R, (*decFnInfo).fastpathDecMapIntfUint64R) - fn(map[interface{}]uintptr(nil), (*encFnInfo).fastpathEncMapIntfUintptrR, (*decFnInfo).fastpathDecMapIntfUintptrR) - fn(map[interface{}]int(nil), (*encFnInfo).fastpathEncMapIntfIntR, (*decFnInfo).fastpathDecMapIntfIntR) - fn(map[interface{}]int8(nil), (*encFnInfo).fastpathEncMapIntfInt8R, (*decFnInfo).fastpathDecMapIntfInt8R) - fn(map[interface{}]int16(nil), (*encFnInfo).fastpathEncMapIntfInt16R, (*decFnInfo).fastpathDecMapIntfInt16R) - fn(map[interface{}]int32(nil), (*encFnInfo).fastpathEncMapIntfInt32R, (*decFnInfo).fastpathDecMapIntfInt32R) - fn(map[interface{}]int64(nil), (*encFnInfo).fastpathEncMapIntfInt64R, (*decFnInfo).fastpathDecMapIntfInt64R) - fn(map[interface{}]float32(nil), (*encFnInfo).fastpathEncMapIntfFloat32R, (*decFnInfo).fastpathDecMapIntfFloat32R) - fn(map[interface{}]float64(nil), (*encFnInfo).fastpathEncMapIntfFloat64R, (*decFnInfo).fastpathDecMapIntfFloat64R) - fn(map[interface{}]bool(nil), (*encFnInfo).fastpathEncMapIntfBoolR, (*decFnInfo).fastpathDecMapIntfBoolR) - fn(map[string]interface{}(nil), (*encFnInfo).fastpathEncMapStringIntfR, (*decFnInfo).fastpathDecMapStringIntfR) - fn(map[string]string(nil), (*encFnInfo).fastpathEncMapStringStringR, (*decFnInfo).fastpathDecMapStringStringR) - fn(map[string]uint(nil), (*encFnInfo).fastpathEncMapStringUintR, (*decFnInfo).fastpathDecMapStringUintR) - fn(map[string]uint8(nil), (*encFnInfo).fastpathEncMapStringUint8R, (*decFnInfo).fastpathDecMapStringUint8R) - fn(map[string]uint16(nil), (*encFnInfo).fastpathEncMapStringUint16R, (*decFnInfo).fastpathDecMapStringUint16R) - fn(map[string]uint32(nil), (*encFnInfo).fastpathEncMapStringUint32R, (*decFnInfo).fastpathDecMapStringUint32R) - fn(map[string]uint64(nil), (*encFnInfo).fastpathEncMapStringUint64R, (*decFnInfo).fastpathDecMapStringUint64R) - fn(map[string]uintptr(nil), (*encFnInfo).fastpathEncMapStringUintptrR, (*decFnInfo).fastpathDecMapStringUintptrR) - fn(map[string]int(nil), (*encFnInfo).fastpathEncMapStringIntR, (*decFnInfo).fastpathDecMapStringIntR) - fn(map[string]int8(nil), (*encFnInfo).fastpathEncMapStringInt8R, (*decFnInfo).fastpathDecMapStringInt8R) - fn(map[string]int16(nil), (*encFnInfo).fastpathEncMapStringInt16R, (*decFnInfo).fastpathDecMapStringInt16R) - fn(map[string]int32(nil), (*encFnInfo).fastpathEncMapStringInt32R, (*decFnInfo).fastpathDecMapStringInt32R) - fn(map[string]int64(nil), (*encFnInfo).fastpathEncMapStringInt64R, (*decFnInfo).fastpathDecMapStringInt64R) - fn(map[string]float32(nil), (*encFnInfo).fastpathEncMapStringFloat32R, (*decFnInfo).fastpathDecMapStringFloat32R) - fn(map[string]float64(nil), (*encFnInfo).fastpathEncMapStringFloat64R, (*decFnInfo).fastpathDecMapStringFloat64R) - fn(map[string]bool(nil), (*encFnInfo).fastpathEncMapStringBoolR, (*decFnInfo).fastpathDecMapStringBoolR) - fn(map[float32]interface{}(nil), (*encFnInfo).fastpathEncMapFloat32IntfR, (*decFnInfo).fastpathDecMapFloat32IntfR) - fn(map[float32]string(nil), (*encFnInfo).fastpathEncMapFloat32StringR, (*decFnInfo).fastpathDecMapFloat32StringR) - fn(map[float32]uint(nil), (*encFnInfo).fastpathEncMapFloat32UintR, (*decFnInfo).fastpathDecMapFloat32UintR) - fn(map[float32]uint8(nil), (*encFnInfo).fastpathEncMapFloat32Uint8R, (*decFnInfo).fastpathDecMapFloat32Uint8R) - fn(map[float32]uint16(nil), (*encFnInfo).fastpathEncMapFloat32Uint16R, (*decFnInfo).fastpathDecMapFloat32Uint16R) - fn(map[float32]uint32(nil), (*encFnInfo).fastpathEncMapFloat32Uint32R, (*decFnInfo).fastpathDecMapFloat32Uint32R) - fn(map[float32]uint64(nil), (*encFnInfo).fastpathEncMapFloat32Uint64R, (*decFnInfo).fastpathDecMapFloat32Uint64R) - fn(map[float32]uintptr(nil), (*encFnInfo).fastpathEncMapFloat32UintptrR, (*decFnInfo).fastpathDecMapFloat32UintptrR) - fn(map[float32]int(nil), (*encFnInfo).fastpathEncMapFloat32IntR, (*decFnInfo).fastpathDecMapFloat32IntR) - fn(map[float32]int8(nil), (*encFnInfo).fastpathEncMapFloat32Int8R, (*decFnInfo).fastpathDecMapFloat32Int8R) - fn(map[float32]int16(nil), (*encFnInfo).fastpathEncMapFloat32Int16R, (*decFnInfo).fastpathDecMapFloat32Int16R) - fn(map[float32]int32(nil), (*encFnInfo).fastpathEncMapFloat32Int32R, (*decFnInfo).fastpathDecMapFloat32Int32R) - fn(map[float32]int64(nil), (*encFnInfo).fastpathEncMapFloat32Int64R, (*decFnInfo).fastpathDecMapFloat32Int64R) - fn(map[float32]float32(nil), (*encFnInfo).fastpathEncMapFloat32Float32R, (*decFnInfo).fastpathDecMapFloat32Float32R) - fn(map[float32]float64(nil), (*encFnInfo).fastpathEncMapFloat32Float64R, (*decFnInfo).fastpathDecMapFloat32Float64R) - fn(map[float32]bool(nil), (*encFnInfo).fastpathEncMapFloat32BoolR, (*decFnInfo).fastpathDecMapFloat32BoolR) - fn(map[float64]interface{}(nil), (*encFnInfo).fastpathEncMapFloat64IntfR, (*decFnInfo).fastpathDecMapFloat64IntfR) - fn(map[float64]string(nil), (*encFnInfo).fastpathEncMapFloat64StringR, (*decFnInfo).fastpathDecMapFloat64StringR) - fn(map[float64]uint(nil), (*encFnInfo).fastpathEncMapFloat64UintR, (*decFnInfo).fastpathDecMapFloat64UintR) - fn(map[float64]uint8(nil), (*encFnInfo).fastpathEncMapFloat64Uint8R, (*decFnInfo).fastpathDecMapFloat64Uint8R) - fn(map[float64]uint16(nil), (*encFnInfo).fastpathEncMapFloat64Uint16R, (*decFnInfo).fastpathDecMapFloat64Uint16R) - fn(map[float64]uint32(nil), (*encFnInfo).fastpathEncMapFloat64Uint32R, (*decFnInfo).fastpathDecMapFloat64Uint32R) - fn(map[float64]uint64(nil), (*encFnInfo).fastpathEncMapFloat64Uint64R, (*decFnInfo).fastpathDecMapFloat64Uint64R) - fn(map[float64]uintptr(nil), (*encFnInfo).fastpathEncMapFloat64UintptrR, (*decFnInfo).fastpathDecMapFloat64UintptrR) - fn(map[float64]int(nil), (*encFnInfo).fastpathEncMapFloat64IntR, (*decFnInfo).fastpathDecMapFloat64IntR) - fn(map[float64]int8(nil), (*encFnInfo).fastpathEncMapFloat64Int8R, (*decFnInfo).fastpathDecMapFloat64Int8R) - fn(map[float64]int16(nil), (*encFnInfo).fastpathEncMapFloat64Int16R, (*decFnInfo).fastpathDecMapFloat64Int16R) - fn(map[float64]int32(nil), (*encFnInfo).fastpathEncMapFloat64Int32R, (*decFnInfo).fastpathDecMapFloat64Int32R) - fn(map[float64]int64(nil), (*encFnInfo).fastpathEncMapFloat64Int64R, (*decFnInfo).fastpathDecMapFloat64Int64R) - fn(map[float64]float32(nil), (*encFnInfo).fastpathEncMapFloat64Float32R, (*decFnInfo).fastpathDecMapFloat64Float32R) - fn(map[float64]float64(nil), (*encFnInfo).fastpathEncMapFloat64Float64R, (*decFnInfo).fastpathDecMapFloat64Float64R) - fn(map[float64]bool(nil), (*encFnInfo).fastpathEncMapFloat64BoolR, (*decFnInfo).fastpathDecMapFloat64BoolR) - fn(map[uint]interface{}(nil), (*encFnInfo).fastpathEncMapUintIntfR, (*decFnInfo).fastpathDecMapUintIntfR) - fn(map[uint]string(nil), (*encFnInfo).fastpathEncMapUintStringR, (*decFnInfo).fastpathDecMapUintStringR) - fn(map[uint]uint(nil), (*encFnInfo).fastpathEncMapUintUintR, (*decFnInfo).fastpathDecMapUintUintR) - fn(map[uint]uint8(nil), (*encFnInfo).fastpathEncMapUintUint8R, (*decFnInfo).fastpathDecMapUintUint8R) - fn(map[uint]uint16(nil), (*encFnInfo).fastpathEncMapUintUint16R, (*decFnInfo).fastpathDecMapUintUint16R) - fn(map[uint]uint32(nil), (*encFnInfo).fastpathEncMapUintUint32R, (*decFnInfo).fastpathDecMapUintUint32R) - fn(map[uint]uint64(nil), (*encFnInfo).fastpathEncMapUintUint64R, (*decFnInfo).fastpathDecMapUintUint64R) - fn(map[uint]uintptr(nil), (*encFnInfo).fastpathEncMapUintUintptrR, (*decFnInfo).fastpathDecMapUintUintptrR) - fn(map[uint]int(nil), (*encFnInfo).fastpathEncMapUintIntR, (*decFnInfo).fastpathDecMapUintIntR) - fn(map[uint]int8(nil), (*encFnInfo).fastpathEncMapUintInt8R, (*decFnInfo).fastpathDecMapUintInt8R) - fn(map[uint]int16(nil), (*encFnInfo).fastpathEncMapUintInt16R, (*decFnInfo).fastpathDecMapUintInt16R) - fn(map[uint]int32(nil), (*encFnInfo).fastpathEncMapUintInt32R, (*decFnInfo).fastpathDecMapUintInt32R) - fn(map[uint]int64(nil), (*encFnInfo).fastpathEncMapUintInt64R, (*decFnInfo).fastpathDecMapUintInt64R) - fn(map[uint]float32(nil), (*encFnInfo).fastpathEncMapUintFloat32R, (*decFnInfo).fastpathDecMapUintFloat32R) - fn(map[uint]float64(nil), (*encFnInfo).fastpathEncMapUintFloat64R, (*decFnInfo).fastpathDecMapUintFloat64R) - fn(map[uint]bool(nil), (*encFnInfo).fastpathEncMapUintBoolR, (*decFnInfo).fastpathDecMapUintBoolR) - fn(map[uint8]interface{}(nil), (*encFnInfo).fastpathEncMapUint8IntfR, (*decFnInfo).fastpathDecMapUint8IntfR) - fn(map[uint8]string(nil), (*encFnInfo).fastpathEncMapUint8StringR, (*decFnInfo).fastpathDecMapUint8StringR) - fn(map[uint8]uint(nil), (*encFnInfo).fastpathEncMapUint8UintR, (*decFnInfo).fastpathDecMapUint8UintR) - fn(map[uint8]uint8(nil), (*encFnInfo).fastpathEncMapUint8Uint8R, (*decFnInfo).fastpathDecMapUint8Uint8R) - fn(map[uint8]uint16(nil), (*encFnInfo).fastpathEncMapUint8Uint16R, (*decFnInfo).fastpathDecMapUint8Uint16R) - fn(map[uint8]uint32(nil), (*encFnInfo).fastpathEncMapUint8Uint32R, (*decFnInfo).fastpathDecMapUint8Uint32R) - fn(map[uint8]uint64(nil), (*encFnInfo).fastpathEncMapUint8Uint64R, (*decFnInfo).fastpathDecMapUint8Uint64R) - fn(map[uint8]uintptr(nil), (*encFnInfo).fastpathEncMapUint8UintptrR, (*decFnInfo).fastpathDecMapUint8UintptrR) - fn(map[uint8]int(nil), (*encFnInfo).fastpathEncMapUint8IntR, (*decFnInfo).fastpathDecMapUint8IntR) - fn(map[uint8]int8(nil), (*encFnInfo).fastpathEncMapUint8Int8R, (*decFnInfo).fastpathDecMapUint8Int8R) - fn(map[uint8]int16(nil), (*encFnInfo).fastpathEncMapUint8Int16R, (*decFnInfo).fastpathDecMapUint8Int16R) - fn(map[uint8]int32(nil), (*encFnInfo).fastpathEncMapUint8Int32R, (*decFnInfo).fastpathDecMapUint8Int32R) - fn(map[uint8]int64(nil), (*encFnInfo).fastpathEncMapUint8Int64R, (*decFnInfo).fastpathDecMapUint8Int64R) - fn(map[uint8]float32(nil), (*encFnInfo).fastpathEncMapUint8Float32R, (*decFnInfo).fastpathDecMapUint8Float32R) - fn(map[uint8]float64(nil), (*encFnInfo).fastpathEncMapUint8Float64R, (*decFnInfo).fastpathDecMapUint8Float64R) - fn(map[uint8]bool(nil), (*encFnInfo).fastpathEncMapUint8BoolR, (*decFnInfo).fastpathDecMapUint8BoolR) - fn(map[uint16]interface{}(nil), (*encFnInfo).fastpathEncMapUint16IntfR, (*decFnInfo).fastpathDecMapUint16IntfR) - fn(map[uint16]string(nil), (*encFnInfo).fastpathEncMapUint16StringR, (*decFnInfo).fastpathDecMapUint16StringR) - fn(map[uint16]uint(nil), (*encFnInfo).fastpathEncMapUint16UintR, (*decFnInfo).fastpathDecMapUint16UintR) - fn(map[uint16]uint8(nil), (*encFnInfo).fastpathEncMapUint16Uint8R, (*decFnInfo).fastpathDecMapUint16Uint8R) - fn(map[uint16]uint16(nil), (*encFnInfo).fastpathEncMapUint16Uint16R, (*decFnInfo).fastpathDecMapUint16Uint16R) - fn(map[uint16]uint32(nil), (*encFnInfo).fastpathEncMapUint16Uint32R, (*decFnInfo).fastpathDecMapUint16Uint32R) - fn(map[uint16]uint64(nil), (*encFnInfo).fastpathEncMapUint16Uint64R, (*decFnInfo).fastpathDecMapUint16Uint64R) - fn(map[uint16]uintptr(nil), (*encFnInfo).fastpathEncMapUint16UintptrR, (*decFnInfo).fastpathDecMapUint16UintptrR) - fn(map[uint16]int(nil), (*encFnInfo).fastpathEncMapUint16IntR, (*decFnInfo).fastpathDecMapUint16IntR) - fn(map[uint16]int8(nil), (*encFnInfo).fastpathEncMapUint16Int8R, (*decFnInfo).fastpathDecMapUint16Int8R) - fn(map[uint16]int16(nil), (*encFnInfo).fastpathEncMapUint16Int16R, (*decFnInfo).fastpathDecMapUint16Int16R) - fn(map[uint16]int32(nil), (*encFnInfo).fastpathEncMapUint16Int32R, (*decFnInfo).fastpathDecMapUint16Int32R) - fn(map[uint16]int64(nil), (*encFnInfo).fastpathEncMapUint16Int64R, (*decFnInfo).fastpathDecMapUint16Int64R) - fn(map[uint16]float32(nil), (*encFnInfo).fastpathEncMapUint16Float32R, (*decFnInfo).fastpathDecMapUint16Float32R) - fn(map[uint16]float64(nil), (*encFnInfo).fastpathEncMapUint16Float64R, (*decFnInfo).fastpathDecMapUint16Float64R) - fn(map[uint16]bool(nil), (*encFnInfo).fastpathEncMapUint16BoolR, (*decFnInfo).fastpathDecMapUint16BoolR) - fn(map[uint32]interface{}(nil), (*encFnInfo).fastpathEncMapUint32IntfR, (*decFnInfo).fastpathDecMapUint32IntfR) - fn(map[uint32]string(nil), (*encFnInfo).fastpathEncMapUint32StringR, (*decFnInfo).fastpathDecMapUint32StringR) - fn(map[uint32]uint(nil), (*encFnInfo).fastpathEncMapUint32UintR, (*decFnInfo).fastpathDecMapUint32UintR) - fn(map[uint32]uint8(nil), (*encFnInfo).fastpathEncMapUint32Uint8R, (*decFnInfo).fastpathDecMapUint32Uint8R) - fn(map[uint32]uint16(nil), (*encFnInfo).fastpathEncMapUint32Uint16R, (*decFnInfo).fastpathDecMapUint32Uint16R) - fn(map[uint32]uint32(nil), (*encFnInfo).fastpathEncMapUint32Uint32R, (*decFnInfo).fastpathDecMapUint32Uint32R) - fn(map[uint32]uint64(nil), (*encFnInfo).fastpathEncMapUint32Uint64R, (*decFnInfo).fastpathDecMapUint32Uint64R) - fn(map[uint32]uintptr(nil), (*encFnInfo).fastpathEncMapUint32UintptrR, (*decFnInfo).fastpathDecMapUint32UintptrR) - fn(map[uint32]int(nil), (*encFnInfo).fastpathEncMapUint32IntR, (*decFnInfo).fastpathDecMapUint32IntR) - fn(map[uint32]int8(nil), (*encFnInfo).fastpathEncMapUint32Int8R, (*decFnInfo).fastpathDecMapUint32Int8R) - fn(map[uint32]int16(nil), (*encFnInfo).fastpathEncMapUint32Int16R, (*decFnInfo).fastpathDecMapUint32Int16R) - fn(map[uint32]int32(nil), (*encFnInfo).fastpathEncMapUint32Int32R, (*decFnInfo).fastpathDecMapUint32Int32R) - fn(map[uint32]int64(nil), (*encFnInfo).fastpathEncMapUint32Int64R, (*decFnInfo).fastpathDecMapUint32Int64R) - fn(map[uint32]float32(nil), (*encFnInfo).fastpathEncMapUint32Float32R, (*decFnInfo).fastpathDecMapUint32Float32R) - fn(map[uint32]float64(nil), (*encFnInfo).fastpathEncMapUint32Float64R, (*decFnInfo).fastpathDecMapUint32Float64R) - fn(map[uint32]bool(nil), (*encFnInfo).fastpathEncMapUint32BoolR, (*decFnInfo).fastpathDecMapUint32BoolR) - fn(map[uint64]interface{}(nil), (*encFnInfo).fastpathEncMapUint64IntfR, (*decFnInfo).fastpathDecMapUint64IntfR) - fn(map[uint64]string(nil), (*encFnInfo).fastpathEncMapUint64StringR, (*decFnInfo).fastpathDecMapUint64StringR) - fn(map[uint64]uint(nil), (*encFnInfo).fastpathEncMapUint64UintR, (*decFnInfo).fastpathDecMapUint64UintR) - fn(map[uint64]uint8(nil), (*encFnInfo).fastpathEncMapUint64Uint8R, (*decFnInfo).fastpathDecMapUint64Uint8R) - fn(map[uint64]uint16(nil), (*encFnInfo).fastpathEncMapUint64Uint16R, (*decFnInfo).fastpathDecMapUint64Uint16R) - fn(map[uint64]uint32(nil), (*encFnInfo).fastpathEncMapUint64Uint32R, (*decFnInfo).fastpathDecMapUint64Uint32R) - fn(map[uint64]uint64(nil), (*encFnInfo).fastpathEncMapUint64Uint64R, (*decFnInfo).fastpathDecMapUint64Uint64R) - fn(map[uint64]uintptr(nil), (*encFnInfo).fastpathEncMapUint64UintptrR, (*decFnInfo).fastpathDecMapUint64UintptrR) - fn(map[uint64]int(nil), (*encFnInfo).fastpathEncMapUint64IntR, (*decFnInfo).fastpathDecMapUint64IntR) - fn(map[uint64]int8(nil), (*encFnInfo).fastpathEncMapUint64Int8R, (*decFnInfo).fastpathDecMapUint64Int8R) - fn(map[uint64]int16(nil), (*encFnInfo).fastpathEncMapUint64Int16R, (*decFnInfo).fastpathDecMapUint64Int16R) - fn(map[uint64]int32(nil), (*encFnInfo).fastpathEncMapUint64Int32R, (*decFnInfo).fastpathDecMapUint64Int32R) - fn(map[uint64]int64(nil), (*encFnInfo).fastpathEncMapUint64Int64R, (*decFnInfo).fastpathDecMapUint64Int64R) - fn(map[uint64]float32(nil), (*encFnInfo).fastpathEncMapUint64Float32R, (*decFnInfo).fastpathDecMapUint64Float32R) - fn(map[uint64]float64(nil), (*encFnInfo).fastpathEncMapUint64Float64R, (*decFnInfo).fastpathDecMapUint64Float64R) - fn(map[uint64]bool(nil), (*encFnInfo).fastpathEncMapUint64BoolR, (*decFnInfo).fastpathDecMapUint64BoolR) - fn(map[uintptr]interface{}(nil), (*encFnInfo).fastpathEncMapUintptrIntfR, (*decFnInfo).fastpathDecMapUintptrIntfR) - fn(map[uintptr]string(nil), (*encFnInfo).fastpathEncMapUintptrStringR, (*decFnInfo).fastpathDecMapUintptrStringR) - fn(map[uintptr]uint(nil), (*encFnInfo).fastpathEncMapUintptrUintR, (*decFnInfo).fastpathDecMapUintptrUintR) - fn(map[uintptr]uint8(nil), (*encFnInfo).fastpathEncMapUintptrUint8R, (*decFnInfo).fastpathDecMapUintptrUint8R) - fn(map[uintptr]uint16(nil), (*encFnInfo).fastpathEncMapUintptrUint16R, (*decFnInfo).fastpathDecMapUintptrUint16R) - fn(map[uintptr]uint32(nil), (*encFnInfo).fastpathEncMapUintptrUint32R, (*decFnInfo).fastpathDecMapUintptrUint32R) - fn(map[uintptr]uint64(nil), (*encFnInfo).fastpathEncMapUintptrUint64R, (*decFnInfo).fastpathDecMapUintptrUint64R) - fn(map[uintptr]uintptr(nil), (*encFnInfo).fastpathEncMapUintptrUintptrR, (*decFnInfo).fastpathDecMapUintptrUintptrR) - fn(map[uintptr]int(nil), (*encFnInfo).fastpathEncMapUintptrIntR, (*decFnInfo).fastpathDecMapUintptrIntR) - fn(map[uintptr]int8(nil), (*encFnInfo).fastpathEncMapUintptrInt8R, (*decFnInfo).fastpathDecMapUintptrInt8R) - fn(map[uintptr]int16(nil), (*encFnInfo).fastpathEncMapUintptrInt16R, (*decFnInfo).fastpathDecMapUintptrInt16R) - fn(map[uintptr]int32(nil), (*encFnInfo).fastpathEncMapUintptrInt32R, (*decFnInfo).fastpathDecMapUintptrInt32R) - fn(map[uintptr]int64(nil), (*encFnInfo).fastpathEncMapUintptrInt64R, (*decFnInfo).fastpathDecMapUintptrInt64R) - fn(map[uintptr]float32(nil), (*encFnInfo).fastpathEncMapUintptrFloat32R, (*decFnInfo).fastpathDecMapUintptrFloat32R) - fn(map[uintptr]float64(nil), (*encFnInfo).fastpathEncMapUintptrFloat64R, (*decFnInfo).fastpathDecMapUintptrFloat64R) - fn(map[uintptr]bool(nil), (*encFnInfo).fastpathEncMapUintptrBoolR, (*decFnInfo).fastpathDecMapUintptrBoolR) - fn(map[int]interface{}(nil), (*encFnInfo).fastpathEncMapIntIntfR, (*decFnInfo).fastpathDecMapIntIntfR) - fn(map[int]string(nil), (*encFnInfo).fastpathEncMapIntStringR, (*decFnInfo).fastpathDecMapIntStringR) - fn(map[int]uint(nil), (*encFnInfo).fastpathEncMapIntUintR, (*decFnInfo).fastpathDecMapIntUintR) - fn(map[int]uint8(nil), (*encFnInfo).fastpathEncMapIntUint8R, (*decFnInfo).fastpathDecMapIntUint8R) - fn(map[int]uint16(nil), (*encFnInfo).fastpathEncMapIntUint16R, (*decFnInfo).fastpathDecMapIntUint16R) - fn(map[int]uint32(nil), (*encFnInfo).fastpathEncMapIntUint32R, (*decFnInfo).fastpathDecMapIntUint32R) - fn(map[int]uint64(nil), (*encFnInfo).fastpathEncMapIntUint64R, (*decFnInfo).fastpathDecMapIntUint64R) - fn(map[int]uintptr(nil), (*encFnInfo).fastpathEncMapIntUintptrR, (*decFnInfo).fastpathDecMapIntUintptrR) - fn(map[int]int(nil), (*encFnInfo).fastpathEncMapIntIntR, (*decFnInfo).fastpathDecMapIntIntR) - fn(map[int]int8(nil), (*encFnInfo).fastpathEncMapIntInt8R, (*decFnInfo).fastpathDecMapIntInt8R) - fn(map[int]int16(nil), (*encFnInfo).fastpathEncMapIntInt16R, (*decFnInfo).fastpathDecMapIntInt16R) - fn(map[int]int32(nil), (*encFnInfo).fastpathEncMapIntInt32R, (*decFnInfo).fastpathDecMapIntInt32R) - fn(map[int]int64(nil), (*encFnInfo).fastpathEncMapIntInt64R, (*decFnInfo).fastpathDecMapIntInt64R) - fn(map[int]float32(nil), (*encFnInfo).fastpathEncMapIntFloat32R, (*decFnInfo).fastpathDecMapIntFloat32R) - fn(map[int]float64(nil), (*encFnInfo).fastpathEncMapIntFloat64R, (*decFnInfo).fastpathDecMapIntFloat64R) - fn(map[int]bool(nil), (*encFnInfo).fastpathEncMapIntBoolR, (*decFnInfo).fastpathDecMapIntBoolR) - fn(map[int8]interface{}(nil), (*encFnInfo).fastpathEncMapInt8IntfR, (*decFnInfo).fastpathDecMapInt8IntfR) - fn(map[int8]string(nil), (*encFnInfo).fastpathEncMapInt8StringR, (*decFnInfo).fastpathDecMapInt8StringR) - fn(map[int8]uint(nil), (*encFnInfo).fastpathEncMapInt8UintR, (*decFnInfo).fastpathDecMapInt8UintR) - fn(map[int8]uint8(nil), (*encFnInfo).fastpathEncMapInt8Uint8R, (*decFnInfo).fastpathDecMapInt8Uint8R) - fn(map[int8]uint16(nil), (*encFnInfo).fastpathEncMapInt8Uint16R, (*decFnInfo).fastpathDecMapInt8Uint16R) - fn(map[int8]uint32(nil), (*encFnInfo).fastpathEncMapInt8Uint32R, (*decFnInfo).fastpathDecMapInt8Uint32R) - fn(map[int8]uint64(nil), (*encFnInfo).fastpathEncMapInt8Uint64R, (*decFnInfo).fastpathDecMapInt8Uint64R) - fn(map[int8]uintptr(nil), (*encFnInfo).fastpathEncMapInt8UintptrR, (*decFnInfo).fastpathDecMapInt8UintptrR) - fn(map[int8]int(nil), (*encFnInfo).fastpathEncMapInt8IntR, (*decFnInfo).fastpathDecMapInt8IntR) - fn(map[int8]int8(nil), (*encFnInfo).fastpathEncMapInt8Int8R, (*decFnInfo).fastpathDecMapInt8Int8R) - fn(map[int8]int16(nil), (*encFnInfo).fastpathEncMapInt8Int16R, (*decFnInfo).fastpathDecMapInt8Int16R) - fn(map[int8]int32(nil), (*encFnInfo).fastpathEncMapInt8Int32R, (*decFnInfo).fastpathDecMapInt8Int32R) - fn(map[int8]int64(nil), (*encFnInfo).fastpathEncMapInt8Int64R, (*decFnInfo).fastpathDecMapInt8Int64R) - fn(map[int8]float32(nil), (*encFnInfo).fastpathEncMapInt8Float32R, (*decFnInfo).fastpathDecMapInt8Float32R) - fn(map[int8]float64(nil), (*encFnInfo).fastpathEncMapInt8Float64R, (*decFnInfo).fastpathDecMapInt8Float64R) - fn(map[int8]bool(nil), (*encFnInfo).fastpathEncMapInt8BoolR, (*decFnInfo).fastpathDecMapInt8BoolR) - fn(map[int16]interface{}(nil), (*encFnInfo).fastpathEncMapInt16IntfR, (*decFnInfo).fastpathDecMapInt16IntfR) - fn(map[int16]string(nil), (*encFnInfo).fastpathEncMapInt16StringR, (*decFnInfo).fastpathDecMapInt16StringR) - fn(map[int16]uint(nil), (*encFnInfo).fastpathEncMapInt16UintR, (*decFnInfo).fastpathDecMapInt16UintR) - fn(map[int16]uint8(nil), (*encFnInfo).fastpathEncMapInt16Uint8R, (*decFnInfo).fastpathDecMapInt16Uint8R) - fn(map[int16]uint16(nil), (*encFnInfo).fastpathEncMapInt16Uint16R, (*decFnInfo).fastpathDecMapInt16Uint16R) - fn(map[int16]uint32(nil), (*encFnInfo).fastpathEncMapInt16Uint32R, (*decFnInfo).fastpathDecMapInt16Uint32R) - fn(map[int16]uint64(nil), (*encFnInfo).fastpathEncMapInt16Uint64R, (*decFnInfo).fastpathDecMapInt16Uint64R) - fn(map[int16]uintptr(nil), (*encFnInfo).fastpathEncMapInt16UintptrR, (*decFnInfo).fastpathDecMapInt16UintptrR) - fn(map[int16]int(nil), (*encFnInfo).fastpathEncMapInt16IntR, (*decFnInfo).fastpathDecMapInt16IntR) - fn(map[int16]int8(nil), (*encFnInfo).fastpathEncMapInt16Int8R, (*decFnInfo).fastpathDecMapInt16Int8R) - fn(map[int16]int16(nil), (*encFnInfo).fastpathEncMapInt16Int16R, (*decFnInfo).fastpathDecMapInt16Int16R) - fn(map[int16]int32(nil), (*encFnInfo).fastpathEncMapInt16Int32R, (*decFnInfo).fastpathDecMapInt16Int32R) - fn(map[int16]int64(nil), (*encFnInfo).fastpathEncMapInt16Int64R, (*decFnInfo).fastpathDecMapInt16Int64R) - fn(map[int16]float32(nil), (*encFnInfo).fastpathEncMapInt16Float32R, (*decFnInfo).fastpathDecMapInt16Float32R) - fn(map[int16]float64(nil), (*encFnInfo).fastpathEncMapInt16Float64R, (*decFnInfo).fastpathDecMapInt16Float64R) - fn(map[int16]bool(nil), (*encFnInfo).fastpathEncMapInt16BoolR, (*decFnInfo).fastpathDecMapInt16BoolR) - fn(map[int32]interface{}(nil), (*encFnInfo).fastpathEncMapInt32IntfR, (*decFnInfo).fastpathDecMapInt32IntfR) - fn(map[int32]string(nil), (*encFnInfo).fastpathEncMapInt32StringR, (*decFnInfo).fastpathDecMapInt32StringR) - fn(map[int32]uint(nil), (*encFnInfo).fastpathEncMapInt32UintR, (*decFnInfo).fastpathDecMapInt32UintR) - fn(map[int32]uint8(nil), (*encFnInfo).fastpathEncMapInt32Uint8R, (*decFnInfo).fastpathDecMapInt32Uint8R) - fn(map[int32]uint16(nil), (*encFnInfo).fastpathEncMapInt32Uint16R, (*decFnInfo).fastpathDecMapInt32Uint16R) - fn(map[int32]uint32(nil), (*encFnInfo).fastpathEncMapInt32Uint32R, (*decFnInfo).fastpathDecMapInt32Uint32R) - fn(map[int32]uint64(nil), (*encFnInfo).fastpathEncMapInt32Uint64R, (*decFnInfo).fastpathDecMapInt32Uint64R) - fn(map[int32]uintptr(nil), (*encFnInfo).fastpathEncMapInt32UintptrR, (*decFnInfo).fastpathDecMapInt32UintptrR) - fn(map[int32]int(nil), (*encFnInfo).fastpathEncMapInt32IntR, (*decFnInfo).fastpathDecMapInt32IntR) - fn(map[int32]int8(nil), (*encFnInfo).fastpathEncMapInt32Int8R, (*decFnInfo).fastpathDecMapInt32Int8R) - fn(map[int32]int16(nil), (*encFnInfo).fastpathEncMapInt32Int16R, (*decFnInfo).fastpathDecMapInt32Int16R) - fn(map[int32]int32(nil), (*encFnInfo).fastpathEncMapInt32Int32R, (*decFnInfo).fastpathDecMapInt32Int32R) - fn(map[int32]int64(nil), (*encFnInfo).fastpathEncMapInt32Int64R, (*decFnInfo).fastpathDecMapInt32Int64R) - fn(map[int32]float32(nil), (*encFnInfo).fastpathEncMapInt32Float32R, (*decFnInfo).fastpathDecMapInt32Float32R) - fn(map[int32]float64(nil), (*encFnInfo).fastpathEncMapInt32Float64R, (*decFnInfo).fastpathDecMapInt32Float64R) - fn(map[int32]bool(nil), (*encFnInfo).fastpathEncMapInt32BoolR, (*decFnInfo).fastpathDecMapInt32BoolR) - fn(map[int64]interface{}(nil), (*encFnInfo).fastpathEncMapInt64IntfR, (*decFnInfo).fastpathDecMapInt64IntfR) - fn(map[int64]string(nil), (*encFnInfo).fastpathEncMapInt64StringR, (*decFnInfo).fastpathDecMapInt64StringR) - fn(map[int64]uint(nil), (*encFnInfo).fastpathEncMapInt64UintR, (*decFnInfo).fastpathDecMapInt64UintR) - fn(map[int64]uint8(nil), (*encFnInfo).fastpathEncMapInt64Uint8R, (*decFnInfo).fastpathDecMapInt64Uint8R) - fn(map[int64]uint16(nil), (*encFnInfo).fastpathEncMapInt64Uint16R, (*decFnInfo).fastpathDecMapInt64Uint16R) - fn(map[int64]uint32(nil), (*encFnInfo).fastpathEncMapInt64Uint32R, (*decFnInfo).fastpathDecMapInt64Uint32R) - fn(map[int64]uint64(nil), (*encFnInfo).fastpathEncMapInt64Uint64R, (*decFnInfo).fastpathDecMapInt64Uint64R) - fn(map[int64]uintptr(nil), (*encFnInfo).fastpathEncMapInt64UintptrR, (*decFnInfo).fastpathDecMapInt64UintptrR) - fn(map[int64]int(nil), (*encFnInfo).fastpathEncMapInt64IntR, (*decFnInfo).fastpathDecMapInt64IntR) - fn(map[int64]int8(nil), (*encFnInfo).fastpathEncMapInt64Int8R, (*decFnInfo).fastpathDecMapInt64Int8R) - fn(map[int64]int16(nil), (*encFnInfo).fastpathEncMapInt64Int16R, (*decFnInfo).fastpathDecMapInt64Int16R) - fn(map[int64]int32(nil), (*encFnInfo).fastpathEncMapInt64Int32R, (*decFnInfo).fastpathDecMapInt64Int32R) - fn(map[int64]int64(nil), (*encFnInfo).fastpathEncMapInt64Int64R, (*decFnInfo).fastpathDecMapInt64Int64R) - fn(map[int64]float32(nil), (*encFnInfo).fastpathEncMapInt64Float32R, (*decFnInfo).fastpathDecMapInt64Float32R) - fn(map[int64]float64(nil), (*encFnInfo).fastpathEncMapInt64Float64R, (*decFnInfo).fastpathDecMapInt64Float64R) - fn(map[int64]bool(nil), (*encFnInfo).fastpathEncMapInt64BoolR, (*decFnInfo).fastpathDecMapInt64BoolR) - fn(map[bool]interface{}(nil), (*encFnInfo).fastpathEncMapBoolIntfR, (*decFnInfo).fastpathDecMapBoolIntfR) - fn(map[bool]string(nil), (*encFnInfo).fastpathEncMapBoolStringR, (*decFnInfo).fastpathDecMapBoolStringR) - fn(map[bool]uint(nil), (*encFnInfo).fastpathEncMapBoolUintR, (*decFnInfo).fastpathDecMapBoolUintR) - fn(map[bool]uint8(nil), (*encFnInfo).fastpathEncMapBoolUint8R, (*decFnInfo).fastpathDecMapBoolUint8R) - fn(map[bool]uint16(nil), (*encFnInfo).fastpathEncMapBoolUint16R, (*decFnInfo).fastpathDecMapBoolUint16R) - fn(map[bool]uint32(nil), (*encFnInfo).fastpathEncMapBoolUint32R, (*decFnInfo).fastpathDecMapBoolUint32R) - fn(map[bool]uint64(nil), (*encFnInfo).fastpathEncMapBoolUint64R, (*decFnInfo).fastpathDecMapBoolUint64R) - fn(map[bool]uintptr(nil), (*encFnInfo).fastpathEncMapBoolUintptrR, (*decFnInfo).fastpathDecMapBoolUintptrR) - fn(map[bool]int(nil), (*encFnInfo).fastpathEncMapBoolIntR, (*decFnInfo).fastpathDecMapBoolIntR) - fn(map[bool]int8(nil), (*encFnInfo).fastpathEncMapBoolInt8R, (*decFnInfo).fastpathDecMapBoolInt8R) - fn(map[bool]int16(nil), (*encFnInfo).fastpathEncMapBoolInt16R, (*decFnInfo).fastpathDecMapBoolInt16R) - fn(map[bool]int32(nil), (*encFnInfo).fastpathEncMapBoolInt32R, (*decFnInfo).fastpathDecMapBoolInt32R) - fn(map[bool]int64(nil), (*encFnInfo).fastpathEncMapBoolInt64R, (*decFnInfo).fastpathDecMapBoolInt64R) - fn(map[bool]float32(nil), (*encFnInfo).fastpathEncMapBoolFloat32R, (*decFnInfo).fastpathDecMapBoolFloat32R) - fn(map[bool]float64(nil), (*encFnInfo).fastpathEncMapBoolFloat64R, (*decFnInfo).fastpathDecMapBoolFloat64R) - fn(map[bool]bool(nil), (*encFnInfo).fastpathEncMapBoolBoolR, (*decFnInfo).fastpathDecMapBoolBoolR) - - sort.Sort(fastpathAslice(fastpathAV[:])) -} - -// -- encode - -// -- -- fast path type switch -func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { - - case []interface{}: - fastpathTV.EncSliceIntfV(v, fastpathCheckNilTrue, e) - case *[]interface{}: - fastpathTV.EncSliceIntfV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]interface{}: - fastpathTV.EncMapIntfIntfV(v, fastpathCheckNilTrue, e) - case *map[interface{}]interface{}: - fastpathTV.EncMapIntfIntfV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]string: - fastpathTV.EncMapIntfStringV(v, fastpathCheckNilTrue, e) - case *map[interface{}]string: - fastpathTV.EncMapIntfStringV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint: - fastpathTV.EncMapIntfUintV(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint: - fastpathTV.EncMapIntfUintV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint8: - fastpathTV.EncMapIntfUint8V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint8: - fastpathTV.EncMapIntfUint8V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint16: - fastpathTV.EncMapIntfUint16V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint16: - fastpathTV.EncMapIntfUint16V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint32: - fastpathTV.EncMapIntfUint32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint32: - fastpathTV.EncMapIntfUint32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint64: - fastpathTV.EncMapIntfUint64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint64: - fastpathTV.EncMapIntfUint64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uintptr: - fastpathTV.EncMapIntfUintptrV(v, fastpathCheckNilTrue, e) - case *map[interface{}]uintptr: - fastpathTV.EncMapIntfUintptrV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int: - fastpathTV.EncMapIntfIntV(v, fastpathCheckNilTrue, e) - case *map[interface{}]int: - fastpathTV.EncMapIntfIntV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int8: - fastpathTV.EncMapIntfInt8V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int8: - fastpathTV.EncMapIntfInt8V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int16: - fastpathTV.EncMapIntfInt16V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int16: - fastpathTV.EncMapIntfInt16V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int32: - fastpathTV.EncMapIntfInt32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int32: - fastpathTV.EncMapIntfInt32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int64: - fastpathTV.EncMapIntfInt64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int64: - fastpathTV.EncMapIntfInt64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]float32: - fastpathTV.EncMapIntfFloat32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]float32: - fastpathTV.EncMapIntfFloat32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]float64: - fastpathTV.EncMapIntfFloat64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]float64: - fastpathTV.EncMapIntfFloat64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]bool: - fastpathTV.EncMapIntfBoolV(v, fastpathCheckNilTrue, e) - case *map[interface{}]bool: - fastpathTV.EncMapIntfBoolV(*v, fastpathCheckNilTrue, e) - - case []string: - fastpathTV.EncSliceStringV(v, fastpathCheckNilTrue, e) - case *[]string: - fastpathTV.EncSliceStringV(*v, fastpathCheckNilTrue, e) - - case map[string]interface{}: - fastpathTV.EncMapStringIntfV(v, fastpathCheckNilTrue, e) - case *map[string]interface{}: - fastpathTV.EncMapStringIntfV(*v, fastpathCheckNilTrue, e) - - case map[string]string: - fastpathTV.EncMapStringStringV(v, fastpathCheckNilTrue, e) - case *map[string]string: - fastpathTV.EncMapStringStringV(*v, fastpathCheckNilTrue, e) - - case map[string]uint: - fastpathTV.EncMapStringUintV(v, fastpathCheckNilTrue, e) - case *map[string]uint: - fastpathTV.EncMapStringUintV(*v, fastpathCheckNilTrue, e) - - case map[string]uint8: - fastpathTV.EncMapStringUint8V(v, fastpathCheckNilTrue, e) - case *map[string]uint8: - fastpathTV.EncMapStringUint8V(*v, fastpathCheckNilTrue, e) - - case map[string]uint16: - fastpathTV.EncMapStringUint16V(v, fastpathCheckNilTrue, e) - case *map[string]uint16: - fastpathTV.EncMapStringUint16V(*v, fastpathCheckNilTrue, e) - - case map[string]uint32: - fastpathTV.EncMapStringUint32V(v, fastpathCheckNilTrue, e) - case *map[string]uint32: - fastpathTV.EncMapStringUint32V(*v, fastpathCheckNilTrue, e) - - case map[string]uint64: - fastpathTV.EncMapStringUint64V(v, fastpathCheckNilTrue, e) - case *map[string]uint64: - fastpathTV.EncMapStringUint64V(*v, fastpathCheckNilTrue, e) - - case map[string]uintptr: - fastpathTV.EncMapStringUintptrV(v, fastpathCheckNilTrue, e) - case *map[string]uintptr: - fastpathTV.EncMapStringUintptrV(*v, fastpathCheckNilTrue, e) - - case map[string]int: - fastpathTV.EncMapStringIntV(v, fastpathCheckNilTrue, e) - case *map[string]int: - fastpathTV.EncMapStringIntV(*v, fastpathCheckNilTrue, e) - - case map[string]int8: - fastpathTV.EncMapStringInt8V(v, fastpathCheckNilTrue, e) - case *map[string]int8: - fastpathTV.EncMapStringInt8V(*v, fastpathCheckNilTrue, e) - - case map[string]int16: - fastpathTV.EncMapStringInt16V(v, fastpathCheckNilTrue, e) - case *map[string]int16: - fastpathTV.EncMapStringInt16V(*v, fastpathCheckNilTrue, e) - - case map[string]int32: - fastpathTV.EncMapStringInt32V(v, fastpathCheckNilTrue, e) - case *map[string]int32: - fastpathTV.EncMapStringInt32V(*v, fastpathCheckNilTrue, e) - - case map[string]int64: - fastpathTV.EncMapStringInt64V(v, fastpathCheckNilTrue, e) - case *map[string]int64: - fastpathTV.EncMapStringInt64V(*v, fastpathCheckNilTrue, e) - - case map[string]float32: - fastpathTV.EncMapStringFloat32V(v, fastpathCheckNilTrue, e) - case *map[string]float32: - fastpathTV.EncMapStringFloat32V(*v, fastpathCheckNilTrue, e) - - case map[string]float64: - fastpathTV.EncMapStringFloat64V(v, fastpathCheckNilTrue, e) - case *map[string]float64: - fastpathTV.EncMapStringFloat64V(*v, fastpathCheckNilTrue, e) - - case map[string]bool: - fastpathTV.EncMapStringBoolV(v, fastpathCheckNilTrue, e) - case *map[string]bool: - fastpathTV.EncMapStringBoolV(*v, fastpathCheckNilTrue, e) - - case []float32: - fastpathTV.EncSliceFloat32V(v, fastpathCheckNilTrue, e) - case *[]float32: - fastpathTV.EncSliceFloat32V(*v, fastpathCheckNilTrue, e) - - case map[float32]interface{}: - fastpathTV.EncMapFloat32IntfV(v, fastpathCheckNilTrue, e) - case *map[float32]interface{}: - fastpathTV.EncMapFloat32IntfV(*v, fastpathCheckNilTrue, e) - - case map[float32]string: - fastpathTV.EncMapFloat32StringV(v, fastpathCheckNilTrue, e) - case *map[float32]string: - fastpathTV.EncMapFloat32StringV(*v, fastpathCheckNilTrue, e) - - case map[float32]uint: - fastpathTV.EncMapFloat32UintV(v, fastpathCheckNilTrue, e) - case *map[float32]uint: - fastpathTV.EncMapFloat32UintV(*v, fastpathCheckNilTrue, e) - - case map[float32]uint8: - fastpathTV.EncMapFloat32Uint8V(v, fastpathCheckNilTrue, e) - case *map[float32]uint8: - fastpathTV.EncMapFloat32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint16: - fastpathTV.EncMapFloat32Uint16V(v, fastpathCheckNilTrue, e) - case *map[float32]uint16: - fastpathTV.EncMapFloat32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint32: - fastpathTV.EncMapFloat32Uint32V(v, fastpathCheckNilTrue, e) - case *map[float32]uint32: - fastpathTV.EncMapFloat32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint64: - fastpathTV.EncMapFloat32Uint64V(v, fastpathCheckNilTrue, e) - case *map[float32]uint64: - fastpathTV.EncMapFloat32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[float32]uintptr: - fastpathTV.EncMapFloat32UintptrV(v, fastpathCheckNilTrue, e) - case *map[float32]uintptr: - fastpathTV.EncMapFloat32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[float32]int: - fastpathTV.EncMapFloat32IntV(v, fastpathCheckNilTrue, e) - case *map[float32]int: - fastpathTV.EncMapFloat32IntV(*v, fastpathCheckNilTrue, e) - - case map[float32]int8: - fastpathTV.EncMapFloat32Int8V(v, fastpathCheckNilTrue, e) - case *map[float32]int8: - fastpathTV.EncMapFloat32Int8V(*v, fastpathCheckNilTrue, e) - - case map[float32]int16: - fastpathTV.EncMapFloat32Int16V(v, fastpathCheckNilTrue, e) - case *map[float32]int16: - fastpathTV.EncMapFloat32Int16V(*v, fastpathCheckNilTrue, e) - - case map[float32]int32: - fastpathTV.EncMapFloat32Int32V(v, fastpathCheckNilTrue, e) - case *map[float32]int32: - fastpathTV.EncMapFloat32Int32V(*v, fastpathCheckNilTrue, e) - - case map[float32]int64: - fastpathTV.EncMapFloat32Int64V(v, fastpathCheckNilTrue, e) - case *map[float32]int64: - fastpathTV.EncMapFloat32Int64V(*v, fastpathCheckNilTrue, e) - - case map[float32]float32: - fastpathTV.EncMapFloat32Float32V(v, fastpathCheckNilTrue, e) - case *map[float32]float32: - fastpathTV.EncMapFloat32Float32V(*v, fastpathCheckNilTrue, e) - - case map[float32]float64: - fastpathTV.EncMapFloat32Float64V(v, fastpathCheckNilTrue, e) - case *map[float32]float64: - fastpathTV.EncMapFloat32Float64V(*v, fastpathCheckNilTrue, e) - - case map[float32]bool: - fastpathTV.EncMapFloat32BoolV(v, fastpathCheckNilTrue, e) - case *map[float32]bool: - fastpathTV.EncMapFloat32BoolV(*v, fastpathCheckNilTrue, e) - - case []float64: - fastpathTV.EncSliceFloat64V(v, fastpathCheckNilTrue, e) - case *[]float64: - fastpathTV.EncSliceFloat64V(*v, fastpathCheckNilTrue, e) - - case map[float64]interface{}: - fastpathTV.EncMapFloat64IntfV(v, fastpathCheckNilTrue, e) - case *map[float64]interface{}: - fastpathTV.EncMapFloat64IntfV(*v, fastpathCheckNilTrue, e) - - case map[float64]string: - fastpathTV.EncMapFloat64StringV(v, fastpathCheckNilTrue, e) - case *map[float64]string: - fastpathTV.EncMapFloat64StringV(*v, fastpathCheckNilTrue, e) - - case map[float64]uint: - fastpathTV.EncMapFloat64UintV(v, fastpathCheckNilTrue, e) - case *map[float64]uint: - fastpathTV.EncMapFloat64UintV(*v, fastpathCheckNilTrue, e) - - case map[float64]uint8: - fastpathTV.EncMapFloat64Uint8V(v, fastpathCheckNilTrue, e) - case *map[float64]uint8: - fastpathTV.EncMapFloat64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint16: - fastpathTV.EncMapFloat64Uint16V(v, fastpathCheckNilTrue, e) - case *map[float64]uint16: - fastpathTV.EncMapFloat64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint32: - fastpathTV.EncMapFloat64Uint32V(v, fastpathCheckNilTrue, e) - case *map[float64]uint32: - fastpathTV.EncMapFloat64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint64: - fastpathTV.EncMapFloat64Uint64V(v, fastpathCheckNilTrue, e) - case *map[float64]uint64: - fastpathTV.EncMapFloat64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[float64]uintptr: - fastpathTV.EncMapFloat64UintptrV(v, fastpathCheckNilTrue, e) - case *map[float64]uintptr: - fastpathTV.EncMapFloat64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[float64]int: - fastpathTV.EncMapFloat64IntV(v, fastpathCheckNilTrue, e) - case *map[float64]int: - fastpathTV.EncMapFloat64IntV(*v, fastpathCheckNilTrue, e) - - case map[float64]int8: - fastpathTV.EncMapFloat64Int8V(v, fastpathCheckNilTrue, e) - case *map[float64]int8: - fastpathTV.EncMapFloat64Int8V(*v, fastpathCheckNilTrue, e) - - case map[float64]int16: - fastpathTV.EncMapFloat64Int16V(v, fastpathCheckNilTrue, e) - case *map[float64]int16: - fastpathTV.EncMapFloat64Int16V(*v, fastpathCheckNilTrue, e) - - case map[float64]int32: - fastpathTV.EncMapFloat64Int32V(v, fastpathCheckNilTrue, e) - case *map[float64]int32: - fastpathTV.EncMapFloat64Int32V(*v, fastpathCheckNilTrue, e) - - case map[float64]int64: - fastpathTV.EncMapFloat64Int64V(v, fastpathCheckNilTrue, e) - case *map[float64]int64: - fastpathTV.EncMapFloat64Int64V(*v, fastpathCheckNilTrue, e) - - case map[float64]float32: - fastpathTV.EncMapFloat64Float32V(v, fastpathCheckNilTrue, e) - case *map[float64]float32: - fastpathTV.EncMapFloat64Float32V(*v, fastpathCheckNilTrue, e) - - case map[float64]float64: - fastpathTV.EncMapFloat64Float64V(v, fastpathCheckNilTrue, e) - case *map[float64]float64: - fastpathTV.EncMapFloat64Float64V(*v, fastpathCheckNilTrue, e) - - case map[float64]bool: - fastpathTV.EncMapFloat64BoolV(v, fastpathCheckNilTrue, e) - case *map[float64]bool: - fastpathTV.EncMapFloat64BoolV(*v, fastpathCheckNilTrue, e) - - case []uint: - fastpathTV.EncSliceUintV(v, fastpathCheckNilTrue, e) - case *[]uint: - fastpathTV.EncSliceUintV(*v, fastpathCheckNilTrue, e) - - case map[uint]interface{}: - fastpathTV.EncMapUintIntfV(v, fastpathCheckNilTrue, e) - case *map[uint]interface{}: - fastpathTV.EncMapUintIntfV(*v, fastpathCheckNilTrue, e) - - case map[uint]string: - fastpathTV.EncMapUintStringV(v, fastpathCheckNilTrue, e) - case *map[uint]string: - fastpathTV.EncMapUintStringV(*v, fastpathCheckNilTrue, e) - - case map[uint]uint: - fastpathTV.EncMapUintUintV(v, fastpathCheckNilTrue, e) - case *map[uint]uint: - fastpathTV.EncMapUintUintV(*v, fastpathCheckNilTrue, e) - - case map[uint]uint8: - fastpathTV.EncMapUintUint8V(v, fastpathCheckNilTrue, e) - case *map[uint]uint8: - fastpathTV.EncMapUintUint8V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint16: - fastpathTV.EncMapUintUint16V(v, fastpathCheckNilTrue, e) - case *map[uint]uint16: - fastpathTV.EncMapUintUint16V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint32: - fastpathTV.EncMapUintUint32V(v, fastpathCheckNilTrue, e) - case *map[uint]uint32: - fastpathTV.EncMapUintUint32V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint64: - fastpathTV.EncMapUintUint64V(v, fastpathCheckNilTrue, e) - case *map[uint]uint64: - fastpathTV.EncMapUintUint64V(*v, fastpathCheckNilTrue, e) - - case map[uint]uintptr: - fastpathTV.EncMapUintUintptrV(v, fastpathCheckNilTrue, e) - case *map[uint]uintptr: - fastpathTV.EncMapUintUintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint]int: - fastpathTV.EncMapUintIntV(v, fastpathCheckNilTrue, e) - case *map[uint]int: - fastpathTV.EncMapUintIntV(*v, fastpathCheckNilTrue, e) - - case map[uint]int8: - fastpathTV.EncMapUintInt8V(v, fastpathCheckNilTrue, e) - case *map[uint]int8: - fastpathTV.EncMapUintInt8V(*v, fastpathCheckNilTrue, e) - - case map[uint]int16: - fastpathTV.EncMapUintInt16V(v, fastpathCheckNilTrue, e) - case *map[uint]int16: - fastpathTV.EncMapUintInt16V(*v, fastpathCheckNilTrue, e) - - case map[uint]int32: - fastpathTV.EncMapUintInt32V(v, fastpathCheckNilTrue, e) - case *map[uint]int32: - fastpathTV.EncMapUintInt32V(*v, fastpathCheckNilTrue, e) - - case map[uint]int64: - fastpathTV.EncMapUintInt64V(v, fastpathCheckNilTrue, e) - case *map[uint]int64: - fastpathTV.EncMapUintInt64V(*v, fastpathCheckNilTrue, e) - - case map[uint]float32: - fastpathTV.EncMapUintFloat32V(v, fastpathCheckNilTrue, e) - case *map[uint]float32: - fastpathTV.EncMapUintFloat32V(*v, fastpathCheckNilTrue, e) - - case map[uint]float64: - fastpathTV.EncMapUintFloat64V(v, fastpathCheckNilTrue, e) - case *map[uint]float64: - fastpathTV.EncMapUintFloat64V(*v, fastpathCheckNilTrue, e) - - case map[uint]bool: - fastpathTV.EncMapUintBoolV(v, fastpathCheckNilTrue, e) - case *map[uint]bool: - fastpathTV.EncMapUintBoolV(*v, fastpathCheckNilTrue, e) - - case map[uint8]interface{}: - fastpathTV.EncMapUint8IntfV(v, fastpathCheckNilTrue, e) - case *map[uint8]interface{}: - fastpathTV.EncMapUint8IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint8]string: - fastpathTV.EncMapUint8StringV(v, fastpathCheckNilTrue, e) - case *map[uint8]string: - fastpathTV.EncMapUint8StringV(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint: - fastpathTV.EncMapUint8UintV(v, fastpathCheckNilTrue, e) - case *map[uint8]uint: - fastpathTV.EncMapUint8UintV(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint8: - fastpathTV.EncMapUint8Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint8: - fastpathTV.EncMapUint8Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint16: - fastpathTV.EncMapUint8Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint16: - fastpathTV.EncMapUint8Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint32: - fastpathTV.EncMapUint8Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint32: - fastpathTV.EncMapUint8Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint64: - fastpathTV.EncMapUint8Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint64: - fastpathTV.EncMapUint8Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uintptr: - fastpathTV.EncMapUint8UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint8]uintptr: - fastpathTV.EncMapUint8UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint8]int: - fastpathTV.EncMapUint8IntV(v, fastpathCheckNilTrue, e) - case *map[uint8]int: - fastpathTV.EncMapUint8IntV(*v, fastpathCheckNilTrue, e) - - case map[uint8]int8: - fastpathTV.EncMapUint8Int8V(v, fastpathCheckNilTrue, e) - case *map[uint8]int8: - fastpathTV.EncMapUint8Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int16: - fastpathTV.EncMapUint8Int16V(v, fastpathCheckNilTrue, e) - case *map[uint8]int16: - fastpathTV.EncMapUint8Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int32: - fastpathTV.EncMapUint8Int32V(v, fastpathCheckNilTrue, e) - case *map[uint8]int32: - fastpathTV.EncMapUint8Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int64: - fastpathTV.EncMapUint8Int64V(v, fastpathCheckNilTrue, e) - case *map[uint8]int64: - fastpathTV.EncMapUint8Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]float32: - fastpathTV.EncMapUint8Float32V(v, fastpathCheckNilTrue, e) - case *map[uint8]float32: - fastpathTV.EncMapUint8Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]float64: - fastpathTV.EncMapUint8Float64V(v, fastpathCheckNilTrue, e) - case *map[uint8]float64: - fastpathTV.EncMapUint8Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]bool: - fastpathTV.EncMapUint8BoolV(v, fastpathCheckNilTrue, e) - case *map[uint8]bool: - fastpathTV.EncMapUint8BoolV(*v, fastpathCheckNilTrue, e) - - case []uint16: - fastpathTV.EncSliceUint16V(v, fastpathCheckNilTrue, e) - case *[]uint16: - fastpathTV.EncSliceUint16V(*v, fastpathCheckNilTrue, e) - - case map[uint16]interface{}: - fastpathTV.EncMapUint16IntfV(v, fastpathCheckNilTrue, e) - case *map[uint16]interface{}: - fastpathTV.EncMapUint16IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint16]string: - fastpathTV.EncMapUint16StringV(v, fastpathCheckNilTrue, e) - case *map[uint16]string: - fastpathTV.EncMapUint16StringV(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint: - fastpathTV.EncMapUint16UintV(v, fastpathCheckNilTrue, e) - case *map[uint16]uint: - fastpathTV.EncMapUint16UintV(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint8: - fastpathTV.EncMapUint16Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint8: - fastpathTV.EncMapUint16Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint16: - fastpathTV.EncMapUint16Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint16: - fastpathTV.EncMapUint16Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint32: - fastpathTV.EncMapUint16Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint32: - fastpathTV.EncMapUint16Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint64: - fastpathTV.EncMapUint16Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint64: - fastpathTV.EncMapUint16Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uintptr: - fastpathTV.EncMapUint16UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint16]uintptr: - fastpathTV.EncMapUint16UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint16]int: - fastpathTV.EncMapUint16IntV(v, fastpathCheckNilTrue, e) - case *map[uint16]int: - fastpathTV.EncMapUint16IntV(*v, fastpathCheckNilTrue, e) - - case map[uint16]int8: - fastpathTV.EncMapUint16Int8V(v, fastpathCheckNilTrue, e) - case *map[uint16]int8: - fastpathTV.EncMapUint16Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int16: - fastpathTV.EncMapUint16Int16V(v, fastpathCheckNilTrue, e) - case *map[uint16]int16: - fastpathTV.EncMapUint16Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int32: - fastpathTV.EncMapUint16Int32V(v, fastpathCheckNilTrue, e) - case *map[uint16]int32: - fastpathTV.EncMapUint16Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int64: - fastpathTV.EncMapUint16Int64V(v, fastpathCheckNilTrue, e) - case *map[uint16]int64: - fastpathTV.EncMapUint16Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]float32: - fastpathTV.EncMapUint16Float32V(v, fastpathCheckNilTrue, e) - case *map[uint16]float32: - fastpathTV.EncMapUint16Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]float64: - fastpathTV.EncMapUint16Float64V(v, fastpathCheckNilTrue, e) - case *map[uint16]float64: - fastpathTV.EncMapUint16Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]bool: - fastpathTV.EncMapUint16BoolV(v, fastpathCheckNilTrue, e) - case *map[uint16]bool: - fastpathTV.EncMapUint16BoolV(*v, fastpathCheckNilTrue, e) - - case []uint32: - fastpathTV.EncSliceUint32V(v, fastpathCheckNilTrue, e) - case *[]uint32: - fastpathTV.EncSliceUint32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]interface{}: - fastpathTV.EncMapUint32IntfV(v, fastpathCheckNilTrue, e) - case *map[uint32]interface{}: - fastpathTV.EncMapUint32IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint32]string: - fastpathTV.EncMapUint32StringV(v, fastpathCheckNilTrue, e) - case *map[uint32]string: - fastpathTV.EncMapUint32StringV(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint: - fastpathTV.EncMapUint32UintV(v, fastpathCheckNilTrue, e) - case *map[uint32]uint: - fastpathTV.EncMapUint32UintV(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint8: - fastpathTV.EncMapUint32Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint8: - fastpathTV.EncMapUint32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint16: - fastpathTV.EncMapUint32Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint16: - fastpathTV.EncMapUint32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint32: - fastpathTV.EncMapUint32Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint32: - fastpathTV.EncMapUint32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint64: - fastpathTV.EncMapUint32Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint64: - fastpathTV.EncMapUint32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uintptr: - fastpathTV.EncMapUint32UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint32]uintptr: - fastpathTV.EncMapUint32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint32]int: - fastpathTV.EncMapUint32IntV(v, fastpathCheckNilTrue, e) - case *map[uint32]int: - fastpathTV.EncMapUint32IntV(*v, fastpathCheckNilTrue, e) - - case map[uint32]int8: - fastpathTV.EncMapUint32Int8V(v, fastpathCheckNilTrue, e) - case *map[uint32]int8: - fastpathTV.EncMapUint32Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int16: - fastpathTV.EncMapUint32Int16V(v, fastpathCheckNilTrue, e) - case *map[uint32]int16: - fastpathTV.EncMapUint32Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int32: - fastpathTV.EncMapUint32Int32V(v, fastpathCheckNilTrue, e) - case *map[uint32]int32: - fastpathTV.EncMapUint32Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int64: - fastpathTV.EncMapUint32Int64V(v, fastpathCheckNilTrue, e) - case *map[uint32]int64: - fastpathTV.EncMapUint32Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]float32: - fastpathTV.EncMapUint32Float32V(v, fastpathCheckNilTrue, e) - case *map[uint32]float32: - fastpathTV.EncMapUint32Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]float64: - fastpathTV.EncMapUint32Float64V(v, fastpathCheckNilTrue, e) - case *map[uint32]float64: - fastpathTV.EncMapUint32Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]bool: - fastpathTV.EncMapUint32BoolV(v, fastpathCheckNilTrue, e) - case *map[uint32]bool: - fastpathTV.EncMapUint32BoolV(*v, fastpathCheckNilTrue, e) - - case []uint64: - fastpathTV.EncSliceUint64V(v, fastpathCheckNilTrue, e) - case *[]uint64: - fastpathTV.EncSliceUint64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]interface{}: - fastpathTV.EncMapUint64IntfV(v, fastpathCheckNilTrue, e) - case *map[uint64]interface{}: - fastpathTV.EncMapUint64IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint64]string: - fastpathTV.EncMapUint64StringV(v, fastpathCheckNilTrue, e) - case *map[uint64]string: - fastpathTV.EncMapUint64StringV(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint: - fastpathTV.EncMapUint64UintV(v, fastpathCheckNilTrue, e) - case *map[uint64]uint: - fastpathTV.EncMapUint64UintV(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint8: - fastpathTV.EncMapUint64Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint8: - fastpathTV.EncMapUint64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint16: - fastpathTV.EncMapUint64Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint16: - fastpathTV.EncMapUint64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint32: - fastpathTV.EncMapUint64Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint32: - fastpathTV.EncMapUint64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint64: - fastpathTV.EncMapUint64Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint64: - fastpathTV.EncMapUint64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uintptr: - fastpathTV.EncMapUint64UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint64]uintptr: - fastpathTV.EncMapUint64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint64]int: - fastpathTV.EncMapUint64IntV(v, fastpathCheckNilTrue, e) - case *map[uint64]int: - fastpathTV.EncMapUint64IntV(*v, fastpathCheckNilTrue, e) - - case map[uint64]int8: - fastpathTV.EncMapUint64Int8V(v, fastpathCheckNilTrue, e) - case *map[uint64]int8: - fastpathTV.EncMapUint64Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int16: - fastpathTV.EncMapUint64Int16V(v, fastpathCheckNilTrue, e) - case *map[uint64]int16: - fastpathTV.EncMapUint64Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int32: - fastpathTV.EncMapUint64Int32V(v, fastpathCheckNilTrue, e) - case *map[uint64]int32: - fastpathTV.EncMapUint64Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int64: - fastpathTV.EncMapUint64Int64V(v, fastpathCheckNilTrue, e) - case *map[uint64]int64: - fastpathTV.EncMapUint64Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]float32: - fastpathTV.EncMapUint64Float32V(v, fastpathCheckNilTrue, e) - case *map[uint64]float32: - fastpathTV.EncMapUint64Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]float64: - fastpathTV.EncMapUint64Float64V(v, fastpathCheckNilTrue, e) - case *map[uint64]float64: - fastpathTV.EncMapUint64Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]bool: - fastpathTV.EncMapUint64BoolV(v, fastpathCheckNilTrue, e) - case *map[uint64]bool: - fastpathTV.EncMapUint64BoolV(*v, fastpathCheckNilTrue, e) - - case []uintptr: - fastpathTV.EncSliceUintptrV(v, fastpathCheckNilTrue, e) - case *[]uintptr: - fastpathTV.EncSliceUintptrV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]interface{}: - fastpathTV.EncMapUintptrIntfV(v, fastpathCheckNilTrue, e) - case *map[uintptr]interface{}: - fastpathTV.EncMapUintptrIntfV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]string: - fastpathTV.EncMapUintptrStringV(v, fastpathCheckNilTrue, e) - case *map[uintptr]string: - fastpathTV.EncMapUintptrStringV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint: - fastpathTV.EncMapUintptrUintV(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint: - fastpathTV.EncMapUintptrUintV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint8: - fastpathTV.EncMapUintptrUint8V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint8: - fastpathTV.EncMapUintptrUint8V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint16: - fastpathTV.EncMapUintptrUint16V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint16: - fastpathTV.EncMapUintptrUint16V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint32: - fastpathTV.EncMapUintptrUint32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint32: - fastpathTV.EncMapUintptrUint32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint64: - fastpathTV.EncMapUintptrUint64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint64: - fastpathTV.EncMapUintptrUint64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uintptr: - fastpathTV.EncMapUintptrUintptrV(v, fastpathCheckNilTrue, e) - case *map[uintptr]uintptr: - fastpathTV.EncMapUintptrUintptrV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int: - fastpathTV.EncMapUintptrIntV(v, fastpathCheckNilTrue, e) - case *map[uintptr]int: - fastpathTV.EncMapUintptrIntV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int8: - fastpathTV.EncMapUintptrInt8V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int8: - fastpathTV.EncMapUintptrInt8V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int16: - fastpathTV.EncMapUintptrInt16V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int16: - fastpathTV.EncMapUintptrInt16V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int32: - fastpathTV.EncMapUintptrInt32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int32: - fastpathTV.EncMapUintptrInt32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int64: - fastpathTV.EncMapUintptrInt64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int64: - fastpathTV.EncMapUintptrInt64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]float32: - fastpathTV.EncMapUintptrFloat32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]float32: - fastpathTV.EncMapUintptrFloat32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]float64: - fastpathTV.EncMapUintptrFloat64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]float64: - fastpathTV.EncMapUintptrFloat64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]bool: - fastpathTV.EncMapUintptrBoolV(v, fastpathCheckNilTrue, e) - case *map[uintptr]bool: - fastpathTV.EncMapUintptrBoolV(*v, fastpathCheckNilTrue, e) - - case []int: - fastpathTV.EncSliceIntV(v, fastpathCheckNilTrue, e) - case *[]int: - fastpathTV.EncSliceIntV(*v, fastpathCheckNilTrue, e) - - case map[int]interface{}: - fastpathTV.EncMapIntIntfV(v, fastpathCheckNilTrue, e) - case *map[int]interface{}: - fastpathTV.EncMapIntIntfV(*v, fastpathCheckNilTrue, e) - - case map[int]string: - fastpathTV.EncMapIntStringV(v, fastpathCheckNilTrue, e) - case *map[int]string: - fastpathTV.EncMapIntStringV(*v, fastpathCheckNilTrue, e) - - case map[int]uint: - fastpathTV.EncMapIntUintV(v, fastpathCheckNilTrue, e) - case *map[int]uint: - fastpathTV.EncMapIntUintV(*v, fastpathCheckNilTrue, e) - - case map[int]uint8: - fastpathTV.EncMapIntUint8V(v, fastpathCheckNilTrue, e) - case *map[int]uint8: - fastpathTV.EncMapIntUint8V(*v, fastpathCheckNilTrue, e) - - case map[int]uint16: - fastpathTV.EncMapIntUint16V(v, fastpathCheckNilTrue, e) - case *map[int]uint16: - fastpathTV.EncMapIntUint16V(*v, fastpathCheckNilTrue, e) - - case map[int]uint32: - fastpathTV.EncMapIntUint32V(v, fastpathCheckNilTrue, e) - case *map[int]uint32: - fastpathTV.EncMapIntUint32V(*v, fastpathCheckNilTrue, e) - - case map[int]uint64: - fastpathTV.EncMapIntUint64V(v, fastpathCheckNilTrue, e) - case *map[int]uint64: - fastpathTV.EncMapIntUint64V(*v, fastpathCheckNilTrue, e) - - case map[int]uintptr: - fastpathTV.EncMapIntUintptrV(v, fastpathCheckNilTrue, e) - case *map[int]uintptr: - fastpathTV.EncMapIntUintptrV(*v, fastpathCheckNilTrue, e) - - case map[int]int: - fastpathTV.EncMapIntIntV(v, fastpathCheckNilTrue, e) - case *map[int]int: - fastpathTV.EncMapIntIntV(*v, fastpathCheckNilTrue, e) - - case map[int]int8: - fastpathTV.EncMapIntInt8V(v, fastpathCheckNilTrue, e) - case *map[int]int8: - fastpathTV.EncMapIntInt8V(*v, fastpathCheckNilTrue, e) - - case map[int]int16: - fastpathTV.EncMapIntInt16V(v, fastpathCheckNilTrue, e) - case *map[int]int16: - fastpathTV.EncMapIntInt16V(*v, fastpathCheckNilTrue, e) - - case map[int]int32: - fastpathTV.EncMapIntInt32V(v, fastpathCheckNilTrue, e) - case *map[int]int32: - fastpathTV.EncMapIntInt32V(*v, fastpathCheckNilTrue, e) - - case map[int]int64: - fastpathTV.EncMapIntInt64V(v, fastpathCheckNilTrue, e) - case *map[int]int64: - fastpathTV.EncMapIntInt64V(*v, fastpathCheckNilTrue, e) - - case map[int]float32: - fastpathTV.EncMapIntFloat32V(v, fastpathCheckNilTrue, e) - case *map[int]float32: - fastpathTV.EncMapIntFloat32V(*v, fastpathCheckNilTrue, e) - - case map[int]float64: - fastpathTV.EncMapIntFloat64V(v, fastpathCheckNilTrue, e) - case *map[int]float64: - fastpathTV.EncMapIntFloat64V(*v, fastpathCheckNilTrue, e) - - case map[int]bool: - fastpathTV.EncMapIntBoolV(v, fastpathCheckNilTrue, e) - case *map[int]bool: - fastpathTV.EncMapIntBoolV(*v, fastpathCheckNilTrue, e) - - case []int8: - fastpathTV.EncSliceInt8V(v, fastpathCheckNilTrue, e) - case *[]int8: - fastpathTV.EncSliceInt8V(*v, fastpathCheckNilTrue, e) - - case map[int8]interface{}: - fastpathTV.EncMapInt8IntfV(v, fastpathCheckNilTrue, e) - case *map[int8]interface{}: - fastpathTV.EncMapInt8IntfV(*v, fastpathCheckNilTrue, e) - - case map[int8]string: - fastpathTV.EncMapInt8StringV(v, fastpathCheckNilTrue, e) - case *map[int8]string: - fastpathTV.EncMapInt8StringV(*v, fastpathCheckNilTrue, e) - - case map[int8]uint: - fastpathTV.EncMapInt8UintV(v, fastpathCheckNilTrue, e) - case *map[int8]uint: - fastpathTV.EncMapInt8UintV(*v, fastpathCheckNilTrue, e) - - case map[int8]uint8: - fastpathTV.EncMapInt8Uint8V(v, fastpathCheckNilTrue, e) - case *map[int8]uint8: - fastpathTV.EncMapInt8Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint16: - fastpathTV.EncMapInt8Uint16V(v, fastpathCheckNilTrue, e) - case *map[int8]uint16: - fastpathTV.EncMapInt8Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint32: - fastpathTV.EncMapInt8Uint32V(v, fastpathCheckNilTrue, e) - case *map[int8]uint32: - fastpathTV.EncMapInt8Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint64: - fastpathTV.EncMapInt8Uint64V(v, fastpathCheckNilTrue, e) - case *map[int8]uint64: - fastpathTV.EncMapInt8Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int8]uintptr: - fastpathTV.EncMapInt8UintptrV(v, fastpathCheckNilTrue, e) - case *map[int8]uintptr: - fastpathTV.EncMapInt8UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int8]int: - fastpathTV.EncMapInt8IntV(v, fastpathCheckNilTrue, e) - case *map[int8]int: - fastpathTV.EncMapInt8IntV(*v, fastpathCheckNilTrue, e) - - case map[int8]int8: - fastpathTV.EncMapInt8Int8V(v, fastpathCheckNilTrue, e) - case *map[int8]int8: - fastpathTV.EncMapInt8Int8V(*v, fastpathCheckNilTrue, e) - - case map[int8]int16: - fastpathTV.EncMapInt8Int16V(v, fastpathCheckNilTrue, e) - case *map[int8]int16: - fastpathTV.EncMapInt8Int16V(*v, fastpathCheckNilTrue, e) - - case map[int8]int32: - fastpathTV.EncMapInt8Int32V(v, fastpathCheckNilTrue, e) - case *map[int8]int32: - fastpathTV.EncMapInt8Int32V(*v, fastpathCheckNilTrue, e) - - case map[int8]int64: - fastpathTV.EncMapInt8Int64V(v, fastpathCheckNilTrue, e) - case *map[int8]int64: - fastpathTV.EncMapInt8Int64V(*v, fastpathCheckNilTrue, e) - - case map[int8]float32: - fastpathTV.EncMapInt8Float32V(v, fastpathCheckNilTrue, e) - case *map[int8]float32: - fastpathTV.EncMapInt8Float32V(*v, fastpathCheckNilTrue, e) - - case map[int8]float64: - fastpathTV.EncMapInt8Float64V(v, fastpathCheckNilTrue, e) - case *map[int8]float64: - fastpathTV.EncMapInt8Float64V(*v, fastpathCheckNilTrue, e) - - case map[int8]bool: - fastpathTV.EncMapInt8BoolV(v, fastpathCheckNilTrue, e) - case *map[int8]bool: - fastpathTV.EncMapInt8BoolV(*v, fastpathCheckNilTrue, e) - - case []int16: - fastpathTV.EncSliceInt16V(v, fastpathCheckNilTrue, e) - case *[]int16: - fastpathTV.EncSliceInt16V(*v, fastpathCheckNilTrue, e) - - case map[int16]interface{}: - fastpathTV.EncMapInt16IntfV(v, fastpathCheckNilTrue, e) - case *map[int16]interface{}: - fastpathTV.EncMapInt16IntfV(*v, fastpathCheckNilTrue, e) - - case map[int16]string: - fastpathTV.EncMapInt16StringV(v, fastpathCheckNilTrue, e) - case *map[int16]string: - fastpathTV.EncMapInt16StringV(*v, fastpathCheckNilTrue, e) - - case map[int16]uint: - fastpathTV.EncMapInt16UintV(v, fastpathCheckNilTrue, e) - case *map[int16]uint: - fastpathTV.EncMapInt16UintV(*v, fastpathCheckNilTrue, e) - - case map[int16]uint8: - fastpathTV.EncMapInt16Uint8V(v, fastpathCheckNilTrue, e) - case *map[int16]uint8: - fastpathTV.EncMapInt16Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint16: - fastpathTV.EncMapInt16Uint16V(v, fastpathCheckNilTrue, e) - case *map[int16]uint16: - fastpathTV.EncMapInt16Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint32: - fastpathTV.EncMapInt16Uint32V(v, fastpathCheckNilTrue, e) - case *map[int16]uint32: - fastpathTV.EncMapInt16Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint64: - fastpathTV.EncMapInt16Uint64V(v, fastpathCheckNilTrue, e) - case *map[int16]uint64: - fastpathTV.EncMapInt16Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int16]uintptr: - fastpathTV.EncMapInt16UintptrV(v, fastpathCheckNilTrue, e) - case *map[int16]uintptr: - fastpathTV.EncMapInt16UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int16]int: - fastpathTV.EncMapInt16IntV(v, fastpathCheckNilTrue, e) - case *map[int16]int: - fastpathTV.EncMapInt16IntV(*v, fastpathCheckNilTrue, e) - - case map[int16]int8: - fastpathTV.EncMapInt16Int8V(v, fastpathCheckNilTrue, e) - case *map[int16]int8: - fastpathTV.EncMapInt16Int8V(*v, fastpathCheckNilTrue, e) - - case map[int16]int16: - fastpathTV.EncMapInt16Int16V(v, fastpathCheckNilTrue, e) - case *map[int16]int16: - fastpathTV.EncMapInt16Int16V(*v, fastpathCheckNilTrue, e) - - case map[int16]int32: - fastpathTV.EncMapInt16Int32V(v, fastpathCheckNilTrue, e) - case *map[int16]int32: - fastpathTV.EncMapInt16Int32V(*v, fastpathCheckNilTrue, e) - - case map[int16]int64: - fastpathTV.EncMapInt16Int64V(v, fastpathCheckNilTrue, e) - case *map[int16]int64: - fastpathTV.EncMapInt16Int64V(*v, fastpathCheckNilTrue, e) - - case map[int16]float32: - fastpathTV.EncMapInt16Float32V(v, fastpathCheckNilTrue, e) - case *map[int16]float32: - fastpathTV.EncMapInt16Float32V(*v, fastpathCheckNilTrue, e) - - case map[int16]float64: - fastpathTV.EncMapInt16Float64V(v, fastpathCheckNilTrue, e) - case *map[int16]float64: - fastpathTV.EncMapInt16Float64V(*v, fastpathCheckNilTrue, e) - - case map[int16]bool: - fastpathTV.EncMapInt16BoolV(v, fastpathCheckNilTrue, e) - case *map[int16]bool: - fastpathTV.EncMapInt16BoolV(*v, fastpathCheckNilTrue, e) - - case []int32: - fastpathTV.EncSliceInt32V(v, fastpathCheckNilTrue, e) - case *[]int32: - fastpathTV.EncSliceInt32V(*v, fastpathCheckNilTrue, e) - - case map[int32]interface{}: - fastpathTV.EncMapInt32IntfV(v, fastpathCheckNilTrue, e) - case *map[int32]interface{}: - fastpathTV.EncMapInt32IntfV(*v, fastpathCheckNilTrue, e) - - case map[int32]string: - fastpathTV.EncMapInt32StringV(v, fastpathCheckNilTrue, e) - case *map[int32]string: - fastpathTV.EncMapInt32StringV(*v, fastpathCheckNilTrue, e) - - case map[int32]uint: - fastpathTV.EncMapInt32UintV(v, fastpathCheckNilTrue, e) - case *map[int32]uint: - fastpathTV.EncMapInt32UintV(*v, fastpathCheckNilTrue, e) - - case map[int32]uint8: - fastpathTV.EncMapInt32Uint8V(v, fastpathCheckNilTrue, e) - case *map[int32]uint8: - fastpathTV.EncMapInt32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint16: - fastpathTV.EncMapInt32Uint16V(v, fastpathCheckNilTrue, e) - case *map[int32]uint16: - fastpathTV.EncMapInt32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint32: - fastpathTV.EncMapInt32Uint32V(v, fastpathCheckNilTrue, e) - case *map[int32]uint32: - fastpathTV.EncMapInt32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint64: - fastpathTV.EncMapInt32Uint64V(v, fastpathCheckNilTrue, e) - case *map[int32]uint64: - fastpathTV.EncMapInt32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int32]uintptr: - fastpathTV.EncMapInt32UintptrV(v, fastpathCheckNilTrue, e) - case *map[int32]uintptr: - fastpathTV.EncMapInt32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int32]int: - fastpathTV.EncMapInt32IntV(v, fastpathCheckNilTrue, e) - case *map[int32]int: - fastpathTV.EncMapInt32IntV(*v, fastpathCheckNilTrue, e) - - case map[int32]int8: - fastpathTV.EncMapInt32Int8V(v, fastpathCheckNilTrue, e) - case *map[int32]int8: - fastpathTV.EncMapInt32Int8V(*v, fastpathCheckNilTrue, e) - - case map[int32]int16: - fastpathTV.EncMapInt32Int16V(v, fastpathCheckNilTrue, e) - case *map[int32]int16: - fastpathTV.EncMapInt32Int16V(*v, fastpathCheckNilTrue, e) - - case map[int32]int32: - fastpathTV.EncMapInt32Int32V(v, fastpathCheckNilTrue, e) - case *map[int32]int32: - fastpathTV.EncMapInt32Int32V(*v, fastpathCheckNilTrue, e) - - case map[int32]int64: - fastpathTV.EncMapInt32Int64V(v, fastpathCheckNilTrue, e) - case *map[int32]int64: - fastpathTV.EncMapInt32Int64V(*v, fastpathCheckNilTrue, e) - - case map[int32]float32: - fastpathTV.EncMapInt32Float32V(v, fastpathCheckNilTrue, e) - case *map[int32]float32: - fastpathTV.EncMapInt32Float32V(*v, fastpathCheckNilTrue, e) - - case map[int32]float64: - fastpathTV.EncMapInt32Float64V(v, fastpathCheckNilTrue, e) - case *map[int32]float64: - fastpathTV.EncMapInt32Float64V(*v, fastpathCheckNilTrue, e) - - case map[int32]bool: - fastpathTV.EncMapInt32BoolV(v, fastpathCheckNilTrue, e) - case *map[int32]bool: - fastpathTV.EncMapInt32BoolV(*v, fastpathCheckNilTrue, e) - - case []int64: - fastpathTV.EncSliceInt64V(v, fastpathCheckNilTrue, e) - case *[]int64: - fastpathTV.EncSliceInt64V(*v, fastpathCheckNilTrue, e) - - case map[int64]interface{}: - fastpathTV.EncMapInt64IntfV(v, fastpathCheckNilTrue, e) - case *map[int64]interface{}: - fastpathTV.EncMapInt64IntfV(*v, fastpathCheckNilTrue, e) - - case map[int64]string: - fastpathTV.EncMapInt64StringV(v, fastpathCheckNilTrue, e) - case *map[int64]string: - fastpathTV.EncMapInt64StringV(*v, fastpathCheckNilTrue, e) - - case map[int64]uint: - fastpathTV.EncMapInt64UintV(v, fastpathCheckNilTrue, e) - case *map[int64]uint: - fastpathTV.EncMapInt64UintV(*v, fastpathCheckNilTrue, e) - - case map[int64]uint8: - fastpathTV.EncMapInt64Uint8V(v, fastpathCheckNilTrue, e) - case *map[int64]uint8: - fastpathTV.EncMapInt64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint16: - fastpathTV.EncMapInt64Uint16V(v, fastpathCheckNilTrue, e) - case *map[int64]uint16: - fastpathTV.EncMapInt64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint32: - fastpathTV.EncMapInt64Uint32V(v, fastpathCheckNilTrue, e) - case *map[int64]uint32: - fastpathTV.EncMapInt64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint64: - fastpathTV.EncMapInt64Uint64V(v, fastpathCheckNilTrue, e) - case *map[int64]uint64: - fastpathTV.EncMapInt64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int64]uintptr: - fastpathTV.EncMapInt64UintptrV(v, fastpathCheckNilTrue, e) - case *map[int64]uintptr: - fastpathTV.EncMapInt64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int64]int: - fastpathTV.EncMapInt64IntV(v, fastpathCheckNilTrue, e) - case *map[int64]int: - fastpathTV.EncMapInt64IntV(*v, fastpathCheckNilTrue, e) - - case map[int64]int8: - fastpathTV.EncMapInt64Int8V(v, fastpathCheckNilTrue, e) - case *map[int64]int8: - fastpathTV.EncMapInt64Int8V(*v, fastpathCheckNilTrue, e) - - case map[int64]int16: - fastpathTV.EncMapInt64Int16V(v, fastpathCheckNilTrue, e) - case *map[int64]int16: - fastpathTV.EncMapInt64Int16V(*v, fastpathCheckNilTrue, e) - - case map[int64]int32: - fastpathTV.EncMapInt64Int32V(v, fastpathCheckNilTrue, e) - case *map[int64]int32: - fastpathTV.EncMapInt64Int32V(*v, fastpathCheckNilTrue, e) - - case map[int64]int64: - fastpathTV.EncMapInt64Int64V(v, fastpathCheckNilTrue, e) - case *map[int64]int64: - fastpathTV.EncMapInt64Int64V(*v, fastpathCheckNilTrue, e) - - case map[int64]float32: - fastpathTV.EncMapInt64Float32V(v, fastpathCheckNilTrue, e) - case *map[int64]float32: - fastpathTV.EncMapInt64Float32V(*v, fastpathCheckNilTrue, e) - - case map[int64]float64: - fastpathTV.EncMapInt64Float64V(v, fastpathCheckNilTrue, e) - case *map[int64]float64: - fastpathTV.EncMapInt64Float64V(*v, fastpathCheckNilTrue, e) - - case map[int64]bool: - fastpathTV.EncMapInt64BoolV(v, fastpathCheckNilTrue, e) - case *map[int64]bool: - fastpathTV.EncMapInt64BoolV(*v, fastpathCheckNilTrue, e) - - case []bool: - fastpathTV.EncSliceBoolV(v, fastpathCheckNilTrue, e) - case *[]bool: - fastpathTV.EncSliceBoolV(*v, fastpathCheckNilTrue, e) - - case map[bool]interface{}: - fastpathTV.EncMapBoolIntfV(v, fastpathCheckNilTrue, e) - case *map[bool]interface{}: - fastpathTV.EncMapBoolIntfV(*v, fastpathCheckNilTrue, e) - - case map[bool]string: - fastpathTV.EncMapBoolStringV(v, fastpathCheckNilTrue, e) - case *map[bool]string: - fastpathTV.EncMapBoolStringV(*v, fastpathCheckNilTrue, e) - - case map[bool]uint: - fastpathTV.EncMapBoolUintV(v, fastpathCheckNilTrue, e) - case *map[bool]uint: - fastpathTV.EncMapBoolUintV(*v, fastpathCheckNilTrue, e) - - case map[bool]uint8: - fastpathTV.EncMapBoolUint8V(v, fastpathCheckNilTrue, e) - case *map[bool]uint8: - fastpathTV.EncMapBoolUint8V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint16: - fastpathTV.EncMapBoolUint16V(v, fastpathCheckNilTrue, e) - case *map[bool]uint16: - fastpathTV.EncMapBoolUint16V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint32: - fastpathTV.EncMapBoolUint32V(v, fastpathCheckNilTrue, e) - case *map[bool]uint32: - fastpathTV.EncMapBoolUint32V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint64: - fastpathTV.EncMapBoolUint64V(v, fastpathCheckNilTrue, e) - case *map[bool]uint64: - fastpathTV.EncMapBoolUint64V(*v, fastpathCheckNilTrue, e) - - case map[bool]uintptr: - fastpathTV.EncMapBoolUintptrV(v, fastpathCheckNilTrue, e) - case *map[bool]uintptr: - fastpathTV.EncMapBoolUintptrV(*v, fastpathCheckNilTrue, e) - - case map[bool]int: - fastpathTV.EncMapBoolIntV(v, fastpathCheckNilTrue, e) - case *map[bool]int: - fastpathTV.EncMapBoolIntV(*v, fastpathCheckNilTrue, e) - - case map[bool]int8: - fastpathTV.EncMapBoolInt8V(v, fastpathCheckNilTrue, e) - case *map[bool]int8: - fastpathTV.EncMapBoolInt8V(*v, fastpathCheckNilTrue, e) - - case map[bool]int16: - fastpathTV.EncMapBoolInt16V(v, fastpathCheckNilTrue, e) - case *map[bool]int16: - fastpathTV.EncMapBoolInt16V(*v, fastpathCheckNilTrue, e) - - case map[bool]int32: - fastpathTV.EncMapBoolInt32V(v, fastpathCheckNilTrue, e) - case *map[bool]int32: - fastpathTV.EncMapBoolInt32V(*v, fastpathCheckNilTrue, e) - - case map[bool]int64: - fastpathTV.EncMapBoolInt64V(v, fastpathCheckNilTrue, e) - case *map[bool]int64: - fastpathTV.EncMapBoolInt64V(*v, fastpathCheckNilTrue, e) - - case map[bool]float32: - fastpathTV.EncMapBoolFloat32V(v, fastpathCheckNilTrue, e) - case *map[bool]float32: - fastpathTV.EncMapBoolFloat32V(*v, fastpathCheckNilTrue, e) - - case map[bool]float64: - fastpathTV.EncMapBoolFloat64V(v, fastpathCheckNilTrue, e) - case *map[bool]float64: - fastpathTV.EncMapBoolFloat64V(*v, fastpathCheckNilTrue, e) - - case map[bool]bool: - fastpathTV.EncMapBoolBoolV(v, fastpathCheckNilTrue, e) - case *map[bool]bool: - fastpathTV.EncMapBoolBoolV(*v, fastpathCheckNilTrue, e) - - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { - - case []interface{}: - fastpathTV.EncSliceIntfV(v, fastpathCheckNilTrue, e) - case *[]interface{}: - fastpathTV.EncSliceIntfV(*v, fastpathCheckNilTrue, e) - - case []string: - fastpathTV.EncSliceStringV(v, fastpathCheckNilTrue, e) - case *[]string: - fastpathTV.EncSliceStringV(*v, fastpathCheckNilTrue, e) - - case []float32: - fastpathTV.EncSliceFloat32V(v, fastpathCheckNilTrue, e) - case *[]float32: - fastpathTV.EncSliceFloat32V(*v, fastpathCheckNilTrue, e) - - case []float64: - fastpathTV.EncSliceFloat64V(v, fastpathCheckNilTrue, e) - case *[]float64: - fastpathTV.EncSliceFloat64V(*v, fastpathCheckNilTrue, e) - - case []uint: - fastpathTV.EncSliceUintV(v, fastpathCheckNilTrue, e) - case *[]uint: - fastpathTV.EncSliceUintV(*v, fastpathCheckNilTrue, e) - - case []uint16: - fastpathTV.EncSliceUint16V(v, fastpathCheckNilTrue, e) - case *[]uint16: - fastpathTV.EncSliceUint16V(*v, fastpathCheckNilTrue, e) - - case []uint32: - fastpathTV.EncSliceUint32V(v, fastpathCheckNilTrue, e) - case *[]uint32: - fastpathTV.EncSliceUint32V(*v, fastpathCheckNilTrue, e) - - case []uint64: - fastpathTV.EncSliceUint64V(v, fastpathCheckNilTrue, e) - case *[]uint64: - fastpathTV.EncSliceUint64V(*v, fastpathCheckNilTrue, e) - - case []uintptr: - fastpathTV.EncSliceUintptrV(v, fastpathCheckNilTrue, e) - case *[]uintptr: - fastpathTV.EncSliceUintptrV(*v, fastpathCheckNilTrue, e) - - case []int: - fastpathTV.EncSliceIntV(v, fastpathCheckNilTrue, e) - case *[]int: - fastpathTV.EncSliceIntV(*v, fastpathCheckNilTrue, e) - - case []int8: - fastpathTV.EncSliceInt8V(v, fastpathCheckNilTrue, e) - case *[]int8: - fastpathTV.EncSliceInt8V(*v, fastpathCheckNilTrue, e) - - case []int16: - fastpathTV.EncSliceInt16V(v, fastpathCheckNilTrue, e) - case *[]int16: - fastpathTV.EncSliceInt16V(*v, fastpathCheckNilTrue, e) - - case []int32: - fastpathTV.EncSliceInt32V(v, fastpathCheckNilTrue, e) - case *[]int32: - fastpathTV.EncSliceInt32V(*v, fastpathCheckNilTrue, e) - - case []int64: - fastpathTV.EncSliceInt64V(v, fastpathCheckNilTrue, e) - case *[]int64: - fastpathTV.EncSliceInt64V(*v, fastpathCheckNilTrue, e) - - case []bool: - fastpathTV.EncSliceBoolV(v, fastpathCheckNilTrue, e) - case *[]bool: - fastpathTV.EncSliceBoolV(*v, fastpathCheckNilTrue, e) - - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { - - case map[interface{}]interface{}: - fastpathTV.EncMapIntfIntfV(v, fastpathCheckNilTrue, e) - case *map[interface{}]interface{}: - fastpathTV.EncMapIntfIntfV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]string: - fastpathTV.EncMapIntfStringV(v, fastpathCheckNilTrue, e) - case *map[interface{}]string: - fastpathTV.EncMapIntfStringV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint: - fastpathTV.EncMapIntfUintV(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint: - fastpathTV.EncMapIntfUintV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint8: - fastpathTV.EncMapIntfUint8V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint8: - fastpathTV.EncMapIntfUint8V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint16: - fastpathTV.EncMapIntfUint16V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint16: - fastpathTV.EncMapIntfUint16V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint32: - fastpathTV.EncMapIntfUint32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint32: - fastpathTV.EncMapIntfUint32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uint64: - fastpathTV.EncMapIntfUint64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]uint64: - fastpathTV.EncMapIntfUint64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]uintptr: - fastpathTV.EncMapIntfUintptrV(v, fastpathCheckNilTrue, e) - case *map[interface{}]uintptr: - fastpathTV.EncMapIntfUintptrV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int: - fastpathTV.EncMapIntfIntV(v, fastpathCheckNilTrue, e) - case *map[interface{}]int: - fastpathTV.EncMapIntfIntV(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int8: - fastpathTV.EncMapIntfInt8V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int8: - fastpathTV.EncMapIntfInt8V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int16: - fastpathTV.EncMapIntfInt16V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int16: - fastpathTV.EncMapIntfInt16V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int32: - fastpathTV.EncMapIntfInt32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int32: - fastpathTV.EncMapIntfInt32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]int64: - fastpathTV.EncMapIntfInt64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]int64: - fastpathTV.EncMapIntfInt64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]float32: - fastpathTV.EncMapIntfFloat32V(v, fastpathCheckNilTrue, e) - case *map[interface{}]float32: - fastpathTV.EncMapIntfFloat32V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]float64: - fastpathTV.EncMapIntfFloat64V(v, fastpathCheckNilTrue, e) - case *map[interface{}]float64: - fastpathTV.EncMapIntfFloat64V(*v, fastpathCheckNilTrue, e) - - case map[interface{}]bool: - fastpathTV.EncMapIntfBoolV(v, fastpathCheckNilTrue, e) - case *map[interface{}]bool: - fastpathTV.EncMapIntfBoolV(*v, fastpathCheckNilTrue, e) - - case map[string]interface{}: - fastpathTV.EncMapStringIntfV(v, fastpathCheckNilTrue, e) - case *map[string]interface{}: - fastpathTV.EncMapStringIntfV(*v, fastpathCheckNilTrue, e) - - case map[string]string: - fastpathTV.EncMapStringStringV(v, fastpathCheckNilTrue, e) - case *map[string]string: - fastpathTV.EncMapStringStringV(*v, fastpathCheckNilTrue, e) - - case map[string]uint: - fastpathTV.EncMapStringUintV(v, fastpathCheckNilTrue, e) - case *map[string]uint: - fastpathTV.EncMapStringUintV(*v, fastpathCheckNilTrue, e) - - case map[string]uint8: - fastpathTV.EncMapStringUint8V(v, fastpathCheckNilTrue, e) - case *map[string]uint8: - fastpathTV.EncMapStringUint8V(*v, fastpathCheckNilTrue, e) - - case map[string]uint16: - fastpathTV.EncMapStringUint16V(v, fastpathCheckNilTrue, e) - case *map[string]uint16: - fastpathTV.EncMapStringUint16V(*v, fastpathCheckNilTrue, e) - - case map[string]uint32: - fastpathTV.EncMapStringUint32V(v, fastpathCheckNilTrue, e) - case *map[string]uint32: - fastpathTV.EncMapStringUint32V(*v, fastpathCheckNilTrue, e) - - case map[string]uint64: - fastpathTV.EncMapStringUint64V(v, fastpathCheckNilTrue, e) - case *map[string]uint64: - fastpathTV.EncMapStringUint64V(*v, fastpathCheckNilTrue, e) - - case map[string]uintptr: - fastpathTV.EncMapStringUintptrV(v, fastpathCheckNilTrue, e) - case *map[string]uintptr: - fastpathTV.EncMapStringUintptrV(*v, fastpathCheckNilTrue, e) - - case map[string]int: - fastpathTV.EncMapStringIntV(v, fastpathCheckNilTrue, e) - case *map[string]int: - fastpathTV.EncMapStringIntV(*v, fastpathCheckNilTrue, e) - - case map[string]int8: - fastpathTV.EncMapStringInt8V(v, fastpathCheckNilTrue, e) - case *map[string]int8: - fastpathTV.EncMapStringInt8V(*v, fastpathCheckNilTrue, e) - - case map[string]int16: - fastpathTV.EncMapStringInt16V(v, fastpathCheckNilTrue, e) - case *map[string]int16: - fastpathTV.EncMapStringInt16V(*v, fastpathCheckNilTrue, e) - - case map[string]int32: - fastpathTV.EncMapStringInt32V(v, fastpathCheckNilTrue, e) - case *map[string]int32: - fastpathTV.EncMapStringInt32V(*v, fastpathCheckNilTrue, e) - - case map[string]int64: - fastpathTV.EncMapStringInt64V(v, fastpathCheckNilTrue, e) - case *map[string]int64: - fastpathTV.EncMapStringInt64V(*v, fastpathCheckNilTrue, e) - - case map[string]float32: - fastpathTV.EncMapStringFloat32V(v, fastpathCheckNilTrue, e) - case *map[string]float32: - fastpathTV.EncMapStringFloat32V(*v, fastpathCheckNilTrue, e) - - case map[string]float64: - fastpathTV.EncMapStringFloat64V(v, fastpathCheckNilTrue, e) - case *map[string]float64: - fastpathTV.EncMapStringFloat64V(*v, fastpathCheckNilTrue, e) - - case map[string]bool: - fastpathTV.EncMapStringBoolV(v, fastpathCheckNilTrue, e) - case *map[string]bool: - fastpathTV.EncMapStringBoolV(*v, fastpathCheckNilTrue, e) - - case map[float32]interface{}: - fastpathTV.EncMapFloat32IntfV(v, fastpathCheckNilTrue, e) - case *map[float32]interface{}: - fastpathTV.EncMapFloat32IntfV(*v, fastpathCheckNilTrue, e) - - case map[float32]string: - fastpathTV.EncMapFloat32StringV(v, fastpathCheckNilTrue, e) - case *map[float32]string: - fastpathTV.EncMapFloat32StringV(*v, fastpathCheckNilTrue, e) - - case map[float32]uint: - fastpathTV.EncMapFloat32UintV(v, fastpathCheckNilTrue, e) - case *map[float32]uint: - fastpathTV.EncMapFloat32UintV(*v, fastpathCheckNilTrue, e) - - case map[float32]uint8: - fastpathTV.EncMapFloat32Uint8V(v, fastpathCheckNilTrue, e) - case *map[float32]uint8: - fastpathTV.EncMapFloat32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint16: - fastpathTV.EncMapFloat32Uint16V(v, fastpathCheckNilTrue, e) - case *map[float32]uint16: - fastpathTV.EncMapFloat32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint32: - fastpathTV.EncMapFloat32Uint32V(v, fastpathCheckNilTrue, e) - case *map[float32]uint32: - fastpathTV.EncMapFloat32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[float32]uint64: - fastpathTV.EncMapFloat32Uint64V(v, fastpathCheckNilTrue, e) - case *map[float32]uint64: - fastpathTV.EncMapFloat32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[float32]uintptr: - fastpathTV.EncMapFloat32UintptrV(v, fastpathCheckNilTrue, e) - case *map[float32]uintptr: - fastpathTV.EncMapFloat32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[float32]int: - fastpathTV.EncMapFloat32IntV(v, fastpathCheckNilTrue, e) - case *map[float32]int: - fastpathTV.EncMapFloat32IntV(*v, fastpathCheckNilTrue, e) - - case map[float32]int8: - fastpathTV.EncMapFloat32Int8V(v, fastpathCheckNilTrue, e) - case *map[float32]int8: - fastpathTV.EncMapFloat32Int8V(*v, fastpathCheckNilTrue, e) - - case map[float32]int16: - fastpathTV.EncMapFloat32Int16V(v, fastpathCheckNilTrue, e) - case *map[float32]int16: - fastpathTV.EncMapFloat32Int16V(*v, fastpathCheckNilTrue, e) - - case map[float32]int32: - fastpathTV.EncMapFloat32Int32V(v, fastpathCheckNilTrue, e) - case *map[float32]int32: - fastpathTV.EncMapFloat32Int32V(*v, fastpathCheckNilTrue, e) - - case map[float32]int64: - fastpathTV.EncMapFloat32Int64V(v, fastpathCheckNilTrue, e) - case *map[float32]int64: - fastpathTV.EncMapFloat32Int64V(*v, fastpathCheckNilTrue, e) - - case map[float32]float32: - fastpathTV.EncMapFloat32Float32V(v, fastpathCheckNilTrue, e) - case *map[float32]float32: - fastpathTV.EncMapFloat32Float32V(*v, fastpathCheckNilTrue, e) - - case map[float32]float64: - fastpathTV.EncMapFloat32Float64V(v, fastpathCheckNilTrue, e) - case *map[float32]float64: - fastpathTV.EncMapFloat32Float64V(*v, fastpathCheckNilTrue, e) - - case map[float32]bool: - fastpathTV.EncMapFloat32BoolV(v, fastpathCheckNilTrue, e) - case *map[float32]bool: - fastpathTV.EncMapFloat32BoolV(*v, fastpathCheckNilTrue, e) - - case map[float64]interface{}: - fastpathTV.EncMapFloat64IntfV(v, fastpathCheckNilTrue, e) - case *map[float64]interface{}: - fastpathTV.EncMapFloat64IntfV(*v, fastpathCheckNilTrue, e) - - case map[float64]string: - fastpathTV.EncMapFloat64StringV(v, fastpathCheckNilTrue, e) - case *map[float64]string: - fastpathTV.EncMapFloat64StringV(*v, fastpathCheckNilTrue, e) - - case map[float64]uint: - fastpathTV.EncMapFloat64UintV(v, fastpathCheckNilTrue, e) - case *map[float64]uint: - fastpathTV.EncMapFloat64UintV(*v, fastpathCheckNilTrue, e) - - case map[float64]uint8: - fastpathTV.EncMapFloat64Uint8V(v, fastpathCheckNilTrue, e) - case *map[float64]uint8: - fastpathTV.EncMapFloat64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint16: - fastpathTV.EncMapFloat64Uint16V(v, fastpathCheckNilTrue, e) - case *map[float64]uint16: - fastpathTV.EncMapFloat64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint32: - fastpathTV.EncMapFloat64Uint32V(v, fastpathCheckNilTrue, e) - case *map[float64]uint32: - fastpathTV.EncMapFloat64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[float64]uint64: - fastpathTV.EncMapFloat64Uint64V(v, fastpathCheckNilTrue, e) - case *map[float64]uint64: - fastpathTV.EncMapFloat64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[float64]uintptr: - fastpathTV.EncMapFloat64UintptrV(v, fastpathCheckNilTrue, e) - case *map[float64]uintptr: - fastpathTV.EncMapFloat64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[float64]int: - fastpathTV.EncMapFloat64IntV(v, fastpathCheckNilTrue, e) - case *map[float64]int: - fastpathTV.EncMapFloat64IntV(*v, fastpathCheckNilTrue, e) - - case map[float64]int8: - fastpathTV.EncMapFloat64Int8V(v, fastpathCheckNilTrue, e) - case *map[float64]int8: - fastpathTV.EncMapFloat64Int8V(*v, fastpathCheckNilTrue, e) - - case map[float64]int16: - fastpathTV.EncMapFloat64Int16V(v, fastpathCheckNilTrue, e) - case *map[float64]int16: - fastpathTV.EncMapFloat64Int16V(*v, fastpathCheckNilTrue, e) - - case map[float64]int32: - fastpathTV.EncMapFloat64Int32V(v, fastpathCheckNilTrue, e) - case *map[float64]int32: - fastpathTV.EncMapFloat64Int32V(*v, fastpathCheckNilTrue, e) - - case map[float64]int64: - fastpathTV.EncMapFloat64Int64V(v, fastpathCheckNilTrue, e) - case *map[float64]int64: - fastpathTV.EncMapFloat64Int64V(*v, fastpathCheckNilTrue, e) - - case map[float64]float32: - fastpathTV.EncMapFloat64Float32V(v, fastpathCheckNilTrue, e) - case *map[float64]float32: - fastpathTV.EncMapFloat64Float32V(*v, fastpathCheckNilTrue, e) - - case map[float64]float64: - fastpathTV.EncMapFloat64Float64V(v, fastpathCheckNilTrue, e) - case *map[float64]float64: - fastpathTV.EncMapFloat64Float64V(*v, fastpathCheckNilTrue, e) - - case map[float64]bool: - fastpathTV.EncMapFloat64BoolV(v, fastpathCheckNilTrue, e) - case *map[float64]bool: - fastpathTV.EncMapFloat64BoolV(*v, fastpathCheckNilTrue, e) - - case map[uint]interface{}: - fastpathTV.EncMapUintIntfV(v, fastpathCheckNilTrue, e) - case *map[uint]interface{}: - fastpathTV.EncMapUintIntfV(*v, fastpathCheckNilTrue, e) - - case map[uint]string: - fastpathTV.EncMapUintStringV(v, fastpathCheckNilTrue, e) - case *map[uint]string: - fastpathTV.EncMapUintStringV(*v, fastpathCheckNilTrue, e) - - case map[uint]uint: - fastpathTV.EncMapUintUintV(v, fastpathCheckNilTrue, e) - case *map[uint]uint: - fastpathTV.EncMapUintUintV(*v, fastpathCheckNilTrue, e) - - case map[uint]uint8: - fastpathTV.EncMapUintUint8V(v, fastpathCheckNilTrue, e) - case *map[uint]uint8: - fastpathTV.EncMapUintUint8V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint16: - fastpathTV.EncMapUintUint16V(v, fastpathCheckNilTrue, e) - case *map[uint]uint16: - fastpathTV.EncMapUintUint16V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint32: - fastpathTV.EncMapUintUint32V(v, fastpathCheckNilTrue, e) - case *map[uint]uint32: - fastpathTV.EncMapUintUint32V(*v, fastpathCheckNilTrue, e) - - case map[uint]uint64: - fastpathTV.EncMapUintUint64V(v, fastpathCheckNilTrue, e) - case *map[uint]uint64: - fastpathTV.EncMapUintUint64V(*v, fastpathCheckNilTrue, e) - - case map[uint]uintptr: - fastpathTV.EncMapUintUintptrV(v, fastpathCheckNilTrue, e) - case *map[uint]uintptr: - fastpathTV.EncMapUintUintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint]int: - fastpathTV.EncMapUintIntV(v, fastpathCheckNilTrue, e) - case *map[uint]int: - fastpathTV.EncMapUintIntV(*v, fastpathCheckNilTrue, e) - - case map[uint]int8: - fastpathTV.EncMapUintInt8V(v, fastpathCheckNilTrue, e) - case *map[uint]int8: - fastpathTV.EncMapUintInt8V(*v, fastpathCheckNilTrue, e) - - case map[uint]int16: - fastpathTV.EncMapUintInt16V(v, fastpathCheckNilTrue, e) - case *map[uint]int16: - fastpathTV.EncMapUintInt16V(*v, fastpathCheckNilTrue, e) - - case map[uint]int32: - fastpathTV.EncMapUintInt32V(v, fastpathCheckNilTrue, e) - case *map[uint]int32: - fastpathTV.EncMapUintInt32V(*v, fastpathCheckNilTrue, e) - - case map[uint]int64: - fastpathTV.EncMapUintInt64V(v, fastpathCheckNilTrue, e) - case *map[uint]int64: - fastpathTV.EncMapUintInt64V(*v, fastpathCheckNilTrue, e) - - case map[uint]float32: - fastpathTV.EncMapUintFloat32V(v, fastpathCheckNilTrue, e) - case *map[uint]float32: - fastpathTV.EncMapUintFloat32V(*v, fastpathCheckNilTrue, e) - - case map[uint]float64: - fastpathTV.EncMapUintFloat64V(v, fastpathCheckNilTrue, e) - case *map[uint]float64: - fastpathTV.EncMapUintFloat64V(*v, fastpathCheckNilTrue, e) - - case map[uint]bool: - fastpathTV.EncMapUintBoolV(v, fastpathCheckNilTrue, e) - case *map[uint]bool: - fastpathTV.EncMapUintBoolV(*v, fastpathCheckNilTrue, e) - - case map[uint8]interface{}: - fastpathTV.EncMapUint8IntfV(v, fastpathCheckNilTrue, e) - case *map[uint8]interface{}: - fastpathTV.EncMapUint8IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint8]string: - fastpathTV.EncMapUint8StringV(v, fastpathCheckNilTrue, e) - case *map[uint8]string: - fastpathTV.EncMapUint8StringV(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint: - fastpathTV.EncMapUint8UintV(v, fastpathCheckNilTrue, e) - case *map[uint8]uint: - fastpathTV.EncMapUint8UintV(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint8: - fastpathTV.EncMapUint8Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint8: - fastpathTV.EncMapUint8Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint16: - fastpathTV.EncMapUint8Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint16: - fastpathTV.EncMapUint8Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint32: - fastpathTV.EncMapUint8Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint32: - fastpathTV.EncMapUint8Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uint64: - fastpathTV.EncMapUint8Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint8]uint64: - fastpathTV.EncMapUint8Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]uintptr: - fastpathTV.EncMapUint8UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint8]uintptr: - fastpathTV.EncMapUint8UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint8]int: - fastpathTV.EncMapUint8IntV(v, fastpathCheckNilTrue, e) - case *map[uint8]int: - fastpathTV.EncMapUint8IntV(*v, fastpathCheckNilTrue, e) - - case map[uint8]int8: - fastpathTV.EncMapUint8Int8V(v, fastpathCheckNilTrue, e) - case *map[uint8]int8: - fastpathTV.EncMapUint8Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int16: - fastpathTV.EncMapUint8Int16V(v, fastpathCheckNilTrue, e) - case *map[uint8]int16: - fastpathTV.EncMapUint8Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int32: - fastpathTV.EncMapUint8Int32V(v, fastpathCheckNilTrue, e) - case *map[uint8]int32: - fastpathTV.EncMapUint8Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]int64: - fastpathTV.EncMapUint8Int64V(v, fastpathCheckNilTrue, e) - case *map[uint8]int64: - fastpathTV.EncMapUint8Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]float32: - fastpathTV.EncMapUint8Float32V(v, fastpathCheckNilTrue, e) - case *map[uint8]float32: - fastpathTV.EncMapUint8Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint8]float64: - fastpathTV.EncMapUint8Float64V(v, fastpathCheckNilTrue, e) - case *map[uint8]float64: - fastpathTV.EncMapUint8Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint8]bool: - fastpathTV.EncMapUint8BoolV(v, fastpathCheckNilTrue, e) - case *map[uint8]bool: - fastpathTV.EncMapUint8BoolV(*v, fastpathCheckNilTrue, e) - - case map[uint16]interface{}: - fastpathTV.EncMapUint16IntfV(v, fastpathCheckNilTrue, e) - case *map[uint16]interface{}: - fastpathTV.EncMapUint16IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint16]string: - fastpathTV.EncMapUint16StringV(v, fastpathCheckNilTrue, e) - case *map[uint16]string: - fastpathTV.EncMapUint16StringV(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint: - fastpathTV.EncMapUint16UintV(v, fastpathCheckNilTrue, e) - case *map[uint16]uint: - fastpathTV.EncMapUint16UintV(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint8: - fastpathTV.EncMapUint16Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint8: - fastpathTV.EncMapUint16Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint16: - fastpathTV.EncMapUint16Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint16: - fastpathTV.EncMapUint16Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint32: - fastpathTV.EncMapUint16Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint32: - fastpathTV.EncMapUint16Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uint64: - fastpathTV.EncMapUint16Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint16]uint64: - fastpathTV.EncMapUint16Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]uintptr: - fastpathTV.EncMapUint16UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint16]uintptr: - fastpathTV.EncMapUint16UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint16]int: - fastpathTV.EncMapUint16IntV(v, fastpathCheckNilTrue, e) - case *map[uint16]int: - fastpathTV.EncMapUint16IntV(*v, fastpathCheckNilTrue, e) - - case map[uint16]int8: - fastpathTV.EncMapUint16Int8V(v, fastpathCheckNilTrue, e) - case *map[uint16]int8: - fastpathTV.EncMapUint16Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int16: - fastpathTV.EncMapUint16Int16V(v, fastpathCheckNilTrue, e) - case *map[uint16]int16: - fastpathTV.EncMapUint16Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int32: - fastpathTV.EncMapUint16Int32V(v, fastpathCheckNilTrue, e) - case *map[uint16]int32: - fastpathTV.EncMapUint16Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]int64: - fastpathTV.EncMapUint16Int64V(v, fastpathCheckNilTrue, e) - case *map[uint16]int64: - fastpathTV.EncMapUint16Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]float32: - fastpathTV.EncMapUint16Float32V(v, fastpathCheckNilTrue, e) - case *map[uint16]float32: - fastpathTV.EncMapUint16Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint16]float64: - fastpathTV.EncMapUint16Float64V(v, fastpathCheckNilTrue, e) - case *map[uint16]float64: - fastpathTV.EncMapUint16Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint16]bool: - fastpathTV.EncMapUint16BoolV(v, fastpathCheckNilTrue, e) - case *map[uint16]bool: - fastpathTV.EncMapUint16BoolV(*v, fastpathCheckNilTrue, e) - - case map[uint32]interface{}: - fastpathTV.EncMapUint32IntfV(v, fastpathCheckNilTrue, e) - case *map[uint32]interface{}: - fastpathTV.EncMapUint32IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint32]string: - fastpathTV.EncMapUint32StringV(v, fastpathCheckNilTrue, e) - case *map[uint32]string: - fastpathTV.EncMapUint32StringV(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint: - fastpathTV.EncMapUint32UintV(v, fastpathCheckNilTrue, e) - case *map[uint32]uint: - fastpathTV.EncMapUint32UintV(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint8: - fastpathTV.EncMapUint32Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint8: - fastpathTV.EncMapUint32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint16: - fastpathTV.EncMapUint32Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint16: - fastpathTV.EncMapUint32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint32: - fastpathTV.EncMapUint32Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint32: - fastpathTV.EncMapUint32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uint64: - fastpathTV.EncMapUint32Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint32]uint64: - fastpathTV.EncMapUint32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]uintptr: - fastpathTV.EncMapUint32UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint32]uintptr: - fastpathTV.EncMapUint32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint32]int: - fastpathTV.EncMapUint32IntV(v, fastpathCheckNilTrue, e) - case *map[uint32]int: - fastpathTV.EncMapUint32IntV(*v, fastpathCheckNilTrue, e) - - case map[uint32]int8: - fastpathTV.EncMapUint32Int8V(v, fastpathCheckNilTrue, e) - case *map[uint32]int8: - fastpathTV.EncMapUint32Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int16: - fastpathTV.EncMapUint32Int16V(v, fastpathCheckNilTrue, e) - case *map[uint32]int16: - fastpathTV.EncMapUint32Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int32: - fastpathTV.EncMapUint32Int32V(v, fastpathCheckNilTrue, e) - case *map[uint32]int32: - fastpathTV.EncMapUint32Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]int64: - fastpathTV.EncMapUint32Int64V(v, fastpathCheckNilTrue, e) - case *map[uint32]int64: - fastpathTV.EncMapUint32Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]float32: - fastpathTV.EncMapUint32Float32V(v, fastpathCheckNilTrue, e) - case *map[uint32]float32: - fastpathTV.EncMapUint32Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint32]float64: - fastpathTV.EncMapUint32Float64V(v, fastpathCheckNilTrue, e) - case *map[uint32]float64: - fastpathTV.EncMapUint32Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint32]bool: - fastpathTV.EncMapUint32BoolV(v, fastpathCheckNilTrue, e) - case *map[uint32]bool: - fastpathTV.EncMapUint32BoolV(*v, fastpathCheckNilTrue, e) - - case map[uint64]interface{}: - fastpathTV.EncMapUint64IntfV(v, fastpathCheckNilTrue, e) - case *map[uint64]interface{}: - fastpathTV.EncMapUint64IntfV(*v, fastpathCheckNilTrue, e) - - case map[uint64]string: - fastpathTV.EncMapUint64StringV(v, fastpathCheckNilTrue, e) - case *map[uint64]string: - fastpathTV.EncMapUint64StringV(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint: - fastpathTV.EncMapUint64UintV(v, fastpathCheckNilTrue, e) - case *map[uint64]uint: - fastpathTV.EncMapUint64UintV(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint8: - fastpathTV.EncMapUint64Uint8V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint8: - fastpathTV.EncMapUint64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint16: - fastpathTV.EncMapUint64Uint16V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint16: - fastpathTV.EncMapUint64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint32: - fastpathTV.EncMapUint64Uint32V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint32: - fastpathTV.EncMapUint64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uint64: - fastpathTV.EncMapUint64Uint64V(v, fastpathCheckNilTrue, e) - case *map[uint64]uint64: - fastpathTV.EncMapUint64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]uintptr: - fastpathTV.EncMapUint64UintptrV(v, fastpathCheckNilTrue, e) - case *map[uint64]uintptr: - fastpathTV.EncMapUint64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[uint64]int: - fastpathTV.EncMapUint64IntV(v, fastpathCheckNilTrue, e) - case *map[uint64]int: - fastpathTV.EncMapUint64IntV(*v, fastpathCheckNilTrue, e) - - case map[uint64]int8: - fastpathTV.EncMapUint64Int8V(v, fastpathCheckNilTrue, e) - case *map[uint64]int8: - fastpathTV.EncMapUint64Int8V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int16: - fastpathTV.EncMapUint64Int16V(v, fastpathCheckNilTrue, e) - case *map[uint64]int16: - fastpathTV.EncMapUint64Int16V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int32: - fastpathTV.EncMapUint64Int32V(v, fastpathCheckNilTrue, e) - case *map[uint64]int32: - fastpathTV.EncMapUint64Int32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]int64: - fastpathTV.EncMapUint64Int64V(v, fastpathCheckNilTrue, e) - case *map[uint64]int64: - fastpathTV.EncMapUint64Int64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]float32: - fastpathTV.EncMapUint64Float32V(v, fastpathCheckNilTrue, e) - case *map[uint64]float32: - fastpathTV.EncMapUint64Float32V(*v, fastpathCheckNilTrue, e) - - case map[uint64]float64: - fastpathTV.EncMapUint64Float64V(v, fastpathCheckNilTrue, e) - case *map[uint64]float64: - fastpathTV.EncMapUint64Float64V(*v, fastpathCheckNilTrue, e) - - case map[uint64]bool: - fastpathTV.EncMapUint64BoolV(v, fastpathCheckNilTrue, e) - case *map[uint64]bool: - fastpathTV.EncMapUint64BoolV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]interface{}: - fastpathTV.EncMapUintptrIntfV(v, fastpathCheckNilTrue, e) - case *map[uintptr]interface{}: - fastpathTV.EncMapUintptrIntfV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]string: - fastpathTV.EncMapUintptrStringV(v, fastpathCheckNilTrue, e) - case *map[uintptr]string: - fastpathTV.EncMapUintptrStringV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint: - fastpathTV.EncMapUintptrUintV(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint: - fastpathTV.EncMapUintptrUintV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint8: - fastpathTV.EncMapUintptrUint8V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint8: - fastpathTV.EncMapUintptrUint8V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint16: - fastpathTV.EncMapUintptrUint16V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint16: - fastpathTV.EncMapUintptrUint16V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint32: - fastpathTV.EncMapUintptrUint32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint32: - fastpathTV.EncMapUintptrUint32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uint64: - fastpathTV.EncMapUintptrUint64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]uint64: - fastpathTV.EncMapUintptrUint64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]uintptr: - fastpathTV.EncMapUintptrUintptrV(v, fastpathCheckNilTrue, e) - case *map[uintptr]uintptr: - fastpathTV.EncMapUintptrUintptrV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int: - fastpathTV.EncMapUintptrIntV(v, fastpathCheckNilTrue, e) - case *map[uintptr]int: - fastpathTV.EncMapUintptrIntV(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int8: - fastpathTV.EncMapUintptrInt8V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int8: - fastpathTV.EncMapUintptrInt8V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int16: - fastpathTV.EncMapUintptrInt16V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int16: - fastpathTV.EncMapUintptrInt16V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int32: - fastpathTV.EncMapUintptrInt32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int32: - fastpathTV.EncMapUintptrInt32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]int64: - fastpathTV.EncMapUintptrInt64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]int64: - fastpathTV.EncMapUintptrInt64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]float32: - fastpathTV.EncMapUintptrFloat32V(v, fastpathCheckNilTrue, e) - case *map[uintptr]float32: - fastpathTV.EncMapUintptrFloat32V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]float64: - fastpathTV.EncMapUintptrFloat64V(v, fastpathCheckNilTrue, e) - case *map[uintptr]float64: - fastpathTV.EncMapUintptrFloat64V(*v, fastpathCheckNilTrue, e) - - case map[uintptr]bool: - fastpathTV.EncMapUintptrBoolV(v, fastpathCheckNilTrue, e) - case *map[uintptr]bool: - fastpathTV.EncMapUintptrBoolV(*v, fastpathCheckNilTrue, e) - - case map[int]interface{}: - fastpathTV.EncMapIntIntfV(v, fastpathCheckNilTrue, e) - case *map[int]interface{}: - fastpathTV.EncMapIntIntfV(*v, fastpathCheckNilTrue, e) - - case map[int]string: - fastpathTV.EncMapIntStringV(v, fastpathCheckNilTrue, e) - case *map[int]string: - fastpathTV.EncMapIntStringV(*v, fastpathCheckNilTrue, e) - - case map[int]uint: - fastpathTV.EncMapIntUintV(v, fastpathCheckNilTrue, e) - case *map[int]uint: - fastpathTV.EncMapIntUintV(*v, fastpathCheckNilTrue, e) - - case map[int]uint8: - fastpathTV.EncMapIntUint8V(v, fastpathCheckNilTrue, e) - case *map[int]uint8: - fastpathTV.EncMapIntUint8V(*v, fastpathCheckNilTrue, e) - - case map[int]uint16: - fastpathTV.EncMapIntUint16V(v, fastpathCheckNilTrue, e) - case *map[int]uint16: - fastpathTV.EncMapIntUint16V(*v, fastpathCheckNilTrue, e) - - case map[int]uint32: - fastpathTV.EncMapIntUint32V(v, fastpathCheckNilTrue, e) - case *map[int]uint32: - fastpathTV.EncMapIntUint32V(*v, fastpathCheckNilTrue, e) - - case map[int]uint64: - fastpathTV.EncMapIntUint64V(v, fastpathCheckNilTrue, e) - case *map[int]uint64: - fastpathTV.EncMapIntUint64V(*v, fastpathCheckNilTrue, e) - - case map[int]uintptr: - fastpathTV.EncMapIntUintptrV(v, fastpathCheckNilTrue, e) - case *map[int]uintptr: - fastpathTV.EncMapIntUintptrV(*v, fastpathCheckNilTrue, e) - - case map[int]int: - fastpathTV.EncMapIntIntV(v, fastpathCheckNilTrue, e) - case *map[int]int: - fastpathTV.EncMapIntIntV(*v, fastpathCheckNilTrue, e) - - case map[int]int8: - fastpathTV.EncMapIntInt8V(v, fastpathCheckNilTrue, e) - case *map[int]int8: - fastpathTV.EncMapIntInt8V(*v, fastpathCheckNilTrue, e) - - case map[int]int16: - fastpathTV.EncMapIntInt16V(v, fastpathCheckNilTrue, e) - case *map[int]int16: - fastpathTV.EncMapIntInt16V(*v, fastpathCheckNilTrue, e) - - case map[int]int32: - fastpathTV.EncMapIntInt32V(v, fastpathCheckNilTrue, e) - case *map[int]int32: - fastpathTV.EncMapIntInt32V(*v, fastpathCheckNilTrue, e) - - case map[int]int64: - fastpathTV.EncMapIntInt64V(v, fastpathCheckNilTrue, e) - case *map[int]int64: - fastpathTV.EncMapIntInt64V(*v, fastpathCheckNilTrue, e) - - case map[int]float32: - fastpathTV.EncMapIntFloat32V(v, fastpathCheckNilTrue, e) - case *map[int]float32: - fastpathTV.EncMapIntFloat32V(*v, fastpathCheckNilTrue, e) - - case map[int]float64: - fastpathTV.EncMapIntFloat64V(v, fastpathCheckNilTrue, e) - case *map[int]float64: - fastpathTV.EncMapIntFloat64V(*v, fastpathCheckNilTrue, e) - - case map[int]bool: - fastpathTV.EncMapIntBoolV(v, fastpathCheckNilTrue, e) - case *map[int]bool: - fastpathTV.EncMapIntBoolV(*v, fastpathCheckNilTrue, e) - - case map[int8]interface{}: - fastpathTV.EncMapInt8IntfV(v, fastpathCheckNilTrue, e) - case *map[int8]interface{}: - fastpathTV.EncMapInt8IntfV(*v, fastpathCheckNilTrue, e) - - case map[int8]string: - fastpathTV.EncMapInt8StringV(v, fastpathCheckNilTrue, e) - case *map[int8]string: - fastpathTV.EncMapInt8StringV(*v, fastpathCheckNilTrue, e) - - case map[int8]uint: - fastpathTV.EncMapInt8UintV(v, fastpathCheckNilTrue, e) - case *map[int8]uint: - fastpathTV.EncMapInt8UintV(*v, fastpathCheckNilTrue, e) - - case map[int8]uint8: - fastpathTV.EncMapInt8Uint8V(v, fastpathCheckNilTrue, e) - case *map[int8]uint8: - fastpathTV.EncMapInt8Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint16: - fastpathTV.EncMapInt8Uint16V(v, fastpathCheckNilTrue, e) - case *map[int8]uint16: - fastpathTV.EncMapInt8Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint32: - fastpathTV.EncMapInt8Uint32V(v, fastpathCheckNilTrue, e) - case *map[int8]uint32: - fastpathTV.EncMapInt8Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int8]uint64: - fastpathTV.EncMapInt8Uint64V(v, fastpathCheckNilTrue, e) - case *map[int8]uint64: - fastpathTV.EncMapInt8Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int8]uintptr: - fastpathTV.EncMapInt8UintptrV(v, fastpathCheckNilTrue, e) - case *map[int8]uintptr: - fastpathTV.EncMapInt8UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int8]int: - fastpathTV.EncMapInt8IntV(v, fastpathCheckNilTrue, e) - case *map[int8]int: - fastpathTV.EncMapInt8IntV(*v, fastpathCheckNilTrue, e) - - case map[int8]int8: - fastpathTV.EncMapInt8Int8V(v, fastpathCheckNilTrue, e) - case *map[int8]int8: - fastpathTV.EncMapInt8Int8V(*v, fastpathCheckNilTrue, e) - - case map[int8]int16: - fastpathTV.EncMapInt8Int16V(v, fastpathCheckNilTrue, e) - case *map[int8]int16: - fastpathTV.EncMapInt8Int16V(*v, fastpathCheckNilTrue, e) - - case map[int8]int32: - fastpathTV.EncMapInt8Int32V(v, fastpathCheckNilTrue, e) - case *map[int8]int32: - fastpathTV.EncMapInt8Int32V(*v, fastpathCheckNilTrue, e) - - case map[int8]int64: - fastpathTV.EncMapInt8Int64V(v, fastpathCheckNilTrue, e) - case *map[int8]int64: - fastpathTV.EncMapInt8Int64V(*v, fastpathCheckNilTrue, e) - - case map[int8]float32: - fastpathTV.EncMapInt8Float32V(v, fastpathCheckNilTrue, e) - case *map[int8]float32: - fastpathTV.EncMapInt8Float32V(*v, fastpathCheckNilTrue, e) - - case map[int8]float64: - fastpathTV.EncMapInt8Float64V(v, fastpathCheckNilTrue, e) - case *map[int8]float64: - fastpathTV.EncMapInt8Float64V(*v, fastpathCheckNilTrue, e) - - case map[int8]bool: - fastpathTV.EncMapInt8BoolV(v, fastpathCheckNilTrue, e) - case *map[int8]bool: - fastpathTV.EncMapInt8BoolV(*v, fastpathCheckNilTrue, e) - - case map[int16]interface{}: - fastpathTV.EncMapInt16IntfV(v, fastpathCheckNilTrue, e) - case *map[int16]interface{}: - fastpathTV.EncMapInt16IntfV(*v, fastpathCheckNilTrue, e) - - case map[int16]string: - fastpathTV.EncMapInt16StringV(v, fastpathCheckNilTrue, e) - case *map[int16]string: - fastpathTV.EncMapInt16StringV(*v, fastpathCheckNilTrue, e) - - case map[int16]uint: - fastpathTV.EncMapInt16UintV(v, fastpathCheckNilTrue, e) - case *map[int16]uint: - fastpathTV.EncMapInt16UintV(*v, fastpathCheckNilTrue, e) - - case map[int16]uint8: - fastpathTV.EncMapInt16Uint8V(v, fastpathCheckNilTrue, e) - case *map[int16]uint8: - fastpathTV.EncMapInt16Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint16: - fastpathTV.EncMapInt16Uint16V(v, fastpathCheckNilTrue, e) - case *map[int16]uint16: - fastpathTV.EncMapInt16Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint32: - fastpathTV.EncMapInt16Uint32V(v, fastpathCheckNilTrue, e) - case *map[int16]uint32: - fastpathTV.EncMapInt16Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int16]uint64: - fastpathTV.EncMapInt16Uint64V(v, fastpathCheckNilTrue, e) - case *map[int16]uint64: - fastpathTV.EncMapInt16Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int16]uintptr: - fastpathTV.EncMapInt16UintptrV(v, fastpathCheckNilTrue, e) - case *map[int16]uintptr: - fastpathTV.EncMapInt16UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int16]int: - fastpathTV.EncMapInt16IntV(v, fastpathCheckNilTrue, e) - case *map[int16]int: - fastpathTV.EncMapInt16IntV(*v, fastpathCheckNilTrue, e) - - case map[int16]int8: - fastpathTV.EncMapInt16Int8V(v, fastpathCheckNilTrue, e) - case *map[int16]int8: - fastpathTV.EncMapInt16Int8V(*v, fastpathCheckNilTrue, e) - - case map[int16]int16: - fastpathTV.EncMapInt16Int16V(v, fastpathCheckNilTrue, e) - case *map[int16]int16: - fastpathTV.EncMapInt16Int16V(*v, fastpathCheckNilTrue, e) - - case map[int16]int32: - fastpathTV.EncMapInt16Int32V(v, fastpathCheckNilTrue, e) - case *map[int16]int32: - fastpathTV.EncMapInt16Int32V(*v, fastpathCheckNilTrue, e) - - case map[int16]int64: - fastpathTV.EncMapInt16Int64V(v, fastpathCheckNilTrue, e) - case *map[int16]int64: - fastpathTV.EncMapInt16Int64V(*v, fastpathCheckNilTrue, e) - - case map[int16]float32: - fastpathTV.EncMapInt16Float32V(v, fastpathCheckNilTrue, e) - case *map[int16]float32: - fastpathTV.EncMapInt16Float32V(*v, fastpathCheckNilTrue, e) - - case map[int16]float64: - fastpathTV.EncMapInt16Float64V(v, fastpathCheckNilTrue, e) - case *map[int16]float64: - fastpathTV.EncMapInt16Float64V(*v, fastpathCheckNilTrue, e) - - case map[int16]bool: - fastpathTV.EncMapInt16BoolV(v, fastpathCheckNilTrue, e) - case *map[int16]bool: - fastpathTV.EncMapInt16BoolV(*v, fastpathCheckNilTrue, e) - - case map[int32]interface{}: - fastpathTV.EncMapInt32IntfV(v, fastpathCheckNilTrue, e) - case *map[int32]interface{}: - fastpathTV.EncMapInt32IntfV(*v, fastpathCheckNilTrue, e) - - case map[int32]string: - fastpathTV.EncMapInt32StringV(v, fastpathCheckNilTrue, e) - case *map[int32]string: - fastpathTV.EncMapInt32StringV(*v, fastpathCheckNilTrue, e) - - case map[int32]uint: - fastpathTV.EncMapInt32UintV(v, fastpathCheckNilTrue, e) - case *map[int32]uint: - fastpathTV.EncMapInt32UintV(*v, fastpathCheckNilTrue, e) - - case map[int32]uint8: - fastpathTV.EncMapInt32Uint8V(v, fastpathCheckNilTrue, e) - case *map[int32]uint8: - fastpathTV.EncMapInt32Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint16: - fastpathTV.EncMapInt32Uint16V(v, fastpathCheckNilTrue, e) - case *map[int32]uint16: - fastpathTV.EncMapInt32Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint32: - fastpathTV.EncMapInt32Uint32V(v, fastpathCheckNilTrue, e) - case *map[int32]uint32: - fastpathTV.EncMapInt32Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int32]uint64: - fastpathTV.EncMapInt32Uint64V(v, fastpathCheckNilTrue, e) - case *map[int32]uint64: - fastpathTV.EncMapInt32Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int32]uintptr: - fastpathTV.EncMapInt32UintptrV(v, fastpathCheckNilTrue, e) - case *map[int32]uintptr: - fastpathTV.EncMapInt32UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int32]int: - fastpathTV.EncMapInt32IntV(v, fastpathCheckNilTrue, e) - case *map[int32]int: - fastpathTV.EncMapInt32IntV(*v, fastpathCheckNilTrue, e) - - case map[int32]int8: - fastpathTV.EncMapInt32Int8V(v, fastpathCheckNilTrue, e) - case *map[int32]int8: - fastpathTV.EncMapInt32Int8V(*v, fastpathCheckNilTrue, e) - - case map[int32]int16: - fastpathTV.EncMapInt32Int16V(v, fastpathCheckNilTrue, e) - case *map[int32]int16: - fastpathTV.EncMapInt32Int16V(*v, fastpathCheckNilTrue, e) - - case map[int32]int32: - fastpathTV.EncMapInt32Int32V(v, fastpathCheckNilTrue, e) - case *map[int32]int32: - fastpathTV.EncMapInt32Int32V(*v, fastpathCheckNilTrue, e) - - case map[int32]int64: - fastpathTV.EncMapInt32Int64V(v, fastpathCheckNilTrue, e) - case *map[int32]int64: - fastpathTV.EncMapInt32Int64V(*v, fastpathCheckNilTrue, e) - - case map[int32]float32: - fastpathTV.EncMapInt32Float32V(v, fastpathCheckNilTrue, e) - case *map[int32]float32: - fastpathTV.EncMapInt32Float32V(*v, fastpathCheckNilTrue, e) - - case map[int32]float64: - fastpathTV.EncMapInt32Float64V(v, fastpathCheckNilTrue, e) - case *map[int32]float64: - fastpathTV.EncMapInt32Float64V(*v, fastpathCheckNilTrue, e) - - case map[int32]bool: - fastpathTV.EncMapInt32BoolV(v, fastpathCheckNilTrue, e) - case *map[int32]bool: - fastpathTV.EncMapInt32BoolV(*v, fastpathCheckNilTrue, e) - - case map[int64]interface{}: - fastpathTV.EncMapInt64IntfV(v, fastpathCheckNilTrue, e) - case *map[int64]interface{}: - fastpathTV.EncMapInt64IntfV(*v, fastpathCheckNilTrue, e) - - case map[int64]string: - fastpathTV.EncMapInt64StringV(v, fastpathCheckNilTrue, e) - case *map[int64]string: - fastpathTV.EncMapInt64StringV(*v, fastpathCheckNilTrue, e) - - case map[int64]uint: - fastpathTV.EncMapInt64UintV(v, fastpathCheckNilTrue, e) - case *map[int64]uint: - fastpathTV.EncMapInt64UintV(*v, fastpathCheckNilTrue, e) - - case map[int64]uint8: - fastpathTV.EncMapInt64Uint8V(v, fastpathCheckNilTrue, e) - case *map[int64]uint8: - fastpathTV.EncMapInt64Uint8V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint16: - fastpathTV.EncMapInt64Uint16V(v, fastpathCheckNilTrue, e) - case *map[int64]uint16: - fastpathTV.EncMapInt64Uint16V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint32: - fastpathTV.EncMapInt64Uint32V(v, fastpathCheckNilTrue, e) - case *map[int64]uint32: - fastpathTV.EncMapInt64Uint32V(*v, fastpathCheckNilTrue, e) - - case map[int64]uint64: - fastpathTV.EncMapInt64Uint64V(v, fastpathCheckNilTrue, e) - case *map[int64]uint64: - fastpathTV.EncMapInt64Uint64V(*v, fastpathCheckNilTrue, e) - - case map[int64]uintptr: - fastpathTV.EncMapInt64UintptrV(v, fastpathCheckNilTrue, e) - case *map[int64]uintptr: - fastpathTV.EncMapInt64UintptrV(*v, fastpathCheckNilTrue, e) - - case map[int64]int: - fastpathTV.EncMapInt64IntV(v, fastpathCheckNilTrue, e) - case *map[int64]int: - fastpathTV.EncMapInt64IntV(*v, fastpathCheckNilTrue, e) - - case map[int64]int8: - fastpathTV.EncMapInt64Int8V(v, fastpathCheckNilTrue, e) - case *map[int64]int8: - fastpathTV.EncMapInt64Int8V(*v, fastpathCheckNilTrue, e) - - case map[int64]int16: - fastpathTV.EncMapInt64Int16V(v, fastpathCheckNilTrue, e) - case *map[int64]int16: - fastpathTV.EncMapInt64Int16V(*v, fastpathCheckNilTrue, e) - - case map[int64]int32: - fastpathTV.EncMapInt64Int32V(v, fastpathCheckNilTrue, e) - case *map[int64]int32: - fastpathTV.EncMapInt64Int32V(*v, fastpathCheckNilTrue, e) - - case map[int64]int64: - fastpathTV.EncMapInt64Int64V(v, fastpathCheckNilTrue, e) - case *map[int64]int64: - fastpathTV.EncMapInt64Int64V(*v, fastpathCheckNilTrue, e) - - case map[int64]float32: - fastpathTV.EncMapInt64Float32V(v, fastpathCheckNilTrue, e) - case *map[int64]float32: - fastpathTV.EncMapInt64Float32V(*v, fastpathCheckNilTrue, e) - - case map[int64]float64: - fastpathTV.EncMapInt64Float64V(v, fastpathCheckNilTrue, e) - case *map[int64]float64: - fastpathTV.EncMapInt64Float64V(*v, fastpathCheckNilTrue, e) - - case map[int64]bool: - fastpathTV.EncMapInt64BoolV(v, fastpathCheckNilTrue, e) - case *map[int64]bool: - fastpathTV.EncMapInt64BoolV(*v, fastpathCheckNilTrue, e) - - case map[bool]interface{}: - fastpathTV.EncMapBoolIntfV(v, fastpathCheckNilTrue, e) - case *map[bool]interface{}: - fastpathTV.EncMapBoolIntfV(*v, fastpathCheckNilTrue, e) - - case map[bool]string: - fastpathTV.EncMapBoolStringV(v, fastpathCheckNilTrue, e) - case *map[bool]string: - fastpathTV.EncMapBoolStringV(*v, fastpathCheckNilTrue, e) - - case map[bool]uint: - fastpathTV.EncMapBoolUintV(v, fastpathCheckNilTrue, e) - case *map[bool]uint: - fastpathTV.EncMapBoolUintV(*v, fastpathCheckNilTrue, e) - - case map[bool]uint8: - fastpathTV.EncMapBoolUint8V(v, fastpathCheckNilTrue, e) - case *map[bool]uint8: - fastpathTV.EncMapBoolUint8V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint16: - fastpathTV.EncMapBoolUint16V(v, fastpathCheckNilTrue, e) - case *map[bool]uint16: - fastpathTV.EncMapBoolUint16V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint32: - fastpathTV.EncMapBoolUint32V(v, fastpathCheckNilTrue, e) - case *map[bool]uint32: - fastpathTV.EncMapBoolUint32V(*v, fastpathCheckNilTrue, e) - - case map[bool]uint64: - fastpathTV.EncMapBoolUint64V(v, fastpathCheckNilTrue, e) - case *map[bool]uint64: - fastpathTV.EncMapBoolUint64V(*v, fastpathCheckNilTrue, e) - - case map[bool]uintptr: - fastpathTV.EncMapBoolUintptrV(v, fastpathCheckNilTrue, e) - case *map[bool]uintptr: - fastpathTV.EncMapBoolUintptrV(*v, fastpathCheckNilTrue, e) - - case map[bool]int: - fastpathTV.EncMapBoolIntV(v, fastpathCheckNilTrue, e) - case *map[bool]int: - fastpathTV.EncMapBoolIntV(*v, fastpathCheckNilTrue, e) - - case map[bool]int8: - fastpathTV.EncMapBoolInt8V(v, fastpathCheckNilTrue, e) - case *map[bool]int8: - fastpathTV.EncMapBoolInt8V(*v, fastpathCheckNilTrue, e) - - case map[bool]int16: - fastpathTV.EncMapBoolInt16V(v, fastpathCheckNilTrue, e) - case *map[bool]int16: - fastpathTV.EncMapBoolInt16V(*v, fastpathCheckNilTrue, e) - - case map[bool]int32: - fastpathTV.EncMapBoolInt32V(v, fastpathCheckNilTrue, e) - case *map[bool]int32: - fastpathTV.EncMapBoolInt32V(*v, fastpathCheckNilTrue, e) - - case map[bool]int64: - fastpathTV.EncMapBoolInt64V(v, fastpathCheckNilTrue, e) - case *map[bool]int64: - fastpathTV.EncMapBoolInt64V(*v, fastpathCheckNilTrue, e) - - case map[bool]float32: - fastpathTV.EncMapBoolFloat32V(v, fastpathCheckNilTrue, e) - case *map[bool]float32: - fastpathTV.EncMapBoolFloat32V(*v, fastpathCheckNilTrue, e) - - case map[bool]float64: - fastpathTV.EncMapBoolFloat64V(v, fastpathCheckNilTrue, e) - case *map[bool]float64: - fastpathTV.EncMapBoolFloat64V(*v, fastpathCheckNilTrue, e) - - case map[bool]bool: - fastpathTV.EncMapBoolBoolV(v, fastpathCheckNilTrue, e) - case *map[bool]bool: - fastpathTV.EncMapBoolBoolV(*v, fastpathCheckNilTrue, e) - - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -// -- -- fast path functions - -func (f *encFnInfo) fastpathEncSliceIntfR(rv reflect.Value) { - fastpathTV.EncSliceIntfV(rv.Interface().([]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceIntfV(v []interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - e.encode(v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceStringR(rv reflect.Value) { - fastpathTV.EncSliceStringV(rv.Interface().([]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceStringV(v []string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeString(c_UTF8, v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceFloat32R(rv reflect.Value) { - fastpathTV.EncSliceFloat32V(rv.Interface().([]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceFloat32V(v []float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeFloat32(v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceFloat64R(rv reflect.Value) { - fastpathTV.EncSliceFloat64V(rv.Interface().([]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceFloat64V(v []float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeFloat64(v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceUintR(rv reflect.Value) { - fastpathTV.EncSliceUintV(rv.Interface().([]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceUintV(v []uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceUint16R(rv reflect.Value) { - fastpathTV.EncSliceUint16V(rv.Interface().([]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceUint16V(v []uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceUint32R(rv reflect.Value) { - fastpathTV.EncSliceUint32V(rv.Interface().([]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceUint32V(v []uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceUint64R(rv reflect.Value) { - fastpathTV.EncSliceUint64V(rv.Interface().([]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceUint64V(v []uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeUint(uint64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceUintptrR(rv reflect.Value) { - fastpathTV.EncSliceUintptrV(rv.Interface().([]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceUintptrV(v []uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - e.encode(v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceIntR(rv reflect.Value) { - fastpathTV.EncSliceIntV(rv.Interface().([]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceIntV(v []int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceInt8R(rv reflect.Value) { - fastpathTV.EncSliceInt8V(rv.Interface().([]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceInt8V(v []int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceInt16R(rv reflect.Value) { - fastpathTV.EncSliceInt16V(rv.Interface().([]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceInt16V(v []int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceInt32R(rv reflect.Value) { - fastpathTV.EncSliceInt32V(rv.Interface().([]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceInt32V(v []int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceInt64R(rv reflect.Value) { - fastpathTV.EncSliceInt64V(rv.Interface().([]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceInt64V(v []int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeInt(int64(v2)) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncSliceBoolR(rv reflect.Value) { - fastpathTV.EncSliceBoolV(rv.Interface().([]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncSliceBoolV(v []bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { - cr.sendContainerState(containerArrayElem) - } - ee.EncodeBool(v2) - } - if cr != nil { - cr.sendContainerState(containerArrayEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfIntfR(rv reflect.Value) { - fastpathTV.EncMapIntfIntfV(rv.Interface().(map[interface{}]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfIntfV(v map[interface{}]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfStringR(rv reflect.Value) { - fastpathTV.EncMapIntfStringV(rv.Interface().(map[interface{}]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfStringV(v map[interface{}]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUintR(rv reflect.Value) { - fastpathTV.EncMapIntfUintV(rv.Interface().(map[interface{}]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUintV(v map[interface{}]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUint8R(rv reflect.Value) { - fastpathTV.EncMapIntfUint8V(rv.Interface().(map[interface{}]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUint8V(v map[interface{}]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUint16R(rv reflect.Value) { - fastpathTV.EncMapIntfUint16V(rv.Interface().(map[interface{}]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUint16V(v map[interface{}]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUint32R(rv reflect.Value) { - fastpathTV.EncMapIntfUint32V(rv.Interface().(map[interface{}]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUint32V(v map[interface{}]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUint64R(rv reflect.Value) { - fastpathTV.EncMapIntfUint64V(rv.Interface().(map[interface{}]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUint64V(v map[interface{}]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfUintptrR(rv reflect.Value) { - fastpathTV.EncMapIntfUintptrV(rv.Interface().(map[interface{}]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfUintptrV(v map[interface{}]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfIntR(rv reflect.Value) { - fastpathTV.EncMapIntfIntV(rv.Interface().(map[interface{}]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfIntV(v map[interface{}]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfInt8R(rv reflect.Value) { - fastpathTV.EncMapIntfInt8V(rv.Interface().(map[interface{}]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfInt8V(v map[interface{}]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfInt16R(rv reflect.Value) { - fastpathTV.EncMapIntfInt16V(rv.Interface().(map[interface{}]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfInt16V(v map[interface{}]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfInt32R(rv reflect.Value) { - fastpathTV.EncMapIntfInt32V(rv.Interface().(map[interface{}]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfInt32V(v map[interface{}]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfInt64R(rv reflect.Value) { - fastpathTV.EncMapIntfInt64V(rv.Interface().(map[interface{}]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfInt64V(v map[interface{}]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfFloat32R(rv reflect.Value) { - fastpathTV.EncMapIntfFloat32V(rv.Interface().(map[interface{}]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfFloat32V(v map[interface{}]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfFloat64R(rv reflect.Value) { - fastpathTV.EncMapIntfFloat64V(rv.Interface().(map[interface{}]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfFloat64V(v map[interface{}]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntfBoolR(rv reflect.Value) { - fastpathTV.EncMapIntfBoolV(rv.Interface().(map[interface{}]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntfBoolV(v map[interface{}]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.asis(v2[j].v) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[v2[j].i]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringIntfR(rv reflect.Value) { - fastpathTV.EncMapStringIntfV(rv.Interface().(map[string]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringIntfV(v map[string]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringStringR(rv reflect.Value) { - fastpathTV.EncMapStringStringV(rv.Interface().(map[string]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringStringV(v map[string]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUintR(rv reflect.Value) { - fastpathTV.EncMapStringUintV(rv.Interface().(map[string]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUintV(v map[string]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUint8R(rv reflect.Value) { - fastpathTV.EncMapStringUint8V(rv.Interface().(map[string]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUint8V(v map[string]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUint16R(rv reflect.Value) { - fastpathTV.EncMapStringUint16V(rv.Interface().(map[string]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUint16V(v map[string]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUint32R(rv reflect.Value) { - fastpathTV.EncMapStringUint32V(rv.Interface().(map[string]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUint32V(v map[string]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUint64R(rv reflect.Value) { - fastpathTV.EncMapStringUint64V(rv.Interface().(map[string]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUint64V(v map[string]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringUintptrR(rv reflect.Value) { - fastpathTV.EncMapStringUintptrV(rv.Interface().(map[string]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringUintptrV(v map[string]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringIntR(rv reflect.Value) { - fastpathTV.EncMapStringIntV(rv.Interface().(map[string]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringIntV(v map[string]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringInt8R(rv reflect.Value) { - fastpathTV.EncMapStringInt8V(rv.Interface().(map[string]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringInt8V(v map[string]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringInt16R(rv reflect.Value) { - fastpathTV.EncMapStringInt16V(rv.Interface().(map[string]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringInt16V(v map[string]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringInt32R(rv reflect.Value) { - fastpathTV.EncMapStringInt32V(rv.Interface().(map[string]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringInt32V(v map[string]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringInt64R(rv reflect.Value) { - fastpathTV.EncMapStringInt64V(rv.Interface().(map[string]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringInt64V(v map[string]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[string(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringFloat32R(rv reflect.Value) { - fastpathTV.EncMapStringFloat32V(rv.Interface().(map[string]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringFloat32V(v map[string]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringFloat64R(rv reflect.Value) { - fastpathTV.EncMapStringFloat64V(rv.Interface().(map[string]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringFloat64V(v map[string]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapStringBoolR(rv reflect.Value) { - fastpathTV.EncMapStringBoolV(rv.Interface().(map[string]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapStringBoolV(v map[string]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - if e.h.Canonical { - v2 := make([]string, len(v)) - var i int - for k, _ := range v { - v2[i] = string(k) - i++ - } - sort.Sort(stringSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[string(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32IntfR(rv reflect.Value) { - fastpathTV.EncMapFloat32IntfV(rv.Interface().(map[float32]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32IntfV(v map[float32]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32StringR(rv reflect.Value) { - fastpathTV.EncMapFloat32StringV(rv.Interface().(map[float32]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32StringV(v map[float32]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32UintR(rv reflect.Value) { - fastpathTV.EncMapFloat32UintV(rv.Interface().(map[float32]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32UintV(v map[float32]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Uint8R(rv reflect.Value) { - fastpathTV.EncMapFloat32Uint8V(rv.Interface().(map[float32]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Uint8V(v map[float32]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Uint16R(rv reflect.Value) { - fastpathTV.EncMapFloat32Uint16V(rv.Interface().(map[float32]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Uint16V(v map[float32]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Uint32R(rv reflect.Value) { - fastpathTV.EncMapFloat32Uint32V(rv.Interface().(map[float32]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Uint32V(v map[float32]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Uint64R(rv reflect.Value) { - fastpathTV.EncMapFloat32Uint64V(rv.Interface().(map[float32]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Uint64V(v map[float32]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32UintptrR(rv reflect.Value) { - fastpathTV.EncMapFloat32UintptrV(rv.Interface().(map[float32]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32UintptrV(v map[float32]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32IntR(rv reflect.Value) { - fastpathTV.EncMapFloat32IntV(rv.Interface().(map[float32]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32IntV(v map[float32]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Int8R(rv reflect.Value) { - fastpathTV.EncMapFloat32Int8V(rv.Interface().(map[float32]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Int8V(v map[float32]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Int16R(rv reflect.Value) { - fastpathTV.EncMapFloat32Int16V(rv.Interface().(map[float32]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Int16V(v map[float32]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Int32R(rv reflect.Value) { - fastpathTV.EncMapFloat32Int32V(rv.Interface().(map[float32]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Int32V(v map[float32]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Int64R(rv reflect.Value) { - fastpathTV.EncMapFloat32Int64V(rv.Interface().(map[float32]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Int64V(v map[float32]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Float32R(rv reflect.Value) { - fastpathTV.EncMapFloat32Float32V(rv.Interface().(map[float32]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Float32V(v map[float32]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32Float64R(rv reflect.Value) { - fastpathTV.EncMapFloat32Float64V(rv.Interface().(map[float32]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32Float64V(v map[float32]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat32BoolR(rv reflect.Value) { - fastpathTV.EncMapFloat32BoolV(rv.Interface().(map[float32]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat32BoolV(v map[float32]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(float32(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[float32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat32(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64IntfR(rv reflect.Value) { - fastpathTV.EncMapFloat64IntfV(rv.Interface().(map[float64]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64IntfV(v map[float64]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64StringR(rv reflect.Value) { - fastpathTV.EncMapFloat64StringV(rv.Interface().(map[float64]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64StringV(v map[float64]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64UintR(rv reflect.Value) { - fastpathTV.EncMapFloat64UintV(rv.Interface().(map[float64]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64UintV(v map[float64]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Uint8R(rv reflect.Value) { - fastpathTV.EncMapFloat64Uint8V(rv.Interface().(map[float64]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Uint8V(v map[float64]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Uint16R(rv reflect.Value) { - fastpathTV.EncMapFloat64Uint16V(rv.Interface().(map[float64]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Uint16V(v map[float64]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Uint32R(rv reflect.Value) { - fastpathTV.EncMapFloat64Uint32V(rv.Interface().(map[float64]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Uint32V(v map[float64]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Uint64R(rv reflect.Value) { - fastpathTV.EncMapFloat64Uint64V(rv.Interface().(map[float64]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Uint64V(v map[float64]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64UintptrR(rv reflect.Value) { - fastpathTV.EncMapFloat64UintptrV(rv.Interface().(map[float64]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64UintptrV(v map[float64]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64IntR(rv reflect.Value) { - fastpathTV.EncMapFloat64IntV(rv.Interface().(map[float64]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64IntV(v map[float64]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Int8R(rv reflect.Value) { - fastpathTV.EncMapFloat64Int8V(rv.Interface().(map[float64]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Int8V(v map[float64]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Int16R(rv reflect.Value) { - fastpathTV.EncMapFloat64Int16V(rv.Interface().(map[float64]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Int16V(v map[float64]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Int32R(rv reflect.Value) { - fastpathTV.EncMapFloat64Int32V(rv.Interface().(map[float64]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Int32V(v map[float64]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Int64R(rv reflect.Value) { - fastpathTV.EncMapFloat64Int64V(rv.Interface().(map[float64]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Int64V(v map[float64]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[float64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Float32R(rv reflect.Value) { - fastpathTV.EncMapFloat64Float32V(rv.Interface().(map[float64]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Float32V(v map[float64]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64Float64R(rv reflect.Value) { - fastpathTV.EncMapFloat64Float64V(rv.Interface().(map[float64]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64Float64V(v map[float64]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapFloat64BoolR(rv reflect.Value) { - fastpathTV.EncMapFloat64BoolV(rv.Interface().(map[float64]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapFloat64BoolV(v map[float64]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]float64, len(v)) - var i int - for k, _ := range v { - v2[i] = float64(k) - i++ - } - sort.Sort(floatSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(float64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[float64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeFloat64(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintIntfR(rv reflect.Value) { - fastpathTV.EncMapUintIntfV(rv.Interface().(map[uint]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintIntfV(v map[uint]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintStringR(rv reflect.Value) { - fastpathTV.EncMapUintStringV(rv.Interface().(map[uint]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintStringV(v map[uint]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUintR(rv reflect.Value) { - fastpathTV.EncMapUintUintV(rv.Interface().(map[uint]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUintV(v map[uint]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUint8R(rv reflect.Value) { - fastpathTV.EncMapUintUint8V(rv.Interface().(map[uint]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUint8V(v map[uint]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUint16R(rv reflect.Value) { - fastpathTV.EncMapUintUint16V(rv.Interface().(map[uint]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUint16V(v map[uint]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUint32R(rv reflect.Value) { - fastpathTV.EncMapUintUint32V(rv.Interface().(map[uint]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUint32V(v map[uint]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUint64R(rv reflect.Value) { - fastpathTV.EncMapUintUint64V(rv.Interface().(map[uint]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUint64V(v map[uint]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintUintptrR(rv reflect.Value) { - fastpathTV.EncMapUintUintptrV(rv.Interface().(map[uint]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintUintptrV(v map[uint]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintIntR(rv reflect.Value) { - fastpathTV.EncMapUintIntV(rv.Interface().(map[uint]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintIntV(v map[uint]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintInt8R(rv reflect.Value) { - fastpathTV.EncMapUintInt8V(rv.Interface().(map[uint]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintInt8V(v map[uint]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintInt16R(rv reflect.Value) { - fastpathTV.EncMapUintInt16V(rv.Interface().(map[uint]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintInt16V(v map[uint]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintInt32R(rv reflect.Value) { - fastpathTV.EncMapUintInt32V(rv.Interface().(map[uint]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintInt32V(v map[uint]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintInt64R(rv reflect.Value) { - fastpathTV.EncMapUintInt64V(rv.Interface().(map[uint]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintInt64V(v map[uint]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintFloat32R(rv reflect.Value) { - fastpathTV.EncMapUintFloat32V(rv.Interface().(map[uint]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintFloat32V(v map[uint]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintFloat64R(rv reflect.Value) { - fastpathTV.EncMapUintFloat64V(rv.Interface().(map[uint]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintFloat64V(v map[uint]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintBoolR(rv reflect.Value) { - fastpathTV.EncMapUintBoolV(rv.Interface().(map[uint]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintBoolV(v map[uint]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uint(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8IntfR(rv reflect.Value) { - fastpathTV.EncMapUint8IntfV(rv.Interface().(map[uint8]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8IntfV(v map[uint8]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8StringR(rv reflect.Value) { - fastpathTV.EncMapUint8StringV(rv.Interface().(map[uint8]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8StringV(v map[uint8]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8UintR(rv reflect.Value) { - fastpathTV.EncMapUint8UintV(rv.Interface().(map[uint8]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8UintV(v map[uint8]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Uint8R(rv reflect.Value) { - fastpathTV.EncMapUint8Uint8V(rv.Interface().(map[uint8]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Uint8V(v map[uint8]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Uint16R(rv reflect.Value) { - fastpathTV.EncMapUint8Uint16V(rv.Interface().(map[uint8]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Uint16V(v map[uint8]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Uint32R(rv reflect.Value) { - fastpathTV.EncMapUint8Uint32V(rv.Interface().(map[uint8]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Uint32V(v map[uint8]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Uint64R(rv reflect.Value) { - fastpathTV.EncMapUint8Uint64V(rv.Interface().(map[uint8]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Uint64V(v map[uint8]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8UintptrR(rv reflect.Value) { - fastpathTV.EncMapUint8UintptrV(rv.Interface().(map[uint8]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8UintptrV(v map[uint8]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8IntR(rv reflect.Value) { - fastpathTV.EncMapUint8IntV(rv.Interface().(map[uint8]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8IntV(v map[uint8]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Int8R(rv reflect.Value) { - fastpathTV.EncMapUint8Int8V(rv.Interface().(map[uint8]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Int8V(v map[uint8]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Int16R(rv reflect.Value) { - fastpathTV.EncMapUint8Int16V(rv.Interface().(map[uint8]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Int16V(v map[uint8]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Int32R(rv reflect.Value) { - fastpathTV.EncMapUint8Int32V(rv.Interface().(map[uint8]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Int32V(v map[uint8]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Int64R(rv reflect.Value) { - fastpathTV.EncMapUint8Int64V(rv.Interface().(map[uint8]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Int64V(v map[uint8]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Float32R(rv reflect.Value) { - fastpathTV.EncMapUint8Float32V(rv.Interface().(map[uint8]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Float32V(v map[uint8]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8Float64R(rv reflect.Value) { - fastpathTV.EncMapUint8Float64V(rv.Interface().(map[uint8]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8Float64V(v map[uint8]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint8BoolR(rv reflect.Value) { - fastpathTV.EncMapUint8BoolV(rv.Interface().(map[uint8]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint8BoolV(v map[uint8]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uint8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16IntfR(rv reflect.Value) { - fastpathTV.EncMapUint16IntfV(rv.Interface().(map[uint16]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16IntfV(v map[uint16]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16StringR(rv reflect.Value) { - fastpathTV.EncMapUint16StringV(rv.Interface().(map[uint16]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16StringV(v map[uint16]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16UintR(rv reflect.Value) { - fastpathTV.EncMapUint16UintV(rv.Interface().(map[uint16]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16UintV(v map[uint16]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Uint8R(rv reflect.Value) { - fastpathTV.EncMapUint16Uint8V(rv.Interface().(map[uint16]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Uint8V(v map[uint16]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Uint16R(rv reflect.Value) { - fastpathTV.EncMapUint16Uint16V(rv.Interface().(map[uint16]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Uint16V(v map[uint16]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Uint32R(rv reflect.Value) { - fastpathTV.EncMapUint16Uint32V(rv.Interface().(map[uint16]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Uint32V(v map[uint16]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Uint64R(rv reflect.Value) { - fastpathTV.EncMapUint16Uint64V(rv.Interface().(map[uint16]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Uint64V(v map[uint16]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16UintptrR(rv reflect.Value) { - fastpathTV.EncMapUint16UintptrV(rv.Interface().(map[uint16]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16UintptrV(v map[uint16]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16IntR(rv reflect.Value) { - fastpathTV.EncMapUint16IntV(rv.Interface().(map[uint16]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16IntV(v map[uint16]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Int8R(rv reflect.Value) { - fastpathTV.EncMapUint16Int8V(rv.Interface().(map[uint16]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Int8V(v map[uint16]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Int16R(rv reflect.Value) { - fastpathTV.EncMapUint16Int16V(rv.Interface().(map[uint16]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Int16V(v map[uint16]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Int32R(rv reflect.Value) { - fastpathTV.EncMapUint16Int32V(rv.Interface().(map[uint16]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Int32V(v map[uint16]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Int64R(rv reflect.Value) { - fastpathTV.EncMapUint16Int64V(rv.Interface().(map[uint16]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Int64V(v map[uint16]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Float32R(rv reflect.Value) { - fastpathTV.EncMapUint16Float32V(rv.Interface().(map[uint16]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Float32V(v map[uint16]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16Float64R(rv reflect.Value) { - fastpathTV.EncMapUint16Float64V(rv.Interface().(map[uint16]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16Float64V(v map[uint16]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint16BoolR(rv reflect.Value) { - fastpathTV.EncMapUint16BoolV(rv.Interface().(map[uint16]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint16BoolV(v map[uint16]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uint16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32IntfR(rv reflect.Value) { - fastpathTV.EncMapUint32IntfV(rv.Interface().(map[uint32]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32IntfV(v map[uint32]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32StringR(rv reflect.Value) { - fastpathTV.EncMapUint32StringV(rv.Interface().(map[uint32]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32StringV(v map[uint32]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32UintR(rv reflect.Value) { - fastpathTV.EncMapUint32UintV(rv.Interface().(map[uint32]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32UintV(v map[uint32]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Uint8R(rv reflect.Value) { - fastpathTV.EncMapUint32Uint8V(rv.Interface().(map[uint32]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Uint8V(v map[uint32]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Uint16R(rv reflect.Value) { - fastpathTV.EncMapUint32Uint16V(rv.Interface().(map[uint32]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Uint16V(v map[uint32]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Uint32R(rv reflect.Value) { - fastpathTV.EncMapUint32Uint32V(rv.Interface().(map[uint32]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Uint32V(v map[uint32]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Uint64R(rv reflect.Value) { - fastpathTV.EncMapUint32Uint64V(rv.Interface().(map[uint32]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Uint64V(v map[uint32]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32UintptrR(rv reflect.Value) { - fastpathTV.EncMapUint32UintptrV(rv.Interface().(map[uint32]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32UintptrV(v map[uint32]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32IntR(rv reflect.Value) { - fastpathTV.EncMapUint32IntV(rv.Interface().(map[uint32]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32IntV(v map[uint32]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Int8R(rv reflect.Value) { - fastpathTV.EncMapUint32Int8V(rv.Interface().(map[uint32]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Int8V(v map[uint32]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Int16R(rv reflect.Value) { - fastpathTV.EncMapUint32Int16V(rv.Interface().(map[uint32]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Int16V(v map[uint32]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Int32R(rv reflect.Value) { - fastpathTV.EncMapUint32Int32V(rv.Interface().(map[uint32]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Int32V(v map[uint32]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Int64R(rv reflect.Value) { - fastpathTV.EncMapUint32Int64V(rv.Interface().(map[uint32]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Int64V(v map[uint32]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Float32R(rv reflect.Value) { - fastpathTV.EncMapUint32Float32V(rv.Interface().(map[uint32]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Float32V(v map[uint32]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32Float64R(rv reflect.Value) { - fastpathTV.EncMapUint32Float64V(rv.Interface().(map[uint32]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32Float64V(v map[uint32]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint32BoolR(rv reflect.Value) { - fastpathTV.EncMapUint32BoolV(rv.Interface().(map[uint32]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint32BoolV(v map[uint32]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uint32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64IntfR(rv reflect.Value) { - fastpathTV.EncMapUint64IntfV(rv.Interface().(map[uint64]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64IntfV(v map[uint64]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64StringR(rv reflect.Value) { - fastpathTV.EncMapUint64StringV(rv.Interface().(map[uint64]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64StringV(v map[uint64]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64UintR(rv reflect.Value) { - fastpathTV.EncMapUint64UintV(rv.Interface().(map[uint64]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64UintV(v map[uint64]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Uint8R(rv reflect.Value) { - fastpathTV.EncMapUint64Uint8V(rv.Interface().(map[uint64]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Uint8V(v map[uint64]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Uint16R(rv reflect.Value) { - fastpathTV.EncMapUint64Uint16V(rv.Interface().(map[uint64]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Uint16V(v map[uint64]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Uint32R(rv reflect.Value) { - fastpathTV.EncMapUint64Uint32V(rv.Interface().(map[uint64]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Uint32V(v map[uint64]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Uint64R(rv reflect.Value) { - fastpathTV.EncMapUint64Uint64V(rv.Interface().(map[uint64]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Uint64V(v map[uint64]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64UintptrR(rv reflect.Value) { - fastpathTV.EncMapUint64UintptrV(rv.Interface().(map[uint64]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64UintptrV(v map[uint64]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64IntR(rv reflect.Value) { - fastpathTV.EncMapUint64IntV(rv.Interface().(map[uint64]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64IntV(v map[uint64]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Int8R(rv reflect.Value) { - fastpathTV.EncMapUint64Int8V(rv.Interface().(map[uint64]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Int8V(v map[uint64]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Int16R(rv reflect.Value) { - fastpathTV.EncMapUint64Int16V(rv.Interface().(map[uint64]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Int16V(v map[uint64]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Int32R(rv reflect.Value) { - fastpathTV.EncMapUint64Int32V(rv.Interface().(map[uint64]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Int32V(v map[uint64]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Int64R(rv reflect.Value) { - fastpathTV.EncMapUint64Int64V(rv.Interface().(map[uint64]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Int64V(v map[uint64]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uint64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Float32R(rv reflect.Value) { - fastpathTV.EncMapUint64Float32V(rv.Interface().(map[uint64]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Float32V(v map[uint64]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64Float64R(rv reflect.Value) { - fastpathTV.EncMapUint64Float64V(rv.Interface().(map[uint64]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64Float64V(v map[uint64]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUint64BoolR(rv reflect.Value) { - fastpathTV.EncMapUint64BoolV(rv.Interface().(map[uint64]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUint64BoolV(v map[uint64]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(uint64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uint64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeUint(uint64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrIntfR(rv reflect.Value) { - fastpathTV.EncMapUintptrIntfV(rv.Interface().(map[uintptr]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrIntfV(v map[uintptr]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrStringR(rv reflect.Value) { - fastpathTV.EncMapUintptrStringV(rv.Interface().(map[uintptr]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrStringV(v map[uintptr]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUintR(rv reflect.Value) { - fastpathTV.EncMapUintptrUintV(rv.Interface().(map[uintptr]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUintV(v map[uintptr]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUint8R(rv reflect.Value) { - fastpathTV.EncMapUintptrUint8V(rv.Interface().(map[uintptr]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUint8V(v map[uintptr]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUint16R(rv reflect.Value) { - fastpathTV.EncMapUintptrUint16V(rv.Interface().(map[uintptr]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUint16V(v map[uintptr]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUint32R(rv reflect.Value) { - fastpathTV.EncMapUintptrUint32V(rv.Interface().(map[uintptr]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUint32V(v map[uintptr]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUint64R(rv reflect.Value) { - fastpathTV.EncMapUintptrUint64V(rv.Interface().(map[uintptr]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUint64V(v map[uintptr]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrUintptrR(rv reflect.Value) { - fastpathTV.EncMapUintptrUintptrV(rv.Interface().(map[uintptr]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrUintptrV(v map[uintptr]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrIntR(rv reflect.Value) { - fastpathTV.EncMapUintptrIntV(rv.Interface().(map[uintptr]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrIntV(v map[uintptr]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrInt8R(rv reflect.Value) { - fastpathTV.EncMapUintptrInt8V(rv.Interface().(map[uintptr]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrInt8V(v map[uintptr]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrInt16R(rv reflect.Value) { - fastpathTV.EncMapUintptrInt16V(rv.Interface().(map[uintptr]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrInt16V(v map[uintptr]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrInt32R(rv reflect.Value) { - fastpathTV.EncMapUintptrInt32V(rv.Interface().(map[uintptr]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrInt32V(v map[uintptr]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrInt64R(rv reflect.Value) { - fastpathTV.EncMapUintptrInt64V(rv.Interface().(map[uintptr]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrInt64V(v map[uintptr]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[uintptr(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrFloat32R(rv reflect.Value) { - fastpathTV.EncMapUintptrFloat32V(rv.Interface().(map[uintptr]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrFloat32V(v map[uintptr]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrFloat64R(rv reflect.Value) { - fastpathTV.EncMapUintptrFloat64V(rv.Interface().(map[uintptr]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrFloat64V(v map[uintptr]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapUintptrBoolR(rv reflect.Value) { - fastpathTV.EncMapUintptrBoolV(rv.Interface().(map[uintptr]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapUintptrBoolV(v map[uintptr]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]uint64, len(v)) - var i int - for k, _ := range v { - v2[i] = uint64(k) - i++ - } - sort.Sort(uintSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(uintptr(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[uintptr(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - e.encode(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntIntfR(rv reflect.Value) { - fastpathTV.EncMapIntIntfV(rv.Interface().(map[int]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntIntfV(v map[int]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntStringR(rv reflect.Value) { - fastpathTV.EncMapIntStringV(rv.Interface().(map[int]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntStringV(v map[int]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUintR(rv reflect.Value) { - fastpathTV.EncMapIntUintV(rv.Interface().(map[int]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUintV(v map[int]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUint8R(rv reflect.Value) { - fastpathTV.EncMapIntUint8V(rv.Interface().(map[int]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUint8V(v map[int]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUint16R(rv reflect.Value) { - fastpathTV.EncMapIntUint16V(rv.Interface().(map[int]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUint16V(v map[int]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUint32R(rv reflect.Value) { - fastpathTV.EncMapIntUint32V(rv.Interface().(map[int]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUint32V(v map[int]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUint64R(rv reflect.Value) { - fastpathTV.EncMapIntUint64V(rv.Interface().(map[int]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUint64V(v map[int]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntUintptrR(rv reflect.Value) { - fastpathTV.EncMapIntUintptrV(rv.Interface().(map[int]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntUintptrV(v map[int]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntIntR(rv reflect.Value) { - fastpathTV.EncMapIntIntV(rv.Interface().(map[int]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntIntV(v map[int]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntInt8R(rv reflect.Value) { - fastpathTV.EncMapIntInt8V(rv.Interface().(map[int]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntInt8V(v map[int]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntInt16R(rv reflect.Value) { - fastpathTV.EncMapIntInt16V(rv.Interface().(map[int]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntInt16V(v map[int]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntInt32R(rv reflect.Value) { - fastpathTV.EncMapIntInt32V(rv.Interface().(map[int]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntInt32V(v map[int]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntInt64R(rv reflect.Value) { - fastpathTV.EncMapIntInt64V(rv.Interface().(map[int]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntInt64V(v map[int]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntFloat32R(rv reflect.Value) { - fastpathTV.EncMapIntFloat32V(rv.Interface().(map[int]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntFloat32V(v map[int]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntFloat64R(rv reflect.Value) { - fastpathTV.EncMapIntFloat64V(rv.Interface().(map[int]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntFloat64V(v map[int]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapIntBoolR(rv reflect.Value) { - fastpathTV.EncMapIntBoolV(rv.Interface().(map[int]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapIntBoolV(v map[int]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[int(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8IntfR(rv reflect.Value) { - fastpathTV.EncMapInt8IntfV(rv.Interface().(map[int8]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8IntfV(v map[int8]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8StringR(rv reflect.Value) { - fastpathTV.EncMapInt8StringV(rv.Interface().(map[int8]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8StringV(v map[int8]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8UintR(rv reflect.Value) { - fastpathTV.EncMapInt8UintV(rv.Interface().(map[int8]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8UintV(v map[int8]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Uint8R(rv reflect.Value) { - fastpathTV.EncMapInt8Uint8V(rv.Interface().(map[int8]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Uint8V(v map[int8]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Uint16R(rv reflect.Value) { - fastpathTV.EncMapInt8Uint16V(rv.Interface().(map[int8]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Uint16V(v map[int8]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Uint32R(rv reflect.Value) { - fastpathTV.EncMapInt8Uint32V(rv.Interface().(map[int8]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Uint32V(v map[int8]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Uint64R(rv reflect.Value) { - fastpathTV.EncMapInt8Uint64V(rv.Interface().(map[int8]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Uint64V(v map[int8]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8UintptrR(rv reflect.Value) { - fastpathTV.EncMapInt8UintptrV(rv.Interface().(map[int8]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8UintptrV(v map[int8]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8IntR(rv reflect.Value) { - fastpathTV.EncMapInt8IntV(rv.Interface().(map[int8]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8IntV(v map[int8]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Int8R(rv reflect.Value) { - fastpathTV.EncMapInt8Int8V(rv.Interface().(map[int8]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Int8V(v map[int8]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Int16R(rv reflect.Value) { - fastpathTV.EncMapInt8Int16V(rv.Interface().(map[int8]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Int16V(v map[int8]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Int32R(rv reflect.Value) { - fastpathTV.EncMapInt8Int32V(rv.Interface().(map[int8]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Int32V(v map[int8]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Int64R(rv reflect.Value) { - fastpathTV.EncMapInt8Int64V(rv.Interface().(map[int8]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Int64V(v map[int8]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int8(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Float32R(rv reflect.Value) { - fastpathTV.EncMapInt8Float32V(rv.Interface().(map[int8]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Float32V(v map[int8]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8Float64R(rv reflect.Value) { - fastpathTV.EncMapInt8Float64V(rv.Interface().(map[int8]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8Float64V(v map[int8]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt8BoolR(rv reflect.Value) { - fastpathTV.EncMapInt8BoolV(rv.Interface().(map[int8]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt8BoolV(v map[int8]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int8(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[int8(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16IntfR(rv reflect.Value) { - fastpathTV.EncMapInt16IntfV(rv.Interface().(map[int16]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16IntfV(v map[int16]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16StringR(rv reflect.Value) { - fastpathTV.EncMapInt16StringV(rv.Interface().(map[int16]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16StringV(v map[int16]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16UintR(rv reflect.Value) { - fastpathTV.EncMapInt16UintV(rv.Interface().(map[int16]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16UintV(v map[int16]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Uint8R(rv reflect.Value) { - fastpathTV.EncMapInt16Uint8V(rv.Interface().(map[int16]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Uint8V(v map[int16]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Uint16R(rv reflect.Value) { - fastpathTV.EncMapInt16Uint16V(rv.Interface().(map[int16]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Uint16V(v map[int16]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Uint32R(rv reflect.Value) { - fastpathTV.EncMapInt16Uint32V(rv.Interface().(map[int16]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Uint32V(v map[int16]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Uint64R(rv reflect.Value) { - fastpathTV.EncMapInt16Uint64V(rv.Interface().(map[int16]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Uint64V(v map[int16]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16UintptrR(rv reflect.Value) { - fastpathTV.EncMapInt16UintptrV(rv.Interface().(map[int16]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16UintptrV(v map[int16]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16IntR(rv reflect.Value) { - fastpathTV.EncMapInt16IntV(rv.Interface().(map[int16]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16IntV(v map[int16]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Int8R(rv reflect.Value) { - fastpathTV.EncMapInt16Int8V(rv.Interface().(map[int16]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Int8V(v map[int16]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Int16R(rv reflect.Value) { - fastpathTV.EncMapInt16Int16V(rv.Interface().(map[int16]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Int16V(v map[int16]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Int32R(rv reflect.Value) { - fastpathTV.EncMapInt16Int32V(rv.Interface().(map[int16]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Int32V(v map[int16]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Int64R(rv reflect.Value) { - fastpathTV.EncMapInt16Int64V(rv.Interface().(map[int16]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Int64V(v map[int16]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int16(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Float32R(rv reflect.Value) { - fastpathTV.EncMapInt16Float32V(rv.Interface().(map[int16]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Float32V(v map[int16]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16Float64R(rv reflect.Value) { - fastpathTV.EncMapInt16Float64V(rv.Interface().(map[int16]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16Float64V(v map[int16]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt16BoolR(rv reflect.Value) { - fastpathTV.EncMapInt16BoolV(rv.Interface().(map[int16]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt16BoolV(v map[int16]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int16(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[int16(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32IntfR(rv reflect.Value) { - fastpathTV.EncMapInt32IntfV(rv.Interface().(map[int32]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32IntfV(v map[int32]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32StringR(rv reflect.Value) { - fastpathTV.EncMapInt32StringV(rv.Interface().(map[int32]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32StringV(v map[int32]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32UintR(rv reflect.Value) { - fastpathTV.EncMapInt32UintV(rv.Interface().(map[int32]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32UintV(v map[int32]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Uint8R(rv reflect.Value) { - fastpathTV.EncMapInt32Uint8V(rv.Interface().(map[int32]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Uint8V(v map[int32]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Uint16R(rv reflect.Value) { - fastpathTV.EncMapInt32Uint16V(rv.Interface().(map[int32]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Uint16V(v map[int32]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Uint32R(rv reflect.Value) { - fastpathTV.EncMapInt32Uint32V(rv.Interface().(map[int32]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Uint32V(v map[int32]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Uint64R(rv reflect.Value) { - fastpathTV.EncMapInt32Uint64V(rv.Interface().(map[int32]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Uint64V(v map[int32]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32UintptrR(rv reflect.Value) { - fastpathTV.EncMapInt32UintptrV(rv.Interface().(map[int32]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32UintptrV(v map[int32]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32IntR(rv reflect.Value) { - fastpathTV.EncMapInt32IntV(rv.Interface().(map[int32]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32IntV(v map[int32]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Int8R(rv reflect.Value) { - fastpathTV.EncMapInt32Int8V(rv.Interface().(map[int32]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Int8V(v map[int32]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Int16R(rv reflect.Value) { - fastpathTV.EncMapInt32Int16V(rv.Interface().(map[int32]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Int16V(v map[int32]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Int32R(rv reflect.Value) { - fastpathTV.EncMapInt32Int32V(rv.Interface().(map[int32]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Int32V(v map[int32]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Int64R(rv reflect.Value) { - fastpathTV.EncMapInt32Int64V(rv.Interface().(map[int32]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Int64V(v map[int32]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int32(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Float32R(rv reflect.Value) { - fastpathTV.EncMapInt32Float32V(rv.Interface().(map[int32]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Float32V(v map[int32]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32Float64R(rv reflect.Value) { - fastpathTV.EncMapInt32Float64V(rv.Interface().(map[int32]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32Float64V(v map[int32]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt32BoolR(rv reflect.Value) { - fastpathTV.EncMapInt32BoolV(rv.Interface().(map[int32]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt32BoolV(v map[int32]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int32(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[int32(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64IntfR(rv reflect.Value) { - fastpathTV.EncMapInt64IntfV(rv.Interface().(map[int64]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64IntfV(v map[int64]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64StringR(rv reflect.Value) { - fastpathTV.EncMapInt64StringV(rv.Interface().(map[int64]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64StringV(v map[int64]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64UintR(rv reflect.Value) { - fastpathTV.EncMapInt64UintV(rv.Interface().(map[int64]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64UintV(v map[int64]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Uint8R(rv reflect.Value) { - fastpathTV.EncMapInt64Uint8V(rv.Interface().(map[int64]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Uint8V(v map[int64]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Uint16R(rv reflect.Value) { - fastpathTV.EncMapInt64Uint16V(rv.Interface().(map[int64]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Uint16V(v map[int64]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Uint32R(rv reflect.Value) { - fastpathTV.EncMapInt64Uint32V(rv.Interface().(map[int64]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Uint32V(v map[int64]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Uint64R(rv reflect.Value) { - fastpathTV.EncMapInt64Uint64V(rv.Interface().(map[int64]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Uint64V(v map[int64]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64UintptrR(rv reflect.Value) { - fastpathTV.EncMapInt64UintptrV(rv.Interface().(map[int64]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64UintptrV(v map[int64]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64IntR(rv reflect.Value) { - fastpathTV.EncMapInt64IntV(rv.Interface().(map[int64]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64IntV(v map[int64]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Int8R(rv reflect.Value) { - fastpathTV.EncMapInt64Int8V(rv.Interface().(map[int64]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Int8V(v map[int64]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Int16R(rv reflect.Value) { - fastpathTV.EncMapInt64Int16V(rv.Interface().(map[int64]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Int16V(v map[int64]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Int32R(rv reflect.Value) { - fastpathTV.EncMapInt64Int32V(rv.Interface().(map[int64]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Int32V(v map[int64]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Int64R(rv reflect.Value) { - fastpathTV.EncMapInt64Int64V(rv.Interface().(map[int64]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Int64V(v map[int64]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[int64(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Float32R(rv reflect.Value) { - fastpathTV.EncMapInt64Float32V(rv.Interface().(map[int64]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Float32V(v map[int64]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64Float64R(rv reflect.Value) { - fastpathTV.EncMapInt64Float64V(rv.Interface().(map[int64]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64Float64V(v map[int64]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapInt64BoolR(rv reflect.Value) { - fastpathTV.EncMapInt64BoolV(rv.Interface().(map[int64]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapInt64BoolV(v map[int64]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]int64, len(v)) - var i int - for k, _ := range v { - v2[i] = int64(k) - i++ - } - sort.Sort(intSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(int64(k2))) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[int64(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeInt(int64(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolIntfR(rv reflect.Value) { - fastpathTV.EncMapBoolIntfV(rv.Interface().(map[bool]interface{}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolIntfV(v map[bool]interface{}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolStringR(rv reflect.Value) { - fastpathTV.EncMapBoolStringV(rv.Interface().(map[bool]string), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolStringV(v map[bool]string, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeString(c_UTF8, v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUintR(rv reflect.Value) { - fastpathTV.EncMapBoolUintV(rv.Interface().(map[bool]uint), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUintV(v map[bool]uint, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUint8R(rv reflect.Value) { - fastpathTV.EncMapBoolUint8V(rv.Interface().(map[bool]uint8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUint8V(v map[bool]uint8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUint16R(rv reflect.Value) { - fastpathTV.EncMapBoolUint16V(rv.Interface().(map[bool]uint16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUint16V(v map[bool]uint16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUint32R(rv reflect.Value) { - fastpathTV.EncMapBoolUint32V(rv.Interface().(map[bool]uint32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUint32V(v map[bool]uint32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUint64R(rv reflect.Value) { - fastpathTV.EncMapBoolUint64V(rv.Interface().(map[bool]uint64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUint64V(v map[bool]uint64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeUint(uint64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolUintptrR(rv reflect.Value) { - fastpathTV.EncMapBoolUintptrV(rv.Interface().(map[bool]uintptr), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolUintptrV(v map[bool]uintptr, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - e.encode(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolIntR(rv reflect.Value) { - fastpathTV.EncMapBoolIntV(rv.Interface().(map[bool]int), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolIntV(v map[bool]int, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolInt8R(rv reflect.Value) { - fastpathTV.EncMapBoolInt8V(rv.Interface().(map[bool]int8), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolInt8V(v map[bool]int8, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolInt16R(rv reflect.Value) { - fastpathTV.EncMapBoolInt16V(rv.Interface().(map[bool]int16), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolInt16V(v map[bool]int16, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolInt32R(rv reflect.Value) { - fastpathTV.EncMapBoolInt32V(rv.Interface().(map[bool]int32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolInt32V(v map[bool]int32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolInt64R(rv reflect.Value) { - fastpathTV.EncMapBoolInt64V(rv.Interface().(map[bool]int64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolInt64V(v map[bool]int64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v[bool(k2)])) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeInt(int64(v2)) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolFloat32R(rv reflect.Value) { - fastpathTV.EncMapBoolFloat32V(rv.Interface().(map[bool]float32), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolFloat32V(v map[bool]float32, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat32(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolFloat64R(rv reflect.Value) { - fastpathTV.EncMapBoolFloat64V(rv.Interface().(map[bool]float64), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolFloat64V(v map[bool]float64, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeFloat64(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -func (f *encFnInfo) fastpathEncMapBoolBoolR(rv reflect.Value) { - fastpathTV.EncMapBoolBoolV(rv.Interface().(map[bool]bool), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) EncMapBoolBoolV(v map[bool]bool, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - if e.h.Canonical { - v2 := make([]bool, len(v)) - var i int - for k, _ := range v { - v2[i] = bool(k) - i++ - } - sort.Sort(boolSlice(v2)) - for _, k2 := range v2 { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(bool(k2)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v[bool(k2)]) - } - } else { - for k2, v2 := range v { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - ee.EncodeBool(k2) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - ee.EncodeBool(v2) - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } -} - -// -- decode - -// -- -- fast path type switch -func fastpathDecodeTypeSwitch(iv interface{}, d *Decoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { - - case []interface{}: - fastpathTV.DecSliceIntfV(v, fastpathCheckNilFalse, false, d) - case *[]interface{}: - v2, changed2 := fastpathTV.DecSliceIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]interface{}: - fastpathTV.DecMapIntfIntfV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]interface{}: - v2, changed2 := fastpathTV.DecMapIntfIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]string: - fastpathTV.DecMapIntfStringV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]string: - v2, changed2 := fastpathTV.DecMapIntfStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uint: - fastpathTV.DecMapIntfUintV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uint: - v2, changed2 := fastpathTV.DecMapIntfUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uint8: - fastpathTV.DecMapIntfUint8V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uint8: - v2, changed2 := fastpathTV.DecMapIntfUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uint16: - fastpathTV.DecMapIntfUint16V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uint16: - v2, changed2 := fastpathTV.DecMapIntfUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uint32: - fastpathTV.DecMapIntfUint32V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uint32: - v2, changed2 := fastpathTV.DecMapIntfUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uint64: - fastpathTV.DecMapIntfUint64V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uint64: - v2, changed2 := fastpathTV.DecMapIntfUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]uintptr: - fastpathTV.DecMapIntfUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]uintptr: - v2, changed2 := fastpathTV.DecMapIntfUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]int: - fastpathTV.DecMapIntfIntV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]int: - v2, changed2 := fastpathTV.DecMapIntfIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]int8: - fastpathTV.DecMapIntfInt8V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]int8: - v2, changed2 := fastpathTV.DecMapIntfInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]int16: - fastpathTV.DecMapIntfInt16V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]int16: - v2, changed2 := fastpathTV.DecMapIntfInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]int32: - fastpathTV.DecMapIntfInt32V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]int32: - v2, changed2 := fastpathTV.DecMapIntfInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]int64: - fastpathTV.DecMapIntfInt64V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]int64: - v2, changed2 := fastpathTV.DecMapIntfInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]float32: - fastpathTV.DecMapIntfFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]float32: - v2, changed2 := fastpathTV.DecMapIntfFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]float64: - fastpathTV.DecMapIntfFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]float64: - v2, changed2 := fastpathTV.DecMapIntfFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[interface{}]bool: - fastpathTV.DecMapIntfBoolV(v, fastpathCheckNilFalse, false, d) - case *map[interface{}]bool: - v2, changed2 := fastpathTV.DecMapIntfBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []string: - fastpathTV.DecSliceStringV(v, fastpathCheckNilFalse, false, d) - case *[]string: - v2, changed2 := fastpathTV.DecSliceStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]interface{}: - fastpathTV.DecMapStringIntfV(v, fastpathCheckNilFalse, false, d) - case *map[string]interface{}: - v2, changed2 := fastpathTV.DecMapStringIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]string: - fastpathTV.DecMapStringStringV(v, fastpathCheckNilFalse, false, d) - case *map[string]string: - v2, changed2 := fastpathTV.DecMapStringStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uint: - fastpathTV.DecMapStringUintV(v, fastpathCheckNilFalse, false, d) - case *map[string]uint: - v2, changed2 := fastpathTV.DecMapStringUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uint8: - fastpathTV.DecMapStringUint8V(v, fastpathCheckNilFalse, false, d) - case *map[string]uint8: - v2, changed2 := fastpathTV.DecMapStringUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uint16: - fastpathTV.DecMapStringUint16V(v, fastpathCheckNilFalse, false, d) - case *map[string]uint16: - v2, changed2 := fastpathTV.DecMapStringUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uint32: - fastpathTV.DecMapStringUint32V(v, fastpathCheckNilFalse, false, d) - case *map[string]uint32: - v2, changed2 := fastpathTV.DecMapStringUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uint64: - fastpathTV.DecMapStringUint64V(v, fastpathCheckNilFalse, false, d) - case *map[string]uint64: - v2, changed2 := fastpathTV.DecMapStringUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]uintptr: - fastpathTV.DecMapStringUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[string]uintptr: - v2, changed2 := fastpathTV.DecMapStringUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]int: - fastpathTV.DecMapStringIntV(v, fastpathCheckNilFalse, false, d) - case *map[string]int: - v2, changed2 := fastpathTV.DecMapStringIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]int8: - fastpathTV.DecMapStringInt8V(v, fastpathCheckNilFalse, false, d) - case *map[string]int8: - v2, changed2 := fastpathTV.DecMapStringInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]int16: - fastpathTV.DecMapStringInt16V(v, fastpathCheckNilFalse, false, d) - case *map[string]int16: - v2, changed2 := fastpathTV.DecMapStringInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]int32: - fastpathTV.DecMapStringInt32V(v, fastpathCheckNilFalse, false, d) - case *map[string]int32: - v2, changed2 := fastpathTV.DecMapStringInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]int64: - fastpathTV.DecMapStringInt64V(v, fastpathCheckNilFalse, false, d) - case *map[string]int64: - v2, changed2 := fastpathTV.DecMapStringInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]float32: - fastpathTV.DecMapStringFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[string]float32: - v2, changed2 := fastpathTV.DecMapStringFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]float64: - fastpathTV.DecMapStringFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[string]float64: - v2, changed2 := fastpathTV.DecMapStringFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[string]bool: - fastpathTV.DecMapStringBoolV(v, fastpathCheckNilFalse, false, d) - case *map[string]bool: - v2, changed2 := fastpathTV.DecMapStringBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []float32: - fastpathTV.DecSliceFloat32V(v, fastpathCheckNilFalse, false, d) - case *[]float32: - v2, changed2 := fastpathTV.DecSliceFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]interface{}: - fastpathTV.DecMapFloat32IntfV(v, fastpathCheckNilFalse, false, d) - case *map[float32]interface{}: - v2, changed2 := fastpathTV.DecMapFloat32IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]string: - fastpathTV.DecMapFloat32StringV(v, fastpathCheckNilFalse, false, d) - case *map[float32]string: - v2, changed2 := fastpathTV.DecMapFloat32StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uint: - fastpathTV.DecMapFloat32UintV(v, fastpathCheckNilFalse, false, d) - case *map[float32]uint: - v2, changed2 := fastpathTV.DecMapFloat32UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uint8: - fastpathTV.DecMapFloat32Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[float32]uint8: - v2, changed2 := fastpathTV.DecMapFloat32Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uint16: - fastpathTV.DecMapFloat32Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[float32]uint16: - v2, changed2 := fastpathTV.DecMapFloat32Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uint32: - fastpathTV.DecMapFloat32Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[float32]uint32: - v2, changed2 := fastpathTV.DecMapFloat32Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uint64: - fastpathTV.DecMapFloat32Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[float32]uint64: - v2, changed2 := fastpathTV.DecMapFloat32Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]uintptr: - fastpathTV.DecMapFloat32UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[float32]uintptr: - v2, changed2 := fastpathTV.DecMapFloat32UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]int: - fastpathTV.DecMapFloat32IntV(v, fastpathCheckNilFalse, false, d) - case *map[float32]int: - v2, changed2 := fastpathTV.DecMapFloat32IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]int8: - fastpathTV.DecMapFloat32Int8V(v, fastpathCheckNilFalse, false, d) - case *map[float32]int8: - v2, changed2 := fastpathTV.DecMapFloat32Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]int16: - fastpathTV.DecMapFloat32Int16V(v, fastpathCheckNilFalse, false, d) - case *map[float32]int16: - v2, changed2 := fastpathTV.DecMapFloat32Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]int32: - fastpathTV.DecMapFloat32Int32V(v, fastpathCheckNilFalse, false, d) - case *map[float32]int32: - v2, changed2 := fastpathTV.DecMapFloat32Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]int64: - fastpathTV.DecMapFloat32Int64V(v, fastpathCheckNilFalse, false, d) - case *map[float32]int64: - v2, changed2 := fastpathTV.DecMapFloat32Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]float32: - fastpathTV.DecMapFloat32Float32V(v, fastpathCheckNilFalse, false, d) - case *map[float32]float32: - v2, changed2 := fastpathTV.DecMapFloat32Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]float64: - fastpathTV.DecMapFloat32Float64V(v, fastpathCheckNilFalse, false, d) - case *map[float32]float64: - v2, changed2 := fastpathTV.DecMapFloat32Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float32]bool: - fastpathTV.DecMapFloat32BoolV(v, fastpathCheckNilFalse, false, d) - case *map[float32]bool: - v2, changed2 := fastpathTV.DecMapFloat32BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []float64: - fastpathTV.DecSliceFloat64V(v, fastpathCheckNilFalse, false, d) - case *[]float64: - v2, changed2 := fastpathTV.DecSliceFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]interface{}: - fastpathTV.DecMapFloat64IntfV(v, fastpathCheckNilFalse, false, d) - case *map[float64]interface{}: - v2, changed2 := fastpathTV.DecMapFloat64IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]string: - fastpathTV.DecMapFloat64StringV(v, fastpathCheckNilFalse, false, d) - case *map[float64]string: - v2, changed2 := fastpathTV.DecMapFloat64StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uint: - fastpathTV.DecMapFloat64UintV(v, fastpathCheckNilFalse, false, d) - case *map[float64]uint: - v2, changed2 := fastpathTV.DecMapFloat64UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uint8: - fastpathTV.DecMapFloat64Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[float64]uint8: - v2, changed2 := fastpathTV.DecMapFloat64Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uint16: - fastpathTV.DecMapFloat64Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[float64]uint16: - v2, changed2 := fastpathTV.DecMapFloat64Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uint32: - fastpathTV.DecMapFloat64Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[float64]uint32: - v2, changed2 := fastpathTV.DecMapFloat64Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uint64: - fastpathTV.DecMapFloat64Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[float64]uint64: - v2, changed2 := fastpathTV.DecMapFloat64Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]uintptr: - fastpathTV.DecMapFloat64UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[float64]uintptr: - v2, changed2 := fastpathTV.DecMapFloat64UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]int: - fastpathTV.DecMapFloat64IntV(v, fastpathCheckNilFalse, false, d) - case *map[float64]int: - v2, changed2 := fastpathTV.DecMapFloat64IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]int8: - fastpathTV.DecMapFloat64Int8V(v, fastpathCheckNilFalse, false, d) - case *map[float64]int8: - v2, changed2 := fastpathTV.DecMapFloat64Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]int16: - fastpathTV.DecMapFloat64Int16V(v, fastpathCheckNilFalse, false, d) - case *map[float64]int16: - v2, changed2 := fastpathTV.DecMapFloat64Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]int32: - fastpathTV.DecMapFloat64Int32V(v, fastpathCheckNilFalse, false, d) - case *map[float64]int32: - v2, changed2 := fastpathTV.DecMapFloat64Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]int64: - fastpathTV.DecMapFloat64Int64V(v, fastpathCheckNilFalse, false, d) - case *map[float64]int64: - v2, changed2 := fastpathTV.DecMapFloat64Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]float32: - fastpathTV.DecMapFloat64Float32V(v, fastpathCheckNilFalse, false, d) - case *map[float64]float32: - v2, changed2 := fastpathTV.DecMapFloat64Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]float64: - fastpathTV.DecMapFloat64Float64V(v, fastpathCheckNilFalse, false, d) - case *map[float64]float64: - v2, changed2 := fastpathTV.DecMapFloat64Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[float64]bool: - fastpathTV.DecMapFloat64BoolV(v, fastpathCheckNilFalse, false, d) - case *map[float64]bool: - v2, changed2 := fastpathTV.DecMapFloat64BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []uint: - fastpathTV.DecSliceUintV(v, fastpathCheckNilFalse, false, d) - case *[]uint: - v2, changed2 := fastpathTV.DecSliceUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]interface{}: - fastpathTV.DecMapUintIntfV(v, fastpathCheckNilFalse, false, d) - case *map[uint]interface{}: - v2, changed2 := fastpathTV.DecMapUintIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]string: - fastpathTV.DecMapUintStringV(v, fastpathCheckNilFalse, false, d) - case *map[uint]string: - v2, changed2 := fastpathTV.DecMapUintStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uint: - fastpathTV.DecMapUintUintV(v, fastpathCheckNilFalse, false, d) - case *map[uint]uint: - v2, changed2 := fastpathTV.DecMapUintUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uint8: - fastpathTV.DecMapUintUint8V(v, fastpathCheckNilFalse, false, d) - case *map[uint]uint8: - v2, changed2 := fastpathTV.DecMapUintUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uint16: - fastpathTV.DecMapUintUint16V(v, fastpathCheckNilFalse, false, d) - case *map[uint]uint16: - v2, changed2 := fastpathTV.DecMapUintUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uint32: - fastpathTV.DecMapUintUint32V(v, fastpathCheckNilFalse, false, d) - case *map[uint]uint32: - v2, changed2 := fastpathTV.DecMapUintUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uint64: - fastpathTV.DecMapUintUint64V(v, fastpathCheckNilFalse, false, d) - case *map[uint]uint64: - v2, changed2 := fastpathTV.DecMapUintUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]uintptr: - fastpathTV.DecMapUintUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uint]uintptr: - v2, changed2 := fastpathTV.DecMapUintUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]int: - fastpathTV.DecMapUintIntV(v, fastpathCheckNilFalse, false, d) - case *map[uint]int: - v2, changed2 := fastpathTV.DecMapUintIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]int8: - fastpathTV.DecMapUintInt8V(v, fastpathCheckNilFalse, false, d) - case *map[uint]int8: - v2, changed2 := fastpathTV.DecMapUintInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]int16: - fastpathTV.DecMapUintInt16V(v, fastpathCheckNilFalse, false, d) - case *map[uint]int16: - v2, changed2 := fastpathTV.DecMapUintInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]int32: - fastpathTV.DecMapUintInt32V(v, fastpathCheckNilFalse, false, d) - case *map[uint]int32: - v2, changed2 := fastpathTV.DecMapUintInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]int64: - fastpathTV.DecMapUintInt64V(v, fastpathCheckNilFalse, false, d) - case *map[uint]int64: - v2, changed2 := fastpathTV.DecMapUintInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]float32: - fastpathTV.DecMapUintFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[uint]float32: - v2, changed2 := fastpathTV.DecMapUintFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]float64: - fastpathTV.DecMapUintFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[uint]float64: - v2, changed2 := fastpathTV.DecMapUintFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint]bool: - fastpathTV.DecMapUintBoolV(v, fastpathCheckNilFalse, false, d) - case *map[uint]bool: - v2, changed2 := fastpathTV.DecMapUintBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]interface{}: - fastpathTV.DecMapUint8IntfV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]interface{}: - v2, changed2 := fastpathTV.DecMapUint8IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]string: - fastpathTV.DecMapUint8StringV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]string: - v2, changed2 := fastpathTV.DecMapUint8StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uint: - fastpathTV.DecMapUint8UintV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uint: - v2, changed2 := fastpathTV.DecMapUint8UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uint8: - fastpathTV.DecMapUint8Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uint8: - v2, changed2 := fastpathTV.DecMapUint8Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uint16: - fastpathTV.DecMapUint8Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uint16: - v2, changed2 := fastpathTV.DecMapUint8Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uint32: - fastpathTV.DecMapUint8Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uint32: - v2, changed2 := fastpathTV.DecMapUint8Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uint64: - fastpathTV.DecMapUint8Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uint64: - v2, changed2 := fastpathTV.DecMapUint8Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]uintptr: - fastpathTV.DecMapUint8UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]uintptr: - v2, changed2 := fastpathTV.DecMapUint8UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]int: - fastpathTV.DecMapUint8IntV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]int: - v2, changed2 := fastpathTV.DecMapUint8IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]int8: - fastpathTV.DecMapUint8Int8V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]int8: - v2, changed2 := fastpathTV.DecMapUint8Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]int16: - fastpathTV.DecMapUint8Int16V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]int16: - v2, changed2 := fastpathTV.DecMapUint8Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]int32: - fastpathTV.DecMapUint8Int32V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]int32: - v2, changed2 := fastpathTV.DecMapUint8Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]int64: - fastpathTV.DecMapUint8Int64V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]int64: - v2, changed2 := fastpathTV.DecMapUint8Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]float32: - fastpathTV.DecMapUint8Float32V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]float32: - v2, changed2 := fastpathTV.DecMapUint8Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]float64: - fastpathTV.DecMapUint8Float64V(v, fastpathCheckNilFalse, false, d) - case *map[uint8]float64: - v2, changed2 := fastpathTV.DecMapUint8Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint8]bool: - fastpathTV.DecMapUint8BoolV(v, fastpathCheckNilFalse, false, d) - case *map[uint8]bool: - v2, changed2 := fastpathTV.DecMapUint8BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []uint16: - fastpathTV.DecSliceUint16V(v, fastpathCheckNilFalse, false, d) - case *[]uint16: - v2, changed2 := fastpathTV.DecSliceUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]interface{}: - fastpathTV.DecMapUint16IntfV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]interface{}: - v2, changed2 := fastpathTV.DecMapUint16IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]string: - fastpathTV.DecMapUint16StringV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]string: - v2, changed2 := fastpathTV.DecMapUint16StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uint: - fastpathTV.DecMapUint16UintV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uint: - v2, changed2 := fastpathTV.DecMapUint16UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uint8: - fastpathTV.DecMapUint16Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uint8: - v2, changed2 := fastpathTV.DecMapUint16Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uint16: - fastpathTV.DecMapUint16Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uint16: - v2, changed2 := fastpathTV.DecMapUint16Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uint32: - fastpathTV.DecMapUint16Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uint32: - v2, changed2 := fastpathTV.DecMapUint16Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uint64: - fastpathTV.DecMapUint16Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uint64: - v2, changed2 := fastpathTV.DecMapUint16Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]uintptr: - fastpathTV.DecMapUint16UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]uintptr: - v2, changed2 := fastpathTV.DecMapUint16UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]int: - fastpathTV.DecMapUint16IntV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]int: - v2, changed2 := fastpathTV.DecMapUint16IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]int8: - fastpathTV.DecMapUint16Int8V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]int8: - v2, changed2 := fastpathTV.DecMapUint16Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]int16: - fastpathTV.DecMapUint16Int16V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]int16: - v2, changed2 := fastpathTV.DecMapUint16Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]int32: - fastpathTV.DecMapUint16Int32V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]int32: - v2, changed2 := fastpathTV.DecMapUint16Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]int64: - fastpathTV.DecMapUint16Int64V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]int64: - v2, changed2 := fastpathTV.DecMapUint16Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]float32: - fastpathTV.DecMapUint16Float32V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]float32: - v2, changed2 := fastpathTV.DecMapUint16Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]float64: - fastpathTV.DecMapUint16Float64V(v, fastpathCheckNilFalse, false, d) - case *map[uint16]float64: - v2, changed2 := fastpathTV.DecMapUint16Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint16]bool: - fastpathTV.DecMapUint16BoolV(v, fastpathCheckNilFalse, false, d) - case *map[uint16]bool: - v2, changed2 := fastpathTV.DecMapUint16BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []uint32: - fastpathTV.DecSliceUint32V(v, fastpathCheckNilFalse, false, d) - case *[]uint32: - v2, changed2 := fastpathTV.DecSliceUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]interface{}: - fastpathTV.DecMapUint32IntfV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]interface{}: - v2, changed2 := fastpathTV.DecMapUint32IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]string: - fastpathTV.DecMapUint32StringV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]string: - v2, changed2 := fastpathTV.DecMapUint32StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uint: - fastpathTV.DecMapUint32UintV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uint: - v2, changed2 := fastpathTV.DecMapUint32UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uint8: - fastpathTV.DecMapUint32Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uint8: - v2, changed2 := fastpathTV.DecMapUint32Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uint16: - fastpathTV.DecMapUint32Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uint16: - v2, changed2 := fastpathTV.DecMapUint32Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uint32: - fastpathTV.DecMapUint32Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uint32: - v2, changed2 := fastpathTV.DecMapUint32Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uint64: - fastpathTV.DecMapUint32Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uint64: - v2, changed2 := fastpathTV.DecMapUint32Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]uintptr: - fastpathTV.DecMapUint32UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]uintptr: - v2, changed2 := fastpathTV.DecMapUint32UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]int: - fastpathTV.DecMapUint32IntV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]int: - v2, changed2 := fastpathTV.DecMapUint32IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]int8: - fastpathTV.DecMapUint32Int8V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]int8: - v2, changed2 := fastpathTV.DecMapUint32Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]int16: - fastpathTV.DecMapUint32Int16V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]int16: - v2, changed2 := fastpathTV.DecMapUint32Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]int32: - fastpathTV.DecMapUint32Int32V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]int32: - v2, changed2 := fastpathTV.DecMapUint32Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]int64: - fastpathTV.DecMapUint32Int64V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]int64: - v2, changed2 := fastpathTV.DecMapUint32Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]float32: - fastpathTV.DecMapUint32Float32V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]float32: - v2, changed2 := fastpathTV.DecMapUint32Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]float64: - fastpathTV.DecMapUint32Float64V(v, fastpathCheckNilFalse, false, d) - case *map[uint32]float64: - v2, changed2 := fastpathTV.DecMapUint32Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint32]bool: - fastpathTV.DecMapUint32BoolV(v, fastpathCheckNilFalse, false, d) - case *map[uint32]bool: - v2, changed2 := fastpathTV.DecMapUint32BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []uint64: - fastpathTV.DecSliceUint64V(v, fastpathCheckNilFalse, false, d) - case *[]uint64: - v2, changed2 := fastpathTV.DecSliceUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]interface{}: - fastpathTV.DecMapUint64IntfV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]interface{}: - v2, changed2 := fastpathTV.DecMapUint64IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]string: - fastpathTV.DecMapUint64StringV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]string: - v2, changed2 := fastpathTV.DecMapUint64StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uint: - fastpathTV.DecMapUint64UintV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uint: - v2, changed2 := fastpathTV.DecMapUint64UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uint8: - fastpathTV.DecMapUint64Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uint8: - v2, changed2 := fastpathTV.DecMapUint64Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uint16: - fastpathTV.DecMapUint64Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uint16: - v2, changed2 := fastpathTV.DecMapUint64Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uint32: - fastpathTV.DecMapUint64Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uint32: - v2, changed2 := fastpathTV.DecMapUint64Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uint64: - fastpathTV.DecMapUint64Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uint64: - v2, changed2 := fastpathTV.DecMapUint64Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]uintptr: - fastpathTV.DecMapUint64UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]uintptr: - v2, changed2 := fastpathTV.DecMapUint64UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]int: - fastpathTV.DecMapUint64IntV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]int: - v2, changed2 := fastpathTV.DecMapUint64IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]int8: - fastpathTV.DecMapUint64Int8V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]int8: - v2, changed2 := fastpathTV.DecMapUint64Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]int16: - fastpathTV.DecMapUint64Int16V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]int16: - v2, changed2 := fastpathTV.DecMapUint64Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]int32: - fastpathTV.DecMapUint64Int32V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]int32: - v2, changed2 := fastpathTV.DecMapUint64Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]int64: - fastpathTV.DecMapUint64Int64V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]int64: - v2, changed2 := fastpathTV.DecMapUint64Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]float32: - fastpathTV.DecMapUint64Float32V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]float32: - v2, changed2 := fastpathTV.DecMapUint64Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]float64: - fastpathTV.DecMapUint64Float64V(v, fastpathCheckNilFalse, false, d) - case *map[uint64]float64: - v2, changed2 := fastpathTV.DecMapUint64Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uint64]bool: - fastpathTV.DecMapUint64BoolV(v, fastpathCheckNilFalse, false, d) - case *map[uint64]bool: - v2, changed2 := fastpathTV.DecMapUint64BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []uintptr: - fastpathTV.DecSliceUintptrV(v, fastpathCheckNilFalse, false, d) - case *[]uintptr: - v2, changed2 := fastpathTV.DecSliceUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]interface{}: - fastpathTV.DecMapUintptrIntfV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]interface{}: - v2, changed2 := fastpathTV.DecMapUintptrIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]string: - fastpathTV.DecMapUintptrStringV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]string: - v2, changed2 := fastpathTV.DecMapUintptrStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uint: - fastpathTV.DecMapUintptrUintV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uint: - v2, changed2 := fastpathTV.DecMapUintptrUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uint8: - fastpathTV.DecMapUintptrUint8V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uint8: - v2, changed2 := fastpathTV.DecMapUintptrUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uint16: - fastpathTV.DecMapUintptrUint16V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uint16: - v2, changed2 := fastpathTV.DecMapUintptrUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uint32: - fastpathTV.DecMapUintptrUint32V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uint32: - v2, changed2 := fastpathTV.DecMapUintptrUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uint64: - fastpathTV.DecMapUintptrUint64V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uint64: - v2, changed2 := fastpathTV.DecMapUintptrUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]uintptr: - fastpathTV.DecMapUintptrUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]uintptr: - v2, changed2 := fastpathTV.DecMapUintptrUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]int: - fastpathTV.DecMapUintptrIntV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]int: - v2, changed2 := fastpathTV.DecMapUintptrIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]int8: - fastpathTV.DecMapUintptrInt8V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]int8: - v2, changed2 := fastpathTV.DecMapUintptrInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]int16: - fastpathTV.DecMapUintptrInt16V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]int16: - v2, changed2 := fastpathTV.DecMapUintptrInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]int32: - fastpathTV.DecMapUintptrInt32V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]int32: - v2, changed2 := fastpathTV.DecMapUintptrInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]int64: - fastpathTV.DecMapUintptrInt64V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]int64: - v2, changed2 := fastpathTV.DecMapUintptrInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]float32: - fastpathTV.DecMapUintptrFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]float32: - v2, changed2 := fastpathTV.DecMapUintptrFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]float64: - fastpathTV.DecMapUintptrFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]float64: - v2, changed2 := fastpathTV.DecMapUintptrFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[uintptr]bool: - fastpathTV.DecMapUintptrBoolV(v, fastpathCheckNilFalse, false, d) - case *map[uintptr]bool: - v2, changed2 := fastpathTV.DecMapUintptrBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []int: - fastpathTV.DecSliceIntV(v, fastpathCheckNilFalse, false, d) - case *[]int: - v2, changed2 := fastpathTV.DecSliceIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]interface{}: - fastpathTV.DecMapIntIntfV(v, fastpathCheckNilFalse, false, d) - case *map[int]interface{}: - v2, changed2 := fastpathTV.DecMapIntIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]string: - fastpathTV.DecMapIntStringV(v, fastpathCheckNilFalse, false, d) - case *map[int]string: - v2, changed2 := fastpathTV.DecMapIntStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uint: - fastpathTV.DecMapIntUintV(v, fastpathCheckNilFalse, false, d) - case *map[int]uint: - v2, changed2 := fastpathTV.DecMapIntUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uint8: - fastpathTV.DecMapIntUint8V(v, fastpathCheckNilFalse, false, d) - case *map[int]uint8: - v2, changed2 := fastpathTV.DecMapIntUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uint16: - fastpathTV.DecMapIntUint16V(v, fastpathCheckNilFalse, false, d) - case *map[int]uint16: - v2, changed2 := fastpathTV.DecMapIntUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uint32: - fastpathTV.DecMapIntUint32V(v, fastpathCheckNilFalse, false, d) - case *map[int]uint32: - v2, changed2 := fastpathTV.DecMapIntUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uint64: - fastpathTV.DecMapIntUint64V(v, fastpathCheckNilFalse, false, d) - case *map[int]uint64: - v2, changed2 := fastpathTV.DecMapIntUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]uintptr: - fastpathTV.DecMapIntUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[int]uintptr: - v2, changed2 := fastpathTV.DecMapIntUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]int: - fastpathTV.DecMapIntIntV(v, fastpathCheckNilFalse, false, d) - case *map[int]int: - v2, changed2 := fastpathTV.DecMapIntIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]int8: - fastpathTV.DecMapIntInt8V(v, fastpathCheckNilFalse, false, d) - case *map[int]int8: - v2, changed2 := fastpathTV.DecMapIntInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]int16: - fastpathTV.DecMapIntInt16V(v, fastpathCheckNilFalse, false, d) - case *map[int]int16: - v2, changed2 := fastpathTV.DecMapIntInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]int32: - fastpathTV.DecMapIntInt32V(v, fastpathCheckNilFalse, false, d) - case *map[int]int32: - v2, changed2 := fastpathTV.DecMapIntInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]int64: - fastpathTV.DecMapIntInt64V(v, fastpathCheckNilFalse, false, d) - case *map[int]int64: - v2, changed2 := fastpathTV.DecMapIntInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]float32: - fastpathTV.DecMapIntFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[int]float32: - v2, changed2 := fastpathTV.DecMapIntFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]float64: - fastpathTV.DecMapIntFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[int]float64: - v2, changed2 := fastpathTV.DecMapIntFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int]bool: - fastpathTV.DecMapIntBoolV(v, fastpathCheckNilFalse, false, d) - case *map[int]bool: - v2, changed2 := fastpathTV.DecMapIntBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []int8: - fastpathTV.DecSliceInt8V(v, fastpathCheckNilFalse, false, d) - case *[]int8: - v2, changed2 := fastpathTV.DecSliceInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]interface{}: - fastpathTV.DecMapInt8IntfV(v, fastpathCheckNilFalse, false, d) - case *map[int8]interface{}: - v2, changed2 := fastpathTV.DecMapInt8IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]string: - fastpathTV.DecMapInt8StringV(v, fastpathCheckNilFalse, false, d) - case *map[int8]string: - v2, changed2 := fastpathTV.DecMapInt8StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uint: - fastpathTV.DecMapInt8UintV(v, fastpathCheckNilFalse, false, d) - case *map[int8]uint: - v2, changed2 := fastpathTV.DecMapInt8UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uint8: - fastpathTV.DecMapInt8Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[int8]uint8: - v2, changed2 := fastpathTV.DecMapInt8Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uint16: - fastpathTV.DecMapInt8Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[int8]uint16: - v2, changed2 := fastpathTV.DecMapInt8Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uint32: - fastpathTV.DecMapInt8Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[int8]uint32: - v2, changed2 := fastpathTV.DecMapInt8Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uint64: - fastpathTV.DecMapInt8Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[int8]uint64: - v2, changed2 := fastpathTV.DecMapInt8Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]uintptr: - fastpathTV.DecMapInt8UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[int8]uintptr: - v2, changed2 := fastpathTV.DecMapInt8UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]int: - fastpathTV.DecMapInt8IntV(v, fastpathCheckNilFalse, false, d) - case *map[int8]int: - v2, changed2 := fastpathTV.DecMapInt8IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]int8: - fastpathTV.DecMapInt8Int8V(v, fastpathCheckNilFalse, false, d) - case *map[int8]int8: - v2, changed2 := fastpathTV.DecMapInt8Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]int16: - fastpathTV.DecMapInt8Int16V(v, fastpathCheckNilFalse, false, d) - case *map[int8]int16: - v2, changed2 := fastpathTV.DecMapInt8Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]int32: - fastpathTV.DecMapInt8Int32V(v, fastpathCheckNilFalse, false, d) - case *map[int8]int32: - v2, changed2 := fastpathTV.DecMapInt8Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]int64: - fastpathTV.DecMapInt8Int64V(v, fastpathCheckNilFalse, false, d) - case *map[int8]int64: - v2, changed2 := fastpathTV.DecMapInt8Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]float32: - fastpathTV.DecMapInt8Float32V(v, fastpathCheckNilFalse, false, d) - case *map[int8]float32: - v2, changed2 := fastpathTV.DecMapInt8Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]float64: - fastpathTV.DecMapInt8Float64V(v, fastpathCheckNilFalse, false, d) - case *map[int8]float64: - v2, changed2 := fastpathTV.DecMapInt8Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int8]bool: - fastpathTV.DecMapInt8BoolV(v, fastpathCheckNilFalse, false, d) - case *map[int8]bool: - v2, changed2 := fastpathTV.DecMapInt8BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []int16: - fastpathTV.DecSliceInt16V(v, fastpathCheckNilFalse, false, d) - case *[]int16: - v2, changed2 := fastpathTV.DecSliceInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]interface{}: - fastpathTV.DecMapInt16IntfV(v, fastpathCheckNilFalse, false, d) - case *map[int16]interface{}: - v2, changed2 := fastpathTV.DecMapInt16IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]string: - fastpathTV.DecMapInt16StringV(v, fastpathCheckNilFalse, false, d) - case *map[int16]string: - v2, changed2 := fastpathTV.DecMapInt16StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uint: - fastpathTV.DecMapInt16UintV(v, fastpathCheckNilFalse, false, d) - case *map[int16]uint: - v2, changed2 := fastpathTV.DecMapInt16UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uint8: - fastpathTV.DecMapInt16Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[int16]uint8: - v2, changed2 := fastpathTV.DecMapInt16Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uint16: - fastpathTV.DecMapInt16Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[int16]uint16: - v2, changed2 := fastpathTV.DecMapInt16Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uint32: - fastpathTV.DecMapInt16Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[int16]uint32: - v2, changed2 := fastpathTV.DecMapInt16Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uint64: - fastpathTV.DecMapInt16Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[int16]uint64: - v2, changed2 := fastpathTV.DecMapInt16Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]uintptr: - fastpathTV.DecMapInt16UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[int16]uintptr: - v2, changed2 := fastpathTV.DecMapInt16UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]int: - fastpathTV.DecMapInt16IntV(v, fastpathCheckNilFalse, false, d) - case *map[int16]int: - v2, changed2 := fastpathTV.DecMapInt16IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]int8: - fastpathTV.DecMapInt16Int8V(v, fastpathCheckNilFalse, false, d) - case *map[int16]int8: - v2, changed2 := fastpathTV.DecMapInt16Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]int16: - fastpathTV.DecMapInt16Int16V(v, fastpathCheckNilFalse, false, d) - case *map[int16]int16: - v2, changed2 := fastpathTV.DecMapInt16Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]int32: - fastpathTV.DecMapInt16Int32V(v, fastpathCheckNilFalse, false, d) - case *map[int16]int32: - v2, changed2 := fastpathTV.DecMapInt16Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]int64: - fastpathTV.DecMapInt16Int64V(v, fastpathCheckNilFalse, false, d) - case *map[int16]int64: - v2, changed2 := fastpathTV.DecMapInt16Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]float32: - fastpathTV.DecMapInt16Float32V(v, fastpathCheckNilFalse, false, d) - case *map[int16]float32: - v2, changed2 := fastpathTV.DecMapInt16Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]float64: - fastpathTV.DecMapInt16Float64V(v, fastpathCheckNilFalse, false, d) - case *map[int16]float64: - v2, changed2 := fastpathTV.DecMapInt16Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int16]bool: - fastpathTV.DecMapInt16BoolV(v, fastpathCheckNilFalse, false, d) - case *map[int16]bool: - v2, changed2 := fastpathTV.DecMapInt16BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []int32: - fastpathTV.DecSliceInt32V(v, fastpathCheckNilFalse, false, d) - case *[]int32: - v2, changed2 := fastpathTV.DecSliceInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]interface{}: - fastpathTV.DecMapInt32IntfV(v, fastpathCheckNilFalse, false, d) - case *map[int32]interface{}: - v2, changed2 := fastpathTV.DecMapInt32IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]string: - fastpathTV.DecMapInt32StringV(v, fastpathCheckNilFalse, false, d) - case *map[int32]string: - v2, changed2 := fastpathTV.DecMapInt32StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uint: - fastpathTV.DecMapInt32UintV(v, fastpathCheckNilFalse, false, d) - case *map[int32]uint: - v2, changed2 := fastpathTV.DecMapInt32UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uint8: - fastpathTV.DecMapInt32Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[int32]uint8: - v2, changed2 := fastpathTV.DecMapInt32Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uint16: - fastpathTV.DecMapInt32Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[int32]uint16: - v2, changed2 := fastpathTV.DecMapInt32Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uint32: - fastpathTV.DecMapInt32Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[int32]uint32: - v2, changed2 := fastpathTV.DecMapInt32Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uint64: - fastpathTV.DecMapInt32Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[int32]uint64: - v2, changed2 := fastpathTV.DecMapInt32Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]uintptr: - fastpathTV.DecMapInt32UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[int32]uintptr: - v2, changed2 := fastpathTV.DecMapInt32UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]int: - fastpathTV.DecMapInt32IntV(v, fastpathCheckNilFalse, false, d) - case *map[int32]int: - v2, changed2 := fastpathTV.DecMapInt32IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]int8: - fastpathTV.DecMapInt32Int8V(v, fastpathCheckNilFalse, false, d) - case *map[int32]int8: - v2, changed2 := fastpathTV.DecMapInt32Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]int16: - fastpathTV.DecMapInt32Int16V(v, fastpathCheckNilFalse, false, d) - case *map[int32]int16: - v2, changed2 := fastpathTV.DecMapInt32Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]int32: - fastpathTV.DecMapInt32Int32V(v, fastpathCheckNilFalse, false, d) - case *map[int32]int32: - v2, changed2 := fastpathTV.DecMapInt32Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]int64: - fastpathTV.DecMapInt32Int64V(v, fastpathCheckNilFalse, false, d) - case *map[int32]int64: - v2, changed2 := fastpathTV.DecMapInt32Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]float32: - fastpathTV.DecMapInt32Float32V(v, fastpathCheckNilFalse, false, d) - case *map[int32]float32: - v2, changed2 := fastpathTV.DecMapInt32Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]float64: - fastpathTV.DecMapInt32Float64V(v, fastpathCheckNilFalse, false, d) - case *map[int32]float64: - v2, changed2 := fastpathTV.DecMapInt32Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int32]bool: - fastpathTV.DecMapInt32BoolV(v, fastpathCheckNilFalse, false, d) - case *map[int32]bool: - v2, changed2 := fastpathTV.DecMapInt32BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []int64: - fastpathTV.DecSliceInt64V(v, fastpathCheckNilFalse, false, d) - case *[]int64: - v2, changed2 := fastpathTV.DecSliceInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]interface{}: - fastpathTV.DecMapInt64IntfV(v, fastpathCheckNilFalse, false, d) - case *map[int64]interface{}: - v2, changed2 := fastpathTV.DecMapInt64IntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]string: - fastpathTV.DecMapInt64StringV(v, fastpathCheckNilFalse, false, d) - case *map[int64]string: - v2, changed2 := fastpathTV.DecMapInt64StringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uint: - fastpathTV.DecMapInt64UintV(v, fastpathCheckNilFalse, false, d) - case *map[int64]uint: - v2, changed2 := fastpathTV.DecMapInt64UintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uint8: - fastpathTV.DecMapInt64Uint8V(v, fastpathCheckNilFalse, false, d) - case *map[int64]uint8: - v2, changed2 := fastpathTV.DecMapInt64Uint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uint16: - fastpathTV.DecMapInt64Uint16V(v, fastpathCheckNilFalse, false, d) - case *map[int64]uint16: - v2, changed2 := fastpathTV.DecMapInt64Uint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uint32: - fastpathTV.DecMapInt64Uint32V(v, fastpathCheckNilFalse, false, d) - case *map[int64]uint32: - v2, changed2 := fastpathTV.DecMapInt64Uint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uint64: - fastpathTV.DecMapInt64Uint64V(v, fastpathCheckNilFalse, false, d) - case *map[int64]uint64: - v2, changed2 := fastpathTV.DecMapInt64Uint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]uintptr: - fastpathTV.DecMapInt64UintptrV(v, fastpathCheckNilFalse, false, d) - case *map[int64]uintptr: - v2, changed2 := fastpathTV.DecMapInt64UintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]int: - fastpathTV.DecMapInt64IntV(v, fastpathCheckNilFalse, false, d) - case *map[int64]int: - v2, changed2 := fastpathTV.DecMapInt64IntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]int8: - fastpathTV.DecMapInt64Int8V(v, fastpathCheckNilFalse, false, d) - case *map[int64]int8: - v2, changed2 := fastpathTV.DecMapInt64Int8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]int16: - fastpathTV.DecMapInt64Int16V(v, fastpathCheckNilFalse, false, d) - case *map[int64]int16: - v2, changed2 := fastpathTV.DecMapInt64Int16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]int32: - fastpathTV.DecMapInt64Int32V(v, fastpathCheckNilFalse, false, d) - case *map[int64]int32: - v2, changed2 := fastpathTV.DecMapInt64Int32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]int64: - fastpathTV.DecMapInt64Int64V(v, fastpathCheckNilFalse, false, d) - case *map[int64]int64: - v2, changed2 := fastpathTV.DecMapInt64Int64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]float32: - fastpathTV.DecMapInt64Float32V(v, fastpathCheckNilFalse, false, d) - case *map[int64]float32: - v2, changed2 := fastpathTV.DecMapInt64Float32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]float64: - fastpathTV.DecMapInt64Float64V(v, fastpathCheckNilFalse, false, d) - case *map[int64]float64: - v2, changed2 := fastpathTV.DecMapInt64Float64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[int64]bool: - fastpathTV.DecMapInt64BoolV(v, fastpathCheckNilFalse, false, d) - case *map[int64]bool: - v2, changed2 := fastpathTV.DecMapInt64BoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case []bool: - fastpathTV.DecSliceBoolV(v, fastpathCheckNilFalse, false, d) - case *[]bool: - v2, changed2 := fastpathTV.DecSliceBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]interface{}: - fastpathTV.DecMapBoolIntfV(v, fastpathCheckNilFalse, false, d) - case *map[bool]interface{}: - v2, changed2 := fastpathTV.DecMapBoolIntfV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]string: - fastpathTV.DecMapBoolStringV(v, fastpathCheckNilFalse, false, d) - case *map[bool]string: - v2, changed2 := fastpathTV.DecMapBoolStringV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uint: - fastpathTV.DecMapBoolUintV(v, fastpathCheckNilFalse, false, d) - case *map[bool]uint: - v2, changed2 := fastpathTV.DecMapBoolUintV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uint8: - fastpathTV.DecMapBoolUint8V(v, fastpathCheckNilFalse, false, d) - case *map[bool]uint8: - v2, changed2 := fastpathTV.DecMapBoolUint8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uint16: - fastpathTV.DecMapBoolUint16V(v, fastpathCheckNilFalse, false, d) - case *map[bool]uint16: - v2, changed2 := fastpathTV.DecMapBoolUint16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uint32: - fastpathTV.DecMapBoolUint32V(v, fastpathCheckNilFalse, false, d) - case *map[bool]uint32: - v2, changed2 := fastpathTV.DecMapBoolUint32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uint64: - fastpathTV.DecMapBoolUint64V(v, fastpathCheckNilFalse, false, d) - case *map[bool]uint64: - v2, changed2 := fastpathTV.DecMapBoolUint64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]uintptr: - fastpathTV.DecMapBoolUintptrV(v, fastpathCheckNilFalse, false, d) - case *map[bool]uintptr: - v2, changed2 := fastpathTV.DecMapBoolUintptrV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]int: - fastpathTV.DecMapBoolIntV(v, fastpathCheckNilFalse, false, d) - case *map[bool]int: - v2, changed2 := fastpathTV.DecMapBoolIntV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]int8: - fastpathTV.DecMapBoolInt8V(v, fastpathCheckNilFalse, false, d) - case *map[bool]int8: - v2, changed2 := fastpathTV.DecMapBoolInt8V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]int16: - fastpathTV.DecMapBoolInt16V(v, fastpathCheckNilFalse, false, d) - case *map[bool]int16: - v2, changed2 := fastpathTV.DecMapBoolInt16V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]int32: - fastpathTV.DecMapBoolInt32V(v, fastpathCheckNilFalse, false, d) - case *map[bool]int32: - v2, changed2 := fastpathTV.DecMapBoolInt32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]int64: - fastpathTV.DecMapBoolInt64V(v, fastpathCheckNilFalse, false, d) - case *map[bool]int64: - v2, changed2 := fastpathTV.DecMapBoolInt64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]float32: - fastpathTV.DecMapBoolFloat32V(v, fastpathCheckNilFalse, false, d) - case *map[bool]float32: - v2, changed2 := fastpathTV.DecMapBoolFloat32V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]float64: - fastpathTV.DecMapBoolFloat64V(v, fastpathCheckNilFalse, false, d) - case *map[bool]float64: - v2, changed2 := fastpathTV.DecMapBoolFloat64V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - case map[bool]bool: - fastpathTV.DecMapBoolBoolV(v, fastpathCheckNilFalse, false, d) - case *map[bool]bool: - v2, changed2 := fastpathTV.DecMapBoolBoolV(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } - - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -// -- -- fast path functions - -func (f *decFnInfo) fastpathDecSliceIntfR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]interface{}) - v, changed := fastpathTV.DecSliceIntfV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]interface{}) - fastpathTV.DecSliceIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceIntfX(vp *[]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecSliceIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceIntfV(v []interface{}, checkNil bool, canChange bool, d *Decoder) (_ []interface{}, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []interface{}{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 16) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]interface{}, xlen) - } - } else { - v = make([]interface{}, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - d.decode(&v[j]) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, nil) - slh.ElemContainerState(j) - d.decode(&v[j]) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []interface{}{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]interface{}, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, nil) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - d.decode(&v[j]) - - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceStringR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]string) - v, changed := fastpathTV.DecSliceStringV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]string) - fastpathTV.DecSliceStringV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceStringX(vp *[]string, checkNil bool, d *Decoder) { - v, changed := f.DecSliceStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceStringV(v []string, checkNil bool, canChange bool, d *Decoder) (_ []string, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []string{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 16) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]string, xlen) - } - } else { - v = make([]string, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = dd.DecodeString() - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, "") - slh.ElemContainerState(j) - v[j] = dd.DecodeString() - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []string{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]string, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, "") - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = dd.DecodeString() - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceFloat32R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]float32) - v, changed := fastpathTV.DecSliceFloat32V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]float32) - fastpathTV.DecSliceFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceFloat32X(vp *[]float32, checkNil bool, d *Decoder) { - v, changed := f.DecSliceFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceFloat32V(v []float32, checkNil bool, canChange bool, d *Decoder) (_ []float32, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []float32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 4) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]float32, xlen) - } - } else { - v = make([]float32, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = float32(dd.DecodeFloat(true)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = float32(dd.DecodeFloat(true)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []float32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]float32, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = float32(dd.DecodeFloat(true)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceFloat64R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]float64) - v, changed := fastpathTV.DecSliceFloat64V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]float64) - fastpathTV.DecSliceFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceFloat64X(vp *[]float64, checkNil bool, d *Decoder) { - v, changed := f.DecSliceFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceFloat64V(v []float64, checkNil bool, canChange bool, d *Decoder) (_ []float64, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []float64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]float64, xlen) - } - } else { - v = make([]float64, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = dd.DecodeFloat(false) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = dd.DecodeFloat(false) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []float64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]float64, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = dd.DecodeFloat(false) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceUintR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]uint) - v, changed := fastpathTV.DecSliceUintV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]uint) - fastpathTV.DecSliceUintV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceUintX(vp *[]uint, checkNil bool, d *Decoder) { - v, changed := f.DecSliceUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceUintV(v []uint, checkNil bool, canChange bool, d *Decoder) (_ []uint, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []uint{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]uint, xlen) - } - } else { - v = make([]uint, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = uint(dd.DecodeUint(uintBitsize)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = uint(dd.DecodeUint(uintBitsize)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []uint{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]uint, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = uint(dd.DecodeUint(uintBitsize)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceUint16R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]uint16) - v, changed := fastpathTV.DecSliceUint16V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]uint16) - fastpathTV.DecSliceUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceUint16X(vp *[]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecSliceUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceUint16V(v []uint16, checkNil bool, canChange bool, d *Decoder) (_ []uint16, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []uint16{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 2) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]uint16, xlen) - } - } else { - v = make([]uint16, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = uint16(dd.DecodeUint(16)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = uint16(dd.DecodeUint(16)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []uint16{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]uint16, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = uint16(dd.DecodeUint(16)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceUint32R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]uint32) - v, changed := fastpathTV.DecSliceUint32V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]uint32) - fastpathTV.DecSliceUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceUint32X(vp *[]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecSliceUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceUint32V(v []uint32, checkNil bool, canChange bool, d *Decoder) (_ []uint32, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []uint32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 4) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]uint32, xlen) - } - } else { - v = make([]uint32, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = uint32(dd.DecodeUint(32)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = uint32(dd.DecodeUint(32)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []uint32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]uint32, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = uint32(dd.DecodeUint(32)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceUint64R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]uint64) - v, changed := fastpathTV.DecSliceUint64V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]uint64) - fastpathTV.DecSliceUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceUint64X(vp *[]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecSliceUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceUint64V(v []uint64, checkNil bool, canChange bool, d *Decoder) (_ []uint64, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []uint64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]uint64, xlen) - } - } else { - v = make([]uint64, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = dd.DecodeUint(64) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = dd.DecodeUint(64) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []uint64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]uint64, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = dd.DecodeUint(64) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceUintptrR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]uintptr) - v, changed := fastpathTV.DecSliceUintptrV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]uintptr) - fastpathTV.DecSliceUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceUintptrX(vp *[]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecSliceUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceUintptrV(v []uintptr, checkNil bool, canChange bool, d *Decoder) (_ []uintptr, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []uintptr{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]uintptr, xlen) - } - } else { - v = make([]uintptr, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = uintptr(dd.DecodeUint(uintBitsize)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = uintptr(dd.DecodeUint(uintBitsize)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []uintptr{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]uintptr, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = uintptr(dd.DecodeUint(uintBitsize)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceIntR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]int) - v, changed := fastpathTV.DecSliceIntV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]int) - fastpathTV.DecSliceIntV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceIntX(vp *[]int, checkNil bool, d *Decoder) { - v, changed := f.DecSliceIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceIntV(v []int, checkNil bool, canChange bool, d *Decoder) (_ []int, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []int{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]int, xlen) - } - } else { - v = make([]int, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = int(dd.DecodeInt(intBitsize)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = int(dd.DecodeInt(intBitsize)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []int{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]int, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = int(dd.DecodeInt(intBitsize)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceInt8R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]int8) - v, changed := fastpathTV.DecSliceInt8V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]int8) - fastpathTV.DecSliceInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceInt8X(vp *[]int8, checkNil bool, d *Decoder) { - v, changed := f.DecSliceInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceInt8V(v []int8, checkNil bool, canChange bool, d *Decoder) (_ []int8, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []int8{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 1) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]int8, xlen) - } - } else { - v = make([]int8, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = int8(dd.DecodeInt(8)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = int8(dd.DecodeInt(8)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []int8{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]int8, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = int8(dd.DecodeInt(8)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceInt16R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]int16) - v, changed := fastpathTV.DecSliceInt16V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]int16) - fastpathTV.DecSliceInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceInt16X(vp *[]int16, checkNil bool, d *Decoder) { - v, changed := f.DecSliceInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceInt16V(v []int16, checkNil bool, canChange bool, d *Decoder) (_ []int16, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []int16{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 2) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]int16, xlen) - } - } else { - v = make([]int16, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = int16(dd.DecodeInt(16)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = int16(dd.DecodeInt(16)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []int16{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]int16, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = int16(dd.DecodeInt(16)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceInt32R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]int32) - v, changed := fastpathTV.DecSliceInt32V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]int32) - fastpathTV.DecSliceInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceInt32X(vp *[]int32, checkNil bool, d *Decoder) { - v, changed := f.DecSliceInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceInt32V(v []int32, checkNil bool, canChange bool, d *Decoder) (_ []int32, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []int32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 4) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]int32, xlen) - } - } else { - v = make([]int32, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = int32(dd.DecodeInt(32)) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = int32(dd.DecodeInt(32)) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []int32{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]int32, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = int32(dd.DecodeInt(32)) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceInt64R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]int64) - v, changed := fastpathTV.DecSliceInt64V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]int64) - fastpathTV.DecSliceInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceInt64X(vp *[]int64, checkNil bool, d *Decoder) { - v, changed := f.DecSliceInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceInt64V(v []int64, checkNil bool, canChange bool, d *Decoder) (_ []int64, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []int64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 8) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]int64, xlen) - } - } else { - v = make([]int64, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = dd.DecodeInt(64) - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, 0) - slh.ElemContainerState(j) - v[j] = dd.DecodeInt(64) - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []int64{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]int64, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, 0) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = dd.DecodeInt(64) - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecSliceBoolR(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { - vp := rv.Addr().Interface().(*[]bool) - v, changed := fastpathTV.DecSliceBoolV(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]bool) - fastpathTV.DecSliceBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) DecSliceBoolX(vp *[]bool, checkNil bool, d *Decoder) { - v, changed := f.DecSliceBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecSliceBoolV(v []bool, checkNil bool, canChange bool, d *Decoder) (_ []bool, changed bool) { - dd := d.d - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []bool{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, 1) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]bool, xlen) - } - } else { - v = make([]bool, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - v[j] = dd.DecodeBool() - } - if xtrunc { - for ; j < containerLenS; j++ { - v = append(v, false) - slh.ElemContainerState(j) - v[j] = dd.DecodeBool() - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() - if breakFound { - if canChange { - if v == nil { - v = []bool{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]bool, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, false) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { - v[j] = dd.DecodeBool() - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]interface{}) - v, changed := fastpathTV.DecMapIntfIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]interface{}) - fastpathTV.DecMapIntfIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfIntfX(vp *map[interface{}]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfIntfV(v map[interface{}]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 32) - v = make(map[interface{}]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk interface{} - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]string) - v, changed := fastpathTV.DecMapIntfStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]string) - fastpathTV.DecMapIntfStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfStringX(vp *map[interface{}]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfStringV(v map[interface{}]string, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 32) - v = make(map[interface{}]string, xlen) - changed = true - } - - var mk interface{} - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uint) - v, changed := fastpathTV.DecMapIntfUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uint) - fastpathTV.DecMapIntfUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUintX(vp *map[interface{}]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUintV(v map[interface{}]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]uint, xlen) - changed = true - } - - var mk interface{} - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uint8) - v, changed := fastpathTV.DecMapIntfUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uint8) - fastpathTV.DecMapIntfUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUint8X(vp *map[interface{}]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUint8V(v map[interface{}]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[interface{}]uint8, xlen) - changed = true - } - - var mk interface{} - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uint16) - v, changed := fastpathTV.DecMapIntfUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uint16) - fastpathTV.DecMapIntfUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUint16X(vp *map[interface{}]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUint16V(v map[interface{}]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[interface{}]uint16, xlen) - changed = true - } - - var mk interface{} - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uint32) - v, changed := fastpathTV.DecMapIntfUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uint32) - fastpathTV.DecMapIntfUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUint32X(vp *map[interface{}]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUint32V(v map[interface{}]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[interface{}]uint32, xlen) - changed = true - } - - var mk interface{} - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uint64) - v, changed := fastpathTV.DecMapIntfUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uint64) - fastpathTV.DecMapIntfUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUint64X(vp *map[interface{}]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUint64V(v map[interface{}]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]uint64, xlen) - changed = true - } - - var mk interface{} - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]uintptr) - v, changed := fastpathTV.DecMapIntfUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]uintptr) - fastpathTV.DecMapIntfUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfUintptrX(vp *map[interface{}]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfUintptrV(v map[interface{}]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]uintptr, xlen) - changed = true - } - - var mk interface{} - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]int) - v, changed := fastpathTV.DecMapIntfIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]int) - fastpathTV.DecMapIntfIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfIntX(vp *map[interface{}]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfIntV(v map[interface{}]int, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]int, xlen) - changed = true - } - - var mk interface{} - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]int8) - v, changed := fastpathTV.DecMapIntfInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]int8) - fastpathTV.DecMapIntfInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfInt8X(vp *map[interface{}]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfInt8V(v map[interface{}]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[interface{}]int8, xlen) - changed = true - } - - var mk interface{} - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]int16) - v, changed := fastpathTV.DecMapIntfInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]int16) - fastpathTV.DecMapIntfInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfInt16X(vp *map[interface{}]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfInt16V(v map[interface{}]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[interface{}]int16, xlen) - changed = true - } - - var mk interface{} - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]int32) - v, changed := fastpathTV.DecMapIntfInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]int32) - fastpathTV.DecMapIntfInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfInt32X(vp *map[interface{}]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfInt32V(v map[interface{}]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[interface{}]int32, xlen) - changed = true - } - - var mk interface{} - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]int64) - v, changed := fastpathTV.DecMapIntfInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]int64) - fastpathTV.DecMapIntfInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfInt64X(vp *map[interface{}]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfInt64V(v map[interface{}]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]int64, xlen) - changed = true - } - - var mk interface{} - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]float32) - v, changed := fastpathTV.DecMapIntfFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]float32) - fastpathTV.DecMapIntfFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfFloat32X(vp *map[interface{}]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfFloat32V(v map[interface{}]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[interface{}]float32, xlen) - changed = true - } - - var mk interface{} - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]float64) - v, changed := fastpathTV.DecMapIntfFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]float64) - fastpathTV.DecMapIntfFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfFloat64X(vp *map[interface{}]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfFloat64V(v map[interface{}]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[interface{}]float64, xlen) - changed = true - } - - var mk interface{} - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntfBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[interface{}]bool) - v, changed := fastpathTV.DecMapIntfBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[interface{}]bool) - fastpathTV.DecMapIntfBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntfBoolX(vp *map[interface{}]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntfBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntfBoolV(v map[interface{}]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[interface{}]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[interface{}]bool, xlen) - changed = true - } - - var mk interface{} - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) - } - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]interface{}) - v, changed := fastpathTV.DecMapStringIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]interface{}) - fastpathTV.DecMapStringIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringIntfX(vp *map[string]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringIntfV(v map[string]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[string]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 32) - v = make(map[string]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk string - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]string) - v, changed := fastpathTV.DecMapStringStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]string) - fastpathTV.DecMapStringStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringStringX(vp *map[string]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringStringV(v map[string]string, checkNil bool, canChange bool, - d *Decoder) (_ map[string]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 32) - v = make(map[string]string, xlen) - changed = true - } - - var mk string - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uint) - v, changed := fastpathTV.DecMapStringUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uint) - fastpathTV.DecMapStringUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUintX(vp *map[string]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUintV(v map[string]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]uint, xlen) - changed = true - } - - var mk string - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uint8) - v, changed := fastpathTV.DecMapStringUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uint8) - fastpathTV.DecMapStringUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUint8X(vp *map[string]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUint8V(v map[string]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[string]uint8, xlen) - changed = true - } - - var mk string - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uint16) - v, changed := fastpathTV.DecMapStringUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uint16) - fastpathTV.DecMapStringUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUint16X(vp *map[string]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUint16V(v map[string]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[string]uint16, xlen) - changed = true - } - - var mk string - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uint32) - v, changed := fastpathTV.DecMapStringUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uint32) - fastpathTV.DecMapStringUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUint32X(vp *map[string]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUint32V(v map[string]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[string]uint32, xlen) - changed = true - } - - var mk string - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uint64) - v, changed := fastpathTV.DecMapStringUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uint64) - fastpathTV.DecMapStringUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUint64X(vp *map[string]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUint64V(v map[string]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]uint64, xlen) - changed = true - } - - var mk string - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]uintptr) - v, changed := fastpathTV.DecMapStringUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]uintptr) - fastpathTV.DecMapStringUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringUintptrX(vp *map[string]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringUintptrV(v map[string]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[string]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]uintptr, xlen) - changed = true - } - - var mk string - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]int) - v, changed := fastpathTV.DecMapStringIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]int) - fastpathTV.DecMapStringIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringIntX(vp *map[string]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringIntV(v map[string]int, checkNil bool, canChange bool, - d *Decoder) (_ map[string]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]int, xlen) - changed = true - } - - var mk string - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]int8) - v, changed := fastpathTV.DecMapStringInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]int8) - fastpathTV.DecMapStringInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringInt8X(vp *map[string]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringInt8V(v map[string]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[string]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[string]int8, xlen) - changed = true - } - - var mk string - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]int16) - v, changed := fastpathTV.DecMapStringInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]int16) - fastpathTV.DecMapStringInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringInt16X(vp *map[string]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringInt16V(v map[string]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[string]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[string]int16, xlen) - changed = true - } - - var mk string - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]int32) - v, changed := fastpathTV.DecMapStringInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]int32) - fastpathTV.DecMapStringInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringInt32X(vp *map[string]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringInt32V(v map[string]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[string]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[string]int32, xlen) - changed = true - } - - var mk string - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]int64) - v, changed := fastpathTV.DecMapStringInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]int64) - fastpathTV.DecMapStringInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringInt64X(vp *map[string]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringInt64V(v map[string]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[string]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]int64, xlen) - changed = true - } - - var mk string - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]float32) - v, changed := fastpathTV.DecMapStringFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]float32) - fastpathTV.DecMapStringFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringFloat32X(vp *map[string]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringFloat32V(v map[string]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[string]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[string]float32, xlen) - changed = true - } - - var mk string - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]float64) - v, changed := fastpathTV.DecMapStringFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]float64) - fastpathTV.DecMapStringFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringFloat64X(vp *map[string]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringFloat64V(v map[string]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[string]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[string]float64, xlen) - changed = true - } - - var mk string - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapStringBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[string]bool) - v, changed := fastpathTV.DecMapStringBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[string]bool) - fastpathTV.DecMapStringBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapStringBoolX(vp *map[string]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapStringBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapStringBoolV(v map[string]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[string]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[string]bool, xlen) - changed = true - } - - var mk string - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeString() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]interface{}) - v, changed := fastpathTV.DecMapFloat32IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]interface{}) - fastpathTV.DecMapFloat32IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32IntfX(vp *map[float32]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32IntfV(v map[float32]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[float32]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk float32 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]string) - v, changed := fastpathTV.DecMapFloat32StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]string) - fastpathTV.DecMapFloat32StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32StringX(vp *map[float32]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32StringV(v map[float32]string, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[float32]string, xlen) - changed = true - } - - var mk float32 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uint) - v, changed := fastpathTV.DecMapFloat32UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uint) - fastpathTV.DecMapFloat32UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32UintX(vp *map[float32]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32UintV(v map[float32]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]uint, xlen) - changed = true - } - - var mk float32 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uint8) - v, changed := fastpathTV.DecMapFloat32Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uint8) - fastpathTV.DecMapFloat32Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Uint8X(vp *map[float32]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Uint8V(v map[float32]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[float32]uint8, xlen) - changed = true - } - - var mk float32 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uint16) - v, changed := fastpathTV.DecMapFloat32Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uint16) - fastpathTV.DecMapFloat32Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Uint16X(vp *map[float32]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Uint16V(v map[float32]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[float32]uint16, xlen) - changed = true - } - - var mk float32 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uint32) - v, changed := fastpathTV.DecMapFloat32Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uint32) - fastpathTV.DecMapFloat32Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Uint32X(vp *map[float32]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Uint32V(v map[float32]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[float32]uint32, xlen) - changed = true - } - - var mk float32 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uint64) - v, changed := fastpathTV.DecMapFloat32Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uint64) - fastpathTV.DecMapFloat32Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Uint64X(vp *map[float32]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Uint64V(v map[float32]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]uint64, xlen) - changed = true - } - - var mk float32 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]uintptr) - v, changed := fastpathTV.DecMapFloat32UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]uintptr) - fastpathTV.DecMapFloat32UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32UintptrX(vp *map[float32]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32UintptrV(v map[float32]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]uintptr, xlen) - changed = true - } - - var mk float32 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]int) - v, changed := fastpathTV.DecMapFloat32IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]int) - fastpathTV.DecMapFloat32IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32IntX(vp *map[float32]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32IntV(v map[float32]int, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]int, xlen) - changed = true - } - - var mk float32 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]int8) - v, changed := fastpathTV.DecMapFloat32Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]int8) - fastpathTV.DecMapFloat32Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Int8X(vp *map[float32]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Int8V(v map[float32]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[float32]int8, xlen) - changed = true - } - - var mk float32 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]int16) - v, changed := fastpathTV.DecMapFloat32Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]int16) - fastpathTV.DecMapFloat32Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Int16X(vp *map[float32]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Int16V(v map[float32]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[float32]int16, xlen) - changed = true - } - - var mk float32 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]int32) - v, changed := fastpathTV.DecMapFloat32Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]int32) - fastpathTV.DecMapFloat32Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Int32X(vp *map[float32]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Int32V(v map[float32]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[float32]int32, xlen) - changed = true - } - - var mk float32 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]int64) - v, changed := fastpathTV.DecMapFloat32Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]int64) - fastpathTV.DecMapFloat32Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Int64X(vp *map[float32]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Int64V(v map[float32]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]int64, xlen) - changed = true - } - - var mk float32 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]float32) - v, changed := fastpathTV.DecMapFloat32Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]float32) - fastpathTV.DecMapFloat32Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Float32X(vp *map[float32]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Float32V(v map[float32]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[float32]float32, xlen) - changed = true - } - - var mk float32 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]float64) - v, changed := fastpathTV.DecMapFloat32Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]float64) - fastpathTV.DecMapFloat32Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32Float64X(vp *map[float32]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32Float64V(v map[float32]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float32]float64, xlen) - changed = true - } - - var mk float32 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat32BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float32]bool) - v, changed := fastpathTV.DecMapFloat32BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float32]bool) - fastpathTV.DecMapFloat32BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat32BoolX(vp *map[float32]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat32BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat32BoolV(v map[float32]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[float32]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[float32]bool, xlen) - changed = true - } - - var mk float32 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = float32(dd.DecodeFloat(true)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]interface{}) - v, changed := fastpathTV.DecMapFloat64IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]interface{}) - fastpathTV.DecMapFloat64IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64IntfX(vp *map[float64]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64IntfV(v map[float64]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[float64]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk float64 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]string) - v, changed := fastpathTV.DecMapFloat64StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]string) - fastpathTV.DecMapFloat64StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64StringX(vp *map[float64]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64StringV(v map[float64]string, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[float64]string, xlen) - changed = true - } - - var mk float64 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uint) - v, changed := fastpathTV.DecMapFloat64UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uint) - fastpathTV.DecMapFloat64UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64UintX(vp *map[float64]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64UintV(v map[float64]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]uint, xlen) - changed = true - } - - var mk float64 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uint8) - v, changed := fastpathTV.DecMapFloat64Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uint8) - fastpathTV.DecMapFloat64Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Uint8X(vp *map[float64]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Uint8V(v map[float64]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[float64]uint8, xlen) - changed = true - } - - var mk float64 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uint16) - v, changed := fastpathTV.DecMapFloat64Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uint16) - fastpathTV.DecMapFloat64Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Uint16X(vp *map[float64]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Uint16V(v map[float64]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[float64]uint16, xlen) - changed = true - } - - var mk float64 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uint32) - v, changed := fastpathTV.DecMapFloat64Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uint32) - fastpathTV.DecMapFloat64Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Uint32X(vp *map[float64]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Uint32V(v map[float64]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float64]uint32, xlen) - changed = true - } - - var mk float64 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uint64) - v, changed := fastpathTV.DecMapFloat64Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uint64) - fastpathTV.DecMapFloat64Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Uint64X(vp *map[float64]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Uint64V(v map[float64]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]uint64, xlen) - changed = true - } - - var mk float64 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]uintptr) - v, changed := fastpathTV.DecMapFloat64UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]uintptr) - fastpathTV.DecMapFloat64UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64UintptrX(vp *map[float64]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64UintptrV(v map[float64]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]uintptr, xlen) - changed = true - } - - var mk float64 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]int) - v, changed := fastpathTV.DecMapFloat64IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]int) - fastpathTV.DecMapFloat64IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64IntX(vp *map[float64]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64IntV(v map[float64]int, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]int, xlen) - changed = true - } - - var mk float64 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]int8) - v, changed := fastpathTV.DecMapFloat64Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]int8) - fastpathTV.DecMapFloat64Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Int8X(vp *map[float64]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Int8V(v map[float64]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[float64]int8, xlen) - changed = true - } - - var mk float64 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]int16) - v, changed := fastpathTV.DecMapFloat64Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]int16) - fastpathTV.DecMapFloat64Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Int16X(vp *map[float64]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Int16V(v map[float64]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[float64]int16, xlen) - changed = true - } - - var mk float64 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]int32) - v, changed := fastpathTV.DecMapFloat64Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]int32) - fastpathTV.DecMapFloat64Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Int32X(vp *map[float64]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Int32V(v map[float64]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float64]int32, xlen) - changed = true - } - - var mk float64 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]int64) - v, changed := fastpathTV.DecMapFloat64Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]int64) - fastpathTV.DecMapFloat64Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Int64X(vp *map[float64]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Int64V(v map[float64]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]int64, xlen) - changed = true - } - - var mk float64 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]float32) - v, changed := fastpathTV.DecMapFloat64Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]float32) - fastpathTV.DecMapFloat64Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Float32X(vp *map[float64]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Float32V(v map[float64]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[float64]float32, xlen) - changed = true - } - - var mk float64 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]float64) - v, changed := fastpathTV.DecMapFloat64Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]float64) - fastpathTV.DecMapFloat64Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64Float64X(vp *map[float64]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64Float64V(v map[float64]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[float64]float64, xlen) - changed = true - } - - var mk float64 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapFloat64BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[float64]bool) - v, changed := fastpathTV.DecMapFloat64BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[float64]bool) - fastpathTV.DecMapFloat64BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapFloat64BoolX(vp *map[float64]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapFloat64BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapFloat64BoolV(v map[float64]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[float64]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[float64]bool, xlen) - changed = true - } - - var mk float64 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeFloat(false) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]interface{}) - v, changed := fastpathTV.DecMapUintIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]interface{}) - fastpathTV.DecMapUintIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintIntfX(vp *map[uint]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintIntfV(v map[uint]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uint]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uint - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]string) - v, changed := fastpathTV.DecMapUintStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]string) - fastpathTV.DecMapUintStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintStringX(vp *map[uint]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintStringV(v map[uint]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uint]string, xlen) - changed = true - } - - var mk uint - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uint) - v, changed := fastpathTV.DecMapUintUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uint) - fastpathTV.DecMapUintUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUintX(vp *map[uint]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUintV(v map[uint]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]uint, xlen) - changed = true - } - - var mk uint - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uint8) - v, changed := fastpathTV.DecMapUintUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uint8) - fastpathTV.DecMapUintUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUint8X(vp *map[uint]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUint8V(v map[uint]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint]uint8, xlen) - changed = true - } - - var mk uint - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uint16) - v, changed := fastpathTV.DecMapUintUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uint16) - fastpathTV.DecMapUintUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUint16X(vp *map[uint]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUint16V(v map[uint]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint]uint16, xlen) - changed = true - } - - var mk uint - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uint32) - v, changed := fastpathTV.DecMapUintUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uint32) - fastpathTV.DecMapUintUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUint32X(vp *map[uint]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUint32V(v map[uint]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint]uint32, xlen) - changed = true - } - - var mk uint - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uint64) - v, changed := fastpathTV.DecMapUintUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uint64) - fastpathTV.DecMapUintUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUint64X(vp *map[uint]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUint64V(v map[uint]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]uint64, xlen) - changed = true - } - - var mk uint - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]uintptr) - v, changed := fastpathTV.DecMapUintUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]uintptr) - fastpathTV.DecMapUintUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintUintptrX(vp *map[uint]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintUintptrV(v map[uint]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]uintptr, xlen) - changed = true - } - - var mk uint - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]int) - v, changed := fastpathTV.DecMapUintIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]int) - fastpathTV.DecMapUintIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintIntX(vp *map[uint]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintIntV(v map[uint]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]int, xlen) - changed = true - } - - var mk uint - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]int8) - v, changed := fastpathTV.DecMapUintInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]int8) - fastpathTV.DecMapUintInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintInt8X(vp *map[uint]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintInt8V(v map[uint]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint]int8, xlen) - changed = true - } - - var mk uint - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]int16) - v, changed := fastpathTV.DecMapUintInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]int16) - fastpathTV.DecMapUintInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintInt16X(vp *map[uint]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintInt16V(v map[uint]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint]int16, xlen) - changed = true - } - - var mk uint - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]int32) - v, changed := fastpathTV.DecMapUintInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]int32) - fastpathTV.DecMapUintInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintInt32X(vp *map[uint]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintInt32V(v map[uint]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint]int32, xlen) - changed = true - } - - var mk uint - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]int64) - v, changed := fastpathTV.DecMapUintInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]int64) - fastpathTV.DecMapUintInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintInt64X(vp *map[uint]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintInt64V(v map[uint]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]int64, xlen) - changed = true - } - - var mk uint - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]float32) - v, changed := fastpathTV.DecMapUintFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]float32) - fastpathTV.DecMapUintFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintFloat32X(vp *map[uint]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintFloat32V(v map[uint]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint]float32, xlen) - changed = true - } - - var mk uint - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]float64) - v, changed := fastpathTV.DecMapUintFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]float64) - fastpathTV.DecMapUintFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintFloat64X(vp *map[uint]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintFloat64V(v map[uint]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint]float64, xlen) - changed = true - } - - var mk uint - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint]bool) - v, changed := fastpathTV.DecMapUintBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint]bool) - fastpathTV.DecMapUintBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintBoolX(vp *map[uint]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintBoolV(v map[uint]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uint]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint]bool, xlen) - changed = true - } - - var mk uint - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]interface{}) - v, changed := fastpathTV.DecMapUint8IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]interface{}) - fastpathTV.DecMapUint8IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8IntfX(vp *map[uint8]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8IntfV(v map[uint8]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[uint8]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uint8 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]string) - v, changed := fastpathTV.DecMapUint8StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]string) - fastpathTV.DecMapUint8StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8StringX(vp *map[uint8]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8StringV(v map[uint8]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[uint8]string, xlen) - changed = true - } - - var mk uint8 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uint) - v, changed := fastpathTV.DecMapUint8UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uint) - fastpathTV.DecMapUint8UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8UintX(vp *map[uint8]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8UintV(v map[uint8]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]uint, xlen) - changed = true - } - - var mk uint8 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uint8) - v, changed := fastpathTV.DecMapUint8Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uint8) - fastpathTV.DecMapUint8Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Uint8X(vp *map[uint8]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Uint8V(v map[uint8]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[uint8]uint8, xlen) - changed = true - } - - var mk uint8 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uint16) - v, changed := fastpathTV.DecMapUint8Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uint16) - fastpathTV.DecMapUint8Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Uint16X(vp *map[uint8]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Uint16V(v map[uint8]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[uint8]uint16, xlen) - changed = true - } - - var mk uint8 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uint32) - v, changed := fastpathTV.DecMapUint8Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uint32) - fastpathTV.DecMapUint8Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Uint32X(vp *map[uint8]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Uint32V(v map[uint8]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint8]uint32, xlen) - changed = true - } - - var mk uint8 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uint64) - v, changed := fastpathTV.DecMapUint8Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uint64) - fastpathTV.DecMapUint8Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Uint64X(vp *map[uint8]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Uint64V(v map[uint8]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]uint64, xlen) - changed = true - } - - var mk uint8 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]uintptr) - v, changed := fastpathTV.DecMapUint8UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]uintptr) - fastpathTV.DecMapUint8UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8UintptrX(vp *map[uint8]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8UintptrV(v map[uint8]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]uintptr, xlen) - changed = true - } - - var mk uint8 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]int) - v, changed := fastpathTV.DecMapUint8IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]int) - fastpathTV.DecMapUint8IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8IntX(vp *map[uint8]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8IntV(v map[uint8]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]int, xlen) - changed = true - } - - var mk uint8 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]int8) - v, changed := fastpathTV.DecMapUint8Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]int8) - fastpathTV.DecMapUint8Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Int8X(vp *map[uint8]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Int8V(v map[uint8]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[uint8]int8, xlen) - changed = true - } - - var mk uint8 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]int16) - v, changed := fastpathTV.DecMapUint8Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]int16) - fastpathTV.DecMapUint8Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Int16X(vp *map[uint8]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Int16V(v map[uint8]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[uint8]int16, xlen) - changed = true - } - - var mk uint8 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]int32) - v, changed := fastpathTV.DecMapUint8Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]int32) - fastpathTV.DecMapUint8Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Int32X(vp *map[uint8]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Int32V(v map[uint8]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint8]int32, xlen) - changed = true - } - - var mk uint8 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]int64) - v, changed := fastpathTV.DecMapUint8Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]int64) - fastpathTV.DecMapUint8Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Int64X(vp *map[uint8]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Int64V(v map[uint8]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]int64, xlen) - changed = true - } - - var mk uint8 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]float32) - v, changed := fastpathTV.DecMapUint8Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]float32) - fastpathTV.DecMapUint8Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Float32X(vp *map[uint8]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Float32V(v map[uint8]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint8]float32, xlen) - changed = true - } - - var mk uint8 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]float64) - v, changed := fastpathTV.DecMapUint8Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]float64) - fastpathTV.DecMapUint8Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8Float64X(vp *map[uint8]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8Float64V(v map[uint8]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint8]float64, xlen) - changed = true - } - - var mk uint8 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint8BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint8]bool) - v, changed := fastpathTV.DecMapUint8BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint8]bool) - fastpathTV.DecMapUint8BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint8BoolX(vp *map[uint8]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint8BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint8BoolV(v map[uint8]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uint8]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[uint8]bool, xlen) - changed = true - } - - var mk uint8 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint8(dd.DecodeUint(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]interface{}) - v, changed := fastpathTV.DecMapUint16IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]interface{}) - fastpathTV.DecMapUint16IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16IntfX(vp *map[uint16]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16IntfV(v map[uint16]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[uint16]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uint16 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]string) - v, changed := fastpathTV.DecMapUint16StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]string) - fastpathTV.DecMapUint16StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16StringX(vp *map[uint16]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16StringV(v map[uint16]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[uint16]string, xlen) - changed = true - } - - var mk uint16 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uint) - v, changed := fastpathTV.DecMapUint16UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uint) - fastpathTV.DecMapUint16UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16UintX(vp *map[uint16]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16UintV(v map[uint16]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]uint, xlen) - changed = true - } - - var mk uint16 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uint8) - v, changed := fastpathTV.DecMapUint16Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uint8) - fastpathTV.DecMapUint16Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Uint8X(vp *map[uint16]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Uint8V(v map[uint16]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[uint16]uint8, xlen) - changed = true - } - - var mk uint16 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uint16) - v, changed := fastpathTV.DecMapUint16Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uint16) - fastpathTV.DecMapUint16Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Uint16X(vp *map[uint16]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Uint16V(v map[uint16]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 4) - v = make(map[uint16]uint16, xlen) - changed = true - } - - var mk uint16 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uint32) - v, changed := fastpathTV.DecMapUint16Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uint32) - fastpathTV.DecMapUint16Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Uint32X(vp *map[uint16]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Uint32V(v map[uint16]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[uint16]uint32, xlen) - changed = true - } - - var mk uint16 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uint64) - v, changed := fastpathTV.DecMapUint16Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uint64) - fastpathTV.DecMapUint16Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Uint64X(vp *map[uint16]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Uint64V(v map[uint16]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]uint64, xlen) - changed = true - } - - var mk uint16 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]uintptr) - v, changed := fastpathTV.DecMapUint16UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]uintptr) - fastpathTV.DecMapUint16UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16UintptrX(vp *map[uint16]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16UintptrV(v map[uint16]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]uintptr, xlen) - changed = true - } - - var mk uint16 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]int) - v, changed := fastpathTV.DecMapUint16IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]int) - fastpathTV.DecMapUint16IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16IntX(vp *map[uint16]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16IntV(v map[uint16]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]int, xlen) - changed = true - } - - var mk uint16 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]int8) - v, changed := fastpathTV.DecMapUint16Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]int8) - fastpathTV.DecMapUint16Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Int8X(vp *map[uint16]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Int8V(v map[uint16]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[uint16]int8, xlen) - changed = true - } - - var mk uint16 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]int16) - v, changed := fastpathTV.DecMapUint16Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]int16) - fastpathTV.DecMapUint16Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Int16X(vp *map[uint16]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Int16V(v map[uint16]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 4) - v = make(map[uint16]int16, xlen) - changed = true - } - - var mk uint16 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]int32) - v, changed := fastpathTV.DecMapUint16Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]int32) - fastpathTV.DecMapUint16Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Int32X(vp *map[uint16]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Int32V(v map[uint16]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[uint16]int32, xlen) - changed = true - } - - var mk uint16 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]int64) - v, changed := fastpathTV.DecMapUint16Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]int64) - fastpathTV.DecMapUint16Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Int64X(vp *map[uint16]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Int64V(v map[uint16]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]int64, xlen) - changed = true - } - - var mk uint16 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]float32) - v, changed := fastpathTV.DecMapUint16Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]float32) - fastpathTV.DecMapUint16Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Float32X(vp *map[uint16]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Float32V(v map[uint16]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[uint16]float32, xlen) - changed = true - } - - var mk uint16 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]float64) - v, changed := fastpathTV.DecMapUint16Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]float64) - fastpathTV.DecMapUint16Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16Float64X(vp *map[uint16]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16Float64V(v map[uint16]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint16]float64, xlen) - changed = true - } - - var mk uint16 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint16BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint16]bool) - v, changed := fastpathTV.DecMapUint16BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint16]bool) - fastpathTV.DecMapUint16BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint16BoolX(vp *map[uint16]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint16BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint16BoolV(v map[uint16]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uint16]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[uint16]bool, xlen) - changed = true - } - - var mk uint16 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint16(dd.DecodeUint(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]interface{}) - v, changed := fastpathTV.DecMapUint32IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]interface{}) - fastpathTV.DecMapUint32IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32IntfX(vp *map[uint32]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32IntfV(v map[uint32]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[uint32]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uint32 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]string) - v, changed := fastpathTV.DecMapUint32StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]string) - fastpathTV.DecMapUint32StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32StringX(vp *map[uint32]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32StringV(v map[uint32]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[uint32]string, xlen) - changed = true - } - - var mk uint32 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uint) - v, changed := fastpathTV.DecMapUint32UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uint) - fastpathTV.DecMapUint32UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32UintX(vp *map[uint32]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32UintV(v map[uint32]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]uint, xlen) - changed = true - } - - var mk uint32 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uint8) - v, changed := fastpathTV.DecMapUint32Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uint8) - fastpathTV.DecMapUint32Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Uint8X(vp *map[uint32]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Uint8V(v map[uint32]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint32]uint8, xlen) - changed = true - } - - var mk uint32 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uint16) - v, changed := fastpathTV.DecMapUint32Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uint16) - fastpathTV.DecMapUint32Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Uint16X(vp *map[uint32]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Uint16V(v map[uint32]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[uint32]uint16, xlen) - changed = true - } - - var mk uint32 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uint32) - v, changed := fastpathTV.DecMapUint32Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uint32) - fastpathTV.DecMapUint32Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Uint32X(vp *map[uint32]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Uint32V(v map[uint32]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[uint32]uint32, xlen) - changed = true - } - - var mk uint32 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uint64) - v, changed := fastpathTV.DecMapUint32Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uint64) - fastpathTV.DecMapUint32Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Uint64X(vp *map[uint32]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Uint64V(v map[uint32]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]uint64, xlen) - changed = true - } - - var mk uint32 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]uintptr) - v, changed := fastpathTV.DecMapUint32UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]uintptr) - fastpathTV.DecMapUint32UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32UintptrX(vp *map[uint32]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32UintptrV(v map[uint32]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]uintptr, xlen) - changed = true - } - - var mk uint32 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]int) - v, changed := fastpathTV.DecMapUint32IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]int) - fastpathTV.DecMapUint32IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32IntX(vp *map[uint32]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32IntV(v map[uint32]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]int, xlen) - changed = true - } - - var mk uint32 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]int8) - v, changed := fastpathTV.DecMapUint32Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]int8) - fastpathTV.DecMapUint32Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Int8X(vp *map[uint32]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Int8V(v map[uint32]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint32]int8, xlen) - changed = true - } - - var mk uint32 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]int16) - v, changed := fastpathTV.DecMapUint32Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]int16) - fastpathTV.DecMapUint32Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Int16X(vp *map[uint32]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Int16V(v map[uint32]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[uint32]int16, xlen) - changed = true - } - - var mk uint32 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]int32) - v, changed := fastpathTV.DecMapUint32Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]int32) - fastpathTV.DecMapUint32Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Int32X(vp *map[uint32]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Int32V(v map[uint32]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[uint32]int32, xlen) - changed = true - } - - var mk uint32 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]int64) - v, changed := fastpathTV.DecMapUint32Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]int64) - fastpathTV.DecMapUint32Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Int64X(vp *map[uint32]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Int64V(v map[uint32]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]int64, xlen) - changed = true - } - - var mk uint32 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]float32) - v, changed := fastpathTV.DecMapUint32Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]float32) - fastpathTV.DecMapUint32Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Float32X(vp *map[uint32]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Float32V(v map[uint32]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[uint32]float32, xlen) - changed = true - } - - var mk uint32 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]float64) - v, changed := fastpathTV.DecMapUint32Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]float64) - fastpathTV.DecMapUint32Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32Float64X(vp *map[uint32]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32Float64V(v map[uint32]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint32]float64, xlen) - changed = true - } - - var mk uint32 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint32BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint32]bool) - v, changed := fastpathTV.DecMapUint32BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint32]bool) - fastpathTV.DecMapUint32BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint32BoolX(vp *map[uint32]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint32BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint32BoolV(v map[uint32]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uint32]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[uint32]bool, xlen) - changed = true - } - - var mk uint32 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uint32(dd.DecodeUint(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]interface{}) - v, changed := fastpathTV.DecMapUint64IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]interface{}) - fastpathTV.DecMapUint64IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64IntfX(vp *map[uint64]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64IntfV(v map[uint64]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uint64]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uint64 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]string) - v, changed := fastpathTV.DecMapUint64StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]string) - fastpathTV.DecMapUint64StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64StringX(vp *map[uint64]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64StringV(v map[uint64]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uint64]string, xlen) - changed = true - } - - var mk uint64 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uint) - v, changed := fastpathTV.DecMapUint64UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uint) - fastpathTV.DecMapUint64UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64UintX(vp *map[uint64]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64UintV(v map[uint64]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]uint, xlen) - changed = true - } - - var mk uint64 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uint8) - v, changed := fastpathTV.DecMapUint64Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uint8) - fastpathTV.DecMapUint64Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Uint8X(vp *map[uint64]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Uint8V(v map[uint64]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint64]uint8, xlen) - changed = true - } - - var mk uint64 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uint16) - v, changed := fastpathTV.DecMapUint64Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uint16) - fastpathTV.DecMapUint64Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Uint16X(vp *map[uint64]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Uint16V(v map[uint64]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint64]uint16, xlen) - changed = true - } - - var mk uint64 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uint32) - v, changed := fastpathTV.DecMapUint64Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uint32) - fastpathTV.DecMapUint64Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Uint32X(vp *map[uint64]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Uint32V(v map[uint64]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint64]uint32, xlen) - changed = true - } - - var mk uint64 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uint64) - v, changed := fastpathTV.DecMapUint64Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uint64) - fastpathTV.DecMapUint64Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Uint64X(vp *map[uint64]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Uint64V(v map[uint64]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]uint64, xlen) - changed = true - } - - var mk uint64 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]uintptr) - v, changed := fastpathTV.DecMapUint64UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]uintptr) - fastpathTV.DecMapUint64UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64UintptrX(vp *map[uint64]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64UintptrV(v map[uint64]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]uintptr, xlen) - changed = true - } - - var mk uint64 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]int) - v, changed := fastpathTV.DecMapUint64IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]int) - fastpathTV.DecMapUint64IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64IntX(vp *map[uint64]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64IntV(v map[uint64]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]int, xlen) - changed = true - } - - var mk uint64 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]int8) - v, changed := fastpathTV.DecMapUint64Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]int8) - fastpathTV.DecMapUint64Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Int8X(vp *map[uint64]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Int8V(v map[uint64]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint64]int8, xlen) - changed = true - } - - var mk uint64 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]int16) - v, changed := fastpathTV.DecMapUint64Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]int16) - fastpathTV.DecMapUint64Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Int16X(vp *map[uint64]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Int16V(v map[uint64]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uint64]int16, xlen) - changed = true - } - - var mk uint64 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]int32) - v, changed := fastpathTV.DecMapUint64Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]int32) - fastpathTV.DecMapUint64Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Int32X(vp *map[uint64]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Int32V(v map[uint64]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint64]int32, xlen) - changed = true - } - - var mk uint64 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]int64) - v, changed := fastpathTV.DecMapUint64Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]int64) - fastpathTV.DecMapUint64Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Int64X(vp *map[uint64]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Int64V(v map[uint64]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]int64, xlen) - changed = true - } - - var mk uint64 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]float32) - v, changed := fastpathTV.DecMapUint64Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]float32) - fastpathTV.DecMapUint64Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Float32X(vp *map[uint64]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Float32V(v map[uint64]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uint64]float32, xlen) - changed = true - } - - var mk uint64 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]float64) - v, changed := fastpathTV.DecMapUint64Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]float64) - fastpathTV.DecMapUint64Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64Float64X(vp *map[uint64]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64Float64V(v map[uint64]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uint64]float64, xlen) - changed = true - } - - var mk uint64 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUint64BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uint64]bool) - v, changed := fastpathTV.DecMapUint64BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uint64]bool) - fastpathTV.DecMapUint64BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUint64BoolX(vp *map[uint64]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUint64BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUint64BoolV(v map[uint64]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uint64]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uint64]bool, xlen) - changed = true - } - - var mk uint64 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeUint(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]interface{}) - v, changed := fastpathTV.DecMapUintptrIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]interface{}) - fastpathTV.DecMapUintptrIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrIntfX(vp *map[uintptr]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrIntfV(v map[uintptr]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uintptr]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk uintptr - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]string) - v, changed := fastpathTV.DecMapUintptrStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]string) - fastpathTV.DecMapUintptrStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrStringX(vp *map[uintptr]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrStringV(v map[uintptr]string, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[uintptr]string, xlen) - changed = true - } - - var mk uintptr - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uint) - v, changed := fastpathTV.DecMapUintptrUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uint) - fastpathTV.DecMapUintptrUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUintX(vp *map[uintptr]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUintV(v map[uintptr]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]uint, xlen) - changed = true - } - - var mk uintptr - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uint8) - v, changed := fastpathTV.DecMapUintptrUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uint8) - fastpathTV.DecMapUintptrUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUint8X(vp *map[uintptr]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUint8V(v map[uintptr]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uintptr]uint8, xlen) - changed = true - } - - var mk uintptr - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uint16) - v, changed := fastpathTV.DecMapUintptrUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uint16) - fastpathTV.DecMapUintptrUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUint16X(vp *map[uintptr]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUint16V(v map[uintptr]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uintptr]uint16, xlen) - changed = true - } - - var mk uintptr - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uint32) - v, changed := fastpathTV.DecMapUintptrUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uint32) - fastpathTV.DecMapUintptrUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUint32X(vp *map[uintptr]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUint32V(v map[uintptr]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uintptr]uint32, xlen) - changed = true - } - - var mk uintptr - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uint64) - v, changed := fastpathTV.DecMapUintptrUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uint64) - fastpathTV.DecMapUintptrUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUint64X(vp *map[uintptr]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUint64V(v map[uintptr]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]uint64, xlen) - changed = true - } - - var mk uintptr - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]uintptr) - v, changed := fastpathTV.DecMapUintptrUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]uintptr) - fastpathTV.DecMapUintptrUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrUintptrX(vp *map[uintptr]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrUintptrV(v map[uintptr]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]uintptr, xlen) - changed = true - } - - var mk uintptr - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]int) - v, changed := fastpathTV.DecMapUintptrIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]int) - fastpathTV.DecMapUintptrIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrIntX(vp *map[uintptr]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrIntV(v map[uintptr]int, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]int, xlen) - changed = true - } - - var mk uintptr - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]int8) - v, changed := fastpathTV.DecMapUintptrInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]int8) - fastpathTV.DecMapUintptrInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrInt8X(vp *map[uintptr]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrInt8V(v map[uintptr]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uintptr]int8, xlen) - changed = true - } - - var mk uintptr - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]int16) - v, changed := fastpathTV.DecMapUintptrInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]int16) - fastpathTV.DecMapUintptrInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrInt16X(vp *map[uintptr]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrInt16V(v map[uintptr]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[uintptr]int16, xlen) - changed = true - } - - var mk uintptr - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]int32) - v, changed := fastpathTV.DecMapUintptrInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]int32) - fastpathTV.DecMapUintptrInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrInt32X(vp *map[uintptr]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrInt32V(v map[uintptr]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uintptr]int32, xlen) - changed = true - } - - var mk uintptr - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]int64) - v, changed := fastpathTV.DecMapUintptrInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]int64) - fastpathTV.DecMapUintptrInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrInt64X(vp *map[uintptr]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrInt64V(v map[uintptr]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]int64, xlen) - changed = true - } - - var mk uintptr - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]float32) - v, changed := fastpathTV.DecMapUintptrFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]float32) - fastpathTV.DecMapUintptrFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrFloat32X(vp *map[uintptr]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrFloat32V(v map[uintptr]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[uintptr]float32, xlen) - changed = true - } - - var mk uintptr - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]float64) - v, changed := fastpathTV.DecMapUintptrFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]float64) - fastpathTV.DecMapUintptrFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrFloat64X(vp *map[uintptr]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrFloat64V(v map[uintptr]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[uintptr]float64, xlen) - changed = true - } - - var mk uintptr - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapUintptrBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[uintptr]bool) - v, changed := fastpathTV.DecMapUintptrBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[uintptr]bool) - fastpathTV.DecMapUintptrBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapUintptrBoolX(vp *map[uintptr]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapUintptrBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapUintptrBoolV(v map[uintptr]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[uintptr]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[uintptr]bool, xlen) - changed = true - } - - var mk uintptr - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = uintptr(dd.DecodeUint(uintBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]interface{}) - v, changed := fastpathTV.DecMapIntIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]interface{}) - fastpathTV.DecMapIntIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntIntfX(vp *map[int]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntIntfV(v map[int]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[int]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[int]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk int - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]string) - v, changed := fastpathTV.DecMapIntStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]string) - fastpathTV.DecMapIntStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntStringX(vp *map[int]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntStringV(v map[int]string, checkNil bool, canChange bool, - d *Decoder) (_ map[int]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[int]string, xlen) - changed = true - } - - var mk int - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uint) - v, changed := fastpathTV.DecMapIntUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uint) - fastpathTV.DecMapIntUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUintX(vp *map[int]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUintV(v map[int]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]uint, xlen) - changed = true - } - - var mk int - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uint8) - v, changed := fastpathTV.DecMapIntUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uint8) - fastpathTV.DecMapIntUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUint8X(vp *map[int]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUint8V(v map[int]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int]uint8, xlen) - changed = true - } - - var mk int - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uint16) - v, changed := fastpathTV.DecMapIntUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uint16) - fastpathTV.DecMapIntUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUint16X(vp *map[int]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUint16V(v map[int]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int]uint16, xlen) - changed = true - } - - var mk int - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uint32) - v, changed := fastpathTV.DecMapIntUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uint32) - fastpathTV.DecMapIntUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUint32X(vp *map[int]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUint32V(v map[int]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int]uint32, xlen) - changed = true - } - - var mk int - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uint64) - v, changed := fastpathTV.DecMapIntUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uint64) - fastpathTV.DecMapIntUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUint64X(vp *map[int]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUint64V(v map[int]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]uint64, xlen) - changed = true - } - - var mk int - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]uintptr) - v, changed := fastpathTV.DecMapIntUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]uintptr) - fastpathTV.DecMapIntUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntUintptrX(vp *map[int]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntUintptrV(v map[int]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[int]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]uintptr, xlen) - changed = true - } - - var mk int - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]int) - v, changed := fastpathTV.DecMapIntIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]int) - fastpathTV.DecMapIntIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntIntX(vp *map[int]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntIntV(v map[int]int, checkNil bool, canChange bool, - d *Decoder) (_ map[int]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]int, xlen) - changed = true - } - - var mk int - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]int8) - v, changed := fastpathTV.DecMapIntInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]int8) - fastpathTV.DecMapIntInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntInt8X(vp *map[int]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntInt8V(v map[int]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[int]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int]int8, xlen) - changed = true - } - - var mk int - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]int16) - v, changed := fastpathTV.DecMapIntInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]int16) - fastpathTV.DecMapIntInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntInt16X(vp *map[int]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntInt16V(v map[int]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[int]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int]int16, xlen) - changed = true - } - - var mk int - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]int32) - v, changed := fastpathTV.DecMapIntInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]int32) - fastpathTV.DecMapIntInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntInt32X(vp *map[int]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntInt32V(v map[int]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[int]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int]int32, xlen) - changed = true - } - - var mk int - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]int64) - v, changed := fastpathTV.DecMapIntInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]int64) - fastpathTV.DecMapIntInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntInt64X(vp *map[int]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntInt64V(v map[int]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[int]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]int64, xlen) - changed = true - } - - var mk int - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]float32) - v, changed := fastpathTV.DecMapIntFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]float32) - fastpathTV.DecMapIntFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntFloat32X(vp *map[int]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntFloat32V(v map[int]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[int]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int]float32, xlen) - changed = true - } - - var mk int - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]float64) - v, changed := fastpathTV.DecMapIntFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]float64) - fastpathTV.DecMapIntFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntFloat64X(vp *map[int]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntFloat64V(v map[int]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[int]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int]float64, xlen) - changed = true - } - - var mk int - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapIntBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int]bool) - v, changed := fastpathTV.DecMapIntBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int]bool) - fastpathTV.DecMapIntBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapIntBoolX(vp *map[int]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapIntBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapIntBoolV(v map[int]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[int]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int]bool, xlen) - changed = true - } - - var mk int - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int(dd.DecodeInt(intBitsize)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]interface{}) - v, changed := fastpathTV.DecMapInt8IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]interface{}) - fastpathTV.DecMapInt8IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8IntfX(vp *map[int8]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8IntfV(v map[int8]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[int8]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk int8 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]string) - v, changed := fastpathTV.DecMapInt8StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]string) - fastpathTV.DecMapInt8StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8StringX(vp *map[int8]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8StringV(v map[int8]string, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[int8]string, xlen) - changed = true - } - - var mk int8 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uint) - v, changed := fastpathTV.DecMapInt8UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uint) - fastpathTV.DecMapInt8UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8UintX(vp *map[int8]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8UintV(v map[int8]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]uint, xlen) - changed = true - } - - var mk int8 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uint8) - v, changed := fastpathTV.DecMapInt8Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uint8) - fastpathTV.DecMapInt8Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Uint8X(vp *map[int8]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Uint8V(v map[int8]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[int8]uint8, xlen) - changed = true - } - - var mk int8 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uint16) - v, changed := fastpathTV.DecMapInt8Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uint16) - fastpathTV.DecMapInt8Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Uint16X(vp *map[int8]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Uint16V(v map[int8]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[int8]uint16, xlen) - changed = true - } - - var mk int8 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uint32) - v, changed := fastpathTV.DecMapInt8Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uint32) - fastpathTV.DecMapInt8Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Uint32X(vp *map[int8]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Uint32V(v map[int8]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int8]uint32, xlen) - changed = true - } - - var mk int8 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uint64) - v, changed := fastpathTV.DecMapInt8Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uint64) - fastpathTV.DecMapInt8Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Uint64X(vp *map[int8]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Uint64V(v map[int8]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]uint64, xlen) - changed = true - } - - var mk int8 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]uintptr) - v, changed := fastpathTV.DecMapInt8UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]uintptr) - fastpathTV.DecMapInt8UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8UintptrX(vp *map[int8]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8UintptrV(v map[int8]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]uintptr, xlen) - changed = true - } - - var mk int8 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]int) - v, changed := fastpathTV.DecMapInt8IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]int) - fastpathTV.DecMapInt8IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8IntX(vp *map[int8]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8IntV(v map[int8]int, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]int, xlen) - changed = true - } - - var mk int8 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]int8) - v, changed := fastpathTV.DecMapInt8Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]int8) - fastpathTV.DecMapInt8Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Int8X(vp *map[int8]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Int8V(v map[int8]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[int8]int8, xlen) - changed = true - } - - var mk int8 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]int16) - v, changed := fastpathTV.DecMapInt8Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]int16) - fastpathTV.DecMapInt8Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Int16X(vp *map[int8]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Int16V(v map[int8]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[int8]int16, xlen) - changed = true - } - - var mk int8 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]int32) - v, changed := fastpathTV.DecMapInt8Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]int32) - fastpathTV.DecMapInt8Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Int32X(vp *map[int8]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Int32V(v map[int8]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int8]int32, xlen) - changed = true - } - - var mk int8 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]int64) - v, changed := fastpathTV.DecMapInt8Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]int64) - fastpathTV.DecMapInt8Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Int64X(vp *map[int8]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Int64V(v map[int8]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]int64, xlen) - changed = true - } - - var mk int8 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]float32) - v, changed := fastpathTV.DecMapInt8Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]float32) - fastpathTV.DecMapInt8Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Float32X(vp *map[int8]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Float32V(v map[int8]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int8]float32, xlen) - changed = true - } - - var mk int8 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]float64) - v, changed := fastpathTV.DecMapInt8Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]float64) - fastpathTV.DecMapInt8Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8Float64X(vp *map[int8]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8Float64V(v map[int8]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int8]float64, xlen) - changed = true - } - - var mk int8 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt8BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int8]bool) - v, changed := fastpathTV.DecMapInt8BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int8]bool) - fastpathTV.DecMapInt8BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt8BoolX(vp *map[int8]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt8BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt8BoolV(v map[int8]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[int8]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[int8]bool, xlen) - changed = true - } - - var mk int8 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int8(dd.DecodeInt(8)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]interface{}) - v, changed := fastpathTV.DecMapInt16IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]interface{}) - fastpathTV.DecMapInt16IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16IntfX(vp *map[int16]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16IntfV(v map[int16]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[int16]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk int16 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]string) - v, changed := fastpathTV.DecMapInt16StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]string) - fastpathTV.DecMapInt16StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16StringX(vp *map[int16]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16StringV(v map[int16]string, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 18) - v = make(map[int16]string, xlen) - changed = true - } - - var mk int16 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uint) - v, changed := fastpathTV.DecMapInt16UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uint) - fastpathTV.DecMapInt16UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16UintX(vp *map[int16]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16UintV(v map[int16]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]uint, xlen) - changed = true - } - - var mk int16 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uint8) - v, changed := fastpathTV.DecMapInt16Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uint8) - fastpathTV.DecMapInt16Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Uint8X(vp *map[int16]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Uint8V(v map[int16]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[int16]uint8, xlen) - changed = true - } - - var mk int16 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uint16) - v, changed := fastpathTV.DecMapInt16Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uint16) - fastpathTV.DecMapInt16Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Uint16X(vp *map[int16]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Uint16V(v map[int16]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 4) - v = make(map[int16]uint16, xlen) - changed = true - } - - var mk int16 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uint32) - v, changed := fastpathTV.DecMapInt16Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uint32) - fastpathTV.DecMapInt16Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Uint32X(vp *map[int16]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Uint32V(v map[int16]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[int16]uint32, xlen) - changed = true - } - - var mk int16 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uint64) - v, changed := fastpathTV.DecMapInt16Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uint64) - fastpathTV.DecMapInt16Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Uint64X(vp *map[int16]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Uint64V(v map[int16]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]uint64, xlen) - changed = true - } - - var mk int16 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]uintptr) - v, changed := fastpathTV.DecMapInt16UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]uintptr) - fastpathTV.DecMapInt16UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16UintptrX(vp *map[int16]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16UintptrV(v map[int16]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]uintptr, xlen) - changed = true - } - - var mk int16 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]int) - v, changed := fastpathTV.DecMapInt16IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]int) - fastpathTV.DecMapInt16IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16IntX(vp *map[int16]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16IntV(v map[int16]int, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]int, xlen) - changed = true - } - - var mk int16 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]int8) - v, changed := fastpathTV.DecMapInt16Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]int8) - fastpathTV.DecMapInt16Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Int8X(vp *map[int16]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Int8V(v map[int16]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[int16]int8, xlen) - changed = true - } - - var mk int16 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]int16) - v, changed := fastpathTV.DecMapInt16Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]int16) - fastpathTV.DecMapInt16Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Int16X(vp *map[int16]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Int16V(v map[int16]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 4) - v = make(map[int16]int16, xlen) - changed = true - } - - var mk int16 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]int32) - v, changed := fastpathTV.DecMapInt16Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]int32) - fastpathTV.DecMapInt16Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Int32X(vp *map[int16]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Int32V(v map[int16]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[int16]int32, xlen) - changed = true - } - - var mk int16 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]int64) - v, changed := fastpathTV.DecMapInt16Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]int64) - fastpathTV.DecMapInt16Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Int64X(vp *map[int16]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Int64V(v map[int16]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]int64, xlen) - changed = true - } - - var mk int16 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]float32) - v, changed := fastpathTV.DecMapInt16Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]float32) - fastpathTV.DecMapInt16Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Float32X(vp *map[int16]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Float32V(v map[int16]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[int16]float32, xlen) - changed = true - } - - var mk int16 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]float64) - v, changed := fastpathTV.DecMapInt16Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]float64) - fastpathTV.DecMapInt16Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16Float64X(vp *map[int16]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16Float64V(v map[int16]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int16]float64, xlen) - changed = true - } - - var mk int16 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt16BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int16]bool) - v, changed := fastpathTV.DecMapInt16BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int16]bool) - fastpathTV.DecMapInt16BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt16BoolX(vp *map[int16]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt16BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt16BoolV(v map[int16]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[int16]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[int16]bool, xlen) - changed = true - } - - var mk int16 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int16(dd.DecodeInt(16)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]interface{}) - v, changed := fastpathTV.DecMapInt32IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]interface{}) - fastpathTV.DecMapInt32IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32IntfX(vp *map[int32]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32IntfV(v map[int32]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[int32]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk int32 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]string) - v, changed := fastpathTV.DecMapInt32StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]string) - fastpathTV.DecMapInt32StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32StringX(vp *map[int32]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32StringV(v map[int32]string, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 20) - v = make(map[int32]string, xlen) - changed = true - } - - var mk int32 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uint) - v, changed := fastpathTV.DecMapInt32UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uint) - fastpathTV.DecMapInt32UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32UintX(vp *map[int32]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32UintV(v map[int32]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]uint, xlen) - changed = true - } - - var mk int32 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uint8) - v, changed := fastpathTV.DecMapInt32Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uint8) - fastpathTV.DecMapInt32Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Uint8X(vp *map[int32]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Uint8V(v map[int32]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int32]uint8, xlen) - changed = true - } - - var mk int32 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uint16) - v, changed := fastpathTV.DecMapInt32Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uint16) - fastpathTV.DecMapInt32Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Uint16X(vp *map[int32]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Uint16V(v map[int32]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[int32]uint16, xlen) - changed = true - } - - var mk int32 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uint32) - v, changed := fastpathTV.DecMapInt32Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uint32) - fastpathTV.DecMapInt32Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Uint32X(vp *map[int32]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Uint32V(v map[int32]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[int32]uint32, xlen) - changed = true - } - - var mk int32 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uint64) - v, changed := fastpathTV.DecMapInt32Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uint64) - fastpathTV.DecMapInt32Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Uint64X(vp *map[int32]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Uint64V(v map[int32]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]uint64, xlen) - changed = true - } - - var mk int32 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]uintptr) - v, changed := fastpathTV.DecMapInt32UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]uintptr) - fastpathTV.DecMapInt32UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32UintptrX(vp *map[int32]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32UintptrV(v map[int32]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]uintptr, xlen) - changed = true - } - - var mk int32 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]int) - v, changed := fastpathTV.DecMapInt32IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]int) - fastpathTV.DecMapInt32IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32IntX(vp *map[int32]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32IntV(v map[int32]int, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]int, xlen) - changed = true - } - - var mk int32 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]int8) - v, changed := fastpathTV.DecMapInt32Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]int8) - fastpathTV.DecMapInt32Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Int8X(vp *map[int32]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Int8V(v map[int32]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int32]int8, xlen) - changed = true - } - - var mk int32 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]int16) - v, changed := fastpathTV.DecMapInt32Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]int16) - fastpathTV.DecMapInt32Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Int16X(vp *map[int32]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Int16V(v map[int32]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 6) - v = make(map[int32]int16, xlen) - changed = true - } - - var mk int32 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]int32) - v, changed := fastpathTV.DecMapInt32Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]int32) - fastpathTV.DecMapInt32Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Int32X(vp *map[int32]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Int32V(v map[int32]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[int32]int32, xlen) - changed = true - } - - var mk int32 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]int64) - v, changed := fastpathTV.DecMapInt32Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]int64) - fastpathTV.DecMapInt32Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Int64X(vp *map[int32]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Int64V(v map[int32]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]int64, xlen) - changed = true - } - - var mk int32 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]float32) - v, changed := fastpathTV.DecMapInt32Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]float32) - fastpathTV.DecMapInt32Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Float32X(vp *map[int32]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Float32V(v map[int32]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 8) - v = make(map[int32]float32, xlen) - changed = true - } - - var mk int32 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]float64) - v, changed := fastpathTV.DecMapInt32Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]float64) - fastpathTV.DecMapInt32Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32Float64X(vp *map[int32]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32Float64V(v map[int32]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int32]float64, xlen) - changed = true - } - - var mk int32 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt32BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int32]bool) - v, changed := fastpathTV.DecMapInt32BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int32]bool) - fastpathTV.DecMapInt32BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt32BoolX(vp *map[int32]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt32BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt32BoolV(v map[int32]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[int32]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[int32]bool, xlen) - changed = true - } - - var mk int32 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = int32(dd.DecodeInt(32)) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64IntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]interface{}) - v, changed := fastpathTV.DecMapInt64IntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]interface{}) - fastpathTV.DecMapInt64IntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64IntfX(vp *map[int64]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64IntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64IntfV(v map[int64]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[int64]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk int64 - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64StringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]string) - v, changed := fastpathTV.DecMapInt64StringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]string) - fastpathTV.DecMapInt64StringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64StringX(vp *map[int64]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64StringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64StringV(v map[int64]string, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 24) - v = make(map[int64]string, xlen) - changed = true - } - - var mk int64 - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64UintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uint) - v, changed := fastpathTV.DecMapInt64UintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uint) - fastpathTV.DecMapInt64UintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64UintX(vp *map[int64]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64UintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64UintV(v map[int64]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]uint, xlen) - changed = true - } - - var mk int64 - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Uint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uint8) - v, changed := fastpathTV.DecMapInt64Uint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uint8) - fastpathTV.DecMapInt64Uint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Uint8X(vp *map[int64]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Uint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Uint8V(v map[int64]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int64]uint8, xlen) - changed = true - } - - var mk int64 - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Uint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uint16) - v, changed := fastpathTV.DecMapInt64Uint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uint16) - fastpathTV.DecMapInt64Uint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Uint16X(vp *map[int64]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Uint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Uint16V(v map[int64]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int64]uint16, xlen) - changed = true - } - - var mk int64 - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Uint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uint32) - v, changed := fastpathTV.DecMapInt64Uint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uint32) - fastpathTV.DecMapInt64Uint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Uint32X(vp *map[int64]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Uint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Uint32V(v map[int64]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int64]uint32, xlen) - changed = true - } - - var mk int64 - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Uint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uint64) - v, changed := fastpathTV.DecMapInt64Uint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uint64) - fastpathTV.DecMapInt64Uint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Uint64X(vp *map[int64]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Uint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Uint64V(v map[int64]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]uint64, xlen) - changed = true - } - - var mk int64 - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64UintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]uintptr) - v, changed := fastpathTV.DecMapInt64UintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]uintptr) - fastpathTV.DecMapInt64UintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64UintptrX(vp *map[int64]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64UintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64UintptrV(v map[int64]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]uintptr, xlen) - changed = true - } - - var mk int64 - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64IntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]int) - v, changed := fastpathTV.DecMapInt64IntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]int) - fastpathTV.DecMapInt64IntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64IntX(vp *map[int64]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64IntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64IntV(v map[int64]int, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]int, xlen) - changed = true - } - - var mk int64 - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Int8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]int8) - v, changed := fastpathTV.DecMapInt64Int8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]int8) - fastpathTV.DecMapInt64Int8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Int8X(vp *map[int64]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Int8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Int8V(v map[int64]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int64]int8, xlen) - changed = true - } - - var mk int64 - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Int16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]int16) - v, changed := fastpathTV.DecMapInt64Int16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]int16) - fastpathTV.DecMapInt64Int16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Int16X(vp *map[int64]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Int16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Int16V(v map[int64]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 10) - v = make(map[int64]int16, xlen) - changed = true - } - - var mk int64 - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Int32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]int32) - v, changed := fastpathTV.DecMapInt64Int32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]int32) - fastpathTV.DecMapInt64Int32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Int32X(vp *map[int64]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Int32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Int32V(v map[int64]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int64]int32, xlen) - changed = true - } - - var mk int64 - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Int64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]int64) - v, changed := fastpathTV.DecMapInt64Int64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]int64) - fastpathTV.DecMapInt64Int64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Int64X(vp *map[int64]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Int64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Int64V(v map[int64]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]int64, xlen) - changed = true - } - - var mk int64 - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Float32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]float32) - v, changed := fastpathTV.DecMapInt64Float32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]float32) - fastpathTV.DecMapInt64Float32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Float32X(vp *map[int64]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Float32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Float32V(v map[int64]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 12) - v = make(map[int64]float32, xlen) - changed = true - } - - var mk int64 - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64Float64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]float64) - v, changed := fastpathTV.DecMapInt64Float64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]float64) - fastpathTV.DecMapInt64Float64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64Float64X(vp *map[int64]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64Float64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64Float64V(v map[int64]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 16) - v = make(map[int64]float64, xlen) - changed = true - } - - var mk int64 - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapInt64BoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[int64]bool) - v, changed := fastpathTV.DecMapInt64BoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[int64]bool) - fastpathTV.DecMapInt64BoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapInt64BoolX(vp *map[int64]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapInt64BoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapInt64BoolV(v map[int64]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[int64]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[int64]bool, xlen) - changed = true - } - - var mk int64 - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeInt(64) - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolIntfR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]interface{}) - v, changed := fastpathTV.DecMapBoolIntfV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]interface{}) - fastpathTV.DecMapBoolIntfV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolIntfX(vp *map[bool]interface{}, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolIntfV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolIntfV(v map[bool]interface{}, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]interface{}, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[bool]interface{}, xlen) - changed = true - } - mapGet := !d.h.MapValueReset && !d.h.InterfaceReset - var mk bool - var mv interface{} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - if mapGet { - mv = v[mk] - } else { - mv = nil - } - d.decode(&mv) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolStringR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]string) - v, changed := fastpathTV.DecMapBoolStringV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]string) - fastpathTV.DecMapBoolStringV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolStringX(vp *map[bool]string, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolStringV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolStringV(v map[bool]string, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]string, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 17) - v = make(map[bool]string, xlen) - changed = true - } - - var mk bool - var mv string - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeString() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUintR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uint) - v, changed := fastpathTV.DecMapBoolUintV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uint) - fastpathTV.DecMapBoolUintV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUintX(vp *map[bool]uint, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUintV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUintV(v map[bool]uint, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uint, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]uint, xlen) - changed = true - } - - var mk bool - var mv uint - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUint8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uint8) - v, changed := fastpathTV.DecMapBoolUint8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uint8) - fastpathTV.DecMapBoolUint8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUint8X(vp *map[bool]uint8, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUint8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUint8V(v map[bool]uint8, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uint8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[bool]uint8, xlen) - changed = true - } - - var mk bool - var mv uint8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint8(dd.DecodeUint(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUint16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uint16) - v, changed := fastpathTV.DecMapBoolUint16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uint16) - fastpathTV.DecMapBoolUint16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUint16X(vp *map[bool]uint16, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUint16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUint16V(v map[bool]uint16, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uint16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[bool]uint16, xlen) - changed = true - } - - var mk bool - var mv uint16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint16(dd.DecodeUint(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUint32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uint32) - v, changed := fastpathTV.DecMapBoolUint32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uint32) - fastpathTV.DecMapBoolUint32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUint32X(vp *map[bool]uint32, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUint32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUint32V(v map[bool]uint32, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uint32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[bool]uint32, xlen) - changed = true - } - - var mk bool - var mv uint32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uint32(dd.DecodeUint(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUint64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uint64) - v, changed := fastpathTV.DecMapBoolUint64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uint64) - fastpathTV.DecMapBoolUint64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUint64X(vp *map[bool]uint64, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUint64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUint64V(v map[bool]uint64, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uint64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]uint64, xlen) - changed = true - } - - var mk bool - var mv uint64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeUint(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolUintptrR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]uintptr) - v, changed := fastpathTV.DecMapBoolUintptrV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]uintptr) - fastpathTV.DecMapBoolUintptrV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolUintptrX(vp *map[bool]uintptr, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolUintptrV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolUintptrV(v map[bool]uintptr, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]uintptr, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]uintptr, xlen) - changed = true - } - - var mk bool - var mv uintptr - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = uintptr(dd.DecodeUint(uintBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolIntR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]int) - v, changed := fastpathTV.DecMapBoolIntV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]int) - fastpathTV.DecMapBoolIntV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolIntX(vp *map[bool]int, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolIntV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolIntV(v map[bool]int, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]int, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]int, xlen) - changed = true - } - - var mk bool - var mv int - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int(dd.DecodeInt(intBitsize)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolInt8R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]int8) - v, changed := fastpathTV.DecMapBoolInt8V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]int8) - fastpathTV.DecMapBoolInt8V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolInt8X(vp *map[bool]int8, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolInt8V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolInt8V(v map[bool]int8, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]int8, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[bool]int8, xlen) - changed = true - } - - var mk bool - var mv int8 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int8(dd.DecodeInt(8)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolInt16R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]int16) - v, changed := fastpathTV.DecMapBoolInt16V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]int16) - fastpathTV.DecMapBoolInt16V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolInt16X(vp *map[bool]int16, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolInt16V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolInt16V(v map[bool]int16, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]int16, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 3) - v = make(map[bool]int16, xlen) - changed = true - } - - var mk bool - var mv int16 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int16(dd.DecodeInt(16)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolInt32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]int32) - v, changed := fastpathTV.DecMapBoolInt32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]int32) - fastpathTV.DecMapBoolInt32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolInt32X(vp *map[bool]int32, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolInt32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolInt32V(v map[bool]int32, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]int32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[bool]int32, xlen) - changed = true - } - - var mk bool - var mv int32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = int32(dd.DecodeInt(32)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolInt64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]int64) - v, changed := fastpathTV.DecMapBoolInt64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]int64) - fastpathTV.DecMapBoolInt64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolInt64X(vp *map[bool]int64, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolInt64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolInt64V(v map[bool]int64, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]int64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]int64, xlen) - changed = true - } - - var mk bool - var mv int64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeInt(64) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolFloat32R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]float32) - v, changed := fastpathTV.DecMapBoolFloat32V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]float32) - fastpathTV.DecMapBoolFloat32V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolFloat32X(vp *map[bool]float32, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolFloat32V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolFloat32V(v map[bool]float32, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]float32, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 5) - v = make(map[bool]float32, xlen) - changed = true - } - - var mk bool - var mv float32 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = float32(dd.DecodeFloat(true)) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolFloat64R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]float64) - v, changed := fastpathTV.DecMapBoolFloat64V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]float64) - fastpathTV.DecMapBoolFloat64V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolFloat64X(vp *map[bool]float64, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolFloat64V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolFloat64V(v map[bool]float64, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]float64, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 9) - v = make(map[bool]float64, xlen) - changed = true - } - - var mk bool - var mv float64 - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeFloat(false) - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} - -func (f *decFnInfo) fastpathDecMapBoolBoolR(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[bool]bool) - v, changed := fastpathTV.DecMapBoolBoolV(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[bool]bool) - fastpathTV.DecMapBoolBoolV(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) DecMapBoolBoolX(vp *map[bool]bool, checkNil bool, d *Decoder) { - v, changed := f.DecMapBoolBoolV(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) DecMapBoolBoolV(v map[bool]bool, checkNil bool, canChange bool, - d *Decoder) (_ map[bool]bool, changed bool) { - dd := d.d - cr := d.cr - - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, 2) - v = make(map[bool]bool, xlen) - changed = true - } - - var mk bool - var mv bool - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { - cr.sendContainerState(containerMapKey) - } - mk = dd.DecodeBool() - if cr != nil { - cr.sendContainerState(containerMapValue) - } - mv = dd.DecodeBool() - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { - cr.sendContainerState(containerMapEnd) - } - return v, changed -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl deleted file mode 100644 index 58cc6df..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.go.tmpl +++ /dev/null @@ -1,511 +0,0 @@ -// +build !notfastpath - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED from fast-path.go.tmpl -// ************************************************************ - -package codec - -// Fast path functions try to create a fast path encode or decode implementation -// for common maps and slices. -// -// We define the functions and register then in this single file -// so as not to pollute the encode.go and decode.go, and create a dependency in there. -// This file can be omitted without causing a build failure. -// -// The advantage of fast paths is: -// - Many calls bypass reflection altogether -// -// Currently support -// - slice of all builtin types, -// - map of all builtin types to string or interface value -// - symetrical maps of all builtin types (e.g. str-str, uint8-uint8) -// This should provide adequate "typical" implementations. -// -// Note that fast track decode functions must handle values for which an address cannot be obtained. -// For example: -// m2 := map[string]int{} -// p2 := []interface{}{m2} -// // decoding into p2 will bomb if fast track functions do not treat like unaddressable. -// - -import ( - "reflect" - "sort" -) - -const fastpathCheckNilFalse = false // for reflect -const fastpathCheckNilTrue = true // for type switch - -type fastpathT struct {} - -var fastpathTV fastpathT - -type fastpathE struct { - rtid uintptr - rt reflect.Type - encfn func(*encFnInfo, reflect.Value) - decfn func(*decFnInfo, reflect.Value) -} - -type fastpathA [{{ .FastpathLen }}]fastpathE - -func (x *fastpathA) index(rtid uintptr) int { - // use binary search to grab the index (adapted from sort/search.go) - h, i, j := 0, 0, {{ .FastpathLen }} // len(x) - for i < j { - h = i + (j-i)/2 - if x[h].rtid < rtid { - i = h + 1 - } else { - j = h - } - } - if i < {{ .FastpathLen }} && x[i].rtid == rtid { - return i - } - return -1 -} - -type fastpathAslice []fastpathE - -func (x fastpathAslice) Len() int { return len(x) } -func (x fastpathAslice) Less(i, j int) bool { return x[i].rtid < x[j].rtid } -func (x fastpathAslice) Swap(i, j int) { x[i], x[j] = x[j], x[i] } - -var fastpathAV fastpathA - -// due to possible initialization loop error, make fastpath in an init() -func init() { - if !fastpathEnabled { - return - } - i := 0 - fn := func(v interface{}, fe func(*encFnInfo, reflect.Value), fd func(*decFnInfo, reflect.Value)) (f fastpathE) { - xrt := reflect.TypeOf(v) - xptr := reflect.ValueOf(xrt).Pointer() - fastpathAV[i] = fastpathE{xptr, xrt, fe, fd} - i++ - return - } - - {{range .Values}}{{if not .Primitive}}{{if not .MapKey }} - fn([]{{ .Elem }}(nil), (*encFnInfo).{{ .MethodNamePfx "fastpathEnc" false }}R, (*decFnInfo).{{ .MethodNamePfx "fastpathDec" false }}R){{end}}{{end}}{{end}} - - {{range .Values}}{{if not .Primitive}}{{if .MapKey }} - fn(map[{{ .MapKey }}]{{ .Elem }}(nil), (*encFnInfo).{{ .MethodNamePfx "fastpathEnc" false }}R, (*decFnInfo).{{ .MethodNamePfx "fastpathDec" false }}R){{end}}{{end}}{{end}} - - sort.Sort(fastpathAslice(fastpathAV[:])) -} - -// -- encode - -// -- -- fast path type switch -func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { -{{range .Values}}{{if not .Primitive}}{{if not .MapKey }} - case []{{ .Elem }}:{{else}} - case map[{{ .MapKey }}]{{ .Elem }}:{{end}} - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(v, fastpathCheckNilTrue, e){{if not .MapKey }} - case *[]{{ .Elem }}:{{else}} - case *map[{{ .MapKey }}]{{ .Elem }}:{{end}} - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(*v, fastpathCheckNilTrue, e) -{{end}}{{end}} - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { -{{range .Values}}{{if not .Primitive}}{{if not .MapKey }} - case []{{ .Elem }}: - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(v, fastpathCheckNilTrue, e) - case *[]{{ .Elem }}: - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(*v, fastpathCheckNilTrue, e) -{{end}}{{end}}{{end}} - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { -{{range .Values}}{{if not .Primitive}}{{if .MapKey }} - case map[{{ .MapKey }}]{{ .Elem }}: - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(v, fastpathCheckNilTrue, e) - case *map[{{ .MapKey }}]{{ .Elem }}: - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(*v, fastpathCheckNilTrue, e) -{{end}}{{end}}{{end}} - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -// -- -- fast path functions -{{range .Values}}{{if not .Primitive}}{{if not .MapKey }} - -func (f *encFnInfo) {{ .MethodNamePfx "fastpathEnc" false }}R(rv reflect.Value) { - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(rv.Interface().([]{{ .Elem }}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) {{ .MethodNamePfx "Enc" false }}V(v []{{ .Elem }}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeArrayStart(len(v)) - for _, v2 := range v { - if cr != nil { cr.sendContainerState(containerArrayElem) } - {{ encmd .Elem "v2"}} - } - if cr != nil { cr.sendContainerState(containerArrayEnd) }{{/* ee.EncodeEnd() */}} -} - -{{end}}{{end}}{{end}} - -{{range .Values}}{{if not .Primitive}}{{if .MapKey }} - -func (f *encFnInfo) {{ .MethodNamePfx "fastpathEnc" false }}R(rv reflect.Value) { - fastpathTV.{{ .MethodNamePfx "Enc" false }}V(rv.Interface().(map[{{ .MapKey }}]{{ .Elem }}), fastpathCheckNilFalse, f.e) -} -func (_ fastpathT) {{ .MethodNamePfx "Enc" false }}V(v map[{{ .MapKey }}]{{ .Elem }}, checkNil bool, e *Encoder) { - ee := e.e - cr := e.cr - if checkNil && v == nil { - ee.EncodeNil() - return - } - ee.EncodeMapStart(len(v)) - {{if eq .MapKey "string"}}asSymbols := e.h.AsSymbols&AsSymbolMapStringKeysFlag != 0 - {{end}}if e.h.Canonical { - {{if eq .MapKey "interface{}"}}{{/* out of band - */}}var mksv []byte = make([]byte, 0, len(v)*16) // temporary byte slice for the encoding - e2 := NewEncoderBytes(&mksv, e.hh) - v2 := make([]bytesI, len(v)) - var i, l int - var vp *bytesI {{/* put loop variables outside. seems currently needed for better perf */}} - for k2, _ := range v { - l = len(mksv) - e2.MustEncode(k2) - vp = &v2[i] - vp.v = mksv[l:] - vp.i = k2 - i++ - } - sort.Sort(bytesISlice(v2)) - for j := range v2 { - if cr != nil { cr.sendContainerState(containerMapKey) } - e.asis(v2[j].v) - if cr != nil { cr.sendContainerState(containerMapValue) } - e.encode(v[v2[j].i]) - } {{else}}{{ $x := sorttype .MapKey true}}v2 := make([]{{ $x }}, len(v)) - var i int - for k, _ := range v { - v2[i] = {{ $x }}(k) - i++ - } - sort.Sort({{ sorttype .MapKey false}}(v2)) - for _, k2 := range v2 { - if cr != nil { cr.sendContainerState(containerMapKey) } - {{if eq .MapKey "string"}}if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - }{{else}}{{ $y := printf "%s(k2)" .MapKey }}{{ encmd .MapKey $y }}{{end}} - if cr != nil { cr.sendContainerState(containerMapValue) } - {{ $y := printf "v[%s(k2)]" .MapKey }}{{ encmd .Elem $y }} - } {{end}} - } else { - for k2, v2 := range v { - if cr != nil { cr.sendContainerState(containerMapKey) } - {{if eq .MapKey "string"}}if asSymbols { - ee.EncodeSymbol(k2) - } else { - ee.EncodeString(c_UTF8, k2) - }{{else}}{{ encmd .MapKey "k2"}}{{end}} - if cr != nil { cr.sendContainerState(containerMapValue) } - {{ encmd .Elem "v2"}} - } - } - if cr != nil { cr.sendContainerState(containerMapEnd) }{{/* ee.EncodeEnd() */}} -} - -{{end}}{{end}}{{end}} - -// -- decode - -// -- -- fast path type switch -func fastpathDecodeTypeSwitch(iv interface{}, d *Decoder) bool { - if !fastpathEnabled { - return false - } - switch v := iv.(type) { -{{range .Values}}{{if not .Primitive}}{{if not .MapKey }} - case []{{ .Elem }}:{{else}} - case map[{{ .MapKey }}]{{ .Elem }}:{{end}} - fastpathTV.{{ .MethodNamePfx "Dec" false }}V(v, fastpathCheckNilFalse, false, d){{if not .MapKey }} - case *[]{{ .Elem }}:{{else}} - case *map[{{ .MapKey }}]{{ .Elem }}:{{end}} - v2, changed2 := fastpathTV.{{ .MethodNamePfx "Dec" false }}V(*v, fastpathCheckNilFalse, true, d) - if changed2 { - *v = v2 - } -{{end}}{{end}} - default: - _ = v // TODO: workaround https://github.com/golang/go/issues/12927 (remove after go 1.6 release) - return false - } - return true -} - -// -- -- fast path functions -{{range .Values}}{{if not .Primitive}}{{if not .MapKey }} -{{/* -Slices can change if they -- did not come from an array -- are addressable (from a ptr) -- are settable (e.g. contained in an interface{}) -*/}} -func (f *decFnInfo) {{ .MethodNamePfx "fastpathDec" false }}R(rv reflect.Value) { - array := f.seq == seqTypeArray - if !array && rv.CanAddr() { {{/* // CanSet => CanAddr + Exported */}} - vp := rv.Addr().Interface().(*[]{{ .Elem }}) - v, changed := fastpathTV.{{ .MethodNamePfx "Dec" false }}V(*vp, fastpathCheckNilFalse, !array, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().([]{{ .Elem }}) - fastpathTV.{{ .MethodNamePfx "Dec" false }}V(v, fastpathCheckNilFalse, false, f.d) - } -} - -func (f fastpathT) {{ .MethodNamePfx "Dec" false }}X(vp *[]{{ .Elem }}, checkNil bool, d *Decoder) { - v, changed := f.{{ .MethodNamePfx "Dec" false }}V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) {{ .MethodNamePfx "Dec" false }}V(v []{{ .Elem }}, checkNil bool, canChange bool, d *Decoder) (_ []{{ .Elem }}, changed bool) { - dd := d.d - {{/* // if dd.isContainerType(valueTypeNil) { dd.TryDecodeAsNil() */}} - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - slh, containerLenS := d.decSliceHelperStart() - if containerLenS == 0 { - if canChange { - if v == nil { - v = []{{ .Elem }}{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - - if containerLenS > 0 { - x2read := containerLenS - var xtrunc bool - if containerLenS > cap(v) { - if canChange { {{/* - // fast-path is for "basic" immutable types, so no need to copy them over - // s := make([]{{ .Elem }}, decInferLen(containerLenS, d.h.MaxInitLen)) - // copy(s, v[:cap(v)]) - // v = s */}} - var xlen int - xlen, xtrunc = decInferLen(containerLenS, d.h.MaxInitLen, {{ .Size }}) - if xtrunc { - if xlen <= cap(v) { - v = v[:xlen] - } else { - v = make([]{{ .Elem }}, xlen) - } - } else { - v = make([]{{ .Elem }}, xlen) - } - changed = true - } else { - d.arrayCannotExpand(len(v), containerLenS) - } - x2read = len(v) - } else if containerLenS != len(v) { - if canChange { - v = v[:containerLenS] - changed = true - } - } {{/* // all checks done. cannot go past len. */}} - j := 0 - for ; j < x2read; j++ { - slh.ElemContainerState(j) - {{ if eq .Elem "interface{}" }}d.decode(&v[j]){{ else }}v[j] = {{ decmd .Elem }}{{ end }} - } - if xtrunc { {{/* // means canChange=true, changed=true already. */}} - for ; j < containerLenS; j++ { - v = append(v, {{ zerocmd .Elem }}) - slh.ElemContainerState(j) - {{ if eq .Elem "interface{}" }}d.decode(&v[j]){{ else }}v[j] = {{ decmd .Elem }}{{ end }} - } - } else if !canChange { - for ; j < containerLenS; j++ { - slh.ElemContainerState(j) - d.swallow() - } - } - } else { - breakFound := dd.CheckBreak() {{/* check break first, so we can initialize v with a capacity of 4 if necessary */}} - if breakFound { - if canChange { - if v == nil { - v = []{{ .Elem }}{} - } else if len(v) != 0 { - v = v[:0] - } - changed = true - } - slh.End() - return - } - if cap(v) == 0 { - v = make([]{{ .Elem }}, 1, 4) - changed = true - } - j := 0 - for ; !breakFound; j++ { - if j >= len(v) { - if canChange { - v = append(v, {{ zerocmd .Elem }}) - changed = true - } else { - d.arrayCannotExpand(len(v), j+1) - } - } - slh.ElemContainerState(j) - if j < len(v) { {{/* // all checks done. cannot go past len. */}} - {{ if eq .Elem "interface{}" }}d.decode(&v[j]) - {{ else }}v[j] = {{ decmd .Elem }}{{ end }} - } else { - d.swallow() - } - breakFound = dd.CheckBreak() - } - if canChange && j < len(v) { - v = v[:j] - changed = true - } - } - slh.End() - return v, changed -} - -{{end}}{{end}}{{end}} - - -{{range .Values}}{{if not .Primitive}}{{if .MapKey }} -{{/* -Maps can change if they are -- addressable (from a ptr) -- settable (e.g. contained in an interface{}) -*/}} -func (f *decFnInfo) {{ .MethodNamePfx "fastpathDec" false }}R(rv reflect.Value) { - if rv.CanAddr() { - vp := rv.Addr().Interface().(*map[{{ .MapKey }}]{{ .Elem }}) - v, changed := fastpathTV.{{ .MethodNamePfx "Dec" false }}V(*vp, fastpathCheckNilFalse, true, f.d) - if changed { - *vp = v - } - } else { - v := rv.Interface().(map[{{ .MapKey }}]{{ .Elem }}) - fastpathTV.{{ .MethodNamePfx "Dec" false }}V(v, fastpathCheckNilFalse, false, f.d) - } -} -func (f fastpathT) {{ .MethodNamePfx "Dec" false }}X(vp *map[{{ .MapKey }}]{{ .Elem }}, checkNil bool, d *Decoder) { - v, changed := f.{{ .MethodNamePfx "Dec" false }}V(*vp, checkNil, true, d) - if changed { - *vp = v - } -} -func (_ fastpathT) {{ .MethodNamePfx "Dec" false }}V(v map[{{ .MapKey }}]{{ .Elem }}, checkNil bool, canChange bool, - d *Decoder) (_ map[{{ .MapKey }}]{{ .Elem }}, changed bool) { - dd := d.d - cr := d.cr - {{/* // if dd.isContainerType(valueTypeNil) {dd.TryDecodeAsNil() */}} - if checkNil && dd.TryDecodeAsNil() { - if v != nil { - changed = true - } - return nil, changed - } - - containerLen := dd.ReadMapStart() - if canChange && v == nil { - xlen, _ := decInferLen(containerLen, d.h.MaxInitLen, {{ .Size }}) - v = make(map[{{ .MapKey }}]{{ .Elem }}, xlen) - changed = true - } - {{ if eq .Elem "interface{}" }}mapGet := !d.h.MapValueReset && !d.h.InterfaceReset{{end}} - var mk {{ .MapKey }} - var mv {{ .Elem }} - if containerLen > 0 { - for j := 0; j < containerLen; j++ { - if cr != nil { cr.sendContainerState(containerMapKey) } - {{ if eq .MapKey "interface{}" }}mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) {{/* // maps cannot have []byte as key. switch to string. */}} - }{{ else }}mk = {{ decmd .MapKey }}{{ end }} - if cr != nil { cr.sendContainerState(containerMapValue) } - {{ if eq .Elem "interface{}" }}if mapGet { mv = v[mk] } else { mv = nil } - d.decode(&mv){{ else }}mv = {{ decmd .Elem }}{{ end }} - if v != nil { - v[mk] = mv - } - } - } else if containerLen < 0 { - for j := 0; !dd.CheckBreak(); j++ { - if cr != nil { cr.sendContainerState(containerMapKey) } - {{ if eq .MapKey "interface{}" }}mk = nil - d.decode(&mk) - if bv, bok := mk.([]byte); bok { - mk = d.string(bv) {{/* // maps cannot have []byte as key. switch to string. */}} - }{{ else }}mk = {{ decmd .MapKey }}{{ end }} - if cr != nil { cr.sendContainerState(containerMapValue) } - {{ if eq .Elem "interface{}" }}if mapGet { mv = v[mk] } else { mv = nil } - d.decode(&mv){{ else }}mv = {{ decmd .Elem }}{{ end }} - if v != nil { - v[mk] = mv - } - } - } - if cr != nil { cr.sendContainerState(containerMapEnd) } - return v, changed -} - -{{end}}{{end}}{{end}} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.not.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.not.go deleted file mode 100644 index d6f5f0c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/fast-path.not.go +++ /dev/null @@ -1,32 +0,0 @@ -// +build notfastpath - -package codec - -import "reflect" - -// The generated fast-path code is very large, and adds a few seconds to the build time. -// This causes test execution, execution of small tools which use codec, etc -// to take a long time. -// -// To mitigate, we now support the notfastpath tag. -// This tag disables fastpath during build, allowing for faster build, test execution, -// short-program runs, etc. - -func fastpathDecodeTypeSwitch(iv interface{}, d *Decoder) bool { return false } -func fastpathEncodeTypeSwitch(iv interface{}, e *Encoder) bool { return false } -func fastpathEncodeTypeSwitchSlice(iv interface{}, e *Encoder) bool { return false } -func fastpathEncodeTypeSwitchMap(iv interface{}, e *Encoder) bool { return false } - -type fastpathT struct{} -type fastpathE struct { - rtid uintptr - rt reflect.Type - encfn func(*encFnInfo, reflect.Value) - decfn func(*decFnInfo, reflect.Value) -} -type fastpathA [0]fastpathE - -func (x fastpathA) index(rtid uintptr) int { return -1 } - -var fastpathAV fastpathA -var fastpathTV fastpathT diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl deleted file mode 100644 index 2caae5b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-array.go.tmpl +++ /dev/null @@ -1,101 +0,0 @@ -{{var "v"}} := {{if not isArray}}*{{end}}{{ .Varname }} -{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}} -var {{var "c"}} bool {{/* // changed */}} -if {{var "l"}} == 0 { - {{if isSlice }}if {{var "v"}} == nil { - {{var "v"}} = []{{ .Typ }}{} - {{var "c"}} = true - } else if len({{var "v"}}) != 0 { - {{var "v"}} = {{var "v"}}[:0] - {{var "c"}} = true - } {{end}} {{if isChan }}if {{var "v"}} == nil { - {{var "v"}} = make({{ .CTyp }}, 0) - {{var "c"}} = true - } {{end}} -} else if {{var "l"}} > 0 { - {{if isChan }}if {{var "v"}} == nil { - {{var "rl"}}, _ = z.DecInferLen({{var "l"}}, z.DecBasicHandle().MaxInitLen, {{ .Size }}) - {{var "v"}} = make({{ .CTyp }}, {{var "rl"}}) - {{var "c"}} = true - } - for {{var "r"}} := 0; {{var "r"}} < {{var "l"}}; {{var "r"}}++ { - {{var "h"}}.ElemContainerState({{var "r"}}) - var {{var "t"}} {{ .Typ }} - {{ $x := printf "%st%s" .TempVar .Rand }}{{ decLineVar $x }} - {{var "v"}} <- {{var "t"}} - } - {{ else }} var {{var "rr"}}, {{var "rl"}} int {{/* // num2read, length of slice/array/chan */}} - var {{var "rt"}} bool {{/* truncated */}} - if {{var "l"}} > cap({{var "v"}}) { - {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "l"}}) - {{ else }}{{if not .Immutable }} - {{var "rg"}} := len({{var "v"}}) > 0 - {{var "v2"}} := {{var "v"}} {{end}} - {{var "rl"}}, {{var "rt"}} = z.DecInferLen({{var "l"}}, z.DecBasicHandle().MaxInitLen, {{ .Size }}) - if {{var "rt"}} { - if {{var "rl"}} <= cap({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "rl"}}] - } else { - {{var "v"}} = make([]{{ .Typ }}, {{var "rl"}}) - } - } else { - {{var "v"}} = make([]{{ .Typ }}, {{var "rl"}}) - } - {{var "c"}} = true - {{var "rr"}} = len({{var "v"}}) {{if not .Immutable }} - if {{var "rg"}} { copy({{var "v"}}, {{var "v2"}}) } {{end}} {{end}}{{/* end not Immutable, isArray */}} - } {{if isSlice }} else if {{var "l"}} != len({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "l"}}] - {{var "c"}} = true - } {{end}} {{/* end isSlice:47 */}} - {{var "j"}} := 0 - for ; {{var "j"}} < {{var "rr"}} ; {{var "j"}}++ { - {{var "h"}}.ElemContainerState({{var "j"}}) - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } - {{if isArray }}for ; {{var "j"}} < {{var "l"}} ; {{var "j"}}++ { - {{var "h"}}.ElemContainerState({{var "j"}}) - z.DecSwallow() - } - {{ else }}if {{var "rt"}} { - for ; {{var "j"}} < {{var "l"}} ; {{var "j"}}++ { - {{var "v"}} = append({{var "v"}}, {{ zero}}) - {{var "h"}}.ElemContainerState({{var "j"}}) - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } - } {{end}} {{/* end isArray:56 */}} - {{end}} {{/* end isChan:16 */}} -} else { {{/* len < 0 */}} - {{var "j"}} := 0 - for ; !r.CheckBreak(); {{var "j"}}++ { - {{if isChan }} - {{var "h"}}.ElemContainerState({{var "j"}}) - var {{var "t"}} {{ .Typ }} - {{ $x := printf "%st%s" .TempVar .Rand }}{{ decLineVar $x }} - {{var "v"}} <- {{var "t"}} - {{ else }} - if {{var "j"}} >= len({{var "v"}}) { - {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "j"}}+1) - {{ else }}{{var "v"}} = append({{var "v"}}, {{zero}})// var {{var "z"}} {{ .Typ }} - {{var "c"}} = true {{end}} - } - {{var "h"}}.ElemContainerState({{var "j"}}) - if {{var "j"}} < len({{var "v"}}) { - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } else { - z.DecSwallow() - } - {{end}} - } - {{if isSlice }}if {{var "j"}} < len({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "j"}}] - {{var "c"}} = true - } else if {{var "j"}} == 0 && {{var "v"}} == nil { - {{var "v"}} = []{{ .Typ }}{} - {{var "c"}} = true - }{{end}} -} -{{var "h"}}.End() -{{if not isArray }}if {{var "c"}} { - *{{ .Varname }} = {{var "v"}} -}{{end}} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-map.go.tmpl b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-map.go.tmpl deleted file mode 100644 index 77400e0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-dec-map.go.tmpl +++ /dev/null @@ -1,58 +0,0 @@ -{{var "v"}} := *{{ .Varname }} -{{var "l"}} := r.ReadMapStart() -{{var "bh"}} := z.DecBasicHandle() -if {{var "v"}} == nil { - {{var "rl"}}, _ := z.DecInferLen({{var "l"}}, {{var "bh"}}.MaxInitLen, {{ .Size }}) - {{var "v"}} = make(map[{{ .KTyp }}]{{ .Typ }}, {{var "rl"}}) - *{{ .Varname }} = {{var "v"}} -} -var {{var "mk"}} {{ .KTyp }} -var {{var "mv"}} {{ .Typ }} -var {{var "mg"}} {{if decElemKindPtr}}, {{var "ms"}}, {{var "mok"}}{{end}} bool -if {{var "bh"}}.MapValueReset { - {{if decElemKindPtr}}{{var "mg"}} = true - {{else if decElemKindIntf}}if !{{var "bh"}}.InterfaceReset { {{var "mg"}} = true } - {{else if not decElemKindImmutable}}{{var "mg"}} = true - {{end}} } -if {{var "l"}} > 0 { -for {{var "j"}} := 0; {{var "j"}} < {{var "l"}}; {{var "j"}}++ { - z.DecSendContainerState(codecSelfer_containerMapKey{{ .Sfx }}) - {{ $x := printf "%vmk%v" .TempVar .Rand }}{{ decLineVarK $x }} -{{ if eq .KTyp "interface{}" }}{{/* // special case if a byte array. */}}if {{var "bv"}}, {{var "bok"}} := {{var "mk"}}.([]byte); {{var "bok"}} { - {{var "mk"}} = string({{var "bv"}}) - }{{ end }}{{if decElemKindPtr}} - {{var "ms"}} = true{{end}} - if {{var "mg"}} { - {{if decElemKindPtr}}{{var "mv"}}, {{var "mok"}} = {{var "v"}}[{{var "mk"}}] - if {{var "mok"}} { - {{var "ms"}} = false - } {{else}}{{var "mv"}} = {{var "v"}}[{{var "mk"}}] {{end}} - } {{if not decElemKindImmutable}}else { {{var "mv"}} = {{decElemZero}} }{{end}} - z.DecSendContainerState(codecSelfer_containerMapValue{{ .Sfx }}) - {{ $x := printf "%vmv%v" .TempVar .Rand }}{{ decLineVar $x }} - if {{if decElemKindPtr}} {{var "ms"}} && {{end}} {{var "v"}} != nil { - {{var "v"}}[{{var "mk"}}] = {{var "mv"}} - } -} -} else if {{var "l"}} < 0 { -for {{var "j"}} := 0; !r.CheckBreak(); {{var "j"}}++ { - z.DecSendContainerState(codecSelfer_containerMapKey{{ .Sfx }}) - {{ $x := printf "%vmk%v" .TempVar .Rand }}{{ decLineVarK $x }} -{{ if eq .KTyp "interface{}" }}{{/* // special case if a byte array. */}}if {{var "bv"}}, {{var "bok"}} := {{var "mk"}}.([]byte); {{var "bok"}} { - {{var "mk"}} = string({{var "bv"}}) - }{{ end }}{{if decElemKindPtr}} - {{var "ms"}} = true {{ end }} - if {{var "mg"}} { - {{if decElemKindPtr}}{{var "mv"}}, {{var "mok"}} = {{var "v"}}[{{var "mk"}}] - if {{var "mok"}} { - {{var "ms"}} = false - } {{else}}{{var "mv"}} = {{var "v"}}[{{var "mk"}}] {{end}} - } {{if not decElemKindImmutable}}else { {{var "mv"}} = {{decElemZero}} }{{end}} - z.DecSendContainerState(codecSelfer_containerMapValue{{ .Sfx }}) - {{ $x := printf "%vmv%v" .TempVar .Rand }}{{ decLineVar $x }} - if {{if decElemKindPtr}} {{var "ms"}} && {{end}} {{var "v"}} != nil { - {{var "v"}}[{{var "mk"}}] = {{var "mv"}} - } -} -} // else len==0: TODO: Should we clear map entries? -z.DecSendContainerState(codecSelfer_containerMapEnd{{ .Sfx }}) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.generated.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.generated.go deleted file mode 100644 index 22bce77..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.generated.go +++ /dev/null @@ -1,233 +0,0 @@ -// //+build ignore - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED from gen-helper.go.tmpl -// ************************************************************ - -package codec - -import ( - "encoding" - "reflect" -) - -// This file is used to generate helper code for codecgen. -// The values here i.e. genHelper(En|De)coder are not to be used directly by -// library users. They WILL change continously and without notice. -// -// To help enforce this, we create an unexported type with exported members. -// The only way to get the type is via the one exported type that we control (somewhat). -// -// When static codecs are created for types, they will use this value -// to perform encoding or decoding of primitives or known slice or map types. - -// GenHelperEncoder is exported so that it can be used externally by codecgen. -// Library users: DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE. -func GenHelperEncoder(e *Encoder) (genHelperEncoder, encDriver) { - return genHelperEncoder{e: e}, e.e -} - -// GenHelperDecoder is exported so that it can be used externally by codecgen. -// Library users: DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE. -func GenHelperDecoder(d *Decoder) (genHelperDecoder, decDriver) { - return genHelperDecoder{d: d}, d.d -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -type genHelperEncoder struct { - e *Encoder - F fastpathT -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -type genHelperDecoder struct { - d *Decoder - F fastpathT -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBasicHandle() *BasicHandle { - return f.e.h -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBinary() bool { - return f.e.be // f.e.hh.isBinaryEncoding() -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncFallback(iv interface{}) { - // println(">>>>>>>>> EncFallback") - f.e.encodeI(iv, false, false) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncTextMarshal(iv encoding.TextMarshaler) { - bs, fnerr := iv.MarshalText() - f.e.marshal(bs, fnerr, false, c_UTF8) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncJSONMarshal(iv jsonMarshaler) { - bs, fnerr := iv.MarshalJSON() - f.e.marshal(bs, fnerr, true, c_UTF8) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBinaryMarshal(iv encoding.BinaryMarshaler) { - bs, fnerr := iv.MarshalBinary() - f.e.marshal(bs, fnerr, false, c_RAW) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) TimeRtidIfBinc() uintptr { - if _, ok := f.e.hh.(*BincHandle); ok { - return timeTypId - } - return 0 -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) IsJSONHandle() bool { - return f.e.js -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) HasExtensions() bool { - return len(f.e.h.extHandle) != 0 -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncExt(v interface{}) (r bool) { - rt := reflect.TypeOf(v) - if rt.Kind() == reflect.Ptr { - rt = rt.Elem() - } - rtid := reflect.ValueOf(rt).Pointer() - if xfFn := f.e.h.getExt(rtid); xfFn != nil { - f.e.e.EncodeExt(v, xfFn.tag, xfFn.ext, f.e) - return true - } - return false -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncSendContainerState(c containerState) { - if f.e.cr != nil { - f.e.cr.sendContainerState(c) - } -} - -// ---------------- DECODER FOLLOWS ----------------- - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBasicHandle() *BasicHandle { - return f.d.h -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBinary() bool { - return f.d.be // f.d.hh.isBinaryEncoding() -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSwallow() { - f.d.swallow() -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecScratchBuffer() []byte { - return f.d.b[:] -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecFallback(iv interface{}, chkPtr bool) { - // println(">>>>>>>>> DecFallback") - f.d.decodeI(iv, chkPtr, false, false, false) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSliceHelperStart() (decSliceHelper, int) { - return f.d.decSliceHelperStart() -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecStructFieldNotFound(index int, name string) { - f.d.structFieldNotFound(index, name) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecArrayCannotExpand(sliceLen, streamLen int) { - f.d.arrayCannotExpand(sliceLen, streamLen) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecTextUnmarshal(tm encoding.TextUnmarshaler) { - fnerr := tm.UnmarshalText(f.d.d.DecodeBytes(f.d.b[:], true, true)) - if fnerr != nil { - panic(fnerr) - } -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecJSONUnmarshal(tm jsonUnmarshaler) { - // bs := f.dd.DecodeBytes(f.d.b[:], true, true) - // grab the bytes to be read, as UnmarshalJSON needs the full JSON so as to unmarshal it itself. - fnerr := tm.UnmarshalJSON(f.d.nextValueBytes()) - if fnerr != nil { - panic(fnerr) - } -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBinaryUnmarshal(bm encoding.BinaryUnmarshaler) { - fnerr := bm.UnmarshalBinary(f.d.d.DecodeBytes(nil, false, true)) - if fnerr != nil { - panic(fnerr) - } -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) TimeRtidIfBinc() uintptr { - if _, ok := f.d.hh.(*BincHandle); ok { - return timeTypId - } - return 0 -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) IsJSONHandle() bool { - return f.d.js -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) HasExtensions() bool { - return len(f.d.h.extHandle) != 0 -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecExt(v interface{}) (r bool) { - rt := reflect.TypeOf(v).Elem() - rtid := reflect.ValueOf(rt).Pointer() - if xfFn := f.d.h.getExt(rtid); xfFn != nil { - f.d.d.DecodeExt(v, xfFn.tag, xfFn.ext) - return true - } - return false -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecInferLen(clen, maxlen, unit int) (rvlen int, truncated bool) { - return decInferLen(clen, maxlen, unit) -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSendContainerState(c containerState) { - if f.d.cr != nil { - f.d.cr.sendContainerState(c) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl deleted file mode 100644 index 3195857..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen-helper.go.tmpl +++ /dev/null @@ -1,364 +0,0 @@ -// //+build ignore - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED from gen-helper.go.tmpl -// ************************************************************ - -package codec - -import ( - "encoding" - "reflect" -) - -// This file is used to generate helper code for codecgen. -// The values here i.e. genHelper(En|De)coder are not to be used directly by -// library users. They WILL change continously and without notice. -// -// To help enforce this, we create an unexported type with exported members. -// The only way to get the type is via the one exported type that we control (somewhat). -// -// When static codecs are created for types, they will use this value -// to perform encoding or decoding of primitives or known slice or map types. - -// GenHelperEncoder is exported so that it can be used externally by codecgen. -// Library users: DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE. -func GenHelperEncoder(e *Encoder) (genHelperEncoder, encDriver) { - return genHelperEncoder{e:e}, e.e -} - -// GenHelperDecoder is exported so that it can be used externally by codecgen. -// Library users: DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE. -func GenHelperDecoder(d *Decoder) (genHelperDecoder, decDriver) { - return genHelperDecoder{d:d}, d.d -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -type genHelperEncoder struct { - e *Encoder - F fastpathT -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -type genHelperDecoder struct { - d *Decoder - F fastpathT -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBasicHandle() *BasicHandle { - return f.e.h -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBinary() bool { - return f.e.be // f.e.hh.isBinaryEncoding() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncFallback(iv interface{}) { - // println(">>>>>>>>> EncFallback") - f.e.encodeI(iv, false, false) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncTextMarshal(iv encoding.TextMarshaler) { - bs, fnerr := iv.MarshalText() - f.e.marshal(bs, fnerr, false, c_UTF8) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncJSONMarshal(iv jsonMarshaler) { - bs, fnerr := iv.MarshalJSON() - f.e.marshal(bs, fnerr, true, c_UTF8) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBinaryMarshal(iv encoding.BinaryMarshaler) { - bs, fnerr := iv.MarshalBinary() - f.e.marshal(bs, fnerr, false, c_RAW) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) TimeRtidIfBinc() uintptr { - if _, ok := f.e.hh.(*BincHandle); ok { - return timeTypId - } - return 0 -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) IsJSONHandle() bool { - return f.e.js -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) HasExtensions() bool { - return len(f.e.h.extHandle) != 0 -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncExt(v interface{}) (r bool) { - rt := reflect.TypeOf(v) - if rt.Kind() == reflect.Ptr { - rt = rt.Elem() - } - rtid := reflect.ValueOf(rt).Pointer() - if xfFn := f.e.h.getExt(rtid); xfFn != nil { - f.e.e.EncodeExt(v, xfFn.tag, xfFn.ext, f.e) - return true - } - return false -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncSendContainerState(c containerState) { - if f.e.cr != nil { - f.e.cr.sendContainerState(c) - } -} - -// ---------------- DECODER FOLLOWS ----------------- - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBasicHandle() *BasicHandle { - return f.d.h -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBinary() bool { - return f.d.be // f.d.hh.isBinaryEncoding() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSwallow() { - f.d.swallow() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecScratchBuffer() []byte { - return f.d.b[:] -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecFallback(iv interface{}, chkPtr bool) { - // println(">>>>>>>>> DecFallback") - f.d.decodeI(iv, chkPtr, false, false, false) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSliceHelperStart() (decSliceHelper, int) { - return f.d.decSliceHelperStart() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecStructFieldNotFound(index int, name string) { - f.d.structFieldNotFound(index, name) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecArrayCannotExpand(sliceLen, streamLen int) { - f.d.arrayCannotExpand(sliceLen, streamLen) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecTextUnmarshal(tm encoding.TextUnmarshaler) { - fnerr := tm.UnmarshalText(f.d.d.DecodeBytes(f.d.b[:], true, true)) - if fnerr != nil { - panic(fnerr) - } -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecJSONUnmarshal(tm jsonUnmarshaler) { - // bs := f.dd.DecodeBytes(f.d.b[:], true, true) - // grab the bytes to be read, as UnmarshalJSON needs the full JSON so as to unmarshal it itself. - fnerr := tm.UnmarshalJSON(f.d.nextValueBytes()) - if fnerr != nil { - panic(fnerr) - } -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBinaryUnmarshal(bm encoding.BinaryUnmarshaler) { - fnerr := bm.UnmarshalBinary(f.d.d.DecodeBytes(nil, false, true)) - if fnerr != nil { - panic(fnerr) - } -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) TimeRtidIfBinc() uintptr { - if _, ok := f.d.hh.(*BincHandle); ok { - return timeTypId - } - return 0 -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) IsJSONHandle() bool { - return f.d.js -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) HasExtensions() bool { - return len(f.d.h.extHandle) != 0 -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecExt(v interface{}) (r bool) { - rt := reflect.TypeOf(v).Elem() - rtid := reflect.ValueOf(rt).Pointer() - if xfFn := f.d.h.getExt(rtid); xfFn != nil { - f.d.d.DecodeExt(v, xfFn.tag, xfFn.ext) - return true - } - return false -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecInferLen(clen, maxlen, unit int) (rvlen int, truncated bool) { - return decInferLen(clen, maxlen, unit) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecSendContainerState(c containerState) { - if f.d.cr != nil { - f.d.cr.sendContainerState(c) - } -} - -{{/* - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncDriver() encDriver { - return f.e.e -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecDriver() decDriver { - return f.d.d -} - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncNil() { - f.e.e.EncodeNil() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncBytes(v []byte) { - f.e.e.EncodeStringBytes(c_RAW, v) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncArrayStart(length int) { - f.e.e.EncodeArrayStart(length) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncArrayEnd() { - f.e.e.EncodeArrayEnd() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncArrayEntrySeparator() { - f.e.e.EncodeArrayEntrySeparator() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncMapStart(length int) { - f.e.e.EncodeMapStart(length) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncMapEnd() { - f.e.e.EncodeMapEnd() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncMapEntrySeparator() { - f.e.e.EncodeMapEntrySeparator() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) EncMapKVSeparator() { - f.e.e.EncodeMapKVSeparator() -} - -// --------- - -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecBytes(v *[]byte) { - *v = f.d.d.DecodeBytes(*v) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecTryNil() bool { - return f.d.d.TryDecodeAsNil() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecContainerIsNil() (b bool) { - return f.d.d.IsContainerType(valueTypeNil) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecContainerIsMap() (b bool) { - return f.d.d.IsContainerType(valueTypeMap) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecContainerIsArray() (b bool) { - return f.d.d.IsContainerType(valueTypeArray) -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecCheckBreak() bool { - return f.d.d.CheckBreak() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecMapStart() int { - return f.d.d.ReadMapStart() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecArrayStart() int { - return f.d.d.ReadArrayStart() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecMapEnd() { - f.d.d.ReadMapEnd() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecArrayEnd() { - f.d.d.ReadArrayEnd() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecArrayEntrySeparator() { - f.d.d.ReadArrayEntrySeparator() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecMapEntrySeparator() { - f.d.d.ReadMapEntrySeparator() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) DecMapKVSeparator() { - f.d.d.ReadMapKVSeparator() -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) ReadStringAsBytes(bs []byte) []byte { - return f.d.d.DecodeStringAsBytes(bs) -} - - -// -- encode calls (primitives) -{{range .Values}}{{if .Primitive }}{{if ne .Primitive "interface{}" }} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) {{ .MethodNamePfx "Enc" true }}(v {{ .Primitive }}) { - ee := f.e.e - {{ encmd .Primitive "v" }} -} -{{ end }}{{ end }}{{ end }} - -// -- decode calls (primitives) -{{range .Values}}{{if .Primitive }}{{if ne .Primitive "interface{}" }} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) {{ .MethodNamePfx "Dec" true }}(vp *{{ .Primitive }}) { - dd := f.d.d - *vp = {{ decmd .Primitive }} -} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperDecoder) {{ .MethodNamePfx "Read" true }}() (v {{ .Primitive }}) { - dd := f.d.d - v = {{ decmd .Primitive }} - return -} -{{ end }}{{ end }}{{ end }} - - -// -- encode calls (slices/maps) -{{range .Values}}{{if not .Primitive }}{{if .Slice }} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) {{ .MethodNamePfx "Enc" false }}(v []{{ .Elem }}) { {{ else }} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -func (f genHelperEncoder) {{ .MethodNamePfx "Enc" false }}(v map[{{ .MapKey }}]{{ .Elem }}) { {{end}} - f.F.{{ .MethodNamePfx "Enc" false }}V(v, false, f.e) -} -{{ end }}{{ end }} - -// -- decode calls (slices/maps) -{{range .Values}}{{if not .Primitive }} -// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE* -{{if .Slice }}func (f genHelperDecoder) {{ .MethodNamePfx "Dec" false }}(vp *[]{{ .Elem }}) { -{{else}}func (f genHelperDecoder) {{ .MethodNamePfx "Dec" false }}(vp *map[{{ .MapKey }}]{{ .Elem }}) { {{end}} - v, changed := f.F.{{ .MethodNamePfx "Dec" false }}V(*vp, false, true, f.d) - if changed { - *vp = v - } -} -{{ end }}{{ end }} -*/}} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.generated.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.generated.go deleted file mode 100644 index fb6f4b8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.generated.go +++ /dev/null @@ -1,172 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -// DO NOT EDIT. THIS FILE IS AUTO-GENERATED FROM gen-dec-(map|array).go.tmpl - -const genDecMapTmpl = ` -{{var "v"}} := *{{ .Varname }} -{{var "l"}} := r.ReadMapStart() -{{var "bh"}} := z.DecBasicHandle() -if {{var "v"}} == nil { - {{var "rl"}}, _ := z.DecInferLen({{var "l"}}, {{var "bh"}}.MaxInitLen, {{ .Size }}) - {{var "v"}} = make(map[{{ .KTyp }}]{{ .Typ }}, {{var "rl"}}) - *{{ .Varname }} = {{var "v"}} -} -var {{var "mk"}} {{ .KTyp }} -var {{var "mv"}} {{ .Typ }} -var {{var "mg"}} {{if decElemKindPtr}}, {{var "ms"}}, {{var "mok"}}{{end}} bool -if {{var "bh"}}.MapValueReset { - {{if decElemKindPtr}}{{var "mg"}} = true - {{else if decElemKindIntf}}if !{{var "bh"}}.InterfaceReset { {{var "mg"}} = true } - {{else if not decElemKindImmutable}}{{var "mg"}} = true - {{end}} } -if {{var "l"}} > 0 { -for {{var "j"}} := 0; {{var "j"}} < {{var "l"}}; {{var "j"}}++ { - z.DecSendContainerState(codecSelfer_containerMapKey{{ .Sfx }}) - {{ $x := printf "%vmk%v" .TempVar .Rand }}{{ decLineVarK $x }} -{{ if eq .KTyp "interface{}" }}{{/* // special case if a byte array. */}}if {{var "bv"}}, {{var "bok"}} := {{var "mk"}}.([]byte); {{var "bok"}} { - {{var "mk"}} = string({{var "bv"}}) - }{{ end }}{{if decElemKindPtr}} - {{var "ms"}} = true{{end}} - if {{var "mg"}} { - {{if decElemKindPtr}}{{var "mv"}}, {{var "mok"}} = {{var "v"}}[{{var "mk"}}] - if {{var "mok"}} { - {{var "ms"}} = false - } {{else}}{{var "mv"}} = {{var "v"}}[{{var "mk"}}] {{end}} - } {{if not decElemKindImmutable}}else { {{var "mv"}} = {{decElemZero}} }{{end}} - z.DecSendContainerState(codecSelfer_containerMapValue{{ .Sfx }}) - {{ $x := printf "%vmv%v" .TempVar .Rand }}{{ decLineVar $x }} - if {{if decElemKindPtr}} {{var "ms"}} && {{end}} {{var "v"}} != nil { - {{var "v"}}[{{var "mk"}}] = {{var "mv"}} - } -} -} else if {{var "l"}} < 0 { -for {{var "j"}} := 0; !r.CheckBreak(); {{var "j"}}++ { - z.DecSendContainerState(codecSelfer_containerMapKey{{ .Sfx }}) - {{ $x := printf "%vmk%v" .TempVar .Rand }}{{ decLineVarK $x }} -{{ if eq .KTyp "interface{}" }}{{/* // special case if a byte array. */}}if {{var "bv"}}, {{var "bok"}} := {{var "mk"}}.([]byte); {{var "bok"}} { - {{var "mk"}} = string({{var "bv"}}) - }{{ end }}{{if decElemKindPtr}} - {{var "ms"}} = true {{ end }} - if {{var "mg"}} { - {{if decElemKindPtr}}{{var "mv"}}, {{var "mok"}} = {{var "v"}}[{{var "mk"}}] - if {{var "mok"}} { - {{var "ms"}} = false - } {{else}}{{var "mv"}} = {{var "v"}}[{{var "mk"}}] {{end}} - } {{if not decElemKindImmutable}}else { {{var "mv"}} = {{decElemZero}} }{{end}} - z.DecSendContainerState(codecSelfer_containerMapValue{{ .Sfx }}) - {{ $x := printf "%vmv%v" .TempVar .Rand }}{{ decLineVar $x }} - if {{if decElemKindPtr}} {{var "ms"}} && {{end}} {{var "v"}} != nil { - {{var "v"}}[{{var "mk"}}] = {{var "mv"}} - } -} -} // else len==0: TODO: Should we clear map entries? -z.DecSendContainerState(codecSelfer_containerMapEnd{{ .Sfx }}) -` - -const genDecListTmpl = ` -{{var "v"}} := {{if not isArray}}*{{end}}{{ .Varname }} -{{var "h"}}, {{var "l"}} := z.DecSliceHelperStart() {{/* // helper, containerLenS */}} -var {{var "c"}} bool {{/* // changed */}} -if {{var "l"}} == 0 { - {{if isSlice }}if {{var "v"}} == nil { - {{var "v"}} = []{{ .Typ }}{} - {{var "c"}} = true - } else if len({{var "v"}}) != 0 { - {{var "v"}} = {{var "v"}}[:0] - {{var "c"}} = true - } {{end}} {{if isChan }}if {{var "v"}} == nil { - {{var "v"}} = make({{ .CTyp }}, 0) - {{var "c"}} = true - } {{end}} -} else if {{var "l"}} > 0 { - {{if isChan }}if {{var "v"}} == nil { - {{var "rl"}}, _ = z.DecInferLen({{var "l"}}, z.DecBasicHandle().MaxInitLen, {{ .Size }}) - {{var "v"}} = make({{ .CTyp }}, {{var "rl"}}) - {{var "c"}} = true - } - for {{var "r"}} := 0; {{var "r"}} < {{var "l"}}; {{var "r"}}++ { - {{var "h"}}.ElemContainerState({{var "r"}}) - var {{var "t"}} {{ .Typ }} - {{ $x := printf "%st%s" .TempVar .Rand }}{{ decLineVar $x }} - {{var "v"}} <- {{var "t"}} - } - {{ else }} var {{var "rr"}}, {{var "rl"}} int {{/* // num2read, length of slice/array/chan */}} - var {{var "rt"}} bool {{/* truncated */}} - if {{var "l"}} > cap({{var "v"}}) { - {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "l"}}) - {{ else }}{{if not .Immutable }} - {{var "rg"}} := len({{var "v"}}) > 0 - {{var "v2"}} := {{var "v"}} {{end}} - {{var "rl"}}, {{var "rt"}} = z.DecInferLen({{var "l"}}, z.DecBasicHandle().MaxInitLen, {{ .Size }}) - if {{var "rt"}} { - if {{var "rl"}} <= cap({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "rl"}}] - } else { - {{var "v"}} = make([]{{ .Typ }}, {{var "rl"}}) - } - } else { - {{var "v"}} = make([]{{ .Typ }}, {{var "rl"}}) - } - {{var "c"}} = true - {{var "rr"}} = len({{var "v"}}) {{if not .Immutable }} - if {{var "rg"}} { copy({{var "v"}}, {{var "v2"}}) } {{end}} {{end}}{{/* end not Immutable, isArray */}} - } {{if isSlice }} else if {{var "l"}} != len({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "l"}}] - {{var "c"}} = true - } {{end}} {{/* end isSlice:47 */}} - {{var "j"}} := 0 - for ; {{var "j"}} < {{var "rr"}} ; {{var "j"}}++ { - {{var "h"}}.ElemContainerState({{var "j"}}) - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } - {{if isArray }}for ; {{var "j"}} < {{var "l"}} ; {{var "j"}}++ { - {{var "h"}}.ElemContainerState({{var "j"}}) - z.DecSwallow() - } - {{ else }}if {{var "rt"}} { - for ; {{var "j"}} < {{var "l"}} ; {{var "j"}}++ { - {{var "v"}} = append({{var "v"}}, {{ zero}}) - {{var "h"}}.ElemContainerState({{var "j"}}) - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } - } {{end}} {{/* end isArray:56 */}} - {{end}} {{/* end isChan:16 */}} -} else { {{/* len < 0 */}} - {{var "j"}} := 0 - for ; !r.CheckBreak(); {{var "j"}}++ { - {{if isChan }} - {{var "h"}}.ElemContainerState({{var "j"}}) - var {{var "t"}} {{ .Typ }} - {{ $x := printf "%st%s" .TempVar .Rand }}{{ decLineVar $x }} - {{var "v"}} <- {{var "t"}} - {{ else }} - if {{var "j"}} >= len({{var "v"}}) { - {{if isArray }}z.DecArrayCannotExpand(len({{var "v"}}), {{var "j"}}+1) - {{ else }}{{var "v"}} = append({{var "v"}}, {{zero}})// var {{var "z"}} {{ .Typ }} - {{var "c"}} = true {{end}} - } - {{var "h"}}.ElemContainerState({{var "j"}}) - if {{var "j"}} < len({{var "v"}}) { - {{ $x := printf "%[1]vv%[2]v[%[1]vj%[2]v]" .TempVar .Rand }}{{ decLineVar $x }} - } else { - z.DecSwallow() - } - {{end}} - } - {{if isSlice }}if {{var "j"}} < len({{var "v"}}) { - {{var "v"}} = {{var "v"}}[:{{var "j"}}] - {{var "c"}} = true - } else if {{var "j"}} == 0 && {{var "v"}} == nil { - {{var "v"}} = []{{ .Typ }}{} - {{var "c"}} = true - }{{end}} -} -{{var "h"}}.End() -{{if not isArray }}if {{var "c"}} { - *{{ .Varname }} = {{var "v"}} -}{{end}} -` - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.go deleted file mode 100644 index a075e7c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/gen.go +++ /dev/null @@ -1,1920 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "bytes" - "encoding/base64" - "errors" - "fmt" - "go/format" - "io" - "io/ioutil" - "math/rand" - "os" - "reflect" - "regexp" - "sort" - "strconv" - "strings" - "sync" - "text/template" - "time" -) - -// --------------------------------------------------- -// codecgen supports the full cycle of reflection-based codec: -// - RawExt -// - Builtins -// - Extensions -// - (Binary|Text|JSON)(Unm|M)arshal -// - generic by-kind -// -// This means that, for dynamic things, we MUST use reflection to at least get the reflect.Type. -// In those areas, we try to only do reflection or interface-conversion when NECESSARY: -// - Extensions, only if Extensions are configured. -// -// However, codecgen doesn't support the following: -// - Canonical option. (codecgen IGNORES it currently) -// This is just because it has not been implemented. -// -// During encode/decode, Selfer takes precedence. -// A type implementing Selfer will know how to encode/decode itself statically. -// -// The following field types are supported: -// array: [n]T -// slice: []T -// map: map[K]V -// primitive: [u]int[n], float(32|64), bool, string -// struct -// -// --------------------------------------------------- -// Note that a Selfer cannot call (e|d).(En|De)code on itself, -// as this will cause a circular reference, as (En|De)code will call Selfer methods. -// Any type that implements Selfer must implement completely and not fallback to (En|De)code. -// -// In addition, code in this file manages the generation of fast-path implementations of -// encode/decode of slices/maps of primitive keys/values. -// -// Users MUST re-generate their implementations whenever the code shape changes. -// The generated code will panic if it was generated with a version older than the supporting library. -// --------------------------------------------------- -// -// codec framework is very feature rich. -// When encoding or decoding into an interface, it depends on the runtime type of the interface. -// The type of the interface may be a named type, an extension, etc. -// Consequently, we fallback to runtime codec for encoding/decoding interfaces. -// In addition, we fallback for any value which cannot be guaranteed at runtime. -// This allows us support ANY value, including any named types, specifically those which -// do not implement our interfaces (e.g. Selfer). -// -// This explains some slowness compared to other code generation codecs (e.g. msgp). -// This reduction in speed is only seen when your refers to interfaces, -// e.g. type T struct { A interface{}; B []interface{}; C map[string]interface{} } -// -// codecgen will panic if the file was generated with an old version of the library in use. -// -// Note: -// It was a concious decision to have gen.go always explicitly call EncodeNil or TryDecodeAsNil. -// This way, there isn't a function call overhead just to see that we should not enter a block of code. - -// GenVersion is the current version of codecgen. -// -// NOTE: Increment this value each time codecgen changes fundamentally. -// Fundamental changes are: -// - helper methods change (signature change, new ones added, some removed, etc) -// - codecgen command line changes -// -// v1: Initial Version -// v2: -// v3: Changes for Kubernetes: -// changes in signature of some unpublished helper methods and codecgen cmdline arguments. -// v4: Removed separator support from (en|de)cDriver, and refactored codec(gen) -// v5: changes to support faster json decoding. Let encoder/decoder maintain state of collections. -const GenVersion = 5 - -const ( - genCodecPkg = "codec1978" - genTempVarPfx = "yy" - genTopLevelVarName = "x" - - // ignore canBeNil parameter, and always set to true. - // This is because nil can appear anywhere, so we should always check. - genAnythingCanBeNil = true - - // if genUseOneFunctionForDecStructMap, make a single codecDecodeSelferFromMap function; - // else make codecDecodeSelferFromMap{LenPrefix,CheckBreak} so that conditionals - // are not executed a lot. - // - // From testing, it didn't make much difference in runtime, so keep as true (one function only) - genUseOneFunctionForDecStructMap = true -) - -type genStructMapStyle uint8 - -const ( - genStructMapStyleConsolidated genStructMapStyle = iota - genStructMapStyleLenPrefix - genStructMapStyleCheckBreak -) - -var ( - genAllTypesSamePkgErr = errors.New("All types must be in the same package") - genExpectArrayOrMapErr = errors.New("unexpected type. Expecting array/map/slice") - genBase64enc = base64.NewEncoding("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789__") - genQNameRegex = regexp.MustCompile(`[A-Za-z_.]+`) -) - -// genRunner holds some state used during a Gen run. -type genRunner struct { - w io.Writer // output - c uint64 // counter used for generating varsfx - t []reflect.Type // list of types to run selfer on - - tc reflect.Type // currently running selfer on this type - te map[uintptr]bool // types for which the encoder has been created - td map[uintptr]bool // types for which the decoder has been created - cp string // codec import path - - im map[string]reflect.Type // imports to add - imn map[string]string // package names of imports to add - imc uint64 // counter for import numbers - - is map[reflect.Type]struct{} // types seen during import search - bp string // base PkgPath, for which we are generating for - - cpfx string // codec package prefix - unsafe bool // is unsafe to be used in generated code? - - tm map[reflect.Type]struct{} // types for which enc/dec must be generated - ts []reflect.Type // types for which enc/dec must be generated - - xs string // top level variable/constant suffix - hn string // fn helper type name - - ti *TypeInfos - // rr *rand.Rand // random generator for file-specific types -} - -// Gen will write a complete go file containing Selfer implementations for each -// type passed. All the types must be in the same package. -// -// Library users: *DO NOT USE IT DIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE.* -func Gen(w io.Writer, buildTags, pkgName, uid string, useUnsafe bool, ti *TypeInfos, typ ...reflect.Type) { - if len(typ) == 0 { - return - } - x := genRunner{ - unsafe: useUnsafe, - w: w, - t: typ, - te: make(map[uintptr]bool), - td: make(map[uintptr]bool), - im: make(map[string]reflect.Type), - imn: make(map[string]string), - is: make(map[reflect.Type]struct{}), - tm: make(map[reflect.Type]struct{}), - ts: []reflect.Type{}, - bp: genImportPath(typ[0]), - xs: uid, - ti: ti, - } - if x.ti == nil { - x.ti = defTypeInfos - } - if x.xs == "" { - rr := rand.New(rand.NewSource(time.Now().UnixNano())) - x.xs = strconv.FormatInt(rr.Int63n(9999), 10) - } - - // gather imports first: - x.cp = genImportPath(reflect.TypeOf(x)) - x.imn[x.cp] = genCodecPkg - for _, t := range typ { - // fmt.Printf("###########: PkgPath: '%v', Name: '%s'\n", genImportPath(t), t.Name()) - if genImportPath(t) != x.bp { - panic(genAllTypesSamePkgErr) - } - x.genRefPkgs(t) - } - if buildTags != "" { - x.line("//+build " + buildTags) - x.line("") - } - x.line(` - -// ************************************************************ -// DO NOT EDIT. -// THIS FILE IS AUTO-GENERATED BY codecgen. -// ************************************************************ - -`) - x.line("package " + pkgName) - x.line("") - x.line("import (") - if x.cp != x.bp { - x.cpfx = genCodecPkg + "." - x.linef("%s \"%s\"", genCodecPkg, x.cp) - } - // use a sorted set of im keys, so that we can get consistent output - imKeys := make([]string, 0, len(x.im)) - for k, _ := range x.im { - imKeys = append(imKeys, k) - } - sort.Strings(imKeys) - for _, k := range imKeys { // for k, _ := range x.im { - x.linef("%s \"%s\"", x.imn[k], k) - } - // add required packages - for _, k := range [...]string{"reflect", "unsafe", "runtime", "fmt", "errors"} { - if _, ok := x.im[k]; !ok { - if k == "unsafe" && !x.unsafe { - continue - } - x.line("\"" + k + "\"") - } - } - x.line(")") - x.line("") - - x.line("const (") - x.linef("// ----- content types ----") - x.linef("codecSelferC_UTF8%s = %v", x.xs, int64(c_UTF8)) - x.linef("codecSelferC_RAW%s = %v", x.xs, int64(c_RAW)) - x.linef("// ----- value types used ----") - x.linef("codecSelferValueTypeArray%s = %v", x.xs, int64(valueTypeArray)) - x.linef("codecSelferValueTypeMap%s = %v", x.xs, int64(valueTypeMap)) - x.linef("// ----- containerStateValues ----") - x.linef("codecSelfer_containerMapKey%s = %v", x.xs, int64(containerMapKey)) - x.linef("codecSelfer_containerMapValue%s = %v", x.xs, int64(containerMapValue)) - x.linef("codecSelfer_containerMapEnd%s = %v", x.xs, int64(containerMapEnd)) - x.linef("codecSelfer_containerArrayElem%s = %v", x.xs, int64(containerArrayElem)) - x.linef("codecSelfer_containerArrayEnd%s = %v", x.xs, int64(containerArrayEnd)) - x.line(")") - x.line("var (") - x.line("codecSelferBitsize" + x.xs + " = uint8(reflect.TypeOf(uint(0)).Bits())") - x.line("codecSelferOnlyMapOrArrayEncodeToStructErr" + x.xs + " = errors.New(`only encoded map or array can be decoded into a struct`)") - x.line(")") - x.line("") - - if x.unsafe { - x.line("type codecSelferUnsafeString" + x.xs + " struct { Data uintptr; Len int}") - x.line("") - } - x.hn = "codecSelfer" + x.xs - x.line("type " + x.hn + " struct{}") - x.line("") - - x.line("func init() {") - x.linef("if %sGenVersion != %v {", x.cpfx, GenVersion) - x.line("_, file, _, _ := runtime.Caller(0)") - x.line(`err := fmt.Errorf("codecgen version mismatch: current: %v, need %v. Re-generate file: %v", `) - x.linef(`%v, %sGenVersion, file)`, GenVersion, x.cpfx) - x.line("panic(err)") - x.linef("}") - x.line("if false { // reference the types, but skip this branch at build/run time") - var n int - // for k, t := range x.im { - for _, k := range imKeys { - t := x.im[k] - x.linef("var v%v %s.%s", n, x.imn[k], t.Name()) - n++ - } - if x.unsafe { - x.linef("var v%v unsafe.Pointer", n) - n++ - } - if n > 0 { - x.out("_") - for i := 1; i < n; i++ { - x.out(", _") - } - x.out(" = v0") - for i := 1; i < n; i++ { - x.outf(", v%v", i) - } - } - x.line("} ") // close if false - x.line("}") // close init - x.line("") - - // generate rest of type info - for _, t := range typ { - x.tc = t - x.selfer(true) - x.selfer(false) - } - - for _, t := range x.ts { - rtid := reflect.ValueOf(t).Pointer() - // generate enc functions for all these slice/map types. - x.linef("func (x %s) enc%s(v %s%s, e *%sEncoder) {", x.hn, x.genMethodNameT(t), x.arr2str(t, "*"), x.genTypeName(t), x.cpfx) - x.genRequiredMethodVars(true) - switch t.Kind() { - case reflect.Array, reflect.Slice, reflect.Chan: - x.encListFallback("v", t) - case reflect.Map: - x.encMapFallback("v", t) - default: - panic(genExpectArrayOrMapErr) - } - x.line("}") - x.line("") - - // generate dec functions for all these slice/map types. - x.linef("func (x %s) dec%s(v *%s, d *%sDecoder) {", x.hn, x.genMethodNameT(t), x.genTypeName(t), x.cpfx) - x.genRequiredMethodVars(false) - switch t.Kind() { - case reflect.Array, reflect.Slice, reflect.Chan: - x.decListFallback("v", rtid, t) - case reflect.Map: - x.decMapFallback("v", rtid, t) - default: - panic(genExpectArrayOrMapErr) - } - x.line("}") - x.line("") - } - - x.line("") -} - -func (x *genRunner) checkForSelfer(t reflect.Type, varname string) bool { - // return varname != genTopLevelVarName && t != x.tc - // the only time we checkForSelfer is if we are not at the TOP of the generated code. - return varname != genTopLevelVarName -} - -func (x *genRunner) arr2str(t reflect.Type, s string) string { - if t.Kind() == reflect.Array { - return s - } - return "" -} - -func (x *genRunner) genRequiredMethodVars(encode bool) { - x.line("var h " + x.hn) - if encode { - x.line("z, r := " + x.cpfx + "GenHelperEncoder(e)") - } else { - x.line("z, r := " + x.cpfx + "GenHelperDecoder(d)") - } - x.line("_, _, _ = h, z, r") -} - -func (x *genRunner) genRefPkgs(t reflect.Type) { - if _, ok := x.is[t]; ok { - return - } - // fmt.Printf(">>>>>>: PkgPath: '%v', Name: '%s'\n", genImportPath(t), t.Name()) - x.is[t] = struct{}{} - tpkg, tname := genImportPath(t), t.Name() - if tpkg != "" && tpkg != x.bp && tpkg != x.cp && tname != "" && tname[0] >= 'A' && tname[0] <= 'Z' { - if _, ok := x.im[tpkg]; !ok { - x.im[tpkg] = t - if idx := strings.LastIndex(tpkg, "/"); idx < 0 { - x.imn[tpkg] = tpkg - } else { - x.imc++ - x.imn[tpkg] = "pkg" + strconv.FormatUint(x.imc, 10) + "_" + tpkg[idx+1:] - } - } - } - switch t.Kind() { - case reflect.Array, reflect.Slice, reflect.Ptr, reflect.Chan: - x.genRefPkgs(t.Elem()) - case reflect.Map: - x.genRefPkgs(t.Elem()) - x.genRefPkgs(t.Key()) - case reflect.Struct: - for i := 0; i < t.NumField(); i++ { - if fname := t.Field(i).Name; fname != "" && fname[0] >= 'A' && fname[0] <= 'Z' { - x.genRefPkgs(t.Field(i).Type) - } - } - } -} - -func (x *genRunner) line(s string) { - x.out(s) - if len(s) == 0 || s[len(s)-1] != '\n' { - x.out("\n") - } -} - -func (x *genRunner) varsfx() string { - x.c++ - return strconv.FormatUint(x.c, 10) -} - -func (x *genRunner) out(s string) { - if _, err := io.WriteString(x.w, s); err != nil { - panic(err) - } -} - -func (x *genRunner) linef(s string, params ...interface{}) { - x.line(fmt.Sprintf(s, params...)) -} - -func (x *genRunner) outf(s string, params ...interface{}) { - x.out(fmt.Sprintf(s, params...)) -} - -func (x *genRunner) genTypeName(t reflect.Type) (n string) { - // defer func() { fmt.Printf(">>>> ####: genTypeName: t: %v, name: '%s'\n", t, n) }() - - // if the type has a PkgPath, which doesn't match the current package, - // then include it. - // We cannot depend on t.String() because it includes current package, - // or t.PkgPath because it includes full import path, - // - var ptrPfx string - for t.Kind() == reflect.Ptr { - ptrPfx += "*" - t = t.Elem() - } - if tn := t.Name(); tn != "" { - return ptrPfx + x.genTypeNamePrim(t) - } - switch t.Kind() { - case reflect.Map: - return ptrPfx + "map[" + x.genTypeName(t.Key()) + "]" + x.genTypeName(t.Elem()) - case reflect.Slice: - return ptrPfx + "[]" + x.genTypeName(t.Elem()) - case reflect.Array: - return ptrPfx + "[" + strconv.FormatInt(int64(t.Len()), 10) + "]" + x.genTypeName(t.Elem()) - case reflect.Chan: - return ptrPfx + t.ChanDir().String() + " " + x.genTypeName(t.Elem()) - default: - if t == intfTyp { - return ptrPfx + "interface{}" - } else { - return ptrPfx + x.genTypeNamePrim(t) - } - } -} - -func (x *genRunner) genTypeNamePrim(t reflect.Type) (n string) { - if t.Name() == "" { - return t.String() - } else if genImportPath(t) == "" || genImportPath(t) == genImportPath(x.tc) { - return t.Name() - } else { - return x.imn[genImportPath(t)] + "." + t.Name() - // return t.String() // best way to get the package name inclusive - } -} - -func (x *genRunner) genZeroValueR(t reflect.Type) string { - // if t is a named type, w - switch t.Kind() { - case reflect.Ptr, reflect.Interface, reflect.Chan, reflect.Func, - reflect.Slice, reflect.Map, reflect.Invalid: - return "nil" - case reflect.Bool: - return "false" - case reflect.String: - return `""` - case reflect.Struct, reflect.Array: - return x.genTypeName(t) + "{}" - default: // all numbers - return "0" - } -} - -func (x *genRunner) genMethodNameT(t reflect.Type) (s string) { - return genMethodNameT(t, x.tc) -} - -func (x *genRunner) selfer(encode bool) { - t := x.tc - t0 := t - // always make decode use a pointer receiver, - // and structs always use a ptr receiver (encode|decode) - isptr := !encode || t.Kind() == reflect.Struct - fnSigPfx := "func (x " - if isptr { - fnSigPfx += "*" - } - fnSigPfx += x.genTypeName(t) - - x.out(fnSigPfx) - if isptr { - t = reflect.PtrTo(t) - } - if encode { - x.line(") CodecEncodeSelf(e *" + x.cpfx + "Encoder) {") - x.genRequiredMethodVars(true) - // x.enc(genTopLevelVarName, t) - x.encVar(genTopLevelVarName, t) - } else { - x.line(") CodecDecodeSelf(d *" + x.cpfx + "Decoder) {") - x.genRequiredMethodVars(false) - // do not use decVar, as there is no need to check TryDecodeAsNil - // or way to elegantly handle that, and also setting it to a - // non-nil value doesn't affect the pointer passed. - // x.decVar(genTopLevelVarName, t, false) - x.dec(genTopLevelVarName, t0) - } - x.line("}") - x.line("") - - if encode || t0.Kind() != reflect.Struct { - return - } - - // write is containerMap - if genUseOneFunctionForDecStructMap { - x.out(fnSigPfx) - x.line(") codecDecodeSelfFromMap(l int, d *" + x.cpfx + "Decoder) {") - x.genRequiredMethodVars(false) - x.decStructMap(genTopLevelVarName, "l", reflect.ValueOf(t0).Pointer(), t0, genStructMapStyleConsolidated) - x.line("}") - x.line("") - } else { - x.out(fnSigPfx) - x.line(") codecDecodeSelfFromMapLenPrefix(l int, d *" + x.cpfx + "Decoder) {") - x.genRequiredMethodVars(false) - x.decStructMap(genTopLevelVarName, "l", reflect.ValueOf(t0).Pointer(), t0, genStructMapStyleLenPrefix) - x.line("}") - x.line("") - - x.out(fnSigPfx) - x.line(") codecDecodeSelfFromMapCheckBreak(l int, d *" + x.cpfx + "Decoder) {") - x.genRequiredMethodVars(false) - x.decStructMap(genTopLevelVarName, "l", reflect.ValueOf(t0).Pointer(), t0, genStructMapStyleCheckBreak) - x.line("}") - x.line("") - } - - // write containerArray - x.out(fnSigPfx) - x.line(") codecDecodeSelfFromArray(l int, d *" + x.cpfx + "Decoder) {") - x.genRequiredMethodVars(false) - x.decStructArray(genTopLevelVarName, "l", "return", reflect.ValueOf(t0).Pointer(), t0) - x.line("}") - x.line("") - -} - -// used for chan, array, slice, map -func (x *genRunner) xtraSM(varname string, encode bool, t reflect.Type) { - if encode { - x.linef("h.enc%s((%s%s)(%s), e)", x.genMethodNameT(t), x.arr2str(t, "*"), x.genTypeName(t), varname) - } else { - x.linef("h.dec%s((*%s)(%s), d)", x.genMethodNameT(t), x.genTypeName(t), varname) - } - if _, ok := x.tm[t]; !ok { - x.tm[t] = struct{}{} - x.ts = append(x.ts, t) - } -} - -// encVar will encode a variable. -// The parameter, t, is the reflect.Type of the variable itself -func (x *genRunner) encVar(varname string, t reflect.Type) { - // fmt.Printf(">>>>>> varname: %s, t: %v\n", varname, t) - var checkNil bool - switch t.Kind() { - case reflect.Ptr, reflect.Interface, reflect.Slice, reflect.Map, reflect.Chan: - checkNil = true - } - if checkNil { - x.linef("if %s == nil { r.EncodeNil() } else { ", varname) - } - switch t.Kind() { - case reflect.Ptr: - switch t.Elem().Kind() { - case reflect.Struct, reflect.Array: - x.enc(varname, genNonPtr(t)) - default: - i := x.varsfx() - x.line(genTempVarPfx + i + " := *" + varname) - x.enc(genTempVarPfx+i, genNonPtr(t)) - } - case reflect.Struct, reflect.Array: - i := x.varsfx() - x.line(genTempVarPfx + i + " := &" + varname) - x.enc(genTempVarPfx+i, t) - default: - x.enc(varname, t) - } - - if checkNil { - x.line("}") - } - -} - -// enc will encode a variable (varname) of type T, -// except t is of kind reflect.Struct or reflect.Array, wherein varname is of type *T (to prevent copying) -func (x *genRunner) enc(varname string, t reflect.Type) { - // varName here must be to a pointer to a struct/array, or to a value directly. - rtid := reflect.ValueOf(t).Pointer() - // We call CodecEncodeSelf if one of the following are honored: - // - the type already implements Selfer, call that - // - the type has a Selfer implementation just created, use that - // - the type is in the list of the ones we will generate for, but it is not currently being generated - - tptr := reflect.PtrTo(t) - tk := t.Kind() - if x.checkForSelfer(t, varname) { - if t.Implements(selferTyp) || (tptr.Implements(selferTyp) && (tk == reflect.Array || tk == reflect.Struct)) { - x.line(varname + ".CodecEncodeSelf(e)") - return - } - - if _, ok := x.te[rtid]; ok { - x.line(varname + ".CodecEncodeSelf(e)") - return - } - } - - inlist := false - for _, t0 := range x.t { - if t == t0 { - inlist = true - if x.checkForSelfer(t, varname) { - x.line(varname + ".CodecEncodeSelf(e)") - return - } - break - } - } - - var rtidAdded bool - if t == x.tc { - x.te[rtid] = true - rtidAdded = true - } - - // check if - // - type is RawExt - // - the type implements (Text|JSON|Binary)(Unm|M)arshal - mi := x.varsfx() - x.linef("%sm%s := z.EncBinary()", genTempVarPfx, mi) - x.linef("_ = %sm%s", genTempVarPfx, mi) - x.line("if false {") //start if block - defer func() { x.line("}") }() //end if block - - if t == rawExtTyp { - x.linef("} else { r.EncodeRawExt(%v, e)", varname) - return - } - // HACK: Support for Builtins. - // Currently, only Binc supports builtins, and the only builtin type is time.Time. - // Have a method that returns the rtid for time.Time if Handle is Binc. - if t == timeTyp { - vrtid := genTempVarPfx + "m" + x.varsfx() - x.linef("} else if %s := z.TimeRtidIfBinc(); %s != 0 { ", vrtid, vrtid) - x.linef("r.EncodeBuiltin(%s, %s)", vrtid, varname) - } - // only check for extensions if the type is named, and has a packagePath. - if genImportPath(t) != "" && t.Name() != "" { - // first check if extensions are configued, before doing the interface conversion - x.linef("} else if z.HasExtensions() && z.EncExt(%s) {", varname) - } - if t.Implements(binaryMarshalerTyp) || tptr.Implements(binaryMarshalerTyp) { - x.linef("} else if %sm%s { z.EncBinaryMarshal(%v) ", genTempVarPfx, mi, varname) - } - if t.Implements(jsonMarshalerTyp) || tptr.Implements(jsonMarshalerTyp) { - x.linef("} else if !%sm%s && z.IsJSONHandle() { z.EncJSONMarshal(%v) ", genTempVarPfx, mi, varname) - } else if t.Implements(textMarshalerTyp) || tptr.Implements(textMarshalerTyp) { - x.linef("} else if !%sm%s { z.EncTextMarshal(%v) ", genTempVarPfx, mi, varname) - } - - x.line("} else {") - - switch t.Kind() { - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - x.line("r.EncodeInt(int64(" + varname + "))") - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - x.line("r.EncodeUint(uint64(" + varname + "))") - case reflect.Float32: - x.line("r.EncodeFloat32(float32(" + varname + "))") - case reflect.Float64: - x.line("r.EncodeFloat64(float64(" + varname + "))") - case reflect.Bool: - x.line("r.EncodeBool(bool(" + varname + "))") - case reflect.String: - x.line("r.EncodeString(codecSelferC_UTF8" + x.xs + ", string(" + varname + "))") - case reflect.Chan: - x.xtraSM(varname, true, t) - // x.encListFallback(varname, rtid, t) - case reflect.Array: - x.xtraSM(varname, true, t) - case reflect.Slice: - // if nil, call dedicated function - // if a []uint8, call dedicated function - // if a known fastpath slice, call dedicated function - // else write encode function in-line. - // - if elements are primitives or Selfers, call dedicated function on each member. - // - else call Encoder.encode(XXX) on it. - if rtid == uint8SliceTypId { - x.line("r.EncodeStringBytes(codecSelferC_RAW" + x.xs + ", []byte(" + varname + "))") - } else if fastpathAV.index(rtid) != -1 { - g := x.newGenV(t) - x.line("z.F." + g.MethodNamePfx("Enc", false) + "V(" + varname + ", false, e)") - } else { - x.xtraSM(varname, true, t) - // x.encListFallback(varname, rtid, t) - } - case reflect.Map: - // if nil, call dedicated function - // if a known fastpath map, call dedicated function - // else write encode function in-line. - // - if elements are primitives or Selfers, call dedicated function on each member. - // - else call Encoder.encode(XXX) on it. - // x.line("if " + varname + " == nil { \nr.EncodeNil()\n } else { ") - if fastpathAV.index(rtid) != -1 { - g := x.newGenV(t) - x.line("z.F." + g.MethodNamePfx("Enc", false) + "V(" + varname + ", false, e)") - } else { - x.xtraSM(varname, true, t) - // x.encMapFallback(varname, rtid, t) - } - case reflect.Struct: - if !inlist { - delete(x.te, rtid) - x.line("z.EncFallback(" + varname + ")") - break - } - x.encStruct(varname, rtid, t) - default: - if rtidAdded { - delete(x.te, rtid) - } - x.line("z.EncFallback(" + varname + ")") - } -} - -func (x *genRunner) encZero(t reflect.Type) { - switch t.Kind() { - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - x.line("r.EncodeInt(0)") - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - x.line("r.EncodeUint(0)") - case reflect.Float32: - x.line("r.EncodeFloat32(0)") - case reflect.Float64: - x.line("r.EncodeFloat64(0)") - case reflect.Bool: - x.line("r.EncodeBool(false)") - case reflect.String: - x.line("r.EncodeString(codecSelferC_UTF8" + x.xs + `, "")`) - default: - x.line("r.EncodeNil()") - } -} - -func (x *genRunner) encStruct(varname string, rtid uintptr, t reflect.Type) { - // Use knowledge from structfieldinfo (mbs, encodable fields. Ignore omitempty. ) - // replicate code in kStruct i.e. for each field, deref type to non-pointer, and call x.enc on it - - // if t === type currently running selfer on, do for all - ti := x.ti.get(rtid, t) - i := x.varsfx() - sepVarname := genTempVarPfx + "sep" + i - numfieldsvar := genTempVarPfx + "q" + i - ti2arrayvar := genTempVarPfx + "r" + i - struct2arrvar := genTempVarPfx + "2arr" + i - - x.line(sepVarname + " := !z.EncBinary()") - x.linef("%s := z.EncBasicHandle().StructToArray", struct2arrvar) - tisfi := ti.sfip // always use sequence from file. decStruct expects same thing. - // due to omitEmpty, we need to calculate the - // number of non-empty things we write out first. - // This is required as we need to pre-determine the size of the container, - // to support length-prefixing. - x.linef("var %s [%v]bool", numfieldsvar, len(tisfi)) - x.linef("_, _, _ = %s, %s, %s", sepVarname, numfieldsvar, struct2arrvar) - x.linef("const %s bool = %v", ti2arrayvar, ti.toArray) - nn := 0 - for j, si := range tisfi { - if !si.omitEmpty { - nn++ - continue - } - var t2 reflect.StructField - var omitline string - if si.i != -1 { - t2 = t.Field(int(si.i)) - } else { - t2typ := t - varname3 := varname - for _, ix := range si.is { - for t2typ.Kind() == reflect.Ptr { - t2typ = t2typ.Elem() - } - t2 = t2typ.Field(ix) - t2typ = t2.Type - varname3 = varname3 + "." + t2.Name - if t2typ.Kind() == reflect.Ptr { - omitline += varname3 + " != nil && " - } - } - } - // never check omitEmpty on a struct type, as it may contain uncomparable map/slice/etc. - // also, for maps/slices/arrays, check if len ! 0 (not if == zero value) - switch t2.Type.Kind() { - case reflect.Struct: - omitline += " true" - case reflect.Map, reflect.Slice, reflect.Array, reflect.Chan: - omitline += "len(" + varname + "." + t2.Name + ") != 0" - default: - omitline += varname + "." + t2.Name + " != " + x.genZeroValueR(t2.Type) - } - x.linef("%s[%v] = %s", numfieldsvar, j, omitline) - } - x.linef("var %snn%s int", genTempVarPfx, i) - x.linef("if %s || %s {", ti2arrayvar, struct2arrvar) // if ti.toArray { - x.line("r.EncodeArrayStart(" + strconv.FormatInt(int64(len(tisfi)), 10) + ")") - x.linef("} else {") // if not ti.toArray - x.linef("%snn%s = %v", genTempVarPfx, i, nn) - x.linef("for _, b := range %s { if b { %snn%s++ } }", numfieldsvar, genTempVarPfx, i) - x.linef("r.EncodeMapStart(%snn%s)", genTempVarPfx, i) - x.linef("%snn%s = %v", genTempVarPfx, i, 0) - // x.line("r.EncodeMapStart(" + strconv.FormatInt(int64(len(tisfi)), 10) + ")") - x.line("}") // close if not StructToArray - - for j, si := range tisfi { - i := x.varsfx() - isNilVarName := genTempVarPfx + "n" + i - var labelUsed bool - var t2 reflect.StructField - if si.i != -1 { - t2 = t.Field(int(si.i)) - } else { - t2typ := t - varname3 := varname - for _, ix := range si.is { - // fmt.Printf("%%%% %v, ix: %v\n", t2typ, ix) - for t2typ.Kind() == reflect.Ptr { - t2typ = t2typ.Elem() - } - t2 = t2typ.Field(ix) - t2typ = t2.Type - varname3 = varname3 + "." + t2.Name - if t2typ.Kind() == reflect.Ptr { - if !labelUsed { - x.line("var " + isNilVarName + " bool") - } - x.line("if " + varname3 + " == nil { " + isNilVarName + " = true ") - x.line("goto LABEL" + i) - x.line("}") - labelUsed = true - // "varname3 = new(" + x.genTypeName(t3.Elem()) + ") }") - } - } - // t2 = t.FieldByIndex(si.is) - } - if labelUsed { - x.line("LABEL" + i + ":") - } - // if the type of the field is a Selfer, or one of the ones - - x.linef("if %s || %s {", ti2arrayvar, struct2arrvar) // if ti.toArray - if labelUsed { - x.line("if " + isNilVarName + " { r.EncodeNil() } else { ") - } - x.linef("z.EncSendContainerState(codecSelfer_containerArrayElem%s)", x.xs) - if si.omitEmpty { - x.linef("if %s[%v] {", numfieldsvar, j) - } - x.encVar(varname+"."+t2.Name, t2.Type) - if si.omitEmpty { - x.linef("} else {") - x.encZero(t2.Type) - x.linef("}") - } - if labelUsed { - x.line("}") - } - - x.linef("} else {") // if not ti.toArray - - if si.omitEmpty { - x.linef("if %s[%v] {", numfieldsvar, j) - } - x.linef("z.EncSendContainerState(codecSelfer_containerMapKey%s)", x.xs) - x.line("r.EncodeString(codecSelferC_UTF8" + x.xs + ", string(\"" + si.encName + "\"))") - x.linef("z.EncSendContainerState(codecSelfer_containerMapValue%s)", x.xs) - if labelUsed { - x.line("if " + isNilVarName + " { r.EncodeNil() } else { ") - x.encVar(varname+"."+t2.Name, t2.Type) - x.line("}") - } else { - x.encVar(varname+"."+t2.Name, t2.Type) - } - if si.omitEmpty { - x.line("}") - } - x.linef("} ") // end if/else ti.toArray - } - x.linef("if %s || %s {", ti2arrayvar, struct2arrvar) // if ti.toArray { - x.linef("z.EncSendContainerState(codecSelfer_containerArrayEnd%s)", x.xs) - x.line("} else {") - x.linef("z.EncSendContainerState(codecSelfer_containerMapEnd%s)", x.xs) - x.line("}") - -} - -func (x *genRunner) encListFallback(varname string, t reflect.Type) { - i := x.varsfx() - g := genTempVarPfx - x.line("r.EncodeArrayStart(len(" + varname + "))") - if t.Kind() == reflect.Chan { - x.linef("for %si%s, %si2%s := 0, len(%s); %si%s < %si2%s; %si%s++ {", g, i, g, i, varname, g, i, g, i, g, i) - x.linef("z.EncSendContainerState(codecSelfer_containerArrayElem%s)", x.xs) - x.linef("%sv%s := <-%s", g, i, varname) - } else { - // x.linef("for %si%s, %sv%s := range %s {", genTempVarPfx, i, genTempVarPfx, i, varname) - x.linef("for _, %sv%s := range %s {", genTempVarPfx, i, varname) - x.linef("z.EncSendContainerState(codecSelfer_containerArrayElem%s)", x.xs) - } - x.encVar(genTempVarPfx+"v"+i, t.Elem()) - x.line("}") - x.linef("z.EncSendContainerState(codecSelfer_containerArrayEnd%s)", x.xs) -} - -func (x *genRunner) encMapFallback(varname string, t reflect.Type) { - // TODO: expand this to handle canonical. - i := x.varsfx() - x.line("r.EncodeMapStart(len(" + varname + "))") - x.linef("for %sk%s, %sv%s := range %s {", genTempVarPfx, i, genTempVarPfx, i, varname) - // x.line("for " + genTempVarPfx + "k" + i + ", " + genTempVarPfx + "v" + i + " := range " + varname + " {") - x.linef("z.EncSendContainerState(codecSelfer_containerMapKey%s)", x.xs) - x.encVar(genTempVarPfx+"k"+i, t.Key()) - x.linef("z.EncSendContainerState(codecSelfer_containerMapValue%s)", x.xs) - x.encVar(genTempVarPfx+"v"+i, t.Elem()) - x.line("}") - x.linef("z.EncSendContainerState(codecSelfer_containerMapEnd%s)", x.xs) -} - -func (x *genRunner) decVar(varname string, t reflect.Type, canBeNil bool) { - // We only encode as nil if a nillable value. - // This removes some of the wasted checks for TryDecodeAsNil. - // We need to think about this more, to see what happens if omitempty, etc - // cause a nil value to be stored when something is expected. - // This could happen when decoding from a struct encoded as an array. - // For that, decVar should be called with canNil=true, to force true as its value. - i := x.varsfx() - if !canBeNil { - canBeNil = genAnythingCanBeNil || !genIsImmutable(t) - } - if canBeNil { - x.line("if r.TryDecodeAsNil() {") - if t.Kind() == reflect.Ptr { - x.line("if " + varname + " != nil { ") - - // if varname is a field of a struct (has a dot in it), - // then just set it to nil - if strings.IndexByte(varname, '.') != -1 { - x.line(varname + " = nil") - } else { - x.line("*" + varname + " = " + x.genZeroValueR(t.Elem())) - } - x.line("}") - } else { - x.line(varname + " = " + x.genZeroValueR(t)) - } - x.line("} else {") - } else { - x.line("// cannot be nil") - } - if t.Kind() != reflect.Ptr { - if x.decTryAssignPrimitive(varname, t) { - x.line(genTempVarPfx + "v" + i + " := &" + varname) - x.dec(genTempVarPfx+"v"+i, t) - } - } else { - x.linef("if %s == nil { %s = new(%s) }", varname, varname, x.genTypeName(t.Elem())) - // Ensure we set underlying ptr to a non-nil value (so we can deref to it later). - // There's a chance of a **T in here which is nil. - var ptrPfx string - for t = t.Elem(); t.Kind() == reflect.Ptr; t = t.Elem() { - ptrPfx += "*" - x.linef("if %s%s == nil { %s%s = new(%s)}", - ptrPfx, varname, ptrPfx, varname, x.genTypeName(t)) - } - // if varname has [ in it, then create temp variable for this ptr thingie - if strings.Index(varname, "[") >= 0 { - varname2 := genTempVarPfx + "w" + i - x.line(varname2 + " := " + varname) - varname = varname2 - } - - if ptrPfx == "" { - x.dec(varname, t) - } else { - x.line(genTempVarPfx + "z" + i + " := " + ptrPfx + varname) - x.dec(genTempVarPfx+"z"+i, t) - } - - } - - if canBeNil { - x.line("} ") - } -} - -func (x *genRunner) dec(varname string, t reflect.Type) { - // assumptions: - // - the varname is to a pointer already. No need to take address of it - // - t is always a baseType T (not a *T, etc). - rtid := reflect.ValueOf(t).Pointer() - tptr := reflect.PtrTo(t) - if x.checkForSelfer(t, varname) { - if t.Implements(selferTyp) || tptr.Implements(selferTyp) { - x.line(varname + ".CodecDecodeSelf(d)") - return - } - if _, ok := x.td[rtid]; ok { - x.line(varname + ".CodecDecodeSelf(d)") - return - } - } - - inlist := false - for _, t0 := range x.t { - if t == t0 { - inlist = true - if x.checkForSelfer(t, varname) { - x.line(varname + ".CodecDecodeSelf(d)") - return - } - break - } - } - - var rtidAdded bool - if t == x.tc { - x.td[rtid] = true - rtidAdded = true - } - - // check if - // - type is RawExt - // - the type implements (Text|JSON|Binary)(Unm|M)arshal - mi := x.varsfx() - x.linef("%sm%s := z.DecBinary()", genTempVarPfx, mi) - x.linef("_ = %sm%s", genTempVarPfx, mi) - x.line("if false {") //start if block - defer func() { x.line("}") }() //end if block - - if t == rawExtTyp { - x.linef("} else { r.DecodeExt(%v, 0, nil)", varname) - return - } - - // HACK: Support for Builtins. - // Currently, only Binc supports builtins, and the only builtin type is time.Time. - // Have a method that returns the rtid for time.Time if Handle is Binc. - if t == timeTyp { - vrtid := genTempVarPfx + "m" + x.varsfx() - x.linef("} else if %s := z.TimeRtidIfBinc(); %s != 0 { ", vrtid, vrtid) - x.linef("r.DecodeBuiltin(%s, %s)", vrtid, varname) - } - // only check for extensions if the type is named, and has a packagePath. - if genImportPath(t) != "" && t.Name() != "" { - // first check if extensions are configued, before doing the interface conversion - x.linef("} else if z.HasExtensions() && z.DecExt(%s) {", varname) - } - - if t.Implements(binaryUnmarshalerTyp) || tptr.Implements(binaryUnmarshalerTyp) { - x.linef("} else if %sm%s { z.DecBinaryUnmarshal(%v) ", genTempVarPfx, mi, varname) - } - if t.Implements(jsonUnmarshalerTyp) || tptr.Implements(jsonUnmarshalerTyp) { - x.linef("} else if !%sm%s && z.IsJSONHandle() { z.DecJSONUnmarshal(%v)", genTempVarPfx, mi, varname) - } else if t.Implements(textUnmarshalerTyp) || tptr.Implements(textUnmarshalerTyp) { - x.linef("} else if !%sm%s { z.DecTextUnmarshal(%v)", genTempVarPfx, mi, varname) - } - - x.line("} else {") - - // Since these are pointers, we cannot share, and have to use them one by one - switch t.Kind() { - case reflect.Int: - x.line("*((*int)(" + varname + ")) = int(r.DecodeInt(codecSelferBitsize" + x.xs + "))") - // x.line("z.DecInt((*int)(" + varname + "))") - case reflect.Int8: - x.line("*((*int8)(" + varname + ")) = int8(r.DecodeInt(8))") - // x.line("z.DecInt8((*int8)(" + varname + "))") - case reflect.Int16: - x.line("*((*int16)(" + varname + ")) = int16(r.DecodeInt(16))") - // x.line("z.DecInt16((*int16)(" + varname + "))") - case reflect.Int32: - x.line("*((*int32)(" + varname + ")) = int32(r.DecodeInt(32))") - // x.line("z.DecInt32((*int32)(" + varname + "))") - case reflect.Int64: - x.line("*((*int64)(" + varname + ")) = int64(r.DecodeInt(64))") - // x.line("z.DecInt64((*int64)(" + varname + "))") - - case reflect.Uint: - x.line("*((*uint)(" + varname + ")) = uint(r.DecodeUint(codecSelferBitsize" + x.xs + "))") - // x.line("z.DecUint((*uint)(" + varname + "))") - case reflect.Uint8: - x.line("*((*uint8)(" + varname + ")) = uint8(r.DecodeUint(8))") - // x.line("z.DecUint8((*uint8)(" + varname + "))") - case reflect.Uint16: - x.line("*((*uint16)(" + varname + ")) = uint16(r.DecodeUint(16))") - //x.line("z.DecUint16((*uint16)(" + varname + "))") - case reflect.Uint32: - x.line("*((*uint32)(" + varname + ")) = uint32(r.DecodeUint(32))") - //x.line("z.DecUint32((*uint32)(" + varname + "))") - case reflect.Uint64: - x.line("*((*uint64)(" + varname + ")) = uint64(r.DecodeUint(64))") - //x.line("z.DecUint64((*uint64)(" + varname + "))") - case reflect.Uintptr: - x.line("*((*uintptr)(" + varname + ")) = uintptr(r.DecodeUint(codecSelferBitsize" + x.xs + "))") - - case reflect.Float32: - x.line("*((*float32)(" + varname + ")) = float32(r.DecodeFloat(true))") - //x.line("z.DecFloat32((*float32)(" + varname + "))") - case reflect.Float64: - x.line("*((*float64)(" + varname + ")) = float64(r.DecodeFloat(false))") - // x.line("z.DecFloat64((*float64)(" + varname + "))") - - case reflect.Bool: - x.line("*((*bool)(" + varname + ")) = r.DecodeBool()") - // x.line("z.DecBool((*bool)(" + varname + "))") - case reflect.String: - x.line("*((*string)(" + varname + ")) = r.DecodeString()") - // x.line("z.DecString((*string)(" + varname + "))") - case reflect.Array, reflect.Chan: - x.xtraSM(varname, false, t) - // x.decListFallback(varname, rtid, true, t) - case reflect.Slice: - // if a []uint8, call dedicated function - // if a known fastpath slice, call dedicated function - // else write encode function in-line. - // - if elements are primitives or Selfers, call dedicated function on each member. - // - else call Encoder.encode(XXX) on it. - if rtid == uint8SliceTypId { - x.line("*" + varname + " = r.DecodeBytes(*(*[]byte)(" + varname + "), false, false)") - } else if fastpathAV.index(rtid) != -1 { - g := x.newGenV(t) - x.line("z.F." + g.MethodNamePfx("Dec", false) + "X(" + varname + ", false, d)") - } else { - x.xtraSM(varname, false, t) - // x.decListFallback(varname, rtid, false, t) - } - case reflect.Map: - // if a known fastpath map, call dedicated function - // else write encode function in-line. - // - if elements are primitives or Selfers, call dedicated function on each member. - // - else call Encoder.encode(XXX) on it. - if fastpathAV.index(rtid) != -1 { - g := x.newGenV(t) - x.line("z.F." + g.MethodNamePfx("Dec", false) + "X(" + varname + ", false, d)") - } else { - x.xtraSM(varname, false, t) - // x.decMapFallback(varname, rtid, t) - } - case reflect.Struct: - if inlist { - x.decStruct(varname, rtid, t) - } else { - // delete(x.td, rtid) - x.line("z.DecFallback(" + varname + ", false)") - } - default: - if rtidAdded { - delete(x.te, rtid) - } - x.line("z.DecFallback(" + varname + ", true)") - } -} - -func (x *genRunner) decTryAssignPrimitive(varname string, t reflect.Type) (tryAsPtr bool) { - // We have to use the actual type name when doing a direct assignment. - // We don't have the luxury of casting the pointer to the underlying type. - // - // Consequently, in the situation of a - // type Message int32 - // var x Message - // var i int32 = 32 - // x = i // this will bomb - // x = Message(i) // this will work - // *((*int32)(&x)) = i // this will work - // - // Consequently, we replace: - // case reflect.Uint32: x.line(varname + " = uint32(r.DecodeUint(32))") - // with: - // case reflect.Uint32: x.line(varname + " = " + genTypeNamePrim(t, x.tc) + "(r.DecodeUint(32))") - - xfn := func(t reflect.Type) string { - return x.genTypeNamePrim(t) - } - switch t.Kind() { - case reflect.Int: - x.linef("%s = %s(r.DecodeInt(codecSelferBitsize%s))", varname, xfn(t), x.xs) - case reflect.Int8: - x.linef("%s = %s(r.DecodeInt(8))", varname, xfn(t)) - case reflect.Int16: - x.linef("%s = %s(r.DecodeInt(16))", varname, xfn(t)) - case reflect.Int32: - x.linef("%s = %s(r.DecodeInt(32))", varname, xfn(t)) - case reflect.Int64: - x.linef("%s = %s(r.DecodeInt(64))", varname, xfn(t)) - - case reflect.Uint: - x.linef("%s = %s(r.DecodeUint(codecSelferBitsize%s))", varname, xfn(t), x.xs) - case reflect.Uint8: - x.linef("%s = %s(r.DecodeUint(8))", varname, xfn(t)) - case reflect.Uint16: - x.linef("%s = %s(r.DecodeUint(16))", varname, xfn(t)) - case reflect.Uint32: - x.linef("%s = %s(r.DecodeUint(32))", varname, xfn(t)) - case reflect.Uint64: - x.linef("%s = %s(r.DecodeUint(64))", varname, xfn(t)) - case reflect.Uintptr: - x.linef("%s = %s(r.DecodeUint(codecSelferBitsize%s))", varname, xfn(t), x.xs) - - case reflect.Float32: - x.linef("%s = %s(r.DecodeFloat(true))", varname, xfn(t)) - case reflect.Float64: - x.linef("%s = %s(r.DecodeFloat(false))", varname, xfn(t)) - - case reflect.Bool: - x.linef("%s = %s(r.DecodeBool())", varname, xfn(t)) - case reflect.String: - x.linef("%s = %s(r.DecodeString())", varname, xfn(t)) - default: - tryAsPtr = true - } - return -} - -func (x *genRunner) decListFallback(varname string, rtid uintptr, t reflect.Type) { - type tstruc struct { - TempVar string - Rand string - Varname string - CTyp string - Typ string - Immutable bool - Size int - } - telem := t.Elem() - ts := tstruc{genTempVarPfx, x.varsfx(), varname, x.genTypeName(t), x.genTypeName(telem), genIsImmutable(telem), int(telem.Size())} - - funcs := make(template.FuncMap) - - funcs["decLineVar"] = func(varname string) string { - x.decVar(varname, telem, false) - return "" - } - funcs["decLine"] = func(pfx string) string { - x.decVar(ts.TempVar+pfx+ts.Rand, reflect.PtrTo(telem), false) - return "" - } - funcs["var"] = func(s string) string { - return ts.TempVar + s + ts.Rand - } - funcs["zero"] = func() string { - return x.genZeroValueR(telem) - } - funcs["isArray"] = func() bool { - return t.Kind() == reflect.Array - } - funcs["isSlice"] = func() bool { - return t.Kind() == reflect.Slice - } - funcs["isChan"] = func() bool { - return t.Kind() == reflect.Chan - } - tm, err := template.New("").Funcs(funcs).Parse(genDecListTmpl) - if err != nil { - panic(err) - } - if err = tm.Execute(x.w, &ts); err != nil { - panic(err) - } -} - -func (x *genRunner) decMapFallback(varname string, rtid uintptr, t reflect.Type) { - type tstruc struct { - TempVar string - Sfx string - Rand string - Varname string - KTyp string - Typ string - Size int - } - telem := t.Elem() - tkey := t.Key() - ts := tstruc{ - genTempVarPfx, x.xs, x.varsfx(), varname, x.genTypeName(tkey), - x.genTypeName(telem), int(telem.Size() + tkey.Size()), - } - - funcs := make(template.FuncMap) - funcs["decElemZero"] = func() string { - return x.genZeroValueR(telem) - } - funcs["decElemKindImmutable"] = func() bool { - return genIsImmutable(telem) - } - funcs["decElemKindPtr"] = func() bool { - return telem.Kind() == reflect.Ptr - } - funcs["decElemKindIntf"] = func() bool { - return telem.Kind() == reflect.Interface - } - funcs["decLineVarK"] = func(varname string) string { - x.decVar(varname, tkey, false) - return "" - } - funcs["decLineVar"] = func(varname string) string { - x.decVar(varname, telem, false) - return "" - } - funcs["decLineK"] = func(pfx string) string { - x.decVar(ts.TempVar+pfx+ts.Rand, reflect.PtrTo(tkey), false) - return "" - } - funcs["decLine"] = func(pfx string) string { - x.decVar(ts.TempVar+pfx+ts.Rand, reflect.PtrTo(telem), false) - return "" - } - funcs["var"] = func(s string) string { - return ts.TempVar + s + ts.Rand - } - - tm, err := template.New("").Funcs(funcs).Parse(genDecMapTmpl) - if err != nil { - panic(err) - } - if err = tm.Execute(x.w, &ts); err != nil { - panic(err) - } -} - -func (x *genRunner) decStructMapSwitch(kName string, varname string, rtid uintptr, t reflect.Type) { - ti := x.ti.get(rtid, t) - tisfi := ti.sfip // always use sequence from file. decStruct expects same thing. - x.line("switch (" + kName + ") {") - for _, si := range tisfi { - x.line("case \"" + si.encName + "\":") - var t2 reflect.StructField - if si.i != -1 { - t2 = t.Field(int(si.i)) - } else { - //we must accomodate anonymous fields, where the embedded field is a nil pointer in the value. - // t2 = t.FieldByIndex(si.is) - t2typ := t - varname3 := varname - for _, ix := range si.is { - for t2typ.Kind() == reflect.Ptr { - t2typ = t2typ.Elem() - } - t2 = t2typ.Field(ix) - t2typ = t2.Type - varname3 = varname3 + "." + t2.Name - if t2typ.Kind() == reflect.Ptr { - x.linef("if %s == nil { %s = new(%s) }", varname3, varname3, x.genTypeName(t2typ.Elem())) - } - } - } - x.decVar(varname+"."+t2.Name, t2.Type, false) - } - x.line("default:") - // pass the slice here, so that the string will not escape, and maybe save allocation - x.line("z.DecStructFieldNotFound(-1, " + kName + ")") - x.line("} // end switch " + kName) -} - -func (x *genRunner) decStructMap(varname, lenvarname string, rtid uintptr, t reflect.Type, style genStructMapStyle) { - tpfx := genTempVarPfx - i := x.varsfx() - kName := tpfx + "s" + i - - // We thought to use ReadStringAsBytes, as go compiler might optimize the copy out. - // However, using that was more expensive, as it seems that the switch expression - // is evaluated each time. - // - // We could depend on decodeString using a temporary/shared buffer internally. - // However, this model of creating a byte array, and using explicitly is faster, - // and allows optional use of unsafe []byte->string conversion without alloc. - - // Also, ensure that the slice array doesn't escape. - // That will help escape analysis prevent allocation when it gets better. - - // x.line("var " + kName + "Arr = [32]byte{} // default string to decode into") - // x.line("var " + kName + "Slc = " + kName + "Arr[:] // default slice to decode into") - // use the scratch buffer to avoid allocation (most field names are < 32). - - x.line("var " + kName + "Slc = z.DecScratchBuffer() // default slice to decode into") - - x.line("_ = " + kName + "Slc") - switch style { - case genStructMapStyleLenPrefix: - x.linef("for %sj%s := 0; %sj%s < %s; %sj%s++ {", tpfx, i, tpfx, i, lenvarname, tpfx, i) - case genStructMapStyleCheckBreak: - x.linef("for %sj%s := 0; !r.CheckBreak(); %sj%s++ {", tpfx, i, tpfx, i) - default: // 0, otherwise. - x.linef("var %shl%s bool = %s >= 0", tpfx, i, lenvarname) // has length - x.linef("for %sj%s := 0; ; %sj%s++ {", tpfx, i, tpfx, i) - x.linef("if %shl%s { if %sj%s >= %s { break }", tpfx, i, tpfx, i, lenvarname) - x.line("} else { if r.CheckBreak() { break }; }") - } - x.linef("z.DecSendContainerState(codecSelfer_containerMapKey%s)", x.xs) - x.line(kName + "Slc = r.DecodeBytes(" + kName + "Slc, true, true)") - // let string be scoped to this loop alone, so it doesn't escape. - if x.unsafe { - x.line(kName + "SlcHdr := codecSelferUnsafeString" + x.xs + "{uintptr(unsafe.Pointer(&" + - kName + "Slc[0])), len(" + kName + "Slc)}") - x.line(kName + " := *(*string)(unsafe.Pointer(&" + kName + "SlcHdr))") - } else { - x.line(kName + " := string(" + kName + "Slc)") - } - x.linef("z.DecSendContainerState(codecSelfer_containerMapValue%s)", x.xs) - x.decStructMapSwitch(kName, varname, rtid, t) - - x.line("} // end for " + tpfx + "j" + i) - x.linef("z.DecSendContainerState(codecSelfer_containerMapEnd%s)", x.xs) -} - -func (x *genRunner) decStructArray(varname, lenvarname, breakString string, rtid uintptr, t reflect.Type) { - tpfx := genTempVarPfx - i := x.varsfx() - ti := x.ti.get(rtid, t) - tisfi := ti.sfip // always use sequence from file. decStruct expects same thing. - x.linef("var %sj%s int", tpfx, i) - x.linef("var %sb%s bool", tpfx, i) // break - x.linef("var %shl%s bool = %s >= 0", tpfx, i, lenvarname) // has length - for _, si := range tisfi { - var t2 reflect.StructField - if si.i != -1 { - t2 = t.Field(int(si.i)) - } else { - //we must accomodate anonymous fields, where the embedded field is a nil pointer in the value. - // t2 = t.FieldByIndex(si.is) - t2typ := t - varname3 := varname - for _, ix := range si.is { - for t2typ.Kind() == reflect.Ptr { - t2typ = t2typ.Elem() - } - t2 = t2typ.Field(ix) - t2typ = t2.Type - varname3 = varname3 + "." + t2.Name - if t2typ.Kind() == reflect.Ptr { - x.linef("if %s == nil { %s = new(%s) }", varname3, varname3, x.genTypeName(t2typ.Elem())) - } - } - } - - x.linef("%sj%s++; if %shl%s { %sb%s = %sj%s > %s } else { %sb%s = r.CheckBreak() }", - tpfx, i, tpfx, i, tpfx, i, - tpfx, i, lenvarname, tpfx, i) - x.linef("if %sb%s { z.DecSendContainerState(codecSelfer_containerArrayEnd%s); %s }", - tpfx, i, x.xs, breakString) - x.linef("z.DecSendContainerState(codecSelfer_containerArrayElem%s)", x.xs) - x.decVar(varname+"."+t2.Name, t2.Type, true) - } - // read remaining values and throw away. - x.line("for {") - x.linef("%sj%s++; if %shl%s { %sb%s = %sj%s > %s } else { %sb%s = r.CheckBreak() }", - tpfx, i, tpfx, i, tpfx, i, - tpfx, i, lenvarname, tpfx, i) - x.linef("if %sb%s { break }", tpfx, i) - x.linef("z.DecSendContainerState(codecSelfer_containerArrayElem%s)", x.xs) - x.linef(`z.DecStructFieldNotFound(%sj%s - 1, "")`, tpfx, i) - x.line("}") - x.linef("z.DecSendContainerState(codecSelfer_containerArrayEnd%s)", x.xs) -} - -func (x *genRunner) decStruct(varname string, rtid uintptr, t reflect.Type) { - // if container is map - i := x.varsfx() - x.linef("%sct%s := r.ContainerType()", genTempVarPfx, i) - x.linef("if %sct%s == codecSelferValueTypeMap%s {", genTempVarPfx, i, x.xs) - x.line(genTempVarPfx + "l" + i + " := r.ReadMapStart()") - x.linef("if %sl%s == 0 {", genTempVarPfx, i) - x.linef("z.DecSendContainerState(codecSelfer_containerMapEnd%s)", x.xs) - if genUseOneFunctionForDecStructMap { - x.line("} else { ") - x.linef("x.codecDecodeSelfFromMap(%sl%s, d)", genTempVarPfx, i) - } else { - x.line("} else if " + genTempVarPfx + "l" + i + " > 0 { ") - x.line("x.codecDecodeSelfFromMapLenPrefix(" + genTempVarPfx + "l" + i + ", d)") - x.line("} else {") - x.line("x.codecDecodeSelfFromMapCheckBreak(" + genTempVarPfx + "l" + i + ", d)") - } - x.line("}") - - // else if container is array - x.linef("} else if %sct%s == codecSelferValueTypeArray%s {", genTempVarPfx, i, x.xs) - x.line(genTempVarPfx + "l" + i + " := r.ReadArrayStart()") - x.linef("if %sl%s == 0 {", genTempVarPfx, i) - x.linef("z.DecSendContainerState(codecSelfer_containerArrayEnd%s)", x.xs) - x.line("} else { ") - x.linef("x.codecDecodeSelfFromArray(%sl%s, d)", genTempVarPfx, i) - x.line("}") - // else panic - x.line("} else { ") - x.line("panic(codecSelferOnlyMapOrArrayEncodeToStructErr" + x.xs + ")") - x.line("} ") -} - -// -------- - -type genV struct { - // genV is either a primitive (Primitive != "") or a map (MapKey != "") or a slice - MapKey string - Elem string - Primitive string - Size int -} - -func (x *genRunner) newGenV(t reflect.Type) (v genV) { - switch t.Kind() { - case reflect.Slice, reflect.Array: - te := t.Elem() - v.Elem = x.genTypeName(te) - v.Size = int(te.Size()) - case reflect.Map: - te, tk := t.Elem(), t.Key() - v.Elem = x.genTypeName(te) - v.MapKey = x.genTypeName(tk) - v.Size = int(te.Size() + tk.Size()) - default: - panic("unexpected type for newGenV. Requires map or slice type") - } - return -} - -func (x *genV) MethodNamePfx(prefix string, prim bool) string { - var name []byte - if prefix != "" { - name = append(name, prefix...) - } - if prim { - name = append(name, genTitleCaseName(x.Primitive)...) - } else { - if x.MapKey == "" { - name = append(name, "Slice"...) - } else { - name = append(name, "Map"...) - name = append(name, genTitleCaseName(x.MapKey)...) - } - name = append(name, genTitleCaseName(x.Elem)...) - } - return string(name) - -} - -var genCheckVendor = os.Getenv("GO15VENDOREXPERIMENT") == "1" - -// genImportPath returns import path of a non-predeclared named typed, or an empty string otherwise. -// -// This handles the misbehaviour that occurs when 1.5-style vendoring is enabled, -// where PkgPath returns the full path, including the vendoring pre-fix that should have been stripped. -// We strip it here. -func genImportPath(t reflect.Type) (s string) { - s = t.PkgPath() - if genCheckVendor { - // HACK: Misbehaviour occurs in go 1.5. May have to re-visit this later. - // if s contains /vendor/ OR startsWith vendor/, then return everything after it. - const vendorStart = "vendor/" - const vendorInline = "/vendor/" - if i := strings.LastIndex(s, vendorInline); i >= 0 { - s = s[i+len(vendorInline):] - } else if strings.HasPrefix(s, vendorStart) { - s = s[len(vendorStart):] - } - } - return -} - -func genNonPtr(t reflect.Type) reflect.Type { - for t.Kind() == reflect.Ptr { - t = t.Elem() - } - return t -} - -func genTitleCaseName(s string) string { - switch s { - case "interface{}": - return "Intf" - default: - return strings.ToUpper(s[0:1]) + s[1:] - } -} - -func genMethodNameT(t reflect.Type, tRef reflect.Type) (n string) { - var ptrPfx string - for t.Kind() == reflect.Ptr { - ptrPfx += "Ptrto" - t = t.Elem() - } - tstr := t.String() - if tn := t.Name(); tn != "" { - if tRef != nil && genImportPath(t) == genImportPath(tRef) { - return ptrPfx + tn - } else { - if genQNameRegex.MatchString(tstr) { - return ptrPfx + strings.Replace(tstr, ".", "_", 1000) - } else { - return ptrPfx + genCustomTypeName(tstr) - } - } - } - switch t.Kind() { - case reflect.Map: - return ptrPfx + "Map" + genMethodNameT(t.Key(), tRef) + genMethodNameT(t.Elem(), tRef) - case reflect.Slice: - return ptrPfx + "Slice" + genMethodNameT(t.Elem(), tRef) - case reflect.Array: - return ptrPfx + "Array" + strconv.FormatInt(int64(t.Len()), 10) + genMethodNameT(t.Elem(), tRef) - case reflect.Chan: - var cx string - switch t.ChanDir() { - case reflect.SendDir: - cx = "ChanSend" - case reflect.RecvDir: - cx = "ChanRecv" - default: - cx = "Chan" - } - return ptrPfx + cx + genMethodNameT(t.Elem(), tRef) - default: - if t == intfTyp { - return ptrPfx + "Interface" - } else { - if tRef != nil && genImportPath(t) == genImportPath(tRef) { - if t.Name() != "" { - return ptrPfx + t.Name() - } else { - return ptrPfx + genCustomTypeName(tstr) - } - } else { - // best way to get the package name inclusive - // return ptrPfx + strings.Replace(tstr, ".", "_", 1000) - // return ptrPfx + genBase64enc.EncodeToString([]byte(tstr)) - if t.Name() != "" && genQNameRegex.MatchString(tstr) { - return ptrPfx + strings.Replace(tstr, ".", "_", 1000) - } else { - return ptrPfx + genCustomTypeName(tstr) - } - } - } - } -} - -// genCustomNameForType base64encodes the t.String() value in such a way -// that it can be used within a function name. -func genCustomTypeName(tstr string) string { - len2 := genBase64enc.EncodedLen(len(tstr)) - bufx := make([]byte, len2) - genBase64enc.Encode(bufx, []byte(tstr)) - for i := len2 - 1; i >= 0; i-- { - if bufx[i] == '=' { - len2-- - } else { - break - } - } - return string(bufx[:len2]) -} - -func genIsImmutable(t reflect.Type) (v bool) { - return isImmutableKind(t.Kind()) -} - -type genInternal struct { - Values []genV - Unsafe bool -} - -func (x genInternal) FastpathLen() (l int) { - for _, v := range x.Values { - if v.Primitive == "" { - l++ - } - } - return -} - -func genInternalZeroValue(s string) string { - switch s { - case "interface{}": - return "nil" - case "bool": - return "false" - case "string": - return `""` - default: - return "0" - } -} - -func genInternalEncCommandAsString(s string, vname string) string { - switch s { - case "uint", "uint8", "uint16", "uint32", "uint64": - return "ee.EncodeUint(uint64(" + vname + "))" - case "int", "int8", "int16", "int32", "int64": - return "ee.EncodeInt(int64(" + vname + "))" - case "string": - return "ee.EncodeString(c_UTF8, " + vname + ")" - case "float32": - return "ee.EncodeFloat32(" + vname + ")" - case "float64": - return "ee.EncodeFloat64(" + vname + ")" - case "bool": - return "ee.EncodeBool(" + vname + ")" - case "symbol": - return "ee.EncodeSymbol(" + vname + ")" - default: - return "e.encode(" + vname + ")" - } -} - -func genInternalDecCommandAsString(s string) string { - switch s { - case "uint": - return "uint(dd.DecodeUint(uintBitsize))" - case "uint8": - return "uint8(dd.DecodeUint(8))" - case "uint16": - return "uint16(dd.DecodeUint(16))" - case "uint32": - return "uint32(dd.DecodeUint(32))" - case "uint64": - return "dd.DecodeUint(64)" - case "uintptr": - return "uintptr(dd.DecodeUint(uintBitsize))" - case "int": - return "int(dd.DecodeInt(intBitsize))" - case "int8": - return "int8(dd.DecodeInt(8))" - case "int16": - return "int16(dd.DecodeInt(16))" - case "int32": - return "int32(dd.DecodeInt(32))" - case "int64": - return "dd.DecodeInt(64)" - - case "string": - return "dd.DecodeString()" - case "float32": - return "float32(dd.DecodeFloat(true))" - case "float64": - return "dd.DecodeFloat(false)" - case "bool": - return "dd.DecodeBool()" - default: - panic(errors.New("gen internal: unknown type for decode: " + s)) - } -} - -func genInternalSortType(s string, elem bool) string { - for _, v := range [...]string{"int", "uint", "float", "bool", "string"} { - if strings.HasPrefix(s, v) { - if elem { - if v == "int" || v == "uint" || v == "float" { - return v + "64" - } else { - return v - } - } - return v + "Slice" - } - } - panic("sorttype: unexpected type: " + s) -} - -// var genInternalMu sync.Mutex -var genInternalV genInternal -var genInternalTmplFuncs template.FuncMap -var genInternalOnce sync.Once - -func genInternalInit() { - types := [...]string{ - "interface{}", - "string", - "float32", - "float64", - "uint", - "uint8", - "uint16", - "uint32", - "uint64", - "uintptr", - "int", - "int8", - "int16", - "int32", - "int64", - "bool", - } - // keep as slice, so it is in specific iteration order. - // Initial order was uint64, string, interface{}, int, int64 - mapvaltypes := [...]string{ - "interface{}", - "string", - "uint", - "uint8", - "uint16", - "uint32", - "uint64", - "uintptr", - "int", - "int8", - "int16", - "int32", - "int64", - "float32", - "float64", - "bool", - } - wordSizeBytes := int(intBitsize) / 8 - - mapvaltypes2 := map[string]int{ - "interface{}": 2 * wordSizeBytes, - "string": 2 * wordSizeBytes, - "uint": 1 * wordSizeBytes, - "uint8": 1, - "uint16": 2, - "uint32": 4, - "uint64": 8, - "uintptr": 1 * wordSizeBytes, - "int": 1 * wordSizeBytes, - "int8": 1, - "int16": 2, - "int32": 4, - "int64": 8, - "float32": 4, - "float64": 8, - "bool": 1, - } - var gt genInternal - - // For each slice or map type, there must be a (symetrical) Encode and Decode fast-path function - for _, s := range types { - gt.Values = append(gt.Values, genV{Primitive: s, Size: mapvaltypes2[s]}) - if s != "uint8" { // do not generate fast path for slice of bytes. Treat specially already. - gt.Values = append(gt.Values, genV{Elem: s, Size: mapvaltypes2[s]}) - } - if _, ok := mapvaltypes2[s]; !ok { - gt.Values = append(gt.Values, genV{MapKey: s, Elem: s, Size: 2 * mapvaltypes2[s]}) - } - for _, ms := range mapvaltypes { - gt.Values = append(gt.Values, genV{MapKey: s, Elem: ms, Size: mapvaltypes2[s] + mapvaltypes2[ms]}) - } - } - - funcs := make(template.FuncMap) - // funcs["haspfx"] = strings.HasPrefix - funcs["encmd"] = genInternalEncCommandAsString - funcs["decmd"] = genInternalDecCommandAsString - funcs["zerocmd"] = genInternalZeroValue - funcs["hasprefix"] = strings.HasPrefix - funcs["sorttype"] = genInternalSortType - - genInternalV = gt - genInternalTmplFuncs = funcs -} - -// genInternalGoFile is used to generate source files from templates. -// It is run by the program author alone. -// Unfortunately, it has to be exported so that it can be called from a command line tool. -// *** DO NOT USE *** -func genInternalGoFile(r io.Reader, w io.Writer, safe bool) (err error) { - genInternalOnce.Do(genInternalInit) - - gt := genInternalV - gt.Unsafe = !safe - - t := template.New("").Funcs(genInternalTmplFuncs) - - tmplstr, err := ioutil.ReadAll(r) - if err != nil { - return - } - - if t, err = t.Parse(string(tmplstr)); err != nil { - return - } - - var out bytes.Buffer - err = t.Execute(&out, gt) - if err != nil { - return - } - - bout, err := format.Source(out.Bytes()) - if err != nil { - w.Write(out.Bytes()) // write out if error, so we can still see. - // w.Write(bout) // write out if error, as much as possible, so we can still see. - return - } - w.Write(bout) - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper.go deleted file mode 100644 index 560014a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper.go +++ /dev/null @@ -1,1129 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -// Contains code shared by both encode and decode. - -// Some shared ideas around encoding/decoding -// ------------------------------------------ -// -// If an interface{} is passed, we first do a type assertion to see if it is -// a primitive type or a map/slice of primitive types, and use a fastpath to handle it. -// -// If we start with a reflect.Value, we are already in reflect.Value land and -// will try to grab the function for the underlying Type and directly call that function. -// This is more performant than calling reflect.Value.Interface(). -// -// This still helps us bypass many layers of reflection, and give best performance. -// -// Containers -// ------------ -// Containers in the stream are either associative arrays (key-value pairs) or -// regular arrays (indexed by incrementing integers). -// -// Some streams support indefinite-length containers, and use a breaking -// byte-sequence to denote that the container has come to an end. -// -// Some streams also are text-based, and use explicit separators to denote the -// end/beginning of different values. -// -// During encode, we use a high-level condition to determine how to iterate through -// the container. That decision is based on whether the container is text-based (with -// separators) or binary (without separators). If binary, we do not even call the -// encoding of separators. -// -// During decode, we use a different high-level condition to determine how to iterate -// through the containers. That decision is based on whether the stream contained -// a length prefix, or if it used explicit breaks. If length-prefixed, we assume that -// it has to be binary, and we do not even try to read separators. -// -// The only codec that may suffer (slightly) is cbor, and only when decoding indefinite-length. -// It may suffer because we treat it like a text-based codec, and read separators. -// However, this read is a no-op and the cost is insignificant. -// -// Philosophy -// ------------ -// On decode, this codec will update containers appropriately: -// - If struct, update fields from stream into fields of struct. -// If field in stream not found in struct, handle appropriately (based on option). -// If a struct field has no corresponding value in the stream, leave it AS IS. -// If nil in stream, set value to nil/zero value. -// - If map, update map from stream. -// If the stream value is NIL, set the map to nil. -// - if slice, try to update up to length of array in stream. -// if container len is less than stream array length, -// and container cannot be expanded, handled (based on option). -// This means you can decode 4-element stream array into 1-element array. -// -// ------------------------------------ -// On encode, user can specify omitEmpty. This means that the value will be omitted -// if the zero value. The problem may occur during decode, where omitted values do not affect -// the value being decoded into. This means that if decoding into a struct with an -// int field with current value=5, and the field is omitted in the stream, then after -// decoding, the value will still be 5 (not 0). -// omitEmpty only works if you guarantee that you always decode into zero-values. -// -// ------------------------------------ -// We could have truncated a map to remove keys not available in the stream, -// or set values in the struct which are not in the stream to their zero values. -// We decided against it because there is no efficient way to do it. -// We may introduce it as an option later. -// However, that will require enabling it for both runtime and code generation modes. -// -// To support truncate, we need to do 2 passes over the container: -// map -// - first collect all keys (e.g. in k1) -// - for each key in stream, mark k1 that the key should not be removed -// - after updating map, do second pass and call delete for all keys in k1 which are not marked -// struct: -// - for each field, track the *typeInfo s1 -// - iterate through all s1, and for each one not marked, set value to zero -// - this involves checking the possible anonymous fields which are nil ptrs. -// too much work. -// -// ------------------------------------------ -// Error Handling is done within the library using panic. -// -// This way, the code doesn't have to keep checking if an error has happened, -// and we don't have to keep sending the error value along with each call -// or storing it in the En|Decoder and checking it constantly along the way. -// -// The disadvantage is that small functions which use panics cannot be inlined. -// The code accounts for that by only using panics behind an interface; -// since interface calls cannot be inlined, this is irrelevant. -// -// We considered storing the error is En|Decoder. -// - once it has its err field set, it cannot be used again. -// - panicing will be optional, controlled by const flag. -// - code should always check error first and return early. -// We eventually decided against it as it makes the code clumsier to always -// check for these error conditions. - -import ( - "bytes" - "encoding" - "encoding/binary" - "errors" - "fmt" - "math" - "reflect" - "sort" - "strings" - "sync" - "time" -) - -const ( - scratchByteArrayLen = 32 - initCollectionCap = 32 // 32 is defensive. 16 is preferred. - - // Support encoding.(Binary|Text)(Unm|M)arshaler. - // This constant flag will enable or disable it. - supportMarshalInterfaces = true - - // Each Encoder or Decoder uses a cache of functions based on conditionals, - // so that the conditionals are not run every time. - // - // Either a map or a slice is used to keep track of the functions. - // The map is more natural, but has a higher cost than a slice/array. - // This flag (useMapForCodecCache) controls which is used. - // - // From benchmarks, slices with linear search perform better with < 32 entries. - // We have typically seen a high threshold of about 24 entries. - useMapForCodecCache = false - - // for debugging, set this to false, to catch panic traces. - // Note that this will always cause rpc tests to fail, since they need io.EOF sent via panic. - recoverPanicToErr = true - - // Fast path functions try to create a fast path encode or decode implementation - // for common maps and slices, by by-passing reflection altogether. - fastpathEnabled = true - - // if checkStructForEmptyValue, check structs fields to see if an empty value. - // This could be an expensive call, so possibly disable it. - checkStructForEmptyValue = false - - // if derefForIsEmptyValue, deref pointers and interfaces when checking isEmptyValue - derefForIsEmptyValue = false - - // if resetSliceElemToZeroValue, then on decoding a slice, reset the element to a zero value first. - // Only concern is that, if the slice already contained some garbage, we will decode into that garbage. - // The chances of this are slim, so leave this "optimization". - // TODO: should this be true, to ensure that we always decode into a "zero" "empty" value? - resetSliceElemToZeroValue bool = false -) - -var oneByteArr = [1]byte{0} -var zeroByteSlice = oneByteArr[:0:0] - -type charEncoding uint8 - -const ( - c_RAW charEncoding = iota - c_UTF8 - c_UTF16LE - c_UTF16BE - c_UTF32LE - c_UTF32BE -) - -// valueType is the stream type -type valueType uint8 - -const ( - valueTypeUnset valueType = iota - valueTypeNil - valueTypeInt - valueTypeUint - valueTypeFloat - valueTypeBool - valueTypeString - valueTypeSymbol - valueTypeBytes - valueTypeMap - valueTypeArray - valueTypeTimestamp - valueTypeExt - - // valueTypeInvalid = 0xff -) - -type seqType uint8 - -const ( - _ seqType = iota - seqTypeArray - seqTypeSlice - seqTypeChan -) - -// note that containerMapStart and containerArraySend are not sent. -// This is because the ReadXXXStart and EncodeXXXStart already does these. -type containerState uint8 - -const ( - _ containerState = iota - - containerMapStart // slot left open, since Driver method already covers it - containerMapKey - containerMapValue - containerMapEnd - containerArrayStart // slot left open, since Driver methods already cover it - containerArrayElem - containerArrayEnd -) - -type containerStateRecv interface { - sendContainerState(containerState) -} - -// mirror json.Marshaler and json.Unmarshaler here, -// so we don't import the encoding/json package -type jsonMarshaler interface { - MarshalJSON() ([]byte, error) -} -type jsonUnmarshaler interface { - UnmarshalJSON([]byte) error -} - -var ( - bigen = binary.BigEndian - structInfoFieldName = "_struct" - - mapStrIntfTyp = reflect.TypeOf(map[string]interface{}(nil)) - mapIntfIntfTyp = reflect.TypeOf(map[interface{}]interface{}(nil)) - intfSliceTyp = reflect.TypeOf([]interface{}(nil)) - intfTyp = intfSliceTyp.Elem() - - stringTyp = reflect.TypeOf("") - timeTyp = reflect.TypeOf(time.Time{}) - rawExtTyp = reflect.TypeOf(RawExt{}) - uint8SliceTyp = reflect.TypeOf([]uint8(nil)) - - mapBySliceTyp = reflect.TypeOf((*MapBySlice)(nil)).Elem() - - binaryMarshalerTyp = reflect.TypeOf((*encoding.BinaryMarshaler)(nil)).Elem() - binaryUnmarshalerTyp = reflect.TypeOf((*encoding.BinaryUnmarshaler)(nil)).Elem() - - textMarshalerTyp = reflect.TypeOf((*encoding.TextMarshaler)(nil)).Elem() - textUnmarshalerTyp = reflect.TypeOf((*encoding.TextUnmarshaler)(nil)).Elem() - - jsonMarshalerTyp = reflect.TypeOf((*jsonMarshaler)(nil)).Elem() - jsonUnmarshalerTyp = reflect.TypeOf((*jsonUnmarshaler)(nil)).Elem() - - selferTyp = reflect.TypeOf((*Selfer)(nil)).Elem() - - uint8SliceTypId = reflect.ValueOf(uint8SliceTyp).Pointer() - rawExtTypId = reflect.ValueOf(rawExtTyp).Pointer() - intfTypId = reflect.ValueOf(intfTyp).Pointer() - timeTypId = reflect.ValueOf(timeTyp).Pointer() - stringTypId = reflect.ValueOf(stringTyp).Pointer() - - mapStrIntfTypId = reflect.ValueOf(mapStrIntfTyp).Pointer() - mapIntfIntfTypId = reflect.ValueOf(mapIntfIntfTyp).Pointer() - intfSliceTypId = reflect.ValueOf(intfSliceTyp).Pointer() - // mapBySliceTypId = reflect.ValueOf(mapBySliceTyp).Pointer() - - intBitsize uint8 = uint8(reflect.TypeOf(int(0)).Bits()) - uintBitsize uint8 = uint8(reflect.TypeOf(uint(0)).Bits()) - - bsAll0x00 = []byte{0, 0, 0, 0, 0, 0, 0, 0} - bsAll0xff = []byte{0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff} - - chkOvf checkOverflow - - noFieldNameToStructFieldInfoErr = errors.New("no field name passed to parseStructFieldInfo") -) - -var defTypeInfos = NewTypeInfos([]string{"codec", "json"}) - -// Selfer defines methods by which a value can encode or decode itself. -// -// Any type which implements Selfer will be able to encode or decode itself. -// Consequently, during (en|de)code, this takes precedence over -// (text|binary)(M|Unm)arshal or extension support. -type Selfer interface { - CodecEncodeSelf(*Encoder) - CodecDecodeSelf(*Decoder) -} - -// MapBySlice represents a slice which should be encoded as a map in the stream. -// The slice contains a sequence of key-value pairs. -// This affords storing a map in a specific sequence in the stream. -// -// The support of MapBySlice affords the following: -// - A slice type which implements MapBySlice will be encoded as a map -// - A slice can be decoded from a map in the stream -type MapBySlice interface { - MapBySlice() -} - -// WARNING: DO NOT USE DIRECTLY. EXPORTED FOR GODOC BENEFIT. WILL BE REMOVED. -// -// BasicHandle encapsulates the common options and extension functions. -type BasicHandle struct { - // TypeInfos is used to get the type info for any type. - // - // If not configured, the default TypeInfos is used, which uses struct tag keys: codec, json - TypeInfos *TypeInfos - - extHandle - EncodeOptions - DecodeOptions -} - -func (x *BasicHandle) getBasicHandle() *BasicHandle { - return x -} - -func (x *BasicHandle) getTypeInfo(rtid uintptr, rt reflect.Type) (pti *typeInfo) { - if x.TypeInfos != nil { - return x.TypeInfos.get(rtid, rt) - } - return defTypeInfos.get(rtid, rt) -} - -// Handle is the interface for a specific encoding format. -// -// Typically, a Handle is pre-configured before first time use, -// and not modified while in use. Such a pre-configured Handle -// is safe for concurrent access. -type Handle interface { - getBasicHandle() *BasicHandle - newEncDriver(w *Encoder) encDriver - newDecDriver(r *Decoder) decDriver - isBinary() bool -} - -// RawExt represents raw unprocessed extension data. -// Some codecs will decode extension data as a *RawExt if there is no registered extension for the tag. -// -// Only one of Data or Value is nil. If Data is nil, then the content of the RawExt is in the Value. -type RawExt struct { - Tag uint64 - // Data is the []byte which represents the raw ext. If Data is nil, ext is exposed in Value. - // Data is used by codecs (e.g. binc, msgpack, simple) which do custom serialization of the types - Data []byte - // Value represents the extension, if Data is nil. - // Value is used by codecs (e.g. cbor) which use the format to do custom serialization of the types. - Value interface{} -} - -// BytesExt handles custom (de)serialization of types to/from []byte. -// It is used by codecs (e.g. binc, msgpack, simple) which do custom serialization of the types. -type BytesExt interface { - // WriteExt converts a value to a []byte. - // - // Note: v *may* be a pointer to the extension type, if the extension type was a struct or array. - WriteExt(v interface{}) []byte - - // ReadExt updates a value from a []byte. - ReadExt(dst interface{}, src []byte) -} - -// InterfaceExt handles custom (de)serialization of types to/from another interface{} value. -// The Encoder or Decoder will then handle the further (de)serialization of that known type. -// -// It is used by codecs (e.g. cbor, json) which use the format to do custom serialization of the types. -type InterfaceExt interface { - // ConvertExt converts a value into a simpler interface for easy encoding e.g. convert time.Time to int64. - // - // Note: v *may* be a pointer to the extension type, if the extension type was a struct or array. - ConvertExt(v interface{}) interface{} - - // UpdateExt updates a value from a simpler interface for easy decoding e.g. convert int64 to time.Time. - UpdateExt(dst interface{}, src interface{}) -} - -// Ext handles custom (de)serialization of custom types / extensions. -type Ext interface { - BytesExt - InterfaceExt -} - -// addExtWrapper is a wrapper implementation to support former AddExt exported method. -type addExtWrapper struct { - encFn func(reflect.Value) ([]byte, error) - decFn func(reflect.Value, []byte) error -} - -func (x addExtWrapper) WriteExt(v interface{}) []byte { - bs, err := x.encFn(reflect.ValueOf(v)) - if err != nil { - panic(err) - } - return bs -} - -func (x addExtWrapper) ReadExt(v interface{}, bs []byte) { - if err := x.decFn(reflect.ValueOf(v), bs); err != nil { - panic(err) - } -} - -func (x addExtWrapper) ConvertExt(v interface{}) interface{} { - return x.WriteExt(v) -} - -func (x addExtWrapper) UpdateExt(dest interface{}, v interface{}) { - x.ReadExt(dest, v.([]byte)) -} - -type setExtWrapper struct { - b BytesExt - i InterfaceExt -} - -func (x *setExtWrapper) WriteExt(v interface{}) []byte { - if x.b == nil { - panic("BytesExt.WriteExt is not supported") - } - return x.b.WriteExt(v) -} - -func (x *setExtWrapper) ReadExt(v interface{}, bs []byte) { - if x.b == nil { - panic("BytesExt.WriteExt is not supported") - - } - x.b.ReadExt(v, bs) -} - -func (x *setExtWrapper) ConvertExt(v interface{}) interface{} { - if x.i == nil { - panic("InterfaceExt.ConvertExt is not supported") - - } - return x.i.ConvertExt(v) -} - -func (x *setExtWrapper) UpdateExt(dest interface{}, v interface{}) { - if x.i == nil { - panic("InterfaceExxt.UpdateExt is not supported") - - } - x.i.UpdateExt(dest, v) -} - -// type errorString string -// func (x errorString) Error() string { return string(x) } - -type binaryEncodingType struct{} - -func (_ binaryEncodingType) isBinary() bool { return true } - -type textEncodingType struct{} - -func (_ textEncodingType) isBinary() bool { return false } - -// noBuiltInTypes is embedded into many types which do not support builtins -// e.g. msgpack, simple, cbor. -type noBuiltInTypes struct{} - -func (_ noBuiltInTypes) IsBuiltinType(rt uintptr) bool { return false } -func (_ noBuiltInTypes) EncodeBuiltin(rt uintptr, v interface{}) {} -func (_ noBuiltInTypes) DecodeBuiltin(rt uintptr, v interface{}) {} - -type noStreamingCodec struct{} - -func (_ noStreamingCodec) CheckBreak() bool { return false } - -// bigenHelper. -// Users must already slice the x completely, because we will not reslice. -type bigenHelper struct { - x []byte // must be correctly sliced to appropriate len. slicing is a cost. - w encWriter -} - -func (z bigenHelper) writeUint16(v uint16) { - bigen.PutUint16(z.x, v) - z.w.writeb(z.x) -} - -func (z bigenHelper) writeUint32(v uint32) { - bigen.PutUint32(z.x, v) - z.w.writeb(z.x) -} - -func (z bigenHelper) writeUint64(v uint64) { - bigen.PutUint64(z.x, v) - z.w.writeb(z.x) -} - -type extTypeTagFn struct { - rtid uintptr - rt reflect.Type - tag uint64 - ext Ext -} - -type extHandle []extTypeTagFn - -// DEPRECATED: Use SetBytesExt or SetInterfaceExt on the Handle instead. -// -// AddExt registes an encode and decode function for a reflect.Type. -// AddExt internally calls SetExt. -// To deregister an Ext, call AddExt with nil encfn and/or nil decfn. -func (o *extHandle) AddExt( - rt reflect.Type, tag byte, - encfn func(reflect.Value) ([]byte, error), decfn func(reflect.Value, []byte) error, -) (err error) { - if encfn == nil || decfn == nil { - return o.SetExt(rt, uint64(tag), nil) - } - return o.SetExt(rt, uint64(tag), addExtWrapper{encfn, decfn}) -} - -// DEPRECATED: Use SetBytesExt or SetInterfaceExt on the Handle instead. -// -// Note that the type must be a named type, and specifically not -// a pointer or Interface. An error is returned if that is not honored. -// -// To Deregister an ext, call SetExt with nil Ext -func (o *extHandle) SetExt(rt reflect.Type, tag uint64, ext Ext) (err error) { - // o is a pointer, because we may need to initialize it - if rt.PkgPath() == "" || rt.Kind() == reflect.Interface { - err = fmt.Errorf("codec.Handle.AddExt: Takes named type, especially not a pointer or interface: %T", - reflect.Zero(rt).Interface()) - return - } - - rtid := reflect.ValueOf(rt).Pointer() - for _, v := range *o { - if v.rtid == rtid { - v.tag, v.ext = tag, ext - return - } - } - - if *o == nil { - *o = make([]extTypeTagFn, 0, 4) - } - *o = append(*o, extTypeTagFn{rtid, rt, tag, ext}) - return -} - -func (o extHandle) getExt(rtid uintptr) *extTypeTagFn { - var v *extTypeTagFn - for i := range o { - v = &o[i] - if v.rtid == rtid { - return v - } - } - return nil -} - -func (o extHandle) getExtForTag(tag uint64) *extTypeTagFn { - var v *extTypeTagFn - for i := range o { - v = &o[i] - if v.tag == tag { - return v - } - } - return nil -} - -type structFieldInfo struct { - encName string // encode name - - // only one of 'i' or 'is' can be set. If 'i' is -1, then 'is' has been set. - - is []int // (recursive/embedded) field index in struct - i int16 // field index in struct - omitEmpty bool - toArray bool // if field is _struct, is the toArray set? -} - -// func (si *structFieldInfo) isZero() bool { -// return si.encName == "" && len(si.is) == 0 && si.i == 0 && !si.omitEmpty && !si.toArray -// } - -// rv returns the field of the struct. -// If anonymous, it returns an Invalid -func (si *structFieldInfo) field(v reflect.Value, update bool) (rv2 reflect.Value) { - if si.i != -1 { - v = v.Field(int(si.i)) - return v - } - // replicate FieldByIndex - for _, x := range si.is { - for v.Kind() == reflect.Ptr { - if v.IsNil() { - if !update { - return - } - v.Set(reflect.New(v.Type().Elem())) - } - v = v.Elem() - } - v = v.Field(x) - } - return v -} - -func (si *structFieldInfo) setToZeroValue(v reflect.Value) { - if si.i != -1 { - v = v.Field(int(si.i)) - v.Set(reflect.Zero(v.Type())) - // v.Set(reflect.New(v.Type()).Elem()) - // v.Set(reflect.New(v.Type())) - } else { - // replicate FieldByIndex - for _, x := range si.is { - for v.Kind() == reflect.Ptr { - if v.IsNil() { - return - } - v = v.Elem() - } - v = v.Field(x) - } - v.Set(reflect.Zero(v.Type())) - } -} - -func parseStructFieldInfo(fname string, stag string) *structFieldInfo { - // if fname == "" { - // panic(noFieldNameToStructFieldInfoErr) - // } - si := structFieldInfo{ - encName: fname, - } - - if stag != "" { - for i, s := range strings.Split(stag, ",") { - if i == 0 { - if s != "" { - si.encName = s - } - } else { - if s == "omitempty" { - si.omitEmpty = true - } else if s == "toarray" { - si.toArray = true - } - } - } - } - // si.encNameBs = []byte(si.encName) - return &si -} - -type sfiSortedByEncName []*structFieldInfo - -func (p sfiSortedByEncName) Len() int { - return len(p) -} - -func (p sfiSortedByEncName) Less(i, j int) bool { - return p[i].encName < p[j].encName -} - -func (p sfiSortedByEncName) Swap(i, j int) { - p[i], p[j] = p[j], p[i] -} - -// typeInfo keeps information about each type referenced in the encode/decode sequence. -// -// During an encode/decode sequence, we work as below: -// - If base is a built in type, en/decode base value -// - If base is registered as an extension, en/decode base value -// - If type is binary(M/Unm)arshaler, call Binary(M/Unm)arshal method -// - If type is text(M/Unm)arshaler, call Text(M/Unm)arshal method -// - Else decode appropriately based on the reflect.Kind -type typeInfo struct { - sfi []*structFieldInfo // sorted. Used when enc/dec struct to map. - sfip []*structFieldInfo // unsorted. Used when enc/dec struct to array. - - rt reflect.Type - rtid uintptr - - numMeth uint16 // number of methods - - // baseId gives pointer to the base reflect.Type, after deferencing - // the pointers. E.g. base type of ***time.Time is time.Time. - base reflect.Type - baseId uintptr - baseIndir int8 // number of indirections to get to base - - mbs bool // base type (T or *T) is a MapBySlice - - bm bool // base type (T or *T) is a binaryMarshaler - bunm bool // base type (T or *T) is a binaryUnmarshaler - bmIndir int8 // number of indirections to get to binaryMarshaler type - bunmIndir int8 // number of indirections to get to binaryUnmarshaler type - - tm bool // base type (T or *T) is a textMarshaler - tunm bool // base type (T or *T) is a textUnmarshaler - tmIndir int8 // number of indirections to get to textMarshaler type - tunmIndir int8 // number of indirections to get to textUnmarshaler type - - jm bool // base type (T or *T) is a jsonMarshaler - junm bool // base type (T or *T) is a jsonUnmarshaler - jmIndir int8 // number of indirections to get to jsonMarshaler type - junmIndir int8 // number of indirections to get to jsonUnmarshaler type - - cs bool // base type (T or *T) is a Selfer - csIndir int8 // number of indirections to get to Selfer type - - toArray bool // whether this (struct) type should be encoded as an array -} - -func (ti *typeInfo) indexForEncName(name string) int { - //tisfi := ti.sfi - const binarySearchThreshold = 16 - if sfilen := len(ti.sfi); sfilen < binarySearchThreshold { - // linear search. faster than binary search in my testing up to 16-field structs. - for i, si := range ti.sfi { - if si.encName == name { - return i - } - } - } else { - // binary search. adapted from sort/search.go. - h, i, j := 0, 0, sfilen - for i < j { - h = i + (j-i)/2 - if ti.sfi[h].encName < name { - i = h + 1 - } else { - j = h - } - } - if i < sfilen && ti.sfi[i].encName == name { - return i - } - } - return -1 -} - -// TypeInfos caches typeInfo for each type on first inspection. -// -// It is configured with a set of tag keys, which are used to get -// configuration for the type. -type TypeInfos struct { - infos map[uintptr]*typeInfo - mu sync.RWMutex - tags []string -} - -// NewTypeInfos creates a TypeInfos given a set of struct tags keys. -// -// This allows users customize the struct tag keys which contain configuration -// of their types. -func NewTypeInfos(tags []string) *TypeInfos { - return &TypeInfos{tags: tags, infos: make(map[uintptr]*typeInfo, 64)} -} - -func (x *TypeInfos) structTag(t reflect.StructTag) (s string) { - // check for tags: codec, json, in that order. - // this allows seamless support for many configured structs. - for _, x := range x.tags { - s = t.Get(x) - if s != "" { - return s - } - } - return -} - -func (x *TypeInfos) get(rtid uintptr, rt reflect.Type) (pti *typeInfo) { - var ok bool - x.mu.RLock() - pti, ok = x.infos[rtid] - x.mu.RUnlock() - if ok { - return - } - - // do not hold lock while computing this. - // it may lead to duplication, but that's ok. - ti := typeInfo{rt: rt, rtid: rtid} - ti.numMeth = uint16(rt.NumMethod()) - - var indir int8 - if ok, indir = implementsIntf(rt, binaryMarshalerTyp); ok { - ti.bm, ti.bmIndir = true, indir - } - if ok, indir = implementsIntf(rt, binaryUnmarshalerTyp); ok { - ti.bunm, ti.bunmIndir = true, indir - } - if ok, indir = implementsIntf(rt, textMarshalerTyp); ok { - ti.tm, ti.tmIndir = true, indir - } - if ok, indir = implementsIntf(rt, textUnmarshalerTyp); ok { - ti.tunm, ti.tunmIndir = true, indir - } - if ok, indir = implementsIntf(rt, jsonMarshalerTyp); ok { - ti.jm, ti.jmIndir = true, indir - } - if ok, indir = implementsIntf(rt, jsonUnmarshalerTyp); ok { - ti.junm, ti.junmIndir = true, indir - } - if ok, indir = implementsIntf(rt, selferTyp); ok { - ti.cs, ti.csIndir = true, indir - } - if ok, _ = implementsIntf(rt, mapBySliceTyp); ok { - ti.mbs = true - } - - pt := rt - var ptIndir int8 - // for ; pt.Kind() == reflect.Ptr; pt, ptIndir = pt.Elem(), ptIndir+1 { } - for pt.Kind() == reflect.Ptr { - pt = pt.Elem() - ptIndir++ - } - if ptIndir == 0 { - ti.base = rt - ti.baseId = rtid - } else { - ti.base = pt - ti.baseId = reflect.ValueOf(pt).Pointer() - ti.baseIndir = ptIndir - } - - if rt.Kind() == reflect.Struct { - var siInfo *structFieldInfo - if f, ok := rt.FieldByName(structInfoFieldName); ok { - siInfo = parseStructFieldInfo(structInfoFieldName, x.structTag(f.Tag)) - ti.toArray = siInfo.toArray - } - sfip := make([]*structFieldInfo, 0, rt.NumField()) - x.rget(rt, nil, make(map[string]bool, 16), &sfip, siInfo) - - ti.sfip = make([]*structFieldInfo, len(sfip)) - ti.sfi = make([]*structFieldInfo, len(sfip)) - copy(ti.sfip, sfip) - sort.Sort(sfiSortedByEncName(sfip)) - copy(ti.sfi, sfip) - } - // sfi = sfip - - x.mu.Lock() - if pti, ok = x.infos[rtid]; !ok { - pti = &ti - x.infos[rtid] = pti - } - x.mu.Unlock() - return -} - -func (x *TypeInfos) rget(rt reflect.Type, indexstack []int, fnameToHastag map[string]bool, - sfi *[]*structFieldInfo, siInfo *structFieldInfo, -) { - for j := 0; j < rt.NumField(); j++ { - f := rt.Field(j) - fkind := f.Type.Kind() - // skip if a func type, or is unexported, or structTag value == "-" - if fkind == reflect.Func { - continue - } - // if r1, _ := utf8.DecodeRuneInString(f.Name); r1 == utf8.RuneError || !unicode.IsUpper(r1) { - if f.PkgPath != "" && !f.Anonymous { // unexported, not embedded - continue - } - stag := x.structTag(f.Tag) - if stag == "-" { - continue - } - var si *structFieldInfo - // if anonymous and no struct tag (or it's blank), and a struct (or pointer to struct), inline it. - if f.Anonymous && fkind != reflect.Interface { - doInline := stag == "" - if !doInline { - si = parseStructFieldInfo("", stag) - doInline = si.encName == "" - // doInline = si.isZero() - } - if doInline { - ft := f.Type - for ft.Kind() == reflect.Ptr { - ft = ft.Elem() - } - if ft.Kind() == reflect.Struct { - indexstack2 := make([]int, len(indexstack)+1, len(indexstack)+4) - copy(indexstack2, indexstack) - indexstack2[len(indexstack)] = j - // indexstack2 := append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) - x.rget(ft, indexstack2, fnameToHastag, sfi, siInfo) - continue - } - } - } - - // after the anonymous dance: if an unexported field, skip - if f.PkgPath != "" { // unexported - continue - } - - // do not let fields with same name in embedded structs override field at higher level. - // this must be done after anonymous check, to allow anonymous field - // still include their child fields - if _, ok := fnameToHastag[f.Name]; ok { - continue - } - if f.Name == "" { - panic(noFieldNameToStructFieldInfoErr) - } - if si == nil { - si = parseStructFieldInfo(f.Name, stag) - } else if si.encName == "" { - si.encName = f.Name - } - // si.ikind = int(f.Type.Kind()) - if len(indexstack) == 0 { - si.i = int16(j) - } else { - si.i = -1 - si.is = append(append(make([]int, 0, len(indexstack)+4), indexstack...), j) - } - - if siInfo != nil { - if siInfo.omitEmpty { - si.omitEmpty = true - } - } - *sfi = append(*sfi, si) - fnameToHastag[f.Name] = stag != "" - } -} - -func panicToErr(err *error) { - if recoverPanicToErr { - if x := recover(); x != nil { - //debug.PrintStack() - panicValToErr(x, err) - } - } -} - -// func doPanic(tag string, format string, params ...interface{}) { -// params2 := make([]interface{}, len(params)+1) -// params2[0] = tag -// copy(params2[1:], params) -// panic(fmt.Errorf("%s: "+format, params2...)) -// } - -func isImmutableKind(k reflect.Kind) (v bool) { - return false || - k == reflect.Int || - k == reflect.Int8 || - k == reflect.Int16 || - k == reflect.Int32 || - k == reflect.Int64 || - k == reflect.Uint || - k == reflect.Uint8 || - k == reflect.Uint16 || - k == reflect.Uint32 || - k == reflect.Uint64 || - k == reflect.Uintptr || - k == reflect.Float32 || - k == reflect.Float64 || - k == reflect.Bool || - k == reflect.String -} - -// these functions must be inlinable, and not call anybody -type checkOverflow struct{} - -func (_ checkOverflow) Float32(f float64) (overflow bool) { - if f < 0 { - f = -f - } - return math.MaxFloat32 < f && f <= math.MaxFloat64 -} - -func (_ checkOverflow) Uint(v uint64, bitsize uint8) (overflow bool) { - if bitsize == 0 || bitsize >= 64 || v == 0 { - return - } - if trunc := (v << (64 - bitsize)) >> (64 - bitsize); v != trunc { - overflow = true - } - return -} - -func (_ checkOverflow) Int(v int64, bitsize uint8) (overflow bool) { - if bitsize == 0 || bitsize >= 64 || v == 0 { - return - } - if trunc := (v << (64 - bitsize)) >> (64 - bitsize); v != trunc { - overflow = true - } - return -} - -func (_ checkOverflow) SignedInt(v uint64) (i int64, overflow bool) { - //e.g. -127 to 128 for int8 - pos := (v >> 63) == 0 - ui2 := v & 0x7fffffffffffffff - if pos { - if ui2 > math.MaxInt64 { - overflow = true - return - } - } else { - if ui2 > math.MaxInt64-1 { - overflow = true - return - } - } - i = int64(v) - return -} - -// ------------------ SORT ----------------- - -func isNaN(f float64) bool { return f != f } - -// ----------------------- - -type intSlice []int64 -type uintSlice []uint64 -type floatSlice []float64 -type boolSlice []bool -type stringSlice []string -type bytesSlice [][]byte - -func (p intSlice) Len() int { return len(p) } -func (p intSlice) Less(i, j int) bool { return p[i] < p[j] } -func (p intSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p uintSlice) Len() int { return len(p) } -func (p uintSlice) Less(i, j int) bool { return p[i] < p[j] } -func (p uintSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p floatSlice) Len() int { return len(p) } -func (p floatSlice) Less(i, j int) bool { - return p[i] < p[j] || isNaN(p[i]) && !isNaN(p[j]) -} -func (p floatSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p stringSlice) Len() int { return len(p) } -func (p stringSlice) Less(i, j int) bool { return p[i] < p[j] } -func (p stringSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p bytesSlice) Len() int { return len(p) } -func (p bytesSlice) Less(i, j int) bool { return bytes.Compare(p[i], p[j]) == -1 } -func (p bytesSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p boolSlice) Len() int { return len(p) } -func (p boolSlice) Less(i, j int) bool { return !p[i] && p[j] } -func (p boolSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -// --------------------- - -type intRv struct { - v int64 - r reflect.Value -} -type intRvSlice []intRv -type uintRv struct { - v uint64 - r reflect.Value -} -type uintRvSlice []uintRv -type floatRv struct { - v float64 - r reflect.Value -} -type floatRvSlice []floatRv -type boolRv struct { - v bool - r reflect.Value -} -type boolRvSlice []boolRv -type stringRv struct { - v string - r reflect.Value -} -type stringRvSlice []stringRv -type bytesRv struct { - v []byte - r reflect.Value -} -type bytesRvSlice []bytesRv - -func (p intRvSlice) Len() int { return len(p) } -func (p intRvSlice) Less(i, j int) bool { return p[i].v < p[j].v } -func (p intRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p uintRvSlice) Len() int { return len(p) } -func (p uintRvSlice) Less(i, j int) bool { return p[i].v < p[j].v } -func (p uintRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p floatRvSlice) Len() int { return len(p) } -func (p floatRvSlice) Less(i, j int) bool { - return p[i].v < p[j].v || isNaN(p[i].v) && !isNaN(p[j].v) -} -func (p floatRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p stringRvSlice) Len() int { return len(p) } -func (p stringRvSlice) Less(i, j int) bool { return p[i].v < p[j].v } -func (p stringRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p bytesRvSlice) Len() int { return len(p) } -func (p bytesRvSlice) Less(i, j int) bool { return bytes.Compare(p[i].v, p[j].v) == -1 } -func (p bytesRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -func (p boolRvSlice) Len() int { return len(p) } -func (p boolRvSlice) Less(i, j int) bool { return !p[i].v && p[j].v } -func (p boolRvSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } - -// ----------------- - -type bytesI struct { - v []byte - i interface{} -} - -type bytesISlice []bytesI - -func (p bytesISlice) Len() int { return len(p) } -func (p bytesISlice) Less(i, j int) bool { return bytes.Compare(p[i].v, p[j].v) == -1 } -func (p bytesISlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] } diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_internal.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_internal.go deleted file mode 100644 index dea981f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_internal.go +++ /dev/null @@ -1,242 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -// All non-std package dependencies live in this file, -// so porting to different environment is easy (just update functions). - -import ( - "errors" - "fmt" - "math" - "reflect" -) - -func panicValToErr(panicVal interface{}, err *error) { - if panicVal == nil { - return - } - // case nil - switch xerr := panicVal.(type) { - case error: - *err = xerr - case string: - *err = errors.New(xerr) - default: - *err = fmt.Errorf("%v", panicVal) - } - return -} - -func hIsEmptyValue(v reflect.Value, deref, checkStruct bool) bool { - switch v.Kind() { - case reflect.Invalid: - return true - case reflect.Array, reflect.Map, reflect.Slice, reflect.String: - return v.Len() == 0 - case reflect.Bool: - return !v.Bool() - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return v.Uint() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.Interface, reflect.Ptr: - if deref { - if v.IsNil() { - return true - } - return hIsEmptyValue(v.Elem(), deref, checkStruct) - } else { - return v.IsNil() - } - case reflect.Struct: - if !checkStruct { - return false - } - // return true if all fields are empty. else return false. - // we cannot use equality check, because some fields may be maps/slices/etc - // and consequently the structs are not comparable. - // return v.Interface() == reflect.Zero(v.Type()).Interface() - for i, n := 0, v.NumField(); i < n; i++ { - if !hIsEmptyValue(v.Field(i), deref, checkStruct) { - return false - } - } - return true - } - return false -} - -func isEmptyValue(v reflect.Value) bool { - return hIsEmptyValue(v, derefForIsEmptyValue, checkStructForEmptyValue) -} - -func pruneSignExt(v []byte, pos bool) (n int) { - if len(v) < 2 { - } else if pos && v[0] == 0 { - for ; v[n] == 0 && n+1 < len(v) && (v[n+1]&(1<<7) == 0); n++ { - } - } else if !pos && v[0] == 0xff { - for ; v[n] == 0xff && n+1 < len(v) && (v[n+1]&(1<<7) != 0); n++ { - } - } - return -} - -func implementsIntf(typ, iTyp reflect.Type) (success bool, indir int8) { - if typ == nil { - return - } - rt := typ - // The type might be a pointer and we need to keep - // dereferencing to the base type until we find an implementation. - for { - if rt.Implements(iTyp) { - return true, indir - } - if p := rt; p.Kind() == reflect.Ptr { - indir++ - if indir >= math.MaxInt8 { // insane number of indirections - return false, 0 - } - rt = p.Elem() - continue - } - break - } - // No luck yet, but if this is a base type (non-pointer), the pointer might satisfy. - if typ.Kind() != reflect.Ptr { - // Not a pointer, but does the pointer work? - if reflect.PtrTo(typ).Implements(iTyp) { - return true, -1 - } - } - return false, 0 -} - -// validate that this function is correct ... -// culled from OGRE (Object-Oriented Graphics Rendering Engine) -// function: halfToFloatI (http://stderr.org/doc/ogre-doc/api/OgreBitwise_8h-source.html) -func halfFloatToFloatBits(yy uint16) (d uint32) { - y := uint32(yy) - s := (y >> 15) & 0x01 - e := (y >> 10) & 0x1f - m := y & 0x03ff - - if e == 0 { - if m == 0 { // plu or minus 0 - return s << 31 - } else { // Denormalized number -- renormalize it - for (m & 0x00000400) == 0 { - m <<= 1 - e -= 1 - } - e += 1 - const zz uint32 = 0x0400 - m &= ^zz - } - } else if e == 31 { - if m == 0 { // Inf - return (s << 31) | 0x7f800000 - } else { // NaN - return (s << 31) | 0x7f800000 | (m << 13) - } - } - e = e + (127 - 15) - m = m << 13 - return (s << 31) | (e << 23) | m -} - -// GrowCap will return a new capacity for a slice, given the following: -// - oldCap: current capacity -// - unit: in-memory size of an element -// - num: number of elements to add -func growCap(oldCap, unit, num int) (newCap int) { - // appendslice logic (if cap < 1024, *2, else *1.25): - // leads to many copy calls, especially when copying bytes. - // bytes.Buffer model (2*cap + n): much better for bytes. - // smarter way is to take the byte-size of the appended element(type) into account - - // maintain 3 thresholds: - // t1: if cap <= t1, newcap = 2x - // t2: if cap <= t2, newcap = 1.75x - // t3: if cap <= t3, newcap = 1.5x - // else newcap = 1.25x - // - // t1, t2, t3 >= 1024 always. - // i.e. if unit size >= 16, then always do 2x or 1.25x (ie t1, t2, t3 are all same) - // - // With this, appending for bytes increase by: - // 100% up to 4K - // 75% up to 8K - // 50% up to 16K - // 25% beyond that - - // unit can be 0 e.g. for struct{}{}; handle that appropriately - var t1, t2, t3 int // thresholds - if unit <= 1 { - t1, t2, t3 = 4*1024, 8*1024, 16*1024 - } else if unit < 16 { - t3 = 16 / unit * 1024 - t1 = t3 * 1 / 4 - t2 = t3 * 2 / 4 - } else { - t1, t2, t3 = 1024, 1024, 1024 - } - - var x int // temporary variable - - // x is multiplier here: one of 5, 6, 7 or 8; incr of 25%, 50%, 75% or 100% respectively - if oldCap <= t1 { // [0,t1] - x = 8 - } else if oldCap > t3 { // (t3,infinity] - x = 5 - } else if oldCap <= t2 { // (t1,t2] - x = 7 - } else { // (t2,t3] - x = 6 - } - newCap = x * oldCap / 4 - - if num > 0 { - newCap += num - } - - // ensure newCap is a multiple of 64 (if it is > 64) or 16. - if newCap > 64 { - if x = newCap % 64; x != 0 { - x = newCap / 64 - newCap = 64 * (x + 1) - } - } else { - if x = newCap % 16; x != 0 { - x = newCap / 16 - newCap = 16 * (x + 1) - } - } - return -} - -func expandSliceValue(s reflect.Value, num int) reflect.Value { - if num <= 0 { - return s - } - l0 := s.Len() - l1 := l0 + num // new slice length - if l1 < l0 { - panic("ExpandSlice: slice overflow") - } - c0 := s.Cap() - if l1 <= c0 { - return s.Slice(0, l1) - } - st := s.Type() - c1 := growCap(c0, int(st.Elem().Size()), num) - s2 := reflect.MakeSlice(st, l1, c1) - // println("expandslicevalue: cap-old: ", c0, ", cap-new: ", c1, ", len-new: ", l1) - reflect.Copy(s2, s) - return s2 -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go deleted file mode 100644 index 7c2ffc0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_not_unsafe.go +++ /dev/null @@ -1,20 +0,0 @@ -//+build !unsafe - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -// stringView returns a view of the []byte as a string. -// In unsafe mode, it doesn't incur allocation and copying caused by conversion. -// In regular safe mode, it is an allocation and copy. -func stringView(v []byte) string { - return string(v) -} - -// bytesView returns a view of the string as a []byte. -// In unsafe mode, it doesn't incur allocation and copying caused by conversion. -// In regular safe mode, it is an allocation and copy. -func bytesView(v string) []byte { - return []byte(v) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_unsafe.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_unsafe.go deleted file mode 100644 index 373b2b1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/helper_unsafe.go +++ /dev/null @@ -1,45 +0,0 @@ -//+build unsafe - -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "unsafe" -) - -// This file has unsafe variants of some helper methods. - -type unsafeString struct { - Data uintptr - Len int -} - -type unsafeBytes struct { - Data uintptr - Len int - Cap int -} - -// stringView returns a view of the []byte as a string. -// In unsafe mode, it doesn't incur allocation and copying caused by conversion. -// In regular safe mode, it is an allocation and copy. -func stringView(v []byte) string { - if len(v) == 0 { - return "" - } - x := unsafeString{uintptr(unsafe.Pointer(&v[0])), len(v)} - return *(*string)(unsafe.Pointer(&x)) -} - -// bytesView returns a view of the string as a []byte. -// In unsafe mode, it doesn't incur allocation and copying caused by conversion. -// In regular safe mode, it is an allocation and copy. -func bytesView(v string) []byte { - if len(v) == 0 { - return zeroByteSlice - } - x := unsafeBytes{uintptr(unsafe.Pointer(&v)), len(v), len(v)} - return *(*[]byte)(unsafe.Pointer(&x)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/json.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/json.go deleted file mode 100644 index a18a5f7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/json.go +++ /dev/null @@ -1,1072 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -// By default, this json support uses base64 encoding for bytes, because you cannot -// store and read any arbitrary string in json (only unicode). -// However, the user can configre how to encode/decode bytes. -// -// This library specifically supports UTF-8 for encoding and decoding only. -// -// Note that the library will happily encode/decode things which are not valid -// json e.g. a map[int64]string. We do it for consistency. With valid json, -// we will encode and decode appropriately. -// Users can specify their map type if necessary to force it. -// -// Note: -// - we cannot use strconv.Quote and strconv.Unquote because json quotes/unquotes differently. -// We implement it here. -// - Also, strconv.ParseXXX for floats and integers -// - only works on strings resulting in unnecessary allocation and []byte-string conversion. -// - it does a lot of redundant checks, because json numbers are simpler that what it supports. -// - We parse numbers (floats and integers) directly here. -// We only delegate parsing floats if it is a hairy float which could cause a loss of precision. -// In that case, we delegate to strconv.ParseFloat. -// -// Note: -// - encode does not beautify. There is no whitespace when encoding. -// - rpc calls which take single integer arguments or write single numeric arguments will need care. - -// Top-level methods of json(End|Dec)Driver (which are implementations of (en|de)cDriver -// MUST not call one-another. - -import ( - "bytes" - "encoding/base64" - "fmt" - "reflect" - "strconv" - "unicode/utf16" - "unicode/utf8" -) - -//-------------------------------- - -var jsonLiterals = [...]byte{'t', 'r', 'u', 'e', 'f', 'a', 'l', 's', 'e', 'n', 'u', 'l', 'l'} - -var jsonFloat64Pow10 = [...]float64{ - 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, - 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, - 1e20, 1e21, 1e22, -} - -var jsonUint64Pow10 = [...]uint64{ - 1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9, - 1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19, -} - -const ( - // jsonUnreadAfterDecNum controls whether we unread after decoding a number. - // - // instead of unreading, just update d.tok (iff it's not a whitespace char) - // However, doing this means that we may HOLD onto some data which belongs to another stream. - // Thus, it is safest to unread the data when done. - // keep behind a constant flag for now. - jsonUnreadAfterDecNum = true - - // If !jsonValidateSymbols, decoding will be faster, by skipping some checks: - // - If we see first character of null, false or true, - // do not validate subsequent characters. - // - e.g. if we see a n, assume null and skip next 3 characters, - // and do not validate they are ull. - // P.S. Do not expect a significant decoding boost from this. - jsonValidateSymbols = true - - // if jsonTruncateMantissa, truncate mantissa if trailing 0's. - // This is important because it could allow some floats to be decoded without - // deferring to strconv.ParseFloat. - jsonTruncateMantissa = true - - // if mantissa >= jsonNumUintCutoff before multiplying by 10, this is an overflow - jsonNumUintCutoff = (1<<64-1)/uint64(10) + 1 // cutoff64(base) - - // if mantissa >= jsonNumUintMaxVal, this is an overflow - jsonNumUintMaxVal = 1<= slen { - e.bs = e.bs[:slen] - } else { - e.bs = make([]byte, slen) - } - base64.StdEncoding.Encode(e.bs, v) - e.w.writen1('"') - e.w.writeb(e.bs) - e.w.writen1('"') - } else { - // e.EncodeString(c, string(v)) - e.quoteStr(stringView(v)) - } -} - -func (e *jsonEncDriver) EncodeAsis(v []byte) { - e.w.writeb(v) -} - -func (e *jsonEncDriver) quoteStr(s string) { - // adapted from std pkg encoding/json - const hex = "0123456789abcdef" - w := e.w - w.writen1('"') - start := 0 - for i := 0; i < len(s); { - if b := s[i]; b < utf8.RuneSelf { - if 0x20 <= b && b != '\\' && b != '"' && b != '<' && b != '>' && b != '&' { - i++ - continue - } - if start < i { - w.writestr(s[start:i]) - } - switch b { - case '\\', '"': - w.writen2('\\', b) - case '\n': - w.writen2('\\', 'n') - case '\r': - w.writen2('\\', 'r') - case '\b': - w.writen2('\\', 'b') - case '\f': - w.writen2('\\', 'f') - case '\t': - w.writen2('\\', 't') - default: - // encode all bytes < 0x20 (except \r, \n). - // also encode < > & to prevent security holes when served to some browsers. - w.writestr(`\u00`) - w.writen2(hex[b>>4], hex[b&0xF]) - } - i++ - start = i - continue - } - c, size := utf8.DecodeRuneInString(s[i:]) - if c == utf8.RuneError && size == 1 { - if start < i { - w.writestr(s[start:i]) - } - w.writestr(`\ufffd`) - i += size - start = i - continue - } - // U+2028 is LINE SEPARATOR. U+2029 is PARAGRAPH SEPARATOR. - // Both technically valid JSON, but bomb on JSONP, so fix here. - if c == '\u2028' || c == '\u2029' { - if start < i { - w.writestr(s[start:i]) - } - w.writestr(`\u202`) - w.writen1(hex[c&0xF]) - i += size - start = i - continue - } - i += size - } - if start < len(s) { - w.writestr(s[start:]) - } - w.writen1('"') -} - -//-------------------------------- - -type jsonNum struct { - // bytes []byte // may have [+-.eE0-9] - mantissa uint64 // where mantissa ends, and maybe dot begins. - exponent int16 // exponent value. - manOverflow bool - neg bool // started with -. No initial sign in the bytes above. - dot bool // has dot - explicitExponent bool // explicit exponent -} - -func (x *jsonNum) reset() { - x.manOverflow = false - x.neg = false - x.dot = false - x.explicitExponent = false - x.mantissa = 0 - x.exponent = 0 -} - -// uintExp is called only if exponent > 0. -func (x *jsonNum) uintExp() (n uint64, overflow bool) { - n = x.mantissa - e := x.exponent - if e >= int16(len(jsonUint64Pow10)) { - overflow = true - return - } - n *= jsonUint64Pow10[e] - if n < x.mantissa || n > jsonNumUintMaxVal { - overflow = true - return - } - return - // for i := int16(0); i < e; i++ { - // if n >= jsonNumUintCutoff { - // overflow = true - // return - // } - // n *= 10 - // } - // return -} - -// these constants are only used withn floatVal. -// They are brought out, so that floatVal can be inlined. -const ( - jsonUint64MantissaBits = 52 - jsonMaxExponent = int16(len(jsonFloat64Pow10)) - 1 -) - -func (x *jsonNum) floatVal() (f float64, parseUsingStrConv bool) { - // We do not want to lose precision. - // Consequently, we will delegate to strconv.ParseFloat if any of the following happen: - // - There are more digits than in math.MaxUint64: 18446744073709551615 (20 digits) - // We expect up to 99.... (19 digits) - // - The mantissa cannot fit into a 52 bits of uint64 - // - The exponent is beyond our scope ie beyong 22. - parseUsingStrConv = x.manOverflow || - x.exponent > jsonMaxExponent || - (x.exponent < 0 && -(x.exponent) > jsonMaxExponent) || - x.mantissa>>jsonUint64MantissaBits != 0 - - if parseUsingStrConv { - return - } - - // all good. so handle parse here. - f = float64(x.mantissa) - // fmt.Printf(".Float: uint64 value: %v, float: %v\n", m, f) - if x.neg { - f = -f - } - if x.exponent > 0 { - f *= jsonFloat64Pow10[x.exponent] - } else if x.exponent < 0 { - f /= jsonFloat64Pow10[-x.exponent] - } - return -} - -type jsonDecDriver struct { - noBuiltInTypes - d *Decoder - h *JsonHandle - r decReader - - c containerState - // tok is used to store the token read right after skipWhiteSpace. - tok uint8 - - bstr [8]byte // scratch used for string \UXXX parsing - b [64]byte // scratch, used for parsing strings or numbers - b2 [64]byte // scratch, used only for decodeBytes (after base64) - bs []byte // scratch. Initialized from b. Used for parsing strings or numbers. - - se setExtWrapper - - n jsonNum -} - -func jsonIsWS(b byte) bool { - return b == ' ' || b == '\t' || b == '\r' || b == '\n' -} - -// // This will skip whitespace characters and return the next byte to read. -// // The next byte determines what the value will be one of. -// func (d *jsonDecDriver) skipWhitespace() { -// // fast-path: do not enter loop. Just check first (in case no whitespace). -// b := d.r.readn1() -// if jsonIsWS(b) { -// r := d.r -// for b = r.readn1(); jsonIsWS(b); b = r.readn1() { -// } -// } -// d.tok = b -// } - -func (d *jsonDecDriver) uncacheRead() { - if d.tok != 0 { - d.r.unreadn1() - d.tok = 0 - } -} - -func (d *jsonDecDriver) sendContainerState(c containerState) { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - var xc uint8 // char expected - if c == containerMapKey { - if d.c != containerMapStart { - xc = ',' - } - } else if c == containerMapValue { - xc = ':' - } else if c == containerMapEnd { - xc = '}' - } else if c == containerArrayElem { - if d.c != containerArrayStart { - xc = ',' - } - } else if c == containerArrayEnd { - xc = ']' - } - if xc != 0 { - if d.tok != xc { - d.d.errorf("json: expect char '%c' but got char '%c'", xc, d.tok) - } - d.tok = 0 - } - d.c = c -} - -func (d *jsonDecDriver) CheckBreak() bool { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok == '}' || d.tok == ']' { - // d.tok = 0 // only checking, not consuming - return true - } - return false -} - -func (d *jsonDecDriver) readStrIdx(fromIdx, toIdx uint8) { - bs := d.r.readx(int(toIdx - fromIdx)) - d.tok = 0 - if jsonValidateSymbols { - if !bytes.Equal(bs, jsonLiterals[fromIdx:toIdx]) { - d.d.errorf("json: expecting %s: got %s", jsonLiterals[fromIdx:toIdx], bs) - return - } - } -} - -func (d *jsonDecDriver) TryDecodeAsNil() bool { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok == 'n' { - d.readStrIdx(10, 13) // ull - return true - } - return false -} - -func (d *jsonDecDriver) DecodeBool() bool { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok == 'f' { - d.readStrIdx(5, 9) // alse - return false - } - if d.tok == 't' { - d.readStrIdx(1, 4) // rue - return true - } - d.d.errorf("json: decode bool: got first char %c", d.tok) - return false // "unreachable" -} - -func (d *jsonDecDriver) ReadMapStart() int { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok != '{' { - d.d.errorf("json: expect char '%c' but got char '%c'", '{', d.tok) - } - d.tok = 0 - d.c = containerMapStart - return -1 -} - -func (d *jsonDecDriver) ReadArrayStart() int { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok != '[' { - d.d.errorf("json: expect char '%c' but got char '%c'", '[', d.tok) - } - d.tok = 0 - d.c = containerArrayStart - return -1 -} - -func (d *jsonDecDriver) ContainerType() (vt valueType) { - // check container type by checking the first char - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if b := d.tok; b == '{' { - return valueTypeMap - } else if b == '[' { - return valueTypeArray - } else if b == 'n' { - return valueTypeNil - } else if b == '"' { - return valueTypeString - } - return valueTypeUnset - // d.d.errorf("isContainerType: unsupported parameter: %v", vt) - // return false // "unreachable" -} - -func (d *jsonDecDriver) decNum(storeBytes bool) { - // If it is has a . or an e|E, decode as a float; else decode as an int. - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - b := d.tok - if !(b == '+' || b == '-' || b == '.' || (b >= '0' && b <= '9')) { - d.d.errorf("json: decNum: got first char '%c'", b) - return - } - d.tok = 0 - - const cutoff = (1<<64-1)/uint64(10) + 1 // cutoff64(base) - const jsonNumUintMaxVal = 1<= jsonNumUintCutoff { - n.manOverflow = true - break - } - v := uint64(b - '0') - n.mantissa *= 10 - if v != 0 { - n1 := n.mantissa + v - if n1 < n.mantissa || n1 > jsonNumUintMaxVal { - n.manOverflow = true // n+v overflows - break - } - n.mantissa = n1 - } - case 6: - state = 7 - fallthrough - case 7: - if !(b == '0' && e == 0) { - e = e*10 + int16(b-'0') - } - default: - break LOOP - } - default: - break LOOP - } - if storeBytes { - d.bs = append(d.bs, b) - } - b, eof = r.readn1eof() - } - - if jsonTruncateMantissa && n.mantissa != 0 { - for n.mantissa%10 == 0 { - n.mantissa /= 10 - n.exponent++ - } - } - - if e != 0 { - if eNeg { - n.exponent -= e - } else { - n.exponent += e - } - } - - // d.n = n - - if !eof { - if jsonUnreadAfterDecNum { - r.unreadn1() - } else { - if !jsonIsWS(b) { - d.tok = b - } - } - } - // fmt.Printf("1: n: bytes: %s, neg: %v, dot: %v, exponent: %v, mantissaEndIndex: %v\n", - // n.bytes, n.neg, n.dot, n.exponent, n.mantissaEndIndex) - return -} - -func (d *jsonDecDriver) DecodeInt(bitsize uint8) (i int64) { - d.decNum(false) - n := &d.n - if n.manOverflow { - d.d.errorf("json: overflow integer after: %v", n.mantissa) - return - } - var u uint64 - if n.exponent == 0 { - u = n.mantissa - } else if n.exponent < 0 { - d.d.errorf("json: fractional integer") - return - } else if n.exponent > 0 { - var overflow bool - if u, overflow = n.uintExp(); overflow { - d.d.errorf("json: overflow integer") - return - } - } - i = int64(u) - if n.neg { - i = -i - } - if chkOvf.Int(i, bitsize) { - d.d.errorf("json: overflow %v bits: %s", bitsize, d.bs) - return - } - // fmt.Printf("DecodeInt: %v\n", i) - return -} - -// floatVal MUST only be called after a decNum, as d.bs now contains the bytes of the number -func (d *jsonDecDriver) floatVal() (f float64) { - f, useStrConv := d.n.floatVal() - if useStrConv { - var err error - if f, err = strconv.ParseFloat(stringView(d.bs), 64); err != nil { - panic(fmt.Errorf("parse float: %s, %v", d.bs, err)) - } - if d.n.neg { - f = -f - } - } - return -} - -func (d *jsonDecDriver) DecodeUint(bitsize uint8) (u uint64) { - d.decNum(false) - n := &d.n - if n.neg { - d.d.errorf("json: unsigned integer cannot be negative") - return - } - if n.manOverflow { - d.d.errorf("json: overflow integer after: %v", n.mantissa) - return - } - if n.exponent == 0 { - u = n.mantissa - } else if n.exponent < 0 { - d.d.errorf("json: fractional integer") - return - } else if n.exponent > 0 { - var overflow bool - if u, overflow = n.uintExp(); overflow { - d.d.errorf("json: overflow integer") - return - } - } - if chkOvf.Uint(u, bitsize) { - d.d.errorf("json: overflow %v bits: %s", bitsize, d.bs) - return - } - // fmt.Printf("DecodeUint: %v\n", u) - return -} - -func (d *jsonDecDriver) DecodeFloat(chkOverflow32 bool) (f float64) { - d.decNum(true) - f = d.floatVal() - if chkOverflow32 && chkOvf.Float32(f) { - d.d.errorf("json: overflow float32: %v, %s", f, d.bs) - return - } - return -} - -func (d *jsonDecDriver) DecodeExt(rv interface{}, xtag uint64, ext Ext) (realxtag uint64) { - if ext == nil { - re := rv.(*RawExt) - re.Tag = xtag - d.d.decode(&re.Value) - } else { - var v interface{} - d.d.decode(&v) - ext.UpdateExt(rv, v) - } - return -} - -func (d *jsonDecDriver) DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) { - // if decoding into raw bytes, and the RawBytesExt is configured, use it to decode. - if !isstring && d.se.i != nil { - bsOut = bs - d.DecodeExt(&bsOut, 0, &d.se) - return - } - d.appendStringAsBytes() - // if isstring, then just return the bytes, even if it is using the scratch buffer. - // the bytes will be converted to a string as needed. - if isstring { - return d.bs - } - bs0 := d.bs - slen := base64.StdEncoding.DecodedLen(len(bs0)) - if slen <= cap(bs) { - bsOut = bs[:slen] - } else if zerocopy && slen <= cap(d.b2) { - bsOut = d.b2[:slen] - } else { - bsOut = make([]byte, slen) - } - slen2, err := base64.StdEncoding.Decode(bsOut, bs0) - if err != nil { - d.d.errorf("json: error decoding base64 binary '%s': %v", bs0, err) - return nil - } - if slen != slen2 { - bsOut = bsOut[:slen2] - } - return -} - -func (d *jsonDecDriver) DecodeString() (s string) { - d.appendStringAsBytes() - // if x := d.s.sc; x != nil && x.so && x.st == '}' { // map key - if d.c == containerMapKey { - return d.d.string(d.bs) - } - return string(d.bs) -} - -func (d *jsonDecDriver) appendStringAsBytes() { - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - if d.tok != '"' { - d.d.errorf("json: expect char '%c' but got char '%c'", '"', d.tok) - } - d.tok = 0 - - v := d.bs[:0] - var c uint8 - r := d.r - for { - c = r.readn1() - if c == '"' { - break - } else if c == '\\' { - c = r.readn1() - switch c { - case '"', '\\', '/', '\'': - v = append(v, c) - case 'b': - v = append(v, '\b') - case 'f': - v = append(v, '\f') - case 'n': - v = append(v, '\n') - case 'r': - v = append(v, '\r') - case 't': - v = append(v, '\t') - case 'u': - rr := d.jsonU4(false) - // fmt.Printf("$$$$$$$$$: is surrogate: %v\n", utf16.IsSurrogate(rr)) - if utf16.IsSurrogate(rr) { - rr = utf16.DecodeRune(rr, d.jsonU4(true)) - } - w2 := utf8.EncodeRune(d.bstr[:], rr) - v = append(v, d.bstr[:w2]...) - default: - d.d.errorf("json: unsupported escaped value: %c", c) - } - } else { - v = append(v, c) - } - } - d.bs = v -} - -func (d *jsonDecDriver) jsonU4(checkSlashU bool) rune { - r := d.r - if checkSlashU && !(r.readn1() == '\\' && r.readn1() == 'u') { - d.d.errorf(`json: unquoteStr: invalid unicode sequence. Expecting \u`) - return 0 - } - // u, _ := strconv.ParseUint(string(d.bstr[:4]), 16, 64) - var u uint32 - for i := 0; i < 4; i++ { - v := r.readn1() - if '0' <= v && v <= '9' { - v = v - '0' - } else if 'a' <= v && v <= 'z' { - v = v - 'a' + 10 - } else if 'A' <= v && v <= 'Z' { - v = v - 'A' + 10 - } else { - d.d.errorf(`json: unquoteStr: invalid hex char in \u unicode sequence: %q`, v) - return 0 - } - u = u*16 + uint32(v) - } - return rune(u) -} - -func (d *jsonDecDriver) DecodeNaked() { - z := &d.d.n - // var decodeFurther bool - - if d.tok == 0 { - var b byte - r := d.r - for b = r.readn1(); jsonIsWS(b); b = r.readn1() { - } - d.tok = b - } - switch d.tok { - case 'n': - d.readStrIdx(10, 13) // ull - z.v = valueTypeNil - case 'f': - d.readStrIdx(5, 9) // alse - z.v = valueTypeBool - z.b = false - case 't': - d.readStrIdx(1, 4) // rue - z.v = valueTypeBool - z.b = true - case '{': - z.v = valueTypeMap - // d.tok = 0 // don't consume. kInterfaceNaked will call ReadMapStart - // decodeFurther = true - case '[': - z.v = valueTypeArray - // d.tok = 0 // don't consume. kInterfaceNaked will call ReadArrayStart - // decodeFurther = true - case '"': - z.v = valueTypeString - z.s = d.DecodeString() - default: // number - d.decNum(true) - n := &d.n - // if the string had a any of [.eE], then decode as float. - switch { - case n.explicitExponent, n.dot, n.exponent < 0, n.manOverflow: - z.v = valueTypeFloat - z.f = d.floatVal() - case n.exponent == 0: - u := n.mantissa - switch { - case n.neg: - z.v = valueTypeInt - z.i = -int64(u) - case d.h.SignedInteger: - z.v = valueTypeInt - z.i = int64(u) - default: - z.v = valueTypeUint - z.u = u - } - default: - u, overflow := n.uintExp() - switch { - case overflow: - z.v = valueTypeFloat - z.f = d.floatVal() - case n.neg: - z.v = valueTypeInt - z.i = -int64(u) - case d.h.SignedInteger: - z.v = valueTypeInt - z.i = int64(u) - default: - z.v = valueTypeUint - z.u = u - } - } - // fmt.Printf("DecodeNaked: Number: %T, %v\n", v, v) - } - // if decodeFurther { - // d.s.sc.retryRead() - // } - return -} - -//---------------------- - -// JsonHandle is a handle for JSON encoding format. -// -// Json is comprehensively supported: -// - decodes numbers into interface{} as int, uint or float64 -// - configurable way to encode/decode []byte . -// by default, encodes and decodes []byte using base64 Std Encoding -// - UTF-8 support for encoding and decoding -// -// It has better performance than the json library in the standard library, -// by leveraging the performance improvements of the codec library and -// minimizing allocations. -// -// In addition, it doesn't read more bytes than necessary during a decode, which allows -// reading multiple values from a stream containing json and non-json content. -// For example, a user can read a json value, then a cbor value, then a msgpack value, -// all from the same stream in sequence. -type JsonHandle struct { - textEncodingType - BasicHandle - // RawBytesExt, if configured, is used to encode and decode raw bytes in a custom way. - // If not configured, raw bytes are encoded to/from base64 text. - RawBytesExt InterfaceExt -} - -func (h *JsonHandle) SetInterfaceExt(rt reflect.Type, tag uint64, ext InterfaceExt) (err error) { - return h.SetExt(rt, tag, &setExtWrapper{i: ext}) -} - -func (h *JsonHandle) newEncDriver(e *Encoder) encDriver { - hd := jsonEncDriver{e: e, w: e.w, h: h} - hd.bs = hd.b[:0] - hd.se.i = h.RawBytesExt - return &hd -} - -func (h *JsonHandle) newDecDriver(d *Decoder) decDriver { - // d := jsonDecDriver{r: r.(*bytesDecReader), h: h} - hd := jsonDecDriver{d: d, r: d.r, h: h} - hd.bs = hd.b[:0] - hd.se.i = h.RawBytesExt - return &hd -} - -func (e *jsonEncDriver) reset() { - e.w = e.e.w -} - -func (d *jsonDecDriver) reset() { - d.r = d.d.r -} - -var jsonEncodeTerminate = []byte{' '} - -func (h *JsonHandle) rpcEncodeTerminate() []byte { - return jsonEncodeTerminate -} - -var _ decDriver = (*jsonDecDriver)(nil) -var _ encDriver = (*jsonEncDriver)(nil) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/msgpack.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/msgpack.go deleted file mode 100644 index 5eb4c96..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/msgpack.go +++ /dev/null @@ -1,844 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -/* -MSGPACK - -Msgpack-c implementation powers the c, c++, python, ruby, etc libraries. -We need to maintain compatibility with it and how it encodes integer values -without caring about the type. - -For compatibility with behaviour of msgpack-c reference implementation: - - Go intX (>0) and uintX - IS ENCODED AS - msgpack +ve fixnum, unsigned - - Go intX (<0) - IS ENCODED AS - msgpack -ve fixnum, signed - -*/ -package codec - -import ( - "fmt" - "io" - "math" - "net/rpc" - "reflect" -) - -const ( - mpPosFixNumMin byte = 0x00 - mpPosFixNumMax = 0x7f - mpFixMapMin = 0x80 - mpFixMapMax = 0x8f - mpFixArrayMin = 0x90 - mpFixArrayMax = 0x9f - mpFixStrMin = 0xa0 - mpFixStrMax = 0xbf - mpNil = 0xc0 - _ = 0xc1 - mpFalse = 0xc2 - mpTrue = 0xc3 - mpFloat = 0xca - mpDouble = 0xcb - mpUint8 = 0xcc - mpUint16 = 0xcd - mpUint32 = 0xce - mpUint64 = 0xcf - mpInt8 = 0xd0 - mpInt16 = 0xd1 - mpInt32 = 0xd2 - mpInt64 = 0xd3 - - // extensions below - mpBin8 = 0xc4 - mpBin16 = 0xc5 - mpBin32 = 0xc6 - mpExt8 = 0xc7 - mpExt16 = 0xc8 - mpExt32 = 0xc9 - mpFixExt1 = 0xd4 - mpFixExt2 = 0xd5 - mpFixExt4 = 0xd6 - mpFixExt8 = 0xd7 - mpFixExt16 = 0xd8 - - mpStr8 = 0xd9 // new - mpStr16 = 0xda - mpStr32 = 0xdb - - mpArray16 = 0xdc - mpArray32 = 0xdd - - mpMap16 = 0xde - mpMap32 = 0xdf - - mpNegFixNumMin = 0xe0 - mpNegFixNumMax = 0xff -) - -// MsgpackSpecRpcMultiArgs is a special type which signifies to the MsgpackSpecRpcCodec -// that the backend RPC service takes multiple arguments, which have been arranged -// in sequence in the slice. -// -// The Codec then passes it AS-IS to the rpc service (without wrapping it in an -// array of 1 element). -type MsgpackSpecRpcMultiArgs []interface{} - -// A MsgpackContainer type specifies the different types of msgpackContainers. -type msgpackContainerType struct { - fixCutoff int - bFixMin, b8, b16, b32 byte - hasFixMin, has8, has8Always bool -} - -var ( - msgpackContainerStr = msgpackContainerType{32, mpFixStrMin, mpStr8, mpStr16, mpStr32, true, true, false} - msgpackContainerBin = msgpackContainerType{0, 0, mpBin8, mpBin16, mpBin32, false, true, true} - msgpackContainerList = msgpackContainerType{16, mpFixArrayMin, 0, mpArray16, mpArray32, true, false, false} - msgpackContainerMap = msgpackContainerType{16, mpFixMapMin, 0, mpMap16, mpMap32, true, false, false} -) - -//--------------------------------------------- - -type msgpackEncDriver struct { - noBuiltInTypes - encNoSeparator - e *Encoder - w encWriter - h *MsgpackHandle - x [8]byte -} - -func (e *msgpackEncDriver) EncodeNil() { - e.w.writen1(mpNil) -} - -func (e *msgpackEncDriver) EncodeInt(i int64) { - if i >= 0 { - e.EncodeUint(uint64(i)) - } else if i >= -32 { - e.w.writen1(byte(i)) - } else if i >= math.MinInt8 { - e.w.writen2(mpInt8, byte(i)) - } else if i >= math.MinInt16 { - e.w.writen1(mpInt16) - bigenHelper{e.x[:2], e.w}.writeUint16(uint16(i)) - } else if i >= math.MinInt32 { - e.w.writen1(mpInt32) - bigenHelper{e.x[:4], e.w}.writeUint32(uint32(i)) - } else { - e.w.writen1(mpInt64) - bigenHelper{e.x[:8], e.w}.writeUint64(uint64(i)) - } -} - -func (e *msgpackEncDriver) EncodeUint(i uint64) { - if i <= math.MaxInt8 { - e.w.writen1(byte(i)) - } else if i <= math.MaxUint8 { - e.w.writen2(mpUint8, byte(i)) - } else if i <= math.MaxUint16 { - e.w.writen1(mpUint16) - bigenHelper{e.x[:2], e.w}.writeUint16(uint16(i)) - } else if i <= math.MaxUint32 { - e.w.writen1(mpUint32) - bigenHelper{e.x[:4], e.w}.writeUint32(uint32(i)) - } else { - e.w.writen1(mpUint64) - bigenHelper{e.x[:8], e.w}.writeUint64(uint64(i)) - } -} - -func (e *msgpackEncDriver) EncodeBool(b bool) { - if b { - e.w.writen1(mpTrue) - } else { - e.w.writen1(mpFalse) - } -} - -func (e *msgpackEncDriver) EncodeFloat32(f float32) { - e.w.writen1(mpFloat) - bigenHelper{e.x[:4], e.w}.writeUint32(math.Float32bits(f)) -} - -func (e *msgpackEncDriver) EncodeFloat64(f float64) { - e.w.writen1(mpDouble) - bigenHelper{e.x[:8], e.w}.writeUint64(math.Float64bits(f)) -} - -func (e *msgpackEncDriver) EncodeExt(v interface{}, xtag uint64, ext Ext, _ *Encoder) { - bs := ext.WriteExt(v) - if bs == nil { - e.EncodeNil() - return - } - if e.h.WriteExt { - e.encodeExtPreamble(uint8(xtag), len(bs)) - e.w.writeb(bs) - } else { - e.EncodeStringBytes(c_RAW, bs) - } -} - -func (e *msgpackEncDriver) EncodeRawExt(re *RawExt, _ *Encoder) { - e.encodeExtPreamble(uint8(re.Tag), len(re.Data)) - e.w.writeb(re.Data) -} - -func (e *msgpackEncDriver) encodeExtPreamble(xtag byte, l int) { - if l == 1 { - e.w.writen2(mpFixExt1, xtag) - } else if l == 2 { - e.w.writen2(mpFixExt2, xtag) - } else if l == 4 { - e.w.writen2(mpFixExt4, xtag) - } else if l == 8 { - e.w.writen2(mpFixExt8, xtag) - } else if l == 16 { - e.w.writen2(mpFixExt16, xtag) - } else if l < 256 { - e.w.writen2(mpExt8, byte(l)) - e.w.writen1(xtag) - } else if l < 65536 { - e.w.writen1(mpExt16) - bigenHelper{e.x[:2], e.w}.writeUint16(uint16(l)) - e.w.writen1(xtag) - } else { - e.w.writen1(mpExt32) - bigenHelper{e.x[:4], e.w}.writeUint32(uint32(l)) - e.w.writen1(xtag) - } -} - -func (e *msgpackEncDriver) EncodeArrayStart(length int) { - e.writeContainerLen(msgpackContainerList, length) -} - -func (e *msgpackEncDriver) EncodeMapStart(length int) { - e.writeContainerLen(msgpackContainerMap, length) -} - -func (e *msgpackEncDriver) EncodeString(c charEncoding, s string) { - if c == c_RAW && e.h.WriteExt { - e.writeContainerLen(msgpackContainerBin, len(s)) - } else { - e.writeContainerLen(msgpackContainerStr, len(s)) - } - if len(s) > 0 { - e.w.writestr(s) - } -} - -func (e *msgpackEncDriver) EncodeSymbol(v string) { - e.EncodeString(c_UTF8, v) -} - -func (e *msgpackEncDriver) EncodeStringBytes(c charEncoding, bs []byte) { - if c == c_RAW && e.h.WriteExt { - e.writeContainerLen(msgpackContainerBin, len(bs)) - } else { - e.writeContainerLen(msgpackContainerStr, len(bs)) - } - if len(bs) > 0 { - e.w.writeb(bs) - } -} - -func (e *msgpackEncDriver) writeContainerLen(ct msgpackContainerType, l int) { - if ct.hasFixMin && l < ct.fixCutoff { - e.w.writen1(ct.bFixMin | byte(l)) - } else if ct.has8 && l < 256 && (ct.has8Always || e.h.WriteExt) { - e.w.writen2(ct.b8, uint8(l)) - } else if l < 65536 { - e.w.writen1(ct.b16) - bigenHelper{e.x[:2], e.w}.writeUint16(uint16(l)) - } else { - e.w.writen1(ct.b32) - bigenHelper{e.x[:4], e.w}.writeUint32(uint32(l)) - } -} - -//--------------------------------------------- - -type msgpackDecDriver struct { - d *Decoder - r decReader // *Decoder decReader decReaderT - h *MsgpackHandle - b [scratchByteArrayLen]byte - bd byte - bdRead bool - br bool // bytes reader - noBuiltInTypes - noStreamingCodec - decNoSeparator -} - -// Note: This returns either a primitive (int, bool, etc) for non-containers, -// or a containerType, or a specific type denoting nil or extension. -// It is called when a nil interface{} is passed, leaving it up to the DecDriver -// to introspect the stream and decide how best to decode. -// It deciphers the value by looking at the stream first. -func (d *msgpackDecDriver) DecodeNaked() { - if !d.bdRead { - d.readNextBd() - } - bd := d.bd - n := &d.d.n - var decodeFurther bool - - switch bd { - case mpNil: - n.v = valueTypeNil - d.bdRead = false - case mpFalse: - n.v = valueTypeBool - n.b = false - case mpTrue: - n.v = valueTypeBool - n.b = true - - case mpFloat: - n.v = valueTypeFloat - n.f = float64(math.Float32frombits(bigen.Uint32(d.r.readx(4)))) - case mpDouble: - n.v = valueTypeFloat - n.f = math.Float64frombits(bigen.Uint64(d.r.readx(8))) - - case mpUint8: - n.v = valueTypeUint - n.u = uint64(d.r.readn1()) - case mpUint16: - n.v = valueTypeUint - n.u = uint64(bigen.Uint16(d.r.readx(2))) - case mpUint32: - n.v = valueTypeUint - n.u = uint64(bigen.Uint32(d.r.readx(4))) - case mpUint64: - n.v = valueTypeUint - n.u = uint64(bigen.Uint64(d.r.readx(8))) - - case mpInt8: - n.v = valueTypeInt - n.i = int64(int8(d.r.readn1())) - case mpInt16: - n.v = valueTypeInt - n.i = int64(int16(bigen.Uint16(d.r.readx(2)))) - case mpInt32: - n.v = valueTypeInt - n.i = int64(int32(bigen.Uint32(d.r.readx(4)))) - case mpInt64: - n.v = valueTypeInt - n.i = int64(int64(bigen.Uint64(d.r.readx(8)))) - - default: - switch { - case bd >= mpPosFixNumMin && bd <= mpPosFixNumMax: - // positive fixnum (always signed) - n.v = valueTypeInt - n.i = int64(int8(bd)) - case bd >= mpNegFixNumMin && bd <= mpNegFixNumMax: - // negative fixnum - n.v = valueTypeInt - n.i = int64(int8(bd)) - case bd == mpStr8, bd == mpStr16, bd == mpStr32, bd >= mpFixStrMin && bd <= mpFixStrMax: - if d.h.RawToString { - n.v = valueTypeString - n.s = d.DecodeString() - } else { - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - } - case bd == mpBin8, bd == mpBin16, bd == mpBin32: - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - case bd == mpArray16, bd == mpArray32, bd >= mpFixArrayMin && bd <= mpFixArrayMax: - n.v = valueTypeArray - decodeFurther = true - case bd == mpMap16, bd == mpMap32, bd >= mpFixMapMin && bd <= mpFixMapMax: - n.v = valueTypeMap - decodeFurther = true - case bd >= mpFixExt1 && bd <= mpFixExt16, bd >= mpExt8 && bd <= mpExt32: - n.v = valueTypeExt - clen := d.readExtLen() - n.u = uint64(d.r.readn1()) - n.l = d.r.readx(clen) - default: - d.d.errorf("Nil-Deciphered DecodeValue: %s: hex: %x, dec: %d", msgBadDesc, bd, bd) - } - } - if !decodeFurther { - d.bdRead = false - } - if n.v == valueTypeUint && d.h.SignedInteger { - n.v = valueTypeInt - n.i = int64(n.v) - } - return -} - -// int can be decoded from msgpack type: intXXX or uintXXX -func (d *msgpackDecDriver) DecodeInt(bitsize uint8) (i int64) { - if !d.bdRead { - d.readNextBd() - } - switch d.bd { - case mpUint8: - i = int64(uint64(d.r.readn1())) - case mpUint16: - i = int64(uint64(bigen.Uint16(d.r.readx(2)))) - case mpUint32: - i = int64(uint64(bigen.Uint32(d.r.readx(4)))) - case mpUint64: - i = int64(bigen.Uint64(d.r.readx(8))) - case mpInt8: - i = int64(int8(d.r.readn1())) - case mpInt16: - i = int64(int16(bigen.Uint16(d.r.readx(2)))) - case mpInt32: - i = int64(int32(bigen.Uint32(d.r.readx(4)))) - case mpInt64: - i = int64(bigen.Uint64(d.r.readx(8))) - default: - switch { - case d.bd >= mpPosFixNumMin && d.bd <= mpPosFixNumMax: - i = int64(int8(d.bd)) - case d.bd >= mpNegFixNumMin && d.bd <= mpNegFixNumMax: - i = int64(int8(d.bd)) - default: - d.d.errorf("Unhandled single-byte unsigned integer value: %s: %x", msgBadDesc, d.bd) - return - } - } - // check overflow (logic adapted from std pkg reflect/value.go OverflowUint() - if bitsize > 0 { - if trunc := (i << (64 - bitsize)) >> (64 - bitsize); i != trunc { - d.d.errorf("Overflow int value: %v", i) - return - } - } - d.bdRead = false - return -} - -// uint can be decoded from msgpack type: intXXX or uintXXX -func (d *msgpackDecDriver) DecodeUint(bitsize uint8) (ui uint64) { - if !d.bdRead { - d.readNextBd() - } - switch d.bd { - case mpUint8: - ui = uint64(d.r.readn1()) - case mpUint16: - ui = uint64(bigen.Uint16(d.r.readx(2))) - case mpUint32: - ui = uint64(bigen.Uint32(d.r.readx(4))) - case mpUint64: - ui = bigen.Uint64(d.r.readx(8)) - case mpInt8: - if i := int64(int8(d.r.readn1())); i >= 0 { - ui = uint64(i) - } else { - d.d.errorf("Assigning negative signed value: %v, to unsigned type", i) - return - } - case mpInt16: - if i := int64(int16(bigen.Uint16(d.r.readx(2)))); i >= 0 { - ui = uint64(i) - } else { - d.d.errorf("Assigning negative signed value: %v, to unsigned type", i) - return - } - case mpInt32: - if i := int64(int32(bigen.Uint32(d.r.readx(4)))); i >= 0 { - ui = uint64(i) - } else { - d.d.errorf("Assigning negative signed value: %v, to unsigned type", i) - return - } - case mpInt64: - if i := int64(bigen.Uint64(d.r.readx(8))); i >= 0 { - ui = uint64(i) - } else { - d.d.errorf("Assigning negative signed value: %v, to unsigned type", i) - return - } - default: - switch { - case d.bd >= mpPosFixNumMin && d.bd <= mpPosFixNumMax: - ui = uint64(d.bd) - case d.bd >= mpNegFixNumMin && d.bd <= mpNegFixNumMax: - d.d.errorf("Assigning negative signed value: %v, to unsigned type", int(d.bd)) - return - default: - d.d.errorf("Unhandled single-byte unsigned integer value: %s: %x", msgBadDesc, d.bd) - return - } - } - // check overflow (logic adapted from std pkg reflect/value.go OverflowUint() - if bitsize > 0 { - if trunc := (ui << (64 - bitsize)) >> (64 - bitsize); ui != trunc { - d.d.errorf("Overflow uint value: %v", ui) - return - } - } - d.bdRead = false - return -} - -// float can either be decoded from msgpack type: float, double or intX -func (d *msgpackDecDriver) DecodeFloat(chkOverflow32 bool) (f float64) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == mpFloat { - f = float64(math.Float32frombits(bigen.Uint32(d.r.readx(4)))) - } else if d.bd == mpDouble { - f = math.Float64frombits(bigen.Uint64(d.r.readx(8))) - } else { - f = float64(d.DecodeInt(0)) - } - if chkOverflow32 && chkOvf.Float32(f) { - d.d.errorf("msgpack: float32 overflow: %v", f) - return - } - d.bdRead = false - return -} - -// bool can be decoded from bool, fixnum 0 or 1. -func (d *msgpackDecDriver) DecodeBool() (b bool) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == mpFalse || d.bd == 0 { - // b = false - } else if d.bd == mpTrue || d.bd == 1 { - b = true - } else { - d.d.errorf("Invalid single-byte value for bool: %s: %x", msgBadDesc, d.bd) - return - } - d.bdRead = false - return -} - -func (d *msgpackDecDriver) DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) { - if !d.bdRead { - d.readNextBd() - } - var clen int - // ignore isstring. Expect that the bytes may be found from msgpackContainerStr or msgpackContainerBin - if bd := d.bd; bd == mpBin8 || bd == mpBin16 || bd == mpBin32 { - clen = d.readContainerLen(msgpackContainerBin) - } else { - clen = d.readContainerLen(msgpackContainerStr) - } - // println("DecodeBytes: clen: ", clen) - d.bdRead = false - // bytes may be nil, so handle it. if nil, clen=-1. - if clen < 0 { - return nil - } - if zerocopy { - if d.br { - return d.r.readx(clen) - } else if len(bs) == 0 { - bs = d.b[:] - } - } - return decByteSlice(d.r, clen, bs) -} - -func (d *msgpackDecDriver) DecodeString() (s string) { - return string(d.DecodeBytes(d.b[:], true, true)) -} - -func (d *msgpackDecDriver) readNextBd() { - d.bd = d.r.readn1() - d.bdRead = true -} - -func (d *msgpackDecDriver) ContainerType() (vt valueType) { - bd := d.bd - if bd == mpNil { - return valueTypeNil - } else if bd == mpBin8 || bd == mpBin16 || bd == mpBin32 || - (!d.h.RawToString && - (bd == mpStr8 || bd == mpStr16 || bd == mpStr32 || (bd >= mpFixStrMin && bd <= mpFixStrMax))) { - return valueTypeBytes - } else if d.h.RawToString && - (bd == mpStr8 || bd == mpStr16 || bd == mpStr32 || (bd >= mpFixStrMin && bd <= mpFixStrMax)) { - return valueTypeString - } else if bd == mpArray16 || bd == mpArray32 || (bd >= mpFixArrayMin && bd <= mpFixArrayMax) { - return valueTypeArray - } else if bd == mpMap16 || bd == mpMap32 || (bd >= mpFixMapMin && bd <= mpFixMapMax) { - return valueTypeMap - } else { - // d.d.errorf("isContainerType: unsupported parameter: %v", vt) - } - return valueTypeUnset -} - -func (d *msgpackDecDriver) TryDecodeAsNil() (v bool) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == mpNil { - d.bdRead = false - v = true - } - return -} - -func (d *msgpackDecDriver) readContainerLen(ct msgpackContainerType) (clen int) { - bd := d.bd - if bd == mpNil { - clen = -1 // to represent nil - } else if bd == ct.b8 { - clen = int(d.r.readn1()) - } else if bd == ct.b16 { - clen = int(bigen.Uint16(d.r.readx(2))) - } else if bd == ct.b32 { - clen = int(bigen.Uint32(d.r.readx(4))) - } else if (ct.bFixMin & bd) == ct.bFixMin { - clen = int(ct.bFixMin ^ bd) - } else { - d.d.errorf("readContainerLen: %s: hex: %x, decimal: %d", msgBadDesc, bd, bd) - return - } - d.bdRead = false - return -} - -func (d *msgpackDecDriver) ReadMapStart() int { - return d.readContainerLen(msgpackContainerMap) -} - -func (d *msgpackDecDriver) ReadArrayStart() int { - return d.readContainerLen(msgpackContainerList) -} - -func (d *msgpackDecDriver) readExtLen() (clen int) { - switch d.bd { - case mpNil: - clen = -1 // to represent nil - case mpFixExt1: - clen = 1 - case mpFixExt2: - clen = 2 - case mpFixExt4: - clen = 4 - case mpFixExt8: - clen = 8 - case mpFixExt16: - clen = 16 - case mpExt8: - clen = int(d.r.readn1()) - case mpExt16: - clen = int(bigen.Uint16(d.r.readx(2))) - case mpExt32: - clen = int(bigen.Uint32(d.r.readx(4))) - default: - d.d.errorf("decoding ext bytes: found unexpected byte: %x", d.bd) - return - } - return -} - -func (d *msgpackDecDriver) DecodeExt(rv interface{}, xtag uint64, ext Ext) (realxtag uint64) { - if xtag > 0xff { - d.d.errorf("decodeExt: tag must be <= 0xff; got: %v", xtag) - return - } - realxtag1, xbs := d.decodeExtV(ext != nil, uint8(xtag)) - realxtag = uint64(realxtag1) - if ext == nil { - re := rv.(*RawExt) - re.Tag = realxtag - re.Data = detachZeroCopyBytes(d.br, re.Data, xbs) - } else { - ext.ReadExt(rv, xbs) - } - return -} - -func (d *msgpackDecDriver) decodeExtV(verifyTag bool, tag byte) (xtag byte, xbs []byte) { - if !d.bdRead { - d.readNextBd() - } - xbd := d.bd - if xbd == mpBin8 || xbd == mpBin16 || xbd == mpBin32 { - xbs = d.DecodeBytes(nil, false, true) - } else if xbd == mpStr8 || xbd == mpStr16 || xbd == mpStr32 || - (xbd >= mpFixStrMin && xbd <= mpFixStrMax) { - xbs = d.DecodeBytes(nil, true, true) - } else { - clen := d.readExtLen() - xtag = d.r.readn1() - if verifyTag && xtag != tag { - d.d.errorf("Wrong extension tag. Got %b. Expecting: %v", xtag, tag) - return - } - xbs = d.r.readx(clen) - } - d.bdRead = false - return -} - -//-------------------------------------------------- - -//MsgpackHandle is a Handle for the Msgpack Schema-Free Encoding Format. -type MsgpackHandle struct { - BasicHandle - - // RawToString controls how raw bytes are decoded into a nil interface{}. - RawToString bool - - // WriteExt flag supports encoding configured extensions with extension tags. - // It also controls whether other elements of the new spec are encoded (ie Str8). - // - // With WriteExt=false, configured extensions are serialized as raw bytes - // and Str8 is not encoded. - // - // A stream can still be decoded into a typed value, provided an appropriate value - // is provided, but the type cannot be inferred from the stream. If no appropriate - // type is provided (e.g. decoding into a nil interface{}), you get back - // a []byte or string based on the setting of RawToString. - WriteExt bool - binaryEncodingType -} - -func (h *MsgpackHandle) SetBytesExt(rt reflect.Type, tag uint64, ext BytesExt) (err error) { - return h.SetExt(rt, tag, &setExtWrapper{b: ext}) -} - -func (h *MsgpackHandle) newEncDriver(e *Encoder) encDriver { - return &msgpackEncDriver{e: e, w: e.w, h: h} -} - -func (h *MsgpackHandle) newDecDriver(d *Decoder) decDriver { - return &msgpackDecDriver{d: d, r: d.r, h: h, br: d.bytes} -} - -func (e *msgpackEncDriver) reset() { - e.w = e.e.w -} - -func (d *msgpackDecDriver) reset() { - d.r = d.d.r -} - -//-------------------------------------------------- - -type msgpackSpecRpcCodec struct { - rpcCodec -} - -// /////////////// Spec RPC Codec /////////////////// -func (c *msgpackSpecRpcCodec) WriteRequest(r *rpc.Request, body interface{}) error { - // WriteRequest can write to both a Go service, and other services that do - // not abide by the 1 argument rule of a Go service. - // We discriminate based on if the body is a MsgpackSpecRpcMultiArgs - var bodyArr []interface{} - if m, ok := body.(MsgpackSpecRpcMultiArgs); ok { - bodyArr = ([]interface{})(m) - } else { - bodyArr = []interface{}{body} - } - r2 := []interface{}{0, uint32(r.Seq), r.ServiceMethod, bodyArr} - return c.write(r2, nil, false, true) -} - -func (c *msgpackSpecRpcCodec) WriteResponse(r *rpc.Response, body interface{}) error { - var moe interface{} - if r.Error != "" { - moe = r.Error - } - if moe != nil && body != nil { - body = nil - } - r2 := []interface{}{1, uint32(r.Seq), moe, body} - return c.write(r2, nil, false, true) -} - -func (c *msgpackSpecRpcCodec) ReadResponseHeader(r *rpc.Response) error { - return c.parseCustomHeader(1, &r.Seq, &r.Error) -} - -func (c *msgpackSpecRpcCodec) ReadRequestHeader(r *rpc.Request) error { - return c.parseCustomHeader(0, &r.Seq, &r.ServiceMethod) -} - -func (c *msgpackSpecRpcCodec) ReadRequestBody(body interface{}) error { - if body == nil { // read and discard - return c.read(nil) - } - bodyArr := []interface{}{body} - return c.read(&bodyArr) -} - -func (c *msgpackSpecRpcCodec) parseCustomHeader(expectTypeByte byte, msgid *uint64, methodOrError *string) (err error) { - - if c.isClosed() { - return io.EOF - } - - // We read the response header by hand - // so that the body can be decoded on its own from the stream at a later time. - - const fia byte = 0x94 //four item array descriptor value - // Not sure why the panic of EOF is swallowed above. - // if bs1 := c.dec.r.readn1(); bs1 != fia { - // err = fmt.Errorf("Unexpected value for array descriptor: Expecting %v. Received %v", fia, bs1) - // return - // } - var b byte - b, err = c.br.ReadByte() - if err != nil { - return - } - if b != fia { - err = fmt.Errorf("Unexpected value for array descriptor: Expecting %v. Received %v", fia, b) - return - } - - if err = c.read(&b); err != nil { - return - } - if b != expectTypeByte { - err = fmt.Errorf("Unexpected byte descriptor in header. Expecting %v. Received %v", expectTypeByte, b) - return - } - if err = c.read(msgid); err != nil { - return - } - if err = c.read(methodOrError); err != nil { - return - } - return -} - -//-------------------------------------------------- - -// msgpackSpecRpc is the implementation of Rpc that uses custom communication protocol -// as defined in the msgpack spec at https://github.com/msgpack-rpc/msgpack-rpc/blob/master/spec.md -type msgpackSpecRpc struct{} - -// MsgpackSpecRpc implements Rpc using the communication protocol defined in -// the msgpack spec at https://github.com/msgpack-rpc/msgpack-rpc/blob/master/spec.md . -// Its methods (ServerCodec and ClientCodec) return values that implement RpcCodecBuffered. -var MsgpackSpecRpc msgpackSpecRpc - -func (x msgpackSpecRpc) ServerCodec(conn io.ReadWriteCloser, h Handle) rpc.ServerCodec { - return &msgpackSpecRpcCodec{newRPCCodec(conn, h)} -} - -func (x msgpackSpecRpc) ClientCodec(conn io.ReadWriteCloser, h Handle) rpc.ClientCodec { - return &msgpackSpecRpcCodec{newRPCCodec(conn, h)} -} - -var _ decDriver = (*msgpackDecDriver)(nil) -var _ encDriver = (*msgpackEncDriver)(nil) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/noop.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/noop.go deleted file mode 100644 index cfee3d0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/noop.go +++ /dev/null @@ -1,213 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "math/rand" - "time" -) - -// NoopHandle returns a no-op handle. It basically does nothing. -// It is only useful for benchmarking, as it gives an idea of the -// overhead from the codec framework. -// -// LIBRARY USERS: *** DO NOT USE *** -func NoopHandle(slen int) *noopHandle { - h := noopHandle{} - h.rand = rand.New(rand.NewSource(time.Now().UnixNano())) - h.B = make([][]byte, slen) - h.S = make([]string, slen) - for i := 0; i < len(h.S); i++ { - b := make([]byte, i+1) - for j := 0; j < len(b); j++ { - b[j] = 'a' + byte(i) - } - h.B[i] = b - h.S[i] = string(b) - } - return &h -} - -// noopHandle does nothing. -// It is used to simulate the overhead of the codec framework. -type noopHandle struct { - BasicHandle - binaryEncodingType - noopDrv // noopDrv is unexported here, so we can get a copy of it when needed. -} - -type noopDrv struct { - d *Decoder - e *Encoder - i int - S []string - B [][]byte - mks []bool // stack. if map (true), else if array (false) - mk bool // top of stack. what container are we on? map or array? - ct valueType // last response for IsContainerType. - cb int // counter for ContainerType - rand *rand.Rand -} - -func (h *noopDrv) r(v int) int { return h.rand.Intn(v) } -func (h *noopDrv) m(v int) int { h.i++; return h.i % v } - -func (h *noopDrv) newEncDriver(e *Encoder) encDriver { h.e = e; return h } -func (h *noopDrv) newDecDriver(d *Decoder) decDriver { h.d = d; return h } - -func (h *noopDrv) reset() {} -func (h *noopDrv) uncacheRead() {} - -// --- encDriver - -// stack functions (for map and array) -func (h *noopDrv) start(b bool) { - // println("start", len(h.mks)+1) - h.mks = append(h.mks, b) - h.mk = b -} -func (h *noopDrv) end() { - // println("end: ", len(h.mks)-1) - h.mks = h.mks[:len(h.mks)-1] - if len(h.mks) > 0 { - h.mk = h.mks[len(h.mks)-1] - } else { - h.mk = false - } -} - -func (h *noopDrv) EncodeBuiltin(rt uintptr, v interface{}) {} -func (h *noopDrv) EncodeNil() {} -func (h *noopDrv) EncodeInt(i int64) {} -func (h *noopDrv) EncodeUint(i uint64) {} -func (h *noopDrv) EncodeBool(b bool) {} -func (h *noopDrv) EncodeFloat32(f float32) {} -func (h *noopDrv) EncodeFloat64(f float64) {} -func (h *noopDrv) EncodeRawExt(re *RawExt, e *Encoder) {} -func (h *noopDrv) EncodeArrayStart(length int) { h.start(true) } -func (h *noopDrv) EncodeMapStart(length int) { h.start(false) } -func (h *noopDrv) EncodeEnd() { h.end() } - -func (h *noopDrv) EncodeString(c charEncoding, v string) {} -func (h *noopDrv) EncodeSymbol(v string) {} -func (h *noopDrv) EncodeStringBytes(c charEncoding, v []byte) {} - -func (h *noopDrv) EncodeExt(rv interface{}, xtag uint64, ext Ext, e *Encoder) {} - -// ---- decDriver -func (h *noopDrv) initReadNext() {} -func (h *noopDrv) CheckBreak() bool { return false } -func (h *noopDrv) IsBuiltinType(rt uintptr) bool { return false } -func (h *noopDrv) DecodeBuiltin(rt uintptr, v interface{}) {} -func (h *noopDrv) DecodeInt(bitsize uint8) (i int64) { return int64(h.m(15)) } -func (h *noopDrv) DecodeUint(bitsize uint8) (ui uint64) { return uint64(h.m(35)) } -func (h *noopDrv) DecodeFloat(chkOverflow32 bool) (f float64) { return float64(h.m(95)) } -func (h *noopDrv) DecodeBool() (b bool) { return h.m(2) == 0 } -func (h *noopDrv) DecodeString() (s string) { return h.S[h.m(8)] } - -// func (h *noopDrv) DecodeStringAsBytes(bs []byte) []byte { return h.DecodeBytes(bs) } - -func (h *noopDrv) DecodeBytes(bs []byte, isstring, zerocopy bool) []byte { return h.B[h.m(len(h.B))] } - -func (h *noopDrv) ReadEnd() { h.end() } - -// toggle map/slice -func (h *noopDrv) ReadMapStart() int { h.start(true); return h.m(10) } -func (h *noopDrv) ReadArrayStart() int { h.start(false); return h.m(10) } - -func (h *noopDrv) ContainerType() (vt valueType) { - // return h.m(2) == 0 - // handle kStruct, which will bomb is it calls this and doesn't get back a map or array. - // consequently, if the return value is not map or array, reset it to one of them based on h.m(7) % 2 - // for kstruct: at least one out of every 2 times, return one of valueTypeMap or Array (else kstruct bombs) - // however, every 10th time it is called, we just return something else. - var vals = [...]valueType{valueTypeArray, valueTypeMap} - // ------------ TAKE ------------ - // if h.cb%2 == 0 { - // if h.ct == valueTypeMap || h.ct == valueTypeArray { - // } else { - // h.ct = vals[h.m(2)] - // } - // } else if h.cb%5 == 0 { - // h.ct = valueType(h.m(8)) - // } else { - // h.ct = vals[h.m(2)] - // } - // ------------ TAKE ------------ - // if h.cb%16 == 0 { - // h.ct = valueType(h.cb % 8) - // } else { - // h.ct = vals[h.cb%2] - // } - h.ct = vals[h.cb%2] - h.cb++ - return h.ct - - // if h.ct == valueTypeNil || h.ct == valueTypeString || h.ct == valueTypeBytes { - // return h.ct - // } - // return valueTypeUnset - // TODO: may need to tweak this so it works. - // if h.ct == valueTypeMap && vt == valueTypeArray || h.ct == valueTypeArray && vt == valueTypeMap { - // h.cb = !h.cb - // h.ct = vt - // return h.cb - // } - // // go in a loop and check it. - // h.ct = vt - // h.cb = h.m(7) == 0 - // return h.cb -} -func (h *noopDrv) TryDecodeAsNil() bool { - if h.mk { - return false - } else { - return h.m(8) == 0 - } -} -func (h *noopDrv) DecodeExt(rv interface{}, xtag uint64, ext Ext) uint64 { - return 0 -} - -func (h *noopDrv) DecodeNaked() { - // use h.r (random) not h.m() because h.m() could cause the same value to be given. - var sk int - if h.mk { - // if mapkey, do not support values of nil OR bytes, array, map or rawext - sk = h.r(7) + 1 - } else { - sk = h.r(12) - } - n := &h.d.n - switch sk { - case 0: - n.v = valueTypeNil - case 1: - n.v, n.b = valueTypeBool, false - case 2: - n.v, n.b = valueTypeBool, true - case 3: - n.v, n.i = valueTypeInt, h.DecodeInt(64) - case 4: - n.v, n.u = valueTypeUint, h.DecodeUint(64) - case 5: - n.v, n.f = valueTypeFloat, h.DecodeFloat(true) - case 6: - n.v, n.f = valueTypeFloat, h.DecodeFloat(false) - case 7: - n.v, n.s = valueTypeString, h.DecodeString() - case 8: - n.v, n.l = valueTypeBytes, h.B[h.m(len(h.B))] - case 9: - n.v = valueTypeArray - case 10: - n.v = valueTypeMap - default: - n.v = valueTypeExt - n.u = h.DecodeUint(64) - n.l = h.B[h.m(len(h.B))] - } - h.ct = n.v - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.go deleted file mode 100644 index 2353263..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.go +++ /dev/null @@ -1,3 +0,0 @@ -package codec - -//go:generate bash prebuild.sh diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.sh b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.sh deleted file mode 100755 index 98f4424..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/prebuild.sh +++ /dev/null @@ -1,199 +0,0 @@ -#!/bin/bash - -# _needgen is a helper function to tell if we need to generate files for msgp, codecgen. -_needgen() { - local a="$1" - zneedgen=0 - if [[ ! -e "$a" ]] - then - zneedgen=1 - echo 1 - return 0 - fi - for i in `ls -1 *.go.tmpl gen.go values_test.go` - do - if [[ "$a" -ot "$i" ]] - then - zneedgen=1 - echo 1 - return 0 - fi - done - echo 0 -} - -# _build generates fast-path.go and gen-helper.go. -# -# It is needed because there is some dependency between the generated code -# and the other classes. Consequently, we have to totally remove the -# generated files and put stubs in place, before calling "go run" again -# to recreate them. -_build() { - if ! [[ "${zforce}" == "1" || - "1" == $( _needgen "fast-path.generated.go" ) || - "1" == $( _needgen "gen-helper.generated.go" ) || - "1" == $( _needgen "gen.generated.go" ) || - 1 == 0 ]] - then - return 0 - fi - - # echo "Running prebuild" - if [ "${zbak}" == "1" ] - then - # echo "Backing up old generated files" - _zts=`date '+%m%d%Y_%H%M%S'` - _gg=".generated.go" - [ -e "gen-helper${_gg}" ] && mv gen-helper${_gg} gen-helper${_gg}__${_zts}.bak - [ -e "fast-path${_gg}" ] && mv fast-path${_gg} fast-path${_gg}__${_zts}.bak - # [ -e "safe${_gg}" ] && mv safe${_gg} safe${_gg}__${_zts}.bak - # [ -e "unsafe${_gg}" ] && mv unsafe${_gg} unsafe${_gg}__${_zts}.bak - else - rm -f fast-path.generated.go gen.generated.go gen-helper.generated.go \ - *safe.generated.go *_generated_test.go *.generated_ffjson_expose.go - fi - - cat > gen.generated.go <> gen.generated.go < gen-dec-map.go.tmpl - - cat >> gen.generated.go <> gen.generated.go < gen-dec-array.go.tmpl - - cat >> gen.generated.go < gen-from-tmpl.codec.generated.go < gen-from-tmpl.generated.go < math.MaxInt64 { - // d.d.errorf("decIntAny: Integer out of range for signed int64: %v", ui) - // return - // } - return -} - -func (d *simpleDecDriver) DecodeInt(bitsize uint8) (i int64) { - ui, neg := d.decCheckInteger() - i, overflow := chkOvf.SignedInt(ui) - if overflow { - d.d.errorf("simple: overflow converting %v to signed integer", ui) - return - } - if neg { - i = -i - } - if chkOvf.Int(i, bitsize) { - d.d.errorf("simple: overflow integer: %v", i) - return - } - d.bdRead = false - return -} - -func (d *simpleDecDriver) DecodeUint(bitsize uint8) (ui uint64) { - ui, neg := d.decCheckInteger() - if neg { - d.d.errorf("Assigning negative signed value to unsigned type") - return - } - if chkOvf.Uint(ui, bitsize) { - d.d.errorf("simple: overflow integer: %v", ui) - return - } - d.bdRead = false - return -} - -func (d *simpleDecDriver) DecodeFloat(chkOverflow32 bool) (f float64) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == simpleVdFloat32 { - f = float64(math.Float32frombits(bigen.Uint32(d.r.readx(4)))) - } else if d.bd == simpleVdFloat64 { - f = math.Float64frombits(bigen.Uint64(d.r.readx(8))) - } else { - if d.bd >= simpleVdPosInt && d.bd <= simpleVdNegInt+3 { - f = float64(d.DecodeInt(64)) - } else { - d.d.errorf("Float only valid from float32/64: Invalid descriptor: %v", d.bd) - return - } - } - if chkOverflow32 && chkOvf.Float32(f) { - d.d.errorf("msgpack: float32 overflow: %v", f) - return - } - d.bdRead = false - return -} - -// bool can be decoded from bool only (single byte). -func (d *simpleDecDriver) DecodeBool() (b bool) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == simpleVdTrue { - b = true - } else if d.bd == simpleVdFalse { - } else { - d.d.errorf("Invalid single-byte value for bool: %s: %x", msgBadDesc, d.bd) - return - } - d.bdRead = false - return -} - -func (d *simpleDecDriver) ReadMapStart() (length int) { - d.bdRead = false - return d.decLen() -} - -func (d *simpleDecDriver) ReadArrayStart() (length int) { - d.bdRead = false - return d.decLen() -} - -func (d *simpleDecDriver) decLen() int { - switch d.bd % 8 { - case 0: - return 0 - case 1: - return int(d.r.readn1()) - case 2: - return int(bigen.Uint16(d.r.readx(2))) - case 3: - ui := uint64(bigen.Uint32(d.r.readx(4))) - if chkOvf.Uint(ui, intBitsize) { - d.d.errorf("simple: overflow integer: %v", ui) - return 0 - } - return int(ui) - case 4: - ui := bigen.Uint64(d.r.readx(8)) - if chkOvf.Uint(ui, intBitsize) { - d.d.errorf("simple: overflow integer: %v", ui) - return 0 - } - return int(ui) - } - d.d.errorf("decLen: Cannot read length: bd%8 must be in range 0..4. Got: %d", d.bd%8) - return -1 -} - -func (d *simpleDecDriver) DecodeString() (s string) { - return string(d.DecodeBytes(d.b[:], true, true)) -} - -func (d *simpleDecDriver) DecodeBytes(bs []byte, isstring, zerocopy bool) (bsOut []byte) { - if !d.bdRead { - d.readNextBd() - } - if d.bd == simpleVdNil { - d.bdRead = false - return - } - clen := d.decLen() - d.bdRead = false - if zerocopy { - if d.br { - return d.r.readx(clen) - } else if len(bs) == 0 { - bs = d.b[:] - } - } - return decByteSlice(d.r, clen, bs) -} - -func (d *simpleDecDriver) DecodeExt(rv interface{}, xtag uint64, ext Ext) (realxtag uint64) { - if xtag > 0xff { - d.d.errorf("decodeExt: tag must be <= 0xff; got: %v", xtag) - return - } - realxtag1, xbs := d.decodeExtV(ext != nil, uint8(xtag)) - realxtag = uint64(realxtag1) - if ext == nil { - re := rv.(*RawExt) - re.Tag = realxtag - re.Data = detachZeroCopyBytes(d.br, re.Data, xbs) - } else { - ext.ReadExt(rv, xbs) - } - return -} - -func (d *simpleDecDriver) decodeExtV(verifyTag bool, tag byte) (xtag byte, xbs []byte) { - if !d.bdRead { - d.readNextBd() - } - switch d.bd { - case simpleVdExt, simpleVdExt + 1, simpleVdExt + 2, simpleVdExt + 3, simpleVdExt + 4: - l := d.decLen() - xtag = d.r.readn1() - if verifyTag && xtag != tag { - d.d.errorf("Wrong extension tag. Got %b. Expecting: %v", xtag, tag) - return - } - xbs = d.r.readx(l) - case simpleVdByteArray, simpleVdByteArray + 1, simpleVdByteArray + 2, simpleVdByteArray + 3, simpleVdByteArray + 4: - xbs = d.DecodeBytes(nil, false, true) - default: - d.d.errorf("Invalid d.bd for extensions (Expecting extensions or byte array). Got: 0x%x", d.bd) - return - } - d.bdRead = false - return -} - -func (d *simpleDecDriver) DecodeNaked() { - if !d.bdRead { - d.readNextBd() - } - - n := &d.d.n - var decodeFurther bool - - switch d.bd { - case simpleVdNil: - n.v = valueTypeNil - case simpleVdFalse: - n.v = valueTypeBool - n.b = false - case simpleVdTrue: - n.v = valueTypeBool - n.b = true - case simpleVdPosInt, simpleVdPosInt + 1, simpleVdPosInt + 2, simpleVdPosInt + 3: - if d.h.SignedInteger { - n.v = valueTypeInt - n.i = d.DecodeInt(64) - } else { - n.v = valueTypeUint - n.u = d.DecodeUint(64) - } - case simpleVdNegInt, simpleVdNegInt + 1, simpleVdNegInt + 2, simpleVdNegInt + 3: - n.v = valueTypeInt - n.i = d.DecodeInt(64) - case simpleVdFloat32: - n.v = valueTypeFloat - n.f = d.DecodeFloat(true) - case simpleVdFloat64: - n.v = valueTypeFloat - n.f = d.DecodeFloat(false) - case simpleVdString, simpleVdString + 1, simpleVdString + 2, simpleVdString + 3, simpleVdString + 4: - n.v = valueTypeString - n.s = d.DecodeString() - case simpleVdByteArray, simpleVdByteArray + 1, simpleVdByteArray + 2, simpleVdByteArray + 3, simpleVdByteArray + 4: - n.v = valueTypeBytes - n.l = d.DecodeBytes(nil, false, false) - case simpleVdExt, simpleVdExt + 1, simpleVdExt + 2, simpleVdExt + 3, simpleVdExt + 4: - n.v = valueTypeExt - l := d.decLen() - n.u = uint64(d.r.readn1()) - n.l = d.r.readx(l) - case simpleVdArray, simpleVdArray + 1, simpleVdArray + 2, simpleVdArray + 3, simpleVdArray + 4: - n.v = valueTypeArray - decodeFurther = true - case simpleVdMap, simpleVdMap + 1, simpleVdMap + 2, simpleVdMap + 3, simpleVdMap + 4: - n.v = valueTypeMap - decodeFurther = true - default: - d.d.errorf("decodeNaked: Unrecognized d.bd: 0x%x", d.bd) - } - - if !decodeFurther { - d.bdRead = false - } - return -} - -//------------------------------------ - -// SimpleHandle is a Handle for a very simple encoding format. -// -// simple is a simplistic codec similar to binc, but not as compact. -// - Encoding of a value is always preceeded by the descriptor byte (bd) -// - True, false, nil are encoded fully in 1 byte (the descriptor) -// - Integers (intXXX, uintXXX) are encoded in 1, 2, 4 or 8 bytes (plus a descriptor byte). -// There are positive (uintXXX and intXXX >= 0) and negative (intXXX < 0) integers. -// - Floats are encoded in 4 or 8 bytes (plus a descriptor byte) -// - Lenght of containers (strings, bytes, array, map, extensions) -// are encoded in 0, 1, 2, 4 or 8 bytes. -// Zero-length containers have no length encoded. -// For others, the number of bytes is given by pow(2, bd%3) -// - maps are encoded as [bd] [length] [[key][value]]... -// - arrays are encoded as [bd] [length] [value]... -// - extensions are encoded as [bd] [length] [tag] [byte]... -// - strings/bytearrays are encoded as [bd] [length] [byte]... -// -// The full spec will be published soon. -type SimpleHandle struct { - BasicHandle - binaryEncodingType -} - -func (h *SimpleHandle) SetBytesExt(rt reflect.Type, tag uint64, ext BytesExt) (err error) { - return h.SetExt(rt, tag, &setExtWrapper{b: ext}) -} - -func (h *SimpleHandle) newEncDriver(e *Encoder) encDriver { - return &simpleEncDriver{e: e, w: e.w, h: h} -} - -func (h *SimpleHandle) newDecDriver(d *Decoder) decDriver { - return &simpleDecDriver{d: d, r: d.r, h: h, br: d.bytes} -} - -func (e *simpleEncDriver) reset() { - e.w = e.e.w -} - -func (d *simpleDecDriver) reset() { - d.r = d.d.r -} - -var _ decDriver = (*simpleDecDriver)(nil) -var _ encDriver = (*simpleEncDriver)(nil) diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test-cbor-goldens.json b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test-cbor-goldens.json deleted file mode 100644 index 9028586..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test-cbor-goldens.json +++ /dev/null @@ -1,639 +0,0 @@ -[ - { - "cbor": "AA==", - "hex": "00", - "roundtrip": true, - "decoded": 0 - }, - { - "cbor": "AQ==", - "hex": "01", - "roundtrip": true, - "decoded": 1 - }, - { - "cbor": "Cg==", - "hex": "0a", - "roundtrip": true, - "decoded": 10 - }, - { - "cbor": "Fw==", - "hex": "17", - "roundtrip": true, - "decoded": 23 - }, - { - "cbor": "GBg=", - "hex": "1818", - "roundtrip": true, - "decoded": 24 - }, - { - "cbor": "GBk=", - "hex": "1819", - "roundtrip": true, - "decoded": 25 - }, - { - "cbor": "GGQ=", - "hex": "1864", - "roundtrip": true, - "decoded": 100 - }, - { - "cbor": "GQPo", - "hex": "1903e8", - "roundtrip": true, - "decoded": 1000 - }, - { - "cbor": "GgAPQkA=", - "hex": "1a000f4240", - "roundtrip": true, - "decoded": 1000000 - }, - { - "cbor": "GwAAAOjUpRAA", - "hex": "1b000000e8d4a51000", - "roundtrip": true, - "decoded": 1000000000000 - }, - { - "cbor": "G///////////", - "hex": "1bffffffffffffffff", - "roundtrip": true, - "decoded": 18446744073709551615 - }, - { - "cbor": "wkkBAAAAAAAAAAA=", - "hex": "c249010000000000000000", - "roundtrip": true, - "decoded": 18446744073709551616 - }, - { - "cbor": "O///////////", - "hex": "3bffffffffffffffff", - "roundtrip": true, - "decoded": -18446744073709551616, - "skip": true - }, - { - "cbor": "w0kBAAAAAAAAAAA=", - "hex": "c349010000000000000000", - "roundtrip": true, - "decoded": -18446744073709551617 - }, - { - "cbor": "IA==", - "hex": "20", - "roundtrip": true, - "decoded": -1 - }, - { - "cbor": "KQ==", - "hex": "29", - "roundtrip": true, - "decoded": -10 - }, - { - "cbor": "OGM=", - "hex": "3863", - "roundtrip": true, - "decoded": -100 - }, - { - "cbor": "OQPn", - "hex": "3903e7", - "roundtrip": true, - "decoded": -1000 - }, - { - "cbor": "+QAA", - "hex": "f90000", - "roundtrip": true, - "decoded": 0.0 - }, - { - "cbor": "+YAA", - "hex": "f98000", - "roundtrip": true, - "decoded": -0.0 - }, - { - "cbor": "+TwA", - "hex": "f93c00", - "roundtrip": true, - "decoded": 1.0 - }, - { - "cbor": "+z/xmZmZmZma", - "hex": "fb3ff199999999999a", - "roundtrip": true, - "decoded": 1.1 - }, - { - "cbor": "+T4A", - "hex": "f93e00", - "roundtrip": true, - "decoded": 1.5 - }, - { - "cbor": "+Xv/", - "hex": "f97bff", - "roundtrip": true, - "decoded": 65504.0 - }, - { - "cbor": "+kfDUAA=", - "hex": "fa47c35000", - "roundtrip": true, - "decoded": 100000.0 - }, - { - "cbor": "+n9///8=", - "hex": "fa7f7fffff", - "roundtrip": true, - "decoded": 3.4028234663852886e+38 - }, - { - "cbor": "+3435DyIAHWc", - "hex": "fb7e37e43c8800759c", - "roundtrip": true, - "decoded": 1.0e+300 - }, - { - "cbor": "+QAB", - "hex": "f90001", - "roundtrip": true, - "decoded": 5.960464477539063e-08 - }, - { - "cbor": "+QQA", - "hex": "f90400", - "roundtrip": true, - "decoded": 6.103515625e-05 - }, - { - "cbor": "+cQA", - "hex": "f9c400", - "roundtrip": true, - "decoded": -4.0 - }, - { - "cbor": "+8AQZmZmZmZm", - "hex": "fbc010666666666666", - "roundtrip": true, - "decoded": -4.1 - }, - { - "cbor": "+XwA", - "hex": "f97c00", - "roundtrip": true, - "diagnostic": "Infinity" - }, - { - "cbor": "+X4A", - "hex": "f97e00", - "roundtrip": true, - "diagnostic": "NaN" - }, - { - "cbor": "+fwA", - "hex": "f9fc00", - "roundtrip": true, - "diagnostic": "-Infinity" - }, - { - "cbor": "+n+AAAA=", - "hex": "fa7f800000", - "roundtrip": false, - "diagnostic": "Infinity" - }, - { - "cbor": "+n/AAAA=", - "hex": "fa7fc00000", - "roundtrip": false, - "diagnostic": "NaN" - }, - { - "cbor": "+v+AAAA=", - "hex": "faff800000", - "roundtrip": false, - "diagnostic": "-Infinity" - }, - { - "cbor": "+3/wAAAAAAAA", - "hex": "fb7ff0000000000000", - "roundtrip": false, - "diagnostic": "Infinity" - }, - { - "cbor": "+3/4AAAAAAAA", - "hex": "fb7ff8000000000000", - "roundtrip": false, - "diagnostic": "NaN" - }, - { - "cbor": "+//wAAAAAAAA", - "hex": "fbfff0000000000000", - "roundtrip": false, - "diagnostic": "-Infinity" - }, - { - "cbor": "9A==", - "hex": "f4", - "roundtrip": true, - "decoded": false - }, - { - "cbor": "9Q==", - "hex": "f5", - "roundtrip": true, - "decoded": true - }, - { - "cbor": "9g==", - "hex": "f6", - "roundtrip": true, - "decoded": null - }, - { - "cbor": "9w==", - "hex": "f7", - "roundtrip": true, - "diagnostic": "undefined" - }, - { - "cbor": "8A==", - "hex": "f0", - "roundtrip": true, - "diagnostic": "simple(16)" - }, - { - "cbor": "+Bg=", - "hex": "f818", - "roundtrip": true, - "diagnostic": "simple(24)" - }, - { - "cbor": "+P8=", - "hex": "f8ff", - "roundtrip": true, - "diagnostic": "simple(255)" - }, - { - "cbor": "wHQyMDEzLTAzLTIxVDIwOjA0OjAwWg==", - "hex": "c074323031332d30332d32315432303a30343a30305a", - "roundtrip": true, - "diagnostic": "0(\"2013-03-21T20:04:00Z\")" - }, - { - "cbor": "wRpRS2ew", - "hex": "c11a514b67b0", - "roundtrip": true, - "diagnostic": "1(1363896240)" - }, - { - "cbor": "wftB1FLZ7CAAAA==", - "hex": "c1fb41d452d9ec200000", - "roundtrip": true, - "diagnostic": "1(1363896240.5)" - }, - { - "cbor": "10QBAgME", - "hex": "d74401020304", - "roundtrip": true, - "diagnostic": "23(h'01020304')" - }, - { - "cbor": "2BhFZElFVEY=", - "hex": "d818456449455446", - "roundtrip": true, - "diagnostic": "24(h'6449455446')" - }, - { - "cbor": "2CB2aHR0cDovL3d3dy5leGFtcGxlLmNvbQ==", - "hex": "d82076687474703a2f2f7777772e6578616d706c652e636f6d", - "roundtrip": true, - "diagnostic": "32(\"http://www.example.com\")" - }, - { - "cbor": "QA==", - "hex": "40", - "roundtrip": true, - "diagnostic": "h''" - }, - { - "cbor": "RAECAwQ=", - "hex": "4401020304", - "roundtrip": true, - "diagnostic": "h'01020304'" - }, - { - "cbor": "YA==", - "hex": "60", - "roundtrip": true, - "decoded": "" - }, - { - "cbor": "YWE=", - "hex": "6161", - "roundtrip": true, - "decoded": "a" - }, - { - "cbor": "ZElFVEY=", - "hex": "6449455446", - "roundtrip": true, - "decoded": "IETF" - }, - { - "cbor": "YiJc", - "hex": "62225c", - "roundtrip": true, - "decoded": "\"\\" - }, - { - "cbor": "YsO8", - "hex": "62c3bc", - "roundtrip": true, - "decoded": "ü" - }, - { - "cbor": "Y+awtA==", - "hex": "63e6b0b4", - "roundtrip": true, - "decoded": "水" - }, - { - "cbor": "ZPCQhZE=", - "hex": "64f0908591", - "roundtrip": true, - "decoded": "𐅑" - }, - { - "cbor": "gA==", - "hex": "80", - "roundtrip": true, - "decoded": [ - - ] - }, - { - "cbor": "gwECAw==", - "hex": "83010203", - "roundtrip": true, - "decoded": [ - 1, - 2, - 3 - ] - }, - { - "cbor": "gwGCAgOCBAU=", - "hex": "8301820203820405", - "roundtrip": true, - "decoded": [ - 1, - [ - 2, - 3 - ], - [ - 4, - 5 - ] - ] - }, - { - "cbor": "mBkBAgMEBQYHCAkKCwwNDg8QERITFBUWFxgYGBk=", - "hex": "98190102030405060708090a0b0c0d0e0f101112131415161718181819", - "roundtrip": true, - "decoded": [ - 1, - 2, - 3, - 4, - 5, - 6, - 7, - 8, - 9, - 10, - 11, - 12, - 13, - 14, - 15, - 16, - 17, - 18, - 19, - 20, - 21, - 22, - 23, - 24, - 25 - ] - }, - { - "cbor": "oA==", - "hex": "a0", - "roundtrip": true, - "decoded": { - } - }, - { - "cbor": "ogECAwQ=", - "hex": "a201020304", - "roundtrip": true, - "skip": true, - "diagnostic": "{1: 2, 3: 4}" - }, - { - "cbor": "omFhAWFiggID", - "hex": "a26161016162820203", - "roundtrip": true, - "decoded": { - "a": 1, - "b": [ - 2, - 3 - ] - } - }, - { - "cbor": "gmFhoWFiYWM=", - "hex": "826161a161626163", - "roundtrip": true, - "decoded": [ - "a", - { - "b": "c" - } - ] - }, - { - "cbor": "pWFhYUFhYmFCYWNhQ2FkYURhZWFF", - "hex": "a56161614161626142616361436164614461656145", - "roundtrip": true, - "decoded": { - "a": "A", - "b": "B", - "c": "C", - "d": "D", - "e": "E" - } - }, - { - "cbor": "X0IBAkMDBAX/", - "hex": "5f42010243030405ff", - "roundtrip": false, - "skip": true, - "diagnostic": "(_ h'0102', h'030405')" - }, - { - "cbor": "f2VzdHJlYWRtaW5n/w==", - "hex": "7f657374726561646d696e67ff", - "roundtrip": false, - "decoded": "streaming" - }, - { - "cbor": "n/8=", - "hex": "9fff", - "roundtrip": false, - "decoded": [ - - ] - }, - { - "cbor": "nwGCAgOfBAX//w==", - "hex": "9f018202039f0405ffff", - "roundtrip": false, - "decoded": [ - 1, - [ - 2, - 3 - ], - [ - 4, - 5 - ] - ] - }, - { - "cbor": "nwGCAgOCBAX/", - "hex": "9f01820203820405ff", - "roundtrip": false, - "decoded": [ - 1, - [ - 2, - 3 - ], - [ - 4, - 5 - ] - ] - }, - { - "cbor": "gwGCAgOfBAX/", - "hex": "83018202039f0405ff", - "roundtrip": false, - "decoded": [ - 1, - [ - 2, - 3 - ], - [ - 4, - 5 - ] - ] - }, - { - "cbor": "gwGfAgP/ggQF", - "hex": "83019f0203ff820405", - "roundtrip": false, - "decoded": [ - 1, - [ - 2, - 3 - ], - [ - 4, - 5 - ] - ] - }, - { - "cbor": "nwECAwQFBgcICQoLDA0ODxAREhMUFRYXGBgYGf8=", - "hex": "9f0102030405060708090a0b0c0d0e0f101112131415161718181819ff", - "roundtrip": false, - "decoded": [ - 1, - 2, - 3, - 4, - 5, - 6, - 7, - 8, - 9, - 10, - 11, - 12, - 13, - 14, - 15, - 16, - 17, - 18, - 19, - 20, - 21, - 22, - 23, - 24, - 25 - ] - }, - { - "cbor": "v2FhAWFinwID//8=", - "hex": "bf61610161629f0203ffff", - "roundtrip": false, - "decoded": { - "a": 1, - "b": [ - 2, - 3 - ] - } - }, - { - "cbor": "gmFhv2FiYWP/", - "hex": "826161bf61626163ff", - "roundtrip": false, - "decoded": [ - "a", - { - "b": "c" - } - ] - }, - { - "cbor": "v2NGdW71Y0FtdCH/", - "hex": "bf6346756ef563416d7421ff", - "roundtrip": false, - "decoded": { - "Fun": true, - "Amt": -2 - } - } -] diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test.py b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test.py deleted file mode 100755 index dfe3b0c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/test.py +++ /dev/null @@ -1,120 +0,0 @@ -#!/usr/bin/env python - -# This will create golden files in a directory passed to it. -# A Test calls this internally to create the golden files -# So it can process them (so we don't have to checkin the files). - -# Ensure msgpack-python and cbor are installed first, using: -# sudo apt-get install python-dev -# sudo apt-get install python-pip -# pip install --user msgpack-python msgpack-rpc-python cbor - -import cbor, msgpack, msgpackrpc, sys, os, threading - -def get_test_data_list(): - # get list with all primitive types, and a combo type - l0 = [ - -8, - -1616, - -32323232, - -6464646464646464, - 192, - 1616, - 32323232, - 6464646464646464, - 192, - -3232.0, - -6464646464.0, - 3232.0, - 6464646464.0, - False, - True, - None, - u"someday", - u"", - u"bytestring", - 1328176922000002000, - -2206187877999998000, - 270, - -2013855847999995777, - #-6795364578871345152, - ] - l1 = [ - { "true": True, - "false": False }, - { "true": "True", - "false": False, - "uint16(1616)": 1616 }, - { "list": [1616, 32323232, True, -3232.0, {"TRUE":True, "FALSE":False}, [True, False] ], - "int32":32323232, "bool": True, - "LONG STRING": "123456789012345678901234567890123456789012345678901234567890", - "SHORT STRING": "1234567890" }, - { True: "true", 8: False, "false": 0 } - ] - - l = [] - l.extend(l0) - l.append(l0) - l.extend(l1) - return l - -def build_test_data(destdir): - l = get_test_data_list() - for i in range(len(l)): - # packer = msgpack.Packer() - serialized = msgpack.dumps(l[i]) - f = open(os.path.join(destdir, str(i) + '.msgpack.golden'), 'wb') - f.write(serialized) - f.close() - serialized = cbor.dumps(l[i]) - f = open(os.path.join(destdir, str(i) + '.cbor.golden'), 'wb') - f.write(serialized) - f.close() - -def doRpcServer(port, stopTimeSec): - class EchoHandler(object): - def Echo123(self, msg1, msg2, msg3): - return ("1:%s 2:%s 3:%s" % (msg1, msg2, msg3)) - def EchoStruct(self, msg): - return ("%s" % msg) - - addr = msgpackrpc.Address('localhost', port) - server = msgpackrpc.Server(EchoHandler()) - server.listen(addr) - # run thread to stop it after stopTimeSec seconds if > 0 - if stopTimeSec > 0: - def myStopRpcServer(): - server.stop() - t = threading.Timer(stopTimeSec, myStopRpcServer) - t.start() - server.start() - -def doRpcClientToPythonSvc(port): - address = msgpackrpc.Address('localhost', port) - client = msgpackrpc.Client(address, unpack_encoding='utf-8') - print client.call("Echo123", "A1", "B2", "C3") - print client.call("EchoStruct", {"A" :"Aa", "B":"Bb", "C":"Cc"}) - -def doRpcClientToGoSvc(port): - # print ">>>> port: ", port, " <<<<<" - address = msgpackrpc.Address('localhost', port) - client = msgpackrpc.Client(address, unpack_encoding='utf-8') - print client.call("TestRpcInt.Echo123", ["A1", "B2", "C3"]) - print client.call("TestRpcInt.EchoStruct", {"A" :"Aa", "B":"Bb", "C":"Cc"}) - -def doMain(args): - if len(args) == 2 and args[0] == "testdata": - build_test_data(args[1]) - elif len(args) == 3 and args[0] == "rpc-server": - doRpcServer(int(args[1]), int(args[2])) - elif len(args) == 2 and args[0] == "rpc-client-python-service": - doRpcClientToPythonSvc(int(args[1])) - elif len(args) == 2 and args[0] == "rpc-client-go-service": - doRpcClientToGoSvc(int(args[1])) - else: - print("Usage: test.py " + - "[testdata|rpc-server|rpc-client-python-service|rpc-client-go-service] ...") - -if __name__ == "__main__": - doMain(sys.argv[1:]) - diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/tests.sh b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/tests.sh deleted file mode 100755 index b1602ea..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/tests.sh +++ /dev/null @@ -1,74 +0,0 @@ -#!/bin/bash - -# Run all the different permutations of all the tests. -# This helps ensure that nothing gets broken. - -_run() { - # 1. VARIATIONS: regular (t), canonical (c), IO R/W (i), - # binc-nosymbols (n), struct2array (s), intern string (e), - # 2. MODE: reflection (r), external (x), codecgen (g), unsafe (u), notfastpath (f) - # 3. OPTIONS: verbose (v), reset (z), must (m), - # - # Use combinations of mode to get exactly what you want, - # and then pass the variations you need. - - ztags="" - zargs="" - local OPTIND - OPTIND=1 - while getopts "xurtcinsvgzmef" flag - do - case "x$flag" in - 'xr') ;; - 'xf') ztags="$ztags notfastpath" ;; - 'xg') ztags="$ztags codecgen" ;; - 'xx') ztags="$ztags x" ;; - 'xu') ztags="$ztags unsafe" ;; - 'xv') zargs="$zargs -tv" ;; - 'xz') zargs="$zargs -tr" ;; - 'xm') zargs="$zargs -tm" ;; - *) ;; - esac - done - # shift $((OPTIND-1)) - printf '............. TAGS: %s .............\n' "$ztags" - # echo ">>>>>>> TAGS: $ztags" - - OPTIND=1 - while getopts "xurtcinsvgzmef" flag - do - case "x$flag" in - 'xt') printf ">>>>>>> REGULAR : "; go test "-tags=$ztags" $zargs ; sleep 2 ;; - 'xc') printf ">>>>>>> CANONICAL : "; go test "-tags=$ztags" $zargs -tc; sleep 2 ;; - 'xi') printf ">>>>>>> I/O : "; go test "-tags=$ztags" $zargs -ti; sleep 2 ;; - 'xn') printf ">>>>>>> NO_SYMBOLS : "; go test "-tags=$ztags" $zargs -tn; sleep 2 ;; - 'xs') printf ">>>>>>> TO_ARRAY : "; go test "-tags=$ztags" $zargs -ts; sleep 2 ;; - 'xe') printf ">>>>>>> INTERN : "; go test "-tags=$ztags" $zargs -te; sleep 2 ;; - *) ;; - esac - done - shift $((OPTIND-1)) - - OPTIND=1 -} - -# echo ">>>>>>> RUNNING VARIATIONS OF TESTS" -if [[ "x$@" = "x" ]]; then - # All: r, x, g, gu - _run "-rtcinsm" # regular - _run "-rtcinsmz" # regular with reset - _run "-rtcinsmf" # regular with no fastpath (notfastpath) - _run "-xtcinsm" # external - _run "-gxtcinsm" # codecgen: requires external - _run "-gxutcinsm" # codecgen + unsafe -elif [[ "x$@" = "x-Z" ]]; then - # Regular - _run "-rtcinsm" # regular - _run "-rtcinsmz" # regular with reset -elif [[ "x$@" = "x-F" ]]; then - # regular with notfastpath - _run "-rtcinsmf" # regular - _run "-rtcinsmzf" # regular with reset -else - _run "$@" -fi diff --git a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/time.go b/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/time.go deleted file mode 100644 index fc4c63e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/github.com/ugorji/go/codec/time.go +++ /dev/null @@ -1,222 +0,0 @@ -// Copyright (c) 2012-2015 Ugorji Nwoke. All rights reserved. -// Use of this source code is governed by a MIT license found in the LICENSE file. - -package codec - -import ( - "fmt" - "time" -) - -var ( - timeDigits = [...]byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'} -) - -type timeExt struct{} - -func (x timeExt) WriteExt(v interface{}) (bs []byte) { - switch v2 := v.(type) { - case time.Time: - bs = encodeTime(v2) - case *time.Time: - bs = encodeTime(*v2) - default: - panic(fmt.Errorf("unsupported format for time conversion: expecting time.Time; got %T", v2)) - } - return -} -func (x timeExt) ReadExt(v interface{}, bs []byte) { - tt, err := decodeTime(bs) - if err != nil { - panic(err) - } - *(v.(*time.Time)) = tt -} - -func (x timeExt) ConvertExt(v interface{}) interface{} { - return x.WriteExt(v) -} -func (x timeExt) UpdateExt(v interface{}, src interface{}) { - x.ReadExt(v, src.([]byte)) -} - -// EncodeTime encodes a time.Time as a []byte, including -// information on the instant in time and UTC offset. -// -// Format Description -// -// A timestamp is composed of 3 components: -// -// - secs: signed integer representing seconds since unix epoch -// - nsces: unsigned integer representing fractional seconds as a -// nanosecond offset within secs, in the range 0 <= nsecs < 1e9 -// - tz: signed integer representing timezone offset in minutes east of UTC, -// and a dst (daylight savings time) flag -// -// When encoding a timestamp, the first byte is the descriptor, which -// defines which components are encoded and how many bytes are used to -// encode secs and nsecs components. *If secs/nsecs is 0 or tz is UTC, it -// is not encoded in the byte array explicitly*. -// -// Descriptor 8 bits are of the form `A B C DDD EE`: -// A: Is secs component encoded? 1 = true -// B: Is nsecs component encoded? 1 = true -// C: Is tz component encoded? 1 = true -// DDD: Number of extra bytes for secs (range 0-7). -// If A = 1, secs encoded in DDD+1 bytes. -// If A = 0, secs is not encoded, and is assumed to be 0. -// If A = 1, then we need at least 1 byte to encode secs. -// DDD says the number of extra bytes beyond that 1. -// E.g. if DDD=0, then secs is represented in 1 byte. -// if DDD=2, then secs is represented in 3 bytes. -// EE: Number of extra bytes for nsecs (range 0-3). -// If B = 1, nsecs encoded in EE+1 bytes (similar to secs/DDD above) -// -// Following the descriptor bytes, subsequent bytes are: -// -// secs component encoded in `DDD + 1` bytes (if A == 1) -// nsecs component encoded in `EE + 1` bytes (if B == 1) -// tz component encoded in 2 bytes (if C == 1) -// -// secs and nsecs components are integers encoded in a BigEndian -// 2-complement encoding format. -// -// tz component is encoded as 2 bytes (16 bits). Most significant bit 15 to -// Least significant bit 0 are described below: -// -// Timezone offset has a range of -12:00 to +14:00 (ie -720 to +840 minutes). -// Bit 15 = have\_dst: set to 1 if we set the dst flag. -// Bit 14 = dst\_on: set to 1 if dst is in effect at the time, or 0 if not. -// Bits 13..0 = timezone offset in minutes. It is a signed integer in Big Endian format. -// -func encodeTime(t time.Time) []byte { - //t := rv.Interface().(time.Time) - tsecs, tnsecs := t.Unix(), t.Nanosecond() - var ( - bd byte - btmp [8]byte - bs [16]byte - i int = 1 - ) - l := t.Location() - if l == time.UTC { - l = nil - } - if tsecs != 0 { - bd = bd | 0x80 - bigen.PutUint64(btmp[:], uint64(tsecs)) - f := pruneSignExt(btmp[:], tsecs >= 0) - bd = bd | (byte(7-f) << 2) - copy(bs[i:], btmp[f:]) - i = i + (8 - f) - } - if tnsecs != 0 { - bd = bd | 0x40 - bigen.PutUint32(btmp[:4], uint32(tnsecs)) - f := pruneSignExt(btmp[:4], true) - bd = bd | byte(3-f) - copy(bs[i:], btmp[f:4]) - i = i + (4 - f) - } - if l != nil { - bd = bd | 0x20 - // Note that Go Libs do not give access to dst flag. - _, zoneOffset := t.Zone() - //zoneName, zoneOffset := t.Zone() - zoneOffset /= 60 - z := uint16(zoneOffset) - bigen.PutUint16(btmp[:2], z) - // clear dst flags - bs[i] = btmp[0] & 0x3f - bs[i+1] = btmp[1] - i = i + 2 - } - bs[0] = bd - return bs[0:i] -} - -// DecodeTime decodes a []byte into a time.Time. -func decodeTime(bs []byte) (tt time.Time, err error) { - bd := bs[0] - var ( - tsec int64 - tnsec uint32 - tz uint16 - i byte = 1 - i2 byte - n byte - ) - if bd&(1<<7) != 0 { - var btmp [8]byte - n = ((bd >> 2) & 0x7) + 1 - i2 = i + n - copy(btmp[8-n:], bs[i:i2]) - //if first bit of bs[i] is set, then fill btmp[0..8-n] with 0xff (ie sign extend it) - if bs[i]&(1<<7) != 0 { - copy(btmp[0:8-n], bsAll0xff) - //for j,k := byte(0), 8-n; j < k; j++ { btmp[j] = 0xff } - } - i = i2 - tsec = int64(bigen.Uint64(btmp[:])) - } - if bd&(1<<6) != 0 { - var btmp [4]byte - n = (bd & 0x3) + 1 - i2 = i + n - copy(btmp[4-n:], bs[i:i2]) - i = i2 - tnsec = bigen.Uint32(btmp[:]) - } - if bd&(1<<5) == 0 { - tt = time.Unix(tsec, int64(tnsec)).UTC() - return - } - // In stdlib time.Parse, when a date is parsed without a zone name, it uses "" as zone name. - // However, we need name here, so it can be shown when time is printed. - // Zone name is in form: UTC-08:00. - // Note that Go Libs do not give access to dst flag, so we ignore dst bits - - i2 = i + 2 - tz = bigen.Uint16(bs[i:i2]) - i = i2 - // sign extend sign bit into top 2 MSB (which were dst bits): - if tz&(1<<13) == 0 { // positive - tz = tz & 0x3fff //clear 2 MSBs: dst bits - } else { // negative - tz = tz | 0xc000 //set 2 MSBs: dst bits - //tzname[3] = '-' (TODO: verify. this works here) - } - tzint := int16(tz) - if tzint == 0 { - tt = time.Unix(tsec, int64(tnsec)).UTC() - } else { - // For Go Time, do not use a descriptive timezone. - // It's unnecessary, and makes it harder to do a reflect.DeepEqual. - // The Offset already tells what the offset should be, if not on UTC and unknown zone name. - // var zoneName = timeLocUTCName(tzint) - tt = time.Unix(tsec, int64(tnsec)).In(time.FixedZone("", int(tzint)*60)) - } - return -} - -func timeLocUTCName(tzint int16) string { - if tzint == 0 { - return "UTC" - } - var tzname = []byte("UTC+00:00") - //tzname := fmt.Sprintf("UTC%s%02d:%02d", tzsign, tz/60, tz%60) //perf issue using Sprintf. inline below. - //tzhr, tzmin := tz/60, tz%60 //faster if u convert to int first - var tzhr, tzmin int16 - if tzint < 0 { - tzname[3] = '-' // (TODO: verify. this works here) - tzhr, tzmin = -tzint/60, (-tzint)%60 - } else { - tzhr, tzmin = tzint/60, tzint%60 - } - tzname[4] = timeDigits[tzhr/10] - tzname[5] = timeDigits[tzhr%10] - tzname[7] = timeDigits[tzmin/10] - tzname[8] = timeDigits[tzmin%10] - return string(tzname) - //return time.FixedZone(string(tzname), int(tzint)*60) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/context.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/context.go deleted file mode 100644 index ea1a7cd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/context.go +++ /dev/null @@ -1,156 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package context defines the Context type, which carries deadlines, -// cancelation signals, and other request-scoped values across API boundaries -// and between processes. -// -// Incoming requests to a server should create a Context, and outgoing calls to -// servers should accept a Context. The chain of function calls between must -// propagate the Context, optionally replacing it with a modified copy created -// using WithDeadline, WithTimeout, WithCancel, or WithValue. -// -// Programs that use Contexts should follow these rules to keep interfaces -// consistent across packages and enable static analysis tools to check context -// propagation: -// -// Do not store Contexts inside a struct type; instead, pass a Context -// explicitly to each function that needs it. The Context should be the first -// parameter, typically named ctx: -// -// func DoSomething(ctx context.Context, arg Arg) error { -// // ... use ctx ... -// } -// -// Do not pass a nil Context, even if a function permits it. Pass context.TODO -// if you are unsure about which Context to use. -// -// Use context Values only for request-scoped data that transits processes and -// APIs, not for passing optional parameters to functions. -// -// The same Context may be passed to functions running in different goroutines; -// Contexts are safe for simultaneous use by multiple goroutines. -// -// See http://blog.golang.org/context for example code for a server that uses -// Contexts. -package context - -import "time" - -// A Context carries a deadline, a cancelation signal, and other values across -// API boundaries. -// -// Context's methods may be called by multiple goroutines simultaneously. -type Context interface { - // Deadline returns the time when work done on behalf of this context - // should be canceled. Deadline returns ok==false when no deadline is - // set. Successive calls to Deadline return the same results. - Deadline() (deadline time.Time, ok bool) - - // Done returns a channel that's closed when work done on behalf of this - // context should be canceled. Done may return nil if this context can - // never be canceled. Successive calls to Done return the same value. - // - // WithCancel arranges for Done to be closed when cancel is called; - // WithDeadline arranges for Done to be closed when the deadline - // expires; WithTimeout arranges for Done to be closed when the timeout - // elapses. - // - // Done is provided for use in select statements: - // - // // Stream generates values with DoSomething and sends them to out - // // until DoSomething returns an error or ctx.Done is closed. - // func Stream(ctx context.Context, out chan<- Value) error { - // for { - // v, err := DoSomething(ctx) - // if err != nil { - // return err - // } - // select { - // case <-ctx.Done(): - // return ctx.Err() - // case out <- v: - // } - // } - // } - // - // See http://blog.golang.org/pipelines for more examples of how to use - // a Done channel for cancelation. - Done() <-chan struct{} - - // Err returns a non-nil error value after Done is closed. Err returns - // Canceled if the context was canceled or DeadlineExceeded if the - // context's deadline passed. No other values for Err are defined. - // After Done is closed, successive calls to Err return the same value. - Err() error - - // Value returns the value associated with this context for key, or nil - // if no value is associated with key. Successive calls to Value with - // the same key returns the same result. - // - // Use context values only for request-scoped data that transits - // processes and API boundaries, not for passing optional parameters to - // functions. - // - // A key identifies a specific value in a Context. Functions that wish - // to store values in Context typically allocate a key in a global - // variable then use that key as the argument to context.WithValue and - // Context.Value. A key can be any type that supports equality; - // packages should define keys as an unexported type to avoid - // collisions. - // - // Packages that define a Context key should provide type-safe accessors - // for the values stores using that key: - // - // // Package user defines a User type that's stored in Contexts. - // package user - // - // import "golang.org/x/net/context" - // - // // User is the type of value stored in the Contexts. - // type User struct {...} - // - // // key is an unexported type for keys defined in this package. - // // This prevents collisions with keys defined in other packages. - // type key int - // - // // userKey is the key for user.User values in Contexts. It is - // // unexported; clients use user.NewContext and user.FromContext - // // instead of using this key directly. - // var userKey key = 0 - // - // // NewContext returns a new Context that carries value u. - // func NewContext(ctx context.Context, u *User) context.Context { - // return context.WithValue(ctx, userKey, u) - // } - // - // // FromContext returns the User value stored in ctx, if any. - // func FromContext(ctx context.Context) (*User, bool) { - // u, ok := ctx.Value(userKey).(*User) - // return u, ok - // } - Value(key interface{}) interface{} -} - -// Background returns a non-nil, empty Context. It is never canceled, has no -// values, and has no deadline. It is typically used by the main function, -// initialization, and tests, and as the top-level Context for incoming -// requests. -func Background() Context { - return background -} - -// TODO returns a non-nil, empty Context. Code should use context.TODO when -// it's unclear which Context to use or it is not yet available (because the -// surrounding function has not yet been extended to accept a Context -// parameter). TODO is recognized by static analysis tools that determine -// whether Contexts are propagated correctly in a program. -func TODO() Context { - return todo -} - -// A CancelFunc tells an operation to abandon its work. -// A CancelFunc does not wait for the work to stop. -// After the first call, subsequent calls to a CancelFunc do nothing. -type CancelFunc func() diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go deleted file mode 100644 index f31d882..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +++ /dev/null @@ -1,64 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.7 - -// Package ctxhttp provides helper functions for performing context-aware HTTP requests. -package ctxhttp - -import ( - "io" - "net/http" - "net/url" - "strings" - - "golang.org/x/net/context" -) - -// Do sends an HTTP request with the provided http.Client and returns -// an HTTP response. -// -// If the client is nil, http.DefaultClient is used. -// -// The provided ctx must be non-nil. If it is canceled or times out, -// ctx.Err() will be returned. -func Do(ctx context.Context, client *http.Client, req *http.Request) (*http.Response, error) { - if client == nil { - client = http.DefaultClient - } - return client.Do(req.WithContext(ctx)) -} - -// Get issues a GET request via the Do function. -func Get(ctx context.Context, client *http.Client, url string) (*http.Response, error) { - req, err := http.NewRequest("GET", url, nil) - if err != nil { - return nil, err - } - return Do(ctx, client, req) -} - -// Head issues a HEAD request via the Do function. -func Head(ctx context.Context, client *http.Client, url string) (*http.Response, error) { - req, err := http.NewRequest("HEAD", url, nil) - if err != nil { - return nil, err - } - return Do(ctx, client, req) -} - -// Post issues a POST request via the Do function. -func Post(ctx context.Context, client *http.Client, url string, bodyType string, body io.Reader) (*http.Response, error) { - req, err := http.NewRequest("POST", url, body) - if err != nil { - return nil, err - } - req.Header.Set("Content-Type", bodyType) - return Do(ctx, client, req) -} - -// PostForm issues a POST request via the Do function. -func PostForm(ctx context.Context, client *http.Client, url string, data url.Values) (*http.Response, error) { - return Post(ctx, client, url, "application/x-www-form-urlencoded", strings.NewReader(data.Encode())) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp_pre17.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp_pre17.go deleted file mode 100644 index 7564b20..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/ctxhttp/ctxhttp_pre17.go +++ /dev/null @@ -1,147 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build !go1.7 - -package ctxhttp - -import ( - "io" - "net/http" - "net/url" - "strings" - - "golang.org/x/net/context" -) - -func nop() {} - -var ( - testHookContextDoneBeforeHeaders = nop - testHookDoReturned = nop - testHookDidBodyClose = nop -) - -// Do sends an HTTP request with the provided http.Client and returns an HTTP response. -// If the client is nil, http.DefaultClient is used. -// If the context is canceled or times out, ctx.Err() will be returned. -func Do(ctx context.Context, client *http.Client, req *http.Request) (*http.Response, error) { - if client == nil { - client = http.DefaultClient - } - - // TODO(djd): Respect any existing value of req.Cancel. - cancel := make(chan struct{}) - req.Cancel = cancel - - type responseAndError struct { - resp *http.Response - err error - } - result := make(chan responseAndError, 1) - - // Make local copies of test hooks closed over by goroutines below. - // Prevents data races in tests. - testHookDoReturned := testHookDoReturned - testHookDidBodyClose := testHookDidBodyClose - - go func() { - resp, err := client.Do(req) - testHookDoReturned() - result <- responseAndError{resp, err} - }() - - var resp *http.Response - - select { - case <-ctx.Done(): - testHookContextDoneBeforeHeaders() - close(cancel) - // Clean up after the goroutine calling client.Do: - go func() { - if r := <-result; r.resp != nil { - testHookDidBodyClose() - r.resp.Body.Close() - } - }() - return nil, ctx.Err() - case r := <-result: - var err error - resp, err = r.resp, r.err - if err != nil { - return resp, err - } - } - - c := make(chan struct{}) - go func() { - select { - case <-ctx.Done(): - close(cancel) - case <-c: - // The response's Body is closed. - } - }() - resp.Body = ¬ifyingReader{resp.Body, c} - - return resp, nil -} - -// Get issues a GET request via the Do function. -func Get(ctx context.Context, client *http.Client, url string) (*http.Response, error) { - req, err := http.NewRequest("GET", url, nil) - if err != nil { - return nil, err - } - return Do(ctx, client, req) -} - -// Head issues a HEAD request via the Do function. -func Head(ctx context.Context, client *http.Client, url string) (*http.Response, error) { - req, err := http.NewRequest("HEAD", url, nil) - if err != nil { - return nil, err - } - return Do(ctx, client, req) -} - -// Post issues a POST request via the Do function. -func Post(ctx context.Context, client *http.Client, url string, bodyType string, body io.Reader) (*http.Response, error) { - req, err := http.NewRequest("POST", url, body) - if err != nil { - return nil, err - } - req.Header.Set("Content-Type", bodyType) - return Do(ctx, client, req) -} - -// PostForm issues a POST request via the Do function. -func PostForm(ctx context.Context, client *http.Client, url string, data url.Values) (*http.Response, error) { - return Post(ctx, client, url, "application/x-www-form-urlencoded", strings.NewReader(data.Encode())) -} - -// notifyingReader is an io.ReadCloser that closes the notify channel after -// Close is called or a Read fails on the underlying ReadCloser. -type notifyingReader struct { - io.ReadCloser - notify chan<- struct{} -} - -func (r *notifyingReader) Read(p []byte) (int, error) { - n, err := r.ReadCloser.Read(p) - if err != nil && r.notify != nil { - close(r.notify) - r.notify = nil - } - return n, err -} - -func (r *notifyingReader) Close() error { - err := r.ReadCloser.Close() - if r.notify != nil { - close(r.notify) - r.notify = nil - } - return err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/go17.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/go17.go deleted file mode 100644 index f8cda19..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/go17.go +++ /dev/null @@ -1,72 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.7 - -package context - -import ( - "context" // standard library's context, as of Go 1.7 - "time" -) - -var ( - todo = context.TODO() - background = context.Background() -) - -// Canceled is the error returned by Context.Err when the context is canceled. -var Canceled = context.Canceled - -// DeadlineExceeded is the error returned by Context.Err when the context's -// deadline passes. -var DeadlineExceeded = context.DeadlineExceeded - -// WithCancel returns a copy of parent with a new Done channel. The returned -// context's Done channel is closed when the returned cancel function is called -// or when the parent context's Done channel is closed, whichever happens first. -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete. -func WithCancel(parent Context) (ctx Context, cancel CancelFunc) { - ctx, f := context.WithCancel(parent) - return ctx, CancelFunc(f) -} - -// WithDeadline returns a copy of the parent context with the deadline adjusted -// to be no later than d. If the parent's deadline is already earlier than d, -// WithDeadline(parent, d) is semantically equivalent to parent. The returned -// context's Done channel is closed when the deadline expires, when the returned -// cancel function is called, or when the parent context's Done channel is -// closed, whichever happens first. -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete. -func WithDeadline(parent Context, deadline time.Time) (Context, CancelFunc) { - ctx, f := context.WithDeadline(parent, deadline) - return ctx, CancelFunc(f) -} - -// WithTimeout returns WithDeadline(parent, time.Now().Add(timeout)). -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete: -// -// func slowOperationWithTimeout(ctx context.Context) (Result, error) { -// ctx, cancel := context.WithTimeout(ctx, 100*time.Millisecond) -// defer cancel() // releases resources if slowOperation completes before timeout elapses -// return slowOperation(ctx) -// } -func WithTimeout(parent Context, timeout time.Duration) (Context, CancelFunc) { - return WithDeadline(parent, time.Now().Add(timeout)) -} - -// WithValue returns a copy of parent in which the value associated with key is -// val. -// -// Use context Values only for request-scoped data that transits processes and -// APIs, not for passing optional parameters to functions. -func WithValue(parent Context, key interface{}, val interface{}) Context { - return context.WithValue(parent, key, val) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/pre_go17.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/pre_go17.go deleted file mode 100644 index 5a30aca..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/context/pre_go17.go +++ /dev/null @@ -1,300 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build !go1.7 - -package context - -import ( - "errors" - "fmt" - "sync" - "time" -) - -// An emptyCtx is never canceled, has no values, and has no deadline. It is not -// struct{}, since vars of this type must have distinct addresses. -type emptyCtx int - -func (*emptyCtx) Deadline() (deadline time.Time, ok bool) { - return -} - -func (*emptyCtx) Done() <-chan struct{} { - return nil -} - -func (*emptyCtx) Err() error { - return nil -} - -func (*emptyCtx) Value(key interface{}) interface{} { - return nil -} - -func (e *emptyCtx) String() string { - switch e { - case background: - return "context.Background" - case todo: - return "context.TODO" - } - return "unknown empty Context" -} - -var ( - background = new(emptyCtx) - todo = new(emptyCtx) -) - -// Canceled is the error returned by Context.Err when the context is canceled. -var Canceled = errors.New("context canceled") - -// DeadlineExceeded is the error returned by Context.Err when the context's -// deadline passes. -var DeadlineExceeded = errors.New("context deadline exceeded") - -// WithCancel returns a copy of parent with a new Done channel. The returned -// context's Done channel is closed when the returned cancel function is called -// or when the parent context's Done channel is closed, whichever happens first. -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete. -func WithCancel(parent Context) (ctx Context, cancel CancelFunc) { - c := newCancelCtx(parent) - propagateCancel(parent, c) - return c, func() { c.cancel(true, Canceled) } -} - -// newCancelCtx returns an initialized cancelCtx. -func newCancelCtx(parent Context) *cancelCtx { - return &cancelCtx{ - Context: parent, - done: make(chan struct{}), - } -} - -// propagateCancel arranges for child to be canceled when parent is. -func propagateCancel(parent Context, child canceler) { - if parent.Done() == nil { - return // parent is never canceled - } - if p, ok := parentCancelCtx(parent); ok { - p.mu.Lock() - if p.err != nil { - // parent has already been canceled - child.cancel(false, p.err) - } else { - if p.children == nil { - p.children = make(map[canceler]bool) - } - p.children[child] = true - } - p.mu.Unlock() - } else { - go func() { - select { - case <-parent.Done(): - child.cancel(false, parent.Err()) - case <-child.Done(): - } - }() - } -} - -// parentCancelCtx follows a chain of parent references until it finds a -// *cancelCtx. This function understands how each of the concrete types in this -// package represents its parent. -func parentCancelCtx(parent Context) (*cancelCtx, bool) { - for { - switch c := parent.(type) { - case *cancelCtx: - return c, true - case *timerCtx: - return c.cancelCtx, true - case *valueCtx: - parent = c.Context - default: - return nil, false - } - } -} - -// removeChild removes a context from its parent. -func removeChild(parent Context, child canceler) { - p, ok := parentCancelCtx(parent) - if !ok { - return - } - p.mu.Lock() - if p.children != nil { - delete(p.children, child) - } - p.mu.Unlock() -} - -// A canceler is a context type that can be canceled directly. The -// implementations are *cancelCtx and *timerCtx. -type canceler interface { - cancel(removeFromParent bool, err error) - Done() <-chan struct{} -} - -// A cancelCtx can be canceled. When canceled, it also cancels any children -// that implement canceler. -type cancelCtx struct { - Context - - done chan struct{} // closed by the first cancel call. - - mu sync.Mutex - children map[canceler]bool // set to nil by the first cancel call - err error // set to non-nil by the first cancel call -} - -func (c *cancelCtx) Done() <-chan struct{} { - return c.done -} - -func (c *cancelCtx) Err() error { - c.mu.Lock() - defer c.mu.Unlock() - return c.err -} - -func (c *cancelCtx) String() string { - return fmt.Sprintf("%v.WithCancel", c.Context) -} - -// cancel closes c.done, cancels each of c's children, and, if -// removeFromParent is true, removes c from its parent's children. -func (c *cancelCtx) cancel(removeFromParent bool, err error) { - if err == nil { - panic("context: internal error: missing cancel error") - } - c.mu.Lock() - if c.err != nil { - c.mu.Unlock() - return // already canceled - } - c.err = err - close(c.done) - for child := range c.children { - // NOTE: acquiring the child's lock while holding parent's lock. - child.cancel(false, err) - } - c.children = nil - c.mu.Unlock() - - if removeFromParent { - removeChild(c.Context, c) - } -} - -// WithDeadline returns a copy of the parent context with the deadline adjusted -// to be no later than d. If the parent's deadline is already earlier than d, -// WithDeadline(parent, d) is semantically equivalent to parent. The returned -// context's Done channel is closed when the deadline expires, when the returned -// cancel function is called, or when the parent context's Done channel is -// closed, whichever happens first. -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete. -func WithDeadline(parent Context, deadline time.Time) (Context, CancelFunc) { - if cur, ok := parent.Deadline(); ok && cur.Before(deadline) { - // The current deadline is already sooner than the new one. - return WithCancel(parent) - } - c := &timerCtx{ - cancelCtx: newCancelCtx(parent), - deadline: deadline, - } - propagateCancel(parent, c) - d := deadline.Sub(time.Now()) - if d <= 0 { - c.cancel(true, DeadlineExceeded) // deadline has already passed - return c, func() { c.cancel(true, Canceled) } - } - c.mu.Lock() - defer c.mu.Unlock() - if c.err == nil { - c.timer = time.AfterFunc(d, func() { - c.cancel(true, DeadlineExceeded) - }) - } - return c, func() { c.cancel(true, Canceled) } -} - -// A timerCtx carries a timer and a deadline. It embeds a cancelCtx to -// implement Done and Err. It implements cancel by stopping its timer then -// delegating to cancelCtx.cancel. -type timerCtx struct { - *cancelCtx - timer *time.Timer // Under cancelCtx.mu. - - deadline time.Time -} - -func (c *timerCtx) Deadline() (deadline time.Time, ok bool) { - return c.deadline, true -} - -func (c *timerCtx) String() string { - return fmt.Sprintf("%v.WithDeadline(%s [%s])", c.cancelCtx.Context, c.deadline, c.deadline.Sub(time.Now())) -} - -func (c *timerCtx) cancel(removeFromParent bool, err error) { - c.cancelCtx.cancel(false, err) - if removeFromParent { - // Remove this timerCtx from its parent cancelCtx's children. - removeChild(c.cancelCtx.Context, c) - } - c.mu.Lock() - if c.timer != nil { - c.timer.Stop() - c.timer = nil - } - c.mu.Unlock() -} - -// WithTimeout returns WithDeadline(parent, time.Now().Add(timeout)). -// -// Canceling this context releases resources associated with it, so code should -// call cancel as soon as the operations running in this Context complete: -// -// func slowOperationWithTimeout(ctx context.Context) (Result, error) { -// ctx, cancel := context.WithTimeout(ctx, 100*time.Millisecond) -// defer cancel() // releases resources if slowOperation completes before timeout elapses -// return slowOperation(ctx) -// } -func WithTimeout(parent Context, timeout time.Duration) (Context, CancelFunc) { - return WithDeadline(parent, time.Now().Add(timeout)) -} - -// WithValue returns a copy of parent in which the value associated with key is -// val. -// -// Use context Values only for request-scoped data that transits processes and -// APIs, not for passing optional parameters to functions. -func WithValue(parent Context, key interface{}, val interface{}) Context { - return &valueCtx{parent, key, val} -} - -// A valueCtx carries a key-value pair. It implements Value for that key and -// delegates all other calls to the embedded Context. -type valueCtx struct { - Context - key, val interface{} -} - -func (c *valueCtx) String() string { - return fmt.Sprintf("%v.WithValue(%#v, %#v)", c.Context, c.key, c.val) -} - -func (c *valueCtx) Value(key interface{}) interface{} { - if c.key == key { - return c.val - } - return c.Context.Value(key) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/.gitignore b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/.gitignore deleted file mode 100644 index 190f122..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/.gitignore +++ /dev/null @@ -1,2 +0,0 @@ -*~ -h2i/h2i diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Dockerfile b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Dockerfile deleted file mode 100644 index 53fc525..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Dockerfile +++ /dev/null @@ -1,51 +0,0 @@ -# -# This Dockerfile builds a recent curl with HTTP/2 client support, using -# a recent nghttp2 build. -# -# See the Makefile for how to tag it. If Docker and that image is found, the -# Go tests use this curl binary for integration tests. -# - -FROM ubuntu:trusty - -RUN apt-get update && \ - apt-get upgrade -y && \ - apt-get install -y git-core build-essential wget - -RUN apt-get install -y --no-install-recommends \ - autotools-dev libtool pkg-config zlib1g-dev \ - libcunit1-dev libssl-dev libxml2-dev libevent-dev \ - automake autoconf - -# The list of packages nghttp2 recommends for h2load: -RUN apt-get install -y --no-install-recommends make binutils \ - autoconf automake autotools-dev \ - libtool pkg-config zlib1g-dev libcunit1-dev libssl-dev libxml2-dev \ - libev-dev libevent-dev libjansson-dev libjemalloc-dev \ - cython python3.4-dev python-setuptools - -# Note: setting NGHTTP2_VER before the git clone, so an old git clone isn't cached: -ENV NGHTTP2_VER 895da9a -RUN cd /root && git clone https://github.com/tatsuhiro-t/nghttp2.git - -WORKDIR /root/nghttp2 -RUN git reset --hard $NGHTTP2_VER -RUN autoreconf -i -RUN automake -RUN autoconf -RUN ./configure -RUN make -RUN make install - -WORKDIR /root -RUN wget http://curl.haxx.se/download/curl-7.45.0.tar.gz -RUN tar -zxvf curl-7.45.0.tar.gz -WORKDIR /root/curl-7.45.0 -RUN ./configure --with-ssl --with-nghttp2=/usr/local -RUN make -RUN make install -RUN ldconfig - -CMD ["-h"] -ENTRYPOINT ["/usr/local/bin/curl"] - diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Makefile b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Makefile deleted file mode 100644 index 55fd826..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/Makefile +++ /dev/null @@ -1,3 +0,0 @@ -curlimage: - docker build -t gohttp2/curl . - diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/README b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/README deleted file mode 100644 index 360d5aa..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/README +++ /dev/null @@ -1,20 +0,0 @@ -This is a work-in-progress HTTP/2 implementation for Go. - -It will eventually live in the Go standard library and won't require -any changes to your code to use. It will just be automatic. - -Status: - -* The server support is pretty good. A few things are missing - but are being worked on. -* The client work has just started but shares a lot of code - is coming along much quicker. - -Docs are at https://godoc.org/golang.org/x/net/http2 - -Demo test server at https://http2.golang.org/ - -Help & bug reports welcome! - -Contributing: https://golang.org/doc/contribute.html -Bugs: https://golang.org/issue/new?title=x/net/http2:+ diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/client_conn_pool.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/client_conn_pool.go deleted file mode 100644 index 547e238..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/client_conn_pool.go +++ /dev/null @@ -1,255 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Transport code's client connection pooling. - -package http2 - -import ( - "crypto/tls" - "net/http" - "sync" -) - -// ClientConnPool manages a pool of HTTP/2 client connections. -type ClientConnPool interface { - GetClientConn(req *http.Request, addr string) (*ClientConn, error) - MarkDead(*ClientConn) -} - -// clientConnPoolIdleCloser is the interface implemented by ClientConnPool -// implementations which can close their idle connections. -type clientConnPoolIdleCloser interface { - ClientConnPool - closeIdleConnections() -} - -var ( - _ clientConnPoolIdleCloser = (*clientConnPool)(nil) - _ clientConnPoolIdleCloser = noDialClientConnPool{} -) - -// TODO: use singleflight for dialing and addConnCalls? -type clientConnPool struct { - t *Transport - - mu sync.Mutex // TODO: maybe switch to RWMutex - // TODO: add support for sharing conns based on cert names - // (e.g. share conn for googleapis.com and appspot.com) - conns map[string][]*ClientConn // key is host:port - dialing map[string]*dialCall // currently in-flight dials - keys map[*ClientConn][]string - addConnCalls map[string]*addConnCall // in-flight addConnIfNeede calls -} - -func (p *clientConnPool) GetClientConn(req *http.Request, addr string) (*ClientConn, error) { - return p.getClientConn(req, addr, dialOnMiss) -} - -const ( - dialOnMiss = true - noDialOnMiss = false -) - -func (p *clientConnPool) getClientConn(req *http.Request, addr string, dialOnMiss bool) (*ClientConn, error) { - if req.Close && dialOnMiss { - // It gets its own connection. - cc, err := p.t.dialClientConn(addr) - if err != nil { - return nil, err - } - cc.singleUse = true - return cc, nil - } - p.mu.Lock() - for _, cc := range p.conns[addr] { - if cc.CanTakeNewRequest() { - p.mu.Unlock() - return cc, nil - } - } - if !dialOnMiss { - p.mu.Unlock() - return nil, ErrNoCachedConn - } - call := p.getStartDialLocked(addr) - p.mu.Unlock() - <-call.done - return call.res, call.err -} - -// dialCall is an in-flight Transport dial call to a host. -type dialCall struct { - p *clientConnPool - done chan struct{} // closed when done - res *ClientConn // valid after done is closed - err error // valid after done is closed -} - -// requires p.mu is held. -func (p *clientConnPool) getStartDialLocked(addr string) *dialCall { - if call, ok := p.dialing[addr]; ok { - // A dial is already in-flight. Don't start another. - return call - } - call := &dialCall{p: p, done: make(chan struct{})} - if p.dialing == nil { - p.dialing = make(map[string]*dialCall) - } - p.dialing[addr] = call - go call.dial(addr) - return call -} - -// run in its own goroutine. -func (c *dialCall) dial(addr string) { - c.res, c.err = c.p.t.dialClientConn(addr) - close(c.done) - - c.p.mu.Lock() - delete(c.p.dialing, addr) - if c.err == nil { - c.p.addConnLocked(addr, c.res) - } - c.p.mu.Unlock() -} - -// addConnIfNeeded makes a NewClientConn out of c if a connection for key doesn't -// already exist. It coalesces concurrent calls with the same key. -// This is used by the http1 Transport code when it creates a new connection. Because -// the http1 Transport doesn't de-dup TCP dials to outbound hosts (because it doesn't know -// the protocol), it can get into a situation where it has multiple TLS connections. -// This code decides which ones live or die. -// The return value used is whether c was used. -// c is never closed. -func (p *clientConnPool) addConnIfNeeded(key string, t *Transport, c *tls.Conn) (used bool, err error) { - p.mu.Lock() - for _, cc := range p.conns[key] { - if cc.CanTakeNewRequest() { - p.mu.Unlock() - return false, nil - } - } - call, dup := p.addConnCalls[key] - if !dup { - if p.addConnCalls == nil { - p.addConnCalls = make(map[string]*addConnCall) - } - call = &addConnCall{ - p: p, - done: make(chan struct{}), - } - p.addConnCalls[key] = call - go call.run(t, key, c) - } - p.mu.Unlock() - - <-call.done - if call.err != nil { - return false, call.err - } - return !dup, nil -} - -type addConnCall struct { - p *clientConnPool - done chan struct{} // closed when done - err error -} - -func (c *addConnCall) run(t *Transport, key string, tc *tls.Conn) { - cc, err := t.NewClientConn(tc) - - p := c.p - p.mu.Lock() - if err != nil { - c.err = err - } else { - p.addConnLocked(key, cc) - } - delete(p.addConnCalls, key) - p.mu.Unlock() - close(c.done) -} - -func (p *clientConnPool) addConn(key string, cc *ClientConn) { - p.mu.Lock() - p.addConnLocked(key, cc) - p.mu.Unlock() -} - -// p.mu must be held -func (p *clientConnPool) addConnLocked(key string, cc *ClientConn) { - for _, v := range p.conns[key] { - if v == cc { - return - } - } - if p.conns == nil { - p.conns = make(map[string][]*ClientConn) - } - if p.keys == nil { - p.keys = make(map[*ClientConn][]string) - } - p.conns[key] = append(p.conns[key], cc) - p.keys[cc] = append(p.keys[cc], key) -} - -func (p *clientConnPool) MarkDead(cc *ClientConn) { - p.mu.Lock() - defer p.mu.Unlock() - for _, key := range p.keys[cc] { - vv, ok := p.conns[key] - if !ok { - continue - } - newList := filterOutClientConn(vv, cc) - if len(newList) > 0 { - p.conns[key] = newList - } else { - delete(p.conns, key) - } - } - delete(p.keys, cc) -} - -func (p *clientConnPool) closeIdleConnections() { - p.mu.Lock() - defer p.mu.Unlock() - // TODO: don't close a cc if it was just added to the pool - // milliseconds ago and has never been used. There's currently - // a small race window with the HTTP/1 Transport's integration - // where it can add an idle conn just before using it, and - // somebody else can concurrently call CloseIdleConns and - // break some caller's RoundTrip. - for _, vv := range p.conns { - for _, cc := range vv { - cc.closeIfIdle() - } - } -} - -func filterOutClientConn(in []*ClientConn, exclude *ClientConn) []*ClientConn { - out := in[:0] - for _, v := range in { - if v != exclude { - out = append(out, v) - } - } - // If we filtered it out, zero out the last item to prevent - // the GC from seeing it. - if len(in) != len(out) { - in[len(in)-1] = nil - } - return out -} - -// noDialClientConnPool is an implementation of http2.ClientConnPool -// which never dials. We let the HTTP/1.1 client dial and use its TLS -// connection instead. -type noDialClientConnPool struct{ *clientConnPool } - -func (p noDialClientConnPool) GetClientConn(req *http.Request, addr string) (*ClientConn, error) { - return p.getClientConn(req, addr, noDialOnMiss) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/configure_transport.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/configure_transport.go deleted file mode 100644 index 4f720f5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/configure_transport.go +++ /dev/null @@ -1,80 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.6 - -package http2 - -import ( - "crypto/tls" - "fmt" - "net/http" -) - -func configureTransport(t1 *http.Transport) (*Transport, error) { - connPool := new(clientConnPool) - t2 := &Transport{ - ConnPool: noDialClientConnPool{connPool}, - t1: t1, - } - connPool.t = t2 - if err := registerHTTPSProtocol(t1, noDialH2RoundTripper{t2}); err != nil { - return nil, err - } - if t1.TLSClientConfig == nil { - t1.TLSClientConfig = new(tls.Config) - } - if !strSliceContains(t1.TLSClientConfig.NextProtos, "h2") { - t1.TLSClientConfig.NextProtos = append([]string{"h2"}, t1.TLSClientConfig.NextProtos...) - } - if !strSliceContains(t1.TLSClientConfig.NextProtos, "http/1.1") { - t1.TLSClientConfig.NextProtos = append(t1.TLSClientConfig.NextProtos, "http/1.1") - } - upgradeFn := func(authority string, c *tls.Conn) http.RoundTripper { - addr := authorityAddr("https", authority) - if used, err := connPool.addConnIfNeeded(addr, t2, c); err != nil { - go c.Close() - return erringRoundTripper{err} - } else if !used { - // Turns out we don't need this c. - // For example, two goroutines made requests to the same host - // at the same time, both kicking off TCP dials. (since protocol - // was unknown) - go c.Close() - } - return t2 - } - if m := t1.TLSNextProto; len(m) == 0 { - t1.TLSNextProto = map[string]func(string, *tls.Conn) http.RoundTripper{ - "h2": upgradeFn, - } - } else { - m["h2"] = upgradeFn - } - return t2, nil -} - -// registerHTTPSProtocol calls Transport.RegisterProtocol but -// convering panics into errors. -func registerHTTPSProtocol(t *http.Transport, rt http.RoundTripper) (err error) { - defer func() { - if e := recover(); e != nil { - err = fmt.Errorf("%v", e) - } - }() - t.RegisterProtocol("https", rt) - return nil -} - -// noDialH2RoundTripper is a RoundTripper which only tries to complete the request -// if there's already has a cached connection to the host. -type noDialH2RoundTripper struct{ t *Transport } - -func (rt noDialH2RoundTripper) RoundTrip(req *http.Request) (*http.Response, error) { - res, err := rt.t.RoundTrip(req) - if err == ErrNoCachedConn { - return nil, http.ErrSkipAltProtocol - } - return res, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/errors.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/errors.go deleted file mode 100644 index 71a4e29..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/errors.go +++ /dev/null @@ -1,122 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "errors" - "fmt" -) - -// An ErrCode is an unsigned 32-bit error code as defined in the HTTP/2 spec. -type ErrCode uint32 - -const ( - ErrCodeNo ErrCode = 0x0 - ErrCodeProtocol ErrCode = 0x1 - ErrCodeInternal ErrCode = 0x2 - ErrCodeFlowControl ErrCode = 0x3 - ErrCodeSettingsTimeout ErrCode = 0x4 - ErrCodeStreamClosed ErrCode = 0x5 - ErrCodeFrameSize ErrCode = 0x6 - ErrCodeRefusedStream ErrCode = 0x7 - ErrCodeCancel ErrCode = 0x8 - ErrCodeCompression ErrCode = 0x9 - ErrCodeConnect ErrCode = 0xa - ErrCodeEnhanceYourCalm ErrCode = 0xb - ErrCodeInadequateSecurity ErrCode = 0xc - ErrCodeHTTP11Required ErrCode = 0xd -) - -var errCodeName = map[ErrCode]string{ - ErrCodeNo: "NO_ERROR", - ErrCodeProtocol: "PROTOCOL_ERROR", - ErrCodeInternal: "INTERNAL_ERROR", - ErrCodeFlowControl: "FLOW_CONTROL_ERROR", - ErrCodeSettingsTimeout: "SETTINGS_TIMEOUT", - ErrCodeStreamClosed: "STREAM_CLOSED", - ErrCodeFrameSize: "FRAME_SIZE_ERROR", - ErrCodeRefusedStream: "REFUSED_STREAM", - ErrCodeCancel: "CANCEL", - ErrCodeCompression: "COMPRESSION_ERROR", - ErrCodeConnect: "CONNECT_ERROR", - ErrCodeEnhanceYourCalm: "ENHANCE_YOUR_CALM", - ErrCodeInadequateSecurity: "INADEQUATE_SECURITY", - ErrCodeHTTP11Required: "HTTP_1_1_REQUIRED", -} - -func (e ErrCode) String() string { - if s, ok := errCodeName[e]; ok { - return s - } - return fmt.Sprintf("unknown error code 0x%x", uint32(e)) -} - -// ConnectionError is an error that results in the termination of the -// entire connection. -type ConnectionError ErrCode - -func (e ConnectionError) Error() string { return fmt.Sprintf("connection error: %s", ErrCode(e)) } - -// StreamError is an error that only affects one stream within an -// HTTP/2 connection. -type StreamError struct { - StreamID uint32 - Code ErrCode -} - -func (e StreamError) Error() string { - return fmt.Sprintf("stream error: stream ID %d; %v", e.StreamID, e.Code) -} - -// 6.9.1 The Flow Control Window -// "If a sender receives a WINDOW_UPDATE that causes a flow control -// window to exceed this maximum it MUST terminate either the stream -// or the connection, as appropriate. For streams, [...]; for the -// connection, a GOAWAY frame with a FLOW_CONTROL_ERROR code." -type goAwayFlowError struct{} - -func (goAwayFlowError) Error() string { return "connection exceeded flow control window size" } - -// connErrorReason wraps a ConnectionError with an informative error about why it occurs. - -// Errors of this type are only returned by the frame parser functions -// and converted into ConnectionError(ErrCodeProtocol). -type connError struct { - Code ErrCode - Reason string -} - -func (e connError) Error() string { - return fmt.Sprintf("http2: connection error: %v: %v", e.Code, e.Reason) -} - -type pseudoHeaderError string - -func (e pseudoHeaderError) Error() string { - return fmt.Sprintf("invalid pseudo-header %q", string(e)) -} - -type duplicatePseudoHeaderError string - -func (e duplicatePseudoHeaderError) Error() string { - return fmt.Sprintf("duplicate pseudo-header %q", string(e)) -} - -type headerFieldNameError string - -func (e headerFieldNameError) Error() string { - return fmt.Sprintf("invalid header field name %q", string(e)) -} - -type headerFieldValueError string - -func (e headerFieldValueError) Error() string { - return fmt.Sprintf("invalid header field value %q", string(e)) -} - -var ( - errMixPseudoHeaderTypes = errors.New("mix of request and response pseudo headers") - errPseudoAfterRegular = errors.New("pseudo header field after regular") -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/fixed_buffer.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/fixed_buffer.go deleted file mode 100644 index 47da0f0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/fixed_buffer.go +++ /dev/null @@ -1,60 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "errors" -) - -// fixedBuffer is an io.ReadWriter backed by a fixed size buffer. -// It never allocates, but moves old data as new data is written. -type fixedBuffer struct { - buf []byte - r, w int -} - -var ( - errReadEmpty = errors.New("read from empty fixedBuffer") - errWriteFull = errors.New("write on full fixedBuffer") -) - -// Read copies bytes from the buffer into p. -// It is an error to read when no data is available. -func (b *fixedBuffer) Read(p []byte) (n int, err error) { - if b.r == b.w { - return 0, errReadEmpty - } - n = copy(p, b.buf[b.r:b.w]) - b.r += n - if b.r == b.w { - b.r = 0 - b.w = 0 - } - return n, nil -} - -// Len returns the number of bytes of the unread portion of the buffer. -func (b *fixedBuffer) Len() int { - return b.w - b.r -} - -// Write copies bytes from p into the buffer. -// It is an error to write more data than the buffer can hold. -func (b *fixedBuffer) Write(p []byte) (n int, err error) { - // Slide existing data to beginning. - if b.r > 0 && len(p) > len(b.buf)-b.w { - copy(b.buf, b.buf[b.r:b.w]) - b.w -= b.r - b.r = 0 - } - - // Write new data. - n = copy(b.buf[b.w:], p) - b.w += n - if n < len(p) { - err = errWriteFull - } - return n, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/flow.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/flow.go deleted file mode 100644 index 957de25..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/flow.go +++ /dev/null @@ -1,50 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Flow control - -package http2 - -// flow is the flow control window's size. -type flow struct { - // n is the number of DATA bytes we're allowed to send. - // A flow is kept both on a conn and a per-stream. - n int32 - - // conn points to the shared connection-level flow that is - // shared by all streams on that conn. It is nil for the flow - // that's on the conn directly. - conn *flow -} - -func (f *flow) setConnFlow(cf *flow) { f.conn = cf } - -func (f *flow) available() int32 { - n := f.n - if f.conn != nil && f.conn.n < n { - n = f.conn.n - } - return n -} - -func (f *flow) take(n int32) { - if n > f.available() { - panic("internal error: took too much") - } - f.n -= n - if f.conn != nil { - f.conn.n -= n - } -} - -// add adds n bytes (positive or negative) to the flow control window. -// It returns false if the sum would exceed 2^31-1. -func (f *flow) add(n int32) bool { - remain := (1<<31 - 1) - f.n - if n > remain { - return false - } - f.n += n - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/frame.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/frame.go deleted file mode 100644 index 981d407..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/frame.go +++ /dev/null @@ -1,1507 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "bytes" - "encoding/binary" - "errors" - "fmt" - "io" - "log" - "strings" - "sync" - - "golang.org/x/net/http2/hpack" - "golang.org/x/net/lex/httplex" -) - -const frameHeaderLen = 9 - -var padZeros = make([]byte, 255) // zeros for padding - -// A FrameType is a registered frame type as defined in -// http://http2.github.io/http2-spec/#rfc.section.11.2 -type FrameType uint8 - -const ( - FrameData FrameType = 0x0 - FrameHeaders FrameType = 0x1 - FramePriority FrameType = 0x2 - FrameRSTStream FrameType = 0x3 - FrameSettings FrameType = 0x4 - FramePushPromise FrameType = 0x5 - FramePing FrameType = 0x6 - FrameGoAway FrameType = 0x7 - FrameWindowUpdate FrameType = 0x8 - FrameContinuation FrameType = 0x9 -) - -var frameName = map[FrameType]string{ - FrameData: "DATA", - FrameHeaders: "HEADERS", - FramePriority: "PRIORITY", - FrameRSTStream: "RST_STREAM", - FrameSettings: "SETTINGS", - FramePushPromise: "PUSH_PROMISE", - FramePing: "PING", - FrameGoAway: "GOAWAY", - FrameWindowUpdate: "WINDOW_UPDATE", - FrameContinuation: "CONTINUATION", -} - -func (t FrameType) String() string { - if s, ok := frameName[t]; ok { - return s - } - return fmt.Sprintf("UNKNOWN_FRAME_TYPE_%d", uint8(t)) -} - -// Flags is a bitmask of HTTP/2 flags. -// The meaning of flags varies depending on the frame type. -type Flags uint8 - -// Has reports whether f contains all (0 or more) flags in v. -func (f Flags) Has(v Flags) bool { - return (f & v) == v -} - -// Frame-specific FrameHeader flag bits. -const ( - // Data Frame - FlagDataEndStream Flags = 0x1 - FlagDataPadded Flags = 0x8 - - // Headers Frame - FlagHeadersEndStream Flags = 0x1 - FlagHeadersEndHeaders Flags = 0x4 - FlagHeadersPadded Flags = 0x8 - FlagHeadersPriority Flags = 0x20 - - // Settings Frame - FlagSettingsAck Flags = 0x1 - - // Ping Frame - FlagPingAck Flags = 0x1 - - // Continuation Frame - FlagContinuationEndHeaders Flags = 0x4 - - FlagPushPromiseEndHeaders Flags = 0x4 - FlagPushPromisePadded Flags = 0x8 -) - -var flagName = map[FrameType]map[Flags]string{ - FrameData: { - FlagDataEndStream: "END_STREAM", - FlagDataPadded: "PADDED", - }, - FrameHeaders: { - FlagHeadersEndStream: "END_STREAM", - FlagHeadersEndHeaders: "END_HEADERS", - FlagHeadersPadded: "PADDED", - FlagHeadersPriority: "PRIORITY", - }, - FrameSettings: { - FlagSettingsAck: "ACK", - }, - FramePing: { - FlagPingAck: "ACK", - }, - FrameContinuation: { - FlagContinuationEndHeaders: "END_HEADERS", - }, - FramePushPromise: { - FlagPushPromiseEndHeaders: "END_HEADERS", - FlagPushPromisePadded: "PADDED", - }, -} - -// a frameParser parses a frame given its FrameHeader and payload -// bytes. The length of payload will always equal fh.Length (which -// might be 0). -type frameParser func(fh FrameHeader, payload []byte) (Frame, error) - -var frameParsers = map[FrameType]frameParser{ - FrameData: parseDataFrame, - FrameHeaders: parseHeadersFrame, - FramePriority: parsePriorityFrame, - FrameRSTStream: parseRSTStreamFrame, - FrameSettings: parseSettingsFrame, - FramePushPromise: parsePushPromise, - FramePing: parsePingFrame, - FrameGoAway: parseGoAwayFrame, - FrameWindowUpdate: parseWindowUpdateFrame, - FrameContinuation: parseContinuationFrame, -} - -func typeFrameParser(t FrameType) frameParser { - if f := frameParsers[t]; f != nil { - return f - } - return parseUnknownFrame -} - -// A FrameHeader is the 9 byte header of all HTTP/2 frames. -// -// See http://http2.github.io/http2-spec/#FrameHeader -type FrameHeader struct { - valid bool // caller can access []byte fields in the Frame - - // Type is the 1 byte frame type. There are ten standard frame - // types, but extension frame types may be written by WriteRawFrame - // and will be returned by ReadFrame (as UnknownFrame). - Type FrameType - - // Flags are the 1 byte of 8 potential bit flags per frame. - // They are specific to the frame type. - Flags Flags - - // Length is the length of the frame, not including the 9 byte header. - // The maximum size is one byte less than 16MB (uint24), but only - // frames up to 16KB are allowed without peer agreement. - Length uint32 - - // StreamID is which stream this frame is for. Certain frames - // are not stream-specific, in which case this field is 0. - StreamID uint32 -} - -// Header returns h. It exists so FrameHeaders can be embedded in other -// specific frame types and implement the Frame interface. -func (h FrameHeader) Header() FrameHeader { return h } - -func (h FrameHeader) String() string { - var buf bytes.Buffer - buf.WriteString("[FrameHeader ") - h.writeDebug(&buf) - buf.WriteByte(']') - return buf.String() -} - -func (h FrameHeader) writeDebug(buf *bytes.Buffer) { - buf.WriteString(h.Type.String()) - if h.Flags != 0 { - buf.WriteString(" flags=") - set := 0 - for i := uint8(0); i < 8; i++ { - if h.Flags&(1< 1 { - buf.WriteByte('|') - } - name := flagName[h.Type][Flags(1<>24), - byte(streamID>>16), - byte(streamID>>8), - byte(streamID)) -} - -func (f *Framer) endWrite() error { - // Now that we know the final size, fill in the FrameHeader in - // the space previously reserved for it. Abuse append. - length := len(f.wbuf) - frameHeaderLen - if length >= (1 << 24) { - return ErrFrameTooLarge - } - _ = append(f.wbuf[:0], - byte(length>>16), - byte(length>>8), - byte(length)) - if logFrameWrites { - f.logWrite() - } - - n, err := f.w.Write(f.wbuf) - if err == nil && n != len(f.wbuf) { - err = io.ErrShortWrite - } - return err -} - -func (f *Framer) logWrite() { - if f.debugFramer == nil { - f.debugFramerBuf = new(bytes.Buffer) - f.debugFramer = NewFramer(nil, f.debugFramerBuf) - f.debugFramer.logReads = false // we log it ourselves, saying "wrote" below - // Let us read anything, even if we accidentally wrote it - // in the wrong order: - f.debugFramer.AllowIllegalReads = true - } - f.debugFramerBuf.Write(f.wbuf) - fr, err := f.debugFramer.ReadFrame() - if err != nil { - log.Printf("http2: Framer %p: failed to decode just-written frame", f) - return - } - log.Printf("http2: Framer %p: wrote %v", f, summarizeFrame(fr)) -} - -func (f *Framer) writeByte(v byte) { f.wbuf = append(f.wbuf, v) } -func (f *Framer) writeBytes(v []byte) { f.wbuf = append(f.wbuf, v...) } -func (f *Framer) writeUint16(v uint16) { f.wbuf = append(f.wbuf, byte(v>>8), byte(v)) } -func (f *Framer) writeUint32(v uint32) { - f.wbuf = append(f.wbuf, byte(v>>24), byte(v>>16), byte(v>>8), byte(v)) -} - -const ( - minMaxFrameSize = 1 << 14 - maxFrameSize = 1<<24 - 1 -) - -// NewFramer returns a Framer that writes frames to w and reads them from r. -func NewFramer(w io.Writer, r io.Reader) *Framer { - fr := &Framer{ - w: w, - r: r, - logReads: logFrameReads, - } - fr.getReadBuf = func(size uint32) []byte { - if cap(fr.readBuf) >= int(size) { - return fr.readBuf[:size] - } - fr.readBuf = make([]byte, size) - return fr.readBuf - } - fr.SetMaxReadFrameSize(maxFrameSize) - return fr -} - -// SetMaxReadFrameSize sets the maximum size of a frame -// that will be read by a subsequent call to ReadFrame. -// It is the caller's responsibility to advertise this -// limit with a SETTINGS frame. -func (fr *Framer) SetMaxReadFrameSize(v uint32) { - if v > maxFrameSize { - v = maxFrameSize - } - fr.maxReadSize = v -} - -// ErrorDetail returns a more detailed error of the last error -// returned by Framer.ReadFrame. For instance, if ReadFrame -// returns a StreamError with code PROTOCOL_ERROR, ErrorDetail -// will say exactly what was invalid. ErrorDetail is not guaranteed -// to return a non-nil value and like the rest of the http2 package, -// its return value is not protected by an API compatibility promise. -// ErrorDetail is reset after the next call to ReadFrame. -func (fr *Framer) ErrorDetail() error { - return fr.errDetail -} - -// ErrFrameTooLarge is returned from Framer.ReadFrame when the peer -// sends a frame that is larger than declared with SetMaxReadFrameSize. -var ErrFrameTooLarge = errors.New("http2: frame too large") - -// terminalReadFrameError reports whether err is an unrecoverable -// error from ReadFrame and no other frames should be read. -func terminalReadFrameError(err error) bool { - if _, ok := err.(StreamError); ok { - return false - } - return err != nil -} - -// ReadFrame reads a single frame. The returned Frame is only valid -// until the next call to ReadFrame. -// -// If the frame is larger than previously set with SetMaxReadFrameSize, the -// returned error is ErrFrameTooLarge. Other errors may be of type -// ConnectionError, StreamError, or anything else from the underlying -// reader. -func (fr *Framer) ReadFrame() (Frame, error) { - fr.errDetail = nil - if fr.lastFrame != nil { - fr.lastFrame.invalidate() - } - fh, err := readFrameHeader(fr.headerBuf[:], fr.r) - if err != nil { - return nil, err - } - if fh.Length > fr.maxReadSize { - return nil, ErrFrameTooLarge - } - payload := fr.getReadBuf(fh.Length) - if _, err := io.ReadFull(fr.r, payload); err != nil { - return nil, err - } - f, err := typeFrameParser(fh.Type)(fh, payload) - if err != nil { - if ce, ok := err.(connError); ok { - return nil, fr.connError(ce.Code, ce.Reason) - } - return nil, err - } - if err := fr.checkFrameOrder(f); err != nil { - return nil, err - } - if fr.logReads { - log.Printf("http2: Framer %p: read %v", fr, summarizeFrame(f)) - } - if fh.Type == FrameHeaders && fr.ReadMetaHeaders != nil { - return fr.readMetaFrame(f.(*HeadersFrame)) - } - return f, nil -} - -// connError returns ConnectionError(code) but first -// stashes away a public reason to the caller can optionally relay it -// to the peer before hanging up on them. This might help others debug -// their implementations. -func (fr *Framer) connError(code ErrCode, reason string) error { - fr.errDetail = errors.New(reason) - return ConnectionError(code) -} - -// checkFrameOrder reports an error if f is an invalid frame to return -// next from ReadFrame. Mostly it checks whether HEADERS and -// CONTINUATION frames are contiguous. -func (fr *Framer) checkFrameOrder(f Frame) error { - last := fr.lastFrame - fr.lastFrame = f - if fr.AllowIllegalReads { - return nil - } - - fh := f.Header() - if fr.lastHeaderStream != 0 { - if fh.Type != FrameContinuation { - return fr.connError(ErrCodeProtocol, - fmt.Sprintf("got %s for stream %d; expected CONTINUATION following %s for stream %d", - fh.Type, fh.StreamID, - last.Header().Type, fr.lastHeaderStream)) - } - if fh.StreamID != fr.lastHeaderStream { - return fr.connError(ErrCodeProtocol, - fmt.Sprintf("got CONTINUATION for stream %d; expected stream %d", - fh.StreamID, fr.lastHeaderStream)) - } - } else if fh.Type == FrameContinuation { - return fr.connError(ErrCodeProtocol, fmt.Sprintf("unexpected CONTINUATION for stream %d", fh.StreamID)) - } - - switch fh.Type { - case FrameHeaders, FrameContinuation: - if fh.Flags.Has(FlagHeadersEndHeaders) { - fr.lastHeaderStream = 0 - } else { - fr.lastHeaderStream = fh.StreamID - } - } - - return nil -} - -// A DataFrame conveys arbitrary, variable-length sequences of octets -// associated with a stream. -// See http://http2.github.io/http2-spec/#rfc.section.6.1 -type DataFrame struct { - FrameHeader - data []byte -} - -func (f *DataFrame) StreamEnded() bool { - return f.FrameHeader.Flags.Has(FlagDataEndStream) -} - -// Data returns the frame's data octets, not including any padding -// size byte or padding suffix bytes. -// The caller must not retain the returned memory past the next -// call to ReadFrame. -func (f *DataFrame) Data() []byte { - f.checkValid() - return f.data -} - -func parseDataFrame(fh FrameHeader, payload []byte) (Frame, error) { - if fh.StreamID == 0 { - // DATA frames MUST be associated with a stream. If a - // DATA frame is received whose stream identifier - // field is 0x0, the recipient MUST respond with a - // connection error (Section 5.4.1) of type - // PROTOCOL_ERROR. - return nil, connError{ErrCodeProtocol, "DATA frame with stream ID 0"} - } - f := &DataFrame{ - FrameHeader: fh, - } - var padSize byte - if fh.Flags.Has(FlagDataPadded) { - var err error - payload, padSize, err = readByte(payload) - if err != nil { - return nil, err - } - } - if int(padSize) > len(payload) { - // If the length of the padding is greater than the - // length of the frame payload, the recipient MUST - // treat this as a connection error. - // Filed: https://github.com/http2/http2-spec/issues/610 - return nil, connError{ErrCodeProtocol, "pad size larger than data payload"} - } - f.data = payload[:len(payload)-int(padSize)] - return f, nil -} - -var ( - errStreamID = errors.New("invalid stream ID") - errDepStreamID = errors.New("invalid dependent stream ID") -) - -func validStreamIDOrZero(streamID uint32) bool { - return streamID&(1<<31) == 0 -} - -func validStreamID(streamID uint32) bool { - return streamID != 0 && streamID&(1<<31) == 0 -} - -// WriteData writes a DATA frame. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteData(streamID uint32, endStream bool, data []byte) error { - // TODO: ignoring padding for now. will add when somebody cares. - if !validStreamID(streamID) && !f.AllowIllegalWrites { - return errStreamID - } - var flags Flags - if endStream { - flags |= FlagDataEndStream - } - f.startWrite(FrameData, flags, streamID) - f.wbuf = append(f.wbuf, data...) - return f.endWrite() -} - -// A SettingsFrame conveys configuration parameters that affect how -// endpoints communicate, such as preferences and constraints on peer -// behavior. -// -// See http://http2.github.io/http2-spec/#SETTINGS -type SettingsFrame struct { - FrameHeader - p []byte -} - -func parseSettingsFrame(fh FrameHeader, p []byte) (Frame, error) { - if fh.Flags.Has(FlagSettingsAck) && fh.Length > 0 { - // When this (ACK 0x1) bit is set, the payload of the - // SETTINGS frame MUST be empty. Receipt of a - // SETTINGS frame with the ACK flag set and a length - // field value other than 0 MUST be treated as a - // connection error (Section 5.4.1) of type - // FRAME_SIZE_ERROR. - return nil, ConnectionError(ErrCodeFrameSize) - } - if fh.StreamID != 0 { - // SETTINGS frames always apply to a connection, - // never a single stream. The stream identifier for a - // SETTINGS frame MUST be zero (0x0). If an endpoint - // receives a SETTINGS frame whose stream identifier - // field is anything other than 0x0, the endpoint MUST - // respond with a connection error (Section 5.4.1) of - // type PROTOCOL_ERROR. - return nil, ConnectionError(ErrCodeProtocol) - } - if len(p)%6 != 0 { - // Expecting even number of 6 byte settings. - return nil, ConnectionError(ErrCodeFrameSize) - } - f := &SettingsFrame{FrameHeader: fh, p: p} - if v, ok := f.Value(SettingInitialWindowSize); ok && v > (1<<31)-1 { - // Values above the maximum flow control window size of 2^31 - 1 MUST - // be treated as a connection error (Section 5.4.1) of type - // FLOW_CONTROL_ERROR. - return nil, ConnectionError(ErrCodeFlowControl) - } - return f, nil -} - -func (f *SettingsFrame) IsAck() bool { - return f.FrameHeader.Flags.Has(FlagSettingsAck) -} - -func (f *SettingsFrame) Value(s SettingID) (v uint32, ok bool) { - f.checkValid() - buf := f.p - for len(buf) > 0 { - settingID := SettingID(binary.BigEndian.Uint16(buf[:2])) - if settingID == s { - return binary.BigEndian.Uint32(buf[2:6]), true - } - buf = buf[6:] - } - return 0, false -} - -// ForeachSetting runs fn for each setting. -// It stops and returns the first error. -func (f *SettingsFrame) ForeachSetting(fn func(Setting) error) error { - f.checkValid() - buf := f.p - for len(buf) > 0 { - if err := fn(Setting{ - SettingID(binary.BigEndian.Uint16(buf[:2])), - binary.BigEndian.Uint32(buf[2:6]), - }); err != nil { - return err - } - buf = buf[6:] - } - return nil -} - -// WriteSettings writes a SETTINGS frame with zero or more settings -// specified and the ACK bit not set. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteSettings(settings ...Setting) error { - f.startWrite(FrameSettings, 0, 0) - for _, s := range settings { - f.writeUint16(uint16(s.ID)) - f.writeUint32(s.Val) - } - return f.endWrite() -} - -// WriteSettings writes an empty SETTINGS frame with the ACK bit set. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteSettingsAck() error { - f.startWrite(FrameSettings, FlagSettingsAck, 0) - return f.endWrite() -} - -// A PingFrame is a mechanism for measuring a minimal round trip time -// from the sender, as well as determining whether an idle connection -// is still functional. -// See http://http2.github.io/http2-spec/#rfc.section.6.7 -type PingFrame struct { - FrameHeader - Data [8]byte -} - -func (f *PingFrame) IsAck() bool { return f.Flags.Has(FlagPingAck) } - -func parsePingFrame(fh FrameHeader, payload []byte) (Frame, error) { - if len(payload) != 8 { - return nil, ConnectionError(ErrCodeFrameSize) - } - if fh.StreamID != 0 { - return nil, ConnectionError(ErrCodeProtocol) - } - f := &PingFrame{FrameHeader: fh} - copy(f.Data[:], payload) - return f, nil -} - -func (f *Framer) WritePing(ack bool, data [8]byte) error { - var flags Flags - if ack { - flags = FlagPingAck - } - f.startWrite(FramePing, flags, 0) - f.writeBytes(data[:]) - return f.endWrite() -} - -// A GoAwayFrame informs the remote peer to stop creating streams on this connection. -// See http://http2.github.io/http2-spec/#rfc.section.6.8 -type GoAwayFrame struct { - FrameHeader - LastStreamID uint32 - ErrCode ErrCode - debugData []byte -} - -// DebugData returns any debug data in the GOAWAY frame. Its contents -// are not defined. -// The caller must not retain the returned memory past the next -// call to ReadFrame. -func (f *GoAwayFrame) DebugData() []byte { - f.checkValid() - return f.debugData -} - -func parseGoAwayFrame(fh FrameHeader, p []byte) (Frame, error) { - if fh.StreamID != 0 { - return nil, ConnectionError(ErrCodeProtocol) - } - if len(p) < 8 { - return nil, ConnectionError(ErrCodeFrameSize) - } - return &GoAwayFrame{ - FrameHeader: fh, - LastStreamID: binary.BigEndian.Uint32(p[:4]) & (1<<31 - 1), - ErrCode: ErrCode(binary.BigEndian.Uint32(p[4:8])), - debugData: p[8:], - }, nil -} - -func (f *Framer) WriteGoAway(maxStreamID uint32, code ErrCode, debugData []byte) error { - f.startWrite(FrameGoAway, 0, 0) - f.writeUint32(maxStreamID & (1<<31 - 1)) - f.writeUint32(uint32(code)) - f.writeBytes(debugData) - return f.endWrite() -} - -// An UnknownFrame is the frame type returned when the frame type is unknown -// or no specific frame type parser exists. -type UnknownFrame struct { - FrameHeader - p []byte -} - -// Payload returns the frame's payload (after the header). It is not -// valid to call this method after a subsequent call to -// Framer.ReadFrame, nor is it valid to retain the returned slice. -// The memory is owned by the Framer and is invalidated when the next -// frame is read. -func (f *UnknownFrame) Payload() []byte { - f.checkValid() - return f.p -} - -func parseUnknownFrame(fh FrameHeader, p []byte) (Frame, error) { - return &UnknownFrame{fh, p}, nil -} - -// A WindowUpdateFrame is used to implement flow control. -// See http://http2.github.io/http2-spec/#rfc.section.6.9 -type WindowUpdateFrame struct { - FrameHeader - Increment uint32 // never read with high bit set -} - -func parseWindowUpdateFrame(fh FrameHeader, p []byte) (Frame, error) { - if len(p) != 4 { - return nil, ConnectionError(ErrCodeFrameSize) - } - inc := binary.BigEndian.Uint32(p[:4]) & 0x7fffffff // mask off high reserved bit - if inc == 0 { - // A receiver MUST treat the receipt of a - // WINDOW_UPDATE frame with an flow control window - // increment of 0 as a stream error (Section 5.4.2) of - // type PROTOCOL_ERROR; errors on the connection flow - // control window MUST be treated as a connection - // error (Section 5.4.1). - if fh.StreamID == 0 { - return nil, ConnectionError(ErrCodeProtocol) - } - return nil, StreamError{fh.StreamID, ErrCodeProtocol} - } - return &WindowUpdateFrame{ - FrameHeader: fh, - Increment: inc, - }, nil -} - -// WriteWindowUpdate writes a WINDOW_UPDATE frame. -// The increment value must be between 1 and 2,147,483,647, inclusive. -// If the Stream ID is zero, the window update applies to the -// connection as a whole. -func (f *Framer) WriteWindowUpdate(streamID, incr uint32) error { - // "The legal range for the increment to the flow control window is 1 to 2^31-1 (2,147,483,647) octets." - if (incr < 1 || incr > 2147483647) && !f.AllowIllegalWrites { - return errors.New("illegal window increment value") - } - f.startWrite(FrameWindowUpdate, 0, streamID) - f.writeUint32(incr) - return f.endWrite() -} - -// A HeadersFrame is used to open a stream and additionally carries a -// header block fragment. -type HeadersFrame struct { - FrameHeader - - // Priority is set if FlagHeadersPriority is set in the FrameHeader. - Priority PriorityParam - - headerFragBuf []byte // not owned -} - -func (f *HeadersFrame) HeaderBlockFragment() []byte { - f.checkValid() - return f.headerFragBuf -} - -func (f *HeadersFrame) HeadersEnded() bool { - return f.FrameHeader.Flags.Has(FlagHeadersEndHeaders) -} - -func (f *HeadersFrame) StreamEnded() bool { - return f.FrameHeader.Flags.Has(FlagHeadersEndStream) -} - -func (f *HeadersFrame) HasPriority() bool { - return f.FrameHeader.Flags.Has(FlagHeadersPriority) -} - -func parseHeadersFrame(fh FrameHeader, p []byte) (_ Frame, err error) { - hf := &HeadersFrame{ - FrameHeader: fh, - } - if fh.StreamID == 0 { - // HEADERS frames MUST be associated with a stream. If a HEADERS frame - // is received whose stream identifier field is 0x0, the recipient MUST - // respond with a connection error (Section 5.4.1) of type - // PROTOCOL_ERROR. - return nil, connError{ErrCodeProtocol, "HEADERS frame with stream ID 0"} - } - var padLength uint8 - if fh.Flags.Has(FlagHeadersPadded) { - if p, padLength, err = readByte(p); err != nil { - return - } - } - if fh.Flags.Has(FlagHeadersPriority) { - var v uint32 - p, v, err = readUint32(p) - if err != nil { - return nil, err - } - hf.Priority.StreamDep = v & 0x7fffffff - hf.Priority.Exclusive = (v != hf.Priority.StreamDep) // high bit was set - p, hf.Priority.Weight, err = readByte(p) - if err != nil { - return nil, err - } - } - if len(p)-int(padLength) <= 0 { - return nil, StreamError{fh.StreamID, ErrCodeProtocol} - } - hf.headerFragBuf = p[:len(p)-int(padLength)] - return hf, nil -} - -// HeadersFrameParam are the parameters for writing a HEADERS frame. -type HeadersFrameParam struct { - // StreamID is the required Stream ID to initiate. - StreamID uint32 - // BlockFragment is part (or all) of a Header Block. - BlockFragment []byte - - // EndStream indicates that the header block is the last that - // the endpoint will send for the identified stream. Setting - // this flag causes the stream to enter one of "half closed" - // states. - EndStream bool - - // EndHeaders indicates that this frame contains an entire - // header block and is not followed by any - // CONTINUATION frames. - EndHeaders bool - - // PadLength is the optional number of bytes of zeros to add - // to this frame. - PadLength uint8 - - // Priority, if non-zero, includes stream priority information - // in the HEADER frame. - Priority PriorityParam -} - -// WriteHeaders writes a single HEADERS frame. -// -// This is a low-level header writing method. Encoding headers and -// splitting them into any necessary CONTINUATION frames is handled -// elsewhere. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteHeaders(p HeadersFrameParam) error { - if !validStreamID(p.StreamID) && !f.AllowIllegalWrites { - return errStreamID - } - var flags Flags - if p.PadLength != 0 { - flags |= FlagHeadersPadded - } - if p.EndStream { - flags |= FlagHeadersEndStream - } - if p.EndHeaders { - flags |= FlagHeadersEndHeaders - } - if !p.Priority.IsZero() { - flags |= FlagHeadersPriority - } - f.startWrite(FrameHeaders, flags, p.StreamID) - if p.PadLength != 0 { - f.writeByte(p.PadLength) - } - if !p.Priority.IsZero() { - v := p.Priority.StreamDep - if !validStreamIDOrZero(v) && !f.AllowIllegalWrites { - return errDepStreamID - } - if p.Priority.Exclusive { - v |= 1 << 31 - } - f.writeUint32(v) - f.writeByte(p.Priority.Weight) - } - f.wbuf = append(f.wbuf, p.BlockFragment...) - f.wbuf = append(f.wbuf, padZeros[:p.PadLength]...) - return f.endWrite() -} - -// A PriorityFrame specifies the sender-advised priority of a stream. -// See http://http2.github.io/http2-spec/#rfc.section.6.3 -type PriorityFrame struct { - FrameHeader - PriorityParam -} - -// PriorityParam are the stream prioritzation parameters. -type PriorityParam struct { - // StreamDep is a 31-bit stream identifier for the - // stream that this stream depends on. Zero means no - // dependency. - StreamDep uint32 - - // Exclusive is whether the dependency is exclusive. - Exclusive bool - - // Weight is the stream's zero-indexed weight. It should be - // set together with StreamDep, or neither should be set. Per - // the spec, "Add one to the value to obtain a weight between - // 1 and 256." - Weight uint8 -} - -func (p PriorityParam) IsZero() bool { - return p == PriorityParam{} -} - -func parsePriorityFrame(fh FrameHeader, payload []byte) (Frame, error) { - if fh.StreamID == 0 { - return nil, connError{ErrCodeProtocol, "PRIORITY frame with stream ID 0"} - } - if len(payload) != 5 { - return nil, connError{ErrCodeFrameSize, fmt.Sprintf("PRIORITY frame payload size was %d; want 5", len(payload))} - } - v := binary.BigEndian.Uint32(payload[:4]) - streamID := v & 0x7fffffff // mask off high bit - return &PriorityFrame{ - FrameHeader: fh, - PriorityParam: PriorityParam{ - Weight: payload[4], - StreamDep: streamID, - Exclusive: streamID != v, // was high bit set? - }, - }, nil -} - -// WritePriority writes a PRIORITY frame. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WritePriority(streamID uint32, p PriorityParam) error { - if !validStreamID(streamID) && !f.AllowIllegalWrites { - return errStreamID - } - if !validStreamIDOrZero(p.StreamDep) { - return errDepStreamID - } - f.startWrite(FramePriority, 0, streamID) - v := p.StreamDep - if p.Exclusive { - v |= 1 << 31 - } - f.writeUint32(v) - f.writeByte(p.Weight) - return f.endWrite() -} - -// A RSTStreamFrame allows for abnormal termination of a stream. -// See http://http2.github.io/http2-spec/#rfc.section.6.4 -type RSTStreamFrame struct { - FrameHeader - ErrCode ErrCode -} - -func parseRSTStreamFrame(fh FrameHeader, p []byte) (Frame, error) { - if len(p) != 4 { - return nil, ConnectionError(ErrCodeFrameSize) - } - if fh.StreamID == 0 { - return nil, ConnectionError(ErrCodeProtocol) - } - return &RSTStreamFrame{fh, ErrCode(binary.BigEndian.Uint32(p[:4]))}, nil -} - -// WriteRSTStream writes a RST_STREAM frame. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteRSTStream(streamID uint32, code ErrCode) error { - if !validStreamID(streamID) && !f.AllowIllegalWrites { - return errStreamID - } - f.startWrite(FrameRSTStream, 0, streamID) - f.writeUint32(uint32(code)) - return f.endWrite() -} - -// A ContinuationFrame is used to continue a sequence of header block fragments. -// See http://http2.github.io/http2-spec/#rfc.section.6.10 -type ContinuationFrame struct { - FrameHeader - headerFragBuf []byte -} - -func parseContinuationFrame(fh FrameHeader, p []byte) (Frame, error) { - if fh.StreamID == 0 { - return nil, connError{ErrCodeProtocol, "CONTINUATION frame with stream ID 0"} - } - return &ContinuationFrame{fh, p}, nil -} - -func (f *ContinuationFrame) HeaderBlockFragment() []byte { - f.checkValid() - return f.headerFragBuf -} - -func (f *ContinuationFrame) HeadersEnded() bool { - return f.FrameHeader.Flags.Has(FlagContinuationEndHeaders) -} - -// WriteContinuation writes a CONTINUATION frame. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WriteContinuation(streamID uint32, endHeaders bool, headerBlockFragment []byte) error { - if !validStreamID(streamID) && !f.AllowIllegalWrites { - return errStreamID - } - var flags Flags - if endHeaders { - flags |= FlagContinuationEndHeaders - } - f.startWrite(FrameContinuation, flags, streamID) - f.wbuf = append(f.wbuf, headerBlockFragment...) - return f.endWrite() -} - -// A PushPromiseFrame is used to initiate a server stream. -// See http://http2.github.io/http2-spec/#rfc.section.6.6 -type PushPromiseFrame struct { - FrameHeader - PromiseID uint32 - headerFragBuf []byte // not owned -} - -func (f *PushPromiseFrame) HeaderBlockFragment() []byte { - f.checkValid() - return f.headerFragBuf -} - -func (f *PushPromiseFrame) HeadersEnded() bool { - return f.FrameHeader.Flags.Has(FlagPushPromiseEndHeaders) -} - -func parsePushPromise(fh FrameHeader, p []byte) (_ Frame, err error) { - pp := &PushPromiseFrame{ - FrameHeader: fh, - } - if pp.StreamID == 0 { - // PUSH_PROMISE frames MUST be associated with an existing, - // peer-initiated stream. The stream identifier of a - // PUSH_PROMISE frame indicates the stream it is associated - // with. If the stream identifier field specifies the value - // 0x0, a recipient MUST respond with a connection error - // (Section 5.4.1) of type PROTOCOL_ERROR. - return nil, ConnectionError(ErrCodeProtocol) - } - // The PUSH_PROMISE frame includes optional padding. - // Padding fields and flags are identical to those defined for DATA frames - var padLength uint8 - if fh.Flags.Has(FlagPushPromisePadded) { - if p, padLength, err = readByte(p); err != nil { - return - } - } - - p, pp.PromiseID, err = readUint32(p) - if err != nil { - return - } - pp.PromiseID = pp.PromiseID & (1<<31 - 1) - - if int(padLength) > len(p) { - // like the DATA frame, error out if padding is longer than the body. - return nil, ConnectionError(ErrCodeProtocol) - } - pp.headerFragBuf = p[:len(p)-int(padLength)] - return pp, nil -} - -// PushPromiseParam are the parameters for writing a PUSH_PROMISE frame. -type PushPromiseParam struct { - // StreamID is the required Stream ID to initiate. - StreamID uint32 - - // PromiseID is the required Stream ID which this - // Push Promises - PromiseID uint32 - - // BlockFragment is part (or all) of a Header Block. - BlockFragment []byte - - // EndHeaders indicates that this frame contains an entire - // header block and is not followed by any - // CONTINUATION frames. - EndHeaders bool - - // PadLength is the optional number of bytes of zeros to add - // to this frame. - PadLength uint8 -} - -// WritePushPromise writes a single PushPromise Frame. -// -// As with Header Frames, This is the low level call for writing -// individual frames. Continuation frames are handled elsewhere. -// -// It will perform exactly one Write to the underlying Writer. -// It is the caller's responsibility to not call other Write methods concurrently. -func (f *Framer) WritePushPromise(p PushPromiseParam) error { - if !validStreamID(p.StreamID) && !f.AllowIllegalWrites { - return errStreamID - } - var flags Flags - if p.PadLength != 0 { - flags |= FlagPushPromisePadded - } - if p.EndHeaders { - flags |= FlagPushPromiseEndHeaders - } - f.startWrite(FramePushPromise, flags, p.StreamID) - if p.PadLength != 0 { - f.writeByte(p.PadLength) - } - if !validStreamID(p.PromiseID) && !f.AllowIllegalWrites { - return errStreamID - } - f.writeUint32(p.PromiseID) - f.wbuf = append(f.wbuf, p.BlockFragment...) - f.wbuf = append(f.wbuf, padZeros[:p.PadLength]...) - return f.endWrite() -} - -// WriteRawFrame writes a raw frame. This can be used to write -// extension frames unknown to this package. -func (f *Framer) WriteRawFrame(t FrameType, flags Flags, streamID uint32, payload []byte) error { - f.startWrite(t, flags, streamID) - f.writeBytes(payload) - return f.endWrite() -} - -func readByte(p []byte) (remain []byte, b byte, err error) { - if len(p) == 0 { - return nil, 0, io.ErrUnexpectedEOF - } - return p[1:], p[0], nil -} - -func readUint32(p []byte) (remain []byte, v uint32, err error) { - if len(p) < 4 { - return nil, 0, io.ErrUnexpectedEOF - } - return p[4:], binary.BigEndian.Uint32(p[:4]), nil -} - -type streamEnder interface { - StreamEnded() bool -} - -type headersEnder interface { - HeadersEnded() bool -} - -type headersOrContinuation interface { - headersEnder - HeaderBlockFragment() []byte -} - -// A MetaHeadersFrame is the representation of one HEADERS frame and -// zero or more contiguous CONTINUATION frames and the decoding of -// their HPACK-encoded contents. -// -// This type of frame does not appear on the wire and is only returned -// by the Framer when Framer.ReadMetaHeaders is set. -type MetaHeadersFrame struct { - *HeadersFrame - - // Fields are the fields contained in the HEADERS and - // CONTINUATION frames. The underlying slice is owned by the - // Framer and must not be retained after the next call to - // ReadFrame. - // - // Fields are guaranteed to be in the correct http2 order and - // not have unknown pseudo header fields or invalid header - // field names or values. Required pseudo header fields may be - // missing, however. Use the MetaHeadersFrame.Pseudo accessor - // method access pseudo headers. - Fields []hpack.HeaderField - - // Truncated is whether the max header list size limit was hit - // and Fields is incomplete. The hpack decoder state is still - // valid, however. - Truncated bool -} - -// PseudoValue returns the given pseudo header field's value. -// The provided pseudo field should not contain the leading colon. -func (mh *MetaHeadersFrame) PseudoValue(pseudo string) string { - for _, hf := range mh.Fields { - if !hf.IsPseudo() { - return "" - } - if hf.Name[1:] == pseudo { - return hf.Value - } - } - return "" -} - -// RegularFields returns the regular (non-pseudo) header fields of mh. -// The caller does not own the returned slice. -func (mh *MetaHeadersFrame) RegularFields() []hpack.HeaderField { - for i, hf := range mh.Fields { - if !hf.IsPseudo() { - return mh.Fields[i:] - } - } - return nil -} - -// PseudoFields returns the pseudo header fields of mh. -// The caller does not own the returned slice. -func (mh *MetaHeadersFrame) PseudoFields() []hpack.HeaderField { - for i, hf := range mh.Fields { - if !hf.IsPseudo() { - return mh.Fields[:i] - } - } - return mh.Fields -} - -func (mh *MetaHeadersFrame) checkPseudos() error { - var isRequest, isResponse bool - pf := mh.PseudoFields() - for i, hf := range pf { - switch hf.Name { - case ":method", ":path", ":scheme", ":authority": - isRequest = true - case ":status": - isResponse = true - default: - return pseudoHeaderError(hf.Name) - } - // Check for duplicates. - // This would be a bad algorithm, but N is 4. - // And this doesn't allocate. - for _, hf2 := range pf[:i] { - if hf.Name == hf2.Name { - return duplicatePseudoHeaderError(hf.Name) - } - } - } - if isRequest && isResponse { - return errMixPseudoHeaderTypes - } - return nil -} - -func (fr *Framer) maxHeaderStringLen() int { - v := fr.maxHeaderListSize() - if uint32(int(v)) == v { - return int(v) - } - // They had a crazy big number for MaxHeaderBytes anyway, - // so give them unlimited header lengths: - return 0 -} - -// readMetaFrame returns 0 or more CONTINUATION frames from fr and -// merge them into into the provided hf and returns a MetaHeadersFrame -// with the decoded hpack values. -func (fr *Framer) readMetaFrame(hf *HeadersFrame) (*MetaHeadersFrame, error) { - if fr.AllowIllegalReads { - return nil, errors.New("illegal use of AllowIllegalReads with ReadMetaHeaders") - } - mh := &MetaHeadersFrame{ - HeadersFrame: hf, - } - var remainSize = fr.maxHeaderListSize() - var sawRegular bool - - var invalid error // pseudo header field errors - hdec := fr.ReadMetaHeaders - hdec.SetEmitEnabled(true) - hdec.SetMaxStringLength(fr.maxHeaderStringLen()) - hdec.SetEmitFunc(func(hf hpack.HeaderField) { - if !httplex.ValidHeaderFieldValue(hf.Value) { - invalid = headerFieldValueError(hf.Value) - } - isPseudo := strings.HasPrefix(hf.Name, ":") - if isPseudo { - if sawRegular { - invalid = errPseudoAfterRegular - } - } else { - sawRegular = true - if !validWireHeaderFieldName(hf.Name) { - invalid = headerFieldNameError(hf.Name) - } - } - - if invalid != nil { - hdec.SetEmitEnabled(false) - return - } - - size := hf.Size() - if size > remainSize { - hdec.SetEmitEnabled(false) - mh.Truncated = true - return - } - remainSize -= size - - mh.Fields = append(mh.Fields, hf) - }) - // Lose reference to MetaHeadersFrame: - defer hdec.SetEmitFunc(func(hf hpack.HeaderField) {}) - - var hc headersOrContinuation = hf - for { - frag := hc.HeaderBlockFragment() - if _, err := hdec.Write(frag); err != nil { - return nil, ConnectionError(ErrCodeCompression) - } - - if hc.HeadersEnded() { - break - } - if f, err := fr.ReadFrame(); err != nil { - return nil, err - } else { - hc = f.(*ContinuationFrame) // guaranteed by checkFrameOrder - } - } - - mh.HeadersFrame.headerFragBuf = nil - mh.HeadersFrame.invalidate() - - if err := hdec.Close(); err != nil { - return nil, ConnectionError(ErrCodeCompression) - } - if invalid != nil { - fr.errDetail = invalid - return nil, StreamError{mh.StreamID, ErrCodeProtocol} - } - if err := mh.checkPseudos(); err != nil { - fr.errDetail = err - return nil, StreamError{mh.StreamID, ErrCodeProtocol} - } - return mh, nil -} - -func summarizeFrame(f Frame) string { - var buf bytes.Buffer - f.Header().writeDebug(&buf) - switch f := f.(type) { - case *SettingsFrame: - n := 0 - f.ForeachSetting(func(s Setting) error { - n++ - if n == 1 { - buf.WriteString(", settings:") - } - fmt.Fprintf(&buf, " %v=%v,", s.ID, s.Val) - return nil - }) - if n > 0 { - buf.Truncate(buf.Len() - 1) // remove trailing comma - } - case *DataFrame: - data := f.Data() - const max = 256 - if len(data) > max { - data = data[:max] - } - fmt.Fprintf(&buf, " data=%q", data) - if len(f.Data()) > max { - fmt.Fprintf(&buf, " (%d bytes omitted)", len(f.Data())-max) - } - case *WindowUpdateFrame: - if f.StreamID == 0 { - buf.WriteString(" (conn)") - } - fmt.Fprintf(&buf, " incr=%v", f.Increment) - case *PingFrame: - fmt.Fprintf(&buf, " ping=%q", f.Data[:]) - case *GoAwayFrame: - fmt.Fprintf(&buf, " LastStreamID=%v ErrCode=%v Debug=%q", - f.LastStreamID, f.ErrCode, f.debugData) - case *RSTStreamFrame: - fmt.Fprintf(&buf, " ErrCode=%v", f.ErrCode) - } - return buf.String() -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go16.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go16.go deleted file mode 100644 index 2b72855..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go16.go +++ /dev/null @@ -1,43 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.6 - -package http2 - -import ( - "crypto/tls" - "net/http" - "time" -) - -func transportExpectContinueTimeout(t1 *http.Transport) time.Duration { - return t1.ExpectContinueTimeout -} - -// isBadCipher reports whether the cipher is blacklisted by the HTTP/2 spec. -func isBadCipher(cipher uint16) bool { - switch cipher { - case tls.TLS_RSA_WITH_RC4_128_SHA, - tls.TLS_RSA_WITH_3DES_EDE_CBC_SHA, - tls.TLS_RSA_WITH_AES_128_CBC_SHA, - tls.TLS_RSA_WITH_AES_256_CBC_SHA, - tls.TLS_RSA_WITH_AES_128_GCM_SHA256, - tls.TLS_RSA_WITH_AES_256_GCM_SHA384, - tls.TLS_ECDHE_ECDSA_WITH_RC4_128_SHA, - tls.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA, - tls.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_RC4_128_SHA, - tls.TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA: - // Reject cipher suites from Appendix A. - // "This list includes those cipher suites that do not - // offer an ephemeral key exchange and those that are - // based on the TLS null, stream or block cipher type" - return true - default: - return false - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go17.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go17.go deleted file mode 100644 index 730319d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/go17.go +++ /dev/null @@ -1,94 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.7 - -package http2 - -import ( - "context" - "net" - "net/http" - "net/http/httptrace" - "time" -) - -type contextContext interface { - context.Context -} - -func serverConnBaseContext(c net.Conn, opts *ServeConnOpts) (ctx contextContext, cancel func()) { - ctx, cancel = context.WithCancel(context.Background()) - ctx = context.WithValue(ctx, http.LocalAddrContextKey, c.LocalAddr()) - if hs := opts.baseConfig(); hs != nil { - ctx = context.WithValue(ctx, http.ServerContextKey, hs) - } - return -} - -func contextWithCancel(ctx contextContext) (_ contextContext, cancel func()) { - return context.WithCancel(ctx) -} - -func requestWithContext(req *http.Request, ctx contextContext) *http.Request { - return req.WithContext(ctx) -} - -type clientTrace httptrace.ClientTrace - -func reqContext(r *http.Request) context.Context { return r.Context() } - -func setResponseUncompressed(res *http.Response) { res.Uncompressed = true } - -func traceGotConn(req *http.Request, cc *ClientConn) { - trace := httptrace.ContextClientTrace(req.Context()) - if trace == nil || trace.GotConn == nil { - return - } - ci := httptrace.GotConnInfo{Conn: cc.tconn} - cc.mu.Lock() - ci.Reused = cc.nextStreamID > 1 - ci.WasIdle = len(cc.streams) == 0 && ci.Reused - if ci.WasIdle && !cc.lastActive.IsZero() { - ci.IdleTime = time.Now().Sub(cc.lastActive) - } - cc.mu.Unlock() - - trace.GotConn(ci) -} - -func traceWroteHeaders(trace *clientTrace) { - if trace != nil && trace.WroteHeaders != nil { - trace.WroteHeaders() - } -} - -func traceGot100Continue(trace *clientTrace) { - if trace != nil && trace.Got100Continue != nil { - trace.Got100Continue() - } -} - -func traceWait100Continue(trace *clientTrace) { - if trace != nil && trace.Wait100Continue != nil { - trace.Wait100Continue() - } -} - -func traceWroteRequest(trace *clientTrace, err error) { - if trace != nil && trace.WroteRequest != nil { - trace.WroteRequest(httptrace.WroteRequestInfo{Err: err}) - } -} - -func traceFirstResponseByte(trace *clientTrace) { - if trace != nil && trace.GotFirstResponseByte != nil { - trace.GotFirstResponseByte() - } -} - -func requestTrace(req *http.Request) *clientTrace { - trace := httptrace.ContextClientTrace(req.Context()) - return (*clientTrace)(trace) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/gotrack.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/gotrack.go deleted file mode 100644 index 9933c9f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/gotrack.go +++ /dev/null @@ -1,170 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Defensive debug-only utility to track that functions run on the -// goroutine that they're supposed to. - -package http2 - -import ( - "bytes" - "errors" - "fmt" - "os" - "runtime" - "strconv" - "sync" -) - -var DebugGoroutines = os.Getenv("DEBUG_HTTP2_GOROUTINES") == "1" - -type goroutineLock uint64 - -func newGoroutineLock() goroutineLock { - if !DebugGoroutines { - return 0 - } - return goroutineLock(curGoroutineID()) -} - -func (g goroutineLock) check() { - if !DebugGoroutines { - return - } - if curGoroutineID() != uint64(g) { - panic("running on the wrong goroutine") - } -} - -func (g goroutineLock) checkNotOn() { - if !DebugGoroutines { - return - } - if curGoroutineID() == uint64(g) { - panic("running on the wrong goroutine") - } -} - -var goroutineSpace = []byte("goroutine ") - -func curGoroutineID() uint64 { - bp := littleBuf.Get().(*[]byte) - defer littleBuf.Put(bp) - b := *bp - b = b[:runtime.Stack(b, false)] - // Parse the 4707 out of "goroutine 4707 [" - b = bytes.TrimPrefix(b, goroutineSpace) - i := bytes.IndexByte(b, ' ') - if i < 0 { - panic(fmt.Sprintf("No space found in %q", b)) - } - b = b[:i] - n, err := parseUintBytes(b, 10, 64) - if err != nil { - panic(fmt.Sprintf("Failed to parse goroutine ID out of %q: %v", b, err)) - } - return n -} - -var littleBuf = sync.Pool{ - New: func() interface{} { - buf := make([]byte, 64) - return &buf - }, -} - -// parseUintBytes is like strconv.ParseUint, but using a []byte. -func parseUintBytes(s []byte, base int, bitSize int) (n uint64, err error) { - var cutoff, maxVal uint64 - - if bitSize == 0 { - bitSize = int(strconv.IntSize) - } - - s0 := s - switch { - case len(s) < 1: - err = strconv.ErrSyntax - goto Error - - case 2 <= base && base <= 36: - // valid base; nothing to do - - case base == 0: - // Look for octal, hex prefix. - switch { - case s[0] == '0' && len(s) > 1 && (s[1] == 'x' || s[1] == 'X'): - base = 16 - s = s[2:] - if len(s) < 1 { - err = strconv.ErrSyntax - goto Error - } - case s[0] == '0': - base = 8 - default: - base = 10 - } - - default: - err = errors.New("invalid base " + strconv.Itoa(base)) - goto Error - } - - n = 0 - cutoff = cutoff64(base) - maxVal = 1<= base { - n = 0 - err = strconv.ErrSyntax - goto Error - } - - if n >= cutoff { - // n*base overflows - n = 1<<64 - 1 - err = strconv.ErrRange - goto Error - } - n *= uint64(base) - - n1 := n + uint64(v) - if n1 < n || n1 > maxVal { - // n+v overflows - n = 1<<64 - 1 - err = strconv.ErrRange - goto Error - } - n = n1 - } - - return n, nil - -Error: - return n, &strconv.NumError{Func: "ParseUint", Num: string(s0), Err: err} -} - -// Return the first number n such that n*base >= 1<<64. -func cutoff64(base int) uint64 { - if base < 2 { - return 0 - } - return (1<<64-1)/uint64(base) + 1 -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/headermap.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/headermap.go deleted file mode 100644 index c2805f6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/headermap.go +++ /dev/null @@ -1,78 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "net/http" - "strings" -) - -var ( - commonLowerHeader = map[string]string{} // Go-Canonical-Case -> lower-case - commonCanonHeader = map[string]string{} // lower-case -> Go-Canonical-Case -) - -func init() { - for _, v := range []string{ - "accept", - "accept-charset", - "accept-encoding", - "accept-language", - "accept-ranges", - "age", - "access-control-allow-origin", - "allow", - "authorization", - "cache-control", - "content-disposition", - "content-encoding", - "content-language", - "content-length", - "content-location", - "content-range", - "content-type", - "cookie", - "date", - "etag", - "expect", - "expires", - "from", - "host", - "if-match", - "if-modified-since", - "if-none-match", - "if-unmodified-since", - "last-modified", - "link", - "location", - "max-forwards", - "proxy-authenticate", - "proxy-authorization", - "range", - "referer", - "refresh", - "retry-after", - "server", - "set-cookie", - "strict-transport-security", - "trailer", - "transfer-encoding", - "user-agent", - "vary", - "via", - "www-authenticate", - } { - chk := http.CanonicalHeaderKey(v) - commonLowerHeader[chk] = v - commonCanonHeader[v] = chk - } -} - -func lowerHeader(v string) string { - if s, ok := commonLowerHeader[v]; ok { - return s - } - return strings.ToLower(v) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/encode.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/encode.go deleted file mode 100644 index f9bb033..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/encode.go +++ /dev/null @@ -1,251 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package hpack - -import ( - "io" -) - -const ( - uint32Max = ^uint32(0) - initialHeaderTableSize = 4096 -) - -type Encoder struct { - dynTab dynamicTable - // minSize is the minimum table size set by - // SetMaxDynamicTableSize after the previous Header Table Size - // Update. - minSize uint32 - // maxSizeLimit is the maximum table size this encoder - // supports. This will protect the encoder from too large - // size. - maxSizeLimit uint32 - // tableSizeUpdate indicates whether "Header Table Size - // Update" is required. - tableSizeUpdate bool - w io.Writer - buf []byte -} - -// NewEncoder returns a new Encoder which performs HPACK encoding. An -// encoded data is written to w. -func NewEncoder(w io.Writer) *Encoder { - e := &Encoder{ - minSize: uint32Max, - maxSizeLimit: initialHeaderTableSize, - tableSizeUpdate: false, - w: w, - } - e.dynTab.setMaxSize(initialHeaderTableSize) - return e -} - -// WriteField encodes f into a single Write to e's underlying Writer. -// This function may also produce bytes for "Header Table Size Update" -// if necessary. If produced, it is done before encoding f. -func (e *Encoder) WriteField(f HeaderField) error { - e.buf = e.buf[:0] - - if e.tableSizeUpdate { - e.tableSizeUpdate = false - if e.minSize < e.dynTab.maxSize { - e.buf = appendTableSize(e.buf, e.minSize) - } - e.minSize = uint32Max - e.buf = appendTableSize(e.buf, e.dynTab.maxSize) - } - - idx, nameValueMatch := e.searchTable(f) - if nameValueMatch { - e.buf = appendIndexed(e.buf, idx) - } else { - indexing := e.shouldIndex(f) - if indexing { - e.dynTab.add(f) - } - - if idx == 0 { - e.buf = appendNewName(e.buf, f, indexing) - } else { - e.buf = appendIndexedName(e.buf, f, idx, indexing) - } - } - n, err := e.w.Write(e.buf) - if err == nil && n != len(e.buf) { - err = io.ErrShortWrite - } - return err -} - -// searchTable searches f in both stable and dynamic header tables. -// The static header table is searched first. Only when there is no -// exact match for both name and value, the dynamic header table is -// then searched. If there is no match, i is 0. If both name and value -// match, i is the matched index and nameValueMatch becomes true. If -// only name matches, i points to that index and nameValueMatch -// becomes false. -func (e *Encoder) searchTable(f HeaderField) (i uint64, nameValueMatch bool) { - for idx, hf := range staticTable { - if !constantTimeStringCompare(hf.Name, f.Name) { - continue - } - if i == 0 { - i = uint64(idx + 1) - } - if f.Sensitive { - continue - } - if !constantTimeStringCompare(hf.Value, f.Value) { - continue - } - i = uint64(idx + 1) - nameValueMatch = true - return - } - - j, nameValueMatch := e.dynTab.search(f) - if nameValueMatch || (i == 0 && j != 0) { - i = j + uint64(len(staticTable)) - } - return -} - -// SetMaxDynamicTableSize changes the dynamic header table size to v. -// The actual size is bounded by the value passed to -// SetMaxDynamicTableSizeLimit. -func (e *Encoder) SetMaxDynamicTableSize(v uint32) { - if v > e.maxSizeLimit { - v = e.maxSizeLimit - } - if v < e.minSize { - e.minSize = v - } - e.tableSizeUpdate = true - e.dynTab.setMaxSize(v) -} - -// SetMaxDynamicTableSizeLimit changes the maximum value that can be -// specified in SetMaxDynamicTableSize to v. By default, it is set to -// 4096, which is the same size of the default dynamic header table -// size described in HPACK specification. If the current maximum -// dynamic header table size is strictly greater than v, "Header Table -// Size Update" will be done in the next WriteField call and the -// maximum dynamic header table size is truncated to v. -func (e *Encoder) SetMaxDynamicTableSizeLimit(v uint32) { - e.maxSizeLimit = v - if e.dynTab.maxSize > v { - e.tableSizeUpdate = true - e.dynTab.setMaxSize(v) - } -} - -// shouldIndex reports whether f should be indexed. -func (e *Encoder) shouldIndex(f HeaderField) bool { - return !f.Sensitive && f.Size() <= e.dynTab.maxSize -} - -// appendIndexed appends index i, as encoded in "Indexed Header Field" -// representation, to dst and returns the extended buffer. -func appendIndexed(dst []byte, i uint64) []byte { - first := len(dst) - dst = appendVarInt(dst, 7, i) - dst[first] |= 0x80 - return dst -} - -// appendNewName appends f, as encoded in one of "Literal Header field -// - New Name" representation variants, to dst and returns the -// extended buffer. -// -// If f.Sensitive is true, "Never Indexed" representation is used. If -// f.Sensitive is false and indexing is true, "Inremental Indexing" -// representation is used. -func appendNewName(dst []byte, f HeaderField, indexing bool) []byte { - dst = append(dst, encodeTypeByte(indexing, f.Sensitive)) - dst = appendHpackString(dst, f.Name) - return appendHpackString(dst, f.Value) -} - -// appendIndexedName appends f and index i referring indexed name -// entry, as encoded in one of "Literal Header field - Indexed Name" -// representation variants, to dst and returns the extended buffer. -// -// If f.Sensitive is true, "Never Indexed" representation is used. If -// f.Sensitive is false and indexing is true, "Incremental Indexing" -// representation is used. -func appendIndexedName(dst []byte, f HeaderField, i uint64, indexing bool) []byte { - first := len(dst) - var n byte - if indexing { - n = 6 - } else { - n = 4 - } - dst = appendVarInt(dst, n, i) - dst[first] |= encodeTypeByte(indexing, f.Sensitive) - return appendHpackString(dst, f.Value) -} - -// appendTableSize appends v, as encoded in "Header Table Size Update" -// representation, to dst and returns the extended buffer. -func appendTableSize(dst []byte, v uint32) []byte { - first := len(dst) - dst = appendVarInt(dst, 5, uint64(v)) - dst[first] |= 0x20 - return dst -} - -// appendVarInt appends i, as encoded in variable integer form using n -// bit prefix, to dst and returns the extended buffer. -// -// See -// http://http2.github.io/http2-spec/compression.html#integer.representation -func appendVarInt(dst []byte, n byte, i uint64) []byte { - k := uint64((1 << n) - 1) - if i < k { - return append(dst, byte(i)) - } - dst = append(dst, byte(k)) - i -= k - for ; i >= 128; i >>= 7 { - dst = append(dst, byte(0x80|(i&0x7f))) - } - return append(dst, byte(i)) -} - -// appendHpackString appends s, as encoded in "String Literal" -// representation, to dst and returns the the extended buffer. -// -// s will be encoded in Huffman codes only when it produces strictly -// shorter byte string. -func appendHpackString(dst []byte, s string) []byte { - huffmanLength := HuffmanEncodeLength(s) - if huffmanLength < uint64(len(s)) { - first := len(dst) - dst = appendVarInt(dst, 7, huffmanLength) - dst = AppendHuffmanString(dst, s) - dst[first] |= 0x80 - } else { - dst = appendVarInt(dst, 7, uint64(len(s))) - dst = append(dst, s...) - } - return dst -} - -// encodeTypeByte returns type byte. If sensitive is true, type byte -// for "Never Indexed" representation is returned. If sensitive is -// false and indexing is true, type byte for "Incremental Indexing" -// representation is returned. Otherwise, type byte for "Without -// Indexing" is returned. -func encodeTypeByte(indexing, sensitive bool) byte { - if sensitive { - return 0x10 - } - if indexing { - return 0x40 - } - return 0 -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/hpack.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/hpack.go deleted file mode 100644 index 8aa197a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/hpack.go +++ /dev/null @@ -1,542 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package hpack implements HPACK, a compression format for -// efficiently representing HTTP header fields in the context of HTTP/2. -// -// See http://tools.ietf.org/html/draft-ietf-httpbis-header-compression-09 -package hpack - -import ( - "bytes" - "errors" - "fmt" -) - -// A DecodingError is something the spec defines as a decoding error. -type DecodingError struct { - Err error -} - -func (de DecodingError) Error() string { - return fmt.Sprintf("decoding error: %v", de.Err) -} - -// An InvalidIndexError is returned when an encoder references a table -// entry before the static table or after the end of the dynamic table. -type InvalidIndexError int - -func (e InvalidIndexError) Error() string { - return fmt.Sprintf("invalid indexed representation index %d", int(e)) -} - -// A HeaderField is a name-value pair. Both the name and value are -// treated as opaque sequences of octets. -type HeaderField struct { - Name, Value string - - // Sensitive means that this header field should never be - // indexed. - Sensitive bool -} - -// IsPseudo reports whether the header field is an http2 pseudo header. -// That is, it reports whether it starts with a colon. -// It is not otherwise guaranteed to be a valid pseudo header field, -// though. -func (hf HeaderField) IsPseudo() bool { - return len(hf.Name) != 0 && hf.Name[0] == ':' -} - -func (hf HeaderField) String() string { - var suffix string - if hf.Sensitive { - suffix = " (sensitive)" - } - return fmt.Sprintf("header field %q = %q%s", hf.Name, hf.Value, suffix) -} - -// Size returns the size of an entry per RFC 7540 section 5.2. -func (hf HeaderField) Size() uint32 { - // http://http2.github.io/http2-spec/compression.html#rfc.section.4.1 - // "The size of the dynamic table is the sum of the size of - // its entries. The size of an entry is the sum of its name's - // length in octets (as defined in Section 5.2), its value's - // length in octets (see Section 5.2), plus 32. The size of - // an entry is calculated using the length of the name and - // value without any Huffman encoding applied." - - // This can overflow if somebody makes a large HeaderField - // Name and/or Value by hand, but we don't care, because that - // won't happen on the wire because the encoding doesn't allow - // it. - return uint32(len(hf.Name) + len(hf.Value) + 32) -} - -// A Decoder is the decoding context for incremental processing of -// header blocks. -type Decoder struct { - dynTab dynamicTable - emit func(f HeaderField) - - emitEnabled bool // whether calls to emit are enabled - maxStrLen int // 0 means unlimited - - // buf is the unparsed buffer. It's only written to - // saveBuf if it was truncated in the middle of a header - // block. Because it's usually not owned, we can only - // process it under Write. - buf []byte // not owned; only valid during Write - - // saveBuf is previous data passed to Write which we weren't able - // to fully parse before. Unlike buf, we own this data. - saveBuf bytes.Buffer -} - -// NewDecoder returns a new decoder with the provided maximum dynamic -// table size. The emitFunc will be called for each valid field -// parsed, in the same goroutine as calls to Write, before Write returns. -func NewDecoder(maxDynamicTableSize uint32, emitFunc func(f HeaderField)) *Decoder { - d := &Decoder{ - emit: emitFunc, - emitEnabled: true, - } - d.dynTab.allowedMaxSize = maxDynamicTableSize - d.dynTab.setMaxSize(maxDynamicTableSize) - return d -} - -// ErrStringLength is returned by Decoder.Write when the max string length -// (as configured by Decoder.SetMaxStringLength) would be violated. -var ErrStringLength = errors.New("hpack: string too long") - -// SetMaxStringLength sets the maximum size of a HeaderField name or -// value string. If a string exceeds this length (even after any -// decompression), Write will return ErrStringLength. -// A value of 0 means unlimited and is the default from NewDecoder. -func (d *Decoder) SetMaxStringLength(n int) { - d.maxStrLen = n -} - -// SetEmitFunc changes the callback used when new header fields -// are decoded. -// It must be non-nil. It does not affect EmitEnabled. -func (d *Decoder) SetEmitFunc(emitFunc func(f HeaderField)) { - d.emit = emitFunc -} - -// SetEmitEnabled controls whether the emitFunc provided to NewDecoder -// should be called. The default is true. -// -// This facility exists to let servers enforce MAX_HEADER_LIST_SIZE -// while still decoding and keeping in-sync with decoder state, but -// without doing unnecessary decompression or generating unnecessary -// garbage for header fields past the limit. -func (d *Decoder) SetEmitEnabled(v bool) { d.emitEnabled = v } - -// EmitEnabled reports whether calls to the emitFunc provided to NewDecoder -// are currently enabled. The default is true. -func (d *Decoder) EmitEnabled() bool { return d.emitEnabled } - -// TODO: add method *Decoder.Reset(maxSize, emitFunc) to let callers re-use Decoders and their -// underlying buffers for garbage reasons. - -func (d *Decoder) SetMaxDynamicTableSize(v uint32) { - d.dynTab.setMaxSize(v) -} - -// SetAllowedMaxDynamicTableSize sets the upper bound that the encoded -// stream (via dynamic table size updates) may set the maximum size -// to. -func (d *Decoder) SetAllowedMaxDynamicTableSize(v uint32) { - d.dynTab.allowedMaxSize = v -} - -type dynamicTable struct { - // ents is the FIFO described at - // http://http2.github.io/http2-spec/compression.html#rfc.section.2.3.2 - // The newest (low index) is append at the end, and items are - // evicted from the front. - ents []HeaderField - size uint32 - maxSize uint32 // current maxSize - allowedMaxSize uint32 // maxSize may go up to this, inclusive -} - -func (dt *dynamicTable) setMaxSize(v uint32) { - dt.maxSize = v - dt.evict() -} - -// TODO: change dynamicTable to be a struct with a slice and a size int field, -// per http://http2.github.io/http2-spec/compression.html#rfc.section.4.1: -// -// -// Then make add increment the size. maybe the max size should move from Decoder to -// dynamicTable and add should return an ok bool if there was enough space. -// -// Later we'll need a remove operation on dynamicTable. - -func (dt *dynamicTable) add(f HeaderField) { - dt.ents = append(dt.ents, f) - dt.size += f.Size() - dt.evict() -} - -// If we're too big, evict old stuff (front of the slice) -func (dt *dynamicTable) evict() { - base := dt.ents // keep base pointer of slice - for dt.size > dt.maxSize { - dt.size -= dt.ents[0].Size() - dt.ents = dt.ents[1:] - } - - // Shift slice contents down if we evicted things. - if len(dt.ents) != len(base) { - copy(base, dt.ents) - dt.ents = base[:len(dt.ents)] - } -} - -// constantTimeStringCompare compares string a and b in a constant -// time manner. -func constantTimeStringCompare(a, b string) bool { - if len(a) != len(b) { - return false - } - - c := byte(0) - - for i := 0; i < len(a); i++ { - c |= a[i] ^ b[i] - } - - return c == 0 -} - -// Search searches f in the table. The return value i is 0 if there is -// no name match. If there is name match or name/value match, i is the -// index of that entry (1-based). If both name and value match, -// nameValueMatch becomes true. -func (dt *dynamicTable) search(f HeaderField) (i uint64, nameValueMatch bool) { - l := len(dt.ents) - for j := l - 1; j >= 0; j-- { - ent := dt.ents[j] - if !constantTimeStringCompare(ent.Name, f.Name) { - continue - } - if i == 0 { - i = uint64(l - j) - } - if f.Sensitive { - continue - } - if !constantTimeStringCompare(ent.Value, f.Value) { - continue - } - i = uint64(l - j) - nameValueMatch = true - return - } - return -} - -func (d *Decoder) maxTableIndex() int { - return len(d.dynTab.ents) + len(staticTable) -} - -func (d *Decoder) at(i uint64) (hf HeaderField, ok bool) { - if i < 1 { - return - } - if i > uint64(d.maxTableIndex()) { - return - } - if i <= uint64(len(staticTable)) { - return staticTable[i-1], true - } - dents := d.dynTab.ents - return dents[len(dents)-(int(i)-len(staticTable))], true -} - -// Decode decodes an entire block. -// -// TODO: remove this method and make it incremental later? This is -// easier for debugging now. -func (d *Decoder) DecodeFull(p []byte) ([]HeaderField, error) { - var hf []HeaderField - saveFunc := d.emit - defer func() { d.emit = saveFunc }() - d.emit = func(f HeaderField) { hf = append(hf, f) } - if _, err := d.Write(p); err != nil { - return nil, err - } - if err := d.Close(); err != nil { - return nil, err - } - return hf, nil -} - -func (d *Decoder) Close() error { - if d.saveBuf.Len() > 0 { - d.saveBuf.Reset() - return DecodingError{errors.New("truncated headers")} - } - return nil -} - -func (d *Decoder) Write(p []byte) (n int, err error) { - if len(p) == 0 { - // Prevent state machine CPU attacks (making us redo - // work up to the point of finding out we don't have - // enough data) - return - } - // Only copy the data if we have to. Optimistically assume - // that p will contain a complete header block. - if d.saveBuf.Len() == 0 { - d.buf = p - } else { - d.saveBuf.Write(p) - d.buf = d.saveBuf.Bytes() - d.saveBuf.Reset() - } - - for len(d.buf) > 0 { - err = d.parseHeaderFieldRepr() - if err == errNeedMore { - // Extra paranoia, making sure saveBuf won't - // get too large. All the varint and string - // reading code earlier should already catch - // overlong things and return ErrStringLength, - // but keep this as a last resort. - const varIntOverhead = 8 // conservative - if d.maxStrLen != 0 && int64(len(d.buf)) > 2*(int64(d.maxStrLen)+varIntOverhead) { - return 0, ErrStringLength - } - d.saveBuf.Write(d.buf) - return len(p), nil - } - if err != nil { - break - } - } - return len(p), err -} - -// errNeedMore is an internal sentinel error value that means the -// buffer is truncated and we need to read more data before we can -// continue parsing. -var errNeedMore = errors.New("need more data") - -type indexType int - -const ( - indexedTrue indexType = iota - indexedFalse - indexedNever -) - -func (v indexType) indexed() bool { return v == indexedTrue } -func (v indexType) sensitive() bool { return v == indexedNever } - -// returns errNeedMore if there isn't enough data available. -// any other error is fatal. -// consumes d.buf iff it returns nil. -// precondition: must be called with len(d.buf) > 0 -func (d *Decoder) parseHeaderFieldRepr() error { - b := d.buf[0] - switch { - case b&128 != 0: - // Indexed representation. - // High bit set? - // http://http2.github.io/http2-spec/compression.html#rfc.section.6.1 - return d.parseFieldIndexed() - case b&192 == 64: - // 6.2.1 Literal Header Field with Incremental Indexing - // 0b10xxxxxx: top two bits are 10 - // http://http2.github.io/http2-spec/compression.html#rfc.section.6.2.1 - return d.parseFieldLiteral(6, indexedTrue) - case b&240 == 0: - // 6.2.2 Literal Header Field without Indexing - // 0b0000xxxx: top four bits are 0000 - // http://http2.github.io/http2-spec/compression.html#rfc.section.6.2.2 - return d.parseFieldLiteral(4, indexedFalse) - case b&240 == 16: - // 6.2.3 Literal Header Field never Indexed - // 0b0001xxxx: top four bits are 0001 - // http://http2.github.io/http2-spec/compression.html#rfc.section.6.2.3 - return d.parseFieldLiteral(4, indexedNever) - case b&224 == 32: - // 6.3 Dynamic Table Size Update - // Top three bits are '001'. - // http://http2.github.io/http2-spec/compression.html#rfc.section.6.3 - return d.parseDynamicTableSizeUpdate() - } - - return DecodingError{errors.New("invalid encoding")} -} - -// (same invariants and behavior as parseHeaderFieldRepr) -func (d *Decoder) parseFieldIndexed() error { - buf := d.buf - idx, buf, err := readVarInt(7, buf) - if err != nil { - return err - } - hf, ok := d.at(idx) - if !ok { - return DecodingError{InvalidIndexError(idx)} - } - d.buf = buf - return d.callEmit(HeaderField{Name: hf.Name, Value: hf.Value}) -} - -// (same invariants and behavior as parseHeaderFieldRepr) -func (d *Decoder) parseFieldLiteral(n uint8, it indexType) error { - buf := d.buf - nameIdx, buf, err := readVarInt(n, buf) - if err != nil { - return err - } - - var hf HeaderField - wantStr := d.emitEnabled || it.indexed() - if nameIdx > 0 { - ihf, ok := d.at(nameIdx) - if !ok { - return DecodingError{InvalidIndexError(nameIdx)} - } - hf.Name = ihf.Name - } else { - hf.Name, buf, err = d.readString(buf, wantStr) - if err != nil { - return err - } - } - hf.Value, buf, err = d.readString(buf, wantStr) - if err != nil { - return err - } - d.buf = buf - if it.indexed() { - d.dynTab.add(hf) - } - hf.Sensitive = it.sensitive() - return d.callEmit(hf) -} - -func (d *Decoder) callEmit(hf HeaderField) error { - if d.maxStrLen != 0 { - if len(hf.Name) > d.maxStrLen || len(hf.Value) > d.maxStrLen { - return ErrStringLength - } - } - if d.emitEnabled { - d.emit(hf) - } - return nil -} - -// (same invariants and behavior as parseHeaderFieldRepr) -func (d *Decoder) parseDynamicTableSizeUpdate() error { - buf := d.buf - size, buf, err := readVarInt(5, buf) - if err != nil { - return err - } - if size > uint64(d.dynTab.allowedMaxSize) { - return DecodingError{errors.New("dynamic table size update too large")} - } - d.dynTab.setMaxSize(uint32(size)) - d.buf = buf - return nil -} - -var errVarintOverflow = DecodingError{errors.New("varint integer overflow")} - -// readVarInt reads an unsigned variable length integer off the -// beginning of p. n is the parameter as described in -// http://http2.github.io/http2-spec/compression.html#rfc.section.5.1. -// -// n must always be between 1 and 8. -// -// The returned remain buffer is either a smaller suffix of p, or err != nil. -// The error is errNeedMore if p doesn't contain a complete integer. -func readVarInt(n byte, p []byte) (i uint64, remain []byte, err error) { - if n < 1 || n > 8 { - panic("bad n") - } - if len(p) == 0 { - return 0, p, errNeedMore - } - i = uint64(p[0]) - if n < 8 { - i &= (1 << uint64(n)) - 1 - } - if i < (1< 0 { - b := p[0] - p = p[1:] - i += uint64(b&127) << m - if b&128 == 0 { - return i, p, nil - } - m += 7 - if m >= 63 { // TODO: proper overflow check. making this up. - return 0, origP, errVarintOverflow - } - } - return 0, origP, errNeedMore -} - -// readString decodes an hpack string from p. -// -// wantStr is whether s will be used. If false, decompression and -// []byte->string garbage are skipped if s will be ignored -// anyway. This does mean that huffman decoding errors for non-indexed -// strings past the MAX_HEADER_LIST_SIZE are ignored, but the server -// is returning an error anyway, and because they're not indexed, the error -// won't affect the decoding state. -func (d *Decoder) readString(p []byte, wantStr bool) (s string, remain []byte, err error) { - if len(p) == 0 { - return "", p, errNeedMore - } - isHuff := p[0]&128 != 0 - strLen, p, err := readVarInt(7, p) - if err != nil { - return "", p, err - } - if d.maxStrLen != 0 && strLen > uint64(d.maxStrLen) { - return "", nil, ErrStringLength - } - if uint64(len(p)) < strLen { - return "", p, errNeedMore - } - if !isHuff { - if wantStr { - s = string(p[:strLen]) - } - return s, p[strLen:], nil - } - - if wantStr { - buf := bufPool.Get().(*bytes.Buffer) - buf.Reset() // don't trust others - defer bufPool.Put(buf) - if err := huffmanDecode(buf, d.maxStrLen, p[:strLen]); err != nil { - buf.Reset() - return "", nil, err - } - s = buf.String() - buf.Reset() // be nice to GC - } - return s, p[strLen:], nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/huffman.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/huffman.go deleted file mode 100644 index 8850e39..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/huffman.go +++ /dev/null @@ -1,212 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package hpack - -import ( - "bytes" - "errors" - "io" - "sync" -) - -var bufPool = sync.Pool{ - New: func() interface{} { return new(bytes.Buffer) }, -} - -// HuffmanDecode decodes the string in v and writes the expanded -// result to w, returning the number of bytes written to w and the -// Write call's return value. At most one Write call is made. -func HuffmanDecode(w io.Writer, v []byte) (int, error) { - buf := bufPool.Get().(*bytes.Buffer) - buf.Reset() - defer bufPool.Put(buf) - if err := huffmanDecode(buf, 0, v); err != nil { - return 0, err - } - return w.Write(buf.Bytes()) -} - -// HuffmanDecodeToString decodes the string in v. -func HuffmanDecodeToString(v []byte) (string, error) { - buf := bufPool.Get().(*bytes.Buffer) - buf.Reset() - defer bufPool.Put(buf) - if err := huffmanDecode(buf, 0, v); err != nil { - return "", err - } - return buf.String(), nil -} - -// ErrInvalidHuffman is returned for errors found decoding -// Huffman-encoded strings. -var ErrInvalidHuffman = errors.New("hpack: invalid Huffman-encoded data") - -// huffmanDecode decodes v to buf. -// If maxLen is greater than 0, attempts to write more to buf than -// maxLen bytes will return ErrStringLength. -func huffmanDecode(buf *bytes.Buffer, maxLen int, v []byte) error { - n := rootHuffmanNode - // cur is the bit buffer that has not been fed into n. - // cbits is the number of low order bits in cur that are valid. - // sbits is the number of bits of the symbol prefix being decoded. - cur, cbits, sbits := uint(0), uint8(0), uint8(0) - for _, b := range v { - cur = cur<<8 | uint(b) - cbits += 8 - sbits += 8 - for cbits >= 8 { - idx := byte(cur >> (cbits - 8)) - n = n.children[idx] - if n == nil { - return ErrInvalidHuffman - } - if n.children == nil { - if maxLen != 0 && buf.Len() == maxLen { - return ErrStringLength - } - buf.WriteByte(n.sym) - cbits -= n.codeLen - n = rootHuffmanNode - sbits = cbits - } else { - cbits -= 8 - } - } - } - for cbits > 0 { - n = n.children[byte(cur<<(8-cbits))] - if n == nil { - return ErrInvalidHuffman - } - if n.children != nil || n.codeLen > cbits { - break - } - if maxLen != 0 && buf.Len() == maxLen { - return ErrStringLength - } - buf.WriteByte(n.sym) - cbits -= n.codeLen - n = rootHuffmanNode - sbits = cbits - } - if sbits > 7 { - // Either there was an incomplete symbol, or overlong padding. - // Both are decoding errors per RFC 7541 section 5.2. - return ErrInvalidHuffman - } - if mask := uint(1< 8 { - codeLen -= 8 - i := uint8(code >> codeLen) - if cur.children[i] == nil { - cur.children[i] = newInternalNode() - } - cur = cur.children[i] - } - shift := 8 - codeLen - start, end := int(uint8(code<> (nbits - rembits)) - dst[len(dst)-1] |= t - } - - return dst -} - -// HuffmanEncodeLength returns the number of bytes required to encode -// s in Huffman codes. The result is round up to byte boundary. -func HuffmanEncodeLength(s string) uint64 { - n := uint64(0) - for i := 0; i < len(s); i++ { - n += uint64(huffmanCodeLen[s[i]]) - } - return (n + 7) / 8 -} - -// appendByteToHuffmanCode appends Huffman code for c to dst and -// returns the extended buffer and the remaining bits in the last -// element. The appending is not byte aligned and the remaining bits -// in the last element of dst is given in rembits. -func appendByteToHuffmanCode(dst []byte, rembits uint8, c byte) ([]byte, uint8) { - code := huffmanCodes[c] - nbits := huffmanCodeLen[c] - - for { - if rembits > nbits { - t := uint8(code << (rembits - nbits)) - dst[len(dst)-1] |= t - rembits -= nbits - break - } - - t := uint8(code >> (nbits - rembits)) - dst[len(dst)-1] |= t - - nbits -= rembits - rembits = 8 - - if nbits == 0 { - break - } - - dst = append(dst, 0) - } - - return dst, rembits -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/tables.go deleted file mode 100644 index b9283a0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/hpack/tables.go +++ /dev/null @@ -1,352 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package hpack - -func pair(name, value string) HeaderField { - return HeaderField{Name: name, Value: value} -} - -// http://tools.ietf.org/html/draft-ietf-httpbis-header-compression-07#appendix-B -var staticTable = [...]HeaderField{ - pair(":authority", ""), // index 1 (1-based) - pair(":method", "GET"), - pair(":method", "POST"), - pair(":path", "/"), - pair(":path", "/index.html"), - pair(":scheme", "http"), - pair(":scheme", "https"), - pair(":status", "200"), - pair(":status", "204"), - pair(":status", "206"), - pair(":status", "304"), - pair(":status", "400"), - pair(":status", "404"), - pair(":status", "500"), - pair("accept-charset", ""), - pair("accept-encoding", "gzip, deflate"), - pair("accept-language", ""), - pair("accept-ranges", ""), - pair("accept", ""), - pair("access-control-allow-origin", ""), - pair("age", ""), - pair("allow", ""), - pair("authorization", ""), - pair("cache-control", ""), - pair("content-disposition", ""), - pair("content-encoding", ""), - pair("content-language", ""), - pair("content-length", ""), - pair("content-location", ""), - pair("content-range", ""), - pair("content-type", ""), - pair("cookie", ""), - pair("date", ""), - pair("etag", ""), - pair("expect", ""), - pair("expires", ""), - pair("from", ""), - pair("host", ""), - pair("if-match", ""), - pair("if-modified-since", ""), - pair("if-none-match", ""), - pair("if-range", ""), - pair("if-unmodified-since", ""), - pair("last-modified", ""), - pair("link", ""), - pair("location", ""), - pair("max-forwards", ""), - pair("proxy-authenticate", ""), - pair("proxy-authorization", ""), - pair("range", ""), - pair("referer", ""), - pair("refresh", ""), - pair("retry-after", ""), - pair("server", ""), - pair("set-cookie", ""), - pair("strict-transport-security", ""), - pair("transfer-encoding", ""), - pair("user-agent", ""), - pair("vary", ""), - pair("via", ""), - pair("www-authenticate", ""), -} - -var huffmanCodes = [256]uint32{ - 0x1ff8, - 0x7fffd8, - 0xfffffe2, - 0xfffffe3, - 0xfffffe4, - 0xfffffe5, - 0xfffffe6, - 0xfffffe7, - 0xfffffe8, - 0xffffea, - 0x3ffffffc, - 0xfffffe9, - 0xfffffea, - 0x3ffffffd, - 0xfffffeb, - 0xfffffec, - 0xfffffed, - 0xfffffee, - 0xfffffef, - 0xffffff0, - 0xffffff1, - 0xffffff2, - 0x3ffffffe, - 0xffffff3, - 0xffffff4, - 0xffffff5, - 0xffffff6, - 0xffffff7, - 0xffffff8, - 0xffffff9, - 0xffffffa, - 0xffffffb, - 0x14, - 0x3f8, - 0x3f9, - 0xffa, - 0x1ff9, - 0x15, - 0xf8, - 0x7fa, - 0x3fa, - 0x3fb, - 0xf9, - 0x7fb, - 0xfa, - 0x16, - 0x17, - 0x18, - 0x0, - 0x1, - 0x2, - 0x19, - 0x1a, - 0x1b, - 0x1c, - 0x1d, - 0x1e, - 0x1f, - 0x5c, - 0xfb, - 0x7ffc, - 0x20, - 0xffb, - 0x3fc, - 0x1ffa, - 0x21, - 0x5d, - 0x5e, - 0x5f, - 0x60, - 0x61, - 0x62, - 0x63, - 0x64, - 0x65, - 0x66, - 0x67, - 0x68, - 0x69, - 0x6a, - 0x6b, - 0x6c, - 0x6d, - 0x6e, - 0x6f, - 0x70, - 0x71, - 0x72, - 0xfc, - 0x73, - 0xfd, - 0x1ffb, - 0x7fff0, - 0x1ffc, - 0x3ffc, - 0x22, - 0x7ffd, - 0x3, - 0x23, - 0x4, - 0x24, - 0x5, - 0x25, - 0x26, - 0x27, - 0x6, - 0x74, - 0x75, - 0x28, - 0x29, - 0x2a, - 0x7, - 0x2b, - 0x76, - 0x2c, - 0x8, - 0x9, - 0x2d, - 0x77, - 0x78, - 0x79, - 0x7a, - 0x7b, - 0x7ffe, - 0x7fc, - 0x3ffd, - 0x1ffd, - 0xffffffc, - 0xfffe6, - 0x3fffd2, - 0xfffe7, - 0xfffe8, - 0x3fffd3, - 0x3fffd4, - 0x3fffd5, - 0x7fffd9, - 0x3fffd6, - 0x7fffda, - 0x7fffdb, - 0x7fffdc, - 0x7fffdd, - 0x7fffde, - 0xffffeb, - 0x7fffdf, - 0xffffec, - 0xffffed, - 0x3fffd7, - 0x7fffe0, - 0xffffee, - 0x7fffe1, - 0x7fffe2, - 0x7fffe3, - 0x7fffe4, - 0x1fffdc, - 0x3fffd8, - 0x7fffe5, - 0x3fffd9, - 0x7fffe6, - 0x7fffe7, - 0xffffef, - 0x3fffda, - 0x1fffdd, - 0xfffe9, - 0x3fffdb, - 0x3fffdc, - 0x7fffe8, - 0x7fffe9, - 0x1fffde, - 0x7fffea, - 0x3fffdd, - 0x3fffde, - 0xfffff0, - 0x1fffdf, - 0x3fffdf, - 0x7fffeb, - 0x7fffec, - 0x1fffe0, - 0x1fffe1, - 0x3fffe0, - 0x1fffe2, - 0x7fffed, - 0x3fffe1, - 0x7fffee, - 0x7fffef, - 0xfffea, - 0x3fffe2, - 0x3fffe3, - 0x3fffe4, - 0x7ffff0, - 0x3fffe5, - 0x3fffe6, - 0x7ffff1, - 0x3ffffe0, - 0x3ffffe1, - 0xfffeb, - 0x7fff1, - 0x3fffe7, - 0x7ffff2, - 0x3fffe8, - 0x1ffffec, - 0x3ffffe2, - 0x3ffffe3, - 0x3ffffe4, - 0x7ffffde, - 0x7ffffdf, - 0x3ffffe5, - 0xfffff1, - 0x1ffffed, - 0x7fff2, - 0x1fffe3, - 0x3ffffe6, - 0x7ffffe0, - 0x7ffffe1, - 0x3ffffe7, - 0x7ffffe2, - 0xfffff2, - 0x1fffe4, - 0x1fffe5, - 0x3ffffe8, - 0x3ffffe9, - 0xffffffd, - 0x7ffffe3, - 0x7ffffe4, - 0x7ffffe5, - 0xfffec, - 0xfffff3, - 0xfffed, - 0x1fffe6, - 0x3fffe9, - 0x1fffe7, - 0x1fffe8, - 0x7ffff3, - 0x3fffea, - 0x3fffeb, - 0x1ffffee, - 0x1ffffef, - 0xfffff4, - 0xfffff5, - 0x3ffffea, - 0x7ffff4, - 0x3ffffeb, - 0x7ffffe6, - 0x3ffffec, - 0x3ffffed, - 0x7ffffe7, - 0x7ffffe8, - 0x7ffffe9, - 0x7ffffea, - 0x7ffffeb, - 0xffffffe, - 0x7ffffec, - 0x7ffffed, - 0x7ffffee, - 0x7ffffef, - 0x7fffff0, - 0x3ffffee, -} - -var huffmanCodeLen = [256]uint8{ - 13, 23, 28, 28, 28, 28, 28, 28, 28, 24, 30, 28, 28, 30, 28, 28, - 28, 28, 28, 28, 28, 28, 30, 28, 28, 28, 28, 28, 28, 28, 28, 28, - 6, 10, 10, 12, 13, 6, 8, 11, 10, 10, 8, 11, 8, 6, 6, 6, - 5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 7, 8, 15, 6, 12, 10, - 13, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, - 7, 7, 7, 7, 7, 7, 7, 7, 8, 7, 8, 13, 19, 13, 14, 6, - 15, 5, 6, 5, 6, 5, 6, 6, 6, 5, 7, 7, 6, 6, 6, 5, - 6, 7, 6, 5, 5, 6, 7, 7, 7, 7, 7, 15, 11, 14, 13, 28, - 20, 22, 20, 20, 22, 22, 22, 23, 22, 23, 23, 23, 23, 23, 24, 23, - 24, 24, 22, 23, 24, 23, 23, 23, 23, 21, 22, 23, 22, 23, 23, 24, - 22, 21, 20, 22, 22, 23, 23, 21, 23, 22, 22, 24, 21, 22, 23, 23, - 21, 21, 22, 21, 23, 22, 23, 23, 20, 22, 22, 22, 23, 22, 22, 23, - 26, 26, 20, 19, 22, 23, 22, 25, 26, 26, 26, 27, 27, 26, 24, 25, - 19, 21, 26, 27, 27, 26, 27, 24, 21, 21, 26, 26, 28, 27, 27, 27, - 20, 24, 20, 21, 22, 21, 21, 23, 22, 22, 25, 25, 24, 24, 26, 23, - 26, 27, 26, 26, 27, 27, 27, 27, 27, 28, 27, 27, 27, 27, 27, 26, -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/http2.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/http2.go deleted file mode 100644 index 0173aed..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/http2.go +++ /dev/null @@ -1,351 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package http2 implements the HTTP/2 protocol. -// -// This package is low-level and intended to be used directly by very -// few people. Most users will use it indirectly through the automatic -// use by the net/http package (from Go 1.6 and later). -// For use in earlier Go versions see ConfigureServer. (Transport support -// requires Go 1.6 or later) -// -// See https://http2.github.io/ for more information on HTTP/2. -// -// See https://http2.golang.org/ for a test server running this code. -package http2 - -import ( - "bufio" - "crypto/tls" - "errors" - "fmt" - "io" - "net/http" - "os" - "sort" - "strconv" - "strings" - "sync" - - "golang.org/x/net/lex/httplex" -) - -var ( - VerboseLogs bool - logFrameWrites bool - logFrameReads bool -) - -func init() { - e := os.Getenv("GODEBUG") - if strings.Contains(e, "http2debug=1") { - VerboseLogs = true - } - if strings.Contains(e, "http2debug=2") { - VerboseLogs = true - logFrameWrites = true - logFrameReads = true - } -} - -const ( - // ClientPreface is the string that must be sent by new - // connections from clients. - ClientPreface = "PRI * HTTP/2.0\r\n\r\nSM\r\n\r\n" - - // SETTINGS_MAX_FRAME_SIZE default - // http://http2.github.io/http2-spec/#rfc.section.6.5.2 - initialMaxFrameSize = 16384 - - // NextProtoTLS is the NPN/ALPN protocol negotiated during - // HTTP/2's TLS setup. - NextProtoTLS = "h2" - - // http://http2.github.io/http2-spec/#SettingValues - initialHeaderTableSize = 4096 - - initialWindowSize = 65535 // 6.9.2 Initial Flow Control Window Size - - defaultMaxReadFrameSize = 1 << 20 -) - -var ( - clientPreface = []byte(ClientPreface) -) - -type streamState int - -const ( - stateIdle streamState = iota - stateOpen - stateHalfClosedLocal - stateHalfClosedRemote - stateResvLocal - stateResvRemote - stateClosed -) - -var stateName = [...]string{ - stateIdle: "Idle", - stateOpen: "Open", - stateHalfClosedLocal: "HalfClosedLocal", - stateHalfClosedRemote: "HalfClosedRemote", - stateResvLocal: "ResvLocal", - stateResvRemote: "ResvRemote", - stateClosed: "Closed", -} - -func (st streamState) String() string { - return stateName[st] -} - -// Setting is a setting parameter: which setting it is, and its value. -type Setting struct { - // ID is which setting is being set. - // See http://http2.github.io/http2-spec/#SettingValues - ID SettingID - - // Val is the value. - Val uint32 -} - -func (s Setting) String() string { - return fmt.Sprintf("[%v = %d]", s.ID, s.Val) -} - -// Valid reports whether the setting is valid. -func (s Setting) Valid() error { - // Limits and error codes from 6.5.2 Defined SETTINGS Parameters - switch s.ID { - case SettingEnablePush: - if s.Val != 1 && s.Val != 0 { - return ConnectionError(ErrCodeProtocol) - } - case SettingInitialWindowSize: - if s.Val > 1<<31-1 { - return ConnectionError(ErrCodeFlowControl) - } - case SettingMaxFrameSize: - if s.Val < 16384 || s.Val > 1<<24-1 { - return ConnectionError(ErrCodeProtocol) - } - } - return nil -} - -// A SettingID is an HTTP/2 setting as defined in -// http://http2.github.io/http2-spec/#iana-settings -type SettingID uint16 - -const ( - SettingHeaderTableSize SettingID = 0x1 - SettingEnablePush SettingID = 0x2 - SettingMaxConcurrentStreams SettingID = 0x3 - SettingInitialWindowSize SettingID = 0x4 - SettingMaxFrameSize SettingID = 0x5 - SettingMaxHeaderListSize SettingID = 0x6 -) - -var settingName = map[SettingID]string{ - SettingHeaderTableSize: "HEADER_TABLE_SIZE", - SettingEnablePush: "ENABLE_PUSH", - SettingMaxConcurrentStreams: "MAX_CONCURRENT_STREAMS", - SettingInitialWindowSize: "INITIAL_WINDOW_SIZE", - SettingMaxFrameSize: "MAX_FRAME_SIZE", - SettingMaxHeaderListSize: "MAX_HEADER_LIST_SIZE", -} - -func (s SettingID) String() string { - if v, ok := settingName[s]; ok { - return v - } - return fmt.Sprintf("UNKNOWN_SETTING_%d", uint16(s)) -} - -var ( - errInvalidHeaderFieldName = errors.New("http2: invalid header field name") - errInvalidHeaderFieldValue = errors.New("http2: invalid header field value") -) - -// validWireHeaderFieldName reports whether v is a valid header field -// name (key). See httplex.ValidHeaderName for the base rules. -// -// Further, http2 says: -// "Just as in HTTP/1.x, header field names are strings of ASCII -// characters that are compared in a case-insensitive -// fashion. However, header field names MUST be converted to -// lowercase prior to their encoding in HTTP/2. " -func validWireHeaderFieldName(v string) bool { - if len(v) == 0 { - return false - } - for _, r := range v { - if !httplex.IsTokenRune(r) { - return false - } - if 'A' <= r && r <= 'Z' { - return false - } - } - return true -} - -var httpCodeStringCommon = map[int]string{} // n -> strconv.Itoa(n) - -func init() { - for i := 100; i <= 999; i++ { - if v := http.StatusText(i); v != "" { - httpCodeStringCommon[i] = strconv.Itoa(i) - } - } -} - -func httpCodeString(code int) string { - if s, ok := httpCodeStringCommon[code]; ok { - return s - } - return strconv.Itoa(code) -} - -// from pkg io -type stringWriter interface { - WriteString(s string) (n int, err error) -} - -// A gate lets two goroutines coordinate their activities. -type gate chan struct{} - -func (g gate) Done() { g <- struct{}{} } -func (g gate) Wait() { <-g } - -// A closeWaiter is like a sync.WaitGroup but only goes 1 to 0 (open to closed). -type closeWaiter chan struct{} - -// Init makes a closeWaiter usable. -// It exists because so a closeWaiter value can be placed inside a -// larger struct and have the Mutex and Cond's memory in the same -// allocation. -func (cw *closeWaiter) Init() { - *cw = make(chan struct{}) -} - -// Close marks the closeWaiter as closed and unblocks any waiters. -func (cw closeWaiter) Close() { - close(cw) -} - -// Wait waits for the closeWaiter to become closed. -func (cw closeWaiter) Wait() { - <-cw -} - -// bufferedWriter is a buffered writer that writes to w. -// Its buffered writer is lazily allocated as needed, to minimize -// idle memory usage with many connections. -type bufferedWriter struct { - w io.Writer // immutable - bw *bufio.Writer // non-nil when data is buffered -} - -func newBufferedWriter(w io.Writer) *bufferedWriter { - return &bufferedWriter{w: w} -} - -var bufWriterPool = sync.Pool{ - New: func() interface{} { - // TODO: pick something better? this is a bit under - // (3 x typical 1500 byte MTU) at least. - return bufio.NewWriterSize(nil, 4<<10) - }, -} - -func (w *bufferedWriter) Write(p []byte) (n int, err error) { - if w.bw == nil { - bw := bufWriterPool.Get().(*bufio.Writer) - bw.Reset(w.w) - w.bw = bw - } - return w.bw.Write(p) -} - -func (w *bufferedWriter) Flush() error { - bw := w.bw - if bw == nil { - return nil - } - err := bw.Flush() - bw.Reset(nil) - bufWriterPool.Put(bw) - w.bw = nil - return err -} - -func mustUint31(v int32) uint32 { - if v < 0 || v > 2147483647 { - panic("out of range") - } - return uint32(v) -} - -// bodyAllowedForStatus reports whether a given response status code -// permits a body. See RFC 2616, section 4.4. -func bodyAllowedForStatus(status int) bool { - switch { - case status >= 100 && status <= 199: - return false - case status == 204: - return false - case status == 304: - return false - } - return true -} - -type httpError struct { - msg string - timeout bool -} - -func (e *httpError) Error() string { return e.msg } -func (e *httpError) Timeout() bool { return e.timeout } -func (e *httpError) Temporary() bool { return true } - -var errTimeout error = &httpError{msg: "http2: timeout awaiting response headers", timeout: true} - -type connectionStater interface { - ConnectionState() tls.ConnectionState -} - -var sorterPool = sync.Pool{New: func() interface{} { return new(sorter) }} - -type sorter struct { - v []string // owned by sorter -} - -func (s *sorter) Len() int { return len(s.v) } -func (s *sorter) Swap(i, j int) { s.v[i], s.v[j] = s.v[j], s.v[i] } -func (s *sorter) Less(i, j int) bool { return s.v[i] < s.v[j] } - -// Keys returns the sorted keys of h. -// -// The returned slice is only valid until s used again or returned to -// its pool. -func (s *sorter) Keys(h http.Header) []string { - keys := s.v[:0] - for k := range h { - keys = append(keys, k) - } - s.v = keys - sort.Sort(s) - return keys -} - -func (s *sorter) SortStrings(ss []string) { - // Our sorter works on s.v, which sorter owners, so - // stash it away while we sort the user's buffer. - save := s.v - s.v = ss - sort.Sort(s) - s.v = save -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go16.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go16.go deleted file mode 100644 index efd2e12..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go16.go +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build !go1.6 - -package http2 - -import ( - "crypto/tls" - "net/http" - "time" -) - -func configureTransport(t1 *http.Transport) (*Transport, error) { - return nil, errTransportVersion -} - -func transportExpectContinueTimeout(t1 *http.Transport) time.Duration { - return 0 - -} - -// isBadCipher reports whether the cipher is blacklisted by the HTTP/2 spec. -func isBadCipher(cipher uint16) bool { - switch cipher { - case tls.TLS_RSA_WITH_RC4_128_SHA, - tls.TLS_RSA_WITH_3DES_EDE_CBC_SHA, - tls.TLS_RSA_WITH_AES_128_CBC_SHA, - tls.TLS_RSA_WITH_AES_256_CBC_SHA, - tls.TLS_ECDHE_ECDSA_WITH_RC4_128_SHA, - tls.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA, - tls.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_RC4_128_SHA, - tls.TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, - tls.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA: - // Reject cipher suites from Appendix A. - // "This list includes those cipher suites that do not - // offer an ephemeral key exchange and those that are - // based on the TLS null, stream or block cipher type" - return true - default: - return false - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go17.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go17.go deleted file mode 100644 index 28df0c1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/not_go17.go +++ /dev/null @@ -1,51 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build !go1.7 - -package http2 - -import ( - "net" - "net/http" -) - -type contextContext interface{} - -type fakeContext struct{} - -func (fakeContext) Done() <-chan struct{} { return nil } -func (fakeContext) Err() error { panic("should not be called") } - -func reqContext(r *http.Request) fakeContext { - return fakeContext{} -} - -func setResponseUncompressed(res *http.Response) { - // Nothing. -} - -type clientTrace struct{} - -func requestTrace(*http.Request) *clientTrace { return nil } -func traceGotConn(*http.Request, *ClientConn) {} -func traceFirstResponseByte(*clientTrace) {} -func traceWroteHeaders(*clientTrace) {} -func traceWroteRequest(*clientTrace, error) {} -func traceGot100Continue(trace *clientTrace) {} -func traceWait100Continue(trace *clientTrace) {} - -func nop() {} - -func serverConnBaseContext(c net.Conn, opts *ServeConnOpts) (ctx contextContext, cancel func()) { - return nil, nop -} - -func contextWithCancel(ctx contextContext) (_ contextContext, cancel func()) { - return ctx, nop -} - -func requestWithContext(req *http.Request, ctx contextContext) *http.Request { - return req -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/pipe.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/pipe.go deleted file mode 100644 index 53b7a1d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/pipe.go +++ /dev/null @@ -1,153 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "errors" - "io" - "sync" -) - -// pipe is a goroutine-safe io.Reader/io.Writer pair. It's like -// io.Pipe except there are no PipeReader/PipeWriter halves, and the -// underlying buffer is an interface. (io.Pipe is always unbuffered) -type pipe struct { - mu sync.Mutex - c sync.Cond // c.L lazily initialized to &p.mu - b pipeBuffer - err error // read error once empty. non-nil means closed. - breakErr error // immediate read error (caller doesn't see rest of b) - donec chan struct{} // closed on error - readFn func() // optional code to run in Read before error -} - -type pipeBuffer interface { - Len() int - io.Writer - io.Reader -} - -func (p *pipe) Len() int { - p.mu.Lock() - defer p.mu.Unlock() - return p.b.Len() -} - -// Read waits until data is available and copies bytes -// from the buffer into p. -func (p *pipe) Read(d []byte) (n int, err error) { - p.mu.Lock() - defer p.mu.Unlock() - if p.c.L == nil { - p.c.L = &p.mu - } - for { - if p.breakErr != nil { - return 0, p.breakErr - } - if p.b.Len() > 0 { - return p.b.Read(d) - } - if p.err != nil { - if p.readFn != nil { - p.readFn() // e.g. copy trailers - p.readFn = nil // not sticky like p.err - } - return 0, p.err - } - p.c.Wait() - } -} - -var errClosedPipeWrite = errors.New("write on closed buffer") - -// Write copies bytes from p into the buffer and wakes a reader. -// It is an error to write more data than the buffer can hold. -func (p *pipe) Write(d []byte) (n int, err error) { - p.mu.Lock() - defer p.mu.Unlock() - if p.c.L == nil { - p.c.L = &p.mu - } - defer p.c.Signal() - if p.err != nil { - return 0, errClosedPipeWrite - } - return p.b.Write(d) -} - -// CloseWithError causes the next Read (waking up a current blocked -// Read if needed) to return the provided err after all data has been -// read. -// -// The error must be non-nil. -func (p *pipe) CloseWithError(err error) { p.closeWithError(&p.err, err, nil) } - -// BreakWithError causes the next Read (waking up a current blocked -// Read if needed) to return the provided err immediately, without -// waiting for unread data. -func (p *pipe) BreakWithError(err error) { p.closeWithError(&p.breakErr, err, nil) } - -// closeWithErrorAndCode is like CloseWithError but also sets some code to run -// in the caller's goroutine before returning the error. -func (p *pipe) closeWithErrorAndCode(err error, fn func()) { p.closeWithError(&p.err, err, fn) } - -func (p *pipe) closeWithError(dst *error, err error, fn func()) { - if err == nil { - panic("err must be non-nil") - } - p.mu.Lock() - defer p.mu.Unlock() - if p.c.L == nil { - p.c.L = &p.mu - } - defer p.c.Signal() - if *dst != nil { - // Already been done. - return - } - p.readFn = fn - *dst = err - p.closeDoneLocked() -} - -// requires p.mu be held. -func (p *pipe) closeDoneLocked() { - if p.donec == nil { - return - } - // Close if unclosed. This isn't racy since we always - // hold p.mu while closing. - select { - case <-p.donec: - default: - close(p.donec) - } -} - -// Err returns the error (if any) first set by BreakWithError or CloseWithError. -func (p *pipe) Err() error { - p.mu.Lock() - defer p.mu.Unlock() - if p.breakErr != nil { - return p.breakErr - } - return p.err -} - -// Done returns a channel which is closed if and when this pipe is closed -// with CloseWithError. -func (p *pipe) Done() <-chan struct{} { - p.mu.Lock() - defer p.mu.Unlock() - if p.donec == nil { - p.donec = make(chan struct{}) - if p.err != nil || p.breakErr != nil { - // Already hit an error. - p.closeDoneLocked() - } - } - return p.donec -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/server.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/server.go deleted file mode 100644 index f368738..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/server.go +++ /dev/null @@ -1,2263 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// TODO: replace all <-sc.doneServing with reads from the stream's cw -// instead, and make sure that on close we close all open -// streams. then remove doneServing? - -// TODO: re-audit GOAWAY support. Consider each incoming frame type and -// whether it should be ignored during graceful shutdown. - -// TODO: disconnect idle clients. GFE seems to do 4 minutes. make -// configurable? or maximum number of idle clients and remove the -// oldest? - -// TODO: turn off the serve goroutine when idle, so -// an idle conn only has the readFrames goroutine active. (which could -// also be optimized probably to pin less memory in crypto/tls). This -// would involve tracking when the serve goroutine is active (atomic -// int32 read/CAS probably?) and starting it up when frames arrive, -// and shutting it down when all handlers exit. the occasional PING -// packets could use time.AfterFunc to call sc.wakeStartServeLoop() -// (which is a no-op if already running) and then queue the PING write -// as normal. The serve loop would then exit in most cases (if no -// Handlers running) and not be woken up again until the PING packet -// returns. - -// TODO (maybe): add a mechanism for Handlers to going into -// half-closed-local mode (rw.(io.Closer) test?) but not exit their -// handler, and continue to be able to read from the -// Request.Body. This would be a somewhat semantic change from HTTP/1 -// (or at least what we expose in net/http), so I'd probably want to -// add it there too. For now, this package says that returning from -// the Handler ServeHTTP function means you're both done reading and -// done writing, without a way to stop just one or the other. - -package http2 - -import ( - "bufio" - "bytes" - "crypto/tls" - "errors" - "fmt" - "io" - "log" - "net" - "net/http" - "net/textproto" - "net/url" - "os" - "reflect" - "runtime" - "strconv" - "strings" - "sync" - "time" - - "golang.org/x/net/http2/hpack" -) - -const ( - prefaceTimeout = 10 * time.Second - firstSettingsTimeout = 2 * time.Second // should be in-flight with preface anyway - handlerChunkWriteSize = 4 << 10 - defaultMaxStreams = 250 // TODO: make this 100 as the GFE seems to? -) - -var ( - errClientDisconnected = errors.New("client disconnected") - errClosedBody = errors.New("body closed by handler") - errHandlerComplete = errors.New("http2: request body closed due to handler exiting") - errStreamClosed = errors.New("http2: stream closed") -) - -var responseWriterStatePool = sync.Pool{ - New: func() interface{} { - rws := &responseWriterState{} - rws.bw = bufio.NewWriterSize(chunkWriter{rws}, handlerChunkWriteSize) - return rws - }, -} - -// Test hooks. -var ( - testHookOnConn func() - testHookGetServerConn func(*serverConn) - testHookOnPanicMu *sync.Mutex // nil except in tests - testHookOnPanic func(sc *serverConn, panicVal interface{}) (rePanic bool) -) - -// Server is an HTTP/2 server. -type Server struct { - // MaxHandlers limits the number of http.Handler ServeHTTP goroutines - // which may run at a time over all connections. - // Negative or zero no limit. - // TODO: implement - MaxHandlers int - - // MaxConcurrentStreams optionally specifies the number of - // concurrent streams that each client may have open at a - // time. This is unrelated to the number of http.Handler goroutines - // which may be active globally, which is MaxHandlers. - // If zero, MaxConcurrentStreams defaults to at least 100, per - // the HTTP/2 spec's recommendations. - MaxConcurrentStreams uint32 - - // MaxReadFrameSize optionally specifies the largest frame - // this server is willing to read. A valid value is between - // 16k and 16M, inclusive. If zero or otherwise invalid, a - // default value is used. - MaxReadFrameSize uint32 - - // PermitProhibitedCipherSuites, if true, permits the use of - // cipher suites prohibited by the HTTP/2 spec. - PermitProhibitedCipherSuites bool -} - -func (s *Server) maxReadFrameSize() uint32 { - if v := s.MaxReadFrameSize; v >= minMaxFrameSize && v <= maxFrameSize { - return v - } - return defaultMaxReadFrameSize -} - -func (s *Server) maxConcurrentStreams() uint32 { - if v := s.MaxConcurrentStreams; v > 0 { - return v - } - return defaultMaxStreams -} - -// ConfigureServer adds HTTP/2 support to a net/http Server. -// -// The configuration conf may be nil. -// -// ConfigureServer must be called before s begins serving. -func ConfigureServer(s *http.Server, conf *Server) error { - if conf == nil { - conf = new(Server) - } - - if s.TLSConfig == nil { - s.TLSConfig = new(tls.Config) - } else if s.TLSConfig.CipherSuites != nil { - // If they already provided a CipherSuite list, return - // an error if it has a bad order or is missing - // ECDHE_RSA_WITH_AES_128_GCM_SHA256. - const requiredCipher = tls.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 - haveRequired := false - sawBad := false - for i, cs := range s.TLSConfig.CipherSuites { - if cs == requiredCipher { - haveRequired = true - } - if isBadCipher(cs) { - sawBad = true - } else if sawBad { - return fmt.Errorf("http2: TLSConfig.CipherSuites index %d contains an HTTP/2-approved cipher suite (%#04x), but it comes after unapproved cipher suites. With this configuration, clients that don't support previous, approved cipher suites may be given an unapproved one and reject the connection.", i, cs) - } - } - if !haveRequired { - return fmt.Errorf("http2: TLSConfig.CipherSuites is missing HTTP/2-required TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256") - } - } - - // Note: not setting MinVersion to tls.VersionTLS12, - // as we don't want to interfere with HTTP/1.1 traffic - // on the user's server. We enforce TLS 1.2 later once - // we accept a connection. Ideally this should be done - // during next-proto selection, but using TLS <1.2 with - // HTTP/2 is still the client's bug. - - s.TLSConfig.PreferServerCipherSuites = true - - haveNPN := false - for _, p := range s.TLSConfig.NextProtos { - if p == NextProtoTLS { - haveNPN = true - break - } - } - if !haveNPN { - s.TLSConfig.NextProtos = append(s.TLSConfig.NextProtos, NextProtoTLS) - } - // h2-14 is temporary (as of 2015-03-05) while we wait for all browsers - // to switch to "h2". - s.TLSConfig.NextProtos = append(s.TLSConfig.NextProtos, "h2-14") - - if s.TLSNextProto == nil { - s.TLSNextProto = map[string]func(*http.Server, *tls.Conn, http.Handler){} - } - protoHandler := func(hs *http.Server, c *tls.Conn, h http.Handler) { - if testHookOnConn != nil { - testHookOnConn() - } - conf.ServeConn(c, &ServeConnOpts{ - Handler: h, - BaseConfig: hs, - }) - } - s.TLSNextProto[NextProtoTLS] = protoHandler - s.TLSNextProto["h2-14"] = protoHandler // temporary; see above. - return nil -} - -// ServeConnOpts are options for the Server.ServeConn method. -type ServeConnOpts struct { - // BaseConfig optionally sets the base configuration - // for values. If nil, defaults are used. - BaseConfig *http.Server - - // Handler specifies which handler to use for processing - // requests. If nil, BaseConfig.Handler is used. If BaseConfig - // or BaseConfig.Handler is nil, http.DefaultServeMux is used. - Handler http.Handler -} - -func (o *ServeConnOpts) baseConfig() *http.Server { - if o != nil && o.BaseConfig != nil { - return o.BaseConfig - } - return new(http.Server) -} - -func (o *ServeConnOpts) handler() http.Handler { - if o != nil { - if o.Handler != nil { - return o.Handler - } - if o.BaseConfig != nil && o.BaseConfig.Handler != nil { - return o.BaseConfig.Handler - } - } - return http.DefaultServeMux -} - -// ServeConn serves HTTP/2 requests on the provided connection and -// blocks until the connection is no longer readable. -// -// ServeConn starts speaking HTTP/2 assuming that c has not had any -// reads or writes. It writes its initial settings frame and expects -// to be able to read the preface and settings frame from the -// client. If c has a ConnectionState method like a *tls.Conn, the -// ConnectionState is used to verify the TLS ciphersuite and to set -// the Request.TLS field in Handlers. -// -// ServeConn does not support h2c by itself. Any h2c support must be -// implemented in terms of providing a suitably-behaving net.Conn. -// -// The opts parameter is optional. If nil, default values are used. -func (s *Server) ServeConn(c net.Conn, opts *ServeConnOpts) { - baseCtx, cancel := serverConnBaseContext(c, opts) - defer cancel() - - sc := &serverConn{ - srv: s, - hs: opts.baseConfig(), - conn: c, - baseCtx: baseCtx, - remoteAddrStr: c.RemoteAddr().String(), - bw: newBufferedWriter(c), - handler: opts.handler(), - streams: make(map[uint32]*stream), - readFrameCh: make(chan readFrameResult), - wantWriteFrameCh: make(chan frameWriteMsg, 8), - wroteFrameCh: make(chan frameWriteResult, 1), // buffered; one send in writeFrameAsync - bodyReadCh: make(chan bodyReadMsg), // buffering doesn't matter either way - doneServing: make(chan struct{}), - advMaxStreams: s.maxConcurrentStreams(), - writeSched: writeScheduler{ - maxFrameSize: initialMaxFrameSize, - }, - initialWindowSize: initialWindowSize, - headerTableSize: initialHeaderTableSize, - serveG: newGoroutineLock(), - pushEnabled: true, - } - - sc.flow.add(initialWindowSize) - sc.inflow.add(initialWindowSize) - sc.hpackEncoder = hpack.NewEncoder(&sc.headerWriteBuf) - - fr := NewFramer(sc.bw, c) - fr.ReadMetaHeaders = hpack.NewDecoder(initialHeaderTableSize, nil) - fr.MaxHeaderListSize = sc.maxHeaderListSize() - fr.SetMaxReadFrameSize(s.maxReadFrameSize()) - sc.framer = fr - - if tc, ok := c.(connectionStater); ok { - sc.tlsState = new(tls.ConnectionState) - *sc.tlsState = tc.ConnectionState() - // 9.2 Use of TLS Features - // An implementation of HTTP/2 over TLS MUST use TLS - // 1.2 or higher with the restrictions on feature set - // and cipher suite described in this section. Due to - // implementation limitations, it might not be - // possible to fail TLS negotiation. An endpoint MUST - // immediately terminate an HTTP/2 connection that - // does not meet the TLS requirements described in - // this section with a connection error (Section - // 5.4.1) of type INADEQUATE_SECURITY. - if sc.tlsState.Version < tls.VersionTLS12 { - sc.rejectConn(ErrCodeInadequateSecurity, "TLS version too low") - return - } - - if sc.tlsState.ServerName == "" { - // Client must use SNI, but we don't enforce that anymore, - // since it was causing problems when connecting to bare IP - // addresses during development. - // - // TODO: optionally enforce? Or enforce at the time we receive - // a new request, and verify the the ServerName matches the :authority? - // But that precludes proxy situations, perhaps. - // - // So for now, do nothing here again. - } - - if !s.PermitProhibitedCipherSuites && isBadCipher(sc.tlsState.CipherSuite) { - // "Endpoints MAY choose to generate a connection error - // (Section 5.4.1) of type INADEQUATE_SECURITY if one of - // the prohibited cipher suites are negotiated." - // - // We choose that. In my opinion, the spec is weak - // here. It also says both parties must support at least - // TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 so there's no - // excuses here. If we really must, we could allow an - // "AllowInsecureWeakCiphers" option on the server later. - // Let's see how it plays out first. - sc.rejectConn(ErrCodeInadequateSecurity, fmt.Sprintf("Prohibited TLS 1.2 Cipher Suite: %x", sc.tlsState.CipherSuite)) - return - } - } - - if hook := testHookGetServerConn; hook != nil { - hook(sc) - } - sc.serve() -} - -func (sc *serverConn) rejectConn(err ErrCode, debug string) { - sc.vlogf("http2: server rejecting conn: %v, %s", err, debug) - // ignoring errors. hanging up anyway. - sc.framer.WriteGoAway(0, err, []byte(debug)) - sc.bw.Flush() - sc.conn.Close() -} - -type serverConn struct { - // Immutable: - srv *Server - hs *http.Server - conn net.Conn - bw *bufferedWriter // writing to conn - handler http.Handler - baseCtx contextContext - framer *Framer - doneServing chan struct{} // closed when serverConn.serve ends - readFrameCh chan readFrameResult // written by serverConn.readFrames - wantWriteFrameCh chan frameWriteMsg // from handlers -> serve - wroteFrameCh chan frameWriteResult // from writeFrameAsync -> serve, tickles more frame writes - bodyReadCh chan bodyReadMsg // from handlers -> serve - testHookCh chan func(int) // code to run on the serve loop - flow flow // conn-wide (not stream-specific) outbound flow control - inflow flow // conn-wide inbound flow control - tlsState *tls.ConnectionState // shared by all handlers, like net/http - remoteAddrStr string - - // Everything following is owned by the serve loop; use serveG.check(): - serveG goroutineLock // used to verify funcs are on serve() - pushEnabled bool - sawFirstSettings bool // got the initial SETTINGS frame after the preface - needToSendSettingsAck bool - unackedSettings int // how many SETTINGS have we sent without ACKs? - clientMaxStreams uint32 // SETTINGS_MAX_CONCURRENT_STREAMS from client (our PUSH_PROMISE limit) - advMaxStreams uint32 // our SETTINGS_MAX_CONCURRENT_STREAMS advertised the client - curOpenStreams uint32 // client's number of open streams - maxStreamID uint32 // max ever seen - streams map[uint32]*stream - initialWindowSize int32 - headerTableSize uint32 - peerMaxHeaderListSize uint32 // zero means unknown (default) - canonHeader map[string]string // http2-lower-case -> Go-Canonical-Case - writingFrame bool // started write goroutine but haven't heard back on wroteFrameCh - needsFrameFlush bool // last frame write wasn't a flush - writeSched writeScheduler - inGoAway bool // we've started to or sent GOAWAY - needToSendGoAway bool // we need to schedule a GOAWAY frame write - goAwayCode ErrCode - shutdownTimerCh <-chan time.Time // nil until used - shutdownTimer *time.Timer // nil until used - freeRequestBodyBuf []byte // if non-nil, a free initialWindowSize buffer for getRequestBodyBuf - - // Owned by the writeFrameAsync goroutine: - headerWriteBuf bytes.Buffer - hpackEncoder *hpack.Encoder -} - -func (sc *serverConn) maxHeaderListSize() uint32 { - n := sc.hs.MaxHeaderBytes - if n <= 0 { - n = http.DefaultMaxHeaderBytes - } - // http2's count is in a slightly different unit and includes 32 bytes per pair. - // So, take the net/http.Server value and pad it up a bit, assuming 10 headers. - const perFieldOverhead = 32 // per http2 spec - const typicalHeaders = 10 // conservative - return uint32(n + typicalHeaders*perFieldOverhead) -} - -// stream represents a stream. This is the minimal metadata needed by -// the serve goroutine. Most of the actual stream state is owned by -// the http.Handler's goroutine in the responseWriter. Because the -// responseWriter's responseWriterState is recycled at the end of a -// handler, this struct intentionally has no pointer to the -// *responseWriter{,State} itself, as the Handler ending nils out the -// responseWriter's state field. -type stream struct { - // immutable: - sc *serverConn - id uint32 - body *pipe // non-nil if expecting DATA frames - cw closeWaiter // closed wait stream transitions to closed state - ctx contextContext - cancelCtx func() - - // owned by serverConn's serve loop: - bodyBytes int64 // body bytes seen so far - declBodyBytes int64 // or -1 if undeclared - flow flow // limits writing from Handler to client - inflow flow // what the client is allowed to POST/etc to us - parent *stream // or nil - numTrailerValues int64 - weight uint8 - state streamState - sentReset bool // only true once detached from streams map - gotReset bool // only true once detacted from streams map - gotTrailerHeader bool // HEADER frame for trailers was seen - wroteHeaders bool // whether we wrote headers (not status 100) - reqBuf []byte - - trailer http.Header // accumulated trailers - reqTrailer http.Header // handler's Request.Trailer -} - -func (sc *serverConn) Framer() *Framer { return sc.framer } -func (sc *serverConn) CloseConn() error { return sc.conn.Close() } -func (sc *serverConn) Flush() error { return sc.bw.Flush() } -func (sc *serverConn) HeaderEncoder() (*hpack.Encoder, *bytes.Buffer) { - return sc.hpackEncoder, &sc.headerWriteBuf -} - -func (sc *serverConn) state(streamID uint32) (streamState, *stream) { - sc.serveG.check() - // http://http2.github.io/http2-spec/#rfc.section.5.1 - if st, ok := sc.streams[streamID]; ok { - return st.state, st - } - // "The first use of a new stream identifier implicitly closes all - // streams in the "idle" state that might have been initiated by - // that peer with a lower-valued stream identifier. For example, if - // a client sends a HEADERS frame on stream 7 without ever sending a - // frame on stream 5, then stream 5 transitions to the "closed" - // state when the first frame for stream 7 is sent or received." - if streamID <= sc.maxStreamID { - return stateClosed, nil - } - return stateIdle, nil -} - -// setConnState calls the net/http ConnState hook for this connection, if configured. -// Note that the net/http package does StateNew and StateClosed for us. -// There is currently no plan for StateHijacked or hijacking HTTP/2 connections. -func (sc *serverConn) setConnState(state http.ConnState) { - if sc.hs.ConnState != nil { - sc.hs.ConnState(sc.conn, state) - } -} - -func (sc *serverConn) vlogf(format string, args ...interface{}) { - if VerboseLogs { - sc.logf(format, args...) - } -} - -func (sc *serverConn) logf(format string, args ...interface{}) { - if lg := sc.hs.ErrorLog; lg != nil { - lg.Printf(format, args...) - } else { - log.Printf(format, args...) - } -} - -// errno returns v's underlying uintptr, else 0. -// -// TODO: remove this helper function once http2 can use build -// tags. See comment in isClosedConnError. -func errno(v error) uintptr { - if rv := reflect.ValueOf(v); rv.Kind() == reflect.Uintptr { - return uintptr(rv.Uint()) - } - return 0 -} - -// isClosedConnError reports whether err is an error from use of a closed -// network connection. -func isClosedConnError(err error) bool { - if err == nil { - return false - } - - // TODO: remove this string search and be more like the Windows - // case below. That might involve modifying the standard library - // to return better error types. - str := err.Error() - if strings.Contains(str, "use of closed network connection") { - return true - } - - // TODO(bradfitz): x/tools/cmd/bundle doesn't really support - // build tags, so I can't make an http2_windows.go file with - // Windows-specific stuff. Fix that and move this, once we - // have a way to bundle this into std's net/http somehow. - if runtime.GOOS == "windows" { - if oe, ok := err.(*net.OpError); ok && oe.Op == "read" { - if se, ok := oe.Err.(*os.SyscallError); ok && se.Syscall == "wsarecv" { - const WSAECONNABORTED = 10053 - const WSAECONNRESET = 10054 - if n := errno(se.Err); n == WSAECONNRESET || n == WSAECONNABORTED { - return true - } - } - } - } - return false -} - -func (sc *serverConn) condlogf(err error, format string, args ...interface{}) { - if err == nil { - return - } - if err == io.EOF || err == io.ErrUnexpectedEOF || isClosedConnError(err) { - // Boring, expected errors. - sc.vlogf(format, args...) - } else { - sc.logf(format, args...) - } -} - -func (sc *serverConn) canonicalHeader(v string) string { - sc.serveG.check() - cv, ok := commonCanonHeader[v] - if ok { - return cv - } - cv, ok = sc.canonHeader[v] - if ok { - return cv - } - if sc.canonHeader == nil { - sc.canonHeader = make(map[string]string) - } - cv = http.CanonicalHeaderKey(v) - sc.canonHeader[v] = cv - return cv -} - -type readFrameResult struct { - f Frame // valid until readMore is called - err error - - // readMore should be called once the consumer no longer needs or - // retains f. After readMore, f is invalid and more frames can be - // read. - readMore func() -} - -// readFrames is the loop that reads incoming frames. -// It takes care to only read one frame at a time, blocking until the -// consumer is done with the frame. -// It's run on its own goroutine. -func (sc *serverConn) readFrames() { - gate := make(gate) - gateDone := gate.Done - for { - f, err := sc.framer.ReadFrame() - select { - case sc.readFrameCh <- readFrameResult{f, err, gateDone}: - case <-sc.doneServing: - return - } - select { - case <-gate: - case <-sc.doneServing: - return - } - if terminalReadFrameError(err) { - return - } - } -} - -// frameWriteResult is the message passed from writeFrameAsync to the serve goroutine. -type frameWriteResult struct { - wm frameWriteMsg // what was written (or attempted) - err error // result of the writeFrame call -} - -// writeFrameAsync runs in its own goroutine and writes a single frame -// and then reports when it's done. -// At most one goroutine can be running writeFrameAsync at a time per -// serverConn. -func (sc *serverConn) writeFrameAsync(wm frameWriteMsg) { - err := wm.write.writeFrame(sc) - sc.wroteFrameCh <- frameWriteResult{wm, err} -} - -func (sc *serverConn) closeAllStreamsOnConnClose() { - sc.serveG.check() - for _, st := range sc.streams { - sc.closeStream(st, errClientDisconnected) - } -} - -func (sc *serverConn) stopShutdownTimer() { - sc.serveG.check() - if t := sc.shutdownTimer; t != nil { - t.Stop() - } -} - -func (sc *serverConn) notePanic() { - // Note: this is for serverConn.serve panicking, not http.Handler code. - if testHookOnPanicMu != nil { - testHookOnPanicMu.Lock() - defer testHookOnPanicMu.Unlock() - } - if testHookOnPanic != nil { - if e := recover(); e != nil { - if testHookOnPanic(sc, e) { - panic(e) - } - } - } -} - -func (sc *serverConn) serve() { - sc.serveG.check() - defer sc.notePanic() - defer sc.conn.Close() - defer sc.closeAllStreamsOnConnClose() - defer sc.stopShutdownTimer() - defer close(sc.doneServing) // unblocks handlers trying to send - - if VerboseLogs { - sc.vlogf("http2: server connection from %v on %p", sc.conn.RemoteAddr(), sc.hs) - } - - sc.writeFrame(frameWriteMsg{ - write: writeSettings{ - {SettingMaxFrameSize, sc.srv.maxReadFrameSize()}, - {SettingMaxConcurrentStreams, sc.advMaxStreams}, - {SettingMaxHeaderListSize, sc.maxHeaderListSize()}, - - // TODO: more actual settings, notably - // SettingInitialWindowSize, but then we also - // want to bump up the conn window size the - // same amount here right after the settings - }, - }) - sc.unackedSettings++ - - if err := sc.readPreface(); err != nil { - sc.condlogf(err, "http2: server: error reading preface from client %v: %v", sc.conn.RemoteAddr(), err) - return - } - // Now that we've got the preface, get us out of the - // "StateNew" state. We can't go directly to idle, though. - // Active means we read some data and anticipate a request. We'll - // do another Active when we get a HEADERS frame. - sc.setConnState(http.StateActive) - sc.setConnState(http.StateIdle) - - go sc.readFrames() // closed by defer sc.conn.Close above - - settingsTimer := time.NewTimer(firstSettingsTimeout) - loopNum := 0 - for { - loopNum++ - select { - case wm := <-sc.wantWriteFrameCh: - sc.writeFrame(wm) - case res := <-sc.wroteFrameCh: - sc.wroteFrame(res) - case res := <-sc.readFrameCh: - if !sc.processFrameFromReader(res) { - return - } - res.readMore() - if settingsTimer.C != nil { - settingsTimer.Stop() - settingsTimer.C = nil - } - case m := <-sc.bodyReadCh: - sc.noteBodyRead(m.st, m.n) - case <-settingsTimer.C: - sc.logf("timeout waiting for SETTINGS frames from %v", sc.conn.RemoteAddr()) - return - case <-sc.shutdownTimerCh: - sc.vlogf("GOAWAY close timer fired; closing conn from %v", sc.conn.RemoteAddr()) - return - case fn := <-sc.testHookCh: - fn(loopNum) - } - } -} - -// readPreface reads the ClientPreface greeting from the peer -// or returns an error on timeout or an invalid greeting. -func (sc *serverConn) readPreface() error { - errc := make(chan error, 1) - go func() { - // Read the client preface - buf := make([]byte, len(ClientPreface)) - if _, err := io.ReadFull(sc.conn, buf); err != nil { - errc <- err - } else if !bytes.Equal(buf, clientPreface) { - errc <- fmt.Errorf("bogus greeting %q", buf) - } else { - errc <- nil - } - }() - timer := time.NewTimer(prefaceTimeout) // TODO: configurable on *Server? - defer timer.Stop() - select { - case <-timer.C: - return errors.New("timeout waiting for client preface") - case err := <-errc: - if err == nil { - if VerboseLogs { - sc.vlogf("http2: server: client %v said hello", sc.conn.RemoteAddr()) - } - } - return err - } -} - -var errChanPool = sync.Pool{ - New: func() interface{} { return make(chan error, 1) }, -} - -var writeDataPool = sync.Pool{ - New: func() interface{} { return new(writeData) }, -} - -// writeDataFromHandler writes DATA response frames from a handler on -// the given stream. -func (sc *serverConn) writeDataFromHandler(stream *stream, data []byte, endStream bool) error { - ch := errChanPool.Get().(chan error) - writeArg := writeDataPool.Get().(*writeData) - *writeArg = writeData{stream.id, data, endStream} - err := sc.writeFrameFromHandler(frameWriteMsg{ - write: writeArg, - stream: stream, - done: ch, - }) - if err != nil { - return err - } - var frameWriteDone bool // the frame write is done (successfully or not) - select { - case err = <-ch: - frameWriteDone = true - case <-sc.doneServing: - return errClientDisconnected - case <-stream.cw: - // If both ch and stream.cw were ready (as might - // happen on the final Write after an http.Handler - // ends), prefer the write result. Otherwise this - // might just be us successfully closing the stream. - // The writeFrameAsync and serve goroutines guarantee - // that the ch send will happen before the stream.cw - // close. - select { - case err = <-ch: - frameWriteDone = true - default: - return errStreamClosed - } - } - errChanPool.Put(ch) - if frameWriteDone { - writeDataPool.Put(writeArg) - } - return err -} - -// writeFrameFromHandler sends wm to sc.wantWriteFrameCh, but aborts -// if the connection has gone away. -// -// This must not be run from the serve goroutine itself, else it might -// deadlock writing to sc.wantWriteFrameCh (which is only mildly -// buffered and is read by serve itself). If you're on the serve -// goroutine, call writeFrame instead. -func (sc *serverConn) writeFrameFromHandler(wm frameWriteMsg) error { - sc.serveG.checkNotOn() // NOT - select { - case sc.wantWriteFrameCh <- wm: - return nil - case <-sc.doneServing: - // Serve loop is gone. - // Client has closed their connection to the server. - return errClientDisconnected - } -} - -// writeFrame schedules a frame to write and sends it if there's nothing -// already being written. -// -// There is no pushback here (the serve goroutine never blocks). It's -// the http.Handlers that block, waiting for their previous frames to -// make it onto the wire -// -// If you're not on the serve goroutine, use writeFrameFromHandler instead. -func (sc *serverConn) writeFrame(wm frameWriteMsg) { - sc.serveG.check() - - var ignoreWrite bool - - // Don't send a 100-continue response if we've already sent headers. - // See golang.org/issue/14030. - switch wm.write.(type) { - case *writeResHeaders: - wm.stream.wroteHeaders = true - case write100ContinueHeadersFrame: - if wm.stream.wroteHeaders { - ignoreWrite = true - } - } - - if !ignoreWrite { - sc.writeSched.add(wm) - } - sc.scheduleFrameWrite() -} - -// startFrameWrite starts a goroutine to write wm (in a separate -// goroutine since that might block on the network), and updates the -// serve goroutine's state about the world, updated from info in wm. -func (sc *serverConn) startFrameWrite(wm frameWriteMsg) { - sc.serveG.check() - if sc.writingFrame { - panic("internal error: can only be writing one frame at a time") - } - - st := wm.stream - if st != nil { - switch st.state { - case stateHalfClosedLocal: - panic("internal error: attempt to send frame on half-closed-local stream") - case stateClosed: - if st.sentReset || st.gotReset { - // Skip this frame. - sc.scheduleFrameWrite() - return - } - panic(fmt.Sprintf("internal error: attempt to send a write %v on a closed stream", wm)) - } - } - - sc.writingFrame = true - sc.needsFrameFlush = true - go sc.writeFrameAsync(wm) -} - -// errHandlerPanicked is the error given to any callers blocked in a read from -// Request.Body when the main goroutine panics. Since most handlers read in the -// the main ServeHTTP goroutine, this will show up rarely. -var errHandlerPanicked = errors.New("http2: handler panicked") - -// wroteFrame is called on the serve goroutine with the result of -// whatever happened on writeFrameAsync. -func (sc *serverConn) wroteFrame(res frameWriteResult) { - sc.serveG.check() - if !sc.writingFrame { - panic("internal error: expected to be already writing a frame") - } - sc.writingFrame = false - - wm := res.wm - st := wm.stream - - closeStream := endsStream(wm.write) - - if _, ok := wm.write.(handlerPanicRST); ok { - sc.closeStream(st, errHandlerPanicked) - } - - // Reply (if requested) to the blocked ServeHTTP goroutine. - if ch := wm.done; ch != nil { - select { - case ch <- res.err: - default: - panic(fmt.Sprintf("unbuffered done channel passed in for type %T", wm.write)) - } - } - wm.write = nil // prevent use (assume it's tainted after wm.done send) - - if closeStream { - if st == nil { - panic("internal error: expecting non-nil stream") - } - switch st.state { - case stateOpen: - // Here we would go to stateHalfClosedLocal in - // theory, but since our handler is done and - // the net/http package provides no mechanism - // for finishing writing to a ResponseWriter - // while still reading data (see possible TODO - // at top of this file), we go into closed - // state here anyway, after telling the peer - // we're hanging up on them. - st.state = stateHalfClosedLocal // won't last long, but necessary for closeStream via resetStream - errCancel := StreamError{st.id, ErrCodeCancel} - sc.resetStream(errCancel) - case stateHalfClosedRemote: - sc.closeStream(st, errHandlerComplete) - } - } - - sc.scheduleFrameWrite() -} - -// scheduleFrameWrite tickles the frame writing scheduler. -// -// If a frame is already being written, nothing happens. This will be called again -// when the frame is done being written. -// -// If a frame isn't being written we need to send one, the best frame -// to send is selected, preferring first things that aren't -// stream-specific (e.g. ACKing settings), and then finding the -// highest priority stream. -// -// If a frame isn't being written and there's nothing else to send, we -// flush the write buffer. -func (sc *serverConn) scheduleFrameWrite() { - sc.serveG.check() - if sc.writingFrame { - return - } - if sc.needToSendGoAway { - sc.needToSendGoAway = false - sc.startFrameWrite(frameWriteMsg{ - write: &writeGoAway{ - maxStreamID: sc.maxStreamID, - code: sc.goAwayCode, - }, - }) - return - } - if sc.needToSendSettingsAck { - sc.needToSendSettingsAck = false - sc.startFrameWrite(frameWriteMsg{write: writeSettingsAck{}}) - return - } - if !sc.inGoAway { - if wm, ok := sc.writeSched.take(); ok { - sc.startFrameWrite(wm) - return - } - } - if sc.needsFrameFlush { - sc.startFrameWrite(frameWriteMsg{write: flushFrameWriter{}}) - sc.needsFrameFlush = false // after startFrameWrite, since it sets this true - return - } -} - -func (sc *serverConn) goAway(code ErrCode) { - sc.serveG.check() - if sc.inGoAway { - return - } - if code != ErrCodeNo { - sc.shutDownIn(250 * time.Millisecond) - } else { - // TODO: configurable - sc.shutDownIn(1 * time.Second) - } - sc.inGoAway = true - sc.needToSendGoAway = true - sc.goAwayCode = code - sc.scheduleFrameWrite() -} - -func (sc *serverConn) shutDownIn(d time.Duration) { - sc.serveG.check() - sc.shutdownTimer = time.NewTimer(d) - sc.shutdownTimerCh = sc.shutdownTimer.C -} - -func (sc *serverConn) resetStream(se StreamError) { - sc.serveG.check() - sc.writeFrame(frameWriteMsg{write: se}) - if st, ok := sc.streams[se.StreamID]; ok { - st.sentReset = true - sc.closeStream(st, se) - } -} - -// processFrameFromReader processes the serve loop's read from readFrameCh from the -// frame-reading goroutine. -// processFrameFromReader returns whether the connection should be kept open. -func (sc *serverConn) processFrameFromReader(res readFrameResult) bool { - sc.serveG.check() - err := res.err - if err != nil { - if err == ErrFrameTooLarge { - sc.goAway(ErrCodeFrameSize) - return true // goAway will close the loop - } - clientGone := err == io.EOF || err == io.ErrUnexpectedEOF || isClosedConnError(err) - if clientGone { - // TODO: could we also get into this state if - // the peer does a half close - // (e.g. CloseWrite) because they're done - // sending frames but they're still wanting - // our open replies? Investigate. - // TODO: add CloseWrite to crypto/tls.Conn first - // so we have a way to test this? I suppose - // just for testing we could have a non-TLS mode. - return false - } - } else { - f := res.f - if VerboseLogs { - sc.vlogf("http2: server read frame %v", summarizeFrame(f)) - } - err = sc.processFrame(f) - if err == nil { - return true - } - } - - switch ev := err.(type) { - case StreamError: - sc.resetStream(ev) - return true - case goAwayFlowError: - sc.goAway(ErrCodeFlowControl) - return true - case ConnectionError: - sc.logf("http2: server connection error from %v: %v", sc.conn.RemoteAddr(), ev) - sc.goAway(ErrCode(ev)) - return true // goAway will handle shutdown - default: - if res.err != nil { - sc.vlogf("http2: server closing client connection; error reading frame from client %s: %v", sc.conn.RemoteAddr(), err) - } else { - sc.logf("http2: server closing client connection: %v", err) - } - return false - } -} - -func (sc *serverConn) processFrame(f Frame) error { - sc.serveG.check() - - // First frame received must be SETTINGS. - if !sc.sawFirstSettings { - if _, ok := f.(*SettingsFrame); !ok { - return ConnectionError(ErrCodeProtocol) - } - sc.sawFirstSettings = true - } - - switch f := f.(type) { - case *SettingsFrame: - return sc.processSettings(f) - case *MetaHeadersFrame: - return sc.processHeaders(f) - case *WindowUpdateFrame: - return sc.processWindowUpdate(f) - case *PingFrame: - return sc.processPing(f) - case *DataFrame: - return sc.processData(f) - case *RSTStreamFrame: - return sc.processResetStream(f) - case *PriorityFrame: - return sc.processPriority(f) - case *PushPromiseFrame: - // A client cannot push. Thus, servers MUST treat the receipt of a PUSH_PROMISE - // frame as a connection error (Section 5.4.1) of type PROTOCOL_ERROR. - return ConnectionError(ErrCodeProtocol) - default: - sc.vlogf("http2: server ignoring frame: %v", f.Header()) - return nil - } -} - -func (sc *serverConn) processPing(f *PingFrame) error { - sc.serveG.check() - if f.IsAck() { - // 6.7 PING: " An endpoint MUST NOT respond to PING frames - // containing this flag." - return nil - } - if f.StreamID != 0 { - // "PING frames are not associated with any individual - // stream. If a PING frame is received with a stream - // identifier field value other than 0x0, the recipient MUST - // respond with a connection error (Section 5.4.1) of type - // PROTOCOL_ERROR." - return ConnectionError(ErrCodeProtocol) - } - sc.writeFrame(frameWriteMsg{write: writePingAck{f}}) - return nil -} - -func (sc *serverConn) processWindowUpdate(f *WindowUpdateFrame) error { - sc.serveG.check() - switch { - case f.StreamID != 0: // stream-level flow control - st := sc.streams[f.StreamID] - if st == nil { - // "WINDOW_UPDATE can be sent by a peer that has sent a - // frame bearing the END_STREAM flag. This means that a - // receiver could receive a WINDOW_UPDATE frame on a "half - // closed (remote)" or "closed" stream. A receiver MUST - // NOT treat this as an error, see Section 5.1." - return nil - } - if !st.flow.add(int32(f.Increment)) { - return StreamError{f.StreamID, ErrCodeFlowControl} - } - default: // connection-level flow control - if !sc.flow.add(int32(f.Increment)) { - return goAwayFlowError{} - } - } - sc.scheduleFrameWrite() - return nil -} - -func (sc *serverConn) processResetStream(f *RSTStreamFrame) error { - sc.serveG.check() - - state, st := sc.state(f.StreamID) - if state == stateIdle { - // 6.4 "RST_STREAM frames MUST NOT be sent for a - // stream in the "idle" state. If a RST_STREAM frame - // identifying an idle stream is received, the - // recipient MUST treat this as a connection error - // (Section 5.4.1) of type PROTOCOL_ERROR. - return ConnectionError(ErrCodeProtocol) - } - if st != nil { - st.gotReset = true - st.cancelCtx() - sc.closeStream(st, StreamError{f.StreamID, f.ErrCode}) - } - return nil -} - -func (sc *serverConn) closeStream(st *stream, err error) { - sc.serveG.check() - if st.state == stateIdle || st.state == stateClosed { - panic(fmt.Sprintf("invariant; can't close stream in state %v", st.state)) - } - st.state = stateClosed - sc.curOpenStreams-- - if sc.curOpenStreams == 0 { - sc.setConnState(http.StateIdle) - } - delete(sc.streams, st.id) - if p := st.body; p != nil { - p.CloseWithError(err) - } - st.cw.Close() // signals Handler's CloseNotifier, unblocks writes, etc - sc.writeSched.forgetStream(st.id) - if st.reqBuf != nil { - // Stash this request body buffer (64k) away for reuse - // by a future POST/PUT/etc. - // - // TODO(bradfitz): share on the server? sync.Pool? - // Server requires locks and might hurt contention. - // sync.Pool might work, or might be worse, depending - // on goroutine CPU migrations. (get and put on - // separate CPUs). Maybe a mix of strategies. But - // this is an easy win for now. - sc.freeRequestBodyBuf = st.reqBuf - } -} - -func (sc *serverConn) processSettings(f *SettingsFrame) error { - sc.serveG.check() - if f.IsAck() { - sc.unackedSettings-- - if sc.unackedSettings < 0 { - // Why is the peer ACKing settings we never sent? - // The spec doesn't mention this case, but - // hang up on them anyway. - return ConnectionError(ErrCodeProtocol) - } - return nil - } - if err := f.ForeachSetting(sc.processSetting); err != nil { - return err - } - sc.needToSendSettingsAck = true - sc.scheduleFrameWrite() - return nil -} - -func (sc *serverConn) processSetting(s Setting) error { - sc.serveG.check() - if err := s.Valid(); err != nil { - return err - } - if VerboseLogs { - sc.vlogf("http2: server processing setting %v", s) - } - switch s.ID { - case SettingHeaderTableSize: - sc.headerTableSize = s.Val - sc.hpackEncoder.SetMaxDynamicTableSize(s.Val) - case SettingEnablePush: - sc.pushEnabled = s.Val != 0 - case SettingMaxConcurrentStreams: - sc.clientMaxStreams = s.Val - case SettingInitialWindowSize: - return sc.processSettingInitialWindowSize(s.Val) - case SettingMaxFrameSize: - sc.writeSched.maxFrameSize = s.Val - case SettingMaxHeaderListSize: - sc.peerMaxHeaderListSize = s.Val - default: - // Unknown setting: "An endpoint that receives a SETTINGS - // frame with any unknown or unsupported identifier MUST - // ignore that setting." - if VerboseLogs { - sc.vlogf("http2: server ignoring unknown setting %v", s) - } - } - return nil -} - -func (sc *serverConn) processSettingInitialWindowSize(val uint32) error { - sc.serveG.check() - // Note: val already validated to be within range by - // processSetting's Valid call. - - // "A SETTINGS frame can alter the initial flow control window - // size for all current streams. When the value of - // SETTINGS_INITIAL_WINDOW_SIZE changes, a receiver MUST - // adjust the size of all stream flow control windows that it - // maintains by the difference between the new value and the - // old value." - old := sc.initialWindowSize - sc.initialWindowSize = int32(val) - growth := sc.initialWindowSize - old // may be negative - for _, st := range sc.streams { - if !st.flow.add(growth) { - // 6.9.2 Initial Flow Control Window Size - // "An endpoint MUST treat a change to - // SETTINGS_INITIAL_WINDOW_SIZE that causes any flow - // control window to exceed the maximum size as a - // connection error (Section 5.4.1) of type - // FLOW_CONTROL_ERROR." - return ConnectionError(ErrCodeFlowControl) - } - } - return nil -} - -func (sc *serverConn) processData(f *DataFrame) error { - sc.serveG.check() - // "If a DATA frame is received whose stream is not in "open" - // or "half closed (local)" state, the recipient MUST respond - // with a stream error (Section 5.4.2) of type STREAM_CLOSED." - id := f.Header().StreamID - st, ok := sc.streams[id] - if !ok || st.state != stateOpen || st.gotTrailerHeader { - // This includes sending a RST_STREAM if the stream is - // in stateHalfClosedLocal (which currently means that - // the http.Handler returned, so it's done reading & - // done writing). Try to stop the client from sending - // more DATA. - return StreamError{id, ErrCodeStreamClosed} - } - if st.body == nil { - panic("internal error: should have a body in this state") - } - data := f.Data() - - // Sender sending more than they'd declared? - if st.declBodyBytes != -1 && st.bodyBytes+int64(len(data)) > st.declBodyBytes { - st.body.CloseWithError(fmt.Errorf("sender tried to send more than declared Content-Length of %d bytes", st.declBodyBytes)) - return StreamError{id, ErrCodeStreamClosed} - } - if len(data) > 0 { - // Check whether the client has flow control quota. - if int(st.inflow.available()) < len(data) { - return StreamError{id, ErrCodeFlowControl} - } - st.inflow.take(int32(len(data))) - wrote, err := st.body.Write(data) - if err != nil { - return StreamError{id, ErrCodeStreamClosed} - } - if wrote != len(data) { - panic("internal error: bad Writer") - } - st.bodyBytes += int64(len(data)) - } - if f.StreamEnded() { - st.endStream() - } - return nil -} - -// endStream closes a Request.Body's pipe. It is called when a DATA -// frame says a request body is over (or after trailers). -func (st *stream) endStream() { - sc := st.sc - sc.serveG.check() - - if st.declBodyBytes != -1 && st.declBodyBytes != st.bodyBytes { - st.body.CloseWithError(fmt.Errorf("request declared a Content-Length of %d but only wrote %d bytes", - st.declBodyBytes, st.bodyBytes)) - } else { - st.body.closeWithErrorAndCode(io.EOF, st.copyTrailersToHandlerRequest) - st.body.CloseWithError(io.EOF) - } - st.state = stateHalfClosedRemote -} - -// copyTrailersToHandlerRequest is run in the Handler's goroutine in -// its Request.Body.Read just before it gets io.EOF. -func (st *stream) copyTrailersToHandlerRequest() { - for k, vv := range st.trailer { - if _, ok := st.reqTrailer[k]; ok { - // Only copy it over it was pre-declared. - st.reqTrailer[k] = vv - } - } -} - -func (sc *serverConn) processHeaders(f *MetaHeadersFrame) error { - sc.serveG.check() - id := f.Header().StreamID - if sc.inGoAway { - // Ignore. - return nil - } - // http://http2.github.io/http2-spec/#rfc.section.5.1.1 - // Streams initiated by a client MUST use odd-numbered stream - // identifiers. [...] An endpoint that receives an unexpected - // stream identifier MUST respond with a connection error - // (Section 5.4.1) of type PROTOCOL_ERROR. - if id%2 != 1 { - return ConnectionError(ErrCodeProtocol) - } - // A HEADERS frame can be used to create a new stream or - // send a trailer for an open one. If we already have a stream - // open, let it process its own HEADERS frame (trailers at this - // point, if it's valid). - st := sc.streams[f.Header().StreamID] - if st != nil { - return st.processTrailerHeaders(f) - } - - // [...] The identifier of a newly established stream MUST be - // numerically greater than all streams that the initiating - // endpoint has opened or reserved. [...] An endpoint that - // receives an unexpected stream identifier MUST respond with - // a connection error (Section 5.4.1) of type PROTOCOL_ERROR. - if id <= sc.maxStreamID { - return ConnectionError(ErrCodeProtocol) - } - sc.maxStreamID = id - - ctx, cancelCtx := contextWithCancel(sc.baseCtx) - st = &stream{ - sc: sc, - id: id, - state: stateOpen, - ctx: ctx, - cancelCtx: cancelCtx, - } - if f.StreamEnded() { - st.state = stateHalfClosedRemote - } - st.cw.Init() - - st.flow.conn = &sc.flow // link to conn-level counter - st.flow.add(sc.initialWindowSize) - st.inflow.conn = &sc.inflow // link to conn-level counter - st.inflow.add(initialWindowSize) // TODO: update this when we send a higher initial window size in the initial settings - - sc.streams[id] = st - if f.HasPriority() { - adjustStreamPriority(sc.streams, st.id, f.Priority) - } - sc.curOpenStreams++ - if sc.curOpenStreams == 1 { - sc.setConnState(http.StateActive) - } - if sc.curOpenStreams > sc.advMaxStreams { - // "Endpoints MUST NOT exceed the limit set by their - // peer. An endpoint that receives a HEADERS frame - // that causes their advertised concurrent stream - // limit to be exceeded MUST treat this as a stream - // error (Section 5.4.2) of type PROTOCOL_ERROR or - // REFUSED_STREAM." - if sc.unackedSettings == 0 { - // They should know better. - return StreamError{st.id, ErrCodeProtocol} - } - // Assume it's a network race, where they just haven't - // received our last SETTINGS update. But actually - // this can't happen yet, because we don't yet provide - // a way for users to adjust server parameters at - // runtime. - return StreamError{st.id, ErrCodeRefusedStream} - } - - rw, req, err := sc.newWriterAndRequest(st, f) - if err != nil { - return err - } - st.reqTrailer = req.Trailer - if st.reqTrailer != nil { - st.trailer = make(http.Header) - } - st.body = req.Body.(*requestBody).pipe // may be nil - st.declBodyBytes = req.ContentLength - - handler := sc.handler.ServeHTTP - if f.Truncated { - // Their header list was too long. Send a 431 error. - handler = handleHeaderListTooLong - } else if err := checkValidHTTP2Request(req); err != nil { - handler = new400Handler(err) - } - - go sc.runHandler(rw, req, handler) - return nil -} - -func (st *stream) processTrailerHeaders(f *MetaHeadersFrame) error { - sc := st.sc - sc.serveG.check() - if st.gotTrailerHeader { - return ConnectionError(ErrCodeProtocol) - } - st.gotTrailerHeader = true - if !f.StreamEnded() { - return StreamError{st.id, ErrCodeProtocol} - } - - if len(f.PseudoFields()) > 0 { - return StreamError{st.id, ErrCodeProtocol} - } - if st.trailer != nil { - for _, hf := range f.RegularFields() { - key := sc.canonicalHeader(hf.Name) - if !ValidTrailerHeader(key) { - // TODO: send more details to the peer somehow. But http2 has - // no way to send debug data at a stream level. Discuss with - // HTTP folk. - return StreamError{st.id, ErrCodeProtocol} - } - st.trailer[key] = append(st.trailer[key], hf.Value) - } - } - st.endStream() - return nil -} - -func (sc *serverConn) processPriority(f *PriorityFrame) error { - adjustStreamPriority(sc.streams, f.StreamID, f.PriorityParam) - return nil -} - -func adjustStreamPriority(streams map[uint32]*stream, streamID uint32, priority PriorityParam) { - st, ok := streams[streamID] - if !ok { - // TODO: not quite correct (this streamID might - // already exist in the dep tree, but be closed), but - // close enough for now. - return - } - st.weight = priority.Weight - parent := streams[priority.StreamDep] // might be nil - if parent == st { - // if client tries to set this stream to be the parent of itself - // ignore and keep going - return - } - - // section 5.3.3: If a stream is made dependent on one of its - // own dependencies, the formerly dependent stream is first - // moved to be dependent on the reprioritized stream's previous - // parent. The moved dependency retains its weight. - for piter := parent; piter != nil; piter = piter.parent { - if piter == st { - parent.parent = st.parent - break - } - } - st.parent = parent - if priority.Exclusive && (st.parent != nil || priority.StreamDep == 0) { - for _, openStream := range streams { - if openStream != st && openStream.parent == st.parent { - openStream.parent = st - } - } - } -} - -func (sc *serverConn) newWriterAndRequest(st *stream, f *MetaHeadersFrame) (*responseWriter, *http.Request, error) { - sc.serveG.check() - - method := f.PseudoValue("method") - path := f.PseudoValue("path") - scheme := f.PseudoValue("scheme") - authority := f.PseudoValue("authority") - - isConnect := method == "CONNECT" - if isConnect { - if path != "" || scheme != "" || authority == "" { - return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} - } - } else if method == "" || path == "" || - (scheme != "https" && scheme != "http") { - // See 8.1.2.6 Malformed Requests and Responses: - // - // Malformed requests or responses that are detected - // MUST be treated as a stream error (Section 5.4.2) - // of type PROTOCOL_ERROR." - // - // 8.1.2.3 Request Pseudo-Header Fields - // "All HTTP/2 requests MUST include exactly one valid - // value for the :method, :scheme, and :path - // pseudo-header fields" - return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} - } - - bodyOpen := !f.StreamEnded() - if method == "HEAD" && bodyOpen { - // HEAD requests can't have bodies - return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} - } - var tlsState *tls.ConnectionState // nil if not scheme https - - if scheme == "https" { - tlsState = sc.tlsState - } - - header := make(http.Header) - for _, hf := range f.RegularFields() { - header.Add(sc.canonicalHeader(hf.Name), hf.Value) - } - - if authority == "" { - authority = header.Get("Host") - } - needsContinue := header.Get("Expect") == "100-continue" - if needsContinue { - header.Del("Expect") - } - // Merge Cookie headers into one "; "-delimited value. - if cookies := header["Cookie"]; len(cookies) > 1 { - header.Set("Cookie", strings.Join(cookies, "; ")) - } - - // Setup Trailers - var trailer http.Header - for _, v := range header["Trailer"] { - for _, key := range strings.Split(v, ",") { - key = http.CanonicalHeaderKey(strings.TrimSpace(key)) - switch key { - case "Transfer-Encoding", "Trailer", "Content-Length": - // Bogus. (copy of http1 rules) - // Ignore. - default: - if trailer == nil { - trailer = make(http.Header) - } - trailer[key] = nil - } - } - } - delete(header, "Trailer") - - body := &requestBody{ - conn: sc, - stream: st, - needsContinue: needsContinue, - } - var url_ *url.URL - var requestURI string - if isConnect { - url_ = &url.URL{Host: authority} - requestURI = authority // mimic HTTP/1 server behavior - } else { - var err error - url_, err = url.ParseRequestURI(path) - if err != nil { - return nil, nil, StreamError{f.StreamID, ErrCodeProtocol} - } - requestURI = path - } - req := &http.Request{ - Method: method, - URL: url_, - RemoteAddr: sc.remoteAddrStr, - Header: header, - RequestURI: requestURI, - Proto: "HTTP/2.0", - ProtoMajor: 2, - ProtoMinor: 0, - TLS: tlsState, - Host: authority, - Body: body, - Trailer: trailer, - } - req = requestWithContext(req, st.ctx) - if bodyOpen { - // Disabled, per golang.org/issue/14960: - // st.reqBuf = sc.getRequestBodyBuf() - // TODO: remove this 64k of garbage per request (again, but without a data race): - buf := make([]byte, initialWindowSize) - - body.pipe = &pipe{ - b: &fixedBuffer{buf: buf}, - } - - if vv, ok := header["Content-Length"]; ok { - req.ContentLength, _ = strconv.ParseInt(vv[0], 10, 64) - } else { - req.ContentLength = -1 - } - } - - rws := responseWriterStatePool.Get().(*responseWriterState) - bwSave := rws.bw - *rws = responseWriterState{} // zero all the fields - rws.conn = sc - rws.bw = bwSave - rws.bw.Reset(chunkWriter{rws}) - rws.stream = st - rws.req = req - rws.body = body - - rw := &responseWriter{rws: rws} - return rw, req, nil -} - -func (sc *serverConn) getRequestBodyBuf() []byte { - sc.serveG.check() - if buf := sc.freeRequestBodyBuf; buf != nil { - sc.freeRequestBodyBuf = nil - return buf - } - return make([]byte, initialWindowSize) -} - -// Run on its own goroutine. -func (sc *serverConn) runHandler(rw *responseWriter, req *http.Request, handler func(http.ResponseWriter, *http.Request)) { - didPanic := true - defer func() { - rw.rws.stream.cancelCtx() - if didPanic { - e := recover() - // Same as net/http: - const size = 64 << 10 - buf := make([]byte, size) - buf = buf[:runtime.Stack(buf, false)] - sc.writeFrameFromHandler(frameWriteMsg{ - write: handlerPanicRST{rw.rws.stream.id}, - stream: rw.rws.stream, - }) - sc.logf("http2: panic serving %v: %v\n%s", sc.conn.RemoteAddr(), e, buf) - return - } - rw.handlerDone() - }() - handler(rw, req) - didPanic = false -} - -func handleHeaderListTooLong(w http.ResponseWriter, r *http.Request) { - // 10.5.1 Limits on Header Block Size: - // .. "A server that receives a larger header block than it is - // willing to handle can send an HTTP 431 (Request Header Fields Too - // Large) status code" - const statusRequestHeaderFieldsTooLarge = 431 // only in Go 1.6+ - w.WriteHeader(statusRequestHeaderFieldsTooLarge) - io.WriteString(w, "

    HTTP Error 431

    Request Header Field(s) Too Large

    ") -} - -// called from handler goroutines. -// h may be nil. -func (sc *serverConn) writeHeaders(st *stream, headerData *writeResHeaders) error { - sc.serveG.checkNotOn() // NOT on - var errc chan error - if headerData.h != nil { - // If there's a header map (which we don't own), so we have to block on - // waiting for this frame to be written, so an http.Flush mid-handler - // writes out the correct value of keys, before a handler later potentially - // mutates it. - errc = errChanPool.Get().(chan error) - } - if err := sc.writeFrameFromHandler(frameWriteMsg{ - write: headerData, - stream: st, - done: errc, - }); err != nil { - return err - } - if errc != nil { - select { - case err := <-errc: - errChanPool.Put(errc) - return err - case <-sc.doneServing: - return errClientDisconnected - case <-st.cw: - return errStreamClosed - } - } - return nil -} - -// called from handler goroutines. -func (sc *serverConn) write100ContinueHeaders(st *stream) { - sc.writeFrameFromHandler(frameWriteMsg{ - write: write100ContinueHeadersFrame{st.id}, - stream: st, - }) -} - -// A bodyReadMsg tells the server loop that the http.Handler read n -// bytes of the DATA from the client on the given stream. -type bodyReadMsg struct { - st *stream - n int -} - -// called from handler goroutines. -// Notes that the handler for the given stream ID read n bytes of its body -// and schedules flow control tokens to be sent. -func (sc *serverConn) noteBodyReadFromHandler(st *stream, n int) { - sc.serveG.checkNotOn() // NOT on - select { - case sc.bodyReadCh <- bodyReadMsg{st, n}: - case <-sc.doneServing: - } -} - -func (sc *serverConn) noteBodyRead(st *stream, n int) { - sc.serveG.check() - sc.sendWindowUpdate(nil, n) // conn-level - if st.state != stateHalfClosedRemote && st.state != stateClosed { - // Don't send this WINDOW_UPDATE if the stream is closed - // remotely. - sc.sendWindowUpdate(st, n) - } -} - -// st may be nil for conn-level -func (sc *serverConn) sendWindowUpdate(st *stream, n int) { - sc.serveG.check() - // "The legal range for the increment to the flow control - // window is 1 to 2^31-1 (2,147,483,647) octets." - // A Go Read call on 64-bit machines could in theory read - // a larger Read than this. Very unlikely, but we handle it here - // rather than elsewhere for now. - const maxUint31 = 1<<31 - 1 - for n >= maxUint31 { - sc.sendWindowUpdate32(st, maxUint31) - n -= maxUint31 - } - sc.sendWindowUpdate32(st, int32(n)) -} - -// st may be nil for conn-level -func (sc *serverConn) sendWindowUpdate32(st *stream, n int32) { - sc.serveG.check() - if n == 0 { - return - } - if n < 0 { - panic("negative update") - } - var streamID uint32 - if st != nil { - streamID = st.id - } - sc.writeFrame(frameWriteMsg{ - write: writeWindowUpdate{streamID: streamID, n: uint32(n)}, - stream: st, - }) - var ok bool - if st == nil { - ok = sc.inflow.add(n) - } else { - ok = st.inflow.add(n) - } - if !ok { - panic("internal error; sent too many window updates without decrements?") - } -} - -type requestBody struct { - stream *stream - conn *serverConn - closed bool - pipe *pipe // non-nil if we have a HTTP entity message body - needsContinue bool // need to send a 100-continue -} - -func (b *requestBody) Close() error { - if b.pipe != nil { - b.pipe.BreakWithError(errClosedBody) - } - b.closed = true - return nil -} - -func (b *requestBody) Read(p []byte) (n int, err error) { - if b.needsContinue { - b.needsContinue = false - b.conn.write100ContinueHeaders(b.stream) - } - if b.pipe == nil { - return 0, io.EOF - } - n, err = b.pipe.Read(p) - if n > 0 { - b.conn.noteBodyReadFromHandler(b.stream, n) - } - return -} - -// responseWriter is the http.ResponseWriter implementation. It's -// intentionally small (1 pointer wide) to minimize garbage. The -// responseWriterState pointer inside is zeroed at the end of a -// request (in handlerDone) and calls on the responseWriter thereafter -// simply crash (caller's mistake), but the much larger responseWriterState -// and buffers are reused between multiple requests. -type responseWriter struct { - rws *responseWriterState -} - -// Optional http.ResponseWriter interfaces implemented. -var ( - _ http.CloseNotifier = (*responseWriter)(nil) - _ http.Flusher = (*responseWriter)(nil) - _ stringWriter = (*responseWriter)(nil) -) - -type responseWriterState struct { - // immutable within a request: - stream *stream - req *http.Request - body *requestBody // to close at end of request, if DATA frames didn't - conn *serverConn - - // TODO: adjust buffer writing sizes based on server config, frame size updates from peer, etc - bw *bufio.Writer // writing to a chunkWriter{this *responseWriterState} - - // mutated by http.Handler goroutine: - handlerHeader http.Header // nil until called - snapHeader http.Header // snapshot of handlerHeader at WriteHeader time - trailers []string // set in writeChunk - status int // status code passed to WriteHeader - wroteHeader bool // WriteHeader called (explicitly or implicitly). Not necessarily sent to user yet. - sentHeader bool // have we sent the header frame? - handlerDone bool // handler has finished - - sentContentLen int64 // non-zero if handler set a Content-Length header - wroteBytes int64 - - closeNotifierMu sync.Mutex // guards closeNotifierCh - closeNotifierCh chan bool // nil until first used -} - -type chunkWriter struct{ rws *responseWriterState } - -func (cw chunkWriter) Write(p []byte) (n int, err error) { return cw.rws.writeChunk(p) } - -func (rws *responseWriterState) hasTrailers() bool { return len(rws.trailers) != 0 } - -// declareTrailer is called for each Trailer header when the -// response header is written. It notes that a header will need to be -// written in the trailers at the end of the response. -func (rws *responseWriterState) declareTrailer(k string) { - k = http.CanonicalHeaderKey(k) - if !ValidTrailerHeader(k) { - // Forbidden by RFC 2616 14.40. - rws.conn.logf("ignoring invalid trailer %q", k) - return - } - if !strSliceContains(rws.trailers, k) { - rws.trailers = append(rws.trailers, k) - } -} - -// writeChunk writes chunks from the bufio.Writer. But because -// bufio.Writer may bypass its chunking, sometimes p may be -// arbitrarily large. -// -// writeChunk is also responsible (on the first chunk) for sending the -// HEADER response. -func (rws *responseWriterState) writeChunk(p []byte) (n int, err error) { - if !rws.wroteHeader { - rws.writeHeader(200) - } - - isHeadResp := rws.req.Method == "HEAD" - if !rws.sentHeader { - rws.sentHeader = true - var ctype, clen string - if clen = rws.snapHeader.Get("Content-Length"); clen != "" { - rws.snapHeader.Del("Content-Length") - clen64, err := strconv.ParseInt(clen, 10, 64) - if err == nil && clen64 >= 0 { - rws.sentContentLen = clen64 - } else { - clen = "" - } - } - if clen == "" && rws.handlerDone && bodyAllowedForStatus(rws.status) && (len(p) > 0 || !isHeadResp) { - clen = strconv.Itoa(len(p)) - } - _, hasContentType := rws.snapHeader["Content-Type"] - if !hasContentType && bodyAllowedForStatus(rws.status) { - ctype = http.DetectContentType(p) - } - var date string - if _, ok := rws.snapHeader["Date"]; !ok { - // TODO(bradfitz): be faster here, like net/http? measure. - date = time.Now().UTC().Format(http.TimeFormat) - } - - for _, v := range rws.snapHeader["Trailer"] { - foreachHeaderElement(v, rws.declareTrailer) - } - - endStream := (rws.handlerDone && !rws.hasTrailers() && len(p) == 0) || isHeadResp - err = rws.conn.writeHeaders(rws.stream, &writeResHeaders{ - streamID: rws.stream.id, - httpResCode: rws.status, - h: rws.snapHeader, - endStream: endStream, - contentType: ctype, - contentLength: clen, - date: date, - }) - if err != nil { - return 0, err - } - if endStream { - return 0, nil - } - } - if isHeadResp { - return len(p), nil - } - if len(p) == 0 && !rws.handlerDone { - return 0, nil - } - - if rws.handlerDone { - rws.promoteUndeclaredTrailers() - } - - endStream := rws.handlerDone && !rws.hasTrailers() - if len(p) > 0 || endStream { - // only send a 0 byte DATA frame if we're ending the stream. - if err := rws.conn.writeDataFromHandler(rws.stream, p, endStream); err != nil { - return 0, err - } - } - - if rws.handlerDone && rws.hasTrailers() { - err = rws.conn.writeHeaders(rws.stream, &writeResHeaders{ - streamID: rws.stream.id, - h: rws.handlerHeader, - trailers: rws.trailers, - endStream: true, - }) - return len(p), err - } - return len(p), nil -} - -// TrailerPrefix is a magic prefix for ResponseWriter.Header map keys -// that, if present, signals that the map entry is actually for -// the response trailers, and not the response headers. The prefix -// is stripped after the ServeHTTP call finishes and the values are -// sent in the trailers. -// -// This mechanism is intended only for trailers that are not known -// prior to the headers being written. If the set of trailers is fixed -// or known before the header is written, the normal Go trailers mechanism -// is preferred: -// https://golang.org/pkg/net/http/#ResponseWriter -// https://golang.org/pkg/net/http/#example_ResponseWriter_trailers -const TrailerPrefix = "Trailer:" - -// promoteUndeclaredTrailers permits http.Handlers to set trailers -// after the header has already been flushed. Because the Go -// ResponseWriter interface has no way to set Trailers (only the -// Header), and because we didn't want to expand the ResponseWriter -// interface, and because nobody used trailers, and because RFC 2616 -// says you SHOULD (but not must) predeclare any trailers in the -// header, the official ResponseWriter rules said trailers in Go must -// be predeclared, and then we reuse the same ResponseWriter.Header() -// map to mean both Headers and Trailers. When it's time to write the -// Trailers, we pick out the fields of Headers that were declared as -// trailers. That worked for a while, until we found the first major -// user of Trailers in the wild: gRPC (using them only over http2), -// and gRPC libraries permit setting trailers mid-stream without -// predeclarnig them. So: change of plans. We still permit the old -// way, but we also permit this hack: if a Header() key begins with -// "Trailer:", the suffix of that key is a Trailer. Because ':' is an -// invalid token byte anyway, there is no ambiguity. (And it's already -// filtered out) It's mildly hacky, but not terrible. -// -// This method runs after the Handler is done and promotes any Header -// fields to be trailers. -func (rws *responseWriterState) promoteUndeclaredTrailers() { - for k, vv := range rws.handlerHeader { - if !strings.HasPrefix(k, TrailerPrefix) { - continue - } - trailerKey := strings.TrimPrefix(k, TrailerPrefix) - rws.declareTrailer(trailerKey) - rws.handlerHeader[http.CanonicalHeaderKey(trailerKey)] = vv - } - - if len(rws.trailers) > 1 { - sorter := sorterPool.Get().(*sorter) - sorter.SortStrings(rws.trailers) - sorterPool.Put(sorter) - } -} - -func (w *responseWriter) Flush() { - rws := w.rws - if rws == nil { - panic("Header called after Handler finished") - } - if rws.bw.Buffered() > 0 { - if err := rws.bw.Flush(); err != nil { - // Ignore the error. The frame writer already knows. - return - } - } else { - // The bufio.Writer won't call chunkWriter.Write - // (writeChunk with zero bytes, so we have to do it - // ourselves to force the HTTP response header and/or - // final DATA frame (with END_STREAM) to be sent. - rws.writeChunk(nil) - } -} - -func (w *responseWriter) CloseNotify() <-chan bool { - rws := w.rws - if rws == nil { - panic("CloseNotify called after Handler finished") - } - rws.closeNotifierMu.Lock() - ch := rws.closeNotifierCh - if ch == nil { - ch = make(chan bool, 1) - rws.closeNotifierCh = ch - go func() { - rws.stream.cw.Wait() // wait for close - ch <- true - }() - } - rws.closeNotifierMu.Unlock() - return ch -} - -func (w *responseWriter) Header() http.Header { - rws := w.rws - if rws == nil { - panic("Header called after Handler finished") - } - if rws.handlerHeader == nil { - rws.handlerHeader = make(http.Header) - } - return rws.handlerHeader -} - -func (w *responseWriter) WriteHeader(code int) { - rws := w.rws - if rws == nil { - panic("WriteHeader called after Handler finished") - } - rws.writeHeader(code) -} - -func (rws *responseWriterState) writeHeader(code int) { - if !rws.wroteHeader { - rws.wroteHeader = true - rws.status = code - if len(rws.handlerHeader) > 0 { - rws.snapHeader = cloneHeader(rws.handlerHeader) - } - } -} - -func cloneHeader(h http.Header) http.Header { - h2 := make(http.Header, len(h)) - for k, vv := range h { - vv2 := make([]string, len(vv)) - copy(vv2, vv) - h2[k] = vv2 - } - return h2 -} - -// The Life Of A Write is like this: -// -// * Handler calls w.Write or w.WriteString -> -// * -> rws.bw (*bufio.Writer) -> -// * (Handler migth call Flush) -// * -> chunkWriter{rws} -// * -> responseWriterState.writeChunk(p []byte) -// * -> responseWriterState.writeChunk (most of the magic; see comment there) -func (w *responseWriter) Write(p []byte) (n int, err error) { - return w.write(len(p), p, "") -} - -func (w *responseWriter) WriteString(s string) (n int, err error) { - return w.write(len(s), nil, s) -} - -// either dataB or dataS is non-zero. -func (w *responseWriter) write(lenData int, dataB []byte, dataS string) (n int, err error) { - rws := w.rws - if rws == nil { - panic("Write called after Handler finished") - } - if !rws.wroteHeader { - w.WriteHeader(200) - } - if !bodyAllowedForStatus(rws.status) { - return 0, http.ErrBodyNotAllowed - } - rws.wroteBytes += int64(len(dataB)) + int64(len(dataS)) // only one can be set - if rws.sentContentLen != 0 && rws.wroteBytes > rws.sentContentLen { - // TODO: send a RST_STREAM - return 0, errors.New("http2: handler wrote more than declared Content-Length") - } - - if dataB != nil { - return rws.bw.Write(dataB) - } else { - return rws.bw.WriteString(dataS) - } -} - -func (w *responseWriter) handlerDone() { - rws := w.rws - rws.handlerDone = true - w.Flush() - w.rws = nil - responseWriterStatePool.Put(rws) -} - -// foreachHeaderElement splits v according to the "#rule" construction -// in RFC 2616 section 2.1 and calls fn for each non-empty element. -func foreachHeaderElement(v string, fn func(string)) { - v = textproto.TrimString(v) - if v == "" { - return - } - if !strings.Contains(v, ",") { - fn(v) - return - } - for _, f := range strings.Split(v, ",") { - if f = textproto.TrimString(f); f != "" { - fn(f) - } - } -} - -// From http://httpwg.org/specs/rfc7540.html#rfc.section.8.1.2.2 -var connHeaders = []string{ - "Connection", - "Keep-Alive", - "Proxy-Connection", - "Transfer-Encoding", - "Upgrade", -} - -// checkValidHTTP2Request checks whether req is a valid HTTP/2 request, -// per RFC 7540 Section 8.1.2.2. -// The returned error is reported to users. -func checkValidHTTP2Request(req *http.Request) error { - for _, h := range connHeaders { - if _, ok := req.Header[h]; ok { - return fmt.Errorf("request header %q is not valid in HTTP/2", h) - } - } - te := req.Header["Te"] - if len(te) > 0 && (len(te) > 1 || (te[0] != "trailers" && te[0] != "")) { - return errors.New(`request header "TE" may only be "trailers" in HTTP/2`) - } - return nil -} - -func new400Handler(err error) http.HandlerFunc { - return func(w http.ResponseWriter, r *http.Request) { - http.Error(w, err.Error(), http.StatusBadRequest) - } -} - -// ValidTrailerHeader reports whether name is a valid header field name to appear -// in trailers. -// See: http://tools.ietf.org/html/rfc7230#section-4.1.2 -func ValidTrailerHeader(name string) bool { - name = http.CanonicalHeaderKey(name) - if strings.HasPrefix(name, "If-") || badTrailer[name] { - return false - } - return true -} - -var badTrailer = map[string]bool{ - "Authorization": true, - "Cache-Control": true, - "Connection": true, - "Content-Encoding": true, - "Content-Length": true, - "Content-Range": true, - "Content-Type": true, - "Expect": true, - "Host": true, - "Keep-Alive": true, - "Max-Forwards": true, - "Pragma": true, - "Proxy-Authenticate": true, - "Proxy-Authorization": true, - "Proxy-Connection": true, - "Range": true, - "Realm": true, - "Te": true, - "Trailer": true, - "Transfer-Encoding": true, - "Www-Authenticate": true, -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/transport.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/transport.go deleted file mode 100644 index fb8dd99..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/transport.go +++ /dev/null @@ -1,1868 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Transport code. - -package http2 - -import ( - "bufio" - "bytes" - "compress/gzip" - "crypto/tls" - "errors" - "fmt" - "io" - "io/ioutil" - "log" - "net" - "net/http" - "sort" - "strconv" - "strings" - "sync" - "time" - - "golang.org/x/net/http2/hpack" - "golang.org/x/net/lex/httplex" -) - -const ( - // transportDefaultConnFlow is how many connection-level flow control - // tokens we give the server at start-up, past the default 64k. - transportDefaultConnFlow = 1 << 30 - - // transportDefaultStreamFlow is how many stream-level flow - // control tokens we announce to the peer, and how many bytes - // we buffer per stream. - transportDefaultStreamFlow = 4 << 20 - - // transportDefaultStreamMinRefresh is the minimum number of bytes we'll send - // a stream-level WINDOW_UPDATE for at a time. - transportDefaultStreamMinRefresh = 4 << 10 - - defaultUserAgent = "Go-http-client/2.0" -) - -// Transport is an HTTP/2 Transport. -// -// A Transport internally caches connections to servers. It is safe -// for concurrent use by multiple goroutines. -type Transport struct { - // DialTLS specifies an optional dial function for creating - // TLS connections for requests. - // - // If DialTLS is nil, tls.Dial is used. - // - // If the returned net.Conn has a ConnectionState method like tls.Conn, - // it will be used to set http.Response.TLS. - DialTLS func(network, addr string, cfg *tls.Config) (net.Conn, error) - - // TLSClientConfig specifies the TLS configuration to use with - // tls.Client. If nil, the default configuration is used. - TLSClientConfig *tls.Config - - // ConnPool optionally specifies an alternate connection pool to use. - // If nil, the default is used. - ConnPool ClientConnPool - - // DisableCompression, if true, prevents the Transport from - // requesting compression with an "Accept-Encoding: gzip" - // request header when the Request contains no existing - // Accept-Encoding value. If the Transport requests gzip on - // its own and gets a gzipped response, it's transparently - // decoded in the Response.Body. However, if the user - // explicitly requested gzip it is not automatically - // uncompressed. - DisableCompression bool - - // AllowHTTP, if true, permits HTTP/2 requests using the insecure, - // plain-text "http" scheme. Note that this does not enable h2c support. - AllowHTTP bool - - // MaxHeaderListSize is the http2 SETTINGS_MAX_HEADER_LIST_SIZE to - // send in the initial settings frame. It is how many bytes - // of response headers are allow. Unlike the http2 spec, zero here - // means to use a default limit (currently 10MB). If you actually - // want to advertise an ulimited value to the peer, Transport - // interprets the highest possible value here (0xffffffff or 1<<32-1) - // to mean no limit. - MaxHeaderListSize uint32 - - // t1, if non-nil, is the standard library Transport using - // this transport. Its settings are used (but not its - // RoundTrip method, etc). - t1 *http.Transport - - connPoolOnce sync.Once - connPoolOrDef ClientConnPool // non-nil version of ConnPool -} - -func (t *Transport) maxHeaderListSize() uint32 { - if t.MaxHeaderListSize == 0 { - return 10 << 20 - } - if t.MaxHeaderListSize == 0xffffffff { - return 0 - } - return t.MaxHeaderListSize -} - -func (t *Transport) disableCompression() bool { - return t.DisableCompression || (t.t1 != nil && t.t1.DisableCompression) -} - -var errTransportVersion = errors.New("http2: ConfigureTransport is only supported starting at Go 1.6") - -// ConfigureTransport configures a net/http HTTP/1 Transport to use HTTP/2. -// It requires Go 1.6 or later and returns an error if the net/http package is too old -// or if t1 has already been HTTP/2-enabled. -func ConfigureTransport(t1 *http.Transport) error { - _, err := configureTransport(t1) // in configure_transport.go (go1.6) or not_go16.go - return err -} - -func (t *Transport) connPool() ClientConnPool { - t.connPoolOnce.Do(t.initConnPool) - return t.connPoolOrDef -} - -func (t *Transport) initConnPool() { - if t.ConnPool != nil { - t.connPoolOrDef = t.ConnPool - } else { - t.connPoolOrDef = &clientConnPool{t: t} - } -} - -// ClientConn is the state of a single HTTP/2 client connection to an -// HTTP/2 server. -type ClientConn struct { - t *Transport - tconn net.Conn // usually *tls.Conn, except specialized impls - tlsState *tls.ConnectionState // nil only for specialized impls - singleUse bool // whether being used for a single http.Request - - // readLoop goroutine fields: - readerDone chan struct{} // closed on error - readerErr error // set before readerDone is closed - - mu sync.Mutex // guards following - cond *sync.Cond // hold mu; broadcast on flow/closed changes - flow flow // our conn-level flow control quota (cs.flow is per stream) - inflow flow // peer's conn-level flow control - closed bool - goAway *GoAwayFrame // if non-nil, the GoAwayFrame we received - goAwayDebug string // goAway frame's debug data, retained as a string - streams map[uint32]*clientStream // client-initiated - nextStreamID uint32 - bw *bufio.Writer - br *bufio.Reader - fr *Framer - lastActive time.Time - - // Settings from peer: - maxFrameSize uint32 - maxConcurrentStreams uint32 - initialWindowSize uint32 - hbuf bytes.Buffer // HPACK encoder writes into this - henc *hpack.Encoder - freeBuf [][]byte - - wmu sync.Mutex // held while writing; acquire AFTER mu if holding both - werr error // first write error that has occurred -} - -// clientStream is the state for a single HTTP/2 stream. One of these -// is created for each Transport.RoundTrip call. -type clientStream struct { - cc *ClientConn - req *http.Request - trace *clientTrace // or nil - ID uint32 - resc chan resAndError - bufPipe pipe // buffered pipe with the flow-controlled response payload - requestedGzip bool - on100 func() // optional code to run if get a 100 continue response - - flow flow // guarded by cc.mu - inflow flow // guarded by cc.mu - bytesRemain int64 // -1 means unknown; owned by transportResponseBody.Read - readErr error // sticky read error; owned by transportResponseBody.Read - stopReqBody error // if non-nil, stop writing req body; guarded by cc.mu - - peerReset chan struct{} // closed on peer reset - resetErr error // populated before peerReset is closed - - done chan struct{} // closed when stream remove from cc.streams map; close calls guarded by cc.mu - - // owned by clientConnReadLoop: - firstByte bool // got the first response byte - pastHeaders bool // got first MetaHeadersFrame (actual headers) - pastTrailers bool // got optional second MetaHeadersFrame (trailers) - - trailer http.Header // accumulated trailers - resTrailer *http.Header // client's Response.Trailer -} - -// awaitRequestCancel runs in its own goroutine and waits for the user -// to cancel a RoundTrip request, its context to expire, or for the -// request to be done (any way it might be removed from the cc.streams -// map: peer reset, successful completion, TCP connection breakage, -// etc) -func (cs *clientStream) awaitRequestCancel(req *http.Request) { - ctx := reqContext(req) - if req.Cancel == nil && ctx.Done() == nil { - return - } - select { - case <-req.Cancel: - cs.bufPipe.CloseWithError(errRequestCanceled) - cs.cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - case <-ctx.Done(): - cs.bufPipe.CloseWithError(ctx.Err()) - cs.cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - case <-cs.done: - } -} - -// checkResetOrDone reports any error sent in a RST_STREAM frame by the -// server, or errStreamClosed if the stream is complete. -func (cs *clientStream) checkResetOrDone() error { - select { - case <-cs.peerReset: - return cs.resetErr - case <-cs.done: - return errStreamClosed - default: - return nil - } -} - -func (cs *clientStream) abortRequestBodyWrite(err error) { - if err == nil { - panic("nil error") - } - cc := cs.cc - cc.mu.Lock() - cs.stopReqBody = err - cc.cond.Broadcast() - cc.mu.Unlock() -} - -type stickyErrWriter struct { - w io.Writer - err *error -} - -func (sew stickyErrWriter) Write(p []byte) (n int, err error) { - if *sew.err != nil { - return 0, *sew.err - } - n, err = sew.w.Write(p) - *sew.err = err - return -} - -var ErrNoCachedConn = errors.New("http2: no cached connection was available") - -// RoundTripOpt are options for the Transport.RoundTripOpt method. -type RoundTripOpt struct { - // OnlyCachedConn controls whether RoundTripOpt may - // create a new TCP connection. If set true and - // no cached connection is available, RoundTripOpt - // will return ErrNoCachedConn. - OnlyCachedConn bool -} - -func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { - return t.RoundTripOpt(req, RoundTripOpt{}) -} - -// authorityAddr returns a given authority (a host/IP, or host:port / ip:port) -// and returns a host:port. The port 443 is added if needed. -func authorityAddr(scheme string, authority string) (addr string) { - if _, _, err := net.SplitHostPort(authority); err == nil { - return authority - } - port := "443" - if scheme == "http" { - port = "80" - } - return net.JoinHostPort(authority, port) -} - -// RoundTripOpt is like RoundTrip, but takes options. -func (t *Transport) RoundTripOpt(req *http.Request, opt RoundTripOpt) (*http.Response, error) { - if !(req.URL.Scheme == "https" || (req.URL.Scheme == "http" && t.AllowHTTP)) { - return nil, errors.New("http2: unsupported scheme") - } - - addr := authorityAddr(req.URL.Scheme, req.URL.Host) - for { - cc, err := t.connPool().GetClientConn(req, addr) - if err != nil { - t.vlogf("http2: Transport failed to get client conn for %s: %v", addr, err) - return nil, err - } - traceGotConn(req, cc) - res, err := cc.RoundTrip(req) - if shouldRetryRequest(req, err) { - continue - } - if err != nil { - t.vlogf("RoundTrip failure: %v", err) - return nil, err - } - return res, nil - } -} - -// CloseIdleConnections closes any connections which were previously -// connected from previous requests but are now sitting idle. -// It does not interrupt any connections currently in use. -func (t *Transport) CloseIdleConnections() { - if cp, ok := t.connPool().(clientConnPoolIdleCloser); ok { - cp.closeIdleConnections() - } -} - -var ( - errClientConnClosed = errors.New("http2: client conn is closed") - errClientConnUnusable = errors.New("http2: client conn not usable") -) - -func shouldRetryRequest(req *http.Request, err error) bool { - // TODO: retry GET requests (no bodies) more aggressively, if shutdown - // before response. - return err == errClientConnUnusable -} - -func (t *Transport) dialClientConn(addr string) (*ClientConn, error) { - host, _, err := net.SplitHostPort(addr) - if err != nil { - return nil, err - } - tconn, err := t.dialTLS()("tcp", addr, t.newTLSConfig(host)) - if err != nil { - return nil, err - } - return t.NewClientConn(tconn) -} - -func (t *Transport) newTLSConfig(host string) *tls.Config { - cfg := new(tls.Config) - if t.TLSClientConfig != nil { - *cfg = *t.TLSClientConfig - } - if !strSliceContains(cfg.NextProtos, NextProtoTLS) { - cfg.NextProtos = append([]string{NextProtoTLS}, cfg.NextProtos...) - } - if cfg.ServerName == "" { - cfg.ServerName = host - } - return cfg -} - -func (t *Transport) dialTLS() func(string, string, *tls.Config) (net.Conn, error) { - if t.DialTLS != nil { - return t.DialTLS - } - return t.dialTLSDefault -} - -func (t *Transport) dialTLSDefault(network, addr string, cfg *tls.Config) (net.Conn, error) { - cn, err := tls.Dial(network, addr, cfg) - if err != nil { - return nil, err - } - if err := cn.Handshake(); err != nil { - return nil, err - } - if !cfg.InsecureSkipVerify { - if err := cn.VerifyHostname(cfg.ServerName); err != nil { - return nil, err - } - } - state := cn.ConnectionState() - if p := state.NegotiatedProtocol; p != NextProtoTLS { - return nil, fmt.Errorf("http2: unexpected ALPN protocol %q; want %q", p, NextProtoTLS) - } - if !state.NegotiatedProtocolIsMutual { - return nil, errors.New("http2: could not negotiate protocol mutually") - } - return cn, nil -} - -// disableKeepAlives reports whether connections should be closed as -// soon as possible after handling the first request. -func (t *Transport) disableKeepAlives() bool { - return t.t1 != nil && t.t1.DisableKeepAlives -} - -func (t *Transport) expectContinueTimeout() time.Duration { - if t.t1 == nil { - return 0 - } - return transportExpectContinueTimeout(t.t1) -} - -func (t *Transport) NewClientConn(c net.Conn) (*ClientConn, error) { - if VerboseLogs { - t.vlogf("http2: Transport creating client conn to %v", c.RemoteAddr()) - } - if _, err := c.Write(clientPreface); err != nil { - t.vlogf("client preface write error: %v", err) - return nil, err - } - - cc := &ClientConn{ - t: t, - tconn: c, - readerDone: make(chan struct{}), - nextStreamID: 1, - maxFrameSize: 16 << 10, // spec default - initialWindowSize: 65535, // spec default - maxConcurrentStreams: 1000, // "infinite", per spec. 1000 seems good enough. - streams: make(map[uint32]*clientStream), - } - cc.cond = sync.NewCond(&cc.mu) - cc.flow.add(int32(initialWindowSize)) - - // TODO: adjust this writer size to account for frame size + - // MTU + crypto/tls record padding. - cc.bw = bufio.NewWriter(stickyErrWriter{c, &cc.werr}) - cc.br = bufio.NewReader(c) - cc.fr = NewFramer(cc.bw, cc.br) - cc.fr.ReadMetaHeaders = hpack.NewDecoder(initialHeaderTableSize, nil) - cc.fr.MaxHeaderListSize = t.maxHeaderListSize() - - // TODO: SetMaxDynamicTableSize, SetMaxDynamicTableSizeLimit on - // henc in response to SETTINGS frames? - cc.henc = hpack.NewEncoder(&cc.hbuf) - - if cs, ok := c.(connectionStater); ok { - state := cs.ConnectionState() - cc.tlsState = &state - } - - initialSettings := []Setting{ - {ID: SettingEnablePush, Val: 0}, - {ID: SettingInitialWindowSize, Val: transportDefaultStreamFlow}, - } - if max := t.maxHeaderListSize(); max != 0 { - initialSettings = append(initialSettings, Setting{ID: SettingMaxHeaderListSize, Val: max}) - } - cc.fr.WriteSettings(initialSettings...) - cc.fr.WriteWindowUpdate(0, transportDefaultConnFlow) - cc.inflow.add(transportDefaultConnFlow + initialWindowSize) - cc.bw.Flush() - if cc.werr != nil { - return nil, cc.werr - } - - // Read the obligatory SETTINGS frame - f, err := cc.fr.ReadFrame() - if err != nil { - return nil, err - } - sf, ok := f.(*SettingsFrame) - if !ok { - return nil, fmt.Errorf("expected settings frame, got: %T", f) - } - cc.fr.WriteSettingsAck() - cc.bw.Flush() - - sf.ForeachSetting(func(s Setting) error { - switch s.ID { - case SettingMaxFrameSize: - cc.maxFrameSize = s.Val - case SettingMaxConcurrentStreams: - cc.maxConcurrentStreams = s.Val - case SettingInitialWindowSize: - cc.initialWindowSize = s.Val - default: - // TODO(bradfitz): handle more; at least SETTINGS_HEADER_TABLE_SIZE? - t.vlogf("Unhandled Setting: %v", s) - } - return nil - }) - - go cc.readLoop() - return cc, nil -} - -func (cc *ClientConn) setGoAway(f *GoAwayFrame) { - cc.mu.Lock() - defer cc.mu.Unlock() - - old := cc.goAway - cc.goAway = f - - // Merge the previous and current GoAway error frames. - if cc.goAwayDebug == "" { - cc.goAwayDebug = string(f.DebugData()) - } - if old != nil && old.ErrCode != ErrCodeNo { - cc.goAway.ErrCode = old.ErrCode - } -} - -func (cc *ClientConn) CanTakeNewRequest() bool { - cc.mu.Lock() - defer cc.mu.Unlock() - return cc.canTakeNewRequestLocked() -} - -func (cc *ClientConn) canTakeNewRequestLocked() bool { - if cc.singleUse && cc.nextStreamID > 1 { - return false - } - return cc.goAway == nil && !cc.closed && - int64(len(cc.streams)+1) < int64(cc.maxConcurrentStreams) && - cc.nextStreamID < 2147483647 -} - -func (cc *ClientConn) closeIfIdle() { - cc.mu.Lock() - if len(cc.streams) > 0 { - cc.mu.Unlock() - return - } - cc.closed = true - // TODO: do clients send GOAWAY too? maybe? Just Close: - cc.mu.Unlock() - - cc.tconn.Close() -} - -const maxAllocFrameSize = 512 << 10 - -// frameBuffer returns a scratch buffer suitable for writing DATA frames. -// They're capped at the min of the peer's max frame size or 512KB -// (kinda arbitrarily), but definitely capped so we don't allocate 4GB -// bufers. -func (cc *ClientConn) frameScratchBuffer() []byte { - cc.mu.Lock() - size := cc.maxFrameSize - if size > maxAllocFrameSize { - size = maxAllocFrameSize - } - for i, buf := range cc.freeBuf { - if len(buf) >= int(size) { - cc.freeBuf[i] = nil - cc.mu.Unlock() - return buf[:size] - } - } - cc.mu.Unlock() - return make([]byte, size) -} - -func (cc *ClientConn) putFrameScratchBuffer(buf []byte) { - cc.mu.Lock() - defer cc.mu.Unlock() - const maxBufs = 4 // arbitrary; 4 concurrent requests per conn? investigate. - if len(cc.freeBuf) < maxBufs { - cc.freeBuf = append(cc.freeBuf, buf) - return - } - for i, old := range cc.freeBuf { - if old == nil { - cc.freeBuf[i] = buf - return - } - } - // forget about it. -} - -// errRequestCanceled is a copy of net/http's errRequestCanceled because it's not -// exported. At least they'll be DeepEqual for h1-vs-h2 comparisons tests. -var errRequestCanceled = errors.New("net/http: request canceled") - -func commaSeparatedTrailers(req *http.Request) (string, error) { - keys := make([]string, 0, len(req.Trailer)) - for k := range req.Trailer { - k = http.CanonicalHeaderKey(k) - switch k { - case "Transfer-Encoding", "Trailer", "Content-Length": - return "", &badStringError{"invalid Trailer key", k} - } - keys = append(keys, k) - } - if len(keys) > 0 { - sort.Strings(keys) - // TODO: could do better allocation-wise here, but trailers are rare, - // so being lazy for now. - return strings.Join(keys, ","), nil - } - return "", nil -} - -func (cc *ClientConn) responseHeaderTimeout() time.Duration { - if cc.t.t1 != nil { - return cc.t.t1.ResponseHeaderTimeout - } - // No way to do this (yet?) with just an http2.Transport. Probably - // no need. Request.Cancel this is the new way. We only need to support - // this for compatibility with the old http.Transport fields when - // we're doing transparent http2. - return 0 -} - -// checkConnHeaders checks whether req has any invalid connection-level headers. -// per RFC 7540 section 8.1.2.2: Connection-Specific Header Fields. -// Certain headers are special-cased as okay but not transmitted later. -func checkConnHeaders(req *http.Request) error { - if v := req.Header.Get("Upgrade"); v != "" { - return errors.New("http2: invalid Upgrade request header") - } - if v := req.Header.Get("Transfer-Encoding"); (v != "" && v != "chunked") || len(req.Header["Transfer-Encoding"]) > 1 { - return errors.New("http2: invalid Transfer-Encoding request header") - } - if v := req.Header.Get("Connection"); (v != "" && v != "close" && v != "keep-alive") || len(req.Header["Connection"]) > 1 { - return errors.New("http2: invalid Connection request header") - } - return nil -} - -func bodyAndLength(req *http.Request) (body io.Reader, contentLen int64) { - body = req.Body - if body == nil { - return nil, 0 - } - if req.ContentLength != 0 { - return req.Body, req.ContentLength - } - - // We have a body but a zero content length. Test to see if - // it's actually zero or just unset. - var buf [1]byte - n, rerr := io.ReadFull(body, buf[:]) - if rerr != nil && rerr != io.EOF { - return errorReader{rerr}, -1 - } - if n == 1 { - // Oh, guess there is data in this Body Reader after all. - // The ContentLength field just wasn't set. - // Stich the Body back together again, re-attaching our - // consumed byte. - return io.MultiReader(bytes.NewReader(buf[:]), body), -1 - } - // Body is actually zero bytes. - return nil, 0 -} - -func (cc *ClientConn) RoundTrip(req *http.Request) (*http.Response, error) { - if err := checkConnHeaders(req); err != nil { - return nil, err - } - - trailers, err := commaSeparatedTrailers(req) - if err != nil { - return nil, err - } - hasTrailers := trailers != "" - - body, contentLen := bodyAndLength(req) - hasBody := body != nil - - cc.mu.Lock() - cc.lastActive = time.Now() - if cc.closed || !cc.canTakeNewRequestLocked() { - cc.mu.Unlock() - return nil, errClientConnUnusable - } - - // TODO(bradfitz): this is a copy of the logic in net/http. Unify somewhere? - var requestedGzip bool - if !cc.t.disableCompression() && - req.Header.Get("Accept-Encoding") == "" && - req.Header.Get("Range") == "" && - req.Method != "HEAD" { - // Request gzip only, not deflate. Deflate is ambiguous and - // not as universally supported anyway. - // See: http://www.gzip.org/zlib/zlib_faq.html#faq38 - // - // Note that we don't request this for HEAD requests, - // due to a bug in nginx: - // http://trac.nginx.org/nginx/ticket/358 - // https://golang.org/issue/5522 - // - // We don't request gzip if the request is for a range, since - // auto-decoding a portion of a gzipped document will just fail - // anyway. See https://golang.org/issue/8923 - requestedGzip = true - } - - // we send: HEADERS{1}, CONTINUATION{0,} + DATA{0,} (DATA is - // sent by writeRequestBody below, along with any Trailers, - // again in form HEADERS{1}, CONTINUATION{0,}) - hdrs, err := cc.encodeHeaders(req, requestedGzip, trailers, contentLen) - if err != nil { - cc.mu.Unlock() - return nil, err - } - - cs := cc.newStream() - cs.req = req - cs.trace = requestTrace(req) - cs.requestedGzip = requestedGzip - bodyWriter := cc.t.getBodyWriterState(cs, body) - cs.on100 = bodyWriter.on100 - - cc.wmu.Lock() - endStream := !hasBody && !hasTrailers - werr := cc.writeHeaders(cs.ID, endStream, hdrs) - cc.wmu.Unlock() - traceWroteHeaders(cs.trace) - cc.mu.Unlock() - - if werr != nil { - if hasBody { - req.Body.Close() // per RoundTripper contract - bodyWriter.cancel() - } - cc.forgetStreamID(cs.ID) - // Don't bother sending a RST_STREAM (our write already failed; - // no need to keep writing) - traceWroteRequest(cs.trace, werr) - return nil, werr - } - - var respHeaderTimer <-chan time.Time - if hasBody { - bodyWriter.scheduleBodyWrite() - } else { - traceWroteRequest(cs.trace, nil) - if d := cc.responseHeaderTimeout(); d != 0 { - timer := time.NewTimer(d) - defer timer.Stop() - respHeaderTimer = timer.C - } - } - - readLoopResCh := cs.resc - bodyWritten := false - ctx := reqContext(req) - - for { - select { - case re := <-readLoopResCh: - res := re.res - if re.err != nil || res.StatusCode > 299 { - // On error or status code 3xx, 4xx, 5xx, etc abort any - // ongoing write, assuming that the server doesn't care - // about our request body. If the server replied with 1xx or - // 2xx, however, then assume the server DOES potentially - // want our body (e.g. full-duplex streaming: - // golang.org/issue/13444). If it turns out the server - // doesn't, they'll RST_STREAM us soon enough. This is a - // heuristic to avoid adding knobs to Transport. Hopefully - // we can keep it. - bodyWriter.cancel() - cs.abortRequestBodyWrite(errStopReqBodyWrite) - } - if re.err != nil { - cc.forgetStreamID(cs.ID) - return nil, re.err - } - res.Request = req - res.TLS = cc.tlsState - return res, nil - case <-respHeaderTimer: - cc.forgetStreamID(cs.ID) - if !hasBody || bodyWritten { - cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - } else { - bodyWriter.cancel() - cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) - } - return nil, errTimeout - case <-ctx.Done(): - cc.forgetStreamID(cs.ID) - if !hasBody || bodyWritten { - cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - } else { - bodyWriter.cancel() - cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) - } - return nil, ctx.Err() - case <-req.Cancel: - cc.forgetStreamID(cs.ID) - if !hasBody || bodyWritten { - cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - } else { - bodyWriter.cancel() - cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) - } - return nil, errRequestCanceled - case <-cs.peerReset: - // processResetStream already removed the - // stream from the streams map; no need for - // forgetStreamID. - return nil, cs.resetErr - case err := <-bodyWriter.resc: - if err != nil { - return nil, err - } - bodyWritten = true - if d := cc.responseHeaderTimeout(); d != 0 { - timer := time.NewTimer(d) - defer timer.Stop() - respHeaderTimer = timer.C - } - } - } -} - -// requires cc.wmu be held -func (cc *ClientConn) writeHeaders(streamID uint32, endStream bool, hdrs []byte) error { - first := true // first frame written (HEADERS is first, then CONTINUATION) - frameSize := int(cc.maxFrameSize) - for len(hdrs) > 0 && cc.werr == nil { - chunk := hdrs - if len(chunk) > frameSize { - chunk = chunk[:frameSize] - } - hdrs = hdrs[len(chunk):] - endHeaders := len(hdrs) == 0 - if first { - cc.fr.WriteHeaders(HeadersFrameParam{ - StreamID: streamID, - BlockFragment: chunk, - EndStream: endStream, - EndHeaders: endHeaders, - }) - first = false - } else { - cc.fr.WriteContinuation(streamID, endHeaders, chunk) - } - } - // TODO(bradfitz): this Flush could potentially block (as - // could the WriteHeaders call(s) above), which means they - // wouldn't respond to Request.Cancel being readable. That's - // rare, but this should probably be in a goroutine. - cc.bw.Flush() - return cc.werr -} - -// internal error values; they don't escape to callers -var ( - // abort request body write; don't send cancel - errStopReqBodyWrite = errors.New("http2: aborting request body write") - - // abort request body write, but send stream reset of cancel. - errStopReqBodyWriteAndCancel = errors.New("http2: canceling request") -) - -func (cs *clientStream) writeRequestBody(body io.Reader, bodyCloser io.Closer) (err error) { - cc := cs.cc - sentEnd := false // whether we sent the final DATA frame w/ END_STREAM - buf := cc.frameScratchBuffer() - defer cc.putFrameScratchBuffer(buf) - - defer func() { - traceWroteRequest(cs.trace, err) - // TODO: write h12Compare test showing whether - // Request.Body is closed by the Transport, - // and in multiple cases: server replies <=299 and >299 - // while still writing request body - cerr := bodyCloser.Close() - if err == nil { - err = cerr - } - }() - - req := cs.req - hasTrailers := req.Trailer != nil - - var sawEOF bool - for !sawEOF { - n, err := body.Read(buf) - if err == io.EOF { - sawEOF = true - err = nil - } else if err != nil { - return err - } - - remain := buf[:n] - for len(remain) > 0 && err == nil { - var allowed int32 - allowed, err = cs.awaitFlowControl(len(remain)) - switch { - case err == errStopReqBodyWrite: - return err - case err == errStopReqBodyWriteAndCancel: - cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - return err - case err != nil: - return err - } - cc.wmu.Lock() - data := remain[:allowed] - remain = remain[allowed:] - sentEnd = sawEOF && len(remain) == 0 && !hasTrailers - err = cc.fr.WriteData(cs.ID, sentEnd, data) - if err == nil { - // TODO(bradfitz): this flush is for latency, not bandwidth. - // Most requests won't need this. Make this opt-in or opt-out? - // Use some heuristic on the body type? Nagel-like timers? - // Based on 'n'? Only last chunk of this for loop, unless flow control - // tokens are low? For now, always: - err = cc.bw.Flush() - } - cc.wmu.Unlock() - } - if err != nil { - return err - } - } - - cc.wmu.Lock() - if !sentEnd { - var trls []byte - if hasTrailers { - cc.mu.Lock() - trls = cc.encodeTrailers(req) - cc.mu.Unlock() - } - - // Avoid forgetting to send an END_STREAM if the encoded - // trailers are 0 bytes. Both results produce and END_STREAM. - if len(trls) > 0 { - err = cc.writeHeaders(cs.ID, true, trls) - } else { - err = cc.fr.WriteData(cs.ID, true, nil) - } - } - if ferr := cc.bw.Flush(); ferr != nil && err == nil { - err = ferr - } - cc.wmu.Unlock() - - return err -} - -// awaitFlowControl waits for [1, min(maxBytes, cc.cs.maxFrameSize)] flow -// control tokens from the server. -// It returns either the non-zero number of tokens taken or an error -// if the stream is dead. -func (cs *clientStream) awaitFlowControl(maxBytes int) (taken int32, err error) { - cc := cs.cc - cc.mu.Lock() - defer cc.mu.Unlock() - for { - if cc.closed { - return 0, errClientConnClosed - } - if cs.stopReqBody != nil { - return 0, cs.stopReqBody - } - if err := cs.checkResetOrDone(); err != nil { - return 0, err - } - if a := cs.flow.available(); a > 0 { - take := a - if int(take) > maxBytes { - - take = int32(maxBytes) // can't truncate int; take is int32 - } - if take > int32(cc.maxFrameSize) { - take = int32(cc.maxFrameSize) - } - cs.flow.take(take) - return take, nil - } - cc.cond.Wait() - } -} - -type badStringError struct { - what string - str string -} - -func (e *badStringError) Error() string { return fmt.Sprintf("%s %q", e.what, e.str) } - -// requires cc.mu be held. -func (cc *ClientConn) encodeHeaders(req *http.Request, addGzipHeader bool, trailers string, contentLength int64) ([]byte, error) { - cc.hbuf.Reset() - - host := req.Host - if host == "" { - host = req.URL.Host - } - - // Check for any invalid headers and return an error before we - // potentially pollute our hpack state. (We want to be able to - // continue to reuse the hpack encoder for future requests) - for k, vv := range req.Header { - if !httplex.ValidHeaderFieldName(k) { - return nil, fmt.Errorf("invalid HTTP header name %q", k) - } - for _, v := range vv { - if !httplex.ValidHeaderFieldValue(v) { - return nil, fmt.Errorf("invalid HTTP header value %q for header %q", v, k) - } - } - } - - // 8.1.2.3 Request Pseudo-Header Fields - // The :path pseudo-header field includes the path and query parts of the - // target URI (the path-absolute production and optionally a '?' character - // followed by the query production (see Sections 3.3 and 3.4 of - // [RFC3986]). - cc.writeHeader(":authority", host) - cc.writeHeader(":method", req.Method) - if req.Method != "CONNECT" { - cc.writeHeader(":path", req.URL.RequestURI()) - cc.writeHeader(":scheme", "https") - } - if trailers != "" { - cc.writeHeader("trailer", trailers) - } - - var didUA bool - for k, vv := range req.Header { - lowKey := strings.ToLower(k) - switch lowKey { - case "host", "content-length": - // Host is :authority, already sent. - // Content-Length is automatic, set below. - continue - case "connection", "proxy-connection", "transfer-encoding", "upgrade", "keep-alive": - // Per 8.1.2.2 Connection-Specific Header - // Fields, don't send connection-specific - // fields. We have already checked if any - // are error-worthy so just ignore the rest. - continue - case "user-agent": - // Match Go's http1 behavior: at most one - // User-Agent. If set to nil or empty string, - // then omit it. Otherwise if not mentioned, - // include the default (below). - didUA = true - if len(vv) < 1 { - continue - } - vv = vv[:1] - if vv[0] == "" { - continue - } - } - for _, v := range vv { - cc.writeHeader(lowKey, v) - } - } - if shouldSendReqContentLength(req.Method, contentLength) { - cc.writeHeader("content-length", strconv.FormatInt(contentLength, 10)) - } - if addGzipHeader { - cc.writeHeader("accept-encoding", "gzip") - } - if !didUA { - cc.writeHeader("user-agent", defaultUserAgent) - } - return cc.hbuf.Bytes(), nil -} - -// shouldSendReqContentLength reports whether the http2.Transport should send -// a "content-length" request header. This logic is basically a copy of the net/http -// transferWriter.shouldSendContentLength. -// The contentLength is the corrected contentLength (so 0 means actually 0, not unknown). -// -1 means unknown. -func shouldSendReqContentLength(method string, contentLength int64) bool { - if contentLength > 0 { - return true - } - if contentLength < 0 { - return false - } - // For zero bodies, whether we send a content-length depends on the method. - // It also kinda doesn't matter for http2 either way, with END_STREAM. - switch method { - case "POST", "PUT", "PATCH": - return true - default: - return false - } -} - -// requires cc.mu be held. -func (cc *ClientConn) encodeTrailers(req *http.Request) []byte { - cc.hbuf.Reset() - for k, vv := range req.Trailer { - // Transfer-Encoding, etc.. have already been filter at the - // start of RoundTrip - lowKey := strings.ToLower(k) - for _, v := range vv { - cc.writeHeader(lowKey, v) - } - } - return cc.hbuf.Bytes() -} - -func (cc *ClientConn) writeHeader(name, value string) { - if VerboseLogs { - log.Printf("http2: Transport encoding header %q = %q", name, value) - } - cc.henc.WriteField(hpack.HeaderField{Name: name, Value: value}) -} - -type resAndError struct { - res *http.Response - err error -} - -// requires cc.mu be held. -func (cc *ClientConn) newStream() *clientStream { - cs := &clientStream{ - cc: cc, - ID: cc.nextStreamID, - resc: make(chan resAndError, 1), - peerReset: make(chan struct{}), - done: make(chan struct{}), - } - cs.flow.add(int32(cc.initialWindowSize)) - cs.flow.setConnFlow(&cc.flow) - cs.inflow.add(transportDefaultStreamFlow) - cs.inflow.setConnFlow(&cc.inflow) - cc.nextStreamID += 2 - cc.streams[cs.ID] = cs - return cs -} - -func (cc *ClientConn) forgetStreamID(id uint32) { - cc.streamByID(id, true) -} - -func (cc *ClientConn) streamByID(id uint32, andRemove bool) *clientStream { - cc.mu.Lock() - defer cc.mu.Unlock() - cs := cc.streams[id] - if andRemove && cs != nil && !cc.closed { - cc.lastActive = time.Now() - delete(cc.streams, id) - close(cs.done) - cc.cond.Broadcast() // wake up checkResetOrDone via clientStream.awaitFlowControl - } - return cs -} - -// clientConnReadLoop is the state owned by the clientConn's frame-reading readLoop. -type clientConnReadLoop struct { - cc *ClientConn - activeRes map[uint32]*clientStream // keyed by streamID - closeWhenIdle bool -} - -// readLoop runs in its own goroutine and reads and dispatches frames. -func (cc *ClientConn) readLoop() { - rl := &clientConnReadLoop{ - cc: cc, - activeRes: make(map[uint32]*clientStream), - } - - defer rl.cleanup() - cc.readerErr = rl.run() - if ce, ok := cc.readerErr.(ConnectionError); ok { - cc.wmu.Lock() - cc.fr.WriteGoAway(0, ErrCode(ce), nil) - cc.wmu.Unlock() - } -} - -// GoAwayError is returned by the Transport when the server closes the -// TCP connection after sending a GOAWAY frame. -type GoAwayError struct { - LastStreamID uint32 - ErrCode ErrCode - DebugData string -} - -func (e GoAwayError) Error() string { - return fmt.Sprintf("http2: server sent GOAWAY and closed the connection; LastStreamID=%v, ErrCode=%v, debug=%q", - e.LastStreamID, e.ErrCode, e.DebugData) -} - -func (rl *clientConnReadLoop) cleanup() { - cc := rl.cc - defer cc.tconn.Close() - defer cc.t.connPool().MarkDead(cc) - defer close(cc.readerDone) - - // Close any response bodies if the server closes prematurely. - // TODO: also do this if we've written the headers but not - // gotten a response yet. - err := cc.readerErr - cc.mu.Lock() - if err == io.EOF { - if cc.goAway != nil { - err = GoAwayError{ - LastStreamID: cc.goAway.LastStreamID, - ErrCode: cc.goAway.ErrCode, - DebugData: cc.goAwayDebug, - } - } else { - err = io.ErrUnexpectedEOF - } - } - for _, cs := range rl.activeRes { - cs.bufPipe.CloseWithError(err) - } - for _, cs := range cc.streams { - select { - case cs.resc <- resAndError{err: err}: - default: - } - close(cs.done) - } - cc.closed = true - cc.cond.Broadcast() - cc.mu.Unlock() -} - -func (rl *clientConnReadLoop) run() error { - cc := rl.cc - rl.closeWhenIdle = cc.t.disableKeepAlives() || cc.singleUse - gotReply := false // ever saw a reply - for { - f, err := cc.fr.ReadFrame() - if err != nil { - cc.vlogf("Transport readFrame error: (%T) %v", err, err) - } - if se, ok := err.(StreamError); ok { - if cs := cc.streamByID(se.StreamID, true /*ended; remove it*/); cs != nil { - rl.endStreamError(cs, cc.fr.errDetail) - } - continue - } else if err != nil { - return err - } - if VerboseLogs { - cc.vlogf("http2: Transport received %s", summarizeFrame(f)) - } - maybeIdle := false // whether frame might transition us to idle - - switch f := f.(type) { - case *MetaHeadersFrame: - err = rl.processHeaders(f) - maybeIdle = true - gotReply = true - case *DataFrame: - err = rl.processData(f) - maybeIdle = true - case *GoAwayFrame: - err = rl.processGoAway(f) - maybeIdle = true - case *RSTStreamFrame: - err = rl.processResetStream(f) - maybeIdle = true - case *SettingsFrame: - err = rl.processSettings(f) - case *PushPromiseFrame: - err = rl.processPushPromise(f) - case *WindowUpdateFrame: - err = rl.processWindowUpdate(f) - case *PingFrame: - err = rl.processPing(f) - default: - cc.logf("Transport: unhandled response frame type %T", f) - } - if err != nil { - return err - } - if rl.closeWhenIdle && gotReply && maybeIdle && len(rl.activeRes) == 0 { - cc.closeIfIdle() - } - } -} - -func (rl *clientConnReadLoop) processHeaders(f *MetaHeadersFrame) error { - cc := rl.cc - cs := cc.streamByID(f.StreamID, f.StreamEnded()) - if cs == nil { - // We'd get here if we canceled a request while the - // server had its response still in flight. So if this - // was just something we canceled, ignore it. - return nil - } - if !cs.firstByte { - if cs.trace != nil { - // TODO(bradfitz): move first response byte earlier, - // when we first read the 9 byte header, not waiting - // until all the HEADERS+CONTINUATION frames have been - // merged. This works for now. - traceFirstResponseByte(cs.trace) - } - cs.firstByte = true - } - if !cs.pastHeaders { - cs.pastHeaders = true - } else { - return rl.processTrailers(cs, f) - } - - res, err := rl.handleResponse(cs, f) - if err != nil { - if _, ok := err.(ConnectionError); ok { - return err - } - // Any other error type is a stream error. - cs.cc.writeStreamReset(f.StreamID, ErrCodeProtocol, err) - cs.resc <- resAndError{err: err} - return nil // return nil from process* funcs to keep conn alive - } - if res == nil { - // (nil, nil) special case. See handleResponse docs. - return nil - } - if res.Body != noBody { - rl.activeRes[cs.ID] = cs - } - cs.resTrailer = &res.Trailer - cs.resc <- resAndError{res: res} - return nil -} - -// may return error types nil, or ConnectionError. Any other error value -// is a StreamError of type ErrCodeProtocol. The returned error in that case -// is the detail. -// -// As a special case, handleResponse may return (nil, nil) to skip the -// frame (currently only used for 100 expect continue). This special -// case is going away after Issue 13851 is fixed. -func (rl *clientConnReadLoop) handleResponse(cs *clientStream, f *MetaHeadersFrame) (*http.Response, error) { - if f.Truncated { - return nil, errResponseHeaderListSize - } - - status := f.PseudoValue("status") - if status == "" { - return nil, errors.New("missing status pseudo header") - } - statusCode, err := strconv.Atoi(status) - if err != nil { - return nil, errors.New("malformed non-numeric status pseudo header") - } - - if statusCode == 100 { - traceGot100Continue(cs.trace) - if cs.on100 != nil { - cs.on100() // forces any write delay timer to fire - } - cs.pastHeaders = false // do it all again - return nil, nil - } - - header := make(http.Header) - res := &http.Response{ - Proto: "HTTP/2.0", - ProtoMajor: 2, - Header: header, - StatusCode: statusCode, - Status: status + " " + http.StatusText(statusCode), - } - for _, hf := range f.RegularFields() { - key := http.CanonicalHeaderKey(hf.Name) - if key == "Trailer" { - t := res.Trailer - if t == nil { - t = make(http.Header) - res.Trailer = t - } - foreachHeaderElement(hf.Value, func(v string) { - t[http.CanonicalHeaderKey(v)] = nil - }) - } else { - header[key] = append(header[key], hf.Value) - } - } - - streamEnded := f.StreamEnded() - isHead := cs.req.Method == "HEAD" - if !streamEnded || isHead { - res.ContentLength = -1 - if clens := res.Header["Content-Length"]; len(clens) == 1 { - if clen64, err := strconv.ParseInt(clens[0], 10, 64); err == nil { - res.ContentLength = clen64 - } else { - // TODO: care? unlike http/1, it won't mess up our framing, so it's - // more safe smuggling-wise to ignore. - } - } else if len(clens) > 1 { - // TODO: care? unlike http/1, it won't mess up our framing, so it's - // more safe smuggling-wise to ignore. - } - } - - if streamEnded || isHead { - res.Body = noBody - return res, nil - } - - buf := new(bytes.Buffer) // TODO(bradfitz): recycle this garbage - cs.bufPipe = pipe{b: buf} - cs.bytesRemain = res.ContentLength - res.Body = transportResponseBody{cs} - go cs.awaitRequestCancel(cs.req) - - if cs.requestedGzip && res.Header.Get("Content-Encoding") == "gzip" { - res.Header.Del("Content-Encoding") - res.Header.Del("Content-Length") - res.ContentLength = -1 - res.Body = &gzipReader{body: res.Body} - setResponseUncompressed(res) - } - return res, nil -} - -func (rl *clientConnReadLoop) processTrailers(cs *clientStream, f *MetaHeadersFrame) error { - if cs.pastTrailers { - // Too many HEADERS frames for this stream. - return ConnectionError(ErrCodeProtocol) - } - cs.pastTrailers = true - if !f.StreamEnded() { - // We expect that any headers for trailers also - // has END_STREAM. - return ConnectionError(ErrCodeProtocol) - } - if len(f.PseudoFields()) > 0 { - // No pseudo header fields are defined for trailers. - // TODO: ConnectionError might be overly harsh? Check. - return ConnectionError(ErrCodeProtocol) - } - - trailer := make(http.Header) - for _, hf := range f.RegularFields() { - key := http.CanonicalHeaderKey(hf.Name) - trailer[key] = append(trailer[key], hf.Value) - } - cs.trailer = trailer - - rl.endStream(cs) - return nil -} - -// transportResponseBody is the concrete type of Transport.RoundTrip's -// Response.Body. It is an io.ReadCloser. On Read, it reads from cs.body. -// On Close it sends RST_STREAM if EOF wasn't already seen. -type transportResponseBody struct { - cs *clientStream -} - -func (b transportResponseBody) Read(p []byte) (n int, err error) { - cs := b.cs - cc := cs.cc - - if cs.readErr != nil { - return 0, cs.readErr - } - n, err = b.cs.bufPipe.Read(p) - if cs.bytesRemain != -1 { - if int64(n) > cs.bytesRemain { - n = int(cs.bytesRemain) - if err == nil { - err = errors.New("net/http: server replied with more than declared Content-Length; truncated") - cc.writeStreamReset(cs.ID, ErrCodeProtocol, err) - } - cs.readErr = err - return int(cs.bytesRemain), err - } - cs.bytesRemain -= int64(n) - if err == io.EOF && cs.bytesRemain > 0 { - err = io.ErrUnexpectedEOF - cs.readErr = err - return n, err - } - } - if n == 0 { - // No flow control tokens to send back. - return - } - - cc.mu.Lock() - defer cc.mu.Unlock() - - var connAdd, streamAdd int32 - // Check the conn-level first, before the stream-level. - if v := cc.inflow.available(); v < transportDefaultConnFlow/2 { - connAdd = transportDefaultConnFlow - v - cc.inflow.add(connAdd) - } - if err == nil { // No need to refresh if the stream is over or failed. - // Consider any buffered body data (read from the conn but not - // consumed by the client) when computing flow control for this - // stream. - v := int(cs.inflow.available()) + cs.bufPipe.Len() - if v < transportDefaultStreamFlow-transportDefaultStreamMinRefresh { - streamAdd = int32(transportDefaultStreamFlow - v) - cs.inflow.add(streamAdd) - } - } - if connAdd != 0 || streamAdd != 0 { - cc.wmu.Lock() - defer cc.wmu.Unlock() - if connAdd != 0 { - cc.fr.WriteWindowUpdate(0, mustUint31(connAdd)) - } - if streamAdd != 0 { - cc.fr.WriteWindowUpdate(cs.ID, mustUint31(streamAdd)) - } - cc.bw.Flush() - } - return -} - -var errClosedResponseBody = errors.New("http2: response body closed") - -func (b transportResponseBody) Close() error { - cs := b.cs - if cs.bufPipe.Err() != io.EOF { - // TODO: write test for this - cs.cc.writeStreamReset(cs.ID, ErrCodeCancel, nil) - } - cs.bufPipe.BreakWithError(errClosedResponseBody) - return nil -} - -func (rl *clientConnReadLoop) processData(f *DataFrame) error { - cc := rl.cc - cs := cc.streamByID(f.StreamID, f.StreamEnded()) - if cs == nil { - cc.mu.Lock() - neverSent := cc.nextStreamID - cc.mu.Unlock() - if f.StreamID >= neverSent { - // We never asked for this. - cc.logf("http2: Transport received unsolicited DATA frame; closing connection") - return ConnectionError(ErrCodeProtocol) - } - // We probably did ask for this, but canceled. Just ignore it. - // TODO: be stricter here? only silently ignore things which - // we canceled, but not things which were closed normally - // by the peer? Tough without accumulating too much state. - return nil - } - if data := f.Data(); len(data) > 0 { - if cs.bufPipe.b == nil { - // Data frame after it's already closed? - cc.logf("http2: Transport received DATA frame for closed stream; closing connection") - return ConnectionError(ErrCodeProtocol) - } - - // Check connection-level flow control. - cc.mu.Lock() - if cs.inflow.available() >= int32(len(data)) { - cs.inflow.take(int32(len(data))) - } else { - cc.mu.Unlock() - return ConnectionError(ErrCodeFlowControl) - } - cc.mu.Unlock() - - if _, err := cs.bufPipe.Write(data); err != nil { - rl.endStreamError(cs, err) - return err - } - } - - if f.StreamEnded() { - rl.endStream(cs) - } - return nil -} - -var errInvalidTrailers = errors.New("http2: invalid trailers") - -func (rl *clientConnReadLoop) endStream(cs *clientStream) { - // TODO: check that any declared content-length matches, like - // server.go's (*stream).endStream method. - rl.endStreamError(cs, nil) -} - -func (rl *clientConnReadLoop) endStreamError(cs *clientStream, err error) { - var code func() - if err == nil { - err = io.EOF - code = cs.copyTrailers - } - cs.bufPipe.closeWithErrorAndCode(err, code) - delete(rl.activeRes, cs.ID) - if cs.req.Close || cs.req.Header.Get("Connection") == "close" { - rl.closeWhenIdle = true - } -} - -func (cs *clientStream) copyTrailers() { - for k, vv := range cs.trailer { - t := cs.resTrailer - if *t == nil { - *t = make(http.Header) - } - (*t)[k] = vv - } -} - -func (rl *clientConnReadLoop) processGoAway(f *GoAwayFrame) error { - cc := rl.cc - cc.t.connPool().MarkDead(cc) - if f.ErrCode != 0 { - // TODO: deal with GOAWAY more. particularly the error code - cc.vlogf("transport got GOAWAY with error code = %v", f.ErrCode) - } - cc.setGoAway(f) - return nil -} - -func (rl *clientConnReadLoop) processSettings(f *SettingsFrame) error { - cc := rl.cc - cc.mu.Lock() - defer cc.mu.Unlock() - return f.ForeachSetting(func(s Setting) error { - switch s.ID { - case SettingMaxFrameSize: - cc.maxFrameSize = s.Val - case SettingMaxConcurrentStreams: - cc.maxConcurrentStreams = s.Val - case SettingInitialWindowSize: - // TODO: error if this is too large. - - // TODO: adjust flow control of still-open - // frames by the difference of the old initial - // window size and this one. - cc.initialWindowSize = s.Val - default: - // TODO(bradfitz): handle more settings? SETTINGS_HEADER_TABLE_SIZE probably. - cc.vlogf("Unhandled Setting: %v", s) - } - return nil - }) -} - -func (rl *clientConnReadLoop) processWindowUpdate(f *WindowUpdateFrame) error { - cc := rl.cc - cs := cc.streamByID(f.StreamID, false) - if f.StreamID != 0 && cs == nil { - return nil - } - - cc.mu.Lock() - defer cc.mu.Unlock() - - fl := &cc.flow - if cs != nil { - fl = &cs.flow - } - if !fl.add(int32(f.Increment)) { - return ConnectionError(ErrCodeFlowControl) - } - cc.cond.Broadcast() - return nil -} - -func (rl *clientConnReadLoop) processResetStream(f *RSTStreamFrame) error { - cs := rl.cc.streamByID(f.StreamID, true) - if cs == nil { - // TODO: return error if server tries to RST_STEAM an idle stream - return nil - } - select { - case <-cs.peerReset: - // Already reset. - // This is the only goroutine - // which closes this, so there - // isn't a race. - default: - err := StreamError{cs.ID, f.ErrCode} - cs.resetErr = err - close(cs.peerReset) - cs.bufPipe.CloseWithError(err) - cs.cc.cond.Broadcast() // wake up checkResetOrDone via clientStream.awaitFlowControl - } - delete(rl.activeRes, cs.ID) - return nil -} - -func (rl *clientConnReadLoop) processPing(f *PingFrame) error { - if f.IsAck() { - // 6.7 PING: " An endpoint MUST NOT respond to PING frames - // containing this flag." - return nil - } - cc := rl.cc - cc.wmu.Lock() - defer cc.wmu.Unlock() - if err := cc.fr.WritePing(true, f.Data); err != nil { - return err - } - return cc.bw.Flush() -} - -func (rl *clientConnReadLoop) processPushPromise(f *PushPromiseFrame) error { - // We told the peer we don't want them. - // Spec says: - // "PUSH_PROMISE MUST NOT be sent if the SETTINGS_ENABLE_PUSH - // setting of the peer endpoint is set to 0. An endpoint that - // has set this setting and has received acknowledgement MUST - // treat the receipt of a PUSH_PROMISE frame as a connection - // error (Section 5.4.1) of type PROTOCOL_ERROR." - return ConnectionError(ErrCodeProtocol) -} - -func (cc *ClientConn) writeStreamReset(streamID uint32, code ErrCode, err error) { - // TODO: do something with err? send it as a debug frame to the peer? - // But that's only in GOAWAY. Invent a new frame type? Is there one already? - cc.wmu.Lock() - cc.fr.WriteRSTStream(streamID, code) - cc.bw.Flush() - cc.wmu.Unlock() -} - -var ( - errResponseHeaderListSize = errors.New("http2: response header list larger than advertised limit") - errPseudoTrailers = errors.New("http2: invalid pseudo header in trailers") -) - -func (cc *ClientConn) logf(format string, args ...interface{}) { - cc.t.logf(format, args...) -} - -func (cc *ClientConn) vlogf(format string, args ...interface{}) { - cc.t.vlogf(format, args...) -} - -func (t *Transport) vlogf(format string, args ...interface{}) { - if VerboseLogs { - t.logf(format, args...) - } -} - -func (t *Transport) logf(format string, args ...interface{}) { - log.Printf(format, args...) -} - -var noBody io.ReadCloser = ioutil.NopCloser(bytes.NewReader(nil)) - -func strSliceContains(ss []string, s string) bool { - for _, v := range ss { - if v == s { - return true - } - } - return false -} - -type erringRoundTripper struct{ err error } - -func (rt erringRoundTripper) RoundTrip(*http.Request) (*http.Response, error) { return nil, rt.err } - -// gzipReader wraps a response body so it can lazily -// call gzip.NewReader on the first call to Read -type gzipReader struct { - body io.ReadCloser // underlying Response.Body - zr *gzip.Reader // lazily-initialized gzip reader - zerr error // sticky error -} - -func (gz *gzipReader) Read(p []byte) (n int, err error) { - if gz.zerr != nil { - return 0, gz.zerr - } - if gz.zr == nil { - gz.zr, err = gzip.NewReader(gz.body) - if err != nil { - gz.zerr = err - return 0, err - } - } - return gz.zr.Read(p) -} - -func (gz *gzipReader) Close() error { - return gz.body.Close() -} - -type errorReader struct{ err error } - -func (r errorReader) Read(p []byte) (int, error) { return 0, r.err } - -// bodyWriterState encapsulates various state around the Transport's writing -// of the request body, particularly regarding doing delayed writes of the body -// when the request contains "Expect: 100-continue". -type bodyWriterState struct { - cs *clientStream - timer *time.Timer // if non-nil, we're doing a delayed write - fnonce *sync.Once // to call fn with - fn func() // the code to run in the goroutine, writing the body - resc chan error // result of fn's execution - delay time.Duration // how long we should delay a delayed write for -} - -func (t *Transport) getBodyWriterState(cs *clientStream, body io.Reader) (s bodyWriterState) { - s.cs = cs - if body == nil { - return - } - resc := make(chan error, 1) - s.resc = resc - s.fn = func() { - resc <- cs.writeRequestBody(body, cs.req.Body) - } - s.delay = t.expectContinueTimeout() - if s.delay == 0 || - !httplex.HeaderValuesContainsToken( - cs.req.Header["Expect"], - "100-continue") { - return - } - s.fnonce = new(sync.Once) - - // Arm the timer with a very large duration, which we'll - // intentionally lower later. It has to be large now because - // we need a handle to it before writing the headers, but the - // s.delay value is defined to not start until after the - // request headers were written. - const hugeDuration = 365 * 24 * time.Hour - s.timer = time.AfterFunc(hugeDuration, func() { - s.fnonce.Do(s.fn) - }) - return -} - -func (s bodyWriterState) cancel() { - if s.timer != nil { - s.timer.Stop() - } -} - -func (s bodyWriterState) on100() { - if s.timer == nil { - // If we didn't do a delayed write, ignore the server's - // bogus 100 continue response. - return - } - s.timer.Stop() - go func() { s.fnonce.Do(s.fn) }() -} - -// scheduleBodyWrite starts writing the body, either immediately (in -// the common case) or after the delay timeout. It should not be -// called until after the headers have been written. -func (s bodyWriterState) scheduleBodyWrite() { - if s.timer == nil { - // We're not doing a delayed write (see - // getBodyWriterState), so just start the writing - // goroutine immediately. - go s.fn() - return - } - traceWait100Continue(s.cs.trace) - if s.timer.Stop() { - s.timer.Reset(s.delay) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/write.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/write.go deleted file mode 100644 index 27ef0dd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/write.go +++ /dev/null @@ -1,264 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import ( - "bytes" - "fmt" - "log" - "net/http" - "time" - - "golang.org/x/net/http2/hpack" - "golang.org/x/net/lex/httplex" -) - -// writeFramer is implemented by any type that is used to write frames. -type writeFramer interface { - writeFrame(writeContext) error -} - -// writeContext is the interface needed by the various frame writer -// types below. All the writeFrame methods below are scheduled via the -// frame writing scheduler (see writeScheduler in writesched.go). -// -// This interface is implemented by *serverConn. -// -// TODO: decide whether to a) use this in the client code (which didn't -// end up using this yet, because it has a simpler design, not -// currently implementing priorities), or b) delete this and -// make the server code a bit more concrete. -type writeContext interface { - Framer() *Framer - Flush() error - CloseConn() error - // HeaderEncoder returns an HPACK encoder that writes to the - // returned buffer. - HeaderEncoder() (*hpack.Encoder, *bytes.Buffer) -} - -// endsStream reports whether the given frame writer w will locally -// close the stream. -func endsStream(w writeFramer) bool { - switch v := w.(type) { - case *writeData: - return v.endStream - case *writeResHeaders: - return v.endStream - case nil: - // This can only happen if the caller reuses w after it's - // been intentionally nil'ed out to prevent use. Keep this - // here to catch future refactoring breaking it. - panic("endsStream called on nil writeFramer") - } - return false -} - -type flushFrameWriter struct{} - -func (flushFrameWriter) writeFrame(ctx writeContext) error { - return ctx.Flush() -} - -type writeSettings []Setting - -func (s writeSettings) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteSettings([]Setting(s)...) -} - -type writeGoAway struct { - maxStreamID uint32 - code ErrCode -} - -func (p *writeGoAway) writeFrame(ctx writeContext) error { - err := ctx.Framer().WriteGoAway(p.maxStreamID, p.code, nil) - if p.code != 0 { - ctx.Flush() // ignore error: we're hanging up on them anyway - time.Sleep(50 * time.Millisecond) - ctx.CloseConn() - } - return err -} - -type writeData struct { - streamID uint32 - p []byte - endStream bool -} - -func (w *writeData) String() string { - return fmt.Sprintf("writeData(stream=%d, p=%d, endStream=%v)", w.streamID, len(w.p), w.endStream) -} - -func (w *writeData) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteData(w.streamID, w.endStream, w.p) -} - -// handlerPanicRST is the message sent from handler goroutines when -// the handler panics. -type handlerPanicRST struct { - StreamID uint32 -} - -func (hp handlerPanicRST) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteRSTStream(hp.StreamID, ErrCodeInternal) -} - -func (se StreamError) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteRSTStream(se.StreamID, se.Code) -} - -type writePingAck struct{ pf *PingFrame } - -func (w writePingAck) writeFrame(ctx writeContext) error { - return ctx.Framer().WritePing(true, w.pf.Data) -} - -type writeSettingsAck struct{} - -func (writeSettingsAck) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteSettingsAck() -} - -// writeResHeaders is a request to write a HEADERS and 0+ CONTINUATION frames -// for HTTP response headers or trailers from a server handler. -type writeResHeaders struct { - streamID uint32 - httpResCode int // 0 means no ":status" line - h http.Header // may be nil - trailers []string // if non-nil, which keys of h to write. nil means all. - endStream bool - - date string - contentType string - contentLength string -} - -func encKV(enc *hpack.Encoder, k, v string) { - if VerboseLogs { - log.Printf("http2: server encoding header %q = %q", k, v) - } - enc.WriteField(hpack.HeaderField{Name: k, Value: v}) -} - -func (w *writeResHeaders) writeFrame(ctx writeContext) error { - enc, buf := ctx.HeaderEncoder() - buf.Reset() - - if w.httpResCode != 0 { - encKV(enc, ":status", httpCodeString(w.httpResCode)) - } - - encodeHeaders(enc, w.h, w.trailers) - - if w.contentType != "" { - encKV(enc, "content-type", w.contentType) - } - if w.contentLength != "" { - encKV(enc, "content-length", w.contentLength) - } - if w.date != "" { - encKV(enc, "date", w.date) - } - - headerBlock := buf.Bytes() - if len(headerBlock) == 0 && w.trailers == nil { - panic("unexpected empty hpack") - } - - // For now we're lazy and just pick the minimum MAX_FRAME_SIZE - // that all peers must support (16KB). Later we could care - // more and send larger frames if the peer advertised it, but - // there's little point. Most headers are small anyway (so we - // generally won't have CONTINUATION frames), and extra frames - // only waste 9 bytes anyway. - const maxFrameSize = 16384 - - first := true - for len(headerBlock) > 0 { - frag := headerBlock - if len(frag) > maxFrameSize { - frag = frag[:maxFrameSize] - } - headerBlock = headerBlock[len(frag):] - endHeaders := len(headerBlock) == 0 - var err error - if first { - first = false - err = ctx.Framer().WriteHeaders(HeadersFrameParam{ - StreamID: w.streamID, - BlockFragment: frag, - EndStream: w.endStream, - EndHeaders: endHeaders, - }) - } else { - err = ctx.Framer().WriteContinuation(w.streamID, endHeaders, frag) - } - if err != nil { - return err - } - } - return nil -} - -type write100ContinueHeadersFrame struct { - streamID uint32 -} - -func (w write100ContinueHeadersFrame) writeFrame(ctx writeContext) error { - enc, buf := ctx.HeaderEncoder() - buf.Reset() - encKV(enc, ":status", "100") - return ctx.Framer().WriteHeaders(HeadersFrameParam{ - StreamID: w.streamID, - BlockFragment: buf.Bytes(), - EndStream: false, - EndHeaders: true, - }) -} - -type writeWindowUpdate struct { - streamID uint32 // or 0 for conn-level - n uint32 -} - -func (wu writeWindowUpdate) writeFrame(ctx writeContext) error { - return ctx.Framer().WriteWindowUpdate(wu.streamID, wu.n) -} - -func encodeHeaders(enc *hpack.Encoder, h http.Header, keys []string) { - if keys == nil { - sorter := sorterPool.Get().(*sorter) - // Using defer here, since the returned keys from the - // sorter.Keys method is only valid until the sorter - // is returned: - defer sorterPool.Put(sorter) - keys = sorter.Keys(h) - } - for _, k := range keys { - vv := h[k] - k = lowerHeader(k) - if !validWireHeaderFieldName(k) { - // Skip it as backup paranoia. Per - // golang.org/issue/14048, these should - // already be rejected at a higher level. - continue - } - isTE := k == "transfer-encoding" - for _, v := range vv { - if !httplex.ValidHeaderFieldValue(v) { - // TODO: return an error? golang.org/issue/14048 - // For now just omit it. - continue - } - // TODO: more of "8.1.2.2 Connection-Specific Header Fields" - if isTE && v != "trailers" { - continue - } - encKV(enc, k, v) - } - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/writesched.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/writesched.go deleted file mode 100644 index c24316c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/http2/writesched.go +++ /dev/null @@ -1,283 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package http2 - -import "fmt" - -// frameWriteMsg is a request to write a frame. -type frameWriteMsg struct { - // write is the interface value that does the writing, once the - // writeScheduler (below) has decided to select this frame - // to write. The write functions are all defined in write.go. - write writeFramer - - stream *stream // used for prioritization. nil for non-stream frames. - - // done, if non-nil, must be a buffered channel with space for - // 1 message and is sent the return value from write (or an - // earlier error) when the frame has been written. - done chan error -} - -// for debugging only: -func (wm frameWriteMsg) String() string { - var streamID uint32 - if wm.stream != nil { - streamID = wm.stream.id - } - var des string - if s, ok := wm.write.(fmt.Stringer); ok { - des = s.String() - } else { - des = fmt.Sprintf("%T", wm.write) - } - return fmt.Sprintf("[frameWriteMsg stream=%d, ch=%v, type: %v]", streamID, wm.done != nil, des) -} - -// writeScheduler tracks pending frames to write, priorities, and decides -// the next one to use. It is not thread-safe. -type writeScheduler struct { - // zero are frames not associated with a specific stream. - // They're sent before any stream-specific freams. - zero writeQueue - - // maxFrameSize is the maximum size of a DATA frame - // we'll write. Must be non-zero and between 16K-16M. - maxFrameSize uint32 - - // sq contains the stream-specific queues, keyed by stream ID. - // when a stream is idle, it's deleted from the map. - sq map[uint32]*writeQueue - - // canSend is a slice of memory that's reused between frame - // scheduling decisions to hold the list of writeQueues (from sq) - // which have enough flow control data to send. After canSend is - // built, the best is selected. - canSend []*writeQueue - - // pool of empty queues for reuse. - queuePool []*writeQueue -} - -func (ws *writeScheduler) putEmptyQueue(q *writeQueue) { - if len(q.s) != 0 { - panic("queue must be empty") - } - ws.queuePool = append(ws.queuePool, q) -} - -func (ws *writeScheduler) getEmptyQueue() *writeQueue { - ln := len(ws.queuePool) - if ln == 0 { - return new(writeQueue) - } - q := ws.queuePool[ln-1] - ws.queuePool = ws.queuePool[:ln-1] - return q -} - -func (ws *writeScheduler) empty() bool { return ws.zero.empty() && len(ws.sq) == 0 } - -func (ws *writeScheduler) add(wm frameWriteMsg) { - st := wm.stream - if st == nil { - ws.zero.push(wm) - } else { - ws.streamQueue(st.id).push(wm) - } -} - -func (ws *writeScheduler) streamQueue(streamID uint32) *writeQueue { - if q, ok := ws.sq[streamID]; ok { - return q - } - if ws.sq == nil { - ws.sq = make(map[uint32]*writeQueue) - } - q := ws.getEmptyQueue() - ws.sq[streamID] = q - return q -} - -// take returns the most important frame to write and removes it from the scheduler. -// It is illegal to call this if the scheduler is empty or if there are no connection-level -// flow control bytes available. -func (ws *writeScheduler) take() (wm frameWriteMsg, ok bool) { - if ws.maxFrameSize == 0 { - panic("internal error: ws.maxFrameSize not initialized or invalid") - } - - // If there any frames not associated with streams, prefer those first. - // These are usually SETTINGS, etc. - if !ws.zero.empty() { - return ws.zero.shift(), true - } - if len(ws.sq) == 0 { - return - } - - // Next, prioritize frames on streams that aren't DATA frames (no cost). - for id, q := range ws.sq { - if q.firstIsNoCost() { - return ws.takeFrom(id, q) - } - } - - // Now, all that remains are DATA frames with non-zero bytes to - // send. So pick the best one. - if len(ws.canSend) != 0 { - panic("should be empty") - } - for _, q := range ws.sq { - if n := ws.streamWritableBytes(q); n > 0 { - ws.canSend = append(ws.canSend, q) - } - } - if len(ws.canSend) == 0 { - return - } - defer ws.zeroCanSend() - - // TODO: find the best queue - q := ws.canSend[0] - - return ws.takeFrom(q.streamID(), q) -} - -// zeroCanSend is defered from take. -func (ws *writeScheduler) zeroCanSend() { - for i := range ws.canSend { - ws.canSend[i] = nil - } - ws.canSend = ws.canSend[:0] -} - -// streamWritableBytes returns the number of DATA bytes we could write -// from the given queue's stream, if this stream/queue were -// selected. It is an error to call this if q's head isn't a -// *writeData. -func (ws *writeScheduler) streamWritableBytes(q *writeQueue) int32 { - wm := q.head() - ret := wm.stream.flow.available() // max we can write - if ret == 0 { - return 0 - } - if int32(ws.maxFrameSize) < ret { - ret = int32(ws.maxFrameSize) - } - if ret == 0 { - panic("internal error: ws.maxFrameSize not initialized or invalid") - } - wd := wm.write.(*writeData) - if len(wd.p) < int(ret) { - ret = int32(len(wd.p)) - } - return ret -} - -func (ws *writeScheduler) takeFrom(id uint32, q *writeQueue) (wm frameWriteMsg, ok bool) { - wm = q.head() - // If the first item in this queue costs flow control tokens - // and we don't have enough, write as much as we can. - if wd, ok := wm.write.(*writeData); ok && len(wd.p) > 0 { - allowed := wm.stream.flow.available() // max we can write - if allowed == 0 { - // No quota available. Caller can try the next stream. - return frameWriteMsg{}, false - } - if int32(ws.maxFrameSize) < allowed { - allowed = int32(ws.maxFrameSize) - } - // TODO: further restrict the allowed size, because even if - // the peer says it's okay to write 16MB data frames, we might - // want to write smaller ones to properly weight competing - // streams' priorities. - - if len(wd.p) > int(allowed) { - wm.stream.flow.take(allowed) - chunk := wd.p[:allowed] - wd.p = wd.p[allowed:] - // Make up a new write message of a valid size, rather - // than shifting one off the queue. - return frameWriteMsg{ - stream: wm.stream, - write: &writeData{ - streamID: wd.streamID, - p: chunk, - // even if the original had endStream set, there - // arebytes remaining because len(wd.p) > allowed, - // so we know endStream is false: - endStream: false, - }, - // our caller is blocking on the final DATA frame, not - // these intermediates, so no need to wait: - done: nil, - }, true - } - wm.stream.flow.take(int32(len(wd.p))) - } - - q.shift() - if q.empty() { - ws.putEmptyQueue(q) - delete(ws.sq, id) - } - return wm, true -} - -func (ws *writeScheduler) forgetStream(id uint32) { - q, ok := ws.sq[id] - if !ok { - return - } - delete(ws.sq, id) - - // But keep it for others later. - for i := range q.s { - q.s[i] = frameWriteMsg{} - } - q.s = q.s[:0] - ws.putEmptyQueue(q) -} - -type writeQueue struct { - s []frameWriteMsg -} - -// streamID returns the stream ID for a non-empty stream-specific queue. -func (q *writeQueue) streamID() uint32 { return q.s[0].stream.id } - -func (q *writeQueue) empty() bool { return len(q.s) == 0 } - -func (q *writeQueue) push(wm frameWriteMsg) { - q.s = append(q.s, wm) -} - -// head returns the next item that would be removed by shift. -func (q *writeQueue) head() frameWriteMsg { - if len(q.s) == 0 { - panic("invalid use of queue") - } - return q.s[0] -} - -func (q *writeQueue) shift() frameWriteMsg { - if len(q.s) == 0 { - panic("invalid use of queue") - } - wm := q.s[0] - // TODO: less copy-happy queue. - copy(q.s, q.s[1:]) - q.s[len(q.s)-1] = frameWriteMsg{} - q.s = q.s[:len(q.s)-1] - return wm -} - -func (q *writeQueue) firstIsNoCost() bool { - if df, ok := q.s[0].write.(*writeData); ok { - return len(df.p) == 0 - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/idna.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/idna.go deleted file mode 100644 index 35ff39d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/idna.go +++ /dev/null @@ -1,68 +0,0 @@ -// Copyright 2012 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package idna implements IDNA2008 (Internationalized Domain Names for -// Applications), defined in RFC 5890, RFC 5891, RFC 5892, RFC 5893 and -// RFC 5894. -package idna - -import ( - "strings" - "unicode/utf8" -) - -// TODO(nigeltao): specify when errors occur. For example, is ToASCII(".") or -// ToASCII("foo\x00") an error? See also http://www.unicode.org/faq/idn.html#11 - -// acePrefix is the ASCII Compatible Encoding prefix. -const acePrefix = "xn--" - -// ToASCII converts a domain or domain label to its ASCII form. For example, -// ToASCII("bücher.example.com") is "xn--bcher-kva.example.com", and -// ToASCII("golang") is "golang". -func ToASCII(s string) (string, error) { - if ascii(s) { - return s, nil - } - labels := strings.Split(s, ".") - for i, label := range labels { - if !ascii(label) { - a, err := encode(acePrefix, label) - if err != nil { - return "", err - } - labels[i] = a - } - } - return strings.Join(labels, "."), nil -} - -// ToUnicode converts a domain or domain label to its Unicode form. For example, -// ToUnicode("xn--bcher-kva.example.com") is "bücher.example.com", and -// ToUnicode("golang") is "golang". -func ToUnicode(s string) (string, error) { - if !strings.Contains(s, acePrefix) { - return s, nil - } - labels := strings.Split(s, ".") - for i, label := range labels { - if strings.HasPrefix(label, acePrefix) { - u, err := decode(label[len(acePrefix):]) - if err != nil { - return "", err - } - labels[i] = u - } - } - return strings.Join(labels, "."), nil -} - -func ascii(s string) bool { - for i := 0; i < len(s); i++ { - if s[i] >= utf8.RuneSelf { - return false - } - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/punycode.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/punycode.go deleted file mode 100644 index 92e733f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/idna/punycode.go +++ /dev/null @@ -1,200 +0,0 @@ -// Copyright 2012 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package idna - -// This file implements the Punycode algorithm from RFC 3492. - -import ( - "fmt" - "math" - "strings" - "unicode/utf8" -) - -// These parameter values are specified in section 5. -// -// All computation is done with int32s, so that overflow behavior is identical -// regardless of whether int is 32-bit or 64-bit. -const ( - base int32 = 36 - damp int32 = 700 - initialBias int32 = 72 - initialN int32 = 128 - skew int32 = 38 - tmax int32 = 26 - tmin int32 = 1 -) - -// decode decodes a string as specified in section 6.2. -func decode(encoded string) (string, error) { - if encoded == "" { - return "", nil - } - pos := 1 + strings.LastIndex(encoded, "-") - if pos == 1 { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - if pos == len(encoded) { - return encoded[:len(encoded)-1], nil - } - output := make([]rune, 0, len(encoded)) - if pos != 0 { - for _, r := range encoded[:pos-1] { - output = append(output, r) - } - } - i, n, bias := int32(0), initialN, initialBias - for pos < len(encoded) { - oldI, w := i, int32(1) - for k := base; ; k += base { - if pos == len(encoded) { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - digit, ok := decodeDigit(encoded[pos]) - if !ok { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - pos++ - i += digit * w - if i < 0 { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - t := k - bias - if t < tmin { - t = tmin - } else if t > tmax { - t = tmax - } - if digit < t { - break - } - w *= base - t - if w >= math.MaxInt32/base { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - } - x := int32(len(output) + 1) - bias = adapt(i-oldI, x, oldI == 0) - n += i / x - i %= x - if n > utf8.MaxRune || len(output) >= 1024 { - return "", fmt.Errorf("idna: invalid label %q", encoded) - } - output = append(output, 0) - copy(output[i+1:], output[i:]) - output[i] = n - i++ - } - return string(output), nil -} - -// encode encodes a string as specified in section 6.3 and prepends prefix to -// the result. -// -// The "while h < length(input)" line in the specification becomes "for -// remaining != 0" in the Go code, because len(s) in Go is in bytes, not runes. -func encode(prefix, s string) (string, error) { - output := make([]byte, len(prefix), len(prefix)+1+2*len(s)) - copy(output, prefix) - delta, n, bias := int32(0), initialN, initialBias - b, remaining := int32(0), int32(0) - for _, r := range s { - if r < 0x80 { - b++ - output = append(output, byte(r)) - } else { - remaining++ - } - } - h := b - if b > 0 { - output = append(output, '-') - } - for remaining != 0 { - m := int32(0x7fffffff) - for _, r := range s { - if m > r && r >= n { - m = r - } - } - delta += (m - n) * (h + 1) - if delta < 0 { - return "", fmt.Errorf("idna: invalid label %q", s) - } - n = m - for _, r := range s { - if r < n { - delta++ - if delta < 0 { - return "", fmt.Errorf("idna: invalid label %q", s) - } - continue - } - if r > n { - continue - } - q := delta - for k := base; ; k += base { - t := k - bias - if t < tmin { - t = tmin - } else if t > tmax { - t = tmax - } - if q < t { - break - } - output = append(output, encodeDigit(t+(q-t)%(base-t))) - q = (q - t) / (base - t) - } - output = append(output, encodeDigit(q)) - bias = adapt(delta, h+1, h == b) - delta = 0 - h++ - remaining-- - } - delta++ - n++ - } - return string(output), nil -} - -func decodeDigit(x byte) (digit int32, ok bool) { - switch { - case '0' <= x && x <= '9': - return int32(x - ('0' - 26)), true - case 'A' <= x && x <= 'Z': - return int32(x - 'A'), true - case 'a' <= x && x <= 'z': - return int32(x - 'a'), true - } - return 0, false -} - -func encodeDigit(digit int32) byte { - switch { - case 0 <= digit && digit < 26: - return byte(digit + 'a') - case 26 <= digit && digit < 36: - return byte(digit + ('0' - 26)) - } - panic("idna: internal error in punycode encoding") -} - -// adapt is the bias adaptation function specified in section 6.1. -func adapt(delta, numPoints int32, firstTime bool) int32 { - if firstTime { - delta /= damp - } else { - delta /= 2 - } - delta += delta / numPoints - k := int32(0) - for delta > ((base-tmin)*tmax)/2 { - delta /= base - tmin - k += base - } - return k + (base-tmin+1)*delta/(delta+skew) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/lex/httplex/httplex.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/lex/httplex/httplex.go deleted file mode 100644 index bd0ec24..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/net/lex/httplex/httplex.go +++ /dev/null @@ -1,312 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package httplex contains rules around lexical matters of various -// HTTP-related specifications. -// -// This package is shared by the standard library (which vendors it) -// and x/net/http2. It comes with no API stability promise. -package httplex - -import ( - "strings" - "unicode/utf8" -) - -var isTokenTable = [127]bool{ - '!': true, - '#': true, - '$': true, - '%': true, - '&': true, - '\'': true, - '*': true, - '+': true, - '-': true, - '.': true, - '0': true, - '1': true, - '2': true, - '3': true, - '4': true, - '5': true, - '6': true, - '7': true, - '8': true, - '9': true, - 'A': true, - 'B': true, - 'C': true, - 'D': true, - 'E': true, - 'F': true, - 'G': true, - 'H': true, - 'I': true, - 'J': true, - 'K': true, - 'L': true, - 'M': true, - 'N': true, - 'O': true, - 'P': true, - 'Q': true, - 'R': true, - 'S': true, - 'T': true, - 'U': true, - 'W': true, - 'V': true, - 'X': true, - 'Y': true, - 'Z': true, - '^': true, - '_': true, - '`': true, - 'a': true, - 'b': true, - 'c': true, - 'd': true, - 'e': true, - 'f': true, - 'g': true, - 'h': true, - 'i': true, - 'j': true, - 'k': true, - 'l': true, - 'm': true, - 'n': true, - 'o': true, - 'p': true, - 'q': true, - 'r': true, - 's': true, - 't': true, - 'u': true, - 'v': true, - 'w': true, - 'x': true, - 'y': true, - 'z': true, - '|': true, - '~': true, -} - -func IsTokenRune(r rune) bool { - i := int(r) - return i < len(isTokenTable) && isTokenTable[i] -} - -func isNotToken(r rune) bool { - return !IsTokenRune(r) -} - -// HeaderValuesContainsToken reports whether any string in values -// contains the provided token, ASCII case-insensitively. -func HeaderValuesContainsToken(values []string, token string) bool { - for _, v := range values { - if headerValueContainsToken(v, token) { - return true - } - } - return false -} - -// isOWS reports whether b is an optional whitespace byte, as defined -// by RFC 7230 section 3.2.3. -func isOWS(b byte) bool { return b == ' ' || b == '\t' } - -// trimOWS returns x with all optional whitespace removes from the -// beginning and end. -func trimOWS(x string) string { - // TODO: consider using strings.Trim(x, " \t") instead, - // if and when it's fast enough. See issue 10292. - // But this ASCII-only code will probably always beat UTF-8 - // aware code. - for len(x) > 0 && isOWS(x[0]) { - x = x[1:] - } - for len(x) > 0 && isOWS(x[len(x)-1]) { - x = x[:len(x)-1] - } - return x -} - -// headerValueContainsToken reports whether v (assumed to be a -// 0#element, in the ABNF extension described in RFC 7230 section 7) -// contains token amongst its comma-separated tokens, ASCII -// case-insensitively. -func headerValueContainsToken(v string, token string) bool { - v = trimOWS(v) - if comma := strings.IndexByte(v, ','); comma != -1 { - return tokenEqual(trimOWS(v[:comma]), token) || headerValueContainsToken(v[comma+1:], token) - } - return tokenEqual(v, token) -} - -// lowerASCII returns the ASCII lowercase version of b. -func lowerASCII(b byte) byte { - if 'A' <= b && b <= 'Z' { - return b + ('a' - 'A') - } - return b -} - -// tokenEqual reports whether t1 and t2 are equal, ASCII case-insensitively. -func tokenEqual(t1, t2 string) bool { - if len(t1) != len(t2) { - return false - } - for i, b := range t1 { - if b >= utf8.RuneSelf { - // No UTF-8 or non-ASCII allowed in tokens. - return false - } - if lowerASCII(byte(b)) != lowerASCII(t2[i]) { - return false - } - } - return true -} - -// isLWS reports whether b is linear white space, according -// to http://www.w3.org/Protocols/rfc2616/rfc2616-sec2.html#sec2.2 -// LWS = [CRLF] 1*( SP | HT ) -func isLWS(b byte) bool { return b == ' ' || b == '\t' } - -// isCTL reports whether b is a control byte, according -// to http://www.w3.org/Protocols/rfc2616/rfc2616-sec2.html#sec2.2 -// CTL = -func isCTL(b byte) bool { - const del = 0x7f // a CTL - return b < ' ' || b == del -} - -// ValidHeaderFieldName reports whether v is a valid HTTP/1.x header name. -// HTTP/2 imposes the additional restriction that uppercase ASCII -// letters are not allowed. -// -// RFC 7230 says: -// header-field = field-name ":" OWS field-value OWS -// field-name = token -// token = 1*tchar -// tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*" / "+" / "-" / "." / -// "^" / "_" / "`" / "|" / "~" / DIGIT / ALPHA -func ValidHeaderFieldName(v string) bool { - if len(v) == 0 { - return false - } - for _, r := range v { - if !IsTokenRune(r) { - return false - } - } - return true -} - -// ValidHostHeader reports whether h is a valid host header. -func ValidHostHeader(h string) bool { - // The latest spec is actually this: - // - // http://tools.ietf.org/html/rfc7230#section-5.4 - // Host = uri-host [ ":" port ] - // - // Where uri-host is: - // http://tools.ietf.org/html/rfc3986#section-3.2.2 - // - // But we're going to be much more lenient for now and just - // search for any byte that's not a valid byte in any of those - // expressions. - for i := 0; i < len(h); i++ { - if !validHostByte[h[i]] { - return false - } - } - return true -} - -// See the validHostHeader comment. -var validHostByte = [256]bool{ - '0': true, '1': true, '2': true, '3': true, '4': true, '5': true, '6': true, '7': true, - '8': true, '9': true, - - 'a': true, 'b': true, 'c': true, 'd': true, 'e': true, 'f': true, 'g': true, 'h': true, - 'i': true, 'j': true, 'k': true, 'l': true, 'm': true, 'n': true, 'o': true, 'p': true, - 'q': true, 'r': true, 's': true, 't': true, 'u': true, 'v': true, 'w': true, 'x': true, - 'y': true, 'z': true, - - 'A': true, 'B': true, 'C': true, 'D': true, 'E': true, 'F': true, 'G': true, 'H': true, - 'I': true, 'J': true, 'K': true, 'L': true, 'M': true, 'N': true, 'O': true, 'P': true, - 'Q': true, 'R': true, 'S': true, 'T': true, 'U': true, 'V': true, 'W': true, 'X': true, - 'Y': true, 'Z': true, - - '!': true, // sub-delims - '$': true, // sub-delims - '%': true, // pct-encoded (and used in IPv6 zones) - '&': true, // sub-delims - '(': true, // sub-delims - ')': true, // sub-delims - '*': true, // sub-delims - '+': true, // sub-delims - ',': true, // sub-delims - '-': true, // unreserved - '.': true, // unreserved - ':': true, // IPv6address + Host expression's optional port - ';': true, // sub-delims - '=': true, // sub-delims - '[': true, - '\'': true, // sub-delims - ']': true, - '_': true, // unreserved - '~': true, // unreserved -} - -// ValidHeaderFieldValue reports whether v is a valid "field-value" according to -// http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.2 : -// -// message-header = field-name ":" [ field-value ] -// field-value = *( field-content | LWS ) -// field-content = -// -// http://www.w3.org/Protocols/rfc2616/rfc2616-sec2.html#sec2.2 : -// -// TEXT = -// LWS = [CRLF] 1*( SP | HT ) -// CTL = -// -// RFC 7230 says: -// field-value = *( field-content / obs-fold ) -// obj-fold = N/A to http2, and deprecated -// field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ] -// field-vchar = VCHAR / obs-text -// obs-text = %x80-FF -// VCHAR = "any visible [USASCII] character" -// -// http2 further says: "Similarly, HTTP/2 allows header field values -// that are not valid. While most of the values that can be encoded -// will not alter header field parsing, carriage return (CR, ASCII -// 0xd), line feed (LF, ASCII 0xa), and the zero character (NUL, ASCII -// 0x0) might be exploited by an attacker if they are translated -// verbatim. Any request or response that contains a character not -// permitted in a header field value MUST be treated as malformed -// (Section 8.1.2.6). Valid characters are defined by the -// field-content ABNF rule in Section 3.2 of [RFC7230]." -// -// This function does not (yet?) properly handle the rejection of -// strings that begin or end with SP or HTAB. -func ValidHeaderFieldValue(v string) bool { - for i := 0; i < len(v); i++ { - b := v[i] - if isCTL(b) && !isLWS(b) { - return false - } - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/.travis.yml b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/.travis.yml deleted file mode 100644 index fa139db..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/.travis.yml +++ /dev/null @@ -1,13 +0,0 @@ -language: go - -go: - - tip - -install: - - export GOPATH="$HOME/gopath" - - mkdir -p "$GOPATH/src/golang.org/x" - - mv "$TRAVIS_BUILD_DIR" "$GOPATH/src/golang.org/x/oauth2" - - go get -v -t -d golang.org/x/oauth2/... - -script: - - go test -v golang.org/x/oauth2/... diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/AUTHORS b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/AUTHORS deleted file mode 100644 index 15167cd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/AUTHORS +++ /dev/null @@ -1,3 +0,0 @@ -# This source code refers to The Go Authors for copyright purposes. -# The master list of authors is in the main Go distribution, -# visible at http://tip.golang.org/AUTHORS. diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTING.md b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTING.md deleted file mode 100644 index 46aa2b1..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTING.md +++ /dev/null @@ -1,31 +0,0 @@ -# Contributing to Go - -Go is an open source project. - -It is the work of hundreds of contributors. We appreciate your help! - - -## Filing issues - -When [filing an issue](https://github.com/golang/oauth2/issues), make sure to answer these five questions: - -1. What version of Go are you using (`go version`)? -2. What operating system and processor architecture are you using? -3. What did you do? -4. What did you expect to see? -5. What did you see instead? - -General questions should go to the [golang-nuts mailing list](https://groups.google.com/group/golang-nuts) instead of the issue tracker. -The gophers there will answer or ask you to file an issue if you've tripped over a bug. - -## Contributing code - -Please read the [Contribution Guidelines](https://golang.org/doc/contribute.html) -before sending patches. - -**We do not accept GitHub pull requests** -(we use [Gerrit](https://code.google.com/p/gerrit/) instead for code review). - -Unless otherwise noted, the Go source files are distributed under -the BSD-style license found in the LICENSE file. - diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTORS b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTORS deleted file mode 100644 index 1c4577e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/CONTRIBUTORS +++ /dev/null @@ -1,3 +0,0 @@ -# This source code was written by the Go contributors. -# The master list of contributors is in the main Go distribution, -# visible at http://tip.golang.org/CONTRIBUTORS. diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/LICENSE b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/LICENSE deleted file mode 100644 index d02f24f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/LICENSE +++ /dev/null @@ -1,27 +0,0 @@ -Copyright (c) 2009 The oauth2 Authors. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/README.md b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/README.md deleted file mode 100644 index 1643c08..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/README.md +++ /dev/null @@ -1,65 +0,0 @@ -# OAuth2 for Go - -[![Build Status](https://travis-ci.org/golang/oauth2.svg?branch=master)](https://travis-ci.org/golang/oauth2) -[![GoDoc](https://godoc.org/golang.org/x/oauth2?status.svg)](https://godoc.org/golang.org/x/oauth2) - -oauth2 package contains a client implementation for OAuth 2.0 spec. - -## Installation - -~~~~ -go get golang.org/x/oauth2 -~~~~ - -See godoc for further documentation and examples. - -* [godoc.org/golang.org/x/oauth2](http://godoc.org/golang.org/x/oauth2) -* [godoc.org/golang.org/x/oauth2/google](http://godoc.org/golang.org/x/oauth2/google) - - -## App Engine - -In change 96e89be (March 2015) we removed the `oauth2.Context2` type in favor -of the [`context.Context`](https://golang.org/x/net/context#Context) type from -the `golang.org/x/net/context` package - -This means its no longer possible to use the "Classic App Engine" -`appengine.Context` type with the `oauth2` package. (You're using -Classic App Engine if you import the package `"appengine"`.) - -To work around this, you may use the new `"google.golang.org/appengine"` -package. This package has almost the same API as the `"appengine"` package, -but it can be fetched with `go get` and used on "Managed VMs" and well as -Classic App Engine. - -See the [new `appengine` package's readme](https://github.com/golang/appengine#updating-a-go-app-engine-app) -for information on updating your app. - -If you don't want to update your entire app to use the new App Engine packages, -you may use both sets of packages in parallel, using only the new packages -with the `oauth2` package. - - import ( - "golang.org/x/net/context" - "golang.org/x/oauth2" - "golang.org/x/oauth2/google" - newappengine "google.golang.org/appengine" - newurlfetch "google.golang.org/appengine/urlfetch" - - "appengine" - ) - - func handler(w http.ResponseWriter, r *http.Request) { - var c appengine.Context = appengine.NewContext(r) - c.Infof("Logging a message with the old package") - - var ctx context.Context = newappengine.NewContext(r) - client := &http.Client{ - Transport: &oauth2.Transport{ - Source: google.AppEngineTokenSource(ctx, "scope"), - Base: &newurlfetch.Transport{Context: ctx}, - }, - } - client.Get("...") - } - diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/client_appengine.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/client_appengine.go deleted file mode 100644 index 8962c49..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/client_appengine.go +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build appengine - -// App Engine hooks. - -package oauth2 - -import ( - "net/http" - - "golang.org/x/net/context" - "golang.org/x/oauth2/internal" - "google.golang.org/appengine/urlfetch" -) - -func init() { - internal.RegisterContextClientFunc(contextClientAppEngine) -} - -func contextClientAppEngine(ctx context.Context) (*http.Client, error) { - return urlfetch.Client(ctx), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine.go deleted file mode 100644 index dc993ef..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine.go +++ /dev/null @@ -1,86 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package google - -import ( - "sort" - "strings" - "sync" - "time" - - "golang.org/x/net/context" - "golang.org/x/oauth2" -) - -// Set at init time by appenginevm_hook.go. If true, we are on App Engine Managed VMs. -var appengineVM bool - -// Set at init time by appengine_hook.go. If nil, we're not on App Engine. -var appengineTokenFunc func(c context.Context, scopes ...string) (token string, expiry time.Time, err error) - -// AppEngineTokenSource returns a token source that fetches tokens -// issued to the current App Engine application's service account. -// If you are implementing a 3-legged OAuth 2.0 flow on App Engine -// that involves user accounts, see oauth2.Config instead. -// -// The provided context must have come from appengine.NewContext. -func AppEngineTokenSource(ctx context.Context, scope ...string) oauth2.TokenSource { - if appengineTokenFunc == nil { - panic("google: AppEngineTokenSource can only be used on App Engine.") - } - scopes := append([]string{}, scope...) - sort.Strings(scopes) - return &appEngineTokenSource{ - ctx: ctx, - scopes: scopes, - key: strings.Join(scopes, " "), - } -} - -// aeTokens helps the fetched tokens to be reused until their expiration. -var ( - aeTokensMu sync.Mutex - aeTokens = make(map[string]*tokenLock) // key is space-separated scopes -) - -type tokenLock struct { - mu sync.Mutex // guards t; held while fetching or updating t - t *oauth2.Token -} - -type appEngineTokenSource struct { - ctx context.Context - scopes []string - key string // to aeTokens map; space-separated scopes -} - -func (ts *appEngineTokenSource) Token() (*oauth2.Token, error) { - if appengineTokenFunc == nil { - panic("google: AppEngineTokenSource can only be used on App Engine.") - } - - aeTokensMu.Lock() - tok, ok := aeTokens[ts.key] - if !ok { - tok = &tokenLock{} - aeTokens[ts.key] = tok - } - aeTokensMu.Unlock() - - tok.mu.Lock() - defer tok.mu.Unlock() - if tok.t.Valid() { - return tok.t, nil - } - access, exp, err := appengineTokenFunc(ts.ctx, ts.scopes...) - if err != nil { - return nil, err - } - tok.t = &oauth2.Token{ - AccessToken: access, - Expiry: exp, - } - return tok.t, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine_hook.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine_hook.go deleted file mode 100644 index 4f42c8b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appengine_hook.go +++ /dev/null @@ -1,13 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build appengine - -package google - -import "google.golang.org/appengine" - -func init() { - appengineTokenFunc = appengine.AccessToken -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appenginevm_hook.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appenginevm_hook.go deleted file mode 100644 index 633611c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/appenginevm_hook.go +++ /dev/null @@ -1,14 +0,0 @@ -// Copyright 2015 The oauth2 Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build appenginevm - -package google - -import "google.golang.org/appengine" - -func init() { - appengineVM = true - appengineTokenFunc = appengine.AccessToken -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/default.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/default.go deleted file mode 100644 index 565d731..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/default.go +++ /dev/null @@ -1,155 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package google - -import ( - "encoding/json" - "errors" - "fmt" - "io/ioutil" - "net/http" - "os" - "path/filepath" - "runtime" - - "cloud.google.com/go/compute/metadata" - "golang.org/x/net/context" - "golang.org/x/oauth2" - "golang.org/x/oauth2/jwt" -) - -// DefaultClient returns an HTTP Client that uses the -// DefaultTokenSource to obtain authentication credentials. -// -// This client should be used when developing services -// that run on Google App Engine or Google Compute Engine -// and use "Application Default Credentials." -// -// For more details, see: -// https://developers.google.com/accounts/docs/application-default-credentials -// -func DefaultClient(ctx context.Context, scope ...string) (*http.Client, error) { - ts, err := DefaultTokenSource(ctx, scope...) - if err != nil { - return nil, err - } - return oauth2.NewClient(ctx, ts), nil -} - -// DefaultTokenSource is a token source that uses -// "Application Default Credentials". -// -// It looks for credentials in the following places, -// preferring the first location found: -// -// 1. A JSON file whose path is specified by the -// GOOGLE_APPLICATION_CREDENTIALS environment variable. -// 2. A JSON file in a location known to the gcloud command-line tool. -// On Windows, this is %APPDATA%/gcloud/application_default_credentials.json. -// On other systems, $HOME/.config/gcloud/application_default_credentials.json. -// 3. On Google App Engine it uses the appengine.AccessToken function. -// 4. On Google Compute Engine and Google App Engine Managed VMs, it fetches -// credentials from the metadata server. -// (In this final case any provided scopes are ignored.) -// -// For more details, see: -// https://developers.google.com/accounts/docs/application-default-credentials -// -func DefaultTokenSource(ctx context.Context, scope ...string) (oauth2.TokenSource, error) { - // First, try the environment variable. - const envVar = "GOOGLE_APPLICATION_CREDENTIALS" - if filename := os.Getenv(envVar); filename != "" { - ts, err := tokenSourceFromFile(ctx, filename, scope) - if err != nil { - return nil, fmt.Errorf("google: error getting credentials using %v environment variable: %v", envVar, err) - } - return ts, nil - } - - // Second, try a well-known file. - filename := wellKnownFile() - _, err := os.Stat(filename) - if err == nil { - ts, err2 := tokenSourceFromFile(ctx, filename, scope) - if err2 == nil { - return ts, nil - } - err = err2 - } else if os.IsNotExist(err) { - err = nil // ignore this error - } - if err != nil { - return nil, fmt.Errorf("google: error getting credentials using well-known file (%v): %v", filename, err) - } - - // Third, if we're on Google App Engine use those credentials. - if appengineTokenFunc != nil && !appengineVM { - return AppEngineTokenSource(ctx, scope...), nil - } - - // Fourth, if we're on Google Compute Engine use the metadata server. - if metadata.OnGCE() { - return ComputeTokenSource(""), nil - } - - // None are found; return helpful error. - const url = "https://developers.google.com/accounts/docs/application-default-credentials" - return nil, fmt.Errorf("google: could not find default credentials. See %v for more information.", url) -} - -func wellKnownFile() string { - const f = "application_default_credentials.json" - if runtime.GOOS == "windows" { - return filepath.Join(os.Getenv("APPDATA"), "gcloud", f) - } - return filepath.Join(guessUnixHomeDir(), ".config", "gcloud", f) -} - -func tokenSourceFromFile(ctx context.Context, filename string, scopes []string) (oauth2.TokenSource, error) { - b, err := ioutil.ReadFile(filename) - if err != nil { - return nil, err - } - var d struct { - // Common fields - Type string - ClientID string `json:"client_id"` - - // User Credential fields - ClientSecret string `json:"client_secret"` - RefreshToken string `json:"refresh_token"` - - // Service Account fields - ClientEmail string `json:"client_email"` - PrivateKeyID string `json:"private_key_id"` - PrivateKey string `json:"private_key"` - } - if err := json.Unmarshal(b, &d); err != nil { - return nil, err - } - switch d.Type { - case "authorized_user": - cfg := &oauth2.Config{ - ClientID: d.ClientID, - ClientSecret: d.ClientSecret, - Scopes: append([]string{}, scopes...), // copy - Endpoint: Endpoint, - } - tok := &oauth2.Token{RefreshToken: d.RefreshToken} - return cfg.TokenSource(ctx, tok), nil - case "service_account": - cfg := &jwt.Config{ - Email: d.ClientEmail, - PrivateKey: []byte(d.PrivateKey), - Scopes: append([]string{}, scopes...), // copy - TokenURL: JWTTokenURL, - } - return cfg.TokenSource(ctx), nil - case "": - return nil, errors.New("missing 'type' field in credentials") - default: - return nil, fmt.Errorf("unknown credential type: %q", d.Type) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/google.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/google.go deleted file mode 100644 index 4f73527..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/google.go +++ /dev/null @@ -1,153 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package google provides support for making OAuth2 authorized and -// authenticated HTTP requests to Google APIs. -// It supports the Web server flow, client-side credentials, service accounts, -// Google Compute Engine service accounts, and Google App Engine service -// accounts. -// -// For more information, please read -// https://developers.google.com/accounts/docs/OAuth2 -// and -// https://developers.google.com/accounts/docs/application-default-credentials. -package google - -import ( - "encoding/json" - "errors" - "fmt" - "strings" - "time" - - "cloud.google.com/go/compute/metadata" - "golang.org/x/oauth2" - "golang.org/x/oauth2/jwt" -) - -// Endpoint is Google's OAuth 2.0 endpoint. -var Endpoint = oauth2.Endpoint{ - AuthURL: "https://accounts.google.com/o/oauth2/auth", - TokenURL: "https://accounts.google.com/o/oauth2/token", -} - -// JWTTokenURL is Google's OAuth 2.0 token URL to use with the JWT flow. -const JWTTokenURL = "https://accounts.google.com/o/oauth2/token" - -// ConfigFromJSON uses a Google Developers Console client_credentials.json -// file to construct a config. -// client_credentials.json can be downloaded from -// https://console.developers.google.com, under "Credentials". Download the Web -// application credentials in the JSON format and provide the contents of the -// file as jsonKey. -func ConfigFromJSON(jsonKey []byte, scope ...string) (*oauth2.Config, error) { - type cred struct { - ClientID string `json:"client_id"` - ClientSecret string `json:"client_secret"` - RedirectURIs []string `json:"redirect_uris"` - AuthURI string `json:"auth_uri"` - TokenURI string `json:"token_uri"` - } - var j struct { - Web *cred `json:"web"` - Installed *cred `json:"installed"` - } - if err := json.Unmarshal(jsonKey, &j); err != nil { - return nil, err - } - var c *cred - switch { - case j.Web != nil: - c = j.Web - case j.Installed != nil: - c = j.Installed - default: - return nil, fmt.Errorf("oauth2/google: no credentials found") - } - if len(c.RedirectURIs) < 1 { - return nil, errors.New("oauth2/google: missing redirect URL in the client_credentials.json") - } - return &oauth2.Config{ - ClientID: c.ClientID, - ClientSecret: c.ClientSecret, - RedirectURL: c.RedirectURIs[0], - Scopes: scope, - Endpoint: oauth2.Endpoint{ - AuthURL: c.AuthURI, - TokenURL: c.TokenURI, - }, - }, nil -} - -// JWTConfigFromJSON uses a Google Developers service account JSON key file to read -// the credentials that authorize and authenticate the requests. -// Create a service account on "Credentials" for your project at -// https://console.developers.google.com to download a JSON key file. -func JWTConfigFromJSON(jsonKey []byte, scope ...string) (*jwt.Config, error) { - var key struct { - Email string `json:"client_email"` - PrivateKey string `json:"private_key"` - PrivateKeyID string `json:"private_key_id"` - TokenURL string `json:"token_uri"` - } - if err := json.Unmarshal(jsonKey, &key); err != nil { - return nil, err - } - config := &jwt.Config{ - Email: key.Email, - PrivateKey: []byte(key.PrivateKey), - PrivateKeyID: key.PrivateKeyID, - Scopes: scope, - TokenURL: key.TokenURL, - } - if config.TokenURL == "" { - config.TokenURL = JWTTokenURL - } - return config, nil -} - -// ComputeTokenSource returns a token source that fetches access tokens -// from Google Compute Engine (GCE)'s metadata server. It's only valid to use -// this token source if your program is running on a GCE instance. -// If no account is specified, "default" is used. -// Further information about retrieving access tokens from the GCE metadata -// server can be found at https://cloud.google.com/compute/docs/authentication. -func ComputeTokenSource(account string) oauth2.TokenSource { - return oauth2.ReuseTokenSource(nil, computeSource{account: account}) -} - -type computeSource struct { - account string -} - -func (cs computeSource) Token() (*oauth2.Token, error) { - if !metadata.OnGCE() { - return nil, errors.New("oauth2/google: can't get a token from the metadata service; not running on GCE") - } - acct := cs.account - if acct == "" { - acct = "default" - } - tokenJSON, err := metadata.Get("instance/service-accounts/" + acct + "/token") - if err != nil { - return nil, err - } - var res struct { - AccessToken string `json:"access_token"` - ExpiresInSec int `json:"expires_in"` - TokenType string `json:"token_type"` - } - err = json.NewDecoder(strings.NewReader(tokenJSON)).Decode(&res) - if err != nil { - return nil, fmt.Errorf("oauth2/google: invalid token JSON from metadata: %v", err) - } - if res.ExpiresInSec == 0 || res.AccessToken == "" { - return nil, fmt.Errorf("oauth2/google: incomplete token received from metadata") - } - return &oauth2.Token{ - AccessToken: res.AccessToken, - TokenType: res.TokenType, - Expiry: time.Now().Add(time.Duration(res.ExpiresInSec) * time.Second), - }, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/jwt.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/jwt.go deleted file mode 100644 index b0fdb3a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/jwt.go +++ /dev/null @@ -1,74 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package google - -import ( - "crypto/rsa" - "fmt" - "time" - - "golang.org/x/oauth2" - "golang.org/x/oauth2/internal" - "golang.org/x/oauth2/jws" -) - -// JWTAccessTokenSourceFromJSON uses a Google Developers service account JSON -// key file to read the credentials that authorize and authenticate the -// requests, and returns a TokenSource that does not use any OAuth2 flow but -// instead creates a JWT and sends that as the access token. -// The audience is typically a URL that specifies the scope of the credentials. -// -// Note that this is not a standard OAuth flow, but rather an -// optimization supported by a few Google services. -// Unless you know otherwise, you should use JWTConfigFromJSON instead. -func JWTAccessTokenSourceFromJSON(jsonKey []byte, audience string) (oauth2.TokenSource, error) { - cfg, err := JWTConfigFromJSON(jsonKey) - if err != nil { - return nil, fmt.Errorf("google: could not parse JSON key: %v", err) - } - pk, err := internal.ParseKey(cfg.PrivateKey) - if err != nil { - return nil, fmt.Errorf("google: could not parse key: %v", err) - } - ts := &jwtAccessTokenSource{ - email: cfg.Email, - audience: audience, - pk: pk, - pkID: cfg.PrivateKeyID, - } - tok, err := ts.Token() - if err != nil { - return nil, err - } - return oauth2.ReuseTokenSource(tok, ts), nil -} - -type jwtAccessTokenSource struct { - email, audience string - pk *rsa.PrivateKey - pkID string -} - -func (ts *jwtAccessTokenSource) Token() (*oauth2.Token, error) { - iat := time.Now() - exp := iat.Add(time.Hour) - cs := &jws.ClaimSet{ - Iss: ts.email, - Sub: ts.email, - Aud: ts.audience, - Iat: iat.Unix(), - Exp: exp.Unix(), - } - hdr := &jws.Header{ - Algorithm: "RS256", - Typ: "JWT", - KeyID: string(ts.pkID), - } - msg, err := jws.Encode(hdr, cs, ts.pk) - if err != nil { - return nil, fmt.Errorf("google: could not encode JWT: %v", err) - } - return &oauth2.Token{AccessToken: msg, TokenType: "Bearer", Expiry: exp}, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/sdk.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/sdk.go deleted file mode 100644 index d29a3bb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/google/sdk.go +++ /dev/null @@ -1,168 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package google - -import ( - "encoding/json" - "errors" - "fmt" - "net/http" - "os" - "os/user" - "path/filepath" - "runtime" - "strings" - "time" - - "golang.org/x/net/context" - "golang.org/x/oauth2" - "golang.org/x/oauth2/internal" -) - -type sdkCredentials struct { - Data []struct { - Credential struct { - ClientID string `json:"client_id"` - ClientSecret string `json:"client_secret"` - AccessToken string `json:"access_token"` - RefreshToken string `json:"refresh_token"` - TokenExpiry *time.Time `json:"token_expiry"` - } `json:"credential"` - Key struct { - Account string `json:"account"` - Scope string `json:"scope"` - } `json:"key"` - } -} - -// An SDKConfig provides access to tokens from an account already -// authorized via the Google Cloud SDK. -type SDKConfig struct { - conf oauth2.Config - initialToken *oauth2.Token -} - -// NewSDKConfig creates an SDKConfig for the given Google Cloud SDK -// account. If account is empty, the account currently active in -// Google Cloud SDK properties is used. -// Google Cloud SDK credentials must be created by running `gcloud auth` -// before using this function. -// The Google Cloud SDK is available at https://cloud.google.com/sdk/. -func NewSDKConfig(account string) (*SDKConfig, error) { - configPath, err := sdkConfigPath() - if err != nil { - return nil, fmt.Errorf("oauth2/google: error getting SDK config path: %v", err) - } - credentialsPath := filepath.Join(configPath, "credentials") - f, err := os.Open(credentialsPath) - if err != nil { - return nil, fmt.Errorf("oauth2/google: failed to load SDK credentials: %v", err) - } - defer f.Close() - - var c sdkCredentials - if err := json.NewDecoder(f).Decode(&c); err != nil { - return nil, fmt.Errorf("oauth2/google: failed to decode SDK credentials from %q: %v", credentialsPath, err) - } - if len(c.Data) == 0 { - return nil, fmt.Errorf("oauth2/google: no credentials found in %q, run `gcloud auth login` to create one", credentialsPath) - } - if account == "" { - propertiesPath := filepath.Join(configPath, "properties") - f, err := os.Open(propertiesPath) - if err != nil { - return nil, fmt.Errorf("oauth2/google: failed to load SDK properties: %v", err) - } - defer f.Close() - ini, err := internal.ParseINI(f) - if err != nil { - return nil, fmt.Errorf("oauth2/google: failed to parse SDK properties %q: %v", propertiesPath, err) - } - core, ok := ini["core"] - if !ok { - return nil, fmt.Errorf("oauth2/google: failed to find [core] section in %v", ini) - } - active, ok := core["account"] - if !ok { - return nil, fmt.Errorf("oauth2/google: failed to find %q attribute in %v", "account", core) - } - account = active - } - - for _, d := range c.Data { - if account == "" || d.Key.Account == account { - if d.Credential.AccessToken == "" && d.Credential.RefreshToken == "" { - return nil, fmt.Errorf("oauth2/google: no token available for account %q", account) - } - var expiry time.Time - if d.Credential.TokenExpiry != nil { - expiry = *d.Credential.TokenExpiry - } - return &SDKConfig{ - conf: oauth2.Config{ - ClientID: d.Credential.ClientID, - ClientSecret: d.Credential.ClientSecret, - Scopes: strings.Split(d.Key.Scope, " "), - Endpoint: Endpoint, - RedirectURL: "oob", - }, - initialToken: &oauth2.Token{ - AccessToken: d.Credential.AccessToken, - RefreshToken: d.Credential.RefreshToken, - Expiry: expiry, - }, - }, nil - } - } - return nil, fmt.Errorf("oauth2/google: no such credentials for account %q", account) -} - -// Client returns an HTTP client using Google Cloud SDK credentials to -// authorize requests. The token will auto-refresh as necessary. The -// underlying http.RoundTripper will be obtained using the provided -// context. The returned client and its Transport should not be -// modified. -func (c *SDKConfig) Client(ctx context.Context) *http.Client { - return &http.Client{ - Transport: &oauth2.Transport{ - Source: c.TokenSource(ctx), - }, - } -} - -// TokenSource returns an oauth2.TokenSource that retrieve tokens from -// Google Cloud SDK credentials using the provided context. -// It will returns the current access token stored in the credentials, -// and refresh it when it expires, but it won't update the credentials -// with the new access token. -func (c *SDKConfig) TokenSource(ctx context.Context) oauth2.TokenSource { - return c.conf.TokenSource(ctx, c.initialToken) -} - -// Scopes are the OAuth 2.0 scopes the current account is authorized for. -func (c *SDKConfig) Scopes() []string { - return c.conf.Scopes -} - -// sdkConfigPath tries to guess where the gcloud config is located. -// It can be overridden during tests. -var sdkConfigPath = func() (string, error) { - if runtime.GOOS == "windows" { - return filepath.Join(os.Getenv("APPDATA"), "gcloud"), nil - } - homeDir := guessUnixHomeDir() - if homeDir == "" { - return "", errors.New("unable to get current user home directory: os/user lookup failed; $HOME is empty") - } - return filepath.Join(homeDir, ".config", "gcloud"), nil -} - -func guessUnixHomeDir() string { - usr, err := user.Current() - if err == nil { - return usr.HomeDir - } - return os.Getenv("HOME") -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/oauth2.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/oauth2.go deleted file mode 100644 index fbe1028..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/oauth2.go +++ /dev/null @@ -1,76 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package internal contains support packages for oauth2 package. -package internal - -import ( - "bufio" - "crypto/rsa" - "crypto/x509" - "encoding/pem" - "errors" - "fmt" - "io" - "strings" -) - -// ParseKey converts the binary contents of a private key file -// to an *rsa.PrivateKey. It detects whether the private key is in a -// PEM container or not. If so, it extracts the the private key -// from PEM container before conversion. It only supports PEM -// containers with no passphrase. -func ParseKey(key []byte) (*rsa.PrivateKey, error) { - block, _ := pem.Decode(key) - if block != nil { - key = block.Bytes - } - parsedKey, err := x509.ParsePKCS8PrivateKey(key) - if err != nil { - parsedKey, err = x509.ParsePKCS1PrivateKey(key) - if err != nil { - return nil, fmt.Errorf("private key should be a PEM or plain PKSC1 or PKCS8; parse error: %v", err) - } - } - parsed, ok := parsedKey.(*rsa.PrivateKey) - if !ok { - return nil, errors.New("private key is invalid") - } - return parsed, nil -} - -func ParseINI(ini io.Reader) (map[string]map[string]string, error) { - result := map[string]map[string]string{ - "": map[string]string{}, // root section - } - scanner := bufio.NewScanner(ini) - currentSection := "" - for scanner.Scan() { - line := strings.TrimSpace(scanner.Text()) - if strings.HasPrefix(line, ";") { - // comment. - continue - } - if strings.HasPrefix(line, "[") && strings.HasSuffix(line, "]") { - currentSection = strings.TrimSpace(line[1 : len(line)-1]) - result[currentSection] = map[string]string{} - continue - } - parts := strings.SplitN(line, "=", 2) - if len(parts) == 2 && parts[0] != "" { - result[currentSection][strings.TrimSpace(parts[0])] = strings.TrimSpace(parts[1]) - } - } - if err := scanner.Err(); err != nil { - return nil, fmt.Errorf("error scanning ini: %v", err) - } - return result, nil -} - -func CondVal(v string) []string { - if v == "" { - return nil - } - return []string{v} -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/token.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/token.go deleted file mode 100644 index 18328a0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/token.go +++ /dev/null @@ -1,225 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package internal contains support packages for oauth2 package. -package internal - -import ( - "encoding/json" - "fmt" - "io" - "io/ioutil" - "mime" - "net/http" - "net/url" - "strconv" - "strings" - "time" - - "golang.org/x/net/context" -) - -// Token represents the crendentials used to authorize -// the requests to access protected resources on the OAuth 2.0 -// provider's backend. -// -// This type is a mirror of oauth2.Token and exists to break -// an otherwise-circular dependency. Other internal packages -// should convert this Token into an oauth2.Token before use. -type Token struct { - // AccessToken is the token that authorizes and authenticates - // the requests. - AccessToken string - - // TokenType is the type of token. - // The Type method returns either this or "Bearer", the default. - TokenType string - - // RefreshToken is a token that's used by the application - // (as opposed to the user) to refresh the access token - // if it expires. - RefreshToken string - - // Expiry is the optional expiration time of the access token. - // - // If zero, TokenSource implementations will reuse the same - // token forever and RefreshToken or equivalent - // mechanisms for that TokenSource will not be used. - Expiry time.Time - - // Raw optionally contains extra metadata from the server - // when updating a token. - Raw interface{} -} - -// tokenJSON is the struct representing the HTTP response from OAuth2 -// providers returning a token in JSON form. -type tokenJSON struct { - AccessToken string `json:"access_token"` - TokenType string `json:"token_type"` - RefreshToken string `json:"refresh_token"` - ExpiresIn expirationTime `json:"expires_in"` // at least PayPal returns string, while most return number - Expires expirationTime `json:"expires"` // broken Facebook spelling of expires_in -} - -func (e *tokenJSON) expiry() (t time.Time) { - if v := e.ExpiresIn; v != 0 { - return time.Now().Add(time.Duration(v) * time.Second) - } - if v := e.Expires; v != 0 { - return time.Now().Add(time.Duration(v) * time.Second) - } - return -} - -type expirationTime int32 - -func (e *expirationTime) UnmarshalJSON(b []byte) error { - var n json.Number - err := json.Unmarshal(b, &n) - if err != nil { - return err - } - i, err := n.Int64() - if err != nil { - return err - } - *e = expirationTime(i) - return nil -} - -var brokenAuthHeaderProviders = []string{ - "https://accounts.google.com/", - "https://api.dropbox.com/", - "https://api.dropboxapi.com/", - "https://api.instagram.com/", - "https://api.netatmo.net/", - "https://api.odnoklassniki.ru/", - "https://api.pushbullet.com/", - "https://api.soundcloud.com/", - "https://api.twitch.tv/", - "https://app.box.com/", - "https://connect.stripe.com/", - "https://login.microsoftonline.com/", - "https://login.salesforce.com/", - "https://oauth.sandbox.trainingpeaks.com/", - "https://oauth.trainingpeaks.com/", - "https://oauth.vk.com/", - "https://openapi.baidu.com/", - "https://slack.com/", - "https://test-sandbox.auth.corp.google.com", - "https://test.salesforce.com/", - "https://user.gini.net/", - "https://www.douban.com/", - "https://www.googleapis.com/", - "https://www.linkedin.com/", - "https://www.strava.com/oauth/", - "https://www.wunderlist.com/oauth/", - "https://api.patreon.com/", -} - -func RegisterBrokenAuthHeaderProvider(tokenURL string) { - brokenAuthHeaderProviders = append(brokenAuthHeaderProviders, tokenURL) -} - -// providerAuthHeaderWorks reports whether the OAuth2 server identified by the tokenURL -// implements the OAuth2 spec correctly -// See https://code.google.com/p/goauth2/issues/detail?id=31 for background. -// In summary: -// - Reddit only accepts client secret in the Authorization header -// - Dropbox accepts either it in URL param or Auth header, but not both. -// - Google only accepts URL param (not spec compliant?), not Auth header -// - Stripe only accepts client secret in Auth header with Bearer method, not Basic -func providerAuthHeaderWorks(tokenURL string) bool { - for _, s := range brokenAuthHeaderProviders { - if strings.HasPrefix(tokenURL, s) { - // Some sites fail to implement the OAuth2 spec fully. - return false - } - } - - // Assume the provider implements the spec properly - // otherwise. We can add more exceptions as they're - // discovered. We will _not_ be adding configurable hooks - // to this package to let users select server bugs. - return true -} - -func RetrieveToken(ctx context.Context, clientID, clientSecret, tokenURL string, v url.Values) (*Token, error) { - hc, err := ContextClient(ctx) - if err != nil { - return nil, err - } - v.Set("client_id", clientID) - bustedAuth := !providerAuthHeaderWorks(tokenURL) - if bustedAuth && clientSecret != "" { - v.Set("client_secret", clientSecret) - } - req, err := http.NewRequest("POST", tokenURL, strings.NewReader(v.Encode())) - if err != nil { - return nil, err - } - req.Header.Set("Content-Type", "application/x-www-form-urlencoded") - if !bustedAuth { - req.SetBasicAuth(clientID, clientSecret) - } - r, err := hc.Do(req) - if err != nil { - return nil, err - } - defer r.Body.Close() - body, err := ioutil.ReadAll(io.LimitReader(r.Body, 1<<20)) - if err != nil { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v", err) - } - if code := r.StatusCode; code < 200 || code > 299 { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v\nResponse: %s", r.Status, body) - } - - var token *Token - content, _, _ := mime.ParseMediaType(r.Header.Get("Content-Type")) - switch content { - case "application/x-www-form-urlencoded", "text/plain": - vals, err := url.ParseQuery(string(body)) - if err != nil { - return nil, err - } - token = &Token{ - AccessToken: vals.Get("access_token"), - TokenType: vals.Get("token_type"), - RefreshToken: vals.Get("refresh_token"), - Raw: vals, - } - e := vals.Get("expires_in") - if e == "" { - // TODO(jbd): Facebook's OAuth2 implementation is broken and - // returns expires_in field in expires. Remove the fallback to expires, - // when Facebook fixes their implementation. - e = vals.Get("expires") - } - expires, _ := strconv.Atoi(e) - if expires != 0 { - token.Expiry = time.Now().Add(time.Duration(expires) * time.Second) - } - default: - var tj tokenJSON - if err = json.Unmarshal(body, &tj); err != nil { - return nil, err - } - token = &Token{ - AccessToken: tj.AccessToken, - TokenType: tj.TokenType, - RefreshToken: tj.RefreshToken, - Expiry: tj.expiry(), - Raw: make(map[string]interface{}), - } - json.Unmarshal(body, &token.Raw) // no error checks for optional fields - } - // Don't overwrite `RefreshToken` with an empty value - // if this was a token refreshing request. - if token.RefreshToken == "" { - token.RefreshToken = v.Get("refresh_token") - } - return token, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/transport.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/transport.go deleted file mode 100644 index f1f173e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/internal/transport.go +++ /dev/null @@ -1,69 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package internal contains support packages for oauth2 package. -package internal - -import ( - "net/http" - - "golang.org/x/net/context" -) - -// HTTPClient is the context key to use with golang.org/x/net/context's -// WithValue function to associate an *http.Client value with a context. -var HTTPClient ContextKey - -// ContextKey is just an empty struct. It exists so HTTPClient can be -// an immutable public variable with a unique type. It's immutable -// because nobody else can create a ContextKey, being unexported. -type ContextKey struct{} - -// ContextClientFunc is a func which tries to return an *http.Client -// given a Context value. If it returns an error, the search stops -// with that error. If it returns (nil, nil), the search continues -// down the list of registered funcs. -type ContextClientFunc func(context.Context) (*http.Client, error) - -var contextClientFuncs []ContextClientFunc - -func RegisterContextClientFunc(fn ContextClientFunc) { - contextClientFuncs = append(contextClientFuncs, fn) -} - -func ContextClient(ctx context.Context) (*http.Client, error) { - if ctx != nil { - if hc, ok := ctx.Value(HTTPClient).(*http.Client); ok { - return hc, nil - } - } - for _, fn := range contextClientFuncs { - c, err := fn(ctx) - if err != nil { - return nil, err - } - if c != nil { - return c, nil - } - } - return http.DefaultClient, nil -} - -func ContextTransport(ctx context.Context) http.RoundTripper { - hc, err := ContextClient(ctx) - // This is a rare error case (somebody using nil on App Engine). - if err != nil { - return ErrorTransport{err} - } - return hc.Transport -} - -// ErrorTransport returns the specified error on RoundTrip. -// This RoundTripper should be used in rare error cases where -// error handling can be postponed to response handling time. -type ErrorTransport struct{ Err error } - -func (t ErrorTransport) RoundTrip(*http.Request) (*http.Response, error) { - return nil, t.Err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jws/jws.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jws/jws.go deleted file mode 100644 index 8bcecb4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jws/jws.go +++ /dev/null @@ -1,182 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package jws provides a partial implementation -// of JSON Web Signature encoding and decoding. -// It exists to support the golang.org/x/oauth2 package. -// -// See RFC 7515. -// -// Deprecated: this package is not intended for public use and might be -// removed in the future. It exists for internal use only. -// Please switch to another JWS package or copy this package into your own -// source tree. -package jws - -import ( - "bytes" - "crypto" - "crypto/rand" - "crypto/rsa" - "crypto/sha256" - "encoding/base64" - "encoding/json" - "errors" - "fmt" - "strings" - "time" -) - -// ClaimSet contains information about the JWT signature including the -// permissions being requested (scopes), the target of the token, the issuer, -// the time the token was issued, and the lifetime of the token. -type ClaimSet struct { - Iss string `json:"iss"` // email address of the client_id of the application making the access token request - Scope string `json:"scope,omitempty"` // space-delimited list of the permissions the application requests - Aud string `json:"aud"` // descriptor of the intended target of the assertion (Optional). - Exp int64 `json:"exp"` // the expiration time of the assertion (seconds since Unix epoch) - Iat int64 `json:"iat"` // the time the assertion was issued (seconds since Unix epoch) - Typ string `json:"typ,omitempty"` // token type (Optional). - - // Email for which the application is requesting delegated access (Optional). - Sub string `json:"sub,omitempty"` - - // The old name of Sub. Client keeps setting Prn to be - // complaint with legacy OAuth 2.0 providers. (Optional) - Prn string `json:"prn,omitempty"` - - // See http://tools.ietf.org/html/draft-jones-json-web-token-10#section-4.3 - // This array is marshalled using custom code (see (c *ClaimSet) encode()). - PrivateClaims map[string]interface{} `json:"-"` -} - -func (c *ClaimSet) encode() (string, error) { - // Reverting time back for machines whose time is not perfectly in sync. - // If client machine's time is in the future according - // to Google servers, an access token will not be issued. - now := time.Now().Add(-10 * time.Second) - if c.Iat == 0 { - c.Iat = now.Unix() - } - if c.Exp == 0 { - c.Exp = now.Add(time.Hour).Unix() - } - if c.Exp < c.Iat { - return "", fmt.Errorf("jws: invalid Exp = %v; must be later than Iat = %v", c.Exp, c.Iat) - } - - b, err := json.Marshal(c) - if err != nil { - return "", err - } - - if len(c.PrivateClaims) == 0 { - return base64.RawURLEncoding.EncodeToString(b), nil - } - - // Marshal private claim set and then append it to b. - prv, err := json.Marshal(c.PrivateClaims) - if err != nil { - return "", fmt.Errorf("jws: invalid map of private claims %v", c.PrivateClaims) - } - - // Concatenate public and private claim JSON objects. - if !bytes.HasSuffix(b, []byte{'}'}) { - return "", fmt.Errorf("jws: invalid JSON %s", b) - } - if !bytes.HasPrefix(prv, []byte{'{'}) { - return "", fmt.Errorf("jws: invalid JSON %s", prv) - } - b[len(b)-1] = ',' // Replace closing curly brace with a comma. - b = append(b, prv[1:]...) // Append private claims. - return base64.RawURLEncoding.EncodeToString(b), nil -} - -// Header represents the header for the signed JWS payloads. -type Header struct { - // The algorithm used for signature. - Algorithm string `json:"alg"` - - // Represents the token type. - Typ string `json:"typ"` - - // The optional hint of which key is being used. - KeyID string `json:"kid,omitempty"` -} - -func (h *Header) encode() (string, error) { - b, err := json.Marshal(h) - if err != nil { - return "", err - } - return base64.RawURLEncoding.EncodeToString(b), nil -} - -// Decode decodes a claim set from a JWS payload. -func Decode(payload string) (*ClaimSet, error) { - // decode returned id token to get expiry - s := strings.Split(payload, ".") - if len(s) < 2 { - // TODO(jbd): Provide more context about the error. - return nil, errors.New("jws: invalid token received") - } - decoded, err := base64.RawURLEncoding.DecodeString(s[1]) - if err != nil { - return nil, err - } - c := &ClaimSet{} - err = json.NewDecoder(bytes.NewBuffer(decoded)).Decode(c) - return c, err -} - -// Signer returns a signature for the given data. -type Signer func(data []byte) (sig []byte, err error) - -// EncodeWithSigner encodes a header and claim set with the provided signer. -func EncodeWithSigner(header *Header, c *ClaimSet, sg Signer) (string, error) { - head, err := header.encode() - if err != nil { - return "", err - } - cs, err := c.encode() - if err != nil { - return "", err - } - ss := fmt.Sprintf("%s.%s", head, cs) - sig, err := sg([]byte(ss)) - if err != nil { - return "", err - } - return fmt.Sprintf("%s.%s", ss, base64.RawURLEncoding.EncodeToString(sig)), nil -} - -// Encode encodes a signed JWS with provided header and claim set. -// This invokes EncodeWithSigner using crypto/rsa.SignPKCS1v15 with the given RSA private key. -func Encode(header *Header, c *ClaimSet, key *rsa.PrivateKey) (string, error) { - sg := func(data []byte) (sig []byte, err error) { - h := sha256.New() - h.Write(data) - return rsa.SignPKCS1v15(rand.Reader, key, crypto.SHA256, h.Sum(nil)) - } - return EncodeWithSigner(header, c, sg) -} - -// Verify tests whether the provided JWT token's signature was produced by the private key -// associated with the supplied public key. -func Verify(token string, key *rsa.PublicKey) error { - parts := strings.Split(token, ".") - if len(parts) != 3 { - return errors.New("jws: invalid token received, token must have 3 parts") - } - - signedContent := parts[0] + "." + parts[1] - signatureString, err := base64.RawURLEncoding.DecodeString(parts[2]) - if err != nil { - return err - } - - h := sha256.New() - h.Write([]byte(signedContent)) - return rsa.VerifyPKCS1v15(key, crypto.SHA256, h.Sum(nil), []byte(signatureString)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jwt/jwt.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jwt/jwt.go deleted file mode 100644 index f4b9523..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/jwt/jwt.go +++ /dev/null @@ -1,157 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package jwt implements the OAuth 2.0 JSON Web Token flow, commonly -// known as "two-legged OAuth 2.0". -// -// See: https://tools.ietf.org/html/draft-ietf-oauth-jwt-bearer-12 -package jwt - -import ( - "encoding/json" - "fmt" - "io" - "io/ioutil" - "net/http" - "net/url" - "strings" - "time" - - "golang.org/x/net/context" - "golang.org/x/oauth2" - "golang.org/x/oauth2/internal" - "golang.org/x/oauth2/jws" -) - -var ( - defaultGrantType = "urn:ietf:params:oauth:grant-type:jwt-bearer" - defaultHeader = &jws.Header{Algorithm: "RS256", Typ: "JWT"} -) - -// Config is the configuration for using JWT to fetch tokens, -// commonly known as "two-legged OAuth 2.0". -type Config struct { - // Email is the OAuth client identifier used when communicating with - // the configured OAuth provider. - Email string - - // PrivateKey contains the contents of an RSA private key or the - // contents of a PEM file that contains a private key. The provided - // private key is used to sign JWT payloads. - // PEM containers with a passphrase are not supported. - // Use the following command to convert a PKCS 12 file into a PEM. - // - // $ openssl pkcs12 -in key.p12 -out key.pem -nodes - // - PrivateKey []byte - - // PrivateKeyID contains an optional hint indicating which key is being - // used. - PrivateKeyID string - - // Subject is the optional user to impersonate. - Subject string - - // Scopes optionally specifies a list of requested permission scopes. - Scopes []string - - // TokenURL is the endpoint required to complete the 2-legged JWT flow. - TokenURL string - - // Expires optionally specifies how long the token is valid for. - Expires time.Duration -} - -// TokenSource returns a JWT TokenSource using the configuration -// in c and the HTTP client from the provided context. -func (c *Config) TokenSource(ctx context.Context) oauth2.TokenSource { - return oauth2.ReuseTokenSource(nil, jwtSource{ctx, c}) -} - -// Client returns an HTTP client wrapping the context's -// HTTP transport and adding Authorization headers with tokens -// obtained from c. -// -// The returned client and its Transport should not be modified. -func (c *Config) Client(ctx context.Context) *http.Client { - return oauth2.NewClient(ctx, c.TokenSource(ctx)) -} - -// jwtSource is a source that always does a signed JWT request for a token. -// It should typically be wrapped with a reuseTokenSource. -type jwtSource struct { - ctx context.Context - conf *Config -} - -func (js jwtSource) Token() (*oauth2.Token, error) { - pk, err := internal.ParseKey(js.conf.PrivateKey) - if err != nil { - return nil, err - } - hc := oauth2.NewClient(js.ctx, nil) - claimSet := &jws.ClaimSet{ - Iss: js.conf.Email, - Scope: strings.Join(js.conf.Scopes, " "), - Aud: js.conf.TokenURL, - } - if subject := js.conf.Subject; subject != "" { - claimSet.Sub = subject - // prn is the old name of sub. Keep setting it - // to be compatible with legacy OAuth 2.0 providers. - claimSet.Prn = subject - } - if t := js.conf.Expires; t > 0 { - claimSet.Exp = time.Now().Add(t).Unix() - } - payload, err := jws.Encode(defaultHeader, claimSet, pk) - if err != nil { - return nil, err - } - v := url.Values{} - v.Set("grant_type", defaultGrantType) - v.Set("assertion", payload) - resp, err := hc.PostForm(js.conf.TokenURL, v) - if err != nil { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v", err) - } - defer resp.Body.Close() - body, err := ioutil.ReadAll(io.LimitReader(resp.Body, 1<<20)) - if err != nil { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v", err) - } - if c := resp.StatusCode; c < 200 || c > 299 { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v\nResponse: %s", resp.Status, body) - } - // tokenRes is the JSON response body. - var tokenRes struct { - AccessToken string `json:"access_token"` - TokenType string `json:"token_type"` - IDToken string `json:"id_token"` - ExpiresIn int64 `json:"expires_in"` // relative seconds from now - } - if err := json.Unmarshal(body, &tokenRes); err != nil { - return nil, fmt.Errorf("oauth2: cannot fetch token: %v", err) - } - token := &oauth2.Token{ - AccessToken: tokenRes.AccessToken, - TokenType: tokenRes.TokenType, - } - raw := make(map[string]interface{}) - json.Unmarshal(body, &raw) // no error checks for optional fields - token = token.WithExtra(raw) - - if secs := tokenRes.ExpiresIn; secs > 0 { - token.Expiry = time.Now().Add(time.Duration(secs) * time.Second) - } - if v := tokenRes.IDToken; v != "" { - // decode returned id token to get expiry - claimSet, err := jws.Decode(v) - if err != nil { - return nil, fmt.Errorf("oauth2: error decoding JWT token: %v", err) - } - token.Expiry = time.Unix(claimSet.Exp, 0) - } - return token, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/oauth2.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/oauth2.go deleted file mode 100644 index 798edc8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/oauth2.go +++ /dev/null @@ -1,341 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package oauth2 provides support for making -// OAuth2 authorized and authenticated HTTP requests. -// It can additionally grant authorization with Bearer JWT. -package oauth2 - -import ( - "bytes" - "errors" - "net/http" - "net/url" - "strings" - "sync" - - "golang.org/x/net/context" - "golang.org/x/oauth2/internal" -) - -// NoContext is the default context you should supply if not using -// your own context.Context (see https://golang.org/x/net/context). -// -// Deprecated: Use context.Background() or context.TODO() instead. -var NoContext = context.TODO() - -// RegisterBrokenAuthHeaderProvider registers an OAuth2 server -// identified by the tokenURL prefix as an OAuth2 implementation -// which doesn't support the HTTP Basic authentication -// scheme to authenticate with the authorization server. -// Once a server is registered, credentials (client_id and client_secret) -// will be passed as query parameters rather than being present -// in the Authorization header. -// See https://code.google.com/p/goauth2/issues/detail?id=31 for background. -func RegisterBrokenAuthHeaderProvider(tokenURL string) { - internal.RegisterBrokenAuthHeaderProvider(tokenURL) -} - -// Config describes a typical 3-legged OAuth2 flow, with both the -// client application information and the server's endpoint URLs. -// For the client credentials 2-legged OAuth2 flow, see the clientcredentials -// package (https://golang.org/x/oauth2/clientcredentials). -type Config struct { - // ClientID is the application's ID. - ClientID string - - // ClientSecret is the application's secret. - ClientSecret string - - // Endpoint contains the resource server's token endpoint - // URLs. These are constants specific to each server and are - // often available via site-specific packages, such as - // google.Endpoint or github.Endpoint. - Endpoint Endpoint - - // RedirectURL is the URL to redirect users going through - // the OAuth flow, after the resource owner's URLs. - RedirectURL string - - // Scope specifies optional requested permissions. - Scopes []string -} - -// A TokenSource is anything that can return a token. -type TokenSource interface { - // Token returns a token or an error. - // Token must be safe for concurrent use by multiple goroutines. - // The returned Token must not be modified. - Token() (*Token, error) -} - -// Endpoint contains the OAuth 2.0 provider's authorization and token -// endpoint URLs. -type Endpoint struct { - AuthURL string - TokenURL string -} - -var ( - // AccessTypeOnline and AccessTypeOffline are options passed - // to the Options.AuthCodeURL method. They modify the - // "access_type" field that gets sent in the URL returned by - // AuthCodeURL. - // - // Online is the default if neither is specified. If your - // application needs to refresh access tokens when the user - // is not present at the browser, then use offline. This will - // result in your application obtaining a refresh token the - // first time your application exchanges an authorization - // code for a user. - AccessTypeOnline AuthCodeOption = SetAuthURLParam("access_type", "online") - AccessTypeOffline AuthCodeOption = SetAuthURLParam("access_type", "offline") - - // ApprovalForce forces the users to view the consent dialog - // and confirm the permissions request at the URL returned - // from AuthCodeURL, even if they've already done so. - ApprovalForce AuthCodeOption = SetAuthURLParam("approval_prompt", "force") -) - -// An AuthCodeOption is passed to Config.AuthCodeURL. -type AuthCodeOption interface { - setValue(url.Values) -} - -type setParam struct{ k, v string } - -func (p setParam) setValue(m url.Values) { m.Set(p.k, p.v) } - -// SetAuthURLParam builds an AuthCodeOption which passes key/value parameters -// to a provider's authorization endpoint. -func SetAuthURLParam(key, value string) AuthCodeOption { - return setParam{key, value} -} - -// AuthCodeURL returns a URL to OAuth 2.0 provider's consent page -// that asks for permissions for the required scopes explicitly. -// -// State is a token to protect the user from CSRF attacks. You must -// always provide a non-zero string and validate that it matches the -// the state query parameter on your redirect callback. -// See http://tools.ietf.org/html/rfc6749#section-10.12 for more info. -// -// Opts may include AccessTypeOnline or AccessTypeOffline, as well -// as ApprovalForce. -func (c *Config) AuthCodeURL(state string, opts ...AuthCodeOption) string { - var buf bytes.Buffer - buf.WriteString(c.Endpoint.AuthURL) - v := url.Values{ - "response_type": {"code"}, - "client_id": {c.ClientID}, - "redirect_uri": internal.CondVal(c.RedirectURL), - "scope": internal.CondVal(strings.Join(c.Scopes, " ")), - "state": internal.CondVal(state), - } - for _, opt := range opts { - opt.setValue(v) - } - if strings.Contains(c.Endpoint.AuthURL, "?") { - buf.WriteByte('&') - } else { - buf.WriteByte('?') - } - buf.WriteString(v.Encode()) - return buf.String() -} - -// PasswordCredentialsToken converts a resource owner username and password -// pair into a token. -// -// Per the RFC, this grant type should only be used "when there is a high -// degree of trust between the resource owner and the client (e.g., the client -// is part of the device operating system or a highly privileged application), -// and when other authorization grant types are not available." -// See https://tools.ietf.org/html/rfc6749#section-4.3 for more info. -// -// The HTTP client to use is derived from the context. -// If nil, http.DefaultClient is used. -func (c *Config) PasswordCredentialsToken(ctx context.Context, username, password string) (*Token, error) { - return retrieveToken(ctx, c, url.Values{ - "grant_type": {"password"}, - "username": {username}, - "password": {password}, - "scope": internal.CondVal(strings.Join(c.Scopes, " ")), - }) -} - -// Exchange converts an authorization code into a token. -// -// It is used after a resource provider redirects the user back -// to the Redirect URI (the URL obtained from AuthCodeURL). -// -// The HTTP client to use is derived from the context. -// If a client is not provided via the context, http.DefaultClient is used. -// -// The code will be in the *http.Request.FormValue("code"). Before -// calling Exchange, be sure to validate FormValue("state"). -func (c *Config) Exchange(ctx context.Context, code string) (*Token, error) { - return retrieveToken(ctx, c, url.Values{ - "grant_type": {"authorization_code"}, - "code": {code}, - "redirect_uri": internal.CondVal(c.RedirectURL), - "scope": internal.CondVal(strings.Join(c.Scopes, " ")), - }) -} - -// Client returns an HTTP client using the provided token. -// The token will auto-refresh as necessary. The underlying -// HTTP transport will be obtained using the provided context. -// The returned client and its Transport should not be modified. -func (c *Config) Client(ctx context.Context, t *Token) *http.Client { - return NewClient(ctx, c.TokenSource(ctx, t)) -} - -// TokenSource returns a TokenSource that returns t until t expires, -// automatically refreshing it as necessary using the provided context. -// -// Most users will use Config.Client instead. -func (c *Config) TokenSource(ctx context.Context, t *Token) TokenSource { - tkr := &tokenRefresher{ - ctx: ctx, - conf: c, - } - if t != nil { - tkr.refreshToken = t.RefreshToken - } - return &reuseTokenSource{ - t: t, - new: tkr, - } -} - -// tokenRefresher is a TokenSource that makes "grant_type"=="refresh_token" -// HTTP requests to renew a token using a RefreshToken. -type tokenRefresher struct { - ctx context.Context // used to get HTTP requests - conf *Config - refreshToken string -} - -// WARNING: Token is not safe for concurrent access, as it -// updates the tokenRefresher's refreshToken field. -// Within this package, it is used by reuseTokenSource which -// synchronizes calls to this method with its own mutex. -func (tf *tokenRefresher) Token() (*Token, error) { - if tf.refreshToken == "" { - return nil, errors.New("oauth2: token expired and refresh token is not set") - } - - tk, err := retrieveToken(tf.ctx, tf.conf, url.Values{ - "grant_type": {"refresh_token"}, - "refresh_token": {tf.refreshToken}, - }) - - if err != nil { - return nil, err - } - if tf.refreshToken != tk.RefreshToken { - tf.refreshToken = tk.RefreshToken - } - return tk, err -} - -// reuseTokenSource is a TokenSource that holds a single token in memory -// and validates its expiry before each call to retrieve it with -// Token. If it's expired, it will be auto-refreshed using the -// new TokenSource. -type reuseTokenSource struct { - new TokenSource // called when t is expired. - - mu sync.Mutex // guards t - t *Token -} - -// Token returns the current token if it's still valid, else will -// refresh the current token (using r.Context for HTTP client -// information) and return the new one. -func (s *reuseTokenSource) Token() (*Token, error) { - s.mu.Lock() - defer s.mu.Unlock() - if s.t.Valid() { - return s.t, nil - } - t, err := s.new.Token() - if err != nil { - return nil, err - } - s.t = t - return t, nil -} - -// StaticTokenSource returns a TokenSource that always returns the same token. -// Because the provided token t is never refreshed, StaticTokenSource is only -// useful for tokens that never expire. -func StaticTokenSource(t *Token) TokenSource { - return staticTokenSource{t} -} - -// staticTokenSource is a TokenSource that always returns the same Token. -type staticTokenSource struct { - t *Token -} - -func (s staticTokenSource) Token() (*Token, error) { - return s.t, nil -} - -// HTTPClient is the context key to use with golang.org/x/net/context's -// WithValue function to associate an *http.Client value with a context. -var HTTPClient internal.ContextKey - -// NewClient creates an *http.Client from a Context and TokenSource. -// The returned client is not valid beyond the lifetime of the context. -// -// As a special case, if src is nil, a non-OAuth2 client is returned -// using the provided context. This exists to support related OAuth2 -// packages. -func NewClient(ctx context.Context, src TokenSource) *http.Client { - if src == nil { - c, err := internal.ContextClient(ctx) - if err != nil { - return &http.Client{Transport: internal.ErrorTransport{Err: err}} - } - return c - } - return &http.Client{ - Transport: &Transport{ - Base: internal.ContextTransport(ctx), - Source: ReuseTokenSource(nil, src), - }, - } -} - -// ReuseTokenSource returns a TokenSource which repeatedly returns the -// same token as long as it's valid, starting with t. -// When its cached token is invalid, a new token is obtained from src. -// -// ReuseTokenSource is typically used to reuse tokens from a cache -// (such as a file on disk) between runs of a program, rather than -// obtaining new tokens unnecessarily. -// -// The initial token t may be nil, in which case the TokenSource is -// wrapped in a caching version if it isn't one already. This also -// means it's always safe to wrap ReuseTokenSource around any other -// TokenSource without adverse effects. -func ReuseTokenSource(t *Token, src TokenSource) TokenSource { - // Don't wrap a reuseTokenSource in itself. That would work, - // but cause an unnecessary number of mutex operations. - // Just build the equivalent one. - if rt, ok := src.(*reuseTokenSource); ok { - if t == nil { - // Just use it directly. - return rt - } - src = rt.new - } - return &reuseTokenSource{ - t: t, - new: src, - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/token.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/token.go deleted file mode 100644 index 7a3167f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/token.go +++ /dev/null @@ -1,158 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package oauth2 - -import ( - "net/http" - "net/url" - "strconv" - "strings" - "time" - - "golang.org/x/net/context" - "golang.org/x/oauth2/internal" -) - -// expiryDelta determines how earlier a token should be considered -// expired than its actual expiration time. It is used to avoid late -// expirations due to client-server time mismatches. -const expiryDelta = 10 * time.Second - -// Token represents the crendentials used to authorize -// the requests to access protected resources on the OAuth 2.0 -// provider's backend. -// -// Most users of this package should not access fields of Token -// directly. They're exported mostly for use by related packages -// implementing derivative OAuth2 flows. -type Token struct { - // AccessToken is the token that authorizes and authenticates - // the requests. - AccessToken string `json:"access_token"` - - // TokenType is the type of token. - // The Type method returns either this or "Bearer", the default. - TokenType string `json:"token_type,omitempty"` - - // RefreshToken is a token that's used by the application - // (as opposed to the user) to refresh the access token - // if it expires. - RefreshToken string `json:"refresh_token,omitempty"` - - // Expiry is the optional expiration time of the access token. - // - // If zero, TokenSource implementations will reuse the same - // token forever and RefreshToken or equivalent - // mechanisms for that TokenSource will not be used. - Expiry time.Time `json:"expiry,omitempty"` - - // raw optionally contains extra metadata from the server - // when updating a token. - raw interface{} -} - -// Type returns t.TokenType if non-empty, else "Bearer". -func (t *Token) Type() string { - if strings.EqualFold(t.TokenType, "bearer") { - return "Bearer" - } - if strings.EqualFold(t.TokenType, "mac") { - return "MAC" - } - if strings.EqualFold(t.TokenType, "basic") { - return "Basic" - } - if t.TokenType != "" { - return t.TokenType - } - return "Bearer" -} - -// SetAuthHeader sets the Authorization header to r using the access -// token in t. -// -// This method is unnecessary when using Transport or an HTTP Client -// returned by this package. -func (t *Token) SetAuthHeader(r *http.Request) { - r.Header.Set("Authorization", t.Type()+" "+t.AccessToken) -} - -// WithExtra returns a new Token that's a clone of t, but using the -// provided raw extra map. This is only intended for use by packages -// implementing derivative OAuth2 flows. -func (t *Token) WithExtra(extra interface{}) *Token { - t2 := new(Token) - *t2 = *t - t2.raw = extra - return t2 -} - -// Extra returns an extra field. -// Extra fields are key-value pairs returned by the server as a -// part of the token retrieval response. -func (t *Token) Extra(key string) interface{} { - if raw, ok := t.raw.(map[string]interface{}); ok { - return raw[key] - } - - vals, ok := t.raw.(url.Values) - if !ok { - return nil - } - - v := vals.Get(key) - switch s := strings.TrimSpace(v); strings.Count(s, ".") { - case 0: // Contains no "."; try to parse as int - if i, err := strconv.ParseInt(s, 10, 64); err == nil { - return i - } - case 1: // Contains a single "."; try to parse as float - if f, err := strconv.ParseFloat(s, 64); err == nil { - return f - } - } - - return v -} - -// expired reports whether the token is expired. -// t must be non-nil. -func (t *Token) expired() bool { - if t.Expiry.IsZero() { - return false - } - return t.Expiry.Add(-expiryDelta).Before(time.Now()) -} - -// Valid reports whether t is non-nil, has an AccessToken, and is not expired. -func (t *Token) Valid() bool { - return t != nil && t.AccessToken != "" && !t.expired() -} - -// tokenFromInternal maps an *internal.Token struct into -// a *Token struct. -func tokenFromInternal(t *internal.Token) *Token { - if t == nil { - return nil - } - return &Token{ - AccessToken: t.AccessToken, - TokenType: t.TokenType, - RefreshToken: t.RefreshToken, - Expiry: t.Expiry, - raw: t.Raw, - } -} - -// retrieveToken takes a *Config and uses that to retrieve an *internal.Token. -// This token is then mapped from *internal.Token into an *oauth2.Token which is returned along -// with an error.. -func retrieveToken(ctx context.Context, c *Config, v url.Values) (*Token, error) { - tk, err := internal.RetrieveToken(ctx, c.ClientID, c.ClientSecret, c.Endpoint.TokenURL, v) - if err != nil { - return nil, err - } - return tokenFromInternal(tk), nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/transport.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/transport.go deleted file mode 100644 index 92ac7e2..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/oauth2/transport.go +++ /dev/null @@ -1,132 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package oauth2 - -import ( - "errors" - "io" - "net/http" - "sync" -) - -// Transport is an http.RoundTripper that makes OAuth 2.0 HTTP requests, -// wrapping a base RoundTripper and adding an Authorization header -// with a token from the supplied Sources. -// -// Transport is a low-level mechanism. Most code will use the -// higher-level Config.Client method instead. -type Transport struct { - // Source supplies the token to add to outgoing requests' - // Authorization headers. - Source TokenSource - - // Base is the base RoundTripper used to make HTTP requests. - // If nil, http.DefaultTransport is used. - Base http.RoundTripper - - mu sync.Mutex // guards modReq - modReq map[*http.Request]*http.Request // original -> modified -} - -// RoundTrip authorizes and authenticates the request with an -// access token. If no token exists or token is expired, -// tries to refresh/fetch a new token. -func (t *Transport) RoundTrip(req *http.Request) (*http.Response, error) { - if t.Source == nil { - return nil, errors.New("oauth2: Transport's Source is nil") - } - token, err := t.Source.Token() - if err != nil { - return nil, err - } - - req2 := cloneRequest(req) // per RoundTripper contract - token.SetAuthHeader(req2) - t.setModReq(req, req2) - res, err := t.base().RoundTrip(req2) - if err != nil { - t.setModReq(req, nil) - return nil, err - } - res.Body = &onEOFReader{ - rc: res.Body, - fn: func() { t.setModReq(req, nil) }, - } - return res, nil -} - -// CancelRequest cancels an in-flight request by closing its connection. -func (t *Transport) CancelRequest(req *http.Request) { - type canceler interface { - CancelRequest(*http.Request) - } - if cr, ok := t.base().(canceler); ok { - t.mu.Lock() - modReq := t.modReq[req] - delete(t.modReq, req) - t.mu.Unlock() - cr.CancelRequest(modReq) - } -} - -func (t *Transport) base() http.RoundTripper { - if t.Base != nil { - return t.Base - } - return http.DefaultTransport -} - -func (t *Transport) setModReq(orig, mod *http.Request) { - t.mu.Lock() - defer t.mu.Unlock() - if t.modReq == nil { - t.modReq = make(map[*http.Request]*http.Request) - } - if mod == nil { - delete(t.modReq, orig) - } else { - t.modReq[orig] = mod - } -} - -// cloneRequest returns a clone of the provided *http.Request. -// The clone is a shallow copy of the struct and its Header map. -func cloneRequest(r *http.Request) *http.Request { - // shallow copy of the struct - r2 := new(http.Request) - *r2 = *r - // deep copy of the Header - r2.Header = make(http.Header, len(r.Header)) - for k, s := range r.Header { - r2.Header[k] = append([]string(nil), s...) - } - return r2 -} - -type onEOFReader struct { - rc io.ReadCloser - fn func() -} - -func (r *onEOFReader) Read(p []byte) (n int, err error) { - n, err = r.rc.Read(p) - if err == io.EOF { - r.runFunc() - } - return -} - -func (r *onEOFReader) Close() error { - err := r.rc.Close() - r.runFunc() - return err -} - -func (r *onEOFReader) runFunc() { - if fn := r.fn; fn != nil { - fn() - r.fn = nil - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/cases.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/cases.go deleted file mode 100644 index 13b3a57..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/cases.go +++ /dev/null @@ -1,129 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate go run gen.go gen_trieval.go - -// Package cases provides general and language-specific case mappers. -package cases - -import ( - "golang.org/x/text/language" - "golang.org/x/text/transform" -) - -// References: -// - Unicode Reference Manual Chapter 3.13, 4.2, and 5.18. -// - http://www.unicode.org/reports/tr29/ -// - http://www.unicode.org/Public/6.3.0/ucd/CaseFolding.txt -// - http://www.unicode.org/Public/6.3.0/ucd/SpecialCasing.txt -// - http://www.unicode.org/Public/6.3.0/ucd/DerivedCoreProperties.txt -// - http://www.unicode.org/Public/6.3.0/ucd/auxiliary/WordBreakProperty.txt -// - http://www.unicode.org/Public/6.3.0/ucd/auxiliary/WordBreakTest.txt -// - http://userguide.icu-project.org/transforms/casemappings - -// TODO: -// - Case folding -// - Wide and Narrow? -// - Segmenter option for title casing. -// - ASCII fast paths -// - Encode Soft-Dotted property within trie somehow. - -// A Caser transforms given input to a certain case. It implements -// transform.Transformer. -// -// A Caser may be stateful and should therefore not be shared between -// goroutines. -type Caser struct { - t transform.Transformer -} - -// Bytes returns a new byte slice with the result of converting b to the case -// form implemented by c. -func (c Caser) Bytes(b []byte) []byte { - b, _, _ = transform.Bytes(c.t, b) - return b -} - -// String returns a string with the result of transforming s to the case form -// implemented by c. -func (c Caser) String(s string) string { - s, _, _ = transform.String(c.t, s) - return s -} - -// Reset resets the Caser to be reused for new input after a previous call to -// Transform. -func (c Caser) Reset() { c.t.Reset() } - -// Transform implements the Transformer interface and transforms the given input -// to the case form implemented by c. -func (c Caser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - return c.t.Transform(dst, src, atEOF) -} - -// Upper returns a Caser for language-specific uppercasing. -func Upper(t language.Tag, opts ...Option) Caser { - return Caser{makeUpper(t, getOpts(opts...))} -} - -// Lower returns a Caser for language-specific lowercasing. -func Lower(t language.Tag, opts ...Option) Caser { - return Caser{makeLower(t, getOpts(opts...))} -} - -// Title returns a Caser for language-specific title casing. It uses an -// approximation of the default Unicode Word Break algorithm. -func Title(t language.Tag, opts ...Option) Caser { - return Caser{makeTitle(t, getOpts(opts...))} -} - -// Fold returns a Caser that implements Unicode case folding. The returned Caser -// is stateless and safe to use concurrently by multiple goroutines. -// -// Case folding does not normalize the input and may not preserve a normal form. -// Use the collate or search package for more convenient and linguistically -// sound comparisons. Use unicode/precis for string comparisons where security -// aspects are a concern. -func Fold(opts ...Option) Caser { - return Caser{makeFold(getOpts(opts...))} -} - -// An Option is used to modify the behavior of a Caser. -type Option func(o *options) - -var ( - // NoLower disables the lowercasing of non-leading letters for a title - // caser. - NoLower Option = noLower - - // Compact omits mappings in case folding for characters that would grow the - // input. (Unimplemented.) - Compact Option = compact -) - -// TODO: option to preserve a normal form, if applicable? - -type options struct { - noLower bool - simple bool - - // TODO: segmenter, max ignorable, alternative versions, etc. - - noFinalSigma bool // Only used for testing. -} - -func getOpts(o ...Option) (res options) { - for _, f := range o { - f(&res) - } - return -} - -func noLower(o *options) { - o.noLower = true -} - -func compact(o *options) { - o.simple = true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/context.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/context.go deleted file mode 100644 index 0d2e497..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/context.go +++ /dev/null @@ -1,281 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package cases - -import ( - "golang.org/x/text/transform" -) - -// A context is used for iterating over source bytes, fetching case info and -// writing to a destination buffer. -// -// Casing operations may need more than one rune of context to decide how a rune -// should be cased. Casing implementations should call checkpoint on context -// whenever it is known to be safe to return the runes processed so far. -// -// It is recommended for implementations to not allow for more than 30 case -// ignorables as lookahead (analogous to the limit in norm) and to use state if -// unbounded lookahead is needed for cased runes. -type context struct { - dst, src []byte - atEOF bool - - pDst int // pDst points past the last written rune in dst. - pSrc int // pSrc points to the start of the currently scanned rune. - - // checkpoints safe to return in Transform, where nDst <= pDst and nSrc <= pSrc. - nDst, nSrc int - err error - - sz int // size of current rune - info info // case information of currently scanned rune - - // State preserved across calls to Transform. - isMidWord bool // false if next cased letter needs to be title-cased. -} - -func (c *context) Reset() { - c.isMidWord = false -} - -// ret returns the return values for the Transform method. It checks whether -// there were insufficient bytes in src to complete and introduces an error -// accordingly, if necessary. -func (c *context) ret() (nDst, nSrc int, err error) { - if c.err != nil || c.nSrc == len(c.src) { - return c.nDst, c.nSrc, c.err - } - // This point is only reached by mappers if there was no short destination - // buffer. This means that the source buffer was exhausted and that c.sz was - // set to 0 by next. - if c.atEOF && c.pSrc == len(c.src) { - return c.pDst, c.pSrc, nil - } - return c.nDst, c.nSrc, transform.ErrShortSrc -} - -// checkpoint sets the return value buffer points for Transform to the current -// positions. -func (c *context) checkpoint() { - if c.err == nil { - c.nDst, c.nSrc = c.pDst, c.pSrc+c.sz - } -} - -// unreadRune causes the last rune read by next to be reread on the next -// invocation of next. Only one unreadRune may be called after a call to next. -func (c *context) unreadRune() { - c.sz = 0 -} - -func (c *context) next() bool { - c.pSrc += c.sz - if c.pSrc == len(c.src) || c.err != nil { - c.info, c.sz = 0, 0 - return false - } - v, sz := trie.lookup(c.src[c.pSrc:]) - c.info, c.sz = info(v), sz - if c.sz == 0 { - if c.atEOF { - // A zero size means we have an incomplete rune. If we are atEOF, - // this means it is an illegal rune, which we will consume one - // byte at a time. - c.sz = 1 - } else { - c.err = transform.ErrShortSrc - return false - } - } - return true -} - -// writeBytes adds bytes to dst. -func (c *context) writeBytes(b []byte) bool { - if len(c.dst)-c.pDst < len(b) { - c.err = transform.ErrShortDst - return false - } - // This loop is faster than using copy. - for _, ch := range b { - c.dst[c.pDst] = ch - c.pDst++ - } - return true -} - -// writeString writes the given string to dst. -func (c *context) writeString(s string) bool { - if len(c.dst)-c.pDst < len(s) { - c.err = transform.ErrShortDst - return false - } - // This loop is faster than using copy. - for i := 0; i < len(s); i++ { - c.dst[c.pDst] = s[i] - c.pDst++ - } - return true -} - -// copy writes the current rune to dst. -func (c *context) copy() bool { - return c.writeBytes(c.src[c.pSrc : c.pSrc+c.sz]) -} - -// copyXOR copies the current rune to dst and modifies it by applying the XOR -// pattern of the case info. It is the responsibility of the caller to ensure -// that this is a rune with a XOR pattern defined. -func (c *context) copyXOR() bool { - if !c.copy() { - return false - } - if c.info&xorIndexBit == 0 { - // Fast path for 6-bit XOR pattern, which covers most cases. - c.dst[c.pDst-1] ^= byte(c.info >> xorShift) - } else { - // Interpret XOR bits as an index. - // TODO: test performance for unrolling this loop. Verify that we have - // at least two bytes and at most three. - idx := c.info >> xorShift - for p := c.pDst - 1; ; p-- { - c.dst[p] ^= xorData[idx] - idx-- - if xorData[idx] == 0 { - break - } - } - } - return true -} - -// hasPrefix returns true if src[pSrc:] starts with the given string. -func (c *context) hasPrefix(s string) bool { - b := c.src[c.pSrc:] - if len(b) < len(s) { - return false - } - for i, c := range b[:len(s)] { - if c != s[i] { - return false - } - } - return true -} - -// caseType returns an info with only the case bits, normalized to either -// cLower, cUpper, cTitle or cUncased. -func (c *context) caseType() info { - cm := c.info & 0x7 - if cm < 4 { - return cm - } - if cm >= cXORCase { - // xor the last bit of the rune with the case type bits. - b := c.src[c.pSrc+c.sz-1] - return info(b&1) ^ cm&0x3 - } - if cm == cIgnorableCased { - return cLower - } - return cUncased -} - -// lower writes the lowercase version of the current rune to dst. -func lower(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cLower { - return c.copy() - } - if c.info&exceptionBit == 0 { - return c.copyXOR() - } - e := exceptions[c.info>>exceptionShift:] - offset := 2 + e[0]&lengthMask // size of header + fold string - if nLower := (e[1] >> lengthBits) & lengthMask; nLower != noChange { - return c.writeString(e[offset : offset+nLower]) - } - return c.copy() -} - -// upper writes the uppercase version of the current rune to dst. -func upper(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cUpper { - return c.copy() - } - if c.info&exceptionBit == 0 { - return c.copyXOR() - } - e := exceptions[c.info>>exceptionShift:] - offset := 2 + e[0]&lengthMask // size of header + fold string - // Get length of first special case mapping. - n := (e[1] >> lengthBits) & lengthMask - if ct == cTitle { - // The first special case mapping is for lower. Set n to the second. - if n == noChange { - n = 0 - } - n, e = e[1]&lengthMask, e[n:] - } - if n != noChange { - return c.writeString(e[offset : offset+n]) - } - return c.copy() -} - -// title writes the title case version of the current rune to dst. -func title(c *context) bool { - ct := c.caseType() - if c.info&hasMappingMask == 0 || ct == cTitle { - return c.copy() - } - if c.info&exceptionBit == 0 { - if ct == cLower { - return c.copyXOR() - } - return c.copy() - } - // Get the exception data. - e := exceptions[c.info>>exceptionShift:] - offset := 2 + e[0]&lengthMask // size of header + fold string - - nFirst := (e[1] >> lengthBits) & lengthMask - if nTitle := e[1] & lengthMask; nTitle != noChange { - if nFirst != noChange { - e = e[nFirst:] - } - return c.writeString(e[offset : offset+nTitle]) - } - if ct == cLower && nFirst != noChange { - // Use the uppercase version instead. - return c.writeString(e[offset : offset+nFirst]) - } - // Already in correct case. - return c.copy() -} - -// foldFull writes the foldFull version of the current rune to dst. -func foldFull(c *context) bool { - if c.info&hasMappingMask == 0 { - return c.copy() - } - ct := c.caseType() - if c.info&exceptionBit == 0 { - if ct != cLower || c.info&inverseFoldBit != 0 { - return c.copyXOR() - } - return c.copy() - } - e := exceptions[c.info>>exceptionShift:] - n := e[0] & lengthMask - if n == 0 { - if ct == cLower { - return c.copy() - } - n = (e[1] >> lengthBits) & lengthMask - } - return c.writeString(e[2 : 2+n]) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/fold.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/fold.go deleted file mode 100644 index e95bfa8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/fold.go +++ /dev/null @@ -1,26 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package cases - -import "golang.org/x/text/transform" - -type caseFolder struct{ transform.NopResetter } - -// caseFolder implements the Transformer interface for doing case folding. -func (t *caseFolder) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - c := context{dst: dst, src: src, atEOF: atEOF} - for c.next() { - foldFull(&c) - c.checkpoint() - } - return c.ret() -} - -func makeFold(o options) transform.Transformer { - // TODO: Special case folding, through option Language, Special/Turkic, or - // both. - // TODO: Implement Compact options. - return &caseFolder{} -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen.go deleted file mode 100644 index f46170f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen.go +++ /dev/null @@ -1,831 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -// This program generates the trie for casing operations. The Unicode casing -// algorithm requires the lookup of various properties and mappings for each -// rune. The table generated by this generator combines several of the most -// frequently used of these into a single trie so that they can be accessed -// with a single lookup. -package main - -import ( - "bytes" - "fmt" - "io" - "io/ioutil" - "log" - "reflect" - "strconv" - "strings" - "unicode" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/triegen" - "golang.org/x/text/internal/ucd" - "golang.org/x/text/unicode/norm" -) - -func main() { - gen.Init() - genTables() - genTablesTest() - gen.Repackage("gen_trieval.go", "trieval.go", "cases") -} - -// runeInfo contains all information for a rune that we care about for casing -// operations. -type runeInfo struct { - Rune rune - - entry info // trie value for this rune. - - CaseMode info - - // Simple case mappings. - Simple [1 + maxCaseMode][]rune - - // Special casing - HasSpecial bool - Conditional bool - Special [1 + maxCaseMode][]rune - - // Folding - FoldSimple rune - FoldSpecial rune - FoldFull []rune - - // TODO: FC_NFKC, or equivalent data. - - // Properties - SoftDotted bool - CaseIgnorable bool - Cased bool - DecomposeGreek bool - BreakType string - BreakCat breakCategory - - // We care mostly about 0, Above, and IotaSubscript. - CCC byte -} - -type breakCategory int - -const ( - breakBreak breakCategory = iota - breakLetter - breakIgnored -) - -// mapping returns the case mapping for the given case type. -func (r *runeInfo) mapping(c info) string { - if r.HasSpecial { - return string(r.Special[c]) - } - if len(r.Simple[c]) != 0 { - return string(r.Simple[c]) - } - return string(r.Rune) -} - -func parse(file string, f func(p *ucd.Parser)) { - ucd.Parse(gen.OpenUCDFile(file), f) -} - -func parseUCD() []runeInfo { - chars := make([]runeInfo, unicode.MaxRune) - - get := func(r rune) *runeInfo { - c := &chars[r] - c.Rune = r - return c - } - - parse("UnicodeData.txt", func(p *ucd.Parser) { - ri := get(p.Rune(0)) - ri.CCC = byte(p.Int(ucd.CanonicalCombiningClass)) - ri.Simple[cLower] = p.Runes(ucd.SimpleLowercaseMapping) - ri.Simple[cUpper] = p.Runes(ucd.SimpleUppercaseMapping) - ri.Simple[cTitle] = p.Runes(ucd.SimpleTitlecaseMapping) - if p.String(ucd.GeneralCategory) == "Lt" { - ri.CaseMode = cTitle - } - }) - - // ; - parse("PropList.txt", func(p *ucd.Parser) { - if p.String(1) == "Soft_Dotted" { - chars[p.Rune(0)].SoftDotted = true - } - }) - - // ; - parse("DerivedCoreProperties.txt", func(p *ucd.Parser) { - ri := get(p.Rune(0)) - switch p.String(1) { - case "Case_Ignorable": - ri.CaseIgnorable = true - case "Cased": - ri.Cased = true - case "Lowercase": - ri.CaseMode = cLower - case "Uppercase": - ri.CaseMode = cUpper - } - }) - - // ; ; ; <upper> ; (<condition_list> ;)? - parse("SpecialCasing.txt", func(p *ucd.Parser) { - // We drop all conditional special casing and deal with them manually in - // the language-specific case mappers. Rune 0x03A3 is the only one with - // a conditional formatting that is not language-specific. However, - // dealing with this letter is tricky, especially in a streaming - // context, so we deal with it in the Caser for Greek specifically. - ri := get(p.Rune(0)) - if p.String(4) == "" { - ri.HasSpecial = true - ri.Special[cLower] = p.Runes(1) - ri.Special[cTitle] = p.Runes(2) - ri.Special[cUpper] = p.Runes(3) - } else { - ri.Conditional = true - } - }) - - // TODO: Use text breaking according to UAX #29. - // <code>; <word break type> - parse("auxiliary/WordBreakProperty.txt", func(p *ucd.Parser) { - ri := get(p.Rune(0)) - ri.BreakType = p.String(1) - - // We collapse the word breaking properties onto the categories we need. - switch p.String(1) { // TODO: officially we need to canonicalize. - case "Format", "MidLetter", "MidNumLet", "Single_Quote": - ri.BreakCat = breakIgnored - case "ALetter", "Hebrew_Letter", "Numeric", "Extend", "ExtendNumLet": - ri.BreakCat = breakLetter - } - }) - - // <code>; <type>; <mapping> - parse("CaseFolding.txt", func(p *ucd.Parser) { - ri := get(p.Rune(0)) - switch p.String(1) { - case "C": - ri.FoldSimple = p.Rune(2) - ri.FoldFull = p.Runes(2) - case "S": - ri.FoldSimple = p.Rune(2) - case "T": - ri.FoldSpecial = p.Rune(2) - case "F": - ri.FoldFull = p.Runes(2) - default: - log.Fatalf("%U: unknown type: %s", p.Rune(0), p.String(1)) - } - }) - - return chars -} - -func genTables() { - chars := parseUCD() - verifyProperties(chars) - - t := triegen.NewTrie("case") - for i := range chars { - c := &chars[i] - makeEntry(c) - t.Insert(rune(i), uint64(c.entry)) - } - - w := gen.NewCodeWriter() - defer w.WriteGoFile("tables.go", "cases") - - gen.WriteUnicodeVersion(w) - - // TODO: write CLDR version after adding a mechanism to detect that the - // tables on which the manually created locale-sensitive casing code is - // based hasn't changed. - - w.WriteVar("xorData", string(xorData)) - w.WriteVar("exceptions", string(exceptionData)) - - sz, err := t.Gen(w, triegen.Compact(&sparseCompacter{})) - if err != nil { - log.Fatal(err) - } - w.Size += sz -} - -func makeEntry(ri *runeInfo) { - if ri.CaseIgnorable { - if ri.Cased { - ri.entry = cIgnorableCased - } else { - ri.entry = cIgnorableUncased - } - } else { - ri.entry = ri.CaseMode - } - - // TODO: handle soft-dotted. - - ccc := cccOther - switch ri.CCC { - case 0: // Not_Reordered - ccc = cccZero - case above: // Above - ccc = cccAbove - } - if ri.BreakCat == breakBreak { - ccc = cccBreak - } - - ri.entry |= ccc - - if ri.CaseMode == cUncased { - return - } - - // Need to do something special. - if ri.CaseMode == cTitle || ri.HasSpecial || ri.mapping(cTitle) != ri.mapping(cUpper) { - makeException(ri) - return - } - if f := string(ri.FoldFull); len(f) > 0 && f != ri.mapping(cUpper) && f != ri.mapping(cLower) { - makeException(ri) - return - } - - // Rune is either lowercase or uppercase. - - orig := string(ri.Rune) - mapped := "" - if ri.CaseMode == cUpper { - mapped = ri.mapping(cLower) - } else { - mapped = ri.mapping(cUpper) - } - - if len(orig) != len(mapped) { - makeException(ri) - return - } - - if string(ri.FoldFull) == ri.mapping(cUpper) { - ri.entry |= inverseFoldBit - } - - n := len(orig) - - // Create per-byte XOR mask. - var b []byte - for i := 0; i < n; i++ { - b = append(b, orig[i]^mapped[i]) - } - - // Remove leading 0 bytes, but keep at least one byte. - for ; len(b) > 1 && b[0] == 0; b = b[1:] { - } - - if len(b) == 1 && b[0]&0xc0 == 0 { - ri.entry |= info(b[0]) << xorShift - return - } - - key := string(b) - x, ok := xorCache[key] - if !ok { - xorData = append(xorData, 0) // for detecting start of sequence - xorData = append(xorData, b...) - - x = len(xorData) - 1 - xorCache[key] = x - } - ri.entry |= info(x<<xorShift) | xorIndexBit -} - -var xorCache = map[string]int{} - -// xorData contains byte-wise XOR data for the least significant bytes of a -// UTF-8 encoded rune. An index points to the last byte. The sequence starts -// with a zero terminator. -var xorData = []byte{} - -// See the comments in gen_trieval.go re "the exceptions slice". -var exceptionData = []byte{0} - -// makeException encodes case mappings that cannot be expressed in a simple -// XOR diff. -func makeException(ri *runeInfo) { - ccc := ri.entry & cccMask - // Set exception bit and retain case type. - ri.entry &= 0x0007 - ri.entry |= exceptionBit - - if len(exceptionData) >= 1<<numExceptionBits { - log.Fatalf("%U:exceptionData too large %x > %d bits", ri.Rune, len(exceptionData), numExceptionBits) - } - - // Set the offset in the exceptionData array. - ri.entry |= info(len(exceptionData) << exceptionShift) - - orig := string(ri.Rune) - tc := ri.mapping(cTitle) - uc := ri.mapping(cUpper) - lc := ri.mapping(cLower) - ff := string(ri.FoldFull) - - // addString sets the length of a string and adds it to the expansions array. - addString := func(s string, b *byte) { - if len(s) == 0 { - // Zero-length mappings exist, but only for conditional casing, - // which we are representing outside of this table. - log.Fatalf("%U: has zero-length mapping.", ri.Rune) - } - *b <<= 3 - if s != orig { - n := len(s) - if n > 7 { - log.Fatalf("%U: mapping larger than 7 (%d)", ri.Rune, n) - } - *b |= byte(n) - exceptionData = append(exceptionData, s...) - } - } - - // byte 0: - exceptionData = append(exceptionData, byte(ccc)|byte(len(ff))) - - // byte 1: - p := len(exceptionData) - exceptionData = append(exceptionData, 0) - - if len(ff) > 7 { // May be zero-length. - log.Fatalf("%U: fold string larger than 7 (%d)", ri.Rune, len(ff)) - } - exceptionData = append(exceptionData, ff...) - ct := ri.CaseMode - if ct != cLower { - addString(lc, &exceptionData[p]) - } - if ct != cUpper { - addString(uc, &exceptionData[p]) - } - if ct != cTitle { - // If title is the same as upper, we set it to the original string so - // that it will be marked as not present. This implies title case is - // the same as upper case. - if tc == uc { - tc = orig - } - addString(tc, &exceptionData[p]) - } -} - -// sparseCompacter is a trie value block Compacter. There are many cases where -// successive runes alternate between lower- and upper-case. This Compacter -// exploits this by adding a special case type where the case value is obtained -// from or-ing it with the least-significant bit of the rune, creating large -// ranges of equal case values that compress well. -type sparseCompacter struct { - sparseBlocks [][]uint16 - sparseOffsets []uint16 - sparseCount int -} - -// makeSparse returns the number of elements that compact block would contain -// as well as the modified values. -func makeSparse(vals []uint64) ([]uint16, int) { - // Copy the values. - values := make([]uint16, len(vals)) - for i, v := range vals { - values[i] = uint16(v) - } - - alt := func(i int, v uint16) uint16 { - if cm := info(v & fullCasedMask); cm == cUpper || cm == cLower { - // Convert cLower or cUpper to cXORCase value, which has the form 11x. - xor := v - xor &^= 1 - xor |= uint16(i&1) ^ (v & 1) - xor |= 0x4 - return xor - } - return v - } - - var count int - var previous uint16 - for i, v := range values { - if v != 0 { - // Try if the unmodified value is equal to the previous. - if v == previous { - continue - } - - // Try if the xor-ed value is equal to the previous value. - a := alt(i, v) - if a == previous { - values[i] = a - continue - } - - // This is a new value. - count++ - - // Use the xor-ed value if it will be identical to the next value. - if p := i + 1; p < len(values) && alt(p, values[p]) == a { - values[i] = a - v = a - } - } - previous = v - } - return values, count -} - -func (s *sparseCompacter) Size(v []uint64) (int, bool) { - _, n := makeSparse(v) - - // We limit using this method to having 16 entries. - if n > 16 { - return 0, false - } - - return 2 + int(reflect.TypeOf(valueRange{}).Size())*n, true -} - -func (s *sparseCompacter) Store(v []uint64) uint32 { - h := uint32(len(s.sparseOffsets)) - values, sz := makeSparse(v) - s.sparseBlocks = append(s.sparseBlocks, values) - s.sparseOffsets = append(s.sparseOffsets, uint16(s.sparseCount)) - s.sparseCount += sz - return h -} - -func (s *sparseCompacter) Handler() string { - // The sparse global variable and its lookup method is defined in gen_trieval.go. - return "sparse.lookup" -} - -func (s *sparseCompacter) Print(w io.Writer) (retErr error) { - p := func(format string, args ...interface{}) { - _, err := fmt.Fprintf(w, format, args...) - if retErr == nil && err != nil { - retErr = err - } - } - - ls := len(s.sparseBlocks) - if ls == len(s.sparseOffsets) { - s.sparseOffsets = append(s.sparseOffsets, uint16(s.sparseCount)) - } - p("// sparseOffsets: %d entries, %d bytes\n", ls+1, (ls+1)*2) - p("var sparseOffsets = %#v\n\n", s.sparseOffsets) - - ns := s.sparseCount - p("// sparseValues: %d entries, %d bytes\n", ns, ns*4) - p("var sparseValues = [%d]valueRange {", ns) - for i, values := range s.sparseBlocks { - p("\n// Block %#x, offset %#x", i, s.sparseOffsets[i]) - var v uint16 - for i, nv := range values { - if nv != v { - if v != 0 { - p(",hi:%#02x},", 0x80+i-1) - } - if nv != 0 { - p("\n{value:%#04x,lo:%#02x", nv, 0x80+i) - } - } - v = nv - } - if v != 0 { - p(",hi:%#02x},", 0x80+len(values)-1) - } - } - p("\n}\n\n") - return -} - -// verifyProperties that properties of the runes that are relied upon in the -// implementation. Each property is marked with an identifier that is referred -// to in the places where it is used. -func verifyProperties(chars []runeInfo) { - for i, c := range chars { - r := rune(i) - - // Rune properties. - - // A.1: modifier never changes on lowercase. [ltLower] - if c.CCC > 0 && unicode.ToLower(r) != r { - log.Fatalf("%U: non-starter changes when lowercased", r) - } - - // A.2: properties of decompositions starting with I or J. [ltLower] - d := norm.NFD.PropertiesString(string(r)).Decomposition() - if len(d) > 0 { - if d[0] == 'I' || d[0] == 'J' { - // A.2.1: we expect at least an ASCII character and a modifier. - if len(d) < 3 { - log.Fatalf("%U: length of decomposition was %d; want >= 3", r, len(d)) - } - - // All subsequent runes are modifiers and all have the same CCC. - runes := []rune(string(d[1:])) - ccc := chars[runes[0]].CCC - - for _, mr := range runes[1:] { - mc := chars[mr] - - // A.2.2: all modifiers have a CCC of Above or less. - if ccc == 0 || ccc > above { - log.Fatalf("%U: CCC of successive rune (%U) was %d; want (0,230]", r, mr, ccc) - } - - // A.2.3: a sequence of modifiers all have the same CCC. - if mc.CCC != ccc { - log.Fatalf("%U: CCC of follow-up modifier (%U) was %d; want %d", r, mr, mc.CCC, ccc) - } - - // A.2.4: for each trailing r, r in [0x300, 0x311] <=> CCC == Above. - if (ccc == above) != (0x300 <= mr && mr <= 0x311) { - log.Fatalf("%U: modifier %U in [U+0300, U+0311] != ccc(%U) == 230", r, mr, mr) - } - - if i += len(string(mr)); i >= len(d) { - break - } - } - } - } - - // A.3: no U+0307 in decomposition of Soft-Dotted rune. [ltUpper] - if unicode.Is(unicode.Soft_Dotted, r) && strings.Contains(string(d), "\u0307") { - log.Fatalf("%U: decomposition of soft-dotted rune may not contain U+0307", r) - } - - // A.4: only rune U+0345 may be of CCC Iota_Subscript. [elUpper] - if c.CCC == iotaSubscript && r != 0x0345 { - log.Fatalf("%U: only rune U+0345 may have CCC Iota_Subscript", r) - } - - // A.5: soft-dotted runes do not have exceptions. - if c.SoftDotted && c.entry&exceptionBit != 0 { - log.Fatalf("%U: soft-dotted has exception", r) - } - - // A.6: Greek decomposition. [elUpper] - if unicode.Is(unicode.Greek, r) { - if b := norm.NFD.PropertiesString(string(r)).Decomposition(); b != nil { - runes := []rune(string(b)) - // A.6.1: If a Greek rune decomposes and the first rune of the - // decomposition is greater than U+00FF, the rune is always - // great and not a modifier. - if f := runes[0]; unicode.IsMark(f) || f > 0xFF && !unicode.Is(unicode.Greek, f) { - log.Fatalf("%U: expeced first rune of Greek decomposition to be letter, found %U", r, f) - } - // A.6.2: Any follow-up rune in a Greek decomposition is a - // modifier of which the first should be gobbled in - // decomposition. - for _, m := range runes[1:] { - switch m { - case 0x0313, 0x0314, 0x0301, 0x0300, 0x0306, 0x0342, 0x0308, 0x0304, 0x345: - default: - log.Fatalf("%U: modifier %U is outside of expeced Greek modifier set", r, m) - } - } - } - } - - // Breaking properties. - - // B.1: all runes with CCC > 0 are of break type Extend. - if c.CCC > 0 && c.BreakType != "Extend" { - log.Fatalf("%U: CCC == %d, but got break type %s; want Extend", r, c.CCC, c.BreakType) - } - - // B.2: all cased runes with c.CCC == 0 are of break type ALetter. - if c.CCC == 0 && c.Cased && c.BreakType != "ALetter" { - log.Fatalf("%U: cased, but got break type %s; want ALetter", r, c.BreakType) - } - - // B.3: letter category. - if c.CCC == 0 && c.BreakCat != breakBreak && !c.CaseIgnorable { - if c.BreakCat != breakLetter { - log.Fatalf("%U: check for letter break type gave %d; want %d", r, c.BreakCat, breakLetter) - } - } - } -} - -func genTablesTest() { - w := &bytes.Buffer{} - - fmt.Fprintln(w, "var (") - printProperties(w, "DerivedCoreProperties.txt", "Case_Ignorable", verifyIgnore) - - // We discard the output as we know we have perfect functions. We run them - // just to verify the properties are correct. - n := printProperties(ioutil.Discard, "DerivedCoreProperties.txt", "Cased", verifyCased) - n += printProperties(ioutil.Discard, "DerivedCoreProperties.txt", "Lowercase", verifyLower) - n += printProperties(ioutil.Discard, "DerivedCoreProperties.txt", "Uppercase", verifyUpper) - if n > 0 { - log.Fatalf("One of the discarded properties does not have a perfect filter.") - } - - // <code>; <lower> ; <title> ; <upper> ; (<condition_list> ;)? - fmt.Fprintln(w, "\tspecial = map[rune]struct{ toLower, toTitle, toUpper string }{") - parse("SpecialCasing.txt", func(p *ucd.Parser) { - // Skip conditional entries. - if p.String(4) != "" { - return - } - r := p.Rune(0) - fmt.Fprintf(w, "\t\t0x%04x: {%q, %q, %q},\n", - r, string(p.Runes(1)), string(p.Runes(2)), string(p.Runes(3))) - }) - fmt.Fprint(w, "\t}\n\n") - - // <code>; <type>; <runes> - table := map[rune]struct{ simple, full, special string }{} - parse("CaseFolding.txt", func(p *ucd.Parser) { - r := p.Rune(0) - t := p.String(1) - v := string(p.Runes(2)) - if t != "T" && v == string(unicode.ToLower(r)) { - return - } - x := table[r] - switch t { - case "C": - x.full = v - x.simple = v - case "S": - x.simple = v - case "F": - x.full = v - case "T": - x.special = v - } - table[r] = x - }) - fmt.Fprintln(w, "\tfoldMap = map[rune]struct{ simple, full, special string }{") - for r := rune(0); r < 0x10FFFF; r++ { - x, ok := table[r] - if !ok { - continue - } - fmt.Fprintf(w, "\t\t0x%04x: {%q, %q, %q},\n", r, x.simple, x.full, x.special) - } - fmt.Fprint(w, "\t}\n\n") - - // Break property - notBreak := map[rune]bool{} - parse("auxiliary/WordBreakProperty.txt", func(p *ucd.Parser) { - switch p.String(1) { - case "Extend", "Format", "MidLetter", "MidNumLet", "Single_Quote", - "ALetter", "Hebrew_Letter", "Numeric", "ExtendNumLet": - notBreak[p.Rune(0)] = true - } - }) - - fmt.Fprintln(w, "\tbreakProp = []struct{ lo, hi rune }{") - inBreak := false - for r := rune(0); r <= lastRuneForTesting; r++ { - if isBreak := !notBreak[r]; isBreak != inBreak { - if isBreak { - fmt.Fprintf(w, "\t\t{0x%x, ", r) - } else { - fmt.Fprintf(w, "0x%x},\n", r-1) - } - inBreak = isBreak - } - } - if inBreak { - fmt.Fprintf(w, "0x%x},\n", lastRuneForTesting) - } - fmt.Fprint(w, "\t}\n\n") - - // Word break test - // Filter out all samples that do not contain cased characters. - cased := map[rune]bool{} - parse("DerivedCoreProperties.txt", func(p *ucd.Parser) { - if p.String(1) == "Cased" { - cased[p.Rune(0)] = true - } - }) - - fmt.Fprintln(w, "\tbreakTest = []string{") - parse("auxiliary/WordBreakTest.txt", func(p *ucd.Parser) { - c := strings.Split(p.String(0), " ") - - const sep = '|' - numCased := 0 - test := "" - for ; len(c) >= 2; c = c[2:] { - if c[0] == "÷" && test != "" { - test += string(sep) - } - i, err := strconv.ParseUint(c[1], 16, 32) - r := rune(i) - if err != nil { - log.Fatalf("Invalid rune %q.", c[1]) - } - if r == sep { - log.Fatalf("Separator %q not allowed in test data. Pick another one.", sep) - } - if cased[r] { - numCased++ - } - test += string(r) - } - if numCased > 1 { - fmt.Fprintf(w, "\t\t%q,\n", test) - } - }) - fmt.Fprintln(w, "\t}") - - fmt.Fprintln(w, ")") - - gen.WriteGoFile("tables_test.go", "cases", w.Bytes()) -} - -// These functions are just used for verification that their definition have not -// changed in the Unicode Standard. - -func verifyCased(r rune) bool { - return verifyLower(r) || verifyUpper(r) || unicode.IsTitle(r) -} - -func verifyLower(r rune) bool { - return unicode.IsLower(r) || unicode.Is(unicode.Other_Lowercase, r) -} - -func verifyUpper(r rune) bool { - return unicode.IsUpper(r) || unicode.Is(unicode.Other_Uppercase, r) -} - -// verifyIgnore is an approximation of the Case_Ignorable property using the -// core unicode package. It is used to reduce the size of the test data. -func verifyIgnore(r rune) bool { - props := []*unicode.RangeTable{ - unicode.Mn, - unicode.Me, - unicode.Cf, - unicode.Lm, - unicode.Sk, - } - for _, p := range props { - if unicode.Is(p, r) { - return true - } - } - return false -} - -// printProperties prints tables of rune properties from the given UCD file. -// A filter func f can be given to exclude certain values. A rune r will have -// the indicated property if it is in the generated table or if f(r). -func printProperties(w io.Writer, file, property string, f func(r rune) bool) int { - verify := map[rune]bool{} - n := 0 - varNameParts := strings.Split(property, "_") - varNameParts[0] = strings.ToLower(varNameParts[0]) - fmt.Fprintf(w, "\t%s = map[rune]bool{\n", strings.Join(varNameParts, "")) - parse(file, func(p *ucd.Parser) { - if p.String(1) == property { - r := p.Rune(0) - verify[r] = true - if !f(r) { - n++ - fmt.Fprintf(w, "\t\t0x%.4x: true,\n", r) - } - } - }) - fmt.Fprint(w, "\t}\n\n") - - // Verify that f is correct, that is, it represents a subset of the property. - for r := rune(0); r <= lastRuneForTesting; r++ { - if !verify[r] && f(r) { - log.Fatalf("Incorrect filter func for property %q.", property) - } - } - return n -} - -// The newCaseTrie, sparseValues and sparseOffsets definitions below are -// placeholders referred to by gen_trieval.go. The real definitions are -// generated by this program and written to tables.go. - -func newCaseTrie(int) int { return 0 } - -var ( - sparseValues [0]valueRange - sparseOffsets [0]uint16 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen_trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen_trieval.go deleted file mode 100644 index cf1a99d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/gen_trieval.go +++ /dev/null @@ -1,217 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// This file contains definitions for interpreting the trie value of the case -// trie generated by "go run gen*.go". It is shared by both the generator -// program and the resultant package. Sharing is achieved by the generator -// copying gen_trieval.go to trieval.go and changing what's above this comment. - -// info holds case information for a single rune. It is the value returned -// by a trie lookup. Most mapping information can be stored in a single 16-bit -// value. If not, for example when a rune is mapped to multiple runes, the value -// stores some basic case data and an index into an array with additional data. -// -// The per-rune values have the following format: -// -// if (exception) { -// 15..5 unsigned exception index -// 4 unused -// } else { -// 15..8 XOR pattern or index to XOR pattern for case mapping -// Only 13..8 are used for XOR patterns. -// 7 inverseFold (fold to upper, not to lower) -// 6 index: interpret the XOR pattern as an index -// 5..4 CCC: zero (normal or break), above or other -// } -// 3 exception: interpret this value as an exception index -// (TODO: is this bit necessary? Probably implied from case mode.) -// 2..0 case mode -// -// For the non-exceptional cases, a rune must be either uncased, lowercase or -// uppercase. If the rune is cased, the XOR pattern maps either a lowercase -// rune to uppercase or an uppercase rune to lowercase (applied to the 10 -// least-significant bits of the rune). -// -// See the definitions below for a more detailed description of the various -// bits. -type info uint16 - -const ( - casedMask = 0x0003 - fullCasedMask = 0x0007 - ignorableMask = 0x0006 - ignorableValue = 0x0004 - - inverseFoldBit = 1 << 7 - - exceptionBit = 1 << 3 - exceptionShift = 5 - numExceptionBits = 11 - - xorIndexBit = 1 << 6 - xorShift = 8 - - // There is no mapping if all xor bits and the exception bit are zero. - hasMappingMask = 0xffc0 | exceptionBit -) - -// The case mode bits encodes the case type of a rune. This includes uncased, -// title, upper and lower case and case ignorable. (For a definition of these -// terms see Chapter 3 of The Unicode Standard Core Specification.) In some rare -// cases, a rune can be both cased and case-ignorable. This is encoded by -// cIgnorableCased. A rune of this type is always lower case. Some runes are -// cased while not having a mapping. -// -// A common pattern for scripts in the Unicode standard is for upper and lower -// case runes to alternate for increasing rune values (e.g. the accented Latin -// ranges starting from U+0100 and U+1E00 among others and some Cyrillic -// characters). We use this property by defining a cXORCase mode, where the case -// mode (always upper or lower case) is derived from the rune value. As the XOR -// pattern for case mappings is often identical for successive runes, using -// cXORCase can result in large series of identical trie values. This, in turn, -// allows us to better compress the trie blocks. -const ( - cUncased info = iota // 000 - cTitle // 001 - cLower // 010 - cUpper // 011 - cIgnorableUncased // 100 - cIgnorableCased // 101 // lower case if mappings exist - cXORCase // 11x // case is cLower | ((rune&1) ^ x) - - maxCaseMode = cUpper -) - -func (c info) isCased() bool { - return c&casedMask != 0 -} - -func (c info) isCaseIgnorable() bool { - return c&ignorableMask == ignorableValue -} - -func (c info) isCaseIgnorableAndNonBreakStarter() bool { - return c&(fullCasedMask|cccMask) == (ignorableValue | cccZero) -} - -func (c info) isNotCasedAndNotCaseIgnorable() bool { - return c&fullCasedMask == 0 -} - -func (c info) isCaseIgnorableAndNotCased() bool { - return c&fullCasedMask == cIgnorableUncased -} - -// The case mapping implementation will need to know about various Canonical -// Combining Class (CCC) values. We encode two of these in the trie value: -// cccZero (0) and cccAbove (230). If the value is cccOther, it means that -// CCC(r) > 0, but not 230. A value of cccBreak means that CCC(r) == 0 and that -// the rune also has the break category Break (see below). -const ( - cccBreak info = iota << 4 - cccZero - cccAbove - cccOther - - cccMask = cccBreak | cccZero | cccAbove | cccOther -) - -const ( - starter = 0 - above = 230 - iotaSubscript = 240 -) - -// The exceptions slice holds data that does not fit in a normal info entry. -// The entry is pointed to by the exception index in an entry. It has the -// following format: -// -// Header -// byte 0: -// 7..6 unused -// 5..4 CCC type (same bits as entry) -// 3 unused -// 2..0 length of fold -// -// byte 1: -// 7..6 unused -// 5..3 length of 1st mapping of case type -// 2..0 length of 2nd mapping of case type -// -// case 1st 2nd -// lower -> upper, title -// upper -> lower, title -// title -> lower, upper -// -// Lengths with the value 0x7 indicate no value and implies no change. -// A length of 0 indicates a mapping to zero-length string. -// -// Body bytes: -// case folding bytes -// lowercase mapping bytes -// uppercase mapping bytes -// titlecase mapping bytes -// closure mapping bytes (for NFKC_Casefold). (TODO) -// -// Fallbacks: -// missing fold -> lower -// missing title -> upper -// all missing -> original rune -// -// exceptions starts with a dummy byte to enforce that there is no zero index -// value. -const ( - lengthMask = 0x07 - lengthBits = 3 - noChange = 0 -) - -// References to generated trie. - -var trie = newCaseTrie(0) - -var sparse = sparseBlocks{ - values: sparseValues[:], - offsets: sparseOffsets[:], -} - -// Sparse block lookup code. - -// valueRange is an entry in a sparse block. -type valueRange struct { - value uint16 - lo, hi byte -} - -type sparseBlocks struct { - values []valueRange - offsets []uint16 -} - -// lookup returns the value from values block n for byte b using binary search. -func (s *sparseBlocks) lookup(n uint32, b byte) uint16 { - lo := s.offsets[n] - hi := s.offsets[n+1] - for lo < hi { - m := lo + (hi-lo)/2 - r := s.values[m] - if r.lo <= b && b <= r.hi { - return r.value - } - if b < r.lo { - hi = m - } else { - lo = m + 1 - } - } - return 0 -} - -// lastRuneForTesting is the last rune used for testing. Everything after this -// is boring. -const lastRuneForTesting = rune(0x1FFFF) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/info.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/info.go deleted file mode 100644 index 669d7ae..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/info.go +++ /dev/null @@ -1,83 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package cases - -func (c info) cccVal() info { - if c&exceptionBit != 0 { - return info(exceptions[c>>exceptionShift]) & cccMask - } - return c & cccMask -} - -func (c info) cccType() info { - ccc := c.cccVal() - if ccc <= cccZero { - return cccZero - } - return ccc -} - -// TODO: Implement full Unicode breaking algorithm: -// 1) Implement breaking in separate package. -// 2) Use the breaker here. -// 3) Compare table size and performance of using the more generic breaker. -// -// Note that we can extend the current algorithm to be much more accurate. This -// only makes sense, though, if the performance and/or space penalty of using -// the generic breaker is big. Extra data will only be needed for non-cased -// runes, which means there are sufficient bits left in the caseType. -// Also note that the standard breaking algorithm doesn't always make sense -// for title casing. For example, a4a -> A4a, but a"4a -> A"4A (where " stands -// for modifier \u0308). -// ICU prohibits breaking in such cases as well. - -// For the purpose of title casing we use an approximation of the Unicode Word -// Breaking algorithm defined in Annex #29: -// http://www.unicode.org/reports/tr29/#Default_Grapheme_Cluster_Table. -// -// For our approximation, we group the Word Break types into the following -// categories, with associated rules: -// -// 1) Letter: -// ALetter, Hebrew_Letter, Numeric, ExtendNumLet, Extend. -// Rule: Never break between consecutive runes of this category. -// -// 2) Mid: -// Format, MidLetter, MidNumLet, Single_Quote. -// (Cf. case-ignorable: MidLetter, MidNumLet or cat is Mn, Me, Cf, Lm or Sk). -// Rule: Don't break between Letter and Mid, but break between two Mids. -// -// 3) Break: -// Any other category, including NewLine, CR, LF and Double_Quote. These -// categories should always result in a break between two cased letters. -// Rule: Always break. -// -// Note 1: the Katakana and MidNum categories can, in esoteric cases, result in -// preventing a break between two cased letters. For now we will ignore this -// (e.g. [ALetter] [ExtendNumLet] [Katakana] [ExtendNumLet] [ALetter] and -// [ALetter] [Numeric] [MidNum] [Numeric] [ALetter].) -// -// Note 2: the rule for Mid is very approximate, but works in most cases. To -// improve, we could store the categories in the trie value and use a FA to -// manage breaks. See TODO comment above. -// -// Note 3: according to the spec, it is possible for the Extend category to -// introduce breaks between other categories grouped in Letter. However, this -// is undesirable for our purposes. ICU prevents breaks in such cases as well. - -// isBreak returns whether this rune should introduce a break. -func (c info) isBreak() bool { - return c.cccVal() == cccBreak -} - -// isLetter returns whether the rune is of break type ALetter, Hebrew_Letter, -// Numeric, ExtendNumLet, or Extend. -func (c info) isLetter() bool { - ccc := c.cccVal() - if ccc == cccZero { - return !c.isCaseIgnorable() - } - return ccc != cccBreak -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/map.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/map.go deleted file mode 100644 index f2a8e96..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/map.go +++ /dev/null @@ -1,599 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package cases - -// This file contains the definitions of case mappings for all supported -// languages. The rules for the language-specific tailorings were taken and -// modified from the CLDR transform definitions in common/transforms. - -import ( - "strings" - "unicode" - "unicode/utf8" - - "golang.org/x/text/language" - "golang.org/x/text/transform" - "golang.org/x/text/unicode/norm" -) - -// A mapFunc takes a context set to the current rune and writes the mapped -// version to the same context. It may advance the context to the next rune. It -// returns whether a checkpoint is possible: whether the pDst bytes written to -// dst so far won't need changing as we see more source bytes. -type mapFunc func(*context) bool - -// maxIgnorable defines the maximum number of ignorables to consider for -// lookahead operations. -const maxIgnorable = 30 - -// supported lists the language tags for which we have tailorings. -const supported = "und af az el lt nl tr" - -func init() { - tags := []language.Tag{} - for _, s := range strings.Split(supported, " ") { - tags = append(tags, language.MustParse(s)) - } - matcher = language.NewMatcher(tags) - Supported = language.NewCoverage(tags) -} - -var ( - matcher language.Matcher - - Supported language.Coverage - - // We keep the following lists separate, instead of having a single per- - // language struct, to give the compiler a chance to remove unused code. - - // Some uppercase mappers are stateless, so we can precompute the - // Transformers and save a bit on runtime allocations. - upperFunc = []mapFunc{ - nil, // und - nil, // af - aztrUpper(upper), // az - elUpper, // el - ltUpper(upper), // lt - nil, // nl - aztrUpper(upper), // tr - } - - undUpper transform.Transformer = &undUpperCaser{} - - lowerFunc = []mapFunc{ - lower, // und - lower, // af - aztrLower, // az - lower, // el - ltLower, // lt - lower, // nl - aztrLower, // tr - } - - titleInfos = []struct { - title, lower mapFunc - rewrite func(*context) - }{ - {title, lower, nil}, // und - {title, lower, afnlRewrite}, // af - {aztrUpper(title), aztrLower, nil}, // az - {title, lower, nil}, // el - {ltUpper(title), ltLower, nil}, // lt - {nlTitle, lower, afnlRewrite}, // nl - {aztrUpper(title), aztrLower, nil}, // tr - } -) - -func makeUpper(t language.Tag, o options) transform.Transformer { - _, i, _ := matcher.Match(t) - f := upperFunc[i] - if f == nil { - return undUpper - } - return &simpleCaser{f: f} -} - -func makeLower(t language.Tag, o options) transform.Transformer { - _, i, _ := matcher.Match(t) - f := lowerFunc[i] - if o.noFinalSigma { - return &simpleCaser{f: f} - } - return &lowerCaser{ - first: f, - midWord: finalSigma(f), - } -} - -func makeTitle(t language.Tag, o options) transform.Transformer { - _, i, _ := matcher.Match(t) - x := &titleInfos[i] - lower := x.lower - if o.noLower { - lower = (*context).copy - } else if !o.noFinalSigma { - lower = finalSigma(lower) - } - return &titleCaser{ - title: x.title, - lower: lower, - rewrite: x.rewrite, - } -} - -// TODO: consider a similar special case for the fast majority lower case. This -// is a bit more involved so will require some more precise benchmarking to -// justify it. - -type undUpperCaser struct{ transform.NopResetter } - -// undUpperCaser implements the Transformer interface for doing an upper case -// mapping for the root locale (und). It eliminates the need for an allocation -// as it prevents escaping by not using function pointers. -func (t *undUpperCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - c := context{dst: dst, src: src, atEOF: atEOF} - for c.next() { - upper(&c) - c.checkpoint() - } - return c.ret() -} - -type simpleCaser struct { - context - f mapFunc -} - -// simpleCaser implements the Transformer interface for doing a case operation -// on a rune-by-rune basis. -func (t *simpleCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - t.context = context{dst: dst, src: src, atEOF: atEOF} - c := &t.context - for c.next() && t.f(c) { - c.checkpoint() - } - return c.ret() -} - -// lowerCaser implements the Transformer interface. The default Unicode lower -// casing requires different treatment for the first and subsequent characters -// of a word, most notably to handle the Greek final Sigma. -type lowerCaser struct { - context - - first, midWord mapFunc -} - -func (t *lowerCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - t.context = context{dst: dst, src: src, atEOF: atEOF} - c := &t.context - - for isInterWord := true; c.next(); { - if isInterWord { - if c.info.isCased() { - if !t.first(c) { - break - } - isInterWord = false - } else if !c.copy() { - break - } - } else { - if c.info.isNotCasedAndNotCaseIgnorable() { - if !c.copy() { - break - } - isInterWord = true - } else if !t.midWord(c) { - break - } - } - c.checkpoint() - } - return c.ret() -} - -// titleCaser implements the Transformer interface. Title casing algorithms -// distinguish between the first letter of a word and subsequent letters of the -// same word. It uses state to avoid requiring a potentially infinite lookahead. -type titleCaser struct { - context - - // rune mappings used by the actual casing algorithms. - title, lower mapFunc - - rewrite func(*context) -} - -// Transform implements the standard Unicode title case algorithm as defined in -// Chapter 3 of The Unicode Standard: -// toTitlecase(X): Find the word boundaries in X according to Unicode Standard -// Annex #29, "Unicode Text Segmentation." For each word boundary, find the -// first cased character F following the word boundary. If F exists, map F to -// Titlecase_Mapping(F); then map all characters C between F and the following -// word boundary to Lowercase_Mapping(C). -func (t *titleCaser) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - t.context = context{dst: dst, src: src, atEOF: atEOF, isMidWord: t.isMidWord} - c := &t.context - - if !c.next() { - return c.ret() - } - - for { - p := c.info - if t.rewrite != nil { - t.rewrite(c) - } - - wasMid := p.isCaseIgnorableAndNonBreakStarter() - // Break out of this loop on failure to ensure we do not modify the - // state incorrectly. - if p.isCased() && !p.isCaseIgnorableAndNotCased() { - if !c.isMidWord { - if !t.title(c) { - break - } - c.isMidWord = true - } else if !t.lower(c) { - break - } - } else if !c.copy() { - break - } - - // TODO: make this an "else if" if we can prove that no rune that does - // not match the first condition of the if statement can be a break. - if p.isBreak() { - c.isMidWord = false - } - - // As we save the state of the transformer, it is safe to call - // checkpoint after any successful write. - c.checkpoint() - - if !c.next() { - break - } - if wasMid && c.info.isCaseIgnorableAndNonBreakStarter() { - c.isMidWord = false - } - } - return c.ret() -} - -// finalSigma adds Greek final Sigma handing to another casing function. It -// determines whether a lowercased sigma should be σ or ς, by looking ahead for -// case-ignorables and a cased letters. -func finalSigma(f mapFunc) mapFunc { - return func(c *context) bool { - // ::NFD(); - // # 03A3; 03C2; 03A3; 03A3; Final_Sigma; # GREEK CAPITAL LETTER SIGMA - // Σ } [:case-ignorable:]* [:cased:] → σ; - // [:cased:] [:case-ignorable:]* { Σ → ς; - // ::Any-Lower; - // ::NFC(); - - if !c.hasPrefix("Σ") { - return f(c) - } - - p := c.pDst - c.writeString("ς") - // We need to do one more iteration after maxIgnorable, as a cased - // letter is not an ignorable and may modify the result. - for i := 0; i < maxIgnorable+1; i++ { - if !c.next() { - return false - } - if !c.info.isCaseIgnorable() { - if c.info.isCased() { - // p+1 is guaranteed to be in bounds: if writing ς was - // successful, p+1 will contain the second byte of ς. If not, - // this function will have returned after c.next returned false. - c.dst[p+1]++ // ς → σ - } - c.unreadRune() - return true - } - // A case ignorable may also introduce a word break, so we may need - // to continue searching even after detecting a break. - c.isMidWord = c.isMidWord && !c.info.isBreak() - c.copy() - } - return true - } -} - -// elUpper implements Greek upper casing, which entails removing a predefined -// set of non-blocked modifiers. Note that these accents should not be removed -// for title casing! -// Example: "Οδός" -> "ΟΔΟΣ". -func elUpper(c *context) bool { - // From CLDR: - // [:Greek:] [^[:ccc=Not_Reordered:][:ccc=Above:]]*? { [\u0313\u0314\u0301\u0300\u0306\u0342\u0308\u0304] → ; - // [:Greek:] [^[:ccc=Not_Reordered:][:ccc=Iota_Subscript:]]*? { \u0345 → ; - - r, _ := utf8.DecodeRune(c.src[c.pSrc:]) - oldPDst := c.pDst - if !upper(c) { - return false - } - if !unicode.Is(unicode.Greek, r) { - return true - } - i := 0 - // Take the properties of the uppercased rune that is already written to the - // destination. This saves us the trouble of having to uppercase the - // decomposed rune again. - if b := norm.NFD.Properties(c.dst[oldPDst:]).Decomposition(); b != nil { - // Restore the destination position and process the decomposed rune. - r, sz := utf8.DecodeRune(b) - if r <= 0xFF { // See A.6.1 - return true - } - c.pDst = oldPDst - // Insert the first rune and ignore the modifiers. See A.6.2. - c.writeBytes(b[:sz]) - i = len(b[sz:]) / 2 // Greek modifiers are always of length 2. - } - - for ; i < maxIgnorable && c.next(); i++ { - switch r, _ := utf8.DecodeRune(c.src[c.pSrc:]); r { - // Above and Iota Subscript - case 0x0300, // U+0300 COMBINING GRAVE ACCENT - 0x0301, // U+0301 COMBINING ACUTE ACCENT - 0x0304, // U+0304 COMBINING MACRON - 0x0306, // U+0306 COMBINING BREVE - 0x0308, // U+0308 COMBINING DIAERESIS - 0x0313, // U+0313 COMBINING COMMA ABOVE - 0x0314, // U+0314 COMBINING REVERSED COMMA ABOVE - 0x0342, // U+0342 COMBINING GREEK PERISPOMENI - 0x0345: // U+0345 COMBINING GREEK YPOGEGRAMMENI - // No-op. Gobble the modifier. - - default: - switch v, _ := trie.lookup(c.src[c.pSrc:]); info(v).cccType() { - case cccZero: - c.unreadRune() - return true - - // We don't need to test for IotaSubscript as the only rune that - // qualifies (U+0345) was already excluded in the switch statement - // above. See A.4. - - case cccAbove: - return c.copy() - default: - // Some other modifier. We're still allowed to gobble Greek - // modifiers after this. - c.copy() - } - } - } - return i == maxIgnorable -} - -func ltLower(c *context) bool { - // From CLDR: - // # Introduce an explicit dot above when lowercasing capital I's and J's - // # whenever there are more accents above. - // # (of the accents used in Lithuanian: grave, acute, tilde above, and ogonek) - // # 0049; 0069 0307; 0049; 0049; lt More_Above; # LATIN CAPITAL LETTER I - // # 004A; 006A 0307; 004A; 004A; lt More_Above; # LATIN CAPITAL LETTER J - // # 012E; 012F 0307; 012E; 012E; lt More_Above; # LATIN CAPITAL LETTER I WITH OGONEK - // # 00CC; 0069 0307 0300; 00CC; 00CC; lt; # LATIN CAPITAL LETTER I WITH GRAVE - // # 00CD; 0069 0307 0301; 00CD; 00CD; lt; # LATIN CAPITAL LETTER I WITH ACUTE - // # 0128; 0069 0307 0303; 0128; 0128; lt; # LATIN CAPITAL LETTER I WITH TILDE - // ::NFD(); - // I } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → i \u0307; - // J } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → j \u0307; - // Į } [^[:ccc=Not_Reordered:][:ccc=Above:]]* [:ccc=Above:] → į \u0307; - // Ì → i \u0307 \u0300; - // Í → i \u0307 \u0301; - // Ĩ → i \u0307 \u0303; - // ::Any-Lower(); - // ::NFC(); - - i := 0 - if r := c.src[c.pSrc]; r < utf8.RuneSelf { - lower(c) - if r != 'I' && r != 'J' { - return true - } - } else { - p := norm.NFD.Properties(c.src[c.pSrc:]) - if d := p.Decomposition(); len(d) >= 3 && (d[0] == 'I' || d[0] == 'J') { - // UTF-8 optimization: the decomposition will only have an above - // modifier if the last rune of the decomposition is in [U+300-U+311]. - // In all other cases, a decomposition starting with I is always - // an I followed by modifiers that are not cased themselves. See A.2. - if d[1] == 0xCC && d[2] <= 0x91 { // A.2.4. - if !c.writeBytes(d[:1]) { - return false - } - c.dst[c.pDst-1] += 'a' - 'A' // lower - - // Assumption: modifier never changes on lowercase. See A.1. - // Assumption: all modifiers added have CCC = Above. See A.2.3. - return c.writeString("\u0307") && c.writeBytes(d[1:]) - } - // In all other cases the additional modifiers will have a CCC - // that is less than 230 (Above). We will insert the U+0307, if - // needed, after these modifiers so that a string in FCD form - // will remain so. See A.2.2. - lower(c) - i = 1 - } else { - return lower(c) - } - } - - for ; i < maxIgnorable && c.next(); i++ { - switch c.info.cccType() { - case cccZero: - c.unreadRune() - return true - case cccAbove: - return c.writeString("\u0307") && c.copy() // See A.1. - default: - c.copy() // See A.1. - } - } - return i == maxIgnorable -} - -func ltUpper(f mapFunc) mapFunc { - return func(c *context) bool { - // From CLDR: - // ::NFD(); - // [:Soft_Dotted:] [^[:ccc=Not_Reordered:][:ccc=Above:]]* { \u0307 → ; - // ::Any-Upper(); - // ::NFC(); - - // TODO: See A.5. A soft-dotted rune never has an exception. This would - // allow us to overload the exception bit and encode this property in - // info. Need to measure performance impact of this. - r, _ := utf8.DecodeRune(c.src[c.pSrc:]) - oldPDst := c.pDst - if !f(c) { - return false - } - if !unicode.Is(unicode.Soft_Dotted, r) { - return true - } - - // We don't need to do an NFD normalization, as a soft-dotted rune never - // contains U+0307. See A.3. - - i := 0 - for ; i < maxIgnorable && c.next(); i++ { - switch c.info.cccType() { - case cccZero: - c.unreadRune() - return true - case cccAbove: - if c.hasPrefix("\u0307") { - // We don't do a full NFC, but rather combine runes for - // some of the common cases. (Returning NFC or - // preserving normal form is neither a requirement nor - // a possibility anyway). - if !c.next() { - return false - } - if c.dst[oldPDst] == 'I' && c.pDst == oldPDst+1 && c.src[c.pSrc] == 0xcc { - s := "" - switch c.src[c.pSrc+1] { - case 0x80: // U+0300 COMBINING GRAVE ACCENT - s = "\u00cc" // U+00CC LATIN CAPITAL LETTER I WITH GRAVE - case 0x81: // U+0301 COMBINING ACUTE ACCENT - s = "\u00cd" // U+00CD LATIN CAPITAL LETTER I WITH ACUTE - case 0x83: // U+0303 COMBINING TILDE - s = "\u0128" // U+0128 LATIN CAPITAL LETTER I WITH TILDE - case 0x88: // U+0308 COMBINING DIAERESIS - s = "\u00cf" // U+00CF LATIN CAPITAL LETTER I WITH DIAERESIS - default: - } - if s != "" { - c.pDst = oldPDst - return c.writeString(s) - } - } - } - return c.copy() - default: - c.copy() - } - } - return i == maxIgnorable - } -} - -func aztrUpper(f mapFunc) mapFunc { - return func(c *context) bool { - // i→İ; - if c.src[c.pSrc] == 'i' { - return c.writeString("İ") - } - return f(c) - } -} - -func aztrLower(c *context) (done bool) { - // From CLDR: - // # I and i-dotless; I-dot and i are case pairs in Turkish and Azeri - // # 0130; 0069; 0130; 0130; tr; # LATIN CAPITAL LETTER I WITH DOT ABOVE - // İ→i; - // # When lowercasing, remove dot_above in the sequence I + dot_above, which will turn into i. - // # This matches the behavior of the canonically equivalent I-dot_above - // # 0307; ; 0307; 0307; tr After_I; # COMBINING DOT ABOVE - // # When lowercasing, unless an I is before a dot_above, it turns into a dotless i. - // # 0049; 0131; 0049; 0049; tr Not_Before_Dot; # LATIN CAPITAL LETTER I - // I([^[:ccc=Not_Reordered:][:ccc=Above:]]*)\u0307 → i$1 ; - // I→ı ; - // ::Any-Lower(); - if c.hasPrefix("\u0130") { // İ - return c.writeString("i") - } - if c.src[c.pSrc] != 'I' { - return lower(c) - } - - // We ignore the lower-case I for now, but insert it later when we know - // which form we need. - start := c.pSrc + c.sz - - i := 0 -Loop: - // We check for up to n ignorables before \u0307. As \u0307 is an - // ignorable as well, n is maxIgnorable-1. - for ; i < maxIgnorable && c.next(); i++ { - switch c.info.cccType() { - case cccAbove: - if c.hasPrefix("\u0307") { - return c.writeString("i") && c.writeBytes(c.src[start:c.pSrc]) // ignore U+0307 - } - done = true - break Loop - case cccZero: - c.unreadRune() - done = true - break Loop - default: - // We'll write this rune after we know which starter to use. - } - } - if i == maxIgnorable { - done = true - } - return c.writeString("ı") && c.writeBytes(c.src[start:c.pSrc+c.sz]) && done -} - -func nlTitle(c *context) bool { - // From CLDR: - // # Special titlecasing for Dutch initial "ij". - // ::Any-Title(); - // # Fix up Ij at the beginning of a "word" (per Any-Title, notUAX #29) - // [:^WB=ALetter:] [:WB=Extend:]* [[:WB=MidLetter:][:WB=MidNumLet:]]? { Ij } → IJ ; - if c.src[c.pSrc] != 'I' && c.src[c.pSrc] != 'i' { - return title(c) - } - - if !c.writeString("I") || !c.next() { - return false - } - if c.src[c.pSrc] == 'j' || c.src[c.pSrc] == 'J' { - return c.writeString("J") - } - c.unreadRune() - return true -} - -// Not part of CLDR, but see http://unicode.org/cldr/trac/ticket/7078. -func afnlRewrite(c *context) { - if c.hasPrefix("'") || c.hasPrefix("’") { - c.isMidWord = true - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/tables.go deleted file mode 100644 index 4257e57..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/tables.go +++ /dev/null @@ -1,2213 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package cases - -// UnicodeVersion is the Unicode version from which the tables in this package are derived. -const UnicodeVersion = "9.0.0" - -var xorData string = "" + // Size: 185 bytes - "\x00\x06\x07\x00\x01?\x00\x0f\x03\x00\x0f\x12\x00\x0f\x1f\x00\x0f\x1d" + - "\x00\x01\x13\x00\x0f\x16\x00\x0f\x0b\x00\x0f3\x00\x0f7\x00\x01#\x00\x0f?" + - "\x00\x0e'\x00\x0f/\x00\x0e>\x00\x0f*\x00\x0c&\x00\x0c*\x00\x0c;\x00\x0c9" + - "\x00\x0c%\x00\x01\x08\x00\x03\x0d\x00\x03\x09\x00\x02\x06\x00\x02\x02" + - "\x00\x02\x0c\x00\x01\x00\x00\x01\x03\x00\x01\x01\x00\x01 \x00\x01\x0c" + - "\x00\x01\x10\x00\x03\x10\x00\x036 \x00\x037 \x00\x0b#\x10\x00\x0b 0\x00" + - "\x0b!\x10\x00\x0b!0\x00\x0b(\x04\x00\x03\x04\x1e\x00\x03\x0a\x00\x02:" + - "\x00\x02>\x00\x02,\x00\x02\x00\x00\x02\x10\x00\x01<\x00\x01&\x00\x01*" + - "\x00\x01.\x00\x010\x003 \x00\x01\x18\x00\x01(\x00\x01\x1e\x00\x01\x22" - -var exceptions string = "" + // Size: 1852 bytes - "\x00\x12\x10μΜ\x12\x12ssSSSs\x13\x18i̇i̇\x10\x08I\x13\x18ʼnʼN\x11\x08sS" + - "\x12\x12dždžDž\x12\x12dždžDŽ\x10\x12DŽDž\x12\x12ljljLj\x12\x12ljljLJ\x10\x12LJLj\x12\x12" + - "njnjNj\x12\x12njnjNJ\x10\x12NJNj\x13\x18ǰJ̌\x12\x12dzdzDz\x12\x12dzdzDZ\x10\x12DZDz" + - "\x13\x18ⱥⱥ\x13\x18ⱦⱦ\x10\x18Ȿ\x10\x18Ɀ\x10\x18Ɐ\x10\x18Ɑ\x10\x18Ɒ\x10" + - "\x18Ɜ\x10\x18Ɡ\x10\x18Ɥ\x10\x18Ɦ\x10\x18Ɪ\x10\x18Ɫ\x10\x18Ɬ\x10\x18Ɱ\x10" + - "\x18Ɽ\x10\x18Ʇ\x10\x18Ʝ\x10\x18Ʞ2\x10ιΙ\x160ΐΪ́\x160ΰΫ́\x12\x10σΣ" + - "\x12\x10βΒ\x12\x10θΘ\x12\x10φΦ\x12\x10πΠ\x12\x10κΚ\x12\x10ρΡ\x12\x10εΕ" + - "\x14$եւԵՒԵւ\x12\x10вВ\x12\x10дД\x12\x10оО\x12\x10сС\x12\x10тТ\x12\x10тТ" + - "\x12\x10ъЪ\x12\x10ѣѢ\x13\x18ꙋꙊ\x13\x18ẖH̱\x13\x18ẗT̈\x13\x18ẘW̊\x13" + - "\x18ẙY̊\x13\x18aʾAʾ\x13\x18ṡṠ\x12\x10ssß\x14 ὐΥ̓\x160ὒΥ̓̀\x160ὔΥ̓́" + - "\x160ὖΥ̓͂\x15+ἀιἈΙᾈ\x15+ἁιἉΙᾉ\x15+ἂιἊΙᾊ\x15+ἃιἋΙᾋ\x15+ἄιἌΙᾌ\x15+ἅιἍΙᾍ" + - "\x15+ἆιἎΙᾎ\x15+ἇιἏΙᾏ\x15\x1dἀιᾀἈΙ\x15\x1dἁιᾁἉΙ\x15\x1dἂιᾂἊΙ\x15\x1dἃιᾃἋΙ" + - "\x15\x1dἄιᾄἌΙ\x15\x1dἅιᾅἍΙ\x15\x1dἆιᾆἎΙ\x15\x1dἇιᾇἏΙ\x15+ἠιἨΙᾘ\x15+ἡιἩΙᾙ" + - "\x15+ἢιἪΙᾚ\x15+ἣιἫΙᾛ\x15+ἤιἬΙᾜ\x15+ἥιἭΙᾝ\x15+ἦιἮΙᾞ\x15+ἧιἯΙᾟ\x15\x1dἠιᾐἨ" + - "Ι\x15\x1dἡιᾑἩΙ\x15\x1dἢιᾒἪΙ\x15\x1dἣιᾓἫΙ\x15\x1dἤιᾔἬΙ\x15\x1dἥιᾕἭΙ\x15" + - "\x1dἦιᾖἮΙ\x15\x1dἧιᾗἯΙ\x15+ὠιὨΙᾨ\x15+ὡιὩΙᾩ\x15+ὢιὪΙᾪ\x15+ὣιὫΙᾫ\x15+ὤιὬΙᾬ" + - "\x15+ὥιὭΙᾭ\x15+ὦιὮΙᾮ\x15+ὧιὯΙᾯ\x15\x1dὠιᾠὨΙ\x15\x1dὡιᾡὩΙ\x15\x1dὢιᾢὪΙ" + - "\x15\x1dὣιᾣὫΙ\x15\x1dὤιᾤὬΙ\x15\x1dὥιᾥὭΙ\x15\x1dὦιᾦὮΙ\x15\x1dὧιᾧὯΙ\x15-ὰι" + - "ᾺΙᾺͅ\x14#αιΑΙᾼ\x14$άιΆΙΆͅ\x14 ᾶΑ͂\x166ᾶιΑ͂Ιᾼ͂\x14\x1cαιᾳΑΙ\x12\x10ι" + - "Ι\x15-ὴιῊΙῊͅ\x14#ηιΗΙῌ\x14$ήιΉΙΉͅ\x14 ῆΗ͂\x166ῆιΗ͂Ιῌ͂\x14\x1cηιῃΗΙ" + - "\x160ῒΪ̀\x160ΐΪ́\x14 ῖΙ͂\x160ῗΪ͂\x160ῢΫ̀\x160ΰΫ́\x14 ῤΡ" + - "̓\x14 ῦΥ͂\x160ῧΫ͂\x15-ὼιῺΙῺͅ\x14#ωιΩΙῼ\x14$ώιΏΙΏͅ\x14 ῶΩ͂\x166ῶιΩ" + - "͂Ιῼ͂\x14\x1cωιῳΩΙ\x12\x10ωω\x11\x08kk\x12\x10åå\x12\x10ɫɫ\x12\x10ɽɽ" + - "\x10\x10Ⱥ\x10\x10Ⱦ\x12\x10ɑɑ\x12\x10ɱɱ\x12\x10ɐɐ\x12\x10ɒɒ\x12\x10ȿȿ\x12" + - "\x10ɀɀ\x12\x10ɥɥ\x12\x10ɦɦ\x12\x10ɜɜ\x12\x10ɡɡ\x12\x10ɬɬ\x12\x10ɪɪ\x12" + - "\x10ʞʞ\x12\x10ʇʇ\x12\x10ʝʝ\x12\x12ffFFFf\x12\x12fiFIFi\x12\x12flFLFl\x13" + - "\x1bffiFFIFfi\x13\x1bfflFFLFfl\x12\x12stSTSt\x12\x12stSTSt\x14$մնՄՆՄն" + - "\x14$մեՄԵՄե\x14$միՄԻՄի\x14$վնՎՆՎն\x14$մխՄԽՄխ" - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *caseTrie) lookup(s []byte) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return caseValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = caseIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = caseIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = caseIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *caseTrie) lookupUnsafe(s []byte) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return caseValues[c0] - } - i := caseIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = caseIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = caseIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *caseTrie) lookupString(s string) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return caseValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = caseIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := caseIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = caseIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = caseIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *caseTrie) lookupStringUnsafe(s string) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return caseValues[c0] - } - i := caseIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = caseIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = caseIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// caseTrie. Total size: 11750 bytes (11.47 KiB). Checksum: 9ec26581a3006e0d. -type caseTrie struct{} - -func newCaseTrie(i int) *caseTrie { - return &caseTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *caseTrie) lookupValue(n uint32, b byte) uint16 { - switch { - case n < 18: - return uint16(caseValues[n<<6+uint32(b)]) - default: - n -= 18 - return uint16(sparse.lookup(n, b)) - } -} - -// caseValues: 20 blocks, 1280 entries, 2560 bytes -// The third block is the zero block. -var caseValues = [1280]uint16{ - // Block 0x0, offset 0x0 - 0x27: 0x0014, - 0x2e: 0x0014, - 0x30: 0x0010, 0x31: 0x0010, 0x32: 0x0010, 0x33: 0x0010, 0x34: 0x0010, 0x35: 0x0010, - 0x36: 0x0010, 0x37: 0x0010, 0x38: 0x0010, 0x39: 0x0010, 0x3a: 0x0014, - // Block 0x1, offset 0x40 - 0x41: 0x2013, 0x42: 0x2013, 0x43: 0x2013, 0x44: 0x2013, 0x45: 0x2013, - 0x46: 0x2013, 0x47: 0x2013, 0x48: 0x2013, 0x49: 0x2013, 0x4a: 0x2013, 0x4b: 0x2013, - 0x4c: 0x2013, 0x4d: 0x2013, 0x4e: 0x2013, 0x4f: 0x2013, 0x50: 0x2013, 0x51: 0x2013, - 0x52: 0x2013, 0x53: 0x2013, 0x54: 0x2013, 0x55: 0x2013, 0x56: 0x2013, 0x57: 0x2013, - 0x58: 0x2013, 0x59: 0x2013, 0x5a: 0x2013, - 0x5e: 0x0004, 0x5f: 0x0010, 0x60: 0x0004, 0x61: 0x2012, 0x62: 0x2012, 0x63: 0x2012, - 0x64: 0x2012, 0x65: 0x2012, 0x66: 0x2012, 0x67: 0x2012, 0x68: 0x2012, 0x69: 0x2012, - 0x6a: 0x2012, 0x6b: 0x2012, 0x6c: 0x2012, 0x6d: 0x2012, 0x6e: 0x2012, 0x6f: 0x2012, - 0x70: 0x2012, 0x71: 0x2012, 0x72: 0x2012, 0x73: 0x2012, 0x74: 0x2012, 0x75: 0x2012, - 0x76: 0x2012, 0x77: 0x2012, 0x78: 0x2012, 0x79: 0x2012, 0x7a: 0x2012, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc0: 0x0852, 0xc1: 0x0b53, 0xc2: 0x0113, 0xc3: 0x0112, 0xc4: 0x0113, 0xc5: 0x0112, - 0xc6: 0x0b53, 0xc7: 0x0f13, 0xc8: 0x0f12, 0xc9: 0x0e53, 0xca: 0x1153, 0xcb: 0x0713, - 0xcc: 0x0712, 0xcd: 0x0012, 0xce: 0x1453, 0xcf: 0x1753, 0xd0: 0x1a53, 0xd1: 0x0313, - 0xd2: 0x0312, 0xd3: 0x1d53, 0xd4: 0x2053, 0xd5: 0x2352, 0xd6: 0x2653, 0xd7: 0x2653, - 0xd8: 0x0113, 0xd9: 0x0112, 0xda: 0x2952, 0xdb: 0x0012, 0xdc: 0x1d53, 0xdd: 0x2c53, - 0xde: 0x2f52, 0xdf: 0x3253, 0xe0: 0x0113, 0xe1: 0x0112, 0xe2: 0x0113, 0xe3: 0x0112, - 0xe4: 0x0113, 0xe5: 0x0112, 0xe6: 0x3553, 0xe7: 0x0f13, 0xe8: 0x0f12, 0xe9: 0x3853, - 0xea: 0x0012, 0xeb: 0x0012, 0xec: 0x0113, 0xed: 0x0112, 0xee: 0x3553, 0xef: 0x1f13, - 0xf0: 0x1f12, 0xf1: 0x3b53, 0xf2: 0x3e53, 0xf3: 0x0713, 0xf4: 0x0712, 0xf5: 0x0313, - 0xf6: 0x0312, 0xf7: 0x4153, 0xf8: 0x0113, 0xf9: 0x0112, 0xfa: 0x0012, 0xfb: 0x0010, - 0xfc: 0x0113, 0xfd: 0x0112, 0xfe: 0x0012, 0xff: 0x4452, - // Block 0x4, offset 0x100 - 0x100: 0x0010, 0x101: 0x0010, 0x102: 0x0010, 0x103: 0x0010, 0x104: 0x04cb, 0x105: 0x05c9, - 0x106: 0x06ca, 0x107: 0x078b, 0x108: 0x0889, 0x109: 0x098a, 0x10a: 0x0a4b, 0x10b: 0x0b49, - 0x10c: 0x0c4a, 0x10d: 0x0313, 0x10e: 0x0312, 0x10f: 0x1f13, 0x110: 0x1f12, 0x111: 0x0313, - 0x112: 0x0312, 0x113: 0x0713, 0x114: 0x0712, 0x115: 0x0313, 0x116: 0x0312, 0x117: 0x0f13, - 0x118: 0x0f12, 0x119: 0x0313, 0x11a: 0x0312, 0x11b: 0x0713, 0x11c: 0x0712, 0x11d: 0x1452, - 0x11e: 0x0113, 0x11f: 0x0112, 0x120: 0x0113, 0x121: 0x0112, 0x122: 0x0113, 0x123: 0x0112, - 0x124: 0x0113, 0x125: 0x0112, 0x126: 0x0113, 0x127: 0x0112, 0x128: 0x0113, 0x129: 0x0112, - 0x12a: 0x0113, 0x12b: 0x0112, 0x12c: 0x0113, 0x12d: 0x0112, 0x12e: 0x0113, 0x12f: 0x0112, - 0x130: 0x0d0a, 0x131: 0x0e0b, 0x132: 0x0f09, 0x133: 0x100a, 0x134: 0x0113, 0x135: 0x0112, - 0x136: 0x2353, 0x137: 0x4453, 0x138: 0x0113, 0x139: 0x0112, 0x13a: 0x0113, 0x13b: 0x0112, - 0x13c: 0x0113, 0x13d: 0x0112, 0x13e: 0x0113, 0x13f: 0x0112, - // Block 0x5, offset 0x140 - 0x140: 0x136a, 0x141: 0x0313, 0x142: 0x0312, 0x143: 0x0853, 0x144: 0x4753, 0x145: 0x4a53, - 0x146: 0x0113, 0x147: 0x0112, 0x148: 0x0113, 0x149: 0x0112, 0x14a: 0x0113, 0x14b: 0x0112, - 0x14c: 0x0113, 0x14d: 0x0112, 0x14e: 0x0113, 0x14f: 0x0112, 0x150: 0x140a, 0x151: 0x14aa, - 0x152: 0x154a, 0x153: 0x0b52, 0x154: 0x0b52, 0x155: 0x0012, 0x156: 0x0e52, 0x157: 0x1152, - 0x158: 0x0012, 0x159: 0x1752, 0x15a: 0x0012, 0x15b: 0x1a52, 0x15c: 0x15ea, 0x15d: 0x0012, - 0x15e: 0x0012, 0x15f: 0x0012, 0x160: 0x1d52, 0x161: 0x168a, 0x162: 0x0012, 0x163: 0x2052, - 0x164: 0x0012, 0x165: 0x172a, 0x166: 0x17ca, 0x167: 0x0012, 0x168: 0x2652, 0x169: 0x2652, - 0x16a: 0x186a, 0x16b: 0x190a, 0x16c: 0x19aa, 0x16d: 0x0012, 0x16e: 0x0012, 0x16f: 0x1d52, - 0x170: 0x0012, 0x171: 0x1a4a, 0x172: 0x2c52, 0x173: 0x0012, 0x174: 0x0012, 0x175: 0x3252, - 0x176: 0x0012, 0x177: 0x0012, 0x178: 0x0012, 0x179: 0x0012, 0x17a: 0x0012, 0x17b: 0x0012, - 0x17c: 0x0012, 0x17d: 0x1aea, 0x17e: 0x0012, 0x17f: 0x0012, - // Block 0x6, offset 0x180 - 0x180: 0x3552, 0x181: 0x0012, 0x182: 0x0012, 0x183: 0x3852, 0x184: 0x0012, 0x185: 0x0012, - 0x186: 0x0012, 0x187: 0x1b8a, 0x188: 0x3552, 0x189: 0x4752, 0x18a: 0x3b52, 0x18b: 0x3e52, - 0x18c: 0x4a52, 0x18d: 0x0012, 0x18e: 0x0012, 0x18f: 0x0012, 0x190: 0x0012, 0x191: 0x0012, - 0x192: 0x4152, 0x193: 0x0012, 0x194: 0x0010, 0x195: 0x0012, 0x196: 0x0012, 0x197: 0x0012, - 0x198: 0x0012, 0x199: 0x0012, 0x19a: 0x0012, 0x19b: 0x0012, 0x19c: 0x0012, 0x19d: 0x1c2a, - 0x19e: 0x1cca, 0x19f: 0x0012, 0x1a0: 0x0012, 0x1a1: 0x0012, 0x1a2: 0x0012, 0x1a3: 0x0012, - 0x1a4: 0x0012, 0x1a5: 0x0012, 0x1a6: 0x0012, 0x1a7: 0x0012, 0x1a8: 0x0012, 0x1a9: 0x0012, - 0x1aa: 0x0012, 0x1ab: 0x0012, 0x1ac: 0x0012, 0x1ad: 0x0012, 0x1ae: 0x0012, 0x1af: 0x0012, - 0x1b0: 0x0015, 0x1b1: 0x0015, 0x1b2: 0x0015, 0x1b3: 0x0015, 0x1b4: 0x0015, 0x1b5: 0x0015, - 0x1b6: 0x0015, 0x1b7: 0x0015, 0x1b8: 0x0015, 0x1b9: 0x0014, 0x1ba: 0x0014, 0x1bb: 0x0014, - 0x1bc: 0x0014, 0x1bd: 0x0014, 0x1be: 0x0014, 0x1bf: 0x0014, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x0024, 0x1c1: 0x0024, 0x1c2: 0x0024, 0x1c3: 0x0024, 0x1c4: 0x0024, 0x1c5: 0x1d6d, - 0x1c6: 0x0024, 0x1c7: 0x0034, 0x1c8: 0x0034, 0x1c9: 0x0034, 0x1ca: 0x0024, 0x1cb: 0x0024, - 0x1cc: 0x0024, 0x1cd: 0x0034, 0x1ce: 0x0034, 0x1cf: 0x0014, 0x1d0: 0x0024, 0x1d1: 0x0024, - 0x1d2: 0x0024, 0x1d3: 0x0034, 0x1d4: 0x0034, 0x1d5: 0x0034, 0x1d6: 0x0034, 0x1d7: 0x0024, - 0x1d8: 0x0034, 0x1d9: 0x0034, 0x1da: 0x0034, 0x1db: 0x0024, 0x1dc: 0x0034, 0x1dd: 0x0034, - 0x1de: 0x0034, 0x1df: 0x0034, 0x1e0: 0x0034, 0x1e1: 0x0034, 0x1e2: 0x0034, 0x1e3: 0x0024, - 0x1e4: 0x0024, 0x1e5: 0x0024, 0x1e6: 0x0024, 0x1e7: 0x0024, 0x1e8: 0x0024, 0x1e9: 0x0024, - 0x1ea: 0x0024, 0x1eb: 0x0024, 0x1ec: 0x0024, 0x1ed: 0x0024, 0x1ee: 0x0024, 0x1ef: 0x0024, - 0x1f0: 0x0113, 0x1f1: 0x0112, 0x1f2: 0x0113, 0x1f3: 0x0112, 0x1f4: 0x0014, 0x1f5: 0x0004, - 0x1f6: 0x0113, 0x1f7: 0x0112, 0x1fa: 0x0015, 0x1fb: 0x4d52, - 0x1fc: 0x5052, 0x1fd: 0x5052, 0x1ff: 0x5353, - // Block 0x8, offset 0x200 - 0x204: 0x0004, 0x205: 0x0004, - 0x206: 0x2a13, 0x207: 0x0014, 0x208: 0x2513, 0x209: 0x2713, 0x20a: 0x2513, - 0x20c: 0x5653, 0x20e: 0x5953, 0x20f: 0x5c53, 0x210: 0x1e2a, 0x211: 0x2013, - 0x212: 0x2013, 0x213: 0x2013, 0x214: 0x2013, 0x215: 0x2013, 0x216: 0x2013, 0x217: 0x2013, - 0x218: 0x2013, 0x219: 0x2013, 0x21a: 0x2013, 0x21b: 0x2013, 0x21c: 0x2013, 0x21d: 0x2013, - 0x21e: 0x2013, 0x21f: 0x2013, 0x220: 0x5f53, 0x221: 0x5f53, 0x223: 0x5f53, - 0x224: 0x5f53, 0x225: 0x5f53, 0x226: 0x5f53, 0x227: 0x5f53, 0x228: 0x5f53, 0x229: 0x5f53, - 0x22a: 0x5f53, 0x22b: 0x5f53, 0x22c: 0x2a12, 0x22d: 0x2512, 0x22e: 0x2712, 0x22f: 0x2512, - 0x230: 0x1fea, 0x231: 0x2012, 0x232: 0x2012, 0x233: 0x2012, 0x234: 0x2012, 0x235: 0x2012, - 0x236: 0x2012, 0x237: 0x2012, 0x238: 0x2012, 0x239: 0x2012, 0x23a: 0x2012, 0x23b: 0x2012, - 0x23c: 0x2012, 0x23d: 0x2012, 0x23e: 0x2012, 0x23f: 0x2012, - // Block 0x9, offset 0x240 - 0x240: 0x5f52, 0x241: 0x5f52, 0x242: 0x21aa, 0x243: 0x5f52, 0x244: 0x5f52, 0x245: 0x5f52, - 0x246: 0x5f52, 0x247: 0x5f52, 0x248: 0x5f52, 0x249: 0x5f52, 0x24a: 0x5f52, 0x24b: 0x5f52, - 0x24c: 0x5652, 0x24d: 0x5952, 0x24e: 0x5c52, 0x24f: 0x1813, 0x250: 0x226a, 0x251: 0x232a, - 0x252: 0x0013, 0x253: 0x0013, 0x254: 0x0013, 0x255: 0x23ea, 0x256: 0x24aa, 0x257: 0x1812, - 0x258: 0x0113, 0x259: 0x0112, 0x25a: 0x0113, 0x25b: 0x0112, 0x25c: 0x0113, 0x25d: 0x0112, - 0x25e: 0x0113, 0x25f: 0x0112, 0x260: 0x0113, 0x261: 0x0112, 0x262: 0x0113, 0x263: 0x0112, - 0x264: 0x0113, 0x265: 0x0112, 0x266: 0x0113, 0x267: 0x0112, 0x268: 0x0113, 0x269: 0x0112, - 0x26a: 0x0113, 0x26b: 0x0112, 0x26c: 0x0113, 0x26d: 0x0112, 0x26e: 0x0113, 0x26f: 0x0112, - 0x270: 0x256a, 0x271: 0x262a, 0x272: 0x0b12, 0x273: 0x5352, 0x274: 0x6253, 0x275: 0x26ea, - 0x277: 0x0f13, 0x278: 0x0f12, 0x279: 0x0b13, 0x27a: 0x0113, 0x27b: 0x0112, - 0x27c: 0x0012, 0x27d: 0x4d53, 0x27e: 0x5053, 0x27f: 0x5053, - // Block 0xa, offset 0x280 - 0x280: 0x0812, 0x281: 0x0812, 0x282: 0x0812, 0x283: 0x0812, 0x284: 0x0812, 0x285: 0x0812, - 0x288: 0x0813, 0x289: 0x0813, 0x28a: 0x0813, 0x28b: 0x0813, - 0x28c: 0x0813, 0x28d: 0x0813, 0x290: 0x372a, 0x291: 0x0812, - 0x292: 0x386a, 0x293: 0x0812, 0x294: 0x3a2a, 0x295: 0x0812, 0x296: 0x3bea, 0x297: 0x0812, - 0x299: 0x0813, 0x29b: 0x0813, 0x29d: 0x0813, - 0x29f: 0x0813, 0x2a0: 0x0812, 0x2a1: 0x0812, 0x2a2: 0x0812, 0x2a3: 0x0812, - 0x2a4: 0x0812, 0x2a5: 0x0812, 0x2a6: 0x0812, 0x2a7: 0x0812, 0x2a8: 0x0813, 0x2a9: 0x0813, - 0x2aa: 0x0813, 0x2ab: 0x0813, 0x2ac: 0x0813, 0x2ad: 0x0813, 0x2ae: 0x0813, 0x2af: 0x0813, - 0x2b0: 0x8b52, 0x2b1: 0x8b52, 0x2b2: 0x8e52, 0x2b3: 0x8e52, 0x2b4: 0x9152, 0x2b5: 0x9152, - 0x2b6: 0x9452, 0x2b7: 0x9452, 0x2b8: 0x9752, 0x2b9: 0x9752, 0x2ba: 0x9a52, 0x2bb: 0x9a52, - 0x2bc: 0x4d52, 0x2bd: 0x4d52, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x3daa, 0x2c1: 0x3f8a, 0x2c2: 0x416a, 0x2c3: 0x434a, 0x2c4: 0x452a, 0x2c5: 0x470a, - 0x2c6: 0x48ea, 0x2c7: 0x4aca, 0x2c8: 0x4ca9, 0x2c9: 0x4e89, 0x2ca: 0x5069, 0x2cb: 0x5249, - 0x2cc: 0x5429, 0x2cd: 0x5609, 0x2ce: 0x57e9, 0x2cf: 0x59c9, 0x2d0: 0x5baa, 0x2d1: 0x5d8a, - 0x2d2: 0x5f6a, 0x2d3: 0x614a, 0x2d4: 0x632a, 0x2d5: 0x650a, 0x2d6: 0x66ea, 0x2d7: 0x68ca, - 0x2d8: 0x6aa9, 0x2d9: 0x6c89, 0x2da: 0x6e69, 0x2db: 0x7049, 0x2dc: 0x7229, 0x2dd: 0x7409, - 0x2de: 0x75e9, 0x2df: 0x77c9, 0x2e0: 0x79aa, 0x2e1: 0x7b8a, 0x2e2: 0x7d6a, 0x2e3: 0x7f4a, - 0x2e4: 0x812a, 0x2e5: 0x830a, 0x2e6: 0x84ea, 0x2e7: 0x86ca, 0x2e8: 0x88a9, 0x2e9: 0x8a89, - 0x2ea: 0x8c69, 0x2eb: 0x8e49, 0x2ec: 0x9029, 0x2ed: 0x9209, 0x2ee: 0x93e9, 0x2ef: 0x95c9, - 0x2f0: 0x0812, 0x2f1: 0x0812, 0x2f2: 0x97aa, 0x2f3: 0x99ca, 0x2f4: 0x9b6a, - 0x2f6: 0x9d2a, 0x2f7: 0x9e6a, 0x2f8: 0x0813, 0x2f9: 0x0813, 0x2fa: 0x8b53, 0x2fb: 0x8b53, - 0x2fc: 0xa0e9, 0x2fd: 0x0004, 0x2fe: 0xa28a, 0x2ff: 0x0004, - // Block 0xc, offset 0x300 - 0x300: 0x0004, 0x301: 0x0004, 0x302: 0xa34a, 0x303: 0xa56a, 0x304: 0xa70a, - 0x306: 0xa8ca, 0x307: 0xaa0a, 0x308: 0x8e53, 0x309: 0x8e53, 0x30a: 0x9153, 0x30b: 0x9153, - 0x30c: 0xac89, 0x30d: 0x0004, 0x30e: 0x0004, 0x30f: 0x0004, 0x310: 0x0812, 0x311: 0x0812, - 0x312: 0xae2a, 0x313: 0xafea, 0x316: 0xb1aa, 0x317: 0xb2ea, - 0x318: 0x0813, 0x319: 0x0813, 0x31a: 0x9453, 0x31b: 0x9453, 0x31d: 0x0004, - 0x31e: 0x0004, 0x31f: 0x0004, 0x320: 0x0812, 0x321: 0x0812, 0x322: 0xb4aa, 0x323: 0xb66a, - 0x324: 0xb82a, 0x325: 0x0912, 0x326: 0xb96a, 0x327: 0xbaaa, 0x328: 0x0813, 0x329: 0x0813, - 0x32a: 0x9a53, 0x32b: 0x9a53, 0x32c: 0x0913, 0x32d: 0x0004, 0x32e: 0x0004, 0x32f: 0x0004, - 0x332: 0xbc6a, 0x333: 0xbe8a, 0x334: 0xc02a, - 0x336: 0xc1ea, 0x337: 0xc32a, 0x338: 0x9753, 0x339: 0x9753, 0x33a: 0x4d53, 0x33b: 0x4d53, - 0x33c: 0xc5a9, 0x33d: 0x0004, 0x33e: 0x0004, - // Block 0xd, offset 0x340 - 0x342: 0x0013, - 0x347: 0x0013, 0x34a: 0x0012, 0x34b: 0x0013, - 0x34c: 0x0013, 0x34d: 0x0013, 0x34e: 0x0012, 0x34f: 0x0012, 0x350: 0x0013, 0x351: 0x0013, - 0x352: 0x0013, 0x353: 0x0012, 0x355: 0x0013, - 0x359: 0x0013, 0x35a: 0x0013, 0x35b: 0x0013, 0x35c: 0x0013, 0x35d: 0x0013, - 0x364: 0x0013, 0x366: 0xc74b, 0x368: 0x0013, - 0x36a: 0xc80b, 0x36b: 0xc88b, 0x36c: 0x0013, 0x36d: 0x0013, 0x36f: 0x0012, - 0x370: 0x0013, 0x371: 0x0013, 0x372: 0x9d53, 0x373: 0x0013, 0x374: 0x0012, 0x375: 0x0010, - 0x376: 0x0010, 0x377: 0x0010, 0x378: 0x0010, 0x379: 0x0012, - 0x37c: 0x0012, 0x37d: 0x0012, 0x37e: 0x0013, 0x37f: 0x0013, - // Block 0xe, offset 0x380 - 0x380: 0x1a13, 0x381: 0x1a13, 0x382: 0x1e13, 0x383: 0x1e13, 0x384: 0x1a13, 0x385: 0x1a13, - 0x386: 0x2613, 0x387: 0x2613, 0x388: 0x2a13, 0x389: 0x2a13, 0x38a: 0x2e13, 0x38b: 0x2e13, - 0x38c: 0x2a13, 0x38d: 0x2a13, 0x38e: 0x2613, 0x38f: 0x2613, 0x390: 0xa052, 0x391: 0xa052, - 0x392: 0xa352, 0x393: 0xa352, 0x394: 0xa652, 0x395: 0xa652, 0x396: 0xa352, 0x397: 0xa352, - 0x398: 0xa052, 0x399: 0xa052, 0x39a: 0x1a12, 0x39b: 0x1a12, 0x39c: 0x1e12, 0x39d: 0x1e12, - 0x39e: 0x1a12, 0x39f: 0x1a12, 0x3a0: 0x2612, 0x3a1: 0x2612, 0x3a2: 0x2a12, 0x3a3: 0x2a12, - 0x3a4: 0x2e12, 0x3a5: 0x2e12, 0x3a6: 0x2a12, 0x3a7: 0x2a12, 0x3a8: 0x2612, 0x3a9: 0x2612, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x6552, 0x3c1: 0x6552, 0x3c2: 0x6552, 0x3c3: 0x6552, 0x3c4: 0x6552, 0x3c5: 0x6552, - 0x3c6: 0x6552, 0x3c7: 0x6552, 0x3c8: 0x6552, 0x3c9: 0x6552, 0x3ca: 0x6552, 0x3cb: 0x6552, - 0x3cc: 0x6552, 0x3cd: 0x6552, 0x3ce: 0x6552, 0x3cf: 0x6552, 0x3d0: 0xa952, 0x3d1: 0xa952, - 0x3d2: 0xa952, 0x3d3: 0xa952, 0x3d4: 0xa952, 0x3d5: 0xa952, 0x3d6: 0xa952, 0x3d7: 0xa952, - 0x3d8: 0xa952, 0x3d9: 0xa952, 0x3da: 0xa952, 0x3db: 0xa952, 0x3dc: 0xa952, 0x3dd: 0xa952, - 0x3de: 0xa952, 0x3e0: 0x0113, 0x3e1: 0x0112, 0x3e2: 0xc94b, 0x3e3: 0x8853, - 0x3e4: 0xca0b, 0x3e5: 0xcaca, 0x3e6: 0xcb4a, 0x3e7: 0x0f13, 0x3e8: 0x0f12, 0x3e9: 0x0313, - 0x3ea: 0x0312, 0x3eb: 0x0713, 0x3ec: 0x0712, 0x3ed: 0xcbcb, 0x3ee: 0xcc8b, 0x3ef: 0xcd4b, - 0x3f0: 0xce0b, 0x3f1: 0x0012, 0x3f2: 0x0113, 0x3f3: 0x0112, 0x3f4: 0x0012, 0x3f5: 0x0313, - 0x3f6: 0x0312, 0x3f7: 0x0012, 0x3f8: 0x0012, 0x3f9: 0x0012, 0x3fa: 0x0012, 0x3fb: 0x0012, - 0x3fc: 0x0015, 0x3fd: 0x0015, 0x3fe: 0xcecb, 0x3ff: 0xcf8b, - // Block 0x10, offset 0x400 - 0x400: 0x0113, 0x401: 0x0112, 0x402: 0x0113, 0x403: 0x0112, 0x404: 0x0113, 0x405: 0x0112, - 0x406: 0x0113, 0x407: 0x0112, 0x408: 0x0014, 0x409: 0x0004, 0x40a: 0x0004, 0x40b: 0x0713, - 0x40c: 0x0712, 0x40d: 0xd04b, 0x40e: 0x0012, 0x40f: 0x0010, 0x410: 0x0113, 0x411: 0x0112, - 0x412: 0x0113, 0x413: 0x0112, 0x414: 0x0012, 0x415: 0x0012, 0x416: 0x0113, 0x417: 0x0112, - 0x418: 0x0113, 0x419: 0x0112, 0x41a: 0x0113, 0x41b: 0x0112, 0x41c: 0x0113, 0x41d: 0x0112, - 0x41e: 0x0113, 0x41f: 0x0112, 0x420: 0x0113, 0x421: 0x0112, 0x422: 0x0113, 0x423: 0x0112, - 0x424: 0x0113, 0x425: 0x0112, 0x426: 0x0113, 0x427: 0x0112, 0x428: 0x0113, 0x429: 0x0112, - 0x42a: 0xd10b, 0x42b: 0xd1cb, 0x42c: 0xd28b, 0x42d: 0xd34b, 0x42e: 0xd40b, - 0x430: 0xd4cb, 0x431: 0xd58b, 0x432: 0xd64b, 0x433: 0xac53, 0x434: 0x0113, 0x435: 0x0112, - 0x436: 0x0113, 0x437: 0x0112, - // Block 0x11, offset 0x440 - 0x440: 0xd70a, 0x441: 0xd80a, 0x442: 0xd90a, 0x443: 0xda0a, 0x444: 0xdb6a, 0x445: 0xdcca, - 0x446: 0xddca, - 0x453: 0xdeca, 0x454: 0xe08a, 0x455: 0xe24a, 0x456: 0xe40a, 0x457: 0xe5ca, - 0x45d: 0x0010, - 0x45e: 0x0034, 0x45f: 0x0010, 0x460: 0x0010, 0x461: 0x0010, 0x462: 0x0010, 0x463: 0x0010, - 0x464: 0x0010, 0x465: 0x0010, 0x466: 0x0010, 0x467: 0x0010, 0x468: 0x0010, - 0x46a: 0x0010, 0x46b: 0x0010, 0x46c: 0x0010, 0x46d: 0x0010, 0x46e: 0x0010, 0x46f: 0x0010, - 0x470: 0x0010, 0x471: 0x0010, 0x472: 0x0010, 0x473: 0x0010, 0x474: 0x0010, 0x475: 0x0010, - 0x476: 0x0010, 0x478: 0x0010, 0x479: 0x0010, 0x47a: 0x0010, 0x47b: 0x0010, - 0x47c: 0x0010, 0x47e: 0x0010, - // Block 0x12, offset 0x480 - 0x480: 0x2213, 0x481: 0x2213, 0x482: 0x2613, 0x483: 0x2613, 0x484: 0x2213, 0x485: 0x2213, - 0x486: 0x2e13, 0x487: 0x2e13, 0x488: 0x2213, 0x489: 0x2213, 0x48a: 0x2613, 0x48b: 0x2613, - 0x48c: 0x2213, 0x48d: 0x2213, 0x48e: 0x3e13, 0x48f: 0x3e13, 0x490: 0x2213, 0x491: 0x2213, - 0x492: 0x2613, 0x493: 0x2613, 0x494: 0x2213, 0x495: 0x2213, 0x496: 0x2e13, 0x497: 0x2e13, - 0x498: 0x2213, 0x499: 0x2213, 0x49a: 0x2613, 0x49b: 0x2613, 0x49c: 0x2213, 0x49d: 0x2213, - 0x49e: 0xb553, 0x49f: 0xb553, 0x4a0: 0xb853, 0x4a1: 0xb853, 0x4a2: 0x2212, 0x4a3: 0x2212, - 0x4a4: 0x2612, 0x4a5: 0x2612, 0x4a6: 0x2212, 0x4a7: 0x2212, 0x4a8: 0x2e12, 0x4a9: 0x2e12, - 0x4aa: 0x2212, 0x4ab: 0x2212, 0x4ac: 0x2612, 0x4ad: 0x2612, 0x4ae: 0x2212, 0x4af: 0x2212, - 0x4b0: 0x3e12, 0x4b1: 0x3e12, 0x4b2: 0x2212, 0x4b3: 0x2212, 0x4b4: 0x2612, 0x4b5: 0x2612, - 0x4b6: 0x2212, 0x4b7: 0x2212, 0x4b8: 0x2e12, 0x4b9: 0x2e12, 0x4ba: 0x2212, 0x4bb: 0x2212, - 0x4bc: 0x2612, 0x4bd: 0x2612, 0x4be: 0x2212, 0x4bf: 0x2212, - // Block 0x13, offset 0x4c0 - 0x4c2: 0x0010, - 0x4c7: 0x0010, 0x4c9: 0x0010, 0x4cb: 0x0010, - 0x4cd: 0x0010, 0x4ce: 0x0010, 0x4cf: 0x0010, 0x4d1: 0x0010, - 0x4d2: 0x0010, 0x4d4: 0x0010, 0x4d7: 0x0010, - 0x4d9: 0x0010, 0x4db: 0x0010, 0x4dd: 0x0010, - 0x4df: 0x0010, 0x4e1: 0x0010, 0x4e2: 0x0010, - 0x4e4: 0x0010, 0x4e7: 0x0010, 0x4e8: 0x0010, 0x4e9: 0x0010, - 0x4ea: 0x0010, 0x4ec: 0x0010, 0x4ed: 0x0010, 0x4ee: 0x0010, 0x4ef: 0x0010, - 0x4f0: 0x0010, 0x4f1: 0x0010, 0x4f2: 0x0010, 0x4f4: 0x0010, 0x4f5: 0x0010, - 0x4f6: 0x0010, 0x4f7: 0x0010, 0x4f9: 0x0010, 0x4fa: 0x0010, 0x4fb: 0x0010, - 0x4fc: 0x0010, 0x4fe: 0x0010, -} - -// caseIndex: 25 blocks, 1600 entries, 3200 bytes -// Block 0 is the zero block. -var caseIndex = [1600]uint16{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x12, 0xc3: 0x13, 0xc4: 0x14, 0xc5: 0x15, 0xc6: 0x01, 0xc7: 0x02, - 0xc8: 0x16, 0xc9: 0x03, 0xca: 0x04, 0xcb: 0x17, 0xcc: 0x18, 0xcd: 0x05, 0xce: 0x06, 0xcf: 0x07, - 0xd0: 0x19, 0xd1: 0x1a, 0xd2: 0x1b, 0xd3: 0x1c, 0xd4: 0x1d, 0xd5: 0x1e, 0xd6: 0x1f, 0xd7: 0x20, - 0xd8: 0x21, 0xd9: 0x22, 0xda: 0x23, 0xdb: 0x24, 0xdc: 0x25, 0xdd: 0x26, 0xde: 0x27, 0xdf: 0x28, - 0xe0: 0x02, 0xe1: 0x03, 0xe2: 0x04, 0xe3: 0x05, - 0xea: 0x06, 0xeb: 0x07, 0xec: 0x07, 0xed: 0x08, 0xef: 0x09, - 0xf0: 0x14, 0xf3: 0x16, - // Block 0x4, offset 0x100 - 0x120: 0x29, 0x121: 0x2a, 0x122: 0x2b, 0x123: 0x2c, 0x124: 0x2d, 0x125: 0x2e, 0x126: 0x2f, 0x127: 0x30, - 0x128: 0x31, 0x129: 0x32, 0x12a: 0x33, 0x12b: 0x34, 0x12c: 0x35, 0x12d: 0x36, 0x12e: 0x37, 0x12f: 0x38, - 0x130: 0x39, 0x131: 0x3a, 0x132: 0x3b, 0x133: 0x3c, 0x134: 0x3d, 0x135: 0x3e, 0x136: 0x3f, 0x137: 0x40, - 0x138: 0x41, 0x139: 0x42, 0x13a: 0x43, 0x13b: 0x44, 0x13c: 0x45, 0x13d: 0x46, 0x13e: 0x47, 0x13f: 0x48, - // Block 0x5, offset 0x140 - 0x140: 0x49, 0x141: 0x4a, 0x142: 0x4b, 0x143: 0x4c, 0x144: 0x23, 0x145: 0x23, 0x146: 0x23, 0x147: 0x23, - 0x148: 0x23, 0x149: 0x4d, 0x14a: 0x4e, 0x14b: 0x4f, 0x14c: 0x50, 0x14d: 0x51, 0x14e: 0x52, 0x14f: 0x53, - 0x150: 0x54, 0x151: 0x23, 0x152: 0x23, 0x153: 0x23, 0x154: 0x23, 0x155: 0x23, 0x156: 0x23, 0x157: 0x23, - 0x158: 0x23, 0x159: 0x55, 0x15a: 0x56, 0x15b: 0x57, 0x15c: 0x58, 0x15d: 0x59, 0x15e: 0x5a, 0x15f: 0x5b, - 0x160: 0x5c, 0x161: 0x5d, 0x162: 0x5e, 0x163: 0x5f, 0x164: 0x60, 0x165: 0x61, 0x167: 0x62, - 0x168: 0x63, 0x169: 0x64, 0x16a: 0x65, 0x16c: 0x66, 0x16d: 0x67, 0x16e: 0x68, 0x16f: 0x69, - 0x170: 0x6a, 0x171: 0x6b, 0x172: 0x6c, 0x173: 0x6d, 0x174: 0x6e, 0x175: 0x6f, 0x176: 0x70, 0x177: 0x71, - 0x178: 0x72, 0x179: 0x72, 0x17a: 0x73, 0x17b: 0x72, 0x17c: 0x74, 0x17d: 0x08, 0x17e: 0x09, 0x17f: 0x0a, - // Block 0x6, offset 0x180 - 0x180: 0x75, 0x181: 0x76, 0x182: 0x77, 0x183: 0x78, 0x184: 0x0b, 0x185: 0x79, 0x186: 0x7a, - 0x192: 0x7b, 0x193: 0x0c, - 0x1b0: 0x7c, 0x1b1: 0x0d, 0x1b2: 0x72, 0x1b3: 0x7d, 0x1b4: 0x7e, 0x1b5: 0x7f, 0x1b6: 0x80, 0x1b7: 0x81, - 0x1b8: 0x82, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x83, 0x1c2: 0x84, 0x1c3: 0x85, 0x1c4: 0x86, 0x1c5: 0x23, 0x1c6: 0x87, - // Block 0x8, offset 0x200 - 0x200: 0x88, 0x201: 0x23, 0x202: 0x23, 0x203: 0x23, 0x204: 0x23, 0x205: 0x23, 0x206: 0x23, 0x207: 0x23, - 0x208: 0x23, 0x209: 0x23, 0x20a: 0x23, 0x20b: 0x23, 0x20c: 0x23, 0x20d: 0x23, 0x20e: 0x23, 0x20f: 0x23, - 0x210: 0x23, 0x211: 0x23, 0x212: 0x89, 0x213: 0x8a, 0x214: 0x23, 0x215: 0x23, 0x216: 0x23, 0x217: 0x23, - 0x218: 0x8b, 0x219: 0x8c, 0x21a: 0x8d, 0x21b: 0x8e, 0x21c: 0x8f, 0x21d: 0x90, 0x21e: 0x0e, 0x21f: 0x91, - 0x220: 0x92, 0x221: 0x93, 0x222: 0x23, 0x223: 0x94, 0x224: 0x95, 0x225: 0x96, 0x226: 0x97, 0x227: 0x98, - 0x228: 0x99, 0x229: 0x9a, 0x22a: 0x9b, 0x22b: 0x9c, 0x22c: 0x9d, 0x22d: 0x9e, 0x22e: 0x9f, 0x22f: 0xa0, - 0x230: 0x23, 0x231: 0x23, 0x232: 0x23, 0x233: 0x23, 0x234: 0x23, 0x235: 0x23, 0x236: 0x23, 0x237: 0x23, - 0x238: 0x23, 0x239: 0x23, 0x23a: 0x23, 0x23b: 0x23, 0x23c: 0x23, 0x23d: 0x23, 0x23e: 0x23, 0x23f: 0x23, - // Block 0x9, offset 0x240 - 0x240: 0x23, 0x241: 0x23, 0x242: 0x23, 0x243: 0x23, 0x244: 0x23, 0x245: 0x23, 0x246: 0x23, 0x247: 0x23, - 0x248: 0x23, 0x249: 0x23, 0x24a: 0x23, 0x24b: 0x23, 0x24c: 0x23, 0x24d: 0x23, 0x24e: 0x23, 0x24f: 0x23, - 0x250: 0x23, 0x251: 0x23, 0x252: 0x23, 0x253: 0x23, 0x254: 0x23, 0x255: 0x23, 0x256: 0x23, 0x257: 0x23, - 0x258: 0x23, 0x259: 0x23, 0x25a: 0x23, 0x25b: 0x23, 0x25c: 0x23, 0x25d: 0x23, 0x25e: 0x23, 0x25f: 0x23, - 0x260: 0x23, 0x261: 0x23, 0x262: 0x23, 0x263: 0x23, 0x264: 0x23, 0x265: 0x23, 0x266: 0x23, 0x267: 0x23, - 0x268: 0x23, 0x269: 0x23, 0x26a: 0x23, 0x26b: 0x23, 0x26c: 0x23, 0x26d: 0x23, 0x26e: 0x23, 0x26f: 0x23, - 0x270: 0x23, 0x271: 0x23, 0x272: 0x23, 0x273: 0x23, 0x274: 0x23, 0x275: 0x23, 0x276: 0x23, 0x277: 0x23, - 0x278: 0x23, 0x279: 0x23, 0x27a: 0x23, 0x27b: 0x23, 0x27c: 0x23, 0x27d: 0x23, 0x27e: 0x23, 0x27f: 0x23, - // Block 0xa, offset 0x280 - 0x280: 0x23, 0x281: 0x23, 0x282: 0x23, 0x283: 0x23, 0x284: 0x23, 0x285: 0x23, 0x286: 0x23, 0x287: 0x23, - 0x288: 0x23, 0x289: 0x23, 0x28a: 0x23, 0x28b: 0x23, 0x28c: 0x23, 0x28d: 0x23, 0x28e: 0x23, 0x28f: 0x23, - 0x290: 0x23, 0x291: 0x23, 0x292: 0x23, 0x293: 0x23, 0x294: 0x23, 0x295: 0x23, 0x296: 0x23, 0x297: 0x23, - 0x298: 0x23, 0x299: 0x23, 0x29a: 0x23, 0x29b: 0x23, 0x29c: 0x23, 0x29d: 0x23, 0x29e: 0xa1, 0x29f: 0xa2, - // Block 0xb, offset 0x2c0 - 0x2ec: 0x0f, 0x2ed: 0xa3, 0x2ee: 0xa4, 0x2ef: 0xa5, - 0x2f0: 0x23, 0x2f1: 0x23, 0x2f2: 0x23, 0x2f3: 0x23, 0x2f4: 0xa6, 0x2f5: 0xa7, 0x2f6: 0xa8, 0x2f7: 0xa9, - 0x2f8: 0xaa, 0x2f9: 0xab, 0x2fa: 0x23, 0x2fb: 0xac, 0x2fc: 0xad, 0x2fd: 0xae, 0x2fe: 0xaf, 0x2ff: 0xb0, - // Block 0xc, offset 0x300 - 0x300: 0xb1, 0x301: 0xb2, 0x302: 0x23, 0x303: 0xb3, 0x305: 0xb4, 0x307: 0xb5, - 0x30a: 0xb6, 0x30b: 0xb7, 0x30c: 0xb8, 0x30d: 0xb9, 0x30e: 0xba, 0x30f: 0xbb, - 0x310: 0xbc, 0x311: 0xbd, 0x312: 0xbe, 0x313: 0xbf, 0x314: 0xc0, 0x315: 0xc1, - 0x318: 0x23, 0x319: 0x23, 0x31a: 0x23, 0x31b: 0x23, 0x31c: 0xc2, 0x31d: 0xc3, - 0x320: 0xc4, 0x321: 0xc5, 0x322: 0xc6, 0x323: 0xc7, 0x324: 0xc8, 0x326: 0xc9, - 0x328: 0xca, 0x329: 0xcb, 0x32a: 0xcc, 0x32b: 0xcd, 0x32c: 0x5f, 0x32d: 0xce, 0x32e: 0xcf, - 0x330: 0x23, 0x331: 0xd0, 0x332: 0xd1, 0x333: 0xd2, - // Block 0xd, offset 0x340 - 0x340: 0xd3, 0x341: 0xd4, 0x342: 0xd5, 0x343: 0xd6, 0x344: 0xd7, 0x345: 0xd8, 0x346: 0xd9, 0x347: 0xda, - 0x348: 0xdb, 0x34a: 0xdc, 0x34b: 0xdd, 0x34c: 0xde, 0x34d: 0xdf, - 0x350: 0xe0, 0x351: 0xe1, 0x352: 0xe2, 0x353: 0xe3, 0x356: 0xe4, 0x357: 0xe5, - 0x358: 0xe6, 0x359: 0xe7, 0x35a: 0xe8, 0x35b: 0xe9, 0x35c: 0xea, - 0x362: 0xeb, 0x363: 0xec, - 0x36b: 0xed, - 0x370: 0xee, 0x371: 0xef, 0x372: 0xf0, - // Block 0xe, offset 0x380 - 0x380: 0x23, 0x381: 0x23, 0x382: 0x23, 0x383: 0x23, 0x384: 0x23, 0x385: 0x23, 0x386: 0x23, 0x387: 0x23, - 0x388: 0x23, 0x389: 0x23, 0x38a: 0x23, 0x38b: 0x23, 0x38c: 0x23, 0x38d: 0x23, 0x38e: 0xf1, - 0x390: 0x23, 0x391: 0xf2, 0x392: 0x23, 0x393: 0x23, 0x394: 0x23, 0x395: 0xf3, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x23, 0x3c1: 0x23, 0x3c2: 0x23, 0x3c3: 0x23, 0x3c4: 0x23, 0x3c5: 0x23, 0x3c6: 0x23, 0x3c7: 0x23, - 0x3c8: 0x23, 0x3c9: 0x23, 0x3ca: 0x23, 0x3cb: 0x23, 0x3cc: 0x23, 0x3cd: 0x23, 0x3ce: 0x23, 0x3cf: 0x23, - 0x3d0: 0xf2, - // Block 0x10, offset 0x400 - 0x410: 0x23, 0x411: 0x23, 0x412: 0x23, 0x413: 0x23, 0x414: 0x23, 0x415: 0x23, 0x416: 0x23, 0x417: 0x23, - 0x418: 0x23, 0x419: 0xf4, - // Block 0x11, offset 0x440 - 0x460: 0x23, 0x461: 0x23, 0x462: 0x23, 0x463: 0x23, 0x464: 0x23, 0x465: 0x23, 0x466: 0x23, 0x467: 0x23, - 0x468: 0xed, 0x469: 0xf5, 0x46b: 0xf6, 0x46c: 0xf7, 0x46d: 0xf8, 0x46e: 0xf9, - 0x47c: 0x23, 0x47d: 0xfa, 0x47e: 0xfb, 0x47f: 0xfc, - // Block 0x12, offset 0x480 - 0x4b0: 0x23, 0x4b1: 0xfd, 0x4b2: 0xfe, - // Block 0x13, offset 0x4c0 - 0x4c5: 0xff, 0x4c6: 0x100, - 0x4c9: 0x101, - 0x4d0: 0x102, 0x4d1: 0x103, 0x4d2: 0x104, 0x4d3: 0x105, 0x4d4: 0x106, 0x4d5: 0x107, 0x4d6: 0x108, 0x4d7: 0x109, - 0x4d8: 0x10a, 0x4d9: 0x10b, 0x4da: 0x10c, 0x4db: 0x10d, 0x4dc: 0x10e, 0x4dd: 0x10f, 0x4de: 0x110, 0x4df: 0x111, - 0x4e8: 0x112, 0x4e9: 0x113, 0x4ea: 0x114, - // Block 0x14, offset 0x500 - 0x500: 0x115, - 0x520: 0x23, 0x521: 0x23, 0x522: 0x23, 0x523: 0x116, 0x524: 0x10, 0x525: 0x117, - 0x538: 0x118, 0x539: 0x11, 0x53a: 0x119, - // Block 0x15, offset 0x540 - 0x544: 0x11a, 0x545: 0x11b, 0x546: 0x11c, - 0x54f: 0x11d, - // Block 0x16, offset 0x580 - 0x590: 0x0a, 0x591: 0x0b, 0x592: 0x0c, 0x593: 0x0d, 0x594: 0x0e, 0x596: 0x0f, - 0x59b: 0x10, 0x59d: 0x11, 0x59e: 0x12, 0x59f: 0x13, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x11e, 0x5c1: 0x11f, 0x5c4: 0x11f, 0x5c5: 0x11f, 0x5c6: 0x11f, 0x5c7: 0x120, - // Block 0x18, offset 0x600 - 0x620: 0x15, -} - -// sparseOffsets: 272 entries, 544 bytes -var sparseOffsets = []uint16{0x0, 0x9, 0xf, 0x18, 0x24, 0x2e, 0x3a, 0x3d, 0x41, 0x44, 0x48, 0x52, 0x54, 0x59, 0x69, 0x70, 0x75, 0x83, 0x84, 0x92, 0xa1, 0xab, 0xae, 0xb4, 0xbc, 0xbe, 0xc0, 0xce, 0xd4, 0xe2, 0xed, 0xf8, 0x103, 0x10f, 0x119, 0x124, 0x12f, 0x13b, 0x147, 0x14f, 0x157, 0x161, 0x16c, 0x178, 0x17e, 0x189, 0x18e, 0x196, 0x199, 0x19e, 0x1a2, 0x1a6, 0x1ad, 0x1b6, 0x1be, 0x1bf, 0x1c8, 0x1cf, 0x1d7, 0x1dd, 0x1e3, 0x1e8, 0x1ec, 0x1ef, 0x1f1, 0x1f4, 0x1f9, 0x1fa, 0x1fc, 0x1fe, 0x200, 0x207, 0x20c, 0x210, 0x219, 0x21c, 0x21f, 0x225, 0x226, 0x231, 0x232, 0x233, 0x238, 0x245, 0x24d, 0x255, 0x25e, 0x267, 0x270, 0x275, 0x278, 0x281, 0x28e, 0x290, 0x297, 0x299, 0x2a4, 0x2a5, 0x2b0, 0x2b8, 0x2c2, 0x2c8, 0x2c9, 0x2d7, 0x2dc, 0x2df, 0x2e4, 0x2e8, 0x2ee, 0x2f3, 0x2f6, 0x2fb, 0x300, 0x301, 0x307, 0x309, 0x30a, 0x30c, 0x30e, 0x311, 0x312, 0x314, 0x317, 0x31d, 0x321, 0x323, 0x329, 0x330, 0x334, 0x33d, 0x33e, 0x346, 0x34a, 0x34f, 0x357, 0x35d, 0x363, 0x36d, 0x372, 0x37b, 0x381, 0x388, 0x38c, 0x394, 0x396, 0x398, 0x39b, 0x39d, 0x39f, 0x3a0, 0x3a1, 0x3a3, 0x3a5, 0x3ab, 0x3b0, 0x3b2, 0x3b8, 0x3bb, 0x3bd, 0x3c3, 0x3c8, 0x3ca, 0x3cb, 0x3cc, 0x3cd, 0x3cf, 0x3d1, 0x3d3, 0x3d6, 0x3d8, 0x3db, 0x3e3, 0x3e6, 0x3ea, 0x3f2, 0x3f4, 0x3f5, 0x3f6, 0x3f8, 0x3fe, 0x400, 0x401, 0x403, 0x405, 0x407, 0x414, 0x415, 0x416, 0x41a, 0x41c, 0x41d, 0x41e, 0x41f, 0x420, 0x424, 0x428, 0x42e, 0x430, 0x437, 0x43a, 0x43e, 0x444, 0x44d, 0x453, 0x459, 0x463, 0x46d, 0x46f, 0x476, 0x47c, 0x482, 0x488, 0x48b, 0x491, 0x494, 0x49c, 0x49d, 0x4a4, 0x4a5, 0x4a8, 0x4a9, 0x4af, 0x4b2, 0x4ba, 0x4bb, 0x4bc, 0x4bd, 0x4be, 0x4c0, 0x4c2, 0x4c4, 0x4c8, 0x4c9, 0x4cb, 0x4cc, 0x4cd, 0x4cf, 0x4d4, 0x4d9, 0x4dd, 0x4de, 0x4e1, 0x4e5, 0x4f0, 0x4f4, 0x4fc, 0x501, 0x505, 0x508, 0x50c, 0x50f, 0x512, 0x517, 0x51b, 0x51f, 0x523, 0x527, 0x529, 0x52b, 0x52e, 0x533, 0x535, 0x53a, 0x543, 0x548, 0x549, 0x54c, 0x54d, 0x54e, 0x550, 0x551, 0x552} - -// sparseValues: 1362 entries, 5448 bytes -var sparseValues = [1362]valueRange{ - // Block 0x0, offset 0x0 - {value: 0x0004, lo: 0xa8, hi: 0xa8}, - {value: 0x0012, lo: 0xaa, hi: 0xaa}, - {value: 0x0014, lo: 0xad, hi: 0xad}, - {value: 0x0004, lo: 0xaf, hi: 0xaf}, - {value: 0x0004, lo: 0xb4, hi: 0xb4}, - {value: 0x002a, lo: 0xb5, hi: 0xb5}, - {value: 0x0014, lo: 0xb7, hi: 0xb7}, - {value: 0x0004, lo: 0xb8, hi: 0xb8}, - {value: 0x0012, lo: 0xba, hi: 0xba}, - // Block 0x1, offset 0x9 - {value: 0x2013, lo: 0x80, hi: 0x96}, - {value: 0x2013, lo: 0x98, hi: 0x9e}, - {value: 0x00ea, lo: 0x9f, hi: 0x9f}, - {value: 0x2012, lo: 0xa0, hi: 0xb6}, - {value: 0x2012, lo: 0xb8, hi: 0xbe}, - {value: 0x0252, lo: 0xbf, hi: 0xbf}, - // Block 0x2, offset 0xf - {value: 0x0117, lo: 0x80, hi: 0xaf}, - {value: 0x01eb, lo: 0xb0, hi: 0xb0}, - {value: 0x02ea, lo: 0xb1, hi: 0xb1}, - {value: 0x0117, lo: 0xb2, hi: 0xb7}, - {value: 0x0012, lo: 0xb8, hi: 0xb8}, - {value: 0x0316, lo: 0xb9, hi: 0xba}, - {value: 0x0716, lo: 0xbb, hi: 0xbc}, - {value: 0x0316, lo: 0xbd, hi: 0xbe}, - {value: 0x0553, lo: 0xbf, hi: 0xbf}, - // Block 0x3, offset 0x18 - {value: 0x0552, lo: 0x80, hi: 0x80}, - {value: 0x0316, lo: 0x81, hi: 0x82}, - {value: 0x0716, lo: 0x83, hi: 0x84}, - {value: 0x0316, lo: 0x85, hi: 0x86}, - {value: 0x0f16, lo: 0x87, hi: 0x88}, - {value: 0x034a, lo: 0x89, hi: 0x89}, - {value: 0x0117, lo: 0x8a, hi: 0xb7}, - {value: 0x0253, lo: 0xb8, hi: 0xb8}, - {value: 0x0316, lo: 0xb9, hi: 0xba}, - {value: 0x0716, lo: 0xbb, hi: 0xbc}, - {value: 0x0316, lo: 0xbd, hi: 0xbe}, - {value: 0x044a, lo: 0xbf, hi: 0xbf}, - // Block 0x4, offset 0x24 - {value: 0x0117, lo: 0x80, hi: 0x9f}, - {value: 0x2f53, lo: 0xa0, hi: 0xa0}, - {value: 0x0012, lo: 0xa1, hi: 0xa1}, - {value: 0x0117, lo: 0xa2, hi: 0xb3}, - {value: 0x0012, lo: 0xb4, hi: 0xb9}, - {value: 0x10cb, lo: 0xba, hi: 0xba}, - {value: 0x0716, lo: 0xbb, hi: 0xbc}, - {value: 0x2953, lo: 0xbd, hi: 0xbd}, - {value: 0x11cb, lo: 0xbe, hi: 0xbe}, - {value: 0x12ca, lo: 0xbf, hi: 0xbf}, - // Block 0x5, offset 0x2e - {value: 0x0015, lo: 0x80, hi: 0x81}, - {value: 0x0004, lo: 0x82, hi: 0x85}, - {value: 0x0014, lo: 0x86, hi: 0x91}, - {value: 0x0004, lo: 0x92, hi: 0x96}, - {value: 0x0014, lo: 0x97, hi: 0x97}, - {value: 0x0004, lo: 0x98, hi: 0x9f}, - {value: 0x0015, lo: 0xa0, hi: 0xa4}, - {value: 0x0004, lo: 0xa5, hi: 0xab}, - {value: 0x0014, lo: 0xac, hi: 0xac}, - {value: 0x0004, lo: 0xad, hi: 0xad}, - {value: 0x0014, lo: 0xae, hi: 0xae}, - {value: 0x0004, lo: 0xaf, hi: 0xbf}, - // Block 0x6, offset 0x3a - {value: 0x0024, lo: 0x80, hi: 0x94}, - {value: 0x0034, lo: 0x95, hi: 0xbc}, - {value: 0x0024, lo: 0xbd, hi: 0xbf}, - // Block 0x7, offset 0x3d - {value: 0x6553, lo: 0x80, hi: 0x8f}, - {value: 0x2013, lo: 0x90, hi: 0x9f}, - {value: 0x5f53, lo: 0xa0, hi: 0xaf}, - {value: 0x2012, lo: 0xb0, hi: 0xbf}, - // Block 0x8, offset 0x41 - {value: 0x5f52, lo: 0x80, hi: 0x8f}, - {value: 0x6552, lo: 0x90, hi: 0x9f}, - {value: 0x0117, lo: 0xa0, hi: 0xbf}, - // Block 0x9, offset 0x44 - {value: 0x0117, lo: 0x80, hi: 0x81}, - {value: 0x0024, lo: 0x83, hi: 0x87}, - {value: 0x0014, lo: 0x88, hi: 0x89}, - {value: 0x0117, lo: 0x8a, hi: 0xbf}, - // Block 0xa, offset 0x48 - {value: 0x0f13, lo: 0x80, hi: 0x80}, - {value: 0x0316, lo: 0x81, hi: 0x82}, - {value: 0x0716, lo: 0x83, hi: 0x84}, - {value: 0x0316, lo: 0x85, hi: 0x86}, - {value: 0x0f16, lo: 0x87, hi: 0x88}, - {value: 0x0316, lo: 0x89, hi: 0x8a}, - {value: 0x0716, lo: 0x8b, hi: 0x8c}, - {value: 0x0316, lo: 0x8d, hi: 0x8e}, - {value: 0x0f12, lo: 0x8f, hi: 0x8f}, - {value: 0x0117, lo: 0x90, hi: 0xbf}, - // Block 0xb, offset 0x52 - {value: 0x0117, lo: 0x80, hi: 0xaf}, - {value: 0x6553, lo: 0xb1, hi: 0xbf}, - // Block 0xc, offset 0x54 - {value: 0x3013, lo: 0x80, hi: 0x8f}, - {value: 0x6853, lo: 0x90, hi: 0x96}, - {value: 0x0014, lo: 0x99, hi: 0x99}, - {value: 0x6552, lo: 0xa1, hi: 0xaf}, - {value: 0x3012, lo: 0xb0, hi: 0xbf}, - // Block 0xd, offset 0x59 - {value: 0x6852, lo: 0x80, hi: 0x86}, - {value: 0x27aa, lo: 0x87, hi: 0x87}, - {value: 0x0034, lo: 0x91, hi: 0x91}, - {value: 0x0024, lo: 0x92, hi: 0x95}, - {value: 0x0034, lo: 0x96, hi: 0x96}, - {value: 0x0024, lo: 0x97, hi: 0x99}, - {value: 0x0034, lo: 0x9a, hi: 0x9b}, - {value: 0x0024, lo: 0x9c, hi: 0xa1}, - {value: 0x0034, lo: 0xa2, hi: 0xa7}, - {value: 0x0024, lo: 0xa8, hi: 0xa9}, - {value: 0x0034, lo: 0xaa, hi: 0xaa}, - {value: 0x0024, lo: 0xab, hi: 0xac}, - {value: 0x0034, lo: 0xad, hi: 0xae}, - {value: 0x0024, lo: 0xaf, hi: 0xaf}, - {value: 0x0034, lo: 0xb0, hi: 0xbd}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xe, offset 0x69 - {value: 0x0034, lo: 0x81, hi: 0x82}, - {value: 0x0024, lo: 0x84, hi: 0x84}, - {value: 0x0034, lo: 0x85, hi: 0x85}, - {value: 0x0034, lo: 0x87, hi: 0x87}, - {value: 0x0010, lo: 0x90, hi: 0xaa}, - {value: 0x0010, lo: 0xb0, hi: 0xb3}, - {value: 0x0014, lo: 0xb4, hi: 0xb4}, - // Block 0xf, offset 0x70 - {value: 0x0014, lo: 0x80, hi: 0x85}, - {value: 0x0024, lo: 0x90, hi: 0x97}, - {value: 0x0034, lo: 0x98, hi: 0x9a}, - {value: 0x0014, lo: 0x9c, hi: 0x9c}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x10, offset 0x75 - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x8a}, - {value: 0x0034, lo: 0x8b, hi: 0x92}, - {value: 0x0024, lo: 0x93, hi: 0x94}, - {value: 0x0034, lo: 0x95, hi: 0x96}, - {value: 0x0024, lo: 0x97, hi: 0x9b}, - {value: 0x0034, lo: 0x9c, hi: 0x9c}, - {value: 0x0024, lo: 0x9d, hi: 0x9e}, - {value: 0x0034, lo: 0x9f, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - {value: 0x0010, lo: 0xab, hi: 0xab}, - {value: 0x0010, lo: 0xae, hi: 0xaf}, - {value: 0x0034, lo: 0xb0, hi: 0xb0}, - {value: 0x0010, lo: 0xb1, hi: 0xbf}, - // Block 0x11, offset 0x83 - {value: 0x0010, lo: 0x80, hi: 0xbf}, - // Block 0x12, offset 0x84 - {value: 0x0010, lo: 0x80, hi: 0x93}, - {value: 0x0010, lo: 0x95, hi: 0x95}, - {value: 0x0024, lo: 0x96, hi: 0x9c}, - {value: 0x0014, lo: 0x9d, hi: 0x9d}, - {value: 0x0024, lo: 0x9f, hi: 0xa2}, - {value: 0x0034, lo: 0xa3, hi: 0xa3}, - {value: 0x0024, lo: 0xa4, hi: 0xa4}, - {value: 0x0014, lo: 0xa5, hi: 0xa6}, - {value: 0x0024, lo: 0xa7, hi: 0xa8}, - {value: 0x0034, lo: 0xaa, hi: 0xaa}, - {value: 0x0024, lo: 0xab, hi: 0xac}, - {value: 0x0034, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xbc}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x13, offset 0x92 - {value: 0x0014, lo: 0x8f, hi: 0x8f}, - {value: 0x0010, lo: 0x90, hi: 0x90}, - {value: 0x0034, lo: 0x91, hi: 0x91}, - {value: 0x0010, lo: 0x92, hi: 0xaf}, - {value: 0x0024, lo: 0xb0, hi: 0xb0}, - {value: 0x0034, lo: 0xb1, hi: 0xb1}, - {value: 0x0024, lo: 0xb2, hi: 0xb3}, - {value: 0x0034, lo: 0xb4, hi: 0xb4}, - {value: 0x0024, lo: 0xb5, hi: 0xb6}, - {value: 0x0034, lo: 0xb7, hi: 0xb9}, - {value: 0x0024, lo: 0xba, hi: 0xba}, - {value: 0x0034, lo: 0xbb, hi: 0xbc}, - {value: 0x0024, lo: 0xbd, hi: 0xbd}, - {value: 0x0034, lo: 0xbe, hi: 0xbe}, - {value: 0x0024, lo: 0xbf, hi: 0xbf}, - // Block 0x14, offset 0xa1 - {value: 0x0024, lo: 0x80, hi: 0x81}, - {value: 0x0034, lo: 0x82, hi: 0x82}, - {value: 0x0024, lo: 0x83, hi: 0x83}, - {value: 0x0034, lo: 0x84, hi: 0x84}, - {value: 0x0024, lo: 0x85, hi: 0x85}, - {value: 0x0034, lo: 0x86, hi: 0x86}, - {value: 0x0024, lo: 0x87, hi: 0x87}, - {value: 0x0034, lo: 0x88, hi: 0x88}, - {value: 0x0024, lo: 0x89, hi: 0x8a}, - {value: 0x0010, lo: 0x8d, hi: 0xbf}, - // Block 0x15, offset 0xab - {value: 0x0010, lo: 0x80, hi: 0xa5}, - {value: 0x0014, lo: 0xa6, hi: 0xb0}, - {value: 0x0010, lo: 0xb1, hi: 0xb1}, - // Block 0x16, offset 0xae - {value: 0x0010, lo: 0x80, hi: 0xaa}, - {value: 0x0024, lo: 0xab, hi: 0xb1}, - {value: 0x0034, lo: 0xb2, hi: 0xb2}, - {value: 0x0024, lo: 0xb3, hi: 0xb3}, - {value: 0x0014, lo: 0xb4, hi: 0xb5}, - {value: 0x0014, lo: 0xba, hi: 0xba}, - // Block 0x17, offset 0xb4 - {value: 0x0010, lo: 0x80, hi: 0x95}, - {value: 0x0024, lo: 0x96, hi: 0x99}, - {value: 0x0014, lo: 0x9a, hi: 0x9a}, - {value: 0x0024, lo: 0x9b, hi: 0xa3}, - {value: 0x0014, lo: 0xa4, hi: 0xa4}, - {value: 0x0024, lo: 0xa5, hi: 0xa7}, - {value: 0x0014, lo: 0xa8, hi: 0xa8}, - {value: 0x0024, lo: 0xa9, hi: 0xad}, - // Block 0x18, offset 0xbc - {value: 0x0010, lo: 0x80, hi: 0x98}, - {value: 0x0034, lo: 0x99, hi: 0x9b}, - // Block 0x19, offset 0xbe - {value: 0x0010, lo: 0xa0, hi: 0xb4}, - {value: 0x0010, lo: 0xb6, hi: 0xbd}, - // Block 0x1a, offset 0xc0 - {value: 0x0024, lo: 0x94, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa2}, - {value: 0x0034, lo: 0xa3, hi: 0xa3}, - {value: 0x0024, lo: 0xa4, hi: 0xa5}, - {value: 0x0034, lo: 0xa6, hi: 0xa6}, - {value: 0x0024, lo: 0xa7, hi: 0xa8}, - {value: 0x0034, lo: 0xa9, hi: 0xa9}, - {value: 0x0024, lo: 0xaa, hi: 0xac}, - {value: 0x0034, lo: 0xad, hi: 0xb2}, - {value: 0x0024, lo: 0xb3, hi: 0xb5}, - {value: 0x0034, lo: 0xb6, hi: 0xb6}, - {value: 0x0024, lo: 0xb7, hi: 0xb8}, - {value: 0x0034, lo: 0xb9, hi: 0xba}, - {value: 0x0024, lo: 0xbb, hi: 0xbf}, - // Block 0x1b, offset 0xce - {value: 0x0014, lo: 0x80, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0xb9}, - {value: 0x0014, lo: 0xba, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbb}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x1c, offset 0xd4 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x88}, - {value: 0x0010, lo: 0x89, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x8e, hi: 0x90}, - {value: 0x0024, lo: 0x91, hi: 0x91}, - {value: 0x0034, lo: 0x92, hi: 0x92}, - {value: 0x0024, lo: 0x93, hi: 0x94}, - {value: 0x0014, lo: 0x95, hi: 0x97}, - {value: 0x0010, lo: 0x98, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0014, lo: 0xb1, hi: 0xb1}, - {value: 0x0010, lo: 0xb2, hi: 0xbf}, - // Block 0x1d, offset 0xe2 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8f, hi: 0x90}, - {value: 0x0010, lo: 0x93, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb2}, - {value: 0x0010, lo: 0xb6, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x1e, offset 0xed - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x84}, - {value: 0x0010, lo: 0x87, hi: 0x88}, - {value: 0x0010, lo: 0x8b, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x8e, hi: 0x8e}, - {value: 0x0010, lo: 0x97, hi: 0x97}, - {value: 0x0010, lo: 0x9c, hi: 0x9d}, - {value: 0x0010, lo: 0x9f, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xb1}, - // Block 0x1f, offset 0xf8 - {value: 0x0014, lo: 0x81, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8a}, - {value: 0x0010, lo: 0x8f, hi: 0x90}, - {value: 0x0010, lo: 0x93, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - {value: 0x0010, lo: 0xb5, hi: 0xb6}, - {value: 0x0010, lo: 0xb8, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0x20, offset 0x103 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x82}, - {value: 0x0014, lo: 0x87, hi: 0x88}, - {value: 0x0014, lo: 0x8b, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0014, lo: 0x91, hi: 0x91}, - {value: 0x0010, lo: 0x99, hi: 0x9c}, - {value: 0x0010, lo: 0x9e, hi: 0x9e}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0014, lo: 0xb0, hi: 0xb1}, - {value: 0x0010, lo: 0xb2, hi: 0xb4}, - {value: 0x0014, lo: 0xb5, hi: 0xb5}, - // Block 0x21, offset 0x10f - {value: 0x0014, lo: 0x81, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8d}, - {value: 0x0010, lo: 0x8f, hi: 0x91}, - {value: 0x0010, lo: 0x93, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - {value: 0x0010, lo: 0xb5, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x22, offset 0x119 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x85}, - {value: 0x0014, lo: 0x87, hi: 0x88}, - {value: 0x0010, lo: 0x89, hi: 0x89}, - {value: 0x0010, lo: 0x8b, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x90}, - {value: 0x0010, lo: 0xa0, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0010, lo: 0xb9, hi: 0xb9}, - // Block 0x23, offset 0x124 - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8f, hi: 0x90}, - {value: 0x0010, lo: 0x93, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - {value: 0x0010, lo: 0xb5, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbe}, - {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x24, offset 0x12f - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x84}, - {value: 0x0010, lo: 0x87, hi: 0x88}, - {value: 0x0010, lo: 0x8b, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0014, lo: 0x96, hi: 0x96}, - {value: 0x0010, lo: 0x97, hi: 0x97}, - {value: 0x0010, lo: 0x9c, hi: 0x9d}, - {value: 0x0010, lo: 0x9f, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0010, lo: 0xb1, hi: 0xb1}, - // Block 0x25, offset 0x13b - {value: 0x0014, lo: 0x82, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8a}, - {value: 0x0010, lo: 0x8e, hi: 0x90}, - {value: 0x0010, lo: 0x92, hi: 0x95}, - {value: 0x0010, lo: 0x99, hi: 0x9a}, - {value: 0x0010, lo: 0x9c, hi: 0x9c}, - {value: 0x0010, lo: 0x9e, hi: 0x9f}, - {value: 0x0010, lo: 0xa3, hi: 0xa4}, - {value: 0x0010, lo: 0xa8, hi: 0xaa}, - {value: 0x0010, lo: 0xae, hi: 0xb9}, - {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0x26, offset 0x147 - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x82}, - {value: 0x0010, lo: 0x86, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x90}, - {value: 0x0010, lo: 0x97, hi: 0x97}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - // Block 0x27, offset 0x14f - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8e, hi: 0x90}, - {value: 0x0010, lo: 0x92, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb9}, - {value: 0x0010, lo: 0xbd, hi: 0xbd}, - {value: 0x0014, lo: 0xbe, hi: 0xbf}, - // Block 0x28, offset 0x157 - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x84}, - {value: 0x0014, lo: 0x86, hi: 0x88}, - {value: 0x0014, lo: 0x8a, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0034, lo: 0x95, hi: 0x96}, - {value: 0x0010, lo: 0x98, hi: 0x9a}, - {value: 0x0010, lo: 0xa0, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - // Block 0x29, offset 0x161 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8e, hi: 0x90}, - {value: 0x0010, lo: 0x92, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb3}, - {value: 0x0010, lo: 0xb5, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbe}, - {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x2a, offset 0x16c - {value: 0x0010, lo: 0x80, hi: 0x84}, - {value: 0x0014, lo: 0x86, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x95, hi: 0x96}, - {value: 0x0010, lo: 0x9e, hi: 0x9e}, - {value: 0x0010, lo: 0xa0, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0010, lo: 0xb1, hi: 0xb2}, - // Block 0x2b, offset 0x178 - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8e, hi: 0x90}, - {value: 0x0010, lo: 0x92, hi: 0xba}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x2c, offset 0x17e - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x84}, - {value: 0x0010, lo: 0x86, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x8e, hi: 0x8e}, - {value: 0x0010, lo: 0x94, hi: 0x97}, - {value: 0x0010, lo: 0x9f, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa3}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0010, lo: 0xba, hi: 0xbf}, - // Block 0x2d, offset 0x189 - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x96}, - {value: 0x0010, lo: 0x9a, hi: 0xb1}, - {value: 0x0010, lo: 0xb3, hi: 0xbb}, - {value: 0x0010, lo: 0xbd, hi: 0xbd}, - // Block 0x2e, offset 0x18e - {value: 0x0010, lo: 0x80, hi: 0x86}, - {value: 0x0034, lo: 0x8a, hi: 0x8a}, - {value: 0x0010, lo: 0x8f, hi: 0x91}, - {value: 0x0014, lo: 0x92, hi: 0x94}, - {value: 0x0014, lo: 0x96, hi: 0x96}, - {value: 0x0010, lo: 0x98, hi: 0x9f}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - // Block 0x2f, offset 0x196 - {value: 0x0014, lo: 0xb1, hi: 0xb1}, - {value: 0x0014, lo: 0xb4, hi: 0xb7}, - {value: 0x0034, lo: 0xb8, hi: 0xba}, - // Block 0x30, offset 0x199 - {value: 0x0004, lo: 0x86, hi: 0x86}, - {value: 0x0014, lo: 0x87, hi: 0x87}, - {value: 0x0034, lo: 0x88, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8e}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0x31, offset 0x19e - {value: 0x0014, lo: 0xb1, hi: 0xb1}, - {value: 0x0014, lo: 0xb4, hi: 0xb7}, - {value: 0x0034, lo: 0xb8, hi: 0xb9}, - {value: 0x0014, lo: 0xbb, hi: 0xbc}, - // Block 0x32, offset 0x1a2 - {value: 0x0004, lo: 0x86, hi: 0x86}, - {value: 0x0034, lo: 0x88, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0x33, offset 0x1a6 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0034, lo: 0x98, hi: 0x99}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - {value: 0x0034, lo: 0xb5, hi: 0xb5}, - {value: 0x0034, lo: 0xb7, hi: 0xb7}, - {value: 0x0034, lo: 0xb9, hi: 0xb9}, - {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0x34, offset 0x1ad - {value: 0x0010, lo: 0x80, hi: 0x87}, - {value: 0x0010, lo: 0x89, hi: 0xac}, - {value: 0x0034, lo: 0xb1, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xb3}, - {value: 0x0034, lo: 0xb4, hi: 0xb4}, - {value: 0x0014, lo: 0xb5, hi: 0xb9}, - {value: 0x0034, lo: 0xba, hi: 0xbd}, - {value: 0x0014, lo: 0xbe, hi: 0xbe}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x35, offset 0x1b6 - {value: 0x0034, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0024, lo: 0x82, hi: 0x83}, - {value: 0x0034, lo: 0x84, hi: 0x84}, - {value: 0x0024, lo: 0x86, hi: 0x87}, - {value: 0x0010, lo: 0x88, hi: 0x8c}, - {value: 0x0014, lo: 0x8d, hi: 0x97}, - {value: 0x0014, lo: 0x99, hi: 0xbc}, - // Block 0x36, offset 0x1be - {value: 0x0034, lo: 0x86, hi: 0x86}, - // Block 0x37, offset 0x1bf - {value: 0x0010, lo: 0xab, hi: 0xac}, - {value: 0x0014, lo: 0xad, hi: 0xb0}, - {value: 0x0010, lo: 0xb1, hi: 0xb1}, - {value: 0x0014, lo: 0xb2, hi: 0xb6}, - {value: 0x0034, lo: 0xb7, hi: 0xb7}, - {value: 0x0010, lo: 0xb8, hi: 0xb8}, - {value: 0x0034, lo: 0xb9, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbc}, - {value: 0x0014, lo: 0xbd, hi: 0xbe}, - // Block 0x38, offset 0x1c8 - {value: 0x0010, lo: 0x80, hi: 0x89}, - {value: 0x0010, lo: 0x96, hi: 0x97}, - {value: 0x0014, lo: 0x98, hi: 0x99}, - {value: 0x0014, lo: 0x9e, hi: 0xa0}, - {value: 0x0010, lo: 0xa2, hi: 0xa4}, - {value: 0x0010, lo: 0xa7, hi: 0xad}, - {value: 0x0014, lo: 0xb1, hi: 0xb4}, - // Block 0x39, offset 0x1cf - {value: 0x0014, lo: 0x82, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x84}, - {value: 0x0014, lo: 0x85, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x8f, hi: 0x9c}, - {value: 0x0014, lo: 0x9d, hi: 0x9d}, - {value: 0x6c53, lo: 0xa0, hi: 0xbf}, - // Block 0x3a, offset 0x1d7 - {value: 0x7053, lo: 0x80, hi: 0x85}, - {value: 0x7053, lo: 0x87, hi: 0x87}, - {value: 0x7053, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0xba}, - {value: 0x0014, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x3b, offset 0x1dd - {value: 0x0010, lo: 0x80, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x96}, - {value: 0x0010, lo: 0x98, hi: 0x98}, - {value: 0x0010, lo: 0x9a, hi: 0x9d}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x3c, offset 0x1e3 - {value: 0x0010, lo: 0x80, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb5}, - {value: 0x0010, lo: 0xb8, hi: 0xbe}, - // Block 0x3d, offset 0x1e8 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x82, hi: 0x85}, - {value: 0x0010, lo: 0x88, hi: 0x96}, - {value: 0x0010, lo: 0x98, hi: 0xbf}, - // Block 0x3e, offset 0x1ec - {value: 0x0010, lo: 0x80, hi: 0x90}, - {value: 0x0010, lo: 0x92, hi: 0x95}, - {value: 0x0010, lo: 0x98, hi: 0xbf}, - // Block 0x3f, offset 0x1ef - {value: 0x0010, lo: 0x80, hi: 0x9a}, - {value: 0x0024, lo: 0x9d, hi: 0x9f}, - // Block 0x40, offset 0x1f1 - {value: 0x0010, lo: 0x80, hi: 0x8f}, - {value: 0x7453, lo: 0xa0, hi: 0xaf}, - {value: 0x7853, lo: 0xb0, hi: 0xbf}, - // Block 0x41, offset 0x1f4 - {value: 0x7c53, lo: 0x80, hi: 0x8f}, - {value: 0x8053, lo: 0x90, hi: 0x9f}, - {value: 0x7c53, lo: 0xa0, hi: 0xaf}, - {value: 0x0813, lo: 0xb0, hi: 0xb5}, - {value: 0x0892, lo: 0xb8, hi: 0xbd}, - // Block 0x42, offset 0x1f9 - {value: 0x0010, lo: 0x81, hi: 0xbf}, - // Block 0x43, offset 0x1fa - {value: 0x0010, lo: 0x80, hi: 0xac}, - {value: 0x0010, lo: 0xaf, hi: 0xbf}, - // Block 0x44, offset 0x1fc - {value: 0x0010, lo: 0x81, hi: 0x9a}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x45, offset 0x1fe - {value: 0x0010, lo: 0x80, hi: 0xaa}, - {value: 0x0010, lo: 0xae, hi: 0xb8}, - // Block 0x46, offset 0x200 - {value: 0x0010, lo: 0x80, hi: 0x8c}, - {value: 0x0010, lo: 0x8e, hi: 0x91}, - {value: 0x0014, lo: 0x92, hi: 0x93}, - {value: 0x0034, lo: 0x94, hi: 0x94}, - {value: 0x0010, lo: 0xa0, hi: 0xb1}, - {value: 0x0014, lo: 0xb2, hi: 0xb3}, - {value: 0x0034, lo: 0xb4, hi: 0xb4}, - // Block 0x47, offset 0x207 - {value: 0x0010, lo: 0x80, hi: 0x91}, - {value: 0x0014, lo: 0x92, hi: 0x93}, - {value: 0x0010, lo: 0xa0, hi: 0xac}, - {value: 0x0010, lo: 0xae, hi: 0xb0}, - {value: 0x0014, lo: 0xb2, hi: 0xb3}, - // Block 0x48, offset 0x20c - {value: 0x0014, lo: 0xb4, hi: 0xb5}, - {value: 0x0010, lo: 0xb6, hi: 0xb6}, - {value: 0x0014, lo: 0xb7, hi: 0xbd}, - {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0x49, offset 0x210 - {value: 0x0010, lo: 0x80, hi: 0x85}, - {value: 0x0014, lo: 0x86, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0x88}, - {value: 0x0014, lo: 0x89, hi: 0x91}, - {value: 0x0034, lo: 0x92, hi: 0x92}, - {value: 0x0014, lo: 0x93, hi: 0x93}, - {value: 0x0004, lo: 0x97, hi: 0x97}, - {value: 0x0024, lo: 0x9d, hi: 0x9d}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - // Block 0x4a, offset 0x219 - {value: 0x0014, lo: 0x8b, hi: 0x8e}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x4b, offset 0x21c - {value: 0x0010, lo: 0x80, hi: 0x82}, - {value: 0x0014, lo: 0x83, hi: 0x83}, - {value: 0x0010, lo: 0x84, hi: 0xb7}, - // Block 0x4c, offset 0x21f - {value: 0x0010, lo: 0x80, hi: 0x84}, - {value: 0x0014, lo: 0x85, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0xa8}, - {value: 0x0034, lo: 0xa9, hi: 0xa9}, - {value: 0x0010, lo: 0xaa, hi: 0xaa}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x4d, offset 0x225 - {value: 0x0010, lo: 0x80, hi: 0xb5}, - // Block 0x4e, offset 0x226 - {value: 0x0010, lo: 0x80, hi: 0x9e}, - {value: 0x0014, lo: 0xa0, hi: 0xa2}, - {value: 0x0010, lo: 0xa3, hi: 0xa6}, - {value: 0x0014, lo: 0xa7, hi: 0xa8}, - {value: 0x0010, lo: 0xa9, hi: 0xab}, - {value: 0x0010, lo: 0xb0, hi: 0xb1}, - {value: 0x0014, lo: 0xb2, hi: 0xb2}, - {value: 0x0010, lo: 0xb3, hi: 0xb8}, - {value: 0x0034, lo: 0xb9, hi: 0xb9}, - {value: 0x0024, lo: 0xba, hi: 0xba}, - {value: 0x0034, lo: 0xbb, hi: 0xbb}, - // Block 0x4f, offset 0x231 - {value: 0x0010, lo: 0x86, hi: 0x8f}, - // Block 0x50, offset 0x232 - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0x51, offset 0x233 - {value: 0x0010, lo: 0x80, hi: 0x96}, - {value: 0x0024, lo: 0x97, hi: 0x97}, - {value: 0x0034, lo: 0x98, hi: 0x98}, - {value: 0x0010, lo: 0x99, hi: 0x9a}, - {value: 0x0014, lo: 0x9b, hi: 0x9b}, - // Block 0x52, offset 0x238 - {value: 0x0010, lo: 0x95, hi: 0x95}, - {value: 0x0014, lo: 0x96, hi: 0x96}, - {value: 0x0010, lo: 0x97, hi: 0x97}, - {value: 0x0014, lo: 0x98, hi: 0x9e}, - {value: 0x0034, lo: 0xa0, hi: 0xa0}, - {value: 0x0010, lo: 0xa1, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa2}, - {value: 0x0010, lo: 0xa3, hi: 0xa4}, - {value: 0x0014, lo: 0xa5, hi: 0xac}, - {value: 0x0010, lo: 0xad, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xb4}, - {value: 0x0024, lo: 0xb5, hi: 0xbc}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0x53, offset 0x245 - {value: 0x0010, lo: 0x80, hi: 0x89}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0004, lo: 0xa7, hi: 0xa7}, - {value: 0x0024, lo: 0xb0, hi: 0xb4}, - {value: 0x0034, lo: 0xb5, hi: 0xba}, - {value: 0x0024, lo: 0xbb, hi: 0xbc}, - {value: 0x0034, lo: 0xbd, hi: 0xbd}, - {value: 0x0014, lo: 0xbe, hi: 0xbe}, - // Block 0x54, offset 0x24d - {value: 0x0014, lo: 0x80, hi: 0x83}, - {value: 0x0010, lo: 0x84, hi: 0xb3}, - {value: 0x0034, lo: 0xb4, hi: 0xb4}, - {value: 0x0010, lo: 0xb5, hi: 0xb5}, - {value: 0x0014, lo: 0xb6, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbb}, - {value: 0x0014, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x55, offset 0x255 - {value: 0x0010, lo: 0x80, hi: 0x81}, - {value: 0x0014, lo: 0x82, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x83}, - {value: 0x0030, lo: 0x84, hi: 0x84}, - {value: 0x0010, lo: 0x85, hi: 0x8b}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0024, lo: 0xab, hi: 0xab}, - {value: 0x0034, lo: 0xac, hi: 0xac}, - {value: 0x0024, lo: 0xad, hi: 0xb3}, - // Block 0x56, offset 0x25e - {value: 0x0014, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa5}, - {value: 0x0010, lo: 0xa6, hi: 0xa7}, - {value: 0x0014, lo: 0xa8, hi: 0xa9}, - {value: 0x0030, lo: 0xaa, hi: 0xaa}, - {value: 0x0034, lo: 0xab, hi: 0xab}, - {value: 0x0014, lo: 0xac, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xbf}, - // Block 0x57, offset 0x267 - {value: 0x0010, lo: 0x80, hi: 0xa5}, - {value: 0x0034, lo: 0xa6, hi: 0xa6}, - {value: 0x0010, lo: 0xa7, hi: 0xa7}, - {value: 0x0014, lo: 0xa8, hi: 0xa9}, - {value: 0x0010, lo: 0xaa, hi: 0xac}, - {value: 0x0014, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xae}, - {value: 0x0014, lo: 0xaf, hi: 0xb1}, - {value: 0x0030, lo: 0xb2, hi: 0xb3}, - // Block 0x58, offset 0x270 - {value: 0x0010, lo: 0x80, hi: 0xab}, - {value: 0x0014, lo: 0xac, hi: 0xb3}, - {value: 0x0010, lo: 0xb4, hi: 0xb5}, - {value: 0x0014, lo: 0xb6, hi: 0xb6}, - {value: 0x0034, lo: 0xb7, hi: 0xb7}, - // Block 0x59, offset 0x275 - {value: 0x0010, lo: 0x80, hi: 0x89}, - {value: 0x0010, lo: 0x8d, hi: 0xb7}, - {value: 0x0014, lo: 0xb8, hi: 0xbd}, - // Block 0x5a, offset 0x278 - {value: 0x296a, lo: 0x80, hi: 0x80}, - {value: 0x2a2a, lo: 0x81, hi: 0x81}, - {value: 0x2aea, lo: 0x82, hi: 0x82}, - {value: 0x2baa, lo: 0x83, hi: 0x83}, - {value: 0x2c6a, lo: 0x84, hi: 0x84}, - {value: 0x2d2a, lo: 0x85, hi: 0x85}, - {value: 0x2dea, lo: 0x86, hi: 0x86}, - {value: 0x2eaa, lo: 0x87, hi: 0x87}, - {value: 0x2f6a, lo: 0x88, hi: 0x88}, - // Block 0x5b, offset 0x281 - {value: 0x0024, lo: 0x90, hi: 0x92}, - {value: 0x0034, lo: 0x94, hi: 0x99}, - {value: 0x0024, lo: 0x9a, hi: 0x9b}, - {value: 0x0034, lo: 0x9c, hi: 0x9f}, - {value: 0x0024, lo: 0xa0, hi: 0xa0}, - {value: 0x0010, lo: 0xa1, hi: 0xa1}, - {value: 0x0034, lo: 0xa2, hi: 0xa8}, - {value: 0x0010, lo: 0xa9, hi: 0xac}, - {value: 0x0034, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xb3}, - {value: 0x0024, lo: 0xb4, hi: 0xb4}, - {value: 0x0010, lo: 0xb5, hi: 0xb6}, - {value: 0x0024, lo: 0xb8, hi: 0xb9}, - // Block 0x5c, offset 0x28e - {value: 0x0012, lo: 0x80, hi: 0xab}, - {value: 0x0015, lo: 0xac, hi: 0xbf}, - // Block 0x5d, offset 0x290 - {value: 0x0015, lo: 0x80, hi: 0xaa}, - {value: 0x0012, lo: 0xab, hi: 0xb7}, - {value: 0x0015, lo: 0xb8, hi: 0xb8}, - {value: 0x8452, lo: 0xb9, hi: 0xb9}, - {value: 0x0012, lo: 0xba, hi: 0xbc}, - {value: 0x8852, lo: 0xbd, hi: 0xbd}, - {value: 0x0012, lo: 0xbe, hi: 0xbf}, - // Block 0x5e, offset 0x297 - {value: 0x0012, lo: 0x80, hi: 0x9a}, - {value: 0x0015, lo: 0x9b, hi: 0xbf}, - // Block 0x5f, offset 0x299 - {value: 0x0024, lo: 0x80, hi: 0x81}, - {value: 0x0034, lo: 0x82, hi: 0x82}, - {value: 0x0024, lo: 0x83, hi: 0x89}, - {value: 0x0034, lo: 0x8a, hi: 0x8a}, - {value: 0x0024, lo: 0x8b, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x90}, - {value: 0x0024, lo: 0x91, hi: 0xb5}, - {value: 0x0024, lo: 0xbb, hi: 0xbb}, - {value: 0x0034, lo: 0xbc, hi: 0xbd}, - {value: 0x0024, lo: 0xbe, hi: 0xbe}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0x60, offset 0x2a4 - {value: 0x0117, lo: 0x80, hi: 0xbf}, - // Block 0x61, offset 0x2a5 - {value: 0x0117, lo: 0x80, hi: 0x95}, - {value: 0x306a, lo: 0x96, hi: 0x96}, - {value: 0x316a, lo: 0x97, hi: 0x97}, - {value: 0x326a, lo: 0x98, hi: 0x98}, - {value: 0x336a, lo: 0x99, hi: 0x99}, - {value: 0x346a, lo: 0x9a, hi: 0x9a}, - {value: 0x356a, lo: 0x9b, hi: 0x9b}, - {value: 0x0012, lo: 0x9c, hi: 0x9d}, - {value: 0x366b, lo: 0x9e, hi: 0x9e}, - {value: 0x0012, lo: 0x9f, hi: 0x9f}, - {value: 0x0117, lo: 0xa0, hi: 0xbf}, - // Block 0x62, offset 0x2b0 - {value: 0x0812, lo: 0x80, hi: 0x87}, - {value: 0x0813, lo: 0x88, hi: 0x8f}, - {value: 0x0812, lo: 0x90, hi: 0x95}, - {value: 0x0813, lo: 0x98, hi: 0x9d}, - {value: 0x0812, lo: 0xa0, hi: 0xa7}, - {value: 0x0813, lo: 0xa8, hi: 0xaf}, - {value: 0x0812, lo: 0xb0, hi: 0xb7}, - {value: 0x0813, lo: 0xb8, hi: 0xbf}, - // Block 0x63, offset 0x2b8 - {value: 0x0004, lo: 0x8b, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8c}, - {value: 0x0004, lo: 0x8d, hi: 0x8d}, - {value: 0x0014, lo: 0x8e, hi: 0x8f}, - {value: 0x0014, lo: 0x98, hi: 0x99}, - {value: 0x0014, lo: 0xa4, hi: 0xa4}, - {value: 0x0014, lo: 0xa7, hi: 0xa7}, - {value: 0x0014, lo: 0xaa, hi: 0xae}, - {value: 0x0010, lo: 0xaf, hi: 0xaf}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x64, offset 0x2c2 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x94, hi: 0x94}, - {value: 0x0014, lo: 0xa0, hi: 0xa4}, - {value: 0x0014, lo: 0xa6, hi: 0xaf}, - {value: 0x0015, lo: 0xb1, hi: 0xb1}, - {value: 0x0015, lo: 0xbf, hi: 0xbf}, - // Block 0x65, offset 0x2c8 - {value: 0x0015, lo: 0x90, hi: 0x9c}, - // Block 0x66, offset 0x2c9 - {value: 0x0024, lo: 0x90, hi: 0x91}, - {value: 0x0034, lo: 0x92, hi: 0x93}, - {value: 0x0024, lo: 0x94, hi: 0x97}, - {value: 0x0034, lo: 0x98, hi: 0x9a}, - {value: 0x0024, lo: 0x9b, hi: 0x9c}, - {value: 0x0014, lo: 0x9d, hi: 0xa0}, - {value: 0x0024, lo: 0xa1, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa4}, - {value: 0x0034, lo: 0xa5, hi: 0xa6}, - {value: 0x0024, lo: 0xa7, hi: 0xa7}, - {value: 0x0034, lo: 0xa8, hi: 0xa8}, - {value: 0x0024, lo: 0xa9, hi: 0xa9}, - {value: 0x0034, lo: 0xaa, hi: 0xaf}, - {value: 0x0024, lo: 0xb0, hi: 0xb0}, - // Block 0x67, offset 0x2d7 - {value: 0x0016, lo: 0x85, hi: 0x86}, - {value: 0x0012, lo: 0x87, hi: 0x89}, - {value: 0x9d52, lo: 0x8e, hi: 0x8e}, - {value: 0x1013, lo: 0xa0, hi: 0xaf}, - {value: 0x1012, lo: 0xb0, hi: 0xbf}, - // Block 0x68, offset 0x2dc - {value: 0x0010, lo: 0x80, hi: 0x82}, - {value: 0x0716, lo: 0x83, hi: 0x84}, - {value: 0x0010, lo: 0x85, hi: 0x88}, - // Block 0x69, offset 0x2df - {value: 0xa053, lo: 0xb6, hi: 0xb7}, - {value: 0xa353, lo: 0xb8, hi: 0xb9}, - {value: 0xa653, lo: 0xba, hi: 0xbb}, - {value: 0xa353, lo: 0xbc, hi: 0xbd}, - {value: 0xa053, lo: 0xbe, hi: 0xbf}, - // Block 0x6a, offset 0x2e4 - {value: 0x3013, lo: 0x80, hi: 0x8f}, - {value: 0x6553, lo: 0x90, hi: 0x9f}, - {value: 0xa953, lo: 0xa0, hi: 0xae}, - {value: 0x3012, lo: 0xb0, hi: 0xbf}, - // Block 0x6b, offset 0x2e8 - {value: 0x0117, lo: 0x80, hi: 0xa3}, - {value: 0x0012, lo: 0xa4, hi: 0xa4}, - {value: 0x0716, lo: 0xab, hi: 0xac}, - {value: 0x0316, lo: 0xad, hi: 0xae}, - {value: 0x0024, lo: 0xaf, hi: 0xb1}, - {value: 0x0117, lo: 0xb2, hi: 0xb3}, - // Block 0x6c, offset 0x2ee - {value: 0x6c52, lo: 0x80, hi: 0x9f}, - {value: 0x7052, lo: 0xa0, hi: 0xa5}, - {value: 0x7052, lo: 0xa7, hi: 0xa7}, - {value: 0x7052, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x6d, offset 0x2f3 - {value: 0x0010, lo: 0x80, hi: 0xa7}, - {value: 0x0014, lo: 0xaf, hi: 0xaf}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0x6e, offset 0x2f6 - {value: 0x0010, lo: 0x80, hi: 0x96}, - {value: 0x0010, lo: 0xa0, hi: 0xa6}, - {value: 0x0010, lo: 0xa8, hi: 0xae}, - {value: 0x0010, lo: 0xb0, hi: 0xb6}, - {value: 0x0010, lo: 0xb8, hi: 0xbe}, - // Block 0x6f, offset 0x2fb - {value: 0x0010, lo: 0x80, hi: 0x86}, - {value: 0x0010, lo: 0x88, hi: 0x8e}, - {value: 0x0010, lo: 0x90, hi: 0x96}, - {value: 0x0010, lo: 0x98, hi: 0x9e}, - {value: 0x0024, lo: 0xa0, hi: 0xbf}, - // Block 0x70, offset 0x300 - {value: 0x0014, lo: 0xaf, hi: 0xaf}, - // Block 0x71, offset 0x301 - {value: 0x0014, lo: 0x85, hi: 0x85}, - {value: 0x0034, lo: 0xaa, hi: 0xad}, - {value: 0x0030, lo: 0xae, hi: 0xaf}, - {value: 0x0004, lo: 0xb1, hi: 0xb5}, - {value: 0x0014, lo: 0xbb, hi: 0xbb}, - {value: 0x0010, lo: 0xbc, hi: 0xbc}, - // Block 0x72, offset 0x307 - {value: 0x0034, lo: 0x99, hi: 0x9a}, - {value: 0x0004, lo: 0x9b, hi: 0x9e}, - // Block 0x73, offset 0x309 - {value: 0x0004, lo: 0xbc, hi: 0xbe}, - // Block 0x74, offset 0x30a - {value: 0x0010, lo: 0x85, hi: 0xad}, - {value: 0x0010, lo: 0xb1, hi: 0xbf}, - // Block 0x75, offset 0x30c - {value: 0x0010, lo: 0x80, hi: 0x8e}, - {value: 0x0010, lo: 0xa0, hi: 0xba}, - // Block 0x76, offset 0x30e - {value: 0x0010, lo: 0x80, hi: 0x94}, - {value: 0x0014, lo: 0x95, hi: 0x95}, - {value: 0x0010, lo: 0x96, hi: 0xbf}, - // Block 0x77, offset 0x311 - {value: 0x0010, lo: 0x80, hi: 0x8c}, - // Block 0x78, offset 0x312 - {value: 0x0010, lo: 0x90, hi: 0xb7}, - {value: 0x0014, lo: 0xb8, hi: 0xbd}, - // Block 0x79, offset 0x314 - {value: 0x0010, lo: 0x80, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8c}, - {value: 0x0010, lo: 0x90, hi: 0xab}, - // Block 0x7a, offset 0x317 - {value: 0x0117, lo: 0x80, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xae}, - {value: 0x0024, lo: 0xaf, hi: 0xaf}, - {value: 0x0014, lo: 0xb0, hi: 0xb2}, - {value: 0x0024, lo: 0xb4, hi: 0xbd}, - {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x7b, offset 0x31d - {value: 0x0117, lo: 0x80, hi: 0x9b}, - {value: 0x0015, lo: 0x9c, hi: 0x9d}, - {value: 0x0024, lo: 0x9e, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0x7c, offset 0x321 - {value: 0x0010, lo: 0x80, hi: 0xaf}, - {value: 0x0024, lo: 0xb0, hi: 0xb1}, - // Block 0x7d, offset 0x323 - {value: 0x0004, lo: 0x80, hi: 0x96}, - {value: 0x0014, lo: 0x97, hi: 0x9f}, - {value: 0x0004, lo: 0xa0, hi: 0xa1}, - {value: 0x0117, lo: 0xa2, hi: 0xaf}, - {value: 0x0012, lo: 0xb0, hi: 0xb1}, - {value: 0x0117, lo: 0xb2, hi: 0xbf}, - // Block 0x7e, offset 0x329 - {value: 0x0117, lo: 0x80, hi: 0xaf}, - {value: 0x0015, lo: 0xb0, hi: 0xb0}, - {value: 0x0012, lo: 0xb1, hi: 0xb8}, - {value: 0x0316, lo: 0xb9, hi: 0xba}, - {value: 0x0716, lo: 0xbb, hi: 0xbc}, - {value: 0x8453, lo: 0xbd, hi: 0xbd}, - {value: 0x0117, lo: 0xbe, hi: 0xbf}, - // Block 0x7f, offset 0x330 - {value: 0x0010, lo: 0xb7, hi: 0xb7}, - {value: 0x0015, lo: 0xb8, hi: 0xb9}, - {value: 0x0012, lo: 0xba, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbf}, - // Block 0x80, offset 0x334 - {value: 0x0010, lo: 0x80, hi: 0x81}, - {value: 0x0014, lo: 0x82, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0x85}, - {value: 0x0034, lo: 0x86, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0x8a}, - {value: 0x0014, lo: 0x8b, hi: 0x8b}, - {value: 0x0010, lo: 0x8c, hi: 0xa4}, - {value: 0x0014, lo: 0xa5, hi: 0xa6}, - {value: 0x0010, lo: 0xa7, hi: 0xa7}, - // Block 0x81, offset 0x33d - {value: 0x0010, lo: 0x80, hi: 0xb3}, - // Block 0x82, offset 0x33e - {value: 0x0010, lo: 0x80, hi: 0x83}, - {value: 0x0034, lo: 0x84, hi: 0x84}, - {value: 0x0014, lo: 0x85, hi: 0x85}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0024, lo: 0xa0, hi: 0xb1}, - {value: 0x0010, lo: 0xb2, hi: 0xb7}, - {value: 0x0010, lo: 0xbb, hi: 0xbb}, - {value: 0x0010, lo: 0xbd, hi: 0xbd}, - // Block 0x83, offset 0x346 - {value: 0x0010, lo: 0x80, hi: 0xa5}, - {value: 0x0014, lo: 0xa6, hi: 0xaa}, - {value: 0x0034, lo: 0xab, hi: 0xad}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x84, offset 0x34a - {value: 0x0010, lo: 0x80, hi: 0x86}, - {value: 0x0014, lo: 0x87, hi: 0x91}, - {value: 0x0010, lo: 0x92, hi: 0x92}, - {value: 0x0030, lo: 0x93, hi: 0x93}, - {value: 0x0010, lo: 0xa0, hi: 0xbc}, - // Block 0x85, offset 0x34f - {value: 0x0014, lo: 0x80, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0xb2}, - {value: 0x0034, lo: 0xb3, hi: 0xb3}, - {value: 0x0010, lo: 0xb4, hi: 0xb5}, - {value: 0x0014, lo: 0xb6, hi: 0xb9}, - {value: 0x0010, lo: 0xba, hi: 0xbb}, - {value: 0x0014, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0x86, offset 0x357 - {value: 0x0030, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x8f, hi: 0x8f}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0014, lo: 0xa5, hi: 0xa5}, - {value: 0x0004, lo: 0xa6, hi: 0xa6}, - {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0x87, offset 0x35d - {value: 0x0010, lo: 0x80, hi: 0xa8}, - {value: 0x0014, lo: 0xa9, hi: 0xae}, - {value: 0x0010, lo: 0xaf, hi: 0xb0}, - {value: 0x0014, lo: 0xb1, hi: 0xb2}, - {value: 0x0010, lo: 0xb3, hi: 0xb4}, - {value: 0x0014, lo: 0xb5, hi: 0xb6}, - // Block 0x88, offset 0x363 - {value: 0x0010, lo: 0x80, hi: 0x82}, - {value: 0x0014, lo: 0x83, hi: 0x83}, - {value: 0x0010, lo: 0x84, hi: 0x8b}, - {value: 0x0014, lo: 0x8c, hi: 0x8c}, - {value: 0x0010, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0004, lo: 0xb0, hi: 0xb0}, - {value: 0x0010, lo: 0xbb, hi: 0xbb}, - {value: 0x0014, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbd}, - // Block 0x89, offset 0x36d - {value: 0x0024, lo: 0xb0, hi: 0xb0}, - {value: 0x0024, lo: 0xb2, hi: 0xb3}, - {value: 0x0034, lo: 0xb4, hi: 0xb4}, - {value: 0x0024, lo: 0xb7, hi: 0xb8}, - {value: 0x0024, lo: 0xbe, hi: 0xbf}, - // Block 0x8a, offset 0x372 - {value: 0x0024, lo: 0x81, hi: 0x81}, - {value: 0x0004, lo: 0x9d, hi: 0x9d}, - {value: 0x0010, lo: 0xa0, hi: 0xab}, - {value: 0x0014, lo: 0xac, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xaf}, - {value: 0x0010, lo: 0xb2, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xb4}, - {value: 0x0010, lo: 0xb5, hi: 0xb5}, - {value: 0x0034, lo: 0xb6, hi: 0xb6}, - // Block 0x8b, offset 0x37b - {value: 0x0010, lo: 0x81, hi: 0x86}, - {value: 0x0010, lo: 0x89, hi: 0x8e}, - {value: 0x0010, lo: 0x91, hi: 0x96}, - {value: 0x0010, lo: 0xa0, hi: 0xa6}, - {value: 0x0010, lo: 0xa8, hi: 0xae}, - {value: 0x0012, lo: 0xb0, hi: 0xbf}, - // Block 0x8c, offset 0x381 - {value: 0x0012, lo: 0x80, hi: 0x92}, - {value: 0xac52, lo: 0x93, hi: 0x93}, - {value: 0x0012, lo: 0x94, hi: 0x9a}, - {value: 0x0004, lo: 0x9b, hi: 0x9b}, - {value: 0x0015, lo: 0x9c, hi: 0x9f}, - {value: 0x0012, lo: 0xa0, hi: 0xa5}, - {value: 0x74d2, lo: 0xb0, hi: 0xbf}, - // Block 0x8d, offset 0x388 - {value: 0x78d2, lo: 0x80, hi: 0x8f}, - {value: 0x7cd2, lo: 0x90, hi: 0x9f}, - {value: 0x80d2, lo: 0xa0, hi: 0xaf}, - {value: 0x7cd2, lo: 0xb0, hi: 0xbf}, - // Block 0x8e, offset 0x38c - {value: 0x0010, lo: 0x80, hi: 0xa4}, - {value: 0x0014, lo: 0xa5, hi: 0xa5}, - {value: 0x0010, lo: 0xa6, hi: 0xa7}, - {value: 0x0014, lo: 0xa8, hi: 0xa8}, - {value: 0x0010, lo: 0xa9, hi: 0xaa}, - {value: 0x0010, lo: 0xac, hi: 0xac}, - {value: 0x0034, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0x8f, offset 0x394 - {value: 0x0010, lo: 0x80, hi: 0xa3}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0x90, offset 0x396 - {value: 0x0010, lo: 0x80, hi: 0x86}, - {value: 0x0010, lo: 0x8b, hi: 0xbb}, - // Block 0x91, offset 0x398 - {value: 0x0010, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x83, hi: 0x84}, - {value: 0x0010, lo: 0x86, hi: 0xbf}, - // Block 0x92, offset 0x39b - {value: 0x0010, lo: 0x80, hi: 0xb1}, - {value: 0x0004, lo: 0xb2, hi: 0xbf}, - // Block 0x93, offset 0x39d - {value: 0x0004, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x93, hi: 0xbf}, - // Block 0x94, offset 0x39f - {value: 0x0010, lo: 0x80, hi: 0xbd}, - // Block 0x95, offset 0x3a0 - {value: 0x0010, lo: 0x90, hi: 0xbf}, - // Block 0x96, offset 0x3a1 - {value: 0x0010, lo: 0x80, hi: 0x8f}, - {value: 0x0010, lo: 0x92, hi: 0xbf}, - // Block 0x97, offset 0x3a3 - {value: 0x0010, lo: 0x80, hi: 0x87}, - {value: 0x0010, lo: 0xb0, hi: 0xbb}, - // Block 0x98, offset 0x3a5 - {value: 0x0014, lo: 0x80, hi: 0x8f}, - {value: 0x0014, lo: 0x93, hi: 0x93}, - {value: 0x0024, lo: 0xa0, hi: 0xa6}, - {value: 0x0034, lo: 0xa7, hi: 0xad}, - {value: 0x0024, lo: 0xae, hi: 0xaf}, - {value: 0x0010, lo: 0xb3, hi: 0xb4}, - // Block 0x99, offset 0x3ab - {value: 0x0010, lo: 0x8d, hi: 0x8f}, - {value: 0x0014, lo: 0x92, hi: 0x92}, - {value: 0x0014, lo: 0x95, hi: 0x95}, - {value: 0x0010, lo: 0xb0, hi: 0xb4}, - {value: 0x0010, lo: 0xb6, hi: 0xbf}, - // Block 0x9a, offset 0x3b0 - {value: 0x0010, lo: 0x80, hi: 0xbc}, - {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0x9b, offset 0x3b2 - {value: 0x0014, lo: 0x87, hi: 0x87}, - {value: 0x0014, lo: 0x8e, hi: 0x8e}, - {value: 0x0014, lo: 0x9a, hi: 0x9a}, - {value: 0x5f53, lo: 0xa1, hi: 0xba}, - {value: 0x0004, lo: 0xbe, hi: 0xbe}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0x9c, offset 0x3b8 - {value: 0x0004, lo: 0x80, hi: 0x80}, - {value: 0x5f52, lo: 0x81, hi: 0x9a}, - {value: 0x0004, lo: 0xb0, hi: 0xb0}, - // Block 0x9d, offset 0x3bb - {value: 0x0014, lo: 0x9e, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xbe}, - // Block 0x9e, offset 0x3bd - {value: 0x0010, lo: 0x82, hi: 0x87}, - {value: 0x0010, lo: 0x8a, hi: 0x8f}, - {value: 0x0010, lo: 0x92, hi: 0x97}, - {value: 0x0010, lo: 0x9a, hi: 0x9c}, - {value: 0x0004, lo: 0xa3, hi: 0xa3}, - {value: 0x0014, lo: 0xb9, hi: 0xbb}, - // Block 0x9f, offset 0x3c3 - {value: 0x0010, lo: 0x80, hi: 0x8b}, - {value: 0x0010, lo: 0x8d, hi: 0xa6}, - {value: 0x0010, lo: 0xa8, hi: 0xba}, - {value: 0x0010, lo: 0xbc, hi: 0xbd}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xa0, offset 0x3c8 - {value: 0x0010, lo: 0x80, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x9d}, - // Block 0xa1, offset 0x3ca - {value: 0x0010, lo: 0x80, hi: 0xba}, - // Block 0xa2, offset 0x3cb - {value: 0x0010, lo: 0x80, hi: 0xb4}, - // Block 0xa3, offset 0x3cc - {value: 0x0034, lo: 0xbd, hi: 0xbd}, - // Block 0xa4, offset 0x3cd - {value: 0x0010, lo: 0x80, hi: 0x9c}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0xa5, offset 0x3cf - {value: 0x0010, lo: 0x80, hi: 0x90}, - {value: 0x0034, lo: 0xa0, hi: 0xa0}, - // Block 0xa6, offset 0x3d1 - {value: 0x0010, lo: 0x80, hi: 0x9f}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xa7, offset 0x3d3 - {value: 0x0010, lo: 0x80, hi: 0x8a}, - {value: 0x0010, lo: 0x90, hi: 0xb5}, - {value: 0x0024, lo: 0xb6, hi: 0xba}, - // Block 0xa8, offset 0x3d6 - {value: 0x0010, lo: 0x80, hi: 0x9d}, - {value: 0x0010, lo: 0xa0, hi: 0xbf}, - // Block 0xa9, offset 0x3d8 - {value: 0x0010, lo: 0x80, hi: 0x83}, - {value: 0x0010, lo: 0x88, hi: 0x8f}, - {value: 0x0010, lo: 0x91, hi: 0x95}, - // Block 0xaa, offset 0x3db - {value: 0x2813, lo: 0x80, hi: 0x87}, - {value: 0x3813, lo: 0x88, hi: 0x8f}, - {value: 0x2813, lo: 0x90, hi: 0x97}, - {value: 0xaf53, lo: 0x98, hi: 0x9f}, - {value: 0xb253, lo: 0xa0, hi: 0xa7}, - {value: 0x2812, lo: 0xa8, hi: 0xaf}, - {value: 0x3812, lo: 0xb0, hi: 0xb7}, - {value: 0x2812, lo: 0xb8, hi: 0xbf}, - // Block 0xab, offset 0x3e3 - {value: 0xaf52, lo: 0x80, hi: 0x87}, - {value: 0xb252, lo: 0x88, hi: 0x8f}, - {value: 0x0010, lo: 0x90, hi: 0xbf}, - // Block 0xac, offset 0x3e6 - {value: 0x0010, lo: 0x80, hi: 0x9d}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - {value: 0xb253, lo: 0xb0, hi: 0xb7}, - {value: 0xaf53, lo: 0xb8, hi: 0xbf}, - // Block 0xad, offset 0x3ea - {value: 0x2813, lo: 0x80, hi: 0x87}, - {value: 0x3813, lo: 0x88, hi: 0x8f}, - {value: 0x2813, lo: 0x90, hi: 0x93}, - {value: 0xb252, lo: 0x98, hi: 0x9f}, - {value: 0xaf52, lo: 0xa0, hi: 0xa7}, - {value: 0x2812, lo: 0xa8, hi: 0xaf}, - {value: 0x3812, lo: 0xb0, hi: 0xb7}, - {value: 0x2812, lo: 0xb8, hi: 0xbb}, - // Block 0xae, offset 0x3f2 - {value: 0x0010, lo: 0x80, hi: 0xa7}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xaf, offset 0x3f4 - {value: 0x0010, lo: 0x80, hi: 0xa3}, - // Block 0xb0, offset 0x3f5 - {value: 0x0010, lo: 0x80, hi: 0xb6}, - // Block 0xb1, offset 0x3f6 - {value: 0x0010, lo: 0x80, hi: 0x95}, - {value: 0x0010, lo: 0xa0, hi: 0xa7}, - // Block 0xb2, offset 0x3f8 - {value: 0x0010, lo: 0x80, hi: 0x85}, - {value: 0x0010, lo: 0x88, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0xb5}, - {value: 0x0010, lo: 0xb7, hi: 0xb8}, - {value: 0x0010, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xb3, offset 0x3fe - {value: 0x0010, lo: 0x80, hi: 0x95}, - {value: 0x0010, lo: 0xa0, hi: 0xb6}, - // Block 0xb4, offset 0x400 - {value: 0x0010, lo: 0x80, hi: 0x9e}, - // Block 0xb5, offset 0x401 - {value: 0x0010, lo: 0xa0, hi: 0xb2}, - {value: 0x0010, lo: 0xb4, hi: 0xb5}, - // Block 0xb6, offset 0x403 - {value: 0x0010, lo: 0x80, hi: 0x95}, - {value: 0x0010, lo: 0xa0, hi: 0xb9}, - // Block 0xb7, offset 0x405 - {value: 0x0010, lo: 0x80, hi: 0xb7}, - {value: 0x0010, lo: 0xbe, hi: 0xbf}, - // Block 0xb8, offset 0x407 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x83}, - {value: 0x0014, lo: 0x85, hi: 0x86}, - {value: 0x0014, lo: 0x8c, hi: 0x8c}, - {value: 0x0034, lo: 0x8d, hi: 0x8d}, - {value: 0x0014, lo: 0x8e, hi: 0x8e}, - {value: 0x0024, lo: 0x8f, hi: 0x8f}, - {value: 0x0010, lo: 0x90, hi: 0x93}, - {value: 0x0010, lo: 0x95, hi: 0x97}, - {value: 0x0010, lo: 0x99, hi: 0xb3}, - {value: 0x0024, lo: 0xb8, hi: 0xb8}, - {value: 0x0034, lo: 0xb9, hi: 0xba}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xb9, offset 0x414 - {value: 0x0010, lo: 0xa0, hi: 0xbc}, - // Block 0xba, offset 0x415 - {value: 0x0010, lo: 0x80, hi: 0x9c}, - // Block 0xbb, offset 0x416 - {value: 0x0010, lo: 0x80, hi: 0x87}, - {value: 0x0010, lo: 0x89, hi: 0xa4}, - {value: 0x0024, lo: 0xa5, hi: 0xa5}, - {value: 0x0034, lo: 0xa6, hi: 0xa6}, - // Block 0xbc, offset 0x41a - {value: 0x0010, lo: 0x80, hi: 0x95}, - {value: 0x0010, lo: 0xa0, hi: 0xb2}, - // Block 0xbd, offset 0x41c - {value: 0x0010, lo: 0x80, hi: 0x91}, - // Block 0xbe, offset 0x41d - {value: 0x0010, lo: 0x80, hi: 0x88}, - // Block 0xbf, offset 0x41e - {value: 0x5653, lo: 0x80, hi: 0xb2}, - // Block 0xc0, offset 0x41f - {value: 0x5652, lo: 0x80, hi: 0xb2}, - // Block 0xc1, offset 0x420 - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0xb7}, - {value: 0x0014, lo: 0xb8, hi: 0xbf}, - // Block 0xc2, offset 0x424 - {value: 0x0014, lo: 0x80, hi: 0x85}, - {value: 0x0034, lo: 0x86, hi: 0x86}, - {value: 0x0010, lo: 0xa6, hi: 0xaf}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xc3, offset 0x428 - {value: 0x0014, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xb6}, - {value: 0x0010, lo: 0xb7, hi: 0xb8}, - {value: 0x0034, lo: 0xb9, hi: 0xba}, - {value: 0x0014, lo: 0xbd, hi: 0xbd}, - // Block 0xc4, offset 0x42e - {value: 0x0010, lo: 0x90, hi: 0xa8}, - {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xc5, offset 0x430 - {value: 0x0024, lo: 0x80, hi: 0x82}, - {value: 0x0010, lo: 0x83, hi: 0xa6}, - {value: 0x0014, lo: 0xa7, hi: 0xab}, - {value: 0x0010, lo: 0xac, hi: 0xac}, - {value: 0x0014, lo: 0xad, hi: 0xb2}, - {value: 0x0034, lo: 0xb3, hi: 0xb4}, - {value: 0x0010, lo: 0xb6, hi: 0xbf}, - // Block 0xc6, offset 0x437 - {value: 0x0010, lo: 0x90, hi: 0xb2}, - {value: 0x0034, lo: 0xb3, hi: 0xb3}, - {value: 0x0010, lo: 0xb6, hi: 0xb6}, - // Block 0xc7, offset 0x43a - {value: 0x0014, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0xb5}, - {value: 0x0014, lo: 0xb6, hi: 0xbe}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xc8, offset 0x43e - {value: 0x0030, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x84}, - {value: 0x0034, lo: 0x8a, hi: 0x8a}, - {value: 0x0014, lo: 0x8b, hi: 0x8c}, - {value: 0x0010, lo: 0x90, hi: 0x9a}, - {value: 0x0010, lo: 0x9c, hi: 0x9c}, - // Block 0xc9, offset 0x444 - {value: 0x0010, lo: 0x80, hi: 0x91}, - {value: 0x0010, lo: 0x93, hi: 0xae}, - {value: 0x0014, lo: 0xaf, hi: 0xb1}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - {value: 0x0014, lo: 0xb4, hi: 0xb4}, - {value: 0x0030, lo: 0xb5, hi: 0xb5}, - {value: 0x0034, lo: 0xb6, hi: 0xb6}, - {value: 0x0014, lo: 0xb7, hi: 0xb7}, - {value: 0x0014, lo: 0xbe, hi: 0xbe}, - // Block 0xca, offset 0x44d - {value: 0x0010, lo: 0x80, hi: 0x86}, - {value: 0x0010, lo: 0x88, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0x8d}, - {value: 0x0010, lo: 0x8f, hi: 0x9d}, - {value: 0x0010, lo: 0x9f, hi: 0xa8}, - {value: 0x0010, lo: 0xb0, hi: 0xbf}, - // Block 0xcb, offset 0x453 - {value: 0x0010, lo: 0x80, hi: 0x9e}, - {value: 0x0014, lo: 0x9f, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xa2}, - {value: 0x0014, lo: 0xa3, hi: 0xa8}, - {value: 0x0034, lo: 0xa9, hi: 0xaa}, - {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xcc, offset 0x459 - {value: 0x0014, lo: 0x80, hi: 0x81}, - {value: 0x0010, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x8c}, - {value: 0x0010, lo: 0x8f, hi: 0x90}, - {value: 0x0010, lo: 0x93, hi: 0xa8}, - {value: 0x0010, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb2, hi: 0xb3}, - {value: 0x0010, lo: 0xb5, hi: 0xb9}, - {value: 0x0034, lo: 0xbc, hi: 0xbc}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0xcd, offset 0x463 - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x84}, - {value: 0x0010, lo: 0x87, hi: 0x88}, - {value: 0x0010, lo: 0x8b, hi: 0x8c}, - {value: 0x0030, lo: 0x8d, hi: 0x8d}, - {value: 0x0010, lo: 0x90, hi: 0x90}, - {value: 0x0010, lo: 0x97, hi: 0x97}, - {value: 0x0010, lo: 0x9d, hi: 0xa3}, - {value: 0x0024, lo: 0xa6, hi: 0xac}, - {value: 0x0024, lo: 0xb0, hi: 0xb4}, - // Block 0xce, offset 0x46d - {value: 0x0010, lo: 0x80, hi: 0xb7}, - {value: 0x0014, lo: 0xb8, hi: 0xbf}, - // Block 0xcf, offset 0x46f - {value: 0x0010, lo: 0x80, hi: 0x81}, - {value: 0x0034, lo: 0x82, hi: 0x82}, - {value: 0x0014, lo: 0x83, hi: 0x84}, - {value: 0x0010, lo: 0x85, hi: 0x85}, - {value: 0x0034, lo: 0x86, hi: 0x86}, - {value: 0x0010, lo: 0x87, hi: 0x8a}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd0, offset 0x476 - {value: 0x0010, lo: 0x80, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xb8}, - {value: 0x0010, lo: 0xb9, hi: 0xb9}, - {value: 0x0014, lo: 0xba, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbe}, - {value: 0x0014, lo: 0xbf, hi: 0xbf}, - // Block 0xd1, offset 0x47c - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x81, hi: 0x81}, - {value: 0x0034, lo: 0x82, hi: 0x83}, - {value: 0x0010, lo: 0x84, hi: 0x85}, - {value: 0x0010, lo: 0x87, hi: 0x87}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd2, offset 0x482 - {value: 0x0010, lo: 0x80, hi: 0xb1}, - {value: 0x0014, lo: 0xb2, hi: 0xb5}, - {value: 0x0010, lo: 0xb8, hi: 0xbb}, - {value: 0x0014, lo: 0xbc, hi: 0xbd}, - {value: 0x0010, lo: 0xbe, hi: 0xbe}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xd3, offset 0x488 - {value: 0x0034, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x98, hi: 0x9b}, - {value: 0x0014, lo: 0x9c, hi: 0x9d}, - // Block 0xd4, offset 0x48b - {value: 0x0010, lo: 0x80, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xba}, - {value: 0x0010, lo: 0xbb, hi: 0xbc}, - {value: 0x0014, lo: 0xbd, hi: 0xbd}, - {value: 0x0010, lo: 0xbe, hi: 0xbe}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xd5, offset 0x491 - {value: 0x0014, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x84, hi: 0x84}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0xd6, offset 0x494 - {value: 0x0010, lo: 0x80, hi: 0xaa}, - {value: 0x0014, lo: 0xab, hi: 0xab}, - {value: 0x0010, lo: 0xac, hi: 0xac}, - {value: 0x0014, lo: 0xad, hi: 0xad}, - {value: 0x0010, lo: 0xae, hi: 0xaf}, - {value: 0x0014, lo: 0xb0, hi: 0xb5}, - {value: 0x0030, lo: 0xb6, hi: 0xb6}, - {value: 0x0034, lo: 0xb7, hi: 0xb7}, - // Block 0xd7, offset 0x49c - {value: 0x0010, lo: 0x80, hi: 0x89}, - // Block 0xd8, offset 0x49d - {value: 0x0014, lo: 0x9d, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xa1}, - {value: 0x0014, lo: 0xa2, hi: 0xa5}, - {value: 0x0010, lo: 0xa6, hi: 0xa6}, - {value: 0x0014, lo: 0xa7, hi: 0xaa}, - {value: 0x0034, lo: 0xab, hi: 0xab}, - {value: 0x0010, lo: 0xb0, hi: 0xb9}, - // Block 0xd9, offset 0x4a4 - {value: 0x5f53, lo: 0xa0, hi: 0xbf}, - // Block 0xda, offset 0x4a5 - {value: 0x5f52, lo: 0x80, hi: 0x9f}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - {value: 0x0010, lo: 0xbf, hi: 0xbf}, - // Block 0xdb, offset 0x4a8 - {value: 0x0010, lo: 0x80, hi: 0xb8}, - // Block 0xdc, offset 0x4a9 - {value: 0x0010, lo: 0x80, hi: 0x88}, - {value: 0x0010, lo: 0x8a, hi: 0xaf}, - {value: 0x0014, lo: 0xb0, hi: 0xb6}, - {value: 0x0014, lo: 0xb8, hi: 0xbd}, - {value: 0x0010, lo: 0xbe, hi: 0xbe}, - {value: 0x0034, lo: 0xbf, hi: 0xbf}, - // Block 0xdd, offset 0x4af - {value: 0x0010, lo: 0x80, hi: 0x80}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0010, lo: 0xb2, hi: 0xbf}, - // Block 0xde, offset 0x4b2 - {value: 0x0010, lo: 0x80, hi: 0x8f}, - {value: 0x0014, lo: 0x92, hi: 0xa7}, - {value: 0x0010, lo: 0xa9, hi: 0xa9}, - {value: 0x0014, lo: 0xaa, hi: 0xb0}, - {value: 0x0010, lo: 0xb1, hi: 0xb1}, - {value: 0x0014, lo: 0xb2, hi: 0xb3}, - {value: 0x0010, lo: 0xb4, hi: 0xb4}, - {value: 0x0014, lo: 0xb5, hi: 0xb6}, - // Block 0xdf, offset 0x4ba - {value: 0x0010, lo: 0x80, hi: 0x99}, - // Block 0xe0, offset 0x4bb - {value: 0x0010, lo: 0x80, hi: 0xae}, - // Block 0xe1, offset 0x4bc - {value: 0x0010, lo: 0x80, hi: 0x83}, - // Block 0xe2, offset 0x4bd - {value: 0x0010, lo: 0x80, hi: 0x86}, - // Block 0xe3, offset 0x4be - {value: 0x0010, lo: 0x80, hi: 0x9e}, - {value: 0x0010, lo: 0xa0, hi: 0xa9}, - // Block 0xe4, offset 0x4c0 - {value: 0x0010, lo: 0x90, hi: 0xad}, - {value: 0x0034, lo: 0xb0, hi: 0xb4}, - // Block 0xe5, offset 0x4c2 - {value: 0x0010, lo: 0x80, hi: 0xaf}, - {value: 0x0024, lo: 0xb0, hi: 0xb6}, - // Block 0xe6, offset 0x4c4 - {value: 0x0014, lo: 0x80, hi: 0x83}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0010, lo: 0xa3, hi: 0xb7}, - {value: 0x0010, lo: 0xbd, hi: 0xbf}, - // Block 0xe7, offset 0x4c8 - {value: 0x0010, lo: 0x80, hi: 0x8f}, - // Block 0xe8, offset 0x4c9 - {value: 0x0010, lo: 0x80, hi: 0x84}, - {value: 0x0010, lo: 0x90, hi: 0xbe}, - // Block 0xe9, offset 0x4cb - {value: 0x0014, lo: 0x8f, hi: 0x9f}, - // Block 0xea, offset 0x4cc - {value: 0x0014, lo: 0xa0, hi: 0xa0}, - // Block 0xeb, offset 0x4cd - {value: 0x0010, lo: 0x80, hi: 0xaa}, - {value: 0x0010, lo: 0xb0, hi: 0xbc}, - // Block 0xec, offset 0x4cf - {value: 0x0010, lo: 0x80, hi: 0x88}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - {value: 0x0014, lo: 0x9d, hi: 0x9d}, - {value: 0x0034, lo: 0x9e, hi: 0x9e}, - {value: 0x0014, lo: 0xa0, hi: 0xa3}, - // Block 0xed, offset 0x4d4 - {value: 0x0030, lo: 0xa5, hi: 0xa6}, - {value: 0x0034, lo: 0xa7, hi: 0xa9}, - {value: 0x0030, lo: 0xad, hi: 0xb2}, - {value: 0x0014, lo: 0xb3, hi: 0xba}, - {value: 0x0034, lo: 0xbb, hi: 0xbf}, - // Block 0xee, offset 0x4d9 - {value: 0x0034, lo: 0x80, hi: 0x82}, - {value: 0x0024, lo: 0x85, hi: 0x89}, - {value: 0x0034, lo: 0x8a, hi: 0x8b}, - {value: 0x0024, lo: 0xaa, hi: 0xad}, - // Block 0xef, offset 0x4dd - {value: 0x0024, lo: 0x82, hi: 0x84}, - // Block 0xf0, offset 0x4de - {value: 0x0013, lo: 0x80, hi: 0x99}, - {value: 0x0012, lo: 0x9a, hi: 0xb3}, - {value: 0x0013, lo: 0xb4, hi: 0xbf}, - // Block 0xf1, offset 0x4e1 - {value: 0x0013, lo: 0x80, hi: 0x8d}, - {value: 0x0012, lo: 0x8e, hi: 0x94}, - {value: 0x0012, lo: 0x96, hi: 0xa7}, - {value: 0x0013, lo: 0xa8, hi: 0xbf}, - // Block 0xf2, offset 0x4e5 - {value: 0x0013, lo: 0x80, hi: 0x81}, - {value: 0x0012, lo: 0x82, hi: 0x9b}, - {value: 0x0013, lo: 0x9c, hi: 0x9c}, - {value: 0x0013, lo: 0x9e, hi: 0x9f}, - {value: 0x0013, lo: 0xa2, hi: 0xa2}, - {value: 0x0013, lo: 0xa5, hi: 0xa6}, - {value: 0x0013, lo: 0xa9, hi: 0xac}, - {value: 0x0013, lo: 0xae, hi: 0xb5}, - {value: 0x0012, lo: 0xb6, hi: 0xb9}, - {value: 0x0012, lo: 0xbb, hi: 0xbb}, - {value: 0x0012, lo: 0xbd, hi: 0xbf}, - // Block 0xf3, offset 0x4f0 - {value: 0x0012, lo: 0x80, hi: 0x83}, - {value: 0x0012, lo: 0x85, hi: 0x8f}, - {value: 0x0013, lo: 0x90, hi: 0xa9}, - {value: 0x0012, lo: 0xaa, hi: 0xbf}, - // Block 0xf4, offset 0x4f4 - {value: 0x0012, lo: 0x80, hi: 0x83}, - {value: 0x0013, lo: 0x84, hi: 0x85}, - {value: 0x0013, lo: 0x87, hi: 0x8a}, - {value: 0x0013, lo: 0x8d, hi: 0x94}, - {value: 0x0013, lo: 0x96, hi: 0x9c}, - {value: 0x0012, lo: 0x9e, hi: 0xb7}, - {value: 0x0013, lo: 0xb8, hi: 0xb9}, - {value: 0x0013, lo: 0xbb, hi: 0xbe}, - // Block 0xf5, offset 0x4fc - {value: 0x0013, lo: 0x80, hi: 0x84}, - {value: 0x0013, lo: 0x86, hi: 0x86}, - {value: 0x0013, lo: 0x8a, hi: 0x90}, - {value: 0x0012, lo: 0x92, hi: 0xab}, - {value: 0x0013, lo: 0xac, hi: 0xbf}, - // Block 0xf6, offset 0x501 - {value: 0x0013, lo: 0x80, hi: 0x85}, - {value: 0x0012, lo: 0x86, hi: 0x9f}, - {value: 0x0013, lo: 0xa0, hi: 0xb9}, - {value: 0x0012, lo: 0xba, hi: 0xbf}, - // Block 0xf7, offset 0x505 - {value: 0x0012, lo: 0x80, hi: 0x93}, - {value: 0x0013, lo: 0x94, hi: 0xad}, - {value: 0x0012, lo: 0xae, hi: 0xbf}, - // Block 0xf8, offset 0x508 - {value: 0x0012, lo: 0x80, hi: 0x87}, - {value: 0x0013, lo: 0x88, hi: 0xa1}, - {value: 0x0012, lo: 0xa2, hi: 0xbb}, - {value: 0x0013, lo: 0xbc, hi: 0xbf}, - // Block 0xf9, offset 0x50c - {value: 0x0013, lo: 0x80, hi: 0x95}, - {value: 0x0012, lo: 0x96, hi: 0xaf}, - {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0xfa, offset 0x50f - {value: 0x0013, lo: 0x80, hi: 0x89}, - {value: 0x0012, lo: 0x8a, hi: 0xa5}, - {value: 0x0013, lo: 0xa8, hi: 0xbf}, - // Block 0xfb, offset 0x512 - {value: 0x0013, lo: 0x80, hi: 0x80}, - {value: 0x0012, lo: 0x82, hi: 0x9a}, - {value: 0x0012, lo: 0x9c, hi: 0xa1}, - {value: 0x0013, lo: 0xa2, hi: 0xba}, - {value: 0x0012, lo: 0xbc, hi: 0xbf}, - // Block 0xfc, offset 0x517 - {value: 0x0012, lo: 0x80, hi: 0x94}, - {value: 0x0012, lo: 0x96, hi: 0x9b}, - {value: 0x0013, lo: 0x9c, hi: 0xb4}, - {value: 0x0012, lo: 0xb6, hi: 0xbf}, - // Block 0xfd, offset 0x51b - {value: 0x0012, lo: 0x80, hi: 0x8e}, - {value: 0x0012, lo: 0x90, hi: 0x95}, - {value: 0x0013, lo: 0x96, hi: 0xae}, - {value: 0x0012, lo: 0xb0, hi: 0xbf}, - // Block 0xfe, offset 0x51f - {value: 0x0012, lo: 0x80, hi: 0x88}, - {value: 0x0012, lo: 0x8a, hi: 0x8f}, - {value: 0x0013, lo: 0x90, hi: 0xa8}, - {value: 0x0012, lo: 0xaa, hi: 0xbf}, - // Block 0xff, offset 0x523 - {value: 0x0012, lo: 0x80, hi: 0x82}, - {value: 0x0012, lo: 0x84, hi: 0x89}, - {value: 0x0017, lo: 0x8a, hi: 0x8b}, - {value: 0x0010, lo: 0x8e, hi: 0xbf}, - // Block 0x100, offset 0x527 - {value: 0x0014, lo: 0x80, hi: 0xb6}, - {value: 0x0014, lo: 0xbb, hi: 0xbf}, - // Block 0x101, offset 0x529 - {value: 0x0014, lo: 0x80, hi: 0xac}, - {value: 0x0014, lo: 0xb5, hi: 0xb5}, - // Block 0x102, offset 0x52b - {value: 0x0014, lo: 0x84, hi: 0x84}, - {value: 0x0014, lo: 0x9b, hi: 0x9f}, - {value: 0x0014, lo: 0xa1, hi: 0xaf}, - // Block 0x103, offset 0x52e - {value: 0x0024, lo: 0x80, hi: 0x86}, - {value: 0x0024, lo: 0x88, hi: 0x98}, - {value: 0x0024, lo: 0x9b, hi: 0xa1}, - {value: 0x0024, lo: 0xa3, hi: 0xa4}, - {value: 0x0024, lo: 0xa6, hi: 0xaa}, - // Block 0x104, offset 0x533 - {value: 0x0010, lo: 0x80, hi: 0x84}, - {value: 0x0034, lo: 0x90, hi: 0x96}, - // Block 0x105, offset 0x535 - {value: 0xb552, lo: 0x80, hi: 0x81}, - {value: 0xb852, lo: 0x82, hi: 0x83}, - {value: 0x0024, lo: 0x84, hi: 0x89}, - {value: 0x0034, lo: 0x8a, hi: 0x8a}, - {value: 0x0010, lo: 0x90, hi: 0x99}, - // Block 0x106, offset 0x53a - {value: 0x0010, lo: 0x80, hi: 0x83}, - {value: 0x0010, lo: 0x85, hi: 0x9f}, - {value: 0x0010, lo: 0xa1, hi: 0xa2}, - {value: 0x0010, lo: 0xa4, hi: 0xa4}, - {value: 0x0010, lo: 0xa7, hi: 0xa7}, - {value: 0x0010, lo: 0xa9, hi: 0xb2}, - {value: 0x0010, lo: 0xb4, hi: 0xb7}, - {value: 0x0010, lo: 0xb9, hi: 0xb9}, - {value: 0x0010, lo: 0xbb, hi: 0xbb}, - // Block 0x107, offset 0x543 - {value: 0x0010, lo: 0x80, hi: 0x89}, - {value: 0x0010, lo: 0x8b, hi: 0x9b}, - {value: 0x0010, lo: 0xa1, hi: 0xa3}, - {value: 0x0010, lo: 0xa5, hi: 0xa9}, - {value: 0x0010, lo: 0xab, hi: 0xbb}, - // Block 0x108, offset 0x548 - {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0x109, offset 0x549 - {value: 0x0013, lo: 0x80, hi: 0x89}, - {value: 0x0013, lo: 0x90, hi: 0xa9}, - {value: 0x0013, lo: 0xb0, hi: 0xbf}, - // Block 0x10a, offset 0x54c - {value: 0x0013, lo: 0x80, hi: 0x89}, - // Block 0x10b, offset 0x54d - {value: 0x0004, lo: 0xbb, hi: 0xbf}, - // Block 0x10c, offset 0x54e - {value: 0x0014, lo: 0x81, hi: 0x81}, - {value: 0x0014, lo: 0xa0, hi: 0xbf}, - // Block 0x10d, offset 0x550 - {value: 0x0014, lo: 0x80, hi: 0xbf}, - // Block 0x10e, offset 0x551 - {value: 0x0014, lo: 0x80, hi: 0xaf}, -} - -// Total table size 13819 bytes (13KiB); checksum: 4CC48DA3 diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/trieval.go deleted file mode 100644 index 7f2aa5b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/cases/trieval.go +++ /dev/null @@ -1,213 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package cases - -// This file contains definitions for interpreting the trie value of the case -// trie generated by "go run gen*.go". It is shared by both the generator -// program and the resultant package. Sharing is achieved by the generator -// copying gen_trieval.go to trieval.go and changing what's above this comment. - -// info holds case information for a single rune. It is the value returned -// by a trie lookup. Most mapping information can be stored in a single 16-bit -// value. If not, for example when a rune is mapped to multiple runes, the value -// stores some basic case data and an index into an array with additional data. -// -// The per-rune values have the following format: -// -// if (exception) { -// 15..5 unsigned exception index -// 4 unused -// } else { -// 15..8 XOR pattern or index to XOR pattern for case mapping -// Only 13..8 are used for XOR patterns. -// 7 inverseFold (fold to upper, not to lower) -// 6 index: interpret the XOR pattern as an index -// 5..4 CCC: zero (normal or break), above or other -// } -// 3 exception: interpret this value as an exception index -// (TODO: is this bit necessary? Probably implied from case mode.) -// 2..0 case mode -// -// For the non-exceptional cases, a rune must be either uncased, lowercase or -// uppercase. If the rune is cased, the XOR pattern maps either a lowercase -// rune to uppercase or an uppercase rune to lowercase (applied to the 10 -// least-significant bits of the rune). -// -// See the definitions below for a more detailed description of the various -// bits. -type info uint16 - -const ( - casedMask = 0x0003 - fullCasedMask = 0x0007 - ignorableMask = 0x0006 - ignorableValue = 0x0004 - - inverseFoldBit = 1 << 7 - - exceptionBit = 1 << 3 - exceptionShift = 5 - numExceptionBits = 11 - - xorIndexBit = 1 << 6 - xorShift = 8 - - // There is no mapping if all xor bits and the exception bit are zero. - hasMappingMask = 0xffc0 | exceptionBit -) - -// The case mode bits encodes the case type of a rune. This includes uncased, -// title, upper and lower case and case ignorable. (For a definition of these -// terms see Chapter 3 of The Unicode Standard Core Specification.) In some rare -// cases, a rune can be both cased and case-ignorable. This is encoded by -// cIgnorableCased. A rune of this type is always lower case. Some runes are -// cased while not having a mapping. -// -// A common pattern for scripts in the Unicode standard is for upper and lower -// case runes to alternate for increasing rune values (e.g. the accented Latin -// ranges starting from U+0100 and U+1E00 among others and some Cyrillic -// characters). We use this property by defining a cXORCase mode, where the case -// mode (always upper or lower case) is derived from the rune value. As the XOR -// pattern for case mappings is often identical for successive runes, using -// cXORCase can result in large series of identical trie values. This, in turn, -// allows us to better compress the trie blocks. -const ( - cUncased info = iota // 000 - cTitle // 001 - cLower // 010 - cUpper // 011 - cIgnorableUncased // 100 - cIgnorableCased // 101 // lower case if mappings exist - cXORCase // 11x // case is cLower | ((rune&1) ^ x) - - maxCaseMode = cUpper -) - -func (c info) isCased() bool { - return c&casedMask != 0 -} - -func (c info) isCaseIgnorable() bool { - return c&ignorableMask == ignorableValue -} - -func (c info) isCaseIgnorableAndNonBreakStarter() bool { - return c&(fullCasedMask|cccMask) == (ignorableValue | cccZero) -} - -func (c info) isNotCasedAndNotCaseIgnorable() bool { - return c&fullCasedMask == 0 -} - -func (c info) isCaseIgnorableAndNotCased() bool { - return c&fullCasedMask == cIgnorableUncased -} - -// The case mapping implementation will need to know about various Canonical -// Combining Class (CCC) values. We encode two of these in the trie value: -// cccZero (0) and cccAbove (230). If the value is cccOther, it means that -// CCC(r) > 0, but not 230. A value of cccBreak means that CCC(r) == 0 and that -// the rune also has the break category Break (see below). -const ( - cccBreak info = iota << 4 - cccZero - cccAbove - cccOther - - cccMask = cccBreak | cccZero | cccAbove | cccOther -) - -const ( - starter = 0 - above = 230 - iotaSubscript = 240 -) - -// The exceptions slice holds data that does not fit in a normal info entry. -// The entry is pointed to by the exception index in an entry. It has the -// following format: -// -// Header -// byte 0: -// 7..6 unused -// 5..4 CCC type (same bits as entry) -// 3 unused -// 2..0 length of fold -// -// byte 1: -// 7..6 unused -// 5..3 length of 1st mapping of case type -// 2..0 length of 2nd mapping of case type -// -// case 1st 2nd -// lower -> upper, title -// upper -> lower, title -// title -> lower, upper -// -// Lengths with the value 0x7 indicate no value and implies no change. -// A length of 0 indicates a mapping to zero-length string. -// -// Body bytes: -// case folding bytes -// lowercase mapping bytes -// uppercase mapping bytes -// titlecase mapping bytes -// closure mapping bytes (for NFKC_Casefold). (TODO) -// -// Fallbacks: -// missing fold -> lower -// missing title -> upper -// all missing -> original rune -// -// exceptions starts with a dummy byte to enforce that there is no zero index -// value. -const ( - lengthMask = 0x07 - lengthBits = 3 - noChange = 0 -) - -// References to generated trie. - -var trie = newCaseTrie(0) - -var sparse = sparseBlocks{ - values: sparseValues[:], - offsets: sparseOffsets[:], -} - -// Sparse block lookup code. - -// valueRange is an entry in a sparse block. -type valueRange struct { - value uint16 - lo, hi byte -} - -type sparseBlocks struct { - values []valueRange - offsets []uint16 -} - -// lookup returns the value from values block n for byte b using binary search. -func (s *sparseBlocks) lookup(n uint32, b byte) uint16 { - lo := s.offsets[n] - hi := s.offsets[n+1] - for lo < hi { - m := lo + (hi-lo)/2 - r := s.values[m] - if r.lo <= b && b <= r.hi { - return r.value - } - if b < r.lo { - hi = m - } else { - lo = m + 1 - } - } - return 0 -} - -// lastRuneForTesting is the last rune used for testing. Everything after this -// is boring. -const lastRuneForTesting = rune(0x1FFFF) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/Makefile b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/Makefile deleted file mode 100644 index 79f0057..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/Makefile +++ /dev/null @@ -1,16 +0,0 @@ -# Copyright 2013 The Go Authors. All rights reserved. -# Use of this source code is governed by a BSD-style -# license that can be found in the LICENSE file. - -CLEANFILES+=maketables - -maketables: maketables.go - go build $^ - -tables: maketables - ./maketables > tables.go - gofmt -w -s tables.go - -# Build (but do not run) maketables during testing, -# just to make sure it still compiles. -testshort: maketables diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/common.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/common.go deleted file mode 100644 index a255bb0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/common.go +++ /dev/null @@ -1,16 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package language - -// This file contains code common to the maketables.go and the package code. - -// langAliasType is the type of an alias in langAliasMap. -type langAliasType int8 - -const ( - langDeprecated langAliasType = iota - langMacro - langLegacy - - langAliasTypeUnknown langAliasType = -1 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/coverage.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/coverage.go deleted file mode 100644 index 101fd23..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/coverage.go +++ /dev/null @@ -1,197 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package language - -import ( - "fmt" - "sort" -) - -// The Coverage interface is used to define the level of coverage of an -// internationalization service. Note that not all types are supported by all -// services. As lists may be generated on the fly, it is recommended that users -// of a Coverage cache the results. -type Coverage interface { - // Tags returns the list of supported tags. - Tags() []Tag - - // BaseLanguages returns the list of supported base languages. - BaseLanguages() []Base - - // Scripts returns the list of supported scripts. - Scripts() []Script - - // Regions returns the list of supported regions. - Regions() []Region -} - -var ( - // Supported defines a Coverage that lists all supported subtags. Tags - // always returns nil. - Supported Coverage = allSubtags{} -) - -// TODO: -// - Support Variants, numbering systems. -// - CLDR coverage levels. -// - Set of common tags defined in this package. - -type allSubtags struct{} - -// Regions returns the list of supported regions. As all regions are in a -// consecutive range, it simply returns a slice of numbers in increasing order. -// The "undefined" region is not returned. -func (s allSubtags) Regions() []Region { - reg := make([]Region, numRegions) - for i := range reg { - reg[i] = Region{regionID(i + 1)} - } - return reg -} - -// Scripts returns the list of supported scripts. As all scripts are in a -// consecutive range, it simply returns a slice of numbers in increasing order. -// The "undefined" script is not returned. -func (s allSubtags) Scripts() []Script { - scr := make([]Script, numScripts) - for i := range scr { - scr[i] = Script{scriptID(i + 1)} - } - return scr -} - -// BaseLanguages returns the list of all supported base languages. It generates -// the list by traversing the internal structures. -func (s allSubtags) BaseLanguages() []Base { - base := make([]Base, 0, numLanguages) - for i := 0; i < langNoIndexOffset; i++ { - // We included "und" already for the value 0. - if i != nonCanonicalUnd { - base = append(base, Base{langID(i)}) - } - } - i := langNoIndexOffset - for _, v := range langNoIndex { - for k := 0; k < 8; k++ { - if v&1 == 1 { - base = append(base, Base{langID(i)}) - } - v >>= 1 - i++ - } - } - return base -} - -// Tags always returns nil. -func (s allSubtags) Tags() []Tag { - return nil -} - -// coverage is used used by NewCoverage which is used as a convenient way for -// creating Coverage implementations for partially defined data. Very often a -// package will only need to define a subset of slices. coverage provides a -// convenient way to do this. Moreover, packages using NewCoverage, instead of -// their own implementation, will not break if later new slice types are added. -type coverage struct { - tags func() []Tag - bases func() []Base - scripts func() []Script - regions func() []Region -} - -func (s *coverage) Tags() []Tag { - if s.tags == nil { - return nil - } - return s.tags() -} - -// bases implements sort.Interface and is used to sort base languages. -type bases []Base - -func (b bases) Len() int { - return len(b) -} - -func (b bases) Swap(i, j int) { - b[i], b[j] = b[j], b[i] -} - -func (b bases) Less(i, j int) bool { - return b[i].langID < b[j].langID -} - -// BaseLanguages returns the result from calling s.bases if it is specified or -// otherwise derives the set of supported base languages from tags. -func (s *coverage) BaseLanguages() []Base { - if s.bases == nil { - tags := s.Tags() - if len(tags) == 0 { - return nil - } - a := make([]Base, len(tags)) - for i, t := range tags { - a[i] = Base{langID(t.lang)} - } - sort.Sort(bases(a)) - k := 0 - for i := 1; i < len(a); i++ { - if a[k] != a[i] { - k++ - a[k] = a[i] - } - } - return a[:k+1] - } - return s.bases() -} - -func (s *coverage) Scripts() []Script { - if s.scripts == nil { - return nil - } - return s.scripts() -} - -func (s *coverage) Regions() []Region { - if s.regions == nil { - return nil - } - return s.regions() -} - -// NewCoverage returns a Coverage for the given lists. It is typically used by -// packages providing internationalization services to define their level of -// coverage. A list may be of type []T or func() []T, where T is either Tag, -// Base, Script or Region. The returned Coverage derives the value for Bases -// from Tags if no func or slice for []Base is specified. For other unspecified -// types the returned Coverage will return nil for the respective methods. -func NewCoverage(list ...interface{}) Coverage { - s := &coverage{} - for _, x := range list { - switch v := x.(type) { - case func() []Base: - s.bases = v - case func() []Script: - s.scripts = v - case func() []Region: - s.regions = v - case func() []Tag: - s.tags = v - case []Base: - s.bases = func() []Base { return v } - case []Script: - s.scripts = func() []Script { return v } - case []Region: - s.regions = func() []Region { return v } - case []Tag: - s.tags = func() []Tag { return v } - default: - panic(fmt.Sprintf("language: unsupported set type %T", v)) - } - } - return s -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_common.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_common.go deleted file mode 100644 index 83ce180..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_common.go +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// This file contains code common to the maketables.go and the package code. - -// langAliasType is the type of an alias in langAliasMap. -type langAliasType int8 - -const ( - langDeprecated langAliasType = iota - langMacro - langLegacy - - langAliasTypeUnknown langAliasType = -1 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_index.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_index.go deleted file mode 100644 index eef555c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/gen_index.go +++ /dev/null @@ -1,162 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// This file generates derivative tables based on the language package itself. - -import ( - "bytes" - "flag" - "fmt" - "io/ioutil" - "log" - "reflect" - "sort" - "strings" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/language" - "golang.org/x/text/unicode/cldr" -) - -var ( - test = flag.Bool("test", false, - "test existing tables; can be used to compare web data with package data.") - - draft = flag.String("draft", - "contributed", - `Minimal draft requirements (approved, contributed, provisional, unconfirmed).`) -) - -func main() { - gen.Init() - - // Read the CLDR zip file. - r := gen.OpenCLDRCoreZip() - defer r.Close() - - d := &cldr.Decoder{} - data, err := d.DecodeZip(r) - if err != nil { - log.Fatalf("DecodeZip: %v", err) - } - - w := gen.NewCodeWriter() - defer func() { - buf := &bytes.Buffer{} - - if _, err = w.WriteGo(buf, "language"); err != nil { - log.Fatalf("Error formatting file index.go: %v", err) - } - - // Since we're generating a table for our own package we need to rewrite - // doing the equivalent of go fmt -r 'language.b -> b'. Using - // bytes.Replace will do. - out := bytes.Replace(buf.Bytes(), []byte("language."), nil, -1) - if err := ioutil.WriteFile("index.go", out, 0600); err != nil { - log.Fatalf("Could not create file index.go: %v", err) - } - }() - - m := map[language.Tag]bool{} - for _, lang := range data.Locales() { - // We include all locales unconditionally to be consistent with en_US. - // We want en_US, even though it has no data associated with it. - - // TODO: put any of the languages for which no data exists at the end - // of the index. This allows all components based on ICU to use that - // as the cutoff point. - // if x := data.RawLDML(lang); false || - // x.LocaleDisplayNames != nil || - // x.Characters != nil || - // x.Delimiters != nil || - // x.Measurement != nil || - // x.Dates != nil || - // x.Numbers != nil || - // x.Units != nil || - // x.ListPatterns != nil || - // x.Collations != nil || - // x.Segmentations != nil || - // x.Rbnf != nil || - // x.Annotations != nil || - // x.Metadata != nil { - - // TODO: support POSIX natively, albeit non-standard. - tag := language.Make(strings.Replace(lang, "_POSIX", "-u-va-posix", 1)) - m[tag] = true - // } - } - // Include locales for plural rules, which uses a different structure. - for _, plurals := range data.Supplemental().Plurals { - for _, rules := range plurals.PluralRules { - for _, lang := range strings.Split(rules.Locales, " ") { - m[language.Make(lang)] = true - } - } - } - - var core, special []language.Tag - - for t := range m { - if x := t.Extensions(); len(x) != 0 && fmt.Sprint(x) != "[u-va-posix]" { - log.Fatalf("Unexpected extension %v in %v", x, t) - } - if len(t.Variants()) == 0 && len(t.Extensions()) == 0 { - core = append(core, t) - } else { - special = append(special, t) - } - } - - w.WriteComment(` - NumCompactTags is the number of common tags. The maximum tag is - NumCompactTags-1.`) - w.WriteConst("NumCompactTags", len(core)+len(special)) - - sort.Sort(byAlpha(special)) - w.WriteVar("specialTags", special) - - // TODO: order by frequency? - sort.Sort(byAlpha(core)) - - // Size computations are just an estimate. - w.Size += int(reflect.TypeOf(map[uint32]uint16{}).Size()) - w.Size += len(core) * 6 // size of uint32 and uint16 - - fmt.Fprintln(w) - fmt.Fprintln(w, "var coreTags = map[uint32]uint16{") - fmt.Fprintln(w, "0x0: 0, // und") - i := len(special) + 1 // Und and special tags already written. - for _, t := range core { - if t == language.Und { - continue - } - fmt.Fprint(w.Hash, t, i) - b, s, r := t.Raw() - fmt.Fprintf(w, "0x%s%s%s: %d, // %s\n", - getIndex(b, 3), // 3 is enough as it is guaranteed to be a compact number - getIndex(s, 2), - getIndex(r, 3), - i, t) - i++ - } - fmt.Fprintln(w, "}") -} - -// getIndex prints the subtag type and extracts its index of size nibble. -// If the index is less than n nibbles, the result is prefixed with 0s. -func getIndex(x interface{}, n int) string { - s := fmt.Sprintf("%#v", x) // s is of form Type{typeID: 0x00} - s = s[strings.Index(s, "0x")+2 : len(s)-1] - return strings.Repeat("0", n-len(s)) + s -} - -type byAlpha []language.Tag - -func (a byAlpha) Len() int { return len(a) } -func (a byAlpha) Swap(i, j int) { a[i], a[j] = a[j], a[i] } -func (a byAlpha) Less(i, j int) bool { return a[i].String() < a[j].String() } diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_1.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_1.go deleted file mode 100644 index 380f4c0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_1.go +++ /dev/null @@ -1,38 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build !go1.2 - -package language - -import "sort" - -func sortStable(s sort.Interface) { - ss := stableSort{ - s: s, - pos: make([]int, s.Len()), - } - for i := range ss.pos { - ss.pos[i] = i - } - sort.Sort(&ss) -} - -type stableSort struct { - s sort.Interface - pos []int -} - -func (s *stableSort) Len() int { - return len(s.pos) -} - -func (s *stableSort) Less(i, j int) bool { - return s.s.Less(i, j) || !s.s.Less(j, i) && s.pos[i] < s.pos[j] -} - -func (s *stableSort) Swap(i, j int) { - s.s.Swap(i, j) - s.pos[i], s.pos[j] = s.pos[j], s.pos[i] -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_2.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_2.go deleted file mode 100644 index 38268c5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/go1_2.go +++ /dev/null @@ -1,11 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build go1.2 - -package language - -import "sort" - -var sortStable = sort.Stable diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/index.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/index.go deleted file mode 100644 index 7fa9cc8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/index.go +++ /dev/null @@ -1,762 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package language - -// NumCompactTags is the number of common tags. The maximum tag is -// NumCompactTags-1. -const NumCompactTags = 747 - -var specialTags = []Tag{ // 2 elements - 0: {lang: 0x61, region: 0x6d, script: 0x0, pVariant: 0x5, pExt: 0xe, str: "ca-ES-valencia"}, - 1: {lang: 0x9b, region: 0x132, script: 0x0, pVariant: 0x5, pExt: 0x5, str: "en-US-u-va-posix"}, -} // Size: 72 bytes - -var coreTags = map[uint32]uint16{ - 0x0: 0, // und - 0x00a00000: 3, // af - 0x00a000d0: 4, // af-NA - 0x00a0015e: 5, // af-ZA - 0x00b00000: 6, // agq - 0x00b00051: 7, // agq-CM - 0x00d00000: 8, // ak - 0x00d0007e: 9, // ak-GH - 0x01100000: 10, // am - 0x0110006e: 11, // am-ET - 0x01500000: 12, // ar - 0x01500001: 13, // ar-001 - 0x01500022: 14, // ar-AE - 0x01500038: 15, // ar-BH - 0x01500061: 16, // ar-DJ - 0x01500066: 17, // ar-DZ - 0x0150006a: 18, // ar-EG - 0x0150006b: 19, // ar-EH - 0x0150006c: 20, // ar-ER - 0x01500095: 21, // ar-IL - 0x01500099: 22, // ar-IQ - 0x0150009f: 23, // ar-JO - 0x015000a6: 24, // ar-KM - 0x015000aa: 25, // ar-KW - 0x015000ae: 26, // ar-LB - 0x015000b7: 27, // ar-LY - 0x015000b8: 28, // ar-MA - 0x015000c7: 29, // ar-MR - 0x015000df: 30, // ar-OM - 0x015000eb: 31, // ar-PS - 0x015000f1: 32, // ar-QA - 0x01500106: 33, // ar-SA - 0x01500109: 34, // ar-SD - 0x01500113: 35, // ar-SO - 0x01500115: 36, // ar-SS - 0x0150011a: 37, // ar-SY - 0x0150011e: 38, // ar-TD - 0x01500126: 39, // ar-TN - 0x0150015b: 40, // ar-YE - 0x01c00000: 41, // as - 0x01c00097: 42, // as-IN - 0x01d00000: 43, // asa - 0x01d0012d: 44, // asa-TZ - 0x01f00000: 45, // ast - 0x01f0006d: 46, // ast-ES - 0x02400000: 47, // az - 0x0241e000: 48, // az-Cyrl - 0x0241e031: 49, // az-Cyrl-AZ - 0x02452000: 50, // az-Latn - 0x02452031: 51, // az-Latn-AZ - 0x02a00000: 52, // bas - 0x02a00051: 53, // bas-CM - 0x02f00000: 54, // be - 0x02f00046: 55, // be-BY - 0x03100000: 56, // bem - 0x0310015f: 57, // bem-ZM - 0x03300000: 58, // bez - 0x0330012d: 59, // bez-TZ - 0x03800000: 60, // bg - 0x03800037: 61, // bg-BG - 0x03c00000: 62, // bh - 0x04900000: 63, // bm - 0x049000c1: 64, // bm-ML - 0x04b00000: 65, // bn - 0x04b00034: 66, // bn-BD - 0x04b00097: 67, // bn-IN - 0x04c00000: 68, // bo - 0x04c00052: 69, // bo-CN - 0x04c00097: 70, // bo-IN - 0x05000000: 71, // br - 0x05000076: 72, // br-FR - 0x05300000: 73, // brx - 0x05300097: 74, // brx-IN - 0x05400000: 75, // bs - 0x0541e000: 76, // bs-Cyrl - 0x0541e032: 77, // bs-Cyrl-BA - 0x05452000: 78, // bs-Latn - 0x05452032: 79, // bs-Latn-BA - 0x06100000: 80, // ca - 0x06100021: 81, // ca-AD - 0x0610006d: 82, // ca-ES - 0x06100076: 83, // ca-FR - 0x0610009c: 84, // ca-IT - 0x06400000: 85, // ce - 0x06400104: 86, // ce-RU - 0x06600000: 87, // cgg - 0x0660012f: 88, // cgg-UG - 0x06c00000: 89, // chr - 0x06c00132: 90, // chr-US - 0x06f00000: 91, // ckb - 0x06f00099: 92, // ckb-IQ - 0x06f0009a: 93, // ckb-IR - 0x07900000: 94, // cs - 0x0790005d: 95, // cs-CZ - 0x07d00000: 96, // cu - 0x07d00104: 97, // cu-RU - 0x07f00000: 98, // cy - 0x07f00079: 99, // cy-GB - 0x08000000: 100, // da - 0x08000062: 101, // da-DK - 0x08000080: 102, // da-GL - 0x08300000: 103, // dav - 0x083000a2: 104, // dav-KE - 0x08500000: 105, // de - 0x0850002d: 106, // de-AT - 0x08500035: 107, // de-BE - 0x0850004d: 108, // de-CH - 0x0850005f: 109, // de-DE - 0x085000b0: 110, // de-LI - 0x085000b5: 111, // de-LU - 0x08800000: 112, // dje - 0x088000d2: 113, // dje-NE - 0x08b00000: 114, // dsb - 0x08b0005f: 115, // dsb-DE - 0x08f00000: 116, // dua - 0x08f00051: 117, // dua-CM - 0x09000000: 118, // dv - 0x09100000: 119, // dyo - 0x09100112: 120, // dyo-SN - 0x09300000: 121, // dz - 0x09300042: 122, // dz-BT - 0x09400000: 123, // ebu - 0x094000a2: 124, // ebu-KE - 0x09500000: 125, // ee - 0x0950007e: 126, // ee-GH - 0x09500120: 127, // ee-TG - 0x09a00000: 128, // el - 0x09a0005c: 129, // el-CY - 0x09a00085: 130, // el-GR - 0x09b00000: 131, // en - 0x09b00001: 132, // en-001 - 0x09b0001a: 133, // en-150 - 0x09b00024: 134, // en-AG - 0x09b00025: 135, // en-AI - 0x09b0002c: 136, // en-AS - 0x09b0002d: 137, // en-AT - 0x09b0002e: 138, // en-AU - 0x09b00033: 139, // en-BB - 0x09b00035: 140, // en-BE - 0x09b00039: 141, // en-BI - 0x09b0003c: 142, // en-BM - 0x09b00041: 143, // en-BS - 0x09b00045: 144, // en-BW - 0x09b00047: 145, // en-BZ - 0x09b00048: 146, // en-CA - 0x09b00049: 147, // en-CC - 0x09b0004d: 148, // en-CH - 0x09b0004f: 149, // en-CK - 0x09b00051: 150, // en-CM - 0x09b0005b: 151, // en-CX - 0x09b0005c: 152, // en-CY - 0x09b0005f: 153, // en-DE - 0x09b00060: 154, // en-DG - 0x09b00062: 155, // en-DK - 0x09b00063: 156, // en-DM - 0x09b0006c: 157, // en-ER - 0x09b00070: 158, // en-FI - 0x09b00071: 159, // en-FJ - 0x09b00072: 160, // en-FK - 0x09b00073: 161, // en-FM - 0x09b00079: 162, // en-GB - 0x09b0007a: 163, // en-GD - 0x09b0007d: 164, // en-GG - 0x09b0007e: 165, // en-GH - 0x09b0007f: 166, // en-GI - 0x09b00081: 167, // en-GM - 0x09b00088: 168, // en-GU - 0x09b0008a: 169, // en-GY - 0x09b0008b: 170, // en-HK - 0x09b00094: 171, // en-IE - 0x09b00095: 172, // en-IL - 0x09b00096: 173, // en-IM - 0x09b00097: 174, // en-IN - 0x09b00098: 175, // en-IO - 0x09b0009d: 176, // en-JE - 0x09b0009e: 177, // en-JM - 0x09b000a2: 178, // en-KE - 0x09b000a5: 179, // en-KI - 0x09b000a7: 180, // en-KN - 0x09b000ab: 181, // en-KY - 0x09b000af: 182, // en-LC - 0x09b000b2: 183, // en-LR - 0x09b000b3: 184, // en-LS - 0x09b000bd: 185, // en-MG - 0x09b000be: 186, // en-MH - 0x09b000c4: 187, // en-MO - 0x09b000c5: 188, // en-MP - 0x09b000c8: 189, // en-MS - 0x09b000c9: 190, // en-MT - 0x09b000ca: 191, // en-MU - 0x09b000cc: 192, // en-MW - 0x09b000ce: 193, // en-MY - 0x09b000d0: 194, // en-NA - 0x09b000d3: 195, // en-NF - 0x09b000d4: 196, // en-NG - 0x09b000d7: 197, // en-NL - 0x09b000db: 198, // en-NR - 0x09b000dd: 199, // en-NU - 0x09b000de: 200, // en-NZ - 0x09b000e4: 201, // en-PG - 0x09b000e5: 202, // en-PH - 0x09b000e6: 203, // en-PK - 0x09b000e9: 204, // en-PN - 0x09b000ea: 205, // en-PR - 0x09b000ee: 206, // en-PW - 0x09b00105: 207, // en-RW - 0x09b00107: 208, // en-SB - 0x09b00108: 209, // en-SC - 0x09b00109: 210, // en-SD - 0x09b0010a: 211, // en-SE - 0x09b0010b: 212, // en-SG - 0x09b0010c: 213, // en-SH - 0x09b0010d: 214, // en-SI - 0x09b00110: 215, // en-SL - 0x09b00115: 216, // en-SS - 0x09b00119: 217, // en-SX - 0x09b0011b: 218, // en-SZ - 0x09b0011d: 219, // en-TC - 0x09b00123: 220, // en-TK - 0x09b00127: 221, // en-TO - 0x09b0012a: 222, // en-TT - 0x09b0012b: 223, // en-TV - 0x09b0012d: 224, // en-TZ - 0x09b0012f: 225, // en-UG - 0x09b00131: 226, // en-UM - 0x09b00132: 227, // en-US - 0x09b00136: 228, // en-VC - 0x09b00139: 229, // en-VG - 0x09b0013a: 230, // en-VI - 0x09b0013c: 231, // en-VU - 0x09b0013f: 232, // en-WS - 0x09b0015e: 233, // en-ZA - 0x09b0015f: 234, // en-ZM - 0x09b00161: 235, // en-ZW - 0x09c00000: 236, // eo - 0x09c00001: 237, // eo-001 - 0x09d00000: 238, // es - 0x09d0001e: 239, // es-419 - 0x09d0002b: 240, // es-AR - 0x09d0003e: 241, // es-BO - 0x09d00040: 242, // es-BR - 0x09d00050: 243, // es-CL - 0x09d00053: 244, // es-CO - 0x09d00055: 245, // es-CR - 0x09d00058: 246, // es-CU - 0x09d00064: 247, // es-DO - 0x09d00067: 248, // es-EA - 0x09d00068: 249, // es-EC - 0x09d0006d: 250, // es-ES - 0x09d00084: 251, // es-GQ - 0x09d00087: 252, // es-GT - 0x09d0008d: 253, // es-HN - 0x09d00092: 254, // es-IC - 0x09d000cd: 255, // es-MX - 0x09d000d6: 256, // es-NI - 0x09d000e0: 257, // es-PA - 0x09d000e2: 258, // es-PE - 0x09d000e5: 259, // es-PH - 0x09d000ea: 260, // es-PR - 0x09d000ef: 261, // es-PY - 0x09d00118: 262, // es-SV - 0x09d00132: 263, // es-US - 0x09d00133: 264, // es-UY - 0x09d00138: 265, // es-VE - 0x09f00000: 266, // et - 0x09f00069: 267, // et-EE - 0x0a100000: 268, // eu - 0x0a10006d: 269, // eu-ES - 0x0a200000: 270, // ewo - 0x0a200051: 271, // ewo-CM - 0x0a400000: 272, // fa - 0x0a400023: 273, // fa-AF - 0x0a40009a: 274, // fa-IR - 0x0a600000: 275, // ff - 0x0a600051: 276, // ff-CM - 0x0a600082: 277, // ff-GN - 0x0a6000c7: 278, // ff-MR - 0x0a600112: 279, // ff-SN - 0x0a800000: 280, // fi - 0x0a800070: 281, // fi-FI - 0x0aa00000: 282, // fil - 0x0aa000e5: 283, // fil-PH - 0x0ad00000: 284, // fo - 0x0ad00062: 285, // fo-DK - 0x0ad00074: 286, // fo-FO - 0x0af00000: 287, // fr - 0x0af00035: 288, // fr-BE - 0x0af00036: 289, // fr-BF - 0x0af00039: 290, // fr-BI - 0x0af0003a: 291, // fr-BJ - 0x0af0003b: 292, // fr-BL - 0x0af00048: 293, // fr-CA - 0x0af0004a: 294, // fr-CD - 0x0af0004b: 295, // fr-CF - 0x0af0004c: 296, // fr-CG - 0x0af0004d: 297, // fr-CH - 0x0af0004e: 298, // fr-CI - 0x0af00051: 299, // fr-CM - 0x0af00061: 300, // fr-DJ - 0x0af00066: 301, // fr-DZ - 0x0af00076: 302, // fr-FR - 0x0af00078: 303, // fr-GA - 0x0af0007c: 304, // fr-GF - 0x0af00082: 305, // fr-GN - 0x0af00083: 306, // fr-GP - 0x0af00084: 307, // fr-GQ - 0x0af0008f: 308, // fr-HT - 0x0af000a6: 309, // fr-KM - 0x0af000b5: 310, // fr-LU - 0x0af000b8: 311, // fr-MA - 0x0af000b9: 312, // fr-MC - 0x0af000bc: 313, // fr-MF - 0x0af000bd: 314, // fr-MG - 0x0af000c1: 315, // fr-ML - 0x0af000c6: 316, // fr-MQ - 0x0af000c7: 317, // fr-MR - 0x0af000ca: 318, // fr-MU - 0x0af000d1: 319, // fr-NC - 0x0af000d2: 320, // fr-NE - 0x0af000e3: 321, // fr-PF - 0x0af000e8: 322, // fr-PM - 0x0af00100: 323, // fr-RE - 0x0af00105: 324, // fr-RW - 0x0af00108: 325, // fr-SC - 0x0af00112: 326, // fr-SN - 0x0af0011a: 327, // fr-SY - 0x0af0011e: 328, // fr-TD - 0x0af00120: 329, // fr-TG - 0x0af00126: 330, // fr-TN - 0x0af0013c: 331, // fr-VU - 0x0af0013d: 332, // fr-WF - 0x0af0015c: 333, // fr-YT - 0x0b600000: 334, // fur - 0x0b60009c: 335, // fur-IT - 0x0b900000: 336, // fy - 0x0b9000d7: 337, // fy-NL - 0x0ba00000: 338, // ga - 0x0ba00094: 339, // ga-IE - 0x0c200000: 340, // gd - 0x0c200079: 341, // gd-GB - 0x0c800000: 342, // gl - 0x0c80006d: 343, // gl-ES - 0x0d200000: 344, // gsw - 0x0d20004d: 345, // gsw-CH - 0x0d200076: 346, // gsw-FR - 0x0d2000b0: 347, // gsw-LI - 0x0d300000: 348, // gu - 0x0d300097: 349, // gu-IN - 0x0d700000: 350, // guw - 0x0d800000: 351, // guz - 0x0d8000a2: 352, // guz-KE - 0x0d900000: 353, // gv - 0x0d900096: 354, // gv-IM - 0x0dc00000: 355, // ha - 0x0dc0007e: 356, // ha-GH - 0x0dc000d2: 357, // ha-NE - 0x0dc000d4: 358, // ha-NG - 0x0de00000: 359, // haw - 0x0de00132: 360, // haw-US - 0x0e000000: 361, // he - 0x0e000095: 362, // he-IL - 0x0e100000: 363, // hi - 0x0e100097: 364, // hi-IN - 0x0ee00000: 365, // hr - 0x0ee00032: 366, // hr-BA - 0x0ee0008e: 367, // hr-HR - 0x0ef00000: 368, // hsb - 0x0ef0005f: 369, // hsb-DE - 0x0f200000: 370, // hu - 0x0f200090: 371, // hu-HU - 0x0f300000: 372, // hy - 0x0f300027: 373, // hy-AM - 0x0f800000: 374, // id - 0x0f800093: 375, // id-ID - 0x0fa00000: 376, // ig - 0x0fa000d4: 377, // ig-NG - 0x0fb00000: 378, // ii - 0x0fb00052: 379, // ii-CN - 0x10200000: 380, // is - 0x1020009b: 381, // is-IS - 0x10300000: 382, // it - 0x1030004d: 383, // it-CH - 0x1030009c: 384, // it-IT - 0x10300111: 385, // it-SM - 0x10400000: 386, // iu - 0x10700000: 387, // ja - 0x107000a0: 388, // ja-JP - 0x10900000: 389, // jbo - 0x10a00000: 390, // jgo - 0x10a00051: 391, // jgo-CM - 0x10c00000: 392, // jmc - 0x10c0012d: 393, // jmc-TZ - 0x10f00000: 394, // jv - 0x11100000: 395, // ka - 0x1110007b: 396, // ka-GE - 0x11300000: 397, // kab - 0x11300066: 398, // kab-DZ - 0x11500000: 399, // kaj - 0x11600000: 400, // kam - 0x116000a2: 401, // kam-KE - 0x11900000: 402, // kcg - 0x11b00000: 403, // kde - 0x11b0012d: 404, // kde-TZ - 0x11d00000: 405, // kea - 0x11d00059: 406, // kea-CV - 0x12800000: 407, // khq - 0x128000c1: 408, // khq-ML - 0x12b00000: 409, // ki - 0x12b000a2: 410, // ki-KE - 0x12f00000: 411, // kk - 0x12f000ac: 412, // kk-KZ - 0x13000000: 413, // kkj - 0x13000051: 414, // kkj-CM - 0x13100000: 415, // kl - 0x13100080: 416, // kl-GL - 0x13200000: 417, // kln - 0x132000a2: 418, // kln-KE - 0x13300000: 419, // km - 0x133000a4: 420, // km-KH - 0x13500000: 421, // kn - 0x13500097: 422, // kn-IN - 0x13600000: 423, // ko - 0x136000a8: 424, // ko-KP - 0x136000a9: 425, // ko-KR - 0x13800000: 426, // kok - 0x13800097: 427, // kok-IN - 0x14100000: 428, // ks - 0x14100097: 429, // ks-IN - 0x14200000: 430, // ksb - 0x1420012d: 431, // ksb-TZ - 0x14300000: 432, // ksf - 0x14300051: 433, // ksf-CM - 0x14400000: 434, // ksh - 0x1440005f: 435, // ksh-DE - 0x14500000: 436, // ku - 0x14a00000: 437, // kw - 0x14a00079: 438, // kw-GB - 0x14d00000: 439, // ky - 0x14d000a3: 440, // ky-KG - 0x15100000: 441, // lag - 0x1510012d: 442, // lag-TZ - 0x15400000: 443, // lb - 0x154000b5: 444, // lb-LU - 0x15a00000: 445, // lg - 0x15a0012f: 446, // lg-UG - 0x16100000: 447, // lkt - 0x16100132: 448, // lkt-US - 0x16400000: 449, // ln - 0x16400029: 450, // ln-AO - 0x1640004a: 451, // ln-CD - 0x1640004b: 452, // ln-CF - 0x1640004c: 453, // ln-CG - 0x16500000: 454, // lo - 0x165000ad: 455, // lo-LA - 0x16800000: 456, // lrc - 0x16800099: 457, // lrc-IQ - 0x1680009a: 458, // lrc-IR - 0x16900000: 459, // lt - 0x169000b4: 460, // lt-LT - 0x16b00000: 461, // lu - 0x16b0004a: 462, // lu-CD - 0x16d00000: 463, // luo - 0x16d000a2: 464, // luo-KE - 0x16e00000: 465, // luy - 0x16e000a2: 466, // luy-KE - 0x17000000: 467, // lv - 0x170000b6: 468, // lv-LV - 0x17a00000: 469, // mas - 0x17a000a2: 470, // mas-KE - 0x17a0012d: 471, // mas-TZ - 0x18000000: 472, // mer - 0x180000a2: 473, // mer-KE - 0x18200000: 474, // mfe - 0x182000ca: 475, // mfe-MU - 0x18300000: 476, // mg - 0x183000bd: 477, // mg-MG - 0x18400000: 478, // mgh - 0x184000cf: 479, // mgh-MZ - 0x18500000: 480, // mgo - 0x18500051: 481, // mgo-CM - 0x18c00000: 482, // mk - 0x18c000c0: 483, // mk-MK - 0x18d00000: 484, // ml - 0x18d00097: 485, // ml-IN - 0x18f00000: 486, // mn - 0x18f000c3: 487, // mn-MN - 0x19600000: 488, // mr - 0x19600097: 489, // mr-IN - 0x19a00000: 490, // ms - 0x19a0003d: 491, // ms-BN - 0x19a000ce: 492, // ms-MY - 0x19a0010b: 493, // ms-SG - 0x19b00000: 494, // mt - 0x19b000c9: 495, // mt-MT - 0x19d00000: 496, // mua - 0x19d00051: 497, // mua-CM - 0x1a500000: 498, // my - 0x1a5000c2: 499, // my-MM - 0x1a900000: 500, // mzn - 0x1a90009a: 501, // mzn-IR - 0x1ab00000: 502, // nah - 0x1ae00000: 503, // naq - 0x1ae000d0: 504, // naq-NA - 0x1af00000: 505, // nb - 0x1af000d8: 506, // nb-NO - 0x1af0010e: 507, // nb-SJ - 0x1b100000: 508, // nd - 0x1b100161: 509, // nd-ZW - 0x1b400000: 510, // ne - 0x1b400097: 511, // ne-IN - 0x1b4000d9: 512, // ne-NP - 0x1bd00000: 513, // nl - 0x1bd0002f: 514, // nl-AW - 0x1bd00035: 515, // nl-BE - 0x1bd0003f: 516, // nl-BQ - 0x1bd0005a: 517, // nl-CW - 0x1bd000d7: 518, // nl-NL - 0x1bd00114: 519, // nl-SR - 0x1bd00119: 520, // nl-SX - 0x1be00000: 521, // nmg - 0x1be00051: 522, // nmg-CM - 0x1bf00000: 523, // nn - 0x1bf000d8: 524, // nn-NO - 0x1c000000: 525, // nnh - 0x1c000051: 526, // nnh-CM - 0x1c100000: 527, // no - 0x1c500000: 528, // nqo - 0x1c600000: 529, // nr - 0x1c800000: 530, // nso - 0x1c900000: 531, // nus - 0x1c900115: 532, // nus-SS - 0x1cc00000: 533, // ny - 0x1ce00000: 534, // nyn - 0x1ce0012f: 535, // nyn-UG - 0x1d200000: 536, // om - 0x1d20006e: 537, // om-ET - 0x1d2000a2: 538, // om-KE - 0x1d300000: 539, // or - 0x1d300097: 540, // or-IN - 0x1d400000: 541, // os - 0x1d40007b: 542, // os-GE - 0x1d400104: 543, // os-RU - 0x1d700000: 544, // pa - 0x1d705000: 545, // pa-Arab - 0x1d7050e6: 546, // pa-Arab-PK - 0x1d72f000: 547, // pa-Guru - 0x1d72f097: 548, // pa-Guru-IN - 0x1db00000: 549, // pap - 0x1e700000: 550, // pl - 0x1e7000e7: 551, // pl-PL - 0x1ed00000: 552, // prg - 0x1ed00001: 553, // prg-001 - 0x1ee00000: 554, // ps - 0x1ee00023: 555, // ps-AF - 0x1ef00000: 556, // pt - 0x1ef00029: 557, // pt-AO - 0x1ef00040: 558, // pt-BR - 0x1ef0004d: 559, // pt-CH - 0x1ef00059: 560, // pt-CV - 0x1ef00084: 561, // pt-GQ - 0x1ef00089: 562, // pt-GW - 0x1ef000b5: 563, // pt-LU - 0x1ef000c4: 564, // pt-MO - 0x1ef000cf: 565, // pt-MZ - 0x1ef000ec: 566, // pt-PT - 0x1ef00116: 567, // pt-ST - 0x1ef00124: 568, // pt-TL - 0x1f100000: 569, // qu - 0x1f10003e: 570, // qu-BO - 0x1f100068: 571, // qu-EC - 0x1f1000e2: 572, // qu-PE - 0x1fc00000: 573, // rm - 0x1fc0004d: 574, // rm-CH - 0x20100000: 575, // rn - 0x20100039: 576, // rn-BI - 0x20300000: 577, // ro - 0x203000ba: 578, // ro-MD - 0x20300102: 579, // ro-RO - 0x20500000: 580, // rof - 0x2050012d: 581, // rof-TZ - 0x20700000: 582, // ru - 0x20700046: 583, // ru-BY - 0x207000a3: 584, // ru-KG - 0x207000ac: 585, // ru-KZ - 0x207000ba: 586, // ru-MD - 0x20700104: 587, // ru-RU - 0x2070012e: 588, // ru-UA - 0x20a00000: 589, // rw - 0x20a00105: 590, // rw-RW - 0x20b00000: 591, // rwk - 0x20b0012d: 592, // rwk-TZ - 0x20f00000: 593, // sah - 0x20f00104: 594, // sah-RU - 0x21000000: 595, // saq - 0x210000a2: 596, // saq-KE - 0x21400000: 597, // sbp - 0x2140012d: 598, // sbp-TZ - 0x21c00000: 599, // sdh - 0x21d00000: 600, // se - 0x21d00070: 601, // se-FI - 0x21d000d8: 602, // se-NO - 0x21d0010a: 603, // se-SE - 0x21f00000: 604, // seh - 0x21f000cf: 605, // seh-MZ - 0x22100000: 606, // ses - 0x221000c1: 607, // ses-ML - 0x22200000: 608, // sg - 0x2220004b: 609, // sg-CF - 0x22600000: 610, // shi - 0x22652000: 611, // shi-Latn - 0x226520b8: 612, // shi-Latn-MA - 0x226d2000: 613, // shi-Tfng - 0x226d20b8: 614, // shi-Tfng-MA - 0x22800000: 615, // si - 0x228000b1: 616, // si-LK - 0x22a00000: 617, // sk - 0x22a0010f: 618, // sk-SK - 0x22c00000: 619, // sl - 0x22c0010d: 620, // sl-SI - 0x23000000: 621, // sma - 0x23100000: 622, // smi - 0x23200000: 623, // smj - 0x23300000: 624, // smn - 0x23300070: 625, // smn-FI - 0x23500000: 626, // sms - 0x23600000: 627, // sn - 0x23600161: 628, // sn-ZW - 0x23800000: 629, // so - 0x23800061: 630, // so-DJ - 0x2380006e: 631, // so-ET - 0x238000a2: 632, // so-KE - 0x23800113: 633, // so-SO - 0x23a00000: 634, // sq - 0x23a00026: 635, // sq-AL - 0x23a000c0: 636, // sq-MK - 0x23a0014a: 637, // sq-XK - 0x23b00000: 638, // sr - 0x23b1e000: 639, // sr-Cyrl - 0x23b1e032: 640, // sr-Cyrl-BA - 0x23b1e0bb: 641, // sr-Cyrl-ME - 0x23b1e103: 642, // sr-Cyrl-RS - 0x23b1e14a: 643, // sr-Cyrl-XK - 0x23b52000: 644, // sr-Latn - 0x23b52032: 645, // sr-Latn-BA - 0x23b520bb: 646, // sr-Latn-ME - 0x23b52103: 647, // sr-Latn-RS - 0x23b5214a: 648, // sr-Latn-XK - 0x24000000: 649, // ss - 0x24100000: 650, // ssy - 0x24200000: 651, // st - 0x24700000: 652, // sv - 0x24700030: 653, // sv-AX - 0x24700070: 654, // sv-FI - 0x2470010a: 655, // sv-SE - 0x24800000: 656, // sw - 0x2480004a: 657, // sw-CD - 0x248000a2: 658, // sw-KE - 0x2480012d: 659, // sw-TZ - 0x2480012f: 660, // sw-UG - 0x24f00000: 661, // syr - 0x25100000: 662, // ta - 0x25100097: 663, // ta-IN - 0x251000b1: 664, // ta-LK - 0x251000ce: 665, // ta-MY - 0x2510010b: 666, // ta-SG - 0x25800000: 667, // te - 0x25800097: 668, // te-IN - 0x25a00000: 669, // teo - 0x25a000a2: 670, // teo-KE - 0x25a0012f: 671, // teo-UG - 0x25d00000: 672, // th - 0x25d00121: 673, // th-TH - 0x26100000: 674, // ti - 0x2610006c: 675, // ti-ER - 0x2610006e: 676, // ti-ET - 0x26200000: 677, // tig - 0x26400000: 678, // tk - 0x26400125: 679, // tk-TM - 0x26b00000: 680, // tn - 0x26c00000: 681, // to - 0x26c00127: 682, // to-TO - 0x26f00000: 683, // tr - 0x26f0005c: 684, // tr-CY - 0x26f00129: 685, // tr-TR - 0x27200000: 686, // ts - 0x27e00000: 687, // twq - 0x27e000d2: 688, // twq-NE - 0x28200000: 689, // tzm - 0x282000b8: 690, // tzm-MA - 0x28400000: 691, // ug - 0x28400052: 692, // ug-CN - 0x28600000: 693, // uk - 0x2860012e: 694, // uk-UA - 0x28c00000: 695, // ur - 0x28c00097: 696, // ur-IN - 0x28c000e6: 697, // ur-PK - 0x28d00000: 698, // uz - 0x28d05000: 699, // uz-Arab - 0x28d05023: 700, // uz-Arab-AF - 0x28d1e000: 701, // uz-Cyrl - 0x28d1e134: 702, // uz-Cyrl-UZ - 0x28d52000: 703, // uz-Latn - 0x28d52134: 704, // uz-Latn-UZ - 0x28e00000: 705, // vai - 0x28e52000: 706, // vai-Latn - 0x28e520b2: 707, // vai-Latn-LR - 0x28ed9000: 708, // vai-Vaii - 0x28ed90b2: 709, // vai-Vaii-LR - 0x28f00000: 710, // ve - 0x29200000: 711, // vi - 0x2920013b: 712, // vi-VN - 0x29700000: 713, // vo - 0x29700001: 714, // vo-001 - 0x29a00000: 715, // vun - 0x29a0012d: 716, // vun-TZ - 0x29b00000: 717, // wa - 0x29c00000: 718, // wae - 0x29c0004d: 719, // wae-CH - 0x2a400000: 720, // wo - 0x2a900000: 721, // xh - 0x2b100000: 722, // xog - 0x2b10012f: 723, // xog-UG - 0x2b700000: 724, // yav - 0x2b700051: 725, // yav-CM - 0x2b900000: 726, // yi - 0x2b900001: 727, // yi-001 - 0x2ba00000: 728, // yo - 0x2ba0003a: 729, // yo-BJ - 0x2ba000d4: 730, // yo-NG - 0x2bd00000: 731, // yue - 0x2bd0008b: 732, // yue-HK - 0x2c300000: 733, // zgh - 0x2c3000b8: 734, // zgh-MA - 0x2c400000: 735, // zh - 0x2c434000: 736, // zh-Hans - 0x2c434052: 737, // zh-Hans-CN - 0x2c43408b: 738, // zh-Hans-HK - 0x2c4340c4: 739, // zh-Hans-MO - 0x2c43410b: 740, // zh-Hans-SG - 0x2c435000: 741, // zh-Hant - 0x2c43508b: 742, // zh-Hant-HK - 0x2c4350c4: 743, // zh-Hant-MO - 0x2c43512c: 744, // zh-Hant-TW - 0x2c600000: 745, // zu - 0x2c60015e: 746, // zu-ZA -} - -// Total table size 4550 bytes (4KiB); checksum: B6D49547 diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/language.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/language.go deleted file mode 100644 index 5c6dcbd..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/language.go +++ /dev/null @@ -1,975 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate go run maketables.go gen_common.go -output tables.go -//go:generate go run gen_index.go - -// Package language implements BCP 47 language tags and related functionality. -// -// The Tag type, which is used to represent languages, is agnostic to the -// meaning of its subtags. Tags are not fully canonicalized to preserve -// information that may be valuable in certain contexts. As a consequence, two -// different tags may represent identical languages. -// -// Initializing language- or locale-specific components usually consists of -// two steps. The first step is to select a display language based on the -// preferred languages of the user and the languages supported by an application. -// The second step is to create the language-specific services based on -// this selection. Each is discussed in more details below. -// -// Matching preferred against supported languages -// -// An application may support various languages. This list is typically limited -// by the languages for which there exists translations of the user interface. -// Similarly, a user may provide a list of preferred languages which is limited -// by the languages understood by this user. -// An application should use a Matcher to find the best supported language based -// on the user's preferred list. -// Matchers are aware of the intricacies of equivalence between languages. -// The default Matcher implementation takes into account things such as -// deprecated subtags, legacy tags, and mutual intelligibility between scripts -// and languages. -// -// A Matcher for English, Australian English, Danish, and standard Mandarin can -// be defined as follows: -// -// var matcher = language.NewMatcher([]language.Tag{ -// language.English, // The first language is used as fallback. -// language.MustParse("en-AU"), -// language.Danish, -// language.Chinese, -// }) -// -// The following code selects the best match for someone speaking Spanish and -// Norwegian: -// -// preferred := []language.Tag{ language.Spanish, language.Norwegian } -// tag, _, _ := matcher.Match(preferred...) -// -// In this case, the best match is Danish, as Danish is sufficiently a match to -// Norwegian to not have to fall back to the default. -// See ParseAcceptLanguage on how to handle the Accept-Language HTTP header. -// -// Selecting language-specific services -// -// One should always use the Tag returned by the Matcher to create an instance -// of any of the language-specific services provided by the text repository. -// This prevents the mixing of languages, such as having a different language for -// messages and display names, as well as improper casing or sorting order for -// the selected language. -// Using the returned Tag also allows user-defined settings, such as collation -// order or numbering system to be transparently passed as options. -// -// If you have language-specific data in your application, however, it will in -// most cases suffice to use the index returned by the matcher to identify -// the user language. -// The following loop provides an alternative in case this is not sufficient: -// -// supported := map[language.Tag]data{ -// language.English: enData, -// language.MustParse("en-AU"): enAUData, -// language.Danish: daData, -// language.Chinese: zhData, -// } -// tag, _, _ := matcher.Match(preferred...) -// for ; tag != language.Und; tag = tag.Parent() { -// if v, ok := supported[tag]; ok { -// return v -// } -// } -// return enData // should not reach here -// -// Repeatedly taking the Parent of the tag returned by Match will eventually -// match one of the tags used to initialize the Matcher. -// -// Canonicalization -// -// By default, only legacy and deprecated tags are converted into their -// canonical equivalent. All other information is preserved. This approach makes -// the confidence scores more accurate and allows matchers to distinguish -// between variants that are otherwise lost. -// -// As a consequence, two tags that should be treated as identical according to -// BCP 47 or CLDR, like "en-Latn" and "en", will be represented differently. The -// Matchers will handle such distinctions, though, and are aware of the -// equivalence relations. The CanonType type can be used to alter the -// canonicalization form. -// -// References -// -// BCP 47 - Tags for Identifying Languages -// http://tools.ietf.org/html/bcp47 -package language - -// TODO: Remove above NOTE after: -// - verifying that tables are dropped correctly (most notably matcher tables). - -import ( - "errors" - "fmt" - "strings" -) - -const ( - // maxCoreSize is the maximum size of a BCP 47 tag without variants and - // extensions. Equals max lang (3) + script (4) + max reg (3) + 2 dashes. - maxCoreSize = 12 - - // max99thPercentileSize is a somewhat arbitrary buffer size that presumably - // is large enough to hold at least 99% of the BCP 47 tags. - max99thPercentileSize = 32 - - // maxSimpleUExtensionSize is the maximum size of a -u extension with one - // key-type pair. Equals len("-u-") + key (2) + dash + max value (8). - maxSimpleUExtensionSize = 14 -) - -// Tag represents a BCP 47 language tag. It is used to specify an instance of a -// specific language or locale. All language tag values are guaranteed to be -// well-formed. -type Tag struct { - lang langID - region regionID - script scriptID - pVariant byte // offset in str, includes preceding '-' - pExt uint16 // offset of first extension, includes preceding '-' - - // str is the string representation of the Tag. It will only be used if the - // tag has variants or extensions. - str string -} - -// Make is a convenience wrapper for Parse that omits the error. -// In case of an error, a sensible default is returned. -func Make(s string) Tag { - return Default.Make(s) -} - -// Make is a convenience wrapper for c.Parse that omits the error. -// In case of an error, a sensible default is returned. -func (c CanonType) Make(s string) Tag { - t, _ := c.Parse(s) - return t -} - -// Raw returns the raw base language, script and region, without making an -// attempt to infer their values. -func (t Tag) Raw() (b Base, s Script, r Region) { - return Base{t.lang}, Script{t.script}, Region{t.region} -} - -// equalTags compares language, script and region subtags only. -func (t Tag) equalTags(a Tag) bool { - return t.lang == a.lang && t.script == a.script && t.region == a.region -} - -// IsRoot returns true if t is equal to language "und". -func (t Tag) IsRoot() bool { - if int(t.pVariant) < len(t.str) { - return false - } - return t.equalTags(und) -} - -// private reports whether the Tag consists solely of a private use tag. -func (t Tag) private() bool { - return t.str != "" && t.pVariant == 0 -} - -// CanonType can be used to enable or disable various types of canonicalization. -type CanonType int - -const ( - // Replace deprecated base languages with their preferred replacements. - DeprecatedBase CanonType = 1 << iota - // Replace deprecated scripts with their preferred replacements. - DeprecatedScript - // Replace deprecated regions with their preferred replacements. - DeprecatedRegion - // Remove redundant scripts. - SuppressScript - // Normalize legacy encodings. This includes legacy languages defined in - // CLDR as well as bibliographic codes defined in ISO-639. - Legacy - // Map the dominant language of a macro language group to the macro language - // subtag. For example cmn -> zh. - Macro - // The CLDR flag should be used if full compatibility with CLDR is required. - // There are a few cases where language.Tag may differ from CLDR. To follow all - // of CLDR's suggestions, use All|CLDR. - CLDR - - // Raw can be used to Compose or Parse without Canonicalization. - Raw CanonType = 0 - - // Replace all deprecated tags with their preferred replacements. - Deprecated = DeprecatedBase | DeprecatedScript | DeprecatedRegion - - // All canonicalizations recommended by BCP 47. - BCP47 = Deprecated | SuppressScript - - // All canonicalizations. - All = BCP47 | Legacy | Macro - - // Default is the canonicalization used by Parse, Make and Compose. To - // preserve as much information as possible, canonicalizations that remove - // potentially valuable information are not included. The Matcher is - // designed to recognize similar tags that would be the same if - // they were canonicalized using All. - Default = Deprecated | Legacy - - canonLang = DeprecatedBase | Legacy | Macro - - // TODO: LikelyScript, LikelyRegion: suppress similar to ICU. -) - -// canonicalize returns the canonicalized equivalent of the tag and -// whether there was any change. -func (t Tag) canonicalize(c CanonType) (Tag, bool) { - if c == Raw { - return t, false - } - changed := false - if c&SuppressScript != 0 { - if t.lang < langNoIndexOffset && uint8(t.script) == suppressScript[t.lang] { - t.script = 0 - changed = true - } - } - if c&canonLang != 0 { - for { - if l, aliasType := normLang(t.lang); l != t.lang { - switch aliasType { - case langLegacy: - if c&Legacy != 0 { - if t.lang == _sh && t.script == 0 { - t.script = _Latn - } - t.lang = l - changed = true - } - case langMacro: - if c&Macro != 0 { - // We deviate here from CLDR. The mapping "nb" -> "no" - // qualifies as a typical Macro language mapping. However, - // for legacy reasons, CLDR maps "no", the macro language - // code for Norwegian, to the dominant variant "nb". This - // change is currently under consideration for CLDR as well. - // See http://unicode.org/cldr/trac/ticket/2698 and also - // http://unicode.org/cldr/trac/ticket/1790 for some of the - // practical implications. TODO: this check could be removed - // if CLDR adopts this change. - if c&CLDR == 0 || t.lang != _nb { - changed = true - t.lang = l - } - } - case langDeprecated: - if c&DeprecatedBase != 0 { - if t.lang == _mo && t.region == 0 { - t.region = _MD - } - t.lang = l - changed = true - // Other canonicalization types may still apply. - continue - } - } - } else if c&Legacy != 0 && t.lang == _no && c&CLDR != 0 { - t.lang = _nb - changed = true - } - break - } - } - if c&DeprecatedScript != 0 { - if t.script == _Qaai { - changed = true - t.script = _Zinh - } - } - if c&DeprecatedRegion != 0 { - if r := normRegion(t.region); r != 0 { - changed = true - t.region = r - } - } - return t, changed -} - -// Canonicalize returns the canonicalized equivalent of the tag. -func (c CanonType) Canonicalize(t Tag) (Tag, error) { - t, changed := t.canonicalize(c) - if changed { - t.remakeString() - } - return t, nil -} - -// Confidence indicates the level of certainty for a given return value. -// For example, Serbian may be written in Cyrillic or Latin script. -// The confidence level indicates whether a value was explicitly specified, -// whether it is typically the only possible value, or whether there is -// an ambiguity. -type Confidence int - -const ( - No Confidence = iota // full confidence that there was no match - Low // most likely value picked out of a set of alternatives - High // value is generally assumed to be the correct match - Exact // exact match or explicitly specified value -) - -var confName = []string{"No", "Low", "High", "Exact"} - -func (c Confidence) String() string { - return confName[c] -} - -// remakeString is used to update t.str in case lang, script or region changed. -// It is assumed that pExt and pVariant still point to the start of the -// respective parts. -func (t *Tag) remakeString() { - if t.str == "" { - return - } - extra := t.str[t.pVariant:] - if t.pVariant > 0 { - extra = extra[1:] - } - if t.equalTags(und) && strings.HasPrefix(extra, "x-") { - t.str = extra - t.pVariant = 0 - t.pExt = 0 - return - } - var buf [max99thPercentileSize]byte // avoid extra memory allocation in most cases. - b := buf[:t.genCoreBytes(buf[:])] - if extra != "" { - diff := len(b) - int(t.pVariant) - b = append(b, '-') - b = append(b, extra...) - t.pVariant = uint8(int(t.pVariant) + diff) - t.pExt = uint16(int(t.pExt) + diff) - } else { - t.pVariant = uint8(len(b)) - t.pExt = uint16(len(b)) - } - t.str = string(b) -} - -// genCoreBytes writes a string for the base languages, script and region tags -// to the given buffer and returns the number of bytes written. It will never -// write more than maxCoreSize bytes. -func (t *Tag) genCoreBytes(buf []byte) int { - n := t.lang.stringToBuf(buf[:]) - if t.script != 0 { - n += copy(buf[n:], "-") - n += copy(buf[n:], t.script.String()) - } - if t.region != 0 { - n += copy(buf[n:], "-") - n += copy(buf[n:], t.region.String()) - } - return n -} - -// String returns the canonical string representation of the language tag. -func (t Tag) String() string { - if t.str != "" { - return t.str - } - if t.script == 0 && t.region == 0 { - return t.lang.String() - } - buf := [maxCoreSize]byte{} - return string(buf[:t.genCoreBytes(buf[:])]) -} - -// Base returns the base language of the language tag. If the base language is -// unspecified, an attempt will be made to infer it from the context. -// It uses a variant of CLDR's Add Likely Subtags algorithm. This is subject to change. -func (t Tag) Base() (Base, Confidence) { - if t.lang != 0 { - return Base{t.lang}, Exact - } - c := High - if t.script == 0 && !(Region{t.region}).IsCountry() { - c = Low - } - if tag, err := addTags(t); err == nil && tag.lang != 0 { - return Base{tag.lang}, c - } - return Base{0}, No -} - -// Script infers the script for the language tag. If it was not explicitly given, it will infer -// a most likely candidate. -// If more than one script is commonly used for a language, the most likely one -// is returned with a low confidence indication. For example, it returns (Cyrl, Low) -// for Serbian. -// If a script cannot be inferred (Zzzz, No) is returned. We do not use Zyyy (undetermined) -// as one would suspect from the IANA registry for BCP 47. In a Unicode context Zyyy marks -// common characters (like 1, 2, 3, '.', etc.) and is therefore more like multiple scripts. -// See http://www.unicode.org/reports/tr24/#Values for more details. Zzzz is also used for -// unknown value in CLDR. (Zzzz, Exact) is returned if Zzzz was explicitly specified. -// Note that an inferred script is never guaranteed to be the correct one. Latin is -// almost exclusively used for Afrikaans, but Arabic has been used for some texts -// in the past. Also, the script that is commonly used may change over time. -// It uses a variant of CLDR's Add Likely Subtags algorithm. This is subject to change. -func (t Tag) Script() (Script, Confidence) { - if t.script != 0 { - return Script{t.script}, Exact - } - sc, c := scriptID(_Zzzz), No - if t.lang < langNoIndexOffset { - if scr := scriptID(suppressScript[t.lang]); scr != 0 { - // Note: it is not always the case that a language with a suppress - // script value is only written in one script (e.g. kk, ms, pa). - if t.region == 0 { - return Script{scriptID(scr)}, High - } - sc, c = scr, High - } - } - if tag, err := addTags(t); err == nil { - if tag.script != sc { - sc, c = tag.script, Low - } - } else { - t, _ = (Deprecated | Macro).Canonicalize(t) - if tag, err := addTags(t); err == nil && tag.script != sc { - sc, c = tag.script, Low - } - } - return Script{sc}, c -} - -// Region returns the region for the language tag. If it was not explicitly given, it will -// infer a most likely candidate from the context. -// It uses a variant of CLDR's Add Likely Subtags algorithm. This is subject to change. -func (t Tag) Region() (Region, Confidence) { - if t.region != 0 { - return Region{t.region}, Exact - } - if t, err := addTags(t); err == nil { - return Region{t.region}, Low // TODO: differentiate between high and low. - } - t, _ = (Deprecated | Macro).Canonicalize(t) - if tag, err := addTags(t); err == nil { - return Region{tag.region}, Low - } - return Region{_ZZ}, No // TODO: return world instead of undetermined? -} - -// Variant returns the variants specified explicitly for this language tag. -// or nil if no variant was specified. -func (t Tag) Variants() []Variant { - v := []Variant{} - if int(t.pVariant) < int(t.pExt) { - for x, str := "", t.str[t.pVariant:t.pExt]; str != ""; { - x, str = nextToken(str) - v = append(v, Variant{x}) - } - } - return v -} - -// Parent returns the CLDR parent of t. In CLDR, missing fields in data for a -// specific language are substituted with fields from the parent language. -// The parent for a language may change for newer versions of CLDR. -func (t Tag) Parent() Tag { - if t.str != "" { - // Strip the variants and extensions. - t, _ = Raw.Compose(t.Raw()) - if t.region == 0 && t.script != 0 && t.lang != 0 { - base, _ := addTags(Tag{lang: t.lang}) - if base.script == t.script { - return Tag{lang: t.lang} - } - } - return t - } - if t.lang != 0 { - if t.region != 0 { - maxScript := t.script - if maxScript == 0 { - max, _ := addTags(t) - maxScript = max.script - } - - for i := range parents { - if langID(parents[i].lang) == t.lang && scriptID(parents[i].maxScript) == maxScript { - for _, r := range parents[i].fromRegion { - if regionID(r) == t.region { - return Tag{ - lang: t.lang, - script: scriptID(parents[i].script), - region: regionID(parents[i].toRegion), - } - } - } - } - } - - // Strip the script if it is the default one. - base, _ := addTags(Tag{lang: t.lang}) - if base.script != maxScript { - return Tag{lang: t.lang, script: maxScript} - } - return Tag{lang: t.lang} - } else if t.script != 0 { - // The parent for an base-script pair with a non-default script is - // "und" instead of the base language. - base, _ := addTags(Tag{lang: t.lang}) - if base.script != t.script { - return und - } - return Tag{lang: t.lang} - } - } - return und -} - -// returns token t and the rest of the string. -func nextToken(s string) (t, tail string) { - p := strings.Index(s[1:], "-") - if p == -1 { - return s[1:], "" - } - p++ - return s[1:p], s[p:] -} - -// Extension is a single BCP 47 extension. -type Extension struct { - s string -} - -// String returns the string representation of the extension, including the -// type tag. -func (e Extension) String() string { - return e.s -} - -// ParseExtension parses s as an extension and returns it on success. -func ParseExtension(s string) (e Extension, err error) { - scan := makeScannerString(s) - var end int - if n := len(scan.token); n != 1 { - return Extension{}, errSyntax - } - scan.toLower(0, len(scan.b)) - end = parseExtension(&scan) - if end != len(s) { - return Extension{}, errSyntax - } - return Extension{string(scan.b)}, nil -} - -// Type returns the one-byte extension type of e. It returns 0 for the zero -// exception. -func (e Extension) Type() byte { - if e.s == "" { - return 0 - } - return e.s[0] -} - -// Tokens returns the list of tokens of e. -func (e Extension) Tokens() []string { - return strings.Split(e.s, "-") -} - -// Extension returns the extension of type x for tag t. It will return -// false for ok if t does not have the requested extension. The returned -// extension will be invalid in this case. -func (t Tag) Extension(x byte) (ext Extension, ok bool) { - for i := int(t.pExt); i < len(t.str)-1; { - var ext string - i, ext = getExtension(t.str, i) - if ext[0] == x { - return Extension{ext}, true - } - } - return Extension{string(x)}, false -} - -// Extensions returns all extensions of t. -func (t Tag) Extensions() []Extension { - e := []Extension{} - for i := int(t.pExt); i < len(t.str)-1; { - var ext string - i, ext = getExtension(t.str, i) - e = append(e, Extension{ext}) - } - return e -} - -// TypeForKey returns the type associated with the given key, where key and type -// are of the allowed values defined for the Unicode locale extension ('u') in -// http://www.unicode.org/reports/tr35/#Unicode_Language_and_Locale_Identifiers. -// TypeForKey will traverse the inheritance chain to get the correct value. -func (t Tag) TypeForKey(key string) string { - if start, end, _ := t.findTypeForKey(key); end != start { - return t.str[start:end] - } - return "" -} - -var ( - errPrivateUse = errors.New("cannot set a key on a private use tag") - errInvalidArguments = errors.New("invalid key or type") -) - -// SetTypeForKey returns a new Tag with the key set to type, where key and type -// are of the allowed values defined for the Unicode locale extension ('u') in -// http://www.unicode.org/reports/tr35/#Unicode_Language_and_Locale_Identifiers. -// An empty value removes an existing pair with the same key. -func (t Tag) SetTypeForKey(key, value string) (Tag, error) { - if t.private() { - return t, errPrivateUse - } - if len(key) != 2 { - return t, errInvalidArguments - } - - // Remove the setting if value is "". - if value == "" { - start, end, _ := t.findTypeForKey(key) - if start != end { - // Remove key tag and leading '-'. - start -= 4 - - // Remove a possible empty extension. - if (end == len(t.str) || t.str[end+2] == '-') && t.str[start-2] == '-' { - start -= 2 - } - if start == int(t.pVariant) && end == len(t.str) { - t.str = "" - t.pVariant, t.pExt = 0, 0 - } else { - t.str = fmt.Sprintf("%s%s", t.str[:start], t.str[end:]) - } - } - return t, nil - } - - if len(value) < 3 || len(value) > 8 { - return t, errInvalidArguments - } - - var ( - buf [maxCoreSize + maxSimpleUExtensionSize]byte - uStart int // start of the -u extension. - ) - - // Generate the tag string if needed. - if t.str == "" { - uStart = t.genCoreBytes(buf[:]) - buf[uStart] = '-' - uStart++ - } - - // Create new key-type pair and parse it to verify. - b := buf[uStart:] - copy(b, "u-") - copy(b[2:], key) - b[4] = '-' - b = b[:5+copy(b[5:], value)] - scan := makeScanner(b) - if parseExtensions(&scan); scan.err != nil { - return t, scan.err - } - - // Assemble the replacement string. - if t.str == "" { - t.pVariant, t.pExt = byte(uStart-1), uint16(uStart-1) - t.str = string(buf[:uStart+len(b)]) - } else { - s := t.str - start, end, hasExt := t.findTypeForKey(key) - if start == end { - if hasExt { - b = b[2:] - } - t.str = fmt.Sprintf("%s-%s%s", s[:start], b, s[end:]) - } else { - t.str = fmt.Sprintf("%s%s%s", s[:start], value, s[end:]) - } - } - return t, nil -} - -// findKeyAndType returns the start and end position for the type corresponding -// to key or the point at which to insert the key-value pair if the type -// wasn't found. The hasExt return value reports whether an -u extension was present. -// Note: the extensions are typically very small and are likely to contain -// only one key-type pair. -func (t Tag) findTypeForKey(key string) (start, end int, hasExt bool) { - p := int(t.pExt) - if len(key) != 2 || p == len(t.str) || p == 0 { - return p, p, false - } - s := t.str - - // Find the correct extension. - for p++; s[p] != 'u'; p++ { - if s[p] > 'u' { - p-- - return p, p, false - } - if p = nextExtension(s, p); p == len(s) { - return len(s), len(s), false - } - } - // Proceed to the hyphen following the extension name. - p++ - - // curKey is the key currently being processed. - curKey := "" - - // Iterate over keys until we get the end of a section. - for { - // p points to the hyphen preceding the current token. - if p3 := p + 3; s[p3] == '-' { - // Found a key. - // Check whether we just processed the key that was requested. - if curKey == key { - return start, p, true - } - // Set to the next key and continue scanning type tokens. - curKey = s[p+1 : p3] - if curKey > key { - return p, p, true - } - // Start of the type token sequence. - start = p + 4 - // A type is at least 3 characters long. - p += 7 // 4 + 3 - } else { - // Attribute or type, which is at least 3 characters long. - p += 4 - } - // p points past the third character of a type or attribute. - max := p + 5 // maximum length of token plus hyphen. - if len(s) < max { - max = len(s) - } - for ; p < max && s[p] != '-'; p++ { - } - // Bail if we have exhausted all tokens or if the next token starts - // a new extension. - if p == len(s) || s[p+2] == '-' { - if curKey == key { - return start, p, true - } - return p, p, true - } - } -} - -// CompactIndex returns an index, where 0 <= index < NumCompactTags, for tags -// for which data exists in the text repository. The index will change over time -// and should not be stored in persistent storage. Extensions, except for the -// 'va' type of the 'u' extension, are ignored. It will return 0, false if no -// compact tag exists, where 0 is the index for the root language (Und). -func CompactIndex(t Tag) (index int, ok bool) { - // TODO: perhaps give more frequent tags a lower index. - // TODO: we could make the indexes stable. This will excluded some - // possibilities for optimization, so don't do this quite yet. - b, s, r := t.Raw() - if len(t.str) > 0 { - if strings.HasPrefix(t.str, "x-") { - // We have no entries for user-defined tags. - return 0, false - } - if uint16(t.pVariant) != t.pExt { - // There are no tags with variants and an u-va type. - if t.TypeForKey("va") != "" { - return 0, false - } - t, _ = Raw.Compose(b, s, r, t.Variants()) - } else if _, ok := t.Extension('u'); ok { - // Strip all but the 'va' entry. - variant := t.TypeForKey("va") - t, _ = Raw.Compose(b, s, r) - t, _ = t.SetTypeForKey("va", variant) - } - if len(t.str) > 0 { - // We have some variants. - for i, s := range specialTags { - if s == t { - return i + 1, true - } - } - return 0, false - } - } - // No variants specified: just compare core components. - // The key has the form lllssrrr, where l, s, and r are nibbles for - // respectively the langID, scriptID, and regionID. - key := uint32(b.langID) << (8 + 12) - key |= uint32(s.scriptID) << 12 - key |= uint32(r.regionID) - x, ok := coreTags[key] - return int(x), ok -} - -// Base is an ISO 639 language code, used for encoding the base language -// of a language tag. -type Base struct { - langID -} - -// ParseBase parses a 2- or 3-letter ISO 639 code. -// It returns a ValueError if s is a well-formed but unknown language identifier -// or another error if another error occurred. -func ParseBase(s string) (Base, error) { - if n := len(s); n < 2 || 3 < n { - return Base{}, errSyntax - } - var buf [3]byte - l, err := getLangID(buf[:copy(buf[:], s)]) - return Base{l}, err -} - -// Script is a 4-letter ISO 15924 code for representing scripts. -// It is idiomatically represented in title case. -type Script struct { - scriptID -} - -// ParseScript parses a 4-letter ISO 15924 code. -// It returns a ValueError if s is a well-formed but unknown script identifier -// or another error if another error occurred. -func ParseScript(s string) (Script, error) { - if len(s) != 4 { - return Script{}, errSyntax - } - var buf [4]byte - sc, err := getScriptID(script, buf[:copy(buf[:], s)]) - return Script{sc}, err -} - -// Region is an ISO 3166-1 or UN M.49 code for representing countries and regions. -type Region struct { - regionID -} - -// EncodeM49 returns the Region for the given UN M.49 code. -// It returns an error if r is not a valid code. -func EncodeM49(r int) (Region, error) { - rid, err := getRegionM49(r) - return Region{rid}, err -} - -// ParseRegion parses a 2- or 3-letter ISO 3166-1 or a UN M.49 code. -// It returns a ValueError if s is a well-formed but unknown region identifier -// or another error if another error occurred. -func ParseRegion(s string) (Region, error) { - if n := len(s); n < 2 || 3 < n { - return Region{}, errSyntax - } - var buf [3]byte - r, err := getRegionID(buf[:copy(buf[:], s)]) - return Region{r}, err -} - -// IsCountry returns whether this region is a country or autonomous area. This -// includes non-standard definitions from CLDR. -func (r Region) IsCountry() bool { - if r.regionID == 0 || r.IsGroup() || r.IsPrivateUse() && r.regionID != _XK { - return false - } - return true -} - -// IsGroup returns whether this region defines a collection of regions. This -// includes non-standard definitions from CLDR. -func (r Region) IsGroup() bool { - if r.regionID == 0 { - return false - } - return int(regionInclusion[r.regionID]) < len(regionContainment) -} - -// Contains returns whether Region c is contained by Region r. It returns true -// if c == r. -func (r Region) Contains(c Region) bool { - return r.regionID.contains(c.regionID) -} - -func (r regionID) contains(c regionID) bool { - if r == c { - return true - } - g := regionInclusion[r] - if g >= nRegionGroups { - return false - } - m := regionContainment[g] - - d := regionInclusion[c] - b := regionInclusionBits[d] - - // A contained country may belong to multiple disjoint groups. Matching any - // of these indicates containment. If the contained region is a group, it - // must strictly be a subset. - if d >= nRegionGroups { - return b&m != 0 - } - return b&^m == 0 -} - -var errNoTLD = errors.New("language: region is not a valid ccTLD") - -// TLD returns the country code top-level domain (ccTLD). UK is returned for GB. -// In all other cases it returns either the region itself or an error. -// -// This method may return an error for a region for which there exists a -// canonical form with a ccTLD. To get that ccTLD canonicalize r first. The -// region will already be canonicalized it was obtained from a Tag that was -// obtained using any of the default methods. -func (r Region) TLD() (Region, error) { - // See http://en.wikipedia.org/wiki/Country_code_top-level_domain for the - // difference between ISO 3166-1 and IANA ccTLD. - if r.regionID == _GB { - r = Region{_UK} - } - if (r.typ() & ccTLD) == 0 { - return Region{}, errNoTLD - } - return r, nil -} - -// Canonicalize returns the region or a possible replacement if the region is -// deprecated. It will not return a replacement for deprecated regions that -// are split into multiple regions. -func (r Region) Canonicalize() Region { - if cr := normRegion(r.regionID); cr != 0 { - return Region{cr} - } - return r -} - -// Variant represents a registered variant of a language as defined by BCP 47. -type Variant struct { - variant string -} - -// ParseVariant parses and returns a Variant. An error is returned if s is not -// a valid variant. -func ParseVariant(s string) (Variant, error) { - s = strings.ToLower(s) - if _, ok := variantIndex[s]; ok { - return Variant{s}, nil - } - return Variant{}, mkErrInvalid([]byte(s)) -} - -// String returns the string representation of the variant. -func (v Variant) String() string { - return v.variant -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/lookup.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/lookup.go deleted file mode 100644 index 1d80ac3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/lookup.go +++ /dev/null @@ -1,396 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package language - -import ( - "bytes" - "fmt" - "sort" - "strconv" - - "golang.org/x/text/internal/tag" -) - -// findIndex tries to find the given tag in idx and returns a standardized error -// if it could not be found. -func findIndex(idx tag.Index, key []byte, form string) (index int, err error) { - if !tag.FixCase(form, key) { - return 0, errSyntax - } - i := idx.Index(key) - if i == -1 { - return 0, mkErrInvalid(key) - } - return i, nil -} - -func searchUint(imap []uint16, key uint16) int { - return sort.Search(len(imap), func(i int) bool { - return imap[i] >= key - }) -} - -type langID uint16 - -// getLangID returns the langID of s if s is a canonical subtag -// or langUnknown if s is not a canonical subtag. -func getLangID(s []byte) (langID, error) { - if len(s) == 2 { - return getLangISO2(s) - } - return getLangISO3(s) -} - -// mapLang returns the mapped langID of id according to mapping m. -func normLang(id langID) (langID, langAliasType) { - k := sort.Search(len(langAliasMap), func(i int) bool { - return langAliasMap[i].from >= uint16(id) - }) - if k < len(langAliasMap) && langAliasMap[k].from == uint16(id) { - return langID(langAliasMap[k].to), langAliasTypes[k] - } - return id, langAliasTypeUnknown -} - -// getLangISO2 returns the langID for the given 2-letter ISO language code -// or unknownLang if this does not exist. -func getLangISO2(s []byte) (langID, error) { - if !tag.FixCase("zz", s) { - return 0, errSyntax - } - if i := lang.Index(s); i != -1 && lang.Elem(i)[3] != 0 { - return langID(i), nil - } - return 0, mkErrInvalid(s) -} - -const base = 'z' - 'a' + 1 - -func strToInt(s []byte) uint { - v := uint(0) - for i := 0; i < len(s); i++ { - v *= base - v += uint(s[i] - 'a') - } - return v -} - -// converts the given integer to the original ASCII string passed to strToInt. -// len(s) must match the number of characters obtained. -func intToStr(v uint, s []byte) { - for i := len(s) - 1; i >= 0; i-- { - s[i] = byte(v%base) + 'a' - v /= base - } -} - -// getLangISO3 returns the langID for the given 3-letter ISO language code -// or unknownLang if this does not exist. -func getLangISO3(s []byte) (langID, error) { - if tag.FixCase("und", s) { - // first try to match canonical 3-letter entries - for i := lang.Index(s[:2]); i != -1; i = lang.Next(s[:2], i) { - if e := lang.Elem(i); e[3] == 0 && e[2] == s[2] { - // We treat "und" as special and always translate it to "unspecified". - // Note that ZZ and Zzzz are private use and are not treated as - // unspecified by default. - id := langID(i) - if id == nonCanonicalUnd { - return 0, nil - } - return id, nil - } - } - if i := altLangISO3.Index(s); i != -1 { - return langID(altLangIndex[altLangISO3.Elem(i)[3]]), nil - } - n := strToInt(s) - if langNoIndex[n/8]&(1<<(n%8)) != 0 { - return langID(n) + langNoIndexOffset, nil - } - // Check for non-canonical uses of ISO3. - for i := lang.Index(s[:1]); i != -1; i = lang.Next(s[:1], i) { - if e := lang.Elem(i); e[2] == s[1] && e[3] == s[2] { - return langID(i), nil - } - } - return 0, mkErrInvalid(s) - } - return 0, errSyntax -} - -// stringToBuf writes the string to b and returns the number of bytes -// written. cap(b) must be >= 3. -func (id langID) stringToBuf(b []byte) int { - if id >= langNoIndexOffset { - intToStr(uint(id)-langNoIndexOffset, b[:3]) - return 3 - } else if id == 0 { - return copy(b, "und") - } - l := lang[id<<2:] - if l[3] == 0 { - return copy(b, l[:3]) - } - return copy(b, l[:2]) -} - -// String returns the BCP 47 representation of the langID. -// Use b as variable name, instead of id, to ensure the variable -// used is consistent with that of Base in which this type is embedded. -func (b langID) String() string { - if b == 0 { - return "und" - } else if b >= langNoIndexOffset { - b -= langNoIndexOffset - buf := [3]byte{} - intToStr(uint(b), buf[:]) - return string(buf[:]) - } - l := lang.Elem(int(b)) - if l[3] == 0 { - return l[:3] - } - return l[:2] -} - -// ISO3 returns the ISO 639-3 language code. -func (b langID) ISO3() string { - if b == 0 || b >= langNoIndexOffset { - return b.String() - } - l := lang.Elem(int(b)) - if l[3] == 0 { - return l[:3] - } else if l[2] == 0 { - return altLangISO3.Elem(int(l[3]))[:3] - } - // This allocation will only happen for 3-letter ISO codes - // that are non-canonical BCP 47 language identifiers. - return l[0:1] + l[2:4] -} - -// IsPrivateUse reports whether this language code is reserved for private use. -func (b langID) IsPrivateUse() bool { - return langPrivateStart <= b && b <= langPrivateEnd -} - -type regionID uint16 - -// getRegionID returns the region id for s if s is a valid 2-letter region code -// or unknownRegion. -func getRegionID(s []byte) (regionID, error) { - if len(s) == 3 { - if isAlpha(s[0]) { - return getRegionISO3(s) - } - if i, err := strconv.ParseUint(string(s), 10, 10); err == nil { - return getRegionM49(int(i)) - } - } - return getRegionISO2(s) -} - -// getRegionISO2 returns the regionID for the given 2-letter ISO country code -// or unknownRegion if this does not exist. -func getRegionISO2(s []byte) (regionID, error) { - i, err := findIndex(regionISO, s, "ZZ") - if err != nil { - return 0, err - } - return regionID(i) + isoRegionOffset, nil -} - -// getRegionISO3 returns the regionID for the given 3-letter ISO country code -// or unknownRegion if this does not exist. -func getRegionISO3(s []byte) (regionID, error) { - if tag.FixCase("ZZZ", s) { - for i := regionISO.Index(s[:1]); i != -1; i = regionISO.Next(s[:1], i) { - if e := regionISO.Elem(i); e[2] == s[1] && e[3] == s[2] { - return regionID(i) + isoRegionOffset, nil - } - } - for i := 0; i < len(altRegionISO3); i += 3 { - if tag.Compare(altRegionISO3[i:i+3], s) == 0 { - return regionID(altRegionIDs[i/3]), nil - } - } - return 0, mkErrInvalid(s) - } - return 0, errSyntax -} - -func getRegionM49(n int) (regionID, error) { - if 0 < n && n <= 999 { - const ( - searchBits = 7 - regionBits = 9 - regionMask = 1<<regionBits - 1 - ) - idx := n >> searchBits - buf := fromM49[m49Index[idx]:m49Index[idx+1]] - val := uint16(n) << regionBits // we rely on bits shifting out - i := sort.Search(len(buf), func(i int) bool { - return buf[i] >= val - }) - if r := fromM49[int(m49Index[idx])+i]; r&^regionMask == val { - return regionID(r & regionMask), nil - } - } - var e ValueError - fmt.Fprint(bytes.NewBuffer([]byte(e.v[:])), n) - return 0, e -} - -// normRegion returns a region if r is deprecated or 0 otherwise. -// TODO: consider supporting BYS (-> BLR), CSK (-> 200 or CZ), PHI (-> PHL) and AFI (-> DJ). -// TODO: consider mapping split up regions to new most populous one (like CLDR). -func normRegion(r regionID) regionID { - m := regionOldMap - k := sort.Search(len(m), func(i int) bool { - return m[i].from >= uint16(r) - }) - if k < len(m) && m[k].from == uint16(r) { - return regionID(m[k].to) - } - return 0 -} - -const ( - iso3166UserAssigned = 1 << iota - ccTLD - bcp47Region -) - -func (r regionID) typ() byte { - return regionTypes[r] -} - -// String returns the BCP 47 representation for the region. -// It returns "ZZ" for an unspecified region. -func (r regionID) String() string { - if r < isoRegionOffset { - if r == 0 { - return "ZZ" - } - return fmt.Sprintf("%03d", r.M49()) - } - r -= isoRegionOffset - return regionISO.Elem(int(r))[:2] -} - -// ISO3 returns the 3-letter ISO code of r. -// Note that not all regions have a 3-letter ISO code. -// In such cases this method returns "ZZZ". -func (r regionID) ISO3() string { - if r < isoRegionOffset { - return "ZZZ" - } - r -= isoRegionOffset - reg := regionISO.Elem(int(r)) - switch reg[2] { - case 0: - return altRegionISO3[reg[3]:][:3] - case ' ': - return "ZZZ" - } - return reg[0:1] + reg[2:4] -} - -// M49 returns the UN M.49 encoding of r, or 0 if this encoding -// is not defined for r. -func (r regionID) M49() int { - return int(m49[r]) -} - -// IsPrivateUse reports whether r has the ISO 3166 User-assigned status. This -// may include private-use tags that are assigned by CLDR and used in this -// implementation. So IsPrivateUse and IsCountry can be simultaneously true. -func (r regionID) IsPrivateUse() bool { - return r.typ()&iso3166UserAssigned != 0 -} - -type scriptID uint8 - -// getScriptID returns the script id for string s. It assumes that s -// is of the format [A-Z][a-z]{3}. -func getScriptID(idx tag.Index, s []byte) (scriptID, error) { - i, err := findIndex(idx, s, "Zzzz") - return scriptID(i), err -} - -// String returns the script code in title case. -// It returns "Zzzz" for an unspecified script. -func (s scriptID) String() string { - if s == 0 { - return "Zzzz" - } - return script.Elem(int(s)) -} - -// IsPrivateUse reports whether this script code is reserved for private use. -func (s scriptID) IsPrivateUse() bool { - return _Qaaa <= s && s <= _Qabx -} - -const ( - maxAltTaglen = len("en-US-POSIX") - maxLen = maxAltTaglen -) - -var ( - // grandfatheredMap holds a mapping from legacy and grandfathered tags to - // their base language or index to more elaborate tag. - grandfatheredMap = map[[maxLen]byte]int16{ - [maxLen]byte{'a', 'r', 't', '-', 'l', 'o', 'j', 'b', 'a', 'n'}: _jbo, // art-lojban - [maxLen]byte{'i', '-', 'a', 'm', 'i'}: _ami, // i-ami - [maxLen]byte{'i', '-', 'b', 'n', 'n'}: _bnn, // i-bnn - [maxLen]byte{'i', '-', 'h', 'a', 'k'}: _hak, // i-hak - [maxLen]byte{'i', '-', 'k', 'l', 'i', 'n', 'g', 'o', 'n'}: _tlh, // i-klingon - [maxLen]byte{'i', '-', 'l', 'u', 'x'}: _lb, // i-lux - [maxLen]byte{'i', '-', 'n', 'a', 'v', 'a', 'j', 'o'}: _nv, // i-navajo - [maxLen]byte{'i', '-', 'p', 'w', 'n'}: _pwn, // i-pwn - [maxLen]byte{'i', '-', 't', 'a', 'o'}: _tao, // i-tao - [maxLen]byte{'i', '-', 't', 'a', 'y'}: _tay, // i-tay - [maxLen]byte{'i', '-', 't', 's', 'u'}: _tsu, // i-tsu - [maxLen]byte{'n', 'o', '-', 'b', 'o', 'k'}: _nb, // no-bok - [maxLen]byte{'n', 'o', '-', 'n', 'y', 'n'}: _nn, // no-nyn - [maxLen]byte{'s', 'g', 'n', '-', 'b', 'e', '-', 'f', 'r'}: _sfb, // sgn-BE-FR - [maxLen]byte{'s', 'g', 'n', '-', 'b', 'e', '-', 'n', 'l'}: _vgt, // sgn-BE-NL - [maxLen]byte{'s', 'g', 'n', '-', 'c', 'h', '-', 'd', 'e'}: _sgg, // sgn-CH-DE - [maxLen]byte{'z', 'h', '-', 'g', 'u', 'o', 'y', 'u'}: _cmn, // zh-guoyu - [maxLen]byte{'z', 'h', '-', 'h', 'a', 'k', 'k', 'a'}: _hak, // zh-hakka - [maxLen]byte{'z', 'h', '-', 'm', 'i', 'n', '-', 'n', 'a', 'n'}: _nan, // zh-min-nan - [maxLen]byte{'z', 'h', '-', 'x', 'i', 'a', 'n', 'g'}: _hsn, // zh-xiang - - // Grandfathered tags with no modern replacement will be converted as - // follows: - [maxLen]byte{'c', 'e', 'l', '-', 'g', 'a', 'u', 'l', 'i', 's', 'h'}: -1, // cel-gaulish - [maxLen]byte{'e', 'n', '-', 'g', 'b', '-', 'o', 'e', 'd'}: -2, // en-GB-oed - [maxLen]byte{'i', '-', 'd', 'e', 'f', 'a', 'u', 'l', 't'}: -3, // i-default - [maxLen]byte{'i', '-', 'e', 'n', 'o', 'c', 'h', 'i', 'a', 'n'}: -4, // i-enochian - [maxLen]byte{'i', '-', 'm', 'i', 'n', 'g', 'o'}: -5, // i-mingo - [maxLen]byte{'z', 'h', '-', 'm', 'i', 'n'}: -6, // zh-min - - // CLDR-specific tag. - [maxLen]byte{'r', 'o', 'o', 't'}: 0, // root - [maxLen]byte{'e', 'n', '-', 'u', 's', '-', 'p', 'o', 's', 'i', 'x'}: -7, // en_US_POSIX" - } - - altTagIndex = [...]uint8{0, 17, 31, 45, 61, 74, 86, 102} - - altTags = "xtg-x-cel-gaulishen-GB-oxendicten-x-i-defaultund-x-i-enochiansee-x-i-mingonan-x-zh-minen-US-u-va-posix" -) - -func grandfathered(s [maxAltTaglen]byte) (t Tag, ok bool) { - if v, ok := grandfatheredMap[s]; ok { - if v < 0 { - return Make(altTags[altTagIndex[-v-1]:altTagIndex[-v]]), true - } - t.lang = langID(v) - return t, true - } - return t, false -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/maketables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/maketables.go deleted file mode 100644 index 2cc995b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/maketables.go +++ /dev/null @@ -1,1635 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -// Language tag table generator. -// Data read from the web. - -package main - -import ( - "bufio" - "flag" - "fmt" - "io" - "io/ioutil" - "log" - "math" - "reflect" - "regexp" - "sort" - "strconv" - "strings" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/tag" - "golang.org/x/text/unicode/cldr" -) - -var ( - test = flag.Bool("test", - false, - "test existing tables; can be used to compare web data with package data.") - outputFile = flag.String("output", - "tables.go", - "output file for generated tables") -) - -var comment = []string{ - ` -lang holds an alphabetically sorted list of ISO-639 language identifiers. -All entries are 4 bytes. The index of the identifier (divided by 4) is the language tag. -For 2-byte language identifiers, the two successive bytes have the following meaning: - - if the first letter of the 2- and 3-letter ISO codes are the same: - the second and third letter of the 3-letter ISO code. - - otherwise: a 0 and a by 2 bits right-shifted index into altLangISO3. -For 3-byte language identifiers the 4th byte is 0.`, - ` -langNoIndex is a bit vector of all 3-letter language codes that are not used as an index -in lookup tables. The language ids for these language codes are derived directly -from the letters and are not consecutive.`, - ` -altLangISO3 holds an alphabetically sorted list of 3-letter language code alternatives -to 2-letter language codes that cannot be derived using the method described above. -Each 3-letter code is followed by its 1-byte langID.`, - ` -altLangIndex is used to convert indexes in altLangISO3 to langIDs.`, - ` -langAliasMap maps langIDs to their suggested replacements.`, - ` -script is an alphabetically sorted list of ISO 15924 codes. The index -of the script in the string, divided by 4, is the internal scriptID.`, - ` -isoRegionOffset needs to be added to the index of regionISO to obtain the regionID -for 2-letter ISO codes. (The first isoRegionOffset regionIDs are reserved for -the UN.M49 codes used for groups.)`, - ` -regionISO holds a list of alphabetically sorted 2-letter ISO region codes. -Each 2-letter codes is followed by two bytes with the following meaning: - - [A-Z}{2}: the first letter of the 2-letter code plus these two - letters form the 3-letter ISO code. - - 0, n: index into altRegionISO3.`, - ` -regionTypes defines the status of a region for various standards.`, - ` -m49 maps regionIDs to UN.M49 codes. The first isoRegionOffset entries are -codes indicating collections of regions.`, - ` -m49Index gives indexes into fromM49 based on the three most significant bits -of a 10-bit UN.M49 code. To search an UN.M49 code in fromM49, search in - fromM49[m49Index[msb39(code)]:m49Index[msb3(code)+1]] -for an entry where the first 7 bits match the 7 lsb of the UN.M49 code. -The region code is stored in the 9 lsb of the indexed value.`, - ` -fromM49 contains entries to map UN.M49 codes to regions. See m49Index for details.`, - ` -altRegionISO3 holds a list of 3-letter region codes that cannot be -mapped to 2-letter codes using the default algorithm. This is a short list.`, - ` -altRegionIDs holds a list of regionIDs the positions of which match those -of the 3-letter ISO codes in altRegionISO3.`, - ` -variantNumSpecialized is the number of specialized variants in variants.`, - ` -suppressScript is an index from langID to the dominant script for that language, -if it exists. If a script is given, it should be suppressed from the language tag.`, - ` -likelyLang is a lookup table, indexed by langID, for the most likely -scripts and regions given incomplete information. If more entries exist for a -given language, region and script are the index and size respectively -of the list in likelyLangList.`, - ` -likelyLangList holds lists info associated with likelyLang.`, - ` -likelyRegion is a lookup table, indexed by regionID, for the most likely -languages and scripts given incomplete information. If more entries exist -for a given regionID, lang and script are the index and size respectively -of the list in likelyRegionList. -TODO: exclude containers and user-definable regions from the list.`, - ` -likelyRegionList holds lists info associated with likelyRegion.`, - ` -likelyScript is a lookup table, indexed by scriptID, for the most likely -languages and regions given a script.`, - ` -matchLang holds pairs of langIDs of base languages that are typically -mutually intelligible. Each pair is associated with a confidence and -whether the intelligibility goes one or both ways.`, - ` -matchScript holds pairs of scriptIDs where readers of one script -can typically also read the other. Each is associated with a confidence.`, - ` -nRegionGroups is the number of region groups.`, - ` -regionInclusion maps region identifiers to sets of regions in regionInclusionBits, -where each set holds all groupings that are directly connected in a region -containment graph.`, - ` -regionInclusionBits is an array of bit vectors where every vector represents -a set of region groupings. These sets are used to compute the distance -between two regions for the purpose of language matching.`, - ` -regionInclusionNext marks, for each entry in regionInclusionBits, the set of -all groups that are reachable from the groups set in the respective entry.`, -} - -// TODO: consider changing some of these structures to tries. This can reduce -// memory, but may increase the need for memory allocations. This could be -// mitigated if we can piggyback on language tags for common cases. - -func failOnError(e error) { - if e != nil { - log.Panic(e) - } -} - -type setType int - -const ( - Indexed setType = 1 + iota // all elements must be of same size - Linear -) - -type stringSet struct { - s []string - sorted, frozen bool - - // We often need to update values after the creation of an index is completed. - // We include a convenience map for keeping track of this. - update map[string]string - typ setType // used for checking. -} - -func (ss *stringSet) clone() stringSet { - c := *ss - c.s = append([]string(nil), c.s...) - return c -} - -func (ss *stringSet) setType(t setType) { - if ss.typ != t && ss.typ != 0 { - log.Panicf("type %d cannot be assigned as it was already %d", t, ss.typ) - } -} - -// parse parses a whitespace-separated string and initializes ss with its -// components. -func (ss *stringSet) parse(s string) { - scan := bufio.NewScanner(strings.NewReader(s)) - scan.Split(bufio.ScanWords) - for scan.Scan() { - ss.add(scan.Text()) - } -} - -func (ss *stringSet) assertChangeable() { - if ss.frozen { - log.Panic("attempt to modify a frozen stringSet") - } -} - -func (ss *stringSet) add(s string) { - ss.assertChangeable() - ss.s = append(ss.s, s) - ss.sorted = ss.frozen -} - -func (ss *stringSet) freeze() { - ss.compact() - ss.frozen = true -} - -func (ss *stringSet) compact() { - if ss.sorted { - return - } - a := ss.s - sort.Strings(a) - k := 0 - for i := 1; i < len(a); i++ { - if a[k] != a[i] { - a[k+1] = a[i] - k++ - } - } - ss.s = a[:k+1] - ss.sorted = ss.frozen -} - -type funcSorter struct { - fn func(a, b string) bool - sort.StringSlice -} - -func (s funcSorter) Less(i, j int) bool { - return s.fn(s.StringSlice[i], s.StringSlice[j]) -} - -func (ss *stringSet) sortFunc(f func(a, b string) bool) { - ss.compact() - sort.Sort(funcSorter{f, sort.StringSlice(ss.s)}) -} - -func (ss *stringSet) remove(s string) { - ss.assertChangeable() - if i, ok := ss.find(s); ok { - copy(ss.s[i:], ss.s[i+1:]) - ss.s = ss.s[:len(ss.s)-1] - } -} - -func (ss *stringSet) replace(ol, nu string) { - ss.s[ss.index(ol)] = nu - ss.sorted = ss.frozen -} - -func (ss *stringSet) index(s string) int { - ss.setType(Indexed) - i, ok := ss.find(s) - if !ok { - if i < len(ss.s) { - log.Panicf("find: item %q is not in list. Closest match is %q.", s, ss.s[i]) - } - log.Panicf("find: item %q is not in list", s) - - } - return i -} - -func (ss *stringSet) find(s string) (int, bool) { - ss.compact() - i := sort.SearchStrings(ss.s, s) - return i, i != len(ss.s) && ss.s[i] == s -} - -func (ss *stringSet) slice() []string { - ss.compact() - return ss.s -} - -func (ss *stringSet) updateLater(v, key string) { - if ss.update == nil { - ss.update = map[string]string{} - } - ss.update[v] = key -} - -// join joins the string and ensures that all entries are of the same length. -func (ss *stringSet) join() string { - ss.setType(Indexed) - n := len(ss.s[0]) - for _, s := range ss.s { - if len(s) != n { - log.Panicf("join: not all entries are of the same length: %q", s) - } - } - ss.s = append(ss.s, strings.Repeat("\xff", n)) - return strings.Join(ss.s, "") -} - -// ianaEntry holds information for an entry in the IANA Language Subtag Repository. -// All types use the same entry. -// See http://tools.ietf.org/html/bcp47#section-5.1 for a description of the various -// fields. -type ianaEntry struct { - typ string - description []string - scope string - added string - preferred string - deprecated string - suppressScript string - macro string - prefix []string -} - -type builder struct { - w *gen.CodeWriter - hw io.Writer // MultiWriter for w and w.Hash - data *cldr.CLDR - supp *cldr.SupplementalData - - // indices - locale stringSet // common locales - lang stringSet // canonical language ids (2 or 3 letter ISO codes) with data - langNoIndex stringSet // 3-letter ISO codes with no associated data - script stringSet // 4-letter ISO codes - region stringSet // 2-letter ISO or 3-digit UN M49 codes - variant stringSet // 4-8-alphanumeric variant code. - - // Region codes that are groups with their corresponding group IDs. - groups map[int]index - - // langInfo - registry map[string]*ianaEntry -} - -type index uint - -func newBuilder(w *gen.CodeWriter) *builder { - r := gen.OpenCLDRCoreZip() - defer r.Close() - d := &cldr.Decoder{} - data, err := d.DecodeZip(r) - failOnError(err) - b := builder{ - w: w, - hw: io.MultiWriter(w, w.Hash), - data: data, - supp: data.Supplemental(), - } - b.parseRegistry() - return &b -} - -func (b *builder) parseRegistry() { - r := gen.OpenIANAFile("assignments/language-subtag-registry") - defer r.Close() - b.registry = make(map[string]*ianaEntry) - - scan := bufio.NewScanner(r) - scan.Split(bufio.ScanWords) - var record *ianaEntry - for more := scan.Scan(); more; { - key := scan.Text() - more = scan.Scan() - value := scan.Text() - switch key { - case "Type:": - record = &ianaEntry{typ: value} - case "Subtag:", "Tag:": - if s := strings.SplitN(value, "..", 2); len(s) > 1 { - for a := s[0]; a <= s[1]; a = inc(a) { - b.addToRegistry(a, record) - } - } else { - b.addToRegistry(value, record) - } - case "Suppress-Script:": - record.suppressScript = value - case "Added:": - record.added = value - case "Deprecated:": - record.deprecated = value - case "Macrolanguage:": - record.macro = value - case "Preferred-Value:": - record.preferred = value - case "Prefix:": - record.prefix = append(record.prefix, value) - case "Scope:": - record.scope = value - case "Description:": - buf := []byte(value) - for more = scan.Scan(); more; more = scan.Scan() { - b := scan.Bytes() - if b[0] == '%' || b[len(b)-1] == ':' { - break - } - buf = append(buf, ' ') - buf = append(buf, b...) - } - record.description = append(record.description, string(buf)) - continue - default: - continue - } - more = scan.Scan() - } - if scan.Err() != nil { - log.Panic(scan.Err()) - } -} - -func (b *builder) addToRegistry(key string, entry *ianaEntry) { - if info, ok := b.registry[key]; ok { - if info.typ != "language" || entry.typ != "extlang" { - log.Fatalf("parseRegistry: tag %q already exists", key) - } - } else { - b.registry[key] = entry - } -} - -var commentIndex = make(map[string]string) - -func init() { - for _, s := range comment { - key := strings.TrimSpace(strings.SplitN(s, " ", 2)[0]) - commentIndex[key] = s - } -} - -func (b *builder) comment(name string) { - if s := commentIndex[name]; len(s) > 0 { - b.w.WriteComment(s) - } else { - fmt.Fprintln(b.w) - } -} - -func (b *builder) pf(f string, x ...interface{}) { - fmt.Fprintf(b.hw, f, x...) - fmt.Fprint(b.hw, "\n") -} - -func (b *builder) p(x ...interface{}) { - fmt.Fprintln(b.hw, x...) -} - -func (b *builder) addSize(s int) { - b.w.Size += s - b.pf("// Size: %d bytes", s) -} - -func (b *builder) writeConst(name string, x interface{}) { - b.comment(name) - b.w.WriteConst(name, x) -} - -// writeConsts computes f(v) for all v in values and writes the results -// as constants named _v to a single constant block. -func (b *builder) writeConsts(f func(string) int, values ...string) { - b.pf("const (") - for _, v := range values { - b.pf("\t_%s = %v", v, f(v)) - } - b.pf(")") -} - -// writeType writes the type of the given value, which must be a struct. -func (b *builder) writeType(value interface{}) { - b.comment(reflect.TypeOf(value).Name()) - b.w.WriteType(value) -} - -func (b *builder) writeSlice(name string, ss interface{}) { - b.writeSliceAddSize(name, 0, ss) -} - -func (b *builder) writeSliceAddSize(name string, extraSize int, ss interface{}) { - b.comment(name) - b.w.Size += extraSize - v := reflect.ValueOf(ss) - t := v.Type().Elem() - b.pf("// Size: %d bytes, %d elements", v.Len()*int(t.Size())+extraSize, v.Len()) - - fmt.Fprintf(b.w, "var %s = ", name) - b.w.WriteArray(ss) - b.p() -} - -type fromTo struct { - from, to uint16 -} - -func (b *builder) writeSortedMap(name string, ss *stringSet, index func(s string) uint16) { - ss.sortFunc(func(a, b string) bool { - return index(a) < index(b) - }) - m := []fromTo{} - for _, s := range ss.s { - m = append(m, fromTo{index(s), index(ss.update[s])}) - } - b.writeSlice(name, m) -} - -const base = 'z' - 'a' + 1 - -func strToInt(s string) uint { - v := uint(0) - for i := 0; i < len(s); i++ { - v *= base - v += uint(s[i] - 'a') - } - return v -} - -// converts the given integer to the original ASCII string passed to strToInt. -// len(s) must match the number of characters obtained. -func intToStr(v uint, s []byte) { - for i := len(s) - 1; i >= 0; i-- { - s[i] = byte(v%base) + 'a' - v /= base - } -} - -func (b *builder) writeBitVector(name string, ss []string) { - vec := make([]uint8, int(math.Ceil(math.Pow(base, float64(len(ss[0])))/8))) - for _, s := range ss { - v := strToInt(s) - vec[v/8] |= 1 << (v % 8) - } - b.writeSlice(name, vec) -} - -// TODO: convert this type into a list or two-stage trie. -func (b *builder) writeMapFunc(name string, m map[string]string, f func(string) uint16) { - b.comment(name) - v := reflect.ValueOf(m) - sz := v.Len() * (2 + int(v.Type().Key().Size())) - for _, k := range m { - sz += len(k) - } - b.addSize(sz) - keys := []string{} - b.pf(`var %s = map[string]uint16{`, name) - for k := range m { - keys = append(keys, k) - } - sort.Strings(keys) - for _, k := range keys { - b.pf("\t%q: %v,", k, f(m[k])) - } - b.p("}") -} - -func (b *builder) writeMap(name string, m interface{}) { - b.comment(name) - v := reflect.ValueOf(m) - sz := v.Len() * (2 + int(v.Type().Key().Size()) + int(v.Type().Elem().Size())) - b.addSize(sz) - f := strings.FieldsFunc(fmt.Sprintf("%#v", m), func(r rune) bool { - return strings.IndexRune("{}, ", r) != -1 - }) - sort.Strings(f[1:]) - b.pf(`var %s = %s{`, name, f[0]) - for _, kv := range f[1:] { - b.pf("\t%s,", kv) - } - b.p("}") -} - -func (b *builder) langIndex(s string) uint16 { - if s == "und" { - return 0 - } - if i, ok := b.lang.find(s); ok { - return uint16(i) - } - return uint16(strToInt(s)) + uint16(len(b.lang.s)) -} - -// inc advances the string to its lexicographical successor. -func inc(s string) string { - const maxTagLength = 4 - var buf [maxTagLength]byte - intToStr(strToInt(strings.ToLower(s))+1, buf[:len(s)]) - for i := 0; i < len(s); i++ { - if s[i] <= 'Z' { - buf[i] -= 'a' - 'A' - } - } - return string(buf[:len(s)]) -} - -func (b *builder) parseIndices() { - meta := b.supp.Metadata - - for k, v := range b.registry { - var ss *stringSet - switch v.typ { - case "language": - if len(k) == 2 || v.suppressScript != "" || v.scope == "special" { - b.lang.add(k) - continue - } else { - ss = &b.langNoIndex - } - case "region": - ss = &b.region - case "script": - ss = &b.script - case "variant": - ss = &b.variant - default: - continue - } - ss.add(k) - } - // Include any language for which there is data. - for _, lang := range b.data.Locales() { - if x := b.data.RawLDML(lang); false || - x.LocaleDisplayNames != nil || - x.Characters != nil || - x.Delimiters != nil || - x.Measurement != nil || - x.Dates != nil || - x.Numbers != nil || - x.Units != nil || - x.ListPatterns != nil || - x.Collations != nil || - x.Segmentations != nil || - x.Rbnf != nil || - x.Annotations != nil || - x.Metadata != nil { - - from := strings.Split(lang, "_") - if lang := from[0]; lang != "root" { - b.lang.add(lang) - } - } - } - // Include locales for plural rules, which uses a different structure. - for _, plurals := range b.data.Supplemental().Plurals { - for _, rules := range plurals.PluralRules { - for _, lang := range strings.Split(rules.Locales, " ") { - if lang = strings.Split(lang, "_")[0]; lang != "root" { - b.lang.add(lang) - } - } - } - } - // Include languages in likely subtags. - for _, m := range b.supp.LikelySubtags.LikelySubtag { - from := strings.Split(m.From, "_") - b.lang.add(from[0]) - } - // Include ISO-639 alpha-3 bibliographic entries. - for _, a := range meta.Alias.LanguageAlias { - if a.Reason == "bibliographic" { - b.langNoIndex.add(a.Type) - } - } - // Include regions in territoryAlias (not all are in the IANA registry!) - for _, reg := range b.supp.Metadata.Alias.TerritoryAlias { - if len(reg.Type) == 2 { - b.region.add(reg.Type) - } - } - - for _, s := range b.lang.s { - if len(s) == 3 { - b.langNoIndex.remove(s) - } - } - b.writeConst("numLanguages", len(b.lang.slice())+len(b.langNoIndex.slice())) - b.writeConst("numScripts", len(b.script.slice())) - b.writeConst("numRegions", len(b.region.slice())) - - // Add dummy codes at the start of each list to represent "unspecified". - b.lang.add("---") - b.script.add("----") - b.region.add("---") - - // common locales - b.locale.parse(meta.DefaultContent.Locales) -} - -func (b *builder) computeRegionGroups() { - b.groups = make(map[int]index) - - // Create group indices. - for i := 1; b.region.s[i][0] < 'A'; i++ { // Base M49 indices on regionID. - b.groups[i] = index(len(b.groups)) - } - for _, g := range b.supp.TerritoryContainment.Group { - group := b.region.index(g.Type) - if _, ok := b.groups[group]; !ok { - b.groups[group] = index(len(b.groups)) - } - } - if len(b.groups) > 32 { - log.Fatalf("only 32 groups supported, found %d", len(b.groups)) - } - b.writeConst("nRegionGroups", len(b.groups)) -} - -var langConsts = []string{ - "af", "am", "ar", "az", "bg", "bn", "ca", "cs", "da", "de", "el", "en", "es", - "et", "fa", "fi", "fil", "fr", "gu", "he", "hi", "hr", "hu", "hy", "id", "is", - "it", "ja", "ka", "kk", "km", "kn", "ko", "ky", "lo", "lt", "lv", "mk", "ml", - "mn", "mo", "mr", "ms", "mul", "my", "nb", "ne", "nl", "no", "pa", "pl", "pt", - "ro", "ru", "sh", "si", "sk", "sl", "sq", "sr", "sv", "sw", "ta", "te", "th", - "tl", "tn", "tr", "uk", "ur", "uz", "vi", "zh", "zu", - - // constants for grandfathered tags (if not already defined) - "jbo", "ami", "bnn", "hak", "tlh", "lb", "nv", "pwn", "tao", "tay", "tsu", - "nn", "sfb", "vgt", "sgg", "cmn", "nan", "hsn", -} - -// writeLanguage generates all tables needed for language canonicalization. -func (b *builder) writeLanguage() { - meta := b.supp.Metadata - - b.writeConst("nonCanonicalUnd", b.lang.index("und")) - b.writeConsts(func(s string) int { return int(b.langIndex(s)) }, langConsts...) - b.writeConst("langPrivateStart", b.langIndex("qaa")) - b.writeConst("langPrivateEnd", b.langIndex("qtz")) - - // Get language codes that need to be mapped (overlong 3-letter codes, - // deprecated 2-letter codes, legacy and grandfathered tags.) - langAliasMap := stringSet{} - aliasTypeMap := map[string]langAliasType{} - - // altLangISO3 get the alternative ISO3 names that need to be mapped. - altLangISO3 := stringSet{} - // Add dummy start to avoid the use of index 0. - altLangISO3.add("---") - altLangISO3.updateLater("---", "aa") - - lang := b.lang.clone() - for _, a := range meta.Alias.LanguageAlias { - if a.Replacement == "" { - a.Replacement = "und" - } - // TODO: support mapping to tags - repl := strings.SplitN(a.Replacement, "_", 2)[0] - if a.Reason == "overlong" { - if len(a.Replacement) == 2 && len(a.Type) == 3 { - lang.updateLater(a.Replacement, a.Type) - } - } else if len(a.Type) <= 3 { - switch a.Reason { - case "macrolanguage": - aliasTypeMap[a.Type] = langMacro - case "deprecated": - // handled elsewhere - continue - case "bibliographic", "legacy": - if a.Type == "no" { - continue - } - aliasTypeMap[a.Type] = langLegacy - default: - log.Fatalf("new %s alias: %s", a.Reason, a.Type) - } - langAliasMap.add(a.Type) - langAliasMap.updateLater(a.Type, repl) - } - } - // Manually add the mapping of "nb" (Norwegian) to its macro language. - // This can be removed if CLDR adopts this change. - langAliasMap.add("nb") - langAliasMap.updateLater("nb", "no") - aliasTypeMap["nb"] = langMacro - - for k, v := range b.registry { - // Also add deprecated values for 3-letter ISO codes, which CLDR omits. - if v.typ == "language" && v.deprecated != "" && v.preferred != "" { - langAliasMap.add(k) - langAliasMap.updateLater(k, v.preferred) - aliasTypeMap[k] = langDeprecated - } - } - // Fix CLDR mappings. - lang.updateLater("tl", "tgl") - lang.updateLater("sh", "hbs") - lang.updateLater("mo", "mol") - lang.updateLater("no", "nor") - lang.updateLater("tw", "twi") - lang.updateLater("nb", "nob") - lang.updateLater("ak", "aka") - - // Ensure that each 2-letter code is matched with a 3-letter code. - for _, v := range lang.s[1:] { - s, ok := lang.update[v] - if !ok { - if s, ok = lang.update[langAliasMap.update[v]]; !ok { - continue - } - lang.update[v] = s - } - if v[0] != s[0] { - altLangISO3.add(s) - altLangISO3.updateLater(s, v) - } - } - - // Complete canonialized language tags. - lang.freeze() - for i, v := range lang.s { - // We can avoid these manual entries by using the IANI registry directly. - // Seems easier to update the list manually, as changes are rare. - // The panic in this loop will trigger if we miss an entry. - add := "" - if s, ok := lang.update[v]; ok { - if s[0] == v[0] { - add = s[1:] - } else { - add = string([]byte{0, byte(altLangISO3.index(s))}) - } - } else if len(v) == 3 { - add = "\x00" - } else { - log.Panicf("no data for long form of %q", v) - } - lang.s[i] += add - } - b.writeConst("lang", tag.Index(lang.join())) - - b.writeConst("langNoIndexOffset", len(b.lang.s)) - - // space of all valid 3-letter language identifiers. - b.writeBitVector("langNoIndex", b.langNoIndex.slice()) - - altLangIndex := []uint16{} - for i, s := range altLangISO3.slice() { - altLangISO3.s[i] += string([]byte{byte(len(altLangIndex))}) - if i > 0 { - idx := b.lang.index(altLangISO3.update[s]) - altLangIndex = append(altLangIndex, uint16(idx)) - } - } - b.writeConst("altLangISO3", tag.Index(altLangISO3.join())) - b.writeSlice("altLangIndex", altLangIndex) - - b.writeSortedMap("langAliasMap", &langAliasMap, b.langIndex) - types := make([]langAliasType, len(langAliasMap.s)) - for i, s := range langAliasMap.s { - types[i] = aliasTypeMap[s] - } - b.writeSlice("langAliasTypes", types) -} - -var scriptConsts = []string{ - "Latn", "Hani", "Hans", "Hant", "Qaaa", "Qaai", "Qabx", "Zinh", "Zyyy", - "Zzzz", -} - -func (b *builder) writeScript() { - b.writeConsts(b.script.index, scriptConsts...) - b.writeConst("script", tag.Index(b.script.join())) - - supp := make([]uint8, len(b.lang.slice())) - for i, v := range b.lang.slice()[1:] { - if sc := b.registry[v].suppressScript; sc != "" { - supp[i+1] = uint8(b.script.index(sc)) - } - } - b.writeSlice("suppressScript", supp) - - // There is only one deprecated script in CLDR. This value is hard-coded. - // We check here if the code must be updated. - for _, a := range b.supp.Metadata.Alias.ScriptAlias { - if a.Type != "Qaai" { - log.Panicf("unexpected deprecated stript %q", a.Type) - } - } -} - -func parseM49(s string) int16 { - if len(s) == 0 { - return 0 - } - v, err := strconv.ParseUint(s, 10, 10) - failOnError(err) - return int16(v) -} - -var regionConsts = []string{ - "001", "419", "BR", "CA", "ES", "GB", "MD", "PT", "UK", "US", - "ZZ", "XA", "XC", "XK", // Unofficial tag for Kosovo. -} - -func (b *builder) writeRegion() { - b.writeConsts(b.region.index, regionConsts...) - - isoOffset := b.region.index("AA") - m49map := make([]int16, len(b.region.slice())) - fromM49map := make(map[int16]int) - altRegionISO3 := "" - altRegionIDs := []uint16{} - - b.writeConst("isoRegionOffset", isoOffset) - - // 2-letter region lookup and mapping to numeric codes. - regionISO := b.region.clone() - regionISO.s = regionISO.s[isoOffset:] - regionISO.sorted = false - - regionTypes := make([]byte, len(b.region.s)) - - // Is the region valid BCP 47? - for s, e := range b.registry { - if len(s) == 2 && s == strings.ToUpper(s) { - i := b.region.index(s) - for _, d := range e.description { - if strings.Contains(d, "Private use") { - regionTypes[i] = iso3166UserAssgined - } - } - regionTypes[i] |= bcp47Region - } - } - - // Is the region a valid ccTLD? - r := gen.OpenIANAFile("domains/root/db") - defer r.Close() - - buf, err := ioutil.ReadAll(r) - failOnError(err) - re := regexp.MustCompile(`"/domains/root/db/([a-z]{2}).html"`) - for _, m := range re.FindAllSubmatch(buf, -1) { - i := b.region.index(strings.ToUpper(string(m[1]))) - regionTypes[i] |= ccTLD - } - - b.writeSlice("regionTypes", regionTypes) - - iso3Set := make(map[string]int) - update := func(iso2, iso3 string) { - i := regionISO.index(iso2) - if j, ok := iso3Set[iso3]; !ok && iso3[0] == iso2[0] { - regionISO.s[i] += iso3[1:] - iso3Set[iso3] = -1 - } else { - if ok && j >= 0 { - regionISO.s[i] += string([]byte{0, byte(j)}) - } else { - iso3Set[iso3] = len(altRegionISO3) - regionISO.s[i] += string([]byte{0, byte(len(altRegionISO3))}) - altRegionISO3 += iso3 - altRegionIDs = append(altRegionIDs, uint16(isoOffset+i)) - } - } - } - for _, tc := range b.supp.CodeMappings.TerritoryCodes { - i := regionISO.index(tc.Type) + isoOffset - if d := m49map[i]; d != 0 { - log.Panicf("%s found as a duplicate UN.M49 code of %03d", tc.Numeric, d) - } - m49 := parseM49(tc.Numeric) - m49map[i] = m49 - if r := fromM49map[m49]; r == 0 { - fromM49map[m49] = i - } else if r != i { - dep := b.registry[regionISO.s[r-isoOffset]].deprecated - if t := b.registry[tc.Type]; t != nil && dep != "" && (t.deprecated == "" || t.deprecated > dep) { - fromM49map[m49] = i - } - } - } - for _, ta := range b.supp.Metadata.Alias.TerritoryAlias { - if len(ta.Type) == 3 && ta.Type[0] <= '9' && len(ta.Replacement) == 2 { - from := parseM49(ta.Type) - if r := fromM49map[from]; r == 0 { - fromM49map[from] = regionISO.index(ta.Replacement) + isoOffset - } - } - } - for _, tc := range b.supp.CodeMappings.TerritoryCodes { - if len(tc.Alpha3) == 3 { - update(tc.Type, tc.Alpha3) - } - } - // This entries are not included in territoryCodes. Mostly 3-letter variants - // of deleted codes and an entry for QU. - for _, m := range []struct{ iso2, iso3 string }{ - {"CT", "CTE"}, - {"DY", "DHY"}, - {"HV", "HVO"}, - {"JT", "JTN"}, - {"MI", "MID"}, - {"NH", "NHB"}, - {"NQ", "ATN"}, - {"PC", "PCI"}, - {"PU", "PUS"}, - {"PZ", "PCZ"}, - {"RH", "RHO"}, - {"VD", "VDR"}, - {"WK", "WAK"}, - // These three-letter codes are used for others as well. - {"FQ", "ATF"}, - } { - update(m.iso2, m.iso3) - } - for i, s := range regionISO.s { - if len(s) != 4 { - regionISO.s[i] = s + " " - } - } - b.writeConst("regionISO", tag.Index(regionISO.join())) - b.writeConst("altRegionISO3", altRegionISO3) - b.writeSlice("altRegionIDs", altRegionIDs) - - // Create list of deprecated regions. - // TODO: consider inserting SF -> FI. Not included by CLDR, but is the only - // Transitionally-reserved mapping not included. - regionOldMap := stringSet{} - // Include regions in territoryAlias (not all are in the IANA registry!) - for _, reg := range b.supp.Metadata.Alias.TerritoryAlias { - if len(reg.Type) == 2 && reg.Reason == "deprecated" && len(reg.Replacement) == 2 { - regionOldMap.add(reg.Type) - regionOldMap.updateLater(reg.Type, reg.Replacement) - i, _ := regionISO.find(reg.Type) - j, _ := regionISO.find(reg.Replacement) - if k := m49map[i+isoOffset]; k == 0 { - m49map[i+isoOffset] = m49map[j+isoOffset] - } - } - } - b.writeSortedMap("regionOldMap", ®ionOldMap, func(s string) uint16 { - return uint16(b.region.index(s)) - }) - // 3-digit region lookup, groupings. - for i := 1; i < isoOffset; i++ { - m := parseM49(b.region.s[i]) - m49map[i] = m - fromM49map[m] = i - } - b.writeSlice("m49", m49map) - - const ( - searchBits = 7 - regionBits = 9 - ) - if len(m49map) >= 1<<regionBits { - log.Fatalf("Maximum number of regions exceeded: %d > %d", len(m49map), 1<<regionBits) - } - m49Index := [9]int16{} - fromM49 := []uint16{} - m49 := []int{} - for k, _ := range fromM49map { - m49 = append(m49, int(k)) - } - sort.Ints(m49) - for _, k := range m49[1:] { - val := (k & (1<<searchBits - 1)) << regionBits - fromM49 = append(fromM49, uint16(val|fromM49map[int16(k)])) - m49Index[1:][k>>searchBits] = int16(len(fromM49)) - } - b.writeSlice("m49Index", m49Index) - b.writeSlice("fromM49", fromM49) -} - -const ( - // TODO: put these lists in regionTypes as user data? Could be used for - // various optimizations and refinements and could be exposed in the API. - iso3166Except = "AC CP DG EA EU FX IC SU TA UK" - iso3166Trans = "AN BU CS NT TP YU ZR" // SF is not in our set of Regions. - // DY and RH are actually not deleted, but indeterminately reserved. - iso3166DelCLDR = "CT DD DY FQ HV JT MI NH NQ PC PU PZ RH VD WK YD" -) - -const ( - iso3166UserAssgined = 1 << iota - ccTLD - bcp47Region -) - -func find(list []string, s string) int { - for i, t := range list { - if t == s { - return i - } - } - return -1 -} - -// writeVariants generates per-variant information and creates a map from variant -// name to index value. We assign index values such that sorting multiple -// variants by index value will result in the correct order. -// There are two types of variants: specialized and general. Specialized variants -// are only applicable to certain language or language-script pairs. Generalized -// variants apply to any language. Generalized variants always sort after -// specialized variants. We will therefore always assign a higher index value -// to a generalized variant than any other variant. Generalized variants are -// sorted alphabetically among themselves. -// Specialized variants may also sort after other specialized variants. Such -// variants will be ordered after any of the variants they may follow. -// We assume that if a variant x is followed by a variant y, then for any prefix -// p of x, p-x is a prefix of y. This allows us to order tags based on the -// maximum of the length of any of its prefixes. -// TODO: it is possible to define a set of Prefix values on variants such that -// a total order cannot be defined to the point that this algorithm breaks. -// In other words, we cannot guarantee the same order of variants for the -// future using the same algorithm or for non-compliant combinations of -// variants. For this reason, consider using simple alphabetic sorting -// of variants and ignore Prefix restrictions altogether. -func (b *builder) writeVariant() { - generalized := stringSet{} - specialized := stringSet{} - specializedExtend := stringSet{} - // Collate the variants by type and check assumptions. - for _, v := range b.variant.slice() { - e := b.registry[v] - if len(e.prefix) == 0 { - generalized.add(v) - continue - } - c := strings.Split(e.prefix[0], "-") - hasScriptOrRegion := false - if len(c) > 1 { - _, hasScriptOrRegion = b.script.find(c[1]) - if !hasScriptOrRegion { - _, hasScriptOrRegion = b.region.find(c[1]) - - } - } - if len(c) == 1 || len(c) == 2 && hasScriptOrRegion { - // Variant is preceded by a language. - specialized.add(v) - continue - } - // Variant is preceded by another variant. - specializedExtend.add(v) - prefix := c[0] + "-" - if hasScriptOrRegion { - prefix += c[1] - } - for _, p := range e.prefix { - // Verify that the prefix minus the last element is a prefix of the - // predecessor element. - i := strings.LastIndex(p, "-") - pred := b.registry[p[i+1:]] - if find(pred.prefix, p[:i]) < 0 { - log.Fatalf("prefix %q for variant %q not consistent with predecessor spec", p, v) - } - // The sorting used below does not work in the general case. It works - // if we assume that variants that may be followed by others only have - // prefixes of the same length. Verify this. - count := strings.Count(p[:i], "-") - for _, q := range pred.prefix { - if c := strings.Count(q, "-"); c != count { - log.Fatalf("variant %q preceding %q has a prefix %q of size %d; want %d", p[i+1:], v, q, c, count) - } - } - if !strings.HasPrefix(p, prefix) { - log.Fatalf("prefix %q of variant %q should start with %q", p, v, prefix) - } - } - } - - // Sort extended variants. - a := specializedExtend.s - less := func(v, w string) bool { - // Sort by the maximum number of elements. - maxCount := func(s string) (max int) { - for _, p := range b.registry[s].prefix { - if c := strings.Count(p, "-"); c > max { - max = c - } - } - return - } - if cv, cw := maxCount(v), maxCount(w); cv != cw { - return cv < cw - } - // Sort by name as tie breaker. - return v < w - } - sort.Sort(funcSorter{less, sort.StringSlice(a)}) - specializedExtend.frozen = true - - // Create index from variant name to index. - variantIndex := make(map[string]uint8) - add := func(s []string) { - for _, v := range s { - variantIndex[v] = uint8(len(variantIndex)) - } - } - add(specialized.slice()) - add(specializedExtend.s) - numSpecialized := len(variantIndex) - add(generalized.slice()) - if n := len(variantIndex); n > 255 { - log.Fatalf("maximum number of variants exceeded: was %d; want <= 255", n) - } - b.writeMap("variantIndex", variantIndex) - b.writeConst("variantNumSpecialized", numSpecialized) -} - -func (b *builder) writeLanguageInfo() { -} - -// writeLikelyData writes tables that are used both for finding parent relations and for -// language matching. Each entry contains additional bits to indicate the status of the -// data to know when it cannot be used for parent relations. -func (b *builder) writeLikelyData() { - const ( - isList = 1 << iota - scriptInFrom - regionInFrom - ) - type ( // generated types - likelyScriptRegion struct { - region uint16 - script uint8 - flags uint8 - } - likelyLangScript struct { - lang uint16 - script uint8 - flags uint8 - } - likelyLangRegion struct { - lang uint16 - region uint16 - } - // likelyTag is used for getting likely tags for group regions, where - // the likely region might be a region contained in the group. - likelyTag struct { - lang uint16 - region uint16 - script uint8 - } - ) - var ( // generated variables - likelyRegionGroup = make([]likelyTag, len(b.groups)) - likelyLang = make([]likelyScriptRegion, len(b.lang.s)) - likelyRegion = make([]likelyLangScript, len(b.region.s)) - likelyScript = make([]likelyLangRegion, len(b.script.s)) - likelyLangList = []likelyScriptRegion{} - likelyRegionList = []likelyLangScript{} - ) - type fromTo struct { - from, to []string - } - langToOther := map[int][]fromTo{} - regionToOther := map[int][]fromTo{} - for _, m := range b.supp.LikelySubtags.LikelySubtag { - from := strings.Split(m.From, "_") - to := strings.Split(m.To, "_") - if len(to) != 3 { - log.Fatalf("invalid number of subtags in %q: found %d, want 3", m.To, len(to)) - } - if len(from) > 3 { - log.Fatalf("invalid number of subtags: found %d, want 1-3", len(from)) - } - if from[0] != to[0] && from[0] != "und" { - log.Fatalf("unexpected language change in expansion: %s -> %s", from, to) - } - if len(from) == 3 { - if from[2] != to[2] { - log.Fatalf("unexpected region change in expansion: %s -> %s", from, to) - } - if from[0] != "und" { - log.Fatalf("unexpected fully specified from tag: %s -> %s", from, to) - } - } - if len(from) == 1 || from[0] != "und" { - id := 0 - if from[0] != "und" { - id = b.lang.index(from[0]) - } - langToOther[id] = append(langToOther[id], fromTo{from, to}) - } else if len(from) == 2 && len(from[1]) == 4 { - sid := b.script.index(from[1]) - likelyScript[sid].lang = uint16(b.langIndex(to[0])) - likelyScript[sid].region = uint16(b.region.index(to[2])) - } else { - r := b.region.index(from[len(from)-1]) - if id, ok := b.groups[r]; ok { - if from[0] != "und" { - log.Fatalf("region changed unexpectedly: %s -> %s", from, to) - } - likelyRegionGroup[id].lang = uint16(b.langIndex(to[0])) - likelyRegionGroup[id].script = uint8(b.script.index(to[1])) - likelyRegionGroup[id].region = uint16(b.region.index(to[2])) - } else { - regionToOther[r] = append(regionToOther[r], fromTo{from, to}) - } - } - } - b.writeType(likelyLangRegion{}) - b.writeSlice("likelyScript", likelyScript) - - for id := range b.lang.s { - list := langToOther[id] - if len(list) == 1 { - likelyLang[id].region = uint16(b.region.index(list[0].to[2])) - likelyLang[id].script = uint8(b.script.index(list[0].to[1])) - } else if len(list) > 1 { - likelyLang[id].flags = isList - likelyLang[id].region = uint16(len(likelyLangList)) - likelyLang[id].script = uint8(len(list)) - for _, x := range list { - flags := uint8(0) - if len(x.from) > 1 { - if x.from[1] == x.to[2] { - flags = regionInFrom - } else { - flags = scriptInFrom - } - } - likelyLangList = append(likelyLangList, likelyScriptRegion{ - region: uint16(b.region.index(x.to[2])), - script: uint8(b.script.index(x.to[1])), - flags: flags, - }) - } - } - } - // TODO: merge suppressScript data with this table. - b.writeType(likelyScriptRegion{}) - b.writeSlice("likelyLang", likelyLang) - b.writeSlice("likelyLangList", likelyLangList) - - for id := range b.region.s { - list := regionToOther[id] - if len(list) == 1 { - likelyRegion[id].lang = uint16(b.langIndex(list[0].to[0])) - likelyRegion[id].script = uint8(b.script.index(list[0].to[1])) - if len(list[0].from) > 2 { - likelyRegion[id].flags = scriptInFrom - } - } else if len(list) > 1 { - likelyRegion[id].flags = isList - likelyRegion[id].lang = uint16(len(likelyRegionList)) - likelyRegion[id].script = uint8(len(list)) - for i, x := range list { - if len(x.from) == 2 && i != 0 || i > 0 && len(x.from) != 3 { - log.Fatalf("unspecified script must be first in list: %v at %d", x.from, i) - } - x := likelyLangScript{ - lang: uint16(b.langIndex(x.to[0])), - script: uint8(b.script.index(x.to[1])), - } - if len(list[0].from) > 2 { - x.flags = scriptInFrom - } - likelyRegionList = append(likelyRegionList, x) - } - } - } - b.writeType(likelyLangScript{}) - b.writeSlice("likelyRegion", likelyRegion) - b.writeSlice("likelyRegionList", likelyRegionList) - - b.writeType(likelyTag{}) - b.writeSlice("likelyRegionGroup", likelyRegionGroup) -} - -type mutualIntelligibility struct { - want, have uint16 - conf uint8 - oneway bool -} - -type scriptIntelligibility struct { - lang uint16 // langID or 0 if * - want, have uint8 - conf uint8 -} - -type sortByConf []mutualIntelligibility - -func (l sortByConf) Less(a, b int) bool { - return l[a].conf > l[b].conf -} - -func (l sortByConf) Swap(a, b int) { - l[a], l[b] = l[b], l[a] -} - -func (l sortByConf) Len() int { - return len(l) -} - -// toConf converts a percentage value [0, 100] to a confidence class. -func toConf(pct uint8) uint8 { - switch { - case pct == 100: - return 3 // Exact - case pct >= 90: - return 2 // High - case pct > 50: - return 1 // Low - default: - return 0 // No - } -} - -// writeMatchData writes tables with languages and scripts for which there is -// mutual intelligibility. The data is based on CLDR's languageMatching data. -// Note that we use a different algorithm than the one defined by CLDR and that -// we slightly modify the data. For example, we convert scores to confidence levels. -// We also drop all region-related data as we use a different algorithm to -// determine region equivalence. -func (b *builder) writeMatchData() { - b.writeType(mutualIntelligibility{}) - b.writeType(scriptIntelligibility{}) - lm := b.supp.LanguageMatching.LanguageMatches - cldr.MakeSlice(&lm).SelectAnyOf("type", "written") - - matchLang := []mutualIntelligibility{} - matchScript := []scriptIntelligibility{} - // Convert the languageMatch entries in lists keyed by desired language. - for _, m := range lm[0].LanguageMatch { - // Different versions of CLDR use different separators. - desired := strings.Replace(m.Desired, "-", "_", -1) - supported := strings.Replace(m.Supported, "-", "_", -1) - d := strings.Split(desired, "_") - s := strings.Split(supported, "_") - if len(d) != len(s) || len(d) > 2 { - // Skip all entries with regions and work around CLDR bug. - continue - } - pct, _ := strconv.ParseInt(m.Percent, 10, 8) - if len(d) == 2 && d[0] == s[0] && len(d[1]) == 4 { - // language-script pair. - lang := uint16(0) - if d[0] != "*" { - lang = uint16(b.langIndex(d[0])) - } - matchScript = append(matchScript, scriptIntelligibility{ - lang: lang, - want: uint8(b.script.index(d[1])), - have: uint8(b.script.index(s[1])), - conf: toConf(uint8(pct)), - }) - if m.Oneway != "true" { - matchScript = append(matchScript, scriptIntelligibility{ - lang: lang, - want: uint8(b.script.index(s[1])), - have: uint8(b.script.index(d[1])), - conf: toConf(uint8(pct)), - }) - } - } else if len(d) == 1 && d[0] != "*" { - if pct == 100 { - // nb == no is already handled by macro mapping. Check there - // really is only this case. - if d[0] != "no" || s[0] != "nb" { - log.Fatalf("unhandled equivalence %s == %s", s[0], d[0]) - } - continue - } - matchLang = append(matchLang, mutualIntelligibility{ - want: uint16(b.langIndex(d[0])), - have: uint16(b.langIndex(s[0])), - conf: uint8(pct), - oneway: m.Oneway == "true", - }) - } else { - // TODO: Handle other mappings. - a := []string{"*;*", "*_*;*_*", "es_MX;es_419"} - s := strings.Join([]string{desired, supported}, ";") - if i := sort.SearchStrings(a, s); i == len(a) || a[i] != s { - log.Printf("%q not handled", s) - } - } - } - sort.Stable(sortByConf(matchLang)) - // collapse percentage into confidence classes - for i, m := range matchLang { - matchLang[i].conf = toConf(m.conf) - } - b.writeSlice("matchLang", matchLang) - b.writeSlice("matchScript", matchScript) -} - -func (b *builder) writeRegionInclusionData() { - var ( - // mm holds for each group the set of groups with a distance of 1. - mm = make(map[int][]index) - - // containment holds for each group the transitive closure of - // containment of other groups. - containment = make(map[index][]index) - ) - for _, g := range b.supp.TerritoryContainment.Group { - group := b.region.index(g.Type) - groupIdx := b.groups[group] - for _, mem := range strings.Split(g.Contains, " ") { - r := b.region.index(mem) - mm[r] = append(mm[r], groupIdx) - if g, ok := b.groups[r]; ok { - mm[group] = append(mm[group], g) - containment[groupIdx] = append(containment[groupIdx], g) - } - } - } - - regionContainment := make([]uint32, len(b.groups)) - for _, g := range b.groups { - l := containment[g] - - // Compute the transitive closure of containment. - for i := 0; i < len(l); i++ { - l = append(l, containment[l[i]]...) - } - - // Compute the bitmask. - regionContainment[g] = 1 << g - for _, v := range l { - regionContainment[g] |= 1 << v - } - // log.Printf("%d: %X", g, regionContainment[g]) - } - b.writeSlice("regionContainment", regionContainment) - - regionInclusion := make([]uint8, len(b.region.s)) - bvs := make(map[uint32]index) - // Make the first bitvector positions correspond with the groups. - for r, i := range b.groups { - bv := uint32(1 << i) - for _, g := range mm[r] { - bv |= 1 << g - } - bvs[bv] = i - regionInclusion[r] = uint8(bvs[bv]) - } - for r := 1; r < len(b.region.s); r++ { - if _, ok := b.groups[r]; !ok { - bv := uint32(0) - for _, g := range mm[r] { - bv |= 1 << g - } - if bv == 0 { - // Pick the world for unspecified regions. - bv = 1 << b.groups[b.region.index("001")] - } - if _, ok := bvs[bv]; !ok { - bvs[bv] = index(len(bvs)) - } - regionInclusion[r] = uint8(bvs[bv]) - } - } - b.writeSlice("regionInclusion", regionInclusion) - regionInclusionBits := make([]uint32, len(bvs)) - for k, v := range bvs { - regionInclusionBits[v] = uint32(k) - } - // Add bit vectors for increasingly large distances until a fixed point is reached. - regionInclusionNext := []uint8{} - for i := 0; i < len(regionInclusionBits); i++ { - bits := regionInclusionBits[i] - next := bits - for i := uint(0); i < uint(len(b.groups)); i++ { - if bits&(1<<i) != 0 { - next |= regionInclusionBits[i] - } - } - if _, ok := bvs[next]; !ok { - bvs[next] = index(len(bvs)) - regionInclusionBits = append(regionInclusionBits, next) - } - regionInclusionNext = append(regionInclusionNext, uint8(bvs[next])) - } - b.writeSlice("regionInclusionBits", regionInclusionBits) - b.writeSlice("regionInclusionNext", regionInclusionNext) -} - -type parentRel struct { - lang uint16 - script uint8 - maxScript uint8 - toRegion uint16 - fromRegion []uint16 -} - -func (b *builder) writeParents() { - b.writeType(parentRel{}) - - parents := []parentRel{} - - // Construct parent overrides. - n := 0 - for _, p := range b.data.Supplemental().ParentLocales.ParentLocale { - // Skipping non-standard scripts to root is implemented using addTags. - if p.Parent == "root" { - continue - } - - sub := strings.Split(p.Parent, "_") - parent := parentRel{lang: b.langIndex(sub[0])} - if len(sub) == 2 { - // TODO: check that all undefined scripts are indeed Latn in these - // cases. - parent.maxScript = uint8(b.script.index("Latn")) - parent.toRegion = uint16(b.region.index(sub[1])) - } else { - parent.script = uint8(b.script.index(sub[1])) - parent.maxScript = parent.script - parent.toRegion = uint16(b.region.index(sub[2])) - } - for _, c := range strings.Split(p.Locales, " ") { - region := b.region.index(c[strings.LastIndex(c, "_")+1:]) - parent.fromRegion = append(parent.fromRegion, uint16(region)) - } - parents = append(parents, parent) - n += len(parent.fromRegion) - } - b.writeSliceAddSize("parents", n*2, parents) -} - -func main() { - gen.Init() - - gen.Repackage("gen_common.go", "common.go", "language") - - w := gen.NewCodeWriter() - defer w.WriteGoFile("tables.go", "language") - - fmt.Fprintln(w, `import "golang.org/x/text/internal/tag"`) - - b := newBuilder(w) - gen.WriteCLDRVersion(w) - - b.parseIndices() - b.writeType(fromTo{}) - b.writeLanguage() - b.writeScript() - b.writeRegion() - b.writeVariant() - // TODO: b.writeLocale() - b.computeRegionGroups() - b.writeLikelyData() - b.writeMatchData() - b.writeRegionInclusionData() - b.writeParents() -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/match.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/match.go deleted file mode 100644 index eec72bc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/match.go +++ /dev/null @@ -1,840 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package language - -import "errors" - -// Matcher is the interface that wraps the Match method. -// -// Match returns the best match for any of the given tags, along with -// a unique index associated with the returned tag and a confidence -// score. -type Matcher interface { - Match(t ...Tag) (tag Tag, index int, c Confidence) -} - -// Comprehends reports the confidence score for a speaker of a given language -// to being able to comprehend the written form of an alternative language. -func Comprehends(speaker, alternative Tag) Confidence { - _, _, c := NewMatcher([]Tag{alternative}).Match(speaker) - return c -} - -// NewMatcher returns a Matcher that matches an ordered list of preferred tags -// against a list of supported tags based on written intelligibility, closeness -// of dialect, equivalence of subtags and various other rules. It is initialized -// with the list of supported tags. The first element is used as the default -// value in case no match is found. -// -// Its Match method matches the first of the given Tags to reach a certain -// confidence threshold. The tags passed to Match should therefore be specified -// in order of preference. Extensions are ignored for matching. -// -// The index returned by the Match method corresponds to the index of the -// matched tag in t, but is augmented with the Unicode extension ('u')of the -// corresponding preferred tag. This allows user locale options to be passed -// transparently. -func NewMatcher(t []Tag) Matcher { - return newMatcher(t) -} - -func (m *matcher) Match(want ...Tag) (t Tag, index int, c Confidence) { - match, w, c := m.getBest(want...) - if match == nil { - t = m.default_.tag - } else { - t, index = match.tag, match.index - } - // Copy options from the user-provided tag into the result tag. This is hard - // to do after the fact, so we do it here. - // TODO: consider also adding in variants that are compatible with the - // matched language. - // TODO: Add back region if it is non-ambiguous? Or create another tag to - // preserve the region? - if u, ok := w.Extension('u'); ok { - t, _ = Raw.Compose(t, u) - } - return t, index, c -} - -type scriptRegionFlags uint8 - -const ( - isList = 1 << iota - scriptInFrom - regionInFrom -) - -func (t *Tag) setUndefinedLang(id langID) { - if t.lang == 0 { - t.lang = id - } -} - -func (t *Tag) setUndefinedScript(id scriptID) { - if t.script == 0 { - t.script = id - } -} - -func (t *Tag) setUndefinedRegion(id regionID) { - if t.region == 0 || t.region.contains(id) { - t.region = id - } -} - -// ErrMissingLikelyTagsData indicates no information was available -// to compute likely values of missing tags. -var ErrMissingLikelyTagsData = errors.New("missing likely tags data") - -// addLikelySubtags sets subtags to their most likely value, given the locale. -// In most cases this means setting fields for unknown values, but in some -// cases it may alter a value. It returns a ErrMissingLikelyTagsData error -// if the given locale cannot be expanded. -func (t Tag) addLikelySubtags() (Tag, error) { - id, err := addTags(t) - if err != nil { - return t, err - } else if id.equalTags(t) { - return t, nil - } - id.remakeString() - return id, nil -} - -// specializeRegion attempts to specialize a group region. -func specializeRegion(t *Tag) bool { - if i := regionInclusion[t.region]; i < nRegionGroups { - x := likelyRegionGroup[i] - if langID(x.lang) == t.lang && scriptID(x.script) == t.script { - t.region = regionID(x.region) - } - return true - } - return false -} - -func addTags(t Tag) (Tag, error) { - // We leave private use identifiers alone. - if t.private() { - return t, nil - } - if t.script != 0 && t.region != 0 { - if t.lang != 0 { - // already fully specified - specializeRegion(&t) - return t, nil - } - // Search matches for und-script-region. Note that for these cases - // region will never be a group so there is no need to check for this. - list := likelyRegion[t.region : t.region+1] - if x := list[0]; x.flags&isList != 0 { - list = likelyRegionList[x.lang : x.lang+uint16(x.script)] - } - for _, x := range list { - // Deviating from the spec. See match_test.go for details. - if scriptID(x.script) == t.script { - t.setUndefinedLang(langID(x.lang)) - return t, nil - } - } - } - if t.lang != 0 { - // Search matches for lang-script and lang-region, where lang != und. - if t.lang < langNoIndexOffset { - x := likelyLang[t.lang] - if x.flags&isList != 0 { - list := likelyLangList[x.region : x.region+uint16(x.script)] - if t.script != 0 { - for _, x := range list { - if scriptID(x.script) == t.script && x.flags&scriptInFrom != 0 { - t.setUndefinedRegion(regionID(x.region)) - return t, nil - } - } - } else if t.region != 0 { - count := 0 - goodScript := true - tt := t - for _, x := range list { - // We visit all entries for which the script was not - // defined, including the ones where the region was not - // defined. This allows for proper disambiguation within - // regions. - if x.flags&scriptInFrom == 0 && t.region.contains(regionID(x.region)) { - tt.region = regionID(x.region) - tt.setUndefinedScript(scriptID(x.script)) - goodScript = goodScript && tt.script == scriptID(x.script) - count++ - } - } - if count == 1 { - return tt, nil - } - // Even if we fail to find a unique Region, we might have - // an unambiguous script. - if goodScript { - t.script = tt.script - } - } - } - } - } else { - // Search matches for und-script. - if t.script != 0 { - x := likelyScript[t.script] - if x.region != 0 { - t.setUndefinedRegion(regionID(x.region)) - t.setUndefinedLang(langID(x.lang)) - return t, nil - } - } - // Search matches for und-region. If und-script-region exists, it would - // have been found earlier. - if t.region != 0 { - if i := regionInclusion[t.region]; i < nRegionGroups { - x := likelyRegionGroup[i] - if x.region != 0 { - t.setUndefinedLang(langID(x.lang)) - t.setUndefinedScript(scriptID(x.script)) - t.region = regionID(x.region) - } - } else { - x := likelyRegion[t.region] - if x.flags&isList != 0 { - x = likelyRegionList[x.lang] - } - if x.script != 0 && x.flags != scriptInFrom { - t.setUndefinedLang(langID(x.lang)) - t.setUndefinedScript(scriptID(x.script)) - return t, nil - } - } - } - } - - // Search matches for lang. - if t.lang < langNoIndexOffset { - x := likelyLang[t.lang] - if x.flags&isList != 0 { - x = likelyLangList[x.region] - } - if x.region != 0 { - t.setUndefinedScript(scriptID(x.script)) - t.setUndefinedRegion(regionID(x.region)) - } - specializeRegion(&t) - if t.lang == 0 { - t.lang = _en // default language - } - return t, nil - } - return t, ErrMissingLikelyTagsData -} - -func (t *Tag) setTagsFrom(id Tag) { - t.lang = id.lang - t.script = id.script - t.region = id.region -} - -// minimize removes the region or script subtags from t such that -// t.addLikelySubtags() == t.minimize().addLikelySubtags(). -func (t Tag) minimize() (Tag, error) { - t, err := minimizeTags(t) - if err != nil { - return t, err - } - t.remakeString() - return t, nil -} - -// minimizeTags mimics the behavior of the ICU 51 C implementation. -func minimizeTags(t Tag) (Tag, error) { - if t.equalTags(und) { - return t, nil - } - max, err := addTags(t) - if err != nil { - return t, err - } - for _, id := range [...]Tag{ - {lang: t.lang}, - {lang: t.lang, region: t.region}, - {lang: t.lang, script: t.script}, - } { - if x, err := addTags(id); err == nil && max.equalTags(x) { - t.setTagsFrom(id) - break - } - } - return t, nil -} - -// Tag Matching -// CLDR defines an algorithm for finding the best match between two sets of language -// tags. The basic algorithm defines how to score a possible match and then find -// the match with the best score -// (see http://www.unicode.org/reports/tr35/#LanguageMatching). -// Using scoring has several disadvantages. The scoring obfuscates the importance of -// the various factors considered, making the algorithm harder to understand. Using -// scoring also requires the full score to be computed for each pair of tags. -// -// We will use a different algorithm which aims to have the following properties: -// - clarity on the precedence of the various selection factors, and -// - improved performance by allowing early termination of a comparison. -// -// Matching algorithm (overview) -// Input: -// - supported: a set of supported tags -// - default: the default tag to return in case there is no match -// - desired: list of desired tags, ordered by preference, starting with -// the most-preferred. -// -// Algorithm: -// 1) Set the best match to the lowest confidence level -// 2) For each tag in "desired": -// a) For each tag in "supported": -// 1) compute the match between the two tags. -// 2) if the match is better than the previous best match, replace it -// with the new match. (see next section) -// b) if the current best match is above a certain threshold, return this -// match without proceeding to the next tag in "desired". [See Note 1] -// 3) If the best match so far is below a certain threshold, return "default". -// -// Ranking: -// We use two phases to determine whether one pair of tags are a better match -// than another pair of tags. First, we determine a rough confidence level. If the -// levels are different, the one with the highest confidence wins. -// Second, if the rough confidence levels are identical, we use a set of tie-breaker -// rules. -// -// The confidence level of matching a pair of tags is determined by finding the -// lowest confidence level of any matches of the corresponding subtags (the -// result is deemed as good as its weakest link). -// We define the following levels: -// Exact - An exact match of a subtag, before adding likely subtags. -// MaxExact - An exact match of a subtag, after adding likely subtags. -// [See Note 2]. -// High - High level of mutual intelligibility between different subtag -// variants. -// Low - Low level of mutual intelligibility between different subtag -// variants. -// No - No mutual intelligibility. -// -// The following levels can occur for each type of subtag: -// Base: Exact, MaxExact, High, Low, No -// Script: Exact, MaxExact [see Note 3], Low, No -// Region: Exact, MaxExact, High -// Variant: Exact, High -// Private: Exact, No -// -// Any result with a confidence level of Low or higher is deemed a possible match. -// Once a desired tag matches any of the supported tags with a level of MaxExact -// or higher, the next desired tag is not considered (see Step 2.b). -// Note that CLDR provides languageMatching data that defines close equivalence -// classes for base languages, scripts and regions. -// -// Tie-breaking -// If we get the same confidence level for two matches, we apply a sequence of -// tie-breaking rules. The first that succeeds defines the result. The rules are -// applied in the following order. -// 1) Original language was defined and was identical. -// 2) Original region was defined and was identical. -// 3) Distance between two maximized regions was the smallest. -// 4) Original script was defined and was identical. -// 5) Distance from want tag to have tag using the parent relation [see Note 5.] -// If there is still no winner after these rules are applied, the first match -// found wins. -// -// Notes: -// [1] Note that even if we may not have a perfect match, if a match is above a -// certain threshold, it is considered a better match than any other match -// to a tag later in the list of preferred language tags. -// [2] In practice, as matching of Exact is done in a separate phase from -// matching the other levels, we reuse the Exact level to mean MaxExact in -// the second phase. As a consequence, we only need the levels defined by -// the Confidence type. The MaxExact confidence level is mapped to High in -// the public API. -// [3] We do not differentiate between maximized script values that were derived -// from suppressScript versus most likely tag data. We determined that in -// ranking the two, one ranks just after the other. Moreover, the two cannot -// occur concurrently. As a consequence, they are identical for practical -// purposes. -// [4] In case of deprecated, macro-equivalents and legacy mappings, we assign -// the MaxExact level to allow iw vs he to still be a closer match than -// en-AU vs en-US, for example. -// [5] In CLDR a locale inherits fields that are unspecified for this locale -// from its parent. Therefore, if a locale is a parent of another locale, -// it is a strong measure for closeness, especially when no other tie -// breaker rule applies. One could also argue it is inconsistent, for -// example, when pt-AO matches pt (which CLDR equates with pt-BR), even -// though its parent is pt-PT according to the inheritance rules. -// -// Implementation Details: -// There are several performance considerations worth pointing out. Most notably, -// we preprocess as much as possible (within reason) at the time of creation of a -// matcher. This includes: -// - creating a per-language map, which includes data for the raw base language -// and its canonicalized variant (if applicable), -// - expanding entries for the equivalence classes defined in CLDR's -// languageMatch data. -// The per-language map ensures that typically only a very small number of tags -// need to be considered. The pre-expansion of canonicalized subtags and -// equivalence classes reduces the amount of map lookups that need to be done at -// runtime. - -// matcher keeps a set of supported language tags, indexed by language. -type matcher struct { - default_ *haveTag - index map[langID]*matchHeader - passSettings bool -} - -// matchHeader has the lists of tags for exact matches and matches based on -// maximized and canonicalized tags for a given language. -type matchHeader struct { - exact []haveTag - max []haveTag -} - -// haveTag holds a supported Tag and its maximized script and region. The maximized -// or canonicalized language is not stored as it is not needed during matching. -type haveTag struct { - tag Tag - - // index of this tag in the original list of supported tags. - index int - - // conf is the maximum confidence that can result from matching this haveTag. - // When conf < Exact this means it was inserted after applying a CLDR equivalence rule. - conf Confidence - - // Maximized region and script. - maxRegion regionID - maxScript scriptID - - // altScript may be checked as an alternative match to maxScript. If altScript - // matches, the confidence level for this match is Low. Theoretically there - // could be multiple alternative scripts. This does not occur in practice. - altScript scriptID - - // nextMax is the index of the next haveTag with the same maximized tags. - nextMax uint16 -} - -func makeHaveTag(tag Tag, index int) (haveTag, langID) { - max := tag - if tag.lang != 0 { - max, _ = max.canonicalize(All) - max, _ = addTags(max) - max.remakeString() - } - return haveTag{tag, index, Exact, max.region, max.script, altScript(max.lang, max.script), 0}, max.lang -} - -// altScript returns an alternative script that may match the given script with -// a low confidence. At the moment, the langMatch data allows for at most one -// script to map to another and we rely on this to keep the code simple. -func altScript(l langID, s scriptID) scriptID { - for _, alt := range matchScript { - if (alt.lang == 0 || langID(alt.lang) == l) && scriptID(alt.have) == s { - return scriptID(alt.want) - } - } - return 0 -} - -// addIfNew adds a haveTag to the list of tags only if it is a unique tag. -// Tags that have the same maximized values are linked by index. -func (h *matchHeader) addIfNew(n haveTag, exact bool) { - // Don't add new exact matches. - for _, v := range h.exact { - if v.tag.equalsRest(n.tag) { - return - } - } - if exact { - h.exact = append(h.exact, n) - } - // Allow duplicate maximized tags, but create a linked list to allow quickly - // comparing the equivalents and bail out. - for i, v := range h.max { - if v.maxScript == n.maxScript && - v.maxRegion == n.maxRegion && - v.tag.variantOrPrivateTagStr() == n.tag.variantOrPrivateTagStr() { - for h.max[i].nextMax != 0 { - i = int(h.max[i].nextMax) - } - h.max[i].nextMax = uint16(len(h.max)) - break - } - } - h.max = append(h.max, n) -} - -// header returns the matchHeader for the given language. It creates one if -// it doesn't already exist. -func (m *matcher) header(l langID) *matchHeader { - if h := m.index[l]; h != nil { - return h - } - h := &matchHeader{} - m.index[l] = h - return h -} - -// newMatcher builds an index for the given supported tags and returns it as -// a matcher. It also expands the index by considering various equivalence classes -// for a given tag. -func newMatcher(supported []Tag) *matcher { - m := &matcher{ - index: make(map[langID]*matchHeader), - } - if len(supported) == 0 { - m.default_ = &haveTag{} - return m - } - // Add supported languages to the index. Add exact matches first to give - // them precedence. - for i, tag := range supported { - pair, _ := makeHaveTag(tag, i) - m.header(tag.lang).addIfNew(pair, true) - } - m.default_ = &m.header(supported[0].lang).exact[0] - for i, tag := range supported { - pair, max := makeHaveTag(tag, i) - if max != tag.lang { - m.header(max).addIfNew(pair, false) - } - } - - // update is used to add indexes in the map for equivalent languages. - // If force is true, the update will also apply to derived entries. To - // avoid applying a "transitive closure", use false. - update := func(want, have uint16, conf Confidence, force bool) { - if hh := m.index[langID(have)]; hh != nil { - if !force && len(hh.exact) == 0 { - return - } - hw := m.header(langID(want)) - for _, v := range hh.max { - if conf < v.conf { - v.conf = conf - } - v.nextMax = 0 // this value needs to be recomputed - if v.altScript != 0 { - v.altScript = altScript(langID(want), v.maxScript) - } - hw.addIfNew(v, conf == Exact && len(hh.exact) > 0) - } - } - } - - // Add entries for languages with mutual intelligibility as defined by CLDR's - // languageMatch data. - for _, ml := range matchLang { - update(ml.want, ml.have, Confidence(ml.conf), false) - if !ml.oneway { - update(ml.have, ml.want, Confidence(ml.conf), false) - } - } - - // Add entries for possible canonicalizations. This is an optimization to - // ensure that only one map lookup needs to be done at runtime per desired tag. - // First we match deprecated equivalents. If they are perfect equivalents - // (their canonicalization simply substitutes a different language code, but - // nothing else), the match confidence is Exact, otherwise it is High. - for i, lm := range langAliasMap { - if lm.from == _sh { - continue - } - - // If deprecated codes match and there is no fiddling with the script or - // or region, we consider it an exact match. - conf := Exact - if langAliasTypes[i] != langMacro { - if !isExactEquivalent(langID(lm.from)) { - conf = High - } - update(lm.to, lm.from, conf, true) - } - update(lm.from, lm.to, conf, true) - } - return m -} - -// getBest gets the best matching tag in m for any of the given tags, taking into -// account the order of preference of the given tags. -func (m *matcher) getBest(want ...Tag) (got *haveTag, orig Tag, c Confidence) { - best := bestMatch{} - for _, w := range want { - var max Tag - // Check for exact match first. - h := m.index[w.lang] - if w.lang != 0 { - // Base language is defined. - if h == nil { - continue - } - for i := range h.exact { - have := &h.exact[i] - if have.tag.equalsRest(w) { - return have, w, Exact - } - } - max, _ = w.canonicalize(Legacy | Deprecated) - max, _ = addTags(max) - } else { - // Base language is not defined. - if h != nil { - for i := range h.exact { - have := &h.exact[i] - if have.tag.equalsRest(w) { - return have, w, Exact - } - } - } - if w.script == 0 && w.region == 0 { - // We skip all tags matching und for approximate matching, including - // private tags. - continue - } - max, _ = addTags(w) - if h = m.index[max.lang]; h == nil { - continue - } - } - // Check for match based on maximized tag. - for i := range h.max { - have := &h.max[i] - best.update(have, w, max.script, max.region) - if best.conf == Exact { - for have.nextMax != 0 { - have = &h.max[have.nextMax] - best.update(have, w, max.script, max.region) - } - return best.have, best.want, High - } - } - } - if best.conf <= No { - if len(want) != 0 { - return nil, want[0], No - } - return nil, Tag{}, No - } - return best.have, best.want, best.conf -} - -// bestMatch accumulates the best match so far. -type bestMatch struct { - have *haveTag - want Tag - conf Confidence - // Cached results from applying tie-breaking rules. - origLang bool - origReg bool - regDist uint8 - origScript bool - parentDist uint8 // 255 if have is not an ancestor of want tag. -} - -// update updates the existing best match if the new pair is considered to be a -// better match. -// To determine if the given pair is a better match, it first computes the rough -// confidence level. If this surpasses the current match, it will replace it and -// update the tie-breaker rule cache. If there is a tie, it proceeds with applying -// a series of tie-breaker rules. If there is no conclusive winner after applying -// the tie-breaker rules, it leaves the current match as the preferred match. -func (m *bestMatch) update(have *haveTag, tag Tag, maxScript scriptID, maxRegion regionID) { - // Bail if the maximum attainable confidence is below that of the current best match. - c := have.conf - if c < m.conf { - return - } - if have.maxScript != maxScript { - // There is usually very little comprehension between different scripts. - // In a few cases there may still be Low comprehension. This possibility is - // pre-computed and stored in have.altScript. - if Low < m.conf || have.altScript != maxScript { - return - } - c = Low - } else if have.maxRegion != maxRegion { - // There is usually a small difference between languages across regions. - // We use the region distance (below) to disambiguate between equal matches. - if High < c { - c = High - } - } - - // We store the results of the computations of the tie-breaker rules along - // with the best match. There is no need to do the checks once we determine - // we have a winner, but we do still need to do the tie-breaker computations. - // We use "beaten" to keep track if we still need to do the checks. - beaten := false // true if the new pair defeats the current one. - if c != m.conf { - if c < m.conf { - return - } - beaten = true - } - - // Tie-breaker rules: - // We prefer if the pre-maximized language was specified and identical. - origLang := have.tag.lang == tag.lang && tag.lang != 0 - if !beaten && m.origLang != origLang { - if m.origLang { - return - } - beaten = true - } - - // We prefer if the pre-maximized region was specified and identical. - origReg := have.tag.region == tag.region && tag.region != 0 - if !beaten && m.origReg != origReg { - if m.origReg { - return - } - beaten = true - } - - // Next we prefer smaller distances between regions, as defined by regionDist. - regDist := regionDist(have.maxRegion, maxRegion, tag.lang) - if !beaten && m.regDist != regDist { - if regDist > m.regDist { - return - } - beaten = true - } - - // Next we prefer if the pre-maximized script was specified and identical. - origScript := have.tag.script == tag.script && tag.script != 0 - if !beaten && m.origScript != origScript { - if m.origScript { - return - } - beaten = true - } - - // Finally we prefer tags which have a closer parent relationship. - parentDist := parentDistance(have.tag.region, tag) - if !beaten && m.parentDist != parentDist { - if parentDist > m.parentDist { - return - } - beaten = true - } - - // Update m to the newly found best match. - if beaten { - m.have = have - m.want = tag - m.conf = c - m.origLang = origLang - m.origReg = origReg - m.origScript = origScript - m.regDist = regDist - m.parentDist = parentDist - } -} - -// parentDistance returns the number of times Parent must be called before the -// regions match. It is assumed that it has already been checked that lang and -// script are identical. If haveRegion does not occur in the ancestor chain of -// tag, it returns 255. -func parentDistance(haveRegion regionID, tag Tag) uint8 { - p := tag.Parent() - d := uint8(1) - for haveRegion != p.region { - if p.region == 0 { - return 255 - } - p = p.Parent() - d++ - } - return d -} - -// regionDist wraps regionDistance with some exceptions to the algorithmic distance. -func regionDist(a, b regionID, lang langID) uint8 { - if lang == _en { - // Two variants of non-US English are close to each other, regardless of distance. - if a != _US && b != _US { - return 2 - } - } - return uint8(regionDistance(a, b)) -} - -// regionDistance computes the distance between two regions based on the -// distance in the graph of region containments as defined in CLDR. It iterates -// over increasingly inclusive sets of groups, represented as bit vectors, until -// the source bit vector has bits in common with the destination vector. -func regionDistance(a, b regionID) int { - if a == b { - return 0 - } - p, q := regionInclusion[a], regionInclusion[b] - if p < nRegionGroups { - p, q = q, p - } - set := regionInclusionBits - if q < nRegionGroups && set[p]&(1<<q) != 0 { - return 1 - } - d := 2 - for goal := set[q]; set[p]&goal == 0; p = regionInclusionNext[p] { - d++ - } - return d -} - -func (t Tag) variants() string { - if t.pVariant == 0 { - return "" - } - return t.str[t.pVariant:t.pExt] -} - -// variantOrPrivateTagStr returns variants or private use tags. -func (t Tag) variantOrPrivateTagStr() string { - if t.pExt > 0 { - return t.str[t.pVariant:t.pExt] - } - return t.str[t.pVariant:] -} - -// equalsRest compares everything except the language. -func (a Tag) equalsRest(b Tag) bool { - // TODO: don't include extensions in this comparison. To do this efficiently, - // though, we should handle private tags separately. - return a.script == b.script && a.region == b.region && a.variantOrPrivateTagStr() == b.variantOrPrivateTagStr() -} - -// isExactEquivalent returns true if canonicalizing the language will not alter -// the script or region of a tag. -func isExactEquivalent(l langID) bool { - for _, o := range notEquivalent { - if o == l { - return false - } - } - return true -} - -var notEquivalent []langID - -func init() { - // Create a list of all languages for which canonicalization may alter the - // script or region. - for _, lm := range langAliasMap { - tag := Tag{lang: langID(lm.from)} - if tag, _ = tag.canonicalize(All); tag.script != 0 || tag.region != 0 { - notEquivalent = append(notEquivalent, langID(lm.from)) - } - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/parse.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/parse.go deleted file mode 100644 index cfa28f5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/parse.go +++ /dev/null @@ -1,859 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package language - -import ( - "bytes" - "errors" - "fmt" - "sort" - "strconv" - "strings" - - "golang.org/x/text/internal/tag" -) - -// isAlpha returns true if the byte is not a digit. -// b must be an ASCII letter or digit. -func isAlpha(b byte) bool { - return b > '9' -} - -// isAlphaNum returns true if the string contains only ASCII letters or digits. -func isAlphaNum(s []byte) bool { - for _, c := range s { - if !('a' <= c && c <= 'z' || 'A' <= c && c <= 'Z' || '0' <= c && c <= '9') { - return false - } - } - return true -} - -// errSyntax is returned by any of the parsing functions when the -// input is not well-formed, according to BCP 47. -// TODO: return the position at which the syntax error occurred? -var errSyntax = errors.New("language: tag is not well-formed") - -// ValueError is returned by any of the parsing functions when the -// input is well-formed but the respective subtag is not recognized -// as a valid value. -type ValueError struct { - v [8]byte -} - -func mkErrInvalid(s []byte) error { - var e ValueError - copy(e.v[:], s) - return e -} - -func (e ValueError) tag() []byte { - n := bytes.IndexByte(e.v[:], 0) - if n == -1 { - n = 8 - } - return e.v[:n] -} - -// Error implements the error interface. -func (e ValueError) Error() string { - return fmt.Sprintf("language: subtag %q is well-formed but unknown", e.tag()) -} - -// Subtag returns the subtag for which the error occurred. -func (e ValueError) Subtag() string { - return string(e.tag()) -} - -// scanner is used to scan BCP 47 tokens, which are separated by _ or -. -type scanner struct { - b []byte - bytes [max99thPercentileSize]byte - token []byte - start int // start position of the current token - end int // end position of the current token - next int // next point for scan - err error - done bool -} - -func makeScannerString(s string) scanner { - scan := scanner{} - if len(s) <= len(scan.bytes) { - scan.b = scan.bytes[:copy(scan.bytes[:], s)] - } else { - scan.b = []byte(s) - } - scan.init() - return scan -} - -// makeScanner returns a scanner using b as the input buffer. -// b is not copied and may be modified by the scanner routines. -func makeScanner(b []byte) scanner { - scan := scanner{b: b} - scan.init() - return scan -} - -func (s *scanner) init() { - for i, c := range s.b { - if c == '_' { - s.b[i] = '-' - } - } - s.scan() -} - -// restToLower converts the string between start and end to lower case. -func (s *scanner) toLower(start, end int) { - for i := start; i < end; i++ { - c := s.b[i] - if 'A' <= c && c <= 'Z' { - s.b[i] += 'a' - 'A' - } - } -} - -func (s *scanner) setError(e error) { - if s.err == nil || (e == errSyntax && s.err != errSyntax) { - s.err = e - } -} - -// resizeRange shrinks or grows the array at position oldStart such that -// a new string of size newSize can fit between oldStart and oldEnd. -// Sets the scan point to after the resized range. -func (s *scanner) resizeRange(oldStart, oldEnd, newSize int) { - s.start = oldStart - if end := oldStart + newSize; end != oldEnd { - diff := end - oldEnd - if end < cap(s.b) { - b := make([]byte, len(s.b)+diff) - copy(b, s.b[:oldStart]) - copy(b[end:], s.b[oldEnd:]) - s.b = b - } else { - s.b = append(s.b[end:], s.b[oldEnd:]...) - } - s.next = end + (s.next - s.end) - s.end = end - } -} - -// replace replaces the current token with repl. -func (s *scanner) replace(repl string) { - s.resizeRange(s.start, s.end, len(repl)) - copy(s.b[s.start:], repl) -} - -// gobble removes the current token from the input. -// Caller must call scan after calling gobble. -func (s *scanner) gobble(e error) { - s.setError(e) - if s.start == 0 { - s.b = s.b[:+copy(s.b, s.b[s.next:])] - s.end = 0 - } else { - s.b = s.b[:s.start-1+copy(s.b[s.start-1:], s.b[s.end:])] - s.end = s.start - 1 - } - s.next = s.start -} - -// deleteRange removes the given range from s.b before the current token. -func (s *scanner) deleteRange(start, end int) { - s.setError(errSyntax) - s.b = s.b[:start+copy(s.b[start:], s.b[end:])] - diff := end - start - s.next -= diff - s.start -= diff - s.end -= diff -} - -// scan parses the next token of a BCP 47 string. Tokens that are larger -// than 8 characters or include non-alphanumeric characters result in an error -// and are gobbled and removed from the output. -// It returns the end position of the last token consumed. -func (s *scanner) scan() (end int) { - end = s.end - s.token = nil - for s.start = s.next; s.next < len(s.b); { - i := bytes.IndexByte(s.b[s.next:], '-') - if i == -1 { - s.end = len(s.b) - s.next = len(s.b) - i = s.end - s.start - } else { - s.end = s.next + i - s.next = s.end + 1 - } - token := s.b[s.start:s.end] - if i < 1 || i > 8 || !isAlphaNum(token) { - s.gobble(errSyntax) - continue - } - s.token = token - return end - } - if n := len(s.b); n > 0 && s.b[n-1] == '-' { - s.setError(errSyntax) - s.b = s.b[:len(s.b)-1] - } - s.done = true - return end -} - -// acceptMinSize parses multiple tokens of the given size or greater. -// It returns the end position of the last token consumed. -func (s *scanner) acceptMinSize(min int) (end int) { - end = s.end - s.scan() - for ; len(s.token) >= min; s.scan() { - end = s.end - } - return end -} - -// Parse parses the given BCP 47 string and returns a valid Tag. If parsing -// failed it returns an error and any part of the tag that could be parsed. -// If parsing succeeded but an unknown value was found, it returns -// ValueError. The Tag returned in this case is just stripped of the unknown -// value. All other values are preserved. It accepts tags in the BCP 47 format -// and extensions to this standard defined in -// http://www.unicode.org/reports/tr35/#Unicode_Language_and_Locale_Identifiers. -// The resulting tag is canonicalized using the default canonicalization type. -func Parse(s string) (t Tag, err error) { - return Default.Parse(s) -} - -// Parse parses the given BCP 47 string and returns a valid Tag. If parsing -// failed it returns an error and any part of the tag that could be parsed. -// If parsing succeeded but an unknown value was found, it returns -// ValueError. The Tag returned in this case is just stripped of the unknown -// value. All other values are preserved. It accepts tags in the BCP 47 format -// and extensions to this standard defined in -// http://www.unicode.org/reports/tr35/#Unicode_Language_and_Locale_Identifiers. -// The resulting tag is canonicalized using the the canonicalization type c. -func (c CanonType) Parse(s string) (t Tag, err error) { - // TODO: consider supporting old-style locale key-value pairs. - if s == "" { - return und, errSyntax - } - if len(s) <= maxAltTaglen { - b := [maxAltTaglen]byte{} - for i, c := range s { - // Generating invalid UTF-8 is okay as it won't match. - if 'A' <= c && c <= 'Z' { - c += 'a' - 'A' - } else if c == '_' { - c = '-' - } - b[i] = byte(c) - } - if t, ok := grandfathered(b); ok { - return t, nil - } - } - scan := makeScannerString(s) - t, err = parse(&scan, s) - t, changed := t.canonicalize(c) - if changed { - t.remakeString() - } - return t, err -} - -func parse(scan *scanner, s string) (t Tag, err error) { - t = und - var end int - if n := len(scan.token); n <= 1 { - scan.toLower(0, len(scan.b)) - if n == 0 || scan.token[0] != 'x' { - return t, errSyntax - } - end = parseExtensions(scan) - } else if n >= 4 { - return und, errSyntax - } else { // the usual case - t, end = parseTag(scan) - if n := len(scan.token); n == 1 { - t.pExt = uint16(end) - end = parseExtensions(scan) - } else if end < len(scan.b) { - scan.setError(errSyntax) - scan.b = scan.b[:end] - } - } - if int(t.pVariant) < len(scan.b) { - if end < len(s) { - s = s[:end] - } - if len(s) > 0 && tag.Compare(s, scan.b) == 0 { - t.str = s - } else { - t.str = string(scan.b) - } - } else { - t.pVariant, t.pExt = 0, 0 - } - return t, scan.err -} - -// parseTag parses language, script, region and variants. -// It returns a Tag and the end position in the input that was parsed. -func parseTag(scan *scanner) (t Tag, end int) { - var e error - // TODO: set an error if an unknown lang, script or region is encountered. - t.lang, e = getLangID(scan.token) - scan.setError(e) - scan.replace(t.lang.String()) - langStart := scan.start - end = scan.scan() - for len(scan.token) == 3 && isAlpha(scan.token[0]) { - // From http://tools.ietf.org/html/bcp47, <lang>-<extlang> tags are equivalent - // to a tag of the form <extlang>. - lang, e := getLangID(scan.token) - if lang != 0 { - t.lang = lang - copy(scan.b[langStart:], lang.String()) - scan.b[langStart+3] = '-' - scan.start = langStart + 4 - } - scan.gobble(e) - end = scan.scan() - } - if len(scan.token) == 4 && isAlpha(scan.token[0]) { - t.script, e = getScriptID(script, scan.token) - if t.script == 0 { - scan.gobble(e) - } - end = scan.scan() - } - if n := len(scan.token); n >= 2 && n <= 3 { - t.region, e = getRegionID(scan.token) - if t.region == 0 { - scan.gobble(e) - } else { - scan.replace(t.region.String()) - } - end = scan.scan() - } - scan.toLower(scan.start, len(scan.b)) - t.pVariant = byte(end) - end = parseVariants(scan, end, t) - t.pExt = uint16(end) - return t, end -} - -var separator = []byte{'-'} - -// parseVariants scans tokens as long as each token is a valid variant string. -// Duplicate variants are removed. -func parseVariants(scan *scanner, end int, t Tag) int { - start := scan.start - varIDBuf := [4]uint8{} - variantBuf := [4][]byte{} - varID := varIDBuf[:0] - variant := variantBuf[:0] - last := -1 - needSort := false - for ; len(scan.token) >= 4; scan.scan() { - // TODO: measure the impact of needing this conversion and redesign - // the data structure if there is an issue. - v, ok := variantIndex[string(scan.token)] - if !ok { - // unknown variant - // TODO: allow user-defined variants? - scan.gobble(mkErrInvalid(scan.token)) - continue - } - varID = append(varID, v) - variant = append(variant, scan.token) - if !needSort { - if last < int(v) { - last = int(v) - } else { - needSort = true - // There is no legal combinations of more than 7 variants - // (and this is by no means a useful sequence). - const maxVariants = 8 - if len(varID) > maxVariants { - break - } - } - } - end = scan.end - } - if needSort { - sort.Sort(variantsSort{varID, variant}) - k, l := 0, -1 - for i, v := range varID { - w := int(v) - if l == w { - // Remove duplicates. - continue - } - varID[k] = varID[i] - variant[k] = variant[i] - k++ - l = w - } - if str := bytes.Join(variant[:k], separator); len(str) == 0 { - end = start - 1 - } else { - scan.resizeRange(start, end, len(str)) - copy(scan.b[scan.start:], str) - end = scan.end - } - } - return end -} - -type variantsSort struct { - i []uint8 - v [][]byte -} - -func (s variantsSort) Len() int { - return len(s.i) -} - -func (s variantsSort) Swap(i, j int) { - s.i[i], s.i[j] = s.i[j], s.i[i] - s.v[i], s.v[j] = s.v[j], s.v[i] -} - -func (s variantsSort) Less(i, j int) bool { - return s.i[i] < s.i[j] -} - -type bytesSort [][]byte - -func (b bytesSort) Len() int { - return len(b) -} - -func (b bytesSort) Swap(i, j int) { - b[i], b[j] = b[j], b[i] -} - -func (b bytesSort) Less(i, j int) bool { - return bytes.Compare(b[i], b[j]) == -1 -} - -// parseExtensions parses and normalizes the extensions in the buffer. -// It returns the last position of scan.b that is part of any extension. -// It also trims scan.b to remove excess parts accordingly. -func parseExtensions(scan *scanner) int { - start := scan.start - exts := [][]byte{} - private := []byte{} - end := scan.end - for len(scan.token) == 1 { - extStart := scan.start - ext := scan.token[0] - end = parseExtension(scan) - extension := scan.b[extStart:end] - if len(extension) < 3 || (ext != 'x' && len(extension) < 4) { - scan.setError(errSyntax) - end = extStart - continue - } else if start == extStart && (ext == 'x' || scan.start == len(scan.b)) { - scan.b = scan.b[:end] - return end - } else if ext == 'x' { - private = extension - break - } - exts = append(exts, extension) - } - sort.Sort(bytesSort(exts)) - if len(private) > 0 { - exts = append(exts, private) - } - scan.b = scan.b[:start] - if len(exts) > 0 { - scan.b = append(scan.b, bytes.Join(exts, separator)...) - } else if start > 0 { - // Strip trailing '-'. - scan.b = scan.b[:start-1] - } - return end -} - -// parseExtension parses a single extension and returns the position of -// the extension end. -func parseExtension(scan *scanner) int { - start, end := scan.start, scan.end - switch scan.token[0] { - case 'u': - attrStart := end - scan.scan() - for last := []byte{}; len(scan.token) > 2; scan.scan() { - if bytes.Compare(scan.token, last) != -1 { - // Attributes are unsorted. Start over from scratch. - p := attrStart + 1 - scan.next = p - attrs := [][]byte{} - for scan.scan(); len(scan.token) > 2; scan.scan() { - attrs = append(attrs, scan.token) - end = scan.end - } - sort.Sort(bytesSort(attrs)) - copy(scan.b[p:], bytes.Join(attrs, separator)) - break - } - last = scan.token - end = scan.end - } - var last, key []byte - for attrEnd := end; len(scan.token) == 2; last = key { - key = scan.token - keyEnd := scan.end - end = scan.acceptMinSize(3) - // TODO: check key value validity - if keyEnd == end || bytes.Compare(key, last) != 1 { - // We have an invalid key or the keys are not sorted. - // Start scanning keys from scratch and reorder. - p := attrEnd + 1 - scan.next = p - keys := [][]byte{} - for scan.scan(); len(scan.token) == 2; { - keyStart, keyEnd := scan.start, scan.end - end = scan.acceptMinSize(3) - if keyEnd != end { - keys = append(keys, scan.b[keyStart:end]) - } else { - scan.setError(errSyntax) - end = keyStart - } - } - sort.Sort(bytesSort(keys)) - reordered := bytes.Join(keys, separator) - if e := p + len(reordered); e < end { - scan.deleteRange(e, end) - end = e - } - copy(scan.b[p:], bytes.Join(keys, separator)) - break - } - } - case 't': - scan.scan() - if n := len(scan.token); n >= 2 && n <= 3 && isAlpha(scan.token[1]) { - _, end = parseTag(scan) - scan.toLower(start, end) - } - for len(scan.token) == 2 && !isAlpha(scan.token[1]) { - end = scan.acceptMinSize(3) - } - case 'x': - end = scan.acceptMinSize(1) - default: - end = scan.acceptMinSize(2) - } - return end -} - -// Compose creates a Tag from individual parts, which may be of type Tag, Base, -// Script, Region, Variant, []Variant, Extension, []Extension or error. If a -// Base, Script or Region or slice of type Variant or Extension is passed more -// than once, the latter will overwrite the former. Variants and Extensions are -// accumulated, but if two extensions of the same type are passed, the latter -// will replace the former. A Tag overwrites all former values and typically -// only makes sense as the first argument. The resulting tag is returned after -// canonicalizing using the Default CanonType. If one or more errors are -// encountered, one of the errors is returned. -func Compose(part ...interface{}) (t Tag, err error) { - return Default.Compose(part...) -} - -// Compose creates a Tag from individual parts, which may be of type Tag, Base, -// Script, Region, Variant, []Variant, Extension, []Extension or error. If a -// Base, Script or Region or slice of type Variant or Extension is passed more -// than once, the latter will overwrite the former. Variants and Extensions are -// accumulated, but if two extensions of the same type are passed, the latter -// will replace the former. A Tag overwrites all former values and typically -// only makes sense as the first argument. The resulting tag is returned after -// canonicalizing using CanonType c. If one or more errors are encountered, -// one of the errors is returned. -func (c CanonType) Compose(part ...interface{}) (t Tag, err error) { - var b builder - if err = b.update(part...); err != nil { - return und, err - } - t, _ = b.tag.canonicalize(c) - - if len(b.ext) > 0 || len(b.variant) > 0 { - sort.Sort(sortVariant(b.variant)) - sort.Strings(b.ext) - if b.private != "" { - b.ext = append(b.ext, b.private) - } - n := maxCoreSize + tokenLen(b.variant...) + tokenLen(b.ext...) - buf := make([]byte, n) - p := t.genCoreBytes(buf) - t.pVariant = byte(p) - p += appendTokens(buf[p:], b.variant...) - t.pExt = uint16(p) - p += appendTokens(buf[p:], b.ext...) - t.str = string(buf[:p]) - } else if b.private != "" { - t.str = b.private - t.remakeString() - } - return -} - -type builder struct { - tag Tag - - private string // the x extension - ext []string - variant []string - - err error -} - -func (b *builder) addExt(e string) { - if e == "" { - } else if e[0] == 'x' { - b.private = e - } else { - b.ext = append(b.ext, e) - } -} - -var errInvalidArgument = errors.New("invalid Extension or Variant") - -func (b *builder) update(part ...interface{}) (err error) { - replace := func(l *[]string, s string, eq func(a, b string) bool) bool { - if s == "" { - b.err = errInvalidArgument - return true - } - for i, v := range *l { - if eq(v, s) { - (*l)[i] = s - return true - } - } - return false - } - for _, x := range part { - switch v := x.(type) { - case Tag: - b.tag.lang = v.lang - b.tag.region = v.region - b.tag.script = v.script - if v.str != "" { - b.variant = nil - for x, s := "", v.str[v.pVariant:v.pExt]; s != ""; { - x, s = nextToken(s) - b.variant = append(b.variant, x) - } - b.ext, b.private = nil, "" - for i, e := int(v.pExt), ""; i < len(v.str); { - i, e = getExtension(v.str, i) - b.addExt(e) - } - } - case Base: - b.tag.lang = v.langID - case Script: - b.tag.script = v.scriptID - case Region: - b.tag.region = v.regionID - case Variant: - if !replace(&b.variant, v.variant, func(a, b string) bool { return a == b }) { - b.variant = append(b.variant, v.variant) - } - case Extension: - if !replace(&b.ext, v.s, func(a, b string) bool { return a[0] == b[0] }) { - b.addExt(v.s) - } - case []Variant: - b.variant = nil - for _, x := range v { - b.update(x) - } - case []Extension: - b.ext, b.private = nil, "" - for _, e := range v { - b.update(e) - } - // TODO: support parsing of raw strings based on morphology or just extensions? - case error: - err = v - } - } - return -} - -func tokenLen(token ...string) (n int) { - for _, t := range token { - n += len(t) + 1 - } - return -} - -func appendTokens(b []byte, token ...string) int { - p := 0 - for _, t := range token { - b[p] = '-' - copy(b[p+1:], t) - p += 1 + len(t) - } - return p -} - -type sortVariant []string - -func (s sortVariant) Len() int { - return len(s) -} - -func (s sortVariant) Swap(i, j int) { - s[j], s[i] = s[i], s[j] -} - -func (s sortVariant) Less(i, j int) bool { - return variantIndex[s[i]] < variantIndex[s[j]] -} - -func findExt(list []string, x byte) int { - for i, e := range list { - if e[0] == x { - return i - } - } - return -1 -} - -// getExtension returns the name, body and end position of the extension. -func getExtension(s string, p int) (end int, ext string) { - if s[p] == '-' { - p++ - } - if s[p] == 'x' { - return len(s), s[p:] - } - end = nextExtension(s, p) - return end, s[p:end] -} - -// nextExtension finds the next extension within the string, searching -// for the -<char>- pattern from position p. -// In the fast majority of cases, language tags will have at most -// one extension and extensions tend to be small. -func nextExtension(s string, p int) int { - for n := len(s) - 3; p < n; { - if s[p] == '-' { - if s[p+2] == '-' { - return p - } - p += 3 - } else { - p++ - } - } - return len(s) -} - -var errInvalidWeight = errors.New("ParseAcceptLanguage: invalid weight") - -// ParseAcceptLanguage parses the contents of a Accept-Language header as -// defined in http://www.ietf.org/rfc/rfc2616.txt and returns a list of Tags and -// a list of corresponding quality weights. It is more permissive than RFC 2616 -// and may return non-nil slices even if the input is not valid. -// The Tags will be sorted by highest weight first and then by first occurrence. -// Tags with a weight of zero will be dropped. An error will be returned if the -// input could not be parsed. -func ParseAcceptLanguage(s string) (tag []Tag, q []float32, err error) { - var entry string - for s != "" { - if entry, s = split(s, ','); entry == "" { - continue - } - - entry, weight := split(entry, ';') - - // Scan the language. - t, err := Parse(entry) - if err != nil { - id, ok := acceptFallback[entry] - if !ok { - return nil, nil, err - } - t = Tag{lang: id} - } - - // Scan the optional weight. - w := 1.0 - if weight != "" { - weight = consume(weight, 'q') - weight = consume(weight, '=') - // consume returns the empty string when a token could not be - // consumed, resulting in an error for ParseFloat. - if w, err = strconv.ParseFloat(weight, 32); err != nil { - return nil, nil, errInvalidWeight - } - // Drop tags with a quality weight of 0. - if w <= 0 { - continue - } - } - - tag = append(tag, t) - q = append(q, float32(w)) - } - sortStable(&tagSort{tag, q}) - return tag, q, nil -} - -// consume removes a leading token c from s and returns the result or the empty -// string if there is no such token. -func consume(s string, c byte) string { - if s == "" || s[0] != c { - return "" - } - return strings.TrimSpace(s[1:]) -} - -func split(s string, c byte) (head, tail string) { - if i := strings.IndexByte(s, c); i >= 0 { - return strings.TrimSpace(s[:i]), strings.TrimSpace(s[i+1:]) - } - return strings.TrimSpace(s), "" -} - -// Add hack mapping to deal with a small number of cases that that occur -// in Accept-Language (with reasonable frequency). -var acceptFallback = map[string]langID{ - "english": _en, - "deutsch": _de, - "italian": _it, - "french": _fr, - "*": _mul, // defined in the spec to match all languages. -} - -type tagSort struct { - tag []Tag - q []float32 -} - -func (s *tagSort) Len() int { - return len(s.q) -} - -func (s *tagSort) Less(i, j int) bool { - return s.q[i] > s.q[j] -} - -func (s *tagSort) Swap(i, j int) { - s.tag[i], s.tag[j] = s.tag[j], s.tag[i] - s.q[i], s.q[j] = s.q[j], s.q[i] -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tables.go deleted file mode 100644 index 5de0f85..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tables.go +++ /dev/null @@ -1,2791 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package language - -import "golang.org/x/text/internal/tag" - -// CLDRVersion is the CLDR version from which the tables in this package are derived. -const CLDRVersion = "29" - -const numLanguages = 8654 - -const numScripts = 230 - -const numRegions = 354 - -type fromTo struct { - from uint16 - to uint16 -} - -const nonCanonicalUnd = 649 -const ( - _af = 10 - _am = 17 - _ar = 21 - _az = 36 - _bg = 56 - _bn = 75 - _ca = 97 - _cs = 121 - _da = 128 - _de = 133 - _el = 154 - _en = 155 - _es = 157 - _et = 159 - _fa = 164 - _fi = 168 - _fil = 170 - _fr = 175 - _gu = 211 - _he = 224 - _hi = 225 - _hr = 238 - _hu = 242 - _hy = 243 - _id = 248 - _is = 258 - _it = 259 - _ja = 263 - _ka = 273 - _kk = 303 - _km = 307 - _kn = 309 - _ko = 310 - _ky = 333 - _lo = 357 - _lt = 361 - _lv = 368 - _mk = 396 - _ml = 397 - _mn = 399 - _mo = 402 - _mr = 406 - _ms = 410 - _mul = 414 - _my = 421 - _nb = 431 - _ne = 436 - _nl = 445 - _no = 449 - _pa = 471 - _pl = 487 - _pt = 495 - _ro = 515 - _ru = 519 - _sh = 549 - _si = 552 - _sk = 554 - _sl = 556 - _sq = 570 - _sr = 571 - _sv = 583 - _sw = 584 - _ta = 593 - _te = 600 - _th = 605 - _tl = 616 - _tn = 619 - _tr = 623 - _uk = 646 - _ur = 652 - _uz = 653 - _vi = 658 - _zh = 708 - _zu = 710 - _jbo = 265 - _ami = 1033 - _bnn = 1740 - _hak = 221 - _tlh = 13850 - _lb = 340 - _nv = 458 - _pwn = 11438 - _tao = 13571 - _tay = 13581 - _tsu = 14045 - _nn = 447 - _sfb = 13012 - _vgt = 15084 - _sgg = 13043 - _cmn = 2390 - _nan = 428 - _hsn = 240 -) - -const langPrivateStart = 0x2d09 - -const langPrivateEnd = 0x2f10 - -// lang holds an alphabetically sorted list of ISO-639 language identifiers. -// All entries are 4 bytes. The index of the identifier (divided by 4) is the language tag. -// For 2-byte language identifiers, the two successive bytes have the following meaning: -// - if the first letter of the 2- and 3-letter ISO codes are the same: -// the second and third letter of the 3-letter ISO code. -// - otherwise: a 0 and a by 2 bits right-shifted index into altLangISO3. -// For 3-byte language identifiers the 4th byte is 0. -var lang tag.Index = "" + // Size: 2856 bytes - "---\x00aaarabbkabr\x00ace\x00ach\x00ada\x00ady\x00aeveaeb\x00affragq\x00" + - "aho\x00akkaakk\x00aln\x00alt\x00ammhamo\x00anrgaoz\x00arraarc\x00arn\x00" + - "aro\x00arq\x00ary\x00arz\x00assmasa\x00ase\x00ast\x00atj\x00avvaawa\x00a" + - "yymazzebaakbal\x00ban\x00bap\x00bar\x00bas\x00bax\x00bbc\x00bbj\x00bci" + - "\x00beelbej\x00bem\x00bew\x00bez\x00bfd\x00bfq\x00bft\x00bfy\x00bgulbgc" + - "\x00bgn\x00bgx\x00bhihbhb\x00bhi\x00bhk\x00bho\x00biisbik\x00bin\x00bjj" + - "\x00bjn\x00bkm\x00bku\x00blt\x00bmambmq\x00bnenboodbpy\x00bqi\x00bqv\x00" + - "brrebra\x00brh\x00brx\x00bsosbsq\x00bss\x00bto\x00btv\x00bua\x00buc\x00b" + - "ug\x00bum\x00bvb\x00byn\x00byv\x00bze\x00caatcch\x00ccp\x00ceheceb\x00cg" + - "g\x00chhachk\x00chm\x00cho\x00chp\x00chr\x00cja\x00cjm\x00ckb\x00cooscop" + - "\x00cps\x00crrecrj\x00crk\x00crl\x00crm\x00crs\x00csescsb\x00csw\x00ctd" + - "\x00cuhucvhvcyymdaandak\x00dar\x00dav\x00dcc\x00deeuden\x00dgr\x00dje" + - "\x00dnj\x00doi\x00dsb\x00dtm\x00dtp\x00dty\x00dua\x00dvivdyo\x00dyu\x00d" + - "zzoebu\x00eeweefi\x00egl\x00egy\x00eky\x00elllenngeopoes\x00\x05esu\x00e" + - "tstett\x00euusewo\x00ext\x00faasfan\x00ffulffm\x00fiinfia\x00fil\x00fit" + - "\x00fjijfoaofon\x00frrafrc\x00frp\x00frr\x00frs\x00fud\x00fuq\x00fur\x00" + - "fuv\x00fvr\x00fyrygalegaa\x00gag\x00gan\x00gay\x00gbm\x00gbz\x00gcr\x00g" + - "dlagez\x00ggn\x00gil\x00gjk\x00gju\x00gllgglk\x00gnrngom\x00gon\x00gor" + - "\x00gos\x00got\x00grc\x00grt\x00gsw\x00guujgub\x00guc\x00gur\x00guw\x00g" + - "uz\x00gvlvgvr\x00gwi\x00haauhak\x00haw\x00haz\x00heebhiinhif\x00hil\x00h" + - "lu\x00hmd\x00hnd\x00hne\x00hnj\x00hnn\x00hno\x00homohoc\x00hoj\x00hrrvhs" + - "b\x00hsn\x00htathuunhyyehzerianaiba\x00ibb\x00idndieleigboiiiiikpkikt" + - "\x00ilo\x00inndinh\x00iodoisslittaiukuiw\x00\x03izh\x00japnjam\x00jbo" + - "\x00jgo\x00ji\x00\x06jmc\x00jml\x00jut\x00jvavjwavkaatkaa\x00kab\x00kac" + - "\x00kaj\x00kam\x00kao\x00kbd\x00kcg\x00kck\x00kde\x00kdt\x00kea\x00ken" + - "\x00kfo\x00kfr\x00kfy\x00kgonkge\x00kgp\x00kha\x00khb\x00khn\x00khq\x00k" + - "ht\x00khw\x00kiikkiu\x00kjuakjg\x00kkazkkj\x00klalkln\x00kmhmkmb\x00knan" + - "koorkoi\x00kok\x00kos\x00kpe\x00kraukrc\x00kri\x00krj\x00krl\x00kru\x00k" + - "sasksb\x00ksf\x00ksh\x00kuurkum\x00kvomkvr\x00kvx\x00kw\x00\x01kxm\x00kx" + - "p\x00kyirlaatlab\x00lad\x00lag\x00lah\x00laj\x00lbtzlbe\x00lbw\x00lcp" + - "\x00lep\x00lez\x00lgugliimlif\x00lij\x00lis\x00ljp\x00lki\x00lkt\x00lmn" + - "\x00lmo\x00lninloaolol\x00loz\x00lrc\x00ltitltg\x00luublua\x00luo\x00luy" + - "\x00luz\x00lvavlwl\x00lzh\x00lzz\x00mad\x00maf\x00mag\x00mai\x00mak\x00m" + - "an\x00mas\x00maz\x00mdf\x00mdh\x00mdr\x00men\x00mer\x00mfa\x00mfe\x00mgl" + - "gmgh\x00mgo\x00mgp\x00mgy\x00mhahmirimin\x00mis\x00mkkdmlalmls\x00mnonmn" + - "i\x00mnw\x00moolmoe\x00moh\x00mos\x00mrarmrd\x00mrj\x00mro\x00mssamtltmt" + - "r\x00mua\x00mul\x00mus\x00mvy\x00mwk\x00mwr\x00mwv\x00mxc\x00myyamyv\x00" + - "myx\x00myz\x00mzn\x00naaunah\x00nan\x00nap\x00naq\x00nbobnch\x00nddendc" + - "\x00nds\x00neepnew\x00ngdongl\x00nhe\x00nhw\x00nij\x00niu\x00njo\x00nlld" + - "nmg\x00nnnonnh\x00noornod\x00noe\x00non\x00nqo\x00nrblnsk\x00nso\x00nus" + - "\x00nvavnxq\x00nyyanym\x00nyn\x00nzi\x00occiojjiomrmorriosssosa\x00otk" + - "\x00paanpag\x00pal\x00pam\x00pap\x00pau\x00pcd\x00pcm\x00pdc\x00pdt\x00p" + - "eo\x00pfl\x00phn\x00pilipka\x00pko\x00plolpms\x00pnt\x00pon\x00pra\x00pr" + - "d\x00prg\x00psusptorpuu\x00quuequc\x00qug\x00raj\x00rcf\x00rej\x00rgn" + - "\x00ria\x00rif\x00rjs\x00rkt\x00rmohrmf\x00rmo\x00rmt\x00rmu\x00rnunrng" + - "\x00roonrob\x00rof\x00rtm\x00ruusrue\x00rug\x00rw\x00\x04rwk\x00ryu\x00s" + - "aansaf\x00sah\x00saq\x00sas\x00sat\x00saz\x00sbp\x00scrdsck\x00scn\x00sc" + - "o\x00scs\x00sdndsdc\x00sdh\x00semesef\x00seh\x00sei\x00ses\x00sgagsga" + - "\x00sgs\x00sh\x00\x02shi\x00shn\x00siinsid\x00sklkskr\x00sllvsli\x00sly" + - "\x00smmosma\x00smi\x00smj\x00smn\x00smp\x00sms\x00snnasnk\x00soomsou\x00" + - "sqqisrrpsrb\x00srn\x00srr\x00srx\x00ssswssy\x00stotstq\x00suunsuk\x00sus" + - "\x00svweswwaswb\x00swc\x00swg\x00swv\x00sxn\x00syl\x00syr\x00szl\x00taam" + - "taj\x00tbw\x00tcy\x00tdd\x00tdg\x00tdh\x00teeltem\x00teo\x00tet\x00tggkt" + - "hhathl\x00thq\x00thr\x00tiirtig\x00tiv\x00tkuktkl\x00tkr\x00tkt\x00tlglt" + - "ly\x00tmh\x00tnsntoontog\x00tpi\x00trurtru\x00trv\x00tssotsd\x00tsf\x00t" + - "sg\x00tsj\x00ttatttj\x00tts\x00ttt\x00tum\x00tvl\x00twwitwq\x00txg\x00ty" + - "ahtyv\x00tzm\x00udm\x00ugiguga\x00ukkruli\x00umb\x00und\x00unr\x00unx" + - "\x00urrduzzbvai\x00veenvec\x00vep\x00viievic\x00vls\x00vmf\x00vmw\x00voo" + - "lvot\x00vro\x00vun\x00walnwae\x00wal\x00war\x00wbp\x00wbq\x00wbr\x00wls" + - "\x00wni\x00woolwtm\x00wuu\x00xav\x00xcr\x00xhhoxlc\x00xld\x00xmf\x00xmn" + - "\x00xmr\x00xna\x00xnr\x00xog\x00xpr\x00xsa\x00xsr\x00yao\x00yap\x00yav" + - "\x00ybb\x00yiidyooryrl\x00yua\x00yue\x00zahazag\x00zbl\x00zdj\x00zea\x00" + - "zgh\x00zhhozmi\x00zuulzxx\x00zza\x00\xff\xff\xff\xff" - -const langNoIndexOffset = 713 - -// langNoIndex is a bit vector of all 3-letter language codes that are not used as an index -// in lookup tables. The language ids for these language codes are derived directly -// from the letters and are not consecutive. -// Size: 2197 bytes, 2197 elements -var langNoIndex = [2197]uint8{ - // Entry 0 - 3F - 0xff, 0xfd, 0xfd, 0xfe, 0xef, 0xf7, 0xbf, 0xd2, - 0xfb, 0xbf, 0xfe, 0xfa, 0xb7, 0x1d, 0x3c, 0x57, - 0x6f, 0x97, 0x73, 0xf8, 0xff, 0xef, 0xff, 0x70, - 0xaf, 0x03, 0xff, 0xff, 0xcf, 0x05, 0x85, 0x62, - 0xe9, 0xbf, 0xfd, 0xff, 0xff, 0xf7, 0xfd, 0x77, - 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe3, - 0xc9, 0xff, 0xff, 0xff, 0x4d, 0xb8, 0x0a, 0x6a, - 0x7e, 0xfa, 0xe3, 0xfe, 0x7e, 0xff, 0x77, 0xff, - // Entry 40 - 7F - 0xff, 0xff, 0xff, 0xdf, 0x2b, 0xf4, 0xf1, 0xe0, - 0x5d, 0xe7, 0x9f, 0x14, 0x07, 0x20, 0xdf, 0xed, - 0x9f, 0x3f, 0xc9, 0x21, 0xf8, 0x3f, 0x94, 0xf7, - 0x7e, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xff, - 0xff, 0xff, 0x5f, 0xfc, 0xdb, 0xfd, 0xbf, 0xb5, - 0x7b, 0xdf, 0x7f, 0xf7, 0xeb, 0xfe, 0xff, 0xa7, - 0xbd, 0xff, 0x7f, 0xf7, 0xff, 0xef, 0xef, 0xef, - 0xff, 0xff, 0x9f, 0xff, 0xff, 0xef, 0xff, 0xdf, - // Entry 80 - BF - 0xff, 0xff, 0xf3, 0xff, 0xfb, 0x2f, 0xff, 0xff, - 0xfb, 0xee, 0xff, 0xbd, 0xdb, 0xff, 0xdf, 0xf7, - 0xff, 0xfa, 0xfd, 0xff, 0x7e, 0xaf, 0x7b, 0xfe, - 0x7f, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xdf, 0xff, - 0xff, 0xdf, 0xfb, 0xff, 0xfd, 0xfc, 0xfb, 0xff, - 0xff, 0xff, 0xff, 0xf7, 0x7f, 0xbf, 0xfd, 0xd5, - 0xa5, 0x77, 0x40, 0xff, 0x9c, 0xc1, 0x41, 0x2c, - 0x08, 0x24, 0x41, 0x00, 0x50, 0x40, 0x00, 0x80, - // Entry C0 - FF - 0xfb, 0x4a, 0xf2, 0x9f, 0xb4, 0x42, 0x41, 0x96, - 0x9b, 0x14, 0x88, 0xf6, 0x7b, 0xe7, 0x17, 0x56, - 0x55, 0x7d, 0x0e, 0x1c, 0x37, 0x71, 0xf3, 0xef, - 0x97, 0xff, 0x5d, 0x38, 0x64, 0x08, 0x00, 0x10, - 0xbc, 0x87, 0xaf, 0xdf, 0xff, 0xf7, 0x73, 0x35, - 0x3e, 0x87, 0xc7, 0xdf, 0xff, 0x00, 0x81, 0x00, - 0xb0, 0x05, 0x80, 0x00, 0x00, 0x00, 0x00, 0x03, - 0x40, 0x00, 0x40, 0x92, 0x21, 0xd0, 0xbf, 0x5d, - // Entry 100 - 13F - 0xfd, 0xde, 0xfe, 0x5e, 0x00, 0x00, 0x02, 0x64, - 0x8d, 0x19, 0xc1, 0xdf, 0x79, 0x22, 0x00, 0x00, - 0x00, 0xdf, 0x6d, 0xdc, 0x26, 0xe5, 0xd9, 0xf3, - 0xfe, 0xff, 0xfd, 0xcb, 0x9f, 0x14, 0x01, 0x0c, - 0x86, 0x00, 0xd1, 0x00, 0xf0, 0xc5, 0x67, 0x5f, - 0x56, 0x89, 0x5e, 0xb7, 0xec, 0xef, 0x03, 0x00, - 0x02, 0x00, 0x00, 0x00, 0xc0, 0x77, 0xda, 0x57, - 0x90, 0x69, 0x01, 0x2c, 0x96, 0x79, 0xe0, 0xff, - // Entry 140 - 17F - 0xff, 0x7f, 0x00, 0x00, 0x00, 0x01, 0x08, 0x56, - 0x01, 0x00, 0x00, 0xb0, 0x14, 0x03, 0x50, 0x16, - 0x0a, 0x00, 0x01, 0x00, 0x00, 0x00, 0x11, 0x09, - 0x00, 0x00, 0x60, 0x10, 0x00, 0x00, 0x00, 0x10, - 0x00, 0x00, 0x44, 0x00, 0x00, 0x10, 0x00, 0x04, - 0x08, 0x00, 0x00, 0x04, 0x00, 0x80, 0x28, 0x04, - 0x00, 0x00, 0x50, 0xd5, 0x2d, 0x00, 0x64, 0x35, - 0x24, 0x53, 0xf5, 0xd4, 0xbd, 0xe2, 0xcd, 0x03, - // Entry 180 - 1BF - 0x00, 0x80, 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x04, 0x17, 0x39, 0x01, 0xdd, 0x57, 0x98, - 0x21, 0x98, 0xa5, 0x00, 0x00, 0x01, 0x40, 0x82, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x01, 0x40, 0x00, 0x44, 0x00, 0x00, 0xb0, 0xfe, - 0xa9, 0x39, 0x00, 0x02, 0x00, 0x00, 0x00, 0x04, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x40, - 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, - // Entry 1C0 - 1FF - 0x00, 0x01, 0x28, 0x05, 0x00, 0x00, 0x00, 0x00, - 0x04, 0x20, 0x04, 0xa6, 0x08, 0x04, 0x00, 0x08, - 0x81, 0x50, 0x00, 0x00, 0x08, 0x11, 0x86, 0x40, - 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x06, 0x55, - 0x02, 0x10, 0x08, 0x04, 0x00, 0x00, 0x00, 0x60, - 0x3b, 0x83, 0x11, 0x00, 0x00, 0x00, 0x11, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0xbe, 0xdf, 0xff, 0xfe, 0xbf, - // Entry 200 - 23F - 0xdf, 0xc7, 0x83, 0x82, 0xc0, 0xff, 0xdf, 0x27, - 0xcf, 0x5f, 0xe7, 0x01, 0x10, 0x20, 0xb2, 0xc5, - 0xa4, 0x45, 0x25, 0x9b, 0x03, 0xcf, 0xf0, 0xdf, - 0x03, 0xc4, 0x08, 0x10, 0x01, 0x0e, 0x01, 0xe3, - 0x92, 0x54, 0xdb, 0x38, 0xf1, 0x7f, 0xf7, 0x6d, - 0xf9, 0xff, 0x1c, 0x7d, 0x04, 0x08, 0x00, 0x01, - 0x21, 0x12, 0x6c, 0x5f, 0xdd, 0x0f, 0x85, 0x4f, - 0x40, 0x40, 0x00, 0x04, 0xf9, 0xfd, 0xbd, 0xd4, - // Entry 240 - 27F - 0xe8, 0x13, 0xf4, 0x27, 0xa3, 0x0d, 0x00, 0x00, - 0x20, 0x7b, 0x39, 0x02, 0x05, 0x84, 0x00, 0xf0, - 0xbf, 0x7f, 0xda, 0x00, 0x18, 0x04, 0x81, 0x00, - 0x00, 0x00, 0x80, 0x10, 0x94, 0x1c, 0x01, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x10, 0x40, 0x00, 0x04, - 0x08, 0xb4, 0x7c, 0xa5, 0x0c, 0x40, 0x00, 0x00, - 0x11, 0x04, 0x04, 0x6c, 0x00, 0x20, 0x70, 0xff, - 0xfb, 0x7f, 0x60, 0x00, 0x05, 0x9b, 0xdd, 0x6e, - // Entry 280 - 2BF - 0x03, 0x00, 0x11, 0x00, 0x00, 0x00, 0x40, 0x05, - 0xb5, 0xb6, 0x80, 0x08, 0x04, 0x00, 0x04, 0x51, - 0xe2, 0xff, 0xfd, 0x3f, 0x05, 0x09, 0x08, 0x05, - 0x40, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, - 0x08, 0x00, 0x00, 0x00, 0x00, 0xa1, 0x02, 0x60, - 0xe5, 0x48, 0x14, 0x89, 0x20, 0xc0, 0x47, 0x80, - 0x07, 0x00, 0x00, 0x00, 0xcc, 0x50, 0x40, 0x24, - 0x85, 0x47, 0x84, 0x40, 0x20, 0x10, 0x00, 0x20, - // Entry 2C0 - 2FF - 0x02, 0x50, 0x88, 0x11, 0x00, 0xd1, 0x6c, 0xee, - 0x50, 0x27, 0x1d, 0x11, 0x69, 0x06, 0x59, 0xe9, - 0x33, 0x08, 0x00, 0x20, 0x05, 0x40, 0x10, 0x00, - 0x00, 0x00, 0x50, 0x44, 0x96, 0x49, 0xd6, 0x5d, - 0xa7, 0x81, 0x47, 0x97, 0xfb, 0x00, 0x10, 0x00, - 0x08, 0x00, 0x80, 0x00, 0x40, 0x45, 0x00, 0x01, - 0x02, 0x00, 0x01, 0x40, 0x80, 0x00, 0x04, 0x08, - 0xf8, 0xeb, 0xf6, 0x39, 0xc4, 0x89, 0x16, 0x00, - // Entry 300 - 33F - 0x00, 0x0c, 0x04, 0x01, 0x20, 0x20, 0xdd, 0xa2, - 0x01, 0x00, 0x00, 0x00, 0x12, 0x04, 0x00, 0x00, - 0x04, 0x10, 0xf0, 0x9d, 0x95, 0x13, 0x04, 0x80, - 0x00, 0x01, 0xd0, 0x12, 0x40, 0x00, 0x10, 0xb0, - 0x10, 0x62, 0x4c, 0xd2, 0x02, 0x01, 0x4a, 0x00, - 0x46, 0x04, 0x00, 0x08, 0x02, 0x00, 0x20, 0xc0, - 0x00, 0x80, 0x06, 0x00, 0x08, 0x00, 0x00, 0x00, - 0x00, 0xf0, 0xd8, 0x6f, 0x15, 0x02, 0x08, 0x00, - // Entry 340 - 37F - 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x10, 0x01, - 0x00, 0x10, 0x00, 0x00, 0x00, 0xf8, 0x85, 0xe3, - 0xdd, 0xff, 0xff, 0xff, 0xbb, 0xff, 0x7f, 0xfb, - 0xff, 0xfc, 0xfe, 0xdf, 0xff, 0xff, 0xff, 0xf6, - 0xfb, 0xfe, 0xf7, 0x1f, 0xff, 0xb3, 0xed, 0xff, - 0xdb, 0xed, 0xff, 0xfe, 0xff, 0xfe, 0xdf, 0xff, - 0xff, 0xff, 0xf7, 0xff, 0xfd, 0xff, 0xff, 0xff, - 0xfd, 0xff, 0xdf, 0xaf, 0x9c, 0xff, 0xfb, 0xff, - // Entry 380 - 3BF - 0xff, 0xff, 0xff, 0xff, 0xef, 0xd2, 0xbb, 0xdf, - 0xf5, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xef, - 0xfd, 0xff, 0xff, 0xf7, 0xfd, 0xff, 0xff, 0xff, - 0xef, 0xdb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0x5f, 0xd3, 0x7b, 0xfd, 0xd9, 0xdf, 0xef, - 0xbc, 0x18, 0x05, 0x2c, 0xff, 0x07, 0xf0, 0xff, - 0xf7, 0x5f, 0x00, 0x08, 0x00, 0xc3, 0x3d, 0x1b, - 0x06, 0xe6, 0x72, 0xf0, 0xdd, 0x3c, 0x7f, 0x44, - // Entry 3C0 - 3FF - 0x02, 0x30, 0x9f, 0x7a, 0x16, 0xfd, 0xff, 0x57, - 0xf2, 0xff, 0x39, 0xff, 0xf2, 0x1e, 0x95, 0xf7, - 0xf7, 0xff, 0x45, 0x80, 0x01, 0x02, 0x00, 0x00, - 0x40, 0x54, 0x9f, 0x8a, 0xd9, 0xd9, 0x0e, 0x11, - 0x84, 0x51, 0xc0, 0xf3, 0xfb, 0x47, 0x00, 0x01, - 0x05, 0xd1, 0x50, 0x58, 0x00, 0x00, 0x00, 0x10, - 0x04, 0x02, 0x00, 0x00, 0x0a, 0x00, 0x17, 0xd2, - 0xf9, 0xfd, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, - // Entry 400 - 43F - 0xd7, 0x6f, 0xff, 0xff, 0xdf, 0x7d, 0xbb, 0xff, - 0xff, 0xff, 0xf7, 0xf3, 0xef, 0xff, 0xff, 0xf7, - 0xff, 0xdf, 0xdb, 0x7f, 0xff, 0xff, 0x7f, 0xff, - 0xff, 0xff, 0xef, 0xff, 0xbc, 0xff, 0xff, 0xfb, - 0xff, 0xfb, 0xff, 0xde, 0x76, 0xbd, 0xff, 0xf7, - 0xff, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xf3, 0xfe, - 0xef, 0xff, 0xff, 0xff, 0xff, 0x7f, 0x7f, 0xde, - 0xf7, 0xbb, 0xef, 0xf7, 0xff, 0xfb, 0xbf, 0xdf, - // Entry 440 - 47F - 0xfd, 0xfe, 0xff, 0xff, 0xfe, 0xff, 0x5f, 0x7d, - 0x7f, 0xff, 0xff, 0xf7, 0xe5, 0xfc, 0xff, 0xfd, - 0x7f, 0x7f, 0xff, 0x9e, 0xae, 0xff, 0xee, 0xff, - 0x7f, 0xf7, 0x7b, 0x02, 0x82, 0x04, 0xff, 0xf7, - 0xff, 0xbf, 0xd7, 0xef, 0xfe, 0xdf, 0xf7, 0xfe, - 0xe2, 0x8e, 0xe7, 0xff, 0xf7, 0xff, 0x56, 0xbd, - 0xcd, 0xff, 0xfb, 0xff, 0xff, 0xdf, 0xef, 0xff, - 0xe5, 0xdf, 0x7d, 0x0f, 0xa7, 0x51, 0x04, 0x44, - // Entry 480 - 4BF - 0x13, 0xd0, 0x5d, 0xaf, 0xa6, 0xfd, 0xb9, 0xff, - 0x63, 0x5d, 0x5b, 0xff, 0xff, 0xbf, 0x3f, 0x20, - 0x14, 0x00, 0x57, 0x51, 0x82, 0x65, 0xf5, 0x49, - 0xe2, 0xff, 0xfc, 0xdf, 0x00, 0x05, 0xc5, 0x05, - 0x00, 0x22, 0x00, 0x74, 0x69, 0x10, 0x08, 0x04, - 0x41, 0x00, 0x01, 0x06, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x51, 0x60, 0x05, 0x04, 0x01, 0x00, 0x00, - 0x06, 0x01, 0x20, 0x00, 0x18, 0x01, 0x92, 0xb1, - // Entry 4C0 - 4FF - 0xfd, 0x67, 0x4b, 0x06, 0x95, 0x06, 0x57, 0xed, - 0xfb, 0x4c, 0x9d, 0x7b, 0x83, 0x04, 0x62, 0x40, - 0x00, 0x15, 0x42, 0x00, 0x00, 0x00, 0x54, 0x83, - 0xf9, 0x4f, 0x10, 0x8c, 0xc9, 0x46, 0xde, 0xf7, - 0x13, 0x31, 0x00, 0x20, 0x00, 0x00, 0x00, 0x90, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x0a, 0x10, 0x00, - 0x01, 0x40, 0x00, 0xf0, 0x5b, 0xf4, 0xbe, 0x7d, - 0xba, 0xcf, 0xf7, 0xaf, 0x42, 0x04, 0x84, 0x41, - // Entry 500 - 53F - 0xb0, 0xff, 0x79, 0x7a, 0x04, 0x00, 0x00, 0x49, - 0x2d, 0x14, 0x27, 0x77, 0xed, 0xf1, 0xbf, 0xef, - 0x3f, 0x00, 0x00, 0x02, 0xc6, 0xa0, 0x1e, 0xfc, - 0xbb, 0xff, 0xfd, 0xfb, 0xb7, 0xfd, 0xf5, 0xff, - 0xfd, 0xfc, 0xd5, 0xed, 0x47, 0xf4, 0x7f, 0x10, - 0x01, 0x01, 0x84, 0x6d, 0xff, 0xf7, 0xdd, 0xf9, - 0x5f, 0x05, 0x86, 0xef, 0xf5, 0x77, 0xbd, 0x3c, - 0x00, 0x00, 0x00, 0x43, 0x71, 0x42, 0x00, 0x40, - // Entry 540 - 57F - 0x00, 0x00, 0x01, 0x43, 0x19, 0x00, 0x08, 0x00, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - // Entry 580 - 5BF - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xab, 0xbd, 0xe7, 0x57, 0xee, 0x13, 0x5d, - 0x09, 0xc1, 0x40, 0x21, 0xfa, 0x17, 0x01, 0x80, - 0x00, 0x00, 0x00, 0x00, 0xf0, 0xde, 0xff, 0xbf, - 0x00, 0x23, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, - 0x00, 0x30, 0x95, 0xe3, 0x10, 0x00, 0x00, 0x00, - 0x11, 0x04, 0x16, 0x00, 0x01, 0x02, 0x00, 0x81, - 0xa3, 0x01, 0x50, 0x00, 0x00, 0x83, 0x11, 0x40, - // Entry 5C0 - 5FF - 0x00, 0x00, 0x00, 0xf0, 0xdd, 0x7b, 0x7e, 0x02, - 0xaa, 0x10, 0x5d, 0xd8, 0x52, 0x00, 0x80, 0x20, - 0x00, 0x00, 0x00, 0x00, 0x40, 0x10, 0x02, 0x02, - 0x19, 0x00, 0x10, 0x02, 0x10, 0x61, 0x5a, 0x9d, - 0x31, 0x00, 0x00, 0x00, 0x01, 0x50, 0x02, 0x20, - 0x00, 0x00, 0x01, 0x00, 0x42, 0x00, 0x20, 0x00, - 0x00, 0x1f, 0xdf, 0xf2, 0xfd, 0xff, 0xfd, 0x3f, - 0x9f, 0x18, 0xcf, 0x9c, 0xbf, 0xaf, 0x5f, 0xfe, - // Entry 600 - 63F - 0x7b, 0x4b, 0x40, 0x10, 0xe1, 0xfd, 0xaf, 0xfd, - 0xb7, 0xf7, 0xff, 0xf3, 0xdf, 0xff, 0x6f, 0xf1, - 0x7b, 0xf1, 0x7f, 0xdf, 0x7f, 0xbf, 0xfe, 0xb7, - 0xee, 0x1c, 0xfb, 0xdb, 0xef, 0xdf, 0xff, 0xfd, - 0x7e, 0xbe, 0x57, 0xff, 0x6f, 0x81, 0x76, 0x1f, - 0xd4, 0x77, 0xf5, 0xfd, 0xff, 0xff, 0xeb, 0xfe, - 0xbf, 0x5f, 0x57, 0x1b, 0xeb, 0x5f, 0x50, 0x18, - 0x02, 0xfa, 0xff, 0x9d, 0x15, 0x97, 0x15, 0x0f, - // Entry 640 - 67F - 0x75, 0xc4, 0x7d, 0x81, 0x82, 0xf1, 0xd7, 0x7e, - 0xff, 0xff, 0xff, 0xef, 0xff, 0xfd, 0xdd, 0xde, - 0xfc, 0xfd, 0xf6, 0x5f, 0x7a, 0x1f, 0x40, 0x98, - 0x02, 0xff, 0xe3, 0xff, 0xf3, 0xd6, 0xf2, 0xff, - 0xfb, 0xdf, 0x7d, 0x50, 0x1e, 0x15, 0x7b, 0xb4, - 0xf5, 0xbe, 0xff, 0xff, 0xf3, 0xf7, 0xff, 0xf7, - 0x7f, 0xff, 0xff, 0xbe, 0xdb, 0xf7, 0xd7, 0xf9, - 0xef, 0x2f, 0x80, 0xbf, 0xc5, 0xff, 0xff, 0xf3, - // Entry 680 - 6BF - 0x97, 0x9d, 0xff, 0xff, 0xf7, 0xcf, 0xfd, 0xbf, - 0xde, 0x7f, 0x06, 0x1d, 0x57, 0xff, 0xf8, 0xda, - 0x5d, 0xce, 0x7d, 0x16, 0xb9, 0xea, 0x69, 0xa0, - 0x1a, 0x20, 0x00, 0x30, 0x02, 0x04, 0x24, 0x48, - 0x04, 0x00, 0x00, 0x40, 0xd4, 0x02, 0x04, 0x00, - 0x00, 0x04, 0x00, 0x04, 0x00, 0x20, 0x01, 0x06, - 0x50, 0x00, 0x08, 0x00, 0x00, 0x00, 0x24, 0x00, - 0x04, 0x00, 0x10, 0x8c, 0x58, 0xd5, 0x0d, 0x0f, - // Entry 6C0 - 6FF - 0x14, 0x4d, 0xf1, 0x16, 0x44, 0xd1, 0x42, 0x08, - 0x40, 0x00, 0x00, 0x40, 0x00, 0x08, 0x00, 0x00, - 0x00, 0xdc, 0xff, 0xeb, 0x1f, 0x58, 0x08, 0x41, - 0x04, 0xa0, 0x04, 0x00, 0x30, 0x12, 0x40, 0x22, - 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x01, 0x00, 0x00, 0x00, 0x80, 0x10, 0x10, 0xaf, - 0x6f, 0x93, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x80, 0x80, 0x25, 0x00, 0x00, - // Entry 700 - 73F - 0x00, 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, - 0x80, 0x86, 0xc2, 0x02, 0x00, 0x00, 0x00, 0x01, - 0xdf, 0x18, 0x00, 0x00, 0x02, 0xf0, 0xfd, 0x79, - 0x3b, 0x00, 0x25, 0x00, 0x00, 0x00, 0x02, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, - 0x03, 0x00, 0x09, 0x20, 0x00, 0x00, 0x01, 0x00, - 0x00, 0x81, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 740 - 77F - 0x00, 0x00, 0x00, 0xef, 0xf7, 0xfd, 0xcf, 0x7e, - 0xa0, 0x11, 0x10, 0x00, 0x00, 0x92, 0x01, 0x44, - 0xcd, 0xf9, 0x5e, 0x00, 0x01, 0x00, 0x30, 0x14, - 0x04, 0x55, 0x10, 0x01, 0x04, 0xf6, 0x3f, 0x7a, - 0x05, 0x04, 0x00, 0xb0, 0x80, 0x00, 0x55, 0x55, - 0x97, 0x7c, 0x9f, 0x71, 0xcc, 0x78, 0xd1, 0x43, - 0xf5, 0x57, 0x67, 0x14, 0x01, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x2c, 0xf7, 0xdb, 0x1f, 0x54, 0x60, - // Entry 780 - 7BF - 0x03, 0x68, 0x01, 0x10, 0x8b, 0x38, 0xaa, 0x01, - 0x00, 0x00, 0x30, 0x00, 0x24, 0x44, 0x00, 0x00, - 0x10, 0x03, 0x11, 0x02, 0x01, 0x00, 0x00, 0xf0, - 0xf5, 0xff, 0xd5, 0xd7, 0xbc, 0x70, 0xd6, 0x78, - 0x78, 0x15, 0x50, 0x00, 0xa4, 0x84, 0xe9, 0x41, - 0x00, 0x00, 0x00, 0x6b, 0x39, 0x52, 0x74, 0x00, - 0xe8, 0x30, 0x90, 0x6a, 0x92, 0x00, 0x00, 0x02, - 0xff, 0xef, 0xff, 0x4f, 0x85, 0x53, 0xf4, 0xed, - // Entry 7C0 - 7FF - 0xdd, 0xbf, 0x72, 0x19, 0xc7, 0x0c, 0xf5, 0x42, - 0x54, 0xdd, 0x77, 0x14, 0x00, 0x80, 0xc0, 0x56, - 0xcc, 0x16, 0x9e, 0xfb, 0x35, 0x7d, 0xef, 0xff, - 0xbd, 0xa4, 0xaf, 0x01, 0x44, 0x18, 0x01, 0x5d, - 0x4e, 0x4a, 0x08, 0x50, 0x28, 0x30, 0xe0, 0x80, - 0x10, 0x20, 0x24, 0x00, 0xff, 0x3f, 0xdf, 0x67, - 0xfe, 0x01, 0x06, 0x88, 0x0a, 0x40, 0x16, 0x01, - 0x01, 0x15, 0x2b, 0x3e, 0x01, 0x00, 0x00, 0x10, - // Entry 800 - 83F - 0x90, 0x69, 0x45, 0x02, 0x02, 0x01, 0xe1, 0xbf, - 0xbf, 0x03, 0x00, 0x00, 0x10, 0xd4, 0xa7, 0xd1, - 0x54, 0x9e, 0x44, 0xdf, 0xfd, 0x8f, 0x66, 0xb3, - 0x55, 0x20, 0xd4, 0xc3, 0xd8, 0x30, 0x3d, 0x80, - 0x00, 0x00, 0x00, 0x4c, 0xd4, 0x11, 0xc5, 0x84, - 0x6e, 0x50, 0x00, 0x22, 0x50, 0x6e, 0xbf, 0xdb, - 0x07, 0x00, 0x20, 0x10, 0x84, 0xb2, 0x45, 0x10, - 0x06, 0x44, 0x00, 0x00, 0x12, 0x02, 0x11, 0x00, - // Entry 840 - 87F - 0xf0, 0xfb, 0xfd, 0x3f, 0x05, 0x00, 0x12, 0x81, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x02, - 0x00, 0x00, 0x00, 0x00, 0x03, 0x30, 0x02, 0x28, - 0x84, 0x00, 0x33, 0xc0, 0x23, 0x24, 0x00, 0x00, - 0x00, 0xcb, 0xe4, 0x3a, 0x42, 0xc8, 0x14, 0xf1, - 0xef, 0xff, 0x7f, 0x16, 0x01, 0x01, 0x84, 0x50, - 0x07, 0xfc, 0xff, 0xff, 0x0f, 0x01, 0x00, 0x40, - 0x10, 0x38, 0x01, 0x01, 0x1c, 0x12, 0x40, 0xe1, - // Entry 880 - 8BF - 0x76, 0x16, 0x08, 0x03, 0x10, 0x00, 0x00, 0x00, - 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x24, - 0x0a, 0x00, 0x80, 0x00, 0x00, -} - -// altLangISO3 holds an alphabetically sorted list of 3-letter language code alternatives -// to 2-letter language codes that cannot be derived using the method described above. -// Each 3-letter code is followed by its 1-byte langID. -var altLangISO3 tag.Index = "---\x00cor\x00hbs\x01heb\x02kin\x03spa\x04yid\x05\xff\xff\xff\xff" - -// altLangIndex is used to convert indexes in altLangISO3 to langIDs. -// Size: 12 bytes, 6 elements -var altLangIndex = [6]uint16{ - 0x014a, 0x0225, 0x0105, 0x020a, 0x009d, 0x010b, -} - -// langAliasMap maps langIDs to their suggested replacements. -// Size: 640 bytes, 160 elements -var langAliasMap = [160]fromTo{ - 0: {from: 0xc4, to: 0xda}, - 1: {from: 0xff, to: 0xf8}, - 2: {from: 0x105, to: 0xe0}, - 3: {from: 0x10b, to: 0x2b9}, - 4: {from: 0x110, to: 0x10f}, - 5: {from: 0x192, to: 0x203}, - 6: {from: 0x1af, to: 0x1c1}, - 7: {from: 0x225, to: 0x23b}, - 8: {from: 0x268, to: 0xaa}, - 9: {from: 0x274, to: 0x252}, - 10: {from: 0x27d, to: 0xd}, - 11: {from: 0x2d5, to: 0x2db}, - 12: {from: 0x326, to: 0x93}, - 13: {from: 0x3c7, to: 0x1c48}, - 14: {from: 0x3e8, to: 0x23a}, - 15: {from: 0x3f9, to: 0x23a}, - 16: {from: 0x484, to: 0x15}, - 17: {from: 0x48f, to: 0xf3}, - 18: {from: 0x4d5, to: 0x1f38}, - 19: {from: 0x54a, to: 0x23}, - 20: {from: 0x550, to: 0x2732}, - 21: {from: 0x55c, to: 0x24}, - 22: {from: 0x57d, to: 0xa1}, - 23: {from: 0x5a3, to: 0x26}, - 24: {from: 0x5ac, to: 0x42}, - 25: {from: 0x615, to: 0x5a7}, - 26: {from: 0x65a, to: 0xc7a}, - 27: {from: 0x786, to: 0x1a5}, - 28: {from: 0x7cd, to: 0x16e}, - 29: {from: 0x7d4, to: 0x59}, - 30: {from: 0x855, to: 0x30b9}, - 31: {from: 0x8cf, to: 0x2c4}, - 32: {from: 0x90c, to: 0x23f1}, - 33: {from: 0x915, to: 0x95a}, - 34: {from: 0x932, to: 0x24f}, - 35: {from: 0x953, to: 0x3fc0}, - 36: {from: 0x956, to: 0x2c4}, - 37: {from: 0x995, to: 0x2b3e}, - 38: {from: 0x9c5, to: 0x2f18}, - 39: {from: 0xa50, to: 0x73}, - 40: {from: 0xa9f, to: 0x79}, - 41: {from: 0xb5f, to: 0x8a}, - 42: {from: 0xb6e, to: 0x1a2}, - 43: {from: 0xb8f, to: 0xb92}, - 44: {from: 0xb95, to: 0x2c8}, - 45: {from: 0xc76, to: 0x1df1}, - 46: {from: 0xc85, to: 0x2c31}, - 47: {from: 0xcd0, to: 0x1bd}, - 48: {from: 0xe67, to: 0x9f}, - 49: {from: 0xe9b, to: 0x179}, - 50: {from: 0xf37, to: 0xfc}, - 51: {from: 0x1010, to: 0xd}, - 52: {from: 0x11bb, to: 0xaf}, - 53: {from: 0x1207, to: 0xa6}, - 54: {from: 0x12b6, to: 0xb32}, - 55: {from: 0x12ba, to: 0x1d2}, - 56: {from: 0x12c9, to: 0x145c}, - 57: {from: 0x1317, to: 0x111}, - 58: {from: 0x131a, to: 0x85}, - 59: {from: 0x133a, to: 0x3a46}, - 60: {from: 0x1401, to: 0xcc}, - 61: {from: 0x145f, to: 0x9a}, - 62: {from: 0x1497, to: 0x278f}, - 63: {from: 0x14af, to: 0xca}, - 64: {from: 0x14be, to: 0xcd6}, - 65: {from: 0x1511, to: 0x12bb}, - 66: {from: 0x15a0, to: 0x154d}, - 67: {from: 0x15ad, to: 0x168a}, - 68: {from: 0x1621, to: 0x23f}, - 69: {from: 0x1710, to: 0x1a98}, - 70: {from: 0x180b, to: 0x2947}, - 71: {from: 0x1821, to: 0x102}, - 72: {from: 0x18f1, to: 0x104}, - 73: {from: 0x191d, to: 0x12ac}, - 74: {from: 0x1dcf, to: 0x3548}, - 75: {from: 0x1dd4, to: 0x1e74}, - 76: {from: 0x1df1, to: 0x18f}, - 77: {from: 0x1e7a, to: 0x145}, - 78: {from: 0x1e85, to: 0x13b}, - 79: {from: 0x1e89, to: 0x122}, - 80: {from: 0x1e90, to: 0x138}, - 81: {from: 0x1ea6, to: 0x1f82}, - 82: {from: 0x1ecc, to: 0x147}, - 83: {from: 0x1f30, to: 0x8d}, - 84: {from: 0x1f65, to: 0x12f8}, - 85: {from: 0x1f7d, to: 0x4235}, - 86: {from: 0x1f8b, to: 0x371a}, - 87: {from: 0x1fc4, to: 0x8d}, - 88: {from: 0x1fce, to: 0x8d}, - 89: {from: 0x1ff9, to: 0x6c1}, - 90: {from: 0x20ad, to: 0x2fbd}, - 91: {from: 0x2119, to: 0x30fc}, - 92: {from: 0x2209, to: 0x170}, - 93: {from: 0x227b, to: 0x18c}, - 94: {from: 0x2287, to: 0x189}, - 95: {from: 0x2291, to: 0x19a}, - 96: {from: 0x22e7, to: 0x8f2}, - 97: {from: 0x2340, to: 0x69}, - 98: {from: 0x23d5, to: 0x179}, - 99: {from: 0x2460, to: 0x244b}, - 100: {from: 0x2490, to: 0x1f4}, - 101: {from: 0x24be, to: 0x3a46}, - 102: {from: 0x24fc, to: 0x244b}, - 103: {from: 0x2520, to: 0x40ef}, - 104: {from: 0x2686, to: 0x25ce}, - 105: {from: 0x26ab, to: 0x1b4}, - 106: {from: 0x271d, to: 0x2b3e}, - 107: {from: 0x28b1, to: 0x1d1}, - 108: {from: 0x2993, to: 0x1d3}, - 109: {from: 0x29d6, to: 0x3a46}, - 110: {from: 0x2a93, to: 0x1ee}, - 111: {from: 0x2aaa, to: 0x32e}, - 112: {from: 0x2ade, to: 0xa4}, - 113: {from: 0x2adf, to: 0xa4}, - 114: {from: 0x2b96, to: 0x183}, - 115: {from: 0x2b9f, to: 0x1763}, - 116: {from: 0x2bb1, to: 0x2b2c}, - 117: {from: 0x2bb8, to: 0x152}, - 118: {from: 0x2beb, to: 0x37}, - 119: {from: 0x2bfc, to: 0x2019}, - 120: {from: 0x2c37, to: 0x2c32}, - 121: {from: 0x2c86, to: 0x2c6e}, - 122: {from: 0x2f2a, to: 0x1f1}, - 123: {from: 0x30fd, to: 0x3125}, - 124: {from: 0x31c1, to: 0x203}, - 125: {from: 0x3285, to: 0x1667}, - 126: {from: 0x337d, to: 0x22a}, - 127: {from: 0x33ef, to: 0x132}, - 128: {from: 0x340d, to: 0x215}, - 129: {from: 0x3494, to: 0x248}, - 130: {from: 0x3557, to: 0x8d}, - 131: {from: 0x35ad, to: 0x3689}, - 132: {from: 0x35c2, to: 0x2a32}, - 133: {from: 0x35c6, to: 0x4c}, - 134: {from: 0x35c9, to: 0x2fbf}, - 135: {from: 0x3603, to: 0x373d}, - 136: {from: 0x3629, to: 0x3d57}, - 137: {from: 0x363c, to: 0x376e}, - 138: {from: 0x364b, to: 0x1d3b}, - 139: {from: 0x364c, to: 0x2c31}, - 140: {from: 0x36f3, to: 0x26a}, - 141: {from: 0x38e5, to: 0xb28}, - 142: {from: 0x390f, to: 0xe91}, - 143: {from: 0x3a30, to: 0x28d}, - 144: {from: 0x3d54, to: 0x7f}, - 145: {from: 0x3f9f, to: 0x828}, - 146: {from: 0x4055, to: 0x30a}, - 147: {from: 0x4090, to: 0x3cf7}, - 148: {from: 0x410f, to: 0x13a}, - 149: {from: 0x4162, to: 0x3462}, - 150: {from: 0x4164, to: 0x86}, - 151: {from: 0x4246, to: 0x30b9}, - 152: {from: 0x427a, to: 0x2b9}, - 153: {from: 0x4361, to: 0x21a0}, - 154: {from: 0x4374, to: 0x2473}, - 155: {from: 0x43a7, to: 0x4645}, - 156: {from: 0x4445, to: 0x4437}, - 157: {from: 0x44d5, to: 0x44dc}, - 158: {from: 0x46ad, to: 0x19a}, - 159: {from: 0x473e, to: 0x2be}, -} - -// Size: 160 bytes, 160 elements -var langAliasTypes = [160]langAliasType{ - // Entry 0 - 3F - 0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 1, 0, 0, 1, 2, 1, - 1, 2, 0, 1, 0, 1, 2, 1, 1, 0, 0, 2, 1, 1, 0, 2, - 0, 0, 1, 0, 1, 0, 0, 1, 2, 1, 1, 1, 1, 0, 0, 2, - 1, 1, 1, 1, 2, 1, 0, 1, 1, 2, 2, 0, 1, 2, 0, 1, - // Entry 40 - 7F - 0, 1, 1, 1, 1, 0, 0, 2, 1, 0, 0, 0, 1, 1, 1, 1, - 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 2, 2, - 0, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, - 2, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 1, 2, 0, 2, 1, - // Entry 80 - BF - 1, 1, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, - 2, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, -} - -const ( - _Latn = 82 - _Hani = 50 - _Hans = 52 - _Hant = 53 - _Qaaa = 131 - _Qaai = 139 - _Qabx = 180 - _Zinh = 224 - _Zyyy = 229 - _Zzzz = 230 -) - -// script is an alphabetically sorted list of ISO 15924 codes. The index -// of the script in the string, divided by 4, is the internal scriptID. -var script tag.Index = "" + // Size: 928 bytes - "----AdlmAfakAghbAhomArabAranArmiArmnAvstBaliBamuBassBatkBengBhksBlisBopo" + - "BrahBraiBugiBuhdCakmCansCariChamCherCirtCoptCprtCyrlCyrsDevaDsrtDuplEgyd" + - "EgyhEgypElbaEthiGeokGeorGlagGothGranGrekGujrGuruHanbHangHaniHanoHansHant" + - "HatrHebrHiraHluwHmngHrktHungIndsItalJamoJavaJpanJurcKaliKanaKharKhmrKhoj" + - "KitlKitsKndaKoreKpelKthiLanaLaooLatfLatgLatnLekeLepcLimbLinaLinbLisuLoma" + - "LyciLydiMahjMandManiMarcMayaMendMercMeroMlymModiMongMoonMrooMteiMultMymr" + - "NarbNbatNewaNkgbNkooNshuOgamOlckOrkhOryaOsgeOsmaPalmPaucPermPhagPhliPhlp" + - "PhlvPhnxPiqdPlrdPrtiQaaaQaabQaacQaadQaaeQaafQaagQaahQaaiQaajQaakQaalQaam" + - "QaanQaaoQaapQaaqQaarQaasQaatQaauQaavQaawQaaxQaayQaazQabaQabbQabcQabdQabe" + - "QabfQabgQabhQabiQabjQabkQablQabmQabnQaboQabpQabqQabrQabsQabtQabuQabvQabw" + - "QabxRjngRoroRunrSamrSaraSarbSaurSgnwShawShrdSiddSindSinhSoraSundSyloSyrc" + - "SyreSyrjSyrnTagbTakrTaleTaluTamlTangTavtTeluTengTfngTglgThaaThaiTibtTirh" + - "UgarVaiiVispWaraWoleXpeoXsuxYiiiZinhZmthZsyeZsymZxxxZyyyZzzz\xff\xff\xff" + - "\xff" - -// suppressScript is an index from langID to the dominant script for that language, -// if it exists. If a script is given, it should be suppressed from the language tag. -// Size: 713 bytes, 713 elements -var suppressScript = [713]uint8{ - // Entry 0 - 3F - 0x00, 0x00, 0x1e, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x27, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x1e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 40 - 7F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - // Entry 80 - BF - 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0xd4, 0x00, 0x00, 0xd6, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x2d, 0x52, 0x52, 0x52, 0x00, 0x52, - 0x00, 0x52, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x52, 0x52, 0x00, 0x52, - 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry C0 - FF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x2e, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x37, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x52, - 0x00, 0x52, 0x52, 0x08, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - // Entry 100 - 13F - 0x00, 0x00, 0x52, 0x52, 0x00, 0x37, 0x00, 0x41, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x29, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, - 0x00, 0x52, 0x00, 0x46, 0x00, 0x4a, 0x4b, 0x00, - 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 140 - 17F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x4f, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - // Entry 180 - 1BF - 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x1e, 0x64, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x20, 0x00, - 0x00, 0x00, 0x52, 0x52, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x6b, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x52, 0x00, 0x52, 0x20, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x52, 0x00, 0x52, 0x00, 0x52, - // Entry 1C0 - 1FF - 0x00, 0x52, 0x00, 0x00, 0x00, 0x70, 0x52, 0x00, - 0x52, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x75, 0x00, 0x00, 0x00, 0x2f, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x52, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - // Entry 200 - 23F - 0x00, 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x1e, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0xc1, 0x00, 0x52, 0x00, 0x52, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 240 - 27F - 0x52, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x52, - 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0xcd, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0xd0, 0x52, 0x00, 0x00, 0x00, 0xd5, 0x00, 0x00, - 0x00, 0x27, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, - 0x52, 0x00, 0x52, 0x52, 0x52, 0x00, 0x52, 0x52, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, - // Entry 280 - 2BF - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x52, - 0x00, 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x52, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x37, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - // Entry 2C0 - 2FF - 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x52, 0x00, - 0x00, -} - -const ( - _001 = 1 - _419 = 30 - _BR = 64 - _CA = 72 - _ES = 109 - _GB = 121 - _MD = 186 - _PT = 236 - _UK = 304 - _US = 306 - _ZZ = 354 - _XA = 320 - _XC = 322 - _XK = 330 -) - -// isoRegionOffset needs to be added to the index of regionISO to obtain the regionID -// for 2-letter ISO codes. (The first isoRegionOffset regionIDs are reserved for -// the UN.M49 codes used for groups.) -const isoRegionOffset = 31 - -// regionTypes defines the status of a region for various standards. -// Size: 355 bytes, 355 elements -var regionTypes = [355]uint8{ - // Entry 0 - 3F - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - // Entry 40 - 7F - 0x06, 0x06, 0x06, 0x04, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, 0x04, 0x00, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, - 0x04, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x04, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x04, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - // Entry 80 - BF - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x00, 0x04, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, - // Entry C0 - FF - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x06, - 0x06, 0x06, 0x00, 0x06, 0x04, 0x06, 0x06, 0x06, - 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, 0x06, - 0x00, 0x06, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - // Entry 100 - 13F - 0x06, 0x00, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x04, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, - 0x02, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, - 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x00, 0x06, - // Entry 140 - 17F - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, - 0x05, 0x05, 0x04, 0x06, 0x06, 0x04, 0x06, 0x06, - 0x04, 0x06, 0x05, -} - -// regionISO holds a list of alphabetically sorted 2-letter ISO region codes. -// Each 2-letter codes is followed by two bytes with the following meaning: -// - [A-Z}{2}: the first letter of the 2-letter code plus these two -// letters form the 3-letter ISO code. -// - 0, n: index into altRegionISO3. -var regionISO tag.Index = "" + // Size: 1300 bytes - "AAAAACSCADNDAEREAFFGAGTGAIIAALLBAMRMANNTAOGOAQTAARRGASSMATUTAUUSAWBWAXLA" + - "AZZEBAIHBBRBBDGDBEELBFFABGGRBHHRBIDIBJENBLLMBMMUBNRNBOOLBQESBRRABSHSBTTN" + - "BUURBVVTBWWABYLRBZLZCAANCCCKCDODCFAFCGOGCHHECIIVCKOKCLHLCMMRCNHNCOOLCPPT" + - "CRRICS\x00\x00CTTECUUBCVPVCWUWCXXRCYYPCZZEDDDRDEEUDGGADJJIDKNKDMMADOOMDY" + - "HYDZZAEA ECCUEESTEGGYEHSHERRIESSPETTHEU\x00\x03FIINFJJIFKLKFMSMFOROFQ" + - "\x00\x18FRRAFXXXGAABGBBRGDRDGEEOGFUFGGGYGHHAGIIBGLRLGMMBGNINGPLPGQNQGRRC" + - "GS\x00\x06GTTMGUUMGWNBGYUYHKKGHMMDHNNDHRRVHTTIHUUNHVVOIC IDDNIERLILSRIM" + - "MNINNDIOOTIQRQIRRNISSLITTAJEEYJMAMJOORJPPNJTTNKEENKGGZKHHMKIIRKM\x00\x09" + - "KNNAKP\x00\x0cKRORKWWTKY\x00\x0fKZAZLAAOLBBNLCCALIIELKKALRBRLSSOLTTULUUX" + - "LVVALYBYMAARMCCOMDDAMENEMFAFMGDGMHHLMIIDMKKDMLLIMMMRMNNGMOACMPNPMQTQMRRT" + - "MSSRMTLTMUUSMVDVMWWIMXEXMYYSMZOZNAAMNCCLNEERNFFKNGGANHHBNIICNLLDNOORNPPL" + - "NQ\x00\x1eNRRUNTTZNUIUNZZLOMMNPAANPCCIPEERPFYFPGNGPHHLPKAKPLOLPM\x00\x12" + - "PNCNPRRIPSSEPTRTPUUSPWLWPYRYPZCZQAATQMMMQNNNQOOOQPPPQQQQQRRRQSSSQTTTQU" + - "\x00\x03QVVVQWWWQXXXQYYYQZZZREEURHHOROOURS\x00\x15RUUSRWWASAAUSBLBSCYCSD" + - "DNSEWESGGPSHHNSIVNSJJMSKVKSLLESMMRSNENSOOMSRURSSSDSTTPSUUNSVLVSXXMSYYRSZ" + - "WZTAAATCCATDCDTF\x00\x18TGGOTHHATJJKTKKLTLLSTMKMTNUNTOONTPMPTRURTTTOTVUV" + - "TWWNTZZAUAKRUGGAUK UMMIUSSAUYRYUZZBVAATVCCTVDDRVEENVGGBVIIRVNNMVUUTWFLF" + - "WKAKWSSMXAAAXBBBXCCCXDDDXEEEXFFFXGGGXHHHXIIIXJJJXKKKXLLLXMMMXNNNXOOOXPPP" + - "XQQQXRRRXSSSXTTTXUUUXVVVXWWWXXXXXYYYXZZZYDMDYEEMYT\x00\x1bYUUGZAAFZMMBZR" + - "ARZWWEZZZZ\xff\xff\xff\xff" - -// altRegionISO3 holds a list of 3-letter region codes that cannot be -// mapped to 2-letter codes using the default algorithm. This is a short list. -var altRegionISO3 string = "SCGQUUSGSCOMPRKCYMSPMSRBATFMYTATN" - -// altRegionIDs holds a list of regionIDs the positions of which match those -// of the 3-letter ISO codes in altRegionISO3. -// Size: 22 bytes, 11 elements -var altRegionIDs = [11]uint16{ - 0x0056, 0x006f, 0x0086, 0x00a6, 0x00a8, 0x00ab, 0x00e8, 0x0103, - 0x011f, 0x015c, 0x00da, -} - -// Size: 80 bytes, 20 elements -var regionOldMap = [20]fromTo{ - 0: {from: 0x43, to: 0xc2}, - 1: {from: 0x57, to: 0xa5}, - 2: {from: 0x5e, to: 0x5f}, - 3: {from: 0x65, to: 0x3a}, - 4: {from: 0x77, to: 0x76}, - 5: {from: 0x91, to: 0x36}, - 6: {from: 0xa1, to: 0x131}, - 7: {from: 0xbf, to: 0x131}, - 8: {from: 0xd5, to: 0x13c}, - 9: {from: 0xda, to: 0x2a}, - 10: {from: 0xed, to: 0x131}, - 11: {from: 0xf0, to: 0xe0}, - 12: {from: 0xfa, to: 0x6f}, - 13: {from: 0x101, to: 0x161}, - 14: {from: 0x128, to: 0x124}, - 15: {from: 0x130, to: 0x79}, - 16: {from: 0x137, to: 0x13b}, - 17: {from: 0x13e, to: 0x131}, - 18: {from: 0x15a, to: 0x15b}, - 19: {from: 0x160, to: 0x4a}, -} - -// m49 maps regionIDs to UN.M49 codes. The first isoRegionOffset entries are -// codes indicating collections of regions. -// Size: 710 bytes, 355 elements -var m49 = [355]int16{ - // Entry 0 - 3F - 0, 1, 2, 3, 5, 9, 11, 13, - 14, 15, 17, 18, 19, 21, 29, 30, - 34, 35, 39, 53, 54, 57, 61, 142, - 143, 145, 150, 151, 154, 155, 419, 958, - 0, 20, 784, 4, 28, 660, 8, 51, - 530, 24, 10, 32, 16, 40, 36, 533, - 248, 31, 70, 52, 50, 56, 854, 100, - 48, 108, 204, 652, 60, 96, 68, 535, - // Entry 40 - 7F - 76, 44, 64, 104, 74, 72, 112, 84, - 124, 166, 180, 140, 178, 756, 384, 184, - 152, 120, 156, 170, 0, 188, 891, 296, - 192, 132, 531, 162, 196, 203, 278, 276, - 0, 262, 208, 212, 214, 204, 12, 0, - 218, 233, 818, 732, 232, 724, 231, 967, - 246, 242, 238, 583, 234, 0, 250, 249, - 266, 826, 308, 268, 254, 831, 288, 292, - // Entry 80 - BF - 304, 270, 324, 312, 226, 300, 239, 320, - 316, 624, 328, 344, 334, 340, 191, 332, - 348, 854, 0, 360, 372, 376, 833, 356, - 86, 368, 364, 352, 380, 832, 388, 400, - 392, 581, 404, 417, 116, 296, 174, 659, - 408, 410, 414, 136, 398, 418, 422, 662, - 438, 144, 430, 426, 440, 442, 428, 434, - 504, 492, 498, 499, 663, 450, 584, 581, - // Entry C0 - FF - 807, 466, 104, 496, 446, 580, 474, 478, - 500, 470, 480, 462, 454, 484, 458, 508, - 516, 540, 562, 574, 566, 548, 558, 528, - 578, 524, 10, 520, 536, 570, 554, 512, - 591, 0, 604, 258, 598, 608, 586, 616, - 666, 612, 630, 275, 620, 581, 585, 600, - 591, 634, 959, 960, 961, 962, 963, 964, - 965, 966, 967, 968, 969, 970, 971, 972, - // Entry 100 - 13F - 638, 716, 642, 688, 643, 646, 682, 90, - 690, 729, 752, 702, 654, 705, 744, 703, - 694, 674, 686, 706, 740, 728, 678, 810, - 222, 534, 760, 748, 0, 796, 148, 260, - 768, 764, 762, 772, 626, 795, 788, 776, - 626, 792, 780, 798, 158, 834, 804, 800, - 826, 581, 840, 858, 860, 336, 670, 704, - 862, 92, 850, 704, 548, 876, 581, 882, - // Entry 140 - 17F - 973, 974, 975, 976, 977, 978, 979, 980, - 981, 982, 983, 984, 985, 986, 987, 988, - 989, 990, 991, 992, 993, 994, 995, 996, - 997, 998, 720, 887, 175, 891, 710, 894, - 180, 716, 999, -} - -// m49Index gives indexes into fromM49 based on the three most significant bits -// of a 10-bit UN.M49 code. To search an UN.M49 code in fromM49, search in -// fromM49[m49Index[msb39(code)]:m49Index[msb3(code)+1]] -// for an entry where the first 7 bits match the 7 lsb of the UN.M49 code. -// The region code is stored in the 9 lsb of the indexed value. -// Size: 18 bytes, 9 elements -var m49Index = [9]int16{ - 0, 59, 107, 142, 180, 219, 258, 290, - 332, -} - -// fromM49 contains entries to map UN.M49 codes to regions. See m49Index for details. -// Size: 664 bytes, 332 elements -var fromM49 = [332]uint16{ - // Entry 0 - 3F - 0x0201, 0x0402, 0x0603, 0x0823, 0x0a04, 0x1026, 0x1205, 0x142a, - 0x1606, 0x1866, 0x1a07, 0x1c08, 0x1e09, 0x202c, 0x220a, 0x240b, - 0x260c, 0x2821, 0x2a0d, 0x3029, 0x3824, 0x3a0e, 0x3c0f, 0x3e31, - 0x402b, 0x4410, 0x4611, 0x482e, 0x4e12, 0x502d, 0x5841, 0x6038, - 0x6434, 0x6627, 0x6833, 0x6a13, 0x6c14, 0x7035, 0x7215, 0x783c, - 0x7a16, 0x8042, 0x883e, 0x8c32, 0x9045, 0x9444, 0x9840, 0xa847, - 0xac98, 0xb507, 0xb939, 0xc03d, 0xc837, 0xd0c2, 0xd839, 0xe046, - 0xe8a4, 0xf051, 0xf848, 0x0859, 0x10ab, 0x184b, 0x1c17, 0x1e18, - // Entry 40 - 7F - 0x20b1, 0x2219, 0x291e, 0x2c1a, 0x2e1b, 0x3050, 0x341c, 0x361d, - 0x3852, 0x3d2c, 0x445b, 0x4c49, 0x5453, 0x5ca6, 0x5f5c, 0x644c, - 0x684a, 0x704f, 0x7855, 0x7e8e, 0x8058, 0x885c, 0x965d, 0x983a, - 0xa062, 0xa863, 0xac64, 0xb468, 0xbd18, 0xc484, 0xcc6e, 0xce6e, - 0xd06c, 0xd269, 0xd474, 0xdc72, 0xde86, 0xe471, 0xec70, 0xf030, - 0xf277, 0xf476, 0xfc7c, 0x04e3, 0x091f, 0x0c61, 0x1478, 0x187b, - 0x1c81, 0x26eb, 0x285f, 0x2c5e, 0x305f, 0x407e, 0x487f, 0x50a5, - 0x5885, 0x6080, 0x687a, 0x7083, 0x7888, 0x8087, 0x8882, 0x908a, - // Entry 80 - BF - 0x988f, 0x9c8c, 0xa135, 0xa88d, 0xb08b, 0xb890, 0xc09b, 0xc897, - 0xd093, 0xd89a, 0xe099, 0xe894, 0xf095, 0xf89c, 0x004e, 0x089e, - 0x10a0, 0x1cac, 0x209f, 0x28a2, 0x30a8, 0x34a9, 0x3caa, 0x42a3, - 0x44ad, 0x461e, 0x4cae, 0x54b3, 0x58b6, 0x5cb2, 0x64b7, 0x6cb0, - 0x70b4, 0x74b5, 0x7cc4, 0x84bd, 0x8ccc, 0x94ce, 0x9ccb, 0xa4c1, - 0xacc9, 0xb4c6, 0xbcc7, 0xc0ca, 0xc8cd, 0xd8b9, 0xe0c3, 0xe4ba, - 0xe6bb, 0xe8c8, 0xf0b8, 0xf8cf, 0x00df, 0x08d0, 0x10db, 0x18d9, - 0x20d7, 0x2428, 0x265a, 0x2a2f, 0x2d19, 0x2e3f, 0x30dc, 0x38d1, - // Entry C0 - FF - 0x493c, 0x54de, 0x5cd6, 0x64d2, 0x6cd4, 0x74dd, 0x7cd3, 0x84d8, - 0x88c5, 0x8b31, 0x8e73, 0x90be, 0x92ee, 0x94e6, 0x9ee0, 0xace4, - 0xb0ef, 0xb8e2, 0xc0e5, 0xc8e9, 0xd0e7, 0xd8ec, 0xe089, 0xe524, - 0xecea, 0xf4f1, 0xfd00, 0x0502, 0x0704, 0x0d05, 0x183b, 0x1d0c, - 0x26a7, 0x2825, 0x2caf, 0x2ebc, 0x34e8, 0x3d36, 0x4511, 0x4d16, - 0x5506, 0x5d12, 0x6103, 0x6508, 0x6d10, 0x7d0b, 0x7f0f, 0x813b, - 0x830d, 0x8513, 0x8d5e, 0x9961, 0xa15a, 0xa86d, 0xb115, 0xb309, - 0xb86b, 0xc109, 0xc914, 0xd10e, 0xd91b, 0xe10a, 0xe84d, 0xf11a, - // Entry 100 - 13F - 0xf522, 0xf921, 0x0120, 0x0923, 0x1127, 0x192a, 0x2022, 0x2926, - 0x3129, 0x3725, 0x391d, 0x3d2b, 0x412f, 0x492e, 0x4ec0, 0x5517, - 0x646a, 0x7479, 0x7e7d, 0x809d, 0x8296, 0x852d, 0x9132, 0xa53a, - 0xac36, 0xb533, 0xb934, 0xbd38, 0xd93d, 0xe53f, 0xed5b, 0xef5b, - 0xf656, 0xfd5f, 0x7c1f, 0x7ef2, 0x80f3, 0x82f4, 0x84f5, 0x86f6, - 0x88f7, 0x8af8, 0x8cf9, 0x8e6f, 0x90fb, 0x92fc, 0x94fd, 0x96fe, - 0x98ff, 0x9b40, 0x9d41, 0x9f42, 0xa143, 0xa344, 0xa545, 0xa746, - 0xa947, 0xab48, 0xad49, 0xaf4a, 0xb14b, 0xb34c, 0xb54d, 0xb74e, - // Entry 140 - 17F - 0xb94f, 0xbb50, 0xbd51, 0xbf52, 0xc153, 0xc354, 0xc555, 0xc756, - 0xc957, 0xcb58, 0xcd59, 0xcf62, -} - -// Size: 1444 bytes -var variantIndex = map[string]uint8{ - "1606nict": 0x0, - "1694acad": 0x1, - "1901": 0x2, - "1959acad": 0x3, - "1994": 0x45, - "1996": 0x4, - "abl1943": 0x5, - "alalc97": 0x47, - "aluku": 0x6, - "ao1990": 0x7, - "arevela": 0x8, - "arevmda": 0x9, - "baku1926": 0xa, - "balanka": 0xb, - "barla": 0xc, - "basiceng": 0xd, - "bauddha": 0xe, - "biscayan": 0xf, - "biske": 0x40, - "bohoric": 0x10, - "boont": 0x11, - "colb1945": 0x12, - "cornu": 0x13, - "dajnko": 0x14, - "ekavsk": 0x15, - "emodeng": 0x16, - "fonipa": 0x48, - "fonupa": 0x49, - "fonxsamp": 0x4a, - "hepburn": 0x17, - "heploc": 0x46, - "hognorsk": 0x18, - "ijekavsk": 0x19, - "itihasa": 0x1a, - "jauer": 0x1b, - "jyutping": 0x1c, - "kkcor": 0x1d, - "kociewie": 0x1e, - "kscor": 0x1f, - "laukika": 0x20, - "lipaw": 0x41, - "luna1918": 0x21, - "metelko": 0x22, - "monoton": 0x23, - "ndyuka": 0x24, - "nedis": 0x25, - "newfound": 0x26, - "njiva": 0x42, - "nulik": 0x27, - "osojs": 0x43, - "oxendict": 0x28, - "pamaka": 0x29, - "petr1708": 0x2a, - "pinyin": 0x2b, - "polyton": 0x2c, - "puter": 0x2d, - "rigik": 0x2e, - "rozaj": 0x2f, - "rumgr": 0x30, - "scotland": 0x31, - "scouse": 0x32, - "simple": 0x4b, - "solba": 0x44, - "sotav": 0x33, - "surmiran": 0x34, - "sursilv": 0x35, - "sutsilv": 0x36, - "tarask": 0x37, - "uccor": 0x38, - "ucrcor": 0x39, - "ulster": 0x3a, - "unifon": 0x3b, - "vaidika": 0x3c, - "valencia": 0x3d, - "vallader": 0x3e, - "wadegile": 0x3f, -} - -// variantNumSpecialized is the number of specialized variants in variants. -const variantNumSpecialized = 71 - -// nRegionGroups is the number of region groups. -const nRegionGroups = 32 - -type likelyLangRegion struct { - lang uint16 - region uint16 -} - -// likelyScript is a lookup table, indexed by scriptID, for the most likely -// languages and regions given a script. -// Size: 928 bytes, 232 elements -var likelyScript = [232]likelyLangRegion{ - 1: {lang: 0xa6, region: 0x82}, - 3: {lang: 0x159, region: 0x104}, - 4: {lang: 0xc, region: 0x97}, - 5: {lang: 0x15, region: 0x6a}, - 7: {lang: 0x16, region: 0x9a}, - 8: {lang: 0xf3, region: 0x27}, - 9: {lang: 0x8, region: 0x9a}, - 10: {lang: 0x27, region: 0x93}, - 11: {lang: 0x2b, region: 0x51}, - 12: {lang: 0x55, region: 0xb2}, - 13: {lang: 0x2c, region: 0x93}, - 14: {lang: 0x4b, region: 0x34}, - 15: {lang: 0x20d, region: 0x97}, - 17: {lang: 0x2c4, region: 0x12c}, - 18: {lang: 0x1e5, region: 0x97}, - 19: {lang: 0xaf, region: 0x76}, - 20: {lang: 0x5b, region: 0x93}, - 21: {lang: 0x47, region: 0xe5}, - 22: {lang: 0x63, region: 0x34}, - 23: {lang: 0x73, region: 0x48}, - 24: {lang: 0x2a8, region: 0x129}, - 25: {lang: 0x6e, region: 0x13b}, - 26: {lang: 0x6c, region: 0x132}, - 28: {lang: 0x71, region: 0x6a}, - 29: {lang: 0xd0, region: 0x5c}, - 30: {lang: 0x207, region: 0x104}, - 32: {lang: 0xe1, region: 0x97}, - 34: {lang: 0xaf, region: 0x76}, - 37: {lang: 0x98, region: 0x6a}, - 38: {lang: 0x23a, region: 0x26}, - 39: {lang: 0x11, region: 0x6e}, - 41: {lang: 0x111, region: 0x7b}, - 42: {lang: 0x7d, region: 0x37}, - 43: {lang: 0xcf, region: 0x12e}, - 44: {lang: 0x20d, region: 0x97}, - 45: {lang: 0x9a, region: 0x85}, - 46: {lang: 0xd3, region: 0x97}, - 47: {lang: 0x1d7, region: 0x97}, - 48: {lang: 0x2c4, region: 0x12c}, - 49: {lang: 0x136, region: 0xa9}, - 50: {lang: 0x2c4, region: 0x52}, - 51: {lang: 0xe9, region: 0xe5}, - 52: {lang: 0x2c4, region: 0x52}, - 53: {lang: 0x2c4, region: 0x12c}, - 54: {lang: 0x18b, region: 0x99}, - 55: {lang: 0xe0, region: 0x95}, - 56: {lang: 0x107, region: 0xa0}, - 57: {lang: 0xe4, region: 0x129}, - 58: {lang: 0xe8, region: 0xad}, - 60: {lang: 0xf2, region: 0x90}, - 62: {lang: 0xa0, region: 0x9c}, - 63: {lang: 0x136, region: 0xa9}, - 64: {lang: 0x10f, region: 0x93}, - 65: {lang: 0x107, region: 0xa0}, - 67: {lang: 0x99, region: 0xc2}, - 68: {lang: 0x107, region: 0xa0}, - 69: {lang: 0x1eb, region: 0xe6}, - 70: {lang: 0x133, region: 0xa4}, - 71: {lang: 0x21a, region: 0x97}, - 74: {lang: 0x135, region: 0x97}, - 75: {lang: 0x136, region: 0xa9}, - 77: {lang: 0x40, region: 0x97}, - 78: {lang: 0x1c2, region: 0x121}, - 79: {lang: 0x165, region: 0xad}, - 84: {lang: 0x158, region: 0x97}, - 85: {lang: 0x15c, region: 0x97}, - 86: {lang: 0x14f, region: 0x85}, - 87: {lang: 0xd0, region: 0x85}, - 88: {lang: 0x15e, region: 0x52}, - 90: {lang: 0x2aa, region: 0x129}, - 91: {lang: 0x2ab, region: 0x129}, - 92: {lang: 0xe1, region: 0x97}, - 93: {lang: 0x1a8, region: 0x9a}, - 94: {lang: 0x2ad, region: 0x52}, - 95: {lang: 0x4c, region: 0x52}, - 97: {lang: 0x17f, region: 0x110}, - 98: {lang: 0x2ae, region: 0x109}, - 99: {lang: 0x2ae, region: 0x109}, - 100: {lang: 0x18d, region: 0x97}, - 101: {lang: 0x196, region: 0x97}, - 102: {lang: 0x18f, region: 0x52}, - 104: {lang: 0x199, region: 0x34}, - 105: {lang: 0x190, region: 0x97}, - 106: {lang: 0x22b, region: 0xe6}, - 107: {lang: 0x1a5, region: 0xc2}, - 108: {lang: 0x2af, region: 0x106}, - 109: {lang: 0x16, region: 0x9f}, - 110: {lang: 0x1b5, region: 0xd9}, - 112: {lang: 0x179, region: 0x82}, - 114: {lang: 0x223, region: 0x94}, - 115: {lang: 0x212, region: 0x97}, - 116: {lang: 0x1d6, region: 0xc3}, - 117: {lang: 0x1d3, region: 0x97}, - 118: {lang: 0x1d5, region: 0x132}, - 119: {lang: 0x238, region: 0x113}, - 120: {lang: 0x16, region: 0x11a}, - 121: {lang: 0x7c, region: 0xc2}, - 122: {lang: 0x147, region: 0x104}, - 123: {lang: 0x172, region: 0x52}, - 124: {lang: 0x1d9, region: 0x9a}, - 125: {lang: 0x1d9, region: 0x52}, - 127: {lang: 0x1e3, region: 0xae}, - 129: {lang: 0xe5, region: 0x52}, - 130: {lang: 0x2b2, region: 0x9a}, - 181: {lang: 0x1f6, region: 0x93}, - 183: {lang: 0x1c4, region: 0x10a}, - 184: {lang: 0x234, region: 0x95}, - 186: {lang: 0x2b3, region: 0x15b}, - 187: {lang: 0x213, region: 0x97}, - 188: {lang: 0x1e, region: 0x132}, - 189: {lang: 0x9b, region: 0x79}, - 190: {lang: 0x20d, region: 0x97}, - 191: {lang: 0x20d, region: 0x97}, - 192: {lang: 0x21a, region: 0x97}, - 193: {lang: 0x228, region: 0xb1}, - 194: {lang: 0x23c, region: 0x97}, - 195: {lang: 0x244, region: 0x93}, - 196: {lang: 0x24e, region: 0x34}, - 197: {lang: 0x24f, region: 0x99}, - 201: {lang: 0x253, region: 0xe5}, - 202: {lang: 0x8a, region: 0x97}, - 203: {lang: 0x255, region: 0x52}, - 204: {lang: 0x126, region: 0x52}, - 205: {lang: 0x251, region: 0x97}, - 206: {lang: 0x27f, region: 0x52}, - 207: {lang: 0x48, region: 0x13b}, - 208: {lang: 0x258, region: 0x97}, - 210: {lang: 0x2c3, region: 0xb8}, - 211: {lang: 0xaa, region: 0xe5}, - 212: {lang: 0x90, region: 0xcb}, - 213: {lang: 0x25d, region: 0x121}, - 214: {lang: 0x4c, region: 0x52}, - 215: {lang: 0x177, region: 0x97}, - 216: {lang: 0x285, region: 0x11a}, - 217: {lang: 0x28e, region: 0xb2}, - 219: {lang: 0xec, region: 0x97}, - 221: {lang: 0x1e1, region: 0x9a}, - 222: {lang: 0xe, region: 0x99}, - 223: {lang: 0xfb, region: 0x52}, -} - -type likelyScriptRegion struct { - region uint16 - script uint8 - flags uint8 -} - -// likelyLang is a lookup table, indexed by langID, for the most likely -// scripts and regions given incomplete information. If more entries exist for a -// given language, region and script are the index and size respectively -// of the list in likelyLangList. -// Size: 2852 bytes, 713 elements -var likelyLang = [713]likelyScriptRegion{ - 0: {region: 0x132, script: 0x52, flags: 0x0}, - 1: {region: 0x6e, script: 0x52, flags: 0x0}, - 2: {region: 0x7b, script: 0x1e, flags: 0x0}, - 3: {region: 0x7e, script: 0x52, flags: 0x0}, - 4: {region: 0x93, script: 0x52, flags: 0x0}, - 5: {region: 0x12f, script: 0x52, flags: 0x0}, - 6: {region: 0x7e, script: 0x52, flags: 0x0}, - 7: {region: 0x104, script: 0x1e, flags: 0x0}, - 8: {region: 0x9a, script: 0x9, flags: 0x0}, - 9: {region: 0x126, script: 0x5, flags: 0x0}, - 10: {region: 0x15e, script: 0x52, flags: 0x0}, - 11: {region: 0x51, script: 0x52, flags: 0x0}, - 12: {region: 0x97, script: 0x4, flags: 0x0}, - 13: {region: 0x7e, script: 0x52, flags: 0x0}, - 14: {region: 0x99, script: 0xde, flags: 0x0}, - 15: {region: 0x14a, script: 0x52, flags: 0x0}, - 16: {region: 0x104, script: 0x1e, flags: 0x0}, - 17: {region: 0x6e, script: 0x27, flags: 0x0}, - 18: {region: 0xd4, script: 0x52, flags: 0x0}, - 20: {region: 0x93, script: 0x52, flags: 0x0}, - 21: {region: 0x6a, script: 0x5, flags: 0x0}, - 22: {region: 0x0, script: 0x3, flags: 0x1}, - 23: {region: 0x50, script: 0x52, flags: 0x0}, - 24: {region: 0x3e, script: 0x52, flags: 0x0}, - 25: {region: 0x66, script: 0x5, flags: 0x0}, - 26: {region: 0xb8, script: 0x5, flags: 0x0}, - 27: {region: 0x6a, script: 0x5, flags: 0x0}, - 28: {region: 0x97, script: 0xe, flags: 0x0}, - 29: {region: 0x12d, script: 0x52, flags: 0x0}, - 30: {region: 0x132, script: 0xbc, flags: 0x0}, - 31: {region: 0x6d, script: 0x52, flags: 0x0}, - 32: {region: 0x48, script: 0x52, flags: 0x0}, - 33: {region: 0x104, script: 0x1e, flags: 0x0}, - 34: {region: 0x97, script: 0x20, flags: 0x0}, - 35: {region: 0x3e, script: 0x52, flags: 0x0}, - 36: {region: 0x3, script: 0x5, flags: 0x1}, - 37: {region: 0x104, script: 0x1e, flags: 0x0}, - 38: {region: 0xe6, script: 0x5, flags: 0x0}, - 39: {region: 0x93, script: 0x52, flags: 0x0}, - 40: {region: 0xd9, script: 0x20, flags: 0x0}, - 41: {region: 0x2d, script: 0x52, flags: 0x0}, - 42: {region: 0x51, script: 0x52, flags: 0x0}, - 43: {region: 0x51, script: 0xb, flags: 0x0}, - 44: {region: 0x93, script: 0x52, flags: 0x0}, - 45: {region: 0x51, script: 0x52, flags: 0x0}, - 46: {region: 0x4e, script: 0x52, flags: 0x0}, - 47: {region: 0x46, script: 0x1e, flags: 0x0}, - 48: {region: 0x109, script: 0x5, flags: 0x0}, - 49: {region: 0x15f, script: 0x52, flags: 0x0}, - 50: {region: 0x93, script: 0x52, flags: 0x0}, - 51: {region: 0x12d, script: 0x52, flags: 0x0}, - 52: {region: 0x51, script: 0x52, flags: 0x0}, - 53: {region: 0x97, script: 0xcd, flags: 0x0}, - 54: {region: 0xe6, script: 0x5, flags: 0x0}, - 55: {region: 0x97, script: 0x20, flags: 0x0}, - 56: {region: 0x37, script: 0x1e, flags: 0x0}, - 57: {region: 0x97, script: 0x20, flags: 0x0}, - 58: {region: 0xe6, script: 0x5, flags: 0x0}, - 59: {region: 0x129, script: 0x2d, flags: 0x0}, - 61: {region: 0x97, script: 0x20, flags: 0x0}, - 62: {region: 0x97, script: 0x20, flags: 0x0}, - 63: {region: 0xe5, script: 0x52, flags: 0x0}, - 64: {region: 0x97, script: 0x20, flags: 0x0}, - 65: {region: 0x13c, script: 0x52, flags: 0x0}, - 66: {region: 0xe5, script: 0x52, flags: 0x0}, - 67: {region: 0xd4, script: 0x52, flags: 0x0}, - 68: {region: 0x97, script: 0x20, flags: 0x0}, - 69: {region: 0x93, script: 0x52, flags: 0x0}, - 70: {region: 0x51, script: 0x52, flags: 0x0}, - 71: {region: 0xe5, script: 0x52, flags: 0x0}, - 72: {region: 0x13b, script: 0xcf, flags: 0x0}, - 73: {region: 0xc1, script: 0x52, flags: 0x0}, - 74: {region: 0xc1, script: 0x52, flags: 0x0}, - 75: {region: 0x34, script: 0xe, flags: 0x0}, - 76: {region: 0x52, script: 0xd6, flags: 0x0}, - 77: {region: 0x97, script: 0xe, flags: 0x0}, - 78: {region: 0x9a, script: 0x5, flags: 0x0}, - 79: {region: 0x4e, script: 0x52, flags: 0x0}, - 80: {region: 0x76, script: 0x52, flags: 0x0}, - 81: {region: 0x97, script: 0x20, flags: 0x0}, - 82: {region: 0xe6, script: 0x5, flags: 0x0}, - 83: {region: 0x97, script: 0x20, flags: 0x0}, - 84: {region: 0x32, script: 0x52, flags: 0x0}, - 85: {region: 0xb2, script: 0xc, flags: 0x0}, - 86: {region: 0x51, script: 0x52, flags: 0x0}, - 87: {region: 0xe5, script: 0x52, flags: 0x0}, - 88: {region: 0xe6, script: 0x20, flags: 0x0}, - 89: {region: 0x104, script: 0x1e, flags: 0x0}, - 90: {region: 0x15c, script: 0x52, flags: 0x0}, - 91: {region: 0x93, script: 0x52, flags: 0x0}, - 92: {region: 0x51, script: 0x52, flags: 0x0}, - 93: {region: 0x84, script: 0x52, flags: 0x0}, - 94: {region: 0x6c, script: 0x27, flags: 0x0}, - 95: {region: 0x51, script: 0x52, flags: 0x0}, - 96: {region: 0xc1, script: 0x52, flags: 0x0}, - 97: {region: 0x6d, script: 0x52, flags: 0x0}, - 98: {region: 0xd4, script: 0x52, flags: 0x0}, - 99: {region: 0x8, script: 0x2, flags: 0x1}, - 100: {region: 0x104, script: 0x1e, flags: 0x0}, - 101: {region: 0xe5, script: 0x52, flags: 0x0}, - 102: {region: 0x12f, script: 0x52, flags: 0x0}, - 103: {region: 0x88, script: 0x52, flags: 0x0}, - 104: {region: 0x73, script: 0x52, flags: 0x0}, - 105: {region: 0x104, script: 0x1e, flags: 0x0}, - 106: {region: 0x132, script: 0x52, flags: 0x0}, - 107: {region: 0x48, script: 0x52, flags: 0x0}, - 108: {region: 0x132, script: 0x1a, flags: 0x0}, - 109: {region: 0xa4, script: 0x5, flags: 0x0}, - 110: {region: 0x13b, script: 0x19, flags: 0x0}, - 111: {region: 0x99, script: 0x5, flags: 0x0}, - 112: {region: 0x76, script: 0x52, flags: 0x0}, - 113: {region: 0x6a, script: 0x1c, flags: 0x0}, - 114: {region: 0xe5, script: 0x52, flags: 0x0}, - 115: {region: 0x48, script: 0x17, flags: 0x0}, - 116: {region: 0x48, script: 0x17, flags: 0x0}, - 117: {region: 0x48, script: 0x17, flags: 0x0}, - 118: {region: 0x48, script: 0x17, flags: 0x0}, - 119: {region: 0x48, script: 0x17, flags: 0x0}, - 120: {region: 0x108, script: 0x52, flags: 0x0}, - 121: {region: 0x5d, script: 0x52, flags: 0x0}, - 122: {region: 0xe7, script: 0x52, flags: 0x0}, - 123: {region: 0x48, script: 0x17, flags: 0x0}, - 124: {region: 0xc2, script: 0x79, flags: 0x0}, - 125: {region: 0xa, script: 0x2, flags: 0x1}, - 126: {region: 0x104, script: 0x1e, flags: 0x0}, - 127: {region: 0x79, script: 0x52, flags: 0x0}, - 128: {region: 0x62, script: 0x52, flags: 0x0}, - 129: {region: 0x132, script: 0x52, flags: 0x0}, - 130: {region: 0x104, script: 0x1e, flags: 0x0}, - 131: {region: 0xa2, script: 0x52, flags: 0x0}, - 132: {region: 0x97, script: 0x5, flags: 0x0}, - 133: {region: 0x5f, script: 0x52, flags: 0x0}, - 134: {region: 0x48, script: 0x52, flags: 0x0}, - 135: {region: 0x48, script: 0x52, flags: 0x0}, - 136: {region: 0xd2, script: 0x52, flags: 0x0}, - 137: {region: 0x4e, script: 0x52, flags: 0x0}, - 138: {region: 0x97, script: 0x5, flags: 0x0}, - 139: {region: 0x5f, script: 0x52, flags: 0x0}, - 140: {region: 0xc1, script: 0x52, flags: 0x0}, - 141: {region: 0xce, script: 0x52, flags: 0x0}, - 142: {region: 0xd9, script: 0x20, flags: 0x0}, - 143: {region: 0x51, script: 0x52, flags: 0x0}, - 144: {region: 0xcb, script: 0xd4, flags: 0x0}, - 145: {region: 0x112, script: 0x52, flags: 0x0}, - 146: {region: 0x36, script: 0x52, flags: 0x0}, - 147: {region: 0x42, script: 0xd6, flags: 0x0}, - 148: {region: 0xa2, script: 0x52, flags: 0x0}, - 149: {region: 0x7e, script: 0x52, flags: 0x0}, - 150: {region: 0xd4, script: 0x52, flags: 0x0}, - 151: {region: 0x9c, script: 0x52, flags: 0x0}, - 152: {region: 0x6a, script: 0x25, flags: 0x0}, - 153: {region: 0xc2, script: 0x43, flags: 0x0}, - 154: {region: 0x85, script: 0x2d, flags: 0x0}, - 155: {region: 0xc, script: 0x2, flags: 0x1}, - 156: {region: 0x1, script: 0x52, flags: 0x0}, - 157: {region: 0x6d, script: 0x52, flags: 0x0}, - 158: {region: 0x132, script: 0x52, flags: 0x0}, - 159: {region: 0x69, script: 0x52, flags: 0x0}, - 160: {region: 0x9c, script: 0x3e, flags: 0x0}, - 161: {region: 0x6d, script: 0x52, flags: 0x0}, - 162: {region: 0x51, script: 0x52, flags: 0x0}, - 163: {region: 0x6d, script: 0x52, flags: 0x0}, - 164: {region: 0x9a, script: 0x5, flags: 0x0}, - 165: {region: 0x84, script: 0x52, flags: 0x0}, - 166: {region: 0xe, script: 0x2, flags: 0x1}, - 167: {region: 0xc1, script: 0x52, flags: 0x0}, - 168: {region: 0x70, script: 0x52, flags: 0x0}, - 169: {region: 0x109, script: 0x5, flags: 0x0}, - 170: {region: 0xe5, script: 0x52, flags: 0x0}, - 171: {region: 0x10a, script: 0x52, flags: 0x0}, - 172: {region: 0x71, script: 0x52, flags: 0x0}, - 173: {region: 0x74, script: 0x52, flags: 0x0}, - 174: {region: 0x3a, script: 0x52, flags: 0x0}, - 175: {region: 0x76, script: 0x52, flags: 0x0}, - 176: {region: 0x132, script: 0x52, flags: 0x0}, - 177: {region: 0x76, script: 0x52, flags: 0x0}, - 178: {region: 0x5f, script: 0x52, flags: 0x0}, - 179: {region: 0x5f, script: 0x52, flags: 0x0}, - 180: {region: 0x13d, script: 0x52, flags: 0x0}, - 181: {region: 0xd2, script: 0x52, flags: 0x0}, - 182: {region: 0x9c, script: 0x52, flags: 0x0}, - 183: {region: 0xd4, script: 0x52, flags: 0x0}, - 184: {region: 0x109, script: 0x52, flags: 0x0}, - 185: {region: 0xd7, script: 0x52, flags: 0x0}, - 186: {region: 0x94, script: 0x52, flags: 0x0}, - 187: {region: 0x7e, script: 0x52, flags: 0x0}, - 188: {region: 0xba, script: 0x52, flags: 0x0}, - 189: {region: 0x52, script: 0x34, flags: 0x0}, - 190: {region: 0x93, script: 0x52, flags: 0x0}, - 191: {region: 0x97, script: 0x20, flags: 0x0}, - 192: {region: 0x9a, script: 0x5, flags: 0x0}, - 193: {region: 0x7c, script: 0x52, flags: 0x0}, - 194: {region: 0x79, script: 0x52, flags: 0x0}, - 195: {region: 0x6e, script: 0x27, flags: 0x0}, - 196: {region: 0xd9, script: 0x20, flags: 0x0}, - 197: {region: 0xa5, script: 0x52, flags: 0x0}, - 198: {region: 0xe6, script: 0x5, flags: 0x0}, - 199: {region: 0xe6, script: 0x5, flags: 0x0}, - 200: {region: 0x6d, script: 0x52, flags: 0x0}, - 201: {region: 0x9a, script: 0x5, flags: 0x0}, - 202: {region: 0xef, script: 0x52, flags: 0x0}, - 203: {region: 0x97, script: 0x20, flags: 0x0}, - 204: {region: 0x97, script: 0xd0, flags: 0x0}, - 205: {region: 0x93, script: 0x52, flags: 0x0}, - 206: {region: 0xd7, script: 0x52, flags: 0x0}, - 207: {region: 0x12e, script: 0x2b, flags: 0x0}, - 208: {region: 0x10, script: 0x2, flags: 0x1}, - 209: {region: 0x97, script: 0xe, flags: 0x0}, - 210: {region: 0x4d, script: 0x52, flags: 0x0}, - 211: {region: 0x97, script: 0x2e, flags: 0x0}, - 212: {region: 0x40, script: 0x52, flags: 0x0}, - 213: {region: 0x53, script: 0x52, flags: 0x0}, - 214: {region: 0x7e, script: 0x52, flags: 0x0}, - 216: {region: 0xa2, script: 0x52, flags: 0x0}, - 217: {region: 0x96, script: 0x52, flags: 0x0}, - 218: {region: 0xd9, script: 0x20, flags: 0x0}, - 219: {region: 0x48, script: 0x52, flags: 0x0}, - 220: {region: 0x12, script: 0x3, flags: 0x1}, - 221: {region: 0x52, script: 0x34, flags: 0x0}, - 222: {region: 0x132, script: 0x52, flags: 0x0}, - 223: {region: 0x23, script: 0x5, flags: 0x0}, - 224: {region: 0x95, script: 0x37, flags: 0x0}, - 225: {region: 0x97, script: 0x20, flags: 0x0}, - 226: {region: 0x71, script: 0x52, flags: 0x0}, - 227: {region: 0xe5, script: 0x52, flags: 0x0}, - 228: {region: 0x129, script: 0x39, flags: 0x0}, - 229: {region: 0x52, script: 0x81, flags: 0x0}, - 230: {region: 0xe6, script: 0x5, flags: 0x0}, - 231: {region: 0x97, script: 0x20, flags: 0x0}, - 232: {region: 0xad, script: 0x3a, flags: 0x0}, - 233: {region: 0xe5, script: 0x52, flags: 0x0}, - 234: {region: 0xe6, script: 0x5, flags: 0x0}, - 235: {region: 0xe4, script: 0x52, flags: 0x0}, - 236: {region: 0x97, script: 0x20, flags: 0x0}, - 237: {region: 0x97, script: 0x20, flags: 0x0}, - 238: {region: 0x8e, script: 0x52, flags: 0x0}, - 239: {region: 0x5f, script: 0x52, flags: 0x0}, - 240: {region: 0x52, script: 0x34, flags: 0x0}, - 241: {region: 0x8f, script: 0x52, flags: 0x0}, - 242: {region: 0x90, script: 0x52, flags: 0x0}, - 243: {region: 0x27, script: 0x8, flags: 0x0}, - 244: {region: 0xd0, script: 0x52, flags: 0x0}, - 245: {region: 0x76, script: 0x52, flags: 0x0}, - 246: {region: 0xce, script: 0x52, flags: 0x0}, - 247: {region: 0xd4, script: 0x52, flags: 0x0}, - 248: {region: 0x93, script: 0x52, flags: 0x0}, - 250: {region: 0xd4, script: 0x52, flags: 0x0}, - 251: {region: 0x52, script: 0xdf, flags: 0x0}, - 252: {region: 0x132, script: 0x52, flags: 0x0}, - 253: {region: 0x48, script: 0x52, flags: 0x0}, - 254: {region: 0xe5, script: 0x52, flags: 0x0}, - 255: {region: 0x93, script: 0x52, flags: 0x0}, - 256: {region: 0x104, script: 0x1e, flags: 0x0}, - 258: {region: 0x9b, script: 0x52, flags: 0x0}, - 259: {region: 0x9c, script: 0x52, flags: 0x0}, - 260: {region: 0x48, script: 0x17, flags: 0x0}, - 261: {region: 0x95, script: 0x37, flags: 0x0}, - 262: {region: 0x104, script: 0x52, flags: 0x0}, - 263: {region: 0xa0, script: 0x41, flags: 0x0}, - 264: {region: 0x9e, script: 0x52, flags: 0x0}, - 266: {region: 0x51, script: 0x52, flags: 0x0}, - 267: {region: 0x12e, script: 0x37, flags: 0x0}, - 268: {region: 0x12d, script: 0x52, flags: 0x0}, - 269: {region: 0xd9, script: 0x20, flags: 0x0}, - 270: {region: 0x62, script: 0x52, flags: 0x0}, - 271: {region: 0x93, script: 0x52, flags: 0x0}, - 272: {region: 0x93, script: 0x52, flags: 0x0}, - 273: {region: 0x7b, script: 0x29, flags: 0x0}, - 274: {region: 0x134, script: 0x1e, flags: 0x0}, - 275: {region: 0x66, script: 0x52, flags: 0x0}, - 276: {region: 0xc2, script: 0x52, flags: 0x0}, - 277: {region: 0xd4, script: 0x52, flags: 0x0}, - 278: {region: 0xa2, script: 0x52, flags: 0x0}, - 279: {region: 0xc1, script: 0x52, flags: 0x0}, - 280: {region: 0x104, script: 0x1e, flags: 0x0}, - 281: {region: 0xd4, script: 0x52, flags: 0x0}, - 282: {region: 0x161, script: 0x52, flags: 0x0}, - 283: {region: 0x12d, script: 0x52, flags: 0x0}, - 284: {region: 0x121, script: 0xd5, flags: 0x0}, - 285: {region: 0x59, script: 0x52, flags: 0x0}, - 286: {region: 0x51, script: 0x52, flags: 0x0}, - 287: {region: 0x4e, script: 0x52, flags: 0x0}, - 288: {region: 0x97, script: 0x20, flags: 0x0}, - 289: {region: 0x97, script: 0x20, flags: 0x0}, - 290: {region: 0x4a, script: 0x52, flags: 0x0}, - 291: {region: 0x93, script: 0x52, flags: 0x0}, - 292: {region: 0x40, script: 0x52, flags: 0x0}, - 293: {region: 0x97, script: 0x52, flags: 0x0}, - 294: {region: 0x52, script: 0xcc, flags: 0x0}, - 295: {region: 0x97, script: 0x20, flags: 0x0}, - 296: {region: 0xc1, script: 0x52, flags: 0x0}, - 297: {region: 0x97, script: 0x6b, flags: 0x0}, - 298: {region: 0xe6, script: 0x5, flags: 0x0}, - 299: {region: 0xa2, script: 0x52, flags: 0x0}, - 300: {region: 0x129, script: 0x52, flags: 0x0}, - 301: {region: 0xd0, script: 0x52, flags: 0x0}, - 302: {region: 0xad, script: 0x4f, flags: 0x0}, - 303: {region: 0x15, script: 0x6, flags: 0x1}, - 304: {region: 0x51, script: 0x52, flags: 0x0}, - 305: {region: 0x80, script: 0x52, flags: 0x0}, - 306: {region: 0xa2, script: 0x52, flags: 0x0}, - 307: {region: 0xa4, script: 0x46, flags: 0x0}, - 308: {region: 0x29, script: 0x52, flags: 0x0}, - 309: {region: 0x97, script: 0x4a, flags: 0x0}, - 310: {region: 0xa9, script: 0x4b, flags: 0x0}, - 311: {region: 0x104, script: 0x1e, flags: 0x0}, - 312: {region: 0x97, script: 0x20, flags: 0x0}, - 313: {region: 0x73, script: 0x52, flags: 0x0}, - 314: {region: 0xb2, script: 0x52, flags: 0x0}, - 316: {region: 0x104, script: 0x1e, flags: 0x0}, - 317: {region: 0x110, script: 0x52, flags: 0x0}, - 318: {region: 0xe5, script: 0x52, flags: 0x0}, - 319: {region: 0x104, script: 0x52, flags: 0x0}, - 320: {region: 0x97, script: 0x20, flags: 0x0}, - 321: {region: 0x97, script: 0x5, flags: 0x0}, - 322: {region: 0x12d, script: 0x52, flags: 0x0}, - 323: {region: 0x51, script: 0x52, flags: 0x0}, - 324: {region: 0x5f, script: 0x52, flags: 0x0}, - 325: {region: 0x1b, script: 0x3, flags: 0x1}, - 326: {region: 0x104, script: 0x1e, flags: 0x0}, - 327: {region: 0x104, script: 0x1e, flags: 0x0}, - 328: {region: 0x93, script: 0x52, flags: 0x0}, - 329: {region: 0xe6, script: 0x5, flags: 0x0}, - 330: {region: 0x79, script: 0x52, flags: 0x0}, - 331: {region: 0x121, script: 0xd5, flags: 0x0}, - 332: {region: 0xe6, script: 0x5, flags: 0x0}, - 333: {region: 0x1e, script: 0x5, flags: 0x1}, - 334: {region: 0x135, script: 0x52, flags: 0x0}, - 335: {region: 0x85, script: 0x56, flags: 0x0}, - 336: {region: 0x95, script: 0x37, flags: 0x0}, - 337: {region: 0x12d, script: 0x52, flags: 0x0}, - 338: {region: 0xe6, script: 0x5, flags: 0x0}, - 339: {region: 0x12f, script: 0x52, flags: 0x0}, - 340: {region: 0xb5, script: 0x52, flags: 0x0}, - 341: {region: 0x104, script: 0x1e, flags: 0x0}, - 342: {region: 0x93, script: 0x52, flags: 0x0}, - 343: {region: 0x52, script: 0xd5, flags: 0x0}, - 344: {region: 0x97, script: 0x54, flags: 0x0}, - 345: {region: 0x104, script: 0x1e, flags: 0x0}, - 346: {region: 0x12f, script: 0x52, flags: 0x0}, - 347: {region: 0xd7, script: 0x52, flags: 0x0}, - 348: {region: 0x23, script: 0x2, flags: 0x1}, - 349: {region: 0x9c, script: 0x52, flags: 0x0}, - 350: {region: 0x52, script: 0x58, flags: 0x0}, - 351: {region: 0x93, script: 0x52, flags: 0x0}, - 352: {region: 0x9a, script: 0x5, flags: 0x0}, - 353: {region: 0x132, script: 0x52, flags: 0x0}, - 354: {region: 0x97, script: 0xd0, flags: 0x0}, - 355: {region: 0x9c, script: 0x52, flags: 0x0}, - 356: {region: 0x4a, script: 0x52, flags: 0x0}, - 357: {region: 0xad, script: 0x4f, flags: 0x0}, - 358: {region: 0x4a, script: 0x52, flags: 0x0}, - 359: {region: 0x15f, script: 0x52, flags: 0x0}, - 360: {region: 0x9a, script: 0x5, flags: 0x0}, - 361: {region: 0xb4, script: 0x52, flags: 0x0}, - 362: {region: 0xb6, script: 0x52, flags: 0x0}, - 363: {region: 0x4a, script: 0x52, flags: 0x0}, - 364: {region: 0x4a, script: 0x52, flags: 0x0}, - 365: {region: 0xa2, script: 0x52, flags: 0x0}, - 366: {region: 0xa2, script: 0x52, flags: 0x0}, - 367: {region: 0x9a, script: 0x5, flags: 0x0}, - 368: {region: 0xb6, script: 0x52, flags: 0x0}, - 369: {region: 0x121, script: 0xd5, flags: 0x0}, - 370: {region: 0x52, script: 0x34, flags: 0x0}, - 371: {region: 0x129, script: 0x52, flags: 0x0}, - 372: {region: 0x93, script: 0x52, flags: 0x0}, - 373: {region: 0x51, script: 0x52, flags: 0x0}, - 374: {region: 0x97, script: 0x20, flags: 0x0}, - 375: {region: 0x97, script: 0x20, flags: 0x0}, - 376: {region: 0x93, script: 0x52, flags: 0x0}, - 377: {region: 0x25, script: 0x3, flags: 0x1}, - 378: {region: 0xa2, script: 0x52, flags: 0x0}, - 379: {region: 0xcd, script: 0x52, flags: 0x0}, - 380: {region: 0x104, script: 0x1e, flags: 0x0}, - 381: {region: 0xe5, script: 0x52, flags: 0x0}, - 382: {region: 0x93, script: 0x52, flags: 0x0}, - 383: {region: 0x110, script: 0x52, flags: 0x0}, - 384: {region: 0xa2, script: 0x52, flags: 0x0}, - 385: {region: 0x121, script: 0x5, flags: 0x0}, - 386: {region: 0xca, script: 0x52, flags: 0x0}, - 387: {region: 0xbd, script: 0x52, flags: 0x0}, - 388: {region: 0xcf, script: 0x52, flags: 0x0}, - 389: {region: 0x51, script: 0x52, flags: 0x0}, - 390: {region: 0xd9, script: 0x20, flags: 0x0}, - 391: {region: 0x12d, script: 0x52, flags: 0x0}, - 392: {region: 0xbe, script: 0x52, flags: 0x0}, - 393: {region: 0xde, script: 0x52, flags: 0x0}, - 394: {region: 0x93, script: 0x52, flags: 0x0}, - 395: {region: 0x99, script: 0x36, flags: 0x0}, - 396: {region: 0xc0, script: 0x1e, flags: 0x0}, - 397: {region: 0x97, script: 0x64, flags: 0x0}, - 398: {region: 0x109, script: 0x52, flags: 0x0}, - 399: {region: 0x28, script: 0x3, flags: 0x1}, - 400: {region: 0x97, script: 0xe, flags: 0x0}, - 401: {region: 0xc2, script: 0x6b, flags: 0x0}, - 403: {region: 0x48, script: 0x52, flags: 0x0}, - 404: {region: 0x48, script: 0x52, flags: 0x0}, - 405: {region: 0x36, script: 0x52, flags: 0x0}, - 406: {region: 0x97, script: 0x20, flags: 0x0}, - 407: {region: 0xd9, script: 0x20, flags: 0x0}, - 408: {region: 0x104, script: 0x1e, flags: 0x0}, - 409: {region: 0x34, script: 0x68, flags: 0x0}, - 410: {region: 0x2b, script: 0x3, flags: 0x1}, - 411: {region: 0xc9, script: 0x52, flags: 0x0}, - 412: {region: 0x97, script: 0x20, flags: 0x0}, - 413: {region: 0x51, script: 0x52, flags: 0x0}, - 415: {region: 0x132, script: 0x52, flags: 0x0}, - 416: {region: 0xe6, script: 0x5, flags: 0x0}, - 417: {region: 0xc1, script: 0x52, flags: 0x0}, - 418: {region: 0x97, script: 0x20, flags: 0x0}, - 419: {region: 0x93, script: 0x52, flags: 0x0}, - 420: {region: 0x161, script: 0x52, flags: 0x0}, - 421: {region: 0xc2, script: 0x6b, flags: 0x0}, - 422: {region: 0x104, script: 0x1e, flags: 0x0}, - 423: {region: 0x12f, script: 0x52, flags: 0x0}, - 424: {region: 0x9a, script: 0x5d, flags: 0x0}, - 425: {region: 0x9a, script: 0x5, flags: 0x0}, - 426: {region: 0xdb, script: 0x52, flags: 0x0}, - 428: {region: 0x52, script: 0x34, flags: 0x0}, - 429: {region: 0x9c, script: 0x52, flags: 0x0}, - 430: {region: 0xd0, script: 0x52, flags: 0x0}, - 431: {region: 0xd8, script: 0x52, flags: 0x0}, - 432: {region: 0xcd, script: 0x52, flags: 0x0}, - 433: {region: 0x161, script: 0x52, flags: 0x0}, - 434: {region: 0xcf, script: 0x52, flags: 0x0}, - 435: {region: 0x5f, script: 0x52, flags: 0x0}, - 436: {region: 0xd9, script: 0x20, flags: 0x0}, - 437: {region: 0xd9, script: 0x20, flags: 0x0}, - 438: {region: 0xd0, script: 0x52, flags: 0x0}, - 439: {region: 0xcf, script: 0x52, flags: 0x0}, - 440: {region: 0xcd, script: 0x52, flags: 0x0}, - 441: {region: 0xcd, script: 0x52, flags: 0x0}, - 442: {region: 0x93, script: 0x52, flags: 0x0}, - 443: {region: 0xdd, script: 0x52, flags: 0x0}, - 444: {region: 0x97, script: 0x52, flags: 0x0}, - 445: {region: 0xd7, script: 0x52, flags: 0x0}, - 446: {region: 0x51, script: 0x52, flags: 0x0}, - 447: {region: 0xd8, script: 0x52, flags: 0x0}, - 448: {region: 0x51, script: 0x52, flags: 0x0}, - 449: {region: 0xd8, script: 0x52, flags: 0x0}, - 450: {region: 0x121, script: 0x4e, flags: 0x0}, - 451: {region: 0x97, script: 0x20, flags: 0x0}, - 452: {region: 0x10a, script: 0xb7, flags: 0x0}, - 453: {region: 0x82, script: 0x70, flags: 0x0}, - 454: {region: 0x15e, script: 0x52, flags: 0x0}, - 455: {region: 0x48, script: 0x17, flags: 0x0}, - 456: {region: 0x15e, script: 0x52, flags: 0x0}, - 457: {region: 0x115, script: 0x52, flags: 0x0}, - 458: {region: 0x132, script: 0x52, flags: 0x0}, - 459: {region: 0x52, script: 0x52, flags: 0x0}, - 460: {region: 0xcc, script: 0x52, flags: 0x0}, - 461: {region: 0x12d, script: 0x52, flags: 0x0}, - 462: {region: 0x12f, script: 0x52, flags: 0x0}, - 463: {region: 0x7e, script: 0x52, flags: 0x0}, - 464: {region: 0x76, script: 0x52, flags: 0x0}, - 466: {region: 0x6e, script: 0x52, flags: 0x0}, - 467: {region: 0x97, script: 0x75, flags: 0x0}, - 468: {region: 0x7b, script: 0x1e, flags: 0x0}, - 469: {region: 0x132, script: 0x76, flags: 0x0}, - 470: {region: 0xc3, script: 0x74, flags: 0x0}, - 471: {region: 0x2e, script: 0x3, flags: 0x1}, - 472: {region: 0xe5, script: 0x52, flags: 0x0}, - 473: {region: 0x31, script: 0x2, flags: 0x1}, - 474: {region: 0xe5, script: 0x52, flags: 0x0}, - 475: {region: 0x2f, script: 0x52, flags: 0x0}, - 476: {region: 0xee, script: 0x52, flags: 0x0}, - 477: {region: 0x76, script: 0x52, flags: 0x0}, - 478: {region: 0xd4, script: 0x52, flags: 0x0}, - 479: {region: 0x132, script: 0x52, flags: 0x0}, - 480: {region: 0x48, script: 0x52, flags: 0x0}, - 481: {region: 0x9a, script: 0xdd, flags: 0x0}, - 482: {region: 0x5f, script: 0x52, flags: 0x0}, - 483: {region: 0xae, script: 0x7f, flags: 0x0}, - 485: {region: 0x97, script: 0x12, flags: 0x0}, - 486: {region: 0xa2, script: 0x52, flags: 0x0}, - 487: {region: 0xe7, script: 0x52, flags: 0x0}, - 488: {region: 0x9c, script: 0x52, flags: 0x0}, - 489: {region: 0x85, script: 0x2d, flags: 0x0}, - 490: {region: 0x73, script: 0x52, flags: 0x0}, - 491: {region: 0xe6, script: 0x45, flags: 0x0}, - 492: {region: 0x9a, script: 0x5, flags: 0x0}, - 493: {region: 0x1, script: 0x52, flags: 0x0}, - 494: {region: 0x23, script: 0x5, flags: 0x0}, - 495: {region: 0x40, script: 0x52, flags: 0x0}, - 496: {region: 0x78, script: 0x52, flags: 0x0}, - 497: {region: 0xe2, script: 0x52, flags: 0x0}, - 498: {region: 0x87, script: 0x52, flags: 0x0}, - 499: {region: 0x68, script: 0x52, flags: 0x0}, - 500: {region: 0x97, script: 0x20, flags: 0x0}, - 501: {region: 0x100, script: 0x52, flags: 0x0}, - 502: {region: 0x93, script: 0x52, flags: 0x0}, - 503: {region: 0x9c, script: 0x52, flags: 0x0}, - 504: {region: 0x97, script: 0x52, flags: 0x0}, - 505: {region: 0x33, script: 0x2, flags: 0x1}, - 506: {region: 0xd9, script: 0x20, flags: 0x0}, - 507: {region: 0x34, script: 0xe, flags: 0x0}, - 508: {region: 0x4d, script: 0x52, flags: 0x0}, - 509: {region: 0x70, script: 0x52, flags: 0x0}, - 510: {region: 0x4d, script: 0x52, flags: 0x0}, - 511: {region: 0x9a, script: 0x5, flags: 0x0}, - 512: {region: 0x10a, script: 0x52, flags: 0x0}, - 513: {region: 0x39, script: 0x52, flags: 0x0}, - 514: {region: 0xcf, script: 0x52, flags: 0x0}, - 515: {region: 0x102, script: 0x52, flags: 0x0}, - 516: {region: 0x93, script: 0x52, flags: 0x0}, - 517: {region: 0x12d, script: 0x52, flags: 0x0}, - 518: {region: 0x71, script: 0x52, flags: 0x0}, - 519: {region: 0x104, script: 0x1e, flags: 0x0}, - 520: {region: 0x12e, script: 0x1e, flags: 0x0}, - 521: {region: 0x107, script: 0x52, flags: 0x0}, - 522: {region: 0x105, script: 0x52, flags: 0x0}, - 523: {region: 0x12d, script: 0x52, flags: 0x0}, - 524: {region: 0xa0, script: 0x44, flags: 0x0}, - 525: {region: 0x97, script: 0x20, flags: 0x0}, - 526: {region: 0x7e, script: 0x52, flags: 0x0}, - 527: {region: 0x104, script: 0x1e, flags: 0x0}, - 528: {region: 0xa2, script: 0x52, flags: 0x0}, - 529: {region: 0x93, script: 0x52, flags: 0x0}, - 530: {region: 0x97, script: 0x52, flags: 0x0}, - 531: {region: 0x97, script: 0xbb, flags: 0x0}, - 532: {region: 0x12d, script: 0x52, flags: 0x0}, - 533: {region: 0x9c, script: 0x52, flags: 0x0}, - 534: {region: 0x97, script: 0x20, flags: 0x0}, - 535: {region: 0x9c, script: 0x52, flags: 0x0}, - 536: {region: 0x79, script: 0x52, flags: 0x0}, - 537: {region: 0x48, script: 0x52, flags: 0x0}, - 538: {region: 0x35, script: 0x4, flags: 0x1}, - 539: {region: 0x9c, script: 0x52, flags: 0x0}, - 540: {region: 0x9a, script: 0x5, flags: 0x0}, - 541: {region: 0xd8, script: 0x52, flags: 0x0}, - 542: {region: 0x4e, script: 0x52, flags: 0x0}, - 543: {region: 0xcf, script: 0x52, flags: 0x0}, - 544: {region: 0xcd, script: 0x52, flags: 0x0}, - 545: {region: 0xc1, script: 0x52, flags: 0x0}, - 546: {region: 0x4b, script: 0x52, flags: 0x0}, - 547: {region: 0x94, script: 0x72, flags: 0x0}, - 548: {region: 0xb4, script: 0x52, flags: 0x0}, - 550: {region: 0xb8, script: 0xd2, flags: 0x0}, - 551: {region: 0xc2, script: 0x6b, flags: 0x0}, - 552: {region: 0xb1, script: 0xc1, flags: 0x0}, - 553: {region: 0x6e, script: 0x52, flags: 0x0}, - 554: {region: 0x10f, script: 0x52, flags: 0x0}, - 555: {region: 0xe6, script: 0x5, flags: 0x0}, - 556: {region: 0x10d, script: 0x52, flags: 0x0}, - 557: {region: 0xe7, script: 0x52, flags: 0x0}, - 558: {region: 0x93, script: 0x52, flags: 0x0}, - 559: {region: 0x13f, script: 0x52, flags: 0x0}, - 560: {region: 0x10a, script: 0x52, flags: 0x0}, - 562: {region: 0x10a, script: 0x52, flags: 0x0}, - 563: {region: 0x70, script: 0x52, flags: 0x0}, - 564: {region: 0x95, script: 0xb8, flags: 0x0}, - 565: {region: 0x70, script: 0x52, flags: 0x0}, - 566: {region: 0x161, script: 0x52, flags: 0x0}, - 567: {region: 0xc1, script: 0x52, flags: 0x0}, - 568: {region: 0x113, script: 0x52, flags: 0x0}, - 569: {region: 0x121, script: 0xd5, flags: 0x0}, - 570: {region: 0x26, script: 0x52, flags: 0x0}, - 571: {region: 0x39, script: 0x5, flags: 0x1}, - 572: {region: 0x97, script: 0xc2, flags: 0x0}, - 573: {region: 0x114, script: 0x52, flags: 0x0}, - 574: {region: 0x112, script: 0x52, flags: 0x0}, - 575: {region: 0x97, script: 0x20, flags: 0x0}, - 576: {region: 0x15e, script: 0x52, flags: 0x0}, - 577: {region: 0x6c, script: 0x52, flags: 0x0}, - 578: {region: 0x15e, script: 0x52, flags: 0x0}, - 579: {region: 0x5f, script: 0x52, flags: 0x0}, - 580: {region: 0x93, script: 0x52, flags: 0x0}, - 581: {region: 0x12d, script: 0x52, flags: 0x0}, - 582: {region: 0x82, script: 0x52, flags: 0x0}, - 583: {region: 0x10a, script: 0x52, flags: 0x0}, - 584: {region: 0x12d, script: 0x52, flags: 0x0}, - 585: {region: 0x15c, script: 0x5, flags: 0x0}, - 586: {region: 0x4a, script: 0x52, flags: 0x0}, - 587: {region: 0x5f, script: 0x52, flags: 0x0}, - 588: {region: 0x97, script: 0x20, flags: 0x0}, - 589: {region: 0x93, script: 0x52, flags: 0x0}, - 590: {region: 0x34, script: 0xe, flags: 0x0}, - 591: {region: 0x99, script: 0xc5, flags: 0x0}, - 592: {region: 0xe7, script: 0x52, flags: 0x0}, - 593: {region: 0x97, script: 0xcd, flags: 0x0}, - 594: {region: 0xd9, script: 0x20, flags: 0x0}, - 595: {region: 0xe5, script: 0x52, flags: 0x0}, - 596: {region: 0x97, script: 0x4a, flags: 0x0}, - 597: {region: 0x52, script: 0xcb, flags: 0x0}, - 598: {region: 0xd9, script: 0x20, flags: 0x0}, - 599: {region: 0xd9, script: 0x20, flags: 0x0}, - 600: {region: 0x97, script: 0xd0, flags: 0x0}, - 601: {region: 0x110, script: 0x52, flags: 0x0}, - 602: {region: 0x12f, script: 0x52, flags: 0x0}, - 603: {region: 0x124, script: 0x52, flags: 0x0}, - 604: {region: 0x3e, script: 0x3, flags: 0x1}, - 605: {region: 0x121, script: 0xd5, flags: 0x0}, - 606: {region: 0xd9, script: 0x20, flags: 0x0}, - 607: {region: 0xd9, script: 0x20, flags: 0x0}, - 608: {region: 0xd9, script: 0x20, flags: 0x0}, - 609: {region: 0x6e, script: 0x27, flags: 0x0}, - 610: {region: 0x6c, script: 0x27, flags: 0x0}, - 611: {region: 0xd4, script: 0x52, flags: 0x0}, - 612: {region: 0x125, script: 0x52, flags: 0x0}, - 613: {region: 0x123, script: 0x52, flags: 0x0}, - 614: {region: 0x31, script: 0x52, flags: 0x0}, - 615: {region: 0xd9, script: 0x20, flags: 0x0}, - 616: {region: 0xe5, script: 0x52, flags: 0x0}, - 617: {region: 0x31, script: 0x52, flags: 0x0}, - 618: {region: 0xd2, script: 0x52, flags: 0x0}, - 619: {region: 0x15e, script: 0x52, flags: 0x0}, - 620: {region: 0x127, script: 0x52, flags: 0x0}, - 621: {region: 0xcc, script: 0x52, flags: 0x0}, - 622: {region: 0xe4, script: 0x52, flags: 0x0}, - 623: {region: 0x129, script: 0x52, flags: 0x0}, - 624: {region: 0x129, script: 0x52, flags: 0x0}, - 625: {region: 0x12c, script: 0x52, flags: 0x0}, - 626: {region: 0x15e, script: 0x52, flags: 0x0}, - 627: {region: 0x85, script: 0x2d, flags: 0x0}, - 628: {region: 0xd9, script: 0x20, flags: 0x0}, - 629: {region: 0xe5, script: 0x52, flags: 0x0}, - 630: {region: 0x42, script: 0xd6, flags: 0x0}, - 631: {region: 0x104, script: 0x1e, flags: 0x0}, - 632: {region: 0x12f, script: 0x52, flags: 0x0}, - 633: {region: 0x121, script: 0xd5, flags: 0x0}, - 634: {region: 0x31, script: 0x52, flags: 0x0}, - 635: {region: 0xcc, script: 0x52, flags: 0x0}, - 636: {region: 0x12b, script: 0x52, flags: 0x0}, - 638: {region: 0xd2, script: 0x52, flags: 0x0}, - 639: {region: 0x52, script: 0xce, flags: 0x0}, - 640: {region: 0xe3, script: 0x52, flags: 0x0}, - 641: {region: 0x104, script: 0x1e, flags: 0x0}, - 642: {region: 0xb8, script: 0x52, flags: 0x0}, - 643: {region: 0x104, script: 0x1e, flags: 0x0}, - 644: {region: 0x41, script: 0x4, flags: 0x1}, - 645: {region: 0x11a, script: 0xd8, flags: 0x0}, - 646: {region: 0x12e, script: 0x1e, flags: 0x0}, - 647: {region: 0x73, script: 0x52, flags: 0x0}, - 648: {region: 0x29, script: 0x52, flags: 0x0}, - 650: {region: 0x45, script: 0x3, flags: 0x1}, - 651: {region: 0x97, script: 0xe, flags: 0x0}, - 652: {region: 0xe6, script: 0x5, flags: 0x0}, - 653: {region: 0x48, script: 0x4, flags: 0x1}, - 654: {region: 0xb2, script: 0xd9, flags: 0x0}, - 655: {region: 0x15e, script: 0x52, flags: 0x0}, - 656: {region: 0x9c, script: 0x52, flags: 0x0}, - 657: {region: 0x104, script: 0x52, flags: 0x0}, - 658: {region: 0x13b, script: 0x52, flags: 0x0}, - 659: {region: 0x119, script: 0x52, flags: 0x0}, - 660: {region: 0x35, script: 0x52, flags: 0x0}, - 661: {region: 0x5f, script: 0x52, flags: 0x0}, - 662: {region: 0xcf, script: 0x52, flags: 0x0}, - 663: {region: 0x1, script: 0x52, flags: 0x0}, - 664: {region: 0x104, script: 0x52, flags: 0x0}, - 665: {region: 0x69, script: 0x52, flags: 0x0}, - 666: {region: 0x12d, script: 0x52, flags: 0x0}, - 667: {region: 0x35, script: 0x52, flags: 0x0}, - 668: {region: 0x4d, script: 0x52, flags: 0x0}, - 669: {region: 0x6e, script: 0x27, flags: 0x0}, - 670: {region: 0xe5, script: 0x52, flags: 0x0}, - 671: {region: 0x2e, script: 0x52, flags: 0x0}, - 672: {region: 0x97, script: 0xd0, flags: 0x0}, - 673: {region: 0x97, script: 0x20, flags: 0x0}, - 674: {region: 0x13d, script: 0x52, flags: 0x0}, - 675: {region: 0xa6, script: 0x5, flags: 0x0}, - 676: {region: 0x112, script: 0x52, flags: 0x0}, - 677: {region: 0x97, script: 0x20, flags: 0x0}, - 678: {region: 0x52, script: 0x34, flags: 0x0}, - 679: {region: 0x40, script: 0x52, flags: 0x0}, - 680: {region: 0x129, script: 0x18, flags: 0x0}, - 681: {region: 0x15e, script: 0x52, flags: 0x0}, - 682: {region: 0x129, script: 0x5a, flags: 0x0}, - 683: {region: 0x129, script: 0x5b, flags: 0x0}, - 684: {region: 0x7b, script: 0x29, flags: 0x0}, - 685: {region: 0x52, script: 0x5e, flags: 0x0}, - 686: {region: 0x109, script: 0x62, flags: 0x0}, - 687: {region: 0x106, script: 0x6c, flags: 0x0}, - 688: {region: 0x97, script: 0x20, flags: 0x0}, - 689: {region: 0x12f, script: 0x52, flags: 0x0}, - 690: {region: 0x9a, script: 0x82, flags: 0x0}, - 691: {region: 0x15b, script: 0xba, flags: 0x0}, - 692: {region: 0xd9, script: 0x20, flags: 0x0}, - 693: {region: 0xcf, script: 0x52, flags: 0x0}, - 694: {region: 0x73, script: 0x52, flags: 0x0}, - 695: {region: 0x51, script: 0x52, flags: 0x0}, - 696: {region: 0x51, script: 0x52, flags: 0x0}, - 697: {region: 0x1, script: 0x37, flags: 0x0}, - 698: {region: 0xd4, script: 0x52, flags: 0x0}, - 699: {region: 0x40, script: 0x52, flags: 0x0}, - 700: {region: 0xcd, script: 0x52, flags: 0x0}, - 701: {region: 0x4c, script: 0x3, flags: 0x1}, - 702: {region: 0x52, script: 0x52, flags: 0x0}, - 703: {region: 0x109, script: 0x52, flags: 0x0}, - 705: {region: 0xa6, script: 0x5, flags: 0x0}, - 706: {region: 0xd7, script: 0x52, flags: 0x0}, - 707: {region: 0xb8, script: 0xd2, flags: 0x0}, - 708: {region: 0x4f, script: 0x14, flags: 0x1}, - 709: {region: 0xce, script: 0x52, flags: 0x0}, - 710: {region: 0x15e, script: 0x52, flags: 0x0}, - 712: {region: 0x129, script: 0x52, flags: 0x0}, -} - -// likelyLangList holds lists info associated with likelyLang. -// Size: 396 bytes, 99 elements -var likelyLangList = [99]likelyScriptRegion{ - 0: {region: 0x9a, script: 0x7, flags: 0x0}, - 1: {region: 0x9f, script: 0x6d, flags: 0x2}, - 2: {region: 0x11a, script: 0x78, flags: 0x2}, - 3: {region: 0x31, script: 0x52, flags: 0x0}, - 4: {region: 0x99, script: 0x5, flags: 0x4}, - 5: {region: 0x9a, script: 0x5, flags: 0x4}, - 6: {region: 0x104, script: 0x1e, flags: 0x4}, - 7: {region: 0x9a, script: 0x5, flags: 0x2}, - 8: {region: 0x97, script: 0xe, flags: 0x0}, - 9: {region: 0x34, script: 0x16, flags: 0x2}, - 10: {region: 0x104, script: 0x1e, flags: 0x0}, - 11: {region: 0x37, script: 0x2a, flags: 0x2}, - 12: {region: 0x132, script: 0x52, flags: 0x0}, - 13: {region: 0x79, script: 0xbd, flags: 0x2}, - 14: {region: 0x112, script: 0x52, flags: 0x0}, - 15: {region: 0x82, script: 0x1, flags: 0x2}, - 16: {region: 0x5c, script: 0x1d, flags: 0x0}, - 17: {region: 0x85, script: 0x57, flags: 0x2}, - 18: {region: 0xd4, script: 0x52, flags: 0x0}, - 19: {region: 0x51, script: 0x5, flags: 0x4}, - 20: {region: 0x109, script: 0x5, flags: 0x4}, - 21: {region: 0xac, script: 0x1e, flags: 0x0}, - 22: {region: 0x23, script: 0x5, flags: 0x4}, - 23: {region: 0x52, script: 0x5, flags: 0x4}, - 24: {region: 0x9a, script: 0x5, flags: 0x4}, - 25: {region: 0xc3, script: 0x5, flags: 0x4}, - 26: {region: 0x52, script: 0x5, flags: 0x2}, - 27: {region: 0x129, script: 0x52, flags: 0x0}, - 28: {region: 0xae, script: 0x5, flags: 0x4}, - 29: {region: 0x99, script: 0x5, flags: 0x2}, - 30: {region: 0xa3, script: 0x1e, flags: 0x0}, - 31: {region: 0x52, script: 0x5, flags: 0x4}, - 32: {region: 0x129, script: 0x52, flags: 0x4}, - 33: {region: 0x52, script: 0x5, flags: 0x2}, - 34: {region: 0x129, script: 0x52, flags: 0x2}, - 35: {region: 0xd9, script: 0x20, flags: 0x0}, - 36: {region: 0x97, script: 0x55, flags: 0x2}, - 37: {region: 0x81, script: 0x52, flags: 0x0}, - 38: {region: 0x82, script: 0x70, flags: 0x4}, - 39: {region: 0x82, script: 0x70, flags: 0x2}, - 40: {region: 0xc3, script: 0x1e, flags: 0x0}, - 41: {region: 0x52, script: 0x66, flags: 0x4}, - 42: {region: 0x52, script: 0x66, flags: 0x2}, - 43: {region: 0xce, script: 0x52, flags: 0x0}, - 44: {region: 0x49, script: 0x5, flags: 0x4}, - 45: {region: 0x93, script: 0x5, flags: 0x4}, - 46: {region: 0x97, script: 0x2f, flags: 0x0}, - 47: {region: 0xe6, script: 0x5, flags: 0x4}, - 48: {region: 0xe6, script: 0x5, flags: 0x2}, - 49: {region: 0x9a, script: 0x7c, flags: 0x0}, - 50: {region: 0x52, script: 0x7d, flags: 0x2}, - 51: {region: 0xb8, script: 0xd2, flags: 0x0}, - 52: {region: 0xd7, script: 0x52, flags: 0x4}, - 53: {region: 0xe6, script: 0x5, flags: 0x0}, - 54: {region: 0x97, script: 0x20, flags: 0x2}, - 55: {region: 0x97, script: 0x47, flags: 0x2}, - 56: {region: 0x97, script: 0xc0, flags: 0x2}, - 57: {region: 0x103, script: 0x1e, flags: 0x0}, - 58: {region: 0xbb, script: 0x52, flags: 0x4}, - 59: {region: 0x102, script: 0x52, flags: 0x4}, - 60: {region: 0x104, script: 0x52, flags: 0x4}, - 61: {region: 0x129, script: 0x52, flags: 0x4}, - 62: {region: 0x122, script: 0x1e, flags: 0x0}, - 63: {region: 0xe6, script: 0x5, flags: 0x4}, - 64: {region: 0xe6, script: 0x5, flags: 0x2}, - 65: {region: 0x52, script: 0x5, flags: 0x0}, - 66: {region: 0xac, script: 0x1e, flags: 0x4}, - 67: {region: 0xc3, script: 0x1e, flags: 0x4}, - 68: {region: 0xac, script: 0x1e, flags: 0x2}, - 69: {region: 0x97, script: 0xe, flags: 0x0}, - 70: {region: 0xd9, script: 0x20, flags: 0x4}, - 71: {region: 0xd9, script: 0x20, flags: 0x2}, - 72: {region: 0x134, script: 0x52, flags: 0x0}, - 73: {region: 0x23, script: 0x5, flags: 0x4}, - 74: {region: 0x52, script: 0x1e, flags: 0x4}, - 75: {region: 0x23, script: 0x5, flags: 0x2}, - 76: {region: 0x8b, script: 0x35, flags: 0x0}, - 77: {region: 0x52, script: 0x34, flags: 0x4}, - 78: {region: 0x52, script: 0x34, flags: 0x2}, - 79: {region: 0x52, script: 0x34, flags: 0x0}, - 80: {region: 0x2e, script: 0x35, flags: 0x4}, - 81: {region: 0x3d, script: 0x35, flags: 0x4}, - 82: {region: 0x79, script: 0x35, flags: 0x4}, - 83: {region: 0x7c, script: 0x35, flags: 0x4}, - 84: {region: 0x8b, script: 0x35, flags: 0x4}, - 85: {region: 0x93, script: 0x35, flags: 0x4}, - 86: {region: 0xc4, script: 0x35, flags: 0x4}, - 87: {region: 0xce, script: 0x35, flags: 0x4}, - 88: {region: 0xe0, script: 0x35, flags: 0x4}, - 89: {region: 0xe3, script: 0x35, flags: 0x4}, - 90: {region: 0xe5, script: 0x35, flags: 0x4}, - 91: {region: 0x114, script: 0x35, flags: 0x4}, - 92: {region: 0x121, script: 0x35, flags: 0x4}, - 93: {region: 0x12c, script: 0x35, flags: 0x4}, - 94: {region: 0x132, script: 0x35, flags: 0x4}, - 95: {region: 0x13b, script: 0x35, flags: 0x4}, - 96: {region: 0x12c, script: 0x11, flags: 0x2}, - 97: {region: 0x12c, script: 0x30, flags: 0x2}, - 98: {region: 0x12c, script: 0x35, flags: 0x2}, -} - -type likelyLangScript struct { - lang uint16 - script uint8 - flags uint8 -} - -// likelyRegion is a lookup table, indexed by regionID, for the most likely -// languages and scripts given incomplete information. If more entries exist -// for a given regionID, lang and script are the index and size respectively -// of the list in likelyRegionList. -// TODO: exclude containers and user-definable regions from the list. -// Size: 1420 bytes, 355 elements -var likelyRegion = [355]likelyLangScript{ - 33: {lang: 0x61, script: 0x52, flags: 0x0}, - 34: {lang: 0x15, script: 0x5, flags: 0x0}, - 35: {lang: 0x0, script: 0x2, flags: 0x1}, - 38: {lang: 0x2, script: 0x2, flags: 0x1}, - 39: {lang: 0x4, script: 0x2, flags: 0x1}, - 41: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 42: {lang: 0x0, script: 0x52, flags: 0x0}, - 43: {lang: 0x9d, script: 0x52, flags: 0x0}, - 44: {lang: 0x22f, script: 0x52, flags: 0x0}, - 45: {lang: 0x85, script: 0x52, flags: 0x0}, - 47: {lang: 0x1bd, script: 0x52, flags: 0x0}, - 48: {lang: 0x247, script: 0x52, flags: 0x0}, - 49: {lang: 0x24, script: 0x52, flags: 0x0}, - 50: {lang: 0x6, script: 0x2, flags: 0x1}, - 52: {lang: 0x4b, script: 0xe, flags: 0x0}, - 53: {lang: 0x1bd, script: 0x52, flags: 0x0}, - 54: {lang: 0xaf, script: 0x52, flags: 0x0}, - 55: {lang: 0x38, script: 0x1e, flags: 0x0}, - 56: {lang: 0x15, script: 0x5, flags: 0x0}, - 57: {lang: 0x201, script: 0x52, flags: 0x0}, - 58: {lang: 0xaf, script: 0x52, flags: 0x0}, - 59: {lang: 0xaf, script: 0x52, flags: 0x0}, - 61: {lang: 0x19a, script: 0x52, flags: 0x0}, - 62: {lang: 0x9d, script: 0x52, flags: 0x0}, - 63: {lang: 0x1db, script: 0x52, flags: 0x0}, - 64: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 66: {lang: 0x8, script: 0x2, flags: 0x1}, - 68: {lang: 0x0, script: 0x52, flags: 0x0}, - 70: {lang: 0x2f, script: 0x1e, flags: 0x0}, - 72: {lang: 0x2b9, script: 0x37, flags: 0x2}, - 73: {lang: 0x19a, script: 0x5, flags: 0x2}, - 74: {lang: 0x248, script: 0x52, flags: 0x0}, - 75: {lang: 0xaf, script: 0x52, flags: 0x0}, - 76: {lang: 0xaf, script: 0x52, flags: 0x0}, - 77: {lang: 0x85, script: 0x52, flags: 0x0}, - 78: {lang: 0xaf, script: 0x52, flags: 0x0}, - 80: {lang: 0x9d, script: 0x52, flags: 0x0}, - 81: {lang: 0xaf, script: 0x52, flags: 0x0}, - 82: {lang: 0xa, script: 0x5, flags: 0x1}, - 83: {lang: 0x9d, script: 0x52, flags: 0x0}, - 84: {lang: 0x0, script: 0x52, flags: 0x0}, - 85: {lang: 0x9d, script: 0x52, flags: 0x0}, - 88: {lang: 0x9d, script: 0x52, flags: 0x0}, - 89: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 90: {lang: 0x1db, script: 0x52, flags: 0x0}, - 92: {lang: 0xf, script: 0x2, flags: 0x1}, - 93: {lang: 0x79, script: 0x52, flags: 0x0}, - 95: {lang: 0x85, script: 0x52, flags: 0x0}, - 97: {lang: 0x1, script: 0x52, flags: 0x0}, - 98: {lang: 0x80, script: 0x52, flags: 0x0}, - 100: {lang: 0x9d, script: 0x52, flags: 0x0}, - 102: {lang: 0x11, script: 0x2, flags: 0x1}, - 103: {lang: 0x9d, script: 0x52, flags: 0x0}, - 104: {lang: 0x9d, script: 0x52, flags: 0x0}, - 105: {lang: 0x9f, script: 0x52, flags: 0x0}, - 106: {lang: 0x15, script: 0x5, flags: 0x0}, - 107: {lang: 0x15, script: 0x5, flags: 0x0}, - 108: {lang: 0x261, script: 0x27, flags: 0x0}, - 109: {lang: 0x9d, script: 0x52, flags: 0x0}, - 110: {lang: 0x13, script: 0x2, flags: 0x1}, - 112: {lang: 0xa8, script: 0x52, flags: 0x0}, - 113: {lang: 0xe2, script: 0x20, flags: 0x2}, - 116: {lang: 0xad, script: 0x52, flags: 0x0}, - 118: {lang: 0xaf, script: 0x52, flags: 0x0}, - 120: {lang: 0xaf, script: 0x52, flags: 0x0}, - 121: {lang: 0x15, script: 0x2, flags: 0x1}, - 123: {lang: 0x17, script: 0x3, flags: 0x1}, - 124: {lang: 0xaf, script: 0x52, flags: 0x0}, - 126: {lang: 0xd, script: 0x52, flags: 0x0}, - 128: {lang: 0x131, script: 0x52, flags: 0x0}, - 130: {lang: 0xaf, script: 0x52, flags: 0x0}, - 131: {lang: 0xaf, script: 0x52, flags: 0x0}, - 132: {lang: 0x9d, script: 0x52, flags: 0x0}, - 133: {lang: 0x1a, script: 0x2, flags: 0x1}, - 134: {lang: 0x0, script: 0x52, flags: 0x0}, - 135: {lang: 0x9d, script: 0x52, flags: 0x0}, - 137: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 139: {lang: 0x2c4, script: 0x35, flags: 0x0}, - 140: {lang: 0x0, script: 0x52, flags: 0x0}, - 141: {lang: 0x9d, script: 0x52, flags: 0x0}, - 142: {lang: 0xee, script: 0x52, flags: 0x0}, - 143: {lang: 0xf1, script: 0x52, flags: 0x0}, - 144: {lang: 0xf2, script: 0x52, flags: 0x0}, - 146: {lang: 0x9d, script: 0x52, flags: 0x0}, - 147: {lang: 0x1c, script: 0x2, flags: 0x1}, - 149: {lang: 0xe0, script: 0x37, flags: 0x0}, - 151: {lang: 0x1e, script: 0x3, flags: 0x1}, - 153: {lang: 0x15, script: 0x5, flags: 0x0}, - 154: {lang: 0x21, script: 0x2, flags: 0x1}, - 155: {lang: 0x102, script: 0x52, flags: 0x0}, - 156: {lang: 0x103, script: 0x52, flags: 0x0}, - 159: {lang: 0x15, script: 0x5, flags: 0x0}, - 160: {lang: 0x107, script: 0x41, flags: 0x0}, - 162: {lang: 0x248, script: 0x52, flags: 0x0}, - 163: {lang: 0x14d, script: 0x1e, flags: 0x0}, - 164: {lang: 0x23, script: 0x3, flags: 0x1}, - 166: {lang: 0x26, script: 0x2, flags: 0x1}, - 168: {lang: 0x136, script: 0x4b, flags: 0x0}, - 169: {lang: 0x136, script: 0x4b, flags: 0x0}, - 170: {lang: 0x15, script: 0x5, flags: 0x0}, - 172: {lang: 0x207, script: 0x1e, flags: 0x0}, - 173: {lang: 0x28, script: 0x2, flags: 0x1}, - 174: {lang: 0x15, script: 0x5, flags: 0x0}, - 176: {lang: 0x85, script: 0x52, flags: 0x0}, - 177: {lang: 0x228, script: 0xc1, flags: 0x0}, - 179: {lang: 0x242, script: 0x52, flags: 0x0}, - 180: {lang: 0x169, script: 0x52, flags: 0x0}, - 181: {lang: 0xaf, script: 0x52, flags: 0x0}, - 182: {lang: 0x170, script: 0x52, flags: 0x0}, - 183: {lang: 0x15, script: 0x5, flags: 0x0}, - 184: {lang: 0x2a, script: 0x2, flags: 0x1}, - 185: {lang: 0xaf, script: 0x52, flags: 0x0}, - 186: {lang: 0x2c, script: 0x2, flags: 0x1}, - 187: {lang: 0x23b, script: 0x52, flags: 0x0}, - 188: {lang: 0xaf, script: 0x52, flags: 0x0}, - 189: {lang: 0x183, script: 0x52, flags: 0x0}, - 192: {lang: 0x2e, script: 0x2, flags: 0x1}, - 193: {lang: 0x49, script: 0x52, flags: 0x0}, - 194: {lang: 0x30, script: 0x2, flags: 0x1}, - 195: {lang: 0x32, script: 0x2, flags: 0x1}, - 196: {lang: 0x34, script: 0x2, flags: 0x1}, - 198: {lang: 0xaf, script: 0x52, flags: 0x0}, - 199: {lang: 0x36, script: 0x2, flags: 0x1}, - 201: {lang: 0x19b, script: 0x52, flags: 0x0}, - 202: {lang: 0x38, script: 0x3, flags: 0x1}, - 203: {lang: 0x90, script: 0xd4, flags: 0x0}, - 205: {lang: 0x9d, script: 0x52, flags: 0x0}, - 206: {lang: 0x19a, script: 0x52, flags: 0x0}, - 207: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 208: {lang: 0xa, script: 0x52, flags: 0x0}, - 209: {lang: 0xaf, script: 0x52, flags: 0x0}, - 210: {lang: 0xdc, script: 0x52, flags: 0x0}, - 212: {lang: 0xdc, script: 0x5, flags: 0x2}, - 214: {lang: 0x9d, script: 0x52, flags: 0x0}, - 215: {lang: 0x1bd, script: 0x52, flags: 0x0}, - 216: {lang: 0x1af, script: 0x52, flags: 0x0}, - 217: {lang: 0x1b4, script: 0x20, flags: 0x0}, - 223: {lang: 0x15, script: 0x5, flags: 0x0}, - 224: {lang: 0x9d, script: 0x52, flags: 0x0}, - 226: {lang: 0x9d, script: 0x52, flags: 0x0}, - 227: {lang: 0xaf, script: 0x52, flags: 0x0}, - 228: {lang: 0x26e, script: 0x52, flags: 0x0}, - 229: {lang: 0xaa, script: 0x52, flags: 0x0}, - 230: {lang: 0x3b, script: 0x3, flags: 0x1}, - 231: {lang: 0x3e, script: 0x2, flags: 0x1}, - 232: {lang: 0xaf, script: 0x52, flags: 0x0}, - 234: {lang: 0x9d, script: 0x52, flags: 0x0}, - 235: {lang: 0x15, script: 0x5, flags: 0x0}, - 236: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 238: {lang: 0x1dc, script: 0x52, flags: 0x0}, - 239: {lang: 0xca, script: 0x52, flags: 0x0}, - 241: {lang: 0x15, script: 0x5, flags: 0x0}, - 256: {lang: 0xaf, script: 0x52, flags: 0x0}, - 258: {lang: 0x40, script: 0x2, flags: 0x1}, - 259: {lang: 0x23b, script: 0x1e, flags: 0x0}, - 260: {lang: 0x42, script: 0x2, flags: 0x1}, - 261: {lang: 0x20a, script: 0x52, flags: 0x0}, - 262: {lang: 0x15, script: 0x5, flags: 0x0}, - 264: {lang: 0xaf, script: 0x52, flags: 0x0}, - 265: {lang: 0x15, script: 0x5, flags: 0x0}, - 266: {lang: 0x44, script: 0x2, flags: 0x1}, - 269: {lang: 0x22c, script: 0x52, flags: 0x0}, - 270: {lang: 0x1af, script: 0x52, flags: 0x0}, - 271: {lang: 0x46, script: 0x2, flags: 0x1}, - 273: {lang: 0x103, script: 0x52, flags: 0x0}, - 274: {lang: 0xaf, script: 0x52, flags: 0x0}, - 275: {lang: 0x238, script: 0x52, flags: 0x0}, - 276: {lang: 0x1bd, script: 0x52, flags: 0x0}, - 278: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 280: {lang: 0x9d, script: 0x52, flags: 0x0}, - 282: {lang: 0x48, script: 0x2, flags: 0x1}, - 286: {lang: 0xaf, script: 0x52, flags: 0x0}, - 287: {lang: 0xaf, script: 0x52, flags: 0x0}, - 288: {lang: 0xaf, script: 0x52, flags: 0x0}, - 289: {lang: 0x4a, script: 0x3, flags: 0x1}, - 290: {lang: 0x4d, script: 0x2, flags: 0x1}, - 291: {lang: 0x265, script: 0x52, flags: 0x0}, - 292: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 293: {lang: 0x264, script: 0x52, flags: 0x0}, - 294: {lang: 0x4f, script: 0x2, flags: 0x1}, - 295: {lang: 0x26c, script: 0x52, flags: 0x0}, - 297: {lang: 0x51, script: 0x4, flags: 0x1}, - 299: {lang: 0x27c, script: 0x52, flags: 0x0}, - 300: {lang: 0x55, script: 0x2, flags: 0x1}, - 301: {lang: 0x248, script: 0x52, flags: 0x0}, - 302: {lang: 0x57, script: 0x3, flags: 0x1}, - 303: {lang: 0x248, script: 0x52, flags: 0x0}, - 306: {lang: 0x2b9, script: 0x37, flags: 0x2}, - 307: {lang: 0x9d, script: 0x52, flags: 0x0}, - 308: {lang: 0x28d, script: 0x52, flags: 0x0}, - 309: {lang: 0x103, script: 0x52, flags: 0x0}, - 312: {lang: 0x9d, script: 0x52, flags: 0x0}, - 315: {lang: 0x292, script: 0x52, flags: 0x0}, - 316: {lang: 0x41, script: 0x52, flags: 0x0}, - 317: {lang: 0xaf, script: 0x52, flags: 0x0}, - 319: {lang: 0x22f, script: 0x52, flags: 0x0}, - 330: {lang: 0x5a, script: 0x2, flags: 0x1}, - 347: {lang: 0x15, script: 0x5, flags: 0x0}, - 348: {lang: 0x5c, script: 0x2, flags: 0x1}, - 353: {lang: 0x236, script: 0x52, flags: 0x0}, -} - -// likelyRegionList holds lists info associated with likelyRegion. -// Size: 376 bytes, 94 elements -var likelyRegionList = [94]likelyLangScript{ - 0: {lang: 0xa4, script: 0x5, flags: 0x0}, - 1: {lang: 0x264, script: 0x52, flags: 0x0}, - 2: {lang: 0x23a, script: 0x52, flags: 0x0}, - 3: {lang: 0x18c, script: 0x1e, flags: 0x0}, - 4: {lang: 0xf3, script: 0x8, flags: 0x0}, - 5: {lang: 0x145, script: 0x52, flags: 0x0}, - 6: {lang: 0x54, script: 0x52, flags: 0x0}, - 7: {lang: 0x23b, script: 0x1e, flags: 0x0}, - 8: {lang: 0x93, script: 0xd6, flags: 0x0}, - 9: {lang: 0x1b4, script: 0x20, flags: 0x0}, - 10: {lang: 0x2c4, script: 0x34, flags: 0x0}, - 11: {lang: 0x284, script: 0x5, flags: 0x0}, - 12: {lang: 0x2bd, script: 0x35, flags: 0x0}, - 13: {lang: 0x2be, script: 0x52, flags: 0x0}, - 14: {lang: 0x157, script: 0xd5, flags: 0x0}, - 15: {lang: 0x9a, script: 0x2d, flags: 0x0}, - 16: {lang: 0x26f, script: 0x52, flags: 0x0}, - 17: {lang: 0x15, script: 0x5, flags: 0x0}, - 18: {lang: 0xaf, script: 0x52, flags: 0x0}, - 19: {lang: 0x11, script: 0x27, flags: 0x0}, - 20: {lang: 0x9b, script: 0x52, flags: 0x0}, - 21: {lang: 0x141, script: 0x5, flags: 0x2}, - 22: {lang: 0x2b9, script: 0x37, flags: 0x2}, - 23: {lang: 0x111, script: 0x29, flags: 0x0}, - 24: {lang: 0x2, script: 0x1e, flags: 0x0}, - 25: {lang: 0x145, script: 0x52, flags: 0x0}, - 26: {lang: 0x9a, script: 0x2d, flags: 0x0}, - 27: {lang: 0x18c, script: 0x1e, flags: 0x0}, - 28: {lang: 0xf8, script: 0x52, flags: 0x0}, - 29: {lang: 0x19a, script: 0x5, flags: 0x0}, - 30: {lang: 0xe1, script: 0x20, flags: 0x0}, - 31: {lang: 0x28c, script: 0x5, flags: 0x0}, - 32: {lang: 0x129, script: 0x6b, flags: 0x0}, - 33: {lang: 0xa4, script: 0x5, flags: 0x0}, - 34: {lang: 0x264, script: 0x52, flags: 0x0}, - 35: {lang: 0x133, script: 0x46, flags: 0x0}, - 36: {lang: 0x6d, script: 0x5, flags: 0x0}, - 37: {lang: 0x11c, script: 0xd5, flags: 0x0}, - 38: {lang: 0x15, script: 0x5, flags: 0x0}, - 39: {lang: 0xaf, script: 0x52, flags: 0x0}, - 40: {lang: 0x165, script: 0x4f, flags: 0x0}, - 41: {lang: 0x11c, script: 0xd5, flags: 0x0}, - 42: {lang: 0x15, script: 0x5, flags: 0x0}, - 43: {lang: 0xaf, script: 0x52, flags: 0x0}, - 44: {lang: 0x203, script: 0x52, flags: 0x0}, - 45: {lang: 0x286, script: 0x1e, flags: 0x0}, - 46: {lang: 0x18c, script: 0x1e, flags: 0x0}, - 47: {lang: 0x23a, script: 0x52, flags: 0x0}, - 48: {lang: 0x1a5, script: 0x6b, flags: 0x0}, - 49: {lang: 0x114, script: 0x52, flags: 0x0}, - 50: {lang: 0x18f, script: 0x1e, flags: 0x0}, - 51: {lang: 0x12f, script: 0x5, flags: 0x0}, - 52: {lang: 0x2c4, script: 0x35, flags: 0x0}, - 53: {lang: 0x1ef, script: 0x52, flags: 0x0}, - 54: {lang: 0x15, script: 0x5, flags: 0x0}, - 55: {lang: 0xaf, script: 0x52, flags: 0x0}, - 56: {lang: 0x182, script: 0x52, flags: 0x0}, - 57: {lang: 0x28c, script: 0x5, flags: 0x0}, - 58: {lang: 0x40, script: 0x20, flags: 0x0}, - 59: {lang: 0x28c, script: 0x5, flags: 0x0}, - 60: {lang: 0x28c, script: 0x5, flags: 0x0}, - 61: {lang: 0x58, script: 0x20, flags: 0x0}, - 62: {lang: 0x1e7, script: 0x52, flags: 0x0}, - 63: {lang: 0x2f, script: 0x1e, flags: 0x0}, - 64: {lang: 0x203, script: 0x52, flags: 0x0}, - 65: {lang: 0x38, script: 0x1e, flags: 0x0}, - 66: {lang: 0x207, script: 0x1e, flags: 0x0}, - 67: {lang: 0x13f, script: 0x52, flags: 0x0}, - 68: {lang: 0x247, script: 0x52, flags: 0x0}, - 69: {lang: 0x2b9, script: 0x37, flags: 0x0}, - 70: {lang: 0x22a, script: 0x52, flags: 0x0}, - 71: {lang: 0x286, script: 0x1e, flags: 0x0}, - 72: {lang: 0x15, script: 0x5, flags: 0x0}, - 73: {lang: 0xaf, script: 0x52, flags: 0x0}, - 74: {lang: 0x25d, script: 0xd5, flags: 0x0}, - 75: {lang: 0x181, script: 0x5, flags: 0x0}, - 76: {lang: 0x191, script: 0x6b, flags: 0x0}, - 77: {lang: 0x25c, script: 0x1e, flags: 0x0}, - 78: {lang: 0xa4, script: 0x5, flags: 0x0}, - 79: {lang: 0x15, script: 0x5, flags: 0x0}, - 80: {lang: 0xaf, script: 0x52, flags: 0x0}, - 81: {lang: 0x26f, script: 0x52, flags: 0x0}, - 82: {lang: 0x24, script: 0x5, flags: 0x0}, - 83: {lang: 0x118, script: 0x1e, flags: 0x0}, - 84: {lang: 0x3b, script: 0x2d, flags: 0x0}, - 85: {lang: 0x2c4, script: 0x35, flags: 0x0}, - 86: {lang: 0x271, script: 0x52, flags: 0x0}, - 87: {lang: 0x286, script: 0x1e, flags: 0x0}, - 88: {lang: 0x2b9, script: 0x37, flags: 0x0}, - 89: {lang: 0x1e7, script: 0x52, flags: 0x0}, - 90: {lang: 0x23a, script: 0x52, flags: 0x0}, - 91: {lang: 0x23b, script: 0x1e, flags: 0x0}, - 92: {lang: 0xaf, script: 0x52, flags: 0x0}, - 93: {lang: 0x249, script: 0x5, flags: 0x0}, -} - -type likelyTag struct { - lang uint16 - region uint16 - script uint8 -} - -// Size: 192 bytes, 32 elements -var likelyRegionGroup = [32]likelyTag{ - 1: {lang: 0x9b, region: 0xd4, script: 0x52}, - 2: {lang: 0x9b, region: 0x132, script: 0x52}, - 3: {lang: 0x1ef, region: 0x40, script: 0x52}, - 4: {lang: 0x9b, region: 0x2e, script: 0x52}, - 5: {lang: 0x9b, region: 0xd4, script: 0x52}, - 6: {lang: 0x9d, region: 0xcd, script: 0x52}, - 7: {lang: 0x248, region: 0x12d, script: 0x52}, - 8: {lang: 0x15, region: 0x6a, script: 0x5}, - 9: {lang: 0x248, region: 0x4a, script: 0x52}, - 10: {lang: 0x9b, region: 0x15e, script: 0x52}, - 11: {lang: 0x9b, region: 0x132, script: 0x52}, - 12: {lang: 0x9b, region: 0x132, script: 0x52}, - 13: {lang: 0x9d, region: 0x58, script: 0x52}, - 14: {lang: 0x2c4, region: 0x52, script: 0x34}, - 15: {lang: 0xe1, region: 0x97, script: 0x20}, - 16: {lang: 0xf8, region: 0x93, script: 0x52}, - 17: {lang: 0x103, region: 0x9c, script: 0x52}, - 18: {lang: 0x9b, region: 0x2e, script: 0x52}, - 19: {lang: 0x9b, region: 0xe4, script: 0x52}, - 20: {lang: 0x9b, region: 0x88, script: 0x52}, - 21: {lang: 0x22f, region: 0x13f, script: 0x52}, - 22: {lang: 0x2c4, region: 0x52, script: 0x34}, - 23: {lang: 0x28d, region: 0x134, script: 0x52}, - 24: {lang: 0x15, region: 0x106, script: 0x5}, - 25: {lang: 0x207, region: 0x104, script: 0x1e}, - 26: {lang: 0x207, region: 0x104, script: 0x1e}, - 27: {lang: 0x9b, region: 0x79, script: 0x52}, - 28: {lang: 0x85, region: 0x5f, script: 0x52}, - 29: {lang: 0x9d, region: 0x1e, script: 0x52}, - 30: {lang: 0x9b, region: 0x98, script: 0x52}, - 31: {lang: 0x9b, region: 0x79, script: 0x52}, -} - -type mutualIntelligibility struct { - want uint16 - have uint16 - conf uint8 - oneway bool -} - -type scriptIntelligibility struct { - lang uint16 - want uint8 - have uint8 - conf uint8 -} - -// matchLang holds pairs of langIDs of base languages that are typically -// mutually intelligible. Each pair is associated with a confidence and -// whether the intelligibility goes one or both ways. -// Size: 708 bytes, 118 elements -var matchLang = [118]mutualIntelligibility{ - 0: {want: 0x1c1, have: 0x1af, conf: 0x2, oneway: false}, - 1: {want: 0x145, have: 0x6f, conf: 0x2, oneway: false}, - 2: {want: 0xee, have: 0x54, conf: 0x2, oneway: false}, - 3: {want: 0x225, have: 0x54, conf: 0x2, oneway: false}, - 4: {want: 0x23b, have: 0x54, conf: 0x2, oneway: false}, - 5: {want: 0x225, have: 0xee, conf: 0x2, oneway: false}, - 6: {want: 0x23b, have: 0xee, conf: 0x2, oneway: false}, - 7: {want: 0x225, have: 0x23b, conf: 0x2, oneway: false}, - 8: {want: 0x241, have: 0x1, conf: 0x2, oneway: false}, - 9: {want: 0xd2, have: 0x85, conf: 0x2, oneway: true}, - 10: {want: 0x154, have: 0x85, conf: 0x2, oneway: true}, - 11: {want: 0x80, have: 0x1c1, conf: 0x2, oneway: false}, - 12: {want: 0x80, have: 0x1af, conf: 0x2, oneway: false}, - 13: {want: 0x6f, have: 0x145, conf: 0x2, oneway: false}, - 14: {want: 0x2, have: 0x207, conf: 0x2, oneway: true}, - 15: {want: 0x5, have: 0x9b, conf: 0x2, oneway: true}, - 16: {want: 0xa, have: 0x1bd, conf: 0x2, oneway: true}, - 17: {want: 0xd, have: 0x9b, conf: 0x2, oneway: true}, - 18: {want: 0x23, have: 0x9d, conf: 0x2, oneway: true}, - 19: {want: 0x24, have: 0x207, conf: 0x2, oneway: true}, - 20: {want: 0x2f, have: 0x207, conf: 0x2, oneway: true}, - 21: {want: 0x31, have: 0x9b, conf: 0x2, oneway: true}, - 22: {want: 0x3c, have: 0xe1, conf: 0x2, oneway: true}, - 23: {want: 0x4b, have: 0x9b, conf: 0x2, oneway: true}, - 24: {want: 0x50, have: 0xaf, conf: 0x2, oneway: true}, - 25: {want: 0x65, have: 0xaa, conf: 0x2, oneway: true}, - 26: {want: 0x6c, have: 0x9b, conf: 0x2, oneway: true}, - 27: {want: 0x6f, have: 0x15, conf: 0x2, oneway: true}, - 28: {want: 0x70, have: 0xaf, conf: 0x2, oneway: true}, - 29: {want: 0x78, have: 0xaf, conf: 0x2, oneway: true}, - 30: {want: 0x7f, have: 0x9b, conf: 0x2, oneway: true}, - 31: {want: 0x95, have: 0x9b, conf: 0x2, oneway: true}, - 32: {want: 0x9c, have: 0x9b, conf: 0x2, oneway: true}, - 33: {want: 0x9f, have: 0xa8, conf: 0x2, oneway: true}, - 34: {want: 0xa1, have: 0x9d, conf: 0x2, oneway: true}, - 35: {want: 0xad, have: 0x80, conf: 0x2, oneway: true}, - 36: {want: 0xb9, have: 0x1bd, conf: 0x2, oneway: true}, - 37: {want: 0xba, have: 0x9b, conf: 0x2, oneway: true}, - 38: {want: 0xbb, have: 0x9b, conf: 0x2, oneway: true}, - 39: {want: 0xc2, have: 0x9b, conf: 0x2, oneway: true}, - 40: {want: 0xc8, have: 0x9d, conf: 0x2, oneway: true}, - 41: {want: 0xca, have: 0x9d, conf: 0x2, oneway: true}, - 42: {want: 0xd3, have: 0xe1, conf: 0x2, oneway: true}, - 43: {want: 0xdc, have: 0x9b, conf: 0x2, oneway: true}, - 44: {want: 0xde, have: 0x9b, conf: 0x2, oneway: true}, - 45: {want: 0xf1, have: 0xaf, conf: 0x2, oneway: true}, - 46: {want: 0xf3, have: 0x207, conf: 0x2, oneway: true}, - 47: {want: 0xf5, have: 0x9b, conf: 0x2, oneway: true}, - 48: {want: 0xfa, have: 0x9b, conf: 0x2, oneway: true}, - 49: {want: 0x102, have: 0x9b, conf: 0x2, oneway: true}, - 50: {want: 0x10f, have: 0xf8, conf: 0x2, oneway: true}, - 51: {want: 0x111, have: 0x9b, conf: 0x2, oneway: true}, - 52: {want: 0x122, have: 0xaf, conf: 0x2, oneway: true}, - 53: {want: 0x12f, have: 0x207, conf: 0x2, oneway: true}, - 54: {want: 0x133, have: 0x9b, conf: 0x2, oneway: true}, - 55: {want: 0x135, have: 0x9b, conf: 0x2, oneway: true}, - 56: {want: 0x13d, have: 0x9b, conf: 0x2, oneway: true}, - 57: {want: 0x145, have: 0x26f, conf: 0x2, oneway: true}, - 58: {want: 0x14d, have: 0x207, conf: 0x2, oneway: true}, - 59: {want: 0x14e, have: 0x103, conf: 0x2, oneway: true}, - 60: {want: 0x15a, have: 0x9b, conf: 0x2, oneway: true}, - 61: {want: 0x164, have: 0xaf, conf: 0x2, oneway: true}, - 62: {want: 0x165, have: 0x9b, conf: 0x2, oneway: true}, - 63: {want: 0x167, have: 0x9b, conf: 0x2, oneway: true}, - 64: {want: 0x16c, have: 0xaf, conf: 0x2, oneway: true}, - 65: {want: 0x182, have: 0x9b, conf: 0x2, oneway: true}, - 66: {want: 0x183, have: 0xaf, conf: 0x2, oneway: true}, - 67: {want: 0x189, have: 0x9b, conf: 0x2, oneway: true}, - 68: {want: 0x18c, have: 0x38, conf: 0x2, oneway: true}, - 69: {want: 0x18d, have: 0x9b, conf: 0x2, oneway: true}, - 70: {want: 0x18f, have: 0x207, conf: 0x2, oneway: true}, - 71: {want: 0x196, have: 0xe1, conf: 0x2, oneway: true}, - 72: {want: 0x19a, have: 0xf8, conf: 0x2, oneway: true}, - 73: {want: 0x19b, have: 0x9b, conf: 0x2, oneway: true}, - 74: {want: 0x1a5, have: 0x9b, conf: 0x2, oneway: true}, - 75: {want: 0x1b4, have: 0x9b, conf: 0x2, oneway: true}, - 76: {want: 0x1bf, have: 0x1af, conf: 0x2, oneway: false}, - 77: {want: 0x1bf, have: 0x1c1, conf: 0x2, oneway: true}, - 78: {want: 0x1c8, have: 0x9b, conf: 0x2, oneway: true}, - 79: {want: 0x1cc, have: 0x9b, conf: 0x2, oneway: true}, - 80: {want: 0x1ce, have: 0x9b, conf: 0x2, oneway: true}, - 81: {want: 0x1d0, have: 0xaf, conf: 0x2, oneway: true}, - 82: {want: 0x1d2, have: 0x9b, conf: 0x2, oneway: true}, - 83: {want: 0x1d3, have: 0x9b, conf: 0x2, oneway: true}, - 84: {want: 0x1d7, have: 0x9b, conf: 0x2, oneway: true}, - 85: {want: 0x1de, have: 0x9b, conf: 0x2, oneway: true}, - 86: {want: 0x1ee, have: 0x9b, conf: 0x2, oneway: true}, - 87: {want: 0x1f1, have: 0x9d, conf: 0x2, oneway: true}, - 88: {want: 0x1fc, have: 0x85, conf: 0x2, oneway: true}, - 89: {want: 0x201, have: 0x9b, conf: 0x2, oneway: true}, - 90: {want: 0x20a, have: 0xaf, conf: 0x2, oneway: true}, - 91: {want: 0x20d, have: 0xe1, conf: 0x2, oneway: true}, - 92: {want: 0x21a, have: 0x9b, conf: 0x2, oneway: true}, - 93: {want: 0x228, have: 0x9b, conf: 0x2, oneway: true}, - 94: {want: 0x236, have: 0x9b, conf: 0x2, oneway: true}, - 95: {want: 0x238, have: 0x9b, conf: 0x2, oneway: true}, - 96: {want: 0x23a, have: 0x9b, conf: 0x2, oneway: true}, - 97: {want: 0x242, have: 0x9b, conf: 0x2, oneway: true}, - 98: {want: 0x244, have: 0xf8, conf: 0x2, oneway: true}, - 99: {want: 0x248, have: 0x9b, conf: 0x2, oneway: true}, - 100: {want: 0x251, have: 0x9b, conf: 0x2, oneway: true}, - 101: {want: 0x258, have: 0x9b, conf: 0x2, oneway: true}, - 102: {want: 0x25c, have: 0x207, conf: 0x2, oneway: true}, - 103: {want: 0x261, have: 0x9b, conf: 0x2, oneway: true}, - 104: {want: 0x264, have: 0x207, conf: 0x2, oneway: true}, - 105: {want: 0x361a, have: 0x9b, conf: 0x2, oneway: true}, - 106: {want: 0x26b, have: 0x9b, conf: 0x2, oneway: true}, - 107: {want: 0x26c, have: 0x9b, conf: 0x2, oneway: true}, - 108: {want: 0x277, have: 0x207, conf: 0x2, oneway: true}, - 109: {want: 0x27b, have: 0x9b, conf: 0x2, oneway: true}, - 110: {want: 0x284, have: 0x2c4, conf: 0x2, oneway: true}, - 111: {want: 0x28c, have: 0x9b, conf: 0x2, oneway: true}, - 112: {want: 0x28d, have: 0x207, conf: 0x2, oneway: true}, - 113: {want: 0x2a4, have: 0xaf, conf: 0x2, oneway: true}, - 114: {want: 0x2a9, have: 0x9b, conf: 0x2, oneway: true}, - 115: {want: 0x2b9, have: 0x9b, conf: 0x2, oneway: true}, - 116: {want: 0x2ba, have: 0x9b, conf: 0x2, oneway: true}, - 117: {want: 0x2c6, have: 0x9b, conf: 0x2, oneway: true}, -} - -// matchScript holds pairs of scriptIDs where readers of one script -// can typically also read the other. Each is associated with a confidence. -// Size: 24 bytes, 4 elements -var matchScript = [4]scriptIntelligibility{ - 0: {lang: 0x23b, want: 0x52, have: 0x1e, conf: 0x2}, - 1: {lang: 0x23b, want: 0x1e, have: 0x52, conf: 0x2}, - 2: {lang: 0x0, want: 0x34, have: 0x35, conf: 0x1}, - 3: {lang: 0x0, want: 0x35, have: 0x34, conf: 0x1}, -} - -// Size: 128 bytes, 32 elements -var regionContainment = [32]uint32{ - 0xffffffff, 0x000007a2, 0x00003044, 0x00000008, - 0x403c0010, 0x00000020, 0x00000040, 0x00000080, - 0x00000100, 0x00000200, 0x00000400, 0x2000384c, - 0x00001000, 0x00002000, 0x00004000, 0x00008000, - 0x00010000, 0x00020000, 0x00040000, 0x00080000, - 0x00100000, 0x00200000, 0x01c1c000, 0x00800000, - 0x01000000, 0x1e020000, 0x04000000, 0x08000000, - 0x10000000, 0x20002048, 0x40000000, 0x80000000, -} - -// regionInclusion maps region identifiers to sets of regions in regionInclusionBits, -// where each set holds all groupings that are directly connected in a region -// containment graph. -// Size: 355 bytes, 355 elements -var regionInclusion = [355]uint8{ - // Entry 0 - 3F - 0x00, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, - 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, - 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, - 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x20, - 0x21, 0x22, 0x23, 0x24, 0x25, 0x25, 0x22, 0x23, - 0x25, 0x26, 0x21, 0x27, 0x28, 0x29, 0x2a, 0x25, - 0x2b, 0x23, 0x22, 0x25, 0x24, 0x29, 0x2c, 0x2d, - 0x23, 0x2e, 0x2c, 0x25, 0x2f, 0x30, 0x27, 0x25, - // Entry 40 - 7F - 0x27, 0x25, 0x24, 0x30, 0x21, 0x31, 0x32, 0x33, - 0x2f, 0x21, 0x26, 0x26, 0x26, 0x34, 0x2c, 0x28, - 0x27, 0x26, 0x35, 0x27, 0x21, 0x33, 0x22, 0x20, - 0x25, 0x2c, 0x25, 0x21, 0x36, 0x2d, 0x34, 0x29, - 0x21, 0x2e, 0x37, 0x25, 0x25, 0x20, 0x38, 0x38, - 0x27, 0x37, 0x38, 0x38, 0x2e, 0x39, 0x2e, 0x1f, - 0x37, 0x3a, 0x27, 0x3b, 0x2b, 0x20, 0x29, 0x34, - 0x26, 0x37, 0x25, 0x23, 0x27, 0x2b, 0x2c, 0x22, - // Entry 80 - BF - 0x2f, 0x2c, 0x2c, 0x25, 0x26, 0x39, 0x21, 0x33, - 0x3b, 0x2c, 0x27, 0x35, 0x21, 0x33, 0x39, 0x25, - 0x2d, 0x20, 0x38, 0x30, 0x37, 0x23, 0x2b, 0x24, - 0x21, 0x23, 0x24, 0x2b, 0x39, 0x2b, 0x25, 0x23, - 0x35, 0x20, 0x2e, 0x3c, 0x30, 0x3b, 0x2e, 0x25, - 0x35, 0x35, 0x23, 0x25, 0x3c, 0x30, 0x23, 0x25, - 0x34, 0x24, 0x2c, 0x31, 0x37, 0x29, 0x37, 0x38, - 0x38, 0x34, 0x32, 0x22, 0x25, 0x2e, 0x3b, 0x20, - // Entry C0 - FF - 0x22, 0x2c, 0x30, 0x35, 0x35, 0x3b, 0x25, 0x2c, - 0x25, 0x39, 0x2e, 0x24, 0x2e, 0x33, 0x30, 0x2e, - 0x31, 0x3a, 0x2c, 0x2a, 0x2c, 0x20, 0x33, 0x29, - 0x2b, 0x24, 0x20, 0x3b, 0x23, 0x28, 0x2a, 0x23, - 0x33, 0x20, 0x27, 0x28, 0x3a, 0x30, 0x24, 0x2d, - 0x2f, 0x28, 0x25, 0x23, 0x39, 0x20, 0x3b, 0x27, - 0x20, 0x23, 0x20, 0x20, 0x1e, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - // Entry 100 - 13F - 0x2e, 0x20, 0x2d, 0x22, 0x32, 0x2e, 0x23, 0x3a, - 0x2e, 0x38, 0x37, 0x30, 0x2c, 0x39, 0x2b, 0x2d, - 0x2c, 0x22, 0x2c, 0x2e, 0x27, 0x2e, 0x26, 0x32, - 0x33, 0x25, 0x23, 0x31, 0x21, 0x25, 0x26, 0x21, - 0x2c, 0x30, 0x3c, 0x28, 0x30, 0x3c, 0x38, 0x28, - 0x30, 0x23, 0x25, 0x28, 0x35, 0x2e, 0x32, 0x2e, - 0x20, 0x21, 0x2f, 0x27, 0x3c, 0x22, 0x25, 0x20, - 0x27, 0x25, 0x25, 0x30, 0x3a, 0x28, 0x20, 0x28, - // Entry 140 - 17F - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x22, 0x20, 0x20, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - 0x20, 0x20, 0x23, 0x23, 0x2e, 0x22, 0x31, 0x2e, - 0x26, 0x2e, 0x20, -} - -// regionInclusionBits is an array of bit vectors where every vector represents -// a set of region groupings. These sets are used to compute the distance -// between two regions for the purpose of language matching. -// Size: 288 bytes, 72 elements -var regionInclusionBits = [72]uint32{ - // Entry 0 - 1F - 0x82400813, 0x000007a3, 0x00003844, 0x20000808, - 0x403c0011, 0x00000022, 0x20000844, 0x00000082, - 0x00000102, 0x00000202, 0x00000402, 0x2000384d, - 0x00001804, 0x20002804, 0x00404000, 0x00408000, - 0x00410000, 0x02020000, 0x00040010, 0x00080010, - 0x00100010, 0x00200010, 0x01c1c001, 0x00c00000, - 0x01400000, 0x1e020001, 0x06000000, 0x0a000000, - 0x12000000, 0x20002848, 0x40000010, 0x80000001, - // Entry 20 - 3F - 0x00000001, 0x40000000, 0x00020000, 0x01000000, - 0x00008000, 0x00002000, 0x00000200, 0x00000008, - 0x00200000, 0x90000000, 0x00040000, 0x08000000, - 0x00000020, 0x84000000, 0x00000080, 0x00001000, - 0x00010000, 0x00000400, 0x04000000, 0x00000040, - 0x10000000, 0x00004000, 0x81000000, 0x88000000, - 0x00000100, 0x80020000, 0x00080000, 0x00100000, - 0x00800000, 0xffffffff, 0x82400fb3, 0xc27c0813, - // Entry 40 - 5F - 0xa240385f, 0x83c1c813, 0x9e420813, 0x92000001, - 0x86000001, 0x81400001, 0x8a000001, 0x82020001, -} - -// regionInclusionNext marks, for each entry in regionInclusionBits, the set of -// all groups that are reachable from the groups set in the respective entry. -// Size: 72 bytes, 72 elements -var regionInclusionNext = [72]uint8{ - // Entry 0 - 3F - 0x3d, 0x3e, 0x0b, 0x0b, 0x3f, 0x01, 0x0b, 0x01, - 0x01, 0x01, 0x01, 0x40, 0x0b, 0x0b, 0x16, 0x16, - 0x16, 0x19, 0x04, 0x04, 0x04, 0x04, 0x41, 0x16, - 0x16, 0x42, 0x19, 0x19, 0x19, 0x0b, 0x04, 0x00, - 0x00, 0x1e, 0x11, 0x18, 0x0f, 0x0d, 0x09, 0x03, - 0x15, 0x43, 0x12, 0x1b, 0x05, 0x44, 0x07, 0x0c, - 0x10, 0x0a, 0x1a, 0x06, 0x1c, 0x0e, 0x45, 0x46, - 0x08, 0x47, 0x13, 0x14, 0x17, 0x3d, 0x3d, 0x3d, - // Entry 40 - 7F - 0x3d, 0x3d, 0x3d, 0x42, 0x42, 0x41, 0x42, 0x42, -} - -type parentRel struct { - lang uint16 - script uint8 - maxScript uint8 - toRegion uint16 - fromRegion []uint16 -} - -// Size: 412 bytes, 5 elements -var parents = [5]parentRel{ - 0: {lang: 0x9b, script: 0x0, maxScript: 0x52, toRegion: 0x1, fromRegion: []uint16{0x1a, 0x24, 0x25, 0x2e, 0x33, 0x35, 0x3c, 0x41, 0x45, 0x47, 0x48, 0x49, 0x4f, 0x51, 0x5b, 0x5c, 0x60, 0x63, 0x6c, 0x71, 0x72, 0x73, 0x79, 0x7a, 0x7d, 0x7e, 0x7f, 0x81, 0x8a, 0x8b, 0x94, 0x95, 0x96, 0x97, 0x98, 0x9d, 0x9e, 0xa2, 0xa5, 0xa7, 0xab, 0xaf, 0xb2, 0xb3, 0xbd, 0xc4, 0xc8, 0xc9, 0xca, 0xcc, 0xce, 0xd0, 0xd3, 0xd4, 0xdb, 0xdd, 0xde, 0xe4, 0xe5, 0xe6, 0xe9, 0xee, 0x105, 0x107, 0x108, 0x109, 0x10b, 0x10c, 0x110, 0x115, 0x119, 0x11b, 0x11d, 0x123, 0x127, 0x12a, 0x12b, 0x12d, 0x12f, 0x136, 0x139, 0x13c, 0x13f, 0x15e, 0x15f, 0x161}}, - 1: {lang: 0x9b, script: 0x0, maxScript: 0x52, toRegion: 0x1a, fromRegion: []uint16{0x2d, 0x4d, 0x5f, 0x62, 0x70, 0xd7, 0x10a, 0x10d}}, - 2: {lang: 0x9d, script: 0x0, maxScript: 0x52, toRegion: 0x1e, fromRegion: []uint16{0x2b, 0x3e, 0x40, 0x50, 0x53, 0x55, 0x58, 0x64, 0x68, 0x87, 0x8d, 0xcd, 0xd6, 0xe0, 0xe2, 0xea, 0xef, 0x118, 0x132, 0x133, 0x138}}, - 3: {lang: 0x1ef, script: 0x0, maxScript: 0x52, toRegion: 0xec, fromRegion: []uint16{0x29, 0x4d, 0x59, 0x84, 0x89, 0xb5, 0xc4, 0xcf, 0x116, 0x124}}, - 4: {lang: 0x2c4, script: 0x35, maxScript: 0x35, toRegion: 0x8b, fromRegion: []uint16{0xc4}}, -} - -// Total table size 20315 bytes (19KiB); checksum: C16EF251 diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tags.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tags.go deleted file mode 100644 index de30155..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/language/tags.go +++ /dev/null @@ -1,143 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package language - -// TODO: Various sets of commonly use tags and regions. - -// MustParse is like Parse, but panics if the given BCP 47 tag cannot be parsed. -// It simplifies safe initialization of Tag values. -func MustParse(s string) Tag { - t, err := Parse(s) - if err != nil { - panic(err) - } - return t -} - -// MustParse is like Parse, but panics if the given BCP 47 tag cannot be parsed. -// It simplifies safe initialization of Tag values. -func (c CanonType) MustParse(s string) Tag { - t, err := c.Parse(s) - if err != nil { - panic(err) - } - return t -} - -// MustParseBase is like ParseBase, but panics if the given base cannot be parsed. -// It simplifies safe initialization of Base values. -func MustParseBase(s string) Base { - b, err := ParseBase(s) - if err != nil { - panic(err) - } - return b -} - -// MustParseScript is like ParseScript, but panics if the given script cannot be -// parsed. It simplifies safe initialization of Script values. -func MustParseScript(s string) Script { - scr, err := ParseScript(s) - if err != nil { - panic(err) - } - return scr -} - -// MustParseRegion is like ParseRegion, but panics if the given region cannot be -// parsed. It simplifies safe initialization of Region values. -func MustParseRegion(s string) Region { - r, err := ParseRegion(s) - if err != nil { - panic(err) - } - return r -} - -var ( - und = Tag{} - - Und Tag = Tag{} - - Afrikaans Tag = Tag{lang: _af} // af - Amharic Tag = Tag{lang: _am} // am - Arabic Tag = Tag{lang: _ar} // ar - ModernStandardArabic Tag = Tag{lang: _ar, region: _001} // ar-001 - Azerbaijani Tag = Tag{lang: _az} // az - Bulgarian Tag = Tag{lang: _bg} // bg - Bengali Tag = Tag{lang: _bn} // bn - Catalan Tag = Tag{lang: _ca} // ca - Czech Tag = Tag{lang: _cs} // cs - Danish Tag = Tag{lang: _da} // da - German Tag = Tag{lang: _de} // de - Greek Tag = Tag{lang: _el} // el - English Tag = Tag{lang: _en} // en - AmericanEnglish Tag = Tag{lang: _en, region: _US} // en-US - BritishEnglish Tag = Tag{lang: _en, region: _GB} // en-GB - Spanish Tag = Tag{lang: _es} // es - EuropeanSpanish Tag = Tag{lang: _es, region: _ES} // es-ES - LatinAmericanSpanish Tag = Tag{lang: _es, region: _419} // es-419 - Estonian Tag = Tag{lang: _et} // et - Persian Tag = Tag{lang: _fa} // fa - Finnish Tag = Tag{lang: _fi} // fi - Filipino Tag = Tag{lang: _fil} // fil - French Tag = Tag{lang: _fr} // fr - CanadianFrench Tag = Tag{lang: _fr, region: _CA} // fr-CA - Gujarati Tag = Tag{lang: _gu} // gu - Hebrew Tag = Tag{lang: _he} // he - Hindi Tag = Tag{lang: _hi} // hi - Croatian Tag = Tag{lang: _hr} // hr - Hungarian Tag = Tag{lang: _hu} // hu - Armenian Tag = Tag{lang: _hy} // hy - Indonesian Tag = Tag{lang: _id} // id - Icelandic Tag = Tag{lang: _is} // is - Italian Tag = Tag{lang: _it} // it - Japanese Tag = Tag{lang: _ja} // ja - Georgian Tag = Tag{lang: _ka} // ka - Kazakh Tag = Tag{lang: _kk} // kk - Khmer Tag = Tag{lang: _km} // km - Kannada Tag = Tag{lang: _kn} // kn - Korean Tag = Tag{lang: _ko} // ko - Kirghiz Tag = Tag{lang: _ky} // ky - Lao Tag = Tag{lang: _lo} // lo - Lithuanian Tag = Tag{lang: _lt} // lt - Latvian Tag = Tag{lang: _lv} // lv - Macedonian Tag = Tag{lang: _mk} // mk - Malayalam Tag = Tag{lang: _ml} // ml - Mongolian Tag = Tag{lang: _mn} // mn - Marathi Tag = Tag{lang: _mr} // mr - Malay Tag = Tag{lang: _ms} // ms - Burmese Tag = Tag{lang: _my} // my - Nepali Tag = Tag{lang: _ne} // ne - Dutch Tag = Tag{lang: _nl} // nl - Norwegian Tag = Tag{lang: _no} // no - Punjabi Tag = Tag{lang: _pa} // pa - Polish Tag = Tag{lang: _pl} // pl - Portuguese Tag = Tag{lang: _pt} // pt - BrazilianPortuguese Tag = Tag{lang: _pt, region: _BR} // pt-BR - EuropeanPortuguese Tag = Tag{lang: _pt, region: _PT} // pt-PT - Romanian Tag = Tag{lang: _ro} // ro - Russian Tag = Tag{lang: _ru} // ru - Sinhala Tag = Tag{lang: _si} // si - Slovak Tag = Tag{lang: _sk} // sk - Slovenian Tag = Tag{lang: _sl} // sl - Albanian Tag = Tag{lang: _sq} // sq - Serbian Tag = Tag{lang: _sr} // sr - SerbianLatin Tag = Tag{lang: _sr, script: _Latn} // sr-Latn - Swedish Tag = Tag{lang: _sv} // sv - Swahili Tag = Tag{lang: _sw} // sw - Tamil Tag = Tag{lang: _ta} // ta - Telugu Tag = Tag{lang: _te} // te - Thai Tag = Tag{lang: _th} // th - Turkish Tag = Tag{lang: _tr} // tr - Ukrainian Tag = Tag{lang: _uk} // uk - Urdu Tag = Tag{lang: _ur} // ur - Uzbek Tag = Tag{lang: _uz} // uz - Vietnamese Tag = Tag{lang: _vi} // vi - Chinese Tag = Tag{lang: _zh} // zh - SimplifiedChinese Tag = Tag{lang: _zh, script: _Hans} // zh-Hans - TraditionalChinese Tag = Tag{lang: _zh, script: _Hant} // zh-Hant - Zulu Tag = Tag{lang: _zu} // zu -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/cond.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/cond.go deleted file mode 100644 index ae7a921..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/cond.go +++ /dev/null @@ -1,126 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package runes - -import ( - "unicode/utf8" - - "golang.org/x/text/transform" -) - -// Note: below we pass invalid UTF-8 to the tIn and tNotIn transformers as is. -// This is done for various reasons: -// - To retain the semantics of the Nop transformer: if input is passed to a Nop -// one would expect it to be unchanged. -// - It would be very expensive to pass a converted RuneError to a transformer: -// a transformer might need more source bytes after RuneError, meaning that -// the only way to pass it safely is to create a new buffer and manage the -// intermingling of RuneErrors and normal input. -// - Many transformers leave ill-formed UTF-8 as is, so this is not -// inconsistent. Generally ill-formed UTF-8 is only replaced if it is a -// logical consequence of the operation (as for Map) or if it otherwise would -// pose security concerns (as for Remove). -// - An alternative would be to return an error on ill-formed UTF-8, but this -// would be inconsistent with other operations. - -// If returns a transformer that applies tIn to consecutive runes for which -// s.Contains(r) and tNotIn to consecutive runes for which !s.Contains(r). Reset -// is called on tIn and tNotIn at the start of each run. A Nop transformer will -// substitute a nil value passed to tIn or tNotIn. Invalid UTF-8 is translated -// to RuneError to determine which transformer to apply, but is passed as is to -// the respective transformer. -func If(s Set, tIn, tNotIn transform.Transformer) Transformer { - if tIn == nil && tNotIn == nil { - return Transformer{transform.Nop} - } - if tIn == nil { - tIn = transform.Nop - } - if tNotIn == nil { - tNotIn = transform.Nop - } - a := &cond{ - tIn: tIn, - tNotIn: tNotIn, - f: s.Contains, - } - a.Reset() - return Transformer{a} -} - -type cond struct { - tIn, tNotIn transform.Transformer - f func(rune) bool - check func(rune) bool // current check to perform - t transform.Transformer // current transformer to use -} - -// Reset implements transform.Transformer. -func (t *cond) Reset() { - t.check = t.is - t.t = t.tIn - t.t.Reset() // notIn will be reset on first usage. -} - -func (t *cond) is(r rune) bool { - if t.f(r) { - return true - } - t.check = t.isNot - t.t = t.tNotIn - t.tNotIn.Reset() - return false -} - -func (t *cond) isNot(r rune) bool { - if !t.f(r) { - return true - } - t.check = t.is - t.t = t.tIn - t.tIn.Reset() - return false -} - -func (t *cond) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - p := 0 - for nSrc < len(src) && err == nil { - // Don't process too much at a time, as the work might be wasted if the - // destination buffer isn't large enough to hold the result or a - // transform returns an error early. - const maxChunk = 4096 - max := len(src) - if n := nSrc + maxChunk; n < len(src) { - max = n - } - atEnd := false - size := 0 - current := t.t - for ; p < max; p += size { - var r rune - r, size = utf8.DecodeRune(src[p:]) - if r == utf8.RuneError && size == 1 { - if !atEOF && !utf8.FullRune(src[p:]) { - err = transform.ErrShortSrc - break - } - } - if !t.check(r) { - // The next rune will be the start of a new run. - atEnd = true - break - } - } - nDst2, nSrc2, err2 := current.Transform(dst[nDst:], src[nSrc:p], atEnd || (atEOF && p == len(src))) - nDst += nDst2 - nSrc += nSrc2 - if err2 != nil { - return nDst, nSrc, err2 - } - // At this point either err != nil or t.check will pass for the rune at p. - p = nSrc + size - } - return nDst, nSrc, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/runes.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/runes.go deleted file mode 100644 index 291de65..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/runes/runes.go +++ /dev/null @@ -1,278 +0,0 @@ -// Copyright 2014 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package runes provide transforms for UTF-8 encoded text. -package runes - -import ( - "unicode" - "unicode/utf8" - - "golang.org/x/text/transform" -) - -// A Set is a collection of runes. -type Set interface { - // Contains returns true if r is contained in the set. - Contains(r rune) bool -} - -type setFunc func(rune) bool - -func (s setFunc) Contains(r rune) bool { - return s(r) -} - -// Note: using funcs here instead of wrapping types result in cleaner -// documentation and a smaller API. - -// In creates a Set with a Contains method that returns true for all runes in -// the given RangeTable. -func In(rt *unicode.RangeTable) Set { - return setFunc(func(r rune) bool { return unicode.Is(rt, r) }) -} - -// In creates a Set with a Contains method that returns true for all runes not -// in the given RangeTable. -func NotIn(rt *unicode.RangeTable) Set { - return setFunc(func(r rune) bool { return !unicode.Is(rt, r) }) -} - -// Predicate creates a Set with a Contains method that returns f(r). -func Predicate(f func(rune) bool) Set { - return setFunc(f) -} - -// Transformer implements the transform.Transformer interface. -type Transformer struct { - transform.Transformer -} - -// Bytes returns a new byte slice with the result of converting b using t. It -// calls Reset on t. It returns nil if any error was found. This can only happen -// if an error-producing Transformer is passed to If. -func (t Transformer) Bytes(b []byte) []byte { - b, _, err := transform.Bytes(t, b) - if err != nil { - return nil - } - return b -} - -// String returns a string with the result of converting s using t. It calls -// Reset on t. It returns the empty string if any error was found. This can only -// happen if an error-producing Transformer is passed to If. -func (t Transformer) String(s string) string { - s, _, err := transform.String(t, s) - if err != nil { - return "" - } - return s -} - -// TODO: -// - Copy: copying strings and bytes in whole-rune units. -// - Validation (maybe) -// - Well-formed-ness (maybe) - -const runeErrorString = string(utf8.RuneError) - -// Remove returns a Transformer that removes runes r for which s.Contains(r). -// Illegal input bytes are replaced by RuneError before being passed to f. -func Remove(s Set) Transformer { - if f, ok := s.(setFunc); ok { - // This little trick cuts the running time of BenchmarkRemove for sets - // created by Predicate roughly in half. - // TODO: special-case RangeTables as well. - return Transformer{remove(f)} - } - return Transformer{remove(s.Contains)} -} - -// TODO: remove transform.RemoveFunc. - -type remove func(r rune) bool - -func (remove) Reset() {} - -// Transform implements transform.Transformer. -func (t remove) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for r, size := rune(0), 0; nSrc < len(src); { - if r = rune(src[nSrc]); r < utf8.RuneSelf { - size = 1 - } else { - r, size = utf8.DecodeRune(src[nSrc:]) - - if size == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src[nSrc:]) { - err = transform.ErrShortSrc - break - } - // We replace illegal bytes with RuneError. Not doing so might - // otherwise turn a sequence of invalid UTF-8 into valid UTF-8. - // The resulting byte sequence may subsequently contain runes - // for which t(r) is true that were passed unnoticed. - if !t(utf8.RuneError) { - if nDst+3 > len(dst) { - err = transform.ErrShortDst - break - } - dst[nDst+0] = runeErrorString[0] - dst[nDst+1] = runeErrorString[1] - dst[nDst+2] = runeErrorString[2] - nDst += 3 - } - nSrc++ - continue - } - } - - if t(r) { - nSrc += size - continue - } - if nDst+size > len(dst) { - err = transform.ErrShortDst - break - } - for i := 0; i < size; i++ { - dst[nDst] = src[nSrc] - nDst++ - nSrc++ - } - } - return -} - -// Map returns a Transformer that maps the runes in the input using the given -// mapping. Illegal bytes in the input are converted to utf8.RuneError before -// being passed to the mapping func. -func Map(mapping func(rune) rune) Transformer { - return Transformer{mapper(mapping)} -} - -type mapper func(rune) rune - -func (mapper) Reset() {} - -// Transform implements transform.Transformer. -func (t mapper) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - var replacement rune - var b [utf8.UTFMax]byte - - for r, size := rune(0), 0; nSrc < len(src); { - if r = rune(src[nSrc]); r < utf8.RuneSelf { - if replacement = t(r); replacement < utf8.RuneSelf { - if nDst == len(dst) { - err = transform.ErrShortDst - break - } - dst[nDst] = byte(replacement) - nDst++ - nSrc++ - continue - } - size = 1 - } else if r, size = utf8.DecodeRune(src[nSrc:]); size == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src[nSrc:]) { - err = transform.ErrShortSrc - break - } - - if replacement = t(utf8.RuneError); replacement == utf8.RuneError { - if nDst+3 > len(dst) { - err = transform.ErrShortDst - break - } - dst[nDst+0] = runeErrorString[0] - dst[nDst+1] = runeErrorString[1] - dst[nDst+2] = runeErrorString[2] - nDst += 3 - nSrc++ - continue - } - } else if replacement = t(r); replacement == r { - if nDst+size > len(dst) { - err = transform.ErrShortDst - break - } - for i := 0; i < size; i++ { - dst[nDst] = src[nSrc] - nDst++ - nSrc++ - } - continue - } - - n := utf8.EncodeRune(b[:], replacement) - - if nDst+n > len(dst) { - err = transform.ErrShortDst - break - } - for i := 0; i < n; i++ { - dst[nDst] = b[i] - nDst++ - } - nSrc += size - } - return -} - -// ReplaceIllFormed returns a transformer that replaces all input bytes that are -// not part of a well-formed UTF-8 code sequence with utf8.RuneError. -func ReplaceIllFormed() Transformer { - return Transformer{&replaceIllFormed{}} -} - -type replaceIllFormed struct{ transform.NopResetter } - -func (t replaceIllFormed) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for nSrc < len(src) { - r, size := utf8.DecodeRune(src[nSrc:]) - - // Look for an ASCII rune. - if r < utf8.RuneSelf { - if nDst == len(dst) { - err = transform.ErrShortDst - break - } - dst[nDst] = byte(r) - nDst++ - nSrc++ - continue - } - - // Look for a valid non-ASCII rune. - if r != utf8.RuneError || size != 1 { - if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { - err = transform.ErrShortDst - break - } - nDst += size - nSrc += size - continue - } - - // Look for short source data. - if !atEOF && !utf8.FullRune(src[nSrc:]) { - err = transform.ErrShortSrc - break - } - - // We have an invalid rune. - if nDst+3 > len(dst) { - err = transform.ErrShortDst - break - } - dst[nDst+0] = runeErrorString[0] - dst[nDst+1] = runeErrorString[1] - dst[nDst+2] = runeErrorString[2] - nDst += 3 - nSrc++ - } - return nDst, nSrc, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/bidirule/bidirule.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/bidirule/bidirule.go deleted file mode 100644 index 277257f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/bidirule/bidirule.go +++ /dev/null @@ -1,290 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package bidirule implements the Bidi Rule defined by RFC 5893. -// -// This package is under development. The API may change without notice and -// without preserving backward compatibility. -package bidirule - -import ( - "errors" - "unicode/utf8" - - "golang.org/x/text/transform" - "golang.org/x/text/unicode/bidi" -) - -// This file contains an implementation of RFC 5893: Right-to-Left Scripts for -// Internationalized Domain Names for Applications (IDNA) -// -// A label is an individual component of a domain name. Labels are usually -// shown separated by dots; for example, the domain name "www.example.com" is -// composed of three labels: "www", "example", and "com". -// -// An RTL label is a label that contains at least one character of class R, AL, -// or AN. An LTR label is any label that is not an RTL label. -// -// A "Bidi domain name" is a domain name that contains at least one RTL label. -// -// The following guarantees can be made based on the above: -// -// o In a domain name consisting of only labels that satisfy the rule, -// the requirements of Section 3 are satisfied. Note that even LTR -// labels and pure ASCII labels have to be tested. -// -// o In a domain name consisting of only LDH labels (as defined in the -// Definitions document [RFC5890]) and labels that satisfy the rule, -// the requirements of Section 3 are satisfied as long as a label -// that starts with an ASCII digit does not come after a -// right-to-left label. -// -// No guarantee is given for other combinations. - -// ErrInvalid indicates a label is invalid according to the Bidi Rule. -var ErrInvalid = errors.New("bidirule: failed Bidi Rule") - -type ruleState uint8 - -const ( - ruleInitial ruleState = iota - ruleLTR - ruleLTRFinal - ruleRTL - ruleRTLFinal - ruleInvalid -) - -type ruleTransition struct { - next ruleState - mask uint16 -} - -var transitions = [...][2]ruleTransition{ - // [2.1] The first character must be a character with Bidi property L, R, or - // AL. If it has the R or AL property, it is an RTL label; if it has the L - // property, it is an LTR label. - ruleInitial: { - {ruleLTRFinal, 1 << bidi.L}, - {ruleRTLFinal, 1<<bidi.R | 1<<bidi.AL}, - }, - ruleRTL: { - // [2.3] In an RTL label, the end of the label must be a character with - // Bidi property R, AL, EN, or AN, followed by zero or more characters - // with Bidi property NSM. - {ruleRTLFinal, 1<<bidi.R | 1<<bidi.AL | 1<<bidi.EN | 1<<bidi.AN}, - - // [2.2] In an RTL label, only characters with the Bidi properties R, - // AL, AN, EN, ES, CS, ET, ON, BN, or NSM are allowed. - // We exclude the entries from [2.3] - {ruleRTL, 1<<bidi.ES | 1<<bidi.CS | 1<<bidi.ET | 1<<bidi.ON | 1<<bidi.BN | 1<<bidi.NSM}, - }, - ruleRTLFinal: { - // [2.3] In an RTL label, the end of the label must be a character with - // Bidi property R, AL, EN, or AN, followed by zero or more characters - // with Bidi property NSM. - {ruleRTLFinal, 1<<bidi.R | 1<<bidi.AL | 1<<bidi.EN | 1<<bidi.AN | 1<<bidi.NSM}, - - // [2.2] In an RTL label, only characters with the Bidi properties R, - // AL, AN, EN, ES, CS, ET, ON, BN, or NSM are allowed. - // We exclude the entries from [2.3] and NSM. - {ruleRTL, 1<<bidi.ES | 1<<bidi.CS | 1<<bidi.ET | 1<<bidi.ON | 1<<bidi.BN}, - }, - ruleLTR: { - // [2.6] In an LTR label, the end of the label must be a character with - // Bidi property L or EN, followed by zero or more characters with Bidi - // property NSM. - {ruleLTRFinal, 1<<bidi.L | 1<<bidi.EN}, - - // [2.5] In an LTR label, only characters with the Bidi properties L, - // EN, ES, CS, ET, ON, BN, or NSM are allowed. - // We exclude the entries from [2.6]. - {ruleLTR, 1<<bidi.ES | 1<<bidi.CS | 1<<bidi.ET | 1<<bidi.ON | 1<<bidi.BN | 1<<bidi.NSM}, - }, - ruleLTRFinal: { - // [2.6] In an LTR label, the end of the label must be a character with - // Bidi property L or EN, followed by zero or more characters with Bidi - // property NSM. - {ruleLTRFinal, 1<<bidi.L | 1<<bidi.EN | 1<<bidi.NSM}, - - // [2.5] In an LTR label, only characters with the Bidi properties L, - // EN, ES, CS, ET, ON, BN, or NSM are allowed. - // We exclude the entries from [2.6]. - {ruleLTR, 1<<bidi.ES | 1<<bidi.CS | 1<<bidi.ET | 1<<bidi.ON | 1<<bidi.BN}, - }, - ruleInvalid: { - {ruleInvalid, 0}, - {ruleInvalid, 0}, - }, -} - -// [2.4] In an RTL label, if an EN is present, no AN may be present, and -// vice versa. -const exclusiveRTL = uint16(1<<bidi.EN | 1<<bidi.AN) - -// Direction reports the direction of the given label as defined by RFC 5893 or -// an error if b is not a valid label according to the Bidi Rule. -func Direction(b []byte) (bidi.Direction, error) { - t := Transformer{} - if n, ok := t.advance(b); ok && n == len(b) { - switch t.state { - case ruleLTRFinal, ruleInitial: - return bidi.LeftToRight, nil - case ruleRTLFinal: - return bidi.RightToLeft, nil - } - } - return bidi.Neutral, ErrInvalid -} - -// DirectionString reports the direction of the given label as defined by RFC -// 5893 or an error if s is not a valid label according to the Bidi Rule. -func DirectionString(s string) (bidi.Direction, error) { - t := Transformer{} - if n, ok := t.advanceString(s); ok && n == len(s) { - switch t.state { - case ruleLTRFinal, ruleInitial: - return bidi.LeftToRight, nil - case ruleRTLFinal: - return bidi.RightToLeft, nil - } - } - return bidi.Neutral, ErrInvalid -} - -// New returns a Transformer that verifies that input adheres to the Bidi Rule. -func New() *Transformer { - return &Transformer{} -} - -// Transformer implements transform.Transform. -type Transformer struct { - state ruleState - seen uint16 -} - -// Reset implements transform.Transformer. -func (t *Transformer) Reset() { *t = Transformer{} } - -// Transform implements transform.Transformer. This Transformer has state and -// needs to be reset between uses. -func (t *Transformer) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - if len(dst) < len(src) { - src = src[:len(dst)] - atEOF = false - err = transform.ErrShortDst - } - n, err1 := t.Span(src, atEOF) - copy(dst, src[:n]) - if err == nil || err1 != nil && err1 != transform.ErrShortSrc { - err = err1 - } - return n, n, err -} - -// Span returns the first n bytes of src that conform to the Bidi rule. -func (t *Transformer) Span(src []byte, atEOF bool) (n int, err error) { - if t.state == ruleInvalid { - return 0, ErrInvalid - } - n, ok := t.advance(src) - switch { - case !ok: - err = ErrInvalid - case n < len(src): - if !atEOF { - err = transform.ErrShortSrc - break - } - err = ErrInvalid - case t.state != ruleLTRFinal && t.state != ruleRTLFinal && t.state != ruleInitial: - err = ErrInvalid - } - return n, err -} - -// Precomputing the ASCII values decreases running time for the ASCII fast path -// by about 30%. -var asciiTable [128]bidi.Properties - -func init() { - for i := range asciiTable { - p, _ := bidi.LookupRune(rune(i)) - asciiTable[i] = p - } -} - -func (t *Transformer) advance(s []byte) (n int, ok bool) { - var e bidi.Properties - var sz int - for n < len(s) { - if s[n] < utf8.RuneSelf { - e, sz = asciiTable[s[n]], 1 - } else { - e, sz = bidi.Lookup(s[n:]) - if sz <= 1 { - if sz == 1 { - return n, false // invalid UTF-8 - } - return n, true // incomplete UTF-8 encoding - } - } - // TODO: using CompactClass results in noticeable speedup. - // See unicode/bidi/prop.go:Properties.CompactClass. - c := uint16(1 << e.Class()) - t.seen |= c - if t.seen&exclusiveRTL == exclusiveRTL { - t.state = ruleInvalid - return n, false - } - switch tr := transitions[t.state]; { - case tr[0].mask&c != 0: - t.state = tr[0].next - case tr[1].mask&c != 0: - t.state = tr[1].next - default: - t.state = ruleInvalid - return n, false - } - n += sz - } - return n, true -} - -func (t *Transformer) advanceString(s string) (n int, ok bool) { - var e bidi.Properties - var sz int - for n < len(s) { - if s[n] < utf8.RuneSelf { - e, sz = asciiTable[s[n]], 1 - } else { - e, sz = bidi.LookupString(s[n:]) - if sz <= 1 { - if sz == 1 { - return n, false // invalid UTF-8 - } - return n, true // incomplete UTF-8 encoding - } - } - // TODO: using CompactClass results in noticeable speedup. - // See unicode/bidi/prop.go:Properties.CompactClass. - c := uint16(1 << e.Class()) - t.seen |= c - if t.seen&exclusiveRTL == exclusiveRTL { - t.state = ruleInvalid - return n, false - } - switch tr := transitions[t.state]; { - case tr[0].mask&c != 0: - t.state = tr[0].next - case tr[1].mask&c != 0: - t.state = tr[1].next - default: - t.state = ruleInvalid - return n, false - } - n += sz - } - return n, true -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/class.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/class.go deleted file mode 100644 index f6b5641..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/class.go +++ /dev/null @@ -1,36 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import ( - "unicode/utf8" -) - -// TODO: Add contextual character rules from Appendix A of RFC5892. - -// A class is a set of characters that match certain derived properties. The -// PRECIS framework defines two classes: The Freeform class and the Identifier -// class. The freeform class should be used for profiles where expressiveness is -// prioritized over safety such as nicknames or passwords. The identifier class -// should be used for profiles where safety is the first priority such as -// addressable network labels and usernames. -type class struct { - validFrom property -} - -// Contains satisfies the runes.Set interface and returns whether the given rune -// is a member of the class. -func (c class) Contains(r rune) bool { - b := make([]byte, 4) - n := utf8.EncodeRune(b, r) - - trieval, _ := dpTrie.lookup(b[:n]) - return c.validFrom <= property(trieval) -} - -var ( - identifier = &class{validFrom: pValid} - freeform = &class{validFrom: idDisOrFreePVal} -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/context.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/context.go deleted file mode 100644 index 2dcaf29..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/context.go +++ /dev/null @@ -1,139 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import "errors" - -// This file contains tables and code related to context rules. - -type catBitmap uint16 - -const ( - // These bits, once set depending on the current value, are never unset. - bJapanese catBitmap = 1 << iota - bArabicIndicDigit - bExtendedArabicIndicDigit - - // These bits are set on each iteration depending on the current value. - bJoinStart - bJoinMid - bJoinEnd - bVirama - bLatinSmallL - bGreek - bHebrew - - // These bits indicated which of the permanent bits need to be set at the - // end of the checks. - bMustHaveJapn - - permanent = bJapanese | bArabicIndicDigit | bExtendedArabicIndicDigit | bMustHaveJapn -) - -const finalShift = 10 - -var errContext = errors.New("precis: contextual rule violated") - -func init() { - // Programmatically set these required bits as, manually setting them seems - // too error prone. - for i, ct := range categoryTransitions { - categoryTransitions[i].keep |= permanent - categoryTransitions[i].accept |= ct.term - } -} - -var categoryTransitions = []struct { - keep catBitmap // mask selecting which bits to keep from the previous state - set catBitmap // mask for which bits to set for this transition - - // These bitmaps are used for rules that require lookahead. - // term&accept == term must be true, which is enforced programmatically. - term catBitmap // bits accepted as termination condition - accept catBitmap // bits that pass, but not sufficient as termination - - // The rule function cannot take a *context as an argument, as it would - // cause the context to escape, adding significant overhead. - rule func(beforeBits catBitmap) (doLookahead bool, err error) -}{ - joiningL: {set: bJoinStart}, - joiningD: {set: bJoinStart | bJoinEnd}, - joiningT: {keep: bJoinStart, set: bJoinMid}, - joiningR: {set: bJoinEnd}, - viramaModifier: {set: bVirama}, - viramaJoinT: {set: bVirama | bJoinMid}, - latinSmallL: {set: bLatinSmallL}, - greek: {set: bGreek}, - greekJoinT: {set: bGreek | bJoinMid}, - hebrew: {set: bHebrew}, - hebrewJoinT: {set: bHebrew | bJoinMid}, - japanese: {set: bJapanese}, - katakanaMiddleDot: {set: bMustHaveJapn}, - - zeroWidthNonJoiner: { - term: bJoinEnd, - accept: bJoinMid, - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bVirama != 0 { - return false, nil - } - if before&bJoinStart == 0 { - return false, errContext - } - return true, nil - }, - }, - zeroWidthJoiner: { - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bVirama == 0 { - err = errContext - } - return false, err - }, - }, - middleDot: { - term: bLatinSmallL, - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bLatinSmallL == 0 { - return false, errContext - } - return true, nil - }, - }, - greekLowerNumeralSign: { - set: bGreek, - term: bGreek, - rule: func(before catBitmap) (doLookAhead bool, err error) { - return true, nil - }, - }, - hebrewPreceding: { - set: bHebrew, - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bHebrew == 0 { - err = errContext - } - return false, err - }, - }, - arabicIndicDigit: { - set: bArabicIndicDigit, - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bExtendedArabicIndicDigit != 0 { - err = errContext - } - return false, err - }, - }, - extendedArabicIndicDigit: { - set: bExtendedArabicIndicDigit, - rule: func(before catBitmap) (doLookAhead bool, err error) { - if before&bArabicIndicDigit != 0 { - err = errContext - } - return false, err - }, - }, -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/doc.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/doc.go deleted file mode 100644 index aa76205..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/doc.go +++ /dev/null @@ -1,14 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package precis contains types and functions for the preparation, -// enforcement, and comparison of internationalized strings ("PRECIS") as -// defined in RFC 7564. It also contains several pre-defined profiles for -// passwords, nicknames, and usernames as defined in RFC 7613 and RFC 7700. -// -// BE ADVISED: This package is under construction and the API may change in -// backwards incompatible ways and without notice. -package precis - -//go:generate go run gen.go gen_trieval.go diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen.go deleted file mode 100644 index dba9004..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen.go +++ /dev/null @@ -1,310 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Unicode table generator. -// Data read from the web. - -// +build ignore - -package main - -import ( - "flag" - "log" - "unicode" - "unicode/utf8" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/triegen" - "golang.org/x/text/internal/ucd" - "golang.org/x/text/unicode/norm" - "golang.org/x/text/unicode/rangetable" -) - -var outputFile = flag.String("output", "tables.go", "output file for generated tables; default tables.go") - -var assigned, disallowedRunes *unicode.RangeTable - -var runeCategory = map[rune]category{} - -var overrides = map[category]category{ - viramaModifier: viramaJoinT, - greek: greekJoinT, - hebrew: hebrewJoinT, -} - -func setCategory(r rune, cat category) { - if c, ok := runeCategory[r]; ok { - if override, ok := overrides[c]; cat == joiningT && ok { - cat = override - } else { - log.Fatalf("%U: multiple categories for rune (%v and %v)", r, c, cat) - } - } - runeCategory[r] = cat -} - -func init() { - if numCategories > 1<<propShift { - log.Fatalf("Number of categories is %d; may at most be %d", numCategories, 1<<propShift) - } -} - -func main() { - gen.Init() - - // Load data - runes := []rune{} - // PrecisIgnorableProperties: https://tools.ietf.org/html/rfc7564#section-9.13 - ucd.Parse(gen.OpenUCDFile("DerivedCoreProperties.txt"), func(p *ucd.Parser) { - if p.String(1) == "Default_Ignorable_Code_Point" { - runes = append(runes, p.Rune(0)) - } - }) - ucd.Parse(gen.OpenUCDFile("PropList.txt"), func(p *ucd.Parser) { - switch p.String(1) { - case "Noncharacter_Code_Point": - runes = append(runes, p.Rune(0)) - } - }) - // OldHangulJamo: https://tools.ietf.org/html/rfc5892#section-2.9 - ucd.Parse(gen.OpenUCDFile("HangulSyllableType.txt"), func(p *ucd.Parser) { - switch p.String(1) { - case "L", "V", "T": - runes = append(runes, p.Rune(0)) - } - }) - - disallowedRunes = rangetable.New(runes...) - assigned = rangetable.Assigned(unicode.Version) - - // Load category data. - runeCategory['l'] = latinSmallL - ucd.Parse(gen.OpenUCDFile("UnicodeData.txt"), func(p *ucd.Parser) { - const cccVirama = 9 - if p.Int(ucd.CanonicalCombiningClass) == cccVirama { - setCategory(p.Rune(0), viramaModifier) - } - }) - ucd.Parse(gen.OpenUCDFile("Scripts.txt"), func(p *ucd.Parser) { - switch p.String(1) { - case "Greek": - setCategory(p.Rune(0), greek) - case "Hebrew": - setCategory(p.Rune(0), hebrew) - case "Hiragana", "Katakana", "Han": - setCategory(p.Rune(0), japanese) - } - }) - - // Set the rule categories associated with exceptions. This overrides any - // previously set categories. The original categories are manually - // reintroduced in the categoryTransitions table. - for r, e := range exceptions { - if e.cat != 0 { - runeCategory[r] = e.cat - } - } - cat := map[string]category{ - "L": joiningL, - "D": joiningD, - "T": joiningT, - - "R": joiningR, - } - ucd.Parse(gen.OpenUCDFile("extracted/DerivedJoiningType.txt"), func(p *ucd.Parser) { - switch v := p.String(1); v { - case "L", "D", "T", "R": - setCategory(p.Rune(0), cat[v]) - } - }) - - writeTables() - gen.Repackage("gen_trieval.go", "trieval.go", "precis") -} - -type exception struct { - prop property - cat category -} - -func init() { - // Programmatically add the Arabic and Indic digits to the exceptions map. - // See comment in the exceptions map below why these are marked disallowed. - for i := rune(0); i <= 9; i++ { - exceptions[0x0660+i] = exception{ - prop: disallowed, - cat: arabicIndicDigit, - } - exceptions[0x06F0+i] = exception{ - prop: disallowed, - cat: extendedArabicIndicDigit, - } - } -} - -// The Exceptions class as defined in RFC 5892 -// https://tools.ietf.org/html/rfc5892#section-2.6 -var exceptions = map[rune]exception{ - 0x00DF: {prop: pValid}, - 0x03C2: {prop: pValid}, - 0x06FD: {prop: pValid}, - 0x06FE: {prop: pValid}, - 0x0F0B: {prop: pValid}, - 0x3007: {prop: pValid}, - - // ContextO|J rules are marked as disallowed, taking a "guilty until proven - // innocent" approach. The main reason for this is that the check for - // whether a context rule should be applied can be moved to the logic for - // handing disallowed runes, taken it off the common path. The exception to - // this rule is for katakanaMiddleDot, as the rule logic is handled without - // using a rule function. - - // ContextJ (Join control) - 0x200C: {prop: disallowed, cat: zeroWidthNonJoiner}, - 0x200D: {prop: disallowed, cat: zeroWidthJoiner}, - - // ContextO - 0x00B7: {prop: disallowed, cat: middleDot}, - 0x0375: {prop: disallowed, cat: greekLowerNumeralSign}, - 0x05F3: {prop: disallowed, cat: hebrewPreceding}, // punctuation Geresh - 0x05F4: {prop: disallowed, cat: hebrewPreceding}, // punctuation Gershayim - 0x30FB: {prop: pValid, cat: katakanaMiddleDot}, - - // These are officially ContextO, but the implementation does not require - // special treatment of these, so we simply mark them as valid. - 0x0660: {prop: pValid}, - 0x0661: {prop: pValid}, - 0x0662: {prop: pValid}, - 0x0663: {prop: pValid}, - 0x0664: {prop: pValid}, - 0x0665: {prop: pValid}, - 0x0666: {prop: pValid}, - 0x0667: {prop: pValid}, - 0x0668: {prop: pValid}, - 0x0669: {prop: pValid}, - 0x06F0: {prop: pValid}, - 0x06F1: {prop: pValid}, - 0x06F2: {prop: pValid}, - 0x06F3: {prop: pValid}, - 0x06F4: {prop: pValid}, - 0x06F5: {prop: pValid}, - 0x06F6: {prop: pValid}, - 0x06F7: {prop: pValid}, - 0x06F8: {prop: pValid}, - 0x06F9: {prop: pValid}, - - 0x0640: {prop: disallowed}, - 0x07FA: {prop: disallowed}, - 0x302E: {prop: disallowed}, - 0x302F: {prop: disallowed}, - 0x3031: {prop: disallowed}, - 0x3032: {prop: disallowed}, - 0x3033: {prop: disallowed}, - 0x3034: {prop: disallowed}, - 0x3035: {prop: disallowed}, - 0x303B: {prop: disallowed}, -} - -// LetterDigits: https://tools.ietf.org/html/rfc5892#section-2.1 -// r in {Ll, Lu, Lo, Nd, Lm, Mn, Mc}. -func isLetterDigits(r rune) bool { - return unicode.In(r, - unicode.Ll, unicode.Lu, unicode.Lm, unicode.Lo, // Letters - unicode.Mn, unicode.Mc, // Modifiers - unicode.Nd, // Digits - ) -} - -func isIdDisAndFreePVal(r rune) bool { - return unicode.In(r, - // OtherLetterDigits: https://tools.ietf.org/html/rfc7564#section-9.18 - // r in in {Lt, Nl, No, Me} - unicode.Lt, unicode.Nl, unicode.No, // Other letters / numbers - unicode.Me, // Modifiers - - // Spaces: https://tools.ietf.org/html/rfc7564#section-9.14 - // r in in {Zs} - unicode.Zs, - - // Symbols: https://tools.ietf.org/html/rfc7564#section-9.15 - // r in {Sm, Sc, Sk, So} - unicode.Sm, unicode.Sc, unicode.Sk, unicode.So, - - // Punctuation: https://tools.ietf.org/html/rfc7564#section-9.16 - // r in {Pc, Pd, Ps, Pe, Pi, Pf, Po} - unicode.Pc, unicode.Pd, unicode.Ps, unicode.Pe, - unicode.Pi, unicode.Pf, unicode.Po, - ) -} - -// HasCompat: https://tools.ietf.org/html/rfc7564#section-9.17 -func hasCompat(r rune) bool { - return !norm.NFKC.IsNormalString(string(r)) -} - -// From https://tools.ietf.org/html/rfc5892: -// -// If .cp. .in. Exceptions Then Exceptions(cp); -// Else If .cp. .in. BackwardCompatible Then BackwardCompatible(cp); -// Else If .cp. .in. Unassigned Then UNASSIGNED; -// Else If .cp. .in. ASCII7 Then PVALID; -// Else If .cp. .in. JoinControl Then CONTEXTJ; -// Else If .cp. .in. OldHangulJamo Then DISALLOWED; -// Else If .cp. .in. PrecisIgnorableProperties Then DISALLOWED; -// Else If .cp. .in. Controls Then DISALLOWED; -// Else If .cp. .in. HasCompat Then ID_DIS or FREE_PVAL; -// Else If .cp. .in. LetterDigits Then PVALID; -// Else If .cp. .in. OtherLetterDigits Then ID_DIS or FREE_PVAL; -// Else If .cp. .in. Spaces Then ID_DIS or FREE_PVAL; -// Else If .cp. .in. Symbols Then ID_DIS or FREE_PVAL; -// Else If .cp. .in. Punctuation Then ID_DIS or FREE_PVAL; -// Else DISALLOWED; - -func writeTables() { - propTrie := triegen.NewTrie("derivedProperties") - w := gen.NewCodeWriter() - defer w.WriteGoFile(*outputFile, "precis") - gen.WriteUnicodeVersion(w) - - // Iterate over all the runes... - for i := rune(0); i < unicode.MaxRune; i++ { - r := rune(i) - - if !utf8.ValidRune(r) { - continue - } - - e, ok := exceptions[i] - p := e.prop - switch { - case ok: - case !unicode.In(r, assigned): - p = unassigned - case r >= 0x0021 && r <= 0x007e: // Is ASCII 7 - p = pValid - case unicode.In(r, disallowedRunes, unicode.Cc): - p = disallowed - case hasCompat(r): - p = idDisOrFreePVal - case isLetterDigits(r): - p = pValid - case isIdDisAndFreePVal(r): - p = idDisOrFreePVal - default: - p = disallowed - } - cat := runeCategory[r] - // Don't set category for runes that are disallowed. - if p == disallowed { - cat = exceptions[r].cat - } - propTrie.Insert(r, uint64(p)|uint64(cat)) - } - sz, err := propTrie.Gen(w) - if err != nil { - log.Fatal(err) - } - w.Size += sz -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen_trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen_trieval.go deleted file mode 100644 index 308510c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/gen_trieval.go +++ /dev/null @@ -1,68 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// entry is the entry of a trie table -// 7..6 property (unassigned, disallowed, maybe, valid) -// 5..0 category -type entry uint8 - -const ( - propShift = 6 - propMask = 0xc0 - catMask = 0x3f -) - -func (e entry) property() property { return property(e & propMask) } -func (e entry) category() category { return category(e & catMask) } - -type property uint8 - -// The order of these constants matter. A Profile may consider runes to be -// allowed either from pValid or idDisOrFreePVal. -const ( - unassigned property = iota << propShift - disallowed - idDisOrFreePVal // disallowed for Identifier, pValid for FreeForm - pValid -) - -// compute permutations of all properties and specialCategories. -type category uint8 - -const ( - other category = iota - - // Special rune types - joiningL - joiningD - joiningT - joiningR - viramaModifier - viramaJoinT // Virama + JoiningT - latinSmallL // U+006c - greek - greekJoinT // Greek + JoiningT - hebrew - hebrewJoinT // Hebrew + JoiningT - japanese // hirigana, katakana, han - - // Special rune types associated with contextual rules defined in - // https://tools.ietf.org/html/rfc5892#appendix-A. - // ContextO - zeroWidthNonJoiner // rule 1 - zeroWidthJoiner // rule 2 - // ContextJ - middleDot // rule 3 - greekLowerNumeralSign // rule 4 - hebrewPreceding // rule 5 and 6 - katakanaMiddleDot // rule 7 - arabicIndicDigit // rule 8 - extendedArabicIndicDigit // rule 9 - - numCategories -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/nickname.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/nickname.go deleted file mode 100644 index cd54b9e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/nickname.go +++ /dev/null @@ -1,70 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import ( - "unicode" - "unicode/utf8" - - "golang.org/x/text/transform" -) - -type nickAdditionalMapping struct { - // TODO: This transformer needs to be stateless somehow… - notStart bool - prevSpace bool -} - -func (t *nickAdditionalMapping) Reset() { - t.prevSpace = false - t.notStart = false -} - -func (t *nickAdditionalMapping) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - // RFC 7700 §2.1. Rules - // - // 2. Additional Mapping Rule: The additional mapping rule consists of - // the following sub-rules. - // - // 1. Any instances of non-ASCII space MUST be mapped to ASCII - // space (U+0020); a non-ASCII space is any Unicode code point - // having a general category of "Zs", naturally with the - // exception of U+0020. - // - // 2. Any instances of the ASCII space character at the beginning - // or end of a nickname MUST be removed (e.g., "stpeter " is - // mapped to "stpeter"). - // - // 3. Interior sequences of more than one ASCII space character - // MUST be mapped to a single ASCII space character (e.g., - // "St Peter" is mapped to "St Peter"). - - for nSrc < len(src) { - r, size := utf8.DecodeRune(src[nSrc:]) - if size == 0 { // Incomplete UTF-8 encoding - if !atEOF { - return nDst, nSrc, transform.ErrShortSrc - } - size = 1 - } - if unicode.Is(unicode.Zs, r) { - t.prevSpace = true - } else { - if t.prevSpace && t.notStart { - dst[nDst] = ' ' - nDst += 1 - } - if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { - nDst += size - return nDst, nSrc, transform.ErrShortDst - } - nDst += size - t.prevSpace = false - t.notStart = true - } - nSrc += size - } - return nDst, nSrc, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/options.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/options.go deleted file mode 100644 index ec63783..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/options.go +++ /dev/null @@ -1,106 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import ( - "golang.org/x/text/cases" - "golang.org/x/text/runes" - "golang.org/x/text/transform" - "golang.org/x/text/unicode/norm" - "golang.org/x/text/width" -) - -// An Option is used to define the behavior and rules of a Profile. -type Option func(*options) - -type options struct { - // Preparation options - foldWidth bool - - // Enforcement options - cases transform.Transformer - disallow runes.Set - norm norm.Form - additional []func() transform.Transformer - width *width.Transformer - disallowEmpty bool - bidiRule bool - - // Comparison options - ignorecase bool -} - -func getOpts(o ...Option) (res options) { - for _, f := range o { - f(&res) - } - return -} - -var ( - // The IgnoreCase option causes the profile to perform a case insensitive - // comparison during the PRECIS comparison step. - IgnoreCase Option = ignoreCase - - // The FoldWidth option causes the profile to map non-canonical wide and - // narrow variants to their decomposition mapping. This is useful for - // profiles that are based on the identifier class which would otherwise - // disallow such characters. - FoldWidth Option = foldWidth - - // The DisallowEmpty option causes the enforcement step to return an error if - // the resulting string would be empty. - DisallowEmpty Option = disallowEmpty - - // The BidiRule option causes the Bidi Rule defined in RFC 5893 to be - // applied. - BidiRule Option = bidiRule -) - -var ( - ignoreCase = func(o *options) { - o.ignorecase = true - } - foldWidth = func(o *options) { - o.foldWidth = true - } - disallowEmpty = func(o *options) { - o.disallowEmpty = true - } - bidiRule = func(o *options) { - o.bidiRule = true - } -) - -// The AdditionalMapping option defines the additional mapping rule for the -// Profile by applying Transformer's in sequence. -func AdditionalMapping(t ...func() transform.Transformer) Option { - return func(o *options) { - o.additional = t - } -} - -// The Norm option defines a Profile's normalization rule. Defaults to NFC. -func Norm(f norm.Form) Option { - return func(o *options) { - o.norm = f - } -} - -// The FoldCase option defines a Profile's case mapping rule. Options can be -// provided to determine the type of case folding used. -func FoldCase(opts ...cases.Option) Option { - return func(o *options) { - o.cases = cases.Fold(opts...) - } -} - -// The Disallow option further restricts a Profile's allowed characters beyond -// what is disallowed by the underlying string class. -func Disallow(set runes.Set) Option { - return func(o *options) { - o.disallow = set - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profile.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profile.go deleted file mode 100644 index fd5c422..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profile.go +++ /dev/null @@ -1,330 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import ( - "errors" - "unicode/utf8" - - "golang.org/x/text/runes" - "golang.org/x/text/secure/bidirule" - "golang.org/x/text/transform" - "golang.org/x/text/width" -) - -var ( - errDisallowedRune = errors.New("precis: disallowed rune encountered") -) - -var dpTrie = newDerivedPropertiesTrie(0) - -// A Profile represents a set of rules for normalizing and validating strings in -// the PRECIS framework. -type Profile struct { - options - class *class -} - -// NewIdentifier creates a new PRECIS profile based on the Identifier string -// class. Profiles created from this class are suitable for use where safety is -// prioritized over expressiveness like network identifiers, user accounts, chat -// rooms, and file names. -func NewIdentifier(opts ...Option) *Profile { - return &Profile{ - options: getOpts(opts...), - class: identifier, - } -} - -// NewFreeform creates a new PRECIS profile based on the Freeform string class. -// Profiles created from this class are suitable for use where expressiveness is -// prioritized over safety like passwords, and display-elements such as -// nicknames in a chat room. -func NewFreeform(opts ...Option) *Profile { - return &Profile{ - options: getOpts(opts...), - class: freeform, - } -} - -// NewTransformer creates a new transform.Transformer that performs the PRECIS -// preparation and enforcement steps on the given UTF-8 encoded bytes. -func (p *Profile) NewTransformer() *Transformer { - var ts []transform.Transformer - - // These transforms are applied in the order defined in - // https://tools.ietf.org/html/rfc7564#section-7 - - if p.options.foldWidth { - ts = append(ts, width.Fold) - } - - for _, f := range p.options.additional { - ts = append(ts, f()) - } - - if p.options.cases != nil { - ts = append(ts, p.options.cases) - } - - ts = append(ts, p.options.norm) - - if p.options.bidiRule { - ts = append(ts, bidirule.New()) - } - - ts = append(ts, &checker{p: p, allowed: p.Allowed()}) - - // TODO: Add the disallow empty rule with a dummy transformer? - - return &Transformer{transform.Chain(ts...)} -} - -var errEmptyString = errors.New("precis: transformation resulted in empty string") - -type buffers struct { - src []byte - buf [2][]byte - next int -} - -func (b *buffers) init(n int) { - b.buf[0] = make([]byte, 0, n) - b.buf[1] = make([]byte, 0, n) -} - -func (b *buffers) apply(t transform.Transformer) (err error) { - // TODO: use Span, once available. - x := b.next & 1 - b.src, _, err = transform.Append(t, b.buf[x][:0], b.src) - b.buf[x] = b.src - b.next++ - return err -} - -func (b *buffers) enforce(p *Profile, src []byte) (str []byte, err error) { - b.src = src - - // These transforms are applied in the order defined in - // https://tools.ietf.org/html/rfc7564#section-7 - - // TODO: allow different width transforms options. - if p.options.foldWidth { - // TODO: use Span, once available. - if err = b.apply(width.Fold); err != nil { - return nil, err - } - } - for _, f := range p.options.additional { - if err = b.apply(f()); err != nil { - return nil, err - } - } - if p.options.cases != nil { - if err = b.apply(p.options.cases); err != nil { - return nil, err - } - } - if n := p.norm.QuickSpan(b.src); n < len(b.src) { - x := b.next & 1 - n = copy(b.buf[x], b.src[:n]) - b.src, _, err = transform.Append(p.norm, b.buf[x][:n], b.src[n:]) - b.buf[x] = b.src - b.next++ - if err != nil { - return nil, err - } - } - if p.options.bidiRule { - if err := b.apply(bidirule.New()); err != nil { - return nil, err - } - } - c := checker{p: p} - if _, err := c.span(b.src, true); err != nil { - return nil, err - } - if p.disallow != nil { - for i := 0; i < len(b.src); { - r, size := utf8.DecodeRune(b.src[i:]) - if p.disallow.Contains(r) { - return nil, errDisallowedRune - } - i += size - } - } - - // TODO: Add the disallow empty rule with a dummy transformer? - - if p.options.disallowEmpty && len(b.src) == 0 { - return nil, errEmptyString - } - return b.src, nil -} - -// Append appends the result of applying p to src writing the result to dst. -// It returns an error if the input string is invalid. -func (p *Profile) Append(dst, src []byte) ([]byte, error) { - var buf buffers - buf.init(8 + len(src) + len(src)>>2) - b, err := buf.enforce(p, src) - if err != nil { - return nil, err - } - return append(dst, b...), nil -} - -// Bytes returns a new byte slice with the result of applying the profile to b. -func (p *Profile) Bytes(b []byte) ([]byte, error) { - var buf buffers - buf.init(8 + len(b) + len(b)>>2) - b, err := buf.enforce(p, b) - if err != nil { - return nil, err - } - if buf.next == 0 { - c := make([]byte, len(b)) - copy(c, b) - return c, nil - } - return b, nil -} - -// String returns a string with the result of applying the profile to s. -func (p *Profile) String(s string) (string, error) { - var buf buffers - buf.init(8 + len(s) + len(s)>>2) - b, err := buf.enforce(p, []byte(s)) - if err != nil { - return "", err - } - return string(b), nil -} - -// Compare enforces both strings, and then compares them for bit-string identity -// (byte-for-byte equality). If either string cannot be enforced, the comparison -// is false. -func (p *Profile) Compare(a, b string) bool { - a, err := p.String(a) - if err != nil { - return false - } - b, err = p.String(b) - if err != nil { - return false - } - - // TODO: This is out of order. Need to extract the transformation logic and - // put this in where the normal case folding would go (but only for - // comparison). - if p.options.ignorecase { - a = width.Fold.String(a) - b = width.Fold.String(a) - } - - return a == b -} - -// Allowed returns a runes.Set containing every rune that is a member of the -// underlying profile's string class and not disallowed by any profile specific -// rules. -func (p *Profile) Allowed() runes.Set { - if p.options.disallow != nil { - return runes.Predicate(func(r rune) bool { - return p.class.Contains(r) && !p.options.disallow.Contains(r) - }) - } - return p.class -} - -type checker struct { - p *Profile - allowed runes.Set - - beforeBits catBitmap - termBits catBitmap - acceptBits catBitmap -} - -func (c *checker) Reset() { - c.beforeBits = 0 - c.termBits = 0 - c.acceptBits = 0 -} - -func (c *checker) span(src []byte, atEOF bool) (n int, err error) { - for n < len(src) { - e, sz := dpTrie.lookup(src[n:]) - d := categoryTransitions[category(e&catMask)] - if sz == 0 { - if !atEOF { - return n, transform.ErrShortSrc - } - return n, errDisallowedRune - } - if property(e) < c.p.class.validFrom { - if d.rule == nil { - return n, errDisallowedRune - } - doLookAhead, err := d.rule(c.beforeBits) - if err != nil { - return n, err - } - if doLookAhead { - c.beforeBits &= d.keep - c.beforeBits |= d.set - // We may still have a lookahead rule which we will require to - // complete (by checking termBits == 0) before setting the new - // bits. - if c.termBits != 0 && (!c.checkLookahead() || c.termBits == 0) { - return n, err - } - c.termBits = d.term - c.acceptBits = d.accept - n += sz - continue - } - } - c.beforeBits &= d.keep - c.beforeBits |= d.set - if c.termBits != 0 && !c.checkLookahead() { - return n, errContext - } - n += sz - } - if m := c.beforeBits >> finalShift; c.beforeBits&m != m || c.termBits != 0 { - err = errContext - } - return n, err -} - -func (c *checker) checkLookahead() bool { - switch { - case c.beforeBits&c.termBits != 0: - c.termBits = 0 - c.acceptBits = 0 - case c.beforeBits&c.acceptBits != 0: - default: - return false - } - return true -} - -// TODO: we may get rid of this transform if transform.Chain understands -// something like a Spanner interface. -func (c checker) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - short := false - if len(dst) < len(src) { - src = src[:len(dst)] - atEOF = false - short = true - } - nSrc, err = c.span(src, atEOF) - nDst = copy(dst, src[:nSrc]) - if short && (err == transform.ErrShortSrc || err == nil) { - err = transform.ErrShortDst - } - return nDst, nSrc, err -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profiles.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profiles.go deleted file mode 100644 index ad50ae8..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/profiles.go +++ /dev/null @@ -1,56 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import ( - "unicode" - - "golang.org/x/text/runes" - "golang.org/x/text/transform" - "golang.org/x/text/unicode/norm" -) - -var ( - Nickname *Profile = nickname // Implements the Nickname profile specified in RFC 7700. - UsernameCaseMapped *Profile = usernameCaseMap // Implements the UsernameCaseMapped profile specified in RFC 7613. - UsernameCasePreserved *Profile = usernameNoCaseMap // Implements the UsernameCasePreserved profile specified in RFC 7613. - OpaqueString *Profile = opaquestring // Implements the OpaqueString profile defined in RFC 7613 for passwords and other secure labels. -) - -// TODO: mvl: "Ultimately, I would manually define the structs for the internal -// profiles. This avoid pulling in unneeded tables when they are not used." -var ( - nickname = NewFreeform( - AdditionalMapping(func() transform.Transformer { - return &nickAdditionalMapping{} - }), - IgnoreCase, - Norm(norm.NFKC), - DisallowEmpty, - ) - usernameCaseMap = NewIdentifier( - FoldWidth, - FoldCase(), - Norm(norm.NFC), - BidiRule, - ) - usernameNoCaseMap = NewIdentifier( - FoldWidth, - Norm(norm.NFC), - BidiRule, - ) - opaquestring = NewFreeform( - AdditionalMapping(func() transform.Transformer { - return runes.Map(func(r rune) rune { - if unicode.Is(unicode.Zs, r) { - return ' ' - } - return r - }) - }), - Norm(norm.NFC), - DisallowEmpty, - ) -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/tables.go deleted file mode 100644 index a9b500d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/tables.go +++ /dev/null @@ -1,3788 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package precis - -// UnicodeVersion is the Unicode version from which the tables in this package are derived. -const UnicodeVersion = "9.0.0" - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *derivedPropertiesTrie) lookup(s []byte) (v uint8, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return derivedPropertiesValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = derivedPropertiesIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = derivedPropertiesIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = derivedPropertiesIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *derivedPropertiesTrie) lookupUnsafe(s []byte) uint8 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return derivedPropertiesValues[c0] - } - i := derivedPropertiesIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = derivedPropertiesIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = derivedPropertiesIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *derivedPropertiesTrie) lookupString(s string) (v uint8, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return derivedPropertiesValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = derivedPropertiesIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := derivedPropertiesIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = derivedPropertiesIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = derivedPropertiesIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *derivedPropertiesTrie) lookupStringUnsafe(s string) uint8 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return derivedPropertiesValues[c0] - } - i := derivedPropertiesIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = derivedPropertiesIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = derivedPropertiesIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// derivedPropertiesTrie. Total size: 25344 bytes (24.75 KiB). Checksum: c5b977d76d42d8a. -type derivedPropertiesTrie struct{} - -func newDerivedPropertiesTrie(i int) *derivedPropertiesTrie { - return &derivedPropertiesTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *derivedPropertiesTrie) lookupValue(n uint32, b byte) uint8 { - switch { - default: - return uint8(derivedPropertiesValues[n<<6+uint32(b)]) - } -} - -// derivedPropertiesValues: 324 blocks, 20736 entries, 20736 bytes -// The third block is the zero block. -var derivedPropertiesValues = [20736]uint8{ - // Block 0x0, offset 0x0 - 0x00: 0x0040, 0x01: 0x0040, 0x02: 0x0040, 0x03: 0x0040, 0x04: 0x0040, 0x05: 0x0040, - 0x06: 0x0040, 0x07: 0x0040, 0x08: 0x0040, 0x09: 0x0040, 0x0a: 0x0040, 0x0b: 0x0040, - 0x0c: 0x0040, 0x0d: 0x0040, 0x0e: 0x0040, 0x0f: 0x0040, 0x10: 0x0040, 0x11: 0x0040, - 0x12: 0x0040, 0x13: 0x0040, 0x14: 0x0040, 0x15: 0x0040, 0x16: 0x0040, 0x17: 0x0040, - 0x18: 0x0040, 0x19: 0x0040, 0x1a: 0x0040, 0x1b: 0x0040, 0x1c: 0x0040, 0x1d: 0x0040, - 0x1e: 0x0040, 0x1f: 0x0040, 0x20: 0x0080, 0x21: 0x00c0, 0x22: 0x00c0, 0x23: 0x00c0, - 0x24: 0x00c0, 0x25: 0x00c0, 0x26: 0x00c0, 0x27: 0x00c0, 0x28: 0x00c0, 0x29: 0x00c0, - 0x2a: 0x00c0, 0x2b: 0x00c0, 0x2c: 0x00c0, 0x2d: 0x00c0, 0x2e: 0x00c0, 0x2f: 0x00c0, - 0x30: 0x00c0, 0x31: 0x00c0, 0x32: 0x00c0, 0x33: 0x00c0, 0x34: 0x00c0, 0x35: 0x00c0, - 0x36: 0x00c0, 0x37: 0x00c0, 0x38: 0x00c0, 0x39: 0x00c0, 0x3a: 0x00c0, 0x3b: 0x00c0, - 0x3c: 0x00c0, 0x3d: 0x00c0, 0x3e: 0x00c0, 0x3f: 0x00c0, - // Block 0x1, offset 0x40 - 0x40: 0x00c0, 0x41: 0x00c0, 0x42: 0x00c0, 0x43: 0x00c0, 0x44: 0x00c0, 0x45: 0x00c0, - 0x46: 0x00c0, 0x47: 0x00c0, 0x48: 0x00c0, 0x49: 0x00c0, 0x4a: 0x00c0, 0x4b: 0x00c0, - 0x4c: 0x00c0, 0x4d: 0x00c0, 0x4e: 0x00c0, 0x4f: 0x00c0, 0x50: 0x00c0, 0x51: 0x00c0, - 0x52: 0x00c0, 0x53: 0x00c0, 0x54: 0x00c0, 0x55: 0x00c0, 0x56: 0x00c0, 0x57: 0x00c0, - 0x58: 0x00c0, 0x59: 0x00c0, 0x5a: 0x00c0, 0x5b: 0x00c0, 0x5c: 0x00c0, 0x5d: 0x00c0, - 0x5e: 0x00c0, 0x5f: 0x00c0, 0x60: 0x00c0, 0x61: 0x00c0, 0x62: 0x00c0, 0x63: 0x00c0, - 0x64: 0x00c0, 0x65: 0x00c0, 0x66: 0x00c0, 0x67: 0x00c0, 0x68: 0x00c0, 0x69: 0x00c0, - 0x6a: 0x00c0, 0x6b: 0x00c0, 0x6c: 0x00c7, 0x6d: 0x00c0, 0x6e: 0x00c0, 0x6f: 0x00c0, - 0x70: 0x00c0, 0x71: 0x00c0, 0x72: 0x00c0, 0x73: 0x00c0, 0x74: 0x00c0, 0x75: 0x00c0, - 0x76: 0x00c0, 0x77: 0x00c0, 0x78: 0x00c0, 0x79: 0x00c0, 0x7a: 0x00c0, 0x7b: 0x00c0, - 0x7c: 0x00c0, 0x7d: 0x00c0, 0x7e: 0x00c0, 0x7f: 0x0040, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc0: 0x0040, 0xc1: 0x0040, 0xc2: 0x0040, 0xc3: 0x0040, 0xc4: 0x0040, 0xc5: 0x0040, - 0xc6: 0x0040, 0xc7: 0x0040, 0xc8: 0x0040, 0xc9: 0x0040, 0xca: 0x0040, 0xcb: 0x0040, - 0xcc: 0x0040, 0xcd: 0x0040, 0xce: 0x0040, 0xcf: 0x0040, 0xd0: 0x0040, 0xd1: 0x0040, - 0xd2: 0x0040, 0xd3: 0x0040, 0xd4: 0x0040, 0xd5: 0x0040, 0xd6: 0x0040, 0xd7: 0x0040, - 0xd8: 0x0040, 0xd9: 0x0040, 0xda: 0x0040, 0xdb: 0x0040, 0xdc: 0x0040, 0xdd: 0x0040, - 0xde: 0x0040, 0xdf: 0x0040, 0xe0: 0x0080, 0xe1: 0x0080, 0xe2: 0x0080, 0xe3: 0x0080, - 0xe4: 0x0080, 0xe5: 0x0080, 0xe6: 0x0080, 0xe7: 0x0080, 0xe8: 0x0080, 0xe9: 0x0080, - 0xea: 0x0080, 0xeb: 0x0080, 0xec: 0x0080, 0xed: 0x0040, 0xee: 0x0080, 0xef: 0x0080, - 0xf0: 0x0080, 0xf1: 0x0080, 0xf2: 0x0080, 0xf3: 0x0080, 0xf4: 0x0080, 0xf5: 0x0080, - 0xf6: 0x0080, 0xf7: 0x004f, 0xf8: 0x0080, 0xf9: 0x0080, 0xfa: 0x0080, 0xfb: 0x0080, - 0xfc: 0x0080, 0xfd: 0x0080, 0xfe: 0x0080, 0xff: 0x0080, - // Block 0x4, offset 0x100 - 0x100: 0x00c0, 0x101: 0x00c0, 0x102: 0x00c0, 0x103: 0x00c0, 0x104: 0x00c0, 0x105: 0x00c0, - 0x106: 0x00c0, 0x107: 0x00c0, 0x108: 0x00c0, 0x109: 0x00c0, 0x10a: 0x00c0, 0x10b: 0x00c0, - 0x10c: 0x00c0, 0x10d: 0x00c0, 0x10e: 0x00c0, 0x10f: 0x00c0, 0x110: 0x00c0, 0x111: 0x00c0, - 0x112: 0x00c0, 0x113: 0x00c0, 0x114: 0x00c0, 0x115: 0x00c0, 0x116: 0x00c0, 0x117: 0x0080, - 0x118: 0x00c0, 0x119: 0x00c0, 0x11a: 0x00c0, 0x11b: 0x00c0, 0x11c: 0x00c0, 0x11d: 0x00c0, - 0x11e: 0x00c0, 0x11f: 0x00c0, 0x120: 0x00c0, 0x121: 0x00c0, 0x122: 0x00c0, 0x123: 0x00c0, - 0x124: 0x00c0, 0x125: 0x00c0, 0x126: 0x00c0, 0x127: 0x00c0, 0x128: 0x00c0, 0x129: 0x00c0, - 0x12a: 0x00c0, 0x12b: 0x00c0, 0x12c: 0x00c0, 0x12d: 0x00c0, 0x12e: 0x00c0, 0x12f: 0x00c0, - 0x130: 0x00c0, 0x131: 0x00c0, 0x132: 0x00c0, 0x133: 0x00c0, 0x134: 0x00c0, 0x135: 0x00c0, - 0x136: 0x00c0, 0x137: 0x0080, 0x138: 0x00c0, 0x139: 0x00c0, 0x13a: 0x00c0, 0x13b: 0x00c0, - 0x13c: 0x00c0, 0x13d: 0x00c0, 0x13e: 0x00c0, 0x13f: 0x00c0, - // Block 0x5, offset 0x140 - 0x140: 0x00c0, 0x141: 0x00c0, 0x142: 0x00c0, 0x143: 0x00c0, 0x144: 0x00c0, 0x145: 0x00c0, - 0x146: 0x00c0, 0x147: 0x00c0, 0x148: 0x00c0, 0x149: 0x00c0, 0x14a: 0x00c0, 0x14b: 0x00c0, - 0x14c: 0x00c0, 0x14d: 0x00c0, 0x14e: 0x00c0, 0x14f: 0x00c0, 0x150: 0x00c0, 0x151: 0x00c0, - 0x152: 0x00c0, 0x153: 0x00c0, 0x154: 0x00c0, 0x155: 0x00c0, 0x156: 0x00c0, 0x157: 0x00c0, - 0x158: 0x00c0, 0x159: 0x00c0, 0x15a: 0x00c0, 0x15b: 0x00c0, 0x15c: 0x00c0, 0x15d: 0x00c0, - 0x15e: 0x00c0, 0x15f: 0x00c0, 0x160: 0x00c0, 0x161: 0x00c0, 0x162: 0x00c0, 0x163: 0x00c0, - 0x164: 0x00c0, 0x165: 0x00c0, 0x166: 0x00c0, 0x167: 0x00c0, 0x168: 0x00c0, 0x169: 0x00c0, - 0x16a: 0x00c0, 0x16b: 0x00c0, 0x16c: 0x00c0, 0x16d: 0x00c0, 0x16e: 0x00c0, 0x16f: 0x00c0, - 0x170: 0x00c0, 0x171: 0x00c0, 0x172: 0x0080, 0x173: 0x0080, 0x174: 0x00c0, 0x175: 0x00c0, - 0x176: 0x00c0, 0x177: 0x00c0, 0x178: 0x00c0, 0x179: 0x00c0, 0x17a: 0x00c0, 0x17b: 0x00c0, - 0x17c: 0x00c0, 0x17d: 0x00c0, 0x17e: 0x00c0, 0x17f: 0x0080, - // Block 0x6, offset 0x180 - 0x180: 0x0080, 0x181: 0x00c0, 0x182: 0x00c0, 0x183: 0x00c0, 0x184: 0x00c0, 0x185: 0x00c0, - 0x186: 0x00c0, 0x187: 0x00c0, 0x188: 0x00c0, 0x189: 0x0080, 0x18a: 0x00c0, 0x18b: 0x00c0, - 0x18c: 0x00c0, 0x18d: 0x00c0, 0x18e: 0x00c0, 0x18f: 0x00c0, 0x190: 0x00c0, 0x191: 0x00c0, - 0x192: 0x00c0, 0x193: 0x00c0, 0x194: 0x00c0, 0x195: 0x00c0, 0x196: 0x00c0, 0x197: 0x00c0, - 0x198: 0x00c0, 0x199: 0x00c0, 0x19a: 0x00c0, 0x19b: 0x00c0, 0x19c: 0x00c0, 0x19d: 0x00c0, - 0x19e: 0x00c0, 0x19f: 0x00c0, 0x1a0: 0x00c0, 0x1a1: 0x00c0, 0x1a2: 0x00c0, 0x1a3: 0x00c0, - 0x1a4: 0x00c0, 0x1a5: 0x00c0, 0x1a6: 0x00c0, 0x1a7: 0x00c0, 0x1a8: 0x00c0, 0x1a9: 0x00c0, - 0x1aa: 0x00c0, 0x1ab: 0x00c0, 0x1ac: 0x00c0, 0x1ad: 0x00c0, 0x1ae: 0x00c0, 0x1af: 0x00c0, - 0x1b0: 0x00c0, 0x1b1: 0x00c0, 0x1b2: 0x00c0, 0x1b3: 0x00c0, 0x1b4: 0x00c0, 0x1b5: 0x00c0, - 0x1b6: 0x00c0, 0x1b7: 0x00c0, 0x1b8: 0x00c0, 0x1b9: 0x00c0, 0x1ba: 0x00c0, 0x1bb: 0x00c0, - 0x1bc: 0x00c0, 0x1bd: 0x00c0, 0x1be: 0x00c0, 0x1bf: 0x0080, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x00c0, 0x1c1: 0x00c0, 0x1c2: 0x00c0, 0x1c3: 0x00c0, 0x1c4: 0x00c0, 0x1c5: 0x00c0, - 0x1c6: 0x00c0, 0x1c7: 0x00c0, 0x1c8: 0x00c0, 0x1c9: 0x00c0, 0x1ca: 0x00c0, 0x1cb: 0x00c0, - 0x1cc: 0x00c0, 0x1cd: 0x00c0, 0x1ce: 0x00c0, 0x1cf: 0x00c0, 0x1d0: 0x00c0, 0x1d1: 0x00c0, - 0x1d2: 0x00c0, 0x1d3: 0x00c0, 0x1d4: 0x00c0, 0x1d5: 0x00c0, 0x1d6: 0x00c0, 0x1d7: 0x00c0, - 0x1d8: 0x00c0, 0x1d9: 0x00c0, 0x1da: 0x00c0, 0x1db: 0x00c0, 0x1dc: 0x00c0, 0x1dd: 0x00c0, - 0x1de: 0x00c0, 0x1df: 0x00c0, 0x1e0: 0x00c0, 0x1e1: 0x00c0, 0x1e2: 0x00c0, 0x1e3: 0x00c0, - 0x1e4: 0x00c0, 0x1e5: 0x00c0, 0x1e6: 0x00c0, 0x1e7: 0x00c0, 0x1e8: 0x00c0, 0x1e9: 0x00c0, - 0x1ea: 0x00c0, 0x1eb: 0x00c0, 0x1ec: 0x00c0, 0x1ed: 0x00c0, 0x1ee: 0x00c0, 0x1ef: 0x00c0, - 0x1f0: 0x00c0, 0x1f1: 0x00c0, 0x1f2: 0x00c0, 0x1f3: 0x00c0, 0x1f4: 0x00c0, 0x1f5: 0x00c0, - 0x1f6: 0x00c0, 0x1f7: 0x00c0, 0x1f8: 0x00c0, 0x1f9: 0x00c0, 0x1fa: 0x00c0, 0x1fb: 0x00c0, - 0x1fc: 0x00c0, 0x1fd: 0x00c0, 0x1fe: 0x00c0, 0x1ff: 0x00c0, - // Block 0x8, offset 0x200 - 0x200: 0x00c0, 0x201: 0x00c0, 0x202: 0x00c0, 0x203: 0x00c0, 0x204: 0x0080, 0x205: 0x0080, - 0x206: 0x0080, 0x207: 0x0080, 0x208: 0x0080, 0x209: 0x0080, 0x20a: 0x0080, 0x20b: 0x0080, - 0x20c: 0x0080, 0x20d: 0x00c0, 0x20e: 0x00c0, 0x20f: 0x00c0, 0x210: 0x00c0, 0x211: 0x00c0, - 0x212: 0x00c0, 0x213: 0x00c0, 0x214: 0x00c0, 0x215: 0x00c0, 0x216: 0x00c0, 0x217: 0x00c0, - 0x218: 0x00c0, 0x219: 0x00c0, 0x21a: 0x00c0, 0x21b: 0x00c0, 0x21c: 0x00c0, 0x21d: 0x00c0, - 0x21e: 0x00c0, 0x21f: 0x00c0, 0x220: 0x00c0, 0x221: 0x00c0, 0x222: 0x00c0, 0x223: 0x00c0, - 0x224: 0x00c0, 0x225: 0x00c0, 0x226: 0x00c0, 0x227: 0x00c0, 0x228: 0x00c0, 0x229: 0x00c0, - 0x22a: 0x00c0, 0x22b: 0x00c0, 0x22c: 0x00c0, 0x22d: 0x00c0, 0x22e: 0x00c0, 0x22f: 0x00c0, - 0x230: 0x00c0, 0x231: 0x0080, 0x232: 0x0080, 0x233: 0x0080, 0x234: 0x00c0, 0x235: 0x00c0, - 0x236: 0x00c0, 0x237: 0x00c0, 0x238: 0x00c0, 0x239: 0x00c0, 0x23a: 0x00c0, 0x23b: 0x00c0, - 0x23c: 0x00c0, 0x23d: 0x00c0, 0x23e: 0x00c0, 0x23f: 0x00c0, - // Block 0x9, offset 0x240 - 0x240: 0x00c0, 0x241: 0x00c0, 0x242: 0x00c0, 0x243: 0x00c0, 0x244: 0x00c0, 0x245: 0x00c0, - 0x246: 0x00c0, 0x247: 0x00c0, 0x248: 0x00c0, 0x249: 0x00c0, 0x24a: 0x00c0, 0x24b: 0x00c0, - 0x24c: 0x00c0, 0x24d: 0x00c0, 0x24e: 0x00c0, 0x24f: 0x00c0, 0x250: 0x00c0, 0x251: 0x00c0, - 0x252: 0x00c0, 0x253: 0x00c0, 0x254: 0x00c0, 0x255: 0x00c0, 0x256: 0x00c0, 0x257: 0x00c0, - 0x258: 0x00c0, 0x259: 0x00c0, 0x25a: 0x00c0, 0x25b: 0x00c0, 0x25c: 0x00c0, 0x25d: 0x00c0, - 0x25e: 0x00c0, 0x25f: 0x00c0, 0x260: 0x00c0, 0x261: 0x00c0, 0x262: 0x00c0, 0x263: 0x00c0, - 0x264: 0x00c0, 0x265: 0x00c0, 0x266: 0x00c0, 0x267: 0x00c0, 0x268: 0x00c0, 0x269: 0x00c0, - 0x26a: 0x00c0, 0x26b: 0x00c0, 0x26c: 0x00c0, 0x26d: 0x00c0, 0x26e: 0x00c0, 0x26f: 0x00c0, - 0x270: 0x0080, 0x271: 0x0080, 0x272: 0x0080, 0x273: 0x0080, 0x274: 0x0080, 0x275: 0x0080, - 0x276: 0x0080, 0x277: 0x0080, 0x278: 0x0080, 0x279: 0x00c0, 0x27a: 0x00c0, 0x27b: 0x00c0, - 0x27c: 0x00c0, 0x27d: 0x00c0, 0x27e: 0x00c0, 0x27f: 0x00c0, - // Block 0xa, offset 0x280 - 0x280: 0x00c0, 0x281: 0x00c0, 0x282: 0x0080, 0x283: 0x0080, 0x284: 0x0080, 0x285: 0x0080, - 0x286: 0x00c0, 0x287: 0x00c0, 0x288: 0x00c0, 0x289: 0x00c0, 0x28a: 0x00c0, 0x28b: 0x00c0, - 0x28c: 0x00c0, 0x28d: 0x00c0, 0x28e: 0x00c0, 0x28f: 0x00c0, 0x290: 0x00c0, 0x291: 0x00c0, - 0x292: 0x0080, 0x293: 0x0080, 0x294: 0x0080, 0x295: 0x0080, 0x296: 0x0080, 0x297: 0x0080, - 0x298: 0x0080, 0x299: 0x0080, 0x29a: 0x0080, 0x29b: 0x0080, 0x29c: 0x0080, 0x29d: 0x0080, - 0x29e: 0x0080, 0x29f: 0x0080, 0x2a0: 0x0080, 0x2a1: 0x0080, 0x2a2: 0x0080, 0x2a3: 0x0080, - 0x2a4: 0x0080, 0x2a5: 0x0080, 0x2a6: 0x0080, 0x2a7: 0x0080, 0x2a8: 0x0080, 0x2a9: 0x0080, - 0x2aa: 0x0080, 0x2ab: 0x0080, 0x2ac: 0x00c0, 0x2ad: 0x0080, 0x2ae: 0x00c0, 0x2af: 0x0080, - 0x2b0: 0x0080, 0x2b1: 0x0080, 0x2b2: 0x0080, 0x2b3: 0x0080, 0x2b4: 0x0080, 0x2b5: 0x0080, - 0x2b6: 0x0080, 0x2b7: 0x0080, 0x2b8: 0x0080, 0x2b9: 0x0080, 0x2ba: 0x0080, 0x2bb: 0x0080, - 0x2bc: 0x0080, 0x2bd: 0x0080, 0x2be: 0x0080, 0x2bf: 0x0080, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x00c3, 0x2c1: 0x00c3, 0x2c2: 0x00c3, 0x2c3: 0x00c3, 0x2c4: 0x00c3, 0x2c5: 0x00c3, - 0x2c6: 0x00c3, 0x2c7: 0x00c3, 0x2c8: 0x00c3, 0x2c9: 0x00c3, 0x2ca: 0x00c3, 0x2cb: 0x00c3, - 0x2cc: 0x00c3, 0x2cd: 0x00c3, 0x2ce: 0x00c3, 0x2cf: 0x00c3, 0x2d0: 0x00c3, 0x2d1: 0x00c3, - 0x2d2: 0x00c3, 0x2d3: 0x00c3, 0x2d4: 0x00c3, 0x2d5: 0x00c3, 0x2d6: 0x00c3, 0x2d7: 0x00c3, - 0x2d8: 0x00c3, 0x2d9: 0x00c3, 0x2da: 0x00c3, 0x2db: 0x00c3, 0x2dc: 0x00c3, 0x2dd: 0x00c3, - 0x2de: 0x00c3, 0x2df: 0x00c3, 0x2e0: 0x00c3, 0x2e1: 0x00c3, 0x2e2: 0x00c3, 0x2e3: 0x00c3, - 0x2e4: 0x00c3, 0x2e5: 0x00c3, 0x2e6: 0x00c3, 0x2e7: 0x00c3, 0x2e8: 0x00c3, 0x2e9: 0x00c3, - 0x2ea: 0x00c3, 0x2eb: 0x00c3, 0x2ec: 0x00c3, 0x2ed: 0x00c3, 0x2ee: 0x00c3, 0x2ef: 0x00c3, - 0x2f0: 0x00c3, 0x2f1: 0x00c3, 0x2f2: 0x00c3, 0x2f3: 0x00c3, 0x2f4: 0x00c3, 0x2f5: 0x00c3, - 0x2f6: 0x00c3, 0x2f7: 0x00c3, 0x2f8: 0x00c3, 0x2f9: 0x00c3, 0x2fa: 0x00c3, 0x2fb: 0x00c3, - 0x2fc: 0x00c3, 0x2fd: 0x00c3, 0x2fe: 0x00c3, 0x2ff: 0x00c3, - // Block 0xc, offset 0x300 - 0x300: 0x0083, 0x301: 0x0083, 0x302: 0x00c3, 0x303: 0x0083, 0x304: 0x0083, 0x305: 0x00c3, - 0x306: 0x00c3, 0x307: 0x00c3, 0x308: 0x00c3, 0x309: 0x00c3, 0x30a: 0x00c3, 0x30b: 0x00c3, - 0x30c: 0x00c3, 0x30d: 0x00c3, 0x30e: 0x00c3, 0x30f: 0x0040, 0x310: 0x00c3, 0x311: 0x00c3, - 0x312: 0x00c3, 0x313: 0x00c3, 0x314: 0x00c3, 0x315: 0x00c3, 0x316: 0x00c3, 0x317: 0x00c3, - 0x318: 0x00c3, 0x319: 0x00c3, 0x31a: 0x00c3, 0x31b: 0x00c3, 0x31c: 0x00c3, 0x31d: 0x00c3, - 0x31e: 0x00c3, 0x31f: 0x00c3, 0x320: 0x00c3, 0x321: 0x00c3, 0x322: 0x00c3, 0x323: 0x00c3, - 0x324: 0x00c3, 0x325: 0x00c3, 0x326: 0x00c3, 0x327: 0x00c3, 0x328: 0x00c3, 0x329: 0x00c3, - 0x32a: 0x00c3, 0x32b: 0x00c3, 0x32c: 0x00c3, 0x32d: 0x00c3, 0x32e: 0x00c3, 0x32f: 0x00c3, - 0x330: 0x00c8, 0x331: 0x00c8, 0x332: 0x00c8, 0x333: 0x00c8, 0x334: 0x0080, 0x335: 0x0050, - 0x336: 0x00c8, 0x337: 0x00c8, 0x33a: 0x0088, 0x33b: 0x00c8, - 0x33c: 0x00c8, 0x33d: 0x00c8, 0x33e: 0x0080, 0x33f: 0x00c8, - // Block 0xd, offset 0x340 - 0x344: 0x0088, 0x345: 0x0080, - 0x346: 0x00c8, 0x347: 0x0080, 0x348: 0x00c8, 0x349: 0x00c8, 0x34a: 0x00c8, - 0x34c: 0x00c8, 0x34e: 0x00c8, 0x34f: 0x00c8, 0x350: 0x00c8, 0x351: 0x00c8, - 0x352: 0x00c8, 0x353: 0x00c8, 0x354: 0x00c8, 0x355: 0x00c8, 0x356: 0x00c8, 0x357: 0x00c8, - 0x358: 0x00c8, 0x359: 0x00c8, 0x35a: 0x00c8, 0x35b: 0x00c8, 0x35c: 0x00c8, 0x35d: 0x00c8, - 0x35e: 0x00c8, 0x35f: 0x00c8, 0x360: 0x00c8, 0x361: 0x00c8, 0x363: 0x00c8, - 0x364: 0x00c8, 0x365: 0x00c8, 0x366: 0x00c8, 0x367: 0x00c8, 0x368: 0x00c8, 0x369: 0x00c8, - 0x36a: 0x00c8, 0x36b: 0x00c8, 0x36c: 0x00c8, 0x36d: 0x00c8, 0x36e: 0x00c8, 0x36f: 0x00c8, - 0x370: 0x00c8, 0x371: 0x00c8, 0x372: 0x00c8, 0x373: 0x00c8, 0x374: 0x00c8, 0x375: 0x00c8, - 0x376: 0x00c8, 0x377: 0x00c8, 0x378: 0x00c8, 0x379: 0x00c8, 0x37a: 0x00c8, 0x37b: 0x00c8, - 0x37c: 0x00c8, 0x37d: 0x00c8, 0x37e: 0x00c8, 0x37f: 0x00c8, - // Block 0xe, offset 0x380 - 0x380: 0x00c8, 0x381: 0x00c8, 0x382: 0x00c8, 0x383: 0x00c8, 0x384: 0x00c8, 0x385: 0x00c8, - 0x386: 0x00c8, 0x387: 0x00c8, 0x388: 0x00c8, 0x389: 0x00c8, 0x38a: 0x00c8, 0x38b: 0x00c8, - 0x38c: 0x00c8, 0x38d: 0x00c8, 0x38e: 0x00c8, 0x38f: 0x00c8, 0x390: 0x0088, 0x391: 0x0088, - 0x392: 0x0088, 0x393: 0x0088, 0x394: 0x0088, 0x395: 0x0088, 0x396: 0x0088, 0x397: 0x00c8, - 0x398: 0x00c8, 0x399: 0x00c8, 0x39a: 0x00c8, 0x39b: 0x00c8, 0x39c: 0x00c8, 0x39d: 0x00c8, - 0x39e: 0x00c8, 0x39f: 0x00c8, 0x3a0: 0x00c8, 0x3a1: 0x00c8, 0x3a2: 0x00c0, 0x3a3: 0x00c0, - 0x3a4: 0x00c0, 0x3a5: 0x00c0, 0x3a6: 0x00c0, 0x3a7: 0x00c0, 0x3a8: 0x00c0, 0x3a9: 0x00c0, - 0x3aa: 0x00c0, 0x3ab: 0x00c0, 0x3ac: 0x00c0, 0x3ad: 0x00c0, 0x3ae: 0x00c0, 0x3af: 0x00c0, - 0x3b0: 0x0088, 0x3b1: 0x0088, 0x3b2: 0x0088, 0x3b3: 0x00c8, 0x3b4: 0x0088, 0x3b5: 0x0088, - 0x3b6: 0x0088, 0x3b7: 0x00c8, 0x3b8: 0x00c8, 0x3b9: 0x0088, 0x3ba: 0x00c8, 0x3bb: 0x00c8, - 0x3bc: 0x00c8, 0x3bd: 0x00c8, 0x3be: 0x00c8, 0x3bf: 0x00c8, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x00c0, 0x3c1: 0x00c0, 0x3c2: 0x0080, 0x3c3: 0x00c3, 0x3c4: 0x00c3, 0x3c5: 0x00c3, - 0x3c6: 0x00c3, 0x3c7: 0x00c3, 0x3c8: 0x0083, 0x3c9: 0x0083, 0x3ca: 0x00c0, 0x3cb: 0x00c0, - 0x3cc: 0x00c0, 0x3cd: 0x00c0, 0x3ce: 0x00c0, 0x3cf: 0x00c0, 0x3d0: 0x00c0, 0x3d1: 0x00c0, - 0x3d2: 0x00c0, 0x3d3: 0x00c0, 0x3d4: 0x00c0, 0x3d5: 0x00c0, 0x3d6: 0x00c0, 0x3d7: 0x00c0, - 0x3d8: 0x00c0, 0x3d9: 0x00c0, 0x3da: 0x00c0, 0x3db: 0x00c0, 0x3dc: 0x00c0, 0x3dd: 0x00c0, - 0x3de: 0x00c0, 0x3df: 0x00c0, 0x3e0: 0x00c0, 0x3e1: 0x00c0, 0x3e2: 0x00c0, 0x3e3: 0x00c0, - 0x3e4: 0x00c0, 0x3e5: 0x00c0, 0x3e6: 0x00c0, 0x3e7: 0x00c0, 0x3e8: 0x00c0, 0x3e9: 0x00c0, - 0x3ea: 0x00c0, 0x3eb: 0x00c0, 0x3ec: 0x00c0, 0x3ed: 0x00c0, 0x3ee: 0x00c0, 0x3ef: 0x00c0, - 0x3f0: 0x00c0, 0x3f1: 0x00c0, 0x3f2: 0x00c0, 0x3f3: 0x00c0, 0x3f4: 0x00c0, 0x3f5: 0x00c0, - 0x3f6: 0x00c0, 0x3f7: 0x00c0, 0x3f8: 0x00c0, 0x3f9: 0x00c0, 0x3fa: 0x00c0, 0x3fb: 0x00c0, - 0x3fc: 0x00c0, 0x3fd: 0x00c0, 0x3fe: 0x00c0, 0x3ff: 0x00c0, - // Block 0x10, offset 0x400 - 0x400: 0x00c0, 0x401: 0x00c0, 0x402: 0x00c0, 0x403: 0x00c0, 0x404: 0x00c0, 0x405: 0x00c0, - 0x406: 0x00c0, 0x407: 0x00c0, 0x408: 0x00c0, 0x409: 0x00c0, 0x40a: 0x00c0, 0x40b: 0x00c0, - 0x40c: 0x00c0, 0x40d: 0x00c0, 0x40e: 0x00c0, 0x40f: 0x00c0, 0x410: 0x00c0, 0x411: 0x00c0, - 0x412: 0x00c0, 0x413: 0x00c0, 0x414: 0x00c0, 0x415: 0x00c0, 0x416: 0x00c0, 0x417: 0x00c0, - 0x418: 0x00c0, 0x419: 0x00c0, 0x41a: 0x00c0, 0x41b: 0x00c0, 0x41c: 0x00c0, 0x41d: 0x00c0, - 0x41e: 0x00c0, 0x41f: 0x00c0, 0x420: 0x00c0, 0x421: 0x00c0, 0x422: 0x00c0, 0x423: 0x00c0, - 0x424: 0x00c0, 0x425: 0x00c0, 0x426: 0x00c0, 0x427: 0x00c0, 0x428: 0x00c0, 0x429: 0x00c0, - 0x42a: 0x00c0, 0x42b: 0x00c0, 0x42c: 0x00c0, 0x42d: 0x00c0, 0x42e: 0x00c0, 0x42f: 0x00c0, - 0x431: 0x00c0, 0x432: 0x00c0, 0x433: 0x00c0, 0x434: 0x00c0, 0x435: 0x00c0, - 0x436: 0x00c0, 0x437: 0x00c0, 0x438: 0x00c0, 0x439: 0x00c0, 0x43a: 0x00c0, 0x43b: 0x00c0, - 0x43c: 0x00c0, 0x43d: 0x00c0, 0x43e: 0x00c0, 0x43f: 0x00c0, - // Block 0x11, offset 0x440 - 0x440: 0x00c0, 0x441: 0x00c0, 0x442: 0x00c0, 0x443: 0x00c0, 0x444: 0x00c0, 0x445: 0x00c0, - 0x446: 0x00c0, 0x447: 0x00c0, 0x448: 0x00c0, 0x449: 0x00c0, 0x44a: 0x00c0, 0x44b: 0x00c0, - 0x44c: 0x00c0, 0x44d: 0x00c0, 0x44e: 0x00c0, 0x44f: 0x00c0, 0x450: 0x00c0, 0x451: 0x00c0, - 0x452: 0x00c0, 0x453: 0x00c0, 0x454: 0x00c0, 0x455: 0x00c0, 0x456: 0x00c0, - 0x459: 0x00c0, 0x45a: 0x0080, 0x45b: 0x0080, 0x45c: 0x0080, 0x45d: 0x0080, - 0x45e: 0x0080, 0x45f: 0x0080, 0x461: 0x00c0, 0x462: 0x00c0, 0x463: 0x00c0, - 0x464: 0x00c0, 0x465: 0x00c0, 0x466: 0x00c0, 0x467: 0x00c0, 0x468: 0x00c0, 0x469: 0x00c0, - 0x46a: 0x00c0, 0x46b: 0x00c0, 0x46c: 0x00c0, 0x46d: 0x00c0, 0x46e: 0x00c0, 0x46f: 0x00c0, - 0x470: 0x00c0, 0x471: 0x00c0, 0x472: 0x00c0, 0x473: 0x00c0, 0x474: 0x00c0, 0x475: 0x00c0, - 0x476: 0x00c0, 0x477: 0x00c0, 0x478: 0x00c0, 0x479: 0x00c0, 0x47a: 0x00c0, 0x47b: 0x00c0, - 0x47c: 0x00c0, 0x47d: 0x00c0, 0x47e: 0x00c0, 0x47f: 0x00c0, - // Block 0x12, offset 0x480 - 0x480: 0x00c0, 0x481: 0x00c0, 0x482: 0x00c0, 0x483: 0x00c0, 0x484: 0x00c0, 0x485: 0x00c0, - 0x486: 0x00c0, 0x487: 0x0080, 0x489: 0x0080, 0x48a: 0x0080, - 0x48d: 0x0080, 0x48e: 0x0080, 0x48f: 0x0080, 0x491: 0x00cb, - 0x492: 0x00cb, 0x493: 0x00cb, 0x494: 0x00cb, 0x495: 0x00cb, 0x496: 0x00cb, 0x497: 0x00cb, - 0x498: 0x00cb, 0x499: 0x00cb, 0x49a: 0x00cb, 0x49b: 0x00cb, 0x49c: 0x00cb, 0x49d: 0x00cb, - 0x49e: 0x00cb, 0x49f: 0x00cb, 0x4a0: 0x00cb, 0x4a1: 0x00cb, 0x4a2: 0x00cb, 0x4a3: 0x00cb, - 0x4a4: 0x00cb, 0x4a5: 0x00cb, 0x4a6: 0x00cb, 0x4a7: 0x00cb, 0x4a8: 0x00cb, 0x4a9: 0x00cb, - 0x4aa: 0x00cb, 0x4ab: 0x00cb, 0x4ac: 0x00cb, 0x4ad: 0x00cb, 0x4ae: 0x00cb, 0x4af: 0x00cb, - 0x4b0: 0x00cb, 0x4b1: 0x00cb, 0x4b2: 0x00cb, 0x4b3: 0x00cb, 0x4b4: 0x00cb, 0x4b5: 0x00cb, - 0x4b6: 0x00cb, 0x4b7: 0x00cb, 0x4b8: 0x00cb, 0x4b9: 0x00cb, 0x4ba: 0x00cb, 0x4bb: 0x00cb, - 0x4bc: 0x00cb, 0x4bd: 0x00cb, 0x4be: 0x008a, 0x4bf: 0x00cb, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x008a, 0x4c1: 0x00cb, 0x4c2: 0x00cb, 0x4c3: 0x008a, 0x4c4: 0x00cb, 0x4c5: 0x00cb, - 0x4c6: 0x008a, 0x4c7: 0x00cb, - 0x4d0: 0x00ca, 0x4d1: 0x00ca, - 0x4d2: 0x00ca, 0x4d3: 0x00ca, 0x4d4: 0x00ca, 0x4d5: 0x00ca, 0x4d6: 0x00ca, 0x4d7: 0x00ca, - 0x4d8: 0x00ca, 0x4d9: 0x00ca, 0x4da: 0x00ca, 0x4db: 0x00ca, 0x4dc: 0x00ca, 0x4dd: 0x00ca, - 0x4de: 0x00ca, 0x4df: 0x00ca, 0x4e0: 0x00ca, 0x4e1: 0x00ca, 0x4e2: 0x00ca, 0x4e3: 0x00ca, - 0x4e4: 0x00ca, 0x4e5: 0x00ca, 0x4e6: 0x00ca, 0x4e7: 0x00ca, 0x4e8: 0x00ca, 0x4e9: 0x00ca, - 0x4ea: 0x00ca, - 0x4f0: 0x00ca, 0x4f1: 0x00ca, 0x4f2: 0x00ca, 0x4f3: 0x0051, 0x4f4: 0x0051, - // Block 0x14, offset 0x500 - 0x500: 0x0040, 0x501: 0x0040, 0x502: 0x0040, 0x503: 0x0040, 0x504: 0x0040, 0x505: 0x0040, - 0x506: 0x0080, 0x507: 0x0080, 0x508: 0x0080, 0x509: 0x0080, 0x50a: 0x0080, 0x50b: 0x0080, - 0x50c: 0x0080, 0x50d: 0x0080, 0x50e: 0x0080, 0x50f: 0x0080, 0x510: 0x00c3, 0x511: 0x00c3, - 0x512: 0x00c3, 0x513: 0x00c3, 0x514: 0x00c3, 0x515: 0x00c3, 0x516: 0x00c3, 0x517: 0x00c3, - 0x518: 0x00c3, 0x519: 0x00c3, 0x51a: 0x00c3, 0x51b: 0x0080, 0x51c: 0x0040, - 0x51e: 0x0080, 0x51f: 0x0080, 0x520: 0x00c2, 0x521: 0x00c0, 0x522: 0x00c4, 0x523: 0x00c4, - 0x524: 0x00c4, 0x525: 0x00c4, 0x526: 0x00c2, 0x527: 0x00c4, 0x528: 0x00c2, 0x529: 0x00c4, - 0x52a: 0x00c2, 0x52b: 0x00c2, 0x52c: 0x00c2, 0x52d: 0x00c2, 0x52e: 0x00c2, 0x52f: 0x00c4, - 0x530: 0x00c4, 0x531: 0x00c4, 0x532: 0x00c4, 0x533: 0x00c2, 0x534: 0x00c2, 0x535: 0x00c2, - 0x536: 0x00c2, 0x537: 0x00c2, 0x538: 0x00c2, 0x539: 0x00c2, 0x53a: 0x00c2, 0x53b: 0x00c2, - 0x53c: 0x00c2, 0x53d: 0x00c2, 0x53e: 0x00c2, 0x53f: 0x00c2, - // Block 0x15, offset 0x540 - 0x540: 0x0040, 0x541: 0x00c2, 0x542: 0x00c2, 0x543: 0x00c2, 0x544: 0x00c2, 0x545: 0x00c2, - 0x546: 0x00c2, 0x547: 0x00c2, 0x548: 0x00c4, 0x549: 0x00c2, 0x54a: 0x00c2, 0x54b: 0x00c3, - 0x54c: 0x00c3, 0x54d: 0x00c3, 0x54e: 0x00c3, 0x54f: 0x00c3, 0x550: 0x00c3, 0x551: 0x00c3, - 0x552: 0x00c3, 0x553: 0x00c3, 0x554: 0x00c3, 0x555: 0x00c3, 0x556: 0x00c3, 0x557: 0x00c3, - 0x558: 0x00c3, 0x559: 0x00c3, 0x55a: 0x00c3, 0x55b: 0x00c3, 0x55c: 0x00c3, 0x55d: 0x00c3, - 0x55e: 0x00c3, 0x55f: 0x00c3, 0x560: 0x0053, 0x561: 0x0053, 0x562: 0x0053, 0x563: 0x0053, - 0x564: 0x0053, 0x565: 0x0053, 0x566: 0x0053, 0x567: 0x0053, 0x568: 0x0053, 0x569: 0x0053, - 0x56a: 0x0080, 0x56b: 0x0080, 0x56c: 0x0080, 0x56d: 0x0080, 0x56e: 0x00c2, 0x56f: 0x00c2, - 0x570: 0x00c3, 0x571: 0x00c4, 0x572: 0x00c4, 0x573: 0x00c4, 0x574: 0x00c0, 0x575: 0x0084, - 0x576: 0x0084, 0x577: 0x0084, 0x578: 0x0082, 0x579: 0x00c2, 0x57a: 0x00c2, 0x57b: 0x00c2, - 0x57c: 0x00c2, 0x57d: 0x00c2, 0x57e: 0x00c2, 0x57f: 0x00c2, - // Block 0x16, offset 0x580 - 0x580: 0x00c2, 0x581: 0x00c2, 0x582: 0x00c2, 0x583: 0x00c2, 0x584: 0x00c2, 0x585: 0x00c2, - 0x586: 0x00c2, 0x587: 0x00c2, 0x588: 0x00c4, 0x589: 0x00c4, 0x58a: 0x00c4, 0x58b: 0x00c4, - 0x58c: 0x00c4, 0x58d: 0x00c4, 0x58e: 0x00c4, 0x58f: 0x00c4, 0x590: 0x00c4, 0x591: 0x00c4, - 0x592: 0x00c4, 0x593: 0x00c4, 0x594: 0x00c4, 0x595: 0x00c4, 0x596: 0x00c4, 0x597: 0x00c4, - 0x598: 0x00c4, 0x599: 0x00c4, 0x59a: 0x00c2, 0x59b: 0x00c2, 0x59c: 0x00c2, 0x59d: 0x00c2, - 0x59e: 0x00c2, 0x59f: 0x00c2, 0x5a0: 0x00c2, 0x5a1: 0x00c2, 0x5a2: 0x00c2, 0x5a3: 0x00c2, - 0x5a4: 0x00c2, 0x5a5: 0x00c2, 0x5a6: 0x00c2, 0x5a7: 0x00c2, 0x5a8: 0x00c2, 0x5a9: 0x00c2, - 0x5aa: 0x00c2, 0x5ab: 0x00c2, 0x5ac: 0x00c2, 0x5ad: 0x00c2, 0x5ae: 0x00c2, 0x5af: 0x00c2, - 0x5b0: 0x00c2, 0x5b1: 0x00c2, 0x5b2: 0x00c2, 0x5b3: 0x00c2, 0x5b4: 0x00c2, 0x5b5: 0x00c2, - 0x5b6: 0x00c2, 0x5b7: 0x00c2, 0x5b8: 0x00c2, 0x5b9: 0x00c2, 0x5ba: 0x00c2, 0x5bb: 0x00c2, - 0x5bc: 0x00c2, 0x5bd: 0x00c2, 0x5be: 0x00c2, 0x5bf: 0x00c2, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x00c4, 0x5c1: 0x00c2, 0x5c2: 0x00c2, 0x5c3: 0x00c4, 0x5c4: 0x00c4, 0x5c5: 0x00c4, - 0x5c6: 0x00c4, 0x5c7: 0x00c4, 0x5c8: 0x00c4, 0x5c9: 0x00c4, 0x5ca: 0x00c4, 0x5cb: 0x00c4, - 0x5cc: 0x00c2, 0x5cd: 0x00c4, 0x5ce: 0x00c2, 0x5cf: 0x00c4, 0x5d0: 0x00c2, 0x5d1: 0x00c2, - 0x5d2: 0x00c4, 0x5d3: 0x00c4, 0x5d4: 0x0080, 0x5d5: 0x00c4, 0x5d6: 0x00c3, 0x5d7: 0x00c3, - 0x5d8: 0x00c3, 0x5d9: 0x00c3, 0x5da: 0x00c3, 0x5db: 0x00c3, 0x5dc: 0x00c3, 0x5dd: 0x0040, - 0x5de: 0x0080, 0x5df: 0x00c3, 0x5e0: 0x00c3, 0x5e1: 0x00c3, 0x5e2: 0x00c3, 0x5e3: 0x00c3, - 0x5e4: 0x00c3, 0x5e5: 0x00c0, 0x5e6: 0x00c0, 0x5e7: 0x00c3, 0x5e8: 0x00c3, 0x5e9: 0x0080, - 0x5ea: 0x00c3, 0x5eb: 0x00c3, 0x5ec: 0x00c3, 0x5ed: 0x00c3, 0x5ee: 0x00c4, 0x5ef: 0x00c4, - 0x5f0: 0x0054, 0x5f1: 0x0054, 0x5f2: 0x0054, 0x5f3: 0x0054, 0x5f4: 0x0054, 0x5f5: 0x0054, - 0x5f6: 0x0054, 0x5f7: 0x0054, 0x5f8: 0x0054, 0x5f9: 0x0054, 0x5fa: 0x00c2, 0x5fb: 0x00c2, - 0x5fc: 0x00c2, 0x5fd: 0x00c0, 0x5fe: 0x00c0, 0x5ff: 0x00c2, - // Block 0x18, offset 0x600 - 0x600: 0x0080, 0x601: 0x0080, 0x602: 0x0080, 0x603: 0x0080, 0x604: 0x0080, 0x605: 0x0080, - 0x606: 0x0080, 0x607: 0x0080, 0x608: 0x0080, 0x609: 0x0080, 0x60a: 0x0080, 0x60b: 0x0080, - 0x60c: 0x0080, 0x60d: 0x0080, 0x60f: 0x0040, 0x610: 0x00c4, 0x611: 0x00c3, - 0x612: 0x00c2, 0x613: 0x00c2, 0x614: 0x00c2, 0x615: 0x00c4, 0x616: 0x00c4, 0x617: 0x00c4, - 0x618: 0x00c4, 0x619: 0x00c4, 0x61a: 0x00c2, 0x61b: 0x00c2, 0x61c: 0x00c2, 0x61d: 0x00c2, - 0x61e: 0x00c4, 0x61f: 0x00c2, 0x620: 0x00c2, 0x621: 0x00c2, 0x622: 0x00c2, 0x623: 0x00c2, - 0x624: 0x00c2, 0x625: 0x00c2, 0x626: 0x00c2, 0x627: 0x00c2, 0x628: 0x00c4, 0x629: 0x00c2, - 0x62a: 0x00c4, 0x62b: 0x00c2, 0x62c: 0x00c4, 0x62d: 0x00c2, 0x62e: 0x00c2, 0x62f: 0x00c4, - 0x630: 0x00c3, 0x631: 0x00c3, 0x632: 0x00c3, 0x633: 0x00c3, 0x634: 0x00c3, 0x635: 0x00c3, - 0x636: 0x00c3, 0x637: 0x00c3, 0x638: 0x00c3, 0x639: 0x00c3, 0x63a: 0x00c3, 0x63b: 0x00c3, - 0x63c: 0x00c3, 0x63d: 0x00c3, 0x63e: 0x00c3, 0x63f: 0x00c3, - // Block 0x19, offset 0x640 - 0x640: 0x00c3, 0x641: 0x00c3, 0x642: 0x00c3, 0x643: 0x00c3, 0x644: 0x00c3, 0x645: 0x00c3, - 0x646: 0x00c3, 0x647: 0x00c3, 0x648: 0x00c3, 0x649: 0x00c3, 0x64a: 0x00c3, - 0x64d: 0x00c4, 0x64e: 0x00c2, 0x64f: 0x00c2, 0x650: 0x00c2, 0x651: 0x00c2, - 0x652: 0x00c2, 0x653: 0x00c2, 0x654: 0x00c2, 0x655: 0x00c2, 0x656: 0x00c2, 0x657: 0x00c2, - 0x658: 0x00c2, 0x659: 0x00c4, 0x65a: 0x00c4, 0x65b: 0x00c4, 0x65c: 0x00c2, 0x65d: 0x00c2, - 0x65e: 0x00c2, 0x65f: 0x00c2, 0x660: 0x00c2, 0x661: 0x00c2, 0x662: 0x00c2, 0x663: 0x00c2, - 0x664: 0x00c2, 0x665: 0x00c2, 0x666: 0x00c2, 0x667: 0x00c2, 0x668: 0x00c2, 0x669: 0x00c2, - 0x66a: 0x00c2, 0x66b: 0x00c4, 0x66c: 0x00c4, 0x66d: 0x00c2, 0x66e: 0x00c2, 0x66f: 0x00c2, - 0x670: 0x00c2, 0x671: 0x00c4, 0x672: 0x00c2, 0x673: 0x00c4, 0x674: 0x00c4, 0x675: 0x00c2, - 0x676: 0x00c2, 0x677: 0x00c2, 0x678: 0x00c4, 0x679: 0x00c4, 0x67a: 0x00c2, 0x67b: 0x00c2, - 0x67c: 0x00c2, 0x67d: 0x00c2, 0x67e: 0x00c2, 0x67f: 0x00c2, - // Block 0x1a, offset 0x680 - 0x680: 0x00c0, 0x681: 0x00c0, 0x682: 0x00c0, 0x683: 0x00c0, 0x684: 0x00c0, 0x685: 0x00c0, - 0x686: 0x00c0, 0x687: 0x00c0, 0x688: 0x00c0, 0x689: 0x00c0, 0x68a: 0x00c0, 0x68b: 0x00c0, - 0x68c: 0x00c0, 0x68d: 0x00c0, 0x68e: 0x00c0, 0x68f: 0x00c0, 0x690: 0x00c0, 0x691: 0x00c0, - 0x692: 0x00c0, 0x693: 0x00c0, 0x694: 0x00c0, 0x695: 0x00c0, 0x696: 0x00c0, 0x697: 0x00c0, - 0x698: 0x00c0, 0x699: 0x00c0, 0x69a: 0x00c0, 0x69b: 0x00c0, 0x69c: 0x00c0, 0x69d: 0x00c0, - 0x69e: 0x00c0, 0x69f: 0x00c0, 0x6a0: 0x00c0, 0x6a1: 0x00c0, 0x6a2: 0x00c0, 0x6a3: 0x00c0, - 0x6a4: 0x00c0, 0x6a5: 0x00c0, 0x6a6: 0x00c3, 0x6a7: 0x00c3, 0x6a8: 0x00c3, 0x6a9: 0x00c3, - 0x6aa: 0x00c3, 0x6ab: 0x00c3, 0x6ac: 0x00c3, 0x6ad: 0x00c3, 0x6ae: 0x00c3, 0x6af: 0x00c3, - 0x6b0: 0x00c3, 0x6b1: 0x00c0, - // Block 0x1b, offset 0x6c0 - 0x6c0: 0x00c0, 0x6c1: 0x00c0, 0x6c2: 0x00c0, 0x6c3: 0x00c0, 0x6c4: 0x00c0, 0x6c5: 0x00c0, - 0x6c6: 0x00c0, 0x6c7: 0x00c0, 0x6c8: 0x00c0, 0x6c9: 0x00c0, 0x6ca: 0x00c2, 0x6cb: 0x00c2, - 0x6cc: 0x00c2, 0x6cd: 0x00c2, 0x6ce: 0x00c2, 0x6cf: 0x00c2, 0x6d0: 0x00c2, 0x6d1: 0x00c2, - 0x6d2: 0x00c2, 0x6d3: 0x00c2, 0x6d4: 0x00c2, 0x6d5: 0x00c2, 0x6d6: 0x00c2, 0x6d7: 0x00c2, - 0x6d8: 0x00c2, 0x6d9: 0x00c2, 0x6da: 0x00c2, 0x6db: 0x00c2, 0x6dc: 0x00c2, 0x6dd: 0x00c2, - 0x6de: 0x00c2, 0x6df: 0x00c2, 0x6e0: 0x00c2, 0x6e1: 0x00c2, 0x6e2: 0x00c2, 0x6e3: 0x00c2, - 0x6e4: 0x00c2, 0x6e5: 0x00c2, 0x6e6: 0x00c2, 0x6e7: 0x00c2, 0x6e8: 0x00c2, 0x6e9: 0x00c2, - 0x6ea: 0x00c2, 0x6eb: 0x00c3, 0x6ec: 0x00c3, 0x6ed: 0x00c3, 0x6ee: 0x00c3, 0x6ef: 0x00c3, - 0x6f0: 0x00c3, 0x6f1: 0x00c3, 0x6f2: 0x00c3, 0x6f3: 0x00c3, 0x6f4: 0x00c0, 0x6f5: 0x00c0, - 0x6f6: 0x0080, 0x6f7: 0x0080, 0x6f8: 0x0080, 0x6f9: 0x0080, 0x6fa: 0x0040, - // Block 0x1c, offset 0x700 - 0x700: 0x00c0, 0x701: 0x00c0, 0x702: 0x00c0, 0x703: 0x00c0, 0x704: 0x00c0, 0x705: 0x00c0, - 0x706: 0x00c0, 0x707: 0x00c0, 0x708: 0x00c0, 0x709: 0x00c0, 0x70a: 0x00c0, 0x70b: 0x00c0, - 0x70c: 0x00c0, 0x70d: 0x00c0, 0x70e: 0x00c0, 0x70f: 0x00c0, 0x710: 0x00c0, 0x711: 0x00c0, - 0x712: 0x00c0, 0x713: 0x00c0, 0x714: 0x00c0, 0x715: 0x00c0, 0x716: 0x00c3, 0x717: 0x00c3, - 0x718: 0x00c3, 0x719: 0x00c3, 0x71a: 0x00c0, 0x71b: 0x00c3, 0x71c: 0x00c3, 0x71d: 0x00c3, - 0x71e: 0x00c3, 0x71f: 0x00c3, 0x720: 0x00c3, 0x721: 0x00c3, 0x722: 0x00c3, 0x723: 0x00c3, - 0x724: 0x00c0, 0x725: 0x00c3, 0x726: 0x00c3, 0x727: 0x00c3, 0x728: 0x00c0, 0x729: 0x00c3, - 0x72a: 0x00c3, 0x72b: 0x00c3, 0x72c: 0x00c3, 0x72d: 0x00c3, - 0x730: 0x0080, 0x731: 0x0080, 0x732: 0x0080, 0x733: 0x0080, 0x734: 0x0080, 0x735: 0x0080, - 0x736: 0x0080, 0x737: 0x0080, 0x738: 0x0080, 0x739: 0x0080, 0x73a: 0x0080, 0x73b: 0x0080, - 0x73c: 0x0080, 0x73d: 0x0080, 0x73e: 0x0080, - // Block 0x1d, offset 0x740 - 0x740: 0x00c4, 0x741: 0x00c2, 0x742: 0x00c2, 0x743: 0x00c2, 0x744: 0x00c2, 0x745: 0x00c2, - 0x746: 0x00c4, 0x747: 0x00c4, 0x748: 0x00c2, 0x749: 0x00c4, 0x74a: 0x00c2, 0x74b: 0x00c2, - 0x74c: 0x00c2, 0x74d: 0x00c2, 0x74e: 0x00c2, 0x74f: 0x00c2, 0x750: 0x00c2, 0x751: 0x00c2, - 0x752: 0x00c2, 0x753: 0x00c2, 0x754: 0x00c4, 0x755: 0x00c2, 0x756: 0x00c0, 0x757: 0x00c0, - 0x758: 0x00c0, 0x759: 0x00c3, 0x75a: 0x00c3, 0x75b: 0x00c3, - 0x75e: 0x0080, - // Block 0x1e, offset 0x780 - 0x7a0: 0x00c2, 0x7a1: 0x00c2, 0x7a2: 0x00c2, 0x7a3: 0x00c2, - 0x7a4: 0x00c2, 0x7a5: 0x00c2, 0x7a6: 0x00c2, 0x7a7: 0x00c2, 0x7a8: 0x00c2, 0x7a9: 0x00c2, - 0x7aa: 0x00c4, 0x7ab: 0x00c4, 0x7ac: 0x00c4, 0x7ad: 0x00c0, 0x7ae: 0x00c4, 0x7af: 0x00c2, - 0x7b0: 0x00c2, 0x7b1: 0x00c4, 0x7b2: 0x00c4, 0x7b3: 0x00c2, 0x7b4: 0x00c2, - 0x7b6: 0x00c2, 0x7b7: 0x00c2, 0x7b8: 0x00c2, 0x7b9: 0x00c4, 0x7ba: 0x00c2, 0x7bb: 0x00c2, - 0x7bc: 0x00c2, 0x7bd: 0x00c2, - // Block 0x1f, offset 0x7c0 - 0x7d4: 0x00c3, 0x7d5: 0x00c3, 0x7d6: 0x00c3, 0x7d7: 0x00c3, - 0x7d8: 0x00c3, 0x7d9: 0x00c3, 0x7da: 0x00c3, 0x7db: 0x00c3, 0x7dc: 0x00c3, 0x7dd: 0x00c3, - 0x7de: 0x00c3, 0x7df: 0x00c3, 0x7e0: 0x00c3, 0x7e1: 0x00c3, 0x7e2: 0x0040, 0x7e3: 0x00c3, - 0x7e4: 0x00c3, 0x7e5: 0x00c3, 0x7e6: 0x00c3, 0x7e7: 0x00c3, 0x7e8: 0x00c3, 0x7e9: 0x00c3, - 0x7ea: 0x00c3, 0x7eb: 0x00c3, 0x7ec: 0x00c3, 0x7ed: 0x00c3, 0x7ee: 0x00c3, 0x7ef: 0x00c3, - 0x7f0: 0x00c3, 0x7f1: 0x00c3, 0x7f2: 0x00c3, 0x7f3: 0x00c3, 0x7f4: 0x00c3, 0x7f5: 0x00c3, - 0x7f6: 0x00c3, 0x7f7: 0x00c3, 0x7f8: 0x00c3, 0x7f9: 0x00c3, 0x7fa: 0x00c3, 0x7fb: 0x00c3, - 0x7fc: 0x00c3, 0x7fd: 0x00c3, 0x7fe: 0x00c3, 0x7ff: 0x00c3, - // Block 0x20, offset 0x800 - 0x800: 0x00c3, 0x801: 0x00c3, 0x802: 0x00c3, 0x803: 0x00c0, 0x804: 0x00c0, 0x805: 0x00c0, - 0x806: 0x00c0, 0x807: 0x00c0, 0x808: 0x00c0, 0x809: 0x00c0, 0x80a: 0x00c0, 0x80b: 0x00c0, - 0x80c: 0x00c0, 0x80d: 0x00c0, 0x80e: 0x00c0, 0x80f: 0x00c0, 0x810: 0x00c0, 0x811: 0x00c0, - 0x812: 0x00c0, 0x813: 0x00c0, 0x814: 0x00c0, 0x815: 0x00c0, 0x816: 0x00c0, 0x817: 0x00c0, - 0x818: 0x00c0, 0x819: 0x00c0, 0x81a: 0x00c0, 0x81b: 0x00c0, 0x81c: 0x00c0, 0x81d: 0x00c0, - 0x81e: 0x00c0, 0x81f: 0x00c0, 0x820: 0x00c0, 0x821: 0x00c0, 0x822: 0x00c0, 0x823: 0x00c0, - 0x824: 0x00c0, 0x825: 0x00c0, 0x826: 0x00c0, 0x827: 0x00c0, 0x828: 0x00c0, 0x829: 0x00c0, - 0x82a: 0x00c0, 0x82b: 0x00c0, 0x82c: 0x00c0, 0x82d: 0x00c0, 0x82e: 0x00c0, 0x82f: 0x00c0, - 0x830: 0x00c0, 0x831: 0x00c0, 0x832: 0x00c0, 0x833: 0x00c0, 0x834: 0x00c0, 0x835: 0x00c0, - 0x836: 0x00c0, 0x837: 0x00c0, 0x838: 0x00c0, 0x839: 0x00c0, 0x83a: 0x00c3, 0x83b: 0x00c0, - 0x83c: 0x00c3, 0x83d: 0x00c0, 0x83e: 0x00c0, 0x83f: 0x00c0, - // Block 0x21, offset 0x840 - 0x840: 0x00c0, 0x841: 0x00c3, 0x842: 0x00c3, 0x843: 0x00c3, 0x844: 0x00c3, 0x845: 0x00c3, - 0x846: 0x00c3, 0x847: 0x00c3, 0x848: 0x00c3, 0x849: 0x00c0, 0x84a: 0x00c0, 0x84b: 0x00c0, - 0x84c: 0x00c0, 0x84d: 0x00c6, 0x84e: 0x00c0, 0x84f: 0x00c0, 0x850: 0x00c0, 0x851: 0x00c3, - 0x852: 0x00c3, 0x853: 0x00c3, 0x854: 0x00c3, 0x855: 0x00c3, 0x856: 0x00c3, 0x857: 0x00c3, - 0x858: 0x0080, 0x859: 0x0080, 0x85a: 0x0080, 0x85b: 0x0080, 0x85c: 0x0080, 0x85d: 0x0080, - 0x85e: 0x0080, 0x85f: 0x0080, 0x860: 0x00c0, 0x861: 0x00c0, 0x862: 0x00c3, 0x863: 0x00c3, - 0x864: 0x0080, 0x865: 0x0080, 0x866: 0x00c0, 0x867: 0x00c0, 0x868: 0x00c0, 0x869: 0x00c0, - 0x86a: 0x00c0, 0x86b: 0x00c0, 0x86c: 0x00c0, 0x86d: 0x00c0, 0x86e: 0x00c0, 0x86f: 0x00c0, - 0x870: 0x0080, 0x871: 0x00c0, 0x872: 0x00c0, 0x873: 0x00c0, 0x874: 0x00c0, 0x875: 0x00c0, - 0x876: 0x00c0, 0x877: 0x00c0, 0x878: 0x00c0, 0x879: 0x00c0, 0x87a: 0x00c0, 0x87b: 0x00c0, - 0x87c: 0x00c0, 0x87d: 0x00c0, 0x87e: 0x00c0, 0x87f: 0x00c0, - // Block 0x22, offset 0x880 - 0x880: 0x00c0, 0x881: 0x00c3, 0x882: 0x00c0, 0x883: 0x00c0, 0x885: 0x00c0, - 0x886: 0x00c0, 0x887: 0x00c0, 0x888: 0x00c0, 0x889: 0x00c0, 0x88a: 0x00c0, 0x88b: 0x00c0, - 0x88c: 0x00c0, 0x88f: 0x00c0, 0x890: 0x00c0, - 0x893: 0x00c0, 0x894: 0x00c0, 0x895: 0x00c0, 0x896: 0x00c0, 0x897: 0x00c0, - 0x898: 0x00c0, 0x899: 0x00c0, 0x89a: 0x00c0, 0x89b: 0x00c0, 0x89c: 0x00c0, 0x89d: 0x00c0, - 0x89e: 0x00c0, 0x89f: 0x00c0, 0x8a0: 0x00c0, 0x8a1: 0x00c0, 0x8a2: 0x00c0, 0x8a3: 0x00c0, - 0x8a4: 0x00c0, 0x8a5: 0x00c0, 0x8a6: 0x00c0, 0x8a7: 0x00c0, 0x8a8: 0x00c0, - 0x8aa: 0x00c0, 0x8ab: 0x00c0, 0x8ac: 0x00c0, 0x8ad: 0x00c0, 0x8ae: 0x00c0, 0x8af: 0x00c0, - 0x8b0: 0x00c0, 0x8b2: 0x00c0, - 0x8b6: 0x00c0, 0x8b7: 0x00c0, 0x8b8: 0x00c0, 0x8b9: 0x00c0, - 0x8bc: 0x00c3, 0x8bd: 0x00c0, 0x8be: 0x00c0, 0x8bf: 0x00c0, - // Block 0x23, offset 0x8c0 - 0x8c0: 0x00c0, 0x8c1: 0x00c3, 0x8c2: 0x00c3, 0x8c3: 0x00c3, 0x8c4: 0x00c3, - 0x8c7: 0x00c0, 0x8c8: 0x00c0, 0x8cb: 0x00c0, - 0x8cc: 0x00c0, 0x8cd: 0x00c6, 0x8ce: 0x00c0, - 0x8d7: 0x00c0, - 0x8dc: 0x0080, 0x8dd: 0x0080, - 0x8df: 0x0080, 0x8e0: 0x00c0, 0x8e1: 0x00c0, 0x8e2: 0x00c3, 0x8e3: 0x00c3, - 0x8e6: 0x00c0, 0x8e7: 0x00c0, 0x8e8: 0x00c0, 0x8e9: 0x00c0, - 0x8ea: 0x00c0, 0x8eb: 0x00c0, 0x8ec: 0x00c0, 0x8ed: 0x00c0, 0x8ee: 0x00c0, 0x8ef: 0x00c0, - 0x8f0: 0x00c0, 0x8f1: 0x00c0, 0x8f2: 0x0080, 0x8f3: 0x0080, 0x8f4: 0x0080, 0x8f5: 0x0080, - 0x8f6: 0x0080, 0x8f7: 0x0080, 0x8f8: 0x0080, 0x8f9: 0x0080, 0x8fa: 0x0080, 0x8fb: 0x0080, - // Block 0x24, offset 0x900 - 0x901: 0x00c3, 0x902: 0x00c3, 0x903: 0x00c0, 0x905: 0x00c0, - 0x906: 0x00c0, 0x907: 0x00c0, 0x908: 0x00c0, 0x909: 0x00c0, 0x90a: 0x00c0, - 0x90f: 0x00c0, 0x910: 0x00c0, - 0x913: 0x00c0, 0x914: 0x00c0, 0x915: 0x00c0, 0x916: 0x00c0, 0x917: 0x00c0, - 0x918: 0x00c0, 0x919: 0x00c0, 0x91a: 0x00c0, 0x91b: 0x00c0, 0x91c: 0x00c0, 0x91d: 0x00c0, - 0x91e: 0x00c0, 0x91f: 0x00c0, 0x920: 0x00c0, 0x921: 0x00c0, 0x922: 0x00c0, 0x923: 0x00c0, - 0x924: 0x00c0, 0x925: 0x00c0, 0x926: 0x00c0, 0x927: 0x00c0, 0x928: 0x00c0, - 0x92a: 0x00c0, 0x92b: 0x00c0, 0x92c: 0x00c0, 0x92d: 0x00c0, 0x92e: 0x00c0, 0x92f: 0x00c0, - 0x930: 0x00c0, 0x932: 0x00c0, 0x933: 0x0080, 0x935: 0x00c0, - 0x936: 0x0080, 0x938: 0x00c0, 0x939: 0x00c0, - 0x93c: 0x00c3, 0x93e: 0x00c0, 0x93f: 0x00c0, - // Block 0x25, offset 0x940 - 0x940: 0x00c0, 0x941: 0x00c3, 0x942: 0x00c3, - 0x947: 0x00c3, 0x948: 0x00c3, 0x94b: 0x00c3, - 0x94c: 0x00c3, 0x94d: 0x00c6, 0x951: 0x00c3, - 0x959: 0x0080, 0x95a: 0x0080, 0x95b: 0x0080, 0x95c: 0x00c0, - 0x95e: 0x0080, - 0x966: 0x00c0, 0x967: 0x00c0, 0x968: 0x00c0, 0x969: 0x00c0, - 0x96a: 0x00c0, 0x96b: 0x00c0, 0x96c: 0x00c0, 0x96d: 0x00c0, 0x96e: 0x00c0, 0x96f: 0x00c0, - 0x970: 0x00c3, 0x971: 0x00c3, 0x972: 0x00c0, 0x973: 0x00c0, 0x974: 0x00c0, 0x975: 0x00c3, - // Block 0x26, offset 0x980 - 0x981: 0x00c3, 0x982: 0x00c3, 0x983: 0x00c0, 0x985: 0x00c0, - 0x986: 0x00c0, 0x987: 0x00c0, 0x988: 0x00c0, 0x989: 0x00c0, 0x98a: 0x00c0, 0x98b: 0x00c0, - 0x98c: 0x00c0, 0x98d: 0x00c0, 0x98f: 0x00c0, 0x990: 0x00c0, 0x991: 0x00c0, - 0x993: 0x00c0, 0x994: 0x00c0, 0x995: 0x00c0, 0x996: 0x00c0, 0x997: 0x00c0, - 0x998: 0x00c0, 0x999: 0x00c0, 0x99a: 0x00c0, 0x99b: 0x00c0, 0x99c: 0x00c0, 0x99d: 0x00c0, - 0x99e: 0x00c0, 0x99f: 0x00c0, 0x9a0: 0x00c0, 0x9a1: 0x00c0, 0x9a2: 0x00c0, 0x9a3: 0x00c0, - 0x9a4: 0x00c0, 0x9a5: 0x00c0, 0x9a6: 0x00c0, 0x9a7: 0x00c0, 0x9a8: 0x00c0, - 0x9aa: 0x00c0, 0x9ab: 0x00c0, 0x9ac: 0x00c0, 0x9ad: 0x00c0, 0x9ae: 0x00c0, 0x9af: 0x00c0, - 0x9b0: 0x00c0, 0x9b2: 0x00c0, 0x9b3: 0x00c0, 0x9b5: 0x00c0, - 0x9b6: 0x00c0, 0x9b7: 0x00c0, 0x9b8: 0x00c0, 0x9b9: 0x00c0, - 0x9bc: 0x00c3, 0x9bd: 0x00c0, 0x9be: 0x00c0, 0x9bf: 0x00c0, - // Block 0x27, offset 0x9c0 - 0x9c0: 0x00c0, 0x9c1: 0x00c3, 0x9c2: 0x00c3, 0x9c3: 0x00c3, 0x9c4: 0x00c3, 0x9c5: 0x00c3, - 0x9c7: 0x00c3, 0x9c8: 0x00c3, 0x9c9: 0x00c0, 0x9cb: 0x00c0, - 0x9cc: 0x00c0, 0x9cd: 0x00c6, 0x9d0: 0x00c0, - 0x9e0: 0x00c0, 0x9e1: 0x00c0, 0x9e2: 0x00c3, 0x9e3: 0x00c3, - 0x9e6: 0x00c0, 0x9e7: 0x00c0, 0x9e8: 0x00c0, 0x9e9: 0x00c0, - 0x9ea: 0x00c0, 0x9eb: 0x00c0, 0x9ec: 0x00c0, 0x9ed: 0x00c0, 0x9ee: 0x00c0, 0x9ef: 0x00c0, - 0x9f0: 0x0080, 0x9f1: 0x0080, - 0x9f9: 0x00c0, - // Block 0x28, offset 0xa00 - 0xa01: 0x00c3, 0xa02: 0x00c0, 0xa03: 0x00c0, 0xa05: 0x00c0, - 0xa06: 0x00c0, 0xa07: 0x00c0, 0xa08: 0x00c0, 0xa09: 0x00c0, 0xa0a: 0x00c0, 0xa0b: 0x00c0, - 0xa0c: 0x00c0, 0xa0f: 0x00c0, 0xa10: 0x00c0, - 0xa13: 0x00c0, 0xa14: 0x00c0, 0xa15: 0x00c0, 0xa16: 0x00c0, 0xa17: 0x00c0, - 0xa18: 0x00c0, 0xa19: 0x00c0, 0xa1a: 0x00c0, 0xa1b: 0x00c0, 0xa1c: 0x00c0, 0xa1d: 0x00c0, - 0xa1e: 0x00c0, 0xa1f: 0x00c0, 0xa20: 0x00c0, 0xa21: 0x00c0, 0xa22: 0x00c0, 0xa23: 0x00c0, - 0xa24: 0x00c0, 0xa25: 0x00c0, 0xa26: 0x00c0, 0xa27: 0x00c0, 0xa28: 0x00c0, - 0xa2a: 0x00c0, 0xa2b: 0x00c0, 0xa2c: 0x00c0, 0xa2d: 0x00c0, 0xa2e: 0x00c0, 0xa2f: 0x00c0, - 0xa30: 0x00c0, 0xa32: 0x00c0, 0xa33: 0x00c0, 0xa35: 0x00c0, - 0xa36: 0x00c0, 0xa37: 0x00c0, 0xa38: 0x00c0, 0xa39: 0x00c0, - 0xa3c: 0x00c3, 0xa3d: 0x00c0, 0xa3e: 0x00c0, 0xa3f: 0x00c3, - // Block 0x29, offset 0xa40 - 0xa40: 0x00c0, 0xa41: 0x00c3, 0xa42: 0x00c3, 0xa43: 0x00c3, 0xa44: 0x00c3, - 0xa47: 0x00c0, 0xa48: 0x00c0, 0xa4b: 0x00c0, - 0xa4c: 0x00c0, 0xa4d: 0x00c6, - 0xa56: 0x00c3, 0xa57: 0x00c0, - 0xa5c: 0x0080, 0xa5d: 0x0080, - 0xa5f: 0x00c0, 0xa60: 0x00c0, 0xa61: 0x00c0, 0xa62: 0x00c3, 0xa63: 0x00c3, - 0xa66: 0x00c0, 0xa67: 0x00c0, 0xa68: 0x00c0, 0xa69: 0x00c0, - 0xa6a: 0x00c0, 0xa6b: 0x00c0, 0xa6c: 0x00c0, 0xa6d: 0x00c0, 0xa6e: 0x00c0, 0xa6f: 0x00c0, - 0xa70: 0x0080, 0xa71: 0x00c0, 0xa72: 0x0080, 0xa73: 0x0080, 0xa74: 0x0080, 0xa75: 0x0080, - 0xa76: 0x0080, 0xa77: 0x0080, - // Block 0x2a, offset 0xa80 - 0xa82: 0x00c3, 0xa83: 0x00c0, 0xa85: 0x00c0, - 0xa86: 0x00c0, 0xa87: 0x00c0, 0xa88: 0x00c0, 0xa89: 0x00c0, 0xa8a: 0x00c0, - 0xa8e: 0x00c0, 0xa8f: 0x00c0, 0xa90: 0x00c0, - 0xa92: 0x00c0, 0xa93: 0x00c0, 0xa94: 0x00c0, 0xa95: 0x00c0, - 0xa99: 0x00c0, 0xa9a: 0x00c0, 0xa9c: 0x00c0, - 0xa9e: 0x00c0, 0xa9f: 0x00c0, 0xaa3: 0x00c0, - 0xaa4: 0x00c0, 0xaa8: 0x00c0, 0xaa9: 0x00c0, - 0xaaa: 0x00c0, 0xaae: 0x00c0, 0xaaf: 0x00c0, - 0xab0: 0x00c0, 0xab1: 0x00c0, 0xab2: 0x00c0, 0xab3: 0x00c0, 0xab4: 0x00c0, 0xab5: 0x00c0, - 0xab6: 0x00c0, 0xab7: 0x00c0, 0xab8: 0x00c0, 0xab9: 0x00c0, - 0xabe: 0x00c0, 0xabf: 0x00c0, - // Block 0x2b, offset 0xac0 - 0xac0: 0x00c3, 0xac1: 0x00c0, 0xac2: 0x00c0, - 0xac6: 0x00c0, 0xac7: 0x00c0, 0xac8: 0x00c0, 0xaca: 0x00c0, 0xacb: 0x00c0, - 0xacc: 0x00c0, 0xacd: 0x00c6, 0xad0: 0x00c0, - 0xad7: 0x00c0, - 0xae6: 0x00c0, 0xae7: 0x00c0, 0xae8: 0x00c0, 0xae9: 0x00c0, - 0xaea: 0x00c0, 0xaeb: 0x00c0, 0xaec: 0x00c0, 0xaed: 0x00c0, 0xaee: 0x00c0, 0xaef: 0x00c0, - 0xaf0: 0x0080, 0xaf1: 0x0080, 0xaf2: 0x0080, 0xaf3: 0x0080, 0xaf4: 0x0080, 0xaf5: 0x0080, - 0xaf6: 0x0080, 0xaf7: 0x0080, 0xaf8: 0x0080, 0xaf9: 0x0080, 0xafa: 0x0080, - // Block 0x2c, offset 0xb00 - 0xb00: 0x00c3, 0xb01: 0x00c0, 0xb02: 0x00c0, 0xb03: 0x00c0, 0xb05: 0x00c0, - 0xb06: 0x00c0, 0xb07: 0x00c0, 0xb08: 0x00c0, 0xb09: 0x00c0, 0xb0a: 0x00c0, 0xb0b: 0x00c0, - 0xb0c: 0x00c0, 0xb0e: 0x00c0, 0xb0f: 0x00c0, 0xb10: 0x00c0, - 0xb12: 0x00c0, 0xb13: 0x00c0, 0xb14: 0x00c0, 0xb15: 0x00c0, 0xb16: 0x00c0, 0xb17: 0x00c0, - 0xb18: 0x00c0, 0xb19: 0x00c0, 0xb1a: 0x00c0, 0xb1b: 0x00c0, 0xb1c: 0x00c0, 0xb1d: 0x00c0, - 0xb1e: 0x00c0, 0xb1f: 0x00c0, 0xb20: 0x00c0, 0xb21: 0x00c0, 0xb22: 0x00c0, 0xb23: 0x00c0, - 0xb24: 0x00c0, 0xb25: 0x00c0, 0xb26: 0x00c0, 0xb27: 0x00c0, 0xb28: 0x00c0, - 0xb2a: 0x00c0, 0xb2b: 0x00c0, 0xb2c: 0x00c0, 0xb2d: 0x00c0, 0xb2e: 0x00c0, 0xb2f: 0x00c0, - 0xb30: 0x00c0, 0xb31: 0x00c0, 0xb32: 0x00c0, 0xb33: 0x00c0, 0xb34: 0x00c0, 0xb35: 0x00c0, - 0xb36: 0x00c0, 0xb37: 0x00c0, 0xb38: 0x00c0, 0xb39: 0x00c0, - 0xb3d: 0x00c0, 0xb3e: 0x00c3, 0xb3f: 0x00c3, - // Block 0x2d, offset 0xb40 - 0xb40: 0x00c3, 0xb41: 0x00c0, 0xb42: 0x00c0, 0xb43: 0x00c0, 0xb44: 0x00c0, - 0xb46: 0x00c3, 0xb47: 0x00c3, 0xb48: 0x00c3, 0xb4a: 0x00c3, 0xb4b: 0x00c3, - 0xb4c: 0x00c3, 0xb4d: 0x00c6, - 0xb55: 0x00c3, 0xb56: 0x00c3, - 0xb58: 0x00c0, 0xb59: 0x00c0, 0xb5a: 0x00c0, - 0xb60: 0x00c0, 0xb61: 0x00c0, 0xb62: 0x00c3, 0xb63: 0x00c3, - 0xb66: 0x00c0, 0xb67: 0x00c0, 0xb68: 0x00c0, 0xb69: 0x00c0, - 0xb6a: 0x00c0, 0xb6b: 0x00c0, 0xb6c: 0x00c0, 0xb6d: 0x00c0, 0xb6e: 0x00c0, 0xb6f: 0x00c0, - 0xb78: 0x0080, 0xb79: 0x0080, 0xb7a: 0x0080, 0xb7b: 0x0080, - 0xb7c: 0x0080, 0xb7d: 0x0080, 0xb7e: 0x0080, 0xb7f: 0x0080, - // Block 0x2e, offset 0xb80 - 0xb80: 0x00c0, 0xb81: 0x00c3, 0xb82: 0x00c0, 0xb83: 0x00c0, 0xb85: 0x00c0, - 0xb86: 0x00c0, 0xb87: 0x00c0, 0xb88: 0x00c0, 0xb89: 0x00c0, 0xb8a: 0x00c0, 0xb8b: 0x00c0, - 0xb8c: 0x00c0, 0xb8e: 0x00c0, 0xb8f: 0x00c0, 0xb90: 0x00c0, - 0xb92: 0x00c0, 0xb93: 0x00c0, 0xb94: 0x00c0, 0xb95: 0x00c0, 0xb96: 0x00c0, 0xb97: 0x00c0, - 0xb98: 0x00c0, 0xb99: 0x00c0, 0xb9a: 0x00c0, 0xb9b: 0x00c0, 0xb9c: 0x00c0, 0xb9d: 0x00c0, - 0xb9e: 0x00c0, 0xb9f: 0x00c0, 0xba0: 0x00c0, 0xba1: 0x00c0, 0xba2: 0x00c0, 0xba3: 0x00c0, - 0xba4: 0x00c0, 0xba5: 0x00c0, 0xba6: 0x00c0, 0xba7: 0x00c0, 0xba8: 0x00c0, - 0xbaa: 0x00c0, 0xbab: 0x00c0, 0xbac: 0x00c0, 0xbad: 0x00c0, 0xbae: 0x00c0, 0xbaf: 0x00c0, - 0xbb0: 0x00c0, 0xbb1: 0x00c0, 0xbb2: 0x00c0, 0xbb3: 0x00c0, 0xbb5: 0x00c0, - 0xbb6: 0x00c0, 0xbb7: 0x00c0, 0xbb8: 0x00c0, 0xbb9: 0x00c0, - 0xbbc: 0x00c3, 0xbbd: 0x00c0, 0xbbe: 0x00c0, 0xbbf: 0x00c3, - // Block 0x2f, offset 0xbc0 - 0xbc0: 0x00c0, 0xbc1: 0x00c0, 0xbc2: 0x00c0, 0xbc3: 0x00c0, 0xbc4: 0x00c0, - 0xbc6: 0x00c3, 0xbc7: 0x00c0, 0xbc8: 0x00c0, 0xbca: 0x00c0, 0xbcb: 0x00c0, - 0xbcc: 0x00c3, 0xbcd: 0x00c6, - 0xbd5: 0x00c0, 0xbd6: 0x00c0, - 0xbde: 0x00c0, 0xbe0: 0x00c0, 0xbe1: 0x00c0, 0xbe2: 0x00c3, 0xbe3: 0x00c3, - 0xbe6: 0x00c0, 0xbe7: 0x00c0, 0xbe8: 0x00c0, 0xbe9: 0x00c0, - 0xbea: 0x00c0, 0xbeb: 0x00c0, 0xbec: 0x00c0, 0xbed: 0x00c0, 0xbee: 0x00c0, 0xbef: 0x00c0, - 0xbf1: 0x00c0, 0xbf2: 0x00c0, - // Block 0x30, offset 0xc00 - 0xc01: 0x00c3, 0xc02: 0x00c0, 0xc03: 0x00c0, 0xc05: 0x00c0, - 0xc06: 0x00c0, 0xc07: 0x00c0, 0xc08: 0x00c0, 0xc09: 0x00c0, 0xc0a: 0x00c0, 0xc0b: 0x00c0, - 0xc0c: 0x00c0, 0xc0e: 0x00c0, 0xc0f: 0x00c0, 0xc10: 0x00c0, - 0xc12: 0x00c0, 0xc13: 0x00c0, 0xc14: 0x00c0, 0xc15: 0x00c0, 0xc16: 0x00c0, 0xc17: 0x00c0, - 0xc18: 0x00c0, 0xc19: 0x00c0, 0xc1a: 0x00c0, 0xc1b: 0x00c0, 0xc1c: 0x00c0, 0xc1d: 0x00c0, - 0xc1e: 0x00c0, 0xc1f: 0x00c0, 0xc20: 0x00c0, 0xc21: 0x00c0, 0xc22: 0x00c0, 0xc23: 0x00c0, - 0xc24: 0x00c0, 0xc25: 0x00c0, 0xc26: 0x00c0, 0xc27: 0x00c0, 0xc28: 0x00c0, 0xc29: 0x00c0, - 0xc2a: 0x00c0, 0xc2b: 0x00c0, 0xc2c: 0x00c0, 0xc2d: 0x00c0, 0xc2e: 0x00c0, 0xc2f: 0x00c0, - 0xc30: 0x00c0, 0xc31: 0x00c0, 0xc32: 0x00c0, 0xc33: 0x00c0, 0xc34: 0x00c0, 0xc35: 0x00c0, - 0xc36: 0x00c0, 0xc37: 0x00c0, 0xc38: 0x00c0, 0xc39: 0x00c0, 0xc3a: 0x00c0, - 0xc3d: 0x00c0, 0xc3e: 0x00c0, 0xc3f: 0x00c0, - // Block 0x31, offset 0xc40 - 0xc40: 0x00c0, 0xc41: 0x00c3, 0xc42: 0x00c3, 0xc43: 0x00c3, 0xc44: 0x00c3, - 0xc46: 0x00c0, 0xc47: 0x00c0, 0xc48: 0x00c0, 0xc4a: 0x00c0, 0xc4b: 0x00c0, - 0xc4c: 0x00c0, 0xc4d: 0x00c6, 0xc4e: 0x00c0, 0xc4f: 0x0080, - 0xc54: 0x00c0, 0xc55: 0x00c0, 0xc56: 0x00c0, 0xc57: 0x00c0, - 0xc58: 0x0080, 0xc59: 0x0080, 0xc5a: 0x0080, 0xc5b: 0x0080, 0xc5c: 0x0080, 0xc5d: 0x0080, - 0xc5e: 0x0080, 0xc5f: 0x00c0, 0xc60: 0x00c0, 0xc61: 0x00c0, 0xc62: 0x00c3, 0xc63: 0x00c3, - 0xc66: 0x00c0, 0xc67: 0x00c0, 0xc68: 0x00c0, 0xc69: 0x00c0, - 0xc6a: 0x00c0, 0xc6b: 0x00c0, 0xc6c: 0x00c0, 0xc6d: 0x00c0, 0xc6e: 0x00c0, 0xc6f: 0x00c0, - 0xc70: 0x0080, 0xc71: 0x0080, 0xc72: 0x0080, 0xc73: 0x0080, 0xc74: 0x0080, 0xc75: 0x0080, - 0xc76: 0x0080, 0xc77: 0x0080, 0xc78: 0x0080, 0xc79: 0x0080, 0xc7a: 0x00c0, 0xc7b: 0x00c0, - 0xc7c: 0x00c0, 0xc7d: 0x00c0, 0xc7e: 0x00c0, 0xc7f: 0x00c0, - // Block 0x32, offset 0xc80 - 0xc82: 0x00c0, 0xc83: 0x00c0, 0xc85: 0x00c0, - 0xc86: 0x00c0, 0xc87: 0x00c0, 0xc88: 0x00c0, 0xc89: 0x00c0, 0xc8a: 0x00c0, 0xc8b: 0x00c0, - 0xc8c: 0x00c0, 0xc8d: 0x00c0, 0xc8e: 0x00c0, 0xc8f: 0x00c0, 0xc90: 0x00c0, 0xc91: 0x00c0, - 0xc92: 0x00c0, 0xc93: 0x00c0, 0xc94: 0x00c0, 0xc95: 0x00c0, 0xc96: 0x00c0, - 0xc9a: 0x00c0, 0xc9b: 0x00c0, 0xc9c: 0x00c0, 0xc9d: 0x00c0, - 0xc9e: 0x00c0, 0xc9f: 0x00c0, 0xca0: 0x00c0, 0xca1: 0x00c0, 0xca2: 0x00c0, 0xca3: 0x00c0, - 0xca4: 0x00c0, 0xca5: 0x00c0, 0xca6: 0x00c0, 0xca7: 0x00c0, 0xca8: 0x00c0, 0xca9: 0x00c0, - 0xcaa: 0x00c0, 0xcab: 0x00c0, 0xcac: 0x00c0, 0xcad: 0x00c0, 0xcae: 0x00c0, 0xcaf: 0x00c0, - 0xcb0: 0x00c0, 0xcb1: 0x00c0, 0xcb3: 0x00c0, 0xcb4: 0x00c0, 0xcb5: 0x00c0, - 0xcb6: 0x00c0, 0xcb7: 0x00c0, 0xcb8: 0x00c0, 0xcb9: 0x00c0, 0xcba: 0x00c0, 0xcbb: 0x00c0, - 0xcbd: 0x00c0, - // Block 0x33, offset 0xcc0 - 0xcc0: 0x00c0, 0xcc1: 0x00c0, 0xcc2: 0x00c0, 0xcc3: 0x00c0, 0xcc4: 0x00c0, 0xcc5: 0x00c0, - 0xcc6: 0x00c0, 0xcca: 0x00c6, - 0xccf: 0x00c0, 0xcd0: 0x00c0, 0xcd1: 0x00c0, - 0xcd2: 0x00c3, 0xcd3: 0x00c3, 0xcd4: 0x00c3, 0xcd6: 0x00c3, - 0xcd8: 0x00c0, 0xcd9: 0x00c0, 0xcda: 0x00c0, 0xcdb: 0x00c0, 0xcdc: 0x00c0, 0xcdd: 0x00c0, - 0xcde: 0x00c0, 0xcdf: 0x00c0, - 0xce6: 0x00c0, 0xce7: 0x00c0, 0xce8: 0x00c0, 0xce9: 0x00c0, - 0xcea: 0x00c0, 0xceb: 0x00c0, 0xcec: 0x00c0, 0xced: 0x00c0, 0xcee: 0x00c0, 0xcef: 0x00c0, - 0xcf2: 0x00c0, 0xcf3: 0x00c0, 0xcf4: 0x0080, - // Block 0x34, offset 0xd00 - 0xd01: 0x00c0, 0xd02: 0x00c0, 0xd03: 0x00c0, 0xd04: 0x00c0, 0xd05: 0x00c0, - 0xd06: 0x00c0, 0xd07: 0x00c0, 0xd08: 0x00c0, 0xd09: 0x00c0, 0xd0a: 0x00c0, 0xd0b: 0x00c0, - 0xd0c: 0x00c0, 0xd0d: 0x00c0, 0xd0e: 0x00c0, 0xd0f: 0x00c0, 0xd10: 0x00c0, 0xd11: 0x00c0, - 0xd12: 0x00c0, 0xd13: 0x00c0, 0xd14: 0x00c0, 0xd15: 0x00c0, 0xd16: 0x00c0, 0xd17: 0x00c0, - 0xd18: 0x00c0, 0xd19: 0x00c0, 0xd1a: 0x00c0, 0xd1b: 0x00c0, 0xd1c: 0x00c0, 0xd1d: 0x00c0, - 0xd1e: 0x00c0, 0xd1f: 0x00c0, 0xd20: 0x00c0, 0xd21: 0x00c0, 0xd22: 0x00c0, 0xd23: 0x00c0, - 0xd24: 0x00c0, 0xd25: 0x00c0, 0xd26: 0x00c0, 0xd27: 0x00c0, 0xd28: 0x00c0, 0xd29: 0x00c0, - 0xd2a: 0x00c0, 0xd2b: 0x00c0, 0xd2c: 0x00c0, 0xd2d: 0x00c0, 0xd2e: 0x00c0, 0xd2f: 0x00c0, - 0xd30: 0x00c0, 0xd31: 0x00c3, 0xd32: 0x00c0, 0xd33: 0x0080, 0xd34: 0x00c3, 0xd35: 0x00c3, - 0xd36: 0x00c3, 0xd37: 0x00c3, 0xd38: 0x00c3, 0xd39: 0x00c3, 0xd3a: 0x00c6, - 0xd3f: 0x0080, - // Block 0x35, offset 0xd40 - 0xd40: 0x00c0, 0xd41: 0x00c0, 0xd42: 0x00c0, 0xd43: 0x00c0, 0xd44: 0x00c0, 0xd45: 0x00c0, - 0xd46: 0x00c0, 0xd47: 0x00c3, 0xd48: 0x00c3, 0xd49: 0x00c3, 0xd4a: 0x00c3, 0xd4b: 0x00c3, - 0xd4c: 0x00c3, 0xd4d: 0x00c3, 0xd4e: 0x00c3, 0xd4f: 0x0080, 0xd50: 0x00c0, 0xd51: 0x00c0, - 0xd52: 0x00c0, 0xd53: 0x00c0, 0xd54: 0x00c0, 0xd55: 0x00c0, 0xd56: 0x00c0, 0xd57: 0x00c0, - 0xd58: 0x00c0, 0xd59: 0x00c0, 0xd5a: 0x0080, 0xd5b: 0x0080, - // Block 0x36, offset 0xd80 - 0xd81: 0x00c0, 0xd82: 0x00c0, 0xd84: 0x00c0, - 0xd87: 0x00c0, 0xd88: 0x00c0, 0xd8a: 0x00c0, - 0xd8d: 0x00c0, - 0xd94: 0x00c0, 0xd95: 0x00c0, 0xd96: 0x00c0, 0xd97: 0x00c0, - 0xd99: 0x00c0, 0xd9a: 0x00c0, 0xd9b: 0x00c0, 0xd9c: 0x00c0, 0xd9d: 0x00c0, - 0xd9e: 0x00c0, 0xd9f: 0x00c0, 0xda1: 0x00c0, 0xda2: 0x00c0, 0xda3: 0x00c0, - 0xda5: 0x00c0, 0xda7: 0x00c0, - 0xdaa: 0x00c0, 0xdab: 0x00c0, 0xdad: 0x00c0, 0xdae: 0x00c0, 0xdaf: 0x00c0, - 0xdb0: 0x00c0, 0xdb1: 0x00c3, 0xdb2: 0x00c0, 0xdb3: 0x0080, 0xdb4: 0x00c3, 0xdb5: 0x00c3, - 0xdb6: 0x00c3, 0xdb7: 0x00c3, 0xdb8: 0x00c3, 0xdb9: 0x00c3, 0xdbb: 0x00c3, - 0xdbc: 0x00c3, 0xdbd: 0x00c0, - // Block 0x37, offset 0xdc0 - 0xdc0: 0x00c0, 0xdc1: 0x00c0, 0xdc2: 0x00c0, 0xdc3: 0x00c0, 0xdc4: 0x00c0, - 0xdc6: 0x00c0, 0xdc8: 0x00c3, 0xdc9: 0x00c3, 0xdca: 0x00c3, 0xdcb: 0x00c3, - 0xdcc: 0x00c3, 0xdcd: 0x00c3, 0xdd0: 0x00c0, 0xdd1: 0x00c0, - 0xdd2: 0x00c0, 0xdd3: 0x00c0, 0xdd4: 0x00c0, 0xdd5: 0x00c0, 0xdd6: 0x00c0, 0xdd7: 0x00c0, - 0xdd8: 0x00c0, 0xdd9: 0x00c0, 0xddc: 0x0080, 0xddd: 0x0080, - 0xdde: 0x00c0, 0xddf: 0x00c0, - // Block 0x38, offset 0xe00 - 0xe00: 0x00c0, 0xe01: 0x0080, 0xe02: 0x0080, 0xe03: 0x0080, 0xe04: 0x0080, 0xe05: 0x0080, - 0xe06: 0x0080, 0xe07: 0x0080, 0xe08: 0x0080, 0xe09: 0x0080, 0xe0a: 0x0080, 0xe0b: 0x00c0, - 0xe0c: 0x0080, 0xe0d: 0x0080, 0xe0e: 0x0080, 0xe0f: 0x0080, 0xe10: 0x0080, 0xe11: 0x0080, - 0xe12: 0x0080, 0xe13: 0x0080, 0xe14: 0x0080, 0xe15: 0x0080, 0xe16: 0x0080, 0xe17: 0x0080, - 0xe18: 0x00c3, 0xe19: 0x00c3, 0xe1a: 0x0080, 0xe1b: 0x0080, 0xe1c: 0x0080, 0xe1d: 0x0080, - 0xe1e: 0x0080, 0xe1f: 0x0080, 0xe20: 0x00c0, 0xe21: 0x00c0, 0xe22: 0x00c0, 0xe23: 0x00c0, - 0xe24: 0x00c0, 0xe25: 0x00c0, 0xe26: 0x00c0, 0xe27: 0x00c0, 0xe28: 0x00c0, 0xe29: 0x00c0, - 0xe2a: 0x0080, 0xe2b: 0x0080, 0xe2c: 0x0080, 0xe2d: 0x0080, 0xe2e: 0x0080, 0xe2f: 0x0080, - 0xe30: 0x0080, 0xe31: 0x0080, 0xe32: 0x0080, 0xe33: 0x0080, 0xe34: 0x0080, 0xe35: 0x00c3, - 0xe36: 0x0080, 0xe37: 0x00c3, 0xe38: 0x0080, 0xe39: 0x00c3, 0xe3a: 0x0080, 0xe3b: 0x0080, - 0xe3c: 0x0080, 0xe3d: 0x0080, 0xe3e: 0x00c0, 0xe3f: 0x00c0, - // Block 0x39, offset 0xe40 - 0xe40: 0x00c0, 0xe41: 0x00c0, 0xe42: 0x00c0, 0xe43: 0x0080, 0xe44: 0x00c0, 0xe45: 0x00c0, - 0xe46: 0x00c0, 0xe47: 0x00c0, 0xe49: 0x00c0, 0xe4a: 0x00c0, 0xe4b: 0x00c0, - 0xe4c: 0x00c0, 0xe4d: 0x0080, 0xe4e: 0x00c0, 0xe4f: 0x00c0, 0xe50: 0x00c0, 0xe51: 0x00c0, - 0xe52: 0x0080, 0xe53: 0x00c0, 0xe54: 0x00c0, 0xe55: 0x00c0, 0xe56: 0x00c0, 0xe57: 0x0080, - 0xe58: 0x00c0, 0xe59: 0x00c0, 0xe5a: 0x00c0, 0xe5b: 0x00c0, 0xe5c: 0x0080, 0xe5d: 0x00c0, - 0xe5e: 0x00c0, 0xe5f: 0x00c0, 0xe60: 0x00c0, 0xe61: 0x00c0, 0xe62: 0x00c0, 0xe63: 0x00c0, - 0xe64: 0x00c0, 0xe65: 0x00c0, 0xe66: 0x00c0, 0xe67: 0x00c0, 0xe68: 0x00c0, 0xe69: 0x0080, - 0xe6a: 0x00c0, 0xe6b: 0x00c0, 0xe6c: 0x00c0, - 0xe71: 0x00c3, 0xe72: 0x00c3, 0xe73: 0x0083, 0xe74: 0x00c3, 0xe75: 0x0083, - 0xe76: 0x0083, 0xe77: 0x0083, 0xe78: 0x0083, 0xe79: 0x0083, 0xe7a: 0x00c3, 0xe7b: 0x00c3, - 0xe7c: 0x00c3, 0xe7d: 0x00c3, 0xe7e: 0x00c3, 0xe7f: 0x00c0, - // Block 0x3a, offset 0xe80 - 0xe80: 0x00c3, 0xe81: 0x0083, 0xe82: 0x00c3, 0xe83: 0x00c3, 0xe84: 0x00c6, 0xe85: 0x0080, - 0xe86: 0x00c3, 0xe87: 0x00c3, 0xe88: 0x00c0, 0xe89: 0x00c0, 0xe8a: 0x00c0, 0xe8b: 0x00c0, - 0xe8c: 0x00c0, 0xe8d: 0x00c3, 0xe8e: 0x00c3, 0xe8f: 0x00c3, 0xe90: 0x00c3, 0xe91: 0x00c3, - 0xe92: 0x00c3, 0xe93: 0x0083, 0xe94: 0x00c3, 0xe95: 0x00c3, 0xe96: 0x00c3, 0xe97: 0x00c3, - 0xe99: 0x00c3, 0xe9a: 0x00c3, 0xe9b: 0x00c3, 0xe9c: 0x00c3, 0xe9d: 0x0083, - 0xe9e: 0x00c3, 0xe9f: 0x00c3, 0xea0: 0x00c3, 0xea1: 0x00c3, 0xea2: 0x0083, 0xea3: 0x00c3, - 0xea4: 0x00c3, 0xea5: 0x00c3, 0xea6: 0x00c3, 0xea7: 0x0083, 0xea8: 0x00c3, 0xea9: 0x00c3, - 0xeaa: 0x00c3, 0xeab: 0x00c3, 0xeac: 0x0083, 0xead: 0x00c3, 0xeae: 0x00c3, 0xeaf: 0x00c3, - 0xeb0: 0x00c3, 0xeb1: 0x00c3, 0xeb2: 0x00c3, 0xeb3: 0x00c3, 0xeb4: 0x00c3, 0xeb5: 0x00c3, - 0xeb6: 0x00c3, 0xeb7: 0x00c3, 0xeb8: 0x00c3, 0xeb9: 0x0083, 0xeba: 0x00c3, 0xebb: 0x00c3, - 0xebc: 0x00c3, 0xebe: 0x0080, 0xebf: 0x0080, - // Block 0x3b, offset 0xec0 - 0xec0: 0x0080, 0xec1: 0x0080, 0xec2: 0x0080, 0xec3: 0x0080, 0xec4: 0x0080, 0xec5: 0x0080, - 0xec6: 0x00c3, 0xec7: 0x0080, 0xec8: 0x0080, 0xec9: 0x0080, 0xeca: 0x0080, 0xecb: 0x0080, - 0xecc: 0x0080, 0xece: 0x0080, 0xecf: 0x0080, 0xed0: 0x0080, 0xed1: 0x0080, - 0xed2: 0x0080, 0xed3: 0x0080, 0xed4: 0x0080, 0xed5: 0x0080, 0xed6: 0x0080, 0xed7: 0x0080, - 0xed8: 0x0080, 0xed9: 0x0080, 0xeda: 0x0080, - // Block 0x3c, offset 0xf00 - 0xf00: 0x00c0, 0xf01: 0x00c0, 0xf02: 0x00c0, 0xf03: 0x00c0, 0xf04: 0x00c0, 0xf05: 0x00c0, - 0xf06: 0x00c0, 0xf07: 0x00c0, 0xf08: 0x00c0, 0xf09: 0x00c0, 0xf0a: 0x00c0, 0xf0b: 0x00c0, - 0xf0c: 0x00c0, 0xf0d: 0x00c0, 0xf0e: 0x00c0, 0xf0f: 0x00c0, 0xf10: 0x00c0, 0xf11: 0x00c0, - 0xf12: 0x00c0, 0xf13: 0x00c0, 0xf14: 0x00c0, 0xf15: 0x00c0, 0xf16: 0x00c0, 0xf17: 0x00c0, - 0xf18: 0x00c0, 0xf19: 0x00c0, 0xf1a: 0x00c0, 0xf1b: 0x00c0, 0xf1c: 0x00c0, 0xf1d: 0x00c0, - 0xf1e: 0x00c0, 0xf1f: 0x00c0, 0xf20: 0x00c0, 0xf21: 0x00c0, 0xf22: 0x00c0, 0xf23: 0x00c0, - 0xf24: 0x00c0, 0xf25: 0x00c0, 0xf26: 0x00c0, 0xf27: 0x00c0, 0xf28: 0x00c0, 0xf29: 0x00c0, - 0xf2a: 0x00c0, 0xf2b: 0x00c0, 0xf2c: 0x00c0, 0xf2d: 0x00c3, 0xf2e: 0x00c3, 0xf2f: 0x00c3, - 0xf30: 0x00c3, 0xf31: 0x00c0, 0xf32: 0x00c3, 0xf33: 0x00c3, 0xf34: 0x00c3, 0xf35: 0x00c3, - 0xf36: 0x00c3, 0xf37: 0x00c3, 0xf38: 0x00c0, 0xf39: 0x00c6, 0xf3a: 0x00c6, 0xf3b: 0x00c0, - 0xf3c: 0x00c0, 0xf3d: 0x00c3, 0xf3e: 0x00c3, 0xf3f: 0x00c0, - // Block 0x3d, offset 0xf40 - 0xf40: 0x00c0, 0xf41: 0x00c0, 0xf42: 0x00c0, 0xf43: 0x00c0, 0xf44: 0x00c0, 0xf45: 0x00c0, - 0xf46: 0x00c0, 0xf47: 0x00c0, 0xf48: 0x00c0, 0xf49: 0x00c0, 0xf4a: 0x0080, 0xf4b: 0x0080, - 0xf4c: 0x0080, 0xf4d: 0x0080, 0xf4e: 0x0080, 0xf4f: 0x0080, 0xf50: 0x00c0, 0xf51: 0x00c0, - 0xf52: 0x00c0, 0xf53: 0x00c0, 0xf54: 0x00c0, 0xf55: 0x00c0, 0xf56: 0x00c0, 0xf57: 0x00c0, - 0xf58: 0x00c3, 0xf59: 0x00c3, 0xf5a: 0x00c0, 0xf5b: 0x00c0, 0xf5c: 0x00c0, 0xf5d: 0x00c0, - 0xf5e: 0x00c3, 0xf5f: 0x00c3, 0xf60: 0x00c3, 0xf61: 0x00c0, 0xf62: 0x00c0, 0xf63: 0x00c0, - 0xf64: 0x00c0, 0xf65: 0x00c0, 0xf66: 0x00c0, 0xf67: 0x00c0, 0xf68: 0x00c0, 0xf69: 0x00c0, - 0xf6a: 0x00c0, 0xf6b: 0x00c0, 0xf6c: 0x00c0, 0xf6d: 0x00c0, 0xf6e: 0x00c0, 0xf6f: 0x00c0, - 0xf70: 0x00c0, 0xf71: 0x00c3, 0xf72: 0x00c3, 0xf73: 0x00c3, 0xf74: 0x00c3, 0xf75: 0x00c0, - 0xf76: 0x00c0, 0xf77: 0x00c0, 0xf78: 0x00c0, 0xf79: 0x00c0, 0xf7a: 0x00c0, 0xf7b: 0x00c0, - 0xf7c: 0x00c0, 0xf7d: 0x00c0, 0xf7e: 0x00c0, 0xf7f: 0x00c0, - // Block 0x3e, offset 0xf80 - 0xf80: 0x00c0, 0xf81: 0x00c0, 0xf82: 0x00c3, 0xf83: 0x00c0, 0xf84: 0x00c0, 0xf85: 0x00c3, - 0xf86: 0x00c3, 0xf87: 0x00c0, 0xf88: 0x00c0, 0xf89: 0x00c0, 0xf8a: 0x00c0, 0xf8b: 0x00c0, - 0xf8c: 0x00c0, 0xf8d: 0x00c3, 0xf8e: 0x00c0, 0xf8f: 0x00c0, 0xf90: 0x00c0, 0xf91: 0x00c0, - 0xf92: 0x00c0, 0xf93: 0x00c0, 0xf94: 0x00c0, 0xf95: 0x00c0, 0xf96: 0x00c0, 0xf97: 0x00c0, - 0xf98: 0x00c0, 0xf99: 0x00c0, 0xf9a: 0x00c0, 0xf9b: 0x00c0, 0xf9c: 0x00c0, 0xf9d: 0x00c3, - 0xf9e: 0x0080, 0xf9f: 0x0080, 0xfa0: 0x00c0, 0xfa1: 0x00c0, 0xfa2: 0x00c0, 0xfa3: 0x00c0, - 0xfa4: 0x00c0, 0xfa5: 0x00c0, 0xfa6: 0x00c0, 0xfa7: 0x00c0, 0xfa8: 0x00c0, 0xfa9: 0x00c0, - 0xfaa: 0x00c0, 0xfab: 0x00c0, 0xfac: 0x00c0, 0xfad: 0x00c0, 0xfae: 0x00c0, 0xfaf: 0x00c0, - 0xfb0: 0x00c0, 0xfb1: 0x00c0, 0xfb2: 0x00c0, 0xfb3: 0x00c0, 0xfb4: 0x00c0, 0xfb5: 0x00c0, - 0xfb6: 0x00c0, 0xfb7: 0x00c0, 0xfb8: 0x00c0, 0xfb9: 0x00c0, 0xfba: 0x00c0, 0xfbb: 0x00c0, - 0xfbc: 0x00c0, 0xfbd: 0x00c0, 0xfbe: 0x00c0, 0xfbf: 0x00c0, - // Block 0x3f, offset 0xfc0 - 0xfc0: 0x00c0, 0xfc1: 0x00c0, 0xfc2: 0x00c0, 0xfc3: 0x00c0, 0xfc4: 0x00c0, 0xfc5: 0x00c0, - 0xfc7: 0x00c0, - 0xfcd: 0x00c0, 0xfd0: 0x00c0, 0xfd1: 0x00c0, - 0xfd2: 0x00c0, 0xfd3: 0x00c0, 0xfd4: 0x00c0, 0xfd5: 0x00c0, 0xfd6: 0x00c0, 0xfd7: 0x00c0, - 0xfd8: 0x00c0, 0xfd9: 0x00c0, 0xfda: 0x00c0, 0xfdb: 0x00c0, 0xfdc: 0x00c0, 0xfdd: 0x00c0, - 0xfde: 0x00c0, 0xfdf: 0x00c0, 0xfe0: 0x00c0, 0xfe1: 0x00c0, 0xfe2: 0x00c0, 0xfe3: 0x00c0, - 0xfe4: 0x00c0, 0xfe5: 0x00c0, 0xfe6: 0x00c0, 0xfe7: 0x00c0, 0xfe8: 0x00c0, 0xfe9: 0x00c0, - 0xfea: 0x00c0, 0xfeb: 0x00c0, 0xfec: 0x00c0, 0xfed: 0x00c0, 0xfee: 0x00c0, 0xfef: 0x00c0, - 0xff0: 0x00c0, 0xff1: 0x00c0, 0xff2: 0x00c0, 0xff3: 0x00c0, 0xff4: 0x00c0, 0xff5: 0x00c0, - 0xff6: 0x00c0, 0xff7: 0x00c0, 0xff8: 0x00c0, 0xff9: 0x00c0, 0xffa: 0x00c0, 0xffb: 0x0080, - 0xffc: 0x0080, 0xffd: 0x00c0, 0xffe: 0x00c0, 0xfff: 0x00c0, - // Block 0x40, offset 0x1000 - 0x1000: 0x0040, 0x1001: 0x0040, 0x1002: 0x0040, 0x1003: 0x0040, 0x1004: 0x0040, 0x1005: 0x0040, - 0x1006: 0x0040, 0x1007: 0x0040, 0x1008: 0x0040, 0x1009: 0x0040, 0x100a: 0x0040, 0x100b: 0x0040, - 0x100c: 0x0040, 0x100d: 0x0040, 0x100e: 0x0040, 0x100f: 0x0040, 0x1010: 0x0040, 0x1011: 0x0040, - 0x1012: 0x0040, 0x1013: 0x0040, 0x1014: 0x0040, 0x1015: 0x0040, 0x1016: 0x0040, 0x1017: 0x0040, - 0x1018: 0x0040, 0x1019: 0x0040, 0x101a: 0x0040, 0x101b: 0x0040, 0x101c: 0x0040, 0x101d: 0x0040, - 0x101e: 0x0040, 0x101f: 0x0040, 0x1020: 0x0040, 0x1021: 0x0040, 0x1022: 0x0040, 0x1023: 0x0040, - 0x1024: 0x0040, 0x1025: 0x0040, 0x1026: 0x0040, 0x1027: 0x0040, 0x1028: 0x0040, 0x1029: 0x0040, - 0x102a: 0x0040, 0x102b: 0x0040, 0x102c: 0x0040, 0x102d: 0x0040, 0x102e: 0x0040, 0x102f: 0x0040, - 0x1030: 0x0040, 0x1031: 0x0040, 0x1032: 0x0040, 0x1033: 0x0040, 0x1034: 0x0040, 0x1035: 0x0040, - 0x1036: 0x0040, 0x1037: 0x0040, 0x1038: 0x0040, 0x1039: 0x0040, 0x103a: 0x0040, 0x103b: 0x0040, - 0x103c: 0x0040, 0x103d: 0x0040, 0x103e: 0x0040, 0x103f: 0x0040, - // Block 0x41, offset 0x1040 - 0x1040: 0x00c0, 0x1041: 0x00c0, 0x1042: 0x00c0, 0x1043: 0x00c0, 0x1044: 0x00c0, 0x1045: 0x00c0, - 0x1046: 0x00c0, 0x1047: 0x00c0, 0x1048: 0x00c0, 0x104a: 0x00c0, 0x104b: 0x00c0, - 0x104c: 0x00c0, 0x104d: 0x00c0, 0x1050: 0x00c0, 0x1051: 0x00c0, - 0x1052: 0x00c0, 0x1053: 0x00c0, 0x1054: 0x00c0, 0x1055: 0x00c0, 0x1056: 0x00c0, - 0x1058: 0x00c0, 0x105a: 0x00c0, 0x105b: 0x00c0, 0x105c: 0x00c0, 0x105d: 0x00c0, - 0x1060: 0x00c0, 0x1061: 0x00c0, 0x1062: 0x00c0, 0x1063: 0x00c0, - 0x1064: 0x00c0, 0x1065: 0x00c0, 0x1066: 0x00c0, 0x1067: 0x00c0, 0x1068: 0x00c0, 0x1069: 0x00c0, - 0x106a: 0x00c0, 0x106b: 0x00c0, 0x106c: 0x00c0, 0x106d: 0x00c0, 0x106e: 0x00c0, 0x106f: 0x00c0, - 0x1070: 0x00c0, 0x1071: 0x00c0, 0x1072: 0x00c0, 0x1073: 0x00c0, 0x1074: 0x00c0, 0x1075: 0x00c0, - 0x1076: 0x00c0, 0x1077: 0x00c0, 0x1078: 0x00c0, 0x1079: 0x00c0, 0x107a: 0x00c0, 0x107b: 0x00c0, - 0x107c: 0x00c0, 0x107d: 0x00c0, 0x107e: 0x00c0, 0x107f: 0x00c0, - // Block 0x42, offset 0x1080 - 0x1080: 0x00c0, 0x1081: 0x00c0, 0x1082: 0x00c0, 0x1083: 0x00c0, 0x1084: 0x00c0, 0x1085: 0x00c0, - 0x1086: 0x00c0, 0x1087: 0x00c0, 0x1088: 0x00c0, 0x108a: 0x00c0, 0x108b: 0x00c0, - 0x108c: 0x00c0, 0x108d: 0x00c0, 0x1090: 0x00c0, 0x1091: 0x00c0, - 0x1092: 0x00c0, 0x1093: 0x00c0, 0x1094: 0x00c0, 0x1095: 0x00c0, 0x1096: 0x00c0, 0x1097: 0x00c0, - 0x1098: 0x00c0, 0x1099: 0x00c0, 0x109a: 0x00c0, 0x109b: 0x00c0, 0x109c: 0x00c0, 0x109d: 0x00c0, - 0x109e: 0x00c0, 0x109f: 0x00c0, 0x10a0: 0x00c0, 0x10a1: 0x00c0, 0x10a2: 0x00c0, 0x10a3: 0x00c0, - 0x10a4: 0x00c0, 0x10a5: 0x00c0, 0x10a6: 0x00c0, 0x10a7: 0x00c0, 0x10a8: 0x00c0, 0x10a9: 0x00c0, - 0x10aa: 0x00c0, 0x10ab: 0x00c0, 0x10ac: 0x00c0, 0x10ad: 0x00c0, 0x10ae: 0x00c0, 0x10af: 0x00c0, - 0x10b0: 0x00c0, 0x10b2: 0x00c0, 0x10b3: 0x00c0, 0x10b4: 0x00c0, 0x10b5: 0x00c0, - 0x10b8: 0x00c0, 0x10b9: 0x00c0, 0x10ba: 0x00c0, 0x10bb: 0x00c0, - 0x10bc: 0x00c0, 0x10bd: 0x00c0, 0x10be: 0x00c0, - // Block 0x43, offset 0x10c0 - 0x10c0: 0x00c0, 0x10c2: 0x00c0, 0x10c3: 0x00c0, 0x10c4: 0x00c0, 0x10c5: 0x00c0, - 0x10c8: 0x00c0, 0x10c9: 0x00c0, 0x10ca: 0x00c0, 0x10cb: 0x00c0, - 0x10cc: 0x00c0, 0x10cd: 0x00c0, 0x10ce: 0x00c0, 0x10cf: 0x00c0, 0x10d0: 0x00c0, 0x10d1: 0x00c0, - 0x10d2: 0x00c0, 0x10d3: 0x00c0, 0x10d4: 0x00c0, 0x10d5: 0x00c0, 0x10d6: 0x00c0, - 0x10d8: 0x00c0, 0x10d9: 0x00c0, 0x10da: 0x00c0, 0x10db: 0x00c0, 0x10dc: 0x00c0, 0x10dd: 0x00c0, - 0x10de: 0x00c0, 0x10df: 0x00c0, 0x10e0: 0x00c0, 0x10e1: 0x00c0, 0x10e2: 0x00c0, 0x10e3: 0x00c0, - 0x10e4: 0x00c0, 0x10e5: 0x00c0, 0x10e6: 0x00c0, 0x10e7: 0x00c0, 0x10e8: 0x00c0, 0x10e9: 0x00c0, - 0x10ea: 0x00c0, 0x10eb: 0x00c0, 0x10ec: 0x00c0, 0x10ed: 0x00c0, 0x10ee: 0x00c0, 0x10ef: 0x00c0, - 0x10f0: 0x00c0, 0x10f1: 0x00c0, 0x10f2: 0x00c0, 0x10f3: 0x00c0, 0x10f4: 0x00c0, 0x10f5: 0x00c0, - 0x10f6: 0x00c0, 0x10f7: 0x00c0, 0x10f8: 0x00c0, 0x10f9: 0x00c0, 0x10fa: 0x00c0, 0x10fb: 0x00c0, - 0x10fc: 0x00c0, 0x10fd: 0x00c0, 0x10fe: 0x00c0, 0x10ff: 0x00c0, - // Block 0x44, offset 0x1100 - 0x1100: 0x00c0, 0x1101: 0x00c0, 0x1102: 0x00c0, 0x1103: 0x00c0, 0x1104: 0x00c0, 0x1105: 0x00c0, - 0x1106: 0x00c0, 0x1107: 0x00c0, 0x1108: 0x00c0, 0x1109: 0x00c0, 0x110a: 0x00c0, 0x110b: 0x00c0, - 0x110c: 0x00c0, 0x110d: 0x00c0, 0x110e: 0x00c0, 0x110f: 0x00c0, 0x1110: 0x00c0, - 0x1112: 0x00c0, 0x1113: 0x00c0, 0x1114: 0x00c0, 0x1115: 0x00c0, - 0x1118: 0x00c0, 0x1119: 0x00c0, 0x111a: 0x00c0, 0x111b: 0x00c0, 0x111c: 0x00c0, 0x111d: 0x00c0, - 0x111e: 0x00c0, 0x111f: 0x00c0, 0x1120: 0x00c0, 0x1121: 0x00c0, 0x1122: 0x00c0, 0x1123: 0x00c0, - 0x1124: 0x00c0, 0x1125: 0x00c0, 0x1126: 0x00c0, 0x1127: 0x00c0, 0x1128: 0x00c0, 0x1129: 0x00c0, - 0x112a: 0x00c0, 0x112b: 0x00c0, 0x112c: 0x00c0, 0x112d: 0x00c0, 0x112e: 0x00c0, 0x112f: 0x00c0, - 0x1130: 0x00c0, 0x1131: 0x00c0, 0x1132: 0x00c0, 0x1133: 0x00c0, 0x1134: 0x00c0, 0x1135: 0x00c0, - 0x1136: 0x00c0, 0x1137: 0x00c0, 0x1138: 0x00c0, 0x1139: 0x00c0, 0x113a: 0x00c0, 0x113b: 0x00c0, - 0x113c: 0x00c0, 0x113d: 0x00c0, 0x113e: 0x00c0, 0x113f: 0x00c0, - // Block 0x45, offset 0x1140 - 0x1140: 0x00c0, 0x1141: 0x00c0, 0x1142: 0x00c0, 0x1143: 0x00c0, 0x1144: 0x00c0, 0x1145: 0x00c0, - 0x1146: 0x00c0, 0x1147: 0x00c0, 0x1148: 0x00c0, 0x1149: 0x00c0, 0x114a: 0x00c0, 0x114b: 0x00c0, - 0x114c: 0x00c0, 0x114d: 0x00c0, 0x114e: 0x00c0, 0x114f: 0x00c0, 0x1150: 0x00c0, 0x1151: 0x00c0, - 0x1152: 0x00c0, 0x1153: 0x00c0, 0x1154: 0x00c0, 0x1155: 0x00c0, 0x1156: 0x00c0, 0x1157: 0x00c0, - 0x1158: 0x00c0, 0x1159: 0x00c0, 0x115a: 0x00c0, 0x115d: 0x00c3, - 0x115e: 0x00c3, 0x115f: 0x00c3, 0x1160: 0x0080, 0x1161: 0x0080, 0x1162: 0x0080, 0x1163: 0x0080, - 0x1164: 0x0080, 0x1165: 0x0080, 0x1166: 0x0080, 0x1167: 0x0080, 0x1168: 0x0080, 0x1169: 0x0080, - 0x116a: 0x0080, 0x116b: 0x0080, 0x116c: 0x0080, 0x116d: 0x0080, 0x116e: 0x0080, 0x116f: 0x0080, - 0x1170: 0x0080, 0x1171: 0x0080, 0x1172: 0x0080, 0x1173: 0x0080, 0x1174: 0x0080, 0x1175: 0x0080, - 0x1176: 0x0080, 0x1177: 0x0080, 0x1178: 0x0080, 0x1179: 0x0080, 0x117a: 0x0080, 0x117b: 0x0080, - 0x117c: 0x0080, - // Block 0x46, offset 0x1180 - 0x1180: 0x00c0, 0x1181: 0x00c0, 0x1182: 0x00c0, 0x1183: 0x00c0, 0x1184: 0x00c0, 0x1185: 0x00c0, - 0x1186: 0x00c0, 0x1187: 0x00c0, 0x1188: 0x00c0, 0x1189: 0x00c0, 0x118a: 0x00c0, 0x118b: 0x00c0, - 0x118c: 0x00c0, 0x118d: 0x00c0, 0x118e: 0x00c0, 0x118f: 0x00c0, 0x1190: 0x0080, 0x1191: 0x0080, - 0x1192: 0x0080, 0x1193: 0x0080, 0x1194: 0x0080, 0x1195: 0x0080, 0x1196: 0x0080, 0x1197: 0x0080, - 0x1198: 0x0080, 0x1199: 0x0080, - 0x11a0: 0x00c0, 0x11a1: 0x00c0, 0x11a2: 0x00c0, 0x11a3: 0x00c0, - 0x11a4: 0x00c0, 0x11a5: 0x00c0, 0x11a6: 0x00c0, 0x11a7: 0x00c0, 0x11a8: 0x00c0, 0x11a9: 0x00c0, - 0x11aa: 0x00c0, 0x11ab: 0x00c0, 0x11ac: 0x00c0, 0x11ad: 0x00c0, 0x11ae: 0x00c0, 0x11af: 0x00c0, - 0x11b0: 0x00c0, 0x11b1: 0x00c0, 0x11b2: 0x00c0, 0x11b3: 0x00c0, 0x11b4: 0x00c0, 0x11b5: 0x00c0, - 0x11b6: 0x00c0, 0x11b7: 0x00c0, 0x11b8: 0x00c0, 0x11b9: 0x00c0, 0x11ba: 0x00c0, 0x11bb: 0x00c0, - 0x11bc: 0x00c0, 0x11bd: 0x00c0, 0x11be: 0x00c0, 0x11bf: 0x00c0, - // Block 0x47, offset 0x11c0 - 0x11c0: 0x00c0, 0x11c1: 0x00c0, 0x11c2: 0x00c0, 0x11c3: 0x00c0, 0x11c4: 0x00c0, 0x11c5: 0x00c0, - 0x11c6: 0x00c0, 0x11c7: 0x00c0, 0x11c8: 0x00c0, 0x11c9: 0x00c0, 0x11ca: 0x00c0, 0x11cb: 0x00c0, - 0x11cc: 0x00c0, 0x11cd: 0x00c0, 0x11ce: 0x00c0, 0x11cf: 0x00c0, 0x11d0: 0x00c0, 0x11d1: 0x00c0, - 0x11d2: 0x00c0, 0x11d3: 0x00c0, 0x11d4: 0x00c0, 0x11d5: 0x00c0, 0x11d6: 0x00c0, 0x11d7: 0x00c0, - 0x11d8: 0x00c0, 0x11d9: 0x00c0, 0x11da: 0x00c0, 0x11db: 0x00c0, 0x11dc: 0x00c0, 0x11dd: 0x00c0, - 0x11de: 0x00c0, 0x11df: 0x00c0, 0x11e0: 0x00c0, 0x11e1: 0x00c0, 0x11e2: 0x00c0, 0x11e3: 0x00c0, - 0x11e4: 0x00c0, 0x11e5: 0x00c0, 0x11e6: 0x00c0, 0x11e7: 0x00c0, 0x11e8: 0x00c0, 0x11e9: 0x00c0, - 0x11ea: 0x00c0, 0x11eb: 0x00c0, 0x11ec: 0x00c0, 0x11ed: 0x00c0, 0x11ee: 0x00c0, 0x11ef: 0x00c0, - 0x11f0: 0x00c0, 0x11f1: 0x00c0, 0x11f2: 0x00c0, 0x11f3: 0x00c0, 0x11f4: 0x00c0, 0x11f5: 0x00c0, - 0x11f8: 0x00c0, 0x11f9: 0x00c0, 0x11fa: 0x00c0, 0x11fb: 0x00c0, - 0x11fc: 0x00c0, 0x11fd: 0x00c0, - // Block 0x48, offset 0x1200 - 0x1200: 0x0080, 0x1201: 0x00c0, 0x1202: 0x00c0, 0x1203: 0x00c0, 0x1204: 0x00c0, 0x1205: 0x00c0, - 0x1206: 0x00c0, 0x1207: 0x00c0, 0x1208: 0x00c0, 0x1209: 0x00c0, 0x120a: 0x00c0, 0x120b: 0x00c0, - 0x120c: 0x00c0, 0x120d: 0x00c0, 0x120e: 0x00c0, 0x120f: 0x00c0, 0x1210: 0x00c0, 0x1211: 0x00c0, - 0x1212: 0x00c0, 0x1213: 0x00c0, 0x1214: 0x00c0, 0x1215: 0x00c0, 0x1216: 0x00c0, 0x1217: 0x00c0, - 0x1218: 0x00c0, 0x1219: 0x00c0, 0x121a: 0x00c0, 0x121b: 0x00c0, 0x121c: 0x00c0, 0x121d: 0x00c0, - 0x121e: 0x00c0, 0x121f: 0x00c0, 0x1220: 0x00c0, 0x1221: 0x00c0, 0x1222: 0x00c0, 0x1223: 0x00c0, - 0x1224: 0x00c0, 0x1225: 0x00c0, 0x1226: 0x00c0, 0x1227: 0x00c0, 0x1228: 0x00c0, 0x1229: 0x00c0, - 0x122a: 0x00c0, 0x122b: 0x00c0, 0x122c: 0x00c0, 0x122d: 0x00c0, 0x122e: 0x00c0, 0x122f: 0x00c0, - 0x1230: 0x00c0, 0x1231: 0x00c0, 0x1232: 0x00c0, 0x1233: 0x00c0, 0x1234: 0x00c0, 0x1235: 0x00c0, - 0x1236: 0x00c0, 0x1237: 0x00c0, 0x1238: 0x00c0, 0x1239: 0x00c0, 0x123a: 0x00c0, 0x123b: 0x00c0, - 0x123c: 0x00c0, 0x123d: 0x00c0, 0x123e: 0x00c0, 0x123f: 0x00c0, - // Block 0x49, offset 0x1240 - 0x1240: 0x00c0, 0x1241: 0x00c0, 0x1242: 0x00c0, 0x1243: 0x00c0, 0x1244: 0x00c0, 0x1245: 0x00c0, - 0x1246: 0x00c0, 0x1247: 0x00c0, 0x1248: 0x00c0, 0x1249: 0x00c0, 0x124a: 0x00c0, 0x124b: 0x00c0, - 0x124c: 0x00c0, 0x124d: 0x00c0, 0x124e: 0x00c0, 0x124f: 0x00c0, 0x1250: 0x00c0, 0x1251: 0x00c0, - 0x1252: 0x00c0, 0x1253: 0x00c0, 0x1254: 0x00c0, 0x1255: 0x00c0, 0x1256: 0x00c0, 0x1257: 0x00c0, - 0x1258: 0x00c0, 0x1259: 0x00c0, 0x125a: 0x00c0, 0x125b: 0x00c0, 0x125c: 0x00c0, 0x125d: 0x00c0, - 0x125e: 0x00c0, 0x125f: 0x00c0, 0x1260: 0x00c0, 0x1261: 0x00c0, 0x1262: 0x00c0, 0x1263: 0x00c0, - 0x1264: 0x00c0, 0x1265: 0x00c0, 0x1266: 0x00c0, 0x1267: 0x00c0, 0x1268: 0x00c0, 0x1269: 0x00c0, - 0x126a: 0x00c0, 0x126b: 0x00c0, 0x126c: 0x00c0, 0x126d: 0x0080, 0x126e: 0x0080, 0x126f: 0x00c0, - 0x1270: 0x00c0, 0x1271: 0x00c0, 0x1272: 0x00c0, 0x1273: 0x00c0, 0x1274: 0x00c0, 0x1275: 0x00c0, - 0x1276: 0x00c0, 0x1277: 0x00c0, 0x1278: 0x00c0, 0x1279: 0x00c0, 0x127a: 0x00c0, 0x127b: 0x00c0, - 0x127c: 0x00c0, 0x127d: 0x00c0, 0x127e: 0x00c0, 0x127f: 0x00c0, - // Block 0x4a, offset 0x1280 - 0x1280: 0x0080, 0x1281: 0x00c0, 0x1282: 0x00c0, 0x1283: 0x00c0, 0x1284: 0x00c0, 0x1285: 0x00c0, - 0x1286: 0x00c0, 0x1287: 0x00c0, 0x1288: 0x00c0, 0x1289: 0x00c0, 0x128a: 0x00c0, 0x128b: 0x00c0, - 0x128c: 0x00c0, 0x128d: 0x00c0, 0x128e: 0x00c0, 0x128f: 0x00c0, 0x1290: 0x00c0, 0x1291: 0x00c0, - 0x1292: 0x00c0, 0x1293: 0x00c0, 0x1294: 0x00c0, 0x1295: 0x00c0, 0x1296: 0x00c0, 0x1297: 0x00c0, - 0x1298: 0x00c0, 0x1299: 0x00c0, 0x129a: 0x00c0, 0x129b: 0x0080, 0x129c: 0x0080, - 0x12a0: 0x00c0, 0x12a1: 0x00c0, 0x12a2: 0x00c0, 0x12a3: 0x00c0, - 0x12a4: 0x00c0, 0x12a5: 0x00c0, 0x12a6: 0x00c0, 0x12a7: 0x00c0, 0x12a8: 0x00c0, 0x12a9: 0x00c0, - 0x12aa: 0x00c0, 0x12ab: 0x00c0, 0x12ac: 0x00c0, 0x12ad: 0x00c0, 0x12ae: 0x00c0, 0x12af: 0x00c0, - 0x12b0: 0x00c0, 0x12b1: 0x00c0, 0x12b2: 0x00c0, 0x12b3: 0x00c0, 0x12b4: 0x00c0, 0x12b5: 0x00c0, - 0x12b6: 0x00c0, 0x12b7: 0x00c0, 0x12b8: 0x00c0, 0x12b9: 0x00c0, 0x12ba: 0x00c0, 0x12bb: 0x00c0, - 0x12bc: 0x00c0, 0x12bd: 0x00c0, 0x12be: 0x00c0, 0x12bf: 0x00c0, - // Block 0x4b, offset 0x12c0 - 0x12c0: 0x00c0, 0x12c1: 0x00c0, 0x12c2: 0x00c0, 0x12c3: 0x00c0, 0x12c4: 0x00c0, 0x12c5: 0x00c0, - 0x12c6: 0x00c0, 0x12c7: 0x00c0, 0x12c8: 0x00c0, 0x12c9: 0x00c0, 0x12ca: 0x00c0, 0x12cb: 0x00c0, - 0x12cc: 0x00c0, 0x12cd: 0x00c0, 0x12ce: 0x00c0, 0x12cf: 0x00c0, 0x12d0: 0x00c0, 0x12d1: 0x00c0, - 0x12d2: 0x00c0, 0x12d3: 0x00c0, 0x12d4: 0x00c0, 0x12d5: 0x00c0, 0x12d6: 0x00c0, 0x12d7: 0x00c0, - 0x12d8: 0x00c0, 0x12d9: 0x00c0, 0x12da: 0x00c0, 0x12db: 0x00c0, 0x12dc: 0x00c0, 0x12dd: 0x00c0, - 0x12de: 0x00c0, 0x12df: 0x00c0, 0x12e0: 0x00c0, 0x12e1: 0x00c0, 0x12e2: 0x00c0, 0x12e3: 0x00c0, - 0x12e4: 0x00c0, 0x12e5: 0x00c0, 0x12e6: 0x00c0, 0x12e7: 0x00c0, 0x12e8: 0x00c0, 0x12e9: 0x00c0, - 0x12ea: 0x00c0, 0x12eb: 0x0080, 0x12ec: 0x0080, 0x12ed: 0x0080, 0x12ee: 0x0080, 0x12ef: 0x0080, - 0x12f0: 0x0080, 0x12f1: 0x00c0, 0x12f2: 0x00c0, 0x12f3: 0x00c0, 0x12f4: 0x00c0, 0x12f5: 0x00c0, - 0x12f6: 0x00c0, 0x12f7: 0x00c0, 0x12f8: 0x00c0, - // Block 0x4c, offset 0x1300 - 0x1300: 0x00c0, 0x1301: 0x00c0, 0x1302: 0x00c0, 0x1303: 0x00c0, 0x1304: 0x00c0, 0x1305: 0x00c0, - 0x1306: 0x00c0, 0x1307: 0x00c0, 0x1308: 0x00c0, 0x1309: 0x00c0, 0x130a: 0x00c0, 0x130b: 0x00c0, - 0x130c: 0x00c0, 0x130e: 0x00c0, 0x130f: 0x00c0, 0x1310: 0x00c0, 0x1311: 0x00c0, - 0x1312: 0x00c3, 0x1313: 0x00c3, 0x1314: 0x00c6, - 0x1320: 0x00c0, 0x1321: 0x00c0, 0x1322: 0x00c0, 0x1323: 0x00c0, - 0x1324: 0x00c0, 0x1325: 0x00c0, 0x1326: 0x00c0, 0x1327: 0x00c0, 0x1328: 0x00c0, 0x1329: 0x00c0, - 0x132a: 0x00c0, 0x132b: 0x00c0, 0x132c: 0x00c0, 0x132d: 0x00c0, 0x132e: 0x00c0, 0x132f: 0x00c0, - 0x1330: 0x00c0, 0x1331: 0x00c0, 0x1332: 0x00c3, 0x1333: 0x00c3, 0x1334: 0x00c6, 0x1335: 0x0080, - 0x1336: 0x0080, - // Block 0x4d, offset 0x1340 - 0x1340: 0x00c0, 0x1341: 0x00c0, 0x1342: 0x00c0, 0x1343: 0x00c0, 0x1344: 0x00c0, 0x1345: 0x00c0, - 0x1346: 0x00c0, 0x1347: 0x00c0, 0x1348: 0x00c0, 0x1349: 0x00c0, 0x134a: 0x00c0, 0x134b: 0x00c0, - 0x134c: 0x00c0, 0x134d: 0x00c0, 0x134e: 0x00c0, 0x134f: 0x00c0, 0x1350: 0x00c0, 0x1351: 0x00c0, - 0x1352: 0x00c3, 0x1353: 0x00c3, - 0x1360: 0x00c0, 0x1361: 0x00c0, 0x1362: 0x00c0, 0x1363: 0x00c0, - 0x1364: 0x00c0, 0x1365: 0x00c0, 0x1366: 0x00c0, 0x1367: 0x00c0, 0x1368: 0x00c0, 0x1369: 0x00c0, - 0x136a: 0x00c0, 0x136b: 0x00c0, 0x136c: 0x00c0, 0x136e: 0x00c0, 0x136f: 0x00c0, - 0x1370: 0x00c0, 0x1372: 0x00c3, 0x1373: 0x00c3, - // Block 0x4e, offset 0x1380 - 0x1380: 0x00c0, 0x1381: 0x00c0, 0x1382: 0x00c0, 0x1383: 0x00c0, 0x1384: 0x00c0, 0x1385: 0x00c0, - 0x1386: 0x00c0, 0x1387: 0x00c0, 0x1388: 0x00c0, 0x1389: 0x00c0, 0x138a: 0x00c0, 0x138b: 0x00c0, - 0x138c: 0x00c0, 0x138d: 0x00c0, 0x138e: 0x00c0, 0x138f: 0x00c0, 0x1390: 0x00c0, 0x1391: 0x00c0, - 0x1392: 0x00c0, 0x1393: 0x00c0, 0x1394: 0x00c0, 0x1395: 0x00c0, 0x1396: 0x00c0, 0x1397: 0x00c0, - 0x1398: 0x00c0, 0x1399: 0x00c0, 0x139a: 0x00c0, 0x139b: 0x00c0, 0x139c: 0x00c0, 0x139d: 0x00c0, - 0x139e: 0x00c0, 0x139f: 0x00c0, 0x13a0: 0x00c0, 0x13a1: 0x00c0, 0x13a2: 0x00c0, 0x13a3: 0x00c0, - 0x13a4: 0x00c0, 0x13a5: 0x00c0, 0x13a6: 0x00c0, 0x13a7: 0x00c0, 0x13a8: 0x00c0, 0x13a9: 0x00c0, - 0x13aa: 0x00c0, 0x13ab: 0x00c0, 0x13ac: 0x00c0, 0x13ad: 0x00c0, 0x13ae: 0x00c0, 0x13af: 0x00c0, - 0x13b0: 0x00c0, 0x13b1: 0x00c0, 0x13b2: 0x00c0, 0x13b3: 0x00c0, 0x13b4: 0x0040, 0x13b5: 0x0040, - 0x13b6: 0x00c0, 0x13b7: 0x00c3, 0x13b8: 0x00c3, 0x13b9: 0x00c3, 0x13ba: 0x00c3, 0x13bb: 0x00c3, - 0x13bc: 0x00c3, 0x13bd: 0x00c3, 0x13be: 0x00c0, 0x13bf: 0x00c0, - // Block 0x4f, offset 0x13c0 - 0x13c0: 0x00c0, 0x13c1: 0x00c0, 0x13c2: 0x00c0, 0x13c3: 0x00c0, 0x13c4: 0x00c0, 0x13c5: 0x00c0, - 0x13c6: 0x00c3, 0x13c7: 0x00c0, 0x13c8: 0x00c0, 0x13c9: 0x00c3, 0x13ca: 0x00c3, 0x13cb: 0x00c3, - 0x13cc: 0x00c3, 0x13cd: 0x00c3, 0x13ce: 0x00c3, 0x13cf: 0x00c3, 0x13d0: 0x00c3, 0x13d1: 0x00c3, - 0x13d2: 0x00c6, 0x13d3: 0x00c3, 0x13d4: 0x0080, 0x13d5: 0x0080, 0x13d6: 0x0080, 0x13d7: 0x00c0, - 0x13d8: 0x0080, 0x13d9: 0x0080, 0x13da: 0x0080, 0x13db: 0x0080, 0x13dc: 0x00c0, 0x13dd: 0x00c3, - 0x13e0: 0x00c0, 0x13e1: 0x00c0, 0x13e2: 0x00c0, 0x13e3: 0x00c0, - 0x13e4: 0x00c0, 0x13e5: 0x00c0, 0x13e6: 0x00c0, 0x13e7: 0x00c0, 0x13e8: 0x00c0, 0x13e9: 0x00c0, - 0x13f0: 0x0080, 0x13f1: 0x0080, 0x13f2: 0x0080, 0x13f3: 0x0080, 0x13f4: 0x0080, 0x13f5: 0x0080, - 0x13f6: 0x0080, 0x13f7: 0x0080, 0x13f8: 0x0080, 0x13f9: 0x0080, - // Block 0x50, offset 0x1400 - 0x1400: 0x0080, 0x1401: 0x0080, 0x1402: 0x0080, 0x1403: 0x0080, 0x1404: 0x0080, 0x1405: 0x0080, - 0x1406: 0x0080, 0x1407: 0x0082, 0x1408: 0x0080, 0x1409: 0x0080, 0x140a: 0x0080, 0x140b: 0x0040, - 0x140c: 0x0040, 0x140d: 0x0040, 0x140e: 0x0040, 0x1410: 0x00c0, 0x1411: 0x00c0, - 0x1412: 0x00c0, 0x1413: 0x00c0, 0x1414: 0x00c0, 0x1415: 0x00c0, 0x1416: 0x00c0, 0x1417: 0x00c0, - 0x1418: 0x00c0, 0x1419: 0x00c0, - 0x1420: 0x00c2, 0x1421: 0x00c2, 0x1422: 0x00c2, 0x1423: 0x00c2, - 0x1424: 0x00c2, 0x1425: 0x00c2, 0x1426: 0x00c2, 0x1427: 0x00c2, 0x1428: 0x00c2, 0x1429: 0x00c2, - 0x142a: 0x00c2, 0x142b: 0x00c2, 0x142c: 0x00c2, 0x142d: 0x00c2, 0x142e: 0x00c2, 0x142f: 0x00c2, - 0x1430: 0x00c2, 0x1431: 0x00c2, 0x1432: 0x00c2, 0x1433: 0x00c2, 0x1434: 0x00c2, 0x1435: 0x00c2, - 0x1436: 0x00c2, 0x1437: 0x00c2, 0x1438: 0x00c2, 0x1439: 0x00c2, 0x143a: 0x00c2, 0x143b: 0x00c2, - 0x143c: 0x00c2, 0x143d: 0x00c2, 0x143e: 0x00c2, 0x143f: 0x00c2, - // Block 0x51, offset 0x1440 - 0x1440: 0x00c2, 0x1441: 0x00c2, 0x1442: 0x00c2, 0x1443: 0x00c2, 0x1444: 0x00c2, 0x1445: 0x00c2, - 0x1446: 0x00c2, 0x1447: 0x00c2, 0x1448: 0x00c2, 0x1449: 0x00c2, 0x144a: 0x00c2, 0x144b: 0x00c2, - 0x144c: 0x00c2, 0x144d: 0x00c2, 0x144e: 0x00c2, 0x144f: 0x00c2, 0x1450: 0x00c2, 0x1451: 0x00c2, - 0x1452: 0x00c2, 0x1453: 0x00c2, 0x1454: 0x00c2, 0x1455: 0x00c2, 0x1456: 0x00c2, 0x1457: 0x00c2, - 0x1458: 0x00c2, 0x1459: 0x00c2, 0x145a: 0x00c2, 0x145b: 0x00c2, 0x145c: 0x00c2, 0x145d: 0x00c2, - 0x145e: 0x00c2, 0x145f: 0x00c2, 0x1460: 0x00c2, 0x1461: 0x00c2, 0x1462: 0x00c2, 0x1463: 0x00c2, - 0x1464: 0x00c2, 0x1465: 0x00c2, 0x1466: 0x00c2, 0x1467: 0x00c2, 0x1468: 0x00c2, 0x1469: 0x00c2, - 0x146a: 0x00c2, 0x146b: 0x00c2, 0x146c: 0x00c2, 0x146d: 0x00c2, 0x146e: 0x00c2, 0x146f: 0x00c2, - 0x1470: 0x00c2, 0x1471: 0x00c2, 0x1472: 0x00c2, 0x1473: 0x00c2, 0x1474: 0x00c2, 0x1475: 0x00c2, - 0x1476: 0x00c2, 0x1477: 0x00c2, - // Block 0x52, offset 0x1480 - 0x1480: 0x00c0, 0x1481: 0x00c0, 0x1482: 0x00c0, 0x1483: 0x00c0, 0x1484: 0x00c0, 0x1485: 0x00c3, - 0x1486: 0x00c3, 0x1487: 0x00c2, 0x1488: 0x00c2, 0x1489: 0x00c2, 0x148a: 0x00c2, 0x148b: 0x00c2, - 0x148c: 0x00c2, 0x148d: 0x00c2, 0x148e: 0x00c2, 0x148f: 0x00c2, 0x1490: 0x00c2, 0x1491: 0x00c2, - 0x1492: 0x00c2, 0x1493: 0x00c2, 0x1494: 0x00c2, 0x1495: 0x00c2, 0x1496: 0x00c2, 0x1497: 0x00c2, - 0x1498: 0x00c2, 0x1499: 0x00c2, 0x149a: 0x00c2, 0x149b: 0x00c2, 0x149c: 0x00c2, 0x149d: 0x00c2, - 0x149e: 0x00c2, 0x149f: 0x00c2, 0x14a0: 0x00c2, 0x14a1: 0x00c2, 0x14a2: 0x00c2, 0x14a3: 0x00c2, - 0x14a4: 0x00c2, 0x14a5: 0x00c2, 0x14a6: 0x00c2, 0x14a7: 0x00c2, 0x14a8: 0x00c2, 0x14a9: 0x00c3, - 0x14aa: 0x00c2, - 0x14b0: 0x00c0, 0x14b1: 0x00c0, 0x14b2: 0x00c0, 0x14b3: 0x00c0, 0x14b4: 0x00c0, 0x14b5: 0x00c0, - 0x14b6: 0x00c0, 0x14b7: 0x00c0, 0x14b8: 0x00c0, 0x14b9: 0x00c0, 0x14ba: 0x00c0, 0x14bb: 0x00c0, - 0x14bc: 0x00c0, 0x14bd: 0x00c0, 0x14be: 0x00c0, 0x14bf: 0x00c0, - // Block 0x53, offset 0x14c0 - 0x14c0: 0x00c0, 0x14c1: 0x00c0, 0x14c2: 0x00c0, 0x14c3: 0x00c0, 0x14c4: 0x00c0, 0x14c5: 0x00c0, - 0x14c6: 0x00c0, 0x14c7: 0x00c0, 0x14c8: 0x00c0, 0x14c9: 0x00c0, 0x14ca: 0x00c0, 0x14cb: 0x00c0, - 0x14cc: 0x00c0, 0x14cd: 0x00c0, 0x14ce: 0x00c0, 0x14cf: 0x00c0, 0x14d0: 0x00c0, 0x14d1: 0x00c0, - 0x14d2: 0x00c0, 0x14d3: 0x00c0, 0x14d4: 0x00c0, 0x14d5: 0x00c0, 0x14d6: 0x00c0, 0x14d7: 0x00c0, - 0x14d8: 0x00c0, 0x14d9: 0x00c0, 0x14da: 0x00c0, 0x14db: 0x00c0, 0x14dc: 0x00c0, 0x14dd: 0x00c0, - 0x14de: 0x00c0, 0x14df: 0x00c0, 0x14e0: 0x00c0, 0x14e1: 0x00c0, 0x14e2: 0x00c0, 0x14e3: 0x00c0, - 0x14e4: 0x00c0, 0x14e5: 0x00c0, 0x14e6: 0x00c0, 0x14e7: 0x00c0, 0x14e8: 0x00c0, 0x14e9: 0x00c0, - 0x14ea: 0x00c0, 0x14eb: 0x00c0, 0x14ec: 0x00c0, 0x14ed: 0x00c0, 0x14ee: 0x00c0, 0x14ef: 0x00c0, - 0x14f0: 0x00c0, 0x14f1: 0x00c0, 0x14f2: 0x00c0, 0x14f3: 0x00c0, 0x14f4: 0x00c0, 0x14f5: 0x00c0, - // Block 0x54, offset 0x1500 - 0x1500: 0x00c0, 0x1501: 0x00c0, 0x1502: 0x00c0, 0x1503: 0x00c0, 0x1504: 0x00c0, 0x1505: 0x00c0, - 0x1506: 0x00c0, 0x1507: 0x00c0, 0x1508: 0x00c0, 0x1509: 0x00c0, 0x150a: 0x00c0, 0x150b: 0x00c0, - 0x150c: 0x00c0, 0x150d: 0x00c0, 0x150e: 0x00c0, 0x150f: 0x00c0, 0x1510: 0x00c0, 0x1511: 0x00c0, - 0x1512: 0x00c0, 0x1513: 0x00c0, 0x1514: 0x00c0, 0x1515: 0x00c0, 0x1516: 0x00c0, 0x1517: 0x00c0, - 0x1518: 0x00c0, 0x1519: 0x00c0, 0x151a: 0x00c0, 0x151b: 0x00c0, 0x151c: 0x00c0, 0x151d: 0x00c0, - 0x151e: 0x00c0, 0x1520: 0x00c3, 0x1521: 0x00c3, 0x1522: 0x00c3, 0x1523: 0x00c0, - 0x1524: 0x00c0, 0x1525: 0x00c0, 0x1526: 0x00c0, 0x1527: 0x00c3, 0x1528: 0x00c3, 0x1529: 0x00c0, - 0x152a: 0x00c0, 0x152b: 0x00c0, - 0x1530: 0x00c0, 0x1531: 0x00c0, 0x1532: 0x00c3, 0x1533: 0x00c0, 0x1534: 0x00c0, 0x1535: 0x00c0, - 0x1536: 0x00c0, 0x1537: 0x00c0, 0x1538: 0x00c0, 0x1539: 0x00c3, 0x153a: 0x00c3, 0x153b: 0x00c3, - // Block 0x55, offset 0x1540 - 0x1540: 0x0080, 0x1544: 0x0080, 0x1545: 0x0080, - 0x1546: 0x00c0, 0x1547: 0x00c0, 0x1548: 0x00c0, 0x1549: 0x00c0, 0x154a: 0x00c0, 0x154b: 0x00c0, - 0x154c: 0x00c0, 0x154d: 0x00c0, 0x154e: 0x00c0, 0x154f: 0x00c0, 0x1550: 0x00c0, 0x1551: 0x00c0, - 0x1552: 0x00c0, 0x1553: 0x00c0, 0x1554: 0x00c0, 0x1555: 0x00c0, 0x1556: 0x00c0, 0x1557: 0x00c0, - 0x1558: 0x00c0, 0x1559: 0x00c0, 0x155a: 0x00c0, 0x155b: 0x00c0, 0x155c: 0x00c0, 0x155d: 0x00c0, - 0x155e: 0x00c0, 0x155f: 0x00c0, 0x1560: 0x00c0, 0x1561: 0x00c0, 0x1562: 0x00c0, 0x1563: 0x00c0, - 0x1564: 0x00c0, 0x1565: 0x00c0, 0x1566: 0x00c0, 0x1567: 0x00c0, 0x1568: 0x00c0, 0x1569: 0x00c0, - 0x156a: 0x00c0, 0x156b: 0x00c0, 0x156c: 0x00c0, 0x156d: 0x00c0, - 0x1570: 0x00c0, 0x1571: 0x00c0, 0x1572: 0x00c0, 0x1573: 0x00c0, 0x1574: 0x00c0, - // Block 0x56, offset 0x1580 - 0x1580: 0x00c0, 0x1581: 0x00c0, 0x1582: 0x00c0, 0x1583: 0x00c0, 0x1584: 0x00c0, 0x1585: 0x00c0, - 0x1586: 0x00c0, 0x1587: 0x00c0, 0x1588: 0x00c0, 0x1589: 0x00c0, 0x158a: 0x00c0, 0x158b: 0x00c0, - 0x158c: 0x00c0, 0x158d: 0x00c0, 0x158e: 0x00c0, 0x158f: 0x00c0, 0x1590: 0x00c0, 0x1591: 0x00c0, - 0x1592: 0x00c0, 0x1593: 0x00c0, 0x1594: 0x00c0, 0x1595: 0x00c0, 0x1596: 0x00c0, 0x1597: 0x00c0, - 0x1598: 0x00c0, 0x1599: 0x00c0, 0x159a: 0x00c0, 0x159b: 0x00c0, 0x159c: 0x00c0, 0x159d: 0x00c0, - 0x159e: 0x00c0, 0x159f: 0x00c0, 0x15a0: 0x00c0, 0x15a1: 0x00c0, 0x15a2: 0x00c0, 0x15a3: 0x00c0, - 0x15a4: 0x00c0, 0x15a5: 0x00c0, 0x15a6: 0x00c0, 0x15a7: 0x00c0, 0x15a8: 0x00c0, 0x15a9: 0x00c0, - 0x15aa: 0x00c0, 0x15ab: 0x00c0, - 0x15b0: 0x00c0, 0x15b1: 0x00c0, 0x15b2: 0x00c0, 0x15b3: 0x00c0, 0x15b4: 0x00c0, 0x15b5: 0x00c0, - 0x15b6: 0x00c0, 0x15b7: 0x00c0, 0x15b8: 0x00c0, 0x15b9: 0x00c0, 0x15ba: 0x00c0, 0x15bb: 0x00c0, - 0x15bc: 0x00c0, 0x15bd: 0x00c0, 0x15be: 0x00c0, 0x15bf: 0x00c0, - // Block 0x57, offset 0x15c0 - 0x15c0: 0x00c0, 0x15c1: 0x00c0, 0x15c2: 0x00c0, 0x15c3: 0x00c0, 0x15c4: 0x00c0, 0x15c5: 0x00c0, - 0x15c6: 0x00c0, 0x15c7: 0x00c0, 0x15c8: 0x00c0, 0x15c9: 0x00c0, - 0x15d0: 0x00c0, 0x15d1: 0x00c0, - 0x15d2: 0x00c0, 0x15d3: 0x00c0, 0x15d4: 0x00c0, 0x15d5: 0x00c0, 0x15d6: 0x00c0, 0x15d7: 0x00c0, - 0x15d8: 0x00c0, 0x15d9: 0x00c0, 0x15da: 0x0080, - 0x15de: 0x0080, 0x15df: 0x0080, 0x15e0: 0x0080, 0x15e1: 0x0080, 0x15e2: 0x0080, 0x15e3: 0x0080, - 0x15e4: 0x0080, 0x15e5: 0x0080, 0x15e6: 0x0080, 0x15e7: 0x0080, 0x15e8: 0x0080, 0x15e9: 0x0080, - 0x15ea: 0x0080, 0x15eb: 0x0080, 0x15ec: 0x0080, 0x15ed: 0x0080, 0x15ee: 0x0080, 0x15ef: 0x0080, - 0x15f0: 0x0080, 0x15f1: 0x0080, 0x15f2: 0x0080, 0x15f3: 0x0080, 0x15f4: 0x0080, 0x15f5: 0x0080, - 0x15f6: 0x0080, 0x15f7: 0x0080, 0x15f8: 0x0080, 0x15f9: 0x0080, 0x15fa: 0x0080, 0x15fb: 0x0080, - 0x15fc: 0x0080, 0x15fd: 0x0080, 0x15fe: 0x0080, 0x15ff: 0x0080, - // Block 0x58, offset 0x1600 - 0x1600: 0x00c0, 0x1601: 0x00c0, 0x1602: 0x00c0, 0x1603: 0x00c0, 0x1604: 0x00c0, 0x1605: 0x00c0, - 0x1606: 0x00c0, 0x1607: 0x00c0, 0x1608: 0x00c0, 0x1609: 0x00c0, 0x160a: 0x00c0, 0x160b: 0x00c0, - 0x160c: 0x00c0, 0x160d: 0x00c0, 0x160e: 0x00c0, 0x160f: 0x00c0, 0x1610: 0x00c0, 0x1611: 0x00c0, - 0x1612: 0x00c0, 0x1613: 0x00c0, 0x1614: 0x00c0, 0x1615: 0x00c0, 0x1616: 0x00c0, 0x1617: 0x00c3, - 0x1618: 0x00c3, 0x1619: 0x00c0, 0x161a: 0x00c0, 0x161b: 0x00c3, - 0x161e: 0x0080, 0x161f: 0x0080, 0x1620: 0x00c0, 0x1621: 0x00c0, 0x1622: 0x00c0, 0x1623: 0x00c0, - 0x1624: 0x00c0, 0x1625: 0x00c0, 0x1626: 0x00c0, 0x1627: 0x00c0, 0x1628: 0x00c0, 0x1629: 0x00c0, - 0x162a: 0x00c0, 0x162b: 0x00c0, 0x162c: 0x00c0, 0x162d: 0x00c0, 0x162e: 0x00c0, 0x162f: 0x00c0, - 0x1630: 0x00c0, 0x1631: 0x00c0, 0x1632: 0x00c0, 0x1633: 0x00c0, 0x1634: 0x00c0, 0x1635: 0x00c0, - 0x1636: 0x00c0, 0x1637: 0x00c0, 0x1638: 0x00c0, 0x1639: 0x00c0, 0x163a: 0x00c0, 0x163b: 0x00c0, - 0x163c: 0x00c0, 0x163d: 0x00c0, 0x163e: 0x00c0, 0x163f: 0x00c0, - // Block 0x59, offset 0x1640 - 0x1640: 0x00c0, 0x1641: 0x00c0, 0x1642: 0x00c0, 0x1643: 0x00c0, 0x1644: 0x00c0, 0x1645: 0x00c0, - 0x1646: 0x00c0, 0x1647: 0x00c0, 0x1648: 0x00c0, 0x1649: 0x00c0, 0x164a: 0x00c0, 0x164b: 0x00c0, - 0x164c: 0x00c0, 0x164d: 0x00c0, 0x164e: 0x00c0, 0x164f: 0x00c0, 0x1650: 0x00c0, 0x1651: 0x00c0, - 0x1652: 0x00c0, 0x1653: 0x00c0, 0x1654: 0x00c0, 0x1655: 0x00c0, 0x1656: 0x00c3, 0x1657: 0x00c0, - 0x1658: 0x00c3, 0x1659: 0x00c3, 0x165a: 0x00c3, 0x165b: 0x00c3, 0x165c: 0x00c3, 0x165d: 0x00c3, - 0x165e: 0x00c3, 0x1660: 0x00c6, 0x1661: 0x00c0, 0x1662: 0x00c3, 0x1663: 0x00c0, - 0x1664: 0x00c0, 0x1665: 0x00c3, 0x1666: 0x00c3, 0x1667: 0x00c3, 0x1668: 0x00c3, 0x1669: 0x00c3, - 0x166a: 0x00c3, 0x166b: 0x00c3, 0x166c: 0x00c3, 0x166d: 0x00c0, 0x166e: 0x00c0, 0x166f: 0x00c0, - 0x1670: 0x00c0, 0x1671: 0x00c0, 0x1672: 0x00c0, 0x1673: 0x00c3, 0x1674: 0x00c3, 0x1675: 0x00c3, - 0x1676: 0x00c3, 0x1677: 0x00c3, 0x1678: 0x00c3, 0x1679: 0x00c3, 0x167a: 0x00c3, 0x167b: 0x00c3, - 0x167c: 0x00c3, 0x167f: 0x00c3, - // Block 0x5a, offset 0x1680 - 0x1680: 0x00c0, 0x1681: 0x00c0, 0x1682: 0x00c0, 0x1683: 0x00c0, 0x1684: 0x00c0, 0x1685: 0x00c0, - 0x1686: 0x00c0, 0x1687: 0x00c0, 0x1688: 0x00c0, 0x1689: 0x00c0, - 0x1690: 0x00c0, 0x1691: 0x00c0, - 0x1692: 0x00c0, 0x1693: 0x00c0, 0x1694: 0x00c0, 0x1695: 0x00c0, 0x1696: 0x00c0, 0x1697: 0x00c0, - 0x1698: 0x00c0, 0x1699: 0x00c0, - 0x16a0: 0x0080, 0x16a1: 0x0080, 0x16a2: 0x0080, 0x16a3: 0x0080, - 0x16a4: 0x0080, 0x16a5: 0x0080, 0x16a6: 0x0080, 0x16a7: 0x00c0, 0x16a8: 0x0080, 0x16a9: 0x0080, - 0x16aa: 0x0080, 0x16ab: 0x0080, 0x16ac: 0x0080, 0x16ad: 0x0080, - 0x16b0: 0x00c3, 0x16b1: 0x00c3, 0x16b2: 0x00c3, 0x16b3: 0x00c3, 0x16b4: 0x00c3, 0x16b5: 0x00c3, - 0x16b6: 0x00c3, 0x16b7: 0x00c3, 0x16b8: 0x00c3, 0x16b9: 0x00c3, 0x16ba: 0x00c3, 0x16bb: 0x00c3, - 0x16bc: 0x00c3, 0x16bd: 0x00c3, 0x16be: 0x0083, - // Block 0x5b, offset 0x16c0 - 0x16c0: 0x00c3, 0x16c1: 0x00c3, 0x16c2: 0x00c3, 0x16c3: 0x00c3, 0x16c4: 0x00c0, 0x16c5: 0x00c0, - 0x16c6: 0x00c0, 0x16c7: 0x00c0, 0x16c8: 0x00c0, 0x16c9: 0x00c0, 0x16ca: 0x00c0, 0x16cb: 0x00c0, - 0x16cc: 0x00c0, 0x16cd: 0x00c0, 0x16ce: 0x00c0, 0x16cf: 0x00c0, 0x16d0: 0x00c0, 0x16d1: 0x00c0, - 0x16d2: 0x00c0, 0x16d3: 0x00c0, 0x16d4: 0x00c0, 0x16d5: 0x00c0, 0x16d6: 0x00c0, 0x16d7: 0x00c0, - 0x16d8: 0x00c0, 0x16d9: 0x00c0, 0x16da: 0x00c0, 0x16db: 0x00c0, 0x16dc: 0x00c0, 0x16dd: 0x00c0, - 0x16de: 0x00c0, 0x16df: 0x00c0, 0x16e0: 0x00c0, 0x16e1: 0x00c0, 0x16e2: 0x00c0, 0x16e3: 0x00c0, - 0x16e4: 0x00c0, 0x16e5: 0x00c0, 0x16e6: 0x00c0, 0x16e7: 0x00c0, 0x16e8: 0x00c0, 0x16e9: 0x00c0, - 0x16ea: 0x00c0, 0x16eb: 0x00c0, 0x16ec: 0x00c0, 0x16ed: 0x00c0, 0x16ee: 0x00c0, 0x16ef: 0x00c0, - 0x16f0: 0x00c0, 0x16f1: 0x00c0, 0x16f2: 0x00c0, 0x16f3: 0x00c0, 0x16f4: 0x00c3, 0x16f5: 0x00c0, - 0x16f6: 0x00c3, 0x16f7: 0x00c3, 0x16f8: 0x00c3, 0x16f9: 0x00c3, 0x16fa: 0x00c3, 0x16fb: 0x00c0, - 0x16fc: 0x00c3, 0x16fd: 0x00c0, 0x16fe: 0x00c0, 0x16ff: 0x00c0, - // Block 0x5c, offset 0x1700 - 0x1700: 0x00c0, 0x1701: 0x00c0, 0x1702: 0x00c3, 0x1703: 0x00c0, 0x1704: 0x00c5, 0x1705: 0x00c0, - 0x1706: 0x00c0, 0x1707: 0x00c0, 0x1708: 0x00c0, 0x1709: 0x00c0, 0x170a: 0x00c0, 0x170b: 0x00c0, - 0x1710: 0x00c0, 0x1711: 0x00c0, - 0x1712: 0x00c0, 0x1713: 0x00c0, 0x1714: 0x00c0, 0x1715: 0x00c0, 0x1716: 0x00c0, 0x1717: 0x00c0, - 0x1718: 0x00c0, 0x1719: 0x00c0, 0x171a: 0x0080, 0x171b: 0x0080, 0x171c: 0x0080, 0x171d: 0x0080, - 0x171e: 0x0080, 0x171f: 0x0080, 0x1720: 0x0080, 0x1721: 0x0080, 0x1722: 0x0080, 0x1723: 0x0080, - 0x1724: 0x0080, 0x1725: 0x0080, 0x1726: 0x0080, 0x1727: 0x0080, 0x1728: 0x0080, 0x1729: 0x0080, - 0x172a: 0x0080, 0x172b: 0x00c3, 0x172c: 0x00c3, 0x172d: 0x00c3, 0x172e: 0x00c3, 0x172f: 0x00c3, - 0x1730: 0x00c3, 0x1731: 0x00c3, 0x1732: 0x00c3, 0x1733: 0x00c3, 0x1734: 0x0080, 0x1735: 0x0080, - 0x1736: 0x0080, 0x1737: 0x0080, 0x1738: 0x0080, 0x1739: 0x0080, 0x173a: 0x0080, 0x173b: 0x0080, - 0x173c: 0x0080, - // Block 0x5d, offset 0x1740 - 0x1740: 0x00c3, 0x1741: 0x00c3, 0x1742: 0x00c0, 0x1743: 0x00c0, 0x1744: 0x00c0, 0x1745: 0x00c0, - 0x1746: 0x00c0, 0x1747: 0x00c0, 0x1748: 0x00c0, 0x1749: 0x00c0, 0x174a: 0x00c0, 0x174b: 0x00c0, - 0x174c: 0x00c0, 0x174d: 0x00c0, 0x174e: 0x00c0, 0x174f: 0x00c0, 0x1750: 0x00c0, 0x1751: 0x00c0, - 0x1752: 0x00c0, 0x1753: 0x00c0, 0x1754: 0x00c0, 0x1755: 0x00c0, 0x1756: 0x00c0, 0x1757: 0x00c0, - 0x1758: 0x00c0, 0x1759: 0x00c0, 0x175a: 0x00c0, 0x175b: 0x00c0, 0x175c: 0x00c0, 0x175d: 0x00c0, - 0x175e: 0x00c0, 0x175f: 0x00c0, 0x1760: 0x00c0, 0x1761: 0x00c0, 0x1762: 0x00c3, 0x1763: 0x00c3, - 0x1764: 0x00c3, 0x1765: 0x00c3, 0x1766: 0x00c0, 0x1767: 0x00c0, 0x1768: 0x00c3, 0x1769: 0x00c3, - 0x176a: 0x00c5, 0x176b: 0x00c6, 0x176c: 0x00c3, 0x176d: 0x00c3, 0x176e: 0x00c0, 0x176f: 0x00c0, - 0x1770: 0x00c0, 0x1771: 0x00c0, 0x1772: 0x00c0, 0x1773: 0x00c0, 0x1774: 0x00c0, 0x1775: 0x00c0, - 0x1776: 0x00c0, 0x1777: 0x00c0, 0x1778: 0x00c0, 0x1779: 0x00c0, 0x177a: 0x00c0, 0x177b: 0x00c0, - 0x177c: 0x00c0, 0x177d: 0x00c0, 0x177e: 0x00c0, 0x177f: 0x00c0, - // Block 0x5e, offset 0x1780 - 0x1780: 0x00c0, 0x1781: 0x00c0, 0x1782: 0x00c0, 0x1783: 0x00c0, 0x1784: 0x00c0, 0x1785: 0x00c0, - 0x1786: 0x00c0, 0x1787: 0x00c0, 0x1788: 0x00c0, 0x1789: 0x00c0, 0x178a: 0x00c0, 0x178b: 0x00c0, - 0x178c: 0x00c0, 0x178d: 0x00c0, 0x178e: 0x00c0, 0x178f: 0x00c0, 0x1790: 0x00c0, 0x1791: 0x00c0, - 0x1792: 0x00c0, 0x1793: 0x00c0, 0x1794: 0x00c0, 0x1795: 0x00c0, 0x1796: 0x00c0, 0x1797: 0x00c0, - 0x1798: 0x00c0, 0x1799: 0x00c0, 0x179a: 0x00c0, 0x179b: 0x00c0, 0x179c: 0x00c0, 0x179d: 0x00c0, - 0x179e: 0x00c0, 0x179f: 0x00c0, 0x17a0: 0x00c0, 0x17a1: 0x00c0, 0x17a2: 0x00c0, 0x17a3: 0x00c0, - 0x17a4: 0x00c0, 0x17a5: 0x00c0, 0x17a6: 0x00c3, 0x17a7: 0x00c0, 0x17a8: 0x00c3, 0x17a9: 0x00c3, - 0x17aa: 0x00c0, 0x17ab: 0x00c0, 0x17ac: 0x00c0, 0x17ad: 0x00c3, 0x17ae: 0x00c0, 0x17af: 0x00c3, - 0x17b0: 0x00c3, 0x17b1: 0x00c3, 0x17b2: 0x00c5, 0x17b3: 0x00c5, - 0x17bc: 0x0080, 0x17bd: 0x0080, 0x17be: 0x0080, 0x17bf: 0x0080, - // Block 0x5f, offset 0x17c0 - 0x17c0: 0x00c0, 0x17c1: 0x00c0, 0x17c2: 0x00c0, 0x17c3: 0x00c0, 0x17c4: 0x00c0, 0x17c5: 0x00c0, - 0x17c6: 0x00c0, 0x17c7: 0x00c0, 0x17c8: 0x00c0, 0x17c9: 0x00c0, 0x17ca: 0x00c0, 0x17cb: 0x00c0, - 0x17cc: 0x00c0, 0x17cd: 0x00c0, 0x17ce: 0x00c0, 0x17cf: 0x00c0, 0x17d0: 0x00c0, 0x17d1: 0x00c0, - 0x17d2: 0x00c0, 0x17d3: 0x00c0, 0x17d4: 0x00c0, 0x17d5: 0x00c0, 0x17d6: 0x00c0, 0x17d7: 0x00c0, - 0x17d8: 0x00c0, 0x17d9: 0x00c0, 0x17da: 0x00c0, 0x17db: 0x00c0, 0x17dc: 0x00c0, 0x17dd: 0x00c0, - 0x17de: 0x00c0, 0x17df: 0x00c0, 0x17e0: 0x00c0, 0x17e1: 0x00c0, 0x17e2: 0x00c0, 0x17e3: 0x00c0, - 0x17e4: 0x00c0, 0x17e5: 0x00c0, 0x17e6: 0x00c0, 0x17e7: 0x00c0, 0x17e8: 0x00c0, 0x17e9: 0x00c0, - 0x17ea: 0x00c0, 0x17eb: 0x00c0, 0x17ec: 0x00c3, 0x17ed: 0x00c3, 0x17ee: 0x00c3, 0x17ef: 0x00c3, - 0x17f0: 0x00c3, 0x17f1: 0x00c3, 0x17f2: 0x00c3, 0x17f3: 0x00c3, 0x17f4: 0x00c0, 0x17f5: 0x00c0, - 0x17f6: 0x00c3, 0x17f7: 0x00c3, 0x17fb: 0x0080, - 0x17fc: 0x0080, 0x17fd: 0x0080, 0x17fe: 0x0080, 0x17ff: 0x0080, - // Block 0x60, offset 0x1800 - 0x1800: 0x00c0, 0x1801: 0x00c0, 0x1802: 0x00c0, 0x1803: 0x00c0, 0x1804: 0x00c0, 0x1805: 0x00c0, - 0x1806: 0x00c0, 0x1807: 0x00c0, 0x1808: 0x00c0, 0x1809: 0x00c0, - 0x180d: 0x00c0, 0x180e: 0x00c0, 0x180f: 0x00c0, 0x1810: 0x00c0, 0x1811: 0x00c0, - 0x1812: 0x00c0, 0x1813: 0x00c0, 0x1814: 0x00c0, 0x1815: 0x00c0, 0x1816: 0x00c0, 0x1817: 0x00c0, - 0x1818: 0x00c0, 0x1819: 0x00c0, 0x181a: 0x00c0, 0x181b: 0x00c0, 0x181c: 0x00c0, 0x181d: 0x00c0, - 0x181e: 0x00c0, 0x181f: 0x00c0, 0x1820: 0x00c0, 0x1821: 0x00c0, 0x1822: 0x00c0, 0x1823: 0x00c0, - 0x1824: 0x00c0, 0x1825: 0x00c0, 0x1826: 0x00c0, 0x1827: 0x00c0, 0x1828: 0x00c0, 0x1829: 0x00c0, - 0x182a: 0x00c0, 0x182b: 0x00c0, 0x182c: 0x00c0, 0x182d: 0x00c0, 0x182e: 0x00c0, 0x182f: 0x00c0, - 0x1830: 0x00c0, 0x1831: 0x00c0, 0x1832: 0x00c0, 0x1833: 0x00c0, 0x1834: 0x00c0, 0x1835: 0x00c0, - 0x1836: 0x00c0, 0x1837: 0x00c0, 0x1838: 0x00c0, 0x1839: 0x00c0, 0x183a: 0x00c0, 0x183b: 0x00c0, - 0x183c: 0x00c0, 0x183d: 0x00c0, 0x183e: 0x0080, 0x183f: 0x0080, - // Block 0x61, offset 0x1840 - 0x1840: 0x00c0, 0x1841: 0x00c0, 0x1842: 0x00c0, 0x1843: 0x00c0, 0x1844: 0x00c0, 0x1845: 0x00c0, - 0x1846: 0x00c0, 0x1847: 0x00c0, 0x1848: 0x00c0, - // Block 0x62, offset 0x1880 - 0x1880: 0x0080, 0x1881: 0x0080, 0x1882: 0x0080, 0x1883: 0x0080, 0x1884: 0x0080, 0x1885: 0x0080, - 0x1886: 0x0080, 0x1887: 0x0080, - 0x1890: 0x00c3, 0x1891: 0x00c3, - 0x1892: 0x00c3, 0x1893: 0x0080, 0x1894: 0x00c3, 0x1895: 0x00c3, 0x1896: 0x00c3, 0x1897: 0x00c3, - 0x1898: 0x00c3, 0x1899: 0x00c3, 0x189a: 0x00c3, 0x189b: 0x00c3, 0x189c: 0x00c3, 0x189d: 0x00c3, - 0x189e: 0x00c3, 0x189f: 0x00c3, 0x18a0: 0x00c3, 0x18a1: 0x00c0, 0x18a2: 0x00c3, 0x18a3: 0x00c3, - 0x18a4: 0x00c3, 0x18a5: 0x00c3, 0x18a6: 0x00c3, 0x18a7: 0x00c3, 0x18a8: 0x00c3, 0x18a9: 0x00c0, - 0x18aa: 0x00c0, 0x18ab: 0x00c0, 0x18ac: 0x00c0, 0x18ad: 0x00c3, 0x18ae: 0x00c0, 0x18af: 0x00c0, - 0x18b0: 0x00c0, 0x18b1: 0x00c0, 0x18b2: 0x00c0, 0x18b3: 0x00c0, 0x18b4: 0x00c3, 0x18b5: 0x00c0, - 0x18b6: 0x00c0, 0x18b8: 0x00c3, 0x18b9: 0x00c3, - // Block 0x63, offset 0x18c0 - 0x18c0: 0x00c0, 0x18c1: 0x00c0, 0x18c2: 0x00c0, 0x18c3: 0x00c0, 0x18c4: 0x00c0, 0x18c5: 0x00c0, - 0x18c6: 0x00c0, 0x18c7: 0x00c0, 0x18c8: 0x00c0, 0x18c9: 0x00c0, 0x18ca: 0x00c0, 0x18cb: 0x00c0, - 0x18cc: 0x00c0, 0x18cd: 0x00c0, 0x18ce: 0x00c0, 0x18cf: 0x00c0, 0x18d0: 0x00c0, 0x18d1: 0x00c0, - 0x18d2: 0x00c0, 0x18d3: 0x00c0, 0x18d4: 0x00c0, 0x18d5: 0x00c0, 0x18d6: 0x00c0, 0x18d7: 0x00c0, - 0x18d8: 0x00c0, 0x18d9: 0x00c0, 0x18da: 0x00c0, 0x18db: 0x00c0, 0x18dc: 0x00c0, 0x18dd: 0x00c0, - 0x18de: 0x00c0, 0x18df: 0x00c0, 0x18e0: 0x00c0, 0x18e1: 0x00c0, 0x18e2: 0x00c0, 0x18e3: 0x00c0, - 0x18e4: 0x00c0, 0x18e5: 0x00c0, 0x18e6: 0x00c8, 0x18e7: 0x00c8, 0x18e8: 0x00c8, 0x18e9: 0x00c8, - 0x18ea: 0x00c8, 0x18eb: 0x00c0, 0x18ec: 0x0080, 0x18ed: 0x0080, 0x18ee: 0x0080, 0x18ef: 0x00c0, - 0x18f0: 0x0080, 0x18f1: 0x0080, 0x18f2: 0x0080, 0x18f3: 0x0080, 0x18f4: 0x0080, 0x18f5: 0x0080, - 0x18f6: 0x0080, 0x18f7: 0x0080, 0x18f8: 0x0080, 0x18f9: 0x0080, 0x18fa: 0x0080, 0x18fb: 0x00c0, - 0x18fc: 0x0080, 0x18fd: 0x0080, 0x18fe: 0x0080, 0x18ff: 0x0080, - // Block 0x64, offset 0x1900 - 0x1900: 0x0080, 0x1901: 0x0080, 0x1902: 0x0080, 0x1903: 0x0080, 0x1904: 0x0080, 0x1905: 0x0080, - 0x1906: 0x0080, 0x1907: 0x0080, 0x1908: 0x0080, 0x1909: 0x0080, 0x190a: 0x0080, 0x190b: 0x0080, - 0x190c: 0x0080, 0x190d: 0x0080, 0x190e: 0x00c0, 0x190f: 0x0080, 0x1910: 0x0080, 0x1911: 0x0080, - 0x1912: 0x0080, 0x1913: 0x0080, 0x1914: 0x0080, 0x1915: 0x0080, 0x1916: 0x0080, 0x1917: 0x0080, - 0x1918: 0x0080, 0x1919: 0x0080, 0x191a: 0x0080, 0x191b: 0x0080, 0x191c: 0x0080, 0x191d: 0x0088, - 0x191e: 0x0088, 0x191f: 0x0088, 0x1920: 0x0088, 0x1921: 0x0088, 0x1922: 0x0080, 0x1923: 0x0080, - 0x1924: 0x0080, 0x1925: 0x0080, 0x1926: 0x0088, 0x1927: 0x0088, 0x1928: 0x0088, 0x1929: 0x0088, - 0x192a: 0x0088, 0x192b: 0x00c0, 0x192c: 0x00c0, 0x192d: 0x00c0, 0x192e: 0x00c0, 0x192f: 0x00c0, - 0x1930: 0x00c0, 0x1931: 0x00c0, 0x1932: 0x00c0, 0x1933: 0x00c0, 0x1934: 0x00c0, 0x1935: 0x00c0, - 0x1936: 0x00c0, 0x1937: 0x00c0, 0x1938: 0x0080, 0x1939: 0x00c0, 0x193a: 0x00c0, 0x193b: 0x00c0, - 0x193c: 0x00c0, 0x193d: 0x00c0, 0x193e: 0x00c0, 0x193f: 0x00c0, - // Block 0x65, offset 0x1940 - 0x1940: 0x00c0, 0x1941: 0x00c0, 0x1942: 0x00c0, 0x1943: 0x00c0, 0x1944: 0x00c0, 0x1945: 0x00c0, - 0x1946: 0x00c0, 0x1947: 0x00c0, 0x1948: 0x00c0, 0x1949: 0x00c0, 0x194a: 0x00c0, 0x194b: 0x00c0, - 0x194c: 0x00c0, 0x194d: 0x00c0, 0x194e: 0x00c0, 0x194f: 0x00c0, 0x1950: 0x00c0, 0x1951: 0x00c0, - 0x1952: 0x00c0, 0x1953: 0x00c0, 0x1954: 0x00c0, 0x1955: 0x00c0, 0x1956: 0x00c0, 0x1957: 0x00c0, - 0x1958: 0x00c0, 0x1959: 0x00c0, 0x195a: 0x00c0, 0x195b: 0x0080, 0x195c: 0x0080, 0x195d: 0x0080, - 0x195e: 0x0080, 0x195f: 0x0080, 0x1960: 0x0080, 0x1961: 0x0080, 0x1962: 0x0080, 0x1963: 0x0080, - 0x1964: 0x0080, 0x1965: 0x0080, 0x1966: 0x0080, 0x1967: 0x0080, 0x1968: 0x0080, 0x1969: 0x0080, - 0x196a: 0x0080, 0x196b: 0x0080, 0x196c: 0x0080, 0x196d: 0x0080, 0x196e: 0x0080, 0x196f: 0x0080, - 0x1970: 0x0080, 0x1971: 0x0080, 0x1972: 0x0080, 0x1973: 0x0080, 0x1974: 0x0080, 0x1975: 0x0080, - 0x1976: 0x0080, 0x1977: 0x0080, 0x1978: 0x0080, 0x1979: 0x0080, 0x197a: 0x0080, 0x197b: 0x0080, - 0x197c: 0x0080, 0x197d: 0x0080, 0x197e: 0x0080, 0x197f: 0x0088, - // Block 0x66, offset 0x1980 - 0x1980: 0x00c3, 0x1981: 0x00c3, 0x1982: 0x00c3, 0x1983: 0x00c3, 0x1984: 0x00c3, 0x1985: 0x00c3, - 0x1986: 0x00c3, 0x1987: 0x00c3, 0x1988: 0x00c3, 0x1989: 0x00c3, 0x198a: 0x00c3, 0x198b: 0x00c3, - 0x198c: 0x00c3, 0x198d: 0x00c3, 0x198e: 0x00c3, 0x198f: 0x00c3, 0x1990: 0x00c3, 0x1991: 0x00c3, - 0x1992: 0x00c3, 0x1993: 0x00c3, 0x1994: 0x00c3, 0x1995: 0x00c3, 0x1996: 0x00c3, 0x1997: 0x00c3, - 0x1998: 0x00c3, 0x1999: 0x00c3, 0x199a: 0x00c3, 0x199b: 0x00c3, 0x199c: 0x00c3, 0x199d: 0x00c3, - 0x199e: 0x00c3, 0x199f: 0x00c3, 0x19a0: 0x00c3, 0x19a1: 0x00c3, 0x19a2: 0x00c3, 0x19a3: 0x00c3, - 0x19a4: 0x00c3, 0x19a5: 0x00c3, 0x19a6: 0x00c3, 0x19a7: 0x00c3, 0x19a8: 0x00c3, 0x19a9: 0x00c3, - 0x19aa: 0x00c3, 0x19ab: 0x00c3, 0x19ac: 0x00c3, 0x19ad: 0x00c3, 0x19ae: 0x00c3, 0x19af: 0x00c3, - 0x19b0: 0x00c3, 0x19b1: 0x00c3, 0x19b2: 0x00c3, 0x19b3: 0x00c3, 0x19b4: 0x00c3, 0x19b5: 0x00c3, - 0x19bb: 0x00c3, - 0x19bc: 0x00c3, 0x19bd: 0x00c3, 0x19be: 0x00c3, 0x19bf: 0x00c3, - // Block 0x67, offset 0x19c0 - 0x19c0: 0x00c0, 0x19c1: 0x00c0, 0x19c2: 0x00c0, 0x19c3: 0x00c0, 0x19c4: 0x00c0, 0x19c5: 0x00c0, - 0x19c6: 0x00c0, 0x19c7: 0x00c0, 0x19c8: 0x00c0, 0x19c9: 0x00c0, 0x19ca: 0x00c0, 0x19cb: 0x00c0, - 0x19cc: 0x00c0, 0x19cd: 0x00c0, 0x19ce: 0x00c0, 0x19cf: 0x00c0, 0x19d0: 0x00c0, 0x19d1: 0x00c0, - 0x19d2: 0x00c0, 0x19d3: 0x00c0, 0x19d4: 0x00c0, 0x19d5: 0x00c0, 0x19d6: 0x00c0, 0x19d7: 0x00c0, - 0x19d8: 0x00c0, 0x19d9: 0x00c0, 0x19da: 0x0080, 0x19db: 0x0080, 0x19dc: 0x00c0, 0x19dd: 0x00c0, - 0x19de: 0x00c0, 0x19df: 0x00c0, 0x19e0: 0x00c0, 0x19e1: 0x00c0, 0x19e2: 0x00c0, 0x19e3: 0x00c0, - 0x19e4: 0x00c0, 0x19e5: 0x00c0, 0x19e6: 0x00c0, 0x19e7: 0x00c0, 0x19e8: 0x00c0, 0x19e9: 0x00c0, - 0x19ea: 0x00c0, 0x19eb: 0x00c0, 0x19ec: 0x00c0, 0x19ed: 0x00c0, 0x19ee: 0x00c0, 0x19ef: 0x00c0, - 0x19f0: 0x00c0, 0x19f1: 0x00c0, 0x19f2: 0x00c0, 0x19f3: 0x00c0, 0x19f4: 0x00c0, 0x19f5: 0x00c0, - 0x19f6: 0x00c0, 0x19f7: 0x00c0, 0x19f8: 0x00c0, 0x19f9: 0x00c0, 0x19fa: 0x00c0, 0x19fb: 0x00c0, - 0x19fc: 0x00c0, 0x19fd: 0x00c0, 0x19fe: 0x00c0, 0x19ff: 0x00c0, - // Block 0x68, offset 0x1a00 - 0x1a00: 0x00c8, 0x1a01: 0x00c8, 0x1a02: 0x00c8, 0x1a03: 0x00c8, 0x1a04: 0x00c8, 0x1a05: 0x00c8, - 0x1a06: 0x00c8, 0x1a07: 0x00c8, 0x1a08: 0x00c8, 0x1a09: 0x00c8, 0x1a0a: 0x00c8, 0x1a0b: 0x00c8, - 0x1a0c: 0x00c8, 0x1a0d: 0x00c8, 0x1a0e: 0x00c8, 0x1a0f: 0x00c8, 0x1a10: 0x00c8, 0x1a11: 0x00c8, - 0x1a12: 0x00c8, 0x1a13: 0x00c8, 0x1a14: 0x00c8, 0x1a15: 0x00c8, - 0x1a18: 0x00c8, 0x1a19: 0x00c8, 0x1a1a: 0x00c8, 0x1a1b: 0x00c8, 0x1a1c: 0x00c8, 0x1a1d: 0x00c8, - 0x1a20: 0x00c8, 0x1a21: 0x00c8, 0x1a22: 0x00c8, 0x1a23: 0x00c8, - 0x1a24: 0x00c8, 0x1a25: 0x00c8, 0x1a26: 0x00c8, 0x1a27: 0x00c8, 0x1a28: 0x00c8, 0x1a29: 0x00c8, - 0x1a2a: 0x00c8, 0x1a2b: 0x00c8, 0x1a2c: 0x00c8, 0x1a2d: 0x00c8, 0x1a2e: 0x00c8, 0x1a2f: 0x00c8, - 0x1a30: 0x00c8, 0x1a31: 0x00c8, 0x1a32: 0x00c8, 0x1a33: 0x00c8, 0x1a34: 0x00c8, 0x1a35: 0x00c8, - 0x1a36: 0x00c8, 0x1a37: 0x00c8, 0x1a38: 0x00c8, 0x1a39: 0x00c8, 0x1a3a: 0x00c8, 0x1a3b: 0x00c8, - 0x1a3c: 0x00c8, 0x1a3d: 0x00c8, 0x1a3e: 0x00c8, 0x1a3f: 0x00c8, - // Block 0x69, offset 0x1a40 - 0x1a40: 0x00c8, 0x1a41: 0x00c8, 0x1a42: 0x00c8, 0x1a43: 0x00c8, 0x1a44: 0x00c8, 0x1a45: 0x00c8, - 0x1a48: 0x00c8, 0x1a49: 0x00c8, 0x1a4a: 0x00c8, 0x1a4b: 0x00c8, - 0x1a4c: 0x00c8, 0x1a4d: 0x00c8, 0x1a50: 0x00c8, 0x1a51: 0x00c8, - 0x1a52: 0x00c8, 0x1a53: 0x00c8, 0x1a54: 0x00c8, 0x1a55: 0x00c8, 0x1a56: 0x00c8, 0x1a57: 0x00c8, - 0x1a59: 0x00c8, 0x1a5b: 0x00c8, 0x1a5d: 0x00c8, - 0x1a5f: 0x00c8, 0x1a60: 0x00c8, 0x1a61: 0x00c8, 0x1a62: 0x00c8, 0x1a63: 0x00c8, - 0x1a64: 0x00c8, 0x1a65: 0x00c8, 0x1a66: 0x00c8, 0x1a67: 0x00c8, 0x1a68: 0x00c8, 0x1a69: 0x00c8, - 0x1a6a: 0x00c8, 0x1a6b: 0x00c8, 0x1a6c: 0x00c8, 0x1a6d: 0x00c8, 0x1a6e: 0x00c8, 0x1a6f: 0x00c8, - 0x1a70: 0x00c8, 0x1a71: 0x0088, 0x1a72: 0x00c8, 0x1a73: 0x0088, 0x1a74: 0x00c8, 0x1a75: 0x0088, - 0x1a76: 0x00c8, 0x1a77: 0x0088, 0x1a78: 0x00c8, 0x1a79: 0x0088, 0x1a7a: 0x00c8, 0x1a7b: 0x0088, - 0x1a7c: 0x00c8, 0x1a7d: 0x0088, - // Block 0x6a, offset 0x1a80 - 0x1a80: 0x00c8, 0x1a81: 0x00c8, 0x1a82: 0x00c8, 0x1a83: 0x00c8, 0x1a84: 0x00c8, 0x1a85: 0x00c8, - 0x1a86: 0x00c8, 0x1a87: 0x00c8, 0x1a88: 0x0088, 0x1a89: 0x0088, 0x1a8a: 0x0088, 0x1a8b: 0x0088, - 0x1a8c: 0x0088, 0x1a8d: 0x0088, 0x1a8e: 0x0088, 0x1a8f: 0x0088, 0x1a90: 0x00c8, 0x1a91: 0x00c8, - 0x1a92: 0x00c8, 0x1a93: 0x00c8, 0x1a94: 0x00c8, 0x1a95: 0x00c8, 0x1a96: 0x00c8, 0x1a97: 0x00c8, - 0x1a98: 0x0088, 0x1a99: 0x0088, 0x1a9a: 0x0088, 0x1a9b: 0x0088, 0x1a9c: 0x0088, 0x1a9d: 0x0088, - 0x1a9e: 0x0088, 0x1a9f: 0x0088, 0x1aa0: 0x00c8, 0x1aa1: 0x00c8, 0x1aa2: 0x00c8, 0x1aa3: 0x00c8, - 0x1aa4: 0x00c8, 0x1aa5: 0x00c8, 0x1aa6: 0x00c8, 0x1aa7: 0x00c8, 0x1aa8: 0x0088, 0x1aa9: 0x0088, - 0x1aaa: 0x0088, 0x1aab: 0x0088, 0x1aac: 0x0088, 0x1aad: 0x0088, 0x1aae: 0x0088, 0x1aaf: 0x0088, - 0x1ab0: 0x00c8, 0x1ab1: 0x00c8, 0x1ab2: 0x00c8, 0x1ab3: 0x00c8, 0x1ab4: 0x00c8, - 0x1ab6: 0x00c8, 0x1ab7: 0x00c8, 0x1ab8: 0x00c8, 0x1ab9: 0x00c8, 0x1aba: 0x00c8, 0x1abb: 0x0088, - 0x1abc: 0x0088, 0x1abd: 0x0088, 0x1abe: 0x0088, 0x1abf: 0x0088, - // Block 0x6b, offset 0x1ac0 - 0x1ac0: 0x0088, 0x1ac1: 0x0088, 0x1ac2: 0x00c8, 0x1ac3: 0x00c8, 0x1ac4: 0x00c8, - 0x1ac6: 0x00c8, 0x1ac7: 0x00c8, 0x1ac8: 0x00c8, 0x1ac9: 0x0088, 0x1aca: 0x00c8, 0x1acb: 0x0088, - 0x1acc: 0x0088, 0x1acd: 0x0088, 0x1ace: 0x0088, 0x1acf: 0x0088, 0x1ad0: 0x00c8, 0x1ad1: 0x00c8, - 0x1ad2: 0x00c8, 0x1ad3: 0x0088, 0x1ad6: 0x00c8, 0x1ad7: 0x00c8, - 0x1ad8: 0x00c8, 0x1ad9: 0x00c8, 0x1ada: 0x00c8, 0x1adb: 0x0088, 0x1add: 0x0088, - 0x1ade: 0x0088, 0x1adf: 0x0088, 0x1ae0: 0x00c8, 0x1ae1: 0x00c8, 0x1ae2: 0x00c8, 0x1ae3: 0x0088, - 0x1ae4: 0x00c8, 0x1ae5: 0x00c8, 0x1ae6: 0x00c8, 0x1ae7: 0x00c8, 0x1ae8: 0x00c8, 0x1ae9: 0x00c8, - 0x1aea: 0x00c8, 0x1aeb: 0x0088, 0x1aec: 0x00c8, 0x1aed: 0x0088, 0x1aee: 0x0088, 0x1aef: 0x0088, - 0x1af2: 0x00c8, 0x1af3: 0x00c8, 0x1af4: 0x00c8, - 0x1af6: 0x00c8, 0x1af7: 0x00c8, 0x1af8: 0x00c8, 0x1af9: 0x0088, 0x1afa: 0x00c8, 0x1afb: 0x0088, - 0x1afc: 0x0088, 0x1afd: 0x0088, 0x1afe: 0x0088, - // Block 0x6c, offset 0x1b00 - 0x1b00: 0x0080, 0x1b01: 0x0080, 0x1b02: 0x0080, 0x1b03: 0x0080, 0x1b04: 0x0080, 0x1b05: 0x0080, - 0x1b06: 0x0080, 0x1b07: 0x0080, 0x1b08: 0x0080, 0x1b09: 0x0080, 0x1b0a: 0x0080, 0x1b0b: 0x0040, - 0x1b0c: 0x004d, 0x1b0d: 0x004e, 0x1b0e: 0x0040, 0x1b0f: 0x0040, 0x1b10: 0x0080, 0x1b11: 0x0080, - 0x1b12: 0x0080, 0x1b13: 0x0080, 0x1b14: 0x0080, 0x1b15: 0x0080, 0x1b16: 0x0080, 0x1b17: 0x0080, - 0x1b18: 0x0080, 0x1b19: 0x0080, 0x1b1a: 0x0080, 0x1b1b: 0x0080, 0x1b1c: 0x0080, 0x1b1d: 0x0080, - 0x1b1e: 0x0080, 0x1b1f: 0x0080, 0x1b20: 0x0080, 0x1b21: 0x0080, 0x1b22: 0x0080, 0x1b23: 0x0080, - 0x1b24: 0x0080, 0x1b25: 0x0080, 0x1b26: 0x0080, 0x1b27: 0x0080, 0x1b28: 0x0040, 0x1b29: 0x0040, - 0x1b2a: 0x0040, 0x1b2b: 0x0040, 0x1b2c: 0x0040, 0x1b2d: 0x0040, 0x1b2e: 0x0040, 0x1b2f: 0x0080, - 0x1b30: 0x0080, 0x1b31: 0x0080, 0x1b32: 0x0080, 0x1b33: 0x0080, 0x1b34: 0x0080, 0x1b35: 0x0080, - 0x1b36: 0x0080, 0x1b37: 0x0080, 0x1b38: 0x0080, 0x1b39: 0x0080, 0x1b3a: 0x0080, 0x1b3b: 0x0080, - 0x1b3c: 0x0080, 0x1b3d: 0x0080, 0x1b3e: 0x0080, 0x1b3f: 0x0080, - // Block 0x6d, offset 0x1b40 - 0x1b40: 0x0080, 0x1b41: 0x0080, 0x1b42: 0x0080, 0x1b43: 0x0080, 0x1b44: 0x0080, 0x1b45: 0x0080, - 0x1b46: 0x0080, 0x1b47: 0x0080, 0x1b48: 0x0080, 0x1b49: 0x0080, 0x1b4a: 0x0080, 0x1b4b: 0x0080, - 0x1b4c: 0x0080, 0x1b4d: 0x0080, 0x1b4e: 0x0080, 0x1b4f: 0x0080, 0x1b50: 0x0080, 0x1b51: 0x0080, - 0x1b52: 0x0080, 0x1b53: 0x0080, 0x1b54: 0x0080, 0x1b55: 0x0080, 0x1b56: 0x0080, 0x1b57: 0x0080, - 0x1b58: 0x0080, 0x1b59: 0x0080, 0x1b5a: 0x0080, 0x1b5b: 0x0080, 0x1b5c: 0x0080, 0x1b5d: 0x0080, - 0x1b5e: 0x0080, 0x1b5f: 0x0080, 0x1b60: 0x0040, 0x1b61: 0x0040, 0x1b62: 0x0040, 0x1b63: 0x0040, - 0x1b64: 0x0040, 0x1b66: 0x0040, 0x1b67: 0x0040, 0x1b68: 0x0040, 0x1b69: 0x0040, - 0x1b6a: 0x0040, 0x1b6b: 0x0040, 0x1b6c: 0x0040, 0x1b6d: 0x0040, 0x1b6e: 0x0040, 0x1b6f: 0x0040, - 0x1b70: 0x0080, 0x1b71: 0x0080, 0x1b74: 0x0080, 0x1b75: 0x0080, - 0x1b76: 0x0080, 0x1b77: 0x0080, 0x1b78: 0x0080, 0x1b79: 0x0080, 0x1b7a: 0x0080, 0x1b7b: 0x0080, - 0x1b7c: 0x0080, 0x1b7d: 0x0080, 0x1b7e: 0x0080, 0x1b7f: 0x0080, - // Block 0x6e, offset 0x1b80 - 0x1b80: 0x0080, 0x1b81: 0x0080, 0x1b82: 0x0080, 0x1b83: 0x0080, 0x1b84: 0x0080, 0x1b85: 0x0080, - 0x1b86: 0x0080, 0x1b87: 0x0080, 0x1b88: 0x0080, 0x1b89: 0x0080, 0x1b8a: 0x0080, 0x1b8b: 0x0080, - 0x1b8c: 0x0080, 0x1b8d: 0x0080, 0x1b8e: 0x0080, 0x1b90: 0x0080, 0x1b91: 0x0080, - 0x1b92: 0x0080, 0x1b93: 0x0080, 0x1b94: 0x0080, 0x1b95: 0x0080, 0x1b96: 0x0080, 0x1b97: 0x0080, - 0x1b98: 0x0080, 0x1b99: 0x0080, 0x1b9a: 0x0080, 0x1b9b: 0x0080, 0x1b9c: 0x0080, - 0x1ba0: 0x0080, 0x1ba1: 0x0080, 0x1ba2: 0x0080, 0x1ba3: 0x0080, - 0x1ba4: 0x0080, 0x1ba5: 0x0080, 0x1ba6: 0x0080, 0x1ba7: 0x0080, 0x1ba8: 0x0080, 0x1ba9: 0x0080, - 0x1baa: 0x0080, 0x1bab: 0x0080, 0x1bac: 0x0080, 0x1bad: 0x0080, 0x1bae: 0x0080, 0x1baf: 0x0080, - 0x1bb0: 0x0080, 0x1bb1: 0x0080, 0x1bb2: 0x0080, 0x1bb3: 0x0080, 0x1bb4: 0x0080, 0x1bb5: 0x0080, - 0x1bb6: 0x0080, 0x1bb7: 0x0080, 0x1bb8: 0x0080, 0x1bb9: 0x0080, 0x1bba: 0x0080, 0x1bbb: 0x0080, - 0x1bbc: 0x0080, 0x1bbd: 0x0080, 0x1bbe: 0x0080, - // Block 0x6f, offset 0x1bc0 - 0x1bd0: 0x00c3, 0x1bd1: 0x00c3, - 0x1bd2: 0x00c3, 0x1bd3: 0x00c3, 0x1bd4: 0x00c3, 0x1bd5: 0x00c3, 0x1bd6: 0x00c3, 0x1bd7: 0x00c3, - 0x1bd8: 0x00c3, 0x1bd9: 0x00c3, 0x1bda: 0x00c3, 0x1bdb: 0x00c3, 0x1bdc: 0x00c3, 0x1bdd: 0x0083, - 0x1bde: 0x0083, 0x1bdf: 0x0083, 0x1be0: 0x0083, 0x1be1: 0x00c3, 0x1be2: 0x0083, 0x1be3: 0x0083, - 0x1be4: 0x0083, 0x1be5: 0x00c3, 0x1be6: 0x00c3, 0x1be7: 0x00c3, 0x1be8: 0x00c3, 0x1be9: 0x00c3, - 0x1bea: 0x00c3, 0x1beb: 0x00c3, 0x1bec: 0x00c3, 0x1bed: 0x00c3, 0x1bee: 0x00c3, 0x1bef: 0x00c3, - 0x1bf0: 0x00c3, - // Block 0x70, offset 0x1c00 - 0x1c00: 0x0080, 0x1c01: 0x0080, 0x1c02: 0x0080, 0x1c03: 0x0080, 0x1c04: 0x0080, 0x1c05: 0x0080, - 0x1c06: 0x0080, 0x1c07: 0x0080, 0x1c08: 0x0080, 0x1c09: 0x0080, 0x1c0a: 0x0080, 0x1c0b: 0x0080, - 0x1c0c: 0x0080, 0x1c0d: 0x0080, 0x1c0e: 0x0080, 0x1c0f: 0x0080, 0x1c10: 0x0080, 0x1c11: 0x0080, - 0x1c12: 0x0080, 0x1c13: 0x0080, 0x1c14: 0x0080, 0x1c15: 0x0080, 0x1c16: 0x0080, 0x1c17: 0x0080, - 0x1c18: 0x0080, 0x1c19: 0x0080, 0x1c1a: 0x0080, 0x1c1b: 0x0080, 0x1c1c: 0x0080, 0x1c1d: 0x0080, - 0x1c1e: 0x0080, 0x1c1f: 0x0080, 0x1c20: 0x0080, 0x1c21: 0x0080, 0x1c22: 0x0080, 0x1c23: 0x0080, - 0x1c24: 0x0080, 0x1c25: 0x0080, 0x1c26: 0x0088, 0x1c27: 0x0080, 0x1c28: 0x0080, 0x1c29: 0x0080, - 0x1c2a: 0x0080, 0x1c2b: 0x0080, 0x1c2c: 0x0080, 0x1c2d: 0x0080, 0x1c2e: 0x0080, 0x1c2f: 0x0080, - 0x1c30: 0x0080, 0x1c31: 0x0080, 0x1c32: 0x00c0, 0x1c33: 0x0080, 0x1c34: 0x0080, 0x1c35: 0x0080, - 0x1c36: 0x0080, 0x1c37: 0x0080, 0x1c38: 0x0080, 0x1c39: 0x0080, 0x1c3a: 0x0080, 0x1c3b: 0x0080, - 0x1c3c: 0x0080, 0x1c3d: 0x0080, 0x1c3e: 0x0080, 0x1c3f: 0x0080, - // Block 0x71, offset 0x1c40 - 0x1c40: 0x0080, 0x1c41: 0x0080, 0x1c42: 0x0080, 0x1c43: 0x0080, 0x1c44: 0x0080, 0x1c45: 0x0080, - 0x1c46: 0x0080, 0x1c47: 0x0080, 0x1c48: 0x0080, 0x1c49: 0x0080, 0x1c4a: 0x0080, 0x1c4b: 0x0080, - 0x1c4c: 0x0080, 0x1c4d: 0x0080, 0x1c4e: 0x00c0, 0x1c4f: 0x0080, 0x1c50: 0x0080, 0x1c51: 0x0080, - 0x1c52: 0x0080, 0x1c53: 0x0080, 0x1c54: 0x0080, 0x1c55: 0x0080, 0x1c56: 0x0080, 0x1c57: 0x0080, - 0x1c58: 0x0080, 0x1c59: 0x0080, 0x1c5a: 0x0080, 0x1c5b: 0x0080, 0x1c5c: 0x0080, 0x1c5d: 0x0080, - 0x1c5e: 0x0080, 0x1c5f: 0x0080, 0x1c60: 0x0080, 0x1c61: 0x0080, 0x1c62: 0x0080, 0x1c63: 0x0080, - 0x1c64: 0x0080, 0x1c65: 0x0080, 0x1c66: 0x0080, 0x1c67: 0x0080, 0x1c68: 0x0080, 0x1c69: 0x0080, - 0x1c6a: 0x0080, 0x1c6b: 0x0080, 0x1c6c: 0x0080, 0x1c6d: 0x0080, 0x1c6e: 0x0080, 0x1c6f: 0x0080, - 0x1c70: 0x0080, 0x1c71: 0x0080, 0x1c72: 0x0080, 0x1c73: 0x0080, 0x1c74: 0x0080, 0x1c75: 0x0080, - 0x1c76: 0x0080, 0x1c77: 0x0080, 0x1c78: 0x0080, 0x1c79: 0x0080, 0x1c7a: 0x0080, 0x1c7b: 0x0080, - 0x1c7c: 0x0080, 0x1c7d: 0x0080, 0x1c7e: 0x0080, 0x1c7f: 0x0080, - // Block 0x72, offset 0x1c80 - 0x1c80: 0x0080, 0x1c81: 0x0080, 0x1c82: 0x0080, 0x1c83: 0x00c0, 0x1c84: 0x00c0, 0x1c85: 0x0080, - 0x1c86: 0x0080, 0x1c87: 0x0080, 0x1c88: 0x0080, 0x1c89: 0x0080, 0x1c8a: 0x0080, 0x1c8b: 0x0080, - 0x1c90: 0x0080, 0x1c91: 0x0080, - 0x1c92: 0x0080, 0x1c93: 0x0080, 0x1c94: 0x0080, 0x1c95: 0x0080, 0x1c96: 0x0080, 0x1c97: 0x0080, - 0x1c98: 0x0080, 0x1c99: 0x0080, 0x1c9a: 0x0080, 0x1c9b: 0x0080, 0x1c9c: 0x0080, 0x1c9d: 0x0080, - 0x1c9e: 0x0080, 0x1c9f: 0x0080, 0x1ca0: 0x0080, 0x1ca1: 0x0080, 0x1ca2: 0x0080, 0x1ca3: 0x0080, - 0x1ca4: 0x0080, 0x1ca5: 0x0080, 0x1ca6: 0x0080, 0x1ca7: 0x0080, 0x1ca8: 0x0080, 0x1ca9: 0x0080, - 0x1caa: 0x0080, 0x1cab: 0x0080, 0x1cac: 0x0080, 0x1cad: 0x0080, 0x1cae: 0x0080, 0x1caf: 0x0080, - 0x1cb0: 0x0080, 0x1cb1: 0x0080, 0x1cb2: 0x0080, 0x1cb3: 0x0080, 0x1cb4: 0x0080, 0x1cb5: 0x0080, - 0x1cb6: 0x0080, 0x1cb7: 0x0080, 0x1cb8: 0x0080, 0x1cb9: 0x0080, 0x1cba: 0x0080, 0x1cbb: 0x0080, - 0x1cbc: 0x0080, 0x1cbd: 0x0080, 0x1cbe: 0x0080, 0x1cbf: 0x0080, - // Block 0x73, offset 0x1cc0 - 0x1cc0: 0x0080, 0x1cc1: 0x0080, 0x1cc2: 0x0080, 0x1cc3: 0x0080, 0x1cc4: 0x0080, 0x1cc5: 0x0080, - 0x1cc6: 0x0080, 0x1cc7: 0x0080, 0x1cc8: 0x0080, 0x1cc9: 0x0080, 0x1cca: 0x0080, 0x1ccb: 0x0080, - 0x1ccc: 0x0080, 0x1ccd: 0x0080, 0x1cce: 0x0080, 0x1ccf: 0x0080, 0x1cd0: 0x0080, 0x1cd1: 0x0080, - 0x1cd2: 0x0080, 0x1cd3: 0x0080, 0x1cd4: 0x0080, 0x1cd5: 0x0080, 0x1cd6: 0x0080, 0x1cd7: 0x0080, - 0x1cd8: 0x0080, 0x1cd9: 0x0080, 0x1cda: 0x0080, 0x1cdb: 0x0080, 0x1cdc: 0x0080, 0x1cdd: 0x0080, - 0x1cde: 0x0080, 0x1cdf: 0x0080, 0x1ce0: 0x0080, 0x1ce1: 0x0080, 0x1ce2: 0x0080, 0x1ce3: 0x0080, - 0x1ce4: 0x0080, 0x1ce5: 0x0080, 0x1ce6: 0x0080, 0x1ce7: 0x0080, 0x1ce8: 0x0080, 0x1ce9: 0x0080, - 0x1cea: 0x0080, 0x1ceb: 0x0080, 0x1cec: 0x0080, 0x1ced: 0x0080, 0x1cee: 0x0080, 0x1cef: 0x0080, - 0x1cf0: 0x0080, 0x1cf1: 0x0080, 0x1cf2: 0x0080, 0x1cf3: 0x0080, 0x1cf4: 0x0080, 0x1cf5: 0x0080, - 0x1cf6: 0x0080, 0x1cf7: 0x0080, 0x1cf8: 0x0080, 0x1cf9: 0x0080, 0x1cfa: 0x0080, 0x1cfb: 0x0080, - 0x1cfc: 0x0080, 0x1cfd: 0x0080, 0x1cfe: 0x0080, 0x1cff: 0x0080, - // Block 0x74, offset 0x1d00 - 0x1d00: 0x0080, 0x1d01: 0x0080, 0x1d02: 0x0080, 0x1d03: 0x0080, 0x1d04: 0x0080, 0x1d05: 0x0080, - 0x1d06: 0x0080, 0x1d07: 0x0080, 0x1d08: 0x0080, 0x1d09: 0x0080, 0x1d0a: 0x0080, 0x1d0b: 0x0080, - 0x1d0c: 0x0080, 0x1d0d: 0x0080, 0x1d0e: 0x0080, 0x1d0f: 0x0080, 0x1d10: 0x0080, 0x1d11: 0x0080, - 0x1d12: 0x0080, 0x1d13: 0x0080, 0x1d14: 0x0080, 0x1d15: 0x0080, 0x1d16: 0x0080, 0x1d17: 0x0080, - 0x1d18: 0x0080, 0x1d19: 0x0080, 0x1d1a: 0x0080, 0x1d1b: 0x0080, 0x1d1c: 0x0080, 0x1d1d: 0x0080, - 0x1d1e: 0x0080, 0x1d1f: 0x0080, 0x1d20: 0x0080, 0x1d21: 0x0080, 0x1d22: 0x0080, 0x1d23: 0x0080, - 0x1d24: 0x0080, 0x1d25: 0x0080, 0x1d26: 0x0080, 0x1d27: 0x0080, 0x1d28: 0x0080, 0x1d29: 0x0080, - 0x1d2a: 0x0080, 0x1d2b: 0x0080, 0x1d2c: 0x0080, 0x1d2d: 0x0080, 0x1d2e: 0x0080, 0x1d2f: 0x0080, - 0x1d30: 0x0080, 0x1d31: 0x0080, 0x1d32: 0x0080, 0x1d33: 0x0080, 0x1d34: 0x0080, 0x1d35: 0x0080, - 0x1d36: 0x0080, 0x1d37: 0x0080, 0x1d38: 0x0080, 0x1d39: 0x0080, 0x1d3a: 0x0080, 0x1d3b: 0x0080, - 0x1d3c: 0x0080, 0x1d3d: 0x0080, 0x1d3e: 0x0080, - // Block 0x75, offset 0x1d40 - 0x1d40: 0x0080, 0x1d41: 0x0080, 0x1d42: 0x0080, 0x1d43: 0x0080, 0x1d44: 0x0080, 0x1d45: 0x0080, - 0x1d46: 0x0080, 0x1d47: 0x0080, 0x1d48: 0x0080, 0x1d49: 0x0080, 0x1d4a: 0x0080, 0x1d4b: 0x0080, - 0x1d4c: 0x0080, 0x1d4d: 0x0080, 0x1d4e: 0x0080, 0x1d4f: 0x0080, 0x1d50: 0x0080, 0x1d51: 0x0080, - 0x1d52: 0x0080, 0x1d53: 0x0080, 0x1d54: 0x0080, 0x1d55: 0x0080, 0x1d56: 0x0080, 0x1d57: 0x0080, - 0x1d58: 0x0080, 0x1d59: 0x0080, 0x1d5a: 0x0080, 0x1d5b: 0x0080, 0x1d5c: 0x0080, 0x1d5d: 0x0080, - 0x1d5e: 0x0080, 0x1d5f: 0x0080, 0x1d60: 0x0080, 0x1d61: 0x0080, 0x1d62: 0x0080, 0x1d63: 0x0080, - 0x1d64: 0x0080, 0x1d65: 0x0080, 0x1d66: 0x0080, - // Block 0x76, offset 0x1d80 - 0x1d80: 0x0080, 0x1d81: 0x0080, 0x1d82: 0x0080, 0x1d83: 0x0080, 0x1d84: 0x0080, 0x1d85: 0x0080, - 0x1d86: 0x0080, 0x1d87: 0x0080, 0x1d88: 0x0080, 0x1d89: 0x0080, 0x1d8a: 0x0080, - 0x1da0: 0x0080, 0x1da1: 0x0080, 0x1da2: 0x0080, 0x1da3: 0x0080, - 0x1da4: 0x0080, 0x1da5: 0x0080, 0x1da6: 0x0080, 0x1da7: 0x0080, 0x1da8: 0x0080, 0x1da9: 0x0080, - 0x1daa: 0x0080, 0x1dab: 0x0080, 0x1dac: 0x0080, 0x1dad: 0x0080, 0x1dae: 0x0080, 0x1daf: 0x0080, - 0x1db0: 0x0080, 0x1db1: 0x0080, 0x1db2: 0x0080, 0x1db3: 0x0080, 0x1db4: 0x0080, 0x1db5: 0x0080, - 0x1db6: 0x0080, 0x1db7: 0x0080, 0x1db8: 0x0080, 0x1db9: 0x0080, 0x1dba: 0x0080, 0x1dbb: 0x0080, - 0x1dbc: 0x0080, 0x1dbd: 0x0080, 0x1dbe: 0x0080, 0x1dbf: 0x0080, - // Block 0x77, offset 0x1dc0 - 0x1dc0: 0x0080, 0x1dc1: 0x0080, 0x1dc2: 0x0080, 0x1dc3: 0x0080, 0x1dc4: 0x0080, 0x1dc5: 0x0080, - 0x1dc6: 0x0080, 0x1dc7: 0x0080, 0x1dc8: 0x0080, 0x1dc9: 0x0080, 0x1dca: 0x0080, 0x1dcb: 0x0080, - 0x1dcc: 0x0080, 0x1dcd: 0x0080, 0x1dce: 0x0080, 0x1dcf: 0x0080, 0x1dd0: 0x0080, 0x1dd1: 0x0080, - 0x1dd2: 0x0080, 0x1dd3: 0x0080, 0x1dd4: 0x0080, 0x1dd5: 0x0080, 0x1dd6: 0x0080, 0x1dd7: 0x0080, - 0x1dd8: 0x0080, 0x1dd9: 0x0080, 0x1dda: 0x0080, 0x1ddb: 0x0080, 0x1ddc: 0x0080, 0x1ddd: 0x0080, - 0x1dde: 0x0080, 0x1ddf: 0x0080, 0x1de0: 0x0080, 0x1de1: 0x0080, 0x1de2: 0x0080, 0x1de3: 0x0080, - 0x1de4: 0x0080, 0x1de5: 0x0080, 0x1de6: 0x0080, 0x1de7: 0x0080, 0x1de8: 0x0080, 0x1de9: 0x0080, - 0x1dea: 0x0080, 0x1deb: 0x0080, 0x1dec: 0x0080, 0x1ded: 0x0080, 0x1dee: 0x0080, 0x1def: 0x0080, - 0x1df0: 0x0080, 0x1df1: 0x0080, 0x1df2: 0x0080, 0x1df3: 0x0080, - 0x1df6: 0x0080, 0x1df7: 0x0080, 0x1df8: 0x0080, 0x1df9: 0x0080, 0x1dfa: 0x0080, 0x1dfb: 0x0080, - 0x1dfc: 0x0080, 0x1dfd: 0x0080, 0x1dfe: 0x0080, 0x1dff: 0x0080, - // Block 0x78, offset 0x1e00 - 0x1e00: 0x0080, 0x1e01: 0x0080, 0x1e02: 0x0080, 0x1e03: 0x0080, 0x1e04: 0x0080, 0x1e05: 0x0080, - 0x1e06: 0x0080, 0x1e07: 0x0080, 0x1e08: 0x0080, 0x1e09: 0x0080, 0x1e0a: 0x0080, 0x1e0b: 0x0080, - 0x1e0c: 0x0080, 0x1e0d: 0x0080, 0x1e0e: 0x0080, 0x1e0f: 0x0080, 0x1e10: 0x0080, 0x1e11: 0x0080, - 0x1e12: 0x0080, 0x1e13: 0x0080, 0x1e14: 0x0080, 0x1e15: 0x0080, - 0x1e18: 0x0080, 0x1e19: 0x0080, 0x1e1a: 0x0080, 0x1e1b: 0x0080, 0x1e1c: 0x0080, 0x1e1d: 0x0080, - 0x1e1e: 0x0080, 0x1e1f: 0x0080, 0x1e20: 0x0080, 0x1e21: 0x0080, 0x1e22: 0x0080, 0x1e23: 0x0080, - 0x1e24: 0x0080, 0x1e25: 0x0080, 0x1e26: 0x0080, 0x1e27: 0x0080, 0x1e28: 0x0080, 0x1e29: 0x0080, - 0x1e2a: 0x0080, 0x1e2b: 0x0080, 0x1e2c: 0x0080, 0x1e2d: 0x0080, 0x1e2e: 0x0080, 0x1e2f: 0x0080, - 0x1e30: 0x0080, 0x1e31: 0x0080, 0x1e32: 0x0080, 0x1e33: 0x0080, 0x1e34: 0x0080, 0x1e35: 0x0080, - 0x1e36: 0x0080, 0x1e37: 0x0080, 0x1e38: 0x0080, 0x1e39: 0x0080, - 0x1e3d: 0x0080, 0x1e3e: 0x0080, 0x1e3f: 0x0080, - // Block 0x79, offset 0x1e40 - 0x1e40: 0x0080, 0x1e41: 0x0080, 0x1e42: 0x0080, 0x1e43: 0x0080, 0x1e44: 0x0080, 0x1e45: 0x0080, - 0x1e46: 0x0080, 0x1e47: 0x0080, 0x1e48: 0x0080, 0x1e4a: 0x0080, 0x1e4b: 0x0080, - 0x1e4c: 0x0080, 0x1e4d: 0x0080, 0x1e4e: 0x0080, 0x1e4f: 0x0080, 0x1e50: 0x0080, 0x1e51: 0x0080, - 0x1e6c: 0x0080, 0x1e6d: 0x0080, 0x1e6e: 0x0080, 0x1e6f: 0x0080, - // Block 0x7a, offset 0x1e80 - 0x1e80: 0x00c0, 0x1e81: 0x00c0, 0x1e82: 0x00c0, 0x1e83: 0x00c0, 0x1e84: 0x00c0, 0x1e85: 0x00c0, - 0x1e86: 0x00c0, 0x1e87: 0x00c0, 0x1e88: 0x00c0, 0x1e89: 0x00c0, 0x1e8a: 0x00c0, 0x1e8b: 0x00c0, - 0x1e8c: 0x00c0, 0x1e8d: 0x00c0, 0x1e8e: 0x00c0, 0x1e8f: 0x00c0, 0x1e90: 0x00c0, 0x1e91: 0x00c0, - 0x1e92: 0x00c0, 0x1e93: 0x00c0, 0x1e94: 0x00c0, 0x1e95: 0x00c0, 0x1e96: 0x00c0, 0x1e97: 0x00c0, - 0x1e98: 0x00c0, 0x1e99: 0x00c0, 0x1e9a: 0x00c0, 0x1e9b: 0x00c0, 0x1e9c: 0x00c0, 0x1e9d: 0x00c0, - 0x1e9e: 0x00c0, 0x1e9f: 0x00c0, 0x1ea0: 0x00c0, 0x1ea1: 0x00c0, 0x1ea2: 0x00c0, 0x1ea3: 0x00c0, - 0x1ea4: 0x00c0, 0x1ea5: 0x00c0, 0x1ea6: 0x00c0, 0x1ea7: 0x00c0, 0x1ea8: 0x00c0, 0x1ea9: 0x00c0, - 0x1eaa: 0x00c0, 0x1eab: 0x00c0, 0x1eac: 0x00c0, 0x1ead: 0x00c0, 0x1eae: 0x00c0, - 0x1eb0: 0x00c0, 0x1eb1: 0x00c0, 0x1eb2: 0x00c0, 0x1eb3: 0x00c0, 0x1eb4: 0x00c0, 0x1eb5: 0x00c0, - 0x1eb6: 0x00c0, 0x1eb7: 0x00c0, 0x1eb8: 0x00c0, 0x1eb9: 0x00c0, 0x1eba: 0x00c0, 0x1ebb: 0x00c0, - 0x1ebc: 0x00c0, 0x1ebd: 0x00c0, 0x1ebe: 0x00c0, 0x1ebf: 0x00c0, - // Block 0x7b, offset 0x1ec0 - 0x1ec0: 0x00c0, 0x1ec1: 0x00c0, 0x1ec2: 0x00c0, 0x1ec3: 0x00c0, 0x1ec4: 0x00c0, 0x1ec5: 0x00c0, - 0x1ec6: 0x00c0, 0x1ec7: 0x00c0, 0x1ec8: 0x00c0, 0x1ec9: 0x00c0, 0x1eca: 0x00c0, 0x1ecb: 0x00c0, - 0x1ecc: 0x00c0, 0x1ecd: 0x00c0, 0x1ece: 0x00c0, 0x1ecf: 0x00c0, 0x1ed0: 0x00c0, 0x1ed1: 0x00c0, - 0x1ed2: 0x00c0, 0x1ed3: 0x00c0, 0x1ed4: 0x00c0, 0x1ed5: 0x00c0, 0x1ed6: 0x00c0, 0x1ed7: 0x00c0, - 0x1ed8: 0x00c0, 0x1ed9: 0x00c0, 0x1eda: 0x00c0, 0x1edb: 0x00c0, 0x1edc: 0x00c0, 0x1edd: 0x00c0, - 0x1ede: 0x00c0, 0x1ee0: 0x00c0, 0x1ee1: 0x00c0, 0x1ee2: 0x00c0, 0x1ee3: 0x00c0, - 0x1ee4: 0x00c0, 0x1ee5: 0x00c0, 0x1ee6: 0x00c0, 0x1ee7: 0x00c0, 0x1ee8: 0x00c0, 0x1ee9: 0x00c0, - 0x1eea: 0x00c0, 0x1eeb: 0x00c0, 0x1eec: 0x00c0, 0x1eed: 0x00c0, 0x1eee: 0x00c0, 0x1eef: 0x00c0, - 0x1ef0: 0x00c0, 0x1ef1: 0x00c0, 0x1ef2: 0x00c0, 0x1ef3: 0x00c0, 0x1ef4: 0x00c0, 0x1ef5: 0x00c0, - 0x1ef6: 0x00c0, 0x1ef7: 0x00c0, 0x1ef8: 0x00c0, 0x1ef9: 0x00c0, 0x1efa: 0x00c0, 0x1efb: 0x00c0, - 0x1efc: 0x0080, 0x1efd: 0x0080, 0x1efe: 0x00c0, 0x1eff: 0x00c0, - // Block 0x7c, offset 0x1f00 - 0x1f00: 0x00c0, 0x1f01: 0x00c0, 0x1f02: 0x00c0, 0x1f03: 0x00c0, 0x1f04: 0x00c0, 0x1f05: 0x00c0, - 0x1f06: 0x00c0, 0x1f07: 0x00c0, 0x1f08: 0x00c0, 0x1f09: 0x00c0, 0x1f0a: 0x00c0, 0x1f0b: 0x00c0, - 0x1f0c: 0x00c0, 0x1f0d: 0x00c0, 0x1f0e: 0x00c0, 0x1f0f: 0x00c0, 0x1f10: 0x00c0, 0x1f11: 0x00c0, - 0x1f12: 0x00c0, 0x1f13: 0x00c0, 0x1f14: 0x00c0, 0x1f15: 0x00c0, 0x1f16: 0x00c0, 0x1f17: 0x00c0, - 0x1f18: 0x00c0, 0x1f19: 0x00c0, 0x1f1a: 0x00c0, 0x1f1b: 0x00c0, 0x1f1c: 0x00c0, 0x1f1d: 0x00c0, - 0x1f1e: 0x00c0, 0x1f1f: 0x00c0, 0x1f20: 0x00c0, 0x1f21: 0x00c0, 0x1f22: 0x00c0, 0x1f23: 0x00c0, - 0x1f24: 0x00c0, 0x1f25: 0x0080, 0x1f26: 0x0080, 0x1f27: 0x0080, 0x1f28: 0x0080, 0x1f29: 0x0080, - 0x1f2a: 0x0080, 0x1f2b: 0x00c0, 0x1f2c: 0x00c0, 0x1f2d: 0x00c0, 0x1f2e: 0x00c0, 0x1f2f: 0x00c3, - 0x1f30: 0x00c3, 0x1f31: 0x00c3, 0x1f32: 0x00c0, 0x1f33: 0x00c0, - 0x1f39: 0x0080, 0x1f3a: 0x0080, 0x1f3b: 0x0080, - 0x1f3c: 0x0080, 0x1f3d: 0x0080, 0x1f3e: 0x0080, 0x1f3f: 0x0080, - // Block 0x7d, offset 0x1f40 - 0x1f40: 0x00c0, 0x1f41: 0x00c0, 0x1f42: 0x00c0, 0x1f43: 0x00c0, 0x1f44: 0x00c0, 0x1f45: 0x00c0, - 0x1f46: 0x00c0, 0x1f47: 0x00c0, 0x1f48: 0x00c0, 0x1f49: 0x00c0, 0x1f4a: 0x00c0, 0x1f4b: 0x00c0, - 0x1f4c: 0x00c0, 0x1f4d: 0x00c0, 0x1f4e: 0x00c0, 0x1f4f: 0x00c0, 0x1f50: 0x00c0, 0x1f51: 0x00c0, - 0x1f52: 0x00c0, 0x1f53: 0x00c0, 0x1f54: 0x00c0, 0x1f55: 0x00c0, 0x1f56: 0x00c0, 0x1f57: 0x00c0, - 0x1f58: 0x00c0, 0x1f59: 0x00c0, 0x1f5a: 0x00c0, 0x1f5b: 0x00c0, 0x1f5c: 0x00c0, 0x1f5d: 0x00c0, - 0x1f5e: 0x00c0, 0x1f5f: 0x00c0, 0x1f60: 0x00c0, 0x1f61: 0x00c0, 0x1f62: 0x00c0, 0x1f63: 0x00c0, - 0x1f64: 0x00c0, 0x1f65: 0x00c0, 0x1f67: 0x00c0, - 0x1f6d: 0x00c0, - 0x1f70: 0x00c0, 0x1f71: 0x00c0, 0x1f72: 0x00c0, 0x1f73: 0x00c0, 0x1f74: 0x00c0, 0x1f75: 0x00c0, - 0x1f76: 0x00c0, 0x1f77: 0x00c0, 0x1f78: 0x00c0, 0x1f79: 0x00c0, 0x1f7a: 0x00c0, 0x1f7b: 0x00c0, - 0x1f7c: 0x00c0, 0x1f7d: 0x00c0, 0x1f7e: 0x00c0, 0x1f7f: 0x00c0, - // Block 0x7e, offset 0x1f80 - 0x1f80: 0x00c0, 0x1f81: 0x00c0, 0x1f82: 0x00c0, 0x1f83: 0x00c0, 0x1f84: 0x00c0, 0x1f85: 0x00c0, - 0x1f86: 0x00c0, 0x1f87: 0x00c0, 0x1f88: 0x00c0, 0x1f89: 0x00c0, 0x1f8a: 0x00c0, 0x1f8b: 0x00c0, - 0x1f8c: 0x00c0, 0x1f8d: 0x00c0, 0x1f8e: 0x00c0, 0x1f8f: 0x00c0, 0x1f90: 0x00c0, 0x1f91: 0x00c0, - 0x1f92: 0x00c0, 0x1f93: 0x00c0, 0x1f94: 0x00c0, 0x1f95: 0x00c0, 0x1f96: 0x00c0, 0x1f97: 0x00c0, - 0x1f98: 0x00c0, 0x1f99: 0x00c0, 0x1f9a: 0x00c0, 0x1f9b: 0x00c0, 0x1f9c: 0x00c0, 0x1f9d: 0x00c0, - 0x1f9e: 0x00c0, 0x1f9f: 0x00c0, 0x1fa0: 0x00c0, 0x1fa1: 0x00c0, 0x1fa2: 0x00c0, 0x1fa3: 0x00c0, - 0x1fa4: 0x00c0, 0x1fa5: 0x00c0, 0x1fa6: 0x00c0, 0x1fa7: 0x00c0, - 0x1faf: 0x0080, - 0x1fb0: 0x0080, - 0x1fbf: 0x00c6, - // Block 0x7f, offset 0x1fc0 - 0x1fc0: 0x00c0, 0x1fc1: 0x00c0, 0x1fc2: 0x00c0, 0x1fc3: 0x00c0, 0x1fc4: 0x00c0, 0x1fc5: 0x00c0, - 0x1fc6: 0x00c0, 0x1fc7: 0x00c0, 0x1fc8: 0x00c0, 0x1fc9: 0x00c0, 0x1fca: 0x00c0, 0x1fcb: 0x00c0, - 0x1fcc: 0x00c0, 0x1fcd: 0x00c0, 0x1fce: 0x00c0, 0x1fcf: 0x00c0, 0x1fd0: 0x00c0, 0x1fd1: 0x00c0, - 0x1fd2: 0x00c0, 0x1fd3: 0x00c0, 0x1fd4: 0x00c0, 0x1fd5: 0x00c0, 0x1fd6: 0x00c0, - 0x1fe0: 0x00c0, 0x1fe1: 0x00c0, 0x1fe2: 0x00c0, 0x1fe3: 0x00c0, - 0x1fe4: 0x00c0, 0x1fe5: 0x00c0, 0x1fe6: 0x00c0, 0x1fe8: 0x00c0, 0x1fe9: 0x00c0, - 0x1fea: 0x00c0, 0x1feb: 0x00c0, 0x1fec: 0x00c0, 0x1fed: 0x00c0, 0x1fee: 0x00c0, - 0x1ff0: 0x00c0, 0x1ff1: 0x00c0, 0x1ff2: 0x00c0, 0x1ff3: 0x00c0, 0x1ff4: 0x00c0, 0x1ff5: 0x00c0, - 0x1ff6: 0x00c0, 0x1ff8: 0x00c0, 0x1ff9: 0x00c0, 0x1ffa: 0x00c0, 0x1ffb: 0x00c0, - 0x1ffc: 0x00c0, 0x1ffd: 0x00c0, 0x1ffe: 0x00c0, - // Block 0x80, offset 0x2000 - 0x2000: 0x00c0, 0x2001: 0x00c0, 0x2002: 0x00c0, 0x2003: 0x00c0, 0x2004: 0x00c0, 0x2005: 0x00c0, - 0x2006: 0x00c0, 0x2008: 0x00c0, 0x2009: 0x00c0, 0x200a: 0x00c0, 0x200b: 0x00c0, - 0x200c: 0x00c0, 0x200d: 0x00c0, 0x200e: 0x00c0, 0x2010: 0x00c0, 0x2011: 0x00c0, - 0x2012: 0x00c0, 0x2013: 0x00c0, 0x2014: 0x00c0, 0x2015: 0x00c0, 0x2016: 0x00c0, - 0x2018: 0x00c0, 0x2019: 0x00c0, 0x201a: 0x00c0, 0x201b: 0x00c0, 0x201c: 0x00c0, 0x201d: 0x00c0, - 0x201e: 0x00c0, 0x2020: 0x00c3, 0x2021: 0x00c3, 0x2022: 0x00c3, 0x2023: 0x00c3, - 0x2024: 0x00c3, 0x2025: 0x00c3, 0x2026: 0x00c3, 0x2027: 0x00c3, 0x2028: 0x00c3, 0x2029: 0x00c3, - 0x202a: 0x00c3, 0x202b: 0x00c3, 0x202c: 0x00c3, 0x202d: 0x00c3, 0x202e: 0x00c3, 0x202f: 0x00c3, - 0x2030: 0x00c3, 0x2031: 0x00c3, 0x2032: 0x00c3, 0x2033: 0x00c3, 0x2034: 0x00c3, 0x2035: 0x00c3, - 0x2036: 0x00c3, 0x2037: 0x00c3, 0x2038: 0x00c3, 0x2039: 0x00c3, 0x203a: 0x00c3, 0x203b: 0x00c3, - 0x203c: 0x00c3, 0x203d: 0x00c3, 0x203e: 0x00c3, 0x203f: 0x00c3, - // Block 0x81, offset 0x2040 - 0x2040: 0x0080, 0x2041: 0x0080, 0x2042: 0x0080, 0x2043: 0x0080, 0x2044: 0x0080, 0x2045: 0x0080, - 0x2046: 0x0080, 0x2047: 0x0080, 0x2048: 0x0080, 0x2049: 0x0080, 0x204a: 0x0080, 0x204b: 0x0080, - 0x204c: 0x0080, 0x204d: 0x0080, 0x204e: 0x0080, 0x204f: 0x0080, 0x2050: 0x0080, 0x2051: 0x0080, - 0x2052: 0x0080, 0x2053: 0x0080, 0x2054: 0x0080, 0x2055: 0x0080, 0x2056: 0x0080, 0x2057: 0x0080, - 0x2058: 0x0080, 0x2059: 0x0080, 0x205a: 0x0080, 0x205b: 0x0080, 0x205c: 0x0080, 0x205d: 0x0080, - 0x205e: 0x0080, 0x205f: 0x0080, 0x2060: 0x0080, 0x2061: 0x0080, 0x2062: 0x0080, 0x2063: 0x0080, - 0x2064: 0x0080, 0x2065: 0x0080, 0x2066: 0x0080, 0x2067: 0x0080, 0x2068: 0x0080, 0x2069: 0x0080, - 0x206a: 0x0080, 0x206b: 0x0080, 0x206c: 0x0080, 0x206d: 0x0080, 0x206e: 0x0080, 0x206f: 0x00c0, - 0x2070: 0x0080, 0x2071: 0x0080, 0x2072: 0x0080, 0x2073: 0x0080, 0x2074: 0x0080, 0x2075: 0x0080, - 0x2076: 0x0080, 0x2077: 0x0080, 0x2078: 0x0080, 0x2079: 0x0080, 0x207a: 0x0080, 0x207b: 0x0080, - 0x207c: 0x0080, 0x207d: 0x0080, 0x207e: 0x0080, 0x207f: 0x0080, - // Block 0x82, offset 0x2080 - 0x2080: 0x0080, 0x2081: 0x0080, 0x2082: 0x0080, 0x2083: 0x0080, 0x2084: 0x0080, - // Block 0x83, offset 0x20c0 - 0x20c0: 0x008c, 0x20c1: 0x008c, 0x20c2: 0x008c, 0x20c3: 0x008c, 0x20c4: 0x008c, 0x20c5: 0x008c, - 0x20c6: 0x008c, 0x20c7: 0x008c, 0x20c8: 0x008c, 0x20c9: 0x008c, 0x20ca: 0x008c, 0x20cb: 0x008c, - 0x20cc: 0x008c, 0x20cd: 0x008c, 0x20ce: 0x008c, 0x20cf: 0x008c, 0x20d0: 0x008c, 0x20d1: 0x008c, - 0x20d2: 0x008c, 0x20d3: 0x008c, 0x20d4: 0x008c, 0x20d5: 0x008c, 0x20d6: 0x008c, 0x20d7: 0x008c, - 0x20d8: 0x008c, 0x20d9: 0x008c, 0x20db: 0x008c, 0x20dc: 0x008c, 0x20dd: 0x008c, - 0x20de: 0x008c, 0x20df: 0x008c, 0x20e0: 0x008c, 0x20e1: 0x008c, 0x20e2: 0x008c, 0x20e3: 0x008c, - 0x20e4: 0x008c, 0x20e5: 0x008c, 0x20e6: 0x008c, 0x20e7: 0x008c, 0x20e8: 0x008c, 0x20e9: 0x008c, - 0x20ea: 0x008c, 0x20eb: 0x008c, 0x20ec: 0x008c, 0x20ed: 0x008c, 0x20ee: 0x008c, 0x20ef: 0x008c, - 0x20f0: 0x008c, 0x20f1: 0x008c, 0x20f2: 0x008c, 0x20f3: 0x008c, 0x20f4: 0x008c, 0x20f5: 0x008c, - 0x20f6: 0x008c, 0x20f7: 0x008c, 0x20f8: 0x008c, 0x20f9: 0x008c, 0x20fa: 0x008c, 0x20fb: 0x008c, - 0x20fc: 0x008c, 0x20fd: 0x008c, 0x20fe: 0x008c, 0x20ff: 0x008c, - // Block 0x84, offset 0x2100 - 0x2100: 0x008c, 0x2101: 0x008c, 0x2102: 0x008c, 0x2103: 0x008c, 0x2104: 0x008c, 0x2105: 0x008c, - 0x2106: 0x008c, 0x2107: 0x008c, 0x2108: 0x008c, 0x2109: 0x008c, 0x210a: 0x008c, 0x210b: 0x008c, - 0x210c: 0x008c, 0x210d: 0x008c, 0x210e: 0x008c, 0x210f: 0x008c, 0x2110: 0x008c, 0x2111: 0x008c, - 0x2112: 0x008c, 0x2113: 0x008c, 0x2114: 0x008c, 0x2115: 0x008c, 0x2116: 0x008c, 0x2117: 0x008c, - 0x2118: 0x008c, 0x2119: 0x008c, 0x211a: 0x008c, 0x211b: 0x008c, 0x211c: 0x008c, 0x211d: 0x008c, - 0x211e: 0x008c, 0x211f: 0x008c, 0x2120: 0x008c, 0x2121: 0x008c, 0x2122: 0x008c, 0x2123: 0x008c, - 0x2124: 0x008c, 0x2125: 0x008c, 0x2126: 0x008c, 0x2127: 0x008c, 0x2128: 0x008c, 0x2129: 0x008c, - 0x212a: 0x008c, 0x212b: 0x008c, 0x212c: 0x008c, 0x212d: 0x008c, 0x212e: 0x008c, 0x212f: 0x008c, - 0x2130: 0x008c, 0x2131: 0x008c, 0x2132: 0x008c, 0x2133: 0x008c, - // Block 0x85, offset 0x2140 - 0x2140: 0x008c, 0x2141: 0x008c, 0x2142: 0x008c, 0x2143: 0x008c, 0x2144: 0x008c, 0x2145: 0x008c, - 0x2146: 0x008c, 0x2147: 0x008c, 0x2148: 0x008c, 0x2149: 0x008c, 0x214a: 0x008c, 0x214b: 0x008c, - 0x214c: 0x008c, 0x214d: 0x008c, 0x214e: 0x008c, 0x214f: 0x008c, 0x2150: 0x008c, 0x2151: 0x008c, - 0x2152: 0x008c, 0x2153: 0x008c, 0x2154: 0x008c, 0x2155: 0x008c, 0x2156: 0x008c, 0x2157: 0x008c, - 0x2158: 0x008c, 0x2159: 0x008c, 0x215a: 0x008c, 0x215b: 0x008c, 0x215c: 0x008c, 0x215d: 0x008c, - 0x215e: 0x008c, 0x215f: 0x008c, 0x2160: 0x008c, 0x2161: 0x008c, 0x2162: 0x008c, 0x2163: 0x008c, - 0x2164: 0x008c, 0x2165: 0x008c, 0x2166: 0x008c, 0x2167: 0x008c, 0x2168: 0x008c, 0x2169: 0x008c, - 0x216a: 0x008c, 0x216b: 0x008c, 0x216c: 0x008c, 0x216d: 0x008c, 0x216e: 0x008c, 0x216f: 0x008c, - 0x2170: 0x008c, 0x2171: 0x008c, 0x2172: 0x008c, 0x2173: 0x008c, 0x2174: 0x008c, 0x2175: 0x008c, - 0x2176: 0x008c, 0x2177: 0x008c, 0x2178: 0x008c, 0x2179: 0x008c, 0x217a: 0x008c, 0x217b: 0x008c, - 0x217c: 0x008c, 0x217d: 0x008c, 0x217e: 0x008c, 0x217f: 0x008c, - // Block 0x86, offset 0x2180 - 0x2180: 0x008c, 0x2181: 0x008c, 0x2182: 0x008c, 0x2183: 0x008c, 0x2184: 0x008c, 0x2185: 0x008c, - 0x2186: 0x008c, 0x2187: 0x008c, 0x2188: 0x008c, 0x2189: 0x008c, 0x218a: 0x008c, 0x218b: 0x008c, - 0x218c: 0x008c, 0x218d: 0x008c, 0x218e: 0x008c, 0x218f: 0x008c, 0x2190: 0x008c, 0x2191: 0x008c, - 0x2192: 0x008c, 0x2193: 0x008c, 0x2194: 0x008c, 0x2195: 0x008c, - 0x21b0: 0x0080, 0x21b1: 0x0080, 0x21b2: 0x0080, 0x21b3: 0x0080, 0x21b4: 0x0080, 0x21b5: 0x0080, - 0x21b6: 0x0080, 0x21b7: 0x0080, 0x21b8: 0x0080, 0x21b9: 0x0080, 0x21ba: 0x0080, 0x21bb: 0x0080, - // Block 0x87, offset 0x21c0 - 0x21c0: 0x0080, 0x21c1: 0x0080, 0x21c2: 0x0080, 0x21c3: 0x0080, 0x21c4: 0x0080, 0x21c5: 0x00cc, - 0x21c6: 0x00c0, 0x21c7: 0x00cc, 0x21c8: 0x0080, 0x21c9: 0x0080, 0x21ca: 0x0080, 0x21cb: 0x0080, - 0x21cc: 0x0080, 0x21cd: 0x0080, 0x21ce: 0x0080, 0x21cf: 0x0080, 0x21d0: 0x0080, 0x21d1: 0x0080, - 0x21d2: 0x0080, 0x21d3: 0x0080, 0x21d4: 0x0080, 0x21d5: 0x0080, 0x21d6: 0x0080, 0x21d7: 0x0080, - 0x21d8: 0x0080, 0x21d9: 0x0080, 0x21da: 0x0080, 0x21db: 0x0080, 0x21dc: 0x0080, 0x21dd: 0x0080, - 0x21de: 0x0080, 0x21df: 0x0080, 0x21e0: 0x0080, 0x21e1: 0x008c, 0x21e2: 0x008c, 0x21e3: 0x008c, - 0x21e4: 0x008c, 0x21e5: 0x008c, 0x21e6: 0x008c, 0x21e7: 0x008c, 0x21e8: 0x008c, 0x21e9: 0x008c, - 0x21ea: 0x00c3, 0x21eb: 0x00c3, 0x21ec: 0x00c3, 0x21ed: 0x00c3, 0x21ee: 0x0040, 0x21ef: 0x0040, - 0x21f0: 0x0080, 0x21f1: 0x0040, 0x21f2: 0x0040, 0x21f3: 0x0040, 0x21f4: 0x0040, 0x21f5: 0x0040, - 0x21f6: 0x0080, 0x21f7: 0x0080, 0x21f8: 0x008c, 0x21f9: 0x008c, 0x21fa: 0x008c, 0x21fb: 0x0040, - 0x21fc: 0x00c0, 0x21fd: 0x0080, 0x21fe: 0x0080, 0x21ff: 0x0080, - // Block 0x88, offset 0x2200 - 0x2201: 0x00cc, 0x2202: 0x00cc, 0x2203: 0x00cc, 0x2204: 0x00cc, 0x2205: 0x00cc, - 0x2206: 0x00cc, 0x2207: 0x00cc, 0x2208: 0x00cc, 0x2209: 0x00cc, 0x220a: 0x00cc, 0x220b: 0x00cc, - 0x220c: 0x00cc, 0x220d: 0x00cc, 0x220e: 0x00cc, 0x220f: 0x00cc, 0x2210: 0x00cc, 0x2211: 0x00cc, - 0x2212: 0x00cc, 0x2213: 0x00cc, 0x2214: 0x00cc, 0x2215: 0x00cc, 0x2216: 0x00cc, 0x2217: 0x00cc, - 0x2218: 0x00cc, 0x2219: 0x00cc, 0x221a: 0x00cc, 0x221b: 0x00cc, 0x221c: 0x00cc, 0x221d: 0x00cc, - 0x221e: 0x00cc, 0x221f: 0x00cc, 0x2220: 0x00cc, 0x2221: 0x00cc, 0x2222: 0x00cc, 0x2223: 0x00cc, - 0x2224: 0x00cc, 0x2225: 0x00cc, 0x2226: 0x00cc, 0x2227: 0x00cc, 0x2228: 0x00cc, 0x2229: 0x00cc, - 0x222a: 0x00cc, 0x222b: 0x00cc, 0x222c: 0x00cc, 0x222d: 0x00cc, 0x222e: 0x00cc, 0x222f: 0x00cc, - 0x2230: 0x00cc, 0x2231: 0x00cc, 0x2232: 0x00cc, 0x2233: 0x00cc, 0x2234: 0x00cc, 0x2235: 0x00cc, - 0x2236: 0x00cc, 0x2237: 0x00cc, 0x2238: 0x00cc, 0x2239: 0x00cc, 0x223a: 0x00cc, 0x223b: 0x00cc, - 0x223c: 0x00cc, 0x223d: 0x00cc, 0x223e: 0x00cc, 0x223f: 0x00cc, - // Block 0x89, offset 0x2240 - 0x2240: 0x00cc, 0x2241: 0x00cc, 0x2242: 0x00cc, 0x2243: 0x00cc, 0x2244: 0x00cc, 0x2245: 0x00cc, - 0x2246: 0x00cc, 0x2247: 0x00cc, 0x2248: 0x00cc, 0x2249: 0x00cc, 0x224a: 0x00cc, 0x224b: 0x00cc, - 0x224c: 0x00cc, 0x224d: 0x00cc, 0x224e: 0x00cc, 0x224f: 0x00cc, 0x2250: 0x00cc, 0x2251: 0x00cc, - 0x2252: 0x00cc, 0x2253: 0x00cc, 0x2254: 0x00cc, 0x2255: 0x00cc, 0x2256: 0x00cc, - 0x2259: 0x00c3, 0x225a: 0x00c3, 0x225b: 0x0080, 0x225c: 0x0080, 0x225d: 0x00cc, - 0x225e: 0x00cc, 0x225f: 0x008c, 0x2260: 0x0080, 0x2261: 0x00cc, 0x2262: 0x00cc, 0x2263: 0x00cc, - 0x2264: 0x00cc, 0x2265: 0x00cc, 0x2266: 0x00cc, 0x2267: 0x00cc, 0x2268: 0x00cc, 0x2269: 0x00cc, - 0x226a: 0x00cc, 0x226b: 0x00cc, 0x226c: 0x00cc, 0x226d: 0x00cc, 0x226e: 0x00cc, 0x226f: 0x00cc, - 0x2270: 0x00cc, 0x2271: 0x00cc, 0x2272: 0x00cc, 0x2273: 0x00cc, 0x2274: 0x00cc, 0x2275: 0x00cc, - 0x2276: 0x00cc, 0x2277: 0x00cc, 0x2278: 0x00cc, 0x2279: 0x00cc, 0x227a: 0x00cc, 0x227b: 0x00cc, - 0x227c: 0x00cc, 0x227d: 0x00cc, 0x227e: 0x00cc, 0x227f: 0x00cc, - // Block 0x8a, offset 0x2280 - 0x2280: 0x00cc, 0x2281: 0x00cc, 0x2282: 0x00cc, 0x2283: 0x00cc, 0x2284: 0x00cc, 0x2285: 0x00cc, - 0x2286: 0x00cc, 0x2287: 0x00cc, 0x2288: 0x00cc, 0x2289: 0x00cc, 0x228a: 0x00cc, 0x228b: 0x00cc, - 0x228c: 0x00cc, 0x228d: 0x00cc, 0x228e: 0x00cc, 0x228f: 0x00cc, 0x2290: 0x00cc, 0x2291: 0x00cc, - 0x2292: 0x00cc, 0x2293: 0x00cc, 0x2294: 0x00cc, 0x2295: 0x00cc, 0x2296: 0x00cc, 0x2297: 0x00cc, - 0x2298: 0x00cc, 0x2299: 0x00cc, 0x229a: 0x00cc, 0x229b: 0x00cc, 0x229c: 0x00cc, 0x229d: 0x00cc, - 0x229e: 0x00cc, 0x229f: 0x00cc, 0x22a0: 0x00cc, 0x22a1: 0x00cc, 0x22a2: 0x00cc, 0x22a3: 0x00cc, - 0x22a4: 0x00cc, 0x22a5: 0x00cc, 0x22a6: 0x00cc, 0x22a7: 0x00cc, 0x22a8: 0x00cc, 0x22a9: 0x00cc, - 0x22aa: 0x00cc, 0x22ab: 0x00cc, 0x22ac: 0x00cc, 0x22ad: 0x00cc, 0x22ae: 0x00cc, 0x22af: 0x00cc, - 0x22b0: 0x00cc, 0x22b1: 0x00cc, 0x22b2: 0x00cc, 0x22b3: 0x00cc, 0x22b4: 0x00cc, 0x22b5: 0x00cc, - 0x22b6: 0x00cc, 0x22b7: 0x00cc, 0x22b8: 0x00cc, 0x22b9: 0x00cc, 0x22ba: 0x00cc, 0x22bb: 0x00d2, - 0x22bc: 0x00c0, 0x22bd: 0x00cc, 0x22be: 0x00cc, 0x22bf: 0x008c, - // Block 0x8b, offset 0x22c0 - 0x22c5: 0x00c0, - 0x22c6: 0x00c0, 0x22c7: 0x00c0, 0x22c8: 0x00c0, 0x22c9: 0x00c0, 0x22ca: 0x00c0, 0x22cb: 0x00c0, - 0x22cc: 0x00c0, 0x22cd: 0x00c0, 0x22ce: 0x00c0, 0x22cf: 0x00c0, 0x22d0: 0x00c0, 0x22d1: 0x00c0, - 0x22d2: 0x00c0, 0x22d3: 0x00c0, 0x22d4: 0x00c0, 0x22d5: 0x00c0, 0x22d6: 0x00c0, 0x22d7: 0x00c0, - 0x22d8: 0x00c0, 0x22d9: 0x00c0, 0x22da: 0x00c0, 0x22db: 0x00c0, 0x22dc: 0x00c0, 0x22dd: 0x00c0, - 0x22de: 0x00c0, 0x22df: 0x00c0, 0x22e0: 0x00c0, 0x22e1: 0x00c0, 0x22e2: 0x00c0, 0x22e3: 0x00c0, - 0x22e4: 0x00c0, 0x22e5: 0x00c0, 0x22e6: 0x00c0, 0x22e7: 0x00c0, 0x22e8: 0x00c0, 0x22e9: 0x00c0, - 0x22ea: 0x00c0, 0x22eb: 0x00c0, 0x22ec: 0x00c0, 0x22ed: 0x00c0, - 0x22f1: 0x0080, 0x22f2: 0x0080, 0x22f3: 0x0080, 0x22f4: 0x0080, 0x22f5: 0x0080, - 0x22f6: 0x0080, 0x22f7: 0x0080, 0x22f8: 0x0080, 0x22f9: 0x0080, 0x22fa: 0x0080, 0x22fb: 0x0080, - 0x22fc: 0x0080, 0x22fd: 0x0080, 0x22fe: 0x0080, 0x22ff: 0x0080, - // Block 0x8c, offset 0x2300 - 0x2300: 0x0080, 0x2301: 0x0080, 0x2302: 0x0080, 0x2303: 0x0080, 0x2304: 0x0080, 0x2305: 0x0080, - 0x2306: 0x0080, 0x2307: 0x0080, 0x2308: 0x0080, 0x2309: 0x0080, 0x230a: 0x0080, 0x230b: 0x0080, - 0x230c: 0x0080, 0x230d: 0x0080, 0x230e: 0x0080, 0x230f: 0x0080, 0x2310: 0x0080, 0x2311: 0x0080, - 0x2312: 0x0080, 0x2313: 0x0080, 0x2314: 0x0080, 0x2315: 0x0080, 0x2316: 0x0080, 0x2317: 0x0080, - 0x2318: 0x0080, 0x2319: 0x0080, 0x231a: 0x0080, 0x231b: 0x0080, 0x231c: 0x0080, 0x231d: 0x0080, - 0x231e: 0x0080, 0x231f: 0x0080, 0x2320: 0x0080, 0x2321: 0x0080, 0x2322: 0x0080, 0x2323: 0x0080, - 0x2324: 0x0040, 0x2325: 0x0080, 0x2326: 0x0080, 0x2327: 0x0080, 0x2328: 0x0080, 0x2329: 0x0080, - 0x232a: 0x0080, 0x232b: 0x0080, 0x232c: 0x0080, 0x232d: 0x0080, 0x232e: 0x0080, 0x232f: 0x0080, - 0x2330: 0x0080, 0x2331: 0x0080, 0x2332: 0x0080, 0x2333: 0x0080, 0x2334: 0x0080, 0x2335: 0x0080, - 0x2336: 0x0080, 0x2337: 0x0080, 0x2338: 0x0080, 0x2339: 0x0080, 0x233a: 0x0080, 0x233b: 0x0080, - 0x233c: 0x0080, 0x233d: 0x0080, 0x233e: 0x0080, 0x233f: 0x0080, - // Block 0x8d, offset 0x2340 - 0x2340: 0x0080, 0x2341: 0x0080, 0x2342: 0x0080, 0x2343: 0x0080, 0x2344: 0x0080, 0x2345: 0x0080, - 0x2346: 0x0080, 0x2347: 0x0080, 0x2348: 0x0080, 0x2349: 0x0080, 0x234a: 0x0080, 0x234b: 0x0080, - 0x234c: 0x0080, 0x234d: 0x0080, 0x234e: 0x0080, 0x2350: 0x0080, 0x2351: 0x0080, - 0x2352: 0x0080, 0x2353: 0x0080, 0x2354: 0x0080, 0x2355: 0x0080, 0x2356: 0x0080, 0x2357: 0x0080, - 0x2358: 0x0080, 0x2359: 0x0080, 0x235a: 0x0080, 0x235b: 0x0080, 0x235c: 0x0080, 0x235d: 0x0080, - 0x235e: 0x0080, 0x235f: 0x0080, 0x2360: 0x00c0, 0x2361: 0x00c0, 0x2362: 0x00c0, 0x2363: 0x00c0, - 0x2364: 0x00c0, 0x2365: 0x00c0, 0x2366: 0x00c0, 0x2367: 0x00c0, 0x2368: 0x00c0, 0x2369: 0x00c0, - 0x236a: 0x00c0, 0x236b: 0x00c0, 0x236c: 0x00c0, 0x236d: 0x00c0, 0x236e: 0x00c0, 0x236f: 0x00c0, - 0x2370: 0x00c0, 0x2371: 0x00c0, 0x2372: 0x00c0, 0x2373: 0x00c0, 0x2374: 0x00c0, 0x2375: 0x00c0, - 0x2376: 0x00c0, 0x2377: 0x00c0, 0x2378: 0x00c0, 0x2379: 0x00c0, 0x237a: 0x00c0, - // Block 0x8e, offset 0x2380 - 0x2380: 0x0080, 0x2381: 0x0080, 0x2382: 0x0080, 0x2383: 0x0080, 0x2384: 0x0080, 0x2385: 0x0080, - 0x2386: 0x0080, 0x2387: 0x0080, 0x2388: 0x0080, 0x2389: 0x0080, 0x238a: 0x0080, 0x238b: 0x0080, - 0x238c: 0x0080, 0x238d: 0x0080, 0x238e: 0x0080, 0x238f: 0x0080, 0x2390: 0x0080, 0x2391: 0x0080, - 0x2392: 0x0080, 0x2393: 0x0080, 0x2394: 0x0080, 0x2395: 0x0080, 0x2396: 0x0080, 0x2397: 0x0080, - 0x2398: 0x0080, 0x2399: 0x0080, 0x239a: 0x0080, 0x239b: 0x0080, 0x239c: 0x0080, 0x239d: 0x0080, - 0x239e: 0x0080, 0x239f: 0x0080, 0x23a0: 0x0080, 0x23a1: 0x0080, 0x23a2: 0x0080, 0x23a3: 0x0080, - 0x23b0: 0x00cc, 0x23b1: 0x00cc, 0x23b2: 0x00cc, 0x23b3: 0x00cc, 0x23b4: 0x00cc, 0x23b5: 0x00cc, - 0x23b6: 0x00cc, 0x23b7: 0x00cc, 0x23b8: 0x00cc, 0x23b9: 0x00cc, 0x23ba: 0x00cc, 0x23bb: 0x00cc, - 0x23bc: 0x00cc, 0x23bd: 0x00cc, 0x23be: 0x00cc, 0x23bf: 0x00cc, - // Block 0x8f, offset 0x23c0 - 0x23c0: 0x0080, 0x23c1: 0x0080, 0x23c2: 0x0080, 0x23c3: 0x0080, 0x23c4: 0x0080, 0x23c5: 0x0080, - 0x23c6: 0x0080, 0x23c7: 0x0080, 0x23c8: 0x0080, 0x23c9: 0x0080, 0x23ca: 0x0080, 0x23cb: 0x0080, - 0x23cc: 0x0080, 0x23cd: 0x0080, 0x23ce: 0x0080, 0x23cf: 0x0080, 0x23d0: 0x0080, 0x23d1: 0x0080, - 0x23d2: 0x0080, 0x23d3: 0x0080, 0x23d4: 0x0080, 0x23d5: 0x0080, 0x23d6: 0x0080, 0x23d7: 0x0080, - 0x23d8: 0x0080, 0x23d9: 0x0080, 0x23da: 0x0080, 0x23db: 0x0080, 0x23dc: 0x0080, 0x23dd: 0x0080, - 0x23de: 0x0080, 0x23e0: 0x0080, 0x23e1: 0x0080, 0x23e2: 0x0080, 0x23e3: 0x0080, - 0x23e4: 0x0080, 0x23e5: 0x0080, 0x23e6: 0x0080, 0x23e7: 0x0080, 0x23e8: 0x0080, 0x23e9: 0x0080, - 0x23ea: 0x0080, 0x23eb: 0x0080, 0x23ec: 0x0080, 0x23ed: 0x0080, 0x23ee: 0x0080, 0x23ef: 0x0080, - 0x23f0: 0x0080, 0x23f1: 0x0080, 0x23f2: 0x0080, 0x23f3: 0x0080, 0x23f4: 0x0080, 0x23f5: 0x0080, - 0x23f6: 0x0080, 0x23f7: 0x0080, 0x23f8: 0x0080, 0x23f9: 0x0080, 0x23fa: 0x0080, 0x23fb: 0x0080, - 0x23fc: 0x0080, 0x23fd: 0x0080, 0x23fe: 0x0080, 0x23ff: 0x0080, - // Block 0x90, offset 0x2400 - 0x2400: 0x0080, 0x2401: 0x0080, 0x2402: 0x0080, 0x2403: 0x0080, 0x2404: 0x0080, 0x2405: 0x0080, - 0x2406: 0x0080, 0x2407: 0x0080, 0x2408: 0x0080, 0x2409: 0x0080, 0x240a: 0x0080, 0x240b: 0x0080, - 0x240c: 0x0080, 0x240d: 0x0080, 0x240e: 0x0080, 0x240f: 0x0080, 0x2410: 0x008c, 0x2411: 0x008c, - 0x2412: 0x008c, 0x2413: 0x008c, 0x2414: 0x008c, 0x2415: 0x008c, 0x2416: 0x008c, 0x2417: 0x008c, - 0x2418: 0x008c, 0x2419: 0x008c, 0x241a: 0x008c, 0x241b: 0x008c, 0x241c: 0x008c, 0x241d: 0x008c, - 0x241e: 0x008c, 0x241f: 0x008c, 0x2420: 0x008c, 0x2421: 0x008c, 0x2422: 0x008c, 0x2423: 0x008c, - 0x2424: 0x008c, 0x2425: 0x008c, 0x2426: 0x008c, 0x2427: 0x008c, 0x2428: 0x008c, 0x2429: 0x008c, - 0x242a: 0x008c, 0x242b: 0x008c, 0x242c: 0x008c, 0x242d: 0x008c, 0x242e: 0x008c, 0x242f: 0x008c, - 0x2430: 0x008c, 0x2431: 0x008c, 0x2432: 0x008c, 0x2433: 0x008c, 0x2434: 0x008c, 0x2435: 0x008c, - 0x2436: 0x008c, 0x2437: 0x008c, 0x2438: 0x008c, 0x2439: 0x008c, 0x243a: 0x008c, 0x243b: 0x008c, - 0x243c: 0x008c, 0x243d: 0x008c, 0x243e: 0x008c, - // Block 0x91, offset 0x2440 - 0x2440: 0x008c, 0x2441: 0x008c, 0x2442: 0x008c, 0x2443: 0x008c, 0x2444: 0x008c, 0x2445: 0x008c, - 0x2446: 0x008c, 0x2447: 0x008c, 0x2448: 0x008c, 0x2449: 0x008c, 0x244a: 0x008c, 0x244b: 0x008c, - 0x244c: 0x008c, 0x244d: 0x008c, 0x244e: 0x008c, 0x244f: 0x008c, 0x2450: 0x008c, 0x2451: 0x008c, - 0x2452: 0x008c, 0x2453: 0x008c, 0x2454: 0x008c, 0x2455: 0x008c, 0x2456: 0x008c, 0x2457: 0x008c, - 0x2458: 0x0080, 0x2459: 0x0080, 0x245a: 0x0080, 0x245b: 0x0080, 0x245c: 0x0080, 0x245d: 0x0080, - 0x245e: 0x0080, 0x245f: 0x0080, 0x2460: 0x0080, 0x2461: 0x0080, 0x2462: 0x0080, 0x2463: 0x0080, - 0x2464: 0x0080, 0x2465: 0x0080, 0x2466: 0x0080, 0x2467: 0x0080, 0x2468: 0x0080, 0x2469: 0x0080, - 0x246a: 0x0080, 0x246b: 0x0080, 0x246c: 0x0080, 0x246d: 0x0080, 0x246e: 0x0080, 0x246f: 0x0080, - 0x2470: 0x0080, 0x2471: 0x0080, 0x2472: 0x0080, 0x2473: 0x0080, 0x2474: 0x0080, 0x2475: 0x0080, - 0x2476: 0x0080, 0x2477: 0x0080, 0x2478: 0x0080, 0x2479: 0x0080, 0x247a: 0x0080, 0x247b: 0x0080, - 0x247c: 0x0080, 0x247d: 0x0080, 0x247e: 0x0080, 0x247f: 0x0080, - // Block 0x92, offset 0x2480 - 0x2480: 0x00cc, 0x2481: 0x00cc, 0x2482: 0x00cc, 0x2483: 0x00cc, 0x2484: 0x00cc, 0x2485: 0x00cc, - 0x2486: 0x00cc, 0x2487: 0x00cc, 0x2488: 0x00cc, 0x2489: 0x00cc, 0x248a: 0x00cc, 0x248b: 0x00cc, - 0x248c: 0x00cc, 0x248d: 0x00cc, 0x248e: 0x00cc, 0x248f: 0x00cc, 0x2490: 0x00cc, 0x2491: 0x00cc, - 0x2492: 0x00cc, 0x2493: 0x00cc, 0x2494: 0x00cc, 0x2495: 0x00cc, 0x2496: 0x00cc, 0x2497: 0x00cc, - 0x2498: 0x00cc, 0x2499: 0x00cc, 0x249a: 0x00cc, 0x249b: 0x00cc, 0x249c: 0x00cc, 0x249d: 0x00cc, - 0x249e: 0x00cc, 0x249f: 0x00cc, 0x24a0: 0x00cc, 0x24a1: 0x00cc, 0x24a2: 0x00cc, 0x24a3: 0x00cc, - 0x24a4: 0x00cc, 0x24a5: 0x00cc, 0x24a6: 0x00cc, 0x24a7: 0x00cc, 0x24a8: 0x00cc, 0x24a9: 0x00cc, - 0x24aa: 0x00cc, 0x24ab: 0x00cc, 0x24ac: 0x00cc, 0x24ad: 0x00cc, 0x24ae: 0x00cc, 0x24af: 0x00cc, - 0x24b0: 0x00cc, 0x24b1: 0x00cc, 0x24b2: 0x00cc, 0x24b3: 0x00cc, 0x24b4: 0x00cc, 0x24b5: 0x00cc, - 0x24b6: 0x00cc, 0x24b7: 0x00cc, 0x24b8: 0x00cc, 0x24b9: 0x00cc, 0x24ba: 0x00cc, 0x24bb: 0x00cc, - 0x24bc: 0x00cc, 0x24bd: 0x00cc, 0x24be: 0x00cc, 0x24bf: 0x00cc, - // Block 0x93, offset 0x24c0 - 0x24c0: 0x00cc, 0x24c1: 0x00cc, 0x24c2: 0x00cc, 0x24c3: 0x00cc, 0x24c4: 0x00cc, 0x24c5: 0x00cc, - 0x24c6: 0x00cc, 0x24c7: 0x00cc, 0x24c8: 0x00cc, 0x24c9: 0x00cc, 0x24ca: 0x00cc, 0x24cb: 0x00cc, - 0x24cc: 0x00cc, 0x24cd: 0x00cc, 0x24ce: 0x00cc, 0x24cf: 0x00cc, 0x24d0: 0x00cc, 0x24d1: 0x00cc, - 0x24d2: 0x00cc, 0x24d3: 0x00cc, 0x24d4: 0x00cc, 0x24d5: 0x00cc, 0x24d6: 0x00cc, 0x24d7: 0x00cc, - 0x24d8: 0x00cc, 0x24d9: 0x00cc, 0x24da: 0x00cc, 0x24db: 0x00cc, 0x24dc: 0x00cc, 0x24dd: 0x00cc, - 0x24de: 0x00cc, 0x24df: 0x00cc, 0x24e0: 0x00cc, 0x24e1: 0x00cc, 0x24e2: 0x00cc, 0x24e3: 0x00cc, - 0x24e4: 0x00cc, 0x24e5: 0x00cc, 0x24e6: 0x00cc, 0x24e7: 0x00cc, 0x24e8: 0x00cc, 0x24e9: 0x00cc, - 0x24ea: 0x00cc, 0x24eb: 0x00cc, 0x24ec: 0x00cc, 0x24ed: 0x00cc, 0x24ee: 0x00cc, 0x24ef: 0x00cc, - 0x24f0: 0x00cc, 0x24f1: 0x00cc, 0x24f2: 0x00cc, 0x24f3: 0x00cc, 0x24f4: 0x00cc, 0x24f5: 0x00cc, - // Block 0x94, offset 0x2500 - 0x2500: 0x00cc, 0x2501: 0x00cc, 0x2502: 0x00cc, 0x2503: 0x00cc, 0x2504: 0x00cc, 0x2505: 0x00cc, - 0x2506: 0x00cc, 0x2507: 0x00cc, 0x2508: 0x00cc, 0x2509: 0x00cc, 0x250a: 0x00cc, 0x250b: 0x00cc, - 0x250c: 0x00cc, 0x250d: 0x00cc, 0x250e: 0x00cc, 0x250f: 0x00cc, 0x2510: 0x00cc, 0x2511: 0x00cc, - 0x2512: 0x00cc, 0x2513: 0x00cc, 0x2514: 0x00cc, 0x2515: 0x00cc, - // Block 0x95, offset 0x2540 - 0x2540: 0x00c0, 0x2541: 0x00c0, 0x2542: 0x00c0, 0x2543: 0x00c0, 0x2544: 0x00c0, 0x2545: 0x00c0, - 0x2546: 0x00c0, 0x2547: 0x00c0, 0x2548: 0x00c0, 0x2549: 0x00c0, 0x254a: 0x00c0, 0x254b: 0x00c0, - 0x254c: 0x00c0, 0x2550: 0x0080, 0x2551: 0x0080, - 0x2552: 0x0080, 0x2553: 0x0080, 0x2554: 0x0080, 0x2555: 0x0080, 0x2556: 0x0080, 0x2557: 0x0080, - 0x2558: 0x0080, 0x2559: 0x0080, 0x255a: 0x0080, 0x255b: 0x0080, 0x255c: 0x0080, 0x255d: 0x0080, - 0x255e: 0x0080, 0x255f: 0x0080, 0x2560: 0x0080, 0x2561: 0x0080, 0x2562: 0x0080, 0x2563: 0x0080, - 0x2564: 0x0080, 0x2565: 0x0080, 0x2566: 0x0080, 0x2567: 0x0080, 0x2568: 0x0080, 0x2569: 0x0080, - 0x256a: 0x0080, 0x256b: 0x0080, 0x256c: 0x0080, 0x256d: 0x0080, 0x256e: 0x0080, 0x256f: 0x0080, - 0x2570: 0x0080, 0x2571: 0x0080, 0x2572: 0x0080, 0x2573: 0x0080, 0x2574: 0x0080, 0x2575: 0x0080, - 0x2576: 0x0080, 0x2577: 0x0080, 0x2578: 0x0080, 0x2579: 0x0080, 0x257a: 0x0080, 0x257b: 0x0080, - 0x257c: 0x0080, 0x257d: 0x0080, 0x257e: 0x0080, 0x257f: 0x0080, - // Block 0x96, offset 0x2580 - 0x2580: 0x0080, 0x2581: 0x0080, 0x2582: 0x0080, 0x2583: 0x0080, 0x2584: 0x0080, 0x2585: 0x0080, - 0x2586: 0x0080, - 0x2590: 0x00c0, 0x2591: 0x00c0, - 0x2592: 0x00c0, 0x2593: 0x00c0, 0x2594: 0x00c0, 0x2595: 0x00c0, 0x2596: 0x00c0, 0x2597: 0x00c0, - 0x2598: 0x00c0, 0x2599: 0x00c0, 0x259a: 0x00c0, 0x259b: 0x00c0, 0x259c: 0x00c0, 0x259d: 0x00c0, - 0x259e: 0x00c0, 0x259f: 0x00c0, 0x25a0: 0x00c0, 0x25a1: 0x00c0, 0x25a2: 0x00c0, 0x25a3: 0x00c0, - 0x25a4: 0x00c0, 0x25a5: 0x00c0, 0x25a6: 0x00c0, 0x25a7: 0x00c0, 0x25a8: 0x00c0, 0x25a9: 0x00c0, - 0x25aa: 0x00c0, 0x25ab: 0x00c0, 0x25ac: 0x00c0, 0x25ad: 0x00c0, 0x25ae: 0x00c0, 0x25af: 0x00c0, - 0x25b0: 0x00c0, 0x25b1: 0x00c0, 0x25b2: 0x00c0, 0x25b3: 0x00c0, 0x25b4: 0x00c0, 0x25b5: 0x00c0, - 0x25b6: 0x00c0, 0x25b7: 0x00c0, 0x25b8: 0x00c0, 0x25b9: 0x00c0, 0x25ba: 0x00c0, 0x25bb: 0x00c0, - 0x25bc: 0x00c0, 0x25bd: 0x00c0, 0x25be: 0x0080, 0x25bf: 0x0080, - // Block 0x97, offset 0x25c0 - 0x25c0: 0x00c0, 0x25c1: 0x00c0, 0x25c2: 0x00c0, 0x25c3: 0x00c0, 0x25c4: 0x00c0, 0x25c5: 0x00c0, - 0x25c6: 0x00c0, 0x25c7: 0x00c0, 0x25c8: 0x00c0, 0x25c9: 0x00c0, 0x25ca: 0x00c0, 0x25cb: 0x00c0, - 0x25cc: 0x00c0, 0x25cd: 0x0080, 0x25ce: 0x0080, 0x25cf: 0x0080, 0x25d0: 0x00c0, 0x25d1: 0x00c0, - 0x25d2: 0x00c0, 0x25d3: 0x00c0, 0x25d4: 0x00c0, 0x25d5: 0x00c0, 0x25d6: 0x00c0, 0x25d7: 0x00c0, - 0x25d8: 0x00c0, 0x25d9: 0x00c0, 0x25da: 0x00c0, 0x25db: 0x00c0, 0x25dc: 0x00c0, 0x25dd: 0x00c0, - 0x25de: 0x00c0, 0x25df: 0x00c0, 0x25e0: 0x00c0, 0x25e1: 0x00c0, 0x25e2: 0x00c0, 0x25e3: 0x00c0, - 0x25e4: 0x00c0, 0x25e5: 0x00c0, 0x25e6: 0x00c0, 0x25e7: 0x00c0, 0x25e8: 0x00c0, 0x25e9: 0x00c0, - 0x25ea: 0x00c0, 0x25eb: 0x00c0, - // Block 0x98, offset 0x2600 - 0x2600: 0x00c0, 0x2601: 0x00c0, 0x2602: 0x00c0, 0x2603: 0x00c0, 0x2604: 0x00c0, 0x2605: 0x00c0, - 0x2606: 0x00c0, 0x2607: 0x00c0, 0x2608: 0x00c0, 0x2609: 0x00c0, 0x260a: 0x00c0, 0x260b: 0x00c0, - 0x260c: 0x00c0, 0x260d: 0x00c0, 0x260e: 0x00c0, 0x260f: 0x00c0, 0x2610: 0x00c0, 0x2611: 0x00c0, - 0x2612: 0x00c0, 0x2613: 0x00c0, 0x2614: 0x00c0, 0x2615: 0x00c0, 0x2616: 0x00c0, 0x2617: 0x00c0, - 0x2618: 0x00c0, 0x2619: 0x00c0, 0x261a: 0x00c0, 0x261b: 0x00c0, 0x261c: 0x00c0, 0x261d: 0x00c0, - 0x261e: 0x00c0, 0x261f: 0x00c0, 0x2620: 0x00c0, 0x2621: 0x00c0, 0x2622: 0x00c0, 0x2623: 0x00c0, - 0x2624: 0x00c0, 0x2625: 0x00c0, 0x2626: 0x00c0, 0x2627: 0x00c0, 0x2628: 0x00c0, 0x2629: 0x00c0, - 0x262a: 0x00c0, 0x262b: 0x00c0, 0x262c: 0x00c0, 0x262d: 0x00c0, 0x262e: 0x00c0, 0x262f: 0x00c3, - 0x2630: 0x0083, 0x2631: 0x0083, 0x2632: 0x0083, 0x2633: 0x0080, 0x2634: 0x00c3, 0x2635: 0x00c3, - 0x2636: 0x00c3, 0x2637: 0x00c3, 0x2638: 0x00c3, 0x2639: 0x00c3, 0x263a: 0x00c3, 0x263b: 0x00c3, - 0x263c: 0x00c3, 0x263d: 0x00c3, 0x263e: 0x0080, 0x263f: 0x00c0, - // Block 0x99, offset 0x2640 - 0x2640: 0x00c0, 0x2641: 0x00c0, 0x2642: 0x00c0, 0x2643: 0x00c0, 0x2644: 0x00c0, 0x2645: 0x00c0, - 0x2646: 0x00c0, 0x2647: 0x00c0, 0x2648: 0x00c0, 0x2649: 0x00c0, 0x264a: 0x00c0, 0x264b: 0x00c0, - 0x264c: 0x00c0, 0x264d: 0x00c0, 0x264e: 0x00c0, 0x264f: 0x00c0, 0x2650: 0x00c0, 0x2651: 0x00c0, - 0x2652: 0x00c0, 0x2653: 0x00c0, 0x2654: 0x00c0, 0x2655: 0x00c0, 0x2656: 0x00c0, 0x2657: 0x00c0, - 0x2658: 0x00c0, 0x2659: 0x00c0, 0x265a: 0x00c0, 0x265b: 0x00c0, 0x265c: 0x0080, 0x265d: 0x0080, - 0x265e: 0x00c3, 0x265f: 0x00c3, 0x2660: 0x00c0, 0x2661: 0x00c0, 0x2662: 0x00c0, 0x2663: 0x00c0, - 0x2664: 0x00c0, 0x2665: 0x00c0, 0x2666: 0x00c0, 0x2667: 0x00c0, 0x2668: 0x00c0, 0x2669: 0x00c0, - 0x266a: 0x00c0, 0x266b: 0x00c0, 0x266c: 0x00c0, 0x266d: 0x00c0, 0x266e: 0x00c0, 0x266f: 0x00c0, - 0x2670: 0x00c0, 0x2671: 0x00c0, 0x2672: 0x00c0, 0x2673: 0x00c0, 0x2674: 0x00c0, 0x2675: 0x00c0, - 0x2676: 0x00c0, 0x2677: 0x00c0, 0x2678: 0x00c0, 0x2679: 0x00c0, 0x267a: 0x00c0, 0x267b: 0x00c0, - 0x267c: 0x00c0, 0x267d: 0x00c0, 0x267e: 0x00c0, 0x267f: 0x00c0, - // Block 0x9a, offset 0x2680 - 0x2680: 0x00c0, 0x2681: 0x00c0, 0x2682: 0x00c0, 0x2683: 0x00c0, 0x2684: 0x00c0, 0x2685: 0x00c0, - 0x2686: 0x00c0, 0x2687: 0x00c0, 0x2688: 0x00c0, 0x2689: 0x00c0, 0x268a: 0x00c0, 0x268b: 0x00c0, - 0x268c: 0x00c0, 0x268d: 0x00c0, 0x268e: 0x00c0, 0x268f: 0x00c0, 0x2690: 0x00c0, 0x2691: 0x00c0, - 0x2692: 0x00c0, 0x2693: 0x00c0, 0x2694: 0x00c0, 0x2695: 0x00c0, 0x2696: 0x00c0, 0x2697: 0x00c0, - 0x2698: 0x00c0, 0x2699: 0x00c0, 0x269a: 0x00c0, 0x269b: 0x00c0, 0x269c: 0x00c0, 0x269d: 0x00c0, - 0x269e: 0x00c0, 0x269f: 0x00c0, 0x26a0: 0x00c0, 0x26a1: 0x00c0, 0x26a2: 0x00c0, 0x26a3: 0x00c0, - 0x26a4: 0x00c0, 0x26a5: 0x00c0, 0x26a6: 0x0080, 0x26a7: 0x0080, 0x26a8: 0x0080, 0x26a9: 0x0080, - 0x26aa: 0x0080, 0x26ab: 0x0080, 0x26ac: 0x0080, 0x26ad: 0x0080, 0x26ae: 0x0080, 0x26af: 0x0080, - 0x26b0: 0x00c3, 0x26b1: 0x00c3, 0x26b2: 0x0080, 0x26b3: 0x0080, 0x26b4: 0x0080, 0x26b5: 0x0080, - 0x26b6: 0x0080, 0x26b7: 0x0080, - // Block 0x9b, offset 0x26c0 - 0x26c0: 0x0080, 0x26c1: 0x0080, 0x26c2: 0x0080, 0x26c3: 0x0080, 0x26c4: 0x0080, 0x26c5: 0x0080, - 0x26c6: 0x0080, 0x26c7: 0x0080, 0x26c8: 0x0080, 0x26c9: 0x0080, 0x26ca: 0x0080, 0x26cb: 0x0080, - 0x26cc: 0x0080, 0x26cd: 0x0080, 0x26ce: 0x0080, 0x26cf: 0x0080, 0x26d0: 0x0080, 0x26d1: 0x0080, - 0x26d2: 0x0080, 0x26d3: 0x0080, 0x26d4: 0x0080, 0x26d5: 0x0080, 0x26d6: 0x0080, 0x26d7: 0x00c0, - 0x26d8: 0x00c0, 0x26d9: 0x00c0, 0x26da: 0x00c0, 0x26db: 0x00c0, 0x26dc: 0x00c0, 0x26dd: 0x00c0, - 0x26de: 0x00c0, 0x26df: 0x00c0, 0x26e0: 0x0080, 0x26e1: 0x0080, 0x26e2: 0x00c0, 0x26e3: 0x00c0, - 0x26e4: 0x00c0, 0x26e5: 0x00c0, 0x26e6: 0x00c0, 0x26e7: 0x00c0, 0x26e8: 0x00c0, 0x26e9: 0x00c0, - 0x26ea: 0x00c0, 0x26eb: 0x00c0, 0x26ec: 0x00c0, 0x26ed: 0x00c0, 0x26ee: 0x00c0, 0x26ef: 0x00c0, - 0x26f0: 0x00c0, 0x26f1: 0x00c0, 0x26f2: 0x00c0, 0x26f3: 0x00c0, 0x26f4: 0x00c0, 0x26f5: 0x00c0, - 0x26f6: 0x00c0, 0x26f7: 0x00c0, 0x26f8: 0x00c0, 0x26f9: 0x00c0, 0x26fa: 0x00c0, 0x26fb: 0x00c0, - 0x26fc: 0x00c0, 0x26fd: 0x00c0, 0x26fe: 0x00c0, 0x26ff: 0x00c0, - // Block 0x9c, offset 0x2700 - 0x2700: 0x00c0, 0x2701: 0x00c0, 0x2702: 0x00c0, 0x2703: 0x00c0, 0x2704: 0x00c0, 0x2705: 0x00c0, - 0x2706: 0x00c0, 0x2707: 0x00c0, 0x2708: 0x00c0, 0x2709: 0x00c0, 0x270a: 0x00c0, 0x270b: 0x00c0, - 0x270c: 0x00c0, 0x270d: 0x00c0, 0x270e: 0x00c0, 0x270f: 0x00c0, 0x2710: 0x00c0, 0x2711: 0x00c0, - 0x2712: 0x00c0, 0x2713: 0x00c0, 0x2714: 0x00c0, 0x2715: 0x00c0, 0x2716: 0x00c0, 0x2717: 0x00c0, - 0x2718: 0x00c0, 0x2719: 0x00c0, 0x271a: 0x00c0, 0x271b: 0x00c0, 0x271c: 0x00c0, 0x271d: 0x00c0, - 0x271e: 0x00c0, 0x271f: 0x00c0, 0x2720: 0x00c0, 0x2721: 0x00c0, 0x2722: 0x00c0, 0x2723: 0x00c0, - 0x2724: 0x00c0, 0x2725: 0x00c0, 0x2726: 0x00c0, 0x2727: 0x00c0, 0x2728: 0x00c0, 0x2729: 0x00c0, - 0x272a: 0x00c0, 0x272b: 0x00c0, 0x272c: 0x00c0, 0x272d: 0x00c0, 0x272e: 0x00c0, 0x272f: 0x00c0, - 0x2730: 0x0080, 0x2731: 0x00c0, 0x2732: 0x00c0, 0x2733: 0x00c0, 0x2734: 0x00c0, 0x2735: 0x00c0, - 0x2736: 0x00c0, 0x2737: 0x00c0, 0x2738: 0x00c0, 0x2739: 0x00c0, 0x273a: 0x00c0, 0x273b: 0x00c0, - 0x273c: 0x00c0, 0x273d: 0x00c0, 0x273e: 0x00c0, 0x273f: 0x00c0, - // Block 0x9d, offset 0x2740 - 0x2740: 0x00c0, 0x2741: 0x00c0, 0x2742: 0x00c0, 0x2743: 0x00c0, 0x2744: 0x00c0, 0x2745: 0x00c0, - 0x2746: 0x00c0, 0x2747: 0x00c0, 0x2748: 0x00c0, 0x2749: 0x0080, 0x274a: 0x0080, 0x274b: 0x00c0, - 0x274c: 0x00c0, 0x274d: 0x00c0, 0x274e: 0x00c0, 0x274f: 0x00c0, 0x2750: 0x00c0, 0x2751: 0x00c0, - 0x2752: 0x00c0, 0x2753: 0x00c0, 0x2754: 0x00c0, 0x2755: 0x00c0, 0x2756: 0x00c0, 0x2757: 0x00c0, - 0x2758: 0x00c0, 0x2759: 0x00c0, 0x275a: 0x00c0, 0x275b: 0x00c0, 0x275c: 0x00c0, 0x275d: 0x00c0, - 0x275e: 0x00c0, 0x275f: 0x00c0, 0x2760: 0x00c0, 0x2761: 0x00c0, 0x2762: 0x00c0, 0x2763: 0x00c0, - 0x2764: 0x00c0, 0x2765: 0x00c0, 0x2766: 0x00c0, 0x2767: 0x00c0, 0x2768: 0x00c0, 0x2769: 0x00c0, - 0x276a: 0x00c0, 0x276b: 0x00c0, 0x276c: 0x00c0, 0x276d: 0x00c0, 0x276e: 0x00c0, - 0x2770: 0x00c0, 0x2771: 0x00c0, 0x2772: 0x00c0, 0x2773: 0x00c0, 0x2774: 0x00c0, 0x2775: 0x00c0, - 0x2776: 0x00c0, 0x2777: 0x00c0, - // Block 0x9e, offset 0x2780 - 0x27b7: 0x00c0, 0x27b8: 0x0080, 0x27b9: 0x0080, 0x27ba: 0x00c0, 0x27bb: 0x00c0, - 0x27bc: 0x00c0, 0x27bd: 0x00c0, 0x27be: 0x00c0, 0x27bf: 0x00c0, - // Block 0x9f, offset 0x27c0 - 0x27c0: 0x00c0, 0x27c1: 0x00c0, 0x27c2: 0x00c3, 0x27c3: 0x00c0, 0x27c4: 0x00c0, 0x27c5: 0x00c0, - 0x27c6: 0x00c6, 0x27c7: 0x00c0, 0x27c8: 0x00c0, 0x27c9: 0x00c0, 0x27ca: 0x00c0, 0x27cb: 0x00c3, - 0x27cc: 0x00c0, 0x27cd: 0x00c0, 0x27ce: 0x00c0, 0x27cf: 0x00c0, 0x27d0: 0x00c0, 0x27d1: 0x00c0, - 0x27d2: 0x00c0, 0x27d3: 0x00c0, 0x27d4: 0x00c0, 0x27d5: 0x00c0, 0x27d6: 0x00c0, 0x27d7: 0x00c0, - 0x27d8: 0x00c0, 0x27d9: 0x00c0, 0x27da: 0x00c0, 0x27db: 0x00c0, 0x27dc: 0x00c0, 0x27dd: 0x00c0, - 0x27de: 0x00c0, 0x27df: 0x00c0, 0x27e0: 0x00c0, 0x27e1: 0x00c0, 0x27e2: 0x00c0, 0x27e3: 0x00c0, - 0x27e4: 0x00c0, 0x27e5: 0x00c3, 0x27e6: 0x00c3, 0x27e7: 0x00c0, 0x27e8: 0x0080, 0x27e9: 0x0080, - 0x27ea: 0x0080, 0x27eb: 0x0080, - 0x27f0: 0x0080, 0x27f1: 0x0080, 0x27f2: 0x0080, 0x27f3: 0x0080, 0x27f4: 0x0080, 0x27f5: 0x0080, - 0x27f6: 0x0080, 0x27f7: 0x0080, 0x27f8: 0x0080, 0x27f9: 0x0080, - // Block 0xa0, offset 0x2800 - 0x2800: 0x00c2, 0x2801: 0x00c2, 0x2802: 0x00c2, 0x2803: 0x00c2, 0x2804: 0x00c2, 0x2805: 0x00c2, - 0x2806: 0x00c2, 0x2807: 0x00c2, 0x2808: 0x00c2, 0x2809: 0x00c2, 0x280a: 0x00c2, 0x280b: 0x00c2, - 0x280c: 0x00c2, 0x280d: 0x00c2, 0x280e: 0x00c2, 0x280f: 0x00c2, 0x2810: 0x00c2, 0x2811: 0x00c2, - 0x2812: 0x00c2, 0x2813: 0x00c2, 0x2814: 0x00c2, 0x2815: 0x00c2, 0x2816: 0x00c2, 0x2817: 0x00c2, - 0x2818: 0x00c2, 0x2819: 0x00c2, 0x281a: 0x00c2, 0x281b: 0x00c2, 0x281c: 0x00c2, 0x281d: 0x00c2, - 0x281e: 0x00c2, 0x281f: 0x00c2, 0x2820: 0x00c2, 0x2821: 0x00c2, 0x2822: 0x00c2, 0x2823: 0x00c2, - 0x2824: 0x00c2, 0x2825: 0x00c2, 0x2826: 0x00c2, 0x2827: 0x00c2, 0x2828: 0x00c2, 0x2829: 0x00c2, - 0x282a: 0x00c2, 0x282b: 0x00c2, 0x282c: 0x00c2, 0x282d: 0x00c2, 0x282e: 0x00c2, 0x282f: 0x00c2, - 0x2830: 0x00c2, 0x2831: 0x00c2, 0x2832: 0x00c1, 0x2833: 0x00c0, 0x2834: 0x0080, 0x2835: 0x0080, - 0x2836: 0x0080, 0x2837: 0x0080, - // Block 0xa1, offset 0x2840 - 0x2840: 0x00c0, 0x2841: 0x00c0, 0x2842: 0x00c0, 0x2843: 0x00c0, 0x2844: 0x00c6, 0x2845: 0x00c3, - 0x284e: 0x0080, 0x284f: 0x0080, 0x2850: 0x00c0, 0x2851: 0x00c0, - 0x2852: 0x00c0, 0x2853: 0x00c0, 0x2854: 0x00c0, 0x2855: 0x00c0, 0x2856: 0x00c0, 0x2857: 0x00c0, - 0x2858: 0x00c0, 0x2859: 0x00c0, - 0x2860: 0x00c3, 0x2861: 0x00c3, 0x2862: 0x00c3, 0x2863: 0x00c3, - 0x2864: 0x00c3, 0x2865: 0x00c3, 0x2866: 0x00c3, 0x2867: 0x00c3, 0x2868: 0x00c3, 0x2869: 0x00c3, - 0x286a: 0x00c3, 0x286b: 0x00c3, 0x286c: 0x00c3, 0x286d: 0x00c3, 0x286e: 0x00c3, 0x286f: 0x00c3, - 0x2870: 0x00c3, 0x2871: 0x00c3, 0x2872: 0x00c0, 0x2873: 0x00c0, 0x2874: 0x00c0, 0x2875: 0x00c0, - 0x2876: 0x00c0, 0x2877: 0x00c0, 0x2878: 0x0080, 0x2879: 0x0080, 0x287a: 0x0080, 0x287b: 0x00c0, - 0x287c: 0x0080, 0x287d: 0x00c0, - // Block 0xa2, offset 0x2880 - 0x2880: 0x00c0, 0x2881: 0x00c0, 0x2882: 0x00c0, 0x2883: 0x00c0, 0x2884: 0x00c0, 0x2885: 0x00c0, - 0x2886: 0x00c0, 0x2887: 0x00c0, 0x2888: 0x00c0, 0x2889: 0x00c0, 0x288a: 0x00c0, 0x288b: 0x00c0, - 0x288c: 0x00c0, 0x288d: 0x00c0, 0x288e: 0x00c0, 0x288f: 0x00c0, 0x2890: 0x00c0, 0x2891: 0x00c0, - 0x2892: 0x00c0, 0x2893: 0x00c0, 0x2894: 0x00c0, 0x2895: 0x00c0, 0x2896: 0x00c0, 0x2897: 0x00c0, - 0x2898: 0x00c0, 0x2899: 0x00c0, 0x289a: 0x00c0, 0x289b: 0x00c0, 0x289c: 0x00c0, 0x289d: 0x00c0, - 0x289e: 0x00c0, 0x289f: 0x00c0, 0x28a0: 0x00c0, 0x28a1: 0x00c0, 0x28a2: 0x00c0, 0x28a3: 0x00c0, - 0x28a4: 0x00c0, 0x28a5: 0x00c0, 0x28a6: 0x00c3, 0x28a7: 0x00c3, 0x28a8: 0x00c3, 0x28a9: 0x00c3, - 0x28aa: 0x00c3, 0x28ab: 0x00c3, 0x28ac: 0x00c3, 0x28ad: 0x00c3, 0x28ae: 0x0080, 0x28af: 0x0080, - 0x28b0: 0x00c0, 0x28b1: 0x00c0, 0x28b2: 0x00c0, 0x28b3: 0x00c0, 0x28b4: 0x00c0, 0x28b5: 0x00c0, - 0x28b6: 0x00c0, 0x28b7: 0x00c0, 0x28b8: 0x00c0, 0x28b9: 0x00c0, 0x28ba: 0x00c0, 0x28bb: 0x00c0, - 0x28bc: 0x00c0, 0x28bd: 0x00c0, 0x28be: 0x00c0, 0x28bf: 0x00c0, - // Block 0xa3, offset 0x28c0 - 0x28c0: 0x00c0, 0x28c1: 0x00c0, 0x28c2: 0x00c0, 0x28c3: 0x00c0, 0x28c4: 0x00c0, 0x28c5: 0x00c0, - 0x28c6: 0x00c0, 0x28c7: 0x00c3, 0x28c8: 0x00c3, 0x28c9: 0x00c3, 0x28ca: 0x00c3, 0x28cb: 0x00c3, - 0x28cc: 0x00c3, 0x28cd: 0x00c3, 0x28ce: 0x00c3, 0x28cf: 0x00c3, 0x28d0: 0x00c3, 0x28d1: 0x00c3, - 0x28d2: 0x00c0, 0x28d3: 0x00c5, - 0x28df: 0x0080, 0x28e0: 0x0040, 0x28e1: 0x0040, 0x28e2: 0x0040, 0x28e3: 0x0040, - 0x28e4: 0x0040, 0x28e5: 0x0040, 0x28e6: 0x0040, 0x28e7: 0x0040, 0x28e8: 0x0040, 0x28e9: 0x0040, - 0x28ea: 0x0040, 0x28eb: 0x0040, 0x28ec: 0x0040, 0x28ed: 0x0040, 0x28ee: 0x0040, 0x28ef: 0x0040, - 0x28f0: 0x0040, 0x28f1: 0x0040, 0x28f2: 0x0040, 0x28f3: 0x0040, 0x28f4: 0x0040, 0x28f5: 0x0040, - 0x28f6: 0x0040, 0x28f7: 0x0040, 0x28f8: 0x0040, 0x28f9: 0x0040, 0x28fa: 0x0040, 0x28fb: 0x0040, - 0x28fc: 0x0040, - // Block 0xa4, offset 0x2900 - 0x2900: 0x00c3, 0x2901: 0x00c3, 0x2902: 0x00c3, 0x2903: 0x00c0, 0x2904: 0x00c0, 0x2905: 0x00c0, - 0x2906: 0x00c0, 0x2907: 0x00c0, 0x2908: 0x00c0, 0x2909: 0x00c0, 0x290a: 0x00c0, 0x290b: 0x00c0, - 0x290c: 0x00c0, 0x290d: 0x00c0, 0x290e: 0x00c0, 0x290f: 0x00c0, 0x2910: 0x00c0, 0x2911: 0x00c0, - 0x2912: 0x00c0, 0x2913: 0x00c0, 0x2914: 0x00c0, 0x2915: 0x00c0, 0x2916: 0x00c0, 0x2917: 0x00c0, - 0x2918: 0x00c0, 0x2919: 0x00c0, 0x291a: 0x00c0, 0x291b: 0x00c0, 0x291c: 0x00c0, 0x291d: 0x00c0, - 0x291e: 0x00c0, 0x291f: 0x00c0, 0x2920: 0x00c0, 0x2921: 0x00c0, 0x2922: 0x00c0, 0x2923: 0x00c0, - 0x2924: 0x00c0, 0x2925: 0x00c0, 0x2926: 0x00c0, 0x2927: 0x00c0, 0x2928: 0x00c0, 0x2929: 0x00c0, - 0x292a: 0x00c0, 0x292b: 0x00c0, 0x292c: 0x00c0, 0x292d: 0x00c0, 0x292e: 0x00c0, 0x292f: 0x00c0, - 0x2930: 0x00c0, 0x2931: 0x00c0, 0x2932: 0x00c0, 0x2933: 0x00c3, 0x2934: 0x00c0, 0x2935: 0x00c0, - 0x2936: 0x00c3, 0x2937: 0x00c3, 0x2938: 0x00c3, 0x2939: 0x00c3, 0x293a: 0x00c0, 0x293b: 0x00c0, - 0x293c: 0x00c3, 0x293d: 0x00c0, 0x293e: 0x00c0, 0x293f: 0x00c0, - // Block 0xa5, offset 0x2940 - 0x2940: 0x00c5, 0x2941: 0x0080, 0x2942: 0x0080, 0x2943: 0x0080, 0x2944: 0x0080, 0x2945: 0x0080, - 0x2946: 0x0080, 0x2947: 0x0080, 0x2948: 0x0080, 0x2949: 0x0080, 0x294a: 0x0080, 0x294b: 0x0080, - 0x294c: 0x0080, 0x294d: 0x0080, 0x294f: 0x00c0, 0x2950: 0x00c0, 0x2951: 0x00c0, - 0x2952: 0x00c0, 0x2953: 0x00c0, 0x2954: 0x00c0, 0x2955: 0x00c0, 0x2956: 0x00c0, 0x2957: 0x00c0, - 0x2958: 0x00c0, 0x2959: 0x00c0, - 0x295e: 0x0080, 0x295f: 0x0080, 0x2960: 0x00c0, 0x2961: 0x00c0, 0x2962: 0x00c0, 0x2963: 0x00c0, - 0x2964: 0x00c0, 0x2965: 0x00c3, 0x2966: 0x00c0, 0x2967: 0x00c0, 0x2968: 0x00c0, 0x2969: 0x00c0, - 0x296a: 0x00c0, 0x296b: 0x00c0, 0x296c: 0x00c0, 0x296d: 0x00c0, 0x296e: 0x00c0, 0x296f: 0x00c0, - 0x2970: 0x00c0, 0x2971: 0x00c0, 0x2972: 0x00c0, 0x2973: 0x00c0, 0x2974: 0x00c0, 0x2975: 0x00c0, - 0x2976: 0x00c0, 0x2977: 0x00c0, 0x2978: 0x00c0, 0x2979: 0x00c0, 0x297a: 0x00c0, 0x297b: 0x00c0, - 0x297c: 0x00c0, 0x297d: 0x00c0, 0x297e: 0x00c0, - // Block 0xa6, offset 0x2980 - 0x2980: 0x00c0, 0x2981: 0x00c0, 0x2982: 0x00c0, 0x2983: 0x00c0, 0x2984: 0x00c0, 0x2985: 0x00c0, - 0x2986: 0x00c0, 0x2987: 0x00c0, 0x2988: 0x00c0, 0x2989: 0x00c0, 0x298a: 0x00c0, 0x298b: 0x00c0, - 0x298c: 0x00c0, 0x298d: 0x00c0, 0x298e: 0x00c0, 0x298f: 0x00c0, 0x2990: 0x00c0, 0x2991: 0x00c0, - 0x2992: 0x00c0, 0x2993: 0x00c0, 0x2994: 0x00c0, 0x2995: 0x00c0, 0x2996: 0x00c0, 0x2997: 0x00c0, - 0x2998: 0x00c0, 0x2999: 0x00c0, 0x299a: 0x00c0, 0x299b: 0x00c0, 0x299c: 0x00c0, 0x299d: 0x00c0, - 0x299e: 0x00c0, 0x299f: 0x00c0, 0x29a0: 0x00c0, 0x29a1: 0x00c0, 0x29a2: 0x00c0, 0x29a3: 0x00c0, - 0x29a4: 0x00c0, 0x29a5: 0x00c0, 0x29a6: 0x00c0, 0x29a7: 0x00c0, 0x29a8: 0x00c0, 0x29a9: 0x00c3, - 0x29aa: 0x00c3, 0x29ab: 0x00c3, 0x29ac: 0x00c3, 0x29ad: 0x00c3, 0x29ae: 0x00c3, 0x29af: 0x00c0, - 0x29b0: 0x00c0, 0x29b1: 0x00c3, 0x29b2: 0x00c3, 0x29b3: 0x00c0, 0x29b4: 0x00c0, 0x29b5: 0x00c3, - 0x29b6: 0x00c3, - // Block 0xa7, offset 0x29c0 - 0x29c0: 0x00c0, 0x29c1: 0x00c0, 0x29c2: 0x00c0, 0x29c3: 0x00c3, 0x29c4: 0x00c0, 0x29c5: 0x00c0, - 0x29c6: 0x00c0, 0x29c7: 0x00c0, 0x29c8: 0x00c0, 0x29c9: 0x00c0, 0x29ca: 0x00c0, 0x29cb: 0x00c0, - 0x29cc: 0x00c3, 0x29cd: 0x00c0, 0x29d0: 0x00c0, 0x29d1: 0x00c0, - 0x29d2: 0x00c0, 0x29d3: 0x00c0, 0x29d4: 0x00c0, 0x29d5: 0x00c0, 0x29d6: 0x00c0, 0x29d7: 0x00c0, - 0x29d8: 0x00c0, 0x29d9: 0x00c0, 0x29dc: 0x0080, 0x29dd: 0x0080, - 0x29de: 0x0080, 0x29df: 0x0080, 0x29e0: 0x00c0, 0x29e1: 0x00c0, 0x29e2: 0x00c0, 0x29e3: 0x00c0, - 0x29e4: 0x00c0, 0x29e5: 0x00c0, 0x29e6: 0x00c0, 0x29e7: 0x00c0, 0x29e8: 0x00c0, 0x29e9: 0x00c0, - 0x29ea: 0x00c0, 0x29eb: 0x00c0, 0x29ec: 0x00c0, 0x29ed: 0x00c0, 0x29ee: 0x00c0, 0x29ef: 0x00c0, - 0x29f0: 0x00c0, 0x29f1: 0x00c0, 0x29f2: 0x00c0, 0x29f3: 0x00c0, 0x29f4: 0x00c0, 0x29f5: 0x00c0, - 0x29f6: 0x00c0, 0x29f7: 0x0080, 0x29f8: 0x0080, 0x29f9: 0x0080, 0x29fa: 0x00c0, 0x29fb: 0x00c0, - 0x29fc: 0x00c3, 0x29fd: 0x00c0, 0x29fe: 0x00c0, 0x29ff: 0x00c0, - // Block 0xa8, offset 0x2a00 - 0x2a00: 0x00c0, 0x2a01: 0x00c0, 0x2a02: 0x00c0, 0x2a03: 0x00c0, 0x2a04: 0x00c0, 0x2a05: 0x00c0, - 0x2a06: 0x00c0, 0x2a07: 0x00c0, 0x2a08: 0x00c0, 0x2a09: 0x00c0, 0x2a0a: 0x00c0, 0x2a0b: 0x00c0, - 0x2a0c: 0x00c0, 0x2a0d: 0x00c0, 0x2a0e: 0x00c0, 0x2a0f: 0x00c0, 0x2a10: 0x00c0, 0x2a11: 0x00c0, - 0x2a12: 0x00c0, 0x2a13: 0x00c0, 0x2a14: 0x00c0, 0x2a15: 0x00c0, 0x2a16: 0x00c0, 0x2a17: 0x00c0, - 0x2a18: 0x00c0, 0x2a19: 0x00c0, 0x2a1a: 0x00c0, 0x2a1b: 0x00c0, 0x2a1c: 0x00c0, 0x2a1d: 0x00c0, - 0x2a1e: 0x00c0, 0x2a1f: 0x00c0, 0x2a20: 0x00c0, 0x2a21: 0x00c0, 0x2a22: 0x00c0, 0x2a23: 0x00c0, - 0x2a24: 0x00c0, 0x2a25: 0x00c0, 0x2a26: 0x00c0, 0x2a27: 0x00c0, 0x2a28: 0x00c0, 0x2a29: 0x00c0, - 0x2a2a: 0x00c0, 0x2a2b: 0x00c0, 0x2a2c: 0x00c0, 0x2a2d: 0x00c0, 0x2a2e: 0x00c0, 0x2a2f: 0x00c0, - 0x2a30: 0x00c3, 0x2a31: 0x00c0, 0x2a32: 0x00c3, 0x2a33: 0x00c3, 0x2a34: 0x00c3, 0x2a35: 0x00c0, - 0x2a36: 0x00c0, 0x2a37: 0x00c3, 0x2a38: 0x00c3, 0x2a39: 0x00c0, 0x2a3a: 0x00c0, 0x2a3b: 0x00c0, - 0x2a3c: 0x00c0, 0x2a3d: 0x00c0, 0x2a3e: 0x00c3, 0x2a3f: 0x00c3, - // Block 0xa9, offset 0x2a40 - 0x2a40: 0x00c0, 0x2a41: 0x00c3, 0x2a42: 0x00c0, - 0x2a5b: 0x00c0, 0x2a5c: 0x00c0, 0x2a5d: 0x00c0, - 0x2a5e: 0x0080, 0x2a5f: 0x0080, 0x2a60: 0x00c0, 0x2a61: 0x00c0, 0x2a62: 0x00c0, 0x2a63: 0x00c0, - 0x2a64: 0x00c0, 0x2a65: 0x00c0, 0x2a66: 0x00c0, 0x2a67: 0x00c0, 0x2a68: 0x00c0, 0x2a69: 0x00c0, - 0x2a6a: 0x00c0, 0x2a6b: 0x00c0, 0x2a6c: 0x00c3, 0x2a6d: 0x00c3, 0x2a6e: 0x00c0, 0x2a6f: 0x00c0, - 0x2a70: 0x0080, 0x2a71: 0x0080, 0x2a72: 0x00c0, 0x2a73: 0x00c0, 0x2a74: 0x00c0, 0x2a75: 0x00c0, - 0x2a76: 0x00c6, - // Block 0xaa, offset 0x2a80 - 0x2a81: 0x00c0, 0x2a82: 0x00c0, 0x2a83: 0x00c0, 0x2a84: 0x00c0, 0x2a85: 0x00c0, - 0x2a86: 0x00c0, 0x2a89: 0x00c0, 0x2a8a: 0x00c0, 0x2a8b: 0x00c0, - 0x2a8c: 0x00c0, 0x2a8d: 0x00c0, 0x2a8e: 0x00c0, 0x2a91: 0x00c0, - 0x2a92: 0x00c0, 0x2a93: 0x00c0, 0x2a94: 0x00c0, 0x2a95: 0x00c0, 0x2a96: 0x00c0, - 0x2aa0: 0x00c0, 0x2aa1: 0x00c0, 0x2aa2: 0x00c0, 0x2aa3: 0x00c0, - 0x2aa4: 0x00c0, 0x2aa5: 0x00c0, 0x2aa6: 0x00c0, 0x2aa8: 0x00c0, 0x2aa9: 0x00c0, - 0x2aaa: 0x00c0, 0x2aab: 0x00c0, 0x2aac: 0x00c0, 0x2aad: 0x00c0, 0x2aae: 0x00c0, - 0x2ab0: 0x00c0, 0x2ab1: 0x00c0, 0x2ab2: 0x00c0, 0x2ab3: 0x00c0, 0x2ab4: 0x00c0, 0x2ab5: 0x00c0, - 0x2ab6: 0x00c0, 0x2ab7: 0x00c0, 0x2ab8: 0x00c0, 0x2ab9: 0x00c0, 0x2aba: 0x00c0, 0x2abb: 0x00c0, - 0x2abc: 0x00c0, 0x2abd: 0x00c0, 0x2abe: 0x00c0, 0x2abf: 0x00c0, - // Block 0xab, offset 0x2ac0 - 0x2ac0: 0x00c0, 0x2ac1: 0x00c0, 0x2ac2: 0x00c0, 0x2ac3: 0x00c0, 0x2ac4: 0x00c0, 0x2ac5: 0x00c0, - 0x2ac6: 0x00c0, 0x2ac7: 0x00c0, 0x2ac8: 0x00c0, 0x2ac9: 0x00c0, 0x2aca: 0x00c0, 0x2acb: 0x00c0, - 0x2acc: 0x00c0, 0x2acd: 0x00c0, 0x2ace: 0x00c0, 0x2acf: 0x00c0, 0x2ad0: 0x00c0, 0x2ad1: 0x00c0, - 0x2ad2: 0x00c0, 0x2ad3: 0x00c0, 0x2ad4: 0x00c0, 0x2ad5: 0x00c0, 0x2ad6: 0x00c0, 0x2ad7: 0x00c0, - 0x2ad8: 0x00c0, 0x2ad9: 0x00c0, 0x2ada: 0x00c0, 0x2adb: 0x0080, 0x2adc: 0x0080, 0x2add: 0x0080, - 0x2ade: 0x0080, 0x2adf: 0x0080, 0x2ae0: 0x00c0, 0x2ae1: 0x00c0, 0x2ae2: 0x00c0, 0x2ae3: 0x00c0, - 0x2ae4: 0x00c0, 0x2ae5: 0x00c8, - 0x2af0: 0x00c0, 0x2af1: 0x00c0, 0x2af2: 0x00c0, 0x2af3: 0x00c0, 0x2af4: 0x00c0, 0x2af5: 0x00c0, - 0x2af6: 0x00c0, 0x2af7: 0x00c0, 0x2af8: 0x00c0, 0x2af9: 0x00c0, 0x2afa: 0x00c0, 0x2afb: 0x00c0, - 0x2afc: 0x00c0, 0x2afd: 0x00c0, 0x2afe: 0x00c0, 0x2aff: 0x00c0, - // Block 0xac, offset 0x2b00 - 0x2b00: 0x00c0, 0x2b01: 0x00c0, 0x2b02: 0x00c0, 0x2b03: 0x00c0, 0x2b04: 0x00c0, 0x2b05: 0x00c0, - 0x2b06: 0x00c0, 0x2b07: 0x00c0, 0x2b08: 0x00c0, 0x2b09: 0x00c0, 0x2b0a: 0x00c0, 0x2b0b: 0x00c0, - 0x2b0c: 0x00c0, 0x2b0d: 0x00c0, 0x2b0e: 0x00c0, 0x2b0f: 0x00c0, 0x2b10: 0x00c0, 0x2b11: 0x00c0, - 0x2b12: 0x00c0, 0x2b13: 0x00c0, 0x2b14: 0x00c0, 0x2b15: 0x00c0, 0x2b16: 0x00c0, 0x2b17: 0x00c0, - 0x2b18: 0x00c0, 0x2b19: 0x00c0, 0x2b1a: 0x00c0, 0x2b1b: 0x00c0, 0x2b1c: 0x00c0, 0x2b1d: 0x00c0, - 0x2b1e: 0x00c0, 0x2b1f: 0x00c0, 0x2b20: 0x00c0, 0x2b21: 0x00c0, 0x2b22: 0x00c0, 0x2b23: 0x00c0, - 0x2b24: 0x00c0, 0x2b25: 0x00c3, 0x2b26: 0x00c0, 0x2b27: 0x00c0, 0x2b28: 0x00c3, 0x2b29: 0x00c0, - 0x2b2a: 0x00c0, 0x2b2b: 0x0080, 0x2b2c: 0x00c0, 0x2b2d: 0x00c6, - 0x2b30: 0x00c0, 0x2b31: 0x00c0, 0x2b32: 0x00c0, 0x2b33: 0x00c0, 0x2b34: 0x00c0, 0x2b35: 0x00c0, - 0x2b36: 0x00c0, 0x2b37: 0x00c0, 0x2b38: 0x00c0, 0x2b39: 0x00c0, - // Block 0xad, offset 0x2b40 - 0x2b40: 0x00c0, 0x2b41: 0x00c0, 0x2b42: 0x00c0, 0x2b43: 0x00c0, 0x2b44: 0x00c0, 0x2b45: 0x00c0, - 0x2b46: 0x00c0, 0x2b47: 0x00c0, 0x2b48: 0x00c0, 0x2b49: 0x00c0, 0x2b4a: 0x00c0, 0x2b4b: 0x00c0, - 0x2b4c: 0x00c0, 0x2b4d: 0x00c0, 0x2b4e: 0x00c0, 0x2b4f: 0x00c0, 0x2b50: 0x00c0, 0x2b51: 0x00c0, - 0x2b52: 0x00c0, 0x2b53: 0x00c0, 0x2b54: 0x00c0, 0x2b55: 0x00c0, 0x2b56: 0x00c0, 0x2b57: 0x00c0, - 0x2b58: 0x00c0, 0x2b59: 0x00c0, 0x2b5a: 0x00c0, 0x2b5b: 0x00c0, 0x2b5c: 0x00c0, 0x2b5d: 0x00c0, - 0x2b5e: 0x00c0, 0x2b5f: 0x00c0, 0x2b60: 0x00c0, 0x2b61: 0x00c0, 0x2b62: 0x00c0, 0x2b63: 0x00c0, - 0x2b70: 0x0040, 0x2b71: 0x0040, 0x2b72: 0x0040, 0x2b73: 0x0040, 0x2b74: 0x0040, 0x2b75: 0x0040, - 0x2b76: 0x0040, 0x2b77: 0x0040, 0x2b78: 0x0040, 0x2b79: 0x0040, 0x2b7a: 0x0040, 0x2b7b: 0x0040, - 0x2b7c: 0x0040, 0x2b7d: 0x0040, 0x2b7e: 0x0040, 0x2b7f: 0x0040, - // Block 0xae, offset 0x2b80 - 0x2b80: 0x0040, 0x2b81: 0x0040, 0x2b82: 0x0040, 0x2b83: 0x0040, 0x2b84: 0x0040, 0x2b85: 0x0040, - 0x2b86: 0x0040, 0x2b8b: 0x0040, - 0x2b8c: 0x0040, 0x2b8d: 0x0040, 0x2b8e: 0x0040, 0x2b8f: 0x0040, 0x2b90: 0x0040, 0x2b91: 0x0040, - 0x2b92: 0x0040, 0x2b93: 0x0040, 0x2b94: 0x0040, 0x2b95: 0x0040, 0x2b96: 0x0040, 0x2b97: 0x0040, - 0x2b98: 0x0040, 0x2b99: 0x0040, 0x2b9a: 0x0040, 0x2b9b: 0x0040, 0x2b9c: 0x0040, 0x2b9d: 0x0040, - 0x2b9e: 0x0040, 0x2b9f: 0x0040, 0x2ba0: 0x0040, 0x2ba1: 0x0040, 0x2ba2: 0x0040, 0x2ba3: 0x0040, - 0x2ba4: 0x0040, 0x2ba5: 0x0040, 0x2ba6: 0x0040, 0x2ba7: 0x0040, 0x2ba8: 0x0040, 0x2ba9: 0x0040, - 0x2baa: 0x0040, 0x2bab: 0x0040, 0x2bac: 0x0040, 0x2bad: 0x0040, 0x2bae: 0x0040, 0x2baf: 0x0040, - 0x2bb0: 0x0040, 0x2bb1: 0x0040, 0x2bb2: 0x0040, 0x2bb3: 0x0040, 0x2bb4: 0x0040, 0x2bb5: 0x0040, - 0x2bb6: 0x0040, 0x2bb7: 0x0040, 0x2bb8: 0x0040, 0x2bb9: 0x0040, 0x2bba: 0x0040, 0x2bbb: 0x0040, - // Block 0xaf, offset 0x2bc0 - 0x2bc0: 0x008c, 0x2bc1: 0x008c, 0x2bc2: 0x008c, 0x2bc3: 0x008c, 0x2bc4: 0x008c, 0x2bc5: 0x008c, - 0x2bc6: 0x008c, 0x2bc7: 0x008c, 0x2bc8: 0x008c, 0x2bc9: 0x008c, 0x2bca: 0x008c, 0x2bcb: 0x008c, - 0x2bcc: 0x008c, 0x2bcd: 0x008c, 0x2bce: 0x00cc, 0x2bcf: 0x00cc, 0x2bd0: 0x008c, 0x2bd1: 0x00cc, - 0x2bd2: 0x008c, 0x2bd3: 0x00cc, 0x2bd4: 0x00cc, 0x2bd5: 0x008c, 0x2bd6: 0x008c, 0x2bd7: 0x008c, - 0x2bd8: 0x008c, 0x2bd9: 0x008c, 0x2bda: 0x008c, 0x2bdb: 0x008c, 0x2bdc: 0x008c, 0x2bdd: 0x008c, - 0x2bde: 0x008c, 0x2bdf: 0x00cc, 0x2be0: 0x008c, 0x2be1: 0x00cc, 0x2be2: 0x008c, 0x2be3: 0x00cc, - 0x2be4: 0x00cc, 0x2be5: 0x008c, 0x2be6: 0x008c, 0x2be7: 0x00cc, 0x2be8: 0x00cc, 0x2be9: 0x00cc, - 0x2bea: 0x008c, 0x2beb: 0x008c, 0x2bec: 0x008c, 0x2bed: 0x008c, 0x2bee: 0x008c, 0x2bef: 0x008c, - 0x2bf0: 0x008c, 0x2bf1: 0x008c, 0x2bf2: 0x008c, 0x2bf3: 0x008c, 0x2bf4: 0x008c, 0x2bf5: 0x008c, - 0x2bf6: 0x008c, 0x2bf7: 0x008c, 0x2bf8: 0x008c, 0x2bf9: 0x008c, 0x2bfa: 0x008c, 0x2bfb: 0x008c, - 0x2bfc: 0x008c, 0x2bfd: 0x008c, 0x2bfe: 0x008c, 0x2bff: 0x008c, - // Block 0xb0, offset 0x2c00 - 0x2c00: 0x008c, 0x2c01: 0x008c, 0x2c02: 0x008c, 0x2c03: 0x008c, 0x2c04: 0x008c, 0x2c05: 0x008c, - 0x2c06: 0x008c, 0x2c07: 0x008c, 0x2c08: 0x008c, 0x2c09: 0x008c, 0x2c0a: 0x008c, 0x2c0b: 0x008c, - 0x2c0c: 0x008c, 0x2c0d: 0x008c, 0x2c0e: 0x008c, 0x2c0f: 0x008c, 0x2c10: 0x008c, 0x2c11: 0x008c, - 0x2c12: 0x008c, 0x2c13: 0x008c, 0x2c14: 0x008c, 0x2c15: 0x008c, 0x2c16: 0x008c, 0x2c17: 0x008c, - 0x2c18: 0x008c, 0x2c19: 0x008c, 0x2c1a: 0x008c, 0x2c1b: 0x008c, 0x2c1c: 0x008c, 0x2c1d: 0x008c, - 0x2c1e: 0x008c, 0x2c1f: 0x008c, 0x2c20: 0x008c, 0x2c21: 0x008c, 0x2c22: 0x008c, 0x2c23: 0x008c, - 0x2c24: 0x008c, 0x2c25: 0x008c, 0x2c26: 0x008c, 0x2c27: 0x008c, 0x2c28: 0x008c, 0x2c29: 0x008c, - 0x2c2a: 0x008c, 0x2c2b: 0x008c, 0x2c2c: 0x008c, 0x2c2d: 0x008c, - 0x2c30: 0x008c, 0x2c31: 0x008c, 0x2c32: 0x008c, 0x2c33: 0x008c, 0x2c34: 0x008c, 0x2c35: 0x008c, - 0x2c36: 0x008c, 0x2c37: 0x008c, 0x2c38: 0x008c, 0x2c39: 0x008c, 0x2c3a: 0x008c, 0x2c3b: 0x008c, - 0x2c3c: 0x008c, 0x2c3d: 0x008c, 0x2c3e: 0x008c, 0x2c3f: 0x008c, - // Block 0xb1, offset 0x2c40 - 0x2c40: 0x008c, 0x2c41: 0x008c, 0x2c42: 0x008c, 0x2c43: 0x008c, 0x2c44: 0x008c, 0x2c45: 0x008c, - 0x2c46: 0x008c, 0x2c47: 0x008c, 0x2c48: 0x008c, 0x2c49: 0x008c, 0x2c4a: 0x008c, 0x2c4b: 0x008c, - 0x2c4c: 0x008c, 0x2c4d: 0x008c, 0x2c4e: 0x008c, 0x2c4f: 0x008c, 0x2c50: 0x008c, 0x2c51: 0x008c, - 0x2c52: 0x008c, 0x2c53: 0x008c, 0x2c54: 0x008c, 0x2c55: 0x008c, 0x2c56: 0x008c, 0x2c57: 0x008c, - 0x2c58: 0x008c, 0x2c59: 0x008c, - // Block 0xb2, offset 0x2c80 - 0x2c80: 0x0080, 0x2c81: 0x0080, 0x2c82: 0x0080, 0x2c83: 0x0080, 0x2c84: 0x0080, 0x2c85: 0x0080, - 0x2c86: 0x0080, - 0x2c93: 0x0080, 0x2c94: 0x0080, 0x2c95: 0x0080, 0x2c96: 0x0080, 0x2c97: 0x0080, - 0x2c9d: 0x008a, - 0x2c9e: 0x00cb, 0x2c9f: 0x008a, 0x2ca0: 0x008a, 0x2ca1: 0x008a, 0x2ca2: 0x008a, 0x2ca3: 0x008a, - 0x2ca4: 0x008a, 0x2ca5: 0x008a, 0x2ca6: 0x008a, 0x2ca7: 0x008a, 0x2ca8: 0x008a, 0x2ca9: 0x008a, - 0x2caa: 0x008a, 0x2cab: 0x008a, 0x2cac: 0x008a, 0x2cad: 0x008a, 0x2cae: 0x008a, 0x2caf: 0x008a, - 0x2cb0: 0x008a, 0x2cb1: 0x008a, 0x2cb2: 0x008a, 0x2cb3: 0x008a, 0x2cb4: 0x008a, 0x2cb5: 0x008a, - 0x2cb6: 0x008a, 0x2cb8: 0x008a, 0x2cb9: 0x008a, 0x2cba: 0x008a, 0x2cbb: 0x008a, - 0x2cbc: 0x008a, 0x2cbe: 0x008a, - // Block 0xb3, offset 0x2cc0 - 0x2cc0: 0x008a, 0x2cc1: 0x008a, 0x2cc3: 0x008a, 0x2cc4: 0x008a, - 0x2cc6: 0x008a, 0x2cc7: 0x008a, 0x2cc8: 0x008a, 0x2cc9: 0x008a, 0x2cca: 0x008a, 0x2ccb: 0x008a, - 0x2ccc: 0x008a, 0x2ccd: 0x008a, 0x2cce: 0x008a, 0x2ccf: 0x008a, 0x2cd0: 0x0080, 0x2cd1: 0x0080, - 0x2cd2: 0x0080, 0x2cd3: 0x0080, 0x2cd4: 0x0080, 0x2cd5: 0x0080, 0x2cd6: 0x0080, 0x2cd7: 0x0080, - 0x2cd8: 0x0080, 0x2cd9: 0x0080, 0x2cda: 0x0080, 0x2cdb: 0x0080, 0x2cdc: 0x0080, 0x2cdd: 0x0080, - 0x2cde: 0x0080, 0x2cdf: 0x0080, 0x2ce0: 0x0080, 0x2ce1: 0x0080, 0x2ce2: 0x0080, 0x2ce3: 0x0080, - 0x2ce4: 0x0080, 0x2ce5: 0x0080, 0x2ce6: 0x0080, 0x2ce7: 0x0080, 0x2ce8: 0x0080, 0x2ce9: 0x0080, - 0x2cea: 0x0080, 0x2ceb: 0x0080, 0x2cec: 0x0080, 0x2ced: 0x0080, 0x2cee: 0x0080, 0x2cef: 0x0080, - 0x2cf0: 0x0080, 0x2cf1: 0x0080, 0x2cf2: 0x0080, 0x2cf3: 0x0080, 0x2cf4: 0x0080, 0x2cf5: 0x0080, - 0x2cf6: 0x0080, 0x2cf7: 0x0080, 0x2cf8: 0x0080, 0x2cf9: 0x0080, 0x2cfa: 0x0080, 0x2cfb: 0x0080, - 0x2cfc: 0x0080, 0x2cfd: 0x0080, 0x2cfe: 0x0080, 0x2cff: 0x0080, - // Block 0xb4, offset 0x2d00 - 0x2d00: 0x0080, 0x2d01: 0x0080, - 0x2d13: 0x0080, 0x2d14: 0x0080, 0x2d15: 0x0080, 0x2d16: 0x0080, 0x2d17: 0x0080, - 0x2d18: 0x0080, 0x2d19: 0x0080, 0x2d1a: 0x0080, 0x2d1b: 0x0080, 0x2d1c: 0x0080, 0x2d1d: 0x0080, - 0x2d1e: 0x0080, 0x2d1f: 0x0080, 0x2d20: 0x0080, 0x2d21: 0x0080, 0x2d22: 0x0080, 0x2d23: 0x0080, - 0x2d24: 0x0080, 0x2d25: 0x0080, 0x2d26: 0x0080, 0x2d27: 0x0080, 0x2d28: 0x0080, 0x2d29: 0x0080, - 0x2d2a: 0x0080, 0x2d2b: 0x0080, 0x2d2c: 0x0080, 0x2d2d: 0x0080, 0x2d2e: 0x0080, 0x2d2f: 0x0080, - 0x2d30: 0x0080, 0x2d31: 0x0080, 0x2d32: 0x0080, 0x2d33: 0x0080, 0x2d34: 0x0080, 0x2d35: 0x0080, - 0x2d36: 0x0080, 0x2d37: 0x0080, 0x2d38: 0x0080, 0x2d39: 0x0080, 0x2d3a: 0x0080, 0x2d3b: 0x0080, - 0x2d3c: 0x0080, 0x2d3d: 0x0080, 0x2d3e: 0x0080, 0x2d3f: 0x0080, - // Block 0xb5, offset 0x2d40 - 0x2d50: 0x0080, 0x2d51: 0x0080, - 0x2d52: 0x0080, 0x2d53: 0x0080, 0x2d54: 0x0080, 0x2d55: 0x0080, 0x2d56: 0x0080, 0x2d57: 0x0080, - 0x2d58: 0x0080, 0x2d59: 0x0080, 0x2d5a: 0x0080, 0x2d5b: 0x0080, 0x2d5c: 0x0080, 0x2d5d: 0x0080, - 0x2d5e: 0x0080, 0x2d5f: 0x0080, 0x2d60: 0x0080, 0x2d61: 0x0080, 0x2d62: 0x0080, 0x2d63: 0x0080, - 0x2d64: 0x0080, 0x2d65: 0x0080, 0x2d66: 0x0080, 0x2d67: 0x0080, 0x2d68: 0x0080, 0x2d69: 0x0080, - 0x2d6a: 0x0080, 0x2d6b: 0x0080, 0x2d6c: 0x0080, 0x2d6d: 0x0080, 0x2d6e: 0x0080, 0x2d6f: 0x0080, - 0x2d70: 0x0080, 0x2d71: 0x0080, 0x2d72: 0x0080, 0x2d73: 0x0080, 0x2d74: 0x0080, 0x2d75: 0x0080, - 0x2d76: 0x0080, 0x2d77: 0x0080, 0x2d78: 0x0080, 0x2d79: 0x0080, 0x2d7a: 0x0080, 0x2d7b: 0x0080, - 0x2d7c: 0x0080, 0x2d7d: 0x0080, 0x2d7e: 0x0080, 0x2d7f: 0x0080, - // Block 0xb6, offset 0x2d80 - 0x2d80: 0x0080, 0x2d81: 0x0080, 0x2d82: 0x0080, 0x2d83: 0x0080, 0x2d84: 0x0080, 0x2d85: 0x0080, - 0x2d86: 0x0080, 0x2d87: 0x0080, 0x2d88: 0x0080, 0x2d89: 0x0080, 0x2d8a: 0x0080, 0x2d8b: 0x0080, - 0x2d8c: 0x0080, 0x2d8d: 0x0080, 0x2d8e: 0x0080, 0x2d8f: 0x0080, - 0x2d92: 0x0080, 0x2d93: 0x0080, 0x2d94: 0x0080, 0x2d95: 0x0080, 0x2d96: 0x0080, 0x2d97: 0x0080, - 0x2d98: 0x0080, 0x2d99: 0x0080, 0x2d9a: 0x0080, 0x2d9b: 0x0080, 0x2d9c: 0x0080, 0x2d9d: 0x0080, - 0x2d9e: 0x0080, 0x2d9f: 0x0080, 0x2da0: 0x0080, 0x2da1: 0x0080, 0x2da2: 0x0080, 0x2da3: 0x0080, - 0x2da4: 0x0080, 0x2da5: 0x0080, 0x2da6: 0x0080, 0x2da7: 0x0080, 0x2da8: 0x0080, 0x2da9: 0x0080, - 0x2daa: 0x0080, 0x2dab: 0x0080, 0x2dac: 0x0080, 0x2dad: 0x0080, 0x2dae: 0x0080, 0x2daf: 0x0080, - 0x2db0: 0x0080, 0x2db1: 0x0080, 0x2db2: 0x0080, 0x2db3: 0x0080, 0x2db4: 0x0080, 0x2db5: 0x0080, - 0x2db6: 0x0080, 0x2db7: 0x0080, 0x2db8: 0x0080, 0x2db9: 0x0080, 0x2dba: 0x0080, 0x2dbb: 0x0080, - 0x2dbc: 0x0080, 0x2dbd: 0x0080, 0x2dbe: 0x0080, 0x2dbf: 0x0080, - // Block 0xb7, offset 0x2dc0 - 0x2dc0: 0x0080, 0x2dc1: 0x0080, 0x2dc2: 0x0080, 0x2dc3: 0x0080, 0x2dc4: 0x0080, 0x2dc5: 0x0080, - 0x2dc6: 0x0080, 0x2dc7: 0x0080, - 0x2df0: 0x0080, 0x2df1: 0x0080, 0x2df2: 0x0080, 0x2df3: 0x0080, 0x2df4: 0x0080, 0x2df5: 0x0080, - 0x2df6: 0x0080, 0x2df7: 0x0080, 0x2df8: 0x0080, 0x2df9: 0x0080, 0x2dfa: 0x0080, 0x2dfb: 0x0080, - 0x2dfc: 0x0080, 0x2dfd: 0x0080, - // Block 0xb8, offset 0x2e00 - 0x2e00: 0x0040, 0x2e01: 0x0040, 0x2e02: 0x0040, 0x2e03: 0x0040, 0x2e04: 0x0040, 0x2e05: 0x0040, - 0x2e06: 0x0040, 0x2e07: 0x0040, 0x2e08: 0x0040, 0x2e09: 0x0040, 0x2e0a: 0x0040, 0x2e0b: 0x0040, - 0x2e0c: 0x0040, 0x2e0d: 0x0040, 0x2e0e: 0x0040, 0x2e0f: 0x0040, 0x2e10: 0x0080, 0x2e11: 0x0080, - 0x2e12: 0x0080, 0x2e13: 0x0080, 0x2e14: 0x0080, 0x2e15: 0x0080, 0x2e16: 0x0080, 0x2e17: 0x0080, - 0x2e18: 0x0080, 0x2e19: 0x0080, - 0x2e20: 0x00c3, 0x2e21: 0x00c3, 0x2e22: 0x00c3, 0x2e23: 0x00c3, - 0x2e24: 0x00c3, 0x2e25: 0x00c3, 0x2e26: 0x00c3, 0x2e27: 0x00c3, 0x2e28: 0x00c3, 0x2e29: 0x00c3, - 0x2e2a: 0x00c3, 0x2e2b: 0x00c3, 0x2e2c: 0x00c3, 0x2e2d: 0x00c3, 0x2e2e: 0x00c3, 0x2e2f: 0x00c3, - 0x2e30: 0x0080, 0x2e31: 0x0080, 0x2e32: 0x0080, 0x2e33: 0x0080, 0x2e34: 0x0080, 0x2e35: 0x0080, - 0x2e36: 0x0080, 0x2e37: 0x0080, 0x2e38: 0x0080, 0x2e39: 0x0080, 0x2e3a: 0x0080, 0x2e3b: 0x0080, - 0x2e3c: 0x0080, 0x2e3d: 0x0080, 0x2e3e: 0x0080, 0x2e3f: 0x0080, - // Block 0xb9, offset 0x2e40 - 0x2e40: 0x0080, 0x2e41: 0x0080, 0x2e42: 0x0080, 0x2e43: 0x0080, 0x2e44: 0x0080, 0x2e45: 0x0080, - 0x2e46: 0x0080, 0x2e47: 0x0080, 0x2e48: 0x0080, 0x2e49: 0x0080, 0x2e4a: 0x0080, 0x2e4b: 0x0080, - 0x2e4c: 0x0080, 0x2e4d: 0x0080, 0x2e4e: 0x0080, 0x2e4f: 0x0080, 0x2e50: 0x0080, 0x2e51: 0x0080, - 0x2e52: 0x0080, 0x2e54: 0x0080, 0x2e55: 0x0080, 0x2e56: 0x0080, 0x2e57: 0x0080, - 0x2e58: 0x0080, 0x2e59: 0x0080, 0x2e5a: 0x0080, 0x2e5b: 0x0080, 0x2e5c: 0x0080, 0x2e5d: 0x0080, - 0x2e5e: 0x0080, 0x2e5f: 0x0080, 0x2e60: 0x0080, 0x2e61: 0x0080, 0x2e62: 0x0080, 0x2e63: 0x0080, - 0x2e64: 0x0080, 0x2e65: 0x0080, 0x2e66: 0x0080, 0x2e68: 0x0080, 0x2e69: 0x0080, - 0x2e6a: 0x0080, 0x2e6b: 0x0080, - 0x2e70: 0x0080, 0x2e71: 0x0080, 0x2e72: 0x0080, 0x2e73: 0x00c0, 0x2e74: 0x0080, - 0x2e76: 0x0080, 0x2e77: 0x0080, 0x2e78: 0x0080, 0x2e79: 0x0080, 0x2e7a: 0x0080, 0x2e7b: 0x0080, - 0x2e7c: 0x0080, 0x2e7d: 0x0080, 0x2e7e: 0x0080, 0x2e7f: 0x0080, - // Block 0xba, offset 0x2e80 - 0x2e80: 0x0080, 0x2e81: 0x0080, 0x2e82: 0x0080, 0x2e83: 0x0080, 0x2e84: 0x0080, 0x2e85: 0x0080, - 0x2e86: 0x0080, 0x2e87: 0x0080, 0x2e88: 0x0080, 0x2e89: 0x0080, 0x2e8a: 0x0080, 0x2e8b: 0x0080, - 0x2e8c: 0x0080, 0x2e8d: 0x0080, 0x2e8e: 0x0080, 0x2e8f: 0x0080, 0x2e90: 0x0080, 0x2e91: 0x0080, - 0x2e92: 0x0080, 0x2e93: 0x0080, 0x2e94: 0x0080, 0x2e95: 0x0080, 0x2e96: 0x0080, 0x2e97: 0x0080, - 0x2e98: 0x0080, 0x2e99: 0x0080, 0x2e9a: 0x0080, 0x2e9b: 0x0080, 0x2e9c: 0x0080, 0x2e9d: 0x0080, - 0x2e9e: 0x0080, 0x2e9f: 0x0080, 0x2ea0: 0x0080, 0x2ea1: 0x0080, 0x2ea2: 0x0080, 0x2ea3: 0x0080, - 0x2ea4: 0x0080, 0x2ea5: 0x0080, 0x2ea6: 0x0080, 0x2ea7: 0x0080, 0x2ea8: 0x0080, 0x2ea9: 0x0080, - 0x2eaa: 0x0080, 0x2eab: 0x0080, 0x2eac: 0x0080, 0x2ead: 0x0080, 0x2eae: 0x0080, 0x2eaf: 0x0080, - 0x2eb0: 0x0080, 0x2eb1: 0x0080, 0x2eb2: 0x0080, 0x2eb3: 0x0080, 0x2eb4: 0x0080, 0x2eb5: 0x0080, - 0x2eb6: 0x0080, 0x2eb7: 0x0080, 0x2eb8: 0x0080, 0x2eb9: 0x0080, 0x2eba: 0x0080, 0x2ebb: 0x0080, - 0x2ebc: 0x0080, 0x2ebf: 0x0040, - // Block 0xbb, offset 0x2ec0 - 0x2ec1: 0x0080, 0x2ec2: 0x0080, 0x2ec3: 0x0080, 0x2ec4: 0x0080, 0x2ec5: 0x0080, - 0x2ec6: 0x0080, 0x2ec7: 0x0080, 0x2ec8: 0x0080, 0x2ec9: 0x0080, 0x2eca: 0x0080, 0x2ecb: 0x0080, - 0x2ecc: 0x0080, 0x2ecd: 0x0080, 0x2ece: 0x0080, 0x2ecf: 0x0080, 0x2ed0: 0x0080, 0x2ed1: 0x0080, - 0x2ed2: 0x0080, 0x2ed3: 0x0080, 0x2ed4: 0x0080, 0x2ed5: 0x0080, 0x2ed6: 0x0080, 0x2ed7: 0x0080, - 0x2ed8: 0x0080, 0x2ed9: 0x0080, 0x2eda: 0x0080, 0x2edb: 0x0080, 0x2edc: 0x0080, 0x2edd: 0x0080, - 0x2ede: 0x0080, 0x2edf: 0x0080, 0x2ee0: 0x0080, 0x2ee1: 0x0080, 0x2ee2: 0x0080, 0x2ee3: 0x0080, - 0x2ee4: 0x0080, 0x2ee5: 0x0080, 0x2ee6: 0x0080, 0x2ee7: 0x0080, 0x2ee8: 0x0080, 0x2ee9: 0x0080, - 0x2eea: 0x0080, 0x2eeb: 0x0080, 0x2eec: 0x0080, 0x2eed: 0x0080, 0x2eee: 0x0080, 0x2eef: 0x0080, - 0x2ef0: 0x0080, 0x2ef1: 0x0080, 0x2ef2: 0x0080, 0x2ef3: 0x0080, 0x2ef4: 0x0080, 0x2ef5: 0x0080, - 0x2ef6: 0x0080, 0x2ef7: 0x0080, 0x2ef8: 0x0080, 0x2ef9: 0x0080, 0x2efa: 0x0080, 0x2efb: 0x0080, - 0x2efc: 0x0080, 0x2efd: 0x0080, 0x2efe: 0x0080, 0x2eff: 0x0080, - // Block 0xbc, offset 0x2f00 - 0x2f00: 0x0080, 0x2f01: 0x0080, 0x2f02: 0x0080, 0x2f03: 0x0080, 0x2f04: 0x0080, 0x2f05: 0x0080, - 0x2f06: 0x0080, 0x2f07: 0x0080, 0x2f08: 0x0080, 0x2f09: 0x0080, 0x2f0a: 0x0080, 0x2f0b: 0x0080, - 0x2f0c: 0x0080, 0x2f0d: 0x0080, 0x2f0e: 0x0080, 0x2f0f: 0x0080, 0x2f10: 0x0080, 0x2f11: 0x0080, - 0x2f12: 0x0080, 0x2f13: 0x0080, 0x2f14: 0x0080, 0x2f15: 0x0080, 0x2f16: 0x0080, 0x2f17: 0x0080, - 0x2f18: 0x0080, 0x2f19: 0x0080, 0x2f1a: 0x0080, 0x2f1b: 0x0080, 0x2f1c: 0x0080, 0x2f1d: 0x0080, - 0x2f1e: 0x0080, 0x2f1f: 0x0080, 0x2f20: 0x0080, 0x2f21: 0x0080, 0x2f22: 0x0080, 0x2f23: 0x0080, - 0x2f24: 0x0080, 0x2f25: 0x0080, 0x2f26: 0x008c, 0x2f27: 0x008c, 0x2f28: 0x008c, 0x2f29: 0x008c, - 0x2f2a: 0x008c, 0x2f2b: 0x008c, 0x2f2c: 0x008c, 0x2f2d: 0x008c, 0x2f2e: 0x008c, 0x2f2f: 0x008c, - 0x2f30: 0x0080, 0x2f31: 0x008c, 0x2f32: 0x008c, 0x2f33: 0x008c, 0x2f34: 0x008c, 0x2f35: 0x008c, - 0x2f36: 0x008c, 0x2f37: 0x008c, 0x2f38: 0x008c, 0x2f39: 0x008c, 0x2f3a: 0x008c, 0x2f3b: 0x008c, - 0x2f3c: 0x008c, 0x2f3d: 0x008c, 0x2f3e: 0x008c, 0x2f3f: 0x008c, - // Block 0xbd, offset 0x2f40 - 0x2f40: 0x008c, 0x2f41: 0x008c, 0x2f42: 0x008c, 0x2f43: 0x008c, 0x2f44: 0x008c, 0x2f45: 0x008c, - 0x2f46: 0x008c, 0x2f47: 0x008c, 0x2f48: 0x008c, 0x2f49: 0x008c, 0x2f4a: 0x008c, 0x2f4b: 0x008c, - 0x2f4c: 0x008c, 0x2f4d: 0x008c, 0x2f4e: 0x008c, 0x2f4f: 0x008c, 0x2f50: 0x008c, 0x2f51: 0x008c, - 0x2f52: 0x008c, 0x2f53: 0x008c, 0x2f54: 0x008c, 0x2f55: 0x008c, 0x2f56: 0x008c, 0x2f57: 0x008c, - 0x2f58: 0x008c, 0x2f59: 0x008c, 0x2f5a: 0x008c, 0x2f5b: 0x008c, 0x2f5c: 0x008c, 0x2f5d: 0x008c, - 0x2f5e: 0x0080, 0x2f5f: 0x0080, 0x2f60: 0x0040, 0x2f61: 0x0080, 0x2f62: 0x0080, 0x2f63: 0x0080, - 0x2f64: 0x0080, 0x2f65: 0x0080, 0x2f66: 0x0080, 0x2f67: 0x0080, 0x2f68: 0x0080, 0x2f69: 0x0080, - 0x2f6a: 0x0080, 0x2f6b: 0x0080, 0x2f6c: 0x0080, 0x2f6d: 0x0080, 0x2f6e: 0x0080, 0x2f6f: 0x0080, - 0x2f70: 0x0080, 0x2f71: 0x0080, 0x2f72: 0x0080, 0x2f73: 0x0080, 0x2f74: 0x0080, 0x2f75: 0x0080, - 0x2f76: 0x0080, 0x2f77: 0x0080, 0x2f78: 0x0080, 0x2f79: 0x0080, 0x2f7a: 0x0080, 0x2f7b: 0x0080, - 0x2f7c: 0x0080, 0x2f7d: 0x0080, 0x2f7e: 0x0080, - // Block 0xbe, offset 0x2f80 - 0x2f82: 0x0080, 0x2f83: 0x0080, 0x2f84: 0x0080, 0x2f85: 0x0080, - 0x2f86: 0x0080, 0x2f87: 0x0080, 0x2f8a: 0x0080, 0x2f8b: 0x0080, - 0x2f8c: 0x0080, 0x2f8d: 0x0080, 0x2f8e: 0x0080, 0x2f8f: 0x0080, - 0x2f92: 0x0080, 0x2f93: 0x0080, 0x2f94: 0x0080, 0x2f95: 0x0080, 0x2f96: 0x0080, 0x2f97: 0x0080, - 0x2f9a: 0x0080, 0x2f9b: 0x0080, 0x2f9c: 0x0080, - 0x2fa0: 0x0080, 0x2fa1: 0x0080, 0x2fa2: 0x0080, 0x2fa3: 0x0080, - 0x2fa4: 0x0080, 0x2fa5: 0x0080, 0x2fa6: 0x0080, 0x2fa8: 0x0080, 0x2fa9: 0x0080, - 0x2faa: 0x0080, 0x2fab: 0x0080, 0x2fac: 0x0080, 0x2fad: 0x0080, 0x2fae: 0x0080, - 0x2fb9: 0x0040, 0x2fba: 0x0040, 0x2fbb: 0x0040, - 0x2fbc: 0x0080, 0x2fbd: 0x0080, - // Block 0xbf, offset 0x2fc0 - 0x2fc0: 0x00c0, 0x2fc1: 0x00c0, 0x2fc2: 0x00c0, 0x2fc3: 0x00c0, 0x2fc4: 0x00c0, 0x2fc5: 0x00c0, - 0x2fc6: 0x00c0, 0x2fc7: 0x00c0, 0x2fc8: 0x00c0, 0x2fc9: 0x00c0, 0x2fca: 0x00c0, 0x2fcb: 0x00c0, - 0x2fcd: 0x00c0, 0x2fce: 0x00c0, 0x2fcf: 0x00c0, 0x2fd0: 0x00c0, 0x2fd1: 0x00c0, - 0x2fd2: 0x00c0, 0x2fd3: 0x00c0, 0x2fd4: 0x00c0, 0x2fd5: 0x00c0, 0x2fd6: 0x00c0, 0x2fd7: 0x00c0, - 0x2fd8: 0x00c0, 0x2fd9: 0x00c0, 0x2fda: 0x00c0, 0x2fdb: 0x00c0, 0x2fdc: 0x00c0, 0x2fdd: 0x00c0, - 0x2fde: 0x00c0, 0x2fdf: 0x00c0, 0x2fe0: 0x00c0, 0x2fe1: 0x00c0, 0x2fe2: 0x00c0, 0x2fe3: 0x00c0, - 0x2fe4: 0x00c0, 0x2fe5: 0x00c0, 0x2fe6: 0x00c0, 0x2fe8: 0x00c0, 0x2fe9: 0x00c0, - 0x2fea: 0x00c0, 0x2feb: 0x00c0, 0x2fec: 0x00c0, 0x2fed: 0x00c0, 0x2fee: 0x00c0, 0x2fef: 0x00c0, - 0x2ff0: 0x00c0, 0x2ff1: 0x00c0, 0x2ff2: 0x00c0, 0x2ff3: 0x00c0, 0x2ff4: 0x00c0, 0x2ff5: 0x00c0, - 0x2ff6: 0x00c0, 0x2ff7: 0x00c0, 0x2ff8: 0x00c0, 0x2ff9: 0x00c0, 0x2ffa: 0x00c0, - 0x2ffc: 0x00c0, 0x2ffd: 0x00c0, 0x2fff: 0x00c0, - // Block 0xc0, offset 0x3000 - 0x3000: 0x00c0, 0x3001: 0x00c0, 0x3002: 0x00c0, 0x3003: 0x00c0, 0x3004: 0x00c0, 0x3005: 0x00c0, - 0x3006: 0x00c0, 0x3007: 0x00c0, 0x3008: 0x00c0, 0x3009: 0x00c0, 0x300a: 0x00c0, 0x300b: 0x00c0, - 0x300c: 0x00c0, 0x300d: 0x00c0, 0x3010: 0x00c0, 0x3011: 0x00c0, - 0x3012: 0x00c0, 0x3013: 0x00c0, 0x3014: 0x00c0, 0x3015: 0x00c0, 0x3016: 0x00c0, 0x3017: 0x00c0, - 0x3018: 0x00c0, 0x3019: 0x00c0, 0x301a: 0x00c0, 0x301b: 0x00c0, 0x301c: 0x00c0, 0x301d: 0x00c0, - // Block 0xc1, offset 0x3040 - 0x3040: 0x00c0, 0x3041: 0x00c0, 0x3042: 0x00c0, 0x3043: 0x00c0, 0x3044: 0x00c0, 0x3045: 0x00c0, - 0x3046: 0x00c0, 0x3047: 0x00c0, 0x3048: 0x00c0, 0x3049: 0x00c0, 0x304a: 0x00c0, 0x304b: 0x00c0, - 0x304c: 0x00c0, 0x304d: 0x00c0, 0x304e: 0x00c0, 0x304f: 0x00c0, 0x3050: 0x00c0, 0x3051: 0x00c0, - 0x3052: 0x00c0, 0x3053: 0x00c0, 0x3054: 0x00c0, 0x3055: 0x00c0, 0x3056: 0x00c0, 0x3057: 0x00c0, - 0x3058: 0x00c0, 0x3059: 0x00c0, 0x305a: 0x00c0, 0x305b: 0x00c0, 0x305c: 0x00c0, 0x305d: 0x00c0, - 0x305e: 0x00c0, 0x305f: 0x00c0, 0x3060: 0x00c0, 0x3061: 0x00c0, 0x3062: 0x00c0, 0x3063: 0x00c0, - 0x3064: 0x00c0, 0x3065: 0x00c0, 0x3066: 0x00c0, 0x3067: 0x00c0, 0x3068: 0x00c0, 0x3069: 0x00c0, - 0x306a: 0x00c0, 0x306b: 0x00c0, 0x306c: 0x00c0, 0x306d: 0x00c0, 0x306e: 0x00c0, 0x306f: 0x00c0, - 0x3070: 0x00c0, 0x3071: 0x00c0, 0x3072: 0x00c0, 0x3073: 0x00c0, 0x3074: 0x00c0, 0x3075: 0x00c0, - 0x3076: 0x00c0, 0x3077: 0x00c0, 0x3078: 0x00c0, 0x3079: 0x00c0, 0x307a: 0x00c0, - // Block 0xc2, offset 0x3080 - 0x3080: 0x0080, 0x3081: 0x0080, 0x3082: 0x0080, - 0x3087: 0x0080, 0x3088: 0x0080, 0x3089: 0x0080, 0x308a: 0x0080, 0x308b: 0x0080, - 0x308c: 0x0080, 0x308d: 0x0080, 0x308e: 0x0080, 0x308f: 0x0080, 0x3090: 0x0080, 0x3091: 0x0080, - 0x3092: 0x0080, 0x3093: 0x0080, 0x3094: 0x0080, 0x3095: 0x0080, 0x3096: 0x0080, 0x3097: 0x0080, - 0x3098: 0x0080, 0x3099: 0x0080, 0x309a: 0x0080, 0x309b: 0x0080, 0x309c: 0x0080, 0x309d: 0x0080, - 0x309e: 0x0080, 0x309f: 0x0080, 0x30a0: 0x0080, 0x30a1: 0x0080, 0x30a2: 0x0080, 0x30a3: 0x0080, - 0x30a4: 0x0080, 0x30a5: 0x0080, 0x30a6: 0x0080, 0x30a7: 0x0080, 0x30a8: 0x0080, 0x30a9: 0x0080, - 0x30aa: 0x0080, 0x30ab: 0x0080, 0x30ac: 0x0080, 0x30ad: 0x0080, 0x30ae: 0x0080, 0x30af: 0x0080, - 0x30b0: 0x0080, 0x30b1: 0x0080, 0x30b2: 0x0080, 0x30b3: 0x0080, - 0x30b7: 0x0080, 0x30b8: 0x0080, 0x30b9: 0x0080, 0x30ba: 0x0080, 0x30bb: 0x0080, - 0x30bc: 0x0080, 0x30bd: 0x0080, 0x30be: 0x0080, 0x30bf: 0x0080, - // Block 0xc3, offset 0x30c0 - 0x30c0: 0x0088, 0x30c1: 0x0088, 0x30c2: 0x0088, 0x30c3: 0x0088, 0x30c4: 0x0088, 0x30c5: 0x0088, - 0x30c6: 0x0088, 0x30c7: 0x0088, 0x30c8: 0x0088, 0x30c9: 0x0088, 0x30ca: 0x0088, 0x30cb: 0x0088, - 0x30cc: 0x0088, 0x30cd: 0x0088, 0x30ce: 0x0088, 0x30cf: 0x0088, 0x30d0: 0x0088, 0x30d1: 0x0088, - 0x30d2: 0x0088, 0x30d3: 0x0088, 0x30d4: 0x0088, 0x30d5: 0x0088, 0x30d6: 0x0088, 0x30d7: 0x0088, - 0x30d8: 0x0088, 0x30d9: 0x0088, 0x30da: 0x0088, 0x30db: 0x0088, 0x30dc: 0x0088, 0x30dd: 0x0088, - 0x30de: 0x0088, 0x30df: 0x0088, 0x30e0: 0x0088, 0x30e1: 0x0088, 0x30e2: 0x0088, 0x30e3: 0x0088, - 0x30e4: 0x0088, 0x30e5: 0x0088, 0x30e6: 0x0088, 0x30e7: 0x0088, 0x30e8: 0x0088, 0x30e9: 0x0088, - 0x30ea: 0x0088, 0x30eb: 0x0088, 0x30ec: 0x0088, 0x30ed: 0x0088, 0x30ee: 0x0088, 0x30ef: 0x0088, - 0x30f0: 0x0088, 0x30f1: 0x0088, 0x30f2: 0x0088, 0x30f3: 0x0088, 0x30f4: 0x0088, 0x30f5: 0x0088, - 0x30f6: 0x0088, 0x30f7: 0x0088, 0x30f8: 0x0088, 0x30f9: 0x0088, 0x30fa: 0x0088, 0x30fb: 0x0088, - 0x30fc: 0x0088, 0x30fd: 0x0088, 0x30fe: 0x0088, 0x30ff: 0x0088, - // Block 0xc4, offset 0x3100 - 0x3100: 0x0088, 0x3101: 0x0088, 0x3102: 0x0088, 0x3103: 0x0088, 0x3104: 0x0088, 0x3105: 0x0088, - 0x3106: 0x0088, 0x3107: 0x0088, 0x3108: 0x0088, 0x3109: 0x0088, 0x310a: 0x0088, 0x310b: 0x0088, - 0x310c: 0x0088, 0x310d: 0x0088, 0x310e: 0x0088, 0x3110: 0x0080, 0x3111: 0x0080, - 0x3112: 0x0080, 0x3113: 0x0080, 0x3114: 0x0080, 0x3115: 0x0080, 0x3116: 0x0080, 0x3117: 0x0080, - 0x3118: 0x0080, 0x3119: 0x0080, 0x311a: 0x0080, 0x311b: 0x0080, - 0x3120: 0x0088, - // Block 0xc5, offset 0x3140 - 0x3150: 0x0080, 0x3151: 0x0080, - 0x3152: 0x0080, 0x3153: 0x0080, 0x3154: 0x0080, 0x3155: 0x0080, 0x3156: 0x0080, 0x3157: 0x0080, - 0x3158: 0x0080, 0x3159: 0x0080, 0x315a: 0x0080, 0x315b: 0x0080, 0x315c: 0x0080, 0x315d: 0x0080, - 0x315e: 0x0080, 0x315f: 0x0080, 0x3160: 0x0080, 0x3161: 0x0080, 0x3162: 0x0080, 0x3163: 0x0080, - 0x3164: 0x0080, 0x3165: 0x0080, 0x3166: 0x0080, 0x3167: 0x0080, 0x3168: 0x0080, 0x3169: 0x0080, - 0x316a: 0x0080, 0x316b: 0x0080, 0x316c: 0x0080, 0x316d: 0x0080, 0x316e: 0x0080, 0x316f: 0x0080, - 0x3170: 0x0080, 0x3171: 0x0080, 0x3172: 0x0080, 0x3173: 0x0080, 0x3174: 0x0080, 0x3175: 0x0080, - 0x3176: 0x0080, 0x3177: 0x0080, 0x3178: 0x0080, 0x3179: 0x0080, 0x317a: 0x0080, 0x317b: 0x0080, - 0x317c: 0x0080, 0x317d: 0x00c3, - // Block 0xc6, offset 0x3180 - 0x3180: 0x00c0, 0x3181: 0x00c0, 0x3182: 0x00c0, 0x3183: 0x00c0, 0x3184: 0x00c0, 0x3185: 0x00c0, - 0x3186: 0x00c0, 0x3187: 0x00c0, 0x3188: 0x00c0, 0x3189: 0x00c0, 0x318a: 0x00c0, 0x318b: 0x00c0, - 0x318c: 0x00c0, 0x318d: 0x00c0, 0x318e: 0x00c0, 0x318f: 0x00c0, 0x3190: 0x00c0, 0x3191: 0x00c0, - 0x3192: 0x00c0, 0x3193: 0x00c0, 0x3194: 0x00c0, 0x3195: 0x00c0, 0x3196: 0x00c0, 0x3197: 0x00c0, - 0x3198: 0x00c0, 0x3199: 0x00c0, 0x319a: 0x00c0, 0x319b: 0x00c0, 0x319c: 0x00c0, - 0x31a0: 0x00c0, 0x31a1: 0x00c0, 0x31a2: 0x00c0, 0x31a3: 0x00c0, - 0x31a4: 0x00c0, 0x31a5: 0x00c0, 0x31a6: 0x00c0, 0x31a7: 0x00c0, 0x31a8: 0x00c0, 0x31a9: 0x00c0, - 0x31aa: 0x00c0, 0x31ab: 0x00c0, 0x31ac: 0x00c0, 0x31ad: 0x00c0, 0x31ae: 0x00c0, 0x31af: 0x00c0, - 0x31b0: 0x00c0, 0x31b1: 0x00c0, 0x31b2: 0x00c0, 0x31b3: 0x00c0, 0x31b4: 0x00c0, 0x31b5: 0x00c0, - 0x31b6: 0x00c0, 0x31b7: 0x00c0, 0x31b8: 0x00c0, 0x31b9: 0x00c0, 0x31ba: 0x00c0, 0x31bb: 0x00c0, - 0x31bc: 0x00c0, 0x31bd: 0x00c0, 0x31be: 0x00c0, 0x31bf: 0x00c0, - // Block 0xc7, offset 0x31c0 - 0x31c0: 0x00c0, 0x31c1: 0x00c0, 0x31c2: 0x00c0, 0x31c3: 0x00c0, 0x31c4: 0x00c0, 0x31c5: 0x00c0, - 0x31c6: 0x00c0, 0x31c7: 0x00c0, 0x31c8: 0x00c0, 0x31c9: 0x00c0, 0x31ca: 0x00c0, 0x31cb: 0x00c0, - 0x31cc: 0x00c0, 0x31cd: 0x00c0, 0x31ce: 0x00c0, 0x31cf: 0x00c0, 0x31d0: 0x00c0, - 0x31e0: 0x00c3, 0x31e1: 0x0080, 0x31e2: 0x0080, 0x31e3: 0x0080, - 0x31e4: 0x0080, 0x31e5: 0x0080, 0x31e6: 0x0080, 0x31e7: 0x0080, 0x31e8: 0x0080, 0x31e9: 0x0080, - 0x31ea: 0x0080, 0x31eb: 0x0080, 0x31ec: 0x0080, 0x31ed: 0x0080, 0x31ee: 0x0080, 0x31ef: 0x0080, - 0x31f0: 0x0080, 0x31f1: 0x0080, 0x31f2: 0x0080, 0x31f3: 0x0080, 0x31f4: 0x0080, 0x31f5: 0x0080, - 0x31f6: 0x0080, 0x31f7: 0x0080, 0x31f8: 0x0080, 0x31f9: 0x0080, 0x31fa: 0x0080, 0x31fb: 0x0080, - // Block 0xc8, offset 0x3200 - 0x3200: 0x00c0, 0x3201: 0x00c0, 0x3202: 0x00c0, 0x3203: 0x00c0, 0x3204: 0x00c0, 0x3205: 0x00c0, - 0x3206: 0x00c0, 0x3207: 0x00c0, 0x3208: 0x00c0, 0x3209: 0x00c0, 0x320a: 0x00c0, 0x320b: 0x00c0, - 0x320c: 0x00c0, 0x320d: 0x00c0, 0x320e: 0x00c0, 0x320f: 0x00c0, 0x3210: 0x00c0, 0x3211: 0x00c0, - 0x3212: 0x00c0, 0x3213: 0x00c0, 0x3214: 0x00c0, 0x3215: 0x00c0, 0x3216: 0x00c0, 0x3217: 0x00c0, - 0x3218: 0x00c0, 0x3219: 0x00c0, 0x321a: 0x00c0, 0x321b: 0x00c0, 0x321c: 0x00c0, 0x321d: 0x00c0, - 0x321e: 0x00c0, 0x321f: 0x00c0, 0x3220: 0x0080, 0x3221: 0x0080, 0x3222: 0x0080, 0x3223: 0x0080, - 0x3230: 0x00c0, 0x3231: 0x00c0, 0x3232: 0x00c0, 0x3233: 0x00c0, 0x3234: 0x00c0, 0x3235: 0x00c0, - 0x3236: 0x00c0, 0x3237: 0x00c0, 0x3238: 0x00c0, 0x3239: 0x00c0, 0x323a: 0x00c0, 0x323b: 0x00c0, - 0x323c: 0x00c0, 0x323d: 0x00c0, 0x323e: 0x00c0, 0x323f: 0x00c0, - // Block 0xc9, offset 0x3240 - 0x3240: 0x00c0, 0x3241: 0x0080, 0x3242: 0x00c0, 0x3243: 0x00c0, 0x3244: 0x00c0, 0x3245: 0x00c0, - 0x3246: 0x00c0, 0x3247: 0x00c0, 0x3248: 0x00c0, 0x3249: 0x00c0, 0x324a: 0x0080, - 0x3250: 0x00c0, 0x3251: 0x00c0, - 0x3252: 0x00c0, 0x3253: 0x00c0, 0x3254: 0x00c0, 0x3255: 0x00c0, 0x3256: 0x00c0, 0x3257: 0x00c0, - 0x3258: 0x00c0, 0x3259: 0x00c0, 0x325a: 0x00c0, 0x325b: 0x00c0, 0x325c: 0x00c0, 0x325d: 0x00c0, - 0x325e: 0x00c0, 0x325f: 0x00c0, 0x3260: 0x00c0, 0x3261: 0x00c0, 0x3262: 0x00c0, 0x3263: 0x00c0, - 0x3264: 0x00c0, 0x3265: 0x00c0, 0x3266: 0x00c0, 0x3267: 0x00c0, 0x3268: 0x00c0, 0x3269: 0x00c0, - 0x326a: 0x00c0, 0x326b: 0x00c0, 0x326c: 0x00c0, 0x326d: 0x00c0, 0x326e: 0x00c0, 0x326f: 0x00c0, - 0x3270: 0x00c0, 0x3271: 0x00c0, 0x3272: 0x00c0, 0x3273: 0x00c0, 0x3274: 0x00c0, 0x3275: 0x00c0, - 0x3276: 0x00c3, 0x3277: 0x00c3, 0x3278: 0x00c3, 0x3279: 0x00c3, 0x327a: 0x00c3, - // Block 0xca, offset 0x3280 - 0x3280: 0x00c0, 0x3281: 0x00c0, 0x3282: 0x00c0, 0x3283: 0x00c0, 0x3284: 0x00c0, 0x3285: 0x00c0, - 0x3286: 0x00c0, 0x3287: 0x00c0, 0x3288: 0x00c0, 0x3289: 0x00c0, 0x328a: 0x00c0, 0x328b: 0x00c0, - 0x328c: 0x00c0, 0x328d: 0x00c0, 0x328e: 0x00c0, 0x328f: 0x00c0, 0x3290: 0x00c0, 0x3291: 0x00c0, - 0x3292: 0x00c0, 0x3293: 0x00c0, 0x3294: 0x00c0, 0x3295: 0x00c0, 0x3296: 0x00c0, 0x3297: 0x00c0, - 0x3298: 0x00c0, 0x3299: 0x00c0, 0x329a: 0x00c0, 0x329b: 0x00c0, 0x329c: 0x00c0, 0x329d: 0x00c0, - 0x329f: 0x0080, 0x32a0: 0x00c0, 0x32a1: 0x00c0, 0x32a2: 0x00c0, 0x32a3: 0x00c0, - 0x32a4: 0x00c0, 0x32a5: 0x00c0, 0x32a6: 0x00c0, 0x32a7: 0x00c0, 0x32a8: 0x00c0, 0x32a9: 0x00c0, - 0x32aa: 0x00c0, 0x32ab: 0x00c0, 0x32ac: 0x00c0, 0x32ad: 0x00c0, 0x32ae: 0x00c0, 0x32af: 0x00c0, - 0x32b0: 0x00c0, 0x32b1: 0x00c0, 0x32b2: 0x00c0, 0x32b3: 0x00c0, 0x32b4: 0x00c0, 0x32b5: 0x00c0, - 0x32b6: 0x00c0, 0x32b7: 0x00c0, 0x32b8: 0x00c0, 0x32b9: 0x00c0, 0x32ba: 0x00c0, 0x32bb: 0x00c0, - 0x32bc: 0x00c0, 0x32bd: 0x00c0, 0x32be: 0x00c0, 0x32bf: 0x00c0, - // Block 0xcb, offset 0x32c0 - 0x32c0: 0x00c0, 0x32c1: 0x00c0, 0x32c2: 0x00c0, 0x32c3: 0x00c0, - 0x32c8: 0x00c0, 0x32c9: 0x00c0, 0x32ca: 0x00c0, 0x32cb: 0x00c0, - 0x32cc: 0x00c0, 0x32cd: 0x00c0, 0x32ce: 0x00c0, 0x32cf: 0x00c0, 0x32d0: 0x0080, 0x32d1: 0x0080, - 0x32d2: 0x0080, 0x32d3: 0x0080, 0x32d4: 0x0080, 0x32d5: 0x0080, - // Block 0xcc, offset 0x3300 - 0x3300: 0x00c0, 0x3301: 0x00c0, 0x3302: 0x00c0, 0x3303: 0x00c0, 0x3304: 0x00c0, 0x3305: 0x00c0, - 0x3306: 0x00c0, 0x3307: 0x00c0, 0x3308: 0x00c0, 0x3309: 0x00c0, 0x330a: 0x00c0, 0x330b: 0x00c0, - 0x330c: 0x00c0, 0x330d: 0x00c0, 0x330e: 0x00c0, 0x330f: 0x00c0, 0x3310: 0x00c0, 0x3311: 0x00c0, - 0x3312: 0x00c0, 0x3313: 0x00c0, 0x3314: 0x00c0, 0x3315: 0x00c0, 0x3316: 0x00c0, 0x3317: 0x00c0, - 0x3318: 0x00c0, 0x3319: 0x00c0, 0x331a: 0x00c0, 0x331b: 0x00c0, 0x331c: 0x00c0, 0x331d: 0x00c0, - 0x3320: 0x00c0, 0x3321: 0x00c0, 0x3322: 0x00c0, 0x3323: 0x00c0, - 0x3324: 0x00c0, 0x3325: 0x00c0, 0x3326: 0x00c0, 0x3327: 0x00c0, 0x3328: 0x00c0, 0x3329: 0x00c0, - 0x3330: 0x00c0, 0x3331: 0x00c0, 0x3332: 0x00c0, 0x3333: 0x00c0, 0x3334: 0x00c0, 0x3335: 0x00c0, - 0x3336: 0x00c0, 0x3337: 0x00c0, 0x3338: 0x00c0, 0x3339: 0x00c0, 0x333a: 0x00c0, 0x333b: 0x00c0, - 0x333c: 0x00c0, 0x333d: 0x00c0, 0x333e: 0x00c0, 0x333f: 0x00c0, - // Block 0xcd, offset 0x3340 - 0x3340: 0x00c0, 0x3341: 0x00c0, 0x3342: 0x00c0, 0x3343: 0x00c0, 0x3344: 0x00c0, 0x3345: 0x00c0, - 0x3346: 0x00c0, 0x3347: 0x00c0, 0x3348: 0x00c0, 0x3349: 0x00c0, 0x334a: 0x00c0, 0x334b: 0x00c0, - 0x334c: 0x00c0, 0x334d: 0x00c0, 0x334e: 0x00c0, 0x334f: 0x00c0, 0x3350: 0x00c0, 0x3351: 0x00c0, - 0x3352: 0x00c0, 0x3353: 0x00c0, - 0x3358: 0x00c0, 0x3359: 0x00c0, 0x335a: 0x00c0, 0x335b: 0x00c0, 0x335c: 0x00c0, 0x335d: 0x00c0, - 0x335e: 0x00c0, 0x335f: 0x00c0, 0x3360: 0x00c0, 0x3361: 0x00c0, 0x3362: 0x00c0, 0x3363: 0x00c0, - 0x3364: 0x00c0, 0x3365: 0x00c0, 0x3366: 0x00c0, 0x3367: 0x00c0, 0x3368: 0x00c0, 0x3369: 0x00c0, - 0x336a: 0x00c0, 0x336b: 0x00c0, 0x336c: 0x00c0, 0x336d: 0x00c0, 0x336e: 0x00c0, 0x336f: 0x00c0, - 0x3370: 0x00c0, 0x3371: 0x00c0, 0x3372: 0x00c0, 0x3373: 0x00c0, 0x3374: 0x00c0, 0x3375: 0x00c0, - 0x3376: 0x00c0, 0x3377: 0x00c0, 0x3378: 0x00c0, 0x3379: 0x00c0, 0x337a: 0x00c0, 0x337b: 0x00c0, - // Block 0xce, offset 0x3380 - 0x3380: 0x00c0, 0x3381: 0x00c0, 0x3382: 0x00c0, 0x3383: 0x00c0, 0x3384: 0x00c0, 0x3385: 0x00c0, - 0x3386: 0x00c0, 0x3387: 0x00c0, 0x3388: 0x00c0, 0x3389: 0x00c0, 0x338a: 0x00c0, 0x338b: 0x00c0, - 0x338c: 0x00c0, 0x338d: 0x00c0, 0x338e: 0x00c0, 0x338f: 0x00c0, 0x3390: 0x00c0, 0x3391: 0x00c0, - 0x3392: 0x00c0, 0x3393: 0x00c0, 0x3394: 0x00c0, 0x3395: 0x00c0, 0x3396: 0x00c0, 0x3397: 0x00c0, - 0x3398: 0x00c0, 0x3399: 0x00c0, 0x339a: 0x00c0, 0x339b: 0x00c0, 0x339c: 0x00c0, 0x339d: 0x00c0, - 0x339e: 0x00c0, 0x339f: 0x00c0, 0x33a0: 0x00c0, 0x33a1: 0x00c0, 0x33a2: 0x00c0, 0x33a3: 0x00c0, - 0x33a4: 0x00c0, 0x33a5: 0x00c0, 0x33a6: 0x00c0, 0x33a7: 0x00c0, - 0x33b0: 0x00c0, 0x33b1: 0x00c0, 0x33b2: 0x00c0, 0x33b3: 0x00c0, 0x33b4: 0x00c0, 0x33b5: 0x00c0, - 0x33b6: 0x00c0, 0x33b7: 0x00c0, 0x33b8: 0x00c0, 0x33b9: 0x00c0, 0x33ba: 0x00c0, 0x33bb: 0x00c0, - 0x33bc: 0x00c0, 0x33bd: 0x00c0, 0x33be: 0x00c0, 0x33bf: 0x00c0, - // Block 0xcf, offset 0x33c0 - 0x33c0: 0x00c0, 0x33c1: 0x00c0, 0x33c2: 0x00c0, 0x33c3: 0x00c0, 0x33c4: 0x00c0, 0x33c5: 0x00c0, - 0x33c6: 0x00c0, 0x33c7: 0x00c0, 0x33c8: 0x00c0, 0x33c9: 0x00c0, 0x33ca: 0x00c0, 0x33cb: 0x00c0, - 0x33cc: 0x00c0, 0x33cd: 0x00c0, 0x33ce: 0x00c0, 0x33cf: 0x00c0, 0x33d0: 0x00c0, 0x33d1: 0x00c0, - 0x33d2: 0x00c0, 0x33d3: 0x00c0, 0x33d4: 0x00c0, 0x33d5: 0x00c0, 0x33d6: 0x00c0, 0x33d7: 0x00c0, - 0x33d8: 0x00c0, 0x33d9: 0x00c0, 0x33da: 0x00c0, 0x33db: 0x00c0, 0x33dc: 0x00c0, 0x33dd: 0x00c0, - 0x33de: 0x00c0, 0x33df: 0x00c0, 0x33e0: 0x00c0, 0x33e1: 0x00c0, 0x33e2: 0x00c0, 0x33e3: 0x00c0, - 0x33ef: 0x0080, - // Block 0xd0, offset 0x3400 - 0x3400: 0x00c0, 0x3401: 0x00c0, 0x3402: 0x00c0, 0x3403: 0x00c0, 0x3404: 0x00c0, 0x3405: 0x00c0, - 0x3406: 0x00c0, 0x3407: 0x00c0, 0x3408: 0x00c0, 0x3409: 0x00c0, 0x340a: 0x00c0, 0x340b: 0x00c0, - 0x340c: 0x00c0, 0x340d: 0x00c0, 0x340e: 0x00c0, 0x340f: 0x00c0, 0x3410: 0x00c0, 0x3411: 0x00c0, - 0x3412: 0x00c0, 0x3413: 0x00c0, 0x3414: 0x00c0, 0x3415: 0x00c0, 0x3416: 0x00c0, 0x3417: 0x00c0, - 0x3418: 0x00c0, 0x3419: 0x00c0, 0x341a: 0x00c0, 0x341b: 0x00c0, 0x341c: 0x00c0, 0x341d: 0x00c0, - 0x341e: 0x00c0, 0x341f: 0x00c0, 0x3420: 0x00c0, 0x3421: 0x00c0, 0x3422: 0x00c0, 0x3423: 0x00c0, - 0x3424: 0x00c0, 0x3425: 0x00c0, 0x3426: 0x00c0, 0x3427: 0x00c0, 0x3428: 0x00c0, 0x3429: 0x00c0, - 0x342a: 0x00c0, 0x342b: 0x00c0, 0x342c: 0x00c0, 0x342d: 0x00c0, 0x342e: 0x00c0, 0x342f: 0x00c0, - 0x3430: 0x00c0, 0x3431: 0x00c0, 0x3432: 0x00c0, 0x3433: 0x00c0, 0x3434: 0x00c0, 0x3435: 0x00c0, - 0x3436: 0x00c0, - // Block 0xd1, offset 0x3440 - 0x3440: 0x00c0, 0x3441: 0x00c0, 0x3442: 0x00c0, 0x3443: 0x00c0, 0x3444: 0x00c0, 0x3445: 0x00c0, - 0x3446: 0x00c0, 0x3447: 0x00c0, 0x3448: 0x00c0, 0x3449: 0x00c0, 0x344a: 0x00c0, 0x344b: 0x00c0, - 0x344c: 0x00c0, 0x344d: 0x00c0, 0x344e: 0x00c0, 0x344f: 0x00c0, 0x3450: 0x00c0, 0x3451: 0x00c0, - 0x3452: 0x00c0, 0x3453: 0x00c0, 0x3454: 0x00c0, 0x3455: 0x00c0, - 0x3460: 0x00c0, 0x3461: 0x00c0, 0x3462: 0x00c0, 0x3463: 0x00c0, - 0x3464: 0x00c0, 0x3465: 0x00c0, 0x3466: 0x00c0, 0x3467: 0x00c0, - // Block 0xd2, offset 0x3480 - 0x3480: 0x00c0, 0x3481: 0x00c0, 0x3482: 0x00c0, 0x3483: 0x00c0, 0x3484: 0x00c0, 0x3485: 0x00c0, - 0x3488: 0x00c0, 0x348a: 0x00c0, 0x348b: 0x00c0, - 0x348c: 0x00c0, 0x348d: 0x00c0, 0x348e: 0x00c0, 0x348f: 0x00c0, 0x3490: 0x00c0, 0x3491: 0x00c0, - 0x3492: 0x00c0, 0x3493: 0x00c0, 0x3494: 0x00c0, 0x3495: 0x00c0, 0x3496: 0x00c0, 0x3497: 0x00c0, - 0x3498: 0x00c0, 0x3499: 0x00c0, 0x349a: 0x00c0, 0x349b: 0x00c0, 0x349c: 0x00c0, 0x349d: 0x00c0, - 0x349e: 0x00c0, 0x349f: 0x00c0, 0x34a0: 0x00c0, 0x34a1: 0x00c0, 0x34a2: 0x00c0, 0x34a3: 0x00c0, - 0x34a4: 0x00c0, 0x34a5: 0x00c0, 0x34a6: 0x00c0, 0x34a7: 0x00c0, 0x34a8: 0x00c0, 0x34a9: 0x00c0, - 0x34aa: 0x00c0, 0x34ab: 0x00c0, 0x34ac: 0x00c0, 0x34ad: 0x00c0, 0x34ae: 0x00c0, 0x34af: 0x00c0, - 0x34b0: 0x00c0, 0x34b1: 0x00c0, 0x34b2: 0x00c0, 0x34b3: 0x00c0, 0x34b4: 0x00c0, 0x34b5: 0x00c0, - 0x34b7: 0x00c0, 0x34b8: 0x00c0, - 0x34bc: 0x00c0, 0x34bf: 0x00c0, - // Block 0xd3, offset 0x34c0 - 0x34c0: 0x00c0, 0x34c1: 0x00c0, 0x34c2: 0x00c0, 0x34c3: 0x00c0, 0x34c4: 0x00c0, 0x34c5: 0x00c0, - 0x34c6: 0x00c0, 0x34c7: 0x00c0, 0x34c8: 0x00c0, 0x34c9: 0x00c0, 0x34ca: 0x00c0, 0x34cb: 0x00c0, - 0x34cc: 0x00c0, 0x34cd: 0x00c0, 0x34ce: 0x00c0, 0x34cf: 0x00c0, 0x34d0: 0x00c0, 0x34d1: 0x00c0, - 0x34d2: 0x00c0, 0x34d3: 0x00c0, 0x34d4: 0x00c0, 0x34d5: 0x00c0, 0x34d7: 0x0080, - 0x34d8: 0x0080, 0x34d9: 0x0080, 0x34da: 0x0080, 0x34db: 0x0080, 0x34dc: 0x0080, 0x34dd: 0x0080, - 0x34de: 0x0080, 0x34df: 0x0080, 0x34e0: 0x00c0, 0x34e1: 0x00c0, 0x34e2: 0x00c0, 0x34e3: 0x00c0, - 0x34e4: 0x00c0, 0x34e5: 0x00c0, 0x34e6: 0x00c0, 0x34e7: 0x00c0, 0x34e8: 0x00c0, 0x34e9: 0x00c0, - 0x34ea: 0x00c0, 0x34eb: 0x00c0, 0x34ec: 0x00c0, 0x34ed: 0x00c0, 0x34ee: 0x00c0, 0x34ef: 0x00c0, - 0x34f0: 0x00c0, 0x34f1: 0x00c0, 0x34f2: 0x00c0, 0x34f3: 0x00c0, 0x34f4: 0x00c0, 0x34f5: 0x00c0, - 0x34f6: 0x00c0, 0x34f7: 0x0080, 0x34f8: 0x0080, 0x34f9: 0x0080, 0x34fa: 0x0080, 0x34fb: 0x0080, - 0x34fc: 0x0080, 0x34fd: 0x0080, 0x34fe: 0x0080, 0x34ff: 0x0080, - // Block 0xd4, offset 0x3500 - 0x3500: 0x00c0, 0x3501: 0x00c0, 0x3502: 0x00c0, 0x3503: 0x00c0, 0x3504: 0x00c0, 0x3505: 0x00c0, - 0x3506: 0x00c0, 0x3507: 0x00c0, 0x3508: 0x00c0, 0x3509: 0x00c0, 0x350a: 0x00c0, 0x350b: 0x00c0, - 0x350c: 0x00c0, 0x350d: 0x00c0, 0x350e: 0x00c0, 0x350f: 0x00c0, 0x3510: 0x00c0, 0x3511: 0x00c0, - 0x3512: 0x00c0, 0x3513: 0x00c0, 0x3514: 0x00c0, 0x3515: 0x00c0, 0x3516: 0x00c0, 0x3517: 0x00c0, - 0x3518: 0x00c0, 0x3519: 0x00c0, 0x351a: 0x00c0, 0x351b: 0x00c0, 0x351c: 0x00c0, 0x351d: 0x00c0, - 0x351e: 0x00c0, - 0x3527: 0x0080, 0x3528: 0x0080, 0x3529: 0x0080, - 0x352a: 0x0080, 0x352b: 0x0080, 0x352c: 0x0080, 0x352d: 0x0080, 0x352e: 0x0080, 0x352f: 0x0080, - // Block 0xd5, offset 0x3540 - 0x3560: 0x00c0, 0x3561: 0x00c0, 0x3562: 0x00c0, 0x3563: 0x00c0, - 0x3564: 0x00c0, 0x3565: 0x00c0, 0x3566: 0x00c0, 0x3567: 0x00c0, 0x3568: 0x00c0, 0x3569: 0x00c0, - 0x356a: 0x00c0, 0x356b: 0x00c0, 0x356c: 0x00c0, 0x356d: 0x00c0, 0x356e: 0x00c0, 0x356f: 0x00c0, - 0x3570: 0x00c0, 0x3571: 0x00c0, 0x3572: 0x00c0, 0x3574: 0x00c0, 0x3575: 0x00c0, - 0x357b: 0x0080, - 0x357c: 0x0080, 0x357d: 0x0080, 0x357e: 0x0080, 0x357f: 0x0080, - // Block 0xd6, offset 0x3580 - 0x3580: 0x00c0, 0x3581: 0x00c0, 0x3582: 0x00c0, 0x3583: 0x00c0, 0x3584: 0x00c0, 0x3585: 0x00c0, - 0x3586: 0x00c0, 0x3587: 0x00c0, 0x3588: 0x00c0, 0x3589: 0x00c0, 0x358a: 0x00c0, 0x358b: 0x00c0, - 0x358c: 0x00c0, 0x358d: 0x00c0, 0x358e: 0x00c0, 0x358f: 0x00c0, 0x3590: 0x00c0, 0x3591: 0x00c0, - 0x3592: 0x00c0, 0x3593: 0x00c0, 0x3594: 0x00c0, 0x3595: 0x00c0, 0x3596: 0x0080, 0x3597: 0x0080, - 0x3598: 0x0080, 0x3599: 0x0080, 0x359a: 0x0080, 0x359b: 0x0080, - 0x359f: 0x0080, 0x35a0: 0x00c0, 0x35a1: 0x00c0, 0x35a2: 0x00c0, 0x35a3: 0x00c0, - 0x35a4: 0x00c0, 0x35a5: 0x00c0, 0x35a6: 0x00c0, 0x35a7: 0x00c0, 0x35a8: 0x00c0, 0x35a9: 0x00c0, - 0x35aa: 0x00c0, 0x35ab: 0x00c0, 0x35ac: 0x00c0, 0x35ad: 0x00c0, 0x35ae: 0x00c0, 0x35af: 0x00c0, - 0x35b0: 0x00c0, 0x35b1: 0x00c0, 0x35b2: 0x00c0, 0x35b3: 0x00c0, 0x35b4: 0x00c0, 0x35b5: 0x00c0, - 0x35b6: 0x00c0, 0x35b7: 0x00c0, 0x35b8: 0x00c0, 0x35b9: 0x00c0, - 0x35bf: 0x0080, - // Block 0xd7, offset 0x35c0 - 0x35c0: 0x00c0, 0x35c1: 0x00c0, 0x35c2: 0x00c0, 0x35c3: 0x00c0, 0x35c4: 0x00c0, 0x35c5: 0x00c0, - 0x35c6: 0x00c0, 0x35c7: 0x00c0, 0x35c8: 0x00c0, 0x35c9: 0x00c0, 0x35ca: 0x00c0, 0x35cb: 0x00c0, - 0x35cc: 0x00c0, 0x35cd: 0x00c0, 0x35ce: 0x00c0, 0x35cf: 0x00c0, 0x35d0: 0x00c0, 0x35d1: 0x00c0, - 0x35d2: 0x00c0, 0x35d3: 0x00c0, 0x35d4: 0x00c0, 0x35d5: 0x00c0, 0x35d6: 0x00c0, 0x35d7: 0x00c0, - 0x35d8: 0x00c0, 0x35d9: 0x00c0, 0x35da: 0x00c0, 0x35db: 0x00c0, 0x35dc: 0x00c0, 0x35dd: 0x00c0, - 0x35de: 0x00c0, 0x35df: 0x00c0, 0x35e0: 0x00c0, 0x35e1: 0x00c0, 0x35e2: 0x00c0, 0x35e3: 0x00c0, - 0x35e4: 0x00c0, 0x35e5: 0x00c0, 0x35e6: 0x00c0, 0x35e7: 0x00c0, 0x35e8: 0x00c0, 0x35e9: 0x00c0, - 0x35ea: 0x00c0, 0x35eb: 0x00c0, 0x35ec: 0x00c0, 0x35ed: 0x00c0, 0x35ee: 0x00c0, 0x35ef: 0x00c0, - 0x35f0: 0x00c0, 0x35f1: 0x00c0, 0x35f2: 0x00c0, 0x35f3: 0x00c0, 0x35f4: 0x00c0, 0x35f5: 0x00c0, - 0x35f6: 0x00c0, 0x35f7: 0x00c0, - 0x35fc: 0x0080, 0x35fd: 0x0080, 0x35fe: 0x00c0, 0x35ff: 0x00c0, - // Block 0xd8, offset 0x3600 - 0x3600: 0x00c0, 0x3601: 0x00c3, 0x3602: 0x00c3, 0x3603: 0x00c3, 0x3605: 0x00c3, - 0x3606: 0x00c3, - 0x360c: 0x00c3, 0x360d: 0x00c3, 0x360e: 0x00c3, 0x360f: 0x00c3, 0x3610: 0x00c0, 0x3611: 0x00c0, - 0x3612: 0x00c0, 0x3613: 0x00c0, 0x3615: 0x00c0, 0x3616: 0x00c0, 0x3617: 0x00c0, - 0x3619: 0x00c0, 0x361a: 0x00c0, 0x361b: 0x00c0, 0x361c: 0x00c0, 0x361d: 0x00c0, - 0x361e: 0x00c0, 0x361f: 0x00c0, 0x3620: 0x00c0, 0x3621: 0x00c0, 0x3622: 0x00c0, 0x3623: 0x00c0, - 0x3624: 0x00c0, 0x3625: 0x00c0, 0x3626: 0x00c0, 0x3627: 0x00c0, 0x3628: 0x00c0, 0x3629: 0x00c0, - 0x362a: 0x00c0, 0x362b: 0x00c0, 0x362c: 0x00c0, 0x362d: 0x00c0, 0x362e: 0x00c0, 0x362f: 0x00c0, - 0x3630: 0x00c0, 0x3631: 0x00c0, 0x3632: 0x00c0, 0x3633: 0x00c0, - 0x3638: 0x00c3, 0x3639: 0x00c3, 0x363a: 0x00c3, - 0x363f: 0x00c6, - // Block 0xd9, offset 0x3640 - 0x3640: 0x0080, 0x3641: 0x0080, 0x3642: 0x0080, 0x3643: 0x0080, 0x3644: 0x0080, 0x3645: 0x0080, - 0x3646: 0x0080, 0x3647: 0x0080, - 0x3650: 0x0080, 0x3651: 0x0080, - 0x3652: 0x0080, 0x3653: 0x0080, 0x3654: 0x0080, 0x3655: 0x0080, 0x3656: 0x0080, 0x3657: 0x0080, - 0x3658: 0x0080, - 0x3660: 0x00c0, 0x3661: 0x00c0, 0x3662: 0x00c0, 0x3663: 0x00c0, - 0x3664: 0x00c0, 0x3665: 0x00c0, 0x3666: 0x00c0, 0x3667: 0x00c0, 0x3668: 0x00c0, 0x3669: 0x00c0, - 0x366a: 0x00c0, 0x366b: 0x00c0, 0x366c: 0x00c0, 0x366d: 0x00c0, 0x366e: 0x00c0, 0x366f: 0x00c0, - 0x3670: 0x00c0, 0x3671: 0x00c0, 0x3672: 0x00c0, 0x3673: 0x00c0, 0x3674: 0x00c0, 0x3675: 0x00c0, - 0x3676: 0x00c0, 0x3677: 0x00c0, 0x3678: 0x00c0, 0x3679: 0x00c0, 0x367a: 0x00c0, 0x367b: 0x00c0, - 0x367c: 0x00c0, 0x367d: 0x0080, 0x367e: 0x0080, 0x367f: 0x0080, - // Block 0xda, offset 0x3680 - 0x3680: 0x00c0, 0x3681: 0x00c0, 0x3682: 0x00c0, 0x3683: 0x00c0, 0x3684: 0x00c0, 0x3685: 0x00c0, - 0x3686: 0x00c0, 0x3687: 0x00c0, 0x3688: 0x00c0, 0x3689: 0x00c0, 0x368a: 0x00c0, 0x368b: 0x00c0, - 0x368c: 0x00c0, 0x368d: 0x00c0, 0x368e: 0x00c0, 0x368f: 0x00c0, 0x3690: 0x00c0, 0x3691: 0x00c0, - 0x3692: 0x00c0, 0x3693: 0x00c0, 0x3694: 0x00c0, 0x3695: 0x00c0, 0x3696: 0x00c0, 0x3697: 0x00c0, - 0x3698: 0x00c0, 0x3699: 0x00c0, 0x369a: 0x00c0, 0x369b: 0x00c0, 0x369c: 0x00c0, 0x369d: 0x0080, - 0x369e: 0x0080, 0x369f: 0x0080, - // Block 0xdb, offset 0x36c0 - 0x36c0: 0x00c2, 0x36c1: 0x00c2, 0x36c2: 0x00c2, 0x36c3: 0x00c2, 0x36c4: 0x00c2, 0x36c5: 0x00c4, - 0x36c6: 0x00c0, 0x36c7: 0x00c4, 0x36c8: 0x0080, 0x36c9: 0x00c4, 0x36ca: 0x00c4, 0x36cb: 0x00c0, - 0x36cc: 0x00c0, 0x36cd: 0x00c1, 0x36ce: 0x00c4, 0x36cf: 0x00c4, 0x36d0: 0x00c4, 0x36d1: 0x00c4, - 0x36d2: 0x00c4, 0x36d3: 0x00c2, 0x36d4: 0x00c2, 0x36d5: 0x00c2, 0x36d6: 0x00c2, 0x36d7: 0x00c1, - 0x36d8: 0x00c2, 0x36d9: 0x00c2, 0x36da: 0x00c2, 0x36db: 0x00c2, 0x36dc: 0x00c2, 0x36dd: 0x00c4, - 0x36de: 0x00c2, 0x36df: 0x00c2, 0x36e0: 0x00c2, 0x36e1: 0x00c4, 0x36e2: 0x00c0, 0x36e3: 0x00c0, - 0x36e4: 0x00c4, 0x36e5: 0x00c3, 0x36e6: 0x00c3, - 0x36eb: 0x0082, 0x36ec: 0x0082, 0x36ed: 0x0082, 0x36ee: 0x0082, 0x36ef: 0x0084, - 0x36f0: 0x0080, 0x36f1: 0x0080, 0x36f2: 0x0080, 0x36f3: 0x0080, 0x36f4: 0x0080, 0x36f5: 0x0080, - 0x36f6: 0x0080, - // Block 0xdc, offset 0x3700 - 0x3700: 0x00c0, 0x3701: 0x00c0, 0x3702: 0x00c0, 0x3703: 0x00c0, 0x3704: 0x00c0, 0x3705: 0x00c0, - 0x3706: 0x00c0, 0x3707: 0x00c0, 0x3708: 0x00c0, 0x3709: 0x00c0, 0x370a: 0x00c0, 0x370b: 0x00c0, - 0x370c: 0x00c0, 0x370d: 0x00c0, 0x370e: 0x00c0, 0x370f: 0x00c0, 0x3710: 0x00c0, 0x3711: 0x00c0, - 0x3712: 0x00c0, 0x3713: 0x00c0, 0x3714: 0x00c0, 0x3715: 0x00c0, 0x3716: 0x00c0, 0x3717: 0x00c0, - 0x3718: 0x00c0, 0x3719: 0x00c0, 0x371a: 0x00c0, 0x371b: 0x00c0, 0x371c: 0x00c0, 0x371d: 0x00c0, - 0x371e: 0x00c0, 0x371f: 0x00c0, 0x3720: 0x00c0, 0x3721: 0x00c0, 0x3722: 0x00c0, 0x3723: 0x00c0, - 0x3724: 0x00c0, 0x3725: 0x00c0, 0x3726: 0x00c0, 0x3727: 0x00c0, 0x3728: 0x00c0, 0x3729: 0x00c0, - 0x372a: 0x00c0, 0x372b: 0x00c0, 0x372c: 0x00c0, 0x372d: 0x00c0, 0x372e: 0x00c0, 0x372f: 0x00c0, - 0x3730: 0x00c0, 0x3731: 0x00c0, 0x3732: 0x00c0, 0x3733: 0x00c0, 0x3734: 0x00c0, 0x3735: 0x00c0, - 0x3739: 0x0080, 0x373a: 0x0080, 0x373b: 0x0080, - 0x373c: 0x0080, 0x373d: 0x0080, 0x373e: 0x0080, 0x373f: 0x0080, - // Block 0xdd, offset 0x3740 - 0x3740: 0x00c0, 0x3741: 0x00c0, 0x3742: 0x00c0, 0x3743: 0x00c0, 0x3744: 0x00c0, 0x3745: 0x00c0, - 0x3746: 0x00c0, 0x3747: 0x00c0, 0x3748: 0x00c0, 0x3749: 0x00c0, 0x374a: 0x00c0, 0x374b: 0x00c0, - 0x374c: 0x00c0, 0x374d: 0x00c0, 0x374e: 0x00c0, 0x374f: 0x00c0, 0x3750: 0x00c0, 0x3751: 0x00c0, - 0x3752: 0x00c0, 0x3753: 0x00c0, 0x3754: 0x00c0, 0x3755: 0x00c0, - 0x3758: 0x0080, 0x3759: 0x0080, 0x375a: 0x0080, 0x375b: 0x0080, 0x375c: 0x0080, 0x375d: 0x0080, - 0x375e: 0x0080, 0x375f: 0x0080, 0x3760: 0x00c0, 0x3761: 0x00c0, 0x3762: 0x00c0, 0x3763: 0x00c0, - 0x3764: 0x00c0, 0x3765: 0x00c0, 0x3766: 0x00c0, 0x3767: 0x00c0, 0x3768: 0x00c0, 0x3769: 0x00c0, - 0x376a: 0x00c0, 0x376b: 0x00c0, 0x376c: 0x00c0, 0x376d: 0x00c0, 0x376e: 0x00c0, 0x376f: 0x00c0, - 0x3770: 0x00c0, 0x3771: 0x00c0, 0x3772: 0x00c0, - 0x3778: 0x0080, 0x3779: 0x0080, 0x377a: 0x0080, 0x377b: 0x0080, - 0x377c: 0x0080, 0x377d: 0x0080, 0x377e: 0x0080, 0x377f: 0x0080, - // Block 0xde, offset 0x3780 - 0x3780: 0x00c2, 0x3781: 0x00c4, 0x3782: 0x00c2, 0x3783: 0x00c4, 0x3784: 0x00c4, 0x3785: 0x00c4, - 0x3786: 0x00c2, 0x3787: 0x00c2, 0x3788: 0x00c2, 0x3789: 0x00c4, 0x378a: 0x00c2, 0x378b: 0x00c2, - 0x378c: 0x00c4, 0x378d: 0x00c2, 0x378e: 0x00c4, 0x378f: 0x00c4, 0x3790: 0x00c2, 0x3791: 0x00c4, - 0x3799: 0x0080, 0x379a: 0x0080, 0x379b: 0x0080, 0x379c: 0x0080, - 0x37a9: 0x0084, - 0x37aa: 0x0084, 0x37ab: 0x0084, 0x37ac: 0x0084, 0x37ad: 0x0082, 0x37ae: 0x0082, 0x37af: 0x0080, - // Block 0xdf, offset 0x37c0 - 0x37c0: 0x00c0, 0x37c1: 0x00c0, 0x37c2: 0x00c0, 0x37c3: 0x00c0, 0x37c4: 0x00c0, 0x37c5: 0x00c0, - 0x37c6: 0x00c0, 0x37c7: 0x00c0, 0x37c8: 0x00c0, 0x37c9: 0x00c0, 0x37ca: 0x00c0, 0x37cb: 0x00c0, - 0x37cc: 0x00c0, 0x37cd: 0x00c0, 0x37ce: 0x00c0, 0x37cf: 0x00c0, 0x37d0: 0x00c0, 0x37d1: 0x00c0, - 0x37d2: 0x00c0, 0x37d3: 0x00c0, 0x37d4: 0x00c0, 0x37d5: 0x00c0, 0x37d6: 0x00c0, 0x37d7: 0x00c0, - 0x37d8: 0x00c0, 0x37d9: 0x00c0, 0x37da: 0x00c0, 0x37db: 0x00c0, 0x37dc: 0x00c0, 0x37dd: 0x00c0, - 0x37de: 0x00c0, 0x37df: 0x00c0, 0x37e0: 0x00c0, 0x37e1: 0x00c0, 0x37e2: 0x00c0, 0x37e3: 0x00c0, - 0x37e4: 0x00c0, 0x37e5: 0x00c0, 0x37e6: 0x00c0, 0x37e7: 0x00c0, 0x37e8: 0x00c0, 0x37e9: 0x00c0, - 0x37ea: 0x00c0, 0x37eb: 0x00c0, 0x37ec: 0x00c0, 0x37ed: 0x00c0, 0x37ee: 0x00c0, 0x37ef: 0x00c0, - 0x37f0: 0x00c0, 0x37f1: 0x00c0, 0x37f2: 0x00c0, - // Block 0xe0, offset 0x3800 - 0x3800: 0x00c0, 0x3801: 0x00c0, 0x3802: 0x00c0, 0x3803: 0x00c0, 0x3804: 0x00c0, 0x3805: 0x00c0, - 0x3806: 0x00c0, 0x3807: 0x00c0, 0x3808: 0x00c0, 0x3809: 0x00c0, 0x380a: 0x00c0, 0x380b: 0x00c0, - 0x380c: 0x00c0, 0x380d: 0x00c0, 0x380e: 0x00c0, 0x380f: 0x00c0, 0x3810: 0x00c0, 0x3811: 0x00c0, - 0x3812: 0x00c0, 0x3813: 0x00c0, 0x3814: 0x00c0, 0x3815: 0x00c0, 0x3816: 0x00c0, 0x3817: 0x00c0, - 0x3818: 0x00c0, 0x3819: 0x00c0, 0x381a: 0x00c0, 0x381b: 0x00c0, 0x381c: 0x00c0, 0x381d: 0x00c0, - 0x381e: 0x00c0, 0x381f: 0x00c0, 0x3820: 0x00c0, 0x3821: 0x00c0, 0x3822: 0x00c0, 0x3823: 0x00c0, - 0x3824: 0x00c0, 0x3825: 0x00c0, 0x3826: 0x00c0, 0x3827: 0x00c0, 0x3828: 0x00c0, 0x3829: 0x00c0, - 0x382a: 0x00c0, 0x382b: 0x00c0, 0x382c: 0x00c0, 0x382d: 0x00c0, 0x382e: 0x00c0, 0x382f: 0x00c0, - 0x3830: 0x00c0, 0x3831: 0x00c0, 0x3832: 0x00c0, - 0x383a: 0x0080, 0x383b: 0x0080, - 0x383c: 0x0080, 0x383d: 0x0080, 0x383e: 0x0080, 0x383f: 0x0080, - // Block 0xe1, offset 0x3840 - 0x3860: 0x0080, 0x3861: 0x0080, 0x3862: 0x0080, 0x3863: 0x0080, - 0x3864: 0x0080, 0x3865: 0x0080, 0x3866: 0x0080, 0x3867: 0x0080, 0x3868: 0x0080, 0x3869: 0x0080, - 0x386a: 0x0080, 0x386b: 0x0080, 0x386c: 0x0080, 0x386d: 0x0080, 0x386e: 0x0080, 0x386f: 0x0080, - 0x3870: 0x0080, 0x3871: 0x0080, 0x3872: 0x0080, 0x3873: 0x0080, 0x3874: 0x0080, 0x3875: 0x0080, - 0x3876: 0x0080, 0x3877: 0x0080, 0x3878: 0x0080, 0x3879: 0x0080, 0x387a: 0x0080, 0x387b: 0x0080, - 0x387c: 0x0080, 0x387d: 0x0080, 0x387e: 0x0080, - // Block 0xe2, offset 0x3880 - 0x3880: 0x00c0, 0x3881: 0x00c3, 0x3882: 0x00c0, 0x3883: 0x00c0, 0x3884: 0x00c0, 0x3885: 0x00c0, - 0x3886: 0x00c0, 0x3887: 0x00c0, 0x3888: 0x00c0, 0x3889: 0x00c0, 0x388a: 0x00c0, 0x388b: 0x00c0, - 0x388c: 0x00c0, 0x388d: 0x00c0, 0x388e: 0x00c0, 0x388f: 0x00c0, 0x3890: 0x00c0, 0x3891: 0x00c0, - 0x3892: 0x00c0, 0x3893: 0x00c0, 0x3894: 0x00c0, 0x3895: 0x00c0, 0x3896: 0x00c0, 0x3897: 0x00c0, - 0x3898: 0x00c0, 0x3899: 0x00c0, 0x389a: 0x00c0, 0x389b: 0x00c0, 0x389c: 0x00c0, 0x389d: 0x00c0, - 0x389e: 0x00c0, 0x389f: 0x00c0, 0x38a0: 0x00c0, 0x38a1: 0x00c0, 0x38a2: 0x00c0, 0x38a3: 0x00c0, - 0x38a4: 0x00c0, 0x38a5: 0x00c0, 0x38a6: 0x00c0, 0x38a7: 0x00c0, 0x38a8: 0x00c0, 0x38a9: 0x00c0, - 0x38aa: 0x00c0, 0x38ab: 0x00c0, 0x38ac: 0x00c0, 0x38ad: 0x00c0, 0x38ae: 0x00c0, 0x38af: 0x00c0, - 0x38b0: 0x00c0, 0x38b1: 0x00c0, 0x38b2: 0x00c0, 0x38b3: 0x00c0, 0x38b4: 0x00c0, 0x38b5: 0x00c0, - 0x38b6: 0x00c0, 0x38b7: 0x00c0, 0x38b8: 0x00c3, 0x38b9: 0x00c3, 0x38ba: 0x00c3, 0x38bb: 0x00c3, - 0x38bc: 0x00c3, 0x38bd: 0x00c3, 0x38be: 0x00c3, 0x38bf: 0x00c3, - // Block 0xe3, offset 0x38c0 - 0x38c0: 0x00c3, 0x38c1: 0x00c3, 0x38c2: 0x00c3, 0x38c3: 0x00c3, 0x38c4: 0x00c3, 0x38c5: 0x00c3, - 0x38c6: 0x00c6, 0x38c7: 0x0080, 0x38c8: 0x0080, 0x38c9: 0x0080, 0x38ca: 0x0080, 0x38cb: 0x0080, - 0x38cc: 0x0080, 0x38cd: 0x0080, - 0x38d2: 0x0080, 0x38d3: 0x0080, 0x38d4: 0x0080, 0x38d5: 0x0080, 0x38d6: 0x0080, 0x38d7: 0x0080, - 0x38d8: 0x0080, 0x38d9: 0x0080, 0x38da: 0x0080, 0x38db: 0x0080, 0x38dc: 0x0080, 0x38dd: 0x0080, - 0x38de: 0x0080, 0x38df: 0x0080, 0x38e0: 0x0080, 0x38e1: 0x0080, 0x38e2: 0x0080, 0x38e3: 0x0080, - 0x38e4: 0x0080, 0x38e5: 0x0080, 0x38e6: 0x00c0, 0x38e7: 0x00c0, 0x38e8: 0x00c0, 0x38e9: 0x00c0, - 0x38ea: 0x00c0, 0x38eb: 0x00c0, 0x38ec: 0x00c0, 0x38ed: 0x00c0, 0x38ee: 0x00c0, 0x38ef: 0x00c0, - 0x38ff: 0x00c6, - // Block 0xe4, offset 0x3900 - 0x3900: 0x00c3, 0x3901: 0x00c3, 0x3902: 0x00c0, 0x3903: 0x00c0, 0x3904: 0x00c0, 0x3905: 0x00c0, - 0x3906: 0x00c0, 0x3907: 0x00c0, 0x3908: 0x00c0, 0x3909: 0x00c0, 0x390a: 0x00c0, 0x390b: 0x00c0, - 0x390c: 0x00c0, 0x390d: 0x00c0, 0x390e: 0x00c0, 0x390f: 0x00c0, 0x3910: 0x00c0, 0x3911: 0x00c0, - 0x3912: 0x00c0, 0x3913: 0x00c0, 0x3914: 0x00c0, 0x3915: 0x00c0, 0x3916: 0x00c0, 0x3917: 0x00c0, - 0x3918: 0x00c0, 0x3919: 0x00c0, 0x391a: 0x00c0, 0x391b: 0x00c0, 0x391c: 0x00c0, 0x391d: 0x00c0, - 0x391e: 0x00c0, 0x391f: 0x00c0, 0x3920: 0x00c0, 0x3921: 0x00c0, 0x3922: 0x00c0, 0x3923: 0x00c0, - 0x3924: 0x00c0, 0x3925: 0x00c0, 0x3926: 0x00c0, 0x3927: 0x00c0, 0x3928: 0x00c0, 0x3929: 0x00c0, - 0x392a: 0x00c0, 0x392b: 0x00c0, 0x392c: 0x00c0, 0x392d: 0x00c0, 0x392e: 0x00c0, 0x392f: 0x00c0, - 0x3930: 0x00c0, 0x3931: 0x00c0, 0x3932: 0x00c0, 0x3933: 0x00c3, 0x3934: 0x00c3, 0x3935: 0x00c3, - 0x3936: 0x00c3, 0x3937: 0x00c0, 0x3938: 0x00c0, 0x3939: 0x00c6, 0x393a: 0x00c3, 0x393b: 0x0080, - 0x393c: 0x0080, 0x393d: 0x0040, 0x393e: 0x0080, 0x393f: 0x0080, - // Block 0xe5, offset 0x3940 - 0x3940: 0x0080, 0x3941: 0x0080, - 0x3950: 0x00c0, 0x3951: 0x00c0, - 0x3952: 0x00c0, 0x3953: 0x00c0, 0x3954: 0x00c0, 0x3955: 0x00c0, 0x3956: 0x00c0, 0x3957: 0x00c0, - 0x3958: 0x00c0, 0x3959: 0x00c0, 0x395a: 0x00c0, 0x395b: 0x00c0, 0x395c: 0x00c0, 0x395d: 0x00c0, - 0x395e: 0x00c0, 0x395f: 0x00c0, 0x3960: 0x00c0, 0x3961: 0x00c0, 0x3962: 0x00c0, 0x3963: 0x00c0, - 0x3964: 0x00c0, 0x3965: 0x00c0, 0x3966: 0x00c0, 0x3967: 0x00c0, 0x3968: 0x00c0, - 0x3970: 0x00c0, 0x3971: 0x00c0, 0x3972: 0x00c0, 0x3973: 0x00c0, 0x3974: 0x00c0, 0x3975: 0x00c0, - 0x3976: 0x00c0, 0x3977: 0x00c0, 0x3978: 0x00c0, 0x3979: 0x00c0, - // Block 0xe6, offset 0x3980 - 0x3980: 0x00c3, 0x3981: 0x00c3, 0x3982: 0x00c3, 0x3983: 0x00c0, 0x3984: 0x00c0, 0x3985: 0x00c0, - 0x3986: 0x00c0, 0x3987: 0x00c0, 0x3988: 0x00c0, 0x3989: 0x00c0, 0x398a: 0x00c0, 0x398b: 0x00c0, - 0x398c: 0x00c0, 0x398d: 0x00c0, 0x398e: 0x00c0, 0x398f: 0x00c0, 0x3990: 0x00c0, 0x3991: 0x00c0, - 0x3992: 0x00c0, 0x3993: 0x00c0, 0x3994: 0x00c0, 0x3995: 0x00c0, 0x3996: 0x00c0, 0x3997: 0x00c0, - 0x3998: 0x00c0, 0x3999: 0x00c0, 0x399a: 0x00c0, 0x399b: 0x00c0, 0x399c: 0x00c0, 0x399d: 0x00c0, - 0x399e: 0x00c0, 0x399f: 0x00c0, 0x39a0: 0x00c0, 0x39a1: 0x00c0, 0x39a2: 0x00c0, 0x39a3: 0x00c0, - 0x39a4: 0x00c0, 0x39a5: 0x00c0, 0x39a6: 0x00c0, 0x39a7: 0x00c3, 0x39a8: 0x00c3, 0x39a9: 0x00c3, - 0x39aa: 0x00c3, 0x39ab: 0x00c3, 0x39ac: 0x00c0, 0x39ad: 0x00c3, 0x39ae: 0x00c3, 0x39af: 0x00c3, - 0x39b0: 0x00c3, 0x39b1: 0x00c3, 0x39b2: 0x00c3, 0x39b3: 0x00c6, 0x39b4: 0x00c6, - 0x39b6: 0x00c0, 0x39b7: 0x00c0, 0x39b8: 0x00c0, 0x39b9: 0x00c0, 0x39ba: 0x00c0, 0x39bb: 0x00c0, - 0x39bc: 0x00c0, 0x39bd: 0x00c0, 0x39be: 0x00c0, 0x39bf: 0x00c0, - // Block 0xe7, offset 0x39c0 - 0x39c0: 0x0080, 0x39c1: 0x0080, 0x39c2: 0x0080, 0x39c3: 0x0080, - 0x39d0: 0x00c0, 0x39d1: 0x00c0, - 0x39d2: 0x00c0, 0x39d3: 0x00c0, 0x39d4: 0x00c0, 0x39d5: 0x00c0, 0x39d6: 0x00c0, 0x39d7: 0x00c0, - 0x39d8: 0x00c0, 0x39d9: 0x00c0, 0x39da: 0x00c0, 0x39db: 0x00c0, 0x39dc: 0x00c0, 0x39dd: 0x00c0, - 0x39de: 0x00c0, 0x39df: 0x00c0, 0x39e0: 0x00c0, 0x39e1: 0x00c0, 0x39e2: 0x00c0, 0x39e3: 0x00c0, - 0x39e4: 0x00c0, 0x39e5: 0x00c0, 0x39e6: 0x00c0, 0x39e7: 0x00c0, 0x39e8: 0x00c0, 0x39e9: 0x00c0, - 0x39ea: 0x00c0, 0x39eb: 0x00c0, 0x39ec: 0x00c0, 0x39ed: 0x00c0, 0x39ee: 0x00c0, 0x39ef: 0x00c0, - 0x39f0: 0x00c0, 0x39f1: 0x00c0, 0x39f2: 0x00c0, 0x39f3: 0x00c3, 0x39f4: 0x0080, 0x39f5: 0x0080, - 0x39f6: 0x00c0, - // Block 0xe8, offset 0x3a00 - 0x3a00: 0x00c3, 0x3a01: 0x00c3, 0x3a02: 0x00c0, 0x3a03: 0x00c0, 0x3a04: 0x00c0, 0x3a05: 0x00c0, - 0x3a06: 0x00c0, 0x3a07: 0x00c0, 0x3a08: 0x00c0, 0x3a09: 0x00c0, 0x3a0a: 0x00c0, 0x3a0b: 0x00c0, - 0x3a0c: 0x00c0, 0x3a0d: 0x00c0, 0x3a0e: 0x00c0, 0x3a0f: 0x00c0, 0x3a10: 0x00c0, 0x3a11: 0x00c0, - 0x3a12: 0x00c0, 0x3a13: 0x00c0, 0x3a14: 0x00c0, 0x3a15: 0x00c0, 0x3a16: 0x00c0, 0x3a17: 0x00c0, - 0x3a18: 0x00c0, 0x3a19: 0x00c0, 0x3a1a: 0x00c0, 0x3a1b: 0x00c0, 0x3a1c: 0x00c0, 0x3a1d: 0x00c0, - 0x3a1e: 0x00c0, 0x3a1f: 0x00c0, 0x3a20: 0x00c0, 0x3a21: 0x00c0, 0x3a22: 0x00c0, 0x3a23: 0x00c0, - 0x3a24: 0x00c0, 0x3a25: 0x00c0, 0x3a26: 0x00c0, 0x3a27: 0x00c0, 0x3a28: 0x00c0, 0x3a29: 0x00c0, - 0x3a2a: 0x00c0, 0x3a2b: 0x00c0, 0x3a2c: 0x00c0, 0x3a2d: 0x00c0, 0x3a2e: 0x00c0, 0x3a2f: 0x00c0, - 0x3a30: 0x00c0, 0x3a31: 0x00c0, 0x3a32: 0x00c0, 0x3a33: 0x00c0, 0x3a34: 0x00c0, 0x3a35: 0x00c0, - 0x3a36: 0x00c3, 0x3a37: 0x00c3, 0x3a38: 0x00c3, 0x3a39: 0x00c3, 0x3a3a: 0x00c3, 0x3a3b: 0x00c3, - 0x3a3c: 0x00c3, 0x3a3d: 0x00c3, 0x3a3e: 0x00c3, 0x3a3f: 0x00c0, - // Block 0xe9, offset 0x3a40 - 0x3a40: 0x00c5, 0x3a41: 0x00c0, 0x3a42: 0x00c0, 0x3a43: 0x00c0, 0x3a44: 0x00c0, 0x3a45: 0x0080, - 0x3a46: 0x0080, 0x3a47: 0x0080, 0x3a48: 0x0080, 0x3a49: 0x0080, 0x3a4a: 0x00c3, 0x3a4b: 0x00c3, - 0x3a4c: 0x00c3, 0x3a4d: 0x0080, 0x3a50: 0x00c0, 0x3a51: 0x00c0, - 0x3a52: 0x00c0, 0x3a53: 0x00c0, 0x3a54: 0x00c0, 0x3a55: 0x00c0, 0x3a56: 0x00c0, 0x3a57: 0x00c0, - 0x3a58: 0x00c0, 0x3a59: 0x00c0, 0x3a5a: 0x00c0, 0x3a5b: 0x0080, 0x3a5c: 0x00c0, 0x3a5d: 0x0080, - 0x3a5e: 0x0080, 0x3a5f: 0x0080, 0x3a61: 0x0080, 0x3a62: 0x0080, 0x3a63: 0x0080, - 0x3a64: 0x0080, 0x3a65: 0x0080, 0x3a66: 0x0080, 0x3a67: 0x0080, 0x3a68: 0x0080, 0x3a69: 0x0080, - 0x3a6a: 0x0080, 0x3a6b: 0x0080, 0x3a6c: 0x0080, 0x3a6d: 0x0080, 0x3a6e: 0x0080, 0x3a6f: 0x0080, - 0x3a70: 0x0080, 0x3a71: 0x0080, 0x3a72: 0x0080, 0x3a73: 0x0080, 0x3a74: 0x0080, - // Block 0xea, offset 0x3a80 - 0x3a80: 0x00c0, 0x3a81: 0x00c0, 0x3a82: 0x00c0, 0x3a83: 0x00c0, 0x3a84: 0x00c0, 0x3a85: 0x00c0, - 0x3a86: 0x00c0, 0x3a87: 0x00c0, 0x3a88: 0x00c0, 0x3a89: 0x00c0, 0x3a8a: 0x00c0, 0x3a8b: 0x00c0, - 0x3a8c: 0x00c0, 0x3a8d: 0x00c0, 0x3a8e: 0x00c0, 0x3a8f: 0x00c0, 0x3a90: 0x00c0, 0x3a91: 0x00c0, - 0x3a93: 0x00c0, 0x3a94: 0x00c0, 0x3a95: 0x00c0, 0x3a96: 0x00c0, 0x3a97: 0x00c0, - 0x3a98: 0x00c0, 0x3a99: 0x00c0, 0x3a9a: 0x00c0, 0x3a9b: 0x00c0, 0x3a9c: 0x00c0, 0x3a9d: 0x00c0, - 0x3a9e: 0x00c0, 0x3a9f: 0x00c0, 0x3aa0: 0x00c0, 0x3aa1: 0x00c0, 0x3aa2: 0x00c0, 0x3aa3: 0x00c0, - 0x3aa4: 0x00c0, 0x3aa5: 0x00c0, 0x3aa6: 0x00c0, 0x3aa7: 0x00c0, 0x3aa8: 0x00c0, 0x3aa9: 0x00c0, - 0x3aaa: 0x00c0, 0x3aab: 0x00c0, 0x3aac: 0x00c0, 0x3aad: 0x00c0, 0x3aae: 0x00c0, 0x3aaf: 0x00c3, - 0x3ab0: 0x00c3, 0x3ab1: 0x00c3, 0x3ab2: 0x00c0, 0x3ab3: 0x00c0, 0x3ab4: 0x00c3, 0x3ab5: 0x00c5, - 0x3ab6: 0x00c3, 0x3ab7: 0x00c3, 0x3ab8: 0x0080, 0x3ab9: 0x0080, 0x3aba: 0x0080, 0x3abb: 0x0080, - 0x3abc: 0x0080, 0x3abd: 0x0080, 0x3abe: 0x00c3, - // Block 0xeb, offset 0x3ac0 - 0x3ac0: 0x00c0, 0x3ac1: 0x00c0, 0x3ac2: 0x00c0, 0x3ac3: 0x00c0, 0x3ac4: 0x00c0, 0x3ac5: 0x00c0, - 0x3ac6: 0x00c0, 0x3ac8: 0x00c0, 0x3aca: 0x00c0, 0x3acb: 0x00c0, - 0x3acc: 0x00c0, 0x3acd: 0x00c0, 0x3acf: 0x00c0, 0x3ad0: 0x00c0, 0x3ad1: 0x00c0, - 0x3ad2: 0x00c0, 0x3ad3: 0x00c0, 0x3ad4: 0x00c0, 0x3ad5: 0x00c0, 0x3ad6: 0x00c0, 0x3ad7: 0x00c0, - 0x3ad8: 0x00c0, 0x3ad9: 0x00c0, 0x3ada: 0x00c0, 0x3adb: 0x00c0, 0x3adc: 0x00c0, 0x3add: 0x00c0, - 0x3adf: 0x00c0, 0x3ae0: 0x00c0, 0x3ae1: 0x00c0, 0x3ae2: 0x00c0, 0x3ae3: 0x00c0, - 0x3ae4: 0x00c0, 0x3ae5: 0x00c0, 0x3ae6: 0x00c0, 0x3ae7: 0x00c0, 0x3ae8: 0x00c0, 0x3ae9: 0x0080, - 0x3af0: 0x00c0, 0x3af1: 0x00c0, 0x3af2: 0x00c0, 0x3af3: 0x00c0, 0x3af4: 0x00c0, 0x3af5: 0x00c0, - 0x3af6: 0x00c0, 0x3af7: 0x00c0, 0x3af8: 0x00c0, 0x3af9: 0x00c0, 0x3afa: 0x00c0, 0x3afb: 0x00c0, - 0x3afc: 0x00c0, 0x3afd: 0x00c0, 0x3afe: 0x00c0, 0x3aff: 0x00c0, - // Block 0xec, offset 0x3b00 - 0x3b00: 0x00c0, 0x3b01: 0x00c0, 0x3b02: 0x00c0, 0x3b03: 0x00c0, 0x3b04: 0x00c0, 0x3b05: 0x00c0, - 0x3b06: 0x00c0, 0x3b07: 0x00c0, 0x3b08: 0x00c0, 0x3b09: 0x00c0, 0x3b0a: 0x00c0, 0x3b0b: 0x00c0, - 0x3b0c: 0x00c0, 0x3b0d: 0x00c0, 0x3b0e: 0x00c0, 0x3b0f: 0x00c0, 0x3b10: 0x00c0, 0x3b11: 0x00c0, - 0x3b12: 0x00c0, 0x3b13: 0x00c0, 0x3b14: 0x00c0, 0x3b15: 0x00c0, 0x3b16: 0x00c0, 0x3b17: 0x00c0, - 0x3b18: 0x00c0, 0x3b19: 0x00c0, 0x3b1a: 0x00c0, 0x3b1b: 0x00c0, 0x3b1c: 0x00c0, 0x3b1d: 0x00c0, - 0x3b1e: 0x00c0, 0x3b1f: 0x00c3, 0x3b20: 0x00c0, 0x3b21: 0x00c0, 0x3b22: 0x00c0, 0x3b23: 0x00c3, - 0x3b24: 0x00c3, 0x3b25: 0x00c3, 0x3b26: 0x00c3, 0x3b27: 0x00c3, 0x3b28: 0x00c3, 0x3b29: 0x00c3, - 0x3b2a: 0x00c6, - 0x3b30: 0x00c0, 0x3b31: 0x00c0, 0x3b32: 0x00c0, 0x3b33: 0x00c0, 0x3b34: 0x00c0, 0x3b35: 0x00c0, - 0x3b36: 0x00c0, 0x3b37: 0x00c0, 0x3b38: 0x00c0, 0x3b39: 0x00c0, - // Block 0xed, offset 0x3b40 - 0x3b40: 0x00c3, 0x3b41: 0x00c3, 0x3b42: 0x00c0, 0x3b43: 0x00c0, 0x3b45: 0x00c0, - 0x3b46: 0x00c0, 0x3b47: 0x00c0, 0x3b48: 0x00c0, 0x3b49: 0x00c0, 0x3b4a: 0x00c0, 0x3b4b: 0x00c0, - 0x3b4c: 0x00c0, 0x3b4f: 0x00c0, 0x3b50: 0x00c0, - 0x3b53: 0x00c0, 0x3b54: 0x00c0, 0x3b55: 0x00c0, 0x3b56: 0x00c0, 0x3b57: 0x00c0, - 0x3b58: 0x00c0, 0x3b59: 0x00c0, 0x3b5a: 0x00c0, 0x3b5b: 0x00c0, 0x3b5c: 0x00c0, 0x3b5d: 0x00c0, - 0x3b5e: 0x00c0, 0x3b5f: 0x00c0, 0x3b60: 0x00c0, 0x3b61: 0x00c0, 0x3b62: 0x00c0, 0x3b63: 0x00c0, - 0x3b64: 0x00c0, 0x3b65: 0x00c0, 0x3b66: 0x00c0, 0x3b67: 0x00c0, 0x3b68: 0x00c0, - 0x3b6a: 0x00c0, 0x3b6b: 0x00c0, 0x3b6c: 0x00c0, 0x3b6d: 0x00c0, 0x3b6e: 0x00c0, 0x3b6f: 0x00c0, - 0x3b70: 0x00c0, 0x3b72: 0x00c0, 0x3b73: 0x00c0, 0x3b75: 0x00c0, - 0x3b76: 0x00c0, 0x3b77: 0x00c0, 0x3b78: 0x00c0, 0x3b79: 0x00c0, - 0x3b7c: 0x00c3, 0x3b7d: 0x00c0, 0x3b7e: 0x00c0, 0x3b7f: 0x00c0, - // Block 0xee, offset 0x3b80 - 0x3b80: 0x00c3, 0x3b81: 0x00c0, 0x3b82: 0x00c0, 0x3b83: 0x00c0, 0x3b84: 0x00c0, - 0x3b87: 0x00c0, 0x3b88: 0x00c0, 0x3b8b: 0x00c0, - 0x3b8c: 0x00c0, 0x3b8d: 0x00c5, 0x3b90: 0x00c0, - 0x3b97: 0x00c0, - 0x3b9d: 0x00c0, - 0x3b9e: 0x00c0, 0x3b9f: 0x00c0, 0x3ba0: 0x00c0, 0x3ba1: 0x00c0, 0x3ba2: 0x00c0, 0x3ba3: 0x00c0, - 0x3ba6: 0x00c3, 0x3ba7: 0x00c3, 0x3ba8: 0x00c3, 0x3ba9: 0x00c3, - 0x3baa: 0x00c3, 0x3bab: 0x00c3, 0x3bac: 0x00c3, - 0x3bb0: 0x00c3, 0x3bb1: 0x00c3, 0x3bb2: 0x00c3, 0x3bb3: 0x00c3, 0x3bb4: 0x00c3, - // Block 0xef, offset 0x3bc0 - 0x3bc0: 0x00c0, 0x3bc1: 0x00c0, 0x3bc2: 0x00c0, 0x3bc3: 0x00c0, 0x3bc4: 0x00c0, 0x3bc5: 0x00c0, - 0x3bc6: 0x00c0, 0x3bc7: 0x00c0, 0x3bc8: 0x00c0, 0x3bc9: 0x00c0, 0x3bca: 0x00c0, 0x3bcb: 0x00c0, - 0x3bcc: 0x00c0, 0x3bcd: 0x00c0, 0x3bce: 0x00c0, 0x3bcf: 0x00c0, 0x3bd0: 0x00c0, 0x3bd1: 0x00c0, - 0x3bd2: 0x00c0, 0x3bd3: 0x00c0, 0x3bd4: 0x00c0, 0x3bd5: 0x00c0, 0x3bd6: 0x00c0, 0x3bd7: 0x00c0, - 0x3bd8: 0x00c0, 0x3bd9: 0x00c0, 0x3bda: 0x00c0, 0x3bdb: 0x00c0, 0x3bdc: 0x00c0, 0x3bdd: 0x00c0, - 0x3bde: 0x00c0, 0x3bdf: 0x00c0, 0x3be0: 0x00c0, 0x3be1: 0x00c0, 0x3be2: 0x00c0, 0x3be3: 0x00c0, - 0x3be4: 0x00c0, 0x3be5: 0x00c0, 0x3be6: 0x00c0, 0x3be7: 0x00c0, 0x3be8: 0x00c0, 0x3be9: 0x00c0, - 0x3bea: 0x00c0, 0x3beb: 0x00c0, 0x3bec: 0x00c0, 0x3bed: 0x00c0, 0x3bee: 0x00c0, 0x3bef: 0x00c0, - 0x3bf0: 0x00c0, 0x3bf1: 0x00c0, 0x3bf2: 0x00c0, 0x3bf3: 0x00c0, 0x3bf4: 0x00c0, 0x3bf5: 0x00c0, - 0x3bf6: 0x00c0, 0x3bf7: 0x00c0, 0x3bf8: 0x00c3, 0x3bf9: 0x00c3, 0x3bfa: 0x00c3, 0x3bfb: 0x00c3, - 0x3bfc: 0x00c3, 0x3bfd: 0x00c3, 0x3bfe: 0x00c3, 0x3bff: 0x00c3, - // Block 0xf0, offset 0x3c00 - 0x3c00: 0x00c0, 0x3c01: 0x00c0, 0x3c02: 0x00c6, 0x3c03: 0x00c3, 0x3c04: 0x00c3, 0x3c05: 0x00c0, - 0x3c06: 0x00c3, 0x3c07: 0x00c0, 0x3c08: 0x00c0, 0x3c09: 0x00c0, 0x3c0a: 0x00c0, 0x3c0b: 0x0080, - 0x3c0c: 0x0080, 0x3c0d: 0x0080, 0x3c0e: 0x0080, 0x3c0f: 0x0080, 0x3c10: 0x00c0, 0x3c11: 0x00c0, - 0x3c12: 0x00c0, 0x3c13: 0x00c0, 0x3c14: 0x00c0, 0x3c15: 0x00c0, 0x3c16: 0x00c0, 0x3c17: 0x00c0, - 0x3c18: 0x00c0, 0x3c19: 0x00c0, 0x3c1b: 0x0080, 0x3c1d: 0x0080, - // Block 0xf1, offset 0x3c40 - 0x3c40: 0x00c0, 0x3c41: 0x00c0, 0x3c42: 0x00c0, 0x3c43: 0x00c0, 0x3c44: 0x00c0, 0x3c45: 0x00c0, - 0x3c46: 0x00c0, 0x3c47: 0x00c0, 0x3c48: 0x00c0, 0x3c49: 0x00c0, 0x3c4a: 0x00c0, 0x3c4b: 0x00c0, - 0x3c4c: 0x00c0, 0x3c4d: 0x00c0, 0x3c4e: 0x00c0, 0x3c4f: 0x00c0, 0x3c50: 0x00c0, 0x3c51: 0x00c0, - 0x3c52: 0x00c0, 0x3c53: 0x00c0, 0x3c54: 0x00c0, 0x3c55: 0x00c0, 0x3c56: 0x00c0, 0x3c57: 0x00c0, - 0x3c58: 0x00c0, 0x3c59: 0x00c0, 0x3c5a: 0x00c0, 0x3c5b: 0x00c0, 0x3c5c: 0x00c0, 0x3c5d: 0x00c0, - 0x3c5e: 0x00c0, 0x3c5f: 0x00c0, 0x3c60: 0x00c0, 0x3c61: 0x00c0, 0x3c62: 0x00c0, 0x3c63: 0x00c0, - 0x3c64: 0x00c0, 0x3c65: 0x00c0, 0x3c66: 0x00c0, 0x3c67: 0x00c0, 0x3c68: 0x00c0, 0x3c69: 0x00c0, - 0x3c6a: 0x00c0, 0x3c6b: 0x00c0, 0x3c6c: 0x00c0, 0x3c6d: 0x00c0, 0x3c6e: 0x00c0, 0x3c6f: 0x00c0, - 0x3c70: 0x00c0, 0x3c71: 0x00c0, 0x3c72: 0x00c0, 0x3c73: 0x00c3, 0x3c74: 0x00c3, 0x3c75: 0x00c3, - 0x3c76: 0x00c3, 0x3c77: 0x00c3, 0x3c78: 0x00c3, 0x3c79: 0x00c0, 0x3c7a: 0x00c3, 0x3c7b: 0x00c0, - 0x3c7c: 0x00c0, 0x3c7d: 0x00c0, 0x3c7e: 0x00c0, 0x3c7f: 0x00c3, - // Block 0xf2, offset 0x3c80 - 0x3c80: 0x00c3, 0x3c81: 0x00c0, 0x3c82: 0x00c6, 0x3c83: 0x00c3, 0x3c84: 0x00c0, 0x3c85: 0x00c0, - 0x3c86: 0x0080, 0x3c87: 0x00c0, - 0x3c90: 0x00c0, 0x3c91: 0x00c0, - 0x3c92: 0x00c0, 0x3c93: 0x00c0, 0x3c94: 0x00c0, 0x3c95: 0x00c0, 0x3c96: 0x00c0, 0x3c97: 0x00c0, - 0x3c98: 0x00c0, 0x3c99: 0x00c0, - // Block 0xf3, offset 0x3cc0 - 0x3cc0: 0x00c0, 0x3cc1: 0x00c0, 0x3cc2: 0x00c0, 0x3cc3: 0x00c0, 0x3cc4: 0x00c0, 0x3cc5: 0x00c0, - 0x3cc6: 0x00c0, 0x3cc7: 0x00c0, 0x3cc8: 0x00c0, 0x3cc9: 0x00c0, 0x3cca: 0x00c0, 0x3ccb: 0x00c0, - 0x3ccc: 0x00c0, 0x3ccd: 0x00c0, 0x3cce: 0x00c0, 0x3ccf: 0x00c0, 0x3cd0: 0x00c0, 0x3cd1: 0x00c0, - 0x3cd2: 0x00c0, 0x3cd3: 0x00c0, 0x3cd4: 0x00c0, 0x3cd5: 0x00c0, 0x3cd6: 0x00c0, 0x3cd7: 0x00c0, - 0x3cd8: 0x00c0, 0x3cd9: 0x00c0, 0x3cda: 0x00c0, 0x3cdb: 0x00c0, 0x3cdc: 0x00c0, 0x3cdd: 0x00c0, - 0x3cde: 0x00c0, 0x3cdf: 0x00c0, 0x3ce0: 0x00c0, 0x3ce1: 0x00c0, 0x3ce2: 0x00c0, 0x3ce3: 0x00c0, - 0x3ce4: 0x00c0, 0x3ce5: 0x00c0, 0x3ce6: 0x00c0, 0x3ce7: 0x00c0, 0x3ce8: 0x00c0, 0x3ce9: 0x00c0, - 0x3cea: 0x00c0, 0x3ceb: 0x00c0, 0x3cec: 0x00c0, 0x3ced: 0x00c0, 0x3cee: 0x00c0, 0x3cef: 0x00c0, - 0x3cf0: 0x00c0, 0x3cf1: 0x00c0, 0x3cf2: 0x00c3, 0x3cf3: 0x00c3, 0x3cf4: 0x00c3, 0x3cf5: 0x00c3, - 0x3cf8: 0x00c0, 0x3cf9: 0x00c0, 0x3cfa: 0x00c0, 0x3cfb: 0x00c0, - 0x3cfc: 0x00c3, 0x3cfd: 0x00c3, 0x3cfe: 0x00c0, 0x3cff: 0x00c6, - // Block 0xf4, offset 0x3d00 - 0x3d00: 0x00c3, 0x3d01: 0x0080, 0x3d02: 0x0080, 0x3d03: 0x0080, 0x3d04: 0x0080, 0x3d05: 0x0080, - 0x3d06: 0x0080, 0x3d07: 0x0080, 0x3d08: 0x0080, 0x3d09: 0x0080, 0x3d0a: 0x0080, 0x3d0b: 0x0080, - 0x3d0c: 0x0080, 0x3d0d: 0x0080, 0x3d0e: 0x0080, 0x3d0f: 0x0080, 0x3d10: 0x0080, 0x3d11: 0x0080, - 0x3d12: 0x0080, 0x3d13: 0x0080, 0x3d14: 0x0080, 0x3d15: 0x0080, 0x3d16: 0x0080, 0x3d17: 0x0080, - 0x3d18: 0x00c0, 0x3d19: 0x00c0, 0x3d1a: 0x00c0, 0x3d1b: 0x00c0, 0x3d1c: 0x00c3, 0x3d1d: 0x00c3, - // Block 0xf5, offset 0x3d40 - 0x3d40: 0x00c0, 0x3d41: 0x00c0, 0x3d42: 0x00c0, 0x3d43: 0x00c0, 0x3d44: 0x00c0, 0x3d45: 0x00c0, - 0x3d46: 0x00c0, 0x3d47: 0x00c0, 0x3d48: 0x00c0, 0x3d49: 0x00c0, 0x3d4a: 0x00c0, 0x3d4b: 0x00c0, - 0x3d4c: 0x00c0, 0x3d4d: 0x00c0, 0x3d4e: 0x00c0, 0x3d4f: 0x00c0, 0x3d50: 0x00c0, 0x3d51: 0x00c0, - 0x3d52: 0x00c0, 0x3d53: 0x00c0, 0x3d54: 0x00c0, 0x3d55: 0x00c0, 0x3d56: 0x00c0, 0x3d57: 0x00c0, - 0x3d58: 0x00c0, 0x3d59: 0x00c0, 0x3d5a: 0x00c0, 0x3d5b: 0x00c0, 0x3d5c: 0x00c0, 0x3d5d: 0x00c0, - 0x3d5e: 0x00c0, 0x3d5f: 0x00c0, 0x3d60: 0x00c0, 0x3d61: 0x00c0, 0x3d62: 0x00c0, 0x3d63: 0x00c0, - 0x3d64: 0x00c0, 0x3d65: 0x00c0, 0x3d66: 0x00c0, 0x3d67: 0x00c0, 0x3d68: 0x00c0, 0x3d69: 0x00c0, - 0x3d6a: 0x00c0, 0x3d6b: 0x00c0, 0x3d6c: 0x00c0, 0x3d6d: 0x00c0, 0x3d6e: 0x00c0, 0x3d6f: 0x00c0, - 0x3d70: 0x00c0, 0x3d71: 0x00c0, 0x3d72: 0x00c0, 0x3d73: 0x00c3, 0x3d74: 0x00c3, 0x3d75: 0x00c3, - 0x3d76: 0x00c3, 0x3d77: 0x00c3, 0x3d78: 0x00c3, 0x3d79: 0x00c3, 0x3d7a: 0x00c3, 0x3d7b: 0x00c0, - 0x3d7c: 0x00c0, 0x3d7d: 0x00c3, 0x3d7e: 0x00c0, 0x3d7f: 0x00c6, - // Block 0xf6, offset 0x3d80 - 0x3d80: 0x00c3, 0x3d81: 0x0080, 0x3d82: 0x0080, 0x3d83: 0x0080, 0x3d84: 0x00c0, - 0x3d90: 0x00c0, 0x3d91: 0x00c0, - 0x3d92: 0x00c0, 0x3d93: 0x00c0, 0x3d94: 0x00c0, 0x3d95: 0x00c0, 0x3d96: 0x00c0, 0x3d97: 0x00c0, - 0x3d98: 0x00c0, 0x3d99: 0x00c0, - 0x3da0: 0x0080, 0x3da1: 0x0080, 0x3da2: 0x0080, 0x3da3: 0x0080, - 0x3da4: 0x0080, 0x3da5: 0x0080, 0x3da6: 0x0080, 0x3da7: 0x0080, 0x3da8: 0x0080, 0x3da9: 0x0080, - 0x3daa: 0x0080, 0x3dab: 0x0080, 0x3dac: 0x0080, - // Block 0xf7, offset 0x3dc0 - 0x3dc0: 0x00c0, 0x3dc1: 0x00c0, 0x3dc2: 0x00c0, 0x3dc3: 0x00c0, 0x3dc4: 0x00c0, 0x3dc5: 0x00c0, - 0x3dc6: 0x00c0, 0x3dc7: 0x00c0, 0x3dc8: 0x00c0, 0x3dc9: 0x00c0, 0x3dca: 0x00c0, 0x3dcb: 0x00c0, - 0x3dcc: 0x00c0, 0x3dcd: 0x00c0, 0x3dce: 0x00c0, 0x3dcf: 0x00c0, 0x3dd0: 0x00c0, 0x3dd1: 0x00c0, - 0x3dd2: 0x00c0, 0x3dd3: 0x00c0, 0x3dd4: 0x00c0, 0x3dd5: 0x00c0, 0x3dd6: 0x00c0, 0x3dd7: 0x00c0, - 0x3dd8: 0x00c0, 0x3dd9: 0x00c0, 0x3dda: 0x00c0, 0x3ddb: 0x00c0, 0x3ddc: 0x00c0, 0x3ddd: 0x00c0, - 0x3dde: 0x00c0, 0x3ddf: 0x00c0, 0x3de0: 0x00c0, 0x3de1: 0x00c0, 0x3de2: 0x00c0, 0x3de3: 0x00c0, - 0x3de4: 0x00c0, 0x3de5: 0x00c0, 0x3de6: 0x00c0, 0x3de7: 0x00c0, 0x3de8: 0x00c0, 0x3de9: 0x00c0, - 0x3dea: 0x00c0, 0x3deb: 0x00c3, 0x3dec: 0x00c0, 0x3ded: 0x00c3, 0x3dee: 0x00c0, 0x3def: 0x00c0, - 0x3df0: 0x00c3, 0x3df1: 0x00c3, 0x3df2: 0x00c3, 0x3df3: 0x00c3, 0x3df4: 0x00c3, 0x3df5: 0x00c3, - 0x3df6: 0x00c5, 0x3df7: 0x00c3, - // Block 0xf8, offset 0x3e00 - 0x3e00: 0x00c0, 0x3e01: 0x00c0, 0x3e02: 0x00c0, 0x3e03: 0x00c0, 0x3e04: 0x00c0, 0x3e05: 0x00c0, - 0x3e06: 0x00c0, 0x3e07: 0x00c0, 0x3e08: 0x00c0, 0x3e09: 0x00c0, - // Block 0xf9, offset 0x3e40 - 0x3e40: 0x00c0, 0x3e41: 0x00c0, 0x3e42: 0x00c0, 0x3e43: 0x00c0, 0x3e44: 0x00c0, 0x3e45: 0x00c0, - 0x3e46: 0x00c0, 0x3e47: 0x00c0, 0x3e48: 0x00c0, 0x3e49: 0x00c0, 0x3e4a: 0x00c0, 0x3e4b: 0x00c0, - 0x3e4c: 0x00c0, 0x3e4d: 0x00c0, 0x3e4e: 0x00c0, 0x3e4f: 0x00c0, 0x3e50: 0x00c0, 0x3e51: 0x00c0, - 0x3e52: 0x00c0, 0x3e53: 0x00c0, 0x3e54: 0x00c0, 0x3e55: 0x00c0, 0x3e56: 0x00c0, 0x3e57: 0x00c0, - 0x3e58: 0x00c0, 0x3e59: 0x00c0, 0x3e5d: 0x00c3, - 0x3e5e: 0x00c3, 0x3e5f: 0x00c3, 0x3e60: 0x00c0, 0x3e61: 0x00c0, 0x3e62: 0x00c3, 0x3e63: 0x00c3, - 0x3e64: 0x00c3, 0x3e65: 0x00c3, 0x3e66: 0x00c0, 0x3e67: 0x00c3, 0x3e68: 0x00c3, 0x3e69: 0x00c3, - 0x3e6a: 0x00c3, 0x3e6b: 0x00c6, - 0x3e70: 0x00c0, 0x3e71: 0x00c0, 0x3e72: 0x00c0, 0x3e73: 0x00c0, 0x3e74: 0x00c0, 0x3e75: 0x00c0, - 0x3e76: 0x00c0, 0x3e77: 0x00c0, 0x3e78: 0x00c0, 0x3e79: 0x00c0, 0x3e7a: 0x0080, 0x3e7b: 0x0080, - 0x3e7c: 0x0080, 0x3e7d: 0x0080, 0x3e7e: 0x0080, 0x3e7f: 0x0080, - // Block 0xfa, offset 0x3e80 - 0x3ea0: 0x00c0, 0x3ea1: 0x00c0, 0x3ea2: 0x00c0, 0x3ea3: 0x00c0, - 0x3ea4: 0x00c0, 0x3ea5: 0x00c0, 0x3ea6: 0x00c0, 0x3ea7: 0x00c0, 0x3ea8: 0x00c0, 0x3ea9: 0x00c0, - 0x3eaa: 0x00c0, 0x3eab: 0x00c0, 0x3eac: 0x00c0, 0x3ead: 0x00c0, 0x3eae: 0x00c0, 0x3eaf: 0x00c0, - 0x3eb0: 0x00c0, 0x3eb1: 0x00c0, 0x3eb2: 0x00c0, 0x3eb3: 0x00c0, 0x3eb4: 0x00c0, 0x3eb5: 0x00c0, - 0x3eb6: 0x00c0, 0x3eb7: 0x00c0, 0x3eb8: 0x00c0, 0x3eb9: 0x00c0, 0x3eba: 0x00c0, 0x3ebb: 0x00c0, - 0x3ebc: 0x00c0, 0x3ebd: 0x00c0, 0x3ebe: 0x00c0, 0x3ebf: 0x00c0, - // Block 0xfb, offset 0x3ec0 - 0x3ec0: 0x00c0, 0x3ec1: 0x00c0, 0x3ec2: 0x00c0, 0x3ec3: 0x00c0, 0x3ec4: 0x00c0, 0x3ec5: 0x00c0, - 0x3ec6: 0x00c0, 0x3ec7: 0x00c0, 0x3ec8: 0x00c0, 0x3ec9: 0x00c0, 0x3eca: 0x00c0, 0x3ecb: 0x00c0, - 0x3ecc: 0x00c0, 0x3ecd: 0x00c0, 0x3ece: 0x00c0, 0x3ecf: 0x00c0, 0x3ed0: 0x00c0, 0x3ed1: 0x00c0, - 0x3ed2: 0x00c0, 0x3ed3: 0x00c0, 0x3ed4: 0x00c0, 0x3ed5: 0x00c0, 0x3ed6: 0x00c0, 0x3ed7: 0x00c0, - 0x3ed8: 0x00c0, 0x3ed9: 0x00c0, 0x3eda: 0x00c0, 0x3edb: 0x00c0, 0x3edc: 0x00c0, 0x3edd: 0x00c0, - 0x3ede: 0x00c0, 0x3edf: 0x00c0, 0x3ee0: 0x00c0, 0x3ee1: 0x00c0, 0x3ee2: 0x00c0, 0x3ee3: 0x00c0, - 0x3ee4: 0x00c0, 0x3ee5: 0x00c0, 0x3ee6: 0x00c0, 0x3ee7: 0x00c0, 0x3ee8: 0x00c0, 0x3ee9: 0x00c0, - 0x3eea: 0x0080, 0x3eeb: 0x0080, 0x3eec: 0x0080, 0x3eed: 0x0080, 0x3eee: 0x0080, 0x3eef: 0x0080, - 0x3ef0: 0x0080, 0x3ef1: 0x0080, 0x3ef2: 0x0080, - 0x3eff: 0x00c0, - // Block 0xfc, offset 0x3f00 - 0x3f00: 0x00c0, 0x3f01: 0x00c0, 0x3f02: 0x00c0, 0x3f03: 0x00c0, 0x3f04: 0x00c0, 0x3f05: 0x00c0, - 0x3f06: 0x00c0, 0x3f07: 0x00c0, 0x3f08: 0x00c0, 0x3f09: 0x00c0, 0x3f0a: 0x00c0, 0x3f0b: 0x00c0, - 0x3f0c: 0x00c0, 0x3f0d: 0x00c0, 0x3f0e: 0x00c0, 0x3f0f: 0x00c0, 0x3f10: 0x00c0, 0x3f11: 0x00c0, - 0x3f12: 0x00c0, 0x3f13: 0x00c0, 0x3f14: 0x00c0, 0x3f15: 0x00c0, 0x3f16: 0x00c0, 0x3f17: 0x00c0, - 0x3f18: 0x00c0, 0x3f19: 0x00c0, 0x3f1a: 0x00c0, 0x3f1b: 0x00c0, 0x3f1c: 0x00c0, 0x3f1d: 0x00c0, - 0x3f1e: 0x00c0, 0x3f1f: 0x00c0, 0x3f20: 0x00c0, 0x3f21: 0x00c0, 0x3f22: 0x00c0, 0x3f23: 0x00c0, - 0x3f24: 0x00c0, 0x3f25: 0x00c0, 0x3f26: 0x00c0, 0x3f27: 0x00c0, 0x3f28: 0x00c0, 0x3f29: 0x00c0, - 0x3f2a: 0x00c0, 0x3f2b: 0x00c0, 0x3f2c: 0x00c0, 0x3f2d: 0x00c0, 0x3f2e: 0x00c0, 0x3f2f: 0x00c0, - 0x3f30: 0x00c0, 0x3f31: 0x00c0, 0x3f32: 0x00c0, 0x3f33: 0x00c0, 0x3f34: 0x00c0, 0x3f35: 0x00c0, - 0x3f36: 0x00c0, 0x3f37: 0x00c0, 0x3f38: 0x00c0, - // Block 0xfd, offset 0x3f40 - 0x3f40: 0x00c0, 0x3f41: 0x00c0, 0x3f42: 0x00c0, 0x3f43: 0x00c0, 0x3f44: 0x00c0, 0x3f45: 0x00c0, - 0x3f46: 0x00c0, 0x3f47: 0x00c0, 0x3f48: 0x00c0, 0x3f4a: 0x00c0, 0x3f4b: 0x00c0, - 0x3f4c: 0x00c0, 0x3f4d: 0x00c0, 0x3f4e: 0x00c0, 0x3f4f: 0x00c0, 0x3f50: 0x00c0, 0x3f51: 0x00c0, - 0x3f52: 0x00c0, 0x3f53: 0x00c0, 0x3f54: 0x00c0, 0x3f55: 0x00c0, 0x3f56: 0x00c0, 0x3f57: 0x00c0, - 0x3f58: 0x00c0, 0x3f59: 0x00c0, 0x3f5a: 0x00c0, 0x3f5b: 0x00c0, 0x3f5c: 0x00c0, 0x3f5d: 0x00c0, - 0x3f5e: 0x00c0, 0x3f5f: 0x00c0, 0x3f60: 0x00c0, 0x3f61: 0x00c0, 0x3f62: 0x00c0, 0x3f63: 0x00c0, - 0x3f64: 0x00c0, 0x3f65: 0x00c0, 0x3f66: 0x00c0, 0x3f67: 0x00c0, 0x3f68: 0x00c0, 0x3f69: 0x00c0, - 0x3f6a: 0x00c0, 0x3f6b: 0x00c0, 0x3f6c: 0x00c0, 0x3f6d: 0x00c0, 0x3f6e: 0x00c0, 0x3f6f: 0x00c0, - 0x3f70: 0x00c3, 0x3f71: 0x00c3, 0x3f72: 0x00c3, 0x3f73: 0x00c3, 0x3f74: 0x00c3, 0x3f75: 0x00c3, - 0x3f76: 0x00c3, 0x3f78: 0x00c3, 0x3f79: 0x00c3, 0x3f7a: 0x00c3, 0x3f7b: 0x00c3, - 0x3f7c: 0x00c3, 0x3f7d: 0x00c3, 0x3f7e: 0x00c0, 0x3f7f: 0x00c6, - // Block 0xfe, offset 0x3f80 - 0x3f80: 0x00c0, 0x3f81: 0x0080, 0x3f82: 0x0080, 0x3f83: 0x0080, 0x3f84: 0x0080, 0x3f85: 0x0080, - 0x3f90: 0x00c0, 0x3f91: 0x00c0, - 0x3f92: 0x00c0, 0x3f93: 0x00c0, 0x3f94: 0x00c0, 0x3f95: 0x00c0, 0x3f96: 0x00c0, 0x3f97: 0x00c0, - 0x3f98: 0x00c0, 0x3f99: 0x00c0, 0x3f9a: 0x0080, 0x3f9b: 0x0080, 0x3f9c: 0x0080, 0x3f9d: 0x0080, - 0x3f9e: 0x0080, 0x3f9f: 0x0080, 0x3fa0: 0x0080, 0x3fa1: 0x0080, 0x3fa2: 0x0080, 0x3fa3: 0x0080, - 0x3fa4: 0x0080, 0x3fa5: 0x0080, 0x3fa6: 0x0080, 0x3fa7: 0x0080, 0x3fa8: 0x0080, 0x3fa9: 0x0080, - 0x3faa: 0x0080, 0x3fab: 0x0080, 0x3fac: 0x0080, - 0x3fb0: 0x0080, 0x3fb1: 0x0080, 0x3fb2: 0x00c0, 0x3fb3: 0x00c0, 0x3fb4: 0x00c0, 0x3fb5: 0x00c0, - 0x3fb6: 0x00c0, 0x3fb7: 0x00c0, 0x3fb8: 0x00c0, 0x3fb9: 0x00c0, 0x3fba: 0x00c0, 0x3fbb: 0x00c0, - 0x3fbc: 0x00c0, 0x3fbd: 0x00c0, 0x3fbe: 0x00c0, 0x3fbf: 0x00c0, - // Block 0xff, offset 0x3fc0 - 0x3fc0: 0x00c0, 0x3fc1: 0x00c0, 0x3fc2: 0x00c0, 0x3fc3: 0x00c0, 0x3fc4: 0x00c0, 0x3fc5: 0x00c0, - 0x3fc6: 0x00c0, 0x3fc7: 0x00c0, 0x3fc8: 0x00c0, 0x3fc9: 0x00c0, 0x3fca: 0x00c0, 0x3fcb: 0x00c0, - 0x3fcc: 0x00c0, 0x3fcd: 0x00c0, 0x3fce: 0x00c0, 0x3fcf: 0x00c0, - 0x3fd2: 0x00c3, 0x3fd3: 0x00c3, 0x3fd4: 0x00c3, 0x3fd5: 0x00c3, 0x3fd6: 0x00c3, 0x3fd7: 0x00c3, - 0x3fd8: 0x00c3, 0x3fd9: 0x00c3, 0x3fda: 0x00c3, 0x3fdb: 0x00c3, 0x3fdc: 0x00c3, 0x3fdd: 0x00c3, - 0x3fde: 0x00c3, 0x3fdf: 0x00c3, 0x3fe0: 0x00c3, 0x3fe1: 0x00c3, 0x3fe2: 0x00c3, 0x3fe3: 0x00c3, - 0x3fe4: 0x00c3, 0x3fe5: 0x00c3, 0x3fe6: 0x00c3, 0x3fe7: 0x00c3, 0x3fe9: 0x00c0, - 0x3fea: 0x00c3, 0x3feb: 0x00c3, 0x3fec: 0x00c3, 0x3fed: 0x00c3, 0x3fee: 0x00c3, 0x3fef: 0x00c3, - 0x3ff0: 0x00c3, 0x3ff1: 0x00c0, 0x3ff2: 0x00c3, 0x3ff3: 0x00c3, 0x3ff4: 0x00c0, 0x3ff5: 0x00c3, - 0x3ff6: 0x00c3, - // Block 0x100, offset 0x4000 - 0x4000: 0x00c0, 0x4001: 0x00c0, 0x4002: 0x00c0, 0x4003: 0x00c0, 0x4004: 0x00c0, 0x4005: 0x00c0, - 0x4006: 0x00c0, 0x4007: 0x00c0, 0x4008: 0x00c0, 0x4009: 0x00c0, 0x400a: 0x00c0, 0x400b: 0x00c0, - 0x400c: 0x00c0, 0x400d: 0x00c0, 0x400e: 0x00c0, 0x400f: 0x00c0, 0x4010: 0x00c0, 0x4011: 0x00c0, - 0x4012: 0x00c0, 0x4013: 0x00c0, 0x4014: 0x00c0, 0x4015: 0x00c0, 0x4016: 0x00c0, 0x4017: 0x00c0, - 0x4018: 0x00c0, 0x4019: 0x00c0, - // Block 0x101, offset 0x4040 - 0x4040: 0x0080, 0x4041: 0x0080, 0x4042: 0x0080, 0x4043: 0x0080, 0x4044: 0x0080, 0x4045: 0x0080, - 0x4046: 0x0080, 0x4047: 0x0080, 0x4048: 0x0080, 0x4049: 0x0080, 0x404a: 0x0080, 0x404b: 0x0080, - 0x404c: 0x0080, 0x404d: 0x0080, 0x404e: 0x0080, 0x404f: 0x0080, 0x4050: 0x0080, 0x4051: 0x0080, - 0x4052: 0x0080, 0x4053: 0x0080, 0x4054: 0x0080, 0x4055: 0x0080, 0x4056: 0x0080, 0x4057: 0x0080, - 0x4058: 0x0080, 0x4059: 0x0080, 0x405a: 0x0080, 0x405b: 0x0080, 0x405c: 0x0080, 0x405d: 0x0080, - 0x405e: 0x0080, 0x405f: 0x0080, 0x4060: 0x0080, 0x4061: 0x0080, 0x4062: 0x0080, 0x4063: 0x0080, - 0x4064: 0x0080, 0x4065: 0x0080, 0x4066: 0x0080, 0x4067: 0x0080, 0x4068: 0x0080, 0x4069: 0x0080, - 0x406a: 0x0080, 0x406b: 0x0080, 0x406c: 0x0080, 0x406d: 0x0080, 0x406e: 0x0080, - 0x4070: 0x0080, 0x4071: 0x0080, 0x4072: 0x0080, 0x4073: 0x0080, 0x4074: 0x0080, - // Block 0x102, offset 0x4080 - 0x4080: 0x00c0, 0x4081: 0x00c0, 0x4082: 0x00c0, 0x4083: 0x00c0, - // Block 0x103, offset 0x40c0 - 0x40c0: 0x00c0, 0x40c1: 0x00c0, 0x40c2: 0x00c0, 0x40c3: 0x00c0, 0x40c4: 0x00c0, 0x40c5: 0x00c0, - 0x40c6: 0x00c0, 0x40c7: 0x00c0, 0x40c8: 0x00c0, 0x40c9: 0x00c0, 0x40ca: 0x00c0, 0x40cb: 0x00c0, - 0x40cc: 0x00c0, 0x40cd: 0x00c0, 0x40ce: 0x00c0, 0x40cf: 0x00c0, 0x40d0: 0x00c0, 0x40d1: 0x00c0, - 0x40d2: 0x00c0, 0x40d3: 0x00c0, 0x40d4: 0x00c0, 0x40d5: 0x00c0, 0x40d6: 0x00c0, 0x40d7: 0x00c0, - 0x40d8: 0x00c0, 0x40d9: 0x00c0, 0x40da: 0x00c0, 0x40db: 0x00c0, 0x40dc: 0x00c0, 0x40dd: 0x00c0, - 0x40de: 0x00c0, 0x40df: 0x00c0, 0x40e0: 0x00c0, 0x40e1: 0x00c0, 0x40e2: 0x00c0, 0x40e3: 0x00c0, - 0x40e4: 0x00c0, 0x40e5: 0x00c0, 0x40e6: 0x00c0, 0x40e7: 0x00c0, 0x40e8: 0x00c0, 0x40e9: 0x00c0, - 0x40ea: 0x00c0, 0x40eb: 0x00c0, 0x40ec: 0x00c0, 0x40ed: 0x00c0, 0x40ee: 0x00c0, - // Block 0x104, offset 0x4100 - 0x4100: 0x00c0, 0x4101: 0x00c0, 0x4102: 0x00c0, 0x4103: 0x00c0, 0x4104: 0x00c0, 0x4105: 0x00c0, - 0x4106: 0x00c0, - // Block 0x105, offset 0x4140 - 0x4140: 0x00c0, 0x4141: 0x00c0, 0x4142: 0x00c0, 0x4143: 0x00c0, 0x4144: 0x00c0, 0x4145: 0x00c0, - 0x4146: 0x00c0, 0x4147: 0x00c0, 0x4148: 0x00c0, 0x4149: 0x00c0, 0x414a: 0x00c0, 0x414b: 0x00c0, - 0x414c: 0x00c0, 0x414d: 0x00c0, 0x414e: 0x00c0, 0x414f: 0x00c0, 0x4150: 0x00c0, 0x4151: 0x00c0, - 0x4152: 0x00c0, 0x4153: 0x00c0, 0x4154: 0x00c0, 0x4155: 0x00c0, 0x4156: 0x00c0, 0x4157: 0x00c0, - 0x4158: 0x00c0, 0x4159: 0x00c0, 0x415a: 0x00c0, 0x415b: 0x00c0, 0x415c: 0x00c0, 0x415d: 0x00c0, - 0x415e: 0x00c0, 0x4160: 0x00c0, 0x4161: 0x00c0, 0x4162: 0x00c0, 0x4163: 0x00c0, - 0x4164: 0x00c0, 0x4165: 0x00c0, 0x4166: 0x00c0, 0x4167: 0x00c0, 0x4168: 0x00c0, 0x4169: 0x00c0, - 0x416e: 0x0080, 0x416f: 0x0080, - // Block 0x106, offset 0x4180 - 0x4190: 0x00c0, 0x4191: 0x00c0, - 0x4192: 0x00c0, 0x4193: 0x00c0, 0x4194: 0x00c0, 0x4195: 0x00c0, 0x4196: 0x00c0, 0x4197: 0x00c0, - 0x4198: 0x00c0, 0x4199: 0x00c0, 0x419a: 0x00c0, 0x419b: 0x00c0, 0x419c: 0x00c0, 0x419d: 0x00c0, - 0x419e: 0x00c0, 0x419f: 0x00c0, 0x41a0: 0x00c0, 0x41a1: 0x00c0, 0x41a2: 0x00c0, 0x41a3: 0x00c0, - 0x41a4: 0x00c0, 0x41a5: 0x00c0, 0x41a6: 0x00c0, 0x41a7: 0x00c0, 0x41a8: 0x00c0, 0x41a9: 0x00c0, - 0x41aa: 0x00c0, 0x41ab: 0x00c0, 0x41ac: 0x00c0, 0x41ad: 0x00c0, - 0x41b0: 0x00c3, 0x41b1: 0x00c3, 0x41b2: 0x00c3, 0x41b3: 0x00c3, 0x41b4: 0x00c3, 0x41b5: 0x0080, - // Block 0x107, offset 0x41c0 - 0x41c0: 0x00c0, 0x41c1: 0x00c0, 0x41c2: 0x00c0, 0x41c3: 0x00c0, 0x41c4: 0x00c0, 0x41c5: 0x00c0, - 0x41c6: 0x00c0, 0x41c7: 0x00c0, 0x41c8: 0x00c0, 0x41c9: 0x00c0, 0x41ca: 0x00c0, 0x41cb: 0x00c0, - 0x41cc: 0x00c0, 0x41cd: 0x00c0, 0x41ce: 0x00c0, 0x41cf: 0x00c0, 0x41d0: 0x00c0, 0x41d1: 0x00c0, - 0x41d2: 0x00c0, 0x41d3: 0x00c0, 0x41d4: 0x00c0, 0x41d5: 0x00c0, 0x41d6: 0x00c0, 0x41d7: 0x00c0, - 0x41d8: 0x00c0, 0x41d9: 0x00c0, 0x41da: 0x00c0, 0x41db: 0x00c0, 0x41dc: 0x00c0, 0x41dd: 0x00c0, - 0x41de: 0x00c0, 0x41df: 0x00c0, 0x41e0: 0x00c0, 0x41e1: 0x00c0, 0x41e2: 0x00c0, 0x41e3: 0x00c0, - 0x41e4: 0x00c0, 0x41e5: 0x00c0, 0x41e6: 0x00c0, 0x41e7: 0x00c0, 0x41e8: 0x00c0, 0x41e9: 0x00c0, - 0x41ea: 0x00c0, 0x41eb: 0x00c0, 0x41ec: 0x00c0, 0x41ed: 0x00c0, 0x41ee: 0x00c0, 0x41ef: 0x00c0, - 0x41f0: 0x00c3, 0x41f1: 0x00c3, 0x41f2: 0x00c3, 0x41f3: 0x00c3, 0x41f4: 0x00c3, 0x41f5: 0x00c3, - 0x41f6: 0x00c3, 0x41f7: 0x0080, 0x41f8: 0x0080, 0x41f9: 0x0080, 0x41fa: 0x0080, 0x41fb: 0x0080, - 0x41fc: 0x0080, 0x41fd: 0x0080, 0x41fe: 0x0080, 0x41ff: 0x0080, - // Block 0x108, offset 0x4200 - 0x4200: 0x00c0, 0x4201: 0x00c0, 0x4202: 0x00c0, 0x4203: 0x00c0, 0x4204: 0x0080, 0x4205: 0x0080, - 0x4210: 0x00c0, 0x4211: 0x00c0, - 0x4212: 0x00c0, 0x4213: 0x00c0, 0x4214: 0x00c0, 0x4215: 0x00c0, 0x4216: 0x00c0, 0x4217: 0x00c0, - 0x4218: 0x00c0, 0x4219: 0x00c0, 0x421b: 0x0080, 0x421c: 0x0080, 0x421d: 0x0080, - 0x421e: 0x0080, 0x421f: 0x0080, 0x4220: 0x0080, 0x4221: 0x0080, 0x4223: 0x00c0, - 0x4224: 0x00c0, 0x4225: 0x00c0, 0x4226: 0x00c0, 0x4227: 0x00c0, 0x4228: 0x00c0, 0x4229: 0x00c0, - 0x422a: 0x00c0, 0x422b: 0x00c0, 0x422c: 0x00c0, 0x422d: 0x00c0, 0x422e: 0x00c0, 0x422f: 0x00c0, - 0x4230: 0x00c0, 0x4231: 0x00c0, 0x4232: 0x00c0, 0x4233: 0x00c0, 0x4234: 0x00c0, 0x4235: 0x00c0, - 0x4236: 0x00c0, 0x4237: 0x00c0, - 0x423d: 0x00c0, 0x423e: 0x00c0, 0x423f: 0x00c0, - // Block 0x109, offset 0x4240 - 0x4240: 0x00c0, 0x4241: 0x00c0, 0x4242: 0x00c0, 0x4243: 0x00c0, 0x4244: 0x00c0, 0x4245: 0x00c0, - 0x4246: 0x00c0, 0x4247: 0x00c0, 0x4248: 0x00c0, 0x4249: 0x00c0, 0x424a: 0x00c0, 0x424b: 0x00c0, - 0x424c: 0x00c0, 0x424d: 0x00c0, 0x424e: 0x00c0, 0x424f: 0x00c0, - // Block 0x10a, offset 0x4280 - 0x4280: 0x00c0, 0x4281: 0x00c0, 0x4282: 0x00c0, 0x4283: 0x00c0, 0x4284: 0x00c0, - 0x4290: 0x00c0, 0x4291: 0x00c0, - 0x4292: 0x00c0, 0x4293: 0x00c0, 0x4294: 0x00c0, 0x4295: 0x00c0, 0x4296: 0x00c0, 0x4297: 0x00c0, - 0x4298: 0x00c0, 0x4299: 0x00c0, 0x429a: 0x00c0, 0x429b: 0x00c0, 0x429c: 0x00c0, 0x429d: 0x00c0, - 0x429e: 0x00c0, 0x429f: 0x00c0, 0x42a0: 0x00c0, 0x42a1: 0x00c0, 0x42a2: 0x00c0, 0x42a3: 0x00c0, - 0x42a4: 0x00c0, 0x42a5: 0x00c0, 0x42a6: 0x00c0, 0x42a7: 0x00c0, 0x42a8: 0x00c0, 0x42a9: 0x00c0, - 0x42aa: 0x00c0, 0x42ab: 0x00c0, 0x42ac: 0x00c0, 0x42ad: 0x00c0, 0x42ae: 0x00c0, 0x42af: 0x00c0, - 0x42b0: 0x00c0, 0x42b1: 0x00c0, 0x42b2: 0x00c0, 0x42b3: 0x00c0, 0x42b4: 0x00c0, 0x42b5: 0x00c0, - 0x42b6: 0x00c0, 0x42b7: 0x00c0, 0x42b8: 0x00c0, 0x42b9: 0x00c0, 0x42ba: 0x00c0, 0x42bb: 0x00c0, - 0x42bc: 0x00c0, 0x42bd: 0x00c0, 0x42be: 0x00c0, - // Block 0x10b, offset 0x42c0 - 0x42cf: 0x00c3, 0x42d0: 0x00c3, 0x42d1: 0x00c3, - 0x42d2: 0x00c3, 0x42d3: 0x00c0, 0x42d4: 0x00c0, 0x42d5: 0x00c0, 0x42d6: 0x00c0, 0x42d7: 0x00c0, - 0x42d8: 0x00c0, 0x42d9: 0x00c0, 0x42da: 0x00c0, 0x42db: 0x00c0, 0x42dc: 0x00c0, 0x42dd: 0x00c0, - 0x42de: 0x00c0, 0x42df: 0x00c0, - // Block 0x10c, offset 0x4300 - 0x4320: 0x00c0, - // Block 0x10d, offset 0x4340 - 0x4340: 0x00c0, 0x4341: 0x00c0, 0x4342: 0x00c0, 0x4343: 0x00c0, 0x4344: 0x00c0, 0x4345: 0x00c0, - 0x4346: 0x00c0, 0x4347: 0x00c0, 0x4348: 0x00c0, 0x4349: 0x00c0, 0x434a: 0x00c0, 0x434b: 0x00c0, - 0x434c: 0x00c0, 0x434d: 0x00c0, 0x434e: 0x00c0, 0x434f: 0x00c0, 0x4350: 0x00c0, 0x4351: 0x00c0, - 0x4352: 0x00c0, 0x4353: 0x00c0, 0x4354: 0x00c0, 0x4355: 0x00c0, 0x4356: 0x00c0, 0x4357: 0x00c0, - 0x4358: 0x00c0, 0x4359: 0x00c0, 0x435a: 0x00c0, 0x435b: 0x00c0, 0x435c: 0x00c0, 0x435d: 0x00c0, - 0x435e: 0x00c0, 0x435f: 0x00c0, 0x4360: 0x00c0, 0x4361: 0x00c0, 0x4362: 0x00c0, 0x4363: 0x00c0, - 0x4364: 0x00c0, 0x4365: 0x00c0, 0x4366: 0x00c0, 0x4367: 0x00c0, 0x4368: 0x00c0, 0x4369: 0x00c0, - 0x436a: 0x00c0, 0x436b: 0x00c0, 0x436c: 0x00c0, - // Block 0x10e, offset 0x4380 - 0x4380: 0x00cc, 0x4381: 0x00cc, - // Block 0x10f, offset 0x43c0 - 0x43c0: 0x00c0, 0x43c1: 0x00c0, 0x43c2: 0x00c0, 0x43c3: 0x00c0, 0x43c4: 0x00c0, 0x43c5: 0x00c0, - 0x43c6: 0x00c0, 0x43c7: 0x00c0, 0x43c8: 0x00c0, 0x43c9: 0x00c0, 0x43ca: 0x00c0, 0x43cb: 0x00c0, - 0x43cc: 0x00c0, 0x43cd: 0x00c0, 0x43ce: 0x00c0, 0x43cf: 0x00c0, 0x43d0: 0x00c0, 0x43d1: 0x00c0, - 0x43d2: 0x00c0, 0x43d3: 0x00c0, 0x43d4: 0x00c0, 0x43d5: 0x00c0, 0x43d6: 0x00c0, 0x43d7: 0x00c0, - 0x43d8: 0x00c0, 0x43d9: 0x00c0, 0x43da: 0x00c0, 0x43db: 0x00c0, 0x43dc: 0x00c0, 0x43dd: 0x00c0, - 0x43de: 0x00c0, 0x43df: 0x00c0, 0x43e0: 0x00c0, 0x43e1: 0x00c0, 0x43e2: 0x00c0, 0x43e3: 0x00c0, - 0x43e4: 0x00c0, 0x43e5: 0x00c0, 0x43e6: 0x00c0, 0x43e7: 0x00c0, 0x43e8: 0x00c0, 0x43e9: 0x00c0, - 0x43ea: 0x00c0, - 0x43f0: 0x00c0, 0x43f1: 0x00c0, 0x43f2: 0x00c0, 0x43f3: 0x00c0, 0x43f4: 0x00c0, 0x43f5: 0x00c0, - 0x43f6: 0x00c0, 0x43f7: 0x00c0, 0x43f8: 0x00c0, 0x43f9: 0x00c0, 0x43fa: 0x00c0, 0x43fb: 0x00c0, - 0x43fc: 0x00c0, - // Block 0x110, offset 0x4400 - 0x4400: 0x00c0, 0x4401: 0x00c0, 0x4402: 0x00c0, 0x4403: 0x00c0, 0x4404: 0x00c0, 0x4405: 0x00c0, - 0x4406: 0x00c0, 0x4407: 0x00c0, 0x4408: 0x00c0, - 0x4410: 0x00c0, 0x4411: 0x00c0, - 0x4412: 0x00c0, 0x4413: 0x00c0, 0x4414: 0x00c0, 0x4415: 0x00c0, 0x4416: 0x00c0, 0x4417: 0x00c0, - 0x4418: 0x00c0, 0x4419: 0x00c0, 0x441c: 0x0080, 0x441d: 0x00c3, - 0x441e: 0x00c3, 0x441f: 0x0080, 0x4420: 0x0040, 0x4421: 0x0040, 0x4422: 0x0040, 0x4423: 0x0040, - // Block 0x111, offset 0x4440 - 0x4440: 0x0080, 0x4441: 0x0080, 0x4442: 0x0080, 0x4443: 0x0080, 0x4444: 0x0080, 0x4445: 0x0080, - 0x4446: 0x0080, 0x4447: 0x0080, 0x4448: 0x0080, 0x4449: 0x0080, 0x444a: 0x0080, 0x444b: 0x0080, - 0x444c: 0x0080, 0x444d: 0x0080, 0x444e: 0x0080, 0x444f: 0x0080, 0x4450: 0x0080, 0x4451: 0x0080, - 0x4452: 0x0080, 0x4453: 0x0080, 0x4454: 0x0080, 0x4455: 0x0080, 0x4456: 0x0080, 0x4457: 0x0080, - 0x4458: 0x0080, 0x4459: 0x0080, 0x445a: 0x0080, 0x445b: 0x0080, 0x445c: 0x0080, 0x445d: 0x0080, - 0x445e: 0x0080, 0x445f: 0x0080, 0x4460: 0x0080, 0x4461: 0x0080, 0x4462: 0x0080, 0x4463: 0x0080, - 0x4464: 0x0080, 0x4465: 0x0080, 0x4466: 0x0080, 0x4467: 0x0080, 0x4468: 0x0080, 0x4469: 0x0080, - 0x446a: 0x0080, 0x446b: 0x0080, 0x446c: 0x0080, 0x446d: 0x0080, 0x446e: 0x0080, 0x446f: 0x0080, - 0x4470: 0x0080, 0x4471: 0x0080, 0x4472: 0x0080, 0x4473: 0x0080, 0x4474: 0x0080, 0x4475: 0x0080, - // Block 0x112, offset 0x4480 - 0x4480: 0x0080, 0x4481: 0x0080, 0x4482: 0x0080, 0x4483: 0x0080, 0x4484: 0x0080, 0x4485: 0x0080, - 0x4486: 0x0080, 0x4487: 0x0080, 0x4488: 0x0080, 0x4489: 0x0080, 0x448a: 0x0080, 0x448b: 0x0080, - 0x448c: 0x0080, 0x448d: 0x0080, 0x448e: 0x0080, 0x448f: 0x0080, 0x4490: 0x0080, 0x4491: 0x0080, - 0x4492: 0x0080, 0x4493: 0x0080, 0x4494: 0x0080, 0x4495: 0x0080, 0x4496: 0x0080, 0x4497: 0x0080, - 0x4498: 0x0080, 0x4499: 0x0080, 0x449a: 0x0080, 0x449b: 0x0080, 0x449c: 0x0080, 0x449d: 0x0080, - 0x449e: 0x0080, 0x449f: 0x0080, 0x44a0: 0x0080, 0x44a1: 0x0080, 0x44a2: 0x0080, 0x44a3: 0x0080, - 0x44a4: 0x0080, 0x44a5: 0x0080, 0x44a6: 0x0080, 0x44a9: 0x0080, - 0x44aa: 0x0080, 0x44ab: 0x0080, 0x44ac: 0x0080, 0x44ad: 0x0080, 0x44ae: 0x0080, 0x44af: 0x0080, - 0x44b0: 0x0080, 0x44b1: 0x0080, 0x44b2: 0x0080, 0x44b3: 0x0080, 0x44b4: 0x0080, 0x44b5: 0x0080, - 0x44b6: 0x0080, 0x44b7: 0x0080, 0x44b8: 0x0080, 0x44b9: 0x0080, 0x44ba: 0x0080, 0x44bb: 0x0080, - 0x44bc: 0x0080, 0x44bd: 0x0080, 0x44be: 0x0080, 0x44bf: 0x0080, - // Block 0x113, offset 0x44c0 - 0x44c0: 0x0080, 0x44c1: 0x0080, 0x44c2: 0x0080, 0x44c3: 0x0080, 0x44c4: 0x0080, 0x44c5: 0x0080, - 0x44c6: 0x0080, 0x44c7: 0x0080, 0x44c8: 0x0080, 0x44c9: 0x0080, 0x44ca: 0x0080, 0x44cb: 0x0080, - 0x44cc: 0x0080, 0x44cd: 0x0080, 0x44ce: 0x0080, 0x44cf: 0x0080, 0x44d0: 0x0080, 0x44d1: 0x0080, - 0x44d2: 0x0080, 0x44d3: 0x0080, 0x44d4: 0x0080, 0x44d5: 0x0080, 0x44d6: 0x0080, 0x44d7: 0x0080, - 0x44d8: 0x0080, 0x44d9: 0x0080, 0x44da: 0x0080, 0x44db: 0x0080, 0x44dc: 0x0080, 0x44dd: 0x0080, - 0x44de: 0x0080, 0x44df: 0x0080, 0x44e0: 0x0080, 0x44e1: 0x0080, 0x44e2: 0x0080, 0x44e3: 0x0080, - 0x44e4: 0x0080, 0x44e5: 0x00c0, 0x44e6: 0x00c0, 0x44e7: 0x00c3, 0x44e8: 0x00c3, 0x44e9: 0x00c3, - 0x44ea: 0x0080, 0x44eb: 0x0080, 0x44ec: 0x0080, 0x44ed: 0x00c0, 0x44ee: 0x00c0, 0x44ef: 0x00c0, - 0x44f0: 0x00c0, 0x44f1: 0x00c0, 0x44f2: 0x00c0, 0x44f3: 0x0040, 0x44f4: 0x0040, 0x44f5: 0x0040, - 0x44f6: 0x0040, 0x44f7: 0x0040, 0x44f8: 0x0040, 0x44f9: 0x0040, 0x44fa: 0x0040, 0x44fb: 0x00c3, - 0x44fc: 0x00c3, 0x44fd: 0x00c3, 0x44fe: 0x00c3, 0x44ff: 0x00c3, - // Block 0x114, offset 0x4500 - 0x4500: 0x00c3, 0x4501: 0x00c3, 0x4502: 0x00c3, 0x4503: 0x0080, 0x4504: 0x0080, 0x4505: 0x00c3, - 0x4506: 0x00c3, 0x4507: 0x00c3, 0x4508: 0x00c3, 0x4509: 0x00c3, 0x450a: 0x00c3, 0x450b: 0x00c3, - 0x450c: 0x0080, 0x450d: 0x0080, 0x450e: 0x0080, 0x450f: 0x0080, 0x4510: 0x0080, 0x4511: 0x0080, - 0x4512: 0x0080, 0x4513: 0x0080, 0x4514: 0x0080, 0x4515: 0x0080, 0x4516: 0x0080, 0x4517: 0x0080, - 0x4518: 0x0080, 0x4519: 0x0080, 0x451a: 0x0080, 0x451b: 0x0080, 0x451c: 0x0080, 0x451d: 0x0080, - 0x451e: 0x0080, 0x451f: 0x0080, 0x4520: 0x0080, 0x4521: 0x0080, 0x4522: 0x0080, 0x4523: 0x0080, - 0x4524: 0x0080, 0x4525: 0x0080, 0x4526: 0x0080, 0x4527: 0x0080, 0x4528: 0x0080, 0x4529: 0x0080, - 0x452a: 0x00c3, 0x452b: 0x00c3, 0x452c: 0x00c3, 0x452d: 0x00c3, 0x452e: 0x0080, 0x452f: 0x0080, - 0x4530: 0x0080, 0x4531: 0x0080, 0x4532: 0x0080, 0x4533: 0x0080, 0x4534: 0x0080, 0x4535: 0x0080, - 0x4536: 0x0080, 0x4537: 0x0080, 0x4538: 0x0080, 0x4539: 0x0080, 0x453a: 0x0080, 0x453b: 0x0080, - 0x453c: 0x0080, 0x453d: 0x0080, 0x453e: 0x0080, 0x453f: 0x0080, - // Block 0x115, offset 0x4540 - 0x4540: 0x0080, 0x4541: 0x0080, 0x4542: 0x0080, 0x4543: 0x0080, 0x4544: 0x0080, 0x4545: 0x0080, - 0x4546: 0x0080, 0x4547: 0x0080, 0x4548: 0x0080, 0x4549: 0x0080, 0x454a: 0x0080, 0x454b: 0x0080, - 0x454c: 0x0080, 0x454d: 0x0080, 0x454e: 0x0080, 0x454f: 0x0080, 0x4550: 0x0080, 0x4551: 0x0080, - 0x4552: 0x0080, 0x4553: 0x0080, 0x4554: 0x0080, 0x4555: 0x0080, 0x4556: 0x0080, 0x4557: 0x0080, - 0x4558: 0x0080, 0x4559: 0x0080, 0x455a: 0x0080, 0x455b: 0x0080, 0x455c: 0x0080, 0x455d: 0x0080, - 0x455e: 0x0080, 0x455f: 0x0080, 0x4560: 0x0080, 0x4561: 0x0080, 0x4562: 0x0080, 0x4563: 0x0080, - 0x4564: 0x0080, 0x4565: 0x0080, 0x4566: 0x0080, 0x4567: 0x0080, 0x4568: 0x0080, - // Block 0x116, offset 0x4580 - 0x4580: 0x0088, 0x4581: 0x0088, 0x4582: 0x00c9, 0x4583: 0x00c9, 0x4584: 0x00c9, 0x4585: 0x0088, - // Block 0x117, offset 0x45c0 - 0x45c0: 0x0080, 0x45c1: 0x0080, 0x45c2: 0x0080, 0x45c3: 0x0080, 0x45c4: 0x0080, 0x45c5: 0x0080, - 0x45c6: 0x0080, 0x45c7: 0x0080, 0x45c8: 0x0080, 0x45c9: 0x0080, 0x45ca: 0x0080, 0x45cb: 0x0080, - 0x45cc: 0x0080, 0x45cd: 0x0080, 0x45ce: 0x0080, 0x45cf: 0x0080, 0x45d0: 0x0080, 0x45d1: 0x0080, - 0x45d2: 0x0080, 0x45d3: 0x0080, 0x45d4: 0x0080, 0x45d5: 0x0080, 0x45d6: 0x0080, - 0x45e0: 0x0080, 0x45e1: 0x0080, 0x45e2: 0x0080, 0x45e3: 0x0080, - 0x45e4: 0x0080, 0x45e5: 0x0080, 0x45e6: 0x0080, 0x45e7: 0x0080, 0x45e8: 0x0080, 0x45e9: 0x0080, - 0x45ea: 0x0080, 0x45eb: 0x0080, 0x45ec: 0x0080, 0x45ed: 0x0080, 0x45ee: 0x0080, 0x45ef: 0x0080, - 0x45f0: 0x0080, 0x45f1: 0x0080, - // Block 0x118, offset 0x4600 - 0x4600: 0x0080, 0x4601: 0x0080, 0x4602: 0x0080, 0x4603: 0x0080, 0x4604: 0x0080, 0x4605: 0x0080, - 0x4606: 0x0080, 0x4607: 0x0080, 0x4608: 0x0080, 0x4609: 0x0080, 0x460a: 0x0080, 0x460b: 0x0080, - 0x460c: 0x0080, 0x460d: 0x0080, 0x460e: 0x0080, 0x460f: 0x0080, 0x4610: 0x0080, 0x4611: 0x0080, - 0x4612: 0x0080, 0x4613: 0x0080, 0x4614: 0x0080, 0x4616: 0x0080, 0x4617: 0x0080, - 0x4618: 0x0080, 0x4619: 0x0080, 0x461a: 0x0080, 0x461b: 0x0080, 0x461c: 0x0080, 0x461d: 0x0080, - 0x461e: 0x0080, 0x461f: 0x0080, 0x4620: 0x0080, 0x4621: 0x0080, 0x4622: 0x0080, 0x4623: 0x0080, - 0x4624: 0x0080, 0x4625: 0x0080, 0x4626: 0x0080, 0x4627: 0x0080, 0x4628: 0x0080, 0x4629: 0x0080, - 0x462a: 0x0080, 0x462b: 0x0080, 0x462c: 0x0080, 0x462d: 0x0080, 0x462e: 0x0080, 0x462f: 0x0080, - 0x4630: 0x0080, 0x4631: 0x0080, 0x4632: 0x0080, 0x4633: 0x0080, 0x4634: 0x0080, 0x4635: 0x0080, - 0x4636: 0x0080, 0x4637: 0x0080, 0x4638: 0x0080, 0x4639: 0x0080, 0x463a: 0x0080, 0x463b: 0x0080, - 0x463c: 0x0080, 0x463d: 0x0080, 0x463e: 0x0080, 0x463f: 0x0080, - // Block 0x119, offset 0x4640 - 0x4640: 0x0080, 0x4641: 0x0080, 0x4642: 0x0080, 0x4643: 0x0080, 0x4644: 0x0080, 0x4645: 0x0080, - 0x4646: 0x0080, 0x4647: 0x0080, 0x4648: 0x0080, 0x4649: 0x0080, 0x464a: 0x0080, 0x464b: 0x0080, - 0x464c: 0x0080, 0x464d: 0x0080, 0x464e: 0x0080, 0x464f: 0x0080, 0x4650: 0x0080, 0x4651: 0x0080, - 0x4652: 0x0080, 0x4653: 0x0080, 0x4654: 0x0080, 0x4655: 0x0080, 0x4656: 0x0080, 0x4657: 0x0080, - 0x4658: 0x0080, 0x4659: 0x0080, 0x465a: 0x0080, 0x465b: 0x0080, 0x465c: 0x0080, - 0x465e: 0x0080, 0x465f: 0x0080, 0x4662: 0x0080, - 0x4665: 0x0080, 0x4666: 0x0080, 0x4669: 0x0080, - 0x466a: 0x0080, 0x466b: 0x0080, 0x466c: 0x0080, 0x466e: 0x0080, 0x466f: 0x0080, - 0x4670: 0x0080, 0x4671: 0x0080, 0x4672: 0x0080, 0x4673: 0x0080, 0x4674: 0x0080, 0x4675: 0x0080, - 0x4676: 0x0080, 0x4677: 0x0080, 0x4678: 0x0080, 0x4679: 0x0080, 0x467b: 0x0080, - 0x467d: 0x0080, 0x467e: 0x0080, 0x467f: 0x0080, - // Block 0x11a, offset 0x4680 - 0x4680: 0x0080, 0x4681: 0x0080, 0x4682: 0x0080, 0x4683: 0x0080, 0x4685: 0x0080, - 0x4686: 0x0080, 0x4687: 0x0080, 0x4688: 0x0080, 0x4689: 0x0080, 0x468a: 0x0080, 0x468b: 0x0080, - 0x468c: 0x0080, 0x468d: 0x0080, 0x468e: 0x0080, 0x468f: 0x0080, 0x4690: 0x0080, 0x4691: 0x0080, - 0x4692: 0x0080, 0x4693: 0x0080, 0x4694: 0x0080, 0x4695: 0x0080, 0x4696: 0x0080, 0x4697: 0x0080, - 0x4698: 0x0080, 0x4699: 0x0080, 0x469a: 0x0080, 0x469b: 0x0080, 0x469c: 0x0080, 0x469d: 0x0080, - 0x469e: 0x0080, 0x469f: 0x0080, 0x46a0: 0x0080, 0x46a1: 0x0080, 0x46a2: 0x0080, 0x46a3: 0x0080, - 0x46a4: 0x0080, 0x46a5: 0x0080, 0x46a6: 0x0080, 0x46a7: 0x0080, 0x46a8: 0x0080, 0x46a9: 0x0080, - 0x46aa: 0x0080, 0x46ab: 0x0080, 0x46ac: 0x0080, 0x46ad: 0x0080, 0x46ae: 0x0080, 0x46af: 0x0080, - 0x46b0: 0x0080, 0x46b1: 0x0080, 0x46b2: 0x0080, 0x46b3: 0x0080, 0x46b4: 0x0080, 0x46b5: 0x0080, - 0x46b6: 0x0080, 0x46b7: 0x0080, 0x46b8: 0x0080, 0x46b9: 0x0080, 0x46ba: 0x0080, 0x46bb: 0x0080, - 0x46bc: 0x0080, 0x46bd: 0x0080, 0x46be: 0x0080, 0x46bf: 0x0080, - // Block 0x11b, offset 0x46c0 - 0x46c0: 0x0080, 0x46c1: 0x0080, 0x46c2: 0x0080, 0x46c3: 0x0080, 0x46c4: 0x0080, 0x46c5: 0x0080, - 0x46c7: 0x0080, 0x46c8: 0x0080, 0x46c9: 0x0080, 0x46ca: 0x0080, - 0x46cd: 0x0080, 0x46ce: 0x0080, 0x46cf: 0x0080, 0x46d0: 0x0080, 0x46d1: 0x0080, - 0x46d2: 0x0080, 0x46d3: 0x0080, 0x46d4: 0x0080, 0x46d6: 0x0080, 0x46d7: 0x0080, - 0x46d8: 0x0080, 0x46d9: 0x0080, 0x46da: 0x0080, 0x46db: 0x0080, 0x46dc: 0x0080, - 0x46de: 0x0080, 0x46df: 0x0080, 0x46e0: 0x0080, 0x46e1: 0x0080, 0x46e2: 0x0080, 0x46e3: 0x0080, - 0x46e4: 0x0080, 0x46e5: 0x0080, 0x46e6: 0x0080, 0x46e7: 0x0080, 0x46e8: 0x0080, 0x46e9: 0x0080, - 0x46ea: 0x0080, 0x46eb: 0x0080, 0x46ec: 0x0080, 0x46ed: 0x0080, 0x46ee: 0x0080, 0x46ef: 0x0080, - 0x46f0: 0x0080, 0x46f1: 0x0080, 0x46f2: 0x0080, 0x46f3: 0x0080, 0x46f4: 0x0080, 0x46f5: 0x0080, - 0x46f6: 0x0080, 0x46f7: 0x0080, 0x46f8: 0x0080, 0x46f9: 0x0080, 0x46fb: 0x0080, - 0x46fc: 0x0080, 0x46fd: 0x0080, 0x46fe: 0x0080, - // Block 0x11c, offset 0x4700 - 0x4700: 0x0080, 0x4701: 0x0080, 0x4702: 0x0080, 0x4703: 0x0080, 0x4704: 0x0080, - 0x4706: 0x0080, 0x470a: 0x0080, 0x470b: 0x0080, - 0x470c: 0x0080, 0x470d: 0x0080, 0x470e: 0x0080, 0x470f: 0x0080, 0x4710: 0x0080, - 0x4712: 0x0080, 0x4713: 0x0080, 0x4714: 0x0080, 0x4715: 0x0080, 0x4716: 0x0080, 0x4717: 0x0080, - 0x4718: 0x0080, 0x4719: 0x0080, 0x471a: 0x0080, 0x471b: 0x0080, 0x471c: 0x0080, 0x471d: 0x0080, - 0x471e: 0x0080, 0x471f: 0x0080, 0x4720: 0x0080, 0x4721: 0x0080, 0x4722: 0x0080, 0x4723: 0x0080, - 0x4724: 0x0080, 0x4725: 0x0080, 0x4726: 0x0080, 0x4727: 0x0080, 0x4728: 0x0080, 0x4729: 0x0080, - 0x472a: 0x0080, 0x472b: 0x0080, 0x472c: 0x0080, 0x472d: 0x0080, 0x472e: 0x0080, 0x472f: 0x0080, - 0x4730: 0x0080, 0x4731: 0x0080, 0x4732: 0x0080, 0x4733: 0x0080, 0x4734: 0x0080, 0x4735: 0x0080, - 0x4736: 0x0080, 0x4737: 0x0080, 0x4738: 0x0080, 0x4739: 0x0080, 0x473a: 0x0080, 0x473b: 0x0080, - 0x473c: 0x0080, 0x473d: 0x0080, 0x473e: 0x0080, 0x473f: 0x0080, - // Block 0x11d, offset 0x4740 - 0x4740: 0x0080, 0x4741: 0x0080, 0x4742: 0x0080, 0x4743: 0x0080, 0x4744: 0x0080, 0x4745: 0x0080, - 0x4746: 0x0080, 0x4747: 0x0080, 0x4748: 0x0080, 0x4749: 0x0080, 0x474a: 0x0080, 0x474b: 0x0080, - 0x474c: 0x0080, 0x474d: 0x0080, 0x474e: 0x0080, 0x474f: 0x0080, 0x4750: 0x0080, 0x4751: 0x0080, - 0x4752: 0x0080, 0x4753: 0x0080, 0x4754: 0x0080, 0x4755: 0x0080, 0x4756: 0x0080, 0x4757: 0x0080, - 0x4758: 0x0080, 0x4759: 0x0080, 0x475a: 0x0080, 0x475b: 0x0080, 0x475c: 0x0080, 0x475d: 0x0080, - 0x475e: 0x0080, 0x475f: 0x0080, 0x4760: 0x0080, 0x4761: 0x0080, 0x4762: 0x0080, 0x4763: 0x0080, - 0x4764: 0x0080, 0x4765: 0x0080, 0x4768: 0x0080, 0x4769: 0x0080, - 0x476a: 0x0080, 0x476b: 0x0080, 0x476c: 0x0080, 0x476d: 0x0080, 0x476e: 0x0080, 0x476f: 0x0080, - 0x4770: 0x0080, 0x4771: 0x0080, 0x4772: 0x0080, 0x4773: 0x0080, 0x4774: 0x0080, 0x4775: 0x0080, - 0x4776: 0x0080, 0x4777: 0x0080, 0x4778: 0x0080, 0x4779: 0x0080, 0x477a: 0x0080, 0x477b: 0x0080, - 0x477c: 0x0080, 0x477d: 0x0080, 0x477e: 0x0080, 0x477f: 0x0080, - // Block 0x11e, offset 0x4780 - 0x4780: 0x0080, 0x4781: 0x0080, 0x4782: 0x0080, 0x4783: 0x0080, 0x4784: 0x0080, 0x4785: 0x0080, - 0x4786: 0x0080, 0x4787: 0x0080, 0x4788: 0x0080, 0x4789: 0x0080, 0x478a: 0x0080, 0x478b: 0x0080, - 0x478e: 0x0080, 0x478f: 0x0080, 0x4790: 0x0080, 0x4791: 0x0080, - 0x4792: 0x0080, 0x4793: 0x0080, 0x4794: 0x0080, 0x4795: 0x0080, 0x4796: 0x0080, 0x4797: 0x0080, - 0x4798: 0x0080, 0x4799: 0x0080, 0x479a: 0x0080, 0x479b: 0x0080, 0x479c: 0x0080, 0x479d: 0x0080, - 0x479e: 0x0080, 0x479f: 0x0080, 0x47a0: 0x0080, 0x47a1: 0x0080, 0x47a2: 0x0080, 0x47a3: 0x0080, - 0x47a4: 0x0080, 0x47a5: 0x0080, 0x47a6: 0x0080, 0x47a7: 0x0080, 0x47a8: 0x0080, 0x47a9: 0x0080, - 0x47aa: 0x0080, 0x47ab: 0x0080, 0x47ac: 0x0080, 0x47ad: 0x0080, 0x47ae: 0x0080, 0x47af: 0x0080, - 0x47b0: 0x0080, 0x47b1: 0x0080, 0x47b2: 0x0080, 0x47b3: 0x0080, 0x47b4: 0x0080, 0x47b5: 0x0080, - 0x47b6: 0x0080, 0x47b7: 0x0080, 0x47b8: 0x0080, 0x47b9: 0x0080, 0x47ba: 0x0080, 0x47bb: 0x0080, - 0x47bc: 0x0080, 0x47bd: 0x0080, 0x47be: 0x0080, 0x47bf: 0x0080, - // Block 0x11f, offset 0x47c0 - 0x47c0: 0x00c3, 0x47c1: 0x00c3, 0x47c2: 0x00c3, 0x47c3: 0x00c3, 0x47c4: 0x00c3, 0x47c5: 0x00c3, - 0x47c6: 0x00c3, 0x47c7: 0x00c3, 0x47c8: 0x00c3, 0x47c9: 0x00c3, 0x47ca: 0x00c3, 0x47cb: 0x00c3, - 0x47cc: 0x00c3, 0x47cd: 0x00c3, 0x47ce: 0x00c3, 0x47cf: 0x00c3, 0x47d0: 0x00c3, 0x47d1: 0x00c3, - 0x47d2: 0x00c3, 0x47d3: 0x00c3, 0x47d4: 0x00c3, 0x47d5: 0x00c3, 0x47d6: 0x00c3, 0x47d7: 0x00c3, - 0x47d8: 0x00c3, 0x47d9: 0x00c3, 0x47da: 0x00c3, 0x47db: 0x00c3, 0x47dc: 0x00c3, 0x47dd: 0x00c3, - 0x47de: 0x00c3, 0x47df: 0x00c3, 0x47e0: 0x00c3, 0x47e1: 0x00c3, 0x47e2: 0x00c3, 0x47e3: 0x00c3, - 0x47e4: 0x00c3, 0x47e5: 0x00c3, 0x47e6: 0x00c3, 0x47e7: 0x00c3, 0x47e8: 0x00c3, 0x47e9: 0x00c3, - 0x47ea: 0x00c3, 0x47eb: 0x00c3, 0x47ec: 0x00c3, 0x47ed: 0x00c3, 0x47ee: 0x00c3, 0x47ef: 0x00c3, - 0x47f0: 0x00c3, 0x47f1: 0x00c3, 0x47f2: 0x00c3, 0x47f3: 0x00c3, 0x47f4: 0x00c3, 0x47f5: 0x00c3, - 0x47f6: 0x00c3, 0x47f7: 0x0080, 0x47f8: 0x0080, 0x47f9: 0x0080, 0x47fa: 0x0080, 0x47fb: 0x00c3, - 0x47fc: 0x00c3, 0x47fd: 0x00c3, 0x47fe: 0x00c3, 0x47ff: 0x00c3, - // Block 0x120, offset 0x4800 - 0x4800: 0x00c3, 0x4801: 0x00c3, 0x4802: 0x00c3, 0x4803: 0x00c3, 0x4804: 0x00c3, 0x4805: 0x00c3, - 0x4806: 0x00c3, 0x4807: 0x00c3, 0x4808: 0x00c3, 0x4809: 0x00c3, 0x480a: 0x00c3, 0x480b: 0x00c3, - 0x480c: 0x00c3, 0x480d: 0x00c3, 0x480e: 0x00c3, 0x480f: 0x00c3, 0x4810: 0x00c3, 0x4811: 0x00c3, - 0x4812: 0x00c3, 0x4813: 0x00c3, 0x4814: 0x00c3, 0x4815: 0x00c3, 0x4816: 0x00c3, 0x4817: 0x00c3, - 0x4818: 0x00c3, 0x4819: 0x00c3, 0x481a: 0x00c3, 0x481b: 0x00c3, 0x481c: 0x00c3, 0x481d: 0x00c3, - 0x481e: 0x00c3, 0x481f: 0x00c3, 0x4820: 0x00c3, 0x4821: 0x00c3, 0x4822: 0x00c3, 0x4823: 0x00c3, - 0x4824: 0x00c3, 0x4825: 0x00c3, 0x4826: 0x00c3, 0x4827: 0x00c3, 0x4828: 0x00c3, 0x4829: 0x00c3, - 0x482a: 0x00c3, 0x482b: 0x00c3, 0x482c: 0x00c3, 0x482d: 0x0080, 0x482e: 0x0080, 0x482f: 0x0080, - 0x4830: 0x0080, 0x4831: 0x0080, 0x4832: 0x0080, 0x4833: 0x0080, 0x4834: 0x0080, 0x4835: 0x00c3, - 0x4836: 0x0080, 0x4837: 0x0080, 0x4838: 0x0080, 0x4839: 0x0080, 0x483a: 0x0080, 0x483b: 0x0080, - 0x483c: 0x0080, 0x483d: 0x0080, 0x483e: 0x0080, 0x483f: 0x0080, - // Block 0x121, offset 0x4840 - 0x4840: 0x0080, 0x4841: 0x0080, 0x4842: 0x0080, 0x4843: 0x0080, 0x4844: 0x00c3, 0x4845: 0x0080, - 0x4846: 0x0080, 0x4847: 0x0080, 0x4848: 0x0080, 0x4849: 0x0080, 0x484a: 0x0080, 0x484b: 0x0080, - 0x485b: 0x00c3, 0x485c: 0x00c3, 0x485d: 0x00c3, - 0x485e: 0x00c3, 0x485f: 0x00c3, 0x4861: 0x00c3, 0x4862: 0x00c3, 0x4863: 0x00c3, - 0x4864: 0x00c3, 0x4865: 0x00c3, 0x4866: 0x00c3, 0x4867: 0x00c3, 0x4868: 0x00c3, 0x4869: 0x00c3, - 0x486a: 0x00c3, 0x486b: 0x00c3, 0x486c: 0x00c3, 0x486d: 0x00c3, 0x486e: 0x00c3, 0x486f: 0x00c3, - // Block 0x122, offset 0x4880 - 0x4880: 0x00c3, 0x4881: 0x00c3, 0x4882: 0x00c3, 0x4883: 0x00c3, 0x4884: 0x00c3, 0x4885: 0x00c3, - 0x4886: 0x00c3, 0x4888: 0x00c3, 0x4889: 0x00c3, 0x488a: 0x00c3, 0x488b: 0x00c3, - 0x488c: 0x00c3, 0x488d: 0x00c3, 0x488e: 0x00c3, 0x488f: 0x00c3, 0x4890: 0x00c3, 0x4891: 0x00c3, - 0x4892: 0x00c3, 0x4893: 0x00c3, 0x4894: 0x00c3, 0x4895: 0x00c3, 0x4896: 0x00c3, 0x4897: 0x00c3, - 0x4898: 0x00c3, 0x489b: 0x00c3, 0x489c: 0x00c3, 0x489d: 0x00c3, - 0x489e: 0x00c3, 0x489f: 0x00c3, 0x48a0: 0x00c3, 0x48a1: 0x00c3, 0x48a3: 0x00c3, - 0x48a4: 0x00c3, 0x48a6: 0x00c3, 0x48a7: 0x00c3, 0x48a8: 0x00c3, 0x48a9: 0x00c3, - 0x48aa: 0x00c3, - // Block 0x123, offset 0x48c0 - 0x48c0: 0x00c0, 0x48c1: 0x00c0, 0x48c2: 0x00c0, 0x48c3: 0x00c0, 0x48c4: 0x00c0, - 0x48c7: 0x0080, 0x48c8: 0x0080, 0x48c9: 0x0080, 0x48ca: 0x0080, 0x48cb: 0x0080, - 0x48cc: 0x0080, 0x48cd: 0x0080, 0x48ce: 0x0080, 0x48cf: 0x0080, 0x48d0: 0x00c3, 0x48d1: 0x00c3, - 0x48d2: 0x00c3, 0x48d3: 0x00c3, 0x48d4: 0x00c3, 0x48d5: 0x00c3, 0x48d6: 0x00c3, - // Block 0x124, offset 0x4900 - 0x4900: 0x00c2, 0x4901: 0x00c2, 0x4902: 0x00c2, 0x4903: 0x00c2, 0x4904: 0x00c2, 0x4905: 0x00c2, - 0x4906: 0x00c2, 0x4907: 0x00c2, 0x4908: 0x00c2, 0x4909: 0x00c2, 0x490a: 0x00c2, 0x490b: 0x00c2, - 0x490c: 0x00c2, 0x490d: 0x00c2, 0x490e: 0x00c2, 0x490f: 0x00c2, 0x4910: 0x00c2, 0x4911: 0x00c2, - 0x4912: 0x00c2, 0x4913: 0x00c2, 0x4914: 0x00c2, 0x4915: 0x00c2, 0x4916: 0x00c2, 0x4917: 0x00c2, - 0x4918: 0x00c2, 0x4919: 0x00c2, 0x491a: 0x00c2, 0x491b: 0x00c2, 0x491c: 0x00c2, 0x491d: 0x00c2, - 0x491e: 0x00c2, 0x491f: 0x00c2, 0x4920: 0x00c2, 0x4921: 0x00c2, 0x4922: 0x00c2, 0x4923: 0x00c2, - 0x4924: 0x00c2, 0x4925: 0x00c2, 0x4926: 0x00c2, 0x4927: 0x00c2, 0x4928: 0x00c2, 0x4929: 0x00c2, - 0x492a: 0x00c2, 0x492b: 0x00c2, 0x492c: 0x00c2, 0x492d: 0x00c2, 0x492e: 0x00c2, 0x492f: 0x00c2, - 0x4930: 0x00c2, 0x4931: 0x00c2, 0x4932: 0x00c2, 0x4933: 0x00c2, 0x4934: 0x00c2, 0x4935: 0x00c2, - 0x4936: 0x00c2, 0x4937: 0x00c2, 0x4938: 0x00c2, 0x4939: 0x00c2, 0x493a: 0x00c2, 0x493b: 0x00c2, - 0x493c: 0x00c2, 0x493d: 0x00c2, 0x493e: 0x00c2, 0x493f: 0x00c2, - // Block 0x125, offset 0x4940 - 0x4940: 0x00c2, 0x4941: 0x00c2, 0x4942: 0x00c2, 0x4943: 0x00c2, 0x4944: 0x00c3, 0x4945: 0x00c3, - 0x4946: 0x00c3, 0x4947: 0x00c3, 0x4948: 0x00c3, 0x4949: 0x00c3, 0x494a: 0x00c3, - 0x4950: 0x00c0, 0x4951: 0x00c0, - 0x4952: 0x00c0, 0x4953: 0x00c0, 0x4954: 0x00c0, 0x4955: 0x00c0, 0x4956: 0x00c0, 0x4957: 0x00c0, - 0x4958: 0x00c0, 0x4959: 0x00c0, - 0x495e: 0x0080, 0x495f: 0x0080, - // Block 0x126, offset 0x4980 - 0x4980: 0x0080, 0x4981: 0x0080, 0x4982: 0x0080, 0x4983: 0x0080, 0x4985: 0x0080, - 0x4986: 0x0080, 0x4987: 0x0080, 0x4988: 0x0080, 0x4989: 0x0080, 0x498a: 0x0080, 0x498b: 0x0080, - 0x498c: 0x0080, 0x498d: 0x0080, 0x498e: 0x0080, 0x498f: 0x0080, 0x4990: 0x0080, 0x4991: 0x0080, - 0x4992: 0x0080, 0x4993: 0x0080, 0x4994: 0x0080, 0x4995: 0x0080, 0x4996: 0x0080, 0x4997: 0x0080, - 0x4998: 0x0080, 0x4999: 0x0080, 0x499a: 0x0080, 0x499b: 0x0080, 0x499c: 0x0080, 0x499d: 0x0080, - 0x499e: 0x0080, 0x499f: 0x0080, 0x49a1: 0x0080, 0x49a2: 0x0080, - 0x49a4: 0x0080, 0x49a7: 0x0080, 0x49a9: 0x0080, - 0x49aa: 0x0080, 0x49ab: 0x0080, 0x49ac: 0x0080, 0x49ad: 0x0080, 0x49ae: 0x0080, 0x49af: 0x0080, - 0x49b0: 0x0080, 0x49b1: 0x0080, 0x49b2: 0x0080, 0x49b4: 0x0080, 0x49b5: 0x0080, - 0x49b6: 0x0080, 0x49b7: 0x0080, 0x49b9: 0x0080, 0x49bb: 0x0080, - // Block 0x127, offset 0x49c0 - 0x49c2: 0x0080, - 0x49c7: 0x0080, 0x49c9: 0x0080, 0x49cb: 0x0080, - 0x49cd: 0x0080, 0x49ce: 0x0080, 0x49cf: 0x0080, 0x49d1: 0x0080, - 0x49d2: 0x0080, 0x49d4: 0x0080, 0x49d7: 0x0080, - 0x49d9: 0x0080, 0x49db: 0x0080, 0x49dd: 0x0080, - 0x49df: 0x0080, 0x49e1: 0x0080, 0x49e2: 0x0080, - 0x49e4: 0x0080, 0x49e7: 0x0080, 0x49e8: 0x0080, 0x49e9: 0x0080, - 0x49ea: 0x0080, 0x49ec: 0x0080, 0x49ed: 0x0080, 0x49ee: 0x0080, 0x49ef: 0x0080, - 0x49f0: 0x0080, 0x49f1: 0x0080, 0x49f2: 0x0080, 0x49f4: 0x0080, 0x49f5: 0x0080, - 0x49f6: 0x0080, 0x49f7: 0x0080, 0x49f9: 0x0080, 0x49fa: 0x0080, 0x49fb: 0x0080, - 0x49fc: 0x0080, 0x49fe: 0x0080, - // Block 0x128, offset 0x4a00 - 0x4a00: 0x0080, 0x4a01: 0x0080, 0x4a02: 0x0080, 0x4a03: 0x0080, 0x4a04: 0x0080, 0x4a05: 0x0080, - 0x4a06: 0x0080, 0x4a07: 0x0080, 0x4a08: 0x0080, 0x4a09: 0x0080, 0x4a0b: 0x0080, - 0x4a0c: 0x0080, 0x4a0d: 0x0080, 0x4a0e: 0x0080, 0x4a0f: 0x0080, 0x4a10: 0x0080, 0x4a11: 0x0080, - 0x4a12: 0x0080, 0x4a13: 0x0080, 0x4a14: 0x0080, 0x4a15: 0x0080, 0x4a16: 0x0080, 0x4a17: 0x0080, - 0x4a18: 0x0080, 0x4a19: 0x0080, 0x4a1a: 0x0080, 0x4a1b: 0x0080, - 0x4a21: 0x0080, 0x4a22: 0x0080, 0x4a23: 0x0080, - 0x4a25: 0x0080, 0x4a26: 0x0080, 0x4a27: 0x0080, 0x4a28: 0x0080, 0x4a29: 0x0080, - 0x4a2b: 0x0080, 0x4a2c: 0x0080, 0x4a2d: 0x0080, 0x4a2e: 0x0080, 0x4a2f: 0x0080, - 0x4a30: 0x0080, 0x4a31: 0x0080, 0x4a32: 0x0080, 0x4a33: 0x0080, 0x4a34: 0x0080, 0x4a35: 0x0080, - 0x4a36: 0x0080, 0x4a37: 0x0080, 0x4a38: 0x0080, 0x4a39: 0x0080, 0x4a3a: 0x0080, 0x4a3b: 0x0080, - // Block 0x129, offset 0x4a40 - 0x4a70: 0x0080, 0x4a71: 0x0080, - // Block 0x12a, offset 0x4a80 - 0x4a80: 0x0080, 0x4a81: 0x0080, 0x4a82: 0x0080, 0x4a83: 0x0080, 0x4a84: 0x0080, 0x4a85: 0x0080, - 0x4a86: 0x0080, 0x4a87: 0x0080, 0x4a88: 0x0080, 0x4a89: 0x0080, 0x4a8a: 0x0080, 0x4a8b: 0x0080, - 0x4a8c: 0x0080, 0x4a8d: 0x0080, 0x4a8e: 0x0080, 0x4a8f: 0x0080, 0x4a90: 0x0080, 0x4a91: 0x0080, - 0x4a92: 0x0080, 0x4a93: 0x0080, 0x4a94: 0x0080, 0x4a95: 0x0080, 0x4a96: 0x0080, 0x4a97: 0x0080, - 0x4a98: 0x0080, 0x4a99: 0x0080, 0x4a9a: 0x0080, 0x4a9b: 0x0080, 0x4a9c: 0x0080, 0x4a9d: 0x0080, - 0x4a9e: 0x0080, 0x4a9f: 0x0080, 0x4aa0: 0x0080, 0x4aa1: 0x0080, 0x4aa2: 0x0080, 0x4aa3: 0x0080, - 0x4aa4: 0x0080, 0x4aa5: 0x0080, 0x4aa6: 0x0080, 0x4aa7: 0x0080, 0x4aa8: 0x0080, 0x4aa9: 0x0080, - 0x4aaa: 0x0080, 0x4aab: 0x0080, - 0x4ab0: 0x0080, 0x4ab1: 0x0080, 0x4ab2: 0x0080, 0x4ab3: 0x0080, 0x4ab4: 0x0080, 0x4ab5: 0x0080, - 0x4ab6: 0x0080, 0x4ab7: 0x0080, 0x4ab8: 0x0080, 0x4ab9: 0x0080, 0x4aba: 0x0080, 0x4abb: 0x0080, - 0x4abc: 0x0080, 0x4abd: 0x0080, 0x4abe: 0x0080, 0x4abf: 0x0080, - // Block 0x12b, offset 0x4ac0 - 0x4ac0: 0x0080, 0x4ac1: 0x0080, 0x4ac2: 0x0080, 0x4ac3: 0x0080, 0x4ac4: 0x0080, 0x4ac5: 0x0080, - 0x4ac6: 0x0080, 0x4ac7: 0x0080, 0x4ac8: 0x0080, 0x4ac9: 0x0080, 0x4aca: 0x0080, 0x4acb: 0x0080, - 0x4acc: 0x0080, 0x4acd: 0x0080, 0x4ace: 0x0080, 0x4acf: 0x0080, 0x4ad0: 0x0080, 0x4ad1: 0x0080, - 0x4ad2: 0x0080, 0x4ad3: 0x0080, - 0x4ae0: 0x0080, 0x4ae1: 0x0080, 0x4ae2: 0x0080, 0x4ae3: 0x0080, - 0x4ae4: 0x0080, 0x4ae5: 0x0080, 0x4ae6: 0x0080, 0x4ae7: 0x0080, 0x4ae8: 0x0080, 0x4ae9: 0x0080, - 0x4aea: 0x0080, 0x4aeb: 0x0080, 0x4aec: 0x0080, 0x4aed: 0x0080, 0x4aee: 0x0080, - 0x4af1: 0x0080, 0x4af2: 0x0080, 0x4af3: 0x0080, 0x4af4: 0x0080, 0x4af5: 0x0080, - 0x4af6: 0x0080, 0x4af7: 0x0080, 0x4af8: 0x0080, 0x4af9: 0x0080, 0x4afa: 0x0080, 0x4afb: 0x0080, - 0x4afc: 0x0080, 0x4afd: 0x0080, 0x4afe: 0x0080, 0x4aff: 0x0080, - // Block 0x12c, offset 0x4b00 - 0x4b01: 0x0080, 0x4b02: 0x0080, 0x4b03: 0x0080, 0x4b04: 0x0080, 0x4b05: 0x0080, - 0x4b06: 0x0080, 0x4b07: 0x0080, 0x4b08: 0x0080, 0x4b09: 0x0080, 0x4b0a: 0x0080, 0x4b0b: 0x0080, - 0x4b0c: 0x0080, 0x4b0d: 0x0080, 0x4b0e: 0x0080, 0x4b0f: 0x0080, 0x4b11: 0x0080, - 0x4b12: 0x0080, 0x4b13: 0x0080, 0x4b14: 0x0080, 0x4b15: 0x0080, 0x4b16: 0x0080, 0x4b17: 0x0080, - 0x4b18: 0x0080, 0x4b19: 0x0080, 0x4b1a: 0x0080, 0x4b1b: 0x0080, 0x4b1c: 0x0080, 0x4b1d: 0x0080, - 0x4b1e: 0x0080, 0x4b1f: 0x0080, 0x4b20: 0x0080, 0x4b21: 0x0080, 0x4b22: 0x0080, 0x4b23: 0x0080, - 0x4b24: 0x0080, 0x4b25: 0x0080, 0x4b26: 0x0080, 0x4b27: 0x0080, 0x4b28: 0x0080, 0x4b29: 0x0080, - 0x4b2a: 0x0080, 0x4b2b: 0x0080, 0x4b2c: 0x0080, 0x4b2d: 0x0080, 0x4b2e: 0x0080, 0x4b2f: 0x0080, - 0x4b30: 0x0080, 0x4b31: 0x0080, 0x4b32: 0x0080, 0x4b33: 0x0080, 0x4b34: 0x0080, 0x4b35: 0x0080, - // Block 0x12d, offset 0x4b40 - 0x4b40: 0x0080, 0x4b41: 0x0080, 0x4b42: 0x0080, 0x4b43: 0x0080, 0x4b44: 0x0080, 0x4b45: 0x0080, - 0x4b46: 0x0080, 0x4b47: 0x0080, 0x4b48: 0x0080, 0x4b49: 0x0080, 0x4b4a: 0x0080, 0x4b4b: 0x0080, - 0x4b4c: 0x0080, 0x4b50: 0x0080, 0x4b51: 0x0080, - 0x4b52: 0x0080, 0x4b53: 0x0080, 0x4b54: 0x0080, 0x4b55: 0x0080, 0x4b56: 0x0080, 0x4b57: 0x0080, - 0x4b58: 0x0080, 0x4b59: 0x0080, 0x4b5a: 0x0080, 0x4b5b: 0x0080, 0x4b5c: 0x0080, 0x4b5d: 0x0080, - 0x4b5e: 0x0080, 0x4b5f: 0x0080, 0x4b60: 0x0080, 0x4b61: 0x0080, 0x4b62: 0x0080, 0x4b63: 0x0080, - 0x4b64: 0x0080, 0x4b65: 0x0080, 0x4b66: 0x0080, 0x4b67: 0x0080, 0x4b68: 0x0080, 0x4b69: 0x0080, - 0x4b6a: 0x0080, 0x4b6b: 0x0080, 0x4b6c: 0x0080, 0x4b6d: 0x0080, 0x4b6e: 0x0080, - 0x4b70: 0x0080, 0x4b71: 0x0080, 0x4b72: 0x0080, 0x4b73: 0x0080, 0x4b74: 0x0080, 0x4b75: 0x0080, - 0x4b76: 0x0080, 0x4b77: 0x0080, 0x4b78: 0x0080, 0x4b79: 0x0080, 0x4b7a: 0x0080, 0x4b7b: 0x0080, - 0x4b7c: 0x0080, 0x4b7d: 0x0080, 0x4b7e: 0x0080, 0x4b7f: 0x0080, - // Block 0x12e, offset 0x4b80 - 0x4b80: 0x0080, 0x4b81: 0x0080, 0x4b82: 0x0080, 0x4b83: 0x0080, 0x4b84: 0x0080, 0x4b85: 0x0080, - 0x4b86: 0x0080, 0x4b87: 0x0080, 0x4b88: 0x0080, 0x4b89: 0x0080, 0x4b8a: 0x0080, 0x4b8b: 0x0080, - 0x4b8c: 0x0080, 0x4b8d: 0x0080, 0x4b8e: 0x0080, 0x4b8f: 0x0080, 0x4b90: 0x0080, 0x4b91: 0x0080, - 0x4b92: 0x0080, 0x4b93: 0x0080, 0x4b94: 0x0080, 0x4b95: 0x0080, 0x4b96: 0x0080, 0x4b97: 0x0080, - 0x4b98: 0x0080, 0x4b99: 0x0080, 0x4b9a: 0x0080, 0x4b9b: 0x0080, 0x4b9c: 0x0080, 0x4b9d: 0x0080, - 0x4b9e: 0x0080, 0x4b9f: 0x0080, 0x4ba0: 0x0080, 0x4ba1: 0x0080, 0x4ba2: 0x0080, 0x4ba3: 0x0080, - 0x4ba4: 0x0080, 0x4ba5: 0x0080, 0x4ba6: 0x0080, 0x4ba7: 0x0080, 0x4ba8: 0x0080, 0x4ba9: 0x0080, - 0x4baa: 0x0080, 0x4bab: 0x0080, 0x4bac: 0x0080, - // Block 0x12f, offset 0x4bc0 - 0x4be6: 0x0080, 0x4be7: 0x0080, 0x4be8: 0x0080, 0x4be9: 0x0080, - 0x4bea: 0x0080, 0x4beb: 0x0080, 0x4bec: 0x0080, 0x4bed: 0x0080, 0x4bee: 0x0080, 0x4bef: 0x0080, - 0x4bf0: 0x0080, 0x4bf1: 0x0080, 0x4bf2: 0x0080, 0x4bf3: 0x0080, 0x4bf4: 0x0080, 0x4bf5: 0x0080, - 0x4bf6: 0x0080, 0x4bf7: 0x0080, 0x4bf8: 0x0080, 0x4bf9: 0x0080, 0x4bfa: 0x0080, 0x4bfb: 0x0080, - 0x4bfc: 0x0080, 0x4bfd: 0x0080, 0x4bfe: 0x0080, 0x4bff: 0x0080, - // Block 0x130, offset 0x4c00 - 0x4c00: 0x008c, 0x4c01: 0x0080, 0x4c02: 0x0080, - 0x4c10: 0x0080, 0x4c11: 0x0080, - 0x4c12: 0x0080, 0x4c13: 0x0080, 0x4c14: 0x0080, 0x4c15: 0x0080, 0x4c16: 0x0080, 0x4c17: 0x0080, - 0x4c18: 0x0080, 0x4c19: 0x0080, 0x4c1a: 0x0080, 0x4c1b: 0x0080, 0x4c1c: 0x0080, 0x4c1d: 0x0080, - 0x4c1e: 0x0080, 0x4c1f: 0x0080, 0x4c20: 0x0080, 0x4c21: 0x0080, 0x4c22: 0x0080, 0x4c23: 0x0080, - 0x4c24: 0x0080, 0x4c25: 0x0080, 0x4c26: 0x0080, 0x4c27: 0x0080, 0x4c28: 0x0080, 0x4c29: 0x0080, - 0x4c2a: 0x0080, 0x4c2b: 0x0080, 0x4c2c: 0x0080, 0x4c2d: 0x0080, 0x4c2e: 0x0080, 0x4c2f: 0x0080, - 0x4c30: 0x0080, 0x4c31: 0x0080, 0x4c32: 0x0080, 0x4c33: 0x0080, 0x4c34: 0x0080, 0x4c35: 0x0080, - 0x4c36: 0x0080, 0x4c37: 0x0080, 0x4c38: 0x0080, 0x4c39: 0x0080, 0x4c3a: 0x0080, 0x4c3b: 0x0080, - // Block 0x131, offset 0x4c40 - 0x4c40: 0x0080, 0x4c41: 0x0080, 0x4c42: 0x0080, 0x4c43: 0x0080, 0x4c44: 0x0080, 0x4c45: 0x0080, - 0x4c46: 0x0080, 0x4c47: 0x0080, 0x4c48: 0x0080, - 0x4c50: 0x0080, 0x4c51: 0x0080, - // Block 0x132, offset 0x4c80 - 0x4c80: 0x0080, 0x4c81: 0x0080, 0x4c82: 0x0080, 0x4c83: 0x0080, 0x4c84: 0x0080, 0x4c85: 0x0080, - 0x4c86: 0x0080, 0x4c87: 0x0080, 0x4c88: 0x0080, 0x4c89: 0x0080, 0x4c8a: 0x0080, 0x4c8b: 0x0080, - 0x4c8c: 0x0080, 0x4c8d: 0x0080, 0x4c8e: 0x0080, 0x4c8f: 0x0080, 0x4c90: 0x0080, 0x4c91: 0x0080, - 0x4c92: 0x0080, - 0x4ca0: 0x0080, 0x4ca1: 0x0080, 0x4ca2: 0x0080, 0x4ca3: 0x0080, - 0x4ca4: 0x0080, 0x4ca5: 0x0080, 0x4ca6: 0x0080, 0x4ca7: 0x0080, 0x4ca8: 0x0080, 0x4ca9: 0x0080, - 0x4caa: 0x0080, 0x4cab: 0x0080, 0x4cac: 0x0080, - 0x4cb0: 0x0080, 0x4cb1: 0x0080, 0x4cb2: 0x0080, 0x4cb3: 0x0080, 0x4cb4: 0x0080, 0x4cb5: 0x0080, - 0x4cb6: 0x0080, - // Block 0x133, offset 0x4cc0 - 0x4cc0: 0x0080, 0x4cc1: 0x0080, 0x4cc2: 0x0080, 0x4cc3: 0x0080, 0x4cc4: 0x0080, 0x4cc5: 0x0080, - 0x4cc6: 0x0080, 0x4cc7: 0x0080, 0x4cc8: 0x0080, 0x4cc9: 0x0080, 0x4cca: 0x0080, 0x4ccb: 0x0080, - 0x4ccc: 0x0080, 0x4ccd: 0x0080, 0x4cce: 0x0080, 0x4ccf: 0x0080, 0x4cd0: 0x0080, 0x4cd1: 0x0080, - 0x4cd2: 0x0080, 0x4cd3: 0x0080, 0x4cd4: 0x0080, 0x4cd5: 0x0080, 0x4cd6: 0x0080, 0x4cd7: 0x0080, - 0x4cd8: 0x0080, 0x4cd9: 0x0080, 0x4cda: 0x0080, 0x4cdb: 0x0080, 0x4cdc: 0x0080, 0x4cdd: 0x0080, - 0x4cde: 0x0080, 0x4cdf: 0x0080, 0x4ce0: 0x0080, 0x4ce1: 0x0080, 0x4ce2: 0x0080, 0x4ce3: 0x0080, - 0x4ce4: 0x0080, 0x4ce5: 0x0080, 0x4ce6: 0x0080, 0x4ce7: 0x0080, 0x4ce8: 0x0080, 0x4ce9: 0x0080, - 0x4cea: 0x0080, 0x4ceb: 0x0080, 0x4cec: 0x0080, 0x4ced: 0x0080, 0x4cee: 0x0080, 0x4cef: 0x0080, - 0x4cf0: 0x0080, 0x4cf1: 0x0080, 0x4cf2: 0x0080, 0x4cf3: 0x0080, - // Block 0x134, offset 0x4d00 - 0x4d00: 0x0080, 0x4d01: 0x0080, 0x4d02: 0x0080, 0x4d03: 0x0080, 0x4d04: 0x0080, 0x4d05: 0x0080, - 0x4d06: 0x0080, 0x4d07: 0x0080, 0x4d08: 0x0080, 0x4d09: 0x0080, 0x4d0a: 0x0080, 0x4d0b: 0x0080, - 0x4d0c: 0x0080, 0x4d0d: 0x0080, 0x4d0e: 0x0080, 0x4d0f: 0x0080, 0x4d10: 0x0080, 0x4d11: 0x0080, - 0x4d12: 0x0080, 0x4d13: 0x0080, 0x4d14: 0x0080, - // Block 0x135, offset 0x4d40 - 0x4d40: 0x0080, 0x4d41: 0x0080, 0x4d42: 0x0080, 0x4d43: 0x0080, 0x4d44: 0x0080, 0x4d45: 0x0080, - 0x4d46: 0x0080, 0x4d47: 0x0080, 0x4d48: 0x0080, 0x4d49: 0x0080, 0x4d4a: 0x0080, 0x4d4b: 0x0080, - 0x4d50: 0x0080, 0x4d51: 0x0080, - 0x4d52: 0x0080, 0x4d53: 0x0080, 0x4d54: 0x0080, 0x4d55: 0x0080, 0x4d56: 0x0080, 0x4d57: 0x0080, - 0x4d58: 0x0080, 0x4d59: 0x0080, 0x4d5a: 0x0080, 0x4d5b: 0x0080, 0x4d5c: 0x0080, 0x4d5d: 0x0080, - 0x4d5e: 0x0080, 0x4d5f: 0x0080, 0x4d60: 0x0080, 0x4d61: 0x0080, 0x4d62: 0x0080, 0x4d63: 0x0080, - 0x4d64: 0x0080, 0x4d65: 0x0080, 0x4d66: 0x0080, 0x4d67: 0x0080, 0x4d68: 0x0080, 0x4d69: 0x0080, - 0x4d6a: 0x0080, 0x4d6b: 0x0080, 0x4d6c: 0x0080, 0x4d6d: 0x0080, 0x4d6e: 0x0080, 0x4d6f: 0x0080, - 0x4d70: 0x0080, 0x4d71: 0x0080, 0x4d72: 0x0080, 0x4d73: 0x0080, 0x4d74: 0x0080, 0x4d75: 0x0080, - 0x4d76: 0x0080, 0x4d77: 0x0080, 0x4d78: 0x0080, 0x4d79: 0x0080, 0x4d7a: 0x0080, 0x4d7b: 0x0080, - 0x4d7c: 0x0080, 0x4d7d: 0x0080, 0x4d7e: 0x0080, 0x4d7f: 0x0080, - // Block 0x136, offset 0x4d80 - 0x4d80: 0x0080, 0x4d81: 0x0080, 0x4d82: 0x0080, 0x4d83: 0x0080, 0x4d84: 0x0080, 0x4d85: 0x0080, - 0x4d86: 0x0080, 0x4d87: 0x0080, - 0x4d90: 0x0080, 0x4d91: 0x0080, - 0x4d92: 0x0080, 0x4d93: 0x0080, 0x4d94: 0x0080, 0x4d95: 0x0080, 0x4d96: 0x0080, 0x4d97: 0x0080, - 0x4d98: 0x0080, 0x4d99: 0x0080, - 0x4da0: 0x0080, 0x4da1: 0x0080, 0x4da2: 0x0080, 0x4da3: 0x0080, - 0x4da4: 0x0080, 0x4da5: 0x0080, 0x4da6: 0x0080, 0x4da7: 0x0080, 0x4da8: 0x0080, 0x4da9: 0x0080, - 0x4daa: 0x0080, 0x4dab: 0x0080, 0x4dac: 0x0080, 0x4dad: 0x0080, 0x4dae: 0x0080, 0x4daf: 0x0080, - 0x4db0: 0x0080, 0x4db1: 0x0080, 0x4db2: 0x0080, 0x4db3: 0x0080, 0x4db4: 0x0080, 0x4db5: 0x0080, - 0x4db6: 0x0080, 0x4db7: 0x0080, 0x4db8: 0x0080, 0x4db9: 0x0080, 0x4dba: 0x0080, 0x4dbb: 0x0080, - 0x4dbc: 0x0080, 0x4dbd: 0x0080, 0x4dbe: 0x0080, 0x4dbf: 0x0080, - // Block 0x137, offset 0x4dc0 - 0x4dc0: 0x0080, 0x4dc1: 0x0080, 0x4dc2: 0x0080, 0x4dc3: 0x0080, 0x4dc4: 0x0080, 0x4dc5: 0x0080, - 0x4dc6: 0x0080, 0x4dc7: 0x0080, - 0x4dd0: 0x0080, 0x4dd1: 0x0080, - 0x4dd2: 0x0080, 0x4dd3: 0x0080, 0x4dd4: 0x0080, 0x4dd5: 0x0080, 0x4dd6: 0x0080, 0x4dd7: 0x0080, - 0x4dd8: 0x0080, 0x4dd9: 0x0080, 0x4dda: 0x0080, 0x4ddb: 0x0080, 0x4ddc: 0x0080, 0x4ddd: 0x0080, - 0x4dde: 0x0080, 0x4ddf: 0x0080, 0x4de0: 0x0080, 0x4de1: 0x0080, 0x4de2: 0x0080, 0x4de3: 0x0080, - 0x4de4: 0x0080, 0x4de5: 0x0080, 0x4de6: 0x0080, 0x4de7: 0x0080, 0x4de8: 0x0080, 0x4de9: 0x0080, - 0x4dea: 0x0080, 0x4deb: 0x0080, 0x4dec: 0x0080, 0x4ded: 0x0080, - // Block 0x138, offset 0x4e00 - 0x4e10: 0x0080, 0x4e11: 0x0080, - 0x4e12: 0x0080, 0x4e13: 0x0080, 0x4e14: 0x0080, 0x4e15: 0x0080, 0x4e16: 0x0080, 0x4e17: 0x0080, - 0x4e18: 0x0080, 0x4e19: 0x0080, 0x4e1a: 0x0080, 0x4e1b: 0x0080, 0x4e1c: 0x0080, 0x4e1d: 0x0080, - 0x4e1e: 0x0080, 0x4e20: 0x0080, 0x4e21: 0x0080, 0x4e22: 0x0080, 0x4e23: 0x0080, - 0x4e24: 0x0080, 0x4e25: 0x0080, 0x4e26: 0x0080, 0x4e27: 0x0080, - 0x4e30: 0x0080, 0x4e33: 0x0080, 0x4e34: 0x0080, 0x4e35: 0x0080, - 0x4e36: 0x0080, 0x4e37: 0x0080, 0x4e38: 0x0080, 0x4e39: 0x0080, 0x4e3a: 0x0080, 0x4e3b: 0x0080, - 0x4e3c: 0x0080, 0x4e3d: 0x0080, 0x4e3e: 0x0080, - // Block 0x139, offset 0x4e40 - 0x4e40: 0x0080, 0x4e41: 0x0080, 0x4e42: 0x0080, 0x4e43: 0x0080, 0x4e44: 0x0080, 0x4e45: 0x0080, - 0x4e46: 0x0080, 0x4e47: 0x0080, 0x4e48: 0x0080, 0x4e49: 0x0080, 0x4e4a: 0x0080, 0x4e4b: 0x0080, - 0x4e50: 0x0080, 0x4e51: 0x0080, - 0x4e52: 0x0080, 0x4e53: 0x0080, 0x4e54: 0x0080, 0x4e55: 0x0080, 0x4e56: 0x0080, 0x4e57: 0x0080, - 0x4e58: 0x0080, 0x4e59: 0x0080, 0x4e5a: 0x0080, 0x4e5b: 0x0080, 0x4e5c: 0x0080, 0x4e5d: 0x0080, - 0x4e5e: 0x0080, - // Block 0x13a, offset 0x4e80 - 0x4e80: 0x0080, 0x4e81: 0x0080, 0x4e82: 0x0080, 0x4e83: 0x0080, 0x4e84: 0x0080, 0x4e85: 0x0080, - 0x4e86: 0x0080, 0x4e87: 0x0080, 0x4e88: 0x0080, 0x4e89: 0x0080, 0x4e8a: 0x0080, 0x4e8b: 0x0080, - 0x4e8c: 0x0080, 0x4e8d: 0x0080, 0x4e8e: 0x0080, 0x4e8f: 0x0080, 0x4e90: 0x0080, 0x4e91: 0x0080, - // Block 0x13b, offset 0x4ec0 - 0x4ec0: 0x0080, - // Block 0x13c, offset 0x4f00 - 0x4f00: 0x00cc, 0x4f01: 0x00cc, 0x4f02: 0x00cc, 0x4f03: 0x00cc, 0x4f04: 0x00cc, 0x4f05: 0x00cc, - 0x4f06: 0x00cc, 0x4f07: 0x00cc, 0x4f08: 0x00cc, 0x4f09: 0x00cc, 0x4f0a: 0x00cc, 0x4f0b: 0x00cc, - 0x4f0c: 0x00cc, 0x4f0d: 0x00cc, 0x4f0e: 0x00cc, 0x4f0f: 0x00cc, 0x4f10: 0x00cc, 0x4f11: 0x00cc, - 0x4f12: 0x00cc, 0x4f13: 0x00cc, 0x4f14: 0x00cc, 0x4f15: 0x00cc, 0x4f16: 0x00cc, - // Block 0x13d, offset 0x4f40 - 0x4f40: 0x00cc, 0x4f41: 0x00cc, 0x4f42: 0x00cc, 0x4f43: 0x00cc, 0x4f44: 0x00cc, 0x4f45: 0x00cc, - 0x4f46: 0x00cc, 0x4f47: 0x00cc, 0x4f48: 0x00cc, 0x4f49: 0x00cc, 0x4f4a: 0x00cc, 0x4f4b: 0x00cc, - 0x4f4c: 0x00cc, 0x4f4d: 0x00cc, 0x4f4e: 0x00cc, 0x4f4f: 0x00cc, 0x4f50: 0x00cc, 0x4f51: 0x00cc, - 0x4f52: 0x00cc, 0x4f53: 0x00cc, 0x4f54: 0x00cc, 0x4f55: 0x00cc, 0x4f56: 0x00cc, 0x4f57: 0x00cc, - 0x4f58: 0x00cc, 0x4f59: 0x00cc, 0x4f5a: 0x00cc, 0x4f5b: 0x00cc, 0x4f5c: 0x00cc, 0x4f5d: 0x00cc, - 0x4f5e: 0x00cc, 0x4f5f: 0x00cc, 0x4f60: 0x00cc, 0x4f61: 0x00cc, 0x4f62: 0x00cc, 0x4f63: 0x00cc, - 0x4f64: 0x00cc, 0x4f65: 0x00cc, 0x4f66: 0x00cc, 0x4f67: 0x00cc, 0x4f68: 0x00cc, 0x4f69: 0x00cc, - 0x4f6a: 0x00cc, 0x4f6b: 0x00cc, 0x4f6c: 0x00cc, 0x4f6d: 0x00cc, 0x4f6e: 0x00cc, 0x4f6f: 0x00cc, - 0x4f70: 0x00cc, 0x4f71: 0x00cc, 0x4f72: 0x00cc, 0x4f73: 0x00cc, 0x4f74: 0x00cc, - // Block 0x13e, offset 0x4f80 - 0x4f80: 0x00cc, 0x4f81: 0x00cc, 0x4f82: 0x00cc, 0x4f83: 0x00cc, 0x4f84: 0x00cc, 0x4f85: 0x00cc, - 0x4f86: 0x00cc, 0x4f87: 0x00cc, 0x4f88: 0x00cc, 0x4f89: 0x00cc, 0x4f8a: 0x00cc, 0x4f8b: 0x00cc, - 0x4f8c: 0x00cc, 0x4f8d: 0x00cc, 0x4f8e: 0x00cc, 0x4f8f: 0x00cc, 0x4f90: 0x00cc, 0x4f91: 0x00cc, - 0x4f92: 0x00cc, 0x4f93: 0x00cc, 0x4f94: 0x00cc, 0x4f95: 0x00cc, 0x4f96: 0x00cc, 0x4f97: 0x00cc, - 0x4f98: 0x00cc, 0x4f99: 0x00cc, 0x4f9a: 0x00cc, 0x4f9b: 0x00cc, 0x4f9c: 0x00cc, 0x4f9d: 0x00cc, - 0x4fa0: 0x00cc, 0x4fa1: 0x00cc, 0x4fa2: 0x00cc, 0x4fa3: 0x00cc, - 0x4fa4: 0x00cc, 0x4fa5: 0x00cc, 0x4fa6: 0x00cc, 0x4fa7: 0x00cc, 0x4fa8: 0x00cc, 0x4fa9: 0x00cc, - 0x4faa: 0x00cc, 0x4fab: 0x00cc, 0x4fac: 0x00cc, 0x4fad: 0x00cc, 0x4fae: 0x00cc, 0x4faf: 0x00cc, - 0x4fb0: 0x00cc, 0x4fb1: 0x00cc, 0x4fb2: 0x00cc, 0x4fb3: 0x00cc, 0x4fb4: 0x00cc, 0x4fb5: 0x00cc, - 0x4fb6: 0x00cc, 0x4fb7: 0x00cc, 0x4fb8: 0x00cc, 0x4fb9: 0x00cc, 0x4fba: 0x00cc, 0x4fbb: 0x00cc, - 0x4fbc: 0x00cc, 0x4fbd: 0x00cc, 0x4fbe: 0x00cc, 0x4fbf: 0x00cc, - // Block 0x13f, offset 0x4fc0 - 0x4fc0: 0x00cc, 0x4fc1: 0x00cc, 0x4fc2: 0x00cc, 0x4fc3: 0x00cc, 0x4fc4: 0x00cc, 0x4fc5: 0x00cc, - 0x4fc6: 0x00cc, 0x4fc7: 0x00cc, 0x4fc8: 0x00cc, 0x4fc9: 0x00cc, 0x4fca: 0x00cc, 0x4fcb: 0x00cc, - 0x4fcc: 0x00cc, 0x4fcd: 0x00cc, 0x4fce: 0x00cc, 0x4fcf: 0x00cc, 0x4fd0: 0x00cc, 0x4fd1: 0x00cc, - 0x4fd2: 0x00cc, 0x4fd3: 0x00cc, 0x4fd4: 0x00cc, 0x4fd5: 0x00cc, 0x4fd6: 0x00cc, 0x4fd7: 0x00cc, - 0x4fd8: 0x00cc, 0x4fd9: 0x00cc, 0x4fda: 0x00cc, 0x4fdb: 0x00cc, 0x4fdc: 0x00cc, 0x4fdd: 0x00cc, - 0x4fde: 0x00cc, 0x4fdf: 0x00cc, 0x4fe0: 0x00cc, 0x4fe1: 0x00cc, - // Block 0x140, offset 0x5000 - 0x5000: 0x008c, 0x5001: 0x008c, 0x5002: 0x008c, 0x5003: 0x008c, 0x5004: 0x008c, 0x5005: 0x008c, - 0x5006: 0x008c, 0x5007: 0x008c, 0x5008: 0x008c, 0x5009: 0x008c, 0x500a: 0x008c, 0x500b: 0x008c, - 0x500c: 0x008c, 0x500d: 0x008c, 0x500e: 0x008c, 0x500f: 0x008c, 0x5010: 0x008c, 0x5011: 0x008c, - 0x5012: 0x008c, 0x5013: 0x008c, 0x5014: 0x008c, 0x5015: 0x008c, 0x5016: 0x008c, 0x5017: 0x008c, - 0x5018: 0x008c, 0x5019: 0x008c, 0x501a: 0x008c, 0x501b: 0x008c, 0x501c: 0x008c, 0x501d: 0x008c, - // Block 0x141, offset 0x5040 - 0x5041: 0x0040, - 0x5060: 0x0040, 0x5061: 0x0040, 0x5062: 0x0040, 0x5063: 0x0040, - 0x5064: 0x0040, 0x5065: 0x0040, 0x5066: 0x0040, 0x5067: 0x0040, 0x5068: 0x0040, 0x5069: 0x0040, - 0x506a: 0x0040, 0x506b: 0x0040, 0x506c: 0x0040, 0x506d: 0x0040, 0x506e: 0x0040, 0x506f: 0x0040, - 0x5070: 0x0040, 0x5071: 0x0040, 0x5072: 0x0040, 0x5073: 0x0040, 0x5074: 0x0040, 0x5075: 0x0040, - 0x5076: 0x0040, 0x5077: 0x0040, 0x5078: 0x0040, 0x5079: 0x0040, 0x507a: 0x0040, 0x507b: 0x0040, - 0x507c: 0x0040, 0x507d: 0x0040, 0x507e: 0x0040, 0x507f: 0x0040, - // Block 0x142, offset 0x5080 - 0x5080: 0x0040, 0x5081: 0x0040, 0x5082: 0x0040, 0x5083: 0x0040, 0x5084: 0x0040, 0x5085: 0x0040, - 0x5086: 0x0040, 0x5087: 0x0040, 0x5088: 0x0040, 0x5089: 0x0040, 0x508a: 0x0040, 0x508b: 0x0040, - 0x508c: 0x0040, 0x508d: 0x0040, 0x508e: 0x0040, 0x508f: 0x0040, 0x5090: 0x0040, 0x5091: 0x0040, - 0x5092: 0x0040, 0x5093: 0x0040, 0x5094: 0x0040, 0x5095: 0x0040, 0x5096: 0x0040, 0x5097: 0x0040, - 0x5098: 0x0040, 0x5099: 0x0040, 0x509a: 0x0040, 0x509b: 0x0040, 0x509c: 0x0040, 0x509d: 0x0040, - 0x509e: 0x0040, 0x509f: 0x0040, 0x50a0: 0x0040, 0x50a1: 0x0040, 0x50a2: 0x0040, 0x50a3: 0x0040, - 0x50a4: 0x0040, 0x50a5: 0x0040, 0x50a6: 0x0040, 0x50a7: 0x0040, 0x50a8: 0x0040, 0x50a9: 0x0040, - 0x50aa: 0x0040, 0x50ab: 0x0040, 0x50ac: 0x0040, 0x50ad: 0x0040, 0x50ae: 0x0040, 0x50af: 0x0040, - // Block 0x143, offset 0x50c0 - 0x50c0: 0x0040, 0x50c1: 0x0040, 0x50c2: 0x0040, 0x50c3: 0x0040, 0x50c4: 0x0040, 0x50c5: 0x0040, - 0x50c6: 0x0040, 0x50c7: 0x0040, 0x50c8: 0x0040, 0x50c9: 0x0040, 0x50ca: 0x0040, 0x50cb: 0x0040, - 0x50cc: 0x0040, 0x50cd: 0x0040, 0x50ce: 0x0040, 0x50cf: 0x0040, 0x50d0: 0x0040, 0x50d1: 0x0040, - 0x50d2: 0x0040, 0x50d3: 0x0040, 0x50d4: 0x0040, 0x50d5: 0x0040, 0x50d6: 0x0040, 0x50d7: 0x0040, - 0x50d8: 0x0040, 0x50d9: 0x0040, 0x50da: 0x0040, 0x50db: 0x0040, 0x50dc: 0x0040, 0x50dd: 0x0040, - 0x50de: 0x0040, 0x50df: 0x0040, 0x50e0: 0x0040, 0x50e1: 0x0040, 0x50e2: 0x0040, 0x50e3: 0x0040, - 0x50e4: 0x0040, 0x50e5: 0x0040, 0x50e6: 0x0040, 0x50e7: 0x0040, 0x50e8: 0x0040, 0x50e9: 0x0040, - 0x50ea: 0x0040, 0x50eb: 0x0040, 0x50ec: 0x0040, 0x50ed: 0x0040, 0x50ee: 0x0040, 0x50ef: 0x0040, - 0x50f0: 0x0040, 0x50f1: 0x0040, 0x50f2: 0x0040, 0x50f3: 0x0040, 0x50f4: 0x0040, 0x50f5: 0x0040, - 0x50f6: 0x0040, 0x50f7: 0x0040, 0x50f8: 0x0040, 0x50f9: 0x0040, 0x50fa: 0x0040, 0x50fb: 0x0040, - 0x50fc: 0x0040, 0x50fd: 0x0040, -} - -// derivedPropertiesIndex: 36 blocks, 2304 entries, 4608 bytes -// Block 0 is the zero block. -var derivedPropertiesIndex = [2304]uint16{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x01, 0xc3: 0x02, 0xc4: 0x03, 0xc5: 0x04, 0xc6: 0x05, 0xc7: 0x06, - 0xc8: 0x05, 0xc9: 0x05, 0xca: 0x07, 0xcb: 0x08, 0xcc: 0x09, 0xcd: 0x0a, 0xce: 0x0b, 0xcf: 0x0c, - 0xd0: 0x05, 0xd1: 0x05, 0xd2: 0x0d, 0xd3: 0x05, 0xd4: 0x0e, 0xd5: 0x0f, 0xd6: 0x10, 0xd7: 0x11, - 0xd8: 0x12, 0xd9: 0x13, 0xda: 0x14, 0xdb: 0x15, 0xdc: 0x16, 0xdd: 0x17, 0xde: 0x18, 0xdf: 0x19, - 0xe0: 0x02, 0xe1: 0x03, 0xe2: 0x04, 0xe3: 0x05, 0xe4: 0x06, 0xe5: 0x07, 0xe6: 0x07, 0xe7: 0x07, - 0xe8: 0x07, 0xe9: 0x08, 0xea: 0x09, 0xeb: 0x0a, 0xec: 0x0a, 0xed: 0x0b, 0xee: 0x0c, 0xef: 0x0d, - 0xf0: 0x1d, 0xf3: 0x20, 0xf4: 0x21, - // Block 0x4, offset 0x100 - 0x120: 0x1a, 0x121: 0x1b, 0x122: 0x1c, 0x123: 0x1d, 0x124: 0x1e, 0x125: 0x1f, 0x126: 0x20, 0x127: 0x21, - 0x128: 0x22, 0x129: 0x23, 0x12a: 0x24, 0x12b: 0x25, 0x12c: 0x26, 0x12d: 0x27, 0x12e: 0x28, 0x12f: 0x29, - 0x130: 0x2a, 0x131: 0x2b, 0x132: 0x2c, 0x133: 0x2d, 0x134: 0x2e, 0x135: 0x2f, 0x136: 0x30, 0x137: 0x31, - 0x138: 0x32, 0x139: 0x33, 0x13a: 0x34, 0x13b: 0x35, 0x13c: 0x36, 0x13d: 0x37, 0x13e: 0x38, 0x13f: 0x39, - // Block 0x5, offset 0x140 - 0x140: 0x3a, 0x141: 0x3b, 0x142: 0x3c, 0x143: 0x3d, 0x144: 0x3e, 0x145: 0x3e, 0x146: 0x3e, 0x147: 0x3e, - 0x148: 0x05, 0x149: 0x3f, 0x14a: 0x40, 0x14b: 0x41, 0x14c: 0x42, 0x14d: 0x43, 0x14e: 0x44, 0x14f: 0x45, - 0x150: 0x46, 0x151: 0x05, 0x152: 0x05, 0x153: 0x05, 0x154: 0x05, 0x155: 0x05, 0x156: 0x05, 0x157: 0x05, - 0x158: 0x05, 0x159: 0x47, 0x15a: 0x48, 0x15b: 0x49, 0x15c: 0x4a, 0x15d: 0x4b, 0x15e: 0x4c, 0x15f: 0x4d, - 0x160: 0x4e, 0x161: 0x4f, 0x162: 0x50, 0x163: 0x51, 0x164: 0x52, 0x165: 0x53, 0x166: 0x54, 0x167: 0x55, - 0x168: 0x56, 0x169: 0x57, 0x16a: 0x58, 0x16c: 0x59, 0x16d: 0x5a, 0x16e: 0x5b, 0x16f: 0x5c, - 0x170: 0x5d, 0x171: 0x5e, 0x172: 0x5f, 0x173: 0x60, 0x174: 0x61, 0x175: 0x62, 0x176: 0x63, 0x177: 0x64, - 0x178: 0x05, 0x179: 0x05, 0x17a: 0x65, 0x17b: 0x05, 0x17c: 0x66, 0x17d: 0x67, 0x17e: 0x68, 0x17f: 0x69, - // Block 0x6, offset 0x180 - 0x180: 0x6a, 0x181: 0x6b, 0x182: 0x6c, 0x183: 0x6d, 0x184: 0x6e, 0x185: 0x6f, 0x186: 0x70, 0x187: 0x71, - 0x188: 0x71, 0x189: 0x71, 0x18a: 0x71, 0x18b: 0x71, 0x18c: 0x71, 0x18d: 0x71, 0x18e: 0x71, 0x18f: 0x72, - 0x190: 0x73, 0x191: 0x74, 0x192: 0x71, 0x193: 0x71, 0x194: 0x71, 0x195: 0x71, 0x196: 0x71, 0x197: 0x71, - 0x198: 0x71, 0x199: 0x71, 0x19a: 0x71, 0x19b: 0x71, 0x19c: 0x71, 0x19d: 0x71, 0x19e: 0x71, 0x19f: 0x71, - 0x1a0: 0x71, 0x1a1: 0x71, 0x1a2: 0x71, 0x1a3: 0x71, 0x1a4: 0x71, 0x1a5: 0x71, 0x1a6: 0x71, 0x1a7: 0x71, - 0x1a8: 0x71, 0x1a9: 0x71, 0x1aa: 0x71, 0x1ab: 0x71, 0x1ac: 0x71, 0x1ad: 0x75, 0x1ae: 0x76, 0x1af: 0x77, - 0x1b0: 0x78, 0x1b1: 0x79, 0x1b2: 0x05, 0x1b3: 0x7a, 0x1b4: 0x7b, 0x1b5: 0x7c, 0x1b6: 0x7d, 0x1b7: 0x7e, - 0x1b8: 0x7f, 0x1b9: 0x80, 0x1ba: 0x81, 0x1bb: 0x82, 0x1bc: 0x83, 0x1bd: 0x83, 0x1be: 0x83, 0x1bf: 0x84, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x85, 0x1c1: 0x86, 0x1c2: 0x87, 0x1c3: 0x88, 0x1c4: 0x89, 0x1c5: 0x8a, 0x1c6: 0x8b, 0x1c7: 0x8c, - 0x1c8: 0x8d, 0x1c9: 0x71, 0x1ca: 0x71, 0x1cb: 0x8e, 0x1cc: 0x83, 0x1cd: 0x8f, 0x1ce: 0x71, 0x1cf: 0x71, - 0x1d0: 0x90, 0x1d1: 0x90, 0x1d2: 0x90, 0x1d3: 0x90, 0x1d4: 0x90, 0x1d5: 0x90, 0x1d6: 0x90, 0x1d7: 0x90, - 0x1d8: 0x90, 0x1d9: 0x90, 0x1da: 0x90, 0x1db: 0x90, 0x1dc: 0x90, 0x1dd: 0x90, 0x1de: 0x90, 0x1df: 0x90, - 0x1e0: 0x90, 0x1e1: 0x90, 0x1e2: 0x90, 0x1e3: 0x90, 0x1e4: 0x90, 0x1e5: 0x90, 0x1e6: 0x90, 0x1e7: 0x90, - 0x1e8: 0x90, 0x1e9: 0x90, 0x1ea: 0x90, 0x1eb: 0x90, 0x1ec: 0x90, 0x1ed: 0x90, 0x1ee: 0x90, 0x1ef: 0x90, - 0x1f0: 0x90, 0x1f1: 0x90, 0x1f2: 0x90, 0x1f3: 0x90, 0x1f4: 0x90, 0x1f5: 0x90, 0x1f6: 0x90, 0x1f7: 0x90, - 0x1f8: 0x90, 0x1f9: 0x90, 0x1fa: 0x90, 0x1fb: 0x90, 0x1fc: 0x90, 0x1fd: 0x90, 0x1fe: 0x90, 0x1ff: 0x90, - // Block 0x8, offset 0x200 - 0x200: 0x90, 0x201: 0x90, 0x202: 0x90, 0x203: 0x90, 0x204: 0x90, 0x205: 0x90, 0x206: 0x90, 0x207: 0x90, - 0x208: 0x90, 0x209: 0x90, 0x20a: 0x90, 0x20b: 0x90, 0x20c: 0x90, 0x20d: 0x90, 0x20e: 0x90, 0x20f: 0x90, - 0x210: 0x90, 0x211: 0x90, 0x212: 0x90, 0x213: 0x90, 0x214: 0x90, 0x215: 0x90, 0x216: 0x90, 0x217: 0x90, - 0x218: 0x90, 0x219: 0x90, 0x21a: 0x90, 0x21b: 0x90, 0x21c: 0x90, 0x21d: 0x90, 0x21e: 0x90, 0x21f: 0x90, - 0x220: 0x90, 0x221: 0x90, 0x222: 0x90, 0x223: 0x90, 0x224: 0x90, 0x225: 0x90, 0x226: 0x90, 0x227: 0x90, - 0x228: 0x90, 0x229: 0x90, 0x22a: 0x90, 0x22b: 0x90, 0x22c: 0x90, 0x22d: 0x90, 0x22e: 0x90, 0x22f: 0x90, - 0x230: 0x90, 0x231: 0x90, 0x232: 0x90, 0x233: 0x90, 0x234: 0x90, 0x235: 0x90, 0x236: 0x91, 0x237: 0x71, - 0x238: 0x90, 0x239: 0x90, 0x23a: 0x90, 0x23b: 0x90, 0x23c: 0x90, 0x23d: 0x90, 0x23e: 0x90, 0x23f: 0x90, - // Block 0x9, offset 0x240 - 0x240: 0x90, 0x241: 0x90, 0x242: 0x90, 0x243: 0x90, 0x244: 0x90, 0x245: 0x90, 0x246: 0x90, 0x247: 0x90, - 0x248: 0x90, 0x249: 0x90, 0x24a: 0x90, 0x24b: 0x90, 0x24c: 0x90, 0x24d: 0x90, 0x24e: 0x90, 0x24f: 0x90, - 0x250: 0x90, 0x251: 0x90, 0x252: 0x90, 0x253: 0x90, 0x254: 0x90, 0x255: 0x90, 0x256: 0x90, 0x257: 0x90, - 0x258: 0x90, 0x259: 0x90, 0x25a: 0x90, 0x25b: 0x90, 0x25c: 0x90, 0x25d: 0x90, 0x25e: 0x90, 0x25f: 0x90, - 0x260: 0x90, 0x261: 0x90, 0x262: 0x90, 0x263: 0x90, 0x264: 0x90, 0x265: 0x90, 0x266: 0x90, 0x267: 0x90, - 0x268: 0x90, 0x269: 0x90, 0x26a: 0x90, 0x26b: 0x90, 0x26c: 0x90, 0x26d: 0x90, 0x26e: 0x90, 0x26f: 0x90, - 0x270: 0x90, 0x271: 0x90, 0x272: 0x90, 0x273: 0x90, 0x274: 0x90, 0x275: 0x90, 0x276: 0x90, 0x277: 0x90, - 0x278: 0x90, 0x279: 0x90, 0x27a: 0x90, 0x27b: 0x90, 0x27c: 0x90, 0x27d: 0x90, 0x27e: 0x90, 0x27f: 0x90, - // Block 0xa, offset 0x280 - 0x280: 0x90, 0x281: 0x90, 0x282: 0x90, 0x283: 0x90, 0x284: 0x90, 0x285: 0x90, 0x286: 0x90, 0x287: 0x90, - 0x288: 0x90, 0x289: 0x90, 0x28a: 0x90, 0x28b: 0x90, 0x28c: 0x90, 0x28d: 0x90, 0x28e: 0x90, 0x28f: 0x90, - 0x290: 0x90, 0x291: 0x90, 0x292: 0x90, 0x293: 0x90, 0x294: 0x90, 0x295: 0x90, 0x296: 0x90, 0x297: 0x90, - 0x298: 0x90, 0x299: 0x90, 0x29a: 0x90, 0x29b: 0x90, 0x29c: 0x90, 0x29d: 0x90, 0x29e: 0x90, 0x29f: 0x90, - 0x2a0: 0x90, 0x2a1: 0x90, 0x2a2: 0x90, 0x2a3: 0x90, 0x2a4: 0x90, 0x2a5: 0x90, 0x2a6: 0x90, 0x2a7: 0x90, - 0x2a8: 0x90, 0x2a9: 0x90, 0x2aa: 0x90, 0x2ab: 0x90, 0x2ac: 0x90, 0x2ad: 0x90, 0x2ae: 0x90, 0x2af: 0x90, - 0x2b0: 0x90, 0x2b1: 0x90, 0x2b2: 0x90, 0x2b3: 0x90, 0x2b4: 0x90, 0x2b5: 0x90, 0x2b6: 0x90, 0x2b7: 0x90, - 0x2b8: 0x90, 0x2b9: 0x90, 0x2ba: 0x90, 0x2bb: 0x90, 0x2bc: 0x90, 0x2bd: 0x90, 0x2be: 0x90, 0x2bf: 0x92, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x05, 0x2c1: 0x05, 0x2c2: 0x05, 0x2c3: 0x05, 0x2c4: 0x05, 0x2c5: 0x05, 0x2c6: 0x05, 0x2c7: 0x05, - 0x2c8: 0x05, 0x2c9: 0x05, 0x2ca: 0x05, 0x2cb: 0x05, 0x2cc: 0x05, 0x2cd: 0x05, 0x2ce: 0x05, 0x2cf: 0x05, - 0x2d0: 0x05, 0x2d1: 0x05, 0x2d2: 0x93, 0x2d3: 0x94, 0x2d4: 0x05, 0x2d5: 0x05, 0x2d6: 0x05, 0x2d7: 0x05, - 0x2d8: 0x95, 0x2d9: 0x96, 0x2da: 0x97, 0x2db: 0x98, 0x2dc: 0x99, 0x2dd: 0x9a, 0x2de: 0x9b, 0x2df: 0x9c, - 0x2e0: 0x9d, 0x2e1: 0x9e, 0x2e2: 0x05, 0x2e3: 0x9f, 0x2e4: 0xa0, 0x2e5: 0xa1, 0x2e6: 0xa2, 0x2e7: 0xa3, - 0x2e8: 0xa4, 0x2e9: 0xa5, 0x2ea: 0xa6, 0x2eb: 0xa7, 0x2ec: 0xa8, 0x2ed: 0xa9, 0x2ee: 0x05, 0x2ef: 0xaa, - 0x2f0: 0x05, 0x2f1: 0x05, 0x2f2: 0x05, 0x2f3: 0x05, 0x2f4: 0x05, 0x2f5: 0x05, 0x2f6: 0x05, 0x2f7: 0x05, - 0x2f8: 0x05, 0x2f9: 0x05, 0x2fa: 0x05, 0x2fb: 0x05, 0x2fc: 0x05, 0x2fd: 0x05, 0x2fe: 0x05, 0x2ff: 0x05, - // Block 0xc, offset 0x300 - 0x300: 0x05, 0x301: 0x05, 0x302: 0x05, 0x303: 0x05, 0x304: 0x05, 0x305: 0x05, 0x306: 0x05, 0x307: 0x05, - 0x308: 0x05, 0x309: 0x05, 0x30a: 0x05, 0x30b: 0x05, 0x30c: 0x05, 0x30d: 0x05, 0x30e: 0x05, 0x30f: 0x05, - 0x310: 0x05, 0x311: 0x05, 0x312: 0x05, 0x313: 0x05, 0x314: 0x05, 0x315: 0x05, 0x316: 0x05, 0x317: 0x05, - 0x318: 0x05, 0x319: 0x05, 0x31a: 0x05, 0x31b: 0x05, 0x31c: 0x05, 0x31d: 0x05, 0x31e: 0x05, 0x31f: 0x05, - 0x320: 0x05, 0x321: 0x05, 0x322: 0x05, 0x323: 0x05, 0x324: 0x05, 0x325: 0x05, 0x326: 0x05, 0x327: 0x05, - 0x328: 0x05, 0x329: 0x05, 0x32a: 0x05, 0x32b: 0x05, 0x32c: 0x05, 0x32d: 0x05, 0x32e: 0x05, 0x32f: 0x05, - 0x330: 0x05, 0x331: 0x05, 0x332: 0x05, 0x333: 0x05, 0x334: 0x05, 0x335: 0x05, 0x336: 0x05, 0x337: 0x05, - 0x338: 0x05, 0x339: 0x05, 0x33a: 0x05, 0x33b: 0x05, 0x33c: 0x05, 0x33d: 0x05, 0x33e: 0x05, 0x33f: 0x05, - // Block 0xd, offset 0x340 - 0x340: 0x05, 0x341: 0x05, 0x342: 0x05, 0x343: 0x05, 0x344: 0x05, 0x345: 0x05, 0x346: 0x05, 0x347: 0x05, - 0x348: 0x05, 0x349: 0x05, 0x34a: 0x05, 0x34b: 0x05, 0x34c: 0x05, 0x34d: 0x05, 0x34e: 0x05, 0x34f: 0x05, - 0x350: 0x05, 0x351: 0x05, 0x352: 0x05, 0x353: 0x05, 0x354: 0x05, 0x355: 0x05, 0x356: 0x05, 0x357: 0x05, - 0x358: 0x05, 0x359: 0x05, 0x35a: 0x05, 0x35b: 0x05, 0x35c: 0x05, 0x35d: 0x05, 0x35e: 0xab, 0x35f: 0xac, - // Block 0xe, offset 0x380 - 0x380: 0x3e, 0x381: 0x3e, 0x382: 0x3e, 0x383: 0x3e, 0x384: 0x3e, 0x385: 0x3e, 0x386: 0x3e, 0x387: 0x3e, - 0x388: 0x3e, 0x389: 0x3e, 0x38a: 0x3e, 0x38b: 0x3e, 0x38c: 0x3e, 0x38d: 0x3e, 0x38e: 0x3e, 0x38f: 0x3e, - 0x390: 0x3e, 0x391: 0x3e, 0x392: 0x3e, 0x393: 0x3e, 0x394: 0x3e, 0x395: 0x3e, 0x396: 0x3e, 0x397: 0x3e, - 0x398: 0x3e, 0x399: 0x3e, 0x39a: 0x3e, 0x39b: 0x3e, 0x39c: 0x3e, 0x39d: 0x3e, 0x39e: 0x3e, 0x39f: 0x3e, - 0x3a0: 0x3e, 0x3a1: 0x3e, 0x3a2: 0x3e, 0x3a3: 0x3e, 0x3a4: 0x3e, 0x3a5: 0x3e, 0x3a6: 0x3e, 0x3a7: 0x3e, - 0x3a8: 0x3e, 0x3a9: 0x3e, 0x3aa: 0x3e, 0x3ab: 0x3e, 0x3ac: 0x3e, 0x3ad: 0x3e, 0x3ae: 0x3e, 0x3af: 0x3e, - 0x3b0: 0x3e, 0x3b1: 0x3e, 0x3b2: 0x3e, 0x3b3: 0x3e, 0x3b4: 0x3e, 0x3b5: 0x3e, 0x3b6: 0x3e, 0x3b7: 0x3e, - 0x3b8: 0x3e, 0x3b9: 0x3e, 0x3ba: 0x3e, 0x3bb: 0x3e, 0x3bc: 0x3e, 0x3bd: 0x3e, 0x3be: 0x3e, 0x3bf: 0x3e, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x3e, 0x3c1: 0x3e, 0x3c2: 0x3e, 0x3c3: 0x3e, 0x3c4: 0x3e, 0x3c5: 0x3e, 0x3c6: 0x3e, 0x3c7: 0x3e, - 0x3c8: 0x3e, 0x3c9: 0x3e, 0x3ca: 0x3e, 0x3cb: 0x3e, 0x3cc: 0x3e, 0x3cd: 0x3e, 0x3ce: 0x3e, 0x3cf: 0x3e, - 0x3d0: 0x3e, 0x3d1: 0x3e, 0x3d2: 0x3e, 0x3d3: 0x3e, 0x3d4: 0x3e, 0x3d5: 0x3e, 0x3d6: 0x3e, 0x3d7: 0x3e, - 0x3d8: 0x3e, 0x3d9: 0x3e, 0x3da: 0x3e, 0x3db: 0x3e, 0x3dc: 0x3e, 0x3dd: 0x3e, 0x3de: 0x3e, 0x3df: 0x3e, - 0x3e0: 0x3e, 0x3e1: 0x3e, 0x3e2: 0x3e, 0x3e3: 0x3e, 0x3e4: 0x83, 0x3e5: 0x83, 0x3e6: 0x83, 0x3e7: 0x83, - 0x3e8: 0xad, 0x3e9: 0xae, 0x3ea: 0x83, 0x3eb: 0xaf, 0x3ec: 0xb0, 0x3ed: 0xb1, 0x3ee: 0x71, 0x3ef: 0xb2, - 0x3f0: 0x71, 0x3f1: 0x71, 0x3f2: 0x71, 0x3f3: 0x71, 0x3f4: 0x71, 0x3f5: 0xb3, 0x3f6: 0xb4, 0x3f7: 0xb5, - 0x3f8: 0xb6, 0x3f9: 0xb7, 0x3fa: 0x71, 0x3fb: 0xb8, 0x3fc: 0xb9, 0x3fd: 0xba, 0x3fe: 0xbb, 0x3ff: 0xbc, - // Block 0x10, offset 0x400 - 0x400: 0xbd, 0x401: 0xbe, 0x402: 0x05, 0x403: 0xbf, 0x404: 0xc0, 0x405: 0xc1, 0x406: 0xc2, 0x407: 0xc3, - 0x40a: 0xc4, 0x40b: 0xc5, 0x40c: 0xc6, 0x40d: 0xc7, 0x40e: 0xc8, 0x40f: 0xc9, - 0x410: 0x05, 0x411: 0x05, 0x412: 0xca, 0x413: 0xcb, 0x414: 0xcc, 0x415: 0xcd, - 0x418: 0x05, 0x419: 0x05, 0x41a: 0x05, 0x41b: 0x05, 0x41c: 0xce, 0x41d: 0xcf, - 0x420: 0xd0, 0x421: 0xd1, 0x422: 0xd2, 0x423: 0xd3, 0x424: 0xd4, 0x426: 0xd5, 0x427: 0xb4, - 0x428: 0xd6, 0x429: 0xd7, 0x42a: 0xd8, 0x42b: 0xd9, 0x42c: 0xda, 0x42d: 0xdb, 0x42e: 0xdc, - 0x430: 0x05, 0x431: 0x5f, 0x432: 0xdd, 0x433: 0xde, - 0x439: 0xdf, - // Block 0x11, offset 0x440 - 0x440: 0xe0, 0x441: 0xe1, 0x442: 0xe2, 0x443: 0xe3, 0x444: 0xe4, 0x445: 0xe5, 0x446: 0xe6, 0x447: 0xe7, - 0x448: 0xe8, 0x44a: 0xe9, 0x44b: 0xea, 0x44c: 0xeb, 0x44d: 0xec, - 0x450: 0xed, 0x451: 0xee, 0x452: 0xef, 0x453: 0xf0, 0x456: 0xf1, 0x457: 0xf2, - 0x458: 0xf3, 0x459: 0xf4, 0x45a: 0xf5, 0x45b: 0xf6, 0x45c: 0xf7, - 0x462: 0xf8, 0x463: 0xf9, - 0x46b: 0xfa, - 0x470: 0xfb, 0x471: 0xfc, 0x472: 0xfd, - // Block 0x12, offset 0x480 - 0x480: 0x05, 0x481: 0x05, 0x482: 0x05, 0x483: 0x05, 0x484: 0x05, 0x485: 0x05, 0x486: 0x05, 0x487: 0x05, - 0x488: 0x05, 0x489: 0x05, 0x48a: 0x05, 0x48b: 0x05, 0x48c: 0x05, 0x48d: 0x05, 0x48e: 0xfe, - 0x490: 0x71, 0x491: 0xff, 0x492: 0x05, 0x493: 0x05, 0x494: 0x05, 0x495: 0x100, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x05, 0x4c1: 0x05, 0x4c2: 0x05, 0x4c3: 0x05, 0x4c4: 0x05, 0x4c5: 0x05, 0x4c6: 0x05, 0x4c7: 0x05, - 0x4c8: 0x05, 0x4c9: 0x05, 0x4ca: 0x05, 0x4cb: 0x05, 0x4cc: 0x05, 0x4cd: 0x05, 0x4ce: 0x05, 0x4cf: 0x05, - 0x4d0: 0x101, - // Block 0x14, offset 0x500 - 0x510: 0x05, 0x511: 0x05, 0x512: 0x05, 0x513: 0x05, 0x514: 0x05, 0x515: 0x05, 0x516: 0x05, 0x517: 0x05, - 0x518: 0x05, 0x519: 0x102, - // Block 0x15, offset 0x540 - 0x560: 0x05, 0x561: 0x05, 0x562: 0x05, 0x563: 0x05, 0x564: 0x05, 0x565: 0x05, 0x566: 0x05, 0x567: 0x05, - 0x568: 0xfa, 0x569: 0x103, 0x56b: 0x104, 0x56c: 0x105, 0x56d: 0x106, 0x56e: 0x107, - 0x57c: 0x05, 0x57d: 0x108, 0x57e: 0x109, 0x57f: 0x10a, - // Block 0x16, offset 0x580 - 0x580: 0x05, 0x581: 0x05, 0x582: 0x05, 0x583: 0x05, 0x584: 0x05, 0x585: 0x05, 0x586: 0x05, 0x587: 0x05, - 0x588: 0x05, 0x589: 0x05, 0x58a: 0x05, 0x58b: 0x05, 0x58c: 0x05, 0x58d: 0x05, 0x58e: 0x05, 0x58f: 0x05, - 0x590: 0x05, 0x591: 0x05, 0x592: 0x05, 0x593: 0x05, 0x594: 0x05, 0x595: 0x05, 0x596: 0x05, 0x597: 0x05, - 0x598: 0x05, 0x599: 0x05, 0x59a: 0x05, 0x59b: 0x05, 0x59c: 0x05, 0x59d: 0x05, 0x59e: 0x05, 0x59f: 0x10b, - 0x5a0: 0x05, 0x5a1: 0x05, 0x5a2: 0x05, 0x5a3: 0x05, 0x5a4: 0x05, 0x5a5: 0x05, 0x5a6: 0x05, 0x5a7: 0x05, - 0x5a8: 0x05, 0x5a9: 0x05, 0x5aa: 0x05, 0x5ab: 0xdd, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x10c, - 0x5f0: 0x05, 0x5f1: 0x10d, 0x5f2: 0x10e, - // Block 0x18, offset 0x600 - 0x600: 0x71, 0x601: 0x71, 0x602: 0x71, 0x603: 0x10f, 0x604: 0x110, 0x605: 0x111, 0x606: 0x112, 0x607: 0x113, - 0x608: 0xc1, 0x609: 0x114, 0x60c: 0x71, 0x60d: 0x115, - 0x610: 0x71, 0x611: 0x116, 0x612: 0x117, 0x613: 0x118, 0x614: 0x119, 0x615: 0x11a, 0x616: 0x71, 0x617: 0x71, - 0x618: 0x71, 0x619: 0x71, 0x61a: 0x11b, 0x61b: 0x71, 0x61c: 0x71, 0x61d: 0x71, 0x61e: 0x71, 0x61f: 0x11c, - 0x620: 0x71, 0x621: 0x71, 0x622: 0x71, 0x623: 0x71, 0x624: 0x71, 0x625: 0x71, 0x626: 0x71, 0x627: 0x71, - 0x628: 0x11d, 0x629: 0x11e, 0x62a: 0x11f, - // Block 0x19, offset 0x640 - 0x640: 0x120, - 0x660: 0x05, 0x661: 0x05, 0x662: 0x05, 0x663: 0x121, 0x664: 0x122, 0x665: 0x123, - 0x678: 0x124, 0x679: 0x125, 0x67a: 0x126, 0x67b: 0x127, - // Block 0x1a, offset 0x680 - 0x680: 0x128, 0x681: 0x71, 0x682: 0x129, 0x683: 0x12a, 0x684: 0x12b, 0x685: 0x128, 0x686: 0x12c, 0x687: 0x12d, - 0x688: 0x12e, 0x689: 0x12f, 0x68c: 0x71, 0x68d: 0x71, 0x68e: 0x71, 0x68f: 0x71, - 0x690: 0x71, 0x691: 0x71, 0x692: 0x71, 0x693: 0x71, 0x694: 0x71, 0x695: 0x71, 0x696: 0x71, 0x697: 0x71, - 0x698: 0x71, 0x699: 0x71, 0x69a: 0x71, 0x69b: 0x130, 0x69c: 0x71, 0x69d: 0x131, 0x69e: 0x71, 0x69f: 0x132, - 0x6a0: 0x133, 0x6a1: 0x134, 0x6a2: 0x135, 0x6a4: 0x136, 0x6a5: 0x137, 0x6a6: 0x138, 0x6a7: 0x139, - // Block 0x1b, offset 0x6c0 - 0x6c0: 0x90, 0x6c1: 0x90, 0x6c2: 0x90, 0x6c3: 0x90, 0x6c4: 0x90, 0x6c5: 0x90, 0x6c6: 0x90, 0x6c7: 0x90, - 0x6c8: 0x90, 0x6c9: 0x90, 0x6ca: 0x90, 0x6cb: 0x90, 0x6cc: 0x90, 0x6cd: 0x90, 0x6ce: 0x90, 0x6cf: 0x90, - 0x6d0: 0x90, 0x6d1: 0x90, 0x6d2: 0x90, 0x6d3: 0x90, 0x6d4: 0x90, 0x6d5: 0x90, 0x6d6: 0x90, 0x6d7: 0x90, - 0x6d8: 0x90, 0x6d9: 0x90, 0x6da: 0x90, 0x6db: 0x13a, 0x6dc: 0x90, 0x6dd: 0x90, 0x6de: 0x90, 0x6df: 0x90, - 0x6e0: 0x90, 0x6e1: 0x90, 0x6e2: 0x90, 0x6e3: 0x90, 0x6e4: 0x90, 0x6e5: 0x90, 0x6e6: 0x90, 0x6e7: 0x90, - 0x6e8: 0x90, 0x6e9: 0x90, 0x6ea: 0x90, 0x6eb: 0x90, 0x6ec: 0x90, 0x6ed: 0x90, 0x6ee: 0x90, 0x6ef: 0x90, - 0x6f0: 0x90, 0x6f1: 0x90, 0x6f2: 0x90, 0x6f3: 0x90, 0x6f4: 0x90, 0x6f5: 0x90, 0x6f6: 0x90, 0x6f7: 0x90, - 0x6f8: 0x90, 0x6f9: 0x90, 0x6fa: 0x90, 0x6fb: 0x90, 0x6fc: 0x90, 0x6fd: 0x90, 0x6fe: 0x90, 0x6ff: 0x90, - // Block 0x1c, offset 0x700 - 0x700: 0x90, 0x701: 0x90, 0x702: 0x90, 0x703: 0x90, 0x704: 0x90, 0x705: 0x90, 0x706: 0x90, 0x707: 0x90, - 0x708: 0x90, 0x709: 0x90, 0x70a: 0x90, 0x70b: 0x90, 0x70c: 0x90, 0x70d: 0x90, 0x70e: 0x90, 0x70f: 0x90, - 0x710: 0x90, 0x711: 0x90, 0x712: 0x90, 0x713: 0x90, 0x714: 0x90, 0x715: 0x90, 0x716: 0x90, 0x717: 0x90, - 0x718: 0x90, 0x719: 0x90, 0x71a: 0x90, 0x71b: 0x90, 0x71c: 0x13b, 0x71d: 0x90, 0x71e: 0x90, 0x71f: 0x90, - 0x720: 0x13c, 0x721: 0x90, 0x722: 0x90, 0x723: 0x90, 0x724: 0x90, 0x725: 0x90, 0x726: 0x90, 0x727: 0x90, - 0x728: 0x90, 0x729: 0x90, 0x72a: 0x90, 0x72b: 0x90, 0x72c: 0x90, 0x72d: 0x90, 0x72e: 0x90, 0x72f: 0x90, - 0x730: 0x90, 0x731: 0x90, 0x732: 0x90, 0x733: 0x90, 0x734: 0x90, 0x735: 0x90, 0x736: 0x90, 0x737: 0x90, - 0x738: 0x90, 0x739: 0x90, 0x73a: 0x90, 0x73b: 0x90, 0x73c: 0x90, 0x73d: 0x90, 0x73e: 0x90, 0x73f: 0x90, - // Block 0x1d, offset 0x740 - 0x740: 0x90, 0x741: 0x90, 0x742: 0x90, 0x743: 0x90, 0x744: 0x90, 0x745: 0x90, 0x746: 0x90, 0x747: 0x90, - 0x748: 0x90, 0x749: 0x90, 0x74a: 0x90, 0x74b: 0x90, 0x74c: 0x90, 0x74d: 0x90, 0x74e: 0x90, 0x74f: 0x90, - 0x750: 0x90, 0x751: 0x90, 0x752: 0x90, 0x753: 0x90, 0x754: 0x90, 0x755: 0x90, 0x756: 0x90, 0x757: 0x90, - 0x758: 0x90, 0x759: 0x90, 0x75a: 0x90, 0x75b: 0x90, 0x75c: 0x90, 0x75d: 0x90, 0x75e: 0x90, 0x75f: 0x90, - 0x760: 0x90, 0x761: 0x90, 0x762: 0x90, 0x763: 0x90, 0x764: 0x90, 0x765: 0x90, 0x766: 0x90, 0x767: 0x90, - 0x768: 0x90, 0x769: 0x90, 0x76a: 0x90, 0x76b: 0x90, 0x76c: 0x90, 0x76d: 0x90, 0x76e: 0x90, 0x76f: 0x90, - 0x770: 0x90, 0x771: 0x90, 0x772: 0x90, 0x773: 0x90, 0x774: 0x90, 0x775: 0x90, 0x776: 0x90, 0x777: 0x90, - 0x778: 0x90, 0x779: 0x90, 0x77a: 0x13d, - // Block 0x1e, offset 0x780 - 0x7a0: 0x83, 0x7a1: 0x83, 0x7a2: 0x83, 0x7a3: 0x83, 0x7a4: 0x83, 0x7a5: 0x83, 0x7a6: 0x83, 0x7a7: 0x83, - 0x7a8: 0x13e, - // Block 0x1f, offset 0x7c0 - 0x7d0: 0x0e, 0x7d1: 0x0f, 0x7d2: 0x10, 0x7d3: 0x11, 0x7d4: 0x12, 0x7d6: 0x13, 0x7d7: 0x0a, - 0x7d8: 0x14, 0x7db: 0x15, 0x7dd: 0x16, 0x7de: 0x17, 0x7df: 0x18, - 0x7e0: 0x07, 0x7e1: 0x07, 0x7e2: 0x07, 0x7e3: 0x07, 0x7e4: 0x07, 0x7e5: 0x07, 0x7e6: 0x07, 0x7e7: 0x07, - 0x7e8: 0x07, 0x7e9: 0x07, 0x7ea: 0x19, 0x7eb: 0x1a, 0x7ec: 0x1b, 0x7ef: 0x1c, - // Block 0x20, offset 0x800 - 0x800: 0x13f, 0x801: 0x3e, 0x804: 0x3e, 0x805: 0x3e, 0x806: 0x3e, 0x807: 0x140, - // Block 0x21, offset 0x840 - 0x840: 0x3e, 0x841: 0x3e, 0x842: 0x3e, 0x843: 0x3e, 0x844: 0x3e, 0x845: 0x3e, 0x846: 0x3e, 0x847: 0x3e, - 0x848: 0x3e, 0x849: 0x3e, 0x84a: 0x3e, 0x84b: 0x3e, 0x84c: 0x3e, 0x84d: 0x3e, 0x84e: 0x3e, 0x84f: 0x3e, - 0x850: 0x3e, 0x851: 0x3e, 0x852: 0x3e, 0x853: 0x3e, 0x854: 0x3e, 0x855: 0x3e, 0x856: 0x3e, 0x857: 0x3e, - 0x858: 0x3e, 0x859: 0x3e, 0x85a: 0x3e, 0x85b: 0x3e, 0x85c: 0x3e, 0x85d: 0x3e, 0x85e: 0x3e, 0x85f: 0x3e, - 0x860: 0x3e, 0x861: 0x3e, 0x862: 0x3e, 0x863: 0x3e, 0x864: 0x3e, 0x865: 0x3e, 0x866: 0x3e, 0x867: 0x3e, - 0x868: 0x3e, 0x869: 0x3e, 0x86a: 0x3e, 0x86b: 0x3e, 0x86c: 0x3e, 0x86d: 0x3e, 0x86e: 0x3e, 0x86f: 0x3e, - 0x870: 0x3e, 0x871: 0x3e, 0x872: 0x3e, 0x873: 0x3e, 0x874: 0x3e, 0x875: 0x3e, 0x876: 0x3e, 0x877: 0x3e, - 0x878: 0x3e, 0x879: 0x3e, 0x87a: 0x3e, 0x87b: 0x3e, 0x87c: 0x3e, 0x87d: 0x3e, 0x87e: 0x3e, 0x87f: 0x141, - // Block 0x22, offset 0x880 - 0x8a0: 0x1e, - 0x8b0: 0x0c, 0x8b1: 0x0c, 0x8b2: 0x0c, 0x8b3: 0x0c, 0x8b4: 0x0c, 0x8b5: 0x0c, 0x8b6: 0x0c, 0x8b7: 0x0c, - 0x8b8: 0x0c, 0x8b9: 0x0c, 0x8ba: 0x0c, 0x8bb: 0x0c, 0x8bc: 0x0c, 0x8bd: 0x0c, 0x8be: 0x0c, 0x8bf: 0x1f, - // Block 0x23, offset 0x8c0 - 0x8c0: 0x0c, 0x8c1: 0x0c, 0x8c2: 0x0c, 0x8c3: 0x0c, 0x8c4: 0x0c, 0x8c5: 0x0c, 0x8c6: 0x0c, 0x8c7: 0x0c, - 0x8c8: 0x0c, 0x8c9: 0x0c, 0x8ca: 0x0c, 0x8cb: 0x0c, 0x8cc: 0x0c, 0x8cd: 0x0c, 0x8ce: 0x0c, 0x8cf: 0x1f, -} - -// Total table size 25344 bytes (24KiB); checksum: 811C9DC5 diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/transformer.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/transformer.go deleted file mode 100644 index 97ce5e7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/transformer.go +++ /dev/null @@ -1,32 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package precis - -import "golang.org/x/text/transform" - -// Transformer implements the transform.Transformer interface. -type Transformer struct { - t transform.Transformer -} - -// Reset implements the transform.Transformer interface. -func (t Transformer) Reset() { t.t.Reset() } - -// Transform implements the transform.Transformer interface. -func (t Transformer) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - return t.t.Transform(dst, src, atEOF) -} - -// Bytes returns a new byte slice with the result of applying t to b. -func (t Transformer) Bytes(b []byte) []byte { - b, _, _ = transform.Bytes(t, b) - return b -} - -// String returns a string with the result of applying t to s. -func (t Transformer) String(s string) string { - s, _, _ = transform.String(t, s) - return s -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/trieval.go deleted file mode 100644 index fed7d75..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/secure/precis/trieval.go +++ /dev/null @@ -1,64 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package precis - -// entry is the entry of a trie table -// 7..6 property (unassigned, disallowed, maybe, valid) -// 5..0 category -type entry uint8 - -const ( - propShift = 6 - propMask = 0xc0 - catMask = 0x3f -) - -func (e entry) property() property { return property(e & propMask) } -func (e entry) category() category { return category(e & catMask) } - -type property uint8 - -// The order of these constants matter. A Profile may consider runes to be -// allowed either from pValid or idDisOrFreePVal. -const ( - unassigned property = iota << propShift - disallowed - idDisOrFreePVal // disallowed for Identifier, pValid for FreeForm - pValid -) - -// compute permutations of all properties and specialCategories. -type category uint8 - -const ( - other category = iota - - // Special rune types - joiningL - joiningD - joiningT - joiningR - viramaModifier - viramaJoinT // Virama + JoiningT - latinSmallL // U+006c - greek - greekJoinT // Greek + JoiningT - hebrew - hebrewJoinT // Hebrew + JoiningT - japanese // hirigana, katakana, han - - // Special rune types associated with contextual rules defined in - // https://tools.ietf.org/html/rfc5892#appendix-A. - // ContextO - zeroWidthNonJoiner // rule 1 - zeroWidthJoiner // rule 2 - // ContextJ - middleDot // rule 3 - greekLowerNumeralSign // rule 4 - hebrewPreceding // rule 5 and 6 - katakanaMiddleDot // rule 7 - arabicIndicDigit // rule 8 - extendedArabicIndicDigit // rule 9 - - numCategories -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/transform/transform.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/transform/transform.go deleted file mode 100644 index 51862b0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/transform/transform.go +++ /dev/null @@ -1,661 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// Package transform provides reader and writer wrappers that transform the -// bytes passing through as well as various transformations. Example -// transformations provided by other packages include normalization and -// conversion between character sets. -package transform - -import ( - "bytes" - "errors" - "io" - "unicode/utf8" -) - -var ( - // ErrShortDst means that the destination buffer was too short to - // receive all of the transformed bytes. - ErrShortDst = errors.New("transform: short destination buffer") - - // ErrShortSrc means that the source buffer has insufficient data to - // complete the transformation. - ErrShortSrc = errors.New("transform: short source buffer") - - // errInconsistentByteCount means that Transform returned success (nil - // error) but also returned nSrc inconsistent with the src argument. - errInconsistentByteCount = errors.New("transform: inconsistent byte count returned") - - // errShortInternal means that an internal buffer is not large enough - // to make progress and the Transform operation must be aborted. - errShortInternal = errors.New("transform: short internal buffer") -) - -// Transformer transforms bytes. -type Transformer interface { - // Transform writes to dst the transformed bytes read from src, and - // returns the number of dst bytes written and src bytes read. The - // atEOF argument tells whether src represents the last bytes of the - // input. - // - // Callers should always process the nDst bytes produced and account - // for the nSrc bytes consumed before considering the error err. - // - // A nil error means that all of the transformed bytes (whether freshly - // transformed from src or left over from previous Transform calls) - // were written to dst. A nil error can be returned regardless of - // whether atEOF is true. If err is nil then nSrc must equal len(src); - // the converse is not necessarily true. - // - // ErrShortDst means that dst was too short to receive all of the - // transformed bytes. ErrShortSrc means that src had insufficient data - // to complete the transformation. If both conditions apply, then - // either error may be returned. Other than the error conditions listed - // here, implementations are free to report other errors that arise. - Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) - - // Reset resets the state and allows a Transformer to be reused. - Reset() -} - -// NopResetter can be embedded by implementations of Transformer to add a nop -// Reset method. -type NopResetter struct{} - -// Reset implements the Reset method of the Transformer interface. -func (NopResetter) Reset() {} - -// Reader wraps another io.Reader by transforming the bytes read. -type Reader struct { - r io.Reader - t Transformer - err error - - // dst[dst0:dst1] contains bytes that have been transformed by t but - // not yet copied out via Read. - dst []byte - dst0, dst1 int - - // src[src0:src1] contains bytes that have been read from r but not - // yet transformed through t. - src []byte - src0, src1 int - - // transformComplete is whether the transformation is complete, - // regardless of whether or not it was successful. - transformComplete bool -} - -const defaultBufSize = 4096 - -// NewReader returns a new Reader that wraps r by transforming the bytes read -// via t. It calls Reset on t. -func NewReader(r io.Reader, t Transformer) *Reader { - t.Reset() - return &Reader{ - r: r, - t: t, - dst: make([]byte, defaultBufSize), - src: make([]byte, defaultBufSize), - } -} - -// Read implements the io.Reader interface. -func (r *Reader) Read(p []byte) (int, error) { - n, err := 0, error(nil) - for { - // Copy out any transformed bytes and return the final error if we are done. - if r.dst0 != r.dst1 { - n = copy(p, r.dst[r.dst0:r.dst1]) - r.dst0 += n - if r.dst0 == r.dst1 && r.transformComplete { - return n, r.err - } - return n, nil - } else if r.transformComplete { - return 0, r.err - } - - // Try to transform some source bytes, or to flush the transformer if we - // are out of source bytes. We do this even if r.r.Read returned an error. - // As the io.Reader documentation says, "process the n > 0 bytes returned - // before considering the error". - if r.src0 != r.src1 || r.err != nil { - r.dst0 = 0 - r.dst1, n, err = r.t.Transform(r.dst, r.src[r.src0:r.src1], r.err == io.EOF) - r.src0 += n - - switch { - case err == nil: - if r.src0 != r.src1 { - r.err = errInconsistentByteCount - } - // The Transform call was successful; we are complete if we - // cannot read more bytes into src. - r.transformComplete = r.err != nil - continue - case err == ErrShortDst && (r.dst1 != 0 || n != 0): - // Make room in dst by copying out, and try again. - continue - case err == ErrShortSrc && r.src1-r.src0 != len(r.src) && r.err == nil: - // Read more bytes into src via the code below, and try again. - default: - r.transformComplete = true - // The reader error (r.err) takes precedence over the - // transformer error (err) unless r.err is nil or io.EOF. - if r.err == nil || r.err == io.EOF { - r.err = err - } - continue - } - } - - // Move any untransformed source bytes to the start of the buffer - // and read more bytes. - if r.src0 != 0 { - r.src0, r.src1 = 0, copy(r.src, r.src[r.src0:r.src1]) - } - n, r.err = r.r.Read(r.src[r.src1:]) - r.src1 += n - } -} - -// TODO: implement ReadByte (and ReadRune??). - -// Writer wraps another io.Writer by transforming the bytes read. -// The user needs to call Close to flush unwritten bytes that may -// be buffered. -type Writer struct { - w io.Writer - t Transformer - dst []byte - - // src[:n] contains bytes that have not yet passed through t. - src []byte - n int -} - -// NewWriter returns a new Writer that wraps w by transforming the bytes written -// via t. It calls Reset on t. -func NewWriter(w io.Writer, t Transformer) *Writer { - t.Reset() - return &Writer{ - w: w, - t: t, - dst: make([]byte, defaultBufSize), - src: make([]byte, defaultBufSize), - } -} - -// Write implements the io.Writer interface. If there are not enough -// bytes available to complete a Transform, the bytes will be buffered -// for the next write. Call Close to convert the remaining bytes. -func (w *Writer) Write(data []byte) (n int, err error) { - src := data - if w.n > 0 { - // Append bytes from data to the last remainder. - // TODO: limit the amount copied on first try. - n = copy(w.src[w.n:], data) - w.n += n - src = w.src[:w.n] - } - for { - nDst, nSrc, err := w.t.Transform(w.dst, src, false) - if _, werr := w.w.Write(w.dst[:nDst]); werr != nil { - return n, werr - } - src = src[nSrc:] - if w.n == 0 { - n += nSrc - } else if len(src) <= n { - // Enough bytes from w.src have been consumed. We make src point - // to data instead to reduce the copying. - w.n = 0 - n -= len(src) - src = data[n:] - if n < len(data) && (err == nil || err == ErrShortSrc) { - continue - } - } - switch err { - case ErrShortDst: - // This error is okay as long as we are making progress. - if nDst > 0 || nSrc > 0 { - continue - } - case ErrShortSrc: - if len(src) < len(w.src) { - m := copy(w.src, src) - // If w.n > 0, bytes from data were already copied to w.src and n - // was already set to the number of bytes consumed. - if w.n == 0 { - n += m - } - w.n = m - err = nil - } else if nDst > 0 || nSrc > 0 { - // Not enough buffer to store the remainder. Keep processing as - // long as there is progress. Without this case, transforms that - // require a lookahead larger than the buffer may result in an - // error. This is not something one may expect to be common in - // practice, but it may occur when buffers are set to small - // sizes during testing. - continue - } - case nil: - if w.n > 0 { - err = errInconsistentByteCount - } - } - return n, err - } -} - -// Close implements the io.Closer interface. -func (w *Writer) Close() error { - src := w.src[:w.n] - for { - nDst, nSrc, err := w.t.Transform(w.dst, src, true) - if _, werr := w.w.Write(w.dst[:nDst]); werr != nil { - return werr - } - if err != ErrShortDst { - return err - } - src = src[nSrc:] - } -} - -type nop struct{ NopResetter } - -func (nop) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - n := copy(dst, src) - if n < len(src) { - err = ErrShortDst - } - return n, n, err -} - -type discard struct{ NopResetter } - -func (discard) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - return 0, len(src), nil -} - -var ( - // Discard is a Transformer for which all Transform calls succeed - // by consuming all bytes and writing nothing. - Discard Transformer = discard{} - - // Nop is a Transformer that copies src to dst. - Nop Transformer = nop{} -) - -// chain is a sequence of links. A chain with N Transformers has N+1 links and -// N+1 buffers. Of those N+1 buffers, the first and last are the src and dst -// buffers given to chain.Transform and the middle N-1 buffers are intermediate -// buffers owned by the chain. The i'th link transforms bytes from the i'th -// buffer chain.link[i].b at read offset chain.link[i].p to the i+1'th buffer -// chain.link[i+1].b at write offset chain.link[i+1].n, for i in [0, N). -type chain struct { - link []link - err error - // errStart is the index at which the error occurred plus 1. Processing - // errStart at this level at the next call to Transform. As long as - // errStart > 0, chain will not consume any more source bytes. - errStart int -} - -func (c *chain) fatalError(errIndex int, err error) { - if i := errIndex + 1; i > c.errStart { - c.errStart = i - c.err = err - } -} - -type link struct { - t Transformer - // b[p:n] holds the bytes to be transformed by t. - b []byte - p int - n int -} - -func (l *link) src() []byte { - return l.b[l.p:l.n] -} - -func (l *link) dst() []byte { - return l.b[l.n:] -} - -// Chain returns a Transformer that applies t in sequence. -func Chain(t ...Transformer) Transformer { - if len(t) == 0 { - return nop{} - } - c := &chain{link: make([]link, len(t)+1)} - for i, tt := range t { - c.link[i].t = tt - } - // Allocate intermediate buffers. - b := make([][defaultBufSize]byte, len(t)-1) - for i := range b { - c.link[i+1].b = b[i][:] - } - return c -} - -// Reset resets the state of Chain. It calls Reset on all the Transformers. -func (c *chain) Reset() { - for i, l := range c.link { - if l.t != nil { - l.t.Reset() - } - c.link[i].p, c.link[i].n = 0, 0 - } -} - -// Transform applies the transformers of c in sequence. -func (c *chain) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - // Set up src and dst in the chain. - srcL := &c.link[0] - dstL := &c.link[len(c.link)-1] - srcL.b, srcL.p, srcL.n = src, 0, len(src) - dstL.b, dstL.n = dst, 0 - var lastFull, needProgress bool // for detecting progress - - // i is the index of the next Transformer to apply, for i in [low, high]. - // low is the lowest index for which c.link[low] may still produce bytes. - // high is the highest index for which c.link[high] has a Transformer. - // The error returned by Transform determines whether to increase or - // decrease i. We try to completely fill a buffer before converting it. - for low, i, high := c.errStart, c.errStart, len(c.link)-2; low <= i && i <= high; { - in, out := &c.link[i], &c.link[i+1] - nDst, nSrc, err0 := in.t.Transform(out.dst(), in.src(), atEOF && low == i) - out.n += nDst - in.p += nSrc - if i > 0 && in.p == in.n { - in.p, in.n = 0, 0 - } - needProgress, lastFull = lastFull, false - switch err0 { - case ErrShortDst: - // Process the destination buffer next. Return if we are already - // at the high index. - if i == high { - return dstL.n, srcL.p, ErrShortDst - } - if out.n != 0 { - i++ - // If the Transformer at the next index is not able to process any - // source bytes there is nothing that can be done to make progress - // and the bytes will remain unprocessed. lastFull is used to - // detect this and break out of the loop with a fatal error. - lastFull = true - continue - } - // The destination buffer was too small, but is completely empty. - // Return a fatal error as this transformation can never complete. - c.fatalError(i, errShortInternal) - case ErrShortSrc: - if i == 0 { - // Save ErrShortSrc in err. All other errors take precedence. - err = ErrShortSrc - break - } - // Source bytes were depleted before filling up the destination buffer. - // Verify we made some progress, move the remaining bytes to the errStart - // and try to get more source bytes. - if needProgress && nSrc == 0 || in.n-in.p == len(in.b) { - // There were not enough source bytes to proceed while the source - // buffer cannot hold any more bytes. Return a fatal error as this - // transformation can never complete. - c.fatalError(i, errShortInternal) - break - } - // in.b is an internal buffer and we can make progress. - in.p, in.n = 0, copy(in.b, in.src()) - fallthrough - case nil: - // if i == low, we have depleted the bytes at index i or any lower levels. - // In that case we increase low and i. In all other cases we decrease i to - // fetch more bytes before proceeding to the next index. - if i > low { - i-- - continue - } - default: - c.fatalError(i, err0) - } - // Exhausted level low or fatal error: increase low and continue - // to process the bytes accepted so far. - i++ - low = i - } - - // If c.errStart > 0, this means we found a fatal error. We will clear - // all upstream buffers. At this point, no more progress can be made - // downstream, as Transform would have bailed while handling ErrShortDst. - if c.errStart > 0 { - for i := 1; i < c.errStart; i++ { - c.link[i].p, c.link[i].n = 0, 0 - } - err, c.errStart, c.err = c.err, 0, nil - } - return dstL.n, srcL.p, err -} - -// RemoveFunc returns a Transformer that removes from the input all runes r for -// which f(r) is true. Illegal bytes in the input are replaced by RuneError. -func RemoveFunc(f func(r rune) bool) Transformer { - return removeF(f) -} - -type removeF func(r rune) bool - -func (removeF) Reset() {} - -// Transform implements the Transformer interface. -func (t removeF) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for r, sz := rune(0), 0; len(src) > 0; src = src[sz:] { - - if r = rune(src[0]); r < utf8.RuneSelf { - sz = 1 - } else { - r, sz = utf8.DecodeRune(src) - - if sz == 1 { - // Invalid rune. - if !atEOF && !utf8.FullRune(src) { - err = ErrShortSrc - break - } - // We replace illegal bytes with RuneError. Not doing so might - // otherwise turn a sequence of invalid UTF-8 into valid UTF-8. - // The resulting byte sequence may subsequently contain runes - // for which t(r) is true that were passed unnoticed. - if !t(r) { - if nDst+3 > len(dst) { - err = ErrShortDst - break - } - nDst += copy(dst[nDst:], "\uFFFD") - } - nSrc++ - continue - } - } - - if !t(r) { - if nDst+sz > len(dst) { - err = ErrShortDst - break - } - nDst += copy(dst[nDst:], src[:sz]) - } - nSrc += sz - } - return -} - -// grow returns a new []byte that is longer than b, and copies the first n bytes -// of b to the start of the new slice. -func grow(b []byte, n int) []byte { - m := len(b) - if m <= 32 { - m = 64 - } else if m <= 256 { - m *= 2 - } else { - m += m >> 1 - } - buf := make([]byte, m) - copy(buf, b[:n]) - return buf -} - -const initialBufSize = 128 - -// String returns a string with the result of converting s[:n] using t, where -// n <= len(s). If err == nil, n will be len(s). It calls Reset on t. -func String(t Transformer, s string) (result string, n int, err error) { - t.Reset() - if s == "" { - // Fast path for the common case for empty input. Results in about a - // 86% reduction of running time for BenchmarkStringLowerEmpty. - if _, _, err := t.Transform(nil, nil, true); err == nil { - return "", 0, nil - } - } - - // Allocate only once. Note that both dst and src escape when passed to - // Transform. - buf := [2 * initialBufSize]byte{} - dst := buf[:initialBufSize:initialBufSize] - src := buf[initialBufSize : 2*initialBufSize] - - // The input string s is transformed in multiple chunks (starting with a - // chunk size of initialBufSize). nDst and nSrc are per-chunk (or - // per-Transform-call) indexes, pDst and pSrc are overall indexes. - nDst, nSrc := 0, 0 - pDst, pSrc := 0, 0 - - // pPrefix is the length of a common prefix: the first pPrefix bytes of the - // result will equal the first pPrefix bytes of s. It is not guaranteed to - // be the largest such value, but if pPrefix, len(result) and len(s) are - // all equal after the final transform (i.e. calling Transform with atEOF - // being true returned nil error) then we don't need to allocate a new - // result string. - pPrefix := 0 - for { - // Invariant: pDst == pPrefix && pSrc == pPrefix. - - n := copy(src, s[pSrc:]) - nDst, nSrc, err = t.Transform(dst, src[:n], pSrc+n == len(s)) - pDst += nDst - pSrc += nSrc - - // TODO: let transformers implement an optional Spanner interface, akin - // to norm's QuickSpan. This would even allow us to avoid any allocation. - if !bytes.Equal(dst[:nDst], src[:nSrc]) { - break - } - pPrefix = pSrc - if err == ErrShortDst { - // A buffer can only be short if a transformer modifies its input. - break - } else if err == ErrShortSrc { - if nSrc == 0 { - // No progress was made. - break - } - // Equal so far and !atEOF, so continue checking. - } else if err != nil || pPrefix == len(s) { - return string(s[:pPrefix]), pPrefix, err - } - } - // Post-condition: pDst == pPrefix + nDst && pSrc == pPrefix + nSrc. - - // We have transformed the first pSrc bytes of the input s to become pDst - // transformed bytes. Those transformed bytes are discontiguous: the first - // pPrefix of them equal s[:pPrefix] and the last nDst of them equal - // dst[:nDst]. We copy them around, into a new dst buffer if necessary, so - // that they become one contiguous slice: dst[:pDst]. - if pPrefix != 0 { - newDst := dst - if pDst > len(newDst) { - newDst = make([]byte, len(s)+nDst-nSrc) - } - copy(newDst[pPrefix:pDst], dst[:nDst]) - copy(newDst[:pPrefix], s[:pPrefix]) - dst = newDst - } - - // Prevent duplicate Transform calls with atEOF being true at the end of - // the input. Also return if we have an unrecoverable error. - if (err == nil && pSrc == len(s)) || - (err != nil && err != ErrShortDst && err != ErrShortSrc) { - return string(dst[:pDst]), pSrc, err - } - - // Transform the remaining input, growing dst and src buffers as necessary. - for { - n := copy(src, s[pSrc:]) - nDst, nSrc, err := t.Transform(dst[pDst:], src[:n], pSrc+n == len(s)) - pDst += nDst - pSrc += nSrc - - // If we got ErrShortDst or ErrShortSrc, do not grow as long as we can - // make progress. This may avoid excessive allocations. - if err == ErrShortDst { - if nDst == 0 { - dst = grow(dst, pDst) - } - } else if err == ErrShortSrc { - if nSrc == 0 { - src = grow(src, 0) - } - } else if err != nil || pSrc == len(s) { - return string(dst[:pDst]), pSrc, err - } - } -} - -// Bytes returns a new byte slice with the result of converting b[:n] using t, -// where n <= len(b). If err == nil, n will be len(b). It calls Reset on t. -func Bytes(t Transformer, b []byte) (result []byte, n int, err error) { - return doAppend(t, 0, make([]byte, len(b)), b) -} - -// Append appends the result of converting src[:n] using t to dst, where -// n <= len(src), If err == nil, n will be len(src). It calls Reset on t. -func Append(t Transformer, dst, src []byte) (result []byte, n int, err error) { - if len(dst) == cap(dst) { - n := len(src) + len(dst) // It is okay for this to be 0. - b := make([]byte, n) - dst = b[:copy(b, dst)] - } - return doAppend(t, len(dst), dst[:cap(dst)], src) -} - -func doAppend(t Transformer, pDst int, dst, src []byte) (result []byte, n int, err error) { - t.Reset() - pSrc := 0 - for { - nDst, nSrc, err := t.Transform(dst[pDst:], src[pSrc:], true) - pDst += nDst - pSrc += nSrc - if err != ErrShortDst { - return dst[:pDst], pSrc, err - } - - // Grow the destination buffer, but do not grow as long as we can make - // progress. This may avoid excessive allocations. - if nDst == 0 { - dst = grow(dst, pDst) - } - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bidi.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bidi.go deleted file mode 100644 index 1254119..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bidi.go +++ /dev/null @@ -1,198 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate go run gen.go gen_trieval.go gen_ranges.go - -// Package bidi contains functionality for bidirectional text support. -// -// See http://www.unicode.org/reports/tr9. -// -// NOTE: UNDER CONSTRUCTION. This API may change in backwards incompatible ways -// and without notice. -package bidi - -// TODO: -// The following functionality would not be hard to implement, but hinges on -// the definition of a Segmenter interface. For now this is up to the user. -// - Iterate over paragraphs -// - Segmenter to iterate over runs directly from a given text. -// Also: -// - Transformer for reordering? -// - Transformer (validator, really) for Bidi Rule. - -// This API tries to avoid dealing with embedding levels for now. Under the hood -// these will be computed, but the question is to which extent the user should -// know they exist. We should at some point allow the user to specify an -// embedding hierarchy, though. - -// A Direction indicates the overall flow of text. -type Direction int - -const ( - // LeftToRight indicates the text contains no right-to-left characters and - // that either there are some left-to-right characters or the option - // DefaultDirection(LeftToRight) was passed. - LeftToRight Direction = iota - - // RightToLeft indicates the text contains no left-to-right characters and - // that either there are some right-to-left characters or the option - // DefaultDirection(RightToLeft) was passed. - RightToLeft - - // Mixed indicates text contains both left-to-right and right-to-left - // characters. - Mixed - - // Neutral means that text contains no left-to-right and right-to-left - // characters and that no default direction has been set. - Neutral -) - -type options struct{} - -// An Option is an option for Bidi processing. -type Option func(*options) - -// ICU allows the user to define embedding levels. This may be used, for example, -// to use hierarchical structure of markup languages to define embeddings. -// The following option may be a way to expose this functionality in this API. -// // LevelFunc sets a function that associates nesting levels with the given text. -// // The levels function will be called with monotonically increasing values for p. -// func LevelFunc(levels func(p int) int) Option { -// panic("unimplemented") -// } - -// DefaultDirection sets the default direction for a Paragraph. The direction is -// overridden if the text contains directional characters. -func DefaultDirection(d Direction) Option { - panic("unimplemented") -} - -// A Paragraph holds a single Paragraph for Bidi processing. -type Paragraph struct { - // buffers -} - -// SetBytes configures p for the given paragraph text. It replaces text -// previously set by SetBytes or SetString. If b contains a paragraph separator -// it will only process the first paragraph and report the number of bytes -// consumed from b including this separator. Error may be non-nil if options are -// given. -func (p *Paragraph) SetBytes(b []byte, opts ...Option) (n int, err error) { - panic("unimplemented") -} - -// SetString configures p for the given paragraph text. It replaces text -// previously set by SetBytes or SetString. If b contains a paragraph separator -// it will only process the first paragraph and report the number of bytes -// consumed from b including this separator. Error may be non-nil if options are -// given. -func (p *Paragraph) SetString(s string, opts ...Option) (n int, err error) { - panic("unimplemented") -} - -// IsLeftToRight reports whether the principle direction of rendering for this -// paragraphs is left-to-right. If this returns false, the principle direction -// of rendering is right-to-left. -func (p *Paragraph) IsLeftToRight() bool { - panic("unimplemented") -} - -// Direction returns the direction of the text of this paragraph. -// -// The direction may be LeftToRight, RightToLeft, Mixed, or Neutral. -func (p *Paragraph) Direction() Direction { - panic("unimplemented") -} - -// RunAt reports the Run at the given position of the input text. -// -// This method can be used for computing line breaks on paragraphs. -func (p *Paragraph) RunAt(pos int) Run { - panic("unimplemented") -} - -// Order computes the visual ordering of all the runs in a Paragraph. -func (p *Paragraph) Order() (Ordering, error) { - panic("unimplemented") -} - -// Line computes the visual ordering of runs for a single line starting and -// ending at the given positions in the original text. -func (p *Paragraph) Line(start, end int) (Ordering, error) { - panic("unimplemented") -} - -// An Ordering holds the computed visual order of runs of a Paragraph. Calling -// SetBytes or SetString on the originating Paragraph invalidates an Ordering. -// The methods of an Ordering should only be called by one goroutine at a time. -type Ordering struct{} - -// Direction reports the directionality of the runs. -// -// The direction may be LeftToRight, RightToLeft, Mixed, or Neutral. -func (o *Ordering) Direction() Direction { - panic("unimplemented") -} - -// NumRuns returns the number of runs. -func (o *Ordering) NumRuns() int { - panic("unimplemented") -} - -// Run returns the ith run within the ordering. -func (o *Ordering) Run(i int) Run { - panic("unimplemented") -} - -// TODO: perhaps with options. -// // Reorder creates a reader that reads the runes in visual order per character. -// // Modifiers remain after the runes they modify. -// func (l *Runs) Reorder() io.Reader { -// panic("unimplemented") -// } - -// A Run is a continuous sequence of characters of a single direction. -type Run struct { -} - -// String returns the text of the run in its original order. -func (r *Run) String() string { - panic("unimplemented") -} - -// Bytes returns the text of the run in its original order. -func (r *Run) Bytes() []byte { - panic("unimplemented") -} - -// TODO: methods for -// - Display order -// - headers and footers -// - bracket replacement. - -// Direction reports the direction of the run. -func (r *Run) Direction() Direction { - panic("unimplemented") -} - -// Position of the Run within the text passed to SetBytes or SetString of the -// originating Paragraph value. -func (r *Run) Pos() (start, end int) { - panic("unimplemented") -} - -// AppendReverse reverses the order of characters of in, appends them to out, -// and returns the result. Modifiers will still follow the runes they modify. -// Brackets are replaced with their counterparts. -func AppendReverse(out, in []byte) []byte { - panic("unimplemented") -} - -// ReverseString reverses the order of characters in s and returns a new string. -// Modifiers will still follow the runes they modify. Brackets are replaced with -// their counterparts. -func ReverseString(s string) string { - panic("unimplemented") -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bracket.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bracket.go deleted file mode 100644 index e88119d..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/bracket.go +++ /dev/null @@ -1,307 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package bidi - -import ( - "container/list" - "fmt" - "sort" -) - -// This file contains a port of the reference implementation of the -// Bidi Parentheses Algorithm: -// http://www.unicode.org/Public/PROGRAMS/BidiReferenceJava/BidiPBAReference.java -// -// The implementation in this file covers definitions BD14-BD16 and rule N0 -// of UAX#9. -// -// Some preprocessing is done for each rune before data is passed to this -// algorithm: -// - opening and closing brackets are identified -// - a bracket pair type, like '(' and ')' is assigned a unique identifier that -// is identical for the opening and closing bracket. It is left to do these -// mappings. -// - The BPA algorithm requires that bracket characters that are canonical -// equivalents of each other be able to be substituted for each other. -// It is the responsibility of the caller to do this canonicalization. -// -// In implementing BD16, this implementation departs slightly from the "logical" -// algorithm defined in UAX#9. In particular, the stack referenced there -// supports operations that go beyond a "basic" stack. An equivalent -// implementation based on a linked list is used here. - -// Bidi_Paired_Bracket_Type -// BD14. An opening paired bracket is a character whose -// Bidi_Paired_Bracket_Type property value is Open. -// -// BD15. A closing paired bracket is a character whose -// Bidi_Paired_Bracket_Type property value is Close. -type bracketType byte - -const ( - bpNone bracketType = iota - bpOpen - bpClose -) - -// bracketPair holds a pair of index values for opening and closing bracket -// location of a bracket pair. -type bracketPair struct { - opener int - closer int -} - -func (b *bracketPair) String() string { - return fmt.Sprintf("(%v, %v)", b.opener, b.closer) -} - -// bracketPairs is a slice of bracketPairs with a sort.Interface implementation. -type bracketPairs []bracketPair - -func (b bracketPairs) Len() int { return len(b) } -func (b bracketPairs) Swap(i, j int) { b[i], b[j] = b[j], b[i] } -func (b bracketPairs) Less(i, j int) bool { return b[i].opener < b[j].opener } - -// resolvePairedBrackets runs the paired bracket part of the UBA algorithm. -// -// For each rune, it takes the indexes into the original string, the class the -// bracket type (in pairTypes) and the bracket identifier (pairValues). It also -// takes the direction type for the start-of-sentence and the embedding level. -// -// The identifiers for bracket types are the rune of the canonicalized opening -// bracket for brackets (open or close) or 0 for runes that are not brackets. -func resolvePairedBrackets(s *isolatingRunSequence) { - p := bracketPairer{ - sos: s.sos, - openers: list.New(), - codesIsolatedRun: s.types, - indexes: s.indexes, - } - dirEmbed := L - if s.level&1 != 0 { - dirEmbed = R - } - p.locateBrackets(s.p.pairTypes, s.p.pairValues) - p.resolveBrackets(dirEmbed) -} - -type bracketPairer struct { - sos Class // direction corresponding to start of sequence - - // The following is a restatement of BD 16 using non-algorithmic language. - // - // A bracket pair is a pair of characters consisting of an opening - // paired bracket and a closing paired bracket such that the - // Bidi_Paired_Bracket property value of the former equals the latter, - // subject to the following constraints. - // - both characters of a pair occur in the same isolating run sequence - // - the closing character of a pair follows the opening character - // - any bracket character can belong at most to one pair, the earliest possible one - // - any bracket character not part of a pair is treated like an ordinary character - // - pairs may nest properly, but their spans may not overlap otherwise - - // Bracket characters with canonical decompositions are supposed to be - // treated as if they had been normalized, to allow normalized and non- - // normalized text to give the same result. In this implementation that step - // is pushed out to the caller. The caller has to ensure that the pairValue - // slices contain the rune of the opening bracket after normalization for - // any opening or closing bracket. - - openers *list.List // list of positions for opening brackets - - // bracket pair positions sorted by location of opening bracket - pairPositions bracketPairs - - codesIsolatedRun []Class // directional bidi codes for an isolated run - indexes []int // array of index values into the original string - -} - -// matchOpener reports whether characters at given positions form a matching -// bracket pair. -func (p *bracketPairer) matchOpener(pairValues []rune, opener, closer int) bool { - return pairValues[p.indexes[opener]] == pairValues[p.indexes[closer]] -} - -// locateBrackets locates matching bracket pairs according to BD16. -// -// This implementation uses a linked list instead of a stack, because, while -// elements are added at the front (like a push) they are not generally removed -// in atomic 'pop' operations, reducing the benefit of the stack archetype. -func (p *bracketPairer) locateBrackets(pairTypes []bracketType, pairValues []rune) { - // traverse the run - // do that explicitly (not in a for-each) so we can record position - for i, index := range p.indexes { - - // look at the bracket type for each character - switch pairTypes[index] { - case bpNone: - // continue scanning - - case bpOpen: - // remember opener location, most recent first - p.openers.PushFront(i) - - case bpClose: - // see if there is a match - count := 0 - for elem := p.openers.Front(); elem != nil; elem = elem.Next() { - count++ - opener := elem.Value.(int) - if p.matchOpener(pairValues, opener, i) { - // if the opener matches, add nested pair to the ordered list - p.pairPositions = append(p.pairPositions, bracketPair{opener, i}) - // remove up to and including matched opener - for ; count > 0; count-- { - p.openers.Remove(p.openers.Front()) - } - break - } - } - sort.Sort(p.pairPositions) - // if we get here, the closing bracket matched no openers - // and gets ignored - } - } -} - -// Bracket pairs within an isolating run sequence are processed as units so -// that both the opening and the closing paired bracket in a pair resolve to -// the same direction. -// -// N0. Process bracket pairs in an isolating run sequence sequentially in -// the logical order of the text positions of the opening paired brackets -// using the logic given below. Within this scope, bidirectional types EN -// and AN are treated as R. -// -// Identify the bracket pairs in the current isolating run sequence -// according to BD16. For each bracket-pair element in the list of pairs of -// text positions: -// -// a Inspect the bidirectional types of the characters enclosed within the -// bracket pair. -// -// b If any strong type (either L or R) matching the embedding direction is -// found, set the type for both brackets in the pair to match the embedding -// direction. -// -// o [ e ] o -> o e e e o -// -// o [ o e ] -> o e o e e -// -// o [ NI e ] -> o e NI e e -// -// c Otherwise, if a strong type (opposite the embedding direction) is -// found, test for adjacent strong types as follows: 1 First, check -// backwards before the opening paired bracket until the first strong type -// (L, R, or sos) is found. If that first preceding strong type is opposite -// the embedding direction, then set the type for both brackets in the pair -// to that type. 2 Otherwise, set the type for both brackets in the pair to -// the embedding direction. -// -// o [ o ] e -> o o o o e -// -// o [ o NI ] o -> o o o NI o o -// -// e [ o ] o -> e e o e o -// -// e [ o ] e -> e e o e e -// -// e ( o [ o ] NI ) e -> e e o o o o NI e e -// -// d Otherwise, do not set the type for the current bracket pair. Note that -// if the enclosed text contains no strong types the paired brackets will -// both resolve to the same level when resolved individually using rules N1 -// and N2. -// -// e ( NI ) o -> e ( NI ) o - -// getStrongTypeN0 maps character's directional code to strong type as required -// by rule N0. -// -// TODO: have separate type for "strong" directionality. -func (p *bracketPairer) getStrongTypeN0(index int) Class { - switch p.codesIsolatedRun[index] { - // in the scope of N0, number types are treated as R - case EN, AN, AL, R: - return R - case L: - return L - default: - return ON - } -} - -// classifyPairContent reports the strong types contained inside a Bracket Pair, -// assuming the given embedding direction. -// -// It returns ON if no strong type is found. If a single strong type is found, -// it returns this this type. Otherwise it returns the embedding direction. -// -// TODO: use separate type for "strong" directionality. -func (p *bracketPairer) classifyPairContent(loc bracketPair, dirEmbed Class) Class { - dirOpposite := ON - for i := loc.opener + 1; i < loc.closer; i++ { - dir := p.getStrongTypeN0(i) - if dir == ON { - continue - } - if dir == dirEmbed { - return dir // type matching embedding direction found - } - dirOpposite = dir - } - // return ON if no strong type found, or class opposite to dirEmbed - return dirOpposite -} - -// classBeforePair determines which strong types are present before a Bracket -// Pair. Return R or L if strong type found, otherwise ON. -func (p *bracketPairer) classBeforePair(loc bracketPair) Class { - for i := loc.opener - 1; i >= 0; i-- { - if dir := p.getStrongTypeN0(i); dir != ON { - return dir - } - } - // no strong types found, return sos - return p.sos -} - -// assignBracketType implements rule N0 for a single bracket pair. -func (p *bracketPairer) assignBracketType(loc bracketPair, dirEmbed Class) { - // rule "N0, a", inspect contents of pair - dirPair := p.classifyPairContent(loc, dirEmbed) - - // dirPair is now L, R, or N (no strong type found) - - // the following logical tests are performed out of order compared to - // the statement of the rules but yield the same results - if dirPair == ON { - return // case "d" - nothing to do - } - - if dirPair != dirEmbed { - // case "c": strong type found, opposite - check before (c.1) - dirPair = p.classBeforePair(loc) - if dirPair == dirEmbed || dirPair == ON { - // no strong opposite type found before - use embedding (c.2) - dirPair = dirEmbed - } - } - // else: case "b", strong type found matching embedding, - // no explicit action needed, as dirPair is already set to embedding - // direction - - // set the bracket types to the type found - p.codesIsolatedRun[loc.opener] = dirPair - p.codesIsolatedRun[loc.closer] = dirPair -} - -// resolveBrackets implements rule N0 for a list of pairs. -func (p *bracketPairer) resolveBrackets(dirEmbed Class) { - for _, loc := range p.pairPositions { - p.assignBracketType(loc, dirEmbed) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/core.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/core.go deleted file mode 100644 index 381f30a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/core.go +++ /dev/null @@ -1,1055 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package bidi - -import "log" - -// This implementation is a port based on the reference implementation found at: -// http://www.unicode.org/Public/PROGRAMS/BidiReferenceJava/ -// -// described in Unicode Bidirectional Algorithm (UAX #9). -// -// Input: -// There are two levels of input to the algorithm, since clients may prefer to -// supply some information from out-of-band sources rather than relying on the -// default behavior. -// -// - Bidi class array -// - Bidi class array, with externally supplied base line direction -// -// Output: -// Output is separated into several stages: -// -// - levels array over entire paragraph -// - reordering array over entire paragraph -// - levels array over line -// - reordering array over line -// -// Note that for conformance to the Unicode Bidirectional Algorithm, -// implementations are only required to generate correct reordering and -// character directionality (odd or even levels) over a line. Generating -// identical level arrays over a line is not required. Bidi explicit format -// codes (LRE, RLE, LRO, RLO, PDF) and BN can be assigned arbitrary levels and -// positions as long as the rest of the input is properly reordered. -// -// As the algorithm is defined to operate on a single paragraph at a time, this -// implementation is written to handle single paragraphs. Thus rule P1 is -// presumed by this implementation-- the data provided to the implementation is -// assumed to be a single paragraph, and either contains no 'B' codes, or a -// single 'B' code at the end of the input. 'B' is allowed as input to -// illustrate how the algorithm assigns it a level. -// -// Also note that rules L3 and L4 depend on the rendering engine that uses the -// result of the bidi algorithm. This implementation assumes that the rendering -// engine expects combining marks in visual order (e.g. to the left of their -// base character in RTL runs) and that it adjusts the glyphs used to render -// mirrored characters that are in RTL runs so that they render appropriately. - -// level is the embedding level of a character. Even embedding levels indicate -// left-to-right order and odd levels indicate right-to-left order. The special -// level of -1 is reserved for undefined order. -type level int8 - -const implicitLevel level = -1 - -// in returns if x is equal to any of the values in set. -func (c Class) in(set ...Class) bool { - for _, s := range set { - if c == s { - return true - } - } - return false -} - -// A paragraph contains the state of a paragraph. -type paragraph struct { - initialTypes []Class - - // Arrays of properties needed for paired bracket evaluation in N0 - pairTypes []bracketType // paired Bracket types for paragraph - pairValues []rune // rune for opening bracket or pbOpen and pbClose; 0 for pbNone - - embeddingLevel level // default: = implicitLevel; - - // at the paragraph levels - resultTypes []Class - resultLevels []level - - // Index of matching PDI for isolate initiator characters. For other - // characters, the value of matchingPDI will be set to -1. For isolate - // initiators with no matching PDI, matchingPDI will be set to the length of - // the input string. - matchingPDI []int - - // Index of matching isolate initiator for PDI characters. For other - // characters, and for PDIs with no matching isolate initiator, the value of - // matchingIsolateInitiator will be set to -1. - matchingIsolateInitiator []int -} - -// newParagraph initializes a paragraph. The user needs to supply a few arrays -// corresponding to the preprocessed text input. The types correspond to the -// Unicode BiDi classes for each rune. pairTypes indicates the bracket type for -// each rune. pairValues provides a unique bracket class identifier for each -// rune (suggested is the rune of the open bracket for opening and matching -// close brackets, after normalization). The embedding levels are optional, but -// may be supplied to encode embedding levels of styled text. -// -// TODO: return an error. -func newParagraph(types []Class, pairTypes []bracketType, pairValues []rune, levels level) *paragraph { - validateTypes(types) - validatePbTypes(pairTypes) - validatePbValues(pairValues, pairTypes) - validateParagraphEmbeddingLevel(levels) - - p := ¶graph{ - initialTypes: append([]Class(nil), types...), - embeddingLevel: levels, - - pairTypes: pairTypes, - pairValues: pairValues, - - resultTypes: append([]Class(nil), types...), - } - p.run() - return p -} - -func (p *paragraph) Len() int { return len(p.initialTypes) } - -// The algorithm. Does not include line-based processing (Rules L1, L2). -// These are applied later in the line-based phase of the algorithm. -func (p *paragraph) run() { - p.determineMatchingIsolates() - - // 1) determining the paragraph level - // Rule P1 is the requirement for entering this algorithm. - // Rules P2, P3. - // If no externally supplied paragraph embedding level, use default. - if p.embeddingLevel == implicitLevel { - p.embeddingLevel = p.determineParagraphEmbeddingLevel(0, p.Len()) - } - - // Initialize result levels to paragraph embedding level. - p.resultLevels = make([]level, p.Len()) - setLevels(p.resultLevels, p.embeddingLevel) - - // 2) Explicit levels and directions - // Rules X1-X8. - p.determineExplicitEmbeddingLevels() - - // Rule X9. - // We do not remove the embeddings, the overrides, the PDFs, and the BNs - // from the string explicitly. But they are not copied into isolating run - // sequences when they are created, so they are removed for all - // practical purposes. - - // Rule X10. - // Run remainder of algorithm one isolating run sequence at a time - for _, seq := range p.determineIsolatingRunSequences() { - // 3) resolving weak types - // Rules W1-W7. - seq.resolveWeakTypes() - - // 4a) resolving paired brackets - // Rule N0 - resolvePairedBrackets(seq) - - // 4b) resolving neutral types - // Rules N1-N3. - seq.resolveNeutralTypes() - - // 5) resolving implicit embedding levels - // Rules I1, I2. - seq.resolveImplicitLevels() - - // Apply the computed levels and types - seq.applyLevelsAndTypes() - } - - // Assign appropriate levels to 'hide' LREs, RLEs, LROs, RLOs, PDFs, and - // BNs. This is for convenience, so the resulting level array will have - // a value for every character. - p.assignLevelsToCharactersRemovedByX9() -} - -// determineMatchingIsolates determines the matching PDI for each isolate -// initiator and vice versa. -// -// Definition BD9. -// -// At the end of this function: -// -// - The member variable matchingPDI is set to point to the index of the -// matching PDI character for each isolate initiator character. If there is -// no matching PDI, it is set to the length of the input text. For other -// characters, it is set to -1. -// - The member variable matchingIsolateInitiator is set to point to the -// index of the matching isolate initiator character for each PDI character. -// If there is no matching isolate initiator, or the character is not a PDI, -// it is set to -1. -func (p *paragraph) determineMatchingIsolates() { - p.matchingPDI = make([]int, p.Len()) - p.matchingIsolateInitiator = make([]int, p.Len()) - - for i := range p.matchingIsolateInitiator { - p.matchingIsolateInitiator[i] = -1 - } - - for i := range p.matchingPDI { - p.matchingPDI[i] = -1 - - if t := p.resultTypes[i]; t.in(LRI, RLI, FSI) { - depthCounter := 1 - for j := i + 1; j < p.Len(); j++ { - if u := p.resultTypes[j]; u.in(LRI, RLI, FSI) { - depthCounter++ - } else if u == PDI { - if depthCounter--; depthCounter == 0 { - p.matchingPDI[i] = j - p.matchingIsolateInitiator[j] = i - break - } - } - } - if p.matchingPDI[i] == -1 { - p.matchingPDI[i] = p.Len() - } - } - } -} - -// determineParagraphEmbeddingLevel reports the resolved paragraph direction of -// the substring limited by the given range [start, end). -// -// Determines the paragraph level based on rules P2, P3. This is also used -// in rule X5c to find if an FSI should resolve to LRI or RLI. -func (p *paragraph) determineParagraphEmbeddingLevel(start, end int) level { - var strongType Class = unknownClass - - // Rule P2. - for i := start; i < end; i++ { - if t := p.resultTypes[i]; t.in(L, AL, R) { - strongType = t - break - } else if t.in(FSI, LRI, RLI) { - i = p.matchingPDI[i] // skip over to the matching PDI - if i > end { - log.Panic("assert (i <= end)") - } - } - } - // Rule P3. - switch strongType { - case unknownClass: // none found - // default embedding level when no strong types found is 0. - return 0 - case L: - return 0 - default: // AL, R - return 1 - } -} - -const maxDepth = 125 - -// This stack will store the embedding levels and override and isolated -// statuses -type directionalStatusStack struct { - stackCounter int - embeddingLevelStack [maxDepth + 1]level - overrideStatusStack [maxDepth + 1]Class - isolateStatusStack [maxDepth + 1]bool -} - -func (s *directionalStatusStack) empty() { s.stackCounter = 0 } -func (s *directionalStatusStack) pop() { s.stackCounter-- } -func (s *directionalStatusStack) depth() int { return s.stackCounter } - -func (s *directionalStatusStack) push(level level, overrideStatus Class, isolateStatus bool) { - s.embeddingLevelStack[s.stackCounter] = level - s.overrideStatusStack[s.stackCounter] = overrideStatus - s.isolateStatusStack[s.stackCounter] = isolateStatus - s.stackCounter++ -} - -func (s *directionalStatusStack) lastEmbeddingLevel() level { - return s.embeddingLevelStack[s.stackCounter-1] -} - -func (s *directionalStatusStack) lastDirectionalOverrideStatus() Class { - return s.overrideStatusStack[s.stackCounter-1] -} - -func (s *directionalStatusStack) lastDirectionalIsolateStatus() bool { - return s.isolateStatusStack[s.stackCounter-1] -} - -// Determine explicit levels using rules X1 - X8 -func (p *paragraph) determineExplicitEmbeddingLevels() { - var stack directionalStatusStack - var overflowIsolateCount, overflowEmbeddingCount, validIsolateCount int - - // Rule X1. - stack.push(p.embeddingLevel, ON, false) - - for i, t := range p.resultTypes { - // Rules X2, X3, X4, X5, X5a, X5b, X5c - switch t { - case RLE, LRE, RLO, LRO, RLI, LRI, FSI: - isIsolate := t.in(RLI, LRI, FSI) - isRTL := t.in(RLE, RLO, RLI) - - // override if this is an FSI that resolves to RLI - if t == FSI { - isRTL = (p.determineParagraphEmbeddingLevel(i+1, p.matchingPDI[i]) == 1) - } - if isIsolate { - p.resultLevels[i] = stack.lastEmbeddingLevel() - } - - var newLevel level - if isRTL { - // least greater odd - newLevel = (stack.lastEmbeddingLevel() + 1) | 1 - } else { - // least greater even - newLevel = (stack.lastEmbeddingLevel() + 2) &^ 1 - } - - if newLevel <= maxDepth && overflowIsolateCount == 0 && overflowEmbeddingCount == 0 { - if isIsolate { - validIsolateCount++ - } - // Push new embedding level, override status, and isolated - // status. - // No check for valid stack counter, since the level check - // suffices. - switch t { - case LRO: - stack.push(newLevel, L, isIsolate) - case RLO: - stack.push(newLevel, R, isIsolate) - default: - stack.push(newLevel, ON, isIsolate) - } - // Not really part of the spec - if !isIsolate { - p.resultLevels[i] = newLevel - } - } else { - // This is an invalid explicit formatting character, - // so apply the "Otherwise" part of rules X2-X5b. - if isIsolate { - overflowIsolateCount++ - } else { // !isIsolate - if overflowIsolateCount == 0 { - overflowEmbeddingCount++ - } - } - } - - // Rule X6a - case PDI: - if overflowIsolateCount > 0 { - overflowIsolateCount-- - } else if validIsolateCount == 0 { - // do nothing - } else { - overflowEmbeddingCount = 0 - for !stack.lastDirectionalIsolateStatus() { - stack.pop() - } - stack.pop() - validIsolateCount-- - } - p.resultLevels[i] = stack.lastEmbeddingLevel() - - // Rule X7 - case PDF: - // Not really part of the spec - p.resultLevels[i] = stack.lastEmbeddingLevel() - - if overflowIsolateCount > 0 { - // do nothing - } else if overflowEmbeddingCount > 0 { - overflowEmbeddingCount-- - } else if !stack.lastDirectionalIsolateStatus() && stack.depth() >= 2 { - stack.pop() - } - - case B: // paragraph separator. - // Rule X8. - - // These values are reset for clarity, in this implementation B - // can only occur as the last code in the array. - stack.empty() - overflowIsolateCount = 0 - overflowEmbeddingCount = 0 - validIsolateCount = 0 - p.resultLevels[i] = p.embeddingLevel - - default: - p.resultLevels[i] = stack.lastEmbeddingLevel() - if stack.lastDirectionalOverrideStatus() != ON { - p.resultTypes[i] = stack.lastDirectionalOverrideStatus() - } - } - } -} - -type isolatingRunSequence struct { - p *paragraph - - indexes []int // indexes to the original string - - types []Class // type of each character using the index - resolvedLevels []level // resolved levels after application of rules - level level - sos, eos Class -} - -func (i *isolatingRunSequence) Len() int { return len(i.indexes) } - -func maxLevel(a, b level) level { - if a > b { - return a - } - return b -} - -// Rule X10, second bullet: Determine the start-of-sequence (sos) and end-of-sequence (eos) types, -// either L or R, for each isolating run sequence. -func (p *paragraph) isolatingRunSequence(indexes []int) *isolatingRunSequence { - length := len(indexes) - types := make([]Class, length) - for i, x := range indexes { - types[i] = p.resultTypes[x] - } - - // assign level, sos and eos - prevChar := indexes[0] - 1 - for prevChar >= 0 && isRemovedByX9(p.initialTypes[prevChar]) { - prevChar-- - } - prevLevel := p.embeddingLevel - if prevChar >= 0 { - prevLevel = p.resultLevels[prevChar] - } - - var succLevel level - lastType := types[length-1] - if lastType.in(LRI, RLI, FSI) { - succLevel = p.embeddingLevel - } else { - // the first character after the end of run sequence - limit := indexes[length-1] + 1 - for ; limit < p.Len() && isRemovedByX9(p.initialTypes[limit]); limit++ { - - } - succLevel = p.embeddingLevel - if limit < p.Len() { - succLevel = p.resultLevels[limit] - } - } - level := p.resultLevels[indexes[0]] - return &isolatingRunSequence{ - p: p, - indexes: indexes, - types: types, - level: level, - sos: typeForLevel(maxLevel(prevLevel, level)), - eos: typeForLevel(maxLevel(succLevel, level)), - } -} - -// Resolving weak types Rules W1-W7. -// -// Note that some weak types (EN, AN) remain after this processing is -// complete. -func (s *isolatingRunSequence) resolveWeakTypes() { - - // on entry, only these types remain - s.assertOnly(L, R, AL, EN, ES, ET, AN, CS, B, S, WS, ON, NSM, LRI, RLI, FSI, PDI) - - // Rule W1. - // Changes all NSMs. - preceedingCharacterType := s.sos - for i, t := range s.types { - if t == NSM { - s.types[i] = preceedingCharacterType - } else { - if t.in(LRI, RLI, FSI, PDI) { - preceedingCharacterType = ON - } - preceedingCharacterType = t - } - } - - // Rule W2. - // EN does not change at the start of the run, because sos != AL. - for i, t := range s.types { - if t == EN { - for j := i - 1; j >= 0; j-- { - if t := s.types[j]; t.in(L, R, AL) { - if t == AL { - s.types[i] = AN - } - break - } - } - } - } - - // Rule W3. - for i, t := range s.types { - if t == AL { - s.types[i] = R - } - } - - // Rule W4. - // Since there must be values on both sides for this rule to have an - // effect, the scan skips the first and last value. - // - // Although the scan proceeds left to right, and changes the type - // values in a way that would appear to affect the computations - // later in the scan, there is actually no problem. A change in the - // current value can only affect the value to its immediate right, - // and only affect it if it is ES or CS. But the current value can - // only change if the value to its right is not ES or CS. Thus - // either the current value will not change, or its change will have - // no effect on the remainder of the analysis. - - for i := 1; i < s.Len()-1; i++ { - t := s.types[i] - if t == ES || t == CS { - prevSepType := s.types[i-1] - succSepType := s.types[i+1] - if prevSepType == EN && succSepType == EN { - s.types[i] = EN - } else if s.types[i] == CS && prevSepType == AN && succSepType == AN { - s.types[i] = AN - } - } - } - - // Rule W5. - for i, t := range s.types { - if t == ET { - // locate end of sequence - runStart := i - runEnd := s.findRunLimit(runStart, ET) - - // check values at ends of sequence - t := s.sos - if runStart > 0 { - t = s.types[runStart-1] - } - if t != EN { - t = s.eos - if runEnd < len(s.types) { - t = s.types[runEnd] - } - } - if t == EN { - setTypes(s.types[runStart:runEnd], EN) - } - // continue at end of sequence - i = runEnd - } - } - - // Rule W6. - for i, t := range s.types { - if t.in(ES, ET, CS) { - s.types[i] = ON - } - } - - // Rule W7. - for i, t := range s.types { - if t == EN { - // set default if we reach start of run - prevStrongType := s.sos - for j := i - 1; j >= 0; j-- { - t = s.types[j] - if t == L || t == R { // AL's have been changed to R - prevStrongType = t - break - } - } - if prevStrongType == L { - s.types[i] = L - } - } - } -} - -// 6) resolving neutral types Rules N1-N2. -func (s *isolatingRunSequence) resolveNeutralTypes() { - - // on entry, only these types can be in resultTypes - s.assertOnly(L, R, EN, AN, B, S, WS, ON, RLI, LRI, FSI, PDI) - - for i, t := range s.types { - switch t { - case WS, ON, B, S, RLI, LRI, FSI, PDI: - // find bounds of run of neutrals - runStart := i - runEnd := s.findRunLimit(runStart, B, S, WS, ON, RLI, LRI, FSI, PDI) - - // determine effective types at ends of run - var leadType, trailType Class - - // Note that the character found can only be L, R, AN, or - // EN. - if runStart == 0 { - leadType = s.sos - } else { - leadType = s.types[runStart-1] - if leadType.in(AN, EN) { - leadType = R - } - } - if runEnd == len(s.types) { - trailType = s.eos - } else { - trailType = s.types[runEnd] - if trailType.in(AN, EN) { - trailType = R - } - } - - var resolvedType Class - if leadType == trailType { - // Rule N1. - resolvedType = leadType - } else { - // Rule N2. - // Notice the embedding level of the run is used, not - // the paragraph embedding level. - resolvedType = typeForLevel(s.level) - } - - setTypes(s.types[runStart:runEnd], resolvedType) - - // skip over run of (former) neutrals - i = runEnd - } - } -} - -func setLevels(levels []level, newLevel level) { - for i := range levels { - levels[i] = newLevel - } -} - -func setTypes(types []Class, newType Class) { - for i := range types { - types[i] = newType - } -} - -// 7) resolving implicit embedding levels Rules I1, I2. -func (s *isolatingRunSequence) resolveImplicitLevels() { - - // on entry, only these types can be in resultTypes - s.assertOnly(L, R, EN, AN) - - s.resolvedLevels = make([]level, len(s.types)) - setLevels(s.resolvedLevels, s.level) - - if (s.level & 1) == 0 { // even level - for i, t := range s.types { - // Rule I1. - if t == L { - // no change - } else if t == R { - s.resolvedLevels[i] += 1 - } else { // t == AN || t == EN - s.resolvedLevels[i] += 2 - } - } - } else { // odd level - for i, t := range s.types { - // Rule I2. - if t == R { - // no change - } else { // t == L || t == AN || t == EN - s.resolvedLevels[i] += 1 - } - } - } -} - -// Applies the levels and types resolved in rules W1-I2 to the -// resultLevels array. -func (s *isolatingRunSequence) applyLevelsAndTypes() { - for i, x := range s.indexes { - s.p.resultTypes[x] = s.types[i] - s.p.resultLevels[x] = s.resolvedLevels[i] - } -} - -// Return the limit of the run consisting only of the types in validSet -// starting at index. This checks the value at index, and will return -// index if that value is not in validSet. -func (s *isolatingRunSequence) findRunLimit(index int, validSet ...Class) int { -loop: - for ; index < len(s.types); index++ { - t := s.types[index] - for _, valid := range validSet { - if t == valid { - continue loop - } - } - return index // didn't find a match in validSet - } - return len(s.types) -} - -// Algorithm validation. Assert that all values in types are in the -// provided set. -func (s *isolatingRunSequence) assertOnly(codes ...Class) { -loop: - for i, t := range s.types { - for _, c := range codes { - if t == c { - continue loop - } - } - log.Panicf("invalid bidi code %s present in assertOnly at position %d", t, s.indexes[i]) - } -} - -// determineLevelRuns returns an array of level runs. Each level run is -// described as an array of indexes into the input string. -// -// Determines the level runs. Rule X9 will be applied in determining the -// runs, in the way that makes sure the characters that are supposed to be -// removed are not included in the runs. -func (p *paragraph) determineLevelRuns() [][]int { - run := []int{} - allRuns := [][]int{} - currentLevel := implicitLevel - - for i := range p.initialTypes { - if !isRemovedByX9(p.initialTypes[i]) { - if p.resultLevels[i] != currentLevel { - // we just encountered a new run; wrap up last run - if currentLevel >= 0 { // only wrap it up if there was a run - allRuns = append(allRuns, run) - run = nil - } - // Start new run - currentLevel = p.resultLevels[i] - } - run = append(run, i) - } - } - // Wrap up the final run, if any - if len(run) > 0 { - allRuns = append(allRuns, run) - } - return allRuns -} - -// Definition BD13. Determine isolating run sequences. -func (p *paragraph) determineIsolatingRunSequences() []*isolatingRunSequence { - levelRuns := p.determineLevelRuns() - - // Compute the run that each character belongs to - runForCharacter := make([]int, p.Len()) - for i, run := range levelRuns { - for _, index := range run { - runForCharacter[index] = i - } - } - - sequences := []*isolatingRunSequence{} - - var currentRunSequence []int - - for _, run := range levelRuns { - first := run[0] - if p.initialTypes[first] != PDI || p.matchingIsolateInitiator[first] == -1 { - currentRunSequence = nil - // int run = i; - for { - // Copy this level run into currentRunSequence - currentRunSequence = append(currentRunSequence, run...) - - last := currentRunSequence[len(currentRunSequence)-1] - lastT := p.initialTypes[last] - if lastT.in(LRI, RLI, FSI) && p.matchingPDI[last] != p.Len() { - run = levelRuns[runForCharacter[p.matchingPDI[last]]] - } else { - break - } - } - sequences = append(sequences, p.isolatingRunSequence(currentRunSequence)) - } - } - return sequences -} - -// Assign level information to characters removed by rule X9. This is for -// ease of relating the level information to the original input data. Note -// that the levels assigned to these codes are arbitrary, they're chosen so -// as to avoid breaking level runs. -func (p *paragraph) assignLevelsToCharactersRemovedByX9() { - for i, t := range p.initialTypes { - if t.in(LRE, RLE, LRO, RLO, PDF, BN) { - p.resultTypes[i] = t - p.resultLevels[i] = -1 - } - } - // now propagate forward the levels information (could have - // propagated backward, the main thing is not to introduce a level - // break where one doesn't already exist). - - if p.resultLevels[0] == -1 { - p.resultLevels[0] = p.embeddingLevel - } - for i := 1; i < len(p.initialTypes); i++ { - if p.resultLevels[i] == -1 { - p.resultLevels[i] = p.resultLevels[i-1] - } - } - // Embedding information is for informational purposes only so need not be - // adjusted. -} - -// -// Output -// - -// getLevels computes levels array breaking lines at offsets in linebreaks. -// Rule L1. -// -// The linebreaks array must include at least one value. The values must be -// in strictly increasing order (no duplicates) between 1 and the length of -// the text, inclusive. The last value must be the length of the text. -func (p *paragraph) getLevels(linebreaks []int) []level { - // Note that since the previous processing has removed all - // P, S, and WS values from resultTypes, the values referred to - // in these rules are the initial types, before any processing - // has been applied (including processing of overrides). - // - // This example implementation has reinserted explicit format codes - // and BN, in order that the levels array correspond to the - // initial text. Their final placement is not normative. - // These codes are treated like WS in this implementation, - // so they don't interrupt sequences of WS. - - validateLineBreaks(linebreaks, p.Len()) - - result := append([]level(nil), p.resultLevels...) - - // don't worry about linebreaks since if there is a break within - // a series of WS values preceding S, the linebreak itself - // causes the reset. - for i, t := range p.initialTypes { - if t.in(B, S) { - // Rule L1, clauses one and two. - result[i] = p.embeddingLevel - - // Rule L1, clause three. - for j := i - 1; j >= 0; j-- { - if isWhitespace(p.initialTypes[j]) { // including format codes - result[j] = p.embeddingLevel - } else { - break - } - } - } - } - - // Rule L1, clause four. - start := 0 - for _, limit := range linebreaks { - for j := limit - 1; j >= start; j-- { - if isWhitespace(p.initialTypes[j]) { // including format codes - result[j] = p.embeddingLevel - } else { - break - } - } - start = limit - } - - return result -} - -// getReordering returns the reordering of lines from a visual index to a -// logical index for line breaks at the given offsets. -// -// Lines are concatenated from left to right. So for example, the fifth -// character from the left on the third line is -// -// getReordering(linebreaks)[linebreaks[1] + 4] -// -// (linebreaks[1] is the position after the last character of the second -// line, which is also the index of the first character on the third line, -// and adding four gets the fifth character from the left). -// -// The linebreaks array must include at least one value. The values must be -// in strictly increasing order (no duplicates) between 1 and the length of -// the text, inclusive. The last value must be the length of the text. -func (p *paragraph) getReordering(linebreaks []int) []int { - validateLineBreaks(linebreaks, p.Len()) - - return computeMultilineReordering(p.getLevels(linebreaks), linebreaks) -} - -// Return multiline reordering array for a given level array. Reordering -// does not occur across a line break. -func computeMultilineReordering(levels []level, linebreaks []int) []int { - result := make([]int, len(levels)) - - start := 0 - for _, limit := range linebreaks { - tempLevels := make([]level, limit-start) - copy(tempLevels, levels[start:]) - - for j, order := range computeReordering(tempLevels) { - result[start+j] = order + start - } - start = limit - } - return result -} - -// Return reordering array for a given level array. This reorders a single -// line. The reordering is a visual to logical map. For example, the -// leftmost char is string.charAt(order[0]). Rule L2. -func computeReordering(levels []level) []int { - result := make([]int, len(levels)) - // initialize order - for i := range result { - result[i] = i - } - - // locate highest level found on line. - // Note the rules say text, but no reordering across line bounds is - // performed, so this is sufficient. - highestLevel := level(0) - lowestOddLevel := level(maxDepth + 2) - for _, level := range levels { - if level > highestLevel { - highestLevel = level - } - if level&1 != 0 && level < lowestOddLevel { - lowestOddLevel = level - } - } - - for level := highestLevel; level >= lowestOddLevel; level-- { - for i := 0; i < len(levels); i++ { - if levels[i] >= level { - // find range of text at or above this level - start := i - limit := i + 1 - for limit < len(levels) && levels[limit] >= level { - limit++ - } - - for j, k := start, limit-1; j < k; j, k = j+1, k-1 { - result[j], result[k] = result[k], result[j] - } - // skip to end of level run - i = limit - } - } - } - - return result -} - -// isWhitespace reports whether the type is considered a whitespace type for the -// line break rules. -func isWhitespace(c Class) bool { - switch c { - case LRE, RLE, LRO, RLO, PDF, LRI, RLI, FSI, PDI, BN, WS: - return true - } - return false -} - -// isRemovedByX9 reports whether the type is one of the types removed in X9. -func isRemovedByX9(c Class) bool { - switch c { - case LRE, RLE, LRO, RLO, PDF, BN: - return true - } - return false -} - -// typeForLevel reports the strong type (L or R) corresponding to the level. -func typeForLevel(level level) Class { - if (level & 0x1) == 0 { - return L - } - return R -} - -// TODO: change validation to not panic - -func validateTypes(types []Class) { - if len(types) == 0 { - log.Panic("types is null") - } - for i, t := range types[:len(types)-1] { - if t == B { - log.Panicf("B type before end of paragraph at index: %d", i) - } - } -} - -func validateParagraphEmbeddingLevel(embeddingLevel level) { - if embeddingLevel != implicitLevel && - embeddingLevel != 0 && - embeddingLevel != 1 { - log.Panicf("illegal paragraph embedding level: %d", embeddingLevel) - } -} - -func validateLineBreaks(linebreaks []int, textLength int) { - prev := 0 - for i, next := range linebreaks { - if next <= prev { - log.Panicf("bad linebreak: %d at index: %d", next, i) - } - prev = next - } - if prev != textLength { - log.Panicf("last linebreak was %d, want %d", prev, textLength) - } -} - -func validatePbTypes(pairTypes []bracketType) { - if len(pairTypes) == 0 { - log.Panic("pairTypes is null") - } - for i, pt := range pairTypes { - switch pt { - case bpNone, bpOpen, bpClose: - default: - log.Panicf("illegal pairType value at %d: %v", i, pairTypes[i]) - } - } -} - -func validatePbValues(pairValues []rune, pairTypes []bracketType) { - if pairValues == nil { - log.Panic("pairValues is null") - } - if len(pairTypes) != len(pairValues) { - log.Panic("pairTypes is different length from pairValues") - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen.go deleted file mode 100644 index 040f301..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen.go +++ /dev/null @@ -1,133 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -import ( - "flag" - "log" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/triegen" - "golang.org/x/text/internal/ucd" -) - -var outputFile = flag.String("out", "tables.go", "output file") - -func main() { - gen.Init() - gen.Repackage("gen_trieval.go", "trieval.go", "bidi") - gen.Repackage("gen_ranges.go", "ranges_test.go", "bidi") - - genTables() -} - -// bidiClass names and codes taken from class "bc" in -// http://www.unicode.org/Public/8.0.0/ucd/PropertyValueAliases.txt -var bidiClass = map[string]Class{ - "AL": AL, // ArabicLetter - "AN": AN, // ArabicNumber - "B": B, // ParagraphSeparator - "BN": BN, // BoundaryNeutral - "CS": CS, // CommonSeparator - "EN": EN, // EuropeanNumber - "ES": ES, // EuropeanSeparator - "ET": ET, // EuropeanTerminator - "L": L, // LeftToRight - "NSM": NSM, // NonspacingMark - "ON": ON, // OtherNeutral - "R": R, // RightToLeft - "S": S, // SegmentSeparator - "WS": WS, // WhiteSpace - - "FSI": Control, - "PDF": Control, - "PDI": Control, - "LRE": Control, - "LRI": Control, - "LRO": Control, - "RLE": Control, - "RLI": Control, - "RLO": Control, -} - -func genTables() { - if numClass > 0x0F { - log.Fatalf("Too many Class constants (%#x > 0x0F).", numClass) - } - w := gen.NewCodeWriter() - defer w.WriteGoFile(*outputFile, "bidi") - - gen.WriteUnicodeVersion(w) - - t := triegen.NewTrie("bidi") - - // Build data about bracket mapping. These bits need to be or-ed with - // any other bits. - orMask := map[rune]uint64{} - - xorMap := map[rune]int{} - xorMasks := []rune{0} // First value is no-op. - - ucd.Parse(gen.OpenUCDFile("BidiBrackets.txt"), func(p *ucd.Parser) { - r1 := p.Rune(0) - r2 := p.Rune(1) - xor := r1 ^ r2 - if _, ok := xorMap[xor]; !ok { - xorMap[xor] = len(xorMasks) - xorMasks = append(xorMasks, xor) - } - entry := uint64(xorMap[xor]) << xorMaskShift - switch p.String(2) { - case "o": - entry |= openMask - case "c", "n": - default: - log.Fatalf("Unknown bracket class %q.", p.String(2)) - } - orMask[r1] = entry - }) - - w.WriteComment(` - xorMasks contains masks to be xor-ed with brackets to get the reverse - version.`) - w.WriteVar("xorMasks", xorMasks) - - done := map[rune]bool{} - - insert := func(r rune, c Class) { - if !done[r] { - t.Insert(r, orMask[r]|uint64(c)) - done[r] = true - } - } - - // Insert the derived BiDi properties. - ucd.Parse(gen.OpenUCDFile("extracted/DerivedBidiClass.txt"), func(p *ucd.Parser) { - r := p.Rune(0) - class, ok := bidiClass[p.String(1)] - if !ok { - log.Fatalf("%U: Unknown BiDi class %q", r, p.String(1)) - } - insert(r, class) - }) - visitDefaults(insert) - - // TODO: use sparse blocks. This would reduce table size considerably - // from the looks of it. - - sz, err := t.Gen(w) - if err != nil { - log.Fatal(err) - } - w.Size += sz -} - -// dummy values to make methods in gen_common compile. The real versions -// will be generated by this file to tables.go. -var ( - xorMasks []rune -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_ranges.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_ranges.go deleted file mode 100644 index 51bd68f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_ranges.go +++ /dev/null @@ -1,57 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -import ( - "unicode" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/ucd" - "golang.org/x/text/unicode/rangetable" -) - -// These tables are hand-extracted from: -// http://www.unicode.org/Public/8.0.0/ucd/extracted/DerivedBidiClass.txt -func visitDefaults(fn func(r rune, c Class)) { - // first write default values for ranges listed above. - visitRunes(fn, AL, []rune{ - 0x0600, 0x07BF, // Arabic - 0x08A0, 0x08FF, // Arabic Extended-A - 0xFB50, 0xFDCF, // Arabic Presentation Forms - 0xFDF0, 0xFDFF, - 0xFE70, 0xFEFF, - 0x0001EE00, 0x0001EEFF, // Arabic Mathematical Alpha Symbols - }) - visitRunes(fn, R, []rune{ - 0x0590, 0x05FF, // Hebrew - 0x07C0, 0x089F, // Nko et al. - 0xFB1D, 0xFB4F, - 0x00010800, 0x00010FFF, // Cypriot Syllabary et. al. - 0x0001E800, 0x0001EDFF, - 0x0001EF00, 0x0001EFFF, - }) - visitRunes(fn, ET, []rune{ // European Terminator - 0x20A0, 0x20Cf, // Currency symbols - }) - rangetable.Visit(unicode.Noncharacter_Code_Point, func(r rune) { - fn(r, BN) // Boundary Neutral - }) - ucd.Parse(gen.OpenUCDFile("DerivedCoreProperties.txt"), func(p *ucd.Parser) { - if p.String(1) == "Default_Ignorable_Code_Point" { - fn(p.Rune(0), BN) // Boundary Neutral - } - }) -} - -func visitRunes(fn func(r rune, c Class), c Class, runes []rune) { - for i := 0; i < len(runes); i += 2 { - lo, hi := runes[i], runes[i+1] - for j := lo; j <= hi; j++ { - fn(j, c) - } - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_trieval.go deleted file mode 100644 index 9cb9942..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/gen_trieval.go +++ /dev/null @@ -1,64 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// Class is the Unicode BiDi class. Each rune has a single class. -type Class uint - -const ( - L Class = iota // LeftToRight - R // RightToLeft - EN // EuropeanNumber - ES // EuropeanSeparator - ET // EuropeanTerminator - AN // ArabicNumber - CS // CommonSeparator - B // ParagraphSeparator - S // SegmentSeparator - WS // WhiteSpace - ON // OtherNeutral - BN // BoundaryNeutral - NSM // NonspacingMark - AL // ArabicLetter - Control // Control LRO - PDI - - numClass - - LRO // LeftToRightOverride - RLO // RightToLeftOverride - LRE // LeftToRightEmbedding - RLE // RightToLeftEmbedding - PDF // PopDirectionalFormat - LRI // LeftToRightIsolate - RLI // RightToLeftIsolate - FSI // FirstStrongIsolate - PDI // PopDirectionalIsolate - - unknownClass = ^Class(0) -) - -var controlToClass = map[rune]Class{ - 0x202D: LRO, // LeftToRightOverride, - 0x202E: RLO, // RightToLeftOverride, - 0x202A: LRE, // LeftToRightEmbedding, - 0x202B: RLE, // RightToLeftEmbedding, - 0x202C: PDF, // PopDirectionalFormat, - 0x2066: LRI, // LeftToRightIsolate, - 0x2067: RLI, // RightToLeftIsolate, - 0x2068: FSI, // FirstStrongIsolate, - 0x2069: PDI, // PopDirectionalIsolate, -} - -// A trie entry has the following bits: -// 7..5 XOR mask for brackets -// 4 1: Bracket open, 0: Bracket close -// 3..0 Class type - -const ( - openMask = 0x10 - xorMaskShift = 5 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/prop.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/prop.go deleted file mode 100644 index 7c9484e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/prop.go +++ /dev/null @@ -1,206 +0,0 @@ -// Copyright 2016 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package bidi - -import "unicode/utf8" - -// Properties provides access to BiDi properties of runes. -type Properties struct { - entry uint8 - last uint8 -} - -var trie = newBidiTrie(0) - -// TODO: using this for bidirule reduces the running time by about 5%. Consider -// if this is worth exposing or if we can find a way to speed up the Class -// method. -// -// // CompactClass is like Class, but maps all of the BiDi control classes -// // (LRO, RLO, LRE, RLE, PDF, LRI, RLI, FSI, PDI) to the class Control. -// func (p Properties) CompactClass() Class { -// return Class(p.entry & 0x0F) -// } - -// Class returns the Bidi class for p. -func (p Properties) Class() Class { - c := Class(p.entry & 0x0F) - if c == Control { - c = controlByteToClass[p.last&0xF] - } - return c -} - -// IsBracket reports whether the rune is a bracket. -func (p Properties) IsBracket() bool { return p.entry&0xF0 != 0 } - -// IsOpeningBracket reports whether the rune is an opening bracket. -// IsBracket must return true. -func (p Properties) IsOpeningBracket() bool { return p.entry&openMask != 0 } - -// TODO: find a better API and expose. -func (p Properties) reverseBracket(r rune) rune { - return xorMasks[p.entry>>xorMaskShift] ^ r -} - -var controlByteToClass = [16]Class{ - 0xD: LRO, // U+202D LeftToRightOverride, - 0xE: RLO, // U+202E RightToLeftOverride, - 0xA: LRE, // U+202A LeftToRightEmbedding, - 0xB: RLE, // U+202B RightToLeftEmbedding, - 0xC: PDF, // U+202C PopDirectionalFormat, - 0x6: LRI, // U+2066 LeftToRightIsolate, - 0x7: RLI, // U+2067 RightToLeftIsolate, - 0x8: FSI, // U+2068 FirstStrongIsolate, - 0x9: PDI, // U+2069 PopDirectionalIsolate, -} - -// LookupRune returns properties for r. -func LookupRune(r rune) (p Properties, size int) { - var buf [4]byte - n := utf8.EncodeRune(buf[:], r) - return Lookup(buf[:n]) -} - -// TODO: these lookup methods are based on the generated trie code. The returned -// sizes have slightly different semantics from the generated code, in that it -// always returns size==1 for an illegal UTF-8 byte (instead of the length -// of the maximum invalid subsequence). Most Transformers, like unicode/norm, -// leave invalid UTF-8 untouched, in which case it has performance benefits to -// do so (without changing the semantics). Bidi requires the semantics used here -// for the bidirule implementation to be compatible with the Go semantics. -// They ultimately should perhaps be adopted by all trie implementations, for -// convenience sake. -// This unrolled code also boosts performance of the secure/bidirule package by -// about 30%. -// So, to remove this code: -// - add option to trie generator to define return type. -// - always return 1 byte size for ill-formed UTF-8 runes. - -// Lookup returns properties for the first rune in s and the width in bytes of -// its encoding. The size will be 0 if s does not hold enough bytes to complete -// the encoding. -func Lookup(s []byte) (p Properties, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return Properties{entry: bidiValues[c0]}, 1 - case c0 < 0xC2: - return Properties{}, 1 - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c1)}, 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c2), last: c2}, 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return Properties{}, 1 - } - o = uint32(i)<<6 + uint32(c2) - i = bidiIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c3)}, 4 - } - // Illegal rune - return Properties{}, 1 -} - -// LookupString returns properties for the first rune in s and the width in -// bytes of its encoding. The size will be 0 if s does not hold enough bytes to -// complete the encoding. -func LookupString(s string) (p Properties, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return Properties{entry: bidiValues[c0]}, 1 - case c0 < 0xC2: - return Properties{}, 1 - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c1)}, 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c2), last: c2}, 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return Properties{}, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return Properties{}, 1 - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return Properties{}, 1 - } - o = uint32(i)<<6 + uint32(c2) - i = bidiIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return Properties{}, 1 - } - return Properties{entry: trie.lookupValue(uint32(i), c3)}, 4 - } - // Illegal rune - return Properties{}, 1 -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/tables.go deleted file mode 100644 index 2d4dde0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/tables.go +++ /dev/null @@ -1,1779 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package bidi - -// UnicodeVersion is the Unicode version from which the tables in this package are derived. -const UnicodeVersion = "9.0.0" - -// xorMasks contains masks to be xor-ed with brackets to get the reverse -// version. -var xorMasks = []int32{ // 8 elements - 0, 1, 6, 7, 3, 15, 29, 63, -} // Size: 56 bytes - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *bidiTrie) lookup(s []byte) (v uint8, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return bidiValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = bidiIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *bidiTrie) lookupUnsafe(s []byte) uint8 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return bidiValues[c0] - } - i := bidiIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = bidiIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = bidiIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *bidiTrie) lookupString(s string) (v uint8, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return bidiValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := bidiIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = bidiIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = bidiIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *bidiTrie) lookupStringUnsafe(s string) uint8 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return bidiValues[c0] - } - i := bidiIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = bidiIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = bidiIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// bidiTrie. Total size: 15744 bytes (15.38 KiB). Checksum: b4c3b70954803b86. -type bidiTrie struct{} - -func newBidiTrie(i int) *bidiTrie { - return &bidiTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *bidiTrie) lookupValue(n uint32, b byte) uint8 { - switch { - default: - return uint8(bidiValues[n<<6+uint32(b)]) - } -} - -// bidiValues: 222 blocks, 14208 entries, 14208 bytes -// The third block is the zero block. -var bidiValues = [14208]uint8{ - // Block 0x0, offset 0x0 - 0x00: 0x000b, 0x01: 0x000b, 0x02: 0x000b, 0x03: 0x000b, 0x04: 0x000b, 0x05: 0x000b, - 0x06: 0x000b, 0x07: 0x000b, 0x08: 0x000b, 0x09: 0x0008, 0x0a: 0x0007, 0x0b: 0x0008, - 0x0c: 0x0009, 0x0d: 0x0007, 0x0e: 0x000b, 0x0f: 0x000b, 0x10: 0x000b, 0x11: 0x000b, - 0x12: 0x000b, 0x13: 0x000b, 0x14: 0x000b, 0x15: 0x000b, 0x16: 0x000b, 0x17: 0x000b, - 0x18: 0x000b, 0x19: 0x000b, 0x1a: 0x000b, 0x1b: 0x000b, 0x1c: 0x0007, 0x1d: 0x0007, - 0x1e: 0x0007, 0x1f: 0x0008, 0x20: 0x0009, 0x21: 0x000a, 0x22: 0x000a, 0x23: 0x0004, - 0x24: 0x0004, 0x25: 0x0004, 0x26: 0x000a, 0x27: 0x000a, 0x28: 0x003a, 0x29: 0x002a, - 0x2a: 0x000a, 0x2b: 0x0003, 0x2c: 0x0006, 0x2d: 0x0003, 0x2e: 0x0006, 0x2f: 0x0006, - 0x30: 0x0002, 0x31: 0x0002, 0x32: 0x0002, 0x33: 0x0002, 0x34: 0x0002, 0x35: 0x0002, - 0x36: 0x0002, 0x37: 0x0002, 0x38: 0x0002, 0x39: 0x0002, 0x3a: 0x0006, 0x3b: 0x000a, - 0x3c: 0x000a, 0x3d: 0x000a, 0x3e: 0x000a, 0x3f: 0x000a, - // Block 0x1, offset 0x40 - 0x40: 0x000a, - 0x5b: 0x005a, 0x5c: 0x000a, 0x5d: 0x004a, - 0x5e: 0x000a, 0x5f: 0x000a, 0x60: 0x000a, - 0x7b: 0x005a, - 0x7c: 0x000a, 0x7d: 0x004a, 0x7e: 0x000a, 0x7f: 0x000b, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc0: 0x000b, 0xc1: 0x000b, 0xc2: 0x000b, 0xc3: 0x000b, 0xc4: 0x000b, 0xc5: 0x0007, - 0xc6: 0x000b, 0xc7: 0x000b, 0xc8: 0x000b, 0xc9: 0x000b, 0xca: 0x000b, 0xcb: 0x000b, - 0xcc: 0x000b, 0xcd: 0x000b, 0xce: 0x000b, 0xcf: 0x000b, 0xd0: 0x000b, 0xd1: 0x000b, - 0xd2: 0x000b, 0xd3: 0x000b, 0xd4: 0x000b, 0xd5: 0x000b, 0xd6: 0x000b, 0xd7: 0x000b, - 0xd8: 0x000b, 0xd9: 0x000b, 0xda: 0x000b, 0xdb: 0x000b, 0xdc: 0x000b, 0xdd: 0x000b, - 0xde: 0x000b, 0xdf: 0x000b, 0xe0: 0x0006, 0xe1: 0x000a, 0xe2: 0x0004, 0xe3: 0x0004, - 0xe4: 0x0004, 0xe5: 0x0004, 0xe6: 0x000a, 0xe7: 0x000a, 0xe8: 0x000a, 0xe9: 0x000a, - 0xeb: 0x000a, 0xec: 0x000a, 0xed: 0x000b, 0xee: 0x000a, 0xef: 0x000a, - 0xf0: 0x0004, 0xf1: 0x0004, 0xf2: 0x0002, 0xf3: 0x0002, 0xf4: 0x000a, - 0xf6: 0x000a, 0xf7: 0x000a, 0xf8: 0x000a, 0xf9: 0x0002, 0xfb: 0x000a, - 0xfc: 0x000a, 0xfd: 0x000a, 0xfe: 0x000a, 0xff: 0x000a, - // Block 0x4, offset 0x100 - 0x117: 0x000a, - 0x137: 0x000a, - // Block 0x5, offset 0x140 - 0x179: 0x000a, 0x17a: 0x000a, - // Block 0x6, offset 0x180 - 0x182: 0x000a, 0x183: 0x000a, 0x184: 0x000a, 0x185: 0x000a, - 0x186: 0x000a, 0x187: 0x000a, 0x188: 0x000a, 0x189: 0x000a, 0x18a: 0x000a, 0x18b: 0x000a, - 0x18c: 0x000a, 0x18d: 0x000a, 0x18e: 0x000a, 0x18f: 0x000a, - 0x192: 0x000a, 0x193: 0x000a, 0x194: 0x000a, 0x195: 0x000a, 0x196: 0x000a, 0x197: 0x000a, - 0x198: 0x000a, 0x199: 0x000a, 0x19a: 0x000a, 0x19b: 0x000a, 0x19c: 0x000a, 0x19d: 0x000a, - 0x19e: 0x000a, 0x19f: 0x000a, - 0x1a5: 0x000a, 0x1a6: 0x000a, 0x1a7: 0x000a, 0x1a8: 0x000a, 0x1a9: 0x000a, - 0x1aa: 0x000a, 0x1ab: 0x000a, 0x1ac: 0x000a, 0x1ad: 0x000a, 0x1af: 0x000a, - 0x1b0: 0x000a, 0x1b1: 0x000a, 0x1b2: 0x000a, 0x1b3: 0x000a, 0x1b4: 0x000a, 0x1b5: 0x000a, - 0x1b6: 0x000a, 0x1b7: 0x000a, 0x1b8: 0x000a, 0x1b9: 0x000a, 0x1ba: 0x000a, 0x1bb: 0x000a, - 0x1bc: 0x000a, 0x1bd: 0x000a, 0x1be: 0x000a, 0x1bf: 0x000a, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x000c, 0x1c1: 0x000c, 0x1c2: 0x000c, 0x1c3: 0x000c, 0x1c4: 0x000c, 0x1c5: 0x000c, - 0x1c6: 0x000c, 0x1c7: 0x000c, 0x1c8: 0x000c, 0x1c9: 0x000c, 0x1ca: 0x000c, 0x1cb: 0x000c, - 0x1cc: 0x000c, 0x1cd: 0x000c, 0x1ce: 0x000c, 0x1cf: 0x000c, 0x1d0: 0x000c, 0x1d1: 0x000c, - 0x1d2: 0x000c, 0x1d3: 0x000c, 0x1d4: 0x000c, 0x1d5: 0x000c, 0x1d6: 0x000c, 0x1d7: 0x000c, - 0x1d8: 0x000c, 0x1d9: 0x000c, 0x1da: 0x000c, 0x1db: 0x000c, 0x1dc: 0x000c, 0x1dd: 0x000c, - 0x1de: 0x000c, 0x1df: 0x000c, 0x1e0: 0x000c, 0x1e1: 0x000c, 0x1e2: 0x000c, 0x1e3: 0x000c, - 0x1e4: 0x000c, 0x1e5: 0x000c, 0x1e6: 0x000c, 0x1e7: 0x000c, 0x1e8: 0x000c, 0x1e9: 0x000c, - 0x1ea: 0x000c, 0x1eb: 0x000c, 0x1ec: 0x000c, 0x1ed: 0x000c, 0x1ee: 0x000c, 0x1ef: 0x000c, - 0x1f0: 0x000c, 0x1f1: 0x000c, 0x1f2: 0x000c, 0x1f3: 0x000c, 0x1f4: 0x000c, 0x1f5: 0x000c, - 0x1f6: 0x000c, 0x1f7: 0x000c, 0x1f8: 0x000c, 0x1f9: 0x000c, 0x1fa: 0x000c, 0x1fb: 0x000c, - 0x1fc: 0x000c, 0x1fd: 0x000c, 0x1fe: 0x000c, 0x1ff: 0x000c, - // Block 0x8, offset 0x200 - 0x200: 0x000c, 0x201: 0x000c, 0x202: 0x000c, 0x203: 0x000c, 0x204: 0x000c, 0x205: 0x000c, - 0x206: 0x000c, 0x207: 0x000c, 0x208: 0x000c, 0x209: 0x000c, 0x20a: 0x000c, 0x20b: 0x000c, - 0x20c: 0x000c, 0x20d: 0x000c, 0x20e: 0x000c, 0x20f: 0x000c, 0x210: 0x000c, 0x211: 0x000c, - 0x212: 0x000c, 0x213: 0x000c, 0x214: 0x000c, 0x215: 0x000c, 0x216: 0x000c, 0x217: 0x000c, - 0x218: 0x000c, 0x219: 0x000c, 0x21a: 0x000c, 0x21b: 0x000c, 0x21c: 0x000c, 0x21d: 0x000c, - 0x21e: 0x000c, 0x21f: 0x000c, 0x220: 0x000c, 0x221: 0x000c, 0x222: 0x000c, 0x223: 0x000c, - 0x224: 0x000c, 0x225: 0x000c, 0x226: 0x000c, 0x227: 0x000c, 0x228: 0x000c, 0x229: 0x000c, - 0x22a: 0x000c, 0x22b: 0x000c, 0x22c: 0x000c, 0x22d: 0x000c, 0x22e: 0x000c, 0x22f: 0x000c, - 0x234: 0x000a, 0x235: 0x000a, - 0x23e: 0x000a, - // Block 0x9, offset 0x240 - 0x244: 0x000a, 0x245: 0x000a, - 0x247: 0x000a, - // Block 0xa, offset 0x280 - 0x2b6: 0x000a, - // Block 0xb, offset 0x2c0 - 0x2c3: 0x000c, 0x2c4: 0x000c, 0x2c5: 0x000c, - 0x2c6: 0x000c, 0x2c7: 0x000c, 0x2c8: 0x000c, 0x2c9: 0x000c, - // Block 0xc, offset 0x300 - 0x30a: 0x000a, - 0x30d: 0x000a, 0x30e: 0x000a, 0x30f: 0x0004, 0x310: 0x0001, 0x311: 0x000c, - 0x312: 0x000c, 0x313: 0x000c, 0x314: 0x000c, 0x315: 0x000c, 0x316: 0x000c, 0x317: 0x000c, - 0x318: 0x000c, 0x319: 0x000c, 0x31a: 0x000c, 0x31b: 0x000c, 0x31c: 0x000c, 0x31d: 0x000c, - 0x31e: 0x000c, 0x31f: 0x000c, 0x320: 0x000c, 0x321: 0x000c, 0x322: 0x000c, 0x323: 0x000c, - 0x324: 0x000c, 0x325: 0x000c, 0x326: 0x000c, 0x327: 0x000c, 0x328: 0x000c, 0x329: 0x000c, - 0x32a: 0x000c, 0x32b: 0x000c, 0x32c: 0x000c, 0x32d: 0x000c, 0x32e: 0x000c, 0x32f: 0x000c, - 0x330: 0x000c, 0x331: 0x000c, 0x332: 0x000c, 0x333: 0x000c, 0x334: 0x000c, 0x335: 0x000c, - 0x336: 0x000c, 0x337: 0x000c, 0x338: 0x000c, 0x339: 0x000c, 0x33a: 0x000c, 0x33b: 0x000c, - 0x33c: 0x000c, 0x33d: 0x000c, 0x33e: 0x0001, 0x33f: 0x000c, - // Block 0xd, offset 0x340 - 0x340: 0x0001, 0x341: 0x000c, 0x342: 0x000c, 0x343: 0x0001, 0x344: 0x000c, 0x345: 0x000c, - 0x346: 0x0001, 0x347: 0x000c, 0x348: 0x0001, 0x349: 0x0001, 0x34a: 0x0001, 0x34b: 0x0001, - 0x34c: 0x0001, 0x34d: 0x0001, 0x34e: 0x0001, 0x34f: 0x0001, 0x350: 0x0001, 0x351: 0x0001, - 0x352: 0x0001, 0x353: 0x0001, 0x354: 0x0001, 0x355: 0x0001, 0x356: 0x0001, 0x357: 0x0001, - 0x358: 0x0001, 0x359: 0x0001, 0x35a: 0x0001, 0x35b: 0x0001, 0x35c: 0x0001, 0x35d: 0x0001, - 0x35e: 0x0001, 0x35f: 0x0001, 0x360: 0x0001, 0x361: 0x0001, 0x362: 0x0001, 0x363: 0x0001, - 0x364: 0x0001, 0x365: 0x0001, 0x366: 0x0001, 0x367: 0x0001, 0x368: 0x0001, 0x369: 0x0001, - 0x36a: 0x0001, 0x36b: 0x0001, 0x36c: 0x0001, 0x36d: 0x0001, 0x36e: 0x0001, 0x36f: 0x0001, - 0x370: 0x0001, 0x371: 0x0001, 0x372: 0x0001, 0x373: 0x0001, 0x374: 0x0001, 0x375: 0x0001, - 0x376: 0x0001, 0x377: 0x0001, 0x378: 0x0001, 0x379: 0x0001, 0x37a: 0x0001, 0x37b: 0x0001, - 0x37c: 0x0001, 0x37d: 0x0001, 0x37e: 0x0001, 0x37f: 0x0001, - // Block 0xe, offset 0x380 - 0x380: 0x0005, 0x381: 0x0005, 0x382: 0x0005, 0x383: 0x0005, 0x384: 0x0005, 0x385: 0x0005, - 0x386: 0x000a, 0x387: 0x000a, 0x388: 0x000d, 0x389: 0x0004, 0x38a: 0x0004, 0x38b: 0x000d, - 0x38c: 0x0006, 0x38d: 0x000d, 0x38e: 0x000a, 0x38f: 0x000a, 0x390: 0x000c, 0x391: 0x000c, - 0x392: 0x000c, 0x393: 0x000c, 0x394: 0x000c, 0x395: 0x000c, 0x396: 0x000c, 0x397: 0x000c, - 0x398: 0x000c, 0x399: 0x000c, 0x39a: 0x000c, 0x39b: 0x000d, 0x39c: 0x000d, 0x39d: 0x000d, - 0x39e: 0x000d, 0x39f: 0x000d, 0x3a0: 0x000d, 0x3a1: 0x000d, 0x3a2: 0x000d, 0x3a3: 0x000d, - 0x3a4: 0x000d, 0x3a5: 0x000d, 0x3a6: 0x000d, 0x3a7: 0x000d, 0x3a8: 0x000d, 0x3a9: 0x000d, - 0x3aa: 0x000d, 0x3ab: 0x000d, 0x3ac: 0x000d, 0x3ad: 0x000d, 0x3ae: 0x000d, 0x3af: 0x000d, - 0x3b0: 0x000d, 0x3b1: 0x000d, 0x3b2: 0x000d, 0x3b3: 0x000d, 0x3b4: 0x000d, 0x3b5: 0x000d, - 0x3b6: 0x000d, 0x3b7: 0x000d, 0x3b8: 0x000d, 0x3b9: 0x000d, 0x3ba: 0x000d, 0x3bb: 0x000d, - 0x3bc: 0x000d, 0x3bd: 0x000d, 0x3be: 0x000d, 0x3bf: 0x000d, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x000d, 0x3c1: 0x000d, 0x3c2: 0x000d, 0x3c3: 0x000d, 0x3c4: 0x000d, 0x3c5: 0x000d, - 0x3c6: 0x000d, 0x3c7: 0x000d, 0x3c8: 0x000d, 0x3c9: 0x000d, 0x3ca: 0x000d, 0x3cb: 0x000c, - 0x3cc: 0x000c, 0x3cd: 0x000c, 0x3ce: 0x000c, 0x3cf: 0x000c, 0x3d0: 0x000c, 0x3d1: 0x000c, - 0x3d2: 0x000c, 0x3d3: 0x000c, 0x3d4: 0x000c, 0x3d5: 0x000c, 0x3d6: 0x000c, 0x3d7: 0x000c, - 0x3d8: 0x000c, 0x3d9: 0x000c, 0x3da: 0x000c, 0x3db: 0x000c, 0x3dc: 0x000c, 0x3dd: 0x000c, - 0x3de: 0x000c, 0x3df: 0x000c, 0x3e0: 0x0005, 0x3e1: 0x0005, 0x3e2: 0x0005, 0x3e3: 0x0005, - 0x3e4: 0x0005, 0x3e5: 0x0005, 0x3e6: 0x0005, 0x3e7: 0x0005, 0x3e8: 0x0005, 0x3e9: 0x0005, - 0x3ea: 0x0004, 0x3eb: 0x0005, 0x3ec: 0x0005, 0x3ed: 0x000d, 0x3ee: 0x000d, 0x3ef: 0x000d, - 0x3f0: 0x000c, 0x3f1: 0x000d, 0x3f2: 0x000d, 0x3f3: 0x000d, 0x3f4: 0x000d, 0x3f5: 0x000d, - 0x3f6: 0x000d, 0x3f7: 0x000d, 0x3f8: 0x000d, 0x3f9: 0x000d, 0x3fa: 0x000d, 0x3fb: 0x000d, - 0x3fc: 0x000d, 0x3fd: 0x000d, 0x3fe: 0x000d, 0x3ff: 0x000d, - // Block 0x10, offset 0x400 - 0x400: 0x000d, 0x401: 0x000d, 0x402: 0x000d, 0x403: 0x000d, 0x404: 0x000d, 0x405: 0x000d, - 0x406: 0x000d, 0x407: 0x000d, 0x408: 0x000d, 0x409: 0x000d, 0x40a: 0x000d, 0x40b: 0x000d, - 0x40c: 0x000d, 0x40d: 0x000d, 0x40e: 0x000d, 0x40f: 0x000d, 0x410: 0x000d, 0x411: 0x000d, - 0x412: 0x000d, 0x413: 0x000d, 0x414: 0x000d, 0x415: 0x000d, 0x416: 0x000d, 0x417: 0x000d, - 0x418: 0x000d, 0x419: 0x000d, 0x41a: 0x000d, 0x41b: 0x000d, 0x41c: 0x000d, 0x41d: 0x000d, - 0x41e: 0x000d, 0x41f: 0x000d, 0x420: 0x000d, 0x421: 0x000d, 0x422: 0x000d, 0x423: 0x000d, - 0x424: 0x000d, 0x425: 0x000d, 0x426: 0x000d, 0x427: 0x000d, 0x428: 0x000d, 0x429: 0x000d, - 0x42a: 0x000d, 0x42b: 0x000d, 0x42c: 0x000d, 0x42d: 0x000d, 0x42e: 0x000d, 0x42f: 0x000d, - 0x430: 0x000d, 0x431: 0x000d, 0x432: 0x000d, 0x433: 0x000d, 0x434: 0x000d, 0x435: 0x000d, - 0x436: 0x000d, 0x437: 0x000d, 0x438: 0x000d, 0x439: 0x000d, 0x43a: 0x000d, 0x43b: 0x000d, - 0x43c: 0x000d, 0x43d: 0x000d, 0x43e: 0x000d, 0x43f: 0x000d, - // Block 0x11, offset 0x440 - 0x440: 0x000d, 0x441: 0x000d, 0x442: 0x000d, 0x443: 0x000d, 0x444: 0x000d, 0x445: 0x000d, - 0x446: 0x000d, 0x447: 0x000d, 0x448: 0x000d, 0x449: 0x000d, 0x44a: 0x000d, 0x44b: 0x000d, - 0x44c: 0x000d, 0x44d: 0x000d, 0x44e: 0x000d, 0x44f: 0x000d, 0x450: 0x000d, 0x451: 0x000d, - 0x452: 0x000d, 0x453: 0x000d, 0x454: 0x000d, 0x455: 0x000d, 0x456: 0x000c, 0x457: 0x000c, - 0x458: 0x000c, 0x459: 0x000c, 0x45a: 0x000c, 0x45b: 0x000c, 0x45c: 0x000c, 0x45d: 0x0005, - 0x45e: 0x000a, 0x45f: 0x000c, 0x460: 0x000c, 0x461: 0x000c, 0x462: 0x000c, 0x463: 0x000c, - 0x464: 0x000c, 0x465: 0x000d, 0x466: 0x000d, 0x467: 0x000c, 0x468: 0x000c, 0x469: 0x000a, - 0x46a: 0x000c, 0x46b: 0x000c, 0x46c: 0x000c, 0x46d: 0x000c, 0x46e: 0x000d, 0x46f: 0x000d, - 0x470: 0x0002, 0x471: 0x0002, 0x472: 0x0002, 0x473: 0x0002, 0x474: 0x0002, 0x475: 0x0002, - 0x476: 0x0002, 0x477: 0x0002, 0x478: 0x0002, 0x479: 0x0002, 0x47a: 0x000d, 0x47b: 0x000d, - 0x47c: 0x000d, 0x47d: 0x000d, 0x47e: 0x000d, 0x47f: 0x000d, - // Block 0x12, offset 0x480 - 0x480: 0x000d, 0x481: 0x000d, 0x482: 0x000d, 0x483: 0x000d, 0x484: 0x000d, 0x485: 0x000d, - 0x486: 0x000d, 0x487: 0x000d, 0x488: 0x000d, 0x489: 0x000d, 0x48a: 0x000d, 0x48b: 0x000d, - 0x48c: 0x000d, 0x48d: 0x000d, 0x48e: 0x000d, 0x48f: 0x000d, 0x490: 0x000d, 0x491: 0x000c, - 0x492: 0x000d, 0x493: 0x000d, 0x494: 0x000d, 0x495: 0x000d, 0x496: 0x000d, 0x497: 0x000d, - 0x498: 0x000d, 0x499: 0x000d, 0x49a: 0x000d, 0x49b: 0x000d, 0x49c: 0x000d, 0x49d: 0x000d, - 0x49e: 0x000d, 0x49f: 0x000d, 0x4a0: 0x000d, 0x4a1: 0x000d, 0x4a2: 0x000d, 0x4a3: 0x000d, - 0x4a4: 0x000d, 0x4a5: 0x000d, 0x4a6: 0x000d, 0x4a7: 0x000d, 0x4a8: 0x000d, 0x4a9: 0x000d, - 0x4aa: 0x000d, 0x4ab: 0x000d, 0x4ac: 0x000d, 0x4ad: 0x000d, 0x4ae: 0x000d, 0x4af: 0x000d, - 0x4b0: 0x000c, 0x4b1: 0x000c, 0x4b2: 0x000c, 0x4b3: 0x000c, 0x4b4: 0x000c, 0x4b5: 0x000c, - 0x4b6: 0x000c, 0x4b7: 0x000c, 0x4b8: 0x000c, 0x4b9: 0x000c, 0x4ba: 0x000c, 0x4bb: 0x000c, - 0x4bc: 0x000c, 0x4bd: 0x000c, 0x4be: 0x000c, 0x4bf: 0x000c, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x000c, 0x4c1: 0x000c, 0x4c2: 0x000c, 0x4c3: 0x000c, 0x4c4: 0x000c, 0x4c5: 0x000c, - 0x4c6: 0x000c, 0x4c7: 0x000c, 0x4c8: 0x000c, 0x4c9: 0x000c, 0x4ca: 0x000c, 0x4cb: 0x000d, - 0x4cc: 0x000d, 0x4cd: 0x000d, 0x4ce: 0x000d, 0x4cf: 0x000d, 0x4d0: 0x000d, 0x4d1: 0x000d, - 0x4d2: 0x000d, 0x4d3: 0x000d, 0x4d4: 0x000d, 0x4d5: 0x000d, 0x4d6: 0x000d, 0x4d7: 0x000d, - 0x4d8: 0x000d, 0x4d9: 0x000d, 0x4da: 0x000d, 0x4db: 0x000d, 0x4dc: 0x000d, 0x4dd: 0x000d, - 0x4de: 0x000d, 0x4df: 0x000d, 0x4e0: 0x000d, 0x4e1: 0x000d, 0x4e2: 0x000d, 0x4e3: 0x000d, - 0x4e4: 0x000d, 0x4e5: 0x000d, 0x4e6: 0x000d, 0x4e7: 0x000d, 0x4e8: 0x000d, 0x4e9: 0x000d, - 0x4ea: 0x000d, 0x4eb: 0x000d, 0x4ec: 0x000d, 0x4ed: 0x000d, 0x4ee: 0x000d, 0x4ef: 0x000d, - 0x4f0: 0x000d, 0x4f1: 0x000d, 0x4f2: 0x000d, 0x4f3: 0x000d, 0x4f4: 0x000d, 0x4f5: 0x000d, - 0x4f6: 0x000d, 0x4f7: 0x000d, 0x4f8: 0x000d, 0x4f9: 0x000d, 0x4fa: 0x000d, 0x4fb: 0x000d, - 0x4fc: 0x000d, 0x4fd: 0x000d, 0x4fe: 0x000d, 0x4ff: 0x000d, - // Block 0x14, offset 0x500 - 0x500: 0x000d, 0x501: 0x000d, 0x502: 0x000d, 0x503: 0x000d, 0x504: 0x000d, 0x505: 0x000d, - 0x506: 0x000d, 0x507: 0x000d, 0x508: 0x000d, 0x509: 0x000d, 0x50a: 0x000d, 0x50b: 0x000d, - 0x50c: 0x000d, 0x50d: 0x000d, 0x50e: 0x000d, 0x50f: 0x000d, 0x510: 0x000d, 0x511: 0x000d, - 0x512: 0x000d, 0x513: 0x000d, 0x514: 0x000d, 0x515: 0x000d, 0x516: 0x000d, 0x517: 0x000d, - 0x518: 0x000d, 0x519: 0x000d, 0x51a: 0x000d, 0x51b: 0x000d, 0x51c: 0x000d, 0x51d: 0x000d, - 0x51e: 0x000d, 0x51f: 0x000d, 0x520: 0x000d, 0x521: 0x000d, 0x522: 0x000d, 0x523: 0x000d, - 0x524: 0x000d, 0x525: 0x000d, 0x526: 0x000c, 0x527: 0x000c, 0x528: 0x000c, 0x529: 0x000c, - 0x52a: 0x000c, 0x52b: 0x000c, 0x52c: 0x000c, 0x52d: 0x000c, 0x52e: 0x000c, 0x52f: 0x000c, - 0x530: 0x000c, 0x531: 0x000d, 0x532: 0x000d, 0x533: 0x000d, 0x534: 0x000d, 0x535: 0x000d, - 0x536: 0x000d, 0x537: 0x000d, 0x538: 0x000d, 0x539: 0x000d, 0x53a: 0x000d, 0x53b: 0x000d, - 0x53c: 0x000d, 0x53d: 0x000d, 0x53e: 0x000d, 0x53f: 0x000d, - // Block 0x15, offset 0x540 - 0x540: 0x0001, 0x541: 0x0001, 0x542: 0x0001, 0x543: 0x0001, 0x544: 0x0001, 0x545: 0x0001, - 0x546: 0x0001, 0x547: 0x0001, 0x548: 0x0001, 0x549: 0x0001, 0x54a: 0x0001, 0x54b: 0x0001, - 0x54c: 0x0001, 0x54d: 0x0001, 0x54e: 0x0001, 0x54f: 0x0001, 0x550: 0x0001, 0x551: 0x0001, - 0x552: 0x0001, 0x553: 0x0001, 0x554: 0x0001, 0x555: 0x0001, 0x556: 0x0001, 0x557: 0x0001, - 0x558: 0x0001, 0x559: 0x0001, 0x55a: 0x0001, 0x55b: 0x0001, 0x55c: 0x0001, 0x55d: 0x0001, - 0x55e: 0x0001, 0x55f: 0x0001, 0x560: 0x0001, 0x561: 0x0001, 0x562: 0x0001, 0x563: 0x0001, - 0x564: 0x0001, 0x565: 0x0001, 0x566: 0x0001, 0x567: 0x0001, 0x568: 0x0001, 0x569: 0x0001, - 0x56a: 0x0001, 0x56b: 0x000c, 0x56c: 0x000c, 0x56d: 0x000c, 0x56e: 0x000c, 0x56f: 0x000c, - 0x570: 0x000c, 0x571: 0x000c, 0x572: 0x000c, 0x573: 0x000c, 0x574: 0x0001, 0x575: 0x0001, - 0x576: 0x000a, 0x577: 0x000a, 0x578: 0x000a, 0x579: 0x000a, 0x57a: 0x0001, 0x57b: 0x0001, - 0x57c: 0x0001, 0x57d: 0x0001, 0x57e: 0x0001, 0x57f: 0x0001, - // Block 0x16, offset 0x580 - 0x580: 0x0001, 0x581: 0x0001, 0x582: 0x0001, 0x583: 0x0001, 0x584: 0x0001, 0x585: 0x0001, - 0x586: 0x0001, 0x587: 0x0001, 0x588: 0x0001, 0x589: 0x0001, 0x58a: 0x0001, 0x58b: 0x0001, - 0x58c: 0x0001, 0x58d: 0x0001, 0x58e: 0x0001, 0x58f: 0x0001, 0x590: 0x0001, 0x591: 0x0001, - 0x592: 0x0001, 0x593: 0x0001, 0x594: 0x0001, 0x595: 0x0001, 0x596: 0x000c, 0x597: 0x000c, - 0x598: 0x000c, 0x599: 0x000c, 0x59a: 0x0001, 0x59b: 0x000c, 0x59c: 0x000c, 0x59d: 0x000c, - 0x59e: 0x000c, 0x59f: 0x000c, 0x5a0: 0x000c, 0x5a1: 0x000c, 0x5a2: 0x000c, 0x5a3: 0x000c, - 0x5a4: 0x0001, 0x5a5: 0x000c, 0x5a6: 0x000c, 0x5a7: 0x000c, 0x5a8: 0x0001, 0x5a9: 0x000c, - 0x5aa: 0x000c, 0x5ab: 0x000c, 0x5ac: 0x000c, 0x5ad: 0x000c, 0x5ae: 0x0001, 0x5af: 0x0001, - 0x5b0: 0x0001, 0x5b1: 0x0001, 0x5b2: 0x0001, 0x5b3: 0x0001, 0x5b4: 0x0001, 0x5b5: 0x0001, - 0x5b6: 0x0001, 0x5b7: 0x0001, 0x5b8: 0x0001, 0x5b9: 0x0001, 0x5ba: 0x0001, 0x5bb: 0x0001, - 0x5bc: 0x0001, 0x5bd: 0x0001, 0x5be: 0x0001, 0x5bf: 0x0001, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x0001, 0x5c1: 0x0001, 0x5c2: 0x0001, 0x5c3: 0x0001, 0x5c4: 0x0001, 0x5c5: 0x0001, - 0x5c6: 0x0001, 0x5c7: 0x0001, 0x5c8: 0x0001, 0x5c9: 0x0001, 0x5ca: 0x0001, 0x5cb: 0x0001, - 0x5cc: 0x0001, 0x5cd: 0x0001, 0x5ce: 0x0001, 0x5cf: 0x0001, 0x5d0: 0x0001, 0x5d1: 0x0001, - 0x5d2: 0x0001, 0x5d3: 0x0001, 0x5d4: 0x0001, 0x5d5: 0x0001, 0x5d6: 0x0001, 0x5d7: 0x0001, - 0x5d8: 0x0001, 0x5d9: 0x000c, 0x5da: 0x000c, 0x5db: 0x000c, 0x5dc: 0x0001, 0x5dd: 0x0001, - 0x5de: 0x0001, 0x5df: 0x0001, 0x5e0: 0x0001, 0x5e1: 0x0001, 0x5e2: 0x0001, 0x5e3: 0x0001, - 0x5e4: 0x0001, 0x5e5: 0x0001, 0x5e6: 0x0001, 0x5e7: 0x0001, 0x5e8: 0x0001, 0x5e9: 0x0001, - 0x5ea: 0x0001, 0x5eb: 0x0001, 0x5ec: 0x0001, 0x5ed: 0x0001, 0x5ee: 0x0001, 0x5ef: 0x0001, - 0x5f0: 0x0001, 0x5f1: 0x0001, 0x5f2: 0x0001, 0x5f3: 0x0001, 0x5f4: 0x0001, 0x5f5: 0x0001, - 0x5f6: 0x0001, 0x5f7: 0x0001, 0x5f8: 0x0001, 0x5f9: 0x0001, 0x5fa: 0x0001, 0x5fb: 0x0001, - 0x5fc: 0x0001, 0x5fd: 0x0001, 0x5fe: 0x0001, 0x5ff: 0x0001, - // Block 0x18, offset 0x600 - 0x600: 0x0001, 0x601: 0x0001, 0x602: 0x0001, 0x603: 0x0001, 0x604: 0x0001, 0x605: 0x0001, - 0x606: 0x0001, 0x607: 0x0001, 0x608: 0x0001, 0x609: 0x0001, 0x60a: 0x0001, 0x60b: 0x0001, - 0x60c: 0x0001, 0x60d: 0x0001, 0x60e: 0x0001, 0x60f: 0x0001, 0x610: 0x0001, 0x611: 0x0001, - 0x612: 0x0001, 0x613: 0x0001, 0x614: 0x0001, 0x615: 0x0001, 0x616: 0x0001, 0x617: 0x0001, - 0x618: 0x0001, 0x619: 0x0001, 0x61a: 0x0001, 0x61b: 0x0001, 0x61c: 0x0001, 0x61d: 0x0001, - 0x61e: 0x0001, 0x61f: 0x0001, 0x620: 0x000d, 0x621: 0x000d, 0x622: 0x000d, 0x623: 0x000d, - 0x624: 0x000d, 0x625: 0x000d, 0x626: 0x000d, 0x627: 0x000d, 0x628: 0x000d, 0x629: 0x000d, - 0x62a: 0x000d, 0x62b: 0x000d, 0x62c: 0x000d, 0x62d: 0x000d, 0x62e: 0x000d, 0x62f: 0x000d, - 0x630: 0x000d, 0x631: 0x000d, 0x632: 0x000d, 0x633: 0x000d, 0x634: 0x000d, 0x635: 0x000d, - 0x636: 0x000d, 0x637: 0x000d, 0x638: 0x000d, 0x639: 0x000d, 0x63a: 0x000d, 0x63b: 0x000d, - 0x63c: 0x000d, 0x63d: 0x000d, 0x63e: 0x000d, 0x63f: 0x000d, - // Block 0x19, offset 0x640 - 0x640: 0x000d, 0x641: 0x000d, 0x642: 0x000d, 0x643: 0x000d, 0x644: 0x000d, 0x645: 0x000d, - 0x646: 0x000d, 0x647: 0x000d, 0x648: 0x000d, 0x649: 0x000d, 0x64a: 0x000d, 0x64b: 0x000d, - 0x64c: 0x000d, 0x64d: 0x000d, 0x64e: 0x000d, 0x64f: 0x000d, 0x650: 0x000d, 0x651: 0x000d, - 0x652: 0x000d, 0x653: 0x000d, 0x654: 0x000c, 0x655: 0x000c, 0x656: 0x000c, 0x657: 0x000c, - 0x658: 0x000c, 0x659: 0x000c, 0x65a: 0x000c, 0x65b: 0x000c, 0x65c: 0x000c, 0x65d: 0x000c, - 0x65e: 0x000c, 0x65f: 0x000c, 0x660: 0x000c, 0x661: 0x000c, 0x662: 0x0005, 0x663: 0x000c, - 0x664: 0x000c, 0x665: 0x000c, 0x666: 0x000c, 0x667: 0x000c, 0x668: 0x000c, 0x669: 0x000c, - 0x66a: 0x000c, 0x66b: 0x000c, 0x66c: 0x000c, 0x66d: 0x000c, 0x66e: 0x000c, 0x66f: 0x000c, - 0x670: 0x000c, 0x671: 0x000c, 0x672: 0x000c, 0x673: 0x000c, 0x674: 0x000c, 0x675: 0x000c, - 0x676: 0x000c, 0x677: 0x000c, 0x678: 0x000c, 0x679: 0x000c, 0x67a: 0x000c, 0x67b: 0x000c, - 0x67c: 0x000c, 0x67d: 0x000c, 0x67e: 0x000c, 0x67f: 0x000c, - // Block 0x1a, offset 0x680 - 0x680: 0x000c, 0x681: 0x000c, 0x682: 0x000c, - 0x6ba: 0x000c, - 0x6bc: 0x000c, - // Block 0x1b, offset 0x6c0 - 0x6c1: 0x000c, 0x6c2: 0x000c, 0x6c3: 0x000c, 0x6c4: 0x000c, 0x6c5: 0x000c, - 0x6c6: 0x000c, 0x6c7: 0x000c, 0x6c8: 0x000c, - 0x6cd: 0x000c, 0x6d1: 0x000c, - 0x6d2: 0x000c, 0x6d3: 0x000c, 0x6d4: 0x000c, 0x6d5: 0x000c, 0x6d6: 0x000c, 0x6d7: 0x000c, - 0x6e2: 0x000c, 0x6e3: 0x000c, - // Block 0x1c, offset 0x700 - 0x701: 0x000c, - 0x73c: 0x000c, - // Block 0x1d, offset 0x740 - 0x741: 0x000c, 0x742: 0x000c, 0x743: 0x000c, 0x744: 0x000c, - 0x74d: 0x000c, - 0x762: 0x000c, 0x763: 0x000c, - 0x772: 0x0004, 0x773: 0x0004, - 0x77b: 0x0004, - // Block 0x1e, offset 0x780 - 0x781: 0x000c, 0x782: 0x000c, - 0x7bc: 0x000c, - // Block 0x1f, offset 0x7c0 - 0x7c1: 0x000c, 0x7c2: 0x000c, - 0x7c7: 0x000c, 0x7c8: 0x000c, 0x7cb: 0x000c, - 0x7cc: 0x000c, 0x7cd: 0x000c, 0x7d1: 0x000c, - 0x7f0: 0x000c, 0x7f1: 0x000c, 0x7f5: 0x000c, - // Block 0x20, offset 0x800 - 0x801: 0x000c, 0x802: 0x000c, 0x803: 0x000c, 0x804: 0x000c, 0x805: 0x000c, - 0x807: 0x000c, 0x808: 0x000c, - 0x80d: 0x000c, - 0x822: 0x000c, 0x823: 0x000c, - 0x831: 0x0004, - // Block 0x21, offset 0x840 - 0x841: 0x000c, - 0x87c: 0x000c, 0x87f: 0x000c, - // Block 0x22, offset 0x880 - 0x881: 0x000c, 0x882: 0x000c, 0x883: 0x000c, 0x884: 0x000c, - 0x88d: 0x000c, - 0x896: 0x000c, - 0x8a2: 0x000c, 0x8a3: 0x000c, - // Block 0x23, offset 0x8c0 - 0x8c2: 0x000c, - // Block 0x24, offset 0x900 - 0x900: 0x000c, - 0x90d: 0x000c, - 0x933: 0x000a, 0x934: 0x000a, 0x935: 0x000a, - 0x936: 0x000a, 0x937: 0x000a, 0x938: 0x000a, 0x939: 0x0004, 0x93a: 0x000a, - // Block 0x25, offset 0x940 - 0x940: 0x000c, - 0x97e: 0x000c, 0x97f: 0x000c, - // Block 0x26, offset 0x980 - 0x980: 0x000c, - 0x986: 0x000c, 0x987: 0x000c, 0x988: 0x000c, 0x98a: 0x000c, 0x98b: 0x000c, - 0x98c: 0x000c, 0x98d: 0x000c, - 0x995: 0x000c, 0x996: 0x000c, - 0x9a2: 0x000c, 0x9a3: 0x000c, - 0x9b8: 0x000a, 0x9b9: 0x000a, 0x9ba: 0x000a, 0x9bb: 0x000a, - 0x9bc: 0x000a, 0x9bd: 0x000a, 0x9be: 0x000a, - // Block 0x27, offset 0x9c0 - 0x9cc: 0x000c, 0x9cd: 0x000c, - 0x9e2: 0x000c, 0x9e3: 0x000c, - // Block 0x28, offset 0xa00 - 0xa01: 0x000c, - // Block 0x29, offset 0xa40 - 0xa41: 0x000c, 0xa42: 0x000c, 0xa43: 0x000c, 0xa44: 0x000c, - 0xa4d: 0x000c, - 0xa62: 0x000c, 0xa63: 0x000c, - // Block 0x2a, offset 0xa80 - 0xa8a: 0x000c, - 0xa92: 0x000c, 0xa93: 0x000c, 0xa94: 0x000c, 0xa96: 0x000c, - // Block 0x2b, offset 0xac0 - 0xaf1: 0x000c, 0xaf4: 0x000c, 0xaf5: 0x000c, - 0xaf6: 0x000c, 0xaf7: 0x000c, 0xaf8: 0x000c, 0xaf9: 0x000c, 0xafa: 0x000c, - 0xaff: 0x0004, - // Block 0x2c, offset 0xb00 - 0xb07: 0x000c, 0xb08: 0x000c, 0xb09: 0x000c, 0xb0a: 0x000c, 0xb0b: 0x000c, - 0xb0c: 0x000c, 0xb0d: 0x000c, 0xb0e: 0x000c, - // Block 0x2d, offset 0xb40 - 0xb71: 0x000c, 0xb74: 0x000c, 0xb75: 0x000c, - 0xb76: 0x000c, 0xb77: 0x000c, 0xb78: 0x000c, 0xb79: 0x000c, 0xb7b: 0x000c, - 0xb7c: 0x000c, - // Block 0x2e, offset 0xb80 - 0xb88: 0x000c, 0xb89: 0x000c, 0xb8a: 0x000c, 0xb8b: 0x000c, - 0xb8c: 0x000c, 0xb8d: 0x000c, - // Block 0x2f, offset 0xbc0 - 0xbd8: 0x000c, 0xbd9: 0x000c, - 0xbf5: 0x000c, - 0xbf7: 0x000c, 0xbf9: 0x000c, 0xbfa: 0x003a, 0xbfb: 0x002a, - 0xbfc: 0x003a, 0xbfd: 0x002a, - // Block 0x30, offset 0xc00 - 0xc31: 0x000c, 0xc32: 0x000c, 0xc33: 0x000c, 0xc34: 0x000c, 0xc35: 0x000c, - 0xc36: 0x000c, 0xc37: 0x000c, 0xc38: 0x000c, 0xc39: 0x000c, 0xc3a: 0x000c, 0xc3b: 0x000c, - 0xc3c: 0x000c, 0xc3d: 0x000c, 0xc3e: 0x000c, - // Block 0x31, offset 0xc40 - 0xc40: 0x000c, 0xc41: 0x000c, 0xc42: 0x000c, 0xc43: 0x000c, 0xc44: 0x000c, - 0xc46: 0x000c, 0xc47: 0x000c, - 0xc4d: 0x000c, 0xc4e: 0x000c, 0xc4f: 0x000c, 0xc50: 0x000c, 0xc51: 0x000c, - 0xc52: 0x000c, 0xc53: 0x000c, 0xc54: 0x000c, 0xc55: 0x000c, 0xc56: 0x000c, 0xc57: 0x000c, - 0xc59: 0x000c, 0xc5a: 0x000c, 0xc5b: 0x000c, 0xc5c: 0x000c, 0xc5d: 0x000c, - 0xc5e: 0x000c, 0xc5f: 0x000c, 0xc60: 0x000c, 0xc61: 0x000c, 0xc62: 0x000c, 0xc63: 0x000c, - 0xc64: 0x000c, 0xc65: 0x000c, 0xc66: 0x000c, 0xc67: 0x000c, 0xc68: 0x000c, 0xc69: 0x000c, - 0xc6a: 0x000c, 0xc6b: 0x000c, 0xc6c: 0x000c, 0xc6d: 0x000c, 0xc6e: 0x000c, 0xc6f: 0x000c, - 0xc70: 0x000c, 0xc71: 0x000c, 0xc72: 0x000c, 0xc73: 0x000c, 0xc74: 0x000c, 0xc75: 0x000c, - 0xc76: 0x000c, 0xc77: 0x000c, 0xc78: 0x000c, 0xc79: 0x000c, 0xc7a: 0x000c, 0xc7b: 0x000c, - 0xc7c: 0x000c, - // Block 0x32, offset 0xc80 - 0xc86: 0x000c, - // Block 0x33, offset 0xcc0 - 0xced: 0x000c, 0xcee: 0x000c, 0xcef: 0x000c, - 0xcf0: 0x000c, 0xcf2: 0x000c, 0xcf3: 0x000c, 0xcf4: 0x000c, 0xcf5: 0x000c, - 0xcf6: 0x000c, 0xcf7: 0x000c, 0xcf9: 0x000c, 0xcfa: 0x000c, - 0xcfd: 0x000c, 0xcfe: 0x000c, - // Block 0x34, offset 0xd00 - 0xd18: 0x000c, 0xd19: 0x000c, - 0xd1e: 0x000c, 0xd1f: 0x000c, 0xd20: 0x000c, - 0xd31: 0x000c, 0xd32: 0x000c, 0xd33: 0x000c, 0xd34: 0x000c, - // Block 0x35, offset 0xd40 - 0xd42: 0x000c, 0xd45: 0x000c, - 0xd46: 0x000c, - 0xd4d: 0x000c, - 0xd5d: 0x000c, - // Block 0x36, offset 0xd80 - 0xd9d: 0x000c, - 0xd9e: 0x000c, 0xd9f: 0x000c, - // Block 0x37, offset 0xdc0 - 0xdd0: 0x000a, 0xdd1: 0x000a, - 0xdd2: 0x000a, 0xdd3: 0x000a, 0xdd4: 0x000a, 0xdd5: 0x000a, 0xdd6: 0x000a, 0xdd7: 0x000a, - 0xdd8: 0x000a, 0xdd9: 0x000a, - // Block 0x38, offset 0xe00 - 0xe00: 0x000a, - // Block 0x39, offset 0xe40 - 0xe40: 0x0009, - 0xe5b: 0x007a, 0xe5c: 0x006a, - // Block 0x3a, offset 0xe80 - 0xe92: 0x000c, 0xe93: 0x000c, 0xe94: 0x000c, - 0xeb2: 0x000c, 0xeb3: 0x000c, 0xeb4: 0x000c, - // Block 0x3b, offset 0xec0 - 0xed2: 0x000c, 0xed3: 0x000c, - 0xef2: 0x000c, 0xef3: 0x000c, - // Block 0x3c, offset 0xf00 - 0xf34: 0x000c, 0xf35: 0x000c, - 0xf37: 0x000c, 0xf38: 0x000c, 0xf39: 0x000c, 0xf3a: 0x000c, 0xf3b: 0x000c, - 0xf3c: 0x000c, 0xf3d: 0x000c, - // Block 0x3d, offset 0xf40 - 0xf46: 0x000c, 0xf49: 0x000c, 0xf4a: 0x000c, 0xf4b: 0x000c, - 0xf4c: 0x000c, 0xf4d: 0x000c, 0xf4e: 0x000c, 0xf4f: 0x000c, 0xf50: 0x000c, 0xf51: 0x000c, - 0xf52: 0x000c, 0xf53: 0x000c, - 0xf5b: 0x0004, 0xf5d: 0x000c, - 0xf70: 0x000a, 0xf71: 0x000a, 0xf72: 0x000a, 0xf73: 0x000a, 0xf74: 0x000a, 0xf75: 0x000a, - 0xf76: 0x000a, 0xf77: 0x000a, 0xf78: 0x000a, 0xf79: 0x000a, - // Block 0x3e, offset 0xf80 - 0xf80: 0x000a, 0xf81: 0x000a, 0xf82: 0x000a, 0xf83: 0x000a, 0xf84: 0x000a, 0xf85: 0x000a, - 0xf86: 0x000a, 0xf87: 0x000a, 0xf88: 0x000a, 0xf89: 0x000a, 0xf8a: 0x000a, 0xf8b: 0x000c, - 0xf8c: 0x000c, 0xf8d: 0x000c, 0xf8e: 0x000b, - // Block 0x3f, offset 0xfc0 - 0xfc5: 0x000c, - 0xfc6: 0x000c, - 0xfe9: 0x000c, - // Block 0x40, offset 0x1000 - 0x1020: 0x000c, 0x1021: 0x000c, 0x1022: 0x000c, - 0x1027: 0x000c, 0x1028: 0x000c, - 0x1032: 0x000c, - 0x1039: 0x000c, 0x103a: 0x000c, 0x103b: 0x000c, - // Block 0x41, offset 0x1040 - 0x1040: 0x000a, 0x1044: 0x000a, 0x1045: 0x000a, - // Block 0x42, offset 0x1080 - 0x109e: 0x000a, 0x109f: 0x000a, 0x10a0: 0x000a, 0x10a1: 0x000a, 0x10a2: 0x000a, 0x10a3: 0x000a, - 0x10a4: 0x000a, 0x10a5: 0x000a, 0x10a6: 0x000a, 0x10a7: 0x000a, 0x10a8: 0x000a, 0x10a9: 0x000a, - 0x10aa: 0x000a, 0x10ab: 0x000a, 0x10ac: 0x000a, 0x10ad: 0x000a, 0x10ae: 0x000a, 0x10af: 0x000a, - 0x10b0: 0x000a, 0x10b1: 0x000a, 0x10b2: 0x000a, 0x10b3: 0x000a, 0x10b4: 0x000a, 0x10b5: 0x000a, - 0x10b6: 0x000a, 0x10b7: 0x000a, 0x10b8: 0x000a, 0x10b9: 0x000a, 0x10ba: 0x000a, 0x10bb: 0x000a, - 0x10bc: 0x000a, 0x10bd: 0x000a, 0x10be: 0x000a, 0x10bf: 0x000a, - // Block 0x43, offset 0x10c0 - 0x10d7: 0x000c, - 0x10d8: 0x000c, 0x10db: 0x000c, - // Block 0x44, offset 0x1100 - 0x1116: 0x000c, - 0x1118: 0x000c, 0x1119: 0x000c, 0x111a: 0x000c, 0x111b: 0x000c, 0x111c: 0x000c, 0x111d: 0x000c, - 0x111e: 0x000c, 0x1120: 0x000c, 0x1122: 0x000c, - 0x1125: 0x000c, 0x1126: 0x000c, 0x1127: 0x000c, 0x1128: 0x000c, 0x1129: 0x000c, - 0x112a: 0x000c, 0x112b: 0x000c, 0x112c: 0x000c, - 0x1133: 0x000c, 0x1134: 0x000c, 0x1135: 0x000c, - 0x1136: 0x000c, 0x1137: 0x000c, 0x1138: 0x000c, 0x1139: 0x000c, 0x113a: 0x000c, 0x113b: 0x000c, - 0x113c: 0x000c, 0x113f: 0x000c, - // Block 0x45, offset 0x1140 - 0x1170: 0x000c, 0x1171: 0x000c, 0x1172: 0x000c, 0x1173: 0x000c, 0x1174: 0x000c, 0x1175: 0x000c, - 0x1176: 0x000c, 0x1177: 0x000c, 0x1178: 0x000c, 0x1179: 0x000c, 0x117a: 0x000c, 0x117b: 0x000c, - 0x117c: 0x000c, 0x117d: 0x000c, 0x117e: 0x000c, - // Block 0x46, offset 0x1180 - 0x1180: 0x000c, 0x1181: 0x000c, 0x1182: 0x000c, 0x1183: 0x000c, - 0x11b4: 0x000c, - 0x11b6: 0x000c, 0x11b7: 0x000c, 0x11b8: 0x000c, 0x11b9: 0x000c, 0x11ba: 0x000c, - 0x11bc: 0x000c, - // Block 0x47, offset 0x11c0 - 0x11c2: 0x000c, - 0x11eb: 0x000c, 0x11ec: 0x000c, 0x11ed: 0x000c, 0x11ee: 0x000c, 0x11ef: 0x000c, - 0x11f0: 0x000c, 0x11f1: 0x000c, 0x11f2: 0x000c, 0x11f3: 0x000c, - // Block 0x48, offset 0x1200 - 0x1200: 0x000c, 0x1201: 0x000c, - 0x1222: 0x000c, 0x1223: 0x000c, - 0x1224: 0x000c, 0x1225: 0x000c, 0x1228: 0x000c, 0x1229: 0x000c, - 0x122b: 0x000c, 0x122c: 0x000c, 0x122d: 0x000c, - // Block 0x49, offset 0x1240 - 0x1266: 0x000c, 0x1268: 0x000c, 0x1269: 0x000c, - 0x126d: 0x000c, 0x126f: 0x000c, - 0x1270: 0x000c, 0x1271: 0x000c, - // Block 0x4a, offset 0x1280 - 0x12ac: 0x000c, 0x12ad: 0x000c, 0x12ae: 0x000c, 0x12af: 0x000c, - 0x12b0: 0x000c, 0x12b1: 0x000c, 0x12b2: 0x000c, 0x12b3: 0x000c, - 0x12b6: 0x000c, 0x12b7: 0x000c, - // Block 0x4b, offset 0x12c0 - 0x12d0: 0x000c, 0x12d1: 0x000c, - 0x12d2: 0x000c, 0x12d4: 0x000c, 0x12d5: 0x000c, 0x12d6: 0x000c, 0x12d7: 0x000c, - 0x12d8: 0x000c, 0x12d9: 0x000c, 0x12da: 0x000c, 0x12db: 0x000c, 0x12dc: 0x000c, 0x12dd: 0x000c, - 0x12de: 0x000c, 0x12df: 0x000c, 0x12e0: 0x000c, 0x12e2: 0x000c, 0x12e3: 0x000c, - 0x12e4: 0x000c, 0x12e5: 0x000c, 0x12e6: 0x000c, 0x12e7: 0x000c, 0x12e8: 0x000c, - 0x12ed: 0x000c, - 0x12f4: 0x000c, - 0x12f8: 0x000c, 0x12f9: 0x000c, - // Block 0x4c, offset 0x1300 - 0x1300: 0x000c, 0x1301: 0x000c, 0x1302: 0x000c, 0x1303: 0x000c, 0x1304: 0x000c, 0x1305: 0x000c, - 0x1306: 0x000c, 0x1307: 0x000c, 0x1308: 0x000c, 0x1309: 0x000c, 0x130a: 0x000c, 0x130b: 0x000c, - 0x130c: 0x000c, 0x130d: 0x000c, 0x130e: 0x000c, 0x130f: 0x000c, 0x1310: 0x000c, 0x1311: 0x000c, - 0x1312: 0x000c, 0x1313: 0x000c, 0x1314: 0x000c, 0x1315: 0x000c, 0x1316: 0x000c, 0x1317: 0x000c, - 0x1318: 0x000c, 0x1319: 0x000c, 0x131a: 0x000c, 0x131b: 0x000c, 0x131c: 0x000c, 0x131d: 0x000c, - 0x131e: 0x000c, 0x131f: 0x000c, 0x1320: 0x000c, 0x1321: 0x000c, 0x1322: 0x000c, 0x1323: 0x000c, - 0x1324: 0x000c, 0x1325: 0x000c, 0x1326: 0x000c, 0x1327: 0x000c, 0x1328: 0x000c, 0x1329: 0x000c, - 0x132a: 0x000c, 0x132b: 0x000c, 0x132c: 0x000c, 0x132d: 0x000c, 0x132e: 0x000c, 0x132f: 0x000c, - 0x1330: 0x000c, 0x1331: 0x000c, 0x1332: 0x000c, 0x1333: 0x000c, 0x1334: 0x000c, 0x1335: 0x000c, - 0x133b: 0x000c, - 0x133c: 0x000c, 0x133d: 0x000c, 0x133e: 0x000c, 0x133f: 0x000c, - // Block 0x4d, offset 0x1340 - 0x137d: 0x000a, 0x137f: 0x000a, - // Block 0x4e, offset 0x1380 - 0x1380: 0x000a, 0x1381: 0x000a, - 0x138d: 0x000a, 0x138e: 0x000a, 0x138f: 0x000a, - 0x139d: 0x000a, - 0x139e: 0x000a, 0x139f: 0x000a, - 0x13ad: 0x000a, 0x13ae: 0x000a, 0x13af: 0x000a, - 0x13bd: 0x000a, 0x13be: 0x000a, - // Block 0x4f, offset 0x13c0 - 0x13c0: 0x0009, 0x13c1: 0x0009, 0x13c2: 0x0009, 0x13c3: 0x0009, 0x13c4: 0x0009, 0x13c5: 0x0009, - 0x13c6: 0x0009, 0x13c7: 0x0009, 0x13c8: 0x0009, 0x13c9: 0x0009, 0x13ca: 0x0009, 0x13cb: 0x000b, - 0x13cc: 0x000b, 0x13cd: 0x000b, 0x13cf: 0x0001, 0x13d0: 0x000a, 0x13d1: 0x000a, - 0x13d2: 0x000a, 0x13d3: 0x000a, 0x13d4: 0x000a, 0x13d5: 0x000a, 0x13d6: 0x000a, 0x13d7: 0x000a, - 0x13d8: 0x000a, 0x13d9: 0x000a, 0x13da: 0x000a, 0x13db: 0x000a, 0x13dc: 0x000a, 0x13dd: 0x000a, - 0x13de: 0x000a, 0x13df: 0x000a, 0x13e0: 0x000a, 0x13e1: 0x000a, 0x13e2: 0x000a, 0x13e3: 0x000a, - 0x13e4: 0x000a, 0x13e5: 0x000a, 0x13e6: 0x000a, 0x13e7: 0x000a, 0x13e8: 0x0009, 0x13e9: 0x0007, - 0x13ea: 0x000e, 0x13eb: 0x000e, 0x13ec: 0x000e, 0x13ed: 0x000e, 0x13ee: 0x000e, 0x13ef: 0x0006, - 0x13f0: 0x0004, 0x13f1: 0x0004, 0x13f2: 0x0004, 0x13f3: 0x0004, 0x13f4: 0x0004, 0x13f5: 0x000a, - 0x13f6: 0x000a, 0x13f7: 0x000a, 0x13f8: 0x000a, 0x13f9: 0x000a, 0x13fa: 0x000a, 0x13fb: 0x000a, - 0x13fc: 0x000a, 0x13fd: 0x000a, 0x13fe: 0x000a, 0x13ff: 0x000a, - // Block 0x50, offset 0x1400 - 0x1400: 0x000a, 0x1401: 0x000a, 0x1402: 0x000a, 0x1403: 0x000a, 0x1404: 0x0006, 0x1405: 0x009a, - 0x1406: 0x008a, 0x1407: 0x000a, 0x1408: 0x000a, 0x1409: 0x000a, 0x140a: 0x000a, 0x140b: 0x000a, - 0x140c: 0x000a, 0x140d: 0x000a, 0x140e: 0x000a, 0x140f: 0x000a, 0x1410: 0x000a, 0x1411: 0x000a, - 0x1412: 0x000a, 0x1413: 0x000a, 0x1414: 0x000a, 0x1415: 0x000a, 0x1416: 0x000a, 0x1417: 0x000a, - 0x1418: 0x000a, 0x1419: 0x000a, 0x141a: 0x000a, 0x141b: 0x000a, 0x141c: 0x000a, 0x141d: 0x000a, - 0x141e: 0x000a, 0x141f: 0x0009, 0x1420: 0x000b, 0x1421: 0x000b, 0x1422: 0x000b, 0x1423: 0x000b, - 0x1424: 0x000b, 0x1425: 0x000b, 0x1426: 0x000e, 0x1427: 0x000e, 0x1428: 0x000e, 0x1429: 0x000e, - 0x142a: 0x000b, 0x142b: 0x000b, 0x142c: 0x000b, 0x142d: 0x000b, 0x142e: 0x000b, 0x142f: 0x000b, - 0x1430: 0x0002, 0x1434: 0x0002, 0x1435: 0x0002, - 0x1436: 0x0002, 0x1437: 0x0002, 0x1438: 0x0002, 0x1439: 0x0002, 0x143a: 0x0003, 0x143b: 0x0003, - 0x143c: 0x000a, 0x143d: 0x009a, 0x143e: 0x008a, - // Block 0x51, offset 0x1440 - 0x1440: 0x0002, 0x1441: 0x0002, 0x1442: 0x0002, 0x1443: 0x0002, 0x1444: 0x0002, 0x1445: 0x0002, - 0x1446: 0x0002, 0x1447: 0x0002, 0x1448: 0x0002, 0x1449: 0x0002, 0x144a: 0x0003, 0x144b: 0x0003, - 0x144c: 0x000a, 0x144d: 0x009a, 0x144e: 0x008a, - 0x1460: 0x0004, 0x1461: 0x0004, 0x1462: 0x0004, 0x1463: 0x0004, - 0x1464: 0x0004, 0x1465: 0x0004, 0x1466: 0x0004, 0x1467: 0x0004, 0x1468: 0x0004, 0x1469: 0x0004, - 0x146a: 0x0004, 0x146b: 0x0004, 0x146c: 0x0004, 0x146d: 0x0004, 0x146e: 0x0004, 0x146f: 0x0004, - 0x1470: 0x0004, 0x1471: 0x0004, 0x1472: 0x0004, 0x1473: 0x0004, 0x1474: 0x0004, 0x1475: 0x0004, - 0x1476: 0x0004, 0x1477: 0x0004, 0x1478: 0x0004, 0x1479: 0x0004, 0x147a: 0x0004, 0x147b: 0x0004, - 0x147c: 0x0004, 0x147d: 0x0004, 0x147e: 0x0004, 0x147f: 0x0004, - // Block 0x52, offset 0x1480 - 0x1480: 0x0004, 0x1481: 0x0004, 0x1482: 0x0004, 0x1483: 0x0004, 0x1484: 0x0004, 0x1485: 0x0004, - 0x1486: 0x0004, 0x1487: 0x0004, 0x1488: 0x0004, 0x1489: 0x0004, 0x148a: 0x0004, 0x148b: 0x0004, - 0x148c: 0x0004, 0x148d: 0x0004, 0x148e: 0x0004, 0x148f: 0x0004, 0x1490: 0x000c, 0x1491: 0x000c, - 0x1492: 0x000c, 0x1493: 0x000c, 0x1494: 0x000c, 0x1495: 0x000c, 0x1496: 0x000c, 0x1497: 0x000c, - 0x1498: 0x000c, 0x1499: 0x000c, 0x149a: 0x000c, 0x149b: 0x000c, 0x149c: 0x000c, 0x149d: 0x000c, - 0x149e: 0x000c, 0x149f: 0x000c, 0x14a0: 0x000c, 0x14a1: 0x000c, 0x14a2: 0x000c, 0x14a3: 0x000c, - 0x14a4: 0x000c, 0x14a5: 0x000c, 0x14a6: 0x000c, 0x14a7: 0x000c, 0x14a8: 0x000c, 0x14a9: 0x000c, - 0x14aa: 0x000c, 0x14ab: 0x000c, 0x14ac: 0x000c, 0x14ad: 0x000c, 0x14ae: 0x000c, 0x14af: 0x000c, - 0x14b0: 0x000c, - // Block 0x53, offset 0x14c0 - 0x14c0: 0x000a, 0x14c1: 0x000a, 0x14c3: 0x000a, 0x14c4: 0x000a, 0x14c5: 0x000a, - 0x14c6: 0x000a, 0x14c8: 0x000a, 0x14c9: 0x000a, - 0x14d4: 0x000a, 0x14d6: 0x000a, 0x14d7: 0x000a, - 0x14d8: 0x000a, - 0x14de: 0x000a, 0x14df: 0x000a, 0x14e0: 0x000a, 0x14e1: 0x000a, 0x14e2: 0x000a, 0x14e3: 0x000a, - 0x14e5: 0x000a, 0x14e7: 0x000a, 0x14e9: 0x000a, - 0x14ee: 0x0004, - 0x14fa: 0x000a, 0x14fb: 0x000a, - // Block 0x54, offset 0x1500 - 0x1500: 0x000a, 0x1501: 0x000a, 0x1502: 0x000a, 0x1503: 0x000a, 0x1504: 0x000a, - 0x150a: 0x000a, 0x150b: 0x000a, - 0x150c: 0x000a, 0x150d: 0x000a, 0x1510: 0x000a, 0x1511: 0x000a, - 0x1512: 0x000a, 0x1513: 0x000a, 0x1514: 0x000a, 0x1515: 0x000a, 0x1516: 0x000a, 0x1517: 0x000a, - 0x1518: 0x000a, 0x1519: 0x000a, 0x151a: 0x000a, 0x151b: 0x000a, 0x151c: 0x000a, 0x151d: 0x000a, - 0x151e: 0x000a, 0x151f: 0x000a, - // Block 0x55, offset 0x1540 - 0x1549: 0x000a, 0x154a: 0x000a, 0x154b: 0x000a, - 0x1550: 0x000a, 0x1551: 0x000a, - 0x1552: 0x000a, 0x1553: 0x000a, 0x1554: 0x000a, 0x1555: 0x000a, 0x1556: 0x000a, 0x1557: 0x000a, - 0x1558: 0x000a, 0x1559: 0x000a, 0x155a: 0x000a, 0x155b: 0x000a, 0x155c: 0x000a, 0x155d: 0x000a, - 0x155e: 0x000a, 0x155f: 0x000a, 0x1560: 0x000a, 0x1561: 0x000a, 0x1562: 0x000a, 0x1563: 0x000a, - 0x1564: 0x000a, 0x1565: 0x000a, 0x1566: 0x000a, 0x1567: 0x000a, 0x1568: 0x000a, 0x1569: 0x000a, - 0x156a: 0x000a, 0x156b: 0x000a, 0x156c: 0x000a, 0x156d: 0x000a, 0x156e: 0x000a, 0x156f: 0x000a, - 0x1570: 0x000a, 0x1571: 0x000a, 0x1572: 0x000a, 0x1573: 0x000a, 0x1574: 0x000a, 0x1575: 0x000a, - 0x1576: 0x000a, 0x1577: 0x000a, 0x1578: 0x000a, 0x1579: 0x000a, 0x157a: 0x000a, 0x157b: 0x000a, - 0x157c: 0x000a, 0x157d: 0x000a, 0x157e: 0x000a, 0x157f: 0x000a, - // Block 0x56, offset 0x1580 - 0x1580: 0x000a, 0x1581: 0x000a, 0x1582: 0x000a, 0x1583: 0x000a, 0x1584: 0x000a, 0x1585: 0x000a, - 0x1586: 0x000a, 0x1587: 0x000a, 0x1588: 0x000a, 0x1589: 0x000a, 0x158a: 0x000a, 0x158b: 0x000a, - 0x158c: 0x000a, 0x158d: 0x000a, 0x158e: 0x000a, 0x158f: 0x000a, 0x1590: 0x000a, 0x1591: 0x000a, - 0x1592: 0x000a, 0x1593: 0x000a, 0x1594: 0x000a, 0x1595: 0x000a, 0x1596: 0x000a, 0x1597: 0x000a, - 0x1598: 0x000a, 0x1599: 0x000a, 0x159a: 0x000a, 0x159b: 0x000a, 0x159c: 0x000a, 0x159d: 0x000a, - 0x159e: 0x000a, 0x159f: 0x000a, 0x15a0: 0x000a, 0x15a1: 0x000a, 0x15a2: 0x000a, 0x15a3: 0x000a, - 0x15a4: 0x000a, 0x15a5: 0x000a, 0x15a6: 0x000a, 0x15a7: 0x000a, 0x15a8: 0x000a, 0x15a9: 0x000a, - 0x15aa: 0x000a, 0x15ab: 0x000a, 0x15ac: 0x000a, 0x15ad: 0x000a, 0x15ae: 0x000a, 0x15af: 0x000a, - 0x15b0: 0x000a, 0x15b1: 0x000a, 0x15b2: 0x000a, 0x15b3: 0x000a, 0x15b4: 0x000a, 0x15b5: 0x000a, - 0x15b6: 0x000a, 0x15b7: 0x000a, 0x15b8: 0x000a, 0x15b9: 0x000a, 0x15ba: 0x000a, 0x15bb: 0x000a, - 0x15bc: 0x000a, 0x15bd: 0x000a, 0x15be: 0x000a, 0x15bf: 0x000a, - // Block 0x57, offset 0x15c0 - 0x15c0: 0x000a, 0x15c1: 0x000a, 0x15c2: 0x000a, 0x15c3: 0x000a, 0x15c4: 0x000a, 0x15c5: 0x000a, - 0x15c6: 0x000a, 0x15c7: 0x000a, 0x15c8: 0x000a, 0x15c9: 0x000a, 0x15ca: 0x000a, 0x15cb: 0x000a, - 0x15cc: 0x000a, 0x15cd: 0x000a, 0x15ce: 0x000a, 0x15cf: 0x000a, 0x15d0: 0x000a, 0x15d1: 0x000a, - 0x15d2: 0x0003, 0x15d3: 0x0004, 0x15d4: 0x000a, 0x15d5: 0x000a, 0x15d6: 0x000a, 0x15d7: 0x000a, - 0x15d8: 0x000a, 0x15d9: 0x000a, 0x15da: 0x000a, 0x15db: 0x000a, 0x15dc: 0x000a, 0x15dd: 0x000a, - 0x15de: 0x000a, 0x15df: 0x000a, 0x15e0: 0x000a, 0x15e1: 0x000a, 0x15e2: 0x000a, 0x15e3: 0x000a, - 0x15e4: 0x000a, 0x15e5: 0x000a, 0x15e6: 0x000a, 0x15e7: 0x000a, 0x15e8: 0x000a, 0x15e9: 0x000a, - 0x15ea: 0x000a, 0x15eb: 0x000a, 0x15ec: 0x000a, 0x15ed: 0x000a, 0x15ee: 0x000a, 0x15ef: 0x000a, - 0x15f0: 0x000a, 0x15f1: 0x000a, 0x15f2: 0x000a, 0x15f3: 0x000a, 0x15f4: 0x000a, 0x15f5: 0x000a, - 0x15f6: 0x000a, 0x15f7: 0x000a, 0x15f8: 0x000a, 0x15f9: 0x000a, 0x15fa: 0x000a, 0x15fb: 0x000a, - 0x15fc: 0x000a, 0x15fd: 0x000a, 0x15fe: 0x000a, 0x15ff: 0x000a, - // Block 0x58, offset 0x1600 - 0x1600: 0x000a, 0x1601: 0x000a, 0x1602: 0x000a, 0x1603: 0x000a, 0x1604: 0x000a, 0x1605: 0x000a, - 0x1606: 0x000a, 0x1607: 0x000a, 0x1608: 0x003a, 0x1609: 0x002a, 0x160a: 0x003a, 0x160b: 0x002a, - 0x160c: 0x000a, 0x160d: 0x000a, 0x160e: 0x000a, 0x160f: 0x000a, 0x1610: 0x000a, 0x1611: 0x000a, - 0x1612: 0x000a, 0x1613: 0x000a, 0x1614: 0x000a, 0x1615: 0x000a, 0x1616: 0x000a, 0x1617: 0x000a, - 0x1618: 0x000a, 0x1619: 0x000a, 0x161a: 0x000a, 0x161b: 0x000a, 0x161c: 0x000a, 0x161d: 0x000a, - 0x161e: 0x000a, 0x161f: 0x000a, 0x1620: 0x000a, 0x1621: 0x000a, 0x1622: 0x000a, 0x1623: 0x000a, - 0x1624: 0x000a, 0x1625: 0x000a, 0x1626: 0x000a, 0x1627: 0x000a, 0x1628: 0x000a, 0x1629: 0x009a, - 0x162a: 0x008a, 0x162b: 0x000a, 0x162c: 0x000a, 0x162d: 0x000a, 0x162e: 0x000a, 0x162f: 0x000a, - 0x1630: 0x000a, 0x1631: 0x000a, 0x1632: 0x000a, 0x1633: 0x000a, 0x1634: 0x000a, 0x1635: 0x000a, - // Block 0x59, offset 0x1640 - 0x167b: 0x000a, - 0x167c: 0x000a, 0x167d: 0x000a, 0x167e: 0x000a, 0x167f: 0x000a, - // Block 0x5a, offset 0x1680 - 0x1680: 0x000a, 0x1681: 0x000a, 0x1682: 0x000a, 0x1683: 0x000a, 0x1684: 0x000a, 0x1685: 0x000a, - 0x1686: 0x000a, 0x1687: 0x000a, 0x1688: 0x000a, 0x1689: 0x000a, 0x168a: 0x000a, 0x168b: 0x000a, - 0x168c: 0x000a, 0x168d: 0x000a, 0x168e: 0x000a, 0x168f: 0x000a, 0x1690: 0x000a, 0x1691: 0x000a, - 0x1692: 0x000a, 0x1693: 0x000a, 0x1694: 0x000a, 0x1696: 0x000a, 0x1697: 0x000a, - 0x1698: 0x000a, 0x1699: 0x000a, 0x169a: 0x000a, 0x169b: 0x000a, 0x169c: 0x000a, 0x169d: 0x000a, - 0x169e: 0x000a, 0x169f: 0x000a, 0x16a0: 0x000a, 0x16a1: 0x000a, 0x16a2: 0x000a, 0x16a3: 0x000a, - 0x16a4: 0x000a, 0x16a5: 0x000a, 0x16a6: 0x000a, 0x16a7: 0x000a, 0x16a8: 0x000a, 0x16a9: 0x000a, - 0x16aa: 0x000a, 0x16ab: 0x000a, 0x16ac: 0x000a, 0x16ad: 0x000a, 0x16ae: 0x000a, 0x16af: 0x000a, - 0x16b0: 0x000a, 0x16b1: 0x000a, 0x16b2: 0x000a, 0x16b3: 0x000a, 0x16b4: 0x000a, 0x16b5: 0x000a, - 0x16b6: 0x000a, 0x16b7: 0x000a, 0x16b8: 0x000a, 0x16b9: 0x000a, 0x16ba: 0x000a, 0x16bb: 0x000a, - 0x16bc: 0x000a, 0x16bd: 0x000a, 0x16be: 0x000a, 0x16bf: 0x000a, - // Block 0x5b, offset 0x16c0 - 0x16c0: 0x000a, 0x16c1: 0x000a, 0x16c2: 0x000a, 0x16c3: 0x000a, 0x16c4: 0x000a, 0x16c5: 0x000a, - 0x16c6: 0x000a, 0x16c7: 0x000a, 0x16c8: 0x000a, 0x16c9: 0x000a, 0x16ca: 0x000a, 0x16cb: 0x000a, - 0x16cc: 0x000a, 0x16cd: 0x000a, 0x16ce: 0x000a, 0x16cf: 0x000a, 0x16d0: 0x000a, 0x16d1: 0x000a, - 0x16d2: 0x000a, 0x16d3: 0x000a, 0x16d4: 0x000a, 0x16d5: 0x000a, 0x16d6: 0x000a, 0x16d7: 0x000a, - 0x16d8: 0x000a, 0x16d9: 0x000a, 0x16da: 0x000a, 0x16db: 0x000a, 0x16dc: 0x000a, 0x16dd: 0x000a, - 0x16de: 0x000a, 0x16df: 0x000a, 0x16e0: 0x000a, 0x16e1: 0x000a, 0x16e2: 0x000a, 0x16e3: 0x000a, - 0x16e4: 0x000a, 0x16e5: 0x000a, 0x16e6: 0x000a, 0x16e7: 0x000a, 0x16e8: 0x000a, 0x16e9: 0x000a, - 0x16ea: 0x000a, 0x16eb: 0x000a, 0x16ec: 0x000a, 0x16ed: 0x000a, 0x16ee: 0x000a, 0x16ef: 0x000a, - 0x16f0: 0x000a, 0x16f1: 0x000a, 0x16f2: 0x000a, 0x16f3: 0x000a, 0x16f4: 0x000a, 0x16f5: 0x000a, - 0x16f6: 0x000a, 0x16f7: 0x000a, 0x16f8: 0x000a, 0x16f9: 0x000a, 0x16fa: 0x000a, 0x16fb: 0x000a, - 0x16fc: 0x000a, 0x16fd: 0x000a, 0x16fe: 0x000a, - // Block 0x5c, offset 0x1700 - 0x1700: 0x000a, 0x1701: 0x000a, 0x1702: 0x000a, 0x1703: 0x000a, 0x1704: 0x000a, 0x1705: 0x000a, - 0x1706: 0x000a, 0x1707: 0x000a, 0x1708: 0x000a, 0x1709: 0x000a, 0x170a: 0x000a, 0x170b: 0x000a, - 0x170c: 0x000a, 0x170d: 0x000a, 0x170e: 0x000a, 0x170f: 0x000a, 0x1710: 0x000a, 0x1711: 0x000a, - 0x1712: 0x000a, 0x1713: 0x000a, 0x1714: 0x000a, 0x1715: 0x000a, 0x1716: 0x000a, 0x1717: 0x000a, - 0x1718: 0x000a, 0x1719: 0x000a, 0x171a: 0x000a, 0x171b: 0x000a, 0x171c: 0x000a, 0x171d: 0x000a, - 0x171e: 0x000a, 0x171f: 0x000a, 0x1720: 0x000a, 0x1721: 0x000a, 0x1722: 0x000a, 0x1723: 0x000a, - 0x1724: 0x000a, 0x1725: 0x000a, 0x1726: 0x000a, - // Block 0x5d, offset 0x1740 - 0x1740: 0x000a, 0x1741: 0x000a, 0x1742: 0x000a, 0x1743: 0x000a, 0x1744: 0x000a, 0x1745: 0x000a, - 0x1746: 0x000a, 0x1747: 0x000a, 0x1748: 0x000a, 0x1749: 0x000a, 0x174a: 0x000a, - 0x1760: 0x000a, 0x1761: 0x000a, 0x1762: 0x000a, 0x1763: 0x000a, - 0x1764: 0x000a, 0x1765: 0x000a, 0x1766: 0x000a, 0x1767: 0x000a, 0x1768: 0x000a, 0x1769: 0x000a, - 0x176a: 0x000a, 0x176b: 0x000a, 0x176c: 0x000a, 0x176d: 0x000a, 0x176e: 0x000a, 0x176f: 0x000a, - 0x1770: 0x000a, 0x1771: 0x000a, 0x1772: 0x000a, 0x1773: 0x000a, 0x1774: 0x000a, 0x1775: 0x000a, - 0x1776: 0x000a, 0x1777: 0x000a, 0x1778: 0x000a, 0x1779: 0x000a, 0x177a: 0x000a, 0x177b: 0x000a, - 0x177c: 0x000a, 0x177d: 0x000a, 0x177e: 0x000a, 0x177f: 0x000a, - // Block 0x5e, offset 0x1780 - 0x1780: 0x000a, 0x1781: 0x000a, 0x1782: 0x000a, 0x1783: 0x000a, 0x1784: 0x000a, 0x1785: 0x000a, - 0x1786: 0x000a, 0x1787: 0x000a, 0x1788: 0x0002, 0x1789: 0x0002, 0x178a: 0x0002, 0x178b: 0x0002, - 0x178c: 0x0002, 0x178d: 0x0002, 0x178e: 0x0002, 0x178f: 0x0002, 0x1790: 0x0002, 0x1791: 0x0002, - 0x1792: 0x0002, 0x1793: 0x0002, 0x1794: 0x0002, 0x1795: 0x0002, 0x1796: 0x0002, 0x1797: 0x0002, - 0x1798: 0x0002, 0x1799: 0x0002, 0x179a: 0x0002, 0x179b: 0x0002, - // Block 0x5f, offset 0x17c0 - 0x17ea: 0x000a, 0x17eb: 0x000a, 0x17ec: 0x000a, 0x17ed: 0x000a, 0x17ee: 0x000a, 0x17ef: 0x000a, - 0x17f0: 0x000a, 0x17f1: 0x000a, 0x17f2: 0x000a, 0x17f3: 0x000a, 0x17f4: 0x000a, 0x17f5: 0x000a, - 0x17f6: 0x000a, 0x17f7: 0x000a, 0x17f8: 0x000a, 0x17f9: 0x000a, 0x17fa: 0x000a, 0x17fb: 0x000a, - 0x17fc: 0x000a, 0x17fd: 0x000a, 0x17fe: 0x000a, 0x17ff: 0x000a, - // Block 0x60, offset 0x1800 - 0x1800: 0x000a, 0x1801: 0x000a, 0x1802: 0x000a, 0x1803: 0x000a, 0x1804: 0x000a, 0x1805: 0x000a, - 0x1806: 0x000a, 0x1807: 0x000a, 0x1808: 0x000a, 0x1809: 0x000a, 0x180a: 0x000a, 0x180b: 0x000a, - 0x180c: 0x000a, 0x180d: 0x000a, 0x180e: 0x000a, 0x180f: 0x000a, 0x1810: 0x000a, 0x1811: 0x000a, - 0x1812: 0x000a, 0x1813: 0x000a, 0x1814: 0x000a, 0x1815: 0x000a, 0x1816: 0x000a, 0x1817: 0x000a, - 0x1818: 0x000a, 0x1819: 0x000a, 0x181a: 0x000a, 0x181b: 0x000a, 0x181c: 0x000a, 0x181d: 0x000a, - 0x181e: 0x000a, 0x181f: 0x000a, 0x1820: 0x000a, 0x1821: 0x000a, 0x1822: 0x000a, 0x1823: 0x000a, - 0x1824: 0x000a, 0x1825: 0x000a, 0x1826: 0x000a, 0x1827: 0x000a, 0x1828: 0x000a, 0x1829: 0x000a, - 0x182a: 0x000a, 0x182b: 0x000a, 0x182d: 0x000a, 0x182e: 0x000a, 0x182f: 0x000a, - 0x1830: 0x000a, 0x1831: 0x000a, 0x1832: 0x000a, 0x1833: 0x000a, 0x1834: 0x000a, 0x1835: 0x000a, - 0x1836: 0x000a, 0x1837: 0x000a, 0x1838: 0x000a, 0x1839: 0x000a, 0x183a: 0x000a, 0x183b: 0x000a, - 0x183c: 0x000a, 0x183d: 0x000a, 0x183e: 0x000a, 0x183f: 0x000a, - // Block 0x61, offset 0x1840 - 0x1840: 0x000a, 0x1841: 0x000a, 0x1842: 0x000a, 0x1843: 0x000a, 0x1844: 0x000a, 0x1845: 0x000a, - 0x1846: 0x000a, 0x1847: 0x000a, 0x1848: 0x000a, 0x1849: 0x000a, 0x184a: 0x000a, 0x184b: 0x000a, - 0x184c: 0x000a, 0x184d: 0x000a, 0x184e: 0x000a, 0x184f: 0x000a, 0x1850: 0x000a, 0x1851: 0x000a, - 0x1852: 0x000a, 0x1853: 0x000a, 0x1854: 0x000a, 0x1855: 0x000a, 0x1856: 0x000a, 0x1857: 0x000a, - 0x1858: 0x000a, 0x1859: 0x000a, 0x185a: 0x000a, 0x185b: 0x000a, 0x185c: 0x000a, 0x185d: 0x000a, - 0x185e: 0x000a, 0x185f: 0x000a, 0x1860: 0x000a, 0x1861: 0x000a, 0x1862: 0x000a, 0x1863: 0x000a, - 0x1864: 0x000a, 0x1865: 0x000a, 0x1866: 0x000a, 0x1867: 0x000a, 0x1868: 0x003a, 0x1869: 0x002a, - 0x186a: 0x003a, 0x186b: 0x002a, 0x186c: 0x003a, 0x186d: 0x002a, 0x186e: 0x003a, 0x186f: 0x002a, - 0x1870: 0x003a, 0x1871: 0x002a, 0x1872: 0x003a, 0x1873: 0x002a, 0x1874: 0x003a, 0x1875: 0x002a, - 0x1876: 0x000a, 0x1877: 0x000a, 0x1878: 0x000a, 0x1879: 0x000a, 0x187a: 0x000a, 0x187b: 0x000a, - 0x187c: 0x000a, 0x187d: 0x000a, 0x187e: 0x000a, 0x187f: 0x000a, - // Block 0x62, offset 0x1880 - 0x1880: 0x000a, 0x1881: 0x000a, 0x1882: 0x000a, 0x1883: 0x000a, 0x1884: 0x000a, 0x1885: 0x009a, - 0x1886: 0x008a, 0x1887: 0x000a, 0x1888: 0x000a, 0x1889: 0x000a, 0x188a: 0x000a, 0x188b: 0x000a, - 0x188c: 0x000a, 0x188d: 0x000a, 0x188e: 0x000a, 0x188f: 0x000a, 0x1890: 0x000a, 0x1891: 0x000a, - 0x1892: 0x000a, 0x1893: 0x000a, 0x1894: 0x000a, 0x1895: 0x000a, 0x1896: 0x000a, 0x1897: 0x000a, - 0x1898: 0x000a, 0x1899: 0x000a, 0x189a: 0x000a, 0x189b: 0x000a, 0x189c: 0x000a, 0x189d: 0x000a, - 0x189e: 0x000a, 0x189f: 0x000a, 0x18a0: 0x000a, 0x18a1: 0x000a, 0x18a2: 0x000a, 0x18a3: 0x000a, - 0x18a4: 0x000a, 0x18a5: 0x000a, 0x18a6: 0x003a, 0x18a7: 0x002a, 0x18a8: 0x003a, 0x18a9: 0x002a, - 0x18aa: 0x003a, 0x18ab: 0x002a, 0x18ac: 0x003a, 0x18ad: 0x002a, 0x18ae: 0x003a, 0x18af: 0x002a, - 0x18b0: 0x000a, 0x18b1: 0x000a, 0x18b2: 0x000a, 0x18b3: 0x000a, 0x18b4: 0x000a, 0x18b5: 0x000a, - 0x18b6: 0x000a, 0x18b7: 0x000a, 0x18b8: 0x000a, 0x18b9: 0x000a, 0x18ba: 0x000a, 0x18bb: 0x000a, - 0x18bc: 0x000a, 0x18bd: 0x000a, 0x18be: 0x000a, 0x18bf: 0x000a, - // Block 0x63, offset 0x18c0 - 0x18c0: 0x000a, 0x18c1: 0x000a, 0x18c2: 0x000a, 0x18c3: 0x007a, 0x18c4: 0x006a, 0x18c5: 0x009a, - 0x18c6: 0x008a, 0x18c7: 0x00ba, 0x18c8: 0x00aa, 0x18c9: 0x009a, 0x18ca: 0x008a, 0x18cb: 0x007a, - 0x18cc: 0x006a, 0x18cd: 0x00da, 0x18ce: 0x002a, 0x18cf: 0x003a, 0x18d0: 0x00ca, 0x18d1: 0x009a, - 0x18d2: 0x008a, 0x18d3: 0x007a, 0x18d4: 0x006a, 0x18d5: 0x009a, 0x18d6: 0x008a, 0x18d7: 0x00ba, - 0x18d8: 0x00aa, 0x18d9: 0x000a, 0x18da: 0x000a, 0x18db: 0x000a, 0x18dc: 0x000a, 0x18dd: 0x000a, - 0x18de: 0x000a, 0x18df: 0x000a, 0x18e0: 0x000a, 0x18e1: 0x000a, 0x18e2: 0x000a, 0x18e3: 0x000a, - 0x18e4: 0x000a, 0x18e5: 0x000a, 0x18e6: 0x000a, 0x18e7: 0x000a, 0x18e8: 0x000a, 0x18e9: 0x000a, - 0x18ea: 0x000a, 0x18eb: 0x000a, 0x18ec: 0x000a, 0x18ed: 0x000a, 0x18ee: 0x000a, 0x18ef: 0x000a, - 0x18f0: 0x000a, 0x18f1: 0x000a, 0x18f2: 0x000a, 0x18f3: 0x000a, 0x18f4: 0x000a, 0x18f5: 0x000a, - 0x18f6: 0x000a, 0x18f7: 0x000a, 0x18f8: 0x000a, 0x18f9: 0x000a, 0x18fa: 0x000a, 0x18fb: 0x000a, - 0x18fc: 0x000a, 0x18fd: 0x000a, 0x18fe: 0x000a, 0x18ff: 0x000a, - // Block 0x64, offset 0x1900 - 0x1900: 0x000a, 0x1901: 0x000a, 0x1902: 0x000a, 0x1903: 0x000a, 0x1904: 0x000a, 0x1905: 0x000a, - 0x1906: 0x000a, 0x1907: 0x000a, 0x1908: 0x000a, 0x1909: 0x000a, 0x190a: 0x000a, 0x190b: 0x000a, - 0x190c: 0x000a, 0x190d: 0x000a, 0x190e: 0x000a, 0x190f: 0x000a, 0x1910: 0x000a, 0x1911: 0x000a, - 0x1912: 0x000a, 0x1913: 0x000a, 0x1914: 0x000a, 0x1915: 0x000a, 0x1916: 0x000a, 0x1917: 0x000a, - 0x1918: 0x003a, 0x1919: 0x002a, 0x191a: 0x003a, 0x191b: 0x002a, 0x191c: 0x000a, 0x191d: 0x000a, - 0x191e: 0x000a, 0x191f: 0x000a, 0x1920: 0x000a, 0x1921: 0x000a, 0x1922: 0x000a, 0x1923: 0x000a, - 0x1924: 0x000a, 0x1925: 0x000a, 0x1926: 0x000a, 0x1927: 0x000a, 0x1928: 0x000a, 0x1929: 0x000a, - 0x192a: 0x000a, 0x192b: 0x000a, 0x192c: 0x000a, 0x192d: 0x000a, 0x192e: 0x000a, 0x192f: 0x000a, - 0x1930: 0x000a, 0x1931: 0x000a, 0x1932: 0x000a, 0x1933: 0x000a, 0x1934: 0x000a, 0x1935: 0x000a, - 0x1936: 0x000a, 0x1937: 0x000a, 0x1938: 0x000a, 0x1939: 0x000a, 0x193a: 0x000a, 0x193b: 0x000a, - 0x193c: 0x003a, 0x193d: 0x002a, 0x193e: 0x000a, 0x193f: 0x000a, - // Block 0x65, offset 0x1940 - 0x1940: 0x000a, 0x1941: 0x000a, 0x1942: 0x000a, 0x1943: 0x000a, 0x1944: 0x000a, 0x1945: 0x000a, - 0x1946: 0x000a, 0x1947: 0x000a, 0x1948: 0x000a, 0x1949: 0x000a, 0x194a: 0x000a, 0x194b: 0x000a, - 0x194c: 0x000a, 0x194d: 0x000a, 0x194e: 0x000a, 0x194f: 0x000a, 0x1950: 0x000a, 0x1951: 0x000a, - 0x1952: 0x000a, 0x1953: 0x000a, 0x1954: 0x000a, 0x1955: 0x000a, 0x1956: 0x000a, 0x1957: 0x000a, - 0x1958: 0x000a, 0x1959: 0x000a, 0x195a: 0x000a, 0x195b: 0x000a, 0x195c: 0x000a, 0x195d: 0x000a, - 0x195e: 0x000a, 0x195f: 0x000a, 0x1960: 0x000a, 0x1961: 0x000a, 0x1962: 0x000a, 0x1963: 0x000a, - 0x1964: 0x000a, 0x1965: 0x000a, 0x1966: 0x000a, 0x1967: 0x000a, 0x1968: 0x000a, 0x1969: 0x000a, - 0x196a: 0x000a, 0x196b: 0x000a, 0x196c: 0x000a, 0x196d: 0x000a, 0x196e: 0x000a, 0x196f: 0x000a, - 0x1970: 0x000a, 0x1971: 0x000a, 0x1972: 0x000a, 0x1973: 0x000a, - 0x1976: 0x000a, 0x1977: 0x000a, 0x1978: 0x000a, 0x1979: 0x000a, 0x197a: 0x000a, 0x197b: 0x000a, - 0x197c: 0x000a, 0x197d: 0x000a, 0x197e: 0x000a, 0x197f: 0x000a, - // Block 0x66, offset 0x1980 - 0x1980: 0x000a, 0x1981: 0x000a, 0x1982: 0x000a, 0x1983: 0x000a, 0x1984: 0x000a, 0x1985: 0x000a, - 0x1986: 0x000a, 0x1987: 0x000a, 0x1988: 0x000a, 0x1989: 0x000a, 0x198a: 0x000a, 0x198b: 0x000a, - 0x198c: 0x000a, 0x198d: 0x000a, 0x198e: 0x000a, 0x198f: 0x000a, 0x1990: 0x000a, 0x1991: 0x000a, - 0x1992: 0x000a, 0x1993: 0x000a, 0x1994: 0x000a, 0x1995: 0x000a, - 0x1998: 0x000a, 0x1999: 0x000a, 0x199a: 0x000a, 0x199b: 0x000a, 0x199c: 0x000a, 0x199d: 0x000a, - 0x199e: 0x000a, 0x199f: 0x000a, 0x19a0: 0x000a, 0x19a1: 0x000a, 0x19a2: 0x000a, 0x19a3: 0x000a, - 0x19a4: 0x000a, 0x19a5: 0x000a, 0x19a6: 0x000a, 0x19a7: 0x000a, 0x19a8: 0x000a, 0x19a9: 0x000a, - 0x19aa: 0x000a, 0x19ab: 0x000a, 0x19ac: 0x000a, 0x19ad: 0x000a, 0x19ae: 0x000a, 0x19af: 0x000a, - 0x19b0: 0x000a, 0x19b1: 0x000a, 0x19b2: 0x000a, 0x19b3: 0x000a, 0x19b4: 0x000a, 0x19b5: 0x000a, - 0x19b6: 0x000a, 0x19b7: 0x000a, 0x19b8: 0x000a, 0x19b9: 0x000a, - 0x19bd: 0x000a, 0x19be: 0x000a, 0x19bf: 0x000a, - // Block 0x67, offset 0x19c0 - 0x19c0: 0x000a, 0x19c1: 0x000a, 0x19c2: 0x000a, 0x19c3: 0x000a, 0x19c4: 0x000a, 0x19c5: 0x000a, - 0x19c6: 0x000a, 0x19c7: 0x000a, 0x19c8: 0x000a, 0x19ca: 0x000a, 0x19cb: 0x000a, - 0x19cc: 0x000a, 0x19cd: 0x000a, 0x19ce: 0x000a, 0x19cf: 0x000a, 0x19d0: 0x000a, 0x19d1: 0x000a, - 0x19ec: 0x000a, 0x19ed: 0x000a, 0x19ee: 0x000a, 0x19ef: 0x000a, - // Block 0x68, offset 0x1a00 - 0x1a25: 0x000a, 0x1a26: 0x000a, 0x1a27: 0x000a, 0x1a28: 0x000a, 0x1a29: 0x000a, - 0x1a2a: 0x000a, 0x1a2f: 0x000c, - 0x1a30: 0x000c, 0x1a31: 0x000c, - 0x1a39: 0x000a, 0x1a3a: 0x000a, 0x1a3b: 0x000a, - 0x1a3c: 0x000a, 0x1a3d: 0x000a, 0x1a3e: 0x000a, 0x1a3f: 0x000a, - // Block 0x69, offset 0x1a40 - 0x1a7f: 0x000c, - // Block 0x6a, offset 0x1a80 - 0x1aa0: 0x000c, 0x1aa1: 0x000c, 0x1aa2: 0x000c, 0x1aa3: 0x000c, - 0x1aa4: 0x000c, 0x1aa5: 0x000c, 0x1aa6: 0x000c, 0x1aa7: 0x000c, 0x1aa8: 0x000c, 0x1aa9: 0x000c, - 0x1aaa: 0x000c, 0x1aab: 0x000c, 0x1aac: 0x000c, 0x1aad: 0x000c, 0x1aae: 0x000c, 0x1aaf: 0x000c, - 0x1ab0: 0x000c, 0x1ab1: 0x000c, 0x1ab2: 0x000c, 0x1ab3: 0x000c, 0x1ab4: 0x000c, 0x1ab5: 0x000c, - 0x1ab6: 0x000c, 0x1ab7: 0x000c, 0x1ab8: 0x000c, 0x1ab9: 0x000c, 0x1aba: 0x000c, 0x1abb: 0x000c, - 0x1abc: 0x000c, 0x1abd: 0x000c, 0x1abe: 0x000c, 0x1abf: 0x000c, - // Block 0x6b, offset 0x1ac0 - 0x1ac0: 0x000a, 0x1ac1: 0x000a, 0x1ac2: 0x000a, 0x1ac3: 0x000a, 0x1ac4: 0x000a, 0x1ac5: 0x000a, - 0x1ac6: 0x000a, 0x1ac7: 0x000a, 0x1ac8: 0x000a, 0x1ac9: 0x000a, 0x1aca: 0x000a, 0x1acb: 0x000a, - 0x1acc: 0x000a, 0x1acd: 0x000a, 0x1ace: 0x000a, 0x1acf: 0x000a, 0x1ad0: 0x000a, 0x1ad1: 0x000a, - 0x1ad2: 0x000a, 0x1ad3: 0x000a, 0x1ad4: 0x000a, 0x1ad5: 0x000a, 0x1ad6: 0x000a, 0x1ad7: 0x000a, - 0x1ad8: 0x000a, 0x1ad9: 0x000a, 0x1ada: 0x000a, 0x1adb: 0x000a, 0x1adc: 0x000a, 0x1add: 0x000a, - 0x1ade: 0x000a, 0x1adf: 0x000a, 0x1ae0: 0x000a, 0x1ae1: 0x000a, 0x1ae2: 0x003a, 0x1ae3: 0x002a, - 0x1ae4: 0x003a, 0x1ae5: 0x002a, 0x1ae6: 0x003a, 0x1ae7: 0x002a, 0x1ae8: 0x003a, 0x1ae9: 0x002a, - 0x1aea: 0x000a, 0x1aeb: 0x000a, 0x1aec: 0x000a, 0x1aed: 0x000a, 0x1aee: 0x000a, 0x1aef: 0x000a, - 0x1af0: 0x000a, 0x1af1: 0x000a, 0x1af2: 0x000a, 0x1af3: 0x000a, 0x1af4: 0x000a, 0x1af5: 0x000a, - 0x1af6: 0x000a, 0x1af7: 0x000a, 0x1af8: 0x000a, 0x1af9: 0x000a, 0x1afa: 0x000a, 0x1afb: 0x000a, - 0x1afc: 0x000a, 0x1afd: 0x000a, 0x1afe: 0x000a, 0x1aff: 0x000a, - // Block 0x6c, offset 0x1b00 - 0x1b00: 0x000a, 0x1b01: 0x000a, 0x1b02: 0x000a, 0x1b03: 0x000a, 0x1b04: 0x000a, - // Block 0x6d, offset 0x1b40 - 0x1b40: 0x000a, 0x1b41: 0x000a, 0x1b42: 0x000a, 0x1b43: 0x000a, 0x1b44: 0x000a, 0x1b45: 0x000a, - 0x1b46: 0x000a, 0x1b47: 0x000a, 0x1b48: 0x000a, 0x1b49: 0x000a, 0x1b4a: 0x000a, 0x1b4b: 0x000a, - 0x1b4c: 0x000a, 0x1b4d: 0x000a, 0x1b4e: 0x000a, 0x1b4f: 0x000a, 0x1b50: 0x000a, 0x1b51: 0x000a, - 0x1b52: 0x000a, 0x1b53: 0x000a, 0x1b54: 0x000a, 0x1b55: 0x000a, 0x1b56: 0x000a, 0x1b57: 0x000a, - 0x1b58: 0x000a, 0x1b59: 0x000a, 0x1b5b: 0x000a, 0x1b5c: 0x000a, 0x1b5d: 0x000a, - 0x1b5e: 0x000a, 0x1b5f: 0x000a, 0x1b60: 0x000a, 0x1b61: 0x000a, 0x1b62: 0x000a, 0x1b63: 0x000a, - 0x1b64: 0x000a, 0x1b65: 0x000a, 0x1b66: 0x000a, 0x1b67: 0x000a, 0x1b68: 0x000a, 0x1b69: 0x000a, - 0x1b6a: 0x000a, 0x1b6b: 0x000a, 0x1b6c: 0x000a, 0x1b6d: 0x000a, 0x1b6e: 0x000a, 0x1b6f: 0x000a, - 0x1b70: 0x000a, 0x1b71: 0x000a, 0x1b72: 0x000a, 0x1b73: 0x000a, 0x1b74: 0x000a, 0x1b75: 0x000a, - 0x1b76: 0x000a, 0x1b77: 0x000a, 0x1b78: 0x000a, 0x1b79: 0x000a, 0x1b7a: 0x000a, 0x1b7b: 0x000a, - 0x1b7c: 0x000a, 0x1b7d: 0x000a, 0x1b7e: 0x000a, 0x1b7f: 0x000a, - // Block 0x6e, offset 0x1b80 - 0x1b80: 0x000a, 0x1b81: 0x000a, 0x1b82: 0x000a, 0x1b83: 0x000a, 0x1b84: 0x000a, 0x1b85: 0x000a, - 0x1b86: 0x000a, 0x1b87: 0x000a, 0x1b88: 0x000a, 0x1b89: 0x000a, 0x1b8a: 0x000a, 0x1b8b: 0x000a, - 0x1b8c: 0x000a, 0x1b8d: 0x000a, 0x1b8e: 0x000a, 0x1b8f: 0x000a, 0x1b90: 0x000a, 0x1b91: 0x000a, - 0x1b92: 0x000a, 0x1b93: 0x000a, 0x1b94: 0x000a, 0x1b95: 0x000a, 0x1b96: 0x000a, 0x1b97: 0x000a, - 0x1b98: 0x000a, 0x1b99: 0x000a, 0x1b9a: 0x000a, 0x1b9b: 0x000a, 0x1b9c: 0x000a, 0x1b9d: 0x000a, - 0x1b9e: 0x000a, 0x1b9f: 0x000a, 0x1ba0: 0x000a, 0x1ba1: 0x000a, 0x1ba2: 0x000a, 0x1ba3: 0x000a, - 0x1ba4: 0x000a, 0x1ba5: 0x000a, 0x1ba6: 0x000a, 0x1ba7: 0x000a, 0x1ba8: 0x000a, 0x1ba9: 0x000a, - 0x1baa: 0x000a, 0x1bab: 0x000a, 0x1bac: 0x000a, 0x1bad: 0x000a, 0x1bae: 0x000a, 0x1baf: 0x000a, - 0x1bb0: 0x000a, 0x1bb1: 0x000a, 0x1bb2: 0x000a, 0x1bb3: 0x000a, - // Block 0x6f, offset 0x1bc0 - 0x1bc0: 0x000a, 0x1bc1: 0x000a, 0x1bc2: 0x000a, 0x1bc3: 0x000a, 0x1bc4: 0x000a, 0x1bc5: 0x000a, - 0x1bc6: 0x000a, 0x1bc7: 0x000a, 0x1bc8: 0x000a, 0x1bc9: 0x000a, 0x1bca: 0x000a, 0x1bcb: 0x000a, - 0x1bcc: 0x000a, 0x1bcd: 0x000a, 0x1bce: 0x000a, 0x1bcf: 0x000a, 0x1bd0: 0x000a, 0x1bd1: 0x000a, - 0x1bd2: 0x000a, 0x1bd3: 0x000a, 0x1bd4: 0x000a, 0x1bd5: 0x000a, - 0x1bf0: 0x000a, 0x1bf1: 0x000a, 0x1bf2: 0x000a, 0x1bf3: 0x000a, 0x1bf4: 0x000a, 0x1bf5: 0x000a, - 0x1bf6: 0x000a, 0x1bf7: 0x000a, 0x1bf8: 0x000a, 0x1bf9: 0x000a, 0x1bfa: 0x000a, 0x1bfb: 0x000a, - // Block 0x70, offset 0x1c00 - 0x1c00: 0x0009, 0x1c01: 0x000a, 0x1c02: 0x000a, 0x1c03: 0x000a, 0x1c04: 0x000a, - 0x1c08: 0x003a, 0x1c09: 0x002a, 0x1c0a: 0x003a, 0x1c0b: 0x002a, - 0x1c0c: 0x003a, 0x1c0d: 0x002a, 0x1c0e: 0x003a, 0x1c0f: 0x002a, 0x1c10: 0x003a, 0x1c11: 0x002a, - 0x1c12: 0x000a, 0x1c13: 0x000a, 0x1c14: 0x003a, 0x1c15: 0x002a, 0x1c16: 0x003a, 0x1c17: 0x002a, - 0x1c18: 0x003a, 0x1c19: 0x002a, 0x1c1a: 0x003a, 0x1c1b: 0x002a, 0x1c1c: 0x000a, 0x1c1d: 0x000a, - 0x1c1e: 0x000a, 0x1c1f: 0x000a, 0x1c20: 0x000a, - 0x1c2a: 0x000c, 0x1c2b: 0x000c, 0x1c2c: 0x000c, 0x1c2d: 0x000c, - 0x1c30: 0x000a, - 0x1c36: 0x000a, 0x1c37: 0x000a, - 0x1c3d: 0x000a, 0x1c3e: 0x000a, 0x1c3f: 0x000a, - // Block 0x71, offset 0x1c40 - 0x1c59: 0x000c, 0x1c5a: 0x000c, 0x1c5b: 0x000a, 0x1c5c: 0x000a, - 0x1c60: 0x000a, - // Block 0x72, offset 0x1c80 - 0x1cbb: 0x000a, - // Block 0x73, offset 0x1cc0 - 0x1cc0: 0x000a, 0x1cc1: 0x000a, 0x1cc2: 0x000a, 0x1cc3: 0x000a, 0x1cc4: 0x000a, 0x1cc5: 0x000a, - 0x1cc6: 0x000a, 0x1cc7: 0x000a, 0x1cc8: 0x000a, 0x1cc9: 0x000a, 0x1cca: 0x000a, 0x1ccb: 0x000a, - 0x1ccc: 0x000a, 0x1ccd: 0x000a, 0x1cce: 0x000a, 0x1ccf: 0x000a, 0x1cd0: 0x000a, 0x1cd1: 0x000a, - 0x1cd2: 0x000a, 0x1cd3: 0x000a, 0x1cd4: 0x000a, 0x1cd5: 0x000a, 0x1cd6: 0x000a, 0x1cd7: 0x000a, - 0x1cd8: 0x000a, 0x1cd9: 0x000a, 0x1cda: 0x000a, 0x1cdb: 0x000a, 0x1cdc: 0x000a, 0x1cdd: 0x000a, - 0x1cde: 0x000a, 0x1cdf: 0x000a, 0x1ce0: 0x000a, 0x1ce1: 0x000a, 0x1ce2: 0x000a, 0x1ce3: 0x000a, - // Block 0x74, offset 0x1d00 - 0x1d1d: 0x000a, - 0x1d1e: 0x000a, - // Block 0x75, offset 0x1d40 - 0x1d50: 0x000a, 0x1d51: 0x000a, - 0x1d52: 0x000a, 0x1d53: 0x000a, 0x1d54: 0x000a, 0x1d55: 0x000a, 0x1d56: 0x000a, 0x1d57: 0x000a, - 0x1d58: 0x000a, 0x1d59: 0x000a, 0x1d5a: 0x000a, 0x1d5b: 0x000a, 0x1d5c: 0x000a, 0x1d5d: 0x000a, - 0x1d5e: 0x000a, 0x1d5f: 0x000a, - 0x1d7c: 0x000a, 0x1d7d: 0x000a, 0x1d7e: 0x000a, - // Block 0x76, offset 0x1d80 - 0x1db1: 0x000a, 0x1db2: 0x000a, 0x1db3: 0x000a, 0x1db4: 0x000a, 0x1db5: 0x000a, - 0x1db6: 0x000a, 0x1db7: 0x000a, 0x1db8: 0x000a, 0x1db9: 0x000a, 0x1dba: 0x000a, 0x1dbb: 0x000a, - 0x1dbc: 0x000a, 0x1dbd: 0x000a, 0x1dbe: 0x000a, 0x1dbf: 0x000a, - // Block 0x77, offset 0x1dc0 - 0x1dcc: 0x000a, 0x1dcd: 0x000a, 0x1dce: 0x000a, 0x1dcf: 0x000a, - // Block 0x78, offset 0x1e00 - 0x1e37: 0x000a, 0x1e38: 0x000a, 0x1e39: 0x000a, 0x1e3a: 0x000a, - // Block 0x79, offset 0x1e40 - 0x1e5e: 0x000a, 0x1e5f: 0x000a, - 0x1e7f: 0x000a, - // Block 0x7a, offset 0x1e80 - 0x1e90: 0x000a, 0x1e91: 0x000a, - 0x1e92: 0x000a, 0x1e93: 0x000a, 0x1e94: 0x000a, 0x1e95: 0x000a, 0x1e96: 0x000a, 0x1e97: 0x000a, - 0x1e98: 0x000a, 0x1e99: 0x000a, 0x1e9a: 0x000a, 0x1e9b: 0x000a, 0x1e9c: 0x000a, 0x1e9d: 0x000a, - 0x1e9e: 0x000a, 0x1e9f: 0x000a, 0x1ea0: 0x000a, 0x1ea1: 0x000a, 0x1ea2: 0x000a, 0x1ea3: 0x000a, - 0x1ea4: 0x000a, 0x1ea5: 0x000a, 0x1ea6: 0x000a, 0x1ea7: 0x000a, 0x1ea8: 0x000a, 0x1ea9: 0x000a, - 0x1eaa: 0x000a, 0x1eab: 0x000a, 0x1eac: 0x000a, 0x1ead: 0x000a, 0x1eae: 0x000a, 0x1eaf: 0x000a, - 0x1eb0: 0x000a, 0x1eb1: 0x000a, 0x1eb2: 0x000a, 0x1eb3: 0x000a, 0x1eb4: 0x000a, 0x1eb5: 0x000a, - 0x1eb6: 0x000a, 0x1eb7: 0x000a, 0x1eb8: 0x000a, 0x1eb9: 0x000a, 0x1eba: 0x000a, 0x1ebb: 0x000a, - 0x1ebc: 0x000a, 0x1ebd: 0x000a, 0x1ebe: 0x000a, 0x1ebf: 0x000a, - // Block 0x7b, offset 0x1ec0 - 0x1ec0: 0x000a, 0x1ec1: 0x000a, 0x1ec2: 0x000a, 0x1ec3: 0x000a, 0x1ec4: 0x000a, 0x1ec5: 0x000a, - 0x1ec6: 0x000a, - // Block 0x7c, offset 0x1f00 - 0x1f0d: 0x000a, 0x1f0e: 0x000a, 0x1f0f: 0x000a, - // Block 0x7d, offset 0x1f40 - 0x1f6f: 0x000c, - 0x1f70: 0x000c, 0x1f71: 0x000c, 0x1f72: 0x000c, 0x1f73: 0x000a, 0x1f74: 0x000c, 0x1f75: 0x000c, - 0x1f76: 0x000c, 0x1f77: 0x000c, 0x1f78: 0x000c, 0x1f79: 0x000c, 0x1f7a: 0x000c, 0x1f7b: 0x000c, - 0x1f7c: 0x000c, 0x1f7d: 0x000c, 0x1f7e: 0x000a, 0x1f7f: 0x000a, - // Block 0x7e, offset 0x1f80 - 0x1f9e: 0x000c, 0x1f9f: 0x000c, - // Block 0x7f, offset 0x1fc0 - 0x1ff0: 0x000c, 0x1ff1: 0x000c, - // Block 0x80, offset 0x2000 - 0x2000: 0x000a, 0x2001: 0x000a, 0x2002: 0x000a, 0x2003: 0x000a, 0x2004: 0x000a, 0x2005: 0x000a, - 0x2006: 0x000a, 0x2007: 0x000a, 0x2008: 0x000a, 0x2009: 0x000a, 0x200a: 0x000a, 0x200b: 0x000a, - 0x200c: 0x000a, 0x200d: 0x000a, 0x200e: 0x000a, 0x200f: 0x000a, 0x2010: 0x000a, 0x2011: 0x000a, - 0x2012: 0x000a, 0x2013: 0x000a, 0x2014: 0x000a, 0x2015: 0x000a, 0x2016: 0x000a, 0x2017: 0x000a, - 0x2018: 0x000a, 0x2019: 0x000a, 0x201a: 0x000a, 0x201b: 0x000a, 0x201c: 0x000a, 0x201d: 0x000a, - 0x201e: 0x000a, 0x201f: 0x000a, 0x2020: 0x000a, 0x2021: 0x000a, - // Block 0x81, offset 0x2040 - 0x2048: 0x000a, - // Block 0x82, offset 0x2080 - 0x2082: 0x000c, - 0x2086: 0x000c, 0x208b: 0x000c, - 0x20a5: 0x000c, 0x20a6: 0x000c, 0x20a8: 0x000a, 0x20a9: 0x000a, - 0x20aa: 0x000a, 0x20ab: 0x000a, - 0x20b8: 0x0004, 0x20b9: 0x0004, - // Block 0x83, offset 0x20c0 - 0x20f4: 0x000a, 0x20f5: 0x000a, - 0x20f6: 0x000a, 0x20f7: 0x000a, - // Block 0x84, offset 0x2100 - 0x2104: 0x000c, 0x2105: 0x000c, - 0x2120: 0x000c, 0x2121: 0x000c, 0x2122: 0x000c, 0x2123: 0x000c, - 0x2124: 0x000c, 0x2125: 0x000c, 0x2126: 0x000c, 0x2127: 0x000c, 0x2128: 0x000c, 0x2129: 0x000c, - 0x212a: 0x000c, 0x212b: 0x000c, 0x212c: 0x000c, 0x212d: 0x000c, 0x212e: 0x000c, 0x212f: 0x000c, - 0x2130: 0x000c, 0x2131: 0x000c, - // Block 0x85, offset 0x2140 - 0x2166: 0x000c, 0x2167: 0x000c, 0x2168: 0x000c, 0x2169: 0x000c, - 0x216a: 0x000c, 0x216b: 0x000c, 0x216c: 0x000c, 0x216d: 0x000c, - // Block 0x86, offset 0x2180 - 0x2187: 0x000c, 0x2188: 0x000c, 0x2189: 0x000c, 0x218a: 0x000c, 0x218b: 0x000c, - 0x218c: 0x000c, 0x218d: 0x000c, 0x218e: 0x000c, 0x218f: 0x000c, 0x2190: 0x000c, 0x2191: 0x000c, - // Block 0x87, offset 0x21c0 - 0x21c0: 0x000c, 0x21c1: 0x000c, 0x21c2: 0x000c, - 0x21f3: 0x000c, - 0x21f6: 0x000c, 0x21f7: 0x000c, 0x21f8: 0x000c, 0x21f9: 0x000c, - 0x21fc: 0x000c, - // Block 0x88, offset 0x2200 - 0x2225: 0x000c, - // Block 0x89, offset 0x2240 - 0x2269: 0x000c, - 0x226a: 0x000c, 0x226b: 0x000c, 0x226c: 0x000c, 0x226d: 0x000c, 0x226e: 0x000c, - 0x2271: 0x000c, 0x2272: 0x000c, 0x2275: 0x000c, - 0x2276: 0x000c, - // Block 0x8a, offset 0x2280 - 0x2283: 0x000c, - 0x228c: 0x000c, - 0x22bc: 0x000c, - // Block 0x8b, offset 0x22c0 - 0x22f0: 0x000c, 0x22f2: 0x000c, 0x22f3: 0x000c, 0x22f4: 0x000c, - 0x22f7: 0x000c, 0x22f8: 0x000c, - 0x22fe: 0x000c, 0x22ff: 0x000c, - // Block 0x8c, offset 0x2300 - 0x2301: 0x000c, - 0x232c: 0x000c, 0x232d: 0x000c, - 0x2336: 0x000c, - // Block 0x8d, offset 0x2340 - 0x2365: 0x000c, 0x2368: 0x000c, - 0x236d: 0x000c, - // Block 0x8e, offset 0x2380 - 0x239d: 0x0001, - 0x239e: 0x000c, 0x239f: 0x0001, 0x23a0: 0x0001, 0x23a1: 0x0001, 0x23a2: 0x0001, 0x23a3: 0x0001, - 0x23a4: 0x0001, 0x23a5: 0x0001, 0x23a6: 0x0001, 0x23a7: 0x0001, 0x23a8: 0x0001, 0x23a9: 0x0003, - 0x23aa: 0x0001, 0x23ab: 0x0001, 0x23ac: 0x0001, 0x23ad: 0x0001, 0x23ae: 0x0001, 0x23af: 0x0001, - 0x23b0: 0x0001, 0x23b1: 0x0001, 0x23b2: 0x0001, 0x23b3: 0x0001, 0x23b4: 0x0001, 0x23b5: 0x0001, - 0x23b6: 0x0001, 0x23b7: 0x0001, 0x23b8: 0x0001, 0x23b9: 0x0001, 0x23ba: 0x0001, 0x23bb: 0x0001, - 0x23bc: 0x0001, 0x23bd: 0x0001, 0x23be: 0x0001, 0x23bf: 0x0001, - // Block 0x8f, offset 0x23c0 - 0x23c0: 0x0001, 0x23c1: 0x0001, 0x23c2: 0x0001, 0x23c3: 0x0001, 0x23c4: 0x0001, 0x23c5: 0x0001, - 0x23c6: 0x0001, 0x23c7: 0x0001, 0x23c8: 0x0001, 0x23c9: 0x0001, 0x23ca: 0x0001, 0x23cb: 0x0001, - 0x23cc: 0x0001, 0x23cd: 0x0001, 0x23ce: 0x0001, 0x23cf: 0x0001, 0x23d0: 0x000d, 0x23d1: 0x000d, - 0x23d2: 0x000d, 0x23d3: 0x000d, 0x23d4: 0x000d, 0x23d5: 0x000d, 0x23d6: 0x000d, 0x23d7: 0x000d, - 0x23d8: 0x000d, 0x23d9: 0x000d, 0x23da: 0x000d, 0x23db: 0x000d, 0x23dc: 0x000d, 0x23dd: 0x000d, - 0x23de: 0x000d, 0x23df: 0x000d, 0x23e0: 0x000d, 0x23e1: 0x000d, 0x23e2: 0x000d, 0x23e3: 0x000d, - 0x23e4: 0x000d, 0x23e5: 0x000d, 0x23e6: 0x000d, 0x23e7: 0x000d, 0x23e8: 0x000d, 0x23e9: 0x000d, - 0x23ea: 0x000d, 0x23eb: 0x000d, 0x23ec: 0x000d, 0x23ed: 0x000d, 0x23ee: 0x000d, 0x23ef: 0x000d, - 0x23f0: 0x000d, 0x23f1: 0x000d, 0x23f2: 0x000d, 0x23f3: 0x000d, 0x23f4: 0x000d, 0x23f5: 0x000d, - 0x23f6: 0x000d, 0x23f7: 0x000d, 0x23f8: 0x000d, 0x23f9: 0x000d, 0x23fa: 0x000d, 0x23fb: 0x000d, - 0x23fc: 0x000d, 0x23fd: 0x000d, 0x23fe: 0x000d, 0x23ff: 0x000d, - // Block 0x90, offset 0x2400 - 0x2400: 0x000d, 0x2401: 0x000d, 0x2402: 0x000d, 0x2403: 0x000d, 0x2404: 0x000d, 0x2405: 0x000d, - 0x2406: 0x000d, 0x2407: 0x000d, 0x2408: 0x000d, 0x2409: 0x000d, 0x240a: 0x000d, 0x240b: 0x000d, - 0x240c: 0x000d, 0x240d: 0x000d, 0x240e: 0x000d, 0x240f: 0x000d, 0x2410: 0x000d, 0x2411: 0x000d, - 0x2412: 0x000d, 0x2413: 0x000d, 0x2414: 0x000d, 0x2415: 0x000d, 0x2416: 0x000d, 0x2417: 0x000d, - 0x2418: 0x000d, 0x2419: 0x000d, 0x241a: 0x000d, 0x241b: 0x000d, 0x241c: 0x000d, 0x241d: 0x000d, - 0x241e: 0x000d, 0x241f: 0x000d, 0x2420: 0x000d, 0x2421: 0x000d, 0x2422: 0x000d, 0x2423: 0x000d, - 0x2424: 0x000d, 0x2425: 0x000d, 0x2426: 0x000d, 0x2427: 0x000d, 0x2428: 0x000d, 0x2429: 0x000d, - 0x242a: 0x000d, 0x242b: 0x000d, 0x242c: 0x000d, 0x242d: 0x000d, 0x242e: 0x000d, 0x242f: 0x000d, - 0x2430: 0x000d, 0x2431: 0x000d, 0x2432: 0x000d, 0x2433: 0x000d, 0x2434: 0x000d, 0x2435: 0x000d, - 0x2436: 0x000d, 0x2437: 0x000d, 0x2438: 0x000d, 0x2439: 0x000d, 0x243a: 0x000d, 0x243b: 0x000d, - 0x243c: 0x000d, 0x243d: 0x000d, 0x243e: 0x000a, 0x243f: 0x000a, - // Block 0x91, offset 0x2440 - 0x2440: 0x000d, 0x2441: 0x000d, 0x2442: 0x000d, 0x2443: 0x000d, 0x2444: 0x000d, 0x2445: 0x000d, - 0x2446: 0x000d, 0x2447: 0x000d, 0x2448: 0x000d, 0x2449: 0x000d, 0x244a: 0x000d, 0x244b: 0x000d, - 0x244c: 0x000d, 0x244d: 0x000d, 0x244e: 0x000d, 0x244f: 0x000d, 0x2450: 0x000b, 0x2451: 0x000b, - 0x2452: 0x000b, 0x2453: 0x000b, 0x2454: 0x000b, 0x2455: 0x000b, 0x2456: 0x000b, 0x2457: 0x000b, - 0x2458: 0x000b, 0x2459: 0x000b, 0x245a: 0x000b, 0x245b: 0x000b, 0x245c: 0x000b, 0x245d: 0x000b, - 0x245e: 0x000b, 0x245f: 0x000b, 0x2460: 0x000b, 0x2461: 0x000b, 0x2462: 0x000b, 0x2463: 0x000b, - 0x2464: 0x000b, 0x2465: 0x000b, 0x2466: 0x000b, 0x2467: 0x000b, 0x2468: 0x000b, 0x2469: 0x000b, - 0x246a: 0x000b, 0x246b: 0x000b, 0x246c: 0x000b, 0x246d: 0x000b, 0x246e: 0x000b, 0x246f: 0x000b, - 0x2470: 0x000d, 0x2471: 0x000d, 0x2472: 0x000d, 0x2473: 0x000d, 0x2474: 0x000d, 0x2475: 0x000d, - 0x2476: 0x000d, 0x2477: 0x000d, 0x2478: 0x000d, 0x2479: 0x000d, 0x247a: 0x000d, 0x247b: 0x000d, - 0x247c: 0x000d, 0x247d: 0x000a, 0x247e: 0x000d, 0x247f: 0x000d, - // Block 0x92, offset 0x2480 - 0x2480: 0x000c, 0x2481: 0x000c, 0x2482: 0x000c, 0x2483: 0x000c, 0x2484: 0x000c, 0x2485: 0x000c, - 0x2486: 0x000c, 0x2487: 0x000c, 0x2488: 0x000c, 0x2489: 0x000c, 0x248a: 0x000c, 0x248b: 0x000c, - 0x248c: 0x000c, 0x248d: 0x000c, 0x248e: 0x000c, 0x248f: 0x000c, 0x2490: 0x000a, 0x2491: 0x000a, - 0x2492: 0x000a, 0x2493: 0x000a, 0x2494: 0x000a, 0x2495: 0x000a, 0x2496: 0x000a, 0x2497: 0x000a, - 0x2498: 0x000a, 0x2499: 0x000a, - 0x24a0: 0x000c, 0x24a1: 0x000c, 0x24a2: 0x000c, 0x24a3: 0x000c, - 0x24a4: 0x000c, 0x24a5: 0x000c, 0x24a6: 0x000c, 0x24a7: 0x000c, 0x24a8: 0x000c, 0x24a9: 0x000c, - 0x24aa: 0x000c, 0x24ab: 0x000c, 0x24ac: 0x000c, 0x24ad: 0x000c, 0x24ae: 0x000c, 0x24af: 0x000c, - 0x24b0: 0x000a, 0x24b1: 0x000a, 0x24b2: 0x000a, 0x24b3: 0x000a, 0x24b4: 0x000a, 0x24b5: 0x000a, - 0x24b6: 0x000a, 0x24b7: 0x000a, 0x24b8: 0x000a, 0x24b9: 0x000a, 0x24ba: 0x000a, 0x24bb: 0x000a, - 0x24bc: 0x000a, 0x24bd: 0x000a, 0x24be: 0x000a, 0x24bf: 0x000a, - // Block 0x93, offset 0x24c0 - 0x24c0: 0x000a, 0x24c1: 0x000a, 0x24c2: 0x000a, 0x24c3: 0x000a, 0x24c4: 0x000a, 0x24c5: 0x000a, - 0x24c6: 0x000a, 0x24c7: 0x000a, 0x24c8: 0x000a, 0x24c9: 0x000a, 0x24ca: 0x000a, 0x24cb: 0x000a, - 0x24cc: 0x000a, 0x24cd: 0x000a, 0x24ce: 0x000a, 0x24cf: 0x000a, 0x24d0: 0x0006, 0x24d1: 0x000a, - 0x24d2: 0x0006, 0x24d4: 0x000a, 0x24d5: 0x0006, 0x24d6: 0x000a, 0x24d7: 0x000a, - 0x24d8: 0x000a, 0x24d9: 0x009a, 0x24da: 0x008a, 0x24db: 0x007a, 0x24dc: 0x006a, 0x24dd: 0x009a, - 0x24de: 0x008a, 0x24df: 0x0004, 0x24e0: 0x000a, 0x24e1: 0x000a, 0x24e2: 0x0003, 0x24e3: 0x0003, - 0x24e4: 0x000a, 0x24e5: 0x000a, 0x24e6: 0x000a, 0x24e8: 0x000a, 0x24e9: 0x0004, - 0x24ea: 0x0004, 0x24eb: 0x000a, - 0x24f0: 0x000d, 0x24f1: 0x000d, 0x24f2: 0x000d, 0x24f3: 0x000d, 0x24f4: 0x000d, 0x24f5: 0x000d, - 0x24f6: 0x000d, 0x24f7: 0x000d, 0x24f8: 0x000d, 0x24f9: 0x000d, 0x24fa: 0x000d, 0x24fb: 0x000d, - 0x24fc: 0x000d, 0x24fd: 0x000d, 0x24fe: 0x000d, 0x24ff: 0x000d, - // Block 0x94, offset 0x2500 - 0x2500: 0x000d, 0x2501: 0x000d, 0x2502: 0x000d, 0x2503: 0x000d, 0x2504: 0x000d, 0x2505: 0x000d, - 0x2506: 0x000d, 0x2507: 0x000d, 0x2508: 0x000d, 0x2509: 0x000d, 0x250a: 0x000d, 0x250b: 0x000d, - 0x250c: 0x000d, 0x250d: 0x000d, 0x250e: 0x000d, 0x250f: 0x000d, 0x2510: 0x000d, 0x2511: 0x000d, - 0x2512: 0x000d, 0x2513: 0x000d, 0x2514: 0x000d, 0x2515: 0x000d, 0x2516: 0x000d, 0x2517: 0x000d, - 0x2518: 0x000d, 0x2519: 0x000d, 0x251a: 0x000d, 0x251b: 0x000d, 0x251c: 0x000d, 0x251d: 0x000d, - 0x251e: 0x000d, 0x251f: 0x000d, 0x2520: 0x000d, 0x2521: 0x000d, 0x2522: 0x000d, 0x2523: 0x000d, - 0x2524: 0x000d, 0x2525: 0x000d, 0x2526: 0x000d, 0x2527: 0x000d, 0x2528: 0x000d, 0x2529: 0x000d, - 0x252a: 0x000d, 0x252b: 0x000d, 0x252c: 0x000d, 0x252d: 0x000d, 0x252e: 0x000d, 0x252f: 0x000d, - 0x2530: 0x000d, 0x2531: 0x000d, 0x2532: 0x000d, 0x2533: 0x000d, 0x2534: 0x000d, 0x2535: 0x000d, - 0x2536: 0x000d, 0x2537: 0x000d, 0x2538: 0x000d, 0x2539: 0x000d, 0x253a: 0x000d, 0x253b: 0x000d, - 0x253c: 0x000d, 0x253d: 0x000d, 0x253e: 0x000d, 0x253f: 0x000b, - // Block 0x95, offset 0x2540 - 0x2541: 0x000a, 0x2542: 0x000a, 0x2543: 0x0004, 0x2544: 0x0004, 0x2545: 0x0004, - 0x2546: 0x000a, 0x2547: 0x000a, 0x2548: 0x003a, 0x2549: 0x002a, 0x254a: 0x000a, 0x254b: 0x0003, - 0x254c: 0x0006, 0x254d: 0x0003, 0x254e: 0x0006, 0x254f: 0x0006, 0x2550: 0x0002, 0x2551: 0x0002, - 0x2552: 0x0002, 0x2553: 0x0002, 0x2554: 0x0002, 0x2555: 0x0002, 0x2556: 0x0002, 0x2557: 0x0002, - 0x2558: 0x0002, 0x2559: 0x0002, 0x255a: 0x0006, 0x255b: 0x000a, 0x255c: 0x000a, 0x255d: 0x000a, - 0x255e: 0x000a, 0x255f: 0x000a, 0x2560: 0x000a, - 0x257b: 0x005a, - 0x257c: 0x000a, 0x257d: 0x004a, 0x257e: 0x000a, 0x257f: 0x000a, - // Block 0x96, offset 0x2580 - 0x2580: 0x000a, - 0x259b: 0x005a, 0x259c: 0x000a, 0x259d: 0x004a, - 0x259e: 0x000a, 0x259f: 0x00fa, 0x25a0: 0x00ea, 0x25a1: 0x000a, 0x25a2: 0x003a, 0x25a3: 0x002a, - 0x25a4: 0x000a, 0x25a5: 0x000a, - // Block 0x97, offset 0x25c0 - 0x25e0: 0x0004, 0x25e1: 0x0004, 0x25e2: 0x000a, 0x25e3: 0x000a, - 0x25e4: 0x000a, 0x25e5: 0x0004, 0x25e6: 0x0004, 0x25e8: 0x000a, 0x25e9: 0x000a, - 0x25ea: 0x000a, 0x25eb: 0x000a, 0x25ec: 0x000a, 0x25ed: 0x000a, 0x25ee: 0x000a, - 0x25f0: 0x000b, 0x25f1: 0x000b, 0x25f2: 0x000b, 0x25f3: 0x000b, 0x25f4: 0x000b, 0x25f5: 0x000b, - 0x25f6: 0x000b, 0x25f7: 0x000b, 0x25f8: 0x000b, 0x25f9: 0x000a, 0x25fa: 0x000a, 0x25fb: 0x000a, - 0x25fc: 0x000a, 0x25fd: 0x000a, 0x25fe: 0x000b, 0x25ff: 0x000b, - // Block 0x98, offset 0x2600 - 0x2601: 0x000a, - // Block 0x99, offset 0x2640 - 0x2640: 0x000a, 0x2641: 0x000a, 0x2642: 0x000a, 0x2643: 0x000a, 0x2644: 0x000a, 0x2645: 0x000a, - 0x2646: 0x000a, 0x2647: 0x000a, 0x2648: 0x000a, 0x2649: 0x000a, 0x264a: 0x000a, 0x264b: 0x000a, - 0x264c: 0x000a, 0x2650: 0x000a, 0x2651: 0x000a, - 0x2652: 0x000a, 0x2653: 0x000a, 0x2654: 0x000a, 0x2655: 0x000a, 0x2656: 0x000a, 0x2657: 0x000a, - 0x2658: 0x000a, 0x2659: 0x000a, 0x265a: 0x000a, 0x265b: 0x000a, - 0x2660: 0x000a, - // Block 0x9a, offset 0x2680 - 0x26bd: 0x000c, - // Block 0x9b, offset 0x26c0 - 0x26e0: 0x000c, 0x26e1: 0x0002, 0x26e2: 0x0002, 0x26e3: 0x0002, - 0x26e4: 0x0002, 0x26e5: 0x0002, 0x26e6: 0x0002, 0x26e7: 0x0002, 0x26e8: 0x0002, 0x26e9: 0x0002, - 0x26ea: 0x0002, 0x26eb: 0x0002, 0x26ec: 0x0002, 0x26ed: 0x0002, 0x26ee: 0x0002, 0x26ef: 0x0002, - 0x26f0: 0x0002, 0x26f1: 0x0002, 0x26f2: 0x0002, 0x26f3: 0x0002, 0x26f4: 0x0002, 0x26f5: 0x0002, - 0x26f6: 0x0002, 0x26f7: 0x0002, 0x26f8: 0x0002, 0x26f9: 0x0002, 0x26fa: 0x0002, 0x26fb: 0x0002, - // Block 0x9c, offset 0x2700 - 0x2736: 0x000c, 0x2737: 0x000c, 0x2738: 0x000c, 0x2739: 0x000c, 0x273a: 0x000c, - // Block 0x9d, offset 0x2740 - 0x2740: 0x0001, 0x2741: 0x0001, 0x2742: 0x0001, 0x2743: 0x0001, 0x2744: 0x0001, 0x2745: 0x0001, - 0x2746: 0x0001, 0x2747: 0x0001, 0x2748: 0x0001, 0x2749: 0x0001, 0x274a: 0x0001, 0x274b: 0x0001, - 0x274c: 0x0001, 0x274d: 0x0001, 0x274e: 0x0001, 0x274f: 0x0001, 0x2750: 0x0001, 0x2751: 0x0001, - 0x2752: 0x0001, 0x2753: 0x0001, 0x2754: 0x0001, 0x2755: 0x0001, 0x2756: 0x0001, 0x2757: 0x0001, - 0x2758: 0x0001, 0x2759: 0x0001, 0x275a: 0x0001, 0x275b: 0x0001, 0x275c: 0x0001, 0x275d: 0x0001, - 0x275e: 0x0001, 0x275f: 0x0001, 0x2760: 0x0001, 0x2761: 0x0001, 0x2762: 0x0001, 0x2763: 0x0001, - 0x2764: 0x0001, 0x2765: 0x0001, 0x2766: 0x0001, 0x2767: 0x0001, 0x2768: 0x0001, 0x2769: 0x0001, - 0x276a: 0x0001, 0x276b: 0x0001, 0x276c: 0x0001, 0x276d: 0x0001, 0x276e: 0x0001, 0x276f: 0x0001, - 0x2770: 0x0001, 0x2771: 0x0001, 0x2772: 0x0001, 0x2773: 0x0001, 0x2774: 0x0001, 0x2775: 0x0001, - 0x2776: 0x0001, 0x2777: 0x0001, 0x2778: 0x0001, 0x2779: 0x0001, 0x277a: 0x0001, 0x277b: 0x0001, - 0x277c: 0x0001, 0x277d: 0x0001, 0x277e: 0x0001, 0x277f: 0x0001, - // Block 0x9e, offset 0x2780 - 0x2780: 0x0001, 0x2781: 0x0001, 0x2782: 0x0001, 0x2783: 0x0001, 0x2784: 0x0001, 0x2785: 0x0001, - 0x2786: 0x0001, 0x2787: 0x0001, 0x2788: 0x0001, 0x2789: 0x0001, 0x278a: 0x0001, 0x278b: 0x0001, - 0x278c: 0x0001, 0x278d: 0x0001, 0x278e: 0x0001, 0x278f: 0x0001, 0x2790: 0x0001, 0x2791: 0x0001, - 0x2792: 0x0001, 0x2793: 0x0001, 0x2794: 0x0001, 0x2795: 0x0001, 0x2796: 0x0001, 0x2797: 0x0001, - 0x2798: 0x0001, 0x2799: 0x0001, 0x279a: 0x0001, 0x279b: 0x0001, 0x279c: 0x0001, 0x279d: 0x0001, - 0x279e: 0x0001, 0x279f: 0x000a, 0x27a0: 0x0001, 0x27a1: 0x0001, 0x27a2: 0x0001, 0x27a3: 0x0001, - 0x27a4: 0x0001, 0x27a5: 0x0001, 0x27a6: 0x0001, 0x27a7: 0x0001, 0x27a8: 0x0001, 0x27a9: 0x0001, - 0x27aa: 0x0001, 0x27ab: 0x0001, 0x27ac: 0x0001, 0x27ad: 0x0001, 0x27ae: 0x0001, 0x27af: 0x0001, - 0x27b0: 0x0001, 0x27b1: 0x0001, 0x27b2: 0x0001, 0x27b3: 0x0001, 0x27b4: 0x0001, 0x27b5: 0x0001, - 0x27b6: 0x0001, 0x27b7: 0x0001, 0x27b8: 0x0001, 0x27b9: 0x0001, 0x27ba: 0x0001, 0x27bb: 0x0001, - 0x27bc: 0x0001, 0x27bd: 0x0001, 0x27be: 0x0001, 0x27bf: 0x0001, - // Block 0x9f, offset 0x27c0 - 0x27c0: 0x0001, 0x27c1: 0x000c, 0x27c2: 0x000c, 0x27c3: 0x000c, 0x27c4: 0x0001, 0x27c5: 0x000c, - 0x27c6: 0x000c, 0x27c7: 0x0001, 0x27c8: 0x0001, 0x27c9: 0x0001, 0x27ca: 0x0001, 0x27cb: 0x0001, - 0x27cc: 0x000c, 0x27cd: 0x000c, 0x27ce: 0x000c, 0x27cf: 0x000c, 0x27d0: 0x0001, 0x27d1: 0x0001, - 0x27d2: 0x0001, 0x27d3: 0x0001, 0x27d4: 0x0001, 0x27d5: 0x0001, 0x27d6: 0x0001, 0x27d7: 0x0001, - 0x27d8: 0x0001, 0x27d9: 0x0001, 0x27da: 0x0001, 0x27db: 0x0001, 0x27dc: 0x0001, 0x27dd: 0x0001, - 0x27de: 0x0001, 0x27df: 0x0001, 0x27e0: 0x0001, 0x27e1: 0x0001, 0x27e2: 0x0001, 0x27e3: 0x0001, - 0x27e4: 0x0001, 0x27e5: 0x0001, 0x27e6: 0x0001, 0x27e7: 0x0001, 0x27e8: 0x0001, 0x27e9: 0x0001, - 0x27ea: 0x0001, 0x27eb: 0x0001, 0x27ec: 0x0001, 0x27ed: 0x0001, 0x27ee: 0x0001, 0x27ef: 0x0001, - 0x27f0: 0x0001, 0x27f1: 0x0001, 0x27f2: 0x0001, 0x27f3: 0x0001, 0x27f4: 0x0001, 0x27f5: 0x0001, - 0x27f6: 0x0001, 0x27f7: 0x0001, 0x27f8: 0x000c, 0x27f9: 0x000c, 0x27fa: 0x000c, 0x27fb: 0x0001, - 0x27fc: 0x0001, 0x27fd: 0x0001, 0x27fe: 0x0001, 0x27ff: 0x000c, - // Block 0xa0, offset 0x2800 - 0x2800: 0x0001, 0x2801: 0x0001, 0x2802: 0x0001, 0x2803: 0x0001, 0x2804: 0x0001, 0x2805: 0x0001, - 0x2806: 0x0001, 0x2807: 0x0001, 0x2808: 0x0001, 0x2809: 0x0001, 0x280a: 0x0001, 0x280b: 0x0001, - 0x280c: 0x0001, 0x280d: 0x0001, 0x280e: 0x0001, 0x280f: 0x0001, 0x2810: 0x0001, 0x2811: 0x0001, - 0x2812: 0x0001, 0x2813: 0x0001, 0x2814: 0x0001, 0x2815: 0x0001, 0x2816: 0x0001, 0x2817: 0x0001, - 0x2818: 0x0001, 0x2819: 0x0001, 0x281a: 0x0001, 0x281b: 0x0001, 0x281c: 0x0001, 0x281d: 0x0001, - 0x281e: 0x0001, 0x281f: 0x0001, 0x2820: 0x0001, 0x2821: 0x0001, 0x2822: 0x0001, 0x2823: 0x0001, - 0x2824: 0x0001, 0x2825: 0x000c, 0x2826: 0x000c, 0x2827: 0x0001, 0x2828: 0x0001, 0x2829: 0x0001, - 0x282a: 0x0001, 0x282b: 0x0001, 0x282c: 0x0001, 0x282d: 0x0001, 0x282e: 0x0001, 0x282f: 0x0001, - 0x2830: 0x0001, 0x2831: 0x0001, 0x2832: 0x0001, 0x2833: 0x0001, 0x2834: 0x0001, 0x2835: 0x0001, - 0x2836: 0x0001, 0x2837: 0x0001, 0x2838: 0x0001, 0x2839: 0x0001, 0x283a: 0x0001, 0x283b: 0x0001, - 0x283c: 0x0001, 0x283d: 0x0001, 0x283e: 0x0001, 0x283f: 0x0001, - // Block 0xa1, offset 0x2840 - 0x2840: 0x0001, 0x2841: 0x0001, 0x2842: 0x0001, 0x2843: 0x0001, 0x2844: 0x0001, 0x2845: 0x0001, - 0x2846: 0x0001, 0x2847: 0x0001, 0x2848: 0x0001, 0x2849: 0x0001, 0x284a: 0x0001, 0x284b: 0x0001, - 0x284c: 0x0001, 0x284d: 0x0001, 0x284e: 0x0001, 0x284f: 0x0001, 0x2850: 0x0001, 0x2851: 0x0001, - 0x2852: 0x0001, 0x2853: 0x0001, 0x2854: 0x0001, 0x2855: 0x0001, 0x2856: 0x0001, 0x2857: 0x0001, - 0x2858: 0x0001, 0x2859: 0x0001, 0x285a: 0x0001, 0x285b: 0x0001, 0x285c: 0x0001, 0x285d: 0x0001, - 0x285e: 0x0001, 0x285f: 0x0001, 0x2860: 0x0001, 0x2861: 0x0001, 0x2862: 0x0001, 0x2863: 0x0001, - 0x2864: 0x0001, 0x2865: 0x0001, 0x2866: 0x0001, 0x2867: 0x0001, 0x2868: 0x0001, 0x2869: 0x0001, - 0x286a: 0x0001, 0x286b: 0x0001, 0x286c: 0x0001, 0x286d: 0x0001, 0x286e: 0x0001, 0x286f: 0x0001, - 0x2870: 0x0001, 0x2871: 0x0001, 0x2872: 0x0001, 0x2873: 0x0001, 0x2874: 0x0001, 0x2875: 0x0001, - 0x2876: 0x0001, 0x2877: 0x0001, 0x2878: 0x0001, 0x2879: 0x000a, 0x287a: 0x000a, 0x287b: 0x000a, - 0x287c: 0x000a, 0x287d: 0x000a, 0x287e: 0x000a, 0x287f: 0x000a, - // Block 0xa2, offset 0x2880 - 0x2880: 0x0001, 0x2881: 0x0001, 0x2882: 0x0001, 0x2883: 0x0001, 0x2884: 0x0001, 0x2885: 0x0001, - 0x2886: 0x0001, 0x2887: 0x0001, 0x2888: 0x0001, 0x2889: 0x0001, 0x288a: 0x0001, 0x288b: 0x0001, - 0x288c: 0x0001, 0x288d: 0x0001, 0x288e: 0x0001, 0x288f: 0x0001, 0x2890: 0x0001, 0x2891: 0x0001, - 0x2892: 0x0001, 0x2893: 0x0001, 0x2894: 0x0001, 0x2895: 0x0001, 0x2896: 0x0001, 0x2897: 0x0001, - 0x2898: 0x0001, 0x2899: 0x0001, 0x289a: 0x0001, 0x289b: 0x0001, 0x289c: 0x0001, 0x289d: 0x0001, - 0x289e: 0x0001, 0x289f: 0x0001, 0x28a0: 0x0005, 0x28a1: 0x0005, 0x28a2: 0x0005, 0x28a3: 0x0005, - 0x28a4: 0x0005, 0x28a5: 0x0005, 0x28a6: 0x0005, 0x28a7: 0x0005, 0x28a8: 0x0005, 0x28a9: 0x0005, - 0x28aa: 0x0005, 0x28ab: 0x0005, 0x28ac: 0x0005, 0x28ad: 0x0005, 0x28ae: 0x0005, 0x28af: 0x0005, - 0x28b0: 0x0005, 0x28b1: 0x0005, 0x28b2: 0x0005, 0x28b3: 0x0005, 0x28b4: 0x0005, 0x28b5: 0x0005, - 0x28b6: 0x0005, 0x28b7: 0x0005, 0x28b8: 0x0005, 0x28b9: 0x0005, 0x28ba: 0x0005, 0x28bb: 0x0005, - 0x28bc: 0x0005, 0x28bd: 0x0005, 0x28be: 0x0005, 0x28bf: 0x0001, - // Block 0xa3, offset 0x28c0 - 0x28c1: 0x000c, - 0x28f8: 0x000c, 0x28f9: 0x000c, 0x28fa: 0x000c, 0x28fb: 0x000c, - 0x28fc: 0x000c, 0x28fd: 0x000c, 0x28fe: 0x000c, 0x28ff: 0x000c, - // Block 0xa4, offset 0x2900 - 0x2900: 0x000c, 0x2901: 0x000c, 0x2902: 0x000c, 0x2903: 0x000c, 0x2904: 0x000c, 0x2905: 0x000c, - 0x2906: 0x000c, - 0x2912: 0x000a, 0x2913: 0x000a, 0x2914: 0x000a, 0x2915: 0x000a, 0x2916: 0x000a, 0x2917: 0x000a, - 0x2918: 0x000a, 0x2919: 0x000a, 0x291a: 0x000a, 0x291b: 0x000a, 0x291c: 0x000a, 0x291d: 0x000a, - 0x291e: 0x000a, 0x291f: 0x000a, 0x2920: 0x000a, 0x2921: 0x000a, 0x2922: 0x000a, 0x2923: 0x000a, - 0x2924: 0x000a, 0x2925: 0x000a, - 0x293f: 0x000c, - // Block 0xa5, offset 0x2940 - 0x2940: 0x000c, 0x2941: 0x000c, - 0x2973: 0x000c, 0x2974: 0x000c, 0x2975: 0x000c, - 0x2976: 0x000c, 0x2979: 0x000c, 0x297a: 0x000c, - // Block 0xa6, offset 0x2980 - 0x2980: 0x000c, 0x2981: 0x000c, 0x2982: 0x000c, - 0x29a7: 0x000c, 0x29a8: 0x000c, 0x29a9: 0x000c, - 0x29aa: 0x000c, 0x29ab: 0x000c, 0x29ad: 0x000c, 0x29ae: 0x000c, 0x29af: 0x000c, - 0x29b0: 0x000c, 0x29b1: 0x000c, 0x29b2: 0x000c, 0x29b3: 0x000c, 0x29b4: 0x000c, - // Block 0xa7, offset 0x29c0 - 0x29f3: 0x000c, - // Block 0xa8, offset 0x2a00 - 0x2a00: 0x000c, 0x2a01: 0x000c, - 0x2a36: 0x000c, 0x2a37: 0x000c, 0x2a38: 0x000c, 0x2a39: 0x000c, 0x2a3a: 0x000c, 0x2a3b: 0x000c, - 0x2a3c: 0x000c, 0x2a3d: 0x000c, 0x2a3e: 0x000c, - // Block 0xa9, offset 0x2a40 - 0x2a4a: 0x000c, 0x2a4b: 0x000c, - 0x2a4c: 0x000c, - // Block 0xaa, offset 0x2a80 - 0x2aaf: 0x000c, - 0x2ab0: 0x000c, 0x2ab1: 0x000c, 0x2ab4: 0x000c, - 0x2ab6: 0x000c, 0x2ab7: 0x000c, - 0x2abe: 0x000c, - // Block 0xab, offset 0x2ac0 - 0x2adf: 0x000c, 0x2ae3: 0x000c, - 0x2ae4: 0x000c, 0x2ae5: 0x000c, 0x2ae6: 0x000c, 0x2ae7: 0x000c, 0x2ae8: 0x000c, 0x2ae9: 0x000c, - 0x2aea: 0x000c, - // Block 0xac, offset 0x2b00 - 0x2b00: 0x000c, 0x2b01: 0x000c, - 0x2b3c: 0x000c, - // Block 0xad, offset 0x2b40 - 0x2b40: 0x000c, - 0x2b66: 0x000c, 0x2b67: 0x000c, 0x2b68: 0x000c, 0x2b69: 0x000c, - 0x2b6a: 0x000c, 0x2b6b: 0x000c, 0x2b6c: 0x000c, - 0x2b70: 0x000c, 0x2b71: 0x000c, 0x2b72: 0x000c, 0x2b73: 0x000c, 0x2b74: 0x000c, - // Block 0xae, offset 0x2b80 - 0x2bb8: 0x000c, 0x2bb9: 0x000c, 0x2bba: 0x000c, 0x2bbb: 0x000c, - 0x2bbc: 0x000c, 0x2bbd: 0x000c, 0x2bbe: 0x000c, 0x2bbf: 0x000c, - // Block 0xaf, offset 0x2bc0 - 0x2bc2: 0x000c, 0x2bc3: 0x000c, 0x2bc4: 0x000c, - 0x2bc6: 0x000c, - // Block 0xb0, offset 0x2c00 - 0x2c33: 0x000c, 0x2c34: 0x000c, 0x2c35: 0x000c, - 0x2c36: 0x000c, 0x2c37: 0x000c, 0x2c38: 0x000c, 0x2c3a: 0x000c, - 0x2c3f: 0x000c, - // Block 0xb1, offset 0x2c40 - 0x2c40: 0x000c, 0x2c42: 0x000c, 0x2c43: 0x000c, - // Block 0xb2, offset 0x2c80 - 0x2cb2: 0x000c, 0x2cb3: 0x000c, 0x2cb4: 0x000c, 0x2cb5: 0x000c, - 0x2cbc: 0x000c, 0x2cbd: 0x000c, 0x2cbf: 0x000c, - // Block 0xb3, offset 0x2cc0 - 0x2cc0: 0x000c, - 0x2cdc: 0x000c, 0x2cdd: 0x000c, - // Block 0xb4, offset 0x2d00 - 0x2d33: 0x000c, 0x2d34: 0x000c, 0x2d35: 0x000c, - 0x2d36: 0x000c, 0x2d37: 0x000c, 0x2d38: 0x000c, 0x2d39: 0x000c, 0x2d3a: 0x000c, - 0x2d3d: 0x000c, 0x2d3f: 0x000c, - // Block 0xb5, offset 0x2d40 - 0x2d40: 0x000c, - 0x2d60: 0x000a, 0x2d61: 0x000a, 0x2d62: 0x000a, 0x2d63: 0x000a, - 0x2d64: 0x000a, 0x2d65: 0x000a, 0x2d66: 0x000a, 0x2d67: 0x000a, 0x2d68: 0x000a, 0x2d69: 0x000a, - 0x2d6a: 0x000a, 0x2d6b: 0x000a, 0x2d6c: 0x000a, - // Block 0xb6, offset 0x2d80 - 0x2dab: 0x000c, 0x2dad: 0x000c, - 0x2db0: 0x000c, 0x2db1: 0x000c, 0x2db2: 0x000c, 0x2db3: 0x000c, 0x2db4: 0x000c, 0x2db5: 0x000c, - 0x2db7: 0x000c, - // Block 0xb7, offset 0x2dc0 - 0x2ddd: 0x000c, - 0x2dde: 0x000c, 0x2ddf: 0x000c, 0x2de2: 0x000c, 0x2de3: 0x000c, - 0x2de4: 0x000c, 0x2de5: 0x000c, 0x2de7: 0x000c, 0x2de8: 0x000c, 0x2de9: 0x000c, - 0x2dea: 0x000c, 0x2deb: 0x000c, - // Block 0xb8, offset 0x2e00 - 0x2e30: 0x000c, 0x2e31: 0x000c, 0x2e32: 0x000c, 0x2e33: 0x000c, 0x2e34: 0x000c, 0x2e35: 0x000c, - 0x2e36: 0x000c, 0x2e38: 0x000c, 0x2e39: 0x000c, 0x2e3a: 0x000c, 0x2e3b: 0x000c, - 0x2e3c: 0x000c, 0x2e3d: 0x000c, - // Block 0xb9, offset 0x2e40 - 0x2e52: 0x000c, 0x2e53: 0x000c, 0x2e54: 0x000c, 0x2e55: 0x000c, 0x2e56: 0x000c, 0x2e57: 0x000c, - 0x2e58: 0x000c, 0x2e59: 0x000c, 0x2e5a: 0x000c, 0x2e5b: 0x000c, 0x2e5c: 0x000c, 0x2e5d: 0x000c, - 0x2e5e: 0x000c, 0x2e5f: 0x000c, 0x2e60: 0x000c, 0x2e61: 0x000c, 0x2e62: 0x000c, 0x2e63: 0x000c, - 0x2e64: 0x000c, 0x2e65: 0x000c, 0x2e66: 0x000c, 0x2e67: 0x000c, - 0x2e6a: 0x000c, 0x2e6b: 0x000c, 0x2e6c: 0x000c, 0x2e6d: 0x000c, 0x2e6e: 0x000c, 0x2e6f: 0x000c, - 0x2e70: 0x000c, 0x2e72: 0x000c, 0x2e73: 0x000c, 0x2e75: 0x000c, - 0x2e76: 0x000c, - // Block 0xba, offset 0x2e80 - 0x2eb0: 0x000c, 0x2eb1: 0x000c, 0x2eb2: 0x000c, 0x2eb3: 0x000c, 0x2eb4: 0x000c, - // Block 0xbb, offset 0x2ec0 - 0x2ef0: 0x000c, 0x2ef1: 0x000c, 0x2ef2: 0x000c, 0x2ef3: 0x000c, 0x2ef4: 0x000c, 0x2ef5: 0x000c, - 0x2ef6: 0x000c, - // Block 0xbc, offset 0x2f00 - 0x2f0f: 0x000c, 0x2f10: 0x000c, 0x2f11: 0x000c, - 0x2f12: 0x000c, - // Block 0xbd, offset 0x2f40 - 0x2f5d: 0x000c, - 0x2f5e: 0x000c, 0x2f60: 0x000b, 0x2f61: 0x000b, 0x2f62: 0x000b, 0x2f63: 0x000b, - // Block 0xbe, offset 0x2f80 - 0x2fa7: 0x000c, 0x2fa8: 0x000c, 0x2fa9: 0x000c, - 0x2fb3: 0x000b, 0x2fb4: 0x000b, 0x2fb5: 0x000b, - 0x2fb6: 0x000b, 0x2fb7: 0x000b, 0x2fb8: 0x000b, 0x2fb9: 0x000b, 0x2fba: 0x000b, 0x2fbb: 0x000c, - 0x2fbc: 0x000c, 0x2fbd: 0x000c, 0x2fbe: 0x000c, 0x2fbf: 0x000c, - // Block 0xbf, offset 0x2fc0 - 0x2fc0: 0x000c, 0x2fc1: 0x000c, 0x2fc2: 0x000c, 0x2fc5: 0x000c, - 0x2fc6: 0x000c, 0x2fc7: 0x000c, 0x2fc8: 0x000c, 0x2fc9: 0x000c, 0x2fca: 0x000c, 0x2fcb: 0x000c, - 0x2fea: 0x000c, 0x2feb: 0x000c, 0x2fec: 0x000c, 0x2fed: 0x000c, - // Block 0xc0, offset 0x3000 - 0x3000: 0x000a, 0x3001: 0x000a, 0x3002: 0x000c, 0x3003: 0x000c, 0x3004: 0x000c, 0x3005: 0x000a, - // Block 0xc1, offset 0x3040 - 0x3040: 0x000a, 0x3041: 0x000a, 0x3042: 0x000a, 0x3043: 0x000a, 0x3044: 0x000a, 0x3045: 0x000a, - 0x3046: 0x000a, 0x3047: 0x000a, 0x3048: 0x000a, 0x3049: 0x000a, 0x304a: 0x000a, 0x304b: 0x000a, - 0x304c: 0x000a, 0x304d: 0x000a, 0x304e: 0x000a, 0x304f: 0x000a, 0x3050: 0x000a, 0x3051: 0x000a, - 0x3052: 0x000a, 0x3053: 0x000a, 0x3054: 0x000a, 0x3055: 0x000a, 0x3056: 0x000a, - // Block 0xc2, offset 0x3080 - 0x309b: 0x000a, - // Block 0xc3, offset 0x30c0 - 0x30d5: 0x000a, - // Block 0xc4, offset 0x3100 - 0x310f: 0x000a, - // Block 0xc5, offset 0x3140 - 0x3149: 0x000a, - // Block 0xc6, offset 0x3180 - 0x3183: 0x000a, - 0x318e: 0x0002, 0x318f: 0x0002, 0x3190: 0x0002, 0x3191: 0x0002, - 0x3192: 0x0002, 0x3193: 0x0002, 0x3194: 0x0002, 0x3195: 0x0002, 0x3196: 0x0002, 0x3197: 0x0002, - 0x3198: 0x0002, 0x3199: 0x0002, 0x319a: 0x0002, 0x319b: 0x0002, 0x319c: 0x0002, 0x319d: 0x0002, - 0x319e: 0x0002, 0x319f: 0x0002, 0x31a0: 0x0002, 0x31a1: 0x0002, 0x31a2: 0x0002, 0x31a3: 0x0002, - 0x31a4: 0x0002, 0x31a5: 0x0002, 0x31a6: 0x0002, 0x31a7: 0x0002, 0x31a8: 0x0002, 0x31a9: 0x0002, - 0x31aa: 0x0002, 0x31ab: 0x0002, 0x31ac: 0x0002, 0x31ad: 0x0002, 0x31ae: 0x0002, 0x31af: 0x0002, - 0x31b0: 0x0002, 0x31b1: 0x0002, 0x31b2: 0x0002, 0x31b3: 0x0002, 0x31b4: 0x0002, 0x31b5: 0x0002, - 0x31b6: 0x0002, 0x31b7: 0x0002, 0x31b8: 0x0002, 0x31b9: 0x0002, 0x31ba: 0x0002, 0x31bb: 0x0002, - 0x31bc: 0x0002, 0x31bd: 0x0002, 0x31be: 0x0002, 0x31bf: 0x0002, - // Block 0xc7, offset 0x31c0 - 0x31c0: 0x000c, 0x31c1: 0x000c, 0x31c2: 0x000c, 0x31c3: 0x000c, 0x31c4: 0x000c, 0x31c5: 0x000c, - 0x31c6: 0x000c, 0x31c7: 0x000c, 0x31c8: 0x000c, 0x31c9: 0x000c, 0x31ca: 0x000c, 0x31cb: 0x000c, - 0x31cc: 0x000c, 0x31cd: 0x000c, 0x31ce: 0x000c, 0x31cf: 0x000c, 0x31d0: 0x000c, 0x31d1: 0x000c, - 0x31d2: 0x000c, 0x31d3: 0x000c, 0x31d4: 0x000c, 0x31d5: 0x000c, 0x31d6: 0x000c, 0x31d7: 0x000c, - 0x31d8: 0x000c, 0x31d9: 0x000c, 0x31da: 0x000c, 0x31db: 0x000c, 0x31dc: 0x000c, 0x31dd: 0x000c, - 0x31de: 0x000c, 0x31df: 0x000c, 0x31e0: 0x000c, 0x31e1: 0x000c, 0x31e2: 0x000c, 0x31e3: 0x000c, - 0x31e4: 0x000c, 0x31e5: 0x000c, 0x31e6: 0x000c, 0x31e7: 0x000c, 0x31e8: 0x000c, 0x31e9: 0x000c, - 0x31ea: 0x000c, 0x31eb: 0x000c, 0x31ec: 0x000c, 0x31ed: 0x000c, 0x31ee: 0x000c, 0x31ef: 0x000c, - 0x31f0: 0x000c, 0x31f1: 0x000c, 0x31f2: 0x000c, 0x31f3: 0x000c, 0x31f4: 0x000c, 0x31f5: 0x000c, - 0x31f6: 0x000c, 0x31fb: 0x000c, - 0x31fc: 0x000c, 0x31fd: 0x000c, 0x31fe: 0x000c, 0x31ff: 0x000c, - // Block 0xc8, offset 0x3200 - 0x3200: 0x000c, 0x3201: 0x000c, 0x3202: 0x000c, 0x3203: 0x000c, 0x3204: 0x000c, 0x3205: 0x000c, - 0x3206: 0x000c, 0x3207: 0x000c, 0x3208: 0x000c, 0x3209: 0x000c, 0x320a: 0x000c, 0x320b: 0x000c, - 0x320c: 0x000c, 0x320d: 0x000c, 0x320e: 0x000c, 0x320f: 0x000c, 0x3210: 0x000c, 0x3211: 0x000c, - 0x3212: 0x000c, 0x3213: 0x000c, 0x3214: 0x000c, 0x3215: 0x000c, 0x3216: 0x000c, 0x3217: 0x000c, - 0x3218: 0x000c, 0x3219: 0x000c, 0x321a: 0x000c, 0x321b: 0x000c, 0x321c: 0x000c, 0x321d: 0x000c, - 0x321e: 0x000c, 0x321f: 0x000c, 0x3220: 0x000c, 0x3221: 0x000c, 0x3222: 0x000c, 0x3223: 0x000c, - 0x3224: 0x000c, 0x3225: 0x000c, 0x3226: 0x000c, 0x3227: 0x000c, 0x3228: 0x000c, 0x3229: 0x000c, - 0x322a: 0x000c, 0x322b: 0x000c, 0x322c: 0x000c, - 0x3235: 0x000c, - // Block 0xc9, offset 0x3240 - 0x3244: 0x000c, - 0x325b: 0x000c, 0x325c: 0x000c, 0x325d: 0x000c, - 0x325e: 0x000c, 0x325f: 0x000c, 0x3261: 0x000c, 0x3262: 0x000c, 0x3263: 0x000c, - 0x3264: 0x000c, 0x3265: 0x000c, 0x3266: 0x000c, 0x3267: 0x000c, 0x3268: 0x000c, 0x3269: 0x000c, - 0x326a: 0x000c, 0x326b: 0x000c, 0x326c: 0x000c, 0x326d: 0x000c, 0x326e: 0x000c, 0x326f: 0x000c, - // Block 0xca, offset 0x3280 - 0x3280: 0x000c, 0x3281: 0x000c, 0x3282: 0x000c, 0x3283: 0x000c, 0x3284: 0x000c, 0x3285: 0x000c, - 0x3286: 0x000c, 0x3288: 0x000c, 0x3289: 0x000c, 0x328a: 0x000c, 0x328b: 0x000c, - 0x328c: 0x000c, 0x328d: 0x000c, 0x328e: 0x000c, 0x328f: 0x000c, 0x3290: 0x000c, 0x3291: 0x000c, - 0x3292: 0x000c, 0x3293: 0x000c, 0x3294: 0x000c, 0x3295: 0x000c, 0x3296: 0x000c, 0x3297: 0x000c, - 0x3298: 0x000c, 0x329b: 0x000c, 0x329c: 0x000c, 0x329d: 0x000c, - 0x329e: 0x000c, 0x329f: 0x000c, 0x32a0: 0x000c, 0x32a1: 0x000c, 0x32a3: 0x000c, - 0x32a4: 0x000c, 0x32a6: 0x000c, 0x32a7: 0x000c, 0x32a8: 0x000c, 0x32a9: 0x000c, - 0x32aa: 0x000c, - // Block 0xcb, offset 0x32c0 - 0x32c0: 0x0001, 0x32c1: 0x0001, 0x32c2: 0x0001, 0x32c3: 0x0001, 0x32c4: 0x0001, 0x32c5: 0x0001, - 0x32c6: 0x0001, 0x32c7: 0x0001, 0x32c8: 0x0001, 0x32c9: 0x0001, 0x32ca: 0x0001, 0x32cb: 0x0001, - 0x32cc: 0x0001, 0x32cd: 0x0001, 0x32ce: 0x0001, 0x32cf: 0x0001, 0x32d0: 0x000c, 0x32d1: 0x000c, - 0x32d2: 0x000c, 0x32d3: 0x000c, 0x32d4: 0x000c, 0x32d5: 0x000c, 0x32d6: 0x000c, 0x32d7: 0x0001, - 0x32d8: 0x0001, 0x32d9: 0x0001, 0x32da: 0x0001, 0x32db: 0x0001, 0x32dc: 0x0001, 0x32dd: 0x0001, - 0x32de: 0x0001, 0x32df: 0x0001, 0x32e0: 0x0001, 0x32e1: 0x0001, 0x32e2: 0x0001, 0x32e3: 0x0001, - 0x32e4: 0x0001, 0x32e5: 0x0001, 0x32e6: 0x0001, 0x32e7: 0x0001, 0x32e8: 0x0001, 0x32e9: 0x0001, - 0x32ea: 0x0001, 0x32eb: 0x0001, 0x32ec: 0x0001, 0x32ed: 0x0001, 0x32ee: 0x0001, 0x32ef: 0x0001, - 0x32f0: 0x0001, 0x32f1: 0x0001, 0x32f2: 0x0001, 0x32f3: 0x0001, 0x32f4: 0x0001, 0x32f5: 0x0001, - 0x32f6: 0x0001, 0x32f7: 0x0001, 0x32f8: 0x0001, 0x32f9: 0x0001, 0x32fa: 0x0001, 0x32fb: 0x0001, - 0x32fc: 0x0001, 0x32fd: 0x0001, 0x32fe: 0x0001, 0x32ff: 0x0001, - // Block 0xcc, offset 0x3300 - 0x3300: 0x0001, 0x3301: 0x0001, 0x3302: 0x0001, 0x3303: 0x0001, 0x3304: 0x000c, 0x3305: 0x000c, - 0x3306: 0x000c, 0x3307: 0x000c, 0x3308: 0x000c, 0x3309: 0x000c, 0x330a: 0x000c, 0x330b: 0x0001, - 0x330c: 0x0001, 0x330d: 0x0001, 0x330e: 0x0001, 0x330f: 0x0001, 0x3310: 0x0001, 0x3311: 0x0001, - 0x3312: 0x0001, 0x3313: 0x0001, 0x3314: 0x0001, 0x3315: 0x0001, 0x3316: 0x0001, 0x3317: 0x0001, - 0x3318: 0x0001, 0x3319: 0x0001, 0x331a: 0x0001, 0x331b: 0x0001, 0x331c: 0x0001, 0x331d: 0x0001, - 0x331e: 0x0001, 0x331f: 0x0001, 0x3320: 0x0001, 0x3321: 0x0001, 0x3322: 0x0001, 0x3323: 0x0001, - 0x3324: 0x0001, 0x3325: 0x0001, 0x3326: 0x0001, 0x3327: 0x0001, 0x3328: 0x0001, 0x3329: 0x0001, - 0x332a: 0x0001, 0x332b: 0x0001, 0x332c: 0x0001, 0x332d: 0x0001, 0x332e: 0x0001, 0x332f: 0x0001, - 0x3330: 0x0001, 0x3331: 0x0001, 0x3332: 0x0001, 0x3333: 0x0001, 0x3334: 0x0001, 0x3335: 0x0001, - 0x3336: 0x0001, 0x3337: 0x0001, 0x3338: 0x0001, 0x3339: 0x0001, 0x333a: 0x0001, 0x333b: 0x0001, - 0x333c: 0x0001, 0x333d: 0x0001, 0x333e: 0x0001, 0x333f: 0x0001, - // Block 0xcd, offset 0x3340 - 0x3340: 0x000d, 0x3341: 0x000d, 0x3342: 0x000d, 0x3343: 0x000d, 0x3344: 0x000d, 0x3345: 0x000d, - 0x3346: 0x000d, 0x3347: 0x000d, 0x3348: 0x000d, 0x3349: 0x000d, 0x334a: 0x000d, 0x334b: 0x000d, - 0x334c: 0x000d, 0x334d: 0x000d, 0x334e: 0x000d, 0x334f: 0x000d, 0x3350: 0x000d, 0x3351: 0x000d, - 0x3352: 0x000d, 0x3353: 0x000d, 0x3354: 0x000d, 0x3355: 0x000d, 0x3356: 0x000d, 0x3357: 0x000d, - 0x3358: 0x000d, 0x3359: 0x000d, 0x335a: 0x000d, 0x335b: 0x000d, 0x335c: 0x000d, 0x335d: 0x000d, - 0x335e: 0x000d, 0x335f: 0x000d, 0x3360: 0x000d, 0x3361: 0x000d, 0x3362: 0x000d, 0x3363: 0x000d, - 0x3364: 0x000d, 0x3365: 0x000d, 0x3366: 0x000d, 0x3367: 0x000d, 0x3368: 0x000d, 0x3369: 0x000d, - 0x336a: 0x000d, 0x336b: 0x000d, 0x336c: 0x000d, 0x336d: 0x000d, 0x336e: 0x000d, 0x336f: 0x000d, - 0x3370: 0x000a, 0x3371: 0x000a, 0x3372: 0x000d, 0x3373: 0x000d, 0x3374: 0x000d, 0x3375: 0x000d, - 0x3376: 0x000d, 0x3377: 0x000d, 0x3378: 0x000d, 0x3379: 0x000d, 0x337a: 0x000d, 0x337b: 0x000d, - 0x337c: 0x000d, 0x337d: 0x000d, 0x337e: 0x000d, 0x337f: 0x000d, - // Block 0xce, offset 0x3380 - 0x3380: 0x000a, 0x3381: 0x000a, 0x3382: 0x000a, 0x3383: 0x000a, 0x3384: 0x000a, 0x3385: 0x000a, - 0x3386: 0x000a, 0x3387: 0x000a, 0x3388: 0x000a, 0x3389: 0x000a, 0x338a: 0x000a, 0x338b: 0x000a, - 0x338c: 0x000a, 0x338d: 0x000a, 0x338e: 0x000a, 0x338f: 0x000a, 0x3390: 0x000a, 0x3391: 0x000a, - 0x3392: 0x000a, 0x3393: 0x000a, 0x3394: 0x000a, 0x3395: 0x000a, 0x3396: 0x000a, 0x3397: 0x000a, - 0x3398: 0x000a, 0x3399: 0x000a, 0x339a: 0x000a, 0x339b: 0x000a, 0x339c: 0x000a, 0x339d: 0x000a, - 0x339e: 0x000a, 0x339f: 0x000a, 0x33a0: 0x000a, 0x33a1: 0x000a, 0x33a2: 0x000a, 0x33a3: 0x000a, - 0x33a4: 0x000a, 0x33a5: 0x000a, 0x33a6: 0x000a, 0x33a7: 0x000a, 0x33a8: 0x000a, 0x33a9: 0x000a, - 0x33aa: 0x000a, 0x33ab: 0x000a, - 0x33b0: 0x000a, 0x33b1: 0x000a, 0x33b2: 0x000a, 0x33b3: 0x000a, 0x33b4: 0x000a, 0x33b5: 0x000a, - 0x33b6: 0x000a, 0x33b7: 0x000a, 0x33b8: 0x000a, 0x33b9: 0x000a, 0x33ba: 0x000a, 0x33bb: 0x000a, - 0x33bc: 0x000a, 0x33bd: 0x000a, 0x33be: 0x000a, 0x33bf: 0x000a, - // Block 0xcf, offset 0x33c0 - 0x33c0: 0x000a, 0x33c1: 0x000a, 0x33c2: 0x000a, 0x33c3: 0x000a, 0x33c4: 0x000a, 0x33c5: 0x000a, - 0x33c6: 0x000a, 0x33c7: 0x000a, 0x33c8: 0x000a, 0x33c9: 0x000a, 0x33ca: 0x000a, 0x33cb: 0x000a, - 0x33cc: 0x000a, 0x33cd: 0x000a, 0x33ce: 0x000a, 0x33cf: 0x000a, 0x33d0: 0x000a, 0x33d1: 0x000a, - 0x33d2: 0x000a, 0x33d3: 0x000a, - 0x33e0: 0x000a, 0x33e1: 0x000a, 0x33e2: 0x000a, 0x33e3: 0x000a, - 0x33e4: 0x000a, 0x33e5: 0x000a, 0x33e6: 0x000a, 0x33e7: 0x000a, 0x33e8: 0x000a, 0x33e9: 0x000a, - 0x33ea: 0x000a, 0x33eb: 0x000a, 0x33ec: 0x000a, 0x33ed: 0x000a, 0x33ee: 0x000a, - 0x33f1: 0x000a, 0x33f2: 0x000a, 0x33f3: 0x000a, 0x33f4: 0x000a, 0x33f5: 0x000a, - 0x33f6: 0x000a, 0x33f7: 0x000a, 0x33f8: 0x000a, 0x33f9: 0x000a, 0x33fa: 0x000a, 0x33fb: 0x000a, - 0x33fc: 0x000a, 0x33fd: 0x000a, 0x33fe: 0x000a, 0x33ff: 0x000a, - // Block 0xd0, offset 0x3400 - 0x3401: 0x000a, 0x3402: 0x000a, 0x3403: 0x000a, 0x3404: 0x000a, 0x3405: 0x000a, - 0x3406: 0x000a, 0x3407: 0x000a, 0x3408: 0x000a, 0x3409: 0x000a, 0x340a: 0x000a, 0x340b: 0x000a, - 0x340c: 0x000a, 0x340d: 0x000a, 0x340e: 0x000a, 0x340f: 0x000a, 0x3411: 0x000a, - 0x3412: 0x000a, 0x3413: 0x000a, 0x3414: 0x000a, 0x3415: 0x000a, 0x3416: 0x000a, 0x3417: 0x000a, - 0x3418: 0x000a, 0x3419: 0x000a, 0x341a: 0x000a, 0x341b: 0x000a, 0x341c: 0x000a, 0x341d: 0x000a, - 0x341e: 0x000a, 0x341f: 0x000a, 0x3420: 0x000a, 0x3421: 0x000a, 0x3422: 0x000a, 0x3423: 0x000a, - 0x3424: 0x000a, 0x3425: 0x000a, 0x3426: 0x000a, 0x3427: 0x000a, 0x3428: 0x000a, 0x3429: 0x000a, - 0x342a: 0x000a, 0x342b: 0x000a, 0x342c: 0x000a, 0x342d: 0x000a, 0x342e: 0x000a, 0x342f: 0x000a, - 0x3430: 0x000a, 0x3431: 0x000a, 0x3432: 0x000a, 0x3433: 0x000a, 0x3434: 0x000a, 0x3435: 0x000a, - // Block 0xd1, offset 0x3440 - 0x3440: 0x0002, 0x3441: 0x0002, 0x3442: 0x0002, 0x3443: 0x0002, 0x3444: 0x0002, 0x3445: 0x0002, - 0x3446: 0x0002, 0x3447: 0x0002, 0x3448: 0x0002, 0x3449: 0x0002, 0x344a: 0x0002, 0x344b: 0x000a, - 0x344c: 0x000a, - // Block 0xd2, offset 0x3480 - 0x34aa: 0x000a, 0x34ab: 0x000a, - // Block 0xd3, offset 0x34c0 - 0x34c0: 0x000a, 0x34c1: 0x000a, 0x34c2: 0x000a, 0x34c3: 0x000a, 0x34c4: 0x000a, 0x34c5: 0x000a, - 0x34c6: 0x000a, 0x34c7: 0x000a, 0x34c8: 0x000a, 0x34c9: 0x000a, 0x34ca: 0x000a, 0x34cb: 0x000a, - 0x34cc: 0x000a, 0x34cd: 0x000a, 0x34ce: 0x000a, 0x34cf: 0x000a, 0x34d0: 0x000a, 0x34d1: 0x000a, - 0x34d2: 0x000a, - 0x34e0: 0x000a, 0x34e1: 0x000a, 0x34e2: 0x000a, 0x34e3: 0x000a, - 0x34e4: 0x000a, 0x34e5: 0x000a, 0x34e6: 0x000a, 0x34e7: 0x000a, 0x34e8: 0x000a, 0x34e9: 0x000a, - 0x34ea: 0x000a, 0x34eb: 0x000a, 0x34ec: 0x000a, - 0x34f0: 0x000a, 0x34f1: 0x000a, 0x34f2: 0x000a, 0x34f3: 0x000a, 0x34f4: 0x000a, 0x34f5: 0x000a, - 0x34f6: 0x000a, - // Block 0xd4, offset 0x3500 - 0x3500: 0x000a, 0x3501: 0x000a, 0x3502: 0x000a, 0x3503: 0x000a, 0x3504: 0x000a, 0x3505: 0x000a, - 0x3506: 0x000a, 0x3507: 0x000a, 0x3508: 0x000a, 0x3509: 0x000a, 0x350a: 0x000a, 0x350b: 0x000a, - 0x350c: 0x000a, 0x350d: 0x000a, 0x350e: 0x000a, 0x350f: 0x000a, 0x3510: 0x000a, 0x3511: 0x000a, - 0x3512: 0x000a, 0x3513: 0x000a, 0x3514: 0x000a, - // Block 0xd5, offset 0x3540 - 0x3540: 0x000a, 0x3541: 0x000a, 0x3542: 0x000a, 0x3543: 0x000a, 0x3544: 0x000a, 0x3545: 0x000a, - 0x3546: 0x000a, 0x3547: 0x000a, 0x3548: 0x000a, 0x3549: 0x000a, 0x354a: 0x000a, 0x354b: 0x000a, - 0x3550: 0x000a, 0x3551: 0x000a, - 0x3552: 0x000a, 0x3553: 0x000a, 0x3554: 0x000a, 0x3555: 0x000a, 0x3556: 0x000a, 0x3557: 0x000a, - 0x3558: 0x000a, 0x3559: 0x000a, 0x355a: 0x000a, 0x355b: 0x000a, 0x355c: 0x000a, 0x355d: 0x000a, - 0x355e: 0x000a, 0x355f: 0x000a, 0x3560: 0x000a, 0x3561: 0x000a, 0x3562: 0x000a, 0x3563: 0x000a, - 0x3564: 0x000a, 0x3565: 0x000a, 0x3566: 0x000a, 0x3567: 0x000a, 0x3568: 0x000a, 0x3569: 0x000a, - 0x356a: 0x000a, 0x356b: 0x000a, 0x356c: 0x000a, 0x356d: 0x000a, 0x356e: 0x000a, 0x356f: 0x000a, - 0x3570: 0x000a, 0x3571: 0x000a, 0x3572: 0x000a, 0x3573: 0x000a, 0x3574: 0x000a, 0x3575: 0x000a, - 0x3576: 0x000a, 0x3577: 0x000a, 0x3578: 0x000a, 0x3579: 0x000a, 0x357a: 0x000a, 0x357b: 0x000a, - 0x357c: 0x000a, 0x357d: 0x000a, 0x357e: 0x000a, 0x357f: 0x000a, - // Block 0xd6, offset 0x3580 - 0x3580: 0x000a, 0x3581: 0x000a, 0x3582: 0x000a, 0x3583: 0x000a, 0x3584: 0x000a, 0x3585: 0x000a, - 0x3586: 0x000a, 0x3587: 0x000a, - 0x3590: 0x000a, 0x3591: 0x000a, - 0x3592: 0x000a, 0x3593: 0x000a, 0x3594: 0x000a, 0x3595: 0x000a, 0x3596: 0x000a, 0x3597: 0x000a, - 0x3598: 0x000a, 0x3599: 0x000a, - 0x35a0: 0x000a, 0x35a1: 0x000a, 0x35a2: 0x000a, 0x35a3: 0x000a, - 0x35a4: 0x000a, 0x35a5: 0x000a, 0x35a6: 0x000a, 0x35a7: 0x000a, 0x35a8: 0x000a, 0x35a9: 0x000a, - 0x35aa: 0x000a, 0x35ab: 0x000a, 0x35ac: 0x000a, 0x35ad: 0x000a, 0x35ae: 0x000a, 0x35af: 0x000a, - 0x35b0: 0x000a, 0x35b1: 0x000a, 0x35b2: 0x000a, 0x35b3: 0x000a, 0x35b4: 0x000a, 0x35b5: 0x000a, - 0x35b6: 0x000a, 0x35b7: 0x000a, 0x35b8: 0x000a, 0x35b9: 0x000a, 0x35ba: 0x000a, 0x35bb: 0x000a, - 0x35bc: 0x000a, 0x35bd: 0x000a, 0x35be: 0x000a, 0x35bf: 0x000a, - // Block 0xd7, offset 0x35c0 - 0x35c0: 0x000a, 0x35c1: 0x000a, 0x35c2: 0x000a, 0x35c3: 0x000a, 0x35c4: 0x000a, 0x35c5: 0x000a, - 0x35c6: 0x000a, 0x35c7: 0x000a, - 0x35d0: 0x000a, 0x35d1: 0x000a, - 0x35d2: 0x000a, 0x35d3: 0x000a, 0x35d4: 0x000a, 0x35d5: 0x000a, 0x35d6: 0x000a, 0x35d7: 0x000a, - 0x35d8: 0x000a, 0x35d9: 0x000a, 0x35da: 0x000a, 0x35db: 0x000a, 0x35dc: 0x000a, 0x35dd: 0x000a, - 0x35de: 0x000a, 0x35df: 0x000a, 0x35e0: 0x000a, 0x35e1: 0x000a, 0x35e2: 0x000a, 0x35e3: 0x000a, - 0x35e4: 0x000a, 0x35e5: 0x000a, 0x35e6: 0x000a, 0x35e7: 0x000a, 0x35e8: 0x000a, 0x35e9: 0x000a, - 0x35ea: 0x000a, 0x35eb: 0x000a, 0x35ec: 0x000a, 0x35ed: 0x000a, - // Block 0xd8, offset 0x3600 - 0x3610: 0x000a, 0x3611: 0x000a, - 0x3612: 0x000a, 0x3613: 0x000a, 0x3614: 0x000a, 0x3615: 0x000a, 0x3616: 0x000a, 0x3617: 0x000a, - 0x3618: 0x000a, 0x3619: 0x000a, 0x361a: 0x000a, 0x361b: 0x000a, 0x361c: 0x000a, 0x361d: 0x000a, - 0x361e: 0x000a, 0x3620: 0x000a, 0x3621: 0x000a, 0x3622: 0x000a, 0x3623: 0x000a, - 0x3624: 0x000a, 0x3625: 0x000a, 0x3626: 0x000a, 0x3627: 0x000a, - 0x3630: 0x000a, 0x3633: 0x000a, 0x3634: 0x000a, 0x3635: 0x000a, - 0x3636: 0x000a, 0x3637: 0x000a, 0x3638: 0x000a, 0x3639: 0x000a, 0x363a: 0x000a, 0x363b: 0x000a, - 0x363c: 0x000a, 0x363d: 0x000a, 0x363e: 0x000a, - // Block 0xd9, offset 0x3640 - 0x3640: 0x000a, 0x3641: 0x000a, 0x3642: 0x000a, 0x3643: 0x000a, 0x3644: 0x000a, 0x3645: 0x000a, - 0x3646: 0x000a, 0x3647: 0x000a, 0x3648: 0x000a, 0x3649: 0x000a, 0x364a: 0x000a, 0x364b: 0x000a, - 0x3650: 0x000a, 0x3651: 0x000a, - 0x3652: 0x000a, 0x3653: 0x000a, 0x3654: 0x000a, 0x3655: 0x000a, 0x3656: 0x000a, 0x3657: 0x000a, - 0x3658: 0x000a, 0x3659: 0x000a, 0x365a: 0x000a, 0x365b: 0x000a, 0x365c: 0x000a, 0x365d: 0x000a, - 0x365e: 0x000a, - // Block 0xda, offset 0x3680 - 0x3680: 0x000a, 0x3681: 0x000a, 0x3682: 0x000a, 0x3683: 0x000a, 0x3684: 0x000a, 0x3685: 0x000a, - 0x3686: 0x000a, 0x3687: 0x000a, 0x3688: 0x000a, 0x3689: 0x000a, 0x368a: 0x000a, 0x368b: 0x000a, - 0x368c: 0x000a, 0x368d: 0x000a, 0x368e: 0x000a, 0x368f: 0x000a, 0x3690: 0x000a, 0x3691: 0x000a, - // Block 0xdb, offset 0x36c0 - 0x36fe: 0x000b, 0x36ff: 0x000b, - // Block 0xdc, offset 0x3700 - 0x3700: 0x000b, 0x3701: 0x000b, 0x3702: 0x000b, 0x3703: 0x000b, 0x3704: 0x000b, 0x3705: 0x000b, - 0x3706: 0x000b, 0x3707: 0x000b, 0x3708: 0x000b, 0x3709: 0x000b, 0x370a: 0x000b, 0x370b: 0x000b, - 0x370c: 0x000b, 0x370d: 0x000b, 0x370e: 0x000b, 0x370f: 0x000b, 0x3710: 0x000b, 0x3711: 0x000b, - 0x3712: 0x000b, 0x3713: 0x000b, 0x3714: 0x000b, 0x3715: 0x000b, 0x3716: 0x000b, 0x3717: 0x000b, - 0x3718: 0x000b, 0x3719: 0x000b, 0x371a: 0x000b, 0x371b: 0x000b, 0x371c: 0x000b, 0x371d: 0x000b, - 0x371e: 0x000b, 0x371f: 0x000b, 0x3720: 0x000b, 0x3721: 0x000b, 0x3722: 0x000b, 0x3723: 0x000b, - 0x3724: 0x000b, 0x3725: 0x000b, 0x3726: 0x000b, 0x3727: 0x000b, 0x3728: 0x000b, 0x3729: 0x000b, - 0x372a: 0x000b, 0x372b: 0x000b, 0x372c: 0x000b, 0x372d: 0x000b, 0x372e: 0x000b, 0x372f: 0x000b, - 0x3730: 0x000b, 0x3731: 0x000b, 0x3732: 0x000b, 0x3733: 0x000b, 0x3734: 0x000b, 0x3735: 0x000b, - 0x3736: 0x000b, 0x3737: 0x000b, 0x3738: 0x000b, 0x3739: 0x000b, 0x373a: 0x000b, 0x373b: 0x000b, - 0x373c: 0x000b, 0x373d: 0x000b, 0x373e: 0x000b, 0x373f: 0x000b, - // Block 0xdd, offset 0x3740 - 0x3740: 0x000c, 0x3741: 0x000c, 0x3742: 0x000c, 0x3743: 0x000c, 0x3744: 0x000c, 0x3745: 0x000c, - 0x3746: 0x000c, 0x3747: 0x000c, 0x3748: 0x000c, 0x3749: 0x000c, 0x374a: 0x000c, 0x374b: 0x000c, - 0x374c: 0x000c, 0x374d: 0x000c, 0x374e: 0x000c, 0x374f: 0x000c, 0x3750: 0x000c, 0x3751: 0x000c, - 0x3752: 0x000c, 0x3753: 0x000c, 0x3754: 0x000c, 0x3755: 0x000c, 0x3756: 0x000c, 0x3757: 0x000c, - 0x3758: 0x000c, 0x3759: 0x000c, 0x375a: 0x000c, 0x375b: 0x000c, 0x375c: 0x000c, 0x375d: 0x000c, - 0x375e: 0x000c, 0x375f: 0x000c, 0x3760: 0x000c, 0x3761: 0x000c, 0x3762: 0x000c, 0x3763: 0x000c, - 0x3764: 0x000c, 0x3765: 0x000c, 0x3766: 0x000c, 0x3767: 0x000c, 0x3768: 0x000c, 0x3769: 0x000c, - 0x376a: 0x000c, 0x376b: 0x000c, 0x376c: 0x000c, 0x376d: 0x000c, 0x376e: 0x000c, 0x376f: 0x000c, - 0x3770: 0x000b, 0x3771: 0x000b, 0x3772: 0x000b, 0x3773: 0x000b, 0x3774: 0x000b, 0x3775: 0x000b, - 0x3776: 0x000b, 0x3777: 0x000b, 0x3778: 0x000b, 0x3779: 0x000b, 0x377a: 0x000b, 0x377b: 0x000b, - 0x377c: 0x000b, 0x377d: 0x000b, 0x377e: 0x000b, 0x377f: 0x000b, -} - -// bidiIndex: 24 blocks, 1536 entries, 1536 bytes -// Block 0 is the zero block. -var bidiIndex = [1536]uint8{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x01, 0xc3: 0x02, - 0xca: 0x03, 0xcb: 0x04, 0xcc: 0x05, 0xcd: 0x06, 0xce: 0x07, 0xcf: 0x08, - 0xd2: 0x09, 0xd6: 0x0a, 0xd7: 0x0b, - 0xd8: 0x0c, 0xd9: 0x0d, 0xda: 0x0e, 0xdb: 0x0f, 0xdc: 0x10, 0xdd: 0x11, 0xde: 0x12, 0xdf: 0x13, - 0xe0: 0x02, 0xe1: 0x03, 0xe2: 0x04, 0xe3: 0x05, 0xe4: 0x06, - 0xea: 0x07, 0xef: 0x08, - 0xf0: 0x11, 0xf1: 0x12, 0xf2: 0x12, 0xf3: 0x14, 0xf4: 0x15, - // Block 0x4, offset 0x100 - 0x120: 0x14, 0x121: 0x15, 0x122: 0x16, 0x123: 0x17, 0x124: 0x18, 0x125: 0x19, 0x126: 0x1a, 0x127: 0x1b, - 0x128: 0x1c, 0x129: 0x1d, 0x12a: 0x1c, 0x12b: 0x1e, 0x12c: 0x1f, 0x12d: 0x20, 0x12e: 0x21, 0x12f: 0x22, - 0x130: 0x23, 0x131: 0x24, 0x132: 0x1a, 0x133: 0x25, 0x134: 0x26, 0x135: 0x27, 0x137: 0x28, - 0x138: 0x29, 0x139: 0x2a, 0x13a: 0x2b, 0x13b: 0x2c, 0x13c: 0x2d, 0x13d: 0x2e, 0x13e: 0x2f, 0x13f: 0x30, - // Block 0x5, offset 0x140 - 0x140: 0x31, 0x141: 0x32, 0x142: 0x33, - 0x14d: 0x34, 0x14e: 0x35, - 0x150: 0x36, - 0x15a: 0x37, 0x15c: 0x38, 0x15d: 0x39, 0x15e: 0x3a, 0x15f: 0x3b, - 0x160: 0x3c, 0x162: 0x3d, 0x164: 0x3e, 0x165: 0x3f, 0x167: 0x40, - 0x168: 0x41, 0x169: 0x42, 0x16a: 0x43, 0x16c: 0x44, 0x16d: 0x45, 0x16e: 0x46, 0x16f: 0x47, - 0x170: 0x48, 0x173: 0x49, 0x177: 0x4a, - 0x17e: 0x4b, 0x17f: 0x4c, - // Block 0x6, offset 0x180 - 0x180: 0x4d, 0x181: 0x4e, 0x182: 0x4f, 0x183: 0x50, 0x184: 0x51, 0x185: 0x52, 0x186: 0x53, 0x187: 0x54, - 0x188: 0x55, 0x189: 0x54, 0x18a: 0x54, 0x18b: 0x54, 0x18c: 0x56, 0x18d: 0x57, 0x18e: 0x58, 0x18f: 0x59, - 0x190: 0x5a, 0x191: 0x5b, 0x192: 0x5c, 0x193: 0x5d, 0x194: 0x54, 0x195: 0x54, 0x196: 0x54, 0x197: 0x54, - 0x198: 0x54, 0x199: 0x54, 0x19a: 0x5e, 0x19b: 0x54, 0x19c: 0x54, 0x19d: 0x5f, 0x19e: 0x54, 0x19f: 0x60, - 0x1a4: 0x54, 0x1a5: 0x54, 0x1a6: 0x61, 0x1a7: 0x62, - 0x1a8: 0x54, 0x1a9: 0x54, 0x1aa: 0x54, 0x1ab: 0x54, 0x1ac: 0x54, 0x1ad: 0x63, 0x1ae: 0x64, 0x1af: 0x65, - 0x1b3: 0x66, 0x1b5: 0x67, 0x1b7: 0x68, - 0x1b8: 0x69, 0x1b9: 0x6a, 0x1ba: 0x6b, 0x1bb: 0x6c, 0x1bc: 0x54, 0x1bd: 0x54, 0x1be: 0x54, 0x1bf: 0x6d, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x6e, 0x1c2: 0x6f, 0x1c3: 0x70, 0x1c7: 0x71, - 0x1c8: 0x72, 0x1c9: 0x73, 0x1ca: 0x74, 0x1cb: 0x75, 0x1cd: 0x76, 0x1cf: 0x77, - // Block 0x8, offset 0x200 - 0x237: 0x54, - // Block 0x9, offset 0x240 - 0x252: 0x78, 0x253: 0x79, - 0x258: 0x7a, 0x259: 0x7b, 0x25a: 0x7c, 0x25b: 0x7d, 0x25c: 0x7e, 0x25e: 0x7f, - 0x260: 0x80, 0x261: 0x81, 0x263: 0x82, 0x264: 0x83, 0x265: 0x84, 0x266: 0x85, 0x267: 0x86, - 0x268: 0x87, 0x269: 0x88, 0x26a: 0x89, 0x26b: 0x8a, 0x26f: 0x8b, - // Block 0xa, offset 0x280 - 0x2ac: 0x8c, 0x2ad: 0x8d, 0x2ae: 0x0e, 0x2af: 0x0e, - 0x2b0: 0x0e, 0x2b1: 0x0e, 0x2b2: 0x0e, 0x2b3: 0x0e, 0x2b4: 0x8e, 0x2b5: 0x0e, 0x2b6: 0x0e, 0x2b7: 0x8f, - 0x2b8: 0x90, 0x2b9: 0x91, 0x2ba: 0x0e, 0x2bb: 0x92, 0x2bc: 0x93, 0x2bd: 0x94, 0x2bf: 0x95, - // Block 0xb, offset 0x2c0 - 0x2c4: 0x96, 0x2c5: 0x54, 0x2c6: 0x97, 0x2c7: 0x98, - 0x2cb: 0x99, 0x2cd: 0x9a, - 0x2e0: 0x9b, 0x2e1: 0x9b, 0x2e2: 0x9b, 0x2e3: 0x9b, 0x2e4: 0x9c, 0x2e5: 0x9b, 0x2e6: 0x9b, 0x2e7: 0x9b, - 0x2e8: 0x9d, 0x2e9: 0x9b, 0x2ea: 0x9b, 0x2eb: 0x9e, 0x2ec: 0x9f, 0x2ed: 0x9b, 0x2ee: 0x9b, 0x2ef: 0x9b, - 0x2f0: 0x9b, 0x2f1: 0x9b, 0x2f2: 0x9b, 0x2f3: 0x9b, 0x2f4: 0x9b, 0x2f5: 0x9b, 0x2f6: 0x9b, 0x2f7: 0x9b, - 0x2f8: 0x9b, 0x2f9: 0xa0, 0x2fa: 0x9b, 0x2fb: 0x9b, 0x2fc: 0x9b, 0x2fd: 0x9b, 0x2fe: 0x9b, 0x2ff: 0x9b, - // Block 0xc, offset 0x300 - 0x300: 0xa1, 0x301: 0xa2, 0x302: 0xa3, 0x304: 0xa4, 0x305: 0xa5, 0x306: 0xa6, 0x307: 0xa7, - 0x308: 0xa8, 0x30b: 0xa9, 0x30c: 0xaa, 0x30d: 0xab, - 0x310: 0xac, 0x311: 0xad, 0x312: 0xae, 0x313: 0xaf, 0x316: 0xb0, 0x317: 0xb1, - 0x318: 0xb2, 0x319: 0xb3, 0x31a: 0xb4, 0x31c: 0xb5, - 0x330: 0xb6, 0x332: 0xb7, - // Block 0xd, offset 0x340 - 0x36b: 0xb8, 0x36c: 0xb9, - 0x37e: 0xba, - // Block 0xe, offset 0x380 - 0x3b2: 0xbb, - // Block 0xf, offset 0x3c0 - 0x3c5: 0xbc, 0x3c6: 0xbd, - 0x3c8: 0x54, 0x3c9: 0xbe, 0x3cc: 0x54, 0x3cd: 0xbf, - 0x3db: 0xc0, 0x3dc: 0xc1, 0x3dd: 0xc2, 0x3de: 0xc3, 0x3df: 0xc4, - 0x3e8: 0xc5, 0x3e9: 0xc6, 0x3ea: 0xc7, - // Block 0x10, offset 0x400 - 0x400: 0xc8, - 0x420: 0x9b, 0x421: 0x9b, 0x422: 0x9b, 0x423: 0xc9, 0x424: 0x9b, 0x425: 0xca, 0x426: 0x9b, 0x427: 0x9b, - 0x428: 0x9b, 0x429: 0x9b, 0x42a: 0x9b, 0x42b: 0x9b, 0x42c: 0x9b, 0x42d: 0x9b, 0x42e: 0x9b, 0x42f: 0x9b, - 0x430: 0x9b, 0x431: 0x9b, 0x432: 0x9b, 0x433: 0x9b, 0x434: 0x9b, 0x435: 0x9b, 0x436: 0x9b, 0x437: 0x9b, - 0x438: 0x0e, 0x439: 0x0e, 0x43a: 0x0e, 0x43b: 0xcb, 0x43c: 0x9b, 0x43d: 0x9b, 0x43e: 0x9b, 0x43f: 0x9b, - // Block 0x11, offset 0x440 - 0x440: 0xcc, 0x441: 0x54, 0x442: 0xcd, 0x443: 0xce, 0x444: 0xcf, 0x445: 0xd0, - 0x44c: 0x54, 0x44d: 0x54, 0x44e: 0x54, 0x44f: 0x54, - 0x450: 0x54, 0x451: 0x54, 0x452: 0x54, 0x453: 0x54, 0x454: 0x54, 0x455: 0x54, 0x456: 0x54, 0x457: 0x54, - 0x458: 0x54, 0x459: 0x54, 0x45a: 0x54, 0x45b: 0xd1, 0x45c: 0x54, 0x45d: 0x6c, 0x45e: 0x54, 0x45f: 0xd2, - 0x460: 0xd3, 0x461: 0xd4, 0x462: 0xd5, 0x464: 0xd6, 0x465: 0xd7, 0x466: 0xd8, 0x467: 0x36, - 0x47f: 0xd9, - // Block 0x12, offset 0x480 - 0x4bf: 0xd9, - // Block 0x13, offset 0x4c0 - 0x4d0: 0x09, 0x4d1: 0x0a, 0x4d6: 0x0b, - 0x4db: 0x0c, 0x4dd: 0x0d, 0x4de: 0x0e, 0x4df: 0x0f, - 0x4ef: 0x10, - 0x4ff: 0x10, - // Block 0x14, offset 0x500 - 0x50f: 0x10, - 0x51f: 0x10, - 0x52f: 0x10, - 0x53f: 0x10, - // Block 0x15, offset 0x540 - 0x540: 0xda, 0x541: 0xda, 0x542: 0xda, 0x543: 0xda, 0x544: 0x05, 0x545: 0x05, 0x546: 0x05, 0x547: 0xdb, - 0x548: 0xda, 0x549: 0xda, 0x54a: 0xda, 0x54b: 0xda, 0x54c: 0xda, 0x54d: 0xda, 0x54e: 0xda, 0x54f: 0xda, - 0x550: 0xda, 0x551: 0xda, 0x552: 0xda, 0x553: 0xda, 0x554: 0xda, 0x555: 0xda, 0x556: 0xda, 0x557: 0xda, - 0x558: 0xda, 0x559: 0xda, 0x55a: 0xda, 0x55b: 0xda, 0x55c: 0xda, 0x55d: 0xda, 0x55e: 0xda, 0x55f: 0xda, - 0x560: 0xda, 0x561: 0xda, 0x562: 0xda, 0x563: 0xda, 0x564: 0xda, 0x565: 0xda, 0x566: 0xda, 0x567: 0xda, - 0x568: 0xda, 0x569: 0xda, 0x56a: 0xda, 0x56b: 0xda, 0x56c: 0xda, 0x56d: 0xda, 0x56e: 0xda, 0x56f: 0xda, - 0x570: 0xda, 0x571: 0xda, 0x572: 0xda, 0x573: 0xda, 0x574: 0xda, 0x575: 0xda, 0x576: 0xda, 0x577: 0xda, - 0x578: 0xda, 0x579: 0xda, 0x57a: 0xda, 0x57b: 0xda, 0x57c: 0xda, 0x57d: 0xda, 0x57e: 0xda, 0x57f: 0xda, - // Block 0x16, offset 0x580 - 0x58f: 0x10, - 0x59f: 0x10, - 0x5a0: 0x13, - 0x5af: 0x10, - 0x5bf: 0x10, - // Block 0x17, offset 0x5c0 - 0x5cf: 0x10, -} - -// Total table size 15800 bytes (15KiB); checksum: F50EF68C diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/trieval.go deleted file mode 100644 index bebd855..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/bidi/trieval.go +++ /dev/null @@ -1,60 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package bidi - -// Class is the Unicode BiDi class. Each rune has a single class. -type Class uint - -const ( - L Class = iota // LeftToRight - R // RightToLeft - EN // EuropeanNumber - ES // EuropeanSeparator - ET // EuropeanTerminator - AN // ArabicNumber - CS // CommonSeparator - B // ParagraphSeparator - S // SegmentSeparator - WS // WhiteSpace - ON // OtherNeutral - BN // BoundaryNeutral - NSM // NonspacingMark - AL // ArabicLetter - Control // Control LRO - PDI - - numClass - - LRO // LeftToRightOverride - RLO // RightToLeftOverride - LRE // LeftToRightEmbedding - RLE // RightToLeftEmbedding - PDF // PopDirectionalFormat - LRI // LeftToRightIsolate - RLI // RightToLeftIsolate - FSI // FirstStrongIsolate - PDI // PopDirectionalIsolate - - unknownClass = ^Class(0) -) - -var controlToClass = map[rune]Class{ - 0x202D: LRO, // LeftToRightOverride, - 0x202E: RLO, // RightToLeftOverride, - 0x202A: LRE, // LeftToRightEmbedding, - 0x202B: RLE, // RightToLeftEmbedding, - 0x202C: PDF, // PopDirectionalFormat, - 0x2066: LRI, // LeftToRightIsolate, - 0x2067: RLI, // RightToLeftIsolate, - 0x2068: FSI, // FirstStrongIsolate, - 0x2069: PDI, // PopDirectionalIsolate, -} - -// A trie entry has the following bits: -// 7..5 XOR mask for brackets -// 4 1: Bracket open, 0: Bracket close -// 3..0 Class type - -const ( - openMask = 0x10 - xorMaskShift = 5 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/composition.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/composition.go deleted file mode 100644 index d17b278..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/composition.go +++ /dev/null @@ -1,514 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -import "unicode/utf8" - -const ( - maxNonStarters = 30 - // The maximum number of characters needed for a buffer is - // maxNonStarters + 1 for the starter + 1 for the GCJ - maxBufferSize = maxNonStarters + 2 - maxNFCExpansion = 3 // NFC(0x1D160) - maxNFKCExpansion = 18 // NFKC(0xFDFA) - - maxByteBufferSize = utf8.UTFMax * maxBufferSize // 128 -) - -// ssState is used for reporting the segment state after inserting a rune. -// It is returned by streamSafe.next. -type ssState int - -const ( - // Indicates a rune was successfully added to the segment. - ssSuccess ssState = iota - // Indicates a rune starts a new segment and should not be added. - ssStarter - // Indicates a rune caused a segment overflow and a CGJ should be inserted. - ssOverflow -) - -// streamSafe implements the policy of when a CGJ should be inserted. -type streamSafe uint8 - -// mkStreamSafe is a shorthand for declaring a streamSafe var and calling -// first on it. -func mkStreamSafe(p Properties) streamSafe { - return streamSafe(p.nTrailingNonStarters()) -} - -// first inserts the first rune of a segment. -func (ss *streamSafe) first(p Properties) { - if *ss != 0 { - panic("!= 0") - } - *ss = streamSafe(p.nTrailingNonStarters()) -} - -// insert returns a ssState value to indicate whether a rune represented by p -// can be inserted. -func (ss *streamSafe) next(p Properties) ssState { - if *ss > maxNonStarters { - panic("streamSafe was not reset") - } - n := p.nLeadingNonStarters() - if *ss += streamSafe(n); *ss > maxNonStarters { - *ss = 0 - return ssOverflow - } - // The Stream-Safe Text Processing prescribes that the counting can stop - // as soon as a starter is encountered. However, there are some starters, - // like Jamo V and T, that can combine with other runes, leaving their - // successive non-starters appended to the previous, possibly causing an - // overflow. We will therefore consider any rune with a non-zero nLead to - // be a non-starter. Note that it always hold that if nLead > 0 then - // nLead == nTrail. - if n == 0 { - *ss = 0 - return ssStarter - } - return ssSuccess -} - -// backwards is used for checking for overflow and segment starts -// when traversing a string backwards. Users do not need to call first -// for the first rune. The state of the streamSafe retains the count of -// the non-starters loaded. -func (ss *streamSafe) backwards(p Properties) ssState { - if *ss > maxNonStarters { - panic("streamSafe was not reset") - } - c := *ss + streamSafe(p.nTrailingNonStarters()) - if c > maxNonStarters { - return ssOverflow - } - *ss = c - if p.nLeadingNonStarters() == 0 { - return ssStarter - } - return ssSuccess -} - -func (ss streamSafe) isMax() bool { - return ss == maxNonStarters -} - -// GraphemeJoiner is inserted after maxNonStarters non-starter runes. -const GraphemeJoiner = "\u034F" - -// reorderBuffer is used to normalize a single segment. Characters inserted with -// insert are decomposed and reordered based on CCC. The compose method can -// be used to recombine characters. Note that the byte buffer does not hold -// the UTF-8 characters in order. Only the rune array is maintained in sorted -// order. flush writes the resulting segment to a byte array. -type reorderBuffer struct { - rune [maxBufferSize]Properties // Per character info. - byte [maxByteBufferSize]byte // UTF-8 buffer. Referenced by runeInfo.pos. - nbyte uint8 // Number or bytes. - ss streamSafe // For limiting length of non-starter sequence. - nrune int // Number of runeInfos. - f formInfo - - src input - nsrc int - tmpBytes input - - out []byte - flushF func(*reorderBuffer) bool -} - -func (rb *reorderBuffer) init(f Form, src []byte) { - rb.f = *formTable[f] - rb.src.setBytes(src) - rb.nsrc = len(src) - rb.ss = 0 -} - -func (rb *reorderBuffer) initString(f Form, src string) { - rb.f = *formTable[f] - rb.src.setString(src) - rb.nsrc = len(src) - rb.ss = 0 -} - -func (rb *reorderBuffer) setFlusher(out []byte, f func(*reorderBuffer) bool) { - rb.out = out - rb.flushF = f -} - -// reset discards all characters from the buffer. -func (rb *reorderBuffer) reset() { - rb.nrune = 0 - rb.nbyte = 0 - rb.ss = 0 -} - -func (rb *reorderBuffer) doFlush() bool { - if rb.f.composing { - rb.compose() - } - res := rb.flushF(rb) - rb.reset() - return res -} - -// appendFlush appends the normalized segment to rb.out. -func appendFlush(rb *reorderBuffer) bool { - for i := 0; i < rb.nrune; i++ { - start := rb.rune[i].pos - end := start + rb.rune[i].size - rb.out = append(rb.out, rb.byte[start:end]...) - } - return true -} - -// flush appends the normalized segment to out and resets rb. -func (rb *reorderBuffer) flush(out []byte) []byte { - for i := 0; i < rb.nrune; i++ { - start := rb.rune[i].pos - end := start + rb.rune[i].size - out = append(out, rb.byte[start:end]...) - } - rb.reset() - return out -} - -// flushCopy copies the normalized segment to buf and resets rb. -// It returns the number of bytes written to buf. -func (rb *reorderBuffer) flushCopy(buf []byte) int { - p := 0 - for i := 0; i < rb.nrune; i++ { - runep := rb.rune[i] - p += copy(buf[p:], rb.byte[runep.pos:runep.pos+runep.size]) - } - rb.reset() - return p -} - -// insertOrdered inserts a rune in the buffer, ordered by Canonical Combining Class. -// It returns false if the buffer is not large enough to hold the rune. -// It is used internally by insert and insertString only. -func (rb *reorderBuffer) insertOrdered(info Properties) { - n := rb.nrune - b := rb.rune[:] - cc := info.ccc - if cc > 0 { - // Find insertion position + move elements to make room. - for ; n > 0; n-- { - if b[n-1].ccc <= cc { - break - } - b[n] = b[n-1] - } - } - rb.nrune += 1 - pos := uint8(rb.nbyte) - rb.nbyte += utf8.UTFMax - info.pos = pos - b[n] = info -} - -// insertErr is an error code returned by insert. Using this type instead -// of error improves performance up to 20% for many of the benchmarks. -type insertErr int - -const ( - iSuccess insertErr = -iota - iShortDst - iShortSrc -) - -// insertFlush inserts the given rune in the buffer ordered by CCC. -// If a decomposition with multiple segments are encountered, they leading -// ones are flushed. -// It returns a non-zero error code if the rune was not inserted. -func (rb *reorderBuffer) insertFlush(src input, i int, info Properties) insertErr { - if rune := src.hangul(i); rune != 0 { - rb.decomposeHangul(rune) - return iSuccess - } - if info.hasDecomposition() { - return rb.insertDecomposed(info.Decomposition()) - } - rb.insertSingle(src, i, info) - return iSuccess -} - -// insertUnsafe inserts the given rune in the buffer ordered by CCC. -// It is assumed there is sufficient space to hold the runes. It is the -// responsibility of the caller to ensure this. This can be done by checking -// the state returned by the streamSafe type. -func (rb *reorderBuffer) insertUnsafe(src input, i int, info Properties) { - if rune := src.hangul(i); rune != 0 { - rb.decomposeHangul(rune) - } - if info.hasDecomposition() { - // TODO: inline. - rb.insertDecomposed(info.Decomposition()) - } else { - rb.insertSingle(src, i, info) - } -} - -// insertDecomposed inserts an entry in to the reorderBuffer for each rune -// in dcomp. dcomp must be a sequence of decomposed UTF-8-encoded runes. -// It flushes the buffer on each new segment start. -func (rb *reorderBuffer) insertDecomposed(dcomp []byte) insertErr { - rb.tmpBytes.setBytes(dcomp) - for i := 0; i < len(dcomp); { - info := rb.f.info(rb.tmpBytes, i) - if info.BoundaryBefore() && rb.nrune > 0 && !rb.doFlush() { - return iShortDst - } - i += copy(rb.byte[rb.nbyte:], dcomp[i:i+int(info.size)]) - rb.insertOrdered(info) - } - return iSuccess -} - -// insertSingle inserts an entry in the reorderBuffer for the rune at -// position i. info is the runeInfo for the rune at position i. -func (rb *reorderBuffer) insertSingle(src input, i int, info Properties) { - src.copySlice(rb.byte[rb.nbyte:], i, i+int(info.size)) - rb.insertOrdered(info) -} - -// insertCGJ inserts a Combining Grapheme Joiner (0x034f) into rb. -func (rb *reorderBuffer) insertCGJ() { - rb.insertSingle(input{str: GraphemeJoiner}, 0, Properties{size: uint8(len(GraphemeJoiner))}) -} - -// appendRune inserts a rune at the end of the buffer. It is used for Hangul. -func (rb *reorderBuffer) appendRune(r rune) { - bn := rb.nbyte - sz := utf8.EncodeRune(rb.byte[bn:], rune(r)) - rb.nbyte += utf8.UTFMax - rb.rune[rb.nrune] = Properties{pos: bn, size: uint8(sz)} - rb.nrune++ -} - -// assignRune sets a rune at position pos. It is used for Hangul and recomposition. -func (rb *reorderBuffer) assignRune(pos int, r rune) { - bn := rb.rune[pos].pos - sz := utf8.EncodeRune(rb.byte[bn:], rune(r)) - rb.rune[pos] = Properties{pos: bn, size: uint8(sz)} -} - -// runeAt returns the rune at position n. It is used for Hangul and recomposition. -func (rb *reorderBuffer) runeAt(n int) rune { - inf := rb.rune[n] - r, _ := utf8.DecodeRune(rb.byte[inf.pos : inf.pos+inf.size]) - return r -} - -// bytesAt returns the UTF-8 encoding of the rune at position n. -// It is used for Hangul and recomposition. -func (rb *reorderBuffer) bytesAt(n int) []byte { - inf := rb.rune[n] - return rb.byte[inf.pos : int(inf.pos)+int(inf.size)] -} - -// For Hangul we combine algorithmically, instead of using tables. -const ( - hangulBase = 0xAC00 // UTF-8(hangulBase) -> EA B0 80 - hangulBase0 = 0xEA - hangulBase1 = 0xB0 - hangulBase2 = 0x80 - - hangulEnd = hangulBase + jamoLVTCount // UTF-8(0xD7A4) -> ED 9E A4 - hangulEnd0 = 0xED - hangulEnd1 = 0x9E - hangulEnd2 = 0xA4 - - jamoLBase = 0x1100 // UTF-8(jamoLBase) -> E1 84 00 - jamoLBase0 = 0xE1 - jamoLBase1 = 0x84 - jamoLEnd = 0x1113 - jamoVBase = 0x1161 - jamoVEnd = 0x1176 - jamoTBase = 0x11A7 - jamoTEnd = 0x11C3 - - jamoTCount = 28 - jamoVCount = 21 - jamoVTCount = 21 * 28 - jamoLVTCount = 19 * 21 * 28 -) - -const hangulUTF8Size = 3 - -func isHangul(b []byte) bool { - if len(b) < hangulUTF8Size { - return false - } - b0 := b[0] - if b0 < hangulBase0 { - return false - } - b1 := b[1] - switch { - case b0 == hangulBase0: - return b1 >= hangulBase1 - case b0 < hangulEnd0: - return true - case b0 > hangulEnd0: - return false - case b1 < hangulEnd1: - return true - } - return b1 == hangulEnd1 && b[2] < hangulEnd2 -} - -func isHangulString(b string) bool { - if len(b) < hangulUTF8Size { - return false - } - b0 := b[0] - if b0 < hangulBase0 { - return false - } - b1 := b[1] - switch { - case b0 == hangulBase0: - return b1 >= hangulBase1 - case b0 < hangulEnd0: - return true - case b0 > hangulEnd0: - return false - case b1 < hangulEnd1: - return true - } - return b1 == hangulEnd1 && b[2] < hangulEnd2 -} - -// Caller must ensure len(b) >= 2. -func isJamoVT(b []byte) bool { - // True if (rune & 0xff00) == jamoLBase - return b[0] == jamoLBase0 && (b[1]&0xFC) == jamoLBase1 -} - -func isHangulWithoutJamoT(b []byte) bool { - c, _ := utf8.DecodeRune(b) - c -= hangulBase - return c < jamoLVTCount && c%jamoTCount == 0 -} - -// decomposeHangul writes the decomposed Hangul to buf and returns the number -// of bytes written. len(buf) should be at least 9. -func decomposeHangul(buf []byte, r rune) int { - const JamoUTF8Len = 3 - r -= hangulBase - x := r % jamoTCount - r /= jamoTCount - utf8.EncodeRune(buf, jamoLBase+r/jamoVCount) - utf8.EncodeRune(buf[JamoUTF8Len:], jamoVBase+r%jamoVCount) - if x != 0 { - utf8.EncodeRune(buf[2*JamoUTF8Len:], jamoTBase+x) - return 3 * JamoUTF8Len - } - return 2 * JamoUTF8Len -} - -// decomposeHangul algorithmically decomposes a Hangul rune into -// its Jamo components. -// See http://unicode.org/reports/tr15/#Hangul for details on decomposing Hangul. -func (rb *reorderBuffer) decomposeHangul(r rune) { - r -= hangulBase - x := r % jamoTCount - r /= jamoTCount - rb.appendRune(jamoLBase + r/jamoVCount) - rb.appendRune(jamoVBase + r%jamoVCount) - if x != 0 { - rb.appendRune(jamoTBase + x) - } -} - -// combineHangul algorithmically combines Jamo character components into Hangul. -// See http://unicode.org/reports/tr15/#Hangul for details on combining Hangul. -func (rb *reorderBuffer) combineHangul(s, i, k int) { - b := rb.rune[:] - bn := rb.nrune - for ; i < bn; i++ { - cccB := b[k-1].ccc - cccC := b[i].ccc - if cccB == 0 { - s = k - 1 - } - if s != k-1 && cccB >= cccC { - // b[i] is blocked by greater-equal cccX below it - b[k] = b[i] - k++ - } else { - l := rb.runeAt(s) // also used to compare to hangulBase - v := rb.runeAt(i) // also used to compare to jamoT - switch { - case jamoLBase <= l && l < jamoLEnd && - jamoVBase <= v && v < jamoVEnd: - // 11xx plus 116x to LV - rb.assignRune(s, hangulBase+ - (l-jamoLBase)*jamoVTCount+(v-jamoVBase)*jamoTCount) - case hangulBase <= l && l < hangulEnd && - jamoTBase < v && v < jamoTEnd && - ((l-hangulBase)%jamoTCount) == 0: - // ACxx plus 11Ax to LVT - rb.assignRune(s, l+v-jamoTBase) - default: - b[k] = b[i] - k++ - } - } - } - rb.nrune = k -} - -// compose recombines the runes in the buffer. -// It should only be used to recompose a single segment, as it will not -// handle alternations between Hangul and non-Hangul characters correctly. -func (rb *reorderBuffer) compose() { - // UAX #15, section X5 , including Corrigendum #5 - // "In any character sequence beginning with starter S, a character C is - // blocked from S if and only if there is some character B between S - // and C, and either B is a starter or it has the same or higher - // combining class as C." - bn := rb.nrune - if bn == 0 { - return - } - k := 1 - b := rb.rune[:] - for s, i := 0, 1; i < bn; i++ { - if isJamoVT(rb.bytesAt(i)) { - // Redo from start in Hangul mode. Necessary to support - // U+320E..U+321E in NFKC mode. - rb.combineHangul(s, i, k) - return - } - ii := b[i] - // We can only use combineForward as a filter if we later - // get the info for the combined character. This is more - // expensive than using the filter. Using combinesBackward() - // is safe. - if ii.combinesBackward() { - cccB := b[k-1].ccc - cccC := ii.ccc - blocked := false // b[i] blocked by starter or greater or equal CCC? - if cccB == 0 { - s = k - 1 - } else { - blocked = s != k-1 && cccB >= cccC - } - if !blocked { - combined := combine(rb.runeAt(s), rb.runeAt(i)) - if combined != 0 { - rb.assignRune(s, combined) - continue - } - } - } - b[k] = b[i] - k++ - } - rb.nrune = k -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/forminfo.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/forminfo.go deleted file mode 100644 index 15a67c6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/forminfo.go +++ /dev/null @@ -1,256 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -// This file contains Form-specific logic and wrappers for data in tables.go. - -// Rune info is stored in a separate trie per composing form. A composing form -// and its corresponding decomposing form share the same trie. Each trie maps -// a rune to a uint16. The values take two forms. For v >= 0x8000: -// bits -// 15: 1 (inverse of NFD_QD bit of qcInfo) -// 13..7: qcInfo (see below). isYesD is always true (no decompostion). -// 6..0: ccc (compressed CCC value). -// For v < 0x8000, the respective rune has a decomposition and v is an index -// into a byte array of UTF-8 decomposition sequences and additional info and -// has the form: -// <header> <decomp_byte>* [<tccc> [<lccc>]] -// The header contains the number of bytes in the decomposition (excluding this -// length byte). The two most significant bits of this length byte correspond -// to bit 5 and 4 of qcInfo (see below). The byte sequence itself starts at v+1. -// The byte sequence is followed by a trailing and leading CCC if the values -// for these are not zero. The value of v determines which ccc are appended -// to the sequences. For v < firstCCC, there are none, for v >= firstCCC, -// the sequence is followed by a trailing ccc, and for v >= firstLeadingCC -// there is an additional leading ccc. The value of tccc itself is the -// trailing CCC shifted left 2 bits. The two least-significant bits of tccc -// are the number of trailing non-starters. - -const ( - qcInfoMask = 0x3F // to clear all but the relevant bits in a qcInfo - headerLenMask = 0x3F // extract the length value from the header byte - headerFlagsMask = 0xC0 // extract the qcInfo bits from the header byte -) - -// Properties provides access to normalization properties of a rune. -type Properties struct { - pos uint8 // start position in reorderBuffer; used in composition.go - size uint8 // length of UTF-8 encoding of this rune - ccc uint8 // leading canonical combining class (ccc if not decomposition) - tccc uint8 // trailing canonical combining class (ccc if not decomposition) - nLead uint8 // number of leading non-starters. - flags qcInfo // quick check flags - index uint16 -} - -// functions dispatchable per form -type lookupFunc func(b input, i int) Properties - -// formInfo holds Form-specific functions and tables. -type formInfo struct { - form Form - composing, compatibility bool // form type - info lookupFunc - nextMain iterFunc -} - -var formTable []*formInfo - -func init() { - formTable = make([]*formInfo, 4) - - for i := range formTable { - f := &formInfo{} - formTable[i] = f - f.form = Form(i) - if Form(i) == NFKD || Form(i) == NFKC { - f.compatibility = true - f.info = lookupInfoNFKC - } else { - f.info = lookupInfoNFC - } - f.nextMain = nextDecomposed - if Form(i) == NFC || Form(i) == NFKC { - f.nextMain = nextComposed - f.composing = true - } - } -} - -// We do not distinguish between boundaries for NFC, NFD, etc. to avoid -// unexpected behavior for the user. For example, in NFD, there is a boundary -// after 'a'. However, 'a' might combine with modifiers, so from the application's -// perspective it is not a good boundary. We will therefore always use the -// boundaries for the combining variants. - -// BoundaryBefore returns true if this rune starts a new segment and -// cannot combine with any rune on the left. -func (p Properties) BoundaryBefore() bool { - if p.ccc == 0 && !p.combinesBackward() { - return true - } - // We assume that the CCC of the first character in a decomposition - // is always non-zero if different from info.ccc and that we can return - // false at this point. This is verified by maketables. - return false -} - -// BoundaryAfter returns true if runes cannot combine with or otherwise -// interact with this or previous runes. -func (p Properties) BoundaryAfter() bool { - // TODO: loosen these conditions. - return p.isInert() -} - -// We pack quick check data in 4 bits: -// 5: Combines forward (0 == false, 1 == true) -// 4..3: NFC_QC Yes(00), No (10), or Maybe (11) -// 2: NFD_QC Yes (0) or No (1). No also means there is a decomposition. -// 1..0: Number of trailing non-starters. -// -// When all 4 bits are zero, the character is inert, meaning it is never -// influenced by normalization. -type qcInfo uint8 - -func (p Properties) isYesC() bool { return p.flags&0x10 == 0 } -func (p Properties) isYesD() bool { return p.flags&0x4 == 0 } - -func (p Properties) combinesForward() bool { return p.flags&0x20 != 0 } -func (p Properties) combinesBackward() bool { return p.flags&0x8 != 0 } // == isMaybe -func (p Properties) hasDecomposition() bool { return p.flags&0x4 != 0 } // == isNoD - -func (p Properties) isInert() bool { - return p.flags&qcInfoMask == 0 && p.ccc == 0 -} - -func (p Properties) multiSegment() bool { - return p.index >= firstMulti && p.index < endMulti -} - -func (p Properties) nLeadingNonStarters() uint8 { - return p.nLead -} - -func (p Properties) nTrailingNonStarters() uint8 { - return uint8(p.flags & 0x03) -} - -// Decomposition returns the decomposition for the underlying rune -// or nil if there is none. -func (p Properties) Decomposition() []byte { - // TODO: create the decomposition for Hangul? - if p.index == 0 { - return nil - } - i := p.index - n := decomps[i] & headerLenMask - i++ - return decomps[i : i+uint16(n)] -} - -// Size returns the length of UTF-8 encoding of the rune. -func (p Properties) Size() int { - return int(p.size) -} - -// CCC returns the canonical combining class of the underlying rune. -func (p Properties) CCC() uint8 { - if p.index >= firstCCCZeroExcept { - return 0 - } - return ccc[p.ccc] -} - -// LeadCCC returns the CCC of the first rune in the decomposition. -// If there is no decomposition, LeadCCC equals CCC. -func (p Properties) LeadCCC() uint8 { - return ccc[p.ccc] -} - -// TrailCCC returns the CCC of the last rune in the decomposition. -// If there is no decomposition, TrailCCC equals CCC. -func (p Properties) TrailCCC() uint8 { - return ccc[p.tccc] -} - -// Recomposition -// We use 32-bit keys instead of 64-bit for the two codepoint keys. -// This clips off the bits of three entries, but we know this will not -// result in a collision. In the unlikely event that changes to -// UnicodeData.txt introduce collisions, the compiler will catch it. -// Note that the recomposition map for NFC and NFKC are identical. - -// combine returns the combined rune or 0 if it doesn't exist. -func combine(a, b rune) rune { - key := uint32(uint16(a))<<16 + uint32(uint16(b)) - return recompMap[key] -} - -func lookupInfoNFC(b input, i int) Properties { - v, sz := b.charinfoNFC(i) - return compInfo(v, sz) -} - -func lookupInfoNFKC(b input, i int) Properties { - v, sz := b.charinfoNFKC(i) - return compInfo(v, sz) -} - -// Properties returns properties for the first rune in s. -func (f Form) Properties(s []byte) Properties { - if f == NFC || f == NFD { - return compInfo(nfcData.lookup(s)) - } - return compInfo(nfkcData.lookup(s)) -} - -// PropertiesString returns properties for the first rune in s. -func (f Form) PropertiesString(s string) Properties { - if f == NFC || f == NFD { - return compInfo(nfcData.lookupString(s)) - } - return compInfo(nfkcData.lookupString(s)) -} - -// compInfo converts the information contained in v and sz -// to a Properties. See the comment at the top of the file -// for more information on the format. -func compInfo(v uint16, sz int) Properties { - if v == 0 { - return Properties{size: uint8(sz)} - } else if v >= 0x8000 { - p := Properties{ - size: uint8(sz), - ccc: uint8(v), - tccc: uint8(v), - flags: qcInfo(v >> 8), - } - if p.ccc > 0 || p.combinesBackward() { - p.nLead = uint8(p.flags & 0x3) - } - return p - } - // has decomposition - h := decomps[v] - f := (qcInfo(h&headerFlagsMask) >> 2) | 0x4 - p := Properties{size: uint8(sz), flags: f, index: v} - if v >= firstCCC { - v += uint16(h&headerLenMask) + 1 - c := decomps[v] - p.tccc = c >> 2 - p.flags |= qcInfo(c & 0x3) - if v >= firstLeadingCCC { - p.nLead = c & 0x3 - if v >= firstStarterWithNLead { - // We were tricked. Remove the decomposition. - p.flags &= 0x03 - p.index = 0 - return p - } - p.ccc = decomps[v+1] - } - } - return p -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/input.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/input.go deleted file mode 100644 index 045d4cc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/input.go +++ /dev/null @@ -1,105 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -import "unicode/utf8" - -type input struct { - str string - bytes []byte -} - -func inputBytes(str []byte) input { - return input{bytes: str} -} - -func inputString(str string) input { - return input{str: str} -} - -func (in *input) setBytes(str []byte) { - in.str = "" - in.bytes = str -} - -func (in *input) setString(str string) { - in.str = str - in.bytes = nil -} - -func (in *input) _byte(p int) byte { - if in.bytes == nil { - return in.str[p] - } - return in.bytes[p] -} - -func (in *input) skipASCII(p, max int) int { - if in.bytes == nil { - for ; p < max && in.str[p] < utf8.RuneSelf; p++ { - } - } else { - for ; p < max && in.bytes[p] < utf8.RuneSelf; p++ { - } - } - return p -} - -func (in *input) skipContinuationBytes(p int) int { - if in.bytes == nil { - for ; p < len(in.str) && !utf8.RuneStart(in.str[p]); p++ { - } - } else { - for ; p < len(in.bytes) && !utf8.RuneStart(in.bytes[p]); p++ { - } - } - return p -} - -func (in *input) appendSlice(buf []byte, b, e int) []byte { - if in.bytes != nil { - return append(buf, in.bytes[b:e]...) - } - for i := b; i < e; i++ { - buf = append(buf, in.str[i]) - } - return buf -} - -func (in *input) copySlice(buf []byte, b, e int) int { - if in.bytes == nil { - return copy(buf, in.str[b:e]) - } - return copy(buf, in.bytes[b:e]) -} - -func (in *input) charinfoNFC(p int) (uint16, int) { - if in.bytes == nil { - return nfcData.lookupString(in.str[p:]) - } - return nfcData.lookup(in.bytes[p:]) -} - -func (in *input) charinfoNFKC(p int) (uint16, int) { - if in.bytes == nil { - return nfkcData.lookupString(in.str[p:]) - } - return nfkcData.lookup(in.bytes[p:]) -} - -func (in *input) hangul(p int) (r rune) { - if in.bytes == nil { - if !isHangulString(in.str[p:]) { - return 0 - } - r, _ = utf8.DecodeRuneInString(in.str[p:]) - } else { - if !isHangul(in.bytes[p:]) { - return 0 - } - r, _ = utf8.DecodeRune(in.bytes[p:]) - } - return r -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/iter.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/iter.go deleted file mode 100644 index 0a42a72..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/iter.go +++ /dev/null @@ -1,450 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -import ( - "fmt" - "unicode/utf8" -) - -// MaxSegmentSize is the maximum size of a byte buffer needed to consider any -// sequence of starter and non-starter runes for the purpose of normalization. -const MaxSegmentSize = maxByteBufferSize - -// An Iter iterates over a string or byte slice, while normalizing it -// to a given Form. -type Iter struct { - rb reorderBuffer - buf [maxByteBufferSize]byte - info Properties // first character saved from previous iteration - next iterFunc // implementation of next depends on form - asciiF iterFunc - - p int // current position in input source - multiSeg []byte // remainder of multi-segment decomposition -} - -type iterFunc func(*Iter) []byte - -// Init initializes i to iterate over src after normalizing it to Form f. -func (i *Iter) Init(f Form, src []byte) { - i.p = 0 - if len(src) == 0 { - i.setDone() - i.rb.nsrc = 0 - return - } - i.multiSeg = nil - i.rb.init(f, src) - i.next = i.rb.f.nextMain - i.asciiF = nextASCIIBytes - i.info = i.rb.f.info(i.rb.src, i.p) -} - -// InitString initializes i to iterate over src after normalizing it to Form f. -func (i *Iter) InitString(f Form, src string) { - i.p = 0 - if len(src) == 0 { - i.setDone() - i.rb.nsrc = 0 - return - } - i.multiSeg = nil - i.rb.initString(f, src) - i.next = i.rb.f.nextMain - i.asciiF = nextASCIIString - i.info = i.rb.f.info(i.rb.src, i.p) -} - -// Seek sets the segment to be returned by the next call to Next to start -// at position p. It is the responsibility of the caller to set p to the -// start of a UTF8 rune. -func (i *Iter) Seek(offset int64, whence int) (int64, error) { - var abs int64 - switch whence { - case 0: - abs = offset - case 1: - abs = int64(i.p) + offset - case 2: - abs = int64(i.rb.nsrc) + offset - default: - return 0, fmt.Errorf("norm: invalid whence") - } - if abs < 0 { - return 0, fmt.Errorf("norm: negative position") - } - if int(abs) >= i.rb.nsrc { - i.setDone() - return int64(i.p), nil - } - i.p = int(abs) - i.multiSeg = nil - i.next = i.rb.f.nextMain - i.info = i.rb.f.info(i.rb.src, i.p) - return abs, nil -} - -// returnSlice returns a slice of the underlying input type as a byte slice. -// If the underlying is of type []byte, it will simply return a slice. -// If the underlying is of type string, it will copy the slice to the buffer -// and return that. -func (i *Iter) returnSlice(a, b int) []byte { - if i.rb.src.bytes == nil { - return i.buf[:copy(i.buf[:], i.rb.src.str[a:b])] - } - return i.rb.src.bytes[a:b] -} - -// Pos returns the byte position at which the next call to Next will commence processing. -func (i *Iter) Pos() int { - return i.p -} - -func (i *Iter) setDone() { - i.next = nextDone - i.p = i.rb.nsrc -} - -// Done returns true if there is no more input to process. -func (i *Iter) Done() bool { - return i.p >= i.rb.nsrc -} - -// Next returns f(i.input[i.Pos():n]), where n is a boundary of i.input. -// For any input a and b for which f(a) == f(b), subsequent calls -// to Next will return the same segments. -// Modifying runes are grouped together with the preceding starter, if such a starter exists. -// Although not guaranteed, n will typically be the smallest possible n. -func (i *Iter) Next() []byte { - return i.next(i) -} - -func nextASCIIBytes(i *Iter) []byte { - p := i.p + 1 - if p >= i.rb.nsrc { - i.setDone() - return i.rb.src.bytes[i.p:p] - } - if i.rb.src.bytes[p] < utf8.RuneSelf { - p0 := i.p - i.p = p - return i.rb.src.bytes[p0:p] - } - i.info = i.rb.f.info(i.rb.src, i.p) - i.next = i.rb.f.nextMain - return i.next(i) -} - -func nextASCIIString(i *Iter) []byte { - p := i.p + 1 - if p >= i.rb.nsrc { - i.buf[0] = i.rb.src.str[i.p] - i.setDone() - return i.buf[:1] - } - if i.rb.src.str[p] < utf8.RuneSelf { - i.buf[0] = i.rb.src.str[i.p] - i.p = p - return i.buf[:1] - } - i.info = i.rb.f.info(i.rb.src, i.p) - i.next = i.rb.f.nextMain - return i.next(i) -} - -func nextHangul(i *Iter) []byte { - p := i.p - next := p + hangulUTF8Size - if next >= i.rb.nsrc { - i.setDone() - } else if i.rb.src.hangul(next) == 0 { - i.info = i.rb.f.info(i.rb.src, i.p) - i.next = i.rb.f.nextMain - return i.next(i) - } - i.p = next - return i.buf[:decomposeHangul(i.buf[:], i.rb.src.hangul(p))] -} - -func nextDone(i *Iter) []byte { - return nil -} - -// nextMulti is used for iterating over multi-segment decompositions -// for decomposing normal forms. -func nextMulti(i *Iter) []byte { - j := 0 - d := i.multiSeg - // skip first rune - for j = 1; j < len(d) && !utf8.RuneStart(d[j]); j++ { - } - for j < len(d) { - info := i.rb.f.info(input{bytes: d}, j) - if info.BoundaryBefore() { - i.multiSeg = d[j:] - return d[:j] - } - j += int(info.size) - } - // treat last segment as normal decomposition - i.next = i.rb.f.nextMain - return i.next(i) -} - -// nextMultiNorm is used for iterating over multi-segment decompositions -// for composing normal forms. -func nextMultiNorm(i *Iter) []byte { - j := 0 - d := i.multiSeg - for j < len(d) { - info := i.rb.f.info(input{bytes: d}, j) - if info.BoundaryBefore() { - i.rb.compose() - seg := i.buf[:i.rb.flushCopy(i.buf[:])] - i.rb.ss.first(info) - i.rb.insertUnsafe(input{bytes: d}, j, info) - i.multiSeg = d[j+int(info.size):] - return seg - } - i.rb.ss.next(info) - i.rb.insertUnsafe(input{bytes: d}, j, info) - j += int(info.size) - } - i.multiSeg = nil - i.next = nextComposed - return doNormComposed(i) -} - -// nextDecomposed is the implementation of Next for forms NFD and NFKD. -func nextDecomposed(i *Iter) (next []byte) { - outp := 0 - inCopyStart, outCopyStart := i.p, 0 - ss := mkStreamSafe(i.info) - for { - if sz := int(i.info.size); sz <= 1 { - p := i.p - i.p++ // ASCII or illegal byte. Either way, advance by 1. - if i.p >= i.rb.nsrc { - i.setDone() - return i.returnSlice(p, i.p) - } else if i.rb.src._byte(i.p) < utf8.RuneSelf { - i.next = i.asciiF - return i.returnSlice(p, i.p) - } - outp++ - } else if d := i.info.Decomposition(); d != nil { - // Note: If leading CCC != 0, then len(d) == 2 and last is also non-zero. - // Case 1: there is a leftover to copy. In this case the decomposition - // must begin with a modifier and should always be appended. - // Case 2: no leftover. Simply return d if followed by a ccc == 0 value. - p := outp + len(d) - if outp > 0 { - i.rb.src.copySlice(i.buf[outCopyStart:], inCopyStart, i.p) - if p > len(i.buf) { - return i.buf[:outp] - } - } else if i.info.multiSegment() { - // outp must be 0 as multi-segment decompositions always - // start a new segment. - if i.multiSeg == nil { - i.multiSeg = d - i.next = nextMulti - return nextMulti(i) - } - // We are in the last segment. Treat as normal decomposition. - d = i.multiSeg - i.multiSeg = nil - p = len(d) - } - prevCC := i.info.tccc - if i.p += sz; i.p >= i.rb.nsrc { - i.setDone() - i.info = Properties{} // Force BoundaryBefore to succeed. - } else { - i.info = i.rb.f.info(i.rb.src, i.p) - } - switch ss.next(i.info) { - case ssOverflow: - i.next = nextCGJDecompose - fallthrough - case ssStarter: - if outp > 0 { - copy(i.buf[outp:], d) - return i.buf[:p] - } - return d - } - copy(i.buf[outp:], d) - outp = p - inCopyStart, outCopyStart = i.p, outp - if i.info.ccc < prevCC { - goto doNorm - } - continue - } else if r := i.rb.src.hangul(i.p); r != 0 { - outp = decomposeHangul(i.buf[:], r) - i.p += hangulUTF8Size - inCopyStart, outCopyStart = i.p, outp - if i.p >= i.rb.nsrc { - i.setDone() - break - } else if i.rb.src.hangul(i.p) != 0 { - i.next = nextHangul - return i.buf[:outp] - } - } else { - p := outp + sz - if p > len(i.buf) { - break - } - outp = p - i.p += sz - } - if i.p >= i.rb.nsrc { - i.setDone() - break - } - prevCC := i.info.tccc - i.info = i.rb.f.info(i.rb.src, i.p) - if v := ss.next(i.info); v == ssStarter { - break - } else if v == ssOverflow { - i.next = nextCGJDecompose - break - } - if i.info.ccc < prevCC { - goto doNorm - } - } - if outCopyStart == 0 { - return i.returnSlice(inCopyStart, i.p) - } else if inCopyStart < i.p { - i.rb.src.copySlice(i.buf[outCopyStart:], inCopyStart, i.p) - } - return i.buf[:outp] -doNorm: - // Insert what we have decomposed so far in the reorderBuffer. - // As we will only reorder, there will always be enough room. - i.rb.src.copySlice(i.buf[outCopyStart:], inCopyStart, i.p) - i.rb.insertDecomposed(i.buf[0:outp]) - return doNormDecomposed(i) -} - -func doNormDecomposed(i *Iter) []byte { - for { - if s := i.rb.ss.next(i.info); s == ssOverflow { - i.next = nextCGJDecompose - break - } - i.rb.insertUnsafe(i.rb.src, i.p, i.info) - if i.p += int(i.info.size); i.p >= i.rb.nsrc { - i.setDone() - break - } - i.info = i.rb.f.info(i.rb.src, i.p) - if i.info.ccc == 0 { - break - } - } - // new segment or too many combining characters: exit normalization - return i.buf[:i.rb.flushCopy(i.buf[:])] -} - -func nextCGJDecompose(i *Iter) []byte { - i.rb.ss = 0 - i.rb.insertCGJ() - i.next = nextDecomposed - buf := doNormDecomposed(i) - return buf -} - -// nextComposed is the implementation of Next for forms NFC and NFKC. -func nextComposed(i *Iter) []byte { - outp, startp := 0, i.p - var prevCC uint8 - ss := mkStreamSafe(i.info) - for { - if !i.info.isYesC() { - goto doNorm - } - prevCC = i.info.tccc - sz := int(i.info.size) - if sz == 0 { - sz = 1 // illegal rune: copy byte-by-byte - } - p := outp + sz - if p > len(i.buf) { - break - } - outp = p - i.p += sz - if i.p >= i.rb.nsrc { - i.setDone() - break - } else if i.rb.src._byte(i.p) < utf8.RuneSelf { - i.next = i.asciiF - break - } - i.info = i.rb.f.info(i.rb.src, i.p) - if v := ss.next(i.info); v == ssStarter { - break - } else if v == ssOverflow { - i.next = nextCGJCompose - break - } - if i.info.ccc < prevCC { - goto doNorm - } - } - return i.returnSlice(startp, i.p) -doNorm: - i.p = startp - i.info = i.rb.f.info(i.rb.src, i.p) - if i.info.multiSegment() { - d := i.info.Decomposition() - info := i.rb.f.info(input{bytes: d}, 0) - i.rb.insertUnsafe(input{bytes: d}, 0, info) - i.multiSeg = d[int(info.size):] - i.next = nextMultiNorm - return nextMultiNorm(i) - } - i.rb.ss.first(i.info) - i.rb.insertUnsafe(i.rb.src, i.p, i.info) - return doNormComposed(i) -} - -func doNormComposed(i *Iter) []byte { - // First rune should already be inserted. - for { - if i.p += int(i.info.size); i.p >= i.rb.nsrc { - i.setDone() - break - } - i.info = i.rb.f.info(i.rb.src, i.p) - if s := i.rb.ss.next(i.info); s == ssStarter { - break - } else if s == ssOverflow { - i.next = nextCGJCompose - break - } - i.rb.insertUnsafe(i.rb.src, i.p, i.info) - } - i.rb.compose() - seg := i.buf[:i.rb.flushCopy(i.buf[:])] - return seg -} - -func nextCGJCompose(i *Iter) []byte { - i.rb.ss = 0 // instead of first - i.rb.insertCGJ() - i.next = nextComposed - // Note that we treat any rune with nLeadingNonStarters > 0 as a non-starter, - // even if they are not. This is particularly dubious for U+FF9E and UFF9A. - // If we ever change that, insert a check here. - i.rb.ss.first(i.info) - i.rb.insertUnsafe(i.rb.src, i.p, i.info) - return doNormComposed(i) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/maketables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/maketables.go deleted file mode 100644 index 07bdff6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/maketables.go +++ /dev/null @@ -1,978 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -// Normalization table generator. -// Data read from the web. -// See forminfo.go for a description of the trie values associated with each rune. - -package main - -import ( - "bytes" - "flag" - "fmt" - "io" - "log" - "sort" - "strconv" - "strings" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/triegen" - "golang.org/x/text/internal/ucd" -) - -func main() { - gen.Init() - loadUnicodeData() - compactCCC() - loadCompositionExclusions() - completeCharFields(FCanonical) - completeCharFields(FCompatibility) - computeNonStarterCounts() - verifyComputed() - printChars() - if *test { - testDerived() - printTestdata() - } else { - makeTables() - } -} - -var ( - tablelist = flag.String("tables", - "all", - "comma-separated list of which tables to generate; "+ - "can be 'decomp', 'recomp', 'info' and 'all'") - test = flag.Bool("test", - false, - "test existing tables against DerivedNormalizationProps and generate test data for regression testing") - verbose = flag.Bool("verbose", - false, - "write data to stdout as it is parsed") -) - -const MaxChar = 0x10FFFF // anything above this shouldn't exist - -// Quick Check properties of runes allow us to quickly -// determine whether a rune may occur in a normal form. -// For a given normal form, a rune may be guaranteed to occur -// verbatim (QC=Yes), may or may not combine with another -// rune (QC=Maybe), or may not occur (QC=No). -type QCResult int - -const ( - QCUnknown QCResult = iota - QCYes - QCNo - QCMaybe -) - -func (r QCResult) String() string { - switch r { - case QCYes: - return "Yes" - case QCNo: - return "No" - case QCMaybe: - return "Maybe" - } - return "***UNKNOWN***" -} - -const ( - FCanonical = iota // NFC or NFD - FCompatibility // NFKC or NFKD - FNumberOfFormTypes -) - -const ( - MComposed = iota // NFC or NFKC - MDecomposed // NFD or NFKD - MNumberOfModes -) - -// This contains only the properties we're interested in. -type Char struct { - name string - codePoint rune // if zero, this index is not a valid code point. - ccc uint8 // canonical combining class - origCCC uint8 - excludeInComp bool // from CompositionExclusions.txt - compatDecomp bool // it has a compatibility expansion - - nTrailingNonStarters uint8 - nLeadingNonStarters uint8 // must be equal to trailing if non-zero - - forms [FNumberOfFormTypes]FormInfo // For FCanonical and FCompatibility - - state State -} - -var chars = make([]Char, MaxChar+1) -var cccMap = make(map[uint8]uint8) - -func (c Char) String() string { - buf := new(bytes.Buffer) - - fmt.Fprintf(buf, "%U [%s]:\n", c.codePoint, c.name) - fmt.Fprintf(buf, " ccc: %v\n", c.ccc) - fmt.Fprintf(buf, " excludeInComp: %v\n", c.excludeInComp) - fmt.Fprintf(buf, " compatDecomp: %v\n", c.compatDecomp) - fmt.Fprintf(buf, " state: %v\n", c.state) - fmt.Fprintf(buf, " NFC:\n") - fmt.Fprint(buf, c.forms[FCanonical]) - fmt.Fprintf(buf, " NFKC:\n") - fmt.Fprint(buf, c.forms[FCompatibility]) - - return buf.String() -} - -// In UnicodeData.txt, some ranges are marked like this: -// 3400;<CJK Ideograph Extension A, First>;Lo;0;L;;;;;N;;;;; -// 4DB5;<CJK Ideograph Extension A, Last>;Lo;0;L;;;;;N;;;;; -// parseCharacter keeps a state variable indicating the weirdness. -type State int - -const ( - SNormal State = iota // known to be zero for the type - SFirst - SLast - SMissing -) - -var lastChar = rune('\u0000') - -func (c Char) isValid() bool { - return c.codePoint != 0 && c.state != SMissing -} - -type FormInfo struct { - quickCheck [MNumberOfModes]QCResult // index: MComposed or MDecomposed - verified [MNumberOfModes]bool // index: MComposed or MDecomposed - - combinesForward bool // May combine with rune on the right - combinesBackward bool // May combine with rune on the left - isOneWay bool // Never appears in result - inDecomp bool // Some decompositions result in this char. - decomp Decomposition - expandedDecomp Decomposition -} - -func (f FormInfo) String() string { - buf := bytes.NewBuffer(make([]byte, 0)) - - fmt.Fprintf(buf, " quickCheck[C]: %v\n", f.quickCheck[MComposed]) - fmt.Fprintf(buf, " quickCheck[D]: %v\n", f.quickCheck[MDecomposed]) - fmt.Fprintf(buf, " cmbForward: %v\n", f.combinesForward) - fmt.Fprintf(buf, " cmbBackward: %v\n", f.combinesBackward) - fmt.Fprintf(buf, " isOneWay: %v\n", f.isOneWay) - fmt.Fprintf(buf, " inDecomp: %v\n", f.inDecomp) - fmt.Fprintf(buf, " decomposition: %X\n", f.decomp) - fmt.Fprintf(buf, " expandedDecomp: %X\n", f.expandedDecomp) - - return buf.String() -} - -type Decomposition []rune - -func parseDecomposition(s string, skipfirst bool) (a []rune, err error) { - decomp := strings.Split(s, " ") - if len(decomp) > 0 && skipfirst { - decomp = decomp[1:] - } - for _, d := range decomp { - point, err := strconv.ParseUint(d, 16, 64) - if err != nil { - return a, err - } - a = append(a, rune(point)) - } - return a, nil -} - -func loadUnicodeData() { - f := gen.OpenUCDFile("UnicodeData.txt") - defer f.Close() - p := ucd.New(f) - for p.Next() { - r := p.Rune(ucd.CodePoint) - char := &chars[r] - - char.ccc = uint8(p.Uint(ucd.CanonicalCombiningClass)) - decmap := p.String(ucd.DecompMapping) - - exp, err := parseDecomposition(decmap, false) - isCompat := false - if err != nil { - if len(decmap) > 0 { - exp, err = parseDecomposition(decmap, true) - if err != nil { - log.Fatalf(`%U: bad decomp |%v|: "%s"`, r, decmap, err) - } - isCompat = true - } - } - - char.name = p.String(ucd.Name) - char.codePoint = r - char.forms[FCompatibility].decomp = exp - if !isCompat { - char.forms[FCanonical].decomp = exp - } else { - char.compatDecomp = true - } - if len(decmap) > 0 { - char.forms[FCompatibility].decomp = exp - } - } - if err := p.Err(); err != nil { - log.Fatal(err) - } -} - -// compactCCC converts the sparse set of CCC values to a continguous one, -// reducing the number of bits needed from 8 to 6. -func compactCCC() { - m := make(map[uint8]uint8) - for i := range chars { - c := &chars[i] - m[c.ccc] = 0 - } - cccs := []int{} - for v, _ := range m { - cccs = append(cccs, int(v)) - } - sort.Ints(cccs) - for i, c := range cccs { - cccMap[uint8(i)] = uint8(c) - m[uint8(c)] = uint8(i) - } - for i := range chars { - c := &chars[i] - c.origCCC = c.ccc - c.ccc = m[c.ccc] - } - if len(m) >= 1<<6 { - log.Fatalf("too many difference CCC values: %d >= 64", len(m)) - } -} - -// CompositionExclusions.txt has form: -// 0958 # ... -// See http://unicode.org/reports/tr44/ for full explanation -func loadCompositionExclusions() { - f := gen.OpenUCDFile("CompositionExclusions.txt") - defer f.Close() - p := ucd.New(f) - for p.Next() { - c := &chars[p.Rune(0)] - if c.excludeInComp { - log.Fatalf("%U: Duplicate entry in exclusions.", c.codePoint) - } - c.excludeInComp = true - } - if e := p.Err(); e != nil { - log.Fatal(e) - } -} - -// hasCompatDecomp returns true if any of the recursive -// decompositions contains a compatibility expansion. -// In this case, the character may not occur in NFK*. -func hasCompatDecomp(r rune) bool { - c := &chars[r] - if c.compatDecomp { - return true - } - for _, d := range c.forms[FCompatibility].decomp { - if hasCompatDecomp(d) { - return true - } - } - return false -} - -// Hangul related constants. -const ( - HangulBase = 0xAC00 - HangulEnd = 0xD7A4 // hangulBase + Jamo combinations (19 * 21 * 28) - - JamoLBase = 0x1100 - JamoLEnd = 0x1113 - JamoVBase = 0x1161 - JamoVEnd = 0x1176 - JamoTBase = 0x11A8 - JamoTEnd = 0x11C3 - - JamoLVTCount = 19 * 21 * 28 - JamoTCount = 28 -) - -func isHangul(r rune) bool { - return HangulBase <= r && r < HangulEnd -} - -func isHangulWithoutJamoT(r rune) bool { - if !isHangul(r) { - return false - } - r -= HangulBase - return r < JamoLVTCount && r%JamoTCount == 0 -} - -func ccc(r rune) uint8 { - return chars[r].ccc -} - -// Insert a rune in a buffer, ordered by Canonical Combining Class. -func insertOrdered(b Decomposition, r rune) Decomposition { - n := len(b) - b = append(b, 0) - cc := ccc(r) - if cc > 0 { - // Use bubble sort. - for ; n > 0; n-- { - if ccc(b[n-1]) <= cc { - break - } - b[n] = b[n-1] - } - } - b[n] = r - return b -} - -// Recursively decompose. -func decomposeRecursive(form int, r rune, d Decomposition) Decomposition { - dcomp := chars[r].forms[form].decomp - if len(dcomp) == 0 { - return insertOrdered(d, r) - } - for _, c := range dcomp { - d = decomposeRecursive(form, c, d) - } - return d -} - -func completeCharFields(form int) { - // Phase 0: pre-expand decomposition. - for i := range chars { - f := &chars[i].forms[form] - if len(f.decomp) == 0 { - continue - } - exp := make(Decomposition, 0) - for _, c := range f.decomp { - exp = decomposeRecursive(form, c, exp) - } - f.expandedDecomp = exp - } - - // Phase 1: composition exclusion, mark decomposition. - for i := range chars { - c := &chars[i] - f := &c.forms[form] - - // Marks script-specific exclusions and version restricted. - f.isOneWay = c.excludeInComp - - // Singletons - f.isOneWay = f.isOneWay || len(f.decomp) == 1 - - // Non-starter decompositions - if len(f.decomp) > 1 { - chk := c.ccc != 0 || chars[f.decomp[0]].ccc != 0 - f.isOneWay = f.isOneWay || chk - } - - // Runes that decompose into more than two runes. - f.isOneWay = f.isOneWay || len(f.decomp) > 2 - - if form == FCompatibility { - f.isOneWay = f.isOneWay || hasCompatDecomp(c.codePoint) - } - - for _, r := range f.decomp { - chars[r].forms[form].inDecomp = true - } - } - - // Phase 2: forward and backward combining. - for i := range chars { - c := &chars[i] - f := &c.forms[form] - - if !f.isOneWay && len(f.decomp) == 2 { - f0 := &chars[f.decomp[0]].forms[form] - f1 := &chars[f.decomp[1]].forms[form] - if !f0.isOneWay { - f0.combinesForward = true - } - if !f1.isOneWay { - f1.combinesBackward = true - } - } - if isHangulWithoutJamoT(rune(i)) { - f.combinesForward = true - } - } - - // Phase 3: quick check values. - for i := range chars { - c := &chars[i] - f := &c.forms[form] - - switch { - case len(f.decomp) > 0: - f.quickCheck[MDecomposed] = QCNo - case isHangul(rune(i)): - f.quickCheck[MDecomposed] = QCNo - default: - f.quickCheck[MDecomposed] = QCYes - } - switch { - case f.isOneWay: - f.quickCheck[MComposed] = QCNo - case (i & 0xffff00) == JamoLBase: - f.quickCheck[MComposed] = QCYes - if JamoLBase <= i && i < JamoLEnd { - f.combinesForward = true - } - if JamoVBase <= i && i < JamoVEnd { - f.quickCheck[MComposed] = QCMaybe - f.combinesBackward = true - f.combinesForward = true - } - if JamoTBase <= i && i < JamoTEnd { - f.quickCheck[MComposed] = QCMaybe - f.combinesBackward = true - } - case !f.combinesBackward: - f.quickCheck[MComposed] = QCYes - default: - f.quickCheck[MComposed] = QCMaybe - } - } -} - -func computeNonStarterCounts() { - // Phase 4: leading and trailing non-starter count - for i := range chars { - c := &chars[i] - - runes := []rune{rune(i)} - // We always use FCompatibility so that the CGJ insertion points do not - // change for repeated normalizations with different forms. - if exp := c.forms[FCompatibility].expandedDecomp; len(exp) > 0 { - runes = exp - } - // We consider runes that combine backwards to be non-starters for the - // purpose of Stream-Safe Text Processing. - for _, r := range runes { - if cr := &chars[r]; cr.ccc == 0 && !cr.forms[FCompatibility].combinesBackward { - break - } - c.nLeadingNonStarters++ - } - for i := len(runes) - 1; i >= 0; i-- { - if cr := &chars[runes[i]]; cr.ccc == 0 && !cr.forms[FCompatibility].combinesBackward { - break - } - c.nTrailingNonStarters++ - } - if c.nTrailingNonStarters > 3 { - log.Fatalf("%U: Decomposition with more than 3 (%d) trailing modifiers (%U)", i, c.nTrailingNonStarters, runes) - } - - if isHangul(rune(i)) { - c.nTrailingNonStarters = 2 - if isHangulWithoutJamoT(rune(i)) { - c.nTrailingNonStarters = 1 - } - } - - if l, t := c.nLeadingNonStarters, c.nTrailingNonStarters; l > 0 && l != t { - log.Fatalf("%U: number of leading and trailing non-starters should be equal (%d vs %d)", i, l, t) - } - if t := c.nTrailingNonStarters; t > 3 { - log.Fatalf("%U: number of trailing non-starters is %d > 3", t) - } - } -} - -func printBytes(w io.Writer, b []byte, name string) { - fmt.Fprintf(w, "// %s: %d bytes\n", name, len(b)) - fmt.Fprintf(w, "var %s = [...]byte {", name) - for i, c := range b { - switch { - case i%64 == 0: - fmt.Fprintf(w, "\n// Bytes %x - %x\n", i, i+63) - case i%8 == 0: - fmt.Fprintf(w, "\n") - } - fmt.Fprintf(w, "0x%.2X, ", c) - } - fmt.Fprint(w, "\n}\n\n") -} - -// See forminfo.go for format. -func makeEntry(f *FormInfo, c *Char) uint16 { - e := uint16(0) - if r := c.codePoint; HangulBase <= r && r < HangulEnd { - e |= 0x40 - } - if f.combinesForward { - e |= 0x20 - } - if f.quickCheck[MDecomposed] == QCNo { - e |= 0x4 - } - switch f.quickCheck[MComposed] { - case QCYes: - case QCNo: - e |= 0x10 - case QCMaybe: - e |= 0x18 - default: - log.Fatalf("Illegal quickcheck value %v.", f.quickCheck[MComposed]) - } - e |= uint16(c.nTrailingNonStarters) - return e -} - -// decompSet keeps track of unique decompositions, grouped by whether -// the decomposition is followed by a trailing and/or leading CCC. -type decompSet [7]map[string]bool - -const ( - normalDecomp = iota - firstMulti - firstCCC - endMulti - firstLeadingCCC - firstCCCZeroExcept - firstStarterWithNLead - lastDecomp -) - -var cname = []string{"firstMulti", "firstCCC", "endMulti", "firstLeadingCCC", "firstCCCZeroExcept", "firstStarterWithNLead", "lastDecomp"} - -func makeDecompSet() decompSet { - m := decompSet{} - for i := range m { - m[i] = make(map[string]bool) - } - return m -} -func (m *decompSet) insert(key int, s string) { - m[key][s] = true -} - -func printCharInfoTables(w io.Writer) int { - mkstr := func(r rune, f *FormInfo) (int, string) { - d := f.expandedDecomp - s := string([]rune(d)) - if max := 1 << 6; len(s) >= max { - const msg = "%U: too many bytes in decomposition: %d >= %d" - log.Fatalf(msg, r, len(s), max) - } - head := uint8(len(s)) - if f.quickCheck[MComposed] != QCYes { - head |= 0x40 - } - if f.combinesForward { - head |= 0x80 - } - s = string([]byte{head}) + s - - lccc := ccc(d[0]) - tccc := ccc(d[len(d)-1]) - cc := ccc(r) - if cc != 0 && lccc == 0 && tccc == 0 { - log.Fatalf("%U: trailing and leading ccc are 0 for non-zero ccc %d", r, cc) - } - if tccc < lccc && lccc != 0 { - const msg = "%U: lccc (%d) must be <= tcc (%d)" - log.Fatalf(msg, r, lccc, tccc) - } - index := normalDecomp - nTrail := chars[r].nTrailingNonStarters - if tccc > 0 || lccc > 0 || nTrail > 0 { - tccc <<= 2 - tccc |= nTrail - s += string([]byte{tccc}) - index = endMulti - for _, r := range d[1:] { - if ccc(r) == 0 { - index = firstCCC - } - } - if lccc > 0 { - s += string([]byte{lccc}) - if index == firstCCC { - log.Fatalf("%U: multi-segment decomposition not supported for decompositions with leading CCC != 0", r) - } - index = firstLeadingCCC - } - if cc != lccc { - if cc != 0 { - log.Fatalf("%U: for lccc != ccc, expected ccc to be 0; was %d", r, cc) - } - index = firstCCCZeroExcept - } - } else if len(d) > 1 { - index = firstMulti - } - return index, s - } - - decompSet := makeDecompSet() - const nLeadStr = "\x00\x01" // 0-byte length and tccc with nTrail. - decompSet.insert(firstStarterWithNLead, nLeadStr) - - // Store the uniqued decompositions in a byte buffer, - // preceded by their byte length. - for _, c := range chars { - for _, f := range c.forms { - if len(f.expandedDecomp) == 0 { - continue - } - if f.combinesBackward { - log.Fatalf("%U: combinesBackward and decompose", c.codePoint) - } - index, s := mkstr(c.codePoint, &f) - decompSet.insert(index, s) - } - } - - decompositions := bytes.NewBuffer(make([]byte, 0, 10000)) - size := 0 - positionMap := make(map[string]uint16) - decompositions.WriteString("\000") - fmt.Fprintln(w, "const (") - for i, m := range decompSet { - sa := []string{} - for s := range m { - sa = append(sa, s) - } - sort.Strings(sa) - for _, s := range sa { - p := decompositions.Len() - decompositions.WriteString(s) - positionMap[s] = uint16(p) - } - if cname[i] != "" { - fmt.Fprintf(w, "%s = 0x%X\n", cname[i], decompositions.Len()) - } - } - fmt.Fprintln(w, "maxDecomp = 0x8000") - fmt.Fprintln(w, ")") - b := decompositions.Bytes() - printBytes(w, b, "decomps") - size += len(b) - - varnames := []string{"nfc", "nfkc"} - for i := 0; i < FNumberOfFormTypes; i++ { - trie := triegen.NewTrie(varnames[i]) - - for r, c := range chars { - f := c.forms[i] - d := f.expandedDecomp - if len(d) != 0 { - _, key := mkstr(c.codePoint, &f) - trie.Insert(rune(r), uint64(positionMap[key])) - if c.ccc != ccc(d[0]) { - // We assume the lead ccc of a decomposition !=0 in this case. - if ccc(d[0]) == 0 { - log.Fatalf("Expected leading CCC to be non-zero; ccc is %d", c.ccc) - } - } - } else if c.nLeadingNonStarters > 0 && len(f.expandedDecomp) == 0 && c.ccc == 0 && !f.combinesBackward { - // Handle cases where it can't be detected that the nLead should be equal - // to nTrail. - trie.Insert(c.codePoint, uint64(positionMap[nLeadStr])) - } else if v := makeEntry(&f, &c)<<8 | uint16(c.ccc); v != 0 { - trie.Insert(c.codePoint, uint64(0x8000|v)) - } - } - sz, err := trie.Gen(w, triegen.Compact(&normCompacter{name: varnames[i]})) - if err != nil { - log.Fatal(err) - } - size += sz - } - return size -} - -func contains(sa []string, s string) bool { - for _, a := range sa { - if a == s { - return true - } - } - return false -} - -func makeTables() { - w := &bytes.Buffer{} - - size := 0 - if *tablelist == "" { - return - } - list := strings.Split(*tablelist, ",") - if *tablelist == "all" { - list = []string{"recomp", "info"} - } - - // Compute maximum decomposition size. - max := 0 - for _, c := range chars { - if n := len(string(c.forms[FCompatibility].expandedDecomp)); n > max { - max = n - } - } - - fmt.Fprintln(w, "const (") - fmt.Fprintln(w, "\t// Version is the Unicode edition from which the tables are derived.") - fmt.Fprintf(w, "\tVersion = %q\n", gen.UnicodeVersion()) - fmt.Fprintln(w) - fmt.Fprintln(w, "\t// MaxTransformChunkSize indicates the maximum number of bytes that Transform") - fmt.Fprintln(w, "\t// may need to write atomically for any Form. Making a destination buffer at") - fmt.Fprintln(w, "\t// least this size ensures that Transform can always make progress and that") - fmt.Fprintln(w, "\t// the user does not need to grow the buffer on an ErrShortDst.") - fmt.Fprintf(w, "\tMaxTransformChunkSize = %d+maxNonStarters*4\n", len(string(0x034F))+max) - fmt.Fprintln(w, ")\n") - - // Print the CCC remap table. - size += len(cccMap) - fmt.Fprintf(w, "var ccc = [%d]uint8{", len(cccMap)) - for i := 0; i < len(cccMap); i++ { - if i%8 == 0 { - fmt.Fprintln(w) - } - fmt.Fprintf(w, "%3d, ", cccMap[uint8(i)]) - } - fmt.Fprintln(w, "\n}\n") - - if contains(list, "info") { - size += printCharInfoTables(w) - } - - if contains(list, "recomp") { - // Note that we use 32 bit keys, instead of 64 bit. - // This clips the bits of three entries, but we know - // this won't cause a collision. The compiler will catch - // any changes made to UnicodeData.txt that introduces - // a collision. - // Note that the recomposition map for NFC and NFKC - // are identical. - - // Recomposition map - nrentries := 0 - for _, c := range chars { - f := c.forms[FCanonical] - if !f.isOneWay && len(f.decomp) > 0 { - nrentries++ - } - } - sz := nrentries * 8 - size += sz - fmt.Fprintf(w, "// recompMap: %d bytes (entries only)\n", sz) - fmt.Fprintln(w, "var recompMap = map[uint32]rune{") - for i, c := range chars { - f := c.forms[FCanonical] - d := f.decomp - if !f.isOneWay && len(d) > 0 { - key := uint32(uint16(d[0]))<<16 + uint32(uint16(d[1])) - fmt.Fprintf(w, "0x%.8X: 0x%.4X,\n", key, i) - } - } - fmt.Fprintf(w, "}\n\n") - } - - fmt.Fprintf(w, "// Total size of tables: %dKB (%d bytes)\n", (size+512)/1024, size) - gen.WriteGoFile("tables.go", "norm", w.Bytes()) -} - -func printChars() { - if *verbose { - for _, c := range chars { - if !c.isValid() || c.state == SMissing { - continue - } - fmt.Println(c) - } - } -} - -// verifyComputed does various consistency tests. -func verifyComputed() { - for i, c := range chars { - for _, f := range c.forms { - isNo := (f.quickCheck[MDecomposed] == QCNo) - if (len(f.decomp) > 0) != isNo && !isHangul(rune(i)) { - log.Fatalf("%U: NF*D QC must be No if rune decomposes", i) - } - - isMaybe := f.quickCheck[MComposed] == QCMaybe - if f.combinesBackward != isMaybe { - log.Fatalf("%U: NF*C QC must be Maybe if combinesBackward", i) - } - if len(f.decomp) > 0 && f.combinesForward && isMaybe { - log.Fatalf("%U: NF*C QC must be Yes or No if combinesForward and decomposes", i) - } - - if len(f.expandedDecomp) != 0 { - continue - } - if a, b := c.nLeadingNonStarters > 0, (c.ccc > 0 || f.combinesBackward); a != b { - // We accept these runes to be treated differently (it only affects - // segment breaking in iteration, most likely on improper use), but - // reconsider if more characters are added. - // U+FF9E HALFWIDTH KATAKANA VOICED SOUND MARK;Lm;0;L;<narrow> 3099;;;;N;;;;; - // U+FF9F HALFWIDTH KATAKANA SEMI-VOICED SOUND MARK;Lm;0;L;<narrow> 309A;;;;N;;;;; - // U+3133 HANGUL LETTER KIYEOK-SIOS;Lo;0;L;<compat> 11AA;;;;N;HANGUL LETTER GIYEOG SIOS;;;; - // U+318E HANGUL LETTER ARAEAE;Lo;0;L;<compat> 11A1;;;;N;HANGUL LETTER ALAE AE;;;; - // U+FFA3 HALFWIDTH HANGUL LETTER KIYEOK-SIOS;Lo;0;L;<narrow> 3133;;;;N;HALFWIDTH HANGUL LETTER GIYEOG SIOS;;;; - // U+FFDC HALFWIDTH HANGUL LETTER I;Lo;0;L;<narrow> 3163;;;;N;;;;; - if i != 0xFF9E && i != 0xFF9F && !(0x3133 <= i && i <= 0x318E) && !(0xFFA3 <= i && i <= 0xFFDC) { - log.Fatalf("%U: nLead was %v; want %v", i, a, b) - } - } - } - nfc := c.forms[FCanonical] - nfkc := c.forms[FCompatibility] - if nfc.combinesBackward != nfkc.combinesBackward { - log.Fatalf("%U: Cannot combine combinesBackward\n", c.codePoint) - } - } -} - -// Use values in DerivedNormalizationProps.txt to compare against the -// values we computed. -// DerivedNormalizationProps.txt has form: -// 00C0..00C5 ; NFD_QC; N # ... -// 0374 ; NFD_QC; N # ... -// See http://unicode.org/reports/tr44/ for full explanation -func testDerived() { - f := gen.OpenUCDFile("DerivedNormalizationProps.txt") - defer f.Close() - p := ucd.New(f) - for p.Next() { - r := p.Rune(0) - c := &chars[r] - - var ftype, mode int - qt := p.String(1) - switch qt { - case "NFC_QC": - ftype, mode = FCanonical, MComposed - case "NFD_QC": - ftype, mode = FCanonical, MDecomposed - case "NFKC_QC": - ftype, mode = FCompatibility, MComposed - case "NFKD_QC": - ftype, mode = FCompatibility, MDecomposed - default: - continue - } - var qr QCResult - switch p.String(2) { - case "Y": - qr = QCYes - case "N": - qr = QCNo - case "M": - qr = QCMaybe - default: - log.Fatalf(`Unexpected quick check value "%s"`, p.String(2)) - } - if got := c.forms[ftype].quickCheck[mode]; got != qr { - log.Printf("%U: FAILED %s (was %v need %v)\n", r, qt, got, qr) - } - c.forms[ftype].verified[mode] = true - } - if err := p.Err(); err != nil { - log.Fatal(err) - } - // Any unspecified value must be QCYes. Verify this. - for i, c := range chars { - for j, fd := range c.forms { - for k, qr := range fd.quickCheck { - if !fd.verified[k] && qr != QCYes { - m := "%U: FAIL F:%d M:%d (was %v need Yes) %s\n" - log.Printf(m, i, j, k, qr, c.name) - } - } - } - } -} - -var testHeader = `const ( - Yes = iota - No - Maybe -) - -type formData struct { - qc uint8 - combinesForward bool - decomposition string -} - -type runeData struct { - r rune - ccc uint8 - nLead uint8 - nTrail uint8 - f [2]formData // 0: canonical; 1: compatibility -} - -func f(qc uint8, cf bool, dec string) [2]formData { - return [2]formData{{qc, cf, dec}, {qc, cf, dec}} -} - -func g(qc, qck uint8, cf, cfk bool, d, dk string) [2]formData { - return [2]formData{{qc, cf, d}, {qck, cfk, dk}} -} - -var testData = []runeData{ -` - -func printTestdata() { - type lastInfo struct { - ccc uint8 - nLead uint8 - nTrail uint8 - f string - } - - last := lastInfo{} - w := &bytes.Buffer{} - fmt.Fprintf(w, testHeader) - for r, c := range chars { - f := c.forms[FCanonical] - qc, cf, d := f.quickCheck[MComposed], f.combinesForward, string(f.expandedDecomp) - f = c.forms[FCompatibility] - qck, cfk, dk := f.quickCheck[MComposed], f.combinesForward, string(f.expandedDecomp) - s := "" - if d == dk && qc == qck && cf == cfk { - s = fmt.Sprintf("f(%s, %v, %q)", qc, cf, d) - } else { - s = fmt.Sprintf("g(%s, %s, %v, %v, %q, %q)", qc, qck, cf, cfk, d, dk) - } - current := lastInfo{c.ccc, c.nLeadingNonStarters, c.nTrailingNonStarters, s} - if last != current { - fmt.Fprintf(w, "\t{0x%x, %d, %d, %d, %s},\n", r, c.origCCC, c.nLeadingNonStarters, c.nTrailingNonStarters, s) - last = current - } - } - fmt.Fprintln(w, "}") - gen.WriteGoFile("data_test.go", "norm", w.Bytes()) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/normalize.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/normalize.go deleted file mode 100644 index a70805c..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/normalize.go +++ /dev/null @@ -1,576 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate go run maketables.go triegen.go -//go:generate go run maketables.go triegen.go -test - -// Package norm contains types and functions for normalizing Unicode strings. -package norm - -import "unicode/utf8" - -// A Form denotes a canonical representation of Unicode code points. -// The Unicode-defined normalization and equivalence forms are: -// -// NFC Unicode Normalization Form C -// NFD Unicode Normalization Form D -// NFKC Unicode Normalization Form KC -// NFKD Unicode Normalization Form KD -// -// For a Form f, this documentation uses the notation f(x) to mean -// the bytes or string x converted to the given form. -// A position n in x is called a boundary if conversion to the form can -// proceed independently on both sides: -// f(x) == append(f(x[0:n]), f(x[n:])...) -// -// References: http://unicode.org/reports/tr15/ and -// http://unicode.org/notes/tn5/. -type Form int - -const ( - NFC Form = iota - NFD - NFKC - NFKD -) - -// Bytes returns f(b). May return b if f(b) = b. -func (f Form) Bytes(b []byte) []byte { - src := inputBytes(b) - ft := formTable[f] - n, ok := ft.quickSpan(src, 0, len(b), true) - if ok { - return b - } - out := make([]byte, n, len(b)) - copy(out, b[0:n]) - rb := reorderBuffer{f: *ft, src: src, nsrc: len(b), out: out, flushF: appendFlush} - return doAppendInner(&rb, n) -} - -// String returns f(s). -func (f Form) String(s string) string { - src := inputString(s) - ft := formTable[f] - n, ok := ft.quickSpan(src, 0, len(s), true) - if ok { - return s - } - out := make([]byte, n, len(s)) - copy(out, s[0:n]) - rb := reorderBuffer{f: *ft, src: src, nsrc: len(s), out: out, flushF: appendFlush} - return string(doAppendInner(&rb, n)) -} - -// IsNormal returns true if b == f(b). -func (f Form) IsNormal(b []byte) bool { - src := inputBytes(b) - ft := formTable[f] - bp, ok := ft.quickSpan(src, 0, len(b), true) - if ok { - return true - } - rb := reorderBuffer{f: *ft, src: src, nsrc: len(b)} - rb.setFlusher(nil, cmpNormalBytes) - for bp < len(b) { - rb.out = b[bp:] - if bp = decomposeSegment(&rb, bp, true); bp < 0 { - return false - } - bp, _ = rb.f.quickSpan(rb.src, bp, len(b), true) - } - return true -} - -func cmpNormalBytes(rb *reorderBuffer) bool { - b := rb.out - for i := 0; i < rb.nrune; i++ { - info := rb.rune[i] - if int(info.size) > len(b) { - return false - } - p := info.pos - pe := p + info.size - for ; p < pe; p++ { - if b[0] != rb.byte[p] { - return false - } - b = b[1:] - } - } - return true -} - -// IsNormalString returns true if s == f(s). -func (f Form) IsNormalString(s string) bool { - src := inputString(s) - ft := formTable[f] - bp, ok := ft.quickSpan(src, 0, len(s), true) - if ok { - return true - } - rb := reorderBuffer{f: *ft, src: src, nsrc: len(s)} - rb.setFlusher(nil, func(rb *reorderBuffer) bool { - for i := 0; i < rb.nrune; i++ { - info := rb.rune[i] - if bp+int(info.size) > len(s) { - return false - } - p := info.pos - pe := p + info.size - for ; p < pe; p++ { - if s[bp] != rb.byte[p] { - return false - } - bp++ - } - } - return true - }) - for bp < len(s) { - if bp = decomposeSegment(&rb, bp, true); bp < 0 { - return false - } - bp, _ = rb.f.quickSpan(rb.src, bp, len(s), true) - } - return true -} - -// patchTail fixes a case where a rune may be incorrectly normalized -// if it is followed by illegal continuation bytes. It returns the -// patched buffer and whether the decomposition is still in progress. -func patchTail(rb *reorderBuffer) bool { - info, p := lastRuneStart(&rb.f, rb.out) - if p == -1 || info.size == 0 { - return true - } - end := p + int(info.size) - extra := len(rb.out) - end - if extra > 0 { - // Potentially allocating memory. However, this only - // happens with ill-formed UTF-8. - x := make([]byte, 0) - x = append(x, rb.out[len(rb.out)-extra:]...) - rb.out = rb.out[:end] - decomposeToLastBoundary(rb) - rb.doFlush() - rb.out = append(rb.out, x...) - return false - } - buf := rb.out[p:] - rb.out = rb.out[:p] - decomposeToLastBoundary(rb) - if s := rb.ss.next(info); s == ssStarter { - rb.doFlush() - rb.ss.first(info) - } else if s == ssOverflow { - rb.doFlush() - rb.insertCGJ() - rb.ss = 0 - } - rb.insertUnsafe(inputBytes(buf), 0, info) - return true -} - -func appendQuick(rb *reorderBuffer, i int) int { - if rb.nsrc == i { - return i - } - end, _ := rb.f.quickSpan(rb.src, i, rb.nsrc, true) - rb.out = rb.src.appendSlice(rb.out, i, end) - return end -} - -// Append returns f(append(out, b...)). -// The buffer out must be nil, empty, or equal to f(out). -func (f Form) Append(out []byte, src ...byte) []byte { - return f.doAppend(out, inputBytes(src), len(src)) -} - -func (f Form) doAppend(out []byte, src input, n int) []byte { - if n == 0 { - return out - } - ft := formTable[f] - // Attempt to do a quickSpan first so we can avoid initializing the reorderBuffer. - if len(out) == 0 { - p, _ := ft.quickSpan(src, 0, n, true) - out = src.appendSlice(out, 0, p) - if p == n { - return out - } - rb := reorderBuffer{f: *ft, src: src, nsrc: n, out: out, flushF: appendFlush} - return doAppendInner(&rb, p) - } - rb := reorderBuffer{f: *ft, src: src, nsrc: n} - return doAppend(&rb, out, 0) -} - -func doAppend(rb *reorderBuffer, out []byte, p int) []byte { - rb.setFlusher(out, appendFlush) - src, n := rb.src, rb.nsrc - doMerge := len(out) > 0 - if q := src.skipContinuationBytes(p); q > p { - // Move leading non-starters to destination. - rb.out = src.appendSlice(rb.out, p, q) - p = q - doMerge = patchTail(rb) - } - fd := &rb.f - if doMerge { - var info Properties - if p < n { - info = fd.info(src, p) - if !info.BoundaryBefore() || info.nLeadingNonStarters() > 0 { - if p == 0 { - decomposeToLastBoundary(rb) - } - p = decomposeSegment(rb, p, true) - } - } - if info.size == 0 { - rb.doFlush() - // Append incomplete UTF-8 encoding. - return src.appendSlice(rb.out, p, n) - } - if rb.nrune > 0 { - return doAppendInner(rb, p) - } - } - p = appendQuick(rb, p) - return doAppendInner(rb, p) -} - -func doAppendInner(rb *reorderBuffer, p int) []byte { - for n := rb.nsrc; p < n; { - p = decomposeSegment(rb, p, true) - p = appendQuick(rb, p) - } - return rb.out -} - -// AppendString returns f(append(out, []byte(s))). -// The buffer out must be nil, empty, or equal to f(out). -func (f Form) AppendString(out []byte, src string) []byte { - return f.doAppend(out, inputString(src), len(src)) -} - -// QuickSpan returns a boundary n such that b[0:n] == f(b[0:n]). -// It is not guaranteed to return the largest such n. -func (f Form) QuickSpan(b []byte) int { - n, _ := formTable[f].quickSpan(inputBytes(b), 0, len(b), true) - return n -} - -// quickSpan returns a boundary n such that src[0:n] == f(src[0:n]) and -// whether any non-normalized parts were found. If atEOF is false, n will -// not point past the last segment if this segment might be become -// non-normalized by appending other runes. -func (f *formInfo) quickSpan(src input, i, end int, atEOF bool) (n int, ok bool) { - var lastCC uint8 - ss := streamSafe(0) - lastSegStart := i - for n = end; i < n; { - if j := src.skipASCII(i, n); i != j { - i = j - lastSegStart = i - 1 - lastCC = 0 - ss = 0 - continue - } - info := f.info(src, i) - if info.size == 0 { - if atEOF { - // include incomplete runes - return n, true - } - return lastSegStart, true - } - // This block needs to be before the next, because it is possible to - // have an overflow for runes that are starters (e.g. with U+FF9E). - switch ss.next(info) { - case ssStarter: - ss.first(info) - lastSegStart = i - case ssOverflow: - return lastSegStart, false - case ssSuccess: - if lastCC > info.ccc { - return lastSegStart, false - } - } - if f.composing { - if !info.isYesC() { - break - } - } else { - if !info.isYesD() { - break - } - } - lastCC = info.ccc - i += int(info.size) - } - if i == n { - if !atEOF { - n = lastSegStart - } - return n, true - } - return lastSegStart, false -} - -// QuickSpanString returns a boundary n such that b[0:n] == f(s[0:n]). -// It is not guaranteed to return the largest such n. -func (f Form) QuickSpanString(s string) int { - n, _ := formTable[f].quickSpan(inputString(s), 0, len(s), true) - return n -} - -// FirstBoundary returns the position i of the first boundary in b -// or -1 if b contains no boundary. -func (f Form) FirstBoundary(b []byte) int { - return f.firstBoundary(inputBytes(b), len(b)) -} - -func (f Form) firstBoundary(src input, nsrc int) int { - i := src.skipContinuationBytes(0) - if i >= nsrc { - return -1 - } - fd := formTable[f] - ss := streamSafe(0) - // We should call ss.first here, but we can't as the first rune is - // skipped already. This means FirstBoundary can't really determine - // CGJ insertion points correctly. Luckily it doesn't have to. - for { - info := fd.info(src, i) - if info.size == 0 { - return -1 - } - if s := ss.next(info); s != ssSuccess { - return i - } - i += int(info.size) - if i >= nsrc { - if !info.BoundaryAfter() && !ss.isMax() { - return -1 - } - return nsrc - } - } -} - -// FirstBoundaryInString returns the position i of the first boundary in s -// or -1 if s contains no boundary. -func (f Form) FirstBoundaryInString(s string) int { - return f.firstBoundary(inputString(s), len(s)) -} - -// NextBoundary reports the index of the boundary between the first and next -// segment in b or -1 if atEOF is false and there are not enough bytes to -// determine this boundary. -func (f Form) NextBoundary(b []byte, atEOF bool) int { - return f.nextBoundary(inputBytes(b), len(b), atEOF) -} - -// NextBoundaryInString reports the index of the boundary between the first and -// next segment in b or -1 if atEOF is false and there are not enough bytes to -// determine this boundary. -func (f Form) NextBoundaryInString(s string, atEOF bool) int { - return f.nextBoundary(inputString(s), len(s), atEOF) -} - -func (f Form) nextBoundary(src input, nsrc int, atEOF bool) int { - if nsrc == 0 { - if atEOF { - return 0 - } - return -1 - } - fd := formTable[f] - info := fd.info(src, 0) - if info.size == 0 { - if atEOF { - return 1 - } - return -1 - } - ss := streamSafe(0) - ss.first(info) - - for i := int(info.size); i < nsrc; i += int(info.size) { - info = fd.info(src, i) - if info.size == 0 { - if atEOF { - return i - } - return -1 - } - if s := ss.next(info); s != ssSuccess { - return i - } - } - if !atEOF && !info.BoundaryAfter() && !ss.isMax() { - return -1 - } - return nsrc -} - -// LastBoundary returns the position i of the last boundary in b -// or -1 if b contains no boundary. -func (f Form) LastBoundary(b []byte) int { - return lastBoundary(formTable[f], b) -} - -func lastBoundary(fd *formInfo, b []byte) int { - i := len(b) - info, p := lastRuneStart(fd, b) - if p == -1 { - return -1 - } - if info.size == 0 { // ends with incomplete rune - if p == 0 { // starts with incomplete rune - return -1 - } - i = p - info, p = lastRuneStart(fd, b[:i]) - if p == -1 { // incomplete UTF-8 encoding or non-starter bytes without a starter - return i - } - } - if p+int(info.size) != i { // trailing non-starter bytes: illegal UTF-8 - return i - } - if info.BoundaryAfter() { - return i - } - ss := streamSafe(0) - v := ss.backwards(info) - for i = p; i >= 0 && v != ssStarter; i = p { - info, p = lastRuneStart(fd, b[:i]) - if v = ss.backwards(info); v == ssOverflow { - break - } - if p+int(info.size) != i { - if p == -1 { // no boundary found - return -1 - } - return i // boundary after an illegal UTF-8 encoding - } - } - return i -} - -// decomposeSegment scans the first segment in src into rb. It inserts 0x034f -// (Grapheme Joiner) when it encounters a sequence of more than 30 non-starters -// and returns the number of bytes consumed from src or iShortDst or iShortSrc. -func decomposeSegment(rb *reorderBuffer, sp int, atEOF bool) int { - // Force one character to be consumed. - info := rb.f.info(rb.src, sp) - if info.size == 0 { - return 0 - } - if rb.nrune > 0 { - if s := rb.ss.next(info); s == ssStarter { - goto end - } else if s == ssOverflow { - rb.insertCGJ() - goto end - } - } else { - rb.ss.first(info) - } - if err := rb.insertFlush(rb.src, sp, info); err != iSuccess { - return int(err) - } - for { - sp += int(info.size) - if sp >= rb.nsrc { - if !atEOF && !info.BoundaryAfter() { - return int(iShortSrc) - } - break - } - info = rb.f.info(rb.src, sp) - if info.size == 0 { - if !atEOF { - return int(iShortSrc) - } - break - } - if s := rb.ss.next(info); s == ssStarter { - break - } else if s == ssOverflow { - rb.insertCGJ() - break - } - if err := rb.insertFlush(rb.src, sp, info); err != iSuccess { - return int(err) - } - } -end: - if !rb.doFlush() { - return int(iShortDst) - } - return sp -} - -// lastRuneStart returns the runeInfo and position of the last -// rune in buf or the zero runeInfo and -1 if no rune was found. -func lastRuneStart(fd *formInfo, buf []byte) (Properties, int) { - p := len(buf) - 1 - for ; p >= 0 && !utf8.RuneStart(buf[p]); p-- { - } - if p < 0 { - return Properties{}, -1 - } - return fd.info(inputBytes(buf), p), p -} - -// decomposeToLastBoundary finds an open segment at the end of the buffer -// and scans it into rb. Returns the buffer minus the last segment. -func decomposeToLastBoundary(rb *reorderBuffer) { - fd := &rb.f - info, i := lastRuneStart(fd, rb.out) - if int(info.size) != len(rb.out)-i { - // illegal trailing continuation bytes - return - } - if info.BoundaryAfter() { - return - } - var add [maxNonStarters + 1]Properties // stores runeInfo in reverse order - padd := 0 - ss := streamSafe(0) - p := len(rb.out) - for { - add[padd] = info - v := ss.backwards(info) - if v == ssOverflow { - // Note that if we have an overflow, it the string we are appending to - // is not correctly normalized. In this case the behavior is undefined. - break - } - padd++ - p -= int(info.size) - if v == ssStarter || p < 0 { - break - } - info, i = lastRuneStart(fd, rb.out[:p]) - if int(info.size) != p-i { - break - } - } - rb.ss = ss - // Copy bytes for insertion as we may need to overwrite rb.out. - var buf [maxBufferSize * utf8.UTFMax]byte - cp := buf[:copy(buf[:], rb.out[p:])] - rb.out = rb.out[:p] - for padd--; padd >= 0; padd-- { - info = add[padd] - rb.insertUnsafe(inputBytes(cp), 0, info) - cp = cp[info.size:] - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/readwriter.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/readwriter.go deleted file mode 100644 index 4fa0e04..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/readwriter.go +++ /dev/null @@ -1,126 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -import "io" - -type normWriter struct { - rb reorderBuffer - w io.Writer - buf []byte -} - -// Write implements the standard write interface. If the last characters are -// not at a normalization boundary, the bytes will be buffered for the next -// write. The remaining bytes will be written on close. -func (w *normWriter) Write(data []byte) (n int, err error) { - // Process data in pieces to keep w.buf size bounded. - const chunk = 4000 - - for len(data) > 0 { - // Normalize into w.buf. - m := len(data) - if m > chunk { - m = chunk - } - w.rb.src = inputBytes(data[:m]) - w.rb.nsrc = m - w.buf = doAppend(&w.rb, w.buf, 0) - data = data[m:] - n += m - - // Write out complete prefix, save remainder. - // Note that lastBoundary looks back at most 31 runes. - i := lastBoundary(&w.rb.f, w.buf) - if i == -1 { - i = 0 - } - if i > 0 { - if _, err = w.w.Write(w.buf[:i]); err != nil { - break - } - bn := copy(w.buf, w.buf[i:]) - w.buf = w.buf[:bn] - } - } - return n, err -} - -// Close forces data that remains in the buffer to be written. -func (w *normWriter) Close() error { - if len(w.buf) > 0 { - _, err := w.w.Write(w.buf) - if err != nil { - return err - } - } - return nil -} - -// Writer returns a new writer that implements Write(b) -// by writing f(b) to w. The returned writer may use an -// an internal buffer to maintain state across Write calls. -// Calling its Close method writes any buffered data to w. -func (f Form) Writer(w io.Writer) io.WriteCloser { - wr := &normWriter{rb: reorderBuffer{}, w: w} - wr.rb.init(f, nil) - return wr -} - -type normReader struct { - rb reorderBuffer - r io.Reader - inbuf []byte - outbuf []byte - bufStart int - lastBoundary int - err error -} - -// Read implements the standard read interface. -func (r *normReader) Read(p []byte) (int, error) { - for { - if r.lastBoundary-r.bufStart > 0 { - n := copy(p, r.outbuf[r.bufStart:r.lastBoundary]) - r.bufStart += n - if r.lastBoundary-r.bufStart > 0 { - return n, nil - } - return n, r.err - } - if r.err != nil { - return 0, r.err - } - outn := copy(r.outbuf, r.outbuf[r.lastBoundary:]) - r.outbuf = r.outbuf[0:outn] - r.bufStart = 0 - - n, err := r.r.Read(r.inbuf) - r.rb.src = inputBytes(r.inbuf[0:n]) - r.rb.nsrc, r.err = n, err - if n > 0 { - r.outbuf = doAppend(&r.rb, r.outbuf, 0) - } - if err == io.EOF { - r.lastBoundary = len(r.outbuf) - } else { - r.lastBoundary = lastBoundary(&r.rb.f, r.outbuf) - if r.lastBoundary == -1 { - r.lastBoundary = 0 - } - } - } - panic("should not reach here") -} - -// Reader returns a new reader that implements Read -// by reading data from r and returning f(data). -func (f Form) Reader(r io.Reader) io.Reader { - const chunk = 4000 - buf := make([]byte, chunk) - rr := &normReader{rb: reorderBuffer{}, r: r, inbuf: buf} - rr.rb.init(f, buf) - return rr -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/tables.go deleted file mode 100644 index a56697b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/tables.go +++ /dev/null @@ -1,7627 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package norm - -const ( - // Version is the Unicode edition from which the tables are derived. - Version = "9.0.0" - - // MaxTransformChunkSize indicates the maximum number of bytes that Transform - // may need to write atomically for any Form. Making a destination buffer at - // least this size ensures that Transform can always make progress and that - // the user does not need to grow the buffer on an ErrShortDst. - MaxTransformChunkSize = 35 + maxNonStarters*4 -) - -var ccc = [55]uint8{ - 0, 1, 7, 8, 9, 10, 11, 12, - 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, - 29, 30, 31, 32, 33, 34, 35, 36, - 84, 91, 103, 107, 118, 122, 129, 130, - 132, 202, 214, 216, 218, 220, 222, 224, - 226, 228, 230, 232, 233, 234, 240, -} - -const ( - firstMulti = 0x186D - firstCCC = 0x2C9E - endMulti = 0x2F60 - firstLeadingCCC = 0x4A44 - firstCCCZeroExcept = 0x4A5A - firstStarterWithNLead = 0x4A81 - lastDecomp = 0x4A83 - maxDecomp = 0x8000 -) - -// decomps: 19075 bytes -var decomps = [...]byte{ - // Bytes 0 - 3f - 0x00, 0x41, 0x20, 0x41, 0x21, 0x41, 0x22, 0x41, - 0x23, 0x41, 0x24, 0x41, 0x25, 0x41, 0x26, 0x41, - 0x27, 0x41, 0x28, 0x41, 0x29, 0x41, 0x2A, 0x41, - 0x2B, 0x41, 0x2C, 0x41, 0x2D, 0x41, 0x2E, 0x41, - 0x2F, 0x41, 0x30, 0x41, 0x31, 0x41, 0x32, 0x41, - 0x33, 0x41, 0x34, 0x41, 0x35, 0x41, 0x36, 0x41, - 0x37, 0x41, 0x38, 0x41, 0x39, 0x41, 0x3A, 0x41, - 0x3B, 0x41, 0x3C, 0x41, 0x3D, 0x41, 0x3E, 0x41, - // Bytes 40 - 7f - 0x3F, 0x41, 0x40, 0x41, 0x41, 0x41, 0x42, 0x41, - 0x43, 0x41, 0x44, 0x41, 0x45, 0x41, 0x46, 0x41, - 0x47, 0x41, 0x48, 0x41, 0x49, 0x41, 0x4A, 0x41, - 0x4B, 0x41, 0x4C, 0x41, 0x4D, 0x41, 0x4E, 0x41, - 0x4F, 0x41, 0x50, 0x41, 0x51, 0x41, 0x52, 0x41, - 0x53, 0x41, 0x54, 0x41, 0x55, 0x41, 0x56, 0x41, - 0x57, 0x41, 0x58, 0x41, 0x59, 0x41, 0x5A, 0x41, - 0x5B, 0x41, 0x5C, 0x41, 0x5D, 0x41, 0x5E, 0x41, - // Bytes 80 - bf - 0x5F, 0x41, 0x60, 0x41, 0x61, 0x41, 0x62, 0x41, - 0x63, 0x41, 0x64, 0x41, 0x65, 0x41, 0x66, 0x41, - 0x67, 0x41, 0x68, 0x41, 0x69, 0x41, 0x6A, 0x41, - 0x6B, 0x41, 0x6C, 0x41, 0x6D, 0x41, 0x6E, 0x41, - 0x6F, 0x41, 0x70, 0x41, 0x71, 0x41, 0x72, 0x41, - 0x73, 0x41, 0x74, 0x41, 0x75, 0x41, 0x76, 0x41, - 0x77, 0x41, 0x78, 0x41, 0x79, 0x41, 0x7A, 0x41, - 0x7B, 0x41, 0x7C, 0x41, 0x7D, 0x41, 0x7E, 0x42, - // Bytes c0 - ff - 0xC2, 0xA2, 0x42, 0xC2, 0xA3, 0x42, 0xC2, 0xA5, - 0x42, 0xC2, 0xA6, 0x42, 0xC2, 0xAC, 0x42, 0xC2, - 0xB7, 0x42, 0xC3, 0x86, 0x42, 0xC3, 0xB0, 0x42, - 0xC4, 0xA6, 0x42, 0xC4, 0xA7, 0x42, 0xC4, 0xB1, - 0x42, 0xC5, 0x8B, 0x42, 0xC5, 0x93, 0x42, 0xC6, - 0x8E, 0x42, 0xC6, 0x90, 0x42, 0xC6, 0xAB, 0x42, - 0xC8, 0xA2, 0x42, 0xC8, 0xB7, 0x42, 0xC9, 0x90, - 0x42, 0xC9, 0x91, 0x42, 0xC9, 0x92, 0x42, 0xC9, - // Bytes 100 - 13f - 0x94, 0x42, 0xC9, 0x95, 0x42, 0xC9, 0x99, 0x42, - 0xC9, 0x9B, 0x42, 0xC9, 0x9C, 0x42, 0xC9, 0x9F, - 0x42, 0xC9, 0xA1, 0x42, 0xC9, 0xA3, 0x42, 0xC9, - 0xA5, 0x42, 0xC9, 0xA6, 0x42, 0xC9, 0xA8, 0x42, - 0xC9, 0xA9, 0x42, 0xC9, 0xAA, 0x42, 0xC9, 0xAB, - 0x42, 0xC9, 0xAD, 0x42, 0xC9, 0xAF, 0x42, 0xC9, - 0xB0, 0x42, 0xC9, 0xB1, 0x42, 0xC9, 0xB2, 0x42, - 0xC9, 0xB3, 0x42, 0xC9, 0xB4, 0x42, 0xC9, 0xB5, - // Bytes 140 - 17f - 0x42, 0xC9, 0xB8, 0x42, 0xC9, 0xB9, 0x42, 0xC9, - 0xBB, 0x42, 0xCA, 0x81, 0x42, 0xCA, 0x82, 0x42, - 0xCA, 0x83, 0x42, 0xCA, 0x89, 0x42, 0xCA, 0x8A, - 0x42, 0xCA, 0x8B, 0x42, 0xCA, 0x8C, 0x42, 0xCA, - 0x90, 0x42, 0xCA, 0x91, 0x42, 0xCA, 0x92, 0x42, - 0xCA, 0x95, 0x42, 0xCA, 0x9D, 0x42, 0xCA, 0x9F, - 0x42, 0xCA, 0xB9, 0x42, 0xCE, 0x91, 0x42, 0xCE, - 0x92, 0x42, 0xCE, 0x93, 0x42, 0xCE, 0x94, 0x42, - // Bytes 180 - 1bf - 0xCE, 0x95, 0x42, 0xCE, 0x96, 0x42, 0xCE, 0x97, - 0x42, 0xCE, 0x98, 0x42, 0xCE, 0x99, 0x42, 0xCE, - 0x9A, 0x42, 0xCE, 0x9B, 0x42, 0xCE, 0x9C, 0x42, - 0xCE, 0x9D, 0x42, 0xCE, 0x9E, 0x42, 0xCE, 0x9F, - 0x42, 0xCE, 0xA0, 0x42, 0xCE, 0xA1, 0x42, 0xCE, - 0xA3, 0x42, 0xCE, 0xA4, 0x42, 0xCE, 0xA5, 0x42, - 0xCE, 0xA6, 0x42, 0xCE, 0xA7, 0x42, 0xCE, 0xA8, - 0x42, 0xCE, 0xA9, 0x42, 0xCE, 0xB1, 0x42, 0xCE, - // Bytes 1c0 - 1ff - 0xB2, 0x42, 0xCE, 0xB3, 0x42, 0xCE, 0xB4, 0x42, - 0xCE, 0xB5, 0x42, 0xCE, 0xB6, 0x42, 0xCE, 0xB7, - 0x42, 0xCE, 0xB8, 0x42, 0xCE, 0xB9, 0x42, 0xCE, - 0xBA, 0x42, 0xCE, 0xBB, 0x42, 0xCE, 0xBC, 0x42, - 0xCE, 0xBD, 0x42, 0xCE, 0xBE, 0x42, 0xCE, 0xBF, - 0x42, 0xCF, 0x80, 0x42, 0xCF, 0x81, 0x42, 0xCF, - 0x82, 0x42, 0xCF, 0x83, 0x42, 0xCF, 0x84, 0x42, - 0xCF, 0x85, 0x42, 0xCF, 0x86, 0x42, 0xCF, 0x87, - // Bytes 200 - 23f - 0x42, 0xCF, 0x88, 0x42, 0xCF, 0x89, 0x42, 0xCF, - 0x9C, 0x42, 0xCF, 0x9D, 0x42, 0xD0, 0xBD, 0x42, - 0xD1, 0x8A, 0x42, 0xD1, 0x8C, 0x42, 0xD7, 0x90, - 0x42, 0xD7, 0x91, 0x42, 0xD7, 0x92, 0x42, 0xD7, - 0x93, 0x42, 0xD7, 0x94, 0x42, 0xD7, 0x9B, 0x42, - 0xD7, 0x9C, 0x42, 0xD7, 0x9D, 0x42, 0xD7, 0xA2, - 0x42, 0xD7, 0xA8, 0x42, 0xD7, 0xAA, 0x42, 0xD8, - 0xA1, 0x42, 0xD8, 0xA7, 0x42, 0xD8, 0xA8, 0x42, - // Bytes 240 - 27f - 0xD8, 0xA9, 0x42, 0xD8, 0xAA, 0x42, 0xD8, 0xAB, - 0x42, 0xD8, 0xAC, 0x42, 0xD8, 0xAD, 0x42, 0xD8, - 0xAE, 0x42, 0xD8, 0xAF, 0x42, 0xD8, 0xB0, 0x42, - 0xD8, 0xB1, 0x42, 0xD8, 0xB2, 0x42, 0xD8, 0xB3, - 0x42, 0xD8, 0xB4, 0x42, 0xD8, 0xB5, 0x42, 0xD8, - 0xB6, 0x42, 0xD8, 0xB7, 0x42, 0xD8, 0xB8, 0x42, - 0xD8, 0xB9, 0x42, 0xD8, 0xBA, 0x42, 0xD9, 0x81, - 0x42, 0xD9, 0x82, 0x42, 0xD9, 0x83, 0x42, 0xD9, - // Bytes 280 - 2bf - 0x84, 0x42, 0xD9, 0x85, 0x42, 0xD9, 0x86, 0x42, - 0xD9, 0x87, 0x42, 0xD9, 0x88, 0x42, 0xD9, 0x89, - 0x42, 0xD9, 0x8A, 0x42, 0xD9, 0xAE, 0x42, 0xD9, - 0xAF, 0x42, 0xD9, 0xB1, 0x42, 0xD9, 0xB9, 0x42, - 0xD9, 0xBA, 0x42, 0xD9, 0xBB, 0x42, 0xD9, 0xBE, - 0x42, 0xD9, 0xBF, 0x42, 0xDA, 0x80, 0x42, 0xDA, - 0x83, 0x42, 0xDA, 0x84, 0x42, 0xDA, 0x86, 0x42, - 0xDA, 0x87, 0x42, 0xDA, 0x88, 0x42, 0xDA, 0x8C, - // Bytes 2c0 - 2ff - 0x42, 0xDA, 0x8D, 0x42, 0xDA, 0x8E, 0x42, 0xDA, - 0x91, 0x42, 0xDA, 0x98, 0x42, 0xDA, 0xA1, 0x42, - 0xDA, 0xA4, 0x42, 0xDA, 0xA6, 0x42, 0xDA, 0xA9, - 0x42, 0xDA, 0xAD, 0x42, 0xDA, 0xAF, 0x42, 0xDA, - 0xB1, 0x42, 0xDA, 0xB3, 0x42, 0xDA, 0xBA, 0x42, - 0xDA, 0xBB, 0x42, 0xDA, 0xBE, 0x42, 0xDB, 0x81, - 0x42, 0xDB, 0x85, 0x42, 0xDB, 0x86, 0x42, 0xDB, - 0x87, 0x42, 0xDB, 0x88, 0x42, 0xDB, 0x89, 0x42, - // Bytes 300 - 33f - 0xDB, 0x8B, 0x42, 0xDB, 0x8C, 0x42, 0xDB, 0x90, - 0x42, 0xDB, 0x92, 0x43, 0xE0, 0xBC, 0x8B, 0x43, - 0xE1, 0x83, 0x9C, 0x43, 0xE1, 0x84, 0x80, 0x43, - 0xE1, 0x84, 0x81, 0x43, 0xE1, 0x84, 0x82, 0x43, - 0xE1, 0x84, 0x83, 0x43, 0xE1, 0x84, 0x84, 0x43, - 0xE1, 0x84, 0x85, 0x43, 0xE1, 0x84, 0x86, 0x43, - 0xE1, 0x84, 0x87, 0x43, 0xE1, 0x84, 0x88, 0x43, - 0xE1, 0x84, 0x89, 0x43, 0xE1, 0x84, 0x8A, 0x43, - // Bytes 340 - 37f - 0xE1, 0x84, 0x8B, 0x43, 0xE1, 0x84, 0x8C, 0x43, - 0xE1, 0x84, 0x8D, 0x43, 0xE1, 0x84, 0x8E, 0x43, - 0xE1, 0x84, 0x8F, 0x43, 0xE1, 0x84, 0x90, 0x43, - 0xE1, 0x84, 0x91, 0x43, 0xE1, 0x84, 0x92, 0x43, - 0xE1, 0x84, 0x94, 0x43, 0xE1, 0x84, 0x95, 0x43, - 0xE1, 0x84, 0x9A, 0x43, 0xE1, 0x84, 0x9C, 0x43, - 0xE1, 0x84, 0x9D, 0x43, 0xE1, 0x84, 0x9E, 0x43, - 0xE1, 0x84, 0xA0, 0x43, 0xE1, 0x84, 0xA1, 0x43, - // Bytes 380 - 3bf - 0xE1, 0x84, 0xA2, 0x43, 0xE1, 0x84, 0xA3, 0x43, - 0xE1, 0x84, 0xA7, 0x43, 0xE1, 0x84, 0xA9, 0x43, - 0xE1, 0x84, 0xAB, 0x43, 0xE1, 0x84, 0xAC, 0x43, - 0xE1, 0x84, 0xAD, 0x43, 0xE1, 0x84, 0xAE, 0x43, - 0xE1, 0x84, 0xAF, 0x43, 0xE1, 0x84, 0xB2, 0x43, - 0xE1, 0x84, 0xB6, 0x43, 0xE1, 0x85, 0x80, 0x43, - 0xE1, 0x85, 0x87, 0x43, 0xE1, 0x85, 0x8C, 0x43, - 0xE1, 0x85, 0x97, 0x43, 0xE1, 0x85, 0x98, 0x43, - // Bytes 3c0 - 3ff - 0xE1, 0x85, 0x99, 0x43, 0xE1, 0x85, 0xA0, 0x43, - 0xE1, 0x86, 0x84, 0x43, 0xE1, 0x86, 0x85, 0x43, - 0xE1, 0x86, 0x88, 0x43, 0xE1, 0x86, 0x91, 0x43, - 0xE1, 0x86, 0x92, 0x43, 0xE1, 0x86, 0x94, 0x43, - 0xE1, 0x86, 0x9E, 0x43, 0xE1, 0x86, 0xA1, 0x43, - 0xE1, 0x87, 0x87, 0x43, 0xE1, 0x87, 0x88, 0x43, - 0xE1, 0x87, 0x8C, 0x43, 0xE1, 0x87, 0x8E, 0x43, - 0xE1, 0x87, 0x93, 0x43, 0xE1, 0x87, 0x97, 0x43, - // Bytes 400 - 43f - 0xE1, 0x87, 0x99, 0x43, 0xE1, 0x87, 0x9D, 0x43, - 0xE1, 0x87, 0x9F, 0x43, 0xE1, 0x87, 0xB1, 0x43, - 0xE1, 0x87, 0xB2, 0x43, 0xE1, 0xB4, 0x82, 0x43, - 0xE1, 0xB4, 0x96, 0x43, 0xE1, 0xB4, 0x97, 0x43, - 0xE1, 0xB4, 0x9C, 0x43, 0xE1, 0xB4, 0x9D, 0x43, - 0xE1, 0xB4, 0xA5, 0x43, 0xE1, 0xB5, 0xBB, 0x43, - 0xE1, 0xB6, 0x85, 0x43, 0xE2, 0x80, 0x82, 0x43, - 0xE2, 0x80, 0x83, 0x43, 0xE2, 0x80, 0x90, 0x43, - // Bytes 440 - 47f - 0xE2, 0x80, 0x93, 0x43, 0xE2, 0x80, 0x94, 0x43, - 0xE2, 0x82, 0xA9, 0x43, 0xE2, 0x86, 0x90, 0x43, - 0xE2, 0x86, 0x91, 0x43, 0xE2, 0x86, 0x92, 0x43, - 0xE2, 0x86, 0x93, 0x43, 0xE2, 0x88, 0x82, 0x43, - 0xE2, 0x88, 0x87, 0x43, 0xE2, 0x88, 0x91, 0x43, - 0xE2, 0x88, 0x92, 0x43, 0xE2, 0x94, 0x82, 0x43, - 0xE2, 0x96, 0xA0, 0x43, 0xE2, 0x97, 0x8B, 0x43, - 0xE2, 0xA6, 0x85, 0x43, 0xE2, 0xA6, 0x86, 0x43, - // Bytes 480 - 4bf - 0xE2, 0xB5, 0xA1, 0x43, 0xE3, 0x80, 0x81, 0x43, - 0xE3, 0x80, 0x82, 0x43, 0xE3, 0x80, 0x88, 0x43, - 0xE3, 0x80, 0x89, 0x43, 0xE3, 0x80, 0x8A, 0x43, - 0xE3, 0x80, 0x8B, 0x43, 0xE3, 0x80, 0x8C, 0x43, - 0xE3, 0x80, 0x8D, 0x43, 0xE3, 0x80, 0x8E, 0x43, - 0xE3, 0x80, 0x8F, 0x43, 0xE3, 0x80, 0x90, 0x43, - 0xE3, 0x80, 0x91, 0x43, 0xE3, 0x80, 0x92, 0x43, - 0xE3, 0x80, 0x94, 0x43, 0xE3, 0x80, 0x95, 0x43, - // Bytes 4c0 - 4ff - 0xE3, 0x80, 0x96, 0x43, 0xE3, 0x80, 0x97, 0x43, - 0xE3, 0x82, 0xA1, 0x43, 0xE3, 0x82, 0xA2, 0x43, - 0xE3, 0x82, 0xA3, 0x43, 0xE3, 0x82, 0xA4, 0x43, - 0xE3, 0x82, 0xA5, 0x43, 0xE3, 0x82, 0xA6, 0x43, - 0xE3, 0x82, 0xA7, 0x43, 0xE3, 0x82, 0xA8, 0x43, - 0xE3, 0x82, 0xA9, 0x43, 0xE3, 0x82, 0xAA, 0x43, - 0xE3, 0x82, 0xAB, 0x43, 0xE3, 0x82, 0xAD, 0x43, - 0xE3, 0x82, 0xAF, 0x43, 0xE3, 0x82, 0xB1, 0x43, - // Bytes 500 - 53f - 0xE3, 0x82, 0xB3, 0x43, 0xE3, 0x82, 0xB5, 0x43, - 0xE3, 0x82, 0xB7, 0x43, 0xE3, 0x82, 0xB9, 0x43, - 0xE3, 0x82, 0xBB, 0x43, 0xE3, 0x82, 0xBD, 0x43, - 0xE3, 0x82, 0xBF, 0x43, 0xE3, 0x83, 0x81, 0x43, - 0xE3, 0x83, 0x83, 0x43, 0xE3, 0x83, 0x84, 0x43, - 0xE3, 0x83, 0x86, 0x43, 0xE3, 0x83, 0x88, 0x43, - 0xE3, 0x83, 0x8A, 0x43, 0xE3, 0x83, 0x8B, 0x43, - 0xE3, 0x83, 0x8C, 0x43, 0xE3, 0x83, 0x8D, 0x43, - // Bytes 540 - 57f - 0xE3, 0x83, 0x8E, 0x43, 0xE3, 0x83, 0x8F, 0x43, - 0xE3, 0x83, 0x92, 0x43, 0xE3, 0x83, 0x95, 0x43, - 0xE3, 0x83, 0x98, 0x43, 0xE3, 0x83, 0x9B, 0x43, - 0xE3, 0x83, 0x9E, 0x43, 0xE3, 0x83, 0x9F, 0x43, - 0xE3, 0x83, 0xA0, 0x43, 0xE3, 0x83, 0xA1, 0x43, - 0xE3, 0x83, 0xA2, 0x43, 0xE3, 0x83, 0xA3, 0x43, - 0xE3, 0x83, 0xA4, 0x43, 0xE3, 0x83, 0xA5, 0x43, - 0xE3, 0x83, 0xA6, 0x43, 0xE3, 0x83, 0xA7, 0x43, - // Bytes 580 - 5bf - 0xE3, 0x83, 0xA8, 0x43, 0xE3, 0x83, 0xA9, 0x43, - 0xE3, 0x83, 0xAA, 0x43, 0xE3, 0x83, 0xAB, 0x43, - 0xE3, 0x83, 0xAC, 0x43, 0xE3, 0x83, 0xAD, 0x43, - 0xE3, 0x83, 0xAF, 0x43, 0xE3, 0x83, 0xB0, 0x43, - 0xE3, 0x83, 0xB1, 0x43, 0xE3, 0x83, 0xB2, 0x43, - 0xE3, 0x83, 0xB3, 0x43, 0xE3, 0x83, 0xBB, 0x43, - 0xE3, 0x83, 0xBC, 0x43, 0xE3, 0x92, 0x9E, 0x43, - 0xE3, 0x92, 0xB9, 0x43, 0xE3, 0x92, 0xBB, 0x43, - // Bytes 5c0 - 5ff - 0xE3, 0x93, 0x9F, 0x43, 0xE3, 0x94, 0x95, 0x43, - 0xE3, 0x9B, 0xAE, 0x43, 0xE3, 0x9B, 0xBC, 0x43, - 0xE3, 0x9E, 0x81, 0x43, 0xE3, 0xA0, 0xAF, 0x43, - 0xE3, 0xA1, 0xA2, 0x43, 0xE3, 0xA1, 0xBC, 0x43, - 0xE3, 0xA3, 0x87, 0x43, 0xE3, 0xA3, 0xA3, 0x43, - 0xE3, 0xA4, 0x9C, 0x43, 0xE3, 0xA4, 0xBA, 0x43, - 0xE3, 0xA8, 0xAE, 0x43, 0xE3, 0xA9, 0xAC, 0x43, - 0xE3, 0xAB, 0xA4, 0x43, 0xE3, 0xAC, 0x88, 0x43, - // Bytes 600 - 63f - 0xE3, 0xAC, 0x99, 0x43, 0xE3, 0xAD, 0x89, 0x43, - 0xE3, 0xAE, 0x9D, 0x43, 0xE3, 0xB0, 0x98, 0x43, - 0xE3, 0xB1, 0x8E, 0x43, 0xE3, 0xB4, 0xB3, 0x43, - 0xE3, 0xB6, 0x96, 0x43, 0xE3, 0xBA, 0xAC, 0x43, - 0xE3, 0xBA, 0xB8, 0x43, 0xE3, 0xBC, 0x9B, 0x43, - 0xE3, 0xBF, 0xBC, 0x43, 0xE4, 0x80, 0x88, 0x43, - 0xE4, 0x80, 0x98, 0x43, 0xE4, 0x80, 0xB9, 0x43, - 0xE4, 0x81, 0x86, 0x43, 0xE4, 0x82, 0x96, 0x43, - // Bytes 640 - 67f - 0xE4, 0x83, 0xA3, 0x43, 0xE4, 0x84, 0xAF, 0x43, - 0xE4, 0x88, 0x82, 0x43, 0xE4, 0x88, 0xA7, 0x43, - 0xE4, 0x8A, 0xA0, 0x43, 0xE4, 0x8C, 0x81, 0x43, - 0xE4, 0x8C, 0xB4, 0x43, 0xE4, 0x8D, 0x99, 0x43, - 0xE4, 0x8F, 0x95, 0x43, 0xE4, 0x8F, 0x99, 0x43, - 0xE4, 0x90, 0x8B, 0x43, 0xE4, 0x91, 0xAB, 0x43, - 0xE4, 0x94, 0xAB, 0x43, 0xE4, 0x95, 0x9D, 0x43, - 0xE4, 0x95, 0xA1, 0x43, 0xE4, 0x95, 0xAB, 0x43, - // Bytes 680 - 6bf - 0xE4, 0x97, 0x97, 0x43, 0xE4, 0x97, 0xB9, 0x43, - 0xE4, 0x98, 0xB5, 0x43, 0xE4, 0x9A, 0xBE, 0x43, - 0xE4, 0x9B, 0x87, 0x43, 0xE4, 0xA6, 0x95, 0x43, - 0xE4, 0xA7, 0xA6, 0x43, 0xE4, 0xA9, 0xAE, 0x43, - 0xE4, 0xA9, 0xB6, 0x43, 0xE4, 0xAA, 0xB2, 0x43, - 0xE4, 0xAC, 0xB3, 0x43, 0xE4, 0xAF, 0x8E, 0x43, - 0xE4, 0xB3, 0x8E, 0x43, 0xE4, 0xB3, 0xAD, 0x43, - 0xE4, 0xB3, 0xB8, 0x43, 0xE4, 0xB5, 0x96, 0x43, - // Bytes 6c0 - 6ff - 0xE4, 0xB8, 0x80, 0x43, 0xE4, 0xB8, 0x81, 0x43, - 0xE4, 0xB8, 0x83, 0x43, 0xE4, 0xB8, 0x89, 0x43, - 0xE4, 0xB8, 0x8A, 0x43, 0xE4, 0xB8, 0x8B, 0x43, - 0xE4, 0xB8, 0x8D, 0x43, 0xE4, 0xB8, 0x99, 0x43, - 0xE4, 0xB8, 0xA6, 0x43, 0xE4, 0xB8, 0xA8, 0x43, - 0xE4, 0xB8, 0xAD, 0x43, 0xE4, 0xB8, 0xB2, 0x43, - 0xE4, 0xB8, 0xB6, 0x43, 0xE4, 0xB8, 0xB8, 0x43, - 0xE4, 0xB8, 0xB9, 0x43, 0xE4, 0xB8, 0xBD, 0x43, - // Bytes 700 - 73f - 0xE4, 0xB8, 0xBF, 0x43, 0xE4, 0xB9, 0x81, 0x43, - 0xE4, 0xB9, 0x99, 0x43, 0xE4, 0xB9, 0x9D, 0x43, - 0xE4, 0xBA, 0x82, 0x43, 0xE4, 0xBA, 0x85, 0x43, - 0xE4, 0xBA, 0x86, 0x43, 0xE4, 0xBA, 0x8C, 0x43, - 0xE4, 0xBA, 0x94, 0x43, 0xE4, 0xBA, 0xA0, 0x43, - 0xE4, 0xBA, 0xA4, 0x43, 0xE4, 0xBA, 0xAE, 0x43, - 0xE4, 0xBA, 0xBA, 0x43, 0xE4, 0xBB, 0x80, 0x43, - 0xE4, 0xBB, 0x8C, 0x43, 0xE4, 0xBB, 0xA4, 0x43, - // Bytes 740 - 77f - 0xE4, 0xBC, 0x81, 0x43, 0xE4, 0xBC, 0x91, 0x43, - 0xE4, 0xBD, 0xA0, 0x43, 0xE4, 0xBE, 0x80, 0x43, - 0xE4, 0xBE, 0x86, 0x43, 0xE4, 0xBE, 0x8B, 0x43, - 0xE4, 0xBE, 0xAE, 0x43, 0xE4, 0xBE, 0xBB, 0x43, - 0xE4, 0xBE, 0xBF, 0x43, 0xE5, 0x80, 0x82, 0x43, - 0xE5, 0x80, 0xAB, 0x43, 0xE5, 0x81, 0xBA, 0x43, - 0xE5, 0x82, 0x99, 0x43, 0xE5, 0x83, 0x8F, 0x43, - 0xE5, 0x83, 0x9A, 0x43, 0xE5, 0x83, 0xA7, 0x43, - // Bytes 780 - 7bf - 0xE5, 0x84, 0xAA, 0x43, 0xE5, 0x84, 0xBF, 0x43, - 0xE5, 0x85, 0x80, 0x43, 0xE5, 0x85, 0x85, 0x43, - 0xE5, 0x85, 0x8D, 0x43, 0xE5, 0x85, 0x94, 0x43, - 0xE5, 0x85, 0xA4, 0x43, 0xE5, 0x85, 0xA5, 0x43, - 0xE5, 0x85, 0xA7, 0x43, 0xE5, 0x85, 0xA8, 0x43, - 0xE5, 0x85, 0xA9, 0x43, 0xE5, 0x85, 0xAB, 0x43, - 0xE5, 0x85, 0xAD, 0x43, 0xE5, 0x85, 0xB7, 0x43, - 0xE5, 0x86, 0x80, 0x43, 0xE5, 0x86, 0x82, 0x43, - // Bytes 7c0 - 7ff - 0xE5, 0x86, 0x8D, 0x43, 0xE5, 0x86, 0x92, 0x43, - 0xE5, 0x86, 0x95, 0x43, 0xE5, 0x86, 0x96, 0x43, - 0xE5, 0x86, 0x97, 0x43, 0xE5, 0x86, 0x99, 0x43, - 0xE5, 0x86, 0xA4, 0x43, 0xE5, 0x86, 0xAB, 0x43, - 0xE5, 0x86, 0xAC, 0x43, 0xE5, 0x86, 0xB5, 0x43, - 0xE5, 0x86, 0xB7, 0x43, 0xE5, 0x87, 0x89, 0x43, - 0xE5, 0x87, 0x8C, 0x43, 0xE5, 0x87, 0x9C, 0x43, - 0xE5, 0x87, 0x9E, 0x43, 0xE5, 0x87, 0xA0, 0x43, - // Bytes 800 - 83f - 0xE5, 0x87, 0xB5, 0x43, 0xE5, 0x88, 0x80, 0x43, - 0xE5, 0x88, 0x83, 0x43, 0xE5, 0x88, 0x87, 0x43, - 0xE5, 0x88, 0x97, 0x43, 0xE5, 0x88, 0x9D, 0x43, - 0xE5, 0x88, 0xA9, 0x43, 0xE5, 0x88, 0xBA, 0x43, - 0xE5, 0x88, 0xBB, 0x43, 0xE5, 0x89, 0x86, 0x43, - 0xE5, 0x89, 0x8D, 0x43, 0xE5, 0x89, 0xB2, 0x43, - 0xE5, 0x89, 0xB7, 0x43, 0xE5, 0x8A, 0x89, 0x43, - 0xE5, 0x8A, 0x9B, 0x43, 0xE5, 0x8A, 0xA3, 0x43, - // Bytes 840 - 87f - 0xE5, 0x8A, 0xB3, 0x43, 0xE5, 0x8A, 0xB4, 0x43, - 0xE5, 0x8B, 0x87, 0x43, 0xE5, 0x8B, 0x89, 0x43, - 0xE5, 0x8B, 0x92, 0x43, 0xE5, 0x8B, 0x9E, 0x43, - 0xE5, 0x8B, 0xA4, 0x43, 0xE5, 0x8B, 0xB5, 0x43, - 0xE5, 0x8B, 0xB9, 0x43, 0xE5, 0x8B, 0xBA, 0x43, - 0xE5, 0x8C, 0x85, 0x43, 0xE5, 0x8C, 0x86, 0x43, - 0xE5, 0x8C, 0x95, 0x43, 0xE5, 0x8C, 0x97, 0x43, - 0xE5, 0x8C, 0x9A, 0x43, 0xE5, 0x8C, 0xB8, 0x43, - // Bytes 880 - 8bf - 0xE5, 0x8C, 0xBB, 0x43, 0xE5, 0x8C, 0xBF, 0x43, - 0xE5, 0x8D, 0x81, 0x43, 0xE5, 0x8D, 0x84, 0x43, - 0xE5, 0x8D, 0x85, 0x43, 0xE5, 0x8D, 0x89, 0x43, - 0xE5, 0x8D, 0x91, 0x43, 0xE5, 0x8D, 0x94, 0x43, - 0xE5, 0x8D, 0x9A, 0x43, 0xE5, 0x8D, 0x9C, 0x43, - 0xE5, 0x8D, 0xA9, 0x43, 0xE5, 0x8D, 0xB0, 0x43, - 0xE5, 0x8D, 0xB3, 0x43, 0xE5, 0x8D, 0xB5, 0x43, - 0xE5, 0x8D, 0xBD, 0x43, 0xE5, 0x8D, 0xBF, 0x43, - // Bytes 8c0 - 8ff - 0xE5, 0x8E, 0x82, 0x43, 0xE5, 0x8E, 0xB6, 0x43, - 0xE5, 0x8F, 0x83, 0x43, 0xE5, 0x8F, 0x88, 0x43, - 0xE5, 0x8F, 0x8A, 0x43, 0xE5, 0x8F, 0x8C, 0x43, - 0xE5, 0x8F, 0x9F, 0x43, 0xE5, 0x8F, 0xA3, 0x43, - 0xE5, 0x8F, 0xA5, 0x43, 0xE5, 0x8F, 0xAB, 0x43, - 0xE5, 0x8F, 0xAF, 0x43, 0xE5, 0x8F, 0xB1, 0x43, - 0xE5, 0x8F, 0xB3, 0x43, 0xE5, 0x90, 0x86, 0x43, - 0xE5, 0x90, 0x88, 0x43, 0xE5, 0x90, 0x8D, 0x43, - // Bytes 900 - 93f - 0xE5, 0x90, 0x8F, 0x43, 0xE5, 0x90, 0x9D, 0x43, - 0xE5, 0x90, 0xB8, 0x43, 0xE5, 0x90, 0xB9, 0x43, - 0xE5, 0x91, 0x82, 0x43, 0xE5, 0x91, 0x88, 0x43, - 0xE5, 0x91, 0xA8, 0x43, 0xE5, 0x92, 0x9E, 0x43, - 0xE5, 0x92, 0xA2, 0x43, 0xE5, 0x92, 0xBD, 0x43, - 0xE5, 0x93, 0xB6, 0x43, 0xE5, 0x94, 0x90, 0x43, - 0xE5, 0x95, 0x8F, 0x43, 0xE5, 0x95, 0x93, 0x43, - 0xE5, 0x95, 0x95, 0x43, 0xE5, 0x95, 0xA3, 0x43, - // Bytes 940 - 97f - 0xE5, 0x96, 0x84, 0x43, 0xE5, 0x96, 0x87, 0x43, - 0xE5, 0x96, 0x99, 0x43, 0xE5, 0x96, 0x9D, 0x43, - 0xE5, 0x96, 0xAB, 0x43, 0xE5, 0x96, 0xB3, 0x43, - 0xE5, 0x96, 0xB6, 0x43, 0xE5, 0x97, 0x80, 0x43, - 0xE5, 0x97, 0x82, 0x43, 0xE5, 0x97, 0xA2, 0x43, - 0xE5, 0x98, 0x86, 0x43, 0xE5, 0x99, 0x91, 0x43, - 0xE5, 0x99, 0xA8, 0x43, 0xE5, 0x99, 0xB4, 0x43, - 0xE5, 0x9B, 0x97, 0x43, 0xE5, 0x9B, 0x9B, 0x43, - // Bytes 980 - 9bf - 0xE5, 0x9B, 0xB9, 0x43, 0xE5, 0x9C, 0x96, 0x43, - 0xE5, 0x9C, 0x97, 0x43, 0xE5, 0x9C, 0x9F, 0x43, - 0xE5, 0x9C, 0xB0, 0x43, 0xE5, 0x9E, 0x8B, 0x43, - 0xE5, 0x9F, 0x8E, 0x43, 0xE5, 0x9F, 0xB4, 0x43, - 0xE5, 0xA0, 0x8D, 0x43, 0xE5, 0xA0, 0xB1, 0x43, - 0xE5, 0xA0, 0xB2, 0x43, 0xE5, 0xA1, 0x80, 0x43, - 0xE5, 0xA1, 0x9A, 0x43, 0xE5, 0xA1, 0x9E, 0x43, - 0xE5, 0xA2, 0xA8, 0x43, 0xE5, 0xA2, 0xAC, 0x43, - // Bytes 9c0 - 9ff - 0xE5, 0xA2, 0xB3, 0x43, 0xE5, 0xA3, 0x98, 0x43, - 0xE5, 0xA3, 0x9F, 0x43, 0xE5, 0xA3, 0xAB, 0x43, - 0xE5, 0xA3, 0xAE, 0x43, 0xE5, 0xA3, 0xB0, 0x43, - 0xE5, 0xA3, 0xB2, 0x43, 0xE5, 0xA3, 0xB7, 0x43, - 0xE5, 0xA4, 0x82, 0x43, 0xE5, 0xA4, 0x86, 0x43, - 0xE5, 0xA4, 0x8A, 0x43, 0xE5, 0xA4, 0x95, 0x43, - 0xE5, 0xA4, 0x9A, 0x43, 0xE5, 0xA4, 0x9C, 0x43, - 0xE5, 0xA4, 0xA2, 0x43, 0xE5, 0xA4, 0xA7, 0x43, - // Bytes a00 - a3f - 0xE5, 0xA4, 0xA9, 0x43, 0xE5, 0xA5, 0x84, 0x43, - 0xE5, 0xA5, 0x88, 0x43, 0xE5, 0xA5, 0x91, 0x43, - 0xE5, 0xA5, 0x94, 0x43, 0xE5, 0xA5, 0xA2, 0x43, - 0xE5, 0xA5, 0xB3, 0x43, 0xE5, 0xA7, 0x98, 0x43, - 0xE5, 0xA7, 0xAC, 0x43, 0xE5, 0xA8, 0x9B, 0x43, - 0xE5, 0xA8, 0xA7, 0x43, 0xE5, 0xA9, 0xA2, 0x43, - 0xE5, 0xA9, 0xA6, 0x43, 0xE5, 0xAA, 0xB5, 0x43, - 0xE5, 0xAC, 0x88, 0x43, 0xE5, 0xAC, 0xA8, 0x43, - // Bytes a40 - a7f - 0xE5, 0xAC, 0xBE, 0x43, 0xE5, 0xAD, 0x90, 0x43, - 0xE5, 0xAD, 0x97, 0x43, 0xE5, 0xAD, 0xA6, 0x43, - 0xE5, 0xAE, 0x80, 0x43, 0xE5, 0xAE, 0x85, 0x43, - 0xE5, 0xAE, 0x97, 0x43, 0xE5, 0xAF, 0x83, 0x43, - 0xE5, 0xAF, 0x98, 0x43, 0xE5, 0xAF, 0xA7, 0x43, - 0xE5, 0xAF, 0xAE, 0x43, 0xE5, 0xAF, 0xB3, 0x43, - 0xE5, 0xAF, 0xB8, 0x43, 0xE5, 0xAF, 0xBF, 0x43, - 0xE5, 0xB0, 0x86, 0x43, 0xE5, 0xB0, 0x8F, 0x43, - // Bytes a80 - abf - 0xE5, 0xB0, 0xA2, 0x43, 0xE5, 0xB0, 0xB8, 0x43, - 0xE5, 0xB0, 0xBF, 0x43, 0xE5, 0xB1, 0xA0, 0x43, - 0xE5, 0xB1, 0xA2, 0x43, 0xE5, 0xB1, 0xA4, 0x43, - 0xE5, 0xB1, 0xA5, 0x43, 0xE5, 0xB1, 0xAE, 0x43, - 0xE5, 0xB1, 0xB1, 0x43, 0xE5, 0xB2, 0x8D, 0x43, - 0xE5, 0xB3, 0x80, 0x43, 0xE5, 0xB4, 0x99, 0x43, - 0xE5, 0xB5, 0x83, 0x43, 0xE5, 0xB5, 0x90, 0x43, - 0xE5, 0xB5, 0xAB, 0x43, 0xE5, 0xB5, 0xAE, 0x43, - // Bytes ac0 - aff - 0xE5, 0xB5, 0xBC, 0x43, 0xE5, 0xB6, 0xB2, 0x43, - 0xE5, 0xB6, 0xBA, 0x43, 0xE5, 0xB7, 0x9B, 0x43, - 0xE5, 0xB7, 0xA1, 0x43, 0xE5, 0xB7, 0xA2, 0x43, - 0xE5, 0xB7, 0xA5, 0x43, 0xE5, 0xB7, 0xA6, 0x43, - 0xE5, 0xB7, 0xB1, 0x43, 0xE5, 0xB7, 0xBD, 0x43, - 0xE5, 0xB7, 0xBE, 0x43, 0xE5, 0xB8, 0xA8, 0x43, - 0xE5, 0xB8, 0xBD, 0x43, 0xE5, 0xB9, 0xA9, 0x43, - 0xE5, 0xB9, 0xB2, 0x43, 0xE5, 0xB9, 0xB4, 0x43, - // Bytes b00 - b3f - 0xE5, 0xB9, 0xBA, 0x43, 0xE5, 0xB9, 0xBC, 0x43, - 0xE5, 0xB9, 0xBF, 0x43, 0xE5, 0xBA, 0xA6, 0x43, - 0xE5, 0xBA, 0xB0, 0x43, 0xE5, 0xBA, 0xB3, 0x43, - 0xE5, 0xBA, 0xB6, 0x43, 0xE5, 0xBB, 0x89, 0x43, - 0xE5, 0xBB, 0x8A, 0x43, 0xE5, 0xBB, 0x92, 0x43, - 0xE5, 0xBB, 0x93, 0x43, 0xE5, 0xBB, 0x99, 0x43, - 0xE5, 0xBB, 0xAC, 0x43, 0xE5, 0xBB, 0xB4, 0x43, - 0xE5, 0xBB, 0xBE, 0x43, 0xE5, 0xBC, 0x84, 0x43, - // Bytes b40 - b7f - 0xE5, 0xBC, 0x8B, 0x43, 0xE5, 0xBC, 0x93, 0x43, - 0xE5, 0xBC, 0xA2, 0x43, 0xE5, 0xBD, 0x90, 0x43, - 0xE5, 0xBD, 0x93, 0x43, 0xE5, 0xBD, 0xA1, 0x43, - 0xE5, 0xBD, 0xA2, 0x43, 0xE5, 0xBD, 0xA9, 0x43, - 0xE5, 0xBD, 0xAB, 0x43, 0xE5, 0xBD, 0xB3, 0x43, - 0xE5, 0xBE, 0x8B, 0x43, 0xE5, 0xBE, 0x8C, 0x43, - 0xE5, 0xBE, 0x97, 0x43, 0xE5, 0xBE, 0x9A, 0x43, - 0xE5, 0xBE, 0xA9, 0x43, 0xE5, 0xBE, 0xAD, 0x43, - // Bytes b80 - bbf - 0xE5, 0xBF, 0x83, 0x43, 0xE5, 0xBF, 0x8D, 0x43, - 0xE5, 0xBF, 0x97, 0x43, 0xE5, 0xBF, 0xB5, 0x43, - 0xE5, 0xBF, 0xB9, 0x43, 0xE6, 0x80, 0x92, 0x43, - 0xE6, 0x80, 0x9C, 0x43, 0xE6, 0x81, 0xB5, 0x43, - 0xE6, 0x82, 0x81, 0x43, 0xE6, 0x82, 0x94, 0x43, - 0xE6, 0x83, 0x87, 0x43, 0xE6, 0x83, 0x98, 0x43, - 0xE6, 0x83, 0xA1, 0x43, 0xE6, 0x84, 0x88, 0x43, - 0xE6, 0x85, 0x84, 0x43, 0xE6, 0x85, 0x88, 0x43, - // Bytes bc0 - bff - 0xE6, 0x85, 0x8C, 0x43, 0xE6, 0x85, 0x8E, 0x43, - 0xE6, 0x85, 0xA0, 0x43, 0xE6, 0x85, 0xA8, 0x43, - 0xE6, 0x85, 0xBA, 0x43, 0xE6, 0x86, 0x8E, 0x43, - 0xE6, 0x86, 0x90, 0x43, 0xE6, 0x86, 0xA4, 0x43, - 0xE6, 0x86, 0xAF, 0x43, 0xE6, 0x86, 0xB2, 0x43, - 0xE6, 0x87, 0x9E, 0x43, 0xE6, 0x87, 0xB2, 0x43, - 0xE6, 0x87, 0xB6, 0x43, 0xE6, 0x88, 0x80, 0x43, - 0xE6, 0x88, 0x88, 0x43, 0xE6, 0x88, 0x90, 0x43, - // Bytes c00 - c3f - 0xE6, 0x88, 0x9B, 0x43, 0xE6, 0x88, 0xAE, 0x43, - 0xE6, 0x88, 0xB4, 0x43, 0xE6, 0x88, 0xB6, 0x43, - 0xE6, 0x89, 0x8B, 0x43, 0xE6, 0x89, 0x93, 0x43, - 0xE6, 0x89, 0x9D, 0x43, 0xE6, 0x8A, 0x95, 0x43, - 0xE6, 0x8A, 0xB1, 0x43, 0xE6, 0x8B, 0x89, 0x43, - 0xE6, 0x8B, 0x8F, 0x43, 0xE6, 0x8B, 0x93, 0x43, - 0xE6, 0x8B, 0x94, 0x43, 0xE6, 0x8B, 0xBC, 0x43, - 0xE6, 0x8B, 0xBE, 0x43, 0xE6, 0x8C, 0x87, 0x43, - // Bytes c40 - c7f - 0xE6, 0x8C, 0xBD, 0x43, 0xE6, 0x8D, 0x90, 0x43, - 0xE6, 0x8D, 0x95, 0x43, 0xE6, 0x8D, 0xA8, 0x43, - 0xE6, 0x8D, 0xBB, 0x43, 0xE6, 0x8E, 0x83, 0x43, - 0xE6, 0x8E, 0xA0, 0x43, 0xE6, 0x8E, 0xA9, 0x43, - 0xE6, 0x8F, 0x84, 0x43, 0xE6, 0x8F, 0x85, 0x43, - 0xE6, 0x8F, 0xA4, 0x43, 0xE6, 0x90, 0x9C, 0x43, - 0xE6, 0x90, 0xA2, 0x43, 0xE6, 0x91, 0x92, 0x43, - 0xE6, 0x91, 0xA9, 0x43, 0xE6, 0x91, 0xB7, 0x43, - // Bytes c80 - cbf - 0xE6, 0x91, 0xBE, 0x43, 0xE6, 0x92, 0x9A, 0x43, - 0xE6, 0x92, 0x9D, 0x43, 0xE6, 0x93, 0x84, 0x43, - 0xE6, 0x94, 0xAF, 0x43, 0xE6, 0x94, 0xB4, 0x43, - 0xE6, 0x95, 0x8F, 0x43, 0xE6, 0x95, 0x96, 0x43, - 0xE6, 0x95, 0xAC, 0x43, 0xE6, 0x95, 0xB8, 0x43, - 0xE6, 0x96, 0x87, 0x43, 0xE6, 0x96, 0x97, 0x43, - 0xE6, 0x96, 0x99, 0x43, 0xE6, 0x96, 0xA4, 0x43, - 0xE6, 0x96, 0xB0, 0x43, 0xE6, 0x96, 0xB9, 0x43, - // Bytes cc0 - cff - 0xE6, 0x97, 0x85, 0x43, 0xE6, 0x97, 0xA0, 0x43, - 0xE6, 0x97, 0xA2, 0x43, 0xE6, 0x97, 0xA3, 0x43, - 0xE6, 0x97, 0xA5, 0x43, 0xE6, 0x98, 0x93, 0x43, - 0xE6, 0x98, 0xA0, 0x43, 0xE6, 0x99, 0x89, 0x43, - 0xE6, 0x99, 0xB4, 0x43, 0xE6, 0x9A, 0x88, 0x43, - 0xE6, 0x9A, 0x91, 0x43, 0xE6, 0x9A, 0x9C, 0x43, - 0xE6, 0x9A, 0xB4, 0x43, 0xE6, 0x9B, 0x86, 0x43, - 0xE6, 0x9B, 0xB0, 0x43, 0xE6, 0x9B, 0xB4, 0x43, - // Bytes d00 - d3f - 0xE6, 0x9B, 0xB8, 0x43, 0xE6, 0x9C, 0x80, 0x43, - 0xE6, 0x9C, 0x88, 0x43, 0xE6, 0x9C, 0x89, 0x43, - 0xE6, 0x9C, 0x97, 0x43, 0xE6, 0x9C, 0x9B, 0x43, - 0xE6, 0x9C, 0xA1, 0x43, 0xE6, 0x9C, 0xA8, 0x43, - 0xE6, 0x9D, 0x8E, 0x43, 0xE6, 0x9D, 0x93, 0x43, - 0xE6, 0x9D, 0x96, 0x43, 0xE6, 0x9D, 0x9E, 0x43, - 0xE6, 0x9D, 0xBB, 0x43, 0xE6, 0x9E, 0x85, 0x43, - 0xE6, 0x9E, 0x97, 0x43, 0xE6, 0x9F, 0xB3, 0x43, - // Bytes d40 - d7f - 0xE6, 0x9F, 0xBA, 0x43, 0xE6, 0xA0, 0x97, 0x43, - 0xE6, 0xA0, 0x9F, 0x43, 0xE6, 0xA0, 0xAA, 0x43, - 0xE6, 0xA1, 0x92, 0x43, 0xE6, 0xA2, 0x81, 0x43, - 0xE6, 0xA2, 0x85, 0x43, 0xE6, 0xA2, 0x8E, 0x43, - 0xE6, 0xA2, 0xA8, 0x43, 0xE6, 0xA4, 0x94, 0x43, - 0xE6, 0xA5, 0x82, 0x43, 0xE6, 0xA6, 0xA3, 0x43, - 0xE6, 0xA7, 0xAA, 0x43, 0xE6, 0xA8, 0x82, 0x43, - 0xE6, 0xA8, 0x93, 0x43, 0xE6, 0xAA, 0xA8, 0x43, - // Bytes d80 - dbf - 0xE6, 0xAB, 0x93, 0x43, 0xE6, 0xAB, 0x9B, 0x43, - 0xE6, 0xAC, 0x84, 0x43, 0xE6, 0xAC, 0xA0, 0x43, - 0xE6, 0xAC, 0xA1, 0x43, 0xE6, 0xAD, 0x94, 0x43, - 0xE6, 0xAD, 0xA2, 0x43, 0xE6, 0xAD, 0xA3, 0x43, - 0xE6, 0xAD, 0xB2, 0x43, 0xE6, 0xAD, 0xB7, 0x43, - 0xE6, 0xAD, 0xB9, 0x43, 0xE6, 0xAE, 0x9F, 0x43, - 0xE6, 0xAE, 0xAE, 0x43, 0xE6, 0xAE, 0xB3, 0x43, - 0xE6, 0xAE, 0xBA, 0x43, 0xE6, 0xAE, 0xBB, 0x43, - // Bytes dc0 - dff - 0xE6, 0xAF, 0x8B, 0x43, 0xE6, 0xAF, 0x8D, 0x43, - 0xE6, 0xAF, 0x94, 0x43, 0xE6, 0xAF, 0x9B, 0x43, - 0xE6, 0xB0, 0x8F, 0x43, 0xE6, 0xB0, 0x94, 0x43, - 0xE6, 0xB0, 0xB4, 0x43, 0xE6, 0xB1, 0x8E, 0x43, - 0xE6, 0xB1, 0xA7, 0x43, 0xE6, 0xB2, 0x88, 0x43, - 0xE6, 0xB2, 0xBF, 0x43, 0xE6, 0xB3, 0x8C, 0x43, - 0xE6, 0xB3, 0x8D, 0x43, 0xE6, 0xB3, 0xA5, 0x43, - 0xE6, 0xB3, 0xA8, 0x43, 0xE6, 0xB4, 0x96, 0x43, - // Bytes e00 - e3f - 0xE6, 0xB4, 0x9B, 0x43, 0xE6, 0xB4, 0x9E, 0x43, - 0xE6, 0xB4, 0xB4, 0x43, 0xE6, 0xB4, 0xBE, 0x43, - 0xE6, 0xB5, 0x81, 0x43, 0xE6, 0xB5, 0xA9, 0x43, - 0xE6, 0xB5, 0xAA, 0x43, 0xE6, 0xB5, 0xB7, 0x43, - 0xE6, 0xB5, 0xB8, 0x43, 0xE6, 0xB6, 0x85, 0x43, - 0xE6, 0xB7, 0x8B, 0x43, 0xE6, 0xB7, 0x9A, 0x43, - 0xE6, 0xB7, 0xAA, 0x43, 0xE6, 0xB7, 0xB9, 0x43, - 0xE6, 0xB8, 0x9A, 0x43, 0xE6, 0xB8, 0xAF, 0x43, - // Bytes e40 - e7f - 0xE6, 0xB9, 0xAE, 0x43, 0xE6, 0xBA, 0x80, 0x43, - 0xE6, 0xBA, 0x9C, 0x43, 0xE6, 0xBA, 0xBA, 0x43, - 0xE6, 0xBB, 0x87, 0x43, 0xE6, 0xBB, 0x8B, 0x43, - 0xE6, 0xBB, 0x91, 0x43, 0xE6, 0xBB, 0x9B, 0x43, - 0xE6, 0xBC, 0x8F, 0x43, 0xE6, 0xBC, 0x94, 0x43, - 0xE6, 0xBC, 0xA2, 0x43, 0xE6, 0xBC, 0xA3, 0x43, - 0xE6, 0xBD, 0xAE, 0x43, 0xE6, 0xBF, 0x86, 0x43, - 0xE6, 0xBF, 0xAB, 0x43, 0xE6, 0xBF, 0xBE, 0x43, - // Bytes e80 - ebf - 0xE7, 0x80, 0x9B, 0x43, 0xE7, 0x80, 0x9E, 0x43, - 0xE7, 0x80, 0xB9, 0x43, 0xE7, 0x81, 0x8A, 0x43, - 0xE7, 0x81, 0xAB, 0x43, 0xE7, 0x81, 0xB0, 0x43, - 0xE7, 0x81, 0xB7, 0x43, 0xE7, 0x81, 0xBD, 0x43, - 0xE7, 0x82, 0x99, 0x43, 0xE7, 0x82, 0xAD, 0x43, - 0xE7, 0x83, 0x88, 0x43, 0xE7, 0x83, 0x99, 0x43, - 0xE7, 0x84, 0xA1, 0x43, 0xE7, 0x85, 0x85, 0x43, - 0xE7, 0x85, 0x89, 0x43, 0xE7, 0x85, 0xAE, 0x43, - // Bytes ec0 - eff - 0xE7, 0x86, 0x9C, 0x43, 0xE7, 0x87, 0x8E, 0x43, - 0xE7, 0x87, 0x90, 0x43, 0xE7, 0x88, 0x90, 0x43, - 0xE7, 0x88, 0x9B, 0x43, 0xE7, 0x88, 0xA8, 0x43, - 0xE7, 0x88, 0xAA, 0x43, 0xE7, 0x88, 0xAB, 0x43, - 0xE7, 0x88, 0xB5, 0x43, 0xE7, 0x88, 0xB6, 0x43, - 0xE7, 0x88, 0xBB, 0x43, 0xE7, 0x88, 0xBF, 0x43, - 0xE7, 0x89, 0x87, 0x43, 0xE7, 0x89, 0x90, 0x43, - 0xE7, 0x89, 0x99, 0x43, 0xE7, 0x89, 0x9B, 0x43, - // Bytes f00 - f3f - 0xE7, 0x89, 0xA2, 0x43, 0xE7, 0x89, 0xB9, 0x43, - 0xE7, 0x8A, 0x80, 0x43, 0xE7, 0x8A, 0x95, 0x43, - 0xE7, 0x8A, 0xAC, 0x43, 0xE7, 0x8A, 0xAF, 0x43, - 0xE7, 0x8B, 0x80, 0x43, 0xE7, 0x8B, 0xBC, 0x43, - 0xE7, 0x8C, 0xAA, 0x43, 0xE7, 0x8D, 0xB5, 0x43, - 0xE7, 0x8D, 0xBA, 0x43, 0xE7, 0x8E, 0x84, 0x43, - 0xE7, 0x8E, 0x87, 0x43, 0xE7, 0x8E, 0x89, 0x43, - 0xE7, 0x8E, 0x8B, 0x43, 0xE7, 0x8E, 0xA5, 0x43, - // Bytes f40 - f7f - 0xE7, 0x8E, 0xB2, 0x43, 0xE7, 0x8F, 0x9E, 0x43, - 0xE7, 0x90, 0x86, 0x43, 0xE7, 0x90, 0x89, 0x43, - 0xE7, 0x90, 0xA2, 0x43, 0xE7, 0x91, 0x87, 0x43, - 0xE7, 0x91, 0x9C, 0x43, 0xE7, 0x91, 0xA9, 0x43, - 0xE7, 0x91, 0xB1, 0x43, 0xE7, 0x92, 0x85, 0x43, - 0xE7, 0x92, 0x89, 0x43, 0xE7, 0x92, 0x98, 0x43, - 0xE7, 0x93, 0x8A, 0x43, 0xE7, 0x93, 0x9C, 0x43, - 0xE7, 0x93, 0xA6, 0x43, 0xE7, 0x94, 0x86, 0x43, - // Bytes f80 - fbf - 0xE7, 0x94, 0x98, 0x43, 0xE7, 0x94, 0x9F, 0x43, - 0xE7, 0x94, 0xA4, 0x43, 0xE7, 0x94, 0xA8, 0x43, - 0xE7, 0x94, 0xB0, 0x43, 0xE7, 0x94, 0xB2, 0x43, - 0xE7, 0x94, 0xB3, 0x43, 0xE7, 0x94, 0xB7, 0x43, - 0xE7, 0x94, 0xBB, 0x43, 0xE7, 0x94, 0xBE, 0x43, - 0xE7, 0x95, 0x99, 0x43, 0xE7, 0x95, 0xA5, 0x43, - 0xE7, 0x95, 0xB0, 0x43, 0xE7, 0x96, 0x8B, 0x43, - 0xE7, 0x96, 0x92, 0x43, 0xE7, 0x97, 0xA2, 0x43, - // Bytes fc0 - fff - 0xE7, 0x98, 0x90, 0x43, 0xE7, 0x98, 0x9D, 0x43, - 0xE7, 0x98, 0x9F, 0x43, 0xE7, 0x99, 0x82, 0x43, - 0xE7, 0x99, 0xA9, 0x43, 0xE7, 0x99, 0xB6, 0x43, - 0xE7, 0x99, 0xBD, 0x43, 0xE7, 0x9A, 0xAE, 0x43, - 0xE7, 0x9A, 0xBF, 0x43, 0xE7, 0x9B, 0x8A, 0x43, - 0xE7, 0x9B, 0x9B, 0x43, 0xE7, 0x9B, 0xA3, 0x43, - 0xE7, 0x9B, 0xA7, 0x43, 0xE7, 0x9B, 0xAE, 0x43, - 0xE7, 0x9B, 0xB4, 0x43, 0xE7, 0x9C, 0x81, 0x43, - // Bytes 1000 - 103f - 0xE7, 0x9C, 0x9E, 0x43, 0xE7, 0x9C, 0x9F, 0x43, - 0xE7, 0x9D, 0x80, 0x43, 0xE7, 0x9D, 0x8A, 0x43, - 0xE7, 0x9E, 0x8B, 0x43, 0xE7, 0x9E, 0xA7, 0x43, - 0xE7, 0x9F, 0x9B, 0x43, 0xE7, 0x9F, 0xA2, 0x43, - 0xE7, 0x9F, 0xB3, 0x43, 0xE7, 0xA1, 0x8E, 0x43, - 0xE7, 0xA1, 0xAB, 0x43, 0xE7, 0xA2, 0x8C, 0x43, - 0xE7, 0xA2, 0x91, 0x43, 0xE7, 0xA3, 0x8A, 0x43, - 0xE7, 0xA3, 0x8C, 0x43, 0xE7, 0xA3, 0xBB, 0x43, - // Bytes 1040 - 107f - 0xE7, 0xA4, 0xAA, 0x43, 0xE7, 0xA4, 0xBA, 0x43, - 0xE7, 0xA4, 0xBC, 0x43, 0xE7, 0xA4, 0xBE, 0x43, - 0xE7, 0xA5, 0x88, 0x43, 0xE7, 0xA5, 0x89, 0x43, - 0xE7, 0xA5, 0x90, 0x43, 0xE7, 0xA5, 0x96, 0x43, - 0xE7, 0xA5, 0x9D, 0x43, 0xE7, 0xA5, 0x9E, 0x43, - 0xE7, 0xA5, 0xA5, 0x43, 0xE7, 0xA5, 0xBF, 0x43, - 0xE7, 0xA6, 0x81, 0x43, 0xE7, 0xA6, 0x8D, 0x43, - 0xE7, 0xA6, 0x8E, 0x43, 0xE7, 0xA6, 0x8F, 0x43, - // Bytes 1080 - 10bf - 0xE7, 0xA6, 0xAE, 0x43, 0xE7, 0xA6, 0xB8, 0x43, - 0xE7, 0xA6, 0xBE, 0x43, 0xE7, 0xA7, 0x8A, 0x43, - 0xE7, 0xA7, 0x98, 0x43, 0xE7, 0xA7, 0xAB, 0x43, - 0xE7, 0xA8, 0x9C, 0x43, 0xE7, 0xA9, 0x80, 0x43, - 0xE7, 0xA9, 0x8A, 0x43, 0xE7, 0xA9, 0x8F, 0x43, - 0xE7, 0xA9, 0xB4, 0x43, 0xE7, 0xA9, 0xBA, 0x43, - 0xE7, 0xAA, 0x81, 0x43, 0xE7, 0xAA, 0xB1, 0x43, - 0xE7, 0xAB, 0x8B, 0x43, 0xE7, 0xAB, 0xAE, 0x43, - // Bytes 10c0 - 10ff - 0xE7, 0xAB, 0xB9, 0x43, 0xE7, 0xAC, 0xA0, 0x43, - 0xE7, 0xAE, 0x8F, 0x43, 0xE7, 0xAF, 0x80, 0x43, - 0xE7, 0xAF, 0x86, 0x43, 0xE7, 0xAF, 0x89, 0x43, - 0xE7, 0xB0, 0xBE, 0x43, 0xE7, 0xB1, 0xA0, 0x43, - 0xE7, 0xB1, 0xB3, 0x43, 0xE7, 0xB1, 0xBB, 0x43, - 0xE7, 0xB2, 0x92, 0x43, 0xE7, 0xB2, 0xBE, 0x43, - 0xE7, 0xB3, 0x92, 0x43, 0xE7, 0xB3, 0x96, 0x43, - 0xE7, 0xB3, 0xA3, 0x43, 0xE7, 0xB3, 0xA7, 0x43, - // Bytes 1100 - 113f - 0xE7, 0xB3, 0xA8, 0x43, 0xE7, 0xB3, 0xB8, 0x43, - 0xE7, 0xB4, 0x80, 0x43, 0xE7, 0xB4, 0x90, 0x43, - 0xE7, 0xB4, 0xA2, 0x43, 0xE7, 0xB4, 0xAF, 0x43, - 0xE7, 0xB5, 0x82, 0x43, 0xE7, 0xB5, 0x9B, 0x43, - 0xE7, 0xB5, 0xA3, 0x43, 0xE7, 0xB6, 0xA0, 0x43, - 0xE7, 0xB6, 0xBE, 0x43, 0xE7, 0xB7, 0x87, 0x43, - 0xE7, 0xB7, 0xB4, 0x43, 0xE7, 0xB8, 0x82, 0x43, - 0xE7, 0xB8, 0x89, 0x43, 0xE7, 0xB8, 0xB7, 0x43, - // Bytes 1140 - 117f - 0xE7, 0xB9, 0x81, 0x43, 0xE7, 0xB9, 0x85, 0x43, - 0xE7, 0xBC, 0xB6, 0x43, 0xE7, 0xBC, 0xBE, 0x43, - 0xE7, 0xBD, 0x91, 0x43, 0xE7, 0xBD, 0xB2, 0x43, - 0xE7, 0xBD, 0xB9, 0x43, 0xE7, 0xBD, 0xBA, 0x43, - 0xE7, 0xBE, 0x85, 0x43, 0xE7, 0xBE, 0x8A, 0x43, - 0xE7, 0xBE, 0x95, 0x43, 0xE7, 0xBE, 0x9A, 0x43, - 0xE7, 0xBE, 0xBD, 0x43, 0xE7, 0xBF, 0xBA, 0x43, - 0xE8, 0x80, 0x81, 0x43, 0xE8, 0x80, 0x85, 0x43, - // Bytes 1180 - 11bf - 0xE8, 0x80, 0x8C, 0x43, 0xE8, 0x80, 0x92, 0x43, - 0xE8, 0x80, 0xB3, 0x43, 0xE8, 0x81, 0x86, 0x43, - 0xE8, 0x81, 0xA0, 0x43, 0xE8, 0x81, 0xAF, 0x43, - 0xE8, 0x81, 0xB0, 0x43, 0xE8, 0x81, 0xBE, 0x43, - 0xE8, 0x81, 0xBF, 0x43, 0xE8, 0x82, 0x89, 0x43, - 0xE8, 0x82, 0x8B, 0x43, 0xE8, 0x82, 0xAD, 0x43, - 0xE8, 0x82, 0xB2, 0x43, 0xE8, 0x84, 0x83, 0x43, - 0xE8, 0x84, 0xBE, 0x43, 0xE8, 0x87, 0x98, 0x43, - // Bytes 11c0 - 11ff - 0xE8, 0x87, 0xA3, 0x43, 0xE8, 0x87, 0xA8, 0x43, - 0xE8, 0x87, 0xAA, 0x43, 0xE8, 0x87, 0xAD, 0x43, - 0xE8, 0x87, 0xB3, 0x43, 0xE8, 0x87, 0xBC, 0x43, - 0xE8, 0x88, 0x81, 0x43, 0xE8, 0x88, 0x84, 0x43, - 0xE8, 0x88, 0x8C, 0x43, 0xE8, 0x88, 0x98, 0x43, - 0xE8, 0x88, 0x9B, 0x43, 0xE8, 0x88, 0x9F, 0x43, - 0xE8, 0x89, 0xAE, 0x43, 0xE8, 0x89, 0xAF, 0x43, - 0xE8, 0x89, 0xB2, 0x43, 0xE8, 0x89, 0xB8, 0x43, - // Bytes 1200 - 123f - 0xE8, 0x89, 0xB9, 0x43, 0xE8, 0x8A, 0x8B, 0x43, - 0xE8, 0x8A, 0x91, 0x43, 0xE8, 0x8A, 0x9D, 0x43, - 0xE8, 0x8A, 0xB1, 0x43, 0xE8, 0x8A, 0xB3, 0x43, - 0xE8, 0x8A, 0xBD, 0x43, 0xE8, 0x8B, 0xA5, 0x43, - 0xE8, 0x8B, 0xA6, 0x43, 0xE8, 0x8C, 0x9D, 0x43, - 0xE8, 0x8C, 0xA3, 0x43, 0xE8, 0x8C, 0xB6, 0x43, - 0xE8, 0x8D, 0x92, 0x43, 0xE8, 0x8D, 0x93, 0x43, - 0xE8, 0x8D, 0xA3, 0x43, 0xE8, 0x8E, 0xAD, 0x43, - // Bytes 1240 - 127f - 0xE8, 0x8E, 0xBD, 0x43, 0xE8, 0x8F, 0x89, 0x43, - 0xE8, 0x8F, 0x8A, 0x43, 0xE8, 0x8F, 0x8C, 0x43, - 0xE8, 0x8F, 0x9C, 0x43, 0xE8, 0x8F, 0xA7, 0x43, - 0xE8, 0x8F, 0xAF, 0x43, 0xE8, 0x8F, 0xB1, 0x43, - 0xE8, 0x90, 0xBD, 0x43, 0xE8, 0x91, 0x89, 0x43, - 0xE8, 0x91, 0x97, 0x43, 0xE8, 0x93, 0xAE, 0x43, - 0xE8, 0x93, 0xB1, 0x43, 0xE8, 0x93, 0xB3, 0x43, - 0xE8, 0x93, 0xBC, 0x43, 0xE8, 0x94, 0x96, 0x43, - // Bytes 1280 - 12bf - 0xE8, 0x95, 0xA4, 0x43, 0xE8, 0x97, 0x8D, 0x43, - 0xE8, 0x97, 0xBA, 0x43, 0xE8, 0x98, 0x86, 0x43, - 0xE8, 0x98, 0x92, 0x43, 0xE8, 0x98, 0xAD, 0x43, - 0xE8, 0x98, 0xBF, 0x43, 0xE8, 0x99, 0x8D, 0x43, - 0xE8, 0x99, 0x90, 0x43, 0xE8, 0x99, 0x9C, 0x43, - 0xE8, 0x99, 0xA7, 0x43, 0xE8, 0x99, 0xA9, 0x43, - 0xE8, 0x99, 0xAB, 0x43, 0xE8, 0x9A, 0x88, 0x43, - 0xE8, 0x9A, 0xA9, 0x43, 0xE8, 0x9B, 0xA2, 0x43, - // Bytes 12c0 - 12ff - 0xE8, 0x9C, 0x8E, 0x43, 0xE8, 0x9C, 0xA8, 0x43, - 0xE8, 0x9D, 0xAB, 0x43, 0xE8, 0x9D, 0xB9, 0x43, - 0xE8, 0x9E, 0x86, 0x43, 0xE8, 0x9E, 0xBA, 0x43, - 0xE8, 0x9F, 0xA1, 0x43, 0xE8, 0xA0, 0x81, 0x43, - 0xE8, 0xA0, 0x9F, 0x43, 0xE8, 0xA1, 0x80, 0x43, - 0xE8, 0xA1, 0x8C, 0x43, 0xE8, 0xA1, 0xA0, 0x43, - 0xE8, 0xA1, 0xA3, 0x43, 0xE8, 0xA3, 0x82, 0x43, - 0xE8, 0xA3, 0x8F, 0x43, 0xE8, 0xA3, 0x97, 0x43, - // Bytes 1300 - 133f - 0xE8, 0xA3, 0x9E, 0x43, 0xE8, 0xA3, 0xA1, 0x43, - 0xE8, 0xA3, 0xB8, 0x43, 0xE8, 0xA3, 0xBA, 0x43, - 0xE8, 0xA4, 0x90, 0x43, 0xE8, 0xA5, 0x81, 0x43, - 0xE8, 0xA5, 0xA4, 0x43, 0xE8, 0xA5, 0xBE, 0x43, - 0xE8, 0xA6, 0x86, 0x43, 0xE8, 0xA6, 0x8B, 0x43, - 0xE8, 0xA6, 0x96, 0x43, 0xE8, 0xA7, 0x92, 0x43, - 0xE8, 0xA7, 0xA3, 0x43, 0xE8, 0xA8, 0x80, 0x43, - 0xE8, 0xAA, 0xA0, 0x43, 0xE8, 0xAA, 0xAA, 0x43, - // Bytes 1340 - 137f - 0xE8, 0xAA, 0xBF, 0x43, 0xE8, 0xAB, 0x8B, 0x43, - 0xE8, 0xAB, 0x92, 0x43, 0xE8, 0xAB, 0x96, 0x43, - 0xE8, 0xAB, 0xAD, 0x43, 0xE8, 0xAB, 0xB8, 0x43, - 0xE8, 0xAB, 0xBE, 0x43, 0xE8, 0xAC, 0x81, 0x43, - 0xE8, 0xAC, 0xB9, 0x43, 0xE8, 0xAD, 0x98, 0x43, - 0xE8, 0xAE, 0x80, 0x43, 0xE8, 0xAE, 0x8A, 0x43, - 0xE8, 0xB0, 0xB7, 0x43, 0xE8, 0xB1, 0x86, 0x43, - 0xE8, 0xB1, 0x88, 0x43, 0xE8, 0xB1, 0x95, 0x43, - // Bytes 1380 - 13bf - 0xE8, 0xB1, 0xB8, 0x43, 0xE8, 0xB2, 0x9D, 0x43, - 0xE8, 0xB2, 0xA1, 0x43, 0xE8, 0xB2, 0xA9, 0x43, - 0xE8, 0xB2, 0xAB, 0x43, 0xE8, 0xB3, 0x81, 0x43, - 0xE8, 0xB3, 0x82, 0x43, 0xE8, 0xB3, 0x87, 0x43, - 0xE8, 0xB3, 0x88, 0x43, 0xE8, 0xB3, 0x93, 0x43, - 0xE8, 0xB4, 0x88, 0x43, 0xE8, 0xB4, 0x9B, 0x43, - 0xE8, 0xB5, 0xA4, 0x43, 0xE8, 0xB5, 0xB0, 0x43, - 0xE8, 0xB5, 0xB7, 0x43, 0xE8, 0xB6, 0xB3, 0x43, - // Bytes 13c0 - 13ff - 0xE8, 0xB6, 0xBC, 0x43, 0xE8, 0xB7, 0x8B, 0x43, - 0xE8, 0xB7, 0xAF, 0x43, 0xE8, 0xB7, 0xB0, 0x43, - 0xE8, 0xBA, 0xAB, 0x43, 0xE8, 0xBB, 0x8A, 0x43, - 0xE8, 0xBB, 0x94, 0x43, 0xE8, 0xBC, 0xA6, 0x43, - 0xE8, 0xBC, 0xAA, 0x43, 0xE8, 0xBC, 0xB8, 0x43, - 0xE8, 0xBC, 0xBB, 0x43, 0xE8, 0xBD, 0xA2, 0x43, - 0xE8, 0xBE, 0x9B, 0x43, 0xE8, 0xBE, 0x9E, 0x43, - 0xE8, 0xBE, 0xB0, 0x43, 0xE8, 0xBE, 0xB5, 0x43, - // Bytes 1400 - 143f - 0xE8, 0xBE, 0xB6, 0x43, 0xE9, 0x80, 0xA3, 0x43, - 0xE9, 0x80, 0xB8, 0x43, 0xE9, 0x81, 0x8A, 0x43, - 0xE9, 0x81, 0xA9, 0x43, 0xE9, 0x81, 0xB2, 0x43, - 0xE9, 0x81, 0xBC, 0x43, 0xE9, 0x82, 0x8F, 0x43, - 0xE9, 0x82, 0x91, 0x43, 0xE9, 0x82, 0x94, 0x43, - 0xE9, 0x83, 0x8E, 0x43, 0xE9, 0x83, 0x9E, 0x43, - 0xE9, 0x83, 0xB1, 0x43, 0xE9, 0x83, 0xBD, 0x43, - 0xE9, 0x84, 0x91, 0x43, 0xE9, 0x84, 0x9B, 0x43, - // Bytes 1440 - 147f - 0xE9, 0x85, 0x89, 0x43, 0xE9, 0x85, 0x8D, 0x43, - 0xE9, 0x85, 0xAA, 0x43, 0xE9, 0x86, 0x99, 0x43, - 0xE9, 0x86, 0xB4, 0x43, 0xE9, 0x87, 0x86, 0x43, - 0xE9, 0x87, 0x8C, 0x43, 0xE9, 0x87, 0x8F, 0x43, - 0xE9, 0x87, 0x91, 0x43, 0xE9, 0x88, 0xB4, 0x43, - 0xE9, 0x88, 0xB8, 0x43, 0xE9, 0x89, 0xB6, 0x43, - 0xE9, 0x89, 0xBC, 0x43, 0xE9, 0x8B, 0x97, 0x43, - 0xE9, 0x8B, 0x98, 0x43, 0xE9, 0x8C, 0x84, 0x43, - // Bytes 1480 - 14bf - 0xE9, 0x8D, 0x8A, 0x43, 0xE9, 0x8F, 0xB9, 0x43, - 0xE9, 0x90, 0x95, 0x43, 0xE9, 0x95, 0xB7, 0x43, - 0xE9, 0x96, 0x80, 0x43, 0xE9, 0x96, 0x8B, 0x43, - 0xE9, 0x96, 0xAD, 0x43, 0xE9, 0x96, 0xB7, 0x43, - 0xE9, 0x98, 0x9C, 0x43, 0xE9, 0x98, 0xAE, 0x43, - 0xE9, 0x99, 0x8B, 0x43, 0xE9, 0x99, 0x8D, 0x43, - 0xE9, 0x99, 0xB5, 0x43, 0xE9, 0x99, 0xB8, 0x43, - 0xE9, 0x99, 0xBC, 0x43, 0xE9, 0x9A, 0x86, 0x43, - // Bytes 14c0 - 14ff - 0xE9, 0x9A, 0xA3, 0x43, 0xE9, 0x9A, 0xB6, 0x43, - 0xE9, 0x9A, 0xB7, 0x43, 0xE9, 0x9A, 0xB8, 0x43, - 0xE9, 0x9A, 0xB9, 0x43, 0xE9, 0x9B, 0x83, 0x43, - 0xE9, 0x9B, 0xA2, 0x43, 0xE9, 0x9B, 0xA3, 0x43, - 0xE9, 0x9B, 0xA8, 0x43, 0xE9, 0x9B, 0xB6, 0x43, - 0xE9, 0x9B, 0xB7, 0x43, 0xE9, 0x9C, 0xA3, 0x43, - 0xE9, 0x9C, 0xB2, 0x43, 0xE9, 0x9D, 0x88, 0x43, - 0xE9, 0x9D, 0x91, 0x43, 0xE9, 0x9D, 0x96, 0x43, - // Bytes 1500 - 153f - 0xE9, 0x9D, 0x9E, 0x43, 0xE9, 0x9D, 0xA2, 0x43, - 0xE9, 0x9D, 0xA9, 0x43, 0xE9, 0x9F, 0x8B, 0x43, - 0xE9, 0x9F, 0x9B, 0x43, 0xE9, 0x9F, 0xA0, 0x43, - 0xE9, 0x9F, 0xAD, 0x43, 0xE9, 0x9F, 0xB3, 0x43, - 0xE9, 0x9F, 0xBF, 0x43, 0xE9, 0xA0, 0x81, 0x43, - 0xE9, 0xA0, 0x85, 0x43, 0xE9, 0xA0, 0x8B, 0x43, - 0xE9, 0xA0, 0x98, 0x43, 0xE9, 0xA0, 0xA9, 0x43, - 0xE9, 0xA0, 0xBB, 0x43, 0xE9, 0xA1, 0x9E, 0x43, - // Bytes 1540 - 157f - 0xE9, 0xA2, 0xA8, 0x43, 0xE9, 0xA3, 0x9B, 0x43, - 0xE9, 0xA3, 0x9F, 0x43, 0xE9, 0xA3, 0xA2, 0x43, - 0xE9, 0xA3, 0xAF, 0x43, 0xE9, 0xA3, 0xBC, 0x43, - 0xE9, 0xA4, 0xA8, 0x43, 0xE9, 0xA4, 0xA9, 0x43, - 0xE9, 0xA6, 0x96, 0x43, 0xE9, 0xA6, 0x99, 0x43, - 0xE9, 0xA6, 0xA7, 0x43, 0xE9, 0xA6, 0xAC, 0x43, - 0xE9, 0xA7, 0x82, 0x43, 0xE9, 0xA7, 0xB1, 0x43, - 0xE9, 0xA7, 0xBE, 0x43, 0xE9, 0xA9, 0xAA, 0x43, - // Bytes 1580 - 15bf - 0xE9, 0xAA, 0xA8, 0x43, 0xE9, 0xAB, 0x98, 0x43, - 0xE9, 0xAB, 0x9F, 0x43, 0xE9, 0xAC, 0x92, 0x43, - 0xE9, 0xAC, 0xA5, 0x43, 0xE9, 0xAC, 0xAF, 0x43, - 0xE9, 0xAC, 0xB2, 0x43, 0xE9, 0xAC, 0xBC, 0x43, - 0xE9, 0xAD, 0x9A, 0x43, 0xE9, 0xAD, 0xAF, 0x43, - 0xE9, 0xB1, 0x80, 0x43, 0xE9, 0xB1, 0x97, 0x43, - 0xE9, 0xB3, 0xA5, 0x43, 0xE9, 0xB3, 0xBD, 0x43, - 0xE9, 0xB5, 0xA7, 0x43, 0xE9, 0xB6, 0xB4, 0x43, - // Bytes 15c0 - 15ff - 0xE9, 0xB7, 0xBA, 0x43, 0xE9, 0xB8, 0x9E, 0x43, - 0xE9, 0xB9, 0xB5, 0x43, 0xE9, 0xB9, 0xBF, 0x43, - 0xE9, 0xBA, 0x97, 0x43, 0xE9, 0xBA, 0x9F, 0x43, - 0xE9, 0xBA, 0xA5, 0x43, 0xE9, 0xBA, 0xBB, 0x43, - 0xE9, 0xBB, 0x83, 0x43, 0xE9, 0xBB, 0x8D, 0x43, - 0xE9, 0xBB, 0x8E, 0x43, 0xE9, 0xBB, 0x91, 0x43, - 0xE9, 0xBB, 0xB9, 0x43, 0xE9, 0xBB, 0xBD, 0x43, - 0xE9, 0xBB, 0xBE, 0x43, 0xE9, 0xBC, 0x85, 0x43, - // Bytes 1600 - 163f - 0xE9, 0xBC, 0x8E, 0x43, 0xE9, 0xBC, 0x8F, 0x43, - 0xE9, 0xBC, 0x93, 0x43, 0xE9, 0xBC, 0x96, 0x43, - 0xE9, 0xBC, 0xA0, 0x43, 0xE9, 0xBC, 0xBB, 0x43, - 0xE9, 0xBD, 0x83, 0x43, 0xE9, 0xBD, 0x8A, 0x43, - 0xE9, 0xBD, 0x92, 0x43, 0xE9, 0xBE, 0x8D, 0x43, - 0xE9, 0xBE, 0x8E, 0x43, 0xE9, 0xBE, 0x9C, 0x43, - 0xE9, 0xBE, 0x9F, 0x43, 0xE9, 0xBE, 0xA0, 0x43, - 0xEA, 0x9C, 0xA7, 0x43, 0xEA, 0x9D, 0xAF, 0x43, - // Bytes 1640 - 167f - 0xEA, 0xAC, 0xB7, 0x43, 0xEA, 0xAD, 0x92, 0x44, - 0xF0, 0xA0, 0x84, 0xA2, 0x44, 0xF0, 0xA0, 0x94, - 0x9C, 0x44, 0xF0, 0xA0, 0x94, 0xA5, 0x44, 0xF0, - 0xA0, 0x95, 0x8B, 0x44, 0xF0, 0xA0, 0x98, 0xBA, - 0x44, 0xF0, 0xA0, 0xA0, 0x84, 0x44, 0xF0, 0xA0, - 0xA3, 0x9E, 0x44, 0xF0, 0xA0, 0xA8, 0xAC, 0x44, - 0xF0, 0xA0, 0xAD, 0xA3, 0x44, 0xF0, 0xA1, 0x93, - 0xA4, 0x44, 0xF0, 0xA1, 0x9A, 0xA8, 0x44, 0xF0, - // Bytes 1680 - 16bf - 0xA1, 0x9B, 0xAA, 0x44, 0xF0, 0xA1, 0xA7, 0x88, - 0x44, 0xF0, 0xA1, 0xAC, 0x98, 0x44, 0xF0, 0xA1, - 0xB4, 0x8B, 0x44, 0xF0, 0xA1, 0xB7, 0xA4, 0x44, - 0xF0, 0xA1, 0xB7, 0xA6, 0x44, 0xF0, 0xA2, 0x86, - 0x83, 0x44, 0xF0, 0xA2, 0x86, 0x9F, 0x44, 0xF0, - 0xA2, 0x8C, 0xB1, 0x44, 0xF0, 0xA2, 0x9B, 0x94, - 0x44, 0xF0, 0xA2, 0xA1, 0x84, 0x44, 0xF0, 0xA2, - 0xA1, 0x8A, 0x44, 0xF0, 0xA2, 0xAC, 0x8C, 0x44, - // Bytes 16c0 - 16ff - 0xF0, 0xA2, 0xAF, 0xB1, 0x44, 0xF0, 0xA3, 0x80, - 0x8A, 0x44, 0xF0, 0xA3, 0x8A, 0xB8, 0x44, 0xF0, - 0xA3, 0x8D, 0x9F, 0x44, 0xF0, 0xA3, 0x8E, 0x93, - 0x44, 0xF0, 0xA3, 0x8E, 0x9C, 0x44, 0xF0, 0xA3, - 0x8F, 0x83, 0x44, 0xF0, 0xA3, 0x8F, 0x95, 0x44, - 0xF0, 0xA3, 0x91, 0xAD, 0x44, 0xF0, 0xA3, 0x9A, - 0xA3, 0x44, 0xF0, 0xA3, 0xA2, 0xA7, 0x44, 0xF0, - 0xA3, 0xAA, 0x8D, 0x44, 0xF0, 0xA3, 0xAB, 0xBA, - // Bytes 1700 - 173f - 0x44, 0xF0, 0xA3, 0xB2, 0xBC, 0x44, 0xF0, 0xA3, - 0xB4, 0x9E, 0x44, 0xF0, 0xA3, 0xBB, 0x91, 0x44, - 0xF0, 0xA3, 0xBD, 0x9E, 0x44, 0xF0, 0xA3, 0xBE, - 0x8E, 0x44, 0xF0, 0xA4, 0x89, 0xA3, 0x44, 0xF0, - 0xA4, 0x8B, 0xAE, 0x44, 0xF0, 0xA4, 0x8E, 0xAB, - 0x44, 0xF0, 0xA4, 0x98, 0x88, 0x44, 0xF0, 0xA4, - 0x9C, 0xB5, 0x44, 0xF0, 0xA4, 0xA0, 0x94, 0x44, - 0xF0, 0xA4, 0xB0, 0xB6, 0x44, 0xF0, 0xA4, 0xB2, - // Bytes 1740 - 177f - 0x92, 0x44, 0xF0, 0xA4, 0xBE, 0xA1, 0x44, 0xF0, - 0xA4, 0xBE, 0xB8, 0x44, 0xF0, 0xA5, 0x81, 0x84, - 0x44, 0xF0, 0xA5, 0x83, 0xB2, 0x44, 0xF0, 0xA5, - 0x83, 0xB3, 0x44, 0xF0, 0xA5, 0x84, 0x99, 0x44, - 0xF0, 0xA5, 0x84, 0xB3, 0x44, 0xF0, 0xA5, 0x89, - 0x89, 0x44, 0xF0, 0xA5, 0x90, 0x9D, 0x44, 0xF0, - 0xA5, 0x98, 0xA6, 0x44, 0xF0, 0xA5, 0x9A, 0x9A, - 0x44, 0xF0, 0xA5, 0x9B, 0x85, 0x44, 0xF0, 0xA5, - // Bytes 1780 - 17bf - 0xA5, 0xBC, 0x44, 0xF0, 0xA5, 0xAA, 0xA7, 0x44, - 0xF0, 0xA5, 0xAE, 0xAB, 0x44, 0xF0, 0xA5, 0xB2, - 0x80, 0x44, 0xF0, 0xA5, 0xB3, 0x90, 0x44, 0xF0, - 0xA5, 0xBE, 0x86, 0x44, 0xF0, 0xA6, 0x87, 0x9A, - 0x44, 0xF0, 0xA6, 0x88, 0xA8, 0x44, 0xF0, 0xA6, - 0x89, 0x87, 0x44, 0xF0, 0xA6, 0x8B, 0x99, 0x44, - 0xF0, 0xA6, 0x8C, 0xBE, 0x44, 0xF0, 0xA6, 0x93, - 0x9A, 0x44, 0xF0, 0xA6, 0x94, 0xA3, 0x44, 0xF0, - // Bytes 17c0 - 17ff - 0xA6, 0x96, 0xA8, 0x44, 0xF0, 0xA6, 0x9E, 0xA7, - 0x44, 0xF0, 0xA6, 0x9E, 0xB5, 0x44, 0xF0, 0xA6, - 0xAC, 0xBC, 0x44, 0xF0, 0xA6, 0xB0, 0xB6, 0x44, - 0xF0, 0xA6, 0xB3, 0x95, 0x44, 0xF0, 0xA6, 0xB5, - 0xAB, 0x44, 0xF0, 0xA6, 0xBC, 0xAC, 0x44, 0xF0, - 0xA6, 0xBE, 0xB1, 0x44, 0xF0, 0xA7, 0x83, 0x92, - 0x44, 0xF0, 0xA7, 0x8F, 0x8A, 0x44, 0xF0, 0xA7, - 0x99, 0xA7, 0x44, 0xF0, 0xA7, 0xA2, 0xAE, 0x44, - // Bytes 1800 - 183f - 0xF0, 0xA7, 0xA5, 0xA6, 0x44, 0xF0, 0xA7, 0xB2, - 0xA8, 0x44, 0xF0, 0xA7, 0xBB, 0x93, 0x44, 0xF0, - 0xA7, 0xBC, 0xAF, 0x44, 0xF0, 0xA8, 0x97, 0x92, - 0x44, 0xF0, 0xA8, 0x97, 0xAD, 0x44, 0xF0, 0xA8, - 0x9C, 0xAE, 0x44, 0xF0, 0xA8, 0xAF, 0xBA, 0x44, - 0xF0, 0xA8, 0xB5, 0xB7, 0x44, 0xF0, 0xA9, 0x85, - 0x85, 0x44, 0xF0, 0xA9, 0x87, 0x9F, 0x44, 0xF0, - 0xA9, 0x88, 0x9A, 0x44, 0xF0, 0xA9, 0x90, 0x8A, - // Bytes 1840 - 187f - 0x44, 0xF0, 0xA9, 0x92, 0x96, 0x44, 0xF0, 0xA9, - 0x96, 0xB6, 0x44, 0xF0, 0xA9, 0xAC, 0xB0, 0x44, - 0xF0, 0xAA, 0x83, 0x8E, 0x44, 0xF0, 0xAA, 0x84, - 0x85, 0x44, 0xF0, 0xAA, 0x88, 0x8E, 0x44, 0xF0, - 0xAA, 0x8A, 0x91, 0x44, 0xF0, 0xAA, 0x8E, 0x92, - 0x44, 0xF0, 0xAA, 0x98, 0x80, 0x42, 0x21, 0x21, - 0x42, 0x21, 0x3F, 0x42, 0x2E, 0x2E, 0x42, 0x30, - 0x2C, 0x42, 0x30, 0x2E, 0x42, 0x31, 0x2C, 0x42, - // Bytes 1880 - 18bf - 0x31, 0x2E, 0x42, 0x31, 0x30, 0x42, 0x31, 0x31, - 0x42, 0x31, 0x32, 0x42, 0x31, 0x33, 0x42, 0x31, - 0x34, 0x42, 0x31, 0x35, 0x42, 0x31, 0x36, 0x42, - 0x31, 0x37, 0x42, 0x31, 0x38, 0x42, 0x31, 0x39, - 0x42, 0x32, 0x2C, 0x42, 0x32, 0x2E, 0x42, 0x32, - 0x30, 0x42, 0x32, 0x31, 0x42, 0x32, 0x32, 0x42, - 0x32, 0x33, 0x42, 0x32, 0x34, 0x42, 0x32, 0x35, - 0x42, 0x32, 0x36, 0x42, 0x32, 0x37, 0x42, 0x32, - // Bytes 18c0 - 18ff - 0x38, 0x42, 0x32, 0x39, 0x42, 0x33, 0x2C, 0x42, - 0x33, 0x2E, 0x42, 0x33, 0x30, 0x42, 0x33, 0x31, - 0x42, 0x33, 0x32, 0x42, 0x33, 0x33, 0x42, 0x33, - 0x34, 0x42, 0x33, 0x35, 0x42, 0x33, 0x36, 0x42, - 0x33, 0x37, 0x42, 0x33, 0x38, 0x42, 0x33, 0x39, - 0x42, 0x34, 0x2C, 0x42, 0x34, 0x2E, 0x42, 0x34, - 0x30, 0x42, 0x34, 0x31, 0x42, 0x34, 0x32, 0x42, - 0x34, 0x33, 0x42, 0x34, 0x34, 0x42, 0x34, 0x35, - // Bytes 1900 - 193f - 0x42, 0x34, 0x36, 0x42, 0x34, 0x37, 0x42, 0x34, - 0x38, 0x42, 0x34, 0x39, 0x42, 0x35, 0x2C, 0x42, - 0x35, 0x2E, 0x42, 0x35, 0x30, 0x42, 0x36, 0x2C, - 0x42, 0x36, 0x2E, 0x42, 0x37, 0x2C, 0x42, 0x37, - 0x2E, 0x42, 0x38, 0x2C, 0x42, 0x38, 0x2E, 0x42, - 0x39, 0x2C, 0x42, 0x39, 0x2E, 0x42, 0x3D, 0x3D, - 0x42, 0x3F, 0x21, 0x42, 0x3F, 0x3F, 0x42, 0x41, - 0x55, 0x42, 0x42, 0x71, 0x42, 0x43, 0x44, 0x42, - // Bytes 1940 - 197f - 0x44, 0x4A, 0x42, 0x44, 0x5A, 0x42, 0x44, 0x7A, - 0x42, 0x47, 0x42, 0x42, 0x47, 0x79, 0x42, 0x48, - 0x50, 0x42, 0x48, 0x56, 0x42, 0x48, 0x67, 0x42, - 0x48, 0x7A, 0x42, 0x49, 0x49, 0x42, 0x49, 0x4A, - 0x42, 0x49, 0x55, 0x42, 0x49, 0x56, 0x42, 0x49, - 0x58, 0x42, 0x4B, 0x42, 0x42, 0x4B, 0x4B, 0x42, - 0x4B, 0x4D, 0x42, 0x4C, 0x4A, 0x42, 0x4C, 0x6A, - 0x42, 0x4D, 0x42, 0x42, 0x4D, 0x43, 0x42, 0x4D, - // Bytes 1980 - 19bf - 0x44, 0x42, 0x4D, 0x56, 0x42, 0x4D, 0x57, 0x42, - 0x4E, 0x4A, 0x42, 0x4E, 0x6A, 0x42, 0x4E, 0x6F, - 0x42, 0x50, 0x48, 0x42, 0x50, 0x52, 0x42, 0x50, - 0x61, 0x42, 0x52, 0x73, 0x42, 0x53, 0x44, 0x42, - 0x53, 0x4D, 0x42, 0x53, 0x53, 0x42, 0x53, 0x76, - 0x42, 0x54, 0x4D, 0x42, 0x56, 0x49, 0x42, 0x57, - 0x43, 0x42, 0x57, 0x5A, 0x42, 0x57, 0x62, 0x42, - 0x58, 0x49, 0x42, 0x63, 0x63, 0x42, 0x63, 0x64, - // Bytes 19c0 - 19ff - 0x42, 0x63, 0x6D, 0x42, 0x64, 0x42, 0x42, 0x64, - 0x61, 0x42, 0x64, 0x6C, 0x42, 0x64, 0x6D, 0x42, - 0x64, 0x7A, 0x42, 0x65, 0x56, 0x42, 0x66, 0x66, - 0x42, 0x66, 0x69, 0x42, 0x66, 0x6C, 0x42, 0x66, - 0x6D, 0x42, 0x68, 0x61, 0x42, 0x69, 0x69, 0x42, - 0x69, 0x6A, 0x42, 0x69, 0x6E, 0x42, 0x69, 0x76, - 0x42, 0x69, 0x78, 0x42, 0x6B, 0x41, 0x42, 0x6B, - 0x56, 0x42, 0x6B, 0x57, 0x42, 0x6B, 0x67, 0x42, - // Bytes 1a00 - 1a3f - 0x6B, 0x6C, 0x42, 0x6B, 0x6D, 0x42, 0x6B, 0x74, - 0x42, 0x6C, 0x6A, 0x42, 0x6C, 0x6D, 0x42, 0x6C, - 0x6E, 0x42, 0x6C, 0x78, 0x42, 0x6D, 0x32, 0x42, - 0x6D, 0x33, 0x42, 0x6D, 0x41, 0x42, 0x6D, 0x56, - 0x42, 0x6D, 0x57, 0x42, 0x6D, 0x62, 0x42, 0x6D, - 0x67, 0x42, 0x6D, 0x6C, 0x42, 0x6D, 0x6D, 0x42, - 0x6D, 0x73, 0x42, 0x6E, 0x41, 0x42, 0x6E, 0x46, - 0x42, 0x6E, 0x56, 0x42, 0x6E, 0x57, 0x42, 0x6E, - // Bytes 1a40 - 1a7f - 0x6A, 0x42, 0x6E, 0x6D, 0x42, 0x6E, 0x73, 0x42, - 0x6F, 0x56, 0x42, 0x70, 0x41, 0x42, 0x70, 0x46, - 0x42, 0x70, 0x56, 0x42, 0x70, 0x57, 0x42, 0x70, - 0x63, 0x42, 0x70, 0x73, 0x42, 0x73, 0x72, 0x42, - 0x73, 0x74, 0x42, 0x76, 0x69, 0x42, 0x78, 0x69, - 0x43, 0x28, 0x31, 0x29, 0x43, 0x28, 0x32, 0x29, - 0x43, 0x28, 0x33, 0x29, 0x43, 0x28, 0x34, 0x29, - 0x43, 0x28, 0x35, 0x29, 0x43, 0x28, 0x36, 0x29, - // Bytes 1a80 - 1abf - 0x43, 0x28, 0x37, 0x29, 0x43, 0x28, 0x38, 0x29, - 0x43, 0x28, 0x39, 0x29, 0x43, 0x28, 0x41, 0x29, - 0x43, 0x28, 0x42, 0x29, 0x43, 0x28, 0x43, 0x29, - 0x43, 0x28, 0x44, 0x29, 0x43, 0x28, 0x45, 0x29, - 0x43, 0x28, 0x46, 0x29, 0x43, 0x28, 0x47, 0x29, - 0x43, 0x28, 0x48, 0x29, 0x43, 0x28, 0x49, 0x29, - 0x43, 0x28, 0x4A, 0x29, 0x43, 0x28, 0x4B, 0x29, - 0x43, 0x28, 0x4C, 0x29, 0x43, 0x28, 0x4D, 0x29, - // Bytes 1ac0 - 1aff - 0x43, 0x28, 0x4E, 0x29, 0x43, 0x28, 0x4F, 0x29, - 0x43, 0x28, 0x50, 0x29, 0x43, 0x28, 0x51, 0x29, - 0x43, 0x28, 0x52, 0x29, 0x43, 0x28, 0x53, 0x29, - 0x43, 0x28, 0x54, 0x29, 0x43, 0x28, 0x55, 0x29, - 0x43, 0x28, 0x56, 0x29, 0x43, 0x28, 0x57, 0x29, - 0x43, 0x28, 0x58, 0x29, 0x43, 0x28, 0x59, 0x29, - 0x43, 0x28, 0x5A, 0x29, 0x43, 0x28, 0x61, 0x29, - 0x43, 0x28, 0x62, 0x29, 0x43, 0x28, 0x63, 0x29, - // Bytes 1b00 - 1b3f - 0x43, 0x28, 0x64, 0x29, 0x43, 0x28, 0x65, 0x29, - 0x43, 0x28, 0x66, 0x29, 0x43, 0x28, 0x67, 0x29, - 0x43, 0x28, 0x68, 0x29, 0x43, 0x28, 0x69, 0x29, - 0x43, 0x28, 0x6A, 0x29, 0x43, 0x28, 0x6B, 0x29, - 0x43, 0x28, 0x6C, 0x29, 0x43, 0x28, 0x6D, 0x29, - 0x43, 0x28, 0x6E, 0x29, 0x43, 0x28, 0x6F, 0x29, - 0x43, 0x28, 0x70, 0x29, 0x43, 0x28, 0x71, 0x29, - 0x43, 0x28, 0x72, 0x29, 0x43, 0x28, 0x73, 0x29, - // Bytes 1b40 - 1b7f - 0x43, 0x28, 0x74, 0x29, 0x43, 0x28, 0x75, 0x29, - 0x43, 0x28, 0x76, 0x29, 0x43, 0x28, 0x77, 0x29, - 0x43, 0x28, 0x78, 0x29, 0x43, 0x28, 0x79, 0x29, - 0x43, 0x28, 0x7A, 0x29, 0x43, 0x2E, 0x2E, 0x2E, - 0x43, 0x31, 0x30, 0x2E, 0x43, 0x31, 0x31, 0x2E, - 0x43, 0x31, 0x32, 0x2E, 0x43, 0x31, 0x33, 0x2E, - 0x43, 0x31, 0x34, 0x2E, 0x43, 0x31, 0x35, 0x2E, - 0x43, 0x31, 0x36, 0x2E, 0x43, 0x31, 0x37, 0x2E, - // Bytes 1b80 - 1bbf - 0x43, 0x31, 0x38, 0x2E, 0x43, 0x31, 0x39, 0x2E, - 0x43, 0x32, 0x30, 0x2E, 0x43, 0x3A, 0x3A, 0x3D, - 0x43, 0x3D, 0x3D, 0x3D, 0x43, 0x43, 0x6F, 0x2E, - 0x43, 0x46, 0x41, 0x58, 0x43, 0x47, 0x48, 0x7A, - 0x43, 0x47, 0x50, 0x61, 0x43, 0x49, 0x49, 0x49, - 0x43, 0x4C, 0x54, 0x44, 0x43, 0x4C, 0xC2, 0xB7, - 0x43, 0x4D, 0x48, 0x7A, 0x43, 0x4D, 0x50, 0x61, - 0x43, 0x4D, 0xCE, 0xA9, 0x43, 0x50, 0x50, 0x4D, - // Bytes 1bc0 - 1bff - 0x43, 0x50, 0x50, 0x56, 0x43, 0x50, 0x54, 0x45, - 0x43, 0x54, 0x45, 0x4C, 0x43, 0x54, 0x48, 0x7A, - 0x43, 0x56, 0x49, 0x49, 0x43, 0x58, 0x49, 0x49, - 0x43, 0x61, 0x2F, 0x63, 0x43, 0x61, 0x2F, 0x73, - 0x43, 0x61, 0xCA, 0xBE, 0x43, 0x62, 0x61, 0x72, - 0x43, 0x63, 0x2F, 0x6F, 0x43, 0x63, 0x2F, 0x75, - 0x43, 0x63, 0x61, 0x6C, 0x43, 0x63, 0x6D, 0x32, - 0x43, 0x63, 0x6D, 0x33, 0x43, 0x64, 0x6D, 0x32, - // Bytes 1c00 - 1c3f - 0x43, 0x64, 0x6D, 0x33, 0x43, 0x65, 0x72, 0x67, - 0x43, 0x66, 0x66, 0x69, 0x43, 0x66, 0x66, 0x6C, - 0x43, 0x67, 0x61, 0x6C, 0x43, 0x68, 0x50, 0x61, - 0x43, 0x69, 0x69, 0x69, 0x43, 0x6B, 0x48, 0x7A, - 0x43, 0x6B, 0x50, 0x61, 0x43, 0x6B, 0x6D, 0x32, - 0x43, 0x6B, 0x6D, 0x33, 0x43, 0x6B, 0xCE, 0xA9, - 0x43, 0x6C, 0x6F, 0x67, 0x43, 0x6C, 0xC2, 0xB7, - 0x43, 0x6D, 0x69, 0x6C, 0x43, 0x6D, 0x6D, 0x32, - // Bytes 1c40 - 1c7f - 0x43, 0x6D, 0x6D, 0x33, 0x43, 0x6D, 0x6F, 0x6C, - 0x43, 0x72, 0x61, 0x64, 0x43, 0x76, 0x69, 0x69, - 0x43, 0x78, 0x69, 0x69, 0x43, 0xC2, 0xB0, 0x43, - 0x43, 0xC2, 0xB0, 0x46, 0x43, 0xCA, 0xBC, 0x6E, - 0x43, 0xCE, 0xBC, 0x41, 0x43, 0xCE, 0xBC, 0x46, - 0x43, 0xCE, 0xBC, 0x56, 0x43, 0xCE, 0xBC, 0x57, - 0x43, 0xCE, 0xBC, 0x67, 0x43, 0xCE, 0xBC, 0x6C, - 0x43, 0xCE, 0xBC, 0x6D, 0x43, 0xCE, 0xBC, 0x73, - // Bytes 1c80 - 1cbf - 0x44, 0x28, 0x31, 0x30, 0x29, 0x44, 0x28, 0x31, - 0x31, 0x29, 0x44, 0x28, 0x31, 0x32, 0x29, 0x44, - 0x28, 0x31, 0x33, 0x29, 0x44, 0x28, 0x31, 0x34, - 0x29, 0x44, 0x28, 0x31, 0x35, 0x29, 0x44, 0x28, - 0x31, 0x36, 0x29, 0x44, 0x28, 0x31, 0x37, 0x29, - 0x44, 0x28, 0x31, 0x38, 0x29, 0x44, 0x28, 0x31, - 0x39, 0x29, 0x44, 0x28, 0x32, 0x30, 0x29, 0x44, - 0x30, 0xE7, 0x82, 0xB9, 0x44, 0x31, 0xE2, 0x81, - // Bytes 1cc0 - 1cff - 0x84, 0x44, 0x31, 0xE6, 0x97, 0xA5, 0x44, 0x31, - 0xE6, 0x9C, 0x88, 0x44, 0x31, 0xE7, 0x82, 0xB9, - 0x44, 0x32, 0xE6, 0x97, 0xA5, 0x44, 0x32, 0xE6, - 0x9C, 0x88, 0x44, 0x32, 0xE7, 0x82, 0xB9, 0x44, - 0x33, 0xE6, 0x97, 0xA5, 0x44, 0x33, 0xE6, 0x9C, - 0x88, 0x44, 0x33, 0xE7, 0x82, 0xB9, 0x44, 0x34, - 0xE6, 0x97, 0xA5, 0x44, 0x34, 0xE6, 0x9C, 0x88, - 0x44, 0x34, 0xE7, 0x82, 0xB9, 0x44, 0x35, 0xE6, - // Bytes 1d00 - 1d3f - 0x97, 0xA5, 0x44, 0x35, 0xE6, 0x9C, 0x88, 0x44, - 0x35, 0xE7, 0x82, 0xB9, 0x44, 0x36, 0xE6, 0x97, - 0xA5, 0x44, 0x36, 0xE6, 0x9C, 0x88, 0x44, 0x36, - 0xE7, 0x82, 0xB9, 0x44, 0x37, 0xE6, 0x97, 0xA5, - 0x44, 0x37, 0xE6, 0x9C, 0x88, 0x44, 0x37, 0xE7, - 0x82, 0xB9, 0x44, 0x38, 0xE6, 0x97, 0xA5, 0x44, - 0x38, 0xE6, 0x9C, 0x88, 0x44, 0x38, 0xE7, 0x82, - 0xB9, 0x44, 0x39, 0xE6, 0x97, 0xA5, 0x44, 0x39, - // Bytes 1d40 - 1d7f - 0xE6, 0x9C, 0x88, 0x44, 0x39, 0xE7, 0x82, 0xB9, - 0x44, 0x56, 0x49, 0x49, 0x49, 0x44, 0x61, 0x2E, - 0x6D, 0x2E, 0x44, 0x6B, 0x63, 0x61, 0x6C, 0x44, - 0x70, 0x2E, 0x6D, 0x2E, 0x44, 0x76, 0x69, 0x69, - 0x69, 0x44, 0xD5, 0xA5, 0xD6, 0x82, 0x44, 0xD5, - 0xB4, 0xD5, 0xA5, 0x44, 0xD5, 0xB4, 0xD5, 0xAB, - 0x44, 0xD5, 0xB4, 0xD5, 0xAD, 0x44, 0xD5, 0xB4, - 0xD5, 0xB6, 0x44, 0xD5, 0xBE, 0xD5, 0xB6, 0x44, - // Bytes 1d80 - 1dbf - 0xD7, 0x90, 0xD7, 0x9C, 0x44, 0xD8, 0xA7, 0xD9, - 0xB4, 0x44, 0xD8, 0xA8, 0xD8, 0xAC, 0x44, 0xD8, - 0xA8, 0xD8, 0xAD, 0x44, 0xD8, 0xA8, 0xD8, 0xAE, - 0x44, 0xD8, 0xA8, 0xD8, 0xB1, 0x44, 0xD8, 0xA8, - 0xD8, 0xB2, 0x44, 0xD8, 0xA8, 0xD9, 0x85, 0x44, - 0xD8, 0xA8, 0xD9, 0x86, 0x44, 0xD8, 0xA8, 0xD9, - 0x87, 0x44, 0xD8, 0xA8, 0xD9, 0x89, 0x44, 0xD8, - 0xA8, 0xD9, 0x8A, 0x44, 0xD8, 0xAA, 0xD8, 0xAC, - // Bytes 1dc0 - 1dff - 0x44, 0xD8, 0xAA, 0xD8, 0xAD, 0x44, 0xD8, 0xAA, - 0xD8, 0xAE, 0x44, 0xD8, 0xAA, 0xD8, 0xB1, 0x44, - 0xD8, 0xAA, 0xD8, 0xB2, 0x44, 0xD8, 0xAA, 0xD9, - 0x85, 0x44, 0xD8, 0xAA, 0xD9, 0x86, 0x44, 0xD8, - 0xAA, 0xD9, 0x87, 0x44, 0xD8, 0xAA, 0xD9, 0x89, - 0x44, 0xD8, 0xAA, 0xD9, 0x8A, 0x44, 0xD8, 0xAB, - 0xD8, 0xAC, 0x44, 0xD8, 0xAB, 0xD8, 0xB1, 0x44, - 0xD8, 0xAB, 0xD8, 0xB2, 0x44, 0xD8, 0xAB, 0xD9, - // Bytes 1e00 - 1e3f - 0x85, 0x44, 0xD8, 0xAB, 0xD9, 0x86, 0x44, 0xD8, - 0xAB, 0xD9, 0x87, 0x44, 0xD8, 0xAB, 0xD9, 0x89, - 0x44, 0xD8, 0xAB, 0xD9, 0x8A, 0x44, 0xD8, 0xAC, - 0xD8, 0xAD, 0x44, 0xD8, 0xAC, 0xD9, 0x85, 0x44, - 0xD8, 0xAC, 0xD9, 0x89, 0x44, 0xD8, 0xAC, 0xD9, - 0x8A, 0x44, 0xD8, 0xAD, 0xD8, 0xAC, 0x44, 0xD8, - 0xAD, 0xD9, 0x85, 0x44, 0xD8, 0xAD, 0xD9, 0x89, - 0x44, 0xD8, 0xAD, 0xD9, 0x8A, 0x44, 0xD8, 0xAE, - // Bytes 1e40 - 1e7f - 0xD8, 0xAC, 0x44, 0xD8, 0xAE, 0xD8, 0xAD, 0x44, - 0xD8, 0xAE, 0xD9, 0x85, 0x44, 0xD8, 0xAE, 0xD9, - 0x89, 0x44, 0xD8, 0xAE, 0xD9, 0x8A, 0x44, 0xD8, - 0xB3, 0xD8, 0xAC, 0x44, 0xD8, 0xB3, 0xD8, 0xAD, - 0x44, 0xD8, 0xB3, 0xD8, 0xAE, 0x44, 0xD8, 0xB3, - 0xD8, 0xB1, 0x44, 0xD8, 0xB3, 0xD9, 0x85, 0x44, - 0xD8, 0xB3, 0xD9, 0x87, 0x44, 0xD8, 0xB3, 0xD9, - 0x89, 0x44, 0xD8, 0xB3, 0xD9, 0x8A, 0x44, 0xD8, - // Bytes 1e80 - 1ebf - 0xB4, 0xD8, 0xAC, 0x44, 0xD8, 0xB4, 0xD8, 0xAD, - 0x44, 0xD8, 0xB4, 0xD8, 0xAE, 0x44, 0xD8, 0xB4, - 0xD8, 0xB1, 0x44, 0xD8, 0xB4, 0xD9, 0x85, 0x44, - 0xD8, 0xB4, 0xD9, 0x87, 0x44, 0xD8, 0xB4, 0xD9, - 0x89, 0x44, 0xD8, 0xB4, 0xD9, 0x8A, 0x44, 0xD8, - 0xB5, 0xD8, 0xAD, 0x44, 0xD8, 0xB5, 0xD8, 0xAE, - 0x44, 0xD8, 0xB5, 0xD8, 0xB1, 0x44, 0xD8, 0xB5, - 0xD9, 0x85, 0x44, 0xD8, 0xB5, 0xD9, 0x89, 0x44, - // Bytes 1ec0 - 1eff - 0xD8, 0xB5, 0xD9, 0x8A, 0x44, 0xD8, 0xB6, 0xD8, - 0xAC, 0x44, 0xD8, 0xB6, 0xD8, 0xAD, 0x44, 0xD8, - 0xB6, 0xD8, 0xAE, 0x44, 0xD8, 0xB6, 0xD8, 0xB1, - 0x44, 0xD8, 0xB6, 0xD9, 0x85, 0x44, 0xD8, 0xB6, - 0xD9, 0x89, 0x44, 0xD8, 0xB6, 0xD9, 0x8A, 0x44, - 0xD8, 0xB7, 0xD8, 0xAD, 0x44, 0xD8, 0xB7, 0xD9, - 0x85, 0x44, 0xD8, 0xB7, 0xD9, 0x89, 0x44, 0xD8, - 0xB7, 0xD9, 0x8A, 0x44, 0xD8, 0xB8, 0xD9, 0x85, - // Bytes 1f00 - 1f3f - 0x44, 0xD8, 0xB9, 0xD8, 0xAC, 0x44, 0xD8, 0xB9, - 0xD9, 0x85, 0x44, 0xD8, 0xB9, 0xD9, 0x89, 0x44, - 0xD8, 0xB9, 0xD9, 0x8A, 0x44, 0xD8, 0xBA, 0xD8, - 0xAC, 0x44, 0xD8, 0xBA, 0xD9, 0x85, 0x44, 0xD8, - 0xBA, 0xD9, 0x89, 0x44, 0xD8, 0xBA, 0xD9, 0x8A, - 0x44, 0xD9, 0x81, 0xD8, 0xAC, 0x44, 0xD9, 0x81, - 0xD8, 0xAD, 0x44, 0xD9, 0x81, 0xD8, 0xAE, 0x44, - 0xD9, 0x81, 0xD9, 0x85, 0x44, 0xD9, 0x81, 0xD9, - // Bytes 1f40 - 1f7f - 0x89, 0x44, 0xD9, 0x81, 0xD9, 0x8A, 0x44, 0xD9, - 0x82, 0xD8, 0xAD, 0x44, 0xD9, 0x82, 0xD9, 0x85, - 0x44, 0xD9, 0x82, 0xD9, 0x89, 0x44, 0xD9, 0x82, - 0xD9, 0x8A, 0x44, 0xD9, 0x83, 0xD8, 0xA7, 0x44, - 0xD9, 0x83, 0xD8, 0xAC, 0x44, 0xD9, 0x83, 0xD8, - 0xAD, 0x44, 0xD9, 0x83, 0xD8, 0xAE, 0x44, 0xD9, - 0x83, 0xD9, 0x84, 0x44, 0xD9, 0x83, 0xD9, 0x85, - 0x44, 0xD9, 0x83, 0xD9, 0x89, 0x44, 0xD9, 0x83, - // Bytes 1f80 - 1fbf - 0xD9, 0x8A, 0x44, 0xD9, 0x84, 0xD8, 0xA7, 0x44, - 0xD9, 0x84, 0xD8, 0xAC, 0x44, 0xD9, 0x84, 0xD8, - 0xAD, 0x44, 0xD9, 0x84, 0xD8, 0xAE, 0x44, 0xD9, - 0x84, 0xD9, 0x85, 0x44, 0xD9, 0x84, 0xD9, 0x87, - 0x44, 0xD9, 0x84, 0xD9, 0x89, 0x44, 0xD9, 0x84, - 0xD9, 0x8A, 0x44, 0xD9, 0x85, 0xD8, 0xA7, 0x44, - 0xD9, 0x85, 0xD8, 0xAC, 0x44, 0xD9, 0x85, 0xD8, - 0xAD, 0x44, 0xD9, 0x85, 0xD8, 0xAE, 0x44, 0xD9, - // Bytes 1fc0 - 1fff - 0x85, 0xD9, 0x85, 0x44, 0xD9, 0x85, 0xD9, 0x89, - 0x44, 0xD9, 0x85, 0xD9, 0x8A, 0x44, 0xD9, 0x86, - 0xD8, 0xAC, 0x44, 0xD9, 0x86, 0xD8, 0xAD, 0x44, - 0xD9, 0x86, 0xD8, 0xAE, 0x44, 0xD9, 0x86, 0xD8, - 0xB1, 0x44, 0xD9, 0x86, 0xD8, 0xB2, 0x44, 0xD9, - 0x86, 0xD9, 0x85, 0x44, 0xD9, 0x86, 0xD9, 0x86, - 0x44, 0xD9, 0x86, 0xD9, 0x87, 0x44, 0xD9, 0x86, - 0xD9, 0x89, 0x44, 0xD9, 0x86, 0xD9, 0x8A, 0x44, - // Bytes 2000 - 203f - 0xD9, 0x87, 0xD8, 0xAC, 0x44, 0xD9, 0x87, 0xD9, - 0x85, 0x44, 0xD9, 0x87, 0xD9, 0x89, 0x44, 0xD9, - 0x87, 0xD9, 0x8A, 0x44, 0xD9, 0x88, 0xD9, 0xB4, - 0x44, 0xD9, 0x8A, 0xD8, 0xAC, 0x44, 0xD9, 0x8A, - 0xD8, 0xAD, 0x44, 0xD9, 0x8A, 0xD8, 0xAE, 0x44, - 0xD9, 0x8A, 0xD8, 0xB1, 0x44, 0xD9, 0x8A, 0xD8, - 0xB2, 0x44, 0xD9, 0x8A, 0xD9, 0x85, 0x44, 0xD9, - 0x8A, 0xD9, 0x86, 0x44, 0xD9, 0x8A, 0xD9, 0x87, - // Bytes 2040 - 207f - 0x44, 0xD9, 0x8A, 0xD9, 0x89, 0x44, 0xD9, 0x8A, - 0xD9, 0x8A, 0x44, 0xD9, 0x8A, 0xD9, 0xB4, 0x44, - 0xDB, 0x87, 0xD9, 0xB4, 0x45, 0x28, 0xE1, 0x84, - 0x80, 0x29, 0x45, 0x28, 0xE1, 0x84, 0x82, 0x29, - 0x45, 0x28, 0xE1, 0x84, 0x83, 0x29, 0x45, 0x28, - 0xE1, 0x84, 0x85, 0x29, 0x45, 0x28, 0xE1, 0x84, - 0x86, 0x29, 0x45, 0x28, 0xE1, 0x84, 0x87, 0x29, - 0x45, 0x28, 0xE1, 0x84, 0x89, 0x29, 0x45, 0x28, - // Bytes 2080 - 20bf - 0xE1, 0x84, 0x8B, 0x29, 0x45, 0x28, 0xE1, 0x84, - 0x8C, 0x29, 0x45, 0x28, 0xE1, 0x84, 0x8E, 0x29, - 0x45, 0x28, 0xE1, 0x84, 0x8F, 0x29, 0x45, 0x28, - 0xE1, 0x84, 0x90, 0x29, 0x45, 0x28, 0xE1, 0x84, - 0x91, 0x29, 0x45, 0x28, 0xE1, 0x84, 0x92, 0x29, - 0x45, 0x28, 0xE4, 0xB8, 0x80, 0x29, 0x45, 0x28, - 0xE4, 0xB8, 0x83, 0x29, 0x45, 0x28, 0xE4, 0xB8, - 0x89, 0x29, 0x45, 0x28, 0xE4, 0xB9, 0x9D, 0x29, - // Bytes 20c0 - 20ff - 0x45, 0x28, 0xE4, 0xBA, 0x8C, 0x29, 0x45, 0x28, - 0xE4, 0xBA, 0x94, 0x29, 0x45, 0x28, 0xE4, 0xBB, - 0xA3, 0x29, 0x45, 0x28, 0xE4, 0xBC, 0x81, 0x29, - 0x45, 0x28, 0xE4, 0xBC, 0x91, 0x29, 0x45, 0x28, - 0xE5, 0x85, 0xAB, 0x29, 0x45, 0x28, 0xE5, 0x85, - 0xAD, 0x29, 0x45, 0x28, 0xE5, 0x8A, 0xB4, 0x29, - 0x45, 0x28, 0xE5, 0x8D, 0x81, 0x29, 0x45, 0x28, - 0xE5, 0x8D, 0x94, 0x29, 0x45, 0x28, 0xE5, 0x90, - // Bytes 2100 - 213f - 0x8D, 0x29, 0x45, 0x28, 0xE5, 0x91, 0xBC, 0x29, - 0x45, 0x28, 0xE5, 0x9B, 0x9B, 0x29, 0x45, 0x28, - 0xE5, 0x9C, 0x9F, 0x29, 0x45, 0x28, 0xE5, 0xAD, - 0xA6, 0x29, 0x45, 0x28, 0xE6, 0x97, 0xA5, 0x29, - 0x45, 0x28, 0xE6, 0x9C, 0x88, 0x29, 0x45, 0x28, - 0xE6, 0x9C, 0x89, 0x29, 0x45, 0x28, 0xE6, 0x9C, - 0xA8, 0x29, 0x45, 0x28, 0xE6, 0xA0, 0xAA, 0x29, - 0x45, 0x28, 0xE6, 0xB0, 0xB4, 0x29, 0x45, 0x28, - // Bytes 2140 - 217f - 0xE7, 0x81, 0xAB, 0x29, 0x45, 0x28, 0xE7, 0x89, - 0xB9, 0x29, 0x45, 0x28, 0xE7, 0x9B, 0xA3, 0x29, - 0x45, 0x28, 0xE7, 0xA4, 0xBE, 0x29, 0x45, 0x28, - 0xE7, 0xA5, 0x9D, 0x29, 0x45, 0x28, 0xE7, 0xA5, - 0xAD, 0x29, 0x45, 0x28, 0xE8, 0x87, 0xAA, 0x29, - 0x45, 0x28, 0xE8, 0x87, 0xB3, 0x29, 0x45, 0x28, - 0xE8, 0xB2, 0xA1, 0x29, 0x45, 0x28, 0xE8, 0xB3, - 0x87, 0x29, 0x45, 0x28, 0xE9, 0x87, 0x91, 0x29, - // Bytes 2180 - 21bf - 0x45, 0x30, 0xE2, 0x81, 0x84, 0x33, 0x45, 0x31, - 0x30, 0xE6, 0x97, 0xA5, 0x45, 0x31, 0x30, 0xE6, - 0x9C, 0x88, 0x45, 0x31, 0x30, 0xE7, 0x82, 0xB9, - 0x45, 0x31, 0x31, 0xE6, 0x97, 0xA5, 0x45, 0x31, - 0x31, 0xE6, 0x9C, 0x88, 0x45, 0x31, 0x31, 0xE7, - 0x82, 0xB9, 0x45, 0x31, 0x32, 0xE6, 0x97, 0xA5, - 0x45, 0x31, 0x32, 0xE6, 0x9C, 0x88, 0x45, 0x31, - 0x32, 0xE7, 0x82, 0xB9, 0x45, 0x31, 0x33, 0xE6, - // Bytes 21c0 - 21ff - 0x97, 0xA5, 0x45, 0x31, 0x33, 0xE7, 0x82, 0xB9, - 0x45, 0x31, 0x34, 0xE6, 0x97, 0xA5, 0x45, 0x31, - 0x34, 0xE7, 0x82, 0xB9, 0x45, 0x31, 0x35, 0xE6, - 0x97, 0xA5, 0x45, 0x31, 0x35, 0xE7, 0x82, 0xB9, - 0x45, 0x31, 0x36, 0xE6, 0x97, 0xA5, 0x45, 0x31, - 0x36, 0xE7, 0x82, 0xB9, 0x45, 0x31, 0x37, 0xE6, - 0x97, 0xA5, 0x45, 0x31, 0x37, 0xE7, 0x82, 0xB9, - 0x45, 0x31, 0x38, 0xE6, 0x97, 0xA5, 0x45, 0x31, - // Bytes 2200 - 223f - 0x38, 0xE7, 0x82, 0xB9, 0x45, 0x31, 0x39, 0xE6, - 0x97, 0xA5, 0x45, 0x31, 0x39, 0xE7, 0x82, 0xB9, - 0x45, 0x31, 0xE2, 0x81, 0x84, 0x32, 0x45, 0x31, - 0xE2, 0x81, 0x84, 0x33, 0x45, 0x31, 0xE2, 0x81, - 0x84, 0x34, 0x45, 0x31, 0xE2, 0x81, 0x84, 0x35, - 0x45, 0x31, 0xE2, 0x81, 0x84, 0x36, 0x45, 0x31, - 0xE2, 0x81, 0x84, 0x37, 0x45, 0x31, 0xE2, 0x81, - 0x84, 0x38, 0x45, 0x31, 0xE2, 0x81, 0x84, 0x39, - // Bytes 2240 - 227f - 0x45, 0x32, 0x30, 0xE6, 0x97, 0xA5, 0x45, 0x32, - 0x30, 0xE7, 0x82, 0xB9, 0x45, 0x32, 0x31, 0xE6, - 0x97, 0xA5, 0x45, 0x32, 0x31, 0xE7, 0x82, 0xB9, - 0x45, 0x32, 0x32, 0xE6, 0x97, 0xA5, 0x45, 0x32, - 0x32, 0xE7, 0x82, 0xB9, 0x45, 0x32, 0x33, 0xE6, - 0x97, 0xA5, 0x45, 0x32, 0x33, 0xE7, 0x82, 0xB9, - 0x45, 0x32, 0x34, 0xE6, 0x97, 0xA5, 0x45, 0x32, - 0x34, 0xE7, 0x82, 0xB9, 0x45, 0x32, 0x35, 0xE6, - // Bytes 2280 - 22bf - 0x97, 0xA5, 0x45, 0x32, 0x36, 0xE6, 0x97, 0xA5, - 0x45, 0x32, 0x37, 0xE6, 0x97, 0xA5, 0x45, 0x32, - 0x38, 0xE6, 0x97, 0xA5, 0x45, 0x32, 0x39, 0xE6, - 0x97, 0xA5, 0x45, 0x32, 0xE2, 0x81, 0x84, 0x33, - 0x45, 0x32, 0xE2, 0x81, 0x84, 0x35, 0x45, 0x33, - 0x30, 0xE6, 0x97, 0xA5, 0x45, 0x33, 0x31, 0xE6, - 0x97, 0xA5, 0x45, 0x33, 0xE2, 0x81, 0x84, 0x34, - 0x45, 0x33, 0xE2, 0x81, 0x84, 0x35, 0x45, 0x33, - // Bytes 22c0 - 22ff - 0xE2, 0x81, 0x84, 0x38, 0x45, 0x34, 0xE2, 0x81, - 0x84, 0x35, 0x45, 0x35, 0xE2, 0x81, 0x84, 0x36, - 0x45, 0x35, 0xE2, 0x81, 0x84, 0x38, 0x45, 0x37, - 0xE2, 0x81, 0x84, 0x38, 0x45, 0x41, 0xE2, 0x88, - 0x95, 0x6D, 0x45, 0x56, 0xE2, 0x88, 0x95, 0x6D, - 0x45, 0x6D, 0xE2, 0x88, 0x95, 0x73, 0x46, 0x31, - 0xE2, 0x81, 0x84, 0x31, 0x30, 0x46, 0x43, 0xE2, - 0x88, 0x95, 0x6B, 0x67, 0x46, 0x6D, 0xE2, 0x88, - // Bytes 2300 - 233f - 0x95, 0x73, 0x32, 0x46, 0xD8, 0xA8, 0xD8, 0xAD, - 0xD9, 0x8A, 0x46, 0xD8, 0xA8, 0xD8, 0xAE, 0xD9, - 0x8A, 0x46, 0xD8, 0xAA, 0xD8, 0xAC, 0xD9, 0x85, - 0x46, 0xD8, 0xAA, 0xD8, 0xAC, 0xD9, 0x89, 0x46, - 0xD8, 0xAA, 0xD8, 0xAC, 0xD9, 0x8A, 0x46, 0xD8, - 0xAA, 0xD8, 0xAD, 0xD8, 0xAC, 0x46, 0xD8, 0xAA, - 0xD8, 0xAD, 0xD9, 0x85, 0x46, 0xD8, 0xAA, 0xD8, - 0xAE, 0xD9, 0x85, 0x46, 0xD8, 0xAA, 0xD8, 0xAE, - // Bytes 2340 - 237f - 0xD9, 0x89, 0x46, 0xD8, 0xAA, 0xD8, 0xAE, 0xD9, - 0x8A, 0x46, 0xD8, 0xAA, 0xD9, 0x85, 0xD8, 0xAC, - 0x46, 0xD8, 0xAA, 0xD9, 0x85, 0xD8, 0xAD, 0x46, - 0xD8, 0xAA, 0xD9, 0x85, 0xD8, 0xAE, 0x46, 0xD8, - 0xAA, 0xD9, 0x85, 0xD9, 0x89, 0x46, 0xD8, 0xAA, - 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD8, 0xAC, 0xD8, - 0xAD, 0xD9, 0x89, 0x46, 0xD8, 0xAC, 0xD8, 0xAD, - 0xD9, 0x8A, 0x46, 0xD8, 0xAC, 0xD9, 0x85, 0xD8, - // Bytes 2380 - 23bf - 0xAD, 0x46, 0xD8, 0xAC, 0xD9, 0x85, 0xD9, 0x89, - 0x46, 0xD8, 0xAC, 0xD9, 0x85, 0xD9, 0x8A, 0x46, - 0xD8, 0xAD, 0xD8, 0xAC, 0xD9, 0x8A, 0x46, 0xD8, - 0xAD, 0xD9, 0x85, 0xD9, 0x89, 0x46, 0xD8, 0xAD, - 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD8, 0xB3, 0xD8, - 0xAC, 0xD8, 0xAD, 0x46, 0xD8, 0xB3, 0xD8, 0xAC, - 0xD9, 0x89, 0x46, 0xD8, 0xB3, 0xD8, 0xAD, 0xD8, - 0xAC, 0x46, 0xD8, 0xB3, 0xD8, 0xAE, 0xD9, 0x89, - // Bytes 23c0 - 23ff - 0x46, 0xD8, 0xB3, 0xD8, 0xAE, 0xD9, 0x8A, 0x46, - 0xD8, 0xB3, 0xD9, 0x85, 0xD8, 0xAC, 0x46, 0xD8, - 0xB3, 0xD9, 0x85, 0xD8, 0xAD, 0x46, 0xD8, 0xB3, - 0xD9, 0x85, 0xD9, 0x85, 0x46, 0xD8, 0xB4, 0xD8, - 0xAC, 0xD9, 0x8A, 0x46, 0xD8, 0xB4, 0xD8, 0xAD, - 0xD9, 0x85, 0x46, 0xD8, 0xB4, 0xD8, 0xAD, 0xD9, - 0x8A, 0x46, 0xD8, 0xB4, 0xD9, 0x85, 0xD8, 0xAE, - 0x46, 0xD8, 0xB4, 0xD9, 0x85, 0xD9, 0x85, 0x46, - // Bytes 2400 - 243f - 0xD8, 0xB5, 0xD8, 0xAD, 0xD8, 0xAD, 0x46, 0xD8, - 0xB5, 0xD8, 0xAD, 0xD9, 0x8A, 0x46, 0xD8, 0xB5, - 0xD9, 0x84, 0xD9, 0x89, 0x46, 0xD8, 0xB5, 0xD9, - 0x84, 0xDB, 0x92, 0x46, 0xD8, 0xB5, 0xD9, 0x85, - 0xD9, 0x85, 0x46, 0xD8, 0xB6, 0xD8, 0xAD, 0xD9, - 0x89, 0x46, 0xD8, 0xB6, 0xD8, 0xAD, 0xD9, 0x8A, - 0x46, 0xD8, 0xB6, 0xD8, 0xAE, 0xD9, 0x85, 0x46, - 0xD8, 0xB7, 0xD9, 0x85, 0xD8, 0xAD, 0x46, 0xD8, - // Bytes 2440 - 247f - 0xB7, 0xD9, 0x85, 0xD9, 0x85, 0x46, 0xD8, 0xB7, - 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD8, 0xB9, 0xD8, - 0xAC, 0xD9, 0x85, 0x46, 0xD8, 0xB9, 0xD9, 0x85, - 0xD9, 0x85, 0x46, 0xD8, 0xB9, 0xD9, 0x85, 0xD9, - 0x89, 0x46, 0xD8, 0xB9, 0xD9, 0x85, 0xD9, 0x8A, - 0x46, 0xD8, 0xBA, 0xD9, 0x85, 0xD9, 0x85, 0x46, - 0xD8, 0xBA, 0xD9, 0x85, 0xD9, 0x89, 0x46, 0xD8, - 0xBA, 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD9, 0x81, - // Bytes 2480 - 24bf - 0xD8, 0xAE, 0xD9, 0x85, 0x46, 0xD9, 0x81, 0xD9, - 0x85, 0xD9, 0x8A, 0x46, 0xD9, 0x82, 0xD9, 0x84, - 0xDB, 0x92, 0x46, 0xD9, 0x82, 0xD9, 0x85, 0xD8, - 0xAD, 0x46, 0xD9, 0x82, 0xD9, 0x85, 0xD9, 0x85, - 0x46, 0xD9, 0x82, 0xD9, 0x85, 0xD9, 0x8A, 0x46, - 0xD9, 0x83, 0xD9, 0x85, 0xD9, 0x85, 0x46, 0xD9, - 0x83, 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD9, 0x84, - 0xD8, 0xAC, 0xD8, 0xAC, 0x46, 0xD9, 0x84, 0xD8, - // Bytes 24c0 - 24ff - 0xAC, 0xD9, 0x85, 0x46, 0xD9, 0x84, 0xD8, 0xAC, - 0xD9, 0x8A, 0x46, 0xD9, 0x84, 0xD8, 0xAD, 0xD9, - 0x85, 0x46, 0xD9, 0x84, 0xD8, 0xAD, 0xD9, 0x89, - 0x46, 0xD9, 0x84, 0xD8, 0xAD, 0xD9, 0x8A, 0x46, - 0xD9, 0x84, 0xD8, 0xAE, 0xD9, 0x85, 0x46, 0xD9, - 0x84, 0xD9, 0x85, 0xD8, 0xAD, 0x46, 0xD9, 0x84, - 0xD9, 0x85, 0xD9, 0x8A, 0x46, 0xD9, 0x85, 0xD8, - 0xAC, 0xD8, 0xAD, 0x46, 0xD9, 0x85, 0xD8, 0xAC, - // Bytes 2500 - 253f - 0xD8, 0xAE, 0x46, 0xD9, 0x85, 0xD8, 0xAC, 0xD9, - 0x85, 0x46, 0xD9, 0x85, 0xD8, 0xAC, 0xD9, 0x8A, - 0x46, 0xD9, 0x85, 0xD8, 0xAD, 0xD8, 0xAC, 0x46, - 0xD9, 0x85, 0xD8, 0xAD, 0xD9, 0x85, 0x46, 0xD9, - 0x85, 0xD8, 0xAD, 0xD9, 0x8A, 0x46, 0xD9, 0x85, - 0xD8, 0xAE, 0xD8, 0xAC, 0x46, 0xD9, 0x85, 0xD8, - 0xAE, 0xD9, 0x85, 0x46, 0xD9, 0x85, 0xD8, 0xAE, - 0xD9, 0x8A, 0x46, 0xD9, 0x85, 0xD9, 0x85, 0xD9, - // Bytes 2540 - 257f - 0x8A, 0x46, 0xD9, 0x86, 0xD8, 0xAC, 0xD8, 0xAD, - 0x46, 0xD9, 0x86, 0xD8, 0xAC, 0xD9, 0x85, 0x46, - 0xD9, 0x86, 0xD8, 0xAC, 0xD9, 0x89, 0x46, 0xD9, - 0x86, 0xD8, 0xAC, 0xD9, 0x8A, 0x46, 0xD9, 0x86, - 0xD8, 0xAD, 0xD9, 0x85, 0x46, 0xD9, 0x86, 0xD8, - 0xAD, 0xD9, 0x89, 0x46, 0xD9, 0x86, 0xD8, 0xAD, - 0xD9, 0x8A, 0x46, 0xD9, 0x86, 0xD9, 0x85, 0xD9, - 0x89, 0x46, 0xD9, 0x86, 0xD9, 0x85, 0xD9, 0x8A, - // Bytes 2580 - 25bf - 0x46, 0xD9, 0x87, 0xD9, 0x85, 0xD8, 0xAC, 0x46, - 0xD9, 0x87, 0xD9, 0x85, 0xD9, 0x85, 0x46, 0xD9, - 0x8A, 0xD8, 0xAC, 0xD9, 0x8A, 0x46, 0xD9, 0x8A, - 0xD8, 0xAD, 0xD9, 0x8A, 0x46, 0xD9, 0x8A, 0xD9, - 0x85, 0xD9, 0x85, 0x46, 0xD9, 0x8A, 0xD9, 0x85, - 0xD9, 0x8A, 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD8, - 0xA7, 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD8, 0xAC, - 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD8, 0xAD, 0x46, - // Bytes 25c0 - 25ff - 0xD9, 0x8A, 0xD9, 0x94, 0xD8, 0xAE, 0x46, 0xD9, - 0x8A, 0xD9, 0x94, 0xD8, 0xB1, 0x46, 0xD9, 0x8A, - 0xD9, 0x94, 0xD8, 0xB2, 0x46, 0xD9, 0x8A, 0xD9, - 0x94, 0xD9, 0x85, 0x46, 0xD9, 0x8A, 0xD9, 0x94, - 0xD9, 0x86, 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD9, - 0x87, 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD9, 0x88, - 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xD9, 0x89, 0x46, - 0xD9, 0x8A, 0xD9, 0x94, 0xD9, 0x8A, 0x46, 0xD9, - // Bytes 2600 - 263f - 0x8A, 0xD9, 0x94, 0xDB, 0x86, 0x46, 0xD9, 0x8A, - 0xD9, 0x94, 0xDB, 0x87, 0x46, 0xD9, 0x8A, 0xD9, - 0x94, 0xDB, 0x88, 0x46, 0xD9, 0x8A, 0xD9, 0x94, - 0xDB, 0x90, 0x46, 0xD9, 0x8A, 0xD9, 0x94, 0xDB, - 0x95, 0x46, 0xE0, 0xB9, 0x8D, 0xE0, 0xB8, 0xB2, - 0x46, 0xE0, 0xBA, 0xAB, 0xE0, 0xBA, 0x99, 0x46, - 0xE0, 0xBA, 0xAB, 0xE0, 0xBA, 0xA1, 0x46, 0xE0, - 0xBB, 0x8D, 0xE0, 0xBA, 0xB2, 0x46, 0xE0, 0xBD, - // Bytes 2640 - 267f - 0x80, 0xE0, 0xBE, 0xB5, 0x46, 0xE0, 0xBD, 0x82, - 0xE0, 0xBE, 0xB7, 0x46, 0xE0, 0xBD, 0x8C, 0xE0, - 0xBE, 0xB7, 0x46, 0xE0, 0xBD, 0x91, 0xE0, 0xBE, - 0xB7, 0x46, 0xE0, 0xBD, 0x96, 0xE0, 0xBE, 0xB7, - 0x46, 0xE0, 0xBD, 0x9B, 0xE0, 0xBE, 0xB7, 0x46, - 0xE0, 0xBE, 0x90, 0xE0, 0xBE, 0xB5, 0x46, 0xE0, - 0xBE, 0x92, 0xE0, 0xBE, 0xB7, 0x46, 0xE0, 0xBE, - 0x9C, 0xE0, 0xBE, 0xB7, 0x46, 0xE0, 0xBE, 0xA1, - // Bytes 2680 - 26bf - 0xE0, 0xBE, 0xB7, 0x46, 0xE0, 0xBE, 0xA6, 0xE0, - 0xBE, 0xB7, 0x46, 0xE0, 0xBE, 0xAB, 0xE0, 0xBE, - 0xB7, 0x46, 0xE2, 0x80, 0xB2, 0xE2, 0x80, 0xB2, - 0x46, 0xE2, 0x80, 0xB5, 0xE2, 0x80, 0xB5, 0x46, - 0xE2, 0x88, 0xAB, 0xE2, 0x88, 0xAB, 0x46, 0xE2, - 0x88, 0xAE, 0xE2, 0x88, 0xAE, 0x46, 0xE3, 0x81, - 0xBB, 0xE3, 0x81, 0x8B, 0x46, 0xE3, 0x82, 0x88, - 0xE3, 0x82, 0x8A, 0x46, 0xE3, 0x82, 0xAD, 0xE3, - // Bytes 26c0 - 26ff - 0x83, 0xAD, 0x46, 0xE3, 0x82, 0xB3, 0xE3, 0x82, - 0xB3, 0x46, 0xE3, 0x82, 0xB3, 0xE3, 0x83, 0x88, - 0x46, 0xE3, 0x83, 0x88, 0xE3, 0x83, 0xB3, 0x46, - 0xE3, 0x83, 0x8A, 0xE3, 0x83, 0x8E, 0x46, 0xE3, - 0x83, 0x9B, 0xE3, 0x83, 0xB3, 0x46, 0xE3, 0x83, - 0x9F, 0xE3, 0x83, 0xAA, 0x46, 0xE3, 0x83, 0xAA, - 0xE3, 0x83, 0xA9, 0x46, 0xE3, 0x83, 0xAC, 0xE3, - 0x83, 0xA0, 0x46, 0xE5, 0xA4, 0xA7, 0xE6, 0xAD, - // Bytes 2700 - 273f - 0xA3, 0x46, 0xE5, 0xB9, 0xB3, 0xE6, 0x88, 0x90, - 0x46, 0xE6, 0x98, 0x8E, 0xE6, 0xB2, 0xBB, 0x46, - 0xE6, 0x98, 0xAD, 0xE5, 0x92, 0x8C, 0x47, 0x72, - 0x61, 0x64, 0xE2, 0x88, 0x95, 0x73, 0x47, 0xE3, - 0x80, 0x94, 0x53, 0xE3, 0x80, 0x95, 0x48, 0x28, - 0xE1, 0x84, 0x80, 0xE1, 0x85, 0xA1, 0x29, 0x48, - 0x28, 0xE1, 0x84, 0x82, 0xE1, 0x85, 0xA1, 0x29, - 0x48, 0x28, 0xE1, 0x84, 0x83, 0xE1, 0x85, 0xA1, - // Bytes 2740 - 277f - 0x29, 0x48, 0x28, 0xE1, 0x84, 0x85, 0xE1, 0x85, - 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, 0x86, 0xE1, - 0x85, 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, 0x87, - 0xE1, 0x85, 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, - 0x89, 0xE1, 0x85, 0xA1, 0x29, 0x48, 0x28, 0xE1, - 0x84, 0x8B, 0xE1, 0x85, 0xA1, 0x29, 0x48, 0x28, - 0xE1, 0x84, 0x8C, 0xE1, 0x85, 0xA1, 0x29, 0x48, - 0x28, 0xE1, 0x84, 0x8C, 0xE1, 0x85, 0xAE, 0x29, - // Bytes 2780 - 27bf - 0x48, 0x28, 0xE1, 0x84, 0x8E, 0xE1, 0x85, 0xA1, - 0x29, 0x48, 0x28, 0xE1, 0x84, 0x8F, 0xE1, 0x85, - 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, 0x90, 0xE1, - 0x85, 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, 0x91, - 0xE1, 0x85, 0xA1, 0x29, 0x48, 0x28, 0xE1, 0x84, - 0x92, 0xE1, 0x85, 0xA1, 0x29, 0x48, 0x72, 0x61, - 0x64, 0xE2, 0x88, 0x95, 0x73, 0x32, 0x48, 0xD8, - 0xA7, 0xD9, 0x83, 0xD8, 0xA8, 0xD8, 0xB1, 0x48, - // Bytes 27c0 - 27ff - 0xD8, 0xA7, 0xD9, 0x84, 0xD9, 0x84, 0xD9, 0x87, - 0x48, 0xD8, 0xB1, 0xD8, 0xB3, 0xD9, 0x88, 0xD9, - 0x84, 0x48, 0xD8, 0xB1, 0xDB, 0x8C, 0xD8, 0xA7, - 0xD9, 0x84, 0x48, 0xD8, 0xB5, 0xD9, 0x84, 0xD8, - 0xB9, 0xD9, 0x85, 0x48, 0xD8, 0xB9, 0xD9, 0x84, - 0xD9, 0x8A, 0xD9, 0x87, 0x48, 0xD9, 0x85, 0xD8, - 0xAD, 0xD9, 0x85, 0xD8, 0xAF, 0x48, 0xD9, 0x88, - 0xD8, 0xB3, 0xD9, 0x84, 0xD9, 0x85, 0x49, 0xE2, - // Bytes 2800 - 283f - 0x80, 0xB2, 0xE2, 0x80, 0xB2, 0xE2, 0x80, 0xB2, - 0x49, 0xE2, 0x80, 0xB5, 0xE2, 0x80, 0xB5, 0xE2, - 0x80, 0xB5, 0x49, 0xE2, 0x88, 0xAB, 0xE2, 0x88, - 0xAB, 0xE2, 0x88, 0xAB, 0x49, 0xE2, 0x88, 0xAE, - 0xE2, 0x88, 0xAE, 0xE2, 0x88, 0xAE, 0x49, 0xE3, - 0x80, 0x94, 0xE4, 0xB8, 0x89, 0xE3, 0x80, 0x95, - 0x49, 0xE3, 0x80, 0x94, 0xE4, 0xBA, 0x8C, 0xE3, - 0x80, 0x95, 0x49, 0xE3, 0x80, 0x94, 0xE5, 0x8B, - // Bytes 2840 - 287f - 0x9D, 0xE3, 0x80, 0x95, 0x49, 0xE3, 0x80, 0x94, - 0xE5, 0xAE, 0x89, 0xE3, 0x80, 0x95, 0x49, 0xE3, - 0x80, 0x94, 0xE6, 0x89, 0x93, 0xE3, 0x80, 0x95, - 0x49, 0xE3, 0x80, 0x94, 0xE6, 0x95, 0x97, 0xE3, - 0x80, 0x95, 0x49, 0xE3, 0x80, 0x94, 0xE6, 0x9C, - 0xAC, 0xE3, 0x80, 0x95, 0x49, 0xE3, 0x80, 0x94, - 0xE7, 0x82, 0xB9, 0xE3, 0x80, 0x95, 0x49, 0xE3, - 0x80, 0x94, 0xE7, 0x9B, 0x97, 0xE3, 0x80, 0x95, - // Bytes 2880 - 28bf - 0x49, 0xE3, 0x82, 0xA2, 0xE3, 0x83, 0xBC, 0xE3, - 0x83, 0xAB, 0x49, 0xE3, 0x82, 0xA4, 0xE3, 0x83, - 0xB3, 0xE3, 0x83, 0x81, 0x49, 0xE3, 0x82, 0xA6, - 0xE3, 0x82, 0xA9, 0xE3, 0x83, 0xB3, 0x49, 0xE3, - 0x82, 0xAA, 0xE3, 0x83, 0xB3, 0xE3, 0x82, 0xB9, - 0x49, 0xE3, 0x82, 0xAA, 0xE3, 0x83, 0xBC, 0xE3, - 0x83, 0xA0, 0x49, 0xE3, 0x82, 0xAB, 0xE3, 0x82, - 0xA4, 0xE3, 0x83, 0xAA, 0x49, 0xE3, 0x82, 0xB1, - // Bytes 28c0 - 28ff - 0xE3, 0x83, 0xBC, 0xE3, 0x82, 0xB9, 0x49, 0xE3, - 0x82, 0xB3, 0xE3, 0x83, 0xAB, 0xE3, 0x83, 0x8A, - 0x49, 0xE3, 0x82, 0xBB, 0xE3, 0x83, 0xB3, 0xE3, - 0x83, 0x81, 0x49, 0xE3, 0x82, 0xBB, 0xE3, 0x83, - 0xB3, 0xE3, 0x83, 0x88, 0x49, 0xE3, 0x83, 0x86, - 0xE3, 0x82, 0x99, 0xE3, 0x82, 0xB7, 0x49, 0xE3, - 0x83, 0x88, 0xE3, 0x82, 0x99, 0xE3, 0x83, 0xAB, - 0x49, 0xE3, 0x83, 0x8E, 0xE3, 0x83, 0x83, 0xE3, - // Bytes 2900 - 293f - 0x83, 0x88, 0x49, 0xE3, 0x83, 0x8F, 0xE3, 0x82, - 0xA4, 0xE3, 0x83, 0x84, 0x49, 0xE3, 0x83, 0x92, - 0xE3, 0x82, 0x99, 0xE3, 0x83, 0xAB, 0x49, 0xE3, - 0x83, 0x92, 0xE3, 0x82, 0x9A, 0xE3, 0x82, 0xB3, - 0x49, 0xE3, 0x83, 0x95, 0xE3, 0x83, 0xA9, 0xE3, - 0x83, 0xB3, 0x49, 0xE3, 0x83, 0x98, 0xE3, 0x82, - 0x9A, 0xE3, 0x82, 0xBD, 0x49, 0xE3, 0x83, 0x98, - 0xE3, 0x83, 0xAB, 0xE3, 0x83, 0x84, 0x49, 0xE3, - // Bytes 2940 - 297f - 0x83, 0x9B, 0xE3, 0x83, 0xBC, 0xE3, 0x83, 0xAB, - 0x49, 0xE3, 0x83, 0x9B, 0xE3, 0x83, 0xBC, 0xE3, - 0x83, 0xB3, 0x49, 0xE3, 0x83, 0x9E, 0xE3, 0x82, - 0xA4, 0xE3, 0x83, 0xAB, 0x49, 0xE3, 0x83, 0x9E, - 0xE3, 0x83, 0x83, 0xE3, 0x83, 0x8F, 0x49, 0xE3, - 0x83, 0x9E, 0xE3, 0x83, 0xAB, 0xE3, 0x82, 0xAF, - 0x49, 0xE3, 0x83, 0xA4, 0xE3, 0x83, 0xBC, 0xE3, - 0x83, 0xAB, 0x49, 0xE3, 0x83, 0xA6, 0xE3, 0x82, - // Bytes 2980 - 29bf - 0xA2, 0xE3, 0x83, 0xB3, 0x49, 0xE3, 0x83, 0xAF, - 0xE3, 0x83, 0x83, 0xE3, 0x83, 0x88, 0x4C, 0xE2, - 0x80, 0xB2, 0xE2, 0x80, 0xB2, 0xE2, 0x80, 0xB2, - 0xE2, 0x80, 0xB2, 0x4C, 0xE2, 0x88, 0xAB, 0xE2, - 0x88, 0xAB, 0xE2, 0x88, 0xAB, 0xE2, 0x88, 0xAB, - 0x4C, 0xE3, 0x82, 0xA2, 0xE3, 0x83, 0xAB, 0xE3, - 0x83, 0x95, 0xE3, 0x82, 0xA1, 0x4C, 0xE3, 0x82, - 0xA8, 0xE3, 0x83, 0xBC, 0xE3, 0x82, 0xAB, 0xE3, - // Bytes 29c0 - 29ff - 0x83, 0xBC, 0x4C, 0xE3, 0x82, 0xAB, 0xE3, 0x82, - 0x99, 0xE3, 0x83, 0xAD, 0xE3, 0x83, 0xB3, 0x4C, - 0xE3, 0x82, 0xAB, 0xE3, 0x82, 0x99, 0xE3, 0x83, - 0xB3, 0xE3, 0x83, 0x9E, 0x4C, 0xE3, 0x82, 0xAB, - 0xE3, 0x83, 0xA9, 0xE3, 0x83, 0x83, 0xE3, 0x83, - 0x88, 0x4C, 0xE3, 0x82, 0xAB, 0xE3, 0x83, 0xAD, - 0xE3, 0x83, 0xAA, 0xE3, 0x83, 0xBC, 0x4C, 0xE3, - 0x82, 0xAD, 0xE3, 0x82, 0x99, 0xE3, 0x83, 0x8B, - // Bytes 2a00 - 2a3f - 0xE3, 0x83, 0xBC, 0x4C, 0xE3, 0x82, 0xAD, 0xE3, - 0x83, 0xA5, 0xE3, 0x83, 0xAA, 0xE3, 0x83, 0xBC, - 0x4C, 0xE3, 0x82, 0xAF, 0xE3, 0x82, 0x99, 0xE3, - 0x83, 0xA9, 0xE3, 0x83, 0xA0, 0x4C, 0xE3, 0x82, - 0xAF, 0xE3, 0x83, 0xAD, 0xE3, 0x83, 0xBC, 0xE3, - 0x83, 0x8D, 0x4C, 0xE3, 0x82, 0xB5, 0xE3, 0x82, - 0xA4, 0xE3, 0x82, 0xAF, 0xE3, 0x83, 0xAB, 0x4C, - 0xE3, 0x82, 0xBF, 0xE3, 0x82, 0x99, 0xE3, 0x83, - // Bytes 2a40 - 2a7f - 0xBC, 0xE3, 0x82, 0xB9, 0x4C, 0xE3, 0x83, 0x8F, - 0xE3, 0x82, 0x9A, 0xE3, 0x83, 0xBC, 0xE3, 0x83, - 0x84, 0x4C, 0xE3, 0x83, 0x92, 0xE3, 0x82, 0x9A, - 0xE3, 0x82, 0xAF, 0xE3, 0x83, 0xAB, 0x4C, 0xE3, - 0x83, 0x95, 0xE3, 0x82, 0xA3, 0xE3, 0x83, 0xBC, - 0xE3, 0x83, 0x88, 0x4C, 0xE3, 0x83, 0x98, 0xE3, - 0x82, 0x99, 0xE3, 0x83, 0xBC, 0xE3, 0x82, 0xBF, - 0x4C, 0xE3, 0x83, 0x98, 0xE3, 0x82, 0x9A, 0xE3, - // Bytes 2a80 - 2abf - 0x83, 0x8B, 0xE3, 0x83, 0x92, 0x4C, 0xE3, 0x83, - 0x98, 0xE3, 0x82, 0x9A, 0xE3, 0x83, 0xB3, 0xE3, - 0x82, 0xB9, 0x4C, 0xE3, 0x83, 0x9B, 0xE3, 0x82, - 0x99, 0xE3, 0x83, 0xAB, 0xE3, 0x83, 0x88, 0x4C, - 0xE3, 0x83, 0x9E, 0xE3, 0x82, 0xA4, 0xE3, 0x82, - 0xAF, 0xE3, 0x83, 0xAD, 0x4C, 0xE3, 0x83, 0x9F, - 0xE3, 0x82, 0xAF, 0xE3, 0x83, 0xAD, 0xE3, 0x83, - 0xB3, 0x4C, 0xE3, 0x83, 0xA1, 0xE3, 0x83, 0xBC, - // Bytes 2ac0 - 2aff - 0xE3, 0x83, 0x88, 0xE3, 0x83, 0xAB, 0x4C, 0xE3, - 0x83, 0xAA, 0xE3, 0x83, 0x83, 0xE3, 0x83, 0x88, - 0xE3, 0x83, 0xAB, 0x4C, 0xE3, 0x83, 0xAB, 0xE3, - 0x83, 0x92, 0xE3, 0x82, 0x9A, 0xE3, 0x83, 0xBC, - 0x4C, 0xE6, 0xA0, 0xAA, 0xE5, 0xBC, 0x8F, 0xE4, - 0xBC, 0x9A, 0xE7, 0xA4, 0xBE, 0x4E, 0x28, 0xE1, - 0x84, 0x8B, 0xE1, 0x85, 0xA9, 0xE1, 0x84, 0x92, - 0xE1, 0x85, 0xAE, 0x29, 0x4F, 0xD8, 0xAC, 0xD9, - // Bytes 2b00 - 2b3f - 0x84, 0x20, 0xD8, 0xAC, 0xD9, 0x84, 0xD8, 0xA7, - 0xD9, 0x84, 0xD9, 0x87, 0x4F, 0xE3, 0x82, 0xA2, - 0xE3, 0x83, 0x8F, 0xE3, 0x82, 0x9A, 0xE3, 0x83, - 0xBC, 0xE3, 0x83, 0x88, 0x4F, 0xE3, 0x82, 0xA2, - 0xE3, 0x83, 0xB3, 0xE3, 0x83, 0x98, 0xE3, 0x82, - 0x9A, 0xE3, 0x82, 0xA2, 0x4F, 0xE3, 0x82, 0xAD, - 0xE3, 0x83, 0xAD, 0xE3, 0x83, 0xAF, 0xE3, 0x83, - 0x83, 0xE3, 0x83, 0x88, 0x4F, 0xE3, 0x82, 0xB5, - // Bytes 2b40 - 2b7f - 0xE3, 0x83, 0xB3, 0xE3, 0x83, 0x81, 0xE3, 0x83, - 0xBC, 0xE3, 0x83, 0xA0, 0x4F, 0xE3, 0x83, 0x8F, - 0xE3, 0x82, 0x99, 0xE3, 0x83, 0xBC, 0xE3, 0x83, - 0xAC, 0xE3, 0x83, 0xAB, 0x4F, 0xE3, 0x83, 0x98, - 0xE3, 0x82, 0xAF, 0xE3, 0x82, 0xBF, 0xE3, 0x83, - 0xBC, 0xE3, 0x83, 0xAB, 0x4F, 0xE3, 0x83, 0x9B, - 0xE3, 0x82, 0x9A, 0xE3, 0x82, 0xA4, 0xE3, 0x83, - 0xB3, 0xE3, 0x83, 0x88, 0x4F, 0xE3, 0x83, 0x9E, - // Bytes 2b80 - 2bbf - 0xE3, 0x83, 0xB3, 0xE3, 0x82, 0xB7, 0xE3, 0x83, - 0xA7, 0xE3, 0x83, 0xB3, 0x4F, 0xE3, 0x83, 0xA1, - 0xE3, 0x82, 0xAB, 0xE3, 0x82, 0x99, 0xE3, 0x83, - 0x88, 0xE3, 0x83, 0xB3, 0x4F, 0xE3, 0x83, 0xAB, - 0xE3, 0x83, 0xBC, 0xE3, 0x83, 0x95, 0xE3, 0x82, - 0x99, 0xE3, 0x83, 0xAB, 0x51, 0x28, 0xE1, 0x84, - 0x8B, 0xE1, 0x85, 0xA9, 0xE1, 0x84, 0x8C, 0xE1, - 0x85, 0xA5, 0xE1, 0x86, 0xAB, 0x29, 0x52, 0xE3, - // Bytes 2bc0 - 2bff - 0x82, 0xAD, 0xE3, 0x82, 0x99, 0xE3, 0x83, 0xAB, - 0xE3, 0x82, 0xBF, 0xE3, 0x82, 0x99, 0xE3, 0x83, - 0xBC, 0x52, 0xE3, 0x82, 0xAD, 0xE3, 0x83, 0xAD, - 0xE3, 0x82, 0xAF, 0xE3, 0x82, 0x99, 0xE3, 0x83, - 0xA9, 0xE3, 0x83, 0xA0, 0x52, 0xE3, 0x82, 0xAD, - 0xE3, 0x83, 0xAD, 0xE3, 0x83, 0xA1, 0xE3, 0x83, - 0xBC, 0xE3, 0x83, 0x88, 0xE3, 0x83, 0xAB, 0x52, - 0xE3, 0x82, 0xAF, 0xE3, 0x82, 0x99, 0xE3, 0x83, - // Bytes 2c00 - 2c3f - 0xA9, 0xE3, 0x83, 0xA0, 0xE3, 0x83, 0x88, 0xE3, - 0x83, 0xB3, 0x52, 0xE3, 0x82, 0xAF, 0xE3, 0x83, - 0xAB, 0xE3, 0x82, 0xBB, 0xE3, 0x82, 0x99, 0xE3, - 0x82, 0xA4, 0xE3, 0x83, 0xAD, 0x52, 0xE3, 0x83, - 0x8F, 0xE3, 0x82, 0x9A, 0xE3, 0x83, 0xBC, 0xE3, - 0x82, 0xBB, 0xE3, 0x83, 0xB3, 0xE3, 0x83, 0x88, - 0x52, 0xE3, 0x83, 0x92, 0xE3, 0x82, 0x9A, 0xE3, - 0x82, 0xA2, 0xE3, 0x82, 0xB9, 0xE3, 0x83, 0x88, - // Bytes 2c40 - 2c7f - 0xE3, 0x83, 0xAB, 0x52, 0xE3, 0x83, 0x95, 0xE3, - 0x82, 0x99, 0xE3, 0x83, 0x83, 0xE3, 0x82, 0xB7, - 0xE3, 0x82, 0xA7, 0xE3, 0x83, 0xAB, 0x52, 0xE3, - 0x83, 0x9F, 0xE3, 0x83, 0xAA, 0xE3, 0x83, 0x8F, - 0xE3, 0x82, 0x99, 0xE3, 0x83, 0xBC, 0xE3, 0x83, - 0xAB, 0x52, 0xE3, 0x83, 0xAC, 0xE3, 0x83, 0xB3, - 0xE3, 0x83, 0x88, 0xE3, 0x82, 0xB1, 0xE3, 0x82, - 0x99, 0xE3, 0x83, 0xB3, 0x61, 0xD8, 0xB5, 0xD9, - // Bytes 2c80 - 2cbf - 0x84, 0xD9, 0x89, 0x20, 0xD8, 0xA7, 0xD9, 0x84, - 0xD9, 0x84, 0xD9, 0x87, 0x20, 0xD8, 0xB9, 0xD9, - 0x84, 0xD9, 0x8A, 0xD9, 0x87, 0x20, 0xD9, 0x88, - 0xD8, 0xB3, 0xD9, 0x84, 0xD9, 0x85, 0x06, 0xE0, - 0xA7, 0x87, 0xE0, 0xA6, 0xBE, 0x01, 0x06, 0xE0, - 0xA7, 0x87, 0xE0, 0xA7, 0x97, 0x01, 0x06, 0xE0, - 0xAD, 0x87, 0xE0, 0xAC, 0xBE, 0x01, 0x06, 0xE0, - 0xAD, 0x87, 0xE0, 0xAD, 0x96, 0x01, 0x06, 0xE0, - // Bytes 2cc0 - 2cff - 0xAD, 0x87, 0xE0, 0xAD, 0x97, 0x01, 0x06, 0xE0, - 0xAE, 0x92, 0xE0, 0xAF, 0x97, 0x01, 0x06, 0xE0, - 0xAF, 0x86, 0xE0, 0xAE, 0xBE, 0x01, 0x06, 0xE0, - 0xAF, 0x86, 0xE0, 0xAF, 0x97, 0x01, 0x06, 0xE0, - 0xAF, 0x87, 0xE0, 0xAE, 0xBE, 0x01, 0x06, 0xE0, - 0xB2, 0xBF, 0xE0, 0xB3, 0x95, 0x01, 0x06, 0xE0, - 0xB3, 0x86, 0xE0, 0xB3, 0x95, 0x01, 0x06, 0xE0, - 0xB3, 0x86, 0xE0, 0xB3, 0x96, 0x01, 0x06, 0xE0, - // Bytes 2d00 - 2d3f - 0xB5, 0x86, 0xE0, 0xB4, 0xBE, 0x01, 0x06, 0xE0, - 0xB5, 0x86, 0xE0, 0xB5, 0x97, 0x01, 0x06, 0xE0, - 0xB5, 0x87, 0xE0, 0xB4, 0xBE, 0x01, 0x06, 0xE0, - 0xB7, 0x99, 0xE0, 0xB7, 0x9F, 0x01, 0x06, 0xE1, - 0x80, 0xA5, 0xE1, 0x80, 0xAE, 0x01, 0x06, 0xE1, - 0xAC, 0x85, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0x87, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0x89, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - // Bytes 2d40 - 2d7f - 0xAC, 0x8B, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0x8D, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0x91, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0xBA, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0xBC, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0xBE, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAC, 0xBF, 0xE1, 0xAC, 0xB5, 0x01, 0x06, 0xE1, - 0xAD, 0x82, 0xE1, 0xAC, 0xB5, 0x01, 0x08, 0xF0, - // Bytes 2d80 - 2dbf - 0x91, 0x84, 0xB1, 0xF0, 0x91, 0x84, 0xA7, 0x01, - 0x08, 0xF0, 0x91, 0x84, 0xB2, 0xF0, 0x91, 0x84, - 0xA7, 0x01, 0x08, 0xF0, 0x91, 0x8D, 0x87, 0xF0, - 0x91, 0x8C, 0xBE, 0x01, 0x08, 0xF0, 0x91, 0x8D, - 0x87, 0xF0, 0x91, 0x8D, 0x97, 0x01, 0x08, 0xF0, - 0x91, 0x92, 0xB9, 0xF0, 0x91, 0x92, 0xB0, 0x01, - 0x08, 0xF0, 0x91, 0x92, 0xB9, 0xF0, 0x91, 0x92, - 0xBA, 0x01, 0x08, 0xF0, 0x91, 0x92, 0xB9, 0xF0, - // Bytes 2dc0 - 2dff - 0x91, 0x92, 0xBD, 0x01, 0x08, 0xF0, 0x91, 0x96, - 0xB8, 0xF0, 0x91, 0x96, 0xAF, 0x01, 0x08, 0xF0, - 0x91, 0x96, 0xB9, 0xF0, 0x91, 0x96, 0xAF, 0x01, - 0x09, 0xE0, 0xB3, 0x86, 0xE0, 0xB3, 0x82, 0xE0, - 0xB3, 0x95, 0x02, 0x09, 0xE0, 0xB7, 0x99, 0xE0, - 0xB7, 0x8F, 0xE0, 0xB7, 0x8A, 0x12, 0x44, 0x44, - 0x5A, 0xCC, 0x8C, 0xC9, 0x44, 0x44, 0x7A, 0xCC, - 0x8C, 0xC9, 0x44, 0x64, 0x7A, 0xCC, 0x8C, 0xC9, - // Bytes 2e00 - 2e3f - 0x46, 0xD9, 0x84, 0xD8, 0xA7, 0xD9, 0x93, 0xC9, - 0x46, 0xD9, 0x84, 0xD8, 0xA7, 0xD9, 0x94, 0xC9, - 0x46, 0xD9, 0x84, 0xD8, 0xA7, 0xD9, 0x95, 0xB5, - 0x46, 0xE1, 0x84, 0x80, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x82, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x83, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x85, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x86, 0xE1, 0x85, 0xA1, 0x01, - // Bytes 2e40 - 2e7f - 0x46, 0xE1, 0x84, 0x87, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x89, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x8B, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x8B, 0xE1, 0x85, 0xAE, 0x01, - 0x46, 0xE1, 0x84, 0x8C, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x8E, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x8F, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x90, 0xE1, 0x85, 0xA1, 0x01, - // Bytes 2e80 - 2ebf - 0x46, 0xE1, 0x84, 0x91, 0xE1, 0x85, 0xA1, 0x01, - 0x46, 0xE1, 0x84, 0x92, 0xE1, 0x85, 0xA1, 0x01, - 0x49, 0xE3, 0x83, 0xA1, 0xE3, 0x82, 0xAB, 0xE3, - 0x82, 0x99, 0x0D, 0x4C, 0xE1, 0x84, 0x8C, 0xE1, - 0x85, 0xAE, 0xE1, 0x84, 0x8B, 0xE1, 0x85, 0xB4, - 0x01, 0x4C, 0xE3, 0x82, 0xAD, 0xE3, 0x82, 0x99, - 0xE3, 0x82, 0xAB, 0xE3, 0x82, 0x99, 0x0D, 0x4C, - 0xE3, 0x82, 0xB3, 0xE3, 0x83, 0xBC, 0xE3, 0x83, - // Bytes 2ec0 - 2eff - 0x9B, 0xE3, 0x82, 0x9A, 0x0D, 0x4C, 0xE3, 0x83, - 0xA4, 0xE3, 0x83, 0xBC, 0xE3, 0x83, 0x88, 0xE3, - 0x82, 0x99, 0x0D, 0x4F, 0xE1, 0x84, 0x8E, 0xE1, - 0x85, 0xA1, 0xE1, 0x86, 0xB7, 0xE1, 0x84, 0x80, - 0xE1, 0x85, 0xA9, 0x01, 0x4F, 0xE3, 0x82, 0xA4, - 0xE3, 0x83, 0x8B, 0xE3, 0x83, 0xB3, 0xE3, 0x82, - 0xAF, 0xE3, 0x82, 0x99, 0x0D, 0x4F, 0xE3, 0x82, - 0xB7, 0xE3, 0x83, 0xAA, 0xE3, 0x83, 0xB3, 0xE3, - // Bytes 2f00 - 2f3f - 0x82, 0xAF, 0xE3, 0x82, 0x99, 0x0D, 0x4F, 0xE3, - 0x83, 0x98, 0xE3, 0x82, 0x9A, 0xE3, 0x83, 0xBC, - 0xE3, 0x82, 0xB7, 0xE3, 0x82, 0x99, 0x0D, 0x4F, - 0xE3, 0x83, 0x9B, 0xE3, 0x82, 0x9A, 0xE3, 0x83, - 0xB3, 0xE3, 0x83, 0x88, 0xE3, 0x82, 0x99, 0x0D, - 0x52, 0xE3, 0x82, 0xA8, 0xE3, 0x82, 0xB9, 0xE3, - 0x82, 0xAF, 0xE3, 0x83, 0xBC, 0xE3, 0x83, 0x88, - 0xE3, 0x82, 0x99, 0x0D, 0x52, 0xE3, 0x83, 0x95, - // Bytes 2f40 - 2f7f - 0xE3, 0x82, 0xA1, 0xE3, 0x83, 0xA9, 0xE3, 0x83, - 0x83, 0xE3, 0x83, 0x88, 0xE3, 0x82, 0x99, 0x0D, - 0x86, 0xE0, 0xB3, 0x86, 0xE0, 0xB3, 0x82, 0x01, - 0x86, 0xE0, 0xB7, 0x99, 0xE0, 0xB7, 0x8F, 0x01, - 0x03, 0x3C, 0xCC, 0xB8, 0x05, 0x03, 0x3D, 0xCC, - 0xB8, 0x05, 0x03, 0x3E, 0xCC, 0xB8, 0x05, 0x03, - 0x41, 0xCC, 0x80, 0xC9, 0x03, 0x41, 0xCC, 0x81, - 0xC9, 0x03, 0x41, 0xCC, 0x83, 0xC9, 0x03, 0x41, - // Bytes 2f80 - 2fbf - 0xCC, 0x84, 0xC9, 0x03, 0x41, 0xCC, 0x89, 0xC9, - 0x03, 0x41, 0xCC, 0x8C, 0xC9, 0x03, 0x41, 0xCC, - 0x8F, 0xC9, 0x03, 0x41, 0xCC, 0x91, 0xC9, 0x03, - 0x41, 0xCC, 0xA5, 0xB5, 0x03, 0x41, 0xCC, 0xA8, - 0xA5, 0x03, 0x42, 0xCC, 0x87, 0xC9, 0x03, 0x42, - 0xCC, 0xA3, 0xB5, 0x03, 0x42, 0xCC, 0xB1, 0xB5, - 0x03, 0x43, 0xCC, 0x81, 0xC9, 0x03, 0x43, 0xCC, - 0x82, 0xC9, 0x03, 0x43, 0xCC, 0x87, 0xC9, 0x03, - // Bytes 2fc0 - 2fff - 0x43, 0xCC, 0x8C, 0xC9, 0x03, 0x44, 0xCC, 0x87, - 0xC9, 0x03, 0x44, 0xCC, 0x8C, 0xC9, 0x03, 0x44, - 0xCC, 0xA3, 0xB5, 0x03, 0x44, 0xCC, 0xA7, 0xA5, - 0x03, 0x44, 0xCC, 0xAD, 0xB5, 0x03, 0x44, 0xCC, - 0xB1, 0xB5, 0x03, 0x45, 0xCC, 0x80, 0xC9, 0x03, - 0x45, 0xCC, 0x81, 0xC9, 0x03, 0x45, 0xCC, 0x83, - 0xC9, 0x03, 0x45, 0xCC, 0x86, 0xC9, 0x03, 0x45, - 0xCC, 0x87, 0xC9, 0x03, 0x45, 0xCC, 0x88, 0xC9, - // Bytes 3000 - 303f - 0x03, 0x45, 0xCC, 0x89, 0xC9, 0x03, 0x45, 0xCC, - 0x8C, 0xC9, 0x03, 0x45, 0xCC, 0x8F, 0xC9, 0x03, - 0x45, 0xCC, 0x91, 0xC9, 0x03, 0x45, 0xCC, 0xA8, - 0xA5, 0x03, 0x45, 0xCC, 0xAD, 0xB5, 0x03, 0x45, - 0xCC, 0xB0, 0xB5, 0x03, 0x46, 0xCC, 0x87, 0xC9, - 0x03, 0x47, 0xCC, 0x81, 0xC9, 0x03, 0x47, 0xCC, - 0x82, 0xC9, 0x03, 0x47, 0xCC, 0x84, 0xC9, 0x03, - 0x47, 0xCC, 0x86, 0xC9, 0x03, 0x47, 0xCC, 0x87, - // Bytes 3040 - 307f - 0xC9, 0x03, 0x47, 0xCC, 0x8C, 0xC9, 0x03, 0x47, - 0xCC, 0xA7, 0xA5, 0x03, 0x48, 0xCC, 0x82, 0xC9, - 0x03, 0x48, 0xCC, 0x87, 0xC9, 0x03, 0x48, 0xCC, - 0x88, 0xC9, 0x03, 0x48, 0xCC, 0x8C, 0xC9, 0x03, - 0x48, 0xCC, 0xA3, 0xB5, 0x03, 0x48, 0xCC, 0xA7, - 0xA5, 0x03, 0x48, 0xCC, 0xAE, 0xB5, 0x03, 0x49, - 0xCC, 0x80, 0xC9, 0x03, 0x49, 0xCC, 0x81, 0xC9, - 0x03, 0x49, 0xCC, 0x82, 0xC9, 0x03, 0x49, 0xCC, - // Bytes 3080 - 30bf - 0x83, 0xC9, 0x03, 0x49, 0xCC, 0x84, 0xC9, 0x03, - 0x49, 0xCC, 0x86, 0xC9, 0x03, 0x49, 0xCC, 0x87, - 0xC9, 0x03, 0x49, 0xCC, 0x89, 0xC9, 0x03, 0x49, - 0xCC, 0x8C, 0xC9, 0x03, 0x49, 0xCC, 0x8F, 0xC9, - 0x03, 0x49, 0xCC, 0x91, 0xC9, 0x03, 0x49, 0xCC, - 0xA3, 0xB5, 0x03, 0x49, 0xCC, 0xA8, 0xA5, 0x03, - 0x49, 0xCC, 0xB0, 0xB5, 0x03, 0x4A, 0xCC, 0x82, - 0xC9, 0x03, 0x4B, 0xCC, 0x81, 0xC9, 0x03, 0x4B, - // Bytes 30c0 - 30ff - 0xCC, 0x8C, 0xC9, 0x03, 0x4B, 0xCC, 0xA3, 0xB5, - 0x03, 0x4B, 0xCC, 0xA7, 0xA5, 0x03, 0x4B, 0xCC, - 0xB1, 0xB5, 0x03, 0x4C, 0xCC, 0x81, 0xC9, 0x03, - 0x4C, 0xCC, 0x8C, 0xC9, 0x03, 0x4C, 0xCC, 0xA7, - 0xA5, 0x03, 0x4C, 0xCC, 0xAD, 0xB5, 0x03, 0x4C, - 0xCC, 0xB1, 0xB5, 0x03, 0x4D, 0xCC, 0x81, 0xC9, - 0x03, 0x4D, 0xCC, 0x87, 0xC9, 0x03, 0x4D, 0xCC, - 0xA3, 0xB5, 0x03, 0x4E, 0xCC, 0x80, 0xC9, 0x03, - // Bytes 3100 - 313f - 0x4E, 0xCC, 0x81, 0xC9, 0x03, 0x4E, 0xCC, 0x83, - 0xC9, 0x03, 0x4E, 0xCC, 0x87, 0xC9, 0x03, 0x4E, - 0xCC, 0x8C, 0xC9, 0x03, 0x4E, 0xCC, 0xA3, 0xB5, - 0x03, 0x4E, 0xCC, 0xA7, 0xA5, 0x03, 0x4E, 0xCC, - 0xAD, 0xB5, 0x03, 0x4E, 0xCC, 0xB1, 0xB5, 0x03, - 0x4F, 0xCC, 0x80, 0xC9, 0x03, 0x4F, 0xCC, 0x81, - 0xC9, 0x03, 0x4F, 0xCC, 0x86, 0xC9, 0x03, 0x4F, - 0xCC, 0x89, 0xC9, 0x03, 0x4F, 0xCC, 0x8B, 0xC9, - // Bytes 3140 - 317f - 0x03, 0x4F, 0xCC, 0x8C, 0xC9, 0x03, 0x4F, 0xCC, - 0x8F, 0xC9, 0x03, 0x4F, 0xCC, 0x91, 0xC9, 0x03, - 0x50, 0xCC, 0x81, 0xC9, 0x03, 0x50, 0xCC, 0x87, - 0xC9, 0x03, 0x52, 0xCC, 0x81, 0xC9, 0x03, 0x52, - 0xCC, 0x87, 0xC9, 0x03, 0x52, 0xCC, 0x8C, 0xC9, - 0x03, 0x52, 0xCC, 0x8F, 0xC9, 0x03, 0x52, 0xCC, - 0x91, 0xC9, 0x03, 0x52, 0xCC, 0xA7, 0xA5, 0x03, - 0x52, 0xCC, 0xB1, 0xB5, 0x03, 0x53, 0xCC, 0x82, - // Bytes 3180 - 31bf - 0xC9, 0x03, 0x53, 0xCC, 0x87, 0xC9, 0x03, 0x53, - 0xCC, 0xA6, 0xB5, 0x03, 0x53, 0xCC, 0xA7, 0xA5, - 0x03, 0x54, 0xCC, 0x87, 0xC9, 0x03, 0x54, 0xCC, - 0x8C, 0xC9, 0x03, 0x54, 0xCC, 0xA3, 0xB5, 0x03, - 0x54, 0xCC, 0xA6, 0xB5, 0x03, 0x54, 0xCC, 0xA7, - 0xA5, 0x03, 0x54, 0xCC, 0xAD, 0xB5, 0x03, 0x54, - 0xCC, 0xB1, 0xB5, 0x03, 0x55, 0xCC, 0x80, 0xC9, - 0x03, 0x55, 0xCC, 0x81, 0xC9, 0x03, 0x55, 0xCC, - // Bytes 31c0 - 31ff - 0x82, 0xC9, 0x03, 0x55, 0xCC, 0x86, 0xC9, 0x03, - 0x55, 0xCC, 0x89, 0xC9, 0x03, 0x55, 0xCC, 0x8A, - 0xC9, 0x03, 0x55, 0xCC, 0x8B, 0xC9, 0x03, 0x55, - 0xCC, 0x8C, 0xC9, 0x03, 0x55, 0xCC, 0x8F, 0xC9, - 0x03, 0x55, 0xCC, 0x91, 0xC9, 0x03, 0x55, 0xCC, - 0xA3, 0xB5, 0x03, 0x55, 0xCC, 0xA4, 0xB5, 0x03, - 0x55, 0xCC, 0xA8, 0xA5, 0x03, 0x55, 0xCC, 0xAD, - 0xB5, 0x03, 0x55, 0xCC, 0xB0, 0xB5, 0x03, 0x56, - // Bytes 3200 - 323f - 0xCC, 0x83, 0xC9, 0x03, 0x56, 0xCC, 0xA3, 0xB5, - 0x03, 0x57, 0xCC, 0x80, 0xC9, 0x03, 0x57, 0xCC, - 0x81, 0xC9, 0x03, 0x57, 0xCC, 0x82, 0xC9, 0x03, - 0x57, 0xCC, 0x87, 0xC9, 0x03, 0x57, 0xCC, 0x88, - 0xC9, 0x03, 0x57, 0xCC, 0xA3, 0xB5, 0x03, 0x58, - 0xCC, 0x87, 0xC9, 0x03, 0x58, 0xCC, 0x88, 0xC9, - 0x03, 0x59, 0xCC, 0x80, 0xC9, 0x03, 0x59, 0xCC, - 0x81, 0xC9, 0x03, 0x59, 0xCC, 0x82, 0xC9, 0x03, - // Bytes 3240 - 327f - 0x59, 0xCC, 0x83, 0xC9, 0x03, 0x59, 0xCC, 0x84, - 0xC9, 0x03, 0x59, 0xCC, 0x87, 0xC9, 0x03, 0x59, - 0xCC, 0x88, 0xC9, 0x03, 0x59, 0xCC, 0x89, 0xC9, - 0x03, 0x59, 0xCC, 0xA3, 0xB5, 0x03, 0x5A, 0xCC, - 0x81, 0xC9, 0x03, 0x5A, 0xCC, 0x82, 0xC9, 0x03, - 0x5A, 0xCC, 0x87, 0xC9, 0x03, 0x5A, 0xCC, 0x8C, - 0xC9, 0x03, 0x5A, 0xCC, 0xA3, 0xB5, 0x03, 0x5A, - 0xCC, 0xB1, 0xB5, 0x03, 0x61, 0xCC, 0x80, 0xC9, - // Bytes 3280 - 32bf - 0x03, 0x61, 0xCC, 0x81, 0xC9, 0x03, 0x61, 0xCC, - 0x83, 0xC9, 0x03, 0x61, 0xCC, 0x84, 0xC9, 0x03, - 0x61, 0xCC, 0x89, 0xC9, 0x03, 0x61, 0xCC, 0x8C, - 0xC9, 0x03, 0x61, 0xCC, 0x8F, 0xC9, 0x03, 0x61, - 0xCC, 0x91, 0xC9, 0x03, 0x61, 0xCC, 0xA5, 0xB5, - 0x03, 0x61, 0xCC, 0xA8, 0xA5, 0x03, 0x62, 0xCC, - 0x87, 0xC9, 0x03, 0x62, 0xCC, 0xA3, 0xB5, 0x03, - 0x62, 0xCC, 0xB1, 0xB5, 0x03, 0x63, 0xCC, 0x81, - // Bytes 32c0 - 32ff - 0xC9, 0x03, 0x63, 0xCC, 0x82, 0xC9, 0x03, 0x63, - 0xCC, 0x87, 0xC9, 0x03, 0x63, 0xCC, 0x8C, 0xC9, - 0x03, 0x64, 0xCC, 0x87, 0xC9, 0x03, 0x64, 0xCC, - 0x8C, 0xC9, 0x03, 0x64, 0xCC, 0xA3, 0xB5, 0x03, - 0x64, 0xCC, 0xA7, 0xA5, 0x03, 0x64, 0xCC, 0xAD, - 0xB5, 0x03, 0x64, 0xCC, 0xB1, 0xB5, 0x03, 0x65, - 0xCC, 0x80, 0xC9, 0x03, 0x65, 0xCC, 0x81, 0xC9, - 0x03, 0x65, 0xCC, 0x83, 0xC9, 0x03, 0x65, 0xCC, - // Bytes 3300 - 333f - 0x86, 0xC9, 0x03, 0x65, 0xCC, 0x87, 0xC9, 0x03, - 0x65, 0xCC, 0x88, 0xC9, 0x03, 0x65, 0xCC, 0x89, - 0xC9, 0x03, 0x65, 0xCC, 0x8C, 0xC9, 0x03, 0x65, - 0xCC, 0x8F, 0xC9, 0x03, 0x65, 0xCC, 0x91, 0xC9, - 0x03, 0x65, 0xCC, 0xA8, 0xA5, 0x03, 0x65, 0xCC, - 0xAD, 0xB5, 0x03, 0x65, 0xCC, 0xB0, 0xB5, 0x03, - 0x66, 0xCC, 0x87, 0xC9, 0x03, 0x67, 0xCC, 0x81, - 0xC9, 0x03, 0x67, 0xCC, 0x82, 0xC9, 0x03, 0x67, - // Bytes 3340 - 337f - 0xCC, 0x84, 0xC9, 0x03, 0x67, 0xCC, 0x86, 0xC9, - 0x03, 0x67, 0xCC, 0x87, 0xC9, 0x03, 0x67, 0xCC, - 0x8C, 0xC9, 0x03, 0x67, 0xCC, 0xA7, 0xA5, 0x03, - 0x68, 0xCC, 0x82, 0xC9, 0x03, 0x68, 0xCC, 0x87, - 0xC9, 0x03, 0x68, 0xCC, 0x88, 0xC9, 0x03, 0x68, - 0xCC, 0x8C, 0xC9, 0x03, 0x68, 0xCC, 0xA3, 0xB5, - 0x03, 0x68, 0xCC, 0xA7, 0xA5, 0x03, 0x68, 0xCC, - 0xAE, 0xB5, 0x03, 0x68, 0xCC, 0xB1, 0xB5, 0x03, - // Bytes 3380 - 33bf - 0x69, 0xCC, 0x80, 0xC9, 0x03, 0x69, 0xCC, 0x81, - 0xC9, 0x03, 0x69, 0xCC, 0x82, 0xC9, 0x03, 0x69, - 0xCC, 0x83, 0xC9, 0x03, 0x69, 0xCC, 0x84, 0xC9, - 0x03, 0x69, 0xCC, 0x86, 0xC9, 0x03, 0x69, 0xCC, - 0x89, 0xC9, 0x03, 0x69, 0xCC, 0x8C, 0xC9, 0x03, - 0x69, 0xCC, 0x8F, 0xC9, 0x03, 0x69, 0xCC, 0x91, - 0xC9, 0x03, 0x69, 0xCC, 0xA3, 0xB5, 0x03, 0x69, - 0xCC, 0xA8, 0xA5, 0x03, 0x69, 0xCC, 0xB0, 0xB5, - // Bytes 33c0 - 33ff - 0x03, 0x6A, 0xCC, 0x82, 0xC9, 0x03, 0x6A, 0xCC, - 0x8C, 0xC9, 0x03, 0x6B, 0xCC, 0x81, 0xC9, 0x03, - 0x6B, 0xCC, 0x8C, 0xC9, 0x03, 0x6B, 0xCC, 0xA3, - 0xB5, 0x03, 0x6B, 0xCC, 0xA7, 0xA5, 0x03, 0x6B, - 0xCC, 0xB1, 0xB5, 0x03, 0x6C, 0xCC, 0x81, 0xC9, - 0x03, 0x6C, 0xCC, 0x8C, 0xC9, 0x03, 0x6C, 0xCC, - 0xA7, 0xA5, 0x03, 0x6C, 0xCC, 0xAD, 0xB5, 0x03, - 0x6C, 0xCC, 0xB1, 0xB5, 0x03, 0x6D, 0xCC, 0x81, - // Bytes 3400 - 343f - 0xC9, 0x03, 0x6D, 0xCC, 0x87, 0xC9, 0x03, 0x6D, - 0xCC, 0xA3, 0xB5, 0x03, 0x6E, 0xCC, 0x80, 0xC9, - 0x03, 0x6E, 0xCC, 0x81, 0xC9, 0x03, 0x6E, 0xCC, - 0x83, 0xC9, 0x03, 0x6E, 0xCC, 0x87, 0xC9, 0x03, - 0x6E, 0xCC, 0x8C, 0xC9, 0x03, 0x6E, 0xCC, 0xA3, - 0xB5, 0x03, 0x6E, 0xCC, 0xA7, 0xA5, 0x03, 0x6E, - 0xCC, 0xAD, 0xB5, 0x03, 0x6E, 0xCC, 0xB1, 0xB5, - 0x03, 0x6F, 0xCC, 0x80, 0xC9, 0x03, 0x6F, 0xCC, - // Bytes 3440 - 347f - 0x81, 0xC9, 0x03, 0x6F, 0xCC, 0x86, 0xC9, 0x03, - 0x6F, 0xCC, 0x89, 0xC9, 0x03, 0x6F, 0xCC, 0x8B, - 0xC9, 0x03, 0x6F, 0xCC, 0x8C, 0xC9, 0x03, 0x6F, - 0xCC, 0x8F, 0xC9, 0x03, 0x6F, 0xCC, 0x91, 0xC9, - 0x03, 0x70, 0xCC, 0x81, 0xC9, 0x03, 0x70, 0xCC, - 0x87, 0xC9, 0x03, 0x72, 0xCC, 0x81, 0xC9, 0x03, - 0x72, 0xCC, 0x87, 0xC9, 0x03, 0x72, 0xCC, 0x8C, - 0xC9, 0x03, 0x72, 0xCC, 0x8F, 0xC9, 0x03, 0x72, - // Bytes 3480 - 34bf - 0xCC, 0x91, 0xC9, 0x03, 0x72, 0xCC, 0xA7, 0xA5, - 0x03, 0x72, 0xCC, 0xB1, 0xB5, 0x03, 0x73, 0xCC, - 0x82, 0xC9, 0x03, 0x73, 0xCC, 0x87, 0xC9, 0x03, - 0x73, 0xCC, 0xA6, 0xB5, 0x03, 0x73, 0xCC, 0xA7, - 0xA5, 0x03, 0x74, 0xCC, 0x87, 0xC9, 0x03, 0x74, - 0xCC, 0x88, 0xC9, 0x03, 0x74, 0xCC, 0x8C, 0xC9, - 0x03, 0x74, 0xCC, 0xA3, 0xB5, 0x03, 0x74, 0xCC, - 0xA6, 0xB5, 0x03, 0x74, 0xCC, 0xA7, 0xA5, 0x03, - // Bytes 34c0 - 34ff - 0x74, 0xCC, 0xAD, 0xB5, 0x03, 0x74, 0xCC, 0xB1, - 0xB5, 0x03, 0x75, 0xCC, 0x80, 0xC9, 0x03, 0x75, - 0xCC, 0x81, 0xC9, 0x03, 0x75, 0xCC, 0x82, 0xC9, - 0x03, 0x75, 0xCC, 0x86, 0xC9, 0x03, 0x75, 0xCC, - 0x89, 0xC9, 0x03, 0x75, 0xCC, 0x8A, 0xC9, 0x03, - 0x75, 0xCC, 0x8B, 0xC9, 0x03, 0x75, 0xCC, 0x8C, - 0xC9, 0x03, 0x75, 0xCC, 0x8F, 0xC9, 0x03, 0x75, - 0xCC, 0x91, 0xC9, 0x03, 0x75, 0xCC, 0xA3, 0xB5, - // Bytes 3500 - 353f - 0x03, 0x75, 0xCC, 0xA4, 0xB5, 0x03, 0x75, 0xCC, - 0xA8, 0xA5, 0x03, 0x75, 0xCC, 0xAD, 0xB5, 0x03, - 0x75, 0xCC, 0xB0, 0xB5, 0x03, 0x76, 0xCC, 0x83, - 0xC9, 0x03, 0x76, 0xCC, 0xA3, 0xB5, 0x03, 0x77, - 0xCC, 0x80, 0xC9, 0x03, 0x77, 0xCC, 0x81, 0xC9, - 0x03, 0x77, 0xCC, 0x82, 0xC9, 0x03, 0x77, 0xCC, - 0x87, 0xC9, 0x03, 0x77, 0xCC, 0x88, 0xC9, 0x03, - 0x77, 0xCC, 0x8A, 0xC9, 0x03, 0x77, 0xCC, 0xA3, - // Bytes 3540 - 357f - 0xB5, 0x03, 0x78, 0xCC, 0x87, 0xC9, 0x03, 0x78, - 0xCC, 0x88, 0xC9, 0x03, 0x79, 0xCC, 0x80, 0xC9, - 0x03, 0x79, 0xCC, 0x81, 0xC9, 0x03, 0x79, 0xCC, - 0x82, 0xC9, 0x03, 0x79, 0xCC, 0x83, 0xC9, 0x03, - 0x79, 0xCC, 0x84, 0xC9, 0x03, 0x79, 0xCC, 0x87, - 0xC9, 0x03, 0x79, 0xCC, 0x88, 0xC9, 0x03, 0x79, - 0xCC, 0x89, 0xC9, 0x03, 0x79, 0xCC, 0x8A, 0xC9, - 0x03, 0x79, 0xCC, 0xA3, 0xB5, 0x03, 0x7A, 0xCC, - // Bytes 3580 - 35bf - 0x81, 0xC9, 0x03, 0x7A, 0xCC, 0x82, 0xC9, 0x03, - 0x7A, 0xCC, 0x87, 0xC9, 0x03, 0x7A, 0xCC, 0x8C, - 0xC9, 0x03, 0x7A, 0xCC, 0xA3, 0xB5, 0x03, 0x7A, - 0xCC, 0xB1, 0xB5, 0x04, 0xC2, 0xA8, 0xCC, 0x80, - 0xCA, 0x04, 0xC2, 0xA8, 0xCC, 0x81, 0xCA, 0x04, - 0xC2, 0xA8, 0xCD, 0x82, 0xCA, 0x04, 0xC3, 0x86, - 0xCC, 0x81, 0xC9, 0x04, 0xC3, 0x86, 0xCC, 0x84, - 0xC9, 0x04, 0xC3, 0x98, 0xCC, 0x81, 0xC9, 0x04, - // Bytes 35c0 - 35ff - 0xC3, 0xA6, 0xCC, 0x81, 0xC9, 0x04, 0xC3, 0xA6, - 0xCC, 0x84, 0xC9, 0x04, 0xC3, 0xB8, 0xCC, 0x81, - 0xC9, 0x04, 0xC5, 0xBF, 0xCC, 0x87, 0xC9, 0x04, - 0xC6, 0xB7, 0xCC, 0x8C, 0xC9, 0x04, 0xCA, 0x92, - 0xCC, 0x8C, 0xC9, 0x04, 0xCE, 0x91, 0xCC, 0x80, - 0xC9, 0x04, 0xCE, 0x91, 0xCC, 0x81, 0xC9, 0x04, - 0xCE, 0x91, 0xCC, 0x84, 0xC9, 0x04, 0xCE, 0x91, - 0xCC, 0x86, 0xC9, 0x04, 0xCE, 0x91, 0xCD, 0x85, - // Bytes 3600 - 363f - 0xD9, 0x04, 0xCE, 0x95, 0xCC, 0x80, 0xC9, 0x04, - 0xCE, 0x95, 0xCC, 0x81, 0xC9, 0x04, 0xCE, 0x97, - 0xCC, 0x80, 0xC9, 0x04, 0xCE, 0x97, 0xCC, 0x81, - 0xC9, 0x04, 0xCE, 0x97, 0xCD, 0x85, 0xD9, 0x04, - 0xCE, 0x99, 0xCC, 0x80, 0xC9, 0x04, 0xCE, 0x99, - 0xCC, 0x81, 0xC9, 0x04, 0xCE, 0x99, 0xCC, 0x84, - 0xC9, 0x04, 0xCE, 0x99, 0xCC, 0x86, 0xC9, 0x04, - 0xCE, 0x99, 0xCC, 0x88, 0xC9, 0x04, 0xCE, 0x9F, - // Bytes 3640 - 367f - 0xCC, 0x80, 0xC9, 0x04, 0xCE, 0x9F, 0xCC, 0x81, - 0xC9, 0x04, 0xCE, 0xA1, 0xCC, 0x94, 0xC9, 0x04, - 0xCE, 0xA5, 0xCC, 0x80, 0xC9, 0x04, 0xCE, 0xA5, - 0xCC, 0x81, 0xC9, 0x04, 0xCE, 0xA5, 0xCC, 0x84, - 0xC9, 0x04, 0xCE, 0xA5, 0xCC, 0x86, 0xC9, 0x04, - 0xCE, 0xA5, 0xCC, 0x88, 0xC9, 0x04, 0xCE, 0xA9, - 0xCC, 0x80, 0xC9, 0x04, 0xCE, 0xA9, 0xCC, 0x81, - 0xC9, 0x04, 0xCE, 0xA9, 0xCD, 0x85, 0xD9, 0x04, - // Bytes 3680 - 36bf - 0xCE, 0xB1, 0xCC, 0x84, 0xC9, 0x04, 0xCE, 0xB1, - 0xCC, 0x86, 0xC9, 0x04, 0xCE, 0xB1, 0xCD, 0x85, - 0xD9, 0x04, 0xCE, 0xB5, 0xCC, 0x80, 0xC9, 0x04, - 0xCE, 0xB5, 0xCC, 0x81, 0xC9, 0x04, 0xCE, 0xB7, - 0xCD, 0x85, 0xD9, 0x04, 0xCE, 0xB9, 0xCC, 0x80, - 0xC9, 0x04, 0xCE, 0xB9, 0xCC, 0x81, 0xC9, 0x04, - 0xCE, 0xB9, 0xCC, 0x84, 0xC9, 0x04, 0xCE, 0xB9, - 0xCC, 0x86, 0xC9, 0x04, 0xCE, 0xB9, 0xCD, 0x82, - // Bytes 36c0 - 36ff - 0xC9, 0x04, 0xCE, 0xBF, 0xCC, 0x80, 0xC9, 0x04, - 0xCE, 0xBF, 0xCC, 0x81, 0xC9, 0x04, 0xCF, 0x81, - 0xCC, 0x93, 0xC9, 0x04, 0xCF, 0x81, 0xCC, 0x94, - 0xC9, 0x04, 0xCF, 0x85, 0xCC, 0x80, 0xC9, 0x04, - 0xCF, 0x85, 0xCC, 0x81, 0xC9, 0x04, 0xCF, 0x85, - 0xCC, 0x84, 0xC9, 0x04, 0xCF, 0x85, 0xCC, 0x86, - 0xC9, 0x04, 0xCF, 0x85, 0xCD, 0x82, 0xC9, 0x04, - 0xCF, 0x89, 0xCD, 0x85, 0xD9, 0x04, 0xCF, 0x92, - // Bytes 3700 - 373f - 0xCC, 0x81, 0xC9, 0x04, 0xCF, 0x92, 0xCC, 0x88, - 0xC9, 0x04, 0xD0, 0x86, 0xCC, 0x88, 0xC9, 0x04, - 0xD0, 0x90, 0xCC, 0x86, 0xC9, 0x04, 0xD0, 0x90, - 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0x93, 0xCC, 0x81, - 0xC9, 0x04, 0xD0, 0x95, 0xCC, 0x80, 0xC9, 0x04, - 0xD0, 0x95, 0xCC, 0x86, 0xC9, 0x04, 0xD0, 0x95, - 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0x96, 0xCC, 0x86, - 0xC9, 0x04, 0xD0, 0x96, 0xCC, 0x88, 0xC9, 0x04, - // Bytes 3740 - 377f - 0xD0, 0x97, 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0x98, - 0xCC, 0x80, 0xC9, 0x04, 0xD0, 0x98, 0xCC, 0x84, - 0xC9, 0x04, 0xD0, 0x98, 0xCC, 0x86, 0xC9, 0x04, - 0xD0, 0x98, 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0x9A, - 0xCC, 0x81, 0xC9, 0x04, 0xD0, 0x9E, 0xCC, 0x88, - 0xC9, 0x04, 0xD0, 0xA3, 0xCC, 0x84, 0xC9, 0x04, - 0xD0, 0xA3, 0xCC, 0x86, 0xC9, 0x04, 0xD0, 0xA3, - 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0xA3, 0xCC, 0x8B, - // Bytes 3780 - 37bf - 0xC9, 0x04, 0xD0, 0xA7, 0xCC, 0x88, 0xC9, 0x04, - 0xD0, 0xAB, 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0xAD, - 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0xB0, 0xCC, 0x86, - 0xC9, 0x04, 0xD0, 0xB0, 0xCC, 0x88, 0xC9, 0x04, - 0xD0, 0xB3, 0xCC, 0x81, 0xC9, 0x04, 0xD0, 0xB5, - 0xCC, 0x80, 0xC9, 0x04, 0xD0, 0xB5, 0xCC, 0x86, - 0xC9, 0x04, 0xD0, 0xB5, 0xCC, 0x88, 0xC9, 0x04, - 0xD0, 0xB6, 0xCC, 0x86, 0xC9, 0x04, 0xD0, 0xB6, - // Bytes 37c0 - 37ff - 0xCC, 0x88, 0xC9, 0x04, 0xD0, 0xB7, 0xCC, 0x88, - 0xC9, 0x04, 0xD0, 0xB8, 0xCC, 0x80, 0xC9, 0x04, - 0xD0, 0xB8, 0xCC, 0x84, 0xC9, 0x04, 0xD0, 0xB8, - 0xCC, 0x86, 0xC9, 0x04, 0xD0, 0xB8, 0xCC, 0x88, - 0xC9, 0x04, 0xD0, 0xBA, 0xCC, 0x81, 0xC9, 0x04, - 0xD0, 0xBE, 0xCC, 0x88, 0xC9, 0x04, 0xD1, 0x83, - 0xCC, 0x84, 0xC9, 0x04, 0xD1, 0x83, 0xCC, 0x86, - 0xC9, 0x04, 0xD1, 0x83, 0xCC, 0x88, 0xC9, 0x04, - // Bytes 3800 - 383f - 0xD1, 0x83, 0xCC, 0x8B, 0xC9, 0x04, 0xD1, 0x87, - 0xCC, 0x88, 0xC9, 0x04, 0xD1, 0x8B, 0xCC, 0x88, - 0xC9, 0x04, 0xD1, 0x8D, 0xCC, 0x88, 0xC9, 0x04, - 0xD1, 0x96, 0xCC, 0x88, 0xC9, 0x04, 0xD1, 0xB4, - 0xCC, 0x8F, 0xC9, 0x04, 0xD1, 0xB5, 0xCC, 0x8F, - 0xC9, 0x04, 0xD3, 0x98, 0xCC, 0x88, 0xC9, 0x04, - 0xD3, 0x99, 0xCC, 0x88, 0xC9, 0x04, 0xD3, 0xA8, - 0xCC, 0x88, 0xC9, 0x04, 0xD3, 0xA9, 0xCC, 0x88, - // Bytes 3840 - 387f - 0xC9, 0x04, 0xD8, 0xA7, 0xD9, 0x93, 0xC9, 0x04, - 0xD8, 0xA7, 0xD9, 0x94, 0xC9, 0x04, 0xD8, 0xA7, - 0xD9, 0x95, 0xB5, 0x04, 0xD9, 0x88, 0xD9, 0x94, - 0xC9, 0x04, 0xD9, 0x8A, 0xD9, 0x94, 0xC9, 0x04, - 0xDB, 0x81, 0xD9, 0x94, 0xC9, 0x04, 0xDB, 0x92, - 0xD9, 0x94, 0xC9, 0x04, 0xDB, 0x95, 0xD9, 0x94, - 0xC9, 0x05, 0x41, 0xCC, 0x82, 0xCC, 0x80, 0xCA, - 0x05, 0x41, 0xCC, 0x82, 0xCC, 0x81, 0xCA, 0x05, - // Bytes 3880 - 38bf - 0x41, 0xCC, 0x82, 0xCC, 0x83, 0xCA, 0x05, 0x41, - 0xCC, 0x82, 0xCC, 0x89, 0xCA, 0x05, 0x41, 0xCC, - 0x86, 0xCC, 0x80, 0xCA, 0x05, 0x41, 0xCC, 0x86, - 0xCC, 0x81, 0xCA, 0x05, 0x41, 0xCC, 0x86, 0xCC, - 0x83, 0xCA, 0x05, 0x41, 0xCC, 0x86, 0xCC, 0x89, - 0xCA, 0x05, 0x41, 0xCC, 0x87, 0xCC, 0x84, 0xCA, - 0x05, 0x41, 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, - 0x41, 0xCC, 0x8A, 0xCC, 0x81, 0xCA, 0x05, 0x41, - // Bytes 38c0 - 38ff - 0xCC, 0xA3, 0xCC, 0x82, 0xCA, 0x05, 0x41, 0xCC, - 0xA3, 0xCC, 0x86, 0xCA, 0x05, 0x43, 0xCC, 0xA7, - 0xCC, 0x81, 0xCA, 0x05, 0x45, 0xCC, 0x82, 0xCC, - 0x80, 0xCA, 0x05, 0x45, 0xCC, 0x82, 0xCC, 0x81, - 0xCA, 0x05, 0x45, 0xCC, 0x82, 0xCC, 0x83, 0xCA, - 0x05, 0x45, 0xCC, 0x82, 0xCC, 0x89, 0xCA, 0x05, - 0x45, 0xCC, 0x84, 0xCC, 0x80, 0xCA, 0x05, 0x45, - 0xCC, 0x84, 0xCC, 0x81, 0xCA, 0x05, 0x45, 0xCC, - // Bytes 3900 - 393f - 0xA3, 0xCC, 0x82, 0xCA, 0x05, 0x45, 0xCC, 0xA7, - 0xCC, 0x86, 0xCA, 0x05, 0x49, 0xCC, 0x88, 0xCC, - 0x81, 0xCA, 0x05, 0x4C, 0xCC, 0xA3, 0xCC, 0x84, - 0xCA, 0x05, 0x4F, 0xCC, 0x82, 0xCC, 0x80, 0xCA, - 0x05, 0x4F, 0xCC, 0x82, 0xCC, 0x81, 0xCA, 0x05, - 0x4F, 0xCC, 0x82, 0xCC, 0x83, 0xCA, 0x05, 0x4F, - 0xCC, 0x82, 0xCC, 0x89, 0xCA, 0x05, 0x4F, 0xCC, - 0x83, 0xCC, 0x81, 0xCA, 0x05, 0x4F, 0xCC, 0x83, - // Bytes 3940 - 397f - 0xCC, 0x84, 0xCA, 0x05, 0x4F, 0xCC, 0x83, 0xCC, - 0x88, 0xCA, 0x05, 0x4F, 0xCC, 0x84, 0xCC, 0x80, - 0xCA, 0x05, 0x4F, 0xCC, 0x84, 0xCC, 0x81, 0xCA, - 0x05, 0x4F, 0xCC, 0x87, 0xCC, 0x84, 0xCA, 0x05, - 0x4F, 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, 0x4F, - 0xCC, 0x9B, 0xCC, 0x80, 0xCA, 0x05, 0x4F, 0xCC, - 0x9B, 0xCC, 0x81, 0xCA, 0x05, 0x4F, 0xCC, 0x9B, - 0xCC, 0x83, 0xCA, 0x05, 0x4F, 0xCC, 0x9B, 0xCC, - // Bytes 3980 - 39bf - 0x89, 0xCA, 0x05, 0x4F, 0xCC, 0x9B, 0xCC, 0xA3, - 0xB6, 0x05, 0x4F, 0xCC, 0xA3, 0xCC, 0x82, 0xCA, - 0x05, 0x4F, 0xCC, 0xA8, 0xCC, 0x84, 0xCA, 0x05, - 0x52, 0xCC, 0xA3, 0xCC, 0x84, 0xCA, 0x05, 0x53, - 0xCC, 0x81, 0xCC, 0x87, 0xCA, 0x05, 0x53, 0xCC, - 0x8C, 0xCC, 0x87, 0xCA, 0x05, 0x53, 0xCC, 0xA3, - 0xCC, 0x87, 0xCA, 0x05, 0x55, 0xCC, 0x83, 0xCC, - 0x81, 0xCA, 0x05, 0x55, 0xCC, 0x84, 0xCC, 0x88, - // Bytes 39c0 - 39ff - 0xCA, 0x05, 0x55, 0xCC, 0x88, 0xCC, 0x80, 0xCA, - 0x05, 0x55, 0xCC, 0x88, 0xCC, 0x81, 0xCA, 0x05, - 0x55, 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, 0x55, - 0xCC, 0x88, 0xCC, 0x8C, 0xCA, 0x05, 0x55, 0xCC, - 0x9B, 0xCC, 0x80, 0xCA, 0x05, 0x55, 0xCC, 0x9B, - 0xCC, 0x81, 0xCA, 0x05, 0x55, 0xCC, 0x9B, 0xCC, - 0x83, 0xCA, 0x05, 0x55, 0xCC, 0x9B, 0xCC, 0x89, - 0xCA, 0x05, 0x55, 0xCC, 0x9B, 0xCC, 0xA3, 0xB6, - // Bytes 3a00 - 3a3f - 0x05, 0x61, 0xCC, 0x82, 0xCC, 0x80, 0xCA, 0x05, - 0x61, 0xCC, 0x82, 0xCC, 0x81, 0xCA, 0x05, 0x61, - 0xCC, 0x82, 0xCC, 0x83, 0xCA, 0x05, 0x61, 0xCC, - 0x82, 0xCC, 0x89, 0xCA, 0x05, 0x61, 0xCC, 0x86, - 0xCC, 0x80, 0xCA, 0x05, 0x61, 0xCC, 0x86, 0xCC, - 0x81, 0xCA, 0x05, 0x61, 0xCC, 0x86, 0xCC, 0x83, - 0xCA, 0x05, 0x61, 0xCC, 0x86, 0xCC, 0x89, 0xCA, - 0x05, 0x61, 0xCC, 0x87, 0xCC, 0x84, 0xCA, 0x05, - // Bytes 3a40 - 3a7f - 0x61, 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, 0x61, - 0xCC, 0x8A, 0xCC, 0x81, 0xCA, 0x05, 0x61, 0xCC, - 0xA3, 0xCC, 0x82, 0xCA, 0x05, 0x61, 0xCC, 0xA3, - 0xCC, 0x86, 0xCA, 0x05, 0x63, 0xCC, 0xA7, 0xCC, - 0x81, 0xCA, 0x05, 0x65, 0xCC, 0x82, 0xCC, 0x80, - 0xCA, 0x05, 0x65, 0xCC, 0x82, 0xCC, 0x81, 0xCA, - 0x05, 0x65, 0xCC, 0x82, 0xCC, 0x83, 0xCA, 0x05, - 0x65, 0xCC, 0x82, 0xCC, 0x89, 0xCA, 0x05, 0x65, - // Bytes 3a80 - 3abf - 0xCC, 0x84, 0xCC, 0x80, 0xCA, 0x05, 0x65, 0xCC, - 0x84, 0xCC, 0x81, 0xCA, 0x05, 0x65, 0xCC, 0xA3, - 0xCC, 0x82, 0xCA, 0x05, 0x65, 0xCC, 0xA7, 0xCC, - 0x86, 0xCA, 0x05, 0x69, 0xCC, 0x88, 0xCC, 0x81, - 0xCA, 0x05, 0x6C, 0xCC, 0xA3, 0xCC, 0x84, 0xCA, - 0x05, 0x6F, 0xCC, 0x82, 0xCC, 0x80, 0xCA, 0x05, - 0x6F, 0xCC, 0x82, 0xCC, 0x81, 0xCA, 0x05, 0x6F, - 0xCC, 0x82, 0xCC, 0x83, 0xCA, 0x05, 0x6F, 0xCC, - // Bytes 3ac0 - 3aff - 0x82, 0xCC, 0x89, 0xCA, 0x05, 0x6F, 0xCC, 0x83, - 0xCC, 0x81, 0xCA, 0x05, 0x6F, 0xCC, 0x83, 0xCC, - 0x84, 0xCA, 0x05, 0x6F, 0xCC, 0x83, 0xCC, 0x88, - 0xCA, 0x05, 0x6F, 0xCC, 0x84, 0xCC, 0x80, 0xCA, - 0x05, 0x6F, 0xCC, 0x84, 0xCC, 0x81, 0xCA, 0x05, - 0x6F, 0xCC, 0x87, 0xCC, 0x84, 0xCA, 0x05, 0x6F, - 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, 0x6F, 0xCC, - 0x9B, 0xCC, 0x80, 0xCA, 0x05, 0x6F, 0xCC, 0x9B, - // Bytes 3b00 - 3b3f - 0xCC, 0x81, 0xCA, 0x05, 0x6F, 0xCC, 0x9B, 0xCC, - 0x83, 0xCA, 0x05, 0x6F, 0xCC, 0x9B, 0xCC, 0x89, - 0xCA, 0x05, 0x6F, 0xCC, 0x9B, 0xCC, 0xA3, 0xB6, - 0x05, 0x6F, 0xCC, 0xA3, 0xCC, 0x82, 0xCA, 0x05, - 0x6F, 0xCC, 0xA8, 0xCC, 0x84, 0xCA, 0x05, 0x72, - 0xCC, 0xA3, 0xCC, 0x84, 0xCA, 0x05, 0x73, 0xCC, - 0x81, 0xCC, 0x87, 0xCA, 0x05, 0x73, 0xCC, 0x8C, - 0xCC, 0x87, 0xCA, 0x05, 0x73, 0xCC, 0xA3, 0xCC, - // Bytes 3b40 - 3b7f - 0x87, 0xCA, 0x05, 0x75, 0xCC, 0x83, 0xCC, 0x81, - 0xCA, 0x05, 0x75, 0xCC, 0x84, 0xCC, 0x88, 0xCA, - 0x05, 0x75, 0xCC, 0x88, 0xCC, 0x80, 0xCA, 0x05, - 0x75, 0xCC, 0x88, 0xCC, 0x81, 0xCA, 0x05, 0x75, - 0xCC, 0x88, 0xCC, 0x84, 0xCA, 0x05, 0x75, 0xCC, - 0x88, 0xCC, 0x8C, 0xCA, 0x05, 0x75, 0xCC, 0x9B, - 0xCC, 0x80, 0xCA, 0x05, 0x75, 0xCC, 0x9B, 0xCC, - 0x81, 0xCA, 0x05, 0x75, 0xCC, 0x9B, 0xCC, 0x83, - // Bytes 3b80 - 3bbf - 0xCA, 0x05, 0x75, 0xCC, 0x9B, 0xCC, 0x89, 0xCA, - 0x05, 0x75, 0xCC, 0x9B, 0xCC, 0xA3, 0xB6, 0x05, - 0xE1, 0xBE, 0xBF, 0xCC, 0x80, 0xCA, 0x05, 0xE1, - 0xBE, 0xBF, 0xCC, 0x81, 0xCA, 0x05, 0xE1, 0xBE, - 0xBF, 0xCD, 0x82, 0xCA, 0x05, 0xE1, 0xBF, 0xBE, - 0xCC, 0x80, 0xCA, 0x05, 0xE1, 0xBF, 0xBE, 0xCC, - 0x81, 0xCA, 0x05, 0xE1, 0xBF, 0xBE, 0xCD, 0x82, - 0xCA, 0x05, 0xE2, 0x86, 0x90, 0xCC, 0xB8, 0x05, - // Bytes 3bc0 - 3bff - 0x05, 0xE2, 0x86, 0x92, 0xCC, 0xB8, 0x05, 0x05, - 0xE2, 0x86, 0x94, 0xCC, 0xB8, 0x05, 0x05, 0xE2, - 0x87, 0x90, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x87, - 0x92, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x87, 0x94, - 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x88, 0x83, 0xCC, - 0xB8, 0x05, 0x05, 0xE2, 0x88, 0x88, 0xCC, 0xB8, - 0x05, 0x05, 0xE2, 0x88, 0x8B, 0xCC, 0xB8, 0x05, - 0x05, 0xE2, 0x88, 0xA3, 0xCC, 0xB8, 0x05, 0x05, - // Bytes 3c00 - 3c3f - 0xE2, 0x88, 0xA5, 0xCC, 0xB8, 0x05, 0x05, 0xE2, - 0x88, 0xBC, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, - 0x83, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, 0x85, - 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, 0x88, 0xCC, - 0xB8, 0x05, 0x05, 0xE2, 0x89, 0x8D, 0xCC, 0xB8, - 0x05, 0x05, 0xE2, 0x89, 0xA1, 0xCC, 0xB8, 0x05, - 0x05, 0xE2, 0x89, 0xA4, 0xCC, 0xB8, 0x05, 0x05, - 0xE2, 0x89, 0xA5, 0xCC, 0xB8, 0x05, 0x05, 0xE2, - // Bytes 3c40 - 3c7f - 0x89, 0xB2, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, - 0xB3, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, 0xB6, - 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x89, 0xB7, 0xCC, - 0xB8, 0x05, 0x05, 0xE2, 0x89, 0xBA, 0xCC, 0xB8, - 0x05, 0x05, 0xE2, 0x89, 0xBB, 0xCC, 0xB8, 0x05, - 0x05, 0xE2, 0x89, 0xBC, 0xCC, 0xB8, 0x05, 0x05, - 0xE2, 0x89, 0xBD, 0xCC, 0xB8, 0x05, 0x05, 0xE2, - 0x8A, 0x82, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, - // Bytes 3c80 - 3cbf - 0x83, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0x86, - 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0x87, 0xCC, - 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0x91, 0xCC, 0xB8, - 0x05, 0x05, 0xE2, 0x8A, 0x92, 0xCC, 0xB8, 0x05, - 0x05, 0xE2, 0x8A, 0xA2, 0xCC, 0xB8, 0x05, 0x05, - 0xE2, 0x8A, 0xA8, 0xCC, 0xB8, 0x05, 0x05, 0xE2, - 0x8A, 0xA9, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, - 0xAB, 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0xB2, - // Bytes 3cc0 - 3cff - 0xCC, 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0xB3, 0xCC, - 0xB8, 0x05, 0x05, 0xE2, 0x8A, 0xB4, 0xCC, 0xB8, - 0x05, 0x05, 0xE2, 0x8A, 0xB5, 0xCC, 0xB8, 0x05, - 0x06, 0xCE, 0x91, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0x91, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0x95, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0x95, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0x95, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - // Bytes 3d00 - 3d3f - 0x06, 0xCE, 0x95, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0x97, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0x97, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0x99, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0x99, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0x99, 0xCC, 0x93, 0xCD, 0x82, 0xCA, - 0x06, 0xCE, 0x99, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0x99, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - // Bytes 3d40 - 3d7f - 0x06, 0xCE, 0x99, 0xCC, 0x94, 0xCD, 0x82, 0xCA, - 0x06, 0xCE, 0x9F, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0x9F, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0x9F, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0x9F, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xA5, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xA5, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xA5, 0xCC, 0x94, 0xCD, 0x82, 0xCA, - // Bytes 3d80 - 3dbf - 0x06, 0xCE, 0xA9, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xA9, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB1, 0xCC, 0x80, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB1, 0xCC, 0x81, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB1, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB1, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB1, 0xCD, 0x82, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB5, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - // Bytes 3dc0 - 3dff - 0x06, 0xCE, 0xB5, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xB5, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xB5, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xB7, 0xCC, 0x80, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB7, 0xCC, 0x81, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB7, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB7, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCE, 0xB7, 0xCD, 0x82, 0xCD, 0x85, 0xDA, - // Bytes 3e00 - 3e3f - 0x06, 0xCE, 0xB9, 0xCC, 0x88, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x88, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x88, 0xCD, 0x82, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x93, 0xCD, 0x82, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xB9, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - // Bytes 3e40 - 3e7f - 0x06, 0xCE, 0xB9, 0xCC, 0x94, 0xCD, 0x82, 0xCA, - 0x06, 0xCE, 0xBF, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xBF, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCE, 0xBF, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCE, 0xBF, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x88, 0xCC, 0x80, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x88, 0xCC, 0x81, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x88, 0xCD, 0x82, 0xCA, - // Bytes 3e80 - 3ebf - 0x06, 0xCF, 0x85, 0xCC, 0x93, 0xCC, 0x80, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x93, 0xCC, 0x81, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x93, 0xCD, 0x82, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x94, 0xCC, 0x80, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x94, 0xCC, 0x81, 0xCA, - 0x06, 0xCF, 0x85, 0xCC, 0x94, 0xCD, 0x82, 0xCA, - 0x06, 0xCF, 0x89, 0xCC, 0x80, 0xCD, 0x85, 0xDA, - 0x06, 0xCF, 0x89, 0xCC, 0x81, 0xCD, 0x85, 0xDA, - // Bytes 3ec0 - 3eff - 0x06, 0xCF, 0x89, 0xCC, 0x93, 0xCD, 0x85, 0xDA, - 0x06, 0xCF, 0x89, 0xCC, 0x94, 0xCD, 0x85, 0xDA, - 0x06, 0xCF, 0x89, 0xCD, 0x82, 0xCD, 0x85, 0xDA, - 0x06, 0xE0, 0xA4, 0xA8, 0xE0, 0xA4, 0xBC, 0x09, - 0x06, 0xE0, 0xA4, 0xB0, 0xE0, 0xA4, 0xBC, 0x09, - 0x06, 0xE0, 0xA4, 0xB3, 0xE0, 0xA4, 0xBC, 0x09, - 0x06, 0xE0, 0xB1, 0x86, 0xE0, 0xB1, 0x96, 0x85, - 0x06, 0xE0, 0xB7, 0x99, 0xE0, 0xB7, 0x8A, 0x11, - // Bytes 3f00 - 3f3f - 0x06, 0xE3, 0x81, 0x86, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x8B, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x8D, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x8F, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x91, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x93, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x95, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x97, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 3f40 - 3f7f - 0x06, 0xE3, 0x81, 0x99, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x9B, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x9D, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0x9F, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xA1, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xA4, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xA6, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xA8, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 3f80 - 3fbf - 0x06, 0xE3, 0x81, 0xAF, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xAF, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x81, 0xB2, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xB2, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x81, 0xB5, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xB5, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x81, 0xB8, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xB8, 0xE3, 0x82, 0x9A, 0x0D, - // Bytes 3fc0 - 3fff - 0x06, 0xE3, 0x81, 0xBB, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x81, 0xBB, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x82, 0x9D, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xA6, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xAB, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xAD, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xAF, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xB1, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 4000 - 403f - 0x06, 0xE3, 0x82, 0xB3, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xB5, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xB7, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xB9, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xBB, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xBD, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x82, 0xBF, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x81, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 4040 - 407f - 0x06, 0xE3, 0x83, 0x84, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x86, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x88, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x8F, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x8F, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x83, 0x92, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x92, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x83, 0x95, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 4080 - 40bf - 0x06, 0xE3, 0x83, 0x95, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x83, 0x98, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x98, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x83, 0x9B, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0x9B, 0xE3, 0x82, 0x9A, 0x0D, - 0x06, 0xE3, 0x83, 0xAF, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0xB0, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0xB1, 0xE3, 0x82, 0x99, 0x0D, - // Bytes 40c0 - 40ff - 0x06, 0xE3, 0x83, 0xB2, 0xE3, 0x82, 0x99, 0x0D, - 0x06, 0xE3, 0x83, 0xBD, 0xE3, 0x82, 0x99, 0x0D, - 0x08, 0xCE, 0x91, 0xCC, 0x93, 0xCC, 0x80, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0x91, 0xCC, 0x93, 0xCC, - 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0x91, 0xCC, - 0x93, 0xCD, 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0x91, 0xCC, 0x94, 0xCC, 0x80, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0x91, 0xCC, 0x94, 0xCC, 0x81, 0xCD, - // Bytes 4100 - 413f - 0x85, 0xDB, 0x08, 0xCE, 0x91, 0xCC, 0x94, 0xCD, - 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0x97, 0xCC, - 0x93, 0xCC, 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0x97, 0xCC, 0x93, 0xCC, 0x81, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0x97, 0xCC, 0x93, 0xCD, 0x82, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0x97, 0xCC, 0x94, 0xCC, - 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0x97, 0xCC, - 0x94, 0xCC, 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - // Bytes 4140 - 417f - 0x97, 0xCC, 0x94, 0xCD, 0x82, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0xA9, 0xCC, 0x93, 0xCC, 0x80, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0xA9, 0xCC, 0x93, 0xCC, - 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0xA9, 0xCC, - 0x93, 0xCD, 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0xA9, 0xCC, 0x94, 0xCC, 0x80, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0xA9, 0xCC, 0x94, 0xCC, 0x81, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0xA9, 0xCC, 0x94, 0xCD, - // Bytes 4180 - 41bf - 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0xB1, 0xCC, - 0x93, 0xCC, 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0xB1, 0xCC, 0x93, 0xCC, 0x81, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0xB1, 0xCC, 0x93, 0xCD, 0x82, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0xB1, 0xCC, 0x94, 0xCC, - 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0xB1, 0xCC, - 0x94, 0xCC, 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0xB1, 0xCC, 0x94, 0xCD, 0x82, 0xCD, 0x85, 0xDB, - // Bytes 41c0 - 41ff - 0x08, 0xCE, 0xB7, 0xCC, 0x93, 0xCC, 0x80, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0xB7, 0xCC, 0x93, 0xCC, - 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCE, 0xB7, 0xCC, - 0x93, 0xCD, 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCE, - 0xB7, 0xCC, 0x94, 0xCC, 0x80, 0xCD, 0x85, 0xDB, - 0x08, 0xCE, 0xB7, 0xCC, 0x94, 0xCC, 0x81, 0xCD, - 0x85, 0xDB, 0x08, 0xCE, 0xB7, 0xCC, 0x94, 0xCD, - 0x82, 0xCD, 0x85, 0xDB, 0x08, 0xCF, 0x89, 0xCC, - // Bytes 4200 - 423f - 0x93, 0xCC, 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCF, - 0x89, 0xCC, 0x93, 0xCC, 0x81, 0xCD, 0x85, 0xDB, - 0x08, 0xCF, 0x89, 0xCC, 0x93, 0xCD, 0x82, 0xCD, - 0x85, 0xDB, 0x08, 0xCF, 0x89, 0xCC, 0x94, 0xCC, - 0x80, 0xCD, 0x85, 0xDB, 0x08, 0xCF, 0x89, 0xCC, - 0x94, 0xCC, 0x81, 0xCD, 0x85, 0xDB, 0x08, 0xCF, - 0x89, 0xCC, 0x94, 0xCD, 0x82, 0xCD, 0x85, 0xDB, - 0x08, 0xF0, 0x91, 0x82, 0x99, 0xF0, 0x91, 0x82, - // Bytes 4240 - 427f - 0xBA, 0x09, 0x08, 0xF0, 0x91, 0x82, 0x9B, 0xF0, - 0x91, 0x82, 0xBA, 0x09, 0x08, 0xF0, 0x91, 0x82, - 0xA5, 0xF0, 0x91, 0x82, 0xBA, 0x09, 0x42, 0xC2, - 0xB4, 0x01, 0x43, 0x20, 0xCC, 0x81, 0xC9, 0x43, - 0x20, 0xCC, 0x83, 0xC9, 0x43, 0x20, 0xCC, 0x84, - 0xC9, 0x43, 0x20, 0xCC, 0x85, 0xC9, 0x43, 0x20, - 0xCC, 0x86, 0xC9, 0x43, 0x20, 0xCC, 0x87, 0xC9, - 0x43, 0x20, 0xCC, 0x88, 0xC9, 0x43, 0x20, 0xCC, - // Bytes 4280 - 42bf - 0x8A, 0xC9, 0x43, 0x20, 0xCC, 0x8B, 0xC9, 0x43, - 0x20, 0xCC, 0x93, 0xC9, 0x43, 0x20, 0xCC, 0x94, - 0xC9, 0x43, 0x20, 0xCC, 0xA7, 0xA5, 0x43, 0x20, - 0xCC, 0xA8, 0xA5, 0x43, 0x20, 0xCC, 0xB3, 0xB5, - 0x43, 0x20, 0xCD, 0x82, 0xC9, 0x43, 0x20, 0xCD, - 0x85, 0xD9, 0x43, 0x20, 0xD9, 0x8B, 0x59, 0x43, - 0x20, 0xD9, 0x8C, 0x5D, 0x43, 0x20, 0xD9, 0x8D, - 0x61, 0x43, 0x20, 0xD9, 0x8E, 0x65, 0x43, 0x20, - // Bytes 42c0 - 42ff - 0xD9, 0x8F, 0x69, 0x43, 0x20, 0xD9, 0x90, 0x6D, - 0x43, 0x20, 0xD9, 0x91, 0x71, 0x43, 0x20, 0xD9, - 0x92, 0x75, 0x43, 0x41, 0xCC, 0x8A, 0xC9, 0x43, - 0x73, 0xCC, 0x87, 0xC9, 0x43, 0xE1, 0x85, 0xA1, - 0x01, 0x43, 0xE1, 0x85, 0xA2, 0x01, 0x43, 0xE1, - 0x85, 0xA3, 0x01, 0x43, 0xE1, 0x85, 0xA4, 0x01, - 0x43, 0xE1, 0x85, 0xA5, 0x01, 0x43, 0xE1, 0x85, - 0xA6, 0x01, 0x43, 0xE1, 0x85, 0xA7, 0x01, 0x43, - // Bytes 4300 - 433f - 0xE1, 0x85, 0xA8, 0x01, 0x43, 0xE1, 0x85, 0xA9, - 0x01, 0x43, 0xE1, 0x85, 0xAA, 0x01, 0x43, 0xE1, - 0x85, 0xAB, 0x01, 0x43, 0xE1, 0x85, 0xAC, 0x01, - 0x43, 0xE1, 0x85, 0xAD, 0x01, 0x43, 0xE1, 0x85, - 0xAE, 0x01, 0x43, 0xE1, 0x85, 0xAF, 0x01, 0x43, - 0xE1, 0x85, 0xB0, 0x01, 0x43, 0xE1, 0x85, 0xB1, - 0x01, 0x43, 0xE1, 0x85, 0xB2, 0x01, 0x43, 0xE1, - 0x85, 0xB3, 0x01, 0x43, 0xE1, 0x85, 0xB4, 0x01, - // Bytes 4340 - 437f - 0x43, 0xE1, 0x85, 0xB5, 0x01, 0x43, 0xE1, 0x86, - 0xAA, 0x01, 0x43, 0xE1, 0x86, 0xAC, 0x01, 0x43, - 0xE1, 0x86, 0xAD, 0x01, 0x43, 0xE1, 0x86, 0xB0, - 0x01, 0x43, 0xE1, 0x86, 0xB1, 0x01, 0x43, 0xE1, - 0x86, 0xB2, 0x01, 0x43, 0xE1, 0x86, 0xB3, 0x01, - 0x43, 0xE1, 0x86, 0xB4, 0x01, 0x43, 0xE1, 0x86, - 0xB5, 0x01, 0x44, 0x20, 0xE3, 0x82, 0x99, 0x0D, - 0x44, 0x20, 0xE3, 0x82, 0x9A, 0x0D, 0x44, 0xC2, - // Bytes 4380 - 43bf - 0xA8, 0xCC, 0x81, 0xCA, 0x44, 0xCE, 0x91, 0xCC, - 0x81, 0xC9, 0x44, 0xCE, 0x95, 0xCC, 0x81, 0xC9, - 0x44, 0xCE, 0x97, 0xCC, 0x81, 0xC9, 0x44, 0xCE, - 0x99, 0xCC, 0x81, 0xC9, 0x44, 0xCE, 0x9F, 0xCC, - 0x81, 0xC9, 0x44, 0xCE, 0xA5, 0xCC, 0x81, 0xC9, - 0x44, 0xCE, 0xA5, 0xCC, 0x88, 0xC9, 0x44, 0xCE, - 0xA9, 0xCC, 0x81, 0xC9, 0x44, 0xCE, 0xB1, 0xCC, - 0x81, 0xC9, 0x44, 0xCE, 0xB5, 0xCC, 0x81, 0xC9, - // Bytes 43c0 - 43ff - 0x44, 0xCE, 0xB7, 0xCC, 0x81, 0xC9, 0x44, 0xCE, - 0xB9, 0xCC, 0x81, 0xC9, 0x44, 0xCE, 0xBF, 0xCC, - 0x81, 0xC9, 0x44, 0xCF, 0x85, 0xCC, 0x81, 0xC9, - 0x44, 0xCF, 0x89, 0xCC, 0x81, 0xC9, 0x44, 0xD7, - 0x90, 0xD6, 0xB7, 0x31, 0x44, 0xD7, 0x90, 0xD6, - 0xB8, 0x35, 0x44, 0xD7, 0x90, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0x91, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - 0x91, 0xD6, 0xBF, 0x49, 0x44, 0xD7, 0x92, 0xD6, - // Bytes 4400 - 443f - 0xBC, 0x41, 0x44, 0xD7, 0x93, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0x94, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - 0x95, 0xD6, 0xB9, 0x39, 0x44, 0xD7, 0x95, 0xD6, - 0xBC, 0x41, 0x44, 0xD7, 0x96, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0x98, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - 0x99, 0xD6, 0xB4, 0x25, 0x44, 0xD7, 0x99, 0xD6, - 0xBC, 0x41, 0x44, 0xD7, 0x9A, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0x9B, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - // Bytes 4440 - 447f - 0x9B, 0xD6, 0xBF, 0x49, 0x44, 0xD7, 0x9C, 0xD6, - 0xBC, 0x41, 0x44, 0xD7, 0x9E, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0xA0, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - 0xA1, 0xD6, 0xBC, 0x41, 0x44, 0xD7, 0xA3, 0xD6, - 0xBC, 0x41, 0x44, 0xD7, 0xA4, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0xA4, 0xD6, 0xBF, 0x49, 0x44, 0xD7, - 0xA6, 0xD6, 0xBC, 0x41, 0x44, 0xD7, 0xA7, 0xD6, - 0xBC, 0x41, 0x44, 0xD7, 0xA8, 0xD6, 0xBC, 0x41, - // Bytes 4480 - 44bf - 0x44, 0xD7, 0xA9, 0xD6, 0xBC, 0x41, 0x44, 0xD7, - 0xA9, 0xD7, 0x81, 0x4D, 0x44, 0xD7, 0xA9, 0xD7, - 0x82, 0x51, 0x44, 0xD7, 0xAA, 0xD6, 0xBC, 0x41, - 0x44, 0xD7, 0xB2, 0xD6, 0xB7, 0x31, 0x44, 0xD8, - 0xA7, 0xD9, 0x8B, 0x59, 0x44, 0xD8, 0xA7, 0xD9, - 0x93, 0xC9, 0x44, 0xD8, 0xA7, 0xD9, 0x94, 0xC9, - 0x44, 0xD8, 0xA7, 0xD9, 0x95, 0xB5, 0x44, 0xD8, - 0xB0, 0xD9, 0xB0, 0x79, 0x44, 0xD8, 0xB1, 0xD9, - // Bytes 44c0 - 44ff - 0xB0, 0x79, 0x44, 0xD9, 0x80, 0xD9, 0x8B, 0x59, - 0x44, 0xD9, 0x80, 0xD9, 0x8E, 0x65, 0x44, 0xD9, - 0x80, 0xD9, 0x8F, 0x69, 0x44, 0xD9, 0x80, 0xD9, - 0x90, 0x6D, 0x44, 0xD9, 0x80, 0xD9, 0x91, 0x71, - 0x44, 0xD9, 0x80, 0xD9, 0x92, 0x75, 0x44, 0xD9, - 0x87, 0xD9, 0xB0, 0x79, 0x44, 0xD9, 0x88, 0xD9, - 0x94, 0xC9, 0x44, 0xD9, 0x89, 0xD9, 0xB0, 0x79, - 0x44, 0xD9, 0x8A, 0xD9, 0x94, 0xC9, 0x44, 0xDB, - // Bytes 4500 - 453f - 0x92, 0xD9, 0x94, 0xC9, 0x44, 0xDB, 0x95, 0xD9, - 0x94, 0xC9, 0x45, 0x20, 0xCC, 0x88, 0xCC, 0x80, - 0xCA, 0x45, 0x20, 0xCC, 0x88, 0xCC, 0x81, 0xCA, - 0x45, 0x20, 0xCC, 0x88, 0xCD, 0x82, 0xCA, 0x45, - 0x20, 0xCC, 0x93, 0xCC, 0x80, 0xCA, 0x45, 0x20, - 0xCC, 0x93, 0xCC, 0x81, 0xCA, 0x45, 0x20, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x45, 0x20, 0xCC, 0x94, - 0xCC, 0x80, 0xCA, 0x45, 0x20, 0xCC, 0x94, 0xCC, - // Bytes 4540 - 457f - 0x81, 0xCA, 0x45, 0x20, 0xCC, 0x94, 0xCD, 0x82, - 0xCA, 0x45, 0x20, 0xD9, 0x8C, 0xD9, 0x91, 0x72, - 0x45, 0x20, 0xD9, 0x8D, 0xD9, 0x91, 0x72, 0x45, - 0x20, 0xD9, 0x8E, 0xD9, 0x91, 0x72, 0x45, 0x20, - 0xD9, 0x8F, 0xD9, 0x91, 0x72, 0x45, 0x20, 0xD9, - 0x90, 0xD9, 0x91, 0x72, 0x45, 0x20, 0xD9, 0x91, - 0xD9, 0xB0, 0x7A, 0x45, 0xE2, 0xAB, 0x9D, 0xCC, - 0xB8, 0x05, 0x46, 0xCE, 0xB9, 0xCC, 0x88, 0xCC, - // Bytes 4580 - 45bf - 0x81, 0xCA, 0x46, 0xCF, 0x85, 0xCC, 0x88, 0xCC, - 0x81, 0xCA, 0x46, 0xD7, 0xA9, 0xD6, 0xBC, 0xD7, - 0x81, 0x4E, 0x46, 0xD7, 0xA9, 0xD6, 0xBC, 0xD7, - 0x82, 0x52, 0x46, 0xD9, 0x80, 0xD9, 0x8E, 0xD9, - 0x91, 0x72, 0x46, 0xD9, 0x80, 0xD9, 0x8F, 0xD9, - 0x91, 0x72, 0x46, 0xD9, 0x80, 0xD9, 0x90, 0xD9, - 0x91, 0x72, 0x46, 0xE0, 0xA4, 0x95, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0x96, 0xE0, 0xA4, - // Bytes 45c0 - 45ff - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0x97, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0x9C, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0xA1, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0xA2, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0xAB, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA4, 0xAF, 0xE0, 0xA4, - 0xBC, 0x09, 0x46, 0xE0, 0xA6, 0xA1, 0xE0, 0xA6, - 0xBC, 0x09, 0x46, 0xE0, 0xA6, 0xA2, 0xE0, 0xA6, - // Bytes 4600 - 463f - 0xBC, 0x09, 0x46, 0xE0, 0xA6, 0xAF, 0xE0, 0xA6, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0x96, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0x97, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0x9C, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0xAB, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0xB2, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xA8, 0xB8, 0xE0, 0xA8, - 0xBC, 0x09, 0x46, 0xE0, 0xAC, 0xA1, 0xE0, 0xAC, - // Bytes 4640 - 467f - 0xBC, 0x09, 0x46, 0xE0, 0xAC, 0xA2, 0xE0, 0xAC, - 0xBC, 0x09, 0x46, 0xE0, 0xBE, 0xB2, 0xE0, 0xBE, - 0x80, 0x9D, 0x46, 0xE0, 0xBE, 0xB3, 0xE0, 0xBE, - 0x80, 0x9D, 0x46, 0xE3, 0x83, 0x86, 0xE3, 0x82, - 0x99, 0x0D, 0x48, 0xF0, 0x9D, 0x85, 0x97, 0xF0, - 0x9D, 0x85, 0xA5, 0xAD, 0x48, 0xF0, 0x9D, 0x85, - 0x98, 0xF0, 0x9D, 0x85, 0xA5, 0xAD, 0x48, 0xF0, - 0x9D, 0x86, 0xB9, 0xF0, 0x9D, 0x85, 0xA5, 0xAD, - // Bytes 4680 - 46bf - 0x48, 0xF0, 0x9D, 0x86, 0xBA, 0xF0, 0x9D, 0x85, - 0xA5, 0xAD, 0x49, 0xE0, 0xBE, 0xB2, 0xE0, 0xBD, - 0xB1, 0xE0, 0xBE, 0x80, 0x9E, 0x49, 0xE0, 0xBE, - 0xB3, 0xE0, 0xBD, 0xB1, 0xE0, 0xBE, 0x80, 0x9E, - 0x4C, 0xF0, 0x9D, 0x85, 0x98, 0xF0, 0x9D, 0x85, - 0xA5, 0xF0, 0x9D, 0x85, 0xAE, 0xAE, 0x4C, 0xF0, - 0x9D, 0x85, 0x98, 0xF0, 0x9D, 0x85, 0xA5, 0xF0, - 0x9D, 0x85, 0xAF, 0xAE, 0x4C, 0xF0, 0x9D, 0x85, - // Bytes 46c0 - 46ff - 0x98, 0xF0, 0x9D, 0x85, 0xA5, 0xF0, 0x9D, 0x85, - 0xB0, 0xAE, 0x4C, 0xF0, 0x9D, 0x85, 0x98, 0xF0, - 0x9D, 0x85, 0xA5, 0xF0, 0x9D, 0x85, 0xB1, 0xAE, - 0x4C, 0xF0, 0x9D, 0x85, 0x98, 0xF0, 0x9D, 0x85, - 0xA5, 0xF0, 0x9D, 0x85, 0xB2, 0xAE, 0x4C, 0xF0, - 0x9D, 0x86, 0xB9, 0xF0, 0x9D, 0x85, 0xA5, 0xF0, - 0x9D, 0x85, 0xAE, 0xAE, 0x4C, 0xF0, 0x9D, 0x86, - 0xB9, 0xF0, 0x9D, 0x85, 0xA5, 0xF0, 0x9D, 0x85, - // Bytes 4700 - 473f - 0xAF, 0xAE, 0x4C, 0xF0, 0x9D, 0x86, 0xBA, 0xF0, - 0x9D, 0x85, 0xA5, 0xF0, 0x9D, 0x85, 0xAE, 0xAE, - 0x4C, 0xF0, 0x9D, 0x86, 0xBA, 0xF0, 0x9D, 0x85, - 0xA5, 0xF0, 0x9D, 0x85, 0xAF, 0xAE, 0x83, 0x41, - 0xCC, 0x82, 0xC9, 0x83, 0x41, 0xCC, 0x86, 0xC9, - 0x83, 0x41, 0xCC, 0x87, 0xC9, 0x83, 0x41, 0xCC, - 0x88, 0xC9, 0x83, 0x41, 0xCC, 0x8A, 0xC9, 0x83, - 0x41, 0xCC, 0xA3, 0xB5, 0x83, 0x43, 0xCC, 0xA7, - // Bytes 4740 - 477f - 0xA5, 0x83, 0x45, 0xCC, 0x82, 0xC9, 0x83, 0x45, - 0xCC, 0x84, 0xC9, 0x83, 0x45, 0xCC, 0xA3, 0xB5, - 0x83, 0x45, 0xCC, 0xA7, 0xA5, 0x83, 0x49, 0xCC, - 0x88, 0xC9, 0x83, 0x4C, 0xCC, 0xA3, 0xB5, 0x83, - 0x4F, 0xCC, 0x82, 0xC9, 0x83, 0x4F, 0xCC, 0x83, - 0xC9, 0x83, 0x4F, 0xCC, 0x84, 0xC9, 0x83, 0x4F, - 0xCC, 0x87, 0xC9, 0x83, 0x4F, 0xCC, 0x88, 0xC9, - 0x83, 0x4F, 0xCC, 0x9B, 0xAD, 0x83, 0x4F, 0xCC, - // Bytes 4780 - 47bf - 0xA3, 0xB5, 0x83, 0x4F, 0xCC, 0xA8, 0xA5, 0x83, - 0x52, 0xCC, 0xA3, 0xB5, 0x83, 0x53, 0xCC, 0x81, - 0xC9, 0x83, 0x53, 0xCC, 0x8C, 0xC9, 0x83, 0x53, - 0xCC, 0xA3, 0xB5, 0x83, 0x55, 0xCC, 0x83, 0xC9, - 0x83, 0x55, 0xCC, 0x84, 0xC9, 0x83, 0x55, 0xCC, - 0x88, 0xC9, 0x83, 0x55, 0xCC, 0x9B, 0xAD, 0x83, - 0x61, 0xCC, 0x82, 0xC9, 0x83, 0x61, 0xCC, 0x86, - 0xC9, 0x83, 0x61, 0xCC, 0x87, 0xC9, 0x83, 0x61, - // Bytes 47c0 - 47ff - 0xCC, 0x88, 0xC9, 0x83, 0x61, 0xCC, 0x8A, 0xC9, - 0x83, 0x61, 0xCC, 0xA3, 0xB5, 0x83, 0x63, 0xCC, - 0xA7, 0xA5, 0x83, 0x65, 0xCC, 0x82, 0xC9, 0x83, - 0x65, 0xCC, 0x84, 0xC9, 0x83, 0x65, 0xCC, 0xA3, - 0xB5, 0x83, 0x65, 0xCC, 0xA7, 0xA5, 0x83, 0x69, - 0xCC, 0x88, 0xC9, 0x83, 0x6C, 0xCC, 0xA3, 0xB5, - 0x83, 0x6F, 0xCC, 0x82, 0xC9, 0x83, 0x6F, 0xCC, - 0x83, 0xC9, 0x83, 0x6F, 0xCC, 0x84, 0xC9, 0x83, - // Bytes 4800 - 483f - 0x6F, 0xCC, 0x87, 0xC9, 0x83, 0x6F, 0xCC, 0x88, - 0xC9, 0x83, 0x6F, 0xCC, 0x9B, 0xAD, 0x83, 0x6F, - 0xCC, 0xA3, 0xB5, 0x83, 0x6F, 0xCC, 0xA8, 0xA5, - 0x83, 0x72, 0xCC, 0xA3, 0xB5, 0x83, 0x73, 0xCC, - 0x81, 0xC9, 0x83, 0x73, 0xCC, 0x8C, 0xC9, 0x83, - 0x73, 0xCC, 0xA3, 0xB5, 0x83, 0x75, 0xCC, 0x83, - 0xC9, 0x83, 0x75, 0xCC, 0x84, 0xC9, 0x83, 0x75, - 0xCC, 0x88, 0xC9, 0x83, 0x75, 0xCC, 0x9B, 0xAD, - // Bytes 4840 - 487f - 0x84, 0xCE, 0x91, 0xCC, 0x93, 0xC9, 0x84, 0xCE, - 0x91, 0xCC, 0x94, 0xC9, 0x84, 0xCE, 0x95, 0xCC, - 0x93, 0xC9, 0x84, 0xCE, 0x95, 0xCC, 0x94, 0xC9, - 0x84, 0xCE, 0x97, 0xCC, 0x93, 0xC9, 0x84, 0xCE, - 0x97, 0xCC, 0x94, 0xC9, 0x84, 0xCE, 0x99, 0xCC, - 0x93, 0xC9, 0x84, 0xCE, 0x99, 0xCC, 0x94, 0xC9, - 0x84, 0xCE, 0x9F, 0xCC, 0x93, 0xC9, 0x84, 0xCE, - 0x9F, 0xCC, 0x94, 0xC9, 0x84, 0xCE, 0xA5, 0xCC, - // Bytes 4880 - 48bf - 0x94, 0xC9, 0x84, 0xCE, 0xA9, 0xCC, 0x93, 0xC9, - 0x84, 0xCE, 0xA9, 0xCC, 0x94, 0xC9, 0x84, 0xCE, - 0xB1, 0xCC, 0x80, 0xC9, 0x84, 0xCE, 0xB1, 0xCC, - 0x81, 0xC9, 0x84, 0xCE, 0xB1, 0xCC, 0x93, 0xC9, - 0x84, 0xCE, 0xB1, 0xCC, 0x94, 0xC9, 0x84, 0xCE, - 0xB1, 0xCD, 0x82, 0xC9, 0x84, 0xCE, 0xB5, 0xCC, - 0x93, 0xC9, 0x84, 0xCE, 0xB5, 0xCC, 0x94, 0xC9, - 0x84, 0xCE, 0xB7, 0xCC, 0x80, 0xC9, 0x84, 0xCE, - // Bytes 48c0 - 48ff - 0xB7, 0xCC, 0x81, 0xC9, 0x84, 0xCE, 0xB7, 0xCC, - 0x93, 0xC9, 0x84, 0xCE, 0xB7, 0xCC, 0x94, 0xC9, - 0x84, 0xCE, 0xB7, 0xCD, 0x82, 0xC9, 0x84, 0xCE, - 0xB9, 0xCC, 0x88, 0xC9, 0x84, 0xCE, 0xB9, 0xCC, - 0x93, 0xC9, 0x84, 0xCE, 0xB9, 0xCC, 0x94, 0xC9, - 0x84, 0xCE, 0xBF, 0xCC, 0x93, 0xC9, 0x84, 0xCE, - 0xBF, 0xCC, 0x94, 0xC9, 0x84, 0xCF, 0x85, 0xCC, - 0x88, 0xC9, 0x84, 0xCF, 0x85, 0xCC, 0x93, 0xC9, - // Bytes 4900 - 493f - 0x84, 0xCF, 0x85, 0xCC, 0x94, 0xC9, 0x84, 0xCF, - 0x89, 0xCC, 0x80, 0xC9, 0x84, 0xCF, 0x89, 0xCC, - 0x81, 0xC9, 0x84, 0xCF, 0x89, 0xCC, 0x93, 0xC9, - 0x84, 0xCF, 0x89, 0xCC, 0x94, 0xC9, 0x84, 0xCF, - 0x89, 0xCD, 0x82, 0xC9, 0x86, 0xCE, 0x91, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0x91, 0xCC, - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0x91, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0x91, 0xCC, - // Bytes 4940 - 497f - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0x91, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0x91, 0xCC, - 0x94, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0x97, 0xCC, - // Bytes 4980 - 49bf - 0x94, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xA9, 0xCC, - 0x94, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - // Bytes 49c0 - 49ff - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xB1, 0xCC, - 0x94, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - // Bytes 4a00 - 4a3f - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCE, 0xB7, 0xCC, - 0x94, 0xCD, 0x82, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - 0x93, 0xCC, 0x80, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - 0x93, 0xCC, 0x81, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - 0x93, 0xCD, 0x82, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - 0x94, 0xCC, 0x80, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - 0x94, 0xCC, 0x81, 0xCA, 0x86, 0xCF, 0x89, 0xCC, - // Bytes 4a40 - 4a7f - 0x94, 0xCD, 0x82, 0xCA, 0x42, 0xCC, 0x80, 0xC9, - 0x32, 0x42, 0xCC, 0x81, 0xC9, 0x32, 0x42, 0xCC, - 0x93, 0xC9, 0x32, 0x44, 0xCC, 0x88, 0xCC, 0x81, - 0xCA, 0x32, 0x43, 0xE3, 0x82, 0x99, 0x0D, 0x03, - 0x43, 0xE3, 0x82, 0x9A, 0x0D, 0x03, 0x46, 0xE0, - 0xBD, 0xB1, 0xE0, 0xBD, 0xB2, 0x9E, 0x26, 0x46, - 0xE0, 0xBD, 0xB1, 0xE0, 0xBD, 0xB4, 0xA2, 0x26, - 0x46, 0xE0, 0xBD, 0xB1, 0xE0, 0xBE, 0x80, 0x9E, - // Bytes 4a80 - 4abf - 0x26, 0x00, 0x01, -} - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *nfcTrie) lookup(s []byte) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return nfcValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = nfcIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *nfcTrie) lookupUnsafe(s []byte) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return nfcValues[c0] - } - i := nfcIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = nfcIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = nfcIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *nfcTrie) lookupString(s string) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return nfcValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := nfcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = nfcIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *nfcTrie) lookupStringUnsafe(s string) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return nfcValues[c0] - } - i := nfcIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = nfcIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = nfcIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// nfcTrie. Total size: 10332 bytes (10.09 KiB). Checksum: ad355b768fddb1b6. -type nfcTrie struct{} - -func newNfcTrie(i int) *nfcTrie { - return &nfcTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *nfcTrie) lookupValue(n uint32, b byte) uint16 { - switch { - case n < 44: - return uint16(nfcValues[n<<6+uint32(b)]) - default: - n -= 44 - return uint16(nfcSparse.lookup(n, b)) - } -} - -// nfcValues: 46 blocks, 2944 entries, 5888 bytes -// The third block is the zero block. -var nfcValues = [2944]uint16{ - // Block 0x0, offset 0x0 - 0x3c: 0xa000, 0x3d: 0xa000, 0x3e: 0xa000, - // Block 0x1, offset 0x40 - 0x41: 0xa000, 0x42: 0xa000, 0x43: 0xa000, 0x44: 0xa000, 0x45: 0xa000, - 0x46: 0xa000, 0x47: 0xa000, 0x48: 0xa000, 0x49: 0xa000, 0x4a: 0xa000, 0x4b: 0xa000, - 0x4c: 0xa000, 0x4d: 0xa000, 0x4e: 0xa000, 0x4f: 0xa000, 0x50: 0xa000, - 0x52: 0xa000, 0x53: 0xa000, 0x54: 0xa000, 0x55: 0xa000, 0x56: 0xa000, 0x57: 0xa000, - 0x58: 0xa000, 0x59: 0xa000, 0x5a: 0xa000, - 0x61: 0xa000, 0x62: 0xa000, 0x63: 0xa000, - 0x64: 0xa000, 0x65: 0xa000, 0x66: 0xa000, 0x67: 0xa000, 0x68: 0xa000, 0x69: 0xa000, - 0x6a: 0xa000, 0x6b: 0xa000, 0x6c: 0xa000, 0x6d: 0xa000, 0x6e: 0xa000, 0x6f: 0xa000, - 0x70: 0xa000, 0x72: 0xa000, 0x73: 0xa000, 0x74: 0xa000, 0x75: 0xa000, - 0x76: 0xa000, 0x77: 0xa000, 0x78: 0xa000, 0x79: 0xa000, 0x7a: 0xa000, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc0: 0x2f6f, 0xc1: 0x2f74, 0xc2: 0x471e, 0xc3: 0x2f79, 0xc4: 0x472d, 0xc5: 0x4732, - 0xc6: 0xa000, 0xc7: 0x473c, 0xc8: 0x2fe2, 0xc9: 0x2fe7, 0xca: 0x4741, 0xcb: 0x2ffb, - 0xcc: 0x306e, 0xcd: 0x3073, 0xce: 0x3078, 0xcf: 0x4755, 0xd1: 0x3104, - 0xd2: 0x3127, 0xd3: 0x312c, 0xd4: 0x475f, 0xd5: 0x4764, 0xd6: 0x4773, - 0xd8: 0xa000, 0xd9: 0x31b3, 0xda: 0x31b8, 0xdb: 0x31bd, 0xdc: 0x47a5, 0xdd: 0x3235, - 0xe0: 0x327b, 0xe1: 0x3280, 0xe2: 0x47af, 0xe3: 0x3285, - 0xe4: 0x47be, 0xe5: 0x47c3, 0xe6: 0xa000, 0xe7: 0x47cd, 0xe8: 0x32ee, 0xe9: 0x32f3, - 0xea: 0x47d2, 0xeb: 0x3307, 0xec: 0x337f, 0xed: 0x3384, 0xee: 0x3389, 0xef: 0x47e6, - 0xf1: 0x3415, 0xf2: 0x3438, 0xf3: 0x343d, 0xf4: 0x47f0, 0xf5: 0x47f5, - 0xf6: 0x4804, 0xf8: 0xa000, 0xf9: 0x34c9, 0xfa: 0x34ce, 0xfb: 0x34d3, - 0xfc: 0x4836, 0xfd: 0x3550, 0xff: 0x3569, - // Block 0x4, offset 0x100 - 0x100: 0x2f7e, 0x101: 0x328a, 0x102: 0x4723, 0x103: 0x47b4, 0x104: 0x2f9c, 0x105: 0x32a8, - 0x106: 0x2fb0, 0x107: 0x32bc, 0x108: 0x2fb5, 0x109: 0x32c1, 0x10a: 0x2fba, 0x10b: 0x32c6, - 0x10c: 0x2fbf, 0x10d: 0x32cb, 0x10e: 0x2fc9, 0x10f: 0x32d5, - 0x112: 0x4746, 0x113: 0x47d7, 0x114: 0x2ff1, 0x115: 0x32fd, 0x116: 0x2ff6, 0x117: 0x3302, - 0x118: 0x3014, 0x119: 0x3320, 0x11a: 0x3005, 0x11b: 0x3311, 0x11c: 0x302d, 0x11d: 0x3339, - 0x11e: 0x3037, 0x11f: 0x3343, 0x120: 0x303c, 0x121: 0x3348, 0x122: 0x3046, 0x123: 0x3352, - 0x124: 0x304b, 0x125: 0x3357, 0x128: 0x307d, 0x129: 0x338e, - 0x12a: 0x3082, 0x12b: 0x3393, 0x12c: 0x3087, 0x12d: 0x3398, 0x12e: 0x30aa, 0x12f: 0x33b6, - 0x130: 0x308c, 0x134: 0x30b4, 0x135: 0x33c0, - 0x136: 0x30c8, 0x137: 0x33d9, 0x139: 0x30d2, 0x13a: 0x33e3, 0x13b: 0x30dc, - 0x13c: 0x33ed, 0x13d: 0x30d7, 0x13e: 0x33e8, - // Block 0x5, offset 0x140 - 0x143: 0x30ff, 0x144: 0x3410, 0x145: 0x3118, - 0x146: 0x3429, 0x147: 0x310e, 0x148: 0x341f, - 0x14c: 0x4769, 0x14d: 0x47fa, 0x14e: 0x3131, 0x14f: 0x3442, 0x150: 0x313b, 0x151: 0x344c, - 0x154: 0x3159, 0x155: 0x346a, 0x156: 0x3172, 0x157: 0x3483, - 0x158: 0x3163, 0x159: 0x3474, 0x15a: 0x478c, 0x15b: 0x481d, 0x15c: 0x317c, 0x15d: 0x348d, - 0x15e: 0x318b, 0x15f: 0x349c, 0x160: 0x4791, 0x161: 0x4822, 0x162: 0x31a4, 0x163: 0x34ba, - 0x164: 0x3195, 0x165: 0x34ab, 0x168: 0x479b, 0x169: 0x482c, - 0x16a: 0x47a0, 0x16b: 0x4831, 0x16c: 0x31c2, 0x16d: 0x34d8, 0x16e: 0x31cc, 0x16f: 0x34e2, - 0x170: 0x31d1, 0x171: 0x34e7, 0x172: 0x31ef, 0x173: 0x3505, 0x174: 0x3212, 0x175: 0x3528, - 0x176: 0x323a, 0x177: 0x3555, 0x178: 0x324e, 0x179: 0x325d, 0x17a: 0x357d, 0x17b: 0x3267, - 0x17c: 0x3587, 0x17d: 0x326c, 0x17e: 0x358c, 0x17f: 0xa000, - // Block 0x6, offset 0x180 - 0x184: 0x8100, 0x185: 0x8100, - 0x186: 0x8100, - 0x18d: 0x2f88, 0x18e: 0x3294, 0x18f: 0x3096, 0x190: 0x33a2, 0x191: 0x3140, - 0x192: 0x3451, 0x193: 0x31d6, 0x194: 0x34ec, 0x195: 0x39cf, 0x196: 0x3b5e, 0x197: 0x39c8, - 0x198: 0x3b57, 0x199: 0x39d6, 0x19a: 0x3b65, 0x19b: 0x39c1, 0x19c: 0x3b50, - 0x19e: 0x38b0, 0x19f: 0x3a3f, 0x1a0: 0x38a9, 0x1a1: 0x3a38, 0x1a2: 0x35b3, 0x1a3: 0x35c5, - 0x1a6: 0x3041, 0x1a7: 0x334d, 0x1a8: 0x30be, 0x1a9: 0x33cf, - 0x1aa: 0x4782, 0x1ab: 0x4813, 0x1ac: 0x3990, 0x1ad: 0x3b1f, 0x1ae: 0x35d7, 0x1af: 0x35dd, - 0x1b0: 0x33c5, 0x1b4: 0x3028, 0x1b5: 0x3334, - 0x1b8: 0x30fa, 0x1b9: 0x340b, 0x1ba: 0x38b7, 0x1bb: 0x3a46, - 0x1bc: 0x35ad, 0x1bd: 0x35bf, 0x1be: 0x35b9, 0x1bf: 0x35cb, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x2f8d, 0x1c1: 0x3299, 0x1c2: 0x2f92, 0x1c3: 0x329e, 0x1c4: 0x300a, 0x1c5: 0x3316, - 0x1c6: 0x300f, 0x1c7: 0x331b, 0x1c8: 0x309b, 0x1c9: 0x33a7, 0x1ca: 0x30a0, 0x1cb: 0x33ac, - 0x1cc: 0x3145, 0x1cd: 0x3456, 0x1ce: 0x314a, 0x1cf: 0x345b, 0x1d0: 0x3168, 0x1d1: 0x3479, - 0x1d2: 0x316d, 0x1d3: 0x347e, 0x1d4: 0x31db, 0x1d5: 0x34f1, 0x1d6: 0x31e0, 0x1d7: 0x34f6, - 0x1d8: 0x3186, 0x1d9: 0x3497, 0x1da: 0x319f, 0x1db: 0x34b5, - 0x1de: 0x305a, 0x1df: 0x3366, - 0x1e6: 0x4728, 0x1e7: 0x47b9, 0x1e8: 0x4750, 0x1e9: 0x47e1, - 0x1ea: 0x395f, 0x1eb: 0x3aee, 0x1ec: 0x393c, 0x1ed: 0x3acb, 0x1ee: 0x476e, 0x1ef: 0x47ff, - 0x1f0: 0x3958, 0x1f1: 0x3ae7, 0x1f2: 0x3244, 0x1f3: 0x355f, - // Block 0x8, offset 0x200 - 0x200: 0x9932, 0x201: 0x9932, 0x202: 0x9932, 0x203: 0x9932, 0x204: 0x9932, 0x205: 0x8132, - 0x206: 0x9932, 0x207: 0x9932, 0x208: 0x9932, 0x209: 0x9932, 0x20a: 0x9932, 0x20b: 0x9932, - 0x20c: 0x9932, 0x20d: 0x8132, 0x20e: 0x8132, 0x20f: 0x9932, 0x210: 0x8132, 0x211: 0x9932, - 0x212: 0x8132, 0x213: 0x9932, 0x214: 0x9932, 0x215: 0x8133, 0x216: 0x812d, 0x217: 0x812d, - 0x218: 0x812d, 0x219: 0x812d, 0x21a: 0x8133, 0x21b: 0x992b, 0x21c: 0x812d, 0x21d: 0x812d, - 0x21e: 0x812d, 0x21f: 0x812d, 0x220: 0x812d, 0x221: 0x8129, 0x222: 0x8129, 0x223: 0x992d, - 0x224: 0x992d, 0x225: 0x992d, 0x226: 0x992d, 0x227: 0x9929, 0x228: 0x9929, 0x229: 0x812d, - 0x22a: 0x812d, 0x22b: 0x812d, 0x22c: 0x812d, 0x22d: 0x992d, 0x22e: 0x992d, 0x22f: 0x812d, - 0x230: 0x992d, 0x231: 0x992d, 0x232: 0x812d, 0x233: 0x812d, 0x234: 0x8101, 0x235: 0x8101, - 0x236: 0x8101, 0x237: 0x8101, 0x238: 0x9901, 0x239: 0x812d, 0x23a: 0x812d, 0x23b: 0x812d, - 0x23c: 0x812d, 0x23d: 0x8132, 0x23e: 0x8132, 0x23f: 0x8132, - // Block 0x9, offset 0x240 - 0x240: 0x4a44, 0x241: 0x4a49, 0x242: 0x9932, 0x243: 0x4a4e, 0x244: 0x4a53, 0x245: 0x9936, - 0x246: 0x8132, 0x247: 0x812d, 0x248: 0x812d, 0x249: 0x812d, 0x24a: 0x8132, 0x24b: 0x8132, - 0x24c: 0x8132, 0x24d: 0x812d, 0x24e: 0x812d, 0x250: 0x8132, 0x251: 0x8132, - 0x252: 0x8132, 0x253: 0x812d, 0x254: 0x812d, 0x255: 0x812d, 0x256: 0x812d, 0x257: 0x8132, - 0x258: 0x8133, 0x259: 0x812d, 0x25a: 0x812d, 0x25b: 0x8132, 0x25c: 0x8134, 0x25d: 0x8135, - 0x25e: 0x8135, 0x25f: 0x8134, 0x260: 0x8135, 0x261: 0x8135, 0x262: 0x8134, 0x263: 0x8132, - 0x264: 0x8132, 0x265: 0x8132, 0x266: 0x8132, 0x267: 0x8132, 0x268: 0x8132, 0x269: 0x8132, - 0x26a: 0x8132, 0x26b: 0x8132, 0x26c: 0x8132, 0x26d: 0x8132, 0x26e: 0x8132, 0x26f: 0x8132, - 0x274: 0x0170, - 0x27a: 0x8100, - 0x27e: 0x0037, - // Block 0xa, offset 0x280 - 0x284: 0x8100, 0x285: 0x35a1, - 0x286: 0x35e9, 0x287: 0x00ce, 0x288: 0x3607, 0x289: 0x3613, 0x28a: 0x3625, - 0x28c: 0x3643, 0x28e: 0x3655, 0x28f: 0x3673, 0x290: 0x3e08, 0x291: 0xa000, - 0x295: 0xa000, 0x297: 0xa000, - 0x299: 0xa000, - 0x29f: 0xa000, 0x2a1: 0xa000, - 0x2a5: 0xa000, 0x2a9: 0xa000, - 0x2aa: 0x3637, 0x2ab: 0x3667, 0x2ac: 0x4894, 0x2ad: 0x3697, 0x2ae: 0x48be, 0x2af: 0x36a9, - 0x2b0: 0x3e70, 0x2b1: 0xa000, 0x2b5: 0xa000, - 0x2b7: 0xa000, 0x2b9: 0xa000, - 0x2bf: 0xa000, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x3721, 0x2c1: 0x372d, 0x2c3: 0x371b, - 0x2c6: 0xa000, 0x2c7: 0x3709, - 0x2cc: 0x375d, 0x2cd: 0x3745, 0x2ce: 0x376f, 0x2d0: 0xa000, - 0x2d3: 0xa000, 0x2d5: 0xa000, 0x2d6: 0xa000, 0x2d7: 0xa000, - 0x2d8: 0xa000, 0x2d9: 0x3751, 0x2da: 0xa000, - 0x2de: 0xa000, 0x2e3: 0xa000, - 0x2e7: 0xa000, - 0x2eb: 0xa000, 0x2ed: 0xa000, - 0x2f0: 0xa000, 0x2f3: 0xa000, 0x2f5: 0xa000, - 0x2f6: 0xa000, 0x2f7: 0xa000, 0x2f8: 0xa000, 0x2f9: 0x37d5, 0x2fa: 0xa000, - 0x2fe: 0xa000, - // Block 0xc, offset 0x300 - 0x301: 0x3733, 0x302: 0x37b7, - 0x310: 0x370f, 0x311: 0x3793, - 0x312: 0x3715, 0x313: 0x3799, 0x316: 0x3727, 0x317: 0x37ab, - 0x318: 0xa000, 0x319: 0xa000, 0x31a: 0x3829, 0x31b: 0x382f, 0x31c: 0x3739, 0x31d: 0x37bd, - 0x31e: 0x373f, 0x31f: 0x37c3, 0x322: 0x374b, 0x323: 0x37cf, - 0x324: 0x3757, 0x325: 0x37db, 0x326: 0x3763, 0x327: 0x37e7, 0x328: 0xa000, 0x329: 0xa000, - 0x32a: 0x3835, 0x32b: 0x383b, 0x32c: 0x378d, 0x32d: 0x3811, 0x32e: 0x3769, 0x32f: 0x37ed, - 0x330: 0x3775, 0x331: 0x37f9, 0x332: 0x377b, 0x333: 0x37ff, 0x334: 0x3781, 0x335: 0x3805, - 0x338: 0x3787, 0x339: 0x380b, - // Block 0xd, offset 0x340 - 0x351: 0x812d, - 0x352: 0x8132, 0x353: 0x8132, 0x354: 0x8132, 0x355: 0x8132, 0x356: 0x812d, 0x357: 0x8132, - 0x358: 0x8132, 0x359: 0x8132, 0x35a: 0x812e, 0x35b: 0x812d, 0x35c: 0x8132, 0x35d: 0x8132, - 0x35e: 0x8132, 0x35f: 0x8132, 0x360: 0x8132, 0x361: 0x8132, 0x362: 0x812d, 0x363: 0x812d, - 0x364: 0x812d, 0x365: 0x812d, 0x366: 0x812d, 0x367: 0x812d, 0x368: 0x8132, 0x369: 0x8132, - 0x36a: 0x812d, 0x36b: 0x8132, 0x36c: 0x8132, 0x36d: 0x812e, 0x36e: 0x8131, 0x36f: 0x8132, - 0x370: 0x8105, 0x371: 0x8106, 0x372: 0x8107, 0x373: 0x8108, 0x374: 0x8109, 0x375: 0x810a, - 0x376: 0x810b, 0x377: 0x810c, 0x378: 0x810d, 0x379: 0x810e, 0x37a: 0x810e, 0x37b: 0x810f, - 0x37c: 0x8110, 0x37d: 0x8111, 0x37f: 0x8112, - // Block 0xe, offset 0x380 - 0x388: 0xa000, 0x38a: 0xa000, 0x38b: 0x8116, - 0x38c: 0x8117, 0x38d: 0x8118, 0x38e: 0x8119, 0x38f: 0x811a, 0x390: 0x811b, 0x391: 0x811c, - 0x392: 0x811d, 0x393: 0x9932, 0x394: 0x9932, 0x395: 0x992d, 0x396: 0x812d, 0x397: 0x8132, - 0x398: 0x8132, 0x399: 0x8132, 0x39a: 0x8132, 0x39b: 0x8132, 0x39c: 0x812d, 0x39d: 0x8132, - 0x39e: 0x8132, 0x39f: 0x812d, - 0x3b0: 0x811e, - // Block 0xf, offset 0x3c0 - 0x3c5: 0xa000, - 0x3c6: 0x2d26, 0x3c7: 0xa000, 0x3c8: 0x2d2e, 0x3c9: 0xa000, 0x3ca: 0x2d36, 0x3cb: 0xa000, - 0x3cc: 0x2d3e, 0x3cd: 0xa000, 0x3ce: 0x2d46, 0x3d1: 0xa000, - 0x3d2: 0x2d4e, - 0x3f4: 0x8102, 0x3f5: 0x9900, - 0x3fa: 0xa000, 0x3fb: 0x2d56, - 0x3fc: 0xa000, 0x3fd: 0x2d5e, 0x3fe: 0xa000, 0x3ff: 0xa000, - // Block 0x10, offset 0x400 - 0x400: 0x2f97, 0x401: 0x32a3, 0x402: 0x2fa1, 0x403: 0x32ad, 0x404: 0x2fa6, 0x405: 0x32b2, - 0x406: 0x2fab, 0x407: 0x32b7, 0x408: 0x38cc, 0x409: 0x3a5b, 0x40a: 0x2fc4, 0x40b: 0x32d0, - 0x40c: 0x2fce, 0x40d: 0x32da, 0x40e: 0x2fdd, 0x40f: 0x32e9, 0x410: 0x2fd3, 0x411: 0x32df, - 0x412: 0x2fd8, 0x413: 0x32e4, 0x414: 0x38ef, 0x415: 0x3a7e, 0x416: 0x38f6, 0x417: 0x3a85, - 0x418: 0x3019, 0x419: 0x3325, 0x41a: 0x301e, 0x41b: 0x332a, 0x41c: 0x3904, 0x41d: 0x3a93, - 0x41e: 0x3023, 0x41f: 0x332f, 0x420: 0x3032, 0x421: 0x333e, 0x422: 0x3050, 0x423: 0x335c, - 0x424: 0x305f, 0x425: 0x336b, 0x426: 0x3055, 0x427: 0x3361, 0x428: 0x3064, 0x429: 0x3370, - 0x42a: 0x3069, 0x42b: 0x3375, 0x42c: 0x30af, 0x42d: 0x33bb, 0x42e: 0x390b, 0x42f: 0x3a9a, - 0x430: 0x30b9, 0x431: 0x33ca, 0x432: 0x30c3, 0x433: 0x33d4, 0x434: 0x30cd, 0x435: 0x33de, - 0x436: 0x475a, 0x437: 0x47eb, 0x438: 0x3912, 0x439: 0x3aa1, 0x43a: 0x30e6, 0x43b: 0x33f7, - 0x43c: 0x30e1, 0x43d: 0x33f2, 0x43e: 0x30eb, 0x43f: 0x33fc, - // Block 0x11, offset 0x440 - 0x440: 0x30f0, 0x441: 0x3401, 0x442: 0x30f5, 0x443: 0x3406, 0x444: 0x3109, 0x445: 0x341a, - 0x446: 0x3113, 0x447: 0x3424, 0x448: 0x3122, 0x449: 0x3433, 0x44a: 0x311d, 0x44b: 0x342e, - 0x44c: 0x3935, 0x44d: 0x3ac4, 0x44e: 0x3943, 0x44f: 0x3ad2, 0x450: 0x394a, 0x451: 0x3ad9, - 0x452: 0x3951, 0x453: 0x3ae0, 0x454: 0x314f, 0x455: 0x3460, 0x456: 0x3154, 0x457: 0x3465, - 0x458: 0x315e, 0x459: 0x346f, 0x45a: 0x4787, 0x45b: 0x4818, 0x45c: 0x3997, 0x45d: 0x3b26, - 0x45e: 0x3177, 0x45f: 0x3488, 0x460: 0x3181, 0x461: 0x3492, 0x462: 0x4796, 0x463: 0x4827, - 0x464: 0x399e, 0x465: 0x3b2d, 0x466: 0x39a5, 0x467: 0x3b34, 0x468: 0x39ac, 0x469: 0x3b3b, - 0x46a: 0x3190, 0x46b: 0x34a1, 0x46c: 0x319a, 0x46d: 0x34b0, 0x46e: 0x31ae, 0x46f: 0x34c4, - 0x470: 0x31a9, 0x471: 0x34bf, 0x472: 0x31ea, 0x473: 0x3500, 0x474: 0x31f9, 0x475: 0x350f, - 0x476: 0x31f4, 0x477: 0x350a, 0x478: 0x39b3, 0x479: 0x3b42, 0x47a: 0x39ba, 0x47b: 0x3b49, - 0x47c: 0x31fe, 0x47d: 0x3514, 0x47e: 0x3203, 0x47f: 0x3519, - // Block 0x12, offset 0x480 - 0x480: 0x3208, 0x481: 0x351e, 0x482: 0x320d, 0x483: 0x3523, 0x484: 0x321c, 0x485: 0x3532, - 0x486: 0x3217, 0x487: 0x352d, 0x488: 0x3221, 0x489: 0x353c, 0x48a: 0x3226, 0x48b: 0x3541, - 0x48c: 0x322b, 0x48d: 0x3546, 0x48e: 0x3249, 0x48f: 0x3564, 0x490: 0x3262, 0x491: 0x3582, - 0x492: 0x3271, 0x493: 0x3591, 0x494: 0x3276, 0x495: 0x3596, 0x496: 0x337a, 0x497: 0x34a6, - 0x498: 0x3537, 0x499: 0x3573, 0x49b: 0x35d1, - 0x4a0: 0x4737, 0x4a1: 0x47c8, 0x4a2: 0x2f83, 0x4a3: 0x328f, - 0x4a4: 0x3878, 0x4a5: 0x3a07, 0x4a6: 0x3871, 0x4a7: 0x3a00, 0x4a8: 0x3886, 0x4a9: 0x3a15, - 0x4aa: 0x387f, 0x4ab: 0x3a0e, 0x4ac: 0x38be, 0x4ad: 0x3a4d, 0x4ae: 0x3894, 0x4af: 0x3a23, - 0x4b0: 0x388d, 0x4b1: 0x3a1c, 0x4b2: 0x38a2, 0x4b3: 0x3a31, 0x4b4: 0x389b, 0x4b5: 0x3a2a, - 0x4b6: 0x38c5, 0x4b7: 0x3a54, 0x4b8: 0x474b, 0x4b9: 0x47dc, 0x4ba: 0x3000, 0x4bb: 0x330c, - 0x4bc: 0x2fec, 0x4bd: 0x32f8, 0x4be: 0x38da, 0x4bf: 0x3a69, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x38d3, 0x4c1: 0x3a62, 0x4c2: 0x38e8, 0x4c3: 0x3a77, 0x4c4: 0x38e1, 0x4c5: 0x3a70, - 0x4c6: 0x38fd, 0x4c7: 0x3a8c, 0x4c8: 0x3091, 0x4c9: 0x339d, 0x4ca: 0x30a5, 0x4cb: 0x33b1, - 0x4cc: 0x477d, 0x4cd: 0x480e, 0x4ce: 0x3136, 0x4cf: 0x3447, 0x4d0: 0x3920, 0x4d1: 0x3aaf, - 0x4d2: 0x3919, 0x4d3: 0x3aa8, 0x4d4: 0x392e, 0x4d5: 0x3abd, 0x4d6: 0x3927, 0x4d7: 0x3ab6, - 0x4d8: 0x3989, 0x4d9: 0x3b18, 0x4da: 0x396d, 0x4db: 0x3afc, 0x4dc: 0x3966, 0x4dd: 0x3af5, - 0x4de: 0x397b, 0x4df: 0x3b0a, 0x4e0: 0x3974, 0x4e1: 0x3b03, 0x4e2: 0x3982, 0x4e3: 0x3b11, - 0x4e4: 0x31e5, 0x4e5: 0x34fb, 0x4e6: 0x31c7, 0x4e7: 0x34dd, 0x4e8: 0x39e4, 0x4e9: 0x3b73, - 0x4ea: 0x39dd, 0x4eb: 0x3b6c, 0x4ec: 0x39f2, 0x4ed: 0x3b81, 0x4ee: 0x39eb, 0x4ef: 0x3b7a, - 0x4f0: 0x39f9, 0x4f1: 0x3b88, 0x4f2: 0x3230, 0x4f3: 0x354b, 0x4f4: 0x3258, 0x4f5: 0x3578, - 0x4f6: 0x3253, 0x4f7: 0x356e, 0x4f8: 0x323f, 0x4f9: 0x355a, - // Block 0x14, offset 0x500 - 0x500: 0x489a, 0x501: 0x48a0, 0x502: 0x49b4, 0x503: 0x49cc, 0x504: 0x49bc, 0x505: 0x49d4, - 0x506: 0x49c4, 0x507: 0x49dc, 0x508: 0x4840, 0x509: 0x4846, 0x50a: 0x4924, 0x50b: 0x493c, - 0x50c: 0x492c, 0x50d: 0x4944, 0x50e: 0x4934, 0x50f: 0x494c, 0x510: 0x48ac, 0x511: 0x48b2, - 0x512: 0x3db8, 0x513: 0x3dc8, 0x514: 0x3dc0, 0x515: 0x3dd0, - 0x518: 0x484c, 0x519: 0x4852, 0x51a: 0x3ce8, 0x51b: 0x3cf8, 0x51c: 0x3cf0, 0x51d: 0x3d00, - 0x520: 0x48c4, 0x521: 0x48ca, 0x522: 0x49e4, 0x523: 0x49fc, - 0x524: 0x49ec, 0x525: 0x4a04, 0x526: 0x49f4, 0x527: 0x4a0c, 0x528: 0x4858, 0x529: 0x485e, - 0x52a: 0x4954, 0x52b: 0x496c, 0x52c: 0x495c, 0x52d: 0x4974, 0x52e: 0x4964, 0x52f: 0x497c, - 0x530: 0x48dc, 0x531: 0x48e2, 0x532: 0x3e18, 0x533: 0x3e30, 0x534: 0x3e20, 0x535: 0x3e38, - 0x536: 0x3e28, 0x537: 0x3e40, 0x538: 0x4864, 0x539: 0x486a, 0x53a: 0x3d18, 0x53b: 0x3d30, - 0x53c: 0x3d20, 0x53d: 0x3d38, 0x53e: 0x3d28, 0x53f: 0x3d40, - // Block 0x15, offset 0x540 - 0x540: 0x48e8, 0x541: 0x48ee, 0x542: 0x3e48, 0x543: 0x3e58, 0x544: 0x3e50, 0x545: 0x3e60, - 0x548: 0x4870, 0x549: 0x4876, 0x54a: 0x3d48, 0x54b: 0x3d58, - 0x54c: 0x3d50, 0x54d: 0x3d60, 0x550: 0x48fa, 0x551: 0x4900, - 0x552: 0x3e80, 0x553: 0x3e98, 0x554: 0x3e88, 0x555: 0x3ea0, 0x556: 0x3e90, 0x557: 0x3ea8, - 0x559: 0x487c, 0x55b: 0x3d68, 0x55d: 0x3d70, - 0x55f: 0x3d78, 0x560: 0x4912, 0x561: 0x4918, 0x562: 0x4a14, 0x563: 0x4a2c, - 0x564: 0x4a1c, 0x565: 0x4a34, 0x566: 0x4a24, 0x567: 0x4a3c, 0x568: 0x4882, 0x569: 0x4888, - 0x56a: 0x4984, 0x56b: 0x499c, 0x56c: 0x498c, 0x56d: 0x49a4, 0x56e: 0x4994, 0x56f: 0x49ac, - 0x570: 0x488e, 0x571: 0x43b4, 0x572: 0x3691, 0x573: 0x43ba, 0x574: 0x48b8, 0x575: 0x43c0, - 0x576: 0x36a3, 0x577: 0x43c6, 0x578: 0x36c1, 0x579: 0x43cc, 0x57a: 0x36d9, 0x57b: 0x43d2, - 0x57c: 0x4906, 0x57d: 0x43d8, - // Block 0x16, offset 0x580 - 0x580: 0x3da0, 0x581: 0x3da8, 0x582: 0x4184, 0x583: 0x41a2, 0x584: 0x418e, 0x585: 0x41ac, - 0x586: 0x4198, 0x587: 0x41b6, 0x588: 0x3cd8, 0x589: 0x3ce0, 0x58a: 0x40d0, 0x58b: 0x40ee, - 0x58c: 0x40da, 0x58d: 0x40f8, 0x58e: 0x40e4, 0x58f: 0x4102, 0x590: 0x3de8, 0x591: 0x3df0, - 0x592: 0x41c0, 0x593: 0x41de, 0x594: 0x41ca, 0x595: 0x41e8, 0x596: 0x41d4, 0x597: 0x41f2, - 0x598: 0x3d08, 0x599: 0x3d10, 0x59a: 0x410c, 0x59b: 0x412a, 0x59c: 0x4116, 0x59d: 0x4134, - 0x59e: 0x4120, 0x59f: 0x413e, 0x5a0: 0x3ec0, 0x5a1: 0x3ec8, 0x5a2: 0x41fc, 0x5a3: 0x421a, - 0x5a4: 0x4206, 0x5a5: 0x4224, 0x5a6: 0x4210, 0x5a7: 0x422e, 0x5a8: 0x3d80, 0x5a9: 0x3d88, - 0x5aa: 0x4148, 0x5ab: 0x4166, 0x5ac: 0x4152, 0x5ad: 0x4170, 0x5ae: 0x415c, 0x5af: 0x417a, - 0x5b0: 0x3685, 0x5b1: 0x367f, 0x5b2: 0x3d90, 0x5b3: 0x368b, 0x5b4: 0x3d98, - 0x5b6: 0x48a6, 0x5b7: 0x3db0, 0x5b8: 0x35f5, 0x5b9: 0x35ef, 0x5ba: 0x35e3, 0x5bb: 0x4384, - 0x5bc: 0x35fb, 0x5bd: 0x8100, 0x5be: 0x01d3, 0x5bf: 0xa100, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x8100, 0x5c1: 0x35a7, 0x5c2: 0x3dd8, 0x5c3: 0x369d, 0x5c4: 0x3de0, - 0x5c6: 0x48d0, 0x5c7: 0x3df8, 0x5c8: 0x3601, 0x5c9: 0x438a, 0x5ca: 0x360d, 0x5cb: 0x4390, - 0x5cc: 0x3619, 0x5cd: 0x3b8f, 0x5ce: 0x3b96, 0x5cf: 0x3b9d, 0x5d0: 0x36b5, 0x5d1: 0x36af, - 0x5d2: 0x3e00, 0x5d3: 0x457a, 0x5d6: 0x36bb, 0x5d7: 0x3e10, - 0x5d8: 0x3631, 0x5d9: 0x362b, 0x5da: 0x361f, 0x5db: 0x4396, 0x5dd: 0x3ba4, - 0x5de: 0x3bab, 0x5df: 0x3bb2, 0x5e0: 0x36eb, 0x5e1: 0x36e5, 0x5e2: 0x3e68, 0x5e3: 0x4582, - 0x5e4: 0x36cd, 0x5e5: 0x36d3, 0x5e6: 0x36f1, 0x5e7: 0x3e78, 0x5e8: 0x3661, 0x5e9: 0x365b, - 0x5ea: 0x364f, 0x5eb: 0x43a2, 0x5ec: 0x3649, 0x5ed: 0x359b, 0x5ee: 0x437e, 0x5ef: 0x0081, - 0x5f2: 0x3eb0, 0x5f3: 0x36f7, 0x5f4: 0x3eb8, - 0x5f6: 0x491e, 0x5f7: 0x3ed0, 0x5f8: 0x363d, 0x5f9: 0x439c, 0x5fa: 0x366d, 0x5fb: 0x43ae, - 0x5fc: 0x3679, 0x5fd: 0x4256, 0x5fe: 0xa100, - // Block 0x18, offset 0x600 - 0x601: 0x3c06, 0x603: 0xa000, 0x604: 0x3c0d, 0x605: 0xa000, - 0x607: 0x3c14, 0x608: 0xa000, 0x609: 0x3c1b, - 0x60d: 0xa000, - 0x620: 0x2f65, 0x621: 0xa000, 0x622: 0x3c29, - 0x624: 0xa000, 0x625: 0xa000, - 0x62d: 0x3c22, 0x62e: 0x2f60, 0x62f: 0x2f6a, - 0x630: 0x3c30, 0x631: 0x3c37, 0x632: 0xa000, 0x633: 0xa000, 0x634: 0x3c3e, 0x635: 0x3c45, - 0x636: 0xa000, 0x637: 0xa000, 0x638: 0x3c4c, 0x639: 0x3c53, 0x63a: 0xa000, 0x63b: 0xa000, - 0x63c: 0xa000, 0x63d: 0xa000, - // Block 0x19, offset 0x640 - 0x640: 0x3c5a, 0x641: 0x3c61, 0x642: 0xa000, 0x643: 0xa000, 0x644: 0x3c76, 0x645: 0x3c7d, - 0x646: 0xa000, 0x647: 0xa000, 0x648: 0x3c84, 0x649: 0x3c8b, - 0x651: 0xa000, - 0x652: 0xa000, - 0x662: 0xa000, - 0x668: 0xa000, 0x669: 0xa000, - 0x66b: 0xa000, 0x66c: 0x3ca0, 0x66d: 0x3ca7, 0x66e: 0x3cae, 0x66f: 0x3cb5, - 0x672: 0xa000, 0x673: 0xa000, 0x674: 0xa000, 0x675: 0xa000, - // Block 0x1a, offset 0x680 - 0x686: 0xa000, 0x68b: 0xa000, - 0x68c: 0x3f08, 0x68d: 0xa000, 0x68e: 0x3f10, 0x68f: 0xa000, 0x690: 0x3f18, 0x691: 0xa000, - 0x692: 0x3f20, 0x693: 0xa000, 0x694: 0x3f28, 0x695: 0xa000, 0x696: 0x3f30, 0x697: 0xa000, - 0x698: 0x3f38, 0x699: 0xa000, 0x69a: 0x3f40, 0x69b: 0xa000, 0x69c: 0x3f48, 0x69d: 0xa000, - 0x69e: 0x3f50, 0x69f: 0xa000, 0x6a0: 0x3f58, 0x6a1: 0xa000, 0x6a2: 0x3f60, - 0x6a4: 0xa000, 0x6a5: 0x3f68, 0x6a6: 0xa000, 0x6a7: 0x3f70, 0x6a8: 0xa000, 0x6a9: 0x3f78, - 0x6af: 0xa000, - 0x6b0: 0x3f80, 0x6b1: 0x3f88, 0x6b2: 0xa000, 0x6b3: 0x3f90, 0x6b4: 0x3f98, 0x6b5: 0xa000, - 0x6b6: 0x3fa0, 0x6b7: 0x3fa8, 0x6b8: 0xa000, 0x6b9: 0x3fb0, 0x6ba: 0x3fb8, 0x6bb: 0xa000, - 0x6bc: 0x3fc0, 0x6bd: 0x3fc8, - // Block 0x1b, offset 0x6c0 - 0x6d4: 0x3f00, - 0x6d9: 0x9903, 0x6da: 0x9903, 0x6db: 0x8100, 0x6dc: 0x8100, 0x6dd: 0xa000, - 0x6de: 0x3fd0, - 0x6e6: 0xa000, - 0x6eb: 0xa000, 0x6ec: 0x3fe0, 0x6ed: 0xa000, 0x6ee: 0x3fe8, 0x6ef: 0xa000, - 0x6f0: 0x3ff0, 0x6f1: 0xa000, 0x6f2: 0x3ff8, 0x6f3: 0xa000, 0x6f4: 0x4000, 0x6f5: 0xa000, - 0x6f6: 0x4008, 0x6f7: 0xa000, 0x6f8: 0x4010, 0x6f9: 0xa000, 0x6fa: 0x4018, 0x6fb: 0xa000, - 0x6fc: 0x4020, 0x6fd: 0xa000, 0x6fe: 0x4028, 0x6ff: 0xa000, - // Block 0x1c, offset 0x700 - 0x700: 0x4030, 0x701: 0xa000, 0x702: 0x4038, 0x704: 0xa000, 0x705: 0x4040, - 0x706: 0xa000, 0x707: 0x4048, 0x708: 0xa000, 0x709: 0x4050, - 0x70f: 0xa000, 0x710: 0x4058, 0x711: 0x4060, - 0x712: 0xa000, 0x713: 0x4068, 0x714: 0x4070, 0x715: 0xa000, 0x716: 0x4078, 0x717: 0x4080, - 0x718: 0xa000, 0x719: 0x4088, 0x71a: 0x4090, 0x71b: 0xa000, 0x71c: 0x4098, 0x71d: 0x40a0, - 0x72f: 0xa000, - 0x730: 0xa000, 0x731: 0xa000, 0x732: 0xa000, 0x734: 0x3fd8, - 0x737: 0x40a8, 0x738: 0x40b0, 0x739: 0x40b8, 0x73a: 0x40c0, - 0x73d: 0xa000, 0x73e: 0x40c8, - // Block 0x1d, offset 0x740 - 0x740: 0x1377, 0x741: 0x0cfb, 0x742: 0x13d3, 0x743: 0x139f, 0x744: 0x0e57, 0x745: 0x06eb, - 0x746: 0x08df, 0x747: 0x162b, 0x748: 0x162b, 0x749: 0x0a0b, 0x74a: 0x145f, 0x74b: 0x0943, - 0x74c: 0x0a07, 0x74d: 0x0bef, 0x74e: 0x0fcf, 0x74f: 0x115f, 0x750: 0x1297, 0x751: 0x12d3, - 0x752: 0x1307, 0x753: 0x141b, 0x754: 0x0d73, 0x755: 0x0dff, 0x756: 0x0eab, 0x757: 0x0f43, - 0x758: 0x125f, 0x759: 0x1447, 0x75a: 0x1573, 0x75b: 0x070f, 0x75c: 0x08b3, 0x75d: 0x0d87, - 0x75e: 0x0ecf, 0x75f: 0x1293, 0x760: 0x15c3, 0x761: 0x0ab3, 0x762: 0x0e77, 0x763: 0x1283, - 0x764: 0x1317, 0x765: 0x0c23, 0x766: 0x11bb, 0x767: 0x12df, 0x768: 0x0b1f, 0x769: 0x0d0f, - 0x76a: 0x0e17, 0x76b: 0x0f1b, 0x76c: 0x1427, 0x76d: 0x074f, 0x76e: 0x07e7, 0x76f: 0x0853, - 0x770: 0x0c8b, 0x771: 0x0d7f, 0x772: 0x0ecb, 0x773: 0x0fef, 0x774: 0x1177, 0x775: 0x128b, - 0x776: 0x12a3, 0x777: 0x13c7, 0x778: 0x14ef, 0x779: 0x15a3, 0x77a: 0x15bf, 0x77b: 0x102b, - 0x77c: 0x106b, 0x77d: 0x1123, 0x77e: 0x1243, 0x77f: 0x147b, - // Block 0x1e, offset 0x780 - 0x780: 0x15cb, 0x781: 0x134b, 0x782: 0x09c7, 0x783: 0x0b3b, 0x784: 0x10db, 0x785: 0x119b, - 0x786: 0x0eff, 0x787: 0x1033, 0x788: 0x1397, 0x789: 0x14e7, 0x78a: 0x09c3, 0x78b: 0x0a8f, - 0x78c: 0x0d77, 0x78d: 0x0e2b, 0x78e: 0x0e5f, 0x78f: 0x1113, 0x790: 0x113b, 0x791: 0x14a7, - 0x792: 0x084f, 0x793: 0x11a7, 0x794: 0x07f3, 0x795: 0x07ef, 0x796: 0x1097, 0x797: 0x1127, - 0x798: 0x125b, 0x799: 0x14af, 0x79a: 0x1367, 0x79b: 0x0c27, 0x79c: 0x0d73, 0x79d: 0x1357, - 0x79e: 0x06f7, 0x79f: 0x0a63, 0x7a0: 0x0b93, 0x7a1: 0x0f2f, 0x7a2: 0x0faf, 0x7a3: 0x0873, - 0x7a4: 0x103b, 0x7a5: 0x075f, 0x7a6: 0x0b77, 0x7a7: 0x06d7, 0x7a8: 0x0deb, 0x7a9: 0x0ca3, - 0x7aa: 0x110f, 0x7ab: 0x08c7, 0x7ac: 0x09b3, 0x7ad: 0x0ffb, 0x7ae: 0x1263, 0x7af: 0x133b, - 0x7b0: 0x0db7, 0x7b1: 0x13f7, 0x7b2: 0x0de3, 0x7b3: 0x0c37, 0x7b4: 0x121b, 0x7b5: 0x0c57, - 0x7b6: 0x0fab, 0x7b7: 0x072b, 0x7b8: 0x07a7, 0x7b9: 0x07eb, 0x7ba: 0x0d53, 0x7bb: 0x10fb, - 0x7bc: 0x11f3, 0x7bd: 0x1347, 0x7be: 0x145b, 0x7bf: 0x085b, - // Block 0x1f, offset 0x7c0 - 0x7c0: 0x090f, 0x7c1: 0x0a17, 0x7c2: 0x0b2f, 0x7c3: 0x0cbf, 0x7c4: 0x0e7b, 0x7c5: 0x103f, - 0x7c6: 0x1497, 0x7c7: 0x157b, 0x7c8: 0x15cf, 0x7c9: 0x15e7, 0x7ca: 0x0837, 0x7cb: 0x0cf3, - 0x7cc: 0x0da3, 0x7cd: 0x13eb, 0x7ce: 0x0afb, 0x7cf: 0x0bd7, 0x7d0: 0x0bf3, 0x7d1: 0x0c83, - 0x7d2: 0x0e6b, 0x7d3: 0x0eb7, 0x7d4: 0x0f67, 0x7d5: 0x108b, 0x7d6: 0x112f, 0x7d7: 0x1193, - 0x7d8: 0x13db, 0x7d9: 0x126b, 0x7da: 0x1403, 0x7db: 0x147f, 0x7dc: 0x080f, 0x7dd: 0x083b, - 0x7de: 0x0923, 0x7df: 0x0ea7, 0x7e0: 0x12f3, 0x7e1: 0x133b, 0x7e2: 0x0b1b, 0x7e3: 0x0b8b, - 0x7e4: 0x0c4f, 0x7e5: 0x0daf, 0x7e6: 0x10d7, 0x7e7: 0x0f23, 0x7e8: 0x073b, 0x7e9: 0x097f, - 0x7ea: 0x0a63, 0x7eb: 0x0ac7, 0x7ec: 0x0b97, 0x7ed: 0x0f3f, 0x7ee: 0x0f5b, 0x7ef: 0x116b, - 0x7f0: 0x118b, 0x7f1: 0x1463, 0x7f2: 0x14e3, 0x7f3: 0x14f3, 0x7f4: 0x152f, 0x7f5: 0x0753, - 0x7f6: 0x107f, 0x7f7: 0x144f, 0x7f8: 0x14cb, 0x7f9: 0x0baf, 0x7fa: 0x0717, 0x7fb: 0x0777, - 0x7fc: 0x0a67, 0x7fd: 0x0a87, 0x7fe: 0x0caf, 0x7ff: 0x0d73, - // Block 0x20, offset 0x800 - 0x800: 0x0ec3, 0x801: 0x0fcb, 0x802: 0x1277, 0x803: 0x1417, 0x804: 0x1623, 0x805: 0x0ce3, - 0x806: 0x14a3, 0x807: 0x0833, 0x808: 0x0d2f, 0x809: 0x0d3b, 0x80a: 0x0e0f, 0x80b: 0x0e47, - 0x80c: 0x0f4b, 0x80d: 0x0fa7, 0x80e: 0x1027, 0x80f: 0x110b, 0x810: 0x153b, 0x811: 0x07af, - 0x812: 0x0c03, 0x813: 0x14b3, 0x814: 0x0767, 0x815: 0x0aab, 0x816: 0x0e2f, 0x817: 0x13df, - 0x818: 0x0b67, 0x819: 0x0bb7, 0x81a: 0x0d43, 0x81b: 0x0f2f, 0x81c: 0x14bb, 0x81d: 0x0817, - 0x81e: 0x08ff, 0x81f: 0x0a97, 0x820: 0x0cd3, 0x821: 0x0d1f, 0x822: 0x0d5f, 0x823: 0x0df3, - 0x824: 0x0f47, 0x825: 0x0fbb, 0x826: 0x1157, 0x827: 0x12f7, 0x828: 0x1303, 0x829: 0x1457, - 0x82a: 0x14d7, 0x82b: 0x0883, 0x82c: 0x0e4b, 0x82d: 0x0903, 0x82e: 0x0ec7, 0x82f: 0x0f6b, - 0x830: 0x1287, 0x831: 0x14bf, 0x832: 0x15ab, 0x833: 0x15d3, 0x834: 0x0d37, 0x835: 0x0e27, - 0x836: 0x11c3, 0x837: 0x10b7, 0x838: 0x10c3, 0x839: 0x10e7, 0x83a: 0x0f17, 0x83b: 0x0e9f, - 0x83c: 0x1363, 0x83d: 0x0733, 0x83e: 0x122b, 0x83f: 0x081b, - // Block 0x21, offset 0x840 - 0x840: 0x080b, 0x841: 0x0b0b, 0x842: 0x0c2b, 0x843: 0x10f3, 0x844: 0x0a53, 0x845: 0x0e03, - 0x846: 0x0cef, 0x847: 0x13e7, 0x848: 0x12e7, 0x849: 0x14ab, 0x84a: 0x1323, 0x84b: 0x0b27, - 0x84c: 0x0787, 0x84d: 0x095b, 0x850: 0x09af, - 0x852: 0x0cdf, 0x855: 0x07f7, 0x856: 0x0f1f, 0x857: 0x0fe3, - 0x858: 0x1047, 0x859: 0x1063, 0x85a: 0x1067, 0x85b: 0x107b, 0x85c: 0x14fb, 0x85d: 0x10eb, - 0x85e: 0x116f, 0x860: 0x128f, 0x862: 0x1353, - 0x865: 0x1407, 0x866: 0x1433, - 0x86a: 0x154f, 0x86b: 0x1553, 0x86c: 0x1557, 0x86d: 0x15bb, 0x86e: 0x142b, 0x86f: 0x14c7, - 0x870: 0x0757, 0x871: 0x077b, 0x872: 0x078f, 0x873: 0x084b, 0x874: 0x0857, 0x875: 0x0897, - 0x876: 0x094b, 0x877: 0x0967, 0x878: 0x096f, 0x879: 0x09ab, 0x87a: 0x09b7, 0x87b: 0x0a93, - 0x87c: 0x0a9b, 0x87d: 0x0ba3, 0x87e: 0x0bcb, 0x87f: 0x0bd3, - // Block 0x22, offset 0x880 - 0x880: 0x0beb, 0x881: 0x0c97, 0x882: 0x0cc7, 0x883: 0x0ce7, 0x884: 0x0d57, 0x885: 0x0e1b, - 0x886: 0x0e37, 0x887: 0x0e67, 0x888: 0x0ebb, 0x889: 0x0edb, 0x88a: 0x0f4f, 0x88b: 0x102f, - 0x88c: 0x104b, 0x88d: 0x1053, 0x88e: 0x104f, 0x88f: 0x1057, 0x890: 0x105b, 0x891: 0x105f, - 0x892: 0x1073, 0x893: 0x1077, 0x894: 0x109b, 0x895: 0x10af, 0x896: 0x10cb, 0x897: 0x112f, - 0x898: 0x1137, 0x899: 0x113f, 0x89a: 0x1153, 0x89b: 0x117b, 0x89c: 0x11cb, 0x89d: 0x11ff, - 0x89e: 0x11ff, 0x89f: 0x1267, 0x8a0: 0x130f, 0x8a1: 0x1327, 0x8a2: 0x135b, 0x8a3: 0x135f, - 0x8a4: 0x13a3, 0x8a5: 0x13a7, 0x8a6: 0x13ff, 0x8a7: 0x1407, 0x8a8: 0x14db, 0x8a9: 0x151f, - 0x8aa: 0x1537, 0x8ab: 0x0b9b, 0x8ac: 0x171e, 0x8ad: 0x11e3, - 0x8b0: 0x06df, 0x8b1: 0x07e3, 0x8b2: 0x07a3, 0x8b3: 0x074b, 0x8b4: 0x078b, 0x8b5: 0x07b7, - 0x8b6: 0x0847, 0x8b7: 0x0863, 0x8b8: 0x094b, 0x8b9: 0x0937, 0x8ba: 0x0947, 0x8bb: 0x0963, - 0x8bc: 0x09af, 0x8bd: 0x09bf, 0x8be: 0x0a03, 0x8bf: 0x0a0f, - // Block 0x23, offset 0x8c0 - 0x8c0: 0x0a2b, 0x8c1: 0x0a3b, 0x8c2: 0x0b23, 0x8c3: 0x0b2b, 0x8c4: 0x0b5b, 0x8c5: 0x0b7b, - 0x8c6: 0x0bab, 0x8c7: 0x0bc3, 0x8c8: 0x0bb3, 0x8c9: 0x0bd3, 0x8ca: 0x0bc7, 0x8cb: 0x0beb, - 0x8cc: 0x0c07, 0x8cd: 0x0c5f, 0x8ce: 0x0c6b, 0x8cf: 0x0c73, 0x8d0: 0x0c9b, 0x8d1: 0x0cdf, - 0x8d2: 0x0d0f, 0x8d3: 0x0d13, 0x8d4: 0x0d27, 0x8d5: 0x0da7, 0x8d6: 0x0db7, 0x8d7: 0x0e0f, - 0x8d8: 0x0e5b, 0x8d9: 0x0e53, 0x8da: 0x0e67, 0x8db: 0x0e83, 0x8dc: 0x0ebb, 0x8dd: 0x1013, - 0x8de: 0x0edf, 0x8df: 0x0f13, 0x8e0: 0x0f1f, 0x8e1: 0x0f5f, 0x8e2: 0x0f7b, 0x8e3: 0x0f9f, - 0x8e4: 0x0fc3, 0x8e5: 0x0fc7, 0x8e6: 0x0fe3, 0x8e7: 0x0fe7, 0x8e8: 0x0ff7, 0x8e9: 0x100b, - 0x8ea: 0x1007, 0x8eb: 0x1037, 0x8ec: 0x10b3, 0x8ed: 0x10cb, 0x8ee: 0x10e3, 0x8ef: 0x111b, - 0x8f0: 0x112f, 0x8f1: 0x114b, 0x8f2: 0x117b, 0x8f3: 0x122f, 0x8f4: 0x1257, 0x8f5: 0x12cb, - 0x8f6: 0x1313, 0x8f7: 0x131f, 0x8f8: 0x1327, 0x8f9: 0x133f, 0x8fa: 0x1353, 0x8fb: 0x1343, - 0x8fc: 0x135b, 0x8fd: 0x1357, 0x8fe: 0x134f, 0x8ff: 0x135f, - // Block 0x24, offset 0x900 - 0x900: 0x136b, 0x901: 0x13a7, 0x902: 0x13e3, 0x903: 0x1413, 0x904: 0x144b, 0x905: 0x146b, - 0x906: 0x14b7, 0x907: 0x14db, 0x908: 0x14fb, 0x909: 0x150f, 0x90a: 0x151f, 0x90b: 0x152b, - 0x90c: 0x1537, 0x90d: 0x158b, 0x90e: 0x162b, 0x90f: 0x16b5, 0x910: 0x16b0, 0x911: 0x16e2, - 0x912: 0x0607, 0x913: 0x062f, 0x914: 0x0633, 0x915: 0x1764, 0x916: 0x1791, 0x917: 0x1809, - 0x918: 0x1617, 0x919: 0x1627, - // Block 0x25, offset 0x940 - 0x940: 0x06fb, 0x941: 0x06f3, 0x942: 0x0703, 0x943: 0x1647, 0x944: 0x0747, 0x945: 0x0757, - 0x946: 0x075b, 0x947: 0x0763, 0x948: 0x076b, 0x949: 0x076f, 0x94a: 0x077b, 0x94b: 0x0773, - 0x94c: 0x05b3, 0x94d: 0x165b, 0x94e: 0x078f, 0x94f: 0x0793, 0x950: 0x0797, 0x951: 0x07b3, - 0x952: 0x164c, 0x953: 0x05b7, 0x954: 0x079f, 0x955: 0x07bf, 0x956: 0x1656, 0x957: 0x07cf, - 0x958: 0x07d7, 0x959: 0x0737, 0x95a: 0x07df, 0x95b: 0x07e3, 0x95c: 0x1831, 0x95d: 0x07ff, - 0x95e: 0x0807, 0x95f: 0x05bf, 0x960: 0x081f, 0x961: 0x0823, 0x962: 0x082b, 0x963: 0x082f, - 0x964: 0x05c3, 0x965: 0x0847, 0x966: 0x084b, 0x967: 0x0857, 0x968: 0x0863, 0x969: 0x0867, - 0x96a: 0x086b, 0x96b: 0x0873, 0x96c: 0x0893, 0x96d: 0x0897, 0x96e: 0x089f, 0x96f: 0x08af, - 0x970: 0x08b7, 0x971: 0x08bb, 0x972: 0x08bb, 0x973: 0x08bb, 0x974: 0x166a, 0x975: 0x0e93, - 0x976: 0x08cf, 0x977: 0x08d7, 0x978: 0x166f, 0x979: 0x08e3, 0x97a: 0x08eb, 0x97b: 0x08f3, - 0x97c: 0x091b, 0x97d: 0x0907, 0x97e: 0x0913, 0x97f: 0x0917, - // Block 0x26, offset 0x980 - 0x980: 0x091f, 0x981: 0x0927, 0x982: 0x092b, 0x983: 0x0933, 0x984: 0x093b, 0x985: 0x093f, - 0x986: 0x093f, 0x987: 0x0947, 0x988: 0x094f, 0x989: 0x0953, 0x98a: 0x095f, 0x98b: 0x0983, - 0x98c: 0x0967, 0x98d: 0x0987, 0x98e: 0x096b, 0x98f: 0x0973, 0x990: 0x080b, 0x991: 0x09cf, - 0x992: 0x0997, 0x993: 0x099b, 0x994: 0x099f, 0x995: 0x0993, 0x996: 0x09a7, 0x997: 0x09a3, - 0x998: 0x09bb, 0x999: 0x1674, 0x99a: 0x09d7, 0x99b: 0x09db, 0x99c: 0x09e3, 0x99d: 0x09ef, - 0x99e: 0x09f7, 0x99f: 0x0a13, 0x9a0: 0x1679, 0x9a1: 0x167e, 0x9a2: 0x0a1f, 0x9a3: 0x0a23, - 0x9a4: 0x0a27, 0x9a5: 0x0a1b, 0x9a6: 0x0a2f, 0x9a7: 0x05c7, 0x9a8: 0x05cb, 0x9a9: 0x0a37, - 0x9aa: 0x0a3f, 0x9ab: 0x0a3f, 0x9ac: 0x1683, 0x9ad: 0x0a5b, 0x9ae: 0x0a5f, 0x9af: 0x0a63, - 0x9b0: 0x0a6b, 0x9b1: 0x1688, 0x9b2: 0x0a73, 0x9b3: 0x0a77, 0x9b4: 0x0b4f, 0x9b5: 0x0a7f, - 0x9b6: 0x05cf, 0x9b7: 0x0a8b, 0x9b8: 0x0a9b, 0x9b9: 0x0aa7, 0x9ba: 0x0aa3, 0x9bb: 0x1692, - 0x9bc: 0x0aaf, 0x9bd: 0x1697, 0x9be: 0x0abb, 0x9bf: 0x0ab7, - // Block 0x27, offset 0x9c0 - 0x9c0: 0x0abf, 0x9c1: 0x0acf, 0x9c2: 0x0ad3, 0x9c3: 0x05d3, 0x9c4: 0x0ae3, 0x9c5: 0x0aeb, - 0x9c6: 0x0aef, 0x9c7: 0x0af3, 0x9c8: 0x05d7, 0x9c9: 0x169c, 0x9ca: 0x05db, 0x9cb: 0x0b0f, - 0x9cc: 0x0b13, 0x9cd: 0x0b17, 0x9ce: 0x0b1f, 0x9cf: 0x1863, 0x9d0: 0x0b37, 0x9d1: 0x16a6, - 0x9d2: 0x16a6, 0x9d3: 0x11d7, 0x9d4: 0x0b47, 0x9d5: 0x0b47, 0x9d6: 0x05df, 0x9d7: 0x16c9, - 0x9d8: 0x179b, 0x9d9: 0x0b57, 0x9da: 0x0b5f, 0x9db: 0x05e3, 0x9dc: 0x0b73, 0x9dd: 0x0b83, - 0x9de: 0x0b87, 0x9df: 0x0b8f, 0x9e0: 0x0b9f, 0x9e1: 0x05eb, 0x9e2: 0x05e7, 0x9e3: 0x0ba3, - 0x9e4: 0x16ab, 0x9e5: 0x0ba7, 0x9e6: 0x0bbb, 0x9e7: 0x0bbf, 0x9e8: 0x0bc3, 0x9e9: 0x0bbf, - 0x9ea: 0x0bcf, 0x9eb: 0x0bd3, 0x9ec: 0x0be3, 0x9ed: 0x0bdb, 0x9ee: 0x0bdf, 0x9ef: 0x0be7, - 0x9f0: 0x0beb, 0x9f1: 0x0bef, 0x9f2: 0x0bfb, 0x9f3: 0x0bff, 0x9f4: 0x0c17, 0x9f5: 0x0c1f, - 0x9f6: 0x0c2f, 0x9f7: 0x0c43, 0x9f8: 0x16ba, 0x9f9: 0x0c3f, 0x9fa: 0x0c33, 0x9fb: 0x0c4b, - 0x9fc: 0x0c53, 0x9fd: 0x0c67, 0x9fe: 0x16bf, 0x9ff: 0x0c6f, - // Block 0x28, offset 0xa00 - 0xa00: 0x0c63, 0xa01: 0x0c5b, 0xa02: 0x05ef, 0xa03: 0x0c77, 0xa04: 0x0c7f, 0xa05: 0x0c87, - 0xa06: 0x0c7b, 0xa07: 0x05f3, 0xa08: 0x0c97, 0xa09: 0x0c9f, 0xa0a: 0x16c4, 0xa0b: 0x0ccb, - 0xa0c: 0x0cff, 0xa0d: 0x0cdb, 0xa0e: 0x05ff, 0xa0f: 0x0ce7, 0xa10: 0x05fb, 0xa11: 0x05f7, - 0xa12: 0x07c3, 0xa13: 0x07c7, 0xa14: 0x0d03, 0xa15: 0x0ceb, 0xa16: 0x11ab, 0xa17: 0x0663, - 0xa18: 0x0d0f, 0xa19: 0x0d13, 0xa1a: 0x0d17, 0xa1b: 0x0d2b, 0xa1c: 0x0d23, 0xa1d: 0x16dd, - 0xa1e: 0x0603, 0xa1f: 0x0d3f, 0xa20: 0x0d33, 0xa21: 0x0d4f, 0xa22: 0x0d57, 0xa23: 0x16e7, - 0xa24: 0x0d5b, 0xa25: 0x0d47, 0xa26: 0x0d63, 0xa27: 0x0607, 0xa28: 0x0d67, 0xa29: 0x0d6b, - 0xa2a: 0x0d6f, 0xa2b: 0x0d7b, 0xa2c: 0x16ec, 0xa2d: 0x0d83, 0xa2e: 0x060b, 0xa2f: 0x0d8f, - 0xa30: 0x16f1, 0xa31: 0x0d93, 0xa32: 0x060f, 0xa33: 0x0d9f, 0xa34: 0x0dab, 0xa35: 0x0db7, - 0xa36: 0x0dbb, 0xa37: 0x16f6, 0xa38: 0x168d, 0xa39: 0x16fb, 0xa3a: 0x0ddb, 0xa3b: 0x1700, - 0xa3c: 0x0de7, 0xa3d: 0x0def, 0xa3e: 0x0ddf, 0xa3f: 0x0dfb, - // Block 0x29, offset 0xa40 - 0xa40: 0x0e0b, 0xa41: 0x0e1b, 0xa42: 0x0e0f, 0xa43: 0x0e13, 0xa44: 0x0e1f, 0xa45: 0x0e23, - 0xa46: 0x1705, 0xa47: 0x0e07, 0xa48: 0x0e3b, 0xa49: 0x0e3f, 0xa4a: 0x0613, 0xa4b: 0x0e53, - 0xa4c: 0x0e4f, 0xa4d: 0x170a, 0xa4e: 0x0e33, 0xa4f: 0x0e6f, 0xa50: 0x170f, 0xa51: 0x1714, - 0xa52: 0x0e73, 0xa53: 0x0e87, 0xa54: 0x0e83, 0xa55: 0x0e7f, 0xa56: 0x0617, 0xa57: 0x0e8b, - 0xa58: 0x0e9b, 0xa59: 0x0e97, 0xa5a: 0x0ea3, 0xa5b: 0x1651, 0xa5c: 0x0eb3, 0xa5d: 0x1719, - 0xa5e: 0x0ebf, 0xa5f: 0x1723, 0xa60: 0x0ed3, 0xa61: 0x0edf, 0xa62: 0x0ef3, 0xa63: 0x1728, - 0xa64: 0x0f07, 0xa65: 0x0f0b, 0xa66: 0x172d, 0xa67: 0x1732, 0xa68: 0x0f27, 0xa69: 0x0f37, - 0xa6a: 0x061b, 0xa6b: 0x0f3b, 0xa6c: 0x061f, 0xa6d: 0x061f, 0xa6e: 0x0f53, 0xa6f: 0x0f57, - 0xa70: 0x0f5f, 0xa71: 0x0f63, 0xa72: 0x0f6f, 0xa73: 0x0623, 0xa74: 0x0f87, 0xa75: 0x1737, - 0xa76: 0x0fa3, 0xa77: 0x173c, 0xa78: 0x0faf, 0xa79: 0x16a1, 0xa7a: 0x0fbf, 0xa7b: 0x1741, - 0xa7c: 0x1746, 0xa7d: 0x174b, 0xa7e: 0x0627, 0xa7f: 0x062b, - // Block 0x2a, offset 0xa80 - 0xa80: 0x0ff7, 0xa81: 0x1755, 0xa82: 0x1750, 0xa83: 0x175a, 0xa84: 0x175f, 0xa85: 0x0fff, - 0xa86: 0x1003, 0xa87: 0x1003, 0xa88: 0x100b, 0xa89: 0x0633, 0xa8a: 0x100f, 0xa8b: 0x0637, - 0xa8c: 0x063b, 0xa8d: 0x1769, 0xa8e: 0x1023, 0xa8f: 0x102b, 0xa90: 0x1037, 0xa91: 0x063f, - 0xa92: 0x176e, 0xa93: 0x105b, 0xa94: 0x1773, 0xa95: 0x1778, 0xa96: 0x107b, 0xa97: 0x1093, - 0xa98: 0x0643, 0xa99: 0x109b, 0xa9a: 0x109f, 0xa9b: 0x10a3, 0xa9c: 0x177d, 0xa9d: 0x1782, - 0xa9e: 0x1782, 0xa9f: 0x10bb, 0xaa0: 0x0647, 0xaa1: 0x1787, 0xaa2: 0x10cf, 0xaa3: 0x10d3, - 0xaa4: 0x064b, 0xaa5: 0x178c, 0xaa6: 0x10ef, 0xaa7: 0x064f, 0xaa8: 0x10ff, 0xaa9: 0x10f7, - 0xaaa: 0x1107, 0xaab: 0x1796, 0xaac: 0x111f, 0xaad: 0x0653, 0xaae: 0x112b, 0xaaf: 0x1133, - 0xab0: 0x1143, 0xab1: 0x0657, 0xab2: 0x17a0, 0xab3: 0x17a5, 0xab4: 0x065b, 0xab5: 0x17aa, - 0xab6: 0x115b, 0xab7: 0x17af, 0xab8: 0x1167, 0xab9: 0x1173, 0xaba: 0x117b, 0xabb: 0x17b4, - 0xabc: 0x17b9, 0xabd: 0x118f, 0xabe: 0x17be, 0xabf: 0x1197, - // Block 0x2b, offset 0xac0 - 0xac0: 0x16ce, 0xac1: 0x065f, 0xac2: 0x11af, 0xac3: 0x11b3, 0xac4: 0x0667, 0xac5: 0x11b7, - 0xac6: 0x0a33, 0xac7: 0x17c3, 0xac8: 0x17c8, 0xac9: 0x16d3, 0xaca: 0x16d8, 0xacb: 0x11d7, - 0xacc: 0x11db, 0xacd: 0x13f3, 0xace: 0x066b, 0xacf: 0x1207, 0xad0: 0x1203, 0xad1: 0x120b, - 0xad2: 0x083f, 0xad3: 0x120f, 0xad4: 0x1213, 0xad5: 0x1217, 0xad6: 0x121f, 0xad7: 0x17cd, - 0xad8: 0x121b, 0xad9: 0x1223, 0xada: 0x1237, 0xadb: 0x123b, 0xadc: 0x1227, 0xadd: 0x123f, - 0xade: 0x1253, 0xadf: 0x1267, 0xae0: 0x1233, 0xae1: 0x1247, 0xae2: 0x124b, 0xae3: 0x124f, - 0xae4: 0x17d2, 0xae5: 0x17dc, 0xae6: 0x17d7, 0xae7: 0x066f, 0xae8: 0x126f, 0xae9: 0x1273, - 0xaea: 0x127b, 0xaeb: 0x17f0, 0xaec: 0x127f, 0xaed: 0x17e1, 0xaee: 0x0673, 0xaef: 0x0677, - 0xaf0: 0x17e6, 0xaf1: 0x17eb, 0xaf2: 0x067b, 0xaf3: 0x129f, 0xaf4: 0x12a3, 0xaf5: 0x12a7, - 0xaf6: 0x12ab, 0xaf7: 0x12b7, 0xaf8: 0x12b3, 0xaf9: 0x12bf, 0xafa: 0x12bb, 0xafb: 0x12cb, - 0xafc: 0x12c3, 0xafd: 0x12c7, 0xafe: 0x12cf, 0xaff: 0x067f, - // Block 0x2c, offset 0xb00 - 0xb00: 0x12d7, 0xb01: 0x12db, 0xb02: 0x0683, 0xb03: 0x12eb, 0xb04: 0x12ef, 0xb05: 0x17f5, - 0xb06: 0x12fb, 0xb07: 0x12ff, 0xb08: 0x0687, 0xb09: 0x130b, 0xb0a: 0x05bb, 0xb0b: 0x17fa, - 0xb0c: 0x17ff, 0xb0d: 0x068b, 0xb0e: 0x068f, 0xb0f: 0x1337, 0xb10: 0x134f, 0xb11: 0x136b, - 0xb12: 0x137b, 0xb13: 0x1804, 0xb14: 0x138f, 0xb15: 0x1393, 0xb16: 0x13ab, 0xb17: 0x13b7, - 0xb18: 0x180e, 0xb19: 0x1660, 0xb1a: 0x13c3, 0xb1b: 0x13bf, 0xb1c: 0x13cb, 0xb1d: 0x1665, - 0xb1e: 0x13d7, 0xb1f: 0x13e3, 0xb20: 0x1813, 0xb21: 0x1818, 0xb22: 0x1423, 0xb23: 0x142f, - 0xb24: 0x1437, 0xb25: 0x181d, 0xb26: 0x143b, 0xb27: 0x1467, 0xb28: 0x1473, 0xb29: 0x1477, - 0xb2a: 0x146f, 0xb2b: 0x1483, 0xb2c: 0x1487, 0xb2d: 0x1822, 0xb2e: 0x1493, 0xb2f: 0x0693, - 0xb30: 0x149b, 0xb31: 0x1827, 0xb32: 0x0697, 0xb33: 0x14d3, 0xb34: 0x0ac3, 0xb35: 0x14eb, - 0xb36: 0x182c, 0xb37: 0x1836, 0xb38: 0x069b, 0xb39: 0x069f, 0xb3a: 0x1513, 0xb3b: 0x183b, - 0xb3c: 0x06a3, 0xb3d: 0x1840, 0xb3e: 0x152b, 0xb3f: 0x152b, - // Block 0x2d, offset 0xb40 - 0xb40: 0x1533, 0xb41: 0x1845, 0xb42: 0x154b, 0xb43: 0x06a7, 0xb44: 0x155b, 0xb45: 0x1567, - 0xb46: 0x156f, 0xb47: 0x1577, 0xb48: 0x06ab, 0xb49: 0x184a, 0xb4a: 0x158b, 0xb4b: 0x15a7, - 0xb4c: 0x15b3, 0xb4d: 0x06af, 0xb4e: 0x06b3, 0xb4f: 0x15b7, 0xb50: 0x184f, 0xb51: 0x06b7, - 0xb52: 0x1854, 0xb53: 0x1859, 0xb54: 0x185e, 0xb55: 0x15db, 0xb56: 0x06bb, 0xb57: 0x15ef, - 0xb58: 0x15f7, 0xb59: 0x15fb, 0xb5a: 0x1603, 0xb5b: 0x160b, 0xb5c: 0x1613, 0xb5d: 0x1868, -} - -// nfcIndex: 22 blocks, 1408 entries, 1408 bytes -// Block 0 is the zero block. -var nfcIndex = [1408]uint8{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x2c, 0xc3: 0x01, 0xc4: 0x02, 0xc5: 0x03, 0xc6: 0x2d, 0xc7: 0x04, - 0xc8: 0x05, 0xca: 0x2e, 0xcb: 0x2f, 0xcc: 0x06, 0xcd: 0x07, 0xce: 0x08, 0xcf: 0x30, - 0xd0: 0x09, 0xd1: 0x31, 0xd2: 0x32, 0xd3: 0x0a, 0xd6: 0x0b, 0xd7: 0x33, - 0xd8: 0x34, 0xd9: 0x0c, 0xdb: 0x35, 0xdc: 0x36, 0xdd: 0x37, 0xdf: 0x38, - 0xe0: 0x02, 0xe1: 0x03, 0xe2: 0x04, 0xe3: 0x05, - 0xea: 0x06, 0xeb: 0x07, 0xec: 0x08, 0xed: 0x09, 0xef: 0x0a, - 0xf0: 0x13, - // Block 0x4, offset 0x100 - 0x120: 0x39, 0x121: 0x3a, 0x123: 0x3b, 0x124: 0x3c, 0x125: 0x3d, 0x126: 0x3e, 0x127: 0x3f, - 0x128: 0x40, 0x129: 0x41, 0x12a: 0x42, 0x12b: 0x43, 0x12c: 0x3e, 0x12d: 0x44, 0x12e: 0x45, 0x12f: 0x46, - 0x131: 0x47, 0x132: 0x48, 0x133: 0x49, 0x134: 0x4a, 0x135: 0x4b, 0x137: 0x4c, - 0x138: 0x4d, 0x139: 0x4e, 0x13a: 0x4f, 0x13b: 0x50, 0x13c: 0x51, 0x13d: 0x52, 0x13e: 0x53, 0x13f: 0x54, - // Block 0x5, offset 0x140 - 0x140: 0x55, 0x142: 0x56, 0x144: 0x57, 0x145: 0x58, 0x146: 0x59, 0x147: 0x5a, - 0x14d: 0x5b, - 0x15c: 0x5c, 0x15f: 0x5d, - 0x162: 0x5e, 0x164: 0x5f, - 0x168: 0x60, 0x169: 0x61, 0x16a: 0x62, 0x16c: 0x0d, 0x16d: 0x63, 0x16e: 0x64, 0x16f: 0x65, - 0x170: 0x66, 0x173: 0x67, 0x177: 0x68, - 0x178: 0x0e, 0x179: 0x0f, 0x17a: 0x10, 0x17b: 0x11, 0x17c: 0x12, 0x17d: 0x13, 0x17e: 0x14, 0x17f: 0x15, - // Block 0x6, offset 0x180 - 0x180: 0x69, 0x183: 0x6a, 0x184: 0x6b, 0x186: 0x6c, 0x187: 0x6d, - 0x188: 0x6e, 0x189: 0x16, 0x18a: 0x17, 0x18b: 0x6f, 0x18c: 0x70, - 0x1ab: 0x71, - 0x1b3: 0x72, 0x1b5: 0x73, 0x1b7: 0x74, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x75, 0x1c1: 0x18, 0x1c2: 0x19, 0x1c3: 0x1a, 0x1c4: 0x76, 0x1c5: 0x77, - 0x1c9: 0x78, 0x1cc: 0x79, 0x1cd: 0x7a, - // Block 0x8, offset 0x200 - 0x219: 0x7b, 0x21a: 0x7c, 0x21b: 0x7d, - 0x220: 0x7e, 0x223: 0x7f, 0x224: 0x80, 0x225: 0x81, 0x226: 0x82, 0x227: 0x83, - 0x22a: 0x84, 0x22b: 0x85, 0x22f: 0x86, - 0x230: 0x87, 0x231: 0x88, 0x232: 0x89, 0x233: 0x8a, 0x234: 0x8b, 0x235: 0x8c, 0x236: 0x8d, 0x237: 0x87, - 0x238: 0x88, 0x239: 0x89, 0x23a: 0x8a, 0x23b: 0x8b, 0x23c: 0x8c, 0x23d: 0x8d, 0x23e: 0x87, 0x23f: 0x88, - // Block 0x9, offset 0x240 - 0x240: 0x89, 0x241: 0x8a, 0x242: 0x8b, 0x243: 0x8c, 0x244: 0x8d, 0x245: 0x87, 0x246: 0x88, 0x247: 0x89, - 0x248: 0x8a, 0x249: 0x8b, 0x24a: 0x8c, 0x24b: 0x8d, 0x24c: 0x87, 0x24d: 0x88, 0x24e: 0x89, 0x24f: 0x8a, - 0x250: 0x8b, 0x251: 0x8c, 0x252: 0x8d, 0x253: 0x87, 0x254: 0x88, 0x255: 0x89, 0x256: 0x8a, 0x257: 0x8b, - 0x258: 0x8c, 0x259: 0x8d, 0x25a: 0x87, 0x25b: 0x88, 0x25c: 0x89, 0x25d: 0x8a, 0x25e: 0x8b, 0x25f: 0x8c, - 0x260: 0x8d, 0x261: 0x87, 0x262: 0x88, 0x263: 0x89, 0x264: 0x8a, 0x265: 0x8b, 0x266: 0x8c, 0x267: 0x8d, - 0x268: 0x87, 0x269: 0x88, 0x26a: 0x89, 0x26b: 0x8a, 0x26c: 0x8b, 0x26d: 0x8c, 0x26e: 0x8d, 0x26f: 0x87, - 0x270: 0x88, 0x271: 0x89, 0x272: 0x8a, 0x273: 0x8b, 0x274: 0x8c, 0x275: 0x8d, 0x276: 0x87, 0x277: 0x88, - 0x278: 0x89, 0x279: 0x8a, 0x27a: 0x8b, 0x27b: 0x8c, 0x27c: 0x8d, 0x27d: 0x87, 0x27e: 0x88, 0x27f: 0x89, - // Block 0xa, offset 0x280 - 0x280: 0x8a, 0x281: 0x8b, 0x282: 0x8c, 0x283: 0x8d, 0x284: 0x87, 0x285: 0x88, 0x286: 0x89, 0x287: 0x8a, - 0x288: 0x8b, 0x289: 0x8c, 0x28a: 0x8d, 0x28b: 0x87, 0x28c: 0x88, 0x28d: 0x89, 0x28e: 0x8a, 0x28f: 0x8b, - 0x290: 0x8c, 0x291: 0x8d, 0x292: 0x87, 0x293: 0x88, 0x294: 0x89, 0x295: 0x8a, 0x296: 0x8b, 0x297: 0x8c, - 0x298: 0x8d, 0x299: 0x87, 0x29a: 0x88, 0x29b: 0x89, 0x29c: 0x8a, 0x29d: 0x8b, 0x29e: 0x8c, 0x29f: 0x8d, - 0x2a0: 0x87, 0x2a1: 0x88, 0x2a2: 0x89, 0x2a3: 0x8a, 0x2a4: 0x8b, 0x2a5: 0x8c, 0x2a6: 0x8d, 0x2a7: 0x87, - 0x2a8: 0x88, 0x2a9: 0x89, 0x2aa: 0x8a, 0x2ab: 0x8b, 0x2ac: 0x8c, 0x2ad: 0x8d, 0x2ae: 0x87, 0x2af: 0x88, - 0x2b0: 0x89, 0x2b1: 0x8a, 0x2b2: 0x8b, 0x2b3: 0x8c, 0x2b4: 0x8d, 0x2b5: 0x87, 0x2b6: 0x88, 0x2b7: 0x89, - 0x2b8: 0x8a, 0x2b9: 0x8b, 0x2ba: 0x8c, 0x2bb: 0x8d, 0x2bc: 0x87, 0x2bd: 0x88, 0x2be: 0x89, 0x2bf: 0x8a, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x8b, 0x2c1: 0x8c, 0x2c2: 0x8d, 0x2c3: 0x87, 0x2c4: 0x88, 0x2c5: 0x89, 0x2c6: 0x8a, 0x2c7: 0x8b, - 0x2c8: 0x8c, 0x2c9: 0x8d, 0x2ca: 0x87, 0x2cb: 0x88, 0x2cc: 0x89, 0x2cd: 0x8a, 0x2ce: 0x8b, 0x2cf: 0x8c, - 0x2d0: 0x8d, 0x2d1: 0x87, 0x2d2: 0x88, 0x2d3: 0x89, 0x2d4: 0x8a, 0x2d5: 0x8b, 0x2d6: 0x8c, 0x2d7: 0x8d, - 0x2d8: 0x87, 0x2d9: 0x88, 0x2da: 0x89, 0x2db: 0x8a, 0x2dc: 0x8b, 0x2dd: 0x8c, 0x2de: 0x8e, - // Block 0xc, offset 0x300 - 0x324: 0x1b, 0x325: 0x1c, 0x326: 0x1d, 0x327: 0x1e, - 0x328: 0x1f, 0x329: 0x20, 0x32a: 0x21, 0x32b: 0x22, 0x32c: 0x8f, 0x32d: 0x90, 0x32e: 0x91, - 0x331: 0x92, 0x332: 0x93, 0x333: 0x94, 0x334: 0x95, - 0x338: 0x96, 0x339: 0x97, 0x33a: 0x98, 0x33b: 0x99, 0x33e: 0x9a, 0x33f: 0x9b, - // Block 0xd, offset 0x340 - 0x347: 0x9c, - 0x34b: 0x9d, 0x34d: 0x9e, - 0x368: 0x9f, 0x36b: 0xa0, - // Block 0xe, offset 0x380 - 0x381: 0xa1, 0x382: 0xa2, 0x384: 0xa3, 0x385: 0x82, 0x387: 0xa4, - 0x388: 0xa5, 0x38b: 0xa6, 0x38c: 0x3e, 0x38d: 0xa7, - 0x391: 0xa8, 0x392: 0xa9, 0x393: 0xaa, 0x396: 0xab, 0x397: 0xac, - 0x398: 0x73, 0x39a: 0xad, 0x39c: 0xae, - 0x3b0: 0x73, - // Block 0xf, offset 0x3c0 - 0x3eb: 0xaf, 0x3ec: 0xb0, - // Block 0x10, offset 0x400 - 0x432: 0xb1, - // Block 0x11, offset 0x440 - 0x445: 0xb2, 0x446: 0xb3, 0x447: 0xb4, - 0x449: 0xb5, - // Block 0x12, offset 0x480 - 0x480: 0xb6, - 0x4a3: 0xb7, 0x4a5: 0xb8, - // Block 0x13, offset 0x4c0 - 0x4c8: 0xb9, - // Block 0x14, offset 0x500 - 0x520: 0x23, 0x521: 0x24, 0x522: 0x25, 0x523: 0x26, 0x524: 0x27, 0x525: 0x28, 0x526: 0x29, 0x527: 0x2a, - 0x528: 0x2b, - // Block 0x15, offset 0x540 - 0x550: 0x0b, 0x551: 0x0c, 0x556: 0x0d, - 0x55b: 0x0e, 0x55d: 0x0f, 0x55e: 0x10, 0x55f: 0x11, - 0x56f: 0x12, -} - -// nfcSparseOffset: 142 entries, 284 bytes -var nfcSparseOffset = []uint16{0x0, 0x5, 0x9, 0xb, 0xd, 0x18, 0x28, 0x2a, 0x2f, 0x3a, 0x49, 0x56, 0x5e, 0x62, 0x67, 0x69, 0x7a, 0x82, 0x89, 0x8c, 0x93, 0x97, 0x9b, 0x9d, 0x9f, 0xa8, 0xac, 0xb3, 0xb8, 0xbb, 0xc5, 0xc7, 0xce, 0xd6, 0xd9, 0xdb, 0xdd, 0xdf, 0xe4, 0xf5, 0x101, 0x103, 0x109, 0x10b, 0x10d, 0x10f, 0x111, 0x113, 0x115, 0x118, 0x11b, 0x11d, 0x120, 0x123, 0x127, 0x12c, 0x135, 0x137, 0x13a, 0x13c, 0x147, 0x157, 0x15b, 0x169, 0x16c, 0x172, 0x178, 0x183, 0x187, 0x189, 0x18b, 0x18d, 0x18f, 0x191, 0x197, 0x19b, 0x19d, 0x19f, 0x1a7, 0x1ab, 0x1ae, 0x1b0, 0x1b2, 0x1b4, 0x1b7, 0x1b9, 0x1bb, 0x1bd, 0x1bf, 0x1c5, 0x1c8, 0x1ca, 0x1d1, 0x1d7, 0x1dd, 0x1e5, 0x1eb, 0x1f1, 0x1f7, 0x1fb, 0x209, 0x212, 0x215, 0x218, 0x21a, 0x21d, 0x21f, 0x223, 0x228, 0x22a, 0x22c, 0x231, 0x237, 0x239, 0x23b, 0x23d, 0x243, 0x246, 0x249, 0x251, 0x258, 0x25b, 0x25e, 0x260, 0x268, 0x26b, 0x272, 0x275, 0x27b, 0x27d, 0x280, 0x282, 0x284, 0x286, 0x288, 0x295, 0x29f, 0x2a1, 0x2a3, 0x2a9, 0x2ab, 0x2ae} - -// nfcSparseValues: 688 entries, 2752 bytes -var nfcSparseValues = [688]valueRange{ - // Block 0x0, offset 0x0 - {value: 0x0000, lo: 0x04}, - {value: 0xa100, lo: 0xa8, hi: 0xa8}, - {value: 0x8100, lo: 0xaf, hi: 0xaf}, - {value: 0x8100, lo: 0xb4, hi: 0xb4}, - {value: 0x8100, lo: 0xb8, hi: 0xb8}, - // Block 0x1, offset 0x5 - {value: 0x0091, lo: 0x03}, - {value: 0x4778, lo: 0xa0, hi: 0xa1}, - {value: 0x47aa, lo: 0xaf, hi: 0xb0}, - {value: 0xa000, lo: 0xb7, hi: 0xb7}, - // Block 0x2, offset 0x9 - {value: 0x0000, lo: 0x01}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - // Block 0x3, offset 0xb - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0x98, hi: 0x9d}, - // Block 0x4, offset 0xd - {value: 0x0006, lo: 0x0a}, - {value: 0xa000, lo: 0x81, hi: 0x81}, - {value: 0xa000, lo: 0x85, hi: 0x85}, - {value: 0xa000, lo: 0x89, hi: 0x89}, - {value: 0x48d6, lo: 0x8a, hi: 0x8a}, - {value: 0x48f4, lo: 0x8b, hi: 0x8b}, - {value: 0x36c7, lo: 0x8c, hi: 0x8c}, - {value: 0x36df, lo: 0x8d, hi: 0x8d}, - {value: 0x490c, lo: 0x8e, hi: 0x8e}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x36fd, lo: 0x93, hi: 0x94}, - // Block 0x5, offset 0x18 - {value: 0x0000, lo: 0x0f}, - {value: 0xa000, lo: 0x83, hi: 0x83}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0xa000, lo: 0x8b, hi: 0x8b}, - {value: 0xa000, lo: 0x8d, hi: 0x8d}, - {value: 0x37a5, lo: 0x90, hi: 0x90}, - {value: 0x37b1, lo: 0x91, hi: 0x91}, - {value: 0x379f, lo: 0x93, hi: 0x93}, - {value: 0xa000, lo: 0x96, hi: 0x96}, - {value: 0x3817, lo: 0x97, hi: 0x97}, - {value: 0x37e1, lo: 0x9c, hi: 0x9c}, - {value: 0x37c9, lo: 0x9d, hi: 0x9d}, - {value: 0x37f3, lo: 0x9e, hi: 0x9e}, - {value: 0xa000, lo: 0xb4, hi: 0xb5}, - {value: 0x381d, lo: 0xb6, hi: 0xb6}, - {value: 0x3823, lo: 0xb7, hi: 0xb7}, - // Block 0x6, offset 0x28 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x83, hi: 0x87}, - // Block 0x7, offset 0x2a - {value: 0x0001, lo: 0x04}, - {value: 0x8113, lo: 0x81, hi: 0x82}, - {value: 0x8132, lo: 0x84, hi: 0x84}, - {value: 0x812d, lo: 0x85, hi: 0x85}, - {value: 0x810d, lo: 0x87, hi: 0x87}, - // Block 0x8, offset 0x2f - {value: 0x0000, lo: 0x0a}, - {value: 0x8132, lo: 0x90, hi: 0x97}, - {value: 0x8119, lo: 0x98, hi: 0x98}, - {value: 0x811a, lo: 0x99, hi: 0x99}, - {value: 0x811b, lo: 0x9a, hi: 0x9a}, - {value: 0x3841, lo: 0xa2, hi: 0xa2}, - {value: 0x3847, lo: 0xa3, hi: 0xa3}, - {value: 0x3853, lo: 0xa4, hi: 0xa4}, - {value: 0x384d, lo: 0xa5, hi: 0xa5}, - {value: 0x3859, lo: 0xa6, hi: 0xa6}, - {value: 0xa000, lo: 0xa7, hi: 0xa7}, - // Block 0x9, offset 0x3a - {value: 0x0000, lo: 0x0e}, - {value: 0x386b, lo: 0x80, hi: 0x80}, - {value: 0xa000, lo: 0x81, hi: 0x81}, - {value: 0x385f, lo: 0x82, hi: 0x82}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x3865, lo: 0x93, hi: 0x93}, - {value: 0xa000, lo: 0x95, hi: 0x95}, - {value: 0x8132, lo: 0x96, hi: 0x9c}, - {value: 0x8132, lo: 0x9f, hi: 0xa2}, - {value: 0x812d, lo: 0xa3, hi: 0xa3}, - {value: 0x8132, lo: 0xa4, hi: 0xa4}, - {value: 0x8132, lo: 0xa7, hi: 0xa8}, - {value: 0x812d, lo: 0xaa, hi: 0xaa}, - {value: 0x8132, lo: 0xab, hi: 0xac}, - {value: 0x812d, lo: 0xad, hi: 0xad}, - // Block 0xa, offset 0x49 - {value: 0x0000, lo: 0x0c}, - {value: 0x811f, lo: 0x91, hi: 0x91}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - {value: 0x812d, lo: 0xb1, hi: 0xb1}, - {value: 0x8132, lo: 0xb2, hi: 0xb3}, - {value: 0x812d, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb5, hi: 0xb6}, - {value: 0x812d, lo: 0xb7, hi: 0xb9}, - {value: 0x8132, lo: 0xba, hi: 0xba}, - {value: 0x812d, lo: 0xbb, hi: 0xbc}, - {value: 0x8132, lo: 0xbd, hi: 0xbd}, - {value: 0x812d, lo: 0xbe, hi: 0xbe}, - {value: 0x8132, lo: 0xbf, hi: 0xbf}, - // Block 0xb, offset 0x56 - {value: 0x0005, lo: 0x07}, - {value: 0x8132, lo: 0x80, hi: 0x80}, - {value: 0x8132, lo: 0x81, hi: 0x81}, - {value: 0x812d, lo: 0x82, hi: 0x83}, - {value: 0x812d, lo: 0x84, hi: 0x85}, - {value: 0x812d, lo: 0x86, hi: 0x87}, - {value: 0x812d, lo: 0x88, hi: 0x89}, - {value: 0x8132, lo: 0x8a, hi: 0x8a}, - // Block 0xc, offset 0x5e - {value: 0x0000, lo: 0x03}, - {value: 0x8132, lo: 0xab, hi: 0xb1}, - {value: 0x812d, lo: 0xb2, hi: 0xb2}, - {value: 0x8132, lo: 0xb3, hi: 0xb3}, - // Block 0xd, offset 0x62 - {value: 0x0000, lo: 0x04}, - {value: 0x8132, lo: 0x96, hi: 0x99}, - {value: 0x8132, lo: 0x9b, hi: 0xa3}, - {value: 0x8132, lo: 0xa5, hi: 0xa7}, - {value: 0x8132, lo: 0xa9, hi: 0xad}, - // Block 0xe, offset 0x67 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x99, hi: 0x9b}, - // Block 0xf, offset 0x69 - {value: 0x0000, lo: 0x10}, - {value: 0x8132, lo: 0x94, hi: 0xa1}, - {value: 0x812d, lo: 0xa3, hi: 0xa3}, - {value: 0x8132, lo: 0xa4, hi: 0xa5}, - {value: 0x812d, lo: 0xa6, hi: 0xa6}, - {value: 0x8132, lo: 0xa7, hi: 0xa8}, - {value: 0x812d, lo: 0xa9, hi: 0xa9}, - {value: 0x8132, lo: 0xaa, hi: 0xac}, - {value: 0x812d, lo: 0xad, hi: 0xaf}, - {value: 0x8116, lo: 0xb0, hi: 0xb0}, - {value: 0x8117, lo: 0xb1, hi: 0xb1}, - {value: 0x8118, lo: 0xb2, hi: 0xb2}, - {value: 0x8132, lo: 0xb3, hi: 0xb5}, - {value: 0x812d, lo: 0xb6, hi: 0xb6}, - {value: 0x8132, lo: 0xb7, hi: 0xb8}, - {value: 0x812d, lo: 0xb9, hi: 0xba}, - {value: 0x8132, lo: 0xbb, hi: 0xbf}, - // Block 0x10, offset 0x7a - {value: 0x0000, lo: 0x07}, - {value: 0xa000, lo: 0xa8, hi: 0xa8}, - {value: 0x3ed8, lo: 0xa9, hi: 0xa9}, - {value: 0xa000, lo: 0xb0, hi: 0xb0}, - {value: 0x3ee0, lo: 0xb1, hi: 0xb1}, - {value: 0xa000, lo: 0xb3, hi: 0xb3}, - {value: 0x3ee8, lo: 0xb4, hi: 0xb4}, - {value: 0x9902, lo: 0xbc, hi: 0xbc}, - // Block 0x11, offset 0x82 - {value: 0x0008, lo: 0x06}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x8132, lo: 0x91, hi: 0x91}, - {value: 0x812d, lo: 0x92, hi: 0x92}, - {value: 0x8132, lo: 0x93, hi: 0x93}, - {value: 0x8132, lo: 0x94, hi: 0x94}, - {value: 0x45b2, lo: 0x98, hi: 0x9f}, - // Block 0x12, offset 0x89 - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x13, offset 0x8c - {value: 0x0008, lo: 0x06}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2c9e, lo: 0x8b, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - {value: 0x45f2, lo: 0x9c, hi: 0x9d}, - {value: 0x4602, lo: 0x9f, hi: 0x9f}, - // Block 0x14, offset 0x93 - {value: 0x0000, lo: 0x03}, - {value: 0x462a, lo: 0xb3, hi: 0xb3}, - {value: 0x4632, lo: 0xb6, hi: 0xb6}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - // Block 0x15, offset 0x97 - {value: 0x0008, lo: 0x03}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x460a, lo: 0x99, hi: 0x9b}, - {value: 0x4622, lo: 0x9e, hi: 0x9e}, - // Block 0x16, offset 0x9b - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - // Block 0x17, offset 0x9d - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - // Block 0x18, offset 0x9f - {value: 0x0000, lo: 0x08}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2cb6, lo: 0x88, hi: 0x88}, - {value: 0x2cae, lo: 0x8b, hi: 0x8b}, - {value: 0x2cbe, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x96, hi: 0x97}, - {value: 0x463a, lo: 0x9c, hi: 0x9c}, - {value: 0x4642, lo: 0x9d, hi: 0x9d}, - // Block 0x19, offset 0xa8 - {value: 0x0000, lo: 0x03}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x2cc6, lo: 0x94, hi: 0x94}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x1a, offset 0xac - {value: 0x0000, lo: 0x06}, - {value: 0xa000, lo: 0x86, hi: 0x87}, - {value: 0x2cce, lo: 0x8a, hi: 0x8a}, - {value: 0x2cde, lo: 0x8b, hi: 0x8b}, - {value: 0x2cd6, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - // Block 0x1b, offset 0xb3 - {value: 0x1801, lo: 0x04}, - {value: 0xa000, lo: 0x86, hi: 0x86}, - {value: 0x3ef0, lo: 0x88, hi: 0x88}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x8120, lo: 0x95, hi: 0x96}, - // Block 0x1c, offset 0xb8 - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - {value: 0xa000, lo: 0xbf, hi: 0xbf}, - // Block 0x1d, offset 0xbb - {value: 0x0000, lo: 0x09}, - {value: 0x2ce6, lo: 0x80, hi: 0x80}, - {value: 0x9900, lo: 0x82, hi: 0x82}, - {value: 0xa000, lo: 0x86, hi: 0x86}, - {value: 0x2cee, lo: 0x87, hi: 0x87}, - {value: 0x2cf6, lo: 0x88, hi: 0x88}, - {value: 0x2f50, lo: 0x8a, hi: 0x8a}, - {value: 0x2dd8, lo: 0x8b, hi: 0x8b}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x95, hi: 0x96}, - // Block 0x1e, offset 0xc5 - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x1f, offset 0xc7 - {value: 0x0000, lo: 0x06}, - {value: 0xa000, lo: 0x86, hi: 0x87}, - {value: 0x2cfe, lo: 0x8a, hi: 0x8a}, - {value: 0x2d0e, lo: 0x8b, hi: 0x8b}, - {value: 0x2d06, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - // Block 0x20, offset 0xce - {value: 0x6bea, lo: 0x07}, - {value: 0x9904, lo: 0x8a, hi: 0x8a}, - {value: 0x9900, lo: 0x8f, hi: 0x8f}, - {value: 0xa000, lo: 0x99, hi: 0x99}, - {value: 0x3ef8, lo: 0x9a, hi: 0x9a}, - {value: 0x2f58, lo: 0x9c, hi: 0x9c}, - {value: 0x2de3, lo: 0x9d, hi: 0x9d}, - {value: 0x2d16, lo: 0x9e, hi: 0x9f}, - // Block 0x21, offset 0xd6 - {value: 0x0000, lo: 0x02}, - {value: 0x8122, lo: 0xb8, hi: 0xb9}, - {value: 0x8104, lo: 0xba, hi: 0xba}, - // Block 0x22, offset 0xd9 - {value: 0x0000, lo: 0x01}, - {value: 0x8123, lo: 0x88, hi: 0x8b}, - // Block 0x23, offset 0xdb - {value: 0x0000, lo: 0x01}, - {value: 0x8124, lo: 0xb8, hi: 0xb9}, - // Block 0x24, offset 0xdd - {value: 0x0000, lo: 0x01}, - {value: 0x8125, lo: 0x88, hi: 0x8b}, - // Block 0x25, offset 0xdf - {value: 0x0000, lo: 0x04}, - {value: 0x812d, lo: 0x98, hi: 0x99}, - {value: 0x812d, lo: 0xb5, hi: 0xb5}, - {value: 0x812d, lo: 0xb7, hi: 0xb7}, - {value: 0x812b, lo: 0xb9, hi: 0xb9}, - // Block 0x26, offset 0xe4 - {value: 0x0000, lo: 0x10}, - {value: 0x2644, lo: 0x83, hi: 0x83}, - {value: 0x264b, lo: 0x8d, hi: 0x8d}, - {value: 0x2652, lo: 0x92, hi: 0x92}, - {value: 0x2659, lo: 0x97, hi: 0x97}, - {value: 0x2660, lo: 0x9c, hi: 0x9c}, - {value: 0x263d, lo: 0xa9, hi: 0xa9}, - {value: 0x8126, lo: 0xb1, hi: 0xb1}, - {value: 0x8127, lo: 0xb2, hi: 0xb2}, - {value: 0x4a66, lo: 0xb3, hi: 0xb3}, - {value: 0x8128, lo: 0xb4, hi: 0xb4}, - {value: 0x4a6f, lo: 0xb5, hi: 0xb5}, - {value: 0x464a, lo: 0xb6, hi: 0xb6}, - {value: 0x8200, lo: 0xb7, hi: 0xb7}, - {value: 0x4652, lo: 0xb8, hi: 0xb8}, - {value: 0x8200, lo: 0xb9, hi: 0xb9}, - {value: 0x8127, lo: 0xba, hi: 0xbd}, - // Block 0x27, offset 0xf5 - {value: 0x0000, lo: 0x0b}, - {value: 0x8127, lo: 0x80, hi: 0x80}, - {value: 0x4a78, lo: 0x81, hi: 0x81}, - {value: 0x8132, lo: 0x82, hi: 0x83}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0x86, hi: 0x87}, - {value: 0x266e, lo: 0x93, hi: 0x93}, - {value: 0x2675, lo: 0x9d, hi: 0x9d}, - {value: 0x267c, lo: 0xa2, hi: 0xa2}, - {value: 0x2683, lo: 0xa7, hi: 0xa7}, - {value: 0x268a, lo: 0xac, hi: 0xac}, - {value: 0x2667, lo: 0xb9, hi: 0xb9}, - // Block 0x28, offset 0x101 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x86, hi: 0x86}, - // Block 0x29, offset 0x103 - {value: 0x0000, lo: 0x05}, - {value: 0xa000, lo: 0xa5, hi: 0xa5}, - {value: 0x2d1e, lo: 0xa6, hi: 0xa6}, - {value: 0x9900, lo: 0xae, hi: 0xae}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - {value: 0x8104, lo: 0xb9, hi: 0xba}, - // Block 0x2a, offset 0x109 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x8d, hi: 0x8d}, - // Block 0x2b, offset 0x10b - {value: 0x0000, lo: 0x01}, - {value: 0xa000, lo: 0x80, hi: 0x92}, - // Block 0x2c, offset 0x10d - {value: 0x0000, lo: 0x01}, - {value: 0xb900, lo: 0xa1, hi: 0xb5}, - // Block 0x2d, offset 0x10f - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0xa8, hi: 0xbf}, - // Block 0x2e, offset 0x111 - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0x80, hi: 0x82}, - // Block 0x2f, offset 0x113 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x9d, hi: 0x9f}, - // Block 0x30, offset 0x115 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x94, hi: 0x94}, - {value: 0x8104, lo: 0xb4, hi: 0xb4}, - // Block 0x31, offset 0x118 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x92, hi: 0x92}, - {value: 0x8132, lo: 0x9d, hi: 0x9d}, - // Block 0x32, offset 0x11b - {value: 0x0000, lo: 0x01}, - {value: 0x8131, lo: 0xa9, hi: 0xa9}, - // Block 0x33, offset 0x11d - {value: 0x0004, lo: 0x02}, - {value: 0x812e, lo: 0xb9, hi: 0xba}, - {value: 0x812d, lo: 0xbb, hi: 0xbb}, - // Block 0x34, offset 0x120 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x97, hi: 0x97}, - {value: 0x812d, lo: 0x98, hi: 0x98}, - // Block 0x35, offset 0x123 - {value: 0x0000, lo: 0x03}, - {value: 0x8104, lo: 0xa0, hi: 0xa0}, - {value: 0x8132, lo: 0xb5, hi: 0xbc}, - {value: 0x812d, lo: 0xbf, hi: 0xbf}, - // Block 0x36, offset 0x127 - {value: 0x0000, lo: 0x04}, - {value: 0x8132, lo: 0xb0, hi: 0xb4}, - {value: 0x812d, lo: 0xb5, hi: 0xba}, - {value: 0x8132, lo: 0xbb, hi: 0xbc}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - // Block 0x37, offset 0x12c - {value: 0x0000, lo: 0x08}, - {value: 0x2d66, lo: 0x80, hi: 0x80}, - {value: 0x2d6e, lo: 0x81, hi: 0x81}, - {value: 0xa000, lo: 0x82, hi: 0x82}, - {value: 0x2d76, lo: 0x83, hi: 0x83}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0xab, hi: 0xab}, - {value: 0x812d, lo: 0xac, hi: 0xac}, - {value: 0x8132, lo: 0xad, hi: 0xb3}, - // Block 0x38, offset 0x135 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xaa, hi: 0xab}, - // Block 0x39, offset 0x137 - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xa6, hi: 0xa6}, - {value: 0x8104, lo: 0xb2, hi: 0xb3}, - // Block 0x3a, offset 0x13a - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - // Block 0x3b, offset 0x13c - {value: 0x0000, lo: 0x0a}, - {value: 0x8132, lo: 0x90, hi: 0x92}, - {value: 0x8101, lo: 0x94, hi: 0x94}, - {value: 0x812d, lo: 0x95, hi: 0x99}, - {value: 0x8132, lo: 0x9a, hi: 0x9b}, - {value: 0x812d, lo: 0x9c, hi: 0x9f}, - {value: 0x8132, lo: 0xa0, hi: 0xa0}, - {value: 0x8101, lo: 0xa2, hi: 0xa8}, - {value: 0x812d, lo: 0xad, hi: 0xad}, - {value: 0x8132, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb8, hi: 0xb9}, - // Block 0x3c, offset 0x147 - {value: 0x0000, lo: 0x0f}, - {value: 0x8132, lo: 0x80, hi: 0x81}, - {value: 0x812d, lo: 0x82, hi: 0x82}, - {value: 0x8132, lo: 0x83, hi: 0x89}, - {value: 0x812d, lo: 0x8a, hi: 0x8a}, - {value: 0x8132, lo: 0x8b, hi: 0x8c}, - {value: 0x8135, lo: 0x8d, hi: 0x8d}, - {value: 0x812a, lo: 0x8e, hi: 0x8e}, - {value: 0x812d, lo: 0x8f, hi: 0x8f}, - {value: 0x8129, lo: 0x90, hi: 0x90}, - {value: 0x8132, lo: 0x91, hi: 0xb5}, - {value: 0x8132, lo: 0xbb, hi: 0xbb}, - {value: 0x8134, lo: 0xbc, hi: 0xbc}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - {value: 0x8132, lo: 0xbe, hi: 0xbe}, - {value: 0x812d, lo: 0xbf, hi: 0xbf}, - // Block 0x3d, offset 0x157 - {value: 0x0004, lo: 0x03}, - {value: 0x0433, lo: 0x80, hi: 0x81}, - {value: 0x8100, lo: 0x97, hi: 0x97}, - {value: 0x8100, lo: 0xbe, hi: 0xbe}, - // Block 0x3e, offset 0x15b - {value: 0x0000, lo: 0x0d}, - {value: 0x8132, lo: 0x90, hi: 0x91}, - {value: 0x8101, lo: 0x92, hi: 0x93}, - {value: 0x8132, lo: 0x94, hi: 0x97}, - {value: 0x8101, lo: 0x98, hi: 0x9a}, - {value: 0x8132, lo: 0x9b, hi: 0x9c}, - {value: 0x8132, lo: 0xa1, hi: 0xa1}, - {value: 0x8101, lo: 0xa5, hi: 0xa6}, - {value: 0x8132, lo: 0xa7, hi: 0xa7}, - {value: 0x812d, lo: 0xa8, hi: 0xa8}, - {value: 0x8132, lo: 0xa9, hi: 0xa9}, - {value: 0x8101, lo: 0xaa, hi: 0xab}, - {value: 0x812d, lo: 0xac, hi: 0xaf}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - // Block 0x3f, offset 0x169 - {value: 0x427b, lo: 0x02}, - {value: 0x01b8, lo: 0xa6, hi: 0xa6}, - {value: 0x0057, lo: 0xaa, hi: 0xab}, - // Block 0x40, offset 0x16c - {value: 0x0007, lo: 0x05}, - {value: 0xa000, lo: 0x90, hi: 0x90}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0xa000, lo: 0x94, hi: 0x94}, - {value: 0x3bb9, lo: 0x9a, hi: 0x9b}, - {value: 0x3bc7, lo: 0xae, hi: 0xae}, - // Block 0x41, offset 0x172 - {value: 0x000e, lo: 0x05}, - {value: 0x3bce, lo: 0x8d, hi: 0x8e}, - {value: 0x3bd5, lo: 0x8f, hi: 0x8f}, - {value: 0xa000, lo: 0x90, hi: 0x90}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0xa000, lo: 0x94, hi: 0x94}, - // Block 0x42, offset 0x178 - {value: 0x6408, lo: 0x0a}, - {value: 0xa000, lo: 0x83, hi: 0x83}, - {value: 0x3be3, lo: 0x84, hi: 0x84}, - {value: 0xa000, lo: 0x88, hi: 0x88}, - {value: 0x3bea, lo: 0x89, hi: 0x89}, - {value: 0xa000, lo: 0x8b, hi: 0x8b}, - {value: 0x3bf1, lo: 0x8c, hi: 0x8c}, - {value: 0xa000, lo: 0xa3, hi: 0xa3}, - {value: 0x3bf8, lo: 0xa4, hi: 0xa5}, - {value: 0x3bff, lo: 0xa6, hi: 0xa6}, - {value: 0xa000, lo: 0xbc, hi: 0xbc}, - // Block 0x43, offset 0x183 - {value: 0x0007, lo: 0x03}, - {value: 0x3c68, lo: 0xa0, hi: 0xa1}, - {value: 0x3c92, lo: 0xa2, hi: 0xa3}, - {value: 0x3cbc, lo: 0xaa, hi: 0xad}, - // Block 0x44, offset 0x187 - {value: 0x0004, lo: 0x01}, - {value: 0x048b, lo: 0xa9, hi: 0xaa}, - // Block 0x45, offset 0x189 - {value: 0x0000, lo: 0x01}, - {value: 0x4573, lo: 0x9c, hi: 0x9c}, - // Block 0x46, offset 0x18b - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xaf, hi: 0xb1}, - // Block 0x47, offset 0x18d - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x48, offset 0x18f - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xa0, hi: 0xbf}, - // Block 0x49, offset 0x191 - {value: 0x0000, lo: 0x05}, - {value: 0x812c, lo: 0xaa, hi: 0xaa}, - {value: 0x8131, lo: 0xab, hi: 0xab}, - {value: 0x8133, lo: 0xac, hi: 0xac}, - {value: 0x812e, lo: 0xad, hi: 0xad}, - {value: 0x812f, lo: 0xae, hi: 0xaf}, - // Block 0x4a, offset 0x197 - {value: 0x0000, lo: 0x03}, - {value: 0x4a81, lo: 0xb3, hi: 0xb3}, - {value: 0x4a81, lo: 0xb5, hi: 0xb6}, - {value: 0x4a81, lo: 0xba, hi: 0xbf}, - // Block 0x4b, offset 0x19b - {value: 0x0000, lo: 0x01}, - {value: 0x4a81, lo: 0x8f, hi: 0xa3}, - // Block 0x4c, offset 0x19d - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0xae, hi: 0xbe}, - // Block 0x4d, offset 0x19f - {value: 0x0000, lo: 0x07}, - {value: 0x8100, lo: 0x84, hi: 0x84}, - {value: 0x8100, lo: 0x87, hi: 0x87}, - {value: 0x8100, lo: 0x90, hi: 0x90}, - {value: 0x8100, lo: 0x9e, hi: 0x9e}, - {value: 0x8100, lo: 0xa1, hi: 0xa1}, - {value: 0x8100, lo: 0xb2, hi: 0xb2}, - {value: 0x8100, lo: 0xbb, hi: 0xbb}, - // Block 0x4e, offset 0x1a7 - {value: 0x0000, lo: 0x03}, - {value: 0x8100, lo: 0x80, hi: 0x80}, - {value: 0x8100, lo: 0x8b, hi: 0x8b}, - {value: 0x8100, lo: 0x8e, hi: 0x8e}, - // Block 0x4f, offset 0x1ab - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0xaf, hi: 0xaf}, - {value: 0x8132, lo: 0xb4, hi: 0xbd}, - // Block 0x50, offset 0x1ae - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x9e, hi: 0x9f}, - // Block 0x51, offset 0x1b0 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb0, hi: 0xb1}, - // Block 0x52, offset 0x1b2 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x86, hi: 0x86}, - // Block 0x53, offset 0x1b4 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0xa0, hi: 0xb1}, - // Block 0x54, offset 0x1b7 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xab, hi: 0xad}, - // Block 0x55, offset 0x1b9 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x93, hi: 0x93}, - // Block 0x56, offset 0x1bb - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xb3, hi: 0xb3}, - // Block 0x57, offset 0x1bd - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x80, hi: 0x80}, - // Block 0x58, offset 0x1bf - {value: 0x0000, lo: 0x05}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - {value: 0x8132, lo: 0xb2, hi: 0xb3}, - {value: 0x812d, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb7, hi: 0xb8}, - {value: 0x8132, lo: 0xbe, hi: 0xbf}, - // Block 0x59, offset 0x1c5 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x81, hi: 0x81}, - {value: 0x8104, lo: 0xb6, hi: 0xb6}, - // Block 0x5a, offset 0x1c8 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xad, hi: 0xad}, - // Block 0x5b, offset 0x1ca - {value: 0x0000, lo: 0x06}, - {value: 0xe500, lo: 0x80, hi: 0x80}, - {value: 0xc600, lo: 0x81, hi: 0x9b}, - {value: 0xe500, lo: 0x9c, hi: 0x9c}, - {value: 0xc600, lo: 0x9d, hi: 0xb7}, - {value: 0xe500, lo: 0xb8, hi: 0xb8}, - {value: 0xc600, lo: 0xb9, hi: 0xbf}, - // Block 0x5c, offset 0x1d1 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x93}, - {value: 0xe500, lo: 0x94, hi: 0x94}, - {value: 0xc600, lo: 0x95, hi: 0xaf}, - {value: 0xe500, lo: 0xb0, hi: 0xb0}, - {value: 0xc600, lo: 0xb1, hi: 0xbf}, - // Block 0x5d, offset 0x1d7 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x8b}, - {value: 0xe500, lo: 0x8c, hi: 0x8c}, - {value: 0xc600, lo: 0x8d, hi: 0xa7}, - {value: 0xe500, lo: 0xa8, hi: 0xa8}, - {value: 0xc600, lo: 0xa9, hi: 0xbf}, - // Block 0x5e, offset 0x1dd - {value: 0x0000, lo: 0x07}, - {value: 0xc600, lo: 0x80, hi: 0x83}, - {value: 0xe500, lo: 0x84, hi: 0x84}, - {value: 0xc600, lo: 0x85, hi: 0x9f}, - {value: 0xe500, lo: 0xa0, hi: 0xa0}, - {value: 0xc600, lo: 0xa1, hi: 0xbb}, - {value: 0xe500, lo: 0xbc, hi: 0xbc}, - {value: 0xc600, lo: 0xbd, hi: 0xbf}, - // Block 0x5f, offset 0x1e5 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x97}, - {value: 0xe500, lo: 0x98, hi: 0x98}, - {value: 0xc600, lo: 0x99, hi: 0xb3}, - {value: 0xe500, lo: 0xb4, hi: 0xb4}, - {value: 0xc600, lo: 0xb5, hi: 0xbf}, - // Block 0x60, offset 0x1eb - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x8f}, - {value: 0xe500, lo: 0x90, hi: 0x90}, - {value: 0xc600, lo: 0x91, hi: 0xab}, - {value: 0xe500, lo: 0xac, hi: 0xac}, - {value: 0xc600, lo: 0xad, hi: 0xbf}, - // Block 0x61, offset 0x1f1 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x87}, - {value: 0xe500, lo: 0x88, hi: 0x88}, - {value: 0xc600, lo: 0x89, hi: 0xa3}, - {value: 0xe500, lo: 0xa4, hi: 0xa4}, - {value: 0xc600, lo: 0xa5, hi: 0xbf}, - // Block 0x62, offset 0x1f7 - {value: 0x0000, lo: 0x03}, - {value: 0xc600, lo: 0x80, hi: 0x87}, - {value: 0xe500, lo: 0x88, hi: 0x88}, - {value: 0xc600, lo: 0x89, hi: 0xa3}, - // Block 0x63, offset 0x1fb - {value: 0x0006, lo: 0x0d}, - {value: 0x4426, lo: 0x9d, hi: 0x9d}, - {value: 0x8115, lo: 0x9e, hi: 0x9e}, - {value: 0x4498, lo: 0x9f, hi: 0x9f}, - {value: 0x4486, lo: 0xaa, hi: 0xab}, - {value: 0x458a, lo: 0xac, hi: 0xac}, - {value: 0x4592, lo: 0xad, hi: 0xad}, - {value: 0x43de, lo: 0xae, hi: 0xb1}, - {value: 0x43fc, lo: 0xb2, hi: 0xb4}, - {value: 0x4414, lo: 0xb5, hi: 0xb6}, - {value: 0x4420, lo: 0xb8, hi: 0xb8}, - {value: 0x442c, lo: 0xb9, hi: 0xbb}, - {value: 0x4444, lo: 0xbc, hi: 0xbc}, - {value: 0x444a, lo: 0xbe, hi: 0xbe}, - // Block 0x64, offset 0x209 - {value: 0x0006, lo: 0x08}, - {value: 0x4450, lo: 0x80, hi: 0x81}, - {value: 0x445c, lo: 0x83, hi: 0x84}, - {value: 0x446e, lo: 0x86, hi: 0x89}, - {value: 0x4492, lo: 0x8a, hi: 0x8a}, - {value: 0x440e, lo: 0x8b, hi: 0x8b}, - {value: 0x43f6, lo: 0x8c, hi: 0x8c}, - {value: 0x443e, lo: 0x8d, hi: 0x8d}, - {value: 0x4468, lo: 0x8e, hi: 0x8e}, - // Block 0x65, offset 0x212 - {value: 0x0000, lo: 0x02}, - {value: 0x8100, lo: 0xa4, hi: 0xa5}, - {value: 0x8100, lo: 0xb0, hi: 0xb1}, - // Block 0x66, offset 0x215 - {value: 0x0000, lo: 0x02}, - {value: 0x8100, lo: 0x9b, hi: 0x9d}, - {value: 0x8200, lo: 0x9e, hi: 0xa3}, - // Block 0x67, offset 0x218 - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0x90, hi: 0x90}, - // Block 0x68, offset 0x21a - {value: 0x0000, lo: 0x02}, - {value: 0x8100, lo: 0x99, hi: 0x99}, - {value: 0x8200, lo: 0xb2, hi: 0xb4}, - // Block 0x69, offset 0x21d - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0xbc, hi: 0xbd}, - // Block 0x6a, offset 0x21f - {value: 0x0000, lo: 0x03}, - {value: 0x8132, lo: 0xa0, hi: 0xa6}, - {value: 0x812d, lo: 0xa7, hi: 0xad}, - {value: 0x8132, lo: 0xae, hi: 0xaf}, - // Block 0x6b, offset 0x223 - {value: 0x0000, lo: 0x04}, - {value: 0x8100, lo: 0x89, hi: 0x8c}, - {value: 0x8100, lo: 0xb0, hi: 0xb2}, - {value: 0x8100, lo: 0xb4, hi: 0xb4}, - {value: 0x8100, lo: 0xb6, hi: 0xbf}, - // Block 0x6c, offset 0x228 - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0x81, hi: 0x8c}, - // Block 0x6d, offset 0x22a - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0xb5, hi: 0xba}, - // Block 0x6e, offset 0x22c - {value: 0x0000, lo: 0x04}, - {value: 0x4a81, lo: 0x9e, hi: 0x9f}, - {value: 0x4a81, lo: 0xa3, hi: 0xa3}, - {value: 0x4a81, lo: 0xa5, hi: 0xa6}, - {value: 0x4a81, lo: 0xaa, hi: 0xaf}, - // Block 0x6f, offset 0x231 - {value: 0x0000, lo: 0x05}, - {value: 0x4a81, lo: 0x82, hi: 0x87}, - {value: 0x4a81, lo: 0x8a, hi: 0x8f}, - {value: 0x4a81, lo: 0x92, hi: 0x97}, - {value: 0x4a81, lo: 0x9a, hi: 0x9c}, - {value: 0x8100, lo: 0xa3, hi: 0xa3}, - // Block 0x70, offset 0x237 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - // Block 0x71, offset 0x239 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xa0, hi: 0xa0}, - // Block 0x72, offset 0x23b - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb6, hi: 0xba}, - // Block 0x73, offset 0x23d - {value: 0x002c, lo: 0x05}, - {value: 0x812d, lo: 0x8d, hi: 0x8d}, - {value: 0x8132, lo: 0x8f, hi: 0x8f}, - {value: 0x8132, lo: 0xb8, hi: 0xb8}, - {value: 0x8101, lo: 0xb9, hi: 0xba}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x74, offset 0x243 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0xa5, hi: 0xa5}, - {value: 0x812d, lo: 0xa6, hi: 0xa6}, - // Block 0x75, offset 0x246 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x86, hi: 0x86}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x76, offset 0x249 - {value: 0x17fe, lo: 0x07}, - {value: 0xa000, lo: 0x99, hi: 0x99}, - {value: 0x4238, lo: 0x9a, hi: 0x9a}, - {value: 0xa000, lo: 0x9b, hi: 0x9b}, - {value: 0x4242, lo: 0x9c, hi: 0x9c}, - {value: 0xa000, lo: 0xa5, hi: 0xa5}, - {value: 0x424c, lo: 0xab, hi: 0xab}, - {value: 0x8104, lo: 0xb9, hi: 0xba}, - // Block 0x77, offset 0x251 - {value: 0x0000, lo: 0x06}, - {value: 0x8132, lo: 0x80, hi: 0x82}, - {value: 0x9900, lo: 0xa7, hi: 0xa7}, - {value: 0x2d7e, lo: 0xae, hi: 0xae}, - {value: 0x2d88, lo: 0xaf, hi: 0xaf}, - {value: 0xa000, lo: 0xb1, hi: 0xb2}, - {value: 0x8104, lo: 0xb3, hi: 0xb4}, - // Block 0x78, offset 0x258 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x80, hi: 0x80}, - {value: 0x8102, lo: 0x8a, hi: 0x8a}, - // Block 0x79, offset 0x25b - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0xb5, hi: 0xb5}, - {value: 0x8102, lo: 0xb6, hi: 0xb6}, - // Block 0x7a, offset 0x25e - {value: 0x0002, lo: 0x01}, - {value: 0x8102, lo: 0xa9, hi: 0xaa}, - // Block 0x7b, offset 0x260 - {value: 0x0000, lo: 0x07}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2d92, lo: 0x8b, hi: 0x8b}, - {value: 0x2d9c, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - {value: 0x8132, lo: 0xa6, hi: 0xac}, - {value: 0x8132, lo: 0xb0, hi: 0xb4}, - // Block 0x7c, offset 0x268 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x82, hi: 0x82}, - {value: 0x8102, lo: 0x86, hi: 0x86}, - // Block 0x7d, offset 0x26b - {value: 0x6b5a, lo: 0x06}, - {value: 0x9900, lo: 0xb0, hi: 0xb0}, - {value: 0xa000, lo: 0xb9, hi: 0xb9}, - {value: 0x9900, lo: 0xba, hi: 0xba}, - {value: 0x2db0, lo: 0xbb, hi: 0xbb}, - {value: 0x2da6, lo: 0xbc, hi: 0xbd}, - {value: 0x2dba, lo: 0xbe, hi: 0xbe}, - // Block 0x7e, offset 0x272 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x82, hi: 0x82}, - {value: 0x8102, lo: 0x83, hi: 0x83}, - // Block 0x7f, offset 0x275 - {value: 0x0000, lo: 0x05}, - {value: 0x9900, lo: 0xaf, hi: 0xaf}, - {value: 0xa000, lo: 0xb8, hi: 0xb9}, - {value: 0x2dc4, lo: 0xba, hi: 0xba}, - {value: 0x2dce, lo: 0xbb, hi: 0xbb}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x80, offset 0x27b - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0x80, hi: 0x80}, - // Block 0x81, offset 0x27d - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0xb6, hi: 0xb6}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - // Block 0x82, offset 0x280 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xab, hi: 0xab}, - // Block 0x83, offset 0x282 - {value: 0x0000, lo: 0x01}, - {value: 0x8101, lo: 0xb0, hi: 0xb4}, - // Block 0x84, offset 0x284 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb0, hi: 0xb6}, - // Block 0x85, offset 0x286 - {value: 0x0000, lo: 0x01}, - {value: 0x8101, lo: 0x9e, hi: 0x9e}, - // Block 0x86, offset 0x288 - {value: 0x0000, lo: 0x0c}, - {value: 0x4662, lo: 0x9e, hi: 0x9e}, - {value: 0x466c, lo: 0x9f, hi: 0x9f}, - {value: 0x46a0, lo: 0xa0, hi: 0xa0}, - {value: 0x46ae, lo: 0xa1, hi: 0xa1}, - {value: 0x46bc, lo: 0xa2, hi: 0xa2}, - {value: 0x46ca, lo: 0xa3, hi: 0xa3}, - {value: 0x46d8, lo: 0xa4, hi: 0xa4}, - {value: 0x812b, lo: 0xa5, hi: 0xa6}, - {value: 0x8101, lo: 0xa7, hi: 0xa9}, - {value: 0x8130, lo: 0xad, hi: 0xad}, - {value: 0x812b, lo: 0xae, hi: 0xb2}, - {value: 0x812d, lo: 0xbb, hi: 0xbf}, - // Block 0x87, offset 0x295 - {value: 0x0000, lo: 0x09}, - {value: 0x812d, lo: 0x80, hi: 0x82}, - {value: 0x8132, lo: 0x85, hi: 0x89}, - {value: 0x812d, lo: 0x8a, hi: 0x8b}, - {value: 0x8132, lo: 0xaa, hi: 0xad}, - {value: 0x4676, lo: 0xbb, hi: 0xbb}, - {value: 0x4680, lo: 0xbc, hi: 0xbc}, - {value: 0x46e6, lo: 0xbd, hi: 0xbd}, - {value: 0x4702, lo: 0xbe, hi: 0xbe}, - {value: 0x46f4, lo: 0xbf, hi: 0xbf}, - // Block 0x88, offset 0x29f - {value: 0x0000, lo: 0x01}, - {value: 0x4710, lo: 0x80, hi: 0x80}, - // Block 0x89, offset 0x2a1 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x82, hi: 0x84}, - // Block 0x8a, offset 0x2a3 - {value: 0x0000, lo: 0x05}, - {value: 0x8132, lo: 0x80, hi: 0x86}, - {value: 0x8132, lo: 0x88, hi: 0x98}, - {value: 0x8132, lo: 0x9b, hi: 0xa1}, - {value: 0x8132, lo: 0xa3, hi: 0xa4}, - {value: 0x8132, lo: 0xa6, hi: 0xaa}, - // Block 0x8b, offset 0x2a9 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x90, hi: 0x96}, - // Block 0x8c, offset 0x2ab - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x84, hi: 0x89}, - {value: 0x8102, lo: 0x8a, hi: 0x8a}, - // Block 0x8d, offset 0x2ae - {value: 0x0000, lo: 0x01}, - {value: 0x8100, lo: 0x93, hi: 0x93}, -} - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *nfkcTrie) lookup(s []byte) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return nfkcValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfkcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfkcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = nfkcIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *nfkcTrie) lookupUnsafe(s []byte) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return nfkcValues[c0] - } - i := nfkcIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = nfkcIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = nfkcIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *nfkcTrie) lookupString(s string) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return nfkcValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfkcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := nfkcIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = nfkcIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = nfkcIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *nfkcTrie) lookupStringUnsafe(s string) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return nfkcValues[c0] - } - i := nfkcIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = nfkcIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = nfkcIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// nfkcTrie. Total size: 16994 bytes (16.60 KiB). Checksum: 146925fc21092b17. -type nfkcTrie struct{} - -func newNfkcTrie(i int) *nfkcTrie { - return &nfkcTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *nfkcTrie) lookupValue(n uint32, b byte) uint16 { - switch { - case n < 90: - return uint16(nfkcValues[n<<6+uint32(b)]) - default: - n -= 90 - return uint16(nfkcSparse.lookup(n, b)) - } -} - -// nfkcValues: 92 blocks, 5888 entries, 11776 bytes -// The third block is the zero block. -var nfkcValues = [5888]uint16{ - // Block 0x0, offset 0x0 - 0x3c: 0xa000, 0x3d: 0xa000, 0x3e: 0xa000, - // Block 0x1, offset 0x40 - 0x41: 0xa000, 0x42: 0xa000, 0x43: 0xa000, 0x44: 0xa000, 0x45: 0xa000, - 0x46: 0xa000, 0x47: 0xa000, 0x48: 0xa000, 0x49: 0xa000, 0x4a: 0xa000, 0x4b: 0xa000, - 0x4c: 0xa000, 0x4d: 0xa000, 0x4e: 0xa000, 0x4f: 0xa000, 0x50: 0xa000, - 0x52: 0xa000, 0x53: 0xa000, 0x54: 0xa000, 0x55: 0xa000, 0x56: 0xa000, 0x57: 0xa000, - 0x58: 0xa000, 0x59: 0xa000, 0x5a: 0xa000, - 0x61: 0xa000, 0x62: 0xa000, 0x63: 0xa000, - 0x64: 0xa000, 0x65: 0xa000, 0x66: 0xa000, 0x67: 0xa000, 0x68: 0xa000, 0x69: 0xa000, - 0x6a: 0xa000, 0x6b: 0xa000, 0x6c: 0xa000, 0x6d: 0xa000, 0x6e: 0xa000, 0x6f: 0xa000, - 0x70: 0xa000, 0x72: 0xa000, 0x73: 0xa000, 0x74: 0xa000, 0x75: 0xa000, - 0x76: 0xa000, 0x77: 0xa000, 0x78: 0xa000, 0x79: 0xa000, 0x7a: 0xa000, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc0: 0x2f6f, 0xc1: 0x2f74, 0xc2: 0x471e, 0xc3: 0x2f79, 0xc4: 0x472d, 0xc5: 0x4732, - 0xc6: 0xa000, 0xc7: 0x473c, 0xc8: 0x2fe2, 0xc9: 0x2fe7, 0xca: 0x4741, 0xcb: 0x2ffb, - 0xcc: 0x306e, 0xcd: 0x3073, 0xce: 0x3078, 0xcf: 0x4755, 0xd1: 0x3104, - 0xd2: 0x3127, 0xd3: 0x312c, 0xd4: 0x475f, 0xd5: 0x4764, 0xd6: 0x4773, - 0xd8: 0xa000, 0xd9: 0x31b3, 0xda: 0x31b8, 0xdb: 0x31bd, 0xdc: 0x47a5, 0xdd: 0x3235, - 0xe0: 0x327b, 0xe1: 0x3280, 0xe2: 0x47af, 0xe3: 0x3285, - 0xe4: 0x47be, 0xe5: 0x47c3, 0xe6: 0xa000, 0xe7: 0x47cd, 0xe8: 0x32ee, 0xe9: 0x32f3, - 0xea: 0x47d2, 0xeb: 0x3307, 0xec: 0x337f, 0xed: 0x3384, 0xee: 0x3389, 0xef: 0x47e6, - 0xf1: 0x3415, 0xf2: 0x3438, 0xf3: 0x343d, 0xf4: 0x47f0, 0xf5: 0x47f5, - 0xf6: 0x4804, 0xf8: 0xa000, 0xf9: 0x34c9, 0xfa: 0x34ce, 0xfb: 0x34d3, - 0xfc: 0x4836, 0xfd: 0x3550, 0xff: 0x3569, - // Block 0x4, offset 0x100 - 0x100: 0x2f7e, 0x101: 0x328a, 0x102: 0x4723, 0x103: 0x47b4, 0x104: 0x2f9c, 0x105: 0x32a8, - 0x106: 0x2fb0, 0x107: 0x32bc, 0x108: 0x2fb5, 0x109: 0x32c1, 0x10a: 0x2fba, 0x10b: 0x32c6, - 0x10c: 0x2fbf, 0x10d: 0x32cb, 0x10e: 0x2fc9, 0x10f: 0x32d5, - 0x112: 0x4746, 0x113: 0x47d7, 0x114: 0x2ff1, 0x115: 0x32fd, 0x116: 0x2ff6, 0x117: 0x3302, - 0x118: 0x3014, 0x119: 0x3320, 0x11a: 0x3005, 0x11b: 0x3311, 0x11c: 0x302d, 0x11d: 0x3339, - 0x11e: 0x3037, 0x11f: 0x3343, 0x120: 0x303c, 0x121: 0x3348, 0x122: 0x3046, 0x123: 0x3352, - 0x124: 0x304b, 0x125: 0x3357, 0x128: 0x307d, 0x129: 0x338e, - 0x12a: 0x3082, 0x12b: 0x3393, 0x12c: 0x3087, 0x12d: 0x3398, 0x12e: 0x30aa, 0x12f: 0x33b6, - 0x130: 0x308c, 0x132: 0x195d, 0x133: 0x19e7, 0x134: 0x30b4, 0x135: 0x33c0, - 0x136: 0x30c8, 0x137: 0x33d9, 0x139: 0x30d2, 0x13a: 0x33e3, 0x13b: 0x30dc, - 0x13c: 0x33ed, 0x13d: 0x30d7, 0x13e: 0x33e8, 0x13f: 0x1bac, - // Block 0x5, offset 0x140 - 0x140: 0x1c34, 0x143: 0x30ff, 0x144: 0x3410, 0x145: 0x3118, - 0x146: 0x3429, 0x147: 0x310e, 0x148: 0x341f, 0x149: 0x1c5c, - 0x14c: 0x4769, 0x14d: 0x47fa, 0x14e: 0x3131, 0x14f: 0x3442, 0x150: 0x313b, 0x151: 0x344c, - 0x154: 0x3159, 0x155: 0x346a, 0x156: 0x3172, 0x157: 0x3483, - 0x158: 0x3163, 0x159: 0x3474, 0x15a: 0x478c, 0x15b: 0x481d, 0x15c: 0x317c, 0x15d: 0x348d, - 0x15e: 0x318b, 0x15f: 0x349c, 0x160: 0x4791, 0x161: 0x4822, 0x162: 0x31a4, 0x163: 0x34ba, - 0x164: 0x3195, 0x165: 0x34ab, 0x168: 0x479b, 0x169: 0x482c, - 0x16a: 0x47a0, 0x16b: 0x4831, 0x16c: 0x31c2, 0x16d: 0x34d8, 0x16e: 0x31cc, 0x16f: 0x34e2, - 0x170: 0x31d1, 0x171: 0x34e7, 0x172: 0x31ef, 0x173: 0x3505, 0x174: 0x3212, 0x175: 0x3528, - 0x176: 0x323a, 0x177: 0x3555, 0x178: 0x324e, 0x179: 0x325d, 0x17a: 0x357d, 0x17b: 0x3267, - 0x17c: 0x3587, 0x17d: 0x326c, 0x17e: 0x358c, 0x17f: 0x00a7, - // Block 0x6, offset 0x180 - 0x184: 0x2dee, 0x185: 0x2df4, - 0x186: 0x2dfa, 0x187: 0x1972, 0x188: 0x1975, 0x189: 0x1a08, 0x18a: 0x1987, 0x18b: 0x198a, - 0x18c: 0x1a3e, 0x18d: 0x2f88, 0x18e: 0x3294, 0x18f: 0x3096, 0x190: 0x33a2, 0x191: 0x3140, - 0x192: 0x3451, 0x193: 0x31d6, 0x194: 0x34ec, 0x195: 0x39cf, 0x196: 0x3b5e, 0x197: 0x39c8, - 0x198: 0x3b57, 0x199: 0x39d6, 0x19a: 0x3b65, 0x19b: 0x39c1, 0x19c: 0x3b50, - 0x19e: 0x38b0, 0x19f: 0x3a3f, 0x1a0: 0x38a9, 0x1a1: 0x3a38, 0x1a2: 0x35b3, 0x1a3: 0x35c5, - 0x1a6: 0x3041, 0x1a7: 0x334d, 0x1a8: 0x30be, 0x1a9: 0x33cf, - 0x1aa: 0x4782, 0x1ab: 0x4813, 0x1ac: 0x3990, 0x1ad: 0x3b1f, 0x1ae: 0x35d7, 0x1af: 0x35dd, - 0x1b0: 0x33c5, 0x1b1: 0x1942, 0x1b2: 0x1945, 0x1b3: 0x19cf, 0x1b4: 0x3028, 0x1b5: 0x3334, - 0x1b8: 0x30fa, 0x1b9: 0x340b, 0x1ba: 0x38b7, 0x1bb: 0x3a46, - 0x1bc: 0x35ad, 0x1bd: 0x35bf, 0x1be: 0x35b9, 0x1bf: 0x35cb, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x2f8d, 0x1c1: 0x3299, 0x1c2: 0x2f92, 0x1c3: 0x329e, 0x1c4: 0x300a, 0x1c5: 0x3316, - 0x1c6: 0x300f, 0x1c7: 0x331b, 0x1c8: 0x309b, 0x1c9: 0x33a7, 0x1ca: 0x30a0, 0x1cb: 0x33ac, - 0x1cc: 0x3145, 0x1cd: 0x3456, 0x1ce: 0x314a, 0x1cf: 0x345b, 0x1d0: 0x3168, 0x1d1: 0x3479, - 0x1d2: 0x316d, 0x1d3: 0x347e, 0x1d4: 0x31db, 0x1d5: 0x34f1, 0x1d6: 0x31e0, 0x1d7: 0x34f6, - 0x1d8: 0x3186, 0x1d9: 0x3497, 0x1da: 0x319f, 0x1db: 0x34b5, - 0x1de: 0x305a, 0x1df: 0x3366, - 0x1e6: 0x4728, 0x1e7: 0x47b9, 0x1e8: 0x4750, 0x1e9: 0x47e1, - 0x1ea: 0x395f, 0x1eb: 0x3aee, 0x1ec: 0x393c, 0x1ed: 0x3acb, 0x1ee: 0x476e, 0x1ef: 0x47ff, - 0x1f0: 0x3958, 0x1f1: 0x3ae7, 0x1f2: 0x3244, 0x1f3: 0x355f, - // Block 0x8, offset 0x200 - 0x200: 0x9932, 0x201: 0x9932, 0x202: 0x9932, 0x203: 0x9932, 0x204: 0x9932, 0x205: 0x8132, - 0x206: 0x9932, 0x207: 0x9932, 0x208: 0x9932, 0x209: 0x9932, 0x20a: 0x9932, 0x20b: 0x9932, - 0x20c: 0x9932, 0x20d: 0x8132, 0x20e: 0x8132, 0x20f: 0x9932, 0x210: 0x8132, 0x211: 0x9932, - 0x212: 0x8132, 0x213: 0x9932, 0x214: 0x9932, 0x215: 0x8133, 0x216: 0x812d, 0x217: 0x812d, - 0x218: 0x812d, 0x219: 0x812d, 0x21a: 0x8133, 0x21b: 0x992b, 0x21c: 0x812d, 0x21d: 0x812d, - 0x21e: 0x812d, 0x21f: 0x812d, 0x220: 0x812d, 0x221: 0x8129, 0x222: 0x8129, 0x223: 0x992d, - 0x224: 0x992d, 0x225: 0x992d, 0x226: 0x992d, 0x227: 0x9929, 0x228: 0x9929, 0x229: 0x812d, - 0x22a: 0x812d, 0x22b: 0x812d, 0x22c: 0x812d, 0x22d: 0x992d, 0x22e: 0x992d, 0x22f: 0x812d, - 0x230: 0x992d, 0x231: 0x992d, 0x232: 0x812d, 0x233: 0x812d, 0x234: 0x8101, 0x235: 0x8101, - 0x236: 0x8101, 0x237: 0x8101, 0x238: 0x9901, 0x239: 0x812d, 0x23a: 0x812d, 0x23b: 0x812d, - 0x23c: 0x812d, 0x23d: 0x8132, 0x23e: 0x8132, 0x23f: 0x8132, - // Block 0x9, offset 0x240 - 0x240: 0x4a44, 0x241: 0x4a49, 0x242: 0x9932, 0x243: 0x4a4e, 0x244: 0x4a53, 0x245: 0x9936, - 0x246: 0x8132, 0x247: 0x812d, 0x248: 0x812d, 0x249: 0x812d, 0x24a: 0x8132, 0x24b: 0x8132, - 0x24c: 0x8132, 0x24d: 0x812d, 0x24e: 0x812d, 0x250: 0x8132, 0x251: 0x8132, - 0x252: 0x8132, 0x253: 0x812d, 0x254: 0x812d, 0x255: 0x812d, 0x256: 0x812d, 0x257: 0x8132, - 0x258: 0x8133, 0x259: 0x812d, 0x25a: 0x812d, 0x25b: 0x8132, 0x25c: 0x8134, 0x25d: 0x8135, - 0x25e: 0x8135, 0x25f: 0x8134, 0x260: 0x8135, 0x261: 0x8135, 0x262: 0x8134, 0x263: 0x8132, - 0x264: 0x8132, 0x265: 0x8132, 0x266: 0x8132, 0x267: 0x8132, 0x268: 0x8132, 0x269: 0x8132, - 0x26a: 0x8132, 0x26b: 0x8132, 0x26c: 0x8132, 0x26d: 0x8132, 0x26e: 0x8132, 0x26f: 0x8132, - 0x274: 0x0170, - 0x27a: 0x42a5, - 0x27e: 0x0037, - // Block 0xa, offset 0x280 - 0x284: 0x425a, 0x285: 0x4511, - 0x286: 0x35e9, 0x287: 0x00ce, 0x288: 0x3607, 0x289: 0x3613, 0x28a: 0x3625, - 0x28c: 0x3643, 0x28e: 0x3655, 0x28f: 0x3673, 0x290: 0x3e08, 0x291: 0xa000, - 0x295: 0xa000, 0x297: 0xa000, - 0x299: 0xa000, - 0x29f: 0xa000, 0x2a1: 0xa000, - 0x2a5: 0xa000, 0x2a9: 0xa000, - 0x2aa: 0x3637, 0x2ab: 0x3667, 0x2ac: 0x4894, 0x2ad: 0x3697, 0x2ae: 0x48be, 0x2af: 0x36a9, - 0x2b0: 0x3e70, 0x2b1: 0xa000, 0x2b5: 0xa000, - 0x2b7: 0xa000, 0x2b9: 0xa000, - 0x2bf: 0xa000, - // Block 0xb, offset 0x2c0 - 0x2c1: 0xa000, 0x2c5: 0xa000, - 0x2c9: 0xa000, 0x2ca: 0x48d6, 0x2cb: 0x48f4, - 0x2cc: 0x36c7, 0x2cd: 0x36df, 0x2ce: 0x490c, 0x2d0: 0x01be, 0x2d1: 0x01d0, - 0x2d2: 0x01ac, 0x2d3: 0x43a2, 0x2d4: 0x43a8, 0x2d5: 0x01fa, 0x2d6: 0x01e8, - 0x2f0: 0x01d6, 0x2f1: 0x01eb, 0x2f2: 0x01ee, 0x2f4: 0x0188, 0x2f5: 0x01c7, - 0x2f9: 0x01a6, - // Block 0xc, offset 0x300 - 0x300: 0x3721, 0x301: 0x372d, 0x303: 0x371b, - 0x306: 0xa000, 0x307: 0x3709, - 0x30c: 0x375d, 0x30d: 0x3745, 0x30e: 0x376f, 0x310: 0xa000, - 0x313: 0xa000, 0x315: 0xa000, 0x316: 0xa000, 0x317: 0xa000, - 0x318: 0xa000, 0x319: 0x3751, 0x31a: 0xa000, - 0x31e: 0xa000, 0x323: 0xa000, - 0x327: 0xa000, - 0x32b: 0xa000, 0x32d: 0xa000, - 0x330: 0xa000, 0x333: 0xa000, 0x335: 0xa000, - 0x336: 0xa000, 0x337: 0xa000, 0x338: 0xa000, 0x339: 0x37d5, 0x33a: 0xa000, - 0x33e: 0xa000, - // Block 0xd, offset 0x340 - 0x341: 0x3733, 0x342: 0x37b7, - 0x350: 0x370f, 0x351: 0x3793, - 0x352: 0x3715, 0x353: 0x3799, 0x356: 0x3727, 0x357: 0x37ab, - 0x358: 0xa000, 0x359: 0xa000, 0x35a: 0x3829, 0x35b: 0x382f, 0x35c: 0x3739, 0x35d: 0x37bd, - 0x35e: 0x373f, 0x35f: 0x37c3, 0x362: 0x374b, 0x363: 0x37cf, - 0x364: 0x3757, 0x365: 0x37db, 0x366: 0x3763, 0x367: 0x37e7, 0x368: 0xa000, 0x369: 0xa000, - 0x36a: 0x3835, 0x36b: 0x383b, 0x36c: 0x378d, 0x36d: 0x3811, 0x36e: 0x3769, 0x36f: 0x37ed, - 0x370: 0x3775, 0x371: 0x37f9, 0x372: 0x377b, 0x373: 0x37ff, 0x374: 0x3781, 0x375: 0x3805, - 0x378: 0x3787, 0x379: 0x380b, - // Block 0xe, offset 0x380 - 0x387: 0x1d61, - 0x391: 0x812d, - 0x392: 0x8132, 0x393: 0x8132, 0x394: 0x8132, 0x395: 0x8132, 0x396: 0x812d, 0x397: 0x8132, - 0x398: 0x8132, 0x399: 0x8132, 0x39a: 0x812e, 0x39b: 0x812d, 0x39c: 0x8132, 0x39d: 0x8132, - 0x39e: 0x8132, 0x39f: 0x8132, 0x3a0: 0x8132, 0x3a1: 0x8132, 0x3a2: 0x812d, 0x3a3: 0x812d, - 0x3a4: 0x812d, 0x3a5: 0x812d, 0x3a6: 0x812d, 0x3a7: 0x812d, 0x3a8: 0x8132, 0x3a9: 0x8132, - 0x3aa: 0x812d, 0x3ab: 0x8132, 0x3ac: 0x8132, 0x3ad: 0x812e, 0x3ae: 0x8131, 0x3af: 0x8132, - 0x3b0: 0x8105, 0x3b1: 0x8106, 0x3b2: 0x8107, 0x3b3: 0x8108, 0x3b4: 0x8109, 0x3b5: 0x810a, - 0x3b6: 0x810b, 0x3b7: 0x810c, 0x3b8: 0x810d, 0x3b9: 0x810e, 0x3ba: 0x810e, 0x3bb: 0x810f, - 0x3bc: 0x8110, 0x3bd: 0x8111, 0x3bf: 0x8112, - // Block 0xf, offset 0x3c0 - 0x3c8: 0xa000, 0x3ca: 0xa000, 0x3cb: 0x8116, - 0x3cc: 0x8117, 0x3cd: 0x8118, 0x3ce: 0x8119, 0x3cf: 0x811a, 0x3d0: 0x811b, 0x3d1: 0x811c, - 0x3d2: 0x811d, 0x3d3: 0x9932, 0x3d4: 0x9932, 0x3d5: 0x992d, 0x3d6: 0x812d, 0x3d7: 0x8132, - 0x3d8: 0x8132, 0x3d9: 0x8132, 0x3da: 0x8132, 0x3db: 0x8132, 0x3dc: 0x812d, 0x3dd: 0x8132, - 0x3de: 0x8132, 0x3df: 0x812d, - 0x3f0: 0x811e, 0x3f5: 0x1d84, - 0x3f6: 0x2013, 0x3f7: 0x204f, 0x3f8: 0x204a, - // Block 0x10, offset 0x400 - 0x405: 0xa000, - 0x406: 0x2d26, 0x407: 0xa000, 0x408: 0x2d2e, 0x409: 0xa000, 0x40a: 0x2d36, 0x40b: 0xa000, - 0x40c: 0x2d3e, 0x40d: 0xa000, 0x40e: 0x2d46, 0x411: 0xa000, - 0x412: 0x2d4e, - 0x434: 0x8102, 0x435: 0x9900, - 0x43a: 0xa000, 0x43b: 0x2d56, - 0x43c: 0xa000, 0x43d: 0x2d5e, 0x43e: 0xa000, 0x43f: 0xa000, - // Block 0x11, offset 0x440 - 0x440: 0x0069, 0x441: 0x006b, 0x442: 0x006f, 0x443: 0x0083, 0x444: 0x00f5, 0x445: 0x00f8, - 0x446: 0x0413, 0x447: 0x0085, 0x448: 0x0089, 0x449: 0x008b, 0x44a: 0x0104, 0x44b: 0x0107, - 0x44c: 0x010a, 0x44d: 0x008f, 0x44f: 0x0097, 0x450: 0x009b, 0x451: 0x00e0, - 0x452: 0x009f, 0x453: 0x00fe, 0x454: 0x0417, 0x455: 0x041b, 0x456: 0x00a1, 0x457: 0x00a9, - 0x458: 0x00ab, 0x459: 0x0423, 0x45a: 0x012b, 0x45b: 0x00ad, 0x45c: 0x0427, 0x45d: 0x01be, - 0x45e: 0x01c1, 0x45f: 0x01c4, 0x460: 0x01fa, 0x461: 0x01fd, 0x462: 0x0093, 0x463: 0x00a5, - 0x464: 0x00ab, 0x465: 0x00ad, 0x466: 0x01be, 0x467: 0x01c1, 0x468: 0x01eb, 0x469: 0x01fa, - 0x46a: 0x01fd, - 0x478: 0x020c, - // Block 0x12, offset 0x480 - 0x49b: 0x00fb, 0x49c: 0x0087, 0x49d: 0x0101, - 0x49e: 0x00d4, 0x49f: 0x010a, 0x4a0: 0x008d, 0x4a1: 0x010d, 0x4a2: 0x0110, 0x4a3: 0x0116, - 0x4a4: 0x011c, 0x4a5: 0x011f, 0x4a6: 0x0122, 0x4a7: 0x042b, 0x4a8: 0x016a, 0x4a9: 0x0128, - 0x4aa: 0x042f, 0x4ab: 0x016d, 0x4ac: 0x0131, 0x4ad: 0x012e, 0x4ae: 0x0134, 0x4af: 0x0137, - 0x4b0: 0x013a, 0x4b1: 0x013d, 0x4b2: 0x0140, 0x4b3: 0x014c, 0x4b4: 0x014f, 0x4b5: 0x00ec, - 0x4b6: 0x0152, 0x4b7: 0x0155, 0x4b8: 0x041f, 0x4b9: 0x0158, 0x4ba: 0x015b, 0x4bb: 0x00b5, - 0x4bc: 0x015e, 0x4bd: 0x0161, 0x4be: 0x0164, 0x4bf: 0x01d0, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x2f97, 0x4c1: 0x32a3, 0x4c2: 0x2fa1, 0x4c3: 0x32ad, 0x4c4: 0x2fa6, 0x4c5: 0x32b2, - 0x4c6: 0x2fab, 0x4c7: 0x32b7, 0x4c8: 0x38cc, 0x4c9: 0x3a5b, 0x4ca: 0x2fc4, 0x4cb: 0x32d0, - 0x4cc: 0x2fce, 0x4cd: 0x32da, 0x4ce: 0x2fdd, 0x4cf: 0x32e9, 0x4d0: 0x2fd3, 0x4d1: 0x32df, - 0x4d2: 0x2fd8, 0x4d3: 0x32e4, 0x4d4: 0x38ef, 0x4d5: 0x3a7e, 0x4d6: 0x38f6, 0x4d7: 0x3a85, - 0x4d8: 0x3019, 0x4d9: 0x3325, 0x4da: 0x301e, 0x4db: 0x332a, 0x4dc: 0x3904, 0x4dd: 0x3a93, - 0x4de: 0x3023, 0x4df: 0x332f, 0x4e0: 0x3032, 0x4e1: 0x333e, 0x4e2: 0x3050, 0x4e3: 0x335c, - 0x4e4: 0x305f, 0x4e5: 0x336b, 0x4e6: 0x3055, 0x4e7: 0x3361, 0x4e8: 0x3064, 0x4e9: 0x3370, - 0x4ea: 0x3069, 0x4eb: 0x3375, 0x4ec: 0x30af, 0x4ed: 0x33bb, 0x4ee: 0x390b, 0x4ef: 0x3a9a, - 0x4f0: 0x30b9, 0x4f1: 0x33ca, 0x4f2: 0x30c3, 0x4f3: 0x33d4, 0x4f4: 0x30cd, 0x4f5: 0x33de, - 0x4f6: 0x475a, 0x4f7: 0x47eb, 0x4f8: 0x3912, 0x4f9: 0x3aa1, 0x4fa: 0x30e6, 0x4fb: 0x33f7, - 0x4fc: 0x30e1, 0x4fd: 0x33f2, 0x4fe: 0x30eb, 0x4ff: 0x33fc, - // Block 0x14, offset 0x500 - 0x500: 0x30f0, 0x501: 0x3401, 0x502: 0x30f5, 0x503: 0x3406, 0x504: 0x3109, 0x505: 0x341a, - 0x506: 0x3113, 0x507: 0x3424, 0x508: 0x3122, 0x509: 0x3433, 0x50a: 0x311d, 0x50b: 0x342e, - 0x50c: 0x3935, 0x50d: 0x3ac4, 0x50e: 0x3943, 0x50f: 0x3ad2, 0x510: 0x394a, 0x511: 0x3ad9, - 0x512: 0x3951, 0x513: 0x3ae0, 0x514: 0x314f, 0x515: 0x3460, 0x516: 0x3154, 0x517: 0x3465, - 0x518: 0x315e, 0x519: 0x346f, 0x51a: 0x4787, 0x51b: 0x4818, 0x51c: 0x3997, 0x51d: 0x3b26, - 0x51e: 0x3177, 0x51f: 0x3488, 0x520: 0x3181, 0x521: 0x3492, 0x522: 0x4796, 0x523: 0x4827, - 0x524: 0x399e, 0x525: 0x3b2d, 0x526: 0x39a5, 0x527: 0x3b34, 0x528: 0x39ac, 0x529: 0x3b3b, - 0x52a: 0x3190, 0x52b: 0x34a1, 0x52c: 0x319a, 0x52d: 0x34b0, 0x52e: 0x31ae, 0x52f: 0x34c4, - 0x530: 0x31a9, 0x531: 0x34bf, 0x532: 0x31ea, 0x533: 0x3500, 0x534: 0x31f9, 0x535: 0x350f, - 0x536: 0x31f4, 0x537: 0x350a, 0x538: 0x39b3, 0x539: 0x3b42, 0x53a: 0x39ba, 0x53b: 0x3b49, - 0x53c: 0x31fe, 0x53d: 0x3514, 0x53e: 0x3203, 0x53f: 0x3519, - // Block 0x15, offset 0x540 - 0x540: 0x3208, 0x541: 0x351e, 0x542: 0x320d, 0x543: 0x3523, 0x544: 0x321c, 0x545: 0x3532, - 0x546: 0x3217, 0x547: 0x352d, 0x548: 0x3221, 0x549: 0x353c, 0x54a: 0x3226, 0x54b: 0x3541, - 0x54c: 0x322b, 0x54d: 0x3546, 0x54e: 0x3249, 0x54f: 0x3564, 0x550: 0x3262, 0x551: 0x3582, - 0x552: 0x3271, 0x553: 0x3591, 0x554: 0x3276, 0x555: 0x3596, 0x556: 0x337a, 0x557: 0x34a6, - 0x558: 0x3537, 0x559: 0x3573, 0x55a: 0x1be0, 0x55b: 0x42d7, - 0x560: 0x4737, 0x561: 0x47c8, 0x562: 0x2f83, 0x563: 0x328f, - 0x564: 0x3878, 0x565: 0x3a07, 0x566: 0x3871, 0x567: 0x3a00, 0x568: 0x3886, 0x569: 0x3a15, - 0x56a: 0x387f, 0x56b: 0x3a0e, 0x56c: 0x38be, 0x56d: 0x3a4d, 0x56e: 0x3894, 0x56f: 0x3a23, - 0x570: 0x388d, 0x571: 0x3a1c, 0x572: 0x38a2, 0x573: 0x3a31, 0x574: 0x389b, 0x575: 0x3a2a, - 0x576: 0x38c5, 0x577: 0x3a54, 0x578: 0x474b, 0x579: 0x47dc, 0x57a: 0x3000, 0x57b: 0x330c, - 0x57c: 0x2fec, 0x57d: 0x32f8, 0x57e: 0x38da, 0x57f: 0x3a69, - // Block 0x16, offset 0x580 - 0x580: 0x38d3, 0x581: 0x3a62, 0x582: 0x38e8, 0x583: 0x3a77, 0x584: 0x38e1, 0x585: 0x3a70, - 0x586: 0x38fd, 0x587: 0x3a8c, 0x588: 0x3091, 0x589: 0x339d, 0x58a: 0x30a5, 0x58b: 0x33b1, - 0x58c: 0x477d, 0x58d: 0x480e, 0x58e: 0x3136, 0x58f: 0x3447, 0x590: 0x3920, 0x591: 0x3aaf, - 0x592: 0x3919, 0x593: 0x3aa8, 0x594: 0x392e, 0x595: 0x3abd, 0x596: 0x3927, 0x597: 0x3ab6, - 0x598: 0x3989, 0x599: 0x3b18, 0x59a: 0x396d, 0x59b: 0x3afc, 0x59c: 0x3966, 0x59d: 0x3af5, - 0x59e: 0x397b, 0x59f: 0x3b0a, 0x5a0: 0x3974, 0x5a1: 0x3b03, 0x5a2: 0x3982, 0x5a3: 0x3b11, - 0x5a4: 0x31e5, 0x5a5: 0x34fb, 0x5a6: 0x31c7, 0x5a7: 0x34dd, 0x5a8: 0x39e4, 0x5a9: 0x3b73, - 0x5aa: 0x39dd, 0x5ab: 0x3b6c, 0x5ac: 0x39f2, 0x5ad: 0x3b81, 0x5ae: 0x39eb, 0x5af: 0x3b7a, - 0x5b0: 0x39f9, 0x5b1: 0x3b88, 0x5b2: 0x3230, 0x5b3: 0x354b, 0x5b4: 0x3258, 0x5b5: 0x3578, - 0x5b6: 0x3253, 0x5b7: 0x356e, 0x5b8: 0x323f, 0x5b9: 0x355a, - // Block 0x17, offset 0x5c0 - 0x5c0: 0x489a, 0x5c1: 0x48a0, 0x5c2: 0x49b4, 0x5c3: 0x49cc, 0x5c4: 0x49bc, 0x5c5: 0x49d4, - 0x5c6: 0x49c4, 0x5c7: 0x49dc, 0x5c8: 0x4840, 0x5c9: 0x4846, 0x5ca: 0x4924, 0x5cb: 0x493c, - 0x5cc: 0x492c, 0x5cd: 0x4944, 0x5ce: 0x4934, 0x5cf: 0x494c, 0x5d0: 0x48ac, 0x5d1: 0x48b2, - 0x5d2: 0x3db8, 0x5d3: 0x3dc8, 0x5d4: 0x3dc0, 0x5d5: 0x3dd0, - 0x5d8: 0x484c, 0x5d9: 0x4852, 0x5da: 0x3ce8, 0x5db: 0x3cf8, 0x5dc: 0x3cf0, 0x5dd: 0x3d00, - 0x5e0: 0x48c4, 0x5e1: 0x48ca, 0x5e2: 0x49e4, 0x5e3: 0x49fc, - 0x5e4: 0x49ec, 0x5e5: 0x4a04, 0x5e6: 0x49f4, 0x5e7: 0x4a0c, 0x5e8: 0x4858, 0x5e9: 0x485e, - 0x5ea: 0x4954, 0x5eb: 0x496c, 0x5ec: 0x495c, 0x5ed: 0x4974, 0x5ee: 0x4964, 0x5ef: 0x497c, - 0x5f0: 0x48dc, 0x5f1: 0x48e2, 0x5f2: 0x3e18, 0x5f3: 0x3e30, 0x5f4: 0x3e20, 0x5f5: 0x3e38, - 0x5f6: 0x3e28, 0x5f7: 0x3e40, 0x5f8: 0x4864, 0x5f9: 0x486a, 0x5fa: 0x3d18, 0x5fb: 0x3d30, - 0x5fc: 0x3d20, 0x5fd: 0x3d38, 0x5fe: 0x3d28, 0x5ff: 0x3d40, - // Block 0x18, offset 0x600 - 0x600: 0x48e8, 0x601: 0x48ee, 0x602: 0x3e48, 0x603: 0x3e58, 0x604: 0x3e50, 0x605: 0x3e60, - 0x608: 0x4870, 0x609: 0x4876, 0x60a: 0x3d48, 0x60b: 0x3d58, - 0x60c: 0x3d50, 0x60d: 0x3d60, 0x610: 0x48fa, 0x611: 0x4900, - 0x612: 0x3e80, 0x613: 0x3e98, 0x614: 0x3e88, 0x615: 0x3ea0, 0x616: 0x3e90, 0x617: 0x3ea8, - 0x619: 0x487c, 0x61b: 0x3d68, 0x61d: 0x3d70, - 0x61f: 0x3d78, 0x620: 0x4912, 0x621: 0x4918, 0x622: 0x4a14, 0x623: 0x4a2c, - 0x624: 0x4a1c, 0x625: 0x4a34, 0x626: 0x4a24, 0x627: 0x4a3c, 0x628: 0x4882, 0x629: 0x4888, - 0x62a: 0x4984, 0x62b: 0x499c, 0x62c: 0x498c, 0x62d: 0x49a4, 0x62e: 0x4994, 0x62f: 0x49ac, - 0x630: 0x488e, 0x631: 0x43b4, 0x632: 0x3691, 0x633: 0x43ba, 0x634: 0x48b8, 0x635: 0x43c0, - 0x636: 0x36a3, 0x637: 0x43c6, 0x638: 0x36c1, 0x639: 0x43cc, 0x63a: 0x36d9, 0x63b: 0x43d2, - 0x63c: 0x4906, 0x63d: 0x43d8, - // Block 0x19, offset 0x640 - 0x640: 0x3da0, 0x641: 0x3da8, 0x642: 0x4184, 0x643: 0x41a2, 0x644: 0x418e, 0x645: 0x41ac, - 0x646: 0x4198, 0x647: 0x41b6, 0x648: 0x3cd8, 0x649: 0x3ce0, 0x64a: 0x40d0, 0x64b: 0x40ee, - 0x64c: 0x40da, 0x64d: 0x40f8, 0x64e: 0x40e4, 0x64f: 0x4102, 0x650: 0x3de8, 0x651: 0x3df0, - 0x652: 0x41c0, 0x653: 0x41de, 0x654: 0x41ca, 0x655: 0x41e8, 0x656: 0x41d4, 0x657: 0x41f2, - 0x658: 0x3d08, 0x659: 0x3d10, 0x65a: 0x410c, 0x65b: 0x412a, 0x65c: 0x4116, 0x65d: 0x4134, - 0x65e: 0x4120, 0x65f: 0x413e, 0x660: 0x3ec0, 0x661: 0x3ec8, 0x662: 0x41fc, 0x663: 0x421a, - 0x664: 0x4206, 0x665: 0x4224, 0x666: 0x4210, 0x667: 0x422e, 0x668: 0x3d80, 0x669: 0x3d88, - 0x66a: 0x4148, 0x66b: 0x4166, 0x66c: 0x4152, 0x66d: 0x4170, 0x66e: 0x415c, 0x66f: 0x417a, - 0x670: 0x3685, 0x671: 0x367f, 0x672: 0x3d90, 0x673: 0x368b, 0x674: 0x3d98, - 0x676: 0x48a6, 0x677: 0x3db0, 0x678: 0x35f5, 0x679: 0x35ef, 0x67a: 0x35e3, 0x67b: 0x4384, - 0x67c: 0x35fb, 0x67d: 0x4287, 0x67e: 0x01d3, 0x67f: 0x4287, - // Block 0x1a, offset 0x680 - 0x680: 0x42a0, 0x681: 0x4518, 0x682: 0x3dd8, 0x683: 0x369d, 0x684: 0x3de0, - 0x686: 0x48d0, 0x687: 0x3df8, 0x688: 0x3601, 0x689: 0x438a, 0x68a: 0x360d, 0x68b: 0x4390, - 0x68c: 0x3619, 0x68d: 0x451f, 0x68e: 0x4526, 0x68f: 0x452d, 0x690: 0x36b5, 0x691: 0x36af, - 0x692: 0x3e00, 0x693: 0x457a, 0x696: 0x36bb, 0x697: 0x3e10, - 0x698: 0x3631, 0x699: 0x362b, 0x69a: 0x361f, 0x69b: 0x4396, 0x69d: 0x4534, - 0x69e: 0x453b, 0x69f: 0x4542, 0x6a0: 0x36eb, 0x6a1: 0x36e5, 0x6a2: 0x3e68, 0x6a3: 0x4582, - 0x6a4: 0x36cd, 0x6a5: 0x36d3, 0x6a6: 0x36f1, 0x6a7: 0x3e78, 0x6a8: 0x3661, 0x6a9: 0x365b, - 0x6aa: 0x364f, 0x6ab: 0x43a2, 0x6ac: 0x3649, 0x6ad: 0x450a, 0x6ae: 0x4511, 0x6af: 0x0081, - 0x6b2: 0x3eb0, 0x6b3: 0x36f7, 0x6b4: 0x3eb8, - 0x6b6: 0x491e, 0x6b7: 0x3ed0, 0x6b8: 0x363d, 0x6b9: 0x439c, 0x6ba: 0x366d, 0x6bb: 0x43ae, - 0x6bc: 0x3679, 0x6bd: 0x425a, 0x6be: 0x428c, - // Block 0x1b, offset 0x6c0 - 0x6c0: 0x1bd8, 0x6c1: 0x1bdc, 0x6c2: 0x0047, 0x6c3: 0x1c54, 0x6c5: 0x1be8, - 0x6c6: 0x1bec, 0x6c7: 0x00e9, 0x6c9: 0x1c58, 0x6ca: 0x008f, 0x6cb: 0x0051, - 0x6cc: 0x0051, 0x6cd: 0x0051, 0x6ce: 0x0091, 0x6cf: 0x00da, 0x6d0: 0x0053, 0x6d1: 0x0053, - 0x6d2: 0x0059, 0x6d3: 0x0099, 0x6d5: 0x005d, 0x6d6: 0x198d, - 0x6d9: 0x0061, 0x6da: 0x0063, 0x6db: 0x0065, 0x6dc: 0x0065, 0x6dd: 0x0065, - 0x6e0: 0x199f, 0x6e1: 0x1bc8, 0x6e2: 0x19a8, - 0x6e4: 0x0075, 0x6e6: 0x01b8, 0x6e8: 0x0075, - 0x6ea: 0x0057, 0x6eb: 0x42d2, 0x6ec: 0x0045, 0x6ed: 0x0047, 0x6ef: 0x008b, - 0x6f0: 0x004b, 0x6f1: 0x004d, 0x6f3: 0x005b, 0x6f4: 0x009f, 0x6f5: 0x0215, - 0x6f6: 0x0218, 0x6f7: 0x021b, 0x6f8: 0x021e, 0x6f9: 0x0093, 0x6fb: 0x1b98, - 0x6fc: 0x01e8, 0x6fd: 0x01c1, 0x6fe: 0x0179, 0x6ff: 0x01a0, - // Block 0x1c, offset 0x700 - 0x700: 0x0463, 0x705: 0x0049, - 0x706: 0x0089, 0x707: 0x008b, 0x708: 0x0093, 0x709: 0x0095, - 0x710: 0x222e, 0x711: 0x223a, - 0x712: 0x22ee, 0x713: 0x2216, 0x714: 0x229a, 0x715: 0x2222, 0x716: 0x22a0, 0x717: 0x22b8, - 0x718: 0x22c4, 0x719: 0x2228, 0x71a: 0x22ca, 0x71b: 0x2234, 0x71c: 0x22be, 0x71d: 0x22d0, - 0x71e: 0x22d6, 0x71f: 0x1cbc, 0x720: 0x0053, 0x721: 0x195a, 0x722: 0x1ba4, 0x723: 0x1963, - 0x724: 0x006d, 0x725: 0x19ab, 0x726: 0x1bd0, 0x727: 0x1d48, 0x728: 0x1966, 0x729: 0x0071, - 0x72a: 0x19b7, 0x72b: 0x1bd4, 0x72c: 0x0059, 0x72d: 0x0047, 0x72e: 0x0049, 0x72f: 0x005b, - 0x730: 0x0093, 0x731: 0x19e4, 0x732: 0x1c18, 0x733: 0x19ed, 0x734: 0x00ad, 0x735: 0x1a62, - 0x736: 0x1c4c, 0x737: 0x1d5c, 0x738: 0x19f0, 0x739: 0x00b1, 0x73a: 0x1a65, 0x73b: 0x1c50, - 0x73c: 0x0099, 0x73d: 0x0087, 0x73e: 0x0089, 0x73f: 0x009b, - // Block 0x1d, offset 0x740 - 0x741: 0x3c06, 0x743: 0xa000, 0x744: 0x3c0d, 0x745: 0xa000, - 0x747: 0x3c14, 0x748: 0xa000, 0x749: 0x3c1b, - 0x74d: 0xa000, - 0x760: 0x2f65, 0x761: 0xa000, 0x762: 0x3c29, - 0x764: 0xa000, 0x765: 0xa000, - 0x76d: 0x3c22, 0x76e: 0x2f60, 0x76f: 0x2f6a, - 0x770: 0x3c30, 0x771: 0x3c37, 0x772: 0xa000, 0x773: 0xa000, 0x774: 0x3c3e, 0x775: 0x3c45, - 0x776: 0xa000, 0x777: 0xa000, 0x778: 0x3c4c, 0x779: 0x3c53, 0x77a: 0xa000, 0x77b: 0xa000, - 0x77c: 0xa000, 0x77d: 0xa000, - // Block 0x1e, offset 0x780 - 0x780: 0x3c5a, 0x781: 0x3c61, 0x782: 0xa000, 0x783: 0xa000, 0x784: 0x3c76, 0x785: 0x3c7d, - 0x786: 0xa000, 0x787: 0xa000, 0x788: 0x3c84, 0x789: 0x3c8b, - 0x791: 0xa000, - 0x792: 0xa000, - 0x7a2: 0xa000, - 0x7a8: 0xa000, 0x7a9: 0xa000, - 0x7ab: 0xa000, 0x7ac: 0x3ca0, 0x7ad: 0x3ca7, 0x7ae: 0x3cae, 0x7af: 0x3cb5, - 0x7b2: 0xa000, 0x7b3: 0xa000, 0x7b4: 0xa000, 0x7b5: 0xa000, - // Block 0x1f, offset 0x7c0 - 0x7e0: 0x0023, 0x7e1: 0x0025, 0x7e2: 0x0027, 0x7e3: 0x0029, - 0x7e4: 0x002b, 0x7e5: 0x002d, 0x7e6: 0x002f, 0x7e7: 0x0031, 0x7e8: 0x0033, 0x7e9: 0x1882, - 0x7ea: 0x1885, 0x7eb: 0x1888, 0x7ec: 0x188b, 0x7ed: 0x188e, 0x7ee: 0x1891, 0x7ef: 0x1894, - 0x7f0: 0x1897, 0x7f1: 0x189a, 0x7f2: 0x189d, 0x7f3: 0x18a6, 0x7f4: 0x1a68, 0x7f5: 0x1a6c, - 0x7f6: 0x1a70, 0x7f7: 0x1a74, 0x7f8: 0x1a78, 0x7f9: 0x1a7c, 0x7fa: 0x1a80, 0x7fb: 0x1a84, - 0x7fc: 0x1a88, 0x7fd: 0x1c80, 0x7fe: 0x1c85, 0x7ff: 0x1c8a, - // Block 0x20, offset 0x800 - 0x800: 0x1c8f, 0x801: 0x1c94, 0x802: 0x1c99, 0x803: 0x1c9e, 0x804: 0x1ca3, 0x805: 0x1ca8, - 0x806: 0x1cad, 0x807: 0x1cb2, 0x808: 0x187f, 0x809: 0x18a3, 0x80a: 0x18c7, 0x80b: 0x18eb, - 0x80c: 0x190f, 0x80d: 0x1918, 0x80e: 0x191e, 0x80f: 0x1924, 0x810: 0x192a, 0x811: 0x1b60, - 0x812: 0x1b64, 0x813: 0x1b68, 0x814: 0x1b6c, 0x815: 0x1b70, 0x816: 0x1b74, 0x817: 0x1b78, - 0x818: 0x1b7c, 0x819: 0x1b80, 0x81a: 0x1b84, 0x81b: 0x1b88, 0x81c: 0x1af4, 0x81d: 0x1af8, - 0x81e: 0x1afc, 0x81f: 0x1b00, 0x820: 0x1b04, 0x821: 0x1b08, 0x822: 0x1b0c, 0x823: 0x1b10, - 0x824: 0x1b14, 0x825: 0x1b18, 0x826: 0x1b1c, 0x827: 0x1b20, 0x828: 0x1b24, 0x829: 0x1b28, - 0x82a: 0x1b2c, 0x82b: 0x1b30, 0x82c: 0x1b34, 0x82d: 0x1b38, 0x82e: 0x1b3c, 0x82f: 0x1b40, - 0x830: 0x1b44, 0x831: 0x1b48, 0x832: 0x1b4c, 0x833: 0x1b50, 0x834: 0x1b54, 0x835: 0x1b58, - 0x836: 0x0043, 0x837: 0x0045, 0x838: 0x0047, 0x839: 0x0049, 0x83a: 0x004b, 0x83b: 0x004d, - 0x83c: 0x004f, 0x83d: 0x0051, 0x83e: 0x0053, 0x83f: 0x0055, - // Block 0x21, offset 0x840 - 0x840: 0x06bf, 0x841: 0x06e3, 0x842: 0x06ef, 0x843: 0x06ff, 0x844: 0x0707, 0x845: 0x0713, - 0x846: 0x071b, 0x847: 0x0723, 0x848: 0x072f, 0x849: 0x0783, 0x84a: 0x079b, 0x84b: 0x07ab, - 0x84c: 0x07bb, 0x84d: 0x07cb, 0x84e: 0x07db, 0x84f: 0x07fb, 0x850: 0x07ff, 0x851: 0x0803, - 0x852: 0x0837, 0x853: 0x085f, 0x854: 0x086f, 0x855: 0x0877, 0x856: 0x087b, 0x857: 0x0887, - 0x858: 0x08a3, 0x859: 0x08a7, 0x85a: 0x08bf, 0x85b: 0x08c3, 0x85c: 0x08cb, 0x85d: 0x08db, - 0x85e: 0x0977, 0x85f: 0x098b, 0x860: 0x09cb, 0x861: 0x09df, 0x862: 0x09e7, 0x863: 0x09eb, - 0x864: 0x09fb, 0x865: 0x0a17, 0x866: 0x0a43, 0x867: 0x0a4f, 0x868: 0x0a6f, 0x869: 0x0a7b, - 0x86a: 0x0a7f, 0x86b: 0x0a83, 0x86c: 0x0a9b, 0x86d: 0x0a9f, 0x86e: 0x0acb, 0x86f: 0x0ad7, - 0x870: 0x0adf, 0x871: 0x0ae7, 0x872: 0x0af7, 0x873: 0x0aff, 0x874: 0x0b07, 0x875: 0x0b33, - 0x876: 0x0b37, 0x877: 0x0b3f, 0x878: 0x0b43, 0x879: 0x0b4b, 0x87a: 0x0b53, 0x87b: 0x0b63, - 0x87c: 0x0b7f, 0x87d: 0x0bf7, 0x87e: 0x0c0b, 0x87f: 0x0c0f, - // Block 0x22, offset 0x880 - 0x880: 0x0c8f, 0x881: 0x0c93, 0x882: 0x0ca7, 0x883: 0x0cab, 0x884: 0x0cb3, 0x885: 0x0cbb, - 0x886: 0x0cc3, 0x887: 0x0ccf, 0x888: 0x0cf7, 0x889: 0x0d07, 0x88a: 0x0d1b, 0x88b: 0x0d8b, - 0x88c: 0x0d97, 0x88d: 0x0da7, 0x88e: 0x0db3, 0x88f: 0x0dbf, 0x890: 0x0dc7, 0x891: 0x0dcb, - 0x892: 0x0dcf, 0x893: 0x0dd3, 0x894: 0x0dd7, 0x895: 0x0e8f, 0x896: 0x0ed7, 0x897: 0x0ee3, - 0x898: 0x0ee7, 0x899: 0x0eeb, 0x89a: 0x0eef, 0x89b: 0x0ef7, 0x89c: 0x0efb, 0x89d: 0x0f0f, - 0x89e: 0x0f2b, 0x89f: 0x0f33, 0x8a0: 0x0f73, 0x8a1: 0x0f77, 0x8a2: 0x0f7f, 0x8a3: 0x0f83, - 0x8a4: 0x0f8b, 0x8a5: 0x0f8f, 0x8a6: 0x0fb3, 0x8a7: 0x0fb7, 0x8a8: 0x0fd3, 0x8a9: 0x0fd7, - 0x8aa: 0x0fdb, 0x8ab: 0x0fdf, 0x8ac: 0x0ff3, 0x8ad: 0x1017, 0x8ae: 0x101b, 0x8af: 0x101f, - 0x8b0: 0x1043, 0x8b1: 0x1083, 0x8b2: 0x1087, 0x8b3: 0x10a7, 0x8b4: 0x10b7, 0x8b5: 0x10bf, - 0x8b6: 0x10df, 0x8b7: 0x1103, 0x8b8: 0x1147, 0x8b9: 0x114f, 0x8ba: 0x1163, 0x8bb: 0x116f, - 0x8bc: 0x1177, 0x8bd: 0x117f, 0x8be: 0x1183, 0x8bf: 0x1187, - // Block 0x23, offset 0x8c0 - 0x8c0: 0x119f, 0x8c1: 0x11a3, 0x8c2: 0x11bf, 0x8c3: 0x11c7, 0x8c4: 0x11cf, 0x8c5: 0x11d3, - 0x8c6: 0x11df, 0x8c7: 0x11e7, 0x8c8: 0x11eb, 0x8c9: 0x11ef, 0x8ca: 0x11f7, 0x8cb: 0x11fb, - 0x8cc: 0x129b, 0x8cd: 0x12af, 0x8ce: 0x12e3, 0x8cf: 0x12e7, 0x8d0: 0x12ef, 0x8d1: 0x131b, - 0x8d2: 0x1323, 0x8d3: 0x132b, 0x8d4: 0x1333, 0x8d5: 0x136f, 0x8d6: 0x1373, 0x8d7: 0x137b, - 0x8d8: 0x137f, 0x8d9: 0x1383, 0x8da: 0x13af, 0x8db: 0x13b3, 0x8dc: 0x13bb, 0x8dd: 0x13cf, - 0x8de: 0x13d3, 0x8df: 0x13ef, 0x8e0: 0x13f7, 0x8e1: 0x13fb, 0x8e2: 0x141f, 0x8e3: 0x143f, - 0x8e4: 0x1453, 0x8e5: 0x1457, 0x8e6: 0x145f, 0x8e7: 0x148b, 0x8e8: 0x148f, 0x8e9: 0x149f, - 0x8ea: 0x14c3, 0x8eb: 0x14cf, 0x8ec: 0x14df, 0x8ed: 0x14f7, 0x8ee: 0x14ff, 0x8ef: 0x1503, - 0x8f0: 0x1507, 0x8f1: 0x150b, 0x8f2: 0x1517, 0x8f3: 0x151b, 0x8f4: 0x1523, 0x8f5: 0x153f, - 0x8f6: 0x1543, 0x8f7: 0x1547, 0x8f8: 0x155f, 0x8f9: 0x1563, 0x8fa: 0x156b, 0x8fb: 0x157f, - 0x8fc: 0x1583, 0x8fd: 0x1587, 0x8fe: 0x158f, 0x8ff: 0x1593, - // Block 0x24, offset 0x900 - 0x906: 0xa000, 0x90b: 0xa000, - 0x90c: 0x3f08, 0x90d: 0xa000, 0x90e: 0x3f10, 0x90f: 0xa000, 0x910: 0x3f18, 0x911: 0xa000, - 0x912: 0x3f20, 0x913: 0xa000, 0x914: 0x3f28, 0x915: 0xa000, 0x916: 0x3f30, 0x917: 0xa000, - 0x918: 0x3f38, 0x919: 0xa000, 0x91a: 0x3f40, 0x91b: 0xa000, 0x91c: 0x3f48, 0x91d: 0xa000, - 0x91e: 0x3f50, 0x91f: 0xa000, 0x920: 0x3f58, 0x921: 0xa000, 0x922: 0x3f60, - 0x924: 0xa000, 0x925: 0x3f68, 0x926: 0xa000, 0x927: 0x3f70, 0x928: 0xa000, 0x929: 0x3f78, - 0x92f: 0xa000, - 0x930: 0x3f80, 0x931: 0x3f88, 0x932: 0xa000, 0x933: 0x3f90, 0x934: 0x3f98, 0x935: 0xa000, - 0x936: 0x3fa0, 0x937: 0x3fa8, 0x938: 0xa000, 0x939: 0x3fb0, 0x93a: 0x3fb8, 0x93b: 0xa000, - 0x93c: 0x3fc0, 0x93d: 0x3fc8, - // Block 0x25, offset 0x940 - 0x954: 0x3f00, - 0x959: 0x9903, 0x95a: 0x9903, 0x95b: 0x4372, 0x95c: 0x4378, 0x95d: 0xa000, - 0x95e: 0x3fd0, 0x95f: 0x26b4, - 0x966: 0xa000, - 0x96b: 0xa000, 0x96c: 0x3fe0, 0x96d: 0xa000, 0x96e: 0x3fe8, 0x96f: 0xa000, - 0x970: 0x3ff0, 0x971: 0xa000, 0x972: 0x3ff8, 0x973: 0xa000, 0x974: 0x4000, 0x975: 0xa000, - 0x976: 0x4008, 0x977: 0xa000, 0x978: 0x4010, 0x979: 0xa000, 0x97a: 0x4018, 0x97b: 0xa000, - 0x97c: 0x4020, 0x97d: 0xa000, 0x97e: 0x4028, 0x97f: 0xa000, - // Block 0x26, offset 0x980 - 0x980: 0x4030, 0x981: 0xa000, 0x982: 0x4038, 0x984: 0xa000, 0x985: 0x4040, - 0x986: 0xa000, 0x987: 0x4048, 0x988: 0xa000, 0x989: 0x4050, - 0x98f: 0xa000, 0x990: 0x4058, 0x991: 0x4060, - 0x992: 0xa000, 0x993: 0x4068, 0x994: 0x4070, 0x995: 0xa000, 0x996: 0x4078, 0x997: 0x4080, - 0x998: 0xa000, 0x999: 0x4088, 0x99a: 0x4090, 0x99b: 0xa000, 0x99c: 0x4098, 0x99d: 0x40a0, - 0x9af: 0xa000, - 0x9b0: 0xa000, 0x9b1: 0xa000, 0x9b2: 0xa000, 0x9b4: 0x3fd8, - 0x9b7: 0x40a8, 0x9b8: 0x40b0, 0x9b9: 0x40b8, 0x9ba: 0x40c0, - 0x9bd: 0xa000, 0x9be: 0x40c8, 0x9bf: 0x26c9, - // Block 0x27, offset 0x9c0 - 0x9c0: 0x0367, 0x9c1: 0x032b, 0x9c2: 0x032f, 0x9c3: 0x0333, 0x9c4: 0x037b, 0x9c5: 0x0337, - 0x9c6: 0x033b, 0x9c7: 0x033f, 0x9c8: 0x0343, 0x9c9: 0x0347, 0x9ca: 0x034b, 0x9cb: 0x034f, - 0x9cc: 0x0353, 0x9cd: 0x0357, 0x9ce: 0x035b, 0x9cf: 0x42dc, 0x9d0: 0x42e1, 0x9d1: 0x42e6, - 0x9d2: 0x42eb, 0x9d3: 0x42f0, 0x9d4: 0x42f5, 0x9d5: 0x42fa, 0x9d6: 0x42ff, 0x9d7: 0x4304, - 0x9d8: 0x4309, 0x9d9: 0x430e, 0x9da: 0x4313, 0x9db: 0x4318, 0x9dc: 0x431d, 0x9dd: 0x4322, - 0x9de: 0x4327, 0x9df: 0x432c, 0x9e0: 0x4331, 0x9e1: 0x4336, 0x9e2: 0x433b, 0x9e3: 0x4340, - 0x9e4: 0x03c3, 0x9e5: 0x035f, 0x9e6: 0x0363, 0x9e7: 0x03e7, 0x9e8: 0x03eb, 0x9e9: 0x03ef, - 0x9ea: 0x03f3, 0x9eb: 0x03f7, 0x9ec: 0x03fb, 0x9ed: 0x03ff, 0x9ee: 0x036b, 0x9ef: 0x0403, - 0x9f0: 0x0407, 0x9f1: 0x036f, 0x9f2: 0x0373, 0x9f3: 0x0377, 0x9f4: 0x037f, 0x9f5: 0x0383, - 0x9f6: 0x0387, 0x9f7: 0x038b, 0x9f8: 0x038f, 0x9f9: 0x0393, 0x9fa: 0x0397, 0x9fb: 0x039b, - 0x9fc: 0x039f, 0x9fd: 0x03a3, 0x9fe: 0x03a7, 0x9ff: 0x03ab, - // Block 0x28, offset 0xa00 - 0xa00: 0x03af, 0xa01: 0x03b3, 0xa02: 0x040b, 0xa03: 0x040f, 0xa04: 0x03b7, 0xa05: 0x03bb, - 0xa06: 0x03bf, 0xa07: 0x03c7, 0xa08: 0x03cb, 0xa09: 0x03cf, 0xa0a: 0x03d3, 0xa0b: 0x03d7, - 0xa0c: 0x03db, 0xa0d: 0x03df, 0xa0e: 0x03e3, - 0xa12: 0x06bf, 0xa13: 0x071b, 0xa14: 0x06cb, 0xa15: 0x097b, 0xa16: 0x06cf, 0xa17: 0x06e7, - 0xa18: 0x06d3, 0xa19: 0x0f93, 0xa1a: 0x0707, 0xa1b: 0x06db, 0xa1c: 0x06c3, 0xa1d: 0x09ff, - 0xa1e: 0x098f, 0xa1f: 0x072f, - // Block 0x29, offset 0xa40 - 0xa40: 0x2054, 0xa41: 0x205a, 0xa42: 0x2060, 0xa43: 0x2066, 0xa44: 0x206c, 0xa45: 0x2072, - 0xa46: 0x2078, 0xa47: 0x207e, 0xa48: 0x2084, 0xa49: 0x208a, 0xa4a: 0x2090, 0xa4b: 0x2096, - 0xa4c: 0x209c, 0xa4d: 0x20a2, 0xa4e: 0x2726, 0xa4f: 0x272f, 0xa50: 0x2738, 0xa51: 0x2741, - 0xa52: 0x274a, 0xa53: 0x2753, 0xa54: 0x275c, 0xa55: 0x2765, 0xa56: 0x276e, 0xa57: 0x2780, - 0xa58: 0x2789, 0xa59: 0x2792, 0xa5a: 0x279b, 0xa5b: 0x27a4, 0xa5c: 0x2777, 0xa5d: 0x2bac, - 0xa5e: 0x2aed, 0xa60: 0x20a8, 0xa61: 0x20c0, 0xa62: 0x20b4, 0xa63: 0x2108, - 0xa64: 0x20c6, 0xa65: 0x20e4, 0xa66: 0x20ae, 0xa67: 0x20de, 0xa68: 0x20ba, 0xa69: 0x20f0, - 0xa6a: 0x2120, 0xa6b: 0x213e, 0xa6c: 0x2138, 0xa6d: 0x212c, 0xa6e: 0x217a, 0xa6f: 0x210e, - 0xa70: 0x211a, 0xa71: 0x2132, 0xa72: 0x2126, 0xa73: 0x2150, 0xa74: 0x20fc, 0xa75: 0x2144, - 0xa76: 0x216e, 0xa77: 0x2156, 0xa78: 0x20ea, 0xa79: 0x20cc, 0xa7a: 0x2102, 0xa7b: 0x2114, - 0xa7c: 0x214a, 0xa7d: 0x20d2, 0xa7e: 0x2174, 0xa7f: 0x20f6, - // Block 0x2a, offset 0xa80 - 0xa80: 0x215c, 0xa81: 0x20d8, 0xa82: 0x2162, 0xa83: 0x2168, 0xa84: 0x092f, 0xa85: 0x0b03, - 0xa86: 0x0ca7, 0xa87: 0x10c7, - 0xa90: 0x1bc4, 0xa91: 0x18a9, - 0xa92: 0x18ac, 0xa93: 0x18af, 0xa94: 0x18b2, 0xa95: 0x18b5, 0xa96: 0x18b8, 0xa97: 0x18bb, - 0xa98: 0x18be, 0xa99: 0x18c1, 0xa9a: 0x18ca, 0xa9b: 0x18cd, 0xa9c: 0x18d0, 0xa9d: 0x18d3, - 0xa9e: 0x18d6, 0xa9f: 0x18d9, 0xaa0: 0x0313, 0xaa1: 0x031b, 0xaa2: 0x031f, 0xaa3: 0x0327, - 0xaa4: 0x032b, 0xaa5: 0x032f, 0xaa6: 0x0337, 0xaa7: 0x033f, 0xaa8: 0x0343, 0xaa9: 0x034b, - 0xaaa: 0x034f, 0xaab: 0x0353, 0xaac: 0x0357, 0xaad: 0x035b, 0xaae: 0x2e18, 0xaaf: 0x2e20, - 0xab0: 0x2e28, 0xab1: 0x2e30, 0xab2: 0x2e38, 0xab3: 0x2e40, 0xab4: 0x2e48, 0xab5: 0x2e50, - 0xab6: 0x2e60, 0xab7: 0x2e68, 0xab8: 0x2e70, 0xab9: 0x2e78, 0xaba: 0x2e80, 0xabb: 0x2e88, - 0xabc: 0x2ed3, 0xabd: 0x2e9b, 0xabe: 0x2e58, - // Block 0x2b, offset 0xac0 - 0xac0: 0x06bf, 0xac1: 0x071b, 0xac2: 0x06cb, 0xac3: 0x097b, 0xac4: 0x071f, 0xac5: 0x07af, - 0xac6: 0x06c7, 0xac7: 0x07ab, 0xac8: 0x070b, 0xac9: 0x0887, 0xaca: 0x0d07, 0xacb: 0x0e8f, - 0xacc: 0x0dd7, 0xacd: 0x0d1b, 0xace: 0x145f, 0xacf: 0x098b, 0xad0: 0x0ccf, 0xad1: 0x0d4b, - 0xad2: 0x0d0b, 0xad3: 0x104b, 0xad4: 0x08fb, 0xad5: 0x0f03, 0xad6: 0x1387, 0xad7: 0x105f, - 0xad8: 0x0843, 0xad9: 0x108f, 0xada: 0x0f9b, 0xadb: 0x0a17, 0xadc: 0x140f, 0xadd: 0x077f, - 0xade: 0x08ab, 0xadf: 0x0df7, 0xae0: 0x1527, 0xae1: 0x0743, 0xae2: 0x07d3, 0xae3: 0x0d9b, - 0xae4: 0x06cf, 0xae5: 0x06e7, 0xae6: 0x06d3, 0xae7: 0x0adb, 0xae8: 0x08ef, 0xae9: 0x087f, - 0xaea: 0x0a57, 0xaeb: 0x0a4b, 0xaec: 0x0feb, 0xaed: 0x073f, 0xaee: 0x139b, 0xaef: 0x089b, - 0xaf0: 0x09f3, 0xaf1: 0x18dc, 0xaf2: 0x18df, 0xaf3: 0x18e2, 0xaf4: 0x18e5, 0xaf5: 0x18ee, - 0xaf6: 0x18f1, 0xaf7: 0x18f4, 0xaf8: 0x18f7, 0xaf9: 0x18fa, 0xafa: 0x18fd, 0xafb: 0x1900, - 0xafc: 0x1903, 0xafd: 0x1906, 0xafe: 0x1909, 0xaff: 0x1912, - // Block 0x2c, offset 0xb00 - 0xb00: 0x1cc6, 0xb01: 0x1cd5, 0xb02: 0x1ce4, 0xb03: 0x1cf3, 0xb04: 0x1d02, 0xb05: 0x1d11, - 0xb06: 0x1d20, 0xb07: 0x1d2f, 0xb08: 0x1d3e, 0xb09: 0x218c, 0xb0a: 0x219e, 0xb0b: 0x21b0, - 0xb0c: 0x1954, 0xb0d: 0x1c04, 0xb0e: 0x19d2, 0xb0f: 0x1ba8, 0xb10: 0x04cb, 0xb11: 0x04d3, - 0xb12: 0x04db, 0xb13: 0x04e3, 0xb14: 0x04eb, 0xb15: 0x04ef, 0xb16: 0x04f3, 0xb17: 0x04f7, - 0xb18: 0x04fb, 0xb19: 0x04ff, 0xb1a: 0x0503, 0xb1b: 0x0507, 0xb1c: 0x050b, 0xb1d: 0x050f, - 0xb1e: 0x0513, 0xb1f: 0x0517, 0xb20: 0x051b, 0xb21: 0x0523, 0xb22: 0x0527, 0xb23: 0x052b, - 0xb24: 0x052f, 0xb25: 0x0533, 0xb26: 0x0537, 0xb27: 0x053b, 0xb28: 0x053f, 0xb29: 0x0543, - 0xb2a: 0x0547, 0xb2b: 0x054b, 0xb2c: 0x054f, 0xb2d: 0x0553, 0xb2e: 0x0557, 0xb2f: 0x055b, - 0xb30: 0x055f, 0xb31: 0x0563, 0xb32: 0x0567, 0xb33: 0x056f, 0xb34: 0x0577, 0xb35: 0x057f, - 0xb36: 0x0583, 0xb37: 0x0587, 0xb38: 0x058b, 0xb39: 0x058f, 0xb3a: 0x0593, 0xb3b: 0x0597, - 0xb3c: 0x059b, 0xb3d: 0x059f, 0xb3e: 0x05a3, - // Block 0x2d, offset 0xb40 - 0xb40: 0x2b0c, 0xb41: 0x29a8, 0xb42: 0x2b1c, 0xb43: 0x2880, 0xb44: 0x2ee4, 0xb45: 0x288a, - 0xb46: 0x2894, 0xb47: 0x2f28, 0xb48: 0x29b5, 0xb49: 0x289e, 0xb4a: 0x28a8, 0xb4b: 0x28b2, - 0xb4c: 0x29dc, 0xb4d: 0x29e9, 0xb4e: 0x29c2, 0xb4f: 0x29cf, 0xb50: 0x2ea9, 0xb51: 0x29f6, - 0xb52: 0x2a03, 0xb53: 0x2bbe, 0xb54: 0x26bb, 0xb55: 0x2bd1, 0xb56: 0x2be4, 0xb57: 0x2b2c, - 0xb58: 0x2a10, 0xb59: 0x2bf7, 0xb5a: 0x2c0a, 0xb5b: 0x2a1d, 0xb5c: 0x28bc, 0xb5d: 0x28c6, - 0xb5e: 0x2eb7, 0xb5f: 0x2a2a, 0xb60: 0x2b3c, 0xb61: 0x2ef5, 0xb62: 0x28d0, 0xb63: 0x28da, - 0xb64: 0x2a37, 0xb65: 0x28e4, 0xb66: 0x28ee, 0xb67: 0x26d0, 0xb68: 0x26d7, 0xb69: 0x28f8, - 0xb6a: 0x2902, 0xb6b: 0x2c1d, 0xb6c: 0x2a44, 0xb6d: 0x2b4c, 0xb6e: 0x2c30, 0xb6f: 0x2a51, - 0xb70: 0x2916, 0xb71: 0x290c, 0xb72: 0x2f3c, 0xb73: 0x2a5e, 0xb74: 0x2c43, 0xb75: 0x2920, - 0xb76: 0x2b5c, 0xb77: 0x292a, 0xb78: 0x2a78, 0xb79: 0x2934, 0xb7a: 0x2a85, 0xb7b: 0x2f06, - 0xb7c: 0x2a6b, 0xb7d: 0x2b6c, 0xb7e: 0x2a92, 0xb7f: 0x26de, - // Block 0x2e, offset 0xb80 - 0xb80: 0x2f17, 0xb81: 0x293e, 0xb82: 0x2948, 0xb83: 0x2a9f, 0xb84: 0x2952, 0xb85: 0x295c, - 0xb86: 0x2966, 0xb87: 0x2b7c, 0xb88: 0x2aac, 0xb89: 0x26e5, 0xb8a: 0x2c56, 0xb8b: 0x2e90, - 0xb8c: 0x2b8c, 0xb8d: 0x2ab9, 0xb8e: 0x2ec5, 0xb8f: 0x2970, 0xb90: 0x297a, 0xb91: 0x2ac6, - 0xb92: 0x26ec, 0xb93: 0x2ad3, 0xb94: 0x2b9c, 0xb95: 0x26f3, 0xb96: 0x2c69, 0xb97: 0x2984, - 0xb98: 0x1cb7, 0xb99: 0x1ccb, 0xb9a: 0x1cda, 0xb9b: 0x1ce9, 0xb9c: 0x1cf8, 0xb9d: 0x1d07, - 0xb9e: 0x1d16, 0xb9f: 0x1d25, 0xba0: 0x1d34, 0xba1: 0x1d43, 0xba2: 0x2192, 0xba3: 0x21a4, - 0xba4: 0x21b6, 0xba5: 0x21c2, 0xba6: 0x21ce, 0xba7: 0x21da, 0xba8: 0x21e6, 0xba9: 0x21f2, - 0xbaa: 0x21fe, 0xbab: 0x220a, 0xbac: 0x2246, 0xbad: 0x2252, 0xbae: 0x225e, 0xbaf: 0x226a, - 0xbb0: 0x2276, 0xbb1: 0x1c14, 0xbb2: 0x19c6, 0xbb3: 0x1936, 0xbb4: 0x1be4, 0xbb5: 0x1a47, - 0xbb6: 0x1a56, 0xbb7: 0x19cc, 0xbb8: 0x1bfc, 0xbb9: 0x1c00, 0xbba: 0x1960, 0xbbb: 0x2701, - 0xbbc: 0x270f, 0xbbd: 0x26fa, 0xbbe: 0x2708, 0xbbf: 0x2ae0, - // Block 0x2f, offset 0xbc0 - 0xbc0: 0x1a4a, 0xbc1: 0x1a32, 0xbc2: 0x1c60, 0xbc3: 0x1a1a, 0xbc4: 0x19f3, 0xbc5: 0x1969, - 0xbc6: 0x1978, 0xbc7: 0x1948, 0xbc8: 0x1bf0, 0xbc9: 0x1d52, 0xbca: 0x1a4d, 0xbcb: 0x1a35, - 0xbcc: 0x1c64, 0xbcd: 0x1c70, 0xbce: 0x1a26, 0xbcf: 0x19fc, 0xbd0: 0x1957, 0xbd1: 0x1c1c, - 0xbd2: 0x1bb0, 0xbd3: 0x1b9c, 0xbd4: 0x1bcc, 0xbd5: 0x1c74, 0xbd6: 0x1a29, 0xbd7: 0x19c9, - 0xbd8: 0x19ff, 0xbd9: 0x19de, 0xbda: 0x1a41, 0xbdb: 0x1c78, 0xbdc: 0x1a2c, 0xbdd: 0x19c0, - 0xbde: 0x1a02, 0xbdf: 0x1c3c, 0xbe0: 0x1bf4, 0xbe1: 0x1a14, 0xbe2: 0x1c24, 0xbe3: 0x1c40, - 0xbe4: 0x1bf8, 0xbe5: 0x1a17, 0xbe6: 0x1c28, 0xbe7: 0x22e8, 0xbe8: 0x22fc, 0xbe9: 0x1996, - 0xbea: 0x1c20, 0xbeb: 0x1bb4, 0xbec: 0x1ba0, 0xbed: 0x1c48, 0xbee: 0x2716, 0xbef: 0x27ad, - 0xbf0: 0x1a59, 0xbf1: 0x1a44, 0xbf2: 0x1c7c, 0xbf3: 0x1a2f, 0xbf4: 0x1a50, 0xbf5: 0x1a38, - 0xbf6: 0x1c68, 0xbf7: 0x1a1d, 0xbf8: 0x19f6, 0xbf9: 0x1981, 0xbfa: 0x1a53, 0xbfb: 0x1a3b, - 0xbfc: 0x1c6c, 0xbfd: 0x1a20, 0xbfe: 0x19f9, 0xbff: 0x1984, - // Block 0x30, offset 0xc00 - 0xc00: 0x1c2c, 0xc01: 0x1bb8, 0xc02: 0x1d4d, 0xc03: 0x1939, 0xc04: 0x19ba, 0xc05: 0x19bd, - 0xc06: 0x22f5, 0xc07: 0x1b94, 0xc08: 0x19c3, 0xc09: 0x194b, 0xc0a: 0x19e1, 0xc0b: 0x194e, - 0xc0c: 0x19ea, 0xc0d: 0x196c, 0xc0e: 0x196f, 0xc0f: 0x1a05, 0xc10: 0x1a0b, 0xc11: 0x1a0e, - 0xc12: 0x1c30, 0xc13: 0x1a11, 0xc14: 0x1a23, 0xc15: 0x1c38, 0xc16: 0x1c44, 0xc17: 0x1990, - 0xc18: 0x1d57, 0xc19: 0x1bbc, 0xc1a: 0x1993, 0xc1b: 0x1a5c, 0xc1c: 0x19a5, 0xc1d: 0x19b4, - 0xc1e: 0x22e2, 0xc1f: 0x22dc, 0xc20: 0x1cc1, 0xc21: 0x1cd0, 0xc22: 0x1cdf, 0xc23: 0x1cee, - 0xc24: 0x1cfd, 0xc25: 0x1d0c, 0xc26: 0x1d1b, 0xc27: 0x1d2a, 0xc28: 0x1d39, 0xc29: 0x2186, - 0xc2a: 0x2198, 0xc2b: 0x21aa, 0xc2c: 0x21bc, 0xc2d: 0x21c8, 0xc2e: 0x21d4, 0xc2f: 0x21e0, - 0xc30: 0x21ec, 0xc31: 0x21f8, 0xc32: 0x2204, 0xc33: 0x2240, 0xc34: 0x224c, 0xc35: 0x2258, - 0xc36: 0x2264, 0xc37: 0x2270, 0xc38: 0x227c, 0xc39: 0x2282, 0xc3a: 0x2288, 0xc3b: 0x228e, - 0xc3c: 0x2294, 0xc3d: 0x22a6, 0xc3e: 0x22ac, 0xc3f: 0x1c10, - // Block 0x31, offset 0xc40 - 0xc40: 0x1377, 0xc41: 0x0cfb, 0xc42: 0x13d3, 0xc43: 0x139f, 0xc44: 0x0e57, 0xc45: 0x06eb, - 0xc46: 0x08df, 0xc47: 0x162b, 0xc48: 0x162b, 0xc49: 0x0a0b, 0xc4a: 0x145f, 0xc4b: 0x0943, - 0xc4c: 0x0a07, 0xc4d: 0x0bef, 0xc4e: 0x0fcf, 0xc4f: 0x115f, 0xc50: 0x1297, 0xc51: 0x12d3, - 0xc52: 0x1307, 0xc53: 0x141b, 0xc54: 0x0d73, 0xc55: 0x0dff, 0xc56: 0x0eab, 0xc57: 0x0f43, - 0xc58: 0x125f, 0xc59: 0x1447, 0xc5a: 0x1573, 0xc5b: 0x070f, 0xc5c: 0x08b3, 0xc5d: 0x0d87, - 0xc5e: 0x0ecf, 0xc5f: 0x1293, 0xc60: 0x15c3, 0xc61: 0x0ab3, 0xc62: 0x0e77, 0xc63: 0x1283, - 0xc64: 0x1317, 0xc65: 0x0c23, 0xc66: 0x11bb, 0xc67: 0x12df, 0xc68: 0x0b1f, 0xc69: 0x0d0f, - 0xc6a: 0x0e17, 0xc6b: 0x0f1b, 0xc6c: 0x1427, 0xc6d: 0x074f, 0xc6e: 0x07e7, 0xc6f: 0x0853, - 0xc70: 0x0c8b, 0xc71: 0x0d7f, 0xc72: 0x0ecb, 0xc73: 0x0fef, 0xc74: 0x1177, 0xc75: 0x128b, - 0xc76: 0x12a3, 0xc77: 0x13c7, 0xc78: 0x14ef, 0xc79: 0x15a3, 0xc7a: 0x15bf, 0xc7b: 0x102b, - 0xc7c: 0x106b, 0xc7d: 0x1123, 0xc7e: 0x1243, 0xc7f: 0x147b, - // Block 0x32, offset 0xc80 - 0xc80: 0x15cb, 0xc81: 0x134b, 0xc82: 0x09c7, 0xc83: 0x0b3b, 0xc84: 0x10db, 0xc85: 0x119b, - 0xc86: 0x0eff, 0xc87: 0x1033, 0xc88: 0x1397, 0xc89: 0x14e7, 0xc8a: 0x09c3, 0xc8b: 0x0a8f, - 0xc8c: 0x0d77, 0xc8d: 0x0e2b, 0xc8e: 0x0e5f, 0xc8f: 0x1113, 0xc90: 0x113b, 0xc91: 0x14a7, - 0xc92: 0x084f, 0xc93: 0x11a7, 0xc94: 0x07f3, 0xc95: 0x07ef, 0xc96: 0x1097, 0xc97: 0x1127, - 0xc98: 0x125b, 0xc99: 0x14af, 0xc9a: 0x1367, 0xc9b: 0x0c27, 0xc9c: 0x0d73, 0xc9d: 0x1357, - 0xc9e: 0x06f7, 0xc9f: 0x0a63, 0xca0: 0x0b93, 0xca1: 0x0f2f, 0xca2: 0x0faf, 0xca3: 0x0873, - 0xca4: 0x103b, 0xca5: 0x075f, 0xca6: 0x0b77, 0xca7: 0x06d7, 0xca8: 0x0deb, 0xca9: 0x0ca3, - 0xcaa: 0x110f, 0xcab: 0x08c7, 0xcac: 0x09b3, 0xcad: 0x0ffb, 0xcae: 0x1263, 0xcaf: 0x133b, - 0xcb0: 0x0db7, 0xcb1: 0x13f7, 0xcb2: 0x0de3, 0xcb3: 0x0c37, 0xcb4: 0x121b, 0xcb5: 0x0c57, - 0xcb6: 0x0fab, 0xcb7: 0x072b, 0xcb8: 0x07a7, 0xcb9: 0x07eb, 0xcba: 0x0d53, 0xcbb: 0x10fb, - 0xcbc: 0x11f3, 0xcbd: 0x1347, 0xcbe: 0x145b, 0xcbf: 0x085b, - // Block 0x33, offset 0xcc0 - 0xcc0: 0x090f, 0xcc1: 0x0a17, 0xcc2: 0x0b2f, 0xcc3: 0x0cbf, 0xcc4: 0x0e7b, 0xcc5: 0x103f, - 0xcc6: 0x1497, 0xcc7: 0x157b, 0xcc8: 0x15cf, 0xcc9: 0x15e7, 0xcca: 0x0837, 0xccb: 0x0cf3, - 0xccc: 0x0da3, 0xccd: 0x13eb, 0xcce: 0x0afb, 0xccf: 0x0bd7, 0xcd0: 0x0bf3, 0xcd1: 0x0c83, - 0xcd2: 0x0e6b, 0xcd3: 0x0eb7, 0xcd4: 0x0f67, 0xcd5: 0x108b, 0xcd6: 0x112f, 0xcd7: 0x1193, - 0xcd8: 0x13db, 0xcd9: 0x126b, 0xcda: 0x1403, 0xcdb: 0x147f, 0xcdc: 0x080f, 0xcdd: 0x083b, - 0xcde: 0x0923, 0xcdf: 0x0ea7, 0xce0: 0x12f3, 0xce1: 0x133b, 0xce2: 0x0b1b, 0xce3: 0x0b8b, - 0xce4: 0x0c4f, 0xce5: 0x0daf, 0xce6: 0x10d7, 0xce7: 0x0f23, 0xce8: 0x073b, 0xce9: 0x097f, - 0xcea: 0x0a63, 0xceb: 0x0ac7, 0xcec: 0x0b97, 0xced: 0x0f3f, 0xcee: 0x0f5b, 0xcef: 0x116b, - 0xcf0: 0x118b, 0xcf1: 0x1463, 0xcf2: 0x14e3, 0xcf3: 0x14f3, 0xcf4: 0x152f, 0xcf5: 0x0753, - 0xcf6: 0x107f, 0xcf7: 0x144f, 0xcf8: 0x14cb, 0xcf9: 0x0baf, 0xcfa: 0x0717, 0xcfb: 0x0777, - 0xcfc: 0x0a67, 0xcfd: 0x0a87, 0xcfe: 0x0caf, 0xcff: 0x0d73, - // Block 0x34, offset 0xd00 - 0xd00: 0x0ec3, 0xd01: 0x0fcb, 0xd02: 0x1277, 0xd03: 0x1417, 0xd04: 0x1623, 0xd05: 0x0ce3, - 0xd06: 0x14a3, 0xd07: 0x0833, 0xd08: 0x0d2f, 0xd09: 0x0d3b, 0xd0a: 0x0e0f, 0xd0b: 0x0e47, - 0xd0c: 0x0f4b, 0xd0d: 0x0fa7, 0xd0e: 0x1027, 0xd0f: 0x110b, 0xd10: 0x153b, 0xd11: 0x07af, - 0xd12: 0x0c03, 0xd13: 0x14b3, 0xd14: 0x0767, 0xd15: 0x0aab, 0xd16: 0x0e2f, 0xd17: 0x13df, - 0xd18: 0x0b67, 0xd19: 0x0bb7, 0xd1a: 0x0d43, 0xd1b: 0x0f2f, 0xd1c: 0x14bb, 0xd1d: 0x0817, - 0xd1e: 0x08ff, 0xd1f: 0x0a97, 0xd20: 0x0cd3, 0xd21: 0x0d1f, 0xd22: 0x0d5f, 0xd23: 0x0df3, - 0xd24: 0x0f47, 0xd25: 0x0fbb, 0xd26: 0x1157, 0xd27: 0x12f7, 0xd28: 0x1303, 0xd29: 0x1457, - 0xd2a: 0x14d7, 0xd2b: 0x0883, 0xd2c: 0x0e4b, 0xd2d: 0x0903, 0xd2e: 0x0ec7, 0xd2f: 0x0f6b, - 0xd30: 0x1287, 0xd31: 0x14bf, 0xd32: 0x15ab, 0xd33: 0x15d3, 0xd34: 0x0d37, 0xd35: 0x0e27, - 0xd36: 0x11c3, 0xd37: 0x10b7, 0xd38: 0x10c3, 0xd39: 0x10e7, 0xd3a: 0x0f17, 0xd3b: 0x0e9f, - 0xd3c: 0x1363, 0xd3d: 0x0733, 0xd3e: 0x122b, 0xd3f: 0x081b, - // Block 0x35, offset 0xd40 - 0xd40: 0x080b, 0xd41: 0x0b0b, 0xd42: 0x0c2b, 0xd43: 0x10f3, 0xd44: 0x0a53, 0xd45: 0x0e03, - 0xd46: 0x0cef, 0xd47: 0x13e7, 0xd48: 0x12e7, 0xd49: 0x14ab, 0xd4a: 0x1323, 0xd4b: 0x0b27, - 0xd4c: 0x0787, 0xd4d: 0x095b, 0xd50: 0x09af, - 0xd52: 0x0cdf, 0xd55: 0x07f7, 0xd56: 0x0f1f, 0xd57: 0x0fe3, - 0xd58: 0x1047, 0xd59: 0x1063, 0xd5a: 0x1067, 0xd5b: 0x107b, 0xd5c: 0x14fb, 0xd5d: 0x10eb, - 0xd5e: 0x116f, 0xd60: 0x128f, 0xd62: 0x1353, - 0xd65: 0x1407, 0xd66: 0x1433, - 0xd6a: 0x154f, 0xd6b: 0x1553, 0xd6c: 0x1557, 0xd6d: 0x15bb, 0xd6e: 0x142b, 0xd6f: 0x14c7, - 0xd70: 0x0757, 0xd71: 0x077b, 0xd72: 0x078f, 0xd73: 0x084b, 0xd74: 0x0857, 0xd75: 0x0897, - 0xd76: 0x094b, 0xd77: 0x0967, 0xd78: 0x096f, 0xd79: 0x09ab, 0xd7a: 0x09b7, 0xd7b: 0x0a93, - 0xd7c: 0x0a9b, 0xd7d: 0x0ba3, 0xd7e: 0x0bcb, 0xd7f: 0x0bd3, - // Block 0x36, offset 0xd80 - 0xd80: 0x0beb, 0xd81: 0x0c97, 0xd82: 0x0cc7, 0xd83: 0x0ce7, 0xd84: 0x0d57, 0xd85: 0x0e1b, - 0xd86: 0x0e37, 0xd87: 0x0e67, 0xd88: 0x0ebb, 0xd89: 0x0edb, 0xd8a: 0x0f4f, 0xd8b: 0x102f, - 0xd8c: 0x104b, 0xd8d: 0x1053, 0xd8e: 0x104f, 0xd8f: 0x1057, 0xd90: 0x105b, 0xd91: 0x105f, - 0xd92: 0x1073, 0xd93: 0x1077, 0xd94: 0x109b, 0xd95: 0x10af, 0xd96: 0x10cb, 0xd97: 0x112f, - 0xd98: 0x1137, 0xd99: 0x113f, 0xd9a: 0x1153, 0xd9b: 0x117b, 0xd9c: 0x11cb, 0xd9d: 0x11ff, - 0xd9e: 0x11ff, 0xd9f: 0x1267, 0xda0: 0x130f, 0xda1: 0x1327, 0xda2: 0x135b, 0xda3: 0x135f, - 0xda4: 0x13a3, 0xda5: 0x13a7, 0xda6: 0x13ff, 0xda7: 0x1407, 0xda8: 0x14db, 0xda9: 0x151f, - 0xdaa: 0x1537, 0xdab: 0x0b9b, 0xdac: 0x171e, 0xdad: 0x11e3, - 0xdb0: 0x06df, 0xdb1: 0x07e3, 0xdb2: 0x07a3, 0xdb3: 0x074b, 0xdb4: 0x078b, 0xdb5: 0x07b7, - 0xdb6: 0x0847, 0xdb7: 0x0863, 0xdb8: 0x094b, 0xdb9: 0x0937, 0xdba: 0x0947, 0xdbb: 0x0963, - 0xdbc: 0x09af, 0xdbd: 0x09bf, 0xdbe: 0x0a03, 0xdbf: 0x0a0f, - // Block 0x37, offset 0xdc0 - 0xdc0: 0x0a2b, 0xdc1: 0x0a3b, 0xdc2: 0x0b23, 0xdc3: 0x0b2b, 0xdc4: 0x0b5b, 0xdc5: 0x0b7b, - 0xdc6: 0x0bab, 0xdc7: 0x0bc3, 0xdc8: 0x0bb3, 0xdc9: 0x0bd3, 0xdca: 0x0bc7, 0xdcb: 0x0beb, - 0xdcc: 0x0c07, 0xdcd: 0x0c5f, 0xdce: 0x0c6b, 0xdcf: 0x0c73, 0xdd0: 0x0c9b, 0xdd1: 0x0cdf, - 0xdd2: 0x0d0f, 0xdd3: 0x0d13, 0xdd4: 0x0d27, 0xdd5: 0x0da7, 0xdd6: 0x0db7, 0xdd7: 0x0e0f, - 0xdd8: 0x0e5b, 0xdd9: 0x0e53, 0xdda: 0x0e67, 0xddb: 0x0e83, 0xddc: 0x0ebb, 0xddd: 0x1013, - 0xdde: 0x0edf, 0xddf: 0x0f13, 0xde0: 0x0f1f, 0xde1: 0x0f5f, 0xde2: 0x0f7b, 0xde3: 0x0f9f, - 0xde4: 0x0fc3, 0xde5: 0x0fc7, 0xde6: 0x0fe3, 0xde7: 0x0fe7, 0xde8: 0x0ff7, 0xde9: 0x100b, - 0xdea: 0x1007, 0xdeb: 0x1037, 0xdec: 0x10b3, 0xded: 0x10cb, 0xdee: 0x10e3, 0xdef: 0x111b, - 0xdf0: 0x112f, 0xdf1: 0x114b, 0xdf2: 0x117b, 0xdf3: 0x122f, 0xdf4: 0x1257, 0xdf5: 0x12cb, - 0xdf6: 0x1313, 0xdf7: 0x131f, 0xdf8: 0x1327, 0xdf9: 0x133f, 0xdfa: 0x1353, 0xdfb: 0x1343, - 0xdfc: 0x135b, 0xdfd: 0x1357, 0xdfe: 0x134f, 0xdff: 0x135f, - // Block 0x38, offset 0xe00 - 0xe00: 0x136b, 0xe01: 0x13a7, 0xe02: 0x13e3, 0xe03: 0x1413, 0xe04: 0x144b, 0xe05: 0x146b, - 0xe06: 0x14b7, 0xe07: 0x14db, 0xe08: 0x14fb, 0xe09: 0x150f, 0xe0a: 0x151f, 0xe0b: 0x152b, - 0xe0c: 0x1537, 0xe0d: 0x158b, 0xe0e: 0x162b, 0xe0f: 0x16b5, 0xe10: 0x16b0, 0xe11: 0x16e2, - 0xe12: 0x0607, 0xe13: 0x062f, 0xe14: 0x0633, 0xe15: 0x1764, 0xe16: 0x1791, 0xe17: 0x1809, - 0xe18: 0x1617, 0xe19: 0x1627, - // Block 0x39, offset 0xe40 - 0xe40: 0x19d5, 0xe41: 0x19d8, 0xe42: 0x19db, 0xe43: 0x1c08, 0xe44: 0x1c0c, 0xe45: 0x1a5f, - 0xe46: 0x1a5f, - 0xe53: 0x1d75, 0xe54: 0x1d66, 0xe55: 0x1d6b, 0xe56: 0x1d7a, 0xe57: 0x1d70, - 0xe5d: 0x4426, - 0xe5e: 0x8115, 0xe5f: 0x4498, 0xe60: 0x022d, 0xe61: 0x0215, 0xe62: 0x021e, 0xe63: 0x0221, - 0xe64: 0x0224, 0xe65: 0x0227, 0xe66: 0x022a, 0xe67: 0x0230, 0xe68: 0x0233, 0xe69: 0x0017, - 0xe6a: 0x4486, 0xe6b: 0x448c, 0xe6c: 0x458a, 0xe6d: 0x4592, 0xe6e: 0x43de, 0xe6f: 0x43e4, - 0xe70: 0x43ea, 0xe71: 0x43f0, 0xe72: 0x43fc, 0xe73: 0x4402, 0xe74: 0x4408, 0xe75: 0x4414, - 0xe76: 0x441a, 0xe78: 0x4420, 0xe79: 0x442c, 0xe7a: 0x4432, 0xe7b: 0x4438, - 0xe7c: 0x4444, 0xe7e: 0x444a, - // Block 0x3a, offset 0xe80 - 0xe80: 0x4450, 0xe81: 0x4456, 0xe83: 0x445c, 0xe84: 0x4462, - 0xe86: 0x446e, 0xe87: 0x4474, 0xe88: 0x447a, 0xe89: 0x4480, 0xe8a: 0x4492, 0xe8b: 0x440e, - 0xe8c: 0x43f6, 0xe8d: 0x443e, 0xe8e: 0x4468, 0xe8f: 0x1d7f, 0xe90: 0x0299, 0xe91: 0x0299, - 0xe92: 0x02a2, 0xe93: 0x02a2, 0xe94: 0x02a2, 0xe95: 0x02a2, 0xe96: 0x02a5, 0xe97: 0x02a5, - 0xe98: 0x02a5, 0xe99: 0x02a5, 0xe9a: 0x02ab, 0xe9b: 0x02ab, 0xe9c: 0x02ab, 0xe9d: 0x02ab, - 0xe9e: 0x029f, 0xe9f: 0x029f, 0xea0: 0x029f, 0xea1: 0x029f, 0xea2: 0x02a8, 0xea3: 0x02a8, - 0xea4: 0x02a8, 0xea5: 0x02a8, 0xea6: 0x029c, 0xea7: 0x029c, 0xea8: 0x029c, 0xea9: 0x029c, - 0xeaa: 0x02cf, 0xeab: 0x02cf, 0xeac: 0x02cf, 0xead: 0x02cf, 0xeae: 0x02d2, 0xeaf: 0x02d2, - 0xeb0: 0x02d2, 0xeb1: 0x02d2, 0xeb2: 0x02b1, 0xeb3: 0x02b1, 0xeb4: 0x02b1, 0xeb5: 0x02b1, - 0xeb6: 0x02ae, 0xeb7: 0x02ae, 0xeb8: 0x02ae, 0xeb9: 0x02ae, 0xeba: 0x02b4, 0xebb: 0x02b4, - 0xebc: 0x02b4, 0xebd: 0x02b4, 0xebe: 0x02b7, 0xebf: 0x02b7, - // Block 0x3b, offset 0xec0 - 0xec0: 0x02b7, 0xec1: 0x02b7, 0xec2: 0x02c0, 0xec3: 0x02c0, 0xec4: 0x02bd, 0xec5: 0x02bd, - 0xec6: 0x02c3, 0xec7: 0x02c3, 0xec8: 0x02ba, 0xec9: 0x02ba, 0xeca: 0x02c9, 0xecb: 0x02c9, - 0xecc: 0x02c6, 0xecd: 0x02c6, 0xece: 0x02d5, 0xecf: 0x02d5, 0xed0: 0x02d5, 0xed1: 0x02d5, - 0xed2: 0x02db, 0xed3: 0x02db, 0xed4: 0x02db, 0xed5: 0x02db, 0xed6: 0x02e1, 0xed7: 0x02e1, - 0xed8: 0x02e1, 0xed9: 0x02e1, 0xeda: 0x02de, 0xedb: 0x02de, 0xedc: 0x02de, 0xedd: 0x02de, - 0xede: 0x02e4, 0xedf: 0x02e4, 0xee0: 0x02e7, 0xee1: 0x02e7, 0xee2: 0x02e7, 0xee3: 0x02e7, - 0xee4: 0x4504, 0xee5: 0x4504, 0xee6: 0x02ed, 0xee7: 0x02ed, 0xee8: 0x02ed, 0xee9: 0x02ed, - 0xeea: 0x02ea, 0xeeb: 0x02ea, 0xeec: 0x02ea, 0xeed: 0x02ea, 0xeee: 0x0308, 0xeef: 0x0308, - 0xef0: 0x44fe, 0xef1: 0x44fe, - // Block 0x3c, offset 0xf00 - 0xf13: 0x02d8, 0xf14: 0x02d8, 0xf15: 0x02d8, 0xf16: 0x02d8, 0xf17: 0x02f6, - 0xf18: 0x02f6, 0xf19: 0x02f3, 0xf1a: 0x02f3, 0xf1b: 0x02f9, 0xf1c: 0x02f9, 0xf1d: 0x204f, - 0xf1e: 0x02ff, 0xf1f: 0x02ff, 0xf20: 0x02f0, 0xf21: 0x02f0, 0xf22: 0x02fc, 0xf23: 0x02fc, - 0xf24: 0x0305, 0xf25: 0x0305, 0xf26: 0x0305, 0xf27: 0x0305, 0xf28: 0x028d, 0xf29: 0x028d, - 0xf2a: 0x25aa, 0xf2b: 0x25aa, 0xf2c: 0x261a, 0xf2d: 0x261a, 0xf2e: 0x25e9, 0xf2f: 0x25e9, - 0xf30: 0x2605, 0xf31: 0x2605, 0xf32: 0x25fe, 0xf33: 0x25fe, 0xf34: 0x260c, 0xf35: 0x260c, - 0xf36: 0x2613, 0xf37: 0x2613, 0xf38: 0x2613, 0xf39: 0x25f0, 0xf3a: 0x25f0, 0xf3b: 0x25f0, - 0xf3c: 0x0302, 0xf3d: 0x0302, 0xf3e: 0x0302, 0xf3f: 0x0302, - // Block 0x3d, offset 0xf40 - 0xf40: 0x25b1, 0xf41: 0x25b8, 0xf42: 0x25d4, 0xf43: 0x25f0, 0xf44: 0x25f7, 0xf45: 0x1d89, - 0xf46: 0x1d8e, 0xf47: 0x1d93, 0xf48: 0x1da2, 0xf49: 0x1db1, 0xf4a: 0x1db6, 0xf4b: 0x1dbb, - 0xf4c: 0x1dc0, 0xf4d: 0x1dc5, 0xf4e: 0x1dd4, 0xf4f: 0x1de3, 0xf50: 0x1de8, 0xf51: 0x1ded, - 0xf52: 0x1dfc, 0xf53: 0x1e0b, 0xf54: 0x1e10, 0xf55: 0x1e15, 0xf56: 0x1e1a, 0xf57: 0x1e29, - 0xf58: 0x1e2e, 0xf59: 0x1e3d, 0xf5a: 0x1e42, 0xf5b: 0x1e47, 0xf5c: 0x1e56, 0xf5d: 0x1e5b, - 0xf5e: 0x1e60, 0xf5f: 0x1e6a, 0xf60: 0x1ea6, 0xf61: 0x1eb5, 0xf62: 0x1ec4, 0xf63: 0x1ec9, - 0xf64: 0x1ece, 0xf65: 0x1ed8, 0xf66: 0x1ee7, 0xf67: 0x1eec, 0xf68: 0x1efb, 0xf69: 0x1f00, - 0xf6a: 0x1f05, 0xf6b: 0x1f14, 0xf6c: 0x1f19, 0xf6d: 0x1f28, 0xf6e: 0x1f2d, 0xf6f: 0x1f32, - 0xf70: 0x1f37, 0xf71: 0x1f3c, 0xf72: 0x1f41, 0xf73: 0x1f46, 0xf74: 0x1f4b, 0xf75: 0x1f50, - 0xf76: 0x1f55, 0xf77: 0x1f5a, 0xf78: 0x1f5f, 0xf79: 0x1f64, 0xf7a: 0x1f69, 0xf7b: 0x1f6e, - 0xf7c: 0x1f73, 0xf7d: 0x1f78, 0xf7e: 0x1f7d, 0xf7f: 0x1f87, - // Block 0x3e, offset 0xf80 - 0xf80: 0x1f8c, 0xf81: 0x1f91, 0xf82: 0x1f96, 0xf83: 0x1fa0, 0xf84: 0x1fa5, 0xf85: 0x1faf, - 0xf86: 0x1fb4, 0xf87: 0x1fb9, 0xf88: 0x1fbe, 0xf89: 0x1fc3, 0xf8a: 0x1fc8, 0xf8b: 0x1fcd, - 0xf8c: 0x1fd2, 0xf8d: 0x1fd7, 0xf8e: 0x1fe6, 0xf8f: 0x1ff5, 0xf90: 0x1ffa, 0xf91: 0x1fff, - 0xf92: 0x2004, 0xf93: 0x2009, 0xf94: 0x200e, 0xf95: 0x2018, 0xf96: 0x201d, 0xf97: 0x2022, - 0xf98: 0x2031, 0xf99: 0x2040, 0xf9a: 0x2045, 0xf9b: 0x44b6, 0xf9c: 0x44bc, 0xf9d: 0x44f2, - 0xf9e: 0x4549, 0xf9f: 0x4550, 0xfa0: 0x4557, 0xfa1: 0x455e, 0xfa2: 0x4565, 0xfa3: 0x456c, - 0xfa4: 0x25c6, 0xfa5: 0x25cd, 0xfa6: 0x25d4, 0xfa7: 0x25db, 0xfa8: 0x25f0, 0xfa9: 0x25f7, - 0xfaa: 0x1d98, 0xfab: 0x1d9d, 0xfac: 0x1da2, 0xfad: 0x1da7, 0xfae: 0x1db1, 0xfaf: 0x1db6, - 0xfb0: 0x1dca, 0xfb1: 0x1dcf, 0xfb2: 0x1dd4, 0xfb3: 0x1dd9, 0xfb4: 0x1de3, 0xfb5: 0x1de8, - 0xfb6: 0x1df2, 0xfb7: 0x1df7, 0xfb8: 0x1dfc, 0xfb9: 0x1e01, 0xfba: 0x1e0b, 0xfbb: 0x1e10, - 0xfbc: 0x1f3c, 0xfbd: 0x1f41, 0xfbe: 0x1f50, 0xfbf: 0x1f55, - // Block 0x3f, offset 0xfc0 - 0xfc0: 0x1f5a, 0xfc1: 0x1f6e, 0xfc2: 0x1f73, 0xfc3: 0x1f78, 0xfc4: 0x1f7d, 0xfc5: 0x1f96, - 0xfc6: 0x1fa0, 0xfc7: 0x1fa5, 0xfc8: 0x1faa, 0xfc9: 0x1fbe, 0xfca: 0x1fdc, 0xfcb: 0x1fe1, - 0xfcc: 0x1fe6, 0xfcd: 0x1feb, 0xfce: 0x1ff5, 0xfcf: 0x1ffa, 0xfd0: 0x44f2, 0xfd1: 0x2027, - 0xfd2: 0x202c, 0xfd3: 0x2031, 0xfd4: 0x2036, 0xfd5: 0x2040, 0xfd6: 0x2045, 0xfd7: 0x25b1, - 0xfd8: 0x25b8, 0xfd9: 0x25bf, 0xfda: 0x25d4, 0xfdb: 0x25e2, 0xfdc: 0x1d89, 0xfdd: 0x1d8e, - 0xfde: 0x1d93, 0xfdf: 0x1da2, 0xfe0: 0x1dac, 0xfe1: 0x1dbb, 0xfe2: 0x1dc0, 0xfe3: 0x1dc5, - 0xfe4: 0x1dd4, 0xfe5: 0x1dde, 0xfe6: 0x1dfc, 0xfe7: 0x1e15, 0xfe8: 0x1e1a, 0xfe9: 0x1e29, - 0xfea: 0x1e2e, 0xfeb: 0x1e3d, 0xfec: 0x1e47, 0xfed: 0x1e56, 0xfee: 0x1e5b, 0xfef: 0x1e60, - 0xff0: 0x1e6a, 0xff1: 0x1ea6, 0xff2: 0x1eab, 0xff3: 0x1eb5, 0xff4: 0x1ec4, 0xff5: 0x1ec9, - 0xff6: 0x1ece, 0xff7: 0x1ed8, 0xff8: 0x1ee7, 0xff9: 0x1efb, 0xffa: 0x1f00, 0xffb: 0x1f05, - 0xffc: 0x1f14, 0xffd: 0x1f19, 0xffe: 0x1f28, 0xfff: 0x1f2d, - // Block 0x40, offset 0x1000 - 0x1000: 0x1f32, 0x1001: 0x1f37, 0x1002: 0x1f46, 0x1003: 0x1f4b, 0x1004: 0x1f5f, 0x1005: 0x1f64, - 0x1006: 0x1f69, 0x1007: 0x1f6e, 0x1008: 0x1f73, 0x1009: 0x1f87, 0x100a: 0x1f8c, 0x100b: 0x1f91, - 0x100c: 0x1f96, 0x100d: 0x1f9b, 0x100e: 0x1faf, 0x100f: 0x1fb4, 0x1010: 0x1fb9, 0x1011: 0x1fbe, - 0x1012: 0x1fcd, 0x1013: 0x1fd2, 0x1014: 0x1fd7, 0x1015: 0x1fe6, 0x1016: 0x1ff0, 0x1017: 0x1fff, - 0x1018: 0x2004, 0x1019: 0x44e6, 0x101a: 0x2018, 0x101b: 0x201d, 0x101c: 0x2022, 0x101d: 0x2031, - 0x101e: 0x203b, 0x101f: 0x25d4, 0x1020: 0x25e2, 0x1021: 0x1da2, 0x1022: 0x1dac, 0x1023: 0x1dd4, - 0x1024: 0x1dde, 0x1025: 0x1dfc, 0x1026: 0x1e06, 0x1027: 0x1e6a, 0x1028: 0x1e6f, 0x1029: 0x1e92, - 0x102a: 0x1e97, 0x102b: 0x1f6e, 0x102c: 0x1f73, 0x102d: 0x1f96, 0x102e: 0x1fe6, 0x102f: 0x1ff0, - 0x1030: 0x2031, 0x1031: 0x203b, 0x1032: 0x459a, 0x1033: 0x45a2, 0x1034: 0x45aa, 0x1035: 0x1ef1, - 0x1036: 0x1ef6, 0x1037: 0x1f0a, 0x1038: 0x1f0f, 0x1039: 0x1f1e, 0x103a: 0x1f23, 0x103b: 0x1e74, - 0x103c: 0x1e79, 0x103d: 0x1e9c, 0x103e: 0x1ea1, 0x103f: 0x1e33, - // Block 0x41, offset 0x1040 - 0x1040: 0x1e38, 0x1041: 0x1e1f, 0x1042: 0x1e24, 0x1043: 0x1e4c, 0x1044: 0x1e51, 0x1045: 0x1eba, - 0x1046: 0x1ebf, 0x1047: 0x1edd, 0x1048: 0x1ee2, 0x1049: 0x1e7e, 0x104a: 0x1e83, 0x104b: 0x1e88, - 0x104c: 0x1e92, 0x104d: 0x1e8d, 0x104e: 0x1e65, 0x104f: 0x1eb0, 0x1050: 0x1ed3, 0x1051: 0x1ef1, - 0x1052: 0x1ef6, 0x1053: 0x1f0a, 0x1054: 0x1f0f, 0x1055: 0x1f1e, 0x1056: 0x1f23, 0x1057: 0x1e74, - 0x1058: 0x1e79, 0x1059: 0x1e9c, 0x105a: 0x1ea1, 0x105b: 0x1e33, 0x105c: 0x1e38, 0x105d: 0x1e1f, - 0x105e: 0x1e24, 0x105f: 0x1e4c, 0x1060: 0x1e51, 0x1061: 0x1eba, 0x1062: 0x1ebf, 0x1063: 0x1edd, - 0x1064: 0x1ee2, 0x1065: 0x1e7e, 0x1066: 0x1e83, 0x1067: 0x1e88, 0x1068: 0x1e92, 0x1069: 0x1e8d, - 0x106a: 0x1e65, 0x106b: 0x1eb0, 0x106c: 0x1ed3, 0x106d: 0x1e7e, 0x106e: 0x1e83, 0x106f: 0x1e88, - 0x1070: 0x1e92, 0x1071: 0x1e6f, 0x1072: 0x1e97, 0x1073: 0x1eec, 0x1074: 0x1e56, 0x1075: 0x1e5b, - 0x1076: 0x1e60, 0x1077: 0x1e7e, 0x1078: 0x1e83, 0x1079: 0x1e88, 0x107a: 0x1eec, 0x107b: 0x1efb, - 0x107c: 0x449e, 0x107d: 0x449e, - // Block 0x42, offset 0x1080 - 0x1090: 0x2311, 0x1091: 0x2326, - 0x1092: 0x2326, 0x1093: 0x232d, 0x1094: 0x2334, 0x1095: 0x2349, 0x1096: 0x2350, 0x1097: 0x2357, - 0x1098: 0x237a, 0x1099: 0x237a, 0x109a: 0x239d, 0x109b: 0x2396, 0x109c: 0x23b2, 0x109d: 0x23a4, - 0x109e: 0x23ab, 0x109f: 0x23ce, 0x10a0: 0x23ce, 0x10a1: 0x23c7, 0x10a2: 0x23d5, 0x10a3: 0x23d5, - 0x10a4: 0x23ff, 0x10a5: 0x23ff, 0x10a6: 0x241b, 0x10a7: 0x23e3, 0x10a8: 0x23e3, 0x10a9: 0x23dc, - 0x10aa: 0x23f1, 0x10ab: 0x23f1, 0x10ac: 0x23f8, 0x10ad: 0x23f8, 0x10ae: 0x2422, 0x10af: 0x2430, - 0x10b0: 0x2430, 0x10b1: 0x2437, 0x10b2: 0x2437, 0x10b3: 0x243e, 0x10b4: 0x2445, 0x10b5: 0x244c, - 0x10b6: 0x2453, 0x10b7: 0x2453, 0x10b8: 0x245a, 0x10b9: 0x2468, 0x10ba: 0x2476, 0x10bb: 0x246f, - 0x10bc: 0x247d, 0x10bd: 0x247d, 0x10be: 0x2492, 0x10bf: 0x2499, - // Block 0x43, offset 0x10c0 - 0x10c0: 0x24ca, 0x10c1: 0x24d8, 0x10c2: 0x24d1, 0x10c3: 0x24b5, 0x10c4: 0x24b5, 0x10c5: 0x24df, - 0x10c6: 0x24df, 0x10c7: 0x24e6, 0x10c8: 0x24e6, 0x10c9: 0x2510, 0x10ca: 0x2517, 0x10cb: 0x251e, - 0x10cc: 0x24f4, 0x10cd: 0x2502, 0x10ce: 0x2525, 0x10cf: 0x252c, - 0x10d2: 0x24fb, 0x10d3: 0x2580, 0x10d4: 0x2587, 0x10d5: 0x255d, 0x10d6: 0x2564, 0x10d7: 0x2548, - 0x10d8: 0x2548, 0x10d9: 0x254f, 0x10da: 0x2579, 0x10db: 0x2572, 0x10dc: 0x259c, 0x10dd: 0x259c, - 0x10de: 0x230a, 0x10df: 0x231f, 0x10e0: 0x2318, 0x10e1: 0x2342, 0x10e2: 0x233b, 0x10e3: 0x2365, - 0x10e4: 0x235e, 0x10e5: 0x2388, 0x10e6: 0x236c, 0x10e7: 0x2381, 0x10e8: 0x23b9, 0x10e9: 0x2406, - 0x10ea: 0x23ea, 0x10eb: 0x2429, 0x10ec: 0x24c3, 0x10ed: 0x24ed, 0x10ee: 0x2595, 0x10ef: 0x258e, - 0x10f0: 0x25a3, 0x10f1: 0x253a, 0x10f2: 0x24a0, 0x10f3: 0x256b, 0x10f4: 0x2492, 0x10f5: 0x24ca, - 0x10f6: 0x2461, 0x10f7: 0x24ae, 0x10f8: 0x2541, 0x10f9: 0x2533, 0x10fa: 0x24bc, 0x10fb: 0x24a7, - 0x10fc: 0x24bc, 0x10fd: 0x2541, 0x10fe: 0x2373, 0x10ff: 0x238f, - // Block 0x44, offset 0x1100 - 0x1100: 0x2509, 0x1101: 0x2484, 0x1102: 0x2303, 0x1103: 0x24a7, 0x1104: 0x244c, 0x1105: 0x241b, - 0x1106: 0x23c0, 0x1107: 0x2556, - 0x1130: 0x2414, 0x1131: 0x248b, 0x1132: 0x27bf, 0x1133: 0x27b6, 0x1134: 0x27ec, 0x1135: 0x27da, - 0x1136: 0x27c8, 0x1137: 0x27e3, 0x1138: 0x27f5, 0x1139: 0x240d, 0x113a: 0x2c7c, 0x113b: 0x2afc, - 0x113c: 0x27d1, - // Block 0x45, offset 0x1140 - 0x1150: 0x0019, 0x1151: 0x0483, - 0x1152: 0x0487, 0x1153: 0x0035, 0x1154: 0x0037, 0x1155: 0x0003, 0x1156: 0x003f, 0x1157: 0x04bf, - 0x1158: 0x04c3, 0x1159: 0x1b5c, - 0x1160: 0x8132, 0x1161: 0x8132, 0x1162: 0x8132, 0x1163: 0x8132, - 0x1164: 0x8132, 0x1165: 0x8132, 0x1166: 0x8132, 0x1167: 0x812d, 0x1168: 0x812d, 0x1169: 0x812d, - 0x116a: 0x812d, 0x116b: 0x812d, 0x116c: 0x812d, 0x116d: 0x812d, 0x116e: 0x8132, 0x116f: 0x8132, - 0x1170: 0x1873, 0x1171: 0x0443, 0x1172: 0x043f, 0x1173: 0x007f, 0x1174: 0x007f, 0x1175: 0x0011, - 0x1176: 0x0013, 0x1177: 0x00b7, 0x1178: 0x00bb, 0x1179: 0x04b7, 0x117a: 0x04bb, 0x117b: 0x04ab, - 0x117c: 0x04af, 0x117d: 0x0493, 0x117e: 0x0497, 0x117f: 0x048b, - // Block 0x46, offset 0x1180 - 0x1180: 0x048f, 0x1181: 0x049b, 0x1182: 0x049f, 0x1183: 0x04a3, 0x1184: 0x04a7, - 0x1187: 0x0077, 0x1188: 0x007b, 0x1189: 0x4269, 0x118a: 0x4269, 0x118b: 0x4269, - 0x118c: 0x4269, 0x118d: 0x007f, 0x118e: 0x007f, 0x118f: 0x007f, 0x1190: 0x0019, 0x1191: 0x0483, - 0x1192: 0x001d, 0x1194: 0x0037, 0x1195: 0x0035, 0x1196: 0x003f, 0x1197: 0x0003, - 0x1198: 0x0443, 0x1199: 0x0011, 0x119a: 0x0013, 0x119b: 0x00b7, 0x119c: 0x00bb, 0x119d: 0x04b7, - 0x119e: 0x04bb, 0x119f: 0x0007, 0x11a0: 0x000d, 0x11a1: 0x0015, 0x11a2: 0x0017, 0x11a3: 0x001b, - 0x11a4: 0x0039, 0x11a5: 0x003d, 0x11a6: 0x003b, 0x11a8: 0x0079, 0x11a9: 0x0009, - 0x11aa: 0x000b, 0x11ab: 0x0041, - 0x11b0: 0x42aa, 0x11b1: 0x44c2, 0x11b2: 0x42af, 0x11b4: 0x42b4, - 0x11b6: 0x42b9, 0x11b7: 0x44c8, 0x11b8: 0x42be, 0x11b9: 0x44ce, 0x11ba: 0x42c3, 0x11bb: 0x44d4, - 0x11bc: 0x42c8, 0x11bd: 0x44da, 0x11be: 0x42cd, 0x11bf: 0x44e0, - // Block 0x47, offset 0x11c0 - 0x11c0: 0x0236, 0x11c1: 0x44a4, 0x11c2: 0x44a4, 0x11c3: 0x44aa, 0x11c4: 0x44aa, 0x11c5: 0x44ec, - 0x11c6: 0x44ec, 0x11c7: 0x44b0, 0x11c8: 0x44b0, 0x11c9: 0x44f8, 0x11ca: 0x44f8, 0x11cb: 0x44f8, - 0x11cc: 0x44f8, 0x11cd: 0x0239, 0x11ce: 0x0239, 0x11cf: 0x023c, 0x11d0: 0x023c, 0x11d1: 0x023c, - 0x11d2: 0x023c, 0x11d3: 0x023f, 0x11d4: 0x023f, 0x11d5: 0x0242, 0x11d6: 0x0242, 0x11d7: 0x0242, - 0x11d8: 0x0242, 0x11d9: 0x0245, 0x11da: 0x0245, 0x11db: 0x0245, 0x11dc: 0x0245, 0x11dd: 0x0248, - 0x11de: 0x0248, 0x11df: 0x0248, 0x11e0: 0x0248, 0x11e1: 0x024b, 0x11e2: 0x024b, 0x11e3: 0x024b, - 0x11e4: 0x024b, 0x11e5: 0x024e, 0x11e6: 0x024e, 0x11e7: 0x024e, 0x11e8: 0x024e, 0x11e9: 0x0251, - 0x11ea: 0x0251, 0x11eb: 0x0254, 0x11ec: 0x0254, 0x11ed: 0x0257, 0x11ee: 0x0257, 0x11ef: 0x025a, - 0x11f0: 0x025a, 0x11f1: 0x025d, 0x11f2: 0x025d, 0x11f3: 0x025d, 0x11f4: 0x025d, 0x11f5: 0x0260, - 0x11f6: 0x0260, 0x11f7: 0x0260, 0x11f8: 0x0260, 0x11f9: 0x0263, 0x11fa: 0x0263, 0x11fb: 0x0263, - 0x11fc: 0x0263, 0x11fd: 0x0266, 0x11fe: 0x0266, 0x11ff: 0x0266, - // Block 0x48, offset 0x1200 - 0x1200: 0x0266, 0x1201: 0x0269, 0x1202: 0x0269, 0x1203: 0x0269, 0x1204: 0x0269, 0x1205: 0x026c, - 0x1206: 0x026c, 0x1207: 0x026c, 0x1208: 0x026c, 0x1209: 0x026f, 0x120a: 0x026f, 0x120b: 0x026f, - 0x120c: 0x026f, 0x120d: 0x0272, 0x120e: 0x0272, 0x120f: 0x0272, 0x1210: 0x0272, 0x1211: 0x0275, - 0x1212: 0x0275, 0x1213: 0x0275, 0x1214: 0x0275, 0x1215: 0x0278, 0x1216: 0x0278, 0x1217: 0x0278, - 0x1218: 0x0278, 0x1219: 0x027b, 0x121a: 0x027b, 0x121b: 0x027b, 0x121c: 0x027b, 0x121d: 0x027e, - 0x121e: 0x027e, 0x121f: 0x027e, 0x1220: 0x027e, 0x1221: 0x0281, 0x1222: 0x0281, 0x1223: 0x0281, - 0x1224: 0x0281, 0x1225: 0x0284, 0x1226: 0x0284, 0x1227: 0x0284, 0x1228: 0x0284, 0x1229: 0x0287, - 0x122a: 0x0287, 0x122b: 0x0287, 0x122c: 0x0287, 0x122d: 0x028a, 0x122e: 0x028a, 0x122f: 0x028d, - 0x1230: 0x028d, 0x1231: 0x0290, 0x1232: 0x0290, 0x1233: 0x0290, 0x1234: 0x0290, 0x1235: 0x2e00, - 0x1236: 0x2e00, 0x1237: 0x2e08, 0x1238: 0x2e08, 0x1239: 0x2e10, 0x123a: 0x2e10, 0x123b: 0x1f82, - 0x123c: 0x1f82, - // Block 0x49, offset 0x1240 - 0x1240: 0x0081, 0x1241: 0x0083, 0x1242: 0x0085, 0x1243: 0x0087, 0x1244: 0x0089, 0x1245: 0x008b, - 0x1246: 0x008d, 0x1247: 0x008f, 0x1248: 0x0091, 0x1249: 0x0093, 0x124a: 0x0095, 0x124b: 0x0097, - 0x124c: 0x0099, 0x124d: 0x009b, 0x124e: 0x009d, 0x124f: 0x009f, 0x1250: 0x00a1, 0x1251: 0x00a3, - 0x1252: 0x00a5, 0x1253: 0x00a7, 0x1254: 0x00a9, 0x1255: 0x00ab, 0x1256: 0x00ad, 0x1257: 0x00af, - 0x1258: 0x00b1, 0x1259: 0x00b3, 0x125a: 0x00b5, 0x125b: 0x00b7, 0x125c: 0x00b9, 0x125d: 0x00bb, - 0x125e: 0x00bd, 0x125f: 0x0477, 0x1260: 0x047b, 0x1261: 0x0487, 0x1262: 0x049b, 0x1263: 0x049f, - 0x1264: 0x0483, 0x1265: 0x05ab, 0x1266: 0x05a3, 0x1267: 0x04c7, 0x1268: 0x04cf, 0x1269: 0x04d7, - 0x126a: 0x04df, 0x126b: 0x04e7, 0x126c: 0x056b, 0x126d: 0x0573, 0x126e: 0x057b, 0x126f: 0x051f, - 0x1270: 0x05af, 0x1271: 0x04cb, 0x1272: 0x04d3, 0x1273: 0x04db, 0x1274: 0x04e3, 0x1275: 0x04eb, - 0x1276: 0x04ef, 0x1277: 0x04f3, 0x1278: 0x04f7, 0x1279: 0x04fb, 0x127a: 0x04ff, 0x127b: 0x0503, - 0x127c: 0x0507, 0x127d: 0x050b, 0x127e: 0x050f, 0x127f: 0x0513, - // Block 0x4a, offset 0x1280 - 0x1280: 0x0517, 0x1281: 0x051b, 0x1282: 0x0523, 0x1283: 0x0527, 0x1284: 0x052b, 0x1285: 0x052f, - 0x1286: 0x0533, 0x1287: 0x0537, 0x1288: 0x053b, 0x1289: 0x053f, 0x128a: 0x0543, 0x128b: 0x0547, - 0x128c: 0x054b, 0x128d: 0x054f, 0x128e: 0x0553, 0x128f: 0x0557, 0x1290: 0x055b, 0x1291: 0x055f, - 0x1292: 0x0563, 0x1293: 0x0567, 0x1294: 0x056f, 0x1295: 0x0577, 0x1296: 0x057f, 0x1297: 0x0583, - 0x1298: 0x0587, 0x1299: 0x058b, 0x129a: 0x058f, 0x129b: 0x0593, 0x129c: 0x0597, 0x129d: 0x05a7, - 0x129e: 0x4a5a, 0x129f: 0x4a60, 0x12a0: 0x03c3, 0x12a1: 0x0313, 0x12a2: 0x0317, 0x12a3: 0x4345, - 0x12a4: 0x031b, 0x12a5: 0x434a, 0x12a6: 0x434f, 0x12a7: 0x031f, 0x12a8: 0x0323, 0x12a9: 0x0327, - 0x12aa: 0x4354, 0x12ab: 0x4359, 0x12ac: 0x435e, 0x12ad: 0x4363, 0x12ae: 0x4368, 0x12af: 0x436d, - 0x12b0: 0x0367, 0x12b1: 0x032b, 0x12b2: 0x032f, 0x12b3: 0x0333, 0x12b4: 0x037b, 0x12b5: 0x0337, - 0x12b6: 0x033b, 0x12b7: 0x033f, 0x12b8: 0x0343, 0x12b9: 0x0347, 0x12ba: 0x034b, 0x12bb: 0x034f, - 0x12bc: 0x0353, 0x12bd: 0x0357, 0x12be: 0x035b, - // Block 0x4b, offset 0x12c0 - 0x12c2: 0x42dc, 0x12c3: 0x42e1, 0x12c4: 0x42e6, 0x12c5: 0x42eb, - 0x12c6: 0x42f0, 0x12c7: 0x42f5, 0x12ca: 0x42fa, 0x12cb: 0x42ff, - 0x12cc: 0x4304, 0x12cd: 0x4309, 0x12ce: 0x430e, 0x12cf: 0x4313, - 0x12d2: 0x4318, 0x12d3: 0x431d, 0x12d4: 0x4322, 0x12d5: 0x4327, 0x12d6: 0x432c, 0x12d7: 0x4331, - 0x12da: 0x4336, 0x12db: 0x433b, 0x12dc: 0x4340, - 0x12e0: 0x00bf, 0x12e1: 0x00c2, 0x12e2: 0x00cb, 0x12e3: 0x4264, - 0x12e4: 0x00c8, 0x12e5: 0x00c5, 0x12e6: 0x0447, 0x12e8: 0x046b, 0x12e9: 0x044b, - 0x12ea: 0x044f, 0x12eb: 0x0453, 0x12ec: 0x0457, 0x12ed: 0x046f, 0x12ee: 0x0473, - // Block 0x4c, offset 0x1300 - 0x1300: 0x0063, 0x1301: 0x0065, 0x1302: 0x0067, 0x1303: 0x0069, 0x1304: 0x006b, 0x1305: 0x006d, - 0x1306: 0x006f, 0x1307: 0x0071, 0x1308: 0x0073, 0x1309: 0x0075, 0x130a: 0x0083, 0x130b: 0x0085, - 0x130c: 0x0087, 0x130d: 0x0089, 0x130e: 0x008b, 0x130f: 0x008d, 0x1310: 0x008f, 0x1311: 0x0091, - 0x1312: 0x0093, 0x1313: 0x0095, 0x1314: 0x0097, 0x1315: 0x0099, 0x1316: 0x009b, 0x1317: 0x009d, - 0x1318: 0x009f, 0x1319: 0x00a1, 0x131a: 0x00a3, 0x131b: 0x00a5, 0x131c: 0x00a7, 0x131d: 0x00a9, - 0x131e: 0x00ab, 0x131f: 0x00ad, 0x1320: 0x00af, 0x1321: 0x00b1, 0x1322: 0x00b3, 0x1323: 0x00b5, - 0x1324: 0x00dd, 0x1325: 0x00f2, 0x1328: 0x0173, 0x1329: 0x0176, - 0x132a: 0x0179, 0x132b: 0x017c, 0x132c: 0x017f, 0x132d: 0x0182, 0x132e: 0x0185, 0x132f: 0x0188, - 0x1330: 0x018b, 0x1331: 0x018e, 0x1332: 0x0191, 0x1333: 0x0194, 0x1334: 0x0197, 0x1335: 0x019a, - 0x1336: 0x019d, 0x1337: 0x01a0, 0x1338: 0x01a3, 0x1339: 0x0188, 0x133a: 0x01a6, 0x133b: 0x01a9, - 0x133c: 0x01ac, 0x133d: 0x01af, 0x133e: 0x01b2, 0x133f: 0x01b5, - // Block 0x4d, offset 0x1340 - 0x1340: 0x01fd, 0x1341: 0x0200, 0x1342: 0x0203, 0x1343: 0x045b, 0x1344: 0x01c7, 0x1345: 0x01d0, - 0x1346: 0x01d6, 0x1347: 0x01fa, 0x1348: 0x01eb, 0x1349: 0x01e8, 0x134a: 0x0206, 0x134b: 0x0209, - 0x134e: 0x0021, 0x134f: 0x0023, 0x1350: 0x0025, 0x1351: 0x0027, - 0x1352: 0x0029, 0x1353: 0x002b, 0x1354: 0x002d, 0x1355: 0x002f, 0x1356: 0x0031, 0x1357: 0x0033, - 0x1358: 0x0021, 0x1359: 0x0023, 0x135a: 0x0025, 0x135b: 0x0027, 0x135c: 0x0029, 0x135d: 0x002b, - 0x135e: 0x002d, 0x135f: 0x002f, 0x1360: 0x0031, 0x1361: 0x0033, 0x1362: 0x0021, 0x1363: 0x0023, - 0x1364: 0x0025, 0x1365: 0x0027, 0x1366: 0x0029, 0x1367: 0x002b, 0x1368: 0x002d, 0x1369: 0x002f, - 0x136a: 0x0031, 0x136b: 0x0033, 0x136c: 0x0021, 0x136d: 0x0023, 0x136e: 0x0025, 0x136f: 0x0027, - 0x1370: 0x0029, 0x1371: 0x002b, 0x1372: 0x002d, 0x1373: 0x002f, 0x1374: 0x0031, 0x1375: 0x0033, - 0x1376: 0x0021, 0x1377: 0x0023, 0x1378: 0x0025, 0x1379: 0x0027, 0x137a: 0x0029, 0x137b: 0x002b, - 0x137c: 0x002d, 0x137d: 0x002f, 0x137e: 0x0031, 0x137f: 0x0033, - // Block 0x4e, offset 0x1380 - 0x1380: 0x0239, 0x1381: 0x023c, 0x1382: 0x0248, 0x1383: 0x0251, 0x1385: 0x028a, - 0x1386: 0x025a, 0x1387: 0x024b, 0x1388: 0x0269, 0x1389: 0x0290, 0x138a: 0x027b, 0x138b: 0x027e, - 0x138c: 0x0281, 0x138d: 0x0284, 0x138e: 0x025d, 0x138f: 0x026f, 0x1390: 0x0275, 0x1391: 0x0263, - 0x1392: 0x0278, 0x1393: 0x0257, 0x1394: 0x0260, 0x1395: 0x0242, 0x1396: 0x0245, 0x1397: 0x024e, - 0x1398: 0x0254, 0x1399: 0x0266, 0x139a: 0x026c, 0x139b: 0x0272, 0x139c: 0x0293, 0x139d: 0x02e4, - 0x139e: 0x02cc, 0x139f: 0x0296, 0x13a1: 0x023c, 0x13a2: 0x0248, - 0x13a4: 0x0287, 0x13a7: 0x024b, 0x13a9: 0x0290, - 0x13aa: 0x027b, 0x13ab: 0x027e, 0x13ac: 0x0281, 0x13ad: 0x0284, 0x13ae: 0x025d, 0x13af: 0x026f, - 0x13b0: 0x0275, 0x13b1: 0x0263, 0x13b2: 0x0278, 0x13b4: 0x0260, 0x13b5: 0x0242, - 0x13b6: 0x0245, 0x13b7: 0x024e, 0x13b9: 0x0266, 0x13bb: 0x0272, - // Block 0x4f, offset 0x13c0 - 0x13c2: 0x0248, - 0x13c7: 0x024b, 0x13c9: 0x0290, 0x13cb: 0x027e, - 0x13cd: 0x0284, 0x13ce: 0x025d, 0x13cf: 0x026f, 0x13d1: 0x0263, - 0x13d2: 0x0278, 0x13d4: 0x0260, 0x13d7: 0x024e, - 0x13d9: 0x0266, 0x13db: 0x0272, 0x13dd: 0x02e4, - 0x13df: 0x0296, 0x13e1: 0x023c, 0x13e2: 0x0248, - 0x13e4: 0x0287, 0x13e7: 0x024b, 0x13e8: 0x0269, 0x13e9: 0x0290, - 0x13ea: 0x027b, 0x13ec: 0x0281, 0x13ed: 0x0284, 0x13ee: 0x025d, 0x13ef: 0x026f, - 0x13f0: 0x0275, 0x13f1: 0x0263, 0x13f2: 0x0278, 0x13f4: 0x0260, 0x13f5: 0x0242, - 0x13f6: 0x0245, 0x13f7: 0x024e, 0x13f9: 0x0266, 0x13fa: 0x026c, 0x13fb: 0x0272, - 0x13fc: 0x0293, 0x13fe: 0x02cc, - // Block 0x50, offset 0x1400 - 0x1400: 0x0239, 0x1401: 0x023c, 0x1402: 0x0248, 0x1403: 0x0251, 0x1404: 0x0287, 0x1405: 0x028a, - 0x1406: 0x025a, 0x1407: 0x024b, 0x1408: 0x0269, 0x1409: 0x0290, 0x140b: 0x027e, - 0x140c: 0x0281, 0x140d: 0x0284, 0x140e: 0x025d, 0x140f: 0x026f, 0x1410: 0x0275, 0x1411: 0x0263, - 0x1412: 0x0278, 0x1413: 0x0257, 0x1414: 0x0260, 0x1415: 0x0242, 0x1416: 0x0245, 0x1417: 0x024e, - 0x1418: 0x0254, 0x1419: 0x0266, 0x141a: 0x026c, 0x141b: 0x0272, - 0x1421: 0x023c, 0x1422: 0x0248, 0x1423: 0x0251, - 0x1425: 0x028a, 0x1426: 0x025a, 0x1427: 0x024b, 0x1428: 0x0269, 0x1429: 0x0290, - 0x142b: 0x027e, 0x142c: 0x0281, 0x142d: 0x0284, 0x142e: 0x025d, 0x142f: 0x026f, - 0x1430: 0x0275, 0x1431: 0x0263, 0x1432: 0x0278, 0x1433: 0x0257, 0x1434: 0x0260, 0x1435: 0x0242, - 0x1436: 0x0245, 0x1437: 0x024e, 0x1438: 0x0254, 0x1439: 0x0266, 0x143a: 0x026c, 0x143b: 0x0272, - // Block 0x51, offset 0x1440 - 0x1440: 0x1879, 0x1441: 0x1876, 0x1442: 0x187c, 0x1443: 0x18a0, 0x1444: 0x18c4, 0x1445: 0x18e8, - 0x1446: 0x190c, 0x1447: 0x1915, 0x1448: 0x191b, 0x1449: 0x1921, 0x144a: 0x1927, - 0x1450: 0x1a8c, 0x1451: 0x1a90, - 0x1452: 0x1a94, 0x1453: 0x1a98, 0x1454: 0x1a9c, 0x1455: 0x1aa0, 0x1456: 0x1aa4, 0x1457: 0x1aa8, - 0x1458: 0x1aac, 0x1459: 0x1ab0, 0x145a: 0x1ab4, 0x145b: 0x1ab8, 0x145c: 0x1abc, 0x145d: 0x1ac0, - 0x145e: 0x1ac4, 0x145f: 0x1ac8, 0x1460: 0x1acc, 0x1461: 0x1ad0, 0x1462: 0x1ad4, 0x1463: 0x1ad8, - 0x1464: 0x1adc, 0x1465: 0x1ae0, 0x1466: 0x1ae4, 0x1467: 0x1ae8, 0x1468: 0x1aec, 0x1469: 0x1af0, - 0x146a: 0x271e, 0x146b: 0x0047, 0x146c: 0x0065, 0x146d: 0x193c, 0x146e: 0x19b1, - 0x1470: 0x0043, 0x1471: 0x0045, 0x1472: 0x0047, 0x1473: 0x0049, 0x1474: 0x004b, 0x1475: 0x004d, - 0x1476: 0x004f, 0x1477: 0x0051, 0x1478: 0x0053, 0x1479: 0x0055, 0x147a: 0x0057, 0x147b: 0x0059, - 0x147c: 0x005b, 0x147d: 0x005d, 0x147e: 0x005f, 0x147f: 0x0061, - // Block 0x52, offset 0x1480 - 0x1480: 0x26ad, 0x1481: 0x26c2, 0x1482: 0x0503, - 0x1490: 0x0c0f, 0x1491: 0x0a47, - 0x1492: 0x08d3, 0x1493: 0x465a, 0x1494: 0x071b, 0x1495: 0x09ef, 0x1496: 0x132f, 0x1497: 0x09ff, - 0x1498: 0x0727, 0x1499: 0x0cd7, 0x149a: 0x0eaf, 0x149b: 0x0caf, 0x149c: 0x0827, 0x149d: 0x0b6b, - 0x149e: 0x07bf, 0x149f: 0x0cb7, 0x14a0: 0x0813, 0x14a1: 0x1117, 0x14a2: 0x0f83, 0x14a3: 0x138b, - 0x14a4: 0x09d3, 0x14a5: 0x090b, 0x14a6: 0x0e63, 0x14a7: 0x0c1b, 0x14a8: 0x0c47, 0x14a9: 0x06bf, - 0x14aa: 0x06cb, 0x14ab: 0x140b, 0x14ac: 0x0adb, 0x14ad: 0x06e7, 0x14ae: 0x08ef, 0x14af: 0x0c3b, - 0x14b0: 0x13b3, 0x14b1: 0x0c13, 0x14b2: 0x106f, 0x14b3: 0x10ab, 0x14b4: 0x08f7, 0x14b5: 0x0e43, - 0x14b6: 0x0d0b, 0x14b7: 0x0d07, 0x14b8: 0x0f97, 0x14b9: 0x082b, 0x14ba: 0x0957, 0x14bb: 0x1443, - // Block 0x53, offset 0x14c0 - 0x14c0: 0x06fb, 0x14c1: 0x06f3, 0x14c2: 0x0703, 0x14c3: 0x1647, 0x14c4: 0x0747, 0x14c5: 0x0757, - 0x14c6: 0x075b, 0x14c7: 0x0763, 0x14c8: 0x076b, 0x14c9: 0x076f, 0x14ca: 0x077b, 0x14cb: 0x0773, - 0x14cc: 0x05b3, 0x14cd: 0x165b, 0x14ce: 0x078f, 0x14cf: 0x0793, 0x14d0: 0x0797, 0x14d1: 0x07b3, - 0x14d2: 0x164c, 0x14d3: 0x05b7, 0x14d4: 0x079f, 0x14d5: 0x07bf, 0x14d6: 0x1656, 0x14d7: 0x07cf, - 0x14d8: 0x07d7, 0x14d9: 0x0737, 0x14da: 0x07df, 0x14db: 0x07e3, 0x14dc: 0x1831, 0x14dd: 0x07ff, - 0x14de: 0x0807, 0x14df: 0x05bf, 0x14e0: 0x081f, 0x14e1: 0x0823, 0x14e2: 0x082b, 0x14e3: 0x082f, - 0x14e4: 0x05c3, 0x14e5: 0x0847, 0x14e6: 0x084b, 0x14e7: 0x0857, 0x14e8: 0x0863, 0x14e9: 0x0867, - 0x14ea: 0x086b, 0x14eb: 0x0873, 0x14ec: 0x0893, 0x14ed: 0x0897, 0x14ee: 0x089f, 0x14ef: 0x08af, - 0x14f0: 0x08b7, 0x14f1: 0x08bb, 0x14f2: 0x08bb, 0x14f3: 0x08bb, 0x14f4: 0x166a, 0x14f5: 0x0e93, - 0x14f6: 0x08cf, 0x14f7: 0x08d7, 0x14f8: 0x166f, 0x14f9: 0x08e3, 0x14fa: 0x08eb, 0x14fb: 0x08f3, - 0x14fc: 0x091b, 0x14fd: 0x0907, 0x14fe: 0x0913, 0x14ff: 0x0917, - // Block 0x54, offset 0x1500 - 0x1500: 0x091f, 0x1501: 0x0927, 0x1502: 0x092b, 0x1503: 0x0933, 0x1504: 0x093b, 0x1505: 0x093f, - 0x1506: 0x093f, 0x1507: 0x0947, 0x1508: 0x094f, 0x1509: 0x0953, 0x150a: 0x095f, 0x150b: 0x0983, - 0x150c: 0x0967, 0x150d: 0x0987, 0x150e: 0x096b, 0x150f: 0x0973, 0x1510: 0x080b, 0x1511: 0x09cf, - 0x1512: 0x0997, 0x1513: 0x099b, 0x1514: 0x099f, 0x1515: 0x0993, 0x1516: 0x09a7, 0x1517: 0x09a3, - 0x1518: 0x09bb, 0x1519: 0x1674, 0x151a: 0x09d7, 0x151b: 0x09db, 0x151c: 0x09e3, 0x151d: 0x09ef, - 0x151e: 0x09f7, 0x151f: 0x0a13, 0x1520: 0x1679, 0x1521: 0x167e, 0x1522: 0x0a1f, 0x1523: 0x0a23, - 0x1524: 0x0a27, 0x1525: 0x0a1b, 0x1526: 0x0a2f, 0x1527: 0x05c7, 0x1528: 0x05cb, 0x1529: 0x0a37, - 0x152a: 0x0a3f, 0x152b: 0x0a3f, 0x152c: 0x1683, 0x152d: 0x0a5b, 0x152e: 0x0a5f, 0x152f: 0x0a63, - 0x1530: 0x0a6b, 0x1531: 0x1688, 0x1532: 0x0a73, 0x1533: 0x0a77, 0x1534: 0x0b4f, 0x1535: 0x0a7f, - 0x1536: 0x05cf, 0x1537: 0x0a8b, 0x1538: 0x0a9b, 0x1539: 0x0aa7, 0x153a: 0x0aa3, 0x153b: 0x1692, - 0x153c: 0x0aaf, 0x153d: 0x1697, 0x153e: 0x0abb, 0x153f: 0x0ab7, - // Block 0x55, offset 0x1540 - 0x1540: 0x0abf, 0x1541: 0x0acf, 0x1542: 0x0ad3, 0x1543: 0x05d3, 0x1544: 0x0ae3, 0x1545: 0x0aeb, - 0x1546: 0x0aef, 0x1547: 0x0af3, 0x1548: 0x05d7, 0x1549: 0x169c, 0x154a: 0x05db, 0x154b: 0x0b0f, - 0x154c: 0x0b13, 0x154d: 0x0b17, 0x154e: 0x0b1f, 0x154f: 0x1863, 0x1550: 0x0b37, 0x1551: 0x16a6, - 0x1552: 0x16a6, 0x1553: 0x11d7, 0x1554: 0x0b47, 0x1555: 0x0b47, 0x1556: 0x05df, 0x1557: 0x16c9, - 0x1558: 0x179b, 0x1559: 0x0b57, 0x155a: 0x0b5f, 0x155b: 0x05e3, 0x155c: 0x0b73, 0x155d: 0x0b83, - 0x155e: 0x0b87, 0x155f: 0x0b8f, 0x1560: 0x0b9f, 0x1561: 0x05eb, 0x1562: 0x05e7, 0x1563: 0x0ba3, - 0x1564: 0x16ab, 0x1565: 0x0ba7, 0x1566: 0x0bbb, 0x1567: 0x0bbf, 0x1568: 0x0bc3, 0x1569: 0x0bbf, - 0x156a: 0x0bcf, 0x156b: 0x0bd3, 0x156c: 0x0be3, 0x156d: 0x0bdb, 0x156e: 0x0bdf, 0x156f: 0x0be7, - 0x1570: 0x0beb, 0x1571: 0x0bef, 0x1572: 0x0bfb, 0x1573: 0x0bff, 0x1574: 0x0c17, 0x1575: 0x0c1f, - 0x1576: 0x0c2f, 0x1577: 0x0c43, 0x1578: 0x16ba, 0x1579: 0x0c3f, 0x157a: 0x0c33, 0x157b: 0x0c4b, - 0x157c: 0x0c53, 0x157d: 0x0c67, 0x157e: 0x16bf, 0x157f: 0x0c6f, - // Block 0x56, offset 0x1580 - 0x1580: 0x0c63, 0x1581: 0x0c5b, 0x1582: 0x05ef, 0x1583: 0x0c77, 0x1584: 0x0c7f, 0x1585: 0x0c87, - 0x1586: 0x0c7b, 0x1587: 0x05f3, 0x1588: 0x0c97, 0x1589: 0x0c9f, 0x158a: 0x16c4, 0x158b: 0x0ccb, - 0x158c: 0x0cff, 0x158d: 0x0cdb, 0x158e: 0x05ff, 0x158f: 0x0ce7, 0x1590: 0x05fb, 0x1591: 0x05f7, - 0x1592: 0x07c3, 0x1593: 0x07c7, 0x1594: 0x0d03, 0x1595: 0x0ceb, 0x1596: 0x11ab, 0x1597: 0x0663, - 0x1598: 0x0d0f, 0x1599: 0x0d13, 0x159a: 0x0d17, 0x159b: 0x0d2b, 0x159c: 0x0d23, 0x159d: 0x16dd, - 0x159e: 0x0603, 0x159f: 0x0d3f, 0x15a0: 0x0d33, 0x15a1: 0x0d4f, 0x15a2: 0x0d57, 0x15a3: 0x16e7, - 0x15a4: 0x0d5b, 0x15a5: 0x0d47, 0x15a6: 0x0d63, 0x15a7: 0x0607, 0x15a8: 0x0d67, 0x15a9: 0x0d6b, - 0x15aa: 0x0d6f, 0x15ab: 0x0d7b, 0x15ac: 0x16ec, 0x15ad: 0x0d83, 0x15ae: 0x060b, 0x15af: 0x0d8f, - 0x15b0: 0x16f1, 0x15b1: 0x0d93, 0x15b2: 0x060f, 0x15b3: 0x0d9f, 0x15b4: 0x0dab, 0x15b5: 0x0db7, - 0x15b6: 0x0dbb, 0x15b7: 0x16f6, 0x15b8: 0x168d, 0x15b9: 0x16fb, 0x15ba: 0x0ddb, 0x15bb: 0x1700, - 0x15bc: 0x0de7, 0x15bd: 0x0def, 0x15be: 0x0ddf, 0x15bf: 0x0dfb, - // Block 0x57, offset 0x15c0 - 0x15c0: 0x0e0b, 0x15c1: 0x0e1b, 0x15c2: 0x0e0f, 0x15c3: 0x0e13, 0x15c4: 0x0e1f, 0x15c5: 0x0e23, - 0x15c6: 0x1705, 0x15c7: 0x0e07, 0x15c8: 0x0e3b, 0x15c9: 0x0e3f, 0x15ca: 0x0613, 0x15cb: 0x0e53, - 0x15cc: 0x0e4f, 0x15cd: 0x170a, 0x15ce: 0x0e33, 0x15cf: 0x0e6f, 0x15d0: 0x170f, 0x15d1: 0x1714, - 0x15d2: 0x0e73, 0x15d3: 0x0e87, 0x15d4: 0x0e83, 0x15d5: 0x0e7f, 0x15d6: 0x0617, 0x15d7: 0x0e8b, - 0x15d8: 0x0e9b, 0x15d9: 0x0e97, 0x15da: 0x0ea3, 0x15db: 0x1651, 0x15dc: 0x0eb3, 0x15dd: 0x1719, - 0x15de: 0x0ebf, 0x15df: 0x1723, 0x15e0: 0x0ed3, 0x15e1: 0x0edf, 0x15e2: 0x0ef3, 0x15e3: 0x1728, - 0x15e4: 0x0f07, 0x15e5: 0x0f0b, 0x15e6: 0x172d, 0x15e7: 0x1732, 0x15e8: 0x0f27, 0x15e9: 0x0f37, - 0x15ea: 0x061b, 0x15eb: 0x0f3b, 0x15ec: 0x061f, 0x15ed: 0x061f, 0x15ee: 0x0f53, 0x15ef: 0x0f57, - 0x15f0: 0x0f5f, 0x15f1: 0x0f63, 0x15f2: 0x0f6f, 0x15f3: 0x0623, 0x15f4: 0x0f87, 0x15f5: 0x1737, - 0x15f6: 0x0fa3, 0x15f7: 0x173c, 0x15f8: 0x0faf, 0x15f9: 0x16a1, 0x15fa: 0x0fbf, 0x15fb: 0x1741, - 0x15fc: 0x1746, 0x15fd: 0x174b, 0x15fe: 0x0627, 0x15ff: 0x062b, - // Block 0x58, offset 0x1600 - 0x1600: 0x0ff7, 0x1601: 0x1755, 0x1602: 0x1750, 0x1603: 0x175a, 0x1604: 0x175f, 0x1605: 0x0fff, - 0x1606: 0x1003, 0x1607: 0x1003, 0x1608: 0x100b, 0x1609: 0x0633, 0x160a: 0x100f, 0x160b: 0x0637, - 0x160c: 0x063b, 0x160d: 0x1769, 0x160e: 0x1023, 0x160f: 0x102b, 0x1610: 0x1037, 0x1611: 0x063f, - 0x1612: 0x176e, 0x1613: 0x105b, 0x1614: 0x1773, 0x1615: 0x1778, 0x1616: 0x107b, 0x1617: 0x1093, - 0x1618: 0x0643, 0x1619: 0x109b, 0x161a: 0x109f, 0x161b: 0x10a3, 0x161c: 0x177d, 0x161d: 0x1782, - 0x161e: 0x1782, 0x161f: 0x10bb, 0x1620: 0x0647, 0x1621: 0x1787, 0x1622: 0x10cf, 0x1623: 0x10d3, - 0x1624: 0x064b, 0x1625: 0x178c, 0x1626: 0x10ef, 0x1627: 0x064f, 0x1628: 0x10ff, 0x1629: 0x10f7, - 0x162a: 0x1107, 0x162b: 0x1796, 0x162c: 0x111f, 0x162d: 0x0653, 0x162e: 0x112b, 0x162f: 0x1133, - 0x1630: 0x1143, 0x1631: 0x0657, 0x1632: 0x17a0, 0x1633: 0x17a5, 0x1634: 0x065b, 0x1635: 0x17aa, - 0x1636: 0x115b, 0x1637: 0x17af, 0x1638: 0x1167, 0x1639: 0x1173, 0x163a: 0x117b, 0x163b: 0x17b4, - 0x163c: 0x17b9, 0x163d: 0x118f, 0x163e: 0x17be, 0x163f: 0x1197, - // Block 0x59, offset 0x1640 - 0x1640: 0x16ce, 0x1641: 0x065f, 0x1642: 0x11af, 0x1643: 0x11b3, 0x1644: 0x0667, 0x1645: 0x11b7, - 0x1646: 0x0a33, 0x1647: 0x17c3, 0x1648: 0x17c8, 0x1649: 0x16d3, 0x164a: 0x16d8, 0x164b: 0x11d7, - 0x164c: 0x11db, 0x164d: 0x13f3, 0x164e: 0x066b, 0x164f: 0x1207, 0x1650: 0x1203, 0x1651: 0x120b, - 0x1652: 0x083f, 0x1653: 0x120f, 0x1654: 0x1213, 0x1655: 0x1217, 0x1656: 0x121f, 0x1657: 0x17cd, - 0x1658: 0x121b, 0x1659: 0x1223, 0x165a: 0x1237, 0x165b: 0x123b, 0x165c: 0x1227, 0x165d: 0x123f, - 0x165e: 0x1253, 0x165f: 0x1267, 0x1660: 0x1233, 0x1661: 0x1247, 0x1662: 0x124b, 0x1663: 0x124f, - 0x1664: 0x17d2, 0x1665: 0x17dc, 0x1666: 0x17d7, 0x1667: 0x066f, 0x1668: 0x126f, 0x1669: 0x1273, - 0x166a: 0x127b, 0x166b: 0x17f0, 0x166c: 0x127f, 0x166d: 0x17e1, 0x166e: 0x0673, 0x166f: 0x0677, - 0x1670: 0x17e6, 0x1671: 0x17eb, 0x1672: 0x067b, 0x1673: 0x129f, 0x1674: 0x12a3, 0x1675: 0x12a7, - 0x1676: 0x12ab, 0x1677: 0x12b7, 0x1678: 0x12b3, 0x1679: 0x12bf, 0x167a: 0x12bb, 0x167b: 0x12cb, - 0x167c: 0x12c3, 0x167d: 0x12c7, 0x167e: 0x12cf, 0x167f: 0x067f, - // Block 0x5a, offset 0x1680 - 0x1680: 0x12d7, 0x1681: 0x12db, 0x1682: 0x0683, 0x1683: 0x12eb, 0x1684: 0x12ef, 0x1685: 0x17f5, - 0x1686: 0x12fb, 0x1687: 0x12ff, 0x1688: 0x0687, 0x1689: 0x130b, 0x168a: 0x05bb, 0x168b: 0x17fa, - 0x168c: 0x17ff, 0x168d: 0x068b, 0x168e: 0x068f, 0x168f: 0x1337, 0x1690: 0x134f, 0x1691: 0x136b, - 0x1692: 0x137b, 0x1693: 0x1804, 0x1694: 0x138f, 0x1695: 0x1393, 0x1696: 0x13ab, 0x1697: 0x13b7, - 0x1698: 0x180e, 0x1699: 0x1660, 0x169a: 0x13c3, 0x169b: 0x13bf, 0x169c: 0x13cb, 0x169d: 0x1665, - 0x169e: 0x13d7, 0x169f: 0x13e3, 0x16a0: 0x1813, 0x16a1: 0x1818, 0x16a2: 0x1423, 0x16a3: 0x142f, - 0x16a4: 0x1437, 0x16a5: 0x181d, 0x16a6: 0x143b, 0x16a7: 0x1467, 0x16a8: 0x1473, 0x16a9: 0x1477, - 0x16aa: 0x146f, 0x16ab: 0x1483, 0x16ac: 0x1487, 0x16ad: 0x1822, 0x16ae: 0x1493, 0x16af: 0x0693, - 0x16b0: 0x149b, 0x16b1: 0x1827, 0x16b2: 0x0697, 0x16b3: 0x14d3, 0x16b4: 0x0ac3, 0x16b5: 0x14eb, - 0x16b6: 0x182c, 0x16b7: 0x1836, 0x16b8: 0x069b, 0x16b9: 0x069f, 0x16ba: 0x1513, 0x16bb: 0x183b, - 0x16bc: 0x06a3, 0x16bd: 0x1840, 0x16be: 0x152b, 0x16bf: 0x152b, - // Block 0x5b, offset 0x16c0 - 0x16c0: 0x1533, 0x16c1: 0x1845, 0x16c2: 0x154b, 0x16c3: 0x06a7, 0x16c4: 0x155b, 0x16c5: 0x1567, - 0x16c6: 0x156f, 0x16c7: 0x1577, 0x16c8: 0x06ab, 0x16c9: 0x184a, 0x16ca: 0x158b, 0x16cb: 0x15a7, - 0x16cc: 0x15b3, 0x16cd: 0x06af, 0x16ce: 0x06b3, 0x16cf: 0x15b7, 0x16d0: 0x184f, 0x16d1: 0x06b7, - 0x16d2: 0x1854, 0x16d3: 0x1859, 0x16d4: 0x185e, 0x16d5: 0x15db, 0x16d6: 0x06bb, 0x16d7: 0x15ef, - 0x16d8: 0x15f7, 0x16d9: 0x15fb, 0x16da: 0x1603, 0x16db: 0x160b, 0x16dc: 0x1613, 0x16dd: 0x1868, -} - -// nfkcIndex: 22 blocks, 1408 entries, 1408 bytes -// Block 0 is the zero block. -var nfkcIndex = [1408]uint8{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x5a, 0xc3: 0x01, 0xc4: 0x02, 0xc5: 0x03, 0xc6: 0x5b, 0xc7: 0x04, - 0xc8: 0x05, 0xca: 0x5c, 0xcb: 0x5d, 0xcc: 0x06, 0xcd: 0x07, 0xce: 0x08, 0xcf: 0x09, - 0xd0: 0x0a, 0xd1: 0x5e, 0xd2: 0x5f, 0xd3: 0x0b, 0xd6: 0x0c, 0xd7: 0x60, - 0xd8: 0x61, 0xd9: 0x0d, 0xdb: 0x62, 0xdc: 0x63, 0xdd: 0x64, 0xdf: 0x65, - 0xe0: 0x02, 0xe1: 0x03, 0xe2: 0x04, 0xe3: 0x05, - 0xea: 0x06, 0xeb: 0x07, 0xec: 0x08, 0xed: 0x09, 0xef: 0x0a, - 0xf0: 0x13, - // Block 0x4, offset 0x100 - 0x120: 0x66, 0x121: 0x67, 0x123: 0x68, 0x124: 0x69, 0x125: 0x6a, 0x126: 0x6b, 0x127: 0x6c, - 0x128: 0x6d, 0x129: 0x6e, 0x12a: 0x6f, 0x12b: 0x70, 0x12c: 0x6b, 0x12d: 0x71, 0x12e: 0x72, 0x12f: 0x73, - 0x131: 0x74, 0x132: 0x75, 0x133: 0x76, 0x134: 0x77, 0x135: 0x78, 0x137: 0x79, - 0x138: 0x7a, 0x139: 0x7b, 0x13a: 0x7c, 0x13b: 0x7d, 0x13c: 0x7e, 0x13d: 0x7f, 0x13e: 0x80, 0x13f: 0x81, - // Block 0x5, offset 0x140 - 0x140: 0x82, 0x142: 0x83, 0x143: 0x84, 0x144: 0x85, 0x145: 0x86, 0x146: 0x87, 0x147: 0x88, - 0x14d: 0x89, - 0x15c: 0x8a, 0x15f: 0x8b, - 0x162: 0x8c, 0x164: 0x8d, - 0x168: 0x8e, 0x169: 0x8f, 0x16a: 0x90, 0x16c: 0x0e, 0x16d: 0x91, 0x16e: 0x92, 0x16f: 0x93, - 0x170: 0x94, 0x173: 0x95, 0x174: 0x96, 0x175: 0x0f, 0x176: 0x10, 0x177: 0x97, - 0x178: 0x11, 0x179: 0x12, 0x17a: 0x13, 0x17b: 0x14, 0x17c: 0x15, 0x17d: 0x16, 0x17e: 0x17, 0x17f: 0x18, - // Block 0x6, offset 0x180 - 0x180: 0x98, 0x181: 0x99, 0x182: 0x9a, 0x183: 0x9b, 0x184: 0x19, 0x185: 0x1a, 0x186: 0x9c, 0x187: 0x9d, - 0x188: 0x9e, 0x189: 0x1b, 0x18a: 0x1c, 0x18b: 0x9f, 0x18c: 0xa0, - 0x191: 0x1d, 0x192: 0x1e, 0x193: 0xa1, - 0x1a8: 0xa2, 0x1a9: 0xa3, 0x1ab: 0xa4, - 0x1b1: 0xa5, 0x1b3: 0xa6, 0x1b5: 0xa7, 0x1b7: 0xa8, - 0x1ba: 0xa9, 0x1bb: 0xaa, 0x1bc: 0x1f, 0x1bd: 0x20, 0x1be: 0x21, 0x1bf: 0xab, - // Block 0x7, offset 0x1c0 - 0x1c0: 0xac, 0x1c1: 0x22, 0x1c2: 0x23, 0x1c3: 0x24, 0x1c4: 0xad, 0x1c5: 0x25, 0x1c6: 0x26, - 0x1c8: 0x27, 0x1c9: 0x28, 0x1ca: 0x29, 0x1cb: 0x2a, 0x1cc: 0x2b, 0x1cd: 0x2c, 0x1ce: 0x2d, 0x1cf: 0x2e, - // Block 0x8, offset 0x200 - 0x219: 0xae, 0x21a: 0xaf, 0x21b: 0xb0, 0x21d: 0xb1, 0x21f: 0xb2, - 0x220: 0xb3, 0x223: 0xb4, 0x224: 0xb5, 0x225: 0xb6, 0x226: 0xb7, 0x227: 0xb8, - 0x22a: 0xb9, 0x22b: 0xba, 0x22d: 0xbb, 0x22f: 0xbc, - 0x230: 0xbd, 0x231: 0xbe, 0x232: 0xbf, 0x233: 0xc0, 0x234: 0xc1, 0x235: 0xc2, 0x236: 0xc3, 0x237: 0xbd, - 0x238: 0xbe, 0x239: 0xbf, 0x23a: 0xc0, 0x23b: 0xc1, 0x23c: 0xc2, 0x23d: 0xc3, 0x23e: 0xbd, 0x23f: 0xbe, - // Block 0x9, offset 0x240 - 0x240: 0xbf, 0x241: 0xc0, 0x242: 0xc1, 0x243: 0xc2, 0x244: 0xc3, 0x245: 0xbd, 0x246: 0xbe, 0x247: 0xbf, - 0x248: 0xc0, 0x249: 0xc1, 0x24a: 0xc2, 0x24b: 0xc3, 0x24c: 0xbd, 0x24d: 0xbe, 0x24e: 0xbf, 0x24f: 0xc0, - 0x250: 0xc1, 0x251: 0xc2, 0x252: 0xc3, 0x253: 0xbd, 0x254: 0xbe, 0x255: 0xbf, 0x256: 0xc0, 0x257: 0xc1, - 0x258: 0xc2, 0x259: 0xc3, 0x25a: 0xbd, 0x25b: 0xbe, 0x25c: 0xbf, 0x25d: 0xc0, 0x25e: 0xc1, 0x25f: 0xc2, - 0x260: 0xc3, 0x261: 0xbd, 0x262: 0xbe, 0x263: 0xbf, 0x264: 0xc0, 0x265: 0xc1, 0x266: 0xc2, 0x267: 0xc3, - 0x268: 0xbd, 0x269: 0xbe, 0x26a: 0xbf, 0x26b: 0xc0, 0x26c: 0xc1, 0x26d: 0xc2, 0x26e: 0xc3, 0x26f: 0xbd, - 0x270: 0xbe, 0x271: 0xbf, 0x272: 0xc0, 0x273: 0xc1, 0x274: 0xc2, 0x275: 0xc3, 0x276: 0xbd, 0x277: 0xbe, - 0x278: 0xbf, 0x279: 0xc0, 0x27a: 0xc1, 0x27b: 0xc2, 0x27c: 0xc3, 0x27d: 0xbd, 0x27e: 0xbe, 0x27f: 0xbf, - // Block 0xa, offset 0x280 - 0x280: 0xc0, 0x281: 0xc1, 0x282: 0xc2, 0x283: 0xc3, 0x284: 0xbd, 0x285: 0xbe, 0x286: 0xbf, 0x287: 0xc0, - 0x288: 0xc1, 0x289: 0xc2, 0x28a: 0xc3, 0x28b: 0xbd, 0x28c: 0xbe, 0x28d: 0xbf, 0x28e: 0xc0, 0x28f: 0xc1, - 0x290: 0xc2, 0x291: 0xc3, 0x292: 0xbd, 0x293: 0xbe, 0x294: 0xbf, 0x295: 0xc0, 0x296: 0xc1, 0x297: 0xc2, - 0x298: 0xc3, 0x299: 0xbd, 0x29a: 0xbe, 0x29b: 0xbf, 0x29c: 0xc0, 0x29d: 0xc1, 0x29e: 0xc2, 0x29f: 0xc3, - 0x2a0: 0xbd, 0x2a1: 0xbe, 0x2a2: 0xbf, 0x2a3: 0xc0, 0x2a4: 0xc1, 0x2a5: 0xc2, 0x2a6: 0xc3, 0x2a7: 0xbd, - 0x2a8: 0xbe, 0x2a9: 0xbf, 0x2aa: 0xc0, 0x2ab: 0xc1, 0x2ac: 0xc2, 0x2ad: 0xc3, 0x2ae: 0xbd, 0x2af: 0xbe, - 0x2b0: 0xbf, 0x2b1: 0xc0, 0x2b2: 0xc1, 0x2b3: 0xc2, 0x2b4: 0xc3, 0x2b5: 0xbd, 0x2b6: 0xbe, 0x2b7: 0xbf, - 0x2b8: 0xc0, 0x2b9: 0xc1, 0x2ba: 0xc2, 0x2bb: 0xc3, 0x2bc: 0xbd, 0x2bd: 0xbe, 0x2be: 0xbf, 0x2bf: 0xc0, - // Block 0xb, offset 0x2c0 - 0x2c0: 0xc1, 0x2c1: 0xc2, 0x2c2: 0xc3, 0x2c3: 0xbd, 0x2c4: 0xbe, 0x2c5: 0xbf, 0x2c6: 0xc0, 0x2c7: 0xc1, - 0x2c8: 0xc2, 0x2c9: 0xc3, 0x2ca: 0xbd, 0x2cb: 0xbe, 0x2cc: 0xbf, 0x2cd: 0xc0, 0x2ce: 0xc1, 0x2cf: 0xc2, - 0x2d0: 0xc3, 0x2d1: 0xbd, 0x2d2: 0xbe, 0x2d3: 0xbf, 0x2d4: 0xc0, 0x2d5: 0xc1, 0x2d6: 0xc2, 0x2d7: 0xc3, - 0x2d8: 0xbd, 0x2d9: 0xbe, 0x2da: 0xbf, 0x2db: 0xc0, 0x2dc: 0xc1, 0x2dd: 0xc2, 0x2de: 0xc4, - // Block 0xc, offset 0x300 - 0x324: 0x2f, 0x325: 0x30, 0x326: 0x31, 0x327: 0x32, - 0x328: 0x33, 0x329: 0x34, 0x32a: 0x35, 0x32b: 0x36, 0x32c: 0x37, 0x32d: 0x38, 0x32e: 0x39, 0x32f: 0x3a, - 0x330: 0x3b, 0x331: 0x3c, 0x332: 0x3d, 0x333: 0x3e, 0x334: 0x3f, 0x335: 0x40, 0x336: 0x41, 0x337: 0x42, - 0x338: 0x43, 0x339: 0x44, 0x33a: 0x45, 0x33b: 0x46, 0x33c: 0xc5, 0x33d: 0x47, 0x33e: 0x48, 0x33f: 0x49, - // Block 0xd, offset 0x340 - 0x347: 0xc6, - 0x34b: 0xc7, 0x34d: 0xc8, - 0x368: 0xc9, 0x36b: 0xca, - // Block 0xe, offset 0x380 - 0x381: 0xcb, 0x382: 0xcc, 0x384: 0xcd, 0x385: 0xb7, 0x387: 0xce, - 0x388: 0xcf, 0x38b: 0xd0, 0x38c: 0x6b, 0x38d: 0xd1, - 0x391: 0xd2, 0x392: 0xd3, 0x393: 0xd4, 0x396: 0xd5, 0x397: 0xd6, - 0x398: 0xd7, 0x39a: 0xd8, 0x39c: 0xd9, - 0x3b0: 0xd7, - // Block 0xf, offset 0x3c0 - 0x3eb: 0xda, 0x3ec: 0xdb, - // Block 0x10, offset 0x400 - 0x432: 0xdc, - // Block 0x11, offset 0x440 - 0x445: 0xdd, 0x446: 0xde, 0x447: 0xdf, - 0x449: 0xe0, - 0x450: 0xe1, 0x451: 0xe2, 0x452: 0xe3, 0x453: 0xe4, 0x454: 0xe5, 0x455: 0xe6, 0x456: 0xe7, 0x457: 0xe8, - 0x458: 0xe9, 0x459: 0xea, 0x45a: 0x4a, 0x45b: 0xeb, 0x45c: 0xec, 0x45d: 0xed, 0x45e: 0xee, 0x45f: 0x4b, - // Block 0x12, offset 0x480 - 0x480: 0xef, - 0x4a3: 0xf0, 0x4a5: 0xf1, - 0x4b8: 0x4c, 0x4b9: 0x4d, 0x4ba: 0x4e, - // Block 0x13, offset 0x4c0 - 0x4c4: 0x4f, 0x4c5: 0xf2, 0x4c6: 0xf3, - 0x4c8: 0x50, 0x4c9: 0xf4, - // Block 0x14, offset 0x500 - 0x520: 0x51, 0x521: 0x52, 0x522: 0x53, 0x523: 0x54, 0x524: 0x55, 0x525: 0x56, 0x526: 0x57, 0x527: 0x58, - 0x528: 0x59, - // Block 0x15, offset 0x540 - 0x550: 0x0b, 0x551: 0x0c, 0x556: 0x0d, - 0x55b: 0x0e, 0x55d: 0x0f, 0x55e: 0x10, 0x55f: 0x11, - 0x56f: 0x12, -} - -// nfkcSparseOffset: 155 entries, 310 bytes -var nfkcSparseOffset = []uint16{0x0, 0xe, 0x12, 0x1b, 0x25, 0x35, 0x37, 0x3c, 0x47, 0x56, 0x63, 0x6b, 0x6f, 0x74, 0x76, 0x87, 0x8f, 0x96, 0x99, 0xa0, 0xa4, 0xa8, 0xaa, 0xac, 0xb5, 0xb9, 0xc0, 0xc5, 0xc8, 0xd2, 0xd4, 0xdb, 0xe3, 0xe7, 0xe9, 0xec, 0xf0, 0xf6, 0x107, 0x113, 0x115, 0x11b, 0x11d, 0x11f, 0x121, 0x123, 0x125, 0x127, 0x129, 0x12c, 0x12f, 0x131, 0x134, 0x137, 0x13b, 0x140, 0x149, 0x14b, 0x14e, 0x150, 0x15b, 0x166, 0x176, 0x184, 0x192, 0x1a2, 0x1b0, 0x1b7, 0x1bd, 0x1cc, 0x1d0, 0x1d2, 0x1d6, 0x1d8, 0x1db, 0x1dd, 0x1e0, 0x1e2, 0x1e5, 0x1e7, 0x1e9, 0x1eb, 0x1f7, 0x201, 0x20b, 0x20e, 0x212, 0x214, 0x216, 0x218, 0x21a, 0x21d, 0x21f, 0x221, 0x223, 0x225, 0x22b, 0x22e, 0x232, 0x234, 0x23b, 0x241, 0x247, 0x24f, 0x255, 0x25b, 0x261, 0x265, 0x267, 0x269, 0x26b, 0x26d, 0x273, 0x276, 0x279, 0x281, 0x288, 0x28b, 0x28e, 0x290, 0x298, 0x29b, 0x2a2, 0x2a5, 0x2ab, 0x2ad, 0x2af, 0x2b2, 0x2b4, 0x2b6, 0x2b8, 0x2ba, 0x2c7, 0x2d1, 0x2d3, 0x2d5, 0x2d9, 0x2de, 0x2ea, 0x2ef, 0x2f8, 0x2fe, 0x303, 0x307, 0x30c, 0x310, 0x320, 0x32e, 0x33c, 0x34a, 0x350, 0x352, 0x355, 0x35f, 0x361} - -// nfkcSparseValues: 875 entries, 3500 bytes -var nfkcSparseValues = [875]valueRange{ - // Block 0x0, offset 0x0 - {value: 0x0002, lo: 0x0d}, - {value: 0x0001, lo: 0xa0, hi: 0xa0}, - {value: 0x4278, lo: 0xa8, hi: 0xa8}, - {value: 0x0083, lo: 0xaa, hi: 0xaa}, - {value: 0x4264, lo: 0xaf, hi: 0xaf}, - {value: 0x0025, lo: 0xb2, hi: 0xb3}, - {value: 0x425a, lo: 0xb4, hi: 0xb4}, - {value: 0x01dc, lo: 0xb5, hi: 0xb5}, - {value: 0x4291, lo: 0xb8, hi: 0xb8}, - {value: 0x0023, lo: 0xb9, hi: 0xb9}, - {value: 0x009f, lo: 0xba, hi: 0xba}, - {value: 0x221c, lo: 0xbc, hi: 0xbc}, - {value: 0x2210, lo: 0xbd, hi: 0xbd}, - {value: 0x22b2, lo: 0xbe, hi: 0xbe}, - // Block 0x1, offset 0xe - {value: 0x0091, lo: 0x03}, - {value: 0x4778, lo: 0xa0, hi: 0xa1}, - {value: 0x47aa, lo: 0xaf, hi: 0xb0}, - {value: 0xa000, lo: 0xb7, hi: 0xb7}, - // Block 0x2, offset 0x12 - {value: 0x0003, lo: 0x08}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x0091, lo: 0xb0, hi: 0xb0}, - {value: 0x0119, lo: 0xb1, hi: 0xb1}, - {value: 0x0095, lo: 0xb2, hi: 0xb2}, - {value: 0x00a5, lo: 0xb3, hi: 0xb3}, - {value: 0x0143, lo: 0xb4, hi: 0xb6}, - {value: 0x00af, lo: 0xb7, hi: 0xb7}, - {value: 0x00b3, lo: 0xb8, hi: 0xb8}, - // Block 0x3, offset 0x1b - {value: 0x000a, lo: 0x09}, - {value: 0x426e, lo: 0x98, hi: 0x98}, - {value: 0x4273, lo: 0x99, hi: 0x9a}, - {value: 0x4296, lo: 0x9b, hi: 0x9b}, - {value: 0x425f, lo: 0x9c, hi: 0x9c}, - {value: 0x4282, lo: 0x9d, hi: 0x9d}, - {value: 0x0113, lo: 0xa0, hi: 0xa0}, - {value: 0x0099, lo: 0xa1, hi: 0xa1}, - {value: 0x00a7, lo: 0xa2, hi: 0xa3}, - {value: 0x0167, lo: 0xa4, hi: 0xa4}, - // Block 0x4, offset 0x25 - {value: 0x0000, lo: 0x0f}, - {value: 0xa000, lo: 0x83, hi: 0x83}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0xa000, lo: 0x8b, hi: 0x8b}, - {value: 0xa000, lo: 0x8d, hi: 0x8d}, - {value: 0x37a5, lo: 0x90, hi: 0x90}, - {value: 0x37b1, lo: 0x91, hi: 0x91}, - {value: 0x379f, lo: 0x93, hi: 0x93}, - {value: 0xa000, lo: 0x96, hi: 0x96}, - {value: 0x3817, lo: 0x97, hi: 0x97}, - {value: 0x37e1, lo: 0x9c, hi: 0x9c}, - {value: 0x37c9, lo: 0x9d, hi: 0x9d}, - {value: 0x37f3, lo: 0x9e, hi: 0x9e}, - {value: 0xa000, lo: 0xb4, hi: 0xb5}, - {value: 0x381d, lo: 0xb6, hi: 0xb6}, - {value: 0x3823, lo: 0xb7, hi: 0xb7}, - // Block 0x5, offset 0x35 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x83, hi: 0x87}, - // Block 0x6, offset 0x37 - {value: 0x0001, lo: 0x04}, - {value: 0x8113, lo: 0x81, hi: 0x82}, - {value: 0x8132, lo: 0x84, hi: 0x84}, - {value: 0x812d, lo: 0x85, hi: 0x85}, - {value: 0x810d, lo: 0x87, hi: 0x87}, - // Block 0x7, offset 0x3c - {value: 0x0000, lo: 0x0a}, - {value: 0x8132, lo: 0x90, hi: 0x97}, - {value: 0x8119, lo: 0x98, hi: 0x98}, - {value: 0x811a, lo: 0x99, hi: 0x99}, - {value: 0x811b, lo: 0x9a, hi: 0x9a}, - {value: 0x3841, lo: 0xa2, hi: 0xa2}, - {value: 0x3847, lo: 0xa3, hi: 0xa3}, - {value: 0x3853, lo: 0xa4, hi: 0xa4}, - {value: 0x384d, lo: 0xa5, hi: 0xa5}, - {value: 0x3859, lo: 0xa6, hi: 0xa6}, - {value: 0xa000, lo: 0xa7, hi: 0xa7}, - // Block 0x8, offset 0x47 - {value: 0x0000, lo: 0x0e}, - {value: 0x386b, lo: 0x80, hi: 0x80}, - {value: 0xa000, lo: 0x81, hi: 0x81}, - {value: 0x385f, lo: 0x82, hi: 0x82}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x3865, lo: 0x93, hi: 0x93}, - {value: 0xa000, lo: 0x95, hi: 0x95}, - {value: 0x8132, lo: 0x96, hi: 0x9c}, - {value: 0x8132, lo: 0x9f, hi: 0xa2}, - {value: 0x812d, lo: 0xa3, hi: 0xa3}, - {value: 0x8132, lo: 0xa4, hi: 0xa4}, - {value: 0x8132, lo: 0xa7, hi: 0xa8}, - {value: 0x812d, lo: 0xaa, hi: 0xaa}, - {value: 0x8132, lo: 0xab, hi: 0xac}, - {value: 0x812d, lo: 0xad, hi: 0xad}, - // Block 0x9, offset 0x56 - {value: 0x0000, lo: 0x0c}, - {value: 0x811f, lo: 0x91, hi: 0x91}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - {value: 0x812d, lo: 0xb1, hi: 0xb1}, - {value: 0x8132, lo: 0xb2, hi: 0xb3}, - {value: 0x812d, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb5, hi: 0xb6}, - {value: 0x812d, lo: 0xb7, hi: 0xb9}, - {value: 0x8132, lo: 0xba, hi: 0xba}, - {value: 0x812d, lo: 0xbb, hi: 0xbc}, - {value: 0x8132, lo: 0xbd, hi: 0xbd}, - {value: 0x812d, lo: 0xbe, hi: 0xbe}, - {value: 0x8132, lo: 0xbf, hi: 0xbf}, - // Block 0xa, offset 0x63 - {value: 0x0005, lo: 0x07}, - {value: 0x8132, lo: 0x80, hi: 0x80}, - {value: 0x8132, lo: 0x81, hi: 0x81}, - {value: 0x812d, lo: 0x82, hi: 0x83}, - {value: 0x812d, lo: 0x84, hi: 0x85}, - {value: 0x812d, lo: 0x86, hi: 0x87}, - {value: 0x812d, lo: 0x88, hi: 0x89}, - {value: 0x8132, lo: 0x8a, hi: 0x8a}, - // Block 0xb, offset 0x6b - {value: 0x0000, lo: 0x03}, - {value: 0x8132, lo: 0xab, hi: 0xb1}, - {value: 0x812d, lo: 0xb2, hi: 0xb2}, - {value: 0x8132, lo: 0xb3, hi: 0xb3}, - // Block 0xc, offset 0x6f - {value: 0x0000, lo: 0x04}, - {value: 0x8132, lo: 0x96, hi: 0x99}, - {value: 0x8132, lo: 0x9b, hi: 0xa3}, - {value: 0x8132, lo: 0xa5, hi: 0xa7}, - {value: 0x8132, lo: 0xa9, hi: 0xad}, - // Block 0xd, offset 0x74 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x99, hi: 0x9b}, - // Block 0xe, offset 0x76 - {value: 0x0000, lo: 0x10}, - {value: 0x8132, lo: 0x94, hi: 0xa1}, - {value: 0x812d, lo: 0xa3, hi: 0xa3}, - {value: 0x8132, lo: 0xa4, hi: 0xa5}, - {value: 0x812d, lo: 0xa6, hi: 0xa6}, - {value: 0x8132, lo: 0xa7, hi: 0xa8}, - {value: 0x812d, lo: 0xa9, hi: 0xa9}, - {value: 0x8132, lo: 0xaa, hi: 0xac}, - {value: 0x812d, lo: 0xad, hi: 0xaf}, - {value: 0x8116, lo: 0xb0, hi: 0xb0}, - {value: 0x8117, lo: 0xb1, hi: 0xb1}, - {value: 0x8118, lo: 0xb2, hi: 0xb2}, - {value: 0x8132, lo: 0xb3, hi: 0xb5}, - {value: 0x812d, lo: 0xb6, hi: 0xb6}, - {value: 0x8132, lo: 0xb7, hi: 0xb8}, - {value: 0x812d, lo: 0xb9, hi: 0xba}, - {value: 0x8132, lo: 0xbb, hi: 0xbf}, - // Block 0xf, offset 0x87 - {value: 0x0000, lo: 0x07}, - {value: 0xa000, lo: 0xa8, hi: 0xa8}, - {value: 0x3ed8, lo: 0xa9, hi: 0xa9}, - {value: 0xa000, lo: 0xb0, hi: 0xb0}, - {value: 0x3ee0, lo: 0xb1, hi: 0xb1}, - {value: 0xa000, lo: 0xb3, hi: 0xb3}, - {value: 0x3ee8, lo: 0xb4, hi: 0xb4}, - {value: 0x9902, lo: 0xbc, hi: 0xbc}, - // Block 0x10, offset 0x8f - {value: 0x0008, lo: 0x06}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x8132, lo: 0x91, hi: 0x91}, - {value: 0x812d, lo: 0x92, hi: 0x92}, - {value: 0x8132, lo: 0x93, hi: 0x93}, - {value: 0x8132, lo: 0x94, hi: 0x94}, - {value: 0x45b2, lo: 0x98, hi: 0x9f}, - // Block 0x11, offset 0x96 - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x12, offset 0x99 - {value: 0x0008, lo: 0x06}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2c9e, lo: 0x8b, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - {value: 0x45f2, lo: 0x9c, hi: 0x9d}, - {value: 0x4602, lo: 0x9f, hi: 0x9f}, - // Block 0x13, offset 0xa0 - {value: 0x0000, lo: 0x03}, - {value: 0x462a, lo: 0xb3, hi: 0xb3}, - {value: 0x4632, lo: 0xb6, hi: 0xb6}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - // Block 0x14, offset 0xa4 - {value: 0x0008, lo: 0x03}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x460a, lo: 0x99, hi: 0x9b}, - {value: 0x4622, lo: 0x9e, hi: 0x9e}, - // Block 0x15, offset 0xa8 - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - // Block 0x16, offset 0xaa - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - // Block 0x17, offset 0xac - {value: 0x0000, lo: 0x08}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2cb6, lo: 0x88, hi: 0x88}, - {value: 0x2cae, lo: 0x8b, hi: 0x8b}, - {value: 0x2cbe, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x96, hi: 0x97}, - {value: 0x463a, lo: 0x9c, hi: 0x9c}, - {value: 0x4642, lo: 0x9d, hi: 0x9d}, - // Block 0x18, offset 0xb5 - {value: 0x0000, lo: 0x03}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0x2cc6, lo: 0x94, hi: 0x94}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x19, offset 0xb9 - {value: 0x0000, lo: 0x06}, - {value: 0xa000, lo: 0x86, hi: 0x87}, - {value: 0x2cce, lo: 0x8a, hi: 0x8a}, - {value: 0x2cde, lo: 0x8b, hi: 0x8b}, - {value: 0x2cd6, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - // Block 0x1a, offset 0xc0 - {value: 0x1801, lo: 0x04}, - {value: 0xa000, lo: 0x86, hi: 0x86}, - {value: 0x3ef0, lo: 0x88, hi: 0x88}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x8120, lo: 0x95, hi: 0x96}, - // Block 0x1b, offset 0xc5 - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xbc, hi: 0xbc}, - {value: 0xa000, lo: 0xbf, hi: 0xbf}, - // Block 0x1c, offset 0xc8 - {value: 0x0000, lo: 0x09}, - {value: 0x2ce6, lo: 0x80, hi: 0x80}, - {value: 0x9900, lo: 0x82, hi: 0x82}, - {value: 0xa000, lo: 0x86, hi: 0x86}, - {value: 0x2cee, lo: 0x87, hi: 0x87}, - {value: 0x2cf6, lo: 0x88, hi: 0x88}, - {value: 0x2f50, lo: 0x8a, hi: 0x8a}, - {value: 0x2dd8, lo: 0x8b, hi: 0x8b}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x95, hi: 0x96}, - // Block 0x1d, offset 0xd2 - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0xbe, hi: 0xbe}, - // Block 0x1e, offset 0xd4 - {value: 0x0000, lo: 0x06}, - {value: 0xa000, lo: 0x86, hi: 0x87}, - {value: 0x2cfe, lo: 0x8a, hi: 0x8a}, - {value: 0x2d0e, lo: 0x8b, hi: 0x8b}, - {value: 0x2d06, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - // Block 0x1f, offset 0xdb - {value: 0x6bea, lo: 0x07}, - {value: 0x9904, lo: 0x8a, hi: 0x8a}, - {value: 0x9900, lo: 0x8f, hi: 0x8f}, - {value: 0xa000, lo: 0x99, hi: 0x99}, - {value: 0x3ef8, lo: 0x9a, hi: 0x9a}, - {value: 0x2f58, lo: 0x9c, hi: 0x9c}, - {value: 0x2de3, lo: 0x9d, hi: 0x9d}, - {value: 0x2d16, lo: 0x9e, hi: 0x9f}, - // Block 0x20, offset 0xe3 - {value: 0x0000, lo: 0x03}, - {value: 0x2621, lo: 0xb3, hi: 0xb3}, - {value: 0x8122, lo: 0xb8, hi: 0xb9}, - {value: 0x8104, lo: 0xba, hi: 0xba}, - // Block 0x21, offset 0xe7 - {value: 0x0000, lo: 0x01}, - {value: 0x8123, lo: 0x88, hi: 0x8b}, - // Block 0x22, offset 0xe9 - {value: 0x0000, lo: 0x02}, - {value: 0x2636, lo: 0xb3, hi: 0xb3}, - {value: 0x8124, lo: 0xb8, hi: 0xb9}, - // Block 0x23, offset 0xec - {value: 0x0000, lo: 0x03}, - {value: 0x8125, lo: 0x88, hi: 0x8b}, - {value: 0x2628, lo: 0x9c, hi: 0x9c}, - {value: 0x262f, lo: 0x9d, hi: 0x9d}, - // Block 0x24, offset 0xf0 - {value: 0x0000, lo: 0x05}, - {value: 0x030b, lo: 0x8c, hi: 0x8c}, - {value: 0x812d, lo: 0x98, hi: 0x99}, - {value: 0x812d, lo: 0xb5, hi: 0xb5}, - {value: 0x812d, lo: 0xb7, hi: 0xb7}, - {value: 0x812b, lo: 0xb9, hi: 0xb9}, - // Block 0x25, offset 0xf6 - {value: 0x0000, lo: 0x10}, - {value: 0x2644, lo: 0x83, hi: 0x83}, - {value: 0x264b, lo: 0x8d, hi: 0x8d}, - {value: 0x2652, lo: 0x92, hi: 0x92}, - {value: 0x2659, lo: 0x97, hi: 0x97}, - {value: 0x2660, lo: 0x9c, hi: 0x9c}, - {value: 0x263d, lo: 0xa9, hi: 0xa9}, - {value: 0x8126, lo: 0xb1, hi: 0xb1}, - {value: 0x8127, lo: 0xb2, hi: 0xb2}, - {value: 0x4a66, lo: 0xb3, hi: 0xb3}, - {value: 0x8128, lo: 0xb4, hi: 0xb4}, - {value: 0x4a6f, lo: 0xb5, hi: 0xb5}, - {value: 0x464a, lo: 0xb6, hi: 0xb6}, - {value: 0x468a, lo: 0xb7, hi: 0xb7}, - {value: 0x4652, lo: 0xb8, hi: 0xb8}, - {value: 0x4695, lo: 0xb9, hi: 0xb9}, - {value: 0x8127, lo: 0xba, hi: 0xbd}, - // Block 0x26, offset 0x107 - {value: 0x0000, lo: 0x0b}, - {value: 0x8127, lo: 0x80, hi: 0x80}, - {value: 0x4a78, lo: 0x81, hi: 0x81}, - {value: 0x8132, lo: 0x82, hi: 0x83}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0x86, hi: 0x87}, - {value: 0x266e, lo: 0x93, hi: 0x93}, - {value: 0x2675, lo: 0x9d, hi: 0x9d}, - {value: 0x267c, lo: 0xa2, hi: 0xa2}, - {value: 0x2683, lo: 0xa7, hi: 0xa7}, - {value: 0x268a, lo: 0xac, hi: 0xac}, - {value: 0x2667, lo: 0xb9, hi: 0xb9}, - // Block 0x27, offset 0x113 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x86, hi: 0x86}, - // Block 0x28, offset 0x115 - {value: 0x0000, lo: 0x05}, - {value: 0xa000, lo: 0xa5, hi: 0xa5}, - {value: 0x2d1e, lo: 0xa6, hi: 0xa6}, - {value: 0x9900, lo: 0xae, hi: 0xae}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - {value: 0x8104, lo: 0xb9, hi: 0xba}, - // Block 0x29, offset 0x11b - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x8d, hi: 0x8d}, - // Block 0x2a, offset 0x11d - {value: 0x0000, lo: 0x01}, - {value: 0x030f, lo: 0xbc, hi: 0xbc}, - // Block 0x2b, offset 0x11f - {value: 0x0000, lo: 0x01}, - {value: 0xa000, lo: 0x80, hi: 0x92}, - // Block 0x2c, offset 0x121 - {value: 0x0000, lo: 0x01}, - {value: 0xb900, lo: 0xa1, hi: 0xb5}, - // Block 0x2d, offset 0x123 - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0xa8, hi: 0xbf}, - // Block 0x2e, offset 0x125 - {value: 0x0000, lo: 0x01}, - {value: 0x9900, lo: 0x80, hi: 0x82}, - // Block 0x2f, offset 0x127 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x9d, hi: 0x9f}, - // Block 0x30, offset 0x129 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x94, hi: 0x94}, - {value: 0x8104, lo: 0xb4, hi: 0xb4}, - // Block 0x31, offset 0x12c - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x92, hi: 0x92}, - {value: 0x8132, lo: 0x9d, hi: 0x9d}, - // Block 0x32, offset 0x12f - {value: 0x0000, lo: 0x01}, - {value: 0x8131, lo: 0xa9, hi: 0xa9}, - // Block 0x33, offset 0x131 - {value: 0x0004, lo: 0x02}, - {value: 0x812e, lo: 0xb9, hi: 0xba}, - {value: 0x812d, lo: 0xbb, hi: 0xbb}, - // Block 0x34, offset 0x134 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x97, hi: 0x97}, - {value: 0x812d, lo: 0x98, hi: 0x98}, - // Block 0x35, offset 0x137 - {value: 0x0000, lo: 0x03}, - {value: 0x8104, lo: 0xa0, hi: 0xa0}, - {value: 0x8132, lo: 0xb5, hi: 0xbc}, - {value: 0x812d, lo: 0xbf, hi: 0xbf}, - // Block 0x36, offset 0x13b - {value: 0x0000, lo: 0x04}, - {value: 0x8132, lo: 0xb0, hi: 0xb4}, - {value: 0x812d, lo: 0xb5, hi: 0xba}, - {value: 0x8132, lo: 0xbb, hi: 0xbc}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - // Block 0x37, offset 0x140 - {value: 0x0000, lo: 0x08}, - {value: 0x2d66, lo: 0x80, hi: 0x80}, - {value: 0x2d6e, lo: 0x81, hi: 0x81}, - {value: 0xa000, lo: 0x82, hi: 0x82}, - {value: 0x2d76, lo: 0x83, hi: 0x83}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0xab, hi: 0xab}, - {value: 0x812d, lo: 0xac, hi: 0xac}, - {value: 0x8132, lo: 0xad, hi: 0xb3}, - // Block 0x38, offset 0x149 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xaa, hi: 0xab}, - // Block 0x39, offset 0x14b - {value: 0x0000, lo: 0x02}, - {value: 0x8102, lo: 0xa6, hi: 0xa6}, - {value: 0x8104, lo: 0xb2, hi: 0xb3}, - // Block 0x3a, offset 0x14e - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - // Block 0x3b, offset 0x150 - {value: 0x0000, lo: 0x0a}, - {value: 0x8132, lo: 0x90, hi: 0x92}, - {value: 0x8101, lo: 0x94, hi: 0x94}, - {value: 0x812d, lo: 0x95, hi: 0x99}, - {value: 0x8132, lo: 0x9a, hi: 0x9b}, - {value: 0x812d, lo: 0x9c, hi: 0x9f}, - {value: 0x8132, lo: 0xa0, hi: 0xa0}, - {value: 0x8101, lo: 0xa2, hi: 0xa8}, - {value: 0x812d, lo: 0xad, hi: 0xad}, - {value: 0x8132, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb8, hi: 0xb9}, - // Block 0x3c, offset 0x15b - {value: 0x0002, lo: 0x0a}, - {value: 0x0043, lo: 0xac, hi: 0xac}, - {value: 0x00d1, lo: 0xad, hi: 0xad}, - {value: 0x0045, lo: 0xae, hi: 0xae}, - {value: 0x0049, lo: 0xb0, hi: 0xb1}, - {value: 0x00e6, lo: 0xb2, hi: 0xb2}, - {value: 0x004f, lo: 0xb3, hi: 0xba}, - {value: 0x005f, lo: 0xbc, hi: 0xbc}, - {value: 0x00ef, lo: 0xbd, hi: 0xbd}, - {value: 0x0061, lo: 0xbe, hi: 0xbe}, - {value: 0x0065, lo: 0xbf, hi: 0xbf}, - // Block 0x3d, offset 0x166 - {value: 0x0000, lo: 0x0f}, - {value: 0x8132, lo: 0x80, hi: 0x81}, - {value: 0x812d, lo: 0x82, hi: 0x82}, - {value: 0x8132, lo: 0x83, hi: 0x89}, - {value: 0x812d, lo: 0x8a, hi: 0x8a}, - {value: 0x8132, lo: 0x8b, hi: 0x8c}, - {value: 0x8135, lo: 0x8d, hi: 0x8d}, - {value: 0x812a, lo: 0x8e, hi: 0x8e}, - {value: 0x812d, lo: 0x8f, hi: 0x8f}, - {value: 0x8129, lo: 0x90, hi: 0x90}, - {value: 0x8132, lo: 0x91, hi: 0xb5}, - {value: 0x8132, lo: 0xbb, hi: 0xbb}, - {value: 0x8134, lo: 0xbc, hi: 0xbc}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - {value: 0x8132, lo: 0xbe, hi: 0xbe}, - {value: 0x812d, lo: 0xbf, hi: 0xbf}, - // Block 0x3e, offset 0x176 - {value: 0x0000, lo: 0x0d}, - {value: 0x0001, lo: 0x80, hi: 0x8a}, - {value: 0x043b, lo: 0x91, hi: 0x91}, - {value: 0x429b, lo: 0x97, hi: 0x97}, - {value: 0x001d, lo: 0xa4, hi: 0xa4}, - {value: 0x1873, lo: 0xa5, hi: 0xa5}, - {value: 0x1b5c, lo: 0xa6, hi: 0xa6}, - {value: 0x0001, lo: 0xaf, hi: 0xaf}, - {value: 0x2691, lo: 0xb3, hi: 0xb3}, - {value: 0x27fe, lo: 0xb4, hi: 0xb4}, - {value: 0x2698, lo: 0xb6, hi: 0xb6}, - {value: 0x2808, lo: 0xb7, hi: 0xb7}, - {value: 0x186d, lo: 0xbc, hi: 0xbc}, - {value: 0x4269, lo: 0xbe, hi: 0xbe}, - // Block 0x3f, offset 0x184 - {value: 0x0002, lo: 0x0d}, - {value: 0x1933, lo: 0x87, hi: 0x87}, - {value: 0x1930, lo: 0x88, hi: 0x88}, - {value: 0x1870, lo: 0x89, hi: 0x89}, - {value: 0x298e, lo: 0x97, hi: 0x97}, - {value: 0x0001, lo: 0x9f, hi: 0x9f}, - {value: 0x0021, lo: 0xb0, hi: 0xb0}, - {value: 0x0093, lo: 0xb1, hi: 0xb1}, - {value: 0x0029, lo: 0xb4, hi: 0xb9}, - {value: 0x0017, lo: 0xba, hi: 0xba}, - {value: 0x0467, lo: 0xbb, hi: 0xbb}, - {value: 0x003b, lo: 0xbc, hi: 0xbc}, - {value: 0x0011, lo: 0xbd, hi: 0xbe}, - {value: 0x009d, lo: 0xbf, hi: 0xbf}, - // Block 0x40, offset 0x192 - {value: 0x0002, lo: 0x0f}, - {value: 0x0021, lo: 0x80, hi: 0x89}, - {value: 0x0017, lo: 0x8a, hi: 0x8a}, - {value: 0x0467, lo: 0x8b, hi: 0x8b}, - {value: 0x003b, lo: 0x8c, hi: 0x8c}, - {value: 0x0011, lo: 0x8d, hi: 0x8e}, - {value: 0x0083, lo: 0x90, hi: 0x90}, - {value: 0x008b, lo: 0x91, hi: 0x91}, - {value: 0x009f, lo: 0x92, hi: 0x92}, - {value: 0x00b1, lo: 0x93, hi: 0x93}, - {value: 0x0104, lo: 0x94, hi: 0x94}, - {value: 0x0091, lo: 0x95, hi: 0x95}, - {value: 0x0097, lo: 0x96, hi: 0x99}, - {value: 0x00a1, lo: 0x9a, hi: 0x9a}, - {value: 0x00a7, lo: 0x9b, hi: 0x9c}, - {value: 0x1999, lo: 0xa8, hi: 0xa8}, - // Block 0x41, offset 0x1a2 - {value: 0x0000, lo: 0x0d}, - {value: 0x8132, lo: 0x90, hi: 0x91}, - {value: 0x8101, lo: 0x92, hi: 0x93}, - {value: 0x8132, lo: 0x94, hi: 0x97}, - {value: 0x8101, lo: 0x98, hi: 0x9a}, - {value: 0x8132, lo: 0x9b, hi: 0x9c}, - {value: 0x8132, lo: 0xa1, hi: 0xa1}, - {value: 0x8101, lo: 0xa5, hi: 0xa6}, - {value: 0x8132, lo: 0xa7, hi: 0xa7}, - {value: 0x812d, lo: 0xa8, hi: 0xa8}, - {value: 0x8132, lo: 0xa9, hi: 0xa9}, - {value: 0x8101, lo: 0xaa, hi: 0xab}, - {value: 0x812d, lo: 0xac, hi: 0xaf}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - // Block 0x42, offset 0x1b0 - {value: 0x0007, lo: 0x06}, - {value: 0x2180, lo: 0x89, hi: 0x89}, - {value: 0xa000, lo: 0x90, hi: 0x90}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0xa000, lo: 0x94, hi: 0x94}, - {value: 0x3bb9, lo: 0x9a, hi: 0x9b}, - {value: 0x3bc7, lo: 0xae, hi: 0xae}, - // Block 0x43, offset 0x1b7 - {value: 0x000e, lo: 0x05}, - {value: 0x3bce, lo: 0x8d, hi: 0x8e}, - {value: 0x3bd5, lo: 0x8f, hi: 0x8f}, - {value: 0xa000, lo: 0x90, hi: 0x90}, - {value: 0xa000, lo: 0x92, hi: 0x92}, - {value: 0xa000, lo: 0x94, hi: 0x94}, - // Block 0x44, offset 0x1bd - {value: 0x0173, lo: 0x0e}, - {value: 0xa000, lo: 0x83, hi: 0x83}, - {value: 0x3be3, lo: 0x84, hi: 0x84}, - {value: 0xa000, lo: 0x88, hi: 0x88}, - {value: 0x3bea, lo: 0x89, hi: 0x89}, - {value: 0xa000, lo: 0x8b, hi: 0x8b}, - {value: 0x3bf1, lo: 0x8c, hi: 0x8c}, - {value: 0xa000, lo: 0xa3, hi: 0xa3}, - {value: 0x3bf8, lo: 0xa4, hi: 0xa4}, - {value: 0xa000, lo: 0xa5, hi: 0xa5}, - {value: 0x3bff, lo: 0xa6, hi: 0xa6}, - {value: 0x269f, lo: 0xac, hi: 0xad}, - {value: 0x26a6, lo: 0xaf, hi: 0xaf}, - {value: 0x281c, lo: 0xb0, hi: 0xb0}, - {value: 0xa000, lo: 0xbc, hi: 0xbc}, - // Block 0x45, offset 0x1cc - {value: 0x0007, lo: 0x03}, - {value: 0x3c68, lo: 0xa0, hi: 0xa1}, - {value: 0x3c92, lo: 0xa2, hi: 0xa3}, - {value: 0x3cbc, lo: 0xaa, hi: 0xad}, - // Block 0x46, offset 0x1d0 - {value: 0x0004, lo: 0x01}, - {value: 0x048b, lo: 0xa9, hi: 0xaa}, - // Block 0x47, offset 0x1d2 - {value: 0x0002, lo: 0x03}, - {value: 0x0057, lo: 0x80, hi: 0x8f}, - {value: 0x0083, lo: 0x90, hi: 0xa9}, - {value: 0x0021, lo: 0xaa, hi: 0xaa}, - // Block 0x48, offset 0x1d6 - {value: 0x0000, lo: 0x01}, - {value: 0x299b, lo: 0x8c, hi: 0x8c}, - // Block 0x49, offset 0x1d8 - {value: 0x0263, lo: 0x02}, - {value: 0x1b8c, lo: 0xb4, hi: 0xb4}, - {value: 0x192d, lo: 0xb5, hi: 0xb6}, - // Block 0x4a, offset 0x1db - {value: 0x0000, lo: 0x01}, - {value: 0x4573, lo: 0x9c, hi: 0x9c}, - // Block 0x4b, offset 0x1dd - {value: 0x0000, lo: 0x02}, - {value: 0x0095, lo: 0xbc, hi: 0xbc}, - {value: 0x006d, lo: 0xbd, hi: 0xbd}, - // Block 0x4c, offset 0x1e0 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xaf, hi: 0xb1}, - // Block 0x4d, offset 0x1e2 - {value: 0x0000, lo: 0x02}, - {value: 0x047f, lo: 0xaf, hi: 0xaf}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x4e, offset 0x1e5 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xa0, hi: 0xbf}, - // Block 0x4f, offset 0x1e7 - {value: 0x0000, lo: 0x01}, - {value: 0x0dc3, lo: 0x9f, hi: 0x9f}, - // Block 0x50, offset 0x1e9 - {value: 0x0000, lo: 0x01}, - {value: 0x162f, lo: 0xb3, hi: 0xb3}, - // Block 0x51, offset 0x1eb - {value: 0x0004, lo: 0x0b}, - {value: 0x1597, lo: 0x80, hi: 0x82}, - {value: 0x15af, lo: 0x83, hi: 0x83}, - {value: 0x15c7, lo: 0x84, hi: 0x85}, - {value: 0x15d7, lo: 0x86, hi: 0x89}, - {value: 0x15eb, lo: 0x8a, hi: 0x8c}, - {value: 0x15ff, lo: 0x8d, hi: 0x8d}, - {value: 0x1607, lo: 0x8e, hi: 0x8e}, - {value: 0x160f, lo: 0x8f, hi: 0x90}, - {value: 0x161b, lo: 0x91, hi: 0x93}, - {value: 0x162b, lo: 0x94, hi: 0x94}, - {value: 0x1633, lo: 0x95, hi: 0x95}, - // Block 0x52, offset 0x1f7 - {value: 0x0004, lo: 0x09}, - {value: 0x0001, lo: 0x80, hi: 0x80}, - {value: 0x812c, lo: 0xaa, hi: 0xaa}, - {value: 0x8131, lo: 0xab, hi: 0xab}, - {value: 0x8133, lo: 0xac, hi: 0xac}, - {value: 0x812e, lo: 0xad, hi: 0xad}, - {value: 0x812f, lo: 0xae, hi: 0xae}, - {value: 0x812f, lo: 0xaf, hi: 0xaf}, - {value: 0x04b3, lo: 0xb6, hi: 0xb6}, - {value: 0x0887, lo: 0xb8, hi: 0xba}, - // Block 0x53, offset 0x201 - {value: 0x0005, lo: 0x09}, - {value: 0x0313, lo: 0xb1, hi: 0xb1}, - {value: 0x0317, lo: 0xb2, hi: 0xb2}, - {value: 0x4345, lo: 0xb3, hi: 0xb3}, - {value: 0x031b, lo: 0xb4, hi: 0xb4}, - {value: 0x434a, lo: 0xb5, hi: 0xb6}, - {value: 0x031f, lo: 0xb7, hi: 0xb7}, - {value: 0x0323, lo: 0xb8, hi: 0xb8}, - {value: 0x0327, lo: 0xb9, hi: 0xb9}, - {value: 0x4354, lo: 0xba, hi: 0xbf}, - // Block 0x54, offset 0x20b - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0xaf, hi: 0xaf}, - {value: 0x8132, lo: 0xb4, hi: 0xbd}, - // Block 0x55, offset 0x20e - {value: 0x0000, lo: 0x03}, - {value: 0x020f, lo: 0x9c, hi: 0x9c}, - {value: 0x0212, lo: 0x9d, hi: 0x9d}, - {value: 0x8132, lo: 0x9e, hi: 0x9f}, - // Block 0x56, offset 0x212 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb0, hi: 0xb1}, - // Block 0x57, offset 0x214 - {value: 0x0000, lo: 0x01}, - {value: 0x163b, lo: 0xb0, hi: 0xb0}, - // Block 0x58, offset 0x216 - {value: 0x000c, lo: 0x01}, - {value: 0x00d7, lo: 0xb8, hi: 0xb9}, - // Block 0x59, offset 0x218 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x86, hi: 0x86}, - // Block 0x5a, offset 0x21a - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x84, hi: 0x84}, - {value: 0x8132, lo: 0xa0, hi: 0xb1}, - // Block 0x5b, offset 0x21d - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xab, hi: 0xad}, - // Block 0x5c, offset 0x21f - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x93, hi: 0x93}, - // Block 0x5d, offset 0x221 - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0xb3, hi: 0xb3}, - // Block 0x5e, offset 0x223 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0x80, hi: 0x80}, - // Block 0x5f, offset 0x225 - {value: 0x0000, lo: 0x05}, - {value: 0x8132, lo: 0xb0, hi: 0xb0}, - {value: 0x8132, lo: 0xb2, hi: 0xb3}, - {value: 0x812d, lo: 0xb4, hi: 0xb4}, - {value: 0x8132, lo: 0xb7, hi: 0xb8}, - {value: 0x8132, lo: 0xbe, hi: 0xbf}, - // Block 0x60, offset 0x22b - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x81, hi: 0x81}, - {value: 0x8104, lo: 0xb6, hi: 0xb6}, - // Block 0x61, offset 0x22e - {value: 0x0008, lo: 0x03}, - {value: 0x1637, lo: 0x9c, hi: 0x9d}, - {value: 0x0125, lo: 0x9e, hi: 0x9e}, - {value: 0x1643, lo: 0x9f, hi: 0x9f}, - // Block 0x62, offset 0x232 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xad, hi: 0xad}, - // Block 0x63, offset 0x234 - {value: 0x0000, lo: 0x06}, - {value: 0xe500, lo: 0x80, hi: 0x80}, - {value: 0xc600, lo: 0x81, hi: 0x9b}, - {value: 0xe500, lo: 0x9c, hi: 0x9c}, - {value: 0xc600, lo: 0x9d, hi: 0xb7}, - {value: 0xe500, lo: 0xb8, hi: 0xb8}, - {value: 0xc600, lo: 0xb9, hi: 0xbf}, - // Block 0x64, offset 0x23b - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x93}, - {value: 0xe500, lo: 0x94, hi: 0x94}, - {value: 0xc600, lo: 0x95, hi: 0xaf}, - {value: 0xe500, lo: 0xb0, hi: 0xb0}, - {value: 0xc600, lo: 0xb1, hi: 0xbf}, - // Block 0x65, offset 0x241 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x8b}, - {value: 0xe500, lo: 0x8c, hi: 0x8c}, - {value: 0xc600, lo: 0x8d, hi: 0xa7}, - {value: 0xe500, lo: 0xa8, hi: 0xa8}, - {value: 0xc600, lo: 0xa9, hi: 0xbf}, - // Block 0x66, offset 0x247 - {value: 0x0000, lo: 0x07}, - {value: 0xc600, lo: 0x80, hi: 0x83}, - {value: 0xe500, lo: 0x84, hi: 0x84}, - {value: 0xc600, lo: 0x85, hi: 0x9f}, - {value: 0xe500, lo: 0xa0, hi: 0xa0}, - {value: 0xc600, lo: 0xa1, hi: 0xbb}, - {value: 0xe500, lo: 0xbc, hi: 0xbc}, - {value: 0xc600, lo: 0xbd, hi: 0xbf}, - // Block 0x67, offset 0x24f - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x97}, - {value: 0xe500, lo: 0x98, hi: 0x98}, - {value: 0xc600, lo: 0x99, hi: 0xb3}, - {value: 0xe500, lo: 0xb4, hi: 0xb4}, - {value: 0xc600, lo: 0xb5, hi: 0xbf}, - // Block 0x68, offset 0x255 - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x8f}, - {value: 0xe500, lo: 0x90, hi: 0x90}, - {value: 0xc600, lo: 0x91, hi: 0xab}, - {value: 0xe500, lo: 0xac, hi: 0xac}, - {value: 0xc600, lo: 0xad, hi: 0xbf}, - // Block 0x69, offset 0x25b - {value: 0x0000, lo: 0x05}, - {value: 0xc600, lo: 0x80, hi: 0x87}, - {value: 0xe500, lo: 0x88, hi: 0x88}, - {value: 0xc600, lo: 0x89, hi: 0xa3}, - {value: 0xe500, lo: 0xa4, hi: 0xa4}, - {value: 0xc600, lo: 0xa5, hi: 0xbf}, - // Block 0x6a, offset 0x261 - {value: 0x0000, lo: 0x03}, - {value: 0xc600, lo: 0x80, hi: 0x87}, - {value: 0xe500, lo: 0x88, hi: 0x88}, - {value: 0xc600, lo: 0x89, hi: 0xa3}, - // Block 0x6b, offset 0x265 - {value: 0x0002, lo: 0x01}, - {value: 0x0003, lo: 0x81, hi: 0xbf}, - // Block 0x6c, offset 0x267 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xbd, hi: 0xbd}, - // Block 0x6d, offset 0x269 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0xa0, hi: 0xa0}, - // Block 0x6e, offset 0x26b - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb6, hi: 0xba}, - // Block 0x6f, offset 0x26d - {value: 0x002c, lo: 0x05}, - {value: 0x812d, lo: 0x8d, hi: 0x8d}, - {value: 0x8132, lo: 0x8f, hi: 0x8f}, - {value: 0x8132, lo: 0xb8, hi: 0xb8}, - {value: 0x8101, lo: 0xb9, hi: 0xba}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x70, offset 0x273 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0xa5, hi: 0xa5}, - {value: 0x812d, lo: 0xa6, hi: 0xa6}, - // Block 0x71, offset 0x276 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x86, hi: 0x86}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x72, offset 0x279 - {value: 0x17fe, lo: 0x07}, - {value: 0xa000, lo: 0x99, hi: 0x99}, - {value: 0x4238, lo: 0x9a, hi: 0x9a}, - {value: 0xa000, lo: 0x9b, hi: 0x9b}, - {value: 0x4242, lo: 0x9c, hi: 0x9c}, - {value: 0xa000, lo: 0xa5, hi: 0xa5}, - {value: 0x424c, lo: 0xab, hi: 0xab}, - {value: 0x8104, lo: 0xb9, hi: 0xba}, - // Block 0x73, offset 0x281 - {value: 0x0000, lo: 0x06}, - {value: 0x8132, lo: 0x80, hi: 0x82}, - {value: 0x9900, lo: 0xa7, hi: 0xa7}, - {value: 0x2d7e, lo: 0xae, hi: 0xae}, - {value: 0x2d88, lo: 0xaf, hi: 0xaf}, - {value: 0xa000, lo: 0xb1, hi: 0xb2}, - {value: 0x8104, lo: 0xb3, hi: 0xb4}, - // Block 0x74, offset 0x288 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x80, hi: 0x80}, - {value: 0x8102, lo: 0x8a, hi: 0x8a}, - // Block 0x75, offset 0x28b - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0xb5, hi: 0xb5}, - {value: 0x8102, lo: 0xb6, hi: 0xb6}, - // Block 0x76, offset 0x28e - {value: 0x0002, lo: 0x01}, - {value: 0x8102, lo: 0xa9, hi: 0xaa}, - // Block 0x77, offset 0x290 - {value: 0x0000, lo: 0x07}, - {value: 0xa000, lo: 0x87, hi: 0x87}, - {value: 0x2d92, lo: 0x8b, hi: 0x8b}, - {value: 0x2d9c, lo: 0x8c, hi: 0x8c}, - {value: 0x8104, lo: 0x8d, hi: 0x8d}, - {value: 0x9900, lo: 0x97, hi: 0x97}, - {value: 0x8132, lo: 0xa6, hi: 0xac}, - {value: 0x8132, lo: 0xb0, hi: 0xb4}, - // Block 0x78, offset 0x298 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x82, hi: 0x82}, - {value: 0x8102, lo: 0x86, hi: 0x86}, - // Block 0x79, offset 0x29b - {value: 0x6b5a, lo: 0x06}, - {value: 0x9900, lo: 0xb0, hi: 0xb0}, - {value: 0xa000, lo: 0xb9, hi: 0xb9}, - {value: 0x9900, lo: 0xba, hi: 0xba}, - {value: 0x2db0, lo: 0xbb, hi: 0xbb}, - {value: 0x2da6, lo: 0xbc, hi: 0xbd}, - {value: 0x2dba, lo: 0xbe, hi: 0xbe}, - // Block 0x7a, offset 0x2a2 - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0x82, hi: 0x82}, - {value: 0x8102, lo: 0x83, hi: 0x83}, - // Block 0x7b, offset 0x2a5 - {value: 0x0000, lo: 0x05}, - {value: 0x9900, lo: 0xaf, hi: 0xaf}, - {value: 0xa000, lo: 0xb8, hi: 0xb9}, - {value: 0x2dc4, lo: 0xba, hi: 0xba}, - {value: 0x2dce, lo: 0xbb, hi: 0xbb}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x7c, offset 0x2ab - {value: 0x0000, lo: 0x01}, - {value: 0x8102, lo: 0x80, hi: 0x80}, - // Block 0x7d, offset 0x2ad - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xbf, hi: 0xbf}, - // Block 0x7e, offset 0x2af - {value: 0x0000, lo: 0x02}, - {value: 0x8104, lo: 0xb6, hi: 0xb6}, - {value: 0x8102, lo: 0xb7, hi: 0xb7}, - // Block 0x7f, offset 0x2b2 - {value: 0x0000, lo: 0x01}, - {value: 0x8104, lo: 0xab, hi: 0xab}, - // Block 0x80, offset 0x2b4 - {value: 0x0000, lo: 0x01}, - {value: 0x8101, lo: 0xb0, hi: 0xb4}, - // Block 0x81, offset 0x2b6 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0xb0, hi: 0xb6}, - // Block 0x82, offset 0x2b8 - {value: 0x0000, lo: 0x01}, - {value: 0x8101, lo: 0x9e, hi: 0x9e}, - // Block 0x83, offset 0x2ba - {value: 0x0000, lo: 0x0c}, - {value: 0x4662, lo: 0x9e, hi: 0x9e}, - {value: 0x466c, lo: 0x9f, hi: 0x9f}, - {value: 0x46a0, lo: 0xa0, hi: 0xa0}, - {value: 0x46ae, lo: 0xa1, hi: 0xa1}, - {value: 0x46bc, lo: 0xa2, hi: 0xa2}, - {value: 0x46ca, lo: 0xa3, hi: 0xa3}, - {value: 0x46d8, lo: 0xa4, hi: 0xa4}, - {value: 0x812b, lo: 0xa5, hi: 0xa6}, - {value: 0x8101, lo: 0xa7, hi: 0xa9}, - {value: 0x8130, lo: 0xad, hi: 0xad}, - {value: 0x812b, lo: 0xae, hi: 0xb2}, - {value: 0x812d, lo: 0xbb, hi: 0xbf}, - // Block 0x84, offset 0x2c7 - {value: 0x0000, lo: 0x09}, - {value: 0x812d, lo: 0x80, hi: 0x82}, - {value: 0x8132, lo: 0x85, hi: 0x89}, - {value: 0x812d, lo: 0x8a, hi: 0x8b}, - {value: 0x8132, lo: 0xaa, hi: 0xad}, - {value: 0x4676, lo: 0xbb, hi: 0xbb}, - {value: 0x4680, lo: 0xbc, hi: 0xbc}, - {value: 0x46e6, lo: 0xbd, hi: 0xbd}, - {value: 0x4702, lo: 0xbe, hi: 0xbe}, - {value: 0x46f4, lo: 0xbf, hi: 0xbf}, - // Block 0x85, offset 0x2d1 - {value: 0x0000, lo: 0x01}, - {value: 0x4710, lo: 0x80, hi: 0x80}, - // Block 0x86, offset 0x2d3 - {value: 0x0000, lo: 0x01}, - {value: 0x8132, lo: 0x82, hi: 0x84}, - // Block 0x87, offset 0x2d5 - {value: 0x0002, lo: 0x03}, - {value: 0x0043, lo: 0x80, hi: 0x99}, - {value: 0x0083, lo: 0x9a, hi: 0xb3}, - {value: 0x0043, lo: 0xb4, hi: 0xbf}, - // Block 0x88, offset 0x2d9 - {value: 0x0002, lo: 0x04}, - {value: 0x005b, lo: 0x80, hi: 0x8d}, - {value: 0x0083, lo: 0x8e, hi: 0x94}, - {value: 0x0093, lo: 0x96, hi: 0xa7}, - {value: 0x0043, lo: 0xa8, hi: 0xbf}, - // Block 0x89, offset 0x2de - {value: 0x0002, lo: 0x0b}, - {value: 0x0073, lo: 0x80, hi: 0x81}, - {value: 0x0083, lo: 0x82, hi: 0x9b}, - {value: 0x0043, lo: 0x9c, hi: 0x9c}, - {value: 0x0047, lo: 0x9e, hi: 0x9f}, - {value: 0x004f, lo: 0xa2, hi: 0xa2}, - {value: 0x0055, lo: 0xa5, hi: 0xa6}, - {value: 0x005d, lo: 0xa9, hi: 0xac}, - {value: 0x0067, lo: 0xae, hi: 0xb5}, - {value: 0x0083, lo: 0xb6, hi: 0xb9}, - {value: 0x008d, lo: 0xbb, hi: 0xbb}, - {value: 0x0091, lo: 0xbd, hi: 0xbf}, - // Block 0x8a, offset 0x2ea - {value: 0x0002, lo: 0x04}, - {value: 0x0097, lo: 0x80, hi: 0x83}, - {value: 0x00a1, lo: 0x85, hi: 0x8f}, - {value: 0x0043, lo: 0x90, hi: 0xa9}, - {value: 0x0083, lo: 0xaa, hi: 0xbf}, - // Block 0x8b, offset 0x2ef - {value: 0x0002, lo: 0x08}, - {value: 0x00af, lo: 0x80, hi: 0x83}, - {value: 0x0043, lo: 0x84, hi: 0x85}, - {value: 0x0049, lo: 0x87, hi: 0x8a}, - {value: 0x0055, lo: 0x8d, hi: 0x94}, - {value: 0x0067, lo: 0x96, hi: 0x9c}, - {value: 0x0083, lo: 0x9e, hi: 0xb7}, - {value: 0x0043, lo: 0xb8, hi: 0xb9}, - {value: 0x0049, lo: 0xbb, hi: 0xbe}, - // Block 0x8c, offset 0x2f8 - {value: 0x0002, lo: 0x05}, - {value: 0x0053, lo: 0x80, hi: 0x84}, - {value: 0x005f, lo: 0x86, hi: 0x86}, - {value: 0x0067, lo: 0x8a, hi: 0x90}, - {value: 0x0083, lo: 0x92, hi: 0xab}, - {value: 0x0043, lo: 0xac, hi: 0xbf}, - // Block 0x8d, offset 0x2fe - {value: 0x0002, lo: 0x04}, - {value: 0x006b, lo: 0x80, hi: 0x85}, - {value: 0x0083, lo: 0x86, hi: 0x9f}, - {value: 0x0043, lo: 0xa0, hi: 0xb9}, - {value: 0x0083, lo: 0xba, hi: 0xbf}, - // Block 0x8e, offset 0x303 - {value: 0x0002, lo: 0x03}, - {value: 0x008f, lo: 0x80, hi: 0x93}, - {value: 0x0043, lo: 0x94, hi: 0xad}, - {value: 0x0083, lo: 0xae, hi: 0xbf}, - // Block 0x8f, offset 0x307 - {value: 0x0002, lo: 0x04}, - {value: 0x00a7, lo: 0x80, hi: 0x87}, - {value: 0x0043, lo: 0x88, hi: 0xa1}, - {value: 0x0083, lo: 0xa2, hi: 0xbb}, - {value: 0x0043, lo: 0xbc, hi: 0xbf}, - // Block 0x90, offset 0x30c - {value: 0x0002, lo: 0x03}, - {value: 0x004b, lo: 0x80, hi: 0x95}, - {value: 0x0083, lo: 0x96, hi: 0xaf}, - {value: 0x0043, lo: 0xb0, hi: 0xbf}, - // Block 0x91, offset 0x310 - {value: 0x0003, lo: 0x0f}, - {value: 0x01b8, lo: 0x80, hi: 0x80}, - {value: 0x045f, lo: 0x81, hi: 0x81}, - {value: 0x01bb, lo: 0x82, hi: 0x9a}, - {value: 0x045b, lo: 0x9b, hi: 0x9b}, - {value: 0x01c7, lo: 0x9c, hi: 0x9c}, - {value: 0x01d0, lo: 0x9d, hi: 0x9d}, - {value: 0x01d6, lo: 0x9e, hi: 0x9e}, - {value: 0x01fa, lo: 0x9f, hi: 0x9f}, - {value: 0x01eb, lo: 0xa0, hi: 0xa0}, - {value: 0x01e8, lo: 0xa1, hi: 0xa1}, - {value: 0x0173, lo: 0xa2, hi: 0xb2}, - {value: 0x0188, lo: 0xb3, hi: 0xb3}, - {value: 0x01a6, lo: 0xb4, hi: 0xba}, - {value: 0x045f, lo: 0xbb, hi: 0xbb}, - {value: 0x01bb, lo: 0xbc, hi: 0xbf}, - // Block 0x92, offset 0x320 - {value: 0x0003, lo: 0x0d}, - {value: 0x01c7, lo: 0x80, hi: 0x94}, - {value: 0x045b, lo: 0x95, hi: 0x95}, - {value: 0x01c7, lo: 0x96, hi: 0x96}, - {value: 0x01d0, lo: 0x97, hi: 0x97}, - {value: 0x01d6, lo: 0x98, hi: 0x98}, - {value: 0x01fa, lo: 0x99, hi: 0x99}, - {value: 0x01eb, lo: 0x9a, hi: 0x9a}, - {value: 0x01e8, lo: 0x9b, hi: 0x9b}, - {value: 0x0173, lo: 0x9c, hi: 0xac}, - {value: 0x0188, lo: 0xad, hi: 0xad}, - {value: 0x01a6, lo: 0xae, hi: 0xb4}, - {value: 0x045f, lo: 0xb5, hi: 0xb5}, - {value: 0x01bb, lo: 0xb6, hi: 0xbf}, - // Block 0x93, offset 0x32e - {value: 0x0003, lo: 0x0d}, - {value: 0x01d9, lo: 0x80, hi: 0x8e}, - {value: 0x045b, lo: 0x8f, hi: 0x8f}, - {value: 0x01c7, lo: 0x90, hi: 0x90}, - {value: 0x01d0, lo: 0x91, hi: 0x91}, - {value: 0x01d6, lo: 0x92, hi: 0x92}, - {value: 0x01fa, lo: 0x93, hi: 0x93}, - {value: 0x01eb, lo: 0x94, hi: 0x94}, - {value: 0x01e8, lo: 0x95, hi: 0x95}, - {value: 0x0173, lo: 0x96, hi: 0xa6}, - {value: 0x0188, lo: 0xa7, hi: 0xa7}, - {value: 0x01a6, lo: 0xa8, hi: 0xae}, - {value: 0x045f, lo: 0xaf, hi: 0xaf}, - {value: 0x01bb, lo: 0xb0, hi: 0xbf}, - // Block 0x94, offset 0x33c - {value: 0x0003, lo: 0x0d}, - {value: 0x01eb, lo: 0x80, hi: 0x88}, - {value: 0x045b, lo: 0x89, hi: 0x89}, - {value: 0x01c7, lo: 0x8a, hi: 0x8a}, - {value: 0x01d0, lo: 0x8b, hi: 0x8b}, - {value: 0x01d6, lo: 0x8c, hi: 0x8c}, - {value: 0x01fa, lo: 0x8d, hi: 0x8d}, - {value: 0x01eb, lo: 0x8e, hi: 0x8e}, - {value: 0x01e8, lo: 0x8f, hi: 0x8f}, - {value: 0x0173, lo: 0x90, hi: 0xa0}, - {value: 0x0188, lo: 0xa1, hi: 0xa1}, - {value: 0x01a6, lo: 0xa2, hi: 0xa8}, - {value: 0x045f, lo: 0xa9, hi: 0xa9}, - {value: 0x01bb, lo: 0xaa, hi: 0xbf}, - // Block 0x95, offset 0x34a - {value: 0x0000, lo: 0x05}, - {value: 0x8132, lo: 0x80, hi: 0x86}, - {value: 0x8132, lo: 0x88, hi: 0x98}, - {value: 0x8132, lo: 0x9b, hi: 0xa1}, - {value: 0x8132, lo: 0xa3, hi: 0xa4}, - {value: 0x8132, lo: 0xa6, hi: 0xaa}, - // Block 0x96, offset 0x350 - {value: 0x0000, lo: 0x01}, - {value: 0x812d, lo: 0x90, hi: 0x96}, - // Block 0x97, offset 0x352 - {value: 0x0000, lo: 0x02}, - {value: 0x8132, lo: 0x84, hi: 0x89}, - {value: 0x8102, lo: 0x8a, hi: 0x8a}, - // Block 0x98, offset 0x355 - {value: 0x0002, lo: 0x09}, - {value: 0x0063, lo: 0x80, hi: 0x89}, - {value: 0x1951, lo: 0x8a, hi: 0x8a}, - {value: 0x1981, lo: 0x8b, hi: 0x8b}, - {value: 0x199c, lo: 0x8c, hi: 0x8c}, - {value: 0x19a2, lo: 0x8d, hi: 0x8d}, - {value: 0x1bc0, lo: 0x8e, hi: 0x8e}, - {value: 0x19ae, lo: 0x8f, hi: 0x8f}, - {value: 0x197b, lo: 0xaa, hi: 0xaa}, - {value: 0x197e, lo: 0xab, hi: 0xab}, - // Block 0x99, offset 0x35f - {value: 0x0000, lo: 0x01}, - {value: 0x193f, lo: 0x90, hi: 0x90}, - // Block 0x9a, offset 0x361 - {value: 0x0028, lo: 0x09}, - {value: 0x2862, lo: 0x80, hi: 0x80}, - {value: 0x2826, lo: 0x81, hi: 0x81}, - {value: 0x2830, lo: 0x82, hi: 0x82}, - {value: 0x2844, lo: 0x83, hi: 0x84}, - {value: 0x284e, lo: 0x85, hi: 0x86}, - {value: 0x283a, lo: 0x87, hi: 0x87}, - {value: 0x2858, lo: 0x88, hi: 0x88}, - {value: 0x0b6f, lo: 0x90, hi: 0x90}, - {value: 0x08e7, lo: 0x91, hi: 0x91}, -} - -// recompMap: 7520 bytes (entries only) -var recompMap = map[uint32]rune{ - 0x00410300: 0x00C0, - 0x00410301: 0x00C1, - 0x00410302: 0x00C2, - 0x00410303: 0x00C3, - 0x00410308: 0x00C4, - 0x0041030A: 0x00C5, - 0x00430327: 0x00C7, - 0x00450300: 0x00C8, - 0x00450301: 0x00C9, - 0x00450302: 0x00CA, - 0x00450308: 0x00CB, - 0x00490300: 0x00CC, - 0x00490301: 0x00CD, - 0x00490302: 0x00CE, - 0x00490308: 0x00CF, - 0x004E0303: 0x00D1, - 0x004F0300: 0x00D2, - 0x004F0301: 0x00D3, - 0x004F0302: 0x00D4, - 0x004F0303: 0x00D5, - 0x004F0308: 0x00D6, - 0x00550300: 0x00D9, - 0x00550301: 0x00DA, - 0x00550302: 0x00DB, - 0x00550308: 0x00DC, - 0x00590301: 0x00DD, - 0x00610300: 0x00E0, - 0x00610301: 0x00E1, - 0x00610302: 0x00E2, - 0x00610303: 0x00E3, - 0x00610308: 0x00E4, - 0x0061030A: 0x00E5, - 0x00630327: 0x00E7, - 0x00650300: 0x00E8, - 0x00650301: 0x00E9, - 0x00650302: 0x00EA, - 0x00650308: 0x00EB, - 0x00690300: 0x00EC, - 0x00690301: 0x00ED, - 0x00690302: 0x00EE, - 0x00690308: 0x00EF, - 0x006E0303: 0x00F1, - 0x006F0300: 0x00F2, - 0x006F0301: 0x00F3, - 0x006F0302: 0x00F4, - 0x006F0303: 0x00F5, - 0x006F0308: 0x00F6, - 0x00750300: 0x00F9, - 0x00750301: 0x00FA, - 0x00750302: 0x00FB, - 0x00750308: 0x00FC, - 0x00790301: 0x00FD, - 0x00790308: 0x00FF, - 0x00410304: 0x0100, - 0x00610304: 0x0101, - 0x00410306: 0x0102, - 0x00610306: 0x0103, - 0x00410328: 0x0104, - 0x00610328: 0x0105, - 0x00430301: 0x0106, - 0x00630301: 0x0107, - 0x00430302: 0x0108, - 0x00630302: 0x0109, - 0x00430307: 0x010A, - 0x00630307: 0x010B, - 0x0043030C: 0x010C, - 0x0063030C: 0x010D, - 0x0044030C: 0x010E, - 0x0064030C: 0x010F, - 0x00450304: 0x0112, - 0x00650304: 0x0113, - 0x00450306: 0x0114, - 0x00650306: 0x0115, - 0x00450307: 0x0116, - 0x00650307: 0x0117, - 0x00450328: 0x0118, - 0x00650328: 0x0119, - 0x0045030C: 0x011A, - 0x0065030C: 0x011B, - 0x00470302: 0x011C, - 0x00670302: 0x011D, - 0x00470306: 0x011E, - 0x00670306: 0x011F, - 0x00470307: 0x0120, - 0x00670307: 0x0121, - 0x00470327: 0x0122, - 0x00670327: 0x0123, - 0x00480302: 0x0124, - 0x00680302: 0x0125, - 0x00490303: 0x0128, - 0x00690303: 0x0129, - 0x00490304: 0x012A, - 0x00690304: 0x012B, - 0x00490306: 0x012C, - 0x00690306: 0x012D, - 0x00490328: 0x012E, - 0x00690328: 0x012F, - 0x00490307: 0x0130, - 0x004A0302: 0x0134, - 0x006A0302: 0x0135, - 0x004B0327: 0x0136, - 0x006B0327: 0x0137, - 0x004C0301: 0x0139, - 0x006C0301: 0x013A, - 0x004C0327: 0x013B, - 0x006C0327: 0x013C, - 0x004C030C: 0x013D, - 0x006C030C: 0x013E, - 0x004E0301: 0x0143, - 0x006E0301: 0x0144, - 0x004E0327: 0x0145, - 0x006E0327: 0x0146, - 0x004E030C: 0x0147, - 0x006E030C: 0x0148, - 0x004F0304: 0x014C, - 0x006F0304: 0x014D, - 0x004F0306: 0x014E, - 0x006F0306: 0x014F, - 0x004F030B: 0x0150, - 0x006F030B: 0x0151, - 0x00520301: 0x0154, - 0x00720301: 0x0155, - 0x00520327: 0x0156, - 0x00720327: 0x0157, - 0x0052030C: 0x0158, - 0x0072030C: 0x0159, - 0x00530301: 0x015A, - 0x00730301: 0x015B, - 0x00530302: 0x015C, - 0x00730302: 0x015D, - 0x00530327: 0x015E, - 0x00730327: 0x015F, - 0x0053030C: 0x0160, - 0x0073030C: 0x0161, - 0x00540327: 0x0162, - 0x00740327: 0x0163, - 0x0054030C: 0x0164, - 0x0074030C: 0x0165, - 0x00550303: 0x0168, - 0x00750303: 0x0169, - 0x00550304: 0x016A, - 0x00750304: 0x016B, - 0x00550306: 0x016C, - 0x00750306: 0x016D, - 0x0055030A: 0x016E, - 0x0075030A: 0x016F, - 0x0055030B: 0x0170, - 0x0075030B: 0x0171, - 0x00550328: 0x0172, - 0x00750328: 0x0173, - 0x00570302: 0x0174, - 0x00770302: 0x0175, - 0x00590302: 0x0176, - 0x00790302: 0x0177, - 0x00590308: 0x0178, - 0x005A0301: 0x0179, - 0x007A0301: 0x017A, - 0x005A0307: 0x017B, - 0x007A0307: 0x017C, - 0x005A030C: 0x017D, - 0x007A030C: 0x017E, - 0x004F031B: 0x01A0, - 0x006F031B: 0x01A1, - 0x0055031B: 0x01AF, - 0x0075031B: 0x01B0, - 0x0041030C: 0x01CD, - 0x0061030C: 0x01CE, - 0x0049030C: 0x01CF, - 0x0069030C: 0x01D0, - 0x004F030C: 0x01D1, - 0x006F030C: 0x01D2, - 0x0055030C: 0x01D3, - 0x0075030C: 0x01D4, - 0x00DC0304: 0x01D5, - 0x00FC0304: 0x01D6, - 0x00DC0301: 0x01D7, - 0x00FC0301: 0x01D8, - 0x00DC030C: 0x01D9, - 0x00FC030C: 0x01DA, - 0x00DC0300: 0x01DB, - 0x00FC0300: 0x01DC, - 0x00C40304: 0x01DE, - 0x00E40304: 0x01DF, - 0x02260304: 0x01E0, - 0x02270304: 0x01E1, - 0x00C60304: 0x01E2, - 0x00E60304: 0x01E3, - 0x0047030C: 0x01E6, - 0x0067030C: 0x01E7, - 0x004B030C: 0x01E8, - 0x006B030C: 0x01E9, - 0x004F0328: 0x01EA, - 0x006F0328: 0x01EB, - 0x01EA0304: 0x01EC, - 0x01EB0304: 0x01ED, - 0x01B7030C: 0x01EE, - 0x0292030C: 0x01EF, - 0x006A030C: 0x01F0, - 0x00470301: 0x01F4, - 0x00670301: 0x01F5, - 0x004E0300: 0x01F8, - 0x006E0300: 0x01F9, - 0x00C50301: 0x01FA, - 0x00E50301: 0x01FB, - 0x00C60301: 0x01FC, - 0x00E60301: 0x01FD, - 0x00D80301: 0x01FE, - 0x00F80301: 0x01FF, - 0x0041030F: 0x0200, - 0x0061030F: 0x0201, - 0x00410311: 0x0202, - 0x00610311: 0x0203, - 0x0045030F: 0x0204, - 0x0065030F: 0x0205, - 0x00450311: 0x0206, - 0x00650311: 0x0207, - 0x0049030F: 0x0208, - 0x0069030F: 0x0209, - 0x00490311: 0x020A, - 0x00690311: 0x020B, - 0x004F030F: 0x020C, - 0x006F030F: 0x020D, - 0x004F0311: 0x020E, - 0x006F0311: 0x020F, - 0x0052030F: 0x0210, - 0x0072030F: 0x0211, - 0x00520311: 0x0212, - 0x00720311: 0x0213, - 0x0055030F: 0x0214, - 0x0075030F: 0x0215, - 0x00550311: 0x0216, - 0x00750311: 0x0217, - 0x00530326: 0x0218, - 0x00730326: 0x0219, - 0x00540326: 0x021A, - 0x00740326: 0x021B, - 0x0048030C: 0x021E, - 0x0068030C: 0x021F, - 0x00410307: 0x0226, - 0x00610307: 0x0227, - 0x00450327: 0x0228, - 0x00650327: 0x0229, - 0x00D60304: 0x022A, - 0x00F60304: 0x022B, - 0x00D50304: 0x022C, - 0x00F50304: 0x022D, - 0x004F0307: 0x022E, - 0x006F0307: 0x022F, - 0x022E0304: 0x0230, - 0x022F0304: 0x0231, - 0x00590304: 0x0232, - 0x00790304: 0x0233, - 0x00A80301: 0x0385, - 0x03910301: 0x0386, - 0x03950301: 0x0388, - 0x03970301: 0x0389, - 0x03990301: 0x038A, - 0x039F0301: 0x038C, - 0x03A50301: 0x038E, - 0x03A90301: 0x038F, - 0x03CA0301: 0x0390, - 0x03990308: 0x03AA, - 0x03A50308: 0x03AB, - 0x03B10301: 0x03AC, - 0x03B50301: 0x03AD, - 0x03B70301: 0x03AE, - 0x03B90301: 0x03AF, - 0x03CB0301: 0x03B0, - 0x03B90308: 0x03CA, - 0x03C50308: 0x03CB, - 0x03BF0301: 0x03CC, - 0x03C50301: 0x03CD, - 0x03C90301: 0x03CE, - 0x03D20301: 0x03D3, - 0x03D20308: 0x03D4, - 0x04150300: 0x0400, - 0x04150308: 0x0401, - 0x04130301: 0x0403, - 0x04060308: 0x0407, - 0x041A0301: 0x040C, - 0x04180300: 0x040D, - 0x04230306: 0x040E, - 0x04180306: 0x0419, - 0x04380306: 0x0439, - 0x04350300: 0x0450, - 0x04350308: 0x0451, - 0x04330301: 0x0453, - 0x04560308: 0x0457, - 0x043A0301: 0x045C, - 0x04380300: 0x045D, - 0x04430306: 0x045E, - 0x0474030F: 0x0476, - 0x0475030F: 0x0477, - 0x04160306: 0x04C1, - 0x04360306: 0x04C2, - 0x04100306: 0x04D0, - 0x04300306: 0x04D1, - 0x04100308: 0x04D2, - 0x04300308: 0x04D3, - 0x04150306: 0x04D6, - 0x04350306: 0x04D7, - 0x04D80308: 0x04DA, - 0x04D90308: 0x04DB, - 0x04160308: 0x04DC, - 0x04360308: 0x04DD, - 0x04170308: 0x04DE, - 0x04370308: 0x04DF, - 0x04180304: 0x04E2, - 0x04380304: 0x04E3, - 0x04180308: 0x04E4, - 0x04380308: 0x04E5, - 0x041E0308: 0x04E6, - 0x043E0308: 0x04E7, - 0x04E80308: 0x04EA, - 0x04E90308: 0x04EB, - 0x042D0308: 0x04EC, - 0x044D0308: 0x04ED, - 0x04230304: 0x04EE, - 0x04430304: 0x04EF, - 0x04230308: 0x04F0, - 0x04430308: 0x04F1, - 0x0423030B: 0x04F2, - 0x0443030B: 0x04F3, - 0x04270308: 0x04F4, - 0x04470308: 0x04F5, - 0x042B0308: 0x04F8, - 0x044B0308: 0x04F9, - 0x06270653: 0x0622, - 0x06270654: 0x0623, - 0x06480654: 0x0624, - 0x06270655: 0x0625, - 0x064A0654: 0x0626, - 0x06D50654: 0x06C0, - 0x06C10654: 0x06C2, - 0x06D20654: 0x06D3, - 0x0928093C: 0x0929, - 0x0930093C: 0x0931, - 0x0933093C: 0x0934, - 0x09C709BE: 0x09CB, - 0x09C709D7: 0x09CC, - 0x0B470B56: 0x0B48, - 0x0B470B3E: 0x0B4B, - 0x0B470B57: 0x0B4C, - 0x0B920BD7: 0x0B94, - 0x0BC60BBE: 0x0BCA, - 0x0BC70BBE: 0x0BCB, - 0x0BC60BD7: 0x0BCC, - 0x0C460C56: 0x0C48, - 0x0CBF0CD5: 0x0CC0, - 0x0CC60CD5: 0x0CC7, - 0x0CC60CD6: 0x0CC8, - 0x0CC60CC2: 0x0CCA, - 0x0CCA0CD5: 0x0CCB, - 0x0D460D3E: 0x0D4A, - 0x0D470D3E: 0x0D4B, - 0x0D460D57: 0x0D4C, - 0x0DD90DCA: 0x0DDA, - 0x0DD90DCF: 0x0DDC, - 0x0DDC0DCA: 0x0DDD, - 0x0DD90DDF: 0x0DDE, - 0x1025102E: 0x1026, - 0x1B051B35: 0x1B06, - 0x1B071B35: 0x1B08, - 0x1B091B35: 0x1B0A, - 0x1B0B1B35: 0x1B0C, - 0x1B0D1B35: 0x1B0E, - 0x1B111B35: 0x1B12, - 0x1B3A1B35: 0x1B3B, - 0x1B3C1B35: 0x1B3D, - 0x1B3E1B35: 0x1B40, - 0x1B3F1B35: 0x1B41, - 0x1B421B35: 0x1B43, - 0x00410325: 0x1E00, - 0x00610325: 0x1E01, - 0x00420307: 0x1E02, - 0x00620307: 0x1E03, - 0x00420323: 0x1E04, - 0x00620323: 0x1E05, - 0x00420331: 0x1E06, - 0x00620331: 0x1E07, - 0x00C70301: 0x1E08, - 0x00E70301: 0x1E09, - 0x00440307: 0x1E0A, - 0x00640307: 0x1E0B, - 0x00440323: 0x1E0C, - 0x00640323: 0x1E0D, - 0x00440331: 0x1E0E, - 0x00640331: 0x1E0F, - 0x00440327: 0x1E10, - 0x00640327: 0x1E11, - 0x0044032D: 0x1E12, - 0x0064032D: 0x1E13, - 0x01120300: 0x1E14, - 0x01130300: 0x1E15, - 0x01120301: 0x1E16, - 0x01130301: 0x1E17, - 0x0045032D: 0x1E18, - 0x0065032D: 0x1E19, - 0x00450330: 0x1E1A, - 0x00650330: 0x1E1B, - 0x02280306: 0x1E1C, - 0x02290306: 0x1E1D, - 0x00460307: 0x1E1E, - 0x00660307: 0x1E1F, - 0x00470304: 0x1E20, - 0x00670304: 0x1E21, - 0x00480307: 0x1E22, - 0x00680307: 0x1E23, - 0x00480323: 0x1E24, - 0x00680323: 0x1E25, - 0x00480308: 0x1E26, - 0x00680308: 0x1E27, - 0x00480327: 0x1E28, - 0x00680327: 0x1E29, - 0x0048032E: 0x1E2A, - 0x0068032E: 0x1E2B, - 0x00490330: 0x1E2C, - 0x00690330: 0x1E2D, - 0x00CF0301: 0x1E2E, - 0x00EF0301: 0x1E2F, - 0x004B0301: 0x1E30, - 0x006B0301: 0x1E31, - 0x004B0323: 0x1E32, - 0x006B0323: 0x1E33, - 0x004B0331: 0x1E34, - 0x006B0331: 0x1E35, - 0x004C0323: 0x1E36, - 0x006C0323: 0x1E37, - 0x1E360304: 0x1E38, - 0x1E370304: 0x1E39, - 0x004C0331: 0x1E3A, - 0x006C0331: 0x1E3B, - 0x004C032D: 0x1E3C, - 0x006C032D: 0x1E3D, - 0x004D0301: 0x1E3E, - 0x006D0301: 0x1E3F, - 0x004D0307: 0x1E40, - 0x006D0307: 0x1E41, - 0x004D0323: 0x1E42, - 0x006D0323: 0x1E43, - 0x004E0307: 0x1E44, - 0x006E0307: 0x1E45, - 0x004E0323: 0x1E46, - 0x006E0323: 0x1E47, - 0x004E0331: 0x1E48, - 0x006E0331: 0x1E49, - 0x004E032D: 0x1E4A, - 0x006E032D: 0x1E4B, - 0x00D50301: 0x1E4C, - 0x00F50301: 0x1E4D, - 0x00D50308: 0x1E4E, - 0x00F50308: 0x1E4F, - 0x014C0300: 0x1E50, - 0x014D0300: 0x1E51, - 0x014C0301: 0x1E52, - 0x014D0301: 0x1E53, - 0x00500301: 0x1E54, - 0x00700301: 0x1E55, - 0x00500307: 0x1E56, - 0x00700307: 0x1E57, - 0x00520307: 0x1E58, - 0x00720307: 0x1E59, - 0x00520323: 0x1E5A, - 0x00720323: 0x1E5B, - 0x1E5A0304: 0x1E5C, - 0x1E5B0304: 0x1E5D, - 0x00520331: 0x1E5E, - 0x00720331: 0x1E5F, - 0x00530307: 0x1E60, - 0x00730307: 0x1E61, - 0x00530323: 0x1E62, - 0x00730323: 0x1E63, - 0x015A0307: 0x1E64, - 0x015B0307: 0x1E65, - 0x01600307: 0x1E66, - 0x01610307: 0x1E67, - 0x1E620307: 0x1E68, - 0x1E630307: 0x1E69, - 0x00540307: 0x1E6A, - 0x00740307: 0x1E6B, - 0x00540323: 0x1E6C, - 0x00740323: 0x1E6D, - 0x00540331: 0x1E6E, - 0x00740331: 0x1E6F, - 0x0054032D: 0x1E70, - 0x0074032D: 0x1E71, - 0x00550324: 0x1E72, - 0x00750324: 0x1E73, - 0x00550330: 0x1E74, - 0x00750330: 0x1E75, - 0x0055032D: 0x1E76, - 0x0075032D: 0x1E77, - 0x01680301: 0x1E78, - 0x01690301: 0x1E79, - 0x016A0308: 0x1E7A, - 0x016B0308: 0x1E7B, - 0x00560303: 0x1E7C, - 0x00760303: 0x1E7D, - 0x00560323: 0x1E7E, - 0x00760323: 0x1E7F, - 0x00570300: 0x1E80, - 0x00770300: 0x1E81, - 0x00570301: 0x1E82, - 0x00770301: 0x1E83, - 0x00570308: 0x1E84, - 0x00770308: 0x1E85, - 0x00570307: 0x1E86, - 0x00770307: 0x1E87, - 0x00570323: 0x1E88, - 0x00770323: 0x1E89, - 0x00580307: 0x1E8A, - 0x00780307: 0x1E8B, - 0x00580308: 0x1E8C, - 0x00780308: 0x1E8D, - 0x00590307: 0x1E8E, - 0x00790307: 0x1E8F, - 0x005A0302: 0x1E90, - 0x007A0302: 0x1E91, - 0x005A0323: 0x1E92, - 0x007A0323: 0x1E93, - 0x005A0331: 0x1E94, - 0x007A0331: 0x1E95, - 0x00680331: 0x1E96, - 0x00740308: 0x1E97, - 0x0077030A: 0x1E98, - 0x0079030A: 0x1E99, - 0x017F0307: 0x1E9B, - 0x00410323: 0x1EA0, - 0x00610323: 0x1EA1, - 0x00410309: 0x1EA2, - 0x00610309: 0x1EA3, - 0x00C20301: 0x1EA4, - 0x00E20301: 0x1EA5, - 0x00C20300: 0x1EA6, - 0x00E20300: 0x1EA7, - 0x00C20309: 0x1EA8, - 0x00E20309: 0x1EA9, - 0x00C20303: 0x1EAA, - 0x00E20303: 0x1EAB, - 0x1EA00302: 0x1EAC, - 0x1EA10302: 0x1EAD, - 0x01020301: 0x1EAE, - 0x01030301: 0x1EAF, - 0x01020300: 0x1EB0, - 0x01030300: 0x1EB1, - 0x01020309: 0x1EB2, - 0x01030309: 0x1EB3, - 0x01020303: 0x1EB4, - 0x01030303: 0x1EB5, - 0x1EA00306: 0x1EB6, - 0x1EA10306: 0x1EB7, - 0x00450323: 0x1EB8, - 0x00650323: 0x1EB9, - 0x00450309: 0x1EBA, - 0x00650309: 0x1EBB, - 0x00450303: 0x1EBC, - 0x00650303: 0x1EBD, - 0x00CA0301: 0x1EBE, - 0x00EA0301: 0x1EBF, - 0x00CA0300: 0x1EC0, - 0x00EA0300: 0x1EC1, - 0x00CA0309: 0x1EC2, - 0x00EA0309: 0x1EC3, - 0x00CA0303: 0x1EC4, - 0x00EA0303: 0x1EC5, - 0x1EB80302: 0x1EC6, - 0x1EB90302: 0x1EC7, - 0x00490309: 0x1EC8, - 0x00690309: 0x1EC9, - 0x00490323: 0x1ECA, - 0x00690323: 0x1ECB, - 0x004F0323: 0x1ECC, - 0x006F0323: 0x1ECD, - 0x004F0309: 0x1ECE, - 0x006F0309: 0x1ECF, - 0x00D40301: 0x1ED0, - 0x00F40301: 0x1ED1, - 0x00D40300: 0x1ED2, - 0x00F40300: 0x1ED3, - 0x00D40309: 0x1ED4, - 0x00F40309: 0x1ED5, - 0x00D40303: 0x1ED6, - 0x00F40303: 0x1ED7, - 0x1ECC0302: 0x1ED8, - 0x1ECD0302: 0x1ED9, - 0x01A00301: 0x1EDA, - 0x01A10301: 0x1EDB, - 0x01A00300: 0x1EDC, - 0x01A10300: 0x1EDD, - 0x01A00309: 0x1EDE, - 0x01A10309: 0x1EDF, - 0x01A00303: 0x1EE0, - 0x01A10303: 0x1EE1, - 0x01A00323: 0x1EE2, - 0x01A10323: 0x1EE3, - 0x00550323: 0x1EE4, - 0x00750323: 0x1EE5, - 0x00550309: 0x1EE6, - 0x00750309: 0x1EE7, - 0x01AF0301: 0x1EE8, - 0x01B00301: 0x1EE9, - 0x01AF0300: 0x1EEA, - 0x01B00300: 0x1EEB, - 0x01AF0309: 0x1EEC, - 0x01B00309: 0x1EED, - 0x01AF0303: 0x1EEE, - 0x01B00303: 0x1EEF, - 0x01AF0323: 0x1EF0, - 0x01B00323: 0x1EF1, - 0x00590300: 0x1EF2, - 0x00790300: 0x1EF3, - 0x00590323: 0x1EF4, - 0x00790323: 0x1EF5, - 0x00590309: 0x1EF6, - 0x00790309: 0x1EF7, - 0x00590303: 0x1EF8, - 0x00790303: 0x1EF9, - 0x03B10313: 0x1F00, - 0x03B10314: 0x1F01, - 0x1F000300: 0x1F02, - 0x1F010300: 0x1F03, - 0x1F000301: 0x1F04, - 0x1F010301: 0x1F05, - 0x1F000342: 0x1F06, - 0x1F010342: 0x1F07, - 0x03910313: 0x1F08, - 0x03910314: 0x1F09, - 0x1F080300: 0x1F0A, - 0x1F090300: 0x1F0B, - 0x1F080301: 0x1F0C, - 0x1F090301: 0x1F0D, - 0x1F080342: 0x1F0E, - 0x1F090342: 0x1F0F, - 0x03B50313: 0x1F10, - 0x03B50314: 0x1F11, - 0x1F100300: 0x1F12, - 0x1F110300: 0x1F13, - 0x1F100301: 0x1F14, - 0x1F110301: 0x1F15, - 0x03950313: 0x1F18, - 0x03950314: 0x1F19, - 0x1F180300: 0x1F1A, - 0x1F190300: 0x1F1B, - 0x1F180301: 0x1F1C, - 0x1F190301: 0x1F1D, - 0x03B70313: 0x1F20, - 0x03B70314: 0x1F21, - 0x1F200300: 0x1F22, - 0x1F210300: 0x1F23, - 0x1F200301: 0x1F24, - 0x1F210301: 0x1F25, - 0x1F200342: 0x1F26, - 0x1F210342: 0x1F27, - 0x03970313: 0x1F28, - 0x03970314: 0x1F29, - 0x1F280300: 0x1F2A, - 0x1F290300: 0x1F2B, - 0x1F280301: 0x1F2C, - 0x1F290301: 0x1F2D, - 0x1F280342: 0x1F2E, - 0x1F290342: 0x1F2F, - 0x03B90313: 0x1F30, - 0x03B90314: 0x1F31, - 0x1F300300: 0x1F32, - 0x1F310300: 0x1F33, - 0x1F300301: 0x1F34, - 0x1F310301: 0x1F35, - 0x1F300342: 0x1F36, - 0x1F310342: 0x1F37, - 0x03990313: 0x1F38, - 0x03990314: 0x1F39, - 0x1F380300: 0x1F3A, - 0x1F390300: 0x1F3B, - 0x1F380301: 0x1F3C, - 0x1F390301: 0x1F3D, - 0x1F380342: 0x1F3E, - 0x1F390342: 0x1F3F, - 0x03BF0313: 0x1F40, - 0x03BF0314: 0x1F41, - 0x1F400300: 0x1F42, - 0x1F410300: 0x1F43, - 0x1F400301: 0x1F44, - 0x1F410301: 0x1F45, - 0x039F0313: 0x1F48, - 0x039F0314: 0x1F49, - 0x1F480300: 0x1F4A, - 0x1F490300: 0x1F4B, - 0x1F480301: 0x1F4C, - 0x1F490301: 0x1F4D, - 0x03C50313: 0x1F50, - 0x03C50314: 0x1F51, - 0x1F500300: 0x1F52, - 0x1F510300: 0x1F53, - 0x1F500301: 0x1F54, - 0x1F510301: 0x1F55, - 0x1F500342: 0x1F56, - 0x1F510342: 0x1F57, - 0x03A50314: 0x1F59, - 0x1F590300: 0x1F5B, - 0x1F590301: 0x1F5D, - 0x1F590342: 0x1F5F, - 0x03C90313: 0x1F60, - 0x03C90314: 0x1F61, - 0x1F600300: 0x1F62, - 0x1F610300: 0x1F63, - 0x1F600301: 0x1F64, - 0x1F610301: 0x1F65, - 0x1F600342: 0x1F66, - 0x1F610342: 0x1F67, - 0x03A90313: 0x1F68, - 0x03A90314: 0x1F69, - 0x1F680300: 0x1F6A, - 0x1F690300: 0x1F6B, - 0x1F680301: 0x1F6C, - 0x1F690301: 0x1F6D, - 0x1F680342: 0x1F6E, - 0x1F690342: 0x1F6F, - 0x03B10300: 0x1F70, - 0x03B50300: 0x1F72, - 0x03B70300: 0x1F74, - 0x03B90300: 0x1F76, - 0x03BF0300: 0x1F78, - 0x03C50300: 0x1F7A, - 0x03C90300: 0x1F7C, - 0x1F000345: 0x1F80, - 0x1F010345: 0x1F81, - 0x1F020345: 0x1F82, - 0x1F030345: 0x1F83, - 0x1F040345: 0x1F84, - 0x1F050345: 0x1F85, - 0x1F060345: 0x1F86, - 0x1F070345: 0x1F87, - 0x1F080345: 0x1F88, - 0x1F090345: 0x1F89, - 0x1F0A0345: 0x1F8A, - 0x1F0B0345: 0x1F8B, - 0x1F0C0345: 0x1F8C, - 0x1F0D0345: 0x1F8D, - 0x1F0E0345: 0x1F8E, - 0x1F0F0345: 0x1F8F, - 0x1F200345: 0x1F90, - 0x1F210345: 0x1F91, - 0x1F220345: 0x1F92, - 0x1F230345: 0x1F93, - 0x1F240345: 0x1F94, - 0x1F250345: 0x1F95, - 0x1F260345: 0x1F96, - 0x1F270345: 0x1F97, - 0x1F280345: 0x1F98, - 0x1F290345: 0x1F99, - 0x1F2A0345: 0x1F9A, - 0x1F2B0345: 0x1F9B, - 0x1F2C0345: 0x1F9C, - 0x1F2D0345: 0x1F9D, - 0x1F2E0345: 0x1F9E, - 0x1F2F0345: 0x1F9F, - 0x1F600345: 0x1FA0, - 0x1F610345: 0x1FA1, - 0x1F620345: 0x1FA2, - 0x1F630345: 0x1FA3, - 0x1F640345: 0x1FA4, - 0x1F650345: 0x1FA5, - 0x1F660345: 0x1FA6, - 0x1F670345: 0x1FA7, - 0x1F680345: 0x1FA8, - 0x1F690345: 0x1FA9, - 0x1F6A0345: 0x1FAA, - 0x1F6B0345: 0x1FAB, - 0x1F6C0345: 0x1FAC, - 0x1F6D0345: 0x1FAD, - 0x1F6E0345: 0x1FAE, - 0x1F6F0345: 0x1FAF, - 0x03B10306: 0x1FB0, - 0x03B10304: 0x1FB1, - 0x1F700345: 0x1FB2, - 0x03B10345: 0x1FB3, - 0x03AC0345: 0x1FB4, - 0x03B10342: 0x1FB6, - 0x1FB60345: 0x1FB7, - 0x03910306: 0x1FB8, - 0x03910304: 0x1FB9, - 0x03910300: 0x1FBA, - 0x03910345: 0x1FBC, - 0x00A80342: 0x1FC1, - 0x1F740345: 0x1FC2, - 0x03B70345: 0x1FC3, - 0x03AE0345: 0x1FC4, - 0x03B70342: 0x1FC6, - 0x1FC60345: 0x1FC7, - 0x03950300: 0x1FC8, - 0x03970300: 0x1FCA, - 0x03970345: 0x1FCC, - 0x1FBF0300: 0x1FCD, - 0x1FBF0301: 0x1FCE, - 0x1FBF0342: 0x1FCF, - 0x03B90306: 0x1FD0, - 0x03B90304: 0x1FD1, - 0x03CA0300: 0x1FD2, - 0x03B90342: 0x1FD6, - 0x03CA0342: 0x1FD7, - 0x03990306: 0x1FD8, - 0x03990304: 0x1FD9, - 0x03990300: 0x1FDA, - 0x1FFE0300: 0x1FDD, - 0x1FFE0301: 0x1FDE, - 0x1FFE0342: 0x1FDF, - 0x03C50306: 0x1FE0, - 0x03C50304: 0x1FE1, - 0x03CB0300: 0x1FE2, - 0x03C10313: 0x1FE4, - 0x03C10314: 0x1FE5, - 0x03C50342: 0x1FE6, - 0x03CB0342: 0x1FE7, - 0x03A50306: 0x1FE8, - 0x03A50304: 0x1FE9, - 0x03A50300: 0x1FEA, - 0x03A10314: 0x1FEC, - 0x00A80300: 0x1FED, - 0x1F7C0345: 0x1FF2, - 0x03C90345: 0x1FF3, - 0x03CE0345: 0x1FF4, - 0x03C90342: 0x1FF6, - 0x1FF60345: 0x1FF7, - 0x039F0300: 0x1FF8, - 0x03A90300: 0x1FFA, - 0x03A90345: 0x1FFC, - 0x21900338: 0x219A, - 0x21920338: 0x219B, - 0x21940338: 0x21AE, - 0x21D00338: 0x21CD, - 0x21D40338: 0x21CE, - 0x21D20338: 0x21CF, - 0x22030338: 0x2204, - 0x22080338: 0x2209, - 0x220B0338: 0x220C, - 0x22230338: 0x2224, - 0x22250338: 0x2226, - 0x223C0338: 0x2241, - 0x22430338: 0x2244, - 0x22450338: 0x2247, - 0x22480338: 0x2249, - 0x003D0338: 0x2260, - 0x22610338: 0x2262, - 0x224D0338: 0x226D, - 0x003C0338: 0x226E, - 0x003E0338: 0x226F, - 0x22640338: 0x2270, - 0x22650338: 0x2271, - 0x22720338: 0x2274, - 0x22730338: 0x2275, - 0x22760338: 0x2278, - 0x22770338: 0x2279, - 0x227A0338: 0x2280, - 0x227B0338: 0x2281, - 0x22820338: 0x2284, - 0x22830338: 0x2285, - 0x22860338: 0x2288, - 0x22870338: 0x2289, - 0x22A20338: 0x22AC, - 0x22A80338: 0x22AD, - 0x22A90338: 0x22AE, - 0x22AB0338: 0x22AF, - 0x227C0338: 0x22E0, - 0x227D0338: 0x22E1, - 0x22910338: 0x22E2, - 0x22920338: 0x22E3, - 0x22B20338: 0x22EA, - 0x22B30338: 0x22EB, - 0x22B40338: 0x22EC, - 0x22B50338: 0x22ED, - 0x304B3099: 0x304C, - 0x304D3099: 0x304E, - 0x304F3099: 0x3050, - 0x30513099: 0x3052, - 0x30533099: 0x3054, - 0x30553099: 0x3056, - 0x30573099: 0x3058, - 0x30593099: 0x305A, - 0x305B3099: 0x305C, - 0x305D3099: 0x305E, - 0x305F3099: 0x3060, - 0x30613099: 0x3062, - 0x30643099: 0x3065, - 0x30663099: 0x3067, - 0x30683099: 0x3069, - 0x306F3099: 0x3070, - 0x306F309A: 0x3071, - 0x30723099: 0x3073, - 0x3072309A: 0x3074, - 0x30753099: 0x3076, - 0x3075309A: 0x3077, - 0x30783099: 0x3079, - 0x3078309A: 0x307A, - 0x307B3099: 0x307C, - 0x307B309A: 0x307D, - 0x30463099: 0x3094, - 0x309D3099: 0x309E, - 0x30AB3099: 0x30AC, - 0x30AD3099: 0x30AE, - 0x30AF3099: 0x30B0, - 0x30B13099: 0x30B2, - 0x30B33099: 0x30B4, - 0x30B53099: 0x30B6, - 0x30B73099: 0x30B8, - 0x30B93099: 0x30BA, - 0x30BB3099: 0x30BC, - 0x30BD3099: 0x30BE, - 0x30BF3099: 0x30C0, - 0x30C13099: 0x30C2, - 0x30C43099: 0x30C5, - 0x30C63099: 0x30C7, - 0x30C83099: 0x30C9, - 0x30CF3099: 0x30D0, - 0x30CF309A: 0x30D1, - 0x30D23099: 0x30D3, - 0x30D2309A: 0x30D4, - 0x30D53099: 0x30D6, - 0x30D5309A: 0x30D7, - 0x30D83099: 0x30D9, - 0x30D8309A: 0x30DA, - 0x30DB3099: 0x30DC, - 0x30DB309A: 0x30DD, - 0x30A63099: 0x30F4, - 0x30EF3099: 0x30F7, - 0x30F03099: 0x30F8, - 0x30F13099: 0x30F9, - 0x30F23099: 0x30FA, - 0x30FD3099: 0x30FE, - 0x109910BA: 0x1109A, - 0x109B10BA: 0x1109C, - 0x10A510BA: 0x110AB, - 0x11311127: 0x1112E, - 0x11321127: 0x1112F, - 0x1347133E: 0x1134B, - 0x13471357: 0x1134C, - 0x14B914BA: 0x114BB, - 0x14B914B0: 0x114BC, - 0x14B914BD: 0x114BE, - 0x15B815AF: 0x115BA, - 0x15B915AF: 0x115BB, -} - -// Total size of tables: 53KB (53976 bytes) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/transform.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/transform.go deleted file mode 100644 index 8589067..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/transform.go +++ /dev/null @@ -1,88 +0,0 @@ -// Copyright 2013 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -import ( - "unicode/utf8" - - "golang.org/x/text/transform" -) - -// Reset implements the Reset method of the transform.Transformer interface. -func (Form) Reset() {} - -// Transform implements the Transform method of the transform.Transformer -// interface. It may need to write segments of up to MaxSegmentSize at once. -// Users should either catch ErrShortDst and allow dst to grow or have dst be at -// least of size MaxTransformChunkSize to be guaranteed of progress. -func (f Form) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - n := 0 - // Cap the maximum number of src bytes to check. - b := src - eof := atEOF - if ns := len(dst); ns < len(b) { - err = transform.ErrShortDst - eof = false - b = b[:ns] - } - i, ok := formTable[f].quickSpan(inputBytes(b), n, len(b), eof) - n += copy(dst[n:], b[n:i]) - if !ok { - nDst, nSrc, err = f.transform(dst[n:], src[n:], atEOF) - return nDst + n, nSrc + n, err - } - if n < len(src) && !atEOF { - err = transform.ErrShortSrc - } - return n, n, err -} - -func flushTransform(rb *reorderBuffer) bool { - // Write out (must fully fit in dst, or else it is a ErrShortDst). - if len(rb.out) < rb.nrune*utf8.UTFMax { - return false - } - rb.out = rb.out[rb.flushCopy(rb.out):] - return true -} - -var errs = []error{nil, transform.ErrShortDst, transform.ErrShortSrc} - -// transform implements the transform.Transformer interface. It is only called -// when quickSpan does not pass for a given string. -func (f Form) transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - // TODO: get rid of reorderBuffer. See CL 23460044. - rb := reorderBuffer{} - rb.init(f, src) - for { - // Load segment into reorder buffer. - rb.setFlusher(dst[nDst:], flushTransform) - end := decomposeSegment(&rb, nSrc, atEOF) - if end < 0 { - return nDst, nSrc, errs[-end] - } - nDst = len(dst) - len(rb.out) - nSrc = end - - // Next quickSpan. - end = rb.nsrc - eof := atEOF - if n := nSrc + len(dst) - nDst; n < end { - err = transform.ErrShortDst - end = n - eof = false - } - end, ok := rb.f.quickSpan(rb.src, nSrc, end, eof) - n := copy(dst[nDst:], rb.src.bytes[nSrc:end]) - nSrc += n - nDst += n - if ok { - if n < rb.nsrc && !atEOF { - err = transform.ErrShortSrc - } - return nDst, nSrc, err - } - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/trie.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/trie.go deleted file mode 100644 index 423386b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/trie.go +++ /dev/null @@ -1,54 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package norm - -type valueRange struct { - value uint16 // header: value:stride - lo, hi byte // header: lo:n -} - -type sparseBlocks struct { - values []valueRange - offset []uint16 -} - -var nfcSparse = sparseBlocks{ - values: nfcSparseValues[:], - offset: nfcSparseOffset[:], -} - -var nfkcSparse = sparseBlocks{ - values: nfkcSparseValues[:], - offset: nfkcSparseOffset[:], -} - -var ( - nfcData = newNfcTrie(0) - nfkcData = newNfkcTrie(0) -) - -// lookupValue determines the type of block n and looks up the value for b. -// For n < t.cutoff, the block is a simple lookup table. Otherwise, the block -// is a list of ranges with an accompanying value. Given a matching range r, -// the value for b is by r.value + (b - r.lo) * stride. -func (t *sparseBlocks) lookup(n uint32, b byte) uint16 { - offset := t.offset[n] - header := t.values[offset] - lo := offset + 1 - hi := lo + uint16(header.lo) - for lo < hi { - m := lo + (hi-lo)/2 - r := t.values[m] - if r.lo <= b && b <= r.hi { - return r.value + uint16(b-r.lo)*header.value - } - if b < r.lo { - hi = m - } else { - lo = m + 1 - } - } - return 0 -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/triegen.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/triegen.go deleted file mode 100644 index 45d7119..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/unicode/norm/triegen.go +++ /dev/null @@ -1,117 +0,0 @@ -// Copyright 2011 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -// Trie table generator. -// Used by make*tables tools to generate a go file with trie data structures -// for mapping UTF-8 to a 16-bit value. All but the last byte in a UTF-8 byte -// sequence are used to lookup offsets in the index table to be used for the -// next byte. The last byte is used to index into a table with 16-bit values. - -package main - -import ( - "fmt" - "io" -) - -const maxSparseEntries = 16 - -type normCompacter struct { - sparseBlocks [][]uint64 - sparseOffset []uint16 - sparseCount int - name string -} - -func mostFrequentStride(a []uint64) int { - counts := make(map[int]int) - var v int - for _, x := range a { - if stride := int(x) - v; v != 0 && stride >= 0 { - counts[stride]++ - } - v = int(x) - } - var maxs, maxc int - for stride, cnt := range counts { - if cnt > maxc || (cnt == maxc && stride < maxs) { - maxs, maxc = stride, cnt - } - } - return maxs -} - -func countSparseEntries(a []uint64) int { - stride := mostFrequentStride(a) - var v, count int - for _, tv := range a { - if int(tv)-v != stride { - if tv != 0 { - count++ - } - } - v = int(tv) - } - return count -} - -func (c *normCompacter) Size(v []uint64) (sz int, ok bool) { - if n := countSparseEntries(v); n <= maxSparseEntries { - return (n+1)*4 + 2, true - } - return 0, false -} - -func (c *normCompacter) Store(v []uint64) uint32 { - h := uint32(len(c.sparseOffset)) - c.sparseBlocks = append(c.sparseBlocks, v) - c.sparseOffset = append(c.sparseOffset, uint16(c.sparseCount)) - c.sparseCount += countSparseEntries(v) + 1 - return h -} - -func (c *normCompacter) Handler() string { - return c.name + "Sparse.lookup" -} - -func (c *normCompacter) Print(w io.Writer) (retErr error) { - p := func(f string, x ...interface{}) { - if _, err := fmt.Fprintf(w, f, x...); retErr == nil && err != nil { - retErr = err - } - } - - ls := len(c.sparseBlocks) - p("// %sSparseOffset: %d entries, %d bytes\n", c.name, ls, ls*2) - p("var %sSparseOffset = %#v\n\n", c.name, c.sparseOffset) - - ns := c.sparseCount - p("// %sSparseValues: %d entries, %d bytes\n", c.name, ns, ns*4) - p("var %sSparseValues = [%d]valueRange {", c.name, ns) - for i, b := range c.sparseBlocks { - p("\n// Block %#x, offset %#x", i, c.sparseOffset[i]) - var v int - stride := mostFrequentStride(b) - n := countSparseEntries(b) - p("\n{value:%#04x,lo:%#02x},", stride, uint8(n)) - for i, nv := range b { - if int(nv)-v != stride { - if v != 0 { - p(",hi:%#02x},", 0x80+i-1) - } - if nv != 0 { - p("\n{value:%#04x,lo:%#02x", nv, 0x80+i) - } - } - v = int(nv) - } - if v != 0 { - p(",hi:%#02x},", 0x80+len(b)-1) - } - } - p("\n}\n\n") - return -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen.go deleted file mode 100644 index 03d9f99..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen.go +++ /dev/null @@ -1,115 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -// This program generates the trie for width operations. The generated table -// includes width category information as well as the normalization mappings. -package main - -import ( - "bytes" - "fmt" - "io" - "log" - "math" - "unicode/utf8" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/triegen" -) - -// See gen_common.go for flags. - -func main() { - gen.Init() - genTables() - genTests() - gen.Repackage("gen_trieval.go", "trieval.go", "width") - gen.Repackage("gen_common.go", "common_test.go", "width") -} - -func genTables() { - t := triegen.NewTrie("width") - // fold and inverse mappings. See mapComment for a description of the format - // of each entry. Add dummy value to make an index of 0 mean no mapping. - inverse := [][4]byte{{}} - mapping := map[[4]byte]int{[4]byte{}: 0} - - getWidthData(func(r rune, tag elem, alt rune) { - idx := 0 - if alt != 0 { - var buf [4]byte - buf[0] = byte(utf8.EncodeRune(buf[1:], alt)) - s := string(r) - buf[buf[0]] ^= s[len(s)-1] - var ok bool - if idx, ok = mapping[buf]; !ok { - idx = len(mapping) - if idx > math.MaxUint8 { - log.Fatalf("Index %d does not fit in a byte.", idx) - } - mapping[buf] = idx - inverse = append(inverse, buf) - } - } - t.Insert(r, uint64(tag|elem(idx))) - }) - - w := &bytes.Buffer{} - gen.WriteUnicodeVersion(w) - - sz, err := t.Gen(w) - if err != nil { - log.Fatal(err) - } - - sz += writeMappings(w, inverse) - - fmt.Fprintf(w, "// Total table size %d bytes (%dKiB)\n", sz, sz/1024) - - gen.WriteGoFile(*outputFile, "width", w.Bytes()) -} - -const inverseDataComment = ` -// inverseData contains 4-byte entries of the following format: -// <length> <modified UTF-8-encoded rune> <0 padding> -// The last byte of the UTF-8-encoded rune is xor-ed with the last byte of the -// UTF-8 encoding of the original rune. Mappings often have the following -// pattern: -// A -> A (U+FF21 -> U+0041) -// B -> B (U+FF22 -> U+0042) -// ... -// By xor-ing the last byte the same entry can be shared by many mappings. This -// reduces the total number of distinct entries by about two thirds. -// The resulting entry for the aforementioned mappings is -// { 0x01, 0xE0, 0x00, 0x00 } -// Using this entry to map U+FF21 (UTF-8 [EF BC A1]), we get -// E0 ^ A1 = 41. -// Similarly, for U+FF22 (UTF-8 [EF BC A2]), we get -// E0 ^ A2 = 42. -// Note that because of the xor-ing, the byte sequence stored in the entry is -// not valid UTF-8.` - -func writeMappings(w io.Writer, data [][4]byte) int { - fmt.Fprintln(w, inverseDataComment) - fmt.Fprintf(w, "var inverseData = [%d][4]byte{\n", len(data)) - for _, x := range data { - fmt.Fprintf(w, "{ 0x%02x, 0x%02x, 0x%02x, 0x%02x },\n", x[0], x[1], x[2], x[3]) - } - fmt.Fprintln(w, "}") - return len(data) * 4 -} - -func genTests() { - w := &bytes.Buffer{} - fmt.Fprintf(w, "\nvar mapRunes = map[rune]struct{r rune; e elem}{\n") - getWidthData(func(r rune, tag elem, alt rune) { - if alt != 0 { - fmt.Fprintf(w, "\t0x%X: {0x%X, 0x%X},\n", r, alt, tag) - } - }) - fmt.Fprintln(w, "}") - gen.WriteGoFile("runes_test.go", "width", w.Bytes()) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_common.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_common.go deleted file mode 100644 index 601e752..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_common.go +++ /dev/null @@ -1,96 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// This code is shared between the main code generator and the test code. - -import ( - "flag" - "log" - "strconv" - "strings" - - "golang.org/x/text/internal/gen" - "golang.org/x/text/internal/ucd" -) - -var ( - outputFile = flag.String("out", "tables.go", "output file") -) - -var typeMap = map[string]elem{ - "A": tagAmbiguous, - "N": tagNeutral, - "Na": tagNarrow, - "W": tagWide, - "F": tagFullwidth, - "H": tagHalfwidth, -} - -// getWidthData calls f for every entry for which it is defined. -// -// f may be called multiple times for the same rune. The last call to f is the -// correct value. f is not called for all runes. The default tag type is -// Neutral. -func getWidthData(f func(r rune, tag elem, alt rune)) { - // Set the default values for Unified Ideographs. In line with Annex 11, - // we encode full ranges instead of the defined runes in Unified_Ideograph. - for _, b := range []struct{ lo, hi rune }{ - {0x4E00, 0x9FFF}, // the CJK Unified Ideographs block, - {0x3400, 0x4DBF}, // the CJK Unified Ideographs Externsion A block, - {0xF900, 0xFAFF}, // the CJK Compatibility Ideographs block, - {0x20000, 0x2FFFF}, // the Supplementary Ideographic Plane, - {0x30000, 0x3FFFF}, // the Tertiary Ideographic Plane, - } { - for r := b.lo; r <= b.hi; r++ { - f(r, tagWide, 0) - } - } - - inverse := map[rune]rune{} - maps := map[string]bool{ - "<wide>": true, - "<narrow>": true, - } - - // We cannot reuse package norm's decomposition, as we need an unexpanded - // decomposition. We make use of the opportunity to verify that the - // decomposition type is as expected. - ucd.Parse(gen.OpenUCDFile("UnicodeData.txt"), func(p *ucd.Parser) { - r := p.Rune(0) - s := strings.SplitN(p.String(ucd.DecompMapping), " ", 2) - if !maps[s[0]] { - return - } - x, err := strconv.ParseUint(s[1], 16, 32) - if err != nil { - log.Fatalf("Error parsing rune %q", s[1]) - } - if inverse[r] != 0 || inverse[rune(x)] != 0 { - log.Fatalf("Circular dependency in mapping between %U and %U", r, x) - } - inverse[r] = rune(x) - inverse[rune(x)] = r - }) - - // <rune range>;<type> - ucd.Parse(gen.OpenUCDFile("EastAsianWidth.txt"), func(p *ucd.Parser) { - tag, ok := typeMap[p.String(1)] - if !ok { - log.Fatalf("Unknown width type %q", p.String(1)) - } - r := p.Rune(0) - alt, ok := inverse[r] - if tag == tagFullwidth || tag == tagHalfwidth && r != wonSign { - tag |= tagNeedsFold - if !ok { - log.Fatalf("Narrow or wide rune %U has no decomposition", r) - } - } - f(r, tag, alt) - }) -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_trieval.go deleted file mode 100644 index c17334a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/gen_trieval.go +++ /dev/null @@ -1,34 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -// +build ignore - -package main - -// elem is an entry of the width trie. The high byte is used to encode the type -// of the rune. The low byte is used to store the index to a mapping entry in -// the inverseData array. -type elem uint16 - -const ( - tagNeutral elem = iota << typeShift - tagAmbiguous - tagWide - tagNarrow - tagFullwidth - tagHalfwidth -) - -const ( - numTypeBits = 3 - typeShift = 16 - numTypeBits - - // tagNeedsFold is true for all fullwidth and halfwidth runes except for - // the Won sign U+20A9. - tagNeedsFold = 0x1000 - - // The Korean Won sign is halfwidth, but SHOULD NOT be mapped to a wide - // variant. - wonSign rune = 0x20A9 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/kind_string.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/kind_string.go deleted file mode 100644 index ab4fee5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/kind_string.go +++ /dev/null @@ -1,16 +0,0 @@ -// Code generated by "stringer -type=Kind"; DO NOT EDIT - -package width - -import "fmt" - -const _Kind_name = "NeutralEastAsianAmbiguousEastAsianWideEastAsianNarrowEastAsianFullwidthEastAsianHalfwidth" - -var _Kind_index = [...]uint8{0, 7, 25, 38, 53, 71, 89} - -func (i Kind) String() string { - if i < 0 || i >= Kind(len(_Kind_index)-1) { - return fmt.Sprintf("Kind(%d)", i) - } - return _Kind_name[_Kind_index[i]:_Kind_index[i+1]] -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/tables.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/tables.go deleted file mode 100644 index 242da0f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/tables.go +++ /dev/null @@ -1,1284 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package width - -// UnicodeVersion is the Unicode version from which the tables in this package are derived. -const UnicodeVersion = "9.0.0" - -// lookup returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *widthTrie) lookup(s []byte) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return widthValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = widthIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = widthIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = widthIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *widthTrie) lookupUnsafe(s []byte) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return widthValues[c0] - } - i := widthIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = widthIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = widthIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// lookupString returns the trie value for the first UTF-8 encoding in s and -// the width in bytes of this encoding. The size will be 0 if s does not -// hold enough bytes to complete the encoding. len(s) must be greater than 0. -func (t *widthTrie) lookupString(s string) (v uint16, sz int) { - c0 := s[0] - switch { - case c0 < 0x80: // is ASCII - return widthValues[c0], 1 - case c0 < 0xC2: - return 0, 1 // Illegal UTF-8: not a starter, not ASCII. - case c0 < 0xE0: // 2-byte UTF-8 - if len(s) < 2 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c1), 2 - case c0 < 0xF0: // 3-byte UTF-8 - if len(s) < 3 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = widthIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c2), 3 - case c0 < 0xF8: // 4-byte UTF-8 - if len(s) < 4 { - return 0, 0 - } - i := widthIndex[c0] - c1 := s[1] - if c1 < 0x80 || 0xC0 <= c1 { - return 0, 1 // Illegal UTF-8: not a continuation byte. - } - o := uint32(i)<<6 + uint32(c1) - i = widthIndex[o] - c2 := s[2] - if c2 < 0x80 || 0xC0 <= c2 { - return 0, 2 // Illegal UTF-8: not a continuation byte. - } - o = uint32(i)<<6 + uint32(c2) - i = widthIndex[o] - c3 := s[3] - if c3 < 0x80 || 0xC0 <= c3 { - return 0, 3 // Illegal UTF-8: not a continuation byte. - } - return t.lookupValue(uint32(i), c3), 4 - } - // Illegal rune - return 0, 1 -} - -// lookupStringUnsafe returns the trie value for the first UTF-8 encoding in s. -// s must start with a full and valid UTF-8 encoded rune. -func (t *widthTrie) lookupStringUnsafe(s string) uint16 { - c0 := s[0] - if c0 < 0x80 { // is ASCII - return widthValues[c0] - } - i := widthIndex[c0] - if c0 < 0xE0 { // 2-byte UTF-8 - return t.lookupValue(uint32(i), s[1]) - } - i = widthIndex[uint32(i)<<6+uint32(s[1])] - if c0 < 0xF0 { // 3-byte UTF-8 - return t.lookupValue(uint32(i), s[2]) - } - i = widthIndex[uint32(i)<<6+uint32(s[2])] - if c0 < 0xF8 { // 4-byte UTF-8 - return t.lookupValue(uint32(i), s[3]) - } - return 0 -} - -// widthTrie. Total size: 14080 bytes (13.75 KiB). Checksum: 3b8aeb3dc03667a3. -type widthTrie struct{} - -func newWidthTrie(i int) *widthTrie { - return &widthTrie{} -} - -// lookupValue determines the type of block n and looks up the value for b. -func (t *widthTrie) lookupValue(n uint32, b byte) uint16 { - switch { - default: - return uint16(widthValues[n<<6+uint32(b)]) - } -} - -// widthValues: 99 blocks, 6336 entries, 12672 bytes -// The third block is the zero block. -var widthValues = [6336]uint16{ - // Block 0x0, offset 0x0 - 0x20: 0x6001, 0x21: 0x6002, 0x22: 0x6002, 0x23: 0x6002, - 0x24: 0x6002, 0x25: 0x6002, 0x26: 0x6002, 0x27: 0x6002, 0x28: 0x6002, 0x29: 0x6002, - 0x2a: 0x6002, 0x2b: 0x6002, 0x2c: 0x6002, 0x2d: 0x6002, 0x2e: 0x6002, 0x2f: 0x6002, - 0x30: 0x6002, 0x31: 0x6002, 0x32: 0x6002, 0x33: 0x6002, 0x34: 0x6002, 0x35: 0x6002, - 0x36: 0x6002, 0x37: 0x6002, 0x38: 0x6002, 0x39: 0x6002, 0x3a: 0x6002, 0x3b: 0x6002, - 0x3c: 0x6002, 0x3d: 0x6002, 0x3e: 0x6002, 0x3f: 0x6002, - // Block 0x1, offset 0x40 - 0x40: 0x6003, 0x41: 0x6003, 0x42: 0x6003, 0x43: 0x6003, 0x44: 0x6003, 0x45: 0x6003, - 0x46: 0x6003, 0x47: 0x6003, 0x48: 0x6003, 0x49: 0x6003, 0x4a: 0x6003, 0x4b: 0x6003, - 0x4c: 0x6003, 0x4d: 0x6003, 0x4e: 0x6003, 0x4f: 0x6003, 0x50: 0x6003, 0x51: 0x6003, - 0x52: 0x6003, 0x53: 0x6003, 0x54: 0x6003, 0x55: 0x6003, 0x56: 0x6003, 0x57: 0x6003, - 0x58: 0x6003, 0x59: 0x6003, 0x5a: 0x6003, 0x5b: 0x6003, 0x5c: 0x6003, 0x5d: 0x6003, - 0x5e: 0x6003, 0x5f: 0x6003, 0x60: 0x6004, 0x61: 0x6004, 0x62: 0x6004, 0x63: 0x6004, - 0x64: 0x6004, 0x65: 0x6004, 0x66: 0x6004, 0x67: 0x6004, 0x68: 0x6004, 0x69: 0x6004, - 0x6a: 0x6004, 0x6b: 0x6004, 0x6c: 0x6004, 0x6d: 0x6004, 0x6e: 0x6004, 0x6f: 0x6004, - 0x70: 0x6004, 0x71: 0x6004, 0x72: 0x6004, 0x73: 0x6004, 0x74: 0x6004, 0x75: 0x6004, - 0x76: 0x6004, 0x77: 0x6004, 0x78: 0x6004, 0x79: 0x6004, 0x7a: 0x6004, 0x7b: 0x6004, - 0x7c: 0x6004, 0x7d: 0x6004, 0x7e: 0x6004, - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xe1: 0x2000, 0xe2: 0x6005, 0xe3: 0x6005, - 0xe4: 0x2000, 0xe5: 0x6006, 0xe6: 0x6005, 0xe7: 0x2000, 0xe8: 0x2000, - 0xea: 0x2000, 0xec: 0x6007, 0xed: 0x2000, 0xee: 0x2000, 0xef: 0x6008, - 0xf0: 0x2000, 0xf1: 0x2000, 0xf2: 0x2000, 0xf3: 0x2000, 0xf4: 0x2000, - 0xf6: 0x2000, 0xf7: 0x2000, 0xf8: 0x2000, 0xf9: 0x2000, 0xfa: 0x2000, - 0xfc: 0x2000, 0xfd: 0x2000, 0xfe: 0x2000, 0xff: 0x2000, - // Block 0x4, offset 0x100 - 0x106: 0x2000, - 0x110: 0x2000, - 0x117: 0x2000, - 0x118: 0x2000, - 0x11e: 0x2000, 0x11f: 0x2000, 0x120: 0x2000, 0x121: 0x2000, - 0x126: 0x2000, 0x128: 0x2000, 0x129: 0x2000, - 0x12a: 0x2000, 0x12c: 0x2000, 0x12d: 0x2000, - 0x130: 0x2000, 0x132: 0x2000, 0x133: 0x2000, - 0x137: 0x2000, 0x138: 0x2000, 0x139: 0x2000, 0x13a: 0x2000, - 0x13c: 0x2000, 0x13e: 0x2000, - // Block 0x5, offset 0x140 - 0x141: 0x2000, - 0x151: 0x2000, - 0x153: 0x2000, - 0x15b: 0x2000, - 0x166: 0x2000, 0x167: 0x2000, - 0x16b: 0x2000, - 0x171: 0x2000, 0x172: 0x2000, 0x173: 0x2000, - 0x178: 0x2000, - 0x17f: 0x2000, - // Block 0x6, offset 0x180 - 0x180: 0x2000, 0x181: 0x2000, 0x182: 0x2000, 0x184: 0x2000, - 0x188: 0x2000, 0x189: 0x2000, 0x18a: 0x2000, 0x18b: 0x2000, - 0x18d: 0x2000, - 0x192: 0x2000, 0x193: 0x2000, - 0x1a6: 0x2000, 0x1a7: 0x2000, - 0x1ab: 0x2000, - // Block 0x7, offset 0x1c0 - 0x1ce: 0x2000, 0x1d0: 0x2000, - 0x1d2: 0x2000, 0x1d4: 0x2000, 0x1d6: 0x2000, - 0x1d8: 0x2000, 0x1da: 0x2000, 0x1dc: 0x2000, - // Block 0x8, offset 0x200 - 0x211: 0x2000, - 0x221: 0x2000, - // Block 0x9, offset 0x240 - 0x244: 0x2000, - 0x247: 0x2000, 0x249: 0x2000, 0x24a: 0x2000, 0x24b: 0x2000, - 0x24d: 0x2000, 0x250: 0x2000, - 0x258: 0x2000, 0x259: 0x2000, 0x25a: 0x2000, 0x25b: 0x2000, 0x25d: 0x2000, - 0x25f: 0x2000, - // Block 0xa, offset 0x280 - 0x280: 0x2000, 0x281: 0x2000, 0x282: 0x2000, 0x283: 0x2000, 0x284: 0x2000, 0x285: 0x2000, - 0x286: 0x2000, 0x287: 0x2000, 0x288: 0x2000, 0x289: 0x2000, 0x28a: 0x2000, 0x28b: 0x2000, - 0x28c: 0x2000, 0x28d: 0x2000, 0x28e: 0x2000, 0x28f: 0x2000, 0x290: 0x2000, 0x291: 0x2000, - 0x292: 0x2000, 0x293: 0x2000, 0x294: 0x2000, 0x295: 0x2000, 0x296: 0x2000, 0x297: 0x2000, - 0x298: 0x2000, 0x299: 0x2000, 0x29a: 0x2000, 0x29b: 0x2000, 0x29c: 0x2000, 0x29d: 0x2000, - 0x29e: 0x2000, 0x29f: 0x2000, 0x2a0: 0x2000, 0x2a1: 0x2000, 0x2a2: 0x2000, 0x2a3: 0x2000, - 0x2a4: 0x2000, 0x2a5: 0x2000, 0x2a6: 0x2000, 0x2a7: 0x2000, 0x2a8: 0x2000, 0x2a9: 0x2000, - 0x2aa: 0x2000, 0x2ab: 0x2000, 0x2ac: 0x2000, 0x2ad: 0x2000, 0x2ae: 0x2000, 0x2af: 0x2000, - 0x2b0: 0x2000, 0x2b1: 0x2000, 0x2b2: 0x2000, 0x2b3: 0x2000, 0x2b4: 0x2000, 0x2b5: 0x2000, - 0x2b6: 0x2000, 0x2b7: 0x2000, 0x2b8: 0x2000, 0x2b9: 0x2000, 0x2ba: 0x2000, 0x2bb: 0x2000, - 0x2bc: 0x2000, 0x2bd: 0x2000, 0x2be: 0x2000, 0x2bf: 0x2000, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x2000, 0x2c1: 0x2000, 0x2c2: 0x2000, 0x2c3: 0x2000, 0x2c4: 0x2000, 0x2c5: 0x2000, - 0x2c6: 0x2000, 0x2c7: 0x2000, 0x2c8: 0x2000, 0x2c9: 0x2000, 0x2ca: 0x2000, 0x2cb: 0x2000, - 0x2cc: 0x2000, 0x2cd: 0x2000, 0x2ce: 0x2000, 0x2cf: 0x2000, 0x2d0: 0x2000, 0x2d1: 0x2000, - 0x2d2: 0x2000, 0x2d3: 0x2000, 0x2d4: 0x2000, 0x2d5: 0x2000, 0x2d6: 0x2000, 0x2d7: 0x2000, - 0x2d8: 0x2000, 0x2d9: 0x2000, 0x2da: 0x2000, 0x2db: 0x2000, 0x2dc: 0x2000, 0x2dd: 0x2000, - 0x2de: 0x2000, 0x2df: 0x2000, 0x2e0: 0x2000, 0x2e1: 0x2000, 0x2e2: 0x2000, 0x2e3: 0x2000, - 0x2e4: 0x2000, 0x2e5: 0x2000, 0x2e6: 0x2000, 0x2e7: 0x2000, 0x2e8: 0x2000, 0x2e9: 0x2000, - 0x2ea: 0x2000, 0x2eb: 0x2000, 0x2ec: 0x2000, 0x2ed: 0x2000, 0x2ee: 0x2000, 0x2ef: 0x2000, - // Block 0xc, offset 0x300 - 0x311: 0x2000, - 0x312: 0x2000, 0x313: 0x2000, 0x314: 0x2000, 0x315: 0x2000, 0x316: 0x2000, 0x317: 0x2000, - 0x318: 0x2000, 0x319: 0x2000, 0x31a: 0x2000, 0x31b: 0x2000, 0x31c: 0x2000, 0x31d: 0x2000, - 0x31e: 0x2000, 0x31f: 0x2000, 0x320: 0x2000, 0x321: 0x2000, 0x323: 0x2000, - 0x324: 0x2000, 0x325: 0x2000, 0x326: 0x2000, 0x327: 0x2000, 0x328: 0x2000, 0x329: 0x2000, - 0x331: 0x2000, 0x332: 0x2000, 0x333: 0x2000, 0x334: 0x2000, 0x335: 0x2000, - 0x336: 0x2000, 0x337: 0x2000, 0x338: 0x2000, 0x339: 0x2000, 0x33a: 0x2000, 0x33b: 0x2000, - 0x33c: 0x2000, 0x33d: 0x2000, 0x33e: 0x2000, 0x33f: 0x2000, - // Block 0xd, offset 0x340 - 0x340: 0x2000, 0x341: 0x2000, 0x343: 0x2000, 0x344: 0x2000, 0x345: 0x2000, - 0x346: 0x2000, 0x347: 0x2000, 0x348: 0x2000, 0x349: 0x2000, - // Block 0xe, offset 0x380 - 0x381: 0x2000, - 0x390: 0x2000, 0x391: 0x2000, - 0x392: 0x2000, 0x393: 0x2000, 0x394: 0x2000, 0x395: 0x2000, 0x396: 0x2000, 0x397: 0x2000, - 0x398: 0x2000, 0x399: 0x2000, 0x39a: 0x2000, 0x39b: 0x2000, 0x39c: 0x2000, 0x39d: 0x2000, - 0x39e: 0x2000, 0x39f: 0x2000, 0x3a0: 0x2000, 0x3a1: 0x2000, 0x3a2: 0x2000, 0x3a3: 0x2000, - 0x3a4: 0x2000, 0x3a5: 0x2000, 0x3a6: 0x2000, 0x3a7: 0x2000, 0x3a8: 0x2000, 0x3a9: 0x2000, - 0x3aa: 0x2000, 0x3ab: 0x2000, 0x3ac: 0x2000, 0x3ad: 0x2000, 0x3ae: 0x2000, 0x3af: 0x2000, - 0x3b0: 0x2000, 0x3b1: 0x2000, 0x3b2: 0x2000, 0x3b3: 0x2000, 0x3b4: 0x2000, 0x3b5: 0x2000, - 0x3b6: 0x2000, 0x3b7: 0x2000, 0x3b8: 0x2000, 0x3b9: 0x2000, 0x3ba: 0x2000, 0x3bb: 0x2000, - 0x3bc: 0x2000, 0x3bd: 0x2000, 0x3be: 0x2000, 0x3bf: 0x2000, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x2000, 0x3c1: 0x2000, 0x3c2: 0x2000, 0x3c3: 0x2000, 0x3c4: 0x2000, 0x3c5: 0x2000, - 0x3c6: 0x2000, 0x3c7: 0x2000, 0x3c8: 0x2000, 0x3c9: 0x2000, 0x3ca: 0x2000, 0x3cb: 0x2000, - 0x3cc: 0x2000, 0x3cd: 0x2000, 0x3ce: 0x2000, 0x3cf: 0x2000, 0x3d1: 0x2000, - // Block 0x10, offset 0x400 - 0x400: 0x4000, 0x401: 0x4000, 0x402: 0x4000, 0x403: 0x4000, 0x404: 0x4000, 0x405: 0x4000, - 0x406: 0x4000, 0x407: 0x4000, 0x408: 0x4000, 0x409: 0x4000, 0x40a: 0x4000, 0x40b: 0x4000, - 0x40c: 0x4000, 0x40d: 0x4000, 0x40e: 0x4000, 0x40f: 0x4000, 0x410: 0x4000, 0x411: 0x4000, - 0x412: 0x4000, 0x413: 0x4000, 0x414: 0x4000, 0x415: 0x4000, 0x416: 0x4000, 0x417: 0x4000, - 0x418: 0x4000, 0x419: 0x4000, 0x41a: 0x4000, 0x41b: 0x4000, 0x41c: 0x4000, 0x41d: 0x4000, - 0x41e: 0x4000, 0x41f: 0x4000, 0x420: 0x4000, 0x421: 0x4000, 0x422: 0x4000, 0x423: 0x4000, - 0x424: 0x4000, 0x425: 0x4000, 0x426: 0x4000, 0x427: 0x4000, 0x428: 0x4000, 0x429: 0x4000, - 0x42a: 0x4000, 0x42b: 0x4000, 0x42c: 0x4000, 0x42d: 0x4000, 0x42e: 0x4000, 0x42f: 0x4000, - 0x430: 0x4000, 0x431: 0x4000, 0x432: 0x4000, 0x433: 0x4000, 0x434: 0x4000, 0x435: 0x4000, - 0x436: 0x4000, 0x437: 0x4000, 0x438: 0x4000, 0x439: 0x4000, 0x43a: 0x4000, 0x43b: 0x4000, - 0x43c: 0x4000, 0x43d: 0x4000, 0x43e: 0x4000, 0x43f: 0x4000, - // Block 0x11, offset 0x440 - 0x440: 0x4000, 0x441: 0x4000, 0x442: 0x4000, 0x443: 0x4000, 0x444: 0x4000, 0x445: 0x4000, - 0x446: 0x4000, 0x447: 0x4000, 0x448: 0x4000, 0x449: 0x4000, 0x44a: 0x4000, 0x44b: 0x4000, - 0x44c: 0x4000, 0x44d: 0x4000, 0x44e: 0x4000, 0x44f: 0x4000, 0x450: 0x4000, 0x451: 0x4000, - 0x452: 0x4000, 0x453: 0x4000, 0x454: 0x4000, 0x455: 0x4000, 0x456: 0x4000, 0x457: 0x4000, - 0x458: 0x4000, 0x459: 0x4000, 0x45a: 0x4000, 0x45b: 0x4000, 0x45c: 0x4000, 0x45d: 0x4000, - 0x45e: 0x4000, 0x45f: 0x4000, - // Block 0x12, offset 0x480 - 0x490: 0x2000, - 0x493: 0x2000, 0x494: 0x2000, 0x495: 0x2000, 0x496: 0x2000, - 0x498: 0x2000, 0x499: 0x2000, 0x49c: 0x2000, 0x49d: 0x2000, - 0x4a0: 0x2000, 0x4a1: 0x2000, 0x4a2: 0x2000, - 0x4a4: 0x2000, 0x4a5: 0x2000, 0x4a6: 0x2000, 0x4a7: 0x2000, - 0x4b0: 0x2000, 0x4b2: 0x2000, 0x4b3: 0x2000, 0x4b5: 0x2000, - 0x4bb: 0x2000, - 0x4be: 0x2000, - // Block 0x13, offset 0x4c0 - 0x4f4: 0x2000, - 0x4ff: 0x2000, - // Block 0x14, offset 0x500 - 0x501: 0x2000, 0x502: 0x2000, 0x503: 0x2000, 0x504: 0x2000, - 0x529: 0xa009, - 0x52c: 0x2000, - // Block 0x15, offset 0x540 - 0x543: 0x2000, 0x545: 0x2000, - 0x549: 0x2000, - 0x553: 0x2000, 0x556: 0x2000, - 0x561: 0x2000, 0x562: 0x2000, - 0x566: 0x2000, - 0x56b: 0x2000, - // Block 0x16, offset 0x580 - 0x593: 0x2000, 0x594: 0x2000, - 0x59b: 0x2000, 0x59c: 0x2000, 0x59d: 0x2000, - 0x59e: 0x2000, 0x5a0: 0x2000, 0x5a1: 0x2000, 0x5a2: 0x2000, 0x5a3: 0x2000, - 0x5a4: 0x2000, 0x5a5: 0x2000, 0x5a6: 0x2000, 0x5a7: 0x2000, 0x5a8: 0x2000, 0x5a9: 0x2000, - 0x5aa: 0x2000, 0x5ab: 0x2000, - 0x5b0: 0x2000, 0x5b1: 0x2000, 0x5b2: 0x2000, 0x5b3: 0x2000, 0x5b4: 0x2000, 0x5b5: 0x2000, - 0x5b6: 0x2000, 0x5b7: 0x2000, 0x5b8: 0x2000, 0x5b9: 0x2000, - // Block 0x17, offset 0x5c0 - 0x5c9: 0x2000, - 0x5d0: 0x200a, 0x5d1: 0x200b, - 0x5d2: 0x200a, 0x5d3: 0x200c, 0x5d4: 0x2000, 0x5d5: 0x2000, 0x5d6: 0x2000, 0x5d7: 0x2000, - 0x5d8: 0x2000, 0x5d9: 0x2000, - 0x5f8: 0x2000, 0x5f9: 0x2000, - // Block 0x18, offset 0x600 - 0x612: 0x2000, 0x614: 0x2000, - 0x627: 0x2000, - // Block 0x19, offset 0x640 - 0x640: 0x2000, 0x642: 0x2000, 0x643: 0x2000, - 0x647: 0x2000, 0x648: 0x2000, 0x64b: 0x2000, - 0x64f: 0x2000, 0x651: 0x2000, - 0x655: 0x2000, - 0x65a: 0x2000, 0x65d: 0x2000, - 0x65e: 0x2000, 0x65f: 0x2000, 0x660: 0x2000, 0x663: 0x2000, - 0x665: 0x2000, 0x667: 0x2000, 0x668: 0x2000, 0x669: 0x2000, - 0x66a: 0x2000, 0x66b: 0x2000, 0x66c: 0x2000, 0x66e: 0x2000, - 0x674: 0x2000, 0x675: 0x2000, - 0x676: 0x2000, 0x677: 0x2000, - 0x67c: 0x2000, 0x67d: 0x2000, - // Block 0x1a, offset 0x680 - 0x688: 0x2000, - 0x68c: 0x2000, - 0x692: 0x2000, - 0x6a0: 0x2000, 0x6a1: 0x2000, - 0x6a4: 0x2000, 0x6a5: 0x2000, 0x6a6: 0x2000, 0x6a7: 0x2000, - 0x6aa: 0x2000, 0x6ab: 0x2000, 0x6ae: 0x2000, 0x6af: 0x2000, - // Block 0x1b, offset 0x6c0 - 0x6c2: 0x2000, 0x6c3: 0x2000, - 0x6c6: 0x2000, 0x6c7: 0x2000, - 0x6d5: 0x2000, - 0x6d9: 0x2000, - 0x6e5: 0x2000, - 0x6ff: 0x2000, - // Block 0x1c, offset 0x700 - 0x712: 0x2000, - 0x71a: 0x4000, 0x71b: 0x4000, - 0x729: 0x4000, - 0x72a: 0x4000, - // Block 0x1d, offset 0x740 - 0x769: 0x4000, - 0x76a: 0x4000, 0x76b: 0x4000, 0x76c: 0x4000, - 0x770: 0x4000, 0x773: 0x4000, - // Block 0x1e, offset 0x780 - 0x7a0: 0x2000, 0x7a1: 0x2000, 0x7a2: 0x2000, 0x7a3: 0x2000, - 0x7a4: 0x2000, 0x7a5: 0x2000, 0x7a6: 0x2000, 0x7a7: 0x2000, 0x7a8: 0x2000, 0x7a9: 0x2000, - 0x7aa: 0x2000, 0x7ab: 0x2000, 0x7ac: 0x2000, 0x7ad: 0x2000, 0x7ae: 0x2000, 0x7af: 0x2000, - 0x7b0: 0x2000, 0x7b1: 0x2000, 0x7b2: 0x2000, 0x7b3: 0x2000, 0x7b4: 0x2000, 0x7b5: 0x2000, - 0x7b6: 0x2000, 0x7b7: 0x2000, 0x7b8: 0x2000, 0x7b9: 0x2000, 0x7ba: 0x2000, 0x7bb: 0x2000, - 0x7bc: 0x2000, 0x7bd: 0x2000, 0x7be: 0x2000, 0x7bf: 0x2000, - // Block 0x1f, offset 0x7c0 - 0x7c0: 0x2000, 0x7c1: 0x2000, 0x7c2: 0x2000, 0x7c3: 0x2000, 0x7c4: 0x2000, 0x7c5: 0x2000, - 0x7c6: 0x2000, 0x7c7: 0x2000, 0x7c8: 0x2000, 0x7c9: 0x2000, 0x7ca: 0x2000, 0x7cb: 0x2000, - 0x7cc: 0x2000, 0x7cd: 0x2000, 0x7ce: 0x2000, 0x7cf: 0x2000, 0x7d0: 0x2000, 0x7d1: 0x2000, - 0x7d2: 0x2000, 0x7d3: 0x2000, 0x7d4: 0x2000, 0x7d5: 0x2000, 0x7d6: 0x2000, 0x7d7: 0x2000, - 0x7d8: 0x2000, 0x7d9: 0x2000, 0x7da: 0x2000, 0x7db: 0x2000, 0x7dc: 0x2000, 0x7dd: 0x2000, - 0x7de: 0x2000, 0x7df: 0x2000, 0x7e0: 0x2000, 0x7e1: 0x2000, 0x7e2: 0x2000, 0x7e3: 0x2000, - 0x7e4: 0x2000, 0x7e5: 0x2000, 0x7e6: 0x2000, 0x7e7: 0x2000, 0x7e8: 0x2000, 0x7e9: 0x2000, - 0x7eb: 0x2000, 0x7ec: 0x2000, 0x7ed: 0x2000, 0x7ee: 0x2000, 0x7ef: 0x2000, - 0x7f0: 0x2000, 0x7f1: 0x2000, 0x7f2: 0x2000, 0x7f3: 0x2000, 0x7f4: 0x2000, 0x7f5: 0x2000, - 0x7f6: 0x2000, 0x7f7: 0x2000, 0x7f8: 0x2000, 0x7f9: 0x2000, 0x7fa: 0x2000, 0x7fb: 0x2000, - 0x7fc: 0x2000, 0x7fd: 0x2000, 0x7fe: 0x2000, 0x7ff: 0x2000, - // Block 0x20, offset 0x800 - 0x800: 0x2000, 0x801: 0x2000, 0x802: 0x200d, 0x803: 0x2000, 0x804: 0x2000, 0x805: 0x2000, - 0x806: 0x2000, 0x807: 0x2000, 0x808: 0x2000, 0x809: 0x2000, 0x80a: 0x2000, 0x80b: 0x2000, - 0x80c: 0x2000, 0x80d: 0x2000, 0x80e: 0x2000, 0x80f: 0x2000, 0x810: 0x2000, 0x811: 0x2000, - 0x812: 0x2000, 0x813: 0x2000, 0x814: 0x2000, 0x815: 0x2000, 0x816: 0x2000, 0x817: 0x2000, - 0x818: 0x2000, 0x819: 0x2000, 0x81a: 0x2000, 0x81b: 0x2000, 0x81c: 0x2000, 0x81d: 0x2000, - 0x81e: 0x2000, 0x81f: 0x2000, 0x820: 0x2000, 0x821: 0x2000, 0x822: 0x2000, 0x823: 0x2000, - 0x824: 0x2000, 0x825: 0x2000, 0x826: 0x2000, 0x827: 0x2000, 0x828: 0x2000, 0x829: 0x2000, - 0x82a: 0x2000, 0x82b: 0x2000, 0x82c: 0x2000, 0x82d: 0x2000, 0x82e: 0x2000, 0x82f: 0x2000, - 0x830: 0x2000, 0x831: 0x2000, 0x832: 0x2000, 0x833: 0x2000, 0x834: 0x2000, 0x835: 0x2000, - 0x836: 0x2000, 0x837: 0x2000, 0x838: 0x2000, 0x839: 0x2000, 0x83a: 0x2000, 0x83b: 0x2000, - 0x83c: 0x2000, 0x83d: 0x2000, 0x83e: 0x2000, 0x83f: 0x2000, - // Block 0x21, offset 0x840 - 0x840: 0x2000, 0x841: 0x2000, 0x842: 0x2000, 0x843: 0x2000, 0x844: 0x2000, 0x845: 0x2000, - 0x846: 0x2000, 0x847: 0x2000, 0x848: 0x2000, 0x849: 0x2000, 0x84a: 0x2000, 0x84b: 0x2000, - 0x850: 0x2000, 0x851: 0x2000, - 0x852: 0x2000, 0x853: 0x2000, 0x854: 0x2000, 0x855: 0x2000, 0x856: 0x2000, 0x857: 0x2000, - 0x858: 0x2000, 0x859: 0x2000, 0x85a: 0x2000, 0x85b: 0x2000, 0x85c: 0x2000, 0x85d: 0x2000, - 0x85e: 0x2000, 0x85f: 0x2000, 0x860: 0x2000, 0x861: 0x2000, 0x862: 0x2000, 0x863: 0x2000, - 0x864: 0x2000, 0x865: 0x2000, 0x866: 0x2000, 0x867: 0x2000, 0x868: 0x2000, 0x869: 0x2000, - 0x86a: 0x2000, 0x86b: 0x2000, 0x86c: 0x2000, 0x86d: 0x2000, 0x86e: 0x2000, 0x86f: 0x2000, - 0x870: 0x2000, 0x871: 0x2000, 0x872: 0x2000, 0x873: 0x2000, - // Block 0x22, offset 0x880 - 0x880: 0x2000, 0x881: 0x2000, 0x882: 0x2000, 0x883: 0x2000, 0x884: 0x2000, 0x885: 0x2000, - 0x886: 0x2000, 0x887: 0x2000, 0x888: 0x2000, 0x889: 0x2000, 0x88a: 0x2000, 0x88b: 0x2000, - 0x88c: 0x2000, 0x88d: 0x2000, 0x88e: 0x2000, 0x88f: 0x2000, - 0x892: 0x2000, 0x893: 0x2000, 0x894: 0x2000, 0x895: 0x2000, - 0x8a0: 0x200e, 0x8a1: 0x2000, 0x8a3: 0x2000, - 0x8a4: 0x2000, 0x8a5: 0x2000, 0x8a6: 0x2000, 0x8a7: 0x2000, 0x8a8: 0x2000, 0x8a9: 0x2000, - 0x8b2: 0x2000, 0x8b3: 0x2000, - 0x8b6: 0x2000, 0x8b7: 0x2000, - 0x8bc: 0x2000, 0x8bd: 0x2000, - // Block 0x23, offset 0x8c0 - 0x8c0: 0x2000, 0x8c1: 0x2000, - 0x8c6: 0x2000, 0x8c7: 0x2000, 0x8c8: 0x2000, 0x8cb: 0x200f, - 0x8ce: 0x2000, 0x8cf: 0x2000, 0x8d0: 0x2000, 0x8d1: 0x2000, - 0x8e2: 0x2000, 0x8e3: 0x2000, - 0x8e4: 0x2000, 0x8e5: 0x2000, - 0x8ef: 0x2000, - 0x8fd: 0x4000, 0x8fe: 0x4000, - // Block 0x24, offset 0x900 - 0x905: 0x2000, - 0x906: 0x2000, 0x909: 0x2000, - 0x90e: 0x2000, 0x90f: 0x2000, - 0x914: 0x4000, 0x915: 0x4000, - 0x91c: 0x2000, - 0x91e: 0x2000, - // Block 0x25, offset 0x940 - 0x940: 0x2000, 0x942: 0x2000, - 0x948: 0x4000, 0x949: 0x4000, 0x94a: 0x4000, 0x94b: 0x4000, - 0x94c: 0x4000, 0x94d: 0x4000, 0x94e: 0x4000, 0x94f: 0x4000, 0x950: 0x4000, 0x951: 0x4000, - 0x952: 0x4000, 0x953: 0x4000, - 0x960: 0x2000, 0x961: 0x2000, 0x963: 0x2000, - 0x964: 0x2000, 0x965: 0x2000, 0x967: 0x2000, 0x968: 0x2000, 0x969: 0x2000, - 0x96a: 0x2000, 0x96c: 0x2000, 0x96d: 0x2000, 0x96f: 0x2000, - 0x97f: 0x4000, - // Block 0x26, offset 0x980 - 0x993: 0x4000, - 0x99e: 0x2000, 0x99f: 0x2000, 0x9a1: 0x4000, - 0x9aa: 0x4000, 0x9ab: 0x4000, - 0x9bd: 0x4000, 0x9be: 0x4000, 0x9bf: 0x2000, - // Block 0x27, offset 0x9c0 - 0x9c4: 0x4000, 0x9c5: 0x4000, - 0x9c6: 0x2000, 0x9c7: 0x2000, 0x9c8: 0x2000, 0x9c9: 0x2000, 0x9ca: 0x2000, 0x9cb: 0x2000, - 0x9cc: 0x2000, 0x9cd: 0x2000, 0x9ce: 0x4000, 0x9cf: 0x2000, 0x9d0: 0x2000, 0x9d1: 0x2000, - 0x9d2: 0x2000, 0x9d3: 0x2000, 0x9d4: 0x4000, 0x9d5: 0x2000, 0x9d6: 0x2000, 0x9d7: 0x2000, - 0x9d8: 0x2000, 0x9d9: 0x2000, 0x9da: 0x2000, 0x9db: 0x2000, 0x9dc: 0x2000, 0x9dd: 0x2000, - 0x9de: 0x2000, 0x9df: 0x2000, 0x9e0: 0x2000, 0x9e1: 0x2000, 0x9e3: 0x2000, - 0x9e8: 0x2000, 0x9e9: 0x2000, - 0x9ea: 0x4000, 0x9eb: 0x2000, 0x9ec: 0x2000, 0x9ed: 0x2000, 0x9ee: 0x2000, 0x9ef: 0x2000, - 0x9f0: 0x2000, 0x9f1: 0x2000, 0x9f2: 0x4000, 0x9f3: 0x4000, 0x9f4: 0x2000, 0x9f5: 0x4000, - 0x9f6: 0x2000, 0x9f7: 0x2000, 0x9f8: 0x2000, 0x9f9: 0x2000, 0x9fa: 0x4000, 0x9fb: 0x2000, - 0x9fc: 0x2000, 0x9fd: 0x4000, 0x9fe: 0x2000, 0x9ff: 0x2000, - // Block 0x28, offset 0xa00 - 0xa05: 0x4000, - 0xa0a: 0x4000, 0xa0b: 0x4000, - 0xa28: 0x4000, - 0xa3d: 0x2000, - // Block 0x29, offset 0xa40 - 0xa4c: 0x4000, 0xa4e: 0x4000, - 0xa53: 0x4000, 0xa54: 0x4000, 0xa55: 0x4000, 0xa57: 0x4000, - 0xa76: 0x2000, 0xa77: 0x2000, 0xa78: 0x2000, 0xa79: 0x2000, 0xa7a: 0x2000, 0xa7b: 0x2000, - 0xa7c: 0x2000, 0xa7d: 0x2000, 0xa7e: 0x2000, 0xa7f: 0x2000, - // Block 0x2a, offset 0xa80 - 0xa95: 0x4000, 0xa96: 0x4000, 0xa97: 0x4000, - 0xab0: 0x4000, - 0xabf: 0x4000, - // Block 0x2b, offset 0xac0 - 0xae6: 0x6000, 0xae7: 0x6000, 0xae8: 0x6000, 0xae9: 0x6000, - 0xaea: 0x6000, 0xaeb: 0x6000, 0xaec: 0x6000, 0xaed: 0x6000, - // Block 0x2c, offset 0xb00 - 0xb05: 0x6010, - 0xb06: 0x6011, - // Block 0x2d, offset 0xb40 - 0xb5b: 0x4000, 0xb5c: 0x4000, - // Block 0x2e, offset 0xb80 - 0xb90: 0x4000, - 0xb95: 0x4000, 0xb96: 0x2000, 0xb97: 0x2000, - 0xb98: 0x2000, 0xb99: 0x2000, - // Block 0x2f, offset 0xbc0 - 0xbc0: 0x4000, 0xbc1: 0x4000, 0xbc2: 0x4000, 0xbc3: 0x4000, 0xbc4: 0x4000, 0xbc5: 0x4000, - 0xbc6: 0x4000, 0xbc7: 0x4000, 0xbc8: 0x4000, 0xbc9: 0x4000, 0xbca: 0x4000, 0xbcb: 0x4000, - 0xbcc: 0x4000, 0xbcd: 0x4000, 0xbce: 0x4000, 0xbcf: 0x4000, 0xbd0: 0x4000, 0xbd1: 0x4000, - 0xbd2: 0x4000, 0xbd3: 0x4000, 0xbd4: 0x4000, 0xbd5: 0x4000, 0xbd6: 0x4000, 0xbd7: 0x4000, - 0xbd8: 0x4000, 0xbd9: 0x4000, 0xbdb: 0x4000, 0xbdc: 0x4000, 0xbdd: 0x4000, - 0xbde: 0x4000, 0xbdf: 0x4000, 0xbe0: 0x4000, 0xbe1: 0x4000, 0xbe2: 0x4000, 0xbe3: 0x4000, - 0xbe4: 0x4000, 0xbe5: 0x4000, 0xbe6: 0x4000, 0xbe7: 0x4000, 0xbe8: 0x4000, 0xbe9: 0x4000, - 0xbea: 0x4000, 0xbeb: 0x4000, 0xbec: 0x4000, 0xbed: 0x4000, 0xbee: 0x4000, 0xbef: 0x4000, - 0xbf0: 0x4000, 0xbf1: 0x4000, 0xbf2: 0x4000, 0xbf3: 0x4000, 0xbf4: 0x4000, 0xbf5: 0x4000, - 0xbf6: 0x4000, 0xbf7: 0x4000, 0xbf8: 0x4000, 0xbf9: 0x4000, 0xbfa: 0x4000, 0xbfb: 0x4000, - 0xbfc: 0x4000, 0xbfd: 0x4000, 0xbfe: 0x4000, 0xbff: 0x4000, - // Block 0x30, offset 0xc00 - 0xc00: 0x4000, 0xc01: 0x4000, 0xc02: 0x4000, 0xc03: 0x4000, 0xc04: 0x4000, 0xc05: 0x4000, - 0xc06: 0x4000, 0xc07: 0x4000, 0xc08: 0x4000, 0xc09: 0x4000, 0xc0a: 0x4000, 0xc0b: 0x4000, - 0xc0c: 0x4000, 0xc0d: 0x4000, 0xc0e: 0x4000, 0xc0f: 0x4000, 0xc10: 0x4000, 0xc11: 0x4000, - 0xc12: 0x4000, 0xc13: 0x4000, 0xc14: 0x4000, 0xc15: 0x4000, 0xc16: 0x4000, 0xc17: 0x4000, - 0xc18: 0x4000, 0xc19: 0x4000, 0xc1a: 0x4000, 0xc1b: 0x4000, 0xc1c: 0x4000, 0xc1d: 0x4000, - 0xc1e: 0x4000, 0xc1f: 0x4000, 0xc20: 0x4000, 0xc21: 0x4000, 0xc22: 0x4000, 0xc23: 0x4000, - 0xc24: 0x4000, 0xc25: 0x4000, 0xc26: 0x4000, 0xc27: 0x4000, 0xc28: 0x4000, 0xc29: 0x4000, - 0xc2a: 0x4000, 0xc2b: 0x4000, 0xc2c: 0x4000, 0xc2d: 0x4000, 0xc2e: 0x4000, 0xc2f: 0x4000, - 0xc30: 0x4000, 0xc31: 0x4000, 0xc32: 0x4000, 0xc33: 0x4000, - // Block 0x31, offset 0xc40 - 0xc40: 0x4000, 0xc41: 0x4000, 0xc42: 0x4000, 0xc43: 0x4000, 0xc44: 0x4000, 0xc45: 0x4000, - 0xc46: 0x4000, 0xc47: 0x4000, 0xc48: 0x4000, 0xc49: 0x4000, 0xc4a: 0x4000, 0xc4b: 0x4000, - 0xc4c: 0x4000, 0xc4d: 0x4000, 0xc4e: 0x4000, 0xc4f: 0x4000, 0xc50: 0x4000, 0xc51: 0x4000, - 0xc52: 0x4000, 0xc53: 0x4000, 0xc54: 0x4000, 0xc55: 0x4000, - 0xc70: 0x4000, 0xc71: 0x4000, 0xc72: 0x4000, 0xc73: 0x4000, 0xc74: 0x4000, 0xc75: 0x4000, - 0xc76: 0x4000, 0xc77: 0x4000, 0xc78: 0x4000, 0xc79: 0x4000, 0xc7a: 0x4000, 0xc7b: 0x4000, - // Block 0x32, offset 0xc80 - 0xc80: 0x9012, 0xc81: 0x4013, 0xc82: 0x4014, 0xc83: 0x4000, 0xc84: 0x4000, 0xc85: 0x4000, - 0xc86: 0x4000, 0xc87: 0x4000, 0xc88: 0x4000, 0xc89: 0x4000, 0xc8a: 0x4000, 0xc8b: 0x4000, - 0xc8c: 0x4015, 0xc8d: 0x4015, 0xc8e: 0x4000, 0xc8f: 0x4000, 0xc90: 0x4000, 0xc91: 0x4000, - 0xc92: 0x4000, 0xc93: 0x4000, 0xc94: 0x4000, 0xc95: 0x4000, 0xc96: 0x4000, 0xc97: 0x4000, - 0xc98: 0x4000, 0xc99: 0x4000, 0xc9a: 0x4000, 0xc9b: 0x4000, 0xc9c: 0x4000, 0xc9d: 0x4000, - 0xc9e: 0x4000, 0xc9f: 0x4000, 0xca0: 0x4000, 0xca1: 0x4000, 0xca2: 0x4000, 0xca3: 0x4000, - 0xca4: 0x4000, 0xca5: 0x4000, 0xca6: 0x4000, 0xca7: 0x4000, 0xca8: 0x4000, 0xca9: 0x4000, - 0xcaa: 0x4000, 0xcab: 0x4000, 0xcac: 0x4000, 0xcad: 0x4000, 0xcae: 0x4000, 0xcaf: 0x4000, - 0xcb0: 0x4000, 0xcb1: 0x4000, 0xcb2: 0x4000, 0xcb3: 0x4000, 0xcb4: 0x4000, 0xcb5: 0x4000, - 0xcb6: 0x4000, 0xcb7: 0x4000, 0xcb8: 0x4000, 0xcb9: 0x4000, 0xcba: 0x4000, 0xcbb: 0x4000, - 0xcbc: 0x4000, 0xcbd: 0x4000, 0xcbe: 0x4000, - // Block 0x33, offset 0xcc0 - 0xcc1: 0x4000, 0xcc2: 0x4000, 0xcc3: 0x4000, 0xcc4: 0x4000, 0xcc5: 0x4000, - 0xcc6: 0x4000, 0xcc7: 0x4000, 0xcc8: 0x4000, 0xcc9: 0x4000, 0xcca: 0x4000, 0xccb: 0x4000, - 0xccc: 0x4000, 0xccd: 0x4000, 0xcce: 0x4000, 0xccf: 0x4000, 0xcd0: 0x4000, 0xcd1: 0x4000, - 0xcd2: 0x4000, 0xcd3: 0x4000, 0xcd4: 0x4000, 0xcd5: 0x4000, 0xcd6: 0x4000, 0xcd7: 0x4000, - 0xcd8: 0x4000, 0xcd9: 0x4000, 0xcda: 0x4000, 0xcdb: 0x4000, 0xcdc: 0x4000, 0xcdd: 0x4000, - 0xcde: 0x4000, 0xcdf: 0x4000, 0xce0: 0x4000, 0xce1: 0x4000, 0xce2: 0x4000, 0xce3: 0x4000, - 0xce4: 0x4000, 0xce5: 0x4000, 0xce6: 0x4000, 0xce7: 0x4000, 0xce8: 0x4000, 0xce9: 0x4000, - 0xcea: 0x4000, 0xceb: 0x4000, 0xcec: 0x4000, 0xced: 0x4000, 0xcee: 0x4000, 0xcef: 0x4000, - 0xcf0: 0x4000, 0xcf1: 0x4000, 0xcf2: 0x4000, 0xcf3: 0x4000, 0xcf4: 0x4000, 0xcf5: 0x4000, - 0xcf6: 0x4000, 0xcf7: 0x4000, 0xcf8: 0x4000, 0xcf9: 0x4000, 0xcfa: 0x4000, 0xcfb: 0x4000, - 0xcfc: 0x4000, 0xcfd: 0x4000, 0xcfe: 0x4000, 0xcff: 0x4000, - // Block 0x34, offset 0xd00 - 0xd00: 0x4000, 0xd01: 0x4000, 0xd02: 0x4000, 0xd03: 0x4000, 0xd04: 0x4000, 0xd05: 0x4000, - 0xd06: 0x4000, 0xd07: 0x4000, 0xd08: 0x4000, 0xd09: 0x4000, 0xd0a: 0x4000, 0xd0b: 0x4000, - 0xd0c: 0x4000, 0xd0d: 0x4000, 0xd0e: 0x4000, 0xd0f: 0x4000, 0xd10: 0x4000, 0xd11: 0x4000, - 0xd12: 0x4000, 0xd13: 0x4000, 0xd14: 0x4000, 0xd15: 0x4000, 0xd16: 0x4000, - 0xd19: 0x4016, 0xd1a: 0x4017, 0xd1b: 0x4000, 0xd1c: 0x4000, 0xd1d: 0x4000, - 0xd1e: 0x4000, 0xd1f: 0x4000, 0xd20: 0x4000, 0xd21: 0x4018, 0xd22: 0x4019, 0xd23: 0x401a, - 0xd24: 0x401b, 0xd25: 0x401c, 0xd26: 0x401d, 0xd27: 0x401e, 0xd28: 0x401f, 0xd29: 0x4020, - 0xd2a: 0x4021, 0xd2b: 0x4022, 0xd2c: 0x4000, 0xd2d: 0x4010, 0xd2e: 0x4000, 0xd2f: 0x4023, - 0xd30: 0x4000, 0xd31: 0x4024, 0xd32: 0x4000, 0xd33: 0x4025, 0xd34: 0x4000, 0xd35: 0x4026, - 0xd36: 0x4000, 0xd37: 0x401a, 0xd38: 0x4000, 0xd39: 0x4027, 0xd3a: 0x4000, 0xd3b: 0x4028, - 0xd3c: 0x4000, 0xd3d: 0x4020, 0xd3e: 0x4000, 0xd3f: 0x4029, - // Block 0x35, offset 0xd40 - 0xd40: 0x4000, 0xd41: 0x402a, 0xd42: 0x4000, 0xd43: 0x402b, 0xd44: 0x402c, 0xd45: 0x4000, - 0xd46: 0x4017, 0xd47: 0x4000, 0xd48: 0x402d, 0xd49: 0x4000, 0xd4a: 0x402e, 0xd4b: 0x402f, - 0xd4c: 0x4030, 0xd4d: 0x4017, 0xd4e: 0x4016, 0xd4f: 0x4017, 0xd50: 0x4000, 0xd51: 0x4000, - 0xd52: 0x4031, 0xd53: 0x4000, 0xd54: 0x4000, 0xd55: 0x4031, 0xd56: 0x4000, 0xd57: 0x4000, - 0xd58: 0x4032, 0xd59: 0x4000, 0xd5a: 0x4000, 0xd5b: 0x4032, 0xd5c: 0x4000, 0xd5d: 0x4000, - 0xd5e: 0x4033, 0xd5f: 0x402e, 0xd60: 0x4034, 0xd61: 0x4035, 0xd62: 0x4034, 0xd63: 0x4036, - 0xd64: 0x4037, 0xd65: 0x4024, 0xd66: 0x4035, 0xd67: 0x4025, 0xd68: 0x4038, 0xd69: 0x4038, - 0xd6a: 0x4039, 0xd6b: 0x4039, 0xd6c: 0x403a, 0xd6d: 0x403a, 0xd6e: 0x4000, 0xd6f: 0x4035, - 0xd70: 0x4000, 0xd71: 0x4000, 0xd72: 0x403b, 0xd73: 0x403c, 0xd74: 0x4000, 0xd75: 0x4000, - 0xd76: 0x4000, 0xd77: 0x4000, 0xd78: 0x4000, 0xd79: 0x4000, 0xd7a: 0x4000, 0xd7b: 0x403d, - 0xd7c: 0x401c, 0xd7d: 0x4000, 0xd7e: 0x4000, 0xd7f: 0x4000, - // Block 0x36, offset 0xd80 - 0xd85: 0x4000, - 0xd86: 0x4000, 0xd87: 0x4000, 0xd88: 0x4000, 0xd89: 0x4000, 0xd8a: 0x4000, 0xd8b: 0x4000, - 0xd8c: 0x4000, 0xd8d: 0x4000, 0xd8e: 0x4000, 0xd8f: 0x4000, 0xd90: 0x4000, 0xd91: 0x4000, - 0xd92: 0x4000, 0xd93: 0x4000, 0xd94: 0x4000, 0xd95: 0x4000, 0xd96: 0x4000, 0xd97: 0x4000, - 0xd98: 0x4000, 0xd99: 0x4000, 0xd9a: 0x4000, 0xd9b: 0x4000, 0xd9c: 0x4000, 0xd9d: 0x4000, - 0xd9e: 0x4000, 0xd9f: 0x4000, 0xda0: 0x4000, 0xda1: 0x4000, 0xda2: 0x4000, 0xda3: 0x4000, - 0xda4: 0x4000, 0xda5: 0x4000, 0xda6: 0x4000, 0xda7: 0x4000, 0xda8: 0x4000, 0xda9: 0x4000, - 0xdaa: 0x4000, 0xdab: 0x4000, 0xdac: 0x4000, 0xdad: 0x4000, - 0xdb1: 0x403e, 0xdb2: 0x403e, 0xdb3: 0x403e, 0xdb4: 0x403e, 0xdb5: 0x403e, - 0xdb6: 0x403e, 0xdb7: 0x403e, 0xdb8: 0x403e, 0xdb9: 0x403e, 0xdba: 0x403e, 0xdbb: 0x403e, - 0xdbc: 0x403e, 0xdbd: 0x403e, 0xdbe: 0x403e, 0xdbf: 0x403e, - // Block 0x37, offset 0xdc0 - 0xdc0: 0x4037, 0xdc1: 0x4037, 0xdc2: 0x4037, 0xdc3: 0x4037, 0xdc4: 0x4037, 0xdc5: 0x4037, - 0xdc6: 0x4037, 0xdc7: 0x4037, 0xdc8: 0x4037, 0xdc9: 0x4037, 0xdca: 0x4037, 0xdcb: 0x4037, - 0xdcc: 0x4037, 0xdcd: 0x4037, 0xdce: 0x4037, 0xdcf: 0x400e, 0xdd0: 0x403f, 0xdd1: 0x4040, - 0xdd2: 0x4041, 0xdd3: 0x4040, 0xdd4: 0x403f, 0xdd5: 0x4042, 0xdd6: 0x4043, 0xdd7: 0x4044, - 0xdd8: 0x4040, 0xdd9: 0x4041, 0xdda: 0x4040, 0xddb: 0x4045, 0xddc: 0x4009, 0xddd: 0x4045, - 0xdde: 0x4046, 0xddf: 0x4045, 0xde0: 0x4047, 0xde1: 0x400b, 0xde2: 0x400a, 0xde3: 0x400c, - 0xde4: 0x4048, 0xde5: 0x4000, 0xde6: 0x4000, 0xde7: 0x4000, 0xde8: 0x4000, 0xde9: 0x4000, - 0xdea: 0x4000, 0xdeb: 0x4000, 0xdec: 0x4000, 0xded: 0x4000, 0xdee: 0x4000, 0xdef: 0x4000, - 0xdf0: 0x4000, 0xdf1: 0x4000, 0xdf2: 0x4000, 0xdf3: 0x4000, 0xdf4: 0x4000, 0xdf5: 0x4000, - 0xdf6: 0x4000, 0xdf7: 0x4000, 0xdf8: 0x4000, 0xdf9: 0x4000, 0xdfa: 0x4000, 0xdfb: 0x4000, - 0xdfc: 0x4000, 0xdfd: 0x4000, 0xdfe: 0x4000, 0xdff: 0x4000, - // Block 0x38, offset 0xe00 - 0xe00: 0x4000, 0xe01: 0x4000, 0xe02: 0x4000, 0xe03: 0x4000, 0xe04: 0x4000, 0xe05: 0x4000, - 0xe06: 0x4000, 0xe07: 0x4000, 0xe08: 0x4000, 0xe09: 0x4000, 0xe0a: 0x4000, 0xe0b: 0x4000, - 0xe0c: 0x4000, 0xe0d: 0x4000, 0xe0e: 0x4000, 0xe10: 0x4000, 0xe11: 0x4000, - 0xe12: 0x4000, 0xe13: 0x4000, 0xe14: 0x4000, 0xe15: 0x4000, 0xe16: 0x4000, 0xe17: 0x4000, - 0xe18: 0x4000, 0xe19: 0x4000, 0xe1a: 0x4000, 0xe1b: 0x4000, 0xe1c: 0x4000, 0xe1d: 0x4000, - 0xe1e: 0x4000, 0xe1f: 0x4000, 0xe20: 0x4000, 0xe21: 0x4000, 0xe22: 0x4000, 0xe23: 0x4000, - 0xe24: 0x4000, 0xe25: 0x4000, 0xe26: 0x4000, 0xe27: 0x4000, 0xe28: 0x4000, 0xe29: 0x4000, - 0xe2a: 0x4000, 0xe2b: 0x4000, 0xe2c: 0x4000, 0xe2d: 0x4000, 0xe2e: 0x4000, 0xe2f: 0x4000, - 0xe30: 0x4000, 0xe31: 0x4000, 0xe32: 0x4000, 0xe33: 0x4000, 0xe34: 0x4000, 0xe35: 0x4000, - 0xe36: 0x4000, 0xe37: 0x4000, 0xe38: 0x4000, 0xe39: 0x4000, 0xe3a: 0x4000, - // Block 0x39, offset 0xe40 - 0xe40: 0x4000, 0xe41: 0x4000, 0xe42: 0x4000, 0xe43: 0x4000, 0xe44: 0x4000, 0xe45: 0x4000, - 0xe46: 0x4000, 0xe47: 0x4000, 0xe48: 0x4000, 0xe49: 0x4000, 0xe4a: 0x4000, 0xe4b: 0x4000, - 0xe4c: 0x4000, 0xe4d: 0x4000, 0xe4e: 0x4000, 0xe4f: 0x4000, 0xe50: 0x4000, 0xe51: 0x4000, - 0xe52: 0x4000, 0xe53: 0x4000, 0xe54: 0x4000, 0xe55: 0x4000, 0xe56: 0x4000, 0xe57: 0x4000, - 0xe58: 0x4000, 0xe59: 0x4000, 0xe5a: 0x4000, 0xe5b: 0x4000, 0xe5c: 0x4000, 0xe5d: 0x4000, - 0xe5e: 0x4000, 0xe5f: 0x4000, 0xe60: 0x4000, 0xe61: 0x4000, 0xe62: 0x4000, 0xe63: 0x4000, - 0xe70: 0x4000, 0xe71: 0x4000, 0xe72: 0x4000, 0xe73: 0x4000, 0xe74: 0x4000, 0xe75: 0x4000, - 0xe76: 0x4000, 0xe77: 0x4000, 0xe78: 0x4000, 0xe79: 0x4000, 0xe7a: 0x4000, 0xe7b: 0x4000, - 0xe7c: 0x4000, 0xe7d: 0x4000, 0xe7e: 0x4000, 0xe7f: 0x4000, - // Block 0x3a, offset 0xe80 - 0xe80: 0x4000, 0xe81: 0x4000, 0xe82: 0x4000, 0xe83: 0x4000, 0xe84: 0x4000, 0xe85: 0x4000, - 0xe86: 0x4000, 0xe87: 0x4000, 0xe88: 0x4000, 0xe89: 0x4000, 0xe8a: 0x4000, 0xe8b: 0x4000, - 0xe8c: 0x4000, 0xe8d: 0x4000, 0xe8e: 0x4000, 0xe8f: 0x4000, 0xe90: 0x4000, 0xe91: 0x4000, - 0xe92: 0x4000, 0xe93: 0x4000, 0xe94: 0x4000, 0xe95: 0x4000, 0xe96: 0x4000, 0xe97: 0x4000, - 0xe98: 0x4000, 0xe99: 0x4000, 0xe9a: 0x4000, 0xe9b: 0x4000, 0xe9c: 0x4000, 0xe9d: 0x4000, - 0xe9e: 0x4000, 0xea0: 0x4000, 0xea1: 0x4000, 0xea2: 0x4000, 0xea3: 0x4000, - 0xea4: 0x4000, 0xea5: 0x4000, 0xea6: 0x4000, 0xea7: 0x4000, 0xea8: 0x4000, 0xea9: 0x4000, - 0xeaa: 0x4000, 0xeab: 0x4000, 0xeac: 0x4000, 0xead: 0x4000, 0xeae: 0x4000, 0xeaf: 0x4000, - 0xeb0: 0x4000, 0xeb1: 0x4000, 0xeb2: 0x4000, 0xeb3: 0x4000, 0xeb4: 0x4000, 0xeb5: 0x4000, - 0xeb6: 0x4000, 0xeb7: 0x4000, 0xeb8: 0x4000, 0xeb9: 0x4000, 0xeba: 0x4000, 0xebb: 0x4000, - 0xebc: 0x4000, 0xebd: 0x4000, 0xebe: 0x4000, 0xebf: 0x4000, - // Block 0x3b, offset 0xec0 - 0xec0: 0x4000, 0xec1: 0x4000, 0xec2: 0x4000, 0xec3: 0x4000, 0xec4: 0x4000, 0xec5: 0x4000, - 0xec6: 0x4000, 0xec7: 0x4000, 0xec8: 0x2000, 0xec9: 0x2000, 0xeca: 0x2000, 0xecb: 0x2000, - 0xecc: 0x2000, 0xecd: 0x2000, 0xece: 0x2000, 0xecf: 0x2000, 0xed0: 0x4000, 0xed1: 0x4000, - 0xed2: 0x4000, 0xed3: 0x4000, 0xed4: 0x4000, 0xed5: 0x4000, 0xed6: 0x4000, 0xed7: 0x4000, - 0xed8: 0x4000, 0xed9: 0x4000, 0xeda: 0x4000, 0xedb: 0x4000, 0xedc: 0x4000, 0xedd: 0x4000, - 0xede: 0x4000, 0xedf: 0x4000, 0xee0: 0x4000, 0xee1: 0x4000, 0xee2: 0x4000, 0xee3: 0x4000, - 0xee4: 0x4000, 0xee5: 0x4000, 0xee6: 0x4000, 0xee7: 0x4000, 0xee8: 0x4000, 0xee9: 0x4000, - 0xeea: 0x4000, 0xeeb: 0x4000, 0xeec: 0x4000, 0xeed: 0x4000, 0xeee: 0x4000, 0xeef: 0x4000, - 0xef0: 0x4000, 0xef1: 0x4000, 0xef2: 0x4000, 0xef3: 0x4000, 0xef4: 0x4000, 0xef5: 0x4000, - 0xef6: 0x4000, 0xef7: 0x4000, 0xef8: 0x4000, 0xef9: 0x4000, 0xefa: 0x4000, 0xefb: 0x4000, - 0xefc: 0x4000, 0xefd: 0x4000, 0xefe: 0x4000, 0xeff: 0x4000, - // Block 0x3c, offset 0xf00 - 0xf00: 0x4000, 0xf01: 0x4000, 0xf02: 0x4000, 0xf03: 0x4000, 0xf04: 0x4000, 0xf05: 0x4000, - 0xf06: 0x4000, 0xf07: 0x4000, 0xf08: 0x4000, 0xf09: 0x4000, 0xf0a: 0x4000, 0xf0b: 0x4000, - 0xf0c: 0x4000, 0xf0d: 0x4000, 0xf0e: 0x4000, 0xf0f: 0x4000, 0xf10: 0x4000, 0xf11: 0x4000, - 0xf12: 0x4000, 0xf13: 0x4000, 0xf14: 0x4000, 0xf15: 0x4000, 0xf16: 0x4000, 0xf17: 0x4000, - 0xf18: 0x4000, 0xf19: 0x4000, 0xf1a: 0x4000, 0xf1b: 0x4000, 0xf1c: 0x4000, 0xf1d: 0x4000, - 0xf1e: 0x4000, 0xf1f: 0x4000, 0xf20: 0x4000, 0xf21: 0x4000, 0xf22: 0x4000, 0xf23: 0x4000, - 0xf24: 0x4000, 0xf25: 0x4000, 0xf26: 0x4000, 0xf27: 0x4000, 0xf28: 0x4000, 0xf29: 0x4000, - 0xf2a: 0x4000, 0xf2b: 0x4000, 0xf2c: 0x4000, 0xf2d: 0x4000, 0xf2e: 0x4000, 0xf2f: 0x4000, - 0xf30: 0x4000, 0xf31: 0x4000, 0xf32: 0x4000, 0xf33: 0x4000, 0xf34: 0x4000, 0xf35: 0x4000, - 0xf36: 0x4000, 0xf37: 0x4000, 0xf38: 0x4000, 0xf39: 0x4000, 0xf3a: 0x4000, 0xf3b: 0x4000, - 0xf3c: 0x4000, 0xf3d: 0x4000, 0xf3e: 0x4000, - // Block 0x3d, offset 0xf40 - 0xf40: 0x4000, 0xf41: 0x4000, 0xf42: 0x4000, 0xf43: 0x4000, 0xf44: 0x4000, 0xf45: 0x4000, - 0xf46: 0x4000, 0xf47: 0x4000, 0xf48: 0x4000, 0xf49: 0x4000, 0xf4a: 0x4000, 0xf4b: 0x4000, - 0xf4c: 0x4000, 0xf50: 0x4000, 0xf51: 0x4000, - 0xf52: 0x4000, 0xf53: 0x4000, 0xf54: 0x4000, 0xf55: 0x4000, 0xf56: 0x4000, 0xf57: 0x4000, - 0xf58: 0x4000, 0xf59: 0x4000, 0xf5a: 0x4000, 0xf5b: 0x4000, 0xf5c: 0x4000, 0xf5d: 0x4000, - 0xf5e: 0x4000, 0xf5f: 0x4000, 0xf60: 0x4000, 0xf61: 0x4000, 0xf62: 0x4000, 0xf63: 0x4000, - 0xf64: 0x4000, 0xf65: 0x4000, 0xf66: 0x4000, 0xf67: 0x4000, 0xf68: 0x4000, 0xf69: 0x4000, - 0xf6a: 0x4000, 0xf6b: 0x4000, 0xf6c: 0x4000, 0xf6d: 0x4000, 0xf6e: 0x4000, 0xf6f: 0x4000, - 0xf70: 0x4000, 0xf71: 0x4000, 0xf72: 0x4000, 0xf73: 0x4000, 0xf74: 0x4000, 0xf75: 0x4000, - 0xf76: 0x4000, 0xf77: 0x4000, 0xf78: 0x4000, 0xf79: 0x4000, 0xf7a: 0x4000, 0xf7b: 0x4000, - 0xf7c: 0x4000, 0xf7d: 0x4000, 0xf7e: 0x4000, 0xf7f: 0x4000, - // Block 0x3e, offset 0xf80 - 0xf80: 0x4000, 0xf81: 0x4000, 0xf82: 0x4000, 0xf83: 0x4000, 0xf84: 0x4000, 0xf85: 0x4000, - 0xf86: 0x4000, - // Block 0x3f, offset 0xfc0 - 0xfe0: 0x4000, 0xfe1: 0x4000, 0xfe2: 0x4000, 0xfe3: 0x4000, - 0xfe4: 0x4000, 0xfe5: 0x4000, 0xfe6: 0x4000, 0xfe7: 0x4000, 0xfe8: 0x4000, 0xfe9: 0x4000, - 0xfea: 0x4000, 0xfeb: 0x4000, 0xfec: 0x4000, 0xfed: 0x4000, 0xfee: 0x4000, 0xfef: 0x4000, - 0xff0: 0x4000, 0xff1: 0x4000, 0xff2: 0x4000, 0xff3: 0x4000, 0xff4: 0x4000, 0xff5: 0x4000, - 0xff6: 0x4000, 0xff7: 0x4000, 0xff8: 0x4000, 0xff9: 0x4000, 0xffa: 0x4000, 0xffb: 0x4000, - 0xffc: 0x4000, - // Block 0x40, offset 0x1000 - 0x1000: 0x4000, 0x1001: 0x4000, 0x1002: 0x4000, 0x1003: 0x4000, 0x1004: 0x4000, 0x1005: 0x4000, - 0x1006: 0x4000, 0x1007: 0x4000, 0x1008: 0x4000, 0x1009: 0x4000, 0x100a: 0x4000, 0x100b: 0x4000, - 0x100c: 0x4000, 0x100d: 0x4000, 0x100e: 0x4000, 0x100f: 0x4000, 0x1010: 0x4000, 0x1011: 0x4000, - 0x1012: 0x4000, 0x1013: 0x4000, 0x1014: 0x4000, 0x1015: 0x4000, 0x1016: 0x4000, 0x1017: 0x4000, - 0x1018: 0x4000, 0x1019: 0x4000, 0x101a: 0x4000, 0x101b: 0x4000, 0x101c: 0x4000, 0x101d: 0x4000, - 0x101e: 0x4000, 0x101f: 0x4000, 0x1020: 0x4000, 0x1021: 0x4000, 0x1022: 0x4000, 0x1023: 0x4000, - // Block 0x41, offset 0x1040 - 0x1040: 0x2000, 0x1041: 0x2000, 0x1042: 0x2000, 0x1043: 0x2000, 0x1044: 0x2000, 0x1045: 0x2000, - 0x1046: 0x2000, 0x1047: 0x2000, 0x1048: 0x2000, 0x1049: 0x2000, 0x104a: 0x2000, 0x104b: 0x2000, - 0x104c: 0x2000, 0x104d: 0x2000, 0x104e: 0x2000, 0x104f: 0x2000, 0x1050: 0x4000, 0x1051: 0x4000, - 0x1052: 0x4000, 0x1053: 0x4000, 0x1054: 0x4000, 0x1055: 0x4000, 0x1056: 0x4000, 0x1057: 0x4000, - 0x1058: 0x4000, 0x1059: 0x4000, - 0x1070: 0x4000, 0x1071: 0x4000, 0x1072: 0x4000, 0x1073: 0x4000, 0x1074: 0x4000, 0x1075: 0x4000, - 0x1076: 0x4000, 0x1077: 0x4000, 0x1078: 0x4000, 0x1079: 0x4000, 0x107a: 0x4000, 0x107b: 0x4000, - 0x107c: 0x4000, 0x107d: 0x4000, 0x107e: 0x4000, 0x107f: 0x4000, - // Block 0x42, offset 0x1080 - 0x1080: 0x4000, 0x1081: 0x4000, 0x1082: 0x4000, 0x1083: 0x4000, 0x1084: 0x4000, 0x1085: 0x4000, - 0x1086: 0x4000, 0x1087: 0x4000, 0x1088: 0x4000, 0x1089: 0x4000, 0x108a: 0x4000, 0x108b: 0x4000, - 0x108c: 0x4000, 0x108d: 0x4000, 0x108e: 0x4000, 0x108f: 0x4000, 0x1090: 0x4000, 0x1091: 0x4000, - 0x1092: 0x4000, 0x1094: 0x4000, 0x1095: 0x4000, 0x1096: 0x4000, 0x1097: 0x4000, - 0x1098: 0x4000, 0x1099: 0x4000, 0x109a: 0x4000, 0x109b: 0x4000, 0x109c: 0x4000, 0x109d: 0x4000, - 0x109e: 0x4000, 0x109f: 0x4000, 0x10a0: 0x4000, 0x10a1: 0x4000, 0x10a2: 0x4000, 0x10a3: 0x4000, - 0x10a4: 0x4000, 0x10a5: 0x4000, 0x10a6: 0x4000, 0x10a8: 0x4000, 0x10a9: 0x4000, - 0x10aa: 0x4000, 0x10ab: 0x4000, - // Block 0x43, offset 0x10c0 - 0x10c1: 0x9012, 0x10c2: 0x9012, 0x10c3: 0x9012, 0x10c4: 0x9012, 0x10c5: 0x9012, - 0x10c6: 0x9012, 0x10c7: 0x9012, 0x10c8: 0x9012, 0x10c9: 0x9012, 0x10ca: 0x9012, 0x10cb: 0x9012, - 0x10cc: 0x9012, 0x10cd: 0x9012, 0x10ce: 0x9012, 0x10cf: 0x9012, 0x10d0: 0x9012, 0x10d1: 0x9012, - 0x10d2: 0x9012, 0x10d3: 0x9012, 0x10d4: 0x9012, 0x10d5: 0x9012, 0x10d6: 0x9012, 0x10d7: 0x9012, - 0x10d8: 0x9012, 0x10d9: 0x9012, 0x10da: 0x9012, 0x10db: 0x9012, 0x10dc: 0x9012, 0x10dd: 0x9012, - 0x10de: 0x9012, 0x10df: 0x9012, 0x10e0: 0x9049, 0x10e1: 0x9049, 0x10e2: 0x9049, 0x10e3: 0x9049, - 0x10e4: 0x9049, 0x10e5: 0x9049, 0x10e6: 0x9049, 0x10e7: 0x9049, 0x10e8: 0x9049, 0x10e9: 0x9049, - 0x10ea: 0x9049, 0x10eb: 0x9049, 0x10ec: 0x9049, 0x10ed: 0x9049, 0x10ee: 0x9049, 0x10ef: 0x9049, - 0x10f0: 0x9049, 0x10f1: 0x9049, 0x10f2: 0x9049, 0x10f3: 0x9049, 0x10f4: 0x9049, 0x10f5: 0x9049, - 0x10f6: 0x9049, 0x10f7: 0x9049, 0x10f8: 0x9049, 0x10f9: 0x9049, 0x10fa: 0x9049, 0x10fb: 0x9049, - 0x10fc: 0x9049, 0x10fd: 0x9049, 0x10fe: 0x9049, 0x10ff: 0x9049, - // Block 0x44, offset 0x1100 - 0x1100: 0x9049, 0x1101: 0x9049, 0x1102: 0x9049, 0x1103: 0x9049, 0x1104: 0x9049, 0x1105: 0x9049, - 0x1106: 0x9049, 0x1107: 0x9049, 0x1108: 0x9049, 0x1109: 0x9049, 0x110a: 0x9049, 0x110b: 0x9049, - 0x110c: 0x9049, 0x110d: 0x9049, 0x110e: 0x9049, 0x110f: 0x9049, 0x1110: 0x9049, 0x1111: 0x9049, - 0x1112: 0x9049, 0x1113: 0x9049, 0x1114: 0x9049, 0x1115: 0x9049, 0x1116: 0x9049, 0x1117: 0x9049, - 0x1118: 0x9049, 0x1119: 0x9049, 0x111a: 0x9049, 0x111b: 0x9049, 0x111c: 0x9049, 0x111d: 0x9049, - 0x111e: 0x9049, 0x111f: 0x904a, 0x1120: 0x904b, 0x1121: 0xb04c, 0x1122: 0xb04d, 0x1123: 0xb04d, - 0x1124: 0xb04e, 0x1125: 0xb04f, 0x1126: 0xb050, 0x1127: 0xb051, 0x1128: 0xb052, 0x1129: 0xb053, - 0x112a: 0xb054, 0x112b: 0xb055, 0x112c: 0xb056, 0x112d: 0xb057, 0x112e: 0xb058, 0x112f: 0xb059, - 0x1130: 0xb05a, 0x1131: 0xb05b, 0x1132: 0xb05c, 0x1133: 0xb05d, 0x1134: 0xb05e, 0x1135: 0xb05f, - 0x1136: 0xb060, 0x1137: 0xb061, 0x1138: 0xb062, 0x1139: 0xb063, 0x113a: 0xb064, 0x113b: 0xb065, - 0x113c: 0xb052, 0x113d: 0xb066, 0x113e: 0xb067, 0x113f: 0xb055, - // Block 0x45, offset 0x1140 - 0x1140: 0xb068, 0x1141: 0xb069, 0x1142: 0xb06a, 0x1143: 0xb06b, 0x1144: 0xb05a, 0x1145: 0xb056, - 0x1146: 0xb06c, 0x1147: 0xb06d, 0x1148: 0xb06b, 0x1149: 0xb06e, 0x114a: 0xb06b, 0x114b: 0xb06f, - 0x114c: 0xb06f, 0x114d: 0xb070, 0x114e: 0xb070, 0x114f: 0xb071, 0x1150: 0xb056, 0x1151: 0xb072, - 0x1152: 0xb073, 0x1153: 0xb072, 0x1154: 0xb074, 0x1155: 0xb073, 0x1156: 0xb075, 0x1157: 0xb075, - 0x1158: 0xb076, 0x1159: 0xb076, 0x115a: 0xb077, 0x115b: 0xb077, 0x115c: 0xb073, 0x115d: 0xb078, - 0x115e: 0xb079, 0x115f: 0xb067, 0x1160: 0xb07a, 0x1161: 0xb07b, 0x1162: 0xb07b, 0x1163: 0xb07b, - 0x1164: 0xb07b, 0x1165: 0xb07b, 0x1166: 0xb07b, 0x1167: 0xb07b, 0x1168: 0xb07b, 0x1169: 0xb07b, - 0x116a: 0xb07b, 0x116b: 0xb07b, 0x116c: 0xb07b, 0x116d: 0xb07b, 0x116e: 0xb07b, 0x116f: 0xb07b, - 0x1170: 0xb07c, 0x1171: 0xb07c, 0x1172: 0xb07c, 0x1173: 0xb07c, 0x1174: 0xb07c, 0x1175: 0xb07c, - 0x1176: 0xb07c, 0x1177: 0xb07c, 0x1178: 0xb07c, 0x1179: 0xb07c, 0x117a: 0xb07c, 0x117b: 0xb07c, - 0x117c: 0xb07c, 0x117d: 0xb07c, 0x117e: 0xb07c, - // Block 0x46, offset 0x1180 - 0x1182: 0xb07d, 0x1183: 0xb07e, 0x1184: 0xb07f, 0x1185: 0xb080, - 0x1186: 0xb07f, 0x1187: 0xb07e, 0x118a: 0xb081, 0x118b: 0xb082, - 0x118c: 0xb083, 0x118d: 0xb07f, 0x118e: 0xb080, 0x118f: 0xb07f, - 0x1192: 0xb084, 0x1193: 0xb085, 0x1194: 0xb084, 0x1195: 0xb086, 0x1196: 0xb084, 0x1197: 0xb087, - 0x119a: 0xb088, 0x119b: 0xb089, 0x119c: 0xb08a, - 0x11a0: 0x908b, 0x11a1: 0x908b, 0x11a2: 0x908c, 0x11a3: 0x908d, - 0x11a4: 0x908b, 0x11a5: 0x908e, 0x11a6: 0x908f, 0x11a8: 0xb090, 0x11a9: 0xb091, - 0x11aa: 0xb092, 0x11ab: 0xb091, 0x11ac: 0xb093, 0x11ad: 0xb094, 0x11ae: 0xb095, - 0x11bd: 0x2000, - // Block 0x47, offset 0x11c0 - 0x11e0: 0x4000, - // Block 0x48, offset 0x1200 - 0x1200: 0x4000, 0x1201: 0x4000, 0x1202: 0x4000, 0x1203: 0x4000, 0x1204: 0x4000, 0x1205: 0x4000, - 0x1206: 0x4000, 0x1207: 0x4000, 0x1208: 0x4000, 0x1209: 0x4000, 0x120a: 0x4000, 0x120b: 0x4000, - 0x120c: 0x4000, 0x120d: 0x4000, 0x120e: 0x4000, 0x120f: 0x4000, 0x1210: 0x4000, 0x1211: 0x4000, - 0x1212: 0x4000, 0x1213: 0x4000, 0x1214: 0x4000, 0x1215: 0x4000, 0x1216: 0x4000, 0x1217: 0x4000, - 0x1218: 0x4000, 0x1219: 0x4000, 0x121a: 0x4000, 0x121b: 0x4000, 0x121c: 0x4000, 0x121d: 0x4000, - 0x121e: 0x4000, 0x121f: 0x4000, 0x1220: 0x4000, 0x1221: 0x4000, 0x1222: 0x4000, 0x1223: 0x4000, - 0x1224: 0x4000, 0x1225: 0x4000, 0x1226: 0x4000, 0x1227: 0x4000, 0x1228: 0x4000, 0x1229: 0x4000, - 0x122a: 0x4000, 0x122b: 0x4000, 0x122c: 0x4000, - // Block 0x49, offset 0x1240 - 0x1240: 0x4000, 0x1241: 0x4000, 0x1242: 0x4000, 0x1243: 0x4000, 0x1244: 0x4000, 0x1245: 0x4000, - 0x1246: 0x4000, 0x1247: 0x4000, 0x1248: 0x4000, 0x1249: 0x4000, 0x124a: 0x4000, 0x124b: 0x4000, - 0x124c: 0x4000, 0x124d: 0x4000, 0x124e: 0x4000, 0x124f: 0x4000, 0x1250: 0x4000, 0x1251: 0x4000, - 0x1252: 0x4000, 0x1253: 0x4000, 0x1254: 0x4000, 0x1255: 0x4000, 0x1256: 0x4000, 0x1257: 0x4000, - 0x1258: 0x4000, 0x1259: 0x4000, 0x125a: 0x4000, 0x125b: 0x4000, 0x125c: 0x4000, 0x125d: 0x4000, - 0x125e: 0x4000, 0x125f: 0x4000, 0x1260: 0x4000, 0x1261: 0x4000, 0x1262: 0x4000, 0x1263: 0x4000, - 0x1264: 0x4000, 0x1265: 0x4000, 0x1266: 0x4000, 0x1267: 0x4000, 0x1268: 0x4000, 0x1269: 0x4000, - 0x126a: 0x4000, 0x126b: 0x4000, 0x126c: 0x4000, 0x126d: 0x4000, 0x126e: 0x4000, 0x126f: 0x4000, - 0x1270: 0x4000, 0x1271: 0x4000, 0x1272: 0x4000, - // Block 0x4a, offset 0x1280 - 0x1280: 0x4000, 0x1281: 0x4000, - // Block 0x4b, offset 0x12c0 - 0x12c4: 0x4000, - // Block 0x4c, offset 0x1300 - 0x130f: 0x4000, - // Block 0x4d, offset 0x1340 - 0x1340: 0x2000, 0x1341: 0x2000, 0x1342: 0x2000, 0x1343: 0x2000, 0x1344: 0x2000, 0x1345: 0x2000, - 0x1346: 0x2000, 0x1347: 0x2000, 0x1348: 0x2000, 0x1349: 0x2000, 0x134a: 0x2000, - 0x1350: 0x2000, 0x1351: 0x2000, - 0x1352: 0x2000, 0x1353: 0x2000, 0x1354: 0x2000, 0x1355: 0x2000, 0x1356: 0x2000, 0x1357: 0x2000, - 0x1358: 0x2000, 0x1359: 0x2000, 0x135a: 0x2000, 0x135b: 0x2000, 0x135c: 0x2000, 0x135d: 0x2000, - 0x135e: 0x2000, 0x135f: 0x2000, 0x1360: 0x2000, 0x1361: 0x2000, 0x1362: 0x2000, 0x1363: 0x2000, - 0x1364: 0x2000, 0x1365: 0x2000, 0x1366: 0x2000, 0x1367: 0x2000, 0x1368: 0x2000, 0x1369: 0x2000, - 0x136a: 0x2000, 0x136b: 0x2000, 0x136c: 0x2000, 0x136d: 0x2000, - 0x1370: 0x2000, 0x1371: 0x2000, 0x1372: 0x2000, 0x1373: 0x2000, 0x1374: 0x2000, 0x1375: 0x2000, - 0x1376: 0x2000, 0x1377: 0x2000, 0x1378: 0x2000, 0x1379: 0x2000, 0x137a: 0x2000, 0x137b: 0x2000, - 0x137c: 0x2000, 0x137d: 0x2000, 0x137e: 0x2000, 0x137f: 0x2000, - // Block 0x4e, offset 0x1380 - 0x1380: 0x2000, 0x1381: 0x2000, 0x1382: 0x2000, 0x1383: 0x2000, 0x1384: 0x2000, 0x1385: 0x2000, - 0x1386: 0x2000, 0x1387: 0x2000, 0x1388: 0x2000, 0x1389: 0x2000, 0x138a: 0x2000, 0x138b: 0x2000, - 0x138c: 0x2000, 0x138d: 0x2000, 0x138e: 0x2000, 0x138f: 0x2000, 0x1390: 0x2000, 0x1391: 0x2000, - 0x1392: 0x2000, 0x1393: 0x2000, 0x1394: 0x2000, 0x1395: 0x2000, 0x1396: 0x2000, 0x1397: 0x2000, - 0x1398: 0x2000, 0x1399: 0x2000, 0x139a: 0x2000, 0x139b: 0x2000, 0x139c: 0x2000, 0x139d: 0x2000, - 0x139e: 0x2000, 0x139f: 0x2000, 0x13a0: 0x2000, 0x13a1: 0x2000, 0x13a2: 0x2000, 0x13a3: 0x2000, - 0x13a4: 0x2000, 0x13a5: 0x2000, 0x13a6: 0x2000, 0x13a7: 0x2000, 0x13a8: 0x2000, 0x13a9: 0x2000, - 0x13b0: 0x2000, 0x13b1: 0x2000, 0x13b2: 0x2000, 0x13b3: 0x2000, 0x13b4: 0x2000, 0x13b5: 0x2000, - 0x13b6: 0x2000, 0x13b7: 0x2000, 0x13b8: 0x2000, 0x13b9: 0x2000, 0x13ba: 0x2000, 0x13bb: 0x2000, - 0x13bc: 0x2000, 0x13bd: 0x2000, 0x13be: 0x2000, 0x13bf: 0x2000, - // Block 0x4f, offset 0x13c0 - 0x13c0: 0x2000, 0x13c1: 0x2000, 0x13c2: 0x2000, 0x13c3: 0x2000, 0x13c4: 0x2000, 0x13c5: 0x2000, - 0x13c6: 0x2000, 0x13c7: 0x2000, 0x13c8: 0x2000, 0x13c9: 0x2000, 0x13ca: 0x2000, 0x13cb: 0x2000, - 0x13cc: 0x2000, 0x13cd: 0x2000, 0x13ce: 0x4000, 0x13cf: 0x2000, 0x13d0: 0x2000, 0x13d1: 0x4000, - 0x13d2: 0x4000, 0x13d3: 0x4000, 0x13d4: 0x4000, 0x13d5: 0x4000, 0x13d6: 0x4000, 0x13d7: 0x4000, - 0x13d8: 0x4000, 0x13d9: 0x4000, 0x13da: 0x4000, 0x13db: 0x2000, 0x13dc: 0x2000, 0x13dd: 0x2000, - 0x13de: 0x2000, 0x13df: 0x2000, 0x13e0: 0x2000, 0x13e1: 0x2000, 0x13e2: 0x2000, 0x13e3: 0x2000, - 0x13e4: 0x2000, 0x13e5: 0x2000, 0x13e6: 0x2000, 0x13e7: 0x2000, 0x13e8: 0x2000, 0x13e9: 0x2000, - 0x13ea: 0x2000, 0x13eb: 0x2000, 0x13ec: 0x2000, - // Block 0x50, offset 0x1400 - 0x1400: 0x4000, 0x1401: 0x4000, 0x1402: 0x4000, - 0x1410: 0x4000, 0x1411: 0x4000, - 0x1412: 0x4000, 0x1413: 0x4000, 0x1414: 0x4000, 0x1415: 0x4000, 0x1416: 0x4000, 0x1417: 0x4000, - 0x1418: 0x4000, 0x1419: 0x4000, 0x141a: 0x4000, 0x141b: 0x4000, 0x141c: 0x4000, 0x141d: 0x4000, - 0x141e: 0x4000, 0x141f: 0x4000, 0x1420: 0x4000, 0x1421: 0x4000, 0x1422: 0x4000, 0x1423: 0x4000, - 0x1424: 0x4000, 0x1425: 0x4000, 0x1426: 0x4000, 0x1427: 0x4000, 0x1428: 0x4000, 0x1429: 0x4000, - 0x142a: 0x4000, 0x142b: 0x4000, 0x142c: 0x4000, 0x142d: 0x4000, 0x142e: 0x4000, 0x142f: 0x4000, - 0x1430: 0x4000, 0x1431: 0x4000, 0x1432: 0x4000, 0x1433: 0x4000, 0x1434: 0x4000, 0x1435: 0x4000, - 0x1436: 0x4000, 0x1437: 0x4000, 0x1438: 0x4000, 0x1439: 0x4000, 0x143a: 0x4000, 0x143b: 0x4000, - // Block 0x51, offset 0x1440 - 0x1440: 0x4000, 0x1441: 0x4000, 0x1442: 0x4000, 0x1443: 0x4000, 0x1444: 0x4000, 0x1445: 0x4000, - 0x1446: 0x4000, 0x1447: 0x4000, 0x1448: 0x4000, - 0x1450: 0x4000, 0x1451: 0x4000, - // Block 0x52, offset 0x1480 - 0x1480: 0x4000, 0x1481: 0x4000, 0x1482: 0x4000, 0x1483: 0x4000, 0x1484: 0x4000, 0x1485: 0x4000, - 0x1486: 0x4000, 0x1487: 0x4000, 0x1488: 0x4000, 0x1489: 0x4000, 0x148a: 0x4000, 0x148b: 0x4000, - 0x148c: 0x4000, 0x148d: 0x4000, 0x148e: 0x4000, 0x148f: 0x4000, 0x1490: 0x4000, 0x1491: 0x4000, - 0x1492: 0x4000, 0x1493: 0x4000, 0x1494: 0x4000, 0x1495: 0x4000, 0x1496: 0x4000, 0x1497: 0x4000, - 0x1498: 0x4000, 0x1499: 0x4000, 0x149a: 0x4000, 0x149b: 0x4000, 0x149c: 0x4000, 0x149d: 0x4000, - 0x149e: 0x4000, 0x149f: 0x4000, 0x14a0: 0x4000, - 0x14ad: 0x4000, 0x14ae: 0x4000, 0x14af: 0x4000, - 0x14b0: 0x4000, 0x14b1: 0x4000, 0x14b2: 0x4000, 0x14b3: 0x4000, 0x14b4: 0x4000, 0x14b5: 0x4000, - 0x14b7: 0x4000, 0x14b8: 0x4000, 0x14b9: 0x4000, 0x14ba: 0x4000, 0x14bb: 0x4000, - 0x14bc: 0x4000, 0x14bd: 0x4000, 0x14be: 0x4000, 0x14bf: 0x4000, - // Block 0x53, offset 0x14c0 - 0x14c0: 0x4000, 0x14c1: 0x4000, 0x14c2: 0x4000, 0x14c3: 0x4000, 0x14c4: 0x4000, 0x14c5: 0x4000, - 0x14c6: 0x4000, 0x14c7: 0x4000, 0x14c8: 0x4000, 0x14c9: 0x4000, 0x14ca: 0x4000, 0x14cb: 0x4000, - 0x14cc: 0x4000, 0x14cd: 0x4000, 0x14ce: 0x4000, 0x14cf: 0x4000, 0x14d0: 0x4000, 0x14d1: 0x4000, - 0x14d2: 0x4000, 0x14d3: 0x4000, 0x14d4: 0x4000, 0x14d5: 0x4000, 0x14d6: 0x4000, 0x14d7: 0x4000, - 0x14d8: 0x4000, 0x14d9: 0x4000, 0x14da: 0x4000, 0x14db: 0x4000, 0x14dc: 0x4000, 0x14dd: 0x4000, - 0x14de: 0x4000, 0x14df: 0x4000, 0x14e0: 0x4000, 0x14e1: 0x4000, 0x14e2: 0x4000, 0x14e3: 0x4000, - 0x14e4: 0x4000, 0x14e5: 0x4000, 0x14e6: 0x4000, 0x14e7: 0x4000, 0x14e8: 0x4000, 0x14e9: 0x4000, - 0x14ea: 0x4000, 0x14eb: 0x4000, 0x14ec: 0x4000, 0x14ed: 0x4000, 0x14ee: 0x4000, 0x14ef: 0x4000, - 0x14f0: 0x4000, 0x14f1: 0x4000, 0x14f2: 0x4000, 0x14f3: 0x4000, 0x14f4: 0x4000, 0x14f5: 0x4000, - 0x14f6: 0x4000, 0x14f7: 0x4000, 0x14f8: 0x4000, 0x14f9: 0x4000, 0x14fa: 0x4000, 0x14fb: 0x4000, - 0x14fc: 0x4000, 0x14fe: 0x4000, 0x14ff: 0x4000, - // Block 0x54, offset 0x1500 - 0x1500: 0x4000, 0x1501: 0x4000, 0x1502: 0x4000, 0x1503: 0x4000, 0x1504: 0x4000, 0x1505: 0x4000, - 0x1506: 0x4000, 0x1507: 0x4000, 0x1508: 0x4000, 0x1509: 0x4000, 0x150a: 0x4000, 0x150b: 0x4000, - 0x150c: 0x4000, 0x150d: 0x4000, 0x150e: 0x4000, 0x150f: 0x4000, 0x1510: 0x4000, 0x1511: 0x4000, - 0x1512: 0x4000, 0x1513: 0x4000, - 0x1520: 0x4000, 0x1521: 0x4000, 0x1522: 0x4000, 0x1523: 0x4000, - 0x1524: 0x4000, 0x1525: 0x4000, 0x1526: 0x4000, 0x1527: 0x4000, 0x1528: 0x4000, 0x1529: 0x4000, - 0x152a: 0x4000, 0x152b: 0x4000, 0x152c: 0x4000, 0x152d: 0x4000, 0x152e: 0x4000, 0x152f: 0x4000, - 0x1530: 0x4000, 0x1531: 0x4000, 0x1532: 0x4000, 0x1533: 0x4000, 0x1534: 0x4000, 0x1535: 0x4000, - 0x1536: 0x4000, 0x1537: 0x4000, 0x1538: 0x4000, 0x1539: 0x4000, 0x153a: 0x4000, 0x153b: 0x4000, - 0x153c: 0x4000, 0x153d: 0x4000, 0x153e: 0x4000, 0x153f: 0x4000, - // Block 0x55, offset 0x1540 - 0x1540: 0x4000, 0x1541: 0x4000, 0x1542: 0x4000, 0x1543: 0x4000, 0x1544: 0x4000, 0x1545: 0x4000, - 0x1546: 0x4000, 0x1547: 0x4000, 0x1548: 0x4000, 0x1549: 0x4000, 0x154a: 0x4000, - 0x154f: 0x4000, 0x1550: 0x4000, 0x1551: 0x4000, - 0x1552: 0x4000, 0x1553: 0x4000, - 0x1560: 0x4000, 0x1561: 0x4000, 0x1562: 0x4000, 0x1563: 0x4000, - 0x1564: 0x4000, 0x1565: 0x4000, 0x1566: 0x4000, 0x1567: 0x4000, 0x1568: 0x4000, 0x1569: 0x4000, - 0x156a: 0x4000, 0x156b: 0x4000, 0x156c: 0x4000, 0x156d: 0x4000, 0x156e: 0x4000, 0x156f: 0x4000, - 0x1570: 0x4000, 0x1574: 0x4000, - 0x1578: 0x4000, 0x1579: 0x4000, 0x157a: 0x4000, 0x157b: 0x4000, - 0x157c: 0x4000, 0x157d: 0x4000, 0x157e: 0x4000, 0x157f: 0x4000, - // Block 0x56, offset 0x1580 - 0x1580: 0x4000, 0x1582: 0x4000, 0x1583: 0x4000, 0x1584: 0x4000, 0x1585: 0x4000, - 0x1586: 0x4000, 0x1587: 0x4000, 0x1588: 0x4000, 0x1589: 0x4000, 0x158a: 0x4000, 0x158b: 0x4000, - 0x158c: 0x4000, 0x158d: 0x4000, 0x158e: 0x4000, 0x158f: 0x4000, 0x1590: 0x4000, 0x1591: 0x4000, - 0x1592: 0x4000, 0x1593: 0x4000, 0x1594: 0x4000, 0x1595: 0x4000, 0x1596: 0x4000, 0x1597: 0x4000, - 0x1598: 0x4000, 0x1599: 0x4000, 0x159a: 0x4000, 0x159b: 0x4000, 0x159c: 0x4000, 0x159d: 0x4000, - 0x159e: 0x4000, 0x159f: 0x4000, 0x15a0: 0x4000, 0x15a1: 0x4000, 0x15a2: 0x4000, 0x15a3: 0x4000, - 0x15a4: 0x4000, 0x15a5: 0x4000, 0x15a6: 0x4000, 0x15a7: 0x4000, 0x15a8: 0x4000, 0x15a9: 0x4000, - 0x15aa: 0x4000, 0x15ab: 0x4000, 0x15ac: 0x4000, 0x15ad: 0x4000, 0x15ae: 0x4000, 0x15af: 0x4000, - 0x15b0: 0x4000, 0x15b1: 0x4000, 0x15b2: 0x4000, 0x15b3: 0x4000, 0x15b4: 0x4000, 0x15b5: 0x4000, - 0x15b6: 0x4000, 0x15b7: 0x4000, 0x15b8: 0x4000, 0x15b9: 0x4000, 0x15ba: 0x4000, 0x15bb: 0x4000, - 0x15bc: 0x4000, 0x15bd: 0x4000, 0x15be: 0x4000, 0x15bf: 0x4000, - // Block 0x57, offset 0x15c0 - 0x15c0: 0x4000, 0x15c1: 0x4000, 0x15c2: 0x4000, 0x15c3: 0x4000, 0x15c4: 0x4000, 0x15c5: 0x4000, - 0x15c6: 0x4000, 0x15c7: 0x4000, 0x15c8: 0x4000, 0x15c9: 0x4000, 0x15ca: 0x4000, 0x15cb: 0x4000, - 0x15cc: 0x4000, 0x15cd: 0x4000, 0x15ce: 0x4000, 0x15cf: 0x4000, 0x15d0: 0x4000, 0x15d1: 0x4000, - 0x15d2: 0x4000, 0x15d3: 0x4000, 0x15d4: 0x4000, 0x15d5: 0x4000, 0x15d6: 0x4000, 0x15d7: 0x4000, - 0x15d8: 0x4000, 0x15d9: 0x4000, 0x15da: 0x4000, 0x15db: 0x4000, 0x15dc: 0x4000, 0x15dd: 0x4000, - 0x15de: 0x4000, 0x15df: 0x4000, 0x15e0: 0x4000, 0x15e1: 0x4000, 0x15e2: 0x4000, 0x15e3: 0x4000, - 0x15e4: 0x4000, 0x15e5: 0x4000, 0x15e6: 0x4000, 0x15e7: 0x4000, 0x15e8: 0x4000, 0x15e9: 0x4000, - 0x15ea: 0x4000, 0x15eb: 0x4000, 0x15ec: 0x4000, 0x15ed: 0x4000, 0x15ee: 0x4000, 0x15ef: 0x4000, - 0x15f0: 0x4000, 0x15f1: 0x4000, 0x15f2: 0x4000, 0x15f3: 0x4000, 0x15f4: 0x4000, 0x15f5: 0x4000, - 0x15f6: 0x4000, 0x15f7: 0x4000, 0x15f8: 0x4000, 0x15f9: 0x4000, 0x15fa: 0x4000, 0x15fb: 0x4000, - 0x15fc: 0x4000, 0x15ff: 0x4000, - // Block 0x58, offset 0x1600 - 0x1600: 0x4000, 0x1601: 0x4000, 0x1602: 0x4000, 0x1603: 0x4000, 0x1604: 0x4000, 0x1605: 0x4000, - 0x1606: 0x4000, 0x1607: 0x4000, 0x1608: 0x4000, 0x1609: 0x4000, 0x160a: 0x4000, 0x160b: 0x4000, - 0x160c: 0x4000, 0x160d: 0x4000, 0x160e: 0x4000, 0x160f: 0x4000, 0x1610: 0x4000, 0x1611: 0x4000, - 0x1612: 0x4000, 0x1613: 0x4000, 0x1614: 0x4000, 0x1615: 0x4000, 0x1616: 0x4000, 0x1617: 0x4000, - 0x1618: 0x4000, 0x1619: 0x4000, 0x161a: 0x4000, 0x161b: 0x4000, 0x161c: 0x4000, 0x161d: 0x4000, - 0x161e: 0x4000, 0x161f: 0x4000, 0x1620: 0x4000, 0x1621: 0x4000, 0x1622: 0x4000, 0x1623: 0x4000, - 0x1624: 0x4000, 0x1625: 0x4000, 0x1626: 0x4000, 0x1627: 0x4000, 0x1628: 0x4000, 0x1629: 0x4000, - 0x162a: 0x4000, 0x162b: 0x4000, 0x162c: 0x4000, 0x162d: 0x4000, 0x162e: 0x4000, 0x162f: 0x4000, - 0x1630: 0x4000, 0x1631: 0x4000, 0x1632: 0x4000, 0x1633: 0x4000, 0x1634: 0x4000, 0x1635: 0x4000, - 0x1636: 0x4000, 0x1637: 0x4000, 0x1638: 0x4000, 0x1639: 0x4000, 0x163a: 0x4000, 0x163b: 0x4000, - 0x163c: 0x4000, 0x163d: 0x4000, - // Block 0x59, offset 0x1640 - 0x164b: 0x4000, - 0x164c: 0x4000, 0x164d: 0x4000, 0x164e: 0x4000, 0x1650: 0x4000, 0x1651: 0x4000, - 0x1652: 0x4000, 0x1653: 0x4000, 0x1654: 0x4000, 0x1655: 0x4000, 0x1656: 0x4000, 0x1657: 0x4000, - 0x1658: 0x4000, 0x1659: 0x4000, 0x165a: 0x4000, 0x165b: 0x4000, 0x165c: 0x4000, 0x165d: 0x4000, - 0x165e: 0x4000, 0x165f: 0x4000, 0x1660: 0x4000, 0x1661: 0x4000, 0x1662: 0x4000, 0x1663: 0x4000, - 0x1664: 0x4000, 0x1665: 0x4000, 0x1666: 0x4000, 0x1667: 0x4000, - 0x167a: 0x4000, - // Block 0x5a, offset 0x1680 - 0x1695: 0x4000, 0x1696: 0x4000, - 0x16a4: 0x4000, - // Block 0x5b, offset 0x16c0 - 0x16fb: 0x4000, - 0x16fc: 0x4000, 0x16fd: 0x4000, 0x16fe: 0x4000, 0x16ff: 0x4000, - // Block 0x5c, offset 0x1700 - 0x1700: 0x4000, 0x1701: 0x4000, 0x1702: 0x4000, 0x1703: 0x4000, 0x1704: 0x4000, 0x1705: 0x4000, - 0x1706: 0x4000, 0x1707: 0x4000, 0x1708: 0x4000, 0x1709: 0x4000, 0x170a: 0x4000, 0x170b: 0x4000, - 0x170c: 0x4000, 0x170d: 0x4000, 0x170e: 0x4000, 0x170f: 0x4000, - // Block 0x5d, offset 0x1740 - 0x1740: 0x4000, 0x1741: 0x4000, 0x1742: 0x4000, 0x1743: 0x4000, 0x1744: 0x4000, 0x1745: 0x4000, - 0x174c: 0x4000, 0x1750: 0x4000, 0x1751: 0x4000, - 0x1752: 0x4000, - 0x176b: 0x4000, 0x176c: 0x4000, - 0x1774: 0x4000, 0x1775: 0x4000, - 0x1776: 0x4000, - // Block 0x5e, offset 0x1780 - 0x1790: 0x4000, 0x1791: 0x4000, - 0x1792: 0x4000, 0x1793: 0x4000, 0x1794: 0x4000, 0x1795: 0x4000, 0x1796: 0x4000, 0x1797: 0x4000, - 0x1798: 0x4000, 0x1799: 0x4000, 0x179a: 0x4000, 0x179b: 0x4000, 0x179c: 0x4000, 0x179d: 0x4000, - 0x179e: 0x4000, 0x17a0: 0x4000, 0x17a1: 0x4000, 0x17a2: 0x4000, 0x17a3: 0x4000, - 0x17a4: 0x4000, 0x17a5: 0x4000, 0x17a6: 0x4000, 0x17a7: 0x4000, - 0x17b0: 0x4000, 0x17b3: 0x4000, 0x17b4: 0x4000, 0x17b5: 0x4000, - 0x17b6: 0x4000, 0x17b7: 0x4000, 0x17b8: 0x4000, 0x17b9: 0x4000, 0x17ba: 0x4000, 0x17bb: 0x4000, - 0x17bc: 0x4000, 0x17bd: 0x4000, 0x17be: 0x4000, - // Block 0x5f, offset 0x17c0 - 0x17c0: 0x4000, 0x17c1: 0x4000, 0x17c2: 0x4000, 0x17c3: 0x4000, 0x17c4: 0x4000, 0x17c5: 0x4000, - 0x17c6: 0x4000, 0x17c7: 0x4000, 0x17c8: 0x4000, 0x17c9: 0x4000, 0x17ca: 0x4000, 0x17cb: 0x4000, - 0x17d0: 0x4000, 0x17d1: 0x4000, - 0x17d2: 0x4000, 0x17d3: 0x4000, 0x17d4: 0x4000, 0x17d5: 0x4000, 0x17d6: 0x4000, 0x17d7: 0x4000, - 0x17d8: 0x4000, 0x17d9: 0x4000, 0x17da: 0x4000, 0x17db: 0x4000, 0x17dc: 0x4000, 0x17dd: 0x4000, - 0x17de: 0x4000, - // Block 0x60, offset 0x1800 - 0x1800: 0x4000, 0x1801: 0x4000, 0x1802: 0x4000, 0x1803: 0x4000, 0x1804: 0x4000, 0x1805: 0x4000, - 0x1806: 0x4000, 0x1807: 0x4000, 0x1808: 0x4000, 0x1809: 0x4000, 0x180a: 0x4000, 0x180b: 0x4000, - 0x180c: 0x4000, 0x180d: 0x4000, 0x180e: 0x4000, 0x180f: 0x4000, 0x1810: 0x4000, 0x1811: 0x4000, - // Block 0x61, offset 0x1840 - 0x1840: 0x4000, - // Block 0x62, offset 0x1880 - 0x1880: 0x2000, 0x1881: 0x2000, 0x1882: 0x2000, 0x1883: 0x2000, 0x1884: 0x2000, 0x1885: 0x2000, - 0x1886: 0x2000, 0x1887: 0x2000, 0x1888: 0x2000, 0x1889: 0x2000, 0x188a: 0x2000, 0x188b: 0x2000, - 0x188c: 0x2000, 0x188d: 0x2000, 0x188e: 0x2000, 0x188f: 0x2000, 0x1890: 0x2000, 0x1891: 0x2000, - 0x1892: 0x2000, 0x1893: 0x2000, 0x1894: 0x2000, 0x1895: 0x2000, 0x1896: 0x2000, 0x1897: 0x2000, - 0x1898: 0x2000, 0x1899: 0x2000, 0x189a: 0x2000, 0x189b: 0x2000, 0x189c: 0x2000, 0x189d: 0x2000, - 0x189e: 0x2000, 0x189f: 0x2000, 0x18a0: 0x2000, 0x18a1: 0x2000, 0x18a2: 0x2000, 0x18a3: 0x2000, - 0x18a4: 0x2000, 0x18a5: 0x2000, 0x18a6: 0x2000, 0x18a7: 0x2000, 0x18a8: 0x2000, 0x18a9: 0x2000, - 0x18aa: 0x2000, 0x18ab: 0x2000, 0x18ac: 0x2000, 0x18ad: 0x2000, 0x18ae: 0x2000, 0x18af: 0x2000, - 0x18b0: 0x2000, 0x18b1: 0x2000, 0x18b2: 0x2000, 0x18b3: 0x2000, 0x18b4: 0x2000, 0x18b5: 0x2000, - 0x18b6: 0x2000, 0x18b7: 0x2000, 0x18b8: 0x2000, 0x18b9: 0x2000, 0x18ba: 0x2000, 0x18bb: 0x2000, - 0x18bc: 0x2000, 0x18bd: 0x2000, -} - -// widthIndex: 22 blocks, 1408 entries, 1408 bytes -// Block 0 is the zero block. -var widthIndex = [1408]uint8{ - // Block 0x0, offset 0x0 - // Block 0x1, offset 0x40 - // Block 0x2, offset 0x80 - // Block 0x3, offset 0xc0 - 0xc2: 0x01, 0xc3: 0x02, 0xc4: 0x03, 0xc5: 0x04, 0xc7: 0x05, - 0xc9: 0x06, 0xcb: 0x07, 0xcc: 0x08, 0xcd: 0x09, 0xce: 0x0a, 0xcf: 0x0b, - 0xd0: 0x0c, 0xd1: 0x0d, - 0xe1: 0x02, 0xe2: 0x03, 0xe3: 0x04, 0xe4: 0x05, 0xe5: 0x06, 0xe6: 0x06, 0xe7: 0x06, - 0xe8: 0x06, 0xe9: 0x06, 0xea: 0x07, 0xeb: 0x06, 0xec: 0x06, 0xed: 0x08, 0xee: 0x09, 0xef: 0x0a, - 0xf0: 0x0f, 0xf3: 0x12, 0xf4: 0x13, - // Block 0x4, offset 0x100 - 0x104: 0x0e, 0x105: 0x0f, - // Block 0x5, offset 0x140 - 0x140: 0x10, 0x141: 0x11, 0x142: 0x12, 0x144: 0x13, 0x145: 0x14, 0x146: 0x15, 0x147: 0x16, - 0x148: 0x17, 0x149: 0x18, 0x14a: 0x19, 0x14c: 0x1a, 0x14f: 0x1b, - 0x151: 0x1c, 0x152: 0x08, 0x153: 0x1d, 0x154: 0x1e, 0x155: 0x1f, 0x156: 0x20, 0x157: 0x21, - 0x158: 0x22, 0x159: 0x23, 0x15a: 0x24, 0x15b: 0x25, 0x15c: 0x26, 0x15d: 0x27, 0x15e: 0x28, 0x15f: 0x29, - 0x166: 0x2a, - 0x16c: 0x2b, 0x16d: 0x2c, - 0x17a: 0x2d, 0x17b: 0x2e, 0x17c: 0x0e, 0x17d: 0x0e, 0x17e: 0x0e, 0x17f: 0x2f, - // Block 0x6, offset 0x180 - 0x180: 0x30, 0x181: 0x31, 0x182: 0x32, 0x183: 0x33, 0x184: 0x34, 0x185: 0x35, 0x186: 0x36, 0x187: 0x37, - 0x188: 0x38, 0x189: 0x39, 0x18a: 0x0e, 0x18b: 0x3a, 0x18c: 0x0e, 0x18d: 0x0e, 0x18e: 0x0e, 0x18f: 0x0e, - 0x190: 0x0e, 0x191: 0x0e, 0x192: 0x0e, 0x193: 0x0e, 0x194: 0x0e, 0x195: 0x0e, 0x196: 0x0e, 0x197: 0x0e, - 0x198: 0x0e, 0x199: 0x0e, 0x19a: 0x0e, 0x19b: 0x0e, 0x19c: 0x0e, 0x19d: 0x0e, 0x19e: 0x0e, 0x19f: 0x0e, - 0x1a0: 0x0e, 0x1a1: 0x0e, 0x1a2: 0x0e, 0x1a3: 0x0e, 0x1a4: 0x0e, 0x1a5: 0x0e, 0x1a6: 0x0e, 0x1a7: 0x0e, - 0x1a8: 0x0e, 0x1a9: 0x0e, 0x1aa: 0x0e, 0x1ab: 0x0e, 0x1ac: 0x0e, 0x1ad: 0x0e, 0x1ae: 0x0e, 0x1af: 0x0e, - 0x1b0: 0x0e, 0x1b1: 0x0e, 0x1b2: 0x0e, 0x1b3: 0x0e, 0x1b4: 0x0e, 0x1b5: 0x0e, 0x1b6: 0x0e, 0x1b7: 0x0e, - 0x1b8: 0x0e, 0x1b9: 0x0e, 0x1ba: 0x0e, 0x1bb: 0x0e, 0x1bc: 0x0e, 0x1bd: 0x0e, 0x1be: 0x0e, 0x1bf: 0x0e, - // Block 0x7, offset 0x1c0 - 0x1c0: 0x0e, 0x1c1: 0x0e, 0x1c2: 0x0e, 0x1c3: 0x0e, 0x1c4: 0x0e, 0x1c5: 0x0e, 0x1c6: 0x0e, 0x1c7: 0x0e, - 0x1c8: 0x0e, 0x1c9: 0x0e, 0x1ca: 0x0e, 0x1cb: 0x0e, 0x1cc: 0x0e, 0x1cd: 0x0e, 0x1ce: 0x0e, 0x1cf: 0x0e, - 0x1d0: 0x0e, 0x1d1: 0x0e, 0x1d2: 0x0e, 0x1d3: 0x0e, 0x1d4: 0x0e, 0x1d5: 0x0e, 0x1d6: 0x0e, 0x1d7: 0x0e, - 0x1d8: 0x0e, 0x1d9: 0x0e, 0x1da: 0x0e, 0x1db: 0x0e, 0x1dc: 0x0e, 0x1dd: 0x0e, 0x1de: 0x0e, 0x1df: 0x0e, - 0x1e0: 0x0e, 0x1e1: 0x0e, 0x1e2: 0x0e, 0x1e3: 0x0e, 0x1e4: 0x0e, 0x1e5: 0x0e, 0x1e6: 0x0e, 0x1e7: 0x0e, - 0x1e8: 0x0e, 0x1e9: 0x0e, 0x1ea: 0x0e, 0x1eb: 0x0e, 0x1ec: 0x0e, 0x1ed: 0x0e, 0x1ee: 0x0e, 0x1ef: 0x0e, - 0x1f0: 0x0e, 0x1f1: 0x0e, 0x1f2: 0x0e, 0x1f3: 0x0e, 0x1f4: 0x0e, 0x1f5: 0x0e, 0x1f6: 0x0e, - 0x1f8: 0x0e, 0x1f9: 0x0e, 0x1fa: 0x0e, 0x1fb: 0x0e, 0x1fc: 0x0e, 0x1fd: 0x0e, 0x1fe: 0x0e, 0x1ff: 0x0e, - // Block 0x8, offset 0x200 - 0x200: 0x0e, 0x201: 0x0e, 0x202: 0x0e, 0x203: 0x0e, 0x204: 0x0e, 0x205: 0x0e, 0x206: 0x0e, 0x207: 0x0e, - 0x208: 0x0e, 0x209: 0x0e, 0x20a: 0x0e, 0x20b: 0x0e, 0x20c: 0x0e, 0x20d: 0x0e, 0x20e: 0x0e, 0x20f: 0x0e, - 0x210: 0x0e, 0x211: 0x0e, 0x212: 0x0e, 0x213: 0x0e, 0x214: 0x0e, 0x215: 0x0e, 0x216: 0x0e, 0x217: 0x0e, - 0x218: 0x0e, 0x219: 0x0e, 0x21a: 0x0e, 0x21b: 0x0e, 0x21c: 0x0e, 0x21d: 0x0e, 0x21e: 0x0e, 0x21f: 0x0e, - 0x220: 0x0e, 0x221: 0x0e, 0x222: 0x0e, 0x223: 0x0e, 0x224: 0x0e, 0x225: 0x0e, 0x226: 0x0e, 0x227: 0x0e, - 0x228: 0x0e, 0x229: 0x0e, 0x22a: 0x0e, 0x22b: 0x0e, 0x22c: 0x0e, 0x22d: 0x0e, 0x22e: 0x0e, 0x22f: 0x0e, - 0x230: 0x0e, 0x231: 0x0e, 0x232: 0x0e, 0x233: 0x0e, 0x234: 0x0e, 0x235: 0x0e, 0x236: 0x0e, 0x237: 0x0e, - 0x238: 0x0e, 0x239: 0x0e, 0x23a: 0x0e, 0x23b: 0x0e, 0x23c: 0x0e, 0x23d: 0x0e, 0x23e: 0x0e, 0x23f: 0x0e, - // Block 0x9, offset 0x240 - 0x240: 0x0e, 0x241: 0x0e, 0x242: 0x0e, 0x243: 0x0e, 0x244: 0x0e, 0x245: 0x0e, 0x246: 0x0e, 0x247: 0x0e, - 0x248: 0x0e, 0x249: 0x0e, 0x24a: 0x0e, 0x24b: 0x0e, 0x24c: 0x0e, 0x24d: 0x0e, 0x24e: 0x0e, 0x24f: 0x0e, - 0x250: 0x0e, 0x251: 0x0e, 0x252: 0x3b, 0x253: 0x3c, - 0x265: 0x3d, - 0x270: 0x0e, 0x271: 0x0e, 0x272: 0x0e, 0x273: 0x0e, 0x274: 0x0e, 0x275: 0x0e, 0x276: 0x0e, 0x277: 0x0e, - 0x278: 0x0e, 0x279: 0x0e, 0x27a: 0x0e, 0x27b: 0x0e, 0x27c: 0x0e, 0x27d: 0x0e, 0x27e: 0x0e, 0x27f: 0x0e, - // Block 0xa, offset 0x280 - 0x280: 0x0e, 0x281: 0x0e, 0x282: 0x0e, 0x283: 0x0e, 0x284: 0x0e, 0x285: 0x0e, 0x286: 0x0e, 0x287: 0x0e, - 0x288: 0x0e, 0x289: 0x0e, 0x28a: 0x0e, 0x28b: 0x0e, 0x28c: 0x0e, 0x28d: 0x0e, 0x28e: 0x0e, 0x28f: 0x0e, - 0x290: 0x0e, 0x291: 0x0e, 0x292: 0x0e, 0x293: 0x0e, 0x294: 0x0e, 0x295: 0x0e, 0x296: 0x0e, 0x297: 0x0e, - 0x298: 0x0e, 0x299: 0x0e, 0x29a: 0x0e, 0x29b: 0x0e, 0x29c: 0x0e, 0x29d: 0x0e, 0x29e: 0x3e, - // Block 0xb, offset 0x2c0 - 0x2c0: 0x08, 0x2c1: 0x08, 0x2c2: 0x08, 0x2c3: 0x08, 0x2c4: 0x08, 0x2c5: 0x08, 0x2c6: 0x08, 0x2c7: 0x08, - 0x2c8: 0x08, 0x2c9: 0x08, 0x2ca: 0x08, 0x2cb: 0x08, 0x2cc: 0x08, 0x2cd: 0x08, 0x2ce: 0x08, 0x2cf: 0x08, - 0x2d0: 0x08, 0x2d1: 0x08, 0x2d2: 0x08, 0x2d3: 0x08, 0x2d4: 0x08, 0x2d5: 0x08, 0x2d6: 0x08, 0x2d7: 0x08, - 0x2d8: 0x08, 0x2d9: 0x08, 0x2da: 0x08, 0x2db: 0x08, 0x2dc: 0x08, 0x2dd: 0x08, 0x2de: 0x08, 0x2df: 0x08, - 0x2e0: 0x08, 0x2e1: 0x08, 0x2e2: 0x08, 0x2e3: 0x08, 0x2e4: 0x08, 0x2e5: 0x08, 0x2e6: 0x08, 0x2e7: 0x08, - 0x2e8: 0x08, 0x2e9: 0x08, 0x2ea: 0x08, 0x2eb: 0x08, 0x2ec: 0x08, 0x2ed: 0x08, 0x2ee: 0x08, 0x2ef: 0x08, - 0x2f0: 0x08, 0x2f1: 0x08, 0x2f2: 0x08, 0x2f3: 0x08, 0x2f4: 0x08, 0x2f5: 0x08, 0x2f6: 0x08, 0x2f7: 0x08, - 0x2f8: 0x08, 0x2f9: 0x08, 0x2fa: 0x08, 0x2fb: 0x08, 0x2fc: 0x08, 0x2fd: 0x08, 0x2fe: 0x08, 0x2ff: 0x08, - // Block 0xc, offset 0x300 - 0x300: 0x08, 0x301: 0x08, 0x302: 0x08, 0x303: 0x08, 0x304: 0x08, 0x305: 0x08, 0x306: 0x08, 0x307: 0x08, - 0x308: 0x08, 0x309: 0x08, 0x30a: 0x08, 0x30b: 0x08, 0x30c: 0x08, 0x30d: 0x08, 0x30e: 0x08, 0x30f: 0x08, - 0x310: 0x08, 0x311: 0x08, 0x312: 0x08, 0x313: 0x08, 0x314: 0x08, 0x315: 0x08, 0x316: 0x08, 0x317: 0x08, - 0x318: 0x08, 0x319: 0x08, 0x31a: 0x08, 0x31b: 0x08, 0x31c: 0x08, 0x31d: 0x08, 0x31e: 0x08, 0x31f: 0x08, - 0x320: 0x08, 0x321: 0x08, 0x322: 0x08, 0x323: 0x08, 0x324: 0x0e, 0x325: 0x0e, 0x326: 0x0e, 0x327: 0x0e, - 0x328: 0x0e, 0x329: 0x0e, 0x32a: 0x0e, 0x32b: 0x0e, - 0x338: 0x3f, 0x339: 0x40, 0x33c: 0x41, 0x33d: 0x42, 0x33e: 0x43, 0x33f: 0x44, - // Block 0xd, offset 0x340 - 0x37f: 0x45, - // Block 0xe, offset 0x380 - 0x380: 0x0e, 0x381: 0x0e, 0x382: 0x0e, 0x383: 0x0e, 0x384: 0x0e, 0x385: 0x0e, 0x386: 0x0e, 0x387: 0x0e, - 0x388: 0x0e, 0x389: 0x0e, 0x38a: 0x0e, 0x38b: 0x0e, 0x38c: 0x0e, 0x38d: 0x0e, 0x38e: 0x0e, 0x38f: 0x0e, - 0x390: 0x0e, 0x391: 0x0e, 0x392: 0x0e, 0x393: 0x0e, 0x394: 0x0e, 0x395: 0x0e, 0x396: 0x0e, 0x397: 0x0e, - 0x398: 0x0e, 0x399: 0x0e, 0x39a: 0x0e, 0x39b: 0x0e, 0x39c: 0x0e, 0x39d: 0x0e, 0x39e: 0x0e, 0x39f: 0x46, - 0x3a0: 0x0e, 0x3a1: 0x0e, 0x3a2: 0x0e, 0x3a3: 0x0e, 0x3a4: 0x0e, 0x3a5: 0x0e, 0x3a6: 0x0e, 0x3a7: 0x0e, - 0x3a8: 0x0e, 0x3a9: 0x0e, 0x3aa: 0x0e, 0x3ab: 0x47, - // Block 0xf, offset 0x3c0 - 0x3c0: 0x48, - // Block 0x10, offset 0x400 - 0x400: 0x49, 0x403: 0x4a, 0x404: 0x4b, 0x405: 0x4c, 0x406: 0x4d, - 0x408: 0x4e, 0x409: 0x4f, 0x40c: 0x50, 0x40d: 0x51, 0x40e: 0x52, 0x40f: 0x53, - 0x410: 0x3a, 0x411: 0x54, 0x412: 0x0e, 0x413: 0x55, 0x414: 0x56, 0x415: 0x57, 0x416: 0x58, 0x417: 0x59, - 0x418: 0x0e, 0x419: 0x5a, 0x41a: 0x0e, 0x41b: 0x5b, - 0x424: 0x5c, 0x425: 0x5d, 0x426: 0x5e, 0x427: 0x5f, - // Block 0x11, offset 0x440 - 0x456: 0x0b, 0x457: 0x06, - 0x458: 0x0c, 0x45b: 0x0d, 0x45f: 0x0e, - 0x460: 0x06, 0x461: 0x06, 0x462: 0x06, 0x463: 0x06, 0x464: 0x06, 0x465: 0x06, 0x466: 0x06, 0x467: 0x06, - 0x468: 0x06, 0x469: 0x06, 0x46a: 0x06, 0x46b: 0x06, 0x46c: 0x06, 0x46d: 0x06, 0x46e: 0x06, 0x46f: 0x06, - 0x470: 0x06, 0x471: 0x06, 0x472: 0x06, 0x473: 0x06, 0x474: 0x06, 0x475: 0x06, 0x476: 0x06, 0x477: 0x06, - 0x478: 0x06, 0x479: 0x06, 0x47a: 0x06, 0x47b: 0x06, 0x47c: 0x06, 0x47d: 0x06, 0x47e: 0x06, 0x47f: 0x06, - // Block 0x12, offset 0x480 - 0x484: 0x08, 0x485: 0x08, 0x486: 0x08, 0x487: 0x09, - // Block 0x13, offset 0x4c0 - 0x4c0: 0x08, 0x4c1: 0x08, 0x4c2: 0x08, 0x4c3: 0x08, 0x4c4: 0x08, 0x4c5: 0x08, 0x4c6: 0x08, 0x4c7: 0x08, - 0x4c8: 0x08, 0x4c9: 0x08, 0x4ca: 0x08, 0x4cb: 0x08, 0x4cc: 0x08, 0x4cd: 0x08, 0x4ce: 0x08, 0x4cf: 0x08, - 0x4d0: 0x08, 0x4d1: 0x08, 0x4d2: 0x08, 0x4d3: 0x08, 0x4d4: 0x08, 0x4d5: 0x08, 0x4d6: 0x08, 0x4d7: 0x08, - 0x4d8: 0x08, 0x4d9: 0x08, 0x4da: 0x08, 0x4db: 0x08, 0x4dc: 0x08, 0x4dd: 0x08, 0x4de: 0x08, 0x4df: 0x08, - 0x4e0: 0x08, 0x4e1: 0x08, 0x4e2: 0x08, 0x4e3: 0x08, 0x4e4: 0x08, 0x4e5: 0x08, 0x4e6: 0x08, 0x4e7: 0x08, - 0x4e8: 0x08, 0x4e9: 0x08, 0x4ea: 0x08, 0x4eb: 0x08, 0x4ec: 0x08, 0x4ed: 0x08, 0x4ee: 0x08, 0x4ef: 0x08, - 0x4f0: 0x08, 0x4f1: 0x08, 0x4f2: 0x08, 0x4f3: 0x08, 0x4f4: 0x08, 0x4f5: 0x08, 0x4f6: 0x08, 0x4f7: 0x08, - 0x4f8: 0x08, 0x4f9: 0x08, 0x4fa: 0x08, 0x4fb: 0x08, 0x4fc: 0x08, 0x4fd: 0x08, 0x4fe: 0x08, 0x4ff: 0x60, - // Block 0x14, offset 0x500 - 0x520: 0x10, - 0x530: 0x09, 0x531: 0x09, 0x532: 0x09, 0x533: 0x09, 0x534: 0x09, 0x535: 0x09, 0x536: 0x09, 0x537: 0x09, - 0x538: 0x09, 0x539: 0x09, 0x53a: 0x09, 0x53b: 0x09, 0x53c: 0x09, 0x53d: 0x09, 0x53e: 0x09, 0x53f: 0x11, - // Block 0x15, offset 0x540 - 0x540: 0x09, 0x541: 0x09, 0x542: 0x09, 0x543: 0x09, 0x544: 0x09, 0x545: 0x09, 0x546: 0x09, 0x547: 0x09, - 0x548: 0x09, 0x549: 0x09, 0x54a: 0x09, 0x54b: 0x09, 0x54c: 0x09, 0x54d: 0x09, 0x54e: 0x09, 0x54f: 0x11, -} - -// inverseData contains 4-byte entries of the following format: -// <length> <modified UTF-8-encoded rune> <0 padding> -// The last byte of the UTF-8-encoded rune is xor-ed with the last byte of the -// UTF-8 encoding of the original rune. Mappings often have the following -// pattern: -// A -> A (U+FF21 -> U+0041) -// B -> B (U+FF22 -> U+0042) -// ... -// By xor-ing the last byte the same entry can be shared by many mappings. This -// reduces the total number of distinct entries by about two thirds. -// The resulting entry for the aforementioned mappings is -// { 0x01, 0xE0, 0x00, 0x00 } -// Using this entry to map U+FF21 (UTF-8 [EF BC A1]), we get -// E0 ^ A1 = 41. -// Similarly, for U+FF22 (UTF-8 [EF BC A2]), we get -// E0 ^ A2 = 42. -// Note that because of the xor-ing, the byte sequence stored in the entry is -// not valid UTF-8. -var inverseData = [150][4]byte{ - {0x00, 0x00, 0x00, 0x00}, - {0x03, 0xe3, 0x80, 0xa0}, - {0x03, 0xef, 0xbc, 0xa0}, - {0x03, 0xef, 0xbc, 0xe0}, - {0x03, 0xef, 0xbd, 0xe0}, - {0x03, 0xef, 0xbf, 0x02}, - {0x03, 0xef, 0xbf, 0x00}, - {0x03, 0xef, 0xbf, 0x0e}, - {0x03, 0xef, 0xbf, 0x0c}, - {0x03, 0xef, 0xbf, 0x0f}, - {0x03, 0xef, 0xbf, 0x39}, - {0x03, 0xef, 0xbf, 0x3b}, - {0x03, 0xef, 0xbf, 0x3f}, - {0x03, 0xef, 0xbf, 0x2a}, - {0x03, 0xef, 0xbf, 0x0d}, - {0x03, 0xef, 0xbf, 0x25}, - {0x03, 0xef, 0xbd, 0x1a}, - {0x03, 0xef, 0xbd, 0x26}, - {0x01, 0xa0, 0x00, 0x00}, - {0x03, 0xef, 0xbd, 0x25}, - {0x03, 0xef, 0xbd, 0x23}, - {0x03, 0xef, 0xbd, 0x2e}, - {0x03, 0xef, 0xbe, 0x07}, - {0x03, 0xef, 0xbe, 0x05}, - {0x03, 0xef, 0xbd, 0x06}, - {0x03, 0xef, 0xbd, 0x13}, - {0x03, 0xef, 0xbd, 0x0b}, - {0x03, 0xef, 0xbd, 0x16}, - {0x03, 0xef, 0xbd, 0x0c}, - {0x03, 0xef, 0xbd, 0x15}, - {0x03, 0xef, 0xbd, 0x0d}, - {0x03, 0xef, 0xbd, 0x1c}, - {0x03, 0xef, 0xbd, 0x02}, - {0x03, 0xef, 0xbd, 0x1f}, - {0x03, 0xef, 0xbd, 0x1d}, - {0x03, 0xef, 0xbd, 0x17}, - {0x03, 0xef, 0xbd, 0x08}, - {0x03, 0xef, 0xbd, 0x09}, - {0x03, 0xef, 0xbd, 0x0e}, - {0x03, 0xef, 0xbd, 0x04}, - {0x03, 0xef, 0xbd, 0x05}, - {0x03, 0xef, 0xbe, 0x3f}, - {0x03, 0xef, 0xbe, 0x00}, - {0x03, 0xef, 0xbd, 0x2c}, - {0x03, 0xef, 0xbe, 0x06}, - {0x03, 0xef, 0xbe, 0x0c}, - {0x03, 0xef, 0xbe, 0x0f}, - {0x03, 0xef, 0xbe, 0x0d}, - {0x03, 0xef, 0xbe, 0x0b}, - {0x03, 0xef, 0xbe, 0x19}, - {0x03, 0xef, 0xbe, 0x15}, - {0x03, 0xef, 0xbe, 0x11}, - {0x03, 0xef, 0xbe, 0x31}, - {0x03, 0xef, 0xbe, 0x33}, - {0x03, 0xef, 0xbd, 0x0f}, - {0x03, 0xef, 0xbe, 0x30}, - {0x03, 0xef, 0xbe, 0x3e}, - {0x03, 0xef, 0xbe, 0x32}, - {0x03, 0xef, 0xbe, 0x36}, - {0x03, 0xef, 0xbd, 0x14}, - {0x03, 0xef, 0xbe, 0x2e}, - {0x03, 0xef, 0xbd, 0x1e}, - {0x03, 0xef, 0xbe, 0x10}, - {0x03, 0xef, 0xbf, 0x13}, - {0x03, 0xef, 0xbf, 0x15}, - {0x03, 0xef, 0xbf, 0x17}, - {0x03, 0xef, 0xbf, 0x1f}, - {0x03, 0xef, 0xbf, 0x1d}, - {0x03, 0xef, 0xbf, 0x1b}, - {0x03, 0xef, 0xbf, 0x09}, - {0x03, 0xef, 0xbf, 0x0b}, - {0x03, 0xef, 0xbf, 0x37}, - {0x03, 0xef, 0xbe, 0x04}, - {0x01, 0xe0, 0x00, 0x00}, - {0x03, 0xe2, 0xa6, 0x1a}, - {0x03, 0xe2, 0xa6, 0x26}, - {0x03, 0xe3, 0x80, 0x23}, - {0x03, 0xe3, 0x80, 0x2e}, - {0x03, 0xe3, 0x80, 0x25}, - {0x03, 0xe3, 0x83, 0x1e}, - {0x03, 0xe3, 0x83, 0x14}, - {0x03, 0xe3, 0x82, 0x06}, - {0x03, 0xe3, 0x82, 0x0b}, - {0x03, 0xe3, 0x82, 0x0c}, - {0x03, 0xe3, 0x82, 0x0d}, - {0x03, 0xe3, 0x82, 0x02}, - {0x03, 0xe3, 0x83, 0x0f}, - {0x03, 0xe3, 0x83, 0x08}, - {0x03, 0xe3, 0x83, 0x09}, - {0x03, 0xe3, 0x83, 0x2c}, - {0x03, 0xe3, 0x83, 0x0c}, - {0x03, 0xe3, 0x82, 0x13}, - {0x03, 0xe3, 0x82, 0x16}, - {0x03, 0xe3, 0x82, 0x15}, - {0x03, 0xe3, 0x82, 0x1c}, - {0x03, 0xe3, 0x82, 0x1f}, - {0x03, 0xe3, 0x82, 0x1d}, - {0x03, 0xe3, 0x82, 0x1a}, - {0x03, 0xe3, 0x82, 0x17}, - {0x03, 0xe3, 0x82, 0x08}, - {0x03, 0xe3, 0x82, 0x09}, - {0x03, 0xe3, 0x82, 0x0e}, - {0x03, 0xe3, 0x82, 0x04}, - {0x03, 0xe3, 0x82, 0x05}, - {0x03, 0xe3, 0x82, 0x3f}, - {0x03, 0xe3, 0x83, 0x00}, - {0x03, 0xe3, 0x83, 0x06}, - {0x03, 0xe3, 0x83, 0x05}, - {0x03, 0xe3, 0x83, 0x0d}, - {0x03, 0xe3, 0x83, 0x0b}, - {0x03, 0xe3, 0x83, 0x07}, - {0x03, 0xe3, 0x83, 0x19}, - {0x03, 0xe3, 0x83, 0x15}, - {0x03, 0xe3, 0x83, 0x11}, - {0x03, 0xe3, 0x83, 0x31}, - {0x03, 0xe3, 0x83, 0x33}, - {0x03, 0xe3, 0x83, 0x30}, - {0x03, 0xe3, 0x83, 0x3e}, - {0x03, 0xe3, 0x83, 0x32}, - {0x03, 0xe3, 0x83, 0x36}, - {0x03, 0xe3, 0x83, 0x2e}, - {0x03, 0xe3, 0x82, 0x07}, - {0x03, 0xe3, 0x85, 0x04}, - {0x03, 0xe3, 0x84, 0x10}, - {0x03, 0xe3, 0x85, 0x30}, - {0x03, 0xe3, 0x85, 0x0d}, - {0x03, 0xe3, 0x85, 0x13}, - {0x03, 0xe3, 0x85, 0x15}, - {0x03, 0xe3, 0x85, 0x17}, - {0x03, 0xe3, 0x85, 0x1f}, - {0x03, 0xe3, 0x85, 0x1d}, - {0x03, 0xe3, 0x85, 0x1b}, - {0x03, 0xe3, 0x85, 0x09}, - {0x03, 0xe3, 0x85, 0x0f}, - {0x03, 0xe3, 0x85, 0x0b}, - {0x03, 0xe3, 0x85, 0x37}, - {0x03, 0xe3, 0x85, 0x3b}, - {0x03, 0xe3, 0x85, 0x39}, - {0x03, 0xe3, 0x85, 0x3f}, - {0x02, 0xc2, 0x02, 0x00}, - {0x02, 0xc2, 0x0e, 0x00}, - {0x02, 0xc2, 0x0c, 0x00}, - {0x02, 0xc2, 0x00, 0x00}, - {0x03, 0xe2, 0x82, 0x0f}, - {0x03, 0xe2, 0x94, 0x2a}, - {0x03, 0xe2, 0x86, 0x39}, - {0x03, 0xe2, 0x86, 0x3b}, - {0x03, 0xe2, 0x86, 0x3f}, - {0x03, 0xe2, 0x96, 0x0d}, - {0x03, 0xe2, 0x97, 0x25}, -} - -// Total table size 14680 bytes (14KiB) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/transform.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/transform.go deleted file mode 100644 index 2ed2509..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/transform.go +++ /dev/null @@ -1,162 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -package width - -import ( - "unicode/utf8" - - "golang.org/x/text/transform" -) - -type foldTransform struct { - transform.NopResetter -} - -func (foldTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for nSrc < len(src) { - if src[nSrc] < utf8.RuneSelf { - // ASCII fast path. - start, end := nSrc, len(src) - if d := len(dst) - nDst; d < end-start { - end = nSrc + d - } - for nSrc++; nSrc < end && src[nSrc] < utf8.RuneSelf; nSrc++ { - } - n := copy(dst[nDst:], src[start:nSrc]) - if nDst += n; nDst == len(dst) { - nSrc = start + n - if nSrc == len(src) { - return nDst, nSrc, nil - } - if src[nSrc] < utf8.RuneSelf { - return nDst, nSrc, transform.ErrShortDst - } - } - continue - } - v, size := trie.lookup(src[nSrc:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - return nDst, nSrc, transform.ErrShortSrc - } - size = 1 // gobble 1 byte - } - if elem(v)&tagNeedsFold == 0 { - if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { - return nDst, nSrc, transform.ErrShortDst - } - nDst += size - } else { - data := inverseData[byte(v)] - if len(dst)-nDst < int(data[0]) { - return nDst, nSrc, transform.ErrShortDst - } - i := 1 - for end := int(data[0]); i < end; i++ { - dst[nDst] = data[i] - nDst++ - } - dst[nDst] = data[i] ^ src[nSrc+size-1] - nDst++ - } - nSrc += size - } - return nDst, nSrc, nil -} - -type narrowTransform struct { - transform.NopResetter -} - -func (narrowTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for nSrc < len(src) { - if src[nSrc] < utf8.RuneSelf { - // ASCII fast path. - start, end := nSrc, len(src) - if d := len(dst) - nDst; d < end-start { - end = nSrc + d - } - for nSrc++; nSrc < end && src[nSrc] < utf8.RuneSelf; nSrc++ { - } - n := copy(dst[nDst:], src[start:nSrc]) - if nDst += n; nDst == len(dst) { - nSrc = start + n - if nSrc == len(src) { - return nDst, nSrc, nil - } - if src[nSrc] < utf8.RuneSelf { - return nDst, nSrc, transform.ErrShortDst - } - } - continue - } - v, size := trie.lookup(src[nSrc:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - return nDst, nSrc, transform.ErrShortSrc - } - size = 1 // gobble 1 byte - } - if k := elem(v).kind(); byte(v) == 0 || k != EastAsianFullwidth && k != EastAsianWide && k != EastAsianAmbiguous { - if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { - return nDst, nSrc, transform.ErrShortDst - } - nDst += size - } else { - data := inverseData[byte(v)] - if len(dst)-nDst < int(data[0]) { - return nDst, nSrc, transform.ErrShortDst - } - i := 1 - for end := int(data[0]); i < end; i++ { - dst[nDst] = data[i] - nDst++ - } - dst[nDst] = data[i] ^ src[nSrc+size-1] - nDst++ - } - nSrc += size - } - return nDst, nSrc, nil -} - -type wideTransform struct { - transform.NopResetter -} - -func (wideTransform) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - for nSrc < len(src) { - // TODO: Consider ASCII fast path. Special-casing ASCII handling can - // reduce the ns/op of BenchmarkWideASCII by about 30%. This is probably - // not enough to warrant the extra code and complexity. - v, size := trie.lookup(src[nSrc:]) - if size == 0 { // incomplete UTF-8 encoding - if !atEOF { - return nDst, nSrc, transform.ErrShortSrc - } - size = 1 // gobble 1 byte - } - if k := elem(v).kind(); byte(v) == 0 || k != EastAsianHalfwidth && k != EastAsianNarrow { - if size != copy(dst[nDst:], src[nSrc:nSrc+size]) { - return nDst, nSrc, transform.ErrShortDst - } - nDst += size - } else { - data := inverseData[byte(v)] - if len(dst)-nDst < int(data[0]) { - return nDst, nSrc, transform.ErrShortDst - } - i := 1 - for end := int(data[0]); i < end; i++ { - dst[nDst] = data[i] - nDst++ - } - dst[nDst] = data[i] ^ src[nSrc+size-1] - nDst++ - } - nSrc += size - } - return nDst, nSrc, nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/trieval.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/trieval.go deleted file mode 100644 index 0ecffb4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/trieval.go +++ /dev/null @@ -1,30 +0,0 @@ -// This file was generated by go generate; DO NOT EDIT - -package width - -// elem is an entry of the width trie. The high byte is used to encode the type -// of the rune. The low byte is used to store the index to a mapping entry in -// the inverseData array. -type elem uint16 - -const ( - tagNeutral elem = iota << typeShift - tagAmbiguous - tagWide - tagNarrow - tagFullwidth - tagHalfwidth -) - -const ( - numTypeBits = 3 - typeShift = 16 - numTypeBits - - // tagNeedsFold is true for all fullwidth and halfwidth runes except for - // the Won sign U+20A9. - tagNeedsFold = 0x1000 - - // The Korean Won sign is halfwidth, but SHOULD NOT be mapped to a wide - // variant. - wonSign rune = 0x20A9 -) diff --git a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/width.go b/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/width.go deleted file mode 100644 index c32d772..0000000 --- a/vendor/k8s.io/kubernetes/vendor/golang.org/x/text/width/width.go +++ /dev/null @@ -1,201 +0,0 @@ -// Copyright 2015 The Go Authors. All rights reserved. -// Use of this source code is governed by a BSD-style -// license that can be found in the LICENSE file. - -//go:generate stringer -type=Kind -//go:generate go run gen.go gen_common.go gen_trieval.go - -// Package width provides functionality for handling different widths in text. -// -// Wide characters behave like ideographs; they tend to allow line breaks after -// each character and remain upright in vertical text layout. Narrow characters -// are kept together in words or runs that are rotated sideways in vertical text -// layout. -// -// For more information, see http://unicode.org/reports/tr11/. -package width - -import ( - "unicode/utf8" - - "golang.org/x/text/transform" -) - -// TODO -// 1) Reduce table size by compressing blocks. -// 2) API proposition for computing display length -// (approximation, fixed pitch only). -// 3) Implement display length. - -// Kind indicates the type of width property as defined in http://unicode.org/reports/tr11/. -type Kind int - -const ( - // Neutral characters do not occur in legacy East Asian character sets. - Neutral Kind = iota - - // EastAsianAmbiguous characters that can be sometimes wide and sometimes - // narrow and require additional information not contained in the character - // code to further resolve their width. - EastAsianAmbiguous - - // EastAsianWide characters are wide in its usual form. They occur only in - // the context of East Asian typography. These runes may have explicit - // halfwidth counterparts. - EastAsianWide - - // EastAsianNarrow characters are narrow in its usual form. They often have - // fullwidth counterparts. - EastAsianNarrow - - // Note: there exist Narrow runes that do not have fullwidth or wide - // counterparts, despite what the definition says (e.g. U+27E6). - - // EastAsianFullwidth characters have a compatibility decompositions of type - // wide that map to a narrow counterpart. - EastAsianFullwidth - - // EastAsianHalfwidth characters have a compatibility decomposition of type - // narrow that map to a wide or ambiguous counterpart, plus U+20A9 ₩ WON - // SIGN. - EastAsianHalfwidth - - // Note: there exist runes that have a halfwidth counterparts but that are - // classified as Ambiguous, rather than wide (e.g. U+2190). -) - -// TODO: the generated tries need to return size 1 for invalid runes for the -// width to be computed correctly (each byte should render width 1) - -var trie = newWidthTrie(0) - -// Lookup reports the Properties of the first rune in b and the number of bytes -// of its UTF-8 encoding. -func Lookup(b []byte) (p Properties, size int) { - v, sz := trie.lookup(b) - return Properties{elem(v), b[sz-1]}, sz -} - -// LookupString reports the Properties of the first rune in s and the number of -// bytes of its UTF-8 encoding. -func LookupString(s string) (p Properties, size int) { - v, sz := trie.lookupString(s) - return Properties{elem(v), s[sz-1]}, sz -} - -// LookupRune reports the Properties of rune r. -func LookupRune(r rune) Properties { - var buf [4]byte - n := utf8.EncodeRune(buf[:], r) - v, _ := trie.lookup(buf[:n]) - last := byte(r) - if r >= utf8.RuneSelf { - last = 0x80 + byte(r&0x3f) - } - return Properties{elem(v), last} -} - -// Properties provides access to width properties of a rune. -type Properties struct { - elem elem - last byte -} - -func (e elem) kind() Kind { - return Kind(e >> typeShift) -} - -// Kind returns the Kind of a rune as defined in Unicode TR #11. -// See http://unicode.org/reports/tr11/ for more details. -func (p Properties) Kind() Kind { - return p.elem.kind() -} - -// Folded returns the folded variant of a rune or 0 if the rune is canonical. -func (p Properties) Folded() rune { - if p.elem&tagNeedsFold != 0 { - buf := inverseData[byte(p.elem)] - buf[buf[0]] ^= p.last - r, _ := utf8.DecodeRune(buf[1 : 1+buf[0]]) - return r - } - return 0 -} - -// Narrow returns the narrow variant of a rune or 0 if the rune is already -// narrow or doesn't have a narrow variant. -func (p Properties) Narrow() rune { - if k := p.elem.kind(); byte(p.elem) != 0 && (k == EastAsianFullwidth || k == EastAsianWide || k == EastAsianAmbiguous) { - buf := inverseData[byte(p.elem)] - buf[buf[0]] ^= p.last - r, _ := utf8.DecodeRune(buf[1 : 1+buf[0]]) - return r - } - return 0 -} - -// Wide returns the wide variant of a rune or 0 if the rune is already -// wide or doesn't have a wide variant. -func (p Properties) Wide() rune { - if k := p.elem.kind(); byte(p.elem) != 0 && (k == EastAsianHalfwidth || k == EastAsianNarrow) { - buf := inverseData[byte(p.elem)] - buf[buf[0]] ^= p.last - r, _ := utf8.DecodeRune(buf[1 : 1+buf[0]]) - return r - } - return 0 -} - -// TODO for Properties: -// - Add Fullwidth/Halfwidth or Inverted methods for computing variants -// mapping. -// - Add width information (including information on non-spacing runes). - -// Transformer implements the transform.Transformer interface. -type Transformer struct { - t transform.Transformer -} - -// Reset implements the transform.Transformer interface. -func (t Transformer) Reset() { t.t.Reset() } - -// Transform implements the Transformer interface. -func (t Transformer) Transform(dst, src []byte, atEOF bool) (nDst, nSrc int, err error) { - return t.t.Transform(dst, src, atEOF) -} - -// Bytes returns a new byte slice with the result of applying t to b. -func (t Transformer) Bytes(b []byte) []byte { - b, _, _ = transform.Bytes(t, b) - return b -} - -// String returns a string with the result of applying t to s. -func (t Transformer) String(s string) string { - s, _, _ = transform.String(t, s) - return s -} - -var ( - // Fold is a transform that maps all runes to their canonical width. - // - // Note that the NFKC and NFKD transforms in golang.org/x/text/unicode/norm - // provide a more generic folding mechanism. - Fold Transformer = Transformer{foldTransform{}} - - // Widen is a transform that maps runes to their wide variant, if - // available. - Widen Transformer = Transformer{wideTransform{}} - - // Narrow is a transform that maps runes to their narrow variant, if - // available. - Narrow Transformer = Transformer{narrowTransform{}} -) - -// TODO: Consider the following options: -// - Treat Ambiguous runes that have a halfwidth counterpart as wide, or some -// generalized variant of this. -// - Consider a wide Won character to be the default width (or some generalized -// variant of this). -// - Filter the set of characters that gets converted (the preferred approach is -// to allow applying filters to transforms). diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/.travis.yml b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/.travis.yml deleted file mode 100644 index 12ea385..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/.travis.yml +++ /dev/null @@ -1,18 +0,0 @@ -language: go - -go: - - 1.6.3 - - 1.7rc6 - -install: - - go get -v -t -d google.golang.org/appengine/... - - mkdir sdk - - curl -o sdk.zip "https://storage.googleapis.com/appengine-sdks/featured/go_appengine_sdk_linux_amd64-1.9.40.zip" - - unzip sdk.zip -d sdk - - export APPENGINE_DEV_APPSERVER=$(pwd)/sdk/go_appengine/dev_appserver.py - -script: - - go version - - go test -v google.golang.org/appengine/... - - go test -v -race google.golang.org/appengine/... - - sdk/go_appengine/goapp test -v google.golang.org/appengine/... diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/LICENSE b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/LICENSE deleted file mode 100644 index d645695..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/LICENSE +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/README.md b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/README.md deleted file mode 100644 index 1efd955..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/README.md +++ /dev/null @@ -1,71 +0,0 @@ -# Go App Engine packages - -[![Build Status](https://travis-ci.org/golang/appengine.svg)](https://travis-ci.org/golang/appengine) - -This repository supports the Go runtime on App Engine, -including both the standard App Engine and the -"App Engine flexible environment" (formerly known as "Managed VMs"). -It provides APIs for interacting with App Engine services. -Its canonical import path is `google.golang.org/appengine`. - -See https://cloud.google.com/appengine/docs/go/ -for more information. - -File issue reports and feature requests on the [Google App Engine issue -tracker](https://code.google.com/p/googleappengine/issues/entry?template=Go%20defect). - -## Directory structure -The top level directory of this repository is the `appengine` package. It -contains the -basic APIs (e.g. `appengine.NewContext`) that apply across APIs. Specific API -packages are in subdirectories (e.g. `datastore`). - -There is an `internal` subdirectory that contains service protocol buffers, -plus packages required for connectivity to make API calls. App Engine apps -should not directly import any package under `internal`. - -## Updating a Go App Engine app - -This section describes how to update an older Go App Engine app to use -these packages. A provided tool, `aefix`, can help automate steps 2 and 3 -(run `go get google.golang.org/appengine/cmd/aefix` to install it), but -read the details below since `aefix` can't perform all the changes. - -### 1. Update YAML files (App Engine flexible environment / Managed VMs only) - -The `app.yaml` file (and YAML files for modules) should have these new lines added: -``` -vm: true -``` -See https://cloud.google.com/appengine/docs/go/modules/#Go_Instance_scaling_and_class for details. - -### 2. Update import paths - -The import paths for App Engine packages are now fully qualified, based at `google.golang.org/appengine`. -You will need to update your code to use import paths starting with that; for instance, -code importing `appengine/datastore` will now need to import `google.golang.org/appengine/datastore`. - -### 3. Update code using deprecated, removed or modified APIs - -Most App Engine services are available with exactly the same API. -A few APIs were cleaned up, and some are not available yet. -This list summarises the differences: - -* `appengine.Context` has been replaced with the `Context` type from `golang.org/x/net/context`. -* Logging methods that were on `appengine.Context` are now functions in `google.golang.org/appengine/log`. -* `appengine.Timeout` has been removed. Use `context.WithTimeout` instead. -* `appengine.Datacenter` now takes a `context.Context` argument. -* `datastore.PropertyLoadSaver` has been simplified to use slices in place of channels. -* `delay.Call` now returns an error. -* `search.FieldLoadSaver` now handles document metadata. -* `urlfetch.Transport` no longer has a Deadline field; set a deadline on the - `context.Context` instead. -* `aetest` no longer declares its own Context type, and uses the standard one instead. -* `taskqueue.QueueStats` no longer takes a maxTasks argument. That argument has been - deprecated and unused for a long time. -* `appengine.BackendHostname` and `appengine.BackendInstance` were for the deprecated backends feature. - Use `appengine.ModuleHostname`and `appengine.ModuleName` instead. -* Most of `appengine/file` and parts of `appengine/blobstore` are deprecated. - Use [Google Cloud Storage](https://godoc.org/google.golang.org/cloud/storage) instead. -* `appengine/socket` is not required on App Engine flexible environment / Managed VMs. - Use the standard `net` package instead. diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine.go deleted file mode 100644 index 8865c49..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine.go +++ /dev/null @@ -1,112 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// Package appengine provides basic functionality for Google App Engine. -// -// For more information on how to write Go apps for Google App Engine, see: -// https://cloud.google.com/appengine/docs/go/ -package appengine - -import ( - "net/http" - - "github.com/golang/protobuf/proto" - "golang.org/x/net/context" - - "google.golang.org/appengine/internal" -) - -// The gophers party all night; the rabbits provide the beats. - -// Main is the principal entry point for an app running in App Engine. -// -// On App Engine Flexible it installs a trivial health checker if one isn't -// already registered, and starts listening on port 8080 (overridden by the -// $PORT environment variable). -// -// See https://cloud.google.com/appengine/docs/flexible/custom-runtimes#health_check_requests -// for details on how to do your own health checking. -// -// Main is not yet supported on App Engine Standard. -// -// Main never returns. -// -// Main is designed so that the app's main package looks like this: -// -// package main -// -// import ( -// "google.golang.org/appengine" -// -// _ "myapp/package0" -// _ "myapp/package1" -// ) -// -// func main() { -// appengine.Main() -// } -// -// The "myapp/packageX" packages are expected to register HTTP handlers -// in their init functions. -func Main() { - internal.Main() -} - -// IsDevAppServer reports whether the App Engine app is running in the -// development App Server. -func IsDevAppServer() bool { - return internal.IsDevAppServer() -} - -// NewContext returns a context for an in-flight HTTP request. -// This function is cheap. -func NewContext(req *http.Request) context.Context { - return WithContext(context.Background(), req) -} - -// WithContext returns a copy of the parent context -// and associates it with an in-flight HTTP request. -// This function is cheap. -func WithContext(parent context.Context, req *http.Request) context.Context { - return internal.WithContext(parent, req) -} - -// TODO(dsymonds): Add a Call function here? Otherwise other packages can't access internal.Call. - -// BlobKey is a key for a blobstore blob. -// -// Conceptually, this type belongs in the blobstore package, but it lives in -// the appengine package to avoid a circular dependency: blobstore depends on -// datastore, and datastore needs to refer to the BlobKey type. -type BlobKey string - -// GeoPoint represents a location as latitude/longitude in degrees. -type GeoPoint struct { - Lat, Lng float64 -} - -// Valid returns whether a GeoPoint is within [-90, 90] latitude and [-180, 180] longitude. -func (g GeoPoint) Valid() bool { - return -90 <= g.Lat && g.Lat <= 90 && -180 <= g.Lng && g.Lng <= 180 -} - -// APICallFunc defines a function type for handling an API call. -// See WithCallOverride. -type APICallFunc func(ctx context.Context, service, method string, in, out proto.Message) error - -// WithAPICallFunc returns a copy of the parent context -// that will cause API calls to invoke f instead of their normal operation. -// -// This is intended for advanced users only. -func WithAPICallFunc(ctx context.Context, f APICallFunc) context.Context { - return internal.WithCallOverride(ctx, internal.CallOverrideFunc(f)) -} - -// APICall performs an API call. -// -// This is not intended for general use; it is exported for use in conjunction -// with WithAPICallFunc. -func APICall(ctx context.Context, service, method string, in, out proto.Message) error { - return internal.Call(ctx, service, method, in, out) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine_vm.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine_vm.go deleted file mode 100644 index f4b645a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/appengine_vm.go +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright 2015 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build !appengine - -package appengine - -import ( - "golang.org/x/net/context" - - "google.golang.org/appengine/internal" -) - -// BackgroundContext returns a context not associated with a request. -// This should only be used when not servicing a request. -// This only works in App Engine "flexible environment". -func BackgroundContext() context.Context { - return internal.BackgroundContext() -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/errors.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/errors.go deleted file mode 100644 index 16d0772..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/errors.go +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// This file provides error functions for common API failure modes. - -package appengine - -import ( - "fmt" - - "google.golang.org/appengine/internal" -) - -// IsOverQuota reports whether err represents an API call failure -// due to insufficient available quota. -func IsOverQuota(err error) bool { - callErr, ok := err.(*internal.CallError) - return ok && callErr.Code == 4 -} - -// MultiError is returned by batch operations when there are errors with -// particular elements. Errors will be in a one-to-one correspondence with -// the input elements; successful elements will have a nil entry. -type MultiError []error - -func (m MultiError) Error() string { - s, n := "", 0 - for _, e := range m { - if e != nil { - if n == 0 { - s = e.Error() - } - n++ - } - } - switch n { - case 0: - return "(0 errors)" - case 1: - return s - case 2: - return s + " (and 1 other error)" - } - return fmt.Sprintf("%s (and %d other errors)", s, n-1) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/identity.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/identity.go deleted file mode 100644 index b8dcf8f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/identity.go +++ /dev/null @@ -1,142 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package appengine - -import ( - "time" - - "golang.org/x/net/context" - - "google.golang.org/appengine/internal" - pb "google.golang.org/appengine/internal/app_identity" - modpb "google.golang.org/appengine/internal/modules" -) - -// AppID returns the application ID for the current application. -// The string will be a plain application ID (e.g. "appid"), with a -// domain prefix for custom domain deployments (e.g. "example.com:appid"). -func AppID(c context.Context) string { return internal.AppID(c) } - -// DefaultVersionHostname returns the standard hostname of the default version -// of the current application (e.g. "my-app.appspot.com"). This is suitable for -// use in constructing URLs. -func DefaultVersionHostname(c context.Context) string { - return internal.DefaultVersionHostname(c) -} - -// ModuleName returns the module name of the current instance. -func ModuleName(c context.Context) string { - return internal.ModuleName(c) -} - -// ModuleHostname returns a hostname of a module instance. -// If module is the empty string, it refers to the module of the current instance. -// If version is empty, it refers to the version of the current instance if valid, -// or the default version of the module of the current instance. -// If instance is empty, ModuleHostname returns the load-balancing hostname. -func ModuleHostname(c context.Context, module, version, instance string) (string, error) { - req := &modpb.GetHostnameRequest{} - if module != "" { - req.Module = &module - } - if version != "" { - req.Version = &version - } - if instance != "" { - req.Instance = &instance - } - res := &modpb.GetHostnameResponse{} - if err := internal.Call(c, "modules", "GetHostname", req, res); err != nil { - return "", err - } - return *res.Hostname, nil -} - -// VersionID returns the version ID for the current application. -// It will be of the form "X.Y", where X is specified in app.yaml, -// and Y is a number generated when each version of the app is uploaded. -// It does not include a module name. -func VersionID(c context.Context) string { return internal.VersionID(c) } - -// InstanceID returns a mostly-unique identifier for this instance. -func InstanceID() string { return internal.InstanceID() } - -// Datacenter returns an identifier for the datacenter that the instance is running in. -func Datacenter(c context.Context) string { return internal.Datacenter(c) } - -// ServerSoftware returns the App Engine release version. -// In production, it looks like "Google App Engine/X.Y.Z". -// In the development appserver, it looks like "Development/X.Y". -func ServerSoftware() string { return internal.ServerSoftware() } - -// RequestID returns a string that uniquely identifies the request. -func RequestID(c context.Context) string { return internal.RequestID(c) } - -// AccessToken generates an OAuth2 access token for the specified scopes on -// behalf of service account of this application. This token will expire after -// the returned time. -func AccessToken(c context.Context, scopes ...string) (token string, expiry time.Time, err error) { - req := &pb.GetAccessTokenRequest{Scope: scopes} - res := &pb.GetAccessTokenResponse{} - - err = internal.Call(c, "app_identity_service", "GetAccessToken", req, res) - if err != nil { - return "", time.Time{}, err - } - return res.GetAccessToken(), time.Unix(res.GetExpirationTime(), 0), nil -} - -// Certificate represents a public certificate for the app. -type Certificate struct { - KeyName string - Data []byte // PEM-encoded X.509 certificate -} - -// PublicCertificates retrieves the public certificates for the app. -// They can be used to verify a signature returned by SignBytes. -func PublicCertificates(c context.Context) ([]Certificate, error) { - req := &pb.GetPublicCertificateForAppRequest{} - res := &pb.GetPublicCertificateForAppResponse{} - if err := internal.Call(c, "app_identity_service", "GetPublicCertificatesForApp", req, res); err != nil { - return nil, err - } - var cs []Certificate - for _, pc := range res.PublicCertificateList { - cs = append(cs, Certificate{ - KeyName: pc.GetKeyName(), - Data: []byte(pc.GetX509CertificatePem()), - }) - } - return cs, nil -} - -// ServiceAccount returns a string representing the service account name, in -// the form of an email address (typically app_id@appspot.gserviceaccount.com). -func ServiceAccount(c context.Context) (string, error) { - req := &pb.GetServiceAccountNameRequest{} - res := &pb.GetServiceAccountNameResponse{} - - err := internal.Call(c, "app_identity_service", "GetServiceAccountName", req, res) - if err != nil { - return "", err - } - return res.GetServiceAccountName(), err -} - -// SignBytes signs bytes using a private key unique to your application. -func SignBytes(c context.Context, bytes []byte) (keyName string, signature []byte, err error) { - req := &pb.SignForAppRequest{BytesToSign: bytes} - res := &pb.SignForAppResponse{} - - if err := internal.Call(c, "app_identity_service", "SignForApp", req, res); err != nil { - return "", nil, err - } - return res.GetKeyName(), res.GetSignatureBytes(), nil -} - -func init() { - internal.RegisterErrorCodeMap("app_identity_service", pb.AppIdentityServiceError_ErrorCode_name) - internal.RegisterErrorCodeMap("modules", modpb.ModulesServiceError_ErrorCode_name) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api.go deleted file mode 100644 index ec5aa59..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api.go +++ /dev/null @@ -1,646 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build !appengine - -package internal - -import ( - "bytes" - "errors" - "fmt" - "io/ioutil" - "log" - "net" - "net/http" - "net/url" - "os" - "runtime" - "strconv" - "strings" - "sync" - "sync/atomic" - "time" - - "github.com/golang/protobuf/proto" - netcontext "golang.org/x/net/context" - - basepb "google.golang.org/appengine/internal/base" - logpb "google.golang.org/appengine/internal/log" - remotepb "google.golang.org/appengine/internal/remote_api" -) - -const ( - apiPath = "/rpc_http" -) - -var ( - // Incoming headers. - ticketHeader = http.CanonicalHeaderKey("X-AppEngine-API-Ticket") - dapperHeader = http.CanonicalHeaderKey("X-Google-DapperTraceInfo") - traceHeader = http.CanonicalHeaderKey("X-Cloud-Trace-Context") - curNamespaceHeader = http.CanonicalHeaderKey("X-AppEngine-Current-Namespace") - userIPHeader = http.CanonicalHeaderKey("X-AppEngine-User-IP") - remoteAddrHeader = http.CanonicalHeaderKey("X-AppEngine-Remote-Addr") - - // Outgoing headers. - apiEndpointHeader = http.CanonicalHeaderKey("X-Google-RPC-Service-Endpoint") - apiEndpointHeaderValue = []string{"app-engine-apis"} - apiMethodHeader = http.CanonicalHeaderKey("X-Google-RPC-Service-Method") - apiMethodHeaderValue = []string{"/VMRemoteAPI.CallRemoteAPI"} - apiDeadlineHeader = http.CanonicalHeaderKey("X-Google-RPC-Service-Deadline") - apiContentType = http.CanonicalHeaderKey("Content-Type") - apiContentTypeValue = []string{"application/octet-stream"} - logFlushHeader = http.CanonicalHeaderKey("X-AppEngine-Log-Flush-Count") - - apiHTTPClient = &http.Client{ - Transport: &http.Transport{ - Proxy: http.ProxyFromEnvironment, - Dial: limitDial, - }, - } -) - -func apiURL() *url.URL { - host, port := "appengine.googleapis.internal", "10001" - if h := os.Getenv("API_HOST"); h != "" { - host = h - } - if p := os.Getenv("API_PORT"); p != "" { - port = p - } - return &url.URL{ - Scheme: "http", - Host: host + ":" + port, - Path: apiPath, - } -} - -func handleHTTP(w http.ResponseWriter, r *http.Request) { - c := &context{ - req: r, - outHeader: w.Header(), - apiURL: apiURL(), - } - stopFlushing := make(chan int) - - ctxs.Lock() - ctxs.m[r] = c - ctxs.Unlock() - defer func() { - ctxs.Lock() - delete(ctxs.m, r) - ctxs.Unlock() - }() - - // Patch up RemoteAddr so it looks reasonable. - if addr := r.Header.Get(userIPHeader); addr != "" { - r.RemoteAddr = addr - } else if addr = r.Header.Get(remoteAddrHeader); addr != "" { - r.RemoteAddr = addr - } else { - // Should not normally reach here, but pick a sensible default anyway. - r.RemoteAddr = "127.0.0.1" - } - // The address in the headers will most likely be of these forms: - // 123.123.123.123 - // 2001:db8::1 - // net/http.Request.RemoteAddr is specified to be in "IP:port" form. - if _, _, err := net.SplitHostPort(r.RemoteAddr); err != nil { - // Assume the remote address is only a host; add a default port. - r.RemoteAddr = net.JoinHostPort(r.RemoteAddr, "80") - } - - // Start goroutine responsible for flushing app logs. - // This is done after adding c to ctx.m (and stopped before removing it) - // because flushing logs requires making an API call. - go c.logFlusher(stopFlushing) - - executeRequestSafely(c, r) - c.outHeader = nil // make sure header changes aren't respected any more - - stopFlushing <- 1 // any logging beyond this point will be dropped - - // Flush any pending logs asynchronously. - c.pendingLogs.Lock() - flushes := c.pendingLogs.flushes - if len(c.pendingLogs.lines) > 0 { - flushes++ - } - c.pendingLogs.Unlock() - go c.flushLog(false) - w.Header().Set(logFlushHeader, strconv.Itoa(flushes)) - - // Avoid nil Write call if c.Write is never called. - if c.outCode != 0 { - w.WriteHeader(c.outCode) - } - if c.outBody != nil { - w.Write(c.outBody) - } -} - -func executeRequestSafely(c *context, r *http.Request) { - defer func() { - if x := recover(); x != nil { - logf(c, 4, "%s", renderPanic(x)) // 4 == critical - c.outCode = 500 - } - }() - - http.DefaultServeMux.ServeHTTP(c, r) -} - -func renderPanic(x interface{}) string { - buf := make([]byte, 16<<10) // 16 KB should be plenty - buf = buf[:runtime.Stack(buf, false)] - - // Remove the first few stack frames: - // this func - // the recover closure in the caller - // That will root the stack trace at the site of the panic. - const ( - skipStart = "internal.renderPanic" - skipFrames = 2 - ) - start := bytes.Index(buf, []byte(skipStart)) - p := start - for i := 0; i < skipFrames*2 && p+1 < len(buf); i++ { - p = bytes.IndexByte(buf[p+1:], '\n') + p + 1 - if p < 0 { - break - } - } - if p >= 0 { - // buf[start:p+1] is the block to remove. - // Copy buf[p+1:] over buf[start:] and shrink buf. - copy(buf[start:], buf[p+1:]) - buf = buf[:len(buf)-(p+1-start)] - } - - // Add panic heading. - head := fmt.Sprintf("panic: %v\n\n", x) - if len(head) > len(buf) { - // Extremely unlikely to happen. - return head - } - copy(buf[len(head):], buf) - copy(buf, head) - - return string(buf) -} - -var ctxs = struct { - sync.Mutex - m map[*http.Request]*context - bg *context // background context, lazily initialized - // dec is used by tests to decorate the netcontext.Context returned - // for a given request. This allows tests to add overrides (such as - // WithAppIDOverride) to the context. The map is nil outside tests. - dec map[*http.Request]func(netcontext.Context) netcontext.Context -}{ - m: make(map[*http.Request]*context), -} - -// context represents the context of an in-flight HTTP request. -// It implements the appengine.Context and http.ResponseWriter interfaces. -type context struct { - req *http.Request - - outCode int - outHeader http.Header - outBody []byte - - pendingLogs struct { - sync.Mutex - lines []*logpb.UserAppLogLine - flushes int - } - - apiURL *url.URL -} - -var contextKey = "holds a *context" - -func fromContext(ctx netcontext.Context) *context { - c, _ := ctx.Value(&contextKey).(*context) - return c -} - -func withContext(parent netcontext.Context, c *context) netcontext.Context { - ctx := netcontext.WithValue(parent, &contextKey, c) - if ns := c.req.Header.Get(curNamespaceHeader); ns != "" { - ctx = withNamespace(ctx, ns) - } - return ctx -} - -func toContext(c *context) netcontext.Context { - return withContext(netcontext.Background(), c) -} - -func IncomingHeaders(ctx netcontext.Context) http.Header { - if c := fromContext(ctx); c != nil { - return c.req.Header - } - return nil -} - -func WithContext(parent netcontext.Context, req *http.Request) netcontext.Context { - ctxs.Lock() - c := ctxs.m[req] - d := ctxs.dec[req] - ctxs.Unlock() - - if d != nil { - parent = d(parent) - } - - if c == nil { - // Someone passed in an http.Request that is not in-flight. - // We panic here rather than panicking at a later point - // so that stack traces will be more sensible. - log.Panic("appengine: NewContext passed an unknown http.Request") - } - return withContext(parent, c) -} - -func BackgroundContext() netcontext.Context { - ctxs.Lock() - defer ctxs.Unlock() - - if ctxs.bg != nil { - return toContext(ctxs.bg) - } - - // Compute background security ticket. - appID := partitionlessAppID() - escAppID := strings.Replace(strings.Replace(appID, ":", "_", -1), ".", "_", -1) - majVersion := VersionID(nil) - if i := strings.Index(majVersion, "."); i > 0 { - majVersion = majVersion[:i] - } - ticket := fmt.Sprintf("%s/%s.%s.%s", escAppID, ModuleName(nil), majVersion, InstanceID()) - - ctxs.bg = &context{ - req: &http.Request{ - Header: http.Header{ - ticketHeader: []string{ticket}, - }, - }, - apiURL: apiURL(), - } - - // TODO(dsymonds): Wire up the shutdown handler to do a final flush. - go ctxs.bg.logFlusher(make(chan int)) - - return toContext(ctxs.bg) -} - -// RegisterTestRequest registers the HTTP request req for testing, such that -// any API calls are sent to the provided URL. It returns a closure to delete -// the registration. -// It should only be used by aetest package. -func RegisterTestRequest(req *http.Request, apiURL *url.URL, decorate func(netcontext.Context) netcontext.Context) func() { - c := &context{ - req: req, - apiURL: apiURL, - } - ctxs.Lock() - defer ctxs.Unlock() - if _, ok := ctxs.m[req]; ok { - log.Panic("req already associated with context") - } - if _, ok := ctxs.dec[req]; ok { - log.Panic("req already associated with context") - } - if ctxs.dec == nil { - ctxs.dec = make(map[*http.Request]func(netcontext.Context) netcontext.Context) - } - ctxs.m[req] = c - ctxs.dec[req] = decorate - - return func() { - ctxs.Lock() - delete(ctxs.m, req) - delete(ctxs.dec, req) - ctxs.Unlock() - } -} - -var errTimeout = &CallError{ - Detail: "Deadline exceeded", - Code: int32(remotepb.RpcError_CANCELLED), - Timeout: true, -} - -func (c *context) Header() http.Header { return c.outHeader } - -// Copied from $GOROOT/src/pkg/net/http/transfer.go. Some response status -// codes do not permit a response body (nor response entity headers such as -// Content-Length, Content-Type, etc). -func bodyAllowedForStatus(status int) bool { - switch { - case status >= 100 && status <= 199: - return false - case status == 204: - return false - case status == 304: - return false - } - return true -} - -func (c *context) Write(b []byte) (int, error) { - if c.outCode == 0 { - c.WriteHeader(http.StatusOK) - } - if len(b) > 0 && !bodyAllowedForStatus(c.outCode) { - return 0, http.ErrBodyNotAllowed - } - c.outBody = append(c.outBody, b...) - return len(b), nil -} - -func (c *context) WriteHeader(code int) { - if c.outCode != 0 { - logf(c, 3, "WriteHeader called multiple times on request.") // error level - return - } - c.outCode = code -} - -func (c *context) post(body []byte, timeout time.Duration) (b []byte, err error) { - hreq := &http.Request{ - Method: "POST", - URL: c.apiURL, - Header: http.Header{ - apiEndpointHeader: apiEndpointHeaderValue, - apiMethodHeader: apiMethodHeaderValue, - apiContentType: apiContentTypeValue, - apiDeadlineHeader: []string{strconv.FormatFloat(timeout.Seconds(), 'f', -1, 64)}, - }, - Body: ioutil.NopCloser(bytes.NewReader(body)), - ContentLength: int64(len(body)), - Host: c.apiURL.Host, - } - if info := c.req.Header.Get(dapperHeader); info != "" { - hreq.Header.Set(dapperHeader, info) - } - if info := c.req.Header.Get(traceHeader); info != "" { - hreq.Header.Set(traceHeader, info) - } - - tr := apiHTTPClient.Transport.(*http.Transport) - - var timedOut int32 // atomic; set to 1 if timed out - t := time.AfterFunc(timeout, func() { - atomic.StoreInt32(&timedOut, 1) - tr.CancelRequest(hreq) - }) - defer t.Stop() - defer func() { - // Check if timeout was exceeded. - if atomic.LoadInt32(&timedOut) != 0 { - err = errTimeout - } - }() - - hresp, err := apiHTTPClient.Do(hreq) - if err != nil { - return nil, &CallError{ - Detail: fmt.Sprintf("service bridge HTTP failed: %v", err), - Code: int32(remotepb.RpcError_UNKNOWN), - } - } - defer hresp.Body.Close() - hrespBody, err := ioutil.ReadAll(hresp.Body) - if hresp.StatusCode != 200 { - return nil, &CallError{ - Detail: fmt.Sprintf("service bridge returned HTTP %d (%q)", hresp.StatusCode, hrespBody), - Code: int32(remotepb.RpcError_UNKNOWN), - } - } - if err != nil { - return nil, &CallError{ - Detail: fmt.Sprintf("service bridge response bad: %v", err), - Code: int32(remotepb.RpcError_UNKNOWN), - } - } - return hrespBody, nil -} - -func Call(ctx netcontext.Context, service, method string, in, out proto.Message) error { - if ns := NamespaceFromContext(ctx); ns != "" { - if fn, ok := NamespaceMods[service]; ok { - fn(in, ns) - } - } - - if f, ctx, ok := callOverrideFromContext(ctx); ok { - return f(ctx, service, method, in, out) - } - - // Handle already-done contexts quickly. - select { - case <-ctx.Done(): - return ctx.Err() - default: - } - - c := fromContext(ctx) - if c == nil { - // Give a good error message rather than a panic lower down. - return errors.New("not an App Engine context") - } - - // Apply transaction modifications if we're in a transaction. - if t := transactionFromContext(ctx); t != nil { - if t.finished { - return errors.New("transaction context has expired") - } - applyTransaction(in, &t.transaction) - } - - // Default RPC timeout is 60s. - timeout := 60 * time.Second - if deadline, ok := ctx.Deadline(); ok { - timeout = deadline.Sub(time.Now()) - } - - data, err := proto.Marshal(in) - if err != nil { - return err - } - - ticket := c.req.Header.Get(ticketHeader) - req := &remotepb.Request{ - ServiceName: &service, - Method: &method, - Request: data, - RequestId: &ticket, - } - hreqBody, err := proto.Marshal(req) - if err != nil { - return err - } - - hrespBody, err := c.post(hreqBody, timeout) - if err != nil { - return err - } - - res := &remotepb.Response{} - if err := proto.Unmarshal(hrespBody, res); err != nil { - return err - } - if res.RpcError != nil { - ce := &CallError{ - Detail: res.RpcError.GetDetail(), - Code: *res.RpcError.Code, - } - switch remotepb.RpcError_ErrorCode(ce.Code) { - case remotepb.RpcError_CANCELLED, remotepb.RpcError_DEADLINE_EXCEEDED: - ce.Timeout = true - } - return ce - } - if res.ApplicationError != nil { - return &APIError{ - Service: *req.ServiceName, - Detail: res.ApplicationError.GetDetail(), - Code: *res.ApplicationError.Code, - } - } - if res.Exception != nil || res.JavaException != nil { - // This shouldn't happen, but let's be defensive. - return &CallError{ - Detail: "service bridge returned exception", - Code: int32(remotepb.RpcError_UNKNOWN), - } - } - return proto.Unmarshal(res.Response, out) -} - -func (c *context) Request() *http.Request { - return c.req -} - -func (c *context) addLogLine(ll *logpb.UserAppLogLine) { - // Truncate long log lines. - // TODO(dsymonds): Check if this is still necessary. - const lim = 8 << 10 - if len(*ll.Message) > lim { - suffix := fmt.Sprintf("...(length %d)", len(*ll.Message)) - ll.Message = proto.String((*ll.Message)[:lim-len(suffix)] + suffix) - } - - c.pendingLogs.Lock() - c.pendingLogs.lines = append(c.pendingLogs.lines, ll) - c.pendingLogs.Unlock() -} - -var logLevelName = map[int64]string{ - 0: "DEBUG", - 1: "INFO", - 2: "WARNING", - 3: "ERROR", - 4: "CRITICAL", -} - -func logf(c *context, level int64, format string, args ...interface{}) { - s := fmt.Sprintf(format, args...) - s = strings.TrimRight(s, "\n") // Remove any trailing newline characters. - c.addLogLine(&logpb.UserAppLogLine{ - TimestampUsec: proto.Int64(time.Now().UnixNano() / 1e3), - Level: &level, - Message: &s, - }) - log.Print(logLevelName[level] + ": " + s) -} - -// flushLog attempts to flush any pending logs to the appserver. -// It should not be called concurrently. -func (c *context) flushLog(force bool) (flushed bool) { - c.pendingLogs.Lock() - // Grab up to 30 MB. We can get away with up to 32 MB, but let's be cautious. - n, rem := 0, 30<<20 - for ; n < len(c.pendingLogs.lines); n++ { - ll := c.pendingLogs.lines[n] - // Each log line will require about 3 bytes of overhead. - nb := proto.Size(ll) + 3 - if nb > rem { - break - } - rem -= nb - } - lines := c.pendingLogs.lines[:n] - c.pendingLogs.lines = c.pendingLogs.lines[n:] - c.pendingLogs.Unlock() - - if len(lines) == 0 && !force { - // Nothing to flush. - return false - } - - rescueLogs := false - defer func() { - if rescueLogs { - c.pendingLogs.Lock() - c.pendingLogs.lines = append(lines, c.pendingLogs.lines...) - c.pendingLogs.Unlock() - } - }() - - buf, err := proto.Marshal(&logpb.UserAppLogGroup{ - LogLine: lines, - }) - if err != nil { - log.Printf("internal.flushLog: marshaling UserAppLogGroup: %v", err) - rescueLogs = true - return false - } - - req := &logpb.FlushRequest{ - Logs: buf, - } - res := &basepb.VoidProto{} - c.pendingLogs.Lock() - c.pendingLogs.flushes++ - c.pendingLogs.Unlock() - if err := Call(toContext(c), "logservice", "Flush", req, res); err != nil { - log.Printf("internal.flushLog: Flush RPC: %v", err) - rescueLogs = true - return false - } - return true -} - -const ( - // Log flushing parameters. - flushInterval = 1 * time.Second - forceFlushInterval = 60 * time.Second -) - -func (c *context) logFlusher(stop <-chan int) { - lastFlush := time.Now() - tick := time.NewTicker(flushInterval) - for { - select { - case <-stop: - // Request finished. - tick.Stop() - return - case <-tick.C: - force := time.Now().Sub(lastFlush) > forceFlushInterval - if c.flushLog(force) { - lastFlush = time.Now() - } - } - } -} - -func ContextForTesting(req *http.Request) netcontext.Context { - return toContext(&context{req: req}) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_classic.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_classic.go deleted file mode 100644 index 597f66e..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_classic.go +++ /dev/null @@ -1,159 +0,0 @@ -// Copyright 2015 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build appengine - -package internal - -import ( - "errors" - "fmt" - "net/http" - "time" - - "appengine" - "appengine_internal" - basepb "appengine_internal/base" - - "github.com/golang/protobuf/proto" - netcontext "golang.org/x/net/context" -) - -var contextKey = "holds an appengine.Context" - -func fromContext(ctx netcontext.Context) appengine.Context { - c, _ := ctx.Value(&contextKey).(appengine.Context) - return c -} - -// This is only for classic App Engine adapters. -func ClassicContextFromContext(ctx netcontext.Context) appengine.Context { - return fromContext(ctx) -} - -func withContext(parent netcontext.Context, c appengine.Context) netcontext.Context { - ctx := netcontext.WithValue(parent, &contextKey, c) - - s := &basepb.StringProto{} - c.Call("__go__", "GetNamespace", &basepb.VoidProto{}, s, nil) - if ns := s.GetValue(); ns != "" { - ctx = NamespacedContext(ctx, ns) - } - - return ctx -} - -func IncomingHeaders(ctx netcontext.Context) http.Header { - if c := fromContext(ctx); c != nil { - if req, ok := c.Request().(*http.Request); ok { - return req.Header - } - } - return nil -} - -func WithContext(parent netcontext.Context, req *http.Request) netcontext.Context { - c := appengine.NewContext(req) - return withContext(parent, c) -} - -type testingContext struct { - appengine.Context - - req *http.Request -} - -func (t *testingContext) FullyQualifiedAppID() string { return "dev~testcontext" } -func (t *testingContext) Call(service, method string, _, _ appengine_internal.ProtoMessage, _ *appengine_internal.CallOptions) error { - if service == "__go__" && method == "GetNamespace" { - return nil - } - return fmt.Errorf("testingContext: unsupported Call") -} -func (t *testingContext) Request() interface{} { return t.req } - -func ContextForTesting(req *http.Request) netcontext.Context { - return withContext(netcontext.Background(), &testingContext{req: req}) -} - -func Call(ctx netcontext.Context, service, method string, in, out proto.Message) error { - if ns := NamespaceFromContext(ctx); ns != "" { - if fn, ok := NamespaceMods[service]; ok { - fn(in, ns) - } - } - - if f, ctx, ok := callOverrideFromContext(ctx); ok { - return f(ctx, service, method, in, out) - } - - // Handle already-done contexts quickly. - select { - case <-ctx.Done(): - return ctx.Err() - default: - } - - c := fromContext(ctx) - if c == nil { - // Give a good error message rather than a panic lower down. - return errors.New("not an App Engine context") - } - - // Apply transaction modifications if we're in a transaction. - if t := transactionFromContext(ctx); t != nil { - if t.finished { - return errors.New("transaction context has expired") - } - applyTransaction(in, &t.transaction) - } - - var opts *appengine_internal.CallOptions - if d, ok := ctx.Deadline(); ok { - opts = &appengine_internal.CallOptions{ - Timeout: d.Sub(time.Now()), - } - } - - err := c.Call(service, method, in, out, opts) - switch v := err.(type) { - case *appengine_internal.APIError: - return &APIError{ - Service: v.Service, - Detail: v.Detail, - Code: v.Code, - } - case *appengine_internal.CallError: - return &CallError{ - Detail: v.Detail, - Code: v.Code, - Timeout: v.Timeout, - } - } - return err -} - -func handleHTTP(w http.ResponseWriter, r *http.Request) { - panic("handleHTTP called; this should be impossible") -} - -func logf(c appengine.Context, level int64, format string, args ...interface{}) { - var fn func(format string, args ...interface{}) - switch level { - case 0: - fn = c.Debugf - case 1: - fn = c.Infof - case 2: - fn = c.Warningf - case 3: - fn = c.Errorf - case 4: - fn = c.Criticalf - default: - // This shouldn't happen. - fn = c.Criticalf - } - fn(format, args...) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_common.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_common.go deleted file mode 100644 index 2db33a7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/api_common.go +++ /dev/null @@ -1,86 +0,0 @@ -// Copyright 2015 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -import ( - "github.com/golang/protobuf/proto" - netcontext "golang.org/x/net/context" -) - -type CallOverrideFunc func(ctx netcontext.Context, service, method string, in, out proto.Message) error - -var callOverrideKey = "holds []CallOverrideFunc" - -func WithCallOverride(ctx netcontext.Context, f CallOverrideFunc) netcontext.Context { - // We avoid appending to any existing call override - // so we don't risk overwriting a popped stack below. - var cofs []CallOverrideFunc - if uf, ok := ctx.Value(&callOverrideKey).([]CallOverrideFunc); ok { - cofs = append(cofs, uf...) - } - cofs = append(cofs, f) - return netcontext.WithValue(ctx, &callOverrideKey, cofs) -} - -func callOverrideFromContext(ctx netcontext.Context) (CallOverrideFunc, netcontext.Context, bool) { - cofs, _ := ctx.Value(&callOverrideKey).([]CallOverrideFunc) - if len(cofs) == 0 { - return nil, nil, false - } - // We found a list of overrides; grab the last, and reconstitute a - // context that will hide it. - f := cofs[len(cofs)-1] - ctx = netcontext.WithValue(ctx, &callOverrideKey, cofs[:len(cofs)-1]) - return f, ctx, true -} - -type logOverrideFunc func(level int64, format string, args ...interface{}) - -var logOverrideKey = "holds a logOverrideFunc" - -func WithLogOverride(ctx netcontext.Context, f logOverrideFunc) netcontext.Context { - return netcontext.WithValue(ctx, &logOverrideKey, f) -} - -var appIDOverrideKey = "holds a string, being the full app ID" - -func WithAppIDOverride(ctx netcontext.Context, appID string) netcontext.Context { - return netcontext.WithValue(ctx, &appIDOverrideKey, appID) -} - -var namespaceKey = "holds the namespace string" - -func withNamespace(ctx netcontext.Context, ns string) netcontext.Context { - return netcontext.WithValue(ctx, &namespaceKey, ns) -} - -func NamespaceFromContext(ctx netcontext.Context) string { - // If there's no namespace, return the empty string. - ns, _ := ctx.Value(&namespaceKey).(string) - return ns -} - -// FullyQualifiedAppID returns the fully-qualified application ID. -// This may contain a partition prefix (e.g. "s~" for High Replication apps), -// or a domain prefix (e.g. "example.com:"). -func FullyQualifiedAppID(ctx netcontext.Context) string { - if id, ok := ctx.Value(&appIDOverrideKey).(string); ok { - return id - } - return fullyQualifiedAppID(ctx) -} - -func Logf(ctx netcontext.Context, level int64, format string, args ...interface{}) { - if f, ok := ctx.Value(&logOverrideKey).(logOverrideFunc); ok { - f(level, format, args...) - return - } - logf(fromContext(ctx), level, format, args...) -} - -// NamespacedContext wraps a Context to support namespaces. -func NamespacedContext(ctx netcontext.Context, namespace string) netcontext.Context { - return withNamespace(ctx, namespace) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_id.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_id.go deleted file mode 100644 index 11df8c0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_id.go +++ /dev/null @@ -1,28 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -import ( - "strings" -) - -func parseFullAppID(appid string) (partition, domain, displayID string) { - if i := strings.Index(appid, "~"); i != -1 { - partition, appid = appid[:i], appid[i+1:] - } - if i := strings.Index(appid, ":"); i != -1 { - domain, appid = appid[:i], appid[i+1:] - } - return partition, domain, appid -} - -// appID returns "appid" or "domain.com:appid". -func appID(fullAppID string) string { - _, dom, dis := parseFullAppID(fullAppID) - if dom != "" { - return dom + ":" + dis - } - return dis -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.pb.go deleted file mode 100644 index 87d9701..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.pb.go +++ /dev/null @@ -1,296 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/app_identity/app_identity_service.proto -// DO NOT EDIT! - -/* -Package app_identity is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/app_identity/app_identity_service.proto - -It has these top-level messages: - AppIdentityServiceError - SignForAppRequest - SignForAppResponse - GetPublicCertificateForAppRequest - PublicCertificate - GetPublicCertificateForAppResponse - GetServiceAccountNameRequest - GetServiceAccountNameResponse - GetAccessTokenRequest - GetAccessTokenResponse - GetDefaultGcsBucketNameRequest - GetDefaultGcsBucketNameResponse -*/ -package app_identity - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type AppIdentityServiceError_ErrorCode int32 - -const ( - AppIdentityServiceError_SUCCESS AppIdentityServiceError_ErrorCode = 0 - AppIdentityServiceError_UNKNOWN_SCOPE AppIdentityServiceError_ErrorCode = 9 - AppIdentityServiceError_BLOB_TOO_LARGE AppIdentityServiceError_ErrorCode = 1000 - AppIdentityServiceError_DEADLINE_EXCEEDED AppIdentityServiceError_ErrorCode = 1001 - AppIdentityServiceError_NOT_A_VALID_APP AppIdentityServiceError_ErrorCode = 1002 - AppIdentityServiceError_UNKNOWN_ERROR AppIdentityServiceError_ErrorCode = 1003 - AppIdentityServiceError_NOT_ALLOWED AppIdentityServiceError_ErrorCode = 1005 - AppIdentityServiceError_NOT_IMPLEMENTED AppIdentityServiceError_ErrorCode = 1006 -) - -var AppIdentityServiceError_ErrorCode_name = map[int32]string{ - 0: "SUCCESS", - 9: "UNKNOWN_SCOPE", - 1000: "BLOB_TOO_LARGE", - 1001: "DEADLINE_EXCEEDED", - 1002: "NOT_A_VALID_APP", - 1003: "UNKNOWN_ERROR", - 1005: "NOT_ALLOWED", - 1006: "NOT_IMPLEMENTED", -} -var AppIdentityServiceError_ErrorCode_value = map[string]int32{ - "SUCCESS": 0, - "UNKNOWN_SCOPE": 9, - "BLOB_TOO_LARGE": 1000, - "DEADLINE_EXCEEDED": 1001, - "NOT_A_VALID_APP": 1002, - "UNKNOWN_ERROR": 1003, - "NOT_ALLOWED": 1005, - "NOT_IMPLEMENTED": 1006, -} - -func (x AppIdentityServiceError_ErrorCode) Enum() *AppIdentityServiceError_ErrorCode { - p := new(AppIdentityServiceError_ErrorCode) - *p = x - return p -} -func (x AppIdentityServiceError_ErrorCode) String() string { - return proto.EnumName(AppIdentityServiceError_ErrorCode_name, int32(x)) -} -func (x *AppIdentityServiceError_ErrorCode) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(AppIdentityServiceError_ErrorCode_value, data, "AppIdentityServiceError_ErrorCode") - if err != nil { - return err - } - *x = AppIdentityServiceError_ErrorCode(value) - return nil -} - -type AppIdentityServiceError struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *AppIdentityServiceError) Reset() { *m = AppIdentityServiceError{} } -func (m *AppIdentityServiceError) String() string { return proto.CompactTextString(m) } -func (*AppIdentityServiceError) ProtoMessage() {} - -type SignForAppRequest struct { - BytesToSign []byte `protobuf:"bytes,1,opt,name=bytes_to_sign" json:"bytes_to_sign,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *SignForAppRequest) Reset() { *m = SignForAppRequest{} } -func (m *SignForAppRequest) String() string { return proto.CompactTextString(m) } -func (*SignForAppRequest) ProtoMessage() {} - -func (m *SignForAppRequest) GetBytesToSign() []byte { - if m != nil { - return m.BytesToSign - } - return nil -} - -type SignForAppResponse struct { - KeyName *string `protobuf:"bytes,1,opt,name=key_name" json:"key_name,omitempty"` - SignatureBytes []byte `protobuf:"bytes,2,opt,name=signature_bytes" json:"signature_bytes,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *SignForAppResponse) Reset() { *m = SignForAppResponse{} } -func (m *SignForAppResponse) String() string { return proto.CompactTextString(m) } -func (*SignForAppResponse) ProtoMessage() {} - -func (m *SignForAppResponse) GetKeyName() string { - if m != nil && m.KeyName != nil { - return *m.KeyName - } - return "" -} - -func (m *SignForAppResponse) GetSignatureBytes() []byte { - if m != nil { - return m.SignatureBytes - } - return nil -} - -type GetPublicCertificateForAppRequest struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetPublicCertificateForAppRequest) Reset() { *m = GetPublicCertificateForAppRequest{} } -func (m *GetPublicCertificateForAppRequest) String() string { return proto.CompactTextString(m) } -func (*GetPublicCertificateForAppRequest) ProtoMessage() {} - -type PublicCertificate struct { - KeyName *string `protobuf:"bytes,1,opt,name=key_name" json:"key_name,omitempty"` - X509CertificatePem *string `protobuf:"bytes,2,opt,name=x509_certificate_pem" json:"x509_certificate_pem,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PublicCertificate) Reset() { *m = PublicCertificate{} } -func (m *PublicCertificate) String() string { return proto.CompactTextString(m) } -func (*PublicCertificate) ProtoMessage() {} - -func (m *PublicCertificate) GetKeyName() string { - if m != nil && m.KeyName != nil { - return *m.KeyName - } - return "" -} - -func (m *PublicCertificate) GetX509CertificatePem() string { - if m != nil && m.X509CertificatePem != nil { - return *m.X509CertificatePem - } - return "" -} - -type GetPublicCertificateForAppResponse struct { - PublicCertificateList []*PublicCertificate `protobuf:"bytes,1,rep,name=public_certificate_list" json:"public_certificate_list,omitempty"` - MaxClientCacheTimeInSecond *int64 `protobuf:"varint,2,opt,name=max_client_cache_time_in_second" json:"max_client_cache_time_in_second,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetPublicCertificateForAppResponse) Reset() { *m = GetPublicCertificateForAppResponse{} } -func (m *GetPublicCertificateForAppResponse) String() string { return proto.CompactTextString(m) } -func (*GetPublicCertificateForAppResponse) ProtoMessage() {} - -func (m *GetPublicCertificateForAppResponse) GetPublicCertificateList() []*PublicCertificate { - if m != nil { - return m.PublicCertificateList - } - return nil -} - -func (m *GetPublicCertificateForAppResponse) GetMaxClientCacheTimeInSecond() int64 { - if m != nil && m.MaxClientCacheTimeInSecond != nil { - return *m.MaxClientCacheTimeInSecond - } - return 0 -} - -type GetServiceAccountNameRequest struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetServiceAccountNameRequest) Reset() { *m = GetServiceAccountNameRequest{} } -func (m *GetServiceAccountNameRequest) String() string { return proto.CompactTextString(m) } -func (*GetServiceAccountNameRequest) ProtoMessage() {} - -type GetServiceAccountNameResponse struct { - ServiceAccountName *string `protobuf:"bytes,1,opt,name=service_account_name" json:"service_account_name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetServiceAccountNameResponse) Reset() { *m = GetServiceAccountNameResponse{} } -func (m *GetServiceAccountNameResponse) String() string { return proto.CompactTextString(m) } -func (*GetServiceAccountNameResponse) ProtoMessage() {} - -func (m *GetServiceAccountNameResponse) GetServiceAccountName() string { - if m != nil && m.ServiceAccountName != nil { - return *m.ServiceAccountName - } - return "" -} - -type GetAccessTokenRequest struct { - Scope []string `protobuf:"bytes,1,rep,name=scope" json:"scope,omitempty"` - ServiceAccountId *int64 `protobuf:"varint,2,opt,name=service_account_id" json:"service_account_id,omitempty"` - ServiceAccountName *string `protobuf:"bytes,3,opt,name=service_account_name" json:"service_account_name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetAccessTokenRequest) Reset() { *m = GetAccessTokenRequest{} } -func (m *GetAccessTokenRequest) String() string { return proto.CompactTextString(m) } -func (*GetAccessTokenRequest) ProtoMessage() {} - -func (m *GetAccessTokenRequest) GetScope() []string { - if m != nil { - return m.Scope - } - return nil -} - -func (m *GetAccessTokenRequest) GetServiceAccountId() int64 { - if m != nil && m.ServiceAccountId != nil { - return *m.ServiceAccountId - } - return 0 -} - -func (m *GetAccessTokenRequest) GetServiceAccountName() string { - if m != nil && m.ServiceAccountName != nil { - return *m.ServiceAccountName - } - return "" -} - -type GetAccessTokenResponse struct { - AccessToken *string `protobuf:"bytes,1,opt,name=access_token" json:"access_token,omitempty"` - ExpirationTime *int64 `protobuf:"varint,2,opt,name=expiration_time" json:"expiration_time,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetAccessTokenResponse) Reset() { *m = GetAccessTokenResponse{} } -func (m *GetAccessTokenResponse) String() string { return proto.CompactTextString(m) } -func (*GetAccessTokenResponse) ProtoMessage() {} - -func (m *GetAccessTokenResponse) GetAccessToken() string { - if m != nil && m.AccessToken != nil { - return *m.AccessToken - } - return "" -} - -func (m *GetAccessTokenResponse) GetExpirationTime() int64 { - if m != nil && m.ExpirationTime != nil { - return *m.ExpirationTime - } - return 0 -} - -type GetDefaultGcsBucketNameRequest struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetDefaultGcsBucketNameRequest) Reset() { *m = GetDefaultGcsBucketNameRequest{} } -func (m *GetDefaultGcsBucketNameRequest) String() string { return proto.CompactTextString(m) } -func (*GetDefaultGcsBucketNameRequest) ProtoMessage() {} - -type GetDefaultGcsBucketNameResponse struct { - DefaultGcsBucketName *string `protobuf:"bytes,1,opt,name=default_gcs_bucket_name" json:"default_gcs_bucket_name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetDefaultGcsBucketNameResponse) Reset() { *m = GetDefaultGcsBucketNameResponse{} } -func (m *GetDefaultGcsBucketNameResponse) String() string { return proto.CompactTextString(m) } -func (*GetDefaultGcsBucketNameResponse) ProtoMessage() {} - -func (m *GetDefaultGcsBucketNameResponse) GetDefaultGcsBucketName() string { - if m != nil && m.DefaultGcsBucketName != nil { - return *m.DefaultGcsBucketName - } - return "" -} - -func init() { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.proto deleted file mode 100644 index 19610ca..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/app_identity/app_identity_service.proto +++ /dev/null @@ -1,64 +0,0 @@ -syntax = "proto2"; -option go_package = "app_identity"; - -package appengine; - -message AppIdentityServiceError { - enum ErrorCode { - SUCCESS = 0; - UNKNOWN_SCOPE = 9; - BLOB_TOO_LARGE = 1000; - DEADLINE_EXCEEDED = 1001; - NOT_A_VALID_APP = 1002; - UNKNOWN_ERROR = 1003; - NOT_ALLOWED = 1005; - NOT_IMPLEMENTED = 1006; - } -} - -message SignForAppRequest { - optional bytes bytes_to_sign = 1; -} - -message SignForAppResponse { - optional string key_name = 1; - optional bytes signature_bytes = 2; -} - -message GetPublicCertificateForAppRequest { -} - -message PublicCertificate { - optional string key_name = 1; - optional string x509_certificate_pem = 2; -} - -message GetPublicCertificateForAppResponse { - repeated PublicCertificate public_certificate_list = 1; - optional int64 max_client_cache_time_in_second = 2; -} - -message GetServiceAccountNameRequest { -} - -message GetServiceAccountNameResponse { - optional string service_account_name = 1; -} - -message GetAccessTokenRequest { - repeated string scope = 1; - optional int64 service_account_id = 2; - optional string service_account_name = 3; -} - -message GetAccessTokenResponse { - optional string access_token = 1; - optional int64 expiration_time = 2; -} - -message GetDefaultGcsBucketNameRequest { -} - -message GetDefaultGcsBucketNameResponse { - optional string default_gcs_bucket_name = 1; -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.pb.go deleted file mode 100644 index 36a1956..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +++ /dev/null @@ -1,133 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/base/api_base.proto -// DO NOT EDIT! - -/* -Package base is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/base/api_base.proto - -It has these top-level messages: - StringProto - Integer32Proto - Integer64Proto - BoolProto - DoubleProto - BytesProto - VoidProto -*/ -package base - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type StringProto struct { - Value *string `protobuf:"bytes,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *StringProto) Reset() { *m = StringProto{} } -func (m *StringProto) String() string { return proto.CompactTextString(m) } -func (*StringProto) ProtoMessage() {} - -func (m *StringProto) GetValue() string { - if m != nil && m.Value != nil { - return *m.Value - } - return "" -} - -type Integer32Proto struct { - Value *int32 `protobuf:"varint,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Integer32Proto) Reset() { *m = Integer32Proto{} } -func (m *Integer32Proto) String() string { return proto.CompactTextString(m) } -func (*Integer32Proto) ProtoMessage() {} - -func (m *Integer32Proto) GetValue() int32 { - if m != nil && m.Value != nil { - return *m.Value - } - return 0 -} - -type Integer64Proto struct { - Value *int64 `protobuf:"varint,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Integer64Proto) Reset() { *m = Integer64Proto{} } -func (m *Integer64Proto) String() string { return proto.CompactTextString(m) } -func (*Integer64Proto) ProtoMessage() {} - -func (m *Integer64Proto) GetValue() int64 { - if m != nil && m.Value != nil { - return *m.Value - } - return 0 -} - -type BoolProto struct { - Value *bool `protobuf:"varint,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *BoolProto) Reset() { *m = BoolProto{} } -func (m *BoolProto) String() string { return proto.CompactTextString(m) } -func (*BoolProto) ProtoMessage() {} - -func (m *BoolProto) GetValue() bool { - if m != nil && m.Value != nil { - return *m.Value - } - return false -} - -type DoubleProto struct { - Value *float64 `protobuf:"fixed64,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *DoubleProto) Reset() { *m = DoubleProto{} } -func (m *DoubleProto) String() string { return proto.CompactTextString(m) } -func (*DoubleProto) ProtoMessage() {} - -func (m *DoubleProto) GetValue() float64 { - if m != nil && m.Value != nil { - return *m.Value - } - return 0 -} - -type BytesProto struct { - Value []byte `protobuf:"bytes,1,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *BytesProto) Reset() { *m = BytesProto{} } -func (m *BytesProto) String() string { return proto.CompactTextString(m) } -func (*BytesProto) ProtoMessage() {} - -func (m *BytesProto) GetValue() []byte { - if m != nil { - return m.Value - } - return nil -} - -type VoidProto struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *VoidProto) Reset() { *m = VoidProto{} } -func (m *VoidProto) String() string { return proto.CompactTextString(m) } -func (*VoidProto) ProtoMessage() {} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.proto deleted file mode 100644 index 56cd7a3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/base/api_base.proto +++ /dev/null @@ -1,33 +0,0 @@ -// Built-in base types for API calls. Primarily useful as return types. - -syntax = "proto2"; -option go_package = "base"; - -package appengine.base; - -message StringProto { - required string value = 1; -} - -message Integer32Proto { - required int32 value = 1; -} - -message Integer64Proto { - required int64 value = 1; -} - -message BoolProto { - required bool value = 1; -} - -message DoubleProto { - required double value = 1; -} - -message BytesProto { - required bytes value = 1 [ctype=CORD]; -} - -message VoidProto { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go deleted file mode 100644 index 8613cb7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +++ /dev/null @@ -1,2778 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/datastore/datastore_v3.proto -// DO NOT EDIT! - -/* -Package datastore is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/datastore/datastore_v3.proto - -It has these top-level messages: - Action - PropertyValue - Property - Path - Reference - User - EntityProto - CompositeProperty - Index - CompositeIndex - IndexPostfix - IndexPosition - Snapshot - InternalHeader - Transaction - Query - CompiledQuery - CompiledCursor - Cursor - Error - Cost - GetRequest - GetResponse - PutRequest - PutResponse - TouchRequest - TouchResponse - DeleteRequest - DeleteResponse - NextRequest - QueryResult - AllocateIdsRequest - AllocateIdsResponse - CompositeIndices - AddActionsRequest - AddActionsResponse - BeginTransactionRequest - CommitResponse -*/ -package datastore - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type Property_Meaning int32 - -const ( - Property_NO_MEANING Property_Meaning = 0 - Property_BLOB Property_Meaning = 14 - Property_TEXT Property_Meaning = 15 - Property_BYTESTRING Property_Meaning = 16 - Property_ATOM_CATEGORY Property_Meaning = 1 - Property_ATOM_LINK Property_Meaning = 2 - Property_ATOM_TITLE Property_Meaning = 3 - Property_ATOM_CONTENT Property_Meaning = 4 - Property_ATOM_SUMMARY Property_Meaning = 5 - Property_ATOM_AUTHOR Property_Meaning = 6 - Property_GD_WHEN Property_Meaning = 7 - Property_GD_EMAIL Property_Meaning = 8 - Property_GEORSS_POINT Property_Meaning = 9 - Property_GD_IM Property_Meaning = 10 - Property_GD_PHONENUMBER Property_Meaning = 11 - Property_GD_POSTALADDRESS Property_Meaning = 12 - Property_GD_RATING Property_Meaning = 13 - Property_BLOBKEY Property_Meaning = 17 - Property_ENTITY_PROTO Property_Meaning = 19 - Property_INDEX_VALUE Property_Meaning = 18 -) - -var Property_Meaning_name = map[int32]string{ - 0: "NO_MEANING", - 14: "BLOB", - 15: "TEXT", - 16: "BYTESTRING", - 1: "ATOM_CATEGORY", - 2: "ATOM_LINK", - 3: "ATOM_TITLE", - 4: "ATOM_CONTENT", - 5: "ATOM_SUMMARY", - 6: "ATOM_AUTHOR", - 7: "GD_WHEN", - 8: "GD_EMAIL", - 9: "GEORSS_POINT", - 10: "GD_IM", - 11: "GD_PHONENUMBER", - 12: "GD_POSTALADDRESS", - 13: "GD_RATING", - 17: "BLOBKEY", - 19: "ENTITY_PROTO", - 18: "INDEX_VALUE", -} -var Property_Meaning_value = map[string]int32{ - "NO_MEANING": 0, - "BLOB": 14, - "TEXT": 15, - "BYTESTRING": 16, - "ATOM_CATEGORY": 1, - "ATOM_LINK": 2, - "ATOM_TITLE": 3, - "ATOM_CONTENT": 4, - "ATOM_SUMMARY": 5, - "ATOM_AUTHOR": 6, - "GD_WHEN": 7, - "GD_EMAIL": 8, - "GEORSS_POINT": 9, - "GD_IM": 10, - "GD_PHONENUMBER": 11, - "GD_POSTALADDRESS": 12, - "GD_RATING": 13, - "BLOBKEY": 17, - "ENTITY_PROTO": 19, - "INDEX_VALUE": 18, -} - -func (x Property_Meaning) Enum() *Property_Meaning { - p := new(Property_Meaning) - *p = x - return p -} -func (x Property_Meaning) String() string { - return proto.EnumName(Property_Meaning_name, int32(x)) -} -func (x *Property_Meaning) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Property_Meaning_value, data, "Property_Meaning") - if err != nil { - return err - } - *x = Property_Meaning(value) - return nil -} - -type Property_FtsTokenizationOption int32 - -const ( - Property_HTML Property_FtsTokenizationOption = 1 - Property_ATOM Property_FtsTokenizationOption = 2 -) - -var Property_FtsTokenizationOption_name = map[int32]string{ - 1: "HTML", - 2: "ATOM", -} -var Property_FtsTokenizationOption_value = map[string]int32{ - "HTML": 1, - "ATOM": 2, -} - -func (x Property_FtsTokenizationOption) Enum() *Property_FtsTokenizationOption { - p := new(Property_FtsTokenizationOption) - *p = x - return p -} -func (x Property_FtsTokenizationOption) String() string { - return proto.EnumName(Property_FtsTokenizationOption_name, int32(x)) -} -func (x *Property_FtsTokenizationOption) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Property_FtsTokenizationOption_value, data, "Property_FtsTokenizationOption") - if err != nil { - return err - } - *x = Property_FtsTokenizationOption(value) - return nil -} - -type EntityProto_Kind int32 - -const ( - EntityProto_GD_CONTACT EntityProto_Kind = 1 - EntityProto_GD_EVENT EntityProto_Kind = 2 - EntityProto_GD_MESSAGE EntityProto_Kind = 3 -) - -var EntityProto_Kind_name = map[int32]string{ - 1: "GD_CONTACT", - 2: "GD_EVENT", - 3: "GD_MESSAGE", -} -var EntityProto_Kind_value = map[string]int32{ - "GD_CONTACT": 1, - "GD_EVENT": 2, - "GD_MESSAGE": 3, -} - -func (x EntityProto_Kind) Enum() *EntityProto_Kind { - p := new(EntityProto_Kind) - *p = x - return p -} -func (x EntityProto_Kind) String() string { - return proto.EnumName(EntityProto_Kind_name, int32(x)) -} -func (x *EntityProto_Kind) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(EntityProto_Kind_value, data, "EntityProto_Kind") - if err != nil { - return err - } - *x = EntityProto_Kind(value) - return nil -} - -type Index_Property_Direction int32 - -const ( - Index_Property_ASCENDING Index_Property_Direction = 1 - Index_Property_DESCENDING Index_Property_Direction = 2 -) - -var Index_Property_Direction_name = map[int32]string{ - 1: "ASCENDING", - 2: "DESCENDING", -} -var Index_Property_Direction_value = map[string]int32{ - "ASCENDING": 1, - "DESCENDING": 2, -} - -func (x Index_Property_Direction) Enum() *Index_Property_Direction { - p := new(Index_Property_Direction) - *p = x - return p -} -func (x Index_Property_Direction) String() string { - return proto.EnumName(Index_Property_Direction_name, int32(x)) -} -func (x *Index_Property_Direction) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Index_Property_Direction_value, data, "Index_Property_Direction") - if err != nil { - return err - } - *x = Index_Property_Direction(value) - return nil -} - -type CompositeIndex_State int32 - -const ( - CompositeIndex_WRITE_ONLY CompositeIndex_State = 1 - CompositeIndex_READ_WRITE CompositeIndex_State = 2 - CompositeIndex_DELETED CompositeIndex_State = 3 - CompositeIndex_ERROR CompositeIndex_State = 4 -) - -var CompositeIndex_State_name = map[int32]string{ - 1: "WRITE_ONLY", - 2: "READ_WRITE", - 3: "DELETED", - 4: "ERROR", -} -var CompositeIndex_State_value = map[string]int32{ - "WRITE_ONLY": 1, - "READ_WRITE": 2, - "DELETED": 3, - "ERROR": 4, -} - -func (x CompositeIndex_State) Enum() *CompositeIndex_State { - p := new(CompositeIndex_State) - *p = x - return p -} -func (x CompositeIndex_State) String() string { - return proto.EnumName(CompositeIndex_State_name, int32(x)) -} -func (x *CompositeIndex_State) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(CompositeIndex_State_value, data, "CompositeIndex_State") - if err != nil { - return err - } - *x = CompositeIndex_State(value) - return nil -} - -type Snapshot_Status int32 - -const ( - Snapshot_INACTIVE Snapshot_Status = 0 - Snapshot_ACTIVE Snapshot_Status = 1 -) - -var Snapshot_Status_name = map[int32]string{ - 0: "INACTIVE", - 1: "ACTIVE", -} -var Snapshot_Status_value = map[string]int32{ - "INACTIVE": 0, - "ACTIVE": 1, -} - -func (x Snapshot_Status) Enum() *Snapshot_Status { - p := new(Snapshot_Status) - *p = x - return p -} -func (x Snapshot_Status) String() string { - return proto.EnumName(Snapshot_Status_name, int32(x)) -} -func (x *Snapshot_Status) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Snapshot_Status_value, data, "Snapshot_Status") - if err != nil { - return err - } - *x = Snapshot_Status(value) - return nil -} - -type Query_Hint int32 - -const ( - Query_ORDER_FIRST Query_Hint = 1 - Query_ANCESTOR_FIRST Query_Hint = 2 - Query_FILTER_FIRST Query_Hint = 3 -) - -var Query_Hint_name = map[int32]string{ - 1: "ORDER_FIRST", - 2: "ANCESTOR_FIRST", - 3: "FILTER_FIRST", -} -var Query_Hint_value = map[string]int32{ - "ORDER_FIRST": 1, - "ANCESTOR_FIRST": 2, - "FILTER_FIRST": 3, -} - -func (x Query_Hint) Enum() *Query_Hint { - p := new(Query_Hint) - *p = x - return p -} -func (x Query_Hint) String() string { - return proto.EnumName(Query_Hint_name, int32(x)) -} -func (x *Query_Hint) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Query_Hint_value, data, "Query_Hint") - if err != nil { - return err - } - *x = Query_Hint(value) - return nil -} - -type Query_Filter_Operator int32 - -const ( - Query_Filter_LESS_THAN Query_Filter_Operator = 1 - Query_Filter_LESS_THAN_OR_EQUAL Query_Filter_Operator = 2 - Query_Filter_GREATER_THAN Query_Filter_Operator = 3 - Query_Filter_GREATER_THAN_OR_EQUAL Query_Filter_Operator = 4 - Query_Filter_EQUAL Query_Filter_Operator = 5 - Query_Filter_IN Query_Filter_Operator = 6 - Query_Filter_EXISTS Query_Filter_Operator = 7 -) - -var Query_Filter_Operator_name = map[int32]string{ - 1: "LESS_THAN", - 2: "LESS_THAN_OR_EQUAL", - 3: "GREATER_THAN", - 4: "GREATER_THAN_OR_EQUAL", - 5: "EQUAL", - 6: "IN", - 7: "EXISTS", -} -var Query_Filter_Operator_value = map[string]int32{ - "LESS_THAN": 1, - "LESS_THAN_OR_EQUAL": 2, - "GREATER_THAN": 3, - "GREATER_THAN_OR_EQUAL": 4, - "EQUAL": 5, - "IN": 6, - "EXISTS": 7, -} - -func (x Query_Filter_Operator) Enum() *Query_Filter_Operator { - p := new(Query_Filter_Operator) - *p = x - return p -} -func (x Query_Filter_Operator) String() string { - return proto.EnumName(Query_Filter_Operator_name, int32(x)) -} -func (x *Query_Filter_Operator) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Query_Filter_Operator_value, data, "Query_Filter_Operator") - if err != nil { - return err - } - *x = Query_Filter_Operator(value) - return nil -} - -type Query_Order_Direction int32 - -const ( - Query_Order_ASCENDING Query_Order_Direction = 1 - Query_Order_DESCENDING Query_Order_Direction = 2 -) - -var Query_Order_Direction_name = map[int32]string{ - 1: "ASCENDING", - 2: "DESCENDING", -} -var Query_Order_Direction_value = map[string]int32{ - "ASCENDING": 1, - "DESCENDING": 2, -} - -func (x Query_Order_Direction) Enum() *Query_Order_Direction { - p := new(Query_Order_Direction) - *p = x - return p -} -func (x Query_Order_Direction) String() string { - return proto.EnumName(Query_Order_Direction_name, int32(x)) -} -func (x *Query_Order_Direction) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Query_Order_Direction_value, data, "Query_Order_Direction") - if err != nil { - return err - } - *x = Query_Order_Direction(value) - return nil -} - -type Error_ErrorCode int32 - -const ( - Error_BAD_REQUEST Error_ErrorCode = 1 - Error_CONCURRENT_TRANSACTION Error_ErrorCode = 2 - Error_INTERNAL_ERROR Error_ErrorCode = 3 - Error_NEED_INDEX Error_ErrorCode = 4 - Error_TIMEOUT Error_ErrorCode = 5 - Error_PERMISSION_DENIED Error_ErrorCode = 6 - Error_BIGTABLE_ERROR Error_ErrorCode = 7 - Error_COMMITTED_BUT_STILL_APPLYING Error_ErrorCode = 8 - Error_CAPABILITY_DISABLED Error_ErrorCode = 9 - Error_TRY_ALTERNATE_BACKEND Error_ErrorCode = 10 - Error_SAFE_TIME_TOO_OLD Error_ErrorCode = 11 -) - -var Error_ErrorCode_name = map[int32]string{ - 1: "BAD_REQUEST", - 2: "CONCURRENT_TRANSACTION", - 3: "INTERNAL_ERROR", - 4: "NEED_INDEX", - 5: "TIMEOUT", - 6: "PERMISSION_DENIED", - 7: "BIGTABLE_ERROR", - 8: "COMMITTED_BUT_STILL_APPLYING", - 9: "CAPABILITY_DISABLED", - 10: "TRY_ALTERNATE_BACKEND", - 11: "SAFE_TIME_TOO_OLD", -} -var Error_ErrorCode_value = map[string]int32{ - "BAD_REQUEST": 1, - "CONCURRENT_TRANSACTION": 2, - "INTERNAL_ERROR": 3, - "NEED_INDEX": 4, - "TIMEOUT": 5, - "PERMISSION_DENIED": 6, - "BIGTABLE_ERROR": 7, - "COMMITTED_BUT_STILL_APPLYING": 8, - "CAPABILITY_DISABLED": 9, - "TRY_ALTERNATE_BACKEND": 10, - "SAFE_TIME_TOO_OLD": 11, -} - -func (x Error_ErrorCode) Enum() *Error_ErrorCode { - p := new(Error_ErrorCode) - *p = x - return p -} -func (x Error_ErrorCode) String() string { - return proto.EnumName(Error_ErrorCode_name, int32(x)) -} -func (x *Error_ErrorCode) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(Error_ErrorCode_value, data, "Error_ErrorCode") - if err != nil { - return err - } - *x = Error_ErrorCode(value) - return nil -} - -type PutRequest_AutoIdPolicy int32 - -const ( - PutRequest_CURRENT PutRequest_AutoIdPolicy = 0 - PutRequest_SEQUENTIAL PutRequest_AutoIdPolicy = 1 -) - -var PutRequest_AutoIdPolicy_name = map[int32]string{ - 0: "CURRENT", - 1: "SEQUENTIAL", -} -var PutRequest_AutoIdPolicy_value = map[string]int32{ - "CURRENT": 0, - "SEQUENTIAL": 1, -} - -func (x PutRequest_AutoIdPolicy) Enum() *PutRequest_AutoIdPolicy { - p := new(PutRequest_AutoIdPolicy) - *p = x - return p -} -func (x PutRequest_AutoIdPolicy) String() string { - return proto.EnumName(PutRequest_AutoIdPolicy_name, int32(x)) -} -func (x *PutRequest_AutoIdPolicy) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(PutRequest_AutoIdPolicy_value, data, "PutRequest_AutoIdPolicy") - if err != nil { - return err - } - *x = PutRequest_AutoIdPolicy(value) - return nil -} - -type Action struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *Action) Reset() { *m = Action{} } -func (m *Action) String() string { return proto.CompactTextString(m) } -func (*Action) ProtoMessage() {} - -type PropertyValue struct { - Int64Value *int64 `protobuf:"varint,1,opt,name=int64Value" json:"int64Value,omitempty"` - BooleanValue *bool `protobuf:"varint,2,opt,name=booleanValue" json:"booleanValue,omitempty"` - StringValue *string `protobuf:"bytes,3,opt,name=stringValue" json:"stringValue,omitempty"` - DoubleValue *float64 `protobuf:"fixed64,4,opt,name=doubleValue" json:"doubleValue,omitempty"` - Pointvalue *PropertyValue_PointValue `protobuf:"group,5,opt,name=PointValue" json:"pointvalue,omitempty"` - Uservalue *PropertyValue_UserValue `protobuf:"group,8,opt,name=UserValue" json:"uservalue,omitempty"` - Referencevalue *PropertyValue_ReferenceValue `protobuf:"group,12,opt,name=ReferenceValue" json:"referencevalue,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PropertyValue) Reset() { *m = PropertyValue{} } -func (m *PropertyValue) String() string { return proto.CompactTextString(m) } -func (*PropertyValue) ProtoMessage() {} - -func (m *PropertyValue) GetInt64Value() int64 { - if m != nil && m.Int64Value != nil { - return *m.Int64Value - } - return 0 -} - -func (m *PropertyValue) GetBooleanValue() bool { - if m != nil && m.BooleanValue != nil { - return *m.BooleanValue - } - return false -} - -func (m *PropertyValue) GetStringValue() string { - if m != nil && m.StringValue != nil { - return *m.StringValue - } - return "" -} - -func (m *PropertyValue) GetDoubleValue() float64 { - if m != nil && m.DoubleValue != nil { - return *m.DoubleValue - } - return 0 -} - -func (m *PropertyValue) GetPointvalue() *PropertyValue_PointValue { - if m != nil { - return m.Pointvalue - } - return nil -} - -func (m *PropertyValue) GetUservalue() *PropertyValue_UserValue { - if m != nil { - return m.Uservalue - } - return nil -} - -func (m *PropertyValue) GetReferencevalue() *PropertyValue_ReferenceValue { - if m != nil { - return m.Referencevalue - } - return nil -} - -type PropertyValue_PointValue struct { - X *float64 `protobuf:"fixed64,6,req,name=x" json:"x,omitempty"` - Y *float64 `protobuf:"fixed64,7,req,name=y" json:"y,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PropertyValue_PointValue) Reset() { *m = PropertyValue_PointValue{} } -func (m *PropertyValue_PointValue) String() string { return proto.CompactTextString(m) } -func (*PropertyValue_PointValue) ProtoMessage() {} - -func (m *PropertyValue_PointValue) GetX() float64 { - if m != nil && m.X != nil { - return *m.X - } - return 0 -} - -func (m *PropertyValue_PointValue) GetY() float64 { - if m != nil && m.Y != nil { - return *m.Y - } - return 0 -} - -type PropertyValue_UserValue struct { - Email *string `protobuf:"bytes,9,req,name=email" json:"email,omitempty"` - AuthDomain *string `protobuf:"bytes,10,req,name=auth_domain" json:"auth_domain,omitempty"` - Nickname *string `protobuf:"bytes,11,opt,name=nickname" json:"nickname,omitempty"` - FederatedIdentity *string `protobuf:"bytes,21,opt,name=federated_identity" json:"federated_identity,omitempty"` - FederatedProvider *string `protobuf:"bytes,22,opt,name=federated_provider" json:"federated_provider,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PropertyValue_UserValue) Reset() { *m = PropertyValue_UserValue{} } -func (m *PropertyValue_UserValue) String() string { return proto.CompactTextString(m) } -func (*PropertyValue_UserValue) ProtoMessage() {} - -func (m *PropertyValue_UserValue) GetEmail() string { - if m != nil && m.Email != nil { - return *m.Email - } - return "" -} - -func (m *PropertyValue_UserValue) GetAuthDomain() string { - if m != nil && m.AuthDomain != nil { - return *m.AuthDomain - } - return "" -} - -func (m *PropertyValue_UserValue) GetNickname() string { - if m != nil && m.Nickname != nil { - return *m.Nickname - } - return "" -} - -func (m *PropertyValue_UserValue) GetFederatedIdentity() string { - if m != nil && m.FederatedIdentity != nil { - return *m.FederatedIdentity - } - return "" -} - -func (m *PropertyValue_UserValue) GetFederatedProvider() string { - if m != nil && m.FederatedProvider != nil { - return *m.FederatedProvider - } - return "" -} - -type PropertyValue_ReferenceValue struct { - App *string `protobuf:"bytes,13,req,name=app" json:"app,omitempty"` - NameSpace *string `protobuf:"bytes,20,opt,name=name_space" json:"name_space,omitempty"` - Pathelement []*PropertyValue_ReferenceValue_PathElement `protobuf:"group,14,rep,name=PathElement" json:"pathelement,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PropertyValue_ReferenceValue) Reset() { *m = PropertyValue_ReferenceValue{} } -func (m *PropertyValue_ReferenceValue) String() string { return proto.CompactTextString(m) } -func (*PropertyValue_ReferenceValue) ProtoMessage() {} - -func (m *PropertyValue_ReferenceValue) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -func (m *PropertyValue_ReferenceValue) GetNameSpace() string { - if m != nil && m.NameSpace != nil { - return *m.NameSpace - } - return "" -} - -func (m *PropertyValue_ReferenceValue) GetPathelement() []*PropertyValue_ReferenceValue_PathElement { - if m != nil { - return m.Pathelement - } - return nil -} - -type PropertyValue_ReferenceValue_PathElement struct { - Type *string `protobuf:"bytes,15,req,name=type" json:"type,omitempty"` - Id *int64 `protobuf:"varint,16,opt,name=id" json:"id,omitempty"` - Name *string `protobuf:"bytes,17,opt,name=name" json:"name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PropertyValue_ReferenceValue_PathElement) Reset() { - *m = PropertyValue_ReferenceValue_PathElement{} -} -func (m *PropertyValue_ReferenceValue_PathElement) String() string { return proto.CompactTextString(m) } -func (*PropertyValue_ReferenceValue_PathElement) ProtoMessage() {} - -func (m *PropertyValue_ReferenceValue_PathElement) GetType() string { - if m != nil && m.Type != nil { - return *m.Type - } - return "" -} - -func (m *PropertyValue_ReferenceValue_PathElement) GetId() int64 { - if m != nil && m.Id != nil { - return *m.Id - } - return 0 -} - -func (m *PropertyValue_ReferenceValue_PathElement) GetName() string { - if m != nil && m.Name != nil { - return *m.Name - } - return "" -} - -type Property struct { - Meaning *Property_Meaning `protobuf:"varint,1,opt,name=meaning,enum=appengine.Property_Meaning,def=0" json:"meaning,omitempty"` - MeaningUri *string `protobuf:"bytes,2,opt,name=meaning_uri" json:"meaning_uri,omitempty"` - Name *string `protobuf:"bytes,3,req,name=name" json:"name,omitempty"` - Value *PropertyValue `protobuf:"bytes,5,req,name=value" json:"value,omitempty"` - Multiple *bool `protobuf:"varint,4,req,name=multiple" json:"multiple,omitempty"` - Searchable *bool `protobuf:"varint,6,opt,name=searchable,def=0" json:"searchable,omitempty"` - FtsTokenizationOption *Property_FtsTokenizationOption `protobuf:"varint,8,opt,name=fts_tokenization_option,enum=appengine.Property_FtsTokenizationOption" json:"fts_tokenization_option,omitempty"` - Locale *string `protobuf:"bytes,9,opt,name=locale,def=en" json:"locale,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Property) Reset() { *m = Property{} } -func (m *Property) String() string { return proto.CompactTextString(m) } -func (*Property) ProtoMessage() {} - -const Default_Property_Meaning Property_Meaning = Property_NO_MEANING -const Default_Property_Searchable bool = false -const Default_Property_Locale string = "en" - -func (m *Property) GetMeaning() Property_Meaning { - if m != nil && m.Meaning != nil { - return *m.Meaning - } - return Default_Property_Meaning -} - -func (m *Property) GetMeaningUri() string { - if m != nil && m.MeaningUri != nil { - return *m.MeaningUri - } - return "" -} - -func (m *Property) GetName() string { - if m != nil && m.Name != nil { - return *m.Name - } - return "" -} - -func (m *Property) GetValue() *PropertyValue { - if m != nil { - return m.Value - } - return nil -} - -func (m *Property) GetMultiple() bool { - if m != nil && m.Multiple != nil { - return *m.Multiple - } - return false -} - -func (m *Property) GetSearchable() bool { - if m != nil && m.Searchable != nil { - return *m.Searchable - } - return Default_Property_Searchable -} - -func (m *Property) GetFtsTokenizationOption() Property_FtsTokenizationOption { - if m != nil && m.FtsTokenizationOption != nil { - return *m.FtsTokenizationOption - } - return Property_HTML -} - -func (m *Property) GetLocale() string { - if m != nil && m.Locale != nil { - return *m.Locale - } - return Default_Property_Locale -} - -type Path struct { - Element []*Path_Element `protobuf:"group,1,rep,name=Element" json:"element,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Path) Reset() { *m = Path{} } -func (m *Path) String() string { return proto.CompactTextString(m) } -func (*Path) ProtoMessage() {} - -func (m *Path) GetElement() []*Path_Element { - if m != nil { - return m.Element - } - return nil -} - -type Path_Element struct { - Type *string `protobuf:"bytes,2,req,name=type" json:"type,omitempty"` - Id *int64 `protobuf:"varint,3,opt,name=id" json:"id,omitempty"` - Name *string `protobuf:"bytes,4,opt,name=name" json:"name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Path_Element) Reset() { *m = Path_Element{} } -func (m *Path_Element) String() string { return proto.CompactTextString(m) } -func (*Path_Element) ProtoMessage() {} - -func (m *Path_Element) GetType() string { - if m != nil && m.Type != nil { - return *m.Type - } - return "" -} - -func (m *Path_Element) GetId() int64 { - if m != nil && m.Id != nil { - return *m.Id - } - return 0 -} - -func (m *Path_Element) GetName() string { - if m != nil && m.Name != nil { - return *m.Name - } - return "" -} - -type Reference struct { - App *string `protobuf:"bytes,13,req,name=app" json:"app,omitempty"` - NameSpace *string `protobuf:"bytes,20,opt,name=name_space" json:"name_space,omitempty"` - Path *Path `protobuf:"bytes,14,req,name=path" json:"path,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Reference) Reset() { *m = Reference{} } -func (m *Reference) String() string { return proto.CompactTextString(m) } -func (*Reference) ProtoMessage() {} - -func (m *Reference) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -func (m *Reference) GetNameSpace() string { - if m != nil && m.NameSpace != nil { - return *m.NameSpace - } - return "" -} - -func (m *Reference) GetPath() *Path { - if m != nil { - return m.Path - } - return nil -} - -type User struct { - Email *string `protobuf:"bytes,1,req,name=email" json:"email,omitempty"` - AuthDomain *string `protobuf:"bytes,2,req,name=auth_domain" json:"auth_domain,omitempty"` - Nickname *string `protobuf:"bytes,3,opt,name=nickname" json:"nickname,omitempty"` - FederatedIdentity *string `protobuf:"bytes,6,opt,name=federated_identity" json:"federated_identity,omitempty"` - FederatedProvider *string `protobuf:"bytes,7,opt,name=federated_provider" json:"federated_provider,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *User) Reset() { *m = User{} } -func (m *User) String() string { return proto.CompactTextString(m) } -func (*User) ProtoMessage() {} - -func (m *User) GetEmail() string { - if m != nil && m.Email != nil { - return *m.Email - } - return "" -} - -func (m *User) GetAuthDomain() string { - if m != nil && m.AuthDomain != nil { - return *m.AuthDomain - } - return "" -} - -func (m *User) GetNickname() string { - if m != nil && m.Nickname != nil { - return *m.Nickname - } - return "" -} - -func (m *User) GetFederatedIdentity() string { - if m != nil && m.FederatedIdentity != nil { - return *m.FederatedIdentity - } - return "" -} - -func (m *User) GetFederatedProvider() string { - if m != nil && m.FederatedProvider != nil { - return *m.FederatedProvider - } - return "" -} - -type EntityProto struct { - Key *Reference `protobuf:"bytes,13,req,name=key" json:"key,omitempty"` - EntityGroup *Path `protobuf:"bytes,16,req,name=entity_group" json:"entity_group,omitempty"` - Owner *User `protobuf:"bytes,17,opt,name=owner" json:"owner,omitempty"` - Kind *EntityProto_Kind `protobuf:"varint,4,opt,name=kind,enum=appengine.EntityProto_Kind" json:"kind,omitempty"` - KindUri *string `protobuf:"bytes,5,opt,name=kind_uri" json:"kind_uri,omitempty"` - Property []*Property `protobuf:"bytes,14,rep,name=property" json:"property,omitempty"` - RawProperty []*Property `protobuf:"bytes,15,rep,name=raw_property" json:"raw_property,omitempty"` - Rank *int32 `protobuf:"varint,18,opt,name=rank" json:"rank,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *EntityProto) Reset() { *m = EntityProto{} } -func (m *EntityProto) String() string { return proto.CompactTextString(m) } -func (*EntityProto) ProtoMessage() {} - -func (m *EntityProto) GetKey() *Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *EntityProto) GetEntityGroup() *Path { - if m != nil { - return m.EntityGroup - } - return nil -} - -func (m *EntityProto) GetOwner() *User { - if m != nil { - return m.Owner - } - return nil -} - -func (m *EntityProto) GetKind() EntityProto_Kind { - if m != nil && m.Kind != nil { - return *m.Kind - } - return EntityProto_GD_CONTACT -} - -func (m *EntityProto) GetKindUri() string { - if m != nil && m.KindUri != nil { - return *m.KindUri - } - return "" -} - -func (m *EntityProto) GetProperty() []*Property { - if m != nil { - return m.Property - } - return nil -} - -func (m *EntityProto) GetRawProperty() []*Property { - if m != nil { - return m.RawProperty - } - return nil -} - -func (m *EntityProto) GetRank() int32 { - if m != nil && m.Rank != nil { - return *m.Rank - } - return 0 -} - -type CompositeProperty struct { - IndexId *int64 `protobuf:"varint,1,req,name=index_id" json:"index_id,omitempty"` - Value []string `protobuf:"bytes,2,rep,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompositeProperty) Reset() { *m = CompositeProperty{} } -func (m *CompositeProperty) String() string { return proto.CompactTextString(m) } -func (*CompositeProperty) ProtoMessage() {} - -func (m *CompositeProperty) GetIndexId() int64 { - if m != nil && m.IndexId != nil { - return *m.IndexId - } - return 0 -} - -func (m *CompositeProperty) GetValue() []string { - if m != nil { - return m.Value - } - return nil -} - -type Index struct { - EntityType *string `protobuf:"bytes,1,req,name=entity_type" json:"entity_type,omitempty"` - Ancestor *bool `protobuf:"varint,5,req,name=ancestor" json:"ancestor,omitempty"` - Property []*Index_Property `protobuf:"group,2,rep,name=Property" json:"property,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Index) Reset() { *m = Index{} } -func (m *Index) String() string { return proto.CompactTextString(m) } -func (*Index) ProtoMessage() {} - -func (m *Index) GetEntityType() string { - if m != nil && m.EntityType != nil { - return *m.EntityType - } - return "" -} - -func (m *Index) GetAncestor() bool { - if m != nil && m.Ancestor != nil { - return *m.Ancestor - } - return false -} - -func (m *Index) GetProperty() []*Index_Property { - if m != nil { - return m.Property - } - return nil -} - -type Index_Property struct { - Name *string `protobuf:"bytes,3,req,name=name" json:"name,omitempty"` - Direction *Index_Property_Direction `protobuf:"varint,4,opt,name=direction,enum=appengine.Index_Property_Direction,def=1" json:"direction,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Index_Property) Reset() { *m = Index_Property{} } -func (m *Index_Property) String() string { return proto.CompactTextString(m) } -func (*Index_Property) ProtoMessage() {} - -const Default_Index_Property_Direction Index_Property_Direction = Index_Property_ASCENDING - -func (m *Index_Property) GetName() string { - if m != nil && m.Name != nil { - return *m.Name - } - return "" -} - -func (m *Index_Property) GetDirection() Index_Property_Direction { - if m != nil && m.Direction != nil { - return *m.Direction - } - return Default_Index_Property_Direction -} - -type CompositeIndex struct { - AppId *string `protobuf:"bytes,1,req,name=app_id" json:"app_id,omitempty"` - Id *int64 `protobuf:"varint,2,req,name=id" json:"id,omitempty"` - Definition *Index `protobuf:"bytes,3,req,name=definition" json:"definition,omitempty"` - State *CompositeIndex_State `protobuf:"varint,4,req,name=state,enum=appengine.CompositeIndex_State" json:"state,omitempty"` - OnlyUseIfRequired *bool `protobuf:"varint,6,opt,name=only_use_if_required,def=0" json:"only_use_if_required,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompositeIndex) Reset() { *m = CompositeIndex{} } -func (m *CompositeIndex) String() string { return proto.CompactTextString(m) } -func (*CompositeIndex) ProtoMessage() {} - -const Default_CompositeIndex_OnlyUseIfRequired bool = false - -func (m *CompositeIndex) GetAppId() string { - if m != nil && m.AppId != nil { - return *m.AppId - } - return "" -} - -func (m *CompositeIndex) GetId() int64 { - if m != nil && m.Id != nil { - return *m.Id - } - return 0 -} - -func (m *CompositeIndex) GetDefinition() *Index { - if m != nil { - return m.Definition - } - return nil -} - -func (m *CompositeIndex) GetState() CompositeIndex_State { - if m != nil && m.State != nil { - return *m.State - } - return CompositeIndex_WRITE_ONLY -} - -func (m *CompositeIndex) GetOnlyUseIfRequired() bool { - if m != nil && m.OnlyUseIfRequired != nil { - return *m.OnlyUseIfRequired - } - return Default_CompositeIndex_OnlyUseIfRequired -} - -type IndexPostfix struct { - IndexValue []*IndexPostfix_IndexValue `protobuf:"bytes,1,rep,name=index_value" json:"index_value,omitempty"` - Key *Reference `protobuf:"bytes,2,opt,name=key" json:"key,omitempty"` - Before *bool `protobuf:"varint,3,opt,name=before,def=1" json:"before,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *IndexPostfix) Reset() { *m = IndexPostfix{} } -func (m *IndexPostfix) String() string { return proto.CompactTextString(m) } -func (*IndexPostfix) ProtoMessage() {} - -const Default_IndexPostfix_Before bool = true - -func (m *IndexPostfix) GetIndexValue() []*IndexPostfix_IndexValue { - if m != nil { - return m.IndexValue - } - return nil -} - -func (m *IndexPostfix) GetKey() *Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *IndexPostfix) GetBefore() bool { - if m != nil && m.Before != nil { - return *m.Before - } - return Default_IndexPostfix_Before -} - -type IndexPostfix_IndexValue struct { - PropertyName *string `protobuf:"bytes,1,req,name=property_name" json:"property_name,omitempty"` - Value *PropertyValue `protobuf:"bytes,2,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *IndexPostfix_IndexValue) Reset() { *m = IndexPostfix_IndexValue{} } -func (m *IndexPostfix_IndexValue) String() string { return proto.CompactTextString(m) } -func (*IndexPostfix_IndexValue) ProtoMessage() {} - -func (m *IndexPostfix_IndexValue) GetPropertyName() string { - if m != nil && m.PropertyName != nil { - return *m.PropertyName - } - return "" -} - -func (m *IndexPostfix_IndexValue) GetValue() *PropertyValue { - if m != nil { - return m.Value - } - return nil -} - -type IndexPosition struct { - Key *string `protobuf:"bytes,1,opt,name=key" json:"key,omitempty"` - Before *bool `protobuf:"varint,2,opt,name=before,def=1" json:"before,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *IndexPosition) Reset() { *m = IndexPosition{} } -func (m *IndexPosition) String() string { return proto.CompactTextString(m) } -func (*IndexPosition) ProtoMessage() {} - -const Default_IndexPosition_Before bool = true - -func (m *IndexPosition) GetKey() string { - if m != nil && m.Key != nil { - return *m.Key - } - return "" -} - -func (m *IndexPosition) GetBefore() bool { - if m != nil && m.Before != nil { - return *m.Before - } - return Default_IndexPosition_Before -} - -type Snapshot struct { - Ts *int64 `protobuf:"varint,1,req,name=ts" json:"ts,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Snapshot) Reset() { *m = Snapshot{} } -func (m *Snapshot) String() string { return proto.CompactTextString(m) } -func (*Snapshot) ProtoMessage() {} - -func (m *Snapshot) GetTs() int64 { - if m != nil && m.Ts != nil { - return *m.Ts - } - return 0 -} - -type InternalHeader struct { - Qos *string `protobuf:"bytes,1,opt,name=qos" json:"qos,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *InternalHeader) Reset() { *m = InternalHeader{} } -func (m *InternalHeader) String() string { return proto.CompactTextString(m) } -func (*InternalHeader) ProtoMessage() {} - -func (m *InternalHeader) GetQos() string { - if m != nil && m.Qos != nil { - return *m.Qos - } - return "" -} - -type Transaction struct { - Header *InternalHeader `protobuf:"bytes,4,opt,name=header" json:"header,omitempty"` - Handle *uint64 `protobuf:"fixed64,1,req,name=handle" json:"handle,omitempty"` - App *string `protobuf:"bytes,2,req,name=app" json:"app,omitempty"` - MarkChanges *bool `protobuf:"varint,3,opt,name=mark_changes,def=0" json:"mark_changes,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Transaction) Reset() { *m = Transaction{} } -func (m *Transaction) String() string { return proto.CompactTextString(m) } -func (*Transaction) ProtoMessage() {} - -const Default_Transaction_MarkChanges bool = false - -func (m *Transaction) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *Transaction) GetHandle() uint64 { - if m != nil && m.Handle != nil { - return *m.Handle - } - return 0 -} - -func (m *Transaction) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -func (m *Transaction) GetMarkChanges() bool { - if m != nil && m.MarkChanges != nil { - return *m.MarkChanges - } - return Default_Transaction_MarkChanges -} - -type Query struct { - Header *InternalHeader `protobuf:"bytes,39,opt,name=header" json:"header,omitempty"` - App *string `protobuf:"bytes,1,req,name=app" json:"app,omitempty"` - NameSpace *string `protobuf:"bytes,29,opt,name=name_space" json:"name_space,omitempty"` - Kind *string `protobuf:"bytes,3,opt,name=kind" json:"kind,omitempty"` - Ancestor *Reference `protobuf:"bytes,17,opt,name=ancestor" json:"ancestor,omitempty"` - Filter []*Query_Filter `protobuf:"group,4,rep,name=Filter" json:"filter,omitempty"` - SearchQuery *string `protobuf:"bytes,8,opt,name=search_query" json:"search_query,omitempty"` - Order []*Query_Order `protobuf:"group,9,rep,name=Order" json:"order,omitempty"` - Hint *Query_Hint `protobuf:"varint,18,opt,name=hint,enum=appengine.Query_Hint" json:"hint,omitempty"` - Count *int32 `protobuf:"varint,23,opt,name=count" json:"count,omitempty"` - Offset *int32 `protobuf:"varint,12,opt,name=offset,def=0" json:"offset,omitempty"` - Limit *int32 `protobuf:"varint,16,opt,name=limit" json:"limit,omitempty"` - CompiledCursor *CompiledCursor `protobuf:"bytes,30,opt,name=compiled_cursor" json:"compiled_cursor,omitempty"` - EndCompiledCursor *CompiledCursor `protobuf:"bytes,31,opt,name=end_compiled_cursor" json:"end_compiled_cursor,omitempty"` - CompositeIndex []*CompositeIndex `protobuf:"bytes,19,rep,name=composite_index" json:"composite_index,omitempty"` - RequirePerfectPlan *bool `protobuf:"varint,20,opt,name=require_perfect_plan,def=0" json:"require_perfect_plan,omitempty"` - KeysOnly *bool `protobuf:"varint,21,opt,name=keys_only,def=0" json:"keys_only,omitempty"` - Transaction *Transaction `protobuf:"bytes,22,opt,name=transaction" json:"transaction,omitempty"` - Compile *bool `protobuf:"varint,25,opt,name=compile,def=0" json:"compile,omitempty"` - FailoverMs *int64 `protobuf:"varint,26,opt,name=failover_ms" json:"failover_ms,omitempty"` - Strong *bool `protobuf:"varint,32,opt,name=strong" json:"strong,omitempty"` - PropertyName []string `protobuf:"bytes,33,rep,name=property_name" json:"property_name,omitempty"` - GroupByPropertyName []string `protobuf:"bytes,34,rep,name=group_by_property_name" json:"group_by_property_name,omitempty"` - Distinct *bool `protobuf:"varint,24,opt,name=distinct" json:"distinct,omitempty"` - MinSafeTimeSeconds *int64 `protobuf:"varint,35,opt,name=min_safe_time_seconds" json:"min_safe_time_seconds,omitempty"` - SafeReplicaName []string `protobuf:"bytes,36,rep,name=safe_replica_name" json:"safe_replica_name,omitempty"` - PersistOffset *bool `protobuf:"varint,37,opt,name=persist_offset,def=0" json:"persist_offset,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Query) Reset() { *m = Query{} } -func (m *Query) String() string { return proto.CompactTextString(m) } -func (*Query) ProtoMessage() {} - -const Default_Query_Offset int32 = 0 -const Default_Query_RequirePerfectPlan bool = false -const Default_Query_KeysOnly bool = false -const Default_Query_Compile bool = false -const Default_Query_PersistOffset bool = false - -func (m *Query) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *Query) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -func (m *Query) GetNameSpace() string { - if m != nil && m.NameSpace != nil { - return *m.NameSpace - } - return "" -} - -func (m *Query) GetKind() string { - if m != nil && m.Kind != nil { - return *m.Kind - } - return "" -} - -func (m *Query) GetAncestor() *Reference { - if m != nil { - return m.Ancestor - } - return nil -} - -func (m *Query) GetFilter() []*Query_Filter { - if m != nil { - return m.Filter - } - return nil -} - -func (m *Query) GetSearchQuery() string { - if m != nil && m.SearchQuery != nil { - return *m.SearchQuery - } - return "" -} - -func (m *Query) GetOrder() []*Query_Order { - if m != nil { - return m.Order - } - return nil -} - -func (m *Query) GetHint() Query_Hint { - if m != nil && m.Hint != nil { - return *m.Hint - } - return Query_ORDER_FIRST -} - -func (m *Query) GetCount() int32 { - if m != nil && m.Count != nil { - return *m.Count - } - return 0 -} - -func (m *Query) GetOffset() int32 { - if m != nil && m.Offset != nil { - return *m.Offset - } - return Default_Query_Offset -} - -func (m *Query) GetLimit() int32 { - if m != nil && m.Limit != nil { - return *m.Limit - } - return 0 -} - -func (m *Query) GetCompiledCursor() *CompiledCursor { - if m != nil { - return m.CompiledCursor - } - return nil -} - -func (m *Query) GetEndCompiledCursor() *CompiledCursor { - if m != nil { - return m.EndCompiledCursor - } - return nil -} - -func (m *Query) GetCompositeIndex() []*CompositeIndex { - if m != nil { - return m.CompositeIndex - } - return nil -} - -func (m *Query) GetRequirePerfectPlan() bool { - if m != nil && m.RequirePerfectPlan != nil { - return *m.RequirePerfectPlan - } - return Default_Query_RequirePerfectPlan -} - -func (m *Query) GetKeysOnly() bool { - if m != nil && m.KeysOnly != nil { - return *m.KeysOnly - } - return Default_Query_KeysOnly -} - -func (m *Query) GetTransaction() *Transaction { - if m != nil { - return m.Transaction - } - return nil -} - -func (m *Query) GetCompile() bool { - if m != nil && m.Compile != nil { - return *m.Compile - } - return Default_Query_Compile -} - -func (m *Query) GetFailoverMs() int64 { - if m != nil && m.FailoverMs != nil { - return *m.FailoverMs - } - return 0 -} - -func (m *Query) GetStrong() bool { - if m != nil && m.Strong != nil { - return *m.Strong - } - return false -} - -func (m *Query) GetPropertyName() []string { - if m != nil { - return m.PropertyName - } - return nil -} - -func (m *Query) GetGroupByPropertyName() []string { - if m != nil { - return m.GroupByPropertyName - } - return nil -} - -func (m *Query) GetDistinct() bool { - if m != nil && m.Distinct != nil { - return *m.Distinct - } - return false -} - -func (m *Query) GetMinSafeTimeSeconds() int64 { - if m != nil && m.MinSafeTimeSeconds != nil { - return *m.MinSafeTimeSeconds - } - return 0 -} - -func (m *Query) GetSafeReplicaName() []string { - if m != nil { - return m.SafeReplicaName - } - return nil -} - -func (m *Query) GetPersistOffset() bool { - if m != nil && m.PersistOffset != nil { - return *m.PersistOffset - } - return Default_Query_PersistOffset -} - -type Query_Filter struct { - Op *Query_Filter_Operator `protobuf:"varint,6,req,name=op,enum=appengine.Query_Filter_Operator" json:"op,omitempty"` - Property []*Property `protobuf:"bytes,14,rep,name=property" json:"property,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Query_Filter) Reset() { *m = Query_Filter{} } -func (m *Query_Filter) String() string { return proto.CompactTextString(m) } -func (*Query_Filter) ProtoMessage() {} - -func (m *Query_Filter) GetOp() Query_Filter_Operator { - if m != nil && m.Op != nil { - return *m.Op - } - return Query_Filter_LESS_THAN -} - -func (m *Query_Filter) GetProperty() []*Property { - if m != nil { - return m.Property - } - return nil -} - -type Query_Order struct { - Property *string `protobuf:"bytes,10,req,name=property" json:"property,omitempty"` - Direction *Query_Order_Direction `protobuf:"varint,11,opt,name=direction,enum=appengine.Query_Order_Direction,def=1" json:"direction,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Query_Order) Reset() { *m = Query_Order{} } -func (m *Query_Order) String() string { return proto.CompactTextString(m) } -func (*Query_Order) ProtoMessage() {} - -const Default_Query_Order_Direction Query_Order_Direction = Query_Order_ASCENDING - -func (m *Query_Order) GetProperty() string { - if m != nil && m.Property != nil { - return *m.Property - } - return "" -} - -func (m *Query_Order) GetDirection() Query_Order_Direction { - if m != nil && m.Direction != nil { - return *m.Direction - } - return Default_Query_Order_Direction -} - -type CompiledQuery struct { - Primaryscan *CompiledQuery_PrimaryScan `protobuf:"group,1,req,name=PrimaryScan" json:"primaryscan,omitempty"` - Mergejoinscan []*CompiledQuery_MergeJoinScan `protobuf:"group,7,rep,name=MergeJoinScan" json:"mergejoinscan,omitempty"` - IndexDef *Index `protobuf:"bytes,21,opt,name=index_def" json:"index_def,omitempty"` - Offset *int32 `protobuf:"varint,10,opt,name=offset,def=0" json:"offset,omitempty"` - Limit *int32 `protobuf:"varint,11,opt,name=limit" json:"limit,omitempty"` - KeysOnly *bool `protobuf:"varint,12,req,name=keys_only" json:"keys_only,omitempty"` - PropertyName []string `protobuf:"bytes,24,rep,name=property_name" json:"property_name,omitempty"` - DistinctInfixSize *int32 `protobuf:"varint,25,opt,name=distinct_infix_size" json:"distinct_infix_size,omitempty"` - Entityfilter *CompiledQuery_EntityFilter `protobuf:"group,13,opt,name=EntityFilter" json:"entityfilter,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledQuery) Reset() { *m = CompiledQuery{} } -func (m *CompiledQuery) String() string { return proto.CompactTextString(m) } -func (*CompiledQuery) ProtoMessage() {} - -const Default_CompiledQuery_Offset int32 = 0 - -func (m *CompiledQuery) GetPrimaryscan() *CompiledQuery_PrimaryScan { - if m != nil { - return m.Primaryscan - } - return nil -} - -func (m *CompiledQuery) GetMergejoinscan() []*CompiledQuery_MergeJoinScan { - if m != nil { - return m.Mergejoinscan - } - return nil -} - -func (m *CompiledQuery) GetIndexDef() *Index { - if m != nil { - return m.IndexDef - } - return nil -} - -func (m *CompiledQuery) GetOffset() int32 { - if m != nil && m.Offset != nil { - return *m.Offset - } - return Default_CompiledQuery_Offset -} - -func (m *CompiledQuery) GetLimit() int32 { - if m != nil && m.Limit != nil { - return *m.Limit - } - return 0 -} - -func (m *CompiledQuery) GetKeysOnly() bool { - if m != nil && m.KeysOnly != nil { - return *m.KeysOnly - } - return false -} - -func (m *CompiledQuery) GetPropertyName() []string { - if m != nil { - return m.PropertyName - } - return nil -} - -func (m *CompiledQuery) GetDistinctInfixSize() int32 { - if m != nil && m.DistinctInfixSize != nil { - return *m.DistinctInfixSize - } - return 0 -} - -func (m *CompiledQuery) GetEntityfilter() *CompiledQuery_EntityFilter { - if m != nil { - return m.Entityfilter - } - return nil -} - -type CompiledQuery_PrimaryScan struct { - IndexName *string `protobuf:"bytes,2,opt,name=index_name" json:"index_name,omitempty"` - StartKey *string `protobuf:"bytes,3,opt,name=start_key" json:"start_key,omitempty"` - StartInclusive *bool `protobuf:"varint,4,opt,name=start_inclusive" json:"start_inclusive,omitempty"` - EndKey *string `protobuf:"bytes,5,opt,name=end_key" json:"end_key,omitempty"` - EndInclusive *bool `protobuf:"varint,6,opt,name=end_inclusive" json:"end_inclusive,omitempty"` - StartPostfixValue []string `protobuf:"bytes,22,rep,name=start_postfix_value" json:"start_postfix_value,omitempty"` - EndPostfixValue []string `protobuf:"bytes,23,rep,name=end_postfix_value" json:"end_postfix_value,omitempty"` - EndUnappliedLogTimestampUs *int64 `protobuf:"varint,19,opt,name=end_unapplied_log_timestamp_us" json:"end_unapplied_log_timestamp_us,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledQuery_PrimaryScan) Reset() { *m = CompiledQuery_PrimaryScan{} } -func (m *CompiledQuery_PrimaryScan) String() string { return proto.CompactTextString(m) } -func (*CompiledQuery_PrimaryScan) ProtoMessage() {} - -func (m *CompiledQuery_PrimaryScan) GetIndexName() string { - if m != nil && m.IndexName != nil { - return *m.IndexName - } - return "" -} - -func (m *CompiledQuery_PrimaryScan) GetStartKey() string { - if m != nil && m.StartKey != nil { - return *m.StartKey - } - return "" -} - -func (m *CompiledQuery_PrimaryScan) GetStartInclusive() bool { - if m != nil && m.StartInclusive != nil { - return *m.StartInclusive - } - return false -} - -func (m *CompiledQuery_PrimaryScan) GetEndKey() string { - if m != nil && m.EndKey != nil { - return *m.EndKey - } - return "" -} - -func (m *CompiledQuery_PrimaryScan) GetEndInclusive() bool { - if m != nil && m.EndInclusive != nil { - return *m.EndInclusive - } - return false -} - -func (m *CompiledQuery_PrimaryScan) GetStartPostfixValue() []string { - if m != nil { - return m.StartPostfixValue - } - return nil -} - -func (m *CompiledQuery_PrimaryScan) GetEndPostfixValue() []string { - if m != nil { - return m.EndPostfixValue - } - return nil -} - -func (m *CompiledQuery_PrimaryScan) GetEndUnappliedLogTimestampUs() int64 { - if m != nil && m.EndUnappliedLogTimestampUs != nil { - return *m.EndUnappliedLogTimestampUs - } - return 0 -} - -type CompiledQuery_MergeJoinScan struct { - IndexName *string `protobuf:"bytes,8,req,name=index_name" json:"index_name,omitempty"` - PrefixValue []string `protobuf:"bytes,9,rep,name=prefix_value" json:"prefix_value,omitempty"` - ValuePrefix *bool `protobuf:"varint,20,opt,name=value_prefix,def=0" json:"value_prefix,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledQuery_MergeJoinScan) Reset() { *m = CompiledQuery_MergeJoinScan{} } -func (m *CompiledQuery_MergeJoinScan) String() string { return proto.CompactTextString(m) } -func (*CompiledQuery_MergeJoinScan) ProtoMessage() {} - -const Default_CompiledQuery_MergeJoinScan_ValuePrefix bool = false - -func (m *CompiledQuery_MergeJoinScan) GetIndexName() string { - if m != nil && m.IndexName != nil { - return *m.IndexName - } - return "" -} - -func (m *CompiledQuery_MergeJoinScan) GetPrefixValue() []string { - if m != nil { - return m.PrefixValue - } - return nil -} - -func (m *CompiledQuery_MergeJoinScan) GetValuePrefix() bool { - if m != nil && m.ValuePrefix != nil { - return *m.ValuePrefix - } - return Default_CompiledQuery_MergeJoinScan_ValuePrefix -} - -type CompiledQuery_EntityFilter struct { - Distinct *bool `protobuf:"varint,14,opt,name=distinct,def=0" json:"distinct,omitempty"` - Kind *string `protobuf:"bytes,17,opt,name=kind" json:"kind,omitempty"` - Ancestor *Reference `protobuf:"bytes,18,opt,name=ancestor" json:"ancestor,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledQuery_EntityFilter) Reset() { *m = CompiledQuery_EntityFilter{} } -func (m *CompiledQuery_EntityFilter) String() string { return proto.CompactTextString(m) } -func (*CompiledQuery_EntityFilter) ProtoMessage() {} - -const Default_CompiledQuery_EntityFilter_Distinct bool = false - -func (m *CompiledQuery_EntityFilter) GetDistinct() bool { - if m != nil && m.Distinct != nil { - return *m.Distinct - } - return Default_CompiledQuery_EntityFilter_Distinct -} - -func (m *CompiledQuery_EntityFilter) GetKind() string { - if m != nil && m.Kind != nil { - return *m.Kind - } - return "" -} - -func (m *CompiledQuery_EntityFilter) GetAncestor() *Reference { - if m != nil { - return m.Ancestor - } - return nil -} - -type CompiledCursor struct { - Position *CompiledCursor_Position `protobuf:"group,2,opt,name=Position" json:"position,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledCursor) Reset() { *m = CompiledCursor{} } -func (m *CompiledCursor) String() string { return proto.CompactTextString(m) } -func (*CompiledCursor) ProtoMessage() {} - -func (m *CompiledCursor) GetPosition() *CompiledCursor_Position { - if m != nil { - return m.Position - } - return nil -} - -type CompiledCursor_Position struct { - StartKey *string `protobuf:"bytes,27,opt,name=start_key" json:"start_key,omitempty"` - Indexvalue []*CompiledCursor_Position_IndexValue `protobuf:"group,29,rep,name=IndexValue" json:"indexvalue,omitempty"` - Key *Reference `protobuf:"bytes,32,opt,name=key" json:"key,omitempty"` - StartInclusive *bool `protobuf:"varint,28,opt,name=start_inclusive,def=1" json:"start_inclusive,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledCursor_Position) Reset() { *m = CompiledCursor_Position{} } -func (m *CompiledCursor_Position) String() string { return proto.CompactTextString(m) } -func (*CompiledCursor_Position) ProtoMessage() {} - -const Default_CompiledCursor_Position_StartInclusive bool = true - -func (m *CompiledCursor_Position) GetStartKey() string { - if m != nil && m.StartKey != nil { - return *m.StartKey - } - return "" -} - -func (m *CompiledCursor_Position) GetIndexvalue() []*CompiledCursor_Position_IndexValue { - if m != nil { - return m.Indexvalue - } - return nil -} - -func (m *CompiledCursor_Position) GetKey() *Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *CompiledCursor_Position) GetStartInclusive() bool { - if m != nil && m.StartInclusive != nil { - return *m.StartInclusive - } - return Default_CompiledCursor_Position_StartInclusive -} - -type CompiledCursor_Position_IndexValue struct { - Property *string `protobuf:"bytes,30,opt,name=property" json:"property,omitempty"` - Value *PropertyValue `protobuf:"bytes,31,req,name=value" json:"value,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompiledCursor_Position_IndexValue) Reset() { *m = CompiledCursor_Position_IndexValue{} } -func (m *CompiledCursor_Position_IndexValue) String() string { return proto.CompactTextString(m) } -func (*CompiledCursor_Position_IndexValue) ProtoMessage() {} - -func (m *CompiledCursor_Position_IndexValue) GetProperty() string { - if m != nil && m.Property != nil { - return *m.Property - } - return "" -} - -func (m *CompiledCursor_Position_IndexValue) GetValue() *PropertyValue { - if m != nil { - return m.Value - } - return nil -} - -type Cursor struct { - Cursor *uint64 `protobuf:"fixed64,1,req,name=cursor" json:"cursor,omitempty"` - App *string `protobuf:"bytes,2,opt,name=app" json:"app,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Cursor) Reset() { *m = Cursor{} } -func (m *Cursor) String() string { return proto.CompactTextString(m) } -func (*Cursor) ProtoMessage() {} - -func (m *Cursor) GetCursor() uint64 { - if m != nil && m.Cursor != nil { - return *m.Cursor - } - return 0 -} - -func (m *Cursor) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -type Error struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *Error) Reset() { *m = Error{} } -func (m *Error) String() string { return proto.CompactTextString(m) } -func (*Error) ProtoMessage() {} - -type Cost struct { - IndexWrites *int32 `protobuf:"varint,1,opt,name=index_writes" json:"index_writes,omitempty"` - IndexWriteBytes *int32 `protobuf:"varint,2,opt,name=index_write_bytes" json:"index_write_bytes,omitempty"` - EntityWrites *int32 `protobuf:"varint,3,opt,name=entity_writes" json:"entity_writes,omitempty"` - EntityWriteBytes *int32 `protobuf:"varint,4,opt,name=entity_write_bytes" json:"entity_write_bytes,omitempty"` - Commitcost *Cost_CommitCost `protobuf:"group,5,opt,name=CommitCost" json:"commitcost,omitempty"` - ApproximateStorageDelta *int32 `protobuf:"varint,8,opt,name=approximate_storage_delta" json:"approximate_storage_delta,omitempty"` - IdSequenceUpdates *int32 `protobuf:"varint,9,opt,name=id_sequence_updates" json:"id_sequence_updates,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Cost) Reset() { *m = Cost{} } -func (m *Cost) String() string { return proto.CompactTextString(m) } -func (*Cost) ProtoMessage() {} - -func (m *Cost) GetIndexWrites() int32 { - if m != nil && m.IndexWrites != nil { - return *m.IndexWrites - } - return 0 -} - -func (m *Cost) GetIndexWriteBytes() int32 { - if m != nil && m.IndexWriteBytes != nil { - return *m.IndexWriteBytes - } - return 0 -} - -func (m *Cost) GetEntityWrites() int32 { - if m != nil && m.EntityWrites != nil { - return *m.EntityWrites - } - return 0 -} - -func (m *Cost) GetEntityWriteBytes() int32 { - if m != nil && m.EntityWriteBytes != nil { - return *m.EntityWriteBytes - } - return 0 -} - -func (m *Cost) GetCommitcost() *Cost_CommitCost { - if m != nil { - return m.Commitcost - } - return nil -} - -func (m *Cost) GetApproximateStorageDelta() int32 { - if m != nil && m.ApproximateStorageDelta != nil { - return *m.ApproximateStorageDelta - } - return 0 -} - -func (m *Cost) GetIdSequenceUpdates() int32 { - if m != nil && m.IdSequenceUpdates != nil { - return *m.IdSequenceUpdates - } - return 0 -} - -type Cost_CommitCost struct { - RequestedEntityPuts *int32 `protobuf:"varint,6,opt,name=requested_entity_puts" json:"requested_entity_puts,omitempty"` - RequestedEntityDeletes *int32 `protobuf:"varint,7,opt,name=requested_entity_deletes" json:"requested_entity_deletes,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Cost_CommitCost) Reset() { *m = Cost_CommitCost{} } -func (m *Cost_CommitCost) String() string { return proto.CompactTextString(m) } -func (*Cost_CommitCost) ProtoMessage() {} - -func (m *Cost_CommitCost) GetRequestedEntityPuts() int32 { - if m != nil && m.RequestedEntityPuts != nil { - return *m.RequestedEntityPuts - } - return 0 -} - -func (m *Cost_CommitCost) GetRequestedEntityDeletes() int32 { - if m != nil && m.RequestedEntityDeletes != nil { - return *m.RequestedEntityDeletes - } - return 0 -} - -type GetRequest struct { - Header *InternalHeader `protobuf:"bytes,6,opt,name=header" json:"header,omitempty"` - Key []*Reference `protobuf:"bytes,1,rep,name=key" json:"key,omitempty"` - Transaction *Transaction `protobuf:"bytes,2,opt,name=transaction" json:"transaction,omitempty"` - FailoverMs *int64 `protobuf:"varint,3,opt,name=failover_ms" json:"failover_ms,omitempty"` - Strong *bool `protobuf:"varint,4,opt,name=strong" json:"strong,omitempty"` - AllowDeferred *bool `protobuf:"varint,5,opt,name=allow_deferred,def=0" json:"allow_deferred,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetRequest) Reset() { *m = GetRequest{} } -func (m *GetRequest) String() string { return proto.CompactTextString(m) } -func (*GetRequest) ProtoMessage() {} - -const Default_GetRequest_AllowDeferred bool = false - -func (m *GetRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *GetRequest) GetKey() []*Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *GetRequest) GetTransaction() *Transaction { - if m != nil { - return m.Transaction - } - return nil -} - -func (m *GetRequest) GetFailoverMs() int64 { - if m != nil && m.FailoverMs != nil { - return *m.FailoverMs - } - return 0 -} - -func (m *GetRequest) GetStrong() bool { - if m != nil && m.Strong != nil { - return *m.Strong - } - return false -} - -func (m *GetRequest) GetAllowDeferred() bool { - if m != nil && m.AllowDeferred != nil { - return *m.AllowDeferred - } - return Default_GetRequest_AllowDeferred -} - -type GetResponse struct { - Entity []*GetResponse_Entity `protobuf:"group,1,rep,name=Entity" json:"entity,omitempty"` - Deferred []*Reference `protobuf:"bytes,5,rep,name=deferred" json:"deferred,omitempty"` - InOrder *bool `protobuf:"varint,6,opt,name=in_order,def=1" json:"in_order,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetResponse) Reset() { *m = GetResponse{} } -func (m *GetResponse) String() string { return proto.CompactTextString(m) } -func (*GetResponse) ProtoMessage() {} - -const Default_GetResponse_InOrder bool = true - -func (m *GetResponse) GetEntity() []*GetResponse_Entity { - if m != nil { - return m.Entity - } - return nil -} - -func (m *GetResponse) GetDeferred() []*Reference { - if m != nil { - return m.Deferred - } - return nil -} - -func (m *GetResponse) GetInOrder() bool { - if m != nil && m.InOrder != nil { - return *m.InOrder - } - return Default_GetResponse_InOrder -} - -type GetResponse_Entity struct { - Entity *EntityProto `protobuf:"bytes,2,opt,name=entity" json:"entity,omitempty"` - Key *Reference `protobuf:"bytes,4,opt,name=key" json:"key,omitempty"` - Version *int64 `protobuf:"varint,3,opt,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetResponse_Entity) Reset() { *m = GetResponse_Entity{} } -func (m *GetResponse_Entity) String() string { return proto.CompactTextString(m) } -func (*GetResponse_Entity) ProtoMessage() {} - -func (m *GetResponse_Entity) GetEntity() *EntityProto { - if m != nil { - return m.Entity - } - return nil -} - -func (m *GetResponse_Entity) GetKey() *Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *GetResponse_Entity) GetVersion() int64 { - if m != nil && m.Version != nil { - return *m.Version - } - return 0 -} - -type PutRequest struct { - Header *InternalHeader `protobuf:"bytes,11,opt,name=header" json:"header,omitempty"` - Entity []*EntityProto `protobuf:"bytes,1,rep,name=entity" json:"entity,omitempty"` - Transaction *Transaction `protobuf:"bytes,2,opt,name=transaction" json:"transaction,omitempty"` - CompositeIndex []*CompositeIndex `protobuf:"bytes,3,rep,name=composite_index" json:"composite_index,omitempty"` - Trusted *bool `protobuf:"varint,4,opt,name=trusted,def=0" json:"trusted,omitempty"` - Force *bool `protobuf:"varint,7,opt,name=force,def=0" json:"force,omitempty"` - MarkChanges *bool `protobuf:"varint,8,opt,name=mark_changes,def=0" json:"mark_changes,omitempty"` - Snapshot []*Snapshot `protobuf:"bytes,9,rep,name=snapshot" json:"snapshot,omitempty"` - AutoIdPolicy *PutRequest_AutoIdPolicy `protobuf:"varint,10,opt,name=auto_id_policy,enum=appengine.PutRequest_AutoIdPolicy,def=0" json:"auto_id_policy,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PutRequest) Reset() { *m = PutRequest{} } -func (m *PutRequest) String() string { return proto.CompactTextString(m) } -func (*PutRequest) ProtoMessage() {} - -const Default_PutRequest_Trusted bool = false -const Default_PutRequest_Force bool = false -const Default_PutRequest_MarkChanges bool = false -const Default_PutRequest_AutoIdPolicy PutRequest_AutoIdPolicy = PutRequest_CURRENT - -func (m *PutRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *PutRequest) GetEntity() []*EntityProto { - if m != nil { - return m.Entity - } - return nil -} - -func (m *PutRequest) GetTransaction() *Transaction { - if m != nil { - return m.Transaction - } - return nil -} - -func (m *PutRequest) GetCompositeIndex() []*CompositeIndex { - if m != nil { - return m.CompositeIndex - } - return nil -} - -func (m *PutRequest) GetTrusted() bool { - if m != nil && m.Trusted != nil { - return *m.Trusted - } - return Default_PutRequest_Trusted -} - -func (m *PutRequest) GetForce() bool { - if m != nil && m.Force != nil { - return *m.Force - } - return Default_PutRequest_Force -} - -func (m *PutRequest) GetMarkChanges() bool { - if m != nil && m.MarkChanges != nil { - return *m.MarkChanges - } - return Default_PutRequest_MarkChanges -} - -func (m *PutRequest) GetSnapshot() []*Snapshot { - if m != nil { - return m.Snapshot - } - return nil -} - -func (m *PutRequest) GetAutoIdPolicy() PutRequest_AutoIdPolicy { - if m != nil && m.AutoIdPolicy != nil { - return *m.AutoIdPolicy - } - return Default_PutRequest_AutoIdPolicy -} - -type PutResponse struct { - Key []*Reference `protobuf:"bytes,1,rep,name=key" json:"key,omitempty"` - Cost *Cost `protobuf:"bytes,2,opt,name=cost" json:"cost,omitempty"` - Version []int64 `protobuf:"varint,3,rep,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *PutResponse) Reset() { *m = PutResponse{} } -func (m *PutResponse) String() string { return proto.CompactTextString(m) } -func (*PutResponse) ProtoMessage() {} - -func (m *PutResponse) GetKey() []*Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *PutResponse) GetCost() *Cost { - if m != nil { - return m.Cost - } - return nil -} - -func (m *PutResponse) GetVersion() []int64 { - if m != nil { - return m.Version - } - return nil -} - -type TouchRequest struct { - Header *InternalHeader `protobuf:"bytes,10,opt,name=header" json:"header,omitempty"` - Key []*Reference `protobuf:"bytes,1,rep,name=key" json:"key,omitempty"` - CompositeIndex []*CompositeIndex `protobuf:"bytes,2,rep,name=composite_index" json:"composite_index,omitempty"` - Force *bool `protobuf:"varint,3,opt,name=force,def=0" json:"force,omitempty"` - Snapshot []*Snapshot `protobuf:"bytes,9,rep,name=snapshot" json:"snapshot,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *TouchRequest) Reset() { *m = TouchRequest{} } -func (m *TouchRequest) String() string { return proto.CompactTextString(m) } -func (*TouchRequest) ProtoMessage() {} - -const Default_TouchRequest_Force bool = false - -func (m *TouchRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *TouchRequest) GetKey() []*Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *TouchRequest) GetCompositeIndex() []*CompositeIndex { - if m != nil { - return m.CompositeIndex - } - return nil -} - -func (m *TouchRequest) GetForce() bool { - if m != nil && m.Force != nil { - return *m.Force - } - return Default_TouchRequest_Force -} - -func (m *TouchRequest) GetSnapshot() []*Snapshot { - if m != nil { - return m.Snapshot - } - return nil -} - -type TouchResponse struct { - Cost *Cost `protobuf:"bytes,1,opt,name=cost" json:"cost,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *TouchResponse) Reset() { *m = TouchResponse{} } -func (m *TouchResponse) String() string { return proto.CompactTextString(m) } -func (*TouchResponse) ProtoMessage() {} - -func (m *TouchResponse) GetCost() *Cost { - if m != nil { - return m.Cost - } - return nil -} - -type DeleteRequest struct { - Header *InternalHeader `protobuf:"bytes,10,opt,name=header" json:"header,omitempty"` - Key []*Reference `protobuf:"bytes,6,rep,name=key" json:"key,omitempty"` - Transaction *Transaction `protobuf:"bytes,5,opt,name=transaction" json:"transaction,omitempty"` - Trusted *bool `protobuf:"varint,4,opt,name=trusted,def=0" json:"trusted,omitempty"` - Force *bool `protobuf:"varint,7,opt,name=force,def=0" json:"force,omitempty"` - MarkChanges *bool `protobuf:"varint,8,opt,name=mark_changes,def=0" json:"mark_changes,omitempty"` - Snapshot []*Snapshot `protobuf:"bytes,9,rep,name=snapshot" json:"snapshot,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *DeleteRequest) Reset() { *m = DeleteRequest{} } -func (m *DeleteRequest) String() string { return proto.CompactTextString(m) } -func (*DeleteRequest) ProtoMessage() {} - -const Default_DeleteRequest_Trusted bool = false -const Default_DeleteRequest_Force bool = false -const Default_DeleteRequest_MarkChanges bool = false - -func (m *DeleteRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *DeleteRequest) GetKey() []*Reference { - if m != nil { - return m.Key - } - return nil -} - -func (m *DeleteRequest) GetTransaction() *Transaction { - if m != nil { - return m.Transaction - } - return nil -} - -func (m *DeleteRequest) GetTrusted() bool { - if m != nil && m.Trusted != nil { - return *m.Trusted - } - return Default_DeleteRequest_Trusted -} - -func (m *DeleteRequest) GetForce() bool { - if m != nil && m.Force != nil { - return *m.Force - } - return Default_DeleteRequest_Force -} - -func (m *DeleteRequest) GetMarkChanges() bool { - if m != nil && m.MarkChanges != nil { - return *m.MarkChanges - } - return Default_DeleteRequest_MarkChanges -} - -func (m *DeleteRequest) GetSnapshot() []*Snapshot { - if m != nil { - return m.Snapshot - } - return nil -} - -type DeleteResponse struct { - Cost *Cost `protobuf:"bytes,1,opt,name=cost" json:"cost,omitempty"` - Version []int64 `protobuf:"varint,3,rep,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *DeleteResponse) Reset() { *m = DeleteResponse{} } -func (m *DeleteResponse) String() string { return proto.CompactTextString(m) } -func (*DeleteResponse) ProtoMessage() {} - -func (m *DeleteResponse) GetCost() *Cost { - if m != nil { - return m.Cost - } - return nil -} - -func (m *DeleteResponse) GetVersion() []int64 { - if m != nil { - return m.Version - } - return nil -} - -type NextRequest struct { - Header *InternalHeader `protobuf:"bytes,5,opt,name=header" json:"header,omitempty"` - Cursor *Cursor `protobuf:"bytes,1,req,name=cursor" json:"cursor,omitempty"` - Count *int32 `protobuf:"varint,2,opt,name=count" json:"count,omitempty"` - Offset *int32 `protobuf:"varint,4,opt,name=offset,def=0" json:"offset,omitempty"` - Compile *bool `protobuf:"varint,3,opt,name=compile,def=0" json:"compile,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *NextRequest) Reset() { *m = NextRequest{} } -func (m *NextRequest) String() string { return proto.CompactTextString(m) } -func (*NextRequest) ProtoMessage() {} - -const Default_NextRequest_Offset int32 = 0 -const Default_NextRequest_Compile bool = false - -func (m *NextRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *NextRequest) GetCursor() *Cursor { - if m != nil { - return m.Cursor - } - return nil -} - -func (m *NextRequest) GetCount() int32 { - if m != nil && m.Count != nil { - return *m.Count - } - return 0 -} - -func (m *NextRequest) GetOffset() int32 { - if m != nil && m.Offset != nil { - return *m.Offset - } - return Default_NextRequest_Offset -} - -func (m *NextRequest) GetCompile() bool { - if m != nil && m.Compile != nil { - return *m.Compile - } - return Default_NextRequest_Compile -} - -type QueryResult struct { - Cursor *Cursor `protobuf:"bytes,1,opt,name=cursor" json:"cursor,omitempty"` - Result []*EntityProto `protobuf:"bytes,2,rep,name=result" json:"result,omitempty"` - SkippedResults *int32 `protobuf:"varint,7,opt,name=skipped_results" json:"skipped_results,omitempty"` - MoreResults *bool `protobuf:"varint,3,req,name=more_results" json:"more_results,omitempty"` - KeysOnly *bool `protobuf:"varint,4,opt,name=keys_only" json:"keys_only,omitempty"` - IndexOnly *bool `protobuf:"varint,9,opt,name=index_only" json:"index_only,omitempty"` - SmallOps *bool `protobuf:"varint,10,opt,name=small_ops" json:"small_ops,omitempty"` - CompiledQuery *CompiledQuery `protobuf:"bytes,5,opt,name=compiled_query" json:"compiled_query,omitempty"` - CompiledCursor *CompiledCursor `protobuf:"bytes,6,opt,name=compiled_cursor" json:"compiled_cursor,omitempty"` - Index []*CompositeIndex `protobuf:"bytes,8,rep,name=index" json:"index,omitempty"` - Version []int64 `protobuf:"varint,11,rep,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *QueryResult) Reset() { *m = QueryResult{} } -func (m *QueryResult) String() string { return proto.CompactTextString(m) } -func (*QueryResult) ProtoMessage() {} - -func (m *QueryResult) GetCursor() *Cursor { - if m != nil { - return m.Cursor - } - return nil -} - -func (m *QueryResult) GetResult() []*EntityProto { - if m != nil { - return m.Result - } - return nil -} - -func (m *QueryResult) GetSkippedResults() int32 { - if m != nil && m.SkippedResults != nil { - return *m.SkippedResults - } - return 0 -} - -func (m *QueryResult) GetMoreResults() bool { - if m != nil && m.MoreResults != nil { - return *m.MoreResults - } - return false -} - -func (m *QueryResult) GetKeysOnly() bool { - if m != nil && m.KeysOnly != nil { - return *m.KeysOnly - } - return false -} - -func (m *QueryResult) GetIndexOnly() bool { - if m != nil && m.IndexOnly != nil { - return *m.IndexOnly - } - return false -} - -func (m *QueryResult) GetSmallOps() bool { - if m != nil && m.SmallOps != nil { - return *m.SmallOps - } - return false -} - -func (m *QueryResult) GetCompiledQuery() *CompiledQuery { - if m != nil { - return m.CompiledQuery - } - return nil -} - -func (m *QueryResult) GetCompiledCursor() *CompiledCursor { - if m != nil { - return m.CompiledCursor - } - return nil -} - -func (m *QueryResult) GetIndex() []*CompositeIndex { - if m != nil { - return m.Index - } - return nil -} - -func (m *QueryResult) GetVersion() []int64 { - if m != nil { - return m.Version - } - return nil -} - -type AllocateIdsRequest struct { - Header *InternalHeader `protobuf:"bytes,4,opt,name=header" json:"header,omitempty"` - ModelKey *Reference `protobuf:"bytes,1,opt,name=model_key" json:"model_key,omitempty"` - Size *int64 `protobuf:"varint,2,opt,name=size" json:"size,omitempty"` - Max *int64 `protobuf:"varint,3,opt,name=max" json:"max,omitempty"` - Reserve []*Reference `protobuf:"bytes,5,rep,name=reserve" json:"reserve,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *AllocateIdsRequest) Reset() { *m = AllocateIdsRequest{} } -func (m *AllocateIdsRequest) String() string { return proto.CompactTextString(m) } -func (*AllocateIdsRequest) ProtoMessage() {} - -func (m *AllocateIdsRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *AllocateIdsRequest) GetModelKey() *Reference { - if m != nil { - return m.ModelKey - } - return nil -} - -func (m *AllocateIdsRequest) GetSize() int64 { - if m != nil && m.Size != nil { - return *m.Size - } - return 0 -} - -func (m *AllocateIdsRequest) GetMax() int64 { - if m != nil && m.Max != nil { - return *m.Max - } - return 0 -} - -func (m *AllocateIdsRequest) GetReserve() []*Reference { - if m != nil { - return m.Reserve - } - return nil -} - -type AllocateIdsResponse struct { - Start *int64 `protobuf:"varint,1,req,name=start" json:"start,omitempty"` - End *int64 `protobuf:"varint,2,req,name=end" json:"end,omitempty"` - Cost *Cost `protobuf:"bytes,3,opt,name=cost" json:"cost,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *AllocateIdsResponse) Reset() { *m = AllocateIdsResponse{} } -func (m *AllocateIdsResponse) String() string { return proto.CompactTextString(m) } -func (*AllocateIdsResponse) ProtoMessage() {} - -func (m *AllocateIdsResponse) GetStart() int64 { - if m != nil && m.Start != nil { - return *m.Start - } - return 0 -} - -func (m *AllocateIdsResponse) GetEnd() int64 { - if m != nil && m.End != nil { - return *m.End - } - return 0 -} - -func (m *AllocateIdsResponse) GetCost() *Cost { - if m != nil { - return m.Cost - } - return nil -} - -type CompositeIndices struct { - Index []*CompositeIndex `protobuf:"bytes,1,rep,name=index" json:"index,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CompositeIndices) Reset() { *m = CompositeIndices{} } -func (m *CompositeIndices) String() string { return proto.CompactTextString(m) } -func (*CompositeIndices) ProtoMessage() {} - -func (m *CompositeIndices) GetIndex() []*CompositeIndex { - if m != nil { - return m.Index - } - return nil -} - -type AddActionsRequest struct { - Header *InternalHeader `protobuf:"bytes,3,opt,name=header" json:"header,omitempty"` - Transaction *Transaction `protobuf:"bytes,1,req,name=transaction" json:"transaction,omitempty"` - Action []*Action `protobuf:"bytes,2,rep,name=action" json:"action,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *AddActionsRequest) Reset() { *m = AddActionsRequest{} } -func (m *AddActionsRequest) String() string { return proto.CompactTextString(m) } -func (*AddActionsRequest) ProtoMessage() {} - -func (m *AddActionsRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *AddActionsRequest) GetTransaction() *Transaction { - if m != nil { - return m.Transaction - } - return nil -} - -func (m *AddActionsRequest) GetAction() []*Action { - if m != nil { - return m.Action - } - return nil -} - -type AddActionsResponse struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *AddActionsResponse) Reset() { *m = AddActionsResponse{} } -func (m *AddActionsResponse) String() string { return proto.CompactTextString(m) } -func (*AddActionsResponse) ProtoMessage() {} - -type BeginTransactionRequest struct { - Header *InternalHeader `protobuf:"bytes,3,opt,name=header" json:"header,omitempty"` - App *string `protobuf:"bytes,1,req,name=app" json:"app,omitempty"` - AllowMultipleEg *bool `protobuf:"varint,2,opt,name=allow_multiple_eg,def=0" json:"allow_multiple_eg,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *BeginTransactionRequest) Reset() { *m = BeginTransactionRequest{} } -func (m *BeginTransactionRequest) String() string { return proto.CompactTextString(m) } -func (*BeginTransactionRequest) ProtoMessage() {} - -const Default_BeginTransactionRequest_AllowMultipleEg bool = false - -func (m *BeginTransactionRequest) GetHeader() *InternalHeader { - if m != nil { - return m.Header - } - return nil -} - -func (m *BeginTransactionRequest) GetApp() string { - if m != nil && m.App != nil { - return *m.App - } - return "" -} - -func (m *BeginTransactionRequest) GetAllowMultipleEg() bool { - if m != nil && m.AllowMultipleEg != nil { - return *m.AllowMultipleEg - } - return Default_BeginTransactionRequest_AllowMultipleEg -} - -type CommitResponse struct { - Cost *Cost `protobuf:"bytes,1,opt,name=cost" json:"cost,omitempty"` - Version []*CommitResponse_Version `protobuf:"group,3,rep,name=Version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CommitResponse) Reset() { *m = CommitResponse{} } -func (m *CommitResponse) String() string { return proto.CompactTextString(m) } -func (*CommitResponse) ProtoMessage() {} - -func (m *CommitResponse) GetCost() *Cost { - if m != nil { - return m.Cost - } - return nil -} - -func (m *CommitResponse) GetVersion() []*CommitResponse_Version { - if m != nil { - return m.Version - } - return nil -} - -type CommitResponse_Version struct { - RootEntityKey *Reference `protobuf:"bytes,4,req,name=root_entity_key" json:"root_entity_key,omitempty"` - Version *int64 `protobuf:"varint,5,req,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *CommitResponse_Version) Reset() { *m = CommitResponse_Version{} } -func (m *CommitResponse_Version) String() string { return proto.CompactTextString(m) } -func (*CommitResponse_Version) ProtoMessage() {} - -func (m *CommitResponse_Version) GetRootEntityKey() *Reference { - if m != nil { - return m.RootEntityKey - } - return nil -} - -func (m *CommitResponse_Version) GetVersion() int64 { - if m != nil && m.Version != nil { - return *m.Version - } - return 0 -} - -func init() { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto deleted file mode 100755 index e76f126..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +++ /dev/null @@ -1,541 +0,0 @@ -syntax = "proto2"; -option go_package = "datastore"; - -package appengine; - -message Action{} - -message PropertyValue { - optional int64 int64Value = 1; - optional bool booleanValue = 2; - optional string stringValue = 3; - optional double doubleValue = 4; - - optional group PointValue = 5 { - required double x = 6; - required double y = 7; - } - - optional group UserValue = 8 { - required string email = 9; - required string auth_domain = 10; - optional string nickname = 11; - optional string federated_identity = 21; - optional string federated_provider = 22; - } - - optional group ReferenceValue = 12 { - required string app = 13; - optional string name_space = 20; - repeated group PathElement = 14 { - required string type = 15; - optional int64 id = 16; - optional string name = 17; - } - } -} - -message Property { - enum Meaning { - NO_MEANING = 0; - BLOB = 14; - TEXT = 15; - BYTESTRING = 16; - - ATOM_CATEGORY = 1; - ATOM_LINK = 2; - ATOM_TITLE = 3; - ATOM_CONTENT = 4; - ATOM_SUMMARY = 5; - ATOM_AUTHOR = 6; - - GD_WHEN = 7; - GD_EMAIL = 8; - GEORSS_POINT = 9; - GD_IM = 10; - - GD_PHONENUMBER = 11; - GD_POSTALADDRESS = 12; - - GD_RATING = 13; - - BLOBKEY = 17; - ENTITY_PROTO = 19; - - INDEX_VALUE = 18; - }; - - optional Meaning meaning = 1 [default = NO_MEANING]; - optional string meaning_uri = 2; - - required string name = 3; - - required PropertyValue value = 5; - - required bool multiple = 4; - - optional bool searchable = 6 [default=false]; - - enum FtsTokenizationOption { - HTML = 1; - ATOM = 2; - } - - optional FtsTokenizationOption fts_tokenization_option = 8; - - optional string locale = 9 [default = "en"]; -} - -message Path { - repeated group Element = 1 { - required string type = 2; - optional int64 id = 3; - optional string name = 4; - } -} - -message Reference { - required string app = 13; - optional string name_space = 20; - required Path path = 14; -} - -message User { - required string email = 1; - required string auth_domain = 2; - optional string nickname = 3; - optional string federated_identity = 6; - optional string federated_provider = 7; -} - -message EntityProto { - required Reference key = 13; - required Path entity_group = 16; - optional User owner = 17; - - enum Kind { - GD_CONTACT = 1; - GD_EVENT = 2; - GD_MESSAGE = 3; - } - optional Kind kind = 4; - optional string kind_uri = 5; - - repeated Property property = 14; - repeated Property raw_property = 15; - - optional int32 rank = 18; -} - -message CompositeProperty { - required int64 index_id = 1; - repeated string value = 2; -} - -message Index { - required string entity_type = 1; - required bool ancestor = 5; - repeated group Property = 2 { - required string name = 3; - enum Direction { - ASCENDING = 1; - DESCENDING = 2; - } - optional Direction direction = 4 [default = ASCENDING]; - } -} - -message CompositeIndex { - required string app_id = 1; - required int64 id = 2; - required Index definition = 3; - - enum State { - WRITE_ONLY = 1; - READ_WRITE = 2; - DELETED = 3; - ERROR = 4; - } - required State state = 4; - - optional bool only_use_if_required = 6 [default = false]; -} - -message IndexPostfix { - message IndexValue { - required string property_name = 1; - required PropertyValue value = 2; - } - - repeated IndexValue index_value = 1; - - optional Reference key = 2; - - optional bool before = 3 [default=true]; -} - -message IndexPosition { - optional string key = 1; - - optional bool before = 2 [default=true]; -} - -message Snapshot { - enum Status { - INACTIVE = 0; - ACTIVE = 1; - } - - required int64 ts = 1; -} - -message InternalHeader { - optional string qos = 1; -} - -message Transaction { - optional InternalHeader header = 4; - required fixed64 handle = 1; - required string app = 2; - optional bool mark_changes = 3 [default = false]; -} - -message Query { - optional InternalHeader header = 39; - - required string app = 1; - optional string name_space = 29; - - optional string kind = 3; - optional Reference ancestor = 17; - - repeated group Filter = 4 { - enum Operator { - LESS_THAN = 1; - LESS_THAN_OR_EQUAL = 2; - GREATER_THAN = 3; - GREATER_THAN_OR_EQUAL = 4; - EQUAL = 5; - IN = 6; - EXISTS = 7; - } - - required Operator op = 6; - repeated Property property = 14; - } - - optional string search_query = 8; - - repeated group Order = 9 { - enum Direction { - ASCENDING = 1; - DESCENDING = 2; - } - - required string property = 10; - optional Direction direction = 11 [default = ASCENDING]; - } - - enum Hint { - ORDER_FIRST = 1; - ANCESTOR_FIRST = 2; - FILTER_FIRST = 3; - } - optional Hint hint = 18; - - optional int32 count = 23; - - optional int32 offset = 12 [default = 0]; - - optional int32 limit = 16; - - optional CompiledCursor compiled_cursor = 30; - optional CompiledCursor end_compiled_cursor = 31; - - repeated CompositeIndex composite_index = 19; - - optional bool require_perfect_plan = 20 [default = false]; - - optional bool keys_only = 21 [default = false]; - - optional Transaction transaction = 22; - - optional bool compile = 25 [default = false]; - - optional int64 failover_ms = 26; - - optional bool strong = 32; - - repeated string property_name = 33; - - repeated string group_by_property_name = 34; - - optional bool distinct = 24; - - optional int64 min_safe_time_seconds = 35; - - repeated string safe_replica_name = 36; - - optional bool persist_offset = 37 [default=false]; -} - -message CompiledQuery { - required group PrimaryScan = 1 { - optional string index_name = 2; - - optional string start_key = 3; - optional bool start_inclusive = 4; - optional string end_key = 5; - optional bool end_inclusive = 6; - - repeated string start_postfix_value = 22; - repeated string end_postfix_value = 23; - - optional int64 end_unapplied_log_timestamp_us = 19; - } - - repeated group MergeJoinScan = 7 { - required string index_name = 8; - - repeated string prefix_value = 9; - - optional bool value_prefix = 20 [default=false]; - } - - optional Index index_def = 21; - - optional int32 offset = 10 [default = 0]; - - optional int32 limit = 11; - - required bool keys_only = 12; - - repeated string property_name = 24; - - optional int32 distinct_infix_size = 25; - - optional group EntityFilter = 13 { - optional bool distinct = 14 [default=false]; - - optional string kind = 17; - optional Reference ancestor = 18; - } -} - -message CompiledCursor { - optional group Position = 2 { - optional string start_key = 27; - - repeated group IndexValue = 29 { - optional string property = 30; - required PropertyValue value = 31; - } - - optional Reference key = 32; - - optional bool start_inclusive = 28 [default=true]; - } -} - -message Cursor { - required fixed64 cursor = 1; - - optional string app = 2; -} - -message Error { - enum ErrorCode { - BAD_REQUEST = 1; - CONCURRENT_TRANSACTION = 2; - INTERNAL_ERROR = 3; - NEED_INDEX = 4; - TIMEOUT = 5; - PERMISSION_DENIED = 6; - BIGTABLE_ERROR = 7; - COMMITTED_BUT_STILL_APPLYING = 8; - CAPABILITY_DISABLED = 9; - TRY_ALTERNATE_BACKEND = 10; - SAFE_TIME_TOO_OLD = 11; - } -} - -message Cost { - optional int32 index_writes = 1; - optional int32 index_write_bytes = 2; - optional int32 entity_writes = 3; - optional int32 entity_write_bytes = 4; - optional group CommitCost = 5 { - optional int32 requested_entity_puts = 6; - optional int32 requested_entity_deletes = 7; - }; - optional int32 approximate_storage_delta = 8; - optional int32 id_sequence_updates = 9; -} - -message GetRequest { - optional InternalHeader header = 6; - - repeated Reference key = 1; - optional Transaction transaction = 2; - - optional int64 failover_ms = 3; - - optional bool strong = 4; - - optional bool allow_deferred = 5 [default=false]; -} - -message GetResponse { - repeated group Entity = 1 { - optional EntityProto entity = 2; - optional Reference key = 4; - - optional int64 version = 3; - } - - repeated Reference deferred = 5; - - optional bool in_order = 6 [default=true]; -} - -message PutRequest { - optional InternalHeader header = 11; - - repeated EntityProto entity = 1; - optional Transaction transaction = 2; - repeated CompositeIndex composite_index = 3; - - optional bool trusted = 4 [default = false]; - - optional bool force = 7 [default = false]; - - optional bool mark_changes = 8 [default = false]; - repeated Snapshot snapshot = 9; - - enum AutoIdPolicy { - CURRENT = 0; - SEQUENTIAL = 1; - } - optional AutoIdPolicy auto_id_policy = 10 [default = CURRENT]; -} - -message PutResponse { - repeated Reference key = 1; - optional Cost cost = 2; - repeated int64 version = 3; -} - -message TouchRequest { - optional InternalHeader header = 10; - - repeated Reference key = 1; - repeated CompositeIndex composite_index = 2; - optional bool force = 3 [default = false]; - repeated Snapshot snapshot = 9; -} - -message TouchResponse { - optional Cost cost = 1; -} - -message DeleteRequest { - optional InternalHeader header = 10; - - repeated Reference key = 6; - optional Transaction transaction = 5; - - optional bool trusted = 4 [default = false]; - - optional bool force = 7 [default = false]; - - optional bool mark_changes = 8 [default = false]; - repeated Snapshot snapshot = 9; -} - -message DeleteResponse { - optional Cost cost = 1; - repeated int64 version = 3; -} - -message NextRequest { - optional InternalHeader header = 5; - - required Cursor cursor = 1; - optional int32 count = 2; - - optional int32 offset = 4 [default = 0]; - - optional bool compile = 3 [default = false]; -} - -message QueryResult { - optional Cursor cursor = 1; - - repeated EntityProto result = 2; - - optional int32 skipped_results = 7; - - required bool more_results = 3; - - optional bool keys_only = 4; - - optional bool index_only = 9; - - optional bool small_ops = 10; - - optional CompiledQuery compiled_query = 5; - - optional CompiledCursor compiled_cursor = 6; - - repeated CompositeIndex index = 8; - - repeated int64 version = 11; -} - -message AllocateIdsRequest { - optional InternalHeader header = 4; - - optional Reference model_key = 1; - - optional int64 size = 2; - - optional int64 max = 3; - - repeated Reference reserve = 5; -} - -message AllocateIdsResponse { - required int64 start = 1; - required int64 end = 2; - optional Cost cost = 3; -} - -message CompositeIndices { - repeated CompositeIndex index = 1; -} - -message AddActionsRequest { - optional InternalHeader header = 3; - - required Transaction transaction = 1; - repeated Action action = 2; -} - -message AddActionsResponse { -} - -message BeginTransactionRequest { - optional InternalHeader header = 3; - - required string app = 1; - optional bool allow_multiple_eg = 2 [default = false]; -} - -message CommitResponse { - optional Cost cost = 1; - - repeated group Version = 3 { - required Reference root_entity_key = 4; - required int64 version = 5; - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity.go deleted file mode 100644 index d538701..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity.go +++ /dev/null @@ -1,14 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -import netcontext "golang.org/x/net/context" - -// These functions are implementations of the wrapper functions -// in ../appengine/identity.go. See that file for commentary. - -func AppID(c netcontext.Context) string { - return appID(FullyQualifiedAppID(c)) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_classic.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_classic.go deleted file mode 100644 index e6b9227..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_classic.go +++ /dev/null @@ -1,27 +0,0 @@ -// Copyright 2015 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build appengine - -package internal - -import ( - "appengine" - - netcontext "golang.org/x/net/context" -) - -func DefaultVersionHostname(ctx netcontext.Context) string { - return appengine.DefaultVersionHostname(fromContext(ctx)) -} - -func RequestID(ctx netcontext.Context) string { return appengine.RequestID(fromContext(ctx)) } -func Datacenter(_ netcontext.Context) string { return appengine.Datacenter() } -func ServerSoftware() string { return appengine.ServerSoftware() } -func ModuleName(ctx netcontext.Context) string { return appengine.ModuleName(fromContext(ctx)) } -func VersionID(ctx netcontext.Context) string { return appengine.VersionID(fromContext(ctx)) } -func InstanceID() string { return appengine.InstanceID() } -func IsDevAppServer() bool { return appengine.IsDevAppServer() } - -func fullyQualifiedAppID(ctx netcontext.Context) string { return fromContext(ctx).FullyQualifiedAppID() } diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_vm.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_vm.go deleted file mode 100644 index ebe68b7..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/identity_vm.go +++ /dev/null @@ -1,97 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build !appengine - -package internal - -import ( - "net/http" - "os" - - netcontext "golang.org/x/net/context" -) - -// These functions are implementations of the wrapper functions -// in ../appengine/identity.go. See that file for commentary. - -const ( - hDefaultVersionHostname = "X-AppEngine-Default-Version-Hostname" - hRequestLogId = "X-AppEngine-Request-Log-Id" - hDatacenter = "X-AppEngine-Datacenter" -) - -func ctxHeaders(ctx netcontext.Context) http.Header { - return fromContext(ctx).Request().Header -} - -func DefaultVersionHostname(ctx netcontext.Context) string { - return ctxHeaders(ctx).Get(hDefaultVersionHostname) -} - -func RequestID(ctx netcontext.Context) string { - return ctxHeaders(ctx).Get(hRequestLogId) -} - -func Datacenter(ctx netcontext.Context) string { - return ctxHeaders(ctx).Get(hDatacenter) -} - -func ServerSoftware() string { - // TODO(dsymonds): Remove fallback when we've verified this. - if s := os.Getenv("SERVER_SOFTWARE"); s != "" { - return s - } - return "Google App Engine/1.x.x" -} - -// TODO(dsymonds): Remove the metadata fetches. - -func ModuleName(_ netcontext.Context) string { - if s := os.Getenv("GAE_MODULE_NAME"); s != "" { - return s - } - return string(mustGetMetadata("instance/attributes/gae_backend_name")) -} - -func VersionID(_ netcontext.Context) string { - if s1, s2 := os.Getenv("GAE_MODULE_VERSION"), os.Getenv("GAE_MINOR_VERSION"); s1 != "" && s2 != "" { - return s1 + "." + s2 - } - return string(mustGetMetadata("instance/attributes/gae_backend_version")) + "." + string(mustGetMetadata("instance/attributes/gae_backend_minor_version")) -} - -func InstanceID() string { - if s := os.Getenv("GAE_MODULE_INSTANCE"); s != "" { - return s - } - return string(mustGetMetadata("instance/attributes/gae_backend_instance")) -} - -func partitionlessAppID() string { - // gae_project has everything except the partition prefix. - appID := os.Getenv("GAE_LONG_APP_ID") - if appID == "" { - appID = string(mustGetMetadata("instance/attributes/gae_project")) - } - return appID -} - -func fullyQualifiedAppID(_ netcontext.Context) string { - appID := partitionlessAppID() - - part := os.Getenv("GAE_PARTITION") - if part == "" { - part = string(mustGetMetadata("instance/attributes/gae_partition")) - } - - if part != "" { - appID = part + "~" + appID - } - return appID -} - -func IsDevAppServer() bool { - return os.Getenv("RUN_WITH_DEVAPPSERVER") != "" -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/internal.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/internal.go deleted file mode 100644 index 051ea39..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/internal.go +++ /dev/null @@ -1,110 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// Package internal provides support for package appengine. -// -// Programs should not use this package directly. Its API is not stable. -// Use packages appengine and appengine/* instead. -package internal - -import ( - "fmt" - - "github.com/golang/protobuf/proto" - - remotepb "google.golang.org/appengine/internal/remote_api" -) - -// errorCodeMaps is a map of service name to the error code map for the service. -var errorCodeMaps = make(map[string]map[int32]string) - -// RegisterErrorCodeMap is called from API implementations to register their -// error code map. This should only be called from init functions. -func RegisterErrorCodeMap(service string, m map[int32]string) { - errorCodeMaps[service] = m -} - -type timeoutCodeKey struct { - service string - code int32 -} - -// timeoutCodes is the set of service+code pairs that represent timeouts. -var timeoutCodes = make(map[timeoutCodeKey]bool) - -func RegisterTimeoutErrorCode(service string, code int32) { - timeoutCodes[timeoutCodeKey{service, code}] = true -} - -// APIError is the type returned by appengine.Context's Call method -// when an API call fails in an API-specific way. This may be, for instance, -// a taskqueue API call failing with TaskQueueServiceError::UNKNOWN_QUEUE. -type APIError struct { - Service string - Detail string - Code int32 // API-specific error code -} - -func (e *APIError) Error() string { - if e.Code == 0 { - if e.Detail == "" { - return "APIError <empty>" - } - return e.Detail - } - s := fmt.Sprintf("API error %d", e.Code) - if m, ok := errorCodeMaps[e.Service]; ok { - s += " (" + e.Service + ": " + m[e.Code] + ")" - } else { - // Shouldn't happen, but provide a bit more detail if it does. - s = e.Service + " " + s - } - if e.Detail != "" { - s += ": " + e.Detail - } - return s -} - -func (e *APIError) IsTimeout() bool { - return timeoutCodes[timeoutCodeKey{e.Service, e.Code}] -} - -// CallError is the type returned by appengine.Context's Call method when an -// API call fails in a generic way, such as RpcError::CAPABILITY_DISABLED. -type CallError struct { - Detail string - Code int32 - // TODO: Remove this if we get a distinguishable error code. - Timeout bool -} - -func (e *CallError) Error() string { - var msg string - switch remotepb.RpcError_ErrorCode(e.Code) { - case remotepb.RpcError_UNKNOWN: - return e.Detail - case remotepb.RpcError_OVER_QUOTA: - msg = "Over quota" - case remotepb.RpcError_CAPABILITY_DISABLED: - msg = "Capability disabled" - case remotepb.RpcError_CANCELLED: - msg = "Canceled" - default: - msg = fmt.Sprintf("Call error %d", e.Code) - } - s := msg + ": " + e.Detail - if e.Timeout { - s += " (timeout)" - } - return s -} - -func (e *CallError) IsTimeout() bool { - return e.Timeout -} - -// NamespaceMods is a map from API service to a function that will mutate an RPC request to attach a namespace. -// The function should be prepared to be called on the same message more than once; it should only modify the -// RPC request the first time. -var NamespaceMods = make(map[string]func(m proto.Message, namespace string)) diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.pb.go deleted file mode 100644 index 20c595b..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +++ /dev/null @@ -1,899 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/log/log_service.proto -// DO NOT EDIT! - -/* -Package log is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/log/log_service.proto - -It has these top-level messages: - LogServiceError - UserAppLogLine - UserAppLogGroup - FlushRequest - SetStatusRequest - LogOffset - LogLine - RequestLog - LogModuleVersion - LogReadRequest - LogReadResponse - LogUsageRecord - LogUsageRequest - LogUsageResponse -*/ -package log - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type LogServiceError_ErrorCode int32 - -const ( - LogServiceError_OK LogServiceError_ErrorCode = 0 - LogServiceError_INVALID_REQUEST LogServiceError_ErrorCode = 1 - LogServiceError_STORAGE_ERROR LogServiceError_ErrorCode = 2 -) - -var LogServiceError_ErrorCode_name = map[int32]string{ - 0: "OK", - 1: "INVALID_REQUEST", - 2: "STORAGE_ERROR", -} -var LogServiceError_ErrorCode_value = map[string]int32{ - "OK": 0, - "INVALID_REQUEST": 1, - "STORAGE_ERROR": 2, -} - -func (x LogServiceError_ErrorCode) Enum() *LogServiceError_ErrorCode { - p := new(LogServiceError_ErrorCode) - *p = x - return p -} -func (x LogServiceError_ErrorCode) String() string { - return proto.EnumName(LogServiceError_ErrorCode_name, int32(x)) -} -func (x *LogServiceError_ErrorCode) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(LogServiceError_ErrorCode_value, data, "LogServiceError_ErrorCode") - if err != nil { - return err - } - *x = LogServiceError_ErrorCode(value) - return nil -} - -type LogServiceError struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogServiceError) Reset() { *m = LogServiceError{} } -func (m *LogServiceError) String() string { return proto.CompactTextString(m) } -func (*LogServiceError) ProtoMessage() {} - -type UserAppLogLine struct { - TimestampUsec *int64 `protobuf:"varint,1,req,name=timestamp_usec" json:"timestamp_usec,omitempty"` - Level *int64 `protobuf:"varint,2,req,name=level" json:"level,omitempty"` - Message *string `protobuf:"bytes,3,req,name=message" json:"message,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *UserAppLogLine) Reset() { *m = UserAppLogLine{} } -func (m *UserAppLogLine) String() string { return proto.CompactTextString(m) } -func (*UserAppLogLine) ProtoMessage() {} - -func (m *UserAppLogLine) GetTimestampUsec() int64 { - if m != nil && m.TimestampUsec != nil { - return *m.TimestampUsec - } - return 0 -} - -func (m *UserAppLogLine) GetLevel() int64 { - if m != nil && m.Level != nil { - return *m.Level - } - return 0 -} - -func (m *UserAppLogLine) GetMessage() string { - if m != nil && m.Message != nil { - return *m.Message - } - return "" -} - -type UserAppLogGroup struct { - LogLine []*UserAppLogLine `protobuf:"bytes,2,rep,name=log_line" json:"log_line,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *UserAppLogGroup) Reset() { *m = UserAppLogGroup{} } -func (m *UserAppLogGroup) String() string { return proto.CompactTextString(m) } -func (*UserAppLogGroup) ProtoMessage() {} - -func (m *UserAppLogGroup) GetLogLine() []*UserAppLogLine { - if m != nil { - return m.LogLine - } - return nil -} - -type FlushRequest struct { - Logs []byte `protobuf:"bytes,1,opt,name=logs" json:"logs,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *FlushRequest) Reset() { *m = FlushRequest{} } -func (m *FlushRequest) String() string { return proto.CompactTextString(m) } -func (*FlushRequest) ProtoMessage() {} - -func (m *FlushRequest) GetLogs() []byte { - if m != nil { - return m.Logs - } - return nil -} - -type SetStatusRequest struct { - Status *string `protobuf:"bytes,1,req,name=status" json:"status,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *SetStatusRequest) Reset() { *m = SetStatusRequest{} } -func (m *SetStatusRequest) String() string { return proto.CompactTextString(m) } -func (*SetStatusRequest) ProtoMessage() {} - -func (m *SetStatusRequest) GetStatus() string { - if m != nil && m.Status != nil { - return *m.Status - } - return "" -} - -type LogOffset struct { - RequestId []byte `protobuf:"bytes,1,opt,name=request_id" json:"request_id,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogOffset) Reset() { *m = LogOffset{} } -func (m *LogOffset) String() string { return proto.CompactTextString(m) } -func (*LogOffset) ProtoMessage() {} - -func (m *LogOffset) GetRequestId() []byte { - if m != nil { - return m.RequestId - } - return nil -} - -type LogLine struct { - Time *int64 `protobuf:"varint,1,req,name=time" json:"time,omitempty"` - Level *int32 `protobuf:"varint,2,req,name=level" json:"level,omitempty"` - LogMessage *string `protobuf:"bytes,3,req,name=log_message" json:"log_message,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogLine) Reset() { *m = LogLine{} } -func (m *LogLine) String() string { return proto.CompactTextString(m) } -func (*LogLine) ProtoMessage() {} - -func (m *LogLine) GetTime() int64 { - if m != nil && m.Time != nil { - return *m.Time - } - return 0 -} - -func (m *LogLine) GetLevel() int32 { - if m != nil && m.Level != nil { - return *m.Level - } - return 0 -} - -func (m *LogLine) GetLogMessage() string { - if m != nil && m.LogMessage != nil { - return *m.LogMessage - } - return "" -} - -type RequestLog struct { - AppId *string `protobuf:"bytes,1,req,name=app_id" json:"app_id,omitempty"` - ModuleId *string `protobuf:"bytes,37,opt,name=module_id,def=default" json:"module_id,omitempty"` - VersionId *string `protobuf:"bytes,2,req,name=version_id" json:"version_id,omitempty"` - RequestId []byte `protobuf:"bytes,3,req,name=request_id" json:"request_id,omitempty"` - Offset *LogOffset `protobuf:"bytes,35,opt,name=offset" json:"offset,omitempty"` - Ip *string `protobuf:"bytes,4,req,name=ip" json:"ip,omitempty"` - Nickname *string `protobuf:"bytes,5,opt,name=nickname" json:"nickname,omitempty"` - StartTime *int64 `protobuf:"varint,6,req,name=start_time" json:"start_time,omitempty"` - EndTime *int64 `protobuf:"varint,7,req,name=end_time" json:"end_time,omitempty"` - Latency *int64 `protobuf:"varint,8,req,name=latency" json:"latency,omitempty"` - Mcycles *int64 `protobuf:"varint,9,req,name=mcycles" json:"mcycles,omitempty"` - Method *string `protobuf:"bytes,10,req,name=method" json:"method,omitempty"` - Resource *string `protobuf:"bytes,11,req,name=resource" json:"resource,omitempty"` - HttpVersion *string `protobuf:"bytes,12,req,name=http_version" json:"http_version,omitempty"` - Status *int32 `protobuf:"varint,13,req,name=status" json:"status,omitempty"` - ResponseSize *int64 `protobuf:"varint,14,req,name=response_size" json:"response_size,omitempty"` - Referrer *string `protobuf:"bytes,15,opt,name=referrer" json:"referrer,omitempty"` - UserAgent *string `protobuf:"bytes,16,opt,name=user_agent" json:"user_agent,omitempty"` - UrlMapEntry *string `protobuf:"bytes,17,req,name=url_map_entry" json:"url_map_entry,omitempty"` - Combined *string `protobuf:"bytes,18,req,name=combined" json:"combined,omitempty"` - ApiMcycles *int64 `protobuf:"varint,19,opt,name=api_mcycles" json:"api_mcycles,omitempty"` - Host *string `protobuf:"bytes,20,opt,name=host" json:"host,omitempty"` - Cost *float64 `protobuf:"fixed64,21,opt,name=cost" json:"cost,omitempty"` - TaskQueueName *string `protobuf:"bytes,22,opt,name=task_queue_name" json:"task_queue_name,omitempty"` - TaskName *string `protobuf:"bytes,23,opt,name=task_name" json:"task_name,omitempty"` - WasLoadingRequest *bool `protobuf:"varint,24,opt,name=was_loading_request" json:"was_loading_request,omitempty"` - PendingTime *int64 `protobuf:"varint,25,opt,name=pending_time" json:"pending_time,omitempty"` - ReplicaIndex *int32 `protobuf:"varint,26,opt,name=replica_index,def=-1" json:"replica_index,omitempty"` - Finished *bool `protobuf:"varint,27,opt,name=finished,def=1" json:"finished,omitempty"` - CloneKey []byte `protobuf:"bytes,28,opt,name=clone_key" json:"clone_key,omitempty"` - Line []*LogLine `protobuf:"bytes,29,rep,name=line" json:"line,omitempty"` - LinesIncomplete *bool `protobuf:"varint,36,opt,name=lines_incomplete" json:"lines_incomplete,omitempty"` - AppEngineRelease []byte `protobuf:"bytes,38,opt,name=app_engine_release" json:"app_engine_release,omitempty"` - ExitReason *int32 `protobuf:"varint,30,opt,name=exit_reason" json:"exit_reason,omitempty"` - WasThrottledForTime *bool `protobuf:"varint,31,opt,name=was_throttled_for_time" json:"was_throttled_for_time,omitempty"` - WasThrottledForRequests *bool `protobuf:"varint,32,opt,name=was_throttled_for_requests" json:"was_throttled_for_requests,omitempty"` - ThrottledTime *int64 `protobuf:"varint,33,opt,name=throttled_time" json:"throttled_time,omitempty"` - ServerName []byte `protobuf:"bytes,34,opt,name=server_name" json:"server_name,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *RequestLog) Reset() { *m = RequestLog{} } -func (m *RequestLog) String() string { return proto.CompactTextString(m) } -func (*RequestLog) ProtoMessage() {} - -const Default_RequestLog_ModuleId string = "default" -const Default_RequestLog_ReplicaIndex int32 = -1 -const Default_RequestLog_Finished bool = true - -func (m *RequestLog) GetAppId() string { - if m != nil && m.AppId != nil { - return *m.AppId - } - return "" -} - -func (m *RequestLog) GetModuleId() string { - if m != nil && m.ModuleId != nil { - return *m.ModuleId - } - return Default_RequestLog_ModuleId -} - -func (m *RequestLog) GetVersionId() string { - if m != nil && m.VersionId != nil { - return *m.VersionId - } - return "" -} - -func (m *RequestLog) GetRequestId() []byte { - if m != nil { - return m.RequestId - } - return nil -} - -func (m *RequestLog) GetOffset() *LogOffset { - if m != nil { - return m.Offset - } - return nil -} - -func (m *RequestLog) GetIp() string { - if m != nil && m.Ip != nil { - return *m.Ip - } - return "" -} - -func (m *RequestLog) GetNickname() string { - if m != nil && m.Nickname != nil { - return *m.Nickname - } - return "" -} - -func (m *RequestLog) GetStartTime() int64 { - if m != nil && m.StartTime != nil { - return *m.StartTime - } - return 0 -} - -func (m *RequestLog) GetEndTime() int64 { - if m != nil && m.EndTime != nil { - return *m.EndTime - } - return 0 -} - -func (m *RequestLog) GetLatency() int64 { - if m != nil && m.Latency != nil { - return *m.Latency - } - return 0 -} - -func (m *RequestLog) GetMcycles() int64 { - if m != nil && m.Mcycles != nil { - return *m.Mcycles - } - return 0 -} - -func (m *RequestLog) GetMethod() string { - if m != nil && m.Method != nil { - return *m.Method - } - return "" -} - -func (m *RequestLog) GetResource() string { - if m != nil && m.Resource != nil { - return *m.Resource - } - return "" -} - -func (m *RequestLog) GetHttpVersion() string { - if m != nil && m.HttpVersion != nil { - return *m.HttpVersion - } - return "" -} - -func (m *RequestLog) GetStatus() int32 { - if m != nil && m.Status != nil { - return *m.Status - } - return 0 -} - -func (m *RequestLog) GetResponseSize() int64 { - if m != nil && m.ResponseSize != nil { - return *m.ResponseSize - } - return 0 -} - -func (m *RequestLog) GetReferrer() string { - if m != nil && m.Referrer != nil { - return *m.Referrer - } - return "" -} - -func (m *RequestLog) GetUserAgent() string { - if m != nil && m.UserAgent != nil { - return *m.UserAgent - } - return "" -} - -func (m *RequestLog) GetUrlMapEntry() string { - if m != nil && m.UrlMapEntry != nil { - return *m.UrlMapEntry - } - return "" -} - -func (m *RequestLog) GetCombined() string { - if m != nil && m.Combined != nil { - return *m.Combined - } - return "" -} - -func (m *RequestLog) GetApiMcycles() int64 { - if m != nil && m.ApiMcycles != nil { - return *m.ApiMcycles - } - return 0 -} - -func (m *RequestLog) GetHost() string { - if m != nil && m.Host != nil { - return *m.Host - } - return "" -} - -func (m *RequestLog) GetCost() float64 { - if m != nil && m.Cost != nil { - return *m.Cost - } - return 0 -} - -func (m *RequestLog) GetTaskQueueName() string { - if m != nil && m.TaskQueueName != nil { - return *m.TaskQueueName - } - return "" -} - -func (m *RequestLog) GetTaskName() string { - if m != nil && m.TaskName != nil { - return *m.TaskName - } - return "" -} - -func (m *RequestLog) GetWasLoadingRequest() bool { - if m != nil && m.WasLoadingRequest != nil { - return *m.WasLoadingRequest - } - return false -} - -func (m *RequestLog) GetPendingTime() int64 { - if m != nil && m.PendingTime != nil { - return *m.PendingTime - } - return 0 -} - -func (m *RequestLog) GetReplicaIndex() int32 { - if m != nil && m.ReplicaIndex != nil { - return *m.ReplicaIndex - } - return Default_RequestLog_ReplicaIndex -} - -func (m *RequestLog) GetFinished() bool { - if m != nil && m.Finished != nil { - return *m.Finished - } - return Default_RequestLog_Finished -} - -func (m *RequestLog) GetCloneKey() []byte { - if m != nil { - return m.CloneKey - } - return nil -} - -func (m *RequestLog) GetLine() []*LogLine { - if m != nil { - return m.Line - } - return nil -} - -func (m *RequestLog) GetLinesIncomplete() bool { - if m != nil && m.LinesIncomplete != nil { - return *m.LinesIncomplete - } - return false -} - -func (m *RequestLog) GetAppEngineRelease() []byte { - if m != nil { - return m.AppEngineRelease - } - return nil -} - -func (m *RequestLog) GetExitReason() int32 { - if m != nil && m.ExitReason != nil { - return *m.ExitReason - } - return 0 -} - -func (m *RequestLog) GetWasThrottledForTime() bool { - if m != nil && m.WasThrottledForTime != nil { - return *m.WasThrottledForTime - } - return false -} - -func (m *RequestLog) GetWasThrottledForRequests() bool { - if m != nil && m.WasThrottledForRequests != nil { - return *m.WasThrottledForRequests - } - return false -} - -func (m *RequestLog) GetThrottledTime() int64 { - if m != nil && m.ThrottledTime != nil { - return *m.ThrottledTime - } - return 0 -} - -func (m *RequestLog) GetServerName() []byte { - if m != nil { - return m.ServerName - } - return nil -} - -type LogModuleVersion struct { - ModuleId *string `protobuf:"bytes,1,opt,name=module_id,def=default" json:"module_id,omitempty"` - VersionId *string `protobuf:"bytes,2,opt,name=version_id" json:"version_id,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogModuleVersion) Reset() { *m = LogModuleVersion{} } -func (m *LogModuleVersion) String() string { return proto.CompactTextString(m) } -func (*LogModuleVersion) ProtoMessage() {} - -const Default_LogModuleVersion_ModuleId string = "default" - -func (m *LogModuleVersion) GetModuleId() string { - if m != nil && m.ModuleId != nil { - return *m.ModuleId - } - return Default_LogModuleVersion_ModuleId -} - -func (m *LogModuleVersion) GetVersionId() string { - if m != nil && m.VersionId != nil { - return *m.VersionId - } - return "" -} - -type LogReadRequest struct { - AppId *string `protobuf:"bytes,1,req,name=app_id" json:"app_id,omitempty"` - VersionId []string `protobuf:"bytes,2,rep,name=version_id" json:"version_id,omitempty"` - ModuleVersion []*LogModuleVersion `protobuf:"bytes,19,rep,name=module_version" json:"module_version,omitempty"` - StartTime *int64 `protobuf:"varint,3,opt,name=start_time" json:"start_time,omitempty"` - EndTime *int64 `protobuf:"varint,4,opt,name=end_time" json:"end_time,omitempty"` - Offset *LogOffset `protobuf:"bytes,5,opt,name=offset" json:"offset,omitempty"` - RequestId [][]byte `protobuf:"bytes,6,rep,name=request_id" json:"request_id,omitempty"` - MinimumLogLevel *int32 `protobuf:"varint,7,opt,name=minimum_log_level" json:"minimum_log_level,omitempty"` - IncludeIncomplete *bool `protobuf:"varint,8,opt,name=include_incomplete" json:"include_incomplete,omitempty"` - Count *int64 `protobuf:"varint,9,opt,name=count" json:"count,omitempty"` - CombinedLogRegex *string `protobuf:"bytes,14,opt,name=combined_log_regex" json:"combined_log_regex,omitempty"` - HostRegex *string `protobuf:"bytes,15,opt,name=host_regex" json:"host_regex,omitempty"` - ReplicaIndex *int32 `protobuf:"varint,16,opt,name=replica_index" json:"replica_index,omitempty"` - IncludeAppLogs *bool `protobuf:"varint,10,opt,name=include_app_logs" json:"include_app_logs,omitempty"` - AppLogsPerRequest *int32 `protobuf:"varint,17,opt,name=app_logs_per_request" json:"app_logs_per_request,omitempty"` - IncludeHost *bool `protobuf:"varint,11,opt,name=include_host" json:"include_host,omitempty"` - IncludeAll *bool `protobuf:"varint,12,opt,name=include_all" json:"include_all,omitempty"` - CacheIterator *bool `protobuf:"varint,13,opt,name=cache_iterator" json:"cache_iterator,omitempty"` - NumShards *int32 `protobuf:"varint,18,opt,name=num_shards" json:"num_shards,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogReadRequest) Reset() { *m = LogReadRequest{} } -func (m *LogReadRequest) String() string { return proto.CompactTextString(m) } -func (*LogReadRequest) ProtoMessage() {} - -func (m *LogReadRequest) GetAppId() string { - if m != nil && m.AppId != nil { - return *m.AppId - } - return "" -} - -func (m *LogReadRequest) GetVersionId() []string { - if m != nil { - return m.VersionId - } - return nil -} - -func (m *LogReadRequest) GetModuleVersion() []*LogModuleVersion { - if m != nil { - return m.ModuleVersion - } - return nil -} - -func (m *LogReadRequest) GetStartTime() int64 { - if m != nil && m.StartTime != nil { - return *m.StartTime - } - return 0 -} - -func (m *LogReadRequest) GetEndTime() int64 { - if m != nil && m.EndTime != nil { - return *m.EndTime - } - return 0 -} - -func (m *LogReadRequest) GetOffset() *LogOffset { - if m != nil { - return m.Offset - } - return nil -} - -func (m *LogReadRequest) GetRequestId() [][]byte { - if m != nil { - return m.RequestId - } - return nil -} - -func (m *LogReadRequest) GetMinimumLogLevel() int32 { - if m != nil && m.MinimumLogLevel != nil { - return *m.MinimumLogLevel - } - return 0 -} - -func (m *LogReadRequest) GetIncludeIncomplete() bool { - if m != nil && m.IncludeIncomplete != nil { - return *m.IncludeIncomplete - } - return false -} - -func (m *LogReadRequest) GetCount() int64 { - if m != nil && m.Count != nil { - return *m.Count - } - return 0 -} - -func (m *LogReadRequest) GetCombinedLogRegex() string { - if m != nil && m.CombinedLogRegex != nil { - return *m.CombinedLogRegex - } - return "" -} - -func (m *LogReadRequest) GetHostRegex() string { - if m != nil && m.HostRegex != nil { - return *m.HostRegex - } - return "" -} - -func (m *LogReadRequest) GetReplicaIndex() int32 { - if m != nil && m.ReplicaIndex != nil { - return *m.ReplicaIndex - } - return 0 -} - -func (m *LogReadRequest) GetIncludeAppLogs() bool { - if m != nil && m.IncludeAppLogs != nil { - return *m.IncludeAppLogs - } - return false -} - -func (m *LogReadRequest) GetAppLogsPerRequest() int32 { - if m != nil && m.AppLogsPerRequest != nil { - return *m.AppLogsPerRequest - } - return 0 -} - -func (m *LogReadRequest) GetIncludeHost() bool { - if m != nil && m.IncludeHost != nil { - return *m.IncludeHost - } - return false -} - -func (m *LogReadRequest) GetIncludeAll() bool { - if m != nil && m.IncludeAll != nil { - return *m.IncludeAll - } - return false -} - -func (m *LogReadRequest) GetCacheIterator() bool { - if m != nil && m.CacheIterator != nil { - return *m.CacheIterator - } - return false -} - -func (m *LogReadRequest) GetNumShards() int32 { - if m != nil && m.NumShards != nil { - return *m.NumShards - } - return 0 -} - -type LogReadResponse struct { - Log []*RequestLog `protobuf:"bytes,1,rep,name=log" json:"log,omitempty"` - Offset *LogOffset `protobuf:"bytes,2,opt,name=offset" json:"offset,omitempty"` - LastEndTime *int64 `protobuf:"varint,3,opt,name=last_end_time" json:"last_end_time,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogReadResponse) Reset() { *m = LogReadResponse{} } -func (m *LogReadResponse) String() string { return proto.CompactTextString(m) } -func (*LogReadResponse) ProtoMessage() {} - -func (m *LogReadResponse) GetLog() []*RequestLog { - if m != nil { - return m.Log - } - return nil -} - -func (m *LogReadResponse) GetOffset() *LogOffset { - if m != nil { - return m.Offset - } - return nil -} - -func (m *LogReadResponse) GetLastEndTime() int64 { - if m != nil && m.LastEndTime != nil { - return *m.LastEndTime - } - return 0 -} - -type LogUsageRecord struct { - VersionId *string `protobuf:"bytes,1,opt,name=version_id" json:"version_id,omitempty"` - StartTime *int32 `protobuf:"varint,2,opt,name=start_time" json:"start_time,omitempty"` - EndTime *int32 `protobuf:"varint,3,opt,name=end_time" json:"end_time,omitempty"` - Count *int64 `protobuf:"varint,4,opt,name=count" json:"count,omitempty"` - TotalSize *int64 `protobuf:"varint,5,opt,name=total_size" json:"total_size,omitempty"` - Records *int32 `protobuf:"varint,6,opt,name=records" json:"records,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogUsageRecord) Reset() { *m = LogUsageRecord{} } -func (m *LogUsageRecord) String() string { return proto.CompactTextString(m) } -func (*LogUsageRecord) ProtoMessage() {} - -func (m *LogUsageRecord) GetVersionId() string { - if m != nil && m.VersionId != nil { - return *m.VersionId - } - return "" -} - -func (m *LogUsageRecord) GetStartTime() int32 { - if m != nil && m.StartTime != nil { - return *m.StartTime - } - return 0 -} - -func (m *LogUsageRecord) GetEndTime() int32 { - if m != nil && m.EndTime != nil { - return *m.EndTime - } - return 0 -} - -func (m *LogUsageRecord) GetCount() int64 { - if m != nil && m.Count != nil { - return *m.Count - } - return 0 -} - -func (m *LogUsageRecord) GetTotalSize() int64 { - if m != nil && m.TotalSize != nil { - return *m.TotalSize - } - return 0 -} - -func (m *LogUsageRecord) GetRecords() int32 { - if m != nil && m.Records != nil { - return *m.Records - } - return 0 -} - -type LogUsageRequest struct { - AppId *string `protobuf:"bytes,1,req,name=app_id" json:"app_id,omitempty"` - VersionId []string `protobuf:"bytes,2,rep,name=version_id" json:"version_id,omitempty"` - StartTime *int32 `protobuf:"varint,3,opt,name=start_time" json:"start_time,omitempty"` - EndTime *int32 `protobuf:"varint,4,opt,name=end_time" json:"end_time,omitempty"` - ResolutionHours *uint32 `protobuf:"varint,5,opt,name=resolution_hours,def=1" json:"resolution_hours,omitempty"` - CombineVersions *bool `protobuf:"varint,6,opt,name=combine_versions" json:"combine_versions,omitempty"` - UsageVersion *int32 `protobuf:"varint,7,opt,name=usage_version" json:"usage_version,omitempty"` - VersionsOnly *bool `protobuf:"varint,8,opt,name=versions_only" json:"versions_only,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogUsageRequest) Reset() { *m = LogUsageRequest{} } -func (m *LogUsageRequest) String() string { return proto.CompactTextString(m) } -func (*LogUsageRequest) ProtoMessage() {} - -const Default_LogUsageRequest_ResolutionHours uint32 = 1 - -func (m *LogUsageRequest) GetAppId() string { - if m != nil && m.AppId != nil { - return *m.AppId - } - return "" -} - -func (m *LogUsageRequest) GetVersionId() []string { - if m != nil { - return m.VersionId - } - return nil -} - -func (m *LogUsageRequest) GetStartTime() int32 { - if m != nil && m.StartTime != nil { - return *m.StartTime - } - return 0 -} - -func (m *LogUsageRequest) GetEndTime() int32 { - if m != nil && m.EndTime != nil { - return *m.EndTime - } - return 0 -} - -func (m *LogUsageRequest) GetResolutionHours() uint32 { - if m != nil && m.ResolutionHours != nil { - return *m.ResolutionHours - } - return Default_LogUsageRequest_ResolutionHours -} - -func (m *LogUsageRequest) GetCombineVersions() bool { - if m != nil && m.CombineVersions != nil { - return *m.CombineVersions - } - return false -} - -func (m *LogUsageRequest) GetUsageVersion() int32 { - if m != nil && m.UsageVersion != nil { - return *m.UsageVersion - } - return 0 -} - -func (m *LogUsageRequest) GetVersionsOnly() bool { - if m != nil && m.VersionsOnly != nil { - return *m.VersionsOnly - } - return false -} - -type LogUsageResponse struct { - Usage []*LogUsageRecord `protobuf:"bytes,1,rep,name=usage" json:"usage,omitempty"` - Summary *LogUsageRecord `protobuf:"bytes,2,opt,name=summary" json:"summary,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *LogUsageResponse) Reset() { *m = LogUsageResponse{} } -func (m *LogUsageResponse) String() string { return proto.CompactTextString(m) } -func (*LogUsageResponse) ProtoMessage() {} - -func (m *LogUsageResponse) GetUsage() []*LogUsageRecord { - if m != nil { - return m.Usage - } - return nil -} - -func (m *LogUsageResponse) GetSummary() *LogUsageRecord { - if m != nil { - return m.Summary - } - return nil -} - -func init() { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.proto deleted file mode 100644 index 8981dc4..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/log/log_service.proto +++ /dev/null @@ -1,150 +0,0 @@ -syntax = "proto2"; -option go_package = "log"; - -package appengine; - -message LogServiceError { - enum ErrorCode { - OK = 0; - INVALID_REQUEST = 1; - STORAGE_ERROR = 2; - } -} - -message UserAppLogLine { - required int64 timestamp_usec = 1; - required int64 level = 2; - required string message = 3; -} - -message UserAppLogGroup { - repeated UserAppLogLine log_line = 2; -} - -message FlushRequest { - optional bytes logs = 1; -} - -message SetStatusRequest { - required string status = 1; -} - - -message LogOffset { - optional bytes request_id = 1; -} - -message LogLine { - required int64 time = 1; - required int32 level = 2; - required string log_message = 3; -} - -message RequestLog { - required string app_id = 1; - optional string module_id = 37 [default="default"]; - required string version_id = 2; - required bytes request_id = 3; - optional LogOffset offset = 35; - required string ip = 4; - optional string nickname = 5; - required int64 start_time = 6; - required int64 end_time = 7; - required int64 latency = 8; - required int64 mcycles = 9; - required string method = 10; - required string resource = 11; - required string http_version = 12; - required int32 status = 13; - required int64 response_size = 14; - optional string referrer = 15; - optional string user_agent = 16; - required string url_map_entry = 17; - required string combined = 18; - optional int64 api_mcycles = 19; - optional string host = 20; - optional double cost = 21; - - optional string task_queue_name = 22; - optional string task_name = 23; - - optional bool was_loading_request = 24; - optional int64 pending_time = 25; - optional int32 replica_index = 26 [default = -1]; - optional bool finished = 27 [default = true]; - optional bytes clone_key = 28; - - repeated LogLine line = 29; - - optional bool lines_incomplete = 36; - optional bytes app_engine_release = 38; - - optional int32 exit_reason = 30; - optional bool was_throttled_for_time = 31; - optional bool was_throttled_for_requests = 32; - optional int64 throttled_time = 33; - - optional bytes server_name = 34; -} - -message LogModuleVersion { - optional string module_id = 1 [default="default"]; - optional string version_id = 2; -} - -message LogReadRequest { - required string app_id = 1; - repeated string version_id = 2; - repeated LogModuleVersion module_version = 19; - - optional int64 start_time = 3; - optional int64 end_time = 4; - optional LogOffset offset = 5; - repeated bytes request_id = 6; - - optional int32 minimum_log_level = 7; - optional bool include_incomplete = 8; - optional int64 count = 9; - - optional string combined_log_regex = 14; - optional string host_regex = 15; - optional int32 replica_index = 16; - - optional bool include_app_logs = 10; - optional int32 app_logs_per_request = 17; - optional bool include_host = 11; - optional bool include_all = 12; - optional bool cache_iterator = 13; - optional int32 num_shards = 18; -} - -message LogReadResponse { - repeated RequestLog log = 1; - optional LogOffset offset = 2; - optional int64 last_end_time = 3; -} - -message LogUsageRecord { - optional string version_id = 1; - optional int32 start_time = 2; - optional int32 end_time = 3; - optional int64 count = 4; - optional int64 total_size = 5; - optional int32 records = 6; -} - -message LogUsageRequest { - required string app_id = 1; - repeated string version_id = 2; - optional int32 start_time = 3; - optional int32 end_time = 4; - optional uint32 resolution_hours = 5 [default = 1]; - optional bool combine_versions = 6; - optional int32 usage_version = 7; - optional bool versions_only = 8; -} - -message LogUsageResponse { - repeated LogUsageRecord usage = 1; - optional LogUsageRecord summary = 2; -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main.go deleted file mode 100644 index 4903616..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main.go +++ /dev/null @@ -1,15 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build appengine - -package internal - -import ( - "appengine_internal" -) - -func Main() { - appengine_internal.Main() -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main_vm.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main_vm.go deleted file mode 100644 index 57331ad..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/main_vm.go +++ /dev/null @@ -1,44 +0,0 @@ -// Copyright 2011 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -// +build !appengine - -package internal - -import ( - "io" - "log" - "net/http" - "net/url" - "os" -) - -func Main() { - installHealthChecker(http.DefaultServeMux) - - port := "8080" - if s := os.Getenv("PORT"); s != "" { - port = s - } - - if err := http.ListenAndServe(":"+port, http.HandlerFunc(handleHTTP)); err != nil { - log.Fatalf("http.ListenAndServe: %v", err) - } -} - -func installHealthChecker(mux *http.ServeMux) { - // If no health check handler has been installed by this point, add a trivial one. - const healthPath = "/_ah/health" - hreq := &http.Request{ - Method: "GET", - URL: &url.URL{ - Path: healthPath, - }, - } - if _, pat := mux.Handler(hreq); pat != healthPath { - mux.HandleFunc(healthPath, func(w http.ResponseWriter, r *http.Request) { - io.WriteString(w, "ok") - }) - } -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/metadata.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/metadata.go deleted file mode 100644 index 9cc1f71..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/metadata.go +++ /dev/null @@ -1,61 +0,0 @@ -// Copyright 2014 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -// This file has code for accessing metadata. -// -// References: -// https://cloud.google.com/compute/docs/metadata - -import ( - "fmt" - "io/ioutil" - "log" - "net/http" - "net/url" -) - -const ( - metadataHost = "metadata" - metadataPath = "/computeMetadata/v1/" -) - -var ( - metadataRequestHeaders = http.Header{ - "Metadata-Flavor": []string{"Google"}, - } -) - -// TODO(dsymonds): Do we need to support default values, like Python? -func mustGetMetadata(key string) []byte { - b, err := getMetadata(key) - if err != nil { - log.Fatalf("Metadata fetch failed: %v", err) - } - return b -} - -func getMetadata(key string) ([]byte, error) { - // TODO(dsymonds): May need to use url.Parse to support keys with query args. - req := &http.Request{ - Method: "GET", - URL: &url.URL{ - Scheme: "http", - Host: metadataHost, - Path: metadataPath + key, - }, - Header: metadataRequestHeaders, - Host: metadataHost, - } - resp, err := http.DefaultClient.Do(req) - if err != nil { - return nil, err - } - defer resp.Body.Close() - if resp.StatusCode != 200 { - return nil, fmt.Errorf("metadata server returned HTTP %d", resp.StatusCode) - } - return ioutil.ReadAll(resp.Body) -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.pb.go deleted file mode 100644 index a0145ed..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.pb.go +++ /dev/null @@ -1,375 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/modules/modules_service.proto -// DO NOT EDIT! - -/* -Package modules is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/modules/modules_service.proto - -It has these top-level messages: - ModulesServiceError - GetModulesRequest - GetModulesResponse - GetVersionsRequest - GetVersionsResponse - GetDefaultVersionRequest - GetDefaultVersionResponse - GetNumInstancesRequest - GetNumInstancesResponse - SetNumInstancesRequest - SetNumInstancesResponse - StartModuleRequest - StartModuleResponse - StopModuleRequest - StopModuleResponse - GetHostnameRequest - GetHostnameResponse -*/ -package modules - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type ModulesServiceError_ErrorCode int32 - -const ( - ModulesServiceError_OK ModulesServiceError_ErrorCode = 0 - ModulesServiceError_INVALID_MODULE ModulesServiceError_ErrorCode = 1 - ModulesServiceError_INVALID_VERSION ModulesServiceError_ErrorCode = 2 - ModulesServiceError_INVALID_INSTANCES ModulesServiceError_ErrorCode = 3 - ModulesServiceError_TRANSIENT_ERROR ModulesServiceError_ErrorCode = 4 - ModulesServiceError_UNEXPECTED_STATE ModulesServiceError_ErrorCode = 5 -) - -var ModulesServiceError_ErrorCode_name = map[int32]string{ - 0: "OK", - 1: "INVALID_MODULE", - 2: "INVALID_VERSION", - 3: "INVALID_INSTANCES", - 4: "TRANSIENT_ERROR", - 5: "UNEXPECTED_STATE", -} -var ModulesServiceError_ErrorCode_value = map[string]int32{ - "OK": 0, - "INVALID_MODULE": 1, - "INVALID_VERSION": 2, - "INVALID_INSTANCES": 3, - "TRANSIENT_ERROR": 4, - "UNEXPECTED_STATE": 5, -} - -func (x ModulesServiceError_ErrorCode) Enum() *ModulesServiceError_ErrorCode { - p := new(ModulesServiceError_ErrorCode) - *p = x - return p -} -func (x ModulesServiceError_ErrorCode) String() string { - return proto.EnumName(ModulesServiceError_ErrorCode_name, int32(x)) -} -func (x *ModulesServiceError_ErrorCode) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(ModulesServiceError_ErrorCode_value, data, "ModulesServiceError_ErrorCode") - if err != nil { - return err - } - *x = ModulesServiceError_ErrorCode(value) - return nil -} - -type ModulesServiceError struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *ModulesServiceError) Reset() { *m = ModulesServiceError{} } -func (m *ModulesServiceError) String() string { return proto.CompactTextString(m) } -func (*ModulesServiceError) ProtoMessage() {} - -type GetModulesRequest struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetModulesRequest) Reset() { *m = GetModulesRequest{} } -func (m *GetModulesRequest) String() string { return proto.CompactTextString(m) } -func (*GetModulesRequest) ProtoMessage() {} - -type GetModulesResponse struct { - Module []string `protobuf:"bytes,1,rep,name=module" json:"module,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetModulesResponse) Reset() { *m = GetModulesResponse{} } -func (m *GetModulesResponse) String() string { return proto.CompactTextString(m) } -func (*GetModulesResponse) ProtoMessage() {} - -func (m *GetModulesResponse) GetModule() []string { - if m != nil { - return m.Module - } - return nil -} - -type GetVersionsRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetVersionsRequest) Reset() { *m = GetVersionsRequest{} } -func (m *GetVersionsRequest) String() string { return proto.CompactTextString(m) } -func (*GetVersionsRequest) ProtoMessage() {} - -func (m *GetVersionsRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -type GetVersionsResponse struct { - Version []string `protobuf:"bytes,1,rep,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetVersionsResponse) Reset() { *m = GetVersionsResponse{} } -func (m *GetVersionsResponse) String() string { return proto.CompactTextString(m) } -func (*GetVersionsResponse) ProtoMessage() {} - -func (m *GetVersionsResponse) GetVersion() []string { - if m != nil { - return m.Version - } - return nil -} - -type GetDefaultVersionRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetDefaultVersionRequest) Reset() { *m = GetDefaultVersionRequest{} } -func (m *GetDefaultVersionRequest) String() string { return proto.CompactTextString(m) } -func (*GetDefaultVersionRequest) ProtoMessage() {} - -func (m *GetDefaultVersionRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -type GetDefaultVersionResponse struct { - Version *string `protobuf:"bytes,1,req,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetDefaultVersionResponse) Reset() { *m = GetDefaultVersionResponse{} } -func (m *GetDefaultVersionResponse) String() string { return proto.CompactTextString(m) } -func (*GetDefaultVersionResponse) ProtoMessage() {} - -func (m *GetDefaultVersionResponse) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -type GetNumInstancesRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - Version *string `protobuf:"bytes,2,opt,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetNumInstancesRequest) Reset() { *m = GetNumInstancesRequest{} } -func (m *GetNumInstancesRequest) String() string { return proto.CompactTextString(m) } -func (*GetNumInstancesRequest) ProtoMessage() {} - -func (m *GetNumInstancesRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -func (m *GetNumInstancesRequest) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -type GetNumInstancesResponse struct { - Instances *int64 `protobuf:"varint,1,req,name=instances" json:"instances,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetNumInstancesResponse) Reset() { *m = GetNumInstancesResponse{} } -func (m *GetNumInstancesResponse) String() string { return proto.CompactTextString(m) } -func (*GetNumInstancesResponse) ProtoMessage() {} - -func (m *GetNumInstancesResponse) GetInstances() int64 { - if m != nil && m.Instances != nil { - return *m.Instances - } - return 0 -} - -type SetNumInstancesRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - Version *string `protobuf:"bytes,2,opt,name=version" json:"version,omitempty"` - Instances *int64 `protobuf:"varint,3,req,name=instances" json:"instances,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *SetNumInstancesRequest) Reset() { *m = SetNumInstancesRequest{} } -func (m *SetNumInstancesRequest) String() string { return proto.CompactTextString(m) } -func (*SetNumInstancesRequest) ProtoMessage() {} - -func (m *SetNumInstancesRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -func (m *SetNumInstancesRequest) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -func (m *SetNumInstancesRequest) GetInstances() int64 { - if m != nil && m.Instances != nil { - return *m.Instances - } - return 0 -} - -type SetNumInstancesResponse struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *SetNumInstancesResponse) Reset() { *m = SetNumInstancesResponse{} } -func (m *SetNumInstancesResponse) String() string { return proto.CompactTextString(m) } -func (*SetNumInstancesResponse) ProtoMessage() {} - -type StartModuleRequest struct { - Module *string `protobuf:"bytes,1,req,name=module" json:"module,omitempty"` - Version *string `protobuf:"bytes,2,req,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *StartModuleRequest) Reset() { *m = StartModuleRequest{} } -func (m *StartModuleRequest) String() string { return proto.CompactTextString(m) } -func (*StartModuleRequest) ProtoMessage() {} - -func (m *StartModuleRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -func (m *StartModuleRequest) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -type StartModuleResponse struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *StartModuleResponse) Reset() { *m = StartModuleResponse{} } -func (m *StartModuleResponse) String() string { return proto.CompactTextString(m) } -func (*StartModuleResponse) ProtoMessage() {} - -type StopModuleRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - Version *string `protobuf:"bytes,2,opt,name=version" json:"version,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *StopModuleRequest) Reset() { *m = StopModuleRequest{} } -func (m *StopModuleRequest) String() string { return proto.CompactTextString(m) } -func (*StopModuleRequest) ProtoMessage() {} - -func (m *StopModuleRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -func (m *StopModuleRequest) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -type StopModuleResponse struct { - XXX_unrecognized []byte `json:"-"` -} - -func (m *StopModuleResponse) Reset() { *m = StopModuleResponse{} } -func (m *StopModuleResponse) String() string { return proto.CompactTextString(m) } -func (*StopModuleResponse) ProtoMessage() {} - -type GetHostnameRequest struct { - Module *string `protobuf:"bytes,1,opt,name=module" json:"module,omitempty"` - Version *string `protobuf:"bytes,2,opt,name=version" json:"version,omitempty"` - Instance *string `protobuf:"bytes,3,opt,name=instance" json:"instance,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetHostnameRequest) Reset() { *m = GetHostnameRequest{} } -func (m *GetHostnameRequest) String() string { return proto.CompactTextString(m) } -func (*GetHostnameRequest) ProtoMessage() {} - -func (m *GetHostnameRequest) GetModule() string { - if m != nil && m.Module != nil { - return *m.Module - } - return "" -} - -func (m *GetHostnameRequest) GetVersion() string { - if m != nil && m.Version != nil { - return *m.Version - } - return "" -} - -func (m *GetHostnameRequest) GetInstance() string { - if m != nil && m.Instance != nil { - return *m.Instance - } - return "" -} - -type GetHostnameResponse struct { - Hostname *string `protobuf:"bytes,1,req,name=hostname" json:"hostname,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *GetHostnameResponse) Reset() { *m = GetHostnameResponse{} } -func (m *GetHostnameResponse) String() string { return proto.CompactTextString(m) } -func (*GetHostnameResponse) ProtoMessage() {} - -func (m *GetHostnameResponse) GetHostname() string { - if m != nil && m.Hostname != nil { - return *m.Hostname - } - return "" -} - -func init() { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.proto deleted file mode 100644 index d29f006..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/modules/modules_service.proto +++ /dev/null @@ -1,80 +0,0 @@ -syntax = "proto2"; -option go_package = "modules"; - -package appengine; - -message ModulesServiceError { - enum ErrorCode { - OK = 0; - INVALID_MODULE = 1; - INVALID_VERSION = 2; - INVALID_INSTANCES = 3; - TRANSIENT_ERROR = 4; - UNEXPECTED_STATE = 5; - } -} - -message GetModulesRequest { -} - -message GetModulesResponse { - repeated string module = 1; -} - -message GetVersionsRequest { - optional string module = 1; -} - -message GetVersionsResponse { - repeated string version = 1; -} - -message GetDefaultVersionRequest { - optional string module = 1; -} - -message GetDefaultVersionResponse { - required string version = 1; -} - -message GetNumInstancesRequest { - optional string module = 1; - optional string version = 2; -} - -message GetNumInstancesResponse { - required int64 instances = 1; -} - -message SetNumInstancesRequest { - optional string module = 1; - optional string version = 2; - required int64 instances = 3; -} - -message SetNumInstancesResponse {} - -message StartModuleRequest { - required string module = 1; - required string version = 2; -} - -message StartModuleResponse {} - -message StopModuleRequest { - optional string module = 1; - optional string version = 2; -} - -message StopModuleResponse {} - -message GetHostnameRequest { - optional string module = 1; - optional string version = 2; - optional string instance = 3; -} - -message GetHostnameResponse { - required string hostname = 1; -} - diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/net.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/net.go deleted file mode 100644 index 3b94cf0..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/net.go +++ /dev/null @@ -1,56 +0,0 @@ -// Copyright 2014 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -// This file implements a network dialer that limits the number of concurrent connections. -// It is only used for API calls. - -import ( - "log" - "net" - "runtime" - "sync" - "time" -) - -var limitSem = make(chan int, 100) // TODO(dsymonds): Use environment variable. - -func limitRelease() { - // non-blocking - select { - case <-limitSem: - default: - // This should not normally happen. - log.Print("appengine: unbalanced limitSem release!") - } -} - -func limitDial(network, addr string) (net.Conn, error) { - limitSem <- 1 - - // Dial with a timeout in case the API host is MIA. - // The connection should normally be very fast. - conn, err := net.DialTimeout(network, addr, 500*time.Millisecond) - if err != nil { - limitRelease() - return nil, err - } - lc := &limitConn{Conn: conn} - runtime.SetFinalizer(lc, (*limitConn).Close) // shouldn't usually be required - return lc, nil -} - -type limitConn struct { - close sync.Once - net.Conn -} - -func (lc *limitConn) Close() error { - defer lc.close.Do(func() { - limitRelease() - runtime.SetFinalizer(lc, nil) - }) - return lc.Conn.Close() -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/regen.sh b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/regen.sh deleted file mode 100755 index 2fdb546..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/regen.sh +++ /dev/null @@ -1,40 +0,0 @@ -#!/bin/bash -e -# -# This script rebuilds the generated code for the protocol buffers. -# To run this you will need protoc and goprotobuf installed; -# see https://github.com/golang/protobuf for instructions. - -PKG=google.golang.org/appengine - -function die() { - echo 1>&2 $* - exit 1 -} - -# Sanity check that the right tools are accessible. -for tool in go protoc protoc-gen-go; do - q=$(which $tool) || die "didn't find $tool" - echo 1>&2 "$tool: $q" -done - -echo -n 1>&2 "finding package dir... " -pkgdir=$(go list -f '{{.Dir}}' $PKG) -echo 1>&2 $pkgdir -base=$(echo $pkgdir | sed "s,/$PKG\$,,") -echo 1>&2 "base: $base" -cd $base - -# Run protoc once per package. -for dir in $(find $PKG/internal -name '*.proto' | xargs dirname | sort | uniq); do - echo 1>&2 "* $dir" - protoc --go_out=. $dir/*.proto -done - -for f in $(find $PKG/internal -name '*.pb.go'); do - # Remove proto.RegisterEnum calls. - # These cause duplicate registration panics when these packages - # are used on classic App Engine. proto.RegisterEnum only affects - # parsing the text format; we don't care about that. - # https://code.google.com/p/googleappengine/issues/detail?id=11670#c17 - sed -i '/proto.RegisterEnum/d' $f -done diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go deleted file mode 100644 index 526bd39..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +++ /dev/null @@ -1,231 +0,0 @@ -// Code generated by protoc-gen-go. -// source: google.golang.org/appengine/internal/remote_api/remote_api.proto -// DO NOT EDIT! - -/* -Package remote_api is a generated protocol buffer package. - -It is generated from these files: - google.golang.org/appengine/internal/remote_api/remote_api.proto - -It has these top-level messages: - Request - ApplicationError - RpcError - Response -*/ -package remote_api - -import proto "github.com/golang/protobuf/proto" -import fmt "fmt" -import math "math" - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -type RpcError_ErrorCode int32 - -const ( - RpcError_UNKNOWN RpcError_ErrorCode = 0 - RpcError_CALL_NOT_FOUND RpcError_ErrorCode = 1 - RpcError_PARSE_ERROR RpcError_ErrorCode = 2 - RpcError_SECURITY_VIOLATION RpcError_ErrorCode = 3 - RpcError_OVER_QUOTA RpcError_ErrorCode = 4 - RpcError_REQUEST_TOO_LARGE RpcError_ErrorCode = 5 - RpcError_CAPABILITY_DISABLED RpcError_ErrorCode = 6 - RpcError_FEATURE_DISABLED RpcError_ErrorCode = 7 - RpcError_BAD_REQUEST RpcError_ErrorCode = 8 - RpcError_RESPONSE_TOO_LARGE RpcError_ErrorCode = 9 - RpcError_CANCELLED RpcError_ErrorCode = 10 - RpcError_REPLAY_ERROR RpcError_ErrorCode = 11 - RpcError_DEADLINE_EXCEEDED RpcError_ErrorCode = 12 -) - -var RpcError_ErrorCode_name = map[int32]string{ - 0: "UNKNOWN", - 1: "CALL_NOT_FOUND", - 2: "PARSE_ERROR", - 3: "SECURITY_VIOLATION", - 4: "OVER_QUOTA", - 5: "REQUEST_TOO_LARGE", - 6: "CAPABILITY_DISABLED", - 7: "FEATURE_DISABLED", - 8: "BAD_REQUEST", - 9: "RESPONSE_TOO_LARGE", - 10: "CANCELLED", - 11: "REPLAY_ERROR", - 12: "DEADLINE_EXCEEDED", -} -var RpcError_ErrorCode_value = map[string]int32{ - "UNKNOWN": 0, - "CALL_NOT_FOUND": 1, - "PARSE_ERROR": 2, - "SECURITY_VIOLATION": 3, - "OVER_QUOTA": 4, - "REQUEST_TOO_LARGE": 5, - "CAPABILITY_DISABLED": 6, - "FEATURE_DISABLED": 7, - "BAD_REQUEST": 8, - "RESPONSE_TOO_LARGE": 9, - "CANCELLED": 10, - "REPLAY_ERROR": 11, - "DEADLINE_EXCEEDED": 12, -} - -func (x RpcError_ErrorCode) Enum() *RpcError_ErrorCode { - p := new(RpcError_ErrorCode) - *p = x - return p -} -func (x RpcError_ErrorCode) String() string { - return proto.EnumName(RpcError_ErrorCode_name, int32(x)) -} -func (x *RpcError_ErrorCode) UnmarshalJSON(data []byte) error { - value, err := proto.UnmarshalJSONEnum(RpcError_ErrorCode_value, data, "RpcError_ErrorCode") - if err != nil { - return err - } - *x = RpcError_ErrorCode(value) - return nil -} - -type Request struct { - ServiceName *string `protobuf:"bytes,2,req,name=service_name" json:"service_name,omitempty"` - Method *string `protobuf:"bytes,3,req,name=method" json:"method,omitempty"` - Request []byte `protobuf:"bytes,4,req,name=request" json:"request,omitempty"` - RequestId *string `protobuf:"bytes,5,opt,name=request_id" json:"request_id,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Request) Reset() { *m = Request{} } -func (m *Request) String() string { return proto.CompactTextString(m) } -func (*Request) ProtoMessage() {} - -func (m *Request) GetServiceName() string { - if m != nil && m.ServiceName != nil { - return *m.ServiceName - } - return "" -} - -func (m *Request) GetMethod() string { - if m != nil && m.Method != nil { - return *m.Method - } - return "" -} - -func (m *Request) GetRequest() []byte { - if m != nil { - return m.Request - } - return nil -} - -func (m *Request) GetRequestId() string { - if m != nil && m.RequestId != nil { - return *m.RequestId - } - return "" -} - -type ApplicationError struct { - Code *int32 `protobuf:"varint,1,req,name=code" json:"code,omitempty"` - Detail *string `protobuf:"bytes,2,req,name=detail" json:"detail,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *ApplicationError) Reset() { *m = ApplicationError{} } -func (m *ApplicationError) String() string { return proto.CompactTextString(m) } -func (*ApplicationError) ProtoMessage() {} - -func (m *ApplicationError) GetCode() int32 { - if m != nil && m.Code != nil { - return *m.Code - } - return 0 -} - -func (m *ApplicationError) GetDetail() string { - if m != nil && m.Detail != nil { - return *m.Detail - } - return "" -} - -type RpcError struct { - Code *int32 `protobuf:"varint,1,req,name=code" json:"code,omitempty"` - Detail *string `protobuf:"bytes,2,opt,name=detail" json:"detail,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *RpcError) Reset() { *m = RpcError{} } -func (m *RpcError) String() string { return proto.CompactTextString(m) } -func (*RpcError) ProtoMessage() {} - -func (m *RpcError) GetCode() int32 { - if m != nil && m.Code != nil { - return *m.Code - } - return 0 -} - -func (m *RpcError) GetDetail() string { - if m != nil && m.Detail != nil { - return *m.Detail - } - return "" -} - -type Response struct { - Response []byte `protobuf:"bytes,1,opt,name=response" json:"response,omitempty"` - Exception []byte `protobuf:"bytes,2,opt,name=exception" json:"exception,omitempty"` - ApplicationError *ApplicationError `protobuf:"bytes,3,opt,name=application_error" json:"application_error,omitempty"` - JavaException []byte `protobuf:"bytes,4,opt,name=java_exception" json:"java_exception,omitempty"` - RpcError *RpcError `protobuf:"bytes,5,opt,name=rpc_error" json:"rpc_error,omitempty"` - XXX_unrecognized []byte `json:"-"` -} - -func (m *Response) Reset() { *m = Response{} } -func (m *Response) String() string { return proto.CompactTextString(m) } -func (*Response) ProtoMessage() {} - -func (m *Response) GetResponse() []byte { - if m != nil { - return m.Response - } - return nil -} - -func (m *Response) GetException() []byte { - if m != nil { - return m.Exception - } - return nil -} - -func (m *Response) GetApplicationError() *ApplicationError { - if m != nil { - return m.ApplicationError - } - return nil -} - -func (m *Response) GetJavaException() []byte { - if m != nil { - return m.JavaException - } - return nil -} - -func (m *Response) GetRpcError() *RpcError { - if m != nil { - return m.RpcError - } - return nil -} - -func init() { -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto deleted file mode 100644 index f21763a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +++ /dev/null @@ -1,44 +0,0 @@ -syntax = "proto2"; -option go_package = "remote_api"; - -package remote_api; - -message Request { - required string service_name = 2; - required string method = 3; - required bytes request = 4; - optional string request_id = 5; -} - -message ApplicationError { - required int32 code = 1; - required string detail = 2; -} - -message RpcError { - enum ErrorCode { - UNKNOWN = 0; - CALL_NOT_FOUND = 1; - PARSE_ERROR = 2; - SECURITY_VIOLATION = 3; - OVER_QUOTA = 4; - REQUEST_TOO_LARGE = 5; - CAPABILITY_DISABLED = 6; - FEATURE_DISABLED = 7; - BAD_REQUEST = 8; - RESPONSE_TOO_LARGE = 9; - CANCELLED = 10; - REPLAY_ERROR = 11; - DEADLINE_EXCEEDED = 12; - } - required int32 code = 1; - optional string detail = 2; -} - -message Response { - optional bytes response = 1; - optional bytes exception = 2; - optional ApplicationError application_error = 3; - optional bytes java_exception = 4; - optional RpcError rpc_error = 5; -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/transaction.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/transaction.go deleted file mode 100644 index 28a6d18..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/internal/transaction.go +++ /dev/null @@ -1,107 +0,0 @@ -// Copyright 2014 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package internal - -// This file implements hooks for applying datastore transactions. - -import ( - "errors" - "reflect" - - "github.com/golang/protobuf/proto" - netcontext "golang.org/x/net/context" - - basepb "google.golang.org/appengine/internal/base" - pb "google.golang.org/appengine/internal/datastore" -) - -var transactionSetters = make(map[reflect.Type]reflect.Value) - -// RegisterTransactionSetter registers a function that sets transaction information -// in a protocol buffer message. f should be a function with two arguments, -// the first being a protocol buffer type, and the second being *datastore.Transaction. -func RegisterTransactionSetter(f interface{}) { - v := reflect.ValueOf(f) - transactionSetters[v.Type().In(0)] = v -} - -// applyTransaction applies the transaction t to message pb -// by using the relevant setter passed to RegisterTransactionSetter. -func applyTransaction(pb proto.Message, t *pb.Transaction) { - v := reflect.ValueOf(pb) - if f, ok := transactionSetters[v.Type()]; ok { - f.Call([]reflect.Value{v, reflect.ValueOf(t)}) - } -} - -var transactionKey = "used for *Transaction" - -func transactionFromContext(ctx netcontext.Context) *transaction { - t, _ := ctx.Value(&transactionKey).(*transaction) - return t -} - -func withTransaction(ctx netcontext.Context, t *transaction) netcontext.Context { - return netcontext.WithValue(ctx, &transactionKey, t) -} - -type transaction struct { - transaction pb.Transaction - finished bool -} - -var ErrConcurrentTransaction = errors.New("internal: concurrent transaction") - -func RunTransactionOnce(c netcontext.Context, f func(netcontext.Context) error, xg bool) error { - if transactionFromContext(c) != nil { - return errors.New("nested transactions are not supported") - } - - // Begin the transaction. - t := &transaction{} - req := &pb.BeginTransactionRequest{ - App: proto.String(FullyQualifiedAppID(c)), - } - if xg { - req.AllowMultipleEg = proto.Bool(true) - } - if err := Call(c, "datastore_v3", "BeginTransaction", req, &t.transaction); err != nil { - return err - } - - // Call f, rolling back the transaction if f returns a non-nil error, or panics. - // The panic is not recovered. - defer func() { - if t.finished { - return - } - t.finished = true - // Ignore the error return value, since we are already returning a non-nil - // error (or we're panicking). - Call(c, "datastore_v3", "Rollback", &t.transaction, &basepb.VoidProto{}) - }() - if err := f(withTransaction(c, t)); err != nil { - return err - } - t.finished = true - - // Commit the transaction. - res := &pb.CommitResponse{} - err := Call(c, "datastore_v3", "Commit", &t.transaction, res) - if ae, ok := err.(*APIError); ok { - /* TODO: restore this conditional - if appengine.IsDevAppServer() { - */ - // The Python Dev AppServer raises an ApplicationError with error code 2 (which is - // Error.CONCURRENT_TRANSACTION) and message "Concurrency exception.". - if ae.Code == int32(pb.Error_BAD_REQUEST) && ae.Detail == "ApplicationError: 2 Concurrency exception." { - return ErrConcurrentTransaction - } - if ae.Code == int32(pb.Error_CONCURRENT_TRANSACTION) { - return ErrConcurrentTransaction - } - } - return err -} diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/namespace.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/namespace.go deleted file mode 100644 index 21860ca..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/namespace.go +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright 2012 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package appengine - -import ( - "fmt" - "regexp" - - "golang.org/x/net/context" - - "google.golang.org/appengine/internal" -) - -// Namespace returns a replacement context that operates within the given namespace. -func Namespace(c context.Context, namespace string) (context.Context, error) { - if !validNamespace.MatchString(namespace) { - return nil, fmt.Errorf("appengine: namespace %q does not match /%s/", namespace, validNamespace) - } - return internal.NamespacedContext(c, namespace), nil -} - -// validNamespace matches valid namespace names. -var validNamespace = regexp.MustCompile(`^[0-9A-Za-z._-]{0,100}$`) diff --git a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/timeout.go b/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/timeout.go deleted file mode 100644 index 05642a9..0000000 --- a/vendor/k8s.io/kubernetes/vendor/google.golang.org/appengine/timeout.go +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright 2013 Google Inc. All rights reserved. -// Use of this source code is governed by the Apache 2.0 -// license that can be found in the LICENSE file. - -package appengine - -import "golang.org/x/net/context" - -// IsTimeoutError reports whether err is a timeout error. -func IsTimeoutError(err error) bool { - if err == context.DeadlineExceeded { - return true - } - if t, ok := err.(interface { - IsTimeout() bool - }); ok { - return t.IsTimeout() - } - return false -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/LICENSE b/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/LICENSE deleted file mode 100644 index 87a5ced..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/LICENSE +++ /dev/null @@ -1,28 +0,0 @@ -Copyright (c) 2012 Péter Surányi. Portions Copyright (c) 2009 The Go -Authors. All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: - - * Redistributions of source code must retain the above copyright -notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above -copyright notice, this list of conditions and the following disclaimer -in the documentation and/or other materials provided with the -distribution. - * Neither the name of Google Inc. nor the names of its -contributors may be used to endorse or promote products derived from -this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/dec.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/dec.go deleted file mode 100644 index d17ad94..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/dec.go +++ /dev/null @@ -1,615 +0,0 @@ -// Package inf (type inf.Dec) implements "infinite-precision" decimal -// arithmetic. -// "Infinite precision" describes two characteristics: practically unlimited -// precision for decimal number representation and no support for calculating -// with any specific fixed precision. -// (Although there is no practical limit on precision, inf.Dec can only -// represent finite decimals.) -// -// This package is currently in experimental stage and the API may change. -// -// This package does NOT support: -// - rounding to specific precisions (as opposed to specific decimal positions) -// - the notion of context (each rounding must be explicit) -// - NaN and Inf values, and distinguishing between positive and negative zero -// - conversions to and from float32/64 types -// -// Features considered for possible addition: -// + formatting options -// + Exp method -// + combined operations such as AddRound/MulAdd etc -// + exchanging data in decimal32/64/128 formats -// -package inf - -// TODO: -// - avoid excessive deep copying (quo and rounders) - -import ( - "fmt" - "io" - "math/big" - "strings" -) - -// A Dec represents a signed arbitrary-precision decimal. -// It is a combination of a sign, an arbitrary-precision integer coefficient -// value, and a signed fixed-precision exponent value. -// The sign and the coefficient value are handled together as a signed value -// and referred to as the unscaled value. -// (Positive and negative zero values are not distinguished.) -// Since the exponent is most commonly non-positive, it is handled in negated -// form and referred to as scale. -// -// The mathematical value of a Dec equals: -// -// unscaled * 10**(-scale) -// -// Note that different Dec representations may have equal mathematical values. -// -// unscaled scale String() -// ------------------------- -// 0 0 "0" -// 0 2 "0.00" -// 0 -2 "0" -// 1 0 "1" -// 100 2 "1.00" -// 10 0 "10" -// 1 -1 "10" -// -// The zero value for a Dec represents the value 0 with scale 0. -// -// Operations are typically performed through the *Dec type. -// The semantics of the assignment operation "=" for "bare" Dec values is -// undefined and should not be relied on. -// -// Methods are typically of the form: -// -// func (z *Dec) Op(x, y *Dec) *Dec -// -// and implement operations z = x Op y with the result as receiver; if it -// is one of the operands it may be overwritten (and its memory reused). -// To enable chaining of operations, the result is also returned. Methods -// returning a result other than *Dec take one of the operands as the receiver. -// -// A "bare" Quo method (quotient / division operation) is not provided, as the -// result is not always a finite decimal and thus in general cannot be -// represented as a Dec. -// Instead, in the common case when rounding is (potentially) necessary, -// QuoRound should be used with a Scale and a Rounder. -// QuoExact or QuoRound with RoundExact can be used in the special cases when it -// is known that the result is always a finite decimal. -// -type Dec struct { - unscaled big.Int - scale Scale -} - -// Scale represents the type used for the scale of a Dec. -type Scale int32 - -const scaleSize = 4 // bytes in a Scale value - -// Scaler represents a method for obtaining the scale to use for the result of -// an operation on x and y. -type scaler interface { - Scale(x *Dec, y *Dec) Scale -} - -var bigInt = [...]*big.Int{ - big.NewInt(0), big.NewInt(1), big.NewInt(2), big.NewInt(3), big.NewInt(4), - big.NewInt(5), big.NewInt(6), big.NewInt(7), big.NewInt(8), big.NewInt(9), - big.NewInt(10), -} - -var exp10cache [64]big.Int = func() [64]big.Int { - e10, e10i := [64]big.Int{}, bigInt[1] - for i, _ := range e10 { - e10[i].Set(e10i) - e10i = new(big.Int).Mul(e10i, bigInt[10]) - } - return e10 -}() - -// NewDec allocates and returns a new Dec set to the given int64 unscaled value -// and scale. -func NewDec(unscaled int64, scale Scale) *Dec { - return new(Dec).SetUnscaled(unscaled).SetScale(scale) -} - -// NewDecBig allocates and returns a new Dec set to the given *big.Int unscaled -// value and scale. -func NewDecBig(unscaled *big.Int, scale Scale) *Dec { - return new(Dec).SetUnscaledBig(unscaled).SetScale(scale) -} - -// Scale returns the scale of x. -func (x *Dec) Scale() Scale { - return x.scale -} - -// Unscaled returns the unscaled value of x for u and true for ok when the -// unscaled value can be represented as int64; otherwise it returns an undefined -// int64 value for u and false for ok. Use x.UnscaledBig().Int64() to avoid -// checking the validity of the value when the check is known to be redundant. -func (x *Dec) Unscaled() (u int64, ok bool) { - u = x.unscaled.Int64() - var i big.Int - ok = i.SetInt64(u).Cmp(&x.unscaled) == 0 - return -} - -// UnscaledBig returns the unscaled value of x as *big.Int. -func (x *Dec) UnscaledBig() *big.Int { - return &x.unscaled -} - -// SetScale sets the scale of z, with the unscaled value unchanged, and returns -// z. -// The mathematical value of the Dec changes as if it was multiplied by -// 10**(oldscale-scale). -func (z *Dec) SetScale(scale Scale) *Dec { - z.scale = scale - return z -} - -// SetUnscaled sets the unscaled value of z, with the scale unchanged, and -// returns z. -func (z *Dec) SetUnscaled(unscaled int64) *Dec { - z.unscaled.SetInt64(unscaled) - return z -} - -// SetUnscaledBig sets the unscaled value of z, with the scale unchanged, and -// returns z. -func (z *Dec) SetUnscaledBig(unscaled *big.Int) *Dec { - z.unscaled.Set(unscaled) - return z -} - -// Set sets z to the value of x and returns z. -// It does nothing if z == x. -func (z *Dec) Set(x *Dec) *Dec { - if z != x { - z.SetUnscaledBig(x.UnscaledBig()) - z.SetScale(x.Scale()) - } - return z -} - -// Sign returns: -// -// -1 if x < 0 -// 0 if x == 0 -// +1 if x > 0 -// -func (x *Dec) Sign() int { - return x.UnscaledBig().Sign() -} - -// Neg sets z to -x and returns z. -func (z *Dec) Neg(x *Dec) *Dec { - z.SetScale(x.Scale()) - z.UnscaledBig().Neg(x.UnscaledBig()) - return z -} - -// Cmp compares x and y and returns: -// -// -1 if x < y -// 0 if x == y -// +1 if x > y -// -func (x *Dec) Cmp(y *Dec) int { - xx, yy := upscale(x, y) - return xx.UnscaledBig().Cmp(yy.UnscaledBig()) -} - -// Abs sets z to |x| (the absolute value of x) and returns z. -func (z *Dec) Abs(x *Dec) *Dec { - z.SetScale(x.Scale()) - z.UnscaledBig().Abs(x.UnscaledBig()) - return z -} - -// Add sets z to the sum x+y and returns z. -// The scale of z is the greater of the scales of x and y. -func (z *Dec) Add(x, y *Dec) *Dec { - xx, yy := upscale(x, y) - z.SetScale(xx.Scale()) - z.UnscaledBig().Add(xx.UnscaledBig(), yy.UnscaledBig()) - return z -} - -// Sub sets z to the difference x-y and returns z. -// The scale of z is the greater of the scales of x and y. -func (z *Dec) Sub(x, y *Dec) *Dec { - xx, yy := upscale(x, y) - z.SetScale(xx.Scale()) - z.UnscaledBig().Sub(xx.UnscaledBig(), yy.UnscaledBig()) - return z -} - -// Mul sets z to the product x*y and returns z. -// The scale of z is the sum of the scales of x and y. -func (z *Dec) Mul(x, y *Dec) *Dec { - z.SetScale(x.Scale() + y.Scale()) - z.UnscaledBig().Mul(x.UnscaledBig(), y.UnscaledBig()) - return z -} - -// Round sets z to the value of x rounded to Scale s using Rounder r, and -// returns z. -func (z *Dec) Round(x *Dec, s Scale, r Rounder) *Dec { - return z.QuoRound(x, NewDec(1, 0), s, r) -} - -// QuoRound sets z to the quotient x/y, rounded using the given Rounder to the -// specified scale. -// -// If the rounder is RoundExact but the result can not be expressed exactly at -// the specified scale, QuoRound returns nil, and the value of z is undefined. -// -// There is no corresponding Div method; the equivalent can be achieved through -// the choice of Rounder used. -// -func (z *Dec) QuoRound(x, y *Dec, s Scale, r Rounder) *Dec { - return z.quo(x, y, sclr{s}, r) -} - -func (z *Dec) quo(x, y *Dec, s scaler, r Rounder) *Dec { - scl := s.Scale(x, y) - var zzz *Dec - if r.UseRemainder() { - zz, rA, rB := new(Dec).quoRem(x, y, scl, true, new(big.Int), new(big.Int)) - zzz = r.Round(new(Dec), zz, rA, rB) - } else { - zz, _, _ := new(Dec).quoRem(x, y, scl, false, nil, nil) - zzz = r.Round(new(Dec), zz, nil, nil) - } - if zzz == nil { - return nil - } - return z.Set(zzz) -} - -// QuoExact sets z to the quotient x/y and returns z when x/y is a finite -// decimal. Otherwise it returns nil and the value of z is undefined. -// -// The scale of a non-nil result is "x.Scale() - y.Scale()" or greater; it is -// calculated so that the remainder will be zero whenever x/y is a finite -// decimal. -func (z *Dec) QuoExact(x, y *Dec) *Dec { - return z.quo(x, y, scaleQuoExact{}, RoundExact) -} - -// quoRem sets z to the quotient x/y with the scale s, and if useRem is true, -// it sets remNum and remDen to the numerator and denominator of the remainder. -// It returns z, remNum and remDen. -// -// The remainder is normalized to the range -1 < r < 1 to simplify rounding; -// that is, the results satisfy the following equation: -// -// x / y = z + (remNum/remDen) * 10**(-z.Scale()) -// -// See Rounder for more details about rounding. -// -func (z *Dec) quoRem(x, y *Dec, s Scale, useRem bool, - remNum, remDen *big.Int) (*Dec, *big.Int, *big.Int) { - // difference (required adjustment) compared to "canonical" result scale - shift := s - (x.Scale() - y.Scale()) - // pointers to adjusted unscaled dividend and divisor - var ix, iy *big.Int - switch { - case shift > 0: - // increased scale: decimal-shift dividend left - ix = new(big.Int).Mul(x.UnscaledBig(), exp10(shift)) - iy = y.UnscaledBig() - case shift < 0: - // decreased scale: decimal-shift divisor left - ix = x.UnscaledBig() - iy = new(big.Int).Mul(y.UnscaledBig(), exp10(-shift)) - default: - ix = x.UnscaledBig() - iy = y.UnscaledBig() - } - // save a copy of iy in case it to be overwritten with the result - iy2 := iy - if iy == z.UnscaledBig() { - iy2 = new(big.Int).Set(iy) - } - // set scale - z.SetScale(s) - // set unscaled - if useRem { - // Int division - _, intr := z.UnscaledBig().QuoRem(ix, iy, new(big.Int)) - // set remainder - remNum.Set(intr) - remDen.Set(iy2) - } else { - z.UnscaledBig().Quo(ix, iy) - } - return z, remNum, remDen -} - -type sclr struct{ s Scale } - -func (s sclr) Scale(x, y *Dec) Scale { - return s.s -} - -type scaleQuoExact struct{} - -func (sqe scaleQuoExact) Scale(x, y *Dec) Scale { - rem := new(big.Rat).SetFrac(x.UnscaledBig(), y.UnscaledBig()) - f2, f5 := factor2(rem.Denom()), factor(rem.Denom(), bigInt[5]) - var f10 Scale - if f2 > f5 { - f10 = Scale(f2) - } else { - f10 = Scale(f5) - } - return x.Scale() - y.Scale() + f10 -} - -func factor(n *big.Int, p *big.Int) int { - // could be improved for large factors - d, f := n, 0 - for { - dd, dm := new(big.Int).DivMod(d, p, new(big.Int)) - if dm.Sign() == 0 { - f++ - d = dd - } else { - break - } - } - return f -} - -func factor2(n *big.Int) int { - // could be improved for large factors - f := 0 - for ; n.Bit(f) == 0; f++ { - } - return f -} - -func upscale(a, b *Dec) (*Dec, *Dec) { - if a.Scale() == b.Scale() { - return a, b - } - if a.Scale() > b.Scale() { - bb := b.rescale(a.Scale()) - return a, bb - } - aa := a.rescale(b.Scale()) - return aa, b -} - -func exp10(x Scale) *big.Int { - if int(x) < len(exp10cache) { - return &exp10cache[int(x)] - } - return new(big.Int).Exp(bigInt[10], big.NewInt(int64(x)), nil) -} - -func (x *Dec) rescale(newScale Scale) *Dec { - shift := newScale - x.Scale() - switch { - case shift < 0: - e := exp10(-shift) - return NewDecBig(new(big.Int).Quo(x.UnscaledBig(), e), newScale) - case shift > 0: - e := exp10(shift) - return NewDecBig(new(big.Int).Mul(x.UnscaledBig(), e), newScale) - } - return x -} - -var zeros = []byte("00000000000000000000000000000000" + - "00000000000000000000000000000000") -var lzeros = Scale(len(zeros)) - -func appendZeros(s []byte, n Scale) []byte { - for i := Scale(0); i < n; i += lzeros { - if n > i+lzeros { - s = append(s, zeros...) - } else { - s = append(s, zeros[0:n-i]...) - } - } - return s -} - -func (x *Dec) String() string { - if x == nil { - return "<nil>" - } - scale := x.Scale() - s := []byte(x.UnscaledBig().String()) - if scale <= 0 { - if scale != 0 && x.unscaled.Sign() != 0 { - s = appendZeros(s, -scale) - } - return string(s) - } - negbit := Scale(-((x.Sign() - 1) / 2)) - // scale > 0 - lens := Scale(len(s)) - if lens-negbit <= scale { - ss := make([]byte, 0, scale+2) - if negbit == 1 { - ss = append(ss, '-') - } - ss = append(ss, '0', '.') - ss = appendZeros(ss, scale-lens+negbit) - ss = append(ss, s[negbit:]...) - return string(ss) - } - // lens > scale - ss := make([]byte, 0, lens+1) - ss = append(ss, s[:lens-scale]...) - ss = append(ss, '.') - ss = append(ss, s[lens-scale:]...) - return string(ss) -} - -// Format is a support routine for fmt.Formatter. It accepts the decimal -// formats 'd' and 'f', and handles both equivalently. -// Width, precision, flags and bases 2, 8, 16 are not supported. -func (x *Dec) Format(s fmt.State, ch rune) { - if ch != 'd' && ch != 'f' && ch != 'v' && ch != 's' { - fmt.Fprintf(s, "%%!%c(dec.Dec=%s)", ch, x.String()) - return - } - fmt.Fprintf(s, x.String()) -} - -func (z *Dec) scan(r io.RuneScanner) (*Dec, error) { - unscaled := make([]byte, 0, 256) // collects chars of unscaled as bytes - dp, dg := -1, -1 // indexes of decimal point, first digit -loop: - for { - ch, _, err := r.ReadRune() - if err == io.EOF { - break loop - } - if err != nil { - return nil, err - } - switch { - case ch == '+' || ch == '-': - if len(unscaled) > 0 || dp >= 0 { // must be first character - r.UnreadRune() - break loop - } - case ch == '.': - if dp >= 0 { - r.UnreadRune() - break loop - } - dp = len(unscaled) - continue // don't add to unscaled - case ch >= '0' && ch <= '9': - if dg == -1 { - dg = len(unscaled) - } - default: - r.UnreadRune() - break loop - } - unscaled = append(unscaled, byte(ch)) - } - if dg == -1 { - return nil, fmt.Errorf("no digits read") - } - if dp >= 0 { - z.SetScale(Scale(len(unscaled) - dp)) - } else { - z.SetScale(0) - } - _, ok := z.UnscaledBig().SetString(string(unscaled), 10) - if !ok { - return nil, fmt.Errorf("invalid decimal: %s", string(unscaled)) - } - return z, nil -} - -// SetString sets z to the value of s, interpreted as a decimal (base 10), -// and returns z and a boolean indicating success. The scale of z is the -// number of digits after the decimal point (including any trailing 0s), -// or 0 if there is no decimal point. If SetString fails, the value of z -// is undefined but the returned value is nil. -func (z *Dec) SetString(s string) (*Dec, bool) { - r := strings.NewReader(s) - _, err := z.scan(r) - if err != nil { - return nil, false - } - _, _, err = r.ReadRune() - if err != io.EOF { - return nil, false - } - // err == io.EOF => scan consumed all of s - return z, true -} - -// Scan is a support routine for fmt.Scanner; it sets z to the value of -// the scanned number. It accepts the decimal formats 'd' and 'f', and -// handles both equivalently. Bases 2, 8, 16 are not supported. -// The scale of z is the number of digits after the decimal point -// (including any trailing 0s), or 0 if there is no decimal point. -func (z *Dec) Scan(s fmt.ScanState, ch rune) error { - if ch != 'd' && ch != 'f' && ch != 's' && ch != 'v' { - return fmt.Errorf("Dec.Scan: invalid verb '%c'", ch) - } - s.SkipSpace() - _, err := z.scan(s) - return err -} - -// Gob encoding version -const decGobVersion byte = 1 - -func scaleBytes(s Scale) []byte { - buf := make([]byte, scaleSize) - i := scaleSize - for j := 0; j < scaleSize; j++ { - i-- - buf[i] = byte(s) - s >>= 8 - } - return buf -} - -func scale(b []byte) (s Scale) { - for j := 0; j < scaleSize; j++ { - s <<= 8 - s |= Scale(b[j]) - } - return -} - -// GobEncode implements the gob.GobEncoder interface. -func (x *Dec) GobEncode() ([]byte, error) { - buf, err := x.UnscaledBig().GobEncode() - if err != nil { - return nil, err - } - buf = append(append(buf, scaleBytes(x.Scale())...), decGobVersion) - return buf, nil -} - -// GobDecode implements the gob.GobDecoder interface. -func (z *Dec) GobDecode(buf []byte) error { - if len(buf) == 0 { - return fmt.Errorf("Dec.GobDecode: no data") - } - b := buf[len(buf)-1] - if b != decGobVersion { - return fmt.Errorf("Dec.GobDecode: encoding version %d not supported", b) - } - l := len(buf) - scaleSize - 1 - err := z.UnscaledBig().GobDecode(buf[:l]) - if err != nil { - return err - } - z.SetScale(scale(buf[l : l+scaleSize])) - return nil -} - -// MarshalText implements the encoding.TextMarshaler interface. -func (x *Dec) MarshalText() ([]byte, error) { - return []byte(x.String()), nil -} - -// UnmarshalText implements the encoding.TextUnmarshaler interface. -func (z *Dec) UnmarshalText(data []byte) error { - _, ok := z.SetString(string(data)) - if !ok { - return fmt.Errorf("invalid inf.Dec") - } - return nil -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/rounder.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/rounder.go deleted file mode 100644 index 3a97ef5..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/inf.v0/rounder.go +++ /dev/null @@ -1,145 +0,0 @@ -package inf - -import ( - "math/big" -) - -// Rounder represents a method for rounding the (possibly infinite decimal) -// result of a division to a finite Dec. It is used by Dec.Round() and -// Dec.Quo(). -// -// See the Example for results of using each Rounder with some sample values. -// -type Rounder rounder - -// See http://speleotrove.com/decimal/damodel.html#refround for more detailed -// definitions of these rounding modes. -var ( - RoundDown Rounder // towards 0 - RoundUp Rounder // away from 0 - RoundFloor Rounder // towards -infinity - RoundCeil Rounder // towards +infinity - RoundHalfDown Rounder // to nearest; towards 0 if same distance - RoundHalfUp Rounder // to nearest; away from 0 if same distance - RoundHalfEven Rounder // to nearest; even last digit if same distance -) - -// RoundExact is to be used in the case when rounding is not necessary. -// When used with Quo or Round, it returns the result verbatim when it can be -// expressed exactly with the given precision, and it returns nil otherwise. -// QuoExact is a shorthand for using Quo with RoundExact. -var RoundExact Rounder - -type rounder interface { - - // When UseRemainder() returns true, the Round() method is passed the - // remainder of the division, expressed as the numerator and denominator of - // a rational. - UseRemainder() bool - - // Round sets the rounded value of a quotient to z, and returns z. - // quo is rounded down (truncated towards zero) to the scale obtained from - // the Scaler in Quo(). - // - // When the remainder is not used, remNum and remDen are nil. - // When used, the remainder is normalized between -1 and 1; that is: - // - // -|remDen| < remNum < |remDen| - // - // remDen has the same sign as y, and remNum is zero or has the same sign - // as x. - Round(z, quo *Dec, remNum, remDen *big.Int) *Dec -} - -type rndr struct { - useRem bool - round func(z, quo *Dec, remNum, remDen *big.Int) *Dec -} - -func (r rndr) UseRemainder() bool { - return r.useRem -} - -func (r rndr) Round(z, quo *Dec, remNum, remDen *big.Int) *Dec { - return r.round(z, quo, remNum, remDen) -} - -var intSign = []*big.Int{big.NewInt(-1), big.NewInt(0), big.NewInt(1)} - -func roundHalf(f func(c int, odd uint) (roundUp bool)) func(z, q *Dec, rA, rB *big.Int) *Dec { - return func(z, q *Dec, rA, rB *big.Int) *Dec { - z.Set(q) - brA, brB := rA.BitLen(), rB.BitLen() - if brA < brB-1 { - // brA < brB-1 => |rA| < |rB/2| - return z - } - roundUp := false - srA, srB := rA.Sign(), rB.Sign() - s := srA * srB - if brA == brB-1 { - rA2 := new(big.Int).Lsh(rA, 1) - if s < 0 { - rA2.Neg(rA2) - } - roundUp = f(rA2.Cmp(rB)*srB, z.UnscaledBig().Bit(0)) - } else { - // brA > brB-1 => |rA| > |rB/2| - roundUp = true - } - if roundUp { - z.UnscaledBig().Add(z.UnscaledBig(), intSign[s+1]) - } - return z - } -} - -func init() { - RoundExact = rndr{true, - func(z, q *Dec, rA, rB *big.Int) *Dec { - if rA.Sign() != 0 { - return nil - } - return z.Set(q) - }} - RoundDown = rndr{false, - func(z, q *Dec, rA, rB *big.Int) *Dec { - return z.Set(q) - }} - RoundUp = rndr{true, - func(z, q *Dec, rA, rB *big.Int) *Dec { - z.Set(q) - if rA.Sign() != 0 { - z.UnscaledBig().Add(z.UnscaledBig(), intSign[rA.Sign()*rB.Sign()+1]) - } - return z - }} - RoundFloor = rndr{true, - func(z, q *Dec, rA, rB *big.Int) *Dec { - z.Set(q) - if rA.Sign()*rB.Sign() < 0 { - z.UnscaledBig().Add(z.UnscaledBig(), intSign[0]) - } - return z - }} - RoundCeil = rndr{true, - func(z, q *Dec, rA, rB *big.Int) *Dec { - z.Set(q) - if rA.Sign()*rB.Sign() > 0 { - z.UnscaledBig().Add(z.UnscaledBig(), intSign[2]) - } - return z - }} - RoundHalfDown = rndr{true, roundHalf( - func(c int, odd uint) bool { - return c > 0 - })} - RoundHalfUp = rndr{true, roundHalf( - func(c int, odd uint) bool { - return c >= 0 - })} - RoundHalfEven = rndr{true, roundHalf( - func(c int, odd uint) bool { - return c > 0 || c == 0 && odd == 1 - })} -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE deleted file mode 100644 index a68e67f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE +++ /dev/null @@ -1,188 +0,0 @@ - -Copyright (c) 2011-2014 - Canonical Inc. - -This software is licensed under the LGPLv3, included below. - -As a special exception to the GNU Lesser General Public License version 3 -("LGPL3"), the copyright holders of this Library give you permission to -convey to a third party a Combined Work that links statically or dynamically -to this Library without providing any Minimal Corresponding Source or -Minimal Application Code as set out in 4d or providing the installation -information set out in section 4e, provided that you comply with the other -provisions of LGPL3 and provided that you meet, for the Application the -terms and conditions of the license(s) which apply to the Application. - -Except as stated in this special exception, the provisions of LGPL3 will -continue to comply in full to this Library. If you modify this Library, you -may apply this exception to your version of this Library, but you are not -obliged to do so. If you do not wish to do so, delete this exception -statement from your version. This exception does not (and cannot) modify any -license terms which apply to the Application, with which you must still -comply. - - - GNU LESSER GENERAL PUBLIC LICENSE - Version 3, 29 June 2007 - - Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/> - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - - This version of the GNU Lesser General Public License incorporates -the terms and conditions of version 3 of the GNU General Public -License, supplemented by the additional permissions listed below. - - 0. Additional Definitions. - - As used herein, "this License" refers to version 3 of the GNU Lesser -General Public License, and the "GNU GPL" refers to version 3 of the GNU -General Public License. - - "The Library" refers to a covered work governed by this License, -other than an Application or a Combined Work as defined below. - - An "Application" is any work that makes use of an interface provided -by the Library, but which is not otherwise based on the Library. -Defining a subclass of a class defined by the Library is deemed a mode -of using an interface provided by the Library. - - A "Combined Work" is a work produced by combining or linking an -Application with the Library. The particular version of the Library -with which the Combined Work was made is also called the "Linked -Version". - - The "Minimal Corresponding Source" for a Combined Work means the -Corresponding Source for the Combined Work, excluding any source code -for portions of the Combined Work that, considered in isolation, are -based on the Application, and not on the Linked Version. - - The "Corresponding Application Code" for a Combined Work means the -object code and/or source code for the Application, including any data -and utility programs needed for reproducing the Combined Work from the -Application, but excluding the System Libraries of the Combined Work. - - 1. Exception to Section 3 of the GNU GPL. - - You may convey a covered work under sections 3 and 4 of this License -without being bound by section 3 of the GNU GPL. - - 2. Conveying Modified Versions. - - If you modify a copy of the Library, and, in your modifications, a -facility refers to a function or data to be supplied by an Application -that uses the facility (other than as an argument passed when the -facility is invoked), then you may convey a copy of the modified -version: - - a) under this License, provided that you make a good faith effort to - ensure that, in the event an Application does not supply the - function or data, the facility still operates, and performs - whatever part of its purpose remains meaningful, or - - b) under the GNU GPL, with none of the additional permissions of - this License applicable to that copy. - - 3. Object Code Incorporating Material from Library Header Files. - - The object code form of an Application may incorporate material from -a header file that is part of the Library. You may convey such object -code under terms of your choice, provided that, if the incorporated -material is not limited to numerical parameters, data structure -layouts and accessors, or small macros, inline functions and templates -(ten or fewer lines in length), you do both of the following: - - a) Give prominent notice with each copy of the object code that the - Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the object code with a copy of the GNU GPL and this license - document. - - 4. Combined Works. - - You may convey a Combined Work under terms of your choice that, -taken together, effectively do not restrict modification of the -portions of the Library contained in the Combined Work and reverse -engineering for debugging such modifications, if you also do each of -the following: - - a) Give prominent notice with each copy of the Combined Work that - the Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the Combined Work with a copy of the GNU GPL and this license - document. - - c) For a Combined Work that displays copyright notices during - execution, include the copyright notice for the Library among - these notices, as well as a reference directing the user to the - copies of the GNU GPL and this license document. - - d) Do one of the following: - - 0) Convey the Minimal Corresponding Source under the terms of this - License, and the Corresponding Application Code in a form - suitable for, and under terms that permit, the user to - recombine or relink the Application with a modified version of - the Linked Version to produce a modified Combined Work, in the - manner specified by section 6 of the GNU GPL for conveying - Corresponding Source. - - 1) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (a) uses at run time - a copy of the Library already present on the user's computer - system, and (b) will operate properly with a modified version - of the Library that is interface-compatible with the Linked - Version. - - e) Provide Installation Information, but only if you would otherwise - be required to provide such information under section 6 of the - GNU GPL, and only to the extent that such information is - necessary to install and execute a modified version of the - Combined Work produced by recombining or relinking the - Application with a modified version of the Linked Version. (If - you use option 4d0, the Installation Information must accompany - the Minimal Corresponding Source and Corresponding Application - Code. If you use option 4d1, you must provide the Installation - Information in the manner specified by section 6 of the GNU GPL - for conveying Corresponding Source.) - - 5. Combined Libraries. - - You may place library facilities that are a work based on the -Library side by side in a single library together with other library -facilities that are not Applications and are not covered by this -License, and convey such a combined library under terms of your -choice, if you do both of the following: - - a) Accompany the combined library with a copy of the same work based - on the Library, uncombined with any other library facilities, - conveyed under the terms of this License. - - b) Give prominent notice with the combined library that part of it - is a work based on the Library, and explaining where to find the - accompanying uncombined form of the same work. - - 6. Revised Versions of the GNU Lesser General Public License. - - The Free Software Foundation may publish revised and/or new versions -of the GNU Lesser General Public License from time to time. Such new -versions will be similar in spirit to the present version, but may -differ in detail to address new problems or concerns. - - Each version is given a distinguishing version number. If the -Library as you received it specifies that a certain numbered version -of the GNU Lesser General Public License "or any later version" -applies to it, you have the option of following the terms and -conditions either of that published version or of any later version -published by the Free Software Foundation. If the Library as you -received it does not specify a version number of the GNU Lesser -General Public License, you may choose any version of the GNU Lesser -General Public License ever published by the Free Software Foundation. - - If the Library as you received it specifies that a proxy can decide -whether future versions of the GNU Lesser General Public License shall -apply, that proxy's public statement of acceptance of any version is -permanent authorization for you to choose that version for the -Library. diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE.libyaml b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE.libyaml deleted file mode 100644 index 8da58fb..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/LICENSE.libyaml +++ /dev/null @@ -1,31 +0,0 @@ -The following files were ported to Go from C files of libyaml, and thus -are still covered by their original copyright and license: - - apic.go - emitterc.go - parserc.go - readerc.go - scannerc.go - writerc.go - yamlh.go - yamlprivateh.go - -Copyright (c) 2006 Kirill Simonov - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/README.md b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/README.md deleted file mode 100644 index 7b8bd86..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/README.md +++ /dev/null @@ -1,131 +0,0 @@ -# YAML support for the Go language - -Introduction ------------- - -The yaml package enables Go programs to comfortably encode and decode YAML -values. It was developed within [Canonical](https://www.canonical.com) as -part of the [juju](https://juju.ubuntu.com) project, and is based on a -pure Go port of the well-known [libyaml](http://pyyaml.org/wiki/LibYAML) -C library to parse and generate YAML data quickly and reliably. - -Compatibility -------------- - -The yaml package supports most of YAML 1.1 and 1.2, including support for -anchors, tags, map merging, etc. Multi-document unmarshalling is not yet -implemented, and base-60 floats from YAML 1.1 are purposefully not -supported since they're a poor design and are gone in YAML 1.2. - -Installation and usage ----------------------- - -The import path for the package is *gopkg.in/yaml.v2*. - -To install it, run: - - go get gopkg.in/yaml.v2 - -API documentation ------------------ - -If opened in a browser, the import path itself leads to the API documentation: - - * [https://gopkg.in/yaml.v2](https://gopkg.in/yaml.v2) - -API stability -------------- - -The package API for yaml v2 will remain stable as described in [gopkg.in](https://gopkg.in). - - -License -------- - -The yaml package is licensed under the LGPL with an exception that allows it to be linked statically. Please see the LICENSE file for details. - - -Example -------- - -```Go -package main - -import ( - "fmt" - "log" - - "gopkg.in/yaml.v2" -) - -var data = ` -a: Easy! -b: - c: 2 - d: [3, 4] -` - -type T struct { - A string - B struct { - RenamedC int `yaml:"c"` - D []int `yaml:",flow"` - } -} - -func main() { - t := T{} - - err := yaml.Unmarshal([]byte(data), &t) - if err != nil { - log.Fatalf("error: %v", err) - } - fmt.Printf("--- t:\n%v\n\n", t) - - d, err := yaml.Marshal(&t) - if err != nil { - log.Fatalf("error: %v", err) - } - fmt.Printf("--- t dump:\n%s\n\n", string(d)) - - m := make(map[interface{}]interface{}) - - err = yaml.Unmarshal([]byte(data), &m) - if err != nil { - log.Fatalf("error: %v", err) - } - fmt.Printf("--- m:\n%v\n\n", m) - - d, err = yaml.Marshal(&m) - if err != nil { - log.Fatalf("error: %v", err) - } - fmt.Printf("--- m dump:\n%s\n\n", string(d)) -} -``` - -This example will generate the following output: - -``` ---- t: -{Easy! {2 [3 4]}} - ---- t dump: -a: Easy! -b: - c: 2 - d: [3, 4] - - ---- m: -map[a:Easy! b:map[c:2 d:[3 4]]] - ---- m dump: -a: Easy! -b: - c: 2 - d: - - 3 - - 4 -``` - diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/apic.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/apic.go deleted file mode 100644 index 95ec014..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/apic.go +++ /dev/null @@ -1,742 +0,0 @@ -package yaml - -import ( - "io" - "os" -) - -func yaml_insert_token(parser *yaml_parser_t, pos int, token *yaml_token_t) { - //fmt.Println("yaml_insert_token", "pos:", pos, "typ:", token.typ, "head:", parser.tokens_head, "len:", len(parser.tokens)) - - // Check if we can move the queue at the beginning of the buffer. - if parser.tokens_head > 0 && len(parser.tokens) == cap(parser.tokens) { - if parser.tokens_head != len(parser.tokens) { - copy(parser.tokens, parser.tokens[parser.tokens_head:]) - } - parser.tokens = parser.tokens[:len(parser.tokens)-parser.tokens_head] - parser.tokens_head = 0 - } - parser.tokens = append(parser.tokens, *token) - if pos < 0 { - return - } - copy(parser.tokens[parser.tokens_head+pos+1:], parser.tokens[parser.tokens_head+pos:]) - parser.tokens[parser.tokens_head+pos] = *token -} - -// Create a new parser object. -func yaml_parser_initialize(parser *yaml_parser_t) bool { - *parser = yaml_parser_t{ - raw_buffer: make([]byte, 0, input_raw_buffer_size), - buffer: make([]byte, 0, input_buffer_size), - } - return true -} - -// Destroy a parser object. -func yaml_parser_delete(parser *yaml_parser_t) { - *parser = yaml_parser_t{} -} - -// String read handler. -func yaml_string_read_handler(parser *yaml_parser_t, buffer []byte) (n int, err error) { - if parser.input_pos == len(parser.input) { - return 0, io.EOF - } - n = copy(buffer, parser.input[parser.input_pos:]) - parser.input_pos += n - return n, nil -} - -// File read handler. -func yaml_file_read_handler(parser *yaml_parser_t, buffer []byte) (n int, err error) { - return parser.input_file.Read(buffer) -} - -// Set a string input. -func yaml_parser_set_input_string(parser *yaml_parser_t, input []byte) { - if parser.read_handler != nil { - panic("must set the input source only once") - } - parser.read_handler = yaml_string_read_handler - parser.input = input - parser.input_pos = 0 -} - -// Set a file input. -func yaml_parser_set_input_file(parser *yaml_parser_t, file *os.File) { - if parser.read_handler != nil { - panic("must set the input source only once") - } - parser.read_handler = yaml_file_read_handler - parser.input_file = file -} - -// Set the source encoding. -func yaml_parser_set_encoding(parser *yaml_parser_t, encoding yaml_encoding_t) { - if parser.encoding != yaml_ANY_ENCODING { - panic("must set the encoding only once") - } - parser.encoding = encoding -} - -// Create a new emitter object. -func yaml_emitter_initialize(emitter *yaml_emitter_t) bool { - *emitter = yaml_emitter_t{ - buffer: make([]byte, output_buffer_size), - raw_buffer: make([]byte, 0, output_raw_buffer_size), - states: make([]yaml_emitter_state_t, 0, initial_stack_size), - events: make([]yaml_event_t, 0, initial_queue_size), - } - return true -} - -// Destroy an emitter object. -func yaml_emitter_delete(emitter *yaml_emitter_t) { - *emitter = yaml_emitter_t{} -} - -// String write handler. -func yaml_string_write_handler(emitter *yaml_emitter_t, buffer []byte) error { - *emitter.output_buffer = append(*emitter.output_buffer, buffer...) - return nil -} - -// File write handler. -func yaml_file_write_handler(emitter *yaml_emitter_t, buffer []byte) error { - _, err := emitter.output_file.Write(buffer) - return err -} - -// Set a string output. -func yaml_emitter_set_output_string(emitter *yaml_emitter_t, output_buffer *[]byte) { - if emitter.write_handler != nil { - panic("must set the output target only once") - } - emitter.write_handler = yaml_string_write_handler - emitter.output_buffer = output_buffer -} - -// Set a file output. -func yaml_emitter_set_output_file(emitter *yaml_emitter_t, file io.Writer) { - if emitter.write_handler != nil { - panic("must set the output target only once") - } - emitter.write_handler = yaml_file_write_handler - emitter.output_file = file -} - -// Set the output encoding. -func yaml_emitter_set_encoding(emitter *yaml_emitter_t, encoding yaml_encoding_t) { - if emitter.encoding != yaml_ANY_ENCODING { - panic("must set the output encoding only once") - } - emitter.encoding = encoding -} - -// Set the canonical output style. -func yaml_emitter_set_canonical(emitter *yaml_emitter_t, canonical bool) { - emitter.canonical = canonical -} - -//// Set the indentation increment. -func yaml_emitter_set_indent(emitter *yaml_emitter_t, indent int) { - if indent < 2 || indent > 9 { - indent = 2 - } - emitter.best_indent = indent -} - -// Set the preferred line width. -func yaml_emitter_set_width(emitter *yaml_emitter_t, width int) { - if width < 0 { - width = -1 - } - emitter.best_width = width -} - -// Set if unescaped non-ASCII characters are allowed. -func yaml_emitter_set_unicode(emitter *yaml_emitter_t, unicode bool) { - emitter.unicode = unicode -} - -// Set the preferred line break character. -func yaml_emitter_set_break(emitter *yaml_emitter_t, line_break yaml_break_t) { - emitter.line_break = line_break -} - -///* -// * Destroy a token object. -// */ -// -//YAML_DECLARE(void) -//yaml_token_delete(yaml_token_t *token) -//{ -// assert(token); // Non-NULL token object expected. -// -// switch (token.type) -// { -// case YAML_TAG_DIRECTIVE_TOKEN: -// yaml_free(token.data.tag_directive.handle); -// yaml_free(token.data.tag_directive.prefix); -// break; -// -// case YAML_ALIAS_TOKEN: -// yaml_free(token.data.alias.value); -// break; -// -// case YAML_ANCHOR_TOKEN: -// yaml_free(token.data.anchor.value); -// break; -// -// case YAML_TAG_TOKEN: -// yaml_free(token.data.tag.handle); -// yaml_free(token.data.tag.suffix); -// break; -// -// case YAML_SCALAR_TOKEN: -// yaml_free(token.data.scalar.value); -// break; -// -// default: -// break; -// } -// -// memset(token, 0, sizeof(yaml_token_t)); -//} -// -///* -// * Check if a string is a valid UTF-8 sequence. -// * -// * Check 'reader.c' for more details on UTF-8 encoding. -// */ -// -//static int -//yaml_check_utf8(yaml_char_t *start, size_t length) -//{ -// yaml_char_t *end = start+length; -// yaml_char_t *pointer = start; -// -// while (pointer < end) { -// unsigned char octet; -// unsigned int width; -// unsigned int value; -// size_t k; -// -// octet = pointer[0]; -// width = (octet & 0x80) == 0x00 ? 1 : -// (octet & 0xE0) == 0xC0 ? 2 : -// (octet & 0xF0) == 0xE0 ? 3 : -// (octet & 0xF8) == 0xF0 ? 4 : 0; -// value = (octet & 0x80) == 0x00 ? octet & 0x7F : -// (octet & 0xE0) == 0xC0 ? octet & 0x1F : -// (octet & 0xF0) == 0xE0 ? octet & 0x0F : -// (octet & 0xF8) == 0xF0 ? octet & 0x07 : 0; -// if (!width) return 0; -// if (pointer+width > end) return 0; -// for (k = 1; k < width; k ++) { -// octet = pointer[k]; -// if ((octet & 0xC0) != 0x80) return 0; -// value = (value << 6) + (octet & 0x3F); -// } -// if (!((width == 1) || -// (width == 2 && value >= 0x80) || -// (width == 3 && value >= 0x800) || -// (width == 4 && value >= 0x10000))) return 0; -// -// pointer += width; -// } -// -// return 1; -//} -// - -// Create STREAM-START. -func yaml_stream_start_event_initialize(event *yaml_event_t, encoding yaml_encoding_t) bool { - *event = yaml_event_t{ - typ: yaml_STREAM_START_EVENT, - encoding: encoding, - } - return true -} - -// Create STREAM-END. -func yaml_stream_end_event_initialize(event *yaml_event_t) bool { - *event = yaml_event_t{ - typ: yaml_STREAM_END_EVENT, - } - return true -} - -// Create DOCUMENT-START. -func yaml_document_start_event_initialize(event *yaml_event_t, version_directive *yaml_version_directive_t, - tag_directives []yaml_tag_directive_t, implicit bool) bool { - *event = yaml_event_t{ - typ: yaml_DOCUMENT_START_EVENT, - version_directive: version_directive, - tag_directives: tag_directives, - implicit: implicit, - } - return true -} - -// Create DOCUMENT-END. -func yaml_document_end_event_initialize(event *yaml_event_t, implicit bool) bool { - *event = yaml_event_t{ - typ: yaml_DOCUMENT_END_EVENT, - implicit: implicit, - } - return true -} - -///* -// * Create ALIAS. -// */ -// -//YAML_DECLARE(int) -//yaml_alias_event_initialize(event *yaml_event_t, anchor *yaml_char_t) -//{ -// mark yaml_mark_t = { 0, 0, 0 } -// anchor_copy *yaml_char_t = NULL -// -// assert(event) // Non-NULL event object is expected. -// assert(anchor) // Non-NULL anchor is expected. -// -// if (!yaml_check_utf8(anchor, strlen((char *)anchor))) return 0 -// -// anchor_copy = yaml_strdup(anchor) -// if (!anchor_copy) -// return 0 -// -// ALIAS_EVENT_INIT(*event, anchor_copy, mark, mark) -// -// return 1 -//} - -// Create SCALAR. -func yaml_scalar_event_initialize(event *yaml_event_t, anchor, tag, value []byte, plain_implicit, quoted_implicit bool, style yaml_scalar_style_t) bool { - *event = yaml_event_t{ - typ: yaml_SCALAR_EVENT, - anchor: anchor, - tag: tag, - value: value, - implicit: plain_implicit, - quoted_implicit: quoted_implicit, - style: yaml_style_t(style), - } - return true -} - -// Create SEQUENCE-START. -func yaml_sequence_start_event_initialize(event *yaml_event_t, anchor, tag []byte, implicit bool, style yaml_sequence_style_t) bool { - *event = yaml_event_t{ - typ: yaml_SEQUENCE_START_EVENT, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(style), - } - return true -} - -// Create SEQUENCE-END. -func yaml_sequence_end_event_initialize(event *yaml_event_t) bool { - *event = yaml_event_t{ - typ: yaml_SEQUENCE_END_EVENT, - } - return true -} - -// Create MAPPING-START. -func yaml_mapping_start_event_initialize(event *yaml_event_t, anchor, tag []byte, implicit bool, style yaml_mapping_style_t) bool { - *event = yaml_event_t{ - typ: yaml_MAPPING_START_EVENT, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(style), - } - return true -} - -// Create MAPPING-END. -func yaml_mapping_end_event_initialize(event *yaml_event_t) bool { - *event = yaml_event_t{ - typ: yaml_MAPPING_END_EVENT, - } - return true -} - -// Destroy an event object. -func yaml_event_delete(event *yaml_event_t) { - *event = yaml_event_t{} -} - -///* -// * Create a document object. -// */ -// -//YAML_DECLARE(int) -//yaml_document_initialize(document *yaml_document_t, -// version_directive *yaml_version_directive_t, -// tag_directives_start *yaml_tag_directive_t, -// tag_directives_end *yaml_tag_directive_t, -// start_implicit int, end_implicit int) -//{ -// struct { -// error yaml_error_type_t -// } context -// struct { -// start *yaml_node_t -// end *yaml_node_t -// top *yaml_node_t -// } nodes = { NULL, NULL, NULL } -// version_directive_copy *yaml_version_directive_t = NULL -// struct { -// start *yaml_tag_directive_t -// end *yaml_tag_directive_t -// top *yaml_tag_directive_t -// } tag_directives_copy = { NULL, NULL, NULL } -// value yaml_tag_directive_t = { NULL, NULL } -// mark yaml_mark_t = { 0, 0, 0 } -// -// assert(document) // Non-NULL document object is expected. -// assert((tag_directives_start && tag_directives_end) || -// (tag_directives_start == tag_directives_end)) -// // Valid tag directives are expected. -// -// if (!STACK_INIT(&context, nodes, INITIAL_STACK_SIZE)) goto error -// -// if (version_directive) { -// version_directive_copy = yaml_malloc(sizeof(yaml_version_directive_t)) -// if (!version_directive_copy) goto error -// version_directive_copy.major = version_directive.major -// version_directive_copy.minor = version_directive.minor -// } -// -// if (tag_directives_start != tag_directives_end) { -// tag_directive *yaml_tag_directive_t -// if (!STACK_INIT(&context, tag_directives_copy, INITIAL_STACK_SIZE)) -// goto error -// for (tag_directive = tag_directives_start -// tag_directive != tag_directives_end; tag_directive ++) { -// assert(tag_directive.handle) -// assert(tag_directive.prefix) -// if (!yaml_check_utf8(tag_directive.handle, -// strlen((char *)tag_directive.handle))) -// goto error -// if (!yaml_check_utf8(tag_directive.prefix, -// strlen((char *)tag_directive.prefix))) -// goto error -// value.handle = yaml_strdup(tag_directive.handle) -// value.prefix = yaml_strdup(tag_directive.prefix) -// if (!value.handle || !value.prefix) goto error -// if (!PUSH(&context, tag_directives_copy, value)) -// goto error -// value.handle = NULL -// value.prefix = NULL -// } -// } -// -// DOCUMENT_INIT(*document, nodes.start, nodes.end, version_directive_copy, -// tag_directives_copy.start, tag_directives_copy.top, -// start_implicit, end_implicit, mark, mark) -// -// return 1 -// -//error: -// STACK_DEL(&context, nodes) -// yaml_free(version_directive_copy) -// while (!STACK_EMPTY(&context, tag_directives_copy)) { -// value yaml_tag_directive_t = POP(&context, tag_directives_copy) -// yaml_free(value.handle) -// yaml_free(value.prefix) -// } -// STACK_DEL(&context, tag_directives_copy) -// yaml_free(value.handle) -// yaml_free(value.prefix) -// -// return 0 -//} -// -///* -// * Destroy a document object. -// */ -// -//YAML_DECLARE(void) -//yaml_document_delete(document *yaml_document_t) -//{ -// struct { -// error yaml_error_type_t -// } context -// tag_directive *yaml_tag_directive_t -// -// context.error = YAML_NO_ERROR // Eliminate a compliler warning. -// -// assert(document) // Non-NULL document object is expected. -// -// while (!STACK_EMPTY(&context, document.nodes)) { -// node yaml_node_t = POP(&context, document.nodes) -// yaml_free(node.tag) -// switch (node.type) { -// case YAML_SCALAR_NODE: -// yaml_free(node.data.scalar.value) -// break -// case YAML_SEQUENCE_NODE: -// STACK_DEL(&context, node.data.sequence.items) -// break -// case YAML_MAPPING_NODE: -// STACK_DEL(&context, node.data.mapping.pairs) -// break -// default: -// assert(0) // Should not happen. -// } -// } -// STACK_DEL(&context, document.nodes) -// -// yaml_free(document.version_directive) -// for (tag_directive = document.tag_directives.start -// tag_directive != document.tag_directives.end -// tag_directive++) { -// yaml_free(tag_directive.handle) -// yaml_free(tag_directive.prefix) -// } -// yaml_free(document.tag_directives.start) -// -// memset(document, 0, sizeof(yaml_document_t)) -//} -// -///** -// * Get a document node. -// */ -// -//YAML_DECLARE(yaml_node_t *) -//yaml_document_get_node(document *yaml_document_t, index int) -//{ -// assert(document) // Non-NULL document object is expected. -// -// if (index > 0 && document.nodes.start + index <= document.nodes.top) { -// return document.nodes.start + index - 1 -// } -// return NULL -//} -// -///** -// * Get the root object. -// */ -// -//YAML_DECLARE(yaml_node_t *) -//yaml_document_get_root_node(document *yaml_document_t) -//{ -// assert(document) // Non-NULL document object is expected. -// -// if (document.nodes.top != document.nodes.start) { -// return document.nodes.start -// } -// return NULL -//} -// -///* -// * Add a scalar node to a document. -// */ -// -//YAML_DECLARE(int) -//yaml_document_add_scalar(document *yaml_document_t, -// tag *yaml_char_t, value *yaml_char_t, length int, -// style yaml_scalar_style_t) -//{ -// struct { -// error yaml_error_type_t -// } context -// mark yaml_mark_t = { 0, 0, 0 } -// tag_copy *yaml_char_t = NULL -// value_copy *yaml_char_t = NULL -// node yaml_node_t -// -// assert(document) // Non-NULL document object is expected. -// assert(value) // Non-NULL value is expected. -// -// if (!tag) { -// tag = (yaml_char_t *)YAML_DEFAULT_SCALAR_TAG -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error -// tag_copy = yaml_strdup(tag) -// if (!tag_copy) goto error -// -// if (length < 0) { -// length = strlen((char *)value) -// } -// -// if (!yaml_check_utf8(value, length)) goto error -// value_copy = yaml_malloc(length+1) -// if (!value_copy) goto error -// memcpy(value_copy, value, length) -// value_copy[length] = '\0' -// -// SCALAR_NODE_INIT(node, tag_copy, value_copy, length, style, mark, mark) -// if (!PUSH(&context, document.nodes, node)) goto error -// -// return document.nodes.top - document.nodes.start -// -//error: -// yaml_free(tag_copy) -// yaml_free(value_copy) -// -// return 0 -//} -// -///* -// * Add a sequence node to a document. -// */ -// -//YAML_DECLARE(int) -//yaml_document_add_sequence(document *yaml_document_t, -// tag *yaml_char_t, style yaml_sequence_style_t) -//{ -// struct { -// error yaml_error_type_t -// } context -// mark yaml_mark_t = { 0, 0, 0 } -// tag_copy *yaml_char_t = NULL -// struct { -// start *yaml_node_item_t -// end *yaml_node_item_t -// top *yaml_node_item_t -// } items = { NULL, NULL, NULL } -// node yaml_node_t -// -// assert(document) // Non-NULL document object is expected. -// -// if (!tag) { -// tag = (yaml_char_t *)YAML_DEFAULT_SEQUENCE_TAG -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error -// tag_copy = yaml_strdup(tag) -// if (!tag_copy) goto error -// -// if (!STACK_INIT(&context, items, INITIAL_STACK_SIZE)) goto error -// -// SEQUENCE_NODE_INIT(node, tag_copy, items.start, items.end, -// style, mark, mark) -// if (!PUSH(&context, document.nodes, node)) goto error -// -// return document.nodes.top - document.nodes.start -// -//error: -// STACK_DEL(&context, items) -// yaml_free(tag_copy) -// -// return 0 -//} -// -///* -// * Add a mapping node to a document. -// */ -// -//YAML_DECLARE(int) -//yaml_document_add_mapping(document *yaml_document_t, -// tag *yaml_char_t, style yaml_mapping_style_t) -//{ -// struct { -// error yaml_error_type_t -// } context -// mark yaml_mark_t = { 0, 0, 0 } -// tag_copy *yaml_char_t = NULL -// struct { -// start *yaml_node_pair_t -// end *yaml_node_pair_t -// top *yaml_node_pair_t -// } pairs = { NULL, NULL, NULL } -// node yaml_node_t -// -// assert(document) // Non-NULL document object is expected. -// -// if (!tag) { -// tag = (yaml_char_t *)YAML_DEFAULT_MAPPING_TAG -// } -// -// if (!yaml_check_utf8(tag, strlen((char *)tag))) goto error -// tag_copy = yaml_strdup(tag) -// if (!tag_copy) goto error -// -// if (!STACK_INIT(&context, pairs, INITIAL_STACK_SIZE)) goto error -// -// MAPPING_NODE_INIT(node, tag_copy, pairs.start, pairs.end, -// style, mark, mark) -// if (!PUSH(&context, document.nodes, node)) goto error -// -// return document.nodes.top - document.nodes.start -// -//error: -// STACK_DEL(&context, pairs) -// yaml_free(tag_copy) -// -// return 0 -//} -// -///* -// * Append an item to a sequence node. -// */ -// -//YAML_DECLARE(int) -//yaml_document_append_sequence_item(document *yaml_document_t, -// sequence int, item int) -//{ -// struct { -// error yaml_error_type_t -// } context -// -// assert(document) // Non-NULL document is required. -// assert(sequence > 0 -// && document.nodes.start + sequence <= document.nodes.top) -// // Valid sequence id is required. -// assert(document.nodes.start[sequence-1].type == YAML_SEQUENCE_NODE) -// // A sequence node is required. -// assert(item > 0 && document.nodes.start + item <= document.nodes.top) -// // Valid item id is required. -// -// if (!PUSH(&context, -// document.nodes.start[sequence-1].data.sequence.items, item)) -// return 0 -// -// return 1 -//} -// -///* -// * Append a pair of a key and a value to a mapping node. -// */ -// -//YAML_DECLARE(int) -//yaml_document_append_mapping_pair(document *yaml_document_t, -// mapping int, key int, value int) -//{ -// struct { -// error yaml_error_type_t -// } context -// -// pair yaml_node_pair_t -// -// assert(document) // Non-NULL document is required. -// assert(mapping > 0 -// && document.nodes.start + mapping <= document.nodes.top) -// // Valid mapping id is required. -// assert(document.nodes.start[mapping-1].type == YAML_MAPPING_NODE) -// // A mapping node is required. -// assert(key > 0 && document.nodes.start + key <= document.nodes.top) -// // Valid key id is required. -// assert(value > 0 && document.nodes.start + value <= document.nodes.top) -// // Valid value id is required. -// -// pair.key = key -// pair.value = value -// -// if (!PUSH(&context, -// document.nodes.start[mapping-1].data.mapping.pairs, pair)) -// return 0 -// -// return 1 -//} -// -// diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/decode.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/decode.go deleted file mode 100644 index 085cddc..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/decode.go +++ /dev/null @@ -1,683 +0,0 @@ -package yaml - -import ( - "encoding" - "encoding/base64" - "fmt" - "math" - "reflect" - "strconv" - "time" -) - -const ( - documentNode = 1 << iota - mappingNode - sequenceNode - scalarNode - aliasNode -) - -type node struct { - kind int - line, column int - tag string - value string - implicit bool - children []*node - anchors map[string]*node -} - -// ---------------------------------------------------------------------------- -// Parser, produces a node tree out of a libyaml event stream. - -type parser struct { - parser yaml_parser_t - event yaml_event_t - doc *node -} - -func newParser(b []byte) *parser { - p := parser{} - if !yaml_parser_initialize(&p.parser) { - panic("failed to initialize YAML emitter") - } - - if len(b) == 0 { - b = []byte{'\n'} - } - - yaml_parser_set_input_string(&p.parser, b) - - p.skip() - if p.event.typ != yaml_STREAM_START_EVENT { - panic("expected stream start event, got " + strconv.Itoa(int(p.event.typ))) - } - p.skip() - return &p -} - -func (p *parser) destroy() { - if p.event.typ != yaml_NO_EVENT { - yaml_event_delete(&p.event) - } - yaml_parser_delete(&p.parser) -} - -func (p *parser) skip() { - if p.event.typ != yaml_NO_EVENT { - if p.event.typ == yaml_STREAM_END_EVENT { - failf("attempted to go past the end of stream; corrupted value?") - } - yaml_event_delete(&p.event) - } - if !yaml_parser_parse(&p.parser, &p.event) { - p.fail() - } -} - -func (p *parser) fail() { - var where string - var line int - if p.parser.problem_mark.line != 0 { - line = p.parser.problem_mark.line - } else if p.parser.context_mark.line != 0 { - line = p.parser.context_mark.line - } - if line != 0 { - where = "line " + strconv.Itoa(line) + ": " - } - var msg string - if len(p.parser.problem) > 0 { - msg = p.parser.problem - } else { - msg = "unknown problem parsing YAML content" - } - failf("%s%s", where, msg) -} - -func (p *parser) anchor(n *node, anchor []byte) { - if anchor != nil { - p.doc.anchors[string(anchor)] = n - } -} - -func (p *parser) parse() *node { - switch p.event.typ { - case yaml_SCALAR_EVENT: - return p.scalar() - case yaml_ALIAS_EVENT: - return p.alias() - case yaml_MAPPING_START_EVENT: - return p.mapping() - case yaml_SEQUENCE_START_EVENT: - return p.sequence() - case yaml_DOCUMENT_START_EVENT: - return p.document() - case yaml_STREAM_END_EVENT: - // Happens when attempting to decode an empty buffer. - return nil - default: - panic("attempted to parse unknown event: " + strconv.Itoa(int(p.event.typ))) - } - panic("unreachable") -} - -func (p *parser) node(kind int) *node { - return &node{ - kind: kind, - line: p.event.start_mark.line, - column: p.event.start_mark.column, - } -} - -func (p *parser) document() *node { - n := p.node(documentNode) - n.anchors = make(map[string]*node) - p.doc = n - p.skip() - n.children = append(n.children, p.parse()) - if p.event.typ != yaml_DOCUMENT_END_EVENT { - panic("expected end of document event but got " + strconv.Itoa(int(p.event.typ))) - } - p.skip() - return n -} - -func (p *parser) alias() *node { - n := p.node(aliasNode) - n.value = string(p.event.anchor) - p.skip() - return n -} - -func (p *parser) scalar() *node { - n := p.node(scalarNode) - n.value = string(p.event.value) - n.tag = string(p.event.tag) - n.implicit = p.event.implicit - p.anchor(n, p.event.anchor) - p.skip() - return n -} - -func (p *parser) sequence() *node { - n := p.node(sequenceNode) - p.anchor(n, p.event.anchor) - p.skip() - for p.event.typ != yaml_SEQUENCE_END_EVENT { - n.children = append(n.children, p.parse()) - } - p.skip() - return n -} - -func (p *parser) mapping() *node { - n := p.node(mappingNode) - p.anchor(n, p.event.anchor) - p.skip() - for p.event.typ != yaml_MAPPING_END_EVENT { - n.children = append(n.children, p.parse(), p.parse()) - } - p.skip() - return n -} - -// ---------------------------------------------------------------------------- -// Decoder, unmarshals a node into a provided value. - -type decoder struct { - doc *node - aliases map[string]bool - mapType reflect.Type - terrors []string -} - -var ( - mapItemType = reflect.TypeOf(MapItem{}) - durationType = reflect.TypeOf(time.Duration(0)) - defaultMapType = reflect.TypeOf(map[interface{}]interface{}{}) - ifaceType = defaultMapType.Elem() -) - -func newDecoder() *decoder { - d := &decoder{mapType: defaultMapType} - d.aliases = make(map[string]bool) - return d -} - -func (d *decoder) terror(n *node, tag string, out reflect.Value) { - if n.tag != "" { - tag = n.tag - } - value := n.value - if tag != yaml_SEQ_TAG && tag != yaml_MAP_TAG { - if len(value) > 10 { - value = " `" + value[:7] + "...`" - } else { - value = " `" + value + "`" - } - } - d.terrors = append(d.terrors, fmt.Sprintf("line %d: cannot unmarshal %s%s into %s", n.line+1, shortTag(tag), value, out.Type())) -} - -func (d *decoder) callUnmarshaler(n *node, u Unmarshaler) (good bool) { - terrlen := len(d.terrors) - err := u.UnmarshalYAML(func(v interface{}) (err error) { - defer handleErr(&err) - d.unmarshal(n, reflect.ValueOf(v)) - if len(d.terrors) > terrlen { - issues := d.terrors[terrlen:] - d.terrors = d.terrors[:terrlen] - return &TypeError{issues} - } - return nil - }) - if e, ok := err.(*TypeError); ok { - d.terrors = append(d.terrors, e.Errors...) - return false - } - if err != nil { - fail(err) - } - return true -} - -// d.prepare initializes and dereferences pointers and calls UnmarshalYAML -// if a value is found to implement it. -// It returns the initialized and dereferenced out value, whether -// unmarshalling was already done by UnmarshalYAML, and if so whether -// its types unmarshalled appropriately. -// -// If n holds a null value, prepare returns before doing anything. -func (d *decoder) prepare(n *node, out reflect.Value) (newout reflect.Value, unmarshaled, good bool) { - if n.tag == yaml_NULL_TAG || n.kind == scalarNode && n.tag == "" && (n.value == "null" || n.value == "") { - return out, false, false - } - again := true - for again { - again = false - if out.Kind() == reflect.Ptr { - if out.IsNil() { - out.Set(reflect.New(out.Type().Elem())) - } - out = out.Elem() - again = true - } - if out.CanAddr() { - if u, ok := out.Addr().Interface().(Unmarshaler); ok { - good = d.callUnmarshaler(n, u) - return out, true, good - } - } - } - return out, false, false -} - -func (d *decoder) unmarshal(n *node, out reflect.Value) (good bool) { - switch n.kind { - case documentNode: - return d.document(n, out) - case aliasNode: - return d.alias(n, out) - } - out, unmarshaled, good := d.prepare(n, out) - if unmarshaled { - return good - } - switch n.kind { - case scalarNode: - good = d.scalar(n, out) - case mappingNode: - good = d.mapping(n, out) - case sequenceNode: - good = d.sequence(n, out) - default: - panic("internal error: unknown node kind: " + strconv.Itoa(n.kind)) - } - return good -} - -func (d *decoder) document(n *node, out reflect.Value) (good bool) { - if len(n.children) == 1 { - d.doc = n - d.unmarshal(n.children[0], out) - return true - } - return false -} - -func (d *decoder) alias(n *node, out reflect.Value) (good bool) { - an, ok := d.doc.anchors[n.value] - if !ok { - failf("unknown anchor '%s' referenced", n.value) - } - if d.aliases[n.value] { - failf("anchor '%s' value contains itself", n.value) - } - d.aliases[n.value] = true - good = d.unmarshal(an, out) - delete(d.aliases, n.value) - return good -} - -var zeroValue reflect.Value - -func resetMap(out reflect.Value) { - for _, k := range out.MapKeys() { - out.SetMapIndex(k, zeroValue) - } -} - -func (d *decoder) scalar(n *node, out reflect.Value) (good bool) { - var tag string - var resolved interface{} - if n.tag == "" && !n.implicit { - tag = yaml_STR_TAG - resolved = n.value - } else { - tag, resolved = resolve(n.tag, n.value) - if tag == yaml_BINARY_TAG { - data, err := base64.StdEncoding.DecodeString(resolved.(string)) - if err != nil { - failf("!!binary value contains invalid base64 data") - } - resolved = string(data) - } - } - if resolved == nil { - if out.Kind() == reflect.Map && !out.CanAddr() { - resetMap(out) - } else { - out.Set(reflect.Zero(out.Type())) - } - return true - } - if s, ok := resolved.(string); ok && out.CanAddr() { - if u, ok := out.Addr().Interface().(encoding.TextUnmarshaler); ok { - err := u.UnmarshalText([]byte(s)) - if err != nil { - fail(err) - } - return true - } - } - switch out.Kind() { - case reflect.String: - if tag == yaml_BINARY_TAG { - out.SetString(resolved.(string)) - good = true - } else if resolved != nil { - out.SetString(n.value) - good = true - } - case reflect.Interface: - if resolved == nil { - out.Set(reflect.Zero(out.Type())) - } else { - out.Set(reflect.ValueOf(resolved)) - } - good = true - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - switch resolved := resolved.(type) { - case int: - if !out.OverflowInt(int64(resolved)) { - out.SetInt(int64(resolved)) - good = true - } - case int64: - if !out.OverflowInt(resolved) { - out.SetInt(resolved) - good = true - } - case uint64: - if resolved <= math.MaxInt64 && !out.OverflowInt(int64(resolved)) { - out.SetInt(int64(resolved)) - good = true - } - case float64: - if resolved <= math.MaxInt64 && !out.OverflowInt(int64(resolved)) { - out.SetInt(int64(resolved)) - good = true - } - case string: - if out.Type() == durationType { - d, err := time.ParseDuration(resolved) - if err == nil { - out.SetInt(int64(d)) - good = true - } - } - } - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - switch resolved := resolved.(type) { - case int: - if resolved >= 0 && !out.OverflowUint(uint64(resolved)) { - out.SetUint(uint64(resolved)) - good = true - } - case int64: - if resolved >= 0 && !out.OverflowUint(uint64(resolved)) { - out.SetUint(uint64(resolved)) - good = true - } - case uint64: - if !out.OverflowUint(uint64(resolved)) { - out.SetUint(uint64(resolved)) - good = true - } - case float64: - if resolved <= math.MaxUint64 && !out.OverflowUint(uint64(resolved)) { - out.SetUint(uint64(resolved)) - good = true - } - } - case reflect.Bool: - switch resolved := resolved.(type) { - case bool: - out.SetBool(resolved) - good = true - } - case reflect.Float32, reflect.Float64: - switch resolved := resolved.(type) { - case int: - out.SetFloat(float64(resolved)) - good = true - case int64: - out.SetFloat(float64(resolved)) - good = true - case uint64: - out.SetFloat(float64(resolved)) - good = true - case float64: - out.SetFloat(resolved) - good = true - } - case reflect.Ptr: - if out.Type().Elem() == reflect.TypeOf(resolved) { - // TODO DOes this make sense? When is out a Ptr except when decoding a nil value? - elem := reflect.New(out.Type().Elem()) - elem.Elem().Set(reflect.ValueOf(resolved)) - out.Set(elem) - good = true - } - } - if !good { - d.terror(n, tag, out) - } - return good -} - -func settableValueOf(i interface{}) reflect.Value { - v := reflect.ValueOf(i) - sv := reflect.New(v.Type()).Elem() - sv.Set(v) - return sv -} - -func (d *decoder) sequence(n *node, out reflect.Value) (good bool) { - l := len(n.children) - - var iface reflect.Value - switch out.Kind() { - case reflect.Slice: - out.Set(reflect.MakeSlice(out.Type(), l, l)) - case reflect.Interface: - // No type hints. Will have to use a generic sequence. - iface = out - out = settableValueOf(make([]interface{}, l)) - default: - d.terror(n, yaml_SEQ_TAG, out) - return false - } - et := out.Type().Elem() - - j := 0 - for i := 0; i < l; i++ { - e := reflect.New(et).Elem() - if ok := d.unmarshal(n.children[i], e); ok { - out.Index(j).Set(e) - j++ - } - } - out.Set(out.Slice(0, j)) - if iface.IsValid() { - iface.Set(out) - } - return true -} - -func (d *decoder) mapping(n *node, out reflect.Value) (good bool) { - switch out.Kind() { - case reflect.Struct: - return d.mappingStruct(n, out) - case reflect.Slice: - return d.mappingSlice(n, out) - case reflect.Map: - // okay - case reflect.Interface: - if d.mapType.Kind() == reflect.Map { - iface := out - out = reflect.MakeMap(d.mapType) - iface.Set(out) - } else { - slicev := reflect.New(d.mapType).Elem() - if !d.mappingSlice(n, slicev) { - return false - } - out.Set(slicev) - return true - } - default: - d.terror(n, yaml_MAP_TAG, out) - return false - } - outt := out.Type() - kt := outt.Key() - et := outt.Elem() - - mapType := d.mapType - if outt.Key() == ifaceType && outt.Elem() == ifaceType { - d.mapType = outt - } - - if out.IsNil() { - out.Set(reflect.MakeMap(outt)) - } - l := len(n.children) - for i := 0; i < l; i += 2 { - if isMerge(n.children[i]) { - d.merge(n.children[i+1], out) - continue - } - k := reflect.New(kt).Elem() - if d.unmarshal(n.children[i], k) { - kkind := k.Kind() - if kkind == reflect.Interface { - kkind = k.Elem().Kind() - } - if kkind == reflect.Map || kkind == reflect.Slice { - failf("invalid map key: %#v", k.Interface()) - } - e := reflect.New(et).Elem() - if d.unmarshal(n.children[i+1], e) { - out.SetMapIndex(k, e) - } - } - } - d.mapType = mapType - return true -} - -func (d *decoder) mappingSlice(n *node, out reflect.Value) (good bool) { - outt := out.Type() - if outt.Elem() != mapItemType { - d.terror(n, yaml_MAP_TAG, out) - return false - } - - mapType := d.mapType - d.mapType = outt - - var slice []MapItem - var l = len(n.children) - for i := 0; i < l; i += 2 { - if isMerge(n.children[i]) { - d.merge(n.children[i+1], out) - continue - } - item := MapItem{} - k := reflect.ValueOf(&item.Key).Elem() - if d.unmarshal(n.children[i], k) { - v := reflect.ValueOf(&item.Value).Elem() - if d.unmarshal(n.children[i+1], v) { - slice = append(slice, item) - } - } - } - out.Set(reflect.ValueOf(slice)) - d.mapType = mapType - return true -} - -func (d *decoder) mappingStruct(n *node, out reflect.Value) (good bool) { - sinfo, err := getStructInfo(out.Type()) - if err != nil { - panic(err) - } - name := settableValueOf("") - l := len(n.children) - - var inlineMap reflect.Value - var elemType reflect.Type - if sinfo.InlineMap != -1 { - inlineMap = out.Field(sinfo.InlineMap) - inlineMap.Set(reflect.New(inlineMap.Type()).Elem()) - elemType = inlineMap.Type().Elem() - } - - for i := 0; i < l; i += 2 { - ni := n.children[i] - if isMerge(ni) { - d.merge(n.children[i+1], out) - continue - } - if !d.unmarshal(ni, name) { - continue - } - if info, ok := sinfo.FieldsMap[name.String()]; ok { - var field reflect.Value - if info.Inline == nil { - field = out.Field(info.Num) - } else { - field = out.FieldByIndex(info.Inline) - } - d.unmarshal(n.children[i+1], field) - } else if sinfo.InlineMap != -1 { - if inlineMap.IsNil() { - inlineMap.Set(reflect.MakeMap(inlineMap.Type())) - } - value := reflect.New(elemType).Elem() - d.unmarshal(n.children[i+1], value) - inlineMap.SetMapIndex(name, value) - } - } - return true -} - -func failWantMap() { - failf("map merge requires map or sequence of maps as the value") -} - -func (d *decoder) merge(n *node, out reflect.Value) { - switch n.kind { - case mappingNode: - d.unmarshal(n, out) - case aliasNode: - an, ok := d.doc.anchors[n.value] - if ok && an.kind != mappingNode { - failWantMap() - } - d.unmarshal(n, out) - case sequenceNode: - // Step backwards as earlier nodes take precedence. - for i := len(n.children) - 1; i >= 0; i-- { - ni := n.children[i] - if ni.kind == aliasNode { - an, ok := d.doc.anchors[ni.value] - if ok && an.kind != mappingNode { - failWantMap() - } - } else if ni.kind != mappingNode { - failWantMap() - } - d.unmarshal(ni, out) - } - default: - failWantMap() - } -} - -func isMerge(n *node) bool { - return n.kind == scalarNode && n.value == "<<" && (n.implicit == true || n.tag == yaml_MERGE_TAG) -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/emitterc.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/emitterc.go deleted file mode 100644 index 2befd55..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/emitterc.go +++ /dev/null @@ -1,1685 +0,0 @@ -package yaml - -import ( - "bytes" -) - -// Flush the buffer if needed. -func flush(emitter *yaml_emitter_t) bool { - if emitter.buffer_pos+5 >= len(emitter.buffer) { - return yaml_emitter_flush(emitter) - } - return true -} - -// Put a character to the output buffer. -func put(emitter *yaml_emitter_t, value byte) bool { - if emitter.buffer_pos+5 >= len(emitter.buffer) && !yaml_emitter_flush(emitter) { - return false - } - emitter.buffer[emitter.buffer_pos] = value - emitter.buffer_pos++ - emitter.column++ - return true -} - -// Put a line break to the output buffer. -func put_break(emitter *yaml_emitter_t) bool { - if emitter.buffer_pos+5 >= len(emitter.buffer) && !yaml_emitter_flush(emitter) { - return false - } - switch emitter.line_break { - case yaml_CR_BREAK: - emitter.buffer[emitter.buffer_pos] = '\r' - emitter.buffer_pos += 1 - case yaml_LN_BREAK: - emitter.buffer[emitter.buffer_pos] = '\n' - emitter.buffer_pos += 1 - case yaml_CRLN_BREAK: - emitter.buffer[emitter.buffer_pos+0] = '\r' - emitter.buffer[emitter.buffer_pos+1] = '\n' - emitter.buffer_pos += 2 - default: - panic("unknown line break setting") - } - emitter.column = 0 - emitter.line++ - return true -} - -// Copy a character from a string into buffer. -func write(emitter *yaml_emitter_t, s []byte, i *int) bool { - if emitter.buffer_pos+5 >= len(emitter.buffer) && !yaml_emitter_flush(emitter) { - return false - } - p := emitter.buffer_pos - w := width(s[*i]) - switch w { - case 4: - emitter.buffer[p+3] = s[*i+3] - fallthrough - case 3: - emitter.buffer[p+2] = s[*i+2] - fallthrough - case 2: - emitter.buffer[p+1] = s[*i+1] - fallthrough - case 1: - emitter.buffer[p+0] = s[*i+0] - default: - panic("unknown character width") - } - emitter.column++ - emitter.buffer_pos += w - *i += w - return true -} - -// Write a whole string into buffer. -func write_all(emitter *yaml_emitter_t, s []byte) bool { - for i := 0; i < len(s); { - if !write(emitter, s, &i) { - return false - } - } - return true -} - -// Copy a line break character from a string into buffer. -func write_break(emitter *yaml_emitter_t, s []byte, i *int) bool { - if s[*i] == '\n' { - if !put_break(emitter) { - return false - } - *i++ - } else { - if !write(emitter, s, i) { - return false - } - emitter.column = 0 - emitter.line++ - } - return true -} - -// Set an emitter error and return false. -func yaml_emitter_set_emitter_error(emitter *yaml_emitter_t, problem string) bool { - emitter.error = yaml_EMITTER_ERROR - emitter.problem = problem - return false -} - -// Emit an event. -func yaml_emitter_emit(emitter *yaml_emitter_t, event *yaml_event_t) bool { - emitter.events = append(emitter.events, *event) - for !yaml_emitter_need_more_events(emitter) { - event := &emitter.events[emitter.events_head] - if !yaml_emitter_analyze_event(emitter, event) { - return false - } - if !yaml_emitter_state_machine(emitter, event) { - return false - } - yaml_event_delete(event) - emitter.events_head++ - } - return true -} - -// Check if we need to accumulate more events before emitting. -// -// We accumulate extra -// - 1 event for DOCUMENT-START -// - 2 events for SEQUENCE-START -// - 3 events for MAPPING-START -// -func yaml_emitter_need_more_events(emitter *yaml_emitter_t) bool { - if emitter.events_head == len(emitter.events) { - return true - } - var accumulate int - switch emitter.events[emitter.events_head].typ { - case yaml_DOCUMENT_START_EVENT: - accumulate = 1 - break - case yaml_SEQUENCE_START_EVENT: - accumulate = 2 - break - case yaml_MAPPING_START_EVENT: - accumulate = 3 - break - default: - return false - } - if len(emitter.events)-emitter.events_head > accumulate { - return false - } - var level int - for i := emitter.events_head; i < len(emitter.events); i++ { - switch emitter.events[i].typ { - case yaml_STREAM_START_EVENT, yaml_DOCUMENT_START_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT: - level++ - case yaml_STREAM_END_EVENT, yaml_DOCUMENT_END_EVENT, yaml_SEQUENCE_END_EVENT, yaml_MAPPING_END_EVENT: - level-- - } - if level == 0 { - return false - } - } - return true -} - -// Append a directive to the directives stack. -func yaml_emitter_append_tag_directive(emitter *yaml_emitter_t, value *yaml_tag_directive_t, allow_duplicates bool) bool { - for i := 0; i < len(emitter.tag_directives); i++ { - if bytes.Equal(value.handle, emitter.tag_directives[i].handle) { - if allow_duplicates { - return true - } - return yaml_emitter_set_emitter_error(emitter, "duplicate %TAG directive") - } - } - - // [Go] Do we actually need to copy this given garbage collection - // and the lack of deallocating destructors? - tag_copy := yaml_tag_directive_t{ - handle: make([]byte, len(value.handle)), - prefix: make([]byte, len(value.prefix)), - } - copy(tag_copy.handle, value.handle) - copy(tag_copy.prefix, value.prefix) - emitter.tag_directives = append(emitter.tag_directives, tag_copy) - return true -} - -// Increase the indentation level. -func yaml_emitter_increase_indent(emitter *yaml_emitter_t, flow, indentless bool) bool { - emitter.indents = append(emitter.indents, emitter.indent) - if emitter.indent < 0 { - if flow { - emitter.indent = emitter.best_indent - } else { - emitter.indent = 0 - } - } else if !indentless { - emitter.indent += emitter.best_indent - } - return true -} - -// State dispatcher. -func yaml_emitter_state_machine(emitter *yaml_emitter_t, event *yaml_event_t) bool { - switch emitter.state { - default: - case yaml_EMIT_STREAM_START_STATE: - return yaml_emitter_emit_stream_start(emitter, event) - - case yaml_EMIT_FIRST_DOCUMENT_START_STATE: - return yaml_emitter_emit_document_start(emitter, event, true) - - case yaml_EMIT_DOCUMENT_START_STATE: - return yaml_emitter_emit_document_start(emitter, event, false) - - case yaml_EMIT_DOCUMENT_CONTENT_STATE: - return yaml_emitter_emit_document_content(emitter, event) - - case yaml_EMIT_DOCUMENT_END_STATE: - return yaml_emitter_emit_document_end(emitter, event) - - case yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE: - return yaml_emitter_emit_flow_sequence_item(emitter, event, true) - - case yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE: - return yaml_emitter_emit_flow_sequence_item(emitter, event, false) - - case yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE: - return yaml_emitter_emit_flow_mapping_key(emitter, event, true) - - case yaml_EMIT_FLOW_MAPPING_KEY_STATE: - return yaml_emitter_emit_flow_mapping_key(emitter, event, false) - - case yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE: - return yaml_emitter_emit_flow_mapping_value(emitter, event, true) - - case yaml_EMIT_FLOW_MAPPING_VALUE_STATE: - return yaml_emitter_emit_flow_mapping_value(emitter, event, false) - - case yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE: - return yaml_emitter_emit_block_sequence_item(emitter, event, true) - - case yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE: - return yaml_emitter_emit_block_sequence_item(emitter, event, false) - - case yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE: - return yaml_emitter_emit_block_mapping_key(emitter, event, true) - - case yaml_EMIT_BLOCK_MAPPING_KEY_STATE: - return yaml_emitter_emit_block_mapping_key(emitter, event, false) - - case yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE: - return yaml_emitter_emit_block_mapping_value(emitter, event, true) - - case yaml_EMIT_BLOCK_MAPPING_VALUE_STATE: - return yaml_emitter_emit_block_mapping_value(emitter, event, false) - - case yaml_EMIT_END_STATE: - return yaml_emitter_set_emitter_error(emitter, "expected nothing after STREAM-END") - } - panic("invalid emitter state") -} - -// Expect STREAM-START. -func yaml_emitter_emit_stream_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if event.typ != yaml_STREAM_START_EVENT { - return yaml_emitter_set_emitter_error(emitter, "expected STREAM-START") - } - if emitter.encoding == yaml_ANY_ENCODING { - emitter.encoding = event.encoding - if emitter.encoding == yaml_ANY_ENCODING { - emitter.encoding = yaml_UTF8_ENCODING - } - } - if emitter.best_indent < 2 || emitter.best_indent > 9 { - emitter.best_indent = 2 - } - if emitter.best_width >= 0 && emitter.best_width <= emitter.best_indent*2 { - emitter.best_width = 80 - } - if emitter.best_width < 0 { - emitter.best_width = 1<<31 - 1 - } - if emitter.line_break == yaml_ANY_BREAK { - emitter.line_break = yaml_LN_BREAK - } - - emitter.indent = -1 - emitter.line = 0 - emitter.column = 0 - emitter.whitespace = true - emitter.indention = true - - if emitter.encoding != yaml_UTF8_ENCODING { - if !yaml_emitter_write_bom(emitter) { - return false - } - } - emitter.state = yaml_EMIT_FIRST_DOCUMENT_START_STATE - return true -} - -// Expect DOCUMENT-START or STREAM-END. -func yaml_emitter_emit_document_start(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - - if event.typ == yaml_DOCUMENT_START_EVENT { - - if event.version_directive != nil { - if !yaml_emitter_analyze_version_directive(emitter, event.version_directive) { - return false - } - } - - for i := 0; i < len(event.tag_directives); i++ { - tag_directive := &event.tag_directives[i] - if !yaml_emitter_analyze_tag_directive(emitter, tag_directive) { - return false - } - if !yaml_emitter_append_tag_directive(emitter, tag_directive, false) { - return false - } - } - - for i := 0; i < len(default_tag_directives); i++ { - tag_directive := &default_tag_directives[i] - if !yaml_emitter_append_tag_directive(emitter, tag_directive, true) { - return false - } - } - - implicit := event.implicit - if !first || emitter.canonical { - implicit = false - } - - if emitter.open_ended && (event.version_directive != nil || len(event.tag_directives) > 0) { - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if event.version_directive != nil { - implicit = false - if !yaml_emitter_write_indicator(emitter, []byte("%YAML"), true, false, false) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte("1.1"), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if len(event.tag_directives) > 0 { - implicit = false - for i := 0; i < len(event.tag_directives); i++ { - tag_directive := &event.tag_directives[i] - if !yaml_emitter_write_indicator(emitter, []byte("%TAG"), true, false, false) { - return false - } - if !yaml_emitter_write_tag_handle(emitter, tag_directive.handle) { - return false - } - if !yaml_emitter_write_tag_content(emitter, tag_directive.prefix, true) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - } - - if yaml_emitter_check_empty_document(emitter) { - implicit = false - } - if !implicit { - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte("---"), true, false, false) { - return false - } - if emitter.canonical { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - } - - emitter.state = yaml_EMIT_DOCUMENT_CONTENT_STATE - return true - } - - if event.typ == yaml_STREAM_END_EVENT { - if emitter.open_ended { - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_flush(emitter) { - return false - } - emitter.state = yaml_EMIT_END_STATE - return true - } - - return yaml_emitter_set_emitter_error(emitter, "expected DOCUMENT-START or STREAM-END") -} - -// Expect the root node. -func yaml_emitter_emit_document_content(emitter *yaml_emitter_t, event *yaml_event_t) bool { - emitter.states = append(emitter.states, yaml_EMIT_DOCUMENT_END_STATE) - return yaml_emitter_emit_node(emitter, event, true, false, false, false) -} - -// Expect DOCUMENT-END. -func yaml_emitter_emit_document_end(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if event.typ != yaml_DOCUMENT_END_EVENT { - return yaml_emitter_set_emitter_error(emitter, "expected DOCUMENT-END") - } - if !yaml_emitter_write_indent(emitter) { - return false - } - if !event.implicit { - // [Go] Allocate the slice elsewhere. - if !yaml_emitter_write_indicator(emitter, []byte("..."), true, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_flush(emitter) { - return false - } - emitter.state = yaml_EMIT_DOCUMENT_START_STATE - emitter.tag_directives = emitter.tag_directives[:0] - return true -} - -// Expect a flow item node. -func yaml_emitter_emit_flow_sequence_item(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - if first { - if !yaml_emitter_write_indicator(emitter, []byte{'['}, true, true, false) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - emitter.flow_level++ - } - - if event.typ == yaml_SEQUENCE_END_EVENT { - emitter.flow_level-- - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - if emitter.canonical && !first { - if !yaml_emitter_write_indicator(emitter, []byte{','}, false, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte{']'}, false, false, false) { - return false - } - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - - return true - } - - if !first { - if !yaml_emitter_write_indicator(emitter, []byte{','}, false, false, false) { - return false - } - } - - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - emitter.states = append(emitter.states, yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE) - return yaml_emitter_emit_node(emitter, event, false, true, false, false) -} - -// Expect a flow key node. -func yaml_emitter_emit_flow_mapping_key(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - if first { - if !yaml_emitter_write_indicator(emitter, []byte{'{'}, true, true, false) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - emitter.flow_level++ - } - - if event.typ == yaml_MAPPING_END_EVENT { - emitter.flow_level-- - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - if emitter.canonical && !first { - if !yaml_emitter_write_indicator(emitter, []byte{','}, false, false, false) { - return false - } - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte{'}'}, false, false, false) { - return false - } - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - return true - } - - if !first { - if !yaml_emitter_write_indicator(emitter, []byte{','}, false, false, false) { - return false - } - } - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - - if !emitter.canonical && yaml_emitter_check_simple_key(emitter) { - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, true) - } - if !yaml_emitter_write_indicator(emitter, []byte{'?'}, true, false, false) { - return false - } - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -// Expect a flow value node. -func yaml_emitter_emit_flow_mapping_value(emitter *yaml_emitter_t, event *yaml_event_t, simple bool) bool { - if simple { - if !yaml_emitter_write_indicator(emitter, []byte{':'}, false, false, false) { - return false - } - } else { - if emitter.canonical || emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !yaml_emitter_write_indicator(emitter, []byte{':'}, true, false, false) { - return false - } - } - emitter.states = append(emitter.states, yaml_EMIT_FLOW_MAPPING_KEY_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -// Expect a block item node. -func yaml_emitter_emit_block_sequence_item(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - if first { - if !yaml_emitter_increase_indent(emitter, false, emitter.mapping_context && !emitter.indention) { - return false - } - } - if event.typ == yaml_SEQUENCE_END_EVENT { - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - return true - } - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte{'-'}, true, false, true) { - return false - } - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE) - return yaml_emitter_emit_node(emitter, event, false, true, false, false) -} - -// Expect a block key node. -func yaml_emitter_emit_block_mapping_key(emitter *yaml_emitter_t, event *yaml_event_t, first bool) bool { - if first { - if !yaml_emitter_increase_indent(emitter, false, false) { - return false - } - } - if event.typ == yaml_MAPPING_END_EVENT { - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - return true - } - if !yaml_emitter_write_indent(emitter) { - return false - } - if yaml_emitter_check_simple_key(emitter) { - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, true) - } - if !yaml_emitter_write_indicator(emitter, []byte{'?'}, true, false, true) { - return false - } - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_VALUE_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -// Expect a block value node. -func yaml_emitter_emit_block_mapping_value(emitter *yaml_emitter_t, event *yaml_event_t, simple bool) bool { - if simple { - if !yaml_emitter_write_indicator(emitter, []byte{':'}, false, false, false) { - return false - } - } else { - if !yaml_emitter_write_indent(emitter) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte{':'}, true, false, true) { - return false - } - } - emitter.states = append(emitter.states, yaml_EMIT_BLOCK_MAPPING_KEY_STATE) - return yaml_emitter_emit_node(emitter, event, false, false, true, false) -} - -// Expect a node. -func yaml_emitter_emit_node(emitter *yaml_emitter_t, event *yaml_event_t, - root bool, sequence bool, mapping bool, simple_key bool) bool { - - emitter.root_context = root - emitter.sequence_context = sequence - emitter.mapping_context = mapping - emitter.simple_key_context = simple_key - - switch event.typ { - case yaml_ALIAS_EVENT: - return yaml_emitter_emit_alias(emitter, event) - case yaml_SCALAR_EVENT: - return yaml_emitter_emit_scalar(emitter, event) - case yaml_SEQUENCE_START_EVENT: - return yaml_emitter_emit_sequence_start(emitter, event) - case yaml_MAPPING_START_EVENT: - return yaml_emitter_emit_mapping_start(emitter, event) - default: - return yaml_emitter_set_emitter_error(emitter, - "expected SCALAR, SEQUENCE-START, MAPPING-START, or ALIAS") - } - return false -} - -// Expect ALIAS. -func yaml_emitter_emit_alias(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - return true -} - -// Expect SCALAR. -func yaml_emitter_emit_scalar(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_select_scalar_style(emitter, event) { - return false - } - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - if !yaml_emitter_increase_indent(emitter, true, false) { - return false - } - if !yaml_emitter_process_scalar(emitter) { - return false - } - emitter.indent = emitter.indents[len(emitter.indents)-1] - emitter.indents = emitter.indents[:len(emitter.indents)-1] - emitter.state = emitter.states[len(emitter.states)-1] - emitter.states = emitter.states[:len(emitter.states)-1] - return true -} - -// Expect SEQUENCE-START. -func yaml_emitter_emit_sequence_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - if emitter.flow_level > 0 || emitter.canonical || event.sequence_style() == yaml_FLOW_SEQUENCE_STYLE || - yaml_emitter_check_empty_sequence(emitter) { - emitter.state = yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE - } else { - emitter.state = yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE - } - return true -} - -// Expect MAPPING-START. -func yaml_emitter_emit_mapping_start(emitter *yaml_emitter_t, event *yaml_event_t) bool { - if !yaml_emitter_process_anchor(emitter) { - return false - } - if !yaml_emitter_process_tag(emitter) { - return false - } - if emitter.flow_level > 0 || emitter.canonical || event.mapping_style() == yaml_FLOW_MAPPING_STYLE || - yaml_emitter_check_empty_mapping(emitter) { - emitter.state = yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE - } else { - emitter.state = yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE - } - return true -} - -// Check if the document content is an empty scalar. -func yaml_emitter_check_empty_document(emitter *yaml_emitter_t) bool { - return false // [Go] Huh? -} - -// Check if the next events represent an empty sequence. -func yaml_emitter_check_empty_sequence(emitter *yaml_emitter_t) bool { - if len(emitter.events)-emitter.events_head < 2 { - return false - } - return emitter.events[emitter.events_head].typ == yaml_SEQUENCE_START_EVENT && - emitter.events[emitter.events_head+1].typ == yaml_SEQUENCE_END_EVENT -} - -// Check if the next events represent an empty mapping. -func yaml_emitter_check_empty_mapping(emitter *yaml_emitter_t) bool { - if len(emitter.events)-emitter.events_head < 2 { - return false - } - return emitter.events[emitter.events_head].typ == yaml_MAPPING_START_EVENT && - emitter.events[emitter.events_head+1].typ == yaml_MAPPING_END_EVENT -} - -// Check if the next node can be expressed as a simple key. -func yaml_emitter_check_simple_key(emitter *yaml_emitter_t) bool { - length := 0 - switch emitter.events[emitter.events_head].typ { - case yaml_ALIAS_EVENT: - length += len(emitter.anchor_data.anchor) - case yaml_SCALAR_EVENT: - if emitter.scalar_data.multiline { - return false - } - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) + - len(emitter.scalar_data.value) - case yaml_SEQUENCE_START_EVENT: - if !yaml_emitter_check_empty_sequence(emitter) { - return false - } - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) - case yaml_MAPPING_START_EVENT: - if !yaml_emitter_check_empty_mapping(emitter) { - return false - } - length += len(emitter.anchor_data.anchor) + - len(emitter.tag_data.handle) + - len(emitter.tag_data.suffix) - default: - return false - } - return length <= 128 -} - -// Determine an acceptable scalar style. -func yaml_emitter_select_scalar_style(emitter *yaml_emitter_t, event *yaml_event_t) bool { - - no_tag := len(emitter.tag_data.handle) == 0 && len(emitter.tag_data.suffix) == 0 - if no_tag && !event.implicit && !event.quoted_implicit { - return yaml_emitter_set_emitter_error(emitter, "neither tag nor implicit flags are specified") - } - - style := event.scalar_style() - if style == yaml_ANY_SCALAR_STYLE { - style = yaml_PLAIN_SCALAR_STYLE - } - if emitter.canonical { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - if emitter.simple_key_context && emitter.scalar_data.multiline { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - - if style == yaml_PLAIN_SCALAR_STYLE { - if emitter.flow_level > 0 && !emitter.scalar_data.flow_plain_allowed || - emitter.flow_level == 0 && !emitter.scalar_data.block_plain_allowed { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - if len(emitter.scalar_data.value) == 0 && (emitter.flow_level > 0 || emitter.simple_key_context) { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - if no_tag && !event.implicit { - style = yaml_SINGLE_QUOTED_SCALAR_STYLE - } - } - if style == yaml_SINGLE_QUOTED_SCALAR_STYLE { - if !emitter.scalar_data.single_quoted_allowed { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - } - if style == yaml_LITERAL_SCALAR_STYLE || style == yaml_FOLDED_SCALAR_STYLE { - if !emitter.scalar_data.block_allowed || emitter.flow_level > 0 || emitter.simple_key_context { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - } - - if no_tag && !event.quoted_implicit && style != yaml_PLAIN_SCALAR_STYLE { - emitter.tag_data.handle = []byte{'!'} - } - emitter.scalar_data.style = style - return true -} - -// Write an achor. -func yaml_emitter_process_anchor(emitter *yaml_emitter_t) bool { - if emitter.anchor_data.anchor == nil { - return true - } - c := []byte{'&'} - if emitter.anchor_data.alias { - c[0] = '*' - } - if !yaml_emitter_write_indicator(emitter, c, true, false, false) { - return false - } - return yaml_emitter_write_anchor(emitter, emitter.anchor_data.anchor) -} - -// Write a tag. -func yaml_emitter_process_tag(emitter *yaml_emitter_t) bool { - if len(emitter.tag_data.handle) == 0 && len(emitter.tag_data.suffix) == 0 { - return true - } - if len(emitter.tag_data.handle) > 0 { - if !yaml_emitter_write_tag_handle(emitter, emitter.tag_data.handle) { - return false - } - if len(emitter.tag_data.suffix) > 0 { - if !yaml_emitter_write_tag_content(emitter, emitter.tag_data.suffix, false) { - return false - } - } - } else { - // [Go] Allocate these slices elsewhere. - if !yaml_emitter_write_indicator(emitter, []byte("!<"), true, false, false) { - return false - } - if !yaml_emitter_write_tag_content(emitter, emitter.tag_data.suffix, false) { - return false - } - if !yaml_emitter_write_indicator(emitter, []byte{'>'}, false, false, false) { - return false - } - } - return true -} - -// Write a scalar. -func yaml_emitter_process_scalar(emitter *yaml_emitter_t) bool { - switch emitter.scalar_data.style { - case yaml_PLAIN_SCALAR_STYLE: - return yaml_emitter_write_plain_scalar(emitter, emitter.scalar_data.value, !emitter.simple_key_context) - - case yaml_SINGLE_QUOTED_SCALAR_STYLE: - return yaml_emitter_write_single_quoted_scalar(emitter, emitter.scalar_data.value, !emitter.simple_key_context) - - case yaml_DOUBLE_QUOTED_SCALAR_STYLE: - return yaml_emitter_write_double_quoted_scalar(emitter, emitter.scalar_data.value, !emitter.simple_key_context) - - case yaml_LITERAL_SCALAR_STYLE: - return yaml_emitter_write_literal_scalar(emitter, emitter.scalar_data.value) - - case yaml_FOLDED_SCALAR_STYLE: - return yaml_emitter_write_folded_scalar(emitter, emitter.scalar_data.value) - } - panic("unknown scalar style") -} - -// Check if a %YAML directive is valid. -func yaml_emitter_analyze_version_directive(emitter *yaml_emitter_t, version_directive *yaml_version_directive_t) bool { - if version_directive.major != 1 || version_directive.minor != 1 { - return yaml_emitter_set_emitter_error(emitter, "incompatible %YAML directive") - } - return true -} - -// Check if a %TAG directive is valid. -func yaml_emitter_analyze_tag_directive(emitter *yaml_emitter_t, tag_directive *yaml_tag_directive_t) bool { - handle := tag_directive.handle - prefix := tag_directive.prefix - if len(handle) == 0 { - return yaml_emitter_set_emitter_error(emitter, "tag handle must not be empty") - } - if handle[0] != '!' { - return yaml_emitter_set_emitter_error(emitter, "tag handle must start with '!'") - } - if handle[len(handle)-1] != '!' { - return yaml_emitter_set_emitter_error(emitter, "tag handle must end with '!'") - } - for i := 1; i < len(handle)-1; i += width(handle[i]) { - if !is_alpha(handle, i) { - return yaml_emitter_set_emitter_error(emitter, "tag handle must contain alphanumerical characters only") - } - } - if len(prefix) == 0 { - return yaml_emitter_set_emitter_error(emitter, "tag prefix must not be empty") - } - return true -} - -// Check if an anchor is valid. -func yaml_emitter_analyze_anchor(emitter *yaml_emitter_t, anchor []byte, alias bool) bool { - if len(anchor) == 0 { - problem := "anchor value must not be empty" - if alias { - problem = "alias value must not be empty" - } - return yaml_emitter_set_emitter_error(emitter, problem) - } - for i := 0; i < len(anchor); i += width(anchor[i]) { - if !is_alpha(anchor, i) { - problem := "anchor value must contain alphanumerical characters only" - if alias { - problem = "alias value must contain alphanumerical characters only" - } - return yaml_emitter_set_emitter_error(emitter, problem) - } - } - emitter.anchor_data.anchor = anchor - emitter.anchor_data.alias = alias - return true -} - -// Check if a tag is valid. -func yaml_emitter_analyze_tag(emitter *yaml_emitter_t, tag []byte) bool { - if len(tag) == 0 { - return yaml_emitter_set_emitter_error(emitter, "tag value must not be empty") - } - for i := 0; i < len(emitter.tag_directives); i++ { - tag_directive := &emitter.tag_directives[i] - if bytes.HasPrefix(tag, tag_directive.prefix) { - emitter.tag_data.handle = tag_directive.handle - emitter.tag_data.suffix = tag[len(tag_directive.prefix):] - return true - } - } - emitter.tag_data.suffix = tag - return true -} - -// Check if a scalar is valid. -func yaml_emitter_analyze_scalar(emitter *yaml_emitter_t, value []byte) bool { - var ( - block_indicators = false - flow_indicators = false - line_breaks = false - special_characters = false - - leading_space = false - leading_break = false - trailing_space = false - trailing_break = false - break_space = false - space_break = false - - preceeded_by_whitespace = false - followed_by_whitespace = false - previous_space = false - previous_break = false - ) - - emitter.scalar_data.value = value - - if len(value) == 0 { - emitter.scalar_data.multiline = false - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = true - emitter.scalar_data.single_quoted_allowed = true - emitter.scalar_data.block_allowed = false - return true - } - - if len(value) >= 3 && ((value[0] == '-' && value[1] == '-' && value[2] == '-') || (value[0] == '.' && value[1] == '.' && value[2] == '.')) { - block_indicators = true - flow_indicators = true - } - - preceeded_by_whitespace = true - for i, w := 0, 0; i < len(value); i += w { - w = width(value[i]) - followed_by_whitespace = i+w >= len(value) || is_blank(value, i+w) - - if i == 0 { - switch value[i] { - case '#', ',', '[', ']', '{', '}', '&', '*', '!', '|', '>', '\'', '"', '%', '@', '`': - flow_indicators = true - block_indicators = true - case '?', ':': - flow_indicators = true - if followed_by_whitespace { - block_indicators = true - } - case '-': - if followed_by_whitespace { - flow_indicators = true - block_indicators = true - } - } - } else { - switch value[i] { - case ',', '?', '[', ']', '{', '}': - flow_indicators = true - case ':': - flow_indicators = true - if followed_by_whitespace { - block_indicators = true - } - case '#': - if preceeded_by_whitespace { - flow_indicators = true - block_indicators = true - } - } - } - - if !is_printable(value, i) || !is_ascii(value, i) && !emitter.unicode { - special_characters = true - } - if is_space(value, i) { - if i == 0 { - leading_space = true - } - if i+width(value[i]) == len(value) { - trailing_space = true - } - if previous_break { - break_space = true - } - previous_space = true - previous_break = false - } else if is_break(value, i) { - line_breaks = true - if i == 0 { - leading_break = true - } - if i+width(value[i]) == len(value) { - trailing_break = true - } - if previous_space { - space_break = true - } - previous_space = false - previous_break = true - } else { - previous_space = false - previous_break = false - } - - // [Go]: Why 'z'? Couldn't be the end of the string as that's the loop condition. - preceeded_by_whitespace = is_blankz(value, i) - } - - emitter.scalar_data.multiline = line_breaks - emitter.scalar_data.flow_plain_allowed = true - emitter.scalar_data.block_plain_allowed = true - emitter.scalar_data.single_quoted_allowed = true - emitter.scalar_data.block_allowed = true - - if leading_space || leading_break || trailing_space || trailing_break { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - } - if trailing_space { - emitter.scalar_data.block_allowed = false - } - if break_space { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - emitter.scalar_data.single_quoted_allowed = false - } - if space_break || special_characters { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - emitter.scalar_data.single_quoted_allowed = false - emitter.scalar_data.block_allowed = false - } - if line_breaks { - emitter.scalar_data.flow_plain_allowed = false - emitter.scalar_data.block_plain_allowed = false - } - if flow_indicators { - emitter.scalar_data.flow_plain_allowed = false - } - if block_indicators { - emitter.scalar_data.block_plain_allowed = false - } - return true -} - -// Check if the event data is valid. -func yaml_emitter_analyze_event(emitter *yaml_emitter_t, event *yaml_event_t) bool { - - emitter.anchor_data.anchor = nil - emitter.tag_data.handle = nil - emitter.tag_data.suffix = nil - emitter.scalar_data.value = nil - - switch event.typ { - case yaml_ALIAS_EVENT: - if !yaml_emitter_analyze_anchor(emitter, event.anchor, true) { - return false - } - - case yaml_SCALAR_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || (!event.implicit && !event.quoted_implicit)) { - if !yaml_emitter_analyze_tag(emitter, event.tag) { - return false - } - } - if !yaml_emitter_analyze_scalar(emitter, event.value) { - return false - } - - case yaml_SEQUENCE_START_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || !event.implicit) { - if !yaml_emitter_analyze_tag(emitter, event.tag) { - return false - } - } - - case yaml_MAPPING_START_EVENT: - if len(event.anchor) > 0 { - if !yaml_emitter_analyze_anchor(emitter, event.anchor, false) { - return false - } - } - if len(event.tag) > 0 && (emitter.canonical || !event.implicit) { - if !yaml_emitter_analyze_tag(emitter, event.tag) { - return false - } - } - } - return true -} - -// Write the BOM character. -func yaml_emitter_write_bom(emitter *yaml_emitter_t) bool { - if !flush(emitter) { - return false - } - pos := emitter.buffer_pos - emitter.buffer[pos+0] = '\xEF' - emitter.buffer[pos+1] = '\xBB' - emitter.buffer[pos+2] = '\xBF' - emitter.buffer_pos += 3 - return true -} - -func yaml_emitter_write_indent(emitter *yaml_emitter_t) bool { - indent := emitter.indent - if indent < 0 { - indent = 0 - } - if !emitter.indention || emitter.column > indent || (emitter.column == indent && !emitter.whitespace) { - if !put_break(emitter) { - return false - } - } - for emitter.column < indent { - if !put(emitter, ' ') { - return false - } - } - emitter.whitespace = true - emitter.indention = true - return true -} - -func yaml_emitter_write_indicator(emitter *yaml_emitter_t, indicator []byte, need_whitespace, is_whitespace, is_indention bool) bool { - if need_whitespace && !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - if !write_all(emitter, indicator) { - return false - } - emitter.whitespace = is_whitespace - emitter.indention = (emitter.indention && is_indention) - emitter.open_ended = false - return true -} - -func yaml_emitter_write_anchor(emitter *yaml_emitter_t, value []byte) bool { - if !write_all(emitter, value) { - return false - } - emitter.whitespace = false - emitter.indention = false - return true -} - -func yaml_emitter_write_tag_handle(emitter *yaml_emitter_t, value []byte) bool { - if !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - if !write_all(emitter, value) { - return false - } - emitter.whitespace = false - emitter.indention = false - return true -} - -func yaml_emitter_write_tag_content(emitter *yaml_emitter_t, value []byte, need_whitespace bool) bool { - if need_whitespace && !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - for i := 0; i < len(value); { - var must_write bool - switch value[i] { - case ';', '/', '?', ':', '@', '&', '=', '+', '$', ',', '_', '.', '~', '*', '\'', '(', ')', '[', ']': - must_write = true - default: - must_write = is_alpha(value, i) - } - if must_write { - if !write(emitter, value, &i) { - return false - } - } else { - w := width(value[i]) - for k := 0; k < w; k++ { - octet := value[i] - i++ - if !put(emitter, '%') { - return false - } - - c := octet >> 4 - if c < 10 { - c += '0' - } else { - c += 'A' - 10 - } - if !put(emitter, c) { - return false - } - - c = octet & 0x0f - if c < 10 { - c += '0' - } else { - c += 'A' - 10 - } - if !put(emitter, c) { - return false - } - } - } - } - emitter.whitespace = false - emitter.indention = false - return true -} - -func yaml_emitter_write_plain_scalar(emitter *yaml_emitter_t, value []byte, allow_breaks bool) bool { - if !emitter.whitespace { - if !put(emitter, ' ') { - return false - } - } - - spaces := false - breaks := false - for i := 0; i < len(value); { - if is_space(value, i) { - if allow_breaks && !spaces && emitter.column > emitter.best_width && !is_space(value, i+1) { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - spaces = true - } else if is_break(value, i) { - if !breaks && value[i] == '\n' { - if !put_break(emitter) { - return false - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - spaces = false - breaks = false - } - } - - emitter.whitespace = false - emitter.indention = false - if emitter.root_context { - emitter.open_ended = true - } - - return true -} - -func yaml_emitter_write_single_quoted_scalar(emitter *yaml_emitter_t, value []byte, allow_breaks bool) bool { - - if !yaml_emitter_write_indicator(emitter, []byte{'\''}, true, false, false) { - return false - } - - spaces := false - breaks := false - for i := 0; i < len(value); { - if is_space(value, i) { - if allow_breaks && !spaces && emitter.column > emitter.best_width && i > 0 && i < len(value)-1 && !is_space(value, i+1) { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - spaces = true - } else if is_break(value, i) { - if !breaks && value[i] == '\n' { - if !put_break(emitter) { - return false - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if value[i] == '\'' { - if !put(emitter, '\'') { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - spaces = false - breaks = false - } - } - if !yaml_emitter_write_indicator(emitter, []byte{'\''}, false, false, false) { - return false - } - emitter.whitespace = false - emitter.indention = false - return true -} - -func yaml_emitter_write_double_quoted_scalar(emitter *yaml_emitter_t, value []byte, allow_breaks bool) bool { - spaces := false - if !yaml_emitter_write_indicator(emitter, []byte{'"'}, true, false, false) { - return false - } - - for i := 0; i < len(value); { - if !is_printable(value, i) || (!emitter.unicode && !is_ascii(value, i)) || - is_bom(value, i) || is_break(value, i) || - value[i] == '"' || value[i] == '\\' { - - octet := value[i] - - var w int - var v rune - switch { - case octet&0x80 == 0x00: - w, v = 1, rune(octet&0x7F) - case octet&0xE0 == 0xC0: - w, v = 2, rune(octet&0x1F) - case octet&0xF0 == 0xE0: - w, v = 3, rune(octet&0x0F) - case octet&0xF8 == 0xF0: - w, v = 4, rune(octet&0x07) - } - for k := 1; k < w; k++ { - octet = value[i+k] - v = (v << 6) + (rune(octet) & 0x3F) - } - i += w - - if !put(emitter, '\\') { - return false - } - - var ok bool - switch v { - case 0x00: - ok = put(emitter, '0') - case 0x07: - ok = put(emitter, 'a') - case 0x08: - ok = put(emitter, 'b') - case 0x09: - ok = put(emitter, 't') - case 0x0A: - ok = put(emitter, 'n') - case 0x0b: - ok = put(emitter, 'v') - case 0x0c: - ok = put(emitter, 'f') - case 0x0d: - ok = put(emitter, 'r') - case 0x1b: - ok = put(emitter, 'e') - case 0x22: - ok = put(emitter, '"') - case 0x5c: - ok = put(emitter, '\\') - case 0x85: - ok = put(emitter, 'N') - case 0xA0: - ok = put(emitter, '_') - case 0x2028: - ok = put(emitter, 'L') - case 0x2029: - ok = put(emitter, 'P') - default: - if v <= 0xFF { - ok = put(emitter, 'x') - w = 2 - } else if v <= 0xFFFF { - ok = put(emitter, 'u') - w = 4 - } else { - ok = put(emitter, 'U') - w = 8 - } - for k := (w - 1) * 4; ok && k >= 0; k -= 4 { - digit := byte((v >> uint(k)) & 0x0F) - if digit < 10 { - ok = put(emitter, digit+'0') - } else { - ok = put(emitter, digit+'A'-10) - } - } - } - if !ok { - return false - } - spaces = false - } else if is_space(value, i) { - if allow_breaks && !spaces && emitter.column > emitter.best_width && i > 0 && i < len(value)-1 { - if !yaml_emitter_write_indent(emitter) { - return false - } - if is_space(value, i+1) { - if !put(emitter, '\\') { - return false - } - } - i += width(value[i]) - } else if !write(emitter, value, &i) { - return false - } - spaces = true - } else { - if !write(emitter, value, &i) { - return false - } - spaces = false - } - } - if !yaml_emitter_write_indicator(emitter, []byte{'"'}, false, false, false) { - return false - } - emitter.whitespace = false - emitter.indention = false - return true -} - -func yaml_emitter_write_block_scalar_hints(emitter *yaml_emitter_t, value []byte) bool { - if is_space(value, 0) || is_break(value, 0) { - indent_hint := []byte{'0' + byte(emitter.best_indent)} - if !yaml_emitter_write_indicator(emitter, indent_hint, false, false, false) { - return false - } - } - - emitter.open_ended = false - - var chomp_hint [1]byte - if len(value) == 0 { - chomp_hint[0] = '-' - } else { - i := len(value) - 1 - for value[i]&0xC0 == 0x80 { - i-- - } - if !is_break(value, i) { - chomp_hint[0] = '-' - } else if i == 0 { - chomp_hint[0] = '+' - emitter.open_ended = true - } else { - i-- - for value[i]&0xC0 == 0x80 { - i-- - } - if is_break(value, i) { - chomp_hint[0] = '+' - emitter.open_ended = true - } - } - } - if chomp_hint[0] != 0 { - if !yaml_emitter_write_indicator(emitter, chomp_hint[:], false, false, false) { - return false - } - } - return true -} - -func yaml_emitter_write_literal_scalar(emitter *yaml_emitter_t, value []byte) bool { - if !yaml_emitter_write_indicator(emitter, []byte{'|'}, true, false, false) { - return false - } - if !yaml_emitter_write_block_scalar_hints(emitter, value) { - return false - } - if !put_break(emitter) { - return false - } - emitter.indention = true - emitter.whitespace = true - breaks := true - for i := 0; i < len(value); { - if is_break(value, i) { - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - } - if !write(emitter, value, &i) { - return false - } - emitter.indention = false - breaks = false - } - } - - return true -} - -func yaml_emitter_write_folded_scalar(emitter *yaml_emitter_t, value []byte) bool { - if !yaml_emitter_write_indicator(emitter, []byte{'>'}, true, false, false) { - return false - } - if !yaml_emitter_write_block_scalar_hints(emitter, value) { - return false - } - - if !put_break(emitter) { - return false - } - emitter.indention = true - emitter.whitespace = true - - breaks := true - leading_spaces := true - for i := 0; i < len(value); { - if is_break(value, i) { - if !breaks && !leading_spaces && value[i] == '\n' { - k := 0 - for is_break(value, k) { - k += width(value[k]) - } - if !is_blankz(value, k) { - if !put_break(emitter) { - return false - } - } - } - if !write_break(emitter, value, &i) { - return false - } - emitter.indention = true - breaks = true - } else { - if breaks { - if !yaml_emitter_write_indent(emitter) { - return false - } - leading_spaces = is_blank(value, i) - } - if !breaks && is_space(value, i) && !is_space(value, i+1) && emitter.column > emitter.best_width { - if !yaml_emitter_write_indent(emitter) { - return false - } - i += width(value[i]) - } else { - if !write(emitter, value, &i) { - return false - } - } - emitter.indention = false - breaks = false - } - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/encode.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/encode.go deleted file mode 100644 index 84f8499..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/encode.go +++ /dev/null @@ -1,306 +0,0 @@ -package yaml - -import ( - "encoding" - "fmt" - "reflect" - "regexp" - "sort" - "strconv" - "strings" - "time" -) - -type encoder struct { - emitter yaml_emitter_t - event yaml_event_t - out []byte - flow bool -} - -func newEncoder() (e *encoder) { - e = &encoder{} - e.must(yaml_emitter_initialize(&e.emitter)) - yaml_emitter_set_output_string(&e.emitter, &e.out) - yaml_emitter_set_unicode(&e.emitter, true) - e.must(yaml_stream_start_event_initialize(&e.event, yaml_UTF8_ENCODING)) - e.emit() - e.must(yaml_document_start_event_initialize(&e.event, nil, nil, true)) - e.emit() - return e -} - -func (e *encoder) finish() { - e.must(yaml_document_end_event_initialize(&e.event, true)) - e.emit() - e.emitter.open_ended = false - e.must(yaml_stream_end_event_initialize(&e.event)) - e.emit() -} - -func (e *encoder) destroy() { - yaml_emitter_delete(&e.emitter) -} - -func (e *encoder) emit() { - // This will internally delete the e.event value. - if !yaml_emitter_emit(&e.emitter, &e.event) && e.event.typ != yaml_DOCUMENT_END_EVENT && e.event.typ != yaml_STREAM_END_EVENT { - e.must(false) - } -} - -func (e *encoder) must(ok bool) { - if !ok { - msg := e.emitter.problem - if msg == "" { - msg = "unknown problem generating YAML content" - } - failf("%s", msg) - } -} - -func (e *encoder) marshal(tag string, in reflect.Value) { - if !in.IsValid() { - e.nilv() - return - } - iface := in.Interface() - if m, ok := iface.(Marshaler); ok { - v, err := m.MarshalYAML() - if err != nil { - fail(err) - } - if v == nil { - e.nilv() - return - } - in = reflect.ValueOf(v) - } else if m, ok := iface.(encoding.TextMarshaler); ok { - text, err := m.MarshalText() - if err != nil { - fail(err) - } - in = reflect.ValueOf(string(text)) - } - switch in.Kind() { - case reflect.Interface: - if in.IsNil() { - e.nilv() - } else { - e.marshal(tag, in.Elem()) - } - case reflect.Map: - e.mapv(tag, in) - case reflect.Ptr: - if in.IsNil() { - e.nilv() - } else { - e.marshal(tag, in.Elem()) - } - case reflect.Struct: - e.structv(tag, in) - case reflect.Slice: - if in.Type().Elem() == mapItemType { - e.itemsv(tag, in) - } else { - e.slicev(tag, in) - } - case reflect.String: - e.stringv(tag, in) - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - if in.Type() == durationType { - e.stringv(tag, reflect.ValueOf(iface.(time.Duration).String())) - } else { - e.intv(tag, in) - } - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - e.uintv(tag, in) - case reflect.Float32, reflect.Float64: - e.floatv(tag, in) - case reflect.Bool: - e.boolv(tag, in) - default: - panic("cannot marshal type: " + in.Type().String()) - } -} - -func (e *encoder) mapv(tag string, in reflect.Value) { - e.mappingv(tag, func() { - keys := keyList(in.MapKeys()) - sort.Sort(keys) - for _, k := range keys { - e.marshal("", k) - e.marshal("", in.MapIndex(k)) - } - }) -} - -func (e *encoder) itemsv(tag string, in reflect.Value) { - e.mappingv(tag, func() { - slice := in.Convert(reflect.TypeOf([]MapItem{})).Interface().([]MapItem) - for _, item := range slice { - e.marshal("", reflect.ValueOf(item.Key)) - e.marshal("", reflect.ValueOf(item.Value)) - } - }) -} - -func (e *encoder) structv(tag string, in reflect.Value) { - sinfo, err := getStructInfo(in.Type()) - if err != nil { - panic(err) - } - e.mappingv(tag, func() { - for _, info := range sinfo.FieldsList { - var value reflect.Value - if info.Inline == nil { - value = in.Field(info.Num) - } else { - value = in.FieldByIndex(info.Inline) - } - if info.OmitEmpty && isZero(value) { - continue - } - e.marshal("", reflect.ValueOf(info.Key)) - e.flow = info.Flow - e.marshal("", value) - } - if sinfo.InlineMap >= 0 { - m := in.Field(sinfo.InlineMap) - if m.Len() > 0 { - e.flow = false - keys := keyList(m.MapKeys()) - sort.Sort(keys) - for _, k := range keys { - if _, found := sinfo.FieldsMap[k.String()]; found { - panic(fmt.Sprintf("Can't have key %q in inlined map; conflicts with struct field", k.String())) - } - e.marshal("", k) - e.flow = false - e.marshal("", m.MapIndex(k)) - } - } - } - }) -} - -func (e *encoder) mappingv(tag string, f func()) { - implicit := tag == "" - style := yaml_BLOCK_MAPPING_STYLE - if e.flow { - e.flow = false - style = yaml_FLOW_MAPPING_STYLE - } - e.must(yaml_mapping_start_event_initialize(&e.event, nil, []byte(tag), implicit, style)) - e.emit() - f() - e.must(yaml_mapping_end_event_initialize(&e.event)) - e.emit() -} - -func (e *encoder) slicev(tag string, in reflect.Value) { - implicit := tag == "" - style := yaml_BLOCK_SEQUENCE_STYLE - if e.flow { - e.flow = false - style = yaml_FLOW_SEQUENCE_STYLE - } - e.must(yaml_sequence_start_event_initialize(&e.event, nil, []byte(tag), implicit, style)) - e.emit() - n := in.Len() - for i := 0; i < n; i++ { - e.marshal("", in.Index(i)) - } - e.must(yaml_sequence_end_event_initialize(&e.event)) - e.emit() -} - -// isBase60 returns whether s is in base 60 notation as defined in YAML 1.1. -// -// The base 60 float notation in YAML 1.1 is a terrible idea and is unsupported -// in YAML 1.2 and by this package, but these should be marshalled quoted for -// the time being for compatibility with other parsers. -func isBase60Float(s string) (result bool) { - // Fast path. - if s == "" { - return false - } - c := s[0] - if !(c == '+' || c == '-' || c >= '0' && c <= '9') || strings.IndexByte(s, ':') < 0 { - return false - } - // Do the full match. - return base60float.MatchString(s) -} - -// From http://yaml.org/type/float.html, except the regular expression there -// is bogus. In practice parsers do not enforce the "\.[0-9_]*" suffix. -var base60float = regexp.MustCompile(`^[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+(?:\.[0-9_]*)?$`) - -func (e *encoder) stringv(tag string, in reflect.Value) { - var style yaml_scalar_style_t - s := in.String() - rtag, rs := resolve("", s) - if rtag == yaml_BINARY_TAG { - if tag == "" || tag == yaml_STR_TAG { - tag = rtag - s = rs.(string) - } else if tag == yaml_BINARY_TAG { - failf("explicitly tagged !!binary data must be base64-encoded") - } else { - failf("cannot marshal invalid UTF-8 data as %s", shortTag(tag)) - } - } - if tag == "" && (rtag != yaml_STR_TAG || isBase60Float(s)) { - style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } else if strings.Contains(s, "\n") { - style = yaml_LITERAL_SCALAR_STYLE - } else { - style = yaml_PLAIN_SCALAR_STYLE - } - e.emitScalar(s, "", tag, style) -} - -func (e *encoder) boolv(tag string, in reflect.Value) { - var s string - if in.Bool() { - s = "true" - } else { - s = "false" - } - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *encoder) intv(tag string, in reflect.Value) { - s := strconv.FormatInt(in.Int(), 10) - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *encoder) uintv(tag string, in reflect.Value) { - s := strconv.FormatUint(in.Uint(), 10) - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *encoder) floatv(tag string, in reflect.Value) { - // FIXME: Handle 64 bits here. - s := strconv.FormatFloat(float64(in.Float()), 'g', -1, 32) - switch s { - case "+Inf": - s = ".inf" - case "-Inf": - s = "-.inf" - case "NaN": - s = ".nan" - } - e.emitScalar(s, "", tag, yaml_PLAIN_SCALAR_STYLE) -} - -func (e *encoder) nilv() { - e.emitScalar("null", "", "", yaml_PLAIN_SCALAR_STYLE) -} - -func (e *encoder) emitScalar(value, anchor, tag string, style yaml_scalar_style_t) { - implicit := tag == "" - e.must(yaml_scalar_event_initialize(&e.event, []byte(anchor), []byte(tag), []byte(value), implicit, implicit, style)) - e.emit() -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/parserc.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/parserc.go deleted file mode 100644 index 0a7037a..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/parserc.go +++ /dev/null @@ -1,1096 +0,0 @@ -package yaml - -import ( - "bytes" -) - -// The parser implements the following grammar: -// -// stream ::= STREAM-START implicit_document? explicit_document* STREAM-END -// implicit_document ::= block_node DOCUMENT-END* -// explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* -// block_node_or_indentless_sequence ::= -// ALIAS -// | properties (block_content | indentless_block_sequence)? -// | block_content -// | indentless_block_sequence -// block_node ::= ALIAS -// | properties block_content? -// | block_content -// flow_node ::= ALIAS -// | properties flow_content? -// | flow_content -// properties ::= TAG ANCHOR? | ANCHOR TAG? -// block_content ::= block_collection | flow_collection | SCALAR -// flow_content ::= flow_collection | SCALAR -// block_collection ::= block_sequence | block_mapping -// flow_collection ::= flow_sequence | flow_mapping -// block_sequence ::= BLOCK-SEQUENCE-START (BLOCK-ENTRY block_node?)* BLOCK-END -// indentless_sequence ::= (BLOCK-ENTRY block_node?)+ -// block_mapping ::= BLOCK-MAPPING_START -// ((KEY block_node_or_indentless_sequence?)? -// (VALUE block_node_or_indentless_sequence?)?)* -// BLOCK-END -// flow_sequence ::= FLOW-SEQUENCE-START -// (flow_sequence_entry FLOW-ENTRY)* -// flow_sequence_entry? -// FLOW-SEQUENCE-END -// flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// flow_mapping ::= FLOW-MAPPING-START -// (flow_mapping_entry FLOW-ENTRY)* -// flow_mapping_entry? -// FLOW-MAPPING-END -// flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? - -// Peek the next token in the token queue. -func peek_token(parser *yaml_parser_t) *yaml_token_t { - if parser.token_available || yaml_parser_fetch_more_tokens(parser) { - return &parser.tokens[parser.tokens_head] - } - return nil -} - -// Remove the next token from the queue (must be called after peek_token). -func skip_token(parser *yaml_parser_t) { - parser.token_available = false - parser.tokens_parsed++ - parser.stream_end_produced = parser.tokens[parser.tokens_head].typ == yaml_STREAM_END_TOKEN - parser.tokens_head++ -} - -// Get the next event. -func yaml_parser_parse(parser *yaml_parser_t, event *yaml_event_t) bool { - // Erase the event object. - *event = yaml_event_t{} - - // No events after the end of the stream or error. - if parser.stream_end_produced || parser.error != yaml_NO_ERROR || parser.state == yaml_PARSE_END_STATE { - return true - } - - // Generate the next event. - return yaml_parser_state_machine(parser, event) -} - -// Set parser error. -func yaml_parser_set_parser_error(parser *yaml_parser_t, problem string, problem_mark yaml_mark_t) bool { - parser.error = yaml_PARSER_ERROR - parser.problem = problem - parser.problem_mark = problem_mark - return false -} - -func yaml_parser_set_parser_error_context(parser *yaml_parser_t, context string, context_mark yaml_mark_t, problem string, problem_mark yaml_mark_t) bool { - parser.error = yaml_PARSER_ERROR - parser.context = context - parser.context_mark = context_mark - parser.problem = problem - parser.problem_mark = problem_mark - return false -} - -// State dispatcher. -func yaml_parser_state_machine(parser *yaml_parser_t, event *yaml_event_t) bool { - //trace("yaml_parser_state_machine", "state:", parser.state.String()) - - switch parser.state { - case yaml_PARSE_STREAM_START_STATE: - return yaml_parser_parse_stream_start(parser, event) - - case yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE: - return yaml_parser_parse_document_start(parser, event, true) - - case yaml_PARSE_DOCUMENT_START_STATE: - return yaml_parser_parse_document_start(parser, event, false) - - case yaml_PARSE_DOCUMENT_CONTENT_STATE: - return yaml_parser_parse_document_content(parser, event) - - case yaml_PARSE_DOCUMENT_END_STATE: - return yaml_parser_parse_document_end(parser, event) - - case yaml_PARSE_BLOCK_NODE_STATE: - return yaml_parser_parse_node(parser, event, true, false) - - case yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE: - return yaml_parser_parse_node(parser, event, true, true) - - case yaml_PARSE_FLOW_NODE_STATE: - return yaml_parser_parse_node(parser, event, false, false) - - case yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE: - return yaml_parser_parse_block_sequence_entry(parser, event, true) - - case yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_block_sequence_entry(parser, event, false) - - case yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_indentless_sequence_entry(parser, event) - - case yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE: - return yaml_parser_parse_block_mapping_key(parser, event, true) - - case yaml_PARSE_BLOCK_MAPPING_KEY_STATE: - return yaml_parser_parse_block_mapping_key(parser, event, false) - - case yaml_PARSE_BLOCK_MAPPING_VALUE_STATE: - return yaml_parser_parse_block_mapping_value(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE: - return yaml_parser_parse_flow_sequence_entry(parser, event, true) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE: - return yaml_parser_parse_flow_sequence_entry(parser, event, false) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_key(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_value(parser, event) - - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE: - return yaml_parser_parse_flow_sequence_entry_mapping_end(parser, event) - - case yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE: - return yaml_parser_parse_flow_mapping_key(parser, event, true) - - case yaml_PARSE_FLOW_MAPPING_KEY_STATE: - return yaml_parser_parse_flow_mapping_key(parser, event, false) - - case yaml_PARSE_FLOW_MAPPING_VALUE_STATE: - return yaml_parser_parse_flow_mapping_value(parser, event, false) - - case yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE: - return yaml_parser_parse_flow_mapping_value(parser, event, true) - - default: - panic("invalid parser state") - } - return false -} - -// Parse the production: -// stream ::= STREAM-START implicit_document? explicit_document* STREAM-END -// ************ -func yaml_parser_parse_stream_start(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_STREAM_START_TOKEN { - return yaml_parser_set_parser_error(parser, "did not find expected <stream-start>", token.start_mark) - } - parser.state = yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE - *event = yaml_event_t{ - typ: yaml_STREAM_START_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - encoding: token.encoding, - } - skip_token(parser) - return true -} - -// Parse the productions: -// implicit_document ::= block_node DOCUMENT-END* -// * -// explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* -// ************************* -func yaml_parser_parse_document_start(parser *yaml_parser_t, event *yaml_event_t, implicit bool) bool { - - token := peek_token(parser) - if token == nil { - return false - } - - // Parse extra document end indicators. - if !implicit { - for token.typ == yaml_DOCUMENT_END_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - } - - if implicit && token.typ != yaml_VERSION_DIRECTIVE_TOKEN && - token.typ != yaml_TAG_DIRECTIVE_TOKEN && - token.typ != yaml_DOCUMENT_START_TOKEN && - token.typ != yaml_STREAM_END_TOKEN { - // Parse an implicit document. - if !yaml_parser_process_directives(parser, nil, nil) { - return false - } - parser.states = append(parser.states, yaml_PARSE_DOCUMENT_END_STATE) - parser.state = yaml_PARSE_BLOCK_NODE_STATE - - *event = yaml_event_t{ - typ: yaml_DOCUMENT_START_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - } else if token.typ != yaml_STREAM_END_TOKEN { - // Parse an explicit document. - var version_directive *yaml_version_directive_t - var tag_directives []yaml_tag_directive_t - start_mark := token.start_mark - if !yaml_parser_process_directives(parser, &version_directive, &tag_directives) { - return false - } - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_DOCUMENT_START_TOKEN { - yaml_parser_set_parser_error(parser, - "did not find expected <document start>", token.start_mark) - return false - } - parser.states = append(parser.states, yaml_PARSE_DOCUMENT_END_STATE) - parser.state = yaml_PARSE_DOCUMENT_CONTENT_STATE - end_mark := token.end_mark - - *event = yaml_event_t{ - typ: yaml_DOCUMENT_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - version_directive: version_directive, - tag_directives: tag_directives, - implicit: false, - } - skip_token(parser) - - } else { - // Parse the stream end. - parser.state = yaml_PARSE_END_STATE - *event = yaml_event_t{ - typ: yaml_STREAM_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - skip_token(parser) - } - - return true -} - -// Parse the productions: -// explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* -// *********** -// -func yaml_parser_parse_document_content(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - if token.typ == yaml_VERSION_DIRECTIVE_TOKEN || - token.typ == yaml_TAG_DIRECTIVE_TOKEN || - token.typ == yaml_DOCUMENT_START_TOKEN || - token.typ == yaml_DOCUMENT_END_TOKEN || - token.typ == yaml_STREAM_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - return yaml_parser_process_empty_scalar(parser, event, - token.start_mark) - } - return yaml_parser_parse_node(parser, event, true, false) -} - -// Parse the productions: -// implicit_document ::= block_node DOCUMENT-END* -// ************* -// explicit_document ::= DIRECTIVE* DOCUMENT-START block_node? DOCUMENT-END* -// -func yaml_parser_parse_document_end(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - start_mark := token.start_mark - end_mark := token.start_mark - - implicit := true - if token.typ == yaml_DOCUMENT_END_TOKEN { - end_mark = token.end_mark - skip_token(parser) - implicit = false - } - - parser.tag_directives = parser.tag_directives[:0] - - parser.state = yaml_PARSE_DOCUMENT_START_STATE - *event = yaml_event_t{ - typ: yaml_DOCUMENT_END_EVENT, - start_mark: start_mark, - end_mark: end_mark, - implicit: implicit, - } - return true -} - -// Parse the productions: -// block_node_or_indentless_sequence ::= -// ALIAS -// ***** -// | properties (block_content | indentless_block_sequence)? -// ********** * -// | block_content | indentless_block_sequence -// * -// block_node ::= ALIAS -// ***** -// | properties block_content? -// ********** * -// | block_content -// * -// flow_node ::= ALIAS -// ***** -// | properties flow_content? -// ********** * -// | flow_content -// * -// properties ::= TAG ANCHOR? | ANCHOR TAG? -// ************************* -// block_content ::= block_collection | flow_collection | SCALAR -// ****** -// flow_content ::= flow_collection | SCALAR -// ****** -func yaml_parser_parse_node(parser *yaml_parser_t, event *yaml_event_t, block, indentless_sequence bool) bool { - //defer trace("yaml_parser_parse_node", "block:", block, "indentless_sequence:", indentless_sequence)() - - token := peek_token(parser) - if token == nil { - return false - } - - if token.typ == yaml_ALIAS_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - *event = yaml_event_t{ - typ: yaml_ALIAS_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - anchor: token.value, - } - skip_token(parser) - return true - } - - start_mark := token.start_mark - end_mark := token.start_mark - - var tag_token bool - var tag_handle, tag_suffix, anchor []byte - var tag_mark yaml_mark_t - if token.typ == yaml_ANCHOR_TOKEN { - anchor = token.value - start_mark = token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ == yaml_TAG_TOKEN { - tag_token = true - tag_handle = token.value - tag_suffix = token.suffix - tag_mark = token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - } else if token.typ == yaml_TAG_TOKEN { - tag_token = true - tag_handle = token.value - tag_suffix = token.suffix - start_mark = token.start_mark - tag_mark = token.start_mark - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ == yaml_ANCHOR_TOKEN { - anchor = token.value - end_mark = token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - } - - var tag []byte - if tag_token { - if len(tag_handle) == 0 { - tag = tag_suffix - tag_suffix = nil - } else { - for i := range parser.tag_directives { - if bytes.Equal(parser.tag_directives[i].handle, tag_handle) { - tag = append([]byte(nil), parser.tag_directives[i].prefix...) - tag = append(tag, tag_suffix...) - break - } - } - if len(tag) == 0 { - yaml_parser_set_parser_error_context(parser, - "while parsing a node", start_mark, - "found undefined tag handle", tag_mark) - return false - } - } - } - - implicit := len(tag) == 0 - if indentless_sequence && token.typ == yaml_BLOCK_ENTRY_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE - *event = yaml_event_t{ - typ: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_SEQUENCE_STYLE), - } - return true - } - if token.typ == yaml_SCALAR_TOKEN { - var plain_implicit, quoted_implicit bool - end_mark = token.end_mark - if (len(tag) == 0 && token.style == yaml_PLAIN_SCALAR_STYLE) || (len(tag) == 1 && tag[0] == '!') { - plain_implicit = true - } else if len(tag) == 0 { - quoted_implicit = true - } - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - typ: yaml_SCALAR_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - value: token.value, - implicit: plain_implicit, - quoted_implicit: quoted_implicit, - style: yaml_style_t(token.style), - } - skip_token(parser) - return true - } - if token.typ == yaml_FLOW_SEQUENCE_START_TOKEN { - // [Go] Some of the events below can be merged as they differ only on style. - end_mark = token.end_mark - parser.state = yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE - *event = yaml_event_t{ - typ: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_FLOW_SEQUENCE_STYLE), - } - return true - } - if token.typ == yaml_FLOW_MAPPING_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE - *event = yaml_event_t{ - typ: yaml_MAPPING_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_FLOW_MAPPING_STYLE), - } - return true - } - if block && token.typ == yaml_BLOCK_SEQUENCE_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE - *event = yaml_event_t{ - typ: yaml_SEQUENCE_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_SEQUENCE_STYLE), - } - return true - } - if block && token.typ == yaml_BLOCK_MAPPING_START_TOKEN { - end_mark = token.end_mark - parser.state = yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE - *event = yaml_event_t{ - typ: yaml_MAPPING_START_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - style: yaml_style_t(yaml_BLOCK_MAPPING_STYLE), - } - return true - } - if len(anchor) > 0 || len(tag) > 0 { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - typ: yaml_SCALAR_EVENT, - start_mark: start_mark, - end_mark: end_mark, - anchor: anchor, - tag: tag, - implicit: implicit, - quoted_implicit: false, - style: yaml_style_t(yaml_PLAIN_SCALAR_STYLE), - } - return true - } - - context := "while parsing a flow node" - if block { - context = "while parsing a block node" - } - yaml_parser_set_parser_error_context(parser, context, start_mark, - "did not find expected node content", token.start_mark) - return false -} - -// Parse the productions: -// block_sequence ::= BLOCK-SEQUENCE-START (BLOCK-ENTRY block_node?)* BLOCK-END -// ******************** *********** * ********* -// -func yaml_parser_parse_block_sequence_entry(parser *yaml_parser_t, event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.typ == yaml_BLOCK_ENTRY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_BLOCK_ENTRY_TOKEN && token.typ != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, true, false) - } else { - parser.state = yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } - if token.typ == yaml_BLOCK_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - *event = yaml_event_t{ - typ: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - skip_token(parser) - return true - } - - context_mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - return yaml_parser_set_parser_error_context(parser, - "while parsing a block collection", context_mark, - "did not find expected '-' indicator", token.start_mark) -} - -// Parse the productions: -// indentless_sequence ::= (BLOCK-ENTRY block_node?)+ -// *********** * -func yaml_parser_parse_indentless_sequence_entry(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - - if token.typ == yaml_BLOCK_ENTRY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_BLOCK_ENTRY_TOKEN && - token.typ != yaml_KEY_TOKEN && - token.typ != yaml_VALUE_TOKEN && - token.typ != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, true, false) - } - parser.state = yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - - *event = yaml_event_t{ - typ: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.start_mark, // [Go] Shouldn't this be token.end_mark? - } - return true -} - -// Parse the productions: -// block_mapping ::= BLOCK-MAPPING_START -// ******************* -// ((KEY block_node_or_indentless_sequence?)? -// *** * -// (VALUE block_node_or_indentless_sequence?)?)* -// -// BLOCK-END -// ********* -// -func yaml_parser_parse_block_mapping_key(parser *yaml_parser_t, event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.typ == yaml_KEY_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_KEY_TOKEN && - token.typ != yaml_VALUE_TOKEN && - token.typ != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, true, true) - } else { - parser.state = yaml_PARSE_BLOCK_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - } else if token.typ == yaml_BLOCK_END_TOKEN { - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - *event = yaml_event_t{ - typ: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - skip_token(parser) - return true - } - - context_mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - return yaml_parser_set_parser_error_context(parser, - "while parsing a block mapping", context_mark, - "did not find expected key", token.start_mark) -} - -// Parse the productions: -// block_mapping ::= BLOCK-MAPPING_START -// -// ((KEY block_node_or_indentless_sequence?)? -// -// (VALUE block_node_or_indentless_sequence?)?)* -// ***** * -// BLOCK-END -// -// -func yaml_parser_parse_block_mapping_value(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - if token.typ == yaml_VALUE_TOKEN { - mark := token.end_mark - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_KEY_TOKEN && - token.typ != yaml_VALUE_TOKEN && - token.typ != yaml_BLOCK_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_BLOCK_MAPPING_KEY_STATE) - return yaml_parser_parse_node(parser, event, true, true) - } - parser.state = yaml_PARSE_BLOCK_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) - } - parser.state = yaml_PARSE_BLOCK_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) -} - -// Parse the productions: -// flow_sequence ::= FLOW-SEQUENCE-START -// ******************* -// (flow_sequence_entry FLOW-ENTRY)* -// * ********** -// flow_sequence_entry? -// * -// FLOW-SEQUENCE-END -// ***************** -// flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// * -// -func yaml_parser_parse_flow_sequence_entry(parser *yaml_parser_t, event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - token := peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_FLOW_SEQUENCE_END_TOKEN { - if !first { - if token.typ == yaml_FLOW_ENTRY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } else { - context_mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - return yaml_parser_set_parser_error_context(parser, - "while parsing a flow sequence", context_mark, - "did not find expected ',' or ']'", token.start_mark) - } - } - - if token.typ == yaml_KEY_TOKEN { - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE - *event = yaml_event_t{ - typ: yaml_MAPPING_START_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - implicit: true, - style: yaml_style_t(yaml_FLOW_MAPPING_STYLE), - } - skip_token(parser) - return true - } else if token.typ != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - - *event = yaml_event_t{ - typ: yaml_SEQUENCE_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - - skip_token(parser) - return true -} - -// -// Parse the productions: -// flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// *** * -// -func yaml_parser_parse_flow_sequence_entry_mapping_key(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_VALUE_TOKEN && - token.typ != yaml_FLOW_ENTRY_TOKEN && - token.typ != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - mark := token.end_mark - skip_token(parser) - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, mark) -} - -// Parse the productions: -// flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// ***** * -// -func yaml_parser_parse_flow_sequence_entry_mapping_value(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - if token.typ == yaml_VALUE_TOKEN { - skip_token(parser) - token := peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_FLOW_ENTRY_TOKEN && token.typ != yaml_FLOW_SEQUENCE_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) -} - -// Parse the productions: -// flow_sequence_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// * -// -func yaml_parser_parse_flow_sequence_entry_mapping_end(parser *yaml_parser_t, event *yaml_event_t) bool { - token := peek_token(parser) - if token == nil { - return false - } - parser.state = yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE - *event = yaml_event_t{ - typ: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.start_mark, // [Go] Shouldn't this be end_mark? - } - return true -} - -// Parse the productions: -// flow_mapping ::= FLOW-MAPPING-START -// ****************** -// (flow_mapping_entry FLOW-ENTRY)* -// * ********** -// flow_mapping_entry? -// ****************** -// FLOW-MAPPING-END -// **************** -// flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// * *** * -// -func yaml_parser_parse_flow_mapping_key(parser *yaml_parser_t, event *yaml_event_t, first bool) bool { - if first { - token := peek_token(parser) - parser.marks = append(parser.marks, token.start_mark) - skip_token(parser) - } - - token := peek_token(parser) - if token == nil { - return false - } - - if token.typ != yaml_FLOW_MAPPING_END_TOKEN { - if !first { - if token.typ == yaml_FLOW_ENTRY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } else { - context_mark := parser.marks[len(parser.marks)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - return yaml_parser_set_parser_error_context(parser, - "while parsing a flow mapping", context_mark, - "did not find expected ',' or '}'", token.start_mark) - } - } - - if token.typ == yaml_KEY_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_VALUE_TOKEN && - token.typ != yaml_FLOW_ENTRY_TOKEN && - token.typ != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } else { - parser.state = yaml_PARSE_FLOW_MAPPING_VALUE_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) - } - } else if token.typ != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - - parser.state = parser.states[len(parser.states)-1] - parser.states = parser.states[:len(parser.states)-1] - parser.marks = parser.marks[:len(parser.marks)-1] - *event = yaml_event_t{ - typ: yaml_MAPPING_END_EVENT, - start_mark: token.start_mark, - end_mark: token.end_mark, - } - skip_token(parser) - return true -} - -// Parse the productions: -// flow_mapping_entry ::= flow_node | KEY flow_node? (VALUE flow_node?)? -// * ***** * -// -func yaml_parser_parse_flow_mapping_value(parser *yaml_parser_t, event *yaml_event_t, empty bool) bool { - token := peek_token(parser) - if token == nil { - return false - } - if empty { - parser.state = yaml_PARSE_FLOW_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) - } - if token.typ == yaml_VALUE_TOKEN { - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - if token.typ != yaml_FLOW_ENTRY_TOKEN && token.typ != yaml_FLOW_MAPPING_END_TOKEN { - parser.states = append(parser.states, yaml_PARSE_FLOW_MAPPING_KEY_STATE) - return yaml_parser_parse_node(parser, event, false, false) - } - } - parser.state = yaml_PARSE_FLOW_MAPPING_KEY_STATE - return yaml_parser_process_empty_scalar(parser, event, token.start_mark) -} - -// Generate an empty scalar event. -func yaml_parser_process_empty_scalar(parser *yaml_parser_t, event *yaml_event_t, mark yaml_mark_t) bool { - *event = yaml_event_t{ - typ: yaml_SCALAR_EVENT, - start_mark: mark, - end_mark: mark, - value: nil, // Empty - implicit: true, - style: yaml_style_t(yaml_PLAIN_SCALAR_STYLE), - } - return true -} - -var default_tag_directives = []yaml_tag_directive_t{ - {[]byte("!"), []byte("!")}, - {[]byte("!!"), []byte("tag:yaml.org,2002:")}, -} - -// Parse directives. -func yaml_parser_process_directives(parser *yaml_parser_t, - version_directive_ref **yaml_version_directive_t, - tag_directives_ref *[]yaml_tag_directive_t) bool { - - var version_directive *yaml_version_directive_t - var tag_directives []yaml_tag_directive_t - - token := peek_token(parser) - if token == nil { - return false - } - - for token.typ == yaml_VERSION_DIRECTIVE_TOKEN || token.typ == yaml_TAG_DIRECTIVE_TOKEN { - if token.typ == yaml_VERSION_DIRECTIVE_TOKEN { - if version_directive != nil { - yaml_parser_set_parser_error(parser, - "found duplicate %YAML directive", token.start_mark) - return false - } - if token.major != 1 || token.minor != 1 { - yaml_parser_set_parser_error(parser, - "found incompatible YAML document", token.start_mark) - return false - } - version_directive = &yaml_version_directive_t{ - major: token.major, - minor: token.minor, - } - } else if token.typ == yaml_TAG_DIRECTIVE_TOKEN { - value := yaml_tag_directive_t{ - handle: token.value, - prefix: token.prefix, - } - if !yaml_parser_append_tag_directive(parser, value, false, token.start_mark) { - return false - } - tag_directives = append(tag_directives, value) - } - - skip_token(parser) - token = peek_token(parser) - if token == nil { - return false - } - } - - for i := range default_tag_directives { - if !yaml_parser_append_tag_directive(parser, default_tag_directives[i], true, token.start_mark) { - return false - } - } - - if version_directive_ref != nil { - *version_directive_ref = version_directive - } - if tag_directives_ref != nil { - *tag_directives_ref = tag_directives - } - return true -} - -// Append a tag directive to the directives stack. -func yaml_parser_append_tag_directive(parser *yaml_parser_t, value yaml_tag_directive_t, allow_duplicates bool, mark yaml_mark_t) bool { - for i := range parser.tag_directives { - if bytes.Equal(value.handle, parser.tag_directives[i].handle) { - if allow_duplicates { - return true - } - return yaml_parser_set_parser_error(parser, "found duplicate %TAG directive", mark) - } - } - - // [Go] I suspect the copy is unnecessary. This was likely done - // because there was no way to track ownership of the data. - value_copy := yaml_tag_directive_t{ - handle: make([]byte, len(value.handle)), - prefix: make([]byte, len(value.prefix)), - } - copy(value_copy.handle, value.handle) - copy(value_copy.prefix, value.prefix) - parser.tag_directives = append(parser.tag_directives, value_copy) - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/readerc.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/readerc.go deleted file mode 100644 index d5fb097..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/readerc.go +++ /dev/null @@ -1,391 +0,0 @@ -package yaml - -import ( - "io" -) - -// Set the reader error and return 0. -func yaml_parser_set_reader_error(parser *yaml_parser_t, problem string, offset int, value int) bool { - parser.error = yaml_READER_ERROR - parser.problem = problem - parser.problem_offset = offset - parser.problem_value = value - return false -} - -// Byte order marks. -const ( - bom_UTF8 = "\xef\xbb\xbf" - bom_UTF16LE = "\xff\xfe" - bom_UTF16BE = "\xfe\xff" -) - -// Determine the input stream encoding by checking the BOM symbol. If no BOM is -// found, the UTF-8 encoding is assumed. Return 1 on success, 0 on failure. -func yaml_parser_determine_encoding(parser *yaml_parser_t) bool { - // Ensure that we had enough bytes in the raw buffer. - for !parser.eof && len(parser.raw_buffer)-parser.raw_buffer_pos < 3 { - if !yaml_parser_update_raw_buffer(parser) { - return false - } - } - - // Determine the encoding. - buf := parser.raw_buffer - pos := parser.raw_buffer_pos - avail := len(buf) - pos - if avail >= 2 && buf[pos] == bom_UTF16LE[0] && buf[pos+1] == bom_UTF16LE[1] { - parser.encoding = yaml_UTF16LE_ENCODING - parser.raw_buffer_pos += 2 - parser.offset += 2 - } else if avail >= 2 && buf[pos] == bom_UTF16BE[0] && buf[pos+1] == bom_UTF16BE[1] { - parser.encoding = yaml_UTF16BE_ENCODING - parser.raw_buffer_pos += 2 - parser.offset += 2 - } else if avail >= 3 && buf[pos] == bom_UTF8[0] && buf[pos+1] == bom_UTF8[1] && buf[pos+2] == bom_UTF8[2] { - parser.encoding = yaml_UTF8_ENCODING - parser.raw_buffer_pos += 3 - parser.offset += 3 - } else { - parser.encoding = yaml_UTF8_ENCODING - } - return true -} - -// Update the raw buffer. -func yaml_parser_update_raw_buffer(parser *yaml_parser_t) bool { - size_read := 0 - - // Return if the raw buffer is full. - if parser.raw_buffer_pos == 0 && len(parser.raw_buffer) == cap(parser.raw_buffer) { - return true - } - - // Return on EOF. - if parser.eof { - return true - } - - // Move the remaining bytes in the raw buffer to the beginning. - if parser.raw_buffer_pos > 0 && parser.raw_buffer_pos < len(parser.raw_buffer) { - copy(parser.raw_buffer, parser.raw_buffer[parser.raw_buffer_pos:]) - } - parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)-parser.raw_buffer_pos] - parser.raw_buffer_pos = 0 - - // Call the read handler to fill the buffer. - size_read, err := parser.read_handler(parser, parser.raw_buffer[len(parser.raw_buffer):cap(parser.raw_buffer)]) - parser.raw_buffer = parser.raw_buffer[:len(parser.raw_buffer)+size_read] - if err == io.EOF { - parser.eof = true - } else if err != nil { - return yaml_parser_set_reader_error(parser, "input error: "+err.Error(), parser.offset, -1) - } - return true -} - -// Ensure that the buffer contains at least `length` characters. -// Return true on success, false on failure. -// -// The length is supposed to be significantly less that the buffer size. -func yaml_parser_update_buffer(parser *yaml_parser_t, length int) bool { - if parser.read_handler == nil { - panic("read handler must be set") - } - - // If the EOF flag is set and the raw buffer is empty, do nothing. - if parser.eof && parser.raw_buffer_pos == len(parser.raw_buffer) { - return true - } - - // Return if the buffer contains enough characters. - if parser.unread >= length { - return true - } - - // Determine the input encoding if it is not known yet. - if parser.encoding == yaml_ANY_ENCODING { - if !yaml_parser_determine_encoding(parser) { - return false - } - } - - // Move the unread characters to the beginning of the buffer. - buffer_len := len(parser.buffer) - if parser.buffer_pos > 0 && parser.buffer_pos < buffer_len { - copy(parser.buffer, parser.buffer[parser.buffer_pos:]) - buffer_len -= parser.buffer_pos - parser.buffer_pos = 0 - } else if parser.buffer_pos == buffer_len { - buffer_len = 0 - parser.buffer_pos = 0 - } - - // Open the whole buffer for writing, and cut it before returning. - parser.buffer = parser.buffer[:cap(parser.buffer)] - - // Fill the buffer until it has enough characters. - first := true - for parser.unread < length { - - // Fill the raw buffer if necessary. - if !first || parser.raw_buffer_pos == len(parser.raw_buffer) { - if !yaml_parser_update_raw_buffer(parser) { - parser.buffer = parser.buffer[:buffer_len] - return false - } - } - first = false - - // Decode the raw buffer. - inner: - for parser.raw_buffer_pos != len(parser.raw_buffer) { - var value rune - var width int - - raw_unread := len(parser.raw_buffer) - parser.raw_buffer_pos - - // Decode the next character. - switch parser.encoding { - case yaml_UTF8_ENCODING: - // Decode a UTF-8 character. Check RFC 3629 - // (http://www.ietf.org/rfc/rfc3629.txt) for more details. - // - // The following table (taken from the RFC) is used for - // decoding. - // - // Char. number range | UTF-8 octet sequence - // (hexadecimal) | (binary) - // --------------------+------------------------------------ - // 0000 0000-0000 007F | 0xxxxxxx - // 0000 0080-0000 07FF | 110xxxxx 10xxxxxx - // 0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx - // 0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx - // - // Additionally, the characters in the range 0xD800-0xDFFF - // are prohibited as they are reserved for use with UTF-16 - // surrogate pairs. - - // Determine the length of the UTF-8 sequence. - octet := parser.raw_buffer[parser.raw_buffer_pos] - switch { - case octet&0x80 == 0x00: - width = 1 - case octet&0xE0 == 0xC0: - width = 2 - case octet&0xF0 == 0xE0: - width = 3 - case octet&0xF8 == 0xF0: - width = 4 - default: - // The leading octet is invalid. - return yaml_parser_set_reader_error(parser, - "invalid leading UTF-8 octet", - parser.offset, int(octet)) - } - - // Check if the raw buffer contains an incomplete character. - if width > raw_unread { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-8 octet sequence", - parser.offset, -1) - } - break inner - } - - // Decode the leading octet. - switch { - case octet&0x80 == 0x00: - value = rune(octet & 0x7F) - case octet&0xE0 == 0xC0: - value = rune(octet & 0x1F) - case octet&0xF0 == 0xE0: - value = rune(octet & 0x0F) - case octet&0xF8 == 0xF0: - value = rune(octet & 0x07) - default: - value = 0 - } - - // Check and decode the trailing octets. - for k := 1; k < width; k++ { - octet = parser.raw_buffer[parser.raw_buffer_pos+k] - - // Check if the octet is valid. - if (octet & 0xC0) != 0x80 { - return yaml_parser_set_reader_error(parser, - "invalid trailing UTF-8 octet", - parser.offset+k, int(octet)) - } - - // Decode the octet. - value = (value << 6) + rune(octet&0x3F) - } - - // Check the length of the sequence against the value. - switch { - case width == 1: - case width == 2 && value >= 0x80: - case width == 3 && value >= 0x800: - case width == 4 && value >= 0x10000: - default: - return yaml_parser_set_reader_error(parser, - "invalid length of a UTF-8 sequence", - parser.offset, -1) - } - - // Check the range of the value. - if value >= 0xD800 && value <= 0xDFFF || value > 0x10FFFF { - return yaml_parser_set_reader_error(parser, - "invalid Unicode character", - parser.offset, int(value)) - } - - case yaml_UTF16LE_ENCODING, yaml_UTF16BE_ENCODING: - var low, high int - if parser.encoding == yaml_UTF16LE_ENCODING { - low, high = 0, 1 - } else { - high, low = 1, 0 - } - - // The UTF-16 encoding is not as simple as one might - // naively think. Check RFC 2781 - // (http://www.ietf.org/rfc/rfc2781.txt). - // - // Normally, two subsequent bytes describe a Unicode - // character. However a special technique (called a - // surrogate pair) is used for specifying character - // values larger than 0xFFFF. - // - // A surrogate pair consists of two pseudo-characters: - // high surrogate area (0xD800-0xDBFF) - // low surrogate area (0xDC00-0xDFFF) - // - // The following formulas are used for decoding - // and encoding characters using surrogate pairs: - // - // U = U' + 0x10000 (0x01 00 00 <= U <= 0x10 FF FF) - // U' = yyyyyyyyyyxxxxxxxxxx (0 <= U' <= 0x0F FF FF) - // W1 = 110110yyyyyyyyyy - // W2 = 110111xxxxxxxxxx - // - // where U is the character value, W1 is the high surrogate - // area, W2 is the low surrogate area. - - // Check for incomplete UTF-16 character. - if raw_unread < 2 { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-16 character", - parser.offset, -1) - } - break inner - } - - // Get the character. - value = rune(parser.raw_buffer[parser.raw_buffer_pos+low]) + - (rune(parser.raw_buffer[parser.raw_buffer_pos+high]) << 8) - - // Check for unexpected low surrogate area. - if value&0xFC00 == 0xDC00 { - return yaml_parser_set_reader_error(parser, - "unexpected low surrogate area", - parser.offset, int(value)) - } - - // Check for a high surrogate area. - if value&0xFC00 == 0xD800 { - width = 4 - - // Check for incomplete surrogate pair. - if raw_unread < 4 { - if parser.eof { - return yaml_parser_set_reader_error(parser, - "incomplete UTF-16 surrogate pair", - parser.offset, -1) - } - break inner - } - - // Get the next character. - value2 := rune(parser.raw_buffer[parser.raw_buffer_pos+low+2]) + - (rune(parser.raw_buffer[parser.raw_buffer_pos+high+2]) << 8) - - // Check for a low surrogate area. - if value2&0xFC00 != 0xDC00 { - return yaml_parser_set_reader_error(parser, - "expected low surrogate area", - parser.offset+2, int(value2)) - } - - // Generate the value of the surrogate pair. - value = 0x10000 + ((value & 0x3FF) << 10) + (value2 & 0x3FF) - } else { - width = 2 - } - - default: - panic("impossible") - } - - // Check if the character is in the allowed range: - // #x9 | #xA | #xD | [#x20-#x7E] (8 bit) - // | #x85 | [#xA0-#xD7FF] | [#xE000-#xFFFD] (16 bit) - // | [#x10000-#x10FFFF] (32 bit) - switch { - case value == 0x09: - case value == 0x0A: - case value == 0x0D: - case value >= 0x20 && value <= 0x7E: - case value == 0x85: - case value >= 0xA0 && value <= 0xD7FF: - case value >= 0xE000 && value <= 0xFFFD: - case value >= 0x10000 && value <= 0x10FFFF: - default: - return yaml_parser_set_reader_error(parser, - "control characters are not allowed", - parser.offset, int(value)) - } - - // Move the raw pointers. - parser.raw_buffer_pos += width - parser.offset += width - - // Finally put the character into the buffer. - if value <= 0x7F { - // 0000 0000-0000 007F . 0xxxxxxx - parser.buffer[buffer_len+0] = byte(value) - } else if value <= 0x7FF { - // 0000 0080-0000 07FF . 110xxxxx 10xxxxxx - parser.buffer[buffer_len+0] = byte(0xC0 + (value >> 6)) - parser.buffer[buffer_len+1] = byte(0x80 + (value & 0x3F)) - } else if value <= 0xFFFF { - // 0000 0800-0000 FFFF . 1110xxxx 10xxxxxx 10xxxxxx - parser.buffer[buffer_len+0] = byte(0xE0 + (value >> 12)) - parser.buffer[buffer_len+1] = byte(0x80 + ((value >> 6) & 0x3F)) - parser.buffer[buffer_len+2] = byte(0x80 + (value & 0x3F)) - } else { - // 0001 0000-0010 FFFF . 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx - parser.buffer[buffer_len+0] = byte(0xF0 + (value >> 18)) - parser.buffer[buffer_len+1] = byte(0x80 + ((value >> 12) & 0x3F)) - parser.buffer[buffer_len+2] = byte(0x80 + ((value >> 6) & 0x3F)) - parser.buffer[buffer_len+3] = byte(0x80 + (value & 0x3F)) - } - buffer_len += width - - parser.unread++ - } - - // On EOF, put NUL into the buffer and return. - if parser.eof { - parser.buffer[buffer_len] = 0 - buffer_len++ - parser.unread++ - break - } - } - parser.buffer = parser.buffer[:buffer_len] - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/resolve.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/resolve.go deleted file mode 100644 index 93a8632..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/resolve.go +++ /dev/null @@ -1,203 +0,0 @@ -package yaml - -import ( - "encoding/base64" - "math" - "strconv" - "strings" - "unicode/utf8" -) - -type resolveMapItem struct { - value interface{} - tag string -} - -var resolveTable = make([]byte, 256) -var resolveMap = make(map[string]resolveMapItem) - -func init() { - t := resolveTable - t[int('+')] = 'S' // Sign - t[int('-')] = 'S' - for _, c := range "0123456789" { - t[int(c)] = 'D' // Digit - } - for _, c := range "yYnNtTfFoO~" { - t[int(c)] = 'M' // In map - } - t[int('.')] = '.' // Float (potentially in map) - - var resolveMapList = []struct { - v interface{} - tag string - l []string - }{ - {true, yaml_BOOL_TAG, []string{"y", "Y", "yes", "Yes", "YES"}}, - {true, yaml_BOOL_TAG, []string{"true", "True", "TRUE"}}, - {true, yaml_BOOL_TAG, []string{"on", "On", "ON"}}, - {false, yaml_BOOL_TAG, []string{"n", "N", "no", "No", "NO"}}, - {false, yaml_BOOL_TAG, []string{"false", "False", "FALSE"}}, - {false, yaml_BOOL_TAG, []string{"off", "Off", "OFF"}}, - {nil, yaml_NULL_TAG, []string{"", "~", "null", "Null", "NULL"}}, - {math.NaN(), yaml_FLOAT_TAG, []string{".nan", ".NaN", ".NAN"}}, - {math.Inf(+1), yaml_FLOAT_TAG, []string{".inf", ".Inf", ".INF"}}, - {math.Inf(+1), yaml_FLOAT_TAG, []string{"+.inf", "+.Inf", "+.INF"}}, - {math.Inf(-1), yaml_FLOAT_TAG, []string{"-.inf", "-.Inf", "-.INF"}}, - {"<<", yaml_MERGE_TAG, []string{"<<"}}, - } - - m := resolveMap - for _, item := range resolveMapList { - for _, s := range item.l { - m[s] = resolveMapItem{item.v, item.tag} - } - } -} - -const longTagPrefix = "tag:yaml.org,2002:" - -func shortTag(tag string) string { - // TODO This can easily be made faster and produce less garbage. - if strings.HasPrefix(tag, longTagPrefix) { - return "!!" + tag[len(longTagPrefix):] - } - return tag -} - -func longTag(tag string) string { - if strings.HasPrefix(tag, "!!") { - return longTagPrefix + tag[2:] - } - return tag -} - -func resolvableTag(tag string) bool { - switch tag { - case "", yaml_STR_TAG, yaml_BOOL_TAG, yaml_INT_TAG, yaml_FLOAT_TAG, yaml_NULL_TAG: - return true - } - return false -} - -func resolve(tag string, in string) (rtag string, out interface{}) { - if !resolvableTag(tag) { - return tag, in - } - - defer func() { - switch tag { - case "", rtag, yaml_STR_TAG, yaml_BINARY_TAG: - return - } - failf("cannot decode %s `%s` as a %s", shortTag(rtag), in, shortTag(tag)) - }() - - // Any data is accepted as a !!str or !!binary. - // Otherwise, the prefix is enough of a hint about what it might be. - hint := byte('N') - if in != "" { - hint = resolveTable[in[0]] - } - if hint != 0 && tag != yaml_STR_TAG && tag != yaml_BINARY_TAG { - // Handle things we can lookup in a map. - if item, ok := resolveMap[in]; ok { - return item.tag, item.value - } - - // Base 60 floats are a bad idea, were dropped in YAML 1.2, and - // are purposefully unsupported here. They're still quoted on - // the way out for compatibility with other parser, though. - - switch hint { - case 'M': - // We've already checked the map above. - - case '.': - // Not in the map, so maybe a normal float. - floatv, err := strconv.ParseFloat(in, 64) - if err == nil { - return yaml_FLOAT_TAG, floatv - } - - case 'D', 'S': - // Int, float, or timestamp. - plain := strings.Replace(in, "_", "", -1) - intv, err := strconv.ParseInt(plain, 0, 64) - if err == nil { - if intv == int64(int(intv)) { - return yaml_INT_TAG, int(intv) - } else { - return yaml_INT_TAG, intv - } - } - uintv, err := strconv.ParseUint(plain, 0, 64) - if err == nil { - return yaml_INT_TAG, uintv - } - floatv, err := strconv.ParseFloat(plain, 64) - if err == nil { - return yaml_FLOAT_TAG, floatv - } - if strings.HasPrefix(plain, "0b") { - intv, err := strconv.ParseInt(plain[2:], 2, 64) - if err == nil { - if intv == int64(int(intv)) { - return yaml_INT_TAG, int(intv) - } else { - return yaml_INT_TAG, intv - } - } - uintv, err := strconv.ParseUint(plain[2:], 2, 64) - if err == nil { - return yaml_INT_TAG, uintv - } - } else if strings.HasPrefix(plain, "-0b") { - intv, err := strconv.ParseInt(plain[3:], 2, 64) - if err == nil { - if intv == int64(int(intv)) { - return yaml_INT_TAG, -int(intv) - } else { - return yaml_INT_TAG, -intv - } - } - } - // XXX Handle timestamps here. - - default: - panic("resolveTable item not yet handled: " + string(rune(hint)) + " (with " + in + ")") - } - } - if tag == yaml_BINARY_TAG { - return yaml_BINARY_TAG, in - } - if utf8.ValidString(in) { - return yaml_STR_TAG, in - } - return yaml_BINARY_TAG, encodeBase64(in) -} - -// encodeBase64 encodes s as base64 that is broken up into multiple lines -// as appropriate for the resulting length. -func encodeBase64(s string) string { - const lineLen = 70 - encLen := base64.StdEncoding.EncodedLen(len(s)) - lines := encLen/lineLen + 1 - buf := make([]byte, encLen*2+lines) - in := buf[0:encLen] - out := buf[encLen:] - base64.StdEncoding.Encode(in, []byte(s)) - k := 0 - for i := 0; i < len(in); i += lineLen { - j := i + lineLen - if j > len(in) { - j = len(in) - } - k += copy(out[k:], in[i:j]) - if lines > 1 { - out[k] = '\n' - k++ - } - } - return string(out[:k]) -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/scannerc.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/scannerc.go deleted file mode 100644 index d97d76f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/scannerc.go +++ /dev/null @@ -1,2710 +0,0 @@ -package yaml - -import ( - "bytes" - "fmt" -) - -// Introduction -// ************ -// -// The following notes assume that you are familiar with the YAML specification -// (http://yaml.org/spec/cvs/current.html). We mostly follow it, although in -// some cases we are less restrictive that it requires. -// -// The process of transforming a YAML stream into a sequence of events is -// divided on two steps: Scanning and Parsing. -// -// The Scanner transforms the input stream into a sequence of tokens, while the -// parser transform the sequence of tokens produced by the Scanner into a -// sequence of parsing events. -// -// The Scanner is rather clever and complicated. The Parser, on the contrary, -// is a straightforward implementation of a recursive-descendant parser (or, -// LL(1) parser, as it is usually called). -// -// Actually there are two issues of Scanning that might be called "clever", the -// rest is quite straightforward. The issues are "block collection start" and -// "simple keys". Both issues are explained below in details. -// -// Here the Scanning step is explained and implemented. We start with the list -// of all the tokens produced by the Scanner together with short descriptions. -// -// Now, tokens: -// -// STREAM-START(encoding) # The stream start. -// STREAM-END # The stream end. -// VERSION-DIRECTIVE(major,minor) # The '%YAML' directive. -// TAG-DIRECTIVE(handle,prefix) # The '%TAG' directive. -// DOCUMENT-START # '---' -// DOCUMENT-END # '...' -// BLOCK-SEQUENCE-START # Indentation increase denoting a block -// BLOCK-MAPPING-START # sequence or a block mapping. -// BLOCK-END # Indentation decrease. -// FLOW-SEQUENCE-START # '[' -// FLOW-SEQUENCE-END # ']' -// BLOCK-SEQUENCE-START # '{' -// BLOCK-SEQUENCE-END # '}' -// BLOCK-ENTRY # '-' -// FLOW-ENTRY # ',' -// KEY # '?' or nothing (simple keys). -// VALUE # ':' -// ALIAS(anchor) # '*anchor' -// ANCHOR(anchor) # '&anchor' -// TAG(handle,suffix) # '!handle!suffix' -// SCALAR(value,style) # A scalar. -// -// The following two tokens are "virtual" tokens denoting the beginning and the -// end of the stream: -// -// STREAM-START(encoding) -// STREAM-END -// -// We pass the information about the input stream encoding with the -// STREAM-START token. -// -// The next two tokens are responsible for tags: -// -// VERSION-DIRECTIVE(major,minor) -// TAG-DIRECTIVE(handle,prefix) -// -// Example: -// -// %YAML 1.1 -// %TAG ! !foo -// %TAG !yaml! tag:yaml.org,2002: -// --- -// -// The correspoding sequence of tokens: -// -// STREAM-START(utf-8) -// VERSION-DIRECTIVE(1,1) -// TAG-DIRECTIVE("!","!foo") -// TAG-DIRECTIVE("!yaml","tag:yaml.org,2002:") -// DOCUMENT-START -// STREAM-END -// -// Note that the VERSION-DIRECTIVE and TAG-DIRECTIVE tokens occupy a whole -// line. -// -// The document start and end indicators are represented by: -// -// DOCUMENT-START -// DOCUMENT-END -// -// Note that if a YAML stream contains an implicit document (without '---' -// and '...' indicators), no DOCUMENT-START and DOCUMENT-END tokens will be -// produced. -// -// In the following examples, we present whole documents together with the -// produced tokens. -// -// 1. An implicit document: -// -// 'a scalar' -// -// Tokens: -// -// STREAM-START(utf-8) -// SCALAR("a scalar",single-quoted) -// STREAM-END -// -// 2. An explicit document: -// -// --- -// 'a scalar' -// ... -// -// Tokens: -// -// STREAM-START(utf-8) -// DOCUMENT-START -// SCALAR("a scalar",single-quoted) -// DOCUMENT-END -// STREAM-END -// -// 3. Several documents in a stream: -// -// 'a scalar' -// --- -// 'another scalar' -// --- -// 'yet another scalar' -// -// Tokens: -// -// STREAM-START(utf-8) -// SCALAR("a scalar",single-quoted) -// DOCUMENT-START -// SCALAR("another scalar",single-quoted) -// DOCUMENT-START -// SCALAR("yet another scalar",single-quoted) -// STREAM-END -// -// We have already introduced the SCALAR token above. The following tokens are -// used to describe aliases, anchors, tag, and scalars: -// -// ALIAS(anchor) -// ANCHOR(anchor) -// TAG(handle,suffix) -// SCALAR(value,style) -// -// The following series of examples illustrate the usage of these tokens: -// -// 1. A recursive sequence: -// -// &A [ *A ] -// -// Tokens: -// -// STREAM-START(utf-8) -// ANCHOR("A") -// FLOW-SEQUENCE-START -// ALIAS("A") -// FLOW-SEQUENCE-END -// STREAM-END -// -// 2. A tagged scalar: -// -// !!float "3.14" # A good approximation. -// -// Tokens: -// -// STREAM-START(utf-8) -// TAG("!!","float") -// SCALAR("3.14",double-quoted) -// STREAM-END -// -// 3. Various scalar styles: -// -// --- # Implicit empty plain scalars do not produce tokens. -// --- a plain scalar -// --- 'a single-quoted scalar' -// --- "a double-quoted scalar" -// --- |- -// a literal scalar -// --- >- -// a folded -// scalar -// -// Tokens: -// -// STREAM-START(utf-8) -// DOCUMENT-START -// DOCUMENT-START -// SCALAR("a plain scalar",plain) -// DOCUMENT-START -// SCALAR("a single-quoted scalar",single-quoted) -// DOCUMENT-START -// SCALAR("a double-quoted scalar",double-quoted) -// DOCUMENT-START -// SCALAR("a literal scalar",literal) -// DOCUMENT-START -// SCALAR("a folded scalar",folded) -// STREAM-END -// -// Now it's time to review collection-related tokens. We will start with -// flow collections: -// -// FLOW-SEQUENCE-START -// FLOW-SEQUENCE-END -// FLOW-MAPPING-START -// FLOW-MAPPING-END -// FLOW-ENTRY -// KEY -// VALUE -// -// The tokens FLOW-SEQUENCE-START, FLOW-SEQUENCE-END, FLOW-MAPPING-START, and -// FLOW-MAPPING-END represent the indicators '[', ']', '{', and '}' -// correspondingly. FLOW-ENTRY represent the ',' indicator. Finally the -// indicators '?' and ':', which are used for denoting mapping keys and values, -// are represented by the KEY and VALUE tokens. -// -// The following examples show flow collections: -// -// 1. A flow sequence: -// -// [item 1, item 2, item 3] -// -// Tokens: -// -// STREAM-START(utf-8) -// FLOW-SEQUENCE-START -// SCALAR("item 1",plain) -// FLOW-ENTRY -// SCALAR("item 2",plain) -// FLOW-ENTRY -// SCALAR("item 3",plain) -// FLOW-SEQUENCE-END -// STREAM-END -// -// 2. A flow mapping: -// -// { -// a simple key: a value, # Note that the KEY token is produced. -// ? a complex key: another value, -// } -// -// Tokens: -// -// STREAM-START(utf-8) -// FLOW-MAPPING-START -// KEY -// SCALAR("a simple key",plain) -// VALUE -// SCALAR("a value",plain) -// FLOW-ENTRY -// KEY -// SCALAR("a complex key",plain) -// VALUE -// SCALAR("another value",plain) -// FLOW-ENTRY -// FLOW-MAPPING-END -// STREAM-END -// -// A simple key is a key which is not denoted by the '?' indicator. Note that -// the Scanner still produce the KEY token whenever it encounters a simple key. -// -// For scanning block collections, the following tokens are used (note that we -// repeat KEY and VALUE here): -// -// BLOCK-SEQUENCE-START -// BLOCK-MAPPING-START -// BLOCK-END -// BLOCK-ENTRY -// KEY -// VALUE -// -// The tokens BLOCK-SEQUENCE-START and BLOCK-MAPPING-START denote indentation -// increase that precedes a block collection (cf. the INDENT token in Python). -// The token BLOCK-END denote indentation decrease that ends a block collection -// (cf. the DEDENT token in Python). However YAML has some syntax pecularities -// that makes detections of these tokens more complex. -// -// The tokens BLOCK-ENTRY, KEY, and VALUE are used to represent the indicators -// '-', '?', and ':' correspondingly. -// -// The following examples show how the tokens BLOCK-SEQUENCE-START, -// BLOCK-MAPPING-START, and BLOCK-END are emitted by the Scanner: -// -// 1. Block sequences: -// -// - item 1 -// - item 2 -// - -// - item 3.1 -// - item 3.2 -// - -// key 1: value 1 -// key 2: value 2 -// -// Tokens: -// -// STREAM-START(utf-8) -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// SCALAR("item 1",plain) -// BLOCK-ENTRY -// SCALAR("item 2",plain) -// BLOCK-ENTRY -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// SCALAR("item 3.1",plain) -// BLOCK-ENTRY -// SCALAR("item 3.2",plain) -// BLOCK-END -// BLOCK-ENTRY -// BLOCK-MAPPING-START -// KEY -// SCALAR("key 1",plain) -// VALUE -// SCALAR("value 1",plain) -// KEY -// SCALAR("key 2",plain) -// VALUE -// SCALAR("value 2",plain) -// BLOCK-END -// BLOCK-END -// STREAM-END -// -// 2. Block mappings: -// -// a simple key: a value # The KEY token is produced here. -// ? a complex key -// : another value -// a mapping: -// key 1: value 1 -// key 2: value 2 -// a sequence: -// - item 1 -// - item 2 -// -// Tokens: -// -// STREAM-START(utf-8) -// BLOCK-MAPPING-START -// KEY -// SCALAR("a simple key",plain) -// VALUE -// SCALAR("a value",plain) -// KEY -// SCALAR("a complex key",plain) -// VALUE -// SCALAR("another value",plain) -// KEY -// SCALAR("a mapping",plain) -// BLOCK-MAPPING-START -// KEY -// SCALAR("key 1",plain) -// VALUE -// SCALAR("value 1",plain) -// KEY -// SCALAR("key 2",plain) -// VALUE -// SCALAR("value 2",plain) -// BLOCK-END -// KEY -// SCALAR("a sequence",plain) -// VALUE -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// SCALAR("item 1",plain) -// BLOCK-ENTRY -// SCALAR("item 2",plain) -// BLOCK-END -// BLOCK-END -// STREAM-END -// -// YAML does not always require to start a new block collection from a new -// line. If the current line contains only '-', '?', and ':' indicators, a new -// block collection may start at the current line. The following examples -// illustrate this case: -// -// 1. Collections in a sequence: -// -// - - item 1 -// - item 2 -// - key 1: value 1 -// key 2: value 2 -// - ? complex key -// : complex value -// -// Tokens: -// -// STREAM-START(utf-8) -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// SCALAR("item 1",plain) -// BLOCK-ENTRY -// SCALAR("item 2",plain) -// BLOCK-END -// BLOCK-ENTRY -// BLOCK-MAPPING-START -// KEY -// SCALAR("key 1",plain) -// VALUE -// SCALAR("value 1",plain) -// KEY -// SCALAR("key 2",plain) -// VALUE -// SCALAR("value 2",plain) -// BLOCK-END -// BLOCK-ENTRY -// BLOCK-MAPPING-START -// KEY -// SCALAR("complex key") -// VALUE -// SCALAR("complex value") -// BLOCK-END -// BLOCK-END -// STREAM-END -// -// 2. Collections in a mapping: -// -// ? a sequence -// : - item 1 -// - item 2 -// ? a mapping -// : key 1: value 1 -// key 2: value 2 -// -// Tokens: -// -// STREAM-START(utf-8) -// BLOCK-MAPPING-START -// KEY -// SCALAR("a sequence",plain) -// VALUE -// BLOCK-SEQUENCE-START -// BLOCK-ENTRY -// SCALAR("item 1",plain) -// BLOCK-ENTRY -// SCALAR("item 2",plain) -// BLOCK-END -// KEY -// SCALAR("a mapping",plain) -// VALUE -// BLOCK-MAPPING-START -// KEY -// SCALAR("key 1",plain) -// VALUE -// SCALAR("value 1",plain) -// KEY -// SCALAR("key 2",plain) -// VALUE -// SCALAR("value 2",plain) -// BLOCK-END -// BLOCK-END -// STREAM-END -// -// YAML also permits non-indented sequences if they are included into a block -// mapping. In this case, the token BLOCK-SEQUENCE-START is not produced: -// -// key: -// - item 1 # BLOCK-SEQUENCE-START is NOT produced here. -// - item 2 -// -// Tokens: -// -// STREAM-START(utf-8) -// BLOCK-MAPPING-START -// KEY -// SCALAR("key",plain) -// VALUE -// BLOCK-ENTRY -// SCALAR("item 1",plain) -// BLOCK-ENTRY -// SCALAR("item 2",plain) -// BLOCK-END -// - -// Ensure that the buffer contains the required number of characters. -// Return true on success, false on failure (reader error or memory error). -func cache(parser *yaml_parser_t, length int) bool { - // [Go] This was inlined: !cache(A, B) -> unread < B && !update(A, B) - return parser.unread >= length || yaml_parser_update_buffer(parser, length) -} - -// Advance the buffer pointer. -func skip(parser *yaml_parser_t) { - parser.mark.index++ - parser.mark.column++ - parser.unread-- - parser.buffer_pos += width(parser.buffer[parser.buffer_pos]) -} - -func skip_line(parser *yaml_parser_t) { - if is_crlf(parser.buffer, parser.buffer_pos) { - parser.mark.index += 2 - parser.mark.column = 0 - parser.mark.line++ - parser.unread -= 2 - parser.buffer_pos += 2 - } else if is_break(parser.buffer, parser.buffer_pos) { - parser.mark.index++ - parser.mark.column = 0 - parser.mark.line++ - parser.unread-- - parser.buffer_pos += width(parser.buffer[parser.buffer_pos]) - } -} - -// Copy a character to a string buffer and advance pointers. -func read(parser *yaml_parser_t, s []byte) []byte { - w := width(parser.buffer[parser.buffer_pos]) - if w == 0 { - panic("invalid character sequence") - } - if len(s) == 0 { - s = make([]byte, 0, 32) - } - if w == 1 && len(s)+w <= cap(s) { - s = s[:len(s)+1] - s[len(s)-1] = parser.buffer[parser.buffer_pos] - parser.buffer_pos++ - } else { - s = append(s, parser.buffer[parser.buffer_pos:parser.buffer_pos+w]...) - parser.buffer_pos += w - } - parser.mark.index++ - parser.mark.column++ - parser.unread-- - return s -} - -// Copy a line break character to a string buffer and advance pointers. -func read_line(parser *yaml_parser_t, s []byte) []byte { - buf := parser.buffer - pos := parser.buffer_pos - switch { - case buf[pos] == '\r' && buf[pos+1] == '\n': - // CR LF . LF - s = append(s, '\n') - parser.buffer_pos += 2 - parser.mark.index++ - parser.unread-- - case buf[pos] == '\r' || buf[pos] == '\n': - // CR|LF . LF - s = append(s, '\n') - parser.buffer_pos += 1 - case buf[pos] == '\xC2' && buf[pos+1] == '\x85': - // NEL . LF - s = append(s, '\n') - parser.buffer_pos += 2 - case buf[pos] == '\xE2' && buf[pos+1] == '\x80' && (buf[pos+2] == '\xA8' || buf[pos+2] == '\xA9'): - // LS|PS . LS|PS - s = append(s, buf[parser.buffer_pos:pos+3]...) - parser.buffer_pos += 3 - default: - return s - } - parser.mark.index++ - parser.mark.column = 0 - parser.mark.line++ - parser.unread-- - return s -} - -// Get the next token. -func yaml_parser_scan(parser *yaml_parser_t, token *yaml_token_t) bool { - // Erase the token object. - *token = yaml_token_t{} // [Go] Is this necessary? - - // No tokens after STREAM-END or error. - if parser.stream_end_produced || parser.error != yaml_NO_ERROR { - return true - } - - // Ensure that the tokens queue contains enough tokens. - if !parser.token_available { - if !yaml_parser_fetch_more_tokens(parser) { - return false - } - } - - // Fetch the next token from the queue. - *token = parser.tokens[parser.tokens_head] - parser.tokens_head++ - parser.tokens_parsed++ - parser.token_available = false - - if token.typ == yaml_STREAM_END_TOKEN { - parser.stream_end_produced = true - } - return true -} - -// Set the scanner error and return false. -func yaml_parser_set_scanner_error(parser *yaml_parser_t, context string, context_mark yaml_mark_t, problem string) bool { - parser.error = yaml_SCANNER_ERROR - parser.context = context - parser.context_mark = context_mark - parser.problem = problem - parser.problem_mark = parser.mark - return false -} - -func yaml_parser_set_scanner_tag_error(parser *yaml_parser_t, directive bool, context_mark yaml_mark_t, problem string) bool { - context := "while parsing a tag" - if directive { - context = "while parsing a %TAG directive" - } - return yaml_parser_set_scanner_error(parser, context, context_mark, "did not find URI escaped octet") -} - -func trace(args ...interface{}) func() { - pargs := append([]interface{}{"+++"}, args...) - fmt.Println(pargs...) - pargs = append([]interface{}{"---"}, args...) - return func() { fmt.Println(pargs...) } -} - -// Ensure that the tokens queue contains at least one token which can be -// returned to the Parser. -func yaml_parser_fetch_more_tokens(parser *yaml_parser_t) bool { - // While we need more tokens to fetch, do it. - for { - // Check if we really need to fetch more tokens. - need_more_tokens := false - - if parser.tokens_head == len(parser.tokens) { - // Queue is empty. - need_more_tokens = true - } else { - // Check if any potential simple key may occupy the head position. - if !yaml_parser_stale_simple_keys(parser) { - return false - } - - for i := range parser.simple_keys { - simple_key := &parser.simple_keys[i] - if simple_key.possible && simple_key.token_number == parser.tokens_parsed { - need_more_tokens = true - break - } - } - } - - // We are finished. - if !need_more_tokens { - break - } - // Fetch the next token. - if !yaml_parser_fetch_next_token(parser) { - return false - } - } - - parser.token_available = true - return true -} - -// The dispatcher for token fetchers. -func yaml_parser_fetch_next_token(parser *yaml_parser_t) bool { - // Ensure that the buffer is initialized. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - // Check if we just started scanning. Fetch STREAM-START then. - if !parser.stream_start_produced { - return yaml_parser_fetch_stream_start(parser) - } - - // Eat whitespaces and comments until we reach the next token. - if !yaml_parser_scan_to_next_token(parser) { - return false - } - - // Remove obsolete potential simple keys. - if !yaml_parser_stale_simple_keys(parser) { - return false - } - - // Check the indentation level against the current column. - if !yaml_parser_unroll_indent(parser, parser.mark.column) { - return false - } - - // Ensure that the buffer contains at least 4 characters. 4 is the length - // of the longest indicators ('--- ' and '... '). - if parser.unread < 4 && !yaml_parser_update_buffer(parser, 4) { - return false - } - - // Is it the end of the stream? - if is_z(parser.buffer, parser.buffer_pos) { - return yaml_parser_fetch_stream_end(parser) - } - - // Is it a directive? - if parser.mark.column == 0 && parser.buffer[parser.buffer_pos] == '%' { - return yaml_parser_fetch_directive(parser) - } - - buf := parser.buffer - pos := parser.buffer_pos - - // Is it the document start indicator? - if parser.mark.column == 0 && buf[pos] == '-' && buf[pos+1] == '-' && buf[pos+2] == '-' && is_blankz(buf, pos+3) { - return yaml_parser_fetch_document_indicator(parser, yaml_DOCUMENT_START_TOKEN) - } - - // Is it the document end indicator? - if parser.mark.column == 0 && buf[pos] == '.' && buf[pos+1] == '.' && buf[pos+2] == '.' && is_blankz(buf, pos+3) { - return yaml_parser_fetch_document_indicator(parser, yaml_DOCUMENT_END_TOKEN) - } - - // Is it the flow sequence start indicator? - if buf[pos] == '[' { - return yaml_parser_fetch_flow_collection_start(parser, yaml_FLOW_SEQUENCE_START_TOKEN) - } - - // Is it the flow mapping start indicator? - if parser.buffer[parser.buffer_pos] == '{' { - return yaml_parser_fetch_flow_collection_start(parser, yaml_FLOW_MAPPING_START_TOKEN) - } - - // Is it the flow sequence end indicator? - if parser.buffer[parser.buffer_pos] == ']' { - return yaml_parser_fetch_flow_collection_end(parser, - yaml_FLOW_SEQUENCE_END_TOKEN) - } - - // Is it the flow mapping end indicator? - if parser.buffer[parser.buffer_pos] == '}' { - return yaml_parser_fetch_flow_collection_end(parser, - yaml_FLOW_MAPPING_END_TOKEN) - } - - // Is it the flow entry indicator? - if parser.buffer[parser.buffer_pos] == ',' { - return yaml_parser_fetch_flow_entry(parser) - } - - // Is it the block entry indicator? - if parser.buffer[parser.buffer_pos] == '-' && is_blankz(parser.buffer, parser.buffer_pos+1) { - return yaml_parser_fetch_block_entry(parser) - } - - // Is it the key indicator? - if parser.buffer[parser.buffer_pos] == '?' && (parser.flow_level > 0 || is_blankz(parser.buffer, parser.buffer_pos+1)) { - return yaml_parser_fetch_key(parser) - } - - // Is it the value indicator? - if parser.buffer[parser.buffer_pos] == ':' && (parser.flow_level > 0 || is_blankz(parser.buffer, parser.buffer_pos+1)) { - return yaml_parser_fetch_value(parser) - } - - // Is it an alias? - if parser.buffer[parser.buffer_pos] == '*' { - return yaml_parser_fetch_anchor(parser, yaml_ALIAS_TOKEN) - } - - // Is it an anchor? - if parser.buffer[parser.buffer_pos] == '&' { - return yaml_parser_fetch_anchor(parser, yaml_ANCHOR_TOKEN) - } - - // Is it a tag? - if parser.buffer[parser.buffer_pos] == '!' { - return yaml_parser_fetch_tag(parser) - } - - // Is it a literal scalar? - if parser.buffer[parser.buffer_pos] == '|' && parser.flow_level == 0 { - return yaml_parser_fetch_block_scalar(parser, true) - } - - // Is it a folded scalar? - if parser.buffer[parser.buffer_pos] == '>' && parser.flow_level == 0 { - return yaml_parser_fetch_block_scalar(parser, false) - } - - // Is it a single-quoted scalar? - if parser.buffer[parser.buffer_pos] == '\'' { - return yaml_parser_fetch_flow_scalar(parser, true) - } - - // Is it a double-quoted scalar? - if parser.buffer[parser.buffer_pos] == '"' { - return yaml_parser_fetch_flow_scalar(parser, false) - } - - // Is it a plain scalar? - // - // A plain scalar may start with any non-blank characters except - // - // '-', '?', ':', ',', '[', ']', '{', '}', - // '#', '&', '*', '!', '|', '>', '\'', '\"', - // '%', '@', '`'. - // - // In the block context (and, for the '-' indicator, in the flow context - // too), it may also start with the characters - // - // '-', '?', ':' - // - // if it is followed by a non-space character. - // - // The last rule is more restrictive than the specification requires. - // [Go] Make this logic more reasonable. - //switch parser.buffer[parser.buffer_pos] { - //case '-', '?', ':', ',', '?', '-', ',', ':', ']', '[', '}', '{', '&', '#', '!', '*', '>', '|', '"', '\'', '@', '%', '-', '`': - //} - if !(is_blankz(parser.buffer, parser.buffer_pos) || parser.buffer[parser.buffer_pos] == '-' || - parser.buffer[parser.buffer_pos] == '?' || parser.buffer[parser.buffer_pos] == ':' || - parser.buffer[parser.buffer_pos] == ',' || parser.buffer[parser.buffer_pos] == '[' || - parser.buffer[parser.buffer_pos] == ']' || parser.buffer[parser.buffer_pos] == '{' || - parser.buffer[parser.buffer_pos] == '}' || parser.buffer[parser.buffer_pos] == '#' || - parser.buffer[parser.buffer_pos] == '&' || parser.buffer[parser.buffer_pos] == '*' || - parser.buffer[parser.buffer_pos] == '!' || parser.buffer[parser.buffer_pos] == '|' || - parser.buffer[parser.buffer_pos] == '>' || parser.buffer[parser.buffer_pos] == '\'' || - parser.buffer[parser.buffer_pos] == '"' || parser.buffer[parser.buffer_pos] == '%' || - parser.buffer[parser.buffer_pos] == '@' || parser.buffer[parser.buffer_pos] == '`') || - (parser.buffer[parser.buffer_pos] == '-' && !is_blank(parser.buffer, parser.buffer_pos+1)) || - (parser.flow_level == 0 && - (parser.buffer[parser.buffer_pos] == '?' || parser.buffer[parser.buffer_pos] == ':') && - !is_blankz(parser.buffer, parser.buffer_pos+1)) { - return yaml_parser_fetch_plain_scalar(parser) - } - - // If we don't determine the token type so far, it is an error. - return yaml_parser_set_scanner_error(parser, - "while scanning for the next token", parser.mark, - "found character that cannot start any token") -} - -// Check the list of potential simple keys and remove the positions that -// cannot contain simple keys anymore. -func yaml_parser_stale_simple_keys(parser *yaml_parser_t) bool { - // Check for a potential simple key for each flow level. - for i := range parser.simple_keys { - simple_key := &parser.simple_keys[i] - - // The specification requires that a simple key - // - // - is limited to a single line, - // - is shorter than 1024 characters. - if simple_key.possible && (simple_key.mark.line < parser.mark.line || simple_key.mark.index+1024 < parser.mark.index) { - - // Check if the potential simple key to be removed is required. - if simple_key.required { - return yaml_parser_set_scanner_error(parser, - "while scanning a simple key", simple_key.mark, - "could not find expected ':'") - } - simple_key.possible = false - } - } - return true -} - -// Check if a simple key may start at the current position and add it if -// needed. -func yaml_parser_save_simple_key(parser *yaml_parser_t) bool { - // A simple key is required at the current position if the scanner is in - // the block context and the current column coincides with the indentation - // level. - - required := parser.flow_level == 0 && parser.indent == parser.mark.column - - // A simple key is required only when it is the first token in the current - // line. Therefore it is always allowed. But we add a check anyway. - if required && !parser.simple_key_allowed { - panic("should not happen") - } - - // - // If the current position may start a simple key, save it. - // - if parser.simple_key_allowed { - simple_key := yaml_simple_key_t{ - possible: true, - required: required, - token_number: parser.tokens_parsed + (len(parser.tokens) - parser.tokens_head), - } - simple_key.mark = parser.mark - - if !yaml_parser_remove_simple_key(parser) { - return false - } - parser.simple_keys[len(parser.simple_keys)-1] = simple_key - } - return true -} - -// Remove a potential simple key at the current flow level. -func yaml_parser_remove_simple_key(parser *yaml_parser_t) bool { - i := len(parser.simple_keys) - 1 - if parser.simple_keys[i].possible { - // If the key is required, it is an error. - if parser.simple_keys[i].required { - return yaml_parser_set_scanner_error(parser, - "while scanning a simple key", parser.simple_keys[i].mark, - "could not find expected ':'") - } - } - // Remove the key from the stack. - parser.simple_keys[i].possible = false - return true -} - -// Increase the flow level and resize the simple key list if needed. -func yaml_parser_increase_flow_level(parser *yaml_parser_t) bool { - // Reset the simple key on the next level. - parser.simple_keys = append(parser.simple_keys, yaml_simple_key_t{}) - - // Increase the flow level. - parser.flow_level++ - return true -} - -// Decrease the flow level. -func yaml_parser_decrease_flow_level(parser *yaml_parser_t) bool { - if parser.flow_level > 0 { - parser.flow_level-- - parser.simple_keys = parser.simple_keys[:len(parser.simple_keys)-1] - } - return true -} - -// Push the current indentation level to the stack and set the new level -// the current column is greater than the indentation level. In this case, -// append or insert the specified token into the token queue. -func yaml_parser_roll_indent(parser *yaml_parser_t, column, number int, typ yaml_token_type_t, mark yaml_mark_t) bool { - // In the flow context, do nothing. - if parser.flow_level > 0 { - return true - } - - if parser.indent < column { - // Push the current indentation level to the stack and set the new - // indentation level. - parser.indents = append(parser.indents, parser.indent) - parser.indent = column - - // Create a token and insert it into the queue. - token := yaml_token_t{ - typ: typ, - start_mark: mark, - end_mark: mark, - } - if number > -1 { - number -= parser.tokens_parsed - } - yaml_insert_token(parser, number, &token) - } - return true -} - -// Pop indentation levels from the indents stack until the current level -// becomes less or equal to the column. For each indentation level, append -// the BLOCK-END token. -func yaml_parser_unroll_indent(parser *yaml_parser_t, column int) bool { - // In the flow context, do nothing. - if parser.flow_level > 0 { - return true - } - - // Loop through the indentation levels in the stack. - for parser.indent > column { - // Create a token and append it to the queue. - token := yaml_token_t{ - typ: yaml_BLOCK_END_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - } - yaml_insert_token(parser, -1, &token) - - // Pop the indentation level. - parser.indent = parser.indents[len(parser.indents)-1] - parser.indents = parser.indents[:len(parser.indents)-1] - } - return true -} - -// Initialize the scanner and produce the STREAM-START token. -func yaml_parser_fetch_stream_start(parser *yaml_parser_t) bool { - - // Set the initial indentation. - parser.indent = -1 - - // Initialize the simple key stack. - parser.simple_keys = append(parser.simple_keys, yaml_simple_key_t{}) - - // A simple key is allowed at the beginning of the stream. - parser.simple_key_allowed = true - - // We have started. - parser.stream_start_produced = true - - // Create the STREAM-START token and append it to the queue. - token := yaml_token_t{ - typ: yaml_STREAM_START_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - encoding: parser.encoding, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the STREAM-END token and shut down the scanner. -func yaml_parser_fetch_stream_end(parser *yaml_parser_t) bool { - - // Force new line. - if parser.mark.column != 0 { - parser.mark.column = 0 - parser.mark.line++ - } - - // Reset the indentation level. - if !yaml_parser_unroll_indent(parser, -1) { - return false - } - - // Reset simple keys. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - // Create the STREAM-END token and append it to the queue. - token := yaml_token_t{ - typ: yaml_STREAM_END_TOKEN, - start_mark: parser.mark, - end_mark: parser.mark, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce a VERSION-DIRECTIVE or TAG-DIRECTIVE token. -func yaml_parser_fetch_directive(parser *yaml_parser_t) bool { - // Reset the indentation level. - if !yaml_parser_unroll_indent(parser, -1) { - return false - } - - // Reset simple keys. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - // Create the YAML-DIRECTIVE or TAG-DIRECTIVE token. - token := yaml_token_t{} - if !yaml_parser_scan_directive(parser, &token) { - return false - } - // Append the token to the queue. - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the DOCUMENT-START or DOCUMENT-END token. -func yaml_parser_fetch_document_indicator(parser *yaml_parser_t, typ yaml_token_type_t) bool { - // Reset the indentation level. - if !yaml_parser_unroll_indent(parser, -1) { - return false - } - - // Reset simple keys. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - parser.simple_key_allowed = false - - // Consume the token. - start_mark := parser.mark - - skip(parser) - skip(parser) - skip(parser) - - end_mark := parser.mark - - // Create the DOCUMENT-START or DOCUMENT-END token. - token := yaml_token_t{ - typ: typ, - start_mark: start_mark, - end_mark: end_mark, - } - // Append the token to the queue. - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the FLOW-SEQUENCE-START or FLOW-MAPPING-START token. -func yaml_parser_fetch_flow_collection_start(parser *yaml_parser_t, typ yaml_token_type_t) bool { - // The indicators '[' and '{' may start a simple key. - if !yaml_parser_save_simple_key(parser) { - return false - } - - // Increase the flow level. - if !yaml_parser_increase_flow_level(parser) { - return false - } - - // A simple key may follow the indicators '[' and '{'. - parser.simple_key_allowed = true - - // Consume the token. - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the FLOW-SEQUENCE-START of FLOW-MAPPING-START token. - token := yaml_token_t{ - typ: typ, - start_mark: start_mark, - end_mark: end_mark, - } - // Append the token to the queue. - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the FLOW-SEQUENCE-END or FLOW-MAPPING-END token. -func yaml_parser_fetch_flow_collection_end(parser *yaml_parser_t, typ yaml_token_type_t) bool { - // Reset any potential simple key on the current flow level. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - // Decrease the flow level. - if !yaml_parser_decrease_flow_level(parser) { - return false - } - - // No simple keys after the indicators ']' and '}'. - parser.simple_key_allowed = false - - // Consume the token. - - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the FLOW-SEQUENCE-END of FLOW-MAPPING-END token. - token := yaml_token_t{ - typ: typ, - start_mark: start_mark, - end_mark: end_mark, - } - // Append the token to the queue. - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the FLOW-ENTRY token. -func yaml_parser_fetch_flow_entry(parser *yaml_parser_t) bool { - // Reset any potential simple keys on the current flow level. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - // Simple keys are allowed after ','. - parser.simple_key_allowed = true - - // Consume the token. - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the FLOW-ENTRY token and append it to the queue. - token := yaml_token_t{ - typ: yaml_FLOW_ENTRY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the BLOCK-ENTRY token. -func yaml_parser_fetch_block_entry(parser *yaml_parser_t) bool { - // Check if the scanner is in the block context. - if parser.flow_level == 0 { - // Check if we are allowed to start a new entry. - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "block sequence entries are not allowed in this context") - } - // Add the BLOCK-SEQUENCE-START token if needed. - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, yaml_BLOCK_SEQUENCE_START_TOKEN, parser.mark) { - return false - } - } else { - // It is an error for the '-' indicator to occur in the flow context, - // but we let the Parser detect and report about it because the Parser - // is able to point to the context. - } - - // Reset any potential simple keys on the current flow level. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - // Simple keys are allowed after '-'. - parser.simple_key_allowed = true - - // Consume the token. - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the BLOCK-ENTRY token and append it to the queue. - token := yaml_token_t{ - typ: yaml_BLOCK_ENTRY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the KEY token. -func yaml_parser_fetch_key(parser *yaml_parser_t) bool { - - // In the block context, additional checks are required. - if parser.flow_level == 0 { - // Check if we are allowed to start a new key (not nessesary simple). - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "mapping keys are not allowed in this context") - } - // Add the BLOCK-MAPPING-START token if needed. - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, yaml_BLOCK_MAPPING_START_TOKEN, parser.mark) { - return false - } - } - - // Reset any potential simple keys on the current flow level. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - // Simple keys are allowed after '?' in the block context. - parser.simple_key_allowed = parser.flow_level == 0 - - // Consume the token. - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the KEY token and append it to the queue. - token := yaml_token_t{ - typ: yaml_KEY_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the VALUE token. -func yaml_parser_fetch_value(parser *yaml_parser_t) bool { - - simple_key := &parser.simple_keys[len(parser.simple_keys)-1] - - // Have we found a simple key? - if simple_key.possible { - // Create the KEY token and insert it into the queue. - token := yaml_token_t{ - typ: yaml_KEY_TOKEN, - start_mark: simple_key.mark, - end_mark: simple_key.mark, - } - yaml_insert_token(parser, simple_key.token_number-parser.tokens_parsed, &token) - - // In the block context, we may need to add the BLOCK-MAPPING-START token. - if !yaml_parser_roll_indent(parser, simple_key.mark.column, - simple_key.token_number, - yaml_BLOCK_MAPPING_START_TOKEN, simple_key.mark) { - return false - } - - // Remove the simple key. - simple_key.possible = false - - // A simple key cannot follow another simple key. - parser.simple_key_allowed = false - - } else { - // The ':' indicator follows a complex key. - - // In the block context, extra checks are required. - if parser.flow_level == 0 { - - // Check if we are allowed to start a complex value. - if !parser.simple_key_allowed { - return yaml_parser_set_scanner_error(parser, "", parser.mark, - "mapping values are not allowed in this context") - } - - // Add the BLOCK-MAPPING-START token if needed. - if !yaml_parser_roll_indent(parser, parser.mark.column, -1, yaml_BLOCK_MAPPING_START_TOKEN, parser.mark) { - return false - } - } - - // Simple keys after ':' are allowed in the block context. - parser.simple_key_allowed = parser.flow_level == 0 - } - - // Consume the token. - start_mark := parser.mark - skip(parser) - end_mark := parser.mark - - // Create the VALUE token and append it to the queue. - token := yaml_token_t{ - typ: yaml_VALUE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the ALIAS or ANCHOR token. -func yaml_parser_fetch_anchor(parser *yaml_parser_t, typ yaml_token_type_t) bool { - // An anchor or an alias could be a simple key. - if !yaml_parser_save_simple_key(parser) { - return false - } - - // A simple key cannot follow an anchor or an alias. - parser.simple_key_allowed = false - - // Create the ALIAS or ANCHOR token and append it to the queue. - var token yaml_token_t - if !yaml_parser_scan_anchor(parser, &token, typ) { - return false - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the TAG token. -func yaml_parser_fetch_tag(parser *yaml_parser_t) bool { - // A tag could be a simple key. - if !yaml_parser_save_simple_key(parser) { - return false - } - - // A simple key cannot follow a tag. - parser.simple_key_allowed = false - - // Create the TAG token and append it to the queue. - var token yaml_token_t - if !yaml_parser_scan_tag(parser, &token) { - return false - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the SCALAR(...,literal) or SCALAR(...,folded) tokens. -func yaml_parser_fetch_block_scalar(parser *yaml_parser_t, literal bool) bool { - // Remove any potential simple keys. - if !yaml_parser_remove_simple_key(parser) { - return false - } - - // A simple key may follow a block scalar. - parser.simple_key_allowed = true - - // Create the SCALAR token and append it to the queue. - var token yaml_token_t - if !yaml_parser_scan_block_scalar(parser, &token, literal) { - return false - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the SCALAR(...,single-quoted) or SCALAR(...,double-quoted) tokens. -func yaml_parser_fetch_flow_scalar(parser *yaml_parser_t, single bool) bool { - // A plain scalar could be a simple key. - if !yaml_parser_save_simple_key(parser) { - return false - } - - // A simple key cannot follow a flow scalar. - parser.simple_key_allowed = false - - // Create the SCALAR token and append it to the queue. - var token yaml_token_t - if !yaml_parser_scan_flow_scalar(parser, &token, single) { - return false - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Produce the SCALAR(...,plain) token. -func yaml_parser_fetch_plain_scalar(parser *yaml_parser_t) bool { - // A plain scalar could be a simple key. - if !yaml_parser_save_simple_key(parser) { - return false - } - - // A simple key cannot follow a flow scalar. - parser.simple_key_allowed = false - - // Create the SCALAR token and append it to the queue. - var token yaml_token_t - if !yaml_parser_scan_plain_scalar(parser, &token) { - return false - } - yaml_insert_token(parser, -1, &token) - return true -} - -// Eat whitespaces and comments until the next token is found. -func yaml_parser_scan_to_next_token(parser *yaml_parser_t) bool { - - // Until the next token is not found. - for { - // Allow the BOM mark to start a line. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if parser.mark.column == 0 && is_bom(parser.buffer, parser.buffer_pos) { - skip(parser) - } - - // Eat whitespaces. - // Tabs are allowed: - // - in the flow context - // - in the block context, but not at the beginning of the line or - // after '-', '?', or ':' (complex value). - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for parser.buffer[parser.buffer_pos] == ' ' || ((parser.flow_level > 0 || !parser.simple_key_allowed) && parser.buffer[parser.buffer_pos] == '\t') { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Eat a comment until a line break. - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - } - - // If it is a line break, eat it. - if is_break(parser.buffer, parser.buffer_pos) { - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - skip_line(parser) - - // In the block context, a new line may start a simple key. - if parser.flow_level == 0 { - parser.simple_key_allowed = true - } - } else { - break // We have found a token. - } - } - - return true -} - -// Scan a YAML-DIRECTIVE or TAG-DIRECTIVE token. -// -// Scope: -// %YAML 1.1 # a comment \n -// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -// %TAG !yaml! tag:yaml.org,2002: \n -// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -// -func yaml_parser_scan_directive(parser *yaml_parser_t, token *yaml_token_t) bool { - // Eat '%'. - start_mark := parser.mark - skip(parser) - - // Scan the directive name. - var name []byte - if !yaml_parser_scan_directive_name(parser, start_mark, &name) { - return false - } - - // Is it a YAML directive? - if bytes.Equal(name, []byte("YAML")) { - // Scan the VERSION directive value. - var major, minor int8 - if !yaml_parser_scan_version_directive_value(parser, start_mark, &major, &minor) { - return false - } - end_mark := parser.mark - - // Create a VERSION-DIRECTIVE token. - *token = yaml_token_t{ - typ: yaml_VERSION_DIRECTIVE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - major: major, - minor: minor, - } - - // Is it a TAG directive? - } else if bytes.Equal(name, []byte("TAG")) { - // Scan the TAG directive value. - var handle, prefix []byte - if !yaml_parser_scan_tag_directive_value(parser, start_mark, &handle, &prefix) { - return false - } - end_mark := parser.mark - - // Create a TAG-DIRECTIVE token. - *token = yaml_token_t{ - typ: yaml_TAG_DIRECTIVE_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: handle, - prefix: prefix, - } - - // Unknown directive. - } else { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "found uknown directive name") - return false - } - - // Eat the rest of the line including any comments. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for is_blank(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - } - - // Check if we are at the end of the line. - if !is_breakz(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "did not find expected comment or line break") - return false - } - - // Eat a line break. - if is_break(parser.buffer, parser.buffer_pos) { - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - skip_line(parser) - } - - return true -} - -// Scan the directive name. -// -// Scope: -// %YAML 1.1 # a comment \n -// ^^^^ -// %TAG !yaml! tag:yaml.org,2002: \n -// ^^^ -// -func yaml_parser_scan_directive_name(parser *yaml_parser_t, start_mark yaml_mark_t, name *[]byte) bool { - // Consume the directive name. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - var s []byte - for is_alpha(parser.buffer, parser.buffer_pos) { - s = read(parser, s) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Check if the name is empty. - if len(s) == 0 { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "could not find expected directive name") - return false - } - - // Check for an blank character after the name. - if !is_blankz(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a directive", - start_mark, "found unexpected non-alphabetical character") - return false - } - *name = s - return true -} - -// Scan the value of VERSION-DIRECTIVE. -// -// Scope: -// %YAML 1.1 # a comment \n -// ^^^^^^ -func yaml_parser_scan_version_directive_value(parser *yaml_parser_t, start_mark yaml_mark_t, major, minor *int8) bool { - // Eat whitespaces. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - for is_blank(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Consume the major version number. - if !yaml_parser_scan_version_directive_number(parser, start_mark, major) { - return false - } - - // Eat '.'. - if parser.buffer[parser.buffer_pos] != '.' { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "did not find expected digit or '.' character") - } - - skip(parser) - - // Consume the minor version number. - if !yaml_parser_scan_version_directive_number(parser, start_mark, minor) { - return false - } - return true -} - -const max_number_length = 2 - -// Scan the version number of VERSION-DIRECTIVE. -// -// Scope: -// %YAML 1.1 # a comment \n -// ^ -// %YAML 1.1 # a comment \n -// ^ -func yaml_parser_scan_version_directive_number(parser *yaml_parser_t, start_mark yaml_mark_t, number *int8) bool { - - // Repeat while the next character is digit. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - var value, length int8 - for is_digit(parser.buffer, parser.buffer_pos) { - // Check if the number is too long. - length++ - if length > max_number_length { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "found extremely long version number") - } - value = value*10 + int8(as_digit(parser.buffer, parser.buffer_pos)) - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Check if the number was present. - if length == 0 { - return yaml_parser_set_scanner_error(parser, "while scanning a %YAML directive", - start_mark, "did not find expected version number") - } - *number = value - return true -} - -// Scan the value of a TAG-DIRECTIVE token. -// -// Scope: -// %TAG !yaml! tag:yaml.org,2002: \n -// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -// -func yaml_parser_scan_tag_directive_value(parser *yaml_parser_t, start_mark yaml_mark_t, handle, prefix *[]byte) bool { - var handle_value, prefix_value []byte - - // Eat whitespaces. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for is_blank(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Scan a handle. - if !yaml_parser_scan_tag_handle(parser, true, start_mark, &handle_value) { - return false - } - - // Expect a whitespace. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if !is_blank(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a %TAG directive", - start_mark, "did not find expected whitespace") - return false - } - - // Eat whitespaces. - for is_blank(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Scan a prefix. - if !yaml_parser_scan_tag_uri(parser, true, nil, start_mark, &prefix_value) { - return false - } - - // Expect a whitespace or line break. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if !is_blankz(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a %TAG directive", - start_mark, "did not find expected whitespace or line break") - return false - } - - *handle = handle_value - *prefix = prefix_value - return true -} - -func yaml_parser_scan_anchor(parser *yaml_parser_t, token *yaml_token_t, typ yaml_token_type_t) bool { - var s []byte - - // Eat the indicator character. - start_mark := parser.mark - skip(parser) - - // Consume the value. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for is_alpha(parser.buffer, parser.buffer_pos) { - s = read(parser, s) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - end_mark := parser.mark - - /* - * Check if length of the anchor is greater than 0 and it is followed by - * a whitespace character or one of the indicators: - * - * '?', ':', ',', ']', '}', '%', '@', '`'. - */ - - if len(s) == 0 || - !(is_blankz(parser.buffer, parser.buffer_pos) || parser.buffer[parser.buffer_pos] == '?' || - parser.buffer[parser.buffer_pos] == ':' || parser.buffer[parser.buffer_pos] == ',' || - parser.buffer[parser.buffer_pos] == ']' || parser.buffer[parser.buffer_pos] == '}' || - parser.buffer[parser.buffer_pos] == '%' || parser.buffer[parser.buffer_pos] == '@' || - parser.buffer[parser.buffer_pos] == '`') { - context := "while scanning an alias" - if typ == yaml_ANCHOR_TOKEN { - context = "while scanning an anchor" - } - yaml_parser_set_scanner_error(parser, context, start_mark, - "did not find expected alphabetic or numeric character") - return false - } - - // Create a token. - *token = yaml_token_t{ - typ: typ, - start_mark: start_mark, - end_mark: end_mark, - value: s, - } - - return true -} - -/* - * Scan a TAG token. - */ - -func yaml_parser_scan_tag(parser *yaml_parser_t, token *yaml_token_t) bool { - var handle, suffix []byte - - start_mark := parser.mark - - // Check if the tag is in the canonical form. - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - - if parser.buffer[parser.buffer_pos+1] == '<' { - // Keep the handle as '' - - // Eat '!<' - skip(parser) - skip(parser) - - // Consume the tag value. - if !yaml_parser_scan_tag_uri(parser, false, nil, start_mark, &suffix) { - return false - } - - // Check for '>' and eat it. - if parser.buffer[parser.buffer_pos] != '>' { - yaml_parser_set_scanner_error(parser, "while scanning a tag", - start_mark, "did not find the expected '>'") - return false - } - - skip(parser) - } else { - // The tag has either the '!suffix' or the '!handle!suffix' form. - - // First, try to scan a handle. - if !yaml_parser_scan_tag_handle(parser, false, start_mark, &handle) { - return false - } - - // Check if it is, indeed, handle. - if handle[0] == '!' && len(handle) > 1 && handle[len(handle)-1] == '!' { - // Scan the suffix now. - if !yaml_parser_scan_tag_uri(parser, false, nil, start_mark, &suffix) { - return false - } - } else { - // It wasn't a handle after all. Scan the rest of the tag. - if !yaml_parser_scan_tag_uri(parser, false, handle, start_mark, &suffix) { - return false - } - - // Set the handle to '!'. - handle = []byte{'!'} - - // A special case: the '!' tag. Set the handle to '' and the - // suffix to '!'. - if len(suffix) == 0 { - handle, suffix = suffix, handle - } - } - } - - // Check the character which ends the tag. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if !is_blankz(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a tag", - start_mark, "did not find expected whitespace or line break") - return false - } - - end_mark := parser.mark - - // Create a token. - *token = yaml_token_t{ - typ: yaml_TAG_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: handle, - suffix: suffix, - } - return true -} - -// Scan a tag handle. -func yaml_parser_scan_tag_handle(parser *yaml_parser_t, directive bool, start_mark yaml_mark_t, handle *[]byte) bool { - // Check the initial '!' character. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if parser.buffer[parser.buffer_pos] != '!' { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected '!'") - return false - } - - var s []byte - - // Copy the '!' character. - s = read(parser, s) - - // Copy all subsequent alphabetical and numerical characters. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - for is_alpha(parser.buffer, parser.buffer_pos) { - s = read(parser, s) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Check if the trailing character is '!' and copy it. - if parser.buffer[parser.buffer_pos] == '!' { - s = read(parser, s) - } else { - // It's either the '!' tag or not really a tag handle. If it's a %TAG - // directive, it's an error. If it's a tag token, it must be a part of URI. - if directive && !(s[0] == '!' && s[1] == 0) { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected '!'") - return false - } - } - - *handle = s - return true -} - -// Scan a tag. -func yaml_parser_scan_tag_uri(parser *yaml_parser_t, directive bool, head []byte, start_mark yaml_mark_t, uri *[]byte) bool { - //size_t length = head ? strlen((char *)head) : 0 - var s []byte - - // Copy the head if needed. - // - // Note that we don't copy the leading '!' character. - if len(head) > 1 { - s = append(s, head[1:]...) - } - - // Scan the tag. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - // The set of characters that may appear in URI is as follows: - // - // '0'-'9', 'A'-'Z', 'a'-'z', '_', '-', ';', '/', '?', ':', '@', '&', - // '=', '+', '$', ',', '.', '!', '~', '*', '\'', '(', ')', '[', ']', - // '%'. - // [Go] Convert this into more reasonable logic. - for is_alpha(parser.buffer, parser.buffer_pos) || parser.buffer[parser.buffer_pos] == ';' || - parser.buffer[parser.buffer_pos] == '/' || parser.buffer[parser.buffer_pos] == '?' || - parser.buffer[parser.buffer_pos] == ':' || parser.buffer[parser.buffer_pos] == '@' || - parser.buffer[parser.buffer_pos] == '&' || parser.buffer[parser.buffer_pos] == '=' || - parser.buffer[parser.buffer_pos] == '+' || parser.buffer[parser.buffer_pos] == '$' || - parser.buffer[parser.buffer_pos] == ',' || parser.buffer[parser.buffer_pos] == '.' || - parser.buffer[parser.buffer_pos] == '!' || parser.buffer[parser.buffer_pos] == '~' || - parser.buffer[parser.buffer_pos] == '*' || parser.buffer[parser.buffer_pos] == '\'' || - parser.buffer[parser.buffer_pos] == '(' || parser.buffer[parser.buffer_pos] == ')' || - parser.buffer[parser.buffer_pos] == '[' || parser.buffer[parser.buffer_pos] == ']' || - parser.buffer[parser.buffer_pos] == '%' { - // Check if it is a URI-escape sequence. - if parser.buffer[parser.buffer_pos] == '%' { - if !yaml_parser_scan_uri_escapes(parser, directive, start_mark, &s) { - return false - } - } else { - s = read(parser, s) - } - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Check if the tag is non-empty. - if len(s) == 0 { - yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find expected tag URI") - return false - } - *uri = s - return true -} - -// Decode an URI-escape sequence corresponding to a single UTF-8 character. -func yaml_parser_scan_uri_escapes(parser *yaml_parser_t, directive bool, start_mark yaml_mark_t, s *[]byte) bool { - - // Decode the required number of characters. - w := 1024 - for w > 0 { - // Check for a URI-escaped octet. - if parser.unread < 3 && !yaml_parser_update_buffer(parser, 3) { - return false - } - - if !(parser.buffer[parser.buffer_pos] == '%' && - is_hex(parser.buffer, parser.buffer_pos+1) && - is_hex(parser.buffer, parser.buffer_pos+2)) { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "did not find URI escaped octet") - } - - // Get the octet. - octet := byte((as_hex(parser.buffer, parser.buffer_pos+1) << 4) + as_hex(parser.buffer, parser.buffer_pos+2)) - - // If it is the leading octet, determine the length of the UTF-8 sequence. - if w == 1024 { - w = width(octet) - if w == 0 { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "found an incorrect leading UTF-8 octet") - } - } else { - // Check if the trailing octet is correct. - if octet&0xC0 != 0x80 { - return yaml_parser_set_scanner_tag_error(parser, directive, - start_mark, "found an incorrect trailing UTF-8 octet") - } - } - - // Copy the octet and move the pointers. - *s = append(*s, octet) - skip(parser) - skip(parser) - skip(parser) - w-- - } - return true -} - -// Scan a block scalar. -func yaml_parser_scan_block_scalar(parser *yaml_parser_t, token *yaml_token_t, literal bool) bool { - // Eat the indicator '|' or '>'. - start_mark := parser.mark - skip(parser) - - // Scan the additional block scalar indicators. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - // Check for a chomping indicator. - var chomping, increment int - if parser.buffer[parser.buffer_pos] == '+' || parser.buffer[parser.buffer_pos] == '-' { - // Set the chomping method and eat the indicator. - if parser.buffer[parser.buffer_pos] == '+' { - chomping = +1 - } else { - chomping = -1 - } - skip(parser) - - // Check for an indentation indicator. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if is_digit(parser.buffer, parser.buffer_pos) { - // Check that the indentation is greater than 0. - if parser.buffer[parser.buffer_pos] == '0' { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found an indentation indicator equal to 0") - return false - } - - // Get the indentation level and eat the indicator. - increment = as_digit(parser.buffer, parser.buffer_pos) - skip(parser) - } - - } else if is_digit(parser.buffer, parser.buffer_pos) { - // Do the same as above, but in the opposite order. - - if parser.buffer[parser.buffer_pos] == '0' { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found an indentation indicator equal to 0") - return false - } - increment = as_digit(parser.buffer, parser.buffer_pos) - skip(parser) - - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - if parser.buffer[parser.buffer_pos] == '+' || parser.buffer[parser.buffer_pos] == '-' { - if parser.buffer[parser.buffer_pos] == '+' { - chomping = +1 - } else { - chomping = -1 - } - skip(parser) - } - } - - // Eat whitespaces and comments to the end of the line. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - for is_blank(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - if parser.buffer[parser.buffer_pos] == '#' { - for !is_breakz(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - } - - // Check if we are at the end of the line. - if !is_breakz(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "did not find expected comment or line break") - return false - } - - // Eat a line break. - if is_break(parser.buffer, parser.buffer_pos) { - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - skip_line(parser) - } - - end_mark := parser.mark - - // Set the indentation level if it was specified. - var indent int - if increment > 0 { - if parser.indent >= 0 { - indent = parser.indent + increment - } else { - indent = increment - } - } - - // Scan the leading line breaks and determine the indentation level if needed. - var s, leading_break, trailing_breaks []byte - if !yaml_parser_scan_block_scalar_breaks(parser, &indent, &trailing_breaks, start_mark, &end_mark) { - return false - } - - // Scan the block scalar content. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - var leading_blank, trailing_blank bool - for parser.mark.column == indent && !is_z(parser.buffer, parser.buffer_pos) { - // We are at the beginning of a non-empty line. - - // Is it a trailing whitespace? - trailing_blank = is_blank(parser.buffer, parser.buffer_pos) - - // Check if we need to fold the leading line break. - if !literal && !leading_blank && !trailing_blank && len(leading_break) > 0 && leading_break[0] == '\n' { - // Do we need to join the lines by space? - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } - } else { - s = append(s, leading_break...) - } - leading_break = leading_break[:0] - - // Append the remaining line breaks. - s = append(s, trailing_breaks...) - trailing_breaks = trailing_breaks[:0] - - // Is it a leading whitespace? - leading_blank = is_blank(parser.buffer, parser.buffer_pos) - - // Consume the current line. - for !is_breakz(parser.buffer, parser.buffer_pos) { - s = read(parser, s) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Consume the line break. - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - - leading_break = read_line(parser, leading_break) - - // Eat the following indentation spaces and line breaks. - if !yaml_parser_scan_block_scalar_breaks(parser, &indent, &trailing_breaks, start_mark, &end_mark) { - return false - } - } - - // Chomp the tail. - if chomping != -1 { - s = append(s, leading_break...) - } - if chomping == 1 { - s = append(s, trailing_breaks...) - } - - // Create a token. - *token = yaml_token_t{ - typ: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_LITERAL_SCALAR_STYLE, - } - if !literal { - token.style = yaml_FOLDED_SCALAR_STYLE - } - return true -} - -// Scan indentation spaces and line breaks for a block scalar. Determine the -// indentation level if needed. -func yaml_parser_scan_block_scalar_breaks(parser *yaml_parser_t, indent *int, breaks *[]byte, start_mark yaml_mark_t, end_mark *yaml_mark_t) bool { - *end_mark = parser.mark - - // Eat the indentation spaces and line breaks. - max_indent := 0 - for { - // Eat the indentation spaces. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - for (*indent == 0 || parser.mark.column < *indent) && is_space(parser.buffer, parser.buffer_pos) { - skip(parser) - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - if parser.mark.column > max_indent { - max_indent = parser.mark.column - } - - // Check for a tab character messing the indentation. - if (*indent == 0 || parser.mark.column < *indent) && is_tab(parser.buffer, parser.buffer_pos) { - return yaml_parser_set_scanner_error(parser, "while scanning a block scalar", - start_mark, "found a tab character where an indentation space is expected") - } - - // Have we found a non-empty line? - if !is_break(parser.buffer, parser.buffer_pos) { - break - } - - // Consume the line break. - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - // [Go] Should really be returning breaks instead. - *breaks = read_line(parser, *breaks) - *end_mark = parser.mark - } - - // Determine the indentation level if needed. - if *indent == 0 { - *indent = max_indent - if *indent < parser.indent+1 { - *indent = parser.indent + 1 - } - if *indent < 1 { - *indent = 1 - } - } - return true -} - -// Scan a quoted scalar. -func yaml_parser_scan_flow_scalar(parser *yaml_parser_t, token *yaml_token_t, single bool) bool { - // Eat the left quote. - start_mark := parser.mark - skip(parser) - - // Consume the content of the quoted scalar. - var s, leading_break, trailing_breaks, whitespaces []byte - for { - // Check that there are no document indicators at the beginning of the line. - if parser.unread < 4 && !yaml_parser_update_buffer(parser, 4) { - return false - } - - if parser.mark.column == 0 && - ((parser.buffer[parser.buffer_pos+0] == '-' && - parser.buffer[parser.buffer_pos+1] == '-' && - parser.buffer[parser.buffer_pos+2] == '-') || - (parser.buffer[parser.buffer_pos+0] == '.' && - parser.buffer[parser.buffer_pos+1] == '.' && - parser.buffer[parser.buffer_pos+2] == '.')) && - is_blankz(parser.buffer, parser.buffer_pos+3) { - yaml_parser_set_scanner_error(parser, "while scanning a quoted scalar", - start_mark, "found unexpected document indicator") - return false - } - - // Check for EOF. - if is_z(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a quoted scalar", - start_mark, "found unexpected end of stream") - return false - } - - // Consume non-blank characters. - leading_blanks := false - for !is_blankz(parser.buffer, parser.buffer_pos) { - if single && parser.buffer[parser.buffer_pos] == '\'' && parser.buffer[parser.buffer_pos+1] == '\'' { - // Is is an escaped single quote. - s = append(s, '\'') - skip(parser) - skip(parser) - - } else if single && parser.buffer[parser.buffer_pos] == '\'' { - // It is a right single quote. - break - } else if !single && parser.buffer[parser.buffer_pos] == '"' { - // It is a right double quote. - break - - } else if !single && parser.buffer[parser.buffer_pos] == '\\' && is_break(parser.buffer, parser.buffer_pos+1) { - // It is an escaped line break. - if parser.unread < 3 && !yaml_parser_update_buffer(parser, 3) { - return false - } - skip(parser) - skip_line(parser) - leading_blanks = true - break - - } else if !single && parser.buffer[parser.buffer_pos] == '\\' { - // It is an escape sequence. - code_length := 0 - - // Check the escape character. - switch parser.buffer[parser.buffer_pos+1] { - case '0': - s = append(s, 0) - case 'a': - s = append(s, '\x07') - case 'b': - s = append(s, '\x08') - case 't', '\t': - s = append(s, '\x09') - case 'n': - s = append(s, '\x0A') - case 'v': - s = append(s, '\x0B') - case 'f': - s = append(s, '\x0C') - case 'r': - s = append(s, '\x0D') - case 'e': - s = append(s, '\x1B') - case ' ': - s = append(s, '\x20') - case '"': - s = append(s, '"') - case '\'': - s = append(s, '\'') - case '\\': - s = append(s, '\\') - case 'N': // NEL (#x85) - s = append(s, '\xC2') - s = append(s, '\x85') - case '_': // #xA0 - s = append(s, '\xC2') - s = append(s, '\xA0') - case 'L': // LS (#x2028) - s = append(s, '\xE2') - s = append(s, '\x80') - s = append(s, '\xA8') - case 'P': // PS (#x2029) - s = append(s, '\xE2') - s = append(s, '\x80') - s = append(s, '\xA9') - case 'x': - code_length = 2 - case 'u': - code_length = 4 - case 'U': - code_length = 8 - default: - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "found unknown escape character") - return false - } - - skip(parser) - skip(parser) - - // Consume an arbitrary escape code. - if code_length > 0 { - var value int - - // Scan the character value. - if parser.unread < code_length && !yaml_parser_update_buffer(parser, code_length) { - return false - } - for k := 0; k < code_length; k++ { - if !is_hex(parser.buffer, parser.buffer_pos+k) { - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "did not find expected hexdecimal number") - return false - } - value = (value << 4) + as_hex(parser.buffer, parser.buffer_pos+k) - } - - // Check the value and write the character. - if (value >= 0xD800 && value <= 0xDFFF) || value > 0x10FFFF { - yaml_parser_set_scanner_error(parser, "while parsing a quoted scalar", - start_mark, "found invalid Unicode character escape code") - return false - } - if value <= 0x7F { - s = append(s, byte(value)) - } else if value <= 0x7FF { - s = append(s, byte(0xC0+(value>>6))) - s = append(s, byte(0x80+(value&0x3F))) - } else if value <= 0xFFFF { - s = append(s, byte(0xE0+(value>>12))) - s = append(s, byte(0x80+((value>>6)&0x3F))) - s = append(s, byte(0x80+(value&0x3F))) - } else { - s = append(s, byte(0xF0+(value>>18))) - s = append(s, byte(0x80+((value>>12)&0x3F))) - s = append(s, byte(0x80+((value>>6)&0x3F))) - s = append(s, byte(0x80+(value&0x3F))) - } - - // Advance the pointer. - for k := 0; k < code_length; k++ { - skip(parser) - } - } - } else { - // It is a non-escaped non-blank character. - s = read(parser, s) - } - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - } - - // Check if we are at the end of the scalar. - if single { - if parser.buffer[parser.buffer_pos] == '\'' { - break - } - } else { - if parser.buffer[parser.buffer_pos] == '"' { - break - } - } - - // Consume blank characters. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for is_blank(parser.buffer, parser.buffer_pos) || is_break(parser.buffer, parser.buffer_pos) { - if is_blank(parser.buffer, parser.buffer_pos) { - // Consume a space or a tab character. - if !leading_blanks { - whitespaces = read(parser, whitespaces) - } else { - skip(parser) - } - } else { - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - - // Check if it is a first line break. - if !leading_blanks { - whitespaces = whitespaces[:0] - leading_break = read_line(parser, leading_break) - leading_blanks = true - } else { - trailing_breaks = read_line(parser, trailing_breaks) - } - } - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Join the whitespaces or fold line breaks. - if leading_blanks { - // Do we need to fold line breaks? - if len(leading_break) > 0 && leading_break[0] == '\n' { - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } else { - s = append(s, trailing_breaks...) - } - } else { - s = append(s, leading_break...) - s = append(s, trailing_breaks...) - } - trailing_breaks = trailing_breaks[:0] - leading_break = leading_break[:0] - } else { - s = append(s, whitespaces...) - whitespaces = whitespaces[:0] - } - } - - // Eat the right quote. - skip(parser) - end_mark := parser.mark - - // Create a token. - *token = yaml_token_t{ - typ: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_SINGLE_QUOTED_SCALAR_STYLE, - } - if !single { - token.style = yaml_DOUBLE_QUOTED_SCALAR_STYLE - } - return true -} - -// Scan a plain scalar. -func yaml_parser_scan_plain_scalar(parser *yaml_parser_t, token *yaml_token_t) bool { - - var s, leading_break, trailing_breaks, whitespaces []byte - var leading_blanks bool - var indent = parser.indent + 1 - - start_mark := parser.mark - end_mark := parser.mark - - // Consume the content of the plain scalar. - for { - // Check for a document indicator. - if parser.unread < 4 && !yaml_parser_update_buffer(parser, 4) { - return false - } - if parser.mark.column == 0 && - ((parser.buffer[parser.buffer_pos+0] == '-' && - parser.buffer[parser.buffer_pos+1] == '-' && - parser.buffer[parser.buffer_pos+2] == '-') || - (parser.buffer[parser.buffer_pos+0] == '.' && - parser.buffer[parser.buffer_pos+1] == '.' && - parser.buffer[parser.buffer_pos+2] == '.')) && - is_blankz(parser.buffer, parser.buffer_pos+3) { - break - } - - // Check for a comment. - if parser.buffer[parser.buffer_pos] == '#' { - break - } - - // Consume non-blank characters. - for !is_blankz(parser.buffer, parser.buffer_pos) { - - // Check for 'x:x' in the flow context. TODO: Fix the test "spec-08-13". - if parser.flow_level > 0 && - parser.buffer[parser.buffer_pos] == ':' && - !is_blankz(parser.buffer, parser.buffer_pos+1) { - yaml_parser_set_scanner_error(parser, "while scanning a plain scalar", - start_mark, "found unexpected ':'") - return false - } - - // Check for indicators that may end a plain scalar. - if (parser.buffer[parser.buffer_pos] == ':' && is_blankz(parser.buffer, parser.buffer_pos+1)) || - (parser.flow_level > 0 && - (parser.buffer[parser.buffer_pos] == ',' || parser.buffer[parser.buffer_pos] == ':' || - parser.buffer[parser.buffer_pos] == '?' || parser.buffer[parser.buffer_pos] == '[' || - parser.buffer[parser.buffer_pos] == ']' || parser.buffer[parser.buffer_pos] == '{' || - parser.buffer[parser.buffer_pos] == '}')) { - break - } - - // Check if we need to join whitespaces and breaks. - if leading_blanks || len(whitespaces) > 0 { - if leading_blanks { - // Do we need to fold line breaks? - if leading_break[0] == '\n' { - if len(trailing_breaks) == 0 { - s = append(s, ' ') - } else { - s = append(s, trailing_breaks...) - } - } else { - s = append(s, leading_break...) - s = append(s, trailing_breaks...) - } - trailing_breaks = trailing_breaks[:0] - leading_break = leading_break[:0] - leading_blanks = false - } else { - s = append(s, whitespaces...) - whitespaces = whitespaces[:0] - } - } - - // Copy the character. - s = read(parser, s) - - end_mark = parser.mark - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - } - - // Is it the end? - if !(is_blank(parser.buffer, parser.buffer_pos) || is_break(parser.buffer, parser.buffer_pos)) { - break - } - - // Consume blank characters. - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - - for is_blank(parser.buffer, parser.buffer_pos) || is_break(parser.buffer, parser.buffer_pos) { - if is_blank(parser.buffer, parser.buffer_pos) { - - // Check for tab character that abuse indentation. - if leading_blanks && parser.mark.column < indent && is_tab(parser.buffer, parser.buffer_pos) { - yaml_parser_set_scanner_error(parser, "while scanning a plain scalar", - start_mark, "found a tab character that violate indentation") - return false - } - - // Consume a space or a tab character. - if !leading_blanks { - whitespaces = read(parser, whitespaces) - } else { - skip(parser) - } - } else { - if parser.unread < 2 && !yaml_parser_update_buffer(parser, 2) { - return false - } - - // Check if it is a first line break. - if !leading_blanks { - whitespaces = whitespaces[:0] - leading_break = read_line(parser, leading_break) - leading_blanks = true - } else { - trailing_breaks = read_line(parser, trailing_breaks) - } - } - if parser.unread < 1 && !yaml_parser_update_buffer(parser, 1) { - return false - } - } - - // Check indentation level. - if parser.flow_level == 0 && parser.mark.column < indent { - break - } - } - - // Create a token. - *token = yaml_token_t{ - typ: yaml_SCALAR_TOKEN, - start_mark: start_mark, - end_mark: end_mark, - value: s, - style: yaml_PLAIN_SCALAR_STYLE, - } - - // Note that we change the 'simple_key_allowed' flag. - if leading_blanks { - parser.simple_key_allowed = true - } - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/sorter.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/sorter.go deleted file mode 100644 index 5958822..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/sorter.go +++ /dev/null @@ -1,104 +0,0 @@ -package yaml - -import ( - "reflect" - "unicode" -) - -type keyList []reflect.Value - -func (l keyList) Len() int { return len(l) } -func (l keyList) Swap(i, j int) { l[i], l[j] = l[j], l[i] } -func (l keyList) Less(i, j int) bool { - a := l[i] - b := l[j] - ak := a.Kind() - bk := b.Kind() - for (ak == reflect.Interface || ak == reflect.Ptr) && !a.IsNil() { - a = a.Elem() - ak = a.Kind() - } - for (bk == reflect.Interface || bk == reflect.Ptr) && !b.IsNil() { - b = b.Elem() - bk = b.Kind() - } - af, aok := keyFloat(a) - bf, bok := keyFloat(b) - if aok && bok { - if af != bf { - return af < bf - } - if ak != bk { - return ak < bk - } - return numLess(a, b) - } - if ak != reflect.String || bk != reflect.String { - return ak < bk - } - ar, br := []rune(a.String()), []rune(b.String()) - for i := 0; i < len(ar) && i < len(br); i++ { - if ar[i] == br[i] { - continue - } - al := unicode.IsLetter(ar[i]) - bl := unicode.IsLetter(br[i]) - if al && bl { - return ar[i] < br[i] - } - if al || bl { - return bl - } - var ai, bi int - var an, bn int64 - for ai = i; ai < len(ar) && unicode.IsDigit(ar[ai]); ai++ { - an = an*10 + int64(ar[ai]-'0') - } - for bi = i; bi < len(br) && unicode.IsDigit(br[bi]); bi++ { - bn = bn*10 + int64(br[bi]-'0') - } - if an != bn { - return an < bn - } - if ai != bi { - return ai < bi - } - return ar[i] < br[i] - } - return len(ar) < len(br) -} - -// keyFloat returns a float value for v if it is a number/bool -// and whether it is a number/bool or not. -func keyFloat(v reflect.Value) (f float64, ok bool) { - switch v.Kind() { - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return float64(v.Int()), true - case reflect.Float32, reflect.Float64: - return v.Float(), true - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return float64(v.Uint()), true - case reflect.Bool: - if v.Bool() { - return 1, true - } - return 0, true - } - return 0, false -} - -// numLess returns whether a < b. -// a and b must necessarily have the same kind. -func numLess(a, b reflect.Value) bool { - switch a.Kind() { - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return a.Int() < b.Int() - case reflect.Float32, reflect.Float64: - return a.Float() < b.Float() - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return a.Uint() < b.Uint() - case reflect.Bool: - return !a.Bool() && b.Bool() - } - panic("not a number") -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/writerc.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/writerc.go deleted file mode 100644 index 190362f..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/writerc.go +++ /dev/null @@ -1,89 +0,0 @@ -package yaml - -// Set the writer error and return false. -func yaml_emitter_set_writer_error(emitter *yaml_emitter_t, problem string) bool { - emitter.error = yaml_WRITER_ERROR - emitter.problem = problem - return false -} - -// Flush the output buffer. -func yaml_emitter_flush(emitter *yaml_emitter_t) bool { - if emitter.write_handler == nil { - panic("write handler not set") - } - - // Check if the buffer is empty. - if emitter.buffer_pos == 0 { - return true - } - - // If the output encoding is UTF-8, we don't need to recode the buffer. - if emitter.encoding == yaml_UTF8_ENCODING { - if err := emitter.write_handler(emitter, emitter.buffer[:emitter.buffer_pos]); err != nil { - return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error()) - } - emitter.buffer_pos = 0 - return true - } - - // Recode the buffer into the raw buffer. - var low, high int - if emitter.encoding == yaml_UTF16LE_ENCODING { - low, high = 0, 1 - } else { - high, low = 1, 0 - } - - pos := 0 - for pos < emitter.buffer_pos { - // See the "reader.c" code for more details on UTF-8 encoding. Note - // that we assume that the buffer contains a valid UTF-8 sequence. - - // Read the next UTF-8 character. - octet := emitter.buffer[pos] - - var w int - var value rune - switch { - case octet&0x80 == 0x00: - w, value = 1, rune(octet&0x7F) - case octet&0xE0 == 0xC0: - w, value = 2, rune(octet&0x1F) - case octet&0xF0 == 0xE0: - w, value = 3, rune(octet&0x0F) - case octet&0xF8 == 0xF0: - w, value = 4, rune(octet&0x07) - } - for k := 1; k < w; k++ { - octet = emitter.buffer[pos+k] - value = (value << 6) + (rune(octet) & 0x3F) - } - pos += w - - // Write the character. - if value < 0x10000 { - var b [2]byte - b[high] = byte(value >> 8) - b[low] = byte(value & 0xFF) - emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1]) - } else { - // Write the character using a surrogate pair (check "reader.c"). - var b [4]byte - value -= 0x10000 - b[high] = byte(0xD8 + (value >> 18)) - b[low] = byte((value >> 10) & 0xFF) - b[high+2] = byte(0xDC + ((value >> 8) & 0xFF)) - b[low+2] = byte(value & 0xFF) - emitter.raw_buffer = append(emitter.raw_buffer, b[0], b[1], b[2], b[3]) - } - } - - // Write the raw buffer. - if err := emitter.write_handler(emitter, emitter.raw_buffer); err != nil { - return yaml_emitter_set_writer_error(emitter, "write error: "+err.Error()) - } - emitter.buffer_pos = 0 - emitter.raw_buffer = emitter.raw_buffer[:0] - return true -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yaml.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yaml.go deleted file mode 100644 index d133edf..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yaml.go +++ /dev/null @@ -1,346 +0,0 @@ -// Package yaml implements YAML support for the Go language. -// -// Source code and other details for the project are available at GitHub: -// -// https://github.com/go-yaml/yaml -// -package yaml - -import ( - "errors" - "fmt" - "reflect" - "strings" - "sync" -) - -// MapSlice encodes and decodes as a YAML map. -// The order of keys is preserved when encoding and decoding. -type MapSlice []MapItem - -// MapItem is an item in a MapSlice. -type MapItem struct { - Key, Value interface{} -} - -// The Unmarshaler interface may be implemented by types to customize their -// behavior when being unmarshaled from a YAML document. The UnmarshalYAML -// method receives a function that may be called to unmarshal the original -// YAML value into a field or variable. It is safe to call the unmarshal -// function parameter more than once if necessary. -type Unmarshaler interface { - UnmarshalYAML(unmarshal func(interface{}) error) error -} - -// The Marshaler interface may be implemented by types to customize their -// behavior when being marshaled into a YAML document. The returned value -// is marshaled in place of the original value implementing Marshaler. -// -// If an error is returned by MarshalYAML, the marshaling procedure stops -// and returns with the provided error. -type Marshaler interface { - MarshalYAML() (interface{}, error) -} - -// Unmarshal decodes the first document found within the in byte slice -// and assigns decoded values into the out value. -// -// Maps and pointers (to a struct, string, int, etc) are accepted as out -// values. If an internal pointer within a struct is not initialized, -// the yaml package will initialize it if necessary for unmarshalling -// the provided data. The out parameter must not be nil. -// -// The type of the decoded values should be compatible with the respective -// values in out. If one or more values cannot be decoded due to a type -// mismatches, decoding continues partially until the end of the YAML -// content, and a *yaml.TypeError is returned with details for all -// missed values. -// -// Struct fields are only unmarshalled if they are exported (have an -// upper case first letter), and are unmarshalled using the field name -// lowercased as the default key. Custom keys may be defined via the -// "yaml" name in the field tag: the content preceding the first comma -// is used as the key, and the following comma-separated options are -// used to tweak the marshalling process (see Marshal). -// Conflicting names result in a runtime error. -// -// For example: -// -// type T struct { -// F int `yaml:"a,omitempty"` -// B int -// } -// var t T -// yaml.Unmarshal([]byte("a: 1\nb: 2"), &t) -// -// See the documentation of Marshal for the format of tags and a list of -// supported tag options. -// -func Unmarshal(in []byte, out interface{}) (err error) { - defer handleErr(&err) - d := newDecoder() - p := newParser(in) - defer p.destroy() - node := p.parse() - if node != nil { - v := reflect.ValueOf(out) - if v.Kind() == reflect.Ptr && !v.IsNil() { - v = v.Elem() - } - d.unmarshal(node, v) - } - if len(d.terrors) > 0 { - return &TypeError{d.terrors} - } - return nil -} - -// Marshal serializes the value provided into a YAML document. The structure -// of the generated document will reflect the structure of the value itself. -// Maps and pointers (to struct, string, int, etc) are accepted as the in value. -// -// Struct fields are only unmarshalled if they are exported (have an upper case -// first letter), and are unmarshalled using the field name lowercased as the -// default key. Custom keys may be defined via the "yaml" name in the field -// tag: the content preceding the first comma is used as the key, and the -// following comma-separated options are used to tweak the marshalling process. -// Conflicting names result in a runtime error. -// -// The field tag format accepted is: -// -// `(...) yaml:"[<key>][,<flag1>[,<flag2>]]" (...)` -// -// The following flags are currently supported: -// -// omitempty Only include the field if it's not set to the zero -// value for the type or to empty slices or maps. -// Does not apply to zero valued structs. -// -// flow Marshal using a flow style (useful for structs, -// sequences and maps). -// -// inline Inline the field, which must be a struct or a map, -// causing all of its fields or keys to be processed as if -// they were part of the outer struct. For maps, keys must -// not conflict with the yaml keys of other struct fields. -// -// In addition, if the key is "-", the field is ignored. -// -// For example: -// -// type T struct { -// F int "a,omitempty" -// B int -// } -// yaml.Marshal(&T{B: 2}) // Returns "b: 2\n" -// yaml.Marshal(&T{F: 1}} // Returns "a: 1\nb: 0\n" -// -func Marshal(in interface{}) (out []byte, err error) { - defer handleErr(&err) - e := newEncoder() - defer e.destroy() - e.marshal("", reflect.ValueOf(in)) - e.finish() - out = e.out - return -} - -func handleErr(err *error) { - if v := recover(); v != nil { - if e, ok := v.(yamlError); ok { - *err = e.err - } else { - panic(v) - } - } -} - -type yamlError struct { - err error -} - -func fail(err error) { - panic(yamlError{err}) -} - -func failf(format string, args ...interface{}) { - panic(yamlError{fmt.Errorf("yaml: "+format, args...)}) -} - -// A TypeError is returned by Unmarshal when one or more fields in -// the YAML document cannot be properly decoded into the requested -// types. When this error is returned, the value is still -// unmarshaled partially. -type TypeError struct { - Errors []string -} - -func (e *TypeError) Error() string { - return fmt.Sprintf("yaml: unmarshal errors:\n %s", strings.Join(e.Errors, "\n ")) -} - -// -------------------------------------------------------------------------- -// Maintain a mapping of keys to structure field indexes - -// The code in this section was copied from mgo/bson. - -// structInfo holds details for the serialization of fields of -// a given struct. -type structInfo struct { - FieldsMap map[string]fieldInfo - FieldsList []fieldInfo - - // InlineMap is the number of the field in the struct that - // contains an ,inline map, or -1 if there's none. - InlineMap int -} - -type fieldInfo struct { - Key string - Num int - OmitEmpty bool - Flow bool - - // Inline holds the field index if the field is part of an inlined struct. - Inline []int -} - -var structMap = make(map[reflect.Type]*structInfo) -var fieldMapMutex sync.RWMutex - -func getStructInfo(st reflect.Type) (*structInfo, error) { - fieldMapMutex.RLock() - sinfo, found := structMap[st] - fieldMapMutex.RUnlock() - if found { - return sinfo, nil - } - - n := st.NumField() - fieldsMap := make(map[string]fieldInfo) - fieldsList := make([]fieldInfo, 0, n) - inlineMap := -1 - for i := 0; i != n; i++ { - field := st.Field(i) - if field.PkgPath != "" { - continue // Private field - } - - info := fieldInfo{Num: i} - - tag := field.Tag.Get("yaml") - if tag == "" && strings.Index(string(field.Tag), ":") < 0 { - tag = string(field.Tag) - } - if tag == "-" { - continue - } - - inline := false - fields := strings.Split(tag, ",") - if len(fields) > 1 { - for _, flag := range fields[1:] { - switch flag { - case "omitempty": - info.OmitEmpty = true - case "flow": - info.Flow = true - case "inline": - inline = true - default: - return nil, errors.New(fmt.Sprintf("Unsupported flag %q in tag %q of type %s", flag, tag, st)) - } - } - tag = fields[0] - } - - if inline { - switch field.Type.Kind() { - case reflect.Map: - if inlineMap >= 0 { - return nil, errors.New("Multiple ,inline maps in struct " + st.String()) - } - if field.Type.Key() != reflect.TypeOf("") { - return nil, errors.New("Option ,inline needs a map with string keys in struct " + st.String()) - } - inlineMap = info.Num - case reflect.Struct: - sinfo, err := getStructInfo(field.Type) - if err != nil { - return nil, err - } - for _, finfo := range sinfo.FieldsList { - if _, found := fieldsMap[finfo.Key]; found { - msg := "Duplicated key '" + finfo.Key + "' in struct " + st.String() - return nil, errors.New(msg) - } - if finfo.Inline == nil { - finfo.Inline = []int{i, finfo.Num} - } else { - finfo.Inline = append([]int{i}, finfo.Inline...) - } - fieldsMap[finfo.Key] = finfo - fieldsList = append(fieldsList, finfo) - } - default: - //return nil, errors.New("Option ,inline needs a struct value or map field") - return nil, errors.New("Option ,inline needs a struct value field") - } - continue - } - - if tag != "" { - info.Key = tag - } else { - info.Key = strings.ToLower(field.Name) - } - - if _, found = fieldsMap[info.Key]; found { - msg := "Duplicated key '" + info.Key + "' in struct " + st.String() - return nil, errors.New(msg) - } - - fieldsList = append(fieldsList, info) - fieldsMap[info.Key] = info - } - - sinfo = &structInfo{fieldsMap, fieldsList, inlineMap} - - fieldMapMutex.Lock() - structMap[st] = sinfo - fieldMapMutex.Unlock() - return sinfo, nil -} - -func isZero(v reflect.Value) bool { - switch v.Kind() { - case reflect.String: - return len(v.String()) == 0 - case reflect.Interface, reflect.Ptr: - return v.IsNil() - case reflect.Slice: - return v.Len() == 0 - case reflect.Map: - return v.Len() == 0 - case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64: - return v.Int() == 0 - case reflect.Float32, reflect.Float64: - return v.Float() == 0 - case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr: - return v.Uint() == 0 - case reflect.Bool: - return !v.Bool() - case reflect.Struct: - vt := v.Type() - for i := v.NumField() - 1; i >= 0; i-- { - if vt.Field(i).PkgPath != "" { - continue // Private field - } - if !isZero(v.Field(i)) { - return false - } - } - return true - } - return false -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlh.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlh.go deleted file mode 100644 index d60a6b6..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlh.go +++ /dev/null @@ -1,716 +0,0 @@ -package yaml - -import ( - "io" -) - -// The version directive data. -type yaml_version_directive_t struct { - major int8 // The major version number. - minor int8 // The minor version number. -} - -// The tag directive data. -type yaml_tag_directive_t struct { - handle []byte // The tag handle. - prefix []byte // The tag prefix. -} - -type yaml_encoding_t int - -// The stream encoding. -const ( - // Let the parser choose the encoding. - yaml_ANY_ENCODING yaml_encoding_t = iota - - yaml_UTF8_ENCODING // The default UTF-8 encoding. - yaml_UTF16LE_ENCODING // The UTF-16-LE encoding with BOM. - yaml_UTF16BE_ENCODING // The UTF-16-BE encoding with BOM. -) - -type yaml_break_t int - -// Line break types. -const ( - // Let the parser choose the break type. - yaml_ANY_BREAK yaml_break_t = iota - - yaml_CR_BREAK // Use CR for line breaks (Mac style). - yaml_LN_BREAK // Use LN for line breaks (Unix style). - yaml_CRLN_BREAK // Use CR LN for line breaks (DOS style). -) - -type yaml_error_type_t int - -// Many bad things could happen with the parser and emitter. -const ( - // No error is produced. - yaml_NO_ERROR yaml_error_type_t = iota - - yaml_MEMORY_ERROR // Cannot allocate or reallocate a block of memory. - yaml_READER_ERROR // Cannot read or decode the input stream. - yaml_SCANNER_ERROR // Cannot scan the input stream. - yaml_PARSER_ERROR // Cannot parse the input stream. - yaml_COMPOSER_ERROR // Cannot compose a YAML document. - yaml_WRITER_ERROR // Cannot write to the output stream. - yaml_EMITTER_ERROR // Cannot emit a YAML stream. -) - -// The pointer position. -type yaml_mark_t struct { - index int // The position index. - line int // The position line. - column int // The position column. -} - -// Node Styles - -type yaml_style_t int8 - -type yaml_scalar_style_t yaml_style_t - -// Scalar styles. -const ( - // Let the emitter choose the style. - yaml_ANY_SCALAR_STYLE yaml_scalar_style_t = iota - - yaml_PLAIN_SCALAR_STYLE // The plain scalar style. - yaml_SINGLE_QUOTED_SCALAR_STYLE // The single-quoted scalar style. - yaml_DOUBLE_QUOTED_SCALAR_STYLE // The double-quoted scalar style. - yaml_LITERAL_SCALAR_STYLE // The literal scalar style. - yaml_FOLDED_SCALAR_STYLE // The folded scalar style. -) - -type yaml_sequence_style_t yaml_style_t - -// Sequence styles. -const ( - // Let the emitter choose the style. - yaml_ANY_SEQUENCE_STYLE yaml_sequence_style_t = iota - - yaml_BLOCK_SEQUENCE_STYLE // The block sequence style. - yaml_FLOW_SEQUENCE_STYLE // The flow sequence style. -) - -type yaml_mapping_style_t yaml_style_t - -// Mapping styles. -const ( - // Let the emitter choose the style. - yaml_ANY_MAPPING_STYLE yaml_mapping_style_t = iota - - yaml_BLOCK_MAPPING_STYLE // The block mapping style. - yaml_FLOW_MAPPING_STYLE // The flow mapping style. -) - -// Tokens - -type yaml_token_type_t int - -// Token types. -const ( - // An empty token. - yaml_NO_TOKEN yaml_token_type_t = iota - - yaml_STREAM_START_TOKEN // A STREAM-START token. - yaml_STREAM_END_TOKEN // A STREAM-END token. - - yaml_VERSION_DIRECTIVE_TOKEN // A VERSION-DIRECTIVE token. - yaml_TAG_DIRECTIVE_TOKEN // A TAG-DIRECTIVE token. - yaml_DOCUMENT_START_TOKEN // A DOCUMENT-START token. - yaml_DOCUMENT_END_TOKEN // A DOCUMENT-END token. - - yaml_BLOCK_SEQUENCE_START_TOKEN // A BLOCK-SEQUENCE-START token. - yaml_BLOCK_MAPPING_START_TOKEN // A BLOCK-SEQUENCE-END token. - yaml_BLOCK_END_TOKEN // A BLOCK-END token. - - yaml_FLOW_SEQUENCE_START_TOKEN // A FLOW-SEQUENCE-START token. - yaml_FLOW_SEQUENCE_END_TOKEN // A FLOW-SEQUENCE-END token. - yaml_FLOW_MAPPING_START_TOKEN // A FLOW-MAPPING-START token. - yaml_FLOW_MAPPING_END_TOKEN // A FLOW-MAPPING-END token. - - yaml_BLOCK_ENTRY_TOKEN // A BLOCK-ENTRY token. - yaml_FLOW_ENTRY_TOKEN // A FLOW-ENTRY token. - yaml_KEY_TOKEN // A KEY token. - yaml_VALUE_TOKEN // A VALUE token. - - yaml_ALIAS_TOKEN // An ALIAS token. - yaml_ANCHOR_TOKEN // An ANCHOR token. - yaml_TAG_TOKEN // A TAG token. - yaml_SCALAR_TOKEN // A SCALAR token. -) - -func (tt yaml_token_type_t) String() string { - switch tt { - case yaml_NO_TOKEN: - return "yaml_NO_TOKEN" - case yaml_STREAM_START_TOKEN: - return "yaml_STREAM_START_TOKEN" - case yaml_STREAM_END_TOKEN: - return "yaml_STREAM_END_TOKEN" - case yaml_VERSION_DIRECTIVE_TOKEN: - return "yaml_VERSION_DIRECTIVE_TOKEN" - case yaml_TAG_DIRECTIVE_TOKEN: - return "yaml_TAG_DIRECTIVE_TOKEN" - case yaml_DOCUMENT_START_TOKEN: - return "yaml_DOCUMENT_START_TOKEN" - case yaml_DOCUMENT_END_TOKEN: - return "yaml_DOCUMENT_END_TOKEN" - case yaml_BLOCK_SEQUENCE_START_TOKEN: - return "yaml_BLOCK_SEQUENCE_START_TOKEN" - case yaml_BLOCK_MAPPING_START_TOKEN: - return "yaml_BLOCK_MAPPING_START_TOKEN" - case yaml_BLOCK_END_TOKEN: - return "yaml_BLOCK_END_TOKEN" - case yaml_FLOW_SEQUENCE_START_TOKEN: - return "yaml_FLOW_SEQUENCE_START_TOKEN" - case yaml_FLOW_SEQUENCE_END_TOKEN: - return "yaml_FLOW_SEQUENCE_END_TOKEN" - case yaml_FLOW_MAPPING_START_TOKEN: - return "yaml_FLOW_MAPPING_START_TOKEN" - case yaml_FLOW_MAPPING_END_TOKEN: - return "yaml_FLOW_MAPPING_END_TOKEN" - case yaml_BLOCK_ENTRY_TOKEN: - return "yaml_BLOCK_ENTRY_TOKEN" - case yaml_FLOW_ENTRY_TOKEN: - return "yaml_FLOW_ENTRY_TOKEN" - case yaml_KEY_TOKEN: - return "yaml_KEY_TOKEN" - case yaml_VALUE_TOKEN: - return "yaml_VALUE_TOKEN" - case yaml_ALIAS_TOKEN: - return "yaml_ALIAS_TOKEN" - case yaml_ANCHOR_TOKEN: - return "yaml_ANCHOR_TOKEN" - case yaml_TAG_TOKEN: - return "yaml_TAG_TOKEN" - case yaml_SCALAR_TOKEN: - return "yaml_SCALAR_TOKEN" - } - return "<unknown token>" -} - -// The token structure. -type yaml_token_t struct { - // The token type. - typ yaml_token_type_t - - // The start/end of the token. - start_mark, end_mark yaml_mark_t - - // The stream encoding (for yaml_STREAM_START_TOKEN). - encoding yaml_encoding_t - - // The alias/anchor/scalar value or tag/tag directive handle - // (for yaml_ALIAS_TOKEN, yaml_ANCHOR_TOKEN, yaml_SCALAR_TOKEN, yaml_TAG_TOKEN, yaml_TAG_DIRECTIVE_TOKEN). - value []byte - - // The tag suffix (for yaml_TAG_TOKEN). - suffix []byte - - // The tag directive prefix (for yaml_TAG_DIRECTIVE_TOKEN). - prefix []byte - - // The scalar style (for yaml_SCALAR_TOKEN). - style yaml_scalar_style_t - - // The version directive major/minor (for yaml_VERSION_DIRECTIVE_TOKEN). - major, minor int8 -} - -// Events - -type yaml_event_type_t int8 - -// Event types. -const ( - // An empty event. - yaml_NO_EVENT yaml_event_type_t = iota - - yaml_STREAM_START_EVENT // A STREAM-START event. - yaml_STREAM_END_EVENT // A STREAM-END event. - yaml_DOCUMENT_START_EVENT // A DOCUMENT-START event. - yaml_DOCUMENT_END_EVENT // A DOCUMENT-END event. - yaml_ALIAS_EVENT // An ALIAS event. - yaml_SCALAR_EVENT // A SCALAR event. - yaml_SEQUENCE_START_EVENT // A SEQUENCE-START event. - yaml_SEQUENCE_END_EVENT // A SEQUENCE-END event. - yaml_MAPPING_START_EVENT // A MAPPING-START event. - yaml_MAPPING_END_EVENT // A MAPPING-END event. -) - -// The event structure. -type yaml_event_t struct { - - // The event type. - typ yaml_event_type_t - - // The start and end of the event. - start_mark, end_mark yaml_mark_t - - // The document encoding (for yaml_STREAM_START_EVENT). - encoding yaml_encoding_t - - // The version directive (for yaml_DOCUMENT_START_EVENT). - version_directive *yaml_version_directive_t - - // The list of tag directives (for yaml_DOCUMENT_START_EVENT). - tag_directives []yaml_tag_directive_t - - // The anchor (for yaml_SCALAR_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT, yaml_ALIAS_EVENT). - anchor []byte - - // The tag (for yaml_SCALAR_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). - tag []byte - - // The scalar value (for yaml_SCALAR_EVENT). - value []byte - - // Is the document start/end indicator implicit, or the tag optional? - // (for yaml_DOCUMENT_START_EVENT, yaml_DOCUMENT_END_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT, yaml_SCALAR_EVENT). - implicit bool - - // Is the tag optional for any non-plain style? (for yaml_SCALAR_EVENT). - quoted_implicit bool - - // The style (for yaml_SCALAR_EVENT, yaml_SEQUENCE_START_EVENT, yaml_MAPPING_START_EVENT). - style yaml_style_t -} - -func (e *yaml_event_t) scalar_style() yaml_scalar_style_t { return yaml_scalar_style_t(e.style) } -func (e *yaml_event_t) sequence_style() yaml_sequence_style_t { return yaml_sequence_style_t(e.style) } -func (e *yaml_event_t) mapping_style() yaml_mapping_style_t { return yaml_mapping_style_t(e.style) } - -// Nodes - -const ( - yaml_NULL_TAG = "tag:yaml.org,2002:null" // The tag !!null with the only possible value: null. - yaml_BOOL_TAG = "tag:yaml.org,2002:bool" // The tag !!bool with the values: true and false. - yaml_STR_TAG = "tag:yaml.org,2002:str" // The tag !!str for string values. - yaml_INT_TAG = "tag:yaml.org,2002:int" // The tag !!int for integer values. - yaml_FLOAT_TAG = "tag:yaml.org,2002:float" // The tag !!float for float values. - yaml_TIMESTAMP_TAG = "tag:yaml.org,2002:timestamp" // The tag !!timestamp for date and time values. - - yaml_SEQ_TAG = "tag:yaml.org,2002:seq" // The tag !!seq is used to denote sequences. - yaml_MAP_TAG = "tag:yaml.org,2002:map" // The tag !!map is used to denote mapping. - - // Not in original libyaml. - yaml_BINARY_TAG = "tag:yaml.org,2002:binary" - yaml_MERGE_TAG = "tag:yaml.org,2002:merge" - - yaml_DEFAULT_SCALAR_TAG = yaml_STR_TAG // The default scalar tag is !!str. - yaml_DEFAULT_SEQUENCE_TAG = yaml_SEQ_TAG // The default sequence tag is !!seq. - yaml_DEFAULT_MAPPING_TAG = yaml_MAP_TAG // The default mapping tag is !!map. -) - -type yaml_node_type_t int - -// Node types. -const ( - // An empty node. - yaml_NO_NODE yaml_node_type_t = iota - - yaml_SCALAR_NODE // A scalar node. - yaml_SEQUENCE_NODE // A sequence node. - yaml_MAPPING_NODE // A mapping node. -) - -// An element of a sequence node. -type yaml_node_item_t int - -// An element of a mapping node. -type yaml_node_pair_t struct { - key int // The key of the element. - value int // The value of the element. -} - -// The node structure. -type yaml_node_t struct { - typ yaml_node_type_t // The node type. - tag []byte // The node tag. - - // The node data. - - // The scalar parameters (for yaml_SCALAR_NODE). - scalar struct { - value []byte // The scalar value. - length int // The length of the scalar value. - style yaml_scalar_style_t // The scalar style. - } - - // The sequence parameters (for YAML_SEQUENCE_NODE). - sequence struct { - items_data []yaml_node_item_t // The stack of sequence items. - style yaml_sequence_style_t // The sequence style. - } - - // The mapping parameters (for yaml_MAPPING_NODE). - mapping struct { - pairs_data []yaml_node_pair_t // The stack of mapping pairs (key, value). - pairs_start *yaml_node_pair_t // The beginning of the stack. - pairs_end *yaml_node_pair_t // The end of the stack. - pairs_top *yaml_node_pair_t // The top of the stack. - style yaml_mapping_style_t // The mapping style. - } - - start_mark yaml_mark_t // The beginning of the node. - end_mark yaml_mark_t // The end of the node. - -} - -// The document structure. -type yaml_document_t struct { - - // The document nodes. - nodes []yaml_node_t - - // The version directive. - version_directive *yaml_version_directive_t - - // The list of tag directives. - tag_directives_data []yaml_tag_directive_t - tag_directives_start int // The beginning of the tag directives list. - tag_directives_end int // The end of the tag directives list. - - start_implicit int // Is the document start indicator implicit? - end_implicit int // Is the document end indicator implicit? - - // The start/end of the document. - start_mark, end_mark yaml_mark_t -} - -// The prototype of a read handler. -// -// The read handler is called when the parser needs to read more bytes from the -// source. The handler should write not more than size bytes to the buffer. -// The number of written bytes should be set to the size_read variable. -// -// [in,out] data A pointer to an application data specified by -// yaml_parser_set_input(). -// [out] buffer The buffer to write the data from the source. -// [in] size The size of the buffer. -// [out] size_read The actual number of bytes read from the source. -// -// On success, the handler should return 1. If the handler failed, -// the returned value should be 0. On EOF, the handler should set the -// size_read to 0 and return 1. -type yaml_read_handler_t func(parser *yaml_parser_t, buffer []byte) (n int, err error) - -// This structure holds information about a potential simple key. -type yaml_simple_key_t struct { - possible bool // Is a simple key possible? - required bool // Is a simple key required? - token_number int // The number of the token. - mark yaml_mark_t // The position mark. -} - -// The states of the parser. -type yaml_parser_state_t int - -const ( - yaml_PARSE_STREAM_START_STATE yaml_parser_state_t = iota - - yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE // Expect the beginning of an implicit document. - yaml_PARSE_DOCUMENT_START_STATE // Expect DOCUMENT-START. - yaml_PARSE_DOCUMENT_CONTENT_STATE // Expect the content of a document. - yaml_PARSE_DOCUMENT_END_STATE // Expect DOCUMENT-END. - yaml_PARSE_BLOCK_NODE_STATE // Expect a block node. - yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE // Expect a block node or indentless sequence. - yaml_PARSE_FLOW_NODE_STATE // Expect a flow node. - yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE // Expect the first entry of a block sequence. - yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE // Expect an entry of a block sequence. - yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE // Expect an entry of an indentless sequence. - yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE // Expect the first key of a block mapping. - yaml_PARSE_BLOCK_MAPPING_KEY_STATE // Expect a block mapping key. - yaml_PARSE_BLOCK_MAPPING_VALUE_STATE // Expect a block mapping value. - yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE // Expect the first entry of a flow sequence. - yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE // Expect an entry of a flow sequence. - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE // Expect a key of an ordered mapping. - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE // Expect a value of an ordered mapping. - yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE // Expect the and of an ordered mapping entry. - yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE // Expect the first key of a flow mapping. - yaml_PARSE_FLOW_MAPPING_KEY_STATE // Expect a key of a flow mapping. - yaml_PARSE_FLOW_MAPPING_VALUE_STATE // Expect a value of a flow mapping. - yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE // Expect an empty value of a flow mapping. - yaml_PARSE_END_STATE // Expect nothing. -) - -func (ps yaml_parser_state_t) String() string { - switch ps { - case yaml_PARSE_STREAM_START_STATE: - return "yaml_PARSE_STREAM_START_STATE" - case yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE: - return "yaml_PARSE_IMPLICIT_DOCUMENT_START_STATE" - case yaml_PARSE_DOCUMENT_START_STATE: - return "yaml_PARSE_DOCUMENT_START_STATE" - case yaml_PARSE_DOCUMENT_CONTENT_STATE: - return "yaml_PARSE_DOCUMENT_CONTENT_STATE" - case yaml_PARSE_DOCUMENT_END_STATE: - return "yaml_PARSE_DOCUMENT_END_STATE" - case yaml_PARSE_BLOCK_NODE_STATE: - return "yaml_PARSE_BLOCK_NODE_STATE" - case yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE: - return "yaml_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE" - case yaml_PARSE_FLOW_NODE_STATE: - return "yaml_PARSE_FLOW_NODE_STATE" - case yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE: - return "yaml_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE" - case yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE: - return "yaml_PARSE_BLOCK_SEQUENCE_ENTRY_STATE" - case yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE: - return "yaml_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE" - case yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE: - return "yaml_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE" - case yaml_PARSE_BLOCK_MAPPING_KEY_STATE: - return "yaml_PARSE_BLOCK_MAPPING_KEY_STATE" - case yaml_PARSE_BLOCK_MAPPING_VALUE_STATE: - return "yaml_PARSE_BLOCK_MAPPING_VALUE_STATE" - case yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE: - return "yaml_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE" - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE: - return "yaml_PARSE_FLOW_SEQUENCE_ENTRY_STATE" - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE: - return "yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE" - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE: - return "yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE" - case yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE: - return "yaml_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE" - case yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE: - return "yaml_PARSE_FLOW_MAPPING_FIRST_KEY_STATE" - case yaml_PARSE_FLOW_MAPPING_KEY_STATE: - return "yaml_PARSE_FLOW_MAPPING_KEY_STATE" - case yaml_PARSE_FLOW_MAPPING_VALUE_STATE: - return "yaml_PARSE_FLOW_MAPPING_VALUE_STATE" - case yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE: - return "yaml_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE" - case yaml_PARSE_END_STATE: - return "yaml_PARSE_END_STATE" - } - return "<unknown parser state>" -} - -// This structure holds aliases data. -type yaml_alias_data_t struct { - anchor []byte // The anchor. - index int // The node id. - mark yaml_mark_t // The anchor mark. -} - -// The parser structure. -// -// All members are internal. Manage the structure using the -// yaml_parser_ family of functions. -type yaml_parser_t struct { - - // Error handling - - error yaml_error_type_t // Error type. - - problem string // Error description. - - // The byte about which the problem occured. - problem_offset int - problem_value int - problem_mark yaml_mark_t - - // The error context. - context string - context_mark yaml_mark_t - - // Reader stuff - - read_handler yaml_read_handler_t // Read handler. - - input_file io.Reader // File input data. - input []byte // String input data. - input_pos int - - eof bool // EOF flag - - buffer []byte // The working buffer. - buffer_pos int // The current position of the buffer. - - unread int // The number of unread characters in the buffer. - - raw_buffer []byte // The raw buffer. - raw_buffer_pos int // The current position of the buffer. - - encoding yaml_encoding_t // The input encoding. - - offset int // The offset of the current position (in bytes). - mark yaml_mark_t // The mark of the current position. - - // Scanner stuff - - stream_start_produced bool // Have we started to scan the input stream? - stream_end_produced bool // Have we reached the end of the input stream? - - flow_level int // The number of unclosed '[' and '{' indicators. - - tokens []yaml_token_t // The tokens queue. - tokens_head int // The head of the tokens queue. - tokens_parsed int // The number of tokens fetched from the queue. - token_available bool // Does the tokens queue contain a token ready for dequeueing. - - indent int // The current indentation level. - indents []int // The indentation levels stack. - - simple_key_allowed bool // May a simple key occur at the current position? - simple_keys []yaml_simple_key_t // The stack of simple keys. - - // Parser stuff - - state yaml_parser_state_t // The current parser state. - states []yaml_parser_state_t // The parser states stack. - marks []yaml_mark_t // The stack of marks. - tag_directives []yaml_tag_directive_t // The list of TAG directives. - - // Dumper stuff - - aliases []yaml_alias_data_t // The alias data. - - document *yaml_document_t // The currently parsed document. -} - -// Emitter Definitions - -// The prototype of a write handler. -// -// The write handler is called when the emitter needs to flush the accumulated -// characters to the output. The handler should write @a size bytes of the -// @a buffer to the output. -// -// @param[in,out] data A pointer to an application data specified by -// yaml_emitter_set_output(). -// @param[in] buffer The buffer with bytes to be written. -// @param[in] size The size of the buffer. -// -// @returns On success, the handler should return @c 1. If the handler failed, -// the returned value should be @c 0. -// -type yaml_write_handler_t func(emitter *yaml_emitter_t, buffer []byte) error - -type yaml_emitter_state_t int - -// The emitter states. -const ( - // Expect STREAM-START. - yaml_EMIT_STREAM_START_STATE yaml_emitter_state_t = iota - - yaml_EMIT_FIRST_DOCUMENT_START_STATE // Expect the first DOCUMENT-START or STREAM-END. - yaml_EMIT_DOCUMENT_START_STATE // Expect DOCUMENT-START or STREAM-END. - yaml_EMIT_DOCUMENT_CONTENT_STATE // Expect the content of a document. - yaml_EMIT_DOCUMENT_END_STATE // Expect DOCUMENT-END. - yaml_EMIT_FLOW_SEQUENCE_FIRST_ITEM_STATE // Expect the first item of a flow sequence. - yaml_EMIT_FLOW_SEQUENCE_ITEM_STATE // Expect an item of a flow sequence. - yaml_EMIT_FLOW_MAPPING_FIRST_KEY_STATE // Expect the first key of a flow mapping. - yaml_EMIT_FLOW_MAPPING_KEY_STATE // Expect a key of a flow mapping. - yaml_EMIT_FLOW_MAPPING_SIMPLE_VALUE_STATE // Expect a value for a simple key of a flow mapping. - yaml_EMIT_FLOW_MAPPING_VALUE_STATE // Expect a value of a flow mapping. - yaml_EMIT_BLOCK_SEQUENCE_FIRST_ITEM_STATE // Expect the first item of a block sequence. - yaml_EMIT_BLOCK_SEQUENCE_ITEM_STATE // Expect an item of a block sequence. - yaml_EMIT_BLOCK_MAPPING_FIRST_KEY_STATE // Expect the first key of a block mapping. - yaml_EMIT_BLOCK_MAPPING_KEY_STATE // Expect the key of a block mapping. - yaml_EMIT_BLOCK_MAPPING_SIMPLE_VALUE_STATE // Expect a value for a simple key of a block mapping. - yaml_EMIT_BLOCK_MAPPING_VALUE_STATE // Expect a value of a block mapping. - yaml_EMIT_END_STATE // Expect nothing. -) - -// The emitter structure. -// -// All members are internal. Manage the structure using the @c yaml_emitter_ -// family of functions. -type yaml_emitter_t struct { - - // Error handling - - error yaml_error_type_t // Error type. - problem string // Error description. - - // Writer stuff - - write_handler yaml_write_handler_t // Write handler. - - output_buffer *[]byte // String output data. - output_file io.Writer // File output data. - - buffer []byte // The working buffer. - buffer_pos int // The current position of the buffer. - - raw_buffer []byte // The raw buffer. - raw_buffer_pos int // The current position of the buffer. - - encoding yaml_encoding_t // The stream encoding. - - // Emitter stuff - - canonical bool // If the output is in the canonical style? - best_indent int // The number of indentation spaces. - best_width int // The preferred width of the output lines. - unicode bool // Allow unescaped non-ASCII characters? - line_break yaml_break_t // The preferred line break. - - state yaml_emitter_state_t // The current emitter state. - states []yaml_emitter_state_t // The stack of states. - - events []yaml_event_t // The event queue. - events_head int // The head of the event queue. - - indents []int // The stack of indentation levels. - - tag_directives []yaml_tag_directive_t // The list of tag directives. - - indent int // The current indentation level. - - flow_level int // The current flow level. - - root_context bool // Is it the document root context? - sequence_context bool // Is it a sequence context? - mapping_context bool // Is it a mapping context? - simple_key_context bool // Is it a simple mapping key context? - - line int // The current line. - column int // The current column. - whitespace bool // If the last character was a whitespace? - indention bool // If the last character was an indentation character (' ', '-', '?', ':')? - open_ended bool // If an explicit document end is required? - - // Anchor analysis. - anchor_data struct { - anchor []byte // The anchor value. - alias bool // Is it an alias? - } - - // Tag analysis. - tag_data struct { - handle []byte // The tag handle. - suffix []byte // The tag suffix. - } - - // Scalar analysis. - scalar_data struct { - value []byte // The scalar value. - multiline bool // Does the scalar contain line breaks? - flow_plain_allowed bool // Can the scalar be expessed in the flow plain style? - block_plain_allowed bool // Can the scalar be expressed in the block plain style? - single_quoted_allowed bool // Can the scalar be expressed in the single quoted style? - block_allowed bool // Can the scalar be expressed in the literal or folded styles? - style yaml_scalar_style_t // The output style. - } - - // Dumper stuff - - opened bool // If the stream was already opened? - closed bool // If the stream was already closed? - - // The information associated with the document nodes. - anchors *struct { - references int // The number of references. - anchor int // The anchor id. - serialized bool // If the node has been emitted? - } - - last_anchor_id int // The last assigned anchor id. - - document *yaml_document_t // The currently emitted document. -} diff --git a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlprivateh.go b/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlprivateh.go deleted file mode 100644 index 8110ce3..0000000 --- a/vendor/k8s.io/kubernetes/vendor/gopkg.in/yaml.v2/yamlprivateh.go +++ /dev/null @@ -1,173 +0,0 @@ -package yaml - -const ( - // The size of the input raw buffer. - input_raw_buffer_size = 512 - - // The size of the input buffer. - // It should be possible to decode the whole raw buffer. - input_buffer_size = input_raw_buffer_size * 3 - - // The size of the output buffer. - output_buffer_size = 128 - - // The size of the output raw buffer. - // It should be possible to encode the whole output buffer. - output_raw_buffer_size = (output_buffer_size*2 + 2) - - // The size of other stacks and queues. - initial_stack_size = 16 - initial_queue_size = 16 - initial_string_size = 16 -) - -// Check if the character at the specified position is an alphabetical -// character, a digit, '_', or '-'. -func is_alpha(b []byte, i int) bool { - return b[i] >= '0' && b[i] <= '9' || b[i] >= 'A' && b[i] <= 'Z' || b[i] >= 'a' && b[i] <= 'z' || b[i] == '_' || b[i] == '-' -} - -// Check if the character at the specified position is a digit. -func is_digit(b []byte, i int) bool { - return b[i] >= '0' && b[i] <= '9' -} - -// Get the value of a digit. -func as_digit(b []byte, i int) int { - return int(b[i]) - '0' -} - -// Check if the character at the specified position is a hex-digit. -func is_hex(b []byte, i int) bool { - return b[i] >= '0' && b[i] <= '9' || b[i] >= 'A' && b[i] <= 'F' || b[i] >= 'a' && b[i] <= 'f' -} - -// Get the value of a hex-digit. -func as_hex(b []byte, i int) int { - bi := b[i] - if bi >= 'A' && bi <= 'F' { - return int(bi) - 'A' + 10 - } - if bi >= 'a' && bi <= 'f' { - return int(bi) - 'a' + 10 - } - return int(bi) - '0' -} - -// Check if the character is ASCII. -func is_ascii(b []byte, i int) bool { - return b[i] <= 0x7F -} - -// Check if the character at the start of the buffer can be printed unescaped. -func is_printable(b []byte, i int) bool { - return ((b[i] == 0x0A) || // . == #x0A - (b[i] >= 0x20 && b[i] <= 0x7E) || // #x20 <= . <= #x7E - (b[i] == 0xC2 && b[i+1] >= 0xA0) || // #0xA0 <= . <= #xD7FF - (b[i] > 0xC2 && b[i] < 0xED) || - (b[i] == 0xED && b[i+1] < 0xA0) || - (b[i] == 0xEE) || - (b[i] == 0xEF && // #xE000 <= . <= #xFFFD - !(b[i+1] == 0xBB && b[i+2] == 0xBF) && // && . != #xFEFF - !(b[i+1] == 0xBF && (b[i+2] == 0xBE || b[i+2] == 0xBF)))) -} - -// Check if the character at the specified position is NUL. -func is_z(b []byte, i int) bool { - return b[i] == 0x00 -} - -// Check if the beginning of the buffer is a BOM. -func is_bom(b []byte, i int) bool { - return b[0] == 0xEF && b[1] == 0xBB && b[2] == 0xBF -} - -// Check if the character at the specified position is space. -func is_space(b []byte, i int) bool { - return b[i] == ' ' -} - -// Check if the character at the specified position is tab. -func is_tab(b []byte, i int) bool { - return b[i] == '\t' -} - -// Check if the character at the specified position is blank (space or tab). -func is_blank(b []byte, i int) bool { - //return is_space(b, i) || is_tab(b, i) - return b[i] == ' ' || b[i] == '\t' -} - -// Check if the character at the specified position is a line break. -func is_break(b []byte, i int) bool { - return (b[i] == '\r' || // CR (#xD) - b[i] == '\n' || // LF (#xA) - b[i] == 0xC2 && b[i+1] == 0x85 || // NEL (#x85) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8 || // LS (#x2028) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9) // PS (#x2029) -} - -func is_crlf(b []byte, i int) bool { - return b[i] == '\r' && b[i+1] == '\n' -} - -// Check if the character is a line break or NUL. -func is_breakz(b []byte, i int) bool { - //return is_break(b, i) || is_z(b, i) - return ( // is_break: - b[i] == '\r' || // CR (#xD) - b[i] == '\n' || // LF (#xA) - b[i] == 0xC2 && b[i+1] == 0x85 || // NEL (#x85) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8 || // LS (#x2028) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9 || // PS (#x2029) - // is_z: - b[i] == 0) -} - -// Check if the character is a line break, space, or NUL. -func is_spacez(b []byte, i int) bool { - //return is_space(b, i) || is_breakz(b, i) - return ( // is_space: - b[i] == ' ' || - // is_breakz: - b[i] == '\r' || // CR (#xD) - b[i] == '\n' || // LF (#xA) - b[i] == 0xC2 && b[i+1] == 0x85 || // NEL (#x85) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8 || // LS (#x2028) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9 || // PS (#x2029) - b[i] == 0) -} - -// Check if the character is a line break, space, tab, or NUL. -func is_blankz(b []byte, i int) bool { - //return is_blank(b, i) || is_breakz(b, i) - return ( // is_blank: - b[i] == ' ' || b[i] == '\t' || - // is_breakz: - b[i] == '\r' || // CR (#xD) - b[i] == '\n' || // LF (#xA) - b[i] == 0xC2 && b[i+1] == 0x85 || // NEL (#x85) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8 || // LS (#x2028) - b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9 || // PS (#x2029) - b[i] == 0) -} - -// Determine the width of the character. -func width(b byte) int { - // Don't replace these by a switch without first - // confirming that it is being inlined. - if b&0x80 == 0x00 { - return 1 - } - if b&0xE0 == 0xC0 { - return 2 - } - if b&0xF0 == 0xE0 { - return 3 - } - if b&0xF8 == 0xF0 { - return 4 - } - return 0 - -}

    TQibCxaR*K(ImeNk|*_Q$1SfkHnJ#@dLJSCWQ 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

    &KUxX>k6eW(PYolTWMieK? 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

  • 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